summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--.gitattributes3
-rw-r--r--LICENSE28
-rw-r--r--Makefile.in22
-rw-r--r--Resource/Init/gs_cmap.ps55
-rw-r--r--Resource/Init/gs_epsf.ps5
-rw-r--r--Resource/Init/gs_init.ps6
-rw-r--r--Resource/Init/gs_lev2.ps29
-rw-r--r--Resource/Init/gs_ll3.ps4
-rw-r--r--Resource/Init/gs_pdfwr.ps10
-rw-r--r--Resource/Init/gs_res.ps4
-rw-r--r--Resource/Init/gs_setpd.ps2
-rw-r--r--Resource/Init/gs_statd.ps4
-rw-r--r--Resource/Init/gs_ttf.ps28
-rw-r--r--Resource/Init/pdf_draw.ps112
-rw-r--r--Resource/Init/pdf_font.ps25
-rw-r--r--Resource/Init/pdf_main.ps1543
-rw-r--r--Resource/Init/pdf_ops.ps32
-rw-r--r--arch/osx-x86-x86_64-ppc-gcc.h2
-rwxr-xr-xautogen.sh7
-rw-r--r--base/ets.c37
-rw-r--r--base/ets.h37
-rw-r--r--base/ets_tm.h37
-rw-r--r--base/fapi_ft.c4
-rw-r--r--base/gdbflags.h2
-rw-r--r--base/gdevabuf.c141
-rw-r--r--base/gdevbbox.c226
-rw-r--r--base/gdevdbit.c75
-rw-r--r--base/gdevddrw.c87
-rw-r--r--base/gdevdevn.c136
-rw-r--r--base/gdevdevn.h9
-rw-r--r--base/gdevdevnprn.h1
-rw-r--r--base/gdevdflt.c367
-rw-r--r--base/gdevdgbr.c355
-rw-r--r--base/gdevdrop.c171
-rw-r--r--base/gdevepo.c303
-rw-r--r--base/gdevepo.h4
-rw-r--r--base/gdevflp.c298
-rw-r--r--base/gdevhit.c68
-rw-r--r--base/gdevkrnlsclass.c2
-rw-r--r--base/gdevm1.c93
-rw-r--r--base/gdevm16.c18
-rw-r--r--base/gdevm2.c46
-rw-r--r--base/gdevm24.c41
-rw-r--r--base/gdevm32.c38
-rw-r--r--base/gdevm4.c45
-rw-r--r--base/gdevm40.c39
-rw-r--r--base/gdevm48.c39
-rw-r--r--base/gdevm56.c39
-rw-r--r--base/gdevm64.c39
-rw-r--r--base/gdevm8.c39
-rw-r--r--base/gdevmem.c157
-rw-r--r--base/gdevmem.h122
-rw-r--r--base/gdevmpla.c295
-rw-r--r--base/gdevmplt.c203
-rw-r--r--base/gdevmplt.h3
-rw-r--r--base/gdevmr1.c28
-rw-r--r--base/gdevmr2n.c41
-rw-r--r--base/gdevmr8n.c18
-rw-r--r--base/gdevmrun.c32
-rw-r--r--base/gdevmrun.h2
-rw-r--r--base/gdevmx.c2
-rw-r--r--base/gdevnfwd.c473
-rw-r--r--base/gdevnup.c423
-rw-r--r--base/gdevnup.h3
-rw-r--r--base/gdevoflt.c177
-rw-r--r--base/gdevp14.c1382
-rw-r--r--base/gdevp14.h2
-rw-r--r--base/gdevpipe.c22
-rw-r--r--base/gdevplnx.c183
-rw-r--r--base/gdevprn.c200
-rw-r--r--base/gdevprn.h208
-rw-r--r--base/gdevrops.c115
-rw-r--r--base/gdevsclass.c257
-rw-r--r--base/gdevsclass.h25
-rw-r--r--base/gdevvec.c12
-rw-r--r--base/gdevvec.h13
-rw-r--r--base/gp_mshdl.c11
-rw-r--r--base/gp_msprn.c10
-rw-r--r--base/gp_os2pr.c13
-rw-r--r--base/gp_unifs.c2
-rw-r--r--base/gp_unix.c6
-rw-r--r--base/gs.mak20
-rw-r--r--base/gsagl.c (renamed from devices/vector/gdevagl.c)2
-rw-r--r--base/gsagl.h (renamed from devices/vector/gdevagl.h)4
-rw-r--r--base/gsbitops.h2
-rw-r--r--base/gscdevn.c42
-rw-r--r--base/gscdevn.h10
-rw-r--r--base/gscms.h4
-rw-r--r--base/gscolor2.c4
-rw-r--r--base/gscolor3.c2
-rw-r--r--base/gscoord.c138
-rw-r--r--base/gscoord.h3
-rw-r--r--base/gscparam.c22
-rw-r--r--base/gscscie.c52
-rw-r--r--base/gscsepr.c12
-rw-r--r--base/gscspace.c76
-rw-r--r--base/gsdcolor.h2
-rw-r--r--base/gsdevice.c111
-rw-r--r--base/gsdparam.c42
-rw-r--r--base/gsdps1.c2
-rw-r--r--base/gsequivc.c10
-rw-r--r--base/gserrors.h5
-rw-r--r--base/gsfont.c7
-rw-r--r--base/gsfunc3.c3
-rw-r--r--base/gsfunc4.c29
-rw-r--r--base/gsgstate.c26
-rw-r--r--base/gsht.c133
-rw-r--r--base/gsht.h9
-rw-r--r--base/gsht1.c2
-rw-r--r--base/gshtscr.c1
-rw-r--r--base/gshtx.c1
-rw-r--r--base/gsicc.c46
-rw-r--r--base/gsicc_cache.c32
-rw-r--r--base/gsicc_cms.h2
-rw-r--r--base/gsicc_lcms2.c7
-rw-r--r--base/gsicc_lcms2mt.c25
-rw-r--r--base/gsicc_manage.c33
-rw-r--r--base/gsicc_manage.h6
-rw-r--r--base/gsicc_nocm.c24
-rw-r--r--base/gsicc_profilecache.c6
-rw-r--r--base/gsicc_replacecm.c26
-rw-r--r--base/gsimage.c70
-rw-r--r--base/gsiparam.h23
-rw-r--r--base/gslib.c47
-rw-r--r--base/gslibctx.c69
-rw-r--r--base/gsmchunk.c5
-rw-r--r--base/gsncdummy.c2
-rw-r--r--base/gsovrc.c462
-rw-r--r--base/gsovrc.h2
-rw-r--r--base/gspaint.c8
-rw-r--r--base/gsparam.c129
-rw-r--r--base/gsparam.h12
-rw-r--r--base/gsparamx.c2
-rw-r--r--base/gspcolor.c4
-rw-r--r--base/gsptype1.c6
-rw-r--r--base/gsptype2.c5
-rw-r--r--base/gsrefct.h2
-rw-r--r--base/gsstate.c34
-rw-r--r--base/gsstate.h4
-rw-r--r--base/gstext.c44
-rw-r--r--base/gstext.h3
-rw-r--r--base/gstiffio.c3
-rw-r--r--base/gstrans.c16
-rw-r--r--base/gstype42.c26
-rw-r--r--base/gxacpath.c88
-rw-r--r--base/gxalpha.h1
-rw-r--r--base/gxblend.c2
-rw-r--r--base/gxblend.h18
-rw-r--r--base/gxblend1.c116
-rw-r--r--base/gxccman.c30
-rw-r--r--base/gxchar.c8
-rw-r--r--base/gxcht.c73
-rw-r--r--base/gxcldev.h3
-rw-r--r--base/gxclimag.c8
-rw-r--r--base/gxclip.c200
-rw-r--r--base/gxclip.h2
-rw-r--r--base/gxclip2.c163
-rw-r--r--base/gxclipm.c162
-rw-r--r--base/gxclist.c157
-rw-r--r--base/gxclist.h3
-rw-r--r--base/gxclpage.c4
-rw-r--r--base/gxclpath.h2
-rw-r--r--base/gxclrast.c54
-rw-r--r--base/gxclread.c11
-rw-r--r--base/gxclrect.c28
-rw-r--r--base/gxclthrd.c14
-rw-r--r--base/gxclutil.c4
-rw-r--r--base/gxcmap.c404
-rw-r--r--base/gxcmap.h20
-rw-r--r--base/gxcspace.h23
-rw-r--r--base/gxdcolor.c44
-rw-r--r--base/gxdevcli.h339
-rw-r--r--base/gxdevice.h161
-rw-r--r--base/gxdevmem.h56
-rw-r--r--base/gxdevsop.h12
-rw-r--r--base/gxdhtserial.c2
-rw-r--r--base/gxdownscale.c235
-rw-r--r--base/gxfapi.c18
-rw-r--r--base/gxfapi.h2
-rw-r--r--base/gxfill.c2
-rw-r--r--base/gxgstate.h61
-rw-r--r--base/gxht.c20
-rw-r--r--base/gxht.h1
-rw-r--r--base/gxht_thresh.c23
-rw-r--r--base/gxicolor.c14
-rw-r--r--base/gxifast.c2
-rw-r--r--base/gximag3x.c2
-rw-r--r--base/gximage.c13
-rw-r--r--base/gximage1.c4
-rw-r--r--base/gximage3.c2
-rw-r--r--base/gximage4.c5
-rw-r--r--base/gximono.c16
-rw-r--r--base/gxiparam.h18
-rw-r--r--base/gxmclip.c7
-rw-r--r--base/gxoprect.c9
-rw-r--r--base/gxp1fill.c23
-rw-r--r--base/gxpath.h1
-rw-r--r--base/gxpath2.c7
-rw-r--r--base/gxpcmap.c170
-rw-r--r--base/gxsamplp.h1
-rw-r--r--base/gxshade.c5
-rw-r--r--base/gxshade.h1
-rw-r--r--base/gxshade1.c218
-rw-r--r--base/gxshade6.c6
-rw-r--r--base/gxtext.h7
-rw-r--r--base/gzht.h9
-rw-r--r--base/gzspotan.c74
-rw-r--r--base/lcups.mak2
-rw-r--r--base/leptonica.mak4
-rw-r--r--base/lib.mak126
-rw-r--r--base/memento.c226
-rw-r--r--base/msvclib.mak25
-rw-r--r--base/ocr.mak2
-rw-r--r--base/scfd.c27
-rw-r--r--base/scfe.c24
-rw-r--r--base/scfparam.c2
-rw-r--r--base/scfx.h8
-rw-r--r--base/scommon.h15
-rw-r--r--base/sdcparam.c4
-rw-r--r--base/sdeparam.c4
-rw-r--r--base/sjpx_openjpeg.c19
-rw-r--r--base/sjpx_openjpeg.h11
-rw-r--r--base/spngp.c3
-rw-r--r--base/stdint_.h2
-rw-r--r--base/stream.c76
-rw-r--r--base/stream.h22
-rw-r--r--base/tesseract.mak7
-rw-r--r--base/tessocr.cpp136
-rw-r--r--base/unix-dll.mak48
-rw-r--r--base/unix-end.mak33
-rw-r--r--base/unix-gcc.mak12
-rw-r--r--base/unixlink.mak21
-rw-r--r--base/version.mak4
-rwxr-xr-xconfigure580
-rw-r--r--configure.ac554
-rw-r--r--contrib/eplaser/gdevescv.c465
-rw-r--r--contrib/gdevadmp.c8
-rw-r--r--contrib/gdevbjc_.c79
-rw-r--r--contrib/gdevbjc_.h8
-rw-r--r--contrib/gdevcd8.c112
-rw-r--r--contrib/gdevdj9.c59
-rw-r--r--contrib/gdevgdi.c15
-rw-r--r--contrib/gdevhl12.c16
-rw-r--r--contrib/gdevln03.c24
-rw-r--r--contrib/gdevlx32.c20
-rw-r--r--contrib/gdevlx7.c19
-rw-r--r--contrib/gdevmd2k.c41
-rw-r--r--contrib/gdevop4w.c13
-rw-r--r--contrib/gdevxes.c13
-rw-r--r--contrib/japanese/gdev10v.c77
-rw-r--r--contrib/japanese/gdevalps.c15
-rw-r--r--contrib/japanese/gdevespg.c27
-rw-r--r--contrib/japanese/gdevfmlbp.c24
-rw-r--r--contrib/japanese/gdevfmpr.c2
-rw-r--r--contrib/japanese/gdevj100.c2
-rw-r--r--contrib/japanese/gdevlbp3.c4
-rw-r--r--contrib/japanese/gdevmjc.c125
-rw-r--r--contrib/japanese/gdevml6.c12
-rw-r--r--contrib/japanese/gdevnpdl.c15
-rw-r--r--contrib/japanese/gdevp201.c26
-rw-r--r--contrib/japanese/gdevrpdl.c14
-rw-r--r--contrib/lips4/gdevl4r.c65
-rw-r--r--contrib/lips4/gdevl4v.c230
-rw-r--r--contrib/lips4/gdevlprn.h8
-rw-r--r--contrib/opvp/gdevopvp.c266
-rw-r--r--contrib/pcl3/eprn/gdeveprn.h79
-rw-r--r--contrib/pcl3/src/gdevpcl3.c21
-rw-r--r--contrib/pcl3/src/pcl3opts.c1
-rw-r--r--cups/gdevcups.c185
-rw-r--r--demos/csharp/README.txt1
-rw-r--r--demos/csharp/api/ghostapi.cs29
-rw-r--r--demos/csharp/api/ghostmono.cs243
-rw-r--r--demos/csharp/api/ghostnet.cs281
-rw-r--r--demos/csharp/linux/gs_mono.sln17
-rw-r--r--demos/csharp/linux/gtk_viewer/Properties/AssemblyInfo.cs26
-rw-r--r--demos/csharp/linux/gtk_viewer/gtk-gui/generated.cs30
-rw-r--r--demos/csharp/linux/gtk_viewer/gtk-gui/gtk_viewer.src.gsOutput.cs10
-rw-r--r--demos/csharp/linux/gtk_viewer/gtk-gui/gui.stetic18
-rw-r--r--demos/csharp/linux/gtk_viewer/gtk_viewer.csproj73
-rw-r--r--demos/csharp/linux/gtk_viewer/gtk_viewer.sln17
-rwxr-xr-xdemos/csharp/linux/gtk_viewer/make.sh18
-rw-r--r--demos/csharp/linux/gtk_viewer/src/DocPage.cs19
-rw-r--r--demos/csharp/linux/gtk_viewer/src/MainRender.cs28
-rw-r--r--demos/csharp/linux/gtk_viewer/src/MainThumbRendering.cs27
-rw-r--r--demos/csharp/linux/gtk_viewer/src/MainWindow.cs32
-rw-r--r--demos/csharp/linux/gtk_viewer/src/MainZoom.cs17
-rw-r--r--demos/csharp/linux/gtk_viewer/src/Program.cs19
-rw-r--r--demos/csharp/linux/gtk_viewer/src/TempFile.cs19
-rw-r--r--demos/csharp/linux/gtk_viewer/src/gsOutput.cs19
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/App.xaml.cs21
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/DocPage.cs19
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/MainPrint.cs52
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/MainRender.cs27
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/MainThumbRendering.cs25
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/MainWindow.xaml20
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/MainWindow.xaml.cs45
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/MainZoom.cs17
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/PrintControl.xaml18
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/PrintControl.xaml.cs17
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/PrintStatus.xaml18
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/PrintStatus.xaml.cs27
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/TempFile.cs17
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/XPSprint.cs15
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/gsIO.cs17
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/gsOutput.xaml18
-rw-r--r--demos/csharp/windows/ghostnet_wpf_example/gsOutput.xaml.cs17
-rw-r--r--demos/java/README.txt8
-rw-r--r--demos/java/gsjava/Manifest.md2
-rw-r--r--demos/java/gsjava/README.txt94
-rw-r--r--demos/java/gsjava/build_darwin.sh62
-rw-r--r--demos/java/gsjava/build_linux.sh62
-rw-r--r--demos/java/gsjava/build_win32.bat101
-rw-r--r--demos/java/gsjava/src/com/artifex/gsjava/GSAPI.java33
-rw-r--r--demos/java/gsjava/src/com/artifex/gsjava/util/NativePointer.java24
-rw-r--r--demos/java/gsviewer/Manifest.md3
-rw-r--r--demos/java/gsviewer/README.txt70
-rw-r--r--demos/java/gsviewer/build_darwin.sh37
-rw-r--r--demos/java/gsviewer/build_linux.sh37
-rw-r--r--demos/java/gsviewer/build_win32.bat42
-rw-r--r--demos/java/gsviewer/install_darwin.sh11
-rw-r--r--demos/java/gsviewer/install_linux.sh7
-rw-r--r--demos/java/gsviewer/src/com/artifex/gsviewer/Document.java4
-rw-r--r--demos/java/gsviewer/src/com/artifex/gsviewer/Main.java1
-rw-r--r--demos/java/gsviewer/start_darwin.sh5
-rw-r--r--demos/java/gsviewer/start_linux.sh5
-rw-r--r--demos/java/jni/gs_jni/README.txt112
-rw-r--r--demos/java/jni/gs_jni/build_darwin.sh57
-rw-r--r--demos/java/jni/gs_jni/build_linux.sh57
-rw-r--r--demos/java/jni/gs_jni/callbacks.cpp15
-rw-r--r--demos/java/jni/gs_jni/com_artifex_gsjava_GSAPI.cpp5
-rw-r--r--demos/java/jni/gs_jni/com_artifex_gsjava_util_NativePointer.cpp2
-rw-r--r--demos/java/jni/gs_jni/gs_jni.vcxproj8
-rw-r--r--demos/java/jni/gs_jni/include/classfile_constants.h560
-rw-r--r--demos/java/jni/gs_jni/include/jawt.h299
-rw-r--r--demos/java/jni/gs_jni/include/jdwpTransport.h259
-rw-r--r--demos/java/jni/gs_jni/include/jni.h1964
-rw-r--r--demos/java/jni/gs_jni/include/jvmti.h2533
-rw-r--r--demos/java/jni/gs_jni/include/jvmticmlr.h115
-rw-r--r--demos/java/jni/gs_jni/include/win32/bridge/AccessBridgeCallbacks.h96
-rw-r--r--demos/java/jni/gs_jni/include/win32/bridge/AccessBridgeCalls.c1131
-rw-r--r--demos/java/jni/gs_jni/include/win32/bridge/AccessBridgeCalls.h706
-rw-r--r--demos/java/jni/gs_jni/include/win32/bridge/AccessBridgePackages.h2215
-rw-r--r--demos/java/jni/gs_jni/include/win32/jawt_md.h59
-rw-r--r--demos/java/jni/gs_jni/include/win32/jni_md.h37
-rw-r--r--demos/java/jni/gs_jni/install_linux.sh7
-rw-r--r--demos/java/jni/gs_jni/jni_util.cpp7
-rwxr-xr-xdemos/python/gsapi.py136
-rw-r--r--devices/devs.mak36
-rw-r--r--devices/extract.mak53
-rw-r--r--devices/gdev3852.c17
-rw-r--r--devices/gdev4081.c3
-rw-r--r--devices/gdev4693.c18
-rw-r--r--devices/gdev8510.c3
-rw-r--r--devices/gdevatx.c3
-rw-r--r--devices/gdevbit.c250
-rw-r--r--devices/gdevbj10.c22
-rw-r--r--devices/gdevbmp.c102
-rw-r--r--devices/gdevccr.c22
-rw-r--r--devices/gdevcdj.c371
-rw-r--r--devices/gdevcfax.c15
-rw-r--r--devices/gdevchameleon.c86
-rw-r--r--devices/gdevcif.c3
-rw-r--r--devices/gdevclj.c65
-rw-r--r--devices/gdevcljc.c11
-rw-r--r--devices/gdevcmykog.c88
-rw-r--r--devices/gdevcslw.c6
-rw-r--r--devices/gdevdfax.c14
-rw-r--r--devices/gdevdjet.c54
-rw-r--r--devices/gdevdjtc.c15
-rw-r--r--devices/gdevdm24.c6
-rw-r--r--devices/gdevdsp.c157
-rw-r--r--devices/gdevepsc.c16
-rw-r--r--devices/gdevepsn.c48
-rw-r--r--devices/gdevescp.c6
-rw-r--r--devices/gdevfax.c14
-rw-r--r--devices/gdevfax.h1
-rw-r--r--devices/gdevfpng.c84
-rw-r--r--devices/gdevhl7x.c13
-rw-r--r--devices/gdevicov.c30
-rw-r--r--devices/gdevifno.c20
-rw-r--r--devices/gdevijs.c79
-rw-r--r--devices/gdevimgn.c12
-rw-r--r--devices/gdevjpeg.c123
-rw-r--r--devices/gdevl31s.c12
-rw-r--r--devices/gdevlbp8.c6
-rw-r--r--devices/gdevlj56.c28
-rw-r--r--devices/gdevlp8k.c3
-rw-r--r--devices/gdevlxm.c13
-rw-r--r--devices/gdevmeds.c60
-rw-r--r--devices/gdevmgr.c76
-rw-r--r--devices/gdevmiff.c11
-rw-r--r--devices/gdevn533.c13
-rw-r--r--devices/gdevo182.c3
-rw-r--r--devices/gdevocr.c38
-rw-r--r--devices/gdevokii.c3
-rw-r--r--devices/gdevpbm.c189
-rw-r--r--devices/gdevpcx.c125
-rw-r--r--devices/gdevpdfimg.c192
-rw-r--r--devices/gdevpdfimg.h10
-rw-r--r--devices/gdevpdfocr.c66
-rw-r--r--devices/gdevpe.c23
-rw-r--r--devices/gdevperm.c72
-rw-r--r--devices/gdevphex.c28
-rw-r--r--devices/gdevpjet.c29
-rw-r--r--devices/gdevplan.c174
-rw-r--r--devices/gdevplib.c164
-rw-r--r--devices/gdevpng.c221
-rw-r--r--devices/gdevpsd.c251
-rw-r--r--devices/gdevpsd.h1
-rw-r--r--devices/gdevrinkj.c98
-rw-r--r--devices/gdevsj48.c7
-rw-r--r--devices/gdevsnfb.c15
-rw-r--r--devices/gdevstc.c243
-rw-r--r--devices/gdevtfax.c21
-rw-r--r--devices/gdevtfnx.c37
-rw-r--r--devices/gdevtifs.c2
-rw-r--r--devices/gdevtknk.c15
-rw-r--r--devices/gdevtrac.c177
-rw-r--r--devices/gdevtsep.c908
-rw-r--r--devices/gdevupd.c60
-rw-r--r--devices/gdevwpr2.c25
-rw-r--r--devices/gdevx.c192
-rw-r--r--devices/gdevx.h15
-rw-r--r--devices/gdevxalt.c360
-rw-r--r--devices/gdevxcf.c123
-rw-r--r--devices/gdevxini.c52
-rw-r--r--devices/gxfcopy.c9
-rw-r--r--devices/rinkj/evenbetter-rll.c6
-rw-r--r--devices/vector/doc_common.c2
-rw-r--r--devices/vector/gdevdocxw.c130
-rw-r--r--devices/vector/gdevpdf.c67
-rw-r--r--devices/vector/gdevpdfb.h83
-rw-r--r--devices/vector/gdevpdfd.c161
-rw-r--r--devices/vector/gdevpdfg.c28
-rw-r--r--devices/vector/gdevpdfi.c258
-rw-r--r--devices/vector/gdevpdfj.c3
-rw-r--r--devices/vector/gdevpdfm.c29
-rw-r--r--devices/vector/gdevpdfp.c19
-rw-r--r--devices/vector/gdevpdft.c4
-rw-r--r--devices/vector/gdevpdfu.c2
-rw-r--r--devices/vector/gdevpdfv.c6
-rw-r--r--devices/vector/gdevpdfx.h11
-rw-r--r--devices/vector/gdevpdtb.c11
-rw-r--r--devices/vector/gdevpdtc.c9
-rw-r--r--devices/vector/gdevpdte.c24
-rw-r--r--devices/vector/gdevpdts.c46
-rw-r--r--devices/vector/gdevpdtt.c35
-rw-r--r--devices/vector/gdevpdtw.c3
-rw-r--r--devices/vector/gdevpsdf.h11
-rw-r--r--devices/vector/gdevpsdi.c8
-rw-r--r--devices/vector/gdevpsdp.c7
-rw-r--r--devices/vector/gdevpsdu.c17
-rw-r--r--devices/vector/gdevpx.c151
-rw-r--r--devices/vector/gdevtxtw.c149
-rw-r--r--devices/vector/gdevxps.c128
-rw-r--r--doc/API.htm2
-rw-r--r--doc/C-style.htm2
-rw-r--r--doc/Commprod.htm2
-rw-r--r--doc/DLL.htm2
-rw-r--r--doc/Deprecated.htm2
-rw-r--r--doc/Develop.htm4
-rw-r--r--doc/Devices.htm34
-rw-r--r--doc/Drivers.htm898
-rw-r--r--doc/Fonts.htm2
-rw-r--r--doc/GPDL.htm2
-rw-r--r--doc/GS9_Color_Management.pdfbin6606532 -> 6648423 bytes
-rw-r--r--doc/History9.htm250533
-rw-r--r--doc/Install.htm2
-rw-r--r--doc/Internal.htm2
-rw-r--r--doc/Language.htm253
-rw-r--r--doc/Lib.htm2
-rw-r--r--doc/Make.htm2
-rw-r--r--doc/News.htm103
-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.htm82
-rw-r--r--doc/VectorDevices.htm18
-rw-r--r--doc/WhatIsGS.htm33
-rw-r--r--doc/colormanage/GS9_Color_Management.tex (renamed from doc/GS9_Color_Management.tex)71
-rw-r--r--doc/colormanage/figures/DeviceN_Figure1.pdfbin0 -> 45524 bytes
-rw-r--r--doc/colormanage/figures/Object_Color.pdf19819
-rw-r--r--doc/colormanage/figures/architecture.pdfbin0 -> 263974 bytes
-rw-r--r--doc/colormanage/figures/des_profile_intent.pdfbin0 -> 81377 bytes
-rw-r--r--doc/colormanage/figures/destination_profile.pdfbin0 -> 83362 bytes
-rw-r--r--doc/colormanage/figures/ghostscriptR_stack_RGBclr_CS6.pdf445
-rw-r--r--doc/colormanage/figures/proof_link.pdfbin0 -> 96247 bytes
-rw-r--r--doc/colormanage/figures/source_intent.pdfbin0 -> 72956 bytes
-rw-r--r--doc/colormanage/figures/source_profile.pdfbin0 -> 70284 bytes
-rw-r--r--doc/colormanage/figures/text_graph_image_cmyk_rgb.pdf1686
-rw-r--r--doc/gs-vms.hlp2
-rw-r--r--doc/language-bindings/c-sharp-ghost-api.html475
-rw-r--r--doc/language-bindings/c-sharp-ghost-mono.html582
-rw-r--r--doc/language-bindings/c-sharp-ghost-net.html621
-rw-r--r--doc/language-bindings/c-sharp-intro.html218
-rw-r--r--doc/language-bindings/css/default.css735
-rw-r--r--doc/language-bindings/demo-code.html91
-rw-r--r--doc/language-bindings/gs-language-bindings.pdfbin0 -> 2223621 bytes
-rw-r--r--doc/language-bindings/images/artifex-logo-white.pngbin0 -> 25279 bytes
-rw-r--r--doc/language-bindings/images/artifex-logo.pngbin0 -> 20028 bytes
-rw-r--r--doc/language-bindings/images/export-jar.pngbin0 -> 203606 bytes
-rw-r--r--doc/language-bindings/images/ghostnet-wpf-example.pngbin0 -> 353078 bytes
-rw-r--r--doc/language-bindings/images/ghostscript-grey.pngbin0 -> 9631 bytes
-rw-r--r--doc/language-bindings/images/ghostscript-plus-text-white.pngbin0 -> 18306 bytes
-rw-r--r--doc/language-bindings/images/ghostscript-plus-text.pngbin0 -> 26728 bytes
-rw-r--r--doc/language-bindings/images/ghostscript.pngbin0 -> 11221 bytes
-rw-r--r--doc/language-bindings/images/gsviewer.pngbin0 -> 63958 bytes
-rw-r--r--doc/language-bindings/images/icon-burger-menu.pngbin0 -> 425 bytes
-rw-r--r--doc/language-bindings/images/icon-shell-command.pngbin0 -> 2521 bytes
-rw-r--r--doc/language-bindings/images/icon-vendor-c-sharp.pngbin0 -> 5656 bytes
-rw-r--r--doc/language-bindings/images/icon-vendor-c.pngbin0 -> 4960 bytes
-rw-r--r--doc/language-bindings/images/icon-vendor-java.pngbin0 -> 6320 bytes
-rw-r--r--doc/language-bindings/images/icon-vendor-python.pngbin0 -> 3848 bytes
-rw-r--r--doc/language-bindings/images/linking-jar.pngbin0 -> 112169 bytes
-rw-r--r--doc/language-bindings/index.html168
-rw-r--r--doc/language-bindings/java-gsjavajar.html783
-rw-r--r--doc/language-bindings/java-intro.html260
-rw-r--r--doc/language-bindings/js/default.js53
-rw-r--r--doc/language-bindings/md/c-sharp-ghost-api.md603
-rw-r--r--doc/language-bindings/md/c-sharp-ghost-mono.md633
-rw-r--r--doc/language-bindings/md/c-sharp-ghost-net.md681
-rw-r--r--doc/language-bindings/md/c-sharp-intro.md120
-rw-r--r--doc/language-bindings/md/demo-code.md17
-rw-r--r--doc/language-bindings/md/images/export-jar.pngbin0 -> 322111 bytes
-rw-r--r--doc/language-bindings/md/images/ghostnet-wpf-example.pngbin0 -> 490641 bytes
-rw-r--r--doc/language-bindings/md/images/gsviewer.pngbin0 -> 147343 bytes
-rw-r--r--doc/language-bindings/md/images/linking-jar.pngbin0 -> 155039 bytes
-rwxr-xr-xdoc/language-bindings/md/introduction.md113
-rw-r--r--doc/language-bindings/md/java-gsjavajar.md1179
-rw-r--r--doc/language-bindings/md/java-intro.md221
-rw-r--r--doc/language-bindings/md/python-gsapi.md813
-rw-r--r--doc/language-bindings/md/python-intro.md76
-rw-r--r--doc/language-bindings/python-gsapi.html598
-rw-r--r--doc/language-bindings/python-intro.html114
-rw-r--r--doc/sample_downscale_device.htm2
-rw-r--r--doc/subclass.htm118
-rw-r--r--doc/thirdparty.htm2
-rw-r--r--extract/Makefile94
-rw-r--r--extract/include/extract.h10
-rw-r--r--extract/src/astring.c97
-rw-r--r--extract/src/astring.h10
-rw-r--r--extract/src/document.h20
-rw-r--r--extract/src/docx.c569
-rwxr-xr-xextract/src/docx_template_build.py132
-rw-r--r--extract/src/extract-exe.c27
-rw-r--r--extract/src/extract.c257
-rw-r--r--extract/src/join.c4
-rw-r--r--extract/src/mem.h2
-rw-r--r--extract/src/odt.c880
-rw-r--r--extract/src/odt.h100
-rw-r--r--extract/src/odt_template.c365
-rw-r--r--extract/src/odt_template.h17
-rw-r--r--extract/src/sys.c137
-rw-r--r--extract/src/sys.h35
-rw-r--r--extract/src/template.odtbin0 -> 7948 bytes
-rw-r--r--extract/src/text.c108
-rw-r--r--extract/src/text.h37
-rw-r--r--extract/src/zip.c178
-rw-r--r--extract/src/zip.h4
-rw-r--r--extract/test/Python2.pdf.mutool.odt.dir.ref/META-INF/manifest.xml11
-rw-r--r--extract/test/Python2.pdf.mutool.odt.dir.ref/Thumbnails/thumbnail.png2
-rw-r--r--extract/test/Python2.pdf.mutool.odt.dir.ref/content.xml113
-rw-r--r--extract/test/Python2.pdf.mutool.odt.dir.ref/manifest.rdf18
-rw-r--r--extract/test/Python2.pdf.mutool.odt.dir.ref/meta.xml2
-rw-r--r--extract/test/Python2.pdf.mutool.odt.dir.ref/mimetype1
-rw-r--r--extract/test/Python2.pdf.mutool.odt.dir.ref/settings.xml2
-rw-r--r--extract/test/Python2.pdf.mutool.odt.dir.ref/styles.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/[Content_Types].xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/_rels/.rels2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/docProps/app.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/docProps/core.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/_rels/document.xml.rels2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/document.xml321
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/fontTable.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/settings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/styles.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/theme/theme1.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/webSettings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/[Content_Types].xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/_rels/.rels2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/docProps/app.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/docProps/core.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/_rels/document.xml.rels2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/document.xml718
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/fontTable.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/settings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/styles.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/theme/theme1.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/webSettings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/[Content_Types].xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/_rels/.rels2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/docProps/app.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/docProps/core.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/_rels/document.xml.rels2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/document.xml682
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/fontTable.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/settings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/styles.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/theme/theme1.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/webSettings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/[Content_Types].xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/_rels/.rels2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/docProps/app.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/docProps/core.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/_rels/document.xml.rels2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/document.xml321
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/fontTable.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/settings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/styles.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/theme/theme1.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/webSettings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/[Content_Types].xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/_rels/.rels2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/docProps/app.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/docProps/core.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/_rels/document.xml.rels2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/document.xml321
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/fontTable.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/settings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/styles.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/theme/theme1.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/webSettings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/[Content_Types].xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/_rels/.rels2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/docProps/app.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/docProps/core.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/_rels/document.xml.rels2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/document.xml718
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/fontTable.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/settings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/styles.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/theme/theme1.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/webSettings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/[Content_Types].xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/_rels/.rels2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/docProps/app.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/docProps/core.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/_rels/document.xml.rels2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/document.xml682
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/fontTable.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/settings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/styles.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/theme/theme1.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/webSettings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/[Content_Types].xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/_rels/.rels2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/docProps/app.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/docProps/core.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/_rels/document.xml.rels2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/document.xml321
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/fontTable.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/settings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/styles.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/theme/theme1.xml2
-rw-r--r--extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/webSettings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.mutool.odt.dir.ref/META-INF/manifest.xml11
-rw-r--r--extract/test/Python2clipped.pdf.mutool.odt.dir.ref/Thumbnails/thumbnail.png2
-rw-r--r--extract/test/Python2clipped.pdf.mutool.odt.dir.ref/content.xml113
-rw-r--r--extract/test/Python2clipped.pdf.mutool.odt.dir.ref/manifest.rdf18
-rw-r--r--extract/test/Python2clipped.pdf.mutool.odt.dir.ref/meta.xml2
-rw-r--r--extract/test/Python2clipped.pdf.mutool.odt.dir.ref/mimetype1
-rw-r--r--extract/test/Python2clipped.pdf.mutool.odt.dir.ref/settings.xml2
-rw-r--r--extract/test/Python2clipped.pdf.mutool.odt.dir.ref/styles.xml2
-rw-r--r--extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/META-INF/manifest.xml12
-rw-r--r--extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/Pictures/image11.jpegbin0 -> 68027 bytes
-rw-r--r--extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/Thumbnails/thumbnail.png2
-rw-r--r--extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/content.xml21
-rw-r--r--extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/manifest.rdf18
-rw-r--r--extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/meta.xml2
-rw-r--r--extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/mimetype1
-rw-r--r--extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/settings.xml2
-rw-r--r--extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/styles.xml2
-rw-r--r--extract/test/zlib.3.pdf.mutool.odt.dir.ref/META-INF/manifest.xml11
-rw-r--r--extract/test/zlib.3.pdf.mutool.odt.dir.ref/Thumbnails/thumbnail.png2
-rw-r--r--extract/test/zlib.3.pdf.mutool.odt.dir.ref/content.xml77
-rw-r--r--extract/test/zlib.3.pdf.mutool.odt.dir.ref/manifest.rdf18
-rw-r--r--extract/test/zlib.3.pdf.mutool.odt.dir.ref/meta.xml2
-rw-r--r--extract/test/zlib.3.pdf.mutool.odt.dir.ref/mimetype1
-rw-r--r--extract/test/zlib.3.pdf.mutool.odt.dir.ref/settings.xml2
-rw-r--r--extract/test/zlib.3.pdf.mutool.odt.dir.ref/styles.xml2
-rw-r--r--jbig2dec/README2
-rw-r--r--jbig2dec/config_win32.h2
-rw-r--r--jbig2dec/configure.ac.in1
-rw-r--r--jbig2dec/jbig2.h5
-rw-r--r--jbig2dec/jbig2_priv.h5
-rw-r--r--jbig2dec/jbig2dec.12
-rw-r--r--jbig2dec/jbig2dec.c112
-rw-r--r--jpeg/Makefile.am22
-rw-r--r--jpeg/Makefile.in450
-rw-r--r--jpeg/README19
-rw-r--r--jpeg/aclocal.m4193
-rwxr-xr-xjpeg/ar-lib4
-rw-r--r--jpeg/cdjpeg.h4
-rw-r--r--jpeg/change.log49
-rw-r--r--jpeg/cjpeg.117
-rwxr-xr-xjpeg/compile8
-rwxr-xr-xjpeg/config.guess559
-rwxr-xr-xjpeg/config.sub249
-rwxr-xr-xjpeg/configure221
-rw-r--r--jpeg/configure.ac9
-rwxr-xr-xjpeg/depcomp8
-rw-r--r--jpeg/djpeg.133
-rw-r--r--jpeg/djpeg.c25
-rw-r--r--jpeg/filelist.txt6
-rwxr-xr-xjpeg/install-sh45
-rw-r--r--jpeg/install.txt58
-rw-r--r--jpeg/jcarith.c17
-rw-r--r--jpeg/jccolor.c97
-rw-r--r--jpeg/jchuff.c151
-rw-r--r--jpeg/jcmarker.c8
-rw-r--r--jpeg/jcmaster.c33
-rw-r--r--jpeg/jcomapi.c138
-rw-r--r--jpeg/jcparam.c113
-rw-r--r--jpeg/jdarith.c32
-rw-r--r--jpeg/jdatadst.c23
-rw-r--r--jpeg/jdatasrc.c31
-rw-r--r--jpeg/jdcolor.c130
-rw-r--r--jpeg/jdct.h9
-rw-r--r--jpeg/jdhuff.c106
-rw-r--r--jpeg/jdmarker.c20
-rw-r--r--jpeg/jdmaster.c47
-rw-r--r--jpeg/jdmerge.c65
-rw-r--r--jpeg/jerror.h4
-rw-r--r--jpeg/jfdctint.c116
-rw-r--r--jpeg/jidctint.c14
-rw-r--r--jpeg/jmemmgr.c60
-rw-r--r--jpeg/jmemnobs.c8
-rw-r--r--jpeg/jpegint.h9
-rw-r--r--jpeg/jpeglib.h11
-rw-r--r--jpeg/jpegtran.130
-rw-r--r--jpeg/jpegtran.c91
-rw-r--r--jpeg/jutils.c6
-rw-r--r--jpeg/jversion.h6
-rw-r--r--jpeg/libjpeg.pc.in2
-rw-r--r--jpeg/libjpeg.txt51
-rw-r--r--jpeg/makeasln.v16 (renamed from jpeg/makeasln.v15)22
-rw-r--r--jpeg/makecdsp.vc64
-rw-r--r--jpeg/makecfil.v16 (renamed from jpeg/makecfil.v15)2
-rw-r--r--jpeg/makecvcx.v16 (renamed from jpeg/makecvcx.v15)51
-rw-r--r--jpeg/makeddsp.vc64
-rw-r--r--jpeg/makedfil.v16 (renamed from jpeg/makedfil.v15)2
-rw-r--r--jpeg/makedvcx.v16 (renamed from jpeg/makedvcx.v15)51
-rw-r--r--jpeg/makefile.ansi18
-rw-r--r--jpeg/makefile.b3218
-rw-r--r--jpeg/makefile.bcc19
-rw-r--r--jpeg/makefile.dj18
-rw-r--r--jpeg/makefile.manx18
-rw-r--r--jpeg/makefile.mc618
-rw-r--r--jpeg/makefile.mms14
-rw-r--r--jpeg/makefile.sas18
-rw-r--r--jpeg/makefile.unix18
-rw-r--r--jpeg/makefile.vc150
-rw-r--r--jpeg/makefile.vs150
-rw-r--r--jpeg/makefile.wat19
-rw-r--r--jpeg/makejdsp.vc62
-rw-r--r--jpeg/makejfil.v16 (renamed from jpeg/makejfil.v15)2
-rw-r--r--jpeg/makejsln.v16 (renamed from jpeg/makejsln.v15)14
-rw-r--r--jpeg/makejvcx.v16 (renamed from jpeg/makejvcx.v15)47
-rw-r--r--jpeg/makerdsp.vc64
-rw-r--r--jpeg/makerfil.v16 (renamed from jpeg/makerfil.v15)2
-rw-r--r--jpeg/makervcx.v16 (renamed from jpeg/makervcx.v15)48
-rw-r--r--jpeg/maketdsp.vc64
-rw-r--r--jpeg/maketfil.v16 (renamed from jpeg/maketfil.v15)2
-rw-r--r--jpeg/maketvcx.v16 (renamed from jpeg/maketvcx.v15)51
-rw-r--r--jpeg/makewdsp.vc64
-rw-r--r--jpeg/makewfil.v16 (renamed from jpeg/makewfil.v15)2
-rw-r--r--jpeg/makewvcx.v16 (renamed from jpeg/makewvcx.v15)48
-rwxr-xr-xjpeg/missing14
-rw-r--r--jpeg/rdbmp.c97
-rw-r--r--jpeg/rdgif.c667
-rw-r--r--jpeg/rdppm.c27
-rw-r--r--jpeg/rdrle.c67
-rw-r--r--jpeg/rdswitch.c7
-rw-r--r--jpeg/rdtarga.c34
-rw-r--r--jpeg/testimg.gifbin0 -> 21718 bytes
-rw-r--r--jpeg/testimgp.jpgbin5645 -> 5645 bytes
-rw-r--r--jpeg/transupp.c682
-rw-r--r--jpeg/transupp.h31
-rw-r--r--jpeg/usage.txt57
-rw-r--r--jpeg/wrbmp.c48
-rw-r--r--jpeg/wrgif.c334
-rw-r--r--jpeg/wrppm.c18
-rw-r--r--jpeg/wrrle.c54
-rw-r--r--jpeg/wrtarga.c36
-rw-r--r--lcms2mt/Makefile.in7
-rw-r--r--lcms2mt/Projects/VC2015/lcms2mt.rc8
-rw-r--r--lcms2mt/Projects/VC2017/lcms2mt.rc8
-rw-r--r--lcms2mt/Projects/VC2019/lcms2mt.rc8
-rw-r--r--lcms2mt/Projects/Xcode_12/lcms2/lcms2.xcodeproj/project.pbxproj1387
-rw-r--r--lcms2mt/Projects/Xcode_12/lcms2/lcms2.xcodeproj/project.xcworkspace/contents.xcworkspacedata7
-rw-r--r--lcms2mt/Projects/Xcode_12/lcms2/lcms2.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist8
-rw-r--r--lcms2mt/Projects/Xcode_12/lcms2/lcms2.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings8
-rwxr-xr-xlcms2mt/autogen.sh12
-rwxr-xr-xlcms2mt/compile2
-rwxr-xr-xlcms2mt/config.guess683
-rwxr-xr-xlcms2mt/config.sub302
-rw-r--r--lcms2mt/configure4102
-rw-r--r--lcms2mt/configure.ac24
-rwxr-xr-xlcms2mt/depcomp6
-rw-r--r--lcms2mt/doc/LittleCMS2.12 API.pdfbin0 -> 887501 bytes
-rw-r--r--lcms2mt/doc/LittleCMS2.12 Plugin API.pdfbin0 -> 651021 bytes
-rw-r--r--lcms2mt/doc/LittleCMS2.12 tutorial.pdfbin0 -> 512619 bytes
-rw-r--r--lcms2mt/include/Makefile.in1
-rw-r--r--lcms2mt/include/lcms2mt.h15
-rwxr-xr-xlcms2mt/install-sh47
-rw-r--r--lcms2mt/lcms2mt.pc.in2
-rwxr-xr-xlcms2mt/ltmain.sh5452
-rw-r--r--lcms2mt/m4/libtool.m42591
-rw-r--r--lcms2mt/m4/ltoptions.m4127
-rw-r--r--lcms2mt/m4/ltsugar.m47
-rw-r--r--lcms2mt/m4/ltversion.m412
-rw-r--r--lcms2mt/m4/lt~obsolete.m47
-rw-r--r--lcms2mt/plugins/Makefile.am1
-rw-r--r--lcms2mt/plugins/Makefile.in646
-rw-r--r--lcms2mt/plugins/fast_float/Makefile.am1
-rw-r--r--lcms2mt/plugins/fast_float/Makefile.in646
-rw-r--r--lcms2mt/plugins/fast_float/doc/LittleCMS floating point extensions 1.4.pdfbin0 -> 413883 bytes
-rw-r--r--lcms2mt/plugins/fast_float/include/Makefile.in591
-rw-r--r--lcms2mt/plugins/fast_float/src/Makefile.in713
-rw-r--r--lcms2mt/plugins/fast_float/src/fast_16_tethra.c7
-rw-r--r--lcms2mt/plugins/fast_float/src/fast_8_matsh_sse.c420
-rw-r--r--lcms2mt/plugins/fast_float/src/fast_8_tethra.c15
-rw-r--r--lcms2mt/plugins/fast_float/src/fast_float_cmyk.c10
-rw-r--r--lcms2mt/plugins/fast_float/src/fast_float_internal.h20
-rw-r--r--lcms2mt/plugins/fast_float/src/fast_float_lab.c433
-rw-r--r--lcms2mt/plugins/fast_float/src/fast_float_tethra.c14
-rw-r--r--lcms2mt/plugins/fast_float/testbed/Makefile.in635
-rw-r--r--lcms2mt/plugins/fast_float/testbed/fast_float_testbed.c257
-rw-r--r--lcms2mt/src/Makefile.in1
-rw-r--r--lcms2mt/src/cmscgats.c21
-rw-r--r--lcms2mt/src/cmsgmt.c61
-rw-r--r--lcms2mt/src/cmsio0.c8
-rw-r--r--lcms2mt/src/cmsopt.c31
-rw-r--r--lcms2mt/src/cmsplugin.c30
-rw-r--r--lcms2mt/src/cmstypes.c4
-rw-r--r--lcms2mt/src/cmsxform.c1265
-rw-r--r--lcms2mt/src/extra_xform.h326
-rw-r--r--lcms2mt/src/lcms2_internal.h3
-rw-r--r--lcms2mt/testbed/Makefile.in1
-rw-r--r--lcms2mt/testbed/new.iccbin25244 -> 25244 bytes
-rw-r--r--lcms2mt/testbed/testcms2.c198
-rw-r--r--lcms2mt/utils/delphi/lcms2dll.pas7
-rw-r--r--lcms2mt/utils/jpgicc/Makefile.in1
-rw-r--r--lcms2mt/utils/jpgicc/jpgicc.c87
-rw-r--r--lcms2mt/utils/linkicc/Makefile.in1
-rw-r--r--lcms2mt/utils/matlab/howto.txt4
-rw-r--r--lcms2mt/utils/psicc/Makefile.in1
-rw-r--r--lcms2mt/utils/tificc/Makefile.in1
-rw-r--r--lcms2mt/utils/tificc/tificc.c56
-rw-r--r--lcms2mt/utils/transicc/Makefile.in1
-rw-r--r--lib/PDFA_def.ps40
-rw-r--r--lib/ghostpdf.catbin7290 -> 9756 bytes
-rw-r--r--lib/gslp.ps79
-rw-r--r--lib/viewgif.ps6
-rw-r--r--lib/zugferd.ps452
-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
-rw-r--r--pdf/ghostpdf.c1938
-rw-r--r--pdf/ghostpdf.h537
-rw-r--r--pdf/pdf.mak340
-rw-r--r--pdf/pdf_annot.c4517
-rw-r--r--pdf/pdf_annot.h (renamed from base/gxdevrop.h)18
-rw-r--r--pdf/pdf_array.c541
-rw-r--r--pdf/pdf_array.h45
-rw-r--r--pdf/pdf_check.c1190
-rw-r--r--pdf/pdf_check.h24
-rw-r--r--pdf/pdf_ciddec.c530
-rw-r--r--pdf/pdf_cmap.c900
-rw-r--r--pdf/pdf_cmap.h70
-rw-r--r--pdf/pdf_colour.c2676
-rw-r--r--pdf/pdf_colour.h60
-rw-r--r--pdf/pdf_deref.c1028
-rw-r--r--pdf/pdf_deref.h26
-rw-r--r--pdf/pdf_device.c184
-rw-r--r--pdf/pdf_device.h27
-rw-r--r--pdf/pdf_dict.c1157
-rw-r--r--pdf/pdf_dict.h73
-rw-r--r--pdf/pdf_doc.c1345
-rw-r--r--pdf/pdf_doc.h33
-rw-r--r--pdf/pdf_fapi.c1514
-rw-r--r--pdf/pdf_file.c1700
-rw-r--r--pdf/pdf_file.h112
-rw-r--r--pdf/pdf_fmap.c181
-rw-r--r--pdf/pdf_fmap.h20
-rw-r--r--pdf/pdf_font.c1581
-rw-r--r--pdf/pdf_font.h106
-rw-r--r--pdf/pdf_font0.c586
-rw-r--r--pdf/pdf_font0.h35
-rw-r--r--pdf/pdf_font1.c797
-rw-r--r--pdf/pdf_font1.h26
-rw-r--r--pdf/pdf_font11.c462
-rw-r--r--pdf/pdf_font1C.c2762
-rw-r--r--pdf/pdf_font1C.h28
-rw-r--r--pdf/pdf_font3.c334
-rw-r--r--pdf/pdf_font3.h24
-rw-r--r--pdf/pdf_font9.c44
-rw-r--r--pdf/pdf_fontTT.c621
-rw-r--r--pdf/pdf_fontTT.h24
-rw-r--r--pdf/pdf_font_types.h231
-rw-r--r--pdf/pdf_fontps.c1239
-rw-r--r--pdf/pdf_fontps.h351
-rw-r--r--pdf/pdf_func.c878
-rw-r--r--pdf/pdf_func.h25
-rw-r--r--pdf/pdf_gstate.c2389
-rw-r--r--pdf/pdf_gstate.h57
-rw-r--r--pdf/pdf_image.c2510
-rw-r--r--pdf/pdf_image.h30
-rw-r--r--pdf/pdf_int.c2125
-rw-r--r--pdf/pdf_int.h49
-rw-r--r--pdf/pdf_loop_detect.c127
-rw-r--r--pdf/pdf_loop_detect.h38
-rw-r--r--pdf/pdf_mark.c1084
-rw-r--r--pdf/pdf_mark.h32
-rw-r--r--pdf/pdf_misc.c305
-rw-r--r--pdf/pdf_misc.h37
-rw-r--r--pdf/pdf_obj.c955
-rw-r--r--pdf/pdf_obj.h28
-rw-r--r--pdf/pdf_optcontent.c510
-rw-r--r--pdf/pdf_optcontent.h28
-rw-r--r--pdf/pdf_page.c926
-rw-r--r--pdf/pdf_page.h49
-rw-r--r--pdf/pdf_path.c477
-rw-r--r--pdf/pdf_path.h40
-rw-r--r--pdf/pdf_pattern.c744
-rw-r--r--pdf/pdf_pattern.h28
-rw-r--r--pdf/pdf_repair.c473
-rw-r--r--pdf/pdf_repair.h21
-rw-r--r--pdf/pdf_sec.c1418
-rw-r--r--pdf/pdf_sec.h23
-rw-r--r--pdf/pdf_shading.c927
-rw-r--r--pdf/pdf_shading.h28
-rw-r--r--pdf/pdf_stack.c126
-rw-r--r--pdf/pdf_stack.h125
-rw-r--r--pdf/pdf_text.c1618
-rw-r--r--pdf/pdf_text.h59
-rw-r--r--pdf/pdf_trans.c811
-rw-r--r--pdf/pdf_trans.h53
-rw-r--r--pdf/pdf_types.h241
-rw-r--r--pdf/pdf_utf8.c128
-rw-r--r--pdf/pdf_utf8.h25
-rw-r--r--pdf/pdf_xref.c1123
-rw-r--r--pdf/pdf_xref.h22
-rw-r--r--pdf/pdfromfs.mak23
-rw-r--r--pdf/pdftop.c867
-rw-r--r--psi/bfont.h1
-rw-r--r--psi/icie.h2
-rw-r--r--psi/idebug.c1
-rw-r--r--psi/igc.c1
-rw-r--r--psi/igcref.c1
-rw-r--r--psi/int.mak5
-rw-r--r--psi/interp.c3
-rw-r--r--psi/iparam.c10
-rw-r--r--psi/iref.h10
-rw-r--r--psi/istack.c3
-rw-r--r--psi/iutil.c4
-rw-r--r--psi/msvc.mak197
-rw-r--r--psi/nsisinst.nsi3
-rw-r--r--psi/zbfont.c8
-rw-r--r--psi/zcfont.c2
-rw-r--r--psi/zchar1.c2
-rw-r--r--psi/zcharout.c20
-rw-r--r--psi/zcie.c22
-rw-r--r--psi/zcolor.c183
-rw-r--r--psi/zcolor1.c6
-rw-r--r--psi/zdevice.c6
-rw-r--r--psi/zfile.c2
-rw-r--r--psi/zfjpx.c31
-rw-r--r--psi/zfsample.c16
-rw-r--r--psi/zfunc.c2
-rw-r--r--psi/zgeneric.c2
-rw-r--r--psi/zht.c2
-rw-r--r--psi/zht1.c1
-rw-r--r--psi/zht2.c77
-rw-r--r--psi/zicc.c10
-rw-r--r--psi/ziodev.c2
-rw-r--r--psi/ziodev2.c4
-rw-r--r--psi/zmatrix.c7
-rw-r--r--psi/zpath.c14
-rw-r--r--psi/zpcolor.c22
-rw-r--r--psi/zpdf_r6.c2
-rw-r--r--psi/zpdfops.c968
-rw-r--r--psi/zupath.c8
-rw-r--r--psi/zvmem.c1
-rw-r--r--tesseract/src/ccutil/strngs.h1
-rw-r--r--toolbin/bmpcmp.c442
-rw-r--r--toolbin/color/icc_creator/nclr/Artifex_6CLR.iccbin0 -> 1523780 bytes
-rw-r--r--toolbin/color/src_color/objsrc_profiles_example.txt8
-rwxr-xr-xtoolbin/headercompile.pl12
-rwxr-xr-xtoolbin/localcluster/clusterpush.pl3
-rw-r--r--toolbin/tif_config.h.for.bmpcmp371
-rw-r--r--toolbin/tiffconf.h.for.bmpcmp122
-rw-r--r--windows/GhostPDL.sln46
-rw-r--r--windows/ghostpcl-ufst.vcproj8
-rw-r--r--windows/ghostpdf.vcproj664
-rw-r--r--windows/ghostpdf.vcxproj394
-rw-r--r--windows/ghostpdf.vcxproj.filters276
-rw-r--r--windows/ghostpdl.vcproj24
-rw-r--r--windows/ghostscript.vcproj140
-rw-r--r--windows/ghostscript.vcxproj323
-rw-r--r--windows/ghostscript.vcxproj.filters1085
-rw-r--r--windows/ghostscript_rt.vcxproj4
1018 files changed, 131337 insertions, 283699 deletions
diff --git a/.gitattributes b/.gitattributes
index 0b0b4275..3e4baa0c 100644
--- a/.gitattributes
+++ b/.gitattributes
@@ -13,7 +13,10 @@ Make* makefile
*.txt spaces
*.htm spaces
*.css spaces
+*.pdf binary
# Source files
*.c spaces
*.h spaces
+
+*.md text \ No newline at end of file
diff --git a/LICENSE b/LICENSE
index 572496a3..52e83a2a 100644
--- a/LICENSE
+++ b/LICENSE
@@ -39,31 +39,3 @@ License along with this program so you can know your rights and
responsibilities. It should be in a file named doc/COPYING. If not,
write to the Free Software Foundation, Inc., 59 Temple Place Suite
330, Boston, MA 02111-1307, USA.
-
----
-
-GPL Ghostscript contains an implementation of techniques covered
-by US Patents 5,055,942 and 5,917,614, and corresponding
-international patents. These patents are licensed for use with
-GPL Ghostscript under the following grant:
-
-Whereas, Raph Levien (hereinafter "Inventor") has obtained patent
-protection for related technology (hereinafter "Patented
-Technology"), Inventor wishes to aid the the GNU free software
-project in achieving its goals, and Inventor also wishes to
-increase public awareness of Patented Technology, Inventor hereby
-grants a fully paid up, nonexclusive, royalty free license to
-practice the patents listed below ("the Patents") if and only if
-practiced in conjunction with software distributed under the
-terms of any version of the GNU Affero General Public License as
-published by the Free Software Foundation, 59 Temple Place, Suite
-330, Boston, MA 02111. Inventor reserves all other rights,
-including without limitation, licensing for software not
-distributed under the GNU Affero General Public License.
-
-5055942 Photographic image reproduction device using digital
-halftoning to screen images allowing adjustable coarseness
-
-5917614 Method and apparatus for error diffusion screening of
-images with improved smoothness in highlight and shadow
-regions
diff --git a/Makefile.in b/Makefile.in
index 5a647990..bb655433 100644
--- a/Makefile.in
+++ b/Makefile.in
@@ -55,6 +55,10 @@ XPSSRCDIR=@srcdir@/xps
XPSGENDIR=./$(BUILDDIRPREFIX)@OBJDIR_BSDMAKE_WORKAROUND@
XPSOBJDIR=./$(BUILDDIRPREFIX)@OBJDIR_BSDMAKE_WORKAROUND@
+PDFSRCDIR=@srcdir@/pdf
+PDFGENDIR=./$(BUILDDIRPREFIX)@OBJDIR_BSDMAKE_WORKAROUND@
+PDFOBJDIR=./$(BUILDDIRPREFIX)@OBJDIR_BSDMAKE_WORKAROUND@
+
GPDLSRCDIR=@srcdir@/gpdl
GPDLGENDIR=./$(BUILDDIRPREFIX)@OBJDIR_BSDMAKE_WORKAROUND@
GPDLOBJDIR=./$(BUILDDIRPREFIX)@OBJDIR_BSDMAKE_WORKAROUND@
@@ -197,6 +201,12 @@ XPS_SONAME=@XPS_SONAME@
XPS_SONAME_MAJOR=@XPS_SONAME_MAJOR@
XPS_SONAME_MAJOR_MINOR=@XPS_SONAME_MAJOR_MINOR@
+PDF=@PDF@
+PDF_SO_BASE=@PDF@
+PDF_SONAME=@PDF_SONAME@
+PDF_SONAME_MAJOR=@PDF_SONAME_MAJOR@
+PDF_SONAME_MAJOR_MINOR=@PDF_SONAME_MAJOR_MINOR@
+
GPDL=@GPDL@
GPDL_SO_BASE=@GPDL@
GPDL_SONAME=@GPDL_SONAME@
@@ -208,9 +218,10 @@ XEAUX=@AUXEXEEXT@
PCL_TARGET=@PCL_TARGET@
XPS_TARGET=@XPS_TARGET@
+PDF_TARGET=@PDF_TARGET@
GPDL_TARGET=@GPDL_TARGET@
-PCL_XPS_PDL_TARGETS=$(PCL_TARGET) $(XPS_TARGET) $(GPDL_TARGET)
+PCL_XPS_PDL_TARGETS=$(PCL_TARGET) $(XPS_TARGET) $(GPDL_TARGET) $(PDF_TARGET)
# Define the directories for debugging and profiling binaries, relative to
# the standard binaries.
@@ -471,11 +482,13 @@ GS_LDFLAGS=$(LDFLAGS)
PCL_LDFLAGS=$(LDFLAGS)
XPS_LDFLAGS=$(LDFLAGS)
PDL_LDFLAGS=$(LDFLAGS)
+PDF_LDFLAGS=$(LDFLAGS)
GS_LDFLAGS_SO=@GS_DYNAMIC_LDFLAGS@
PCL_LDFLAGS_SO=@PCL_DYNAMIC_LDFLAGS@
XPS_LDFLAGS_SO=@XPS_DYNAMIC_LDFLAGS@
PDL_LDFLAGS_SO=@PDL_DYNAMIC_LDFLAGS@
+PDF_LDFLAGS_SO=@PDF_DYNAMIC_LDFLAGS@
# Define any extra libraries to link into the executable.
# ISC Unix 2.2 wants -linet.
@@ -557,7 +570,7 @@ MKROMFS_FLAGS=@MKROMFS_FLAGS@
# Choose the language feature(s) to include. See gs.mak for details.
# if it's included, $(PSD)gs_pdfwr.dev should always be one of the last in the list
-PSI_FEATURE_DEVS=$(PSD)psl3.dev $(PSD)pdf.dev $(PSD)epsf.dev $(PSD)ttfont.dev \
+PSI_FEATURE_DEVS=$(PSD)psl3.dev $(PSD)pdf.dev @GPDF_DEV@ $(PSD)epsf.dev $(PSD)ttfont.dev \
@UTF8DEVS@ $(PSD)fapi_ps.dev $(PSD)jpx.dev $(PSD)jbig2.dev $(PSD)gs_pdfwr.dev
@@ -566,6 +579,8 @@ PCL_FEATURE_DEVS=$(PLOBJDIR)/pl.dev $(PLOBJDIR)/pjl.dev $(PXLOBJDIR)/pxl.dev $(P
XPS_FEATURE_DEVS=$(XPSOBJDIR)/pl.dev $(XPSOBJDIR)/xps.dev
+PDF_FEATURE_DEVS=$(PDFOBJDIR)/pl.dev $(PDFOBJDIR)/gpdf.dev
+
FEATURE_DEVS=$(GLD)pipe.dev $(GLD)gsnogc.dev $(GLD)htxlib.dev $(GLD)psl3lib.dev $(GLD)psl2lib.dev \
$(GLD)dps2lib.dev $(GLD)path1lib.dev $(GLD)patlib.dev $(GLD)psl2cs.dev $(GLD)rld.dev $(GLD)gxfapiu$(UFST_BRIDGE).dev\
$(GLD)ttflib.dev $(GLD)cielib.dev $(GLD)pipe.dev $(GLD)htxlib.dev $(GLD)sdct.dev $(GLD)libpng.dev\
@@ -726,6 +741,7 @@ include $(GLSRCDIR)/gs.mak
# *romfs.mak must precede lib.mak
include @PLROMFS_MAK@ # plromfs.mak
include @XPSROMFS_MAK@ # xpsromfs.mak
+include @PDFROMFS_MAK@ # pdfromfs.mak
include $(PSSRCDIR)/psromfs.mak
include $(GLSRCDIR)/lib.mak
@@ -740,6 +756,8 @@ include @XPS_MAK@ # xps.mak
include $(GLSRCDIR)/jpeg.mak
+include @PDF_MAK@ # pdf.mak
+
include @GPDL_MAK@ # gpdl.mak
include $(GLSRCDIR)/freetype.mak
diff --git a/Resource/Init/gs_cmap.ps b/Resource/Init/gs_cmap.ps
index 0c2e1421..b836c638 100644
--- a/Resource/Init/gs_cmap.ps
+++ b/Resource/Init/gs_cmap.ps
@@ -224,11 +224,19 @@
/beginbfchar { % <count> beginbfchar -
pop mark
} bind def
-/endbfchar { % <code> <to_code|charname> ... endbfchar
- counttomark 2 idiv {
- counttomark -2 roll % process in correct order
- .addbfchar
- } repeat 1 .appendmap
+/endbfchar { % [ <code> <to_code|charname> ... endbfchar
+ ] [ //true % [<da><ta>] [ true
+ 3 -1 roll % [ true [<da><ta>]
+ {
+ exch {
+ //false % [ <da> false
+ } { % [ <da> <ta>
+ .addbfchar % [ prefix params key value font_index
+ //true
+ } ifelse
+ } forall
+ pop
+ 1 .appendmap
} bind def
/beginbfrange { % <count> beginbfrange -
@@ -236,26 +244,35 @@
} bind def
/endbfrange { % <code_lo> <code_hi> <to_code|(charname*)> ...
% endbfrange -
- counttomark 3 idiv {
- counttomark -3 roll % process in correct order
- dup type dup /arraytype eq exch /packedarraytype eq or {
+ ] [ 0 % [<da><ta><set>] [ 0
+ 3 -1 roll % [ 0 [<da><ta><set>]
+ {
+ exch % [ <da> 0
+ { 1 2
+ {
+ dup type dup /arraytype eq exch /packedarraytype eq or {
% Array value, split up.
- exch pop {
+ exch pop {
% Stack: code to_code|charname
- 1 index exch .addbfchar
+ 1 index exch .addbfchar
% Increment the code. As noted above, we require
% that only the last byte vary, but we still must
% mask it after incrementing, in case the last
% value was 0xff.
% Stack: code prefix params key value fontindex
- 6 -1 roll dup length string copy
- dup dup length 1 sub 2 copy get 1 add 255 and put
- } forall pop
- } {
+ 6 -1 roll dup length string copy
+ dup dup length 1 sub 2 copy get 1 add 255 and put
+ } forall pop
+ } {
% Single value, handle directly.
- .addbfrange
- } ifelse
- } repeat 1 .appendmap
+ .addbfrange
+ } ifelse
+ 0
+ }
+ } exch get exec
+ } forall
+ pop
+ 1 .appendmap
} bind def
/.addbfchar { % <code> <to_code|charname> .addbfchar
@@ -349,7 +366,7 @@
4 -1 roll % <prefix> <param'> <key> <cid>
.endmapvalue % <prefix> <param'> <key> <hex_cid> <font_idx>
% prefix params keys value fontindex
- counttomark 5 gt { % 2 (or more) ranges (1 range = 5 item)
+ counttomark 9 gt { % 2 (or more) ranges (1 range = 5 item)
4 index 10 index eq % compare prefix
4 index 10 index eq and % compare params
1 index 7 index eq and % compare fontindex
@@ -462,7 +479,7 @@
% See if we can merge with the previous value.
% The prefix, params, and font index must match.
% prefix params keys value fontindex
- counttomark 5 gt { % 2 (or more) ranges (1 range = 5 item)
+ counttomark 9 gt { % 2 (or more) ranges (1 range = 5 item)
4 index 10 index eq % compare prefix
4 index 10 index eq and % compare params
1 index 7 index eq and % compare fontindex
diff --git a/Resource/Init/gs_epsf.ps b/Resource/Init/gs_epsf.ps
index 47b68bba..7f2329d6 100644
--- a/Resource/Init/gs_epsf.ps
+++ b/Resource/Init/gs_epsf.ps
@@ -270,13 +270,14 @@
/.runNoEPS /run load def
/.runEPS { % file OR string --
+ .updatematrices
/runEPS_save save def
/runEPS_dict_count countdictstack def
/runEPS_op_count count 2 sub def
- /runEPS_page_count currentpagedevice /PageCount get def
+ /runEPS_page_count .currentshowpagecount not {0} if def
0 EPSBoundingBoxSetState
//.runNoEPS
- currentpagedevice /PageCount get runEPS_page_count sub 0 eq
+ .currentshowpagecount not {0} if runEPS_page_count sub 0 eq
{ /showpage load exec } if
count runEPS_op_count sub {pop} repeat
countdictstack runEPS_dict_count sub {end} repeat
diff --git a/Resource/Init/gs_init.ps b/Resource/Init/gs_init.ps
index 088c8583..e3d65eca 100644
--- a/Resource/Init/gs_init.ps
+++ b/Resource/Init/gs_init.ps
@@ -34,7 +34,7 @@
% Interpreter library version number
% NOTE: the interpreter code requires that the first non-comment token
% in this file be an integer, and that it match the compiled-in version!
-9540
+9550
% Check the interpreter revision.
dup revision ne
@@ -476,6 +476,7 @@ userdict /#copies 1 put
% We have to guard against the BeginPage procedure not popping its operand.
% This is really stupid, but the Genoa CET does it.
/.beginpage { % - .beginpage -
+ .updatematrices
.currentshowpagecount {
.currentpagedevice pop
dup //null ne { /BeginPage .knownget } { pop //false } ifelse {
@@ -491,6 +492,7 @@ userdict /#copies 1 put
% Guard similarly against EndPage not popping its operand.
/.endpage { % <reason> .endpage <print_bool>
+ .updatematrices
.currentshowpagecount {
1 index .currentpagedevice pop
dup //null ne { /EndPage .knownget } { pop //false } ifelse {
@@ -2415,7 +2417,7 @@ currentdict /.locksafeglobal .undef
[
/.bitadd /.charboxpath /.cond /.runandhide /.popdevicefilter
/.execfile /.filenamesplit /.file_name_parent
- /.setdefaultmatrix /.isprocfilter /.unread /.psstringencode
+ /.setdefaultmatrix /.updatematrices /.isprocfilter /.unread /.psstringencode
/.buildsampledfunction /.isencapfunction /.currentaccuratecurves /.currentcurvejoin /.currentdashadapt /.currentdotlength
/.currentlimitclamp /.dotorientation /.setaccuratecurves /.setcurvejoin /.setdashadapt /.setdotorientation
/.setlimitclamp /.currentscreenlevels /.dashpath /.pathbbox /.identeq /.identne /.tokenexec /.forgetsave /.pantonecallback
diff --git a/Resource/Init/gs_lev2.ps b/Resource/Init/gs_lev2.ps
index 54849370..ecd49370 100644
--- a/Resource/Init/gs_lev2.ps
+++ b/Resource/Init/gs_lev2.ps
@@ -201,7 +201,7 @@ end
[ /GenericResourceDir /FontResourceDir /GenericResourcePathSep ] {
2 copy .knownget {
exch //pssystemparams exch .knownget {
- ne { /setsystemparams /invalidaccess signalerror } if
+ ne { /setsystemparams cvx /invalidaccess signalerror } if
} {
pop
} ifelse
@@ -279,7 +279,7 @@ end
/.checkFilePermitparams {
type /arraytype eq {
currentuserparams /LockFilePermissions get {
- 5 { pop } repeat /setuserparams /invalidaccess signalerror
+ 5 { pop } repeat /setuserparams cvx /invalidaccess signalerror
}{
% in addition to validating the value, ensure the value is read/only
dup { readonly exch } forall
@@ -288,7 +288,7 @@ end
}
ifelse
} {
- 5 { pop } repeat /setuserparams /typecheck signalerror
+ 5 { pop } repeat /setuserparams cvx /typecheck signalerror
}
ifelse
//true
@@ -534,7 +534,7 @@ serverdict begin
/exitserver { % <password> exitserver -
//true exch { .startnewjob } .startjob not {
- /exitserver /invalidaccess signalerror
+ /exitserver cvx /invalidaccess signalerror
} if
} bind def
@@ -621,13 +621,13 @@ currentuserparams /WaitTimeout known
.dicttomark setpagedevice
} bind def
/setresolution
- { count 1 lt { /setresolution /stackunderflow signalerror } if
+ { count 1 lt { /setresolution cvx /stackunderflow signalerror } if
dup type dup /integertype eq exch /realtype eq or not
{
- /setresolution /typecheck signalerror
+ /setresolution cvx /typecheck signalerror
} if
dup 2 array astore /HWResolution //.pair2dict exec { setpagedevice } stopped {
- pop /setresolution $error /errorname get signalerror
+ pop /setresolution cvx $error /errorname get signalerror
} if
} bind def
%END PAGEDEVICE
@@ -1139,13 +1139,14 @@ def
}{
% Check that the tint is a number between 0 and 1
dup type dup /integertype eq exch /realtype eq or not {
- /setcustomcolor /typecheck cvx signalerror
+ /setcustomcolor cvx /typecheck signalerror
} if
+ % Bug 703869. Apparently Adobe (at least Acrobat Pro) silently clamps values
dup 1 le not {
- /setcustomcolor /rangecheck cvx signalerror
+ pop 1
} if
dup 0 ge not {
- /setcustomcolor /rangecheck cvx signalerror
+ pop 0
} if
% The array is supposed to be the result of fundcmykcustomcolor. Our
@@ -1157,20 +1158,20 @@ def
{
1 index exch get dup
type dup /integertype eq exch /realtype eq or not {
- /setcustomcolor /typecheck cvx signalerror
+ /setcustomcolor cvx /typecheck signalerror
} if
dup
1 le not {
- /setcustomcolor /rangecheck cvx signalerror
+ /setcustomcolor cvx /rangecheck signalerror
} if
0 ge not {
- /setcustomcolor /rangecheck cvx signalerror
+ /setcustomcolor cvx /rangecheck signalerror
} if
} for
% Finally, check the last element of the array, which must be a string.
dup length 1 sub get type /stringtype eq not {
- /setcustomcolor /typecheck cvx signalerror
+ /setcustomcolor cvx /typecheck signalerror
} if
exch //buildcolorspacearray exec
diff --git a/Resource/Init/gs_ll3.ps b/Resource/Init/gs_ll3.ps
index 98e2a65f..00ec8bca 100644
--- a/Resource/Init/gs_ll3.ps
+++ b/Resource/Init/gs_ll3.ps
@@ -113,9 +113,9 @@ currentdict /.bind_ undef
} bind def
/.bigstring { % <size> .bigstring <string|bytestring>
- count 1 lt { /.bigstring /stackunderflow signalerror } if
+ count 1 lt { /.bigstring cvx /stackunderflow signalerror } if
dup type /integertype ne {
- /.bigstring /typecheck signalerror
+ /.bigstring cvx /typecheck signalerror
} if
dup 65400 gt { .bytestring } { string } ifelse
} bind def
diff --git a/Resource/Init/gs_pdfwr.ps b/Resource/Init/gs_pdfwr.ps
index 9386339b..ef468522 100644
--- a/Resource/Init/gs_pdfwr.ps
+++ b/Resource/Init/gs_pdfwr.ps
@@ -102,6 +102,7 @@ languagelevel 2 .setlanguagelevel
/UseFlateCompression //true
/UsePrologue //false
/PassThroughJPEGImages //true
+ /PassThroughJPXImages //true
.dicttomark readonly def
/.distillersettings mark
@@ -573,10 +574,10 @@ userdict /.pdfcvstring () put
/pdfmark { % -mark- <key> <value> ... <markname> pdfmark -
counttomark 0 eq {
- /pdfmark /stackunderflow signalerror
+ /pdfmark cvx /stackunderflow signalerror
} if
dup type /nametype eq not {
- /pdfmark /typecheck signalerror
+ /pdfmark cvx /typecheck signalerror
} if
dup /SP eq {
% A hack for synchronizing the clipping path.
@@ -823,6 +824,7 @@ currentdict /.pdf_hook_DSC_Creator undef
/SubsetFonts { }
/DSCEncodingToUnicode { }
/PassThroughJPEGImages { }
+ /PassThroughJPXImages { }
/PSDocOptions { }
/PSPageOptions { }
.dicttomark readonly def
@@ -873,7 +875,7 @@ currentdict /.pdf_hook_DSC_Creator undef
//true
}ifelse
{
- /setdistillerparams /undefined signalerror
+ /setdistillerparams cvx /undefined signalerror
} if
.setdistillerparams
} bind odef
@@ -885,7 +887,7 @@ currentdict /.pdf_hook_DSC_Creator undef
//true
}ifelse
{
- /currentdistillerparams /undefined signalerror
+ /currentdistillerparams cvx /undefined signalerror
} if
.currentdistillerparams
} bind odef
diff --git a/Resource/Init/gs_res.ps b/Resource/Init/gs_res.ps
index 41214bf3..c531b366 100644
--- a/Resource/Init/gs_res.ps
+++ b/Resource/Init/gs_res.ps
@@ -1075,7 +1075,7 @@ end
% but it still needs to restore the stacks reliably if it fails.
/.findfontop {
{ /Font findresource } stopped {
- pop /findfont $error /errorname get signalerror
+ pop /findfont cvx $error /errorname get signalerror
} if
} bind executeonly odef
/findfont {
@@ -1100,7 +1100,7 @@ end % level2dict
} forall
/.findencoding {
{ /Encoding findresource } stopped {
- pop /findencoding $error /errorname get signalerror
+ pop /findencoding cvx $error /errorname get signalerror
} if
} bind def
/findencoding /.findencoding load def % must be a procedure
diff --git a/Resource/Init/gs_setpd.ps b/Resource/Init/gs_setpd.ps
index 2a333bf7..8d00da5f 100644
--- a/Resource/Init/gs_setpd.ps
+++ b/Resource/Init/gs_setpd.ps
@@ -919,7 +919,7 @@ SETPDDEBUG { (Installing.) = pstack flush } if
.currentpagedevice pop exch
{ .setdevice } stopped {
cleartomark exch pop
- /setpagedevice $error /errorname get
+ /setpagedevice cvx $error /errorname get
signalerror
} if
pop
diff --git a/Resource/Init/gs_statd.ps b/Resource/Init/gs_statd.ps
index 8f01c78c..6751c032 100644
--- a/Resource/Init/gs_statd.ps
+++ b/Resource/Init/gs_statd.ps
@@ -269,10 +269,10 @@ readonly def
% (a Level 1 operator) as accepting the values 0 and 1,
% so we do too.
dup type /integertype ne {
- /setpage /typecheck signalerror
+ /setpage cvx /typecheck signalerror
} {
dup 0 ne 1 index 1 ne or {
- /setpage /rangecheck signalerror
+ /setpage cvx /rangecheck signalerror
} {
{/letter /note} 1 index get
//systemdict /userdict get exch get cvx exec
diff --git a/Resource/Init/gs_ttf.ps b/Resource/Init/gs_ttf.ps
index 95d50c6b..4fcbd69c 100644
--- a/Resource/Init/gs_ttf.ps
+++ b/Resource/Init/gs_ttf.ps
@@ -240,11 +240,25 @@
% <nametable> <nameid> findname false
/findname {
TTFDEBUG { (findname: ) print dup =only } if
- //false 3 1 roll
- 1 index length 0 gt { % check for zero length name table
+ [ //false 4 2 roll
+ {
0 1 3 index 2 getu16 1 sub {
% Stack: false table id index
- 12 mul 6 add 2 index exch 12 getinterval
+ 12 mul 6 add 2 index exch 12
+ % Check the table is actually long enough to contain the requested index
+ 1 index add 2 index length gt
+ {
+ /pdfformaterror where
+ {
+ ( **** TrueType font has malformed name table.\n) exch /pdfformaterror get exec
+ PDFSTOPONERROR {
+ /.loadpdfttfont cvx /invalidfont signalerror
+ } if
+ } if
+ pop pop
+ exit
+ } if
+ 12 getinterval
dup 6 getu16 2 index eq 1 index 8 getu16 0 ne and {
% We found the name we want.
exch pop
@@ -265,8 +279,12 @@
} ifelse
} if pop
} for
- } if
- pop pop
+ } stopped {
+ cleartomark //false
+ } {
+ pop pop
+ counttomark 1 add -1 roll pop
+ } ifelse
TTFDEBUG {
dup { ( = ) print 1 index //== exec } { ( not found) = } ifelse
} if
diff --git a/Resource/Init/pdf_draw.ps b/Resource/Init/pdf_draw.ps
index 8527312c..6ee8f7e7 100644
--- a/Resource/Init/pdf_draw.ps
+++ b/Resource/Init/pdf_draw.ps
@@ -92,10 +92,10 @@ pdfdict begin
exch dup length dict copy % filepos stream fndict2
dup /Function undef % filepos stream fndict2
exch dup token not {
- () /rangecheck cvx signalerror
+ () /rangecheck signalerror
} if
exch token {
- /rangecheck cvx signalerror
+ /rangecheck signalerror
} if
% Use .bind to avoid idiom recognition.
.bind
@@ -529,7 +529,7 @@ end
pdfformaterror
( Output may be incorrect.\n) pdfformaterror
//pdfdict /.gs_warning_issued //true .forceput
- PDFSTOPONERROR { /gs /undefined signalerror } if
+ PDFSTOPONERROR { /gs cvx /undefined signalerror } if
} executeonly if
} executeonly
ifelse
@@ -1758,14 +1758,16 @@ currentdict /jp2_csp_dict .undef
% <resdict> <key> <value> -> <resdict>
/add-to-last-param {
2 index /DecodeParms knownoget {
- dup {} eq {
+ dup type /dicttype ne 1 index type /arrratype ne and 1 index length 1 lt or {
pop //false
} {
//true
} ifelse
} {
//false
- } ifelse {
+ }
+ ifelse
+ {
dup type /arraytype eq {
[ exch { oforce } forall
dup //null eq { pop 1 dict } if
@@ -2180,33 +2182,48 @@ currentdict /last-ditch-bpc-csp undef
%% and don't exhaust memory. Note that we have to copy the actual colour space array too, copying
%% the dictionary just copies the opriginal array as well.
%%
- dup /ColorSpace known {
- dup /ColorSpace get dup type /arraytype eq {
- exch dup length dict copy exch
- dup length array copy /ColorSpace exch 2 index 3 1 roll put
- } {pop} ifelse
- } if
+ 1 dict begin
+ /.ImageDictStackDepth countdictstack def
+ /.ImageOpStackDepth count 2 sub def
+ {
+ dup /ColorSpace known {
+ dup /ColorSpace get dup type /arraytype eq {
+ exch dup length dict copy exch
+ dup length array copy /ColorSpace exch 2 index 3 1 roll put
+ } {pop} ifelse
+ } if
- checkaltimage dup length 6 add dict % <<image>> <<>>
- 1 index /SMask knownoget { % <<image>> <<>> <<sm>>
- dup 3 index ne { % <<image>> <<>> <<sm>> <<sm>>
- 1 index exch /SMask exch put
- } {
- pop
- ( **** Error: ignoring recursive /SMask attribute.\n) pdfformaterror
- ( Output may be incorrect.\n) pdfformaterror
- } ifelse
- } if
- 1 index /Mask knownoget {
- dup type dup /dicttype eq exch /arraytype eq or { % Bug #703681
- 1 index exch /Mask exch put
- } {
- pop
- ( **** Error: Ignoring Mask attribute that is not an array or a dictionary.\n)
- pdfformaterror
- } ifelse
+ checkaltimage dup length 6 add dict % <<image>> <<>>
+ 1 index /SMask knownoget { % <<image>> <<>> <<sm>>
+ dup 3 index ne { % <<image>> <<>> <<sm>> <<sm>>
+ 1 index exch /SMask exch put
+ } {
+ pop
+ ( **** Error: ignoring recursive /SMask attribute.\n) pdfformaterror
+ ( Output may be incorrect.\n) pdfformaterror
+ } ifelse
+ } if
+ 1 index /Mask knownoget {
+ dup type dup /dicttype eq exch /arraytype eq or { % Bug #703681
+ 1 index exch /Mask exch put
+ } {
+ pop
+ ( **** Error: Ignoring Mask attribute that is not an array or a dictionary.\n)
+ pdfformaterror
+ } ifelse
+ } if
+ makeimagedict doimagesmask
+ } PDFSTOPONERROR {exec false}{stopped} ifelse
+ {
+ (\n **** Error: File encountered ')
+ $error /errorname get dup length string cvs concatstrings
+ (' error while processing an image.\n) concatstrings
+ ( Output may be incorrect.\n) concatstrings
+ pdfformaterror
} if
- makeimagedict doimagesmask
+ count .ImageOpStackDepth sub {pop} repeat
+ countdictstack .ImageDictStackDepth sub {end} repeat
+ end
} bind executeonly def
/makemaskimage { % <datasource> <imagemask> <Mask> makemaskimage
% <datasource> <imagemask>, updates currentdict =
@@ -2852,6 +2869,7 @@ currentdict end readonly def
{
%% We are behaving as a printer, check the Print state
/Print .knownget {
+ oforce
/PrintState .knownget {
oforce
/OFF eq {
@@ -2871,6 +2889,7 @@ currentdict end readonly def
/View .knownget {
oforce
/ViewState .knownget {
+ oforce
/OFF eq {
//false
}{
@@ -4331,7 +4350,7 @@ currentdict /set_bc_color undef
scale
dup /InkList knownoget {
{ oforce
- mark exch { oforce } forall
+ [ exch { oforce } forall ]
.pdfinkpath
stroke
} forall
@@ -4695,6 +4714,21 @@ currentdict /set_bc_color undef
/K {setcmykcolor}
>> def
+ % Set some sane defaults, in case the /DA does not.
+ 0 setgray
+ /Helvetica findfont
+ % re-encode the font to PDFDocEncoding
+ dup length dict begin
+ {
+ 1 index /FID ne 2 index /UniqueID ne and { def } { pop pop } ifelse
+ } forall
+ /Encoding /PDFDocEncoding /Encoding findresource def
+ /FontName /Helvetica-PDFDocEncoding def
+ currentdict
+ end
+ /Helvetica-PDFDocEncoding exch definefont
+ 12 scalefont setfont
+
dup /DA knownoget {
length string /tempstr exch def
dup /DA get tempstr copy pop
@@ -4729,21 +4763,7 @@ currentdict /set_bc_color undef
} stopped
{cleartomark setgstate}
{cleartomark pop} ifelse
- } {
- 0 setgray
- /Helvetica findfont
- % re-encode the font to PDFDocEncoding
- dup length dict begin
- {
- 1 index /FID ne 2 index /UniqueID ne and { def } { pop pop } ifelse
- } forall
- /Encoding /PDFDocEncoding /Encoding findresource def
- /FontName /Helvetica-PDFDocEncoding def
- currentdict
- end
- /Helvetica-PDFDocEncoding exch definefont
- 12 scalefont setfont
- }ifelse
+ } if
%% draw the border, if we don't have a border style dictionary, draw a default one.
dup /BS knownoget
diff --git a/Resource/Init/pdf_font.ps b/Resource/Init/pdf_font.ps
index 699c14fe..b42cd4cf 100644
--- a/Resource/Init/pdf_font.ps
+++ b/Resource/Init/pdf_font.ps
@@ -1246,7 +1246,7 @@ setglobal
{
3 index /CharStrings eq
currentdict 3 index known and
- { pstack flush pop pop }
+ { pop pop }
{ systemdict /def get exec }
ifelse
} bind executeonly def
@@ -1301,7 +1301,7 @@ currentdict /eexec_pdf_param_dict .undef
/Resources 1 index /Resources knownoget {
oforce
} {
- LocalResources
+ 0 dict
} ifelse def
/FontBBox 1 index /FontBBox get cvx def
/FontMatrix 1 index /FontMatrix oget def
@@ -1339,8 +1339,9 @@ currentdict /eexec_pdf_param_dict .undef
0 0 0 0 0 0
pdfopdict /d1 get exec
}{
- { //false resolvestream
- % Stack: filepos stream
+ {
+ dup //false resolvestream
+ % Stack: filepos streamdict stream
% Don't let setgcolor set the color inside the BuildGlyph
% procedure, because this causes an /undefined error.
q
@@ -1351,7 +1352,17 @@ currentdict /eexec_pdf_param_dict .undef
%% we use 'nodict'[ to store other PDF state stuff that isn't gstate, and we
%% probably always will, so it may well be more trouble than its worth.
/Dummy //false gput
- Font /Resources get exch pdfopdict
+ Font /Resources get % Stack: filepos streamdict stream resdict
+ dup length 0 eq {
+ 3 -1 roll /Resources knownoget {
+ exch pop
+ ( **** Warning: Type 3 font has resource dictionary in glyph stream.\n)
+ pdfformatwarning
+ } if
+ } {
+ 3 -1 roll pop
+ } ifelse
+ exch pdfopdict
/BuildCharDictDepth countdictstack def
.pdfruncontext
countdictstack BuildCharDictDepth sub
@@ -2740,7 +2751,7 @@ drawopdict begin
{
PDFSTOPONERROR
{
- /typecheck cvx signalerror
+ /typecheck signalerror
}
{
% Bug 689450
@@ -2758,7 +2769,7 @@ drawopdict begin
{
PDFSTOPONERROR
{
- pop /undefined cvx signalerror
+ pop /undefined signalerror
}
{
% Bug 689037
diff --git a/Resource/Init/pdf_main.ps b/Resource/Init/pdf_main.ps
index ded2782a..038c19d1 100644
--- a/Resource/Init/pdf_main.ps
+++ b/Resource/Init/pdf_main.ps
@@ -19,14 +19,14 @@
/.setlanguagelevel where { pop 2 .setlanguagelevel } if
.currentglobal //true .setglobal
pdfdict begin
-/GS_PDF_ProcSet dup load def % keep in pdfdict to hide it
+/GS_PDF_ProcSet dup load def % keep in pdfdict to hide it
userdict /GS_PDF_ProcSet undef
% Patch in an obsolete variable used by some third-party software.
/#? //false def
% Test whether the current output device handles pdfmark.
-/.writepdfmarks { % - .writepdfmarks <bool>
+/.writepdfmarks { % - .writepdfmarks <bool>
/PdfmarkCapable /GetDeviceParam .special_op {
exch pop
}{
@@ -41,7 +41,7 @@ userdict /GS_PDF_ProcSet undef
objopdict { } forall
drawopdict { } forall
/endstream { exit } bind executeonly
- (%%EOF) cvn { exit } bind executeonly % for filters
+ (%%EOF) cvn { exit } bind executeonly % for filters
/obj { ( **** Error: Content stream is not terminated by 'endstream'.\n)
pdfformaterror
( Output may be incorrect.\n) pdfformaterror
@@ -49,7 +49,7 @@ userdict /GS_PDF_ProcSet undef
% PDF 1.1 operators
/BX { /BXlevel BXlevel 1 add store } bind executeonly
/EX { /BXlevel BXlevel 1 sub store } bind executeonly
- /PS { DOPS { cvx exec } { pop } ifelse } bind executeonly % PS disabled by default, as in pdf_draw.ps DoPS
+ /PS { DOPS { cvx exec } { pop } ifelse } bind executeonly % PS disabled by default, as in pdf_draw.ps DoPS
% PDF 1.2 operators
/BMC {
/BMClevel BMClevel 1 add store
@@ -204,7 +204,7 @@ userdict /GS_PDF_ProcSet undef
% ======================== Main program ======================== %
-end % pdfdict
+end % pdfdict
userdict begin
/defaultfontname /Times-Roman def
@@ -217,6 +217,864 @@ DingbatsEncoding pop
% Redefine 'run' so it recognizes PDF files.
systemdict begin
+
+systemdict /NEWPDF known not {/NEWPDF //false def} if
+
+% PostScript interface to the ghostpdf C-based interpreter
+%
+% Promised or documented as used by customers
+% ===========================================
+% runpdf <file> runpdf -
+% Called from the modified run operator (which copies stdin to a temp
+% file if required). Calls runpdfbegin, check for PDF collections. Then
+% calls process_trailer_attrs, runpdfpagerange, dopdfpages and runpdfend
+% to process all the required pages.
+%
+% runpdfbegin <file> runpdfbegin -
+% creates /pdfdict in userdict set userparmas (ProcessDSCComment
+% setobjectformat to 0 /Page# /Page to null DSCPageCount to 0
+% /PDFSave /null.
+% calls pdfopen and then 'begin's the returned dictionary.
+% Also disables page handler device.
+%
+% pdfgetpage <int> pdfgetpage <pagedict> | <null>
+% int is a number from 1 to N indicating the desired page number from
+% the PDF file. Returns a dictionary, apparently the /Page dictionary. Probably
+% we only need the Boxes and Rotate key ? If this fails, returns a null object.
+%
+% pdfshowpage_init <int> pdfshowpage_init <dict>
+% This simply adds 1 to the /DSCPageCount value in the supplied dictioanry
+%
+% pdfshowpage_setpage <pagedict> pdfshowpage_setpage <pagedict>
+% Takes a dictionary as returned from pdfgetpage, extracts various
+% parameters from it, and sets the media size for the page, taking into
+% account the boxes, and requested Box, Rotate value and PDFFitPage.
+%
+% pdfshowpage_finish <pagedict> pdfshowpage_finish -
+% Takes a dictionary as returned from pdfgetpage, renders the page content
+% executes showpage to transfer the rendered content to the device.
+%
+% runpdfend -
+% Uses currentdict as an argument to pdfclose, which closes /PDFfile. Also
+% executes restore and various cleanup activities.
+%
+% Also Used by gsview 5
+% =====================
+% pdfopen <file> pdfopen <dict>
+% According to the comments; open a PDF file and read the header, trailer
+% and cross-reference. Calls pdfopenfile and 'begin's the returned dictionary
+% calls pdfopencache and then closes the current dictionary.
+% pdfopenfile appears to create a dictionary containing a load of stuff but
+% most importantly, sets /PDFfile to the passed-in file. Probably also contains
+% the Trailer dictionary.
+%
+% pdfclose <dict> pdfclose -
+% The supplied dictionary contains /PDFfile and it executes closefile on that
+% supplied file.
+%
+% Supplied by Ray to customer
+% ============================
+% pdfshowpage <pagedict> pdfshowpage
+% Takes a dictionary returned from pdfgetpage and calls the pdfshowpage_init
+% pdfshowpage_setpage, pdfshowpage_finish trio to start the page, set up the
+% media and render the page.
+%
+% dopdfpages <int> <int> dopdfpages -
+% The integers are the first and last pages to be run from the file. Runs a loop from
+% the fist integer to the last. NOTE! If the current dictionary contains a PDFPageList
+% array then we 'get' the entry from the array corresponding to the current loop
+% index, and use that to determine whether we should draw the page. Otherwise we
+% simply draw the page. Uses pdfshowpage to actually render the page.
+%
+% Additionallly useful ?
+% =======================
+% runpdfpagerange - runpdfpagerange <int> <int>
+% Processes the PostScript /FirstPage, /LastPage and /PageList parameters to build an array
+% of page numbers to run (if PageList is present) and a FirstPage and LastPage value.
+% There seems no point in rewriting this, may as well use it to control page processing.
+%
+% Normal operation
+% =================
+% runpdf - runpdfbegin - pdfopen
+% - process_trailer_attrs
+% - runpdfpagerange
+% - dopdfpages - pdfgetpage
+% - pdfshowpage - pdfshowpage_init
+% - pdfshowpage_setpage
+% - pdfshowpage_finish
+% - runpdfend - pdfclose
+%
+
+/DisablePageHandlerDevice
+{
+ systemdict /FirstPage known
+ systemdict /LastPage known or
+ systemdict /PageList known or
+ {
+ <</DisablePageHandler //true>> setpagedevice
+ } if
+} bind def
+
+/EnablePageHandlerDevice
+{
+ systemdict /FirstPage known
+ systemdict /LastPage known or
+ systemdict /PageList known or
+ {
+ <</DisablePageHandler //false>> setpagedevice
+ } if
+} bind def
+
+/newpdf_pdfformaterror { % <string> pdfformaterror -
+ (%stdout) (w) file
+ dup 3 -1 roll writestring flushfile
+} bind executeonly def
+
+% This routine sets up the transparency compositor requirement, and
+% number of spot channels required (if any) in the device. This needs
+% to be done before we set the media size, so that the erasepage is
+% correct. Called with the dictionary returned from .PDFPageInfo
+/newpdf_device_setup
+{
+ 2 dict exch % <<page dict>> << >>
+ dup /UsesTransparency get % << >> <<page dict>> bool
+ /PageUsesTransparency exch % << >> <<page dict>> /PageUsesTransparency bool
+ 3 index 3 1 roll % << >> <<page dict>> <<info dict>> << >> /PageUsesTransparency bool
+ put % <</PageUsesTransparency bool>> <<page dict>>
+ /NumSpots get % <</PageUsesTransparency bool>> int
+ /PageSpotColors exch % <</PageUsesTransparency bool>> /PageSpotColors int
+ 2 index 3 1 roll % <</PageUsesTransparency bool>> <<page dict>> /PageSpotColors int
+ put % <</PageUsesTransparency bool /PageSpotColors int >>
+ setpagedevice
+}bind def
+
+% Takes the selected Box as a parameter and scales it to fit the current media.
+% If the amount of scaling would be reduced by rotating the content, then
+% rotate the content.
+% Caters for the box non-zero lower left x and y (ie cropping)
+/NewPDF_FitPage
+{
+ dup 2 get 1 index 0 get sub %urx -llx = width
+ 1 index 3 get 2 index 1 get sub %ury - lly = height
+
+ currentpagedevice /PageSize get aload pop % Stack - box boxwidth boxheight mediawidth mediaheight
+
+ % Start by deciding if we should rotate the page to better fit the media.
+ 4 copy eq
+ 3 1 roll eq
+ or % square media or square page, no point in rotating
+ {
+ //false
+ }
+ {
+ gt
+ { % landscape media
+ ge
+ { % landscape media, landscape box, no rotation
+ //false
+ }
+ { % landscape media, portrait box, rotate it to landscape
+ //true
+ } ifelse
+ }
+ { % portrait media
+ ge
+ { % portrait media, landscape box, rotate it to portrait
+ //true
+ }
+ { % portrait media, portrait box, no rotation
+ //false
+ } ifelse
+ }ifelse
+ } ifelse
+
+ % Store values for calculating scale, we do this here because we want to
+ % swap the media width and height (for the scale calculation) if we are
+ % rotating the page
+ 1 index 2 get 2 index 0 get sub % urx -llx = width
+ 2 index 3 get 3 index 1 get sub % ury - lly = height
+ currentpagedevice /PageSize get aload pop % Stack - box rotate boxwidth boxheight mediawidth mediaheight
+ 5 -1 roll % Stack - box boxwidth boxheight mediawidth mediaheight rotate
+
+ % If we need to rotate, recalculate the box
+ {
+ 90 rotate
+ 0 2 index neg translate % move 0,0 to bottom right of media to account for rotation
+ exch % swap media width/height for scaling calculation
+ }if
+
+ % Stack - box boxwidth boxheight mediawidth mediaheight
+ % Incorporate up any offset from 0,0
+ 4 index aload pop pop pop neg exch neg exch
+ 2 copy exch
+ translate
+
+ % Now use the box and media values to calculate the required x/y scale factors
+ 3 -1 roll div % box boxwidth mediawidth (mediaheight / boxheight)
+ 3 1 roll % box (mediaheight / boxheight) boxwidth mediawidth
+ exch % box (mediaheight / boxheight) mediawidth boxwidth
+ div % box (mediaheight / boxheight) (mediawidth / boxwidth)
+
+ 2 copy % box Yscale Xscale Yscale Xscale
+ gt {exch} if % select smallest scale factor
+ pop %
+ dup scale % and scale page isomorphically
+ pop pop
+} bind def
+
+/newpdf_get_media_box { % <pagedict> get_media_box <box> <bool>
+ dup /MediaBox known {
+ /MediaBox get
+ dup length 4 eq {
+ //true
+ }
+ {
+ pop
+ ( **** Error: Page has an invalid /MediaBox attribute. Using the current page size.\n)
+ newpdf_pdfformaterror
+ ( Output may be incorrect.\n) pdfformaterror
+ [ 0 0 currentpagedevice /PageSize get aload pop ]
+ //false
+ }ifelse
+ }
+ {
+ pop
+ ( **** Error: Page has no /MediaBox attribute. Using the current page size.\n)
+ newpdf_pdfformaterror
+ ( Output may be incorrect.\n) newpdf_pdfformaterror
+ [ 0 0 currentpagedevice /PageSize get aload pop ] //false
+ } ifelse
+%(newpdf_get_media_box end) == flush
+} bind executeonly def
+
+/newpdf_get_any_box { % <pagedict> get_any_box <box name> <box>
+%(newpdf_get_any_box start) == flush
+ //systemdict /UseBleedBox .knownget dup { and } if {
+ dup /BleedBox get {
+ /BleedBox exch
+ } if
+ } if
+ //systemdict /UseTrimBox .knownget dup { and } if {
+ dup /TrimBox get {
+ /TrimBox exch
+ } if
+ } if
+ dup type /arraytype ne {
+ //systemdict /UseArtBox .knownget dup { and } if {
+ dup /ArtBox get {
+ /ArtBox exch
+ } if
+ } if
+ } if
+ dup type /arraytype ne {
+ //systemdict /UseCropBox .knownget dup { and } if {
+ dup /CropBox get {
+ /CropBox exch
+ } if
+ } if
+ } if
+ dup type /arraytype ne {
+ /MediaBox exch newpdf_get_media_box pop
+ } {
+ %% Complicated stuff. We need to use the 'Box' we identified (if any), but we
+ %% need to clamp the boundaries of the 'Box' to the MediaBox. This appears to
+ %% be what Acrobat does. The complication arises because the Box values don't
+ %% have to be sensibly positive, its permissible to have the MediaBox set up
+ %% so that it extends down and left instead of up and right. We take care of the
+ %% content when we st up the CTM, but we do need to make sure that we clamp
+ %% the BoundingBox, and that means we need to take direcitonality into account...
+
+ 6 -1 roll newpdf_get_media_box { % /SomeBox x0 y0 x1 y1 [MediaBox]
+ aload pop % /SomeBox x0 y0 x1 y1 X0 Y0 X1 Y1
+
+ %% Start with the width, get the X0 and X1 values of the MediaBox
+ 3 index % /SomeBox x0 y0 x1 y1 X0 Y0 X1 Y1 X0
+ 2 index % /SomeBox x0 y0 x1 y1 X0 Y0 X1 Y1 X0 X1
+ gt {
+ %% Media extends to left
+ 4 -1 roll % /SomeBox x0 y0 x1 y1 Y0 X1 Y1 X0
+ 8 -1 roll % /SomeBox y0 x1 y1 Y0 X1 Y1 X0 x0
+ .min % /SomeBox y0 x1 y1 Y0 X1 Y1 mX0
+ 7 1 roll % /SomeBox mX0 y0 x1 y1 Y0 X1 Y1
+ exch % /SomeBox mX0 y0 x1 y1 Y0 Y1 X1
+ 5 -1 roll % /SomeBox mX0 y0 y1 Y0 Y1 X1 x1
+ .max % /SomeBox mX0 y0 y1 Y0 Y1 mX1
+ 5 1 roll % /SomeBox mX0 mX1 y0 y1 Y0 Y1
+ }{
+ %% Media extends to right
+ 4 -1 roll % /SomeBox x0 y0 x1 y1 Y0 X1 Y1 X0
+ 8 -1 roll % /SomeBox y0 x1 y1 Y0 X1 Y1 X0 x0
+ .max % /SomeBox y0 x1 y1 Y0 X1 Y1 mX0
+ 7 1 roll % /SomeBox mX0 y0 x1 y1 Y0 X1 Y1
+ exch % /SomeBox mX0 y0 x1 y1 Y0 Y1 X1
+ 5 -1 roll % /SomeBox mX0 y0 y1 Y0 Y1 X1 x1
+ .min % /SomeBox mX0 y0 y1 Y0 Y1 mX1
+ 5 1 roll % /SomeBox mX0 mX1 y0 y1 Y0 Y1
+ } ifelse
+
+ %% Now deal with the height
+ 2 copy % /SomeBox mX0 mX1 y0 y1 Y0 Y1 Y0 Y1
+ gt {
+ %% Media extends down
+ exch % /SomeBox mX0 mX1 y0 y1 Y1 Y0
+ 4 -1 roll % /SomeBox mX0 mX1 y1 Y1 Y0 y0
+ .min % /SomeBox mX0 mX1 y1 Y1 mY0
+ 3 1 roll % /SomeBox mX0 mX1 mY0 y1 Y1
+ .max % /SomeBox mX0 mX1 mY0 mY1
+ }{
+ %% Media extends up
+ exch % /SomeBox mX0 mX1 y0 y1 Y1 Y0
+ 4 -1 roll % /SomeBox mX0 mX1 y1 Y1 Y0 y0
+ .max % /SomeBox mX0 mX1 y1 Y1 mY0
+ 3 1 roll % /SomeBox mX0 mX1 mY0 y1 Y1
+ .min % /SomeBox mX0 mX1 mY0 mY1
+ } ifelse
+ exch % /SomeBox mX0 mX1 mY1 mY0
+ 3 1 roll % /SomeBox mX0 mY0 mX1 mY1
+ } {
+ pop
+ } ifelse
+ 4 array astore % /SomeBox [mX0 mY0 mX1 mY1]
+ } ifelse
+} bind executeonly def
+
+% This routine is used to set the PostScript /PageSize from the requested Box of the
+% PDF file. Much of this is copied from the old pdfshowpage_setpage routine which
+% is used for the PDF interpreter written in PostScript.
+%
+% Called with a dictionary containing the PDF page information.
+%
+/newpdf_set_pagesize
+{
+ % Stack: pdfpagedict
+
+ % Don't understand this at all, removed for now replace if we ever figure out
+ % what it's for.
+ % Only lock in Orientation if we need to for pdfmarks
+% .writepdfmarks { /Orientation 0 def } if
+
+ dup
+ dup newpdf_get_any_box % Stack: pdfpagedict pdfpagedict /BoxName [box]
+
+ //systemdict /PDFFitPage known {
+ NewPDF_FitPage
+ } {
+ 6 dict begin % for setpagedevice
+
+ % Set the page size.
+ 2 index /UserUnit known
+ {
+ systemdict /NoUserUnit .knownget not {//false} if
+ {
+ 2 index /UserUnit undef
+ % No scaling required, calculate PageSize as the width and height of the box
+ aload 5 1 roll % box llx lly urx ury
+ 2 index sub % box llx lly urx (ury - lly)
+ exch 3 index sub % box llx lly (ury - lly) (urx - llx)
+ exch
+ }
+ {
+ 2 index /UserUnit get
+ % The PageSize needs to be multiplied too
+ exch aload 5 1 roll % UserUnit box llx lly urx ury
+ 2 index sub exch % UserUnit box llx lly (ury - lly) urx
+ 3 index sub % UserUnit box llx lly boxheight boxwidth
+ 5 index mul % UserUnit box llx lly boxheight (Boxwidth*UserUnit)
+ exch
+ 5 index mul % UserUnit box llx lly (Boxwidth*UserUnit) (boxheight*UserUnit)
+ 4 -2 roll
+ 5 index mul exch % UserUnit box (Boxwidth*UserUnit) (boxheight*UserUnit) (lly*UserUnit) llx
+ 5 index mul exch % UserUnit box (Boxwidth*UserUnit) (boxheight*UserUnit) (llx*UserUnit) (lly*UserUnit)
+ 4 2 roll % UserUnit box (llx*UserUnit) (lly*UserUnit) (Boxwidth*UserUnit) (boxheight*UserUnit)
+ 6 -1 roll pop % box (llx*UserUnit) (lly*UserUnit) (Boxwidth*UserUnit) (boxheight*UserUnit)
+ } ifelse
+ }
+ {
+ /PassUserUnit /GetDeviceParam .special_op {
+ exch pop {
+ [ /UserUnit 1 .pdfputparams pop pop
+ } if
+ }if
+ % No scaling required, calculate PageSize as the width and height of the box
+ aload 5 1 roll % box llx lly urx ury
+ 2 index sub % box llx lly urx (ury - lly)
+ exch 3 index sub % box llx lly (ury - lly) (urx - llx)
+ exch
+ } ifelse
+
+ % handle page rotation here
+ 6 index /Rotate known {
+ % PDF page rotation runs clockwise and must be a multiple of 90, unlike PostScript.....
+ % convert Rotate into a quadrant number
+ 6 index /Rotate get 90 div cvi
+ % Make sure quadrant is 0-3
+ dup 0 lt {
+ % Negative rotation... Turn it into a positive rotation
+ % Again, limit the quadrant to -0 to -3
+ dup -4 lt {4 mod} if
+ % Adding 360 degrees results in the same positive rotation
+ 4 add
+ } if
+ dup 3 gt {4 mod} if
+ dup 0 eq
+ {
+ pop
+ 2 array astore /PageSize exch def
+ currentdict end setpagedevice
+ neg exch neg exch
+ translate
+ }
+ {
+ dup 1 eq
+ {
+ pop
+ exch 4 2 roll exch 4 2 roll
+ 2 array astore dup /PageSize exch def
+ currentdict end setpagedevice
+ 270 rotate
+ 1 get add neg exch neg
+ translate
+ }
+ {
+ 2 eq
+ {
+ 2 array astore dup /PageSize exch def
+ currentdict end setpagedevice
+ 180 rotate
+ aload pop 3 -1 roll add neg 3 1 roll add neg exch
+ translate
+ }
+ {
+ exch 4 2 roll exch 4 2 roll
+ 2 array astore dup /PageSize exch def
+ currentdict end setpagedevice
+ 90 rotate
+ 0 get 3 -1 roll add
+ neg exch neg exch
+ translate
+ } ifelse
+ } ifelse
+ } ifelse
+ }
+ {
+ 2 array astore /PageSize exch def
+ currentdict end setpagedevice
+ neg exch neg exch
+ translate
+ }ifelse
+
+ % scale the co-ordinate system by the UserUnit
+ % We have to do this after setting the PageSize, because
+ % setpagedevice does an implicit initgraphics, resetting the CTM.
+ %
+ //systemdict /NoUserUnit .knownget not { //false } if not
+ {
+ 2 index /UserUnit known {
+ 2 index /UserUnit get
+ dup scale
+ } if
+ } if
+ } ifelse
+
+ pop % The box
+
+ % If we are using the MediaBox (and only the MediaBox) then we
+ % want to clip to the CropBox, if there s one present
+
+ /MediaBox eq {
+ dup /CropBox known {
+ /CropBox get
+ aload pop 2 index sub exch 3 index sub exch rectclip
+ } {
+ pop
+ } ifelse
+ } if
+
+ pop
+} bind executeonly def
+
+% This routine checks a list of known/implemented command line switches to see if they
+% have been defined in the PostScript environment. If they have we construct a dictionary
+% containing the names and their values, and return it. That dictionary can then be
+% passed to a custom PostScript operator and used to configure the PDF interpreter.
+%
+% NB device parameters will already have been sent to the device and used to configure it
+% so here we should only handle parameters which control the behaviour of the interpreter.
+%
+/newpdf_gather_parameters
+{
+ 10 dict begin
+ /PDFSwitches [ /PDFPassword /PDFDEBUG /PDFSTOPONERROR /PDFSTOPONWARNING /NOTRANSPARENCY /FirstPage /LastPage
+ /NOCIDFALLBACK /NO_PDFMARK_OUTLINES /NO_PDFMARK_DESTS /PDFFitPage /Printed
+ /UseBleedBox /UseCropBox /UseArtBox /UseTrimBox /ShowAcroForm /ShowAnnots /PreserveAnnots
+ /NoUserUnit /RENDERTTNOTDEF /DOPDFMARKS /PDFINFO /SHOWANNOTTYPES /PRESERVEANNOTTYPES] def
+
+ 0 1 PDFSwitches length 1 sub {
+ PDFSwitches exch get dup where {
+ exch dup 3 1 roll get def
+ }
+ {
+ pop
+ } ifelse
+ } for
+ currentdict /PDFSwitches undef
+ currentdict end
+} bind executeonly def
+
+/newpdf_pagecount
+{
+ PDFFile //null eq not
+ {
+ PDFFile {.PDFInfo} stopped not
+ {
+ dup /NumPages known
+ {
+ /NumPages get
+ }
+ {
+ pop 0
+ } ifelse
+ }
+ {
+ pop 0
+ } ifelse
+ }
+ {
+ 0
+ } ifelse
+}bind def
+
+/newpdf_runpdfpagerange
+{
+ /PageList where {
+ pop PageList
+ (even) anchorsearch {
+ pop length 0 gt {
+ /runpdfpagerange cvx /syntaxerror signalerror
+ } if
+ /PDFPageList pdfpagecount 1 add array def
+ 2 2 pdfpagecount {
+ PDFPageList exch 1 put
+ } for
+ QUIET not {
+ (Processing even-numbered pages\n) print (1 through ) print pdfpagecount =only
+ (.) = flush
+ } if
+ } {
+ (odd) anchorsearch {
+ pop length 0 gt {
+ /runpdfpagerange cvx /syntaxerror signalerror
+ } if
+ /PDFPageList pdfpagecount 1 add array def
+ 1 2 pdfpagecount {
+ PDFPageList exch 1 put
+ } for
+ QUIET not {
+ (Processing odd-numbered pages\n) print (1 through ) print pdfpagecount =only
+ (.) = flush
+ } if
+ } {
+ %% validate string contents, check for digit comma or minus
+ dup
+ {
+ dup 44 eq not {
+ dup 45 eq not {
+ dup 48 lt 1 index 57 gt or {
+ /runpdfpagerange cvx /syntaxerror signalerror
+ } if
+ } if
+ } if
+ pop
+ }
+ forall
+ /PDFPageList pdfpagecount 1 add array def
+ {
+ (,) search {
+ %% We now have (post) (,) (pre)
+ exch pop %% get rid of the (,), leave the (post) as the string for the next iteration, deal with the section up to the comma
+ (-) search {
+ %% Now we have (end) (-) (start)
+ exch pop %% get rid of the minus (end) (start)
+ 0 exch {48 sub exch 10 mul add} forall
+ %% Make sure the start of the range is inside the number of available pages
+ dup pdfpagecount le {
+ exch
+ %% deal with a trailing '-' by replacing it with the number of pages in the file
+ dup length 0 eq {
+ pop pdfpagecount
+ }{
+ 0 exch {48 sub exch 10 mul add} forall
+ } ifelse
+ 1 exch %% start 1 end
+ %% Make sure the end of the range is inside the number of available pages
+ dup pdfpagecount gt {pop pdfpagecount} if
+ {PDFPageList exch 1 put} for
+ } {
+ %% start of range invalid, drop this range.
+ pop pop
+ }ifelse
+ }{
+ %% no minus signs, must be a simple page number
+ 0 exch {48 sub exch 10 mul add} forall
+ %% ensure its in the valid range of pages
+ dup pdfpagecount le {
+ PDFPageList exch 1 put
+ } {
+ pop
+ } ifelse
+ } ifelse
+ }{
+ %% no commas separating pages, just the original string (), deal with its as a section, then exit the loop
+ (-) search {
+ %% Now we have (end) (-) (start)
+ exch pop %% get rid of the minus (end) (start)
+ 0 exch {48 sub exch 10 mul add} forall
+ %% Make sure the start of the range is inside the number of available pages
+ dup pdfpagecount le {
+ exch
+ %% deal with a trailing '-' by replacing it with the number of pages in the file
+ dup length 0 eq {
+ pop pdfpagecount
+ }{
+ 0 exch {48 sub exch 10 mul add} forall
+ } ifelse
+ 1 exch %% start 1 end
+ %% Make sure the end of the range is inside the number of available pages
+ dup pdfpagecount gt {pop pdfpagecount} if
+ {PDFPageList exch 1 put} for
+ } {
+ %% start of range invalid, drop this range.
+ pop pop
+ }ifelse
+ }{
+ %% no minus signs, must be a simple page number
+ 0 exch {48 sub exch 10 mul add} forall
+ %% ensure its in the valid range of pages
+ dup pdfpagecount le {
+ PDFPageList exch 1 put
+ } {
+ pop
+ } ifelse
+ } ifelse
+ exit %% done all the sections.
+ } ifelse
+ } loop
+ QUIET not {
+ (Processing pages ) print PageList =only
+ (.) = flush
+ } if
+ } ifelse
+ } ifelse
+ 1 pdfpagecount
+ }{
+ /FirstPage where {
+ pop FirstPage dup pdfpagecount gt {
+ (\nRequested FirstPage is greater than the number of pages in the file: ) print
+ pdfpagecount = flush
+ } if
+ } {
+ 1
+ } ifelse
+ /LastPage where {pop LastPage pdfpagecount .min } { pdfpagecount } ifelse
+ 1 index 1 index gt {
+ ( No pages will be processed \(FirstPage > LastPage\).) = flush
+ } {
+ QUIET not {
+ (Processing pages ) print 1 index =only ( through ) print dup =only
+ (.) = flush
+ } if
+ } ifelse
+ } ifelse
+} bind def
+
+% <file> runpdf -
+/newpdf_runpdf
+{
+ runpdfbegin % <file> runpdfbegin -
+ PDFInfo /Collection known
+ {
+ PDFInfo /Collection get
+ pdfclose
+ dup length 1 sub 0 2 3 -1 roll
+ {
+ 1 index exch get (r) file runpdf
+ } for
+ pop
+ }
+ {
+ process_trailer_attrs % - process_trailer_attrs -
+ runpdfpagerange % - runpdfpagerange <int> <int>
+ dopdfpages % <int> <int> dopdfpages -
+ runpdfend % - runpdfend -
+ } ifelse
+} bind def
+
+/newpdf_runpdfbegin
+{
+ /pdfdict 10 dict def
+ pdfdict begin
+
+ % This is for the benefit of pdf2dsc which assumes it will be present
+ /Trailer << >> def
+ /PDFSave save def
+ % Define these in the current dictionary, if anyone uses
+ % systemdict then this will be defeated so we'll add extra
+ % code to the systemdict definitions as well.
+ /pdfpagecount /newpdf_pagecount load def
+ /pdfgetpage /newpdf_pdfgetpage load def
+ /pdfshowpage /newpdf_pdfshowpage load def
+ /pdfshowpage_init /newpdf_pdfshowpage_init load def
+ /pdfshowpage_setpage /newpdf_pdfshowpage_setpage load def
+ /pdfshowpage_finish /newpdf_pdfshowpage_finish load def
+ /pdfopen /newpdf_pdfopen load def
+ /pdfclose /newpdf_pdfclose load def
+ /dopdfpages /newpdf_dopdfpages load def
+ /runpdfend /newpdf_runpdfend load def
+ /runpdfpagerange /newpdf_runpdfpagerange load def
+ /process_trailer_attrs /newpdf_process_trailer_attrs load def
+
+ % These are also for the benefit of pdf2dsc, which assumes they
+ % are available.
+ /knownoget {2 copy known {get //true}{pop //false}ifelse} bind def
+ /pget {2 copy known {get //true}{pop //false}ifelse}bind def
+
+ newpdf_gather_parameters
+ {.PDFInit} stopped
+ {
+ /PDFFile //null def
+ /PDFInfo //null def
+ }
+ {
+ /PDFFile exch def
+ pdfopen
+ /PDFInfo exch def
+ pop
+ }ifelse
+} bind def
+
+/newpdf_pdfgetpage
+{
+ PDFFile exch 1 sub {.PDFPageInfo} stopped
+ {
+ pop pop
+ ( **** Error: Couldn't get page info.\n) newpdf_pdfformaterror
+ ( Output may be incorrect.\n) newpdf_pdfformaterror
+ //null
+ } if
+} bind def
+
+/newpdf_process_trailer_attrs
+{
+}bind def
+
+/newpdf_pdfshowpage_init
+{
+ gsave
+} bind def
+
+/newpdf_pdfshowpage_setpage
+{
+ dup newpdf_device_setup
+ dup newpdf_set_pagesize
+} bind def
+
+/newpdf_pdfshowpage_finish
+{
+ /Page# get PDFFile exch 1 sub {.PDFDrawPage} stopped
+ {
+ pop pop
+ ( **** Error: Page drawing error occured.\n) newpdf_pdfformaterror
+ ( Output may be incorrect.\n) newpdf_pdfformaterror
+ } if
+ showpage
+ grestore
+} bind def
+
+/newpdf_pdfshowpage
+{
+ pdfshowpage_init
+ pdfshowpage_setpage
+ pdfshowpage_finish
+} bind def
+
+/newpdf_runpdfend
+{
+ pdfclose
+ PDFSave restore
+ end % pdfdict
+} bind def
+
+/newpdf_pdfopen
+{
+ dup PDFFile //null ne
+ {
+ PDFFile {.PDFStream} stopped
+ {
+ pop pop
+ ( **** Error: Couldn't initialise file.\n) newpdf_pdfformaterror
+ ( Output may be incorrect.\n) newpdf_pdfformaterror
+ <</NumPages 0>>
+ }
+ {
+ PDFFile {.PDFInfo} stopped
+ {
+ pop
+ ( **** Error: Couldn't get page information.\n) newpdf_pdfformaterror
+ ( Output may be incorrect.\n) newpdf_pdfformaterror
+ <</NumPages 0>>
+ } if
+ } ifelse
+ }
+ {
+ pop
+ <</NumPages 0>>
+ } ifelse
+} bind def
+
+/newpdf_pdfclose
+{
+ PDFFile {.PDFClose} stopped
+ {
+ pop
+ } if
+} bind def
+
+% <int> <int> dopdfpages -
+% First Page and then LastPage
+/newpdf_dopdfpages
+{
+ //DisablePageHandlerDevice exec
+ 1 exch
+ {
+ %% If we have a array of pages to render, use it.
+ /PDFPageList where {
+ pop dup PDFPageList exch get 1 eq
+ }
+ {//true} ifelse
+
+ {
+ QUIET not { (Page ) print dup //== exec flush } if
+ dup pdfgetpage
+ dup //null ne {
+ exch 1 index
+ /Page# 3 -1 roll put
+ pdfshowpage
+ } {
+ PDFSTOPONERROR {
+ /dopdfpages cvx /syntaxerror signalerror
+ } {
+ pop pop
+ ( **** Error: page) newpdf_pdfformaterror
+ ( not found.\n) newpdf_pdfformaterror
+ } ifelse
+ } ifelse
+ }{
+ pop
+ }ifelse
+ } for
+ //EnablePageHandlerDevice exec
+} bind def
+
/.runps /run load def
/run {
dup type /filetype ne { (r) file } if
@@ -280,27 +1138,12 @@ systemdict begin
} bind odef
currentdict /runpdfstring .undef
-/DisablePageHandlerDevice
-{
- systemdict /FirstPage known
- systemdict /LastPage known or
- systemdict /PageList known or
+/runpdfbegin { % <file> runpdfbegin -
+ /NEWPDF where {/NEWPDF get} {//true} ifelse
{
- <</DisablePageHandler //true>> setpagedevice
- } if
-} bind def
-
-/EnablePageHandlerDevice
-{
- systemdict /FirstPage known
- systemdict /LastPage known or
- systemdict /PageList known or
+ newpdf_runpdfbegin
+ }
{
- <</DisablePageHandler //false>> setpagedevice
- } if
-} bind def
-
-/runpdfbegin { % <file> runpdfbegin -
userdict begin
% It turns out that the PDF interpreter uses memory more
% effectively if it is run under at least one level of save.
@@ -335,10 +1178,16 @@ currentdict /runpdfstring .undef
//pdfdict begin
pdfopen begin
/CumulativePageCount currentpagedevice /PageCount get def
+ } ifelse
} bind executeonly def
-/runpdfpagerange { % - runpdfpagerange <firstpage#> <lastpage#>
+/runpdfpagerange { % - runpdfpagerange <firstpage#> <lastpage#>
+ /NEWPDF where {/NEWPDF get} {//true} ifelse
+ {
+ newpdf_runpdfpagerange
+ }
+ {
/PortfolioPage where {
pop
PortfolioPage cvi dup pdfpagecount add % a b+1
@@ -382,7 +1231,7 @@ currentdict /runpdfstring .undef
pop PageList
(even) anchorsearch {
pop length 0 gt {
- /runpdfpagerange /syntaxerror cvx signalerror
+ /runpdfpagerange cvx /syntaxerror signalerror
} if
/PDFPageList pdfpagecount 1 add array def
2 2 pdfpagecount {
@@ -395,7 +1244,7 @@ currentdict /runpdfstring .undef
} {
(odd) anchorsearch {
pop length 0 gt {
- /runpdfpagerange /syntaxerror cvx signalerror
+ /runpdfpagerange cvx /syntaxerror signalerror
} if
/PDFPageList pdfpagecount 1 add array def
1 2 pdfpagecount {
@@ -412,7 +1261,7 @@ currentdict /runpdfstring .undef
dup 44 eq not {
dup 45 eq not {
dup 48 lt 1 index 57 gt or {
- /runpdfpagerange /syntaxerror cvx signalerror
+ /runpdfpagerange cvx /syntaxerror signalerror
} if
} if
} if
@@ -518,12 +1367,18 @@ currentdict /runpdfstring .undef
} ifelse
} ifelse
}ifelse
+ }ifelse
} bind executeonly def
/dopdfpages { % firstpage# lastpage# dopdfpages -
- << /PDFScanRules //true >> setuserparams % set scanning rules for PDF vs. PS
+ /NEWPDF where {/NEWPDF get} {//true} ifelse
+ {
+ newpdf_dopdfpages
+ }
+ {
+ << /PDFScanRules //true >> setuserparams % set scanning rules for PDF vs. PS
<< /RenderTTNotdef systemdict
- /RENDERTTNOTDEF get >> setuserparams % Should we render TT /.notdef
+ /RENDERTTNOTDEF get >> setuserparams % Should we render TT /.notdef
1 exch
{
%% If we have a array of pages to render, use it.
@@ -554,10 +1409,16 @@ currentdict /runpdfstring .undef
% Indicate that the number of spot colors is unknown in case the next page
% imaged is a PS file.
currentpagedevice /PageSpotColors known { << /PageSpotColors -1 >> setpagedevice } if
- << /PDFScanRules //null >> setuserparams % restore scanning rules for PS
+ << /PDFScanRules //null >> setuserparams % restore scanning rules for PS
+ } ifelse
} bind executeonly def
/runpdfend {
+ /NEWPDF where {/NEWPDF get} {//true} ifelse
+ {
+ newpdf_runpdfend
+ }
+ {
RepairedAnError
{
printrepairederror
@@ -565,13 +1426,14 @@ currentdict /runpdfstring .undef
Repaired { printrepaired } if
} ifelse
currentdict pdfclose
- end % temporary dict
- end % pdfdict
- end % GS_PDF_ProcSet
+ end % temporary dict
+ end % pdfdict
+ end % GS_PDF_ProcSet
PDFTopSave restore
- end % userdict
- 2 vmreclaim % couldn't hurt
+ end % userdict
+ 2 vmreclaim % couldn't hurt
//EnablePageHandlerDevice exec
+ } ifelse
} bind executeonly def
currentdict /DisablePageHandlerDevice undef
@@ -657,59 +1519,62 @@ currentdict /EnablePageHandlerDevice undef
} if
} bind executeonly def
-/runpdf { % <file> runpdf -
- %% Get the PDF filename (it *must* be a file even if it came from stdin it gets
- %% copied to a temporary file) and store it in pdfdict. We will use this for
- %% hashing fonts to detect if fonts with the same name are from different files.
- %%
- dup currentglobal exch //true setglobal .getfilename exch setglobal /InputPDFFileName exch //pdfdict 3 1 roll .forceput
-
- //runpdfbegin exec
- //pdf_collection_files exec
- dup mark eq {
- pop
- process_trailer_attrs
- //runpdfpagerange exec
- //dopdfpages exec
- //runpdfend exec
- } {
- //runpdfend exec
- ]
- (1 ) 10 string copy exch
- {
- dup type /filetype eq {
- //runpdfbegin exec
- dup /PortfolioPage exch def
- process_trailer_attrs
- //runpdfpagerange exec
- //dopdfpages exec
- //runpdfend exec
- closefile
- } {
- .namestring dup (r) file
- //runpdfbegin exec
- /PortfolioPage 2 index def
- process_trailer_attrs
- //runpdfpagerange exec
- //dopdfpages exec
- //runpdfend exec
- deletefile
- } ifelse
- } forall
- pop
+/runpdf { % <file> runpdf -
+ /NEWPDF where {/NEWPDF get} {//true} ifelse
+ {newpdf_runpdf}
+ {
+ %% Get the PDF filename (it *must* be a file even if it came from stdin it gets
+ %% copied to a temporary file) and store it in pdfdict. We will use this for
+ %% hashing fonts to detect if fonts with the same name are from different files.
+ %%
+ dup currentglobal exch //true setglobal .getfilename exch setglobal /InputPDFFileName exch //pdfdict 3 1 roll .forceput
+ //runpdfbegin exec
+ //pdf_collection_files exec
+ dup mark eq {
+ pop
+ process_trailer_attrs
+ //runpdfpagerange exec
+ //dopdfpages exec
+ //runpdfend exec
+ } {
+ //runpdfend exec
+ ]
+ (1 ) 10 string copy exch
+ {
+ dup type /filetype eq {
+ //runpdfbegin exec
+ dup /PortfolioPage exch def
+ process_trailer_attrs
+ //runpdfpagerange exec
+ //dopdfpages exec
+ //runpdfend exec
+ closefile
+ } {
+ .namestring dup (r) file
+ //runpdfbegin exec
+ /PortfolioPage 2 index def
+ process_trailer_attrs
+ //runpdfpagerange exec
+ //dopdfpages exec
+ //runpdfend exec
+ deletefile
+ } ifelse
+ } forall
+ pop
+ } ifelse
} ifelse
} bind executeonly odef
currentdict /pdf_collection_files .undef
-end % systemdict
+end % systemdict
% Redefine the procedure that the C code uses for running piped input.
% It is OK to use { (%stdin) run } here, because a startjob cannot occur.
/.runstdin {
{ (%stdin) run } execute0
} bind executeonly def
-end % userdict
+end % userdict
pdfdict begin
% ======================== File parsing ======================== %
@@ -731,11 +1596,11 @@ pdfdict begin
/dictlevelcount dictlevelcount 1 sub def
dictlevelcount 0 eq { exit } if
} bind executeonly
- ([) cvn { mark } bind executeonly % ditto
+ ([) cvn { mark } bind executeonly % ditto
(]) cvn dup load
-% /true true % see .pdfexectoken in pdf_base.ps
-% /false false % ibid.
-% /null null % ibid.
+% /true true % see .pdfexectoken in pdf_base.ps
+% /false false % ibid.
+% /null null % ibid.
/R {
1 index type /integertype eq 1 index type /integertype eq and {
/resolveR cvx 3 packedarray cvx
@@ -743,7 +1608,7 @@ pdfdict begin
( **** Error: indirect object reference \(R\) encountered with invalid arguments.) pdfformaterror
( Output may be incorrect.\n) pdfformaterror
} ifelse
- } bind executeonly % see Objects below
+ } bind executeonly % see Objects below
.dicttomark readonly def
% After reading entry count: skip whitespace, exit on a digit
@@ -783,9 +1648,9 @@ pdfdict begin
% Read original version (pre PDF 1.5) of the xref table.
% Note: The position is the location of 'xref'. The current PDFfile
% position is just after the 'XREF'.
-/readorigxref % <pos> readorigxref <trailerdict>
+/readorigxref % <pos> readorigxref <trailerdict>
{
- pop % We do not need the position.
+ pop % We do not need the position.
% First we search this (and any Previous) trailers, looking for
% the /Size of the xref. We use ths to initialise our storage
@@ -825,9 +1690,9 @@ pdfdict begin
% Initialise the objects with the detected Size.
TrailerSize growPDFobjects
PDFfile exch setfileposition
- 0 % Initialize xref table error counter
+ 0 % Initialize xref table error counter
//false % Have we seen at least one section entry in this xref ? Bug #694342
- { PDFfile token pop % first object # or trailer
+ { PDFfile token pop % first object # or trailer
dup /trailer eq {
%% check to see if we have seen at least an empty section for this xref
pop {exit}
@@ -841,7 +1706,7 @@ pdfdict begin
%% remove the boolean telling us if we have a section or not, leaving the first object number
exch pop
} ifelse
- PDFfile token pop % entry count
+ PDFfile token pop % entry count
% remaining must be whitespace only (otherwise this xref Size was invalid.
{ PDFfile (0) .peekstring not { pop exit } if
@@ -864,7 +1729,7 @@ pdfdict begin
PDFSTOPONERROR not {
(**** Warning: Discovered more entries in xref than declared in trailer /Size\n) pdfformatwarning
} {
- /readorigxref cvx /rangecheckerror signalerror
+ /readorigxref cvx /rangecheck signalerror
} ifelse
} if
% We now know that the /Size was wrong. We could read the whole table
@@ -875,13 +1740,13 @@ pdfdict begin
1 index 65534 add dup /TrailerSize exch def
growPDFobjects
} if
- { % stack: <err count> <obj num>
+ { % stack: <err count> <obj num>
% Read xref line
PDFfile 20 string readstring pop % always read 20 chars.
- token pop % object position
- exch token pop % generation #
- exch token pop % n or f
- exch % stack: <err count> <obj#> <loc> <gen#> <tag> <remainder of line>
+ token pop % object position
+ exch token pop % generation #
+ exch token pop % n or f
+ exch % stack: <err count> <obj#> <loc> <gen#> <tag> <remainder of line>
% check to make sure trailing garbage is just white space
//false 1 index { 32 gt or } forall {
6 -1 roll 1 add 6 1 roll % bump error count on garbage
@@ -895,20 +1760,20 @@ pdfdict begin
length
PDFfile fileposition exch sub PDFfile exch setfileposition
} if
- pop % Stack: <err count> <obj#> <loc> <gen#> <tag>
- dup /n eq { % xref line tag is /n
- pop % pop dup of line tag
+ pop % Stack: <err count> <obj#> <loc> <gen#> <tag>
+ dup /n eq { % xref line tag is /n
+ pop % pop dup of line tag
1 index 0 eq {
( **** Warning: considering '0000000000 XXXXX n' as a free entry.\n)
pdfformatwarning
} {
- 0 3 1 roll % Set ObjectStream object number = 0
- //false setxrefentry % Save xref entry, don't change existing entries
- 3 -1 roll pop % Remove ObjectStream object onumber
+ 0 3 1 roll % Set ObjectStream object number = 0
+ //false setxrefentry % Save xref entry, don't change existing entries
+ 3 -1 roll pop % Remove ObjectStream object onumber
} ifelse
}
- { % xref line tag was not /n
- /f ne % verify that the tag was /f
+ { % xref line tag was not /n
+ /f ne % verify that the tag was /f
{ /setxrefentry cvx /syntaxerror signalerror
} {
% Bug #703214 has a invalid initial xref table. The table entries are correct
@@ -930,11 +1795,11 @@ pdfdict begin
}if
}ifelse
} ifelse
- pop pop % pop <obj location> and <gen num>
+ pop pop % pop <obj location> and <gen num>
% stack: <err count> <obj num>
- 1 add % increment object number
+ 1 add % increment object number
} repeat
- pop % pop <obj #>
+ pop % pop <obj #>
//true % We have seen at least one entry in an xref section Bug #694342
} loop
0 ne {
@@ -952,60 +1817,60 @@ currentdict /xref-char-dict undef
(<<) cvn { /dictlevelcount dictlevelcount 1 add def mark } bind executeonly
(>>) cvn { .dicttomark /dictlevelcount dictlevelcount 1 sub def
dictlevelcount 0 eq { exit} if } bind executeonly
- ([) cvn { mark } bind executeonly % ditto
+ ([) cvn { mark } bind executeonly % ditto
(]) cvn dup load
-% /true true % see .pdfexectoken in pdf_base.ps
-% /false false % ibid.
-% /null null % ibid.
- /R { /resolveR cvx 3 packedarray cvx } bind executeonly % see Objects below
+% /true true % see .pdfexectoken in pdf_base.ps
+% /false false % ibid.
+% /null null % ibid.
+ /R { /resolveR cvx 3 packedarray cvx } bind executeonly % see Objects below
.dicttomark readonly def
% Get a variable length positive integer value from a stream. A value
% of zero is returned if the count is zero.
-/getintn { % <stream> <count> getintn int
+/getintn { % <stream> <count> getintn int
0 exch { 256 mul 1 index read pop add } repeat
- exch pop % Discard stream
+ exch pop % Discard stream
} bind executeonly def
% This array contains handlers for processing the different types of
% entries in the XRef stream.
% Stack: <Xrefdict> <xref stream> <Index array> <pair loc> <obj num>
-% <field 2> <field 3>
+% <field 2> <field 3>
% The handlers leave the stack unchanged.
/xref15entryhandlers [
- { % XRef entry type 0 - free or f type xref entry
+ { % XRef entry type 0 - free or f type xref entry
% (free ) print
% (obj num: ) print 2 index pdfstring cvs print ( ) print
% (loc: ) print 1 index pdfstring cvs print ( ) print
% (gen: ) print dup === flush
- } bind executeonly % Do nothing for free xref entries
+ } bind executeonly % Do nothing for free xref entries
% XRef entry type 1 - normal or n type xref entry
- { % field 2 = obj loc, field 3 = gen num
+ { % field 2 = obj loc, field 3 = gen num
% (normal ) print
% (obj num: ) print 2 index pdfstring cvs print ( ) print
% (loc: ) print 1 index pdfstring cvs print ( ) print
% (gen: ) print dup === flush
- 0 3 1 roll % set stream number = 0
+ 0 3 1 roll % set stream number = 0
//false setxrefentry
- 3 -1 roll pop % remove stream number
+ 3 -1 roll pop % remove stream number
} bind executeonly
% XRef entry type 2 - compressed object type xref entry
- { % field 2 = object stream num, field 3 = index into object stream
+ { % field 2 = object stream num, field 3 = index into object stream
% (Compressed objects: ) print
% (obj num: ) print 2 index pdfstring cvs print ( ) print
% (field 2: ) print 1 index pdfstring cvs print ( ) print
% (field 3: ) print dup === flush
- 0 //false setxrefentry pop % set generation number = 0
+ 0 //false setxrefentry pop % set generation number = 0
} bind executeonly
] def
% Read the PDF 1.5 version of the xref table.
% Note: The position is the location of the start of the dictionary object
% In PDF 1.5, the XRef dictionary also serves as the trailer dictionary
-/readpdf15xref % <pos> readpdf15xref <trailerdict>
+/readpdf15xref % <pos> readpdf15xref <trailerdict>
{
/Classic-xref //false store
- PDFfile exch setfileposition % move to start of object
+ PDFfile exch setfileposition % move to start of object
% Get object number, revision, and 'obj' and discard
//false PDFfile token {
type /integertype eq {
@@ -1043,47 +1908,47 @@ currentdict /xref-char-dict undef
} if
growPDFobjects
% Create a stream for the XRef data
- PDFfile token pop pop % Skip over 'stream'
+ PDFfile token pop pop % Skip over 'stream'
dup stream //false resolvestream
% Stack: <XRefdict> <xref stream>
% The Index array defines the ranges of object numbers in the
% XRef stream. Each value pair is consists of starting object
% number and the count of consecutive objects.
% Get the Index array, if present
- 1 index /Index .knownget not { % If no Index array ...
- [ 0 3 index /Size get ] % Default = [ 0 Size ]
+ 1 index /Index .knownget not { % If no Index array ...
+ [ 0 3 index /Size get ] % Default = [ 0 Size ]
} if
% Loop through the Index array
0 2 2 index length 1 sub {
% Get start and end of object range
- 2 copy get % Start of the range
- dup 3 index 3 index 1 add get % Number of entries in range
+ 2 copy get % Start of the range
+ dup 3 index 3 index 1 add get % Number of entries in range
% Loop through the range of object numbers
- add 1 sub 1 exch { % Form end of range, set increment = 1
+ add 1 sub 1 exch { % Form end of range, set increment = 1
% Stack: <Xrefdict> <xref stream> <Index array> <pair loc> <obj num>
% Get xref parameters. Note: The number of bytes for each parameter
% is defined by the entries in the W array.
- 4 index /W get aload pop % Get W array values
+ 4 index /W get aload pop % Get W array values
% The first field indicates type of entry. Get first field value.
% If the num. of bytes for field 1 is 0 then default field value is 1
3 -1 roll dup 0 eq { pop 1 } { 6 index exch getintn } ifelse
% Get the handler for the xref entry type. We will execute the
% handler after we get the other two field values.
xref15entryhandlers exch get
- 3 -1 roll 6 index exch getintn % Get second field
- 3 -1 roll 6 index exch getintn % Get third field
- 3 -1 roll exec % Execute Xref entry handler
- pop pop pop % Remove field values and obj num
- } for % Loop through Xref entries
- pop % Remove Index array pair loc
- } for % Loop through Index array entries
- pop pop % Remove Index array and xref stream
+ 3 -1 roll 6 index exch getintn % Get second field
+ 3 -1 roll 6 index exch getintn % Get third field
+ 3 -1 roll exec % Execute Xref entry handler
+ pop pop pop % Remove field values and obj num
+ } for % Loop through Xref entries
+ pop % Remove Index array pair loc
+ } for % Loop through Index array entries
+ pop pop % Remove Index array and xref stream
} bind executeonly def
% Read the cross-reference table.
% <pos> is the position either from the startxref statement or the /Prev
% entry in the prior trailer dictionary.
-/readxref % <pos> readxref <trailerdict>
+/readxref % <pos> readxref <trailerdict>
{
PDFoffset add PDFfile exch
% Check that the given location is within the file.
@@ -1098,7 +1963,7 @@ currentdict /xref-char-dict undef
{
PDFfile fileposition PDFfile read pop 32 gt { exit } if pop
} loop
- dup % Make copy of the file position (before last char was read).
+ dup % Make copy of the file position (before last char was read).
PDFfile exch setfileposition
% The PDF specification says that the 'xref' must be on a line
% by itself. The code here formerly used readline and linene to
@@ -1108,7 +1973,7 @@ currentdict /xref-char-dict undef
PDFfile pdfstring 0 4 getinterval readstring pop
(xref) eq
{
- readorigxref % 'xref' -> original xref table
+ readorigxref % 'xref' -> original xref table
% if hybrid-reference PDF, also fetch the entries
% found in the XRef stream pointed by /XRefStm
dup /XRefStm knownoget {
@@ -1130,12 +1995,17 @@ currentdict /xref-char-dict undef
}ifelse
} if
}
- { readpdf15xref } % otherwise assume PDF 1.5 xref stream
+ { readpdf15xref } % otherwise assume PDF 1.5 xref stream
ifelse
} bind executeonly def
% Open a PDF file and read the header, trailer, and cross-reference.
-/pdfopen { % <file> pdfopen <dict>
+/pdfopen { % <file> pdfopen <dict>
+ /NEWPDF where {/NEWPDF get} {//true} ifelse
+ {
+ newpdf_pdfopen
+ }
+ {
% Color space substitution in PDF is handled somewhat differently
% than in PostScript. A given device color space will be substituted
% if the corresponding "Default..." entry exists in the Page's
@@ -1151,17 +2021,18 @@ currentdict /xref-char-dict undef
% respectively. This is not done if UseCIEColor is true by default,
% as in that case color substitution is presumably desired even
% if the file does not request it.
- currentpagedevice /UseCIEColor .knownget dup { pop } if not
+ currentpagedevice /UseCIEColor .knownget dup { pop } if not
{ .currentglobal //false .setglobal
/DefaultGray { /DeviceGray } cvlit /ColorSpace defineresource pop
/DefaultRGB { /DeviceRGB } cvlit /ColorSpace defineresource pop
/DefaultCMYK { /DeviceCMYK } cvlit /ColorSpace defineresource pop
.setglobal
}
- if
- pdfopenfile begin
- pdfopencache
- currentdict end
+ if
+ pdfopenfile begin
+ pdfopencache
+ currentdict end
+ } ifelse
} bind executeonly def
/process_trailer_attrs { % - process_trailer_attrs -
@@ -1396,38 +2267,38 @@ currentdict /xref-char-dict undef
% Verify that each entry in the xref table is pointing at an object with
% the correct object number and generation number.
-/verify_xref % - verify_xref -
+/verify_xref % - verify_xref -
{ PDFfilelen
- 1 1 Objects length 1 sub % stack: filesize 1 1 <number of objects - 1>
- { % Check if the object is free (i.e. not used). The values in
+ 1 1 Objects length 1 sub % stack: filesize 1 1 <number of objects - 1>
+ { % Check if the object is free (i.e. not used). The values in
% Generations is the generation number plus 1. If the value in
% Generations is zero then the object is free.
% Stack: <filesize> <obj num>
- Generations 1 index get % Get the genration number
- 0 ne { % Skip if object number is free
- ObjectStream 1 index get % Check if object is in objectstream
- 0 eq { % We only check objects not in an objectstream
- { % Use stop context since we may get an error if object is invalid
- dup Objects exch get % Get the object location
- PDFoffset add dup 3 index ge % Compare object location to file size
- { pop //true } % Rebuild if location not in file
+ Generations 1 index get % Get the genration number
+ 0 ne { % Skip if object number is free
+ ObjectStream 1 index get % Check if object is in objectstream
+ 0 eq { % We only check objects not in an objectstream
+ { % Use stop context since we may get an error if object is invalid
+ dup Objects exch get % Get the object location
+ PDFoffset add dup 3 index ge % Compare object location to file size
+ { pop //true } % Rebuild if location not in file
{ PDFfile exch setfileposition % Go to the object location
- //true % Stack: <filesize> <obj num> <true>
- PDFfile token pop % Read object number from file
- 2 index eq { % Verify object number
- PDFfile token pop % Read generation number from file
- Generations 3 index % Get specified generaton number
- get 1 sub % Gen numbs are stored with 1 added.
- eq { % Verify generation number
+ //true % Stack: <filesize> <obj num> <true>
+ PDFfile token pop % Read object number from file
+ 2 index eq { % Verify object number
+ PDFfile token pop % Read generation number from file
+ Generations 3 index % Get specified generaton number
+ get 1 sub % Gen numbs are stored with 1 added.
+ eq { % Verify generation number
PDFfile token pop
/obj eq { % Verify 'obj' text
- pop //false % We have valid object, do not rebuild
+ pop //false % We have valid object, do not rebuild
} if
} if
} if
} ifelse
} //.internalstopped exec
- { //true } if % If we stop then we need to rebuild
+ { //true } if % If we stop then we need to rebuild
% Stack: <filesize> <obj num> <need rebuild flag>
{
( **** Warning: File has an invalid xref entry: )
@@ -1436,31 +2307,31 @@ currentdict /xref-char-dict undef
(. Rebuilding xref table.\n) pdfformatwarning
search_objects
exit
- } if % If the entry is invalid
+ } if % If the entry is invalid
} {
% The object is in an object stream. We currently do not rebuild
% objects in an object stream. So If we find one, then abort the
% verification of the xref table entries.
- pop exit % Pop object number and then exit loop
- } ifelse % If not in an object stream
- } if % If object entry is not free
- pop % Remove object number
+ pop exit % Pop object number and then exit loop
+ } ifelse % If not in an object stream
+ } if % If object entry is not free
+ pop % Remove object number
} for
- pop % Remove the size of the file
+ pop % Remove the size of the file
} bind odef
-/pdfopencache { % - pdfopencache -
+/pdfopencache { % - pdfopencache -
% Create and initialize some caches.
/PageCount pdfpagecount def
/PageNumbers PageCount 65534 .min dict def
/PageIndex PageCount 65534 .min array def
} bind executeonly def
-/pdfopenfile { % <file> pdfopenfile <dict>
- //pdfdict readonly pop % can't do it any earlier than this
+/pdfopenfile { % <file> pdfopenfile <dict>
+ //pdfdict readonly pop % can't do it any earlier than this
32 dict begin
/LocalResources 0 dict def
- /DefaultQstate //null def % establish binding
+ /DefaultQstate //null def % establish binding
/Printed where { pop } {
% Guess whether the output device is a printer.
/Printed currentpagedevice /OutputFile known def
@@ -1497,11 +2368,11 @@ currentdict /xref-char-dict undef
% some badly formed PDF's (Visioneer) have something other than EOL
% after the version number. If we get an error, shorten the string
% and try again.
- //false exch % error encountered
+ //false exch % error encountered
{ { cvr } stopped
{ exch pop //true exch 0 1 index length 1 sub dup 0 eq
- { pop 0 exit } if % exit if string now empty
- getinterval % trim character from right end and retry
+ { pop 0 exit } if % exit if string now empty
+ getinterval % trim character from right end and retry
}
{ exch {
( **** Warning: PDF version number not followed by EOL.\n)
@@ -1516,12 +2387,12 @@ currentdict /xref-char-dict undef
/PDFversion exch def
% Read the last cross-reference table.
count /pdfemptycount exch def
- /Trailer << >> def % Initialize to an emptry dict.
+ /Trailer << >> def % Initialize to an emptry dict.
{initPDFobjects findxref readxref}
PDFSTOPONERROR not {
//.internalstopped exec {
- recover_xref_data % Read failed. Attempt to recover xref data.
- search_trailer % Search for the primary trailer
+ recover_xref_data % Read failed. Attempt to recover xref data.
+ search_trailer % Search for the primary trailer
//false % search_trailer sets up /Trailer, so don't run the code to do that...
} {
//true
@@ -1531,14 +2402,14 @@ currentdict /xref-char-dict undef
} ifelse
{
- /Trailer exch def % Save trailer dict after first xref table
+ /Trailer exch def % Save trailer dict after first xref table
% Read any previous cross-reference tables. When we are done,
% verify that the entries in the xref tables are valid if NoVerifyXref
% is not defined.
/PrevArray [] def % Empty array, we use this to detect circular /Prev entries in xref (see below)
% For some reqason, leaving this on the stack messes up seom files.
Trailer
- { /Prev knownoget not { % If no previous xref table then ...
+ { /Prev knownoget not { % If no previous xref table then ...
Classic-xref {
/NoVerifyXref where { pop } { verify_xref } ifelse
} if
@@ -1563,7 +2434,7 @@ currentdict /xref-char-dict undef
(\n **** Error: Circular /Prev entry while reading xref.\n Aborting xref read, output may be incorrect.\n)
pdfformaterror
PDFSTOPONERROR {
- /readxref /syntaxerror cvx signalerror
+ /readxref cvx /syntaxerror signalerror
} if
pop exit %% [...] and then exit this loop
} if
@@ -1579,10 +2450,10 @@ currentdict /xref-char-dict undef
{ readxref }
PDFSTOPONERROR not {
//.internalstopped exec {
- recover_xref_data % Read failed. Attempt to recover xref data.
+ recover_xref_data % Read failed. Attempt to recover xref data.
/PrevArray where {/PrevArray undef} if %% remove the array we were using to detect circular references
- exit % Exit loop since recover gets all obj data.
- } if % If readxref stopped
+ exit % Exit loop since recover gets all obj data.
+ } if % If readxref stopped
} {
exec
} ifelse
@@ -1598,7 +2469,7 @@ currentdict /xref-char-dict undef
Trailer 3 1 roll put % add key if not present
} ifelse
} forall
- } loop % Loop to previous trailer
+ } loop % Loop to previous trailer
/PrevArray where {/PrevArray undef} if %% remove the array we were using to detect circular references
} if
@@ -1609,7 +2480,7 @@ currentdict /xref-char-dict undef
<< /PDFScanUnsigned //true >> setuserparams
{ Trailer /Encrypt knownoget {
pop
- pdf_process_Encrypt % signal error
+ pdf_process_Encrypt % signal error
} if
} stopped
<< /PDFScanUnsigned //false >> setuserparams
@@ -1668,7 +2539,7 @@ currentdict /xref-char-dict undef
% appended to the PDF file. Current record (60K) belongs to
% PDF-Out (v 2.0 - 35). We start the search from the last 1024
% bytes and continue from the beginning of the file.
-/findxref { % - findxref <xrefpos>
+/findxref { % - findxref <xrefpos>
PDFfile dup dup dup 0 setfileposition bytesavailable
dup /PDFfilelen exch def
% Find the last %%EOF string (within 1024 bytes)
@@ -1704,13 +2575,13 @@ currentdict /xref-char-dict undef
//stdoutfile dup 3 -1 roll writestring flushfile
} bind executeonly def
-/pdfformaterror { % <string> pdfformaterror -
+/pdfformaterror { % <string> pdfformaterror -
stdoutprint
/Repaired //true store
/RepairedAnError //true store
} bind executeonly def
-/pdfformatwarning { % <string> pdfformaterror -
+/pdfformatwarning { % <string> pdfformaterror -
QUIET not {stdoutprint}{pop}ifelse
/Repaired //true store
PDFSTOPONWARNING {/warning cvx /undefined signalerror} if
@@ -1789,7 +2660,7 @@ currentdict /xref-char-dict undef
% Write the outline structure for a file. Uses linkdest (below).
% omit links to pages that don't exist.
-/writeoutline % <outlinedict> writeoutline -
+/writeoutline % <outlinedict> writeoutline -
{ mark
0 2 index /First knownoget
{ { exch 1 add exch /Next knownoget not { exit } if } loop }
@@ -1850,7 +2721,7 @@ currentdict /xref-char-dict undef
linkdest
} stopped
{
- cleartomark % ignore this link
+ cleartomark % ignore this link
( **** Warning: Outline has invalid link that was discarded.\n)
pdfformatwarning
} {
@@ -1869,7 +2740,7 @@ currentdict /xref-char-dict undef
} bind executeonly def
% Close a PDF file.
-/pdfclose % <dict> pdfclose -
+/pdfclose % <dict> pdfclose -
{ begin
PDFfile closefile
end
@@ -1878,7 +2749,7 @@ currentdict /xref-char-dict undef
% ======================== Page accessing ======================== %
% Get a (possibly inherited) attribute of a page.
-/pget % <pagedict> <key> pget <value> -true-
+/pget % <pagedict> <key> pget <value> -true-
% <pagedict> <key> pget -false-
{
2 copy knownoget
@@ -1928,10 +2799,10 @@ currentdict /xref-char-dict undef
4 index .knownget {
0 get 5 1 roll pop pop pop pop
} {
- parent_obj_get % not found -- check it's parent.
+ parent_obj_get % not found -- check it's parent.
} ifelse
} {
- parent_obj_get % not found -- check it's parent.
+ parent_obj_get % not found -- check it's parent.
} ifelse
} {
pop pop 0
@@ -1956,7 +2827,7 @@ currentdict /xref-char-dict undef
0 get 4 1 roll pop pop pop
}{
% Not in Page Resources, recursively try ParentResources as a last resort
- pop % page Resources
+ pop % page Resources
LocalResources parent_obj_get
}ifelse
}{
@@ -1971,7 +2842,7 @@ currentdict /xref-char-dict undef
}bind executeonly def
% Get the value of a resource on a given page.
-/rget { % <resname> <pagedict> <restype> rget <value> -true-
+/rget { % <resname> <pagedict> <restype> rget <value> -true-
% <resname> <pagedict> <restype> rget -false-
LocalResources 1 index knownoget {
3 index knownoget
@@ -2007,7 +2878,7 @@ currentdict /xref-char-dict undef
} bind executeonly def
% Get the total number of pages in the document.
-/pdfpagecount % - pdfpagecount <int>
+/pdfpagecount % - pdfpagecount <int>
{
Trailer /Root knownoget {
/Pages knownoget {
@@ -2023,7 +2894,7 @@ currentdict /xref-char-dict undef
exch pop
//null eq { exit } { pop } ifelse
} for
- 1 sub % decrement to last page that we were able to find
+ 1 sub % decrement to last page that we were able to find
2 copy /Count exch put
} {
0 % return 0 and keep 0 page count.
@@ -2104,11 +2975,11 @@ currentdict /xref-char-dict undef
} if
} bind executeonly def
-/pdffindpage? { % <int> pdffindpage? 1 null (page not found)
+/pdffindpage? { % <int> pdffindpage? 1 null (page not found)
% <int> pdffindpage? 1 noderef (page found)
- % <int> pdffindpage? 0 null (Error: page not found)
+ % <int> pdffindpage? 0 null (Error: page not found)
Trailer /Root oget /Pages get
- { % We should be able to tell when we reach a leaf
+ { % We should be able to tell when we reach a leaf
% by finding a Type unequal to /Pages. Unfortunately,
% some files distributed by Adobe lack the Type key
% in some of the Pages nodes! Instead, we check for Kids.
@@ -2138,7 +3009,7 @@ currentdict /xref-char-dict undef
% Find the N'th page of the document by iterating through the Pages tree.
% The first page is numbered 1.
-/pdffindpageref { % <int> pdffindpage <objref>
+/pdffindpageref { % <int> pdffindpage <objref>
dup pdffindpage?
% Stack: index countleft noderef
dup //null ne {
@@ -2147,21 +3018,21 @@ currentdict /xref-char-dict undef
PageIndex 2 index 1 sub 65533 .min 2 index oforce put
PageNumbers 1 index oforce 3 index dup 65534 le
{ put }
- { pop pop pop } % don't store more than 65534 pagenumbers
+ { pop pop pop } % don't store more than 65534 pagenumbers
ifelse
} {
- exch pop % return the //null
+ exch pop % return the //null
}
ifelse
- exch pop % pop the page number, return the object or null
+ exch pop % pop the page number, return the object or null
} bind executeonly def
-/pdffindpage { % <int> pdffindpage <pagedict>
+/pdffindpage { % <int> pdffindpage <pagedict>
pdffindpageref oforce
} bind executeonly def
% Find the N'th page of the document.
% The first page is numbered 1.
-/pdfgetpage % <int> pdfgetpage <pagedict>
+/pdfgetpage % <int> pdfgetpage <pagedict>
{ PageIndex 1 index 1 sub dup 65533 lt
{ get }
{ pop pop //null }
@@ -2173,12 +3044,12 @@ currentdict /xref-char-dict undef
} bind executeonly def
% Find the page number of a page object (inverse of pdfgetpage).
-/pdfpagenumber % <pagedict> pdfpagenumber <int>
- { % We use the simplest and stupidest of all possible algorithms....
+/pdfpagenumber % <pagedict> pdfpagenumber <int>
+ { % We use the simplest and stupidest of all possible algorithms....
PageNumbers 1 index .knownget
{ exch pop
}
- { 1 1 PageCount 1 add % will give a rangecheck if not found
+ { 1 1 PageCount 1 add % will give a rangecheck if not found
{ dup pdfgetpage oforce 2 index eq { exit } if pop
}
for exch pop
@@ -2198,15 +3069,15 @@ currentdict /xref-char-dict undef
} if
4 1 roll
} repeat
- exch 4 1 roll % <x2> <x1> <y1> <y2>
- 2 copy gt { exch } if % <x2> <x1> <lly> <ury>
- 4 2 roll 2 copy lt { exch } if % <lly> <ury> <urx> <llx>
- 4 1 roll exch % <llx> <lly> <urx> <ury>
+ exch 4 1 roll % <x2> <x1> <y1> <y2>
+ 2 copy gt { exch } if % <x2> <x1> <lly> <ury>
+ 4 2 roll 2 copy lt { exch } if % <lly> <ury> <urx> <llx>
+ 4 1 roll exch % <llx> <lly> <urx> <ury>
} bind executeonly def
% Arrange a rectangle into a 'normal' order. I.e the lower left corner
% followed by the upper right corner.
-/normrect % <rect> normrect <rect>
+/normrect % <rect> normrect <rect>
{
aload pop normrect_elems 4 array astore
} bind executeonly def
@@ -2223,10 +3094,10 @@ currentdict /xref-char-dict undef
} ifelse
} bind executeonly def
-/boxrect % <llx> <lly> <urx> <ury> boxrect <x> <y> <w> <h>
+/boxrect % <llx> <lly> <urx> <ury> boxrect <x> <y> <w> <h>
{ exch 3 index sub exch 2 index sub
} bind executeonly def
-/resolvedest { % <name|string|other> resolvedest <other|null>
+/resolvedest { % <name|string|other> resolvedest <other|null>
dup type /nametype eq {
Trailer /Root oget /Dests knownoget {
exch knownoget not { //null } if
@@ -2298,9 +3169,9 @@ currentdict /xref-char-dict undef
} ifelse
} ifelse
3 1 roll
- 2 copy 7 -1 roll 1 and 0 ne { exch } if 4 2 roll % odd rotation switches x<->y
- 2 { dup //null eq { pop 0 } if exch } repeat % replace nulls with 0
- 7 -1 roll transform % transform coordinates
+ 2 copy 7 -1 roll 1 and 0 ne { exch } if 4 2 roll % odd rotation switches x<->y
+ 2 { dup //null eq { pop 0 } if exch } repeat % replace nulls with 0
+ 7 -1 roll transform % transform coordinates
2 { 3 -1 roll //null eq { pop //null } if exch } repeat % put the nulls back
3 -1 roll
4 array astore
@@ -2314,7 +3185,7 @@ currentdict /xref-char-dict undef
} bind executeonly def
end readonly def
-/linkdest { % <link|outline> linkdest
+/linkdest { % <link|outline> linkdest
% ([/Page <n>] /View <view> | ) <link|outline>
dup /NewWindow knownoget {
/NewWindow exch 3 -1 roll
@@ -2341,11 +3212,11 @@ end readonly def
} if
} if
} if
- % stack: <link|outline> <dest> ( <PDF2PS_matrix> <rot> <page#> true | <page> false )
+ % stack: <link|outline> <dest> ( <PDF2PS_matrix> <rot> <page#> true | <page> false )
{
- /Page exch 6 2 roll
+ /Page exch 6 2 roll
% stack: [/Page <page#>] <link|outline> <dest> <PDF2PS_matrix> <rot>
- 3 -1 roll dup length 1 sub 1 exch getinterval /View 4 1 roll
+ 3 -1 roll dup length 1 sub 1 exch getinterval /View 4 1 roll
% stack: [/Page <page#>] <link|outline> /View <PDF2PS_matrix> <rot> <view>
//viewdestprocs 1 index 0 get get exec
3 -1 roll
@@ -2393,17 +3264,17 @@ end readonly def
% **** and some Artifex customers rely on the pdfshowpage_init,
% **** pdfshowpage_setpage, pdfshowpage_finish so all logic should be
% **** implemented in one of those three procedures.
-/pdfshowpage % <pagedict> pdfshowpage -
+/pdfshowpage % <pagedict> pdfshowpage -
{ dup /Page exch store
pdfshowpage_init % <pagedict>
pdfshowpage_setpage % <pagedict>
pdfshowpage_finish % -
} bind executeonly def
-/pdfpagecontents % <pagedict> pdfpagecontents <contents>
+/pdfpagecontents % <pagedict> pdfpagecontents <contents>
{ } bind executeonly def
-/pdfshowpage_init % <pagedict> pdfshowpage_init <pagedict>
+/pdfshowpage_init % <pagedict> pdfshowpage_init <pagedict>
{ /DSCPageCount DSCPageCount 1 add store
} bind executeonly def
@@ -2522,7 +3393,7 @@ end readonly def
} bind executeonly def
% Compute the matrix that transforms the PDF->PS "default" user space
-/pdf_PDF2PS_matrix { % <pdfpagedict> -- matrix
+/pdf_PDF2PS_matrix { % <pdfpagedict> -- matrix
matrix currentmatrix matrix setmatrix exch
% stack: savedCTM <pdfpagedict>
dup get_any_box
@@ -2533,13 +3404,13 @@ end readonly def
currentpagedevice /.HWMargins get aload pop
currentpagedevice /PageSize get aload pop
% Adjust PageSize and .HWMargins for the page portrait/landscape orientation
- 2 copy gt % PageSize_is_landscape
+ 2 copy gt % PageSize_is_landscape
7 index aload pop 3 -1 roll sub 3 1 roll exch sub exch
10 index /Rotate pget not { 0 } if cvi 90 idiv 1 and 0 ne { exch } if
- gt % Box_is_landscape
- xor % PageSize_is_landscape(or square) xor'ed with Box_is_lanscape suggests rotate
- 2 index 2 index eq not and { % don't rotate if Page is square
- 1 index 0 translate 90 rotate % add in a rotation
+ gt % Box_is_landscape
+ xor % PageSize_is_landscape(or square) xor'ed with Box_is_lanscape suggests rotate
+ 2 index 2 index eq not and { % don't rotate if Page is square
+ 1 index 0 translate 90 rotate % add in a rotation
PDFDEBUG { ( Rotating the page for best fit) = flush } if
2 copy ne {
% rotate the .HWMargins
@@ -2555,7 +3426,7 @@ end readonly def
3 -1 roll sub 3 1 roll exch sub exch
% stack: savedCTM <pdfpagedict> <Crop|Media Box> Xmin Ymin Xmax Ymax
PDFDEBUG { ( Translate up by [ ) print 3 index =print (, ) print 2 index =print ( ]) = flush } if
- 3 index 3 index translate % move origin up to imageable area
+ 3 index 3 index translate % move origin up to imageable area
2 index sub exch 3 index sub exch 4 2 roll pop pop
% stack: savedCTM <pdfpagedict> [Box] XImageable YImageable
2 index aload pop 2 index sub exch 3 index sub exch 4 2 roll pop pop
@@ -2631,13 +3502,13 @@ end readonly def
} bind executeonly def
currentdict /PDF2PS_matrix_key undef
-/.pdfshowpage_Install { % <pagedict> [<prevproc>] .pdfshowpage_Install -
+/.pdfshowpage_Install { % <pagedict> [<prevproc>] .pdfshowpage_Install -
0 get exec
pdf_cached_PDF2PS_matrix concat
} bind executeonly def
-/pdfshowpage_setpage { % <pagedict> pdfshowpage_setpage <pagedict>
- 6 dict begin % for setpagedevice
+/pdfshowpage_setpage { % <pagedict> pdfshowpage_setpage <pagedict>
+ 6 dict begin % for setpagedevice
% Stack: pdfpagedict
% This comment is no longer true, and is maintained here for history only:
%
@@ -2741,7 +3612,7 @@ currentdict /PDF2PS_matrix_key undef
dup type dup /arraytype eq exch /packedarraytype eq or {
dup length 4 eq {
dup 2 get /.pdfshowpage_Install load eq {
- 1 get 0 get % previous procedure
+ 1 get 0 get % previous procedure
} if
} if
} if
@@ -2754,7 +3625,7 @@ currentdict /PDF2PS_matrix_key undef
/Install exch def
% Stack: pagedict currentpagedict
% If the Overprint device flag is not /disable, check usage of OP/op
- /PageUsesOverprint //false def % assume we don't need OP simulation
+ /PageUsesOverprint //false def % assume we don't need OP simulation
dup /Overprint get /disable ne
% If the device suppports SpotColors (DeviceN device) we don't need simulation
1 index /PageSpotColors known
@@ -2769,13 +3640,13 @@ currentdict /PDF2PS_matrix_key undef
% Overprint is /enable, so the device might need the overprint compositor
% if it does not support spot colors, thus check if overprint is used so
% overprint simulation can be done with the pdf14 compositor
- 1 index countspotcolors userdict exch /PageSpotColors exch put % save it in a known place
+ 1 index countspotcolors userdict exch /PageSpotColors exch put % save it in a known place
1 index pageusesoverprint
1 index /ProcessColorModel get /DeviceCMYK eq {
- PageSpotColors 0 gt % count of colorants NOT including CMYK
+ PageSpotColors 0 gt % count of colorants NOT including CMYK
and
} if
- /PageUsesOverprint exch def % the page needs OP simulation so set device param.
+ /PageUsesOverprint exch def % the page needs OP simulation so set device param.
} if
pop currentdict end setpagedevice
} bind executeonly def
@@ -2794,7 +3665,7 @@ currentdict /PDF2PS_matrix_key undef
} if
} bind executeonly def
-/pdfshowpage_finish { % <pagedict> pdfshowpage_finish -
+/pdfshowpage_finish { % <pagedict> pdfshowpage_finish -
save /PDFSave exch store
/PDFdictstackcount countdictstack store
/PDFexecstackcount count 2 sub store
@@ -2820,7 +3691,7 @@ currentdict /PDF2PS_matrix_key undef
pop
} ifelse
} forall
- } if % end .writepdfmarks
+ } if % end .writepdfmarks
% Display the actual page contents.
9 dict begin
@@ -2850,34 +3721,34 @@ currentdict /PDF2PS_matrix_key undef
% If the current device isn't CMYK, or if it is a device that supports transparency
% we don't need the special handling of Overprint transparency, so disable the checking.
- 4 dict begin % working directory to simplify
+ 4 dict begin % working directory to simplify
currentpagedevice dup /Colors get
- /devColors exch def % put into our convenience dict
+ /devColors exch def % put into our convenience dict
dup /HaveTransparency .knownget not { //false } if
- /devSupportsTrans exch def % put into our convenience dict
+ /devSupportsTrans exch def % put into our convenience dict
dup /Overprint get
- /SimOP exch def % put into our convenience dict
+ /SimOP exch def % put into our convenience dict
SimOP /simulate eq
exch /PageUsesOverprint .knownget not { //false } if
- and % both Overprint==/simulate and PageUsesOverprint
+ and % both Overprint==/simulate and PageUsesOverprint
{
% Determine if the device needs the special pdf14 compositor push
- devColors 4 eq PageSpotColors 0 gt and % CMYK device, but device has spot colors
- devColors 4 lt % RGB or Gray device
+ devColors 4 eq PageSpotColors 0 gt and % CMYK device, but device has spot colors
+ devColors 4 lt % RGB or Gray device
or
} {
- //false % Overprint is not /simulate or PageUseOverprint is false
+ //false % Overprint is not /simulate or PageUseOverprint is false
} ifelse
% Determine if the device needs SMask for Overprint
SimOP /simulate eq {
- //true % we will need setupOPrtans for Compatible BM
+ //true % we will need setupOPrtans for Compatible BM
} {
SimOP /enable eq
- devColors 4 ge % CMYK device
+ devColors 4 ge % CMYK device
and
} ifelse
- devSupportsTrans not and % If device supports transparency (e.g. pdfwrite) then no setupOPtrans
- end % pop the convenience dict
+ devSupportsTrans not and % If device supports transparency (e.g. pdfwrite) then no setupOPtrans
+ end % pop the convenience dict
/setup_trans exch
{ /setupOPtrans } { /setupSMtrans } ifelse
load def
@@ -2885,7 +3756,7 @@ currentdict /PDF2PS_matrix_key undef
% Show the page within a PDF 1.4 device filter.
{ -1 } { 0 } ifelse
.pushpdf14devicefilter {
- /DefaultQstate qstate store % device has changed -- reset DefaultQstate
+ /DefaultQstate qstate store % device has changed -- reset DefaultQstate
% If the page has a Group, enclose contents in transparency group.
% (Adobe Tech Note 5407, sec 9.2)
dup /Group knownoget {
@@ -2903,12 +3774,12 @@ currentdict /PDF2PS_matrix_key undef
} stopped {
% abort the transparency device
.abortpdf14devicefilter
- /DefaultQstate qstate store % device has changed -- reset DefaultQstate
+ /DefaultQstate qstate store % device has changed -- reset DefaultQstate
stop
} if
- { } settransfer % identity transfer during popdevice (put_image)
- .poppdf14devicefilter % NB: reset to DefaultQstate will also restore transfer function
- /DefaultQstate qstate store % device has changed -- reset DefaultQstate
+ { } settransfer % identity transfer during popdevice (put_image)
+ .poppdf14devicefilter % NB: reset to DefaultQstate will also restore transfer function
+ /DefaultQstate qstate store % device has changed -- reset DefaultQstate
} {
/setup_trans { pop pop } def % no-op this if the page doesn't use transparency
% NB: original will be restored from PDFsave
@@ -2923,17 +3794,17 @@ currentdict /PDF2PS_matrix_key undef
{
% Show the page within a PDF 1.4 device filter for overprint_simulation.
-1 .pushpdf14devicefilter {
- /DefaultQstate qstate store % device has changed -- reset DefaultQstate
+ /DefaultQstate qstate store % device has changed -- reset DefaultQstate
showpagecontents
} stopped {
% abort the transparency device
.abortpdf14devicefilter
- /DefaultQstate qstate store % device has changed -- reset DefaultQstate
+ /DefaultQstate qstate store % device has changed -- reset DefaultQstate
stop
} if
- { } settransfer % identity transfer during popdevice (put_image)
- .poppdf14devicefilter % NB: reset to DefaultQstate will also restore transfer function
- /DefaultQstate qstate store % device has changed -- reset DefaultQstate
+ { } settransfer % identity transfer during popdevice (put_image)
+ .poppdf14devicefilter % NB: reset to DefaultQstate will also restore transfer function
+ /DefaultQstate qstate store % device has changed -- reset DefaultQstate
} {
showpagecontents
} ifelse
@@ -2942,7 +3813,7 @@ currentdict /PDF2PS_matrix_key undef
% todo: mixing drawing ops outside the device filter could cause
% problems, for example with the pnga device.
endpage
- end % scratch dict
+ end % scratch dict
% Some PDF files don't have matching q/Q (gsave/grestore) so we need
% to clean up any left over dicts from the dictstack
@@ -2977,7 +3848,7 @@ currentdict /PDF2PS_matrix_key undef
pop
count PDFexecstackcount sub { pop } repeat
(after exec) VMDEBUG
- Repaired % pass Repaired state around the restore
+ Repaired % pass Repaired state around the restore
RepairedAnError
PDFSave restore
currentglobal //pdfdict gcheck .setglobal
@@ -2988,8 +3859,8 @@ currentdict /PDF2PS_matrix_key undef
} bind executeonly odef
% Display the contents of a page (including annotations).
-/showpagecontents { % <pagedict> showpagecontents -
- dup % Save the pagedict for the Annotations
+/showpagecontents { % <pagedict> showpagecontents -
+ dup % Save the pagedict for the Annotations
% We do a 'save' here in order to allow us to restore at the end of the page, before
% we run the annotations. There are two reasons for this; firstly so that the graphics state
@@ -3078,9 +3949,9 @@ currentdict /PDF2PS_matrix_key undef
not
and
//systemdict /PreserveAnnots .knownget not {//true} if and {
- mark exch {preserveannot} PDFSTOPONERROR {exec}{stopped {(Error: Ignoring invalid annotation, output may be incorrect.\n) pdfformaterror} if} ifelse cleartomark
+ mark exch {preserveannot} PDFSTOPONERROR {exec}{stopped {(Error: Ignoring invalid annotation, output may be incorrect.\n) pdfformaterror} if} ifelse {cleartomark} stopped pop
}{
- mark exch {drawannot} PDFSTOPONERROR {exec}{stopped {(Error: Ignoring invalid annotation, output may be incorrect.\n) pdfformaterror} if} ifelse cleartomark
+ mark exch {drawannot} PDFSTOPONERROR {exec}{stopped {(Error: Ignoring invalid annotation, output may be incorrect.\n) pdfformaterror} if} ifelse {cleartomark} stopped pop
} ifelse
} {
pop
@@ -3101,7 +3972,7 @@ currentdict /PDF2PS_matrix_key undef
} if
} bind executeonly def
-/processcolorspace { % - processcolorspace <colorspace>
+/processcolorspace { % - processcolorspace <colorspace>
% The following is per the PLRM3.
currentdevice 1 dict dup /ProcessColorModel dup put .getdeviceparams
exch pop exch pop
@@ -3110,7 +3981,7 @@ currentdict /PDF2PS_matrix_key undef
} bind executeonly def
% returns true if OP or op is true in an ExtGState
-/pageusesoverprint { % <pagedict> pageusesoverprint <bool>
+/pageusesoverprint { % <pagedict> pageusesoverprint <bool>
dup //false exch {
4 dict 1 index resourceusesoverprint { pop not exit } if
%% Check the current dictionary and its Parent (if any) to see
@@ -3135,12 +4006,12 @@ currentdict /PDF2PS_matrix_key undef
} bind def
% Check if Overprint (OP/op) is specified in an ExtGState dict
-/extgstateusesoverprint { % <gstate dict> extgstateusesoverprint <bool>
- //false exch % Assume no overprint
+/extgstateusesoverprint { % <gstate dict> extgstateusesoverprint <bool>
+ //false exch % Assume no overprint
dup //null eq {
pop % bug 692050
} {
- { % establish loop context
+ { % establish loop context
dup /OP knownoget { { pop not exit } if } if
dup /op knownoget { { pop not exit } if } if
pop exit
@@ -3149,8 +4020,8 @@ currentdict /PDF2PS_matrix_key undef
} bind def
% Check if overprint is used in a Pattern
-/patternusesoverprint { % <Pattern dict> patternusesoverprint <bool>
- //false exch % Assume no overprint
+/patternusesoverprint { % <Pattern dict> patternusesoverprint <bool>
+ //false exch % Assume no overprint
{
4 dict 1 index resourceusesoverprint { pop not exit } if
dup /ExtGState knownoget { extgstateusesoverprint { pop not exit } if } if
@@ -3159,8 +4030,8 @@ currentdict /PDF2PS_matrix_key undef
} bind def
% Check the Resources of a page or Form. Check for loops in the resource chain.
-/resourceusesoverprint { % <dict> <dict> resourceusesoverprint <bool>
- { % Use loop to provide an exitable context.
+/resourceusesoverprint { % <dict> <dict> resourceusesoverprint <bool>
+ { % Use loop to provide an exitable context.
/Resources knownoget not { 0 dict } if
2 copy .knownget {
{ % Some circular references may be missed because scanning stops
@@ -3190,22 +4061,22 @@ currentdict /PDF2PS_matrix_key undef
} bind def
% Check if the annotations on a page use overprint
-/annotsuseoverprint { % <page dict> annotsuseoverprint <bool>
- //false exch % Assume no overprint
- /Annots knownoget { % Get Annots array
+/annotsuseoverprint { % <page dict> annotsuseoverprint <bool>
+ //false exch % Assume no overprint
+ /Annots knownoget { % Get Annots array
dup type /arraytype eq {
{
oforce
dup //null ne {
- /AP knownoget { % Get appearance dict for the annoation
- /N knownogetdict { % Get the /N (i.e. normal) appearance stream
- 4 dict exch resourceusesoverprint { pop pop //true exit } if
+ /AP knownoget { % Get appearance dict for the annoation
+ /N knownogetdict { % Get the /N (i.e. normal) appearance stream
+ 4 dict exch resourceusesoverprint { not exit } if
} if
- } if % If AP dict known
+ } if % If AP dict known
} {
pop
} ifelse
- } forall % For all annots on the page
+ } forall % For all annots on the page
} {
( **** Error: Annotation array is not an array, ignoring it.\n) pdfformaterror
( Output may be incorrect.\n) pdfformaterror
@@ -3218,8 +4089,8 @@ currentdict /PDF2PS_matrix_key undef
% ------ Transparency support ------ %
% Determine whether a page might invoke any transparency features:
-% - Non-default BM, ca, CA, or SMask in an ExtGState
-% - Image XObject with SMask
+% - Non-default BM, ca, CA, or SMask in an ExtGState
+% - Image XObject with SMask
% Note: we deliberately don't check to see whether a Group is defined,
% because Adobe Illustrator 10 (and possibly other applications) define
% a page-level group whether transparency is actually used or not.
@@ -3228,7 +4099,7 @@ currentdict /PDF2PS_matrix_key undef
%
% Transparency is a 1.4 feature however we have seen files that claimed
% to be PDF 1.1 with transparency features. Bugs 689288, 691273.
-/pageusestransparency { % <pagedict> pageusestransparency <bool>
+/pageusestransparency { % <pagedict> pageusestransparency <bool>
NOTRANSPARENCY {
pop //false
} {
@@ -3257,12 +4128,12 @@ currentdict /PDF2PS_matrix_key undef
} bind executeonly def
% Check if transparency is specified in an ExtGState dict
-/extgstateusestransparency { % <gstate dict> extgstateusestransparency <bool>
- //false exch % Assume no transparency
+/extgstateusestransparency { % <gstate dict> extgstateusestransparency <bool>
+ //false exch % Assume no transparency
dup //null eq {
pop % bug 692050
} {
- { % establish loop context
+ { % establish loop context
dup /BM knownoget {
dup /Normal ne exch /Compatible ne and { pop not exit } if
} if
@@ -3275,10 +4146,10 @@ currentdict /PDF2PS_matrix_key undef
} bind executeonly def
% Check if transparency is used in a Pattern
-/patternusestransparency { % <Pattern dict> patternusestransparency <bool>
+/patternusestransparency { % <Pattern dict> patternusestransparency <bool>
dup //null eq NOTRANSPARENCY or
{ pop //false }
- { //false exch % Assume no transparency
+ { //false exch % Assume no transparency
{
4 dict 1 index resourceusestransparency { pop not exit } if
dup /ExtGState knownoget { extgstateusestransparency { pop not exit } if } if
@@ -3289,8 +4160,8 @@ currentdict /PDF2PS_matrix_key undef
} bind executeonly def
% Check the Resources of a page or Form. Check for loops in the resource chain.
-/resourceusestransparency { % <dict> <dict> resourceusestransparency <bool>
- { % Use loop to provide an exitable context.
+/resourceusestransparency { % <dict> <dict> resourceusestransparency <bool>
+ { % Use loop to provide an exitable context.
/Resources knownoget not { 0 dict } if
2 copy .knownget {
{ % Some circular references may be missed because scanning stops
@@ -3380,9 +4251,9 @@ currentdict /PDF2PS_matrix_key undef
} bind executeonly def
% Check if the annotations on a page use transparency
-/annotsusetransparency { % <page dict> annotsusetransparency <bool>
- //false exch % Assume no transparency
- /Annots knownoget { % Get Annots array
+/annotsusetransparency { % <page dict> annotsusetransparency <bool>
+ //false exch % Assume no transparency
+ /Annots knownoget { % Get Annots array
dup type /arraytype eq {
{
/AnnotTransparencyCheck exch % marker to clean up stack on error
@@ -3404,11 +4275,11 @@ currentdict /PDF2PS_matrix_key undef
pop pop //true exit % as transparency.
} if
} if
- dup /AP knownoget { % Get appearance dict for the annoation
- /N knownogetdict { % Get the /N (i.e. normal) appearance stream
+ dup /AP knownoget { % Get appearance dict for the annoation
+ /N knownogetdict { % Get the /N (i.e. normal) appearance stream
4 dict exch resourceusestransparency { pop pop //true exit } if
} if
- } if % If AP dict known
+ } if % If AP dict known
dup /BM knownoget {
pop pop pop //true exit
} if
@@ -3431,7 +4302,7 @@ currentdict /PDF2PS_matrix_key undef
pop
} ifelse
} ifelse
- } forall % For all annots on the page
+ } forall % For all annots on the page
}
{
( **** Error: Annotation array is not an array, ignoring it.\n) pdfformaterror
@@ -3443,7 +4314,7 @@ currentdict /PDF2PS_matrix_key undef
} bind executeonly def
% Add a color name to our spot color list. Ignore /All and /None
-/putspotcolor { % <name> <spotcolordict> putspotcolor -
+/putspotcolor { % <name> <spotcolordict> putspotcolor -
% The 'name' could be a string. If so then convert to a name.
exch dup type /stringtype eq { cvn } if
dup dup /None eq exch /All eq or { pop pop } { 0 put } ifelse
@@ -3452,7 +4323,7 @@ currentdict /PDF2PS_matrix_key undef
% Determine which spot colors are used within a color space Note: This
% dict will include all colors used in Separation or DeviceN color spaces.
% Thus it may include Cyan, Magenta, Yellow, and Black.
-% <colorspace> <spotcolordict> colorspacespotcolors -
+% <colorspace> <spotcolordict> colorspacespotcolors -
/colorspacespotcolors {
% Make sure we have an array, and that it is has enough info
exch dup type /arraytype eq
@@ -3464,7 +4335,7 @@ currentdict /PDF2PS_matrix_key undef
2 copy exch colorspacespotcolors
} {
dup /Pattern eq {
- 1 index length 1 gt { % only uncolored patterns have colorspace
+ 1 index length 1 gt { % only uncolored patterns have colorspace
pop 1 oget % <<>> [base]
2 copy exch colorspacespotcolors
} {
@@ -3490,10 +4361,10 @@ currentdict /PDF2PS_matrix_key undef
% all colors used in Separation or DeviceN color spaces. Thus it may include
% Cyan, Magenta, Yellow, and Black. We also pass a dict that is used to check
% for loops in the resource list.
-% <spotcolordict> <loopdict> <page/form/annot dict>
-% resourcespotcolors <spotcolordict> <loopdict>
+% <spotcolordict> <loopdict> <page/form/annot dict>
+% resourcespotcolors <spotcolordict> <loopdict>
/resourcespotcolors {
- { % Use loop to provide an exitable context.
+ { % Use loop to provide an exitable context.
% Exit if no Resources entry
/Resources knownoget not { exit } if
% Exit if we have already seen this dict
@@ -3563,17 +4434,17 @@ currentdict /PDF2PS_matrix_key undef
% Determine which spot colors are used within the annotations. Note: This
% dict will include all colors used in Separation or DeviceN color spaces.
% Thus it may include Cyan, Magenta, Yellow, and Black.
-% <spotcolordict> <loopdict> <annotsarray>
-% annotsspotcolors <spotcolordict> <loopdict>
+% <spotcolordict> <loopdict> <annotsarray>
+% annotsspotcolors <spotcolordict> <loopdict>
/annotsspotcolors {
dup type /arraytype eq {
{ oforce
dup //null ne {
- /AP knownoget { % Get appearance dict for the annoation
- /N knownogetdict { % Get the /N (i.e. normal) appearance stream
+ /AP knownoget { % Get appearance dict for the annoation
+ /N knownogetdict { % Get the /N (i.e. normal) appearance stream
resourcespotcolors
- } if % If normal appearance streamknown
- } if % If AP dict known
+ } if % If normal appearance streamknown
+ } if % If AP dict known
} {
pop
} ifelse
@@ -3594,7 +4465,7 @@ currentdict /PDF2PS_matrix_key undef
% page's resources. Thus it may include Cyan, Magenta, Yellow, and Black.
% There is no attempt to verify that these color spaces are actually used
% within the object streams for the page.
-/pagespotcolors { % <pagedict> pagespotcolors <spotcolordict>
+/pagespotcolors { % <pagedict> pagespotcolors <spotcolordict>
dup
% Create a dict to hold spot color names.
0 dict exch
@@ -3607,7 +4478,7 @@ currentdict /PDF2PS_matrix_key undef
{
/Parent knownoget
{
- dup /Pages known not { pop exit } if % not a valid Page Tree ancestor
+ dup /Pages known not { pop exit } if % not a valid Page Tree ancestor
dup 4 1 roll
resourcespotcolors
3 -1 roll
@@ -3619,18 +4490,18 @@ currentdict /PDF2PS_matrix_key undef
% Also check for color spaces in the annotations.
3 -1 roll
/Annots knownoget { annotsspotcolors } if
- pop % Discard reference loop dict
+ pop % Discard reference loop dict
} bind executeonly def
% Determine how many (if any) spot colors are used by a page.
% Note: This count does not include Cyan, Magenta, Yellow, or Black
-/countspotcolors { % <pagedict> countspotcolors <count>
- pagespotcolors % Get dict with all spot colors
- dup length % spot color dict length
+/countspotcolors { % <pagedict> countspotcolors <count>
+ pagespotcolors % Get dict with all spot colors
+ dup length % spot color dict length
% Remove CMYK from the spot color count.
[ /Cyan /Magenta /Yellow /Black ]
{ 2 index exch known { 1 sub } if } forall
- exch pop % Remove spot color dict
+ exch pop % Remove spot color dict
} bind executeonly def
% ------ ColorSpace substitution support ------ %
@@ -3848,7 +4719,7 @@ currentdict /PDF2PS_matrix_key undef
Trailer /Root knownoget {
/OutputIntents knownoget {
dup type /arraytype eq {
- { % process all output profiles present
+ { % process all output profiles present
oforce
dup length dict .copydict
dup /DestOutputProfile knownoget {
@@ -3880,7 +4751,7 @@ currentdict /PDF2PS_matrix_key undef
{ currentdevice //null //false counttomark 1 add 3 roll .putdeviceparamsonly }
ifelse
pop pop
- pop % done with this OutputIntent dictionary
+ pop % done with this OutputIntent dictionary
} forall
} {
pop
@@ -3888,7 +4759,7 @@ currentdict /PDF2PS_matrix_key undef
pdfformaterror
( Output may be incorrect.\n) pdfformaterror
} ifelse
- } if % OutputIntents known
+ } if % OutputIntents known
% tell device there are no more OutputIntents
[ /OutputIntent [ ] /.pdfputparams where
{ pop .pdfputparams }
@@ -3963,7 +4834,7 @@ currentdict /PDF2PS_matrix_key undef
pop
}bind readonly def
-end % pdfdict
+end % pdfdict
systemdict /ALLOWPSTRANSPARENCY get
@@ -4017,7 +4888,7 @@ systemdict /ALLOWPSTRANSPARENCY get
/.pdfinkpath /.pdfFormName /.settextspacing /.currenttextspacing /.settextleading /.currenttextleading
/.settextrise /.currenttextrise /.setwordspacing /.currentwordspacing /.settexthscaling /.currenttexthscaling
-/.setPDFfontsize /.currentPDFfontsize /.setdistillerparams
+/.setPDFfontsize /.currentPDFfontsize /.setdistillerparams /.currentpoint_valid
% undefining these causes errors/incorrect output
%/.settextrenderingmode
diff --git a/Resource/Init/pdf_ops.ps b/Resource/Init/pdf_ops.ps
index fe61b12d..27c20680 100644
--- a/Resource/Init/pdf_ops.ps
+++ b/Resource/Init/pdf_ops.ps
@@ -680,8 +680,8 @@ end
} def
/Dpop { //OPsaveDstack begin previous { def } forall end } def
-% colorspaces that don't require special overprint transparency handling
-/okOPcs mark /DeviceGray 0 /DeviceCMYK 1 /DeviceN 2 /Separation 3 .dicttomark def
+% colorspaces that require special overprint transparency handling
+/specialOPcs mark /DeviceGray 0 /DeviceCMYK 1 /DeviceN 2 /Separation 3 .dicttomark def
% Take care of pushing a transparency group if we need it for SMask or for Overprint..
% After pushing the group, we save the ca and CA and change them
@@ -696,11 +696,18 @@ end
//OPsaveDstack begin
//Dpush exec % push the current OPsaveDstack values into 'previous'
/SupportsDevn .special_op
- okOPcs currentcolorspace 0 get dup /Indexed eq {
+ specialOPcs currentcolorspace 0 get dup /Indexed eq {
pop currentcolorspace 1 get % use the base space
} if
known or {
- 1 index /stroke ne { .currentfilloverprint } { .currentstrokeoverprint } ifelse
+ dup /stroke ne {
+ .currentfilloverprint
+ 1 index dup /.fillstroke eq exch /.eofillstroke eq or {
+ .currentstrokeoverprint or
+ } if
+ } {
+ .currentstrokeoverprint
+ } ifelse
% Change BM to CompatibleOverprint if this has overprint true
dup /ChangeBM exch def
.currentblendmode dup /Normal eq exch /Compatible eq or
@@ -961,12 +968,12 @@ currentdict dup /Dpush .undef /Dpop .undef
n
} bind executeonly def
/b { closepath B* } bind executeonly def
-/n { end { currentpoint } stopped not { pop pop clip } if newpath } bind executeonly def
+/n { end .currentpoint_valid { clip } if newpath } bind executeonly def
end readonly def
/W { //Wdict begin } bind executeonly def
/W*dict 8 dict dup begin
Wdict { def } forall
-/n { end { currentpoint } stopped not { pop pop eoclip } if newpath } bind executeonly def
+/n { end .currentpoint_valid { eoclip } if newpath } bind executeonly def
end readonly def
/W* { //W*dict begin } bind executeonly def
% ---------------- Text control ---------------- %
@@ -1057,7 +1064,8 @@ end readonly def
/settextposition {
% Update the TextMatrix translation.
gsave TextSaveMatrix setmatrix
- {currentpoint} stopped not {
+ .currentpoint_valid {
+ currentpoint
.currenttextrise
sub
matrix .currenttextmatrix
@@ -1105,6 +1113,9 @@ end readonly def
} bind executeonly odef
/BT {
+ % Bug 703996 has a path defined before BT, then stroked afterwards
+ .currentpoint_valid { //false upath } { //null } ifelse
+ /BT_upath gput
//false /illegal_BT gput
currentdict /TextSaveMatrix known {
( **** Error: illegal nested BT operator detected.\n)
@@ -1153,10 +1164,8 @@ end readonly def
/clip_if_required {
.currenttextrenderingmode 4 ge
- {currentpoint} //.internalstopped exec
- {//false}
- {pop pop //true}
- ifelse and
+ .currentpoint_valid
+ and
{ .currentfilladjust2 0 dup .setfilladjust2 clip .setfilladjust2} if
newpath
} bind def
@@ -1183,6 +1192,7 @@ end readonly def
%% in a nested text block (inside a gsave).
currentdict /qTextSaveMatrix known not {
switch_to_normal_marking_ops
+ currentdict /BT_upath get dup //null eq { pop } { newpath uappend } ifelse
} if
} bind executeonly def
diff --git a/arch/osx-x86-x86_64-ppc-gcc.h b/arch/osx-x86-x86_64-ppc-gcc.h
index 6166f897..15ebc40b 100644
--- a/arch/osx-x86-x86_64-ppc-gcc.h
+++ b/arch/osx-x86-x86_64-ppc-gcc.h
@@ -20,7 +20,7 @@
#define ARCH_LOG2_SIZEOF_LONG 2
#define ARCH_LOG2_SIZEOF_SIZE_T 2
#define ARCH_LOG2_SIZEOF_LONG_LONG 3
-#define ARCH_SIZEOF_SIZET 4
+#define ARCH_SIZEOF_SIZE_T 4
#ifndef ARCH_SIZEOF_GX_COLOR_INDEX
#define ARCH_SIZEOF_GX_COLOR_INDEX 8
diff --git a/autogen.sh b/autogen.sh
index 7a078362..09f732b4 100755
--- a/autogen.sh
+++ b/autogen.sh
@@ -29,9 +29,6 @@ rm -rf autom4te.cache
echo "Generating configuration files for $package, please wait...."
-echo " running autoreconf"
-autoreconf || exit 1
-
if test ! -x config.guess -o ! -x config.sub ; then
rm -f config.guess config.sub
cp `automake --print-libdir`/config.guess . || exit 1
@@ -43,6 +40,10 @@ if test ! -x install-sh ; then
cp `automake --print-libdir`/install-sh . || exit 1
fi
+echo " running autoreconf"
+autoreconf || exit 1
+
+
if test -z "$*"; then
echo "I am going to run ./configure with no arguments - if you wish "
echo "to pass any to it, please specify them on the $0 command line."
diff --git a/base/ets.c b/base/ets.c
index f24d118f..d2ac20a0 100644
--- a/base/ets.c
+++ b/base/ets.c
@@ -1,26 +1,17 @@
-/*
- * Testbed implementation of Even Better Screening. Please see
- * http://www.artofcode.com/eventone/ for more details.
- *
- * Copyright 2001-2004 Raph Levien <raph@acm.org>
- *
- * Code in this module is covered by US Patents 5,055,942 and
- * 5,917,614, and corresponding international patents. This version
- * of ETS is for commercial licensees and is governed by the licensing
- * agreement between artofcode LLC and the licensee. Please see
- * http://www.artofcode.com/eventone/ for information on licensing.
- *
- * Subsequent Changes: Copyright (C) 2013-2021 Artifex Software, Inc.
- *
- * All Rights Reserved.
- *
- * This software is provided AS-IS with no warranty, either express or
- * implied.
- *
- * This software is distributed under license and may not be copied,
- * modified or distributed except as expressly authorized under the terms
- * of the license contained in the file LICENSE in this distribution.
- */
+/* Copyright (C) 2013-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
#include <stdlib.h>
#include <string.h>
diff --git a/base/ets.h b/base/ets.h
index 29530442..09bffbc5 100644
--- a/base/ets.h
+++ b/base/ets.h
@@ -1,26 +1,17 @@
-/*
- * Testbed implementation of Even Better Screening. Please see
- * http://www.artofcode.com/eventone/ for more details.
- *
- * Copyright 2001-2004 Raph Levien <raph@acm.org>
- *
- * Code in this module is covered by US Patents 5,055,942 and
- * 5,917,614, and corresponding international patents. This version
- * of ETS is for commercial licensees and is governed by the licensing
- * agreement between artofcode LLC and the licensee. Please see
- * http://www.artofcode.com/eventone/ for information on licensing.
- *
- * Subsequent Changes: Copyright (C) 2013-2021 Artifex Software, Inc.
- *
- * All Rights Reserved.
- *
- * This software is provided AS-IS with no warranty, either express or
- * implied.
- *
- * This software is distributed under license and may not be copied,
- * modified or distributed except as expressly authorized under the terms
- * of the license contained in the file LICENSE in this distribution.
- */
+/* Copyright (C) 2013-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
#ifndef ets_h_INCLUDED
# define ets_h_INCLUDED
diff --git a/base/ets_tm.h b/base/ets_tm.h
index 61318977..ab737162 100644
--- a/base/ets_tm.h
+++ b/base/ets_tm.h
@@ -1,26 +1,17 @@
-/*
- * Testbed implementation of Even Better Screening. Please see
- * http://www.artofcode.com/eventone/ for more details.
- *
- * Copyright 2001-2004 Raph Levien <raph@acm.org>
- *
- * Code in this module is covered by US Patents 5,055,942 and
- * 5,917,614, and corresponding international patents. This version
- * of ETS is for commercial licensees and is governed by the licensing
- * agreement between artofcode LLC and the licensee. Please see
- * http://www.artofcode.com/eventone/ for information on licensing.
- *
- * Subsequent Changes: Copyright (C) 2013-2021 Artifex Software, Inc.
- *
- * All Rights Reserved.
- *
- * This software is provided AS-IS with no warranty, either express or
- * implied.
- *
- * This software is distributed under license and may not be copied,
- * modified or distributed except as expressly authorized under the terms
- * of the license contained in the file LICENSE in this distribution.
- */
+/* Copyright (C) 2013-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
#ifndef ets_tm_h_INCLUDED
diff --git a/base/fapi_ft.c b/base/fapi_ft.c
index e4d935d9..4b4b6857 100644
--- a/base/fapi_ft.c
+++ b/base/fapi_ft.c
@@ -56,6 +56,7 @@
#include FT_IMAGE_H
#include FT_BITMAP_H
#include FT_TRUETYPE_DRIVER_H
+#include FT_TRUETYPE_TABLES_H
#include FT_MULTIPLE_MASTERS_H
#include FT_TYPE1_TABLES_H
@@ -1381,7 +1382,8 @@ gs_fapi_ft_get_scaled_font(gs_fapi_server * a_server, gs_fapi_font * a_font,
for (i = 0; i < GS_FAPI_NUM_TTF_CMAP_REQ && !cmap; i++) {
if (a_font->ttf_cmap_req[i].platform_id > 0) {
for (j = 0; j < face->ft_face->num_charmaps; j++) {
- if (face->ft_face->charmaps[j]->platform_id == a_font->ttf_cmap_req[i].platform_id
+ if (FT_Get_CMap_Format(face->ft_face->charmaps[j]) >= 0
+ && face->ft_face->charmaps[j]->platform_id == a_font->ttf_cmap_req[i].platform_id
&& face->ft_face->charmaps[j]->encoding_id == a_font->ttf_cmap_req[i].encoding_id) {
cmap = face->ft_face->charmaps[j];
diff --git a/base/gdbflags.h b/base/gdbflags.h
index 073ca73f..8f044b4a 100644
--- a/base/gdbflags.h
+++ b/base/gdbflags.h
@@ -32,7 +32,7 @@ FLAG(epo_details, 5, 0, "Erasepage Optimization tracing"),
FLAG(epo_install_only, 6, 0, "Erasepage Optimization install only (for debugging subclass)"),
FLAG(init_details, 7, 0, "Language initialisation (detail)"),
FLAG(overprint, 8, 0, "Overprint"),
-UNUSED(9)
+FLAG(clist_color, 9, 0, "Clist color"),
UNUSED(10)
UNUSED(11)
UNUSED(12)
diff --git a/base/gdevabuf.c b/base/gdevabuf.c
index 1f7c3902..e22418a3 100644
--- a/base/gdevabuf.c
+++ b/base/gdevabuf.c
@@ -32,100 +32,6 @@
* useful for other things someday.
*/
-/* We can't initialize the device descriptor statically very well, */
-/* so we patch up the image2 or image4 descriptor. */
-static dev_proc_map_rgb_color(mem_alpha_map_rgb_color);
-static dev_proc_map_color_rgb(mem_alpha_map_color_rgb);
-static dev_proc_map_rgb_alpha_color(mem_alpha_map_rgb_alpha_color);
-static dev_proc_copy_alpha(mem_alpha_copy_alpha);
-
-void
-gs_make_mem_alpha_device(gx_device_memory * adev, gs_memory_t * mem,
- gx_device * target, int alpha_bits)
-{
- gs_make_mem_device(adev, gdev_mem_device_for_bits(alpha_bits),
- mem, 0, target);
- /* This is a black-and-white device ... */
- adev->color_info = gdev_mem_device_for_bits(1)->color_info;
- /* ... but it has multiple bits per pixel ... */
- adev->color_info.depth = alpha_bits;
- adev->graphics_type_tag = target->graphics_type_tag;
- /* ... and different color mapping. */
- set_dev_proc(adev, map_rgb_color, mem_alpha_map_rgb_color);
- set_dev_proc(adev, map_color_rgb, mem_alpha_map_color_rgb);
- set_dev_proc(adev, map_rgb_alpha_color, mem_alpha_map_rgb_alpha_color);
- set_dev_proc(adev, copy_alpha, mem_alpha_copy_alpha);
-}
-
-/* Reimplement color mapping. */
-static gx_color_index
-mem_alpha_map_rgb_color(gx_device * dev, const gx_color_value cv[])
-{
- gx_device_memory * const mdev = (gx_device_memory *)dev;
- gx_color_index color = gx_forward_map_rgb_color(dev, cv);
-
- return (color == 0 || color == gx_no_color_index ? color :
- (((gx_color_index)1 << mdev->log2_alpha_bits) - 1));
-}
-static int
-mem_alpha_map_color_rgb(gx_device * dev, gx_color_index color,
- gx_color_value prgb[3])
-{
- return
- gx_forward_map_color_rgb(dev,
- (color == 0 ? color : (gx_color_index) 1),
- prgb);
-}
-static gx_color_index
-mem_alpha_map_rgb_alpha_color(gx_device * dev, gx_color_value r,
- gx_color_value g, gx_color_value b, gx_color_value alpha)
-{
- gx_device_memory * const mdev = (gx_device_memory *)dev;
- gx_color_index color;
- gx_color_value cv[3];
-
- cv[0] = r; cv[1] = g; cv[2] = b;
- color = gx_forward_map_rgb_color(dev, cv);
-
- return (color == 0 || color == gx_no_color_index ? color :
- (gx_color_index) (alpha >> (gx_color_value_bits -
- mdev->log2_alpha_bits)));
-}
-/* Implement alpha copying. */
-static int
-mem_alpha_copy_alpha(gx_device * dev, const byte * data, int data_x,
- int raster, gx_bitmap_id id, int x, int y, int width, int height,
- gx_color_index color, int depth)
-{ /* Just use copy_color. */
- if (depth == 8) {
- /* We don't support depth=8 in this function, but this doesn't
- * matter, because:
- * 1) This code is only called for dTextAlphaBits > 0, when
- * DisableFAPI=true. And we don't support DisableFAPI.
- * 2) Even if we did support DisableFAPI, this can never actually
- * be called because gx_compute_text_oversampling arranges that
- * log2_scale.{x,y} sum to <= alpha_bits, and this code is only
- * called if it sums to MORE than alpha_bits.
- * 3) Even if copy_alpha DID somehow manage to be called, the
- * only place that uses depth==8 is the imagemask interpolation
- * code, and that can never hit this code. (Type 3 fonts might
- * include Imagemasks, but those don't go through FAPI).
- *
- * If in the future we ever rearrange the conditions under which
- * this code is called (so that it CAN be called with depth == 8)
- * then this will probably be best implemented by decimating the
- * input alpha values to either 2 or 4 bits as appropriate and
- * then recursively calling us back.
- */
- return_error(gs_error_unknownerror);
- }
- return (color == 0 ?
- (*dev_proc(dev, fill_rectangle)) (dev, x, y, width, height,
- color) :
- (*dev_proc(dev, copy_color)) (dev, data, data_x, raster, id,
- x, y, width, height));
-}
-
/* ================ Alpha-buffer device ================ */
/*
@@ -170,11 +76,22 @@ static dev_proc_get_clipping_box(mem_abuf_get_clipping_box);
static dev_proc_fill_rectangle_hl_color(mem_abuf_fill_rectangle_hl_color);
/* The device descriptor. */
+static void
+mem_alpha_initialize_device_procs(gx_device *dev)
+{
+ mem_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_rgb_color, gx_forward_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_forward_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, mem_abuf_fill_rectangle);
+ set_dev_proc(dev, copy_mono, mem_abuf_copy_mono);
+ set_dev_proc(dev, copy_color, gx_default_copy_color);
+ set_dev_proc(dev, strip_copy_rop2, gx_no_strip_copy_rop2);
+ set_dev_proc(dev, fill_rectangle_hl_color, mem_abuf_fill_rectangle_hl_color);
+}
+
static const gx_device_memory mem_alpha_buffer_device =
-mem_device_hl("image(alpha buffer)", 0, 1,
- gx_forward_map_rgb_color, gx_forward_map_color_rgb,
- mem_abuf_copy_mono, gx_default_copy_color, mem_abuf_fill_rectangle,
- gx_no_strip_copy_rop, mem_abuf_fill_rectangle_hl_color);
+ mem_device("image(alpha buffer)", 0, 1, mem_alpha_initialize_device_procs);
/* Make an alpha-buffer memory device. */
/* We use abuf instead of alpha_buffer because */
@@ -406,11 +323,13 @@ mem_abuf_copy_mono(gx_device * dev,
code = y_transfer_next(&yt, dev);
if (code < 0)
return code;
- (*dev_proc(&mem_mono_device, copy_mono)) (dev,
- base + (yt.y_next - y) * sraster,
- sourcex, sraster, gx_no_bitmap_id,
- x, yt.transfer_y, w, yt.transfer_height,
- gx_no_color_index, (gx_color_index) 1);
+ code = mem_mono_copy_mono(dev,
+ base + (yt.y_next - y) * sraster,
+ sourcex, sraster, gx_no_bitmap_id,
+ x, yt.transfer_y, w, yt.transfer_height,
+ gx_no_color_index, (gx_color_index) 1);
+ if (code < 0)
+ return code;
}
return 0;
}
@@ -442,9 +361,11 @@ mem_abuf_fill_rectangle(gx_device * dev, int x, int y, int w, int h,
code = y_transfer_next(&yt, dev);
if (code < 0)
return code;
- (*dev_proc(&mem_mono_device, fill_rectangle)) (dev,
- x, yt.transfer_y, w, yt.transfer_height,
- (gx_color_index) 1);
+ code = mem_mono_fill_rectangle(dev, x, yt.transfer_y,
+ w, yt.transfer_height,
+ (gx_color_index) 1);
+ if (code < 0)
+ return code;
}
return 0;
}
@@ -484,9 +405,11 @@ mem_abuf_fill_rectangle_hl_color(gx_device * dev, const gs_fixed_rect *rect,
code = y_transfer_next(&yt, dev);
if (code < 0)
return code;
- (*dev_proc(&mem_mono_device, fill_rectangle)) (dev,
- x, yt.transfer_y, w, yt.transfer_height,
- (gx_color_index) 1);
+ code = mem_mono_fill_rectangle(dev, x, yt.transfer_y,
+ w, yt.transfer_height,
+ (gx_color_index) 1);
+ if (code < 0)
+ return code;
}
return 0;
}
diff --git a/base/gdevbbox.c b/base/gdevbbox.c
index 542124a9..ac5c2e8b 100644
--- a/base/gdevbbox.c
+++ b/base/gdevbbox.c
@@ -52,14 +52,45 @@ static dev_proc_fill_parallelogram(bbox_fill_parallelogram);
static dev_proc_fill_triangle(bbox_fill_triangle);
static dev_proc_draw_thin_line(bbox_draw_thin_line);
static dev_proc_strip_tile_rectangle(bbox_strip_tile_rectangle);
-static dev_proc_strip_copy_rop(bbox_strip_copy_rop);
static dev_proc_strip_copy_rop2(bbox_strip_copy_rop2);
static dev_proc_strip_tile_rect_devn(bbox_strip_tile_rect_devn);
static dev_proc_begin_typed_image(bbox_begin_typed_image);
-static dev_proc_create_compositor(bbox_create_compositor);
+static dev_proc_composite(bbox_composite);
static dev_proc_text_begin(bbox_text_begin);
static dev_proc_fillpage(bbox_fillpage);
+static void
+bbox_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, bbox_open_device);
+ set_dev_proc(dev, get_initial_matrix, gx_upright_get_initial_matrix);
+ set_dev_proc(dev, output_page, bbox_output_page);
+ set_dev_proc(dev, close_device, bbox_close_device);
+ set_dev_proc(dev, map_rgb_color, gx_default_gray_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_default_gray_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, bbox_fill_rectangle);
+ set_dev_proc(dev, copy_mono, bbox_copy_mono);
+ set_dev_proc(dev, copy_color, bbox_copy_color);
+ set_dev_proc(dev, get_params, bbox_get_params);
+ set_dev_proc(dev, put_params, bbox_put_params);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
+ set_dev_proc(dev, copy_alpha, bbox_copy_alpha);
+ set_dev_proc(dev, fill_path, bbox_fill_path);
+ set_dev_proc(dev, stroke_path, bbox_stroke_path);
+ set_dev_proc(dev, fill_mask, bbox_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, bbox_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, bbox_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, bbox_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, bbox_draw_thin_line);
+ set_dev_proc(dev, strip_tile_rectangle, bbox_strip_tile_rectangle);
+ set_dev_proc(dev, begin_typed_image, bbox_begin_typed_image);
+ set_dev_proc(dev, composite, bbox_composite);
+ set_dev_proc(dev, text_begin, bbox_text_begin);
+ set_dev_proc(dev, fillpage, bbox_fillpage);
+ set_dev_proc(dev, strip_copy_rop2, bbox_strip_copy_rop2);
+ set_dev_proc(dev, strip_tile_rect_devn, bbox_strip_tile_rect_devn);
+}
+
/* The device prototype */
/*
* Normally this would be static, but if the device is going to be used
@@ -85,82 +116,11 @@ gx_device_bbox gs_bbox_device =
/*
* Define the device as 8-bit gray scale to avoid computing halftones.
*/
- std_device_dci_body(gx_device_bbox, 0, "bbox",
+ std_device_dci_body(gx_device_bbox, bbox_initialize_device_procs, "bbox",
MAX_COORD, MAX_COORD,
MAX_RESOLUTION, MAX_RESOLUTION,
1, 8, 255, 0, 256, 1),
- {bbox_open_device,
- gx_upright_get_initial_matrix,
- NULL, /* sync_output */
- bbox_output_page,
- bbox_close_device,
- gx_default_gray_map_rgb_color,
- gx_default_gray_map_color_rgb,
- bbox_fill_rectangle,
- NULL, /* tile_rectangle */
- bbox_copy_mono,
- bbox_copy_color,
- NULL, /* draw_line */
- NULL, /* get_bits */
- bbox_get_params,
- bbox_put_params,
- gx_default_map_cmyk_color,
- NULL, /* get_xfont_procs */
- NULL, /* get_xfont_device */
- gx_default_map_rgb_alpha_color,
- gx_page_device_get_page_device,
- NULL, /* get_alpha_bits */
- bbox_copy_alpha,
- NULL, /* get_band */
- NULL, /* copy_rop */
- bbox_fill_path,
- bbox_stroke_path,
- bbox_fill_mask,
- bbox_fill_trapezoid,
- bbox_fill_parallelogram,
- bbox_fill_triangle,
- bbox_draw_thin_line,
- gx_default_begin_image,
- NULL, /* image_data */
- NULL, /* end_image */
- bbox_strip_tile_rectangle,
- bbox_strip_copy_rop,
- NULL, /* get_clipping_box */
- bbox_begin_typed_image,
- NULL, /* get_bits_rectangle */
- gx_default_map_color_rgb_alpha,
- bbox_create_compositor,
- NULL, /* get_hardware_params */
- bbox_text_begin,
- NULL, /* finish_copydevice */
- NULL, /* begin_transparency_group */
- NULL, /* end_transparency_group */
- NULL, /* begin_transparency_mask */
- NULL, /* end_transparency_mask */
- NULL, /* discard_transparency_layer */
- NULL, /* get_color_mapping_procs */
- NULL, /* get_color_comp_index */
- NULL, /* encode_color */
- NULL, /* decode_color */
- NULL, /* pattern_manage */
- NULL, /* fill_rectangle_hl_color */
- NULL, /* include_color_space */
- NULL, /* fill_linear_color_scanline */
- NULL, /* fill_linear_color_trapezoid */
- NULL, /* fill_linear_color_triangle */
- NULL, /* update_spot_equivalent_colors */
- NULL, /* ret_devn_params */
- bbox_fillpage, /* fillpage */
- NULL, /* push_transparency_state */
- NULL, /* pop_transparency_state */
- NULL, /* put_image */
- NULL, /* dev_spec_op */
- NULL, /* copy_planes */
- NULL, /* get_profile */
- NULL, /* set_graphics_type_tag */
- bbox_strip_copy_rop2,
- bbox_strip_tile_rect_devn
- },
+ { 0 },
0, /* target */
1, /*true *//* free_standing */
1 /*true *//* forward_open_close */
@@ -275,15 +235,15 @@ bbox_close_device(gx_device * dev)
void
gx_device_bbox_init(gx_device_bbox * dev, gx_device * target, gs_memory_t *mem)
{
- gx_device_init((gx_device *) dev, (const gx_device *)&gs_bbox_device,
- (target ? target->memory : mem), true);
+ /* Can never fail */
+ (void)gx_device_init((gx_device *) dev, (const gx_device *)&gs_bbox_device,
+ (target ? target->memory : mem), true);
if (target) {
gx_device_forward_fill_in_procs((gx_device_forward *) dev);
set_dev_proc(dev, get_initial_matrix, gx_forward_get_initial_matrix);
set_dev_proc(dev, map_rgb_color, gx_forward_map_rgb_color);
set_dev_proc(dev, map_color_rgb, gx_forward_map_color_rgb);
set_dev_proc(dev, map_cmyk_color, gx_forward_map_cmyk_color);
- set_dev_proc(dev, map_rgb_alpha_color, gx_forward_map_rgb_alpha_color);
set_dev_proc(dev, get_color_mapping_procs, gx_forward_get_color_mapping_procs);
set_dev_proc(dev, get_color_comp_index, gx_forward_get_color_comp_index);
set_dev_proc(dev, encode_color, gx_forward_encode_color);
@@ -417,7 +377,8 @@ bbox_fill_rectangle(gx_device * dev, int x, int y, int w, int h,
{
gx_device_bbox *const bdev = (gx_device_bbox *) dev;
gx_device *tdev = bdev->target;
- /* gx_forward_fill_rectangle doesn't exist */
+ /* gx_forward_fill_rectangle exists, but does the wrong thing in
+ * the event of a NULL target, so open code it here. */
int code =
(tdev == 0 ? 0 :
dev_proc(tdev, fill_rectangle)(tdev, x, y, w, h, color));
@@ -432,7 +393,8 @@ bbox_copy_mono(gx_device * dev, const byte * data,
gx_color_index zero, gx_color_index one)
{
gx_device_bbox *const bdev = (gx_device_bbox *) dev;
- /* gx_forward_copy_mono doesn't exist */
+ /* gx_forward_copy_mono exists, but does the wrong thing in
+ * the event of a NULL target, so open code it here. */
gx_device *tdev = bdev->target;
int code =
(tdev == 0 ? 0 :
@@ -451,7 +413,8 @@ bbox_copy_color(gx_device * dev, const byte * data,
int dx, int raster, gx_bitmap_id id, int x, int y, int w, int h)
{
gx_device_bbox *const bdev = (gx_device_bbox *) dev;
- /* gx_forward_copy_color doesn't exist */
+ /* gx_forward_copy_color exists, but does the wrong thing in
+ * the event of a NULL target, so open code it here. */
gx_device *tdev = bdev->target;
int code =
(tdev == 0 ? 0 :
@@ -468,7 +431,8 @@ bbox_copy_alpha(gx_device * dev, const byte * data, int data_x,
gx_color_index color, int depth)
{
gx_device_bbox *const bdev = (gx_device_bbox *) dev;
- /* gx_forward_copy_alpha doesn't exist */
+ /* gx_forward_copy_alpha exists, but does the wrong thing in
+ * the event of a NULL target, so open code it here. */
gx_device *tdev = bdev->target;
int code =
(tdev == 0 ? 0 :
@@ -512,29 +476,6 @@ bbox_strip_tile_rect_devn(gx_device * dev, const gx_strip_bitmap * tiles,
}
static int
-bbox_strip_copy_rop(gx_device * dev,
- const byte * sdata, int sourcex, uint sraster,
- gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_strip_bitmap * textures,
- const gx_color_index * tcolors,
- int x, int y, int w, int h,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- gx_device_bbox *const bdev = (gx_device_bbox *) dev;
- /* gx_forward_strip_copy_rop doesn't exist */
- gx_device *tdev = bdev->target;
- int code =
- (tdev == 0 ? 0 :
- dev_proc(tdev, strip_copy_rop)
- (tdev, sdata, sourcex, sraster, id, scolors,
- textures, tcolors, x, y, w, h, phase_x, phase_y, lop));
-
- BBOX_ADD_INT_RECT(bdev, x, y, x + w, y + h);
- return code;
-}
-
-static int
bbox_strip_copy_rop2(gx_device * dev,
const byte * sdata, int sourcex, uint sraster,
gx_bitmap_id id,
@@ -546,7 +487,8 @@ bbox_strip_copy_rop2(gx_device * dev,
uint planar_height)
{
gx_device_bbox *const bdev = (gx_device_bbox *) dev;
- /* gx_forward_strip_copy_rop doesn't exist */
+ /* gx_forward_strip_copy_rop2 exists, but does the wrong thing in
+ * the event of a NULL target, so open code it here. */
gx_device *tdev = bdev->target;
int code =
(tdev == 0 ? 0 :
@@ -817,8 +759,7 @@ bbox_fill_path(gx_device * dev, const gs_gstate * pgs, gx_path * ppath,
gx_device_bbox *const bdev = (gx_device_bbox *) dev;
gx_device *tdev = bdev->target;
dev_proc_fill_path((*fill_path)) =
- (tdev == 0 ? dev_proc(&gs_null_device, fill_path) :
- dev_proc(tdev, fill_path));
+ (tdev == 0 ? NULL : dev_proc(tdev, fill_path));
int code;
gx_drawing_color devc;
@@ -846,18 +787,25 @@ bbox_fill_path(gx_device * dev, const gs_gstate * pgs, gx_path * ppath,
* If the path lies within the already accumulated box, just draw
* on the target.
*/
- if (BBOX_IN_RECT(bdev, &ibox))
+ if (BBOX_IN_RECT(bdev, &ibox)) {
+ /* If we have no target device, just exit */
+ if (fill_path == NULL)
+ return 0;
return fill_path(tdev, pgs, ppath, params, pdevc, pcpath);
- /*
- * If the target uses the default algorithm, just draw on the
- * bbox device.
- */
- if (tdev != 0 && fill_path == gx_default_fill_path)
- return fill_path(dev, pgs, ppath, params, pdevc, pcpath);
- /* Draw on the target now. */
- code = fill_path(tdev, pgs, ppath, params, pdevc, pcpath);
- if (code < 0)
- return code;
+ }
+ if (tdev != 0) {
+ /*
+ * If the target uses the default algorithm, just draw on the
+ * bbox device.
+ */
+ if (fill_path == gx_default_fill_path)
+ return fill_path(dev, pgs, ppath, params, pdevc, pcpath);
+ /* Draw on the target now. */
+ code = fill_path(tdev, pgs, ppath, params, pdevc, pcpath);
+ if (code < 0)
+ return code;
+ }
+
/* Previously we would use the path bbox above usually, but that bbox is
* inaccurate for curves, because it considers the control points of the
* curves to be included whcih of course they are not. Now we scan-convert
@@ -873,7 +821,9 @@ bbox_fill_path(gx_device * dev, const gs_gstate * pgs, gx_path * ppath,
code = gx_default_fill_path(dev, pgs, ppath, params, &devc, pcpath);
bdev->target = tdev;
return code;
- } else
+ } else if (fill_path == NULL)
+ return 0;
+ else
return fill_path(tdev, pgs, ppath, params, pdevc, pcpath);
}
@@ -950,8 +900,9 @@ bbox_fill_mask(gx_device * dev,
pdcolor, depth, lop, pcpath);
bdev->target = tdev;
} else {
- /* Just use the mask bounding box. */
- BBOX_ADD_INT_RECT(bdev, x, y, x + w, y + h);
+ if (w > 0 && h > 0)
+ /* Just use the mask bounding box. */
+ BBOX_ADD_INT_RECT(bdev, x, y, x + w, y + h);
}
return code;
}
@@ -1010,15 +961,8 @@ bbox_image_begin(const gs_gstate * pgs, const gs_matrix * pmat,
pbe->x0 = prect->p.x, pbe->x1 = prect->q.x;
pbe->y = prect->p.y, pbe->height = prect->q.y - prect->p.y;
} else {
- gs_int_point size;
- int code = (*pic->type->source_size) (pgs, pic, &size);
-
- if (code < 0) {
- gs_free_object(memory, pbe, "bbox_image_begin");
- return code;
- }
- pbe->x0 = 0, pbe->x1 = size.x;
- pbe->y = 0, pbe->height = size.y;
+ pbe->x0 = 0, pbe->x1 = pic->Width;
+ pbe->y = 0, pbe->height = pic->Height;
}
*ppbe = pbe;
return 0;
@@ -1051,7 +995,7 @@ bbox_begin_typed_image(gx_device * dev,
if (code < 0)
return code;
/*
- * If there is no target, we still have to call default_begin_image
+ * If there is no target, we still have to call default_begin_typed_image
* to get the correct num_planes and plane_depths.
*/
{
@@ -1145,8 +1089,9 @@ bbox_image_plane_data(gx_image_enum_common_t * info,
bx2, by2, &devc, lop_default);
bdev->target = tdev;
} else {
- /* Just use the bounding box. */
- BBOX_ADD_RECT(bdev, ibox.p.x, ibox.p.y, ibox.q.x, ibox.q.y);
+ /* Just use the bounding box if the image is not 0 width or height */
+ if (ibox.p.x != ibox.q.x && ibox.p.y != ibox.q.y)
+ BBOX_ADD_RECT(bdev, ibox.p.x, ibox.p.y, ibox.q.x, ibox.q.y);
}
return code;
}
@@ -1218,7 +1163,7 @@ static const gx_device_bbox_procs_t box_procs_forward = {
};
static int
-bbox_create_compositor(gx_device * dev,
+bbox_composite(gx_device * dev,
gx_device ** pcdev, const gs_composite_t * pcte,
gs_gstate * pgs, gs_memory_t * memory, gx_device *cindev)
{
@@ -1241,7 +1186,7 @@ bbox_create_compositor(gx_device * dev,
{
gx_device *temp_cdev;
gx_device_bbox *bbcdev;
- int code = (*dev_proc(target, create_compositor))
+ int code = (*dev_proc(target, composite))
(target, &temp_cdev, pcte, pgs, memory, cindev);
/* If the target did not create a new compositor then we are done. */
@@ -1251,7 +1196,7 @@ bbox_create_compositor(gx_device * dev,
}
bbcdev = gs_alloc_struct_immovable(memory, gx_device_bbox,
&st_device_bbox,
- "bbox_create_compositor");
+ "bbox_composite");
if (bbcdev == 0) {
(*dev_proc(temp_cdev, close_device)) (temp_cdev);
return_error(gs_error_VMerror);
@@ -1272,13 +1217,12 @@ bbox_create_compositor(gx_device * dev,
static int
bbox_text_begin(gx_device * dev, gs_gstate * pgs,
const gs_text_params_t * text, gs_font * font,
- gx_path * path, const gx_device_color * pdcolor,
const gx_clip_path * pcpath,
- gs_memory_t * memory, gs_text_enum_t ** ppenum)
+ gs_text_enum_t ** ppenum)
{
gx_device_bbox *const bdev = (gx_device_bbox *) dev;
- int code = gx_default_text_begin(dev, pgs, text, font, path, pdcolor,
- pcpath, memory, ppenum);
+ int code = gx_default_text_begin(dev, pgs, text, font,
+ pcpath, ppenum);
if (code >=0 && bdev->target != NULL) {
/* See note on imaging_dev in gxtext.h */
diff --git a/base/gdevdbit.c b/base/gdevdbit.c
index aba17446..a04e0b33 100644
--- a/base/gdevdbit.c
+++ b/base/gdevdbit.c
@@ -28,21 +28,6 @@
#undef mdev
#include "gxcpath.h"
-/* By default, implement tile_rectangle using strip_tile_rectangle. */
-int
-gx_default_tile_rectangle(gx_device * dev, const gx_tile_bitmap * tile,
- int x, int y, int w, int h, gx_color_index color0, gx_color_index color1,
- int px, int py)
-{
- gx_strip_bitmap tiles;
-
- *(gx_tile_bitmap *) & tiles = *tile;
- tiles.shift = tiles.rep_shift = 0;
- tiles.num_planes = 1;
- return (*dev_proc(dev, strip_tile_rectangle))
- (dev, &tiles, x, y, w, h, color0, color1, px, py);
-}
-
/* Implement copy_mono by filling lots of small rectangles. */
/* This is very inefficient, but it works as a default. */
int
@@ -241,7 +226,7 @@ gx_default_copy_alpha_hl_color(gx_device * dev, const byte * data, int data_x,
gb_params.data[j] = 0;
gb_params.data[k] = gb_buff + k * out_raster;
code = dev_proc(dev, get_bits_rectangle) (dev, &gb_rect,
- &gb_params, 0);
+ &gb_params);
src_planes[k] = gb_params.data[k];
if (code < 0) {
gs_free_object(mem, gb_buff, "copy_alpha_hl_color");
@@ -370,6 +355,7 @@ gx_default_copy_alpha(gx_device * dev, const byte * data, int data_x,
int code = 0;
gx_color_value color_cv[GX_DEVICE_COLOR_MAX_COMPONENTS];
int ry, lx;
+ gs_int_rect rect;
fit_copy(dev, data, data_x, raster, id, x, y, width, height);
row = data;
@@ -381,6 +367,8 @@ gx_default_copy_alpha(gx_device * dev, const byte * data, int data_x,
goto out;
}
(*dev_proc(dev, decode_color)) (dev, color, color_cv);
+ rect.p.x = 0;
+ rect.q.x = dev->width;
for (ry = y; ry < y + height; row += raster, ++ry) {
byte *line;
int sx, rx;
@@ -389,10 +377,23 @@ gx_default_copy_alpha(gx_device * dev, const byte * data, int data_x,
int l_dbit = 0;
byte l_dbyte = ((l_dbit) ? (byte)(*(l_dptr) & (0xff00 >> (l_dbit))) : 0);
int l_xprev = x;
-
- code = (*dev_proc(dev, get_bits)) (dev, ry, lin, &line);
+ gs_get_bits_params_t params;
+
+ params.options = (GB_ALIGN_ANY |
+ (GB_RETURN_COPY | GB_RETURN_POINTER) |
+ GB_OFFSET_0 |
+ GB_RASTER_STANDARD | GB_PACKING_CHUNKY |
+ GB_COLORS_NATIVE | GB_ALPHA_NONE);
+ params.x_offset = 0;
+ params.raster = bitmap_raster(dev->width * dev->color_info.depth);
+ params.data[0] = lin;
+ rect.p.y = ry;
+ rect.q.y = ry+1;
+ code = (*dev_proc(dev, get_bits_rectangle))(dev, &rect,
+ &params);
if (code < 0)
break;
+ line = params.data[0];
lx = x;
for (sx = data_x, rx = x; sx < data_x + width; ++sx, ++rx) {
gx_color_index previous = gx_no_color_index;
@@ -530,17 +531,6 @@ gx_default_copy_alpha(gx_device * dev, const byte * data, int data_x,
}
int
-gx_no_copy_rop(gx_device * dev,
- const byte * sdata, int sourcex, uint sraster, gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_tile_bitmap * texture, const gx_color_index * tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- return_error(gs_error_unknownerror); /* not implemented */
-}
-
-int
gx_default_fill_mask(gx_device * orig_dev,
const byte * data, int dx, int raster, gx_bitmap_id id,
int x, int y, int w, int h,
@@ -644,27 +634,7 @@ gx_default_strip_tile_rectangle(gx_device * dev, const gx_strip_bitmap * tiles,
}
#endif
- if (dev_proc(dev, tile_rectangle) != gx_default_tile_rectangle) {
- if (shift == 0) { /*
- * Temporarily patch the tile_rectangle procedure in the
- * device so we don't get into a recursion loop if the
- * device has a tile_rectangle procedure that conditionally
- * calls the strip_tile_rectangle procedure.
- */
- dev_proc_tile_rectangle((*tile_proc)) =
- dev_proc(dev, tile_rectangle);
- int code = 0;
-
- set_dev_proc(dev, tile_rectangle, gx_default_tile_rectangle);
- code = (*tile_proc)
- (dev, (const gx_tile_bitmap *)tiles, x, y, w, h,
- color0, color1, px, py);
- set_dev_proc(dev, tile_rectangle, tile_proc);
- return code;
- }
- /* We should probably optimize this case too, for the benefit */
- /* of window systems, but we don't yet. */
- } { /*
+ { /*
* Note: we can't do the following computations until after
* the fit_fill_xy.
*/
@@ -794,12 +764,13 @@ gx_default_strip_tile_rectangle(gx_device * dev, const gx_strip_bitmap * tiles,
}
int
-gx_no_strip_copy_rop(gx_device * dev,
+gx_no_strip_copy_rop2(gx_device * dev,
const byte * sdata, int sourcex, uint sraster, gx_bitmap_id id,
const gx_color_index * scolors,
const gx_strip_bitmap * textures, const gx_color_index * tcolors,
int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
+ int phase_x, int phase_y, gs_logical_operation_t lop,
+ uint planar_height)
{
return_error(gs_error_unknownerror); /* not implemented */
}
diff --git a/base/gdevddrw.c b/base/gdevddrw.c
index 4f91a02d..1d22e746 100644
--- a/base/gdevddrw.c
+++ b/base/gdevddrw.c
@@ -955,14 +955,6 @@ gx_default_draw_thin_line(gx_device * dev,
}
}
-/* Stub out the obsolete procedure. */
-int
-gx_default_draw_line(gx_device * dev,
- int x0, int y0, int x1, int y1, gx_color_index color)
-{
- return -1;
-}
-
/* ---------------- Image drawing ---------------- */
/* GC structures for image enumerator */
@@ -980,51 +972,6 @@ static RELOC_PTRS_WITH(image_enum_common_reloc_ptrs, gx_image_enum_common_t *ept
}
RELOC_PTRS_END
-/*
- * gx_default_begin_image is only invoked for ImageType 1 images. However,
- * the argument types are different, and if the device provides a
- * begin_typed_image procedure, we should use it. See gxdevice.h.
- */
-static int
-gx_no_begin_image(gx_device * dev,
- const gs_gstate * pgs, const gs_image_t * pim,
- gs_image_format_t format, const gs_int_rect * prect,
- const gx_drawing_color * pdcolor, const gx_clip_path * pcpath,
- gs_memory_t * memory, gx_image_enum_common_t ** pinfo)
-{
- return -1;
-}
-int
-gx_default_begin_image(gx_device * dev,
- const gs_gstate * pgs, const gs_image_t * pim,
- gs_image_format_t format, const gs_int_rect * prect,
- const gx_drawing_color * pdcolor, const gx_clip_path * pcpath,
- gs_memory_t * memory, gx_image_enum_common_t ** pinfo)
-{
- /*
- * Hand off to begin_typed_image, being careful to avoid a
- * possible recursion loop.
- */
- dev_proc_begin_image((*save_begin_image)) = dev_proc(dev, begin_image);
- gs_image_t image;
- const gs_image_t *ptim;
- int code;
-
- set_dev_proc(dev, begin_image, gx_no_begin_image);
- if (pim->format == format)
- ptim = pim;
- else {
- image = *pim;
- image.format = format;
- ptim = &image;
- }
- code = (*dev_proc(dev, begin_typed_image))
- (dev, pgs, NULL, (const gs_image_common_t *)ptim, prect, pdcolor,
- pcpath, memory, pinfo);
- set_dev_proc(dev, begin_image, save_begin_image);
- return code;
-}
-
int
gx_default_begin_typed_image(gx_device * dev,
const gs_gstate * pgs, const gs_matrix * pmat,
@@ -1032,44 +979,10 @@ gx_default_begin_typed_image(gx_device * dev,
const gx_drawing_color * pdcolor, const gx_clip_path * pcpath,
gs_memory_t * memory, gx_image_enum_common_t ** pinfo)
{
- /* If this is an ImageType 1 image using the gs_gstate's CTM,
- * defer to begin_image.
- */
- if (pic->type->begin_typed_image == gx_begin_image1) {
- const gs_image_t *pim = (const gs_image_t *)pic;
-
- if (pmat == 0 ||
- (pgs != 0 && !gs_matrix_compare(pmat, &ctm_only(pgs)))
- ) {
- int code = (*dev_proc(dev, begin_image))
- (dev, pgs, pim, pim->format, prect, pdcolor,
- pcpath, memory, pinfo);
-
- if (code >= 0)
- return code;
- }
- }
return (*pic->type->begin_typed_image)
(dev, pgs, pmat, pic, prect, pdcolor, pcpath, memory, pinfo);
}
-/* Backward compatibility for obsolete driver procedures. */
-
-int
-gx_default_image_data(gx_device *dev, gx_image_enum_common_t * info,
- const byte ** plane_data,
- int data_x, uint raster, int height)
-{
- return gx_image_data(info, plane_data, data_x, raster, height);
-}
-
-int
-gx_default_end_image(gx_device *dev, gx_image_enum_common_t * info,
- bool draw_last)
-{
- return gx_image_end(info, draw_last);
-}
-
int
gx_default_fillpage(gx_device *dev, gs_gstate * pgs, gx_device_color *pdevc)
{
diff --git a/base/gdevdevn.c b/base/gdevdevn.c
index 692edf76..f6791276 100644
--- a/base/gdevdevn.c
+++ b/base/gdevdevn.c
@@ -38,7 +38,7 @@
/* Convert a gray color space to DeviceN colorants. */
void
-gray_cs_to_devn_cm(gx_device * dev, int * map, frac gray, frac out[])
+gray_cs_to_devn_cm(const gx_device * dev, int * map, frac gray, frac out[])
{
int i = dev->color_info.num_components - 1;
@@ -50,7 +50,7 @@ gray_cs_to_devn_cm(gx_device * dev, int * map, frac gray, frac out[])
/* Convert an RGB color space to DeviceN colorants. */
void
-rgb_cs_to_devn_cm(gx_device * dev, int * map,
+rgb_cs_to_devn_cm(const gx_device * dev, int * map,
const gs_gstate *pgs, frac r, frac g, frac b, frac out[])
{
int i = dev->color_info.num_components - 1;
@@ -71,7 +71,7 @@ rgb_cs_to_devn_cm(gx_device * dev, int * map,
/* Convert a CMYK color space to DeviceN colorants. */
void
-cmyk_cs_to_devn_cm(gx_device * dev, const int * map,
+cmyk_cs_to_devn_cm(const gx_device * dev, const int * map,
frac c, frac m, frac y, frac k, frac out[])
{
int i = dev->color_info.num_components - 1;
@@ -845,8 +845,19 @@ devn_printer_put_params(gx_device * pdev, gs_param_list * plist,
!devn_params_equal(pdevn_params, &saved_devn_params) ||
(pequiv_colors != NULL &&
compare_equivalent_cmyk_color_params(pequiv_colors, &saved_equiv_colors))) {
- gs_closedevice(pdev);
- /* Reset the sparable and linear shift, masks, bits. */
+ gx_device *parent_dev = pdev;
+ gx_device_color_info resave_info = pdev->color_info;
+
+ while (parent_dev->parent != NULL)
+ parent_dev = parent_dev->parent;
+
+ /* Temporarily restore the old color_info, so the close happens with
+ * the old version. In particular this allows Nup to flush properly. */
+ pdev->color_info = save_info;
+ gs_closedevice(parent_dev);
+ /* Then put the shiny new color_info back in. */
+ pdev->color_info = resave_info;
+ /* Reset the separable and linear shift, masks, bits. */
set_linear_color_bits_mask_shift(pdev);
}
/*
@@ -940,71 +951,21 @@ gs_public_st_composite_final(st_gx_devn_prn_device, gx_devn_prn_device,
"gx_devn_prn_device", gx_devn_prn_device_enum_ptrs, gx_devn_prn_device_reloc_ptrs,
static_gx_devn_prn_device_finalize);
-/*
- * Macro definition for DeviceN procedures
- */
-#define device_procs()\
-{ spotcmyk_prn_open,\
- gx_default_get_initial_matrix,\
- NULL, /* sync_output */\
- gdev_prn_output_page, /* output_page */\
- gdev_prn_close, /* close */\
- NULL, /* map_rgb_color - not used */\
- NULL, /* map_color_rgb - not used */\
- NULL, /* fill_rectangle */\
- NULL, /* tile_rectangle */\
- NULL, /* copy_mono */\
- NULL, /* copy_color */\
- NULL, /* draw_line */\
- NULL, /* get_bits */\
- gx_devn_prn_get_params, /* get_params */\
- gx_devn_prn_put_params, /* put_params */\
- NULL, /* map_cmyk_color - not used */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- gx_page_device_get_page_device, /* get_page_device */\
- NULL, /* get_alpha_bits */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- NULL, /* fill_path */\
- NULL, /* stroke_path */\
- NULL, /* fill_mask */\
- NULL, /* fill_trapezoid */\
- NULL, /* fill_parallelogram */\
- NULL, /* fill_triangle */\
- NULL, /* draw_thin_line */\
- NULL, /* begin_image */\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL, /* strip_copy_rop */\
- NULL, /* get_clipping_box */\
- NULL, /* begin_typed_image */\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- NULL, /* create_compositor */\
- NULL, /* get_hardware_params */\
- NULL, /* text_begin */\
- NULL, /* finish_copydevice */\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL, /* discard_transparency_layer */\
- gx_devn_prn_get_color_mapping_procs,/* get_color_mapping_procs */\
- gx_devn_prn_get_color_comp_index,/* get_color_comp_index */\
- gx_devn_prn_encode_color, /* encode_color */\
- gx_devn_prn_decode_color, /* decode_color */\
- NULL, /* pattern_manage */\
- NULL, /* fill_rectangle_hl_color */\
- NULL, /* include_color_space */\
- NULL, /* fill_linear_color_scanline */\
- NULL, /* fill_linear_color_trapezoid */\
- NULL, /* fill_linear_color_triangle */\
- gx_devn_prn_update_spot_equivalent_colors,/* update_spot_equivalent_colors */\
- gx_devn_prn_ret_devn_params /* ret_devn_params */\
+static void
+devicen_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, spotcmyk_prn_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page);
+ set_dev_proc(dev, close_device, gdev_prn_close);
+ set_dev_proc(dev, get_params, gx_devn_prn_get_params);
+ set_dev_proc(dev, put_params, gx_devn_prn_put_params);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
+ set_dev_proc(dev, get_color_mapping_procs, gx_devn_prn_get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, gx_devn_prn_get_color_comp_index);
+ set_dev_proc(dev, encode_color, gx_devn_prn_encode_color);
+ set_dev_proc(dev, decode_color, gx_devn_prn_decode_color);
+ set_dev_proc(dev, update_spot_equivalent_colors, gx_devn_prn_update_spot_equivalent_colors);
+ set_dev_proc(dev, ret_devn_params, gx_devn_prn_ret_devn_params);
}
fixed_colorant_name DeviceGrayComponents[] = {
@@ -1027,8 +988,8 @@ fixed_colorant_name DeviceCMYKComponents[] = {
0 /* List terminator */
};
-#define gx_devn_prn_device_body(procs, dname, ncomp, pol, depth, mg, mc, cn)\
- std_device_full_body_type_extended(gx_devn_prn_device, &procs, dname,\
+#define gx_devn_prn_device_body(init, dname, ncomp, pol, depth, mg, mc, cn)\
+ std_device_full_body_type_extended(gx_devn_prn_device, init, dname,\
&st_gx_devn_prn_device,\
(int)((long)(DEFAULT_WIDTH_10THS) * (X_DPI) / 10),\
(int)((long)(DEFAULT_HEIGHT_10THS) * (Y_DPI) / 10),\
@@ -1049,11 +1010,11 @@ fixed_colorant_name DeviceCMYKComponents[] = {
/*
* Example device with CMYK and spot color support
*/
-static const gx_device_procs spot_cmyk_procs = device_procs();
-
const gx_devn_prn_device gs_spotcmyk_device =
{
- gx_devn_prn_device_body(spot_cmyk_procs, "spotcmyk", 4, GX_CINFO_POLARITY_SUBTRACTIVE, 4, 1, 1, "DeviceCMYK"),
+ gx_devn_prn_device_body(devicen_initialize_device_procs, "spotcmyk",
+ 4, GX_CINFO_POLARITY_SUBTRACTIVE, 4, 1, 1,
+ "DeviceCMYK"),
/* DeviceN device specific parameters */
{ 1, /* Bits per color - must match ncomp, depth, etc. above */
DeviceCMYKComponents, /* Names of color model colorants */
@@ -1069,11 +1030,11 @@ const gx_devn_prn_device gs_spotcmyk_device =
/*
* Example DeviceN color device
*/
-static const gx_device_procs devicen_procs = device_procs();
-
const gx_devn_prn_device gs_devicen_device =
{
- gx_devn_prn_device_body(devicen_procs, "devicen", 4, GX_CINFO_POLARITY_SUBTRACTIVE, 32, 255, 255, "DeviceCMYK"),
+ gx_devn_prn_device_body(devicen_initialize_device_procs, "devicen",
+ 4, GX_CINFO_POLARITY_SUBTRACTIVE, 32, 255, 255,
+ "DeviceCMYK"),
/* DeviceN device specific parameters */
{ 8, /* Bits per color - must match ncomp, depth, etc. above */
DeviceCMYKComponents, /* Names of color model colorants */
@@ -1103,7 +1064,7 @@ spotcmyk_prn_open(gx_device * pdev)
/* Color mapping routines for the spotcmyk device */
static void
-gray_cs_to_spotcmyk_cm(gx_device * dev, frac gray, frac out[])
+gray_cs_to_spotcmyk_cm(const gx_device * dev, frac gray, frac out[])
{
int * map = ((gx_devn_prn_device *) dev)->devn_params.separation_order_map;
@@ -1111,7 +1072,7 @@ gray_cs_to_spotcmyk_cm(gx_device * dev, frac gray, frac out[])
}
static void
-rgb_cs_to_spotcmyk_cm(gx_device * dev, const gs_gstate *pgs,
+rgb_cs_to_spotcmyk_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
int * map = ((gx_devn_prn_device *) dev)->devn_params.separation_order_map;
@@ -1120,7 +1081,7 @@ rgb_cs_to_spotcmyk_cm(gx_device * dev, const gs_gstate *pgs,
}
static void
-cmyk_cs_to_spotcmyk_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+cmyk_cs_to_spotcmyk_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
int * map = ((gx_devn_prn_device *) dev)->devn_params.separation_order_map;
@@ -1132,8 +1093,9 @@ static const gx_cm_color_map_procs spotCMYK_procs = {
};
const gx_cm_color_map_procs *
-gx_devn_prn_get_color_mapping_procs(const gx_device * dev)
+gx_devn_prn_get_color_mapping_procs(const gx_device * dev, const gx_device **map_dev)
{
+ *map_dev = dev;
return &spotCMYK_procs;
}
@@ -1211,6 +1173,14 @@ gx_devn_prn_ret_devn_params(gx_device * dev)
return &pdev->devn_params;
}
+const gs_devn_params *
+gx_devn_prn_ret_devn_params_const(const gx_device * dev)
+{
+ const gx_devn_prn_device *pdev = (const gx_devn_prn_device *)dev;
+
+ return &pdev->devn_params;
+}
+
/*
* Device proc for updating the equivalent CMYK color for spot colors.
*/
@@ -1882,7 +1852,7 @@ devn_pcx_write_page(gx_device_printer * pdev, gp_file * infile, int linesize, gp
/* If needed, convert to rgb */
if (convert_to_rgb) {
int i;
- byte *row_in = line;
+ byte *row_in = line;
/* Transform the data. */
row = rgb_buff; /* adjust to converted output buffer */
diff --git a/base/gdevdevn.h b/base/gdevdevn.h
index fb34e1c0..89d7b882 100644
--- a/base/gdevdevn.h
+++ b/base/gdevdevn.h
@@ -21,9 +21,6 @@
#include "gxblend.h"
#include "gsequivc.h"
-/* See Comments in gdevtsep.c or gdevpsd.c as to the purpose of this */
-#define LIMIT_TO_ICC 1
-
/*
* Type definitions associated with the fixed color model names.
*/
@@ -110,12 +107,12 @@ extern fixed_colorant_name DeviceCMYKComponents[];
* Convert standard color spaces into DeviceN colorants.
* Note; This routine require SeparationOrder map.
*/
-void gray_cs_to_devn_cm(gx_device * dev, int * map, frac gray, frac out[]);
+void gray_cs_to_devn_cm(const gx_device * dev, int * map, frac gray, frac out[]);
-void rgb_cs_to_devn_cm(gx_device * dev, int * map,
+void rgb_cs_to_devn_cm(const gx_device * dev, int * map,
const gs_gstate *pgs, frac r, frac g, frac b, frac out[]);
-void cmyk_cs_to_devn_cm(gx_device * dev, const int * map,
+void cmyk_cs_to_devn_cm(const gx_device * dev, const int * map,
frac c, frac m, frac y, frac k, frac out[]);
/*
diff --git a/base/gdevdevnprn.h b/base/gdevdevnprn.h
index 4d556b60..fb009286 100644
--- a/base/gdevdevnprn.h
+++ b/base/gdevdevnprn.h
@@ -54,6 +54,7 @@ dev_proc_encode_color(gx_devn_prn_encode_color);
dev_proc_decode_color(gx_devn_prn_decode_color);
dev_proc_update_spot_equivalent_colors(gx_devn_prn_update_spot_equivalent_colors);
dev_proc_ret_devn_params(gx_devn_prn_ret_devn_params);
+dev_proc_ret_devn_params_const(gx_devn_prn_ret_devn_params_const);
#endif /* ifndef gdevdevnprn_INCLUDED */
diff --git a/base/gdevdflt.c b/base/gdevdflt.c
index 4f92c7a2..71d8c1c7 100644
--- a/base/gdevdflt.c
+++ b/base/gdevdflt.c
@@ -127,18 +127,19 @@ static gx_color_index
static bool
is_like_DeviceRGB(gx_device * dev)
{
- subclass_color_mappings scm;
frac cm_comp_fracs[3];
int i;
+ const gx_device *cmdev;
+ const gx_cm_color_map_procs *cmprocs;
if ( dev->color_info.num_components != 3 ||
dev->color_info.polarity != GX_CINFO_POLARITY_ADDITIVE )
return false;
- scm = get_color_mapping_procs_subclass(dev);
+ cmprocs = dev_proc(dev, get_color_mapping_procs)(dev, &cmdev);
/* check the values 1/4, 1/3, and 3/4 */
- map_rgb_subclass(scm, 0, frac_1 / 4, frac_1 / 3, 3 * frac_1 / 4,cm_comp_fracs);
+ cmprocs->map_rgb(cmdev, 0, frac_1 / 4, frac_1 / 3, 3 * frac_1 / 4, cm_comp_fracs);
/* verify results to .01 */
cm_comp_fracs[0] -= frac_1 / 4;
@@ -159,23 +160,24 @@ is_like_DeviceRGB(gx_device * dev)
static bool
is_like_DeviceCMYK(gx_device * dev)
{
- subclass_color_mappings scm;
frac cm_comp_fracs[4];
int i;
+ const gx_device *cmdev;
+ const gx_cm_color_map_procs *cmprocs;
if ( dev->color_info.num_components != 4 ||
dev->color_info.polarity != GX_CINFO_POLARITY_SUBTRACTIVE )
return false;
- scm = get_color_mapping_procs_subclass(dev);
+ cmprocs = dev_proc(dev, get_color_mapping_procs)(dev, &cmdev);
/* check the values 1/4, 1/3, 3/4, and 1/8 */
- map_cmyk_subclass( scm,
- frac_1 / 4,
- frac_1 / 3,
- 3 * frac_1 / 4,
- frac_1 / 8,
- cm_comp_fracs );
+ cmprocs->map_cmyk(cmdev,
+ frac_1 / 4,
+ frac_1 / 3,
+ 3 * frac_1 / 4,
+ frac_1 / 8,
+ cm_comp_fracs);
/* verify results to .01 */
cm_comp_fracs[0] -= frac_1 / 4;
@@ -586,7 +588,6 @@ int gx_default_no_copy_alpha_hl_color(gx_device * dev, const byte * data, int da
void
gx_device_fill_in_procs(register gx_device * dev)
{
- gx_device_set_procs(dev);
fill_dev_proc(dev, open_device, gx_default_open_device);
fill_dev_proc(dev, get_initial_matrix, gx_default_get_initial_matrix);
fill_dev_proc(dev, sync_output, gx_default_sync_output);
@@ -595,22 +596,14 @@ gx_device_fill_in_procs(register gx_device * dev)
/* see below for map_rgb_color */
fill_dev_proc(dev, map_color_rgb, gx_default_map_color_rgb);
/* NOT fill_rectangle */
- fill_dev_proc(dev, tile_rectangle, gx_default_tile_rectangle);
fill_dev_proc(dev, copy_mono, gx_default_copy_mono);
fill_dev_proc(dev, copy_color, gx_default_copy_color);
- fill_dev_proc(dev, obsolete_draw_line, gx_default_draw_line);
- fill_dev_proc(dev, get_bits, gx_default_get_bits);
fill_dev_proc(dev, get_params, gx_default_get_params);
fill_dev_proc(dev, put_params, gx_default_put_params);
/* see below for map_cmyk_color */
- fill_dev_proc(dev, get_xfont_procs, gx_default_get_xfont_procs);
- fill_dev_proc(dev, get_xfont_device, gx_default_get_xfont_device);
- fill_dev_proc(dev, map_rgb_alpha_color, gx_default_map_rgb_alpha_color);
fill_dev_proc(dev, get_page_device, gx_default_get_page_device);
fill_dev_proc(dev, get_alpha_bits, gx_default_get_alpha_bits);
fill_dev_proc(dev, copy_alpha, gx_default_copy_alpha);
- fill_dev_proc(dev, get_band, gx_default_get_band);
- fill_dev_proc(dev, copy_rop, gx_default_copy_rop);
fill_dev_proc(dev, fill_path, gx_default_fill_path);
fill_dev_proc(dev, stroke_path, gx_default_stroke_path);
fill_dev_proc(dev, fill_mask, gx_default_fill_mask);
@@ -618,43 +611,16 @@ gx_device_fill_in_procs(register gx_device * dev)
fill_dev_proc(dev, fill_parallelogram, gx_default_fill_parallelogram);
fill_dev_proc(dev, fill_triangle, gx_default_fill_triangle);
fill_dev_proc(dev, draw_thin_line, gx_default_draw_thin_line);
- fill_dev_proc(dev, begin_image, gx_default_begin_image);
- /*
- * We always replace get_alpha_bits, image_data, and end_image with the
- * new procedures, and, if in a DEBUG configuration, print a warning if
- * the definitions aren't the default ones.
- */
-#ifdef DEBUG
-# define CHECK_NON_DEFAULT(proc, default, procname)\
- BEGIN\
- if ( dev_proc(dev, proc) != NULL && dev_proc(dev, proc) != default )\
- dmprintf2(dev->memory, "**** Warning: device %s implements obsolete procedure %s\n",\
- dev->dname, procname);\
- END
-#else
-# define CHECK_NON_DEFAULT(proc, default, procname)\
- DO_NOTHING
-#endif
- CHECK_NON_DEFAULT(get_alpha_bits, gx_default_get_alpha_bits,
- "get_alpha_bits");
- set_dev_proc(dev, get_alpha_bits, gx_default_get_alpha_bits);
- CHECK_NON_DEFAULT(image_data, gx_default_image_data, "image_data");
- set_dev_proc(dev, image_data, gx_default_image_data);
- CHECK_NON_DEFAULT(end_image, gx_default_end_image, "end_image");
- set_dev_proc(dev, end_image, gx_default_end_image);
-#undef CHECK_NON_DEFAULT
+ fill_dev_proc(dev, get_alpha_bits, gx_default_get_alpha_bits);
fill_dev_proc(dev, strip_tile_rectangle, gx_default_strip_tile_rectangle);
- fill_dev_proc(dev, strip_copy_rop, gx_default_strip_copy_rop);
fill_dev_proc(dev, strip_copy_rop2, gx_default_strip_copy_rop2);
fill_dev_proc(dev, strip_tile_rect_devn, gx_default_strip_tile_rect_devn);
fill_dev_proc(dev, get_clipping_box, gx_default_get_clipping_box);
fill_dev_proc(dev, begin_typed_image, gx_default_begin_typed_image);
fill_dev_proc(dev, get_bits_rectangle, gx_default_get_bits_rectangle);
- fill_dev_proc(dev, map_color_rgb_alpha, gx_default_map_color_rgb_alpha);
- fill_dev_proc(dev, create_compositor, gx_default_create_compositor);
+ fill_dev_proc(dev, composite, gx_default_composite);
fill_dev_proc(dev, get_hardware_params, gx_default_get_hardware_params);
fill_dev_proc(dev, text_begin, gx_default_text_begin);
- fill_dev_proc(dev, finish_copydevice, gx_default_finish_copydevice);
set_dev_proc(dev, encode_color, get_encode_color(dev));
if (dev->color_info.num_components == 3)
@@ -727,19 +693,6 @@ gx_device_fill_in_procs(register gx_device * dev)
fill_dev_proc(dev, get_profile, gx_default_get_profile);
fill_dev_proc(dev, set_graphics_type_tag, gx_default_set_graphics_type_tag);
- /*
- * If the device is known not to support overprint mode, indicate this now.
- * Note that we do not insist that a device be use a strict DeviceCMYK
- * encoding; any color model that is subtractive and supports the cyan,
- * magenta, yellow, and black color components will do. We defer a more
- * explicit check until this information is explicitly required.
- */
- if ( dev->color_info.opmode == GX_CINFO_OPMODE_UNKNOWN &&
- (dev->color_info.num_components < 4 ||
- dev->color_info.polarity == GX_CINFO_POLARITY_ADDITIVE ||
- dev->color_info.gray_index == GX_CINFO_COMP_NO_INDEX ) )
- dev->color_info.opmode = GX_CINFO_OPMODE_NOT;
-
fill_dev_proc(dev, fill_rectangle_hl_color, gx_default_fill_rectangle_hl_color);
fill_dev_proc(dev, include_color_space, gx_default_include_color_space);
fill_dev_proc(dev, fill_linear_color_scanline, gx_default_fill_linear_color_scanline);
@@ -757,7 +710,6 @@ gx_device_fill_in_procs(register gx_device * dev)
fill_dev_proc(dev, end_transparency_mask, gx_default_end_transparency_mask);
fill_dev_proc(dev, discard_transparency_layer, gx_default_discard_transparency_layer);
- fill_dev_proc(dev, pattern_manage, gx_default_pattern_manage);
fill_dev_proc(dev, push_transparency_state, gx_default_push_transparency_state);
fill_dev_proc(dev, pop_transparency_state, gx_default_pop_transparency_state);
@@ -864,18 +816,6 @@ gx_default_close_device(gx_device * dev)
return 0;
}
-const gx_xfont_procs *
-gx_default_get_xfont_procs(gx_device * dev)
-{
- return NULL;
-}
-
-gx_device *
-gx_default_get_xfont_device(gx_device * dev)
-{
- return dev;
-}
-
gx_device *
gx_default_get_page_device(gx_device * dev)
{
@@ -894,12 +834,6 @@ gx_default_get_alpha_bits(gx_device * dev, graphics_object_type type)
dev->color_info.anti_alias.graphics_bits);
}
-int
-gx_default_get_band(gx_device * dev, int y, int *band_start)
-{
- return 0;
-}
-
void
gx_default_get_clipping_box(gx_device * dev, gs_fixed_rect * pbox)
{
@@ -918,7 +852,7 @@ gx_get_largest_clipping_box(gx_device * dev, gs_fixed_rect * pbox)
}
int
-gx_no_create_compositor(gx_device * dev, gx_device ** pcdev,
+gx_no_composite(gx_device * dev, gx_device ** pcdev,
const gs_composite_t * pcte,
gs_gstate * pgs, gs_memory_t * memory,
gx_device *cdev)
@@ -926,7 +860,7 @@ gx_no_create_compositor(gx_device * dev, gx_device ** pcdev,
return_error(gs_error_unknownerror); /* not implemented */
}
int
-gx_default_create_compositor(gx_device * dev, gx_device ** pcdev,
+gx_default_composite(gx_device * dev, gx_device ** pcdev,
const gs_composite_t * pcte,
gs_gstate * pgs, gs_memory_t * memory,
gx_device *cdev)
@@ -935,7 +869,7 @@ gx_default_create_compositor(gx_device * dev, gx_device ** pcdev,
(pcte, pcdev, dev, pgs, memory);
}
int
-gx_null_create_compositor(gx_device * dev, gx_device ** pcdev,
+gx_null_composite(gx_device * dev, gx_device ** pcdev,
const gs_composite_t * pcte,
gs_gstate * pgs, gs_memory_t * memory,
gx_device *cdev)
@@ -1001,10 +935,9 @@ gx_default_composite_get_cropping(const gs_composite_t *pxcte, int *ry, int *rhe
}
int
-gx_default_finish_copydevice(gx_device *dev, const gx_device *from_dev)
+gx_default_initialize_device(gx_device *dev)
{
- /* Only allow copying the prototype. */
- return (from_dev->memory ? gs_note_error(gs_error_rangecheck) : 0);
+ return 0;
}
int
@@ -1028,6 +961,7 @@ gx_default_dev_spec_op(gx_device *pdev, int dev_spec_op, void *data, int size)
case gxdso_supports_iccpostrender:
case gxdso_supports_alpha:
case gxdso_pdf14_sep_device:
+ case gxdso_supports_pattern_transparency:
return 0;
case gxdso_pattern_shfill_doesnt_need_path:
return (dev_proc(pdev, fill_path) == gx_default_fill_path);
@@ -1171,12 +1105,6 @@ gx_default_discard_transparency_layer(gx_device *dev, gs_gstate *pgs)
}
int
-gx_default_pattern_manage(gx_device *pdev, gx_bitmap_id id, gs_pattern1_instance_t *pinst, pattern_manage_t function)
-{
- return_error(gs_error_undefined);
-}
-
-int
gx_default_push_transparency_state(gx_device *dev, gs_gstate *pgs)
{
return 0;
@@ -1236,7 +1164,7 @@ gx_default_set_graphics_type_tag(gx_device *dev, gs_graphics_type_tag_t graphics
/* ---------------- Device subclassing procedures ---------------- */
/* Non-obvious code. The 'dest_procs' is the 'procs' memory occupied by the original device that we decided to subclass,
- * 'src_procs' is the newly allocated piece of memory, to whch we have already copied the content of the
+ * 'src_procs' is the newly allocated piece of memory, to which we have already copied the content of the
* original device (including the procs), prototype is the device structure prototype for the subclassing device.
* Here we copy the methods from the prototype to the original device procs memory *but* if the original (src_procs)
* device had a NULL method, we make the new device procs have a NULL method too.
@@ -1253,83 +1181,83 @@ gx_default_set_graphics_type_tag(gx_device *dev, gs_graphics_type_tag_t graphics
* prototype (subclass device) method if the original device had the default implementation.
* I suspect a combination of forwarding and subclassing devices will not work properly for this reason.
*/
-int gx_copy_device_procs(gx_device *dest, gx_device *src, gx_device *prototype)
-{
- set_dev_proc(dest, open_device, dev_proc(prototype, open_device));
- set_dev_proc(dest, get_initial_matrix, dev_proc(prototype, get_initial_matrix));
- set_dev_proc(dest, sync_output, dev_proc(prototype, sync_output));
- set_dev_proc(dest, output_page, dev_proc(prototype, output_page));
- set_dev_proc(dest, close_device, dev_proc(prototype, close_device));
- set_dev_proc(dest, map_rgb_color, dev_proc(prototype, map_rgb_color));
- set_dev_proc(dest, map_color_rgb, dev_proc(prototype, map_color_rgb));
- set_dev_proc(dest, fill_rectangle, dev_proc(prototype, fill_rectangle));
- set_dev_proc(dest, tile_rectangle, dev_proc(prototype, tile_rectangle));
- set_dev_proc(dest, copy_mono, dev_proc(prototype, copy_mono));
- set_dev_proc(dest, copy_color, dev_proc(prototype, copy_color));
- set_dev_proc(dest, obsolete_draw_line, dev_proc(prototype, obsolete_draw_line));
- set_dev_proc(dest, get_bits, dev_proc(prototype, get_bits));
- set_dev_proc(dest, get_params, dev_proc(prototype, get_params));
- set_dev_proc(dest, put_params, dev_proc(prototype, put_params));
- set_dev_proc(dest, map_cmyk_color, dev_proc(prototype, map_cmyk_color));
- set_dev_proc(dest, get_xfont_procs, dev_proc(prototype, get_xfont_procs));
- set_dev_proc(dest, get_xfont_device, dev_proc(prototype, get_xfont_device));
- set_dev_proc(dest, map_rgb_alpha_color, dev_proc(prototype, map_rgb_alpha_color));
- set_dev_proc(dest, get_page_device, dev_proc(prototype, get_page_device));
- set_dev_proc(dest, get_alpha_bits, dev_proc(prototype, get_alpha_bits));
- set_dev_proc(dest, copy_alpha, dev_proc(prototype, copy_alpha));
- set_dev_proc(dest, get_band, dev_proc(prototype, get_band));
- set_dev_proc(dest, copy_rop, dev_proc(prototype, copy_rop));
- set_dev_proc(dest, fill_path, dev_proc(prototype, fill_path));
- set_dev_proc(dest, stroke_path, dev_proc(prototype, stroke_path));
- set_dev_proc(dest, fill_trapezoid, dev_proc(prototype, fill_trapezoid));
- set_dev_proc(dest, fill_parallelogram, dev_proc(prototype, fill_parallelogram));
- set_dev_proc(dest, fill_triangle, dev_proc(prototype, fill_triangle));
- set_dev_proc(dest, draw_thin_line, dev_proc(prototype, draw_thin_line));
- set_dev_proc(dest, begin_image, dev_proc(prototype, begin_image));
- set_dev_proc(dest, image_data, dev_proc(prototype, image_data));
- set_dev_proc(dest, end_image, dev_proc(prototype, end_image));
- set_dev_proc(dest, strip_tile_rectangle, dev_proc(prototype, strip_tile_rectangle));
- set_dev_proc(dest, strip_copy_rop, dev_proc(prototype, strip_copy_rop));
- set_dev_proc(dest, get_clipping_box, dev_proc(prototype, get_clipping_box));
- set_dev_proc(dest, begin_typed_image, dev_proc(prototype, begin_typed_image));
- set_dev_proc(dest, get_bits_rectangle, dev_proc(prototype, get_bits_rectangle));
- set_dev_proc(dest, map_color_rgb_alpha, dev_proc(prototype, map_color_rgb_alpha));
- set_dev_proc(dest, create_compositor, dev_proc(prototype, create_compositor));
- set_dev_proc(dest, get_hardware_params, dev_proc(prototype, get_hardware_params));
- set_dev_proc(dest, text_begin, dev_proc(prototype, text_begin));
- set_dev_proc(dest, finish_copydevice, dev_proc(prototype, finish_copydevice));
- set_dev_proc(dest, discard_transparency_layer, dev_proc(prototype, discard_transparency_layer));
- set_dev_proc(dest, get_color_mapping_procs, dev_proc(prototype, get_color_mapping_procs));
- set_dev_proc(dest, get_color_comp_index, dev_proc(prototype, get_color_comp_index));
- set_dev_proc(dest, encode_color, dev_proc(prototype, encode_color));
- set_dev_proc(dest, decode_color, dev_proc(prototype, decode_color));
- set_dev_proc(dest, pattern_manage, dev_proc(prototype, pattern_manage));
- set_dev_proc(dest, fill_rectangle_hl_color, dev_proc(prototype, fill_rectangle_hl_color));
- set_dev_proc(dest, include_color_space, dev_proc(prototype, include_color_space));
- set_dev_proc(dest, fill_linear_color_scanline, dev_proc(prototype, fill_linear_color_scanline));
- set_dev_proc(dest, fill_linear_color_trapezoid, dev_proc(prototype, fill_linear_color_trapezoid));
- set_dev_proc(dest, fill_linear_color_triangle, dev_proc(prototype, fill_linear_color_triangle));
- set_dev_proc(dest, update_spot_equivalent_colors, dev_proc(prototype, update_spot_equivalent_colors));
- set_dev_proc(dest, ret_devn_params, dev_proc(prototype, ret_devn_params));
- set_dev_proc(dest, fillpage, dev_proc(prototype, fillpage));
- set_dev_proc(dest, push_transparency_state, dev_proc(prototype, push_transparency_state));
- set_dev_proc(dest, pop_transparency_state, dev_proc(prototype, pop_transparency_state));
- set_dev_proc(dest, dev_spec_op, dev_proc(prototype, dev_spec_op));
- set_dev_proc(dest, get_profile, dev_proc(prototype, get_profile));
- set_dev_proc(dest, strip_copy_rop2, dev_proc(prototype, strip_copy_rop2));
- set_dev_proc(dest, strip_tile_rect_devn, dev_proc(prototype, strip_tile_rect_devn));
- set_dev_proc(dest, process_page, dev_proc(prototype, process_page));
- set_dev_proc(dest, transform_pixel_region, dev_proc(prototype, transform_pixel_region));
- set_dev_proc(dest, fill_stroke_path, dev_proc(prototype, fill_stroke_path));
+int gx_copy_device_procs(gx_device *dest, const gx_device *src, const gx_device *pprototype)
+{
+ gx_device prototype = *pprototype;
+
+ /* In the new (as of 2021) world, the prototype does not contain
+ * device procs. We need to call the 'initialize_device_procs'
+ * function to properly populate the procs array. We can't write to
+ * the const prototype pointer we are passed in, so copy it to a
+ * local block, and initialize that instead, */
+ prototype.initialize_device_procs(&prototype);
+ /* Fill in missing entries with the global defaults */
+ gx_device_fill_in_procs(&prototype);
+
+ if (dest->initialize_device_procs == NULL)
+ dest->initialize_device_procs = prototype.initialize_device_procs;
+
+ set_dev_proc(dest, initialize_device, dev_proc(&prototype, initialize_device));
+ set_dev_proc(dest, open_device, dev_proc(&prototype, open_device));
+ set_dev_proc(dest, get_initial_matrix, dev_proc(&prototype, get_initial_matrix));
+ set_dev_proc(dest, sync_output, dev_proc(&prototype, sync_output));
+ set_dev_proc(dest, output_page, dev_proc(&prototype, output_page));
+ set_dev_proc(dest, close_device, dev_proc(&prototype, close_device));
+ set_dev_proc(dest, map_rgb_color, dev_proc(&prototype, map_rgb_color));
+ set_dev_proc(dest, map_color_rgb, dev_proc(&prototype, map_color_rgb));
+ set_dev_proc(dest, fill_rectangle, dev_proc(&prototype, fill_rectangle));
+ set_dev_proc(dest, copy_mono, dev_proc(&prototype, copy_mono));
+ set_dev_proc(dest, copy_color, dev_proc(&prototype, copy_color));
+ set_dev_proc(dest, get_params, dev_proc(&prototype, get_params));
+ set_dev_proc(dest, put_params, dev_proc(&prototype, put_params));
+ set_dev_proc(dest, map_cmyk_color, dev_proc(&prototype, map_cmyk_color));
+ set_dev_proc(dest, get_page_device, dev_proc(&prototype, get_page_device));
+ set_dev_proc(dest, get_alpha_bits, dev_proc(&prototype, get_alpha_bits));
+ set_dev_proc(dest, copy_alpha, dev_proc(&prototype, copy_alpha));
+ set_dev_proc(dest, fill_path, dev_proc(&prototype, fill_path));
+ set_dev_proc(dest, stroke_path, dev_proc(&prototype, stroke_path));
+ set_dev_proc(dest, fill_trapezoid, dev_proc(&prototype, fill_trapezoid));
+ set_dev_proc(dest, fill_parallelogram, dev_proc(&prototype, fill_parallelogram));
+ set_dev_proc(dest, fill_triangle, dev_proc(&prototype, fill_triangle));
+ set_dev_proc(dest, draw_thin_line, dev_proc(&prototype, draw_thin_line));
+ set_dev_proc(dest, strip_tile_rectangle, dev_proc(&prototype, strip_tile_rectangle));
+ set_dev_proc(dest, get_clipping_box, dev_proc(&prototype, get_clipping_box));
+ set_dev_proc(dest, begin_typed_image, dev_proc(&prototype, begin_typed_image));
+ set_dev_proc(dest, get_bits_rectangle, dev_proc(&prototype, get_bits_rectangle));
+ set_dev_proc(dest, composite, dev_proc(&prototype, composite));
+ set_dev_proc(dest, get_hardware_params, dev_proc(&prototype, get_hardware_params));
+ set_dev_proc(dest, text_begin, dev_proc(&prototype, text_begin));
+ set_dev_proc(dest, discard_transparency_layer, dev_proc(&prototype, discard_transparency_layer));
+ set_dev_proc(dest, get_color_mapping_procs, dev_proc(&prototype, get_color_mapping_procs));
+ set_dev_proc(dest, get_color_comp_index, dev_proc(&prototype, get_color_comp_index));
+ set_dev_proc(dest, encode_color, dev_proc(&prototype, encode_color));
+ set_dev_proc(dest, decode_color, dev_proc(&prototype, decode_color));
+ set_dev_proc(dest, fill_rectangle_hl_color, dev_proc(&prototype, fill_rectangle_hl_color));
+ set_dev_proc(dest, include_color_space, dev_proc(&prototype, include_color_space));
+ set_dev_proc(dest, fill_linear_color_scanline, dev_proc(&prototype, fill_linear_color_scanline));
+ set_dev_proc(dest, fill_linear_color_trapezoid, dev_proc(&prototype, fill_linear_color_trapezoid));
+ set_dev_proc(dest, fill_linear_color_triangle, dev_proc(&prototype, fill_linear_color_triangle));
+ set_dev_proc(dest, update_spot_equivalent_colors, dev_proc(&prototype, update_spot_equivalent_colors));
+ set_dev_proc(dest, ret_devn_params, dev_proc(&prototype, ret_devn_params));
+ set_dev_proc(dest, fillpage, dev_proc(&prototype, fillpage));
+ set_dev_proc(dest, push_transparency_state, dev_proc(&prototype, push_transparency_state));
+ set_dev_proc(dest, pop_transparency_state, dev_proc(&prototype, pop_transparency_state));
+ set_dev_proc(dest, dev_spec_op, dev_proc(&prototype, dev_spec_op));
+ set_dev_proc(dest, get_profile, dev_proc(&prototype, get_profile));
+ set_dev_proc(dest, strip_copy_rop2, dev_proc(&prototype, strip_copy_rop2));
+ set_dev_proc(dest, strip_tile_rect_devn, dev_proc(&prototype, strip_tile_rect_devn));
+ set_dev_proc(dest, process_page, dev_proc(&prototype, process_page));
+ set_dev_proc(dest, transform_pixel_region, dev_proc(&prototype, transform_pixel_region));
+ set_dev_proc(dest, fill_stroke_path, dev_proc(&prototype, fill_stroke_path));
/*
* We absolutely must set the 'set_graphics_type_tag' to the default subclass one
* even if the subclassed device is using the default. This is because the
* default implementation sets a flag in the device structure, and if we
- * copy the default method, we'lll end up setting the flag in the subclassing device
+ * copy the default method, we'll end up setting the flag in the subclassing device
* instead of the subclassed device!
*/
- set_dev_proc(dest, set_graphics_type_tag, dev_proc(prototype, set_graphics_type_tag));
+ set_dev_proc(dest, set_graphics_type_tag, dev_proc(&prototype, set_graphics_type_tag));
/* These are the routines whose existence is checked against the default at
* some point in the code. The code path differs when the device implements a
@@ -1338,17 +1266,18 @@ int gx_copy_device_procs(gx_device *dest, gx_device *src, gx_device *prototype)
* do not overwrite the default method.
*/
if (dev_proc(src, fill_mask) != gx_default_fill_mask)
- set_dev_proc(dest, fill_mask, dev_proc(prototype, fill_mask));
+ set_dev_proc(dest, fill_mask, dev_proc(&prototype, fill_mask));
if (dev_proc(src, begin_transparency_group) != gx_default_begin_transparency_group)
- set_dev_proc(dest, begin_transparency_group, dev_proc(prototype, begin_transparency_group));
+ set_dev_proc(dest, begin_transparency_group, dev_proc(&prototype, begin_transparency_group));
if (dev_proc(src, end_transparency_group) != gx_default_end_transparency_group)
- set_dev_proc(dest, end_transparency_group, dev_proc(prototype, end_transparency_group));
+ set_dev_proc(dest, end_transparency_group, dev_proc(&prototype, end_transparency_group));
if (dev_proc(src, put_image) != gx_default_put_image)
- set_dev_proc(dest, put_image, dev_proc(prototype, put_image));
+ set_dev_proc(dest, put_image, dev_proc(&prototype, put_image));
if (dev_proc(src, copy_planes) != gx_default_copy_planes)
- set_dev_proc(dest, copy_planes, dev_proc(prototype, copy_planes));
+ set_dev_proc(dest, copy_planes, dev_proc(&prototype, copy_planes));
if (dev_proc(src, copy_alpha_hl_color) != gx_default_no_copy_alpha_hl_color)
- set_dev_proc(dest, copy_alpha_hl_color, dev_proc(prototype, copy_alpha_hl_color));
+ set_dev_proc(dest, copy_alpha_hl_color, dev_proc(&prototype, copy_alpha_hl_color));
+
return 0;
}
@@ -1423,8 +1352,6 @@ int gx_device_subclass(gx_device *dev_to_subclass, gx_device *new_prototype, uns
memset(psubclass_data, 0x00, private_data_size);
gx_copy_device_procs(dev_to_subclass, child_dev, new_prototype);
- set_dev_proc(dev_to_subclass, fill_rectangle, dev_proc(new_prototype, fill_rectangle));
- set_dev_proc(dev_to_subclass, copy_planes, dev_proc(new_prototype, copy_planes));
dev_to_subclass->finalize = new_prototype->finalize;
dev_to_subclass->dname = new_prototype->dname;
if (dev_to_subclass->icc_struct)
@@ -1434,6 +1361,9 @@ int gx_device_subclass(gx_device *dev_to_subclass, gx_device *new_prototype, uns
if (dev_to_subclass->NupControl)
rc_increment(dev_to_subclass->NupControl);
+ dev_to_subclass->page_procs = new_prototype->page_procs;
+ gx_subclass_fill_in_page_procs(dev_to_subclass);
+
/* In case the new device we're creating has already been initialised, copy
* its additional data.
*/
@@ -1484,7 +1414,7 @@ int gx_device_subclass(gx_device *dev_to_subclass, gx_device *new_prototype, uns
return 0;
}
-int gx_device_unsubclass(gx_device *dev)
+void gx_device_unsubclass(gx_device *dev)
{
generic_subclass_data *psubclass_data;
gx_device *parent, *child;
@@ -1493,7 +1423,7 @@ int gx_device_unsubclass(gx_device *dev)
/* This should not happen... */
if (!dev)
- return 0;
+ return;
ref_count = dev->rc.ref_count;
child = dev->child;
@@ -1503,7 +1433,7 @@ int gx_device_unsubclass(gx_device *dev)
/* We need to account for the fact that we are removing ourselves from
* the device chain after a clist device has been pushed, due to a
- * compositor action. Since we patched the clist 'create_compositor'
+ * compositor action. Since we patched the clist 'composite'
* method (and target device) when it was pushed.
* A point to note; we *don't* want to change the forwarding device's
* 'target', because when we copy the child up to replace 'this' device
@@ -1511,7 +1441,7 @@ int gx_device_unsubclass(gx_device *dev)
* device that goes away.
*/
if (psubclass_data != NULL && psubclass_data->forwarding_dev != NULL && psubclass_data->saved_compositor_method)
- psubclass_data->forwarding_dev->procs.create_compositor = psubclass_data->saved_compositor_method;
+ psubclass_data->forwarding_dev->procs.composite = psubclass_data->saved_compositor_method;
/* If ths device's stype is dynamically allocated, keep a copy of it
* in case we might need it.
@@ -1524,7 +1454,7 @@ int gx_device_unsubclass(gx_device *dev)
/* If ths device has any private storage, free it now */
if (psubclass_data)
- gs_free_object(dev->memory->non_gc_memory, psubclass_data, "subclass memory for first-last page");
+ gs_free_object(dev->memory->non_gc_memory, psubclass_data, "gx_device_unsubclass");
/* Copy the child device into ths device's memory */
if (child) {
@@ -1536,62 +1466,67 @@ int gx_device_unsubclass(gx_device *dev)
gs_set_object_type(child->memory, dev, b_std);
dev->stype = b_std;
- /* The reference count of the subclassing device may have been changed
- * (eg graphics states pointing to it) after we subclassed the device. We
- * need to ensure that we do not overwrite this when we copy back the subclassed
- * device.
+ /* The reference count of the subclassing device may have been
+ * changed (eg graphics states pointing to it) after we subclassed
+ * the device. We need to ensure that we do not overwrite this
+ * when we copy back the subclassed device.
*/
dev->rc.ref_count = ref_count;
- /* If we have a chain of devices, make sure the chain beond the device we're unsubclassing
- * doesn't get broken, we needd to detach the lower chain and reattach it at the new
- * highest level
+ /* If we have a chain of devices, make sure the chain beyond the
+ * device we're unsubclassing doesn't get broken, we need to
+ * detach the lower chain and reattach it at the new highest level.
*/
if (child->child)
child->child->parent = dev;
child->parent->child = child->child;
}
- /* How can we have a subclass device with no child ? Simples; when we hit the end of job
- * restore, the devices are not freed in device chain order. To make sure we don't end up
- * following stale pointers, when a device is freed we remove it from the chain and update
- * any danlging poitners to NULL. When we later free the remaining devices its possible that
- * their child pointer can then be NULL.
+ /* How can we have a subclass device with no child ? Simples; when we
+ * hit the end of job restore, the devices are not freed in device
+ * chain order. To make sure we don't end up following stale pointers,
+ * when a device is freed we remove it from the chain and update
+ * any dangling pointers to NULL. When we later free the remaining
+ * devices it's possible that their child pointer can then be NULL.
*/
if (child) {
if (child->icc_struct)
- rc_decrement(child->icc_struct, "gx_unsubclass_device, icc_struct");
+ rc_decrement(child->icc_struct, "gx_device_unsubclass, icc_struct");
if (child->PageList)
- rc_decrement(child->PageList, "gx_unsubclass_device, PageList");
+ rc_decrement(child->PageList, "gx_device_unsubclass, PageList");
if (child->NupControl)
- rc_decrement(child->NupControl, "gx_unsubclass_device, NupControl");
- /* we cannot afford to free the child device if its stype is not dynamic because
- * we can't 'null' the finalise routine, and we cannot permit the device to be finalised
- * because we have copied it up one level, not discarded it.
- * (this shouldn't happen! Child devices are always created with a dynamic stype)
- * If this ever happens garbage collecton will eventually clean up the memory.
+ rc_decrement(child->NupControl, "gx_device_unsubclass, NupControl");
+ /* We cannot afford to free the child device if its stype is not
+ * dynamic because we can't 'null' the finalise routine, and we
+ * cannot permit the device to be finalised because we have copied
+ * it up one level, not discarded it. (This shouldn't happen! Child
+ * devices are always created with a dynamic stype.) If this ever
+ * happens garbage collecton will eventually clean up the memory.
*/
if (child->stype_is_dynamic) {
- /* Make sure that nothing will tyr to follow the device chain, just security here */
+ /* Make sure that nothing will try to follow the device chain,
+ * just security here. */
child->parent = NULL;
child->child = NULL;
- /* Make certainthe memory will be freed, zap the reference count */
+ /* Make certain the memory will be freed, zap the reference count */
child->rc.ref_count = 0;
- /* We *don't* want to run the finalize routine. This would free the stype and
- * properly handle the icc_struct and PageList, but for devices with a custom
- * finalize (eg psdcmyk) it might also free memory it had allocated, and we're
- * still pointing at that memory in the parent.
- * The indirection through a variable is just to get rid of const warnings.
+ /* We *don't* want to run the finalize routine. This would free
+ * the stype and properly handle the icc_struct and PageList,
+ * but for devices with a custom finalize (eg psdcmyk) it might
+ * also free memory it had allocated, and we're still pointing
+ * at that memory in the parent. The indirection through a
+ * variable is just to get rid of const warnings.
*/
b_std = (gs_memory_struct_type_t *)child->stype;
b_std->finalize = NULL;
- /* Having patched the stype, we need to make sure the memory manager uses it.
- * It keeps a copy in its own data structure, and would use that copy, which would
- * mean it would call the finalize routine that we just patched out.
+ /* Having patched the stype, we need to make sure the memory
+ * manager uses it. It keeps a copy in its own data structure,
+ * and would use that copy, which would mean it would call the
+ * finalize routine that we just patched out.
*/
gs_set_object_type(dev->memory->stable_memory, child, b_std);
/* Now (finally) free the child memory */
- gs_free_object(dev->memory->stable_memory, child, "gx_unsubclass_device(device)");
+ gs_free_object(dev->memory->stable_memory, child, "gx_device_unsubclass(device)");
/* And the stype for it */
gs_free_const_object(dev->memory->non_gc_memory, b_std, "gs_device_unsubclass(stype)");
child = 0;
@@ -1611,8 +1546,6 @@ int gx_device_unsubclass(gx_device *dev)
} else {
dev->stype_is_dynamic = 0;
}
-
- return 0;
}
int gx_update_from_subclass(gx_device *dev)
@@ -1655,7 +1588,7 @@ int gx_update_from_subclass(gx_device *dev)
return 0;
}
-int gx_subclass_create_compositor(gx_device *dev, gx_device **pcdev, const gs_composite_t *pcte,
+int gx_subclass_composite(gx_device *dev, gx_device **pcdev, const gs_composite_t *pcte,
gs_gstate *pgs, gs_memory_t *memory, gx_device *cdev)
{
pdf14_clist_device *p14dev;
@@ -1663,9 +1596,9 @@ int gx_subclass_create_compositor(gx_device *dev, gx_device **pcdev, const gs_co
int code = 0;
p14dev = (pdf14_clist_device *)dev;
- psubclass_data = p14dev->target->subclass_data;
+ psubclass_data = (generic_subclass_data *)p14dev->target->subclass_data;
- set_dev_proc(dev, create_compositor, psubclass_data->saved_compositor_method);
+ set_dev_proc(dev, composite, psubclass_data->saved_compositor_method);
if (gs_is_pdf14trans_compositor(pcte) != 0 && strncmp(dev->dname, "pdf14clist", 10) == 0) {
const gs_pdf14trans_t * pdf14pct = (const gs_pdf14trans_t *) pcte;
@@ -1692,7 +1625,7 @@ int gx_subclass_create_compositor(gx_device *dev, gx_device **pcdev, const gs_co
subclass_device = p14dev->target;
p14dev->target = p14dev->target->child;
- code = dev_proc(dev, create_compositor)(dev, pcdev, pcte, pgs, memory, cdev);
+ code = dev_proc(dev, composite)(dev, pcdev, pcte, pgs, memory, cdev);
p14dev->target = subclass_device;
@@ -1704,13 +1637,13 @@ int gx_subclass_create_compositor(gx_device *dev, gx_device **pcdev, const gs_co
}
break;
default:
- code = dev_proc(dev, create_compositor)(dev, pcdev, pcte, pgs, memory, cdev);
+ code = dev_proc(dev, composite)(dev, pcdev, pcte, pgs, memory, cdev);
break;
}
} else {
- code = dev_proc(dev, create_compositor)(dev, pcdev, pcte, pgs, memory, cdev);
+ code = dev_proc(dev, composite)(dev, pcdev, pcte, pgs, memory, cdev);
}
- set_dev_proc(dev, create_compositor, gx_subclass_create_compositor);
+ set_dev_proc(dev, composite, gx_subclass_composite);
return code;
}
diff --git a/base/gdevdgbr.c b/base/gdevdgbr.c
index d7b34b77..c2376202 100644
--- a/base/gdevdgbr.c
+++ b/base/gdevdgbr.c
@@ -24,41 +24,6 @@
#include "gdevmem.h"
#include "gxdevsop.h"
-int
-gx_no_get_bits(gx_device * dev, int y, byte * data, byte ** actual_data)
-{
- return_error(gs_error_unknownerror);
-}
-int
-gx_default_get_bits(gx_device * dev, int y, byte * data, byte ** actual_data)
-{ /*
- * Hand off to get_bits_rectangle, being careful to avoid a
- * possible recursion loop.
- */
- dev_proc_get_bits((*save_get_bits)) = dev_proc(dev, get_bits);
- gs_int_rect rect;
- gs_get_bits_params_t params;
- int code;
-
- rect.p.x = 0, rect.p.y = y;
- rect.q.x = dev->width, rect.q.y = y + 1;
- params.options =
- (actual_data ? GB_RETURN_POINTER : 0) | GB_RETURN_COPY |
- (GB_ALIGN_STANDARD | GB_OFFSET_0 | GB_RASTER_STANDARD |
- /* No depth specified, we always use native colors. */
- GB_PACKING_CHUNKY | GB_COLORS_NATIVE | GB_ALPHA_NONE);
- params.x_offset = 0;
- params.raster = bitmap_raster(dev->width * dev->color_info.depth);
- params.data[0] = data;
- set_dev_proc(dev, get_bits, gx_no_get_bits);
- code = (*dev_proc(dev, get_bits_rectangle))
- (dev, &rect, &params, NULL);
- if (actual_data)
- *actual_data = params.data[0];
- set_dev_proc(dev, get_bits, save_get_bits);
- return code;
-}
-
/*
* Determine whether we can satisfy a request by simply using the stored
* representation. dev is used only for color_info.{num_components, depth}.
@@ -246,11 +211,6 @@ gx_get_bits_copy_cmyk_1bit(byte *dest_line, uint dest_raster,
* A good optimizing compiler would compile them in-line.
*/
static int
- gx_get_bits_std_to_native(gx_device * dev, int x, int w, int h,
- gs_get_bits_params_t * params,
- const gs_get_bits_params_t *stored,
- const byte * src_base, uint dev_raster,
- int x_offset, uint raster),
gx_get_bits_native_to_std(gx_device * dev, int x, int w, int h,
gs_get_bits_params_t * params,
const gs_get_bits_params_t *stored,
@@ -330,17 +290,16 @@ gx_get_bits_copy(gx_device * dev, int x, int w, int h,
/* set up parameters required by copy_mono's fit_copy */
tdev.width = dest_bit_x + (align << 3) + bit_w;
tdev.height = 1;
- (*dev_proc(&mem_mono_device, copy_mono))
- ((gx_device *) & tdev, src, bit_x, dev_raster, gx_no_bitmap_id,
- dest_bit_x + (align << 3), 0, bit_w, 1,
- (gx_color_index) 0, (gx_color_index) 1);
+ code = mem_mono_copy_mono((gx_device *) & tdev, src, bit_x,
+ dev_raster, gx_no_bitmap_id,
+ dest_bit_x + (align << 3), 0, bit_w, 1,
+ (gx_color_index) 0, (gx_color_index) 1);
+ if (code < 0)
+ break;
}
} else if (options & ~stored_options & GB_COLORS_NATIVE) {
/* Convert standard colors to native. */
- code = gx_get_bits_std_to_native(dev, x, w, h, params, stored,
- src_base, dev_raster,
- x_offset, raster);
- options = params->options;
+ return_error(gs_error_rangecheck);
} else {
/* Convert native colors to standard. */
code = gx_get_bits_native_to_std(dev, x, w, h, params, stored,
@@ -398,120 +357,6 @@ gx_get_bits_copy(gx_device * dev, int x, int w, int h,
}
/*
- * Convert standard colors to native. Note that the source
- * may have depths other than 8 bits per component.
- */
-static int
-gx_get_bits_std_to_native(gx_device * dev, int x, int w, int h,
- gs_get_bits_params_t * params,
- const gs_get_bits_params_t *stored,
- const byte * src_base, uint dev_raster,
- int x_offset, uint raster)
-{
- int depth = dev->color_info.depth;
- int dest_bit_offset = x_offset * depth;
- byte *dest_line = params->data[0] + (dest_bit_offset >> 3);
- int ncolors =
- (stored->options & GB_COLORS_RGB ? 3 :
- stored->options & GB_COLORS_CMYK ? 4 :
- stored->options & GB_COLORS_GRAY ? 1 : -1);
- int ncomp = ncolors +
- ((stored->options & (GB_ALPHA_FIRST | GB_ALPHA_LAST)) != 0);
- int src_depth = GB_OPTIONS_DEPTH(stored->options);
- int src_bit_offset = x * src_depth * ncomp;
- const byte *src_line = src_base + (src_bit_offset >> 3);
- gx_color_value src_max = (1 << src_depth) - 1;
-#define v2cv(value) ((ulong)(value) * gx_max_color_value / src_max)
- gx_color_value alpha_default = src_max;
- subclass_color_mappings scm;
-
- scm = get_color_mapping_procs_subclass(dev);
-
- params->options &= ~GB_COLORS_ALL | GB_COLORS_NATIVE;
- for (; h > 0; dest_line += raster, src_line += dev_raster, --h) {
- int i;
- const byte *src = src_line;
- int sbit = src_bit_offset & 7;
- byte *dest = dest_line;
- int dbit = dest_bit_offset & 7;
- byte dbyte = (dbit ? (byte)(*dest & (0xff00 >> dbit)) : 0);
-
-#define v2frac(value) ((long)(value) * frac_1 / src_max)
-
- for (i = 0; i < w; ++i) {
- int j;
- uchar k;
- frac sc[4], dc[GX_DEVICE_COLOR_MAX_COMPONENTS];
- gx_color_value v[GX_DEVICE_COLOR_MAX_COMPONENTS];
- gx_color_value va = alpha_default;
- gx_color_index pixel;
- bool do_alpha = false;
-
- /* Fetch the source data. */
- if (stored->options & GB_ALPHA_FIRST) {
- if (sample_load_next16(&va, &src, &sbit, src_depth) < 0)
- return_error(gs_error_rangecheck);
- va = v2cv(va);
- do_alpha = true;
- }
- for (j = 0; j < ncolors; ++j) {
- gx_color_value vj;
-
- if (sample_load_next16(&vj, &src, &sbit, src_depth) < 0)
- return_error(gs_error_rangecheck);
- sc[j] = v2frac(vj);
- }
- if (stored->options & GB_ALPHA_LAST) {
- if (sample_load_next16(&va, &src, &sbit, src_depth) < 0)
- return_error(gs_error_rangecheck);
- va = v2cv(va);
- do_alpha = true;
- }
-
- /* Convert and store the pixel value. */
- if (do_alpha) {
- for (j = 0; j < ncolors; j++)
- v[j] = frac2cv(sc[j]);
- if (ncolors == 1)
- v[2] = v[1] = v[0];
- pixel = dev_proc(dev, map_rgb_alpha_color)
- (dev, v[0], v[1], v[2], va);
- } else {
-
- switch (ncolors) {
- case 1:
- map_gray_subclass(scm, sc[0], dc);
- break;
- case 3:
- map_rgb_subclass(scm, 0, sc[0], sc[1], sc[2], dc);
- break;
- case 4:
- map_cmyk_subclass(scm, sc[0], sc[1], sc[2], sc[3], dc);
- break;
- default:
- return_error(gs_error_rangecheck);
- }
-
- for (k = 0; k < dev->color_info.num_components; k++)
- v[k] = frac2cv(dc[k]);
-
- pixel = dev_proc(dev, encode_color)(dev, v);
- }
- if (sizeof(pixel) > 4) {
- if (sample_store_next64(pixel, &dest, &dbit, depth, &dbyte) < 0)
- return_error(gs_error_rangecheck);
- }
- else {
- if (sample_store_next32(pixel, &dest, &dbit, depth, &dbyte) < 0)
- return_error(gs_error_rangecheck);
- }
- }
- sample_store_flush(dest, dbit, dbyte);
- }
- return 0;
-}
-
-/*
* Convert native colors to standard. Only GB_DEPTH_8 is supported.
*/
static int
@@ -603,9 +448,9 @@ gx_get_bits_native_to_std(gx_device * dev, int x, int w, int h,
}
mapped[pixel] = dest;
}
- (*dev_proc(dev, map_color_rgb_alpha)) (dev, pixel, rgba);
+ (*dev_proc(dev, map_color_rgb)) (dev, pixel, rgba);
if (options & GB_ALPHA_FIRST)
- *dest++ = gx_color_value_to_byte(rgba[3]);
+ *dest++ = 0xff;
/* Convert to the requested color space. */
if (options & GB_COLORS_RGB) {
dest[0] = gx_color_value_to_byte(rgba[0]);
@@ -632,7 +477,7 @@ gx_get_bits_native_to_std(gx_device * dev, int x, int w, int h,
/ lum_all_weights);
}
if (options & GB_ALPHA_LAST)
- *dest++ = gx_color_value_to_byte(rgba[3]);
+ *dest++ = 0xff;
}
}
return 0;
@@ -641,162 +486,38 @@ gx_get_bits_native_to_std(gx_device * dev, int x, int w, int h,
/* ------ Default implementations of get_bits_rectangle ------ */
int
-gx_no_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
- gs_get_bits_params_t * params, gs_int_rect ** unread)
+gx_default_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
+ gs_get_bits_params_t * params)
{
return_error(gs_error_unknownerror);
}
-int
-gx_default_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
- gs_get_bits_params_t * params, gs_int_rect ** unread)
+int gx_blank_get_bits_rectangle(gx_device *dev, const gs_int_rect *prect,
+ gs_get_bits_params_t *params)
{
- dev_proc_get_bits_rectangle((*save_get_bits_rectangle)) =
- dev_proc(dev, get_bits_rectangle);
- int depth = dev->color_info.depth;
- uint min_raster = (dev->width * depth + 7) >> 3;
- gs_get_bits_options_t options = params->options;
- int code;
-
- /* Avoid a recursion loop. */
- set_dev_proc(dev, get_bits_rectangle, gx_no_get_bits_rectangle);
- /*
- * If the parameters are right, try to call get_bits directly. Note
- * that this may fail if a device only implements get_bits_rectangle
- * (not get_bits) for a limited set of options. Note also that this
- * must handle the case of the recursive call from within
- * get_bits_rectangle (see below): because of this, and only because
- * of this, it must handle partial scan lines.
- */
- if (prect->q.y == prect->p.y + 1 &&
- !(~options &
- (GB_RETURN_COPY | GB_PACKING_CHUNKY | GB_COLORS_NATIVE)) &&
- (options & (GB_ALIGN_STANDARD | GB_ALIGN_ANY)) &&
- ((options & (GB_OFFSET_0 | GB_OFFSET_ANY)) ||
- ((options & GB_OFFSET_SPECIFIED) && params->x_offset == 0)) &&
- ((options & (GB_RASTER_STANDARD | GB_RASTER_ANY)) ||
- ((options & GB_RASTER_SPECIFIED) &&
- params->raster >= min_raster)) &&
- unread == NULL
- ) {
- byte *data = params->data[0];
- byte *row = data;
-
- if (!(prect->p.x == 0 && prect->q.x == dev->width)) {
- /* Allocate an intermediate row buffer. */
- row = gs_alloc_bytes(dev->memory, min_raster,
- "gx_default_get_bits_rectangle");
-
- if (row == 0) {
- code = gs_note_error(gs_error_VMerror);
- goto ret;
- }
- }
- code = (*dev_proc(dev, get_bits)) (dev, prect->p.y, row,
- (params->options & GB_RETURN_POINTER) ? &params->data[0]
- : NULL );
- if (code >= 0) {
- if (row != data) {
- if (prect->p.x == 0 && params->data[0] != row
- && params->options & GB_RETURN_POINTER) {
- /*
- * get_bits returned an appropriate pointer: we can
- * avoid doing any copying.
- */
- DO_NOTHING;
- } else {
- /* Copy the partial row into the supplied buffer. */
- int width_bits = (prect->q.x - prect->p.x) * depth;
- gx_device_memory tdev;
-
- tdev.width = width_bits;
- tdev.height = 1;
- tdev.line_ptrs = &tdev.base;
- tdev.base = data;
- tdev.raster = bitmap_raster(width_bits);
- code = (*dev_proc(&mem_mono_device, copy_mono))
- ((gx_device *) & tdev,
- (params->options & GB_RETURN_POINTER) ? params->data[0] : row,
- prect->p.x * depth,
- min_raster, gx_no_bitmap_id, 0, 0, width_bits, 1,
- (gx_color_index) 0, (gx_color_index) 1);
- params->data[0] = data;
- }
- gs_free_object(dev->memory, row,
- "gx_default_get_bits_rectangle");
- }
- params->options =
- GB_ALIGN_STANDARD | GB_OFFSET_0 | GB_PACKING_CHUNKY |
- GB_ALPHA_NONE | GB_COLORS_NATIVE | GB_RASTER_STANDARD |
- (params->data[0] == data ? GB_RETURN_COPY : GB_RETURN_POINTER);
- goto ret;
- }
- } {
- /* Do the transfer row-by-row using a buffer. */
- int x = prect->p.x, w = prect->q.x - x;
- int bits_per_pixel = depth;
- byte *row;
-
- if (options & GB_COLORS_STANDARD_ALL) {
- /*
- * Make sure the row buffer can hold the standard color
- * representation, in case the device decides to use it.
- */
- int bpc = GB_OPTIONS_MAX_DEPTH(options);
- int nc =
- (options & GB_COLORS_CMYK ? 4 :
- options & GB_COLORS_RGB ? 3 : 1) +
- (options & (GB_ALPHA_ALL - GB_ALPHA_NONE) ? 1 : 0);
- int bpp = bpc * nc;
-
- if (bpp > bits_per_pixel)
- bits_per_pixel = bpp;
- }
- row = gs_alloc_bytes(dev->memory, (bits_per_pixel * w + 7) >> 3,
- "gx_default_get_bits_rectangle");
- if (row == 0) {
- code = gs_note_error(gs_error_VMerror);
- } else {
- uint dev_raster = gx_device_raster(dev, true);
- uint raster =
- (options & GB_RASTER_SPECIFIED ? params->raster :
- options & GB_ALIGN_STANDARD ? bitmap_raster(depth * w) :
- (depth * w + 7) >> 3);
- gs_int_rect rect;
- gs_get_bits_params_t copy_params;
- gs_get_bits_options_t copy_options =
- (GB_ALIGN_STANDARD | GB_ALIGN_ANY) |
- (GB_RETURN_COPY | GB_RETURN_POINTER) |
- (GB_OFFSET_0 | GB_OFFSET_ANY) |
- (GB_RASTER_STANDARD | GB_RASTER_ANY) | GB_PACKING_CHUNKY |
- GB_COLORS_NATIVE | (options & (GB_DEPTH_ALL | GB_COLORS_ALL)) |
- GB_ALPHA_ALL;
- byte *dest = params->data[0];
- int y;
-
- rect.p.x = x, rect.q.x = x + w;
- code = 0;
- for (y = prect->p.y; y < prect->q.y; ++y) {
- rect.p.y = y, rect.q.y = y + 1;
- copy_params.options = copy_options;
- copy_params.data[0] = row;
- code = (*save_get_bits_rectangle)
- (dev, &rect, &copy_params, NULL);
- if (code < 0)
- break;
- if (copy_params.options & GB_OFFSET_0)
- copy_params.x_offset = 0;
- params->data[0] = dest + (y - prect->p.y) * raster;
- code = gx_get_bits_copy(dev, copy_params.x_offset, w, 1,
- params, &copy_params,
- copy_params.data[0], dev_raster);
- if (code < 0)
- break;
- }
- gs_free_object(dev->memory, row, "gx_default_get_bits_rectangle");
- params->data[0] = dest;
- }
+ int supported = GB_COLORS_NATIVE |
+ GB_ALPHA_NONE |
+ GB_DEPTH_8 |
+ GB_PACKING_CHUNKY |
+ GB_RETURN_COPY |
+ GB_ALIGN_STANDARD |
+ GB_OFFSET_0 |
+ GB_RASTER_STANDARD;
+ unsigned char *ptr = params->data[0];
+ int bytes = (prect->q.x - prect->p.x) * dev->color_info.num_components;
+ int col = dev->color_info.num_components > 3 ? 0 : 0xff;
+ int raster = bitmap_raster(dev->width * dev->color_info.num_components);
+ int y;
+
+ if ((params->options & supported) != supported)
+ return_error(gs_error_unknownerror);
+
+ params->options = supported;
+
+ for (y = prect->p.y; y < prect->q.y; y++) {
+ memset(ptr, col, bytes);
+ ptr += raster;
}
- ret:set_dev_proc(dev, get_bits_rectangle, save_get_bits_rectangle);
- return (code < 0 ? code : 0);
+
+ return 0;
}
diff --git a/base/gdevdrop.c b/base/gdevdrop.c
index 9186eea1..7a6ca1d4 100644
--- a/base/gdevdrop.c
+++ b/base/gdevdrop.c
@@ -23,7 +23,6 @@
#include "gxdcolor.h"
#include "gxdevice.h"
#include "gxdevmem.h"
-#include "gxdevrop.h"
#include "gxgetbit.h"
#include "gdevmem.h" /* for mem_default_strip_copy_rop prototype */
#include "gdevmpla.h"
@@ -89,28 +88,6 @@ trace_copy_rop(const char *cname, gx_device * dev,
/* ---------------- Default copy_rop implementations ---------------- */
-/*
- * The default implementation for non-memory devices uses get_bits_rectangle
- * to read out the pixels, the memory device implementation to do the
- * operation, and copy_color to write the pixels back.
- */
-int
-gx_default_strip_copy_rop(gx_device * dev,
- const byte * sdata, int sourcex,
- uint sraster, gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_strip_bitmap * textures,
- const gx_color_index * tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y,
- gs_logical_operation_t lop)
-{
- return gx_default_strip_copy_rop2(dev, sdata, sourcex, sraster, id,
- scolors, textures, tcolors,
- x, y, width, height,
- phase_x, phase_y, lop, 0);
-}
-
int
gx_default_strip_copy_rop2(gx_device * dev,
const byte * sdata, int sourcex,
@@ -139,7 +116,7 @@ gx_default_strip_copy_rop2(gx_device * dev,
#ifdef DEBUG
if (gs_debug_c('b'))
- trace_copy_rop("gx_default_strip_copy_rop",
+ trace_copy_rop("gx_default_strip_copy_rop2",
dev, sdata, sourcex, sraster,
id, scolors, textures, tcolors,
x, y, width, height, phase_x, phase_y, lop);
@@ -212,7 +189,7 @@ gx_default_strip_copy_rop2(gx_device * dev,
bit_params.data[0] = row;
bit_params.x_offset = 0;
code = (*dev_proc(dev, get_bits_rectangle))
- (dev, &rect, &bit_params, NULL);
+ (dev, &rect, &bit_params);
if (code < 0)
break;
code = (*dev_proc(pmdev, copy_color))
@@ -222,23 +199,13 @@ gx_default_strip_copy_rop2(gx_device * dev,
if (code < 0)
return code;
}
- if (planar_height == 0) {
- code = (*dev_proc(pmdev, strip_copy_rop))
- ((gx_device *)pmdev,
- sdata + (py - y) * sraster, sourcex, sraster,
- gx_no_bitmap_id, scolors, textures, tcolors,
- 0, 0, width, block_height,
- phase_x + x, phase_y + py,
- lop);
- } else {
- code = (*dev_proc(pmdev, strip_copy_rop2))
+ code = (*dev_proc(pmdev, strip_copy_rop2))
((gx_device *)pmdev,
sdata + (py - y) * sraster, sourcex, sraster,
gx_no_bitmap_id, scolors, textures, tcolors,
0, 0, width, block_height,
phase_x + x, phase_y + py,
lop, planar_height);
- }
if (code < 0)
break;
if (is_planar) {
@@ -598,24 +565,8 @@ pack_planar_from_standard(gx_device_memory * dev, int y, int destx,
* operation, pack_from_standard to convert them back to the device
* representation, and copy_color to write the pixels back.
*/
-int
-mem_default_strip_copy_rop2(gx_device * dev,
- const byte * sdata, int sourcex,
- uint sraster, gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_strip_bitmap * textures,
- const gx_color_index * tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y,
- gs_logical_operation_t lop,
- uint planar_height)
-{
- dmlprintf(dev->memory, "mem_default_strip_copy_rop2 should never be called!\n");
- return_error(gs_error_Fatal);
-}
-
-int
-mem_default_strip_copy_rop(gx_device * dev,
+static int
+do_strip_copy_rop(gx_device * dev,
const byte * sdata, int sourcex,
uint sraster, gx_bitmap_id id,
const gx_color_index * scolors,
@@ -823,7 +774,7 @@ mem_default_strip_copy_rop(gx_device * dev,
bit_params.x_offset = 0;
bit_params.raster = mdev.raster;
code = (*dev_proc(dev, get_bits_rectangle))
- (dev, &rect, &bit_params, NULL);
+ (dev, &rect, &bit_params);
if (code < 0)
break;
}
@@ -836,10 +787,10 @@ mem_default_strip_copy_rop(gx_device * dev,
source_data = source_row;
source_raster = source_row_raster;
}
- code = (*dev_proc(&mdev, strip_copy_rop))
+ code = (*dev_proc(&mdev, strip_copy_rop2))
((gx_device *)&mdev, source_data, sx, source_raster,
gx_no_bitmap_id, real_scolors, real_texture, real_tcolors,
- 0, 0, width, loop_height, phase_x + x, phase_y + py, lop);
+ 0, 0, width, loop_height, phase_x + x, phase_y + py, lop, 0);
if (code < 0)
break;
/* Convert the result back to the device's format. */
@@ -863,104 +814,26 @@ out:
return code;
}
-/* ------ Implementation of related functions ------ */
-
int
-gx_default_copy_rop(gx_device * dev,
- const byte * sdata, int sourcex, uint sraster, gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_tile_bitmap * texture, const gx_color_index * tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- const gx_strip_bitmap *textures;
- gx_strip_bitmap tiles;
-
- if (texture == 0)
- textures = 0;
- else {
- *(gx_tile_bitmap *) & tiles = *texture;
- tiles.rep_shift = tiles.shift = 0;
- tiles.num_planes = 1;
- textures = &tiles;
- }
- return (*dev_proc(dev, strip_copy_rop))
- (dev, sdata, sourcex, sraster, id, scolors, textures, tcolors,
- x, y, width, height, phase_x, phase_y, lop);
-}
-
-int
-gx_copy_rop_unaligned(gx_device * dev,
- const byte * sdata, int sourcex, uint sraster, gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_tile_bitmap * texture, const gx_color_index * tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- const gx_strip_bitmap *textures;
- gx_strip_bitmap tiles;
-
- if (texture == 0)
- textures = 0;
- else {
- *(gx_tile_bitmap *) & tiles = *texture;
- tiles.rep_shift = tiles.shift = 0;
- tiles.num_planes = 1;
- textures = &tiles;
- }
- return gx_strip_copy_rop_unaligned
- (dev, sdata, sourcex, sraster, id, scolors, textures, tcolors,
- x, y, width, height, phase_x, phase_y, lop);
-}
-
-int
-gx_strip_copy_rop_unaligned(gx_device * dev,
- const byte * sdata, int sourcex, uint sraster, gx_bitmap_id id,
+mem_default_strip_copy_rop2(gx_device * dev,
+ const byte * sdata, int sourcex,
+ uint sraster, gx_bitmap_id id,
const gx_color_index * scolors,
- const gx_strip_bitmap * textures, const gx_color_index * tcolors,
+ const gx_strip_bitmap * textures,
+ const gx_color_index * tcolors,
int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
+ int phase_x, int phase_y,
+ gs_logical_operation_t lop,
+ uint planar_height)
{
- dev_proc_strip_copy_rop((*copy_rop)) = dev_proc(dev, strip_copy_rop);
- int depth = (scolors == 0 ? dev->color_info.depth : 1);
- int step = sraster & (align_bitmap_mod - 1);
-
- /* Adjust the origin. */
- if (sdata != 0) {
- uint offset =
- (uint) (sdata - (const byte *)0) & (align_bitmap_mod - 1);
-
- /* See copy_color above re the following statement. */
- if (depth == 24)
- offset += (offset % 3) *
- (align_bitmap_mod * (3 - (align_bitmap_mod % 3)));
- sdata -= offset;
- sourcex += (offset << 3) / depth;
- }
- /* Adjust the raster. */
- if (!step || sdata == 0 ||
- (scolors != 0 && scolors[0] == scolors[1])
- ) { /* No adjustment needed. */
- return (*copy_rop) (dev, sdata, sourcex, sraster, id, scolors,
- textures, tcolors, x, y, width, height,
- phase_x, phase_y, lop);
- }
- /* Do the transfer one scan line at a time. */
+ if (planar_height != 0)
{
- const byte *p = sdata;
- int d = sourcex;
- int dstep = (step << 3) / depth;
- int code = 0;
- int i;
-
- for (i = 0; i < height && code >= 0;
- ++i, p += sraster - step, d += dstep
- )
- code = (*copy_rop) (dev, p, d, sraster, gx_no_bitmap_id, scolors,
- textures, tcolors, x, y + i, width, 1,
- phase_x, phase_y, lop);
- return code;
+ dmlprintf(dev->memory, "mem_default_strip_copy_rop2 should never be called!\n");
+ return_error(gs_error_Fatal);
}
+ return do_strip_copy_rop(dev, sdata, sourcex, sraster, id, scolors,
+ textures, tcolors, x, y, width, height,
+ phase_x, phase_y, lop);
}
/* ---------------- Internal routines ---------------- */
diff --git a/base/gdevepo.c b/base/gdevepo.c
index 7c9eb0b7..f8c46c54 100644
--- a/base/gdevepo.c
+++ b/base/gdevepo.c
@@ -49,7 +49,6 @@ extern void epo_disable(int flag);
/* Device procedures, we need quite a lot of them */
static dev_proc_output_page(epo_output_page);
static dev_proc_fill_rectangle(epo_fill_rectangle);
-static dev_proc_draw_line(epo_draw_line);
static dev_proc_fill_path(epo_fill_path);
static dev_proc_fill_mask(epo_fill_mask);
static dev_proc_fill_trapezoid(epo_fill_trapezoid);
@@ -62,20 +61,16 @@ static dev_proc_fill_linear_color_trapezoid(epo_fill_linear_color_trapezoid);
static dev_proc_fill_linear_color_triangle(epo_fill_linear_color_triangle);
static dev_proc_put_image(epo_put_image);
static dev_proc_fillpage(epo_fillpage);
-static dev_proc_create_compositor(epo_create_compositor);
+static dev_proc_composite(epo_composite);
static dev_proc_text_begin(epo_text_begin);
-static dev_proc_finish_copydevice(epo_finish_copydevice);
-static dev_proc_begin_image(epo_begin_image);
+static dev_proc_initialize_device_procs(epo_initialize_device_procs);
static dev_proc_begin_typed_image(epo_begin_typed_image);
static dev_proc_stroke_path(epo_stroke_path);
-static dev_proc_tile_rectangle(epo_tile_rectangle);
static dev_proc_copy_mono(epo_copy_mono);
static dev_proc_copy_color(epo_copy_color);
-static dev_proc_get_bits(epo_get_bits);
static dev_proc_copy_alpha(epo_copy_alpha);
-static dev_proc_copy_rop(epo_copy_rop);
+static dev_proc_get_bits_rectangle(epo_get_bits_rectangle);
static dev_proc_strip_tile_rectangle(epo_strip_tile_rectangle);
-static dev_proc_strip_copy_rop(epo_strip_copy_rop);
static dev_proc_strip_copy_rop2(epo_strip_copy_rop2);
static dev_proc_copy_planes(epo_copy_planes);
static dev_proc_copy_alpha_hl_color(epo_copy_alpha_hl_color);
@@ -108,86 +103,11 @@ public_st_epo_device();
const
gx_device_epo gs_epo_device =
{
- std_device_dci_type_body(gx_device_epo, 0, EPO_DEVICENAME, &st_epo_device,
+ std_device_dci_type_body_sc(gx_device_epo, epo_initialize_device_procs,
+ EPO_DEVICENAME, &st_epo_device,
MAX_COORD, MAX_COORD,
MAX_RESOLUTION, MAX_RESOLUTION,
- 1, 8, 255, 0, 256, 1),
- {default_subclass_open_device,
- default_subclass_get_initial_matrix,
- default_subclass_sync_output, /* sync_output */
- epo_output_page,
- default_subclass_close_device,
- default_subclass_map_rgb_color,
- default_subclass_map_color_rgb,
- epo_fill_rectangle,
- epo_tile_rectangle, /* tile_rectangle */
- epo_copy_mono,
- epo_copy_color,
- epo_draw_line, /* draw_line */
- epo_get_bits, /* get_bits */
- default_subclass_get_params,
- default_subclass_put_params,
- default_subclass_map_cmyk_color,
- default_subclass_get_xfont_procs, /* get_xfont_procs */
- default_subclass_get_xfont_device, /* get_xfont_device */
- default_subclass_map_rgb_alpha_color,
- default_subclass_get_page_device,
- default_subclass_get_alpha_bits, /* get_alpha_bits */
- epo_copy_alpha,
- default_subclass_get_band, /* get_band */
- epo_copy_rop, /* copy_rop */
- epo_fill_path,
- epo_stroke_path,
- epo_fill_mask,
- epo_fill_trapezoid,
- epo_fill_parallelogram,
- epo_fill_triangle,
- epo_draw_thin_line,
- epo_begin_image,
- default_subclass_image_data, /* image_data */
- default_subclass_end_image, /* end_image */
- epo_strip_tile_rectangle,
- epo_strip_copy_rop,
- default_subclass_get_clipping_box, /* get_clipping_box */
- epo_begin_typed_image,
- default_subclass_get_bits_rectangle, /* get_bits_rectangle */
- default_subclass_map_color_rgb_alpha,
- epo_create_compositor,
- default_subclass_get_hardware_params, /* get_hardware_params */
- epo_text_begin,
- epo_finish_copydevice, /* finish_copydevice */
- default_subclass_begin_transparency_group, /* begin_transparency_group */
- default_subclass_end_transparency_group, /* end_transparency_group */
- default_subclass_begin_transparency_mask, /* begin_transparency_mask */
- default_subclass_end_transparency_mask, /* end_transparency_mask */
- default_subclass_discard_transparency_layer, /* discard_transparency_layer */
- default_subclass_get_color_mapping_procs, /* get_color_mapping_procs */
- default_subclass_get_color_comp_index, /* get_color_comp_index */
- default_subclass_encode_color, /* encode_color */
- default_subclass_decode_color, /* decode_color */
- default_subclass_pattern_manage, /* pattern_manage */
- epo_fill_rectangle_hl_color, /* fill_rectangle_hl_color */
- default_subclass_include_color_space, /* include_color_space */
- epo_fill_linear_color_scanline, /* fill_linear_color_scanline */
- epo_fill_linear_color_trapezoid, /* fill_linear_color_trapezoid */
- epo_fill_linear_color_triangle, /* fill_linear_color_triangle */
- default_subclass_update_spot_equivalent_colors, /* update_spot_equivalent_colors */
- default_subclass_ret_devn_params, /* ret_devn_params */
- epo_fillpage, /* fillpage */
- default_subclass_push_transparency_state, /* push_transparency_state */
- default_subclass_pop_transparency_state, /* pop_transparency_state */
- epo_put_image, /* put_image */
- default_subclass_dev_spec_op, /* dev_spec_op */
- epo_copy_planes, /* copy_planes */
- default_subclass_get_profile, /* get_profile */
- default_subclass_set_graphics_type_tag, /* set_graphics_type_tag */
- epo_strip_copy_rop2,
- default_subclass_strip_tile_rect_devn,
- epo_copy_alpha_hl_color,
- epo_process_page,
- epo_transform_pixel_region,
- epo_fill_stroke_path,
- }
+ 1, 8, 255, 0, 256, 1, NULL, NULL, NULL)
};
#undef MAX_COORD
@@ -236,6 +156,87 @@ epo_disable(int flag)
gs_debug[gs_debug_flag_epo_disable] = flag;
}
+static void
+enable_procs(gx_device *dev)
+{
+ set_dev_proc(dev, output_page, epo_output_page);
+ set_dev_proc(dev, fill_rectangle, epo_fill_rectangle);
+ set_dev_proc(dev, copy_mono, epo_copy_mono);
+ set_dev_proc(dev, copy_color, epo_copy_color);
+ set_dev_proc(dev, copy_alpha, epo_copy_alpha);
+ set_dev_proc(dev, get_bits_rectangle, epo_get_bits_rectangle);
+ set_dev_proc(dev, fill_path, epo_fill_path);
+ set_dev_proc(dev, stroke_path, epo_stroke_path);
+ set_dev_proc(dev, fill_mask, epo_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, epo_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, epo_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, epo_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, epo_draw_thin_line);
+ set_dev_proc(dev, strip_tile_rectangle, epo_strip_tile_rectangle);
+ set_dev_proc(dev, begin_typed_image, epo_begin_typed_image);
+ set_dev_proc(dev, composite, epo_composite);
+ set_dev_proc(dev, text_begin, epo_text_begin);
+ set_dev_proc(dev, fill_rectangle_hl_color, epo_fill_rectangle_hl_color);
+ set_dev_proc(dev, fill_linear_color_scanline, epo_fill_linear_color_scanline);
+ set_dev_proc(dev, fill_linear_color_trapezoid, epo_fill_linear_color_trapezoid);
+ set_dev_proc(dev, fill_linear_color_triangle, epo_fill_linear_color_triangle);
+ set_dev_proc(dev, fillpage, epo_fillpage);
+ set_dev_proc(dev, put_image, epo_put_image);
+ set_dev_proc(dev, copy_planes, epo_copy_planes);
+ set_dev_proc(dev, strip_copy_rop2, epo_strip_copy_rop2);
+ set_dev_proc(dev, copy_alpha_hl_color, epo_copy_alpha_hl_color);
+ set_dev_proc(dev, process_page, epo_process_page);
+ set_dev_proc(dev, transform_pixel_region, epo_transform_pixel_region);
+ set_dev_proc(dev, fill_stroke_path, epo_fill_stroke_path);
+}
+
+static void
+enable_self(gx_device *dev)
+{
+ erasepage_subclass_data *data = (erasepage_subclass_data *)dev->subclass_data;
+
+ data->disabled = 0;
+ enable_procs(dev);
+}
+
+static void
+disable_self(gx_device *dev)
+{
+ erasepage_subclass_data *data = (erasepage_subclass_data *)dev->subclass_data;
+
+ data->disabled = 1;
+
+ set_dev_proc(dev, output_page, default_subclass_output_page);
+ set_dev_proc(dev, fill_rectangle, default_subclass_fill_rectangle);
+ set_dev_proc(dev, copy_mono, default_subclass_copy_mono);
+ set_dev_proc(dev, copy_color, default_subclass_copy_color);
+ set_dev_proc(dev, copy_alpha, default_subclass_copy_alpha);
+ set_dev_proc(dev, get_bits_rectangle, default_subclass_get_bits_rectangle);
+ set_dev_proc(dev, fill_path, default_subclass_fill_path);
+ set_dev_proc(dev, stroke_path, default_subclass_stroke_path);
+ set_dev_proc(dev, fill_mask, default_subclass_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, default_subclass_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, default_subclass_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, default_subclass_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, default_subclass_draw_thin_line);
+ set_dev_proc(dev, strip_tile_rectangle, default_subclass_strip_tile_rectangle);
+ set_dev_proc(dev, begin_typed_image, default_subclass_begin_typed_image);
+ set_dev_proc(dev, composite, default_subclass_composite);
+ set_dev_proc(dev, text_begin, default_subclass_text_begin);
+ set_dev_proc(dev, fill_rectangle_hl_color, default_subclass_fill_rectangle_hl_color);
+ set_dev_proc(dev, fill_linear_color_scanline, default_subclass_fill_linear_color_scanline);
+ set_dev_proc(dev, fill_linear_color_trapezoid, default_subclass_fill_linear_color_trapezoid);
+ set_dev_proc(dev, fill_linear_color_triangle, default_subclass_fill_linear_color_triangle);
+ /* NOT fillpage! */
+ set_dev_proc(dev, put_image, default_subclass_put_image);
+ set_dev_proc(dev, copy_planes, default_subclass_copy_planes);
+ set_dev_proc(dev, strip_copy_rop2, default_subclass_strip_copy_rop2);
+ set_dev_proc(dev, copy_alpha_hl_color, default_subclass_copy_alpha_hl_color);
+ set_dev_proc(dev, process_page, default_subclass_process_page);
+ set_dev_proc(dev, transform_pixel_region, default_subclass_transform_pixel_region);
+ set_dev_proc(dev, fill_stroke_path, default_subclass_fill_stroke_path);
+}
+
int
epo_check_and_install(gx_device *dev)
{
@@ -264,7 +265,7 @@ epo_check_and_install(gx_device *dev)
if (!can_optimize) {
DPRINTF1(dev->memory, "child %s can't be optimized, uninstalling\n", installed_epo_device->child->dname);
/* Not doing any pending fillpages because we are about to do a fillpage anyway */
- gx_device_unsubclass(installed_epo_device);
+ disable_self(installed_epo_device);
return code;
}
} else {
@@ -273,6 +274,7 @@ epo_check_and_install(gx_device *dev)
/* Already installed, nothing to do */
if (installed_epo_device != NULL) {
+ enable_self(installed_epo_device);
return code;
}
@@ -282,6 +284,10 @@ epo_check_and_install(gx_device *dev)
return code;
}
+ /* Always install us as low down the chain as possible. */
+ while (dev->child)
+ dev = dev->child;
+
/* Install subclass for optimization */
code = gx_device_subclass(dev, (gx_device *)&gs_epo_device, sizeof(erasepage_subclass_data));
if (code < 0) {
@@ -299,8 +305,11 @@ epo_handle_erase_page(gx_device *dev)
erasepage_subclass_data *data = (erasepage_subclass_data *)dev->subclass_data;
int code = 0;
+ if (data->disabled)
+ return 0;
+
if (gs_debug_c(gs_debug_flag_epo_install_only)) {
- gx_device_unsubclass(dev);
+ disable_self(dev);
DPRINTF1(dev->memory, "Uninstall erasepage, device=%s\n", dev->dname);
return code;
}
@@ -308,15 +317,15 @@ epo_handle_erase_page(gx_device *dev)
DPRINTF1(dev->memory, "Do fillpage, Uninstall erasepage, device %s\n", dev->dname);
/* Just do a fill_rectangle (using saved color) */
- if (dev->child) {
+ if (dev->child && dev->child->is_open && data->queued) {
code = dev_proc(dev->child, fill_rectangle)(dev->child,
0, 0,
dev->child->width,
dev->child->height,
data->last_color);
}
- /* Remove the epo device */
- gx_device_unsubclass(dev);
+ /* Disable the epo device */
+ disable_self(dev);
return code;
}
@@ -325,19 +334,20 @@ int epo_fillpage(gx_device *dev, gs_gstate * pgs, gx_device_color *pdevc)
{
erasepage_subclass_data *data = (erasepage_subclass_data *)dev->subclass_data;
- if (gs_debug_c(gs_debug_flag_epo_install_only)) {
+ if (data->disabled || gs_debug_c(gs_debug_flag_epo_install_only)) {
return default_subclass_fillpage(dev, pgs, pdevc);
}
/* If color is not pure, don't defer this, uninstall and do it now */
if (!color_is_pure(pdevc)) {
DPRINTF(dev->memory, "epo_fillpage(), color is not pure, uninstalling\n");
- gx_device_unsubclass(dev);
- return dev_proc(dev, fillpage)(dev, pgs, pdevc);
+ disable_self(dev);
+ return dev_proc(dev->child, fillpage)(dev->child, pgs, pdevc);
}
/* Save the color being requested, and swallow the fillpage */
data->last_color = pdevc->colors.pure;
+ data->queued = 1;
DPRINTF(dev->memory, "Swallowing fillpage\n");
return 0;
@@ -349,6 +359,7 @@ int epo_output_page(gx_device *dev, int num_copies, int flush)
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, output_page)(dev, num_copies, flush);
}
@@ -358,18 +369,10 @@ int epo_fill_rectangle(gx_device *dev, int x, int y, int width, int height, gx_c
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, fill_rectangle)(dev, x, y, width, height, color);
}
-int epo_draw_line(gx_device *dev, int x0, int y0, int x1, int y1, gx_color_index color)
-{
- int code = epo_handle_erase_page(dev);
-
- if (code != 0)
- return code;
- return dev_proc(dev, obsolete_draw_line)(dev, x0, y0, x1, y1, color);
-}
-
int epo_fill_path(gx_device *dev, const gs_gstate *pgs, gx_path *ppath,
const gx_fill_params *params,
const gx_drawing_color *pdcolor, const gx_clip_path *pcpath)
@@ -378,6 +381,7 @@ int epo_fill_path(gx_device *dev, const gs_gstate *pgs, gx_path *ppath,
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, fill_path)(dev, pgs, ppath, params, pdcolor, pcpath);
}
@@ -390,6 +394,7 @@ int epo_fill_mask(gx_device *dev, const byte *data, int data_x, int raster, gx_b
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, fill_mask)(dev, data, data_x, raster, id, x, y, width, height, pdcolor, depth, lop, pcpath);
}
@@ -401,6 +406,7 @@ int epo_fill_trapezoid(gx_device *dev, const gs_fixed_edge *left, const gs_fixed
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, fill_trapezoid)(dev, left, right, ybot, ytop, swap_axes, pdcolor, lop);
}
@@ -411,6 +417,7 @@ int epo_fill_parallelogram(gx_device *dev, fixed px, fixed py, fixed ax, fixed a
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, fill_parallelogram)(dev, px, py, ax, ay, bx, by, pdcolor, lop);
}
@@ -421,6 +428,7 @@ int epo_fill_triangle(gx_device *dev, fixed px, fixed py, fixed ax, fixed ay, fi
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, fill_triangle)(dev, px, py, ax, ay, bx, by, pdcolor, lop);
}
@@ -432,6 +440,7 @@ int epo_draw_thin_line(gx_device *dev, fixed fx0, fixed fy0, fixed fx1, fixed fy
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, draw_thin_line)(dev, fx0, fy0, fx1, fy1, pdcolor, lop, adjustx, adjusty);
}
@@ -442,6 +451,7 @@ int epo_fill_rectangle_hl_color(gx_device *dev, const gs_fixed_rect *rect,
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, fill_rectangle_hl_color)(dev, rect, pgs, pdcolor, pcpath);
}
@@ -453,6 +463,7 @@ int epo_fill_linear_color_scanline(gx_device *dev, const gs_fill_attributes *fa,
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, fill_linear_color_scanline)(dev, fa, i, j, w, c0, c0_f, cg_num, cg_den);
}
@@ -466,6 +477,7 @@ int epo_fill_linear_color_trapezoid(gx_device *dev, const gs_fill_attributes *fa
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, fill_linear_color_trapezoid)(dev, fa, p0, p1, p2, p3, c0, c1, c2, c3);
}
@@ -477,6 +489,7 @@ int epo_fill_linear_color_triangle(gx_device *dev, const gs_fill_attributes *fa,
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, fill_linear_color_triangle)(dev, fa, p0, p1, p2, c0, c1, c2);
}
@@ -488,31 +501,33 @@ int epo_put_image(gx_device *dev, gx_device *mdev, const byte **buffers, int num
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, put_image)(dev, mdev, buffers, num_chan, x, y, width, height, row_stride, alpha_plane_index, tag_plane_index);
}
-int epo_create_compositor(gx_device *dev, gx_device **pcdev, const gs_composite_t *pcte,
+int epo_composite(gx_device *dev, gx_device **pcdev, const gs_composite_t *pcte,
gs_gstate *pgs, gs_memory_t *memory, gx_device *cdev)
{
int code = epo_handle_erase_page(dev);
if (code != 0)
return code;
- return dev_proc(dev, create_compositor)(dev, pcdev, pcte, pgs, memory, cdev);
+ return default_subclass_composite(dev, pcdev, pcte, pgs, memory, cdev);
}
int epo_text_begin(gx_device *dev, gs_gstate *pgs, const gs_text_params_t *text,
- gs_font *font, gx_path *path, const gx_device_color *pdcolor, const gx_clip_path *pcpath,
- gs_memory_t *memory, gs_text_enum_t **ppte)
+ gs_font *font, const gx_clip_path *pcpath,
+ gs_text_enum_t **ppte)
{
int code = epo_handle_erase_page(dev);
if (code != 0)
return code;
- return dev_proc(dev, text_begin)(dev, pgs, text, font, path, pdcolor, pcpath, memory, ppte);
+ dev = dev->child;
+ return dev_proc(dev, text_begin)(dev, pgs, text, font, pcpath, ppte);
}
-int epo_finish_copydevice(gx_device *dev, const gx_device *from_dev)
+static int epo_initialize_device(gx_device *dev)
{
/* We musn't allow the following pointers to remain shared with the from_dev
because we're about to tell the caller it's only allowed to copy the prototype
@@ -522,20 +537,15 @@ int epo_finish_copydevice(gx_device *dev, const gx_device *from_dev)
dev->child = NULL;
dev->parent = NULL;
dev->subclass_data = NULL;
- /* Only allow copying the prototype. */
- return (from_dev->memory ? gs_note_error(gs_error_rangecheck) : 0);
+ return 0;
}
-int epo_begin_image(gx_device *dev, const gs_gstate *pgs, const gs_image_t *pim,
- gs_image_format_t format, const gs_int_rect *prect,
- const gx_drawing_color *pdcolor, const gx_clip_path *pcpath,
- gs_memory_t *memory, gx_image_enum_common_t **pinfo)
+void epo_initialize_device_procs(gx_device *dev)
{
- int code = epo_handle_erase_page(dev);
+ default_subclass_initialize_device_procs(dev);
- if (code != 0)
- return code;
- return dev_proc(dev, begin_image)(dev, pgs, pim, format, prect, pdcolor, pcpath, memory, pinfo);
+ set_dev_proc(dev, initialize_device, epo_initialize_device);
+ enable_procs(dev);
}
int epo_begin_typed_image(gx_device *dev, const gs_gstate *pgs, const gs_matrix *pmat,
@@ -547,6 +557,7 @@ int epo_begin_typed_image(gx_device *dev, const gs_gstate *pgs, const gs_matrix
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, begin_typed_image)(dev, pgs, pmat, pic, prect, pdcolor, pcpath, memory, pinfo);
}
@@ -558,20 +569,10 @@ int epo_stroke_path(gx_device *dev, const gs_gstate *pgs, gx_path *ppath,
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, stroke_path)(dev, pgs, ppath, params, pdcolor, pcpath);
}
-int epo_tile_rectangle(gx_device *dev, const gx_tile_bitmap *tile, int x, int y, int width, int height,
- gx_color_index color0, gx_color_index color1,
- int phase_x, int phase_y)
-{
- int code = epo_handle_erase_page(dev);
-
- if (code != 0)
- return code;
- return dev_proc(dev, tile_rectangle)(dev, tile, x, y, width, height, color0, color1, phase_x, phase_y);
-}
-
int epo_copy_mono(gx_device *dev, const byte *data, int data_x, int raster, gx_bitmap_id id,
int x, int y, int width, int height,
gx_color_index color0, gx_color_index color1)
@@ -580,6 +581,7 @@ int epo_copy_mono(gx_device *dev, const byte *data, int data_x, int raster, gx_b
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, copy_mono)(dev, data, data_x, raster, id, x, y, width, height, color0, color1);
}
@@ -590,16 +592,19 @@ int epo_copy_color(gx_device *dev, const byte *data, int data_x, int raster, gx_
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, copy_color)(dev, data, data_x, raster, id, x, y, width, height);
}
-int epo_get_bits(gx_device *dev, int y, byte *data, byte **actual_data)
+int epo_get_bits_rectangle(gx_device *dev, const gs_int_rect *prect,
+ gs_get_bits_params_t *params)
{
int code = epo_handle_erase_page(dev);
if (code != 0)
return code;
- return dev_proc(dev, get_bits)(dev, y, data, actual_data);
+ dev = dev->child;
+ return dev_proc(dev, get_bits_rectangle)(dev, prect, params);
}
int epo_copy_alpha(gx_device *dev, const byte *data, int data_x,
@@ -610,22 +615,10 @@ int epo_copy_alpha(gx_device *dev, const byte *data, int data_x,
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, copy_alpha)(dev, data, data_x, raster, id, x, y, width, height, color, depth);
}
-int epo_copy_rop(gx_device *dev, const byte *sdata, int sourcex, uint sraster, gx_bitmap_id id,
- const gx_color_index *scolors,
- const gx_tile_bitmap *texture, const gx_color_index *tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- int code = epo_handle_erase_page(dev);
-
- if (code != 0)
- return code;
- return dev_proc(dev, copy_rop)(dev, sdata, sourcex, sraster, id, scolors, texture, tcolors, x, y, width, height, phase_x, phase_y, lop);
-}
-
int epo_strip_tile_rectangle(gx_device *dev, const gx_strip_bitmap *tiles, int x, int y, int width, int height,
gx_color_index color0, gx_color_index color1,
int phase_x, int phase_y)
@@ -634,22 +627,10 @@ int epo_strip_tile_rectangle(gx_device *dev, const gx_strip_bitmap *tiles, int x
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, strip_tile_rectangle)(dev, tiles, x, y, width, height, color0, color1, phase_x, phase_y);
}
-int epo_strip_copy_rop(gx_device *dev, const byte *sdata, int sourcex, uint sraster, gx_bitmap_id id,
- const gx_color_index *scolors,
- const gx_strip_bitmap *textures, const gx_color_index *tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- int code = epo_handle_erase_page(dev);
-
- if (code != 0)
- return code;
- return dev_proc(dev, strip_copy_rop)(dev, sdata, sourcex, sraster, id, scolors, textures, tcolors, x, y, width, height, phase_x, phase_y, lop);
-}
-
int epo_strip_copy_rop2(gx_device *dev, const byte *sdata, int sourcex, uint sraster, gx_bitmap_id id,
const gx_color_index *scolors, const gx_strip_bitmap *textures, const gx_color_index *tcolors,
int x, int y, int width, int height, int phase_x, int phase_y, gs_logical_operation_t lop, uint planar_height)
@@ -658,6 +639,7 @@ int epo_strip_copy_rop2(gx_device *dev, const byte *sdata, int sourcex, uint sra
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, strip_copy_rop2)(dev, sdata, sourcex, sraster, id, scolors, textures, tcolors, x, y, width, height, phase_x, phase_y, lop, planar_height);
}
@@ -668,6 +650,7 @@ int epo_copy_planes(gx_device *dev, const byte *data, int data_x, int raster, gx
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, copy_planes)(dev, data, data_x, raster, id, x, y, width, height, plane_height);
}
@@ -679,6 +662,7 @@ int epo_copy_alpha_hl_color(gx_device *dev, const byte *data, int data_x,
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, copy_alpha_hl_color)(dev, data, data_x, raster, id, x, y, width, height, pdcolor, depth);
}
@@ -688,6 +672,7 @@ int epo_process_page(gx_device *dev, gx_process_page_options_t *options)
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, process_page)(dev, options);
}
@@ -700,6 +685,7 @@ int epo_fill_stroke_path(gx_device *dev, const gs_gstate *pgs, gx_path *ppath,
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, fill_stroke_path)(dev, pgs, ppath, fill_params, pdcolor_fill,
stroke_params, pdcolor_stroke, pcpath);
}
@@ -710,5 +696,6 @@ int epo_transform_pixel_region(gx_device *dev, transform_pixel_region_reason rea
if (code != 0)
return code;
+ dev = dev->child;
return dev_proc(dev, transform_pixel_region)(dev, reason, data);
}
diff --git a/base/gdevepo.h b/base/gdevepo.h
index 029a54ad..eeadc2a2 100644
--- a/base/gdevepo.h
+++ b/base/gdevepo.h
@@ -29,7 +29,9 @@ typedef struct gx_device_s gx_device_epo;
typedef struct {
subclass_common;
- gx_color_index last_color; // Pure color only
+ gx_color_index last_color; /* Pure color only */
+ int queued; /* We have a fillpage queued */
+ int disabled; /* Set once we have done our job */
} erasepage_subclass_data;
/* Check if epo subclass device installed, and install it if not */
diff --git a/base/gdevflp.c b/base/gdevflp.c
index 20757bbe..3c1ad135 100644
--- a/base/gdevflp.c
+++ b/base/gdevflp.c
@@ -60,16 +60,12 @@ private_st_flp_text_enum();
static dev_proc_output_page(flp_output_page);
static dev_proc_close_device(flp_close_device);
static dev_proc_fill_rectangle(flp_fill_rectangle);
-static dev_proc_tile_rectangle(flp_tile_rectangle);
static dev_proc_copy_mono(flp_copy_mono);
static dev_proc_copy_color(flp_copy_color);
-static dev_proc_draw_line(flp_draw_line);
-static dev_proc_get_bits(flp_get_bits);
+static dev_proc_get_bits_rectangle(flp_get_bits_rectangle);
static dev_proc_get_params(flp_put_params);
static dev_proc_get_alpha_bits(flp_get_alpha_bits);
static dev_proc_copy_alpha(flp_copy_alpha);
-static dev_proc_get_band(flp_get_band);
-static dev_proc_copy_rop(flp_copy_rop);
static dev_proc_fill_path(flp_fill_path);
static dev_proc_stroke_path(flp_stroke_path);
static dev_proc_fill_mask(flp_fill_mask);
@@ -77,21 +73,16 @@ static dev_proc_fill_trapezoid(flp_fill_trapezoid);
static dev_proc_fill_parallelogram(flp_fill_parallelogram);
static dev_proc_fill_triangle(flp_fill_triangle);
static dev_proc_draw_thin_line(flp_draw_thin_line);
-static dev_proc_begin_image(flp_begin_image);
-static dev_proc_image_data(flp_image_data);
-static dev_proc_end_image(flp_end_image);
static dev_proc_strip_tile_rectangle(flp_strip_tile_rectangle);
-static dev_proc_strip_copy_rop(flp_strip_copy_rop);
static dev_proc_begin_typed_image(flp_begin_typed_image);
static dev_proc_get_bits_rectangle(flp_get_bits_rectangle);
-static dev_proc_create_compositor(flp_create_compositor);
+static dev_proc_composite(flp_composite);
static dev_proc_text_begin(flp_text_begin);
static dev_proc_begin_transparency_group(flp_begin_transparency_group);
static dev_proc_end_transparency_group(flp_end_transparency_group);
static dev_proc_begin_transparency_mask(flp_begin_transparency_mask);
static dev_proc_end_transparency_mask(flp_end_transparency_mask);
static dev_proc_discard_transparency_layer(flp_discard_transparency_layer);
-static dev_proc_pattern_manage(flp_pattern_manage);
static dev_proc_fill_rectangle_hl_color(flp_fill_rectangle_hl_color);
static dev_proc_fill_linear_color_scanline(flp_fill_linear_color_scanline);
static dev_proc_fill_linear_color_trapezoid(flp_fill_linear_color_trapezoid);
@@ -107,6 +98,7 @@ static dev_proc_copy_alpha_hl_color(flp_copy_alpha_hl_color);
static dev_proc_process_page(flp_process_page);
static dev_proc_transform_pixel_region(flp_transform_pixel_region);
static dev_proc_fill_stroke_path(flp_fill_stroke_path);
+static dev_proc_initialize_device_procs(flp_initialize_device_procs);
/* The device prototype */
#define MAX_COORD (max_int_in_fixed - 1000)
@@ -133,86 +125,11 @@ public_st_flp_device();
const
gx_device_flp gs_flp_device =
{
- std_device_dci_type_body(gx_device_flp, 0, "first_lastpage", &st_flp_device,
+ std_device_dci_type_body_sc(gx_device_flp, flp_initialize_device_procs,
+ "first_lastpage", &st_flp_device,
MAX_COORD, MAX_COORD,
MAX_RESOLUTION, MAX_RESOLUTION,
- 1, 8, 255, 0, 256, 1),
- {default_subclass_open_device,
- default_subclass_get_initial_matrix,
- default_subclass_sync_output, /* sync_output */
- flp_output_page,
- flp_close_device,
- default_subclass_map_rgb_color,
- default_subclass_map_color_rgb,
- flp_fill_rectangle,
- flp_tile_rectangle, /* tile_rectangle */
- flp_copy_mono,
- flp_copy_color,
- flp_draw_line, /* draw_line */
- flp_get_bits, /* get_bits */
- default_subclass_get_params,
- flp_put_params,
- default_subclass_map_cmyk_color,
- default_subclass_get_xfont_procs, /* get_xfont_procs */
- default_subclass_get_xfont_device, /* get_xfont_device */
- default_subclass_map_rgb_alpha_color,
- default_subclass_get_page_device,
- flp_get_alpha_bits, /* get_alpha_bits */
- flp_copy_alpha,
- flp_get_band, /* get_band */
- flp_copy_rop, /* copy_rop */
- flp_fill_path,
- flp_stroke_path,
- flp_fill_mask,
- flp_fill_trapezoid,
- flp_fill_parallelogram,
- flp_fill_triangle,
- flp_draw_thin_line,
- flp_begin_image,
- flp_image_data, /* image_data */
- flp_end_image, /* end_image */
- flp_strip_tile_rectangle,
- flp_strip_copy_rop,
- default_subclass_get_clipping_box, /* get_clipping_box */
- flp_begin_typed_image,
- flp_get_bits_rectangle, /* get_bits_rectangle */
- default_subclass_map_color_rgb_alpha,
- flp_create_compositor,
- default_subclass_get_hardware_params, /* get_hardware_params */
- flp_text_begin,
- default_subclass_finish_copydevice, /* finish_copydevice */
- flp_begin_transparency_group, /* begin_transparency_group */
- flp_end_transparency_group, /* end_transparency_group */
- flp_begin_transparency_mask, /* begin_transparency_mask */
- flp_end_transparency_mask, /* end_transparency_mask */
- flp_discard_transparency_layer, /* discard_transparency_layer */
- default_subclass_get_color_mapping_procs, /* get_color_mapping_procs */
- default_subclass_get_color_comp_index, /* get_color_comp_index */
- default_subclass_encode_color, /* encode_color */
- default_subclass_decode_color, /* decode_color */
- flp_pattern_manage, /* pattern_manage */
- flp_fill_rectangle_hl_color, /* fill_rectangle_hl_color */
- default_subclass_include_color_space, /* include_color_space */
- flp_fill_linear_color_scanline, /* fill_linear_color_scanline */
- flp_fill_linear_color_trapezoid, /* fill_linear_color_trapezoid */
- flp_fill_linear_color_triangle, /* fill_linear_color_triangle */
- default_subclass_update_spot_equivalent_colors, /* update_spot_equivalent_colors */
- default_subclass_ret_devn_params, /* ret_devn_params */
- flp_fillpage, /* fillpage */
- flp_push_transparency_state, /* push_transparency_state */
- flp_pop_transparency_state, /* pop_transparency_state */
- flp_put_image, /* put_image */
- default_subclass_dev_spec_op, /* dev_spec_op */
- flp_copy_planes, /* copy_planes */
- default_subclass_get_profile, /* get_profile */
- default_subclass_set_graphics_type_tag, /* set_graphics_type_tag */
- flp_strip_copy_rop2,
- flp_strip_tile_rect_devn,
- flp_copy_alpha_hl_color,
- flp_process_page,
- flp_transform_pixel_region,
- flp_fill_stroke_path,
- }
+ 1, 8, 255, 0, 256, 1, NULL, NULL, NULL)
};
#undef MAX_COORD
@@ -449,20 +366,6 @@ int flp_fill_rectangle(gx_device *dev, int x, int y, int width, int height, gx_c
return 0;
}
-int flp_tile_rectangle(gx_device *dev, const gx_tile_bitmap *tile, int x, int y, int width, int height,
- gx_color_index color0, gx_color_index color1,
- int phase_x, int phase_y)
-{
- int code = SkipPage(dev);
-
- if (code < 0)
- return code;
- if (!code)
- return default_subclass_tile_rectangle(dev, tile, x, y, width, height, color0, color1, phase_x, phase_y);
-
- return 0;
-}
-
int flp_copy_mono(gx_device *dev, const byte *data, int data_x, int raster, gx_bitmap_id id,
int x, int y, int width, int height,
gx_color_index color0, gx_color_index color1)
@@ -490,30 +393,6 @@ int flp_copy_color(gx_device *dev, const byte *data, int data_x, int raster, gx_
return 0;
}
-int flp_draw_line(gx_device *dev, int x0, int y0, int x1, int y1, gx_color_index color)
-{
- int code = SkipPage(dev);
-
- if (code < 0)
- return code;
- if (!code)
- return default_subclass_draw_line(dev, x0, y0, x1, y1, color);
-
- return 0;
-}
-
-int flp_get_bits(gx_device *dev, int y, byte *data, byte **actual_data)
-{
- int code = SkipPage(dev);
-
- if (code < 0)
- return code;
- if (!code)
- return default_subclass_get_bits(dev, y, data, actual_data);
-
- return gx_default_get_bits(dev, y, data, actual_data);
-}
-
static void
flp_rc_free_pages_list(gs_memory_t * mem, void *ptr_in, client_name_t cname)
{
@@ -653,34 +532,6 @@ int flp_copy_alpha(gx_device *dev, const byte *data, int data_x,
return 0;
}
-int flp_get_band(gx_device *dev, int y, int *band_start)
-{
- int code = SkipPage(dev);
-
- if (code < 0)
- return code;
- if (!code)
- return default_subclass_get_band(dev, y, band_start);
-
- return gx_default_get_band(dev, y, band_start);
-}
-
-int flp_copy_rop(gx_device *dev, const byte *sdata, int sourcex, uint sraster, gx_bitmap_id id,
- const gx_color_index *scolors,
- const gx_tile_bitmap *texture, const gx_color_index *tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- int code = SkipPage(dev);
-
- if (code < 0)
- return code;
- if (!code)
- return default_subclass_copy_rop(dev, sdata, sourcex, sraster, id, scolors, texture, tcolors, x, y, width, height, phase_x, phase_y, lop);
-
- return 0;
-}
-
int flp_fill_path(gx_device *dev, const gs_gstate *pgs, gx_path *ppath,
const gx_fill_params *params,
const gx_drawing_color *pdcolor, const gx_clip_path *pcpath)
@@ -778,46 +629,6 @@ int flp_draw_thin_line(gx_device *dev, fixed fx0, fixed fy0, fixed fx1, fixed fy
return 0;
}
-int flp_begin_image(gx_device *dev, const gs_gstate *pgs, const gs_image_t *pim,
- gs_image_format_t format, const gs_int_rect *prect,
- const gx_drawing_color *pdcolor, const gx_clip_path *pcpath,
- gs_memory_t *memory, gx_image_enum_common_t **pinfo)
-{
- int code = SkipPage(dev);
-
- if (code < 0)
- return code;
- if (!code)
- return default_subclass_begin_image(dev, pgs, pim, format, prect, pdcolor, pcpath, memory, pinfo);
-
- return 0;
-}
-
-int flp_image_data(gx_device *dev, gx_image_enum_common_t *info, const byte **planes, int data_x,
- uint raster, int height)
-{
- int code = SkipPage(dev);
-
- if (code < 0)
- return code;
- if (!code)
- return default_subclass_image_data(dev, info, planes, data_x, raster, height);
-
- return 0;
-}
-
-int flp_end_image(gx_device *dev, gx_image_enum_common_t *info, bool draw_last)
-{
- int code = SkipPage(dev);
-
- if (code < 0)
- return code;
- if (!code)
- return default_subclass_end_image(dev, info, draw_last);
-
- return 0;
-}
-
int flp_strip_tile_rectangle(gx_device *dev, const gx_strip_bitmap *tiles, int x, int y, int width, int height,
gx_color_index color0, gx_color_index color1,
int phase_x, int phase_y)
@@ -832,22 +643,6 @@ int flp_strip_tile_rectangle(gx_device *dev, const gx_strip_bitmap *tiles, int x
return 0;
}
-int flp_strip_copy_rop(gx_device *dev, const byte *sdata, int sourcex, uint sraster, gx_bitmap_id id,
- const gx_color_index *scolors,
- const gx_strip_bitmap *textures, const gx_color_index *tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- int code = SkipPage(dev);
-
- if (code < 0)
- return code;
- if (!code)
- return default_subclass_strip_copy_rop(dev, sdata, sourcex, sraster, id, scolors, textures, tcolors, x, y, width, height, phase_x, phase_y, lop);
-
- return 0;
-}
-
typedef struct flp_image_enum_s {
gx_image_enum_common;
int y;
@@ -937,19 +732,19 @@ int flp_begin_typed_image(gx_device *dev, const gs_gstate *pgs, const gs_matrix
}
int flp_get_bits_rectangle(gx_device *dev, const gs_int_rect *prect,
- gs_get_bits_params_t *params, gs_int_rect **unread)
+ gs_get_bits_params_t *params)
{
int code = SkipPage(dev);
if (code < 0)
return code;
if (!code)
- return default_subclass_get_bits_rectangle(dev, prect, params, unread);
+ return default_subclass_get_bits_rectangle(dev, prect, params);
- return gx_default_get_bits_rectangle(dev->child, prect, params, unread);
+ return gx_default_get_bits_rectangle(dev->child, prect, params);
}
-int flp_create_compositor(gx_device *dev, gx_device **pcdev, const gs_composite_t *pcte,
+int flp_composite(gx_device *dev, gx_device **pcdev, const gs_composite_t *pcte,
gs_gstate *pgs, gs_memory_t *memory, gx_device *cdev)
{
int code = SkipPage(dev);
@@ -965,7 +760,7 @@ int flp_create_compositor(gx_device *dev, gx_device **pcdev, const gs_composite_
if (code < 0)
return code;
if (!code)
- return default_subclass_create_compositor(dev, pcdev, pcte, pgs, memory, cdev);
+ return default_subclass_composite(dev, pcdev, pcte, pgs, memory, cdev);
return 0;
}
@@ -1034,11 +829,12 @@ static const gs_text_enum_procs_t flp_text_procs = {
* up to the device, in which case we simply pass on the 'begin' method to the device.
*/
int flp_text_begin(gx_device *dev, gs_gstate *pgs, const gs_text_params_t *text,
- gs_font *font, gx_path *path, const gx_device_color *pdcolor, const gx_clip_path *pcpath,
- gs_memory_t *memory, gs_text_enum_t **ppte)
+ gs_font *font, const gx_clip_path *pcpath,
+ gs_text_enum_t **ppte)
{
flp_text_enum_t *penum;
int code;
+ gs_memory_t *memory = pgs->memory;
/* We don't want to simply ignore stringwidth for 2 reasons;
* firstly because following elelments may be positioned based on the value returned
@@ -1050,19 +846,19 @@ int flp_text_begin(gx_device *dev, gs_gstate *pgs, const gs_text_params_t *text,
* stringwidth operation, or they won;t be able to cache the glyphs properly.
* So always pass stringwidth operations to the child.
*/
- return default_subclass_text_begin(dev, pgs, text, font, path, pdcolor, pcpath, memory, ppte);
+ return default_subclass_text_begin(dev, pgs, text, font, pcpath, ppte);
code = SkipPage(dev);
if (code < 0)
return code;
if (!code)
- return default_subclass_text_begin(dev, pgs, text, font, path, pdcolor, pcpath, memory, ppte);
+ return default_subclass_text_begin(dev, pgs, text, font, pcpath, ppte);
rc_alloc_struct_1(penum, flp_text_enum_t, &st_flp_text_enum, memory,
return_error(gs_error_VMerror), "gdev_flp_text_begin");
penum->rc.free = rc_free_text_enum;
code = gs_text_enum_init((gs_text_enum_t *)penum, &flp_text_procs,
- dev, pgs, text, font, path, pdcolor, pcpath, memory);
+ dev, pgs, text, font, pcpath, memory);
if (code < 0) {
gs_free_object(memory, penum, "gdev_flp_text_begin");
return code;
@@ -1134,19 +930,6 @@ int flp_discard_transparency_layer(gx_device *dev, gs_gstate *pgs)
return 0;
}
-int flp_pattern_manage(gx_device *dev, gx_bitmap_id id,
- gs_pattern1_instance_t *pinst, pattern_manage_t function)
-{
- int code = SkipPage(dev);
-
- if (code < 0)
- return code;
- if (!code)
- return default_subclass_pattern_manage(dev, id, pinst, function);
-
- return 0;
-}
-
int flp_fill_rectangle_hl_color(gx_device *dev, const gs_fixed_rect *rect,
const gs_gstate *pgs, const gx_drawing_color *pdcolor, const gx_clip_path *pcpath)
{
@@ -1346,3 +1129,50 @@ int flp_transform_pixel_region(gx_device *dev, transform_pixel_region_reason rea
return 0;
}
+
+static void
+flp_initialize_device_procs(gx_device *dev)
+{
+ default_subclass_initialize_device_procs(dev);
+
+ set_dev_proc(dev, output_page, flp_output_page);
+ set_dev_proc(dev, close_device, flp_close_device);
+ set_dev_proc(dev, fill_rectangle, flp_fill_rectangle);
+ set_dev_proc(dev, copy_mono, flp_copy_mono);
+ set_dev_proc(dev, copy_color, flp_copy_color);
+ set_dev_proc(dev, put_params, flp_put_params);
+ set_dev_proc(dev, get_alpha_bits, flp_get_alpha_bits);
+ set_dev_proc(dev, copy_alpha, flp_copy_alpha);
+ set_dev_proc(dev, fill_path, flp_fill_path);
+ set_dev_proc(dev, stroke_path, flp_stroke_path);
+ set_dev_proc(dev, fill_mask, flp_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, flp_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, flp_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, flp_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, flp_draw_thin_line);
+ set_dev_proc(dev, strip_tile_rectangle, flp_strip_tile_rectangle);
+ set_dev_proc(dev, begin_typed_image, flp_begin_typed_image);
+ set_dev_proc(dev, get_bits_rectangle, flp_get_bits_rectangle);
+ set_dev_proc(dev, composite, flp_composite);
+ set_dev_proc(dev, text_begin, flp_text_begin);
+ set_dev_proc(dev, begin_transparency_group, flp_begin_transparency_group);
+ set_dev_proc(dev, end_transparency_group, flp_end_transparency_group);
+ set_dev_proc(dev, begin_transparency_mask, flp_begin_transparency_mask);
+ set_dev_proc(dev, end_transparency_mask, flp_end_transparency_mask);
+ set_dev_proc(dev, discard_transparency_layer, flp_discard_transparency_layer);
+ set_dev_proc(dev, fill_rectangle_hl_color, flp_fill_rectangle_hl_color);
+ set_dev_proc(dev, fill_linear_color_scanline, flp_fill_linear_color_scanline);
+ set_dev_proc(dev, fill_linear_color_trapezoid, flp_fill_linear_color_trapezoid);
+ set_dev_proc(dev, fill_linear_color_triangle, flp_fill_linear_color_triangle);
+ set_dev_proc(dev, fillpage, flp_fillpage);
+ set_dev_proc(dev, push_transparency_state, flp_push_transparency_state);
+ set_dev_proc(dev, pop_transparency_state, flp_pop_transparency_state);
+ set_dev_proc(dev, put_image, flp_put_image);
+ set_dev_proc(dev, copy_planes, flp_copy_planes);
+ set_dev_proc(dev, strip_copy_rop2, flp_strip_copy_rop2);
+ set_dev_proc(dev, strip_tile_rect_devn, flp_strip_tile_rect_devn);
+ set_dev_proc(dev, copy_alpha_hl_color, flp_copy_alpha_hl_color);
+ set_dev_proc(dev, process_page, flp_process_page);
+ set_dev_proc(dev, transform_pixel_region, flp_transform_pixel_region);
+ set_dev_proc(dev, fill_stroke_path, flp_fill_stroke_path);
+} \ No newline at end of file
diff --git a/base/gdevhit.c b/base/gdevhit.c
index 0a804b4c..04f7345a 100644
--- a/base/gdevhit.c
+++ b/base/gdevhit.c
@@ -28,52 +28,30 @@ const int gs_hit_detected = gs_error_hit_detected;
* It returns e_hit whenever it is asked to actually paint any pixels.
*/
static dev_proc_fill_rectangle(hit_fill_rectangle);
+static void
+hit_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, fill_rectangle, hit_fill_rectangle);
+ set_dev_proc(dev, composite, gx_non_imaging_composite);
+
+ set_dev_proc(dev, map_rgb_color, gx_default_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_default_map_color_rgb);
+ set_dev_proc(dev, map_cmyk_color, gx_default_map_cmyk_color);
+ set_dev_proc(dev, get_page_device, gx_default_get_page_device);
+ set_dev_proc(dev, get_alpha_bits, gx_default_get_alpha_bits);
+ set_dev_proc(dev, fill_path, gx_default_fill_path);
+ set_dev_proc(dev, fill_trapezoid, gx_default_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, gx_default_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, gx_default_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, gx_default_draw_thin_line);
+ set_dev_proc(dev, strip_tile_rectangle, gx_default_strip_tile_rectangle);
+ set_dev_proc(dev, strip_copy_rop2, gx_default_strip_copy_rop2);
+ set_dev_proc(dev, get_clipping_box, gx_get_largest_clipping_box);
+ set_dev_proc(dev, begin_typed_image, gx_default_begin_typed_image);
+}
const gx_device gs_hit_device = {
- std_device_std_body(gx_device, 0, "hit detector",
- 0, 0, 1, 1),
- {NULL, /* open_device */
- NULL, /* get_initial_matrix */
- NULL, /* sync_output */
- NULL, /* output_page */
- NULL, /* close_device */
- gx_default_map_rgb_color,
- gx_default_map_color_rgb,
- hit_fill_rectangle,
- NULL, /* tile_rectangle */
- NULL, /* copy_mono */
- NULL, /* copy_color */
- gx_default_draw_line,
- NULL, /* get_bits */
- NULL, /* get_params */
- NULL, /* put_params */
- gx_default_map_cmyk_color,
- NULL, /* get_xfont_procs */
- NULL, /* get_xfont_device */
- gx_default_map_rgb_alpha_color,
- gx_default_get_page_device,
- gx_default_get_alpha_bits,
- NULL, /* copy_alpha */
- gx_default_get_band,
- NULL, /* copy_rop */
- gx_default_fill_path,
- NULL, /* stroke_path */
- NULL, /* fill_mask */
- gx_default_fill_trapezoid,
- gx_default_fill_parallelogram,
- gx_default_fill_triangle,
- gx_default_draw_thin_line,
- gx_default_begin_image,
- gx_default_image_data,
- gx_default_end_image,
- gx_default_strip_tile_rectangle,
- gx_default_strip_copy_rop,
- gx_get_largest_clipping_box,
- gx_default_begin_typed_image,
- NULL, /* get_bits_rectangle */
- gx_default_map_color_rgb_alpha,
- gx_non_imaging_create_compositor,
- NULL /* get_hardware_params */
- }
+ std_device_std_body(gx_device, hit_initialize_device_procs, "hit detector",
+ 0, 0, 1, 1)
};
/* Test for a hit when filling a rectangle. */
diff --git a/base/gdevkrnlsclass.c b/base/gdevkrnlsclass.c
index d615a100..8ae05fb2 100644
--- a/base/gdevkrnlsclass.c
+++ b/base/gdevkrnlsclass.c
@@ -39,7 +39,7 @@ int install_internal_subclass_devices(gx_device **ppdev, int *devices_loaded)
#else
if (!dev->NupHandlerPushed && dev->NupControl != 0) {
#endif
- code = gx_device_subclass(dev, (gx_device *)&gs_nup_device, sizeof(Nup_device_subclass_data));
+ code = gx_device_nup_device_install(dev);
if (code < 0)
return code;
diff --git a/base/gdevm1.c b/base/gdevm1.c
index 7801c3a6..f7381446 100644
--- a/base/gdevm1.c
+++ b/base/gdevm1.c
@@ -48,14 +48,15 @@
* functions below. In this function, rop works in terms of device pixel
* values, not RGB-space values. */
int
-mem_mono_strip_copy_rop_dev(gx_device * dev, const byte * sdata,
- int sourcex,uint sraster, gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_strip_bitmap * textures,
- const gx_color_index * tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y,
- gs_logical_operation_t lop)
+mem_mono_strip_copy_rop2_dev(gx_device * dev, const byte * sdata,
+ int sourcex,uint sraster, gx_bitmap_id id,
+ const gx_color_index * scolors,
+ const gx_strip_bitmap * textures,
+ const gx_color_index * tcolors,
+ int x, int y, int width, int height,
+ int phase_x, int phase_y,
+ gs_logical_operation_t lop,
+ uint planar_height)
{
gx_device_memory *mdev = (gx_device_memory *) dev;
gs_rop3_t rop = (gs_rop3_t)lop;
@@ -67,6 +68,11 @@ mem_mono_strip_copy_rop_dev(gx_device * dev, const byte * sdata,
int ty;
rop_run_op ropper;
+ if (planar_height != 0) {
+ dmlprintf(dev->memory, "mem_default_strip_copy_rop2 should never be called!\n");
+ return_error(gs_error_Fatal);
+ }
+
/* Modify the raster operation according to the source palette. */
if (scolors != 0) { /* Source with palette. */
switch ((int)((scolors[1] << 1) + scolors[0])) {
@@ -426,19 +432,25 @@ mem_mono_strip_copy_rop_dev(gx_device * dev, const byte * sdata,
/* Procedures */
static dev_proc_map_rgb_color(mem_mono_map_rgb_color);
static dev_proc_map_color_rgb(mem_mono_map_color_rgb);
-static dev_proc_copy_mono(mem_mono_copy_mono);
-static dev_proc_fill_rectangle(mem_mono_fill_rectangle);
static dev_proc_strip_tile_rectangle(mem_mono_strip_tile_rectangle);
/* The device descriptor. */
/* The instance is public. */
const gx_device_memory mem_mono_device =
-mem_full_alpha_device("image1", 0, 1, mem_open,
- mem_mono_map_rgb_color, mem_mono_map_color_rgb,
- mem_mono_copy_mono, gx_default_copy_color, mem_mono_fill_rectangle,
- gx_default_map_cmyk_color, gx_no_copy_alpha,
- mem_mono_strip_tile_rectangle, mem_mono_strip_copy_rop,
- mem_get_bits_rectangle);
+ mem_device("image1", 0, 1, mem_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_1 =
+{
+ mem_mono_map_rgb_color,
+ mem_mono_map_color_rgb,
+ mem_mono_fill_rectangle,
+ mem_mono_copy_mono,
+ gx_default_copy_color,
+ gx_default_copy_alpha,
+ mem_mono_strip_tile_rectangle,
+ mem_mono_strip_copy_rop2,
+ mem_get_bits_rectangle
+};
/* Map color to/from RGB. This may be inverted. */
static gx_color_index
@@ -458,7 +470,7 @@ mem_mono_map_color_rgb(gx_device * dev, gx_color_index color,
}
/* Fill a rectangle with a color. */
-static int
+int
mem_mono_fill_rectangle(gx_device * dev, int x, int y, int w, int h,
gx_color_index color)
{
@@ -582,7 +594,7 @@ static const copy_mode copy_modes[16] = {
(invert ? gs_note_error(-1) :\
mem_mono_fill_rectangle(dev, x, y, w, h, color0))
-static int
+int
mem_mono_copy_mono(gx_device * dev,
const byte * source_data, int source_x, int source_raster, gx_bitmap_id id,
int x, int y, int w, int h, gx_color_index color0, gx_color_index color1)
@@ -617,14 +629,15 @@ mem_mono_copy_mono(gx_device * dev,
fit_copy(dev, source_data, source_x, source_raster, id, x, y, w, h);
#ifdef DO_COPY_MONO_BY_COPY_ROP
if (w >= 32) {
- return mem_mono_strip_copy_rop_dev(dev, source_data, source_x,
- source_raster,
- id, NULL, NULL, NULL,
- x, y, w, h, 0, 0,
- ((color0 == gx_no_color_index ? rop3_D :
- color0 == 0 ? rop3_0 : rop3_1) & ~rop3_S) |
- ((color1 == gx_no_color_index ? rop3_D :
- color1 == 0 ? rop3_0 : rop3_1) & rop3_S));
+ return mem_mono_strip_copy_rop2_dev(dev, source_data, source_x,
+ source_raster,
+ id, NULL, NULL, NULL,
+ x, y, w, h, 0, 0,
+ ((color0 == gx_no_color_index ? rop3_D :
+ color0 == 0 ? rop3_0 : rop3_1) & ~rop3_S) |
+ ((color1 == gx_no_color_index ? rop3_D :
+ color1 == 0 ? rop3_0 : rop3_1) & rop3_S),
+ 0);
}
#endif /* !DO_COPY_MONO_BY_COPY_ROP */
#if gx_no_color_index_value != -1 /* hokey! */
@@ -867,9 +880,9 @@ int tx, int y, int tw, int th, gx_color_index color0, gx_color_index color1,
if (rop == 0xAA)
return gx_default_strip_tile_rectangle(dev, tiles, tx, y, tw, th,
color0, color1, px, py);
- return mem_mono_strip_copy_rop_dev(dev, NULL, 0, 0, tiles->id, NULL,
- tiles, NULL,
- tx, y, tw, th, px, py, rop);
+ return mem_mono_strip_copy_rop2_dev(dev, NULL, 0, 0, tiles->id, NULL,
+ tiles, NULL,
+ tx, y, tw, th, px, py, rop, 0);
#else /* !USE_COPY_ROP */
gx_device_memory * const mdev = (gx_device_memory *)dev;
register uint invert;
@@ -1074,6 +1087,8 @@ int tx, int y, int tw, int th, gx_color_index color0, gx_color_index color1,
#endif /* !USE_COPY_ROP */
}
+
+
/* ================ "Word"-oriented device ================ */
/* Note that on a big-endian machine, this is the same as the */
@@ -1089,12 +1104,20 @@ static dev_proc_fill_rectangle(mem1_word_fill_rectangle);
/* Here is the device descriptor. */
const gx_device_memory mem_mono_word_device =
-mem_full_alpha_device("image1w", 0, 1, mem_open,
- mem_mono_map_rgb_color, mem_mono_map_color_rgb,
- mem1_word_copy_mono, gx_default_copy_color, mem1_word_fill_rectangle,
- gx_default_map_cmyk_color, gx_no_copy_alpha,
- mem1_word_strip_tile_rectangle, gx_no_strip_copy_rop,
- mem_word_get_bits_rectangle);
+ mem_device("image1w", 0, 1, mem_word_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_1w =
+{
+ mem_mono_map_rgb_color,
+ mem_mono_map_color_rgb,
+ mem1_word_fill_rectangle,
+ mem1_word_copy_mono,
+ gx_default_copy_color,
+ gx_default_copy_alpha,
+ mem1_word_strip_tile_rectangle,
+ gx_no_strip_copy_rop2,
+ mem_word_get_bits_rectangle
+};
/* Fill a rectangle with a color. */
static int
diff --git a/base/gdevm16.c b/base/gdevm16.c
index f4d662eb..0f54f2b8 100644
--- a/base/gdevm16.c
+++ b/base/gdevm16.c
@@ -32,10 +32,20 @@ declare_mem_procs(mem_true16_copy_mono, mem_true16_copy_color, mem_true16_fill_r
/* The device descriptor. */
const gx_device_memory mem_true16_device =
- mem_device("image16", 16, 0,
- mem_true16_map_rgb_color, mem_true16_map_color_rgb,
- mem_true16_copy_mono, mem_true16_copy_color,
- mem_true16_fill_rectangle, mem_default_strip_copy_rop);
+ mem_device("image16", 16, 0, mem_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_16 =
+{
+ mem_true16_map_rgb_color,
+ mem_true16_map_color_rgb,
+ mem_true16_fill_rectangle,
+ mem_true16_copy_mono,
+ mem_true16_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ mem_default_strip_copy_rop2,
+ mem_get_bits_rectangle
+};
/* Map a r-g-b color to a color index. */
static gx_color_index
diff --git a/base/gdevm2.c b/base/gdevm2.c
index 863811b8..107e0700 100644
--- a/base/gdevm2.c
+++ b/base/gdevm2.c
@@ -31,10 +31,20 @@ declare_mem_procs(mem_mapped2_copy_mono, mem_mapped2_copy_color, mem_mapped2_fil
/* The device descriptor. */
const gx_device_memory mem_mapped2_device =
-mem_device("image2", 2, 0,
- mem_mapped_map_rgb_color, mem_mapped_map_color_rgb,
- mem_mapped2_copy_mono, mem_mapped2_copy_color,
- mem_mapped2_fill_rectangle, mem_gray_strip_copy_rop);
+ mem_device("image2", 2, 0, mem_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_2 =
+{
+ mem_mapped_map_rgb_color,
+ mem_mapped_map_color_rgb,
+ mem_mapped2_fill_rectangle,
+ mem_mapped2_copy_mono,
+ mem_mapped2_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ mem_gray_strip_copy_rop2,
+ mem_get_bits_rectangle
+};
/* Convert x coordinate to byte offset in scan line. */
#undef x_to_byte
@@ -157,9 +167,9 @@ mem_mapped2_copy_color(gx_device * dev,
/* Use monobit copy_mono. */
/* Patch the width in the device temporarily. */
dev->width <<= 1;
- code = (*dev_proc(&mem_mono_device, copy_mono))
- (dev, base, sourcex << 1, sraster, id,
- x << 1, y, w << 1, h, (gx_color_index) 0, (gx_color_index) 1);
+ code = mem_mono_copy_mono(dev, base, sourcex << 1, sraster, id,
+ x << 1, y, w << 1, h,
+ (gx_color_index) 0, (gx_color_index) 1);
/* Restore the correct width. */
dev->width >>= 1;
return code;
@@ -177,12 +187,20 @@ declare_mem_procs(mem2_word_copy_mono, mem2_word_copy_color, mem2_word_fill_rect
/* Here is the device descriptor. */
const gx_device_memory mem_mapped2_word_device =
-mem_full_device("image2w", 2, 0, mem_open,
- mem_mapped_map_rgb_color, mem_mapped_map_color_rgb,
- mem2_word_copy_mono, mem2_word_copy_color,
- mem2_word_fill_rectangle, gx_default_map_cmyk_color,
- gx_default_strip_tile_rectangle, gx_no_strip_copy_rop,
- mem_word_get_bits_rectangle);
+ mem_device("image2w", 2, 0, mem_word_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_2w =
+{
+ mem_mapped_map_rgb_color,
+ mem_mapped_map_color_rgb,
+ mem2_word_fill_rectangle,
+ mem2_word_copy_mono,
+ mem2_word_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ gx_no_strip_copy_rop2,
+ mem_word_get_bits_rectangle
+};
/* Fill a rectangle with a color. */
static int
@@ -238,7 +256,7 @@ mem2_word_copy_color(gx_device * dev,
/* Use monobit copy_mono. */
/* Patch the width in the device temporarily. */
dev->width <<= 1;
- code = (*dev_proc(&mem_mono_word_device, copy_mono))
+ code = gdev_mem_word_functions_for_bits(1)->copy_mono
(dev, base, sourcex << 1, sraster, id,
x << 1, y, w << 1, h, (gx_color_index) 0, (gx_color_index) 1);
/* Restore the correct width. */
diff --git a/base/gdevm24.c b/base/gdevm24.c
index 332279b6..913f0028 100644
--- a/base/gdevm24.c
+++ b/base/gdevm24.c
@@ -20,7 +20,7 @@
#include "gxdevmem.h" /* semi-public definitions */
#include "gdevmem.h" /* private definitions */
-#define mem_true24_strip_copy_rop mem_gray8_rgb24_strip_copy_rop
+#define mem_true24_strip_copy_rop2 mem_gray8_rgb24_strip_copy_rop2
/*
* Define whether to use the library's memset.
@@ -58,12 +58,20 @@ static dev_proc_copy_alpha(mem_true24_copy_alpha);
/* The device descriptor. */
const gx_device_memory mem_true24_device =
-mem_full_alpha_device("image24", 24, 0, mem_open,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb,
- mem_true24_copy_mono, mem_true24_copy_color, mem_true24_fill_rectangle,
- gx_default_map_cmyk_color, mem_true24_copy_alpha,
- gx_default_strip_tile_rectangle, mem_true24_strip_copy_rop,
- mem_get_bits_rectangle);
+ mem_device("image24", 24, 0, mem_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_24 =
+{
+ gx_default_rgb_map_rgb_color,
+ gx_default_rgb_map_color_rgb,
+ mem_true24_fill_rectangle,
+ mem_true24_copy_mono,
+ mem_true24_copy_color,
+ mem_true24_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ mem_true24_strip_copy_rop2,
+ mem_get_bits_rectangle
+};
/* Convert x coordinate to byte offset in scan line. */
#undef x_to_byte
@@ -551,11 +559,20 @@ declare_mem_procs(mem24_word_copy_mono, mem24_word_copy_color, mem24_word_fill_r
/* Here is the device descriptor. */
const gx_device_memory mem_true24_word_device =
-mem_full_device("image24w", 24, 0, mem_open,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb,
- mem24_word_copy_mono, mem24_word_copy_color, mem24_word_fill_rectangle,
- gx_default_map_cmyk_color, gx_default_strip_tile_rectangle,
- gx_no_strip_copy_rop, mem_word_get_bits_rectangle);
+ mem_device("image24w", 24, 0, mem_word_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_24w =
+{
+ gx_default_rgb_map_rgb_color,
+ gx_default_rgb_map_color_rgb,
+ mem24_word_fill_rectangle,
+ mem24_word_copy_mono,
+ mem24_word_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ gx_no_strip_copy_rop2,
+ mem_word_get_bits_rectangle
+};
/* Fill a rectangle with a color. */
static int
diff --git a/base/gdevm32.c b/base/gdevm32.c
index 414831c1..7fb0746a 100644
--- a/base/gdevm32.c
+++ b/base/gdevm32.c
@@ -30,11 +30,20 @@ declare_mem_procs(mem_true32_copy_mono, mem_true32_copy_color, mem_true32_fill_r
/* The device descriptor. */
const gx_device_memory mem_true32_device =
-mem_full_device("image32", 24, 8, mem_open,
- gx_default_map_rgb_color, gx_default_map_color_rgb,
- mem_true32_copy_mono, mem_true32_copy_color, mem_true32_fill_rectangle,
- gx_default_cmyk_map_cmyk_color, gx_default_strip_tile_rectangle,
- mem_default_strip_copy_rop, mem_get_bits_rectangle);
+ mem_device("image32", 24, 8, mem_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_32 =
+{
+ gx_default_map_rgb_color,
+ gx_default_map_color_rgb,
+ mem_true32_fill_rectangle,
+ mem_true32_copy_mono,
+ mem_true32_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ mem_default_strip_copy_rop2,
+ mem_get_bits_rectangle
+};
/* Convert x coordinate to byte offset in scan line. */
#undef x_to_byte
@@ -248,11 +257,20 @@ declare_mem_procs(mem32_word_copy_mono, mem32_word_copy_color, mem32_word_fill_r
/* Here is the device descriptor. */
const gx_device_memory mem_true32_word_device =
-mem_full_device("image32w", 24, 8, mem_open,
- gx_default_map_rgb_color, gx_default_map_color_rgb,
- mem32_word_copy_mono, mem32_word_copy_color, mem32_word_fill_rectangle,
- gx_default_cmyk_map_cmyk_color, gx_default_strip_tile_rectangle,
- gx_no_strip_copy_rop, mem_word_get_bits_rectangle);
+ mem_device("image32w", 24, 8, mem_word_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_32w =
+{
+ gx_default_map_rgb_color,
+ gx_default_map_color_rgb,
+ mem32_word_fill_rectangle,
+ mem32_word_copy_mono,
+ mem32_word_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ gx_no_strip_copy_rop2,
+ mem_word_get_bits_rectangle
+};
/* Fill a rectangle with a color. */
static int
diff --git a/base/gdevm4.c b/base/gdevm4.c
index 51940a5b..d4832eec 100644
--- a/base/gdevm4.c
+++ b/base/gdevm4.c
@@ -31,10 +31,20 @@ declare_mem_procs(mem_mapped4_copy_mono, mem_mapped4_copy_color, mem_mapped4_fil
/* The device descriptor. */
const gx_device_memory mem_mapped4_device =
-mem_device("image4", 3, 1,
- mem_mapped_map_rgb_color, mem_mapped_map_color_rgb,
- mem_mapped4_copy_mono, mem_mapped4_copy_color, mem_mapped4_fill_rectangle,
- mem_gray_strip_copy_rop);
+ mem_device("image4", 3, 1, mem_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_4 =
+{
+ mem_mapped_map_rgb_color,
+ mem_mapped_map_color_rgb,
+ mem_mapped4_fill_rectangle,
+ mem_mapped4_copy_mono,
+ mem_mapped4_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ mem_gray_strip_copy_rop2,
+ mem_get_bits_rectangle
+};
/* Convert x coordinate to byte offset in scan line. */
#undef x_to_byte
@@ -216,9 +226,9 @@ mem_mapped4_copy_color(gx_device * dev,
/* Patch the width in the device temporarily. */
dev->width <<= 2;
- code = (*dev_proc(&mem_mono_device, copy_mono))
- (dev, base, sourcex << 2, sraster, id,
- x << 2, y, w << 2, h, (gx_color_index) 0, (gx_color_index) 1);
+ code = mem_mono_copy_mono(dev, base, sourcex << 2, sraster, id,
+ x << 2, y, w << 2, h,
+ (gx_color_index) 0, (gx_color_index) 1);
/* Restore the correct width. */
dev->width >>= 2;
return code;
@@ -236,11 +246,20 @@ declare_mem_procs(mem4_word_copy_mono, mem4_word_copy_color, mem4_word_fill_rect
/* Here is the device descriptor. */
const gx_device_memory mem_mapped4_word_device =
-mem_full_device("image4w", 4, 0, mem_open,
- mem_mapped_map_rgb_color, mem_mapped_map_color_rgb,
- mem4_word_copy_mono, mem4_word_copy_color, mem4_word_fill_rectangle,
- gx_default_map_cmyk_color, gx_default_strip_tile_rectangle,
- gx_no_strip_copy_rop, mem_word_get_bits_rectangle);
+ mem_device("image4w", 4, 0, mem_word_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_4w =
+{
+ mem_mapped_map_rgb_color,
+ mem_mapped_map_color_rgb,
+ mem4_word_fill_rectangle,
+ mem4_word_copy_mono,
+ mem4_word_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ gx_no_strip_copy_rop2,
+ mem_word_get_bits_rectangle
+};
/* Fill a rectangle with a color. */
static int
@@ -295,7 +314,7 @@ mem4_word_copy_color(gx_device * dev,
/* Use monobit copy_mono. */
/* Patch the width in the device temporarily. */
dev->width <<= 2;
- code = (*dev_proc(&mem_mono_word_device, copy_mono))
+ code = gdev_mem_word_functions_for_bits(1)->copy_mono
(dev, base, sourcex << 2, sraster, id,
x << 2, y, w << 2, h, (gx_color_index) 0, (gx_color_index) 1);
/* Restore the correct width. */
diff --git a/base/gdevm40.c b/base/gdevm40.c
index 0946a033..31425f1a 100644
--- a/base/gdevm40.c
+++ b/base/gdevm40.c
@@ -46,12 +46,20 @@ declare_mem_procs(mem_true40_copy_mono, mem_true40_copy_color, mem_true40_fill_r
/* The device descriptor. */
const gx_device_memory mem_true40_device =
-mem_full_alpha_device("image40", 40, 0, mem_open,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb,
- mem_true40_copy_mono, mem_true40_copy_color, mem_true40_fill_rectangle,
- gx_default_map_cmyk_color, gx_default_copy_alpha,
- gx_default_strip_tile_rectangle, mem_default_strip_copy_rop,
- mem_get_bits_rectangle);
+ mem_device("image40", 40, 0, mem_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_40 =
+{
+ gx_default_rgb_map_rgb_color,
+ gx_default_rgb_map_color_rgb,
+ mem_true40_fill_rectangle,
+ mem_true40_copy_mono,
+ mem_true40_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ mem_default_strip_copy_rop2,
+ mem_get_bits_rectangle
+};
/* Convert x coordinate to byte offset in scan line. */
#undef x_to_byte
@@ -416,11 +424,20 @@ declare_mem_procs(mem40_word_copy_mono, mem40_word_copy_color, mem40_word_fill_r
/* Here is the device descriptor. */
const gx_device_memory mem_true40_word_device =
-mem_full_device("image40w", 40, 0, mem_open,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb,
- mem40_word_copy_mono, mem40_word_copy_color, mem40_word_fill_rectangle,
- gx_default_map_cmyk_color, gx_default_strip_tile_rectangle,
- gx_no_strip_copy_rop, mem_word_get_bits_rectangle);
+ mem_device("image40w", 40, 0, mem_word_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_40w =
+{
+ gx_default_rgb_map_rgb_color,
+ gx_default_rgb_map_color_rgb,
+ mem40_word_fill_rectangle,
+ mem40_word_copy_mono,
+ mem40_word_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ gx_no_strip_copy_rop2,
+ mem_word_get_bits_rectangle
+};
/* Fill a rectangle with a color. */
static int
diff --git a/base/gdevm48.c b/base/gdevm48.c
index d951ccfa..0a3d8a29 100644
--- a/base/gdevm48.c
+++ b/base/gdevm48.c
@@ -46,12 +46,20 @@ declare_mem_procs(mem_true48_copy_mono, mem_true48_copy_color, mem_true48_fill_r
/* The device descriptor. */
const gx_device_memory mem_true48_device =
-mem_full_alpha_device("image48", 48, 0, mem_open,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb,
- mem_true48_copy_mono, mem_true48_copy_color, mem_true48_fill_rectangle,
- gx_default_map_cmyk_color, gx_default_copy_alpha,
- gx_default_strip_tile_rectangle, mem_default_strip_copy_rop,
- mem_get_bits_rectangle);
+ mem_device("image48", 48, 0, mem_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_48 =
+{
+ gx_default_rgb_map_rgb_color,
+ gx_default_rgb_map_color_rgb,
+ mem_true48_fill_rectangle,
+ mem_true48_copy_mono,
+ mem_true48_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ mem_default_strip_copy_rop2,
+ mem_get_bits_rectangle
+};
/* Convert x coordinate to byte offset in scan line. */
#undef x_to_byte
@@ -385,11 +393,20 @@ declare_mem_procs(mem48_word_copy_mono, mem48_word_copy_color, mem48_word_fill_r
/* Here is the device descriptor. */
const gx_device_memory mem_true48_word_device =
-mem_full_device("image48w", 48, 0, mem_open,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb,
- mem48_word_copy_mono, mem48_word_copy_color, mem48_word_fill_rectangle,
- gx_default_map_cmyk_color, gx_default_strip_tile_rectangle,
- gx_no_strip_copy_rop, mem_word_get_bits_rectangle);
+ mem_device("image48w", 48, 0, mem_word_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_48w =
+{
+ gx_default_rgb_map_rgb_color,
+ gx_default_rgb_map_color_rgb,
+ mem48_word_fill_rectangle,
+ mem48_word_copy_mono,
+ mem48_word_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ gx_no_strip_copy_rop2,
+ mem_word_get_bits_rectangle
+};
/* Fill a rectangle with a color. */
static int
diff --git a/base/gdevm56.c b/base/gdevm56.c
index 72774fb9..70cfd942 100644
--- a/base/gdevm56.c
+++ b/base/gdevm56.c
@@ -46,12 +46,20 @@ declare_mem_procs(mem_true56_copy_mono, mem_true56_copy_color, mem_true56_fill_r
/* The device descriptor. */
const gx_device_memory mem_true56_device =
-mem_full_alpha_device("image56", 56, 0, mem_open,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb,
- mem_true56_copy_mono, mem_true56_copy_color, mem_true56_fill_rectangle,
- gx_default_map_cmyk_color, gx_default_copy_alpha,
- gx_default_strip_tile_rectangle, mem_default_strip_copy_rop,
- mem_get_bits_rectangle);
+ mem_device("image56", 56, 0, mem_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_56 =
+{
+ gx_default_rgb_map_rgb_color,
+ gx_default_rgb_map_color_rgb,
+ mem_true56_fill_rectangle,
+ mem_true56_copy_mono,
+ mem_true56_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ mem_default_strip_copy_rop2,
+ mem_get_bits_rectangle
+};
/* Convert x coordinate to byte offset in scan line. */
#undef x_to_byte
@@ -440,11 +448,20 @@ declare_mem_procs(mem56_word_copy_mono, mem56_word_copy_color, mem56_word_fill_r
/* Here is the device descriptor. */
const gx_device_memory mem_true56_word_device =
-mem_full_device("image56w", 56, 0, mem_open,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb,
- mem56_word_copy_mono, mem56_word_copy_color, mem56_word_fill_rectangle,
- gx_default_map_cmyk_color, gx_default_strip_tile_rectangle,
- gx_no_strip_copy_rop, mem_word_get_bits_rectangle);
+ mem_device("image56w", 56, 0, mem_word_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_56w =
+{
+ gx_default_rgb_map_rgb_color,
+ gx_default_rgb_map_color_rgb,
+ mem56_word_fill_rectangle,
+ mem56_word_copy_mono,
+ mem56_word_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ gx_no_strip_copy_rop2,
+ mem_word_get_bits_rectangle
+};
/* Fill a rectangle with a color. */
static int
diff --git a/base/gdevm64.c b/base/gdevm64.c
index 899713ef..a66c3c16 100644
--- a/base/gdevm64.c
+++ b/base/gdevm64.c
@@ -46,12 +46,20 @@ declare_mem_procs(mem_true64_copy_mono, mem_true64_copy_color, mem_true64_fill_r
/* The device descriptor. */
const gx_device_memory mem_true64_device =
-mem_full_alpha_device("image64", 64, 0, mem_open,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb,
- mem_true64_copy_mono, mem_true64_copy_color, mem_true64_fill_rectangle,
- gx_default_map_cmyk_color, gx_default_copy_alpha,
- gx_default_strip_tile_rectangle, mem_default_strip_copy_rop,
- mem_get_bits_rectangle);
+ mem_device("image64", 64, 0, mem_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_64 =
+{
+ gx_default_rgb_map_rgb_color,
+ gx_default_rgb_map_color_rgb,
+ mem_true64_fill_rectangle,
+ mem_true64_copy_mono,
+ mem_true64_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ mem_default_strip_copy_rop2,
+ mem_get_bits_rectangle
+};
/* Convert x coordinate to byte offset in scan line. */
#undef x_to_byte
@@ -343,11 +351,20 @@ declare_mem_procs(mem64_word_copy_mono, mem64_word_copy_color, mem64_word_fill_r
/* Here is the device descriptor. */
const gx_device_memory mem_true64_word_device =
-mem_full_device("image64w", 64, 0, mem_open,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb,
- mem64_word_copy_mono, mem64_word_copy_color, mem64_word_fill_rectangle,
- gx_default_map_cmyk_color, gx_default_strip_tile_rectangle,
- gx_no_strip_copy_rop, mem_word_get_bits_rectangle);
+ mem_device("image64w", 64, 0, mem_word_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_64w =
+{
+ gx_default_rgb_map_rgb_color,
+ gx_default_rgb_map_color_rgb,
+ mem64_word_fill_rectangle,
+ mem64_word_copy_mono,
+ mem64_word_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ gx_no_strip_copy_rop2,
+ mem_word_get_bits_rectangle
+};
/* Fill a rectangle with a color. */
static int
diff --git a/base/gdevm8.c b/base/gdevm8.c
index 65013507..6717c585 100644
--- a/base/gdevm8.c
+++ b/base/gdevm8.c
@@ -20,7 +20,7 @@
#include "gxdevmem.h" /* semi-public definitions */
#include "gdevmem.h" /* private definitions */
-#define mem_gray8_strip_copy_rop mem_gray8_rgb24_strip_copy_rop
+#define mem_gray8_strip_copy_rop2 mem_gray8_rgb24_strip_copy_rop2
/* ================ Standard (byte-oriented) device ================ */
@@ -32,10 +32,20 @@ declare_mem_procs(mem_mapped8_copy_mono, mem_mapped8_copy_color, mem_mapped8_fil
/* The device descriptor. */
const gx_device_memory mem_mapped8_device =
-mem_device("image8", 8, 0,
- mem_mapped_map_rgb_color, mem_mapped_map_color_rgb,
- mem_mapped8_copy_mono, mem_mapped8_copy_color, mem_mapped8_fill_rectangle,
- mem_gray8_strip_copy_rop);
+ mem_device("image8", 8, 0, mem_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_8 =
+{
+ mem_mapped_map_rgb_color,
+ mem_mapped_map_color_rgb,
+ mem_mapped8_fill_rectangle,
+ mem_mapped8_copy_mono,
+ mem_mapped8_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ mem_gray8_strip_copy_rop2,
+ mem_get_bits_rectangle
+};
/* Convert x coordinate to byte offset in scan line. */
#undef x_to_byte
@@ -330,11 +340,20 @@ declare_mem_procs(mem8_word_copy_mono, mem8_word_copy_color, mem8_word_fill_rect
/* Here is the device descriptor. */
const gx_device_memory mem_mapped8_word_device =
-mem_full_device("image8w", 8, 0, mem_open,
- mem_mapped_map_rgb_color, mem_mapped_map_color_rgb,
- mem8_word_copy_mono, mem8_word_copy_color, mem8_word_fill_rectangle,
- gx_default_map_cmyk_color, gx_default_strip_tile_rectangle,
- gx_no_strip_copy_rop, mem_word_get_bits_rectangle);
+ mem_device("image8w", 8, 0, mem_word_dev_initialize_device_procs);
+
+const gdev_mem_functions gdev_mem_fns_8w =
+{
+ gx_default_rgb_map_rgb_color,
+ gx_default_rgb_map_color_rgb,
+ mem8_word_fill_rectangle,
+ mem8_word_copy_mono,
+ mem8_word_copy_color,
+ gx_default_copy_alpha,
+ gx_default_strip_tile_rectangle,
+ gx_no_strip_copy_rop2,
+ mem_word_get_bits_rectangle
+};
/* Fill a rectangle with a color. */
static int
diff --git a/base/gdevmem.c b/base/gdevmem.c
index 68e7e857..aa47dc95 100644
--- a/base/gdevmem.c
+++ b/base/gdevmem.c
@@ -122,6 +122,44 @@ gdev_mem_word_device_for_bits(int bits_per_pixel)
mem_word_devices[bits_per_pixel]);
}
+static const gdev_mem_functions *mem_fns[65] = {
+ NULL, &gdev_mem_fns_1, &gdev_mem_fns_2, NULL,
+ &gdev_mem_fns_4, NULL, NULL, NULL,
+ &gdev_mem_fns_8, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ &gdev_mem_fns_16, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ &gdev_mem_fns_24, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ &gdev_mem_fns_32, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ &gdev_mem_fns_40, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ &gdev_mem_fns_48, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ &gdev_mem_fns_56, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ &gdev_mem_fns_64
+};
+
+const gdev_mem_functions *
+gdev_mem_functions_for_bits(int bits_per_pixel)
+{
+ return ((uint)bits_per_pixel > 64 ? NULL : mem_fns[bits_per_pixel]);
+}
+
+static const gdev_mem_functions *mem_word_fns[65] = {
+ NULL, &gdev_mem_fns_1, &gdev_mem_fns_2w, NULL,
+ &gdev_mem_fns_4w, NULL, NULL, NULL,
+ &gdev_mem_fns_8w, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ &gdev_mem_fns_24w, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ &gdev_mem_fns_32w, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ &gdev_mem_fns_40w, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ &gdev_mem_fns_48w, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ &gdev_mem_fns_56w, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
+ &gdev_mem_fns_64w
+};
+
+const gdev_mem_functions *
+gdev_mem_word_functions_for_bits(int bits_per_pixel)
+{
+ return ((uint)bits_per_pixel > 64 ? NULL : mem_word_fns[bits_per_pixel]);
+}
+
/* Test whether a device is a memory device */
bool
gs_device_is_memory(const gx_device * dev)
@@ -130,17 +168,7 @@ gs_device_is_memory(const gx_device * dev)
* We use the draw_thin_line procedure to mark memory devices.
* See gdevmem.h.
*/
- int bits_per_pixel = dev->color_info.depth;
- const gx_device_memory *mdproto;
-
- if (dev->is_planar)
- bits_per_pixel /= dev->color_info.num_components;
-
- mdproto = gdev_mem_device_for_bits(bits_per_pixel);
- if (mdproto != 0 && dev_proc(dev, draw_thin_line) == dev_proc(mdproto, draw_thin_line))
- return true;
- mdproto = gdev_mem_word_device_for_bits(bits_per_pixel);
- return (mdproto != 0 && dev_proc(dev, draw_thin_line) == dev_proc(mdproto, draw_thin_line));
+ return (dev_proc(dev, draw_thin_line) == mem_draw_thin_line);
}
/* Make a memory device. */
@@ -149,8 +177,9 @@ void
gs_make_mem_device(gx_device_memory * dev, const gx_device_memory * mdproto,
gs_memory_t * mem, int page_device, gx_device * target)
{
- gx_device_init((gx_device *) dev, (const gx_device *)mdproto,
- mem, true);
+ /* Can never fail */
+ (void)gx_device_init((gx_device *) dev, (const gx_device *)mdproto,
+ mem, true);
dev->stype = &st_device_memory;
switch (page_device) {
case -1:
@@ -297,8 +326,10 @@ void
gs_make_mem_mono_device(gx_device_memory * dev, gs_memory_t * mem,
gx_device * target)
{
- gx_device_init((gx_device *)dev, (const gx_device *)&mem_mono_device,
- mem, true);
+ /* Can never fail */
+ (void)gx_device_init((gx_device *)dev,
+ (const gx_device *)&mem_mono_device,
+ mem, true);
set_dev_proc(dev, get_page_device, gx_default_get_page_device);
gx_device_set_target((gx_device_forward *)dev, target);
dev->raster = gx_device_raster((gx_device *)dev, 1);
@@ -624,7 +655,7 @@ mem_close(gx_device * dev)
#define chunk byte
int
mem_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
- gs_get_bits_params_t * params, gs_int_rect ** unread)
+ gs_get_bits_params_t * params)
{
gx_device_memory * const mdev = (gx_device_memory *)dev;
gs_get_bits_options_t options = params->options;
@@ -720,7 +751,7 @@ mem_swap_byte_rect(byte * base, uint raster, int x, int w, int h, bool store)
/* Copy a word-oriented rectangle to the client, swapping bytes as needed. */
int
mem_word_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
- gs_get_bits_params_t * params, gs_int_rect ** unread)
+ gs_get_bits_params_t * params)
{
gx_device_memory * const mdev = (gx_device_memory *)dev;
byte *src;
@@ -736,8 +767,7 @@ mem_word_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
if (w <= 0 || h <= 0) {
/*
* It's easiest to just keep going with an empty rectangle.
- * We pass the original rectangle to mem_get_bits_rectangle,
- * so unread will be filled in correctly.
+ * We pass the original rectangle to mem_get_bits_rectangle.
*/
x = y = w = h = 0;
}
@@ -749,7 +779,7 @@ mem_word_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
src = scan_line_base(mdev, y);
mem_swap_byte_rect(src, dev_raster, bit_x, bit_w, h, false);
- code = mem_get_bits_rectangle(dev, prect, params, unread);
+ code = mem_get_bits_rectangle(dev, prect, params);
mem_swap_byte_rect(src, dev_raster, bit_x, bit_w, h, false);
return code;
}
@@ -827,11 +857,20 @@ mem_mapped_map_color_rgb(gx_device * dev, gx_color_index color,
gx_color_value prgb[3])
{
gx_device_memory * const mdev = (gx_device_memory *)dev;
- const byte *pptr = mdev->palette.data + (int)color * 3;
+ const byte *pptr = mdev->palette.data;
- prgb[0] = gx_color_value_from_byte(pptr[0]);
- prgb[1] = gx_color_value_from_byte(pptr[1]);
- prgb[2] = gx_color_value_from_byte(pptr[2]);
+ if (pptr == NULL) {
+ color = color * gx_max_color_value / ((1<<mdev->color_info.depth)-1);
+ prgb[0] = color;
+ prgb[1] = color;
+ prgb[2] = color;
+ } else {
+ pptr += (int)color * 3;
+
+ prgb[0] = gx_color_value_from_byte(pptr[0]);
+ prgb[1] = gx_color_value_from_byte(pptr[1]);
+ prgb[2] = gx_color_value_from_byte(pptr[2]);
+ }
return 0;
}
@@ -848,3 +887,73 @@ mem_draw_thin_line(gx_device *dev, fixed fx0, fixed fy0, fixed fx1, fixed fy1,
return gx_default_draw_thin_line(dev, fx0, fy0, fx1, fy1, pdcolor, lop,
adjustx, adjusty);
}
+
+void mem_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, get_initial_matrix, mem_get_initial_matrix);
+ set_dev_proc(dev, sync_output, gx_default_sync_output);
+ set_dev_proc(dev, output_page, gx_default_output_page);
+ set_dev_proc(dev, close_device, mem_close);
+ set_dev_proc(dev, get_params, gx_default_get_params);
+ set_dev_proc(dev, put_params, gx_default_put_params);
+ set_dev_proc(dev, get_page_device, gx_forward_get_page_device);
+ set_dev_proc(dev, get_alpha_bits, gx_default_get_alpha_bits);
+ set_dev_proc(dev, fill_path, gx_default_fill_path);
+ set_dev_proc(dev, stroke_path, gx_default_stroke_path);
+ set_dev_proc(dev, fill_mask, gx_default_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, gx_default_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, gx_default_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, gx_default_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, mem_draw_thin_line);
+ set_dev_proc(dev, get_clipping_box, gx_default_get_clipping_box);
+ set_dev_proc(dev, begin_typed_image, gx_default_begin_typed_image);
+ set_dev_proc(dev, composite, gx_default_composite);
+ set_dev_proc(dev, get_hardware_params, gx_default_get_hardware_params);
+ set_dev_proc(dev, text_begin, gx_default_text_begin);
+ set_dev_proc(dev, transform_pixel_region, mem_transform_pixel_region);
+
+ /* Defaults that may well get overridden. */
+ set_dev_proc(dev, open_device, mem_open);
+ set_dev_proc(dev, copy_alpha, gx_default_copy_alpha);
+ set_dev_proc(dev, map_cmyk_color, gx_default_map_cmyk_color);
+ set_dev_proc(dev, strip_tile_rectangle, gx_default_strip_tile_rectangle);
+ set_dev_proc(dev, get_bits_rectangle, mem_get_bits_rectangle);
+}
+
+void mem_dev_initialize_device_procs(gx_device *dev)
+{
+ int depth = dev->color_info.depth;
+ const gdev_mem_functions *fns;
+
+ if (dev->is_planar)
+ depth /= dev->color_info.num_components;
+ fns = gdev_mem_functions_for_bits(depth);
+
+ mem_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_rgb_color, fns->map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, fns->map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, fns->fill_rectangle);
+ set_dev_proc(dev, copy_mono, fns->copy_mono);
+ set_dev_proc(dev, copy_color, fns->copy_color);
+ set_dev_proc(dev, copy_alpha, fns->copy_alpha);
+ set_dev_proc(dev, strip_copy_rop2, fns->strip_copy_rop2);
+ set_dev_proc(dev, strip_tile_rectangle, fns->strip_tile_rectangle);
+}
+
+void mem_word_dev_initialize_device_procs(gx_device *dev)
+{
+ const gdev_mem_functions *fns =
+ gdev_mem_word_functions_for_bits(dev->color_info.depth);
+
+ mem_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_rgb_color, fns->map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, fns->map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, fns->fill_rectangle);
+ set_dev_proc(dev, copy_mono, fns->copy_mono);
+ set_dev_proc(dev, copy_color, fns->copy_color);
+ set_dev_proc(dev, copy_alpha, fns->copy_alpha);
+ set_dev_proc(dev, strip_copy_rop2, fns->strip_copy_rop2);
+ set_dev_proc(dev, strip_tile_rectangle, fns->strip_tile_rectangle);
+}
diff --git a/base/gdevmem.h b/base/gdevmem.h
index 71db0797..ef2b7c60 100644
--- a/base/gdevmem.h
+++ b/base/gdevmem.h
@@ -101,7 +101,6 @@ dev_proc_get_bits_rectangle(mem_word_get_bits_rectangle);
dev_proc_map_rgb_color(mem_mapped_map_rgb_color);
dev_proc_map_color_rgb(mem_mapped_map_color_rgb);
/* Default implementations */
-dev_proc_strip_copy_rop(mem_default_strip_copy_rop);
dev_proc_strip_copy_rop2(mem_default_strip_copy_rop2);
dev_proc_transform_pixel_region(mem_transform_pixel_region);
@@ -120,8 +119,13 @@ dev_proc_transform_pixel_region(mem_transform_pixel_region);
#define max_value_rgb(rgb_depth, gray_depth)\
(rgb_depth >= 8 ? 255 : rgb_depth == 4 ? 15 : rgb_depth == 2 ? 3 :\
rgb_depth == 1 ? 1 : (1 << gray_depth) - 1)
-#define mem_full_alpha_device_hl(name, rgb_depth, gray_depth, open, map_rgb_color, map_color_rgb, copy_mono, copy_color, fill_rectangle, map_cmyk_color, copy_alpha, strip_tile_rectangle, strip_copy_rop, get_bits_rectangle, fill_rectangle_hl_color)\
-{ std_device_dci_body(gx_device_memory, 0, name,\
+
+void mem_initialize_device_procs(gx_device *dev);
+void mem_dev_initialize_device_procs(gx_device *dev);
+void mem_word_dev_initialize_device_procs(gx_device *dev);
+
+#define mem_device(name, rgb_depth, gray_depth, initialize)\
+{ std_device_dci_body(gx_device_memory, initialize, name,\
0, 0, 72, 72,\
(rgb_depth ? 3 : 0) + (gray_depth ? 1 : 0), /* num_components */\
rgb_depth + gray_depth, /* depth */\
@@ -130,110 +134,10 @@ dev_proc_transform_pixel_region(mem_transform_pixel_region);
max_value_gray(rgb_depth, gray_depth) + 1, /* dither_grays */\
max_value_rgb(rgb_depth, gray_depth) + 1 /* dither_colors */\
),\
- { open, /* differs */\
- mem_get_initial_matrix,\
- gx_default_sync_output,\
- gx_default_output_page,\
- mem_close,\
- map_rgb_color, /* differs */\
- map_color_rgb, /* differs */\
- fill_rectangle, /* differs */\
- gx_default_tile_rectangle,\
- copy_mono, /* differs */\
- copy_color, /* differs */\
- gx_default_draw_line,\
- gx_default_get_bits,\
- gx_default_get_params,\
- gx_default_put_params,\
- map_cmyk_color, /* differs */\
- gx_forward_get_xfont_procs,\
- gx_forward_get_xfont_device,\
- gx_default_map_rgb_alpha_color,\
- gx_forward_get_page_device,\
- gx_default_get_alpha_bits, /* default is no alpha */\
- copy_alpha, /* differs */\
- gx_default_get_band,\
- gx_default_copy_rop,\
- gx_default_fill_path,\
- gx_default_stroke_path,\
- gx_default_fill_mask,\
- gx_default_fill_trapezoid,\
- gx_default_fill_parallelogram,\
- gx_default_fill_triangle,\
- mem_draw_thin_line, /* see above */\
- gx_default_begin_image,\
- gx_default_image_data,\
- gx_default_end_image,\
- strip_tile_rectangle, /* differs */\
- strip_copy_rop, /* differs */\
- gx_default_get_clipping_box,\
- gx_default_begin_typed_image,\
- get_bits_rectangle, /* differs */\
- gx_default_map_color_rgb_alpha,\
- gx_default_create_compositor,\
- gx_default_get_hardware_params,\
- gx_default_text_begin,\
- gx_default_finish_copydevice,\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL, /* discard_transparency_layer */\
- NULL, /* get_color_mapping_procs */\
- NULL, /* get_color_comp_index */\
- NULL, /* encode_color */\
- NULL, /* decode_color */\
- NULL, /* pattern_manage */\
- fill_rectangle_hl_color, /* fill_rectangle_hl_color */\
- NULL, /* include_color_space */\
- NULL, /* fill_linear_color_scanline */\
- NULL, /* fill_linear_color_trapezoid */\
- NULL, /* fill_linear_color_triangle */\
- NULL, /* update_spot_equivalent_colors */\
- NULL, /* ret_devn_params */\
- NULL, /* fillpage */\
- NULL, /* push_transparency_state */\
- NULL, /* pop_transparency_state */\
- NULL, /* put_image */\
- NULL, /* dev_spec_op */\
- NULL, /* copy_planes */\
- NULL, /* get_profile */\
- NULL, /* set_graphics_type_tag */\
- NULL, /* strip_copy_rop2 */\
- NULL, /* strip_tile_rect_devn */\
- NULL, /* copy_alpha_hl_color */\
- NULL, /* process_page */\
- mem_transform_pixel_region,\
- NULL, /* fill_stroke_path */\
- },\
+ { 0 },\
0, /* target */\
mem_device_init_private /* see gxdevmem.h */\
}
-#define mem_full_alpha_device(name, rgb_depth, gray_depth, open, map_rgb_color, map_color_rgb, copy_mono, copy_color, fill_rectangle, map_cmyk_color, copy_alpha, strip_tile_rectangle, strip_copy_rop, get_bits_rectangle)\
- mem_full_alpha_device_hl(name, rgb_depth, gray_depth, open, map_rgb_color, map_color_rgb, copy_mono, copy_color, fill_rectangle, map_cmyk_color, copy_alpha, strip_tile_rectangle, strip_copy_rop, get_bits_rectangle, NULL)
-
-#define mem_full_device(name, rgb_depth, gray_depth, open, map_rgb_color, map_color_rgb, copy_mono, copy_color, fill_rectangle, map_cmyk_color, strip_tile_rectangle, strip_copy_rop, get_bits_rectangle)\
- mem_full_alpha_device(name, rgb_depth, gray_depth, open, map_rgb_color,\
- map_color_rgb, copy_mono, copy_color, fill_rectangle,\
- map_cmyk_color, gx_default_copy_alpha,\
- strip_tile_rectangle, strip_copy_rop,\
- get_bits_rectangle)
-#define mem_device(name, rgb_depth, gray_depth, map_rgb_color, map_color_rgb, copy_mono, copy_color, fill_rectangle, strip_copy_rop)\
- mem_full_device(name, rgb_depth, gray_depth, mem_open, map_rgb_color,\
- map_color_rgb, copy_mono, copy_color, fill_rectangle,\
- gx_default_map_cmyk_color, gx_default_strip_tile_rectangle,\
- strip_copy_rop, mem_get_bits_rectangle)
-#define mem_full_device_hl(name, rgb_depth, gray_depth, open, map_rgb_color, map_color_rgb, copy_mono, copy_color, fill_rectangle, map_cmyk_color, strip_tile_rectangle, strip_copy_rop, get_bits_rectangle, fill_rectangle_hl)\
- mem_full_alpha_device_hl(name, rgb_depth, gray_depth, open, map_rgb_color,\
- map_color_rgb, copy_mono, copy_color, fill_rectangle,\
- map_cmyk_color, gx_default_copy_alpha,\
- strip_tile_rectangle, strip_copy_rop,\
- get_bits_rectangle, fill_rectangle_hl)
-#define mem_device_hl(name, rgb_depth, gray_depth, map_rgb_color, map_color_rgb, copy_mono, copy_color, fill_rectangle, strip_copy_rop, fill_rectangle_hl)\
- mem_full_device_hl(name, rgb_depth, gray_depth, mem_open, map_rgb_color,\
- map_color_rgb, copy_mono, copy_color, fill_rectangle,\
- gx_default_map_cmyk_color, gx_default_strip_tile_rectangle,\
- strip_copy_rop, mem_get_bits_rectangle, fill_rectangle_hl)
/* Swap a rectangle of bytes, for converting between word- and */
/* byte-oriented representation. */
@@ -265,10 +169,12 @@ extern const gx_device_memory mem_planar_device;
* We declare the RasterOp implementation procedures here because they are
* referenced in several implementation modules.
*/
-dev_proc_strip_copy_rop(mem_mono_strip_copy_rop);
-dev_proc_strip_copy_rop(mem_mono_strip_copy_rop_dev);
-dev_proc_strip_copy_rop(mem_gray_strip_copy_rop);
-dev_proc_strip_copy_rop(mem_gray8_rgb24_strip_copy_rop);
+dev_proc_strip_copy_rop2(mem_mono_strip_copy_rop2);
+dev_proc_strip_copy_rop2(mem_mono_strip_copy_rop2_dev);
+dev_proc_strip_copy_rop2(mem_gray_strip_copy_rop2);
+dev_proc_strip_copy_rop2(mem_gray8_rgb24_strip_copy_rop2);
+dev_proc_copy_mono(mem_mono_copy_mono);
+dev_proc_fill_rectangle(mem_mono_fill_rectangle);
#if ARCH_IS_BIG_ENDIAN
# define mem_mono_word_device mem_mono_device
diff --git a/base/gdevmpla.c b/base/gdevmpla.c
index d233a132..632610d3 100644
--- a/base/gdevmpla.c
+++ b/base/gdevmpla.c
@@ -37,7 +37,6 @@ static dev_proc_copy_planes(mem_planar_copy_planes);
/* Not static due to an optimized case in tile_clip_fill_rectangle_hl_color*/
static dev_proc_strip_tile_rectangle(mem_planar_strip_tile_rectangle);
static dev_proc_strip_tile_rect_devn(mem_planar_strip_tile_rect_devn);
-static dev_proc_strip_copy_rop(mem_planar_strip_copy_rop);
static dev_proc_strip_copy_rop2(mem_planar_strip_copy_rop2);
static dev_proc_get_bits_rectangle(mem_planar_get_bits_rectangle);
static dev_proc_fill_rectangle_hl_color(mem_planar_fill_rectangle_hl_color);
@@ -94,7 +93,8 @@ gdev_mem_set_planar_interleaved(gx_device_memory * mdev, int num_planes,
int same_depth = planes[0].depth;
gx_color_index covered = 0;
int pi;
- const gx_device_memory *mdproto = gdev_mem_device_for_bits(mdev->color_info.depth);
+ const gdev_mem_functions *fns =
+ gdev_mem_functions_for_bits(mdev->color_info.depth);
if (num_planes < 1 || num_planes > GX_DEVICE_COLOR_MAX_COMPONENTS || num_planes != mdev->color_info.num_components)
return_error(gs_error_rangecheck);
@@ -136,20 +136,20 @@ gdev_mem_set_planar_interleaved(gx_device_memory * mdev, int num_planes,
mem_planar_fill_rectangle_hl_color);
if (num_planes == 1) {
/* For 1 plane, just use a normal device */
- set_dev_proc(mdev, fill_rectangle, dev_proc(mdproto, fill_rectangle));
- set_dev_proc(mdev, copy_mono, dev_proc(mdproto, copy_mono));
- set_dev_proc(mdev, copy_color, dev_proc(mdproto, copy_color));
- set_dev_proc(mdev, copy_alpha, dev_proc(mdproto, copy_alpha));
- set_dev_proc(mdev, strip_tile_rectangle, dev_proc(mdproto, strip_tile_rectangle));
- set_dev_proc(mdev, strip_copy_rop, dev_proc(mdproto, strip_copy_rop));
- set_dev_proc(mdev, strip_copy_rop2, dev_proc(mdproto, strip_copy_rop2));
- set_dev_proc(mdev, get_bits_rectangle, dev_proc(mdproto, get_bits_rectangle));
+ set_dev_proc(mdev, fill_rectangle, fns->fill_rectangle);
+ set_dev_proc(mdev, copy_mono, fns->copy_mono);
+ set_dev_proc(mdev, copy_color, fns->copy_color);
+ set_dev_proc(mdev, copy_alpha, fns->copy_alpha);
+ set_dev_proc(mdev, strip_tile_rectangle, fns->strip_tile_rectangle);
+ set_dev_proc(mdev, strip_copy_rop2, fns->strip_copy_rop2);
+ set_dev_proc(mdev, get_bits_rectangle, fns->get_bits_rectangle);
} else {
/* If we are going out to a separation device or one that has more than
four planes then use the high level color filling procedure. Also
make use of the put_image operation to go from the pdf14 device
directly to the planar buffer. */
- if (num_planes >= 4) {
+ /* Note this is only valid for contone (8 or more bits per component) */
+ if (num_planes >= 4 && mdev->color_info.depth/num_planes >= 8) {
set_dev_proc(mdev, put_image, mem_planar_put_image);
}
set_dev_proc(mdev, fill_rectangle, mem_planar_fill_rectangle);
@@ -175,7 +175,6 @@ gdev_mem_set_planar_interleaved(gx_device_memory * mdev, int num_planes,
set_dev_proc(mdev, copy_alpha, gx_default_copy_alpha);
set_dev_proc(mdev, strip_tile_rectangle, mem_planar_strip_tile_rectangle);
set_dev_proc(mdev, strip_tile_rect_devn, mem_planar_strip_tile_rect_devn);
- set_dev_proc(mdev, strip_copy_rop, mem_planar_strip_copy_rop);
set_dev_proc(mdev, strip_copy_rop2, mem_planar_strip_copy_rop2);
set_dev_proc(mdev, get_bits_rectangle, mem_planar_get_bits_rectangle);
}
@@ -247,7 +246,7 @@ put_image_copy_planes(gx_device * dev, const byte **base_ptr, int sourcex,
gx_device_memory * const mdev = (gx_device_memory *)dev;
int plane_depth;
mem_save_params_t save;
- const gx_device_memory *mdproto;
+ const gdev_mem_functions *fns;
int code = 0;
uchar plane;
@@ -256,19 +255,17 @@ put_image_copy_planes(gx_device * dev, const byte **base_ptr, int sourcex,
{
const byte *base = base_ptr[plane];
plane_depth = mdev->planes[plane].depth;
- mdproto = gdev_mem_device_for_bits(plane_depth);
+ fns = gdev_mem_functions_for_bits(plane_depth);
if (base == NULL) {
/* Blank the plane */
- code = dev_proc(mdproto, fill_rectangle)(dev, x, y, w, h,
+ code = fns->fill_rectangle(dev, x, y, w, h,
(gx_color_index)(dev->color_info.polarity == GX_CINFO_POLARITY_ADDITIVE ? 0 : -1));
} else if (plane_depth == 1)
- code = dev_proc(mdproto, copy_mono)(dev, base, sourcex, sraster, id,
- x, y, w, h,
- (gx_color_index)0,
- (gx_color_index)1);
+ code = fns->copy_mono(dev, base, sourcex, sraster, id,
+ x, y, w, h,
+ (gx_color_index)0, (gx_color_index)1);
else
- code = dev_proc(mdproto, copy_color)(dev, base, sourcex, sraster,
- id, x, y, w, h);
+ fns->copy_color(dev, base, sourcex, sraster, id, x, y, w, h);
mdev->line_ptrs += mdev->height;
}
MEM_RESTORE_PARAMS(mdev, save);
@@ -319,11 +316,12 @@ mem_planar_fill_rectangle_hl_color(gx_device *dev, const gs_fixed_rect *rect,
int plane_depth = mdev->planes[pi].depth;
gx_color_index mask = ((gx_color_index)1 << plane_depth) - 1;
int shift = 16 - plane_depth;
- const gx_device_memory *mdproto = gdev_mem_device_for_bits(plane_depth);
+ const gdev_mem_functions *fns =
+ gdev_mem_functions_for_bits(plane_depth);
MEM_SET_PARAMS(mdev, plane_depth);
- dev_proc(mdproto, fill_rectangle)(dev, x, y, w, h,
- (pdcolor->colors.devn.values[pi]) >> shift & mask);
+ fns->fill_rectangle(dev, x, y, w, h,
+ (pdcolor->colors.devn.values[pi]) >> shift & mask);
mdev->line_ptrs += mdev->height;
}
MEM_RESTORE_PARAMS(mdev, save);
@@ -343,13 +341,12 @@ mem_planar_fill_rectangle(gx_device * dev, int x, int y, int w, int h,
for (pi = 0; pi < mdev->color_info.num_components; ++pi) {
int plane_depth = mdev->planes[pi].depth;
gx_color_index mask = ((gx_color_index)1 << plane_depth) - 1;
- const gx_device_memory *mdproto =
- gdev_mem_device_for_bits(plane_depth);
+ const gdev_mem_functions *fns =
+ gdev_mem_functions_for_bits(plane_depth);
MEM_SET_PARAMS(mdev, plane_depth);
- dev_proc(mdproto, fill_rectangle)(dev, x, y, w, h,
- (color >> mdev->planes[pi].shift) &
- mask);
+ fns->fill_rectangle(dev, x, y, w, h,
+ (color >> mdev->planes[pi].shift) & mask);
mdev->line_ptrs += mdev->height;
}
MEM_RESTORE_PARAMS(mdev, save);
@@ -371,8 +368,8 @@ mem_planar_copy_mono(gx_device * dev, const byte * base, int sourcex,
int plane_depth = mdev->planes[pi].depth;
int shift = mdev->planes[pi].shift;
gx_color_index mask = ((gx_color_index)1 << plane_depth) - 1;
- const gx_device_memory *mdproto =
- gdev_mem_device_for_bits(plane_depth);
+ const gdev_mem_functions *fns =
+ gdev_mem_functions_for_bits(plane_depth);
gx_color_index c0 =
(color0 == gx_no_color_index ? gx_no_color_index :
(color0 >> shift) & mask);
@@ -382,10 +379,10 @@ mem_planar_copy_mono(gx_device * dev, const byte * base, int sourcex,
MEM_SET_PARAMS(mdev, plane_depth);
if (c0 == c1)
- dev_proc(mdproto, fill_rectangle)(dev, x, y, w, h, c0);
+ fns->fill_rectangle(dev, x, y, w, h, c0);
else
- dev_proc(mdproto, copy_mono)
- (dev, base, sourcex, sraster, id, x, y, w, h, c0, c1);
+ fns->copy_mono(dev, base, sourcex, sraster, id,
+ x, y, w, h, c0, c1);
mdev->line_ptrs += mdev->height;
}
MEM_RESTORE_PARAMS(mdev, save);
@@ -406,7 +403,8 @@ mem_planar_copy_color_24to8(gx_device * dev, const byte * base, int sourcex,
byte b[BUF_BYTES];
} buf, buf1, buf2;
mem_save_params_t save;
- const gx_device_memory *mdproto = gdev_mem_device_for_bits(8);
+ dev_proc_copy_color((*copy_color)) =
+ gdev_mem_functions_for_bits(8)->copy_color;
uint plane_raster = bitmap_raster(w<<3);
int br, bw, bh, cx, cy, cw, ch, ix, iy;
@@ -449,14 +447,11 @@ mem_planar_copy_color_24to8(gx_device * dev, const byte * base, int sourcex,
} while (--ix);
source_base += sraster;
}
- dev_proc(mdproto, copy_color)
- (dev, buf.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch);
+ copy_color(dev, buf.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch);
mdev->line_ptrs += mdev->height;
- dev_proc(mdproto, copy_color)
- (dev, buf1.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch);
+ copy_color(dev, buf1.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch);
mdev->line_ptrs += mdev->height;
- dev_proc(mdproto, copy_color)
- (dev, buf2.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch);
+ copy_color(dev, buf2.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch);
mdev->line_ptrs -= 2*mdev->height;
}
}
@@ -485,7 +480,8 @@ mem_planar_copy_color_4to1(gx_device * dev, const byte * base, int sourcex,
byte b[BUF_BYTES];
} buf0, buf1, buf2, buf3;
mem_save_params_t save;
- const gx_device_memory *mdproto = gdev_mem_device_for_bits(1);
+ dev_proc_copy_mono((*copy_mono)) =
+ gdev_mem_fill_functions_for_bits(1)->copy_mono;
uint plane_raster = bitmap_raster(w);
int br, bw, bh, cx, cy, cw, ch, ix, iy;
@@ -632,21 +628,17 @@ loop_entry:
source_base += sraster;
}
}
- dev_proc(mdproto, copy_mono)
- (dev, buf0.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
- (gx_color_index)0, (gx_color_index)1);
+ copy_mono(dev, buf0.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
+ (gx_color_index)0, (gx_color_index)1);
mdev->line_ptrs += mdev->height;
- dev_proc(mdproto, copy_mono)
- (dev, buf1.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
- (gx_color_index)0, (gx_color_index)1);
+ copy_mono(dev, buf1.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
+ (gx_color_index)0, (gx_color_index)1);
mdev->line_ptrs += mdev->height;
- dev_proc(mdproto, copy_mono)
- (dev, buf2.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
- (gx_color_index)0, (gx_color_index)1);
+ copy_mono(dev, buf2.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
+ (gx_color_index)0, (gx_color_index)1);
mdev->line_ptrs += mdev->height;
- dev_proc(mdproto, copy_mono)
- (dev, buf3.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
- (gx_color_index)0, (gx_color_index)1);
+ copy_mono(dev, buf3.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
+ (gx_color_index)0, (gx_color_index)1);
mdev->line_ptrs -= 3*mdev->height;
}
}
@@ -736,7 +728,8 @@ mem_planar_copy_color_4to1(gx_device * dev, const byte * base, int sourcex,
byte b[BUF_BYTES];
} buf0, buf1, buf2, buf3;
mem_save_params_t save;
- const gx_device_memory *mdproto = gdev_mem_device_for_bits(1);
+ dev_proc_copy_mono((*copy_mono)) =
+ gdev_mem_functions_for_bits(1)->copy_mono;
uint plane_raster = bitmap_raster(w);
int br, bw, bh, cx, cy, cw, ch, ix, iy;
@@ -833,21 +826,17 @@ loop_entry:
source_base += sraster;
}
}
- dev_proc(mdproto, copy_mono)
- (dev, buf0.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
- (gx_color_index)0, (gx_color_index)1);
+ copy_mono(dev, buf0.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
+ (gx_color_index)0, (gx_color_index)1);
mdev->line_ptrs += mdev->height;
- dev_proc(mdproto, copy_mono)
- (dev, buf1.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
- (gx_color_index)0, (gx_color_index)1);
+ copy_mono(dev, buf1.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
+ (gx_color_index)0, (gx_color_index)1);
mdev->line_ptrs += mdev->height;
- dev_proc(mdproto, copy_mono)
- (dev, buf2.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
- (gx_color_index)0, (gx_color_index)1);
+ copy_mono(dev, buf2.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
+ (gx_color_index)0, (gx_color_index)1);
mdev->line_ptrs += mdev->height;
- dev_proc(mdproto, copy_mono)
- (dev, buf3.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
- (gx_color_index)0, (gx_color_index)1);
+ copy_mono(dev, buf3.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
+ (gx_color_index)0, (gx_color_index)1);
mdev->line_ptrs -= 3*mdev->height;
}
}
@@ -888,8 +877,8 @@ mem_planar_copy_color(gx_device * dev, const byte * base, int sourcex,
int plane_depth = mdev->planes[pi].depth;
int shift = mdev->planes[pi].shift;
gx_color_index mask = ((gx_color_index)1 << plane_depth) - 1;
- const gx_device_memory *mdproto =
- gdev_mem_device_for_bits(plane_depth);
+ const gdev_mem_functions *fns =
+ gdev_mem_functions_for_bits(plane_depth);
/*
* Divide up the transfer into chunks that can be assembled
* within the fixed-size buffer. This code can be simplified
@@ -960,11 +949,11 @@ mem_planar_copy_color(gx_device * dev, const byte * base, int sourcex,
* defined in terms of copy_mono.
*/
if (plane_depth == 1)
- dev_proc(mdproto, copy_mono)
+ fns->copy_mono
(dev, buf.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch,
(gx_color_index)0, (gx_color_index)1);
else
- dev_proc(mdproto, copy_color)
+ fns->copy_color
(dev, buf.b, 0, br, gx_no_bitmap_id, cx, cy, cw, ch);
}
}
@@ -983,25 +972,23 @@ mem_planar_copy_planes(gx_device * dev, const byte * base, int sourcex,
int x, int y, int w, int h, int plane_height)
{
gx_device_memory * const mdev = (gx_device_memory *)dev;
- int plane_depth;
mem_save_params_t save;
- const gx_device_memory *mdproto;
int code = 0;
uchar plane;
MEM_SAVE_PARAMS(mdev, save);
for (plane = 0; plane < mdev->color_info.num_components; plane++)
{
- plane_depth = mdev->planes[plane].depth;
- mdproto = gdev_mem_device_for_bits(plane_depth);
+ int plane_depth = mdev->planes[plane].depth;
+ const gdev_mem_functions *fns =
+ gdev_mem_functions_for_bits(plane_depth);
if (plane_depth == 1)
- code = dev_proc(mdproto, copy_mono)(dev, base, sourcex, sraster, id,
- x, y, w, h,
- (gx_color_index)0,
- (gx_color_index)1);
+ code = fns->copy_mono(dev, base, sourcex, sraster, id,
+ x, y, w, h,
+ (gx_color_index)0, (gx_color_index)1);
else
- code = dev_proc(mdproto, copy_color)(dev, base, sourcex, sraster,
- id, x, y, w, h);
+ code = fns->copy_color(dev, base, sourcex, sraster,
+ id, x, y, w, h);
base += sraster * plane_height;
mdev->line_ptrs += mdev->height;
}
@@ -1024,8 +1011,8 @@ mem_planar_strip_tile_rect_devn(gx_device * dev, const gx_strip_bitmap * tiles,
int plane_depth = mdev->planes[pi].depth;
gx_color_index mask = ((gx_color_index)1 << plane_depth) - 1;
int shift = 16 - plane_depth;
- const gx_device_memory *mdproto =
- gdev_mem_device_for_bits(plane_depth);
+ const gdev_mem_functions *fns =
+ gdev_mem_functions_for_bits(plane_depth);
gx_color_index c1, c0;
if (pdcolor0->type == gx_dc_type_devn) {
@@ -1045,15 +1032,14 @@ mem_planar_strip_tile_rect_devn(gx_device * dev, const gx_strip_bitmap * tiles,
#endif
MEM_SET_PARAMS(mdev, plane_depth);
if (c0 == c1)
- dev_proc(mdproto, fill_rectangle)(dev, x, y, w, h, c0);
+ fns->fill_rectangle(dev, x, y, w, h, c0);
else {
/*
* Temporarily replace copy_mono in case strip_tile_rectangle is
* defined in terms of it.
*/
- set_dev_proc(dev, copy_mono, dev_proc(mdproto, copy_mono));
- dev_proc(mdproto, strip_tile_rectangle)
- (dev, tiles, x, y, w, h, c0, c1, px, py);
+ set_dev_proc(dev, copy_mono, fns->copy_mono);
+ fns->strip_tile_rectangle(dev, tiles, x, y, w, h, c0, c1, px, py);
}
mdev->line_ptrs += mdev->height;
}
@@ -1081,8 +1067,8 @@ mem_planar_strip_tile_rectangle(gx_device * dev, const gx_strip_bitmap * tiles,
int plane_depth = mdev->planes[pi].depth;
int shift = mdev->planes[pi].shift;
gx_color_index mask = ((gx_color_index)1 << plane_depth) - 1;
- const gx_device_memory *mdproto =
- gdev_mem_device_for_bits(plane_depth);
+ const gdev_mem_functions *fns =
+ gdev_mem_functions_for_bits(plane_depth);
gx_color_index c0 =
(color0 == gx_no_color_index ? gx_no_color_index :
(color0 >> shift) & mask);
@@ -1092,15 +1078,14 @@ mem_planar_strip_tile_rectangle(gx_device * dev, const gx_strip_bitmap * tiles,
MEM_SET_PARAMS(mdev, plane_depth);
if (c0 == c1)
- dev_proc(mdproto, fill_rectangle)(dev, x, y, w, h, c0);
+ fns->fill_rectangle(dev, x, y, w, h, c0);
else {
/*
* Temporarily replace copy_mono in case strip_tile_rectangle is
* defined in terms of it.
*/
- set_dev_proc(dev, copy_mono, dev_proc(mdproto, copy_mono));
- dev_proc(mdproto, strip_tile_rectangle)
- (dev, tiles, x, y, w, h, c0, c1, px, py);
+ set_dev_proc(dev, copy_mono, fns->copy_mono);
+ fns->strip_tile_rectangle(dev, tiles, x, y, w, h, c0, c1, px, py);
}
mdev->line_ptrs += mdev->height;
}
@@ -1110,14 +1095,15 @@ mem_planar_strip_tile_rectangle(gx_device * dev, const gx_strip_bitmap * tiles,
}
static int
-planar_cmyk4bit_strip_copy_rop(gx_device_memory * mdev,
- const byte * srow, int sourcex, uint sraster,
- gx_bitmap_id id, const gx_color_index * scolors,
- const gx_strip_bitmap * textures,
- const gx_color_index * tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y,
- gs_logical_operation_t lop)
+planar_cmyk4bit_strip_copy_rop2(gx_device_memory * mdev,
+ const byte * srow, int sourcex, uint sraster,
+ gx_bitmap_id id, const gx_color_index * scolors,
+ const gx_strip_bitmap * textures,
+ const gx_color_index * tcolors,
+ int x, int y, int width, int height,
+ int phase_x, int phase_y,
+ gs_logical_operation_t lop,
+ uint planar_height)
{
gs_rop3_t rop = (gs_rop3_t)lop;
uint draster = mdev->raster;
@@ -1130,6 +1116,8 @@ planar_cmyk4bit_strip_copy_rop(gx_device_memory * mdev,
int ctcolor = 0, mtcolor = 0, ytcolor = 0, ktcolor = 0;
int constant_s = 0;
+ /* assert(planar_height == 0) */
+
/* Modify the raster operation according to the source palette. */
fit_copy(mdev, srow, sourcex, sraster, id, x, y, width, height);
@@ -1722,32 +1710,39 @@ planar_cmyk4bit_strip_copy_rop(gx_device_memory * mdev,
}
static int
-plane_strip_copy_rop(gx_device_memory * mdev,
- const byte * sdata, int sourcex, uint sraster,
- gx_bitmap_id id, const gx_color_index * scolors,
- const gx_strip_bitmap * textures,
- const gx_color_index * tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y,
- gs_logical_operation_t lop, int plane)
+plane_strip_copy_rop2(gx_device_memory * mdev,
+ const byte * sdata, int sourcex, uint sraster,
+ gx_bitmap_id id, const gx_color_index * scolors,
+ const gx_strip_bitmap * textures,
+ const gx_color_index * tcolors,
+ int x, int y, int width, int height,
+ int phase_x, int phase_y,
+ gs_logical_operation_t lop, int plane,
+ uint planar_height)
{
mem_save_params_t save;
int code;
- const gx_device_memory *mdproto;
+ const gdev_mem_functions *fns;
+ int n;
+
+ /* assert(planar_height == 0); */
MEM_SAVE_PARAMS(mdev, save);
mdev->line_ptrs += mdev->height * plane;
- mdproto = gdev_mem_device_for_bits(mdev->planes[plane].depth);
- /* strip_copy_rop might end up calling get_bits_rectangle or fill_rectangle,
+ fns = gdev_mem_functions_for_bits(mdev->planes[plane].depth);
+ /* strip_copy_rop2 might end up calling get_bits_rectangle or fill_rectangle,
* so ensure we have the right ones in there. */
- set_dev_proc(mdev, get_bits_rectangle, dev_proc(mdproto, get_bits_rectangle));
- set_dev_proc(mdev, fill_rectangle, dev_proc(mdproto, fill_rectangle));
+ set_dev_proc(mdev, get_bits_rectangle, fns->get_bits_rectangle);
+ set_dev_proc(mdev, fill_rectangle, fns->fill_rectangle);
/* mdev->color_info.depth is restored by MEM_RESTORE_PARAMS below. */
mdev->color_info.depth = mdev->planes[plane].depth;
- code = dev_proc(mdproto, strip_copy_rop)((gx_device *)mdev, sdata, sourcex, sraster,
- id, scolors, textures, tcolors,
- x, y, width, height,
- phase_x, phase_y, lop);
+ n = mdev->color_info.num_components;
+ mdev->color_info.num_components = 1;
+ code = fns->strip_copy_rop2((gx_device *)mdev, sdata, sourcex, sraster,
+ id, scolors, textures, tcolors,
+ x, y, width, height,
+ phase_x, phase_y, lop, planar_height);
+ mdev->color_info.num_components = n;
set_dev_proc(mdev, get_bits_rectangle, mem_planar_get_bits_rectangle);
set_dev_proc(mdev, fill_rectangle, mem_planar_fill_rectangle);
/* The following effectively does: mdev->line_ptrs -= mdev->height * plane; */
@@ -1881,22 +1876,6 @@ static byte cmykrop[256] =
};
static int
-mem_planar_strip_copy_rop(gx_device * dev,
- const byte * sdata, int sourcex, uint sraster,
- gx_bitmap_id id, const gx_color_index * scolors,
- const gx_strip_bitmap * textures,
- const gx_color_index * tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y,
- gs_logical_operation_t lop)
-{
- return mem_planar_strip_copy_rop2(dev, sdata, sourcex, sraster,
- id, scolors, textures, tcolors,
- x, y, width, height,
- phase_x, phase_y, lop, 0);
-}
-
-static int
mem_planar_strip_copy_rop2(gx_device * dev,
const byte * sdata, int sourcex, uint sraster,
gx_bitmap_id id, const gx_color_index * scolors,
@@ -2043,11 +2022,11 @@ mem_planar_strip_copy_rop2(gx_device * dev,
scolors2[0] = (scolors[0] >> shift) & mask;
scolors2[1] = (scolors[1] >> shift) & mask;
}
- code = plane_strip_copy_rop(mdev, sdata, sourcex, sraster,
- id, (scolors ? scolors2 : NULL),
- textures, (tcolors ? tcolors2 : NULL),
- x, y, width, height,
- phase_x, phase_y, lop, plane);
+ code = plane_strip_copy_rop2(mdev, sdata, sourcex, sraster,
+ id, (scolors ? scolors2 : NULL),
+ textures, (tcolors ? tcolors2 : NULL),
+ x, y, width, height,
+ phase_x, phase_y, lop, plane, 0);
if (code < 0)
return code;
}
@@ -2056,37 +2035,36 @@ mem_planar_strip_copy_rop2(gx_device * dev,
if ((mdev->color_info.num_components == 4) && (mdev->plane_depth == 1))
{
lop = cmykrop[lop & 0xff] | (lop & ~0xff);
- return planar_cmyk4bit_strip_copy_rop(mdev, sdata, sourcex,
- sraster, id, scolors,
- textures, tcolors,
- x, y, width, height,
- phase_x, phase_y,
- lop);
+ return planar_cmyk4bit_strip_copy_rop2(mdev, sdata, sourcex,
+ sraster, id, scolors,
+ textures, tcolors,
+ x, y, width, height,
+ phase_x, phase_y,
+ lop, 0);
}
}
if (!tcolors && !scolors &&
(mdev->color_info.num_components == 4) && (mdev->plane_depth == 1)) {
lop = cmykrop[lop & 0xff] | (lop & ~0xff);
- return planar_cmyk4bit_strip_copy_rop(mdev, sdata, sourcex,
- sraster, id, scolors,
- textures, tcolors,
- x, y, width, height,
- phase_x, phase_y,
- lop);
+ return planar_cmyk4bit_strip_copy_rop2(mdev, sdata, sourcex,
+ sraster, id, scolors,
+ textures, tcolors,
+ x, y, width, height,
+ phase_x, phase_y,
+ lop, 0);
}
/* Fall back to the default implementation (the only one that
* guarantees to properly cope with D being planar). */
- return mem_default_strip_copy_rop(dev, sdata, sourcex, sraster,
- id, scolors, textures, tcolors,
- x, y, width, height,
- phase_x, phase_y, lop);
+ return mem_default_strip_copy_rop2(dev, sdata, sourcex, sraster,
+ id, scolors, textures, tcolors,
+ x, y, width, height,
+ phase_x, phase_y, lop, 0);
}
/* Copy bits back from a planar memory device. */
static int
mem_planar_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
- gs_get_bits_params_t * params,
- gs_int_rect ** unread)
+ gs_get_bits_params_t * params)
{
/* This duplicates most of mem_get_bits_rectangle. Tant pgs. */
gx_device_memory * const mdev = (gx_device_memory *)dev;
@@ -2180,8 +2158,7 @@ mem_planar_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
MEM_SAVE_PARAMS(mdev, save);
mdev->line_ptrs += mdev->height * plane;
MEM_SET_PARAMS(mdev, mdev->planes[plane].depth);
- code = mem_get_bits_rectangle(dev, prect, &copy_params,
- unread);
+ code = mem_get_bits_rectangle(dev, prect, &copy_params);
MEM_RESTORE_PARAMS(mdev, save);
if (code >= 0) {
params->data[plane] = copy_params.data[0];
diff --git a/base/gdevmplt.c b/base/gdevmplt.c
index 89720535..85e5e87f 100644
--- a/base/gdevmplt.c
+++ b/base/gdevmplt.c
@@ -41,6 +41,7 @@
#include "gdevsclass.h"
#include "gdevmplt.h"
#include "gxdcconv.h" /* for color_rgb_to_gray and color_cmyk_to_gray */
+#include "gxdevsop.h"
/* Device procedures, we only need one */
static dev_proc_get_color_mapping_procs(pcl_mono_palette_get_color_mapping_procs);
@@ -69,92 +70,58 @@ RELOC_PTRS_END
public_st_pcl_mono_palette_device();
+static int
+pcl_mono_dev_spec_op(gx_device *dev, int dev_spec_op, void *data, int size)
+{
+ if (dev_spec_op == gxdso_supports_hlcolor)
+ return 0;
+ if (dev->child)
+ return dev_proc(dev->child, dev_spec_op)(dev->child, dev_spec_op, data, size);
+ return_error(gs_error_rangecheck);
+}
+
+static int
+pcl_mono_text_begin(gx_device *dev, gs_gstate *pgs, const gs_text_params_t *text,
+ gs_font *font, const gx_clip_path *pcpath, gs_text_enum_t **ppte)
+{
+ /* The 'high level' version of the color has not been 'monochromized' by this
+ * device, so ensure that routines that we call (notably pdfwrite) don't
+ * think it's valid and use it. */
+ pgs->color[0].dev_color->ccolor_valid = 0;
+
+ if (dev->child)
+ return dev_proc(dev->child, text_begin)(dev->child, pgs, text, font, pcpath, ppte);
+ else
+ return gx_default_text_begin(dev, pgs, text, font, pcpath, ppte);
+}
+
+static void
+pcl_mono_palette_initialize(gx_device *dev)
+{
+ default_subclass_initialize_device_procs(dev);
+
+ set_dev_proc(dev, get_color_mapping_procs, pcl_mono_palette_get_color_mapping_procs);
+ /* We must override begin_typed_image here with the default. If
+ * we don't, then we forward down to the underlying devices own
+ * begin_typed_image, and the color calls done during that bypass
+ * the monochroming behaviour. See: page 32 of 75dpi png rendering of
+ * tests_private/pcl/pcl5ccet/15-01.BIN for an example. */
+ set_dev_proc(dev, begin_typed_image, gx_default_begin_typed_image);
+ set_dev_proc(dev, dev_spec_op, pcl_mono_dev_spec_op);
+ set_dev_proc(dev, text_begin, pcl_mono_text_begin);
+}
+
const
gx_device_mplt gs_pcl_mono_palette_device =
{
/*
* Define the device as 8-bit gray scale to avoid computing halftones.
*/
- std_device_dci_type_body(gx_device_mplt, 0, "PCL_Mono_Palette", &st_pcl_mono_palette_device,
+ std_device_dci_type_body_sc(gx_device_mplt, pcl_mono_palette_initialize,
+ "PCL_Mono_Palette", &st_pcl_mono_palette_device,
MAX_COORD, MAX_COORD,
MAX_RESOLUTION, MAX_RESOLUTION,
- 1, 8, 255, 0, 256, 1),
- {default_subclass_open_device,
- default_subclass_get_initial_matrix,
- default_subclass_sync_output, /* sync_output */
- default_subclass_output_page,
- default_subclass_close_device,
- default_subclass_map_rgb_color,
- default_subclass_map_color_rgb,
- default_subclass_fill_rectangle,
- default_subclass_tile_rectangle, /* tile_rectangle */
- default_subclass_copy_mono,
- default_subclass_copy_color,
- default_subclass_draw_line, /* draw_line */
- default_subclass_get_bits, /* get_bits */
- default_subclass_get_params,
- default_subclass_put_params,
- default_subclass_map_cmyk_color,
- default_subclass_get_xfont_procs, /* get_xfont_procs */
- default_subclass_get_xfont_device, /* get_xfont_device */
- default_subclass_map_rgb_alpha_color,
- default_subclass_get_page_device,
- default_subclass_get_alpha_bits, /* get_alpha_bits */
- default_subclass_copy_alpha,
- default_subclass_get_band, /* get_band */
- default_subclass_copy_rop, /* copy_rop */
- default_subclass_fill_path,
- default_subclass_stroke_path,
- default_subclass_fill_mask,
- default_subclass_fill_trapezoid,
- default_subclass_fill_parallelogram,
- default_subclass_fill_triangle,
- default_subclass_draw_thin_line,
- default_subclass_begin_image,
- default_subclass_image_data, /* image_data */
- default_subclass_end_image, /* end_image */
- default_subclass_strip_tile_rectangle,
- default_subclass_strip_copy_rop,
- default_subclass_get_clipping_box, /* get_clipping_box */
- default_subclass_begin_typed_image,
- default_subclass_get_bits_rectangle, /* get_bits_rectangle */
- default_subclass_map_color_rgb_alpha,
- default_subclass_create_compositor,
- default_subclass_get_hardware_params, /* get_hardware_params */
- default_subclass_text_begin,
- default_subclass_finish_copydevice, /* finish_copydevice */
- default_subclass_begin_transparency_group, /* begin_transparency_group */
- default_subclass_end_transparency_group, /* end_transparency_group */
- default_subclass_begin_transparency_mask, /* begin_transparency_mask */
- default_subclass_end_transparency_mask, /* end_transparency_mask */
- default_subclass_discard_transparency_layer, /* discard_transparency_layer */
- pcl_mono_palette_get_color_mapping_procs, /* get_color_mapping_procs */
- default_subclass_get_color_comp_index, /* get_color_comp_index */
- default_subclass_encode_color, /* encode_color */
- default_subclass_decode_color, /* decode_color */
- default_subclass_pattern_manage, /* pattern_manage */
- default_subclass_fill_rectangle_hl_color, /* fill_rectangle_hl_color */
- default_subclass_include_color_space, /* include_color_space */
- default_subclass_fill_linear_color_scanline, /* fill_linear_color_scanline */
- default_subclass_fill_linear_color_trapezoid, /* fill_linear_color_trapezoid */
- default_subclass_fill_linear_color_triangle, /* fill_linear_color_triangle */
- default_subclass_update_spot_equivalent_colors, /* update_spot_equivalent_colors */
- default_subclass_ret_devn_params, /* ret_devn_params */
- default_subclass_fillpage, /* fillpage */
- default_subclass_push_transparency_state, /* push_transparency_state */
- default_subclass_pop_transparency_state, /* pop_transparency_state */
- default_subclass_put_image, /* put_image */
- default_subclass_dev_spec_op, /* dev_spec_op */
- default_subclass_copy_planes, /* copy_planes */
- default_subclass_get_profile, /* get_profile */
- default_subclass_set_graphics_type_tag, /* set_graphics_type_tag */
- default_subclass_strip_copy_rop2,
- default_subclass_strip_tile_rect_devn,
- default_subclass_copy_alpha_hl_color,
- default_subclass_process_page,
- default_subclass_transform_pixel_region,
- default_subclass_fill_stroke_path,
- }
+ 1, 8, 255, 0, 256, 1, NULL, NULL, NULL)
};
#undef MAX_COORD
@@ -164,76 +131,70 @@ gx_device_mplt gs_pcl_mono_palette_device =
* to gray values
*/
static void
-pcl_gray_cs_to_cm(gx_device * dev, frac gray, frac out[])
+pcl_gray_cs_to_cm(const gx_device * dev, frac gray, frac out[])
{
- pcl_mono_palette_subclass_data *psubclass_data;
+ pcl_mono_palette_subclass_data *psubclass_data = dev->subclass_data;
- while(dev && dev->child) {
- if (strncmp(dev->dname, "PCL_Mono_Palette", 16) == 0)
- break;
- dev = dev->child;
- };
+ /* assert(strncmp(dev->dname, "PCL_Mono_Palette", 16) == 0) - otherwise we are being
+ * called with the wrong dev! */
- if (dev && dev->child) {
- psubclass_data = dev->subclass_data;
+ if (psubclass_data->device_cm) {
/* just pass it along */
- psubclass_data->device_cm_procs->map_gray(dev, gray, out);
- } else
- return;
+ psubclass_data->device_cm_procs->map_gray(psubclass_data->device_cm, gray, out);
+ }
}
static void
-pcl_rgb_cs_to_cm(gx_device * dev, const gs_gstate * pgs, frac r, frac g,
+pcl_rgb_cs_to_cm(const gx_device * dev, const gs_gstate * pgs, frac r, frac g,
frac b, frac out[])
{
- pcl_mono_palette_subclass_data *psubclass_data;
+ pcl_mono_palette_subclass_data *psubclass_data = dev->subclass_data;
frac gray;
- while(dev && dev->child) {
- if (strncmp(dev->dname, "PCL_Mono_Palette", 16) == 0)
- break;
- dev = dev->child;
- };
+ /* assert(strncmp(dev->dname, "PCL_Mono_Palette", 16) == 0) - otherwise we are being
+ * called with the wrong dev! */
- if (dev && dev->child) {
- psubclass_data = dev->subclass_data;
+ if (psubclass_data->device_cm) {
gray = color_rgb_to_gray(r, g, b, NULL);
- psubclass_data->device_cm_procs->map_rgb(dev, pgs, gray, gray, gray, out);
- } else
- return;
+ psubclass_data->device_cm_procs->map_rgb(psubclass_data->device_cm, pgs, gray, gray, gray, out);
+ }
}
static void
-pcl_cmyk_cs_to_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+pcl_cmyk_cs_to_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
- pcl_mono_palette_subclass_data *psubclass_data;
+ pcl_mono_palette_subclass_data *psubclass_data = dev->subclass_data;
frac gray;
- while(dev && dev->child) {
- if (strncmp(dev->dname, "PCL_Mono_Palette", 16) == 0)
- break;
- dev = dev->child;
- };
+ /* assert(strncmp(dev->dname, "PCL_Mono_Palette", 16) == 0) - otherwise we are being
+ * called with the wrong dev! */
- if (dev && dev->child) {
- psubclass_data = dev->subclass_data;
+ if (psubclass_data->device_cm) {
gray = color_cmyk_to_gray(c, m, y, k, NULL);
- psubclass_data->device_cm_procs->map_cmyk(dev, gray, gray, gray, gray, out);
- } else
- return;
+ psubclass_data->device_cm_procs->map_cmyk(psubclass_data->device_cm, gray, gray, gray, gray, out);
+ }
}
-const gx_cm_color_map_procs *pcl_mono_palette_get_color_mapping_procs(const gx_device *dev)
+static gx_cm_color_map_procs pcl_mono_procs =
+{
+ pcl_gray_cs_to_cm,
+ pcl_rgb_cs_to_cm,
+ pcl_cmyk_cs_to_cm
+};
+
+const gx_cm_color_map_procs *pcl_mono_palette_get_color_mapping_procs(const gx_device *dev,
+ const gx_device **tdev)
{
pcl_mono_palette_subclass_data *psubclass_data = dev->subclass_data;
- if (psubclass_data->device_cm_procs == 0L) {
- psubclass_data->pcl_mono_procs.map_gray = pcl_gray_cs_to_cm;
- psubclass_data->pcl_mono_procs.map_rgb = pcl_rgb_cs_to_cm;
- psubclass_data->pcl_mono_procs.map_cmyk = pcl_cmyk_cs_to_cm;
- psubclass_data->device_cm_procs = (gx_cm_color_map_procs *)dev_proc(dev->child, get_color_mapping_procs) (dev->child);
+ /* assert(strncmp(dev->dname, "PCL_Mono_Palette", 16) == 0) - otherwise we are being
+ * called with the wrong dev! */
+
+ *tdev = dev;
+ if (psubclass_data->device_cm_procs == NULL) {
+ psubclass_data->device_cm_procs = (gx_cm_color_map_procs *)dev_proc(dev->child, get_color_mapping_procs)(dev->child, &psubclass_data->device_cm);
}
- return &psubclass_data->pcl_mono_procs;
+ return &pcl_mono_procs;
}
diff --git a/base/gdevmplt.h b/base/gdevmplt.h
index 669efdc7..de20ca25 100644
--- a/base/gdevmplt.h
+++ b/base/gdevmplt.h
@@ -29,7 +29,8 @@ void gx_device_pcl_mono_palette_init(gx_device_mplt * dev);
typedef struct {
subclass_common;
gx_cm_color_map_procs pcl_mono_procs;
- gx_cm_color_map_procs *device_cm_procs;
+ const gx_cm_color_map_procs *device_cm_procs;
+ const gx_device *device_cm;
} pcl_mono_palette_subclass_data;
extern_st(st_device_mplt);
diff --git a/base/gdevmr1.c b/base/gdevmr1.c
index ed2faab9..fb9a4373 100644
--- a/base/gdevmr1.c
+++ b/base/gdevmr1.c
@@ -23,7 +23,6 @@
#include "gxdcolor.h"
#include "gxdevice.h"
#include "gxdevmem.h"
-#include "gxdevrop.h"
#include "gdevmem.h"
#include "gdevmrop.h"
@@ -35,19 +34,22 @@
* does everything in device space.
*/
int
-mem_mono_strip_copy_rop(gx_device * dev, const byte * sdata,
- int sourcex,uint sraster, gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_strip_bitmap * textures,
- const gx_color_index * tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y,
- gs_logical_operation_t lop)
+mem_mono_strip_copy_rop2(gx_device * dev, const byte * sdata,
+ int sourcex,uint sraster, gx_bitmap_id id,
+ const gx_color_index * scolors,
+ const gx_strip_bitmap * textures,
+ const gx_color_index * tcolors,
+ int x, int y, int width, int height,
+ int phase_x, int phase_y,
+ gs_logical_operation_t lop,
+ uint planar_height)
{
gx_device_memory *mdev = (gx_device_memory *) dev;
gs_rop3_t rop = lop_sanitize(lop); /* handle transparency */
bool invert;
+ /* assert(planar_height == 0); */
+
/* If map_rgb_color isn't the default one for monobit memory */
/* devices, palette might not be set; set it now if needed. */
if (mdev->palette.data == 0) {
@@ -80,8 +82,8 @@ mem_mono_strip_copy_rop(gx_device * dev, const byte * sdata,
if (invert)
rop = byte_reverse_bits[rop & 0xff] ^ 0xff;
- return mem_mono_strip_copy_rop_dev(dev, sdata, sourcex, sraster, id,
- scolors, textures, tcolors, x, y,
- width, height, phase_x, phase_y,
- (gs_logical_operation_t)rop);
+ return mem_mono_strip_copy_rop2_dev(dev, sdata, sourcex, sraster, id,
+ scolors, textures, tcolors, x, y,
+ width, height, phase_x, phase_y,
+ (gs_logical_operation_t)rop, 0);
}
diff --git a/base/gdevmr2n.c b/base/gdevmr2n.c
index a19b9f69..4a12eed2 100644
--- a/base/gdevmr2n.c
+++ b/base/gdevmr2n.c
@@ -23,7 +23,6 @@
#include "gxdcolor.h"
#include "gxdevice.h"
#include "gxdevmem.h"
-#include "gxdevrop.h"
#include "gdevmem.h"
#include "gdevmrop.h"
@@ -65,12 +64,13 @@ mem_gray_rop_strip_tile_rectangle(gx_device * dev,
}
int
-mem_gray_strip_copy_rop(gx_device * dev,
+mem_gray_strip_copy_rop2(gx_device * dev,
const byte * sdata, int sourcex, uint sraster, gx_bitmap_id id,
const gx_color_index * scolors,
const gx_strip_bitmap * textures, const gx_color_index * tcolors,
int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
+ int phase_x, int phase_y, gs_logical_operation_t lop,
+ uint planar_height)
{
gx_color_index scolors2[2];
const gx_color_index *real_scolors = scolors;
@@ -84,6 +84,8 @@ mem_gray_strip_copy_rop(gx_device * dev,
gx_color_index max_pixel = ((gx_color_index)1 << depth) - 1;
int code;
+ /* assert(planar_height == 0); */
+
#ifdef DEBUG
if (gs_debug_c('b'))
trace_copy_rop("mem_gray_strip_copy_rop",
@@ -99,10 +101,10 @@ mem_gray_strip_copy_rop(gx_device * dev,
(tcolors && (tcolors[0] != tcolors[1]))
) {
/* We can't fake it: do it the slow, painful way. */
- return mem_default_strip_copy_rop(dev, sdata, sourcex, sraster, id,
- scolors, textures, tcolors,
- x, y, width, height,
- phase_x, phase_y, lop);
+ return mem_default_strip_copy_rop2(dev, sdata, sourcex, sraster, id,
+ scolors, textures, tcolors,
+ x, y, width, height,
+ phase_x, phase_y, lop, 0);
}
if (scolors) { /* Must be a solid color: see above. */
scolors2[0] = scolors2[1] = scolors[0] & 1;
@@ -154,14 +156,15 @@ mem_gray_strip_copy_rop(gx_device * dev,
set_dev_proc(dev, strip_tile_rectangle,
mem_gray_rop_strip_tile_rectangle);
dev->width <<= log2_depth;
- code = mem_mono_strip_copy_rop(dev, sdata,
- (real_scolors == NULL ?
- sourcex << log2_depth : sourcex),
- sraster, id, real_scolors,
- real_texture, real_tcolors,
- x << log2_depth, y,
- width << log2_depth, height,
- phase_x << log2_depth, phase_y, lop);
+ code = mem_mono_strip_copy_rop2(dev, sdata,
+ (real_scolors == NULL ?
+ sourcex << log2_depth : sourcex),
+ sraster, id, real_scolors,
+ real_texture, real_tcolors,
+ x << log2_depth, y,
+ width << log2_depth, height,
+ phase_x << log2_depth, phase_y,
+ lop, 0);
set_dev_proc(dev, fill_rectangle, fill_rectangle);
set_dev_proc(dev, copy_mono, copy_mono);
set_dev_proc(dev, strip_tile_rectangle, strip_tile_rectangle);
@@ -169,9 +172,9 @@ mem_gray_strip_copy_rop(gx_device * dev,
}
/* If we punted, use the general procedure. */
if (code < 0)
- return mem_default_strip_copy_rop(dev, sdata, sourcex, sraster, id,
- scolors, textures, tcolors,
- x, y, width, height,
- phase_x, phase_y, lop);
+ return mem_default_strip_copy_rop2(dev, sdata, sourcex, sraster, id,
+ scolors, textures, tcolors,
+ x, y, width, height,
+ phase_x, phase_y, lop, 0);
return code;
}
diff --git a/base/gdevmr8n.c b/base/gdevmr8n.c
index e90bb151..c4224697 100644
--- a/base/gdevmr8n.c
+++ b/base/gdevmr8n.c
@@ -23,7 +23,6 @@
#include "gxdcolor.h"
#include "gxdevice.h"
#include "gxdevmem.h"
-#include "gxdevrop.h"
#include "gdevmem.h"
#include "gdevmrop.h"
@@ -47,12 +46,13 @@
/* ---------------- RasterOp with 8-bit gray / 24-bit RGB ---------------- */
int
-mem_gray8_rgb24_strip_copy_rop(gx_device * dev,
+mem_gray8_rgb24_strip_copy_rop2(gx_device * dev,
const byte * sdata, int sourcex, uint sraster, gx_bitmap_id id,
const gx_color_index * scolors,
const gx_strip_bitmap * textures, const gx_color_index * tcolors,
int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t dirty_lop)
+ int phase_x, int phase_y,
+ gs_logical_operation_t dirty_lop, uint planar_height)
{
gx_device_memory *mdev = (gx_device_memory *) dev;
gs_logical_operation_t lop = lop_sanitize(dirty_lop);
@@ -77,6 +77,8 @@ mem_gray8_rgb24_strip_copy_rop(gx_device * dev,
#endif
#endif
+ /* assert(planar_height == 0); */
+
/* Check for constant source. */
if (!rop3_uses_S(lop)) {
const_source = 0; /* arbitrary */
@@ -136,11 +138,11 @@ bw: if (bw_pixel == 0x00)
case rop3_T:
break;
default:
-df: return mem_default_strip_copy_rop(dev,
- sdata, sourcex, sraster, id,
- scolors, textures, tcolors,
- x, y, width, height,
- phase_x, phase_y, lop);
+df: return mem_default_strip_copy_rop2(dev,
+ sdata, sourcex, sraster, id,
+ scolors, textures, tcolors,
+ x, y, width, height,
+ phase_x, phase_y, lop, 0);
}
/* Put the updated rop back into the lop */
lop = rop;
diff --git a/base/gdevmrun.c b/base/gdevmrun.c
index fa16ffbc..f143fbd8 100644
--- a/base/gdevmrun.c
+++ b/base/gdevmrun.c
@@ -165,7 +165,7 @@ static dev_proc_copy_color(run_copy_color);
static dev_proc_fill_rectangle(run_fill_rectangle);
static dev_proc_copy_alpha(run_copy_alpha);
static dev_proc_strip_tile_rectangle(run_strip_tile_rectangle);
-static dev_proc_strip_copy_rop(run_strip_copy_rop);
+static dev_proc_strip_copy_rop2(run_strip_copy_rop2);
static dev_proc_get_bits_rectangle(run_get_bits_rectangle);
/*
@@ -211,7 +211,7 @@ gdev_run_from_mem(gx_device_run *rdev, gx_device_memory *mdev)
REPLACE(fill_rectangle, run_fill_rectangle);
REPLACE(copy_alpha, run_copy_alpha);
REPLACE(strip_tile_rectangle, run_strip_tile_rectangle);
- REPLACE(strip_copy_rop, run_strip_copy_rop);
+ REPLACE(strip_copy_rop2, run_strip_copy_rop2);
REPLACE(get_bits_rectangle, run_get_bits_rectangle);
#undef REPLACE
return 0;
@@ -334,31 +334,33 @@ run_strip_tile_rectangle(gx_device * dev, const gx_strip_bitmap * tiles,
color0, color1, px, py);
}
static int
-run_strip_copy_rop(gx_device * dev, const byte * sdata, int sourcex,
- uint sraster, gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_strip_bitmap * textures,
- const gx_color_index * tcolors,
- int x, int y, int w, int h, int px, int py,
- gs_logical_operation_t lop)
+run_strip_copy_rop2(gx_device * dev, const byte * sdata, int sourcex,
+ uint sraster, gx_bitmap_id id,
+ const gx_color_index * scolors,
+ const gx_strip_bitmap * textures,
+ const gx_color_index * tcolors,
+ int x, int y, int w, int h, int px, int py,
+ gs_logical_operation_t lop,
+ uint planar_height)
{
gx_device_run *const rdev = (gx_device_run *)dev;
run_standardize(rdev, y, h);
- return rdev->save_procs.strip_copy_rop((gx_device *)&rdev->md,
- sdata, sourcex, sraster,
- id, scolors, textures, tcolors,
- x, y, w, h, px, py, lop);
+ return rdev->save_procs.strip_copy_rop2((gx_device *)&rdev->md,
+ sdata, sourcex, sraster,
+ id, scolors, textures, tcolors,
+ x, y, w, h, px, py, lop,
+ planar_height);
}
static int
run_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
- gs_get_bits_params_t * params, gs_int_rect **unread)
+ gs_get_bits_params_t * params)
{
gx_device_run *const rdev = (gx_device_run *)dev;
run_standardize(rdev, prect->p.y, prect->q.y - prect->p.y);
return rdev->save_procs.get_bits_rectangle((gx_device *)&rdev->md,
- prect, params, unread);
+ prect, params);
}
/* Finish initializing a line. This is a separate procedure only */
diff --git a/base/gdevmrun.h b/base/gdevmrun.h
index 15ee2f79..ff6666d3 100644
--- a/base/gdevmrun.h
+++ b/base/gdevmrun.h
@@ -44,7 +44,7 @@ typedef struct gx_device_run_s {
dev_proc_fill_rectangle((*fill_rectangle));
dev_proc_copy_alpha((*copy_alpha));
dev_proc_strip_tile_rectangle((*strip_tile_rectangle));
- dev_proc_strip_copy_rop((*strip_copy_rop));
+ dev_proc_strip_copy_rop2((*strip_copy_rop2));
dev_proc_get_bits_rectangle((*get_bits_rectangle));
} save_procs;
} gx_device_run;
diff --git a/base/gdevmx.c b/base/gdevmx.c
index fa2287cc..08b0cbcf 100644
--- a/base/gdevmx.c
+++ b/base/gdevmx.c
@@ -25,4 +25,4 @@
/* The device descriptor. */
const gx_device_memory mem_x_device =
- mem_device("imagex", 256, 0, NULL, NULL, NULL, NULL, NULL, NULL);
+ mem_device("imagex", 256, 0, NULL);
diff --git a/base/gdevnfwd.c b/base/gdevnfwd.c
index a6c69e44..f761750b 100644
--- a/base/gdevnfwd.c
+++ b/base/gdevnfwd.c
@@ -55,7 +55,6 @@ gx_device_set_target(gx_device_forward *fdev, gx_device *target)
void
gx_device_forward_fill_in_procs(register gx_device_forward * dev)
{
- gx_device_set_procs((gx_device *) dev);
/* NOT open_device */
fill_dev_proc(dev, get_initial_matrix, gx_forward_get_initial_matrix);
fill_dev_proc(dev, sync_output, gx_forward_sync_output);
@@ -64,22 +63,14 @@ gx_device_forward_fill_in_procs(register gx_device_forward * dev)
fill_dev_proc(dev, map_rgb_color, gx_forward_map_rgb_color);
fill_dev_proc(dev, map_color_rgb, gx_forward_map_color_rgb);
/* NOT fill_rectangle */
- /* NOT tile_rectangle */
/* NOT copy_mono */
/* NOT copy_color */
- /* NOT draw_line (OBSOLETE) */
- fill_dev_proc(dev, get_bits, gx_forward_get_bits);
fill_dev_proc(dev, get_params, gx_forward_get_params);
fill_dev_proc(dev, put_params, gx_forward_put_params);
fill_dev_proc(dev, map_cmyk_color, gx_forward_map_cmyk_color);
- fill_dev_proc(dev, get_xfont_procs, gx_forward_get_xfont_procs);
- fill_dev_proc(dev, get_xfont_device, gx_forward_get_xfont_device);
- fill_dev_proc(dev, map_rgb_alpha_color, gx_forward_map_rgb_alpha_color);
fill_dev_proc(dev, get_page_device, gx_forward_get_page_device);
- /* NOT get_alpha_bits (OBSOLETE) */
+ fill_dev_proc(dev, get_alpha_bits, gx_forward_get_alpha_bits);
/* NOT copy_alpha */
- fill_dev_proc(dev, get_band, gx_forward_get_band);
- fill_dev_proc(dev, copy_rop, gx_forward_copy_rop);
fill_dev_proc(dev, fill_path, gx_forward_fill_path);
fill_dev_proc(dev, stroke_path, gx_forward_stroke_path);
fill_dev_proc(dev, fill_mask, gx_forward_fill_mask);
@@ -87,16 +78,11 @@ gx_device_forward_fill_in_procs(register gx_device_forward * dev)
fill_dev_proc(dev, fill_parallelogram, gx_forward_fill_parallelogram);
fill_dev_proc(dev, fill_triangle, gx_forward_fill_triangle);
fill_dev_proc(dev, draw_thin_line, gx_forward_draw_thin_line);
- fill_dev_proc(dev, begin_image, gx_forward_begin_image);
- /* NOT image_data (OBSOLETE) */
- /* NOT end_image (OBSOLETE) */
/* NOT strip_tile_rectangle */
- fill_dev_proc(dev, strip_copy_rop, gx_forward_strip_copy_rop);
fill_dev_proc(dev, get_clipping_box, gx_forward_get_clipping_box);
fill_dev_proc(dev, begin_typed_image, gx_forward_begin_typed_image);
fill_dev_proc(dev, get_bits_rectangle, gx_forward_get_bits_rectangle);
- fill_dev_proc(dev, map_color_rgb_alpha, gx_forward_map_color_rgb_alpha);
- fill_dev_proc(dev, create_compositor, gx_no_create_compositor);
+ fill_dev_proc(dev, composite, gx_no_composite);
fill_dev_proc(dev, get_hardware_params, gx_forward_get_hardware_params);
fill_dev_proc(dev, text_begin, gx_forward_text_begin);
fill_dev_proc(dev, get_color_mapping_procs, gx_forward_get_color_mapping_procs);
@@ -130,7 +116,6 @@ gx_device_forward_color_procs(gx_device_forward * dev)
set_dev_proc(dev, map_rgb_color, gx_forward_map_rgb_color);
set_dev_proc(dev, map_color_rgb, gx_forward_map_color_rgb);
set_dev_proc(dev, map_cmyk_color, gx_forward_map_cmyk_color);
- set_dev_proc(dev, map_rgb_alpha_color, gx_forward_map_rgb_alpha_color);
set_dev_proc(dev, get_color_mapping_procs, gx_forward_get_color_mapping_procs);
set_dev_proc(dev, get_color_comp_index, gx_forward_get_color_comp_index);
set_dev_proc(dev, encode_color, gx_forward_encode_color);
@@ -224,20 +209,6 @@ gx_forward_fill_rectangle(gx_device * dev, int x, int y, int w, int h,
}
int
-gx_forward_tile_rectangle(gx_device * dev, const gx_tile_bitmap * tile,
- int x, int y, int w, int h, gx_color_index color0,
- gx_color_index color1, int px, int py)
-{
- gx_device_forward * const fdev = (gx_device_forward *)dev;
- gx_device *tdev = fdev->target;
- dev_proc_tile_rectangle((*proc)) =
- (tdev == 0 ? (tdev = dev, gx_default_tile_rectangle) :
- dev_proc(tdev, tile_rectangle));
-
- return proc(tdev, tile, x, y, w, h, color0, color1, px, py);
-}
-
-int
gx_forward_copy_mono(gx_device * dev, const byte * data,
int dx, int raster, gx_bitmap_id id,
int x, int y, int w, int h,
@@ -295,16 +266,6 @@ gx_forward_copy_planes(gx_device * dev, const byte * data,
}
int
-gx_forward_get_bits(gx_device * dev, int y, byte * data, byte ** actual_data)
-{
- gx_device_forward * const fdev = (gx_device_forward *)dev;
- gx_device *tdev = fdev->target;
-
- return (tdev == 0 ? gx_default_get_bits(dev, y, data, actual_data) :
- dev_proc(tdev, get_bits)(tdev, y, data, actual_data));
-}
-
-int
gx_forward_get_params(gx_device * dev, gs_param_list * plist)
{
gx_device_forward * const fdev = (gx_device_forward *)dev;
@@ -344,39 +305,6 @@ gx_forward_map_cmyk_color(gx_device * dev, const gx_color_value cv[])
dev_proc(tdev, map_cmyk_color)(tdev, cv));
}
-const gx_xfont_procs *
-gx_forward_get_xfont_procs(gx_device * dev)
-{
- gx_device_forward * const fdev = (gx_device_forward *)dev;
- gx_device *tdev = fdev->target;
-
- return (tdev == 0 ? gx_default_get_xfont_procs(dev) :
- dev_proc(tdev, get_xfont_procs)(tdev));
-}
-
-gx_device *
-gx_forward_get_xfont_device(gx_device * dev)
-{
- gx_device_forward * const fdev = (gx_device_forward *)dev;
- gx_device *tdev = fdev->target;
-
- return (tdev == 0 ? gx_default_get_xfont_device(dev) :
- dev_proc(tdev, get_xfont_device)(tdev));
-}
-
-gx_color_index
-gx_forward_map_rgb_alpha_color(gx_device * dev, gx_color_value r,
- gx_color_value g, gx_color_value b,
- gx_color_value alpha)
-{
- gx_device_forward * const fdev = (gx_device_forward *)dev;
- gx_device *tdev = fdev->target;
-
- return (tdev == 0 ?
- gx_default_map_rgb_alpha_color(dev, r, g, b, alpha) :
- dev_proc(tdev, map_rgb_alpha_color)(tdev, r, g, b, alpha));
-}
-
gx_device *
gx_forward_get_page_device(gx_device * dev)
{
@@ -391,37 +319,6 @@ gx_forward_get_page_device(gx_device * dev)
}
int
-gx_forward_get_band(gx_device * dev, int y, int *band_start)
-{
- gx_device_forward * const fdev = (gx_device_forward *)dev;
- gx_device *tdev = fdev->target;
-
- return (tdev == 0 ?
- gx_default_get_band(dev, y, band_start) :
- dev_proc(tdev, get_band)(tdev, y, band_start));
-}
-
-int
-gx_forward_copy_rop(gx_device * dev,
- const byte * sdata, int sourcex, uint sraster,
- gx_bitmap_id id, const gx_color_index * scolors,
- const gx_tile_bitmap * texture,
- const gx_color_index * tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- gx_device_forward * const fdev = (gx_device_forward *)dev;
- gx_device *tdev = fdev->target;
- dev_proc_copy_rop((*proc)) =
- (tdev == 0 ? (tdev = dev, gx_default_copy_rop) :
- dev_proc(tdev, copy_rop));
-
- return proc(tdev, sdata, sourcex, sraster, id, scolors,
- texture, tcolors, x, y, width, height,
- phase_x, phase_y, lop);
-}
-
-int
gx_forward_fill_path(gx_device * dev, const gs_gstate * pgs,
gx_path * ppath, const gx_fill_params * params,
const gx_drawing_color * pdcolor,
@@ -547,24 +444,6 @@ gx_forward_draw_thin_line(gx_device * dev,
}
int
-gx_forward_begin_image(gx_device * dev,
- const gs_gstate * pgs, const gs_image_t * pim,
- gs_image_format_t format, const gs_int_rect * prect,
- const gx_drawing_color * pdcolor,
- const gx_clip_path * pcpath,
- gs_memory_t * memory, gx_image_enum_common_t ** pinfo)
-{
- gx_device_forward * const fdev = (gx_device_forward *)dev;
- gx_device *tdev = fdev->target;
- dev_proc_begin_image((*proc)) =
- (tdev == 0 ? (tdev = dev, gx_default_begin_image) :
- dev_proc(tdev, begin_image));
-
- return proc(tdev, pgs, pim, format, prect, pdcolor, pcpath,
- memory, pinfo);
-}
-
-int
gx_forward_strip_tile_rectangle(gx_device * dev, const gx_strip_bitmap * tiles,
int x, int y, int w, int h, gx_color_index color0, gx_color_index color1,
int px, int py)
@@ -579,26 +458,6 @@ gx_forward_strip_tile_rectangle(gx_device * dev, const gx_strip_bitmap * tiles,
}
int
-gx_forward_strip_copy_rop(gx_device * dev, const byte * sdata, int sourcex,
- uint sraster, gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_strip_bitmap * textures,
- const gx_color_index * tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- gx_device_forward * const fdev = (gx_device_forward *)dev;
- gx_device *tdev = fdev->target;
- dev_proc_strip_copy_rop((*proc)) =
- (tdev == 0 ? (tdev = dev, gx_default_strip_copy_rop) :
- dev_proc(tdev, strip_copy_rop));
-
- return proc(tdev, sdata, sourcex, sraster, id, scolors,
- textures, tcolors, x, y, width, height,
- phase_x, phase_y, lop);
-}
-
-int
gx_forward_strip_copy_rop2(gx_device * dev, const byte * sdata, int sourcex,
uint sraster, gx_bitmap_id id,
const gx_color_index * scolors,
@@ -611,23 +470,13 @@ gx_forward_strip_copy_rop2(gx_device * dev, const byte * sdata, int sourcex,
gx_device_forward * const fdev = (gx_device_forward *)dev;
gx_device *tdev = fdev->target;
- if (planar_height != 0) {
- dev_proc_strip_copy_rop2((*proc2)) =
+ dev_proc_strip_copy_rop2((*proc2)) =
(tdev == 0 ? (tdev = dev, gx_default_strip_copy_rop2) :
dev_proc(tdev, strip_copy_rop2));
- return proc2(tdev, sdata, sourcex, sraster, id, scolors,
- textures, tcolors, x, y, width, height,
- phase_x, phase_y, lop, planar_height);
- } else {
- dev_proc_strip_copy_rop((*proc)) =
- (tdev == 0 ? (tdev = dev, gx_default_strip_copy_rop) :
- dev_proc(tdev, strip_copy_rop));
-
- return proc(tdev, sdata, sourcex, sraster, id, scolors,
- textures, tcolors, x, y, width, height,
- phase_x, phase_y, lop);
- }
+ return proc2(tdev, sdata, sourcex, sraster, id, scolors,
+ textures, tcolors, x, y, width, height,
+ phase_x, phase_y, lop, planar_height);
}
int
@@ -680,7 +529,7 @@ gx_forward_begin_typed_image(gx_device * dev, const gs_gstate * pgs,
int
gx_forward_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
- gs_get_bits_params_t * params, gs_int_rect ** unread)
+ gs_get_bits_params_t * params)
{
gx_device_forward * const fdev = (gx_device_forward *)dev;
gx_device *tdev = fdev->target;
@@ -688,18 +537,7 @@ gx_forward_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
(tdev == 0 ? (tdev = dev, gx_default_get_bits_rectangle) :
dev_proc(tdev, get_bits_rectangle));
- return proc(tdev, prect, params, unread);
-}
-
-int
-gx_forward_map_color_rgb_alpha(gx_device * dev, gx_color_index color,
- gx_color_value prgba[4])
-{
- gx_device_forward * const fdev = (gx_device_forward *)dev;
- gx_device *tdev = fdev->target;
-
- return (tdev == 0 ? gx_default_map_color_rgb_alpha(dev, color, prgba) :
- dev_proc(tdev, map_color_rgb_alpha)(tdev, color, prgba));
+ return proc(tdev, prect, params);
}
int
@@ -715,8 +553,7 @@ gx_forward_get_hardware_params(gx_device * dev, gs_param_list * plist)
int
gx_forward_text_begin(gx_device * dev, gs_gstate * pgs,
const gs_text_params_t * text, gs_font * font,
- gx_path * path, const gx_device_color * pdcolor,
- const gx_clip_path * pcpath, gs_memory_t * memory,
+ const gx_clip_path * pcpath,
gs_text_enum_t ** ppenum)
{
gx_device_forward * const fdev = (gx_device_forward *)dev;
@@ -725,8 +562,7 @@ gx_forward_text_begin(gx_device * dev, gs_gstate * pgs,
(tdev == 0 ? (tdev = dev, gx_default_text_begin) :
dev_proc(tdev, text_begin));
- return proc(tdev, pgs, text, font, path, pdcolor, pcpath,
- memory, ppenum);
+ return proc(tdev, pgs, text, font, pcpath, ppenum);
}
/* Forwarding device color mapping procs. */
@@ -735,15 +571,16 @@ gx_forward_text_begin(gx_device * dev, gs_gstate * pgs,
* We need to forward the color mapping to the target device.
*/
static void
-fwd_map_gray_cs(gx_device * dev, frac gray, frac out[])
+fwd_map_gray_cs(const gx_device * dev, frac gray, frac out[])
{
gx_device_forward * const fdev = (gx_device_forward *)dev;
gx_device * tdev = fdev->target;
- subclass_color_mappings scm;
+ const gx_device *cmdev;
+ const gx_cm_color_map_procs *cmprocs;
if (tdev) {
- scm = get_color_mapping_procs_subclass(tdev);
- map_gray_subclass(scm, gray, out);
+ cmprocs = dev_proc(tdev, get_color_mapping_procs)(tdev, &cmdev);
+ cmprocs->map_gray(cmdev, gray, out);
}
else
gray_cs_to_gray_cm(tdev, gray, out); /* if all else fails */
@@ -753,16 +590,17 @@ fwd_map_gray_cs(gx_device * dev, frac gray, frac out[])
* We need to forward the color mapping to the target device.
*/
static void
-fwd_map_rgb_cs(gx_device * dev, const gs_gstate *pgs,
+fwd_map_rgb_cs(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
gx_device_forward * const fdev = (gx_device_forward *)dev;
gx_device * tdev = fdev->target;
- subclass_color_mappings scm;
+ const gx_device *cmdev;
+ const gx_cm_color_map_procs *cmprocs;
if (tdev) {
- scm = get_color_mapping_procs_subclass(tdev);
- map_rgb_subclass(scm, pgs, r, g, b, out);
+ cmprocs = dev_proc(tdev, get_color_mapping_procs)(tdev, &cmdev);
+ cmprocs->map_rgb(cmdev, pgs, r, g, b, out);
}
else
rgb_cs_to_rgb_cm(tdev, pgs, r, g, b, out); /* if all else fails */
@@ -772,15 +610,16 @@ fwd_map_rgb_cs(gx_device * dev, const gs_gstate *pgs,
* We need to forward the color mapping to the target device.
*/
static void
-fwd_map_cmyk_cs(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+fwd_map_cmyk_cs(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
gx_device_forward * const fdev = (gx_device_forward *)dev;
gx_device * tdev = fdev->target;
- subclass_color_mappings scm;
+ const gx_device *cmdev;
+ const gx_cm_color_map_procs *cmprocs;
if (tdev) {
- scm = get_color_mapping_procs_subclass(tdev);
- map_cmyk_subclass(scm, c, m, y, k, out);
+ cmprocs = dev_proc(tdev, get_color_mapping_procs)(tdev, &cmdev);
+ cmprocs->map_cmyk(cmdev, c, m, y, k, out);
}
else
cmyk_cs_to_cmyk_cm(tdev, c, m, y, k, out); /* if all else fails */
@@ -797,13 +636,18 @@ static const gx_cm_color_map_procs FwdDevice_cm_map_procs = {
* device pointer).
*/
const gx_cm_color_map_procs *
-gx_forward_get_color_mapping_procs(const gx_device * dev)
+gx_forward_get_color_mapping_procs(const gx_device * dev, const gx_device **map_dev)
{
const gx_device_forward * fdev = (const gx_device_forward *)dev;
gx_device * tdev = fdev->target;
- return (tdev == 0 ? gx_default_DevGray_get_color_mapping_procs(dev)
- : &FwdDevice_cm_map_procs);
+ if (tdev)
+ return dev_proc(tdev, get_color_mapping_procs)(tdev, map_dev);
+
+ /* Testing in the cluster seems to indicate that we never get here,
+ * but we've written the code now... */
+ *map_dev = dev;
+ return &FwdDevice_cm_map_procs;
}
int
@@ -999,7 +843,7 @@ gx_forward_fillpage(gx_device *dev, gs_gstate * pgs, gx_device_color *pdevc)
}
int
-gx_forward_create_compositor(gx_device * dev, gx_device ** pcdev,
+gx_forward_composite(gx_device * dev, gx_device ** pcdev,
const gs_composite_t * pcte,
gs_gstate * pgs, gs_memory_t * memory,
gx_device *cdev)
@@ -1009,9 +853,9 @@ gx_forward_create_compositor(gx_device * dev, gx_device ** pcdev,
int code;
if (tdev == 0)
- return gx_no_create_compositor(dev, pcdev, pcte, pgs, memory, cdev);
+ return gx_no_composite(dev, pcdev, pcte, pgs, memory, cdev);
/* else do the compositor action */
- code = dev_proc(tdev, create_compositor)(tdev, pcdev, pcte, pgs, memory, cdev);
+ code = dev_proc(tdev, composite)(tdev, pcdev, pcte, pgs, memory, cdev);
/* the compositor may have changed color_info. Pick up the new value */
dev->color_info = tdev->color_info;
if (code == 1) {
@@ -1024,14 +868,14 @@ gx_forward_create_compositor(gx_device * dev, gx_device ** pcdev,
}
int
-gx_forward_get_profile(gx_device *dev, cmm_dev_profile_t **profile)
+gx_forward_get_profile(const gx_device *dev, cmm_dev_profile_t **profile)
{
gx_device_forward * const fdev = (gx_device_forward *)dev;
- gx_device *tdev = fdev->target;
- dev_proc_get_profile((*proc)) =
- (tdev == 0 ? (tdev = dev, gx_default_get_profile) :
- dev_proc(tdev, get_profile));
- return proc(tdev, profile);
+ const gx_device *tdev = fdev->target;
+
+ if (tdev == NULL)
+ return gx_default_get_profile(dev, profile);
+ return dev_proc(tdev, get_profile)(tdev, profile);
}
void
@@ -1080,7 +924,6 @@ static dev_proc_copy_mono(null_copy_mono);
static dev_proc_copy_color(null_copy_color);
static dev_proc_put_params(null_put_params);
static dev_proc_copy_alpha(null_copy_alpha);
-static dev_proc_copy_rop(null_copy_rop);
static dev_proc_fill_path(null_fill_path);
static dev_proc_stroke_path(null_stroke_path);
static dev_proc_fill_trapezoid(null_fill_trapezoid);
@@ -1091,105 +934,69 @@ static dev_proc_decode_color(null_decode_color);
/* We would like to have null implementations of begin/data/end image, */
/* but we can't do this, because image_data must keep track of the */
/* Y position so it can return 1 when done. */
-static dev_proc_strip_copy_rop(null_strip_copy_rop);
static dev_proc_strip_copy_rop2(null_strip_copy_rop2);
static dev_proc_strip_tile_rect_devn(null_strip_tile_rect_devn);
static dev_proc_fill_rectangle_hl_color(null_fill_rectangle_hl_color);
static dev_proc_dev_spec_op(null_spec_op);
-#define null_procs(get_initial_matrix, get_page_device) {\
- gx_default_open_device,\
- get_initial_matrix, /* differs */\
- gx_default_sync_output,\
- gx_default_output_page,\
- gx_default_close_device,\
- gx_forward_map_rgb_color,\
- gx_forward_map_color_rgb,\
- null_fill_rectangle,\
- gx_default_tile_rectangle,\
- null_copy_mono,\
- null_copy_color,\
- gx_default_draw_line,\
- gx_default_get_bits,\
- gx_forward_get_params,\
- null_put_params,\
- gx_forward_map_cmyk_color,\
- gx_forward_get_xfont_procs,\
- gx_forward_get_xfont_device,\
- gx_forward_map_rgb_alpha_color,\
- get_page_device, /* differs */\
- gx_default_get_alpha_bits,\
- null_copy_alpha,\
- gx_forward_get_band,\
- null_copy_rop,\
- null_fill_path,\
- null_stroke_path,\
- gx_default_fill_mask,\
- null_fill_trapezoid,\
- null_fill_parallelogram,\
- null_fill_triangle,\
- null_draw_thin_line,\
- gx_default_begin_image,\
- gx_default_image_data,\
- gx_default_end_image,\
- gx_default_strip_tile_rectangle,\
- null_strip_copy_rop,\
- gx_default_get_clipping_box,\
- gx_default_begin_typed_image,\
- gx_default_get_bits_rectangle,\
- gx_forward_map_color_rgb_alpha,\
- gx_non_imaging_create_compositor,\
- gx_forward_get_hardware_params,\
- gx_default_text_begin,\
- gx_default_finish_copydevice,\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL, /* discard_transparency_layer */\
- gx_default_DevGray_get_color_mapping_procs, /* get_color_mapping_procs */\
- gx_default_DevGray_get_color_comp_index,/* get_color_comp_index */\
- gx_default_gray_fast_encode, /* encode_color */\
- null_decode_color, /* decode_color */\
- NULL, /* pattern_manage */\
- null_fill_rectangle_hl_color,\
- gx_default_include_color_space,\
- NULL, /* fill_line_sl */\
- NULL, /* fill_line_tr */\
- NULL, /* fill_line_tri */\
- NULL, /* up_spot_eq_col */\
- gx_default_ret_devn_params, /* ret_devn_params */\
- NULL, /* fillpage */\
- NULL, /* push_transparency_state */\
- NULL, /* pop_transparency_state */\
- NULL, /* put_image */\
- null_spec_op, /* dev_spec_op */\
- NULL, /* copy_planes */\
- NULL, /* get_profile */\
- NULL, /* set_graphics_type_tag */\
- null_strip_copy_rop2,\
- null_strip_tile_rect_devn\
+static void
+null_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, get_initial_matrix, gx_forward_upright_get_initial_matrix);
+ set_dev_proc(dev, get_page_device, gx_default_get_page_device);
+ set_dev_proc(dev, map_rgb_color, gx_forward_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_forward_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, null_fill_rectangle);
+ set_dev_proc(dev, copy_mono, null_copy_mono);
+ set_dev_proc(dev, copy_color, null_copy_color);
+ set_dev_proc(dev, get_params, gx_forward_get_params);
+ set_dev_proc(dev, put_params, null_put_params);
+ set_dev_proc(dev, map_cmyk_color, gx_forward_map_cmyk_color);
+ set_dev_proc(dev, copy_alpha, null_copy_alpha);
+ set_dev_proc(dev, fill_path, null_fill_path);
+ set_dev_proc(dev, stroke_path, null_stroke_path);
+ set_dev_proc(dev, fill_trapezoid, null_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, null_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, null_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, null_draw_thin_line);
+ set_dev_proc(dev, composite, gx_non_imaging_composite);
+ set_dev_proc(dev, get_hardware_params, gx_forward_get_hardware_params);
+ set_dev_proc(dev, get_color_mapping_procs, gx_default_DevGray_get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, gx_default_DevGray_get_color_comp_index);
+ set_dev_proc(dev, encode_color, gx_default_gray_fast_encode);
+ set_dev_proc(dev, decode_color, null_decode_color);
+ set_dev_proc(dev, fill_rectangle_hl_color, null_fill_rectangle_hl_color);
+ set_dev_proc(dev, dev_spec_op, null_spec_op);
+ set_dev_proc(dev, strip_copy_rop2, null_strip_copy_rop2);
+ set_dev_proc(dev, strip_tile_rect_devn, null_strip_tile_rect_devn);
+}
+
+static void
+nullpage_initialize_device_procs(gx_device *dev)
+{
+ null_initialize_device_procs(dev);
+
+ set_dev_proc(dev, get_initial_matrix, gx_forward_get_initial_matrix);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
}
#define NULLD_X_RES 72
#define NULLD_Y_RES 72
const gx_device_null gs_null_device = {
- std_device_std_body_type_open(gx_device_null, 0, "null", &st_device_null,
- 0, 0, NULLD_X_RES, NULLD_Y_RES),
- null_procs(gx_forward_upright_get_initial_matrix, /* upright matrix */
- gx_default_get_page_device /* not a page device */ ),
- 0 /* target */
+ std_device_std_body_type_open(gx_device_null,
+ null_initialize_device_procs,
+ "null", &st_device_null,
+ 0, 0, NULLD_X_RES, NULLD_Y_RES)
};
const gx_device_null gs_nullpage_device = {
-std_device_std_body_type_open(gx_device_null, 0, "nullpage", &st_device_null,
+std_device_std_body_type_open(gx_device_null,
+ nullpage_initialize_device_procs,
+ "nullpage", &st_device_null,
(int)((float)(DEFAULT_WIDTH_10THS * NULLD_X_RES) / 10),
(int)((float)(DEFAULT_HEIGHT_10THS * NULLD_Y_RES) / 10),
- NULLD_X_RES, NULLD_Y_RES),
- null_procs( gx_forward_get_initial_matrix, /* default matrix */
- gx_page_device_get_page_device /* a page device */ ),
- 0 /* target */
+ NULLD_X_RES, NULLD_Y_RES)
};
static void
@@ -1261,16 +1068,6 @@ null_copy_alpha(gx_device * dev, const byte * data, int data_x, int raster,
return 0;
}
static int
-null_copy_rop(gx_device * dev,
- const byte * sdata, int sourcex, uint sraster, gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_tile_bitmap * texture, const gx_color_index * tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- return 0;
-}
-static int
null_fill_path(gx_device * dev, const gs_gstate * pgs,
gx_path * ppath, const gx_fill_params * params,
const gx_drawing_color * pdcolor, const gx_clip_path * pcpath)
@@ -1319,17 +1116,6 @@ null_draw_thin_line(gx_device * dev,
return 0;
}
static int
-null_strip_copy_rop(gx_device * dev, const byte * sdata, int sourcex,
- uint sraster, gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_strip_bitmap * textures,
- const gx_color_index * tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- return 0;
-}
-static int
null_strip_copy_rop2(gx_device * dev, const byte * sdata, int sourcex,
uint sraster, gx_bitmap_id id,
const gx_color_index * scolors,
@@ -1372,36 +1158,67 @@ null_spec_op(gx_device *pdev, int dev_spec_op, void *data, int size)
/* Defeat the ICC profile components check, which we want to do since
we also short-circuit ICC device parameters - see null_put_params.
*/
- if (dev_spec_op == gxdso_skip_icc_component_validation) {
+ if (dev_spec_op == gxdso_skip_icc_component_validation)
+ return 1;
+ if (dev_spec_op == gxdso_is_null_device)
return 1;
- }
return gx_default_dev_spec_op(pdev, dev_spec_op, data, size);
}
-bool
-fwd_uses_fwd_cmap_procs(gx_device * dev)
-{
- const gx_cm_color_map_procs *pprocs;
-
- pprocs = dev_proc(dev, get_color_mapping_procs)(dev);
- if (pprocs == &FwdDevice_cm_map_procs) {
- return true;
- }
- return false;
-}
-
-const gx_cm_color_map_procs*
-fwd_get_target_cmap_procs(gx_device * dev)
+void gx_forward_device_initialize_procs(gx_device *dev)
{
- const gx_cm_color_map_procs *pprocs;
- gx_device_forward * const fdev = (gx_device_forward *)dev;
- gx_device * const tdev = fdev->target;
-
- pprocs = dev_proc(tdev, get_color_mapping_procs(tdev));
- while (pprocs == &FwdDevice_cm_map_procs) {
- pprocs = fwd_get_target_cmap_procs(tdev);
- }
- return pprocs;
+ fill_dev_proc(dev, close_device, gx_forward_close_device);
+ fill_dev_proc(dev, get_initial_matrix, gx_forward_get_initial_matrix);
+ fill_dev_proc(dev, sync_output, gx_forward_sync_output);
+ fill_dev_proc(dev, output_page, gx_forward_output_page);
+ fill_dev_proc(dev, map_rgb_color, gx_forward_map_rgb_color);
+ fill_dev_proc(dev, map_color_rgb, gx_forward_map_color_rgb);
+ fill_dev_proc(dev, fill_rectangle, gx_forward_fill_rectangle);
+ fill_dev_proc(dev, copy_mono, gx_forward_copy_mono);
+ fill_dev_proc(dev, copy_color, gx_forward_copy_color);
+ fill_dev_proc(dev, get_params, gx_forward_get_params);
+ fill_dev_proc(dev, put_params, gx_forward_put_params);
+ fill_dev_proc(dev, map_cmyk_color, gx_forward_map_cmyk_color);
+ fill_dev_proc(dev, get_page_device, gx_forward_get_page_device);
+ fill_dev_proc(dev, get_alpha_bits, gx_forward_get_alpha_bits);
+ fill_dev_proc(dev, copy_alpha, gx_forward_copy_alpha);
+ fill_dev_proc(dev, fill_path, gx_forward_fill_path);
+ fill_dev_proc(dev, stroke_path, gx_forward_stroke_path);
+ fill_dev_proc(dev, fill_mask, gx_forward_fill_mask);
+ fill_dev_proc(dev, fill_trapezoid, gx_forward_fill_trapezoid);
+ fill_dev_proc(dev, fill_parallelogram, gx_forward_fill_parallelogram);
+ fill_dev_proc(dev, fill_triangle, gx_forward_fill_triangle);
+ fill_dev_proc(dev, draw_thin_line, gx_forward_draw_thin_line);
+ fill_dev_proc(dev, strip_tile_rectangle, gx_forward_strip_tile_rectangle);
+ fill_dev_proc(dev, get_clipping_box, gx_forward_get_clipping_box);
+ fill_dev_proc(dev, begin_typed_image, gx_forward_begin_typed_image);
+ fill_dev_proc(dev, get_bits_rectangle, gx_forward_get_bits_rectangle);
+ /* There is no forward_composite (see Drivers.htm). */
+ fill_dev_proc(dev, get_hardware_params, gx_forward_get_hardware_params);
+ fill_dev_proc(dev, text_begin, gx_forward_text_begin);
+ fill_dev_proc(dev, get_color_mapping_procs, gx_forward_get_color_mapping_procs);
+ fill_dev_proc(dev, get_color_comp_index, gx_forward_get_color_comp_index);
+ fill_dev_proc(dev, encode_color, gx_forward_encode_color);
+ fill_dev_proc(dev, decode_color, gx_forward_decode_color);
+ fill_dev_proc(dev, dev_spec_op, gx_forward_dev_spec_op);
+ fill_dev_proc(dev, fill_rectangle_hl_color, gx_forward_fill_rectangle_hl_color);
+ fill_dev_proc(dev, include_color_space, gx_forward_include_color_space);
+ fill_dev_proc(dev, fill_linear_color_scanline, gx_forward_fill_linear_color_scanline);
+ fill_dev_proc(dev, fill_linear_color_trapezoid, gx_forward_fill_linear_color_trapezoid);
+ fill_dev_proc(dev, fill_linear_color_triangle, gx_forward_fill_linear_color_triangle);
+ fill_dev_proc(dev, update_spot_equivalent_colors, gx_forward_update_spot_equivalent_colors);
+ fill_dev_proc(dev, ret_devn_params, gx_forward_ret_devn_params);
+ fill_dev_proc(dev, fillpage, gx_forward_fillpage);
+ fill_dev_proc(dev, put_image, gx_forward_put_image);
+ fill_dev_proc(dev, copy_planes, gx_forward_copy_planes);
+ fill_dev_proc(dev, composite, gx_forward_composite);
+ fill_dev_proc(dev, get_profile, gx_forward_get_profile);
+ fill_dev_proc(dev, set_graphics_type_tag, gx_forward_set_graphics_type_tag);
+ fill_dev_proc(dev, strip_copy_rop2, gx_forward_strip_copy_rop2);
+ fill_dev_proc(dev, strip_tile_rect_devn, gx_forward_strip_tile_rect_devn);
+ fill_dev_proc(dev, copy_alpha_hl_color, gx_forward_copy_alpha_hl_color);
+ fill_dev_proc(dev, transform_pixel_region, gx_forward_transform_pixel_region);
+ fill_dev_proc(dev, fill_stroke_path, gx_forward_fill_stroke_path);
}
#ifdef DEBUG
diff --git a/base/gdevnup.c b/base/gdevnup.c
index e1d79d1c..b9f4f356 100644
--- a/base/gdevnup.c
+++ b/base/gdevnup.c
@@ -86,92 +86,30 @@ static dev_proc_dev_spec_op(nup_dev_spec_op);
#define MAX_COORD (max_int_in_fixed - 1000)
#define MAX_RESOLUTION 4000
+static void
+nup_initialize_device_procs(gx_device *dev)
+{
+ default_subclass_initialize_device_procs(dev);
+
+ set_dev_proc(dev, get_initial_matrix, nup_get_initial_matrix);
+ set_dev_proc(dev, output_page, nup_output_page);
+ set_dev_proc(dev, close_device, nup_close_device);
+ set_dev_proc(dev, put_params, nup_put_params); /* to catch PageSize changes */
+ set_dev_proc(dev, fillpage, nup_fillpage);
+ set_dev_proc(dev, dev_spec_op, nup_dev_spec_op);
+}
+
const
gx_device_nup gs_nup_device =
{
/*
* Define the device as 8-bit gray scale to avoid computing halftones.
*/
- std_device_dci_type_body(gx_device_nup, 0, "N-up", &st_nup_device,
+ std_device_dci_type_body_sc(gx_device_nup, nup_initialize_device_procs,
+ "N-up", &st_nup_device,
MAX_COORD, MAX_COORD,
MAX_RESOLUTION, MAX_RESOLUTION,
- 1, 8, 255, 0, 256, 1),
- {default_subclass_open_device,
- nup_get_initial_matrix,
- default_subclass_sync_output, /* sync_output */
- nup_output_page,
- nup_close_device,
- default_subclass_map_rgb_color,
- default_subclass_map_color_rgb,
- default_subclass_fill_rectangle,
- default_subclass_tile_rectangle, /* tile_rectangle */
- default_subclass_copy_mono,
- default_subclass_copy_color,
- default_subclass_draw_line, /* draw_line */
- default_subclass_get_bits, /* get_bits */
- default_subclass_get_params,
- nup_put_params, /* to catch PageSize changes */
- default_subclass_map_cmyk_color,
- default_subclass_get_xfont_procs, /* get_xfont_procs */
- default_subclass_get_xfont_device, /* get_xfont_device */
- default_subclass_map_rgb_alpha_color,
- default_subclass_get_page_device,
- default_subclass_get_alpha_bits, /* get_alpha_bits */
- default_subclass_copy_alpha,
- default_subclass_get_band, /* get_band */
- default_subclass_copy_rop, /* copy_rop */
- default_subclass_fill_path,
- default_subclass_stroke_path,
- default_subclass_fill_mask,
- default_subclass_fill_trapezoid,
- default_subclass_fill_parallelogram,
- default_subclass_fill_triangle,
- default_subclass_draw_thin_line,
- default_subclass_begin_image,
- default_subclass_image_data, /* image_data */
- default_subclass_end_image, /* end_image */
- default_subclass_strip_tile_rectangle,
- default_subclass_strip_copy_rop,
- default_subclass_get_clipping_box, /* get_clipping_box */
- default_subclass_begin_typed_image,
- default_subclass_get_bits_rectangle, /* get_bits_rectangle */
- default_subclass_map_color_rgb_alpha,
- default_subclass_create_compositor,
- default_subclass_get_hardware_params, /* get_hardware_params */
- default_subclass_text_begin,
- default_subclass_finish_copydevice, /* finish_copydevice */
- default_subclass_begin_transparency_group, /* begin_transparency_group */
- default_subclass_end_transparency_group, /* end_transparency_group */
- default_subclass_begin_transparency_mask, /* begin_transparency_mask */
- default_subclass_end_transparency_mask, /* end_transparency_mask */
- default_subclass_discard_transparency_layer, /* discard_transparency_layer */
- default_subclass_get_color_mapping_procs, /* get_color_mapping_procs */
- default_subclass_get_color_comp_index, /* get_color_comp_index */
- default_subclass_encode_color, /* encode_color */
- default_subclass_decode_color, /* decode_color */
- default_subclass_pattern_manage, /* pattern_manage */
- default_subclass_fill_rectangle_hl_color, /* fill_rectangle_hl_color */
- default_subclass_include_color_space, /* include_color_space */
- default_subclass_fill_linear_color_scanline, /* fill_linear_color_scanline */
- default_subclass_fill_linear_color_trapezoid, /* fill_linear_color_trapezoid */
- default_subclass_fill_linear_color_triangle, /* fill_linear_color_triangle */
- default_subclass_update_spot_equivalent_colors, /* update_spot_equivalent_colors */
- default_subclass_ret_devn_params, /* ret_devn_params */
- nup_fillpage, /* fillpage */
- default_subclass_push_transparency_state, /* push_transparency_state */
- default_subclass_pop_transparency_state, /* pop_transparency_state */
- default_subclass_put_image, /* put_image */
- nup_dev_spec_op, /* for GetParam of PdfmarkCapable */
- default_subclass_copy_planes, /* copy_planes */
- default_subclass_get_profile, /* get_profile */
- default_subclass_set_graphics_type_tag, /* set_graphics_type_tag */
- default_subclass_strip_copy_rop2,
- default_subclass_strip_tile_rect_devn,
- default_subclass_copy_alpha_hl_color,
- default_subclass_process_page,
- default_subclass_transform_pixel_region,
- default_subclass_fill_stroke_path,
- }
+ 1, 8, 255, 0, 256, 1, NULL, NULL, NULL)
};
#undef MAX_COORD
@@ -291,7 +229,7 @@ nup_set_children_MediaSize(gx_device *dev, float PageW, float PageH)
}
static int
-nup_flush_nest_to_output(gx_device *dev, Nup_device_subclass_data *pNup_data, bool flush)
+nup_flush_nest_to_output(gx_device *dev, Nup_device_subclass_data *pNup_data)
{
int code = 0;
@@ -315,7 +253,7 @@ nup_close_device(gx_device *dev)
return code;
if (pNup_data->PageCount > 0)
- acode = nup_flush_nest_to_output(dev, pNup_data, true);
+ acode = nup_flush_nest_to_output(dev, pNup_data);
/* Reset the Nup control data */
/* NB: the data will be freed from non_gc_memory by the finalize function */
@@ -327,34 +265,6 @@ nup_close_device(gx_device *dev)
return min(code, acode);
}
- /*
- * Template:
- * BEGIN_ARRAY_PARAM(param_read_xxx_array, "pname", pxxa, size, pxxe) {
- * ... check value if desired ...
- * if (success)
- * break;
- * ... set ecode ...
- * } END_ARRAY_PARAM(pxxa, pxxe);
- */
-
-#define BEGIN_ARRAY_PARAM(pread, pname, pa, psize, e)\
- BEGIN\
- switch (code = pread(plist, (param_name = pname), &(pa))) {\
- case 0:\
- if ((pa).size != psize) {\
- ecode = gs_note_error(gs_error_rangecheck);\
- (pa).data = 0; /* mark as not filled */\
- } else
-#define END_ARRAY_PARAM(pa, e)\
- goto e;\
- default:\
- ecode = code;\
-e: param_signal_error(plist, param_name, ecode);\
- case 1:\
- (pa).data = 0; /* mark as not filled */\
- }\
- END
-
/* Read .MediaSize or, if supported as a synonym, PageSize. */
static int
param_MediaSize(gs_param_list * plist, gs_param_name pname,
@@ -364,26 +274,171 @@ param_MediaSize(gs_param_list * plist, gs_param_name pname,
int ecode = 0;
int code;
- BEGIN_ARRAY_PARAM(param_read_float_array, pname, *pa, 2, mse) {
- float width_new = pa->data[0] * res[0] / 72;
- float height_new = pa->data[1] * res[1] / 72;
-
- if (width_new < 0 || height_new < 0)
- ecode = gs_note_error(gs_error_rangecheck);
+ switch (code = param_read_float_array(plist, (param_name = pname), pa)) {
+ case 0:
+ if (pa->size != 2) {
+ ecode = gs_note_error(gs_error_rangecheck);
+ pa->data = 0; /* mark as not filled */
+ } else {
+ float width_new = pa->data[0] * res[0] / 72;
+ float height_new = pa->data[1] * res[1] / 72;
+
+ if (width_new < 0 || height_new < 0)
+ ecode = gs_note_error(gs_error_rangecheck);
#define max_coord (max_fixed / fixed_1)
#if max_coord < max_int
- else if (width_new > (long)max_coord || height_new > (long)max_coord)
- ecode = gs_note_error(gs_error_limitcheck);
+ else if (width_new > (long)max_coord || height_new > (long)max_coord)
+ ecode = gs_note_error(gs_error_limitcheck);
#endif
#undef max_coord
- else
- break;
- } END_ARRAY_PARAM(*pa, mse);
+ else
+ break;
+ }
+ goto err;
+ default:
+ ecode = code;
+err: param_signal_error(plist, param_name, ecode);
+ /* fall through */
+ case 1:
+ pa->data = 0; /* mark as not filled */
+ }
return ecode;
}
+/* Horrible hacked version of param_list_copy from gsparamx.c.
+ * Copy one parameter list to another, recursively if necessary,
+ * rewriting PageUsesTransparency to be true if it occurs. */
+static int
+copy_and_modify_sub(gs_param_list *plto, gs_param_list *plfrom, int *present)
+{
+ gs_param_enumerator_t key_enum;
+ gs_param_key_t key;
+ bool copy_persists;
+ int code;
+
+ if (present)
+ *present = 0;
+ if (plfrom == NULL)
+ return 0;
+
+ /* If plfrom and plto use different allocators, we must copy
+ * aggregate values even if they are "persistent". */
+ copy_persists = plto->memory == plfrom->memory;
+
+ param_init_enumerator(&key_enum);
+ while ((code = param_get_next_key(plfrom, &key_enum, &key)) == 0) {
+ char string_key[256]; /* big enough for any reasonable key */
+ gs_param_typed_value value;
+ gs_param_collection_type_t coll_type;
+ gs_param_typed_value copy;
+
+ if (key.size > sizeof(string_key) - 1) {
+ code = gs_note_error(gs_error_rangecheck);
+ break;
+ }
+ memcpy(string_key, key.data, key.size);
+ string_key[key.size] = 0;
+ if ((code = param_read_typed(plfrom, string_key, &value)) != 0) {
+ code = (code > 0 ? gs_note_error(gs_error_unknownerror) : code);
+ break;
+ }
+ gs_param_list_set_persistent_keys(plto, key.persistent);
+ switch (value.type) {
+ case gs_param_type_dict:
+ coll_type = gs_param_collection_dict_any;
+ goto cc;
+ case gs_param_type_dict_int_keys:
+ coll_type = gs_param_collection_dict_int_keys;
+ goto cc;
+ case gs_param_type_array:
+ coll_type = gs_param_collection_array;
+ cc:
+ copy.value.d.size = value.value.d.size;
+ if (copy.value.d.size == 0)
+ break;
+ if ((code = param_begin_write_collection(plto, string_key,
+ &copy.value.d,
+ coll_type)) < 0 ||
+ (code = copy_and_modify_sub(copy.value.d.list,
+ value.value.d.list,
+ NULL)) < 0 ||
+ (code = param_end_write_collection(plto, string_key,
+ &copy.value.d)) < 0)
+ break;
+ code = param_end_read_collection(plfrom, string_key,
+ &value.value.d);
+ break;
+ case gs_param_type_bool:
+ if (strcmp(string_key, "PageUsesTransparency") == 0 && present != NULL)
+ {
+ value.value.b = 1;
+ *present = 1;
+ }
+ goto ca;
+ case gs_param_type_string:
+ value.value.s.persistent &= copy_persists; goto ca;
+ case gs_param_type_name:
+ value.value.n.persistent &= copy_persists; goto ca;
+ case gs_param_type_int_array:
+ value.value.ia.persistent &= copy_persists; goto ca;
+ case gs_param_type_float_array:
+ value.value.fa.persistent &= copy_persists; goto ca;
+ case gs_param_type_string_array:
+ value.value.sa.persistent &= copy_persists;
+ /* fall through */
+ ca:
+ default:
+ code = param_write_typed(plto, string_key, &value);
+ }
+ if (code < 0)
+ break;
+ }
+ return code;
+}
+
static int
-nup_put_params(gx_device *dev, gs_param_list * plist)
+param_list_copy_and_modify(gs_param_list *plto, gs_param_list *plfrom)
+{
+ int found_put;
+ int code = copy_and_modify_sub(plto, plfrom, &found_put);
+
+ if (code >= 0 && !found_put) {
+ gs_param_typed_value value;
+ value.type = gs_param_type_bool;
+ value.value.b = 1;
+ code = param_write_typed(plto, "PageUsesTransparency", &value);
+ }
+
+ return code;
+}
+
+static int
+promote_errors(gs_param_list * plist_orig, gs_param_list * plist)
+{
+ gs_param_enumerator_t key_enum;
+ gs_param_key_t key;
+ int code;
+ int error;
+
+ param_init_enumerator(&key_enum);
+ while ((code = param_get_next_key(plist_orig, &key_enum, &key)) == 0) {
+ char string_key[256]; /* big enough for any reasonable key */
+
+ if (key.size > sizeof(string_key) - 1) {
+ code = gs_note_error(gs_error_rangecheck);
+ break;
+ }
+ memcpy(string_key, key.data, key.size);
+ string_key[key.size] = 0;
+ error = param_read_signalled_error(plist, string_key);
+ param_signal_error(plist_orig, string_key, error);
+ }
+
+ return code;
+}
+
+static int
+nup_put_params(gx_device *dev, gs_param_list * plist_orig)
{
int code, ecode = 0;
gs_param_float_array msa;
@@ -392,11 +447,29 @@ nup_put_params(gx_device *dev, gs_param_list * plist)
gs_param_string nuplist;
Nup_device_subclass_data* pNup_data = dev->subclass_data;
gx_device *next_dev;
+ gs_c_param_list *plist_c;
+ gs_param_list *plist;
#if 0000
-gs_param_list_dump(plist);
+gs_param_list_dump(plist_orig);
#endif
+ plist_c = gs_c_param_list_alloc(dev->memory->non_gc_memory, "nup_put_params");
+ plist = (gs_param_list *)plist_c;
+ if (plist == NULL)
+ return_error(gs_error_VMerror);
+ gs_c_param_list_write(plist_c, dev->memory->non_gc_memory);
+ gs_param_list_set_persistent_keys((gs_param_list *)plist_c, false);
+
+ /* Bulk copy the whole list. Can't enumerate and copy without it
+ * becoming an absolute nightmare due to the stupid way we handle
+ * 'collection' objects on writing. */
+ code = param_list_copy_and_modify((gs_param_list *)plist_c, plist_orig);
+ if (code < 0)
+ goto fail;
+
+ gs_c_param_list_read(plist_c);
+
code = param_read_string(plist, "NupControl", &nuplist);
if (code < 0)
ecode = code;
@@ -406,7 +479,7 @@ gs_param_list_dump(plist);
(strncmp(dev->NupControl->nupcontrol_str, (const char *)nuplist.data, nuplist.size) != 0))) {
/* If we have accumulated a nest when the NupControl changes, flush the nest */
if (pNup_data->PagesPerNest > 1 && pNup_data->PageCount > 0)
- code = nup_flush_nest_to_output(dev, pNup_data, true);
+ code = nup_flush_nest_to_output(dev, pNup_data);
if (code < 0)
ecode = code;
/* There was a NupControl, but this one is different -- no longer use the old one */
@@ -416,15 +489,18 @@ gs_param_list_dump(plist);
if (dev->NupControl == NULL && nuplist.size > 0) {
dev->NupControl = (gdev_nupcontrol *)gs_alloc_bytes(dev->memory->non_gc_memory,
sizeof(gdev_nupcontrol), "structure to hold nupcontrol_str");
- if (dev->NupControl == NULL)
- return gs_note_error(gs_error_VMerror);
+ if (dev->NupControl == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto fail;
+ }
dev->NupControl->nupcontrol_str = (void *)gs_alloc_bytes(dev->memory->non_gc_memory,
nuplist.size + 1, "nupcontrol string");
if (dev->NupControl->nupcontrol_str == NULL){
gs_free(dev->memory->non_gc_memory, dev->NupControl, 1, sizeof(gdev_nupcontrol),
"free structure to hold nupcontrol string");
dev->NupControl = 0;
- return gs_note_error(gs_error_VMerror);
+ code = gs_note_error(gs_error_VMerror);
+ goto fail;
}
memset(dev->NupControl->nupcontrol_str, 0x00, nuplist.size + 1);
memcpy(dev->NupControl->nupcontrol_str, nuplist.data, nuplist.size);
@@ -446,17 +522,21 @@ gs_param_list_dump(plist);
rc_increment(next_dev->NupControl);
next_dev = next_dev->parent;
}
- if (ecode < 0)
- return ecode;
+ if (ecode < 0) {
+ code = ecode;
+ goto fail;
+ }
}
code = ParseNupControl(dev, pNup_data); /* update the nesting params */
if (code < 0)
- return code;
+ goto fail;
/* If nesting is now off, just pass params on to children devices */
- if (pNup_data->PagesPerNest == 1)
- return default_subclass_put_params(dev, plist);
+ if (pNup_data->PagesPerNest == 1) {
+ code = default_subclass_put_params(dev, plist);
+ goto fail; /* Not actually failing! */
+ }
/* .MediaSize takes precedence over PageSize, so we read PageSize first. */
code = param_MediaSize(plist, "PageSize", res, &msa);
@@ -468,34 +548,54 @@ gs_param_list_dump(plist);
code = param_MediaSize(plist, ".MediaSize", res, &msa);
if (code < 0)
ecode = code;
- else if (msa.data == 0)
+ else if (msa.data == NULL)
msa.data = data;
- if (ecode < 0)
- return ecode;
+ if (ecode < 0) {
+ code = ecode;
+ goto fail;
+ }
/* If there was PageSize or .MediaSize, update the NestedPage size */
- if (msa.data != 0) {
+ if (msa.data != NULL) {
Nup_device_subclass_data *pNup_data = dev->subclass_data;
+ /* Calculate the page sizes as ints to allow for tiny changes
+ * of width that don't actually make a difference. */
+ int w1 = (int)(pNup_data->NestedPageW * dev->HWResolution[0] / 72.0f + 0.5f);
+ int w2 = (int)(msa.data[0] * dev->HWResolution[0] / 72.0f + 0.5f);
+ int h1 = (int)(pNup_data->NestedPageH * dev->HWResolution[1] / 72.0f + 0.5f);
+ int h2 = (int)(msa.data[1] * dev->HWResolution[1] / 72.0f + 0.5f);
/* FIXME: Handle changing size (if previous value was non-zero) */
- if (msa.data[0] != pNup_data->NestedPageW || msa.data[1] != pNup_data->NestedPageH) {
+ if (w1 != w2 || h1 != h2) {
/* If needed, flush previous nest before changing */
if (pNup_data->PageCount > 0 && pNup_data->PagesPerNest > 1) {
- code = nup_flush_nest_to_output(dev, pNup_data, true);
+ code = nup_flush_nest_to_output(dev, pNup_data);
if (code < 0)
- return code;
+ goto fail;
}
pNup_data->NestedPageW = msa.data[0];
pNup_data->NestedPageH = msa.data[1];
/* And update the Nup parameters based on the updated PageSize */
code = ParseNupControl(dev, pNup_data);
if (code < 0)
- return code;
+ goto fail;
}
}
/* now that we've intercepted PageSize and/or MediaSize, pass the rest along */
code = default_subclass_put_params(dev, plist);
+
+ /* Now promote errors from the copied list to the original list. */
+ {
+ int ecode = promote_errors(plist_orig, plist);
+ if (code == 0)
+ code = ecode;
+ }
+
+fail:
+ gs_c_param_list_release(plist_c);
+ gs_free_object(dev->memory->non_gc_memory, plist_c, "nup_put_params");
+
return code;
}
@@ -519,11 +619,19 @@ nup_output_page(gx_device *dev, int num_copies, int flush)
}
/* FIXME: Handle num_copies > 1 */
+
+ /* pNup_data holds the number of 'sub pages' we have produced,
+ * so update that. dev->PageCount holds the number of 'actual'
+ * pages we've output, so only increment that if we really
+ * do an output. */
pNup_data->PageCount++;
- dev->PageCount++;
dev->ShowpageCount = dev->child->ShowpageCount;
- if (pNup_data->PageCount >= pNup_data->PagesPerNest)
- code = nup_flush_nest_to_output(dev, pNup_data, flush);
+ if (pNup_data->PageCount >= pNup_data->PagesPerNest) {
+ code = nup_flush_nest_to_output(dev, pNup_data);
+ /* Increment this afterwards, in case the child accesses
+ * the value to fill in a %d in the filename. */
+ dev->PageCount++;
+ }
return code;
}
@@ -591,3 +699,36 @@ nup_dev_spec_op(gx_device *dev, int dev_spec_op, void *data, int size)
}
return default_subclass_dev_spec_op(dev, dev_spec_op, data, size);
}
+
+int gx_device_nup_device_install(gx_device *dev)
+{
+ gs_param_typed_value value;
+ gs_c_param_list *plist_c;
+ int code;
+
+ code = gx_device_subclass(dev, (gx_device *)&gs_nup_device, sizeof(Nup_device_subclass_data));
+ if (code < 0)
+ return code;
+
+ /* Ensure that PageUsesTransparency is set. */
+ plist_c = gs_c_param_list_alloc(dev->memory->non_gc_memory, "nup_open_device");
+ if (plist_c == NULL)
+ return_error(gs_error_VMerror);
+ gs_c_param_list_write(plist_c, dev->memory->non_gc_memory);
+ gs_param_list_set_persistent_keys((gs_param_list *)plist_c, false);
+
+ value.type = gs_param_type_bool;
+ value.value.b = 1;
+ code = param_write_typed((gs_param_list *)plist_c, "PageUsesTransparency", &value);
+ if (code >= 0) {
+ gs_c_param_list_read(plist_c);
+
+ code = default_subclass_put_params(dev, (gs_param_list *)plist_c);
+ if (code >= 0)
+ code = default_subclass_open_device(dev->child);
+ }
+ gs_c_param_list_release(plist_c);
+ gs_free_object(dev->memory->non_gc_memory, plist_c, "nup_open_device");
+
+ return code;
+}
diff --git a/base/gdevnup.h b/base/gdevnup.h
index a8b34c4b..51cf24eb 100644
--- a/base/gdevnup.h
+++ b/base/gdevnup.h
@@ -23,8 +23,7 @@
typedef struct gx_device_s gx_device_nup;
-/* Initialize device. */
-void gx_device_nup_device_init(gx_device_nup * dev);
+int gx_device_nup_device_install(gx_device *dev);
typedef struct {
subclass_common;
diff --git a/base/gdevoflt.c b/base/gdevoflt.c
index e7fc3809..98f16f49 100644
--- a/base/gdevoflt.c
+++ b/base/gdevoflt.c
@@ -44,8 +44,6 @@ private_st_obj_filter_text_enum();
/* Device procedures, we need to implement all of them */
static dev_proc_fill_rectangle(obj_filter_fill_rectangle);
-static dev_proc_tile_rectangle(obj_filter_tile_rectangle);
-static dev_proc_draw_line(obj_filter_draw_line);
static dev_proc_fill_path(obj_filter_fill_path);
static dev_proc_stroke_path(obj_filter_stroke_path);
static dev_proc_fill_mask(obj_filter_fill_mask);
@@ -53,11 +51,7 @@ static dev_proc_fill_trapezoid(obj_filter_fill_trapezoid);
static dev_proc_fill_parallelogram(obj_filter_fill_parallelogram);
static dev_proc_fill_triangle(obj_filter_fill_triangle);
static dev_proc_draw_thin_line(obj_filter_draw_thin_line);
-static dev_proc_begin_image(obj_filter_begin_image);
-static dev_proc_image_data(obj_filter_image_data);
-static dev_proc_end_image(obj_filter_end_image);
static dev_proc_strip_tile_rectangle(obj_filter_strip_tile_rectangle);
-static dev_proc_strip_copy_rop(obj_filter_strip_copy_rop);
static dev_proc_begin_typed_image(obj_filter_begin_typed_image);
static dev_proc_text_begin(obj_filter_text_begin);
static dev_proc_fill_rectangle_hl_color(obj_filter_fill_rectangle_hl_color);
@@ -92,92 +86,44 @@ RELOC_PTRS_END
public_st_obj_filter_device();
+static void
+obj_filter_initialize_device_procs(gx_device *dev)
+{
+ default_subclass_initialize_device_procs(dev);
+
+ set_dev_proc(dev, fill_rectangle, obj_filter_fill_rectangle);
+ set_dev_proc(dev, fill_path, obj_filter_fill_path);
+ set_dev_proc(dev, stroke_path, obj_filter_stroke_path);
+ set_dev_proc(dev, fill_mask, obj_filter_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, obj_filter_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, obj_filter_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, obj_filter_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, obj_filter_draw_thin_line);
+ set_dev_proc(dev, strip_tile_rectangle, obj_filter_strip_tile_rectangle);
+ set_dev_proc(dev, begin_typed_image, obj_filter_begin_typed_image);
+ set_dev_proc(dev, text_begin, obj_filter_text_begin);
+ set_dev_proc(dev, fill_rectangle_hl_color, obj_filter_fill_rectangle_hl_color);
+ set_dev_proc(dev, fill_linear_color_scanline, obj_filter_fill_linear_color_scanline);
+ set_dev_proc(dev, fill_linear_color_trapezoid, obj_filter_fill_linear_color_trapezoid);
+ set_dev_proc(dev, fill_linear_color_triangle, obj_filter_fill_linear_color_triangle);
+ set_dev_proc(dev, put_image, obj_filter_put_image);
+ set_dev_proc(dev, strip_copy_rop2, obj_filter_strip_copy_rop2);
+ set_dev_proc(dev, strip_tile_rect_devn, obj_filter_strip_tile_rect_devn);
+ set_dev_proc(dev, fill_stroke_path, obj_filter_fill_stroke_path);
+}
+
const
gx_device_obj_filter gs_obj_filter_device =
{
/*
* Define the device as 8-bit gray scale to avoid computing halftones.
*/
- std_device_dci_type_body(gx_device_obj_filter, 0, "object_filter", &st_obj_filter_device,
+ std_device_dci_type_body_sc(gx_device_obj_filter,
+ obj_filter_initialize_device_procs,
+ "object_filter", &st_obj_filter_device,
MAX_COORD, MAX_COORD,
MAX_RESOLUTION, MAX_RESOLUTION,
- 1, 8, 255, 0, 256, 1),
- {default_subclass_open_device,
- default_subclass_get_initial_matrix,
- default_subclass_sync_output, /* sync_output */
- default_subclass_output_page,
- default_subclass_close_device,
- default_subclass_map_rgb_color,
- default_subclass_map_color_rgb,
- obj_filter_fill_rectangle,
- obj_filter_tile_rectangle, /* tile_rectangle */
- default_subclass_copy_mono,
- default_subclass_copy_color,
- obj_filter_draw_line, /* draw_line */
- default_subclass_get_bits, /* get_bits */
- default_subclass_get_params,
- default_subclass_put_params,
- default_subclass_map_cmyk_color,
- default_subclass_get_xfont_procs, /* get_xfont_procs */
- default_subclass_get_xfont_device, /* get_xfont_device */
- default_subclass_map_rgb_alpha_color,
- default_subclass_get_page_device,
- default_subclass_get_alpha_bits, /* get_alpha_bits */
- default_subclass_copy_alpha,
- default_subclass_get_band, /* get_band */
- default_subclass_copy_rop, /* copy_rop */
- obj_filter_fill_path,
- obj_filter_stroke_path,
- obj_filter_fill_mask,
- obj_filter_fill_trapezoid,
- obj_filter_fill_parallelogram,
- obj_filter_fill_triangle,
- obj_filter_draw_thin_line,
- obj_filter_begin_image,
- obj_filter_image_data, /* image_data */
- obj_filter_end_image, /* end_image */
- obj_filter_strip_tile_rectangle,
- obj_filter_strip_copy_rop,
- default_subclass_get_clipping_box, /* get_clipping_box */
- obj_filter_begin_typed_image,
- default_subclass_get_bits_rectangle, /* get_bits_rectangle */
- default_subclass_map_color_rgb_alpha,
- default_subclass_create_compositor,
- default_subclass_get_hardware_params, /* get_hardware_params */
- obj_filter_text_begin,
- default_subclass_finish_copydevice, /* finish_copydevice */
- default_subclass_begin_transparency_group, /* begin_transparency_group */
- default_subclass_end_transparency_group, /* end_transparency_group */
- default_subclass_begin_transparency_mask, /* begin_transparency_mask */
- default_subclass_end_transparency_mask, /* end_transparency_mask */
- default_subclass_discard_transparency_layer, /* discard_transparency_layer */
- default_subclass_get_color_mapping_procs, /* get_color_mapping_procs */
- default_subclass_get_color_comp_index, /* get_color_comp_index */
- default_subclass_encode_color, /* encode_color */
- default_subclass_decode_color, /* decode_color */
- default_subclass_pattern_manage, /* pattern_manage */
- obj_filter_fill_rectangle_hl_color, /* fill_rectangle_hl_color */
- default_subclass_include_color_space, /* include_color_space */
- obj_filter_fill_linear_color_scanline, /* fill_linear_color_scanline */
- obj_filter_fill_linear_color_trapezoid, /* fill_linear_color_trapezoid */
- obj_filter_fill_linear_color_triangle, /* fill_linear_color_triangle */
- default_subclass_update_spot_equivalent_colors, /* update_spot_equivalent_colors */
- default_subclass_ret_devn_params, /* ret_devn_params */
- default_subclass_fillpage, /* fillpage */
- default_subclass_push_transparency_state, /* push_transparency_state */
- default_subclass_pop_transparency_state, /* pop_transparency_state */
- obj_filter_put_image, /* put_image */
- default_subclass_dev_spec_op, /* dev_spec_op */
- default_subclass_copy_planes, /* copy_planes */
- default_subclass_get_profile, /* get_profile */
- default_subclass_set_graphics_type_tag, /* set_graphics_type_tag */
- obj_filter_strip_copy_rop2,
- obj_filter_strip_tile_rect_devn,
- default_subclass_copy_alpha_hl_color,
- default_subclass_process_page,
- default_subclass_transform_pixel_region,
- obj_filter_fill_stroke_path,
- }
+ 1, 8, 255, 0, 256, 1, NULL, NULL, NULL)
};
#undef MAX_COORD
@@ -190,22 +136,6 @@ int obj_filter_fill_rectangle(gx_device *dev, int x, int y, int width, int heigh
return 0;
}
-int obj_filter_tile_rectangle(gx_device *dev, const gx_tile_bitmap *tile, int x, int y, int width, int height,
- gx_color_index color0, gx_color_index color1,
- int phase_x, int phase_y)
-{
- if ((dev->ObjectFilter & FILTERVECTOR) == 0)
- return default_subclass_tile_rectangle(dev, tile, x, y, width, height, color0, color1, phase_x, phase_y);
- return 0;
-}
-
-int obj_filter_draw_line(gx_device *dev, int x0, int y0, int x1, int y1, gx_color_index color)
-{
- if ((dev->ObjectFilter & FILTERVECTOR) == 0)
- return default_subclass_draw_line(dev, x0, y0, x1, y1, color);
- return 0;
-}
-
int obj_filter_fill_path(gx_device *dev, const gs_gstate *pgs, gx_path *ppath,
const gx_fill_params *params,
const gx_drawing_color *pdcolor, const gx_clip_path *pcpath)
@@ -278,31 +208,6 @@ int obj_filter_draw_thin_line(gx_device *dev, fixed fx0, fixed fy0, fixed fx1, f
return 0;
}
-int obj_filter_begin_image(gx_device *dev, const gs_gstate *pgs, const gs_image_t *pim,
- gs_image_format_t format, const gs_int_rect *prect,
- const gx_drawing_color *pdcolor, const gx_clip_path *pcpath,
- gs_memory_t *memory, gx_image_enum_common_t **pinfo)
-{
- if ((dev->ObjectFilter & FILTERIMAGE) == 0)
- return default_subclass_begin_image(dev, pgs, pim, format, prect, pdcolor, pcpath, memory, pinfo);
- return 0;
-}
-
-int obj_filter_image_data(gx_device *dev, gx_image_enum_common_t *info, const byte **planes, int data_x,
- uint raster, int height)
-{
- if ((dev->ObjectFilter & FILTERIMAGE) == 0)
- return default_subclass_image_data(dev, info, planes, data_x, raster, height);
- return 0;
-}
-
-int obj_filter_end_image(gx_device *dev, gx_image_enum_common_t *info, bool draw_last)
-{
- if ((dev->ObjectFilter & FILTERIMAGE) == 0)
- return default_subclass_end_image(dev, info, draw_last);
- return 0;
-}
-
int obj_filter_strip_tile_rectangle(gx_device *dev, const gx_strip_bitmap *tiles, int x, int y, int width, int height,
gx_color_index color0, gx_color_index color1,
int phase_x, int phase_y)
@@ -312,17 +217,6 @@ int obj_filter_strip_tile_rectangle(gx_device *dev, const gx_strip_bitmap *tiles
return 0;
}
-int obj_filter_strip_copy_rop(gx_device *dev, const byte *sdata, int sourcex, uint sraster, gx_bitmap_id id,
- const gx_color_index *scolors,
- const gx_strip_bitmap *textures, const gx_color_index *tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- if ((dev->ObjectFilter & FILTERIMAGE) == 0)
- return default_subclass_strip_copy_rop(dev, sdata, sourcex, sraster, id, scolors, textures, tcolors, x, y, width, height, phase_x, phase_y, lop);
- return 0;
-}
-
typedef struct obj_filter_image_enum_s {
gx_image_enum_common;
int y;
@@ -474,11 +368,12 @@ static const gs_text_enum_procs_t obj_filter_text_procs = {
* up to the device, in which case we simply pass on the 'begin' method to the device.
*/
int obj_filter_text_begin(gx_device *dev, gs_gstate *pgs, const gs_text_params_t *text,
- gs_font *font, gx_path *path, const gx_device_color *pdcolor, const gx_clip_path *pcpath,
- gs_memory_t *memory, gs_text_enum_t **ppte)
+ gs_font *font, const gx_clip_path *pcpath,
+ gs_text_enum_t **ppte)
{
obj_filter_text_enum_t *penum;
int code = 0;
+ gs_memory_t * memory = pgs->memory;
/* We don't want to simply ignore stringwidth for 2 reasons;
* firstly because following elelments may be positioned based on the value returned
@@ -490,16 +385,16 @@ int obj_filter_text_begin(gx_device *dev, gs_gstate *pgs, const gs_text_params_t
* stringwidth operation, or they won;t be able to cache the glyphs properly.
* So always pass stringwidth operations to the child.
*/
- return default_subclass_text_begin(dev, pgs, text, font, path, pdcolor, pcpath, memory, ppte);
+ return default_subclass_text_begin(dev, pgs, text, font, pcpath, ppte);
if ((dev->ObjectFilter & FILTERTEXT) == 0)
- return default_subclass_text_begin(dev, pgs, text, font, path, pdcolor, pcpath, memory, ppte);
+ return default_subclass_text_begin(dev, pgs, text, font, pcpath, ppte);
rc_alloc_struct_1(penum, obj_filter_text_enum_t, &st_obj_filter_text_enum, memory,
return_error(gs_error_VMerror), "gdev_obj_filter_text_begin");
penum->rc.free = rc_free_text_enum;
code = gs_text_enum_init((gs_text_enum_t *)penum, &obj_filter_text_procs,
- dev, pgs, text, font, path, pdcolor, pcpath, memory);
+ dev, pgs, text, font, pcpath, memory);
if (code < 0) {
gs_free_object(memory, penum, "gdev_obj_filter_text_begin");
return code;
diff --git a/base/gdevp14.c b/base/gdevp14.c
index 8819ad90..d7992bc4 100644
--- a/base/gdevp14.c
+++ b/base/gdevp14.c
@@ -69,6 +69,7 @@
#define CAL_SLOP 0
#endif
#include "assert_.h"
+#include "gxgetbit.h"
#if RAW_DUMP
unsigned int global_index = 0;
@@ -119,7 +120,7 @@ static int pdf14_increment_smask_color(gs_gstate * pgs, gx_device * dev);
# define INCR(v) DO_NOTHING
/* Forward prototypes */
-void pdf14_cmyk_cs_to_cmyk_cm(gx_device *, frac, frac, frac, frac, frac *);
+void pdf14_cmyk_cs_to_cmyk_cm(const gx_device *, frac, frac, frac, frac, frac *);
static int gs_pdf14_device_push(gs_memory_t *mem, gs_gstate * pgs,
gx_device ** pdev, gx_device * target,
const gs_pdf14trans_t * pdf14pct);
@@ -168,6 +169,8 @@ gs_private_st_ptrs1(st_pdf14_smaskcolor, pdf14_smaskcolor_t, "pdf14_smaskcolor",
#define X_DPI 72
#define Y_DPI 72
+static int pdf14_initialize_device(gx_device *dev);
+
static int pdf14_open(gx_device * pdev);
static dev_proc_close_device(pdf14_close);
static int pdf14_output_page(gx_device * pdev, int num_copies, int flush);
@@ -193,9 +196,8 @@ static dev_proc_fill_mask(pdf14_fill_mask);
static dev_proc_stroke_path(pdf14_stroke_path);
static dev_proc_begin_typed_image(pdf14_begin_typed_image);
static dev_proc_text_begin(pdf14_text_begin);
-static dev_proc_finish_copydevice(pdf14_finish_copydevice);
-static dev_proc_create_compositor(pdf14_create_compositor);
-static dev_proc_create_compositor(pdf14_forward_create_compositor);
+static dev_proc_composite(pdf14_composite);
+static dev_proc_composite(pdf14_forward_composite);
static dev_proc_begin_transparency_group(pdf14_begin_transparency_group);
static dev_proc_end_transparency_group(pdf14_end_transparency_group);
static dev_proc_begin_transparency_mask(pdf14_begin_transparency_mask);
@@ -218,121 +220,121 @@ static const gx_color_map_procs *
/* 24-bit color. */
-#define pdf14_dev_procs(get_color_mapping_procs, get_color_comp_index, encode_color, decode_color) \
-{\
- pdf14_open, /* open */\
- NULL, /* get_initial_matrix */\
- NULL, /* sync_output */\
- pdf14_output_page, /* output_page */\
- pdf14_close, /* close */\
- encode_color, /* rgb_map_rgb_color */\
- decode_color, /* gx_default_rgb_map_color_rgb */\
- pdf14_fill_rectangle, /* fill_rectangle */\
- NULL, /* tile_rectangle */\
- pdf14_copy_mono, /* copy_mono */\
- NULL, /* copy_color */\
- NULL, /* draw_line */\
- NULL, /* get_bits */\
- gx_forward_get_params, /* get_params */\
- pdf14_put_params, /* put_params */\
- NULL, /* map_cmyk_color */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- NULL, /* get_page_device */\
- NULL, /* get_alpha_bits */\
- pdf14_copy_alpha, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- pdf14_fill_path, /* fill_path */\
- pdf14_stroke_path, /* stroke_path */\
- pdf14_fill_mask, /* fill_mask */\
- NULL, /* fill_trapezoid */\
- NULL, /* fill_parallelogram */\
- NULL, /* fill_triangle */\
- NULL, /* draw_thin_line */\
- NULL, /* begin_image */\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL, /* strip_copy_rop, */\
- NULL, /* get_clipping_box */\
- pdf14_begin_typed_image, /* begin_typed_image */\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- pdf14_create_compositor, /* create_compositor */\
- NULL, /* get_hardware_params */\
- pdf14_text_begin, /* text_begin */\
- pdf14_finish_copydevice, /* finish_copydevice */\
- pdf14_begin_transparency_group,\
- pdf14_end_transparency_group,\
- pdf14_begin_transparency_mask,\
- pdf14_end_transparency_mask,\
- pdf14_discard_trans_layer,\
- get_color_mapping_procs, /* get_color_mapping_procs */\
- get_color_comp_index, /* get_color_comp_index */\
- encode_color, /* encode_color */\
- decode_color, /* decode_color */\
- NULL, /* pattern_manage */\
- pdf14_fill_rectangle_hl_color, /* fill_rectangle_hl_color */\
- NULL, /* include_color_space */\
- NULL, /* fill_linear_color_scanline */\
- NULL, /* fill_linear_color_trapezoid */\
- NULL, /* fill_linear_color_triangle */\
- gx_forward_update_spot_equivalent_colors, /* update spot */\
- pdf14_ret_devn_params, /* DevN params */\
- NULL, /* fill page */\
- pdf14_push_transparency_state, /* push_transparency_state */\
- pdf14_pop_transparency_state, /* pop_transparency_state */\
- NULL, /* put_image */\
- pdf14_dev_spec_op, /* dev_spec_op */\
- pdf14_copy_planes, /* copy_planes */\
- NULL, /* */\
- gx_forward_set_graphics_type_tag, /* set_graphics_type_tag */\
- NULL, /* strip_copy_rop2 */\
- pdf14_strip_tile_rect_devn, /* strip_tile_rect_devn */\
- pdf14_copy_alpha_hl_color, /* copy_alpha_hl_color */\
- NULL, /* process_page */\
- NULL, /* transform_pixel_region */\
- pdf14_fill_stroke_path, /* fill_stroke */\
-}
-
-static const gx_device_procs pdf14_Gray_procs =
- pdf14_dev_procs(gx_default_DevGray_get_color_mapping_procs,
- gx_default_DevGray_get_color_comp_index,
- pdf14_encode_color, pdf14_decode_color);
-
-static const gx_device_procs pdf14_RGB_procs =
- pdf14_dev_procs(gx_default_DevRGB_get_color_mapping_procs,
- gx_default_DevRGB_get_color_comp_index,
- pdf14_encode_color, pdf14_decode_color);
-
-static const gx_device_procs pdf14_CMYK_procs =
- pdf14_dev_procs(gx_default_DevCMYK_get_color_mapping_procs,
- gx_default_DevCMYK_get_color_comp_index,
- pdf14_encode_color, pdf14_decode_color);
-
-static const gx_device_procs pdf14_CMYKspot_procs =
- pdf14_dev_procs(pdf14_cmykspot_get_color_mapping_procs,
- pdf14_cmykspot_get_color_comp_index,
- pdf14_encode_color, pdf14_decode_color);
-
-static const gx_device_procs pdf14_RGBspot_procs =
- pdf14_dev_procs(pdf14_rgbspot_get_color_mapping_procs,
- pdf14_rgbspot_get_color_comp_index,
- pdf14_encode_color, pdf14_decode_color);
-
-static const gx_device_procs pdf14_Grayspot_procs =
-pdf14_dev_procs(pdf14_grayspot_get_color_mapping_procs,
- pdf14_grayspot_get_color_comp_index,
- pdf14_encode_color, pdf14_decode_color);
-
-
-static const gx_device_procs pdf14_custom_procs =
- pdf14_dev_procs(gx_forward_get_color_mapping_procs,
- gx_forward_get_color_comp_index,
- gx_forward_encode_color,
- gx_forward_decode_color);
+static void
+pdf14_procs_initialize(gx_device *dev,
+ dev_proc_get_color_mapping_procs(get_color_mapping_procs),
+ dev_proc_get_color_comp_index(get_color_comp_index),
+ dev_proc_encode_color(encode_color),
+ dev_proc_decode_color(decode_color))
+{
+ set_dev_proc(dev, initialize_device, pdf14_initialize_device);
+ set_dev_proc(dev, open_device, pdf14_open);
+ set_dev_proc(dev, output_page, pdf14_output_page);
+ set_dev_proc(dev, close_device, pdf14_close);
+ set_dev_proc(dev, map_rgb_color, encode_color);
+ set_dev_proc(dev, map_color_rgb, decode_color);
+ set_dev_proc(dev, fill_rectangle, pdf14_fill_rectangle);
+ set_dev_proc(dev, copy_mono, pdf14_copy_mono);
+ set_dev_proc(dev, get_params, gx_forward_get_params);
+ set_dev_proc(dev, put_params, pdf14_put_params);
+ set_dev_proc(dev, copy_alpha, pdf14_copy_alpha);
+ set_dev_proc(dev, fill_path, pdf14_fill_path);
+ set_dev_proc(dev, stroke_path, pdf14_stroke_path);
+ set_dev_proc(dev, fill_mask, pdf14_fill_mask);
+ set_dev_proc(dev, begin_typed_image, pdf14_begin_typed_image);
+ set_dev_proc(dev, composite, pdf14_composite);
+ set_dev_proc(dev, text_begin, pdf14_text_begin);
+ set_dev_proc(dev, begin_transparency_group, pdf14_begin_transparency_group);
+ set_dev_proc(dev, end_transparency_group, pdf14_end_transparency_group);
+ set_dev_proc(dev, begin_transparency_mask, pdf14_begin_transparency_mask);
+ set_dev_proc(dev, end_transparency_mask, pdf14_end_transparency_mask);
+ set_dev_proc(dev, discard_transparency_layer, pdf14_discard_trans_layer);
+ set_dev_proc(dev, get_color_mapping_procs, get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, get_color_comp_index);
+ set_dev_proc(dev, encode_color, encode_color);
+ set_dev_proc(dev, decode_color, decode_color);
+ set_dev_proc(dev, fill_rectangle_hl_color, pdf14_fill_rectangle_hl_color);
+ set_dev_proc(dev, update_spot_equivalent_colors, gx_forward_update_spot_equivalent_colors);
+ set_dev_proc(dev, ret_devn_params, pdf14_ret_devn_params);
+ set_dev_proc(dev, push_transparency_state, pdf14_push_transparency_state);
+ set_dev_proc(dev, pop_transparency_state, pdf14_pop_transparency_state);
+ set_dev_proc(dev, dev_spec_op, pdf14_dev_spec_op);
+ set_dev_proc(dev, copy_planes, pdf14_copy_planes);
+ set_dev_proc(dev, set_graphics_type_tag, gx_forward_set_graphics_type_tag);
+ set_dev_proc(dev, strip_tile_rect_devn, pdf14_strip_tile_rect_devn);
+ set_dev_proc(dev, copy_alpha_hl_color, pdf14_copy_alpha_hl_color);
+ set_dev_proc(dev, fill_stroke_path, pdf14_fill_stroke_path);
+}
+
+static void
+pdf14_Gray_initialize_device_procs(gx_device *dev)
+{
+ pdf14_procs_initialize(dev,
+ gx_default_DevGray_get_color_mapping_procs,
+ gx_default_DevGray_get_color_comp_index,
+ pdf14_encode_color,
+ pdf14_decode_color);
+}
+
+static void
+pdf14_RGB_initialize_device_procs(gx_device *dev)
+{
+ pdf14_procs_initialize(dev,
+ gx_default_DevRGB_get_color_mapping_procs,
+ gx_default_DevRGB_get_color_comp_index,
+ pdf14_encode_color,
+ pdf14_decode_color);
+}
+
+static void
+pdf14_CMYK_initialize_device_procs(gx_device *dev)
+{
+ pdf14_procs_initialize(dev,
+ gx_default_DevCMYK_get_color_mapping_procs,
+ gx_default_DevCMYK_get_color_comp_index,
+ pdf14_encode_color,
+ pdf14_decode_color);
+}
+
+static void
+pdf14_CMYKspot_initialize_device_procs(gx_device *dev)
+{
+ pdf14_procs_initialize(dev,
+ pdf14_cmykspot_get_color_mapping_procs,
+ pdf14_cmykspot_get_color_comp_index,
+ pdf14_encode_color,
+ pdf14_decode_color);
+}
+
+static void
+pdf14_RGBspot_initialize_device_procs(gx_device *dev)
+{
+ pdf14_procs_initialize(dev,
+ pdf14_rgbspot_get_color_mapping_procs,
+ pdf14_rgbspot_get_color_comp_index,
+ pdf14_encode_color,
+ pdf14_decode_color);
+}
+
+static void
+pdf14_Grayspot_initialize_device_procs(gx_device *dev)
+{
+ pdf14_procs_initialize(dev,
+ pdf14_grayspot_get_color_mapping_procs,
+ pdf14_grayspot_get_color_comp_index,
+ pdf14_encode_color,
+ pdf14_decode_color);
+}
+
+static void
+pdf14_custom_initialize_device_procs(gx_device *dev)
+{
+ pdf14_procs_initialize(dev,
+ gx_forward_get_color_mapping_procs,
+ gx_forward_get_color_comp_index,
+ gx_forward_encode_color,
+ gx_forward_decode_color);
+}
static struct_proc_finalize(pdf14_device_finalize);
@@ -448,10 +450,12 @@ static const pdf14_nonseparable_blending_procs_t custom_blending_procs = {
};
const pdf14_device gs_pdf14_Gray_device = {
- std_device_std_color_full_body_type(pdf14_device, &pdf14_Gray_procs, "pdf14gray",
- &st_pdf14_device,
- XSIZE, YSIZE, X_DPI, Y_DPI, 8,
- 0, 0, 0, 0, 0, 0),
+ std_device_std_color_full_body_type(pdf14_device,
+ pdf14_Gray_initialize_device_procs,
+ "pdf14gray",
+ &st_pdf14_device,
+ XSIZE, YSIZE, X_DPI, Y_DPI, 8,
+ 0, 0, 0, 0, 0, 0),
{ 0 }, /* Procs */
NULL, /* target */
{ 0 }, /* devn_params - not used */
@@ -461,7 +465,9 @@ const pdf14_device gs_pdf14_Gray_device = {
};
const pdf14_device gs_pdf14_RGB_device = {
- std_device_color_stype_body(pdf14_device, &pdf14_RGB_procs, "pdf14RGB",
+ std_device_color_stype_body(pdf14_device,
+ pdf14_RGB_initialize_device_procs,
+ "pdf14RGB",
&st_pdf14_device,
XSIZE, YSIZE, X_DPI, Y_DPI, 24, 255, 256),
{ 0 }, /* Procs */
@@ -472,10 +478,13 @@ const pdf14_device gs_pdf14_RGB_device = {
3
};
-const pdf14_device gs_pdf14_CMYK_device = {
- std_device_std_color_full_body_type(pdf14_device, &pdf14_CMYK_procs,
- "pdf14cmyk", &st_pdf14_device, XSIZE, YSIZE, X_DPI, Y_DPI, 32,
- 0, 0, 0, 0, 0, 0),
+const pdf14_device gs_pdf14_CMYK_device = {
+ std_device_std_color_full_body_type(pdf14_device,
+ pdf14_CMYK_initialize_device_procs,
+ "pdf14cmyk",
+ &st_pdf14_device,
+ XSIZE, YSIZE, X_DPI, Y_DPI, 32,
+ 0, 0, 0, 0, 0, 0),
{ 0 }, /* Procs */
NULL, /* target */
{ 0 }, /* devn_params - not used */
@@ -485,8 +494,11 @@ const pdf14_device gs_pdf14_CMYK_device = {
};
const pdf14_device gs_pdf14_CMYKspot_device = {
- std_device_part1_(pdf14_device, &pdf14_CMYKspot_procs, "pdf14cmykspot",
- &st_pdf14_device, open_init_closed),
+ std_device_part1_(pdf14_device,
+ pdf14_CMYKspot_initialize_device_procs,
+ "pdf14cmykspot",
+ &st_pdf14_device,
+ open_init_closed),
dci_values(GX_DEVICE_COLOR_MAX_COMPONENTS,64,255,255,256,256),
std_device_part2_(XSIZE, YSIZE, X_DPI, Y_DPI),
offset_margin_values(0, 0, 0, 0, 0, 0),
@@ -509,8 +521,11 @@ const pdf14_device gs_pdf14_CMYKspot_device = {
};
const pdf14_device gs_pdf14_RGBspot_device = {
- std_device_part1_(pdf14_device, &pdf14_RGBspot_procs, "pdf14rgbspot",
- &st_pdf14_device, open_init_closed),
+ std_device_part1_(pdf14_device,
+ pdf14_RGBspot_initialize_device_procs,
+ "pdf14rgbspot",
+ &st_pdf14_device,
+ open_init_closed),
dci_values(GX_DEVICE_COLOR_MAX_COMPONENTS,64,255,255,256,256),
std_device_part2_(XSIZE, YSIZE, X_DPI, Y_DPI),
offset_margin_values(0, 0, 0, 0, 0, 0),
@@ -533,8 +548,11 @@ const pdf14_device gs_pdf14_RGBspot_device = {
};
const pdf14_device gs_pdf14_Grayspot_device = {
- std_device_part1_(pdf14_device, &pdf14_Grayspot_procs, "pdf14grayspot",
- &st_pdf14_device, open_init_closed),
+ std_device_part1_(pdf14_device,
+ pdf14_Grayspot_initialize_device_procs,
+ "pdf14grayspot",
+ &st_pdf14_device,
+ open_init_closed),
dci_values(GX_DEVICE_COLOR_MAX_COMPONENTS,64,255,255,256,256),
std_device_part2_(XSIZE, YSIZE, X_DPI, Y_DPI),
offset_margin_values(0, 0, 0, 0, 0, 0),
@@ -568,8 +586,11 @@ const pdf14_device gs_pdf14_Grayspot_device = {
* about how to treat these blending modes.
*/
const pdf14_device gs_pdf14_custom_device = {
- std_device_part1_(pdf14_device, &pdf14_custom_procs, "pdf14custom",
- &st_pdf14_device, open_init_closed),
+ std_device_part1_(pdf14_device,
+ pdf14_custom_initialize_device_procs,
+ "pdf14custom",
+ &st_pdf14_device,
+ open_init_closed),
dci_values(GX_DEVICE_COLOR_MAX_COMPONENTS,64,255,255,256,256),
std_device_part2_(XSIZE, YSIZE, X_DPI, Y_DPI),
offset_margin_values(0, 0, 0, 0, 0, 0),
@@ -634,141 +655,96 @@ gs_private_st_suffix_add1_final(st_gx_devn_accum_device, gx_device_pdf14_accum,
"gx_device_pdf14_accum", pdf14_accum_device_enum_ptrs, pdf14_accum_device_reloc_ptrs,
gx_devn_prn_device_finalize, st_gx_devn_prn_device, save_p14dev);
-static const gx_device_procs pdf14_accum_Gray_procs =
- prn_color_procs(gdev_prn_open, NULL, gdev_prn_close,
- gx_default_8bit_map_gray_color, gx_default_8bit_map_color_gray);
+static void
+pdf14_accum_Gray_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray8(dev);
+
+ set_dev_proc(dev, encode_color, gx_default_8bit_map_gray_color);
+ set_dev_proc(dev, decode_color, gx_default_8bit_map_color_gray);
+}
const gx_device_pdf14_accum pdf14_accum_Gray = {
- prn_device_stype_body(gx_device_pdf14_accum, pdf14_accum_Gray_procs, "pdf14-accum-Gray",
- &st_gx_devn_accum_device,
- 0/*width*/, 0/*height*/, 300/*xdpi*/, 300/*ydpi*/,
- 0/*lm*/, 0/*bm*/, 0/*rm*/, 0/*tm*/,
- 1/*ncomp*/, 8/*depth*/, 255/*max_gray*/, 0/*max_color*/,
- 256/*dither_grays*/, 0/*dither_colors*/,
- no_print_page),
+ prn_device_stype_body(gx_device_pdf14_accum,
+ pdf14_accum_Gray_initialize_device_procs,
+ "pdf14-accum-Gray",
+ &st_gx_devn_accum_device,
+ 0/*width*/, 0/*height*/, 300/*xdpi*/, 300/*ydpi*/,
+ 0/*lm*/, 0/*bm*/, 0/*rm*/, 0/*tm*/,
+ 1/*ncomp*/, 8/*depth*/, 255/*max_gray*/, 0/*max_color*/,
+ 256/*dither_grays*/, 0/*dither_colors*/,
+ no_print_page),
{ 0 }, /* devn_params - not used */
{ 0 }, /* equivalent_cmyk_color_params - not used */
0/*save_p14dev*/
};
-static const gx_device_procs pdf14_accum_RGB_procs =
- prn_color_procs(gdev_prn_open, NULL, gdev_prn_close,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb);
+static void
+pdf14_accum_RGB_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_rgb(dev);
+}
const gx_device_pdf14_accum pdf14_accum_RGB = {
- prn_device_stype_body(gx_device_pdf14_accum, pdf14_accum_RGB_procs, "pdf14-accum-RGB",
- &st_gx_devn_accum_device,
- 0/*width*/, 0/*height*/, 300/*xdpi*/, 300/*ydpi*/,
- 0/*lm*/, 0/*bm*/, 0/*rm*/, 0/*tm*/,
- 3/*ncomp*/, 24/*depth*/, 0/*max_gray*/, 255/*max_color*/,
- 1/*dither_grays*/, 256/*dither_colors*/,
- no_print_page),
+ prn_device_stype_body(gx_device_pdf14_accum,
+ pdf14_accum_RGB_initialize_device_procs,
+ "pdf14-accum-RGB",
+ &st_gx_devn_accum_device,
+ 0/*width*/, 0/*height*/, 300/*xdpi*/, 300/*ydpi*/,
+ 0/*lm*/, 0/*bm*/, 0/*rm*/, 0/*tm*/,
+ 3/*ncomp*/, 24/*depth*/, 0/*max_gray*/, 255/*max_color*/,
+ 1/*dither_grays*/, 256/*dither_colors*/,
+ no_print_page),
{ 0 }, /* devn_params - not used */
{ 0 }, /* equivalent_cmyk_color_params - not used */
0/*save_p14dev*/
};
-static const gx_device_procs pdf14_accum_CMYK_procs =
- prn_color_procs(gdev_prn_open, NULL, gdev_prn_close,
- cmyk_8bit_map_cmyk_color, cmyk_8bit_map_color_cmyk);
+static void
+pdf14_accum_CMYK_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_cmyk8(dev);
+
+ set_dev_proc(dev, encode_color, cmyk_8bit_map_cmyk_color);
+ set_dev_proc(dev, decode_color, cmyk_8bit_map_color_cmyk);
+}
const gx_device_pdf14_accum pdf14_accum_CMYK = {
- prn_device_stype_body(gx_device_pdf14_accum, pdf14_accum_CMYK_procs, "pdf14-accum-CMYK",
- &st_gx_devn_accum_device,
- 0/*width*/, 0/*height*/, 300/*xdpi*/, 300/*ydpi*/,
- 0/*lm*/, 0/*bm*/, 0/*rm*/, 0/*tm*/,
- 4/*ncomp*/, 32/*depth*/, 255/*max_gray*/, 255/*max_color*/,
- 256/*dither_grays*/, 256/*dither_colors*/,
- no_print_page),
+ prn_device_stype_body(gx_device_pdf14_accum,
+ pdf14_accum_CMYK_initialize_device_procs,
+ "pdf14-accum-CMYK",
+ &st_gx_devn_accum_device,
+ 0/*width*/, 0/*height*/, 300/*xdpi*/, 300/*ydpi*/,
+ 0/*lm*/, 0/*bm*/, 0/*rm*/, 0/*tm*/,
+ 4/*ncomp*/, 32/*depth*/, 255/*max_gray*/, 255/*max_color*/,
+ 256/*dither_grays*/, 256/*dither_colors*/,
+ no_print_page),
{ 0 }, /* devn_params - not used */
{ 0 }, /* equivalent_cmyk_color_params - not used */
0/*save_p14dev*/
};
-static const gx_device_procs pdf14_accum_CMYKspot_procs =
-{\
- gdev_prn_open, /* open */\
- NULL, /* get_initial_matrix */\
- NULL, /* sync_output */\
- NULL, /* output_page */\
- gdev_prn_close, /* close */\
- cmyk_8bit_map_cmyk_color, /* rgb_map_rgb_color */\
- cmyk_8bit_map_color_cmyk, /* gx_default_rgb_map_color_rgb */\
- NULL, /* fill_rectangle */\
- NULL, /* tile_rectangle */\
- NULL, /* copy_mono */\
- NULL, /* copy_color */\
- NULL, /* draw_line */\
- NULL, /* get_bits */\
- NULL, /* get_params */\
- NULL, /* put_params */\
- NULL, /* map_cmyk_color */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- NULL, /* get_page_device */\
- NULL, /* get_alpha_bits */\
- NULL , /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- NULL, /* fill_path */\
- NULL, /* stroke_path */\
- NULL, /* fill_mask */\
- NULL, /* fill_trapezoid */\
- NULL, /* fill_parallelogram */\
- NULL, /* fill_triangle */\
- NULL, /* draw_thin_line */\
- NULL, /* begin_image */\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL, /* strip_copy_rop, */\
- NULL, /* get_clipping_box */\
- NULL, /* begin_typed_image */\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- NULL, /* create_compositor */\
- NULL, /* get_hardware_params */\
- NULL, /* text_begin */\
- NULL, /* finish_copydevice */\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL, /* discard_trans_layer */\
- pdf14_accum_get_color_mapping_procs, /* get_color_mapping_procs */\
- pdf14_accum_get_color_comp_index, /* get_color_comp_index */\
- cmyk_8bit_map_cmyk_color, /* encode_color */\
- cmyk_8bit_map_color_cmyk, /* decode_color */\
- NULL, /* pattern_manage */\
- NULL, /* fill_rectangle_hl_color */\
- NULL, /* include_color_space */\
- NULL, /* fill_linear_color_scanline */\
- NULL, /* fill_linear_color_trapezoid */\
- NULL, /* fill_linear_color_triangle */\
- pdf14_accum_update_spot_equivalent_colors, /* update spot */\
- pdf14_accum_ret_devn_params, /* DevN params */\
- NULL, /* fill page */\
- NULL, /* push_transparency_state */\
- NULL, /* pop_transparency_state */\
- NULL, /* put_image */\
- NULL, /* dev_spec_op */\
- NULL, /* copy_planes */\
- NULL, /* */\
- NULL, /* set_graphics_type_tag */\
- NULL, /* strip_copy_rop2 */\
- NULL, /* strip_tile_rect_devn */\
- NULL /* copy_alpha_hl_color */\
-};
+static void
+pdf14_accum_initialize_device_procs_cmykspot(gx_device *dev)
+{
+ pdf14_accum_CMYK_initialize_device_procs(dev);
+
+ set_dev_proc(dev, get_color_mapping_procs, pdf14_accum_get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, pdf14_accum_get_color_comp_index);
+ set_dev_proc(dev, update_spot_equivalent_colors, pdf14_accum_update_spot_equivalent_colors);
+ set_dev_proc(dev, ret_devn_params, pdf14_accum_ret_devn_params);
+}
const gx_device_pdf14_accum pdf14_accum_CMYKspot = {
- prn_device_stype_body(gx_device_pdf14_accum, pdf14_accum_CMYKspot_procs, "pdf14-accum-CMYKspot",
- &st_gx_devn_accum_device,
- 0/*width*/, 0/*height*/, 300/*xdpi*/, 300/*ydpi*/,
- 0/*lm*/, 0/*bm*/, 0/*rm*/, 0/*tm*/,
- 4/*ncomp*/, 32/*depth*/, 255/*max_gray*/, 255/*max_color*/,
- 256/*dither_grays*/, 256/*dither_colors*/,
- no_print_page),
+ prn_device_stype_body(gx_device_pdf14_accum,
+ pdf14_accum_initialize_device_procs_cmykspot,
+ "pdf14-accum-CMYKspot",
+ &st_gx_devn_accum_device,
+ 0/*width*/, 0/*height*/, 300/*xdpi*/, 300/*ydpi*/,
+ 0/*lm*/, 0/*bm*/, 0/*rm*/, 0/*tm*/,
+ 4/*ncomp*/, 32/*depth*/, 255/*max_gray*/, 255/*max_color*/,
+ 256/*dither_grays*/, 256/*dither_colors*/,
+ no_print_page),
/* DeviceN parameters */
{ 8, /* Not used - Bits per color */
DeviceCMYKComponents, /* Names of color model colorants */
@@ -1609,6 +1585,7 @@ pdf14_pop_transparency_group(gs_gstate *pgs, pdf14_ctx *ctx,
bool overprint = pdev->overprint;
gx_color_index drawn_comps = pdev->drawn_comps_stroke | pdev->drawn_comps_fill;
bool has_matte = false;
+ int code = 0;
#ifdef DEBUG
pdf14_debug_mask_stack_state(ctx);
@@ -1643,8 +1620,10 @@ pdf14_pop_transparency_group(gs_gstate *pgs, pdf14_ctx *ctx,
if (nos == NULL && maskbuf != NULL) {
nos = pdf14_buf_new(&(tos->rect), ctx->has_tags, !tos->isolated, tos->has_shape,
tos->idle, tos->n_chan, tos->num_spots, ctx->memory, ctx->deep);
- if (nos == NULL)
- return gs_error_VMerror;
+ if (nos == NULL) {
+ code = gs_error_VMerror;
+ goto exit;
+ }
if_debug4m('v', ctx->memory,
"[v] special buffer for softmask application: %d x %d, %d color channels, %d planes\n",
@@ -1744,8 +1723,11 @@ pdf14_pop_transparency_group(gs_gstate *pgs, pdf14_ctx *ctx,
tos->rect.p.x, tos->rect.p.y, tos->rect.q.x - tos->rect.p.x,
tos->rect.q.y - tos->rect.p.y, &did_alloc, tos->deep, false);
}
- if (result == NULL)
- return_error(gs_error_unknownerror); /* transform failed */
+ if (result == NULL) {
+ /* Clean up and return error code */
+ code = gs_error_unknownerror;
+ goto exit;
+ }
#if RAW_DUMP
/* Dump the current buffer to see what we have. */
@@ -1781,6 +1763,8 @@ exit:
}
if_debug1m('v', ctx->memory, "[v]pop buf, idle=%d\n", tos->idle);
pdf14_buf_free(tos);
+ if (code < 0)
+ return_error(code);
return 0;
}
@@ -2239,20 +2223,23 @@ static const gx_cm_color_map_procs pdf14_DeviceGrayspot_procs = {
};
static const gx_cm_color_map_procs *
-pdf14_cmykspot_get_color_mapping_procs(const gx_device * dev)
+pdf14_cmykspot_get_color_mapping_procs(const gx_device * dev, const gx_device **tdev)
{
+ *tdev = dev;
return &pdf14_DeviceCMYKspot_procs;
}
static const gx_cm_color_map_procs *
-pdf14_rgbspot_get_color_mapping_procs(const gx_device * dev)
+pdf14_rgbspot_get_color_mapping_procs(const gx_device * dev, const gx_device **tdev)
{
+ *tdev = dev;
return &pdf14_DeviceRGBspot_procs;
}
static const gx_cm_color_map_procs *
-pdf14_grayspot_get_color_mapping_procs(const gx_device * dev)
+pdf14_grayspot_get_color_mapping_procs(const gx_device * dev, const gx_device **tdev)
{
+ *tdev = dev;
return &pdf14_DeviceGrayspot_procs;
}
@@ -3124,6 +3111,48 @@ pdf14_blend_image_mixed_buffer16(byte* buf_ptr_, int width, int height, int rows
}
}
+static pdf14_buf*
+insert_empty_planes(pdf14_ctx* ctx, pdf14_buf** src_buf, int num_new_planes, int insert_index)
+{
+ int planestride = (*src_buf)->planestride;
+ int src_n_planes = (*src_buf)->n_planes;
+ int src_n_chan = (*src_buf)->n_chan;
+ int des_n_planes = src_n_planes + num_new_planes;
+ int des_n_chan = src_n_chan + num_new_planes;
+ byte *src_ptr = (*src_buf)->data;
+ byte* des_ptr;
+ byte *des_data;
+ bool deep = ctx->deep;
+
+ des_data = gs_alloc_bytes(ctx->memory,
+ (size_t)planestride * des_n_planes + CAL_SLOP,
+ "insert_empty_planes");
+ if (des_data == NULL)
+ return NULL;
+
+ des_ptr = des_data;
+
+ /* First copy portion prior to insert point */
+ memcpy(des_ptr, src_ptr, (planestride * insert_index) << deep);
+
+ /* New planes */
+ des_ptr += (planestride * insert_index) << deep;
+ src_ptr += (planestride * insert_index) << deep;
+ memset(des_ptr, 0, (planestride * num_new_planes) << deep);
+
+ /* Extra planes (i.e. doc spots, tags) */
+ des_ptr += (planestride * num_new_planes) << deep;
+ memcpy(des_ptr, src_ptr, (planestride * (src_n_planes - insert_index)) << deep);
+
+ /* Set up buffer structure */
+ gs_free_object(ctx->memory, (*src_buf)->data, "insert_empty_planes");
+ (*src_buf)->n_planes = des_n_planes;
+ (*src_buf)->n_chan = des_n_chan;
+ (*src_buf)->data = des_data;
+
+ return *src_buf;
+}
+
static int
pdf14_put_blended_image_cmykspot(gx_device* dev, gx_device* target,
gs_gstate* pgs, pdf14_buf* buf, int planestride_in,
@@ -3367,6 +3396,30 @@ pdf14_put_blended_image_cmykspot(gx_device* dev, gx_device* target,
tag_offset = buf->has_tags ? buf->n_chan : 0;
}
+ /* We may need to pad the buffers to ensure that any additional spot
+ channels that are not created by the ICC color conversion (or
+ non-conversion if this is not an NCLR profile) get placed properly.
+ It is up to the target device to
+ handle these planes how it sees fit based upon the image data
+ and/or any tags plane during any put image call. We *could*
+ do something here to possibly communicate through the put_image
+ call where the page related spots start, but that would/could
+ be confusing, especially for long term maintenance. Easier just
+ to have put_image hand all the data */
+ if (dev_target_profile->spotnames != NULL &&
+ dev_target_profile->spotnames->count > des_profile->num_comps) {
+ int num_new_planes = dev_target_profile->spotnames->count - des_profile->num_comps;
+ int insert_index = des_profile->num_comps;
+ pdf14_buf* result;
+
+ result = insert_empty_planes(pdev->ctx, &buf, num_new_planes, insert_index);
+ if (result == NULL)
+ return_error(gs_error_VMerror);
+
+ num_comp = buf->n_chan;
+ tag_offset = buf->has_tags ? buf->n_chan : 0;
+ buf_ptr = buf->data + (rect.p.y - buf->rect.p.y) * buf->rowstride + ((rect.p.x - buf->rect.p.x) << deep);
+ }
#if RAW_DUMP
/* Dump after the CS transform */
dump_raw_buffer_be(target->memory, height, width, buf->n_planes, planestride, rowstride,
@@ -4018,6 +4071,7 @@ pdf14_fill_path(gx_device *dev, const gs_gstate *pgs,
if (pdcolor == NULL)
return_error(gs_error_unknownerror); /* color must be defined */
+ ((pdf14_device *)dev)->op_state = pgs->is_fill_color ? PDF14_OP_STATE_FILL : PDF14_OP_STATE_STROKE;
if (gx_dc_is_pattern1_color(pdcolor)){
if( gx_pattern1_get_transptr(pdcolor) != NULL ||
gx_pattern1_clist_has_trans(pdcolor) ){
@@ -4209,9 +4263,13 @@ pdf14_stroke_path(gx_device *dev, const gs_gstate *pgs,
} else
update_lop_for_pdf14(&new_pgs, pdcolor);
pdf14_set_marking_params(dev, &new_pgs);
- if (code >= 0)
- code = gx_default_stroke_path(dev, &new_pgs, ppath, params, pdcolor,
- pcpath);
+ if (code >= 0) {
+ PDF14_OP_FS_STATE save_op_state = ((pdf14_device *)dev)->op_state;
+
+ ((pdf14_device*)dev)->op_state = PDF14_OP_STATE_STROKE;
+ code = gx_default_stroke_path(dev, &new_pgs, ppath, params, pdcolor, pcpath);
+ ((pdf14_device*)dev)->op_state = save_op_state;
+ }
if (code >= 0 && push_group) {
code = pop_shfill_group(&new_pgs);
pdf14_set_marking_params(dev, pgs);
@@ -4242,6 +4300,7 @@ pdf14_fill_stroke_path(gx_device *dev, const gs_gstate *cpgs, gx_path *ppath,
float stroke_alpha = cpgs->strokeconstantalpha;
float fill_alpha = cpgs->fillconstantalpha;
gs_blend_mode_t blend_mode = cpgs->blend_mode;
+ PDF14_OP_FS_STATE save_op_state = p14dev->op_state;
/* Break const just once, neatly */
const_breaker.cpgs = cpgs;
@@ -4290,7 +4349,10 @@ pdf14_fill_stroke_path(gx_device *dev, const gs_gstate *cpgs, gx_path *ppath,
code = gs_bbox_transform_inverse(&bbox, &ctm_only(pgs), &group_stroke_box);
if (code < 0)
return code;
-
+ if (p14dev->overprint != pgs->overprint || p14dev->stroke_overprint != pgs->stroke_overprint) {
+ p14dev->overprint = pgs->overprint;
+ p14dev->stroke_overprint = pgs->stroke_overprint;
+ }
/* See if overprint is enabled for both stroke and fill AND if ca == CA */
if (fill_alpha == stroke_alpha &&
p14dev->overprint && p14dev->stroke_overprint &&
@@ -4345,7 +4407,6 @@ pdf14_fill_stroke_path(gx_device *dev, const gs_gstate *cpgs, gx_path *ppath,
/* restore blend mode for actual drawing in the group */
(void)gs_setblendmode(pgs, blend_mode); /* Can never fail */
- p14dev->op_state = PDF14_OP_STATE_FILL;
/* If we are in an overprint situation, set the blend mode to compatible
overprint */
@@ -4384,6 +4445,7 @@ pdf14_fill_stroke_path(gx_device *dev, const gs_gstate *cpgs, gx_path *ppath,
cleanup:
/* Restore the state */
+ p14dev->op_state = save_op_state;
(void)gs_setblendmode(pgs, blend_mode); /* Can never fail */
(void)gs_setstrokeconstantalpha(pgs, stroke_alpha);
(void)gs_setfillconstantalpha(pgs, fill_alpha);
@@ -5343,7 +5405,7 @@ pdf14_begin_typed_image(gx_device * dev, const gs_gstate * pgs,
renderer which will end up installed for this case.
Detect setting of begin_image to gx_no_begin_image.
(final recursive call) */
- if (dev_proc(dev, begin_image) != gx_default_begin_image) {
+ if (dev_proc(dev, begin_typed_image) != gx_default_begin_typed_image) {
code = pdf14_patt_trans_image_fill(dev, pgs, pmat, pic,
prect, pdcolor, pcpath, mem,
pinfo);
@@ -5444,7 +5506,6 @@ pdf14_forward_device_procs(gx_device * dev)
set_dev_proc(dev, close_device, gx_forward_close_device);
set_dev_proc(dev, fill_rectangle, gx_forward_fill_rectangle);
set_dev_proc(dev, fill_rectangle_hl_color, gx_forward_fill_rectangle_hl_color);
- set_dev_proc(dev, tile_rectangle, gx_forward_tile_rectangle);
set_dev_proc(dev, copy_mono, gx_forward_copy_mono);
set_dev_proc(dev, copy_color, gx_forward_copy_color);
set_dev_proc(dev, get_page_device, gx_forward_get_page_device);
@@ -5471,7 +5532,7 @@ pdf14_disable_device(gx_device * dev)
if_debug0m('v', dev->memory, "[v]pdf14_disable_device\n");
dev->color_info = pdev->target->color_info;
pdf14_forward_device_procs(dev);
- set_dev_proc(dev, create_compositor, pdf14_forward_create_compositor);
+ set_dev_proc(dev, composite, pdf14_forward_composite);
return 0;
}
@@ -5600,9 +5661,11 @@ pdf14_determine_default_blend_cs(gx_device * pdev, bool use_pdf14_accum,
* currently only using a color space based upon the device.
*/
static int
-get_pdf14_device_proto(gx_device * dev, pdf14_device ** pdevproto,
- pdf14_device * ptempdevproto, gs_gstate * pgs,
- const gs_pdf14trans_t * pdf14pct, bool use_pdf14_accum)
+get_pdf14_device_proto(gx_device *dev,
+ pdf14_device *pdevproto,
+ gs_gstate *pgs,
+ const gs_pdf14trans_t *pdf14pct,
+ bool use_pdf14_accum)
{
bool using_blend_cs;
pdf14_default_colorspace_t dev_cs =
@@ -5623,38 +5686,32 @@ get_pdf14_device_proto(gx_device * dev, pdf14_device ** pdevproto,
switch (dev_cs) {
case PDF14_DeviceGray:
- *pdevproto = (pdf14_device *)&gs_pdf14_Gray_device;
- *ptempdevproto = **pdevproto;
- ptempdevproto->color_info.max_components = 1;
- ptempdevproto->color_info.num_components =
- ptempdevproto->color_info.max_components;
- ptempdevproto->color_info.depth = 8<<deep;
- ptempdevproto->color_info.max_gray = deep ? 65535 : 255;
- ptempdevproto->color_info.gray_index = 0; /* Avoid halftoning */
- ptempdevproto->color_info.dither_grays = deep ? 65536 : 256;
- ptempdevproto->sep_device = false;
- *pdevproto = ptempdevproto;
+ *pdevproto = gs_pdf14_Gray_device;
+ pdevproto->color_info.max_components = 1;
+ pdevproto->color_info.num_components =
+ pdevproto->color_info.max_components;
+ pdevproto->color_info.depth = 8<<deep;
+ pdevproto->color_info.max_gray = deep ? 65535 : 255;
+ pdevproto->color_info.gray_index = 0; /* Avoid halftoning */
+ pdevproto->color_info.dither_grays = deep ? 65536 : 256;
+ pdevproto->sep_device = false;
break;
case PDF14_DeviceRGB:
- *pdevproto = (pdf14_device *)&gs_pdf14_RGB_device;
- *ptempdevproto = **pdevproto;
- ptempdevproto->color_info.depth = 24<<deep;
- ptempdevproto->color_info.max_gray = deep ? 65535 : 255;
- ptempdevproto->color_info.dither_grays = deep ? 65536 : 256;
- ptempdevproto->sep_device = false;
- *pdevproto = ptempdevproto;
+ *pdevproto = gs_pdf14_RGB_device;
+ pdevproto->color_info.depth = 24<<deep;
+ pdevproto->color_info.max_gray = deep ? 65535 : 255;
+ pdevproto->color_info.dither_grays = deep ? 65536 : 256;
+ pdevproto->sep_device = false;
break;
case PDF14_DeviceCMYK:
- *pdevproto = (pdf14_device *)&gs_pdf14_CMYK_device;
- *ptempdevproto = **pdevproto;
- ptempdevproto->color_info.depth = 32<<deep;
- ptempdevproto->color_info.max_gray = deep ? 65535 : 255;
- ptempdevproto->color_info.dither_grays = deep ? 65536 : 256;
- ptempdevproto->sep_device = false;
- *pdevproto = ptempdevproto;
+ *pdevproto = gs_pdf14_CMYK_device;
+ pdevproto->color_info.depth = 32<<deep;
+ pdevproto->color_info.max_gray = deep ? 65535 : 255;
+ pdevproto->color_info.dither_grays = deep ? 65536 : 256;
+ pdevproto->sep_device = false;
break;
case PDF14_DeviceCMYKspot:
- *pdevproto = (pdf14_device *)&gs_pdf14_CMYKspot_device;
+ *pdevproto = gs_pdf14_CMYKspot_device;
/* Need to figure out how we want to handle the device profile
for this case */
/*
@@ -5663,18 +5720,14 @@ get_pdf14_device_proto(gx_device * dev, pdf14_device ** pdevproto,
* for the page.
*/
if (num_spots >= 0) {
- *ptempdevproto = **pdevproto;
- ptempdevproto->devn_params.page_spot_colors = num_spots;
- ptempdevproto->color_info.num_components =
- ptempdevproto->devn_params.num_std_colorant_names + num_spots;
- if (ptempdevproto->color_info.num_components >
- GS_CLIENT_COLOR_MAX_COMPONENTS)
- ptempdevproto->color_info.num_components =
- GS_CLIENT_COLOR_MAX_COMPONENTS;
- ptempdevproto->color_info.depth =
- ptempdevproto->color_info.num_components * (8<<deep);
- ptempdevproto->sep_device = true;
- *pdevproto = ptempdevproto;
+ pdevproto->devn_params.page_spot_colors = num_spots;
+ pdevproto->color_info.num_components =
+ pdevproto->devn_params.num_std_colorant_names + num_spots;
+ if (pdevproto->color_info.num_components > GS_CLIENT_COLOR_MAX_COMPONENTS)
+ pdevproto->color_info.num_components = GS_CLIENT_COLOR_MAX_COMPONENTS;
+ pdevproto->color_info.depth =
+ pdevproto->color_info.num_components * (8<<deep);
+ pdevproto->sep_device = true;
}
break;
case PDF14_DeviceCustom:
@@ -5683,23 +5736,22 @@ get_pdf14_device_proto(gx_device * dev, pdf14_device ** pdevproto,
* color_info for the PDF 1.4 compositing device needs to match
* the output device.
*/
- *ptempdevproto = gs_pdf14_custom_device;
- ptempdevproto->color_info = dev->color_info;
+ *pdevproto = gs_pdf14_custom_device;
+ pdevproto->color_info = dev->color_info;
/* The pdf14 device has to be 8 (or 16) bit continuous tone. Force it */
- ptempdevproto->color_info.depth =
- ptempdevproto->color_info.num_components * (8<<deep);
- ptempdevproto->color_info.max_gray = deep ? 65535 : 255;
- ptempdevproto->color_info.max_color = deep ? 65535 : 255;
- ptempdevproto->color_info.dither_grays = deep ? 65536 : 256;
- ptempdevproto->color_info.dither_colors = deep ? 65536 : 256;
-
- *pdevproto = ptempdevproto;
+ pdevproto->color_info.depth =
+ pdevproto->color_info.num_components * (8<<deep);
+ pdevproto->color_info.max_gray = deep ? 65535 : 255;
+ pdevproto->color_info.max_color = deep ? 65535 : 255;
+ pdevproto->color_info.dither_grays = deep ? 65536 : 256;
+ pdevproto->color_info.dither_colors = deep ? 65536 : 256;
break;
default: /* Should not occur */
return_error(gs_error_rangecheck);
}
- ptempdevproto->using_blend_cs = using_blend_cs;
- ptempdevproto->overprint_sim = pdf14pct->params.overprint_sim_push;
+ pdevproto->initialize_device_procs((gx_device *)pdevproto);
+ pdevproto->using_blend_cs = using_blend_cs;
+ pdevproto->overprint_sim = pdf14pct->params.overprint_sim_push;
return 0;
}
@@ -5773,8 +5825,7 @@ pdf14_recreate_device(gs_memory_t *mem, gs_gstate * pgs,
{
pdf14_device * pdev = (pdf14_device *)dev;
gx_device * target = pdev->target;
- pdf14_device * dev_proto;
- pdf14_device temp_dev_proto;
+ pdf14_device dev_proto;
bool has_tags = device_encodes_tags(dev);
int code;
bool deep = device_is_deep(dev);
@@ -5785,11 +5836,11 @@ pdf14_recreate_device(gs_memory_t *mem, gs_gstate * pgs,
* We will not use the entire prototype device but we will set the
* color related info and the device procs to match the prototype.
*/
- code = get_pdf14_device_proto(target, &dev_proto, &temp_dev_proto, pgs,
+ code = get_pdf14_device_proto(target, &dev_proto, pgs,
pdf14pct, false);
if (code < 0)
return code;
- pdev->color_info = dev_proto->color_info;
+ pdev->color_info = dev_proto.color_info;
pdev->pad = target->pad;
pdev->log2_align_mod = target->log2_align_mod;
@@ -5798,7 +5849,7 @@ pdf14_recreate_device(gs_memory_t *mem, gs_gstate * pgs,
else
pdev->is_planar = target->is_planar;
- pdev->procs = dev_proto->procs;
+ pdev->procs = dev_proto.procs;
if (deep) {
set_dev_proc(pdev, encode_color, pdf14_encode_color16);
set_dev_proc(pdev, decode_color, pdf14_decode_color16);
@@ -5808,8 +5859,6 @@ pdf14_recreate_device(gs_memory_t *mem, gs_gstate * pgs,
pdev->color_info.comp_shift[pdev->color_info.num_components] = pdev->color_info.depth;
pdev->color_info.depth += 8;
}
- dev->static_procs = dev_proto->static_procs;
- gx_device_set_procs(dev);
pdev->color_info.separable_and_linear = GX_CINFO_SEP_LIN_STANDARD;
gx_device_fill_in_procs((gx_device *)pdev);
pdev->save_get_cmap_procs = pgs->get_cmap_procs;
@@ -5947,7 +5996,7 @@ gx_update_pdf14_compositor(gx_device * pdev, gs_gstate * pgs,
* to the target.
*/
static int
-pdf14_forward_create_compositor(gx_device * dev, gx_device * * pcdev,
+pdf14_forward_composite(gx_device * dev, gx_device * * pcdev,
const gs_composite_t * pct, gs_gstate * pgs,
gs_memory_t * mem, gx_device *cdev)
{
@@ -5963,7 +6012,7 @@ pdf14_forward_create_compositor(gx_device * dev, gx_device * * pcdev,
return gx_update_pdf14_compositor(dev, pgs, pdf14pct, mem);
return 0;
}
- code = dev_proc(tdev, create_compositor)(tdev, pcdev, pct, pgs, mem, cdev);
+ code = dev_proc(tdev, composite)(tdev, pcdev, pct, pgs, mem, cdev);
if (code == 1) {
/* We have created a new compositor that wrapped tdev. This means
* that our target should be updated to point to that. */
@@ -5979,7 +6028,7 @@ pdf14_forward_create_compositor(gx_device * dev, gx_device * * pcdev,
* of the interface, don't bother trying to handle any other compositor.
*/
static int
-pdf14_create_compositor(gx_device * dev, gx_device * * pcdev,
+pdf14_composite(gx_device * dev, gx_device * * pcdev,
const gs_composite_t * pct, gs_gstate * pgs,
gs_memory_t * mem, gx_device *cdev)
{
@@ -6005,7 +6054,8 @@ pdf14_create_compositor(gx_device * dev, gx_device * * pcdev,
p14dev->op_state = op_pct->params.op_state;
- if (!p14dev->op_state) {
+
+ if (p14dev->op_state == PDF14_OP_STATE_NONE) {
if (op_pct->params.retain_any_comps) {
drawn_comps = op_pct->params.drawn_comps;
} else {
@@ -6026,7 +6076,7 @@ pdf14_create_compositor(gx_device * dev, gx_device * * pcdev,
*pcdev = dev;
return 0;
} else
- return gx_no_create_compositor(dev, pcdev, pct, pgs, mem, cdev);
+ return gx_no_composite(dev, pcdev, pct, pgs, mem, cdev);
}
static int
@@ -6073,8 +6123,7 @@ pdf14_push_text_group(gx_device *dev, gs_gstate *pgs,
static int
pdf14_text_begin(gx_device * dev, gs_gstate * pgs,
const gs_text_params_t * text, gs_font * font,
- gx_path * path, const gx_device_color * pdcolor,
- const gx_clip_path * pcpath, gs_memory_t * memory,
+ const gx_clip_path * pcpath,
gs_text_enum_t ** ppenum)
{
int code;
@@ -6094,10 +6143,9 @@ pdf14_text_begin(gx_device * dev, gs_gstate * pgs,
if (code < 0)
return code;
- if_debug0m('v', memory, "[v]pdf14_text_begin\n");
+ if_debug0m('v', pgs->memory, "[v]pdf14_text_begin\n");
pdf14_set_marking_params(dev, pgs);
- code = gx_default_text_begin(dev, pgs, text, font, path, pdcolor, pcpath,
- memory, &penum);
+ code = gx_default_text_begin(dev, pgs, text, font, pcpath, &penum);
if (code < 0)
return code;
@@ -6139,7 +6187,7 @@ pdf14_text_begin(gx_device * dev, gs_gstate * pgs,
}
static int
-pdf14_finish_copydevice(gx_device *new_dev, const gx_device *from_dev)
+pdf14_initialize_device(gx_device *new_dev)
{
pdf14_device *pdev = (pdf14_device*)new_dev;
@@ -6147,8 +6195,7 @@ pdf14_finish_copydevice(gx_device *new_dev, const gx_device *from_dev)
pdev->color_model_stack = NULL;
pdev->smaskcolor = NULL;
- /* Only allow copying the prototype. */
- return (from_dev->memory ? gs_note_error(gs_error_rangecheck) : 0);
+ return 0;
}
/*
@@ -6488,11 +6535,18 @@ pdf14_strip_tile_rect_devn(gx_device *dev, const gx_strip_bitmap *tiles,
const gx_drawing_color *pdcolor1, int px, int py)
{
pdf14_device *pdev = (pdf14_device *)dev;
- pdf14_buf *buf = pdev->ctx->stack;
- int num_comp = buf->n_chan - 1;
+ pdf14_buf *buf;
+ int num_comp;
int k;
bool same = false;
- int code = 0;
+ int code;
+
+ code = pdf14_initialize_ctx(dev, dev->color_info.num_components,
+ dev->color_info.polarity != GX_CINFO_POLARITY_SUBTRACTIVE, NULL);
+ if (code < 0)
+ return code;
+ buf = pdev->ctx->stack;
+ num_comp = buf->n_chan - 1;
/* if color0 is identical to color1, do rect fill */
if (pdcolor0->type == gx_dc_type_devn && pdcolor1->type == gx_dc_type_devn) {
@@ -6829,6 +6883,8 @@ pdf14_end_transparency_group(gx_device* dev, gs_gstate* pgs)
code = pdf14_pop_transparency_group(pgs, pdev->ctx, pdev->blend_procs,
pdev->color_info.num_components, group_profile, (gx_device*)pdev);
+ if (code < 0)
+ return code;
#ifdef DEBUG
pdf14_debug_mask_stack_state(pdev->ctx);
#endif
@@ -7019,8 +7075,14 @@ pdf14_push_color_model(gx_device *dev, gs_transparency_color_t group_color_type,
if_debug2m('v', pdev->memory,
"[v]pdf14_push_color_model, num_components_old = %d num_components_new = %d\n",
pdev->color_info.num_components,new_num_comps);
- set_dev_proc(pdev, get_color_mapping_procs, pdevproto->static_procs->get_color_mapping_procs);
- set_dev_proc(pdev, get_color_comp_index, pdevproto->static_procs->get_color_comp_index);
+ {
+ gx_device local_device;
+
+ local_device.initialize_device_procs = pdevproto->initialize_device_procs;
+ local_device.initialize_device_procs((gx_device *)&local_device);
+ set_dev_proc(pdev, get_color_mapping_procs, local_device.procs.get_color_mapping_procs);
+ set_dev_proc(pdev, get_color_comp_index, local_device.procs.get_color_comp_index);
+ }
group_color->blend_procs = pdev->blend_procs = pdevproto->blend_procs;
group_color->polarity = pdev->color_info.polarity = new_polarity;
group_color->num_components = pdev->color_info.num_components = new_num_comps;
@@ -7296,8 +7358,14 @@ pdf14_clist_push_color_model(gx_device *dev, gx_device* cdev, gs_gstate *pgs,
"[v]pdf14_clist_push_color_model, num_components_old = %d num_components_new = %d\n",
pdev->color_info.num_components, new_num_comps);
/* Set new information in the device */
- set_dev_proc(pdev, get_color_mapping_procs, pdevproto->static_procs->get_color_mapping_procs);
- set_dev_proc(pdev, get_color_comp_index, pdevproto->static_procs->get_color_comp_index);
+ {
+ gx_device local_device;
+
+ local_device.initialize_device_procs = pdevproto->initialize_device_procs;
+ local_device.initialize_device_procs((gx_device *)&local_device);
+ set_dev_proc(pdev, get_color_mapping_procs, local_device.procs.get_color_mapping_procs);
+ set_dev_proc(pdev, get_color_comp_index, local_device.procs.get_color_comp_index);
+ }
pdev->blend_procs = pdevproto->blend_procs;
pdev->color_info.polarity = new_polarity;
pdev->color_info.num_components = new_num_comps;
@@ -7726,6 +7794,7 @@ do_mark_fill_rectangle_ko_simple(gx_device *dev, int x, int y, int w, int h,
dst_ptr[k * planestride] = dst2[k];
}
}
+ dst_ptr[num_comp * planestride] = dst[num_comp]; /* alpha */
}
} else {
if (overprint) {
@@ -7942,6 +8011,7 @@ do_mark_fill_rectangle_ko_simple16(gx_device *dev, int x, int y, int w, int h,
dst_ptr[k * planestride] = dst2[k];
}
}
+ dst_ptr[num_comp * planestride] = dst[num_comp]; /* alpha */
}
} else {
if (overprint) {
@@ -8024,7 +8094,6 @@ pdf14_mark_fill_rectangle_ko_simple(gx_device * dev, int x, int y, int w, int h,
static cmap_proc_gray(pdf14_cmap_gray_direct);
static cmap_proc_rgb(pdf14_cmap_rgb_direct);
static cmap_proc_cmyk(pdf14_cmap_cmyk_direct);
-static cmap_proc_rgb_alpha(pdf14_cmap_rgb_alpha_direct);
static cmap_proc_separation(pdf14_cmap_separation_direct);
static cmap_proc_devicen(pdf14_cmap_devicen_direct);
static cmap_proc_is_halftoned(pdf14_cmap_is_halftoned);
@@ -8033,7 +8102,6 @@ static const gx_color_map_procs pdf14_cmap_many = {
pdf14_cmap_gray_direct,
pdf14_cmap_rgb_direct,
pdf14_cmap_cmyk_direct,
- pdf14_cmap_rgb_alpha_direct,
pdf14_cmap_separation_direct,
pdf14_cmap_devicen_direct,
pdf14_cmap_is_halftoned
@@ -8087,6 +8155,8 @@ pdf14_cmap_gray_direct(frac gray, gx_device_color * pdc, const gs_gstate * pgs,
gx_color_value cv[GX_DEVICE_COLOR_MAX_COMPONENTS];
gx_color_index color;
gx_device *trans_device;
+ const gx_device *map_dev;
+ const gx_cm_color_map_procs *procs;
/* If trans device is set, we need to use its procs. */
if (pgs->trans_device != NULL) {
@@ -8097,7 +8167,8 @@ pdf14_cmap_gray_direct(frac gray, gx_device_color * pdc, const gs_gstate * pgs,
ncomps = trans_device->color_info.num_components;
/* map to the color model */
- dev_proc(trans_device, get_color_mapping_procs)(trans_device)->map_gray(trans_device, gray, cm_comps);
+ procs = dev_proc(trans_device, get_color_mapping_procs)(trans_device, &map_dev);
+ procs->map_gray(map_dev, gray, cm_comps);
if (pdf14_state_opaque(trans_device, pgs)) {
for (i = 0; i < ncomps; i++)
@@ -8131,6 +8202,8 @@ pdf14_cmap_rgb_direct(frac r, frac g, frac b, gx_device_color * pdc,
gx_color_value cv[GX_DEVICE_COLOR_MAX_COMPONENTS];
gx_color_index color;
gx_device *trans_device;
+ const gx_device *map_dev;
+ const gx_cm_color_map_procs *procs;
/* If trans device is set, we need to use its procs. */
if (pgs->trans_device != NULL){
@@ -8140,7 +8213,8 @@ pdf14_cmap_rgb_direct(frac r, frac g, frac b, gx_device_color * pdc,
}
ncomps = trans_device->color_info.num_components;
/* map to the color model */
- dev_proc(trans_device, get_color_mapping_procs)(trans_device)->map_rgb(trans_device, pgs, r, g, b, cm_comps);
+ procs = dev_proc(trans_device, get_color_mapping_procs)(trans_device, &map_dev);
+ procs->map_rgb(map_dev, pgs, r, g, b, cm_comps);
if (pdf14_state_opaque(trans_device, pgs)) {
for (i = 0; i < ncomps; i++)
@@ -8175,6 +8249,9 @@ pdf14_cmap_cmyk_direct(frac c, frac m, frac y, frac k, gx_device_color * pdc,
gx_color_value cv[GX_DEVICE_COLOR_MAX_COMPONENTS];
gx_color_index color;
gx_device *trans_device;
+ const gx_device *map_dev;
+ const gx_cm_color_map_procs *procs;
+
/* If trans device is set, we need to use its procs. */
if (pgs->trans_device != NULL){
@@ -8186,7 +8263,8 @@ pdf14_cmap_cmyk_direct(frac c, frac m, frac y, frac k, gx_device_color * pdc,
/* Map to the color model. Transfer function is only used
if we are drawing with an opaque color. */
- dev_proc(trans_device, get_color_mapping_procs)(trans_device)->map_cmyk(trans_device, c, m, y, k, cm_comps);
+ procs = dev_proc(trans_device, get_color_mapping_procs)(trans_device, &map_dev);
+ procs->map_cmyk(map_dev, c, m, y, k, cm_comps);
if (pdf14_state_opaque(trans_device, pgs)) {
for (i = 0; i < ncomps; i++)
@@ -8211,47 +8289,6 @@ pdf14_cmap_cmyk_direct(frac c, frac m, frac y, frac k, gx_device_color * pdc,
}
}
-static void
-pdf14_cmap_rgb_alpha_direct(frac r, frac g, frac b, frac alpha, gx_device_color * pdc,
- const gs_gstate * pgs, gx_device * dev, gs_color_select_t select)
-{
- int i, ncomps;
- frac cm_comps[GX_DEVICE_COLOR_MAX_COMPONENTS];
- gx_color_value cv[GX_DEVICE_COLOR_MAX_COMPONENTS];
- gx_color_index color;
- gx_device *trans_device;
-
- /* We may be coming from the clist writer which often forwards us the
- target device. If this occurs we actually need to get to the color
- space defined by the transparency group and we use the operators
- defined by the transparency device to do the job. */
- if (pgs->trans_device != NULL){
- trans_device = pgs->trans_device;
- } else {
- trans_device = dev;
- }
- ncomps = trans_device->color_info.num_components;
- /* map to the color model */
- dev_proc(trans_device, get_color_mapping_procs)(trans_device)->map_rgb(trans_device, pgs, r, g, b, cm_comps);
- /* pre-multiply to account for the alpha weighting */
- if (alpha != frac_1) {
-#ifdef PREMULTIPLY_TOWARDS_WHITE
- frac alpha_bias = frac_1 - alpha;
-#else
- frac alpha_bias = 0;
-#endif
- for (i = 0; i < ncomps; i++)
- cm_comps[i] = (frac)((long)cm_comps[i] * alpha) / frac_1 + alpha_bias;
- }
-
- for (i = 0; i < ncomps; i++)
- cv[i] = frac2cv(gx_map_color_frac(pgs, cm_comps[i], effective_transfer[i]));
- color = dev_proc(trans_device, encode_color)(trans_device, cv);
- /* check if the encoding was successful; we presume failure is rare */
- if (color != gx_no_color_index)
- color_set_pure(pdc, color);
-}
-
static int
pdf14_get_num_spots(gx_device * dev)
{
@@ -8398,6 +8435,8 @@ pdf14_dev_spec_op(gx_device *pdev, int dev_spec_op,
{
pdf14_device * p14dev = (pdf14_device *)pdev;
+ if (dev_spec_op == gxdso_supports_pattern_transparency)
+ return 1;
if (dev_spec_op == gxdso_pattern_shfill_doesnt_need_path)
return 1;
if (dev_spec_op == gxdso_is_pdf14_device) {
@@ -8492,8 +8531,8 @@ static int
gs_pdf14_device_push(gs_memory_t *mem, gs_gstate * pgs,
gx_device ** pdev, gx_device * target, const gs_pdf14trans_t * pdf14pct)
{
- pdf14_device * dev_proto;
- pdf14_device * p14dev, temp_dev_proto;
+ pdf14_device dev_proto;
+ pdf14_device * p14dev;
int code;
bool has_tags;
cmm_profile_t *icc_profile;
@@ -8540,12 +8579,12 @@ gs_pdf14_device_push(gs_memory_t *mem, gs_gstate * pgs,
&render_cond);
if_debug0m('v', mem, "[v]gs_pdf14_device_push\n");
- code = get_pdf14_device_proto(target, &dev_proto, &temp_dev_proto, pgs,
+ code = get_pdf14_device_proto(target, &dev_proto, pgs,
pdf14pct, use_pdf14_accum);
if (code < 0)
return code;
code = gs_copydevice((gx_device **) &p14dev,
- (const gx_device *) dev_proto, mem);
+ (const gx_device *) &dev_proto, mem);
if (code < 0)
return code;
@@ -8564,8 +8603,11 @@ gs_pdf14_device_push(gs_memory_t *mem, gs_gstate * pgs,
p14dev->fillconstantalpha = 1.0;
p14dev->strokeconstantalpha = 1.0;
- /* Simulated overprint case. We have to use CMYK-based profile */
- if (p14dev->overprint_sim && icc_profile->data_cs != gsCMYK) {
+ /* Simulated overprint case. We have to use CMYK-based profile. Also if the target
+ profile is NCLR, we are going to use a pdf14 device that is CMYK based and
+ do the mapping to the NCLR profile when the put_image occurs */
+ if ((p14dev->overprint_sim && icc_profile->data_cs != gsCMYK) ||
+ icc_profile->data_cs == gsNCHANNEL) {
gsicc_adjust_profile_rc(pgs->icc_manager->default_cmyk, 1, "gs_pdf14_device_push");
gsicc_adjust_profile_rc(p14dev->icc_struct->device_profile[GS_DEFAULT_DEVICE_PROFILE],
-1, "gs_pdf14_device_push");
@@ -8638,7 +8680,7 @@ gs_pdf14_device_push(gs_memory_t *mem, gs_gstate * pgs,
p14dev->height = 1;
}
- p14dev->op_state = pgs->is_fill_color;
+ p14dev->op_state = pgs->is_fill_color ? PDF14_OP_STATE_FILL : PDF14_OP_STATE_NONE;
code = dev_proc((gx_device *) p14dev, open_device) ((gx_device *) p14dev);
*pdev = (gx_device *) p14dev;
pdf14_set_marking_params((gx_device *)p14dev, pgs);
@@ -8716,7 +8758,7 @@ gs_pdf14_device_push(gs_memory_t *mem, gs_gstate * pgs,
goto no_clist_accum;
(*dev_proc(new_target, fillpage))(new_target, pgs, &pdcolor);
- code = clist_create_compositor(new_target, pdev, (gs_composite_t *)pdf14pct, pgs, mem, NULL);
+ code = clist_composite(new_target, pdev, (gs_composite_t *)pdf14pct, pgs, mem, NULL);
if (code < 0)
goto no_clist_accum;
@@ -9248,7 +9290,7 @@ c_pdf14trans_create_default_compositor(const gs_composite_t * pct,
/*
* We only handle the push operation. All other operations are ignored.
- * The other operations will be handled by the create_compositor routine
+ * The other operations will be handled by the composite routine
* for the PDF 1.4 compositing device.
*/
switch (pdf14pct->params.pdf14_op) {
@@ -9522,7 +9564,7 @@ send_pdf14trans(gs_gstate * pgs, gx_device * dev,
code = gs_create_pdf14trans(&pct, pparams, mem);
if (code < 0)
return code;
- code = dev_proc(dev, create_compositor) (dev, pcdev, pct, pgs, mem, NULL);
+ code = dev_proc(dev, composite) (dev, pcdev, pct, pgs, mem, NULL);
if (code == gs_error_handled)
code = 0;
@@ -9551,137 +9593,127 @@ send_pdf14trans(gs_gstate * pgs, gx_device * dev,
* device.
*/
-#define pdf14_clist_procs(get_color_mapping_procs, get_color_comp_index,\
- encode_color, decode_color) \
-{\
- NULL, /* open */\
- gx_forward_get_initial_matrix, /* get_initial_matrix */\
- gx_forward_sync_output, /* sync_output */\
- gx_forward_output_page, /* output_page */\
- gx_forward_close_device, /* close_device */\
- encode_color, /* rgb_map_rgb_color */\
- decode_color, /* map_color_rgb */\
- gx_forward_fill_rectangle, /* fill_rectangle */\
- gx_forward_tile_rectangle, /* tile_rectangle */\
- gx_forward_copy_mono, /* copy_mono */\
- gx_forward_copy_color, /* copy_color */\
- NULL , /* draw_line - obsolete */\
- gx_forward_get_bits, /* get_bits */\
- gx_forward_get_params, /* get_params */\
- pdf14_put_params, /* put_params */\
- encode_color, /* map_cmyk_color */\
- gx_forward_get_xfont_procs, /* get_xfont_procs */\
- gx_forward_get_xfont_device, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- gx_forward_get_page_device, /* get_page_device */\
- NULL, /* get_alpha_bits */\
- gx_forward_copy_alpha, /* copy_alpha */\
- gx_forward_get_band, /* get_band */\
- gx_forward_copy_rop, /* copy_rop */\
- pdf14_clist_fill_path, /* fill_path */\
- pdf14_clist_stroke_path, /* stroke_path */\
- gx_forward_fill_mask, /* fill_mask */\
- gx_forward_fill_trapezoid, /* fill_trapezoid */\
- gx_forward_fill_parallelogram, /* fill_parallelogram */\
- gx_forward_fill_triangle, /* fill_triangle */\
- gx_forward_draw_thin_line, /* draw_thin_line */\
- pdf14_clist_begin_image, /* begin_image */\
- gx_forward_image_data, /* image_data */\
- gx_forward_end_image, /* end_image */\
- gx_forward_strip_tile_rectangle, /* strip_tile_rectangle */\
- gx_forward_strip_copy_rop, /* strip_copy_rop, */\
- gx_forward_get_clipping_box, /* get_clipping_box */\
- pdf14_clist_begin_typed_image, /* begin_typed_image */\
- gx_forward_get_bits_rectangle, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- pdf14_clist_create_compositor, /* create_compositor */\
- gx_forward_get_hardware_params, /* get_hardware_params */\
- pdf14_clist_text_begin, /* text_begin */\
- NULL, /* finish_copydevice */\
- pdf14_begin_transparency_group,\
- pdf14_end_transparency_group,\
- pdf14_begin_transparency_mask,\
- pdf14_end_transparency_mask,\
- gx_default_discard_transparency_layer, /* discard_transparency_layer */\
- get_color_mapping_procs, /* get_color_mapping_procs */\
- get_color_comp_index, /* get_color_comp_index */\
- encode_color, /* encode_color */\
- decode_color, /* decode_color */\
- NULL, /* pattern_manage */\
- gx_forward_fill_rectangle_hl_color, /* fill_rectangle_hl_color */\
- NULL, /* include_color_space */\
- NULL, /* fill_linear_color_scanline */\
- NULL, /* fill_linear_color_trapezoid */\
- NULL, /* fill_linear_color_triangle */\
- gx_forward_update_spot_equivalent_colors, /* update spot */\
- gx_forward_ret_devn_params, /* gx_forward_ret_devn_params */\
- gx_forward_fillpage,\
- pdf14_push_transparency_state,\
- pdf14_pop_transparency_state,\
- NULL, /* put_image */\
- pdf14_dev_spec_op,\
- pdf14_clist_copy_planes, /* copy planes */\
- NULL, /* get_profile */\
- gx_forward_set_graphics_type_tag, /* set_graphics_type_tag */\
- NULL, /* strip_copy_rop2 */\
- NULL, /* strip_tile_rect_devn */\
- gx_forward_copy_alpha_hl_color,\
- NULL, /* process_page */\
- NULL, /* transform_pixel_region */\
- pdf14_clist_fill_stroke_path,\
-}
-
-static dev_proc_create_compositor(pdf14_clist_create_compositor);
-static dev_proc_create_compositor(pdf14_clist_forward_create_compositor);
+static dev_proc_composite(pdf14_clist_composite);
+static dev_proc_composite(pdf14_clist_forward_composite);
static dev_proc_fill_path(pdf14_clist_fill_path);
static dev_proc_stroke_path(pdf14_clist_stroke_path);
static dev_proc_fill_stroke_path(pdf14_clist_fill_stroke_path);
static dev_proc_text_begin(pdf14_clist_text_begin);
-static dev_proc_begin_image(pdf14_clist_begin_image);
static dev_proc_begin_typed_image(pdf14_clist_begin_typed_image);
static dev_proc_copy_planes(pdf14_clist_copy_planes);
-static const gx_device_procs pdf14_clist_Gray_procs =
- pdf14_clist_procs(gx_default_DevGray_get_color_mapping_procs,
- gx_default_DevGray_get_color_comp_index,
- pdf14_encode_color,
- pdf14_decode_color);
-
-static const gx_device_procs pdf14_clist_RGB_procs =
- pdf14_clist_procs(gx_default_DevRGB_get_color_mapping_procs,
- gx_default_DevRGB_get_color_comp_index,
- pdf14_encode_color,
- pdf14_decode_color);
-
-static const gx_device_procs pdf14_clist_CMYK_procs =
- pdf14_clist_procs(gx_default_DevCMYK_get_color_mapping_procs,
- gx_default_DevCMYK_get_color_comp_index,
- pdf14_encode_color, pdf14_decode_color);
-
-static const gx_device_procs pdf14_clist_CMYKspot_procs =
- pdf14_clist_procs(pdf14_cmykspot_get_color_mapping_procs,
- pdf14_cmykspot_get_color_comp_index,
- pdf14_encode_color,
- pdf14_decode_color);
+static void
+pdf14_clist_init_procs(gx_device *dev,
+ dev_proc_get_color_mapping_procs(get_color_mapping_procs),
+ dev_proc_get_color_comp_index(get_color_comp_index))
+{
+ set_dev_proc(dev, get_initial_matrix, gx_forward_get_initial_matrix);
+ set_dev_proc(dev, sync_output, gx_forward_sync_output);
+ set_dev_proc(dev, output_page, gx_forward_output_page);
+ set_dev_proc(dev, close_device, gx_forward_close_device);
+ set_dev_proc(dev, map_rgb_color, pdf14_encode_color);
+ set_dev_proc(dev, map_color_rgb, pdf14_decode_color);
+ set_dev_proc(dev, fill_rectangle, gx_forward_fill_rectangle);
+ set_dev_proc(dev, copy_mono, gx_forward_copy_mono);
+ set_dev_proc(dev, copy_color, gx_forward_copy_color);
+ set_dev_proc(dev, get_params, gx_forward_get_params);
+ set_dev_proc(dev, put_params, pdf14_put_params);
+ set_dev_proc(dev, map_cmyk_color, pdf14_encode_color);
+ set_dev_proc(dev, get_page_device, gx_forward_get_page_device);
+ set_dev_proc(dev, copy_alpha, gx_forward_copy_alpha);
+ set_dev_proc(dev, fill_path, pdf14_clist_fill_path);
+ set_dev_proc(dev, stroke_path, pdf14_clist_stroke_path);
+ set_dev_proc(dev, fill_mask, gx_forward_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, gx_forward_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, gx_forward_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, gx_forward_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, gx_forward_draw_thin_line);
+ set_dev_proc(dev, strip_tile_rectangle, gx_forward_strip_tile_rectangle);
+ set_dev_proc(dev, strip_copy_rop2, gx_forward_strip_copy_rop2);
+ set_dev_proc(dev, get_clipping_box, gx_forward_get_clipping_box);
+ set_dev_proc(dev, begin_typed_image, pdf14_clist_begin_typed_image);
+ set_dev_proc(dev, get_bits_rectangle, gx_forward_get_bits_rectangle);
+ set_dev_proc(dev, composite, pdf14_clist_composite);
+ set_dev_proc(dev, get_hardware_params, gx_forward_get_hardware_params);
+ set_dev_proc(dev, text_begin, pdf14_clist_text_begin);
+ set_dev_proc(dev, begin_transparency_group, pdf14_begin_transparency_group);
+ set_dev_proc(dev, end_transparency_group, pdf14_end_transparency_group);
+ set_dev_proc(dev, begin_transparency_mask, pdf14_begin_transparency_mask);
+ set_dev_proc(dev, end_transparency_mask, pdf14_end_transparency_mask);
+ set_dev_proc(dev, discard_transparency_layer, gx_default_discard_transparency_layer);
+ set_dev_proc(dev, get_color_mapping_procs, get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, get_color_comp_index);
+ set_dev_proc(dev, encode_color, pdf14_encode_color);
+ set_dev_proc(dev, decode_color, pdf14_decode_color);
+ set_dev_proc(dev, fill_rectangle_hl_color, gx_forward_fill_rectangle_hl_color);
+ set_dev_proc(dev, update_spot_equivalent_colors, gx_forward_update_spot_equivalent_colors);
+ set_dev_proc(dev, ret_devn_params, gx_forward_ret_devn_params);
+ set_dev_proc(dev, fillpage, gx_forward_fillpage);
+ set_dev_proc(dev, push_transparency_state, pdf14_push_transparency_state);
+ set_dev_proc(dev, pop_transparency_state, pdf14_pop_transparency_state);
+ set_dev_proc(dev, dev_spec_op, pdf14_dev_spec_op);
+ set_dev_proc(dev, copy_planes, pdf14_clist_copy_planes);
+ set_dev_proc(dev, set_graphics_type_tag, gx_forward_set_graphics_type_tag);
+ set_dev_proc(dev, copy_alpha_hl_color, gx_forward_copy_alpha_hl_color);
+ set_dev_proc(dev, fill_stroke_path, pdf14_clist_fill_stroke_path);
+}
+
+static void
+pdf14_clist_Gray_initialize_device_procs(gx_device *dev)
+{
+ pdf14_clist_init_procs(dev,
+ gx_default_DevGray_get_color_mapping_procs,
+ gx_default_DevGray_get_color_comp_index);
+}
+
+static void
+pdf14_clist_RGB_initialize_device_procs(gx_device *dev)
+{
+ pdf14_clist_init_procs(dev,
+ gx_default_DevRGB_get_color_mapping_procs,
+ gx_default_DevRGB_get_color_comp_index);
+}
+
+static void
+pdf14_clist_CMYK_initialize_device_procs(gx_device *dev)
+{
+ pdf14_clist_init_procs(dev,
+ gx_default_DevCMYK_get_color_mapping_procs,
+ gx_default_DevCMYK_get_color_comp_index);
+}
+
+static void
+pdf14_clist_CMYKspot_initialize_device_procs(gx_device *dev)
+{
+ pdf14_clist_init_procs(dev,
+ pdf14_cmykspot_get_color_mapping_procs,
+ pdf14_cmykspot_get_color_comp_index);
+}
#if 0 /* NOT USED */
-static const gx_device_procs pdf14_clist_RGBspot_procs =
- pdf14_clist_procs(pdf14_rgbspot_get_color_mapping_procs,
- pdf14_rgbspot_get_color_comp_index,
- pdf14_encode_color,
- pdf14_decode_color);
-
-static const gx_device_procs pdf14_clist_Grayspot_procs =
- pdf14_clist_procs(pdf14_grayspot_get_color_mapping_procs,
- pdf14_grayspot_get_color_comp_index,
- pdf14_encode_color,
- pdf14_decode_color);
+static void
+pdf14_clist_RGBspot_initialize_device_procs(gx_device *dev)
+{
+ pdf14_clist_init_procs(dev,
+ pdf14_rgbspot_get_color_mapping_procs,
+ pdf14_rgbspot_get_color_comp_index);
+}
+
+static int
+pdf14_clist_Grayspot_initialize_device_procs(gx_device *dev)
+{
+ pdf14_clist_init_procs(dev,
+ pdf14_grayspot_get_color_mapping_procs,
+ pdf14_grayspot_get_color_comp_index);
+}
#endif /* NOT USED */
const pdf14_clist_device pdf14_clist_Gray_device = {
- std_device_color_stype_body(pdf14_clist_device, &pdf14_clist_Gray_procs,
- "pdf14clistgray", &st_pdf14_device,
- XSIZE, YSIZE, X_DPI, Y_DPI, 8, 255, 256),
+ std_device_color_stype_body(pdf14_clist_device,
+ pdf14_clist_Gray_initialize_device_procs,
+ "pdf14clistgray",
+ &st_pdf14_device,
+ XSIZE, YSIZE, X_DPI, Y_DPI, 8, 255, 256),
{ 0 }, /* Procs */
NULL, /* target */
{ 0 }, /* devn_params - not used */
@@ -9690,9 +9722,11 @@ const pdf14_clist_device pdf14_clist_Gray_device = {
};
const pdf14_clist_device pdf14_clist_RGB_device = {
- std_device_color_stype_body(pdf14_clist_device, &pdf14_clist_RGB_procs,
- "pdf14clistRGB", &st_pdf14_device,
- XSIZE, YSIZE, X_DPI, Y_DPI, 24, 255, 256),
+ std_device_color_stype_body(pdf14_clist_device,
+ pdf14_clist_RGB_initialize_device_procs,
+ "pdf14clistRGB",
+ &st_pdf14_device,
+ XSIZE, YSIZE, X_DPI, Y_DPI, 24, 255, 256),
{ 0 }, /* Procs */
NULL, /* target */
{ 0 }, /* devn_params - not used */
@@ -9702,9 +9736,11 @@ const pdf14_clist_device pdf14_clist_RGB_device = {
const pdf14_clist_device pdf14_clist_CMYK_device = {
std_device_std_color_full_body_type(pdf14_clist_device,
- &pdf14_clist_CMYK_procs, "pdf14clistcmyk",
- &st_pdf14_device, XSIZE, YSIZE, X_DPI, Y_DPI, 32,
- 0, 0, 0, 0, 0, 0),
+ pdf14_clist_CMYK_initialize_device_procs,
+ "pdf14clistcmyk",
+ &st_pdf14_device,
+ XSIZE, YSIZE, X_DPI, Y_DPI, 32,
+ 0, 0, 0, 0, 0, 0),
{ 0 }, /* Procs */
NULL, /* target */
{ 0 }, /* devn_params - not used */
@@ -9713,7 +9749,11 @@ const pdf14_clist_device pdf14_clist_CMYK_device = {
};
const pdf14_clist_device pdf14_clist_CMYKspot_device = {
- std_device_part1_(pdf14_device, &pdf14_clist_CMYKspot_procs, "pdf14clistcmykspot", &st_pdf14_device, open_init_closed),
+ std_device_part1_(pdf14_device,
+ pdf14_clist_CMYKspot_initialize_device_procs,
+ "pdf14clistcmykspot",
+ &st_pdf14_device,
+ open_init_closed),
dci_values(GX_DEVICE_COLOR_MAX_COMPONENTS,64,255,255,256,256),
std_device_part2_(XSIZE, YSIZE, X_DPI, Y_DPI),
offset_margin_values(0, 0, 0, 0, 0, 0),
@@ -9735,7 +9775,11 @@ const pdf14_clist_device pdf14_clist_CMYKspot_device = {
};
const pdf14_clist_device pdf14_clist_custom_device = {
- std_device_part1_(pdf14_device, &pdf14_clist_CMYKspot_procs, "pdf14clistcustom", &st_pdf14_device, open_init_closed),
+ std_device_part1_(pdf14_device,
+ pdf14_clist_CMYKspot_initialize_device_procs,
+ "pdf14clistcustom",
+ &st_pdf14_device,
+ open_init_closed),
dci_values(GX_DEVICE_COLOR_MAX_COMPONENTS,64,255,255,256,256),
std_device_part2_(XSIZE, YSIZE, X_DPI, Y_DPI),
offset_margin_values(0, 0, 0, 0, 0, 0),
@@ -9763,9 +9807,11 @@ const pdf14_clist_device pdf14_clist_custom_device = {
* currently only using a color space based upon the device.
*/
static int
-get_pdf14_clist_device_proto(gx_device * dev, pdf14_clist_device ** pdevproto,
- pdf14_clist_device * ptempdevproto, gs_gstate * pgs,
- const gs_pdf14trans_t * pdf14pct, bool use_pdf14_accum)
+get_pdf14_clist_device_proto(gx_device *dev,
+ pdf14_clist_device *pdevproto,
+ gs_gstate *pgs,
+ const gs_pdf14trans_t *pdf14pct,
+ bool use_pdf14_accum)
{
bool using_blend_cs;
pdf14_default_colorspace_t dev_cs =
@@ -9787,7 +9833,6 @@ get_pdf14_clist_device_proto(gx_device * dev, pdf14_clist_device ** pdevproto,
switch (dev_cs) {
case PDF14_DeviceGray:
- *pdevproto = (pdf14_clist_device *)&pdf14_clist_Gray_device;
/* We want gray to be single channel. Low level
initialization of gray device prototype is
peculiar in that in dci_std_color_num_components
@@ -9796,70 +9841,67 @@ get_pdf14_clist_device_proto(gx_device * dev, pdf14_clist_device ** pdevproto,
Here we want monochrome anytime we have a gray device.
To avoid breaking things elsewhere, we will overide
the prototype intialization here */
- *ptempdevproto = **pdevproto;
- ptempdevproto->color_info.max_components = 1;
- ptempdevproto->color_info.num_components =
- ptempdevproto->color_info.max_components;
- ptempdevproto->color_info.max_gray = deep ? 65535 : 255;
- ptempdevproto->color_info.gray_index = 0; /* Avoid halftoning */
- ptempdevproto->color_info.dither_grays = ptempdevproto->color_info.max_gray+1;
- ptempdevproto->color_info.anti_alias = dev->color_info.anti_alias;
- ptempdevproto->color_info.depth = deep ? 16 : 8;
- ptempdevproto->sep_device = false;
- *pdevproto = ptempdevproto;
+ *pdevproto = pdf14_clist_Gray_device;
+ pdevproto->color_info.max_components = 1;
+ pdevproto->color_info.num_components =
+ pdevproto->color_info.max_components;
+ pdevproto->color_info.max_gray = deep ? 65535 : 255;
+ pdevproto->color_info.gray_index = 0; /* Avoid halftoning */
+ pdevproto->color_info.dither_grays = pdevproto->color_info.max_gray+1;
+ pdevproto->color_info.anti_alias = dev->color_info.anti_alias;
+ pdevproto->color_info.depth = deep ? 16 : 8;
+ pdevproto->sep_device = false;
break;
case PDF14_DeviceRGB:
- *pdevproto = (pdf14_clist_device *)&pdf14_clist_RGB_device;
- *ptempdevproto = **pdevproto;
- ptempdevproto->color_info.anti_alias = dev->color_info.anti_alias;
- ptempdevproto->sep_device = false;
+ *pdevproto = pdf14_clist_RGB_device;
+ pdevproto->color_info.anti_alias = dev->color_info.anti_alias;
+ pdevproto->sep_device = false;
if (deep) {
- ptempdevproto->color_info.depth = 3*16;
- ptempdevproto->color_info.max_color = 65535;
- ptempdevproto->color_info.max_gray = 65535;
- ptempdevproto->color_info.dither_colors = 65536;
- ptempdevproto->color_info.dither_grays = 65536;
+ pdevproto->color_info.depth = 3*16;
+ pdevproto->color_info.max_color = 65535;
+ pdevproto->color_info.max_gray = 65535;
+ pdevproto->color_info.dither_colors = 65536;
+ pdevproto->color_info.dither_grays = 65536;
}
- *pdevproto = ptempdevproto;
break;
case PDF14_DeviceCMYK:
- *pdevproto = (pdf14_clist_device *)&pdf14_clist_CMYK_device;
- *ptempdevproto = **pdevproto;
- ptempdevproto->color_info.anti_alias = dev->color_info.anti_alias;
- ptempdevproto->sep_device = false;
+ *pdevproto = pdf14_clist_CMYK_device;
+ pdevproto->color_info.anti_alias = dev->color_info.anti_alias;
+ pdevproto->sep_device = false;
if (deep) {
- ptempdevproto->color_info.depth = 4*16;
- ptempdevproto->color_info.max_color = 65535;
- ptempdevproto->color_info.max_gray = 65535;
- ptempdevproto->color_info.dither_colors = 65536;
- ptempdevproto->color_info.dither_grays = 65536;
+ pdevproto->color_info.depth = 4*16;
+ pdevproto->color_info.max_color = 65535;
+ pdevproto->color_info.max_gray = 65535;
+ pdevproto->color_info.dither_colors = 65536;
+ pdevproto->color_info.dither_grays = 65536;
}
- *pdevproto = ptempdevproto;
break;
case PDF14_DeviceCMYKspot:
- *pdevproto = (pdf14_clist_device *)&pdf14_clist_CMYKspot_device;
- *ptempdevproto = **pdevproto;
+ *pdevproto = pdf14_clist_CMYKspot_device;
/*
* The number of components for the PDF14 device is the sum
* of the process components and the number of spot colors
- * for the page.
+ * for the page. If we are using an NCLR ICC profile at
+ * the output device, those spot colors are skipped. They
+ * do not appear in the transparency buffer, but appear
+ * during put image transform of the page group to the target
+ * color space.
*/
if (num_spots >= 0) {
- ptempdevproto->devn_params.page_spot_colors = num_spots;
- ptempdevproto->color_info.num_components =
- ptempdevproto->devn_params.num_std_colorant_names + num_spots;
- if (ptempdevproto->color_info.num_components >
- ptempdevproto->color_info.max_components)
- ptempdevproto->color_info.num_components =
- ptempdevproto->color_info.max_components;
- ptempdevproto->color_info.depth =
- ptempdevproto->color_info.num_components * (8<<deep);
+ pdevproto->devn_params.page_spot_colors = num_spots;
+ pdevproto->color_info.num_components =
+ pdevproto->devn_params.num_std_colorant_names + num_spots;
+ if (pdevproto->color_info.num_components >
+ pdevproto->color_info.max_components)
+ pdevproto->color_info.num_components =
+ pdevproto->color_info.max_components;
+ pdevproto->color_info.depth =
+ pdevproto->color_info.num_components * (8<<deep);
if (deep && has_tags)
- ptempdevproto->color_info.depth -= 8;
+ pdevproto->color_info.depth -= 8;
}
- ptempdevproto->color_info.anti_alias = dev->color_info.anti_alias;
- ptempdevproto->sep_device = true;
- *pdevproto = ptempdevproto;
+ pdevproto->color_info.anti_alias = dev->color_info.anti_alias;
+ pdevproto->sep_device = true;
break;
case PDF14_DeviceCustom:
/*
@@ -9867,23 +9909,22 @@ get_pdf14_clist_device_proto(gx_device * dev, pdf14_clist_device ** pdevproto,
* color_info for the PDF 1.4 compositing device needs to match
* the output device.
*/
- *ptempdevproto = pdf14_clist_custom_device;
- ptempdevproto->color_info = dev->color_info;
+ *pdevproto = pdf14_clist_custom_device;
+ pdevproto->color_info = dev->color_info;
/* The pdf14 device has to be 8 (or 16) bit continuous tone. Force it */
- ptempdevproto->color_info.depth =
- ptempdevproto->color_info.num_components * (8<<deep);
- ptempdevproto->color_info.max_gray = deep ? 65535 : 255;
- ptempdevproto->color_info.max_color = deep ? 65535 : 255;
- ptempdevproto->color_info.dither_grays = deep ? 65536 : 256;
- ptempdevproto->color_info.dither_colors = deep ? 65536 : 256;
- ptempdevproto->color_info.anti_alias = dev->color_info.anti_alias;
- *pdevproto = ptempdevproto;
+ pdevproto->color_info.depth =
+ pdevproto->color_info.num_components * (8<<deep);
+ pdevproto->color_info.max_gray = deep ? 65535 : 255;
+ pdevproto->color_info.max_color = deep ? 65535 : 255;
+ pdevproto->color_info.dither_grays = deep ? 65536 : 256;
+ pdevproto->color_info.dither_colors = deep ? 65536 : 256;
+ pdevproto->color_info.anti_alias = dev->color_info.anti_alias;
break;
default: /* Should not occur */
return_error(gs_error_rangecheck);
}
- ptempdevproto->overprint_sim = pdf14pct->params.overprint_sim_push;
- ptempdevproto->using_blend_cs = using_blend_cs;
+ pdevproto->overprint_sim = pdf14pct->params.overprint_sim_push;
+ pdevproto->using_blend_cs = using_blend_cs;
return 0;
}
@@ -9892,8 +9933,8 @@ pdf14_create_clist_device(gs_memory_t *mem, gs_gstate * pgs,
gx_device ** ppdev, gx_device * target,
const gs_pdf14trans_t * pdf14pct)
{
- pdf14_clist_device * dev_proto;
- pdf14_clist_device * pdev, temp_dev_proto;
+ pdf14_clist_device dev_proto;
+ pdf14_clist_device * pdev;
int code;
bool has_tags = device_encodes_tags(target);
cmm_profile_t *target_profile;
@@ -9911,11 +9952,11 @@ pdf14_create_clist_device(gs_memory_t *mem, gs_gstate * pgs,
&render_cond);
if_debug0m('v', pgs->memory, "[v]pdf14_create_clist_device\n");
code = get_pdf14_clist_device_proto(target, &dev_proto,
- &temp_dev_proto, pgs, pdf14pct, false);
+ pgs, pdf14pct, false);
if (code < 0)
return code;
code = gs_copydevice((gx_device **) &pdev,
- (const gx_device *) dev_proto, mem);
+ (const gx_device *) &dev_proto, mem);
if (code < 0)
return code;
@@ -9936,7 +9977,7 @@ pdf14_create_clist_device(gs_memory_t *mem, gs_gstate * pgs,
else
pdev->is_planar = target->is_planar;
- pdev->op_state = pgs->is_fill_color;
+ pdev->op_state = pgs->is_fill_color ? PDF14_OP_STATE_FILL : PDF14_OP_STATE_NONE;
if (deep) {
set_dev_proc(pdev, encode_color, pdf14_encode_color16);
@@ -9973,8 +10014,12 @@ pdf14_create_clist_device(gs_memory_t *mem, gs_gstate * pgs,
&render_cond);
if_debug0m('v', mem, "[v]pdf14_create_clist_device\n");
- /* Simulated overprint case. We have to use CMYK-based profile */
- if (pdev->overprint_sim && icc_profile->data_cs != gsCMYK) {
+ /* Simulated overprint case. We have to use CMYK-based profile
+ Also if the target profile is NCLR, we are going to use a pdf14
+ device that is CMYK based and do the mapping to the NCLR profile
+ when the put_image occurs */
+ if ((pdev->overprint_sim && icc_profile->data_cs != gsCMYK) ||
+ icc_profile->data_cs == gsNCHANNEL) {
gsicc_adjust_profile_rc(pgs->icc_manager->default_cmyk, 1, "pdf14_create_clist_device");
gsicc_adjust_profile_rc(pdev->icc_struct->device_profile[GS_DEFAULT_DEVICE_PROFILE],
-1, "pdf14_create_clist_device");
@@ -10026,12 +10071,12 @@ pdf14_disable_clist_device(gs_memory_t *mem, gs_gstate * pgs,
/*
* To disable the action of this device, we forward all device
- * procedures to the target except the create_compositor and copy
+ * procedures to the target except the composite and copy
* the target's color_info.
*/
dev->color_info = target->color_info;
pdf14_forward_device_procs(dev);
- set_dev_proc(dev, create_compositor, pdf14_clist_forward_create_compositor);
+ set_dev_proc(dev, composite, pdf14_clist_forward_composite);
return 0;
}
@@ -10048,8 +10093,7 @@ pdf14_recreate_clist_device(gs_memory_t *mem, gs_gstate * pgs,
{
pdf14_clist_device * pdev = (pdf14_clist_device *)dev;
gx_device * target = pdev->target;
- pdf14_clist_device * dev_proto;
- pdf14_clist_device temp_dev_proto;
+ pdf14_clist_device dev_proto;
int code;
if_debug0m('v', pgs->memory, "[v]pdf14_recreate_clist_device\n");
@@ -10058,12 +10102,11 @@ pdf14_recreate_clist_device(gs_memory_t *mem, gs_gstate * pgs,
* color related info to match the prototype.
*/
code = get_pdf14_clist_device_proto(target, &dev_proto,
- &temp_dev_proto, pgs, pdf14pct, false);
+ pgs, pdf14pct, false);
if (code < 0)
return code;
- pdev->color_info = dev_proto->color_info;
- pdev->procs = dev_proto->procs;
- pdev->static_procs = dev_proto->static_procs;
+ pdev->color_info = dev_proto.color_info;
+ pdev->procs = dev_proto.procs;
pdev->pad = target->pad;
pdev->log2_align_mod = target->log2_align_mod;
@@ -10126,7 +10169,7 @@ pdf14_accum_get_color_comp_index(gx_device * dev,
* the separation color components for the pdf14_accum device.
*/
static void
-pdf14_accum_gray_cs_to_cmyk_cm(gx_device * dev, frac gray, frac out[])
+pdf14_accum_gray_cs_to_cmyk_cm(const gx_device * dev, frac gray, frac out[])
{
int * map =
(int *)(&((gx_device_pdf14_accum *) dev)->devn_params.separation_order_map);
@@ -10135,7 +10178,7 @@ pdf14_accum_gray_cs_to_cmyk_cm(gx_device * dev, frac gray, frac out[])
}
static void
-pdf14_accum_rgb_cs_to_cmyk_cm(gx_device * dev,
+pdf14_accum_rgb_cs_to_cmyk_cm(const gx_device * dev,
const gs_gstate *pgs, frac r, frac g, frac b, frac out[])
{
int * map =
@@ -10145,7 +10188,7 @@ pdf14_accum_rgb_cs_to_cmyk_cm(gx_device * dev,
}
static void
-pdf14_accum_cmyk_cs_to_cmyk_cm(gx_device * dev,
+pdf14_accum_cmyk_cs_to_cmyk_cm(const gx_device * dev,
frac c, frac m, frac y, frac k, frac out[])
{
const int * map =
@@ -10161,8 +10204,9 @@ static const gx_cm_color_map_procs pdf14_accum_cm_procs = {
};
static const gx_cm_color_map_procs *
-pdf14_accum_get_color_mapping_procs(const gx_device * dev)
+pdf14_accum_get_color_mapping_procs(const gx_device * dev, const gx_device **map_dev)
{
+ *map_dev = dev;
return &pdf14_accum_cm_procs;
}
@@ -10276,7 +10320,7 @@ pdf14_put_devn_params(gx_device * pdev, gs_devn_params * pdevn_params,
* exists.
*/
static int
-pdf14_clist_create_compositor(gx_device * dev, gx_device ** pcdev,
+pdf14_clist_composite(gx_device * dev, gx_device ** pcdev,
const gs_composite_t * pct, gs_gstate * pgs, gs_memory_t * mem,
gx_device *cdev)
{
@@ -10323,7 +10367,7 @@ pdf14_clist_create_compositor(gx_device * dev, gx_device ** pcdev,
gs_pdf14trans_t pctemp = *pdf14pct;
pctemp.type = &gs_composite_pdf14trans_no_clist_writer_type;
- code = dev_proc(pdev->target, create_compositor)
+ code = dev_proc(pdev->target, composite)
(pdev->target, pcdev, (gs_composite_t *)&pctemp, pgs, mem, cdev);
/* We should never have created a new device here. */
assert(code != 1);
@@ -10366,6 +10410,7 @@ pdf14_clist_create_compositor(gx_device * dev, gx_device ** pcdev,
pdf14_decrement_smask_color(pgs, dev);
/* Restore the color_info for the clist device */
clistdev->color_info = pdev->saved_target_color_info;
+ ((gx_device_clist_writer*)clistdev)->clist_color_info = clistdev->color_info; /* also reset for writer */
set_dev_proc(clistdev, encode_color, pdev->saved_target_encode_color);
set_dev_proc(clistdev, decode_color, pdev->saved_target_decode_color);
set_dev_proc(clistdev, get_color_mapping_procs, pdev->saved_target_get_color_mapping_procs);
@@ -10499,7 +10544,7 @@ pdf14_clist_create_compositor(gx_device * dev, gx_device ** pcdev,
break; /* Pass remaining ops to target */
}
}
- code = dev_proc(pdev->target, create_compositor)
+ code = dev_proc(pdev->target, composite)
(pdev->target, pcdev, pct, pgs, mem, cdev);
/* If we were accumulating into a pdf14-clist-accum device, */
/* we now have to render the page into it's target device */
@@ -10521,6 +10566,7 @@ pdf14_clist_create_compositor(gx_device * dev, gx_device ** pcdev,
bool save_planar = pdev->is_planar;
gs_devn_params *target_devn_params = dev_proc(target, ret_devn_params)(target);
int save_num_separations;
+ gs_int_rect rect;
pdev->is_planar = false; /* so gx_device_raster is for entire chunky pixel line */
linebuf = gs_alloc_bytes(mem, gx_device_raster((gx_device *)pdev, true), "pdf14-clist_accum pop dev");
@@ -10550,7 +10596,7 @@ pdf14_clist_create_compositor(gx_device * dev, gx_device ** pcdev,
gsicc_extract_profile(GS_UNKNOWN_TAG, dev_profile,
&(pcs->cmm_icc_profile_data), &render_cond);
/* pcs takes a reference to the profile data it just retrieved. */
- gsicc_adjust_profile_rc(pcs->cmm_icc_profile_data, 1, "pdf14_clist_create_compositor");
+ gsicc_adjust_profile_rc(pcs->cmm_icc_profile_data, 1, "pdf14_clist_composite");
gsicc_set_icc_range(&(pcs->cmm_icc_profile_data));
} else {
/* DeviceN case -- need to handle spot colors */
@@ -10602,10 +10648,26 @@ pdf14_clist_create_compositor(gx_device * dev, gx_device ** pcdev,
pgs->memory, &info);
if (code < 0)
goto put_accum_error;
+ rect.p.x = 0;
+ rect.q.x = tdev->width;
for (y=0; y < tdev->height; y++) {
- code = dev_proc(tdev, get_bits)((gx_device *)tdev, y, linebuf, &actual_data);
+ gs_get_bits_params_t params;
+
+ params.options = (GB_ALIGN_ANY |
+ (GB_RETURN_COPY | GB_RETURN_POINTER) |
+ GB_OFFSET_0 |
+ GB_RASTER_STANDARD | GB_PACKING_CHUNKY |
+ GB_COLORS_NATIVE | GB_ALPHA_NONE);
+ params.x_offset = 0;
+ params.raster = bitmap_raster(dev->width * dev->color_info.depth);
+ params.data[0] = linebuf;
+ rect.p.y = y;
+ rect.q.y = y+1;
+ code = dev_proc(tdev, get_bits_rectangle)((gx_device *)tdev,
+ &rect, &params);
if (code < 0)
goto put_accum_error;
+ actual_data = params.data[0];
planes.data = actual_data;
planes.data_x = 0;
planes.raster = tdev->width * tdev->color_info.num_components;
@@ -10654,7 +10716,7 @@ put_accum_error:
* to the targer.
*/
static int
-pdf14_clist_forward_create_compositor(gx_device * dev, gx_device * * pcdev,
+pdf14_clist_forward_composite(gx_device * dev, gx_device * * pcdev,
const gs_composite_t * pct, gs_gstate * pgs,
gs_memory_t * mem, gx_device *cdev)
{
@@ -10668,10 +10730,10 @@ pdf14_clist_forward_create_compositor(gx_device * dev, gx_device * * pcdev,
const gs_pdf14trans_t * pdf14pct = (const gs_pdf14trans_t *) pct;
if (pdf14pct->params.pdf14_op == PDF14_PUSH_DEVICE)
- return pdf14_clist_create_compositor(dev, &ndev, pct, pgs, mem, cdev);
+ return pdf14_clist_composite(dev, &ndev, pct, pgs, mem, cdev);
return 0;
}
- code = dev_proc(tdev, create_compositor)(tdev, &ndev, pct, pgs, mem, cdev);
+ code = dev_proc(tdev, composite)(tdev, &ndev, pct, pgs, mem, cdev);
if (code == 1) {
/* We just wrapped tdev, so update our target. */
gx_device_set_target((gx_device_forward *)pdev, ndev);
@@ -10747,7 +10809,7 @@ pdf14_clist_update_params(pdf14_clist_device * pdev, const gs_gstate * pgs,
if (changed != 0) {
code = gs_create_pdf14trans(&pct_new, &params, pgs->memory);
if (code < 0) return code;
- code = dev_proc(pdev->target, create_compositor)
+ code = dev_proc(pdev->target, composite)
(pdev->target, &pcdev, pct_new, (gs_gstate *)pgs, pgs->memory, NULL);
gs_free_object(pgs->memory, pct_new, "pdf14_clist_update_params");
}
@@ -11198,8 +11260,7 @@ pdf14_clist_fill_stroke_path(gx_device *dev, const gs_gstate *pgs, gx_path *ppat
static int
pdf14_clist_text_begin(gx_device * dev, gs_gstate * pgs,
const gs_text_params_t * text, gs_font * font,
- gx_path * path, const gx_device_color * pdcolor,
- const gx_clip_path * pcpath, gs_memory_t * memory,
+ const gx_clip_path * pcpath,
gs_text_enum_t ** ppenum)
{
pdf14_clist_device * pdev = (pdf14_clist_device *)dev;
@@ -11214,7 +11275,7 @@ pdf14_clist_text_begin(gx_device * dev, gs_gstate * pgs,
bool text_stroke = (text_mode == 1 || text_mode == 2 || text_mode == 5 || text_mode == 6);
bool text_fill = (text_mode == 0 || text_mode == 2 || text_mode == 4 || text_mode == 6);
- if_debug0m('v', memory, "[v]pdf14_clist_text_begin\n");
+ if_debug0m('v', pgs->memory, "[v]pdf14_clist_text_begin\n");
/*
* Ensure that that the PDF 1.4 reading compositor will have the current
* blending parameters. This is needed since the fill_rectangle routines
@@ -11225,8 +11286,8 @@ pdf14_clist_text_begin(gx_device * dev, gs_gstate * pgs,
if (code < 0)
return code;
/* Pass text_begin to the target */
- code = gx_forward_text_begin(dev, pgs, text, font, path,
- pdcolor, pcpath, memory, &penum);
+ code = gx_forward_text_begin(dev, pgs, text, font,
+ pcpath, &penum);
if (code < 0)
return code;
@@ -11267,36 +11328,6 @@ pdf14_clist_text_begin(gx_device * dev, gs_gstate * pgs,
}
static int
-pdf14_clist_begin_image(gx_device * dev,
- const gs_gstate * pgs, const gs_image_t * pim,
- gs_image_format_t format, const gs_int_rect * prect,
- const gx_drawing_color * pdcolor,
- const gx_clip_path * pcpath,
- gs_memory_t * memory, gx_image_enum_common_t ** pinfo)
-{
- pdf14_clist_device * pdev = (pdf14_clist_device *)dev;
- int code;
-
- /*
- * Ensure that that the PDF 1.4 reading compositor will have the current
- * blending parameters. This is needed since the fill_rectangle routines
- * do not have access to the gs_gstate. Thus we have to pass any
- * changes explictly.
- */
- code = pdf14_clist_update_params(pdev, pgs, false, NULL);
- if (code < 0)
- return code;
- /* Pass image to the target */
- code = gx_forward_begin_image(dev, pgs, pim, format, prect,
- pdcolor, pcpath, memory, pinfo);
- if (code < 0)
- return gx_default_begin_image(dev, pgs, pim, format, prect,
- pdcolor, pcpath, memory, pinfo);
- else return code;
-
-}
-
-static int
pdf14_clist_begin_typed_image(gx_device * dev, const gs_gstate * pgs,
const gs_matrix *pmat, const gs_image_common_t *pic,
const gs_int_rect * prect,
@@ -11335,7 +11366,7 @@ pdf14_clist_begin_typed_image(gx_device * dev, const gs_gstate * pgs,
if (pim->ImageMask) {
if (pdcolor != NULL && gx_dc_is_pattern1_color(pdcolor)) {
if( gx_pattern1_get_transptr(pdcolor) != NULL){
- if (dev_proc(dev, begin_image) != pdf14_clist_begin_image) {
+ if (dev_proc(dev, begin_typed_image) != pdf14_clist_begin_typed_image) {
ptile = pdcolor->colors.pattern.p_tile;
/* Set up things in the ptile so that we get the proper
blending etc */
@@ -11439,7 +11470,7 @@ gs_pdf14_clist_device_push(gs_memory_t *mem, gs_gstate *pgs, gx_device **pcdev,
/*
* Set the color_info of the clist device to match the compositing
* device. We will restore it when the compositor is popped.
- * See pdf14_clist_create_compositor for the restore. Do the
+ * See pdf14_clist_composite for the restore. Do the
* same with the gs_gstate's get_cmap_procs. We do not want
* the gs_gstate to use transfer functions on our color values.
* The transfer functions will be applied at the end after we
@@ -11505,17 +11536,6 @@ c_pdf14trans_clist_write_update(const gs_composite_t * pcte, gx_device * dev,
return code;
case PDF14_POP_DEVICE:
-# if 0 /* Disabled because pdf14_clist_create_compositor does so. */
- /*
- * Ensure that the tranfer functions, etc. are current before we
- * dump our transparency image to the output device.
- */
- if (pgs->dev_ht)
- code = cmd_put_halftone((gx_device_clist_writer *)
- (((pdf14_clist_device *)dev)->target), pgs->dev_ht);
-# else
- code = 0;
-# endif
code = clist_writer_check_empty_cropping_stack(cdev);
break;
@@ -11584,7 +11604,7 @@ c_pdf14trans_clist_write_update(const gs_composite_t * pcte, gx_device * dev,
if (code < 0)
return code;
/* See c_pdf14trans_write, c_pdf14trans_adjust_ctm, and
- apply_create_compositor. */
+ apply_composite. */
code = gs_gstate_setmatrix(&cdev->gs_gstate, &pdf14pct->params.ctm);
/* Wrote an extra ctm. */
cmd_clear_known(cdev, ctm_known);
@@ -11630,14 +11650,16 @@ c_pdf14trans_clist_read_update(gs_composite_t * pcte, gx_device * cdev,
* device.
*/
switch (pdf14pct->params.pdf14_op) {
- case PDF14_PUSH_DEVICE:
- /* Overprint simulation sets the profile at prototype creation. */
- if (!p14dev->overprint_sim) {
- gsicc_adjust_profile_rc(cl_icc_profile, 1, "c_pdf14trans_clist_read_update");
- gsicc_adjust_profile_rc(p14dev->icc_struct->device_profile[GS_DEFAULT_DEVICE_PROFILE],
- -1, "c_pdf14trans_clist_read_update");
- p14dev->icc_struct->device_profile[GS_DEFAULT_DEVICE_PROFILE] = cl_icc_profile;
- }
+ case PDF14_PUSH_DEVICE:
+ /* Overprint simulation sets the profile at prototype creation, as does
+ when the target profile is NCLR. Match the logic in gs_pdf14_device_push */
+ if (!((p14dev->overprint_sim && cl_icc_profile->data_cs != gsCMYK) ||
+ cl_icc_profile->data_cs == gsNCHANNEL)) {
+ gsicc_adjust_profile_rc(cl_icc_profile, 1, "c_pdf14trans_clist_read_update");
+ gsicc_adjust_profile_rc(p14dev->icc_struct->device_profile[GS_DEFAULT_DEVICE_PROFILE],
+ -1, "c_pdf14trans_clist_read_update");
+ p14dev->icc_struct->device_profile[GS_DEFAULT_DEVICE_PROFILE] = cl_icc_profile;
+ }
/*
* If we are blending using spot colors (i.e. the output device
* supports spot colors) then we need to transfer
@@ -11853,7 +11875,7 @@ pdf14_spot_get_color_comp_index(gx_device *dev, const char *pname,
target_get_color_comp_index = dev_proc(tdev, get_color_comp_index);
- /* The pdf14_clist_create_compositor may have set the color procs.
+ /* The pdf14_clist_composite may have set the color procs.
We need the real target procs, but not if we are doing simulated
overprint */
if (target_get_color_comp_index == pdf14_cmykspot_get_color_comp_index &&
@@ -12189,8 +12211,8 @@ dump_mask_stack(pdf14_mask_t *mask_stack)
while (curr_mask != NULL) {
if_debug1m('v', curr_mask->memory, "[v]mask_level, %d\n", level);
- if_debug1m('v', curr_mask->memory, "[v]mask_buf, %x\n", curr_mask->rc_mask->mask_buf);
- if_debug1m('v', curr_mask->memory, "[v]rc_count, %d\n", curr_mask->rc_mask->rc);
+ if_debug1m('v', curr_mask->memory, "[v]mask_buf, %p\n", curr_mask->rc_mask->mask_buf);
+ if_debug1m('v', curr_mask->memory, "[v]rc_count, %ld\n", curr_mask->rc_mask->rc.ref_count);
level++;
curr_mask = curr_mask->previous;
}
@@ -12200,13 +12222,13 @@ dump_mask_stack(pdf14_mask_t *mask_stack)
static void
pdf14_debug_mask_stack_state(pdf14_ctx *ctx)
{
- if_debug1m('v', ctx->memory, "[v]ctx_maskstack, %x\n", ctx->mask_stack);
+ if_debug1m('v', ctx->memory, "[v]ctx_maskstack, %p\n", ctx->mask_stack);
if (ctx->mask_stack != NULL) {
dump_mask_stack(ctx->mask_stack);
}
- if_debug1m('v', ctx->memory, "[v]ctx_stack, %x\n", ctx->stack);
+ if_debug1m('v', ctx->memory, "[v]ctx_stack, %p\n", ctx->stack);
if (ctx->stack != NULL) {
- if_debug1m('v', ctx->memory, "[v]ctx_stack_maskstack, %x\n", ctx->stack->mask_stack);
+ if_debug1m('v', ctx->memory, "[v]ctx_stack_maskstack, %p\n", ctx->stack->mask_stack);
if (ctx->stack->mask_stack != NULL) {
dump_mask_stack(ctx->stack->mask_stack);
}
diff --git a/base/gdevp14.h b/base/gdevp14.h
index 44f0b8a5..434f594f 100644
--- a/base/gdevp14.h
+++ b/base/gdevp14.h
@@ -116,7 +116,7 @@ struct pdf14_group_color_s {
uint max_color; /* Causes issues if these are not maintained */
const gx_color_map_procs *(*get_cmap_procs)(const gs_gstate *,
const gx_device *);
- const gx_cm_color_map_procs *(*group_color_mapping_procs)(const gx_device *);
+ const gx_cm_color_map_procs *(*group_color_mapping_procs)(const gx_device *, const gx_device **);
gx_color_index (*encode)(gx_device *, const gx_color_value value[]);
int (*decode)(gx_device *, gx_color_index, gx_color_value *);
int (*group_color_comp_index)(gx_device *, const char *, int, int);
diff --git a/base/gdevpipe.c b/base/gdevpipe.c
index 96d71f5d..5bdc485b 100644
--- a/base/gdevpipe.c
+++ b/base/gdevpipe.c
@@ -72,8 +72,28 @@ pipe_fopen(gx_io_device * iodev, const char *fname, const char *access,
#else
gs_lib_ctx_t *ctx = mem->gs_lib_ctx;
gs_fs_list_t *fs = ctx->core->fs;
+ /* The pipe device can be reached in two ways, explicltly with %pipe%
+ or implicitly with "|", so we have to check for both
+ */
+ char f[gp_file_name_sizeof];
+ const char *pipestr = "|";
+ const size_t pipestrlen = strlen(pipestr);
+ const size_t preflen = strlen(iodev->dname);
+ const size_t nlen = strlen(fname);
+ int code1;
+
+ if (preflen + nlen >= gp_file_name_sizeof)
+ return_error(gs_error_invalidaccess);
+
+ memcpy(f, iodev->dname, preflen);
+ memcpy(f + preflen, fname, nlen + 1);
+
+ code1 = gp_validate_path(mem, f, access);
+
+ memcpy(f, pipestr, pipestrlen);
+ memcpy(f + pipestrlen, fname, nlen + 1);
- if (gp_validate_path(mem, fname, access) != 0)
+ if (code1 != 0 && gp_validate_path(mem, f, access) != 0 )
return gs_error_invalidfileaccess;
/*
diff --git a/base/gdevplnx.c b/base/gdevplnx.c
index e60b7565..60a84139 100644
--- a/base/gdevplnx.c
+++ b/base/gdevplnx.c
@@ -64,88 +64,53 @@ static dev_proc_fill_mask(plane_fill_mask);
static dev_proc_fill_parallelogram(plane_fill_parallelogram);
static dev_proc_fill_triangle(plane_fill_triangle);
static dev_proc_strip_tile_rectangle(plane_strip_tile_rectangle);
-static dev_proc_strip_copy_rop(plane_strip_copy_rop);
+static dev_proc_strip_copy_rop2(plane_strip_copy_rop2);
static dev_proc_begin_typed_image(plane_begin_typed_image);
static dev_proc_get_bits_rectangle(plane_get_bits_rectangle);
/* Device prototype */
+static void
+plane_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, plane_open_device);
+ set_dev_proc(dev, fill_rectangle, plane_fill_rectangle);
+ set_dev_proc(dev, copy_mono, plane_copy_mono);
+ set_dev_proc(dev, copy_color, plane_copy_color);
+ set_dev_proc(dev, copy_alpha, plane_copy_alpha);
+ set_dev_proc(dev, fill_path, plane_fill_path);
+ set_dev_proc(dev, stroke_path, plane_stroke_path);
+ set_dev_proc(dev, fill_mask, plane_fill_mask);
+ set_dev_proc(dev, fill_parallelogram, plane_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, plane_fill_triangle);
+ set_dev_proc(dev, strip_tile_rectangle, plane_strip_tile_rectangle);
+ set_dev_proc(dev, strip_copy_rop2, plane_strip_copy_rop2);
+ set_dev_proc(dev, begin_typed_image, plane_begin_typed_image);
+ set_dev_proc(dev, get_bits_rectangle, plane_get_bits_rectangle);
+ set_dev_proc(dev, composite, gx_no_composite); /* WRONG */
+
+ /* Ideally the following would be initialized to the defaults
+ * automatically, but this does not currently work. */
+ set_dev_proc(dev, close_device, gx_default_close_device);
+ set_dev_proc(dev, fill_trapezoid, gx_default_fill_trapezoid);
+ set_dev_proc(dev, draw_thin_line, gx_default_draw_thin_line);
+ set_dev_proc(dev, text_begin, gx_default_text_begin);
+ set_dev_proc(dev, fill_rectangle_hl_color, gx_default_fill_rectangle_hl_color);
+ set_dev_proc(dev, include_color_space, gx_default_include_color_space);
+ set_dev_proc(dev, fill_linear_color_scanline, gx_default_fill_linear_color_scanline);
+ set_dev_proc(dev, fill_linear_color_trapezoid, gx_default_fill_linear_color_trapezoid);
+ set_dev_proc(dev, fill_linear_color_triangle, gx_default_fill_linear_color_triangle);
+ set_dev_proc(dev, update_spot_equivalent_colors, gx_default_update_spot_equivalent_colors);
+ set_dev_proc(dev, ret_devn_params, gx_default_ret_devn_params);
+ set_dev_proc(dev, fillpage, gx_default_fillpage);
+ set_dev_proc(dev, strip_tile_rect_devn, gx_default_strip_tile_rect_devn);
+ set_dev_proc(dev, copy_alpha_hl_color, gx_default_copy_alpha_hl_color);
+}
+
static const gx_device_plane_extract gs_plane_extract_device = {
- std_device_std_body(gx_device_plane_extract, 0, "plane_extract",
+ std_device_std_body(gx_device_plane_extract,
+ plane_initialize_device_procs, "plane_extract",
0, 0, 72, 72),
- {
- plane_open_device,
- NULL,
- NULL,
- NULL,
- gx_default_close_device,
- NULL,
- NULL,
- plane_fill_rectangle,
- gx_default_tile_rectangle,
- plane_copy_mono,
- plane_copy_color,
- gx_default_draw_line,
- gx_default_get_bits,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- plane_copy_alpha,
- NULL,
- gx_default_copy_rop,
- plane_fill_path,
- plane_stroke_path,
- plane_fill_mask,
- gx_default_fill_trapezoid,
- plane_fill_parallelogram,
- plane_fill_triangle,
- gx_default_draw_thin_line,
- gx_default_begin_image,
- gx_default_image_data,
- gx_default_end_image,
- plane_strip_tile_rectangle,
- plane_strip_copy_rop,
- NULL,
- plane_begin_typed_image,
- plane_get_bits_rectangle,
- NULL,
- gx_no_create_compositor, /* WRONG */
- NULL,
- gx_default_text_begin,
- gx_default_finish_copydevice,
- NULL, /* deprecated and never implemented transparency procs */
- NULL, /* | */
- NULL, /* | */
- NULL, /* | */
- NULL, /* V */
- NULL, /* DeviceN support color mapping procs */
- NULL, /* | */
- NULL, /* | */
- NULL, /* | */
- NULL, /* pattern_manage */
- gx_default_fill_rectangle_hl_color,
- gx_default_include_color_space,
- gx_default_fill_linear_color_scanline,
- gx_default_fill_linear_color_trapezoid,
- gx_default_fill_linear_color_triangle,
- gx_default_update_spot_equivalent_colors,
- gx_default_ret_devn_params,
- gx_default_fillpage,
- NULL, /* push_transparency_state */
- NULL, /* pop_transparency_state */
- NULL, /* put_image */
- NULL, /* dev_spec_op */
- NULL, /* copy_planes */
- NULL, /* get_profile */
- NULL, /* set_graphics_type_tag */
- gx_default_strip_copy_rop2,
- gx_default_strip_tile_rect_devn,
- gx_default_copy_alpha_hl_color
- },
+ { 0 },
/* device-specific members */
NULL, /* target */
NULL, /* plane_dev */
@@ -220,9 +185,7 @@ reduce_drawing_color(gx_device_color *ppdc, gx_device_plane_extract *edev,
gx_devn_reduce_colored_halftone(ppdc, (gx_device *)edev);
ppdc->colors.pure = COLOR_PIXEL(edev, ppdc->colors.pure);
reduced = REDUCE_PURE(edev, gx_dc_pure_color(ppdc));
- } else if (ppdc->colors.colored.alpha != gx_max_color_value)
- return REDUCE_FAILED; /* can't reduce */
- else {
+ } else {
gx_devn_reduce_colored_halftone(ppdc, (gx_device *)edev);
ppdc->colors.binary.color[0] =
COLOR_PIXEL(edev, ppdc->colors.binary.color[0]);
@@ -418,12 +381,15 @@ int
plane_device_init(gx_device_plane_extract *edev, gx_device *target,
gx_device *plane_dev, const gx_render_plane_t *render_plane, bool clear)
{
+ int code;
/* Check for compatibility of the plane specification. */
if (render_plane->depth > plane_dev->color_info.depth)
return_error(gs_error_rangecheck);
- gx_device_init((gx_device *)edev,
- (const gx_device *)&gs_plane_extract_device,
- edev->memory, true);
+ code = gx_device_init((gx_device *)edev,
+ (const gx_device *)&gs_plane_extract_device,
+ edev->memory, true);
+ if (code < 0)
+ return code;
check_device_separable((gx_device *)edev);
gx_device_forward_fill_in_procs((gx_device_forward *)edev);
gx_device_set_target((gx_device_forward *)edev, target);
@@ -449,13 +415,13 @@ plane_open_device(gx_device *dev)
gx_device_plane_extract * const edev = (gx_device_plane_extract *)dev;
gx_device * const plane_dev = edev->plane_dev;
int plane_depth = plane_dev->color_info.depth;
- const gx_device_memory * const mdproto =
- gdev_mem_device_for_bits(plane_depth);
+ const gdev_mem_functions *fns =
+ gdev_mem_functions_for_bits(plane_depth);
edev->plane_white = gx_device_white(plane_dev);
edev->plane_mask = (1 << plane_depth) - 1;
- edev->plane_dev_is_memory = mdproto != 0 &&
- dev_proc(plane_dev, copy_color) == dev_proc(mdproto, copy_color);
+ edev->plane_dev_is_memory = fns != NULL &&
+ dev_proc(plane_dev, copy_color) == fns->copy_color;
/* We don't set or clear any_marks here: see ...init above. */
return 0;
}
@@ -744,12 +710,13 @@ plane_strip_tile_rectangle(gx_device *dev,
}
static int
-plane_strip_copy_rop(gx_device *dev,
+plane_strip_copy_rop2(gx_device *dev,
const byte *sdata, int sourcex, uint sraster, gx_bitmap_id id,
const gx_color_index *scolors,
const gx_strip_bitmap *textures, const gx_color_index *tcolors,
int x, int y, int w, int h,
- int phase_x, int phase_y, gs_logical_operation_t lop)
+ int phase_x, int phase_y, gs_logical_operation_t lop,
+ uint plane_height)
{
gx_device_plane_extract * const edev = (gx_device_plane_extract *)dev;
gx_device * const plane_dev = edev->plane_dev;
@@ -795,9 +762,10 @@ plane_strip_copy_rop(gx_device *dev,
code = begin_tiling(&source.state, edev, sdata, sourcex, sraster, w, y,
(byte *)sbuf, sizeof(sbuf), true);
if (code < 0)
- return gx_default_strip_copy_rop(dev, sdata, sourcex, sraster, id,
- scolors, textures, tcolors,
- x, y, w, h, phase_x, phase_y, rop);
+ return gx_default_strip_copy_rop2(dev, sdata, sourcex, sraster, id,
+ scolors, textures, tcolors,
+ x, y, w, h, phase_x, phase_y, rop,
+ plane_height);
plane_source = source.state.buffer.data;
plane_raster = source.state.buffer.raster;
} else
@@ -822,10 +790,10 @@ plane_strip_copy_rop(gx_device *dev,
do {
if (sdata)
extract_partial_tile(&source.state);
- code = dev_proc(plane_dev, strip_copy_rop)
+ code = dev_proc(plane_dev, strip_copy_rop2)
(plane_dev, plane_source, sourcex, plane_raster, gx_no_bitmap_id,
source.colors, plane_textures, texture.colors,
- x, y, w, h, phase_x, phase_y, rop);
+ x, y, w, h, phase_x, phase_y, rop, plane_height);
} while (code >= 0 && sdata && next_tile(&source.state));
if (textures)
end_tiling(&texture.state);
@@ -904,21 +872,6 @@ plane_cmap_cmyk(frac c, frac m, frac y, frac k, gx_device_color * pdc,
(gx_device *)edev, select, NULL);
reduce_drawing_color(pdc, edev, &dcolor, &lop);
}
-static void
-plane_cmap_rgb_alpha(frac r, frac g, frac b, frac alpha, gx_device_color * pdc,
- const gs_gstate *pgs_image, gx_device *dev, gs_color_select_t select)
-{
- const plane_image_enum_t *ppie =
- (const plane_image_enum_t *)pgs_image->client_data;
- gx_device_plane_extract * const edev =
- (gx_device_plane_extract *)ppie->dev;
- gs_logical_operation_t lop = gs_current_logical_op_inline(pgs_image);
- gx_device_color dcolor;
-
- gx_remap_concrete_rgb_alpha(r, g, b, alpha, &dcolor, ppie->pgs,
- (gx_device *)edev, select);
- reduce_drawing_color(pdc, edev, &dcolor, &lop);
-}
static bool
plane_cmap_is_halftoned(const gs_gstate *pgs_image, gx_device *dev)
{
@@ -926,7 +879,7 @@ plane_cmap_is_halftoned(const gs_gstate *pgs_image, gx_device *dev)
}
static const gx_color_map_procs plane_color_map_procs = {
- plane_cmap_gray, plane_cmap_rgb, plane_cmap_cmyk, plane_cmap_rgb_alpha,
+ plane_cmap_gray, plane_cmap_rgb, plane_cmap_cmyk,
NULL, NULL, plane_cmap_is_halftoned
};
static const gx_color_map_procs *
@@ -1048,7 +1001,7 @@ plane_image_end_image(gx_image_enum_common_t * info, bool draw_last)
static int
plane_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
- gs_get_bits_params_t * params, gs_int_rect ** unread)
+ gs_get_bits_params_t * params)
{
gx_device_plane_extract * const edev = (gx_device_plane_extract *)dev;
gx_device * const plane_dev = edev->plane_dev;
@@ -1066,11 +1019,11 @@ plane_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
*/
if ((options & GB_PACKING_PLANAR) && (options & GB_SELECT_PLANES)) {
if (params->data[plane_index] == 0)
- return gx_default_get_bits_rectangle(dev, prect, params, unread);
+ return gx_default_get_bits_rectangle(dev, prect, params);
/* If the caller wants any other plane(s), punt. */
for (plane = 0; plane < dev->color_info.num_components; ++plane)
if (plane != plane_index && params->data[plane] != 0)
- return gx_default_get_bits_rectangle(dev, prect, params, unread);
+ return gx_default_get_bits_rectangle(dev, prect, params);
/* Pass the request on to the plane device. */
plane_params = *params;
plane_params.options =
@@ -1078,7 +1031,7 @@ plane_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
GB_PACKING_CHUNKY;
plane_params.data[0] = params->data[plane_index];
code = dev_proc(plane_dev, get_bits_rectangle)
- (plane_dev, prect, &plane_params, unread);
+ (plane_dev, prect, &plane_params);
if (code >= 0) {
*params = plane_params;
params->options = (params->options & ~GB_PACKING_ALL) |
@@ -1116,7 +1069,7 @@ plane_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
(GB_RASTER_STANDARD | GB_RASTER_ANY));
plane_params.raster = gx_device_raster(plane_dev, true);
code = dev_proc(plane_dev, get_bits_rectangle)
- (plane_dev, prect, &plane_params, unread);
+ (plane_dev, prect, &plane_params);
if (code >= 0) {
/* Success, expand the plane into pixels. */
source.data.read = plane_params.data[0];
@@ -1128,6 +1081,6 @@ plane_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
}
params->options = (options & ~GB_RETURN_POINTER) | GB_RETURN_COPY;
} else
- return gx_default_get_bits_rectangle(dev, prect, params, unread);
+ return gx_default_get_bits_rectangle(dev, prect, params);
return code;
}
diff --git a/base/gdevprn.c b/base/gdevprn.c
index cb3fdf45..0cfb453f 100644
--- a/base/gdevprn.c
+++ b/base/gdevprn.c
@@ -53,12 +53,6 @@ public_st_device_printer();
/* ---------------- Standard device procedures ---------------- */
-/* Define the standard printer procedure vector. */
-const gx_device_procs prn_std_procs =
- prn_procs(gdev_prn_open, gdev_prn_output_page, gdev_prn_close);
-const gx_device_procs prn_bg_procs =
- prn_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close);
-
/* Forward references */
int gdev_prn_maybe_realloc_memory(gx_device_printer *pdev,
gdev_space_params *old_space,
@@ -70,6 +64,7 @@ gdev_prn_output_page_aux(gx_device * pdev, int num_copies, int flush, bool seeka
extern dev_proc_open_device(pattern_clist_open_device);
extern dev_proc_open_device(clist_open);
+extern dev_proc_close_device(clist_close);
/* The function run in a background thread */
static void prn_print_page_in_background(void *data);
@@ -230,10 +225,11 @@ gdev_prn_tear_down(gx_device *pdev, byte **the_memory)
if (PRINTER_IS_CLIST(ppdev)) {
/* Close cmd list device & point to the storage */
- (*gs_clist_device_procs.close_device)( (gx_device *)pcldev );
+ clist_close( (gx_device *)pcldev );
*the_memory = ppdev->buf;
ppdev->buf = 0;
ppdev->buffer_space = 0;
+ pmemdev->base = 0; /* in case finalize tries to free this */
was_command_list = true;
prn_finish_bg_print(ppdev);
@@ -435,8 +431,12 @@ gdev_prn_allocate(gx_device *pdev, gdev_space_params *new_space_params,
if (ecode == 0)
ecode = code;
- if (code >= 0 || (reallocate && pass > 1))
- ppdev->procs = gs_clist_device_procs;
+ if (code >= 0 || (reallocate && pass > 1)) {
+ ppdev->initialize_device_procs = clist_initialize_device_procs;
+ /* Hacky - we know this can't fail. */
+ (void)ppdev->initialize_device_procs((gx_device *)ppdev);
+ gx_device_fill_in_procs((gx_device *)ppdev);
+ }
} else {
/* Render entirely in memory. */
gx_device *bdev = (gx_device *)pmemdev;
@@ -475,14 +475,10 @@ gdev_prn_allocate(gx_device *pdev, gdev_space_params *new_space_params,
COPY_PROC(get_params);
COPY_PROC(put_params);
COPY_PROC(map_cmyk_color);
- COPY_PROC(get_xfont_procs);
- COPY_PROC(get_xfont_device);
- COPY_PROC(map_rgb_alpha_color);
/* All printers are page devices, even if they didn't use the */
/* standard macros for generating their procedure vectors. */
set_dev_proc(ppdev, get_page_device, gx_page_device_get_page_device);
COPY_PROC(get_clipping_box);
- COPY_PROC(map_color_rgb_alpha);
COPY_PROC(get_hardware_params);
COPY_PROC(get_color_mapping_procs);
COPY_PROC(get_color_comp_index);
@@ -1399,6 +1395,9 @@ gx_default_create_buf_device(gx_device **pbdev, gx_device *target, int y,
dev_t_proc_dev_spec_op((*orig_dso), gx_device) = dev_proc(mdev, dev_spec_op);
/* The following is a special hack for setting up printer devices. */
assign_dev_procs(mdev, mdproto);
+ mdev->initialize_device_procs = mdproto->initialize_device_procs;
+ mdev->initialize_device_procs((gx_device *)mdev);
+ /* We know mdev->procs.initialize_device is NULL! */
/* Do not override the dev_spec_op! */
dev_proc(mdev, dev_spec_op) = orig_dso;
check_device_separable((gx_device *)mdev);
@@ -1471,6 +1470,7 @@ gx_default_size_buf_device(gx_device_buf_space_t *space, gx_device *target,
mdev.color_info.depth =
(render_plane && render_plane->index >= 0 ? render_plane->depth :
target->color_info.depth);
+ mdev.color_info.num_components = target->color_info.num_components;
mdev.width = target->width;
mdev.is_planar = target->is_planar;
mdev.pad = target->pad;
@@ -1580,7 +1580,7 @@ gdev_prn_get_lines(gx_device_printer *pdev, int y, int height,
params.x_offset = 0;
params.raster = bytes_per_line;
code = dev_proc(pdev, get_bits_rectangle)
- ((gx_device *)pdev, &rect, &params, NULL);
+ ((gx_device *)pdev, &rect, &params);
if (code < 0 && actual_buffer) {
/*
* RETURN_POINTER might not be implemented for this
@@ -1589,7 +1589,7 @@ gdev_prn_get_lines(gx_device_printer *pdev, int y, int height,
params.options &= ~(GB_RETURN_POINTER | GB_RASTER_ALL);
params.options |= GB_RETURN_COPY | GB_RASTER_SPECIFIED;
code = dev_proc(pdev, get_bits_rectangle)
- ((gx_device *)pdev, &rect, &params, NULL);
+ ((gx_device *)pdev, &rect, &params);
}
if (code < 0)
return code;
@@ -1604,14 +1604,35 @@ gdev_prn_get_lines(gx_device_printer *pdev, int y, int height,
int
gdev_prn_get_bits(gx_device_printer * pdev, int y, byte * str, byte ** actual_data)
{
- int code = (*dev_proc(pdev, get_bits)) ((gx_device *) pdev, y, str, actual_data);
+ int code;
uint line_size = gdev_prn_raster(pdev);
int last_bits = -(pdev->width * pdev->color_info.depth) & 7;
+ gs_int_rect rect;
+ gs_get_bits_params_t params;
+ rect.p.x = 0;
+ rect.p.y = y;
+ rect.q.x = pdev->width;
+ rect.q.y = y+1;
+
+ params.options = (GB_ALIGN_ANY |
+ GB_RETURN_COPY |
+ GB_OFFSET_0 |
+ GB_RASTER_STANDARD | GB_PACKING_CHUNKY |
+ GB_COLORS_NATIVE | GB_ALPHA_NONE);
+ if (actual_data)
+ params.options |= GB_RETURN_POINTER;
+ params.x_offset = 0;
+ params.raster = bitmap_raster(pdev->width * pdev->color_info.depth);
+ params.data[0] = str;
+ code = (*dev_proc(pdev, get_bits_rectangle))((gx_device *)pdev, &rect,
+ &params);
if (code < 0)
return code;
+ if (actual_data)
+ *actual_data = params.data[0];
if (last_bits != 0) {
- byte *dest = (actual_data != 0 ? *actual_data : str);
+ byte *dest = (actual_data != NULL ? *actual_data : str);
dest[line_size - 1] &= 0xff << last_bits;
}
@@ -1707,3 +1728,148 @@ dmprintf4(pdev->memory, "w=%d/%d, h=%d/%d\n", old_width, new_width, old_height,
}
return code;
}
+
+void
+gdev_prn_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, gdev_prn_open);
+ set_dev_proc(dev, close_device, gdev_prn_close);
+ set_dev_proc(dev, output_page, gdev_prn_output_page);
+ set_dev_proc(dev, get_params, gdev_prn_get_params);
+ set_dev_proc(dev, put_params, gdev_prn_put_params);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
+ set_dev_proc(dev, dev_spec_op, gdev_prn_dev_spec_op);
+ set_dev_proc(dev, map_rgb_color, gdev_prn_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gdev_prn_map_color_rgb);
+ set_dev_proc(dev, encode_color, gdev_prn_map_rgb_color);
+ set_dev_proc(dev, decode_color, gdev_prn_map_color_rgb);
+}
+
+void gdev_prn_initialize_device_procs_bg(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, output_page, gdev_prn_bg_output_page);
+}
+
+void
+gdev_prn_initialize_device_procs_mono(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_rgb_color, gdev_prn_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gdev_prn_map_color_rgb);
+ set_dev_proc(dev, encode_color, gdev_prn_map_rgb_color);
+ set_dev_proc(dev, decode_color, gdev_prn_map_color_rgb);
+}
+
+void gdev_prn_initialize_device_procs_mono_bg(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, output_page, gdev_prn_bg_output_page);
+}
+
+void
+gdev_prn_initialize_device_procs_gray(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_rgb_color, gx_default_gray_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_default_gray_map_color_rgb);
+ set_dev_proc(dev, encode_color, gx_default_gray_map_rgb_color);
+ set_dev_proc(dev, decode_color, gx_default_gray_map_color_rgb);
+}
+
+void gdev_prn_initialize_device_procs_gray_bg(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray(dev);
+
+ set_dev_proc(dev, output_page, gdev_prn_bg_output_page);
+}
+
+void gdev_prn_initialize_device_procs_rgb(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_rgb_color, gx_default_rgb_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_default_rgb_map_color_rgb);
+ set_dev_proc(dev, encode_color, gx_default_rgb_map_rgb_color);
+ set_dev_proc(dev, decode_color, gx_default_rgb_map_color_rgb);
+}
+
+void gdev_prn_initialize_device_procs_rgb_bg(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_rgb(dev);
+
+ set_dev_proc(dev, output_page, gdev_prn_bg_output_page);
+}
+
+void
+gdev_prn_initialize_device_procs_gray8(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_rgb_color, gx_default_8bit_map_gray_color);
+ set_dev_proc(dev, map_color_rgb, gx_default_8bit_map_color_gray);
+ set_dev_proc(dev, encode_color, gx_default_8bit_map_gray_color);
+ set_dev_proc(dev, decode_color, gx_default_8bit_map_color_gray);
+}
+
+void gdev_prn_initialize_device_procs_gray8_bg(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray8(dev);
+
+ set_dev_proc(dev, output_page, gdev_prn_bg_output_page);
+}
+
+void gdev_prn_initialize_device_procs_cmyk1(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_cmyk_color, cmyk_1bit_map_cmyk_color);
+ set_dev_proc(dev, map_color_rgb, cmyk_1bit_map_color_rgb);
+ set_dev_proc(dev, encode_color, cmyk_1bit_map_cmyk_color);
+ set_dev_proc(dev, decode_color, cmyk_1bit_map_color_cmyk);
+}
+
+void gdev_prn_initialize_device_procs_cmyk1_bg(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_cmyk1(dev);
+
+ set_dev_proc(dev, output_page, gdev_prn_bg_output_page);
+}
+
+void gdev_prn_initialize_device_procs_cmyk8(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_cmyk_color, cmyk_8bit_map_cmyk_color);
+ set_dev_proc(dev, map_color_rgb, cmyk_8bit_map_color_rgb);
+ set_dev_proc(dev, encode_color, cmyk_8bit_map_cmyk_color);
+ set_dev_proc(dev, decode_color, cmyk_8bit_map_color_cmyk);
+}
+
+void gdev_prn_initialize_device_procs_cmyk8_bg(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_cmyk8(dev);
+
+ set_dev_proc(dev, output_page, gdev_prn_bg_output_page);
+}
+
+void gdev_prn_initialize_device_procs_cmyk16(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_cmyk_color, cmyk_16bit_map_cmyk_color);
+ set_dev_proc(dev, map_color_rgb, cmyk_16bit_map_color_rgb);
+ set_dev_proc(dev, encode_color, cmyk_16bit_map_cmyk_color);
+ set_dev_proc(dev, decode_color, cmyk_16bit_map_color_cmyk);
+}
+
+void gdev_prn_initialize_device_procs_cmyk16_bg(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_cmyk16(dev);
+
+ set_dev_proc(dev, output_page, gdev_prn_bg_output_page);
+}
diff --git a/base/gdevprn.h b/base/gdevprn.h
index fbc7cb0c..a7e1b9c5 100644
--- a/base/gdevprn.h
+++ b/base/gdevprn.h
@@ -187,95 +187,6 @@ prn_dev_proc_get_space_params(gx_default_get_space_params);
/* BACKWARD COMPATIBILITY */
#define gdev_prn_default_get_space_params gx_default_get_space_params
-/* Macro for generating procedure table */
-#define prn_procs(p_open, p_output_page, p_close)\
- prn_color_procs_enc_dec(p_open, p_output_page, p_close, gdev_prn_map_rgb_color, gdev_prn_map_color_rgb, gdev_prn_map_rgb_color, gdev_prn_map_color_rgb)
-#define prn_params_procs(p_open, p_output_page, p_close, p_get_params, p_put_params)\
- prn_color_params_procs_enc_dec(p_open, p_output_page, p_close, gdev_prn_map_rgb_color, gdev_prn_map_color_rgb, p_get_params, p_put_params, gdev_prn_map_rgb_color, gdev_prn_map_color_rgb)
-#define prn_color_procs(p_open, p_output_page, p_close, p_map_rgb_color, p_map_color_rgb)\
- prn_color_params_procs(p_open, p_output_page, p_close, p_map_rgb_color, p_map_color_rgb, gdev_prn_get_params, gdev_prn_put_params)
-#define prn_color_procs_enc_dec(p_open, p_output_page, p_close, p_map_rgb_color, p_map_color_rgb, p_encode_color, p_decode_color)\
- prn_color_params_procs_enc_dec(p_open, p_output_page, p_close, p_map_rgb_color, p_map_color_rgb, gdev_prn_get_params, gdev_prn_put_params, p_encode_color, p_decode_color)
-/* See gdev_prn_open for explanation of the NULLs below. */
-#define prn_color_params_procs(p_open, p_output_page, p_close, p_map_rgb_color, p_map_color_rgb, p_get_params, p_put_params) \
- prn_color_params_procs_enc_dec(p_open, p_output_page, p_close, p_map_rgb_color, p_map_color_rgb, p_get_params, p_put_params, NULL, NULL)
-#define prn_color_params_procs_enc_dec(p_open, p_output_page, p_close, p_map_rgb_color, p_map_color_rgb, p_get_params, p_put_params, p_encode_color, p_decode_color) {\
- p_open,\
- NULL, /* get_initial_matrix */\
- NULL, /* sync_output */\
- p_output_page,\
- p_close,\
- p_map_rgb_color,\
- p_map_color_rgb,\
- NULL, /* fill_rectangle */\
- NULL, /* tile_rectangle */\
- NULL, /* copy_mono */\
- NULL, /* copy_color */\
- NULL, /* draw_line */\
- NULL, /* get_bits */\
- p_get_params,\
- p_put_params,\
- NULL, /* map_cmyk_color */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- gx_page_device_get_page_device,\
- NULL, /* get_alpha_bits */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- NULL, /* fill_path */\
- NULL, /* stroke_path */\
- NULL, /* fill_mask */\
- NULL, /* fill_trapezoid */\
- NULL, /* fill_parallelogram */\
- NULL, /* fill_triangle */\
- NULL, /* draw_thin_line */\
- NULL, /* begin_image */\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL, /* strip_copy_rop, */\
- NULL, /* get_clipping_box */\
- NULL, /* begin_typed_image */\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- NULL, /* create_compositor */\
- NULL, /* get_hardware_params */\
- NULL, /* text_begin */\
- NULL, /* finish_copydevice */\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL, /* discard_transparency_layer */\
- NULL, /* get_color_mapping_procs */\
- NULL, /* get_color_comp_index */\
- p_encode_color, /* encode_color */\
- p_decode_color, /* decode_color */\
- NULL, /* pattern_manage */\
- NULL, /* fill_rectangle_hl_color */\
- NULL, /* include_color_space */\
- NULL, /* fill_linear_color_scanline */\
- NULL, /* fill_linear_color_trapezoid */\
- NULL, /* fill_linear_color_triangle */\
- NULL, /* update_spot_equivalent_colors */\
- NULL, /* ret_devn_params */\
- NULL, /* fillpage */\
- NULL, /* push_transparency_state */\
- NULL, /* pop_transparency_state */\
- NULL, /* put_image */\
- gdev_prn_dev_spec_op, /* dev_spec_op */\
- NULL, /* copy plane */\
- gx_default_get_profile, /* get_profile */\
- gx_default_set_graphics_type_tag /* set_graphics_type_tag */\
-}
-
-/* The standard printer device procedures */
-/* (using gdev_prn_open/output_page/close). */
-extern const gx_device_procs prn_std_procs;
-extern const gx_device_procs prn_bg_procs;
-
/*
* Define macros for generating the device structure,
* analogous to the std_device_body macros in gxdevice.h
@@ -320,8 +231,8 @@ extern const gx_device_procs prn_bg_procs;
/* The Sun cc compiler won't allow \ within a macro argument list. */
/* This accounts for the short parameter names here and below. */
-#define prn_device_margins_body(dtype, procs, dname, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page)\
- std_device_full_body_type(dtype, &procs, dname, &st_device_printer,\
+#define prn_device_margins_body(dtype, init, dname, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page)\
+ std_device_full_body_type(dtype, init, dname, &st_device_printer,\
(int)((float)(w10) * (xdpi) / 10 + 0.5),\
(int)((float)(h10) * (ydpi) / 10 + 0.5),\
xdpi, ydpi,\
@@ -331,8 +242,19 @@ extern const gx_device_procs prn_bg_procs;
(float)((rm) * 72.0), (float)((tm) * 72.0)\
),\
prn_device_body_rest_(print_page)
-#define prn_device_margins_stype_body(dtype, procs, dname, stype, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page)\
- std_device_full_body_type(dtype, &procs, dname, stype,\
+#define prn_device_margins_body_duplex(dtype, init, dname, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page)\
+ std_device_full_body_type(dtype, init, dname, &st_device_printer,\
+ (int)((float)(w10) * (xdpi) / 10 + 0.5),\
+ (int)((float)(h10) * (ydpi) / 10 + 0.5),\
+ xdpi, ydpi,\
+ ncomp, depth, mg, mc, dg, dc,\
+ (float)(-(lo) * (xdpi)), (float)(-(to) * (ydpi)),\
+ (float)((lm) * 72.0), (float)((bm) * 72.0),\
+ (float)((rm) * 72.0), (float)((tm) * 72.0)\
+ ),\
+ prn_device_body_rest2_(print_page, gx_default_print_page_copies, 0)
+#define prn_device_margins_stype_body(dtype, init, dname, stype, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page)\
+ std_device_full_body_type(dtype, init, dname, stype,\
(int)((float)(w10) * (xdpi) / 10 + 0.5),\
(int)((float)(h10) * (ydpi) / 10 + 0.5),\
xdpi, ydpi,\
@@ -343,15 +265,18 @@ extern const gx_device_procs prn_bg_procs;
),\
prn_device_body_rest_(print_page)
-#define prn_device_body(dtype, procs, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page)\
- prn_device_margins_body(dtype, procs, dname, w10, h10, xdpi, ydpi,\
+#define prn_device_body(dtype, init, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page)\
+ prn_device_margins_body(dtype, init, dname, w10, h10, xdpi, ydpi,\
+ lm, tm, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page)
+#define prn_device_body_duplex(dtype, init, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page)\
+ prn_device_margins_body_duplex(dtype, init, dname, w10, h10, xdpi, ydpi,\
lm, tm, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page)
-#define prn_device_stype_body(dtype, procs, dname, stype, w10, h10, xdpi, ydpi, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page)\
- prn_device_margins_stype_body(dtype, procs, dname, stype, w10, h10, xdpi, ydpi,\
+#define prn_device_stype_body(dtype, init, dname, stype, w10, h10, xdpi, ydpi, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page)\
+ prn_device_margins_stype_body(dtype, init, dname, stype, w10, h10, xdpi, ydpi,\
lm, tm, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page)
-#define prn_device_margins_body_extended(dtype, procs, dname, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, mcomp, ncomp, pol, depth, gi, mg, mc, dg, dc, ef, cn, print_page)\
- std_device_full_body_type_extended(dtype, &procs, dname, &st_device_printer,\
+#define prn_device_margins_body_extended(dtype, init, dname, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, mcomp, ncomp, pol, depth, gi, mg, mc, dg, dc, ef, cn, print_page)\
+ std_device_full_body_type_extended(dtype, init, dname, &st_device_printer,\
(int)((long)(w10) * (xdpi) / 10),\
(int)((long)(h10) * (ydpi) / 10),\
xdpi, ydpi,\
@@ -362,12 +287,12 @@ extern const gx_device_procs prn_bg_procs;
),\
prn_device_body_rest_(print_page)
-#define prn_device_body_extended(dtype, procs, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, mcomp, ncomp, pol, depth, gi, mg, mc, dg, dc, ef, cn, print_page)\
- prn_device_margins_body_extended(dtype, procs, dname, w10, h10, xdpi, ydpi,\
+#define prn_device_body_extended(dtype, init, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, mcomp, ncomp, pol, depth, gi, mg, mc, dg, dc, ef, cn, print_page)\
+ prn_device_margins_body_extended(dtype, init, dname, w10, h10, xdpi, ydpi,\
lm, tm, lm, bm, rm, tm, mcomp, ncomp, pol, depth, gi, mg, mc, dg, dc, ef, cn, print_page)
-#define prn_device_std_margins_body(dtype, procs, dname, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, color_bits, print_page)\
- std_device_std_color_full_body_type(dtype, &procs, dname, &st_device_printer,\
+#define prn_device_std_margins_body(dtype, init, dname, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, color_bits, print_page)\
+ std_device_std_color_full_body_type(dtype,init, dname, &st_device_printer,\
(int)((float)(w10) * (xdpi) / 10 + 0.5),\
(int)((float)(h10) * (ydpi) / 10 + 0.5),\
xdpi, ydpi, color_bits,\
@@ -377,12 +302,12 @@ extern const gx_device_procs prn_bg_procs;
),\
prn_device_body_rest_(print_page)
-#define prn_device_std_body(dtype, procs, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, color_bits, print_page)\
- prn_device_std_margins_body(dtype, procs, dname, w10, h10, xdpi, ydpi,\
+#define prn_device_std_body(dtype, init, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, color_bits, print_page)\
+ prn_device_std_margins_body(dtype, init, dname, w10, h10, xdpi, ydpi,\
lm, tm, lm, bm, rm, tm, color_bits, print_page)
-#define prn_device_std_margins_body_copies(dtype, procs, dname, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, color_bits, print_page_copies)\
- std_device_std_color_full_body_type(dtype, &procs, dname, &st_device_printer,\
+#define prn_device_std_margins_body_copies(dtype, init, dname, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, color_bits, print_page_copies)\
+ std_device_std_color_full_body_type(dtype, init, dname, &st_device_printer,\
(int)((float)(w10) * (xdpi) / 10 + 0.5),\
(int)((float)(h10) * (ydpi) / 10 + 0.5),\
xdpi, ydpi, color_bits,\
@@ -392,28 +317,28 @@ extern const gx_device_procs prn_bg_procs;
),\
prn_device_body_copies_rest_(print_page_copies)
-#define prn_device_std_body_copies(dtype, procs, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, color_bits, print_page_copies)\
- prn_device_std_margins_body_copies(dtype, procs, dname, w10, h10, xdpi, ydpi,\
+#define prn_device_std_body_copies(dtype, init, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, color_bits, print_page_copies)\
+ prn_device_std_margins_body_copies(dtype, init, dname, w10, h10, xdpi, ydpi,\
lm, tm, lm, bm, rm, tm, color_bits, print_page_copies)
/* Note that the following macros add { } around the data. */
-#define prn_device_margins(procs, dname, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, color_bits, print_page)\
-{ prn_device_std_margins_body(gx_device_printer, procs, dname,\
+#define prn_device_margins(init, dname, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, color_bits, print_page)\
+{ prn_device_std_margins_body(gx_device_printer, init, dname,\
w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, color_bits, print_page)\
}
-#define prn_device(procs, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, color_bits, print_page)\
- prn_device_margins(procs, dname, w10, h10, xdpi, ydpi,\
+#define prn_device(init, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, color_bits, print_page)\
+ prn_device_margins(init, dname, w10, h10, xdpi, ydpi,\
lm, tm, lm, bm, rm, tm, color_bits, print_page)
-#define prn_device_margins_copies(procs, dname, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, color_bits, print_page_copies)\
-{ prn_device_std_margins_body_copies(gx_device_printer, procs, dname,\
+#define prn_device_margins_copies(init, dname, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, color_bits, print_page_copies)\
+{ prn_device_std_margins_body_copies(gx_device_printer, init, dname,\
w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, color_bits, print_page_copies)\
}
-#define prn_device_copies(procs, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, color_bits, print_page_copies)\
- prn_device_margins_copies(procs, dname, w10, h10, xdpi, ydpi,\
+#define prn_device_copies(init, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, color_bits, print_page_copies)\
+ prn_device_margins_copies(init, dname, w10, h10, xdpi, ydpi,\
lm, tm, lm, bm, rm, tm, color_bits, print_page_copies)
/* ------ Utilities ------ */
@@ -452,8 +377,8 @@ bool gdev_prn_file_is_new(const gx_device_printer *pdev);
* not available, so we return all-1s (i.e., any color may appear) as the
* 'or', and the entire page as the range; we may improve this someday.
*
- * The return value is like get_band: the first Y value of the actual range
- * is stored in *range_start, and the height of the range is returned.
+ * On return the first Y value of the actual range is stored in
+ * *range_start, and the height of the range is returned.
* If the parameters are invalid, the procedure returns -1.
*/
int gdev_prn_color_usage(gx_device *dev, int y, int height,
@@ -593,34 +518,21 @@ int gdev_create_buf_device(create_buf_device_proc_t cbd_proc,
#define gdev_prn_transpose_8x8(inp,ils,outp,ols)\
memflip8x8(inp,ils,outp,ols)
-/* ------ Printer device types ------ */
-/**************** THE FOLLOWING CODE IS NOT USED YET. ****************/
-
-#if 0 /**************** VMS linker gets upset *************** */
-#endif
-int gdev_prn_initialize(gx_device *, const char *, dev_proc_print_page((*)));
-void gdev_prn_init_color(gx_device *, int, dev_proc_map_rgb_color((*)), dev_proc_map_color_rgb((*)));
-
-#define prn_device_type(dtname, initproc, pageproc)\
-static dev_proc_print_page(pageproc);\
-device_type(dtname, st_prn_device, initproc)
-
-#define prn_device_type_mono(dtname, dname, initproc, pageproc)\
-static dev_proc_print_page(pageproc);\
-static int \
-initproc(gx_device *dev)\
-{ return gdev_prn_initialize(dev, dname, pageproc);\
-}\
-device_type(dtname, st_prn_device, initproc)
-
-#define prn_device_type_color(dtname, dname, depth, initproc, pageproc, rcproc, crproc)\
-static dev_proc_print_page(pageproc);\
-static int \
-initproc(gx_device *dev)\
-{ int code = gdev_prn_initialize(dev, dname, pageproc);\
- gdev_prn_init_color(dev, depth, rcproc, crproc);\
- return code;\
-}\
-device_type(dtname, st_prn_device, initproc)
+void gdev_prn_initialize_device_procs(gx_device *dev);
+void gdev_prn_initialize_device_procs_bg(gx_device *dev);
+void gdev_prn_initialize_device_procs_mono(gx_device *dev);
+void gdev_prn_initialize_device_procs_mono_bg(gx_device *dev);
+void gdev_prn_initialize_device_procs_rgb(gx_device *dev);
+void gdev_prn_initialize_device_procs_rgb_bg(gx_device *dev);
+void gdev_prn_initialize_device_procs_gray(gx_device *dev);
+void gdev_prn_initialize_device_procs_gray_bg(gx_device *dev);
+void gdev_prn_initialize_device_procs_gray8(gx_device *dev);
+void gdev_prn_initialize_device_procs_gray8_bg(gx_device *dev);
+void gdev_prn_initialize_device_procs_cmyk1(gx_device *dev);
+void gdev_prn_initialize_device_procs_cmyk1_bg(gx_device *dev);
+void gdev_prn_initialize_device_procs_cmyk8(gx_device *dev);
+void gdev_prn_initialize_device_procs_cmyk8_bg(gx_device *dev);
+void gdev_prn_initialize_device_procs_cmyk16(gx_device *dev);
+void gdev_prn_initialize_device_procs_cmyk16_bg(gx_device *dev);
#endif /* gdevprn_INCLUDED */
diff --git a/base/gdevrops.c b/base/gdevrops.c
index 13582008..d0c97b04 100644
--- a/base/gdevrops.c
+++ b/base/gdevrops.c
@@ -46,79 +46,45 @@ static dev_proc_copy_color(rop_texture_copy_color);
static dev_proc_copy_planes(rop_texture_copy_planes);
/* The device descriptor. */
+static void
+rop_texture_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, get_initial_matrix,gx_forward_get_initial_matrix);
+ set_dev_proc(dev, map_rgb_color, gx_forward_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_forward_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, rop_texture_fill_rectangle);
+ set_dev_proc(dev, copy_mono, rop_texture_copy_mono);
+ set_dev_proc(dev, copy_color, rop_texture_copy_color);
+ set_dev_proc(dev, get_params, gx_forward_get_params);
+ set_dev_proc(dev, put_params, gx_forward_put_params);
+ set_dev_proc(dev, map_cmyk_color, gx_forward_map_cmyk_color);
+ set_dev_proc(dev, get_page_device, gx_forward_get_page_device);
+ set_dev_proc(dev, copy_alpha, gx_no_copy_alpha);
+ set_dev_proc(dev, get_clipping_box, gx_forward_get_clipping_box);
+ set_dev_proc(dev, get_hardware_params, gx_forward_get_hardware_params);
+ set_dev_proc(dev, get_color_mapping_procs, gx_forward_get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, gx_forward_get_color_comp_index);
+ set_dev_proc(dev, encode_color, gx_forward_encode_color);
+ set_dev_proc(dev, decode_color, gx_forward_decode_color);
+ set_dev_proc(dev, fill_rectangle_hl_color, gx_forward_fill_rectangle_hl_color);
+ set_dev_proc(dev, include_color_space, gx_forward_include_color_space);
+ set_dev_proc(dev, fill_linear_color_scanline, gx_forward_fill_linear_color_scanline);
+ set_dev_proc(dev, fill_linear_color_trapezoid, gx_forward_fill_linear_color_trapezoid);
+ set_dev_proc(dev, fill_linear_color_triangle, gx_forward_fill_linear_color_triangle);
+ set_dev_proc(dev, update_spot_equivalent_colors, gx_forward_update_spot_equivalent_colors);
+ set_dev_proc(dev, ret_devn_params, gx_forward_ret_devn_params);
+ set_dev_proc(dev, fillpage, gx_forward_fillpage);
+ set_dev_proc(dev, dev_spec_op, gx_forward_dev_spec_op);
+ set_dev_proc(dev, copy_planes, rop_texture_copy_planes);
+ set_dev_proc(dev, get_profile, gx_forward_get_profile);
+ set_dev_proc(dev, set_graphics_type_tag, gx_forward_set_graphics_type_tag);
+}
static const gx_device_rop_texture gs_rop_texture_device = {
- std_device_std_body(gx_device_rop_texture, 0, "rop source",
+ std_device_std_body(gx_device_rop_texture,
+ rop_texture_initialize_device_procs,
+ "rop source",
0, 0, 1, 1),
- {NULL, /* open_device */
- gx_forward_get_initial_matrix,
- NULL, /* default_sync_output */
- NULL, /* output_page */
- NULL, /* close_device */
- gx_forward_map_rgb_color,
- gx_forward_map_color_rgb,
- rop_texture_fill_rectangle,
- NULL, /* tile_rectangle */
- rop_texture_copy_mono,
- rop_texture_copy_color,
- NULL, /* draw_line */
- NULL, /* get_bits */
- gx_forward_get_params,
- gx_forward_put_params,
- gx_forward_map_cmyk_color,
- gx_forward_get_xfont_procs,
- gx_forward_get_xfont_device,
- gx_forward_map_rgb_alpha_color,
- gx_forward_get_page_device,
- NULL, /* get_alpha_bits (no alpha) */
- gx_no_copy_alpha, /* shouldn't be called */
- gx_forward_get_band,
- gx_no_copy_rop, /* shouldn't be called */
- NULL, /* fill_path */
- NULL, /* stroke_path */
- NULL, /* fill_mask */
- NULL, /* fill_trapezoid */
- NULL, /* fill_parallelogram */
- NULL, /* fill_triangle */
- NULL, /* draw_thin_line */
- NULL, /* begin_image */
- NULL, /* image_data */
- NULL, /* end_image */
- NULL, /* strip_tile_rectangle */
- NULL, /* strip_copy_rop */
- gx_forward_get_clipping_box,
- NULL, /* begin_typed_image */
- NULL, /* get_bits_rectangle */
- gx_forward_map_color_rgb_alpha,
- NULL, /* create_compositor */
- gx_forward_get_hardware_params,
- NULL, /* text_begin */
- NULL, /* finish_copydevice */
- NULL, /* begin_transparency_group */
- NULL, /* end_transparency_group */
- NULL, /* begin_transparency_mask */
- NULL, /* end_transparency_mask */
- NULL, /* discard_transparency_layer */
- gx_forward_get_color_mapping_procs,
- gx_forward_get_color_comp_index,
- gx_forward_encode_color,
- gx_forward_decode_color,
- NULL, /* dev_spec_op */
- gx_forward_fill_rectangle_hl_color,
- gx_forward_include_color_space,
- gx_forward_fill_linear_color_scanline,
- gx_forward_fill_linear_color_trapezoid,
- gx_forward_fill_linear_color_triangle,
- gx_forward_update_spot_equivalent_colors,
- gx_forward_ret_devn_params,
- gx_forward_fillpage,
- NULL, /* push_transparency_state */
- NULL, /* pop_transparency_state */
- NULL, /* put_image */
- gx_forward_dev_spec_op,
- rop_texture_copy_planes, /* copy planes */
- gx_forward_get_profile,
- gx_forward_set_graphics_type_tag
- },
+ { 0 },
0, /* target */
lop_default /* log_op */
/* */ /* texture */
@@ -140,9 +106,10 @@ void
gx_make_rop_texture_device(gx_device_rop_texture * dev, gx_device * target,
gs_logical_operation_t log_op, const gx_device_color * texture)
{
- gx_device_init((gx_device *) dev,
- (const gx_device *)&gs_rop_texture_device,
- target->memory, true);
+ /* Can never fail */
+ (void)gx_device_init((gx_device *) dev,
+ (const gx_device *)&gs_rop_texture_device,
+ target->memory, true);
gx_device_set_target((gx_device_forward *)dev, target);
/* Drawing operations are defaulted, non-drawing are forwarded. */
check_device_separable((gx_device *) dev);
diff --git a/base/gdevsclass.c b/base/gdevsclass.c
index 9ce98148..aec26893 100644
--- a/base/gdevsclass.c
+++ b/base/gdevsclass.c
@@ -62,7 +62,7 @@
* before overwriting it, rather than the current check for NULL.
*/
-/* More observations; method naems, we have text_begin, but begin_image.
+/* More observations; method naems, we have text_begin, but begin_typed_image.
* The enumerator initialiser for images gx_image_enum_common_init doesn't initialise
* the 'memory' member variable. The text enumerator initialiser gs_text_enum_init does.
* The default text enum init routine increments the reference count of the device, but the image enumerator
@@ -178,15 +178,6 @@ int default_subclass_fill_rectangle(gx_device *dev, int x, int y, int width, int
return 0;
}
-int default_subclass_tile_rectangle(gx_device *dev, const gx_tile_bitmap *tile, int x, int y, int width, int height,
- gx_color_index color0, gx_color_index color1,
- int phase_x, int phase_y)
-{
- if (dev->child)
- return dev_proc(dev->child, tile_rectangle)(dev->child, tile, x, y, width, height, color0, color1, phase_x, phase_y);
- return 0;
-}
-
int default_subclass_copy_mono(gx_device *dev, const byte *data, int data_x, int raster, gx_bitmap_id id,
int x, int y, int width, int height,
gx_color_index color0, gx_color_index color1)
@@ -204,21 +195,6 @@ int default_subclass_copy_color(gx_device *dev, const byte *data, int data_x, in
return 0;
}
-int default_subclass_draw_line(gx_device *dev, int x0, int y0, int x1, int y1, gx_color_index color)
-{
- if (dev->child)
- return dev_proc(dev->child, obsolete_draw_line)(dev->child, x0, y0, x1, y1, color);
- return 0;
-}
-
-int default_subclass_get_bits(gx_device *dev, int y, byte *data, byte **actual_data)
-{
- if (dev->child)
- return dev_proc(dev->child, get_bits)(dev->child, y, data, actual_data);
- /* else */
- return gx_default_get_bits(dev, y, data, actual_data);
-}
-
int default_subclass_get_params(gx_device *dev, gs_param_list *plist)
{
if (dev->child)
@@ -250,31 +226,6 @@ gx_color_index default_subclass_map_cmyk_color(gx_device *dev, const gx_color_va
return gx_default_map_cmyk_color(dev, cv);
}
-const gx_xfont_procs *default_subclass_get_xfont_procs(gx_device *dev)
-{
- if (dev->child)
- return dev_proc(dev->child, get_xfont_procs)(dev->child);
- /* else */
- return gx_default_get_xfont_procs(dev);
-}
-
-gx_device *default_subclass_get_xfont_device(gx_device *dev)
-{
- if (dev->child)
- return dev_proc(dev->child, get_xfont_device)(dev->child);
- /* else */
- return gx_default_get_xfont_device(dev);
-}
-
-gx_color_index default_subclass_map_rgb_alpha_color(gx_device *dev, gx_color_value red, gx_color_value green, gx_color_value blue,
- gx_color_value alpha)
-{
- if (dev->child)
- return dev_proc(dev->child, map_rgb_alpha_color)(dev->child, red, green, blue, alpha);
- /* else */
- return gx_default_map_rgb_alpha_color(dev, red, green, blue, alpha);
-}
-
gx_device *default_subclass_get_page_device(gx_device *dev)
{
if (dev->child)
@@ -299,26 +250,6 @@ int default_subclass_copy_alpha(gx_device *dev, const byte *data, int data_x,
return 0;
}
-int default_subclass_get_band(gx_device *dev, int y, int *band_start)
-{
- if (dev->child)
- return dev_proc(dev->child, get_band)(dev->child, y, band_start);
- /* else */
- return gx_default_get_band(dev, y, band_start);
-}
-
-int default_subclass_copy_rop(gx_device *dev, const byte *sdata, int sourcex, uint sraster, gx_bitmap_id id,
- const gx_color_index *scolors,
- const gx_tile_bitmap *texture, const gx_color_index *tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- if (dev->child)
- return dev_proc(dev->child, copy_rop)(dev->child, sdata, sourcex, sraster, id, scolors, texture, tcolors, x, y, width, height, phase_x, phase_y, lop);
- /* else */
- return gx_default_copy_rop(dev, sdata, sourcex, sraster, id, scolors, texture, tcolors, x, y, width, height, phase_x, phase_y, lop);
-}
-
int default_subclass_fill_path(gx_device *dev, const gs_gstate *pgs, gx_path *ppath,
const gx_fill_params *params,
const gx_drawing_color *pdcolor, const gx_clip_path *pcpath)
@@ -388,32 +319,6 @@ int default_subclass_draw_thin_line(gx_device *dev, fixed fx0, fixed fy0, fixed
return gx_default_draw_thin_line(dev, fx0, fy0, fx1, fy1, pdcolor, lop, adjustx, adjusty);
}
-int default_subclass_begin_image(gx_device *dev, const gs_gstate *pgs, const gs_image_t *pim,
- gs_image_format_t format, const gs_int_rect *prect,
- const gx_drawing_color *pdcolor, const gx_clip_path *pcpath,
- gs_memory_t *memory, gx_image_enum_common_t **pinfo)
-{
- if (dev->child)
- return dev_proc(dev->child, begin_image)(dev->child, pgs, pim, format, prect, pdcolor, pcpath, memory, pinfo);
- /* else */
- return gx_default_begin_image(dev, pgs, pim, format, prect, pdcolor, pcpath, memory, pinfo);
-}
-
-int default_subclass_image_data(gx_device *dev, gx_image_enum_common_t *info, const byte **planes, int data_x,
- uint raster, int height)
-{
- if (dev->child)
- return dev_proc(dev->child, image_data)(dev->child, info, planes, data_x, raster, height);
- return 0;
-}
-
-int default_subclass_end_image(gx_device *dev, gx_image_enum_common_t *info, bool draw_last)
-{
- if (dev->child)
- return dev_proc(dev->child, end_image)(dev->child, info, draw_last);
- return 0;
-}
-
int default_subclass_strip_tile_rectangle(gx_device *dev, const gx_strip_bitmap *tiles, int x, int y, int width, int height,
gx_color_index color0, gx_color_index color1,
int phase_x, int phase_y)
@@ -424,18 +329,6 @@ int default_subclass_strip_tile_rectangle(gx_device *dev, const gx_strip_bitmap
return gx_default_strip_tile_rectangle(dev, tiles, x, y, width, height, color0, color1, phase_x, phase_y);
}
-int default_subclass_strip_copy_rop(gx_device *dev, const byte *sdata, int sourcex, uint sraster, gx_bitmap_id id,
- const gx_color_index *scolors,
- const gx_strip_bitmap *textures, const gx_color_index *tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- if (dev->child)
- return dev_proc(dev->child, strip_copy_rop)(dev->child, sdata, sourcex, sraster, id, scolors, textures, tcolors, x, y, width, height, phase_x, phase_y, lop);
- /* else */
- return gx_default_strip_copy_rop(dev, sdata, sourcex, sraster, id, scolors, textures, tcolors, x, y, width, height, phase_x, phase_y, lop);
-}
-
void default_subclass_get_clipping_box(gx_device *dev, gs_fixed_rect *pbox)
{
if (dev->child) {
@@ -458,23 +351,15 @@ int default_subclass_begin_typed_image(gx_device *dev, const gs_gstate *pgs, con
}
int default_subclass_get_bits_rectangle(gx_device *dev, const gs_int_rect *prect,
- gs_get_bits_params_t *params, gs_int_rect **unread)
+ gs_get_bits_params_t *params)
{
if (dev->child)
- return dev_proc(dev->child, get_bits_rectangle)(dev->child, prect, params, unread);
+ return dev_proc(dev->child, get_bits_rectangle)(dev->child, prect, params);
/* else */
- return gx_default_get_bits_rectangle(dev, prect, params, unread);
+ return gx_default_get_bits_rectangle(dev, prect, params);
}
-int default_subclass_map_color_rgb_alpha(gx_device *dev, gx_color_index color, gx_color_value rgba[4])
-{
- if (dev->child)
- return dev_proc(dev->child, map_color_rgb_alpha)(dev->child, color, rgba);
- /* else */
- return gx_default_map_color_rgb_alpha(dev, color, rgba);
-}
-
-int default_subclass_create_compositor(gx_device *dev, gx_device **pcdev, const gs_composite_t *pcte,
+int default_subclass_composite(gx_device *dev, gx_device **pcdev, const gs_composite_t *pcte,
gs_gstate *pgs, gs_memory_t *memory, gx_device *cdev)
{
int code;
@@ -484,7 +369,7 @@ int default_subclass_create_compositor(gx_device *dev, gx_device **pcdev, const
* that we pass to access its own data (not unreasonably), so we need to make sure we pass in the
* child device. This has some follow on implications detailed below.
*/
- code = dev_proc(dev->child, create_compositor)(dev->child, pcdev, pcte, pgs, memory, cdev);
+ code = dev_proc(dev->child, composite)(dev->child, pcdev, pcte, pgs, memory, cdev);
if (code < 0)
return code;
@@ -575,22 +460,13 @@ int default_subclass_get_hardware_params(gx_device *dev, gs_param_list *plist)
}
int default_subclass_text_begin(gx_device *dev, gs_gstate *pgs, const gs_text_params_t *text,
- gs_font *font, gx_path *path, const gx_device_color *pdcolor, const gx_clip_path *pcpath,
- gs_memory_t *memory, gs_text_enum_t **ppte)
+ gs_font *font, const gx_clip_path *pcpath,
+ gs_text_enum_t **ppte)
{
if (dev->child)
- return dev_proc(dev->child, text_begin)(dev->child, pgs, text, font, path, pdcolor, pcpath, memory, ppte);
+ return dev_proc(dev->child, text_begin)(dev->child, pgs, text, font, pcpath, ppte);
/* else */
- return gx_default_text_begin(dev, pgs, text, font, path, pdcolor, pcpath, memory, ppte);
-}
-
-/* This method seems (despite the name) to be intended to allow for
- * devices to initialise data before being invoked. For our subclassed
- * device this should already have been done.
- */
-int default_subclass_finish_copydevice(gx_device *dev, const gx_device *from_dev)
-{
- return 0;
+ return gx_default_text_begin(dev, pgs, text, font, pcpath, ppte);
}
int default_subclass_begin_transparency_group(gx_device *dev, const gs_transparency_group_params_t *ptgp,
@@ -635,12 +511,13 @@ int default_subclass_discard_transparency_layer(gx_device *dev, gs_gstate *pgs)
return 0;
}
-const gx_cm_color_map_procs *default_subclass_get_color_mapping_procs(const gx_device *dev)
+const gx_cm_color_map_procs *default_subclass_get_color_mapping_procs(const gx_device *dev,
+ const gx_device **tdev)
{
if (dev->child)
- return dev_proc(dev->child, get_color_mapping_procs)(dev->child);
+ return dev_proc(dev->child, get_color_mapping_procs)(dev->child, tdev);
/* else */
- return gx_default_DevGray_get_color_mapping_procs(dev);
+ return gx_default_DevGray_get_color_mapping_procs(dev, tdev);
}
int default_subclass_get_color_comp_index(gx_device *dev, const char * pname, int name_size, int component_type)
@@ -670,15 +547,6 @@ int default_subclass_decode_color(gx_device *dev, gx_color_index cindex, gx_colo
return 0;
}
-int default_subclass_pattern_manage(gx_device *dev, gx_bitmap_id id,
- gs_pattern1_instance_t *pinst, pattern_manage_t function)
-{
- if (dev->child)
- return dev_proc(dev->child, pattern_manage)(dev->child, id, pinst, function);
-
- return 0;
-}
-
int default_subclass_fill_rectangle_hl_color(gx_device *dev, const gs_fixed_rect *rect,
const gs_gstate *pgs, const gx_drawing_color *pdcolor, const gx_clip_path *pcpath)
{
@@ -809,7 +677,7 @@ int default_subclass_copy_planes(gx_device *dev, const byte *data, int data_x, i
return 0;
}
-int default_subclass_get_profile(gx_device *dev, cmm_dev_profile_t **dev_profile)
+int default_subclass_get_profile(const gx_device *dev, cmm_dev_profile_t **dev_profile)
{
if (dev->child) {
return dev_proc(dev->child, get_profile)(dev->child, dev_profile);
@@ -929,3 +797,98 @@ void default_subclass_finalize(const gs_memory_t *cmem, void *vptr)
if (dev->NupControl)
rc_decrement(dev->NupControl, "finalize subclass device");
}
+
+void default_subclass_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, default_subclass_open_device);
+ set_dev_proc(dev, get_initial_matrix, default_subclass_get_initial_matrix);
+ set_dev_proc(dev, sync_output, default_subclass_sync_output);
+ set_dev_proc(dev, output_page, default_subclass_output_page);
+ set_dev_proc(dev, close_device, default_subclass_close_device);
+ set_dev_proc(dev, map_rgb_color, default_subclass_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, default_subclass_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, default_subclass_fill_rectangle);
+ set_dev_proc(dev, copy_mono, default_subclass_copy_mono);
+ set_dev_proc(dev, copy_color, default_subclass_copy_color);
+ set_dev_proc(dev, get_params, default_subclass_get_params);
+ set_dev_proc(dev, put_params, default_subclass_put_params);
+ set_dev_proc(dev, map_cmyk_color, default_subclass_map_cmyk_color);
+ set_dev_proc(dev, get_page_device, default_subclass_get_page_device);
+ set_dev_proc(dev, get_alpha_bits, default_subclass_get_alpha_bits);
+ set_dev_proc(dev, copy_alpha, default_subclass_copy_alpha);
+ set_dev_proc(dev, fill_path, default_subclass_fill_path);
+ set_dev_proc(dev, stroke_path, default_subclass_stroke_path);
+ set_dev_proc(dev, fill_mask, default_subclass_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, default_subclass_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, default_subclass_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, default_subclass_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, default_subclass_draw_thin_line);
+ set_dev_proc(dev, strip_tile_rectangle, default_subclass_strip_tile_rectangle);
+ set_dev_proc(dev, get_clipping_box, default_subclass_get_clipping_box);
+ set_dev_proc(dev, begin_typed_image, default_subclass_begin_typed_image);
+ set_dev_proc(dev, get_bits_rectangle, default_subclass_get_bits_rectangle);
+ set_dev_proc(dev, composite, default_subclass_composite);
+ set_dev_proc(dev, get_hardware_params, default_subclass_get_hardware_params);
+ set_dev_proc(dev, text_begin, default_subclass_text_begin);
+ set_dev_proc(dev, begin_transparency_group, default_subclass_begin_transparency_group);
+ set_dev_proc(dev, end_transparency_group, default_subclass_end_transparency_group);
+ set_dev_proc(dev, begin_transparency_mask, default_subclass_begin_transparency_mask);
+ set_dev_proc(dev, end_transparency_mask, default_subclass_end_transparency_mask);
+ set_dev_proc(dev, discard_transparency_layer, default_subclass_discard_transparency_layer);
+ set_dev_proc(dev, get_color_mapping_procs, default_subclass_get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, default_subclass_get_color_comp_index);
+ set_dev_proc(dev, encode_color, default_subclass_encode_color);
+ set_dev_proc(dev, decode_color, default_subclass_decode_color);
+ set_dev_proc(dev, fill_rectangle_hl_color, default_subclass_fill_rectangle_hl_color);
+ set_dev_proc(dev, include_color_space, default_subclass_include_color_space);
+ set_dev_proc(dev, fill_linear_color_scanline, default_subclass_fill_linear_color_scanline);
+ set_dev_proc(dev, fill_linear_color_trapezoid, default_subclass_fill_linear_color_trapezoid);
+ set_dev_proc(dev, fill_linear_color_triangle, default_subclass_fill_linear_color_triangle);
+ set_dev_proc(dev, update_spot_equivalent_colors, default_subclass_update_spot_equivalent_colors);
+ set_dev_proc(dev, ret_devn_params, default_subclass_ret_devn_params);
+ set_dev_proc(dev, fillpage, default_subclass_fillpage);
+ set_dev_proc(dev, push_transparency_state, default_subclass_push_transparency_state);
+ set_dev_proc(dev, pop_transparency_state, default_subclass_pop_transparency_state);
+ set_dev_proc(dev, put_image, default_subclass_put_image);
+ set_dev_proc(dev, dev_spec_op, default_subclass_dev_spec_op);
+ set_dev_proc(dev, copy_planes, default_subclass_copy_planes);
+ set_dev_proc(dev, get_profile, default_subclass_get_profile);
+ set_dev_proc(dev, set_graphics_type_tag, default_subclass_set_graphics_type_tag);
+ set_dev_proc(dev, strip_copy_rop2, default_subclass_strip_copy_rop2);
+ set_dev_proc(dev, strip_tile_rect_devn, default_subclass_strip_tile_rect_devn);
+ set_dev_proc(dev, copy_alpha_hl_color, default_subclass_copy_alpha_hl_color);
+ set_dev_proc(dev, process_page, default_subclass_process_page);
+ set_dev_proc(dev, transform_pixel_region, default_subclass_transform_pixel_region);
+ set_dev_proc(dev, fill_stroke_path, default_subclass_fill_stroke_path);
+}
+
+int
+default_subclass_install(gx_device *dev, gs_gstate *pgs)
+{
+ dev = dev->child;
+ return dev->page_procs.install(dev, pgs);
+}
+
+int
+default_subclass_begin_page(gx_device *dev, gs_gstate *pgs)
+{
+ dev = dev->child;
+ return dev->page_procs.begin_page(dev, pgs);
+}
+
+int
+default_subclass_end_page(gx_device *dev, int reason, gs_gstate *pgs)
+{
+ dev = dev->child;
+ return dev->page_procs.end_page(dev, reason, pgs);
+}
+
+void gx_subclass_fill_in_page_procs(gx_device *dev)
+{
+ if (dev->page_procs.install == NULL)
+ dev->page_procs.install = default_subclass_install;
+ if (dev->page_procs.begin_page == NULL)
+ dev->page_procs.begin_page = default_subclass_begin_page;
+ if (dev->page_procs.end_page == NULL)
+ dev->page_procs.end_page = default_subclass_end_page;
+}
diff --git a/base/gdevsclass.h b/base/gdevsclass.h
index aface183..2fb440d6 100644
--- a/base/gdevsclass.h
+++ b/base/gdevsclass.h
@@ -36,22 +36,14 @@ dev_proc_close_device(default_subclass_close_device);
dev_proc_map_rgb_color(default_subclass_map_rgb_color);
dev_proc_map_color_rgb(default_subclass_map_color_rgb);
dev_proc_fill_rectangle(default_subclass_fill_rectangle);
-dev_proc_tile_rectangle(default_subclass_tile_rectangle);
dev_proc_copy_mono(default_subclass_copy_mono);
dev_proc_copy_color(default_subclass_copy_color);
-dev_proc_draw_line(default_subclass_draw_line);
-dev_proc_get_bits(default_subclass_get_bits);
dev_proc_get_params(default_subclass_get_params);
dev_proc_put_params(default_subclass_put_params);
dev_proc_map_cmyk_color(default_subclass_map_cmyk_color);
-dev_proc_get_xfont_procs(default_subclass_get_xfont_procs);
-dev_proc_get_xfont_device(default_subclass_get_xfont_device);
-dev_proc_map_rgb_alpha_color(default_subclass_map_rgb_alpha_color);
dev_proc_get_page_device(default_subclass_get_page_device);
dev_proc_get_alpha_bits(default_subclass_get_alpha_bits);
dev_proc_copy_alpha(default_subclass_copy_alpha);
-dev_proc_get_band(default_subclass_get_band);
-dev_proc_copy_rop(default_subclass_copy_rop);
dev_proc_fill_path(default_subclass_fill_path);
dev_proc_stroke_path(default_subclass_stroke_path);
dev_proc_fill_mask(default_subclass_fill_mask);
@@ -59,19 +51,14 @@ dev_proc_fill_trapezoid(default_subclass_fill_trapezoid);
dev_proc_fill_parallelogram(default_subclass_fill_parallelogram);
dev_proc_fill_triangle(default_subclass_fill_triangle);
dev_proc_draw_thin_line(default_subclass_draw_thin_line);
-dev_proc_begin_image(default_subclass_begin_image);
-dev_proc_image_data(default_subclass_image_data);
-dev_proc_end_image(default_subclass_end_image);
dev_proc_strip_tile_rectangle(default_subclass_strip_tile_rectangle);
-dev_proc_strip_copy_rop(default_subclass_strip_copy_rop);
dev_proc_get_clipping_box(default_subclass_get_clipping_box);
dev_proc_begin_typed_image(default_subclass_begin_typed_image);
dev_proc_get_bits_rectangle(default_subclass_get_bits_rectangle);
-dev_proc_map_color_rgb_alpha(default_subclass_map_color_rgb_alpha);
-dev_proc_create_compositor(default_subclass_create_compositor);
+dev_proc_composite(default_subclass_composite);
dev_proc_get_hardware_params(default_subclass_get_hardware_params);
dev_proc_text_begin(default_subclass_text_begin);
-dev_proc_finish_copydevice(default_subclass_finish_copydevice);
+dev_proc_initialize_device_procs(default_subclass_initialize_device_procs);
dev_proc_begin_transparency_group(default_subclass_begin_transparency_group);
dev_proc_end_transparency_group(default_subclass_end_transparency_group);
dev_proc_begin_transparency_mask(default_subclass_begin_transparency_mask);
@@ -81,7 +68,6 @@ dev_proc_get_color_mapping_procs(default_subclass_get_color_mapping_procs);
dev_proc_get_color_comp_index(default_subclass_get_color_comp_index);
dev_proc_encode_color(default_subclass_encode_color);
dev_proc_decode_color(default_subclass_decode_color);
-dev_proc_pattern_manage(default_subclass_pattern_manage);
dev_proc_fill_rectangle_hl_color(default_subclass_fill_rectangle_hl_color);
dev_proc_include_color_space(default_subclass_include_color_space);
dev_proc_fill_linear_color_scanline(default_subclass_fill_linear_color_scanline);
@@ -103,7 +89,10 @@ dev_proc_copy_alpha_hl_color(default_subclass_copy_alpha_hl_color);
dev_proc_process_page(default_subclass_process_page);
dev_proc_transform_pixel_region(default_subclass_transform_pixel_region);
dev_proc_fill_stroke_path(default_subclass_fill_stroke_path);
-
+dev_page_proc_install(default_subclass_install);
+dev_page_proc_begin_page(default_subclass_begin_page);
+dev_page_proc_end_page(default_subclass_end_page);
void default_subclass_finalize(const gs_memory_t *cmem, void *vptr);
-#endif /* gdev_obj_filter_INCLUDED */
+
+#endif /* gdev_default_subclass_INCLUDED */
diff --git a/base/gdevvec.c b/base/gdevvec.c
index d2694207..2a9915cd 100644
--- a/base/gdevvec.c
+++ b/base/gdevvec.c
@@ -643,7 +643,7 @@ gdev_vector_dopath_init(gdev_vector_dopath_state_t *state,
*/
int
gdev_vector_dopath_segment(gdev_vector_dopath_state_t *state, int pe_op,
- gs_fixed_point vs[3])
+ gs_fixed_point *vs)
{
gx_device_vector *vdev = state->vdev;
const gs_matrix *const pmat = &state->scale_mat;
@@ -901,9 +901,10 @@ gdev_vector_begin_image(gx_device_vector * vdev,
(pim->CombineWithColor && rop3_uses_T(pgs->log_op))) &&
(code = gdev_vector_update_fill_color(vdev, pgs, pdcolor)) < 0) ||
(vdev->bbox_device &&
- (code = (*dev_proc(vdev->bbox_device, begin_image))
- ((gx_device *) vdev->bbox_device, pgs, pim, format, prect,
- pdcolor, pcpath, mem, &pie->bbox_info)) < 0)
+ (code = (*dev_proc(vdev->bbox_device, begin_typed_image))
+ ((gx_device *) vdev->bbox_device, pgs, NULL,
+ (gs_image_common_t *)pim, prect,
+ pdcolor, pcpath, mem, &pie->bbox_info)) < 0)
)
return code;
pie->memory = mem;
@@ -926,8 +927,7 @@ gdev_vector_end_image(gx_device_vector * vdev,
int code;
if (pie->default_info) {
- code = gx_default_end_image((gx_device *) vdev, pie->default_info,
- draw_last);
+ code = gx_image_end(pie->default_info, draw_last);
if (code >= 0)
code = 0;
} else { /* Fill out to the full image height. */
diff --git a/base/gdevvec.h b/base/gdevvec.h
index b7476229..b7998e52 100644
--- a/base/gdevvec.h
+++ b/base/gdevvec.h
@@ -306,7 +306,7 @@ void gdev_vector_dopath_init(gdev_vector_dopath_state_t *state,
/* Write a segment of a path using the default implementation. */
int gdev_vector_dopath_segment(gdev_vector_dopath_state_t *state, int pe_op,
- gs_fixed_point vs[3]);
+ gs_fixed_point *vs);
typedef struct gdev_vector_path_seg_record_s {
int op;
@@ -374,6 +374,17 @@ int gdev_vector_begin_image(gx_device_vector * vdev,
gs_memory_t * mem, const gx_image_enum_procs_t * pprocs,
gdev_vector_image_enum_t * pie);
+int gdev_vector_begin_typed_image(gx_device_vector *vdev,
+ const gs_gstate *pgs,
+ const gs_matrix *pmat,
+ const gs_image_common_t *pim,
+ const gs_int_rect *prect,
+ const gx_drawing_color *pdcolor,
+ const gx_clip_path *pcpath,
+ gs_memory_t *mem,
+ const gx_image_enum_procs_t *pprocs,
+ gdev_vector_image_enum_t *pie);
+
/* End an image, optionally supplying any necessary blank padding rows. */
/* Return 0 if we used the default implementation, 1 if not. */
int gdev_vector_end_image(gx_device_vector * vdev,
diff --git a/base/gp_mshdl.c b/base/gp_mshdl.c
index 2b964ed7..8d87cead 100644
--- a/base/gp_mshdl.c
+++ b/base/gp_mshdl.c
@@ -95,8 +95,17 @@ mswin_handle_fopen(gx_io_device * iodev, const char *fname, const char *access,
long hfile; /* Correct for Win32, may be wrong for Win64 */
gs_lib_ctx_t *ctx = mem->gs_lib_ctx;
gs_fs_list_t *fs = ctx->core->fs;
+ char f[gp_file_name_sizeof];
+ const size_t preflen = strlen(iodev->dname);
+ const size_t nlen = strlen(fname);
- if (gp_validate_path(mem, fname, access) != 0)
+ if (preflen + nlen >= gp_file_name_sizeof)
+ return_error(gs_error_invalidaccess);
+
+ memcpy(f, iodev->dname, preflen);
+ memcpy(f + preflen, fname, nlen + 1);
+
+ if (gp_validate_path(mem, f, access) != 0)
return gs_error_invalidfileaccess;
/* First we try the open_handle method. */
diff --git a/base/gp_msprn.c b/base/gp_msprn.c
index ed482796..746a974f 100644
--- a/base/gp_msprn.c
+++ b/base/gp_msprn.c
@@ -168,8 +168,16 @@ mswin_printer_fopen(gx_io_device * iodev, const char *fname, const char *access,
uintptr_t *ptid = &((tid_t *)(iodev->state))->tid;
gs_lib_ctx_t *ctx = mem->gs_lib_ctx;
gs_fs_list_t *fs = ctx->core->fs;
+ const size_t preflen = strlen(iodev->dname);
+ const size_t nlen = strlen(fname);
- if (gp_validate_path(mem, fname, access) != 0)
+ if (preflen + nlen >= gp_file_name_sizeof)
+ return_error(gs_error_invalidaccess);
+
+ memcpy(pname, iodev->dname, preflen);
+ memcpy(pname + preflen, fname, nlen + 1);
+
+ if (gp_validate_path(mem, pname, access) != 0)
return gs_error_invalidfileaccess;
/* First we try the open_printer method. */
diff --git a/base/gp_os2pr.c b/base/gp_os2pr.c
index f852c71f..ba54cde6 100644
--- a/base/gp_os2pr.c
+++ b/base/gp_os2pr.c
@@ -107,9 +107,20 @@ os2_printer_fopen(gx_io_device * iodev, const char *fname, const char *access,
FILE ** pfile, char *rfname, uint rnamelen)
{
os2_printer_t *pr = (os2_printer_t *)iodev->state;
- char driver_name[256];
+ char driver_name[gp_file_name_sizeof];
gs_lib_ctx_t *ctx = mem->gs_lib_ctx;
gs_fs_list_t *fs = ctx->core->fs;
+ const size_t preflen = strlen(iodev->dname);
+ const int size_t = strlen(fname);
+
+ if (preflen + nlen >= gp_file_name_sizeof)
+ return_error(gs_error_invalidaccess);
+
+ memcpy(driver_name, iodev->dname, preflen);
+ memcpy(driver_name + preflen, fname, nlen + 1);
+
+ if (gp_validate_path(mem, driver_name, access) != 0)
+ return gs_error_invalidfileaccess;
/* First we try the open_printer method. */
/* Note that the loop condition here ensures we don't
diff --git a/base/gp_unifs.c b/base/gp_unifs.c
index a007ddce..3da81444 100644
--- a/base/gp_unifs.c
+++ b/base/gp_unifs.c
@@ -112,7 +112,7 @@ gp_open_scratch_file_impl(const gs_memory_t *mem,
# else
file = mkstemp(fname);
# endif
- if (file < -1) {
+ if (file < 0) {
emprintf1(mem, "**** Could not open temporary file %s\n", ofname);
return NULL;
}
diff --git a/base/gp_unix.c b/base/gp_unix.c
index 420f7526..98db2ddf 100644
--- a/base/gp_unix.c
+++ b/base/gp_unix.c
@@ -497,7 +497,7 @@ void gp_enumerate_fonts_free(void *enum_state)
#ifdef __MINGW32__
int
-gp_local_arg_encoding_get_codepoint(FILE *file, const char **astr)
+gp_local_arg_encoding_get_codepoint(gp_file *file, const char **astr)
{
int len;
int c;
@@ -506,7 +506,7 @@ gp_local_arg_encoding_get_codepoint(FILE *file, const char **astr)
char utf8[4];
if (file) {
- c = fgetc(file);
+ c = gp_fgetc(file);
if (c == EOF)
return EOF;
} else if (**astr) {
@@ -520,7 +520,7 @@ gp_local_arg_encoding_get_codepoint(FILE *file, const char **astr)
arg[0] = c;
if (IsDBCSLeadByte(c)) {
if (file) {
- c = fgetc(file);
+ c = gp_fgetc(file);
if (c == EOF)
return EOF;
} else if (**astr) {
diff --git a/base/gs.mak b/base/gs.mak
index f67a2446..0b84be49 100644
--- a/base/gs.mak
+++ b/base/gs.mak
@@ -248,6 +248,7 @@ GS_MAK=$(GLSRCDIR)$(D)gs.mak $(TOP_MAKEFILES)
GS_XE=$(BINDIR)$(D)$(GS)$(XE)
GPCL_XE=$(BINDIR)$(D)$(PCL)$(XE)
GXPS_XE=$(BINDIR)$(D)$(XPS)$(XE)
+GPDF_XE=$(BINDIR)$(D)$(PDF)$(XE)
GPDL_XE=$(BINDIR)$(D)$(GPDL)$(XE)
AUX=$(AUXDIR)$(D)
@@ -411,6 +412,11 @@ XPS_DEVS_ALL=$(GSPLAT_DEVS_ALL) \
$(FEATURE_DEVS_EXTRA) \
$(DEVICE_DEVS_ALL)
+PDF_DEVS_ALL=$(GSPLAT_DEVS_ALL) \
+ $(FEATURE_DEVS) \
+ $(FEATURE_DEVS_EXTRA) \
+ $(DEVICE_DEVS_ALL)
+
DEVS_ALL=$(GLGENDIR)$(D)$(GSPLATFORM).dev\
$(FEATURE_DEVS_EXTRA) \
$(DEVICE_DEVS) $(DEVICE_DEVS1) \
@@ -513,6 +519,16 @@ $(xps_tr): $(GS_MAK) $(GLSRCDIR)$(D)version.mak $(GENCONF_XE) $(ECHOGS_XE) $(ld_
$(EXP)$(ECHOGS_XE) -a $(xps_tr) -R $(ixps_tr)
$(EXP)$(GENCONF_XE) $(xps_tr) -h $(GLGENDIR)$(D)unused.h $(CONFILES) $(CONFLDTR) $(xpsld_tr)
+pdf_tr=$(GLGENDIR)$(D)pdf.tr
+ipdf_tr=$(GLGENDIR)$(D)ipdf.tr
+pdfld_tr=$(GLGENDIR)$(D)pdfld.tr
+$(pdf_tr): $(GS_MAK) $(GLSRCDIR)$(D)version.mak $(GENCONF_XE) $(ECHOGS_XE) $(ld_tr) $(devs_tr) $(PDF_DEVS_ALL) \
+ $(devs_tr) $(PDF_FEATURE_DEVS) $(GLGENDIR)$(D)libcore.dev $(MAKEDIRS)
+ $(EXP)$(ECHOGS_XE) -w $(ipdf_tr) - -include $(PDF_FEATURE_DEVS)
+ $(EXP)$(ECHOGS_XE) -w $(pdf_tr) -R $(devs_tr)
+ $(EXP)$(ECHOGS_XE) -a $(pdf_tr) -R $(ipdf_tr)
+ $(EXP)$(GENCONF_XE) $(pdf_tr) -h $(GLGENDIR)$(D)unused.h $(CONFILES) $(CONFLDTR) $(pdfld_tr)
+
gpdl_tr=$(GLGENDIR)$(D)gpdl.tr
igpdl_tr=$(GLGENDIR)$(D)igpdl.tr
gpdlld_tr=$(GLGENDIR)$(D)gpdlld.tr
@@ -560,6 +576,10 @@ xpsobj_tr=$(GLGENDIR)$(D)xpsobj.tr
$(xpsobj_tr) : $(xps_tr)
$(EXP)$(GENCONF_XE) $(xps_tr) -h $(GLGENDIR)$(D)unused.h $(CONFILES) -o $(xpsobj_tr)
+pdfobj_tr=$(GLGENDIR)$(D)pdfobj.tr
+$(pdfobj_tr) : $(pdf_tr)
+ $(EXP)$(GENCONF_XE) $(pdf_tr) -h $(GLGENDIR)$(D)unused.h $(CONFILES) -o $(pdfobj_tr)
+
pdlobj_tr=$(GLGENDIR)$(D)pdlobj.tr
$(pdlobj_tr) : $(gpdl_tr)
diff --git a/devices/vector/gdevagl.c b/base/gsagl.c
index 05b971a1..434520cf 100644
--- a/devices/vector/gdevagl.c
+++ b/base/gsagl.c
@@ -12,7 +12,7 @@
Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
CA 94945, U.S.A., +1(415)492-9861, for further information.
*/
-#include "gdevagl.h"
+#include "gsagl.h"
single_glyph_list_t SingleGlyphList[] = {
{"A", 0x0041},
diff --git a/devices/vector/gdevagl.h b/base/gsagl.h
index e05b53be..949789a8 100644
--- a/devices/vector/gdevagl.h
+++ b/base/gsagl.h
@@ -16,8 +16,8 @@
* Unicode code points.
*/
-#ifndef gdevagl_h_INCLUDED
-#define gdevagl_h_INCLUDED
+#ifndef gsagl_h_INCLUDED
+#define gsagl_h_INCLUDED
typedef struct single_glyph_list_s {
const char *Glyph;
diff --git a/base/gsbitops.h b/base/gsbitops.h
index 4087f19b..127c24aa 100644
--- a/base/gsbitops.h
+++ b/base/gsbitops.h
@@ -257,7 +257,7 @@ static int inline sample_store_next8(uint value, byte **dptr, int *dbit, int dbp
if ( *dbit ^= 4 )
*dbbyte = (byte)(value << 4);
else
- *(*dptr)++ = *dbbyte | ((byte)value);\
+ *(*dptr)++ = *dbbyte | ((byte)value);
break;
case 2:
*(*dptr)++ = (byte)value;
diff --git a/base/gscdevn.c b/base/gscdevn.c
index 94ffc562..41febb7f 100644
--- a/base/gscdevn.c
+++ b/base/gscdevn.c
@@ -205,6 +205,31 @@ gs_attachcolorant(char *sep_name, gs_gstate * pgs)
return 0;
}
+int
+gs_attach_colorant_to_space(char *sep_name, gs_color_space *pcs, gs_color_space *colorant_space, gs_memory_t *mem)
+{
+ gs_device_n_colorant * patt;
+
+ if (pcs->type != &gs_color_space_type_DeviceN)
+ return_error(gs_error_rangecheck);
+
+ /* Allocate an attribute list element for our linked list of colorants */
+ rc_alloc_struct_1(patt, gs_device_n_colorant, &st_device_n_colorant,
+ mem, return_error(gs_error_VMerror),
+ "gs_attachattributrescolorspace");
+
+ /* Point our attribute list entry to the attribute color space */
+ patt->colorant_name = sep_name;
+ patt->cspace = colorant_space;
+ rc_increment_cs(patt->cspace);
+
+ /* Link our new attribute color space to the DeviceN color space */
+ patt->next = pcs->params.device_n.colorants;
+ pcs->params.device_n.colorants = patt;
+
+ return 0;
+}
+
#if 0 /* Unused; Unsupported by gx_serialize_device_n_map. */
/*
* Set the DeviceN tint transformation procedure.
@@ -557,6 +582,14 @@ check_DeviceN_component_names(const gs_color_space * pcs, gs_gstate * pgs)
pcolor_component_map->cspace_id = pcs->id;
pcolor_component_map->num_colorants = dev->color_info.num_components;
pcolor_component_map->sep_type = SEP_OTHER;
+
+ /* If the named color profile supports the components, don't use
+ the alternate tint transform. */
+ if (gsicc_support_named_color(pcs, pgs)) {
+ pcolor_component_map->use_alt_cspace = false;
+ return 0;
+ }
+
/*
* Always use the alternate color space if the current device is
* using an additive color model. The exception is if we have a separation
@@ -577,7 +610,6 @@ check_DeviceN_component_names(const gs_color_space * pcs, gs_gstate * pgs)
* additive color space then use the alternate tint transform.
*/
- non_match = false;
for(i = 0; i < num_comp; i++ ) {
/*
* Get the character string and length for the component name.
@@ -748,11 +780,11 @@ gx_set_overprint_DeviceN(const gs_color_space * pcs, gs_gstate * pgs)
params.retain_any_comps = (pgs->overprint && pgs->is_fill_color) ||
(pgs->stroke_overprint && !pgs->is_fill_color);
+ params.drawn_comps = 0;
if (params.retain_any_comps) {
int i, ncomps = pcs->params.device_n.num_components;
params.is_fill_color = pgs->is_fill_color; /* for fill_stroke */
- params.drawn_comps = 0;
for (i = 0; i < ncomps; i++) {
int mcomp = pcmap->color_map[i];
if (mcomp >= 0)
@@ -770,7 +802,7 @@ gx_set_overprint_DeviceN(const gs_color_space * pcs, gs_gstate * pgs)
/* Finalize contents of a DeviceN color space. */
static void
-gx_final_DeviceN(const gs_color_space * pcs)
+gx_final_DeviceN(gs_color_space * pcs)
{
gs_device_n_colorant * pnextatt, * patt = pcs->params.device_n.colorants;
uint num_proc_names = pcs->params.device_n.num_process_names;
@@ -797,6 +829,10 @@ gx_final_DeviceN(const gs_color_space * pcs)
rc_decrement(patt, "gx_adjust_DeviceN");
patt = pnextatt;
}
+ if (pcs->params.device_n.devn_process_space)
+ rc_decrement_only(pcs->params.device_n.devn_process_space, "gx_final_DeviceN");
+ /* Ensure idempotency */
+ memset(&pcs->params.device_n, 0, sizeof(pcs->params.device_n));
}
/* ---------------- Serialization. -------------------------------- */
diff --git a/base/gscdevn.h b/base/gscdevn.h
index f35e9b0e..b2b6c5de 100644
--- a/base/gscdevn.h
+++ b/base/gscdevn.h
@@ -78,4 +78,14 @@ int gx_serialize_device_n_map(const gs_color_space * pcs, gs_device_n_map * m, s
*/
int gs_attachcolorant(char *sep_name, gs_gstate * pgs);
+/*
+ * This is the same routine as above, but more general. Instead of assuming that
+ * the current coloru space is hte colorant space, and the saved graphics state
+ * contains the DeviceN space, we pass both those in, along with the memory
+ * allocater we want the routine to use.
+ * This is for the pdfi PDF interpreter (and potentially any other non-PostScript
+ * interpreter)
+ */
+int gs_attach_colorant_to_space(char *sep_name, gs_color_space *pcs, gs_color_space *colorant_space, gs_memory_t *mem);
+
#endif /* gscdevn_INCLUDED */
diff --git a/base/gscms.h b/base/gscms.h
index caedcb90..7fb362fe 100644
--- a/base/gscms.h
+++ b/base/gscms.h
@@ -29,7 +29,7 @@
#define NUM_DEVICE_PROFILES 4
#define NUM_SOURCE_PROFILES 3
#define GS_DEFAULT_DEVICE_PROFILE 0
-#define GS_GRAPHIC_DEVICE_PROFILE 1
+#define GS_VECTOR_DEVICE_PROFILE 1
#define GS_IMAGE_DEVICE_PROFILE 2
#define GS_TEXT_DEVICE_PROFILE 3
@@ -210,7 +210,7 @@ typedef enum {
GS_UNTOUCHED_TAG = 0x0, /* UNTOUCHED *must* be 0 -- transparency code relies on this */
GS_TEXT_TAG = 0x1,
GS_IMAGE_TAG = 0x2,
- GS_PATH_TAG = 0x4,
+ GS_VECTOR_TAG = 0x4,
GS_UNKNOWN_TAG = 0x40,
GS_DEVICE_ENCODES_TAGS = 0x80
} gs_graphics_type_tag_t;
diff --git a/base/gscolor2.c b/base/gscolor2.c
index 85238bf4..e730ae02 100644
--- a/base/gscolor2.c
+++ b/base/gscolor2.c
@@ -294,16 +294,18 @@ gx_set_overprint_Indexed(const gs_color_space * pcs, gs_gstate * pgs)
/* Color space finalization ditto. */
static void
-gx_final_Indexed(const gs_color_space * pcs)
+gx_final_Indexed(gs_color_space * pcs)
{
if (pcs->params.indexed.use_proc) {
rc_adjust_const(pcs->params.indexed.lookup.map, -1,
"gx_adjust_Indexed");
+ pcs->params.indexed.lookup.map = NULL;
} else {
byte *data = (byte *)pcs->params.indexed.lookup.table.data; /* Break 'const'. */
gs_free_string(pcs->rc.memory, data,
pcs->params.indexed.lookup.table.size, "gx_final_Indexed");
+ pcs->params.indexed.lookup.table.data = NULL;
}
}
diff --git a/base/gscolor3.c b/base/gscolor3.c
index 66cadecd..951f6741 100644
--- a/base/gscolor3.c
+++ b/base/gscolor3.c
@@ -109,7 +109,7 @@ gs_shfill(gs_gstate * pgs, const gs_shading_t * psh)
/* make sure the tag gets set correctly */
if (pgs->show_gstate == NULL)
- ensure_tag_is_set(pgs, pgs->device, GS_PATH_TAG); /* NB: may unset_dev_color */
+ ensure_tag_is_set(pgs, pgs->device, GS_VECTOR_TAG); /* NB: may unset_dev_color */
else
ensure_tag_is_set(pgs, pgs->device, GS_TEXT_TAG); /* NB: may unset_dev_color */
diff --git a/base/gscoord.c b/base/gscoord.c
index 8343a091..f32e4cd3 100644
--- a/base/gscoord.c
+++ b/base/gscoord.c
@@ -130,16 +130,150 @@ gs_defaultmatrix(const gs_gstate * pgs, gs_matrix * pmat)
int
gs_setdefaultmatrix(gs_gstate * pgs, const gs_matrix * pmat)
{
- if (pmat == NULL)
+ if (pmat == NULL) {
pgs->ctm_default_set = false;
- else {
+ pgs->ctm_initial_set = false;
+ } else {
+ gx_device *dev;
+
pgs->ctm_default = *pmat;
pgs->ctm_default_set = true;
+
+ /* We also store the current 'initial' matrix, so we can spot
+ * changes in this in future. */
+ dev = gs_currentdevice_inline(pgs);
+ gs_deviceinitialmatrix(dev, &pgs->ctm_initial);
+ pgs->ctm_initial_set = 1;
}
return 0;
}
int
+gs_updatematrices(gs_gstate *pgs)
+{
+ gx_device *dev;
+ gs_matrix newdefault, init, t, inv, newctm;
+ int code;
+#ifdef DEBUG
+ gs_matrix *mat;
+#endif
+
+ /* Read the current device initial matrix. */
+ dev = gs_currentdevice_inline(pgs);
+ gs_deviceinitialmatrix(dev, &init);
+
+#ifdef DEBUG
+ if (gs_debug_c('x'))
+ dlprintf("[x]updatematrices\n");
+#endif
+
+ if (pgs->ctm_default_set == 0 ||
+ pgs->ctm_initial_set == 0) {
+ /* If neither default or initial are set, then store them for the
+ * first time. */
+ pgs->ctm_initial = init;
+ pgs->ctm_initial_set = 1;
+ pgs->ctm_default = init;
+ pgs->ctm_default_set = 1;
+#ifdef DEBUG
+ if (gs_debug_c('x')) {
+ mat = &pgs->ctm_initial;
+ dlprintf6("storing initial/default = %g %g %g %g %g %g\n", mat->xx, mat->xy, mat->yx, mat->yy, mat->tx, mat->ty);
+ }
+#endif
+ return 0;
+ }
+
+#ifdef DEBUG
+ if (gs_debug_c('x')) {
+ mat = &init;
+ dlprintf6("initial = %g %g %g %g %g %g\n", mat->xx, mat->xy, mat->yx, mat->yy, mat->tx, mat->ty);
+ mat = &pgs->ctm_default;
+ dlprintf6("default = %g %g %g %g %g %g\n", mat->xx, mat->xy, mat->yx, mat->yy, mat->tx, mat->ty);
+ mat = (gs_matrix *)&pgs->ctm;
+ dlprintf6("ctm = %g %g %g %g %g %g\n", mat->xx, mat->xy, mat->yx, mat->yy, mat->tx, mat->ty);
+ mat = &pgs->ctm_initial;
+ dlprintf6("stored initial = %g %g %g %g %g %g\n", mat->xx, mat->xy, mat->yx, mat->yy, mat->tx, mat->ty);
+ }
+#endif
+ /* If no change, then nothing else to do here. */
+ if (init.xx == pgs->ctm_initial.xx &&
+ init.xy == pgs->ctm_initial.xy &&
+ init.yx == pgs->ctm_initial.yx &&
+ init.yy == pgs->ctm_initial.yy &&
+ init.tx == pgs->ctm_initial.tx &&
+ init.ty == pgs->ctm_initial.ty)
+ return 0;
+
+ /* So, the initial matrix has changed from what it was
+ * the last time the default matrix was set. The default
+ * matrix is some modification of the initial matrix
+ * (typically a scale, or a translation, or a flip or
+ * some combination thereof). Now the initial matrix
+ * has changed (possibly because of Nup, or because of
+ * a device doing Duplex etc), the default matrix is
+ * almost certainly wrong. We therefore adjust it here.*/
+
+ /* So originally: old_default = modification.old_init
+ * and we want: new_default = modification.new_init
+ *
+ * So: modification = old_default.INV(old_init)
+ * new_default = old_default.INV(old_init).new_init
+ */
+ code = gs_matrix_invert(&pgs->ctm_initial, &inv);
+ if (code < 0)
+ return code;
+ code = gs_matrix_multiply(&pgs->ctm_default, &inv, &t);
+ if (code < 0)
+ return code;
+ code = gs_matrix_multiply(&t, &init, &newdefault);
+ if (code < 0)
+ return code;
+
+ /* Now, the current ctm is similarly derived from the
+ * old default. We want to update it to be derived (in the
+ * same way) from the new default.
+ *
+ * So: old_ctm = modification.old_default
+ * old_ctm.INV(old_default) = modification
+ * And: new_ctm = modification.new_default
+ * = old_ctm.INV(old_default).new_default
+ */
+ code = gs_matrix_invert(&pgs->ctm_default, &inv);
+ if (code < 0)
+ return code;
+ code = gs_matrix_multiply((gs_matrix *)&pgs->ctm, &inv, &t);
+ if (code < 0)
+ return code;
+ code = gs_matrix_multiply(&t, &newdefault, &newctm);
+ if (code < 0)
+ return code;
+
+ pgs->ctm_initial = init;
+ pgs->ctm_default = newdefault;
+ gs_setmatrix(pgs, &newctm);
+
+#ifdef DEBUG
+ if (gs_debug_c('x')) {
+ mat = &pgs->ctm_default;
+ dlprintf6("new default = %g %g %g %g %g %g\n", mat->xx, mat->xy, mat->yx, mat->yy, mat->tx, mat->ty);
+ mat = (gs_matrix *)&pgs->ctm;
+ dlprintf6("new ctm = %g %g %g %g %g %g\n", mat->xx, mat->xy, mat->yx, mat->yy, mat->tx, mat->ty);
+ }
+#endif
+
+ /* This is a bit nasty. This resets the clipping box to the page.
+ * We need to do this, because otherwise the clipping box is
+ * not updated with the ctm, and (typically) the entire contents
+ * of the page end up clipped away. This will break usages where
+ * we run 1 file (or set of postscript commands) to set the clipping
+ * box, and then another file to actually draw stuff to be clipped.
+ * Given this will only go wrong in the case where the device is
+ * Nupping or Duplexing, we'll live with this for now. */
+ return gs_initclip(pgs);
+}
+
+int
gs_currentmatrix(const gs_gstate * pgs, gs_matrix * pmat)
{
*pmat = ctm_only(pgs);
diff --git a/base/gscoord.h b/base/gscoord.h
index 0c18f6c6..af05c9af 100644
--- a/base/gscoord.h
+++ b/base/gscoord.h
@@ -38,7 +38,8 @@ int gs_initmatrix(gs_gstate *),
int gs_setdefaultmatrix(gs_gstate *, const gs_matrix *),
gs_currentcharmatrix(gs_gstate *, gs_matrix *, bool),
gs_setcharmatrix(gs_gstate *, const gs_matrix *),
- gs_settocharmatrix(gs_gstate *);
+ gs_settocharmatrix(gs_gstate *),
+ gs_updatematrices(gs_gstate *);
/* Coordinate transformation */
int gs_transform(gs_gstate *, double, double, gs_point *),
diff --git a/base/gscparam.c b/base/gscparam.c
index 1b4522a8..b3934417 100644
--- a/base/gscparam.c
+++ b/base/gscparam.c
@@ -53,6 +53,7 @@ struct gs_c_param_s {
gs_c_param_value value;
gs_param_type type;
void *alternate_typed_data;
+ int error;
};
/* GC descriptor and procedures */
@@ -261,6 +262,7 @@ c_param_add(gs_c_param_list * plist, gs_param_name pkey)
}
pparam->key.size = len;
pparam->alternate_typed_data = 0;
+ pparam->error = 0;
return pparam;
}
@@ -450,6 +452,7 @@ static param_proc_xmit_typed(c_param_read_typed);
static param_proc_next_key(c_param_get_next_key);
static param_proc_get_policy(c_param_read_get_policy);
static param_proc_signal_error(c_param_read_signal_error);
+static param_proc_read_signalled_error(c_param_read_signalled_error);
static param_proc_commit(c_param_read_commit);
static const gs_param_list_procs c_read_procs =
{
@@ -461,7 +464,8 @@ static const gs_param_list_procs c_read_procs =
NULL, /* requested, N/A */
c_param_read_get_policy,
c_param_read_signal_error,
- c_param_read_commit
+ c_param_read_commit,
+ c_param_read_signalled_error
};
/* Switch a list from writing to reading. */
@@ -596,10 +600,24 @@ c_param_read_get_policy(gs_param_list * plist, gs_param_name pkey)
static int
c_param_read_signal_error(gs_param_list * plist, gs_param_name pkey, int code)
{
- return code;
+ gs_c_param_list *const cplist = (gs_c_param_list *)plist;
+ gs_c_param *pparam = c_param_find(cplist, pkey, false);
+
+ if (pparam)
+ pparam->error = code;
+
+ return 0;
}
static int
c_param_read_commit(gs_param_list * plist)
{
return 0;
}
+static int
+c_param_read_signalled_error(gs_param_list * plist, gs_param_name pkey)
+{
+ gs_c_param_list *const cplist = (gs_c_param_list *)plist;
+ gs_c_param *pparam = c_param_find(cplist, pkey, false);
+
+ return (pparam ? pparam->error : 0);
+}
diff --git a/base/gscscie.c b/base/gscscie.c
index 3bc94aed..d39f0244 100644
--- a/base/gscscie.c
+++ b/base/gscscie.c
@@ -148,59 +148,63 @@ gx_install_CIE(gs_color_space * pcs, gs_gstate * pgs)
/* Free params for a CIE color space */
static void
-gx_final_CIEDEFG(const gs_color_space * pcs)
+gx_final_CIEDEFG(gs_color_space * pcs)
{
- gs_color_space *pcs_noconst = (gs_color_space *)pcs;
-
if (pcs->icc_equivalent != NULL) {
- rc_decrement(pcs_noconst->icc_equivalent, "gx_final_CIEDEFG");
+ rc_decrement(pcs->icc_equivalent, "gx_final_CIEDEFG");
+ pcs->icc_equivalent = NULL;
}
if (pcs->cmm_icc_profile_data != NULL) {
- gsicc_adjust_profile_rc(pcs_noconst->cmm_icc_profile_data, -1, "gx_final_CIEDEFG");
+ gsicc_adjust_profile_rc(pcs->cmm_icc_profile_data, -1, "gx_final_CIEDEFG");
+ pcs->cmm_icc_profile_data = NULL;
}
- rc_decrement(pcs_noconst->params.defg, "gx_final_CIEDEFG");
+ rc_decrement(pcs->params.defg, "gx_final_CIEDEFG");
+ pcs->params.defg = NULL;
}
static void
-gx_final_CIEDEF(const gs_color_space * pcs)
+gx_final_CIEDEF(gs_color_space * pcs)
{
- gs_color_space *pcs_noconst = (gs_color_space *)pcs;
-
if (pcs->icc_equivalent != NULL) {
- rc_decrement(pcs_noconst->icc_equivalent,"gx_final_CIEDEF");
+ rc_decrement(pcs->icc_equivalent,"gx_final_CIEDEF");
+ pcs->icc_equivalent = NULL;
}
if (pcs->cmm_icc_profile_data != NULL) {
- gsicc_adjust_profile_rc(pcs_noconst->cmm_icc_profile_data, -1, "gx_final_CIEDEF");
+ gsicc_adjust_profile_rc(pcs->cmm_icc_profile_data, -1, "gx_final_CIEDEF");
+ pcs->cmm_icc_profile_data = NULL;
}
- rc_decrement(pcs_noconst->params.def, "gx_final_CIEDEF");
+ rc_decrement(pcs->params.def, "gx_final_CIEDEF");
+ pcs->params.def = NULL;
}
static void
-gx_final_CIEABC(const gs_color_space * pcs)
+gx_final_CIEABC(gs_color_space * pcs)
{
- gs_color_space *pcs_noconst = (gs_color_space *)pcs;
-
if (pcs->icc_equivalent != NULL) {
- rc_decrement(pcs_noconst->icc_equivalent,"gx_final_CIEABC");
+ rc_decrement(pcs->icc_equivalent,"gx_final_CIEABC");
+ pcs->icc_equivalent = NULL;
}
if (pcs->cmm_icc_profile_data != NULL) {
- gsicc_adjust_profile_rc(pcs_noconst->cmm_icc_profile_data, -1, "gx_final_CIEABC");
+ gsicc_adjust_profile_rc(pcs->cmm_icc_profile_data, -1, "gx_final_CIEABC");
+ pcs->cmm_icc_profile_data = NULL;
}
- rc_decrement(pcs_noconst->params.abc, "gx_final_CIEABC");
+ rc_decrement(pcs->params.abc, "gx_final_CIEABC");
+ pcs->params.abc = NULL;
}
static void
-gx_final_CIEA(const gs_color_space * pcs)
+gx_final_CIEA(gs_color_space * pcs)
{
- gs_color_space *pcs_noconst = (gs_color_space *)pcs;
-
if (pcs->icc_equivalent != NULL) {
- rc_decrement(pcs_noconst->icc_equivalent,"gx_final_CIEA");
+ rc_decrement(pcs->icc_equivalent,"gx_final_CIEA");
+ pcs->icc_equivalent = NULL;
}
if (pcs->cmm_icc_profile_data != NULL) {
- gsicc_adjust_profile_rc(pcs_noconst->cmm_icc_profile_data, -1, "gx_final_CIEA");
+ gsicc_adjust_profile_rc(pcs->cmm_icc_profile_data, -1, "gx_final_CIEA");
+ pcs->cmm_icc_profile_data = NULL;
}
- rc_decrement(pcs_noconst->params.a, "gx_adjust_cspace_CIEA");
+ rc_decrement(pcs->params.a, "gx_adjust_cspace_CIEA");
+ pcs->params.a = NULL;
}
/* ---------------- Procedures ---------------- */
diff --git a/base/gscsepr.c b/base/gscsepr.c
index 34118988..10400106 100644
--- a/base/gscsepr.c
+++ b/base/gscsepr.c
@@ -210,11 +210,13 @@ gx_set_overprint_Separation(const gs_color_space * pcs, gs_gstate * pgs)
/* Finalize contents of a Separation color space. */
static void
-gx_final_Separation(const gs_color_space * pcs)
+gx_final_Separation(gs_color_space * pcs)
{
rc_adjust_const(pcs->params.separation.map, -1,
"gx_adjust_Separation");
+ pcs->params.separation.map = NULL;
gs_free_object(pcs->params.separation.mem, pcs->params.separation.sep_name, "gx_final_Separation");
+ pcs->params.separation.sep_name = NULL;
}
/* ------ Constructors/accessors ------ */
@@ -454,9 +456,11 @@ check_Separation_component_name(const gs_color_space * pcs, gs_gstate * pgs)
pcolor_component_map->sep_type = pcs->params.separation.sep_type;
/*
* If this is a None or All separation then we do not need to
- * use the alternate color space.
- */
- if (pcs->params.separation.sep_type != SEP_OTHER) {
+ * use the alternate color space. Also if the named color
+ * profile supports the component, don't use the alternate
+ * tint transform. */
+ if (pcs->params.separation.sep_type != SEP_OTHER ||
+ gsicc_support_named_color(pcs, pgs)) {
pcolor_component_map->use_alt_cspace = false;
return 0;
}
diff --git a/base/gscspace.c b/base/gscspace.c
index 81baac9a..d662bc02 100644
--- a/base/gscspace.c
+++ b/base/gscspace.c
@@ -92,6 +92,8 @@ public_st_base_color_space();
/* ------ Create/copy/destroy ------ */
+/* Ghostscript object finalizers can be called many times and hence
+ * must be idempotent. */
static void
gs_cspace_final(const gs_memory_t *cmem, void *vptr)
{
@@ -100,17 +102,20 @@ gs_cspace_final(const gs_memory_t *cmem, void *vptr)
if (pcs->interpreter_free_cspace_proc != NULL) {
(*pcs->interpreter_free_cspace_proc) ((gs_memory_t *)cmem, pcs);
+ pcs->interpreter_free_cspace_proc = NULL;
}
if (pcs->type->final)
pcs->type->final(pcs);
if_debug2m('c', cmem, "[c]cspace final "PRI_INTPTR" %d\n", (intptr_t)pcs, (int)pcs->id);
rc_decrement_only_cs(pcs->base_space, "gs_cspace_final");
- if (pcs->params.device_n.devn_process_space != NULL)
+ pcs->base_space = NULL;
+ if (pcs->params.device_n.devn_process_space != NULL) {
rc_decrement_only_cs(pcs->params.device_n.devn_process_space, "gs_cspace_final");
+ pcs->params.device_n.devn_process_space = NULL;
+ }
/* No need to decrement the ICC profile data. It is handled
by the finalize of the ICC space which is called above using
pcs->type->final(pcs); */
-
}
static gs_color_space *
@@ -425,7 +430,8 @@ void cs_adjust_counts_icc(gs_gstate *pgs, int delta)
gs_color_space *pcs = gs_currentcolorspace_inline(pgs);
if (pcs) {
- cs_adjust_counts(pgs, delta);
+ cs_adjust_color_count(pgs, delta);
+ rc_adjust_const(pcs, delta, "cs_adjust_counts_icc");
}
}
@@ -434,7 +440,8 @@ void cs_adjust_swappedcounts_icc(gs_gstate *pgs, int delta)
gs_color_space *pcs = gs_swappedcolorspace_inline(pgs);
if (pcs) {
- cs_adjust_swappedcounts(pgs, delta);
+ cs_adjust_swappedcolor_count(pgs, delta);
+ rc_adjust_const(pcs, delta, "cs_adjust_swappedcounts_icc");
}
}
@@ -513,16 +520,7 @@ gx_set_spot_only_overprint(gs_gstate* pgs)
{
gs_overprint_params_t params = { 0 };
gx_device* dev = pgs->device;
- gx_color_index drawn_comps = 0;
- gx_device_color_info* pcinfo = (dev == 0 ? 0 : &dev->color_info);
-
- if (dev) {
- /* check if color model behavior must be determined */
- if (pcinfo->opmode == GX_CINFO_OPMODE_UNKNOWN)
- drawn_comps = check_cmyk_color_model_comps(dev);
- else
- drawn_comps = pcinfo->process_comps;
- }
+ gx_color_index drawn_comps = dev == NULL ? 0 : gx_get_process_comps(dev);
params.retain_any_comps = true;
params.op_state = OP_STATE_NONE;
@@ -595,10 +593,19 @@ check_cmyk_color_model_comps(gx_device * dev)
gx_device_color_info * pcinfo = &dev->color_info;
uchar ncomps = pcinfo->num_components;
int cyan_c, magenta_c, yellow_c, black_c;
- subclass_color_mappings scm;
frac frac_14 = frac_1 / 4;
frac out[GX_DEVICE_COLOR_MAX_COMPONENTS];
gx_color_index process_comps;
+ const gx_cm_color_map_procs *cmprocs;
+ const gx_device *cmdev;
+
+
+ if (pcinfo->num_components < 4 ||
+ pcinfo->polarity == GX_CINFO_POLARITY_ADDITIVE ||
+ pcinfo->gray_index == GX_CINFO_COMP_NO_INDEX) {
+ pcinfo->opmsupported = GX_CINFO_OPMSUPPORTED_NOT;
+ return 0;
+ }
/* check for the appropriate components */
if ( ncomps < 4 ||
@@ -629,26 +636,34 @@ check_cmyk_color_model_comps(gx_device * dev)
return 0;
/* check the mapping */
- scm = get_color_mapping_procs_subclass(dev);
+ cmprocs = dev_proc(dev, get_color_mapping_procs)(dev, &cmdev);
- map_cmyk_subclass(scm, frac_14, frac_0, frac_0, frac_0, out);
- if (!check_single_comp(cyan_c, frac_14, ncomps, out))
+ cmprocs->map_cmyk(cmdev, frac_14, frac_0, frac_0, frac_0, out);
+ if (!check_single_comp(cyan_c, frac_14, ncomps, out)) {
+ pcinfo->opmsupported = GX_CINFO_OPMSUPPORTED_NOT;
return 0;
- map_cmyk_subclass(scm, frac_0, frac_14, frac_0, frac_0, out);
- if (!check_single_comp(magenta_c, frac_14, ncomps, out))
+ }
+ cmprocs->map_cmyk(cmdev, frac_0, frac_14, frac_0, frac_0, out);
+ if (!check_single_comp(magenta_c, frac_14, ncomps, out)) {
+ pcinfo->opmsupported = GX_CINFO_OPMSUPPORTED_NOT;
return 0;
- map_cmyk_subclass(scm, frac_0, frac_0, frac_14, frac_0, out);
- if (!check_single_comp(yellow_c, frac_14, ncomps, out))
- return false;
- map_cmyk_subclass(scm, frac_0, frac_0, frac_0, frac_14, out);
- if (!check_single_comp(black_c, frac_14, ncomps, out))
+ }
+ cmprocs->map_cmyk(cmdev, frac_0, frac_0, frac_14, frac_0, out);
+ if (!check_single_comp(yellow_c, frac_14, ncomps, out)) {
+ pcinfo->opmsupported = GX_CINFO_OPMSUPPORTED_NOT;
return 0;
+ }
+ cmprocs->map_cmyk(cmdev, frac_0, frac_0, frac_0, frac_14, out);
+ if (!check_single_comp(black_c, frac_14, ncomps, out)) {
+ pcinfo->opmsupported = GX_CINFO_OPMSUPPORTED_NOT;
+ return 0;
+ }
process_comps = ((gx_color_index)1 << cyan_c)
| ((gx_color_index)1 << magenta_c)
| ((gx_color_index)1 << yellow_c)
| ((gx_color_index)1 << black_c);
- pcinfo->opmode = GX_CINFO_OPMODE;
+ pcinfo->opmsupported = GX_CINFO_OPMSUPPORTED;
pcinfo->process_comps = process_comps;
pcinfo->black_component = black_c;
return process_comps;
@@ -671,7 +686,7 @@ gx_set_overprint_DeviceCMYK(const gs_color_space * pcs, gs_gstate * pgs)
if ( !pgs->overprint ||
pgs->overprint_mode != 1 ||
pcinfo == 0 ||
- pcinfo->opmode == GX_CINFO_OPMODE_NOT )
+ pcinfo->opmsupported == GX_CINFO_OPMSUPPORTED_NOT)
return gx_spot_colors_set_overprint(pcs, pgs);
/* Share code with CMYK ICC case */
return gx_set_overprint_cmyk(pcs, pgs);
@@ -695,7 +710,6 @@ gx_set_overprint_DeviceCMYK(const gs_color_space * pcs, gs_gstate * pgs)
int gx_set_overprint_cmyk(const gs_color_space * pcs, gs_gstate * pgs)
{
gx_device * dev = pgs->device;
- gx_device_color_info * pcinfo = (dev == 0 ? 0 : &dev->color_info);
gx_color_index drawn_comps = 0;
gs_overprint_params_t params = { 0 };
gx_device_color *pdc;
@@ -717,11 +731,7 @@ int gx_set_overprint_cmyk(const gs_color_space * pcs, gs_gstate * pgs)
gsicc_extract_profile(dev->graphics_type_tag, dev_profile, &(output_profile),
&render_cond);
- /* check if color model behavior must be determined */
- if (pcinfo->opmode == GX_CINFO_OPMODE_UNKNOWN)
- drawn_comps = check_cmyk_color_model_comps(dev);
- else
- drawn_comps = pcinfo->process_comps;
+ drawn_comps = gx_get_process_comps(dev);
}
if_debug1m(gs_debug_flag_overprint, pgs->memory,
diff --git a/base/gsdcolor.h b/base/gsdcolor.h
index 367dcd48..253799ed 100644
--- a/base/gsdcolor.h
+++ b/base/gsdcolor.h
@@ -271,7 +271,6 @@ struct gx_device_color_s {
ushort num_components;
byte c_base[GX_DEVICE_COLOR_MAX_COMPONENTS];
uint c_level[GX_DEVICE_COLOR_MAX_COMPONENTS];
- ushort /*gx_color_value */ alpha;
#if GX_DEVICE_COLOR_MAX_COMPONENTS <= ARCH_SIZEOF_SHORT * 8
ushort plane_mask;
#else
@@ -371,7 +370,6 @@ struct gx_device_color_saved_s {
struct _svcol {
byte c_base[GX_DEVICE_COLOR_MAX_COMPONENTS];
uint c_level[GX_DEVICE_COLOR_MAX_COMPONENTS];
- ushort alpha;
} colored;
struct _svdevn {
ushort values[GX_DEVICE_COLOR_MAX_COMPONENTS];
diff --git a/base/gsdevice.c b/base/gsdevice.c
index 630ed493..b02c324c 100644
--- a/base/gsdevice.c
+++ b/base/gsdevice.c
@@ -37,6 +37,7 @@
#include "gxcspace.h"
#include "gsicc_manage.h"
#include "gscms.h"
+#include "gxgetbit.h"
/* Include the extern for the device list. */
extern_gs_lib_device_list();
@@ -161,17 +162,6 @@ gx_device_reloc_ptr(gx_device * dev, gc_state_t * gcst)
return RELOC_OBJ(dev); /* gcst implicit */
}
-/* Set up the device procedures in the device structure. */
-/* Also copy old fields to new ones. */
-void
-gx_device_set_procs(gx_device * dev)
-{
- if (dev->static_procs != 0) { /* 0 if already populated */
- dev->procs = *dev->static_procs;
- dev->static_procs = 0;
- }
-}
-
/* Flush buffered output to the device */
int
gs_flushpage(gs_gstate * pgs)
@@ -247,10 +237,27 @@ gs_copyscanlines(gx_device * dev, int start_y, byte * data, uint size,
uint count = size / line_size;
uint i;
byte *dest = data;
+ gs_int_rect rect;
+ gs_get_bits_params_t params;
- for (i = 0; i < count; i++, dest += line_size) {
- int code = (*dev_proc(dev, get_bits)) (dev, start_y + i, dest, NULL);
+ rect.p.x = 0;
+ rect.q.x = dev->width;
+ params.x_offset = 0;
+ params.raster = bitmap_raster(dev->width * dev->color_info.depth);
+ for (i = 0; i < count; i++, dest += line_size) {
+ int code;
+
+ rect.p.y = start_y+i;
+ rect.q.y = start_y+i+1;
+
+ params.options = (GB_ALIGN_ANY |
+ GB_RETURN_COPY |
+ GB_OFFSET_0 |
+ GB_RASTER_STANDARD | GB_PACKING_CHUNKY |
+ GB_COLORS_NATIVE | GB_ALPHA_NONE);
+ params.data[0] = dest;
+ code = (*dev_proc(dev, get_bits_rectangle))(dev, &rect, &params);
if (code < 0) {
/* Might just be an overrun. */
if (start_y + i == dev->height)
@@ -356,7 +363,7 @@ gx_device_make_struct_type(gs_memory_struct_type_t *st,
{
if (dev->stype)
*st = *dev->stype;
- else if (dev_proc(dev, get_xfont_procs) == gx_forward_get_xfont_procs)
+ else if (dev_proc(dev, get_page_device) == gx_forward_get_page_device)
*st = st_device_forward;
else
*st = st_device;
@@ -409,34 +416,29 @@ gs_copydevice2(gx_device ** pnew_dev, const gx_device * dev, bool keep_open,
gs_free_object(mem->non_gc_memory, a_std, "gs_copydevice(stype)");
return_error(gs_error_VMerror);
}
- gx_device_init(new_dev, dev, mem, false);
- gx_device_set_procs(new_dev);
+ code = gx_device_init(new_dev, dev, mem, false);
new_dev->stype = new_std;
new_dev->stype_is_dynamic = new_std != std;
/*
* keep_open is very dangerous. On the other hand, so is copydevice in
* general, since it just copies the bits without any regard to pointers
- * (including self-pointers) that they may contain. We handle this by
- * making the default finish_copydevice forbid copying of anything other
- * than the device prototype.
+ * (including self-pointers) that they may contain.
*/
new_dev->is_open = dev->is_open && keep_open;
- fill_dev_proc(new_dev, finish_copydevice, gx_default_finish_copydevice);
- /* We really want to be able to interrogate the device for capabilities
- * and/or preferences right from when it is created, so set dev_spec_op
- * now (if not already set).
- */
- fill_dev_proc(new_dev, dev_spec_op, gx_default_dev_spec_op);
- code = dev_proc(new_dev, finish_copydevice)(new_dev, dev);
if (code < 0) {
gs_free_object(mem, new_dev, "gs_copydevice(device)");
#if 0 /* gs_free_object above calls gx_device_finalize,
- which closes the device and releaszes its stype, i.e. a_std. */
+ which closes the device and releases its stype, i.e. a_std. */
if (a_std)
gs_free_object(dev->memory->non_gc_memory, a_std, "gs_copydevice(stype)");
#endif
return code;
}
+ /* We really want to be able to interrogate the device for capabilities
+ * and/or preferences right from when it is created, so set dev_spec_op
+ * now (if not already set).
+ */
+ fill_dev_proc(new_dev, dev_spec_op, gx_default_dev_spec_op);
*pnew_dev = new_dev;
return 0;
}
@@ -619,15 +621,25 @@ gs_setdevice_no_init(gs_gstate * pgs, gx_device * dev)
}
/* Initialize a just-allocated device. */
-void
+int
gx_device_init(gx_device * dev, const gx_device * proto, gs_memory_t * mem,
bool internal)
{
memcpy(dev, proto, proto->params_size);
- dev->memory = mem;
+ dev->initialize_device_procs = proto->initialize_device_procs;
+ if (dev->initialize_device_procs != NULL)
+ dev->initialize_device_procs(dev);
+ dev->memory = mem; /* must precede initialize_device call so devices can use it */
+ if (dev->procs.initialize_device) {
+ int code = dev->procs.initialize_device(dev);
+ if (code < 0)
+ return code;
+ }
dev->retained = !internal;
rc_init(dev, mem, (internal ? 0 : 1));
rc_increment(dev->icc_struct);
+
+ return 0;
}
void
@@ -635,6 +647,14 @@ gx_device_init_on_stack(gx_device * dev, const gx_device * proto,
gs_memory_t * mem)
{
memcpy(dev, proto, proto->params_size);
+ dev->initialize_device_procs = proto->initialize_device_procs;
+ dev->initialize_device_procs(dev);
+ if (dev->procs.initialize_device) {
+ /* A condition of devices inited on the stack is that they can
+ * never fail to initialize! */
+ (void)dev->procs.initialize_device(dev);
+ }
+ gx_device_fill_in_procs(dev);
dev->memory = mem;
dev->retained = 0;
dev->pad = proto->pad;
@@ -648,8 +668,10 @@ void
gs_make_null_device(gx_device_null *dev_null, gx_device *dev,
gs_memory_t * mem)
{
- gx_device_init((gx_device *)dev_null, (const gx_device *)&gs_null_device,
- mem, true);
+ /* Can never fail */
+ (void)gx_device_init((gx_device *)dev_null,
+ (const gx_device *)&gs_null_device,
+ mem, true);
gx_device_fill_in_procs((gx_device *)dev_null);
gx_device_set_target((gx_device_forward *)dev_null, dev);
if (dev) {
@@ -671,7 +693,6 @@ gs_make_null_device(gx_device_null *dev_null, gx_device *dev,
set_dev_proc(dn, begin_transparency_mask, gx_default_begin_transparency_mask);
set_dev_proc(dn, end_transparency_mask, gx_default_end_transparency_mask);
set_dev_proc(dn, discard_transparency_layer, gx_default_discard_transparency_layer);
- set_dev_proc(dn, pattern_manage, gx_default_pattern_manage);
set_dev_proc(dn, push_transparency_state, gx_default_push_transparency_state);
set_dev_proc(dn, pop_transparency_state, gx_default_pop_transparency_state);
set_dev_proc(dn, put_image, gx_default_put_image);
@@ -787,16 +808,28 @@ gx_set_device_only(gs_gstate * pgs, gx_device * dev)
uint
gx_device_raster(const gx_device * dev, bool pad)
{
- ulong bits = (ulong) dev->width * dev->color_info.depth;
+ int depth = dev->color_info.depth;
+ ulong bits = (ulong) dev->width * depth;
ulong raster;
int l2align;
- if (dev->is_planar)
- {
- int has_tags = device_encodes_tags(dev);
- bits /= (dev->color_info.num_components + has_tags);
- }
+ if (dev->is_planar) {
+ int num_components = dev->color_info.num_components;
+ /* bpc accounts for unused bits, e.g. depth==4, num_comp==3, or depth==8, num_comps==5 */
+ int bpc = depth / num_components;
+ /* depth can be <= num_components if planar and MEM_SET_PARAMS has changed it */
+ if (depth <= num_components || bpc >= 8) {
+ /* tag plane requires at least 8 bits (per component as well as tags) */
+ int has_tags = bpc >= 8 ? device_encodes_tags(dev): 0;
+
+ bits /= (num_components + has_tags);
+ }
+ else {
+ /* depth is original depth, not the plane_depth since it is > num_components */
+ bits /= (depth / bpc);
+ }
+ }
raster = (uint)((bits + 7) >> 3);
if (!pad)
return raster;
@@ -1360,7 +1393,7 @@ bool gx_color_info_equal(const gx_device_color_info * p1, const gx_device_color_
return false;
if (p1->max_components != p2->max_components)
return false;
- if (p1->opmode != p2->opmode)
+ if (p1->opmsupported != p2->opmsupported)
return false;
if (p1->polarity != p2->polarity)
return false;
diff --git a/base/gsdparam.c b/base/gsdparam.c
index b86dcfb4..f1827261 100644
--- a/base/gsdparam.c
+++ b/base/gsdparam.c
@@ -61,7 +61,6 @@ gs_get_device_or_hw_params(gx_device * orig_dev, gs_param_list * plist,
if (code < 0)
return code;
}
- gx_device_set_procs(dev);
fill_dev_proc(dev, get_params, gx_default_get_params);
fill_dev_proc(dev, get_page_device, gx_default_get_page_device);
fill_dev_proc(dev, get_alpha_bits, gx_default_get_alpha_bits);
@@ -426,8 +425,8 @@ int gx_default_get_param(gx_device *dev, char *Param, void *list)
if (strcmp(Param, "OutputICCProfile") == 0) {
return param_write_string(plist,"OutputICCProfile", &(profile_array[0]));
}
- if (strcmp(Param, "GraphicICCProfile") == 0) {
- return param_write_string(plist,"GraphicICCProfile", &(profile_array[1]));
+ if (strcmp(Param, "VectorICCProfile") == 0) {
+ return param_write_string(plist,"VectorICCProfile", &(profile_array[1]));
}
if (strcmp(Param, "ImageICCProfile") == 0) {
return param_write_string(plist,"ImageICCProfile", &(profile_array[2]));
@@ -441,8 +440,8 @@ int gx_default_get_param(gx_device *dev, char *Param, void *list)
if (strcmp(Param, "RenderIntent") == 0) {
return param_write_int(plist,"RenderIntent", (const int *) (&(profile_intents[0])));
}
- if (strcmp(Param, "GraphicIntent") == 0) {
- return param_write_int(plist,"GraphicIntent", (const int *) &(profile_intents[1]));
+ if (strcmp(Param, "VectorIntent") == 0) {
+ return param_write_int(plist,"VectorIntent", (const int *) &(profile_intents[1]));
}
if (strcmp(Param, "ImageIntent") == 0) {
return param_write_int(plist,"ImageIntent", (const int *) &(profile_intents[2]));
@@ -453,8 +452,8 @@ int gx_default_get_param(gx_device *dev, char *Param, void *list)
if (strcmp(Param, "BlackPtComp") == 0) {
return param_write_int(plist,"BlackPtComp", (const int *) (&(blackptcomps[0])));
}
- if (strcmp(Param, "GraphicBlackPt") == 0) {
- return param_write_int(plist,"GraphicBlackPt", (const int *) &(blackptcomps[1]));
+ if (strcmp(Param, "VectorBlackPt") == 0) {
+ return param_write_int(plist,"VectorBlackPt", (const int *) &(blackptcomps[1]));
}
if (strcmp(Param, "ImageBlackPt") == 0) {
return param_write_int(plist,"ImageBlackPt", (const int *) &(blackptcomps[2]));
@@ -465,8 +464,8 @@ int gx_default_get_param(gx_device *dev, char *Param, void *list)
if (strcmp(Param, "KPreserve") == 0) {
return param_write_int(plist,"KPreserve", (const int *) (&(blackpreserve[0])));
}
- if (strcmp(Param, "GraphicKPreserve") == 0) {
- return param_write_int(plist,"GraphicKPreserve", (const int *) &(blackpreserve[1]));
+ if (strcmp(Param, "VectorKPreserve") == 0) {
+ return param_write_int(plist,"VectorKPreserve", (const int *) &(blackpreserve[1]));
}
if (strcmp(Param, "ImageKPreserve") == 0) {
return param_write_int(plist,"ImageKPreserve", (const int *) &(blackpreserve[2]));
@@ -718,7 +717,7 @@ gx_default_get_params(gx_device * dev, gs_param_list * plist)
(code = param_write_bool(plist, "BlackText", &blacktext)) < 0 ||
(code = param_write_bool(plist, "PreBandThreshold", &prebandthreshold)) < 0 ||
(code = param_write_string(plist,"OutputICCProfile", &(profile_array[0]))) < 0 ||
- (code = param_write_string(plist,"GraphicICCProfile", &(profile_array[1]))) < 0 ||
+ (code = param_write_string(plist,"VectorICCProfile", &(profile_array[1]))) < 0 ||
(code = param_write_string(plist,"ImageICCProfile", &(profile_array[2]))) < 0 ||
(code = param_write_string(plist,"TextICCProfile", &(profile_array[3]))) < 0 ||
(code = param_write_string(plist,"ProofProfile", &(proof_profile))) < 0 ||
@@ -728,15 +727,15 @@ gx_default_get_params(gx_device * dev, gs_param_list * plist)
(code = param_write_string(plist,"ICCOutputColors", &(icc_colorants))) < 0 ||
(code = param_write_int(plist, "RenderIntent", (const int *)(&(profile_intents[0])))) < 0 ||
(code = param_write_int(plist, "ColorAccuracy", (const int *)(&(color_accuracy)))) < 0 ||
- (code = param_write_int(plist,"GraphicIntent", (const int *) &(profile_intents[1]))) < 0 ||
+ (code = param_write_int(plist,"VectorIntent", (const int *) &(profile_intents[1]))) < 0 ||
(code = param_write_int(plist,"ImageIntent", (const int *) &(profile_intents[2]))) < 0 ||
(code = param_write_int(plist,"TextIntent", (const int *) &(profile_intents[3]))) < 0 ||
(code = param_write_int(plist,"BlackPtComp", (const int *) (&(blackptcomps[0])))) < 0 ||
- (code = param_write_int(plist,"GraphicBlackPt", (const int *) &(blackptcomps[1]))) < 0 ||
+ (code = param_write_int(plist,"VectorBlackPt", (const int *) &(blackptcomps[1]))) < 0 ||
(code = param_write_int(plist,"ImageBlackPt", (const int *) &(blackptcomps[2]))) < 0 ||
(code = param_write_int(plist,"TextBlackPt", (const int *) &(blackptcomps[3]))) < 0 ||
(code = param_write_int(plist,"KPreserve", (const int *) (&(blackpreserve[0])))) < 0 ||
- (code = param_write_int(plist,"GraphicKPreserve", (const int *) &(blackpreserve[1]))) < 0 ||
+ (code = param_write_int(plist,"VectorKPreserve", (const int *) &(blackpreserve[1]))) < 0 ||
(code = param_write_int(plist,"ImageKPreserve", (const int *) &(blackpreserve[2]))) < 0 ||
(code = param_write_int(plist,"TextKPreserve", (const int *) &(blackpreserve[3]))) < 0 ||
(code = param_write_int_array(plist, "HWSize", &hwsa)) < 0 ||
@@ -802,7 +801,7 @@ gx_default_get_params(gx_device * dev, gs_param_list * plist)
if (dev->PageList) {
gdev_pagelist *p = (gdev_pagelist *)dev->PageList;
- param_string_from_string(pagelist, p->Pages);
+ param_string_from_transient_string(pagelist, p->Pages);
} else {
param_string_from_string(pagelist, null_str);
}
@@ -1056,7 +1055,6 @@ gs_putdeviceparams(gx_device * dev, gs_param_list * plist)
/* gs_param_list_dump(plist); */
- gx_device_set_procs(dev);
fill_dev_proc(dev, put_params, gx_default_put_params);
fill_dev_proc(dev, get_alpha_bits, gx_default_get_alpha_bits);
code = (*dev_proc(dev, put_params)) (dev, plist);
@@ -1737,10 +1735,10 @@ nce:
}
/* Note, if a change is made to NUM_DEVICE_PROFILES we need to update
this with the name of the profile */
- if ((code = param_read_string(plist, "GraphicICCProfile", &icc_pro)) != 1) {
+ if ((code = param_read_string(plist, "VectorICCProfile", &icc_pro)) != 1) {
if ((code = gx_default_put_icc(&icc_pro, dev, gsGRAPHICPROFILE)) < 0) {
ecode = code;
- param_signal_error(plist, "GraphicICCProfile", ecode);
+ param_signal_error(plist, "VectorICCProfile", ecode);
}
}
if ((code = param_read_string(plist, "ImageICCProfile", &icc_pro)) != 1) {
@@ -1772,7 +1770,7 @@ nce:
ecode = code;
param_signal_error(plist, param_name, ecode);
}
- if ((code = param_read_int(plist, (param_name = "GraphicIntent"),
+ if ((code = param_read_int(plist, (param_name = "VectorIntent"),
&(rend_intent[1]))) < 0) {
ecode = code;
param_signal_error(plist, param_name, ecode);
@@ -1792,7 +1790,7 @@ nce:
ecode = code;
param_signal_error(plist, param_name, ecode);
}
- if ((code = param_read_int(plist, (param_name = "GraphicBlackPt"),
+ if ((code = param_read_int(plist, (param_name = "VectorBlackPt"),
&(blackptcomp[1]))) < 0) {
ecode = code;
param_signal_error(plist, param_name, ecode);
@@ -1812,7 +1810,7 @@ nce:
ecode = code;
param_signal_error(plist, param_name, ecode);
}
- if ((code = param_read_int(plist, (param_name = "GraphicKPreserve"),
+ if ((code = param_read_int(plist, (param_name = "VectorKPreserve"),
&(blackpreserve[1]))) < 0) {
ecode = code;
param_signal_error(plist, param_name, ecode);
@@ -1912,8 +1910,10 @@ label:\
}
switch (code = param_read_int(plist, (param_name = "BandHeight"), &sp.band.BandHeight)) {
- CHECK_PARAM_CASES(band.BandHeight, sp.band.BandHeight < 0, bhe);
+ CHECK_PARAM_CASES(band.BandHeight, sp.band.BandHeight < -1, bhe);
}
+ if (sp.band.BandHeight == -1)
+ sp.band.BandHeight = dev->height; /* 1 band for the page requested */
switch (code = param_read_size_t(plist, (param_name = "BandBufferSpace"), &sp.band.BandBufferSpace)) {
CHECK_PARAM_CASES(band.BandBufferSpace, 0, bbse);
diff --git a/base/gsdps1.c b/base/gsdps1.c
index 640853d5..06998b7b 100644
--- a/base/gsdps1.c
+++ b/base/gsdps1.c
@@ -201,7 +201,7 @@ gs_rectfill(gs_gstate * pgs, const gs_rect * pr, uint count)
bool center_of_pixel = (pgs->fill_adjust.x == 0 && pgs->fill_adjust.y == 0);
/* Processing a fill object operation */
- ensure_tag_is_set(pgs, pgs->device, GS_PATH_TAG); /* NB: may unset_dev_color */
+ ensure_tag_is_set(pgs, pgs->device, GS_VECTOR_TAG); /* NB: may unset_dev_color */
code = gx_set_dev_color(pgs);
if (code != 0)
diff --git a/base/gsequivc.c b/base/gsequivc.c
index e89e23ab..e2b9c33d 100644
--- a/base/gsequivc.c
+++ b/base/gsequivc.c
@@ -368,7 +368,6 @@ typedef struct color_capture_device_s {
static cmap_proc_gray(cmap_gray_capture_cmyk_color);
static cmap_proc_rgb(cmap_rgb_capture_cmyk_color);
static cmap_proc_cmyk(cmap_cmyk_capture_cmyk_color);
-static cmap_proc_rgb_alpha(cmap_rgb_alpha_capture_cmyk_color);
static cmap_proc_separation(cmap_separation_capture_cmyk_color);
static cmap_proc_devicen(cmap_devicen_capture_cmyk_color);
@@ -376,7 +375,6 @@ static const gx_color_map_procs cmap_capture_cmyk_color = {
cmap_gray_capture_cmyk_color,
cmap_rgb_capture_cmyk_color,
cmap_cmyk_capture_cmyk_color,
- cmap_rgb_alpha_capture_cmyk_color,
cmap_separation_capture_cmyk_color,
cmap_devicen_capture_cmyk_color
};
@@ -426,14 +424,6 @@ cmap_cmyk_capture_cmyk_color(frac c, frac m, frac y, frac k, gx_device_color * p
}
static void
-cmap_rgb_alpha_capture_cmyk_color(frac r, frac g, frac b, frac alpha,
- gx_device_color * pdc, const gs_gstate * pgs, gx_device * dev,
- gs_color_select_t select)
-{
- cmap_rgb_capture_cmyk_color(r, g, b, pdc, pgs, dev, select);
-}
-
-static void
cmap_separation_capture_cmyk_color(frac all, gx_device_color * pdc,
const gs_gstate * pgs, gx_device * dev, gs_color_select_t select,
const gs_color_space *pcs)
diff --git a/base/gserrors.h b/base/gserrors.h
index 1bdbb8a0..91b05cdf 100644
--- a/base/gserrors.h
+++ b/base/gserrors.h
@@ -119,7 +119,10 @@ enum gs_error_type {
* subclasses should not perform any further action. Currently this is limited
* to compositor creation.
*/
- gs_error_handled = -111
+ gs_error_handled = -111,
+
+/* Internal error for the C-based PDF interpreter, to indicate a circular PDF reference */
+ gs_error_circular_reference = -112,
};
/* We do provide a typedef type for external API use */
diff --git a/base/gsfont.c b/base/gsfont.c
index b8335c1d..3fcb8deb 100644
--- a/base/gsfont.c
+++ b/base/gsfont.c
@@ -283,11 +283,18 @@ gs_font_dir_finalize(const gs_memory_t *cmem, void *vptr)
gx_bits_cache_chunk *chunk = pdir->ccache.chunks;
gx_bits_cache_chunk *start_chunk = chunk;
gx_bits_cache_chunk *prev_chunk;
+ int i;
if (pdir == cmem->gs_lib_ctx->font_dir) {
cmem->gs_lib_ctx->font_dir = NULL;
}
+ for (i = 0; i < pdir->fmcache.mmax; i++) {
+ if (uid_is_XUID(&pdir->fmcache.mdata[i].UID)) {
+ gs_free_object(pdir->memory->stable_memory, pdir->fmcache.mdata[i].UID.xvalues, "gs_font_dir_finalize");
+ }
+ }
+
/* free character cache machinery */
gs_free_object(pdir->memory, pdir->fmcache.mdata, "gs_font_dir_finalize");
gs_free_object(pdir->memory, pdir->ccache.table, "gs_font_dir_finalize");
diff --git a/base/gsfunc3.c b/base/gsfunc3.c
index 11968efd..5ae33934 100644
--- a/base/gsfunc3.c
+++ b/base/gsfunc3.c
@@ -41,6 +41,9 @@ fn_free_functions(const gs_function_t *const * Functions, int count,
{
int i;
+ if (Functions == NULL)
+ return;
+
for (i = count; --i >= 0;)
if (Functions[i])
gs_function_free((gs_function_t *)Functions[i], true, mem);
diff --git a/base/gsfunc4.c b/base/gsfunc4.c
index d5daf9ce..c2bddaf2 100644
--- a/base/gsfunc4.c
+++ b/base/gsfunc4.c
@@ -555,19 +555,22 @@ fn_PtCr_evaluate(const gs_function_t *pfn_common, const float *in, float *out)
}
}
fin:
-
- if (vsp != vstack + pfn->params.n)
- return_error(gs_error_rangecheck);
- for (i = 0; i < pfn->params.n; ++i) {
- switch (vstack[i + 1].type) {
- case CVT_INT:
- out[i] = (float)vstack[i + 1].value.i;
- break;
- case CVT_FLOAT:
- out[i] = vstack[i + 1].value.f;
- break;
- default:
- return_error(gs_error_typecheck);
+ { /* Following Acrobat, take the desired number of parameters */
+ /* from the top of stack and ignore the rest. Bug 702950. */
+ int extra_ops = vsp - vstack - pfn->params.n;
+ if (extra_ops < 0)
+ return_error(gs_error_rangecheck);
+ for (i = 0; i < pfn->params.n; ++i) {
+ switch (vstack[i + 1 + extra_ops].type) {
+ case CVT_INT:
+ out[i] = (float)vstack[i + 1 + extra_ops].value.i;
+ break;
+ case CVT_FLOAT:
+ out[i] = vstack[i + 1 + extra_ops].value.f;
+ break;
+ default:
+ return_error(gs_error_typecheck);
+ }
}
}
return 0;
diff --git a/base/gsgstate.c b/base/gsgstate.c
index 6eb9b817..0f7d182a 100644
--- a/base/gsgstate.c
+++ b/base/gsgstate.c
@@ -112,7 +112,8 @@ gs_gstate_initialize(gs_gstate * pgs, gs_memory_t * mem)
for (i = 0; i < gs_color_select_count; ++i)
pgs->screen_phase[i].x = pgs->screen_phase[i].y = 0;
}
- pgs->dev_ht = 0;
+ for (i=0; i < HT_OBJTYPE_COUNT; i++)
+ pgs->dev_ht[i] = NULL;
pgs->cie_render = 0;
pgs->cie_to_xyz = false;
pgs->black_generation = 0;
@@ -159,8 +160,11 @@ gs_gstate_initialize(gs_gstate * pgs, gs_memory_t * mem)
void
gs_gstate_copied(gs_gstate * pgs)
{
+ int i;
+
rc_increment(pgs->halftone);
- rc_increment(pgs->dev_ht);
+ for (i=0; i < HT_OBJTYPE_COUNT; i++)
+ rc_increment(pgs->dev_ht[i]);
rc_increment(pgs->cie_render);
rc_increment(pgs->black_generation);
rc_increment(pgs->undercolor_removal);
@@ -183,6 +187,7 @@ void
gs_gstate_pre_assign(gs_gstate *pto, const gs_gstate *pfrom)
{
const char *const cname = "gs_gstate_pre_assign";
+ int i;
#define RCCOPY(element)\
rc_pre_assign(pto->element, pfrom->element, cname)
@@ -196,7 +201,8 @@ gs_gstate_pre_assign(gs_gstate *pto, const gs_gstate *pfrom)
RCCOPY(undercolor_removal);
RCCOPY(black_generation);
RCCOPY(cie_render);
- RCCOPY(dev_ht);
+ for (i=0; i < HT_OBJTYPE_COUNT; i++)
+ RCCOPY(dev_ht[i]);
RCCOPY(halftone);
RCCOPY(devicergb_cs);
RCCOPY(devicecmyk_cs);
@@ -212,7 +218,8 @@ void
gs_gstate_release(gs_gstate * pgs)
{
const char *const cname = "gs_gstate_release";
- gx_device_halftone *pdht = pgs->dev_ht;
+ gx_device_halftone *pdht;
+ int i;
#define RCDECR(element)\
rc_decrement(pgs->element, cname);\
@@ -227,13 +234,16 @@ gs_gstate_release(gs_gstate * pgs)
RCDECR(black_generation);
RCDECR(cie_render);
/*
- * If we're going to free the device halftone, make sure we free the
+ * If we're going to free a device halftone, make sure we free the
* dependent structures as well.
*/
- if (pdht != 0 && pdht->rc.ref_count == 1) {
- gx_device_halftone_release(pdht, pdht->rc.memory);
+ for (i=0; i < HT_OBJTYPE_COUNT; i++) {
+ pdht = pgs->dev_ht[i];
+ if (pdht != NULL && pdht->rc.ref_count == 1) {
+ gx_device_halftone_release(pdht, pdht->rc.memory);
+ }
+ RCDECR(dev_ht[i]);
}
- RCDECR(dev_ht);
RCDECR(halftone);
RCDECR(devicergb_cs);
RCDECR(devicecmyk_cs);
diff --git a/base/gsht.c b/base/gsht.c
index bc72f0e1..2b8567f9 100644
--- a/base/gsht.c
+++ b/base/gsht.c
@@ -17,6 +17,7 @@
/* setscreen operator for Ghostscript library */
#include "memory_.h"
#include "string_.h"
+#include "assert_.h"
#include <stdlib.h> /* for qsort */
#include "gx.h"
#include "gserrors.h"
@@ -25,6 +26,7 @@
#include "gxarith.h" /* for igcd */
#include "gzstate.h"
#include "gxdevice.h" /* for gzht.h */
+#include "gxdevsop.h"
#include "gzht.h"
#include "gxfmap.h" /* For effective transfer usage in threshold */
#include "gp.h"
@@ -168,12 +170,12 @@ gs_currentscreenlevels(const gs_gstate * pgs)
{
int gi = 0;
- if (pgs->device != 0)
+ if (pgs->device != NULL)
gi = pgs->device->color_info.gray_index;
if (gi != GX_CINFO_COMP_NO_INDEX)
- return pgs->dev_ht->components[gi].corder.num_levels;
+ return pgs->dev_ht[HT_OBJTYPE_DEFAULT]->components[gi].corder.num_levels;
else
- return pgs->dev_ht->components[0].corder.num_levels;
+ return pgs->dev_ht[HT_OBJTYPE_DEFAULT]->components[0].corder.num_levels;
}
/* .setscreenphase */
@@ -321,9 +323,9 @@ gx_ht_copy_ht_order(gx_ht_order * pdest, gx_ht_order * psrc, gs_memory_t * mem)
psrc->procs, mem);
if (code < 0)
return code;
- if (pdest->levels != 0)
+ if (pdest->levels != NULL)
memcpy(pdest->levels, psrc->levels, psrc->num_levels * sizeof(uint));
- if (pdest->bit_data != 0)
+ if (pdest->bit_data != NULL)
memcpy(pdest->bit_data, psrc->bit_data,
(size_t)psrc->num_bits * psrc->procs->bit_data_elt_size);
pdest->transfer = psrc->transfer;
@@ -576,13 +578,13 @@ gx_ht_order_release(gx_ht_order * porder, gs_memory_t * mem, bool free_cache)
{
/* "free cache" is a proxy for "differs from default" */
if (free_cache) {
- if (porder->cache != 0)
+ if (porder->cache != NULL)
gx_ht_free_cache(mem, porder->cache);
}
porder->cache = 0;
rc_decrement(porder->transfer, "gx_ht_order_release(transfer)");
porder->transfer = 0;
- if (porder->data_memory != 0) {
+ if (porder->data_memory != NULL) {
gs_free_object(porder->data_memory, porder->bit_data,
"gx_ht_order_release(bit_data)");
gs_free_object(porder->data_memory, porder->levels,
@@ -644,53 +646,53 @@ int
gs_color_name_component_number(gx_device * dev, const char * pname,
int name_size, int halftonetype)
{
- int num_colorant;
+ int num_colorant = -1; /* initialize to "unknown" */
+ int color_component_type = NO_COMP_NAME_TYPE_HT;
+ bool devn = dev_proc(dev, dev_spec_op)(dev, gxdso_supports_devn, NULL, 0);
-#define check_colorant_name(dev, name) \
- ((*dev_proc(dev, get_color_comp_index)) (dev, name, strlen(name), NO_COMP_NAME_TYPE_HT))
+#define check_colorant_name(dev, name, component_type) \
+ ((*dev_proc(dev, get_color_comp_index)) (dev, name, strlen(name), component_type))
-#define check_colorant_name_length(dev, name, length) \
- ((*dev_proc(dev, get_color_comp_index)) (dev, name, length, NO_COMP_NAME_TYPE_HT))
+#define check_colorant_name_length(dev, name, length, component_type) \
+ ((*dev_proc(dev, get_color_comp_index)) (dev, name, length, component_type))
#define check_name(str, pname, length) \
((strlen(str) == length) && (strncmp(pname, str, length) == 0))
/*
- * Check if this is a device colorant.
- */
- num_colorant = check_colorant_name_length(dev, pname, name_size);
- if (num_colorant >= 0) {
- /*
- * The device will return GX_DEVICE_COLOR_MAX_COMPONENTS if the
- * colorant is logically present in the device but not being used
- * because a SeparationOrder parameter is specified. Since we are
- * using this value to indicate 'Default', we use -1 to indicate
- * that the colorant is not really being used.
- */
- if (num_colorant == GX_DEVICE_COLOR_MAX_COMPONENTS)
- num_colorant = -1;
- return num_colorant;
- }
-
- /*
* Check if this is the default component
*/
if (check_name("Default", pname, name_size))
return GX_DEVICE_COLOR_MAX_COMPONENTS;
+ if (check_cmyk_color_model_comps(dev))
+ color_component_type = SEPARATION_NAME; /* allow separations to be added */
+
+ /*
+ * Check if this is a device colorant.
+ */
/* Halftones set by setcolorscreen, and (we think) */
- /* Type 2 and Type 4 halftones, are supposed to work */
+ /* Type 2, 4, and 5 halftones, are supposed to work */
/* for both RGB and CMYK, so we need a special check here. */
if (halftonetype == ht_type_colorscreen ||
- halftonetype == ht_type_multiple_colorscreen) {
+ halftonetype == ht_type_multiple_colorscreen ||
+ (halftonetype == ht_type_multiple && devn)) {
+ /* Note that Red, Green, Blue and/or Gray can be added using setcolorspace */
+ /* we just don't automatically add it as a result of sethalftone */
+ /* The NO_COMP_NAME_TYPE_HT won't add colorants */
if (check_name("Red", pname, name_size))
- num_colorant = check_colorant_name(dev, "Cyan");
+ num_colorant = check_colorant_name(dev, "Cyan", NO_COMP_NAME_TYPE_HT);
else if (check_name("Green", pname, name_size))
- num_colorant = check_colorant_name(dev, "Magenta");
+ num_colorant = check_colorant_name(dev, "Magenta", NO_COMP_NAME_TYPE_HT);
else if (check_name("Blue", pname, name_size))
- num_colorant = check_colorant_name(dev, "Yellow");
+ num_colorant = check_colorant_name(dev, "Yellow", NO_COMP_NAME_TYPE_HT);
else if (check_name("Gray", pname, name_size))
- num_colorant = check_colorant_name(dev, "Black");
+ num_colorant = check_colorant_name(dev, "Black", NO_COMP_NAME_TYPE_HT);
+ }
+ if (num_colorant < 0)
+ num_colorant = check_colorant_name_length(dev, pname, name_size, color_component_type);
+
+ if (num_colorant >= 0) {
/*
* The device will return GX_DEVICE_COLOR_MAX_COMPONENTS if the
* colorant is logically present in the device but not being used
@@ -700,12 +702,12 @@ gs_color_name_component_number(gx_device * dev, const char * pname,
*/
if (num_colorant == GX_DEVICE_COLOR_MAX_COMPONENTS)
num_colorant = -1;
-
+ return num_colorant;
+ }
#undef check_colorant_name
#undef check_colorant_name_length
#undef check_name
- }
return num_colorant;
}
@@ -949,7 +951,8 @@ gx_gstate_dev_ht_install(
gs_gstate * pgs,
gx_device_halftone * pdht,
gs_halftone_type type,
- const gx_device * dev )
+ const gx_device * dev,
+ gs_HT_objtype_t objtype )
{
gx_device_halftone dht;
int num_comps = pdht->num_dev_comp;
@@ -960,6 +963,8 @@ gx_gstate_dev_ht_install(
uint w, h;
int dw, dh;
+ assert(objtype < HT_OBJTYPE_COUNT);
+
/* construct the new device halftone structure */
memset(&dht.order, 0, sizeof(dht.order));
/* the rc field is filled in later */
@@ -988,7 +993,7 @@ gx_gstate_dev_ht_install(
* by clearing the corresponding pointers in the operand halftone's
* orders.
*/
- if (pdht->components != 0) {
+ if (pdht->components != NULL) {
int input_ncomps = pdht->num_comp;
for (i = 0; i < input_ncomps && code >= 0; i++) {
@@ -1101,27 +1106,28 @@ gx_gstate_dev_ht_install(
* we still need.
*/
if (code >= 0) {
- gx_device_halftone * pgsdht = pgs->dev_ht;
- rc_header tmp_rc;
-
- if (pgsdht != 0 && pgsdht->rc.ref_count == 1) {
- if (pdht != pgsdht)
- gx_device_halftone_release(pgsdht, pgsdht->rc.memory);
+ gx_device_halftone **ppgsdht;
+ rc_header tmp_rc;
+
+ /* The pgsdht corresponds to the one we will be installing according to 'objtype' */
+ ppgsdht = &(pgs->dev_ht[objtype]);
+ if (*ppgsdht != NULL && (*ppgsdht)->rc.ref_count == 1) {
+ if (pdht != *ppgsdht)
+ gx_device_halftone_release(*ppgsdht, (*ppgsdht)->rc.memory);
} else {
- rc_unshare_struct( pgs->dev_ht,
+ rc_unshare_struct( *ppgsdht,
gx_device_halftone,
&st_device_halftone,
pgs->memory,
BEGIN code = gs_error_VMerror; goto err; END,
"gx_gstate_dev_ht_install" );
- pgsdht = pgs->dev_ht;
}
/*
* Everything worked. "Assume ownership" of the appropriate
* portions of the source device halftone by clearing the
* associated references. Since we might have
- * pdht == pgs->dev_ht, this must done before updating pgs->dev_ht.
+ * pdht == pgs->dev_ht[], this must done before updating pgs->dev_ht[].
*
* If the default order has been used for a device component, and
* any of the source component orders share their levels or bit_data
@@ -1130,7 +1136,7 @@ gx_gstate_dev_ht_install(
* be cleared immediately below, so subsequently it will not be
* possible to tell if that this information is being shared.
*/
- if (pdht->components != 0) {
+ if (pdht->components != NULL) {
int input_ncomps = pdht->num_comp;
for (i = 0; i < input_ncomps; i++) {
@@ -1150,9 +1156,9 @@ gx_gstate_dev_ht_install(
memset(&pdht->order, 0, sizeof(pdht->order));
}
- tmp_rc = pgsdht->rc;
- *pgsdht = dht;
- pgsdht->rc = tmp_rc;
+ tmp_rc = (*ppgsdht)->rc;
+ **ppgsdht = dht;
+ (*ppgsdht)->rc = tmp_rc;
/* update the effective transfer function array */
gx_gstate_set_effective_xfer(pgs);
@@ -1180,6 +1186,22 @@ gx_gstate_dev_ht_install(
}
/*
+ * Copy the dev_ht[HT_OBJTYPE_DEFAULT] to the dev_ht[] for the specified object type.
+ */
+int
+gx_gstate_dev_ht_copy_to_objtype(gs_gstate *pgs, gs_HT_objtype_t objtype)
+{
+ gx_device_halftone *pdht = pgs->dev_ht[HT_OBJTYPE_DEFAULT]; /* the current dev_ht */
+
+ if (objtype >= HT_OBJTYPE_COUNT) {
+ return_error(gs_error_undefined);
+ }
+ rc_increment(pdht);
+ pgs->dev_ht[objtype] = pdht;
+ return 0;
+}
+
+/*
* Install a new halftone in the graphics state. Note that we copy the top
* level of the gs_halftone and the gx_device_halftone, and take ownership
* of any substructures.
@@ -1194,7 +1216,7 @@ gx_ht_install(gs_gstate * pgs, const gs_halftone * pht,
int code;
pdht->num_dev_comp = pgs->device->color_info.num_components;
- if (old_ht != 0 && old_ht->rc.memory == mem &&
+ if (old_ht != NULL && old_ht->rc.memory == mem &&
old_ht->rc.ref_count == 1
)
new_ht = old_ht;
@@ -1203,7 +1225,8 @@ gx_ht_install(gs_gstate * pgs, const gs_halftone * pht,
mem, return_error(gs_error_VMerror),
"gx_ht_install(new halftone)");
code = gx_gstate_dev_ht_install(pgs,
- pdht, pht->type, gs_currentdevice_inline(pgs));
+ pdht, pht->type, gs_currentdevice_inline(pgs),
+ pht->objtype);
if (code < 0) {
if (new_ht != old_ht)
gs_free_object(mem, new_ht, "gx_ht_install(new halftone)");
@@ -1242,7 +1265,7 @@ gx_ht_install(gs_gstate * pgs, const gs_halftone * pht,
void
gx_gstate_set_effective_xfer(gs_gstate * pgs)
{
- gx_device_halftone *pdht = pgs->dev_ht;
+ gx_device_halftone *pdht = pgs->dev_ht[HT_OBJTYPE_DEFAULT];
gx_transfer_map *pmap;
gx_ht_order *porder;
int i, component_num, non_id_count;
diff --git a/base/gsht.h b/base/gsht.h
index 05857f9f..f5280852 100644
--- a/base/gsht.h
+++ b/base/gsht.h
@@ -23,6 +23,15 @@
#include "gsgstate.h"
#include "gstypes.h"
+/* Define the ObjectType enum for Halftones */
+typedef enum {
+ HT_OBJTYPE_DEFAULT = 0,
+ HT_OBJTYPE_VECTOR,
+ HT_OBJTYPE_IMAGE,
+ HT_OBJTYPE_TEXT,
+ HT_OBJTYPE_COUNT /* Must be last */
+} gs_HT_objtype_t;
+
/* Client definition of (Type 1) halftones */
typedef struct gs_screen_halftone_s {
float frequency;
diff --git a/base/gsht1.c b/base/gsht1.c
index 05fceb54..90f7e51b 100644
--- a/base/gsht1.c
+++ b/base/gsht1.c
@@ -169,6 +169,8 @@ gs_sethalftone_prepare(gs_gstate * pgs, gs_halftone * pht,
gx_ht_order_component *pocs = 0;
int code = 0;
+ if (pht->objtype >= HT_OBJTYPE_COUNT)
+ return_error(gs_error_limitcheck);
switch (pht->type) {
case ht_type_colorscreen:
{
diff --git a/base/gshtscr.c b/base/gshtscr.c
index 34ca1240..6807a9f3 100644
--- a/base/gshtscr.c
+++ b/base/gshtscr.c
@@ -627,6 +627,7 @@ gs_screen_install(gs_screen_enum * penum)
dev_ht.rc.memory = penum->halftone.rc.memory;
dev_ht.order = penum->order;
dev_ht.components = 0;
+ penum->halftone.objtype = HT_OBJTYPE_DEFAULT;
if ((code = gx_ht_install(penum->pgs, &penum->halftone, &dev_ht)) < 0)
gx_device_halftone_release(&dev_ht, dev_ht.rc.memory);
return code;
diff --git a/base/gshtx.c b/base/gshtx.c
index c42f19ba..bf01fb24 100644
--- a/base/gshtx.c
+++ b/base/gshtx.c
@@ -95,6 +95,7 @@ gs_ht_build(
/* initialize the halftone */
pht->type = ht_type_multiple;
pht->rc.free = free_comps;
+ pht->objtype = HT_OBJTYPE_DEFAULT;
pht->params.ht_multiple.components = phtc;
pht->params.ht_multiple.num_comp = num_comps;
diff --git a/base/gsicc.c b/base/gsicc.c
index f77d7028..d8e2bd3a 100644
--- a/base/gsicc.c
+++ b/base/gsicc.c
@@ -427,9 +427,13 @@ gx_remap_ICC_with_link(const gs_client_color * pcc, const gs_color_space * pcs,
the transfer function and potentially the halftoning */
/* Right now we need to go from unsigned short to frac. I really
would like to avoid this sort of stuff. That will come. */
- for ( k = 0; k < num_des_comps; k++){
+ for (k = 0; k < num_des_comps; k++){
conc[k] = ushort2frac(psrc_temp[k]);
}
+ /* In case there are extra components beyond the ICC ones */
+ for (k = num_des_comps; k < dev->color_info.num_components; k++) {
+ conc[k] = 0;
+ }
gx_remap_concrete_ICC(pcs, conc, pdc, pgs, dev, select, dev_profile);
/* Save original color space and color info into dev color */
@@ -535,9 +539,13 @@ gx_remap_ICC_imagelab(const gs_client_color * pcc, const gs_color_space * pcs,
the transfer function and potentially the halftoning */
/* Right now we need to go from unsigned short to frac. I really
would like to avoid this sort of stuff. That will come. */
- for ( k = 0; k < num_des_comps; k++){
+ for (k = 0; k < num_des_comps; k++){
conc[k] = ushort2frac(psrc_temp[k]);
}
+ /* We have to worry about extra colorants in the device. */
+ for (k = num_des_comps; k < dev->color_info.num_components; k++) {
+ conc[k] = 0;
+ }
gx_remap_concrete_ICC(pcs, conc, pdc, pgs, dev, select, dev_profile);
/* Save original color space and color info into dev color */
@@ -599,9 +607,14 @@ gx_concretize_ICC(
(icc_link->procs.map_color)(dev, icc_link, psrc, psrc_temp, 2);
}
/* This needs to be optimized */
- for (k = 0; k < num_des_comps; k++){
+ for (k = 0; k < num_des_comps; k++) {
pconc[k] = float2frac(((float) psrc_temp[k])/65535.0);
}
+ /* We have to worry about extra colorants in the device. */
+ for (k = num_des_comps; k < dev->color_info.num_components; k++) {
+ pconc[k] = 0;
+ }
+
/* Release the link */
gsicc_release_link(icc_link);
return 0;
@@ -615,10 +628,11 @@ gx_concretize_ICC(
* unintuitive but otherwise legitimate state of affairs".
*/
static void
-gx_final_ICC(const gs_color_space * pcs)
+gx_final_ICC(gs_color_space * pcs)
{
if (pcs->cmm_icc_profile_data != NULL) {
gsicc_adjust_profile_rc(pcs->cmm_icc_profile_data, -1, "gx_final_ICC");
+ pcs->cmm_icc_profile_data = NULL;
}
}
@@ -681,7 +695,8 @@ gx_set_overprint_ICC(const gs_color_space * pcs, gs_gstate * pgs)
bool gray_to_k;
bool op = pgs->is_fill_color ? pgs->overprint : pgs->stroke_overprint;
- if (dev == 0 || pcinfo == NULL)
+ if (dev == 0 || pcinfo == NULL || !op ||
+ gx_get_opmsupported(dev) == GX_CINFO_OPMSUPPORTED_NOT)
return gx_set_no_overprint(pgs);
dev_proc(dev, get_profile)(dev, &dev_profile);
@@ -697,22 +712,19 @@ gx_set_overprint_ICC(const gs_color_space * pcs, gs_gstate * pgs)
"[overprint] gx_set_overprint_ICC. cs_ok = %d is_fill_color = %d overprint = %d stroke_overprint = %d \n",
cs_ok, pgs->is_fill_color, pgs->overprint, pgs->stroke_overprint);
- if (!op || pcinfo->opmode == GX_CINFO_OPMODE_NOT) {
- return gx_set_no_overprint(pgs);
- } else if (!cs_ok) {
- /* In this case, we still need to maintain any spot
- colorant channels. Per Table 7.14. */
- if (dev_proc(dev, dev_spec_op)(dev, gxdso_supports_devn, NULL, 0)) {
- return gx_set_spot_only_overprint(pgs);
- } else {
- return gx_set_no_overprint(pgs);
- }
- } else
+ if (cs_ok)
return gx_set_overprint_cmyk(pcs, pgs);
+
+ /* In this case, we still need to maintain any spot
+ colorant channels. Per Table 7.14. */
+ if (dev_proc(dev, dev_spec_op)(dev, gxdso_supports_devn, NULL, 0))
+ return gx_set_spot_only_overprint(pgs);
+
+ return gx_set_no_overprint(pgs);
}
int
-gx_default_get_profile(gx_device *dev, cmm_dev_profile_t **profile)
+gx_default_get_profile(const gx_device *dev, cmm_dev_profile_t **profile)
{
*profile = dev->icc_struct;
return 0;
diff --git a/base/gsicc_cache.c b/base/gsicc_cache.c
index fda958aa..ba332060 100644
--- a/base/gsicc_cache.c
+++ b/base/gsicc_cache.c
@@ -635,7 +635,7 @@ gsicc_get_srcprofile(gsicc_colorbuffer_t data_cs,
case GS_UNTOUCHED_TAG:
default:
break;
- case GS_PATH_TAG:
+ case GS_VECTOR_TAG:
if (data_cs == gsRGB) {
(*profile) = srcgtag_profile->rgb_profiles[gsSRC_GRAPPRO];
*render_cond = srcgtag_profile->rgb_rend_cond[gsSRC_GRAPPRO];
@@ -870,6 +870,7 @@ gsicc_alloc_link_entry(gsicc_link_cache_t *icc_link_cache,
{
gs_memory_t *cache_mem = icc_link_cache->memory;
gsicc_link_t *link;
+ int retries = 0;
*ret_link = NULL;
/* First see if we can add a link */
@@ -908,6 +909,10 @@ gsicc_alloc_link_entry(gsicc_link_cache_t *icc_link_cache,
return true;
gx_monitor_enter(icc_link_cache->lock); /* restore the lock */
+ /* we will re-test the num_links above while locked to insure */
+ /* that some other thread didn't grab the slot and max us out */
+ if (retries++ > 10)
+ return false;
} else {
/* Remove the zero ref_count link profile we found. */
/* Even if we remove this link, we may still be maxed out so*/
@@ -1515,9 +1520,12 @@ gsicc_support_named_color(const gs_color_space *pcs, const gs_gstate *pgs)
byte *pname = NULL; /* Silence compiler warning */
uint name_size = 0; /* Silence compiler warning */
bool is_supported;
+ bool none_colorant;
/* Get the data for the named profile */
named_profile = pgs->icc_manager->device_named;
+ if (named_profile == NULL)
+ return false;
if (named_profile->buffer != NULL &&
named_profile->profile_handle == NULL) {
@@ -1547,8 +1555,10 @@ gsicc_support_named_color(const gs_color_space *pcs, const gs_gstate *pgs)
name_size = strlen(names[i]);
}
+ none_colorant = (strncmp((char*)pname, "None", name_size) == 0);
+
/* Classify */
- if (strncmp((char *)pname, "None", name_size) == 0 ||
+ if (none_colorant ||
strncmp((char *)pname, "All", name_size) == 0) {
num_other++;
} else {
@@ -1564,12 +1574,18 @@ gsicc_support_named_color(const gs_color_space *pcs, const gs_gstate *pgs)
/* Check if the colorant is supported */
is_supported = false;
- for (k = 0; k < num_entries; k++) {
- if (name_size == namedcolor_table->named_color[k].name_size) {
- if (strncmp((const char *)namedcolor_table->named_color[k].colorant_name,
- (const char *)pname, name_size) == 0) {
- is_supported = true;
- break;
+
+ /* If we have a none colorant name in the DeviceN list, just ignore it */
+ if (none_colorant && type == gs_color_space_index_DeviceN)
+ is_supported = true;
+ else {
+ for (k = 0; k < num_entries; k++) {
+ if (name_size == namedcolor_table->named_color[k].name_size) {
+ if (strncmp((const char*)namedcolor_table->named_color[k].colorant_name,
+ (const char*)pname, name_size) == 0) {
+ is_supported = true;
+ break;
+ }
}
}
}
diff --git a/base/gsicc_cms.h b/base/gsicc_cms.h
index 9d271f19..b9b38f93 100644
--- a/base/gsicc_cms.h
+++ b/base/gsicc_cms.h
@@ -62,6 +62,8 @@ gsicc_colorbuffer_t gscms_get_profile_data_space(gcmmhprofile_t profile,
gs_memory_t *memory);
int gscms_transform_color(gx_device *dev, gsicc_link_t *icclink, void *inputcolor,
void *outputcolor, int num_bytes);
+int gscms_transform_color_const(const gx_device *dev, gsicc_link_t *icclink, void *inputcolor,
+ void *outputcolor, int num_bytes);
gcmmhlink_t gscms_get_link(gcmmhprofile_t lcms_srchandle,
gcmmhprofile_t lcms_deshandle,
gsicc_rendering_param_t *rendering_params,
diff --git a/base/gsicc_lcms2.c b/base/gsicc_lcms2.c
index 5e9355e6..ccf1d705 100644
--- a/base/gsicc_lcms2.c
+++ b/base/gsicc_lcms2.c
@@ -462,6 +462,13 @@ int
gscms_transform_color(gx_device *dev, gsicc_link_t *icclink, void *inputcolor,
void *outputcolor, int num_bytes)
{
+ return gscms_transformm_color_const(dev, icclink, inputcolor, outputcolor, num_bytes);
+}
+
+int
+gscms_transform_color_const(const gx_device *dev, gsicc_link_t *icclink, void *inputcolor,
+ void *outputcolor, int num_bytes)
+{
cmsHTRANSFORM hTransform = (cmsHTRANSFORM)icclink->link_handle;
cmsUInt32Number dwInputFormat,dwOutputFormat;
diff --git a/base/gsicc_lcms2mt.c b/base/gsicc_lcms2mt.c
index eb621b96..b0d85405 100644
--- a/base/gsicc_lcms2mt.c
+++ b/base/gsicc_lcms2mt.c
@@ -475,6 +475,13 @@ int
gscms_transform_color(gx_device *dev, gsicc_link_t *icclink, void *inputcolor,
void *outputcolor, int num_bytes)
{
+ return gscms_transform_color_const(dev, icclink, inputcolor, outputcolor, num_bytes);
+}
+
+int
+gscms_transform_color_const(const gx_device *dev, gsicc_link_t *icclink, void *inputcolor,
+ void *outputcolor, int num_bytes)
+{
gsicc_lcms2mt_link_list_t *link_handle = (gsicc_lcms2mt_link_list_t *)(icclink->link_handle);
cmsHTRANSFORM hTransform = (cmsHTRANSFORM)link_handle->hTransform;
cmsUInt32Number dwInputFormat, dwOutputFormat;
@@ -670,9 +677,25 @@ gscms_get_link(gcmmhprofile_t lcms_srchandle, gcmmhprofile_t lcms_deshandle,
rendering_params->rendering_intent,
flag | cmm_flags);
if (link_handle->hTransform == NULL) {
- gs_free_object(memory, link_handle, "gscms_get_link");
+ int k;
+
+ /* Add a bit of robustness here. Some profiles are ill-formed and
+ do not have all the intents. If we failed due to a missing
+ intent, lets go ahead and try each and see if we can get something
+ that works. */
+ for (k = 0; k <= gsABSOLUTECOLORIMETRIC; k++) {
+ link_handle->hTransform = cmsCreateTransform(ctx, lcms_srchandle, src_data_type,
+ lcms_deshandle, des_data_type, k, flag | cmm_flags);
+ if (link_handle->hTransform != NULL)
+ break;
+ }
+
+ if (link_handle->hTransform == NULL) {
+ gs_free_object(memory, link_handle, "gscms_get_link");
return NULL;
+ }
}
+
link_handle->next = NULL;
link_handle->flags = gsicc_link_flags(0, 0, 0, 0, 0, /* no alpha, not planar, no endian swap */
sizeof(gx_color_value), sizeof(gx_color_value));
diff --git a/base/gsicc_manage.c b/base/gsicc_manage.c
index 4cf82e0c..0842628d 100644
--- a/base/gsicc_manage.c
+++ b/base/gsicc_manage.c
@@ -759,7 +759,7 @@ gsicc_set_srcgtag_struct(gsicc_manager_t *icc_manager, const char* pname,
/* Color tune profile. No intent */
srcgtag->color_warp_profile = icc_profile;
break;
- case GRAPHIC_CMYK:
+ case VECTOR_CMYK:
srcgtag->cmyk_profiles[gsSRC_GRAPPRO] = icc_profile;
srcgtag->cmyk_rend_cond[gsSRC_GRAPPRO].cmm = cmm;
if (cmm == gsCMM_DEFAULT) {
@@ -786,7 +786,7 @@ gsicc_set_srcgtag_struct(gsicc_manager_t *icc_manager, const char* pname,
return code;
}
break;
- case GRAPHIC_RGB:
+ case VECTOR_RGB:
srcgtag->rgb_profiles[gsSRC_GRAPPRO] = icc_profile;
srcgtag->rgb_rend_cond[gsSRC_GRAPPRO].cmm = cmm;
if (cmm == gsCMM_DEFAULT) {
@@ -813,7 +813,7 @@ gsicc_set_srcgtag_struct(gsicc_manager_t *icc_manager, const char* pname,
return code;
}
break;
- case GRAPHIC_GRAY:
+ case VECTOR_GRAY:
srcgtag->gray_profiles[gsSRC_GRAPPRO] = icc_profile;
srcgtag->gray_rend_cond[gsSRC_GRAPPRO].cmm = cmm;
if (cmm == gsCMM_DEFAULT) {
@@ -1586,8 +1586,15 @@ gsicc_set_device_profile_colorants(gx_device *dev, char *name_str)
char temp_str[DEFAULT_ICC_COLORANT_LENGTH+2];
/* If names are already set then we do not want to set default ones */
- if (profile_struct->spotnames != NULL)
- return 0;
+ if (profile_struct->spotnames != NULL) {
+ /* Check if we have at least as many spot names
+ as there are channels in the proFfile */
+ if (num_comps > profile_struct->spotnames->count) {
+ gs_warn("ICC profile colorant names count insufficient");
+ return_error(gs_error_rangecheck);
+ } else
+ return 0;
+ }
free_str = true;
/* Assume first 4 are CMYK */
@@ -1933,7 +1940,7 @@ gsicc_set_device_profile(gx_device * pdev, gs_memory_t * mem,
{
cmm_profile_t *icc_profile;
stream *str;
- int code;
+ int code = 0;
/* This is slightly silly, we have a device method for 'get_profile' we really ought to
* have one for 'set_profile' as well. In its absence, make sure we are setting the profile
@@ -2047,7 +2054,7 @@ gsicc_set_device_profile(gx_device * pdev, gs_memory_t * mem,
break;
default:
/* NCLR Profile. Set up default colorant names */
- gsicc_set_device_profile_colorants(pdev, NULL);
+ code = gsicc_set_device_profile_colorants(pdev, NULL);
break;
}
if_debug1m(gs_debug_flag_icc, mem, "[icc] Profile data CS is %d\n",
@@ -2055,7 +2062,7 @@ gsicc_set_device_profile(gx_device * pdev, gs_memory_t * mem,
} else
return gs_rethrow(-1, "cannot find device profile");
}
- return 0;
+ return code;
}
/* Set the icc profile in the gs_color_space object */
@@ -2796,10 +2803,10 @@ gsicc_extract_profile(gs_graphics_type_tag_t graphics_type_tag,
(*profile) = profile_struct->device_profile[GS_DEFAULT_DEVICE_PROFILE];
*render_cond = profile_struct->rendercond[GS_DEFAULT_DEVICE_PROFILE];
break;
- case GS_PATH_TAG:
- *render_cond = profile_struct->rendercond[GS_GRAPHIC_DEVICE_PROFILE];
- if (profile_struct->device_profile[GS_GRAPHIC_DEVICE_PROFILE] != NULL) {
- (*profile) = profile_struct->device_profile[GS_GRAPHIC_DEVICE_PROFILE];
+ case GS_VECTOR_TAG:
+ *render_cond = profile_struct->rendercond[GS_VECTOR_DEVICE_PROFILE];
+ if (profile_struct->device_profile[GS_VECTOR_DEVICE_PROFILE] != NULL) {
+ (*profile) = profile_struct->device_profile[GS_VECTOR_DEVICE_PROFILE];
} else {
(*profile) = profile_struct->device_profile[GS_DEFAULT_DEVICE_PROFILE];
}
@@ -2863,7 +2870,7 @@ dump_icc_buffer(const gs_memory_t *mem, int buffersize, char filename[],byte *Bu
gs_sprintf(full_file_name,"%d)%s_debug.icc",global_icc_index,filename);
fid = gp_fopen(mem, full_file_name,"wb");
gp_fwrite(Buffer,sizeof(unsigned char),buffersize,fid);
- fclose(fid);
+ gp_fclose(fid);
}
#endif
diff --git a/base/gsicc_manage.h b/base/gsicc_manage.h
index 437db045..bc5a0082 100644
--- a/base/gsicc_manage.h
+++ b/base/gsicc_manage.h
@@ -45,13 +45,13 @@
/* This enumeration has to be in sync with GSICC_SRCGTAG_KEYS */
typedef enum {
COLOR_TUNE,
- GRAPHIC_CMYK,
+ VECTOR_CMYK,
IMAGE_CMYK,
TEXT_CMYK,
- GRAPHIC_RGB,
+ VECTOR_RGB,
IMAGE_RGB,
TEXT_RGB,
- GRAPHIC_GRAY,
+ VECTOR_GRAY,
IMAGE_GRAY,
TEXT_GRAY
} gsicc_srcgtagkey_t;
diff --git a/base/gsicc_nocm.c b/base/gsicc_nocm.c
index efea6c1c..a592e3b1 100644
--- a/base/gsicc_nocm.c
+++ b/base/gsicc_nocm.c
@@ -40,7 +40,7 @@ typedef struct nocm_link_s {
gs_memory_t *memory;
} nocm_link_t;
-static void gsicc_nocm_transform_general(gx_device *dev, gsicc_link_t *icclink,
+static void gsicc_nocm_transform_general(const gx_device *dev, gsicc_link_t *icclink,
void *inputcolor, void *outputcolor,
int num_bytes_in, int num_bytes_out);
@@ -51,7 +51,7 @@ static void gsicc_nocm_transform_general(gx_device *dev, gsicc_link_t *icclink,
/* At most, we have 4 input and 4 output ptrs. Since this is used only in
DeviceGray, DeviceRGB and DeviceCMYK cases */
static void
-gsicc_nocm_planar_to_planar(gx_device *dev, gsicc_link_t *icclink,
+gsicc_nocm_planar_to_planar(const gx_device *dev, gsicc_link_t *icclink,
gsicc_bufferdesc_t *input_buff_desc,
gsicc_bufferdesc_t *output_buff_desc,
void *inputbuffer, void *outputbuffer)
@@ -88,7 +88,7 @@ gsicc_nocm_planar_to_planar(gx_device *dev, gsicc_link_t *icclink,
/* This is not really used yet */
static void
-gsicc_nocm_planar_to_chunky(gx_device *dev, gsicc_link_t *icclink,
+gsicc_nocm_planar_to_chunky(const gx_device *dev, gsicc_link_t *icclink,
gsicc_bufferdesc_t *input_buff_desc,
gsicc_bufferdesc_t *output_buff_desc,
void *inputbuffer, void *outputbuffer)
@@ -100,7 +100,7 @@ gsicc_nocm_planar_to_chunky(gx_device *dev, gsicc_link_t *icclink,
/* This is used with the fast thresholding code when doing -dUseFastColor
and going out to a planar device */
static void
-gsicc_nocm_chunky_to_planar(gx_device *dev, gsicc_link_t *icclink,
+gsicc_nocm_chunky_to_planar(const gx_device *dev, gsicc_link_t *icclink,
gsicc_bufferdesc_t *input_buff_desc,
gsicc_bufferdesc_t *output_buff_desc,
void *inputbuffer, void *outputbuffer)
@@ -156,7 +156,7 @@ gsicc_nocm_chunky_to_planar(gx_device *dev, gsicc_link_t *icclink,
}
static void
-gsicc_nocm_chunky_to_chunky(gx_device *dev, gsicc_link_t *icclink,
+gsicc_nocm_chunky_to_chunky(const gx_device *dev, gsicc_link_t *icclink,
gsicc_bufferdesc_t *input_buff_desc,
gsicc_bufferdesc_t *output_buff_desc,
void *inputbuffer, void *outputbuffer)
@@ -224,7 +224,7 @@ gsicc_nocm_transform_color_buffer(gx_device *dev, gsicc_link_t *icclink,
/* Shared function between the single and buffer conversions */
static void
-gsicc_nocm_transform_general(gx_device *dev, gsicc_link_t *icclink,
+gsicc_nocm_transform_general(const gx_device *dev, gsicc_link_t *icclink,
void *inputcolor, void *outputcolor,
int num_bytes_in, int num_bytes_out)
{
@@ -238,6 +238,9 @@ gsicc_nocm_transform_general(gx_device *dev, gsicc_link_t *icclink,
frac frac_in[4];
frac frac_out[GX_DEVICE_COLOR_MAX_COMPONENTS];
int k;
+ const gx_device *map_dev;
+ const gx_cm_color_map_procs *procs;
+
if (num_bytes_in == 2) {
unsigned short *data = (unsigned short *) inputcolor;
@@ -253,14 +256,17 @@ gsicc_nocm_transform_general(gx_device *dev, gsicc_link_t *icclink,
/* Use the device procedures to do the mapping */
switch (num_in) {
case 1:
- dev_proc(dev, get_color_mapping_procs)(dev)->map_gray(dev, frac_in[0], frac_out);
+ procs = dev_proc(dev, get_color_mapping_procs)(dev, &map_dev);
+ procs->map_gray(map_dev, frac_in[0], frac_out);
break;
case 3:
- dev_proc(dev, get_color_mapping_procs)(dev)->map_rgb(dev, link->pgs, frac_in[0], frac_in[1],
+ procs = dev_proc(dev, get_color_mapping_procs)(dev, &map_dev);
+ procs->map_rgb(map_dev, link->pgs, frac_in[0], frac_in[1],
frac_in[2], frac_out);
break;
case 4:
- dev_proc(dev, get_color_mapping_procs)(dev)->map_cmyk(dev, frac_in[0], frac_in[1],
+ procs = dev_proc(dev, get_color_mapping_procs)(dev, &map_dev);
+ procs->map_cmyk(map_dev, frac_in[0], frac_in[1],
frac_in[2], frac_in[3], frac_out);
break;
default:
diff --git a/base/gsicc_profilecache.c b/base/gsicc_profilecache.c
index db2e8ae4..900a3440 100644
--- a/base/gsicc_profilecache.c
+++ b/base/gsicc_profilecache.c
@@ -95,6 +95,9 @@ gsicc_add_cs(gs_gstate * pgs, gs_color_space * colorspace, uint64_t dictkey)
gsicc_profile_cache_t *profile_cache = pgs->icc_profile_cache;
gs_memory_t *memory = pgs->memory;
+ if (dictkey == 0)
+ return;
+
/* The entry has to be added in stable memory. We want them
to be maintained across the gsave and grestore process */
result = gs_alloc_struct(memory->stable_memory, gsicc_profile_entry_t,
@@ -125,6 +128,9 @@ gsicc_find_cs(uint64_t key_test, gs_gstate * pgs)
gsicc_profile_cache_t *profile_cache = pgs->icc_profile_cache;
gsicc_profile_entry_t *prev = NULL, *curr = profile_cache->head;
+ if (key_test == 0)
+ return NULL;
+
/* Look through the cache for the key. If found, move to MRU */
while (curr != NULL ){
if (curr->key == key_test){
diff --git a/base/gsicc_replacecm.c b/base/gsicc_replacecm.c
index e7cc7706..21a1c601 100644
--- a/base/gsicc_replacecm.c
+++ b/base/gsicc_replacecm.c
@@ -37,10 +37,11 @@ typedef struct rcm_link_s {
gsicc_colorbuffer_t data_cs_in;
gs_memory_t *memory;
gx_cm_color_map_procs cm_procs; /* for the demo */
+ const gx_device *cmdev;
void *context; /* For a table and or a set of procs */
} rcm_link_t;
-static void gsicc_rcm_transform_general(gx_device *dev, gsicc_link_t *icclink,
+static void gsicc_rcm_transform_general(const gx_device *dev, gsicc_link_t *icclink,
void *inputcolor, void *outputcolor,
int num_bytes_in, int num_bytes_out);
@@ -48,7 +49,7 @@ static void gsicc_rcm_transform_general(gx_device *dev, gsicc_link_t *icclink,
color conversions. Just putting in something that should work
right now */
static void
-gsicc_rcm_planar_to_planar(gx_device *dev, gsicc_link_t *icclink,
+gsicc_rcm_planar_to_planar(const gx_device *dev, gsicc_link_t *icclink,
gsicc_bufferdesc_t *input_buff_desc,
gsicc_bufferdesc_t *output_buff_desc,
void *inputbuffer, void *outputbuffer)
@@ -85,7 +86,7 @@ gsicc_rcm_planar_to_planar(gx_device *dev, gsicc_link_t *icclink,
/* This is not really used yet */
static void
-gsicc_rcm_planar_to_chunky(gx_device *dev, gsicc_link_t *icclink,
+gsicc_rcm_planar_to_chunky(const gx_device *dev, gsicc_link_t *icclink,
gsicc_bufferdesc_t *input_buff_desc,
gsicc_bufferdesc_t *output_buff_desc,
void *inputbuffer, void *outputbuffer)
@@ -97,7 +98,7 @@ gsicc_rcm_planar_to_chunky(gx_device *dev, gsicc_link_t *icclink,
/* This is used with the fast thresholding code when doing -dUseFastColor
and going out to a planar device */
static void
-gsicc_rcm_chunky_to_planar(gx_device *dev, gsicc_link_t *icclink,
+gsicc_rcm_chunky_to_planar(const gx_device *dev, gsicc_link_t *icclink,
gsicc_bufferdesc_t *input_buff_desc,
gsicc_bufferdesc_t *output_buff_desc,
void *inputbuffer, void *outputbuffer)
@@ -153,7 +154,7 @@ gsicc_rcm_chunky_to_planar(gx_device *dev, gsicc_link_t *icclink,
}
static void
-gsicc_rcm_chunky_to_chunky(gx_device *dev, gsicc_link_t *icclink,
+gsicc_rcm_chunky_to_chunky(const gx_device *dev, gsicc_link_t *icclink,
gsicc_bufferdesc_t *input_buff_desc,
gsicc_bufferdesc_t *output_buff_desc,
void *inputbuffer, void *outputbuffer)
@@ -223,7 +224,7 @@ gsicc_rcm_transform_color_buffer(gx_device *dev, gsicc_link_t *icclink,
negative to show the effect of what using color replacement. We also use
the device procs to map to the device value. */
static void
-gsicc_rcm_transform_general(gx_device *dev, gsicc_link_t *icclink,
+gsicc_rcm_transform_general(const gx_device *dev, gsicc_link_t *icclink,
void *inputcolor, void *outputcolor,
int num_bytes_in, int num_bytes_out)
{
@@ -234,7 +235,6 @@ gsicc_rcm_transform_general(gx_device *dev, gsicc_link_t *icclink,
frac frac_in[4];
frac frac_out[GX_DEVICE_COLOR_MAX_COMPONENTS];
int k;
- gx_device *parentmost_dev = subclass_parentmost_device(dev);
/* Make the negative for the demo.... */
if (num_bytes_in == 2) {
@@ -251,14 +251,14 @@ gsicc_rcm_transform_general(gx_device *dev, gsicc_link_t *icclink,
/* Use the device procedure */
switch (num_in) {
case 1:
- (link->cm_procs.map_gray)(parentmost_dev, frac_in[0], frac_out);
+ (link->cm_procs.map_gray)(link->cmdev, frac_in[0], frac_out);
break;
case 3:
- (link->cm_procs.map_rgb)(parentmost_dev, NULL, frac_in[0], frac_in[1],
+ (link->cm_procs.map_rgb)(link->cmdev, NULL, frac_in[0], frac_in[1],
frac_in[2], frac_out);
break;
case 4:
- (link->cm_procs.map_cmyk)(parentmost_dev, frac_in[0], frac_in[1], frac_in[2],
+ (link->cm_procs.map_cmyk)(link->cmdev, frac_in[0], frac_in[1], frac_in[2],
frac_in[3], frac_out);
break;
default:
@@ -311,10 +311,10 @@ gsicc_rcm_get_link(const gs_gstate *pgs, gx_device *dev,
rcm_link_t *rcm_link;
gs_memory_t *mem;
const gx_cm_color_map_procs * cm_procs;
+ const gx_device *cmdev;
bool pageneutralcolor = false;
cmm_dev_profile_t *dev_profile;
int code;
- subclass_color_mappings scm;
if (dev == NULL)
return NULL;
@@ -328,8 +328,7 @@ gsicc_rcm_get_link(const gs_gstate *pgs, gx_device *dev,
pageneutralcolor = dev_profile->pageneutralcolor;
}
- scm = get_color_mapping_procs_subclass(dev);
- cm_procs = scm.procs;
+ cm_procs = dev_proc(dev, get_color_mapping_procs)(dev, &cmdev);
hash.rend_hash = gsCMM_REPLACE;
hash.des_hash = dev->color_info.num_components;
@@ -368,6 +367,7 @@ gsicc_rcm_get_link(const gs_gstate *pgs, gx_device *dev,
rcm_link->cm_procs.map_cmyk = cm_procs->map_cmyk;
rcm_link->cm_procs.map_rgb = cm_procs->map_rgb;
rcm_link->cm_procs.map_gray = cm_procs->map_gray;
+ rcm_link->cmdev = cmdev;
switch (data_cs) {
case gsGRAY:
diff --git a/base/gsimage.c b/base/gsimage.c
index b3aefb93..25ae90b0 100644
--- a/base/gsimage.c
+++ b/base/gsimage.c
@@ -154,48 +154,40 @@ RELOC_PTRS_END
static int
is_image_visible(const gs_image_common_t * pic, gs_gstate * pgs, gx_clip_path *pcpath)
{
- /* HACK : We need the source image size here,
- but gs_image_common_t doesn't pass it.
- We would like to move Width, Height to gs_image_common,
- but gs_image2_t appears to have those fields of double type.
- */
- if (pic->type->begin_typed_image == gx_begin_image1) {
- gs_image1_t *pim = (gs_image1_t *) pic;
- gs_rect image_rect = {{0, 0}, {0, 0}};
- gs_rect device_rect;
- gs_int_rect device_int_rect;
- gs_matrix mat;
- int code;
-
- image_rect.q.x = pim->Width;
- image_rect.q.y = pim->Height;
- if (pic->ImageMatrix.xx == ctm_only(pgs).xx &&
- pic->ImageMatrix.xy == ctm_only(pgs).xy &&
- pic->ImageMatrix.yx == ctm_only(pgs).yx &&
- pic->ImageMatrix.yy == ctm_only(pgs).yy) {
- /* Handle common special case separately to accept singular matrix */
- mat.xx = mat.yy = 1.;
- mat.yx = mat.xy = 0.;
- mat.tx = ctm_only(pgs).tx - pic->ImageMatrix.tx;
- mat.ty = ctm_only(pgs).ty - pic->ImageMatrix.ty;
- } else {
- code = gs_matrix_invert(&pic->ImageMatrix, &mat);
- if (code < 0)
- return code;
- code = gs_matrix_multiply(&mat, &ctm_only(pgs), &mat);
- if (code < 0)
- return code;
- }
- code = gs_bbox_transform(&image_rect, &mat, &device_rect);
+ gs_rect image_rect = {{0, 0}, {0, 0}};
+ gs_rect device_rect;
+ gs_int_rect device_int_rect;
+ gs_matrix mat;
+ int code;
+
+ image_rect.q.x = pic->Width;
+ image_rect.q.y = pic->Height;
+ if (pic->ImageMatrix.xx == ctm_only(pgs).xx &&
+ pic->ImageMatrix.xy == ctm_only(pgs).xy &&
+ pic->ImageMatrix.yx == ctm_only(pgs).yx &&
+ pic->ImageMatrix.yy == ctm_only(pgs).yy) {
+ /* Handle common special case separately to accept singular matrix */
+ mat.xx = mat.yy = 1.;
+ mat.yx = mat.xy = 0.;
+ mat.tx = ctm_only(pgs).tx - pic->ImageMatrix.tx;
+ mat.ty = ctm_only(pgs).ty - pic->ImageMatrix.ty;
+ } else {
+ code = gs_matrix_invert(&pic->ImageMatrix, &mat);
+ if (code < 0)
+ return code;
+ code = gs_matrix_multiply(&mat, &ctm_only(pgs), &mat);
if (code < 0)
return code;
- device_int_rect.p.x = (int)floor(device_rect.p.x);
- device_int_rect.p.y = (int)floor(device_rect.p.y);
- device_int_rect.q.x = (int)ceil(device_rect.q.x);
- device_int_rect.q.y = (int)ceil(device_rect.q.y);
- if (!gx_cpath_rect_visible(pcpath, &device_int_rect))
- return 0;
}
+ code = gs_bbox_transform(&image_rect, &mat, &device_rect);
+ if (code < 0)
+ return code;
+ device_int_rect.p.x = (int)floor(device_rect.p.x);
+ device_int_rect.p.y = (int)floor(device_rect.p.y);
+ device_int_rect.q.x = (int)ceil(device_rect.q.x);
+ device_int_rect.q.y = (int)ceil(device_rect.q.y);
+ if (!gx_cpath_rect_visible(pcpath, &device_int_rect))
+ return 0;
return 1;
}
diff --git a/base/gsiparam.h b/base/gsiparam.h
index 365c625a..bcf65371 100644
--- a/base/gsiparam.h
+++ b/base/gsiparam.h
@@ -43,20 +43,6 @@
*/
typedef struct gx_image_type_s gx_image_type_t;
-#define gs_image_common\
- const gx_image_type_t *type;\
- /*\
- * Define the transformation from user space to image space.\
- */\
- gs_matrix ImageMatrix
-typedef struct gs_image_common_s {
- gs_image_common;
-} gs_image_common_t;
-
-#define public_st_gs_image_common() /* in gximage.c */\
- gs_public_st_simple(st_gs_image_common, gs_image_common_t,\
- "gs_image_common_t")
-
/* Parent image type enumerations. Since type3 images can give rise to
type 1 image types, we want to know the origin of these to avoid
doing different halftone methods to the image and the mask. */
@@ -87,7 +73,11 @@ typedef enum {
* how the data are actually supplied.
*/
#define gs_data_image_common\
- gs_image_common;\
+ const gx_image_type_t *type;\
+ /*\
+ * Define the transformation from user space to image space.\
+ */\
+ gs_matrix ImageMatrix;\
/*\
* Define the width of source image in pixels.\
*/\
@@ -123,6 +113,9 @@ typedef struct gs_data_image_s {
gs_public_st_simple(st_gs_data_image, gs_data_image_t,\
"gs_data_image_t")
+/* Historically these were different. No longer. */
+typedef gs_data_image_t gs_image_common_t;
+
/*
* Define the data common to ImageType 1 images, ImageType 3 DataDicts,
* and ImageType 4 images -- i.e., all the image types that provide pixel
diff --git a/base/gslib.c b/base/gslib.c
index ef426b45..53d9db38 100644
--- a/base/gslib.c
+++ b/base/gslib.c
@@ -55,7 +55,6 @@
/* Test programs */
static int test1(gs_gstate *, gs_memory_t *); /* kaleidoscope */
static int test2(gs_gstate *, gs_memory_t *); /* pattern fill */
-static int test3(gs_gstate *, gs_memory_t *); /* RasterOp */
static int test4(gs_gstate *, gs_memory_t *); /* set resolution */
static int test5(gs_gstate *, gs_memory_t *); /* images */
static int test6(gs_gstate *, gs_memory_t *); /* CIE API, snapping */
@@ -69,7 +68,7 @@ static int test10(gs_gstate *, gs_memory_t *); /* captured data */
#endif
static int (*tests[]) (gs_gstate *, gs_memory_t *) =
{
- test1, test2, test3, test4, test5,
+ test1, test2, test4, test5,
test6, test7, test8, 0
#ifdef CAPTURE
test10
@@ -408,45 +407,6 @@ test2(gs_gstate * pgs, gs_memory_t * mem)
/* Exercise RasterOp a little. */
/* Currently, this only works with monobit devices. */
-static int
-test3(gs_gstate * pgs, gs_memory_t * mem)
-{
- gx_device *dev = gs_currentdevice(pgs);
- gx_color_index black = gx_device_black(dev);
- gx_color_index white = gx_device_white(dev);
- gx_color_index black2[2];
- gx_color_index black_white[2];
- gx_color_index white_black[2];
- long pattern[max(align_bitmap_mod / sizeof(long), 1) * 4];
-
-#define pbytes ((byte *)pattern)
- gx_tile_bitmap tile;
-
- black2[0] = black2[1] = black;
- black_white[0] = white_black[1] = black;
- black_white[1] = white_black[0] = white;
- pbytes[0] = 0xf0;
- pbytes[align_bitmap_mod] = 0x90;
- pbytes[align_bitmap_mod * 2] = 0x90;
- pbytes[align_bitmap_mod * 3] = 0xf0;
- tile.data = pbytes;
- tile.raster = align_bitmap_mod;
- tile.size.x = tile.size.y = 4;
- tile.id = gs_next_ids(mem, 1);
- tile.rep_width = tile.rep_height = 4;
- (*dev_proc(dev, copy_rop))
- (dev, NULL, 0, 0, gx_no_bitmap_id, black2,
- &tile, white_black, 100, 100, 150, 150, 0, 0, rop3_T);
- (*dev_proc(dev, copy_rop))
- (dev, NULL, 0, 0, gx_no_bitmap_id, black2,
- NULL, NULL, 120, 120, 110, 110, 0, 0, ~rop3_S & rop3_1);
- (*dev_proc(dev, copy_rop))
- (dev, NULL, 0, 0, gx_no_bitmap_id, black2,
- &tile, white_black, 110, 110, 130, 130, 0, 0, rop3_T ^ rop3_D);
-#undef pbytes
- return 0;
-}
-
/* ---------------- Test program 4 ---------------- */
/* Set the resolution dynamically. */
@@ -576,10 +536,11 @@ test5(gs_gstate * pgs, gs_memory_t * mem)
image1.Width = W;
image1.Height = H;
image1.BitsPerComponent = 8;
+ image1.format = gs_image_format_chunky;
gs_translate(pgs, 0.5, 4.0);
- code = gx_device_begin_image(dev, pgs,
- &image1, gs_image_format_chunky,
+ code = gx_device_begin_typed_image(dev, pgs, NULL
+ (gs_image_common_t *)&image1,
NULL, &dcolor, NULL, mem, &info1);
/****** TEST code >= 0 ******/
planes[0].data = data3;
diff --git a/base/gslibctx.c b/base/gslibctx.c
index 6dfed6cd..318039fa 100644
--- a/base/gslibctx.c
+++ b/base/gslibctx.c
@@ -655,82 +655,39 @@ rewrite_percent_specifiers(char *s)
int
gs_add_outputfile_control_path(gs_memory_t *mem, const char *fname)
{
- char *fp, f[gp_file_name_sizeof];
- const int pipe = 124; /* ASCII code for '|' */
- const int len = strlen(fname);
- int i, code;
+ char f[gp_file_name_sizeof];
+ int code;
/* Be sure the string copy will fit */
- if (len >= gp_file_name_sizeof)
+ if (strlen(fname) >= gp_file_name_sizeof)
return gs_error_rangecheck;
strcpy(f, fname);
- fp = f;
/* Try to rewrite any %d (or similar) in the string */
rewrite_percent_specifiers(f);
- for (i = 0; i < len; i++) {
- if (f[i] == pipe) {
- fp = &f[i + 1];
- /* Because we potentially have to check file permissions at two levels
- for the output file (gx_device_open_output_file and the low level
- fopen API, if we're using a pipe, we have to add both the full string,
- (including the '|', and just the command to which we pipe - since at
- the pipe_fopen(), the leading '|' has been stripped.
- */
- code = gs_add_control_path(mem, gs_permit_file_writing, f);
- if (code < 0)
- return code;
- code = gs_add_control_path(mem, gs_permit_file_control, f);
- if (code < 0)
- return code;
- break;
- }
- if (!IS_WHITESPACE(f[i]))
- break;
- }
- code = gs_add_control_path(mem, gs_permit_file_control, fp);
+
+ code = gs_add_control_path(mem, gs_permit_file_control, f);
if (code < 0)
return code;
- return gs_add_control_path(mem, gs_permit_file_writing, fp);
+ return gs_add_control_path(mem, gs_permit_file_writing, f);
}
int
gs_remove_outputfile_control_path(gs_memory_t *mem, const char *fname)
{
- char *fp, f[gp_file_name_sizeof];
- const int pipe = 124; /* ASCII code for '|' */
- const int len = strlen(fname);
- int i, code;
+ char f[gp_file_name_sizeof];
+ int code;
/* Be sure the string copy will fit */
- if (len >= gp_file_name_sizeof)
+ if (strlen(fname) >= gp_file_name_sizeof)
return gs_error_rangecheck;
strcpy(f, fname);
- fp = f;
/* Try to rewrite any %d (or similar) in the string */
- for (i = 0; i < len; i++) {
- if (f[i] == pipe) {
- fp = &f[i + 1];
- /* Because we potentially have to check file permissions at two levels
- for the output file (gx_device_open_output_file and the low level
- fopen API, if we're using a pipe, we have to add both the full string,
- (including the '|', and just the command to which we pipe - since at
- the pipe_fopen(), the leading '|' has been stripped.
- */
- code = gs_remove_control_path(mem, gs_permit_file_writing, f);
- if (code < 0)
- return code;
- code = gs_remove_control_path(mem, gs_permit_file_control, f);
- if (code < 0)
- return code;
- break;
- }
- if (!IS_WHITESPACE(f[i]))
- break;
- }
- code = gs_remove_control_path(mem, gs_permit_file_control, fp);
+ rewrite_percent_specifiers(f);
+
+ code = gs_remove_control_path(mem, gs_permit_file_control, f);
if (code < 0)
return code;
- return gs_remove_control_path(mem, gs_permit_file_writing, fp);
+ return gs_remove_control_path(mem, gs_permit_file_writing, f);
}
int
diff --git a/base/gsmchunk.c b/base/gsmchunk.c
index 1fec7acd..1d3e89d6 100644
--- a/base/gsmchunk.c
+++ b/base/gsmchunk.c
@@ -942,6 +942,7 @@ chunk_obj_alloc(gs_memory_t *mem, size_t size, gs_memory_type_ptr_t type, client
memset((byte *)(obj) + SIZEOF_ROUND_ALIGN(chunk_obj_node_t), 0xac, size);
}
+ cmem->used += newsize;
obj->size = newsize; /* actual size */
obj->padding = newsize - size; /* actual size - client requested size */
obj->type = type; /* and client desired type */
@@ -1095,9 +1096,11 @@ chunk_free_object(gs_memory_t *mem, void *ptr, client_name_t cname)
}
/* finalize may change the head_**_chunk doing free of stuff */
- if_debug3m('A', cmem->target, "[a-]chunk_free_object(%s) "PRI_INTPTR"(%u)\n",
+ if_debug3m('A', cmem->target, "[a-]chunk_free_object(%s) "PRI_INTPTR"(%"PRIuSIZE")\n",
client_name_string(cname), (intptr_t)ptr, obj->size);
+ cmem->used -= obj->size;
+
if (SINGLE_OBJECT_CHUNK(obj->size - obj->padding)) {
gs_free_object(cmem->target, obj, "chunk_free_object(single object)");
#ifdef DEBUG_CHUNK
diff --git a/base/gsncdummy.c b/base/gsncdummy.c
index 631bf2c4..aadc2d1c 100644
--- a/base/gsncdummy.c
+++ b/base/gsncdummy.c
@@ -526,7 +526,7 @@ convert_intensity_into_device_color(const frac intensity,
cm = ck = 0;
cc = cy = frac_1 - intensity;
break;
- case GS_PATH_TAG: /* Make lines and fills blue. */
+ case GS_VECTOR_TAG: /* Make lines and fills blue. */
default:
cy = ck = 0;
cc = cm = frac_1 - intensity;
diff --git a/base/gsovrc.c b/base/gsovrc.c
index 16cd729c..745ebfbe 100644
--- a/base/gsovrc.c
+++ b/base/gsovrc.c
@@ -160,10 +160,10 @@ c_overprint_write(const gs_composite_t * pct, byte * data, uint * psize, gx_devi
}
/* encoded the booleans in a single byte */
- if (pparams->retain_any_comps || pparams->is_fill_color || pparams->op_state) {
+ if (pparams->retain_any_comps || pparams->is_fill_color || pparams->op_state != OP_STATE_NONE) {
flags |= (pparams->retain_any_comps) ? OVERPRINT_ANY_COMPS : 0;
flags |= (pparams->is_fill_color) ? OVERPRINT_IS_FILL_COLOR : 0;
- flags |= (pparams->op_state) << 2;
+ flags |= OVERPRINT_SET_FILL_COLOR & ((pparams->op_state) << 2);
flags |= (pparams->effective_opm) << 4;
/* write out the component bits */
@@ -181,11 +181,14 @@ c_overprint_write(const gs_composite_t * pct, byte * data, uint * psize, gx_devi
/* check for overflow */
*psize = used;
- if (used > avail)
- return_error(gs_error_rangecheck);
+ if (used > avail) {
+ if (avail != 0)
+ return_error(gs_error_rangecheck);
+ return gs_error_rangecheck;
+ }
data[0] = flags;
- if_debug2m('v', ((const gx_device *)cdev)->memory, "[v]c_overprint_write(%d), drawn_comps=0x%x\n",
- flags, pparams->drawn_comps);
+ if_debug2m('v', ((const gx_device *)cdev)->memory, "[v]c_overprint_write(%d), drawn_comps=0x%"PRIx64"\n",
+ flags, (uint64_t)pparams->drawn_comps);
return 0;
}
@@ -225,7 +228,7 @@ c_overprint_read(
}
if_debug1m('v', mem, ", retain_any_comps=%d", params.retain_any_comps);
if_debug1m('v', mem, ", is_fill_color=%d", params.is_fill_color);
- if_debug1m('v', mem, ", drawn_comps=0x%x", params.drawn_comps);
+ if_debug1m('v', mem, ", drawn_comps=0x%"PRIx64, (uint64_t)params.drawn_comps);
if_debug1m('v', mem, ", op_state=%d", params.op_state);
if_debug0m('v', mem, "\n");
code = gs_create_overprint(ppct, &params, mem);
@@ -381,7 +384,7 @@ gs_private_st_suffix_add0_final( st_overprint_device_t,
/*
* In the default (overprint false) case, the overprint device is almost
- * a pure forwarding device: only the open_device and create_compositor
+ * a pure forwarding device: only the open_device and composite
* methods are not pure-forwarding methods. The
* gx_device_foward_fill_in_procs procedure does not fill in all of the
* necessary procedures, so some of them are provided explicitly below.
@@ -396,7 +399,7 @@ gs_private_st_suffix_add0_final( st_overprint_device_t,
static dev_proc_open_device(overprint_open_device);
static dev_proc_put_params(overprint_put_params);
static dev_proc_get_page_device(overprint_get_page_device);
-static dev_proc_create_compositor(overprint_create_compositor);
+static dev_proc_composite(overprint_composite);
static dev_proc_get_color_comp_index(overprint_get_color_comp_index);
static dev_proc_fill_stroke_path(overprint_fill_stroke_path);
static dev_proc_fill_path(overprint_fill_path);
@@ -404,83 +407,24 @@ static dev_proc_stroke_path(overprint_stroke_path);
static dev_proc_text_begin(overprint_text_begin);
static dev_proc_dev_spec_op(overprint_dev_spec_op);
-static const gx_device_procs no_overprint_procs = {
- overprint_open_device, /* open_device */
- 0, /* get_initial_matrix */
- 0, /* sync_output */
- 0, /* output_page */
- 0, /* close_device */
- 0, /* map_rgb_color */
- 0, /* map_color_rgb */
- gx_forward_fill_rectangle, /* fill_rectangle */
- gx_forward_tile_rectangle, /* tile_rectangle */
- gx_forward_copy_mono, /* copy_mono */
- gx_forward_copy_color, /* copy_color */
- 0, /* draw_line (obsolete) */
- 0, /* get_bits */
- 0, /* get_params */
- overprint_put_params, /* put_params */
- 0, /* map_cmyk_color */
- 0, /* get_xfont_procs */
- 0, /* get_xfont_device */
- 0, /* map_rgb_alpha_color */
- overprint_get_page_device, /* get_page_device */
- 0, /* get_alpha_bits (obsolete) */
- 0, /* copy alpha */
- 0, /* get_band */
- 0, /* copy_rop */
- 0, /* fill_path */
- 0, /* stroke_path */
- 0, /* fill_mask */
- 0, /* fill_trapezoid */
- 0, /* fill_parallelogram */
- 0, /* fill_triangle */
- 0, /* draw_thin_line */
- 0, /* begin_image */
- 0, /* image_data (obsolete) */
- 0, /* end_image (obsolete) */
- gx_forward_strip_tile_rectangle, /* strip_tile_rectangle */
- 0, /* strip_copy_rop */
- 0, /* get_clipping_box */
- 0, /* begin_typed_image */
- 0, /* get_bits_rectangle */
- 0, /* map_color_rgb_alpha */
- overprint_create_compositor, /* create_compositor */
- 0, /* get_hardware_params */
- 0, /* text_begin */
- 0, /* gx_finish_copydevice */
- 0, /* begin_transparency_group */
- 0, /* end_transparency_group */
- 0, /* being_transparency_mask */
- 0, /* end_transparency_mask */
- 0, /* discard_transparency_layer */
- 0, /* get_color_mapping_procs */
- overprint_get_color_comp_index, /* get_color_comp_index */
- 0, /* encode_color */
- 0, /* decode_color */
- 0, /* pattern_manage */
- 0, /* fill_rectangle_hl_color */
- 0, /* include_color_space */
- 0, /* fill_linear_color_scanline */
- 0, /* fill_linear_color_trapezoid */
- 0, /* fill_linear_color_triangle */
- 0, /* update_spot_equivalent_colors */
- 0, /* ret_devn_params */
- gx_forward_fillpage,
- 0, /* push_transparency_state */
- 0, /* pop_transparency_state */
- 0, /* put_image */
- overprint_dev_spec_op, /* dev_spec_op */
- gx_forward_copy_planes,
- 0, /* get profile */
- 0, /* set graphics type tag */
- 0, /* strip_copy_rop2 */
- 0, /* strip_tile_rect_devn */
- gx_forward_copy_alpha_hl_color, /* copy_alpha_hl_color */
- NULL, /* process_page */\
- NULL, /* transform_pixel_region */\
- gx_forward_fill_stroke_path, /* fill_stroke */\
-};
+static void
+nooverprint_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, overprint_open_device);
+ set_dev_proc(dev, fill_rectangle, gx_forward_fill_rectangle);
+ set_dev_proc(dev, copy_mono, gx_forward_copy_mono);
+ set_dev_proc(dev, copy_color, gx_forward_copy_color);
+ set_dev_proc(dev, put_params, overprint_put_params);
+ set_dev_proc(dev, get_page_device, overprint_get_page_device);
+ set_dev_proc(dev, strip_tile_rectangle, gx_forward_strip_tile_rectangle);
+ set_dev_proc(dev, composite, overprint_composite);
+ set_dev_proc(dev, get_color_comp_index, overprint_get_color_comp_index);
+ set_dev_proc(dev, fillpage, gx_forward_fillpage);
+ set_dev_proc(dev, dev_spec_op, overprint_dev_spec_op);
+ set_dev_proc(dev, copy_planes, gx_forward_copy_planes);
+ set_dev_proc(dev, copy_alpha_hl_color, gx_forward_copy_alpha_hl_color);
+ set_dev_proc(dev, fill_stroke_path, gx_forward_fill_stroke_path);
+}
/*
* If overprint is set, the high and mid-level rendering methods are
@@ -516,161 +460,75 @@ static dev_proc_copy_alpha_hl_color(overprint_copy_alpha_hl_color);
/* other low-level overprint_sep_* rendering methods prototypes go here */
-static const gx_device_procs generic_overprint_procs = {
- overprint_open_device, /* open_device */
- 0, /* get_initial_matrix */
- 0, /* sync_output */
- 0, /* output_page */
- 0, /* close_device */
- 0, /* map_rgb_color */
- 0, /* map_color_rgb */
- overprint_generic_fill_rectangle, /* fill_rectangle */
- gx_default_tile_rectangle, /* tile_rectangle */
- gx_default_copy_mono, /* copy_mono */
- gx_default_copy_color, /* copy_color */
- gx_default_draw_line, /* draw_line (obsolete) */
- 0, /* get_bits */
- 0, /* get_params */
- overprint_put_params, /* put_params */
- 0, /* map_cmyk_color */
- 0, /* get_xfont_procs */
- gx_default_get_xfont_device, /* get_xfont_device */
- 0, /* map_rgb_alpha_color */
- overprint_get_page_device, /* get_page_device */
- 0, /* get_alpha_bits (obsolete) */
- gx_default_copy_alpha, /* copy alpha */
- 0, /* get_band */
- gx_default_copy_rop, /* copy_rop */
- overprint_fill_path, /* fill_path */
- overprint_stroke_path, /* stroke_path */
- gx_default_fill_mask, /* fill_mask */
- gx_default_fill_trapezoid, /* fill_trapezoid */
- gx_default_fill_parallelogram, /* fill_parallelogram */
- gx_default_fill_triangle, /* fill_triangle */
- gx_default_draw_thin_line, /* draw_thin_line */
- gx_default_begin_image, /* begin_image */
- 0, /* image_data (obsolete) */
- 0, /* end_image (obsolete) */
- gx_default_strip_tile_rectangle, /* strip_tile_rectangle */
- gx_default_strip_copy_rop, /* strip_copy_rop */
- 0, /* get_clipping_box */
- gx_default_begin_typed_image, /* begin_typed_image */
- 0, /* get_bits_rectangle */
- 0, /* map_color_rgb_alpha */
- overprint_create_compositor, /* create_compositor */
- 0, /* get_hardware_params */
- overprint_text_begin, /* text_begin */
- 0, /* gx_finish_copydevice */
- 0, /* begin_transparency_group */
- 0, /* end_transparency_group */
- 0, /* begin_transparency_mask */
- 0, /* end_transparency_mask */
- 0, /* discard_transparency_layer */
- 0, /* get_color_mapping_procs */
- overprint_get_color_comp_index, /* get_color_comp_index */
- 0, /* encode_color */
- 0, /* decode_color */
- 0, /* pattern_manage */
- overprint_fill_rectangle_hl_color, /* fill_rectangle_hl_color */
- 0, /* include_color_space */
- 0, /* fill_linear_color_scanline */
- 0, /* fill_linear_color_trapezoid */
- 0, /* fill_linear_color_triangle */
- 0, /* update_spot_equivalent_colors */
- 0, /* ret_devn_params */
- 0, /* fillpage */
- 0, /* push_transparency_state */
- 0, /* pop_transparency_state */
- 0, /* put_image */
- overprint_dev_spec_op, /* dev_spec_op */
- gx_forward_copy_planes,
- 0, /* get profile */
- 0, /* set graphics type tag */
- 0, /* strip_copy_rop2 */
- 0, /* strip_tile_rect_devn */
- gx_forward_copy_alpha_hl_color, /* copy_alpha_hl_color */
- NULL, /* process_page */\
- NULL, /* transform_pixel_region */\
- overprint_fill_stroke_path, /* fill_stroke */
-};
+static void
+generic_overprint_initialize_device_procs(gx_device *dev)
+{
+ /* Note that we set lots of things to 'default' here. You can't
+ * omit them, because the caller for this particular initialization
+ * proc fills them in with 'forward' ones, rather than 'default'
+ * ones, and that doesn't work. Maybe look into this in future. */
+ set_dev_proc(dev, open_device, overprint_open_device);
+ set_dev_proc(dev, fill_rectangle, overprint_generic_fill_rectangle);
+ set_dev_proc(dev, copy_mono, gx_default_copy_mono);
+ set_dev_proc(dev, copy_color, gx_default_copy_color);
+ set_dev_proc(dev, put_params, overprint_put_params);
+ set_dev_proc(dev, get_page_device, overprint_get_page_device);
+ set_dev_proc(dev, copy_alpha, gx_default_copy_alpha);
+ set_dev_proc(dev, fill_path, overprint_fill_path);
+ set_dev_proc(dev, stroke_path, overprint_stroke_path);
+ set_dev_proc(dev, fill_mask, gx_default_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, gx_default_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, gx_default_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, gx_default_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, gx_default_draw_thin_line);
+ set_dev_proc(dev, strip_tile_rectangle, gx_default_strip_tile_rectangle);
+ set_dev_proc(dev, strip_copy_rop2, gx_default_strip_copy_rop2);
+ set_dev_proc(dev, begin_typed_image, gx_default_begin_typed_image);
+ set_dev_proc(dev, composite, overprint_composite);
+ set_dev_proc(dev, text_begin, overprint_text_begin);
+ set_dev_proc(dev, get_color_comp_index, overprint_get_color_comp_index);
+ set_dev_proc(dev, fill_rectangle_hl_color, overprint_fill_rectangle_hl_color);
+ set_dev_proc(dev, dev_spec_op, overprint_dev_spec_op);
+ set_dev_proc(dev, copy_planes, gx_forward_copy_planes);
+ set_dev_proc(dev, copy_alpha_hl_color, dev->is_planar ?
+ overprint_copy_alpha_hl_color :
+ gx_forward_copy_alpha_hl_color);
+ set_dev_proc(dev, fill_stroke_path, overprint_fill_stroke_path);
+}
-static const gx_device_procs sep_overprint_procs = {
- overprint_open_device, /* open_device */
- 0, /* get_initial_matrix */
- 0, /* sync_output */
- 0, /* output_page */
- 0, /* close_device */
- 0, /* map_rgb_color */
- 0, /* map_color_rgb */
- overprint_sep_fill_rectangle, /* fill_rectangle */
- gx_default_tile_rectangle, /* tile_rectangle */
- gx_default_copy_mono, /* copy_mono */
- gx_default_copy_color, /* copy_color */
- gx_default_draw_line, /* draw_line (obsolete) */
- 0, /* get_bits */
- 0, /* get_params */
- overprint_put_params, /* put_params */
- 0, /* map_cmyk_color */
- 0, /* get_xfont_procs */
- gx_default_get_xfont_device, /* get_xfont_device */
- 0, /* map_rgb_alpha_color */
- overprint_get_page_device, /* get_page_device */
- 0, /* get_alpha_bits (obsolete) */
- gx_default_copy_alpha, /* copy alpha */
- 0, /* get_band */
- gx_default_copy_rop, /* copy_rop */
- overprint_fill_path, /* fill_path */
- overprint_stroke_path, /* stroke_path */
- gx_default_fill_mask, /* fill_mask */
- gx_default_fill_trapezoid, /* fill_trapezoid */
- gx_default_fill_parallelogram, /* fill_parallelogram */
- gx_default_fill_triangle, /* fill_triangle */
- gx_default_draw_thin_line, /* draw_thin_line */
- gx_default_begin_image, /* begin_image */
- 0, /* image_data (obsolete) */
- 0, /* end_image (obsolete) */
- gx_default_strip_tile_rectangle, /* strip_tile_rectangle */
- gx_default_strip_copy_rop, /* strip_copy_rop */
- 0, /* get_clipping_box */
- gx_default_begin_typed_image, /* begin_typed_image */
- 0, /* get_bits_rectangle */
- 0, /* map_color_rgb_alpha */
- overprint_create_compositor, /* create_compositor */
- 0, /* get_hardware_params */
- overprint_text_begin, /* text_begin */
- 0, /* gx_finish_copydevice */
- 0, /* begin_transparency_group */
- 0, /* end_transparency_group */
- 0, /* begin_transparency_mask */
- 0, /* end_transparency_mask */
- 0, /* discard_transparency_layer */
- 0, /* get_color_mapping_procs */
- overprint_get_color_comp_index, /* get_color_comp_index */
- 0, /* encode_color */
- 0, /* decode_color */
- 0, /* pattern_manage */
- overprint_fill_rectangle_hl_color, /* fill_rectangle_hl_color */
- 0, /* include_color_space */
- 0, /* fill_linear_color_scanline */
- 0, /* fill_linear_color_trapezoid */
- 0, /* fill_linear_color_triangle */
- 0, /* update_spot_equivalent_colors */
- 0, /* ret_devn_params */
- 0, /* fillpage */
- 0, /* push_transparency_state */
- 0, /* pop_transparency_state */
- 0, /* put_image */
- overprint_dev_spec_op, /* dev_spec_op */
- overprint_copy_planes, /* copy planes */
- 0, /* get profile */
- 0, /* set graphics type tag */
- 0, /* strip_copy_rop2 */
- 0, /* strip_tile_rect_devn */
- overprint_copy_alpha_hl_color, /* copy_alpha_hl_color */
- NULL, /* process_page */\
- NULL, /* transform_pixel_region */\
- overprint_fill_stroke_path, /* fill_stroke */
-};
+static void
+sep_overprint_initialize_device_procs(gx_device *dev)
+{
+ /* Note that we set lots of things to 'default' here. You can't
+ * omit them, because the caller for this particular initialization
+ * proc fills them in with 'forward' ones, rather than 'default'
+ * ones, and that doesn't work. Maybe look into this in future. */
+ set_dev_proc(dev, open_device, overprint_open_device);
+ set_dev_proc(dev, fill_rectangle, overprint_sep_fill_rectangle);
+ set_dev_proc(dev, copy_mono, gx_default_copy_mono);
+ set_dev_proc(dev, copy_color, gx_default_copy_color);
+ set_dev_proc(dev, put_params, overprint_put_params);
+ set_dev_proc(dev, get_page_device, overprint_get_page_device);
+ set_dev_proc(dev, copy_alpha, gx_default_copy_alpha);
+ set_dev_proc(dev, fill_path, overprint_fill_path);
+ set_dev_proc(dev, stroke_path, overprint_stroke_path);
+ set_dev_proc(dev, fill_mask, gx_default_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, gx_default_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, gx_default_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, gx_default_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, gx_default_draw_thin_line);
+ set_dev_proc(dev, strip_tile_rectangle, gx_default_strip_tile_rectangle);
+ set_dev_proc(dev, strip_copy_rop2, gx_default_strip_copy_rop2);
+ set_dev_proc(dev, begin_typed_image, gx_default_begin_typed_image);
+ set_dev_proc(dev, composite, overprint_composite);
+ set_dev_proc(dev, text_begin, overprint_text_begin);
+ set_dev_proc(dev, get_color_comp_index, overprint_get_color_comp_index);
+ set_dev_proc(dev, fill_rectangle_hl_color, overprint_fill_rectangle_hl_color);
+ set_dev_proc(dev, dev_spec_op, overprint_dev_spec_op);
+ set_dev_proc(dev, copy_planes, overprint_copy_planes);
+ set_dev_proc(dev, copy_alpha_hl_color, overprint_copy_alpha_hl_color);
+ set_dev_proc(dev, fill_stroke_path, overprint_fill_stroke_path);
+}
/*
* The prototype for the overprint device does not provide much
@@ -679,7 +537,7 @@ static const gx_device_procs sep_overprint_procs = {
*/
const overprint_device_t gs_overprint_device = {
std_device_std_body_open( overprint_device_t, /* device type */
- 0, /* static_procs */
+ NULL, /* initialize */
"overprint_device", /* dname */
0, 0, /* width, height */
1, 1 ), /* HWResolution */
@@ -785,15 +643,16 @@ update_overprint_params(
we will turn it off when setting one and turn on
when setting the other (or vice versa) */
- /* Note if pparams is to set the opdev fill stroke state. Do that now and exit */
+ /* Note if pparams->op_state is not NONE, set the opdev fill/stroke state. */
if (pparams->op_state != OP_STATE_NONE) {
opdev->op_state = pparams->op_state;
return 0;
}
if_debug4m(gs_debug_flag_overprint, opdev->memory,
- "[overprint] update_overprint_params enter. retain_any_comps = %d, idle = %d, drawn_comps = 0x%x, is_fill_color = %d\n",
- pparams->retain_any_comps, pparams->idle, pparams->drawn_comps, pparams->is_fill_color);
+ "[overprint] update_overprint_params enter. retain_any_comps = %d, idle = %d, drawn_comps = 0x%"PRIx64", is_fill_color = %d\n",
+ pparams->retain_any_comps, pparams->idle,
+ (uint64_t)pparams->drawn_comps, pparams->is_fill_color);
/* check if overprint is to be turned off */
if (!pparams->retain_any_comps || pparams->idle) {
@@ -820,8 +679,10 @@ update_overprint_params(
}
if_debug4m(gs_debug_flag_overprint, opdev->memory,
- "[overprint] update_overprint_params exit. drawn_comps_fill = 0x%x, drawn_comps_stroke = 0x%x, retain_none_fill = %d, retain_none_stroke = %d \n",
- opdev->drawn_comps_fill, opdev->drawn_comps_stroke, opdev->retain_none_fill, opdev->retain_none_stroke);
+ "[overprint] update_overprint_params exit. drawn_comps_fill = 0x%"PRIx64", drawn_comps_stroke = 0x%"PRIx64", retain_none_fill = %d, retain_none_stroke = %d \n",
+ (uint64_t)opdev->drawn_comps_fill,
+ (uint64_t)opdev->drawn_comps_stroke,
+ opdev->retain_none_fill, opdev->retain_none_stroke);
return 0;
}
@@ -848,8 +709,10 @@ update_overprint_params(
}
if_debug4m(gs_debug_flag_overprint, opdev->memory,
- "[overprint] update_overprint_params exit. drawn_comps_fill = 0x%x, drawn_comps_stroke = 0x%x, retain_none_fill = %d, retain_none_stroke = %d \n",
- opdev->drawn_comps_fill, opdev->drawn_comps_stroke, opdev->retain_none_fill, opdev->retain_none_stroke);
+ "[overprint] update_overprint_params exit. drawn_comps_fill = 0x%"PRIx64", drawn_comps_stroke = 0x%"PRIx64", retain_none_fill = %d, retain_none_stroke = %d \n",
+ (uint64_t)opdev->drawn_comps_fill,
+ (uint64_t)opdev->drawn_comps_stroke,
+ opdev->retain_none_fill, opdev->retain_none_stroke);
/* if appropriate, update the retain_mask field */
if (colors_are_separable_and_linear(&opdev->color_info))
@@ -942,11 +805,11 @@ overprint_get_page_device(gx_device * dev)
}
/*
- * Calling create_compositor on the overprint device just updates the
+ * Calling composite on the overprint device just updates the
* overprint parameters; no new device is created.
*/
static int
-overprint_create_compositor(
+overprint_composite(
gx_device * dev,
gx_device ** pcdev,
const gs_composite_t * pct,
@@ -955,7 +818,7 @@ overprint_create_compositor(
gx_device * cdev)
{
if (pct->type != &gs_composite_overprint_type)
- return gx_default_create_compositor(dev, pcdev, pct, pgs, memory, cdev);
+ return gx_default_composite(dev, pcdev, pct, pgs, memory, cdev);
else {
gs_overprint_params_t params = ((const gs_overprint_t *)pct)->params;
overprint_device_t *opdev = (overprint_device_t *)dev;
@@ -972,8 +835,11 @@ overprint_create_compositor(
params.idle = pct->idle;
/* device must already exist, so just update the parameters if settings change */
if_debug6m(gs_debug_flag_overprint, opdev->memory,
- "[overprint] overprint_create_compositor test for change. params.idle = %d vs. opdev->is_idle = %d \n params.is_fill_color = %d: params.drawn_comps = 0x%x vs. opdev->drawn_comps_fill = 0x%x OR opdev->drawn_comps_stroke = 0x%x\n",
- params.idle, opdev->is_idle, params.is_fill_color, params.drawn_comps, opdev->drawn_comps_fill, opdev->drawn_comps_stroke);
+ "[overprint] overprint_composite test for change. params.idle = %d vs. opdev->is_idle = %d \n params.is_fill_color = %d: params.drawn_comps = 0x%"PRIx64" vs. opdev->drawn_comps_fill = 0x%"PRIx64" OR opdev->drawn_comps_stroke = 0x%"PRIx64"\n",
+ params.idle, opdev->is_idle, params.is_fill_color,
+ (uint64_t)params.drawn_comps,
+ (uint64_t)opdev->drawn_comps_fill,
+ (uint64_t)opdev->drawn_comps_stroke);
if (update || params.idle != opdev->is_idle || params.op_state != OP_STATE_NONE)
code = update_overprint_params(opdev, &params);
@@ -1006,7 +872,7 @@ overprint_generic_fill_rectangle(
return 0;
else {
- assert(opdev->op_state != 0);
+ assert(opdev->op_state != OP_STATE_NONE);
/* See if we even need to do any overprinting. We have to maintain
the compositor active for fill/stroke cases even if we are only
@@ -1118,7 +984,7 @@ overprint_copy_planes(gx_device * dev, const byte * data, int data_x, int raster
gb_params.data[j] = 0;
gb_params.data[k] = gb_buff + k * raster;
code = dev_proc(tdev, get_bits_rectangle) (tdev, &gb_rect,
- &gb_params, 0);
+ &gb_params);
if (code < 0) {
gs_free_object(mem, gb_buff, "overprint_copy_planes" );
return code;
@@ -1185,7 +1051,7 @@ overprint_fill_rectangle_hl_color(gx_device *dev,
if (tdev == 0)
return 0;
- assert(opdev->op_state != 0);
+ assert(opdev->op_state != OP_STATE_NONE);
/* See if we even need to do any overprinting. We have to maintain
the compositor active for fill/stroke cases even if we are only
@@ -1242,7 +1108,7 @@ overprint_fill_rectangle_hl_color(gx_device *dev,
gb_params.data[j] = 0;
gb_params.data[k] = gb_buff + k * raster;
code = dev_proc(tdev, get_bits_rectangle) (tdev, &gb_rect,
- &gb_params, 0);
+ &gb_params);
if (code < 0) {
gs_free_object(mem, gb_buff,
"overprint_fill_rectangle_hl_color" );
@@ -1288,7 +1154,7 @@ overprint_sep_fill_rectangle(
else {
int depth = tdev->color_info.depth;
- assert(opdev->op_state != 0);
+ assert(opdev->op_state != OP_STATE_NONE);
/* See if we even need to do any overprinting. We have to maintain
the compositor active for fill/stroke cases even if we are only
@@ -1341,10 +1207,13 @@ overprint_fill_path(gx_device* pdev, const gs_gstate* pgs,
const gx_device_color* pdcolor, const gx_clip_path* pcpath)
{
overprint_device_t* opdev = (overprint_device_t*)pdev;
+ OP_FS_STATE save_op_state = opdev->op_state;
+ int code;
opdev->op_state = OP_STATE_FILL;
- return gx_default_fill_path(pdev, pgs, ppath, params_fill,
- pdcolor, pcpath);
+ code = gx_default_fill_path(pdev, pgs, ppath, params_fill, pdcolor, pcpath);
+ opdev->op_state = save_op_state;
+ return code;
}
/* We need this to ensure the device knows we are doing a stroke */
@@ -1354,6 +1223,7 @@ overprint_stroke_path(gx_device* pdev, const gs_gstate* pgs,
const gx_device_color* pdcolor, const gx_clip_path* pcpath)
{
overprint_device_t* opdev = (overprint_device_t*)pdev;
+ OP_FS_STATE save_op_state = opdev->op_state;
int code;
opdev->op_state = OP_STATE_STROKE;
@@ -1361,9 +1231,9 @@ overprint_stroke_path(gx_device* pdev, const gs_gstate* pgs,
/* Stroke methods use fill path so set that to default to
avoid mix up of is_fill_color */
opdev->procs.fill_path = gx_default_fill_path;
- code = gx_default_stroke_path(pdev, pgs, ppath, params_stroke,
- pdcolor, pcpath);
+ code = gx_default_stroke_path(pdev, pgs, ppath, params_stroke, pdcolor, pcpath);
opdev->procs.fill_path = overprint_fill_path;
+ opdev->op_state = save_op_state;
return code;
}
@@ -1382,6 +1252,7 @@ overprint_fill_stroke_path(gx_device * pdev, const gs_gstate * pgs,
{
int code;
overprint_device_t *opdev = (overprint_device_t *)pdev;
+ OP_FS_STATE save_op_state = opdev->op_state;
opdev->op_state = OP_STATE_FILL;
code = dev_proc(pdev, fill_path)(pdev, pgs, ppath, params_fill, pdevc_fill, pcpath);
@@ -1391,6 +1262,7 @@ overprint_fill_stroke_path(gx_device * pdev, const gs_gstate * pgs,
/* Set up for stroke */
opdev->op_state = OP_STATE_STROKE;
code = dev_proc(pdev, stroke_path)(pdev, pgs, ppath, params_stroke, pdevc_stroke, pcpath);
+ opdev->op_state = save_op_state;
return code;
}
@@ -1398,19 +1270,21 @@ overprint_fill_stroke_path(gx_device * pdev, const gs_gstate * pgs,
static int
overprint_text_begin(gx_device* dev, gs_gstate* pgs,
const gs_text_params_t* text, gs_font* font,
- gx_path* path, const gx_device_color* pdcolor,
const gx_clip_path* pcpath,
- gs_memory_t* mem, gs_text_enum_t** ppte)
+ gs_text_enum_t** ppte)
{
overprint_device_t* opdev = (overprint_device_t*)dev;
+ OP_FS_STATE save_op_state = opdev->op_state;
+ int code = 0;
if (pgs->text_rendering_mode == 0)
opdev->op_state = OP_STATE_FILL;
else if (pgs->text_rendering_mode == 1)
opdev->op_state = OP_STATE_STROKE;
- return gx_default_text_begin(dev, pgs, text, font,
- path, pdcolor, pcpath, mem, ppte);
+ code = gx_default_text_begin(dev, pgs, text, font, pcpath, ppte);
+ opdev->op_state = save_op_state;
+ return code;
}
static int
@@ -1443,10 +1317,12 @@ overprint_dev_spec_op(gx_device* pdev, int dev_spec_op,
}
/* complete a procedure set */
-static void
-fill_in_procs(gx_device_procs * pprocs)
+static int
+fill_in_procs(gx_device_procs * pprocs,
+ dev_proc_initialize_device_procs(initialize_device_procs),
+ int is_planar)
{
- gx_device_forward tmpdev;
+ gx_device_forward tmpdev;
/*
* gx_device_forward_fill_in_procs calls gx_device_fill_in_procs, which
@@ -1457,15 +1333,20 @@ fill_in_procs(gx_device_procs * pprocs)
memcpy( &tmpdev.color_info,
&gs_overprint_device.color_info,
sizeof(tmpdev.color_info) );
+ tmpdev.is_planar = is_planar;
+
/*
* Prevent the check_device_separable routine from executing while we
* fill in the procs. Our tmpdev is not complete enough for it.
*/
tmpdev.color_info.separable_and_linear = GX_CINFO_SEP_LIN_NONE;
- tmpdev.static_procs = 0;
- memcpy(&tmpdev.procs, pprocs, sizeof(tmpdev.procs));
+ memset(&tmpdev.procs, 0, sizeof(tmpdev.procs));
+ tmpdev.initialize_device_procs = initialize_device_procs;
+ initialize_device_procs((gx_device *)&tmpdev);
gx_device_forward_fill_in_procs(&tmpdev);
memcpy(pprocs, &tmpdev.procs, sizeof(tmpdev.procs));
+
+ return 0;
}
/*
@@ -1506,30 +1387,33 @@ c_overprint_create_default_compositor(
*popdev = (gx_device *)opdev;
if (opdev == NULL)
return_error(gs_error_VMerror);
- gx_device_init((gx_device *)opdev,
- (const gx_device *)&gs_overprint_device,
- mem,
- false );
- memcpy(&opdev->no_overprint_procs,
- &no_overprint_procs,
- sizeof(no_overprint_procs));
- memcpy(&opdev->generic_overprint_procs,
- &generic_overprint_procs,
- sizeof(generic_overprint_procs));
- memcpy(&opdev->sep_overprint_procs,
- &sep_overprint_procs,
- sizeof(sep_overprint_procs));
- fill_in_procs(&opdev->no_overprint_procs);
- fill_in_procs(&opdev->generic_overprint_procs);
- fill_in_procs(&opdev->sep_overprint_procs);
+ code = gx_device_init((gx_device *)opdev,
+ (const gx_device *)&gs_overprint_device,
+ mem,
+ false);
+ if (code < 0)
+ return code;
+ code = fill_in_procs(&opdev->no_overprint_procs,
+ nooverprint_initialize_device_procs,
+ tdev->is_planar);
+ if (code < 0)
+ return code;
+ code = fill_in_procs(&opdev->generic_overprint_procs,
+ generic_overprint_initialize_device_procs,
+ tdev->is_planar);
+ if (code < 0)
+ return code;
+ code = fill_in_procs(&opdev->sep_overprint_procs,
+ sep_overprint_initialize_device_procs,
+ tdev->is_planar);
+ if (code < 0)
+ return code;
gx_device_copy_params((gx_device *)opdev, tdev);
gx_device_set_target((gx_device_forward *)opdev, tdev);
opdev->pad = tdev->pad;
opdev->log2_align_mod = tdev->log2_align_mod;
opdev->is_planar = tdev->is_planar;
- if (opdev->is_planar)
- opdev->generic_overprint_procs.copy_alpha_hl_color = overprint_copy_alpha_hl_color;
params = ovrpct->params;
params.idle = ovrpct->idle;
diff --git a/base/gsovrc.h b/base/gsovrc.h
index 790fcaf5..64e2a9d5 100644
--- a/base/gsovrc.h
+++ b/base/gsovrc.h
@@ -195,7 +195,7 @@
* state, cease to exist as as independent item. The only way to discard
* the compositor is to change the current device.
*
- * Subsequent invocations of create_compositor will not create a new
+ * Subsequent invocations of composite will not create a new
* compositor. Rather, they change the parameters of the existing
* compositor device. The compositor functions with only a small
* performance penalty if overprint is disabled, so there is no reason
diff --git a/base/gspaint.c b/base/gspaint.c
index 70ff0ce6..9c4e8210 100644
--- a/base/gspaint.c
+++ b/base/gspaint.c
@@ -295,7 +295,7 @@ static int do_fill(gs_gstate *pgs, int rule)
segment structure (depending on how fine grained we require it to be).
*/
if (pgs->show_gstate == NULL)
- ensure_tag_is_set(pgs, pgs->device, GS_PATH_TAG); /* NB: may unset_dev_color */
+ ensure_tag_is_set(pgs, pgs->device, GS_VECTOR_TAG); /* NB: may unset_dev_color */
else
ensure_tag_is_set(pgs, pgs->device, GS_TEXT_TAG); /* NB: may unset_dev_color */
@@ -415,7 +415,7 @@ do_stroke(gs_gstate * pgs)
segment structure (depending on how fine grained we require it to be).
*/
if (pgs->show_gstate == NULL)
- ensure_tag_is_set(pgs, pgs->device, GS_PATH_TAG); /* NB: may unset_dev_color */
+ ensure_tag_is_set(pgs, pgs->device, GS_VECTOR_TAG); /* NB: may unset_dev_color */
else
ensure_tag_is_set(pgs, pgs->device, GS_TEXT_TAG); /* NB: may unset_dev_color */
@@ -644,7 +644,7 @@ static int do_fill_stroke(gs_gstate *pgs, int rule, int *restart)
segment structure (depending on how fine grained we require it to be).
*/
if (pgs->show_gstate == NULL)
- ensure_tag_is_set(pgs, pgs->device, GS_PATH_TAG); /* NB: may unset_dev_color */
+ ensure_tag_is_set(pgs, pgs->device, GS_VECTOR_TAG); /* NB: may unset_dev_color */
else
ensure_tag_is_set(pgs, pgs->device, GS_TEXT_TAG); /* NB: may unset_dev_color */
@@ -684,7 +684,7 @@ static int do_fill_stroke(gs_gstate *pgs, int rule, int *restart)
/* Have to set the fill color too */
if (pgs->show_gstate == NULL)
- ensure_tag_is_set(pgs, pgs->device, GS_PATH_TAG); /* NB: may unset_dev_color */
+ ensure_tag_is_set(pgs, pgs->device, GS_VECTOR_TAG); /* NB: may unset_dev_color */
else
ensure_tag_is_set(pgs, pgs->device, GS_TEXT_TAG); /* NB: may unset_dev_color */
diff --git a/base/gsparam.c b/base/gsparam.c
index e8a2f0c5..c8bfe7f9 100644
--- a/base/gsparam.c
+++ b/base/gsparam.c
@@ -102,7 +102,8 @@ static const byte xfer_item_sizes[] = {
};
int
gs_param_read_items(gs_param_list * plist, void *obj,
- const gs_param_item_t * items)
+ const gs_param_item_t * items,
+ gs_memory_t *mem)
{
const gs_param_item_t *pi;
int ecode = 0;
@@ -123,8 +124,128 @@ gs_param_read_items(gs_param_list * plist, void *obj,
case 0:
if (typed.type != pi->type) /* shouldn't happen! */
ecode = gs_note_error(gs_error_typecheck);
- else
- memcpy(pvalue, &typed.value, xfer_item_sizes[pi->type]);
+ else {
+ switch(typed.type)
+ {
+ case gs_param_type_dict:
+ case gs_param_type_dict_int_keys:
+ case gs_param_type_array:
+ return_error(gs_error_rangecheck);
+ case gs_param_type_string:
+ case gs_param_type_name:
+ {
+ void *copy;
+ gs_string *s;
+ if (mem == NULL) {
+ /* Return pointers to the data in the param list. This
+ * means that if the caller wants to keep it around it
+ * needs to copy it itself, or run the risk of the
+ * param list going away. */
+ goto copy_pointer;
+ }
+ /* Free any existing data before copying into it. */
+ s = ((gs_string *)pvalue);
+ if (typed.value.s.size != s->size) {
+ gs_free_string(mem, s->data, s->size, "gs_param_read_items");
+ s->data = NULL;
+ s->size = 0;
+ copy = gs_alloc_string(mem, typed.value.s.size, "gs_param_read_items");
+ if (copy == NULL)
+ return_error(gs_error_VMerror);
+ s->size = typed.value.s.size;
+ } else {
+ copy = s->data;
+ }
+ memcpy(copy, typed.value.s.data, typed.value.s.size);
+ s->data = copy;
+ ((gs_param_string *)pvalue)->persistent = 0; /* 0 => We own this copy */
+ break;
+ }
+ case gs_param_type_int_array:
+ case gs_param_type_float_array:
+ case gs_param_type_string_array:
+ case gs_param_type_name_array:
+ {
+ int eltsize;
+ gs_param_string_array *sa;
+ if (mem == NULL) {
+ /* Return pointers to the data in the param list. This
+ * means that if the caller wants to keep it around it
+ * needs to copy it itself, or run the risk of the
+ * param list going away. */
+ goto copy_pointer;
+ }
+ /* Free any existing data before copying into it. */
+ eltsize = gs_param_type_base_sizes[typed.type];
+ sa = ((gs_param_string_array *)pvalue);
+ if (typed.value.ia.size != sa->size) {
+ void *copy;
+ if (typed.type == gs_param_type_name_array ||
+ typed.type == gs_param_type_string_array) {
+ /* Free the strings. */
+ int i;
+ gs_param_string *arr;
+ union { const gs_param_string *cs; gs_param_string *s; } u;
+ u.cs = sa->data;
+ arr = u.s; /* Hideous dodge to avoid the const. */
+ for (i = 0; i < typed.value.sa.size; i++) {
+ /* Hideous hackery to get around the const nature of gs_param_strings. */
+ gs_string *arr_non_const = (gs_string *)(void *)(&arr[i]);
+ if (arr[i].persistent == 0)
+ gs_free_string(mem, arr_non_const->data, arr_non_const->size, "gs_param_read_items");
+ arr_non_const->data = NULL;
+ arr_non_const->size = 0;
+ }
+ }
+ gs_free_const_object(mem, sa->data, "gs_param_read_items");
+ sa->data = NULL;
+ sa->size = 0;
+ copy = gs_alloc_bytes(mem, eltsize * typed.value.s.size, "gs_param_read_items");
+ if (copy == NULL)
+ return_error(gs_error_VMerror);
+ memset(copy, 0, eltsize * typed.value.s.size);
+ sa->size = typed.value.s.size;
+ sa->data = copy;
+ }
+ /* Now copy the elements of the arrays. */
+ if (typed.type == gs_param_type_name_array ||
+ typed.type == gs_param_type_string_array) {
+ /* Free the strings. */
+ int i;
+ const gs_param_string *src = typed.value.sa.data;
+ gs_param_string *dst;
+ union { const gs_param_string *cs; gs_param_string *s; } u;
+ u.cs = sa->data;
+ dst = u.s; /* Hideous dodge to avoid the const. */
+ for (i = 0; i < typed.value.sa.size; i++) {
+ /* Hideous hackery to get around the const nature of gs_param_strings. */
+ gs_string *dst_non_const = (gs_string *)(void *)(&dst[i]);
+ if (dst[i].persistent == 0)
+ gs_free_string(mem, dst_non_const->data, dst_non_const->size, "gs_param_read_items");
+ dst_non_const->data = NULL;
+ dst_non_const->size = 0;
+ }
+ /* Copy values */
+ for (i = 0; i < sa->size; i++) {
+ dst[i].data = gs_alloc_string(mem, src[i].size, "gs_param_read_items");
+ if (dst[i].data == NULL)
+ return_error(gs_error_VMerror);
+ dst[i].size = src[i].size;
+ dst[i].persistent = 0; /* 0 => We own this copy */
+ }
+ } else {
+ /* Hideous hackery to get around the const nature of gs_param_strings. */
+ gs_string *s = (gs_string *)(void *)sa;
+ memcpy(s->data, typed.value.s.data, eltsize * typed.value.s.size);
+ }
+ ((gs_param_string *)pvalue)->persistent = 0; /* 0 => We own this copy */
+ break;
+ }
+ default:
+ copy_pointer:
+ memcpy(pvalue, &typed.value, xfer_item_sizes[pi->type]);
+ }
+ }
}
}
return ecode;
@@ -150,6 +271,8 @@ gs_param_write_items(gs_param_list * plist, const void *obj,
continue;
memcpy(&typed.value, pvalue, size);
typed.type = pi->type;
+ /* Ensure the list doesn't end up keeping a pointer to our values. */
+ typed.value.s.persistent = 0;
code = (*plist->procs->xmit_typed) (plist, key, &typed);
if (code < 0)
ecode = code;
diff --git a/base/gsparam.h b/base/gsparam.h
index 43cc92d8..df3b1c03 100644
--- a/base/gsparam.h
+++ b/base/gsparam.h
@@ -374,6 +374,15 @@ typedef struct gs_param_list_procs_s {
#define param_commit(plist)\
(*(plist)->procs->commit)(plist)
+ /*
+ * Read the value of a previously signalled error. (Only used when reading.)
+ */
+#define param_proc_read_signalled_error(proc)\
+ int proc(gs_param_list *, gs_param_name)
+ param_proc_read_signalled_error((*read_signalled_error));
+#define param_read_signalled_error(plist, pkey)\
+ (*(plist)->procs->read_signalled_error)(plist, pkey)
+
} gs_param_list_procs;
/* Transmit typed parameters. */
@@ -477,7 +486,8 @@ typedef struct gs_param_item_s {
* the optional default_obj, the item isn't transferred.
*/
int gs_param_read_items(gs_param_list * plist, void *obj,
- const gs_param_item_t * items);
+ const gs_param_item_t * items,
+ gs_memory_t *mem);
int gs_param_write_items(gs_param_list * plist, const void *obj,
const void *default_obj,
const gs_param_item_t * items);
diff --git a/base/gsparamx.c b/base/gsparamx.c
index 2893253a..8ca19a5b 100644
--- a/base/gsparamx.c
+++ b/base/gsparamx.c
@@ -156,6 +156,8 @@ param_list_copy(gs_param_list *plto, gs_param_list *plfrom)
coll_type = gs_param_collection_array;
cc:
copy.value.d.size = value.value.d.size;
+ /* FIXME: RJW: I suspect that this will go wrong, if size == 0.
+ * We should probably spot size == 0 and break. */
if ((code = param_begin_write_collection(plto, string_key,
&copy.value.d,
coll_type)) < 0 ||
diff --git a/base/gspcolor.c b/base/gspcolor.c
index 4fb53680..417fb139 100644
--- a/base/gspcolor.c
+++ b/base/gspcolor.c
@@ -293,7 +293,7 @@ gx_set_overprint_Pattern(const gs_color_space * pcs, gs_gstate * pgs)
/* Adjust the reference counts for Pattern color spaces or colors. */
static void
-gx_final_Pattern(const gs_color_space * pcs)
+gx_final_Pattern(gs_color_space * pcs)
{
/* {csrc} really do nothing? */
}
@@ -305,7 +305,7 @@ gx_adjust_color_Pattern(const gs_client_color * pcc,
gs_pattern_instance_t *pinst = pcc->pattern;
rc_adjust_only(pinst, delta, "gx_adjust_color_Pattern");
- if (pcs && pcs->params.pattern.has_base_space)
+ if (pcs && pcs->base_space && pcs->params.pattern.has_base_space)
(pcs->base_space->type->adjust_color_count)
(pcc, pcs->base_space, delta);
}
diff --git a/base/gsptype1.c b/base/gsptype1.c
index c4589488..732047ec 100644
--- a/base/gsptype1.c
+++ b/base/gsptype1.c
@@ -184,7 +184,11 @@ gs_pattern1_make_pattern(gs_client_color * pcc,
code = gs_note_error(gs_error_rangecheck);
goto fsaved;
}
+
inst.templat = *pcp;
+ /* Even if the pattern wants to use transparency, don't permit it if there is no device which will support it */
+ inst.templat.uses_transparency &= dev_proc( gs_currentdevice_inline(pgs), dev_spec_op)( gs_currentdevice_inline(pgs), gxdso_supports_pattern_transparency, NULL, 0);;
+
code = compute_inst_matrix(&inst, &bbox, dev_width, dev_height, &bbw, &bbh);
if (code < 0)
goto fsaved;
@@ -775,7 +779,7 @@ gs_pattern1_set_color(const gs_client_color * pcc, gs_gstate * pgs)
params.retain_any_comps = false;
params.effective_opm = pgs->color[0].effective_opm = 0;
params.op_state = OP_STATE_NONE;
- params.is_fill_color = false;
+ params.is_fill_color = pgs->is_fill_color;
params.idle = false;
return gs_gstate_update_overprint(pgs, &params);
diff --git a/base/gsptype2.c b/base/gsptype2.c
index 878fbe64..b9ef6a05 100644
--- a/base/gsptype2.c
+++ b/base/gsptype2.c
@@ -158,13 +158,14 @@ gx_dc_is_pattern2_color(const gx_device_color *pdevc)
}
/*
- * The device halftone used by a PatternType 2 patter is that current in
+ * The device halftone used by a PatternType 2 pattern is that current in
* the graphic state at the time of the makepattern call.
*/
static const gx_device_halftone *
gx_dc_pattern2_get_dev_halftone(const gx_device_color * pdevc)
{
- return ((gs_pattern2_instance_t *)pdevc->ccolor.pattern)->saved->dev_ht;
+ /* FIXME: Do we need to be objtype specific w.r.t. to the dev_ht ??? */
+ return ((gs_pattern2_instance_t *)pdevc->ccolor.pattern)->saved->dev_ht[HT_OBJTYPE_DEFAULT];
}
/* Load a PatternType 2 color into the cache. (No effect.) */
diff --git a/base/gsrefct.h b/base/gsrefct.h
index bfdb1a6f..98d1896e 100644
--- a/base/gsrefct.h
+++ b/base/gsrefct.h
@@ -21,6 +21,7 @@
#include "memento.h"
#include "std.h"
+#include "gdebug.h"
/*
* A reference-counted object must include the following header:
@@ -135,6 +136,7 @@ rc_free_proc(rc_free_struct_only);
BEGIN\
IF_RC_DEBUG(rc_trace_adjust(vp, &(vp)->rc, delta, cname));\
(vp)->rc.ref_count += (delta);\
+ (void)Memento_adjustRef((vp), delta);\
END
#define rc_unshare_struct(vp, typ, pstype, mem, errstat, cname)\
BEGIN\
diff --git a/base/gsstate.c b/base/gsstate.c
index e8077d07..3a4542d1 100644
--- a/base/gsstate.c
+++ b/base/gsstate.c
@@ -76,7 +76,7 @@ static void clip_stack_rc_adjust(gx_clip_stack_t *cs, int delta, client_name_t c
*
* (3a) Objects that are logically connected to individual gstates.
* We use reference counting to manage these. Currently these are:
- * halftone, dev_ht, cie_render, black_generation,
+ * halftone, dev_ht(4), cie_render, black_generation,
* undercolor_removal, set_transfer.*, cie_joint_caches,
* clip_stack, {opacity,shape}.mask
* effective_transfer.* may point to some of the same objects as
@@ -277,7 +277,7 @@ gs_gstate_client_data(const gs_gstate * pgs)
}
/* Free the chain of gstates.*/
-int
+void
gs_gstate_free_chain(gs_gstate * pgs)
{
gs_gstate *saved = pgs, *tmp;
@@ -287,16 +287,16 @@ gs_gstate_free_chain(gs_gstate * pgs)
gs_gstate_free(saved);
saved = tmp;
}
- return 0;
}
/* Free a graphics state. */
-int
+void
gs_gstate_free(gs_gstate * pgs)
{
+ if (pgs == NULL)
+ return;
gstate_free_contents(pgs);
gs_free_object(pgs->memory, pgs, "gs_gstate_free");
- return 0;
}
/* Save the graphics state. */
@@ -571,7 +571,7 @@ gs_gstate_swap_memory(gs_gstate * pgs, gs_memory_t * mem)
/*
* Push an overprint compositor onto the current device. Note that if
* the current device already is an overprint compositor, the
- * create_compositor will update its parameters but not create a new
+ * composite will update its parameters but not create a new
* compositor device.
*/
int
@@ -584,7 +584,7 @@ gs_gstate_update_overprint(gs_gstate * pgs, const gs_overprint_params_t * pparam
code = gs_create_overprint(&pct, pparams, pgs->memory);
if (code >= 0) {
- code = dev_proc(dev, create_compositor)( dev,
+ code = dev_proc(dev, composite)( dev,
&ovptdev,
pct,
pgs,
@@ -1317,11 +1317,11 @@ typedef struct {
static gs_gstate *
gstate_clone_core(const gs_gstate *pfrom,
+ gs_memory_t *mem,
client_name_t cname,
gs_gstate_clone_data *clone_data,
gs_gstate_copy_reason_t reason)
{
- gs_memory_t *mem = pfrom->memory;
gs_gstate *pgs = gstate_alloc(mem, cname, pfrom);
void *pdata = NULL;
@@ -1386,8 +1386,8 @@ gstate_clone_for_gsave(gs_gstate *pfrom,
client_name_t cname)
{
gs_gstate_clone_data clone_data;
- gs_gstate *pgs = gstate_clone_core(pfrom, cname, &clone_data,
- copy_for_gsave);
+ gs_gstate *pgs = gstate_clone_core(pfrom, pfrom->memory, cname,
+ &clone_data, copy_for_gsave);
if (pgs == NULL)
return NULL;
@@ -1407,7 +1407,7 @@ gstate_clone_for_gstate(const gs_gstate *pfrom,
client_name_t cname)
{
gs_gstate_clone_data clone_data;
- gs_gstate *pgs = gstate_clone_core(pfrom, cname, &clone_data,
+ gs_gstate *pgs = gstate_clone_core(pfrom, mem, cname, &clone_data,
copy_for_gstate);
if (pgs == NULL)
@@ -1468,10 +1468,8 @@ gstate_free_contents(gs_gstate * pgs)
if (pgs->client_data != 0)
(*pgs->client_procs.free) (pgs->client_data, mem, pgs);
pgs->client_data = 0;
- gs_swapcolors_quick(pgs);
- cs_adjust_counts_icc(pgs, -1);
- gs_swapcolors_quick(pgs);
cs_adjust_counts_icc(pgs, -1);
+ cs_adjust_swappedcounts_icc(pgs, -1);
pgs->color[0].color_space = 0;
pgs->color[1].color_space = 0;
gs_free_object(mem, pgs->line_params.dash.pattern, cname);
@@ -1503,9 +1501,7 @@ gstate_copy(gs_gstate * pto, const gs_gstate * pfrom,
* Handle references from contents.
*/
cs_adjust_counts_icc(pto, -1);
- gs_swapcolors_quick(pto);
- cs_adjust_counts_icc(pto, -1);
- gs_swapcolors_quick(pto);
+ cs_adjust_swappedcounts_icc(pto, -1);
gx_path_assign_preserve(pto->path, pfrom->path);
gx_cpath_assign_preserve(pto->clip_path, pfrom->clip_path);
/*
@@ -1556,9 +1552,7 @@ gstate_copy(gs_gstate * pto, const gs_gstate * pfrom,
}
GSTATE_ASSIGN_PARTS(pto, &parts);
cs_adjust_counts_icc(pto, 1);
- gs_swapcolors_quick(pto);
- cs_adjust_counts_icc(pto, 1);
- gs_swapcolors_quick(pto);
+ cs_adjust_swappedcounts_icc(pto, 1);
pto->show_gstate =
(pfrom->show_gstate == pfrom ? pto : 0);
return 0;
diff --git a/base/gsstate.h b/base/gsstate.h
index b786dde4..7d9bde46 100644
--- a/base/gsstate.h
+++ b/base/gsstate.h
@@ -25,8 +25,8 @@
/* Initial allocation and freeing */
gs_gstate *gs_gstate_alloc(gs_memory_t *); /* 0 if fails */
-int gs_gstate_free(gs_gstate *);
-int gs_gstate_free_chain(gs_gstate *);
+void gs_gstate_free(gs_gstate *);
+void gs_gstate_free_chain(gs_gstate *);
/* Initialization, saving, restoring, and copying */
int gs_gsave(gs_gstate *), gs_grestore(gs_gstate *), gs_grestoreall(gs_gstate *);
diff --git a/base/gstext.c b/base/gstext.c
index e8373295..c4bf16a3 100644
--- a/base/gstext.c
+++ b/base/gstext.c
@@ -83,13 +83,13 @@ RELOC_PTRS_END
static ENUM_PTRS_WITH(text_enum_enum_ptrs, gs_text_enum_t *eptr)
{
- if (index == 8) {
+ if (index == 6) {
if (eptr->pair != 0)
ENUM_RETURN(eptr->pair - eptr->pair->index);
else
ENUM_RETURN(0);
}
- index -= 9;
+ index -= 7;
if (index <= eptr->fstack.depth)
ENUM_RETURN(eptr->fstack.items[index].font);
index -= eptr->fstack.depth + 1;
@@ -97,8 +97,8 @@ static ENUM_PTRS_WITH(text_enum_enum_ptrs, gs_text_enum_t *eptr)
}
case 0: return ENUM_OBJ(gx_device_enum_ptr(eptr->dev));
case 1: return ENUM_OBJ(gx_device_enum_ptr(eptr->imaging_dev));
-ENUM_PTR3(2, gs_text_enum_t, pgs, orig_font, path);
-ENUM_PTR3(5, gs_text_enum_t, pdcolor, pcpath, current_font);
+ENUM_PTR2(2, gs_text_enum_t, pgs, orig_font);
+ENUM_PTR2(4, gs_text_enum_t, pcpath, current_font);
ENUM_PTRS_END
static RELOC_PTRS_WITH(text_enum_reloc_ptrs, gs_text_enum_t *eptr)
@@ -108,8 +108,8 @@ static RELOC_PTRS_WITH(text_enum_reloc_ptrs, gs_text_enum_t *eptr)
RELOC_USING(st_gs_text_params, &eptr->text, sizeof(eptr->text));
eptr->dev = gx_device_reloc_ptr(eptr->dev, gcst);
eptr->imaging_dev = gx_device_reloc_ptr(eptr->imaging_dev, gcst);
- RELOC_PTR3(gs_text_enum_t, pgs, orig_font, path);
- RELOC_PTR3(gs_text_enum_t, pdcolor, pcpath, current_font);
+ RELOC_PTR2(gs_text_enum_t, pgs, orig_font);
+ RELOC_PTR2(gs_text_enum_t, pcpath, current_font);
if (eptr->pair != NULL)
eptr->pair = (cached_fm_pair *)RELOC_OBJ(eptr->pair - eptr->pair->index) +
eptr->pair->index;
@@ -122,17 +122,12 @@ RELOC_PTRS_END
int
gx_device_text_begin(gx_device * dev, gs_gstate * pgs,
const gs_text_params_t * text, gs_font * font,
- gx_path * path, /* unless DO_NONE & !RETURN_WIDTH */
- const gx_device_color * pdcolor, /* DO_DRAW */
const gx_clip_path * pcpath, /* DO_DRAW */
- gs_memory_t * mem, gs_text_enum_t ** ppte)
+ gs_text_enum_t ** ppte)
{
if (TEXT_PARAMS_ARE_INVALID(text))
return_error(gs_error_rangecheck);
{
- gx_path *tpath =
- ((text->operation & TEXT_DO_NONE) &&
- !(text->operation & TEXT_RETURN_WIDTH) ? 0 : path);
const gx_clip_path *tcpath =
(text->operation & TEXT_DO_DRAW ? pcpath : 0);
@@ -141,7 +136,7 @@ gx_device_text_begin(gx_device * dev, gs_gstate * pgs,
Since the accumulation may happen while stringwidth.
we pass the device color unconditionally. */
return dev_proc(dev, text_begin)
- (dev, pgs, text, font, tpath, pdcolor, tcpath, mem, ppte);
+ (dev, pgs, text, font, tcpath, ppte);
}
}
@@ -186,8 +181,8 @@ gs_text_enum_init_dynamic(gs_text_enum_t *pte, gs_font *font)
int
gs_text_enum_init(gs_text_enum_t *pte, const gs_text_enum_procs_t *procs,
gx_device *dev, gs_gstate *pgs,
- const gs_text_params_t *text, gs_font *font, gx_path *path,
- const gx_device_color *pdcolor, const gx_clip_path *pcpath,
+ const gs_text_params_t *text, gs_font *font,
+ const gx_clip_path *pcpath,
gs_memory_t *mem)
{
int code;
@@ -197,8 +192,6 @@ gs_text_enum_init(gs_text_enum_t *pte, const gs_text_enum_procs_t *procs,
pte->imaging_dev = NULL;
pte->pgs = pgs;
pte->orig_font = font;
- pte->path = path;
- pte->pdcolor = pdcolor;
pte->pcpath = pcpath;
pte->memory = mem;
pte->procs = procs;
@@ -406,9 +399,8 @@ gs_text_begin(gs_gstate * pgs, const gs_text_params_t * text,
pgs->device->sgr.stroke_stored = false;
code = gx_device_text_begin(pgs->device, pgs,
- text, pgs->font, pgs->path,
- gs_currentdevicecolor_inline(pgs),
- pcpath, mem, ppte);
+ text, pgs->font,
+ pcpath, ppte);
/* we need to know if we are doing a highlevel device.
Also we need to know if we are doing any stroke
@@ -438,18 +430,12 @@ gs_text_begin(gs_gstate * pgs, const gs_text_params_t * text,
int
gs_text_update_dev_color(gs_gstate * pgs, gs_text_enum_t * pte)
{
- /*
- * The text enumerator holds a device color pointer, which may be a
- * null pointer or a pointer to the same device color as the graphic
- * state points to. In the former case the text is not to be
- * rendered, and hence of no interest here. In the latter case the
- * update of the graphic state color will update the text color as
- * well.
- */
/* Processing a text object operation */
ensure_tag_is_set(pgs, pgs->device, GS_TEXT_TAG); /* NB: may unset_dev_color */
- if (pte->pdcolor != 0) {
+ if (pte->text.operation & TEXT_DO_DRAW) {
+ /* FIXME: It feels bad that we're setting the dev color in
+ * pgs, rather than pte->pgs. */
int code = gx_set_dev_color(pgs);
if (code != 0)
return code;
diff --git a/base/gstext.h b/base/gstext.h
index e8de9fea..630d16b8 100644
--- a/base/gstext.h
+++ b/base/gstext.h
@@ -159,10 +159,7 @@ typedef struct gs_text_enum_s gs_text_enum_t;
gs_gstate *pgs,\
const gs_text_params_t *text,\
gs_font *font,\
- gx_path *path, /* unless DO_NONE */\
- const gx_device_color *pdcolor, /* if DO_DRAW */\
const gx_clip_path *pcpath, /* if DO_DRAW */\
- gs_memory_t *memory,\
gs_text_enum_t **ppte)
#define dev_proc_text_begin(proc)\
dev_t_proc_text_begin(proc, gx_device)
diff --git a/base/gstiffio.c b/base/gstiffio.c
index 004f9feb..bb2ce85e 100644
--- a/base/gstiffio.c
+++ b/base/gstiffio.c
@@ -30,7 +30,6 @@
#include "gstiffio.h"
-
#define TIFF_PRINT_BUF_LENGTH 1024
static const char tifs_msg_truncated[] = "\n*** Previous line has been truncated.\n";
@@ -295,6 +294,8 @@ _TIFFmemcmp(const void* p1, const void* p2, tmsize_t c)
#if !defined(HAVE_SNPRINTF) && !defined(HAVE__SNPRINTF)
#include "gssprintf.h"
+/* gets rid of compiler warning -- could include tiffiop.h, not sure which is better */
+int _TIFF_snprintf_f(char* buf, size_t size, const char* format, ...);
int
_TIFF_snprintf_f(char* buf, size_t size, const char* format, ...)
{
diff --git a/base/gstrans.c b/base/gstrans.c
index cb201eba..d810524a 100644
--- a/base/gstrans.c
+++ b/base/gstrans.c
@@ -124,7 +124,7 @@ check_for_nontrans_pattern(gs_gstate *pgs, unsigned char *comp_name)
/*
* Push a PDF 1.4 transparency compositor onto the current device. Note that
* if the current device already is a PDF 1.4 transparency compositor, the
- * create_compositor will update its parameters but not create a new
+ * composite will update its parameters but not create a new
* compositor device.
*/
static int
@@ -207,7 +207,7 @@ gs_begin_transparency_group(gs_gstate *pgs,
}
/*
* Put parameters into a compositor parameter and then call the
- * create_compositor. This will pass the data to the PDF 1.4
+ * composite. This will pass the data to the PDF 1.4
* transparency device.
*/
params.pdf14_op = group_type;
@@ -810,6 +810,18 @@ gs_push_pdf14trans_device(gs_gstate * pgs, bool is_pattern, bool retain,
if (depth < 0)
params.overprint_sim_push = true;
+ /* If we have an NCLR ICC profile, the extra spot colorants do not
+ get included in the transparency buffers. This is also true
+ for any extra colorant names listed, which go beyond the profile.
+ Finally, we could have a CMYK profile with colorants listed, that
+ go beyond CMYK. To detect, simply look at dev_profile->spotnames */
+ if (dev_profile->spotnames != NULL && dev_profile->spotnames->count > 4) {
+ /* Making an assumption here, that list is CMYK + extra. */
+ int delta = dev_profile->spotnames->count - 4;
+ params.num_spot_colors_int -= delta;
+ params.num_spot_colors -= delta;
+ }
+
/* If we happen to be in a situation where we are going out to a device
whose profile is CIELAB then we will need to make sure that we
do our blending in RGB and convert to CIELAB when we do the put_image
diff --git a/base/gstype42.c b/base/gstype42.c
index dab1b52c..3cc92213 100644
--- a/base/gstype42.c
+++ b/base/gstype42.c
@@ -748,7 +748,9 @@ mac_glyph_ordering_t MacintoshOrdering[] =
int
gs_type42_find_post_name(gs_font_type42 * pfont, gs_glyph glyph, gs_string *gname)
{
- int code = 0;
+ /* READ_SFNTS() uses "code" in the macro, so we need code2 to keep track here */
+ int code, code2 = gs_error_undefined;
+
if (pfont->FontType == ft_TrueType) {
if (pfont->data.post_offset != 0) {
byte ver[4];
@@ -760,6 +762,7 @@ gs_type42_find_post_name(gs_font_type42 * pfont, gs_glyph glyph, gs_string *gnam
if (glyph > 257) glyph = 0;
gname->data = (byte *)MacintoshOrdering[glyph].name;
gname->size = strlen(MacintoshOrdering[glyph].name);
+ code2 = 0;
}
else if (!memcmp(ver, ver20, 4)) {
byte val[2];
@@ -769,6 +772,7 @@ gs_type42_find_post_name(gs_font_type42 * pfont, gs_glyph glyph, gs_string *gnam
if (gind < 258) {
gname->data = (byte *)MacintoshOrdering[gind].name;
gname->size = strlen(MacintoshOrdering[gind].name);
+ code2 = 0;
}
else {
int i;
@@ -784,8 +788,8 @@ gs_type42_find_post_name(gs_font_type42 * pfont, gs_glyph glyph, gs_string *gnam
for (i = 0; i < numglyphs; i++) {
if (i == gind) {
READ_SFNTS(pfont, offs, 1, val);
- code = pfont->data.string_proc(pfont, offs + 1, (uint)val[0], (const byte **)&(gname->data));
- if (code > 0)
+ code2 = pfont->data.string_proc(pfont, offs + 1, (uint)val[0], (const byte **)&(gname->data));
+ if (code2 >= 0)
gname->size = val[0];
break;
}
@@ -795,24 +799,14 @@ gs_type42_find_post_name(gs_font_type42 * pfont, gs_glyph glyph, gs_string *gnam
}
}
}
- else {
- gname->data = (byte *)MacintoshOrdering[0].name;
- gname->size = strlen(MacintoshOrdering[0].name);
- }
}
}
- else {
- gname->data = (byte *)MacintoshOrdering[0].name;
- gname->size = strlen(MacintoshOrdering[0].name);
- }
- }
- else {
- gname->data = (byte *)MacintoshOrdering[0].name;
- gname->size = strlen(MacintoshOrdering[0].name);
}
}
else
- code = gs_note_error(gs_error_invalidfont);
+ code2 = gs_error_invalidfont;
+
+ if (code2 < 0) code = gs_note_error(code2);
return code;
}
diff --git a/base/gxacpath.c b/base/gxacpath.c
index 36ff8c3f..8c3bf349 100644
--- a/base/gxacpath.c
+++ b/base/gxacpath.c
@@ -55,80 +55,24 @@ RELOC_PTRS_WITH(device_cpath_accum_reloc_ptrs, gx_device_cpath_accum *pdev)
public_st_device_cpath_accum();
/* The device descriptor */
+static void
+cpath_accum_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, accum_open_device);
+ set_dev_proc(dev, close_device, accum_close);
+ set_dev_proc(dev, fill_rectangle, accum_fill_rectangle);
+ set_dev_proc(dev, get_clipping_box, accum_get_clipping_box);
+ set_dev_proc(dev, get_color_mapping_procs, gx_default_DevGray_get_color_mapping_procs);
+ set_dev_proc(dev, dev_spec_op, accum_dev_spec_op);
+}
+
+
/* Many of these procedures won't be called; they are set to NULL. */
static const gx_device_cpath_accum gs_cpath_accum_device =
-{std_device_std_body(gx_device_cpath_accum, 0, "clip list accumulator",
- 0, 0, 1, 1),
- {accum_open_device,
- NULL,
- NULL,
- NULL,
- accum_close,
- NULL,
- NULL,
- accum_fill_rectangle,
- NULL,
- gx_default_copy_mono,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- gx_default_fill_path,
- gx_default_stroke_path,
- gx_default_fill_mask,
- gx_default_fill_trapezoid,
- gx_default_fill_parallelogram,
- gx_default_fill_triangle,
- gx_default_draw_thin_line,
- gx_default_begin_image,
- gx_default_image_data,
- gx_default_end_image,
- NULL,
- NULL,
- accum_get_clipping_box,
- gx_default_begin_typed_image,
- NULL,
- NULL,
- NULL,
- NULL,
- gx_default_text_begin,
- gx_default_finish_copydevice,
- NULL, /* begin_transparency_group */
- NULL, /* end_transparency_group */
- NULL, /* begin_transparency_mask */
- NULL, /* end_transparency_mask */
- NULL, /* discard_transparency_layer */
- gx_default_DevGray_get_color_mapping_procs,
- NULL, /* get_color_comp_index */
- NULL, /* encode_color */
- NULL, /* decode_color */
- NULL, /* pattern_manage */
- NULL, /* fill_rectangle_hl_color */
- NULL, /* ics */
- NULL, /* fill_lin_tri */
- NULL, /* fill_lin_tri */
- NULL, /* fill_lin_tri */
- NULL, /* up_spot_eq_col */
- NULL, /* ret_dev */
- NULL, /* fillpage */
- NULL, /* push_transparency_state */
- NULL, /* pop_transparency_state */
- NULL, /* put_image */
- accum_dev_spec_op,
- NULL, /* copy_planes */
- NULL, /* get_profile */
- gx_default_set_graphics_type_tag
- }
+{std_device_std_body(gx_device_cpath_accum,
+ cpath_accum_initialize_device_procs,
+ "clip list accumulator",
+ 0, 0, 1, 1)
};
/* Start accumulating a clipping path. */
diff --git a/base/gxalpha.h b/base/gxalpha.h
index 4134d857..6403ca4e 100644
--- a/base/gxalpha.h
+++ b/base/gxalpha.h
@@ -35,7 +35,6 @@
* are the following:
* - alphaimage, if it doesn't assume premultiplication (see below)
* - readimage
- * - The cmap_rgb_alpha_ procedures in gxcmap.c
* - [color]image, if they are supposed to use currentalpha (see below)
* - The compositing code in gsalphac.c
*
diff --git a/base/gxblend.c b/base/gxblend.c
index a7c22332..b2e61a42 100644
--- a/base/gxblend.c
+++ b/base/gxblend.c
@@ -5242,7 +5242,7 @@ do_mark_fill_rectangle(gx_device * dev, int x, int y, int w, int h,
fn = mark_fill_rect_add_nospots_common;
} else
fn = mark_fill_rect_add_nospots;
- } else if (!additive && num_spots == 0 && num_comp == 4 && num_spots == 0 &&
+ } else if (!additive && num_spots == 0 && num_comp == 4 &&
first_blend_spot == 0 && blend_mode == BLEND_MODE_Normal &&
!overprint && tag_off == 0 && alpha_g_off == 0 && shape_off == 0)
fn = mark_fill_rect_sub4_fast;
diff --git a/base/gxblend.h b/base/gxblend.h
index a1f62e18..276bf8dd 100644
--- a/base/gxblend.h
+++ b/base/gxblend.h
@@ -367,20 +367,20 @@ gx_color_index pdf14_encode_color16_tag(gx_device *dev, const gx_color_value col
int pdf14_decode_color(gx_device * dev, gx_color_index color, gx_color_value * out);
int pdf14_decode_color16(gx_device * dev, gx_color_index color, gx_color_value * out);
-void pdf14_gray_cs_to_cmyk_cm(gx_device * dev, frac gray, frac out[]);
-void pdf14_rgb_cs_to_cmyk_cm(gx_device * dev, const gs_gstate *pgs,
+void pdf14_gray_cs_to_cmyk_cm(const gx_device * dev, frac gray, frac out[]);
+void pdf14_rgb_cs_to_cmyk_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[]);
-void pdf14_cmyk_cs_to_cmyk_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[]);
+void pdf14_cmyk_cs_to_cmyk_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[]);
-void pdf14_gray_cs_to_rgbspot_cm(gx_device * dev, frac gray, frac out[]);
-void pdf14_rgb_cs_to_rgbspot_cm(gx_device * dev, const gs_gstate *pgs,
+void pdf14_gray_cs_to_rgbspot_cm(const gx_device * dev, frac gray, frac out[]);
+void pdf14_rgb_cs_to_rgbspot_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[]);
-void pdf14_cmyk_cs_to_rgbspot_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[]);
+void pdf14_cmyk_cs_to_rgbspot_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[]);
-void pdf14_gray_cs_to_grayspot_cm(gx_device * dev, frac gray, frac out[]);
-void pdf14_rgb_cs_to_grayspot_cm(gx_device * dev, const gs_gstate *pgs,
+void pdf14_gray_cs_to_grayspot_cm(const gx_device * dev, frac gray, frac out[]);
+void pdf14_rgb_cs_to_grayspot_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[]);
-void pdf14_cmyk_cs_to_grayspot_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[]);
+void pdf14_cmyk_cs_to_grayspot_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[]);
void gx_build_blended_image_row(const byte *gs_restrict buf_ptr, int planestride,
int width, int num_comp, uint16_t bg, byte *gs_restrict linebuf);
diff --git a/base/gxblend1.c b/base/gxblend1.c
index c4f14e6c..3f8842a9 100644
--- a/base/gxblend1.c
+++ b/base/gxblend1.c
@@ -201,9 +201,9 @@ copy_extra_planes(byte *des_buf, pdf14_buf *des_info, byte *src_buf,
pdf14_buf *src_info, int width, int height)
{
/* alpha_g and shape do not copy */
- des_buf += des_info->planestride * ((des_info->has_shape ? 1 : 0) +
+ des_buf += des_info->planestride * (size_t)((des_info->has_shape ? 1 : 0) +
(des_info->has_alpha_g ? 1 : 0));
- src_buf += src_info->planestride * ((src_info->has_shape ? 1 : 0) +
+ src_buf += src_info->planestride * (size_t)((src_info->has_shape ? 1 : 0) +
(src_info->has_alpha_g ? 1 : 0));
/* tags plane does copy */
if (des_info->has_tags) {
@@ -261,20 +261,20 @@ pdf14_preserve_backdrop_cm(pdf14_buf *buf, cmm_profile_t *group_profile,
} else {
if (knockout_buff) {
buf_plane = buf->backdrop + ((x0 - buf->rect.p.x)<<deep) +
- (y0 - buf->rect.p.y) * buf->rowstride;
+ (y0 - buf->rect.p.y) * (size_t)buf->rowstride;
tos_plane = tos->backdrop + ((x0 - tos->rect.p.x)<<deep) +
- (y0 - tos->rect.p.y) * tos->rowstride;
- memset(buf->backdrop, 0, buf->n_chan * buf->planestride<<deep);
+ (y0 - tos->rect.p.y) * (size_t)tos->rowstride;
+ memset(buf->backdrop, 0, buf->n_chan * ((size_t)buf->planestride)<<deep);
} else {
buf_plane = buf->data + ((x0 - buf->rect.p.x)<<deep) +
- (y0 - buf->rect.p.y) * buf->rowstride;
+ (y0 - buf->rect.p.y) * (size_t)buf->rowstride;
tos_plane = tos->data + ((x0 - tos->rect.p.x)<<deep) +
- (y0 - tos->rect.p.y) * tos->rowstride;
+ (y0 - tos->rect.p.y) * (size_t)tos->rowstride;
/* First clear out everything. There are cases where the incoming buf
has a region outside the existing tos group. Need to check if this
is getting clipped in which case we need to fix the allocation of
the buffer to be smaller */
- memset(buf->data, 0, buf->n_planes * buf->planestride<<deep);
+ memset(buf->data, 0, buf->n_planes * ((size_t)buf->planestride)<<deep);
}
/* Set up the buffer descriptors. */
gsicc_init_buffer(&input_buff_desc, tos_profile->num_comps, 1<<deep, false,
@@ -291,8 +291,8 @@ pdf14_preserve_backdrop_cm(pdf14_buf *buf, cmm_profile_t *group_profile,
return gs_throw(gs_error_unknownerror, "ICC transform failed. Trans backdrop");
}
/* Copy the alpha data */
- buf_plane += buf->planestride * (buf->n_chan - 1);
- tos_plane += tos->planestride * (tos->n_chan - 1);
+ buf_plane += (buf->planestride) * (size_t)(buf->n_chan - 1);
+ tos_plane += (tos->planestride) * (size_t)(tos->n_chan - 1);
copy_plane_part(buf_plane, buf->rowstride, tos_plane, tos->rowstride, width,
height, deep);
buf_plane += buf->planestride;
@@ -304,7 +304,7 @@ pdf14_preserve_backdrop_cm(pdf14_buf *buf, cmm_profile_t *group_profile,
#if RAW_DUMP
if (x0 < x1 && y0 < y1) {
byte *buf_plane = buf->data + ((x0 - buf->rect.p.x)<<deep) +
- (y0 - buf->rect.p.y) * buf->rowstride;
+ (y0 - buf->rect.p.y) * (size_t)buf->rowstride;
dump_raw_buffer(dev->memory, y1 - y0, x1 - x0, buf->n_planes, buf->planestride,
buf->rowstride, "BackDropInit_CM", buf_plane, deep);
global_index++;
@@ -349,7 +349,7 @@ pdf14_preserve_backdrop(pdf14_buf *buf, pdf14_buf *tos, bool from_backdrop
y0 > buf->rect.p.y || y1 < buf->rect.q.y) {
/* FIXME: There is potential for more optimisation here,
* but I don't know how often we hit this case. */
- memset(buf_plane, 0, (size_t)n_planes * buf->planestride);
+ memset(buf_plane, 0, n_planes * (size_t)buf->planestride);
} else if (n_planes > tos->n_chan) {
/* The next planes are alpha_g, shape, tags. We need to clear
* alpha_g and shape, but don't need to clear the tag plane
@@ -358,12 +358,12 @@ pdf14_preserve_backdrop(pdf14_buf *buf, pdf14_buf *tos, bool from_backdrop
if (!from_backdrop && n_planes > tag_plane_num)
n_planes = tag_plane_num;
if (n_planes > tos->n_chan)
- memset(buf->data + (size_t)tos->n_chan * buf->planestride, 0,
- (size_t)(n_planes - tos->n_chan) * buf->planestride);
+ memset(buf->data + tos->n_chan * (size_t)buf->planestride, 0,
+ (n_planes - tos->n_chan) * (size_t)buf->planestride);
}
- buf_plane += (y0 - buf->rect.p.y) * buf->rowstride +
+ buf_plane += (y0 - buf->rect.p.y) * (size_t)buf->rowstride +
((x0 - buf->rect.p.x)<<deep);
- tos_plane += (y0 - tos->rect.p.y) * tos->rowstride +
+ tos_plane += (y0 - tos->rect.p.y) * (size_t)tos->rowstride +
((x0 - tos->rect.p.x)<<deep);
/* Color and alpha plane */
for (i = 0; i < tos->n_chan; i++) {
@@ -380,7 +380,7 @@ pdf14_preserve_backdrop(pdf14_buf *buf, pdf14_buf *tos, bool from_backdrop
byte *buf_plane = (from_backdrop ? buf->backdrop : buf->data);
if (buf_plane != NULL) {
buf_plane += ((x0 - buf->rect.p.x) << buf->deep) +
- (y0 - buf->rect.p.y) * buf->rowstride;
+ (y0 - buf->rect.p.y) * (size_t)buf->rowstride;
dump_raw_buffer(mem, y1 - y0, x1 - x0, buf->n_planes, buf->planestride,
buf->rowstride, "BackDropInit", buf_plane, buf->deep);
global_index++;
@@ -494,7 +494,7 @@ pdf14_decode_color16(gx_device * dev, gx_color_index color, gx_color_value * out
}
void
-pdf14_gray_cs_to_cmyk_cm(gx_device * dev, frac gray, frac out[])
+pdf14_gray_cs_to_cmyk_cm(const gx_device * dev, frac gray, frac out[])
{
uchar num_comp = dev->color_info.num_components;
@@ -506,7 +506,7 @@ pdf14_gray_cs_to_cmyk_cm(gx_device * dev, frac gray, frac out[])
/* These three must handle rgb + spot */
void
-pdf14_gray_cs_to_rgbspot_cm(gx_device * dev, frac gray, frac out[])
+pdf14_gray_cs_to_rgbspot_cm(const gx_device * dev, frac gray, frac out[])
{
uchar num_comp = dev->color_info.num_components;
@@ -516,7 +516,7 @@ pdf14_gray_cs_to_rgbspot_cm(gx_device * dev, frac gray, frac out[])
}
void
-pdf14_rgb_cs_to_rgbspot_cm(gx_device * dev, const gs_gstate *pgs,
+pdf14_rgb_cs_to_rgbspot_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
uchar num_comp = dev->color_info.num_components;
@@ -529,7 +529,7 @@ pdf14_rgb_cs_to_rgbspot_cm(gx_device * dev, const gs_gstate *pgs,
}
void
-pdf14_cmyk_cs_to_rgbspot_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+pdf14_cmyk_cs_to_rgbspot_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
uchar num_comp = dev->color_info.num_components;
@@ -540,7 +540,7 @@ pdf14_cmyk_cs_to_rgbspot_cm(gx_device * dev, frac c, frac m, frac y, frac k, fra
/* These three must handle gray + spot */
void
-pdf14_gray_cs_to_grayspot_cm(gx_device * dev, frac gray, frac out[])
+pdf14_gray_cs_to_grayspot_cm(const gx_device * dev, frac gray, frac out[])
{
uchar num_comp = dev->color_info.num_components;
@@ -550,7 +550,7 @@ pdf14_gray_cs_to_grayspot_cm(gx_device * dev, frac gray, frac out[])
}
void
-pdf14_rgb_cs_to_grayspot_cm(gx_device * dev, const gs_gstate *pgs,
+pdf14_rgb_cs_to_grayspot_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
uchar num_comp = dev->color_info.num_components;
@@ -561,7 +561,7 @@ pdf14_rgb_cs_to_grayspot_cm(gx_device * dev, const gs_gstate *pgs,
}
void
-pdf14_cmyk_cs_to_grayspot_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+pdf14_cmyk_cs_to_grayspot_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
uchar num_comp = dev->color_info.num_components;
@@ -586,7 +586,7 @@ pdf14_cmyk_cs_to_grayspot_cm(gx_device * dev, frac c, frac m, frac y, frac k, fr
* often they are { pop 0 }.
*/
void
-pdf14_rgb_cs_to_cmyk_cm(gx_device * dev, const gs_gstate *pgs,
+pdf14_rgb_cs_to_cmyk_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
uchar num_comp = dev->color_info.num_components;
@@ -607,7 +607,7 @@ pdf14_rgb_cs_to_cmyk_cm(gx_device * dev, const gs_gstate *pgs,
}
void
-pdf14_cmyk_cs_to_cmyk_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+pdf14_cmyk_cs_to_cmyk_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
uchar num_comp = dev->color_info.num_components;
@@ -624,14 +624,14 @@ pdf14_cmyk_cs_to_cmyk_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac o
static int
dump_planar_rgba(gs_memory_t *mem, const pdf14_buf *pbuf)
{
- int rowstride = pbuf->rowstride, planestride = pbuf->planestride;
+ size_t rowstride = pbuf->rowstride, planestride = pbuf->planestride;
int rowbytes = width << 2;
gs_int_rect rect = buf->rect;
int x1 = min(pdev->width, rect.q.x);
int y1 = min(pdev->height, rect.q.y);
int width = x1 - rect.p.x;
int height = y1 - rect.p.y;
- byte *buf_ptr = buf->data + rect.p.y * buf->rowstride + rect.p.x;
+ byte *buf_ptr = buf->data + rect.p.y * (size_t)buf->rowstride + rect.p.x;
byte *row = gs_malloc(mem, rowbytes, 1, "png raster buffer");
png_struct *png_ptr =
png_create_write_struct(PNG_LIBPNG_VER_STRING, NULL, NULL, NULL);
@@ -705,8 +705,8 @@ dump_planar_rgba(gs_memory_t *mem, const pdf14_buf *pbuf)
for (x = 0; x < width; ++x) {
row[(x << 2)] = buf_ptr[x];
row[(x << 2) + 1] = buf_ptr[x + planestride];
- row[(x << 2) + 2] = buf_ptr[x + planestride * 2];
- row[(x << 2) + 3] = buf_ptr[x + planestride * 3];
+ row[(x << 2) + 2] = buf_ptr[x + planestride * (size_t)2];
+ row[(x << 2) + 3] = buf_ptr[x + planestride * (size_t)3];
}
png_write_row(png_ptr, row);
buf_ptr += rowstride;
@@ -729,7 +729,7 @@ void
gx_build_blended_image_row(const byte *gs_restrict buf_ptr, int planestride,
int width, int num_comp, uint16_t bg, byte *gs_restrict linebuf)
{
- int inc = planestride * num_comp;
+ size_t inc = planestride * (size_t)num_comp;
buf_ptr += inc - 1;
for (; width > 0; width--) {
@@ -767,12 +767,12 @@ gx_build_blended_image_row16(const byte *gs_restrict buf_ptr_, int planestride,
int width, int num_comp, uint16_t bg, byte *gs_restrict linebuf)
{
const uint16_t *gs_restrict buf_ptr = (const uint16_t *)(const void *)buf_ptr_;
- int inc;
+ size_t inc;
/* Note that we read in in native endian and blend,
* then store out in big endian. */
planestride >>= 1; /* Array indexing, not byte indexing */
- inc = planestride * num_comp;
+ inc = planestride * (size_t)num_comp;
buf_ptr += inc - 1;
for (; width > 0; width--) {
/* composite RGBA (or CMYKA, etc.) pixel with over solid background */
@@ -822,18 +822,18 @@ gx_blend_image_buffer(byte *buf_ptr, int width, int height, int rowstride,
position = y * rowstride;
for (x = 0; x < width; x++) {
/* composite RGBA (or CMYKA, etc.) pixel with over solid background */
- a = buf_ptr[position + planestride * num_comp];
+ a = buf_ptr[position + planestride * (size_t)num_comp];
if ((a + 1) & 0xfe) {
a ^= 0xff;
for (comp_num = 0; comp_num < num_comp; comp_num++) {
- comp = buf_ptr[position + planestride * comp_num];
+ comp = buf_ptr[position + planestride * (size_t)comp_num];
tmp = ((bg - comp) * a) + 0x80;
comp += (tmp + (tmp >> 8)) >> 8;
- buf_ptr[position + planestride * comp_num] = comp;
+ buf_ptr[position + planestride * (size_t)comp_num] = comp;
}
} else if (a == 0) {
for (comp_num = 0; comp_num < num_comp; comp_num++) {
- buf_ptr[position + planestride * comp_num] = bg;
+ buf_ptr[position + planestride * (size_t)comp_num] = bg;
}
}
position+=1;
@@ -865,19 +865,19 @@ gx_blend_image_buffer16(byte *buf_ptr_, int width, int height, int rowstride,
position = y * rowstride;
for (x = 0; x < width; x++) {
/* composite RGBA (or CMYKA, etc.) pixel with over solid background */
- a = buf_ptr[position + planestride * num_comp];
+ a = buf_ptr[position + planestride * (size_t)num_comp];
if (a == 0) {
for (comp_num = 0; comp_num < num_comp; comp_num++) {
- buf_ptr[position + planestride * comp_num] = bebg;
+ buf_ptr[position + planestride * (size_t)comp_num] = bebg;
}
} else if (a == 0xffff) {
#if ARCH_IS_BIG_ENDIAN
#else
if (!keep_native) {
for (comp_num = 0; comp_num < num_comp; comp_num++) {
- comp = buf_ptr[position + planestride * comp_num];
- ((byte *)&buf_ptr[position + planestride * comp_num])[0] = comp >> 8;
- ((byte *)&buf_ptr[position + planestride * comp_num])[1] = comp;
+ comp = buf_ptr[position + planestride * (size_t)comp_num];
+ ((byte *)&buf_ptr[position + planestride * (size_t)comp_num])[0] = comp >> 8;
+ ((byte *)&buf_ptr[position + planestride * (size_t)comp_num])[1] = comp;
}
}
#endif
@@ -886,12 +886,12 @@ gx_blend_image_buffer16(byte *buf_ptr_, int width, int height, int rowstride,
a += a>>15; /* a is now 0 to 0x10000 */
a >>= 1; /* We can only use 15 bits as bg-comp has a sign bit we can't lose */
for (comp_num = 0; comp_num < num_comp; comp_num++) {
- comp = buf_ptr[position + planestride * comp_num];
+ comp = buf_ptr[position + planestride * (size_t)comp_num];
tmp = (((int)bg - comp) * a) + 0x4000;
comp += (tmp >> 15); /* Errors in bit 16 upwards will be ignored */
/* Store as big endian */
- ((byte *)&buf_ptr[position + planestride * comp_num])[0] = comp>>8;
- ((byte *)&buf_ptr[position + planestride * comp_num])[1] = comp;
+ ((byte *)&buf_ptr[position + planestride * (size_t)comp_num])[0] = comp>>8;
+ ((byte *)&buf_ptr[position + planestride * (size_t)comp_num])[1] = comp;
}
}
position+=1;
@@ -913,26 +913,26 @@ gx_blend_image_buffer8to16(const byte *buf_ptr_in, unsigned short *buf_ptr_out,
position = y * rowstride;
for (x = 0; x < width; x++) {
/* composite RGBA (or CMYKA, etc.) pixel with over solid background */
- a = buf_ptr_in[position + planestride * num_comp];
+ a = buf_ptr_in[position + planestride * (size_t)num_comp];
if (a == 0xff) {
for (comp_num = 0; comp_num < num_comp; comp_num++) {
- comp = buf_ptr_in[position + planestride * comp_num];
- buf_ptr_out[position + planestride * comp_num] = (comp + (comp << 8));
+ comp = buf_ptr_in[position + planestride * (size_t)comp_num];
+ buf_ptr_out[position + planestride * (size_t)comp_num] = (comp + (comp << 8));
}
} else if (a == 0) {
for (comp_num = 0; comp_num < num_comp; comp_num++) {
- buf_ptr_out[position + planestride * comp_num] = bg_out;
+ buf_ptr_out[position + planestride * (size_t)comp_num] = bg_out;
}
} else {
a ^= 0xff;
a += (a << 8);
for (comp_num = 0; comp_num < num_comp; comp_num++) {
- comp = buf_ptr_in[position + planestride * comp_num];
+ comp = buf_ptr_in[position + planestride * (size_t)comp_num];
comp += (comp << 8);
tmp = ((bg_out - comp) * a) + 0x8000;
comp += (tmp + (tmp >> 16)) >> 16;
comp = ((comp & 0xff) << 8) + ((comp & 0xff00) >> 8);
- buf_ptr_out[position + planestride * comp_num] = comp;
+ buf_ptr_out[position + planestride * (size_t)comp_num] = comp;
}
}
position += 1;
@@ -960,7 +960,7 @@ gx_put_blended_image_custom(gx_device *target, byte *buf_ptr_,
/* composite CMYKA, etc. pixel with over solid background */
#define GET16(v) (*((uint16_t *)(void *)&(v)))
- uint16_t a = GET16(buf_ptr[x + planestride * num_comp]);
+ uint16_t a = GET16(buf_ptr[x + planestride * (size_t)num_comp]);
if (a == 0) {
for (comp_num = 0; comp_num < num_comp; comp_num++) {
@@ -968,13 +968,13 @@ gx_put_blended_image_custom(gx_device *target, byte *buf_ptr_,
}
} else if (a == 0xffff) {
for (comp_num = 0; comp_num < num_comp; comp_num++) {
- comp = buf_ptr[x + planestride * comp_num];
+ comp = buf_ptr[x + planestride * (size_t)comp_num];
cv[comp_num] = comp;
}
} else {
a ^= 0xffff;
for (comp_num = 0; comp_num < num_comp; comp_num++) {
- comp = GET16(buf_ptr[x + planestride * comp_num]);
+ comp = GET16(buf_ptr[x + planestride * (size_t)comp_num]);
tmp = ((bg - comp) * a) + 0x8000;
cv[comp_num] = comp + ((tmp + (tmp>>16))>>16);
}
@@ -994,12 +994,12 @@ gx_put_blended_image_custom(gx_device *target, byte *buf_ptr_,
for (x = 0; x < width; x++) {
/* composite CMYKA, etc. pixel with over solid background */
- byte a = buf_ptr[x + planestride * num_comp];
+ byte a = buf_ptr[x + planestride * (size_t)num_comp];
if ((a + 1) & 0xfe) {
a ^= 0xff;
for (comp_num = 0; comp_num < num_comp; comp_num++) {
- comp = buf_ptr[x + planestride * comp_num];
+ comp = buf_ptr[x + planestride * (size_t)comp_num];
tmp = ((bg - comp) * a) + 0x80;
comp += tmp + (tmp >> 8);
cv[comp_num] = comp;
@@ -1010,7 +1010,7 @@ gx_put_blended_image_custom(gx_device *target, byte *buf_ptr_,
}
} else {
for (comp_num = 0; comp_num < num_comp; comp_num++) {
- comp = buf_ptr[x + planestride * comp_num];
+ comp = buf_ptr[x + planestride * (size_t)comp_num];
cv[comp_num] = (comp << 8) + comp;
}
}
@@ -1025,4 +1025,4 @@ gx_put_blended_image_custom(gx_device *target, byte *buf_ptr_,
}
}
return code;
-} \ No newline at end of file
+}
diff --git a/base/gxccman.c b/base/gxccman.c
index b31b6959..869fccdc 100644
--- a/base/gxccman.c
+++ b/base/gxccman.c
@@ -442,11 +442,12 @@ gs_purge_fm_pair(gs_font_dir * dir, cached_fm_pair * pair, int xfont_only)
pair->num_chars);
}
#endif
- { /* Free xvalues here because gx_add_fm_pair copied
- them into the stable memory dir->memory. */
+ if (uid_is_XUID(&pair->UID)) {
gs_free_object(dir->memory->stable_memory, pair->UID.xvalues, "gs_purge_fm_pair");
- pair->UID.xvalues = 0;
+ pair->UID.id = 0;
+ pair->UID.xvalues = NULL;
}
+
fm_pair_set_free(pair);
code = fm_pair_remove_from_list(dir, pair, &dir->fmcache.used);
if (code < 0)
@@ -549,7 +550,6 @@ gx_alloc_char_bits(gs_font_dir * dir, gx_device_memory * dev,
* as the conditions set up in gx_compute_text_oversampling
* preclude this function ever being called in a way that
* will cause this else clause to be executed. */
-#ifndef ENABLE_IMPOSSIBLE_ALPHA_CODE
static int THIS_NEVER_HAPPENS = 0;
if (THIS_NEVER_HAPPENS == 0) {
@@ -560,28 +560,6 @@ gx_alloc_char_bits(gs_font_dir * dir, gx_device_memory * dev,
THIS_NEVER_HAPPENS = 1;
}
return_error(gs_error_unknownerror);
-#else /* ENABLE_IMPOSSIBLE_ALPHA_CODE */
- /* Use an alpha-buffer device to compress as we go. */
- /* Preserve the reference counts, if any. */
- rc_header rc;
-
- rc = dev2->rc;
- gs_make_mem_alpha_device(dev2, dev2->memory, NULL, depth);
- dev2->rc = rc;
- dev2->width = iwidth >> log2_xscale;
- dev2->height = iheight >> log2_yscale;
- rc = dev->rc;
- gs_make_mem_abuf_device(dev, dev->memory, (gx_device *) dev2,
- pscale, depth, 0, false);
- dev->rc = rc;
- dev->width = iwidth;
- dev->height = 2 << log2_yscale;
- gdev_mem_bitmap_size(dev, &isize); /* Assume less than max_ulong */
- gdev_mem_bitmap_size(dev2, &isize2); /* Assume less than max_ulong */
- isize += isize2; /* Assume less than max_ulong */
- dev->HWResolution[0] = HWResolution0 * (1 >> log2_xscale);
- dev->HWResolution[1] = HWResolution1 * (1 >> log2_yscale);
-#endif /* ENABLE_IMPOSSIBLE_ALPHA_CODE */
}
icdsize = isize + sizeof_cached_char;
code = alloc_char(dir, icdsize, &cc);
diff --git a/base/gxchar.c b/base/gxchar.c
index 2332b70a..7704c91b 100644
--- a/base/gxchar.c
+++ b/base/gxchar.c
@@ -120,21 +120,21 @@ static const gs_text_enum_procs_t default_text_procs = {
int
gx_default_text_begin(gx_device * dev, gs_gstate * pgs1,
const gs_text_params_t * text, gs_font * font,
- gx_path * path, const gx_device_color * pdcolor,
const gx_clip_path * pcpath,
- gs_memory_t * mem, gs_text_enum_t ** ppte)
+ gs_text_enum_t ** ppte)
{
uint operation = text->operation;
bool propagate_charpath = (operation & TEXT_DO_DRAW) != 0;
int code;
gs_gstate *pgs = (gs_gstate *)pgs1;
gs_show_enum *penum;
+ gs_memory_t * mem = pgs->memory;
penum = gs_show_enum_alloc(mem, pgs, "gx_default_text_begin");
if (!penum)
return_error(gs_error_VMerror);
code = gs_text_enum_init((gs_text_enum_t *)penum, &default_text_procs,
- dev, pgs, text, font, path, pdcolor, pcpath, mem);
+ dev, pgs, text, font, pcpath, mem);
if (code < 0) {
gs_free_object(mem, penum, "gx_default_text_begin");
return code;
@@ -210,7 +210,7 @@ gs_text_count_chars(gs_gstate * pgs, gs_text_params_t *text, gs_memory_t * mem)
code = gs_text_enum_init(&tenum, &default_text_procs,
NULL, NULL, text, pgs->root_font,
- NULL, NULL, NULL, mem);
+ NULL, mem);
if (code < 0)
return code;
while ((code = (*next_proc)(&tenum, &tchr, &tglyph)) != 2) {
diff --git a/base/gxcht.c b/base/gxcht.c
index dc1064a1..ed9868d3 100644
--- a/base/gxcht.c
+++ b/base/gxcht.c
@@ -85,7 +85,6 @@ gx_dc_ht_colored_save_dc(const gx_device_color * pdevc,
memcpy( psdc->colors.colored.c_level,
pdevc->colors.colored.c_level,
sizeof(psdc->colors.colored.c_base) );
- psdc->colors.colored.alpha = pdevc->colors.colored.alpha;
psdc->phase = pdevc->phase;
}
@@ -105,7 +104,6 @@ gx_dc_ht_colored_equal(const gx_device_color * pdevc1,
if (pdevc2->type != pdevc1->type ||
pdevc1->colors.colored.c_ht != pdevc2->colors.colored.c_ht ||
- pdevc1->colors.colored.alpha != pdevc2->colors.colored.alpha ||
pdevc1->phase.x != pdevc2->phase.x ||
pdevc1->phase.y != pdevc2->phase.y ||
num_comp != pdevc2->colors.colored.num_components
@@ -133,8 +131,6 @@ gx_dc_ht_colored_equal(const gx_device_color * pdevc1,
*/
static const int dc_ht_colored_has_base = 0x01;
static const int dc_ht_colored_has_level = 0x02;
-static const int dc_ht_colored_has_alpha = 0x04;
-static const int dc_ht_colored_alpha_is_max = 0x08;
/*
* Serialize a device color that uses a traditional colored halftone.
@@ -196,7 +192,6 @@ gx_dc_ht_colored_write(
int num_comps = dev->color_info.num_components;
int depth = dev->color_info.depth;
gx_color_index plane_mask = pdevc->colors.colored.plane_mask;
- gx_color_value alpha = pdevc->colors.colored.alpha;
const gx_device_color_saved * psdc = psdc0;
byte * pdata0 = pdata;
@@ -248,15 +243,6 @@ gx_dc_ht_colored_write(
}
}
- if (psdc == 0 || alpha != psdc->colors.colored.alpha) {
- if (alpha == gx_max_color_value)
- flag_bits |= dc_ht_colored_alpha_is_max;
- else {
- flag_bits |= dc_ht_colored_has_alpha;
- req_size += enc_u_sizew(alpha);
- }
- }
-
/* see if there is anything to do */
if (flag_bits == 0) {
*psize = 0;
@@ -313,9 +299,6 @@ gx_dc_ht_colored_write(
}
}
- if ((flag_bits & dc_ht_colored_has_alpha) != 0)
- enc_u_putw(alpha, pdata);
-
*psize = pdata - pdata0;
return 0;
}
@@ -379,7 +362,7 @@ gx_dc_ht_colored_read(
/* the number of components is determined by the color model */
devc.colors.colored.num_components = num_comps;
- devc.colors.colored.c_ht = pgs->dev_ht;
+ devc.colors.colored.c_ht = pgs->dev_ht[HT_OBJTYPE_DEFAULT];
/*
* Verify that we have at least the flag bits. For performance
@@ -447,23 +430,12 @@ gx_dc_ht_colored_read(
size -= pdata - pdata_start;
}
- if ((flag_bits & dc_ht_colored_alpha_is_max) != 0)
- devc.colors.colored.alpha = gx_max_color_value;
- else if ((flag_bits & dc_ht_colored_has_alpha) != 0) {
- const byte * pdata_start = pdata;
-
- if (size < 1)
- return_error(gs_error_rangecheck);
- enc_u_getw(devc.colors.colored.alpha, pdata);
- size -= pdata - pdata_start;
- }
-
/* set the phase as required (select value is arbitrary) */
color_set_phase_mod( &devc,
pgs->screen_phase[0].x,
pgs->screen_phase[0].y,
- pgs->dev_ht->lcm_width,
- pgs->dev_ht->lcm_height );
+ pgs->dev_ht[HT_OBJTYPE_DEFAULT]->lcm_width,
+ pgs->dev_ht[HT_OBJTYPE_DEFAULT]->lcm_height );
/* everything looks OK */
*pdevc = devc;
@@ -671,8 +643,8 @@ gx_dc_ht_colored_fill_rectangle(const gx_device_color * pdevc,
/*
* If the LCM of the plane cell sizes is smaller than the rectangle
- * being filled, compute a single tile and let tile_rectangle do the
- * replication.
+ * being filled, compute a single tile and let strip_tile_rectangle
+ * do the replication.
*/
if ((w > lw || h > lh) &&
(raster = bitmap_raster(lw * depth)) <= tile_bytes / lh
@@ -703,18 +675,7 @@ gx_dc_ht_colored_fill_rectangle(const gx_device_color * pdevc,
gx_no_color_index,
pdevc->phase.x,
pdevc->phase.y);
- if (source->planar_height == 0)
- return (*dev_proc(dev, strip_copy_rop))
- (dev,
- source->sdata + (y - origy) * source->sraster,
- source->sourcex + (x - origx),
- source->sraster, source->id,
- (source->use_scolors ? source->scolors : NULL),
- &tiles, NULL,
- x, y, w, h,
- pdevc->phase.x, pdevc->phase.y, lop);
- else
- return (*dev_proc(dev, strip_copy_rop2))
+ return (*dev_proc(dev, strip_copy_rop2))
(dev,
source->sdata + (y - origy) * source->sraster,
source->sourcex + (x - origx),
@@ -779,16 +740,7 @@ fit: /* Now the tile will definitely fit. */
x, cy, dw, ch);
} else {
tiles.rep_height = tiles.size.y = ch;
- if (source->planar_height == 0)
- code = (*dev_proc(dev, strip_copy_rop))
- (dev, source->sdata + source->sraster * (cy-origy),
- source->sourcex + (x - origx),
- source->sraster,
- source->id,
- (source->use_scolors ? source->scolors : NULL),
- &tiles, NULL, x, cy, dw, ch, 0, 0, lop);
- else
- code = (*dev_proc(dev, strip_copy_rop2))
+ code = (*dev_proc(dev, strip_copy_rop2))
(dev, source->sdata + source->sraster * (cy-origy),
source->sourcex + (x - origx),
source->sraster,
@@ -891,9 +843,6 @@ set_ht_colors_le_4(color_values_pair_t *pvp /* only used internally */,
set_plane_color(2, pvp, pdc, sbits, caches, max_color, invert);
}
if (nplanes == 3) {
- gx_color_value alpha = pdc->colors.colored.alpha;
-
- if (alpha == gx_max_color_value) {
#define M(i)\
cvalues[0] = pvp->values[(i) & 1][0];\
cvalues[1] = pvp->values[((i) & 2) >> 1][1];\
@@ -902,14 +851,6 @@ set_ht_colors_le_4(color_values_pair_t *pvp /* only used internally */,
M(0); M(1); M(2); M(3); M(4); M(5); M(6); M(7);
#undef M
- } else {
-#define M(i)\
- colors[i] = dev_proc(dev, map_rgb_alpha_color)(dev, pvp->values[(i) & 1][0],\
- pvp->values[((i) & 2) >> 1][1],\
- pvp->values[(i) >> 2][2], alpha)
- M(0); M(1); M(2); M(3); M(4); M(5); M(6); M(7);
-#undef M
- }
} else if (nplanes > 3){
set_plane_color(3, pvp, pdc, sbits, caches, max_color, invert);
if (nplanes > 4) {
diff --git a/base/gxcldev.h b/base/gxcldev.h
index 290c6cda..012c5bf6 100644
--- a/base/gxcldev.h
+++ b/base/gxcldev.h
@@ -316,7 +316,6 @@ dev_proc_copy_color(clist_copy_color);
dev_proc_copy_alpha(clist_copy_alpha);
dev_proc_strip_tile_rectangle(clist_strip_tile_rectangle);
dev_proc_strip_tile_rect_devn(clist_strip_tile_rect_devn);
-dev_proc_strip_copy_rop(clist_strip_copy_rop);
dev_proc_strip_copy_rop2(clist_strip_copy_rop2);
dev_proc_fill_trapezoid(clist_fill_trapezoid);
dev_proc_fill_linear_color_trapezoid(clist_fill_linear_color_trapezoid);
@@ -330,7 +329,7 @@ dev_proc_process_page(clist_process_page);
/* In gxclimag.c */
dev_proc_fill_mask(clist_fill_mask);
dev_proc_begin_typed_image(clist_begin_typed_image);
-dev_proc_create_compositor(clist_create_compositor);
+dev_proc_composite(clist_composite);
/* In gxclread.c */
dev_proc_get_bits_rectangle(clist_get_bits_rectangle);
diff --git a/base/gxclimag.c b/base/gxclimag.c
index d638bea6..3958e372 100644
--- a/base/gxclimag.c
+++ b/base/gxclimag.c
@@ -1287,7 +1287,7 @@ clist_image_end_image(gx_image_enum_common_t * info, bool draw_last)
/* Create a compositor device. */
int
-clist_create_compositor(gx_device * dev,
+clist_composite(gx_device * dev,
gx_device ** pcdev, const gs_composite_t * pcte,
gs_gstate * pgs, gs_memory_t * mem, gx_device *cldev)
{
@@ -1375,7 +1375,7 @@ clist_create_compositor(gx_device * dev,
return code;
/* insert the command and compositor identifier */
- dp[1] = cmd_opv_ext_create_compositor;
+ dp[1] = cmd_opv_ext_composite;
dp[2] = pcte->type->comp_id;
/* serialize the remainder of the compositor */
@@ -1416,7 +1416,7 @@ clist_create_compositor(gx_device * dev,
code = set_cmd_put_op(&dp, cdev, re.pcls, cmd_opv_extend, size);
if (code >= 0) {
size_dummy = size;
- dp[1] = cmd_opv_ext_create_compositor;
+ dp[1] = cmd_opv_ext_composite;
dp[2] = pcte->type->comp_id;
code = pcte->type->procs.write(pcte, dp + 3, &size_dummy, cdev);
}
@@ -1585,7 +1585,7 @@ cmd_put_color_mapping(gx_device_clist_writer * cldev,
const gs_gstate * pgs)
{
int code;
- const gx_device_halftone *pdht = pgs->dev_ht;
+ const gx_device_halftone *pdht = gx_select_dev_ht(pgs);
/* Put out the halftone, if present. */
if (pdht && pdht->id != cldev->device_halftone_id) {
diff --git a/base/gxclip.c b/base/gxclip.c
index 0b7939ef..3cad4695 100644
--- a/base/gxclip.c
+++ b/base/gxclip.c
@@ -41,7 +41,6 @@ static dev_proc_copy_alpha_hl_color(clip_copy_alpha_hl_color);
static dev_proc_fill_mask(clip_fill_mask);
static dev_proc_strip_tile_rectangle(clip_strip_tile_rectangle);
static dev_proc_strip_tile_rect_devn(clip_strip_tile_rect_devn);
-static dev_proc_strip_copy_rop(clip_strip_copy_rop);
static dev_proc_strip_copy_rop2(clip_strip_copy_rop2);
static dev_proc_get_clipping_box(clip_get_clipping_box);
static dev_proc_get_bits_rectangle(clip_get_bits_rectangle);
@@ -50,85 +49,68 @@ static dev_proc_transform_pixel_region(clip_transform_pixel_region);
static dev_proc_fill_stroke_path(clip_fill_stroke_path);
/* The device descriptor. */
+static void
+clipper_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, clip_open);
+ set_dev_proc(dev, get_initial_matrix, gx_forward_get_initial_matrix);
+ set_dev_proc(dev, map_rgb_color, gx_forward_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_forward_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, clip_fill_rectangle);
+ set_dev_proc(dev, copy_mono, clip_copy_mono);
+ set_dev_proc(dev, copy_color, clip_copy_color);
+ set_dev_proc(dev, get_params, gx_forward_get_params);
+ set_dev_proc(dev, put_params, gx_forward_put_params);
+ set_dev_proc(dev, map_cmyk_color, gx_forward_map_cmyk_color);
+ set_dev_proc(dev, get_page_device, gx_forward_get_page_device);
+ set_dev_proc(dev, get_alpha_bits, gx_forward_get_alpha_bits);
+ set_dev_proc(dev, copy_alpha, clip_copy_alpha);
+ set_dev_proc(dev, fill_path, clip_fill_path);
+ set_dev_proc(dev, fill_mask, clip_fill_mask);
+ set_dev_proc(dev, strip_tile_rectangle, clip_strip_tile_rectangle);
+ set_dev_proc(dev, get_clipping_box, clip_get_clipping_box);
+ set_dev_proc(dev, get_bits_rectangle, clip_get_bits_rectangle);
+ set_dev_proc(dev, composite, gx_forward_composite);
+ set_dev_proc(dev, get_hardware_params, gx_forward_get_hardware_params);
+ set_dev_proc(dev, get_color_mapping_procs, gx_forward_get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, gx_forward_get_color_comp_index);
+ set_dev_proc(dev, encode_color, gx_forward_encode_color);
+ set_dev_proc(dev, decode_color, gx_forward_decode_color);
+ set_dev_proc(dev, fill_rectangle_hl_color, clip_fill_rectangle_hl_color);
+ set_dev_proc(dev, include_color_space, gx_forward_include_color_space);
+ set_dev_proc(dev, update_spot_equivalent_colors, gx_forward_update_spot_equivalent_colors);
+ set_dev_proc(dev, ret_devn_params, gx_forward_ret_devn_params);
+ set_dev_proc(dev, fillpage, gx_forward_fillpage);
+ set_dev_proc(dev, dev_spec_op, gx_forward_dev_spec_op);
+ set_dev_proc(dev, copy_planes, clip_copy_planes);
+ set_dev_proc(dev, get_profile, gx_forward_get_profile);
+ set_dev_proc(dev, set_graphics_type_tag, gx_forward_set_graphics_type_tag);
+ set_dev_proc(dev, strip_copy_rop2, clip_strip_copy_rop2);
+ set_dev_proc(dev, strip_tile_rect_devn, clip_strip_tile_rect_devn);
+ set_dev_proc(dev, copy_alpha_hl_color, clip_copy_alpha_hl_color);
+ set_dev_proc(dev, transform_pixel_region, clip_transform_pixel_region);
+ set_dev_proc(dev, fill_stroke_path, clip_fill_stroke_path);
+ /* Ideally the following defaults would be filled in for us, but that
+ * doesn't work at the moment. */
+ set_dev_proc(dev, sync_output, gx_default_sync_output);
+ set_dev_proc(dev, output_page, gx_default_output_page);
+ set_dev_proc(dev, close_device, gx_default_close_device);
+ set_dev_proc(dev, draw_thin_line, gx_default_draw_thin_line);
+ set_dev_proc(dev, stroke_path, gx_default_stroke_path);
+ set_dev_proc(dev, fill_trapezoid, gx_default_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, gx_default_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, gx_default_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, gx_default_draw_thin_line);
+ set_dev_proc(dev, begin_typed_image, gx_default_begin_typed_image);
+ set_dev_proc(dev, text_begin, gx_default_text_begin);
+ set_dev_proc(dev, fill_linear_color_scanline, gx_default_fill_linear_color_scanline);
+ set_dev_proc(dev, fill_linear_color_trapezoid, gx_default_fill_linear_color_trapezoid);
+ set_dev_proc(dev, fill_linear_color_triangle, gx_default_fill_linear_color_triangle);
+}
static const gx_device_clip gs_clip_device =
-{std_device_std_body(gx_device_clip, 0, "clipper",
- 0, 0, 1, 1),
- {clip_open,
- gx_forward_get_initial_matrix,
- gx_default_sync_output,
- gx_default_output_page,
- gx_default_close_device,
- gx_forward_map_rgb_color,
- gx_forward_map_color_rgb,
- clip_fill_rectangle,
- gx_default_tile_rectangle,
- clip_copy_mono,
- clip_copy_color,
- gx_default_draw_line,
- gx_default_get_bits,
- gx_forward_get_params,
- gx_forward_put_params,
- gx_forward_map_cmyk_color,
- gx_forward_get_xfont_procs,
- gx_forward_get_xfont_device,
- gx_forward_map_rgb_alpha_color,
- gx_forward_get_page_device,
- gx_forward_get_alpha_bits,
- clip_copy_alpha,
- gx_forward_get_band,
- gx_default_copy_rop,
- clip_fill_path,
- gx_default_stroke_path,
- clip_fill_mask,
- gx_default_fill_trapezoid,
- gx_default_fill_parallelogram,
- gx_default_fill_triangle,
- gx_default_draw_thin_line,
- gx_default_begin_image,
- gx_default_image_data,
- gx_default_end_image,
- clip_strip_tile_rectangle,
- clip_strip_copy_rop,
- clip_get_clipping_box,
- gx_default_begin_typed_image,
- clip_get_bits_rectangle,
- gx_forward_map_color_rgb_alpha,
- gx_forward_create_compositor,
- gx_forward_get_hardware_params,
- gx_default_text_begin,
- gx_default_finish_copydevice,
- NULL, /* begin_transparency_group */
- NULL, /* end_transparency_group */
- NULL, /* begin_transparency_mask */
- NULL, /* end_transparency_mask */
- NULL, /* discard_transparency_layer */
- gx_forward_get_color_mapping_procs,
- gx_forward_get_color_comp_index,
- gx_forward_encode_color,
- gx_forward_decode_color,
- NULL,
- clip_fill_rectangle_hl_color,
- gx_forward_include_color_space,
- gx_default_fill_linear_color_scanline,
- gx_default_fill_linear_color_trapezoid,
- gx_default_fill_linear_color_triangle,
- gx_forward_update_spot_equivalent_colors,
- gx_forward_ret_devn_params,
- gx_forward_fillpage,
- NULL, /* push_transparency_state */
- NULL, /* pop_transparency_state */
- NULL, /* put_image */
- gx_forward_dev_spec_op,
- clip_copy_planes, /* copy planes */
- gx_forward_get_profile,
- gx_forward_set_graphics_type_tag,
- clip_strip_copy_rop2,
- clip_strip_tile_rect_devn,
- clip_copy_alpha_hl_color,
- NULL, /* process_page */
- clip_transform_pixel_region,
- clip_fill_stroke_path,
- }
+{std_device_std_body(gx_device_clip,
+ clipper_initialize_device_procs, "clipper",
+ 0, 0, 1, 1)
};
/* Make a clipping device. */
@@ -197,10 +179,14 @@ gx_make_clip_device_on_stack_if_needed(gx_device_clip * dev, const gx_clip_path
return (gx_device *)dev;
}
void
-gx_make_clip_device_in_heap(gx_device_clip * dev, const gx_clip_path *pcpath, gx_device *target,
- gs_memory_t *mem)
+gx_make_clip_device_in_heap(gx_device_clip *dev,
+ const gx_clip_path *pcpath,
+ gx_device *target,
+ gs_memory_t *mem)
{
- gx_device_init((gx_device *)dev, (const gx_device *)&gs_clip_device, mem, true);
+ /* Can never fail */
+ (void)gx_device_init((gx_device *)dev,
+ (const gx_device *)&gs_clip_device, mem, true);
dev->list = *gx_cpath_list(pcpath);
dev->translation.x = 0;
dev->translation.y = 0;
@@ -212,7 +198,8 @@ gx_make_clip_device_in_heap(gx_device_clip * dev, const gx_clip_path *pcpath, gx
dev->is_planar = target->is_planar;
gx_device_set_target((gx_device_forward *)dev, target);
gx_device_retain((gx_device *)dev, true); /* will free explicitly */
- (*dev_proc(dev, open_device)) ((gx_device *)dev);
+ /* Can never fail */
+ (void)(*dev_proc(dev, open_device)) ((gx_device *)dev);
}
/* Define debugging statistics for the clipping loops. */
#if defined(DEBUG) && !defined(GS_THREADSAFE)
@@ -1346,35 +1333,6 @@ clip_strip_tile_rectangle(gx_device * dev, const gx_strip_bitmap * tiles,
/* Copy a rectangle with RasterOp and strip texture. */
int
-clip_call_strip_copy_rop(clip_callback_data_t * pccd, int xc, int yc, int xec, int yec)
-{
- return (*dev_proc(pccd->tdev, strip_copy_rop))
- (pccd->tdev, pccd->data + (yc - pccd->y) * pccd->raster,
- pccd->sourcex + xc - pccd->x, pccd->raster, gx_no_bitmap_id,
- pccd->scolors, pccd->textures, pccd->tcolors,
- xc, yc, xec - xc, yec - yc, pccd->phase.x, pccd->phase.y,
- pccd->lop);
-}
-static int
-clip_strip_copy_rop(gx_device * dev,
- const byte * sdata, int sourcex, uint raster, gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_strip_bitmap * textures, const gx_color_index * tcolors,
- int x, int y, int w, int h,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- gx_device_clip *rdev = (gx_device_clip *) dev;
- clip_callback_data_t ccdata;
-
- ccdata.data = sdata, ccdata.sourcex = sourcex, ccdata.raster = raster;
- ccdata.scolors = scolors, ccdata.textures = textures,
- ccdata.tcolors = tcolors;
- ccdata.phase.x = phase_x, ccdata.phase.y = phase_y, ccdata.lop = lop;
- return clip_enumerate(rdev, x, y, w, h, clip_call_strip_copy_rop, &ccdata);
-}
-
-/* Copy a rectangle with RasterOp and strip texture. */
-int
clip_call_strip_copy_rop2(clip_callback_data_t * pccd, int xc, int yc, int xec, int yec)
{
return (*dev_proc(pccd->tdev, strip_copy_rop2))
@@ -1479,29 +1437,17 @@ clip_get_clipping_box(gx_device * dev, gs_fixed_rect * pbox)
/* Get bits back from the device. */
static int
clip_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
- gs_get_bits_params_t * params, gs_int_rect ** unread)
+ gs_get_bits_params_t * params)
{
gx_device_clip *rdev = (gx_device_clip *) dev;
gx_device *tdev = rdev->target;
int tx = rdev->translation.x, ty = rdev->translation.y;
gs_int_rect rect;
- int code;
rect.p.x = prect->p.x - tx, rect.p.y = prect->p.y - ty;
rect.q.x = prect->q.x - tx, rect.q.y = prect->q.y - ty;
- code = (*dev_proc(tdev, get_bits_rectangle))
- (tdev, &rect, params, unread);
- if (code > 0) {
- /* Adjust unread rectangle coordinates */
- gs_int_rect *list = *unread;
- int i;
-
- for (i = 0; i < code; ++list, ++i) {
- list->p.x += tx, list->p.y += ty;
- list->q.x += tx, list->q.y += ty;
- }
- }
- return code;
+ return (*dev_proc(tdev, get_bits_rectangle))
+ (tdev, &rect, params);
}
static int
diff --git a/base/gxclip.h b/base/gxclip.h
index 5d44bc00..f071864f 100644
--- a/base/gxclip.h
+++ b/base/gxclip.h
@@ -78,8 +78,6 @@ int
int xc, int yc, int xec, int yec),
clip_call_strip_tile_rect_devn(clip_callback_data_t * pccd,
int xc, int yc, int xec, int yec),
- clip_call_strip_copy_rop(clip_callback_data_t * pccd,
- int xc, int yc, int xec, int yec),
clip_call_strip_copy_rop2(clip_callback_data_t * pccd,
int xc, int yc, int xec, int yec),
clip_call_fill_rectangle_hl_color(clip_callback_data_t * pccd,
diff --git a/base/gxclip2.c b/base/gxclip2.c
index 38e79fab..ef3eb5b3 100644
--- a/base/gxclip2.c
+++ b/base/gxclip2.c
@@ -36,86 +36,69 @@ static dev_proc_copy_color(tile_clip_copy_color);
static dev_proc_copy_planes(tile_clip_copy_planes);
static dev_proc_copy_alpha(tile_clip_copy_alpha);
static dev_proc_copy_alpha_hl_color(tile_clip_copy_alpha_hl_color);
-static dev_proc_strip_copy_rop(tile_clip_strip_copy_rop);
static dev_proc_strip_copy_rop2(tile_clip_strip_copy_rop2);
/* The device descriptor. */
+static void
+tile_clipper_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, get_initial_matrix, gx_forward_get_initial_matrix);
+ set_dev_proc(dev, map_rgb_color, gx_forward_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_forward_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, tile_clip_fill_rectangle);
+ set_dev_proc(dev, copy_mono, tile_clip_copy_mono);
+ set_dev_proc(dev, copy_color, tile_clip_copy_color);
+ set_dev_proc(dev, get_params, gx_forward_get_params);
+ set_dev_proc(dev, put_params, gx_forward_put_params);
+ set_dev_proc(dev, map_cmyk_color, gx_forward_map_cmyk_color);
+ set_dev_proc(dev, get_page_device, gx_forward_get_page_device);
+ set_dev_proc(dev, get_alpha_bits, gx_forward_get_alpha_bits);
+ set_dev_proc(dev, copy_alpha, tile_clip_copy_alpha);
+ set_dev_proc(dev, get_clipping_box, gx_forward_get_clipping_box);
+ set_dev_proc(dev, get_bits_rectangle, gx_forward_get_bits_rectangle);
+ set_dev_proc(dev, composite, gx_no_composite);
+ set_dev_proc(dev, get_hardware_params, gx_forward_get_hardware_params);
+ set_dev_proc(dev, get_color_mapping_procs, gx_forward_get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, gx_forward_get_color_comp_index);
+ set_dev_proc(dev, encode_color, gx_forward_encode_color);
+ set_dev_proc(dev, decode_color, gx_forward_decode_color);
+ set_dev_proc(dev, fill_rectangle_hl_color, tile_clip_fill_rectangle_hl_color);
+ set_dev_proc(dev, include_color_space, gx_forward_include_color_space);
+ set_dev_proc(dev, fill_linear_color_scanline, gx_forward_fill_linear_color_scanline);
+ set_dev_proc(dev, fill_linear_color_trapezoid, gx_forward_fill_linear_color_trapezoid);
+ set_dev_proc(dev, fill_linear_color_triangle, gx_forward_fill_linear_color_triangle);
+ set_dev_proc(dev, update_spot_equivalent_colors, gx_forward_update_spot_equivalent_colors);
+ set_dev_proc(dev, ret_devn_params, gx_forward_ret_devn_params);
+ set_dev_proc(dev, fillpage, gx_forward_fillpage);
+ set_dev_proc(dev, dev_spec_op, gx_forward_dev_spec_op);
+ set_dev_proc(dev, copy_planes, tile_clip_copy_planes);
+ set_dev_proc(dev, strip_copy_rop2, tile_clip_strip_copy_rop2);
+ set_dev_proc(dev, copy_alpha_hl_color, tile_clip_copy_alpha_hl_color);
+
+ /* Ideally the following defaults would be set up for us, but this
+ * does not currently work. */
+ set_dev_proc(dev, open_device, gx_default_open_device);
+ set_dev_proc(dev, sync_output, gx_default_sync_output);
+ set_dev_proc(dev, output_page, gx_default_output_page);
+ set_dev_proc(dev, close_device, gx_default_close_device);
+ set_dev_proc(dev, fill_path, gx_default_fill_path);
+ set_dev_proc(dev, stroke_path, gx_default_stroke_path);
+ set_dev_proc(dev, fill_mask, gx_default_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, gx_default_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, gx_default_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, gx_default_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, gx_default_draw_thin_line);
+ set_dev_proc(dev, strip_tile_rectangle, gx_default_strip_tile_rectangle);
+ set_dev_proc(dev, begin_typed_image, gx_default_begin_typed_image);
+ set_dev_proc(dev, text_begin, gx_default_text_begin);
+ set_dev_proc(dev, strip_tile_rect_devn, gx_default_strip_tile_rect_devn);
+}
+
static const gx_device_tile_clip gs_tile_clip_device =
-{std_device_std_body_open(gx_device_tile_clip, 0, "tile clipper",
- 0, 0, 1, 1),
- {gx_default_open_device,
- gx_forward_get_initial_matrix,
- gx_default_sync_output,
- gx_default_output_page,
- gx_default_close_device,
- gx_forward_map_rgb_color,
- gx_forward_map_color_rgb,
- tile_clip_fill_rectangle,
- gx_default_tile_rectangle,
- tile_clip_copy_mono,
- tile_clip_copy_color,
- gx_default_draw_line,
- gx_forward_get_bits,
- gx_forward_get_params,
- gx_forward_put_params,
- gx_forward_map_cmyk_color,
- gx_forward_get_xfont_procs,
- gx_forward_get_xfont_device,
- gx_forward_map_rgb_alpha_color,
- gx_forward_get_page_device,
- gx_forward_get_alpha_bits,
- tile_clip_copy_alpha,
- gx_forward_get_band,
- gx_default_copy_rop,
- gx_default_fill_path,
- gx_default_stroke_path,
- gx_default_fill_mask,
- gx_default_fill_trapezoid,
- gx_default_fill_parallelogram,
- gx_default_fill_triangle,
- gx_default_draw_thin_line,
- gx_default_begin_image,
- gx_default_image_data,
- gx_default_end_image,
- gx_default_strip_tile_rectangle,
- tile_clip_strip_copy_rop,
- gx_forward_get_clipping_box,
- gx_default_begin_typed_image,
- gx_forward_get_bits_rectangle,
- gx_forward_map_color_rgb_alpha,
- gx_no_create_compositor,
- gx_forward_get_hardware_params,
- gx_default_text_begin,
- gx_default_finish_copydevice,
- NULL, /* begin_transparency_group */
- NULL, /* end_transparency_group */
- NULL, /* begin_transparency_mask */
- NULL, /* end_transparency_mask */
- NULL, /* discard_transparency_layer */
- gx_forward_get_color_mapping_procs,
- gx_forward_get_color_comp_index,
- gx_forward_encode_color,
- gx_forward_decode_color,
- NULL, /* pattern_manage */
- tile_clip_fill_rectangle_hl_color,
- gx_forward_include_color_space,
- gx_forward_fill_linear_color_scanline,
- gx_forward_fill_linear_color_trapezoid,
- gx_forward_fill_linear_color_triangle,
- gx_forward_update_spot_equivalent_colors,
- gx_forward_ret_devn_params,
- gx_forward_fillpage,
- NULL, /* push_transparency_state */
- NULL, /* pop_transparency_state */
- NULL, /* put_image */
- gx_forward_dev_spec_op,
- tile_clip_copy_planes,
- NULL, /* get_profile */
- NULL, /* set_graphics_type_tag */
- tile_clip_strip_copy_rop2,
- gx_default_strip_tile_rect_devn,
- tile_clip_copy_alpha_hl_color
- }
+{std_device_std_body_open(gx_device_tile_clip,
+ tile_clipper_initialize_device_procs,
+ "tile clipper",
+ 0, 0, 1, 1)
};
/* Initialize a tile clipping device from a mask. */
@@ -400,34 +383,6 @@ tile_clip_copy_alpha_hl_color(gx_device * dev,
return 0;
}
-/* Copy a RasterOp rectangle similarly. */
-static int
-tile_clip_strip_copy_rop(gx_device * dev,
- const byte * data, int sourcex, uint raster, gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_strip_bitmap * textures, const gx_color_index * tcolors,
- int x, int y, int w, int h,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- gx_device_tile_clip *cdev = (gx_device_tile_clip *) dev;
-
- fit_copy(dev, data, sourcex, raster, id, x, y, w, h);
- {
- FOR_RUNS(data_row, txrun, tx, ty) {
- /* Copy the run. */
- int code = (*dev_proc(cdev->target, strip_copy_rop))
- (cdev->target, data_row, sourcex + txrun - x, raster,
- gx_no_bitmap_id, scolors, textures, tcolors,
- txrun, ty, tx - txrun, 1, phase_x, phase_y, lop);
-
- if (code < 0)
- return code;
- }
- END_FOR_RUNS();
- }
- return 0;
-}
-
static int
tile_clip_strip_copy_rop2(gx_device * dev,
const byte * data, int sourcex, uint raster, gx_bitmap_id id,
diff --git a/base/gxclipm.c b/base/gxclipm.c
index 59f1e765..627f28a5 100644
--- a/base/gxclipm.c
+++ b/base/gxclipm.c
@@ -32,90 +32,74 @@ static dev_proc_copy_alpha(mask_clip_copy_alpha);
static dev_proc_copy_alpha_hl_color(mask_clip_copy_alpha_hl_color);
static dev_proc_strip_tile_rectangle(mask_clip_strip_tile_rectangle);
static dev_proc_strip_tile_rect_devn(mask_clip_strip_tile_rect_devn);
-static dev_proc_strip_copy_rop(mask_clip_strip_copy_rop);
static dev_proc_strip_copy_rop2(mask_clip_strip_copy_rop2);
static dev_proc_get_clipping_box(mask_clip_get_clipping_box);
/* The device descriptor. */
-const gx_device_mask_clip gs_mask_clip_device =
-{std_device_std_body_open(gx_device_mask_clip, 0, "mask clipper",
- 0, 0, 1, 1),
- {gx_default_open_device,
- gx_forward_get_initial_matrix,
- gx_default_sync_output,
- gx_default_output_page,
- gx_default_close_device,
- gx_forward_map_rgb_color,
- gx_forward_map_color_rgb,
- mask_clip_fill_rectangle,
- gx_default_tile_rectangle,
- mask_clip_copy_mono,
- mask_clip_copy_color,
- gx_default_draw_line,
- gx_forward_get_bits,
- gx_forward_get_params,
- gx_forward_put_params,
- gx_forward_map_cmyk_color,
- gx_forward_get_xfont_procs,
- gx_forward_get_xfont_device,
- gx_forward_map_rgb_alpha_color,
- gx_forward_get_page_device,
- gx_forward_get_alpha_bits,
- mask_clip_copy_alpha,
- gx_forward_get_band,
- gx_default_copy_rop,
- gx_default_fill_path,
- gx_default_stroke_path,
- gx_default_fill_mask,
- gx_default_fill_trapezoid,
- gx_default_fill_parallelogram,
- gx_default_fill_triangle,
- gx_default_draw_thin_line,
- gx_default_begin_image,
- gx_default_image_data,
- gx_default_end_image,
- mask_clip_strip_tile_rectangle,
- mask_clip_strip_copy_rop,
- mask_clip_get_clipping_box,
- gx_default_begin_typed_image,
- gx_forward_get_bits_rectangle,
- gx_forward_map_color_rgb_alpha,
- gx_no_create_compositor,
- gx_forward_get_hardware_params,
- gx_default_text_begin,
- gx_default_finish_copydevice,
- NULL, /* begin_transparency_group */
- NULL, /* end_transparency_group */
- NULL, /* begin_transparency_mask */
- NULL, /* end_transparency_mask */
- NULL, /* discard_transparency_layer */
- gx_forward_get_color_mapping_procs,
- gx_forward_get_color_comp_index,
- gx_forward_encode_color,
- gx_forward_decode_color,
- NULL, /* pattern_manage */
- mask_clip_fill_rectangle_hl_color,
- gx_forward_include_color_space,
- gx_forward_fill_linear_color_scanline,
- gx_forward_fill_linear_color_trapezoid,
- gx_forward_fill_linear_color_triangle,
- gx_forward_update_spot_equivalent_colors,
- gx_forward_ret_devn_params,
- gx_forward_fillpage,
- NULL, /* push_transparency_state */
- NULL, /* pop_transparency_state */
- NULL, /* put_image */
- gx_forward_dev_spec_op,
- NULL,
- gx_forward_get_profile,
- gx_forward_set_graphics_type_tag,
- mask_clip_strip_copy_rop2,
- mask_clip_strip_tile_rect_devn,
- mask_clip_copy_alpha_hl_color,
- NULL,
- gx_default_transform_pixel_region,
- gx_forward_fill_stroke_path,
+
+static void
+mask_clip_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, get_initial_matrix, gx_forward_get_initial_matrix);
+ set_dev_proc(dev, map_rgb_color, gx_forward_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_forward_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, mask_clip_fill_rectangle);
+ set_dev_proc(dev, copy_mono, mask_clip_copy_mono);
+ set_dev_proc(dev, copy_color, mask_clip_copy_color);
+ set_dev_proc(dev, get_params, gx_forward_get_params);
+ set_dev_proc(dev, put_params, gx_forward_put_params);
+ set_dev_proc(dev, map_cmyk_color, gx_forward_map_cmyk_color);
+ set_dev_proc(dev, get_page_device, gx_forward_get_page_device);
+ set_dev_proc(dev, get_alpha_bits, gx_forward_get_alpha_bits);
+ set_dev_proc(dev, copy_alpha, mask_clip_copy_alpha);
+ set_dev_proc(dev, strip_tile_rectangle, mask_clip_strip_tile_rectangle);
+ set_dev_proc(dev, get_clipping_box, mask_clip_get_clipping_box);
+ set_dev_proc(dev, get_bits_rectangle, gx_forward_get_bits_rectangle);
+ set_dev_proc(dev, composite, gx_no_composite);
+ set_dev_proc(dev, get_hardware_params, gx_forward_get_hardware_params);
+ set_dev_proc(dev, get_color_mapping_procs, gx_forward_get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, gx_forward_get_color_comp_index);
+ set_dev_proc(dev, encode_color, gx_forward_encode_color);
+ set_dev_proc(dev, decode_color, gx_forward_decode_color);
+ set_dev_proc(dev, fill_rectangle_hl_color, mask_clip_fill_rectangle_hl_color);
+ set_dev_proc(dev, include_color_space, gx_forward_include_color_space);
+ set_dev_proc(dev, fill_linear_color_scanline, gx_forward_fill_linear_color_scanline);
+ set_dev_proc(dev, fill_linear_color_trapezoid, gx_forward_fill_linear_color_trapezoid);
+ set_dev_proc(dev, fill_linear_color_triangle, gx_forward_fill_linear_color_triangle);
+ set_dev_proc(dev, update_spot_equivalent_colors, gx_forward_update_spot_equivalent_colors);
+ set_dev_proc(dev, ret_devn_params, gx_forward_ret_devn_params);
+ set_dev_proc(dev, fillpage, gx_forward_fillpage);
+ set_dev_proc(dev, dev_spec_op, gx_forward_dev_spec_op);
+ set_dev_proc(dev, get_profile, gx_forward_get_profile);
+ set_dev_proc(dev, set_graphics_type_tag, gx_forward_set_graphics_type_tag);
+ set_dev_proc(dev, strip_copy_rop2, mask_clip_strip_copy_rop2);
+ set_dev_proc(dev, strip_tile_rect_devn, mask_clip_strip_tile_rect_devn);
+ set_dev_proc(dev, copy_alpha_hl_color, mask_clip_copy_alpha_hl_color);
+ set_dev_proc(dev, transform_pixel_region, gx_default_transform_pixel_region);
+ set_dev_proc(dev, fill_stroke_path, gx_forward_fill_stroke_path);
+
+ /* Ideally these defaults would be set up automatically for us. */
+ set_dev_proc(dev, open_device, gx_default_open_device);
+ set_dev_proc(dev, sync_output, gx_default_sync_output);
+ set_dev_proc(dev, output_page, gx_default_output_page);
+ set_dev_proc(dev, close_device, gx_default_close_device);
+ set_dev_proc(dev, fill_path, gx_default_fill_path);
+ set_dev_proc(dev, stroke_path, gx_default_stroke_path);
+ set_dev_proc(dev, fill_mask, gx_default_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, gx_default_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, gx_default_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, gx_default_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, gx_default_draw_thin_line);
+ set_dev_proc(dev, begin_typed_image, gx_default_begin_typed_image);
+ set_dev_proc(dev, text_begin, gx_default_text_begin);
+
}
+
+const gx_device_mask_clip gs_mask_clip_device =
+{std_device_std_body_open(gx_device_mask_clip,
+ mask_clip_initialize_device_procs,
+ "mask clipper",
+ 0, 0, 1, 1)
};
/* Fill a rectangle with a hl color, painting through the mask */
@@ -453,26 +437,6 @@ mask_clip_strip_tile_rect_devn(gx_device * dev, const gx_strip_bitmap * tiles,
}
static int
-mask_clip_strip_copy_rop(gx_device * dev,
- const byte * data, int sourcex, uint raster, gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_strip_bitmap * textures, const gx_color_index * tcolors,
- int x, int y, int w, int h,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- gx_device_mask_clip *cdev = (gx_device_mask_clip *) dev;
- clip_callback_data_t ccdata;
-
- ccdata.tdev = cdev->target;
- ccdata.x = x, ccdata.y = y, ccdata.w = w, ccdata.h = h;
- ccdata.data = data, ccdata.sourcex = sourcex, ccdata.raster = raster;
- ccdata.scolors = scolors, ccdata.textures = textures,
- ccdata.tcolors = tcolors;
- ccdata.phase.x = phase_x, ccdata.phase.y = phase_y, ccdata.lop = lop;
- return clip_runs_enumerate(cdev, clip_call_strip_copy_rop, &ccdata);
-}
-
-static int
mask_clip_strip_copy_rop2(gx_device * dev,
const byte * data, int sourcex, uint raster, gx_bitmap_id id,
const gx_color_index * scolors,
diff --git a/base/gxclist.c b/base/gxclist.c
index 7c7f0aa4..a3b3ccb3 100644
--- a/base/gxclist.c
+++ b/base/gxclist.c
@@ -120,95 +120,65 @@ private_st_clist_icctable();
/* Forward declarations of driver procedures */
dev_proc_open_device(clist_open);
dev_proc_output_page(clist_output_page);
-static dev_proc_close_device(clist_close);
-static dev_proc_get_band(clist_get_band);
+dev_proc_close_device(clist_close);
/* Driver procedures defined in other files are declared in gxcldev.h. */
/* Other forward declarations */
static int clist_put_current_params(gx_device_clist_writer *cldev);
-/* The device procedures */
-const gx_device_procs gs_clist_device_procs = {
- clist_open,
- gx_forward_get_initial_matrix,
- gx_default_sync_output,
- clist_output_page,
- clist_close,
- gx_forward_map_rgb_color,
- gx_forward_map_color_rgb,
- clist_fill_rectangle,
- gx_default_tile_rectangle,
- clist_copy_mono,
- clist_copy_color,
- gx_default_draw_line,
- gx_default_get_bits,
- gx_forward_get_params,
- gx_forward_put_params,
- gx_forward_map_cmyk_color,
- gx_forward_get_xfont_procs,
- gx_forward_get_xfont_device,
- gx_forward_map_rgb_alpha_color,
- gx_forward_get_page_device,
- gx_forward_get_alpha_bits,
- clist_copy_alpha,
- clist_get_band,
- gx_default_copy_rop,
- clist_fill_path,
- clist_stroke_path,
- clist_fill_mask,
- clist_fill_trapezoid,
- clist_fill_parallelogram,
- clist_fill_triangle,
- gx_default_draw_thin_line,
- gx_default_begin_image,
- gx_default_image_data,
- gx_default_end_image,
- clist_strip_tile_rectangle,
- clist_strip_copy_rop,
- gx_forward_get_clipping_box,
- clist_begin_typed_image,
- clist_get_bits_rectangle,
- gx_forward_map_color_rgb_alpha,
- clist_create_compositor,
- gx_forward_get_hardware_params,
- gx_default_text_begin,
- gx_default_finish_copydevice,
- gx_default_begin_transparency_group, /* begin_transparency_group */
- gx_default_end_transparency_group, /* end_transparency_group */
- gx_default_begin_transparency_mask, /* begin_transparency_mask */
- gx_default_end_transparency_mask, /* end_transparency_mask */
- gx_default_discard_transparency_layer, /* discard_transparency_layer */
- gx_forward_get_color_mapping_procs,
- gx_forward_get_color_comp_index,
- gx_forward_encode_color,
- gx_forward_decode_color,
- gx_default_pattern_manage, /* pattern_manage */
- clist_fill_rectangle_hl_color,
- gx_default_include_color_space,
- gx_default_fill_linear_color_scanline,
- clist_fill_linear_color_trapezoid,
- clist_fill_linear_color_triangle,
- gx_forward_update_spot_equivalent_colors,
- gx_forward_ret_devn_params,
- clist_fillpage,
- gx_default_push_transparency_state, /* push_transparency_state */
- gx_default_pop_transparency_state, /* pop_transparency_state */
- gx_default_put_image, /* put_image */
- clist_dev_spec_op,
- clist_copy_planes, /* copy planes */
- gx_default_get_profile,
- gx_default_set_graphics_type_tag,
- clist_strip_copy_rop2,
- clist_strip_tile_rect_devn,
- clist_copy_alpha_hl_color,
- clist_process_page,
- gx_default_transform_pixel_region,
- clist_fill_stroke_path,
-};
+void
+clist_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, clist_open);
+ set_dev_proc(dev, get_initial_matrix, gx_forward_get_initial_matrix);
+ set_dev_proc(dev, sync_output, gx_default_sync_output);
+ set_dev_proc(dev, output_page, clist_output_page);
+ set_dev_proc(dev, close_device, clist_close);
+ set_dev_proc(dev, map_rgb_color, gx_forward_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_forward_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, clist_fill_rectangle);
+ set_dev_proc(dev, copy_mono, clist_copy_mono);
+ set_dev_proc(dev, copy_color, clist_copy_color);
+ set_dev_proc(dev, get_params, gx_forward_get_params);
+ set_dev_proc(dev, put_params, gx_forward_put_params);
+ set_dev_proc(dev, map_cmyk_color, gx_forward_map_cmyk_color);
+ set_dev_proc(dev, get_page_device, gx_forward_get_page_device);
+ set_dev_proc(dev, get_alpha_bits, gx_forward_get_alpha_bits);
+ set_dev_proc(dev, copy_alpha, clist_copy_alpha);
+ set_dev_proc(dev, fill_path, clist_fill_path);
+ set_dev_proc(dev, stroke_path, clist_stroke_path);
+ set_dev_proc(dev, fill_mask, clist_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, clist_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, clist_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, clist_fill_triangle);
+ set_dev_proc(dev, strip_tile_rectangle, clist_strip_tile_rectangle);
+ set_dev_proc(dev, get_clipping_box, gx_forward_get_clipping_box);
+ set_dev_proc(dev, begin_typed_image, clist_begin_typed_image);
+ set_dev_proc(dev, get_bits_rectangle, clist_get_bits_rectangle);
+ set_dev_proc(dev, composite, clist_composite);
+ set_dev_proc(dev, get_hardware_params, gx_forward_get_hardware_params);
+ set_dev_proc(dev, get_color_mapping_procs, gx_forward_get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, gx_forward_get_color_comp_index);
+ set_dev_proc(dev, encode_color, gx_forward_encode_color);
+ set_dev_proc(dev, decode_color, gx_forward_decode_color);
+ set_dev_proc(dev, fill_rectangle_hl_color, clist_fill_rectangle_hl_color);
+ set_dev_proc(dev, fill_linear_color_trapezoid, clist_fill_linear_color_trapezoid);
+ set_dev_proc(dev, fill_linear_color_triangle, clist_fill_linear_color_triangle);
+ set_dev_proc(dev, update_spot_equivalent_colors, gx_forward_update_spot_equivalent_colors);
+ set_dev_proc(dev, ret_devn_params, gx_forward_ret_devn_params);
+ set_dev_proc(dev, fillpage, clist_fillpage);
+ set_dev_proc(dev, dev_spec_op, clist_dev_spec_op);
+ set_dev_proc(dev, copy_planes, clist_copy_planes);
+ set_dev_proc(dev, strip_copy_rop2, clist_strip_copy_rop2);
+ set_dev_proc(dev, strip_tile_rect_devn, clist_strip_tile_rect_devn);
+ set_dev_proc(dev, copy_alpha_hl_color, clist_copy_alpha_hl_color);
+ set_dev_proc(dev, process_page, clist_process_page);
+ set_dev_proc(dev, fill_stroke_path, clist_fill_stroke_path);
+}
/*------------------- Choose the implementation -----------------------
- For chossing the clist i/o implementation by makefile options
+ For choosing the clist i/o implementation by makefile options
we define global variables, which are initialized with
file/memory io procs when they are included into the build.
*/
@@ -741,7 +711,7 @@ errxit:
return code;
}
-static int
+int
clist_close(gx_device *dev)
{
int i;
@@ -965,22 +935,6 @@ clist_put_current_params(gx_device_clist_writer *cldev)
/* ---------------- Driver interface ---------------- */
-static int
-clist_get_band(gx_device * dev, int y, int *band_start)
-{
- gx_device_clist_writer * const cdev =
- &((gx_device_clist *)dev)->writer;
- int band_height = cdev->page_band_height;
- int start;
-
- if (y < 0)
- y = 0;
- else if (y >= dev->height)
- y = dev->height;
- *band_start = start = y - y % band_height;
- return min(dev->height - start, band_height);
-}
-
/* ICC table operations. See gxclist.h for details */
/* This checks the table for a hash code entry */
bool
@@ -1386,7 +1340,7 @@ clist_make_accum_device(gs_memory_t *mem, gx_device *target, const char *dname,
return 0;
memset(cdev, 0, sizeof(*cdev));
cwdev->params_size = sizeof(gx_device_clist);
- cwdev->static_procs = NULL;
+ cwdev->initialize_device_procs = clist_initialize_device_procs;
cwdev->dname = dname;
cwdev->memory = mem->stable_memory;
cwdev->stype = &st_device_clist;
@@ -1413,7 +1367,8 @@ clist_make_accum_device(gs_memory_t *mem, gx_device *target, const char *dname,
cwdev->icc_table = NULL;
cwdev->UseCIEColor = target->UseCIEColor;
cwdev->LockSafetyParams = true;
- cwdev->procs = gs_clist_device_procs;
+ cwdev->initialize_device_procs((gx_device *)cwdev);
+ gx_device_fill_in_procs((gx_device *)cwdev);
gx_device_copy_color_params((gx_device *)cwdev, target);
rc_assign(cwdev->target, target, "clist_make_accum_device");
clist_init_io_procs(cdev, use_memory_clist);
@@ -1550,7 +1505,7 @@ open_c:
pdev->clist_disable_mask,
pdev->page_uses_transparency,
pdev->page_uses_overprint);
- code = (*gs_clist_device_procs.open_device)( (gx_device *)pcldev );
+ code = clist_open( (gx_device *)pcldev );
if (code < 0) {
/* If there wasn't enough room, and we haven't */
/* already shrunk the buffer, try enlarging it. */
diff --git a/base/gxclist.h b/base/gxclist.h
index a30331fb..bc63cc7f 100644
--- a/base/gxclist.h
+++ b/base/gxclist.h
@@ -433,8 +433,7 @@ extern_st(st_device_clist);
(xclist)->writer.pinst = NULL;\
END
-/* The device template itself is never used, only the procedures. */
-extern const gx_device_procs gs_clist_device_procs;
+void clist_initialize_device_procs(gx_device *dev);
void clist_init_io_procs(gx_device_clist *pclist_dev, bool in_memory);
diff --git a/base/gxclpage.c b/base/gxclpage.c
index 18ff9b81..0e358da3 100644
--- a/base/gxclpage.c
+++ b/base/gxclpage.c
@@ -24,6 +24,8 @@
#include "string_.h"
#include <ctype.h> /* for isalpha, etc. */
+extern dev_proc_open_device(clist_open);
+
/* Save the current clist state into a saved page structure,
* and optionally stashes the files into the given save_files
* pointers.
@@ -106,7 +108,7 @@ params_out:
}
}
/* Now re-open the clist device so that we get new files for the next page */
- return (*gs_clist_device_procs.open_device) ((gx_device *) pdev);
+ return clist_open((gx_device *) pdev);
}
/* Save a page. The elements are allocated by this function in non_gc_memory */
diff --git a/base/gxclpath.h b/base/gxclpath.h
index 7a393730..f5e9555c 100644
--- a/base/gxclpath.h
+++ b/base/gxclpath.h
@@ -175,7 +175,7 @@ typedef enum {
*/
typedef enum {
cmd_opv_ext_put_params = 0x00, /* serialized parameter list */
- cmd_opv_ext_create_compositor = 0x01, /* compositor id,
+ cmd_opv_ext_composite = 0x01, /* compositor id,
* serialized compositor */
cmd_opv_ext_put_halftone = 0x02, /* length of entire halftone */
cmd_opv_ext_put_ht_seg = 0x03, /* segment length,
diff --git a/base/gxclrast.c b/base/gxclrast.c
index f9f42d88..bfed7ddb 100644
--- a/base/gxclrast.c
+++ b/base/gxclrast.c
@@ -256,8 +256,8 @@ static int read_begin_image(command_buf_t *pcb, gs_image_common_t *pic,
static int read_put_params(command_buf_t *pcb, gs_gstate *pgs,
gx_device_clist_reader *cdev,
gs_memory_t *mem);
-static int read_create_compositor(command_buf_t *pcb, gs_memory_t *mem, gs_composite_t **ppcomp);
-static int apply_create_compositor(gx_device_clist_reader *cdev, gs_gstate *pgs,
+static int read_composite(command_buf_t *pcb, gs_memory_t *mem, gs_composite_t **ppcomp);
+static int apply_composite(gx_device_clist_reader *cdev, gs_gstate *pgs,
gs_memory_t *mem, gs_composite_t *pcomp,
int x0, int y0, gx_device **ptarget);
static int read_alloc_ht_buff(ht_buff_t *, uint, gs_memory_t *);
@@ -382,7 +382,7 @@ execute_compositor_queue(gx_device_clist_reader *cdev, gx_device **target, gx_de
if (code < 0)
return code;
pcomp->idle |= idle;
- code = apply_create_compositor(cdev, pgs, mem, pcomp, x0, y0, target); /* Releases the compositor. */
+ code = apply_composite(cdev, pgs, mem, pcomp, x0, y0, target); /* Releases the compositor. */
if (code < 0)
return code;
*tdev = *target;
@@ -809,7 +809,7 @@ in: /* Initialize for a new page. */
halftone_type, num_comp);
#endif
code = cmd_resize_halftone(
- &gs_gstate.dev_ht,
+ &gs_gstate.dev_ht[HT_OBJTYPE_DEFAULT],
num_comp, mem);
if (code < 0)
goto out;
@@ -1209,10 +1209,10 @@ set_phase: /*
if (state_tile.size.x)
tile_phase.x =
(state.tile_phase.x + x0) % state_tile.size.x;
- if (gs_gstate.dev_ht && gs_gstate.dev_ht->lcm_width)
+ if (gs_gstate.dev_ht[HT_OBJTYPE_DEFAULT] && gs_gstate.dev_ht[HT_OBJTYPE_DEFAULT]->lcm_width)
color_phase.x =
(state.tile_phase.x + x0) %
- gs_gstate.dev_ht->lcm_width;
+ gs_gstate.dev_ht[HT_OBJTYPE_DEFAULT]->lcm_width;
/*
* The true tile height for shifted tiles is not
* size.y: see gxbitmap.h for the computation.
@@ -1230,10 +1230,10 @@ set_phase: /*
tile_phase.y =
(state.tile_phase.y + y0) % full_height;
}
- if (gs_gstate.dev_ht && gs_gstate.dev_ht->lcm_height)
+ if (gs_gstate.dev_ht[HT_OBJTYPE_DEFAULT] && gs_gstate.dev_ht[HT_OBJTYPE_DEFAULT]->lcm_height)
color_phase.y =
(state.tile_phase.y + y0) %
- gs_gstate.dev_ht->lcm_height;
+ gs_gstate.dev_ht[HT_OBJTYPE_DEFAULT]->lcm_height;
gx_gstate_setscreenphase(&gs_gstate,
-(state.tile_phase.x + x0),
-(state.tile_phase.y + y0),
@@ -1615,8 +1615,8 @@ idata: data_size = 0;
if (playback_action == playback_action_setup)
goto out;
break;
- case cmd_opv_ext_create_compositor:
- if_debug0m('L', mem, " ext_create_compositor\n");
+ case cmd_opv_ext_composite:
+ if_debug0m('L', mem, " ext_composite\n");
cbuf.ptr = cbp;
/*
* The screen phase may have been changed during
@@ -1637,12 +1637,12 @@ idata: data_size = 0;
if (code < 0)
goto out;
}
- if (cbp[0] == cmd_opv_extend && cbp[1] == cmd_opv_ext_create_compositor) {
+ if (cbp[0] == cmd_opv_extend && cbp[1] == cmd_opv_ext_composite) {
gs_composite_t *pcomp, *pcomp_opening;
gs_compositor_closing_state closing_state;
cbuf.ptr = cbp += 2;
- code = read_create_compositor(&cbuf, mem, &pcomp);
+ code = read_composite(&cbuf, mem, &pcomp);
if (code < 0)
goto out;
cbp = cbuf.ptr;
@@ -1651,7 +1651,7 @@ idata: data_size = 0;
if (gs_is_pdf14trans_compositor(pcomp) &&
playback_action == playback_action_render_no_pdf14) {
/* free the compositor object */
- gs_free_object(mem, pcomp, "read_create_compositor");
+ gs_free_object(mem, pcomp, "read_composite");
pcomp = NULL;
continue;
}
@@ -2258,18 +2258,7 @@ idata: data_size = 0;
colors[0] = colors[1] = state.colors[1];
log_op = state.lop;
pcolor = colors;
- do_rop:if (plane_height == 0) {
- code = (*dev_proc(tdev, strip_copy_rop))
- (tdev, source, data_x, raster, gx_no_bitmap_id,
- pcolor, &state_tile,
- (state.tile_colors[0] == gx_no_color_index &&
- state.tile_colors[1] == gx_no_color_index ?
- NULL : state.tile_colors),
- state.rect.x - x0, state.rect.y - y0,
- state.rect.width - data_x, state.rect.height,
- tile_phase.x, tile_phase.y, log_op);
- } else {
- code = (*dev_proc(tdev, strip_copy_rop2))
+ do_rop:code = (*dev_proc(tdev, strip_copy_rop2))
(tdev, source, data_x, raster, gx_no_bitmap_id,
pcolor, &state_tile,
(state.tile_colors[0] == gx_no_color_index &&
@@ -2280,7 +2269,6 @@ idata: data_size = 0;
tile_phase.x, tile_phase.y, log_op,
plane_height);
plane_height = 0;
- }
data_x = 0;
break;
case cmd_op_tile_rect >> 4:
@@ -2291,7 +2279,7 @@ idata: data_size = 0;
}
case cmd_op_tile_rect_short >> 4:
case cmd_op_tile_rect_tiny >> 4:
- /* Currently we don't use lop with tile_rectangle. */
+ /* Currently we don't use lop with strip_tile_rectangle. */
code = (*dev_proc(tdev, strip_tile_rectangle))
(tdev, &state_tile,
state.rect.x - x0, state.rect.y - y0,
@@ -3030,7 +3018,7 @@ out:
}
/*
- * Read a "create_compositor" command, and execute the command.
+ * Read a "composite" command, and execute the command.
*
* This code assumes that a the largest create compositor command,
* including the compositor name size, is smaller than the data buffer
@@ -3038,7 +3026,7 @@ out:
* and the de-serializer interface, as no length field is provided.
*
* At the time of this writing, no compositor violates this assumption.
- * The largest create_compositor is currently 1275 bytes, while the command
+ * The largest composite is currently 1275 bytes, while the command
* data buffer is 4096 bytes.
*
* In the event that this assumption is violated, a change in the encoding
@@ -3049,7 +3037,7 @@ out:
extern_gs_find_compositor();
static int
-read_create_compositor(
+read_composite(
command_buf_t *pcb, gs_memory_t *mem, gs_composite_t **ppcomp)
{
const byte * cbp = pcb->ptr;
@@ -3081,7 +3069,7 @@ read_create_compositor(
return code;
}
-static int apply_create_compositor(gx_device_clist_reader *cdev, gs_gstate *pgs,
+static int apply_composite(gx_device_clist_reader *cdev, gs_gstate *pgs,
gs_memory_t *mem, gs_composite_t *pcomp,
int x0, int y0, gx_device **ptarget)
{
@@ -3095,7 +3083,7 @@ static int apply_create_compositor(gx_device_clist_reader *cdev, gs_gstate *pgs,
* Apply the compositor to the target device; note that this may
* change the target device.
*/
- code = dev_proc(tdev, create_compositor)(tdev, &tdev, pcomp, pgs, mem, (gx_device*) cdev);
+ code = dev_proc(tdev, composite)(tdev, &tdev, pcomp, pgs, mem, (gx_device*) cdev);
if (code == 1) {
/* A new compositor was created that wrapped tdev. This should
* be our new target. */
@@ -3112,7 +3100,7 @@ static int apply_create_compositor(gx_device_clist_reader *cdev, gs_gstate *pgs,
return code;
/* free the compositor object */
- gs_free_object(mem, pcomp, "read_create_compositor");
+ gs_free_object(mem, pcomp, "read_composite");
return code;
}
diff --git a/base/gxclread.c b/base/gxclread.c
index 2323b68c..23b07ac3 100644
--- a/base/gxclread.c
+++ b/base/gxclread.c
@@ -590,7 +590,7 @@ clist_render_init(gx_device_clist *dev)
/* Copy a rasterized rectangle to the client, rasterizing if needed. */
int
clist_get_bits_rectangle(gx_device *dev, const gs_int_rect * prect,
- gs_get_bits_params_t *params, gs_int_rect **unread)
+ gs_get_bits_params_t *params)
{
gx_device_clist *cldev = (gx_device_clist *)dev;
gx_device_clist_reader *crdev = &cldev->reader;
@@ -631,8 +631,7 @@ clist_get_bits_rectangle(gx_device *dev, const gs_int_rect * prect,
for (i = 0; i < num_planes; ++i)
if (params->data[i]) {
if (plane_index >= 0) /* >1 plane requested */
- return gx_default_get_bits_rectangle(dev, prect, params,
- unread);
+ return gx_default_get_bits_rectangle(dev, prect, params);
plane_index = i;
}
}
@@ -655,7 +654,7 @@ clist_get_bits_rectangle(gx_device *dev, const gs_int_rect * prect,
band_rect.p.y = my;
band_rect.q.y = my + lines_rasterized;
code = dev_proc(bdev, get_bits_rectangle)
- (bdev, &band_rect, params, unread);
+ (bdev, &band_rect, params);
}
cdev->buf_procs.destroy_buf_device(bdev);
if (code < 0 || lines_rasterized == line_count)
@@ -668,7 +667,7 @@ clist_get_bits_rectangle(gx_device *dev, const gs_int_rect * prect,
* rectangles, punt.
*/
if (!(options & GB_RETURN_COPY) || code > 0)
- return gx_default_get_bits_rectangle(dev, prect, params, unread);
+ return gx_default_get_bits_rectangle(dev, prect, params);
options = params->options;
if (!(options & GB_RETURN_COPY)) {
/* Redo the first piece with copying. */
@@ -703,7 +702,7 @@ clist_get_bits_rectangle(gx_device *dev, const gs_int_rect * prect,
band_rect.p.y = my;
band_rect.q.y = my + lines_rasterized;
code = dev_proc(bdev, get_bits_rectangle)
- (bdev, &band_rect, &band_params, unread);
+ (bdev, &band_rect, &band_params);
if (code < 0)
break;
params->options = options = band_params.options;
diff --git a/base/gxclrect.c b/base/gxclrect.c
index bbfb40d8..a97cf0f6 100644
--- a/base/gxclrect.c
+++ b/base/gxclrect.c
@@ -1421,20 +1421,6 @@ copy:{
}
int
-clist_strip_copy_rop(gx_device * dev,
- const byte * sdata, int sourcex, uint sraster, gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_strip_bitmap * textures, const gx_color_index * tcolors,
- int rx, int ry, int rwidth, int rheight,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- return clist_strip_copy_rop2(dev, sdata, sourcex, sraster, id,
- scolors, textures, tcolors,
- rx, ry, rwidth, rheight, phase_x, phase_y,
- lop, 0);
-}
-
-int
clist_strip_copy_rop2(gx_device * dev,
const byte * sdata, int sourcex, uint sraster, gx_bitmap_id id,
const gx_color_index * scolors,
@@ -1647,13 +1633,13 @@ clist_strip_copy_rop2(gx_device * dev,
}
continue;
}
- if (((phase_x != re.pcls->tile_phase.x) && (tiles->rep_width > 1)) ||
- ((phase_y != re.pcls->tile_phase.y) && (tiles->rep_height > 1))) {
- code = cmd_set_tile_phase(cdev, re.pcls, phase_x,
- phase_y);
- if (code < 0)
- return code;
- }
+ }
+ if (((phase_x != re.pcls->tile_phase.x) && (tiles->rep_width > 1)) ||
+ ((phase_y != re.pcls->tile_phase.y) && (tiles->rep_height > 1))) {
+ code = cmd_set_tile_phase(cdev, re.pcls, phase_x,
+ phase_y);
+ if (code < 0)
+ return code;
}
}
/* Set the tile colors. */
diff --git a/base/gxclthrd.c b/base/gxclthrd.c
index 088de2bf..a5835cc1 100644
--- a/base/gxclthrd.c
+++ b/base/gxclthrd.c
@@ -837,7 +837,7 @@ clist_get_band_from_thread(gx_device *dev, int band_needed, gx_process_page_opti
/* rendering adjacent to the first band (forward or backward) */
static int
clist_get_bits_rect_mt(gx_device *dev, const gs_int_rect * prect,
- gs_get_bits_params_t *params, gs_int_rect **unread)
+ gs_get_bits_params_t *params)
{
gx_device_printer *pdev = (gx_device_printer *)dev;
gx_device_clist *cldev = (gx_device_clist *)dev;
@@ -861,7 +861,7 @@ clist_get_bits_rect_mt(gx_device *dev, const gs_int_rect * prect,
/* This page might not want multiple threads */
/* Also we don't support plane extraction using multiple threads */
if (pdev->num_render_threads_requested < 1 || (options & GB_SELECT_PLANES))
- return clist_get_bits_rectangle(dev, prect, params, unread);
+ return clist_get_bits_rectangle(dev, prect, params);
if (prect->p.x < 0 || prect->q.x > dev->width ||
y < 0 || end_y > dev->height
@@ -878,12 +878,12 @@ clist_get_bits_rect_mt(gx_device *dev, const gs_int_rect * prect,
/* Haven't done any rendering yet, try to set up the threads */
if (clist_setup_render_threads(dev, y, NULL) < 0)
/* problem setting up the threads, revert to single threaded */
- return clist_get_bits_rectangle(dev, prect, params, unread);
+ return clist_get_bits_rectangle(dev, prect, params);
} else {
if (crdev->render_threads == NULL) {
/* If we get here with with ymin and ymax > 0 it's because we closed the threads */
/* while doing a page due to an error. Use single threaded mode. */
- return clist_get_bits_rectangle(dev, prect, params, unread);
+ return clist_get_bits_rectangle(dev, prect, params);
}
}
/* If we already have the band's data, just return it */
@@ -905,7 +905,7 @@ clist_get_bits_rect_mt(gx_device *dev, const gs_int_rect * prect,
band_rect.p.y = 0;
band_rect.q.y = lines_rasterized;
code = dev_proc(bdev, get_bits_rectangle)
- (bdev, &band_rect, params, unread);
+ (bdev, &band_rect, params);
cdev->buf_procs.destroy_buf_device(bdev);
if (code < 0)
goto free_thread_out;
@@ -924,7 +924,7 @@ clist_get_bits_rect_mt(gx_device *dev, const gs_int_rect * prect,
* rectangles, punt.
*/
if (!(options & GB_RETURN_COPY) || code > 0)
- return gx_default_get_bits_rectangle(dev, prect, params, unread);
+ return gx_default_get_bits_rectangle(dev, prect, params);
options = params->options;
if (!(options & GB_RETURN_COPY)) {
/* Redo the first piece with copying. */
@@ -952,7 +952,7 @@ clist_get_bits_rect_mt(gx_device *dev, const gs_int_rect * prect,
band_rect.p.y = my;
band_rect.q.y = my + lines_rasterized;
code = dev_proc(bdev, get_bits_rectangle)
- (bdev, &band_rect, &band_params, unread);
+ (bdev, &band_rect, &band_params);
if (code < 0)
break;
params->options = band_params.options;
diff --git a/base/gxclutil.c b/base/gxclutil.c
index 055fbcf7..1884348e 100644
--- a/base/gxclutil.c
+++ b/base/gxclutil.c
@@ -83,7 +83,7 @@ cmd_uncount_op(int op, uint size)
#endif
/* Print statistics. */
-#if defined(DEBUG) && !defined(GS_THREADSAFE)
+#if defined(DEBUG_CLIST_STATS) && !defined(GS_THREADSAFE)
void
cmd_print_stats(const gs_memory_t *mem)
{
@@ -287,7 +287,7 @@ cmd_write_buffer(gx_device_clist_writer * cldev, byte cmd_end)
VALGRIND_MAKE_MEM_UNDEFINED(cldev->cbuf, cldev->cend - cldev->cbuf);
#endif
cldev->ccl = 0;
-#if defined(DEBUG) && !defined(GS_THREADSAFE)
+#if defined(DEBUG_CLIST_STATS) && !defined(GS_THREADSAFE)
if (gs_debug_c('l'))
cmd_print_stats(cldev->memory);
#endif
diff --git a/base/gxcmap.c b/base/gxcmap.c
index cba4908e..a3c2443a 100644
--- a/base/gxcmap.c
+++ b/base/gxcmap.c
@@ -15,6 +15,7 @@
/* Color mapping for Ghostscript */
+#include "assert_.h"
#include "gx.h"
#include "gserrors.h"
#include "gsccolor.h"
@@ -27,6 +28,7 @@
#include "gxcmap.h"
#include "gxlum.h"
#include "gzstate.h"
+#include "gzht.h"
#include "gxdither.h"
#include "gxcdevn.h"
#include "string_.h"
@@ -209,32 +211,32 @@ gx_backwards_compatible_gray_encode(gx_device *dev,
/* -------- Default color space to color model conversion routines -------- */
void
-gray_cs_to_gray_cm(gx_device * dev, frac gray, frac out[])
+gray_cs_to_gray_cm(const gx_device * dev, frac gray, frac out[])
{
out[0] = gray;
}
static void
-rgb_cs_to_gray_cm(gx_device * dev, const gs_gstate *pgs,
+rgb_cs_to_gray_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
out[0] = color_rgb_to_gray(r, g, b, NULL);
}
static void
-cmyk_cs_to_gray_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+cmyk_cs_to_gray_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
out[0] = color_cmyk_to_gray(c, m, y, k, NULL);
}
static void
-gray_cs_to_rgb_cm(gx_device * dev, frac gray, frac out[])
+gray_cs_to_rgb_cm(const gx_device * dev, frac gray, frac out[])
{
out[0] = out[1] = out[2] = gray;
}
void
-rgb_cs_to_rgb_cm(gx_device * dev, const gs_gstate *pgs,
+rgb_cs_to_rgb_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
out[0] = r;
@@ -243,20 +245,20 @@ rgb_cs_to_rgb_cm(gx_device * dev, const gs_gstate *pgs,
}
static void
-cmyk_cs_to_rgb_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+cmyk_cs_to_rgb_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
color_cmyk_to_rgb(c, m, y, k, NULL, out, dev->memory);
}
static void
-gray_cs_to_rgbk_cm(gx_device * dev, frac gray, frac out[])
+gray_cs_to_rgbk_cm(const gx_device * dev, frac gray, frac out[])
{
out[0] = out[1] = out[2] = frac_0;
out[3] = gray;
}
static void
-rgb_cs_to_rgbk_cm(gx_device * dev, const gs_gstate *pgs,
+rgb_cs_to_rgbk_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
if ((r == g) && (g == b)) {
@@ -272,7 +274,7 @@ rgb_cs_to_rgbk_cm(gx_device * dev, const gs_gstate *pgs,
}
static void
-cmyk_cs_to_rgbk_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+cmyk_cs_to_rgbk_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
frac rgb[3];
if ((c == frac_0) && (m == frac_0) && (y == frac_0)) {
@@ -286,7 +288,7 @@ cmyk_cs_to_rgbk_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
}
static void
-gray_cs_to_cmyk_cm(gx_device * dev, frac gray, frac out[])
+gray_cs_to_cmyk_cm(const gx_device * dev, frac gray, frac out[])
{
out[0] = out[1] = out[2] = frac_0;
out[3] = frac_1 - gray;
@@ -308,7 +310,7 @@ gray_cs_to_cmyk_cm(gx_device * dev, frac gray, frac out[])
* often they are { pop 0 }.
*/
static void
-rgb_cs_to_cmyk_cm(gx_device * dev, const gs_gstate *pgs,
+rgb_cs_to_cmyk_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
if (pgs != 0)
@@ -325,7 +327,7 @@ rgb_cs_to_cmyk_cm(gx_device * dev, const gs_gstate *pgs,
}
void
-cmyk_cs_to_cmyk_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+cmyk_cs_to_cmyk_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
out[0] = c;
out[1] = m;
@@ -356,31 +358,40 @@ static const gx_cm_color_map_procs DeviceRGBK_procs = {
* to color model conversion routines.
*/
const gx_cm_color_map_procs *
-gx_default_DevGray_get_color_mapping_procs(const gx_device * dev)
+gx_default_DevGray_get_color_mapping_procs(const gx_device * dev,
+ const gx_device ** tdev)
{
+ *tdev = dev;
return &DeviceGray_procs;
}
const gx_cm_color_map_procs *
-gx_default_DevRGB_get_color_mapping_procs(const gx_device * dev)
+gx_default_DevRGB_get_color_mapping_procs(const gx_device * dev,
+ const gx_device ** tdev)
{
+ *tdev = dev;
return &DeviceRGB_procs;
}
const gx_cm_color_map_procs *
-gx_default_DevCMYK_get_color_mapping_procs(const gx_device * dev)
+gx_default_DevCMYK_get_color_mapping_procs(const gx_device * dev,
+ const gx_device ** tdev)
{
+ *tdev = dev;
return &DeviceCMYK_procs;
}
const gx_cm_color_map_procs *
-gx_default_DevRGBK_get_color_mapping_procs(const gx_device * dev)
+gx_default_DevRGBK_get_color_mapping_procs(const gx_device * dev,
+ const gx_device ** tdev)
{
+ *tdev = dev;
return &DeviceRGBK_procs;
}
const gx_cm_color_map_procs *
-gx_error_get_color_mapping_procs(const gx_device * dev)
+gx_error_get_color_mapping_procs(const gx_device * dev,
+ const gx_device ** tdev)
{
/*
* We should never get here. If we do then we do not have a "get_color_mapping_procs"
@@ -392,14 +403,14 @@ gx_error_get_color_mapping_procs(const gx_device * dev)
dev->dname);
switch (dev->color_info.num_components) {
case 1: /* DeviceGray or DeviceInvertGray */
- return gx_default_DevGray_get_color_mapping_procs(dev);
+ return gx_default_DevGray_get_color_mapping_procs(dev, tdev);
case 3:
- return gx_default_DevRGB_get_color_mapping_procs(dev);
+ return gx_default_DevRGB_get_color_mapping_procs(dev, tdev);
case 4:
default: /* Unknown color model - punt with CMYK */
- return gx_default_DevCMYK_get_color_mapping_procs(dev);
+ return gx_default_DevCMYK_get_color_mapping_procs(dev, tdev);
}
}
@@ -497,13 +508,7 @@ static cmap_proc_rgb(cmap_rgb_direct);
#define cmap_cmyk_halftoned cmap_cmyk_direct
static cmap_proc_cmyk(cmap_cmyk_direct);
-static cmap_proc_rgb_alpha(cmap_rgb_alpha_halftoned);
-static cmap_proc_rgb_alpha(cmap_rgb_alpha_direct);
-
/* Procedure names are only guaranteed unique to 23 characters.... */
-static cmap_proc_rgb_alpha(cmap_rgb_alpha_halftoned);
-static cmap_proc_rgb_alpha(cmap_rgb_alpha_direct);
-
static cmap_proc_separation(cmap_separation_halftoned);
static cmap_proc_separation(cmap_separation_direct);
@@ -517,7 +522,6 @@ static const gx_color_map_procs cmap_few = {
cmap_gray_halftoned,
cmap_rgb_halftoned,
cmap_cmyk_halftoned,
- cmap_rgb_alpha_halftoned,
cmap_separation_halftoned,
cmap_devicen_halftoned,
cmap_halftoned_is_halftoned
@@ -526,7 +530,6 @@ static const gx_color_map_procs cmap_many = {
cmap_gray_direct,
cmap_rgb_direct,
cmap_cmyk_direct,
- cmap_rgb_alpha_direct,
cmap_separation_direct,
cmap_devicen_direct,
cmap_direct_is_halftoned
@@ -888,6 +891,32 @@ gx_remap_DeviceCMYK(const gs_client_color * pc, const gs_color_space * pcs,
return 0;
}
+/* ------ Utility for selecting the dev_ht from the pgs using the dev->graphics_type_tag ----- */
+
+static gs_HT_objtype_t
+tag_to_HT_objtype[8] = { HT_OBJTYPE_DEFAULT,
+ HT_OBJTYPE_TEXT, /* GS_TEXT_TAG = 0x1 */
+ HT_OBJTYPE_IMAGE, /* GS_IMAGE_TAG = 0x2 */
+ HT_OBJTYPE_DEFAULT,
+ HT_OBJTYPE_VECTOR, /* GS_VECTOR_TAG = 0x4 */
+ HT_OBJTYPE_DEFAULT, HT_OBJTYPE_DEFAULT, HT_OBJTYPE_DEFAULT
+ };
+
+/* Return the selected dev_ht[] or the pgs->dev_ht[HT_OBJTYPE_DEFAULT] */
+gx_device_halftone *
+gx_select_dev_ht(const gs_gstate *pgs)
+{
+ gs_HT_objtype_t objtype;
+
+ /* This function only works with 3 bits currently. Flag here in case we add object types */
+ assert(HT_OBJTYPE_COUNT == 4);
+
+ objtype = tag_to_HT_objtype[pgs->device->graphics_type_tag & 7];
+ if (pgs->dev_ht[objtype] == NULL)
+ objtype = HT_OBJTYPE_DEFAULT;
+ return pgs->dev_ht[objtype];
+}
+
/* ------ Render Gray color. ------ */
static void
@@ -896,24 +925,21 @@ cmap_gray_halftoned(frac gray, gx_device_color * pdc,
{
uchar i, ncomps = dev->color_info.num_components;
frac cm_comps[GX_DEVICE_COLOR_MAX_COMPONENTS];
- subclass_color_mappings scm;
+ const gx_device *cmdev;
+ const gx_cm_color_map_procs *cmprocs;
/* map to the color model */
- scm = get_color_mapping_procs_subclass(dev);
- map_gray_subclass(scm, gray, cm_comps);
+ cmprocs = dev_proc(dev, get_color_mapping_procs)(dev, &cmdev);
+ cmprocs->map_gray(cmdev, gray, cm_comps);
/* apply the transfer function(s); convert to color values */
if (pgs->effective_transfer_non_identity_count == 0) {
- if (dev->color_info.polarity != GX_CINFO_POLARITY_ADDITIVE && dev->color_info.opmode == GX_CINFO_OPMODE_UNKNOWN)
- check_cmyk_color_model_comps(dev);
} else if (dev->color_info.polarity == GX_CINFO_POLARITY_ADDITIVE)
for (i = 0; i < ncomps; i++)
cm_comps[i] = gx_map_color_frac(pgs,
cm_comps[i], effective_transfer[i]);
else {
- if (dev->color_info.opmode == GX_CINFO_OPMODE_UNKNOWN)
- check_cmyk_color_model_comps(dev);
- if (dev->color_info.opmode == GX_CINFO_OPMODE) { /* CMYK-like color space */
+ if (gx_get_opmsupported(dev) == GX_CINFO_OPMSUPPORTED) { /* CMYK-like color space */
i = dev->color_info.black_component;
if (i < ncomps)
cm_comps[i] = frac_1 - gx_map_color_frac(pgs,
@@ -924,7 +950,7 @@ cmap_gray_halftoned(frac gray, gx_device_color * pdc,
(frac)(frac_1 - cm_comps[i]), effective_transfer[i]);
}
}
- if (gx_render_device_DeviceN(cm_comps, pdc, dev, pgs->dev_ht,
+ if (gx_render_device_DeviceN(cm_comps, pdc, dev, gx_select_dev_ht(pgs),
&pgs->screen_phase[select]) == 1)
gx_color_load_select(pdc, pgs, dev, select);
}
@@ -937,16 +963,15 @@ cmap_gray_direct(frac gray, gx_device_color * pdc, const gs_gstate * pgs,
frac cm_comps[GX_DEVICE_COLOR_MAX_COMPONENTS];
gx_color_value cv[GX_DEVICE_COLOR_MAX_COMPONENTS];
gx_color_index color;
- subclass_color_mappings scm;
+ const gx_device *cmdev;
+ const gx_cm_color_map_procs *cmprocs;
/* map to the color model */
- scm = get_color_mapping_procs_subclass(dev);
- map_gray_subclass(scm, gray, cm_comps);
+ cmprocs = dev_proc(dev, get_color_mapping_procs)(dev, &cmdev);
+ cmprocs->map_gray(cmdev, gray, cm_comps);
/* apply the transfer function(s); convert to color values */
if (pgs->effective_transfer_non_identity_count == 0) {
- if (dev->color_info.polarity != GX_CINFO_POLARITY_ADDITIVE && dev->color_info.opmode == GX_CINFO_OPMODE_UNKNOWN)
- check_cmyk_color_model_comps(dev);
for (i = 0; i < ncomps; i++)
cv[i] = frac2cv(cm_comps[i]);
} else if (dev->color_info.polarity == GX_CINFO_POLARITY_ADDITIVE)
@@ -956,9 +981,7 @@ cmap_gray_direct(frac gray, gx_device_color * pdc, const gs_gstate * pgs,
cv[i] = frac2cv(cm_comps[i]);
}
else {
- if (dev->color_info.opmode == GX_CINFO_OPMODE_UNKNOWN)
- check_cmyk_color_model_comps(dev);
- if (dev->color_info.opmode == GX_CINFO_OPMODE) { /* CMYK-like color space */
+ if (gx_get_opmsupported(dev) == GX_CINFO_OPMSUPPORTED) { /* CMYK-like color space */
i = dev->color_info.black_component;
if (i < ncomps)
cm_comps[i] = frac_1 - gx_map_color_frac(pgs,
@@ -981,7 +1004,7 @@ cmap_gray_direct(frac gray, gx_device_color * pdc, const gs_gstate * pgs,
color_set_pure(pdc, color);
return;
}
- if (gx_render_device_DeviceN(cm_comps, pdc, dev, pgs->dev_ht,
+ if (gx_render_device_DeviceN(cm_comps, pdc, dev, gx_select_dev_ht(pgs),
&pgs->screen_phase[select]) == 1)
gx_color_load_select(pdc, pgs, dev, select);
}
@@ -994,11 +1017,12 @@ cmap_rgb_halftoned(frac r, frac g, frac b, gx_device_color * pdc,
{
uchar i, ncomps = dev->color_info.num_components;
frac cm_comps[GX_DEVICE_COLOR_MAX_COMPONENTS];
- subclass_color_mappings scm;
+ const gx_device *cmdev;
+ const gx_cm_color_map_procs *cmprocs;
/* map to the color model */
- scm = get_color_mapping_procs_subclass(dev);
- map_rgb_subclass(scm, pgs, r, g, b, cm_comps);
+ cmprocs = dev_proc(dev, get_color_mapping_procs)(dev, &cmdev);
+ cmprocs->map_rgb(cmdev, pgs, r, g, b, cm_comps);
/* apply the transfer function(s); convert to color values */
if (pgs->effective_transfer_non_identity_count != 0) {
@@ -1012,7 +1036,7 @@ cmap_rgb_halftoned(frac r, frac g, frac b, gx_device_color * pdc,
(frac)(frac_1 - cm_comps[i]), effective_transfer[i]);
}
- if (gx_render_device_DeviceN(cm_comps, pdc, dev, pgs->dev_ht,
+ if (gx_render_device_DeviceN(cm_comps, pdc, dev, gx_select_dev_ht(pgs),
&pgs->screen_phase[select]) == 1)
gx_color_load_select(pdc, pgs, dev, select);
}
@@ -1025,11 +1049,12 @@ cmap_rgb_direct(frac r, frac g, frac b, gx_device_color * pdc,
frac cm_comps[GX_DEVICE_COLOR_MAX_COMPONENTS];
gx_color_value cv[GX_DEVICE_COLOR_MAX_COMPONENTS];
gx_color_index color;
- subclass_color_mappings scm;
+ const gx_device *cmdev;
+ const gx_cm_color_map_procs *cmprocs;
/* map to the color model */
- scm = get_color_mapping_procs_subclass(dev);
- map_rgb_subclass(scm, pgs, r, g, b, cm_comps);
+ cmprocs = dev_proc(dev, get_color_mapping_procs)(dev, &cmdev);
+ cmprocs->map_rgb(cmdev, pgs, r, g, b, cm_comps);
/* apply the transfer function(s); convert to color values */
if (pgs->effective_transfer_non_identity_count == 0) {
@@ -1056,7 +1081,7 @@ cmap_rgb_direct(frac r, frac g, frac b, gx_device_color * pdc,
color_set_pure(pdc, color);
return;
}
- if (gx_render_device_DeviceN(cm_comps, pdc, dev, pgs->dev_ht,
+ if (gx_render_device_DeviceN(cm_comps, pdc, dev, gx_select_dev_ht(pgs),
&pgs->screen_phase[select]) == 1)
gx_color_load_select(pdc, pgs, dev, select);
}
@@ -1076,11 +1101,12 @@ cmap_cmyk_direct(frac c, frac m, frac y, frac k, gx_device_color * pdc,
cmm_dev_profile_t *dev_profile;
gsicc_colorbuffer_t src_space = gsUNDEFINED;
bool gray_to_k;
- subclass_color_mappings scm;
+ const gx_device *cmdev;
+ const gx_cm_color_map_procs *cmprocs;
/* map to the color model */
- scm = get_color_mapping_procs_subclass(dev);
- map_cmyk_subclass(scm, c, m, y, k, cm_comps);
+ cmprocs = dev_proc(dev, get_color_mapping_procs)(dev, &cmdev);
+ cmprocs->map_cmyk(cmdev, c, m, y, k, cm_comps);
/* apply the transfer function(s); convert to color values */
if (dev->color_info.polarity == GX_CINFO_POLARITY_ADDITIVE) {
@@ -1115,7 +1141,7 @@ cmap_cmyk_direct(frac c, frac m, frac y, frac k, gx_device_color * pdc,
/* duplicating most of the code of this procedure. */
if (gx_device_must_halftone(dev)) {
if (gx_render_device_DeviceN(cm_comps, pdc, dev,
- pgs->dev_ht, &pgs->screen_phase[select]) == 1)
+ gx_select_dev_ht(pgs), &pgs->screen_phase[select]) == 1)
gx_color_load_select(pdc, pgs, dev, select);
return;
}
@@ -1133,111 +1159,13 @@ cmap_cmyk_direct(frac c, frac m, frac y, frac k, gx_device_color * pdc,
color_set_pure(pdc, color);
else {
if (gx_render_device_DeviceN(cm_comps, pdc, dev,
- pgs->dev_ht, &pgs->screen_phase[select]) == 1)
+ gx_select_dev_ht(pgs), &pgs->screen_phase[select]) == 1)
gx_color_load_select(pdc, pgs, dev, select);
}
}
return;
}
-static void
-cmap_rgb_alpha_halftoned(frac r, frac g, frac b, frac alpha,
- gx_device_color * pdc, const gs_gstate * pgs, gx_device * dev,
- gs_color_select_t select)
-{
- uchar i, ncomps = dev->color_info.num_components;
- frac cm_comps[GX_DEVICE_COLOR_MAX_COMPONENTS];
- subclass_color_mappings scm;
-
- /* map to the color model */
- scm = get_color_mapping_procs_subclass(dev);
- map_rgb_subclass(scm, pgs, r, g, b, cm_comps);
-
- /* pre-multiply to account for the alpha weighting */
- if (alpha != frac_1) {
-#ifdef PREMULTIPLY_TOWARDS_WHITE
- frac alpha_bias = frac_1 - alpha;
-#else
- frac alpha_bias = 0;
-#endif
-
- for (i = 0; i < ncomps; i++)
- cm_comps[i] = (frac)((long)cm_comps[i] * alpha) / frac_1 + alpha_bias;
- }
-
- /* apply the transfer function(s); convert to color values */
- if (pgs->effective_transfer_non_identity_count != 0) {
- if (dev->color_info.polarity == GX_CINFO_POLARITY_ADDITIVE)
- for (i = 0; i < ncomps; i++)
- cm_comps[i] = gx_map_color_frac(pgs,
- cm_comps[i], effective_transfer[i]);
- else
- for (i = 0; i < ncomps; i++)
- cm_comps[i] = frac_1 - gx_map_color_frac(pgs,
- (frac)(frac_1 - cm_comps[i]), effective_transfer[i]);
- }
-
- if (gx_render_device_DeviceN(cm_comps, pdc, dev, pgs->dev_ht,
- &pgs->screen_phase[select]) == 1)
- gx_color_load_select(pdc, pgs, dev, select);
-}
-
-static void
-cmap_rgb_alpha_direct(frac r, frac g, frac b, frac alpha, gx_device_color * pdc,
- const gs_gstate * pgs, gx_device * dev, gs_color_select_t select)
-{
- uchar i, ncomps = dev->color_info.num_components;
- frac cm_comps[GX_DEVICE_COLOR_MAX_COMPONENTS];
- gx_color_value cv_alpha, cv[GX_DEVICE_COLOR_MAX_COMPONENTS];
- gx_color_index color;
- subclass_color_mappings scm;
-
- /* map to the color model */
- scm = get_color_mapping_procs_subclass(dev);
- map_rgb_subclass(scm, pgs, r, g, b, cm_comps);
-
- /* pre-multiply to account for the alpha weighting */
- if (alpha != frac_1) {
-#ifdef PREMULTIPLY_TOWARDS_WHITE
- frac alpha_bias = frac_1 - alpha;
-#else
- frac alpha_bias = 0;
-#endif
-
- for (i = 0; i < ncomps; i++)
- cm_comps[i] = (frac)((long)cm_comps[i] * alpha) / frac_1 + alpha_bias;
- }
-
- /* apply the transfer function(s); convert to color values */
- if (pgs->effective_transfer_non_identity_count == 0)
- for (i = 0; i < ncomps; i++)
- cv[i] = frac2cv(cm_comps[i]);
- else if (dev->color_info.polarity == GX_CINFO_POLARITY_ADDITIVE)
- for (i = 0; i < ncomps; i++)
- cv[i] = frac2cv(gx_map_color_frac(pgs,
- cm_comps[i], effective_transfer[i]));
- else
- for (i = 0; i < ncomps; i++)
- cv[i] = frac2cv(frac_1 - gx_map_color_frac(pgs,
- (frac)(frac_1 - cm_comps[i]), effective_transfer[i]));
-
- /* encode as a color index */
- if (dev_proc(dev, map_rgb_alpha_color) != gx_default_map_rgb_alpha_color &&
- (cv_alpha = frac2cv(alpha)) != gx_max_color_value)
- color = dev_proc(dev, map_rgb_alpha_color)(dev, cv[0], cv[1], cv[2], cv_alpha);
- else
- color = dev_proc(dev, encode_color)(dev, cv);
-
- /* check if the encoding was successful; we presume failure is rare */
- if (color != gx_no_color_index) {
- color_set_pure(pdc, color);
- return;
- }
- if (gx_render_device_DeviceN(cm_comps, pdc, dev, pgs->dev_ht,
- &pgs->screen_phase[select]) == 1)
- gx_color_load_select(pdc, pgs, dev, select);
-}
-
/* ------ Render Separation All color. ------ */
/*
@@ -1249,19 +1177,26 @@ cmap_rgb_alpha_direct(frac r, frac g, frac b, frac alpha, gx_device_color * pdc,
* pcolor_component_map - Map from DeviceN to the Devices colorants.
* A negative value indicates component is not to be mapped.
* plist - Pointer to list for mapped components
+ * num_comps - num_comps that we need to zero (may be more than
+ * is set if we are mapping values for an NCLR ICC profile
+ * via an alternate tint transform for a sep value) --
+ * i.e. cmyk+og values and we may have some spots that
+ * are supported but may have reached the limit and
+ * using the alt tint values. Need to make sure to zero all.
*
* Returns:
* Mapped components in plist.
*/
static inline void
map_components_to_colorants(const frac * pcc,
- const gs_devicen_color_map * pcolor_component_map, frac * plist)
+ const gs_devicen_color_map * pcolor_component_map, frac * plist,
+ int num_colorants)
{
- int i = pcolor_component_map->num_colorants - 1;
+ int i;
int pos;
/* Clear all output colorants first */
- for (; i >= 0; i--) {
+ for (i = num_colorants - 1; i >= 0; i--) {
plist[i] = frac_0;
}
@@ -1426,7 +1361,8 @@ cmap_separation_halftoned(frac all, gx_device_color * pdc,
cm_comps[i] = comp_value;
} else {
/* map to the color model */
- map_components_to_colorants(&all, &(pgs->color_component_map), cm_comps);
+ map_components_to_colorants(&all, &(pgs->color_component_map), cm_comps,
+ pgs->color_component_map.num_colorants);
}
if (devicen_has_cmyk(dev, des_profile) &&
@@ -1447,7 +1383,7 @@ cmap_separation_halftoned(frac all, gx_device_color * pdc,
(frac)(frac_1 - cm_comps[i]), effective_transfer[i]);
}
- if (gx_render_device_DeviceN(cm_comps, pdc, dev, pgs->dev_ht,
+ if (gx_render_device_DeviceN(cm_comps, pdc, dev, gx_select_dev_ht(pgs),
&pgs->screen_phase[select]) == 1)
gx_color_load_select(pdc, pgs, dev, select);
}
@@ -1493,7 +1429,8 @@ cmap_separation_direct(frac all, gx_device_color * pdc, const gs_gstate * pgs,
}
else {
/* map to the color model */
- map_components_to_colorants(&comp_value, &(pgs->color_component_map), cm_comps);
+ map_components_to_colorants(&comp_value, &(pgs->color_component_map), cm_comps,
+ pgs->color_component_map.num_colorants);
}
/* Check if we have the standard colorants. If yes, then we will apply
@@ -1572,7 +1509,7 @@ cmap_separation_direct(frac all, gx_device_color * pdc, const gs_gstate * pgs,
return;
}
- if (gx_render_device_DeviceN(cm_comps, pdc, dev, pgs->dev_ht,
+ if (gx_render_device_DeviceN(cm_comps, pdc, dev, gx_select_dev_ht(pgs),
&pgs->screen_phase[select]) == 1)
gx_color_load_select(pdc, pgs, dev, select);
}
@@ -1598,7 +1535,8 @@ cmap_devicen_halftoned(const frac * pcc,
gsicc_extract_profile(dev->graphics_type_tag,
dev_profile, &des_profile, &render_cond);
/* map to the color model */
- map_components_to_colorants(pcc, &(pgs->color_component_map), cm_comps);
+ map_components_to_colorants(pcc, &(pgs->color_component_map), cm_comps,
+ pgs->color_component_map.num_colorants);
/* See comments in cmap_devicen_direct for details on below operations */
if (devicen_has_cmyk(dev, des_profile) &&
des_profile->data_cs == gsCMYK &&
@@ -1618,7 +1556,7 @@ cmap_devicen_halftoned(const frac * pcc,
}
/* We need to finish halftoning */
- if (gx_render_device_DeviceN(cm_comps, pdc, dev, pgs->dev_ht,
+ if (gx_render_device_DeviceN(cm_comps, pdc, dev, gx_select_dev_ht(pgs),
&pgs->screen_phase[select]) == 1)
gx_color_load_select(pdc, pgs, dev, select);
}
@@ -1647,9 +1585,10 @@ cmap_devicen_direct(const frac * pcc,
/* map to the color model */
if (dev_profile->spotnames != NULL && dev_profile->spotnames->equiv_cmyk_set) {
map_components_to_colorants(pcc, dev_profile->spotnames->color_map,
- cm_comps);
+ cm_comps, ncomps);
} else {
- map_components_to_colorants(pcc, &(pgs->color_component_map), cm_comps);
+ map_components_to_colorants(pcc, &(pgs->color_component_map), cm_comps,
+ pgs->color_component_map.num_colorants);
}
/* Check if we have the standard colorants. If yes, then we will apply
ICC color management to those colorants. To understand why, consider
@@ -1713,7 +1652,7 @@ cmap_devicen_direct(const frac * pcc,
color_set_pure(pdc, color);
return;
}
- if (gx_render_device_DeviceN(cm_comps, pdc, dev, pgs->dev_ht,
+ if (gx_render_device_DeviceN(cm_comps, pdc, dev, gx_select_dev_ht(pgs),
&pgs->screen_phase[select]) == 1)
gx_color_load_select(pdc, pgs, dev, select);
}
@@ -1814,6 +1753,21 @@ gx_default_w_b_map_color_rgb(gx_device * dev, gx_color_index color,
return 0;
}
+gx_color_index
+gx_default_w_b_mono_encode_color(gx_device *dev, const gx_color_value cv[])
+{
+ return cv[0] > gx_max_color_value / 2 ? (gx_color_index)1
+ : (gx_color_index)0;
+}
+
+int
+gx_default_w_b_mono_decode_color(gx_device * dev, gx_color_index color,
+ gx_color_value pgray[1])
+{ /* Map 0 to max_value, 1 to 0. */
+ pgray[0] = -(gx_color_value) color;
+ return 0;
+}
+
/* Black-on-white */
gx_color_index
gx_default_b_w_map_rgb_color(gx_device * dev, const gx_color_value cv[])
@@ -1835,6 +1789,21 @@ gx_default_b_w_map_color_rgb(gx_device * dev, gx_color_index color,
return 0;
}
+gx_color_index
+gx_default_b_w_mono_encode_color(gx_device *dev, const gx_color_value cv[])
+{
+ return cv[0] > gx_max_color_value / 2 ? (gx_color_index)0
+ : (gx_color_index)1;
+}
+
+int
+gx_default_b_w_mono_decode_color(gx_device * dev, gx_color_index color,
+ gx_color_value pgray[1])
+{ /* Map 0 to max_value, 1 to 0. */
+ pgray[0] = -((gx_color_value) color ^ 1);
+ return 0;
+}
+
/* RGB mapping for gray-scale devices */
gx_color_index
@@ -1865,6 +1834,26 @@ gx_default_gray_map_color_rgb(gx_device * dev, gx_color_index color,
}
gx_color_index
+gx_default_gray_encode_color(gx_device * dev, const gx_color_value cv[])
+{
+ gx_color_value gray = (cv[0] * dev->color_info.max_gray +
+ (gx_max_color_value / 2)) / gx_max_color_value;
+
+ return gray;
+}
+
+int
+gx_default_gray_decode_color(gx_device * dev, gx_color_index color,
+ gx_color_value *cv)
+{
+ gx_color_value gray = (gx_color_value)
+ (color * gx_max_color_value / dev->color_info.max_gray);
+
+ cv[0] = gray;
+ return 0;
+}
+
+gx_color_index
gx_default_8bit_map_gray_color(gx_device * dev, const gx_color_value cv[])
{
gx_color_index color = gx_color_value_to_byte(cv[0]);
@@ -2042,23 +2031,22 @@ cmyk_16bit_map_color_cmyk(gx_device * dev, gx_color_index color,
return 0;
}
-/* Default mapping between RGB+alpha and RGB. */
-
-gx_color_index
-gx_default_map_rgb_alpha_color(gx_device * dev,
- gx_color_value r, gx_color_value g, gx_color_value b, gx_color_value alpha)
-{ /* Colors have been premultiplied: we don't need to do it here. */
- gx_color_value cv[3];
- cv[0] = r; cv[1] = g; cv[2] = b;
- return (*dev_proc(dev, map_rgb_color))(dev, cv);
-}
-
int
-gx_default_map_color_rgb_alpha(gx_device * dev, gx_color_index color,
- gx_color_value prgba[4])
-{
- prgba[3] = gx_max_color_value; /* alpha = 1 */
- return (*dev_proc(dev, map_color_rgb)) (dev, color, prgba);
+cmyk_16bit_map_color_rgb(gx_device * dev, gx_color_index color,
+ gx_color_value prgb[3])
+{
+ gx_color_value c = ((color >> 24) >> 24) & 0xffff;
+ gx_color_value m = ((color >> 16) >> 16) & 0xffff;
+ gx_color_value y = ( color >> 16) & 0xffff;
+ gx_color_value not_k = (~color ) & 0xffff;
+ int r = not_k - c;
+ int g = not_k - m;
+ int b = not_k - y;
+
+ prgb[0] = (r < 0 ? 0 : r);
+ prgb[1] = (g < 0 ? 0 : g);
+ prgb[2] = (b < 0 ? 0 : b);
+ return 0;
}
frac
@@ -2093,7 +2081,7 @@ cmapper_transfer_halftone_add(gx_cmapper_t *data)
}
/* Halftoning */
if (gx_render_device_DeviceN(&(cv_frac[0]), &data->devc, dev,
- pgs->dev_ht, &pgs->screen_phase[select]) == 1)
+ gx_select_dev_ht(pgs), &pgs->screen_phase[select]) == 1)
gx_color_load_select(&data->devc, pgs, dev, select);
}
@@ -2122,7 +2110,7 @@ cmapper_transfer_halftone_op(gx_cmapper_t *data)
}
/* Halftoning */
if (gx_render_device_DeviceN(&(cv_frac[0]), &data->devc, dev,
- pgs->dev_ht, &pgs->screen_phase[select]) == 1)
+ gx_select_dev_ht(pgs), &pgs->screen_phase[select]) == 1)
gx_color_load_select(&data->devc, pgs, dev, select);
}
@@ -2146,7 +2134,7 @@ cmapper_transfer_halftone_sub(gx_cmapper_t *data)
}
/* Halftoning */
if (gx_render_device_DeviceN(&(cv_frac[0]), &data->devc, dev,
- pgs->dev_ht, &pgs->screen_phase[select]) == 1)
+ gx_select_dev_ht(pgs), &pgs->screen_phase[select]) == 1)
gx_color_load_select(&data->devc, pgs, dev, select);
}
@@ -2242,7 +2230,7 @@ cmapper_halftone(gx_cmapper_t *data)
cv_frac[i] = cv2frac(pconc[i]);
}
if (gx_render_device_DeviceN(&(cv_frac[0]), &data->devc, dev,
- pgs->dev_ht, &pgs->screen_phase[select]) == 1)
+ gx_select_dev_ht(pgs), &pgs->screen_phase[select]) == 1)
gx_color_load_select(&data->devc, pgs, dev, select);
}
@@ -2274,8 +2262,6 @@ gx_get_cmapper(gx_cmapper_t *data, const gs_gstate *pgs,
data->select = select;
data->devc.type = gx_dc_type_none;
data->direct = 0;
- if (has_transfer && dev->color_info.opmode == GX_CINFO_OPMODE_UNKNOWN)
- check_cmyk_color_model_comps(dev);
/* Per spec. Images with soft mask, and the mask, do not use transfer function */
if (pgs->effective_transfer_non_identity_count == 0 ||
(dev_proc(dev, dev_spec_op)(dev, gxdso_in_smask, NULL, 0)) > 0)
@@ -2286,7 +2272,7 @@ gx_get_cmapper(gx_cmapper_t *data, const gs_gstate *pgs,
data->set_color = cmapper_transfer_halftone_add;
else
data->set_color = cmapper_transfer_add;
- } else if (dev->color_info.opmode == GX_CINFO_OPMODE) {
+ } else if (gx_get_opmsupported(dev) == GX_CINFO_OPMSUPPORTED) {
if (has_halftone)
data->set_color = cmapper_transfer_halftone_op;
else
@@ -2327,8 +2313,6 @@ cmap_transfer_halftone(gx_color_value *pconc, gx_device_color * pdc,
/* apply the transfer function(s) */
if (has_transfer) {
if (pgs->effective_transfer_non_identity_count == 0) {
- if (dev->color_info.polarity != GX_CINFO_POLARITY_ADDITIVE && dev->color_info.opmode == GX_CINFO_OPMODE_UNKNOWN)
- check_cmyk_color_model_comps(dev);
for (i = 0; i < ncomps; i++)
cv_frac[i] = cv2frac(pconc[i]);
} else if (dev->color_info.polarity == GX_CINFO_POLARITY_ADDITIVE) {
@@ -2338,10 +2322,7 @@ cmap_transfer_halftone(gx_color_value *pconc, gx_device_color * pdc,
frac_value, effective_transfer[i]);
}
} else {
- if (dev->color_info.opmode == GX_CINFO_OPMODE_UNKNOWN) {
- check_cmyk_color_model_comps(dev);
- }
- if (dev->color_info.opmode == GX_CINFO_OPMODE) { /* CMYK-like color space */
+ if (gx_get_opmsupported(dev) == GX_CINFO_OPMSUPPORTED) { /* CMYK-like color space */
uint k = dev->color_info.black_component;
for (i = 0; i < ncomps; i++) {
frac_value = cv2frac(pconc[i]);
@@ -2371,7 +2352,7 @@ cmap_transfer_halftone(gx_color_value *pconc, gx_device_color * pdc,
/* Halftoning */
if (has_halftone) {
if (gx_render_device_DeviceN(&(cv_frac[0]), pdc, dev,
- pgs->dev_ht, &pgs->screen_phase[select]) == 1)
+ gx_select_dev_ht(pgs), &pgs->screen_phase[select]) == 1)
gx_color_load_select(pdc, pgs, dev, select);
} else {
/* We have a frac value from the transfer function. Do the encode.
@@ -2396,17 +2377,12 @@ cmap_transfer(gx_color_value *pconc, const gs_gstate * pgs, gx_device * dev)
/* apply the transfer function(s) */
if (pgs->effective_transfer_non_identity_count == 0) {
- if (dev->color_info.polarity != GX_CINFO_POLARITY_ADDITIVE && dev->color_info.opmode == GX_CINFO_OPMODE_UNKNOWN)
- check_cmyk_color_model_comps(dev);
} else if (dev->color_info.polarity == GX_CINFO_POLARITY_ADDITIVE)
for (i = 0; i < ncomps; i++)
pconc[i] = frac2cv(gx_map_color_frac(pgs,
cv2frac(pconc[i]), effective_transfer[i]));
else {
- if (dev->color_info.opmode == GX_CINFO_OPMODE_UNKNOWN) {
- check_cmyk_color_model_comps(dev);
- }
- if (dev->color_info.opmode == GX_CINFO_OPMODE) { /* CMYK-like color space */
+ if (gx_get_opmsupported(dev) == GX_CINFO_OPMSUPPORTED) { /* CMYK-like color space */
i = dev->color_info.black_component;
if (i < ncomps)
pconc[i] = frac2cv(frac_1 - gx_map_color_frac(pgs,
@@ -2433,10 +2409,7 @@ cmap_transfer_plane(gx_color_value *pconc, const gs_gstate *pgs,
cv_frac = gx_map_color_frac(pgs, frac_value, effective_transfer[plane]);
pconc[0] = frac2cv(cv_frac);
} else {
- if (dev->color_info.opmode == GX_CINFO_OPMODE_UNKNOWN) {
- check_cmyk_color_model_comps(dev);
- }
- if (dev->color_info.opmode == GX_CINFO_OPMODE) { /* CMYK-like color space */
+ if (gx_get_opmsupported(dev) == GX_CINFO_OPMSUPPORTED) { /* CMYK-like color space */
uint k = dev->color_info.black_component;
if (plane == k) {
frac_value = cv2frac(pconc[0]);
@@ -2457,7 +2430,6 @@ cmap_transfer_plane(gx_color_value *pconc, const gs_gstate *pgs,
bool
gx_device_uses_std_cmap_procs(gx_device * dev, const gs_gstate * pgs)
{
- subclass_color_mappings scm;
const gx_cm_color_map_procs *pprocs;
gsicc_rendering_param_t render_cond;
cmm_dev_profile_t *dev_profile = NULL;
@@ -2468,16 +2440,10 @@ gx_device_uses_std_cmap_procs(gx_device * dev, const gs_gstate * pgs)
dev_profile, &des_profile, &render_cond);
if (des_profile != NULL) {
- scm = get_color_mapping_procs_subclass(dev);
- pprocs = scm.procs;
- /* FIXME: This looks wrong to me. Presumably we should be finding
- * the parentmost device, looking at the procs for that, and if
- * they are forwarding ones, getting the procs for the forwarded
- * device. This is NOT what this code does. */
+ const gx_device *cmdev;
+
+ pprocs = dev_proc(dev, get_color_mapping_procs)(dev, &cmdev);
/* Check if they are forwarding procs */
- if (fwd_uses_fwd_cmap_procs(dev)) {
- pprocs = fwd_get_target_cmap_procs(dev);
- }
switch(des_profile->num_comps) {
case 1:
if (pprocs == &DeviceGray_procs) {
diff --git a/base/gxcmap.h b/base/gxcmap.h
index b626e632..4197a48d 100644
--- a/base/gxcmap.h
+++ b/base/gxcmap.h
@@ -38,9 +38,6 @@
void proc(frac, frac, frac, frac, gx_device_color *,\
const gs_gstate *, gx_device *, gs_color_select_t,\
const gs_color_space *)
-#define cmap_proc_rgb_alpha(proc)\
- void proc(frac, frac, frac, frac, gx_device_color *,\
- const gs_gstate *, gx_device *, gs_color_select_t)
#define cmap_proc_separation(proc)\
void proc(frac, gx_device_color *, const gs_gstate *,\
gx_device *, gs_color_select_t, const gs_color_space *)
@@ -55,17 +52,17 @@
* device color model. Any unused component will be mapped to 0.
*/
#define cm_map_proc_gray(proc) \
- void proc (gx_device * dev, frac gray, \
+ void proc (const gx_device * dev, frac gray, \
frac * out)
#define cm_map_proc_rgb(proc) \
- void proc (gx_device * dev, \
+ void proc (const gx_device * dev, \
const gs_gstate *pgs, \
frac r, frac g, frac b, \
frac * out)
#define cm_map_proc_cmyk(proc) \
- void proc (gx_device * dev, \
+ void proc (const gx_device * dev, \
frac c, frac m, frac y, frac k, \
frac * out)
@@ -110,7 +107,6 @@ struct gx_color_map_procs_s {
cmap_proc_gray((*map_gray));
cmap_proc_rgb((*map_rgb));
cmap_proc_cmyk((*map_cmyk));
- cmap_proc_rgb_alpha((*map_rgb_alpha));
cmap_proc_separation((*map_separation));
cmap_proc_devicen((*map_devicen));
cmap_proc_is_halftoned((*is_halftoned));
@@ -142,8 +138,6 @@ void gx_set_cmap_procs(gs_gstate *, const gx_device *);
((pgs)->cmap_procs->map_rgb)(cr, cg, cb, pdc, pgs, dev, select)
#define gx_remap_concrete_cmyk(cc, cm, cy, ck, pdc, pgs, dev, select, pcs)\
((pgs)->cmap_procs->map_cmyk)(cc, cm, cy, ck, pdc, pgs, dev, select, pcs)
-#define gx_remap_concrete_rgb_alpha(cr, cg, cb, ca, pdc, pgs, dev, select)\
- ((pgs)->cmap_procs->map_rgb_alpha)(cr, cg, cb, ca, pdc, pgs, dev, select)
#define gx_remap_concrete_separation(pcc, pdc, pgs, dev, select, pcs)\
((pgs)->cmap_procs->map_separation)(pcc, pdc, pgs, dev, select, pcs)
#define gx_remap_concrete_devicen(pcc, pdc, pgs, dev, select, pcs)\
@@ -158,7 +152,7 @@ void gx_set_cmap_procs(gs_gstate *, const gx_device *);
color model.
*/
#define dev_t_proc_get_color_mapping_procs(proc, dev_t) \
- const gx_cm_color_map_procs * (proc)(const dev_t * dev)
+ const gx_cm_color_map_procs * (proc)(const dev_t * dev, const gx_device **)
#define dev_proc_get_color_mapping_procs(proc) \
dev_t_proc_get_color_mapping_procs(proc, gx_device)
@@ -262,8 +256,6 @@ frac gx_unit_frac(float fvalue);
images */
bool gx_device_uses_std_cmap_procs(gx_device * dev,
const gs_gstate * pgs);
-bool fwd_uses_fwd_cmap_procs(gx_device * dev);
-const gx_cm_color_map_procs* fwd_get_target_cmap_procs(gx_device * dev);
void cmap_transfer_halftone(gx_color_value *pconc, gx_device_color * pdc,
const gs_gstate * pgs, gx_device * dev, bool has_transfer,
bool has_halftone, gs_color_select_t select);
@@ -290,4 +282,8 @@ void gx_get_cmapper(gx_cmapper_t *cmapper, const gs_gstate *pgs,
gx_device *dev, bool has_transfer, bool has_halftone,
gs_color_select_t select);
+/* Return the dev_ht[] selected by the pgs->device->graphics_tag */
+/* or the pgs->dev_ht[HT_OBJTYPE_DEFAULT] */
+gx_device_halftone *gx_select_dev_ht(const gs_gstate *pgs);
+
#endif /* gxcmap_INCLUDED */
diff --git a/base/gxcspace.h b/base/gxcspace.h
index 40fbee16..56f2d183 100644
--- a/base/gxcspace.h
+++ b/base/gxcspace.h
@@ -152,7 +152,7 @@ struct gs_color_space_type_s {
/* Free contents of composite colorspace objects. */
#define cs_proc_final(proc)\
- void proc(const gs_color_space *)
+ void proc(gs_color_space *)
cs_proc_final((*final));
/* Adjust reference counts of indirect color components. */
@@ -166,29 +166,8 @@ struct gs_color_space_type_s {
#define cs_proc_adjust_color_count(proc)\
void proc(const gs_client_color *, const gs_color_space *, int)
- /* Adjust the color reference counts for the current space. */
-#define cs_adjust_color_count(pgs, delta)\
- (*gs_currentcolorspace_inline(pgs)->type->adjust_color_count)\
- (gs_currentcolor_inline(pgs), gs_currentcolorspace_inline(pgs), delta)
- /* Adjust the color reference counts for the swapped space (i.e.
- * the one that is not current). */
-#define cs_adjust_swappedcolor_count(pgs, delta)\
- (*gs_swappedcolorspace_inline(pgs)->type->adjust_color_count)\
- (gs_swappedcolor_inline(pgs), gs_swappedcolorspace_inline(pgs), delta)
-
cs_proc_adjust_color_count((*adjust_color_count));
-/* Adjust both reference counts for the current color/colorspace. */
-#define cs_adjust_counts(pgs, delta)\
- cs_adjust_color_count(pgs, delta); \
- rc_adjust_const(gs_currentcolorspace_inline(pgs), delta, "cs_adjust_counts")
-
-/* Adjust both reference counts for the swapped (i.e. non-current)
- * color/colorspace. */
-#define cs_adjust_swappedcounts(pgs, delta)\
- cs_adjust_swappedcolor_count(pgs, delta); \
- rc_adjust_const(gs_swappedcolorspace_inline(pgs), delta, "cs_adjust_swappedcounts")
-
/* Serialization. */
/*
* Note : We don't include *(pcs)->type into serialization,
diff --git a/base/gxdcolor.c b/base/gxdcolor.c
index 20116fd8..87de8001 100644
--- a/base/gxdcolor.c
+++ b/base/gxdcolor.c
@@ -107,14 +107,15 @@ gx_color_index
gx_device_black(gx_device *dev)
{
if (dev->cached_colors.black == gx_no_color_index) {
- subclass_color_mappings scm;
uchar i, ncomps = dev->color_info.num_components;
frac cm_comps[GX_DEVICE_COLOR_MAX_COMPONENTS];
gx_color_value cv[GX_DEVICE_COLOR_MAX_COMPONENTS];
+ const gx_device *cmdev;
+ const gx_cm_color_map_procs *cmprocs;
- scm = get_color_mapping_procs_subclass(dev);
+ cmprocs = dev_proc(dev, get_color_mapping_procs)(dev, &cmdev);
/* Get color components for black (gray = 0) */
- map_gray_subclass(scm, frac_0, cm_comps);
+ cmprocs->map_gray(cmdev, frac_0, cm_comps);
for (i = 0; i < ncomps; i++)
cv[i] = frac2cv(cm_comps[i]);
@@ -127,14 +128,15 @@ gx_color_index
gx_device_white(gx_device *dev)
{
if (dev->cached_colors.white == gx_no_color_index) {
- subclass_color_mappings scm;
uchar i, ncomps = dev->color_info.num_components;
frac cm_comps[GX_DEVICE_COLOR_MAX_COMPONENTS];
gx_color_value cv[GX_DEVICE_COLOR_MAX_COMPONENTS];
+ const gx_device *cmdev;
+ const gx_cm_color_map_procs *cmprocs;
- scm = get_color_mapping_procs_subclass(dev);
+ cmprocs = dev_proc(dev, get_color_mapping_procs)(dev, &cmdev);
/* Get color components for white (gray = 1) */
- map_gray_subclass(scm, frac_1, cm_comps);
+ cmprocs->map_gray(cmdev, frac_1, cm_comps);
for (i = 0; i < ncomps; i++)
cv[i] = frac2cv(cm_comps[i]);
@@ -563,14 +565,20 @@ gx_devn_write_color(
uchar ncomps = cdev->clist_color_info.num_components; /* Could be different than target if 1.4 device */
gx_color_index mask = 0x1, comp_bits = 0;
+ if_debug1m(gs_debug_flag_clist_color, dev->memory,
+ "[clist_color] Writing devn color, %d components [ ", ncomps);
+
/* First find the number of non zero values */
for (i = 0; i < ncomps; i++, mask <<= 1) {
+ if_debug1m(gs_debug_flag_clist_color, dev->memory,
+ "%d ", pdevc->colors.devn.values[i]);
if (pdevc->colors.devn.values[i] != 0) {
comp_bits |= mask;
count++;
}
}
mask = comp_bits;
+ if_debug0m(gs_debug_flag_clist_color, dev->memory, "]\n");
num_bytes1 = sizeof(gx_color_index);
num_bytes = num_bytes1 + count * 2 + 1; /* One for the tag byte */
@@ -706,6 +714,9 @@ gx_devn_read_color(
pos++;
num_bytes++;
+ if_debug1m(gs_debug_flag_clist_color, dev->memory,
+ "[clist_color] Reading devn color, %d components [ ", ncomps);
+
/* Now the data */
for (i = 0; i < ncomps; i++) {
if (mask & 1) {
@@ -717,8 +728,11 @@ gx_devn_read_color(
} else {
values[i] = 0;
}
+ if_debug1m(gs_debug_flag_clist_color, dev->memory,
+ "%d ", values[i]);
mask >>= 1;
}
+ if_debug0m(gs_debug_flag_clist_color, dev->memory, "]\n");
return num_bytes;
}
@@ -826,13 +840,7 @@ gx_dc_pure_fill_rectangle(const gx_device_color * pdevc, int x, int y,
colors[0] = colors[1] = pdevc->colors.pure;
if (source == NULL)
set_rop_no_source(source, no_source, dev);
- if (source->planar_height == 0)
- return (*dev_proc(dev, strip_copy_rop))
- (dev, source->sdata, source->sourcex, source->sraster,
- source->id, (source->use_scolors ? source->scolors : NULL),
- NULL /*arbitrary */ , colors, x, y, w, h, 0, 0, lop);
- else
- return (*dev_proc(dev, strip_copy_rop2))
+ return (*dev_proc(dev, strip_copy_rop2))
(dev, source->sdata, source->sourcex, source->sraster,
source->id, (source->use_scolors ? source->scolors : NULL),
NULL /*arbitrary */ , colors, x, y, w, h, 0, 0, lop, source->planar_height);
@@ -874,10 +882,10 @@ gx_dc_pure_fill_masked(const gx_device_color * pdevc, const byte * data,
if (!rop3_uses_S(lop))
lop |= rop3_S;
- return (*dev_proc(dev, strip_copy_rop))
+ return (*dev_proc(dev, strip_copy_rop2))
(dev, data, data_x, raster, id, scolors,
NULL, tcolors, x, y, w, h, 0, 0,
- lop_sanitize(lop | lop_S_transparent));
+ lop_sanitize(lop | lop_S_transparent), 0);
}
}
@@ -1018,7 +1026,6 @@ gx_complete_halftone(gx_device_color *pdevc, int num_comps, gx_device_halftone *
pdevc->type = gx_dc_type_ht_colored;
pdevc->colors.colored.c_ht = pdht;
pdevc->colors.colored.num_components = num_comps;
- pdevc->colors.colored.alpha = max_ushort;
for (i = 0; i < num_comps; i++)
mask |= ((pdevc->colors.colored.c_level[i] != 0 ? 1 : 0) << i);
pdevc->colors.colored.plane_mask = mask;
@@ -1146,8 +1153,11 @@ gx_dc_write_color(
/* check for adequate space */
if (*psize < num_bytes) {
+ uint x = *psize;
*psize = num_bytes;
- return_error(gs_error_rangecheck);
+ if (x != 0)
+ return_error(gs_error_rangecheck);
+ return gs_error_rangecheck;
}
*psize = num_bytes;
diff --git a/base/gxdevcli.h b/base/gxdevcli.h
index f41f8d11..9364349c 100644
--- a/base/gxdevcli.h
+++ b/base/gxdevcli.h
@@ -116,7 +116,7 @@
/* ---------------- Auxiliary types and structures ---------------- */
/* We need an abstract type for the pattern instance, */
-/* for pattern_manage. */
+/* for pattern management. */
typedef struct gs_pattern1_instance_s gs_pattern1_instance_t;
/* Define the type for colors passed to the higher-level procedures. */
@@ -241,10 +241,10 @@ typedef enum {
*
*/
typedef enum {
- GX_CINFO_OPMODE_UNKNOWN = -1,
- GX_CINFO_OPMODE_NOT = 0,
- GX_CINFO_OPMODE = 1
-} gx_cm_opmode_t;
+ GX_CINFO_OPMSUPPORTED_UNKNOWN = -1,
+ GX_CINFO_OPMSUPPORTED_NOT = 0,
+ GX_CINFO_OPMSUPPORTED = 1
+} gx_cm_opmsupported_t;
/* component index value used to indicate no color component. */
#define GX_CINFO_COMP_NO_INDEX 0xff
@@ -420,15 +420,12 @@ typedef struct gx_device_color_info_s {
* Most such color spaces will have the name DeviceCMYK, but it is
* also possible for DeviceN color models this behavior.
*
- * If opmode has the value GX_CINFO_OPMODE, the process_comps will
+ * If opmsupported has the value GX_CINFO_OPMSUPPORTED, the process_comps will
* be a bit mask, with the (1 << i) bit set if i'th component is the
* cyan, magenta, yellow, or black component and black_component will
* be set to the index of a black component.
- *
- * A new mode GX_CINFO_OPMODE_RGB was added so that an RGB device could
- * simulate CMYK overprinting.
*/
- gx_cm_opmode_t opmode;
+ gx_cm_opmsupported_t opmsupported;
gx_color_index process_comps;
uint black_component;
bool use_antidropout_downscaler;
@@ -459,7 +456,7 @@ static inline int colors_are_separable_and_linear(gx_device_color_info *info)
{ 0 } /* component bits */, \
{ 0 } /* component mask */, \
cn /* process color name */, \
- GX_CINFO_OPMODE_UNKNOWN /* opmode */, \
+ GX_CINFO_OPMSUPPORTED_UNKNOWN /* opmsupported */, \
0 /* process_cmps */ }
/*
@@ -643,21 +640,15 @@ typedef struct gx_stroked_gradient_recognizer_s {
/* ---------------- Device structure ---------------- */
/*
- * Define the generic device structure. The device procedures can
- * have two different configurations:
- *
- * - Statically initialized devices predating release 2.8.1
- * set the static_procs pointer to point to a separate procedure record,
- * and do not initialize procs.
+ * Define the generic device structure.
*
- * - Statically initialized devices starting with release 2.8.1,
- * and all dynamically created device instances,
- * set the static_procs pointer to 0, and initialize procs.
+ * All devices start off with no device procs. The initialize_device_procs
+ * function is called as soon as the device is copied from its prototype,
+ * and that fills in the procs table with the device procedure pointers.
+ * This can never fail.
*
- * The gx_device_set_procs procedure converts the first of these to
- * the second, which is what all client code starting in 2.8.1 expects
- * (using the procs record, not the static_procs pointer, to call the
- * driver procedures).
+ * Next, the 'initialize_device' proc (if there is one) is called to do
+ * the minimal initialization required for a device.
*
* The choice of the name Margins (rather than, say, HWOffset), and the
* specification in terms of a default device resolution rather than
@@ -717,11 +708,16 @@ typedef struct gdev_pagelist_s {
int PagesSize;
} gdev_pagelist;
+#define dev_t_proc_initialize_device_procs(proc, dev_t)\
+ void proc(dev_t *dev)
+#define dev_proc_initialize_device_procs(proc)\
+ dev_t_proc_initialize_device_procs((proc), gx_device)
+
#define gx_device_common\
int params_size; /* OBSOLETE if stype != 0: */\
/* size of this structure */\
- const gx_device_procs *static_procs; /* OBSOLETE */\
- /* pointer to procs */\
+ dev_proc_initialize_device_procs(*initialize_device_procs);\
+ /* initialize_device_procs */\
const char *dname; /* the device name */\
gs_memory_t *memory; /* (0 iff static prototype) */\
gs_memory_type_ptr_t stype; /* memory manager structure type, */\
@@ -864,6 +860,11 @@ typedef enum FILTER_FLAGS {
/* Define macros for declaring device procedures. */
+#define dev_t_proc_initialize_device(proc, dev_t)\
+ int proc(dev_t *dev)
+#define dev_proc_initialize_device(proc)\
+ dev_t_proc_initialize_device(proc, gx_device)
+
#define dev_t_proc_open_device(proc, dev_t)\
int proc(dev_t *dev)
#define dev_proc_open_device(proc)\
@@ -906,14 +907,6 @@ typedef enum FILTER_FLAGS {
#define dev_proc_fill_rectangle(proc)\
dev_t_proc_fill_rectangle(proc, gx_device)
-#define dev_t_proc_tile_rectangle(proc, dev_t)\
- int proc(dev_t *dev,\
- const gx_tile_bitmap *tile, int x, int y, int width, int height,\
- gx_color_index color0, gx_color_index color1,\
- int phase_x, int phase_y)
-#define dev_proc_tile_rectangle(proc)\
- dev_t_proc_tile_rectangle(proc, gx_device)
-
#define dev_t_proc_copy_mono(proc, dev_t)\
int proc(dev_t *dev,\
const byte *data, int data_x, int raster, gx_bitmap_id id,\
@@ -929,22 +922,6 @@ typedef enum FILTER_FLAGS {
#define dev_proc_copy_color(proc)\
dev_t_proc_copy_color(proc, gx_device)
- /* OBSOLETED in release 3.66 */
-
-#define dev_t_proc_draw_line(proc, dev_t)\
- int proc(dev_t *dev,\
- int x0, int y0, int x1, int y1, gx_color_index color)
-#define dev_proc_draw_line(proc)\
- dev_t_proc_draw_line(proc, gx_device)
-
- /* Added in release 2.4 */
-
-#define dev_t_proc_get_bits(proc, dev_t)\
- int proc(dev_t *dev,\
- int y, byte *data, byte **actual_data)
-#define dev_proc_get_bits(proc)\
- dev_t_proc_get_bits(proc, gx_device)
-
/* Added in release 2.4, changed in 2.8, */
/* renamed in 2.9.6 */
@@ -965,27 +942,6 @@ typedef enum FILTER_FLAGS {
#define dev_proc_map_cmyk_color(proc)\
dev_t_proc_map_cmyk_color(proc, gx_device)
-#define dev_t_proc_get_xfont_procs(proc, dev_t)\
- const gx_xfont_procs *proc(dev_t *dev)
-#define dev_proc_get_xfont_procs(proc)\
- dev_t_proc_get_xfont_procs(proc, gx_device)
-
- /* Added in release 2.6.1 */
-
-#define dev_t_proc_get_xfont_device(proc, dev_t)\
- gx_device *proc(dev_t *dev)
-#define dev_proc_get_xfont_device(proc)\
- dev_t_proc_get_xfont_device(proc, gx_device)
-
- /* Added in release 2.7.1 */
-
-#define dev_t_proc_map_rgb_alpha_color(proc, dev_t)\
- gx_color_index proc(dev_t *dev,\
- gx_color_value red, gx_color_value green, gx_color_value blue,\
- gx_color_value alpha)
-#define dev_proc_map_rgb_alpha_color(proc)\
- dev_t_proc_map_rgb_alpha_color(proc, gx_device)
-
/* Added in release 2.8.1 */
#define dev_t_proc_get_page_device(proc, dev_t)\
@@ -994,6 +950,7 @@ typedef enum FILTER_FLAGS {
dev_t_proc_get_page_device(proc, gx_device)
/* Added in release 3.20, OBSOLETED in 5.65 */
+ /* 'Unobsoleted' in 9.55. */
#define dev_t_proc_get_alpha_bits(proc, dev_t)\
int proc(dev_t *dev, graphics_object_type type)
@@ -1009,25 +966,6 @@ typedef enum FILTER_FLAGS {
#define dev_proc_copy_alpha(proc)\
dev_t_proc_copy_alpha(proc, gx_device)
- /* Added in release 3.38 */
-
-#define dev_t_proc_get_band(proc, dev_t)\
- int proc(dev_t *dev, int y, int *band_start)
-#define dev_proc_get_band(proc)\
- dev_t_proc_get_band(proc, gx_device)
-
- /* Added in release 3.44 */
-
-#define dev_t_proc_copy_rop(proc, dev_t)\
- int proc(dev_t *dev,\
- const byte *sdata, int sourcex, uint sraster, gx_bitmap_id id,\
- const gx_color_index *scolors,\
- const gx_tile_bitmap *texture, const gx_color_index *tcolors,\
- int x, int y, int width, int height,\
- int phase_x, int phase_y, gs_logical_operation_t lop)
-#define dev_proc_copy_rop(proc)\
- dev_t_proc_copy_rop(proc, gx_device)
-
/* Added in release 3.60, changed in 3.68. */
#define dev_t_proc_fill_path(proc, dev_t)\
@@ -1107,37 +1045,6 @@ typedef enum FILTER_FLAGS {
#define dev_proc_draw_thin_line(proc)\
dev_t_proc_draw_thin_line(proc, gx_device)
- /* Added in release 3.66 (as stubs); */
- /* changed in 3.68; */
- /* begin_image and image_data changed in 4.30, */
- /* begin_image changed in 5.23. */
-
-#define dev_t_proc_begin_image(proc, dev_t)\
- int proc(dev_t *dev,\
- const gs_gstate *pgs, const gs_image_t *pim,\
- gs_image_format_t format, const gs_int_rect *prect,\
- const gx_drawing_color *pdcolor, const gx_clip_path *pcpath,\
- gs_memory_t *memory, gx_image_enum_common_t **pinfo)
-#define dev_proc_begin_image(proc)\
- dev_t_proc_begin_image(proc, gx_device)
-
- /* OBSOLETED in release 5.23 */
-
-#define dev_t_proc_image_data(proc, dev_t)\
- int proc(dev_t *dev,\
- gx_image_enum_common_t *info, const byte **planes, int data_x,\
- uint raster, int height)
-#define dev_proc_image_data(proc)\
- dev_t_proc_image_data(proc, gx_device)
-
- /* OBSOLETED in release 5.23 */
-
-#define dev_t_proc_end_image(proc, dev_t)\
- int proc(dev_t *dev,\
- gx_image_enum_common_t *info, bool draw_last)
-#define dev_proc_end_image(proc)\
- dev_t_proc_end_image(proc, gx_device)
-
/* Added in release 3.68 */
#define dev_t_proc_strip_tile_rectangle(proc, dev_t)\
@@ -1148,16 +1055,6 @@ typedef enum FILTER_FLAGS {
#define dev_proc_strip_tile_rectangle(proc)\
dev_t_proc_strip_tile_rectangle(proc, gx_device)
-#define dev_t_proc_strip_copy_rop(proc, dev_t)\
- int proc(dev_t *dev,\
- const byte *sdata, int sourcex, uint sraster, gx_bitmap_id id,\
- const gx_color_index *scolors,\
- const gx_strip_bitmap *textures, const gx_color_index *tcolors,\
- int x, int y, int width, int height,\
- int phase_x, int phase_y, gs_logical_operation_t lop)
-#define dev_proc_strip_copy_rop(proc)\
- dev_t_proc_strip_copy_rop(proc, gx_device)
-
/* Added in release 4.20 */
#define dev_t_proc_get_clipping_box(proc, dev_t)\
@@ -1180,22 +1077,16 @@ typedef enum FILTER_FLAGS {
#define dev_t_proc_get_bits_rectangle(proc, dev_t)\
int proc(dev_t *dev, const gs_int_rect *prect,\
- gs_get_bits_params_t *params, gs_int_rect **unread)
+ gs_get_bits_params_t *params)
#define dev_proc_get_bits_rectangle(proc)\
dev_t_proc_get_bits_rectangle(proc, gx_device)
-#define dev_t_proc_map_color_rgb_alpha(proc, dev_t)\
- int proc(dev_t *dev,\
- gx_color_index color, gx_color_value rgba[4])
-#define dev_proc_map_color_rgb_alpha(proc)\
- dev_t_proc_map_color_rgb_alpha(proc, gx_device)
-
-#define dev_t_proc_create_compositor(proc, dev_t)\
+#define dev_t_proc_composite(proc, dev_t)\
int proc(dev_t *dev,\
gx_device **pcdev, const gs_composite_t *pcte,\
gs_gstate *pgs, gs_memory_t *memory, gx_device *cdev)
-#define dev_proc_create_compositor(proc)\
- dev_t_proc_create_compositor(proc, gx_device)\
+#define dev_proc_composite(proc)\
+ dev_t_proc_composite(proc, gx_device)\
/* Added in release 5.23 */
@@ -1208,13 +1099,6 @@ typedef enum FILTER_FLAGS {
/* ... text_begin ... see gstext.h for definition */
- /* Added in release 6.23 */
-
-#define dev_t_proc_finish_copydevice(proc, dev_t)\
- int proc(dev_t *dev, const gx_device *from_dev)
-#define dev_proc_finish_copydevice(proc)\
- dev_t_proc_finish_copydevice(proc, gx_device)
-
/* Added in release 6.61 (raph) */
/*
@@ -1306,38 +1190,6 @@ typedef enum FILTER_FLAGS {
/* (end of DeviceN color support) */
/*
- Pattern management for high level devices.
- Now we need it for PatternType 1 only.
- Return codes :
- 1 - the device handles high level patterns.
- 0 - the device needs low level pattern tiles.
- <0 - error.
-
- THIS IS NOW DEPRECATED, AND UNUSED. DO NOT USE THIS. USE THIS NOT. THIS
- IS NOT TO BE USED.
-
- Pattern Management is now done using the dev_spec_op calls.
-*/
-
-/* High level device support. */
-typedef enum {
- pattern_manage__can_accum,
- pattern_manage__start_accum,
- pattern_manage__finish_accum,
- pattern_manage__load,
- pattern_manage__shading_area,
- pattern_manage__is_cpath_accum,
- pattern_manage__shfill_doesnt_need_path,
- pattern_manage__handles_clip_path
-} pattern_manage_t;
-
-#define dev_t_proc_pattern_manage(proc, dev_t)\
- int proc(gx_device *pdev, gx_bitmap_id id,\
- gs_pattern1_instance_t *pinst, pattern_manage_t function)
-#define dev_proc_pattern_manage(proc)\
- dev_t_proc_pattern_manage(proc, gx_device)
-
-/*
Fill rectangle with a high level color.
Return rangecheck, if the device can't handle the high level color.
@@ -1457,6 +1309,8 @@ typedef struct gs_devn_params_s gs_devn_params;
gs_devn_params * proc(dev_t *dev)
#define dev_proc_ret_devn_params(proc)\
dev_t_proc_ret_devn_params(proc, gx_device)
+#define dev_proc_ret_devn_params_const(proc)\
+ const dev_t_proc_ret_devn_params(proc, const gx_device)
/*
* Erase page.
@@ -1499,7 +1353,7 @@ typedef struct gs_devn_params_s gs_devn_params;
dev_t_proc_copy_planes(proc, gx_device)
#define dev_t_proc_get_profile(proc, dev_t)\
- int proc(dev_t *dev, cmm_dev_profile_t **dev_profile)
+ int proc(const dev_t *dev, cmm_dev_profile_t **dev_profile)
#define dev_proc_get_profile(proc)\
dev_t_proc_get_profile(proc, gx_device)
@@ -1592,7 +1446,9 @@ typedef struct {
/* Define the device procedure vector template proper. */
#define gx_device_proc_struct(dev_t)\
-{ dev_t_proc_open_device((*open_device), dev_t);\
+{\
+ dev_t_proc_initialize_device((*initialize_device), dev_t);\
+ dev_t_proc_open_device((*open_device), dev_t);\
dev_t_proc_get_initial_matrix((*get_initial_matrix), dev_t);\
dev_t_proc_sync_output((*sync_output), dev_t);\
dev_t_proc_output_page((*output_page), dev_t);\
@@ -1600,22 +1456,14 @@ typedef struct {
dev_t_proc_map_rgb_color((*map_rgb_color), dev_t);\
dev_t_proc_map_color_rgb((*map_color_rgb), dev_t);\
dev_t_proc_fill_rectangle((*fill_rectangle), dev_t);\
- dev_t_proc_tile_rectangle((*tile_rectangle), dev_t);\
dev_t_proc_copy_mono((*copy_mono), dev_t);\
dev_t_proc_copy_color((*copy_color), dev_t);\
- dev_t_proc_draw_line((*obsolete_draw_line), dev_t);\
- dev_t_proc_get_bits((*get_bits), dev_t);\
dev_t_proc_get_params((*get_params), dev_t);\
dev_t_proc_put_params((*put_params), dev_t);\
dev_t_proc_map_cmyk_color((*map_cmyk_color), dev_t);\
- dev_t_proc_get_xfont_procs((*get_xfont_procs), dev_t);\
- dev_t_proc_get_xfont_device((*get_xfont_device), dev_t);\
- dev_t_proc_map_rgb_alpha_color((*map_rgb_alpha_color), dev_t);\
dev_t_proc_get_page_device((*get_page_device), dev_t);\
dev_t_proc_get_alpha_bits((*get_alpha_bits), dev_t);\
dev_t_proc_copy_alpha((*copy_alpha), dev_t);\
- dev_t_proc_get_band((*get_band), dev_t);\
- dev_t_proc_copy_rop((*copy_rop), dev_t);\
dev_t_proc_fill_path((*fill_path), dev_t);\
dev_t_proc_stroke_path((*stroke_path), dev_t);\
dev_t_proc_fill_mask((*fill_mask), dev_t);\
@@ -1623,19 +1471,13 @@ typedef struct {
dev_t_proc_fill_parallelogram((*fill_parallelogram), dev_t);\
dev_t_proc_fill_triangle((*fill_triangle), dev_t);\
dev_t_proc_draw_thin_line((*draw_thin_line), dev_t);\
- dev_t_proc_begin_image((*begin_image), dev_t);\
- dev_t_proc_image_data((*image_data), dev_t);\
- dev_t_proc_end_image((*end_image), dev_t);\
dev_t_proc_strip_tile_rectangle((*strip_tile_rectangle), dev_t);\
- dev_t_proc_strip_copy_rop((*strip_copy_rop), dev_t);\
dev_t_proc_get_clipping_box((*get_clipping_box), dev_t);\
dev_t_proc_begin_typed_image((*begin_typed_image), dev_t);\
dev_t_proc_get_bits_rectangle((*get_bits_rectangle), dev_t);\
- dev_t_proc_map_color_rgb_alpha((*map_color_rgb_alpha), dev_t);\
- dev_t_proc_create_compositor((*create_compositor), dev_t);\
+ dev_t_proc_composite((*composite), dev_t);\
dev_t_proc_get_hardware_params((*get_hardware_params), dev_t);\
dev_t_proc_text_begin((*text_begin), dev_t);\
- dev_t_proc_finish_copydevice((*finish_copydevice), dev_t);\
dev_t_proc_begin_transparency_group((*begin_transparency_group), dev_t);\
dev_t_proc_end_transparency_group((*end_transparency_group), dev_t);\
dev_t_proc_begin_transparency_mask((*begin_transparency_mask), dev_t);\
@@ -1645,7 +1487,6 @@ typedef struct {
dev_t_proc_get_color_comp_index((*get_color_comp_index), dev_t); \
dev_t_proc_encode_color((*encode_color), dev_t); \
dev_t_proc_decode_color((*decode_color), dev_t); \
- dev_t_proc_pattern_manage((*pattern_manage), dev_t); \
dev_t_proc_fill_rectangle_hl_color((*fill_rectangle_hl_color), dev_t); \
dev_t_proc_include_color_space((*include_color_space), dev_t); \
dev_t_proc_fill_linear_color_scanline((*fill_linear_color_scanline), dev_t); \
@@ -1682,9 +1523,6 @@ typedef struct gx_image_plane_s {
uint raster;
} gx_image_plane_t;
-#define gx_device_begin_image(dev, pgs, pim, format, prect, pdcolor, pcpath, memory, pinfo)\
- ((*dev_proc(dev, begin_image))\
- (dev, pgs, pim, format, prect, pdcolor, pcpath, memory, pinfo))
#define gx_device_begin_typed_image(dev, pgs, pmat, pim, prect, pdcolor, pcpath, memory, pinfo)\
((*dev_proc(dev, begin_typed_image))\
(dev, pgs, pmat, pim, prect, pdcolor, pcpath, memory, pinfo))
@@ -1704,13 +1542,6 @@ int gx_image_flush(gx_image_enum_common_t *info);
bool gx_image_planes_wanted(const gx_image_enum_common_t *info, byte *wanted);
int gx_image_end(gx_image_enum_common_t *info, bool draw_last);
-/*
- * Get the anti-aliasing parameters for a device. This replaces the
- * obsolete get_alpha_bits device procedure.
- */
-#define gx_device_get_alpha_bits(dev, type)\
- gx_default_get_alpha_bits(dev, type)
-
/* A generic device procedure record. */
struct gx_device_procs_s gx_device_proc_struct(gx_device);
@@ -1778,70 +1609,6 @@ extern_st(st_device_forward);
device_forward_reloc_ptrs, gx_device_finalize)
#define st_device_forward_max_ptrs (st_device_max_ptrs + 1)
-/* The color mapping procs were used in a way which defeats a 'pipeline'
- * approach to devices. Certain graphics library routines (eg images)
- * called the color mapping procs *directly* from the device procs of the
- * current (ie terminal) device. This prevented any pipeline approach from
- * working as earlier devices in the chain wouldn't see the call. In particular
- * this prevented the use of such a device to do 'monochrome mode' in PCL
- * (see pcpalet.c, pcl_update_mono). This macro walks back up the pipeline
- * and retrieves the uppermost device color_mapping procs.
- */
-typedef struct {
- gx_cm_color_map_procs *procs;
- gx_device *dev;
-} subclass_color_mappings;
-
-static inline gx_device *
-subclass_parentmost_device(gx_device *dev)
-{
- while (dev->parent)
- dev = dev->parent;
- return dev;
-}
-
-extern const gx_cm_color_map_procs *default_subclass_get_color_mapping_procs(const gx_device *dev);
-
-static inline
-subclass_color_mappings get_color_mapping_procs_subclass(gx_device *dev)
-{
- subclass_color_mappings sc;
- gx_device *d;
- sc.dev = NULL;
-
- d = subclass_parentmost_device(dev);
- while (d->procs.get_color_mapping_procs == default_subclass_get_color_mapping_procs) {
- if (d->child)
- d = d->child;
- else {
- break;
- }
- }
- sc.dev = d;
-
- sc.procs = (gx_cm_color_map_procs *)(dev_proc(sc.dev, get_color_mapping_procs) == NULL ?
- NULL : dev_proc(sc.dev, get_color_mapping_procs)(sc.dev));
- return sc;
-}
-
-static inline
-void map_rgb_subclass(const subclass_color_mappings scm, const gs_gstate *pgs, frac r, frac g, frac b, frac out[])
-{
- scm.procs->map_rgb(scm.dev, pgs, r, g, b, out);
-}
-
-static inline
-void map_gray_subclass(const subclass_color_mappings scm, frac gray, frac out[])
-{
- scm.procs->map_gray(scm.dev, gray, out);
-}
-
-static inline
-void map_cmyk_subclass(const subclass_color_mappings scm, frac c, frac m, frac y, frac k, frac out[])
-{
- scm.procs->map_cmyk(scm.dev, c, m, y, k, out);
-}
-
/* Test to see if the device wants to use tags */
static inline bool device_encodes_tags(const gx_device *dev)
{
@@ -1885,13 +1652,16 @@ extern_st(st_device_null);
* about what this means. Normally, devices created for temporary use have
* internal = true (retained = false).
*/
-void gx_device_init(gx_device * dev, const gx_device * proto,
- gs_memory_t * mem, bool internal);
+int gx_device_init(gx_device * dev, const gx_device * proto,
+ gs_memory_t * mem, bool internal);
/*
* Identical to gx_device_init, except that the reference counting is set
* up so that it doesn't attempt to free the device structure when the last
* instance is removed, and the device is always internal (never retained).
+ *
+ * If the device uses an initialize proc (and it should!) it can never
+ * fail.
*/
void gx_device_init_on_stack(gx_device * dev, const gx_device * proto,
gs_memory_t * mem);
@@ -1984,4 +1754,25 @@ bool gx_color_info_equal(const gx_device_color_info *p1, const gx_device_color_i
/* Perform a callout to registered handlers from the device. */
int gx_callout(gx_device *dev, int id, int size, void *data);
+static inline
+gx_cm_opmsupported_t gx_get_opmsupported(gx_device *dev)
+{
+ if (dev->color_info.opmsupported != GX_CINFO_OPMSUPPORTED_UNKNOWN)
+ return dev->color_info.opmsupported;
+
+ (void)check_cmyk_color_model_comps(dev);
+
+ return dev->color_info.opmsupported;
+}
+
+static inline
+gx_color_index gx_get_process_comps(gx_device *dev)
+{
+ if (dev->color_info.opmsupported != GX_CINFO_OPMSUPPORTED_UNKNOWN)
+ return dev->color_info.process_comps;
+
+ return check_cmyk_color_model_comps(dev);
+}
+
+
#endif /* gxdevcli_INCLUDED */
diff --git a/base/gxdevice.h b/base/gxdevice.h
index c757fa2d..ce69c72d 100644
--- a/base/gxdevice.h
+++ b/base/gxdevice.h
@@ -98,8 +98,8 @@
* Note also that the macro does not initialize procs, which is
* the next element of the structure.
*/
- #define std_device_part1_(devtype, ptr_procs, dev_name, stype, open_init)\
- sizeof(devtype), ptr_procs, dev_name,\
+ #define std_device_part1_(devtype, init, dev_name, stype, open_init)\
+ sizeof(devtype), init, dev_name,\
0 /*memory*/, stype, 0 /*stype_is_dynamic*/, 0 /*finalize*/,\
{ 0 } /*rc*/, 0 /*retained*/, 0 /* parent */, 0 /* child */, 0 /* subclass_data */, 0 /* PageList */,\
open_init() /*is_open, max_fill_band*/
@@ -118,7 +118,7 @@
{ x_dpi, y_dpi }/*HWResolution*/
/* offsets and margins go here */
-#define std_device_part3_()\
+#define std_device_part3_sc(ins, bp, ep)\
0/*FirstPage*/, 0/*LastPage*/, 0/*PageHandlerPushed*/, 0/*DisablePageHandler*/,\
0/* Object Filter*/, 0/*ObjectHandlerPushed*/,\
0, /* NupControl */ 0, /* NupHandlerPushed */\
@@ -135,7 +135,10 @@
0/*Profile Array*/,\
0/* graphics_type_tag default GS_UNTOUCHED_TAG */,\
1/* interpolate_control default 1, uses image /Interpolate flag, full device resolution */,\
- { gx_default_install, gx_default_begin_page, gx_default_end_page }
+ { ins, bp, ep }
+#define std_device_part3_()\
+ std_device_part3_sc(gx_default_install, gx_default_begin_page, gx_default_end_page)
+
/*
* We need a number of different variants of the std_device_ macro simply
* because we can't pass the color_info or offsets/margins
@@ -151,91 +154,101 @@
* 6 for margins/offset).
*
*/
-#define std_device_body_with_macros_(dtype, pprocs, dname, stype, w, h, xdpi, ydpi, open_init, dci_macro, margins_macro)\
- std_device_part1_(dtype, pprocs, dname, stype, open_init),\
+#define std_device_body_with_macros_(dtype, init, dname, stype, w, h, xdpi, ydpi, open_init, dci_macro, margins_macro)\
+ std_device_part1_(dtype, init, dname, stype, open_init),\
dci_macro(),\
std_device_part2_(w, h, xdpi, ydpi),\
margins_macro(),\
std_device_part3_()
-#define std_device_std_body_type(dtype, pprocs, dname, stype, w, h, xdpi, ydpi)\
- std_device_body_with_macros_(dtype, pprocs, dname, stype,\
+#define std_device_std_body_type(dtype, init, dname, stype, w, h, xdpi, ydpi)\
+ std_device_body_with_macros_(dtype, init, dname, stype,\
w, h, xdpi, ydpi,\
open_init_closed, dci_black_and_white_, no_margins_)
-#define std_device_std_body(dtype, pprocs, dname, w, h, xdpi, ydpi)\
- std_device_std_body_type(dtype, pprocs, dname, 0, w, h, xdpi, ydpi)
+#define std_device_std_body(dtype, init, dname, w, h, xdpi, ydpi)\
+ std_device_std_body_type(dtype, init, dname, 0, w, h, xdpi, ydpi)
-#define std_device_std_body_type_open(dtype, pprocs, dname, stype, w, h, xdpi, ydpi)\
- std_device_body_with_macros_(dtype, pprocs, dname, stype,\
+#define std_device_std_body_type_open(dtype, init, dname, stype, w, h, xdpi, ydpi)\
+ std_device_body_with_macros_(dtype, init, dname, stype,\
w, h, xdpi, ydpi,\
open_init_open, dci_black_and_white_, no_margins_)
-#define std_device_std_body_open(dtype, pprocs, dname, w, h, xdpi, ydpi)\
- std_device_std_body_type_open(dtype, pprocs, dname, 0, w, h, xdpi, ydpi)
+#define std_device_std_body_open(dtype, init, dname, w, h, xdpi, ydpi)\
+ std_device_std_body_type_open(dtype, init, dname, 0, w, h, xdpi, ydpi)
-#define std_device_full_body_type(dtype, pprocs, dname, stype, w, h, xdpi, ydpi, ncomp, depth, mg, mc, dg, dc, xoff, yoff, lm, bm, rm, tm)\
- std_device_part1_(dtype, pprocs, dname, stype, open_init_closed),\
+#define std_device_full_body_type(dtype, init, dname, stype, w, h, xdpi, ydpi, ncomp, depth, mg, mc, dg, dc, xoff, yoff, lm, bm, rm, tm)\
+ std_device_part1_(dtype, init, dname, stype, open_init_closed),\
dci_values(ncomp, depth, mg, mc, dg, dc),\
std_device_part2_(w, h, xdpi, ydpi),\
offset_margin_values(xoff, yoff, lm, bm, rm, tm),\
std_device_part3_()
-#define std_device_full_body_type_extended(dtype, pprocs, dname, stype, w, h, xdpi, ydpi, mcomp, ncomp, pol, depth, gi, mg, mc, dg, dc, ef, cn, xoff, yoff, lm, bm, rm, tm)\
- std_device_part1_(dtype, pprocs, dname, stype, open_init_closed),\
+#define std_device_full_body_type_extended(dtype, init, dname, stype, w, h, xdpi, ydpi, mcomp, ncomp, pol, depth, gi, mg, mc, dg, dc, ef, cn, xoff, yoff, lm, bm, rm, tm)\
+ std_device_part1_(dtype, init, dname, stype, open_init_closed),\
dci_extended_alpha_values(mcomp, ncomp, pol, depth, gi, mg, mc, dg, dc, 1, 1, ef, cn), \
std_device_part2_(w, h, xdpi, ydpi),\
offset_margin_values(xoff, yoff, lm, bm, rm, tm),\
std_device_part3_()
-#define std_device_full_body(dtype, pprocs, dname, w, h, xdpi, ydpi, ncomp, depth, mg, mc, dg, dc, xoff, yoff, lm, bm, rm, tm)\
- std_device_full_body_type(dtype, pprocs, dname, 0, w, h, xdpi, ydpi,\
+#define std_device_full_body(dtype, init, dname, w, h, xdpi, ydpi, ncomp, depth, mg, mc, dg, dc, xoff, yoff, lm, bm, rm, tm)\
+ std_device_full_body_type(dtype, init, dname, 0, w, h, xdpi, ydpi,\
ncomp, depth, mg, mc, dg, dc, xoff, yoff, lm, bm, rm, tm)
-#define std_device_dci_alpha_type_body(dtype, pprocs, dname, stype, w, h, xdpi, ydpi, ncomp, depth, mg, mc, dg, dc, ta, ga)\
- std_device_part1_(dtype, pprocs, dname, stype, open_init_closed),\
+#define std_device_dci_alpha_type_body(dtype, init, dname, stype, w, h, xdpi, ydpi, ncomp, depth, mg, mc, dg, dc, ta, ga)\
+ std_device_part1_(dtype, init, dname, stype, open_init_closed),\
dci_alpha_values(ncomp, depth, mg, mc, dg, dc, ta, ga),\
std_device_part2_(w, h, xdpi, ydpi),\
offset_margin_values(0, 0, 0, 0, 0, 0),\
std_device_part3_()
+#define std_device_dci_alpha_type_body_sc(dtype, init, dname, stype, w, h, xdpi, ydpi, ncomp, depth, mg, mc, dg, dc, ta, ga, ins, bp, ep)\
+ std_device_part1_(dtype, init, dname, stype, open_init_closed),\
+ dci_alpha_values(ncomp, depth, mg, mc, dg, dc, ta, ga),\
+ std_device_part2_(w, h, xdpi, ydpi),\
+ offset_margin_values(0, 0, 0, 0, 0, 0),\
+ std_device_part3_sc(ins, bp, ep)
-#define std_device_dci_type_body(dtype, pprocs, dname, stype, w, h, xdpi, ydpi, ncomp, depth, mg, mc, dg, dc)\
- std_device_dci_alpha_type_body(dtype, pprocs, dname, stype, w, h,\
+#define std_device_dci_type_body(dtype, init, dname, stype, w, h, xdpi, ydpi, ncomp, depth, mg, mc, dg, dc)\
+ std_device_dci_alpha_type_body(dtype, init, dname, stype, w, h,\
xdpi, ydpi, ncomp, depth, mg, mc, dg, dc, 1, 1)
-#define std_device_dci_body(dtype, pprocs, dname, w, h, xdpi, ydpi, ncomp, depth, mg, mc, dg, dc)\
- std_device_dci_type_body(dtype, pprocs, dname, 0,\
+#define std_device_dci_type_body_sc(dtype, init, dname, stype, w, h, xdpi, ydpi, ncomp, depth, mg, mc, dg, dc, ins, bp, ep)\
+ std_device_dci_alpha_type_body_sc(dtype, init, dname, stype, w, h,\
+ xdpi, ydpi, ncomp, depth, mg, mc, dg, dc, 1, 1, ins, bp, ep)
+
+#define std_device_dci_body(dtype, init, dname, w, h, xdpi, ydpi, ncomp, depth, mg, mc, dg, dc)\
+ std_device_dci_type_body(dtype, init, dname, 0,\
w, h, xdpi, ydpi, ncomp, depth, mg, mc, dg, dc)
-#define std_device_color_full_body(dtype, pprocs, dname, w, h, xdpi, ydpi, depth, max_value, dither, xoff, yoff, lm, bm, rm, tm)\
- std_device_part1_(dtype, pprocs, dname, 0, open_init_closed),\
+#define std_device_color_full_body(dtype, init, dname, w, h, xdpi, ydpi, depth, max_value, dither, xoff, yoff, lm, bm, rm, tm)\
+ std_device_part1_(dtype, init, dname, 0, open_init_closed),\
dci_color(depth, max_value, dither),\
std_device_part2_(w, h, xdpi, ydpi),\
offset_margin_values(xoff, yoff, lm, bm, rm, tm),\
std_device_part3_()
-#define std_device_color_body(dtype, pprocs, dname, w, h, xdpi, ydpi, depth, max_value, dither)\
- std_device_color_full_body(dtype, pprocs, dname,\
+#define std_device_color_body(dtype, init, dname, w, h, xdpi, ydpi, depth, max_value, dither)\
+ std_device_color_full_body(dtype, init, dname,\
w, h, xdpi, ydpi,\
depth, max_value, dither,\
0, 0, 0, 0, 0, 0)
-#define std_device_color_stype_body(dtype, pprocs, dname, stype, w, h, xdpi, ydpi, depth, max_value, dither)\
- std_device_part1_(dtype, pprocs, dname, stype, open_init_closed),\
+#define std_device_color_stype_body(dtype, init, dname, stype, w, h, xdpi, ydpi, depth, max_value, dither)\
+ std_device_part1_(dtype, init, dname, stype, open_init_closed),\
dci_color(depth, max_value, dither),\
std_device_part2_(w, h, xdpi, ydpi),\
offset_margin_values(0, 0, 0, 0, 0, 0),\
std_device_part3_()
-#define std_device_std_color_full_body_type(dtype, pprocs, dname, stype, w, h, xdpi, ydpi, depth, xoff, yoff, lm, bm, rm, tm)\
- std_device_part1_(dtype, pprocs, dname, stype, open_init_closed),\
+#define std_device_std_color_full_body_type(dtype, init, dname, stype, w, h, xdpi, ydpi, depth, xoff, yoff, lm, bm, rm, tm)\
+ std_device_part1_(dtype, init, dname, stype, open_init_closed),\
dci_std_color(depth),\
std_device_part2_(w, h, xdpi, ydpi),\
offset_margin_values(xoff, yoff, lm, bm, rm, tm),\
std_device_part3_()
-#define std_device_std_color_full_body(dtype, pprocs, dname, w, h, xdpi, ydpi, depth, xoff, yoff, lm, bm, rm, tm)\
- std_device_std_color_full_body_type(dtype, pprocs, dname, 0,\
+#define std_device_std_color_full_body(dtype, init, dname, w, h, xdpi, ydpi, depth, xoff, yoff, lm, bm, rm, tm)\
+ std_device_std_color_full_body_type(dtype, init, dname, 0,\
w, h, xdpi, ydpi, depth, xoff, yoff, lm, bm, rm, tm)
/* ---------------- Default implementations ---------------- */
@@ -250,28 +263,20 @@ dev_proc_output_page(gx_default_output_page);
dev_proc_close_device(gx_default_close_device);
dev_proc_map_rgb_color(gx_default_w_b_map_rgb_color);
dev_proc_map_color_rgb(gx_default_w_b_map_color_rgb);
+dev_proc_encode_color(gx_default_w_b_mono_encode_color);
+dev_proc_decode_color(gx_default_w_b_mono_decode_color);
#define gx_default_map_rgb_color gx_default_w_b_map_rgb_color
#define gx_default_map_color_rgb gx_default_w_b_map_color_rgb
-dev_proc_tile_rectangle(gx_default_tile_rectangle);
dev_proc_copy_mono(gx_default_copy_mono);
dev_proc_copy_color(gx_default_copy_color);
-dev_proc_draw_line(gx_default_draw_line);
-dev_proc_get_bits(gx_no_get_bits); /* gives error */
-dev_proc_get_bits(gx_default_get_bits);
dev_proc_get_params(gx_default_get_params);
dev_proc_put_params(gx_default_put_params);
dev_proc_map_cmyk_color(gx_default_map_cmyk_color);
-dev_proc_get_xfont_procs(gx_default_get_xfont_procs);
-dev_proc_get_xfont_device(gx_default_get_xfont_device);
-dev_proc_map_rgb_alpha_color(gx_default_map_rgb_alpha_color);
dev_proc_get_page_device(gx_default_get_page_device); /* returns NULL */
dev_proc_get_page_device(gx_page_device_get_page_device); /* returns dev */
dev_proc_get_alpha_bits(gx_default_get_alpha_bits);
dev_proc_copy_alpha(gx_no_copy_alpha); /* gives error */
dev_proc_copy_alpha(gx_default_copy_alpha);
-dev_proc_get_band(gx_default_get_band);
-dev_proc_copy_rop(gx_no_copy_rop); /* gives error */
-dev_proc_copy_rop(gx_default_copy_rop);
dev_proc_fill_path(gx_default_fill_path);
dev_proc_stroke_path(gx_default_stroke_path);
dev_proc_fill_mask(gx_default_fill_mask);
@@ -279,26 +284,20 @@ dev_proc_fill_trapezoid(gx_default_fill_trapezoid);
dev_proc_fill_parallelogram(gx_default_fill_parallelogram);
dev_proc_fill_triangle(gx_default_fill_triangle);
dev_proc_draw_thin_line(gx_default_draw_thin_line);
-dev_proc_begin_image(gx_default_begin_image);
-dev_proc_image_data(gx_default_image_data);
-dev_proc_end_image(gx_default_end_image);
dev_proc_strip_tile_rectangle(gx_default_strip_tile_rectangle);
-dev_proc_strip_copy_rop(gx_no_strip_copy_rop); /* gives error */
-dev_proc_strip_copy_rop(gx_default_strip_copy_rop);
+dev_proc_strip_copy_rop2(gx_no_strip_copy_rop2);
dev_proc_get_clipping_box(gx_default_get_clipping_box);
dev_proc_get_clipping_box(gx_get_largest_clipping_box);
dev_proc_begin_typed_image(gx_default_begin_typed_image);
-dev_proc_get_bits_rectangle(gx_no_get_bits_rectangle); /* gives error */
-dev_proc_get_bits_rectangle(gx_default_get_bits_rectangle);
-dev_proc_map_color_rgb_alpha(gx_default_map_color_rgb_alpha);
-dev_proc_create_compositor(gx_no_create_compositor);
+dev_proc_get_bits_rectangle(gx_default_get_bits_rectangle); /* just returns error */
+dev_proc_get_bits_rectangle(gx_blank_get_bits_rectangle);
+dev_proc_composite(gx_no_composite);
/* default is for ordinary "leaf" devices, null is for */
/* devices that only care about coverage and not contents. */
-dev_proc_create_compositor(gx_default_create_compositor);
-dev_proc_create_compositor(gx_null_create_compositor);
+dev_proc_composite(gx_default_composite);
+dev_proc_composite(gx_null_composite);
dev_proc_get_hardware_params(gx_default_get_hardware_params);
dev_proc_text_begin(gx_default_text_begin);
-dev_proc_finish_copydevice(gx_default_finish_copydevice);
dev_proc_dev_spec_op(gx_default_dev_spec_op);
dev_proc_fill_rectangle_hl_color(gx_default_fill_rectangle_hl_color);
dev_proc_include_color_space(gx_default_include_color_space);
@@ -322,23 +321,28 @@ dev_proc_end_transparency_group(gx_default_end_transparency_group);
dev_proc_begin_transparency_mask(gx_default_begin_transparency_mask);
dev_proc_end_transparency_mask(gx_default_end_transparency_mask);
dev_proc_discard_transparency_layer(gx_default_discard_transparency_layer);
-dev_proc_pattern_manage(gx_default_pattern_manage);
dev_proc_push_transparency_state(gx_default_push_transparency_state);
dev_proc_pop_transparency_state(gx_default_pop_transparency_state);
dev_proc_put_image(gx_default_put_image);
dev_proc_copy_alpha_hl_color(gx_default_no_copy_alpha_hl_color);
dev_proc_copy_planes(gx_default_copy_planes);
+int gx_default_initialize_device(gx_device *dev);
+
/* BACKWARD COMPATIBILITY */
-#define gx_non_imaging_create_compositor gx_null_create_compositor
+#define gx_non_imaging_composite gx_null_composite
/* Color mapping routines for black-on-white, gray scale, true RGB, */
/* true CMYK, and 1-bit CMYK color. */
dev_proc_map_rgb_color(gx_default_b_w_map_rgb_color);
dev_proc_map_color_rgb(gx_default_b_w_map_color_rgb);
+dev_proc_encode_color(gx_default_b_w_mono_encode_color);
+dev_proc_decode_color(gx_default_b_w_mono_decode_color);
dev_proc_map_rgb_color(gx_default_gray_map_rgb_color);
dev_proc_map_color_rgb(gx_default_gray_map_color_rgb);
dev_proc_map_color_rgb(gx_default_rgb_map_color_rgb);
+dev_proc_encode_color(gx_default_gray_encode_color);
+dev_proc_decode_color(gx_default_gray_decode_color);
#define gx_default_cmyk_map_cmyk_color cmyk_8bit_map_cmyk_color /*see below*/
/*
* The following are defined as "standard" color mapping procedures
@@ -353,11 +357,13 @@ dev_proc_map_cmyk_color(cmyk_8bit_map_cmyk_color);
dev_proc_map_color_rgb(cmyk_8bit_map_color_rgb);
dev_proc_decode_color(cmyk_8bit_map_color_cmyk);
dev_proc_map_cmyk_color(cmyk_16bit_map_cmyk_color);
+dev_proc_map_color_rgb(cmyk_16bit_map_color_rgb);
dev_proc_decode_color(cmyk_16bit_map_color_cmyk);
dev_proc_encode_color(gx_default_8bit_map_gray_color);
dev_proc_decode_color(gx_default_8bit_map_color_gray);
/* Default implementations for forwarding devices */
+void gx_forward_initialize_procs(gx_device *dev);
dev_proc_close_device(gx_forward_close_device);
dev_proc_get_initial_matrix(gx_forward_get_initial_matrix);
dev_proc_sync_output(gx_forward_sync_output);
@@ -365,21 +371,14 @@ dev_proc_output_page(gx_forward_output_page);
dev_proc_map_rgb_color(gx_forward_map_rgb_color);
dev_proc_map_color_rgb(gx_forward_map_color_rgb);
dev_proc_fill_rectangle(gx_forward_fill_rectangle);
-dev_proc_tile_rectangle(gx_forward_tile_rectangle);
dev_proc_copy_mono(gx_forward_copy_mono);
dev_proc_copy_color(gx_forward_copy_color);
-dev_proc_get_bits(gx_forward_get_bits);
dev_proc_get_params(gx_forward_get_params);
dev_proc_put_params(gx_forward_put_params);
dev_proc_map_cmyk_color(gx_forward_map_cmyk_color);
-dev_proc_get_xfont_procs(gx_forward_get_xfont_procs);
-dev_proc_get_xfont_device(gx_forward_get_xfont_device);
-dev_proc_map_rgb_alpha_color(gx_forward_map_rgb_alpha_color);
dev_proc_get_page_device(gx_forward_get_page_device);
#define gx_forward_get_alpha_bits gx_default_get_alpha_bits
dev_proc_copy_alpha(gx_forward_copy_alpha);
-dev_proc_get_band(gx_forward_get_band);
-dev_proc_copy_rop(gx_forward_copy_rop);
dev_proc_fill_path(gx_forward_fill_path);
dev_proc_stroke_path(gx_forward_stroke_path);
dev_proc_fill_mask(gx_forward_fill_mask);
@@ -387,16 +386,11 @@ dev_proc_fill_trapezoid(gx_forward_fill_trapezoid);
dev_proc_fill_parallelogram(gx_forward_fill_parallelogram);
dev_proc_fill_triangle(gx_forward_fill_triangle);
dev_proc_draw_thin_line(gx_forward_draw_thin_line);
-dev_proc_begin_image(gx_forward_begin_image);
-#define gx_forward_image_data gx_default_image_data
-#define gx_forward_end_image gx_default_end_image
dev_proc_strip_tile_rectangle(gx_forward_strip_tile_rectangle);
-dev_proc_strip_copy_rop(gx_forward_strip_copy_rop);
dev_proc_get_clipping_box(gx_forward_get_clipping_box);
dev_proc_begin_typed_image(gx_forward_begin_typed_image);
dev_proc_get_bits_rectangle(gx_forward_get_bits_rectangle);
-dev_proc_map_color_rgb_alpha(gx_forward_map_color_rgb_alpha);
-/* There is no forward_create_compositor (see Drivers.htm). */
+/* There is no forward_composite (see Drivers.htm). */
dev_proc_get_hardware_params(gx_forward_get_hardware_params);
dev_proc_text_begin(gx_forward_text_begin);
dev_proc_get_color_mapping_procs(gx_forward_get_color_mapping_procs);
@@ -414,7 +408,7 @@ dev_proc_ret_devn_params(gx_forward_ret_devn_params);
dev_proc_fillpage(gx_forward_fillpage);
dev_proc_put_image(gx_forward_put_image);
dev_proc_copy_planes(gx_forward_copy_planes);
-dev_proc_create_compositor(gx_forward_create_compositor);
+dev_proc_composite(gx_forward_composite);
dev_proc_get_profile(gx_forward_get_profile);
dev_proc_set_graphics_type_tag(gx_forward_set_graphics_type_tag);
dev_proc_strip_copy_rop2(gx_forward_strip_copy_rop2);
@@ -422,13 +416,11 @@ dev_proc_strip_tile_rect_devn(gx_forward_strip_tile_rect_devn);
dev_proc_copy_alpha_hl_color(gx_forward_copy_alpha_hl_color);
dev_proc_transform_pixel_region(gx_forward_transform_pixel_region);
dev_proc_fill_stroke_path(gx_forward_fill_stroke_path);
+void gx_forward_device_initialize_procs(gx_device *dev);
/* ---------------- Implementation utilities ---------------- */
int gx_default_get_param(gx_device *dev, char *Param, void *list);
-/* Convert the device procedures to the proper form (see above). */
-void gx_device_set_procs(gx_device *);
-
/* Fill in defaulted procedures in a device procedure record. */
void gx_device_fill_in_procs(gx_device *);
void gx_device_forward_fill_in_procs(gx_device_forward *);
@@ -669,23 +661,22 @@ void gx_device_request_leadingedge(gx_device *dev, int le_req);
int gs_is_pdf14trans_compositor(const gs_composite_t * pct);
#define subclass_common\
- t_dev_proc_create_compositor *saved_compositor_method;\
+ t_dev_proc_composite *saved_compositor_method;\
gx_device_forward *forwarding_dev
-typedef int (t_dev_proc_create_compositor) (gx_device *dev, gx_device **pcdev, const gs_composite_t *pcte, gs_gstate *pgs, gs_memory_t *memory, gx_device *cdev);
+typedef int (t_dev_proc_composite) (gx_device *dev, gx_device **pcdev, const gs_composite_t *pcte, gs_gstate *pgs, gs_memory_t *memory, gx_device *cdev);
typedef struct {
- t_dev_proc_create_compositor *saved_compositor_method;
+ t_dev_proc_composite *saved_compositor_method;
gx_device_forward *forwarding_dev;
} generic_subclass_data;
-
-int gx_copy_device_procs(gx_device *dest, gx_device *src, gx_device *prototype);
+int gx_copy_device_procs(gx_device *dest, const gx_device *src, const gx_device *prototype);
int gx_device_subclass(gx_device *dev_to_subclass, gx_device *new_prototype, unsigned int private_data_size);
-int gx_device_unsubclass(gx_device *dev);
+void gx_device_unsubclass(gx_device *dev);
int gx_update_from_subclass(gx_device *dev);
-int gx_subclass_create_compositor(gx_device *dev, gx_device **pcdev, const gs_composite_t *pcte,
+int gx_subclass_composite(gx_device *dev, gx_device **pcdev, const gs_composite_t *pcte,
gs_gstate *pgs, gs_memory_t *memory, gx_device *cdev);
-
+void gx_subclass_fill_in_page_procs(gx_device *dev);
#endif /* gxdevice_INCLUDED */
diff --git a/base/gxdevmem.h b/base/gxdevmem.h
index bb890a27..8141331c 100644
--- a/base/gxdevmem.h
+++ b/base/gxdevmem.h
@@ -202,6 +202,56 @@ int gdev_mem_max_height(const gx_device_memory * dev, int width, ulong size,
#define gdev_mem_raster(mdev)\
gx_device_raster((const gx_device *)(mdev), true)
+typedef struct
+{
+ dev_proc_map_rgb_color((*map_rgb_color));
+ dev_proc_map_color_rgb((*map_color_rgb));
+ dev_proc_fill_rectangle((*fill_rectangle));
+ dev_proc_copy_mono((*copy_mono));
+ dev_proc_copy_color((*copy_color));
+ dev_proc_copy_alpha((*copy_alpha));
+ dev_proc_strip_tile_rectangle((*strip_tile_rectangle));
+ dev_proc_strip_copy_rop2((*strip_copy_rop2));
+ dev_proc_get_bits_rectangle((*get_bits_rectangle));
+} gdev_mem_functions;
+
+extern const gdev_mem_functions gdev_mem_fns_1;
+extern const gdev_mem_functions gdev_mem_fns_2;
+extern const gdev_mem_functions gdev_mem_fns_4;
+extern const gdev_mem_functions gdev_mem_fns_8;
+extern const gdev_mem_functions gdev_mem_fns_16;
+extern const gdev_mem_functions gdev_mem_fns_24;
+extern const gdev_mem_functions gdev_mem_fns_32;
+extern const gdev_mem_functions gdev_mem_fns_40;
+extern const gdev_mem_functions gdev_mem_fns_48;
+extern const gdev_mem_functions gdev_mem_fns_56;
+extern const gdev_mem_functions gdev_mem_fns_64;
+#if ARCH_IS_BIG_ENDIAN
+#define gdev_mem_fns_1w gdev_mem_fns_1
+#define gdev_mem_fns_2w gdev_mem_fns_2
+#define gdev_mem_fns_4w gdev_mem_fns_4
+#define gdev_mem_fns_8w gdev_mem_fns_8
+#define gdev_mem_fns_24w gdev_mem_fns_24
+#define gdev_mem_fns_32w gdev_mem_fns_32
+#define gdev_mem_fns_40w gdev_mem_fns_40
+#define gdev_mem_fns_48w gdev_mem_fns_48
+#define gdev_mem_fns_56w gdev_mem_fns_56
+#define gdev_mem_fns_64w gdev_mem_fns_64
+#else
+extern const gdev_mem_functions gdev_mem_fns_1w;
+extern const gdev_mem_functions gdev_mem_fns_2w;
+extern const gdev_mem_functions gdev_mem_fns_4w;
+extern const gdev_mem_functions gdev_mem_fns_8w;
+extern const gdev_mem_functions gdev_mem_fns_24w;
+extern const gdev_mem_functions gdev_mem_fns_32w;
+extern const gdev_mem_functions gdev_mem_fns_40w;
+extern const gdev_mem_functions gdev_mem_fns_48w;
+extern const gdev_mem_functions gdev_mem_fns_56w;
+extern const gdev_mem_functions gdev_mem_fns_64w;
+#endif
+const gdev_mem_functions *gdev_mem_functions_for_bits(int bits);
+const gdev_mem_functions *gdev_mem_word_functions_for_bits(int bits);
+
/* Determine the appropriate memory device for a given */
/* number of bits per pixel (0 if none suitable). */
const gx_device_memory *gdev_mem_device_for_bits(int);
@@ -230,8 +280,6 @@ void gs_make_mem_abuf_device(gx_device_memory * adev, gs_memory_t * mem,
gx_device * target,
const gs_log2_scale_point * pscale,
int alpha_bits, int mapped_x, bool devn);
-void gs_make_mem_alpha_device(gx_device_memory * adev, gs_memory_t * mem,
- gx_device * target, int alpha_bits);
/*
* Create memory devices with copydevice. For now the destructor is
@@ -249,8 +297,8 @@ int gs_make_mem_device_with_copydevice(gx_device_memory ** mdev,
gx_device * target);
/*
- * TODO replace gs_make_mem_abuf_device, gs_make_mem_alpha_device with
- * procedures that use copydevice.
+ * TODO replace gs_make_mem_abuf_device with
+ * procedure that uses copydevice.
*/
/*
diff --git a/base/gxdevsop.h b/base/gxdevsop.h
index a5af0f41..0131d0e2 100644
--- a/base/gxdevsop.h
+++ b/base/gxdevsop.h
@@ -227,6 +227,8 @@ enum {
*/
gxdso_is_pdf14_device,
+ gxdso_supports_pattern_transparency,
+
/* gxdso_device_child:
* data = pointer to gxdso_device_child_request struct
* size = sizeof(gxdso_device_child_request)
@@ -328,6 +330,13 @@ enum {
gxdso_JPEG_passthrough_begin,
gxdso_JPEG_passthrough_data,
gxdso_JPEG_passthrough_end,
+ /* And similarly JPX passthrough requests/control. Currently used for the pdfwrite family only.
+ */
+ gxdso_JPX_passthrough_query,
+ gxdso_JPX_passthrough_begin,
+ gxdso_JPX_passthrough_data,
+ gxdso_JPX_passthrough_end,
+
gxdso_supports_iccpostrender,
/* Retrieve the last device in a device chain
(either forwarding or subclass devices).
@@ -430,6 +439,9 @@ enum {
/* Determine if a given device is a clist one. Returns 1 if it is. */
gxdso_is_clist_device,
+ /* Determine if a given device is a null device. Returns 1 if it is. */
+ gxdso_is_null_device,
+
/* Add new gxdso_ keys above this. */
gxdso_pattern__LAST
};
diff --git a/base/gxdhtserial.c b/base/gxdhtserial.c
index 6f8bb18f..cd851951 100644
--- a/base/gxdhtserial.c
+++ b/base/gxdhtserial.c
@@ -584,7 +584,7 @@ gx_ht_read_and_install(
/* save since the 'install' copies the order, but then clears the source order */
for (i = 0; i < num_dev_comps; i++)
components_save[i] = components[i];
- code = gx_gstate_dev_ht_install(pgs, &dht, dht.type, dev);
+ code = gx_gstate_dev_ht_install(pgs, &dht, dht.type, dev, HT_OBJTYPE_DEFAULT);
if (code >= 0) {
for (i = 0; i < num_dev_comps; i++)
gx_ht_order_release(&components_save[i].corder, mem, false);
diff --git a/base/gxdownscale.c b/base/gxdownscale.c
index fd51a695..4e36c81a 100644
--- a/base/gxdownscale.c
+++ b/base/gxdownscale.c
@@ -1991,8 +1991,22 @@ static int
getbits_chunky_line(gx_downscale_liner *liner_, void *buffer, int row)
{
liner_getbits_chunky *liner = (liner_getbits_chunky *)liner_;
+ gs_int_rect rect;
+ gs_get_bits_params_t params;
- return (*dev_proc(liner->dev, get_bits))(liner->dev, row, buffer, NULL);
+ rect.p.x = 0;
+ rect.p.y = row;
+ rect.q.x = liner->dev->width;
+ rect.q.y = row+1;
+ params.x_offset = 0;
+ params.raster = bitmap_raster(liner->dev->width * liner->dev->color_info.depth);
+ params.options = (GB_ALIGN_ANY |
+ GB_RETURN_COPY |
+ GB_OFFSET_0 |
+ GB_RASTER_STANDARD | GB_PACKING_CHUNKY |
+ GB_COLORS_NATIVE | GB_ALPHA_NONE);
+ params.data[0] = buffer;
+ return (*dev_proc(liner->dev, get_bits_rectangle))(liner->dev, &rect, &params);
}
static void
@@ -2030,7 +2044,7 @@ getbits_planar_line(gx_downscale_liner *liner_, void *output, int row)
params2 = *params;
- code = (*dev_proc(liner->dev, get_bits_rectangle))(liner->dev, &rect, &params2, NULL);
+ code = (*dev_proc(liner->dev, get_bits_rectangle))(liner->dev, &rect, &params2);
/* get_bits_rectangle doesn't like doing planar copies, only return
* pointers. This is a problem for us, so fudge it here. */
@@ -2081,13 +2095,18 @@ claptrap_drop(gx_downscale_liner *liner_, gs_memory_t *mem)
}
#ifdef WITH_CAL
+static unsigned char bg0[GX_DEVICE_COLOR_MAX_COMPONENTS] = {0};
+static unsigned char bg1[GX_DEVICE_COLOR_MAX_COMPONENTS] = {
+ 0xFF, 0xFF, 0xFF, 0xFF };
+
typedef struct {
gx_downscale_liner base;
- cal_deskewer *deskewer;
- cal_deskewer_bander *bander;
+ cal_deskewer *deskewer[GX_DEVICE_COLOR_MAX_COMPONENTS];
+ cal_deskewer_bander *bander[GX_DEVICE_COLOR_MAX_COMPONENTS];
int height;
int get_row;
int got_row;
+ int num_planes;
gx_downscale_liner *chain;
} liner_skew;
@@ -2103,7 +2122,7 @@ skew_line(gx_downscale_liner *liner_, void *buffer, int row)
liner->got_row = row;
while (1) {
- code = cal_deskewer_band_pull(liner->bander, buffer);
+ code = cal_deskewer_band_pull(liner->bander[0], buffer);
if (code == 1)
return 0; /* We got a line! */
@@ -2112,7 +2131,7 @@ skew_line(gx_downscale_liner *liner_, void *buffer, int row)
liner->get_row++);
if (code < 0)
return code;
- code = cal_deskewer_band_push(liner->bander,
+ code = cal_deskewer_band_push(liner->bander[0],
buffer);
if (code < 0)
return code;
@@ -2124,11 +2143,70 @@ skew_drop(gx_downscale_liner *liner_, gs_memory_t *mem)
{
liner_skew *liner = (liner_skew *)liner_;
gx_downscale_liner *next;
+ int i;
if (!liner)
return;
- cal_deskewer_band_end(liner->bander, mem);
- cal_deskewer_fin(liner->deskewer, mem);
+ for (i = 0; i < liner->num_planes; i++) {
+ cal_deskewer_band_end(liner->bander[i], mem);
+ cal_deskewer_fin(liner->deskewer[i], mem);
+ }
+ next = liner->chain;
+ gs_free_object(mem, liner, "liner_skew");
+ if (next)
+ next->drop(next, mem);
+}
+
+static int
+planar_skew_line(gx_downscale_liner *liner_, void *params_, int row)
+{
+ liner_skew *liner = (liner_skew *)liner_;
+ int code;
+ gs_get_bits_params_t *params = (gs_get_bits_params_t *)params_;
+ int i;
+
+ if (row < liner->got_row)
+ liner->get_row = 0;
+
+ liner->got_row = row;
+
+ while (1) {
+ for (i = 0; i < liner->num_planes; i++) {
+ code = cal_deskewer_band_pull(liner->bander[i], params->data[i]);
+ if (code < 0)
+ return code;
+ }
+ if (code == 1)
+ return 0; /* We got a line! */
+
+ code = liner->chain->get_line(liner->chain,
+ params,
+ liner->get_row++);
+ if (code < 0)
+ return code;
+
+ for (i = 0; i < liner->num_planes; i++) {
+ code = cal_deskewer_band_push(liner->bander[i],
+ params->data[i]);
+ if (code < 0)
+ return code;
+ }
+ }
+}
+
+static void
+planar_skew_drop(gx_downscale_liner *liner_, gs_memory_t *mem)
+{
+ liner_skew *liner = (liner_skew *)liner_;
+ gx_downscale_liner *next;
+ int i;
+
+ if (!liner)
+ return;
+ for (i = 0; i < liner->num_planes; i++) {
+ cal_deskewer_band_end(liner->bander[i], mem);
+ cal_deskewer_fin(liner->deskewer[i], mem);
+ }
next = liner->chain;
gs_free_object(mem, liner, "liner_skew");
if (next)
@@ -2196,6 +2274,7 @@ int gx_downscaler_init_planar_cm(gx_downscaler_t *ds,
ds->apply_cm_arg = apply_cm_arg;
ds->early_cm = dst_bpc < src_bpc;
ds->post_cm_num_comps = post_cm_num_comps;
+ ds->do_skew_detection = params->do_skew_detection;
if (apply_cm) {
for (i = 0; i < post_cm_num_comps; i++) {
@@ -2226,6 +2305,108 @@ int gx_downscaler_init_planar_cm(gx_downscaler_t *ds,
ds->liner = &gb_liner->base;
}
+ memcpy(&ds->params, gb_params, sizeof(*gb_params));
+ ds->params.raster = span;
+ for (i = 0; i < num_comps; i++) {
+ ds->pre_cm[i] = gs_alloc_bytes(dev->memory,
+ (size_t)span * downfactor,
+ "gx_downscaler(planar_data)");
+ if (ds->pre_cm[i] == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto cleanup;
+ }
+ }
+
+#ifdef WITH_CAL
+ if (ds->do_skew_detection) {
+ /* Do a skew detection pass */
+ int j;
+ int w = ds->dev->width;
+ int h = ds->dev->height;
+ cal_skew *skew;
+
+ for (i = 0; i < num_comps; i++) {
+ ds->params.data[i] = ds->pre_cm[i];
+ }
+
+ skew = cal_skew_init(ds->dev->memory->gs_lib_ctx->core->cal_ctx,
+ ds->dev->memory,
+ w, h);
+ if (skew == NULL)
+ code = gs_error_VMerror;
+ for (j = 0; code >= 0 && j < h; j++) {
+ gs_get_bits_params_t params2 = ds->params;
+ code = ds->liner->get_line(ds->liner, &params2, j);
+ /* Craply turn that into "greyscale" - this assumes 8 bit. */
+ if (num_comps > 1) {
+ int i, k;
+ byte *dst = ds->params.data[0];
+ for (i = 0; i < w; i++) {
+ int v = 0;
+ for (k = num_comps-1; k > 0; k--)
+ v += ((unsigned char *)params2.data[k])[i];
+ *dst++ = (v+(num_comps>>1))/num_comps;
+ }
+ }
+ code = cal_skew_process(skew, ds->dev->memory, ds->params.data[0]);
+ }
+ if (code >= 0) {
+ ds->skew_angle = cal_skew_detect(skew, ds->dev->memory);
+ if (ds->skew_angle < -45 || ds->skew_angle > 45)
+ ds->skew_angle = 0;
+ }
+ cal_skew_fin(skew, ds->dev->memory);
+ if (code < 0)
+ goto cleanup;
+
+ if (ds->skew_angle != 0) {
+ liner_skew *sk_liner;
+ unsigned int dw, dh;
+
+ code = alloc_liner(dev->memory,
+ liner_skew,
+ planar_skew_line,
+ planar_skew_drop,
+ &sk_liner);
+ if (code < 0)
+ goto cleanup;
+ sk_liner->chain = ds->liner;
+ sk_liner->get_row = 0;
+ sk_liner->got_row = 0;
+ sk_liner->height = dev->height;
+ sk_liner->num_planes = num_comps;
+ ds->liner = &sk_liner->base;
+ for (i = 0; i < num_comps; i++)
+ {
+ sk_liner->deskewer[i] = cal_deskewer_init(
+ ds->dev->memory->gs_lib_ctx->core->cal_ctx,
+ ds->dev->memory,
+ ds->dev->width, ds->dev->height,
+ &dw,
+ &dh,
+ ds->skew_angle,
+ 1, /* Keep the page size constant */
+ 1.0, 1.0, 1.0, 1.0,
+ bg0,
+ 1);
+ if (sk_liner->deskewer[i] == NULL) {
+ emprintf(dev->memory, "Deskewer initialisation failed");
+ code = gs_note_error(gs_error_VMerror);
+ goto cleanup;
+ }
+ sk_liner->bander[i] = cal_deskewer_band_begin(sk_liner->deskewer[i],
+ ds->dev->memory,
+ 0, 0);
+ if (sk_liner->bander[i] == NULL) {
+ emprintf(dev->memory, "Deskewer initialisation(2) failed");
+ code = gs_note_error(gs_error_VMerror);
+ goto cleanup;
+ }
+ }
+ }
+ }
+#endif
+
code = check_trapping(dev->memory, params->trap_w, params->trap_h,
num_comps, params->trap_order);
if (code < 0)
@@ -2263,17 +2444,6 @@ int gx_downscaler_init_planar_cm(gx_downscaler_t *ds,
}
}
- memcpy(&ds->params, gb_params, sizeof(*gb_params));
- ds->params.raster = span;
- for (i = 0; i < num_comps; i++) {
- ds->pre_cm[i] = gs_alloc_bytes(dev->memory,
- (size_t)span * downfactor,
- "gx_downscaler(planar_data)");
- if (ds->pre_cm[i] == NULL) {
- code = gs_note_error(gs_error_VMerror);
- goto cleanup;
- }
- }
if (upfactor > 1) {
ds->scaled_data = gs_alloc_bytes(dev->memory,
(size_t)ds->scaled_span * upfactor * num_comps,
@@ -2419,12 +2589,6 @@ select_8_to_8_core(int nc, int factor)
return NULL;
}
-#ifdef WITH_CAL
-static unsigned char bg0[GX_DEVICE_COLOR_MAX_COMPONENTS] = {0};
-static unsigned char bg1[GX_DEVICE_COLOR_MAX_COMPONENTS] = {
- 0xFF, 0xFF, 0xFF, 0xFF };
-#endif
-
int
gx_downscaler_init_cm_halftone(gx_downscaler_t *ds,
gx_device *dev,
@@ -2555,8 +2719,9 @@ gx_downscaler_init_cm_halftone(gx_downscaler_t *ds,
sk_liner->get_row = 0;
sk_liner->got_row = 0;
sk_liner->height = dev->height;
+ sk_liner->num_planes = 1;
ds->liner = &sk_liner->base;
- sk_liner->deskewer = cal_deskewer_init(
+ sk_liner->deskewer[0] = cal_deskewer_init(
ds->dev->memory->gs_lib_ctx->core->cal_ctx,
ds->dev->memory,
ds->dev->width, ds->dev->height,
@@ -2567,15 +2732,15 @@ gx_downscaler_init_cm_halftone(gx_downscaler_t *ds,
1.0, 1.0, 1.0, 1.0,
(ds->num_comps <= 3 ? bg1 : bg0),
ds->num_comps);
- if (sk_liner->deskewer == NULL) {
+ if (sk_liner->deskewer[0] == NULL) {
emprintf(dev->memory, "Deskewer initialisation failed");
code = gs_note_error(gs_error_VMerror);
goto cleanup;
}
- sk_liner->bander = cal_deskewer_band_begin(sk_liner->deskewer,
+ sk_liner->bander[0] = cal_deskewer_band_begin(sk_liner->deskewer[0],
ds->dev->memory,
0, 0);
- if (sk_liner->bander == NULL) {
+ if (sk_liner->bander[0] == NULL) {
emprintf(dev->memory, "Deskewer initialisation(2) failed");
code = gs_note_error(gs_error_VMerror);
goto cleanup;
@@ -3051,7 +3216,7 @@ static int downscaler_process_fn(void *arg_, gx_device *dev, gx_device *bdev, co
/* Where do we get the data from? */
params.options = GB_COLORS_NATIVE | GB_ALPHA_NONE | GB_PACKING_CHUNKY | GB_RETURN_POINTER | GB_ALIGN_ANY | GB_OFFSET_0 | GB_RASTER_ANY;
- code = dev_proc(bdev, get_bits_rectangle)(bdev, &in_rect, &params, NULL);
+ code = dev_proc(bdev, get_bits_rectangle)(bdev, &in_rect, &params);
if (code < 0)
return code;
raster_in = params.raster;
@@ -3059,7 +3224,7 @@ static int downscaler_process_fn(void *arg_, gx_device *dev, gx_device *bdev, co
/* Where do we write it to? */
if (buffer->bdev) {
- code = dev_proc(bdev, get_bits_rectangle)(buffer->bdev, &out_rect, &params, NULL);
+ code = dev_proc(bdev, get_bits_rectangle)(buffer->bdev, &out_rect, &params);
if (code < 0)
return code;
raster_out = params.raster;
@@ -3207,9 +3372,9 @@ int gx_downscaler_read_params(gs_param_list *plist,
return code;
}
- switch (code = param_read_int(plist,
- (param_name = "Deskew"),
- &deskew)) {
+ switch (code = param_read_bool(plist,
+ (param_name = "Deskew"),
+ &deskew)) {
case 1:
break;
case 0:
@@ -3355,7 +3520,7 @@ int gx_downscaler_write_params(gs_param_list *plist,
if ((code = param_write_int(plist, "DownScaleFactor", &params->downscale_factor)) < 0)
ecode = code;
- if ((code = param_write_int(plist, "Deskew", &params->do_skew_detection)) < 0)
+ if ((code = param_write_bool(plist, "Deskew", &params->do_skew_detection)) < 0)
ecode = code;
if (features & GX_DOWNSCALER_PARAMS_MFS)
{
diff --git a/base/gxfapi.c b/base/gxfapi.c
index 6b97d708..2bc385a3 100644
--- a/base/gxfapi.c
+++ b/base/gxfapi.c
@@ -33,6 +33,7 @@
#include "gsimage.h"
#include "gsbittab.h"
#include "gzpath.h"
+#include "gxdevsop.h"
#include "gxfapi.h"
@@ -261,9 +262,7 @@ using_transparency_pattern(gs_gstate *pgs)
{
gx_device *dev = gs_currentdevice_inline(pgs);
- return ((!gs_color_writes_pure(pgs))
- && dev_proc(dev, begin_transparency_group) != gx_default_begin_transparency_group
- && dev_proc(dev, end_transparency_group) != gx_default_end_transparency_group);
+ return ((!gs_color_writes_pure(pgs)) && dev_proc(dev, dev_spec_op)(dev, gxdso_supports_pattern_transparency, NULL, 0));
}
static inline bool
@@ -428,7 +427,14 @@ gs_fapi_prepare_font(gs_font *pfont, gs_fapi_server *I, int subfont, const char
< 0)
return code;
pbfont->FAPI_font_data = I->ff.server_font_data; /* Save it back to GS font. */
- if (I->ff.server_font_data != 0) {
+
+ /* We only want to "refine" the FontBBox for fonts where we allow FAPI to be
+ treated as a "black box", handing over the entire font to the FAPI server.
+ That is, fonts where we give the server either the file, or a buffer with
+ the entire font description in it.
+ */
+ if (I->ff.server_font_data != 0
+ && (font_file_path != NULL || full_font_buf != NULL)) {
if ((code =
gs_fapi_renderer_retcode(mem, I,
I->get_font_bbox(I, &I->ff,
@@ -776,7 +782,7 @@ fapi_image_uncached_glyph(gs_font *pfont, gs_gstate *pgs, gs_show_enum *penum,
gs_gstate *penum_pgs = (gs_gstate *) penum->pgs;
int code;
const gx_clip_path *pcpath = pgs->clip_path;
- const gx_drawing_color *pdcolor = penum->pdcolor;
+ const gx_drawing_color *pdcolor = gs_currentdevicecolor_inline(penum->pgs);
int rast_orig_x = rast->orig_x;
int rast_orig_y = -rast->orig_y;
gs_font_base *pbfont = (gs_font_base *)pfont;
@@ -1485,7 +1491,7 @@ gs_fapi_do_char(gs_font *pfont, gs_gstate *pgs, gs_text_enum_t *penum, char *fon
}
if (cr.metrics_type == gs_fapi_metrics_notdef && !bVertical) {
code =
- I->ff.fapi_get_metrics(&I->ff, &enc_char_name_string, index, sbw,
+ I->ff.fapi_get_metrics(&I->ff, &enc_char_name_string, (int)index, sbw,
bVertical);
if (code < 0)
return code;
diff --git a/base/gxfapi.h b/base/gxfapi.h
index 728630e6..7f5dd03f 100644
--- a/base/gxfapi.h
+++ b/base/gxfapi.h
@@ -209,7 +209,7 @@ struct gs_fapi_font_s
int (*get_glyphname_or_cid) (gs_text_enum_t *penum, gs_font_base *pbfont,
gs_string *charstring, gs_string *name,
gs_glyph ccode, gs_string *enc_char_name,
- char *font_file_path, gs_fapi_char_ref *cr,
+ char *font_file_path, gs_fapi_char_ref *cr,
bool bCID);
int (*fapi_get_metrics) (gs_fapi_font *ff, gs_string *char_name, gs_glyph cid, double *m, bool vertical);
diff --git a/base/gxfill.c b/base/gxfill.c
index 921c2baf..88e44c99 100644
--- a/base/gxfill.c
+++ b/base/gxfill.c
@@ -196,7 +196,7 @@ is_spotan_device(gx_device * dev)
{
/* Use open_device procedure to identify the type of the device
* instead of the standard gs_object_type() because gs_cpath_accum_device
- * is allocaded on the stack i.e. has no block header with a descriptor
+ * is allocated on the stack i.e. has no block header with a descriptor
* but has dev->memory set like a heap-allocated device.
*/
return dev_proc(dev, open_device) == san_open;
diff --git a/base/gxgstate.h b/base/gxgstate.h
index a6309d89..b1ce6a08 100644
--- a/base/gxgstate.h
+++ b/base/gxgstate.h
@@ -81,7 +81,7 @@ typedef struct gx_transfer_s {
gs_halftone *halftone; /* (RC) */\
gs_int_point screen_phase[gs_color_select_count];\
/* dev_ht depends on halftone and device resolution. */\
- gx_device_halftone *dev_ht; /* (RC) */\
+ gx_device_halftone *dev_ht[HT_OBJTYPE_COUNT]; /* (RC) */\
\
/* Color (device-dependent): */\
\
@@ -139,7 +139,10 @@ typedef struct gs_gstate_color_s {
*/
#define gs_cr_state_do_rc_ptrs(m)\
m(halftone) \
- m(dev_ht) \
+ m(dev_ht[HT_OBJTYPE_DEFAULT]) \
+ m(dev_ht[HT_OBJTYPE_VECTOR]) \
+ m(dev_ht[HT_OBJTYPE_IMAGE]) \
+ m(dev_ht[HT_OBJTYPE_TEXT]) \
m(cie_render) \
m(black_generation) \
m(undercolor_removal) \
@@ -155,19 +158,22 @@ typedef struct gs_gstate_color_s {
/* Enumerate the pointers in a c.r. state. */
#define gs_cr_state_do_ptrs(m)\
m(0,halftone) \
- m(1,dev_ht) \
- m(2,cie_render) \
- m(3,black_generation) \
- m(4,undercolor_removal) \
- m(5,set_transfer.red) \
- m(6,set_transfer.green) \
- m(7,set_transfer.blue) \
- m(8,set_transfer.gray)\
- m(9,cie_joint_caches) \
- m(10,pattern_cache) \
- m(11,devicergb_cs) \
- m(12,devicecmyk_cs)\
- m(13,cie_joint_caches_alt)
+ m(1,dev_ht[HT_OBJTYPE_DEFAULT]) \
+ m(2, dev_ht[HT_OBJTYPE_VECTOR]) \
+ m(3, dev_ht[HT_OBJTYPE_IMAGE]) \
+ m(4, dev_ht[HT_OBJTYPE_TEXT]) \
+ m(5,cie_render) \
+ m(6,black_generation) \
+ m(7,undercolor_removal) \
+ m(8,set_transfer.red) \
+ m(9,set_transfer.green) \
+ m(10,set_transfer.blue) \
+ m(11,set_transfer.gray)\
+ m(12,cie_joint_caches) \
+ m(13,pattern_cache) \
+ m(14,devicergb_cs) \
+ m(15,devicecmyk_cs)\
+ m(16,cie_joint_caches_alt)
/*
* We handle effective_transfer specially in gsistate.c since its pointers
* are not enumerated for garbage collection but they are are relocated.
@@ -176,7 +182,7 @@ typedef struct gs_gstate_color_s {
* This count does not include the effective_transfer pointers since they
* are not enumerated for GC.
*/
-#define st_cr_state_num_ptrs 14
+#define st_cr_state_num_ptrs 17
struct gs_devicen_color_map_s {
bool use_alt_cspace;
@@ -279,6 +285,9 @@ struct gs_gstate_s {
gs_matrix ctm_default;
bool ctm_default_set; /* if true, use ctm_default; */
/* if false, ask device */
+ gs_matrix ctm_initial; /* The value of the device initial matrix at the time the default was set. */
+ bool ctm_initial_set; /* if true, modification set. If not, assume identity. */
+
/* Paths: */
gx_path *path;
@@ -468,5 +477,25 @@ static inline void ensure_tag_is_set(gs_gstate *pgs, gx_device *dev, gs_graphics
}
}
+/* Adjust the color reference counts for the current space. */
+static inline void
+cs_adjust_color_count(gs_gstate *pgs, int delta)
+{
+ gs_color_space *pcs = gs_currentcolorspace_inline(pgs);
+
+ (pcs->type->adjust_color_count)(gs_currentcolor_inline(pgs),
+ pcs, delta);
+}
+
+/* Adjust the color reference counts for the swapped space (i.e.
+ * the one that is not current). */
+static inline void
+cs_adjust_swappedcolor_count(gs_gstate *pgs, int delta)
+{
+ gs_color_space *pcs = gs_swappedcolorspace_inline(pgs);
+
+ (pcs->type->adjust_color_count)(gs_swappedcolor_inline(pgs),
+ pcs, delta);
+}
#endif /* gxistate_INCLUDED */
diff --git a/base/gxht.c b/base/gxht.c
index aeb23362..a57662ce 100644
--- a/base/gxht.c
+++ b/base/gxht.c
@@ -301,17 +301,7 @@ gx_dc_ht_binary_fill_rectangle(const gx_device_color * pdevc, int x, int y,
lop = rop3_use_D_when_T_1(lop);
if (source == NULL)
set_rop_no_source(source, no_source, dev);
- if (source->planar_height == 0)
- return (*dev_proc(dev, strip_copy_rop))
- (dev, source->sdata,
- source->sourcex, source->sraster, source->id,
- (source->use_scolors ? source->scolors : NULL),
- &pdevc->colors.binary.b_tile->tiles,
- pdevc->colors.binary.color,
- x, y, w, h, pdevc->phase.x, pdevc->phase.y,
- lop);
- else
- return (*dev_proc(dev, strip_copy_rop2))
+ return (*dev_proc(dev, strip_copy_rop2))
(dev, source->sdata,
source->sourcex, source->sraster, source->id,
(source->use_scolors ? source->scolors : NULL),
@@ -555,7 +545,7 @@ gx_dc_ht_binary_read(
devc.type = gx_dc_type_ht_binary;
/* the halftone is always taken from the gs_gstate */
- devc.colors.binary.b_ht = pgs->dev_ht;
+ devc.colors.binary.b_ht = pgs->dev_ht[HT_OBJTYPE_DEFAULT];
/* cache is not porvided until the device color is used */
devc.colors.binary.b_tile = 0;
@@ -602,14 +592,14 @@ gx_dc_ht_binary_read(
devc.colors.binary.b_index = *pdata++;
}
- if (pgs->dev_ht == NULL)
+ if (pgs->dev_ht[HT_OBJTYPE_DEFAULT] == NULL)
return_error(gs_error_unregistered); /* Must not happen. */
/* set the phase as required (select value is arbitrary) */
color_set_phase_mod( &devc,
pgs->screen_phase[0].x,
pgs->screen_phase[0].y,
- pgs->dev_ht->lcm_width,
- pgs->dev_ht->lcm_height );
+ pgs->dev_ht[HT_OBJTYPE_DEFAULT]->lcm_width,
+ pgs->dev_ht[HT_OBJTYPE_DEFAULT]->lcm_height );
/* everything looks good */
*pdevc = devc;
diff --git a/base/gxht.h b/base/gxht.h
index b2743a5a..e22f4f9a 100644
--- a/base/gxht.h
+++ b/base/gxht.h
@@ -182,6 +182,7 @@ typedef struct gs_multiple_halftone_s {
struct gs_halftone_s {
gs_halftone_type type;
rc_header rc;
+ gs_HT_objtype_t objtype;
union {
gs_screen_halftone screen; /* setscreen */
gs_colorscreen_halftone colorscreen; /* setcolorscreen */
diff --git a/base/gxht_thresh.c b/base/gxht_thresh.c
index 348307ec..c981f81b 100644
--- a/base/gxht_thresh.c
+++ b/base/gxht_thresh.c
@@ -585,9 +585,11 @@ gxht_thresh_image_init(gx_image_enum *penum)
gx_dda_fixed dda_ht;
if (gx_device_must_halftone(penum->dev)) {
- if (penum->pgs != NULL && penum->pgs->dev_ht != NULL) {
- for (k = 0; k < penum->pgs->dev_ht->num_comp; k++) {
- d_order = &(penum->pgs->dev_ht->components[k].corder);
+ if (penum->pgs != NULL && penum->pgs->dev_ht[HT_OBJTYPE_DEFAULT] != NULL) {
+ gx_device_halftone *pdht = gx_select_dev_ht(penum->pgs);
+
+ for (k = 0; k < pdht->num_comp; k++) {
+ d_order = &(pdht->components[k].corder);
code = gx_ht_construct_threshold(d_order, penum->dev,
penum->pgs, k);
if (code < 0 ) {
@@ -871,6 +873,7 @@ gxht_thresh_planes(gx_image_enum *penum, fixed xrun,
gx_color_index dev_black = gx_device_black(dev);
int spp_out = dev->color_info.num_components;
byte *contone_align = NULL; /* Init to silence compiler warnings */
+ gx_device_halftone *pdht = gx_select_dev_ht(penum->pgs);
/* Go ahead and fill the threshold line buffer with tiled threshold values.
First just grab the row or column that we are going to tile with and
@@ -883,10 +886,10 @@ gxht_thresh_planes(gx_image_enum *penum, fixed xrun,
/* Iterate over the vdi and fill up our threshold buffer. We
also need to loop across the planes of data */
for (j = 0; j < spp_out; j++) {
- bool threshold_inverted = penum->pgs->dev_ht->components[j].corder.threshold_inverted;
+ bool threshold_inverted = pdht->components[j].corder.threshold_inverted;
- thresh_width = penum->pgs->dev_ht->components[j].corder.width;
- thresh_height = penum->pgs->dev_ht->components[j].corder.full_height;
+ thresh_width = pdht->components[j].corder.width;
+ thresh_height = pdht->components[j].corder.full_height;
halftone = penum->ht_buffer + j * vdi * dithered_stride;
/* Compute the tiling positions with dest_width */
dx = (fixed2int_var_rounded(xrun) + penum->pgs->screen_phase[0].x) % thresh_width;
@@ -901,7 +904,7 @@ gxht_thresh_planes(gx_image_enum *penum, fixed xrun,
right_tile_width = dest_width - num_full_tiles * thresh_width -
left_width;
/* Get the proper threshold for the colorant count */
- threshold = penum->pgs->dev_ht->components[j].corder.threshold;
+ threshold = pdht->components[j].corder.threshold;
/* Point to the proper contone data */
contone_align = penum->line + contone_stride * j +
offset_contone[j];
@@ -995,11 +998,11 @@ gxht_thresh_planes(gx_image_enum *penum, fixed xrun,
for (j = 0; j < spp_out; j++) {
halftone = penum->ht_buffer +
j * penum->ht_plane_height * (LAND_BITS>>3);
- thresh_width = penum->pgs->dev_ht->components[j].corder.width;
+ thresh_width = pdht->components[j].corder.width;
thresh_height =
- penum->pgs->dev_ht->components[j].corder.full_height;
+ pdht->components[j].corder.full_height;
/* Get the proper threshold for the colorant count */
- threshold = penum->pgs->dev_ht->components[j].corder.threshold;
+ threshold = pdht->components[j].corder.threshold;
/* Point to the proper contone data */
contone_align = penum->line + offset_contone[j] +
LAND_BITS * j * contone_stride;
diff --git a/base/gxicolor.c b/base/gxicolor.c
index 05820695..4785ab4f 100644
--- a/base/gxicolor.c
+++ b/base/gxicolor.c
@@ -108,7 +108,7 @@ color_halftone_init(gx_image_enum *penum)
if (!gx_device_must_halftone(penum->dev))
return NULL;
- if (penum->pgs == NULL || penum->pgs->dev_ht == NULL)
+ if (penum->pgs == NULL || penum->pgs->dev_ht[HT_OBJTYPE_DEFAULT] == NULL)
return NULL;
dda_ht = penum->dda.pixel0.x;
if (penum->dxx > 0)
@@ -136,20 +136,20 @@ color_halftone_init(gx_image_enum *penum)
if (cal_ht == NULL)
goto fail;
- for (k = 0; k < penum->pgs->dev_ht->num_comp; k++) {
- d_order = &(penum->pgs->dev_ht->components[k].corder);
+ for (k = 0; k < penum->pgs->dev_ht[HT_OBJTYPE_DEFAULT]->num_comp; k++) {
+ d_order = &(penum->pgs->dev_ht[HT_OBJTYPE_DEFAULT]->components[k].corder);
code = gx_ht_construct_threshold(d_order, penum->dev, penum->pgs, k);
if (code < 0)
goto fail;
if (cal_halftone_add_screen(ctx,
penum->memory->non_gc_memory,
cal_ht,
- penum->pgs->dev_ht->components[k].corder.threshold_inverted,
- penum->pgs->dev_ht->components[k].corder.width,
- penum->pgs->dev_ht->components[k].corder.full_height,
+ penum->pgs->dev_ht[HT_OBJTYPE_DEFAULT]->components[k].corder.threshold_inverted,
+ penum->pgs->dev_ht[HT_OBJTYPE_DEFAULT]->components[k].corder.width,
+ penum->pgs->dev_ht[HT_OBJTYPE_DEFAULT]->components[k].corder.full_height,
-penum->pgs->screen_phase[k].x,
-penum->pgs->screen_phase[k].y,
- penum->pgs->dev_ht->components[k].corder.threshold) < 0)
+ penum->pgs->dev_ht[HT_OBJTYPE_DEFAULT]->components[k].corder.threshold) < 0)
goto fail;
}
diff --git a/base/gxifast.c b/base/gxifast.c
index b93c5861..7ec7a1de 100644
--- a/base/gxifast.c
+++ b/base/gxifast.c
@@ -606,7 +606,7 @@ image_render_simple(gx_image_enum * penum, const byte * buffer, int data_x,
line_size = (w + 7) >> 3;
line_width = w;
line_x = 0;
- } else if (copy_mono == dev_proc(&mem_mono_device, copy_mono) &&
+ } else if (copy_mono == mem_mono_copy_mono &&
dxx > 0 && gx_dc_is_pure(pdc1) && gx_dc_is_pure(pdc0) &&
/* We know the colors must be (0,1) or (1,0). */
(pdc0->colors.pure ^ pdc1->colors.pure) == 1 &&
diff --git a/base/gximag3x.c b/base/gximag3x.c
index 3e6b4009..df0face5 100644
--- a/base/gximag3x.c
+++ b/base/gximag3x.c
@@ -45,7 +45,7 @@ private_st_gs_image3x();
/* Define the image type for ImageType 3x images. */
const gx_image_type_t gs_image_type_3x = {
- &st_gs_image3x, gx_begin_image3x, gx_data_image_source_size,
+ &st_gs_image3x, gx_begin_image3x,
gx_image_no_sput, gx_image_no_sget, gx_image_default_release,
IMAGE3X_IMAGETYPE
};
diff --git a/base/gximage.c b/base/gximage.c
index 1d97ac26..90a60f4b 100644
--- a/base/gximage.c
+++ b/base/gximage.c
@@ -28,7 +28,6 @@
/* ---------------- Generic image support ---------------- */
/* Structure descriptors */
-public_st_gs_image_common();
public_st_gs_data_image();
public_st_gs_pixel_image();
@@ -112,18 +111,6 @@ gx_image_enum_common_init(gx_image_enum_common_t * piec,
return 0;
}
-/* Compute the source size of an ordinary image with explicit data. */
-int
-gx_data_image_source_size(const gs_gstate * pgs,
- const gs_image_common_t * pim, gs_int_point * psize)
-{
- const gs_data_image_t *pdi = (const gs_data_image_t *)pim;
-
- psize->x = pdi->Width;
- psize->y = pdi->Height;
- return 0;
-}
-
/* Process the next piece of an image with no source data. */
/* This procedure should never be called. */
int
diff --git a/base/gximage1.c b/base/gximage1.c
index 787fb4a1..ddd2ef0e 100644
--- a/base/gximage1.c
+++ b/base/gximage1.c
@@ -34,7 +34,7 @@ static image_proc_sput(gx_image1_sput);
static image_proc_sget(gx_image1_sget);
static image_proc_release(gx_image1_release);
const gx_image_type_t gs_image_type_1 = {
- &st_gs_image1, gx_begin_image1, gx_data_image_source_size,
+ &st_gs_image1, gx_begin_image1,
gx_image1_sput, gx_image1_sget, gx_image1_release, 1
};
static image_proc_sput(gx_image1_mask_sput);
@@ -44,7 +44,7 @@ static image_proc_sget(gx_image1_mask_sget);
* worry about releasing the color space.
*/
const gx_image_type_t gs_image_type_mask1 = {
- &st_gs_image1, gx_begin_image1, gx_data_image_source_size,
+ &st_gs_image1, gx_begin_image1,
gx_image1_mask_sput, gx_image1_mask_sget, gx_image_default_release, 1
};
diff --git a/base/gximage3.c b/base/gximage3.c
index 9fd47798..8e39d7b1 100644
--- a/base/gximage3.c
+++ b/base/gximage3.c
@@ -42,7 +42,7 @@ private_st_gs_image3();
/* Define the image type for ImageType 3 images. */
const gx_image_type_t gs_image_type_3 = {
- &st_gs_image3, gx_begin_image3, gx_data_image_source_size,
+ &st_gs_image3, gx_begin_image3,
gx_image_no_sput, gx_image_no_sget, gx_image_default_release, 3
};
static const gx_image_enum_procs_t image3_enum_procs = {
diff --git a/base/gximage4.c b/base/gximage4.c
index 1a3a4761..0c96da49 100644
--- a/base/gximage4.c
+++ b/base/gximage4.c
@@ -35,7 +35,7 @@ static image_proc_sput(gx_image4_sput);
static image_proc_sget(gx_image4_sget);
static image_proc_release(gx_image4_release);
const gx_image_type_t gs_image_type_4 = {
- &st_gs_image4, gx_begin_image4, gx_data_image_source_size,
+ &st_gs_image4, gx_begin_image4,
gx_image4_sput, gx_image4_sget, gx_image4_release, 4
};
/*
@@ -66,7 +66,7 @@ gx_begin_image4(gx_device * dev,
const gx_drawing_color * pdcolor, const gx_clip_path * pcpath,
gs_memory_t * mem, gx_image_enum_common_t ** pinfo)
{
- gx_image_enum *penum;
+ gx_image_enum *penum = NULL;
const gs_image4_t *pim = (const gs_image4_t *)pic;
int code = gx_image_enum_alloc(pic, prect, mem, &penum);
@@ -109,6 +109,7 @@ gx_begin_image4(gx_device * dev,
if (code >= 0)
*pinfo = (gx_image_enum_common_t *)penum;
else {
+ gs_free_object(mem, penum, "gx_begin_image4");
*pinfo = NULL;
}
return code;
diff --git a/base/gximono.c b/base/gximono.c
index 659a6ccb..7b40f3de 100644
--- a/base/gximono.c
+++ b/base/gximono.c
@@ -96,12 +96,14 @@ halftone_init(gx_image_enum *penum)
byte *cache = (penum->color_cache != NULL ? penum->color_cache->device_contone : NULL);
cal_matrix matrix;
int clip_x, clip_y;
+ gx_device_halftone *pdht = gx_select_dev_ht(penum->pgs);
if (!gx_device_must_halftone(penum->dev))
return NULL;
- if (penum->pgs == NULL || penum->pgs->dev_ht == NULL)
+ if (penum->pgs == NULL || pdht == NULL)
return NULL;
+
dda_ht = penum->dda.pixel0.x;
if (penum->dxx > 0)
dda_translate(dda_ht, -fixed_epsilon);
@@ -129,20 +131,20 @@ halftone_init(gx_image_enum *penum)
if (cal_ht == NULL)
goto fail;
- for (k = 0; k < penum->pgs->dev_ht->num_comp; k++) {
- d_order = &(penum->pgs->dev_ht->components[k].corder);
+ for (k = 0; k < pdht->num_comp; k++) {
+ d_order = &(pdht->components[k].corder);
code = gx_ht_construct_threshold(d_order, penum->dev, penum->pgs, k);
if (code < 0)
goto fail;
if (cal_halftone_add_screen(penum->memory->gs_lib_ctx->core->cal_ctx,
penum->memory->non_gc_memory,
cal_ht,
- penum->pgs->dev_ht->components[k].corder.threshold_inverted,
- penum->pgs->dev_ht->components[k].corder.width,
- penum->pgs->dev_ht->components[k].corder.full_height,
+ pdht->components[k].corder.threshold_inverted,
+ pdht->components[k].corder.width,
+ pdht->components[k].corder.full_height,
penum->pgs->screen_phase[k].x,
-penum->pgs->screen_phase[k].y,
- penum->pgs->dev_ht->components[k].corder.threshold) < 0)
+ pdht->components[k].corder.threshold) < 0)
goto fail;
}
diff --git a/base/gxiparam.h b/base/gxiparam.h
index 0336ca8a..250cbbc3 100644
--- a/base/gxiparam.h
+++ b/base/gxiparam.h
@@ -41,19 +41,6 @@ struct gx_image_type_s {
dev_proc_begin_typed_image((*begin_typed_image));
/*
- * Compute the width and height of the source data. For images with
- * explicit data, this information is in the gs_data_image_t
- * structure, but ImageType 2 images must compute it.
- * NOTE: we no longer support ImageType 2, so maybe this could be
- * simplified/refactored?
- */
-#define image_proc_source_size(proc)\
- int proc(const gs_gstate *pgs, const gs_image_common_t *pic,\
- gs_int_point *psize)
-
- image_proc_source_size((*source_size));
-
- /*
* Put image parameters on a stream. Currently this is used
* only for banding. If the parameters include a color space,
* store it in *ppcs.
@@ -91,11 +78,6 @@ struct gx_image_type_s {
};
/*
- * Define the procedure for getting the source size of an image with
- * explicit data.
- */
-image_proc_source_size(gx_data_image_source_size);
-/*
* Define dummy sput/sget/release procedures for image types that don't
* implement these functions.
*/
diff --git a/base/gxmclip.c b/base/gxmclip.c
index b2b59e35..02c90922 100644
--- a/base/gxmclip.c
+++ b/base/gxmclip.c
@@ -73,10 +73,13 @@ gx_mask_clip_initialize(gx_device_mask_clip * cdev,
tile_clip_buffer_size / (bits->raster + sizeof(byte *));
if (mem == NULL)
- gx_device_init_on_stack((gx_device *)cdev, (const gx_device *)proto,
+ gx_device_init_on_stack((gx_device *)cdev,
+ (const gx_device *)proto,
tdev->memory);
else
- gx_device_init((gx_device *)cdev, (const gx_device *)proto, mem, true);
+ (void)gx_device_init((gx_device *)cdev,
+ (const gx_device *)proto,
+ mem, true);
cdev->width = tdev->width;
cdev->height = tdev->height;
cdev->color_info = tdev->color_info;
diff --git a/base/gxoprect.c b/base/gxoprect.c
index 9b409e8c..08f64eb7 100644
--- a/base/gxoprect.c
+++ b/base/gxoprect.c
@@ -308,8 +308,7 @@ gx_overprint_generic_fill_rectangle(
gb_rect.q.y = y;
code = dev_proc(tdev, get_bits_rectangle)( tdev,
&gb_rect,
- &gb_params,
- 0 );
+ &gb_params );
if (code < 0)
break;
unpack_proc(pcolor_buff, gb_buff, 0, w, depth);
@@ -496,8 +495,7 @@ gx_overprint_sep_fill_rectangle_1(
gb_rect.q.y = y;
code = dev_proc(tdev, get_bits_rectangle)( tdev,
&gb_rect,
- &gb_params,
- 0 );
+ &gb_params );
if (code < 0)
break;
bits_fill_rectangle_masked( gb_buff,
@@ -586,8 +584,7 @@ gx_overprint_sep_fill_rectangle_2(
gb_rect.q.y = y;
code = dev_proc(tdev, get_bits_rectangle)( tdev,
&gb_rect,
- &gb_params,
- 0 );
+ &gb_params );
if (code < 0)
break;
for (i = 0, j = 0; i < byte_w; i++, cp++) {
diff --git a/base/gxp1fill.c b/base/gxp1fill.c
index dab8c333..99f05f5c 100644
--- a/base/gxp1fill.c
+++ b/base/gxp1fill.c
@@ -286,20 +286,7 @@ tile_colored_fill(const tile_fill_state_t * ptfs,
data_tile.id = bits->id;
data_tile.shift = data_tile.rep_shift = 0;
data_tile.num_planes = (ptfs->num_planes > 1 ? ptfs->num_planes : 1);
- if (source->planar_height == 0) {
- code = (*dev_proc(ptfs->pcdev, strip_copy_rop))
- (ptfs->pcdev,
- source->sdata + (y - ptfs->y0) * source->sraster,
- source->sourcex + (x - ptfs->x0),
- source->sraster, source_id,
- (source->use_scolors ? source->scolors : NULL),
- &data_tile, NULL,
- x, y, w, h,
- imod(xoff - x, data_tile.rep_width),
- imod(yoff - y, data_tile.rep_height),
- lop);
- } else {
- code = (*dev_proc(ptfs->pcdev, strip_copy_rop2))
+ code = (*dev_proc(ptfs->pcdev, strip_copy_rop2))
(ptfs->pcdev,
source->sdata + (y - ptfs->y0) * source->sraster,
source->sourcex + (x - ptfs->x0),
@@ -311,7 +298,6 @@ tile_colored_fill(const tile_fill_state_t * ptfs,
imod(yoff - y, data_tile.rep_height),
lop,
source->planar_height);
- }
}
return code;
}
@@ -393,13 +379,6 @@ gx_dc_pattern_fill_rectangle(const gx_device_color * pdevc, int x, int y,
code = (*dev_proc(state.pcdev, strip_tile_rectangle))
(state.pcdev, bits, x, y, w, h,
gx_no_color_index, gx_no_color_index, px, py);
- else if (rop_source->planar_height == 0)
- code = (*dev_proc(state.pcdev, strip_copy_rop))
- (state.pcdev,
- rop_source->sdata, rop_source->sourcex,
- rop_source->sraster, rop_source->id,
- (rop_source->use_scolors ? rop_source->scolors : NULL),
- bits, NULL, x, y, w, h, px, py, lop);
else
code = (*dev_proc(state.pcdev, strip_copy_rop2))
(state.pcdev,
diff --git a/base/gxpath.h b/base/gxpath.h
index 90d62bed..21afd4bc 100644
--- a/base/gxpath.h
+++ b/base/gxpath.h
@@ -201,6 +201,7 @@ typedef enum {
/* Path accessors */
gx_path *gx_current_path(const gs_gstate *);
+bool gx_path_position_valid(const gx_path *ppath);
int gx_path_current_point(const gx_path *, gs_fixed_point *),
gx_path_bbox(gx_path *, gs_fixed_rect *),
gx_path_bbox_set(gx_path *, gs_fixed_rect *);
diff --git a/base/gxpath2.c b/base/gxpath2.c
index 0f856f5a..0989f41f 100644
--- a/base/gxpath2.c
+++ b/base/gxpath2.c
@@ -27,6 +27,13 @@
/* Define the enumeration structure. */
public_st_path_enum();
+/* Check whether current path has valid point */
+bool
+gx_path_position_valid(const gx_path *ppath)
+{
+ return path_position_valid(ppath);
+}
+
/* Read the current point of a path. */
int
gx_path_current_point(const gx_path * ppath, gs_fixed_point * ppt)
diff --git a/base/gxpcmap.c b/base/gxpcmap.c
index e6ec7b9a..bdcca0c8 100644
--- a/base/gxpcmap.c
+++ b/base/gxpcmap.c
@@ -101,97 +101,55 @@ static dev_proc_fill_rectangle_hl_color(pattern_accum_fill_rectangle_hl_color);
dev_proc_dev_spec_op(pattern_accum_dev_spec_op);
/* The device descriptor */
+static void
+pattern_accum_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, pattern_accum_open);
+ set_dev_proc(dev, close_device, pattern_accum_close);
+ set_dev_proc(dev, fill_rectangle, pattern_accum_fill_rectangle);
+ set_dev_proc(dev, copy_mono, pattern_accum_copy_mono);
+ set_dev_proc(dev, copy_color, pattern_accum_copy_color);
+ set_dev_proc(dev, get_clipping_box, gx_get_largest_clipping_box);
+ set_dev_proc(dev, get_bits_rectangle, pattern_accum_get_bits_rectangle);
+ set_dev_proc(dev, fill_rectangle_hl_color, pattern_accum_fill_rectangle_hl_color);
+ set_dev_proc(dev, dev_spec_op, pattern_accum_dev_spec_op);
+ set_dev_proc(dev, copy_planes, pattern_accum_copy_planes);
+
+ /* It would be much nicer if gx_device_init set the following
+ * defaults for us, but that doesn't work for some reason. */
+ set_dev_proc(dev, copy_alpha, gx_default_copy_alpha);
+ set_dev_proc(dev, fill_path, gx_default_fill_path);
+ set_dev_proc(dev, stroke_path, gx_default_stroke_path);
+ set_dev_proc(dev, fill_mask, gx_default_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, gx_default_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, gx_default_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, gx_default_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, gx_default_draw_thin_line);
+ set_dev_proc(dev, strip_tile_rectangle, gx_default_strip_tile_rectangle);
+ set_dev_proc(dev, begin_typed_image, gx_default_begin_typed_image);
+ set_dev_proc(dev, composite, gx_default_composite);
+ set_dev_proc(dev, text_begin, gx_default_text_begin);
+ set_dev_proc(dev, strip_copy_rop2, gx_default_strip_copy_rop2);
+ set_dev_proc(dev, strip_tile_rect_devn, gx_default_strip_tile_rect_devn);
+ set_dev_proc(dev, transform_pixel_region, gx_default_transform_pixel_region);
+ set_dev_proc(dev, fill_stroke_path, gx_default_fill_stroke_path);
+}
+
static const gx_device_pattern_accum gs_pattern_accum_device =
-{std_device_std_body_type_open(gx_device_pattern_accum, 0,
- "pattern accumulator", &st_device_pattern_accum,
- 0, 0, 72, 72),
- {
- /* NOTE: all drawing procedures must be defaulted, not forwarded. */
- pattern_accum_open,
- NULL, /* get_initial_matrix */
- NULL, /* sync_output */
- NULL, /* output_page */
- pattern_accum_close,
- NULL, /* map_rgb_color */
- NULL, /* map_color_rgb */
- pattern_accum_fill_rectangle,
- gx_default_tile_rectangle,
- pattern_accum_copy_mono,
- pattern_accum_copy_color,
- NULL, /* obselete_draw_line */
- gx_default_get_bits,
- NULL, /* get_params */
- NULL, /* put_params */
- NULL, /* map_cmyk_color */
- NULL, /* get_xfont_procs */
- NULL, /* get_xfont_device */
- NULL, /* map_rgb_alpha_color */
- NULL, /* get_page_device */
- NULL, /* get_alpha_bits */
- gx_default_copy_alpha,
- NULL, /* get_band */
- gx_default_copy_rop,
- gx_default_fill_path,
- gx_default_stroke_path,
- gx_default_fill_mask,
- gx_default_fill_trapezoid,
- gx_default_fill_parallelogram,
- gx_default_fill_triangle,
- gx_default_draw_thin_line,
- gx_default_begin_image,
- gx_default_image_data,
- gx_default_end_image,
- gx_default_strip_tile_rectangle,
- gx_default_strip_copy_rop,
- gx_get_largest_clipping_box,
- gx_default_begin_typed_image,
- pattern_accum_get_bits_rectangle,
- NULL, /* map_color_rgb_alpha */
- gx_default_create_compositor,
- NULL, /* create_compositor */
- gx_default_text_begin,
- gx_default_finish_copydevice,
- NULL, /* begin_transparency_group */
- NULL, /* end_transparency_group */
- NULL, /* begin_transparency_mask */
- NULL, /* end_transparency_mask */
- NULL, /* discard_transparency_layer */
- NULL, /* get_color_mapping_procs */
- NULL, /* get_color_comp_index */
- NULL, /* encode_color */
- NULL, /* decode_color */
- NULL, /* pattern_manage */
- pattern_accum_fill_rectangle_hl_color, /* fill_rectangle_hl_color */
- NULL, /* include_color_space */
- NULL, /* fill_linear_color_scanline */
- NULL, /* fill_linear_color_trapezoid */
- NULL, /* fill_linear_color_triangle */
- NULL, /* update_spot_equivalent_colors */
- NULL, /* ret_devn_params */
- NULL, /* fillpage */
- NULL, /* push_transparency_state */
- NULL, /* pop_transparency_state */
- NULL, /* put_image */
- pattern_accum_dev_spec_op, /* dev_spec_op */
- pattern_accum_copy_planes, /* copy_planes */
- NULL, /* get_profile */
- NULL, /* set_graphics_type_tag */
- gx_default_strip_copy_rop2,
- gx_default_strip_tile_rect_devn,
- NULL, /* alpha_hl_color */
- NULL, /* process_page */
- gx_default_transform_pixel_region, /* NOT the default forwarding one */
- gx_default_fill_stroke_path,
-},
- 0, /* target */
- 0, 0, 0, 0 /* bitmap_memory, bits, mask, instance */
+{std_device_std_body_type_open(gx_device_pattern_accum,
+ pattern_accum_initialize_device_procs,
+ "pattern accumulator",
+ &st_device_pattern_accum,
+ 0, 0, 72, 72)
};
+extern dev_proc_open_device(clist_open);
+
int
pattern_clist_open_device(gx_device *dev)
{
/* This function is defiled only for clist_init_bands. */
- return gs_clist_device_procs.open_device(dev);
+ return clist_open(dev);
}
static dev_proc_create_buf_device(dummy_create_buf_device)
@@ -296,9 +254,9 @@ gx_pattern_accum_alloc(gs_memory_t * mem, gs_memory_t * storage_memory,
emprintf(mem, "not using clist even though clist is requested\n");
#endif
pinst->is_clist = false;
- gx_device_init((gx_device *)adev,
- (const gx_device *)&gs_pattern_accum_device,
- mem, true);
+ (void)gx_device_init((gx_device *)adev,
+ (const gx_device *)&gs_pattern_accum_device,
+ mem, true);
adev->instance = pinst;
adev->bitmap_memory = storage_memory;
fdev = (gx_device_forward *)adev;
@@ -673,6 +631,8 @@ blank_unmasked_bits(gx_device * mask,
int code = 0;
byte *ptr;
int blank = (polarity == GX_CINFO_POLARITY_ADDITIVE ? 255 : 0);
+ gs_int_rect rect;
+ gs_get_bits_params_t params;
if ((p->options & required_options) != required_options)
return_error(gs_error_rangecheck);
@@ -681,6 +641,11 @@ blank_unmasked_bits(gx_device * mask,
if (min == NULL)
return_error(gs_error_VMerror);
+ rect.p.x = 0;
+ rect.q.x = mask->width;
+ params.x_offset = 0;
+ params.raster = bitmap_raster(mask->width * mask->color_info.depth);
+
if (p->options & GB_PACKING_CHUNKY)
{
if ((depth & 7) != 0 || depth > 64)
@@ -691,9 +656,20 @@ blank_unmasked_bits(gx_device * mask,
for (y = 0; y < h; y++)
{
byte *mine;
- code = dev_proc(mask, get_bits)(mask, y+y0, min, &mine);
+
+ rect.p.y = y+y0;
+ rect.q.y = y+y0+1;
+ params.options = (GB_ALIGN_ANY |
+ (GB_RETURN_COPY | GB_RETURN_POINTER) |
+ GB_OFFSET_0 |
+ GB_RASTER_STANDARD | GB_PACKING_CHUNKY |
+ GB_COLORS_NATIVE | GB_ALPHA_NONE);
+ params.data[0] = min;
+ code = (*dev_proc(mask, get_bits_rectangle))(mask, &rect,
+ &params);
if (code < 0)
goto fail;
+ mine = params.data[0];
for (x = 0; x < w; x++)
{
int xx = x+x0;
@@ -734,9 +710,21 @@ blank_unmasked_bits(gx_device * mask,
{
int c;
byte *mine;
- code = dev_proc(mask, get_bits)(mask, y+y0, min, &mine);
+
+ rect.p.y = y+y0;
+ rect.q.y = y+y0+1;
+ params.options = (GB_ALIGN_ANY |
+ (GB_RETURN_COPY | GB_RETURN_POINTER) |
+ GB_OFFSET_0 |
+ GB_RASTER_STANDARD | GB_PACKING_CHUNKY |
+ GB_COLORS_NATIVE | GB_ALPHA_NONE);
+ params.data[0] = min;
+ code = (*dev_proc(mask, get_bits_rectangle))(mask, &rect,
+ &params);
if (code < 0)
goto fail;
+ mine = params.data[0];
+
for (c = 0; c < num_comps; c++)
{
if (p->data[c] == NULL)
@@ -767,7 +755,7 @@ fail:
/****** SHOULD USE MASK TO DEFINE UNREAD AREA *****/
static int
pattern_accum_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
- gs_get_bits_params_t * params, gs_int_rect ** unread)
+ gs_get_bits_params_t * params)
{
gx_device_pattern_accum *const padev = (gx_device_pattern_accum *) dev;
int code;
@@ -777,7 +765,7 @@ pattern_accum_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
if (padev->mask)
params2.options &= ~GB_RETURN_POINTER;
code = (*dev_proc(padev->target, get_bits_rectangle))
- (padev->target, prect, &params2, unread);
+ (padev->target, prect, &params2);
/* If we have a mask, then unmarked pixels of the bits
* will be undefined. Strictly speaking it makes no
* sense for us to return any value here, but the only
diff --git a/base/gxsamplp.h b/base/gxsamplp.h
index 143b240c..8d5e39f9 100644
--- a/base/gxsamplp.h
+++ b/base/gxsamplp.h
@@ -325,4 +325,3 @@ TEMPLATE_sample_unpack_8(byte * bptr, int *pdata_x, const byte * data, int data_
#else
int dummy;
#endif
-
diff --git a/base/gxshade.c b/base/gxshade.c
index 80e3b742..69134fb0 100644
--- a/base/gxshade.c
+++ b/base/gxshade.c
@@ -87,6 +87,7 @@ shade_next_init(shade_coord_stream_t * cs,
cs->is_eod = cs_eod;
cs->left = 0;
cs->ds_EOF = false;
+ cs->first_patch = 1;
}
/* Check for the End-Of-Data state form a stream. */
@@ -365,7 +366,7 @@ top:
}
if (num_colors <= 32) {
/****** WRONG FOR MULTI-PLANE HALFTONES ******/
- num_colors *= pgs->dev_ht->components[0].corder.num_levels;
+ num_colors *= pgs->dev_ht[HT_OBJTYPE_DEFAULT]->components[0].corder.num_levels;
}
if (psh->head.type == 2 || psh->head.type == 3) {
max_error *= 0.25;
@@ -390,7 +391,7 @@ top:
return code;
}
rendering_params.black_point_comp = pgs->blackptcomp;
- rendering_params.graphics_type_tag = GS_PATH_TAG;
+ rendering_params.graphics_type_tag = GS_VECTOR_TAG;
rendering_params.override_icc = false;
rendering_params.preserve_black = gsBKPRESNOTSPECIFIED;
rendering_params.rendering_intent = pgs->renderingintent;
diff --git a/base/gxshade.h b/base/gxshade.h
index 4990b25e..3a2de811 100644
--- a/base/gxshade.h
+++ b/base/gxshade.h
@@ -122,6 +122,7 @@ struct shade_coord_stream_s {
const float decode[2], float *pvalue);
void (*align)(shade_coord_stream_t *cs, int radix);
bool (*is_eod)(const shade_coord_stream_t *cs);
+ int first_patch; /* True, if we have not read a patch yet */
};
/* Define one vertex of a mesh. */
diff --git a/base/gxshade1.c b/base/gxshade1.c
index c105f6cf..fc207718 100644
--- a/base/gxshade1.c
+++ b/base/gxshade1.c
@@ -175,6 +175,165 @@ typedef struct A_fill_state_s {
/* Note t0 and t1 vary over [0..1], not the Domain. */
+typedef struct
+{
+ patch_curve_t curve[4];
+ gs_point corners[4];
+} corners_and_curves;
+
+/* Ghostscript cannot possibly render any patch whose bounds aren't
+ * representable in fixed's. In fact, this is a larger limit than
+ * we need. We notionally have an area defined by coordinates
+ * that can be represented in fixed point with at least 1 bit to
+ * spare.
+ *
+ * Any patch that lies completely outside this region can be clipped
+ * away. Any patch that isn't representable by fixed points can be
+ * subdivided into 4.
+ *
+ * This avoids us subdividing patches huge numbers of times because
+ * one side is just outside the region we will accept.
+ */
+
+
+#define MIN_CLIP_LIMIT ((int)(fixed2int(min_fixed)/2))
+#define MAX_CLIP_LIMIT ((int)(fixed2int(max_fixed)/2))
+
+static int not_clipped_away(const gs_point *p)
+{
+ if (p[0].x < MIN_CLIP_LIMIT &&
+ p[1].x < MIN_CLIP_LIMIT &&
+ p[2].x < MIN_CLIP_LIMIT &&
+ p[3].x < MIN_CLIP_LIMIT)
+ return 0; /* Clipped away! */
+ if (p[0].x > MAX_CLIP_LIMIT &&
+ p[1].x > MAX_CLIP_LIMIT &&
+ p[2].x > MAX_CLIP_LIMIT &&
+ p[3].x > MAX_CLIP_LIMIT)
+ return 0; /* Clipped away! */
+ if (p[0].y < MIN_CLIP_LIMIT &&
+ p[1].y < MIN_CLIP_LIMIT &&
+ p[2].y < MIN_CLIP_LIMIT &&
+ p[3].y < MIN_CLIP_LIMIT)
+ return 0; /* Clipped away! */
+ if (p[0].y > MAX_CLIP_LIMIT &&
+ p[1].y > MAX_CLIP_LIMIT &&
+ p[2].y > MAX_CLIP_LIMIT &&
+ p[3].y > MAX_CLIP_LIMIT)
+ return 0; /* Clipped away! */
+ return 1;
+}
+
+#define f_fits_in_fixed(f) f_fits_in_bits(f, fixed_int_bits)
+
+static int
+A_fill_region_floats(patch_fill_state_t *pfs1, corners_and_curves *cc, int depth)
+{
+ corners_and_curves sub[4];
+ int code;
+
+ if (depth == 32)
+ return gs_error_limitcheck;
+
+ if (depth > 0 &&
+ f_fits_in_fixed(cc->corners[0].x) &&
+ f_fits_in_fixed(cc->corners[0].y) &&
+ f_fits_in_fixed(cc->corners[1].x) &&
+ f_fits_in_fixed(cc->corners[1].y) &&
+ f_fits_in_fixed(cc->corners[2].x) &&
+ f_fits_in_fixed(cc->corners[2].y) &&
+ f_fits_in_fixed(cc->corners[3].x) &&
+ f_fits_in_fixed(cc->corners[3].y))
+ {
+ cc->curve[0].vertex.p.x = float2fixed(cc->corners[0].x);
+ cc->curve[0].vertex.p.y = float2fixed(cc->corners[0].y);
+ cc->curve[1].vertex.p.x = float2fixed(cc->corners[1].x);
+ cc->curve[1].vertex.p.y = float2fixed(cc->corners[1].y);
+ cc->curve[2].vertex.p.x = float2fixed(cc->corners[2].x);
+ cc->curve[2].vertex.p.y = float2fixed(cc->corners[2].y);
+ cc->curve[3].vertex.p.x = float2fixed(cc->corners[3].x);
+ cc->curve[3].vertex.p.y = float2fixed(cc->corners[3].y);
+ cc->curve[0].vertex.cc[1] = cc->curve[1].vertex.cc[1] =
+ cc->curve[2].vertex.cc[1] =
+ cc->curve[3].vertex.cc[1] = 0;
+ make_other_poles(cc->curve);
+ return patch_fill(pfs1, cc->curve, NULL, NULL);
+ }
+
+ /* We have patches with corners:
+ * 0 1
+ * 3 2
+ * We subdivide these into 4 smaller patches:
+ *
+ * 0 10 1 Where 0123 are corners
+ * [0] [1] [0][1][2][3] are patches.
+ * 3 23 2
+ * 0 10 1
+ * [3] [2]
+ * 3 23 2
+ */
+
+ sub[0].corners[0].x = cc->corners[0].x;
+ sub[0].corners[0].y = cc->corners[0].y;
+ sub[1].corners[1].x = cc->corners[1].x;
+ sub[1].corners[1].y = cc->corners[1].y;
+ sub[2].corners[2].x = cc->corners[2].x;
+ sub[2].corners[2].y = cc->corners[2].y;
+ sub[3].corners[3].x = cc->corners[3].x;
+ sub[3].corners[3].y = cc->corners[3].y;
+ sub[1].corners[0].x = sub[0].corners[1].x = (cc->corners[0].x + cc->corners[1].x)/2;
+ sub[1].corners[0].y = sub[0].corners[1].y = (cc->corners[0].y + cc->corners[1].y)/2;
+ sub[3].corners[2].x = sub[2].corners[3].x = (cc->corners[2].x + cc->corners[3].x)/2;
+ sub[3].corners[2].y = sub[2].corners[3].y = (cc->corners[2].y + cc->corners[3].y)/2;
+ sub[3].corners[0].x = sub[0].corners[3].x = (cc->corners[0].x + cc->corners[3].x)/2;
+ sub[3].corners[0].y = sub[0].corners[3].y = (cc->corners[0].y + cc->corners[3].y)/2;
+ sub[2].corners[1].x = sub[1].corners[2].x = (cc->corners[1].x + cc->corners[2].x)/2;
+ sub[2].corners[1].y = sub[1].corners[2].y = (cc->corners[1].y + cc->corners[2].y)/2;
+ sub[0].corners[2].x = sub[1].corners[3].x =
+ sub[2].corners[0].x =
+ sub[3].corners[1].x = (sub[0].corners[3].x + sub[1].corners[2].x)/2;
+ sub[0].corners[2].y = sub[1].corners[3].y =
+ sub[2].corners[0].y =
+ sub[3].corners[1].y = (sub[0].corners[3].y + sub[1].corners[2].y)/2;
+ sub[0].curve[0].vertex.cc[0] = sub[0].curve[3].vertex.cc[0] =
+ sub[3].curve[0].vertex.cc[0] =
+ sub[3].curve[3].vertex.cc[0] = cc->curve[0].vertex.cc[0];
+ sub[1].curve[1].vertex.cc[0] = sub[1].curve[2].vertex.cc[0] =
+ sub[2].curve[1].vertex.cc[0] =
+ sub[2].curve[2].vertex.cc[0] = cc->curve[1].vertex.cc[0];
+ sub[0].curve[1].vertex.cc[0] = sub[0].curve[2].vertex.cc[0] =
+ sub[1].curve[0].vertex.cc[0] =
+ sub[1].curve[3].vertex.cc[0] =
+ sub[2].curve[0].vertex.cc[0] =
+ sub[2].curve[3].vertex.cc[0] =
+ sub[3].curve[1].vertex.cc[0] =
+ sub[3].curve[2].vertex.cc[0] = (cc->curve[0].vertex.cc[0] + cc->curve[1].vertex.cc[0])/2;
+
+ depth++;
+ if (not_clipped_away(sub[0].corners)) {
+ code = A_fill_region_floats(pfs1, &sub[0], depth);
+ if (code < 0)
+ return code;
+ }
+ if (not_clipped_away(sub[1].corners)) {
+ code = A_fill_region_floats(pfs1, &sub[1], depth);
+ if (code < 0)
+ return code;
+ }
+ if (not_clipped_away(sub[2].corners)) {
+ code = A_fill_region_floats(pfs1, &sub[2], depth);
+ if (code < 0)
+ return code;
+ }
+ if (not_clipped_away(sub[3].corners)) {
+ code = A_fill_region_floats(pfs1, &sub[3], depth);
+ if (code < 0)
+ return code;
+ }
+
+ return 0;
+}
+
static int
A_fill_region(A_fill_state_t * pfs, patch_fill_state_t *pfs1)
{
@@ -184,31 +343,60 @@ A_fill_region(A_fill_state_t * pfs, patch_fill_state_t *pfs1)
double x1 = psh->params.Coords[0] + pfs->delta.x * pfs->v1;
double y1 = psh->params.Coords[1] + pfs->delta.y * pfs->v1;
double h0 = pfs->u0, h1 = pfs->u1;
- patch_curve_t curve[4];
+ corners_and_curves cc;
int code;
- code = gs_point_transform2fixed(&pfs1->pgs->ctm, x0 + pfs->delta.y * h0, y0 - pfs->delta.x * h0, &curve[0].vertex.p);
+ double dx0 = pfs->delta.x * h0;
+ double dy0 = pfs->delta.y * h0;
+ double dx1 = pfs->delta.x * h1;
+ double dy1 = pfs->delta.y * h1;
+
+ cc.curve[0].vertex.cc[0] = pfs->t0; /* The element cc[1] is set to a dummy value against */
+ cc.curve[1].vertex.cc[0] = pfs->t1; /* interrupts while an idle priocessing in gxshade.6.c . */
+ cc.curve[2].vertex.cc[0] = pfs->t1;
+ cc.curve[3].vertex.cc[0] = pfs->t0;
+ cc.curve[0].vertex.cc[1] = 0; /* The element cc[1] is set to a dummy value against */
+ cc.curve[1].vertex.cc[1] = 0; /* interrupts while an idle priocessing in gxshade.6.c . */
+ cc.curve[2].vertex.cc[1] = 0;
+ cc.curve[3].vertex.cc[1] = 0;
+ cc.corners[0].x = x0 + dy0;
+ cc.corners[0].y = y0 - dx0;
+ cc.corners[1].x = x1 + dy0;
+ cc.corners[1].y = y1 - dx0;
+ cc.corners[2].x = x1 + dy1;
+ cc.corners[2].y = y1 - dx1;
+ cc.corners[3].x = x0 + dy1;
+ cc.corners[3].y = y0 - dx1;
+ code = gs_point_transform2fixed(&pfs1->pgs->ctm, cc.corners[0].x, cc.corners[0].y, &cc.curve[0].vertex.p);
+ if (code < 0)
+ goto fail;
+ code = gs_point_transform2fixed(&pfs1->pgs->ctm, cc.corners[1].x, cc.corners[1].y, &cc.curve[1].vertex.p);
+ if (code < 0)
+ goto fail;
+ code = gs_point_transform2fixed(&pfs1->pgs->ctm, cc.corners[2].x, cc.corners[2].y, &cc.curve[2].vertex.p);
+ if (code < 0)
+ goto fail;
+ code = gs_point_transform2fixed(&pfs1->pgs->ctm, cc.corners[3].x, cc.corners[3].y, &cc.curve[3].vertex.p);
+ if (code < 0)
+ goto fail;
+ make_other_poles(cc.curve);
+ return patch_fill(pfs1, cc.curve, NULL, NULL);
+fail:
+ if (code != gs_error_limitcheck)
+ return code;
+ code = gs_point_transform(cc.corners[0].x, cc.corners[0].y, (const gs_matrix *)&pfs1->pgs->ctm, &cc.corners[0]);
if (code < 0)
return code;
- code = gs_point_transform2fixed(&pfs1->pgs->ctm, x1 + pfs->delta.y * h0, y1 - pfs->delta.x * h0, &curve[1].vertex.p);
+ code = gs_point_transform(cc.corners[1].x, cc.corners[1].y, (const gs_matrix *)&pfs1->pgs->ctm, &cc.corners[1]);
if (code < 0)
return code;
- code = gs_point_transform2fixed(&pfs1->pgs->ctm, x1 + pfs->delta.y * h1, y1 - pfs->delta.x * h1, &curve[2].vertex.p);
+ code = gs_point_transform(cc.corners[2].x, cc.corners[2].y, (const gs_matrix *)&pfs1->pgs->ctm, &cc.corners[2]);
if (code < 0)
return code;
- code = gs_point_transform2fixed(&pfs1->pgs->ctm, x0 + pfs->delta.y * h1, y0 - pfs->delta.x * h1, &curve[3].vertex.p);
+ code = gs_point_transform(cc.corners[3].x, cc.corners[3].y, (const gs_matrix *)&pfs1->pgs->ctm, &cc.corners[3]);
if (code < 0)
return code;
- curve[0].vertex.cc[0] = pfs->t0; /* The element cc[1] is set to a dummy value against */
- curve[1].vertex.cc[0] = pfs->t1; /* interrupts while an idle priocessing in gxshade.6.c . */
- curve[2].vertex.cc[0] = pfs->t1;
- curve[3].vertex.cc[0] = pfs->t0;
- curve[0].vertex.cc[1] = 0; /* The element cc[1] is set to a dummy value against */
- curve[1].vertex.cc[1] = 0; /* interrupts while an idle priocessing in gxshade.6.c . */
- curve[2].vertex.cc[1] = 0;
- curve[3].vertex.cc[1] = 0;
- make_other_poles(curve);
- return patch_fill(pfs1, curve, NULL, NULL);
+ return A_fill_region_floats(pfs1, &cc, 0);
}
static inline int
diff --git a/base/gxshade6.c b/base/gxshade6.c
index e8f9349b..334e05a6 100644
--- a/base/gxshade6.c
+++ b/base/gxshade6.c
@@ -169,7 +169,7 @@ shade_next_curve(shade_coord_stream_t * cs, patch_curve_t * curve)
*/
static int
shade_next_patch(shade_coord_stream_t * cs, int BitsPerFlag,
- patch_curve_t curve[4], gs_fixed_point interior[4] /* 0 for Coons patch */ )
+ patch_curve_t curve[4], gs_fixed_point interior[4] /* 0 for Coons patch */)
{
int flag = shade_next_flag(cs, BitsPerFlag);
int num_colors, code;
@@ -179,6 +179,10 @@ shade_next_patch(shade_coord_stream_t * cs, int BitsPerFlag,
return_error(gs_error_rangecheck);
return 1; /* no more data */
}
+ if (cs->first_patch && (flag & 3) != 0) {
+ return_error(gs_error_rangecheck);
+ }
+ cs->first_patch = 0;
switch (flag & 3) {
default:
return_error(gs_error_rangecheck); /* not possible */
diff --git a/base/gxtext.h b/base/gxtext.h
index e6836ae7..babaaf1e 100644
--- a/base/gxtext.h
+++ b/base/gxtext.h
@@ -97,8 +97,6 @@ rc_free_proc(rc_free_text_enum);
gx_device *imaging_dev; /* see note below */\
gs_gstate *pgs;\
gs_font *orig_font;\
- gx_path *path; /* unless DO_NONE & !RETURN_WIDTH */\
- const gx_device_color *pdcolor; /* if DO_DRAW */\
const gx_clip_path *pcpath; /* if DO_DRAW */\
gs_memory_t *memory;\
/* The following additional members are set at initialization. */\
@@ -175,6 +173,8 @@ struct gs_text_enum_s {
gs_text_enum_common;
};
+#define gs_text_enum_path(pte) ((pte)->pgs->path)
+
/*
* Notes on the imaging_dev field of device enumeration structures:
*
@@ -227,8 +227,7 @@ int gs_text_enum_init(gs_text_enum_t *pte,
const gs_text_enum_procs_t *procs,
gx_device *dev, gs_gstate *pgs,
const gs_text_params_t *text,
- gs_font *font, gx_path *path,
- const gx_device_color *pdcolor,
+ gs_font *font,
const gx_clip_path *pcpath,
gs_memory_t *mem);
diff --git a/base/gzht.h b/base/gzht.h
index 9c1e0fe8..358bd350 100644
--- a/base/gzht.h
+++ b/base/gzht.h
@@ -196,7 +196,14 @@ void gx_ht_order_release(gx_ht_order * porder, gs_memory_t * mem, bool free_cach
int gx_gstate_dev_ht_install(gs_gstate * pgs,
gx_device_halftone * pdht,
gs_halftone_type type,
- const gx_device * dev);
+ const gx_device * dev,
+ gs_HT_objtype_t objtype);
+
+/*
+ * Copy the current dev_ht[HT_OBJTYPE_DEFAULT] to the dev_ht[] for the specified object type.
+ */
+int
+gx_gstate_dev_ht_copy_to_objtype(gs_gstate *pgs, gs_HT_objtype_t objtype);
/*
* Install a new halftone in the graphics state. Note that we copy the top
diff --git a/base/gzspotan.c b/base/gzspotan.c
index 847f3c9d..4deef1c8 100644
--- a/base/gzspotan.c
+++ b/base/gzspotan.c
@@ -205,63 +205,18 @@ trap_is_last(const gx_san_trap *list, const gx_san_trap *t)
/* The device descriptor */
/* Many of these procedures won't be called; they are set to NULL. */
+static void
+san_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, san_open);
+ set_dev_proc(dev, close_device, san_close);
+ set_dev_proc(dev, fill_path, gx_default_fill_path);
+ set_dev_proc(dev, get_clipping_box, san_get_clipping_box);
+}
static const gx_device_spot_analyzer gx_spot_analyzer_device =
-{std_device_std_body(gx_device_spot_analyzer, 0, "spot analyzer",
- 0, 0, 1, 1),
- {san_open,
- NULL,
- NULL,
- NULL,
- san_close,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- gx_default_fill_path,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- san_get_clipping_box,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- gx_default_finish_copydevice,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL,
- NULL
- }
+{std_device_std_body(gx_device_spot_analyzer,
+ san_initialize_device_procs, "spot analyzer",
+ 0, 0, 1, 1)
};
int
@@ -419,8 +374,11 @@ gx_san__obtain(gs_memory_t *mem, gx_device_spot_analyzer **ppadev)
&st_device_spot_analyzer, "gx_san__obtain");
if (padev == 0)
return_error(gs_error_VMerror);
- gx_device_init((gx_device *)padev, (const gx_device *)&gx_spot_analyzer_device,
- mem, false);
+ code = gx_device_init((gx_device *)padev,
+ (const gx_device *)&gx_spot_analyzer_device,
+ mem, false);
+ if (code < 0)
+ return code;
code = gs_opendevice((gx_device *)padev);
if (code < 0) {
gs_free_object(mem, padev, "gx_san__obtain");
diff --git a/base/lcups.mak b/base/lcups.mak
index 5189fe71..001b538c 100644
--- a/base/lcups.mak
+++ b/base/lcups.mak
@@ -30,7 +30,7 @@ LCUPSO_=$(O_)$(LIBCUPSOBJ)
# NB: we can't use the normal $(CC_) here because msvccmd.mak
# adds /Za which conflicts with the cups source.
-LCUPS_CC=$(CUPS_CC) $(I_)$(LIBCUPSSRC) $(I_)$(LIBCUPSGEN)$(D)cups $(I_)$(LCUPSSRCDIR)$(D)libs
+LCUPS_CC=$(CUPS_CC) $(CUPSCFLAGS) $(I_)$(LIBCUPSSRC) $(I_)$(LIBCUPSGEN)$(D)cups $(I_)$(LCUPSSRCDIR)$(D)libs
# Define the name of this makefile.
LCUPS_MAK=$(GLSRC)lcups.mak $(TOP_MAKEFILES)
diff --git a/base/leptonica.mak b/base/leptonica.mak
index df72241d..5ffcee63 100644
--- a/base/leptonica.mak
+++ b/base/leptonica.mak
@@ -4,7 +4,7 @@ LEPTINCLUDES=\
$(I_)$(GLGENDIR)$(_I)
LEPTCFLAGS_LOCAL=\
- -DLEPTONICA_INTERCEPT_MALLOC=1\
+ -DLEPTONICA_INTERCEPT_ALLOC=1\
-DHAVE_LIBJPEG=0\
-DHAVE_LIBTIFF=0\
-DHAVE_LIBPNG=0\
@@ -15,7 +15,7 @@ LEPTCFLAGS_LOCAL=\
-DHAVE_LIBWEBP_ANIM=0\
-DHAVE_LIBJP2K=0
-LEPTCC = $(CC) $(CCFLAGS) $(LEPTINCLUDES) $(LEPTCFLAGS_LOCAL)
+LEPTCC = $(CC) $(CCFLAGS) $(LEPTINCLUDES) $(LEPTCFLAGS_LOCAL) $(LEPTSUPPRESS)
LEPTOBJ = $(GLOBJDIR)$(D)leptonica_
LEPTO_ = $(O_)$(LEPTOBJ)
diff --git a/base/lib.mak b/base/lib.mak
index f6845c97..e8d5719d 100644
--- a/base/lib.mak
+++ b/base/lib.mak
@@ -434,6 +434,7 @@ gsccolor_h=$(GLSRC)gsccolor.h
# gscedata.[ch] are generated automatically by lib/encs2c.ps.
gscedata_h=$(GLSRC)gscedata.h
gscencs_h=$(GLSRC)gscencs.h
+gsagl_h=$(GLSRC)gsagl.h
gsclipsr_h=$(GLSRC)gsclipsr.h
gscsel_h=$(GLSRC)gscsel.h
gscolor1_h=$(GLSRC)gscolor1.h
@@ -488,7 +489,6 @@ gxcoord_h=$(GLSRC)gxcoord.h
gxcpath_h=$(GLSRC)gxcpath.h
gxdda_h=$(GLSRC)gxdda.h
gxdevbuf_h=$(GLSRC)gxdevbuf.h
-gxdevrop_h=$(GLSRC)gxdevrop.h
gxdevmem_h=$(GLSRC)gxdevmem.h
gxdhtres_h=$(GLSRC)gxdhtres.h
gxfont0_h=$(GLSRC)gxfont0.h
@@ -1012,7 +1012,7 @@ $(GLOBJ)gsgcache.$(OBJ) : $(GLSRC)gsgcache.c $(AK) $(gx_h)\
$(GLCC) $(GLO_)gsgcache.$(OBJ) $(C_) $(GLSRC)gsgcache.c
$(GLOBJ)gsht.$(OBJ) : $(GLSRC)gsht.c $(AK) $(gx_h) $(gserrors_h)\
- $(memory__h) $(string__h) $(gsstruct_h) $(gsutil_h) $(gxarith_h)\
+ $(memory__h) $(string__h) $(gsstruct_h) $(gsutil_h) $(gxarith_h) $(gxdevsop_h)\
$(gxdevice_h) $(gzht_h) $(gzstate_h) $(gxfmap_h) $(gp_h) $(LIB_MAK) $(MAKEDIRS)
$(GLCC) $(GLO_)gsht.$(OBJ) $(C_) $(GLSRC)gsht.c
@@ -1969,8 +1969,9 @@ $(GLOBJ)sfilter1.$(OBJ) : $(GLSRC)sfilter1.c $(AK) $(stdio__h) $(memory__h)\
$(GLCC) $(GLO_)sfilter1.$(OBJ) $(C_) $(GLSRC)sfilter1.c
$(GLD)psfilters.dev : $(ECHOGS_XE) $(LIB_MAK) $(GLOBJ)sfilter2.$(OBJ)\
- $(GLOBJ)sfilter1.$(OBJ) $(LIB_MAK) $(MAKEDIRS)
- $(SETMOD) $(GLD)psfilters $(GLOBJ)sfilter1.$(OBJ) $(GLOBJ)sfilter2.$(OBJ)
+ $(GLOBJ)sfilter1.$(OBJ) $(GLOBJ)sa85d.$(OBJ) $(LIB_MAK) $(MAKEDIRS)
+ $(SETMOD) $(GLD)psfilters $(GLOBJ)sfilter1.$(OBJ) $(GLOBJ)sfilter2.$(OBJ) $(GLOBJ)sa85d.$(OBJ)
+ $(ADDMOD) $(GLD)psfilters $(GLOBJ)sa85d.$(OBJ)
$(GLOBJ)sstring.$(OBJ) : $(GLSRC)sstring.c $(AK)\
$(stdio__h) $(memory__h) $(string__h)\
@@ -2407,13 +2408,13 @@ $(GLD)roplib.dev : $(LIB_MAK) $(ECHOGS_XE) $(roplib_) $(LIB_MAK) $(MAKEDIRS)
$(GLOBJ)gdevdrop_1.$(OBJ) : $(GLSRC)gdevdrop.c $(AK) $(gx_h) $(gserrors_h) \
$(memory__h) $(gxdevsop_h) $(gsbittab_h) $(gsropt_h) $(gxcindex_h) \
- $(gxdcolor_h) $(gxdevice_h) $(gxdevmem_h) $(gxdevrop_h) $(gxgetbit_h) \
+ $(gxdcolor_h) $(gxdevice_h) $(gxdevmem_h) $(gxgetbit_h) \
$(gdevmem_h) $(gdevmrop_h) $(gdevmpla_h) $(stdint__h) $(LIB_MAK) $(MAKEDIRS)
$(GLCC) $(D_)WITH_CAL$(_D) $(I_)$(CALSRCDIR)$(_I) $(GLO_)gdevdrop_1.$(OBJ) $(C_) $(GLSRC)gdevdrop.c
$(GLOBJ)gdevdrop_0.$(OBJ) : $(GLSRC)gdevdrop.c $(AK) $(gx_h) $(gserrors_h) \
$(memory__h) $(gxdevsop_h) $(gsbittab_h) $(gsropt_h) $(gxcindex_h) \
- $(gxdcolor_h) $(gxdevice_h) $(gxdevmem_h) $(gxdevrop_h) $(gxgetbit_h) \
+ $(gxdcolor_h) $(gxdevice_h) $(gxdevmem_h) $(gxgetbit_h) \
$(gdevmem_h) $(gdevmrop_h) $(gdevmpla_h) $(stdint__h) $(LIB_MAK) $(MAKEDIRS)
$(GLCC) $(GLO_)gdevdrop_0.$(OBJ) $(C_) $(GLSRC)gdevdrop.c
@@ -3398,6 +3399,33 @@ $(GLGEN)xpsromfs0_1.c : $(MKROMFS_XE) $(LIB_MAK) $(MAKEDIRS)
$(GLGEN)xpsromfs0.c : $(GLGEN)xpsromfs0_$(UFST_BRIDGE).c $(LIB_MAK) $(MAKEDIRS)
$(CP_) $(GLGEN)xpsromfs0_$(UFST_BRIDGE).c $(GLGEN)xpsromfs0.c
+# pdf
+$(GLGEN)pdfromfs1_.c : $(MKROMFS_XE) $(LIB_MAK) $(MAKEDIRS)
+ $(EXP)$(MKROMFS_XE) -o $(GLGEN)pdfromfs1_.c \
+ -X .svn -X CVS -P $(GLSRCDIR)$(D)..$(D) iccprofiles$(D)* \
+ $(PDF_ROMFS_ARGS) $(PDF_FONT_ROMFS_ARGS) $(GL_ROMFS_ARGS)
+
+$(GLGEN)pdfromfs1_1.c : $(MKROMFS_XE) $(LIB_MAK) $(MAKEDIRS)
+ $(EXP)$(MKROMFS_XE) -o $(GLGEN)pdfromfs1_1.c \
+ -X .svn -X CVS -P $(GLSRCDIR)$(D)..$(D) iccprofiles$(D)* \
+ $(PDF_ROMFS_ARGS) $(GL_ROMFS_ARGS)
+
+$(GLGEN)pdfromfs1.c : $(GLGEN)pdfromfs1_$(UFST_BRIDGE).c $(LIB_MAK) $(MAKEDIRS)
+ $(CP_) $(GLGEN)pdfromfs1_$(UFST_BRIDGE).c $(GLGEN)pdfromfs1.c
+
+$(GLGEN)pdfromfs0_.c : $(MKROMFS_XE) $(LIB_MAK) $(MAKEDIRS)
+ $(EXP)$(MKROMFS_XE) -o $(GLGEN)pdfromfs0_.c \
+ -X .svn -X CVS -P $(GLSRCDIR)$(D)..$(D) iccprofiles$(D)* \
+ $(GL_ROMFS_ARGS)
+
+$(GLGEN)pdfromfs0_1.c : $(MKROMFS_XE) $(LIB_MAK) $(MAKEDIRS)
+ $(EXP)$(MKROMFS_XE) -o $(GLGEN)pdfromfs0_1.c \
+ -X .svn -X CVS -P $(GLSRCDIR)$(D)..$(D) iccprofiles$(D)* \
+ $(GL_ROMFS_ARGS)
+
+$(GLGEN)pdfromfs0.c : $(GLGEN)pdfromfs0_$(UFST_BRIDGE).c $(LIB_MAK) $(MAKEDIRS)
+ $(CP_) $(GLGEN)pdfromfs0_$(UFST_BRIDGE).c $(GLGEN)pdfromfs0.c
+
# pdl
# We generate the pdl romfs in index + 4 lumps because of size
@@ -3546,6 +3574,13 @@ $(GLOBJ)xpsromfs0.$(OBJ) : $(GLGEN)xpsromfs0.c $(stdint__h) $(LIB_MAK) $(MAKEDIR
$(GLOBJ)xpsromfs1.$(OBJ) : $(GLOBJ)xpsromfs1.c $(time__h) $(LIB_MAK) $(MAKEDIRS)
$(GLCC) $(GLO_)xpsromfs1.$(OBJ) $(C_) $(GLOBJ)xpsromfs1.c
+# A pdfromfs module with only ICC profiles for COMPILE_INITS=0
+$(GLOBJ)pdfromfs0.$(OBJ) : $(GLGEN)pdfromfs0.c $(stdint__h) $(LIB_MAK) $(MAKEDIRS)
+ $(GLCC) $(GLO_)pdfromfs0.$(OBJ) $(C_) $(GLGEN)pdfromfs0.c
+
+$(GLOBJ)pdfromfs1.$(OBJ) : $(GLOBJ)pdfromfs1.c $(time__h) $(LIB_MAK) $(MAKEDIRS)
+ $(GLCC) $(GLO_)pdfromfs1.$(OBJ) $(C_) $(GLOBJ)pdfromfs1.c
+
# A pdlromfs module with only ICC profiles for COMPILE_INITS=0
$(GLOBJ)pdlromfs0.$(OBJ) : $(GLGEN)pdlromfs0.c $(stdint__h) $(LIB_MAK) $(MAKEDIRS)
$(GLCC) $(GLO_)pdlromfs0.$(OBJ) $(C_) $(GLGEN)pdlromfs0.c
@@ -3719,6 +3754,16 @@ $(GLOBJ)gp_nxpsprn.$(OBJ) : $(GLSRC)gp_nxpsprn.c $(gp_h) $(std_h) $(LIB_MAK) \
$(AK) $(MAKEDIRS)
$(GLCC) $(GLO_)gp_nxpsprn.$(OBJ) $(C_) $(GLSRC)gp_nxpsprn.c
+# ================ Adobe Glyph List ================ #
+
+gsagl_=$(GLOBJ)gsagl.$(OBJ)
+$(GLD)gsagl.dev : $(LIB_MAK) $(ECHOGS_XE) $(gsagl_) $(LIB_MAK) $(MAKEDIRS)
+ $(SETMOD) $(GLD)gsagl $(gsagl_)
+
+$(GLOBJ)gsagl.$(OBJ) : $(GLSRC)gsagl.c $(GDEV)\
+ $(gsagl_h) $(DEVS_MAK) $(MAKEDIRS)
+ $(GLCC) $(GLO_)gsagl.$(OBJ) $(C_) $(GLSRC)gsagl.c
+
# ================ Dependencies for auxiliary programs ================ #
GENARCH_DEPS=$(stdpre_h)
@@ -5585,75 +5630,6 @@ $(GLSRC)gxdevbuf.h:$(GLSRC)std.h
$(GLSRC)gxdevbuf.h:$(GLSRC)stdpre.h
$(GLSRC)gxdevbuf.h:$(GLGEN)arch.h
$(GLSRC)gxdevbuf.h:$(GLSRC)gs_dll_call.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxdevcli.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxcmap.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxtext.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gstext.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsnamecl.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gstparam.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxfmap.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsfunc.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxcspace.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxrplane.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gscsel.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxfcache.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsfont.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsimage.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsdcolor.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxcvalue.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxbcache.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsropt.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxdda.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxpath.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxfrac.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxtmap.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxftype.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gscms.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsrect.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gslparam.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsdevice.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gscpm.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gscspace.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsgstate.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsxfont.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsdsrc.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsiparam.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxfixed.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gscompt.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsmatrix.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gspenum.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxhttile.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsparam.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsrefct.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gp.h
-$(GLSRC)gxdevrop.h:$(GLSRC)memento.h
-$(GLSRC)gxdevrop.h:$(GLSRC)memory_.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsuid.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsstruct.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxsync.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxbitmap.h
-$(GLSRC)gxdevrop.h:$(GLSRC)srdline.h
-$(GLSRC)gxdevrop.h:$(GLSRC)scommon.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsbitmap.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsccolor.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxarith.h
-$(GLSRC)gxdevrop.h:$(GLSRC)stat_.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gpsync.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsstype.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsmemory.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gpgetenv.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gscdefs.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gslibctx.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gxcindex.h
-$(GLSRC)gxdevrop.h:$(GLSRC)stdio_.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gsccode.h
-$(GLSRC)gxdevrop.h:$(GLSRC)stdint_.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gssprintf.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gstypes.h
-$(GLSRC)gxdevrop.h:$(GLSRC)std.h
-$(GLSRC)gxdevrop.h:$(GLSRC)stdpre.h
-$(GLSRC)gxdevrop.h:$(GLGEN)arch.h
-$(GLSRC)gxdevrop.h:$(GLSRC)gs_dll_call.h
$(GLSRC)gxdevmem.h:$(GLSRC)gxdevcli.h
$(GLSRC)gxdevmem.h:$(GLSRC)gxcmap.h
$(GLSRC)gxdevmem.h:$(GLSRC)gxtext.h
diff --git a/base/memento.c b/base/memento.c
index fddb17fe..56b7788b 100644
--- a/base/memento.c
+++ b/base/memento.c
@@ -1099,6 +1099,12 @@ static void Memento_addBlockTail(Memento_Blocks *blks,
}
typedef struct BlkCheckData {
+ /* found holds some bits:
+ * Bit 0 (1) -> At least one block has been checked.
+ * Bit 1 (2) -> We have found an "Allocated block".
+ * Bit 2 (4) -> We have found a "Freed block".
+ * Bit 3 (8) -> Trigger a breakpoint on completion.
+ */
int found;
int preCorrupt;
int postCorrupt;
@@ -1639,6 +1645,7 @@ void Memento_blockInfo(void *p)
#ifdef MEMENTO_DETAILS
MEMENTO_LOCK();
Memento_appBlocks(&memento.used, showBlockInfo, p);
+ Memento_appBlocks(&memento.free, showBlockInfo, p);
MEMENTO_UNLOCK();
#endif
}
@@ -1971,12 +1978,11 @@ static int Memento_containsAddr(Memento_BlkHeader *b,
return 0;
}
-void Memento_info(void *addr)
+static void Memento_infoLocked(void *addr)
{
#ifdef MEMENTO_DETAILS
findBlkData data;
- MEMENTO_LOCK();
data.addr = addr;
data.blk = NULL;
data.flags = 0;
@@ -1988,12 +1994,18 @@ void Memento_info(void *addr)
Memento_appBlocks(&memento.free, Memento_containsAddr, &data);
if (data.blk != NULL)
showInfo(data.blk, NULL);
- MEMENTO_UNLOCK();
#else
printf("Memento not compiled with details support\n");
#endif
}
+void Memento_info(void *addr)
+{
+ MEMENTO_LOCK();
+ Memento_infoLocked(addr);
+ MEMENTO_UNLOCK();
+}
+
#ifdef MEMENTO_HAS_FORK
#include <unistd.h>
#include <sys/wait.h>
@@ -2165,13 +2177,16 @@ static void Memento_startFailing(void)
static int Memento_event(void)
{
+ int ret = 0;
+
memento.sequence++;
if ((memento.sequence >= memento.paranoidAt) && (memento.paranoidAt != 0)) {
memento.paranoia = 1;
memento.countdown = 1;
}
if (--memento.countdown == 0) {
- Memento_checkAllMemoryLocked();
+ ret = Memento_checkAllMemoryLocked();
+ ret = (ret & 8) != 0;
if (memento.paranoia > 0)
memento.countdown = memento.paranoia;
else
@@ -2186,7 +2201,7 @@ static int Memento_event(void)
fprintf(stderr, "Breaking at event %d\n", memento.breakAt);
return 1;
}
- return 0;
+ return ret;
}
int Memento_sequence(void)
@@ -2499,7 +2514,7 @@ static void do_reference(Memento_BlkHeader *blk, int event)
#endif /* MEMENTO_DETAILS */
}
-int Memento_checkPointerOrNull(void *blk)
+static int checkPointerOrNullLocked(void *blk)
{
if (blk == NULL)
return 0;
@@ -2517,17 +2532,27 @@ int Memento_checkPointerOrNull(void *blk)
fprintf(stderr, "Current backtrace:\n");
Memento_bt();
fprintf(stderr, "History:\n");
- Memento_info(blk);
+ Memento_infoLocked(blk);
#endif
+ Memento_breakpointLocked();
return 1;
}
-int Memento_checkBytePointerOrNull(void *blk)
+int Memento_checkPointerOrNull(void *blk)
+{
+ int ret;
+ MEMENTO_LOCK();
+ ret = checkPointerOrNullLocked(blk);
+ MEMENTO_UNLOCK();
+ return ret;
+}
+
+static int checkBytePointerOrNullLocked(void *blk)
{
unsigned char i;
if (blk == NULL)
return 0;
- Memento_checkPointerOrNull(blk);
+ checkPointerOrNullLocked(blk);
i = *(unsigned char *)blk;
@@ -2545,18 +2570,27 @@ int Memento_checkBytePointerOrNull(void *blk)
fprintf(stderr, "Current backtrace:\n");
Memento_bt();
fprintf(stderr, "History:\n");
- Memento_info(blk);
+ Memento_infoLocked(blk);
#endif
- Memento_breakpoint();
+ Memento_breakpointLocked();
return 1;
}
-int Memento_checkShortPointerOrNull(void *blk)
+int Memento_checkBytePointerOrNull(void *blk)
+{
+ int ret;
+ MEMENTO_LOCK();
+ ret = checkBytePointerOrNullLocked(blk);
+ MEMENTO_UNLOCK();
+ return ret;
+}
+
+static int checkShortPointerOrNullLocked(void *blk)
{
unsigned short i;
if (blk == NULL)
return 0;
- Memento_checkPointerOrNull(blk);
+ checkPointerOrNullLocked(blk);
i = *(unsigned short *)blk;
@@ -2574,18 +2608,27 @@ int Memento_checkShortPointerOrNull(void *blk)
fprintf(stderr, "Current backtrace:\n");
Memento_bt();
fprintf(stderr, "History:\n");
- Memento_info(blk);
+ Memento_infoLocked(blk);
#endif
- Memento_breakpoint();
+ Memento_breakpointLocked();
return 1;
}
-int Memento_checkIntPointerOrNull(void *blk)
+int Memento_checkShortPointerOrNull(void *blk)
+{
+ int ret;
+ MEMENTO_LOCK();
+ ret = checkShortPointerOrNullLocked(blk);
+ MEMENTO_UNLOCK();
+ return ret;
+}
+
+static int checkIntPointerOrNullLocked(void *blk)
{
unsigned int i;
if (blk == NULL)
return 0;
- Memento_checkPointerOrNull(blk);
+ checkPointerOrNullLocked(blk);
i = *(unsigned int *)blk;
@@ -2603,15 +2646,29 @@ int Memento_checkIntPointerOrNull(void *blk)
fprintf(stderr, "Current backtrace:\n");
Memento_bt();
fprintf(stderr, "History:\n");
- Memento_info(blk);
+ Memento_infoLocked(blk);
#endif
- Memento_breakpoint();
+ Memento_breakpointLocked();
return 1;
}
-static void *do_takeRef(void *blk)
+int Memento_checkIntPointerOrNull(void *blk)
{
+ int ret;
MEMENTO_LOCK();
+ ret = checkIntPointerOrNullLocked(blk);
+ MEMENTO_UNLOCK();
+ return ret;
+}
+
+static void *do_takeRef(void *blk)
+{
+ do_reference(safe_find_block(blk), Memento_EventType_takeRef);
+ return blk;
+}
+
+static void *do_takeRefAndUnlock(void *blk)
+{
do_reference(safe_find_block(blk), Memento_EventType_takeRef);
MEMENTO_UNLOCK();
return blk;
@@ -2622,14 +2679,17 @@ void *Memento_takeByteRef(void *blk)
if (!memento.inited)
Memento_init();
- if (Memento_event()) Memento_breakpoint();
+ MEMENTO_LOCK();
+ if (Memento_event()) Memento_breakpointLocked();
- if (!blk)
+ if (!blk) {
+ MEMENTO_UNLOCK();
return NULL;
+ }
- (void)Memento_checkBytePointerOrNull(blk);
+ (void)checkBytePointerOrNullLocked(blk);
- return do_takeRef(blk);
+ return do_takeRefAndUnlock(blk);
}
void *Memento_takeShortRef(void *blk)
@@ -2637,14 +2697,17 @@ void *Memento_takeShortRef(void *blk)
if (!memento.inited)
Memento_init();
- if (Memento_event()) Memento_breakpoint();
+ MEMENTO_LOCK();
+ if (Memento_event()) Memento_breakpointLocked();
- if (!blk)
+ if (!blk) {
+ MEMENTO_UNLOCK();
return NULL;
+ }
- (void)Memento_checkShortPointerOrNull(blk);
+ (void)checkShortPointerOrNullLocked(blk);
- return do_takeRef(blk);
+ return do_takeRefAndUnlock(blk);
}
void *Memento_takeIntRef(void *blk)
@@ -2652,14 +2715,17 @@ void *Memento_takeIntRef(void *blk)
if (!memento.inited)
Memento_init();
- if (Memento_event()) Memento_breakpoint();
+ MEMENTO_LOCK();
+ if (Memento_event()) Memento_breakpointLocked();
- if (!blk)
+ if (!blk) {
+ MEMENTO_UNLOCK();
return NULL;
+ }
- (void)Memento_checkIntPointerOrNull(blk);
+ (void)checkIntPointerOrNullLocked(blk);
- return do_takeRef(blk);
+ return do_takeRefAndUnlock(blk);
}
void *Memento_takeRef(void *blk)
@@ -2667,17 +2733,25 @@ void *Memento_takeRef(void *blk)
if (!memento.inited)
Memento_init();
- if (Memento_event()) Memento_breakpoint();
+ MEMENTO_LOCK();
+ if (Memento_event()) Memento_breakpointLocked();
- if (!blk)
+ if (!blk) {
+ MEMENTO_UNLOCK();
return NULL;
+ }
- return do_takeRef(blk);
+ return do_takeRefAndUnlock(blk);
}
static void *do_dropRef(void *blk)
{
- MEMENTO_LOCK();
+ do_reference(safe_find_block(blk), Memento_EventType_dropRef);
+ return blk;
+}
+
+static void *do_dropRefAndUnlock(void *blk)
+{
do_reference(safe_find_block(blk), Memento_EventType_dropRef);
MEMENTO_UNLOCK();
return blk;
@@ -2688,14 +2762,17 @@ void *Memento_dropByteRef(void *blk)
if (!memento.inited)
Memento_init();
- if (Memento_event()) Memento_breakpoint();
+ MEMENTO_LOCK();
+ if (Memento_event()) Memento_breakpointLocked();
- if (!blk)
+ if (!blk) {
+ MEMENTO_UNLOCK();
return NULL;
+ }
- Memento_checkBytePointerOrNull(blk);
+ checkBytePointerOrNullLocked(blk);
- return do_dropRef(blk);
+ return do_dropRefAndUnlock(blk);
}
void *Memento_dropShortRef(void *blk)
@@ -2703,14 +2780,17 @@ void *Memento_dropShortRef(void *blk)
if (!memento.inited)
Memento_init();
- if (Memento_event()) Memento_breakpoint();
+ MEMENTO_LOCK();
+ if (Memento_event()) Memento_breakpointLocked();
- if (!blk)
+ if (!blk) {
+ MEMENTO_UNLOCK();
return NULL;
+ }
- Memento_checkShortPointerOrNull(blk);
+ checkShortPointerOrNullLocked(blk);
- return do_dropRef(blk);
+ return do_dropRefAndUnlock(blk);
}
void *Memento_dropIntRef(void *blk)
@@ -2718,14 +2798,17 @@ void *Memento_dropIntRef(void *blk)
if (!memento.inited)
Memento_init();
- if (Memento_event()) Memento_breakpoint();
+ MEMENTO_LOCK();
+ if (Memento_event()) Memento_breakpointLocked();
- if (!blk)
+ if (!blk) {
+ MEMENTO_UNLOCK();
return NULL;
+ }
- Memento_checkIntPointerOrNull(blk);
+ checkIntPointerOrNullLocked(blk);
- return do_dropRef(blk);
+ return do_dropRefAndUnlock(blk);
}
void *Memento_dropRef(void *blk)
@@ -2733,20 +2816,29 @@ void *Memento_dropRef(void *blk)
if (!memento.inited)
Memento_init();
- if (Memento_event()) Memento_breakpoint();
+ MEMENTO_LOCK();
+ if (Memento_event()) Memento_breakpointLocked();
- if (!blk)
+ if (!blk) {
+ MEMENTO_UNLOCK();
return NULL;
+ }
- return do_dropRef(blk);
+ return do_dropRefAndUnlock(blk);
}
void *Memento_adjustRef(void *blk, int adjust)
{
- if (Memento_event()) Memento_breakpoint();
+ if (!memento.inited)
+ Memento_init();
- if (blk == NULL)
+ MEMENTO_LOCK();
+ if (Memento_event()) Memento_breakpointLocked();
+
+ if (blk == NULL) {
+ MEMENTO_UNLOCK();
return NULL;
+ }
while (adjust > 0)
{
@@ -2759,6 +2851,7 @@ void *Memento_adjustRef(void *blk, int adjust)
adjust++;
}
+ MEMENTO_UNLOCK();
return blk;
}
@@ -2829,8 +2922,7 @@ static int checkBlock(Memento_BlkHeader *memblk, const char *action)
fprintf(stderr, "Attempt to %s invalid block ", action);
showBlock(memblk, 32);
fprintf(stderr, "\n");
- Memento_breakpointLocked();
- return 1;
+ return 2;
}
#ifndef MEMENTO_LEAKONLY
@@ -2842,8 +2934,7 @@ static int checkBlock(Memento_BlkHeader *memblk, const char *action)
fprintf(stderr, "Attempt to %s block ", action);
showBlock(memblk, 32);
fprintf(stderr, "\n");
- Memento_breakpointLocked();
- return 1;
+ return 2;
} else if (data.preCorrupt || data.postCorrupt) {
fprintf(stderr, "Block ");
showBlock(memblk, ' ');
@@ -2859,7 +2950,7 @@ static int checkBlock(Memento_BlkHeader *memblk, const char *action)
if ((memblk->flags & Memento_Flag_Reported) == 0)
{
memblk->flags |= Memento_Flag_Reported;
- Memento_breakpointLocked();
+ return 2;
}
return 1;
}
@@ -2870,6 +2961,7 @@ static int checkBlock(Memento_BlkHeader *memblk, const char *action)
static void do_free(void *blk, int eventType)
{
Memento_BlkHeader *memblk;
+ int ret;
(void)eventType;
@@ -2880,8 +2972,11 @@ static void do_free(void *blk, int eventType)
memblk = MEMBLK_FROMBLK(blk);
VALGRIND_MAKE_MEM_DEFINED(memblk, sizeof(*memblk));
- if (checkBlock(memblk, "free"))
+ ret = checkBlock(memblk, "free");
+ if (ret)
{
+ if (ret & 2)
+ Memento_breakpoint();
if (memento.abortOnCorruption) {
fprintf(stderr, "*** memblk corrupted, calling abort()\n");
abort();
@@ -2931,7 +3026,7 @@ static void *do_realloc(void *blk, size_t newsize, int type)
{
Memento_BlkHeader *memblk, *newmemblk;
size_t newsizemem;
- int flags;
+ int flags, ret;
if (Memento_failThisEventLocked()) {
errno = ENOMEM;
@@ -2940,7 +3035,10 @@ static void *do_realloc(void *blk, size_t newsize, int type)
memblk = MEMBLK_FROMBLK(blk);
VALGRIND_MAKE_MEM_DEFINED(memblk, sizeof(*memblk));
- if (checkBlock(memblk, "realloc")) {
+ ret = checkBlock(memblk, "realloc");
+ if (ret) {
+ if (ret == 2)
+ Memento_breakpoint();
errno = ENOMEM;
return NULL;
}
@@ -3070,7 +3168,7 @@ static int Memento_Internal_checkAllAlloced(Memento_BlkHeader *memblk, void *arg
if ((memblk->flags & Memento_Flag_Reported) == 0)
{
memblk->flags |= Memento_Flag_Reported;
- Memento_breakpointLocked();
+ data->found |= 8;
}
}
else
@@ -3115,7 +3213,7 @@ static int Memento_Internal_checkAllFreed(Memento_BlkHeader *memblk, void *arg)
if ((memblk->flags & Memento_Flag_Reported) == 0)
{
memblk->flags |= Memento_Flag_Reported;
- Memento_breakpointLocked();
+ data->found |= 8;
}
VALGRIND_MAKE_MEM_NOACCESS(memblk, sizeof(Memento_BlkHeader));
data->preCorrupt = 0;
@@ -3150,7 +3248,7 @@ int Memento_checkAllMemory(void)
MEMENTO_LOCK();
ret = Memento_checkAllMemoryLocked();
MEMENTO_UNLOCK();
- if (ret & 6) {
+ if (ret & 8) {
Memento_breakpoint();
return 1;
}
diff --git a/base/msvclib.mak b/base/msvclib.mak
index dbf49296..a9f57985 100644
--- a/base/msvclib.mak
+++ b/base/msvclib.mak
@@ -611,6 +611,31 @@ MS_TOOLSET_VERSION=14.28.29333
MSVC_VERSION=16
MS_TOOLSET_VERSION=14.28.29333
!endif
+!if "$(_NMAKE_VER)" == "14.28.29913.0"
+# VS2019 (Toolset v142)
+MSVC_VERSION=16
+MS_TOOLSET_VERSION=14.28.29333
+!endif
+!if "$(_NMAKE_VER)" == "14.28.29914.0"
+# VS2019 (Toolset v142)
+MSVC_VERSION=16
+MS_TOOLSET_VERSION=14.28.29333
+!endif
+!if "$(_NMAKE_VER)" == "14.28.29915.0"
+# VS2019 (Toolset v142)
+MSVC_VERSION=16
+MS_TOOLSET_VERSION=14.28.29333
+!endif
+!if "$(_NMAKE_VER)" == "14.29.30038.1"
+# VS2019 (Toolset v142)
+MSVC_VERSION=16
+MS_TOOLSET_VERSION=14.29.30037
+!endif
+!if "$(_NMAKE_VER)" == "14.29.30133.0"
+# VS2019 (Toolset v142)
+MSVC_VERSION=16
+MS_TOOLSET_VERSION=14.29.30133
+!endif
!endif
!ifndef MSVC_VERSION
diff --git a/base/ocr.mak b/base/ocr.mak
index 3c9e2787..6445a5ef 100644
--- a/base/ocr.mak
+++ b/base/ocr.mak
@@ -28,7 +28,7 @@ $(GLGEN)libocr.dev : $(LIBOCR_MAK) $(ECHOGS_XE)$(MAKEDIRS)\
# Tesseract veneer.
$(GLGEN)tessocr.$(OBJ) : $(GLSRC)tessocr.cpp $(GLSRC)tessocr.h $(LIBOCR_MAK) \
$(gsmemory_h) $(gxiodev_h) $(stream_h) $(TESSDEPS)
- $(TESSCXX) $(D_)LEPTONICA_INTERCEPT_MALLOC=1$(_D) $(I_)$(LEPTONICADIR)$(D)src$(_I) $(GLO_)tessocr.$(OBJ) $(C_) $(D_)TESSDATA="$(TESSDATA)"$(_D) $(GLSRC)tessocr.cpp
+ $(TESSCXX) $(D_)LEPTONICA_INTERCEPT_ALLOC=1$(_D) $(I_)$(LEPTONICADIR)$(D)src$(_I) $(GLO_)tessocr.$(OBJ) $(C_) $(D_)TESSDATA="$(TESSDATA)"$(_D) $(GLSRC)tessocr.cpp
# 0 = No version.
diff --git a/base/scfd.c b/base/scfd.c
index 1ad2b5ad..03085fbf 100644
--- a/base/scfd.c
+++ b/base/scfd.c
@@ -62,20 +62,24 @@ s_CFD_init(stream_state * st)
s_hcd_init_inline(ss);
/* Because skip_white_pixels can look as many as 4 bytes ahead, */
/* we need to allow 4 extra bytes at the end of the row buffers. */
- ss->lbuf = gs_alloc_bytes(st->memory, raster + CFD_BUFFER_SLOP, "CFD lbuf");
+ ss->lbufstart = gs_alloc_bytes(st->memory, raster + CFD_BUFFER_SLOP * 2, "CFD lbuf");
ss->lprev = 0;
- if (ss->lbuf == 0)
+ if (ss->lbufstart == 0)
return ERRC; /****** WRONG ******/
+ ss->lbuf = ss->lbufstart + CFD_BUFFER_SLOP;
+ memset(ss->lbufstart, 0xaa, CFD_BUFFER_SLOP);
memset(ss->lbuf, white, raster);
memset(ss->lbuf + raster, 0xaa, CFD_BUFFER_SLOP); /* for Valgrind */
if (ss->K != 0) {
- ss->lprev = gs_alloc_bytes(st->memory, raster + CFD_BUFFER_SLOP, "CFD lprev");
- if (ss->lprev == 0)
+ ss->lprevstart = gs_alloc_bytes(st->memory, raster + CFD_BUFFER_SLOP * 2, "CFD lprev");
+ if (ss->lprevstart == 0)
return ERRC; /****** WRONG ******/
+ ss->lprev = ss->lprevstart + CFD_BUFFER_SLOP;
/* Clear the initial reference line for 2-D encoding. */
memset(ss->lprev, white, raster);
/* Ensure that the scan of the reference line will stop. */
memset(ss->lprev + raster, 0xaa, CFD_BUFFER_SLOP);
+ memset(ss->lprevstart, 0xaa, CFD_BUFFER_SLOP);
}
ss->k_left = min(ss->K, 0);
ss->run_color = 0;
@@ -98,8 +102,8 @@ s_CFD_release(stream_state * st)
{
stream_CFD_state *const ss = (stream_CFD_state *) st;
- gs_free_object(st->memory, ss->lprev, "CFD lprev(close)");
- gs_free_object(st->memory, ss->lbuf, "CFD lbuf(close)");
+ gs_free_object(st->memory, ss->lprevstart, "CFD lprev(close)");
+ gs_free_object(st->memory, ss->lbufstart, "CFD lbuf(close)");
}
/* Declare the variables that hold the state. */
@@ -211,7 +215,7 @@ static inline int invert_data(stream_CFD_state *ss, stream_cursor_read *pr, int
cfd_load_state();
(void)rlimit;
- if (q >= ss->lbuf + ss->raster + CFD_BUFFER_SLOP) {
+ if (q >= ss->lbuf + ss->raster + CFD_BUFFER_SLOP || q < ss->lbufstart) {
return(-1);
}
@@ -300,7 +304,11 @@ s_CFD_process(stream_state * st, stream_cursor_read * pr,
#endif
- top:
+ /* Update the pointers we actually use, in case GC moved the buffer */
+ ss->lbuf = ss->lbufstart + CFD_BUFFER_SLOP;
+ ss->lprev = ss->lprevstart + CFD_BUFFER_SLOP;
+
+top:
#ifdef DEBUG
{
hcd_declare_state;
@@ -370,9 +378,12 @@ s_CFD_process(stream_state * st, stream_cursor_read * pr,
goto ck_eol; /* handle EOD if it is present */
if (ss->K != 0) {
byte *prev_bits = ss->lprev;
+ byte *prev_start = ss->lprevstart;
ss->lprev = ss->lbuf;
+ ss->lprevstart = ss->lbufstart;
ss->lbuf = prev_bits;
+ ss->lbufstart = prev_start;
if (ss->K > 0)
k_left = (k_left == 0 ? ss->K : k_left) - 1;
}
diff --git a/base/scfe.c b/base/scfe.c
index 13e56fe7..15e1a490 100644
--- a/base/scfe.c
+++ b/base/scfe.c
@@ -150,21 +150,23 @@ s_CFE_init(register stream_state * st)
/****** WRONG ******/
/* Because skip_white_pixels can look as many as 4 bytes ahead, */
/* we need to allow 4 extra bytes at the end of the row buffers. */
- ss->lbuf = gs_alloc_bytes(st->memory, raster + 4, "CFE lbuf");
+ ss->lbufstart = gs_alloc_bytes(st->memory, raster + 8, "CFE lbuf");
ss->lcode = gs_alloc_bytes(st->memory, code_bytes, "CFE lcode");
- if (ss->lbuf == 0 || ss->lcode == 0) {
+ if (ss->lbufstart == 0 || ss->lcode == 0) {
s_CFE_release(st);
return ERRC;
/****** WRONG ******/
}
+ ss->lbuf = ss->lbufstart + 4;
memset(ss->lbuf + raster, 0, 4); /* to pacify Valgrind */
if (ss->K != 0) {
- ss->lprev = gs_alloc_bytes(st->memory, raster + 4, "CFE lprev");
- if (ss->lprev == 0) {
+ ss->lprevstart = gs_alloc_bytes(st->memory, raster + 8, "CFE lprev");
+ if (ss->lprevstart == 0) {
s_CFE_release(st);
return ERRC;
/****** WRONG ******/
}
+ ss->lprev = ss->lprevstart + 4;
/* Clear the initial reference line for 2-D encoding. */
/* Make sure it is terminated properly. */
memset(ss->lprev, (ss->BlackIs1 ? 0 : 0xff), raster + 4); /* +4 to pacify Valgrind */
@@ -186,9 +188,9 @@ s_CFE_release(stream_state * st)
{
stream_CFE_state *const ss = (stream_CFE_state *) st;
- gs_free_object(st->memory, ss->lprev, "CFE lprev(close)");
+ gs_free_object(st->memory, ss->lprevstart, "CFE lprev(close)");
gs_free_object(st->memory, ss->lcode, "CFE lcode(close)");
- gs_free_object(st->memory, ss->lbuf, "CFE lbuf(close)");
+ gs_free_object(st->memory, ss->lbufstart, "CFE lbuf(close)");
}
/* Flush the buffer */
@@ -207,6 +209,10 @@ s_CFE_process(stream_state * st, stream_cursor_read * pr,
byte end_mask = 1 << (-ss->Columns & 7);
int status = 0;
+ /* Update the pointers we actually use, in case GC moved the buffer */
+ ss->lbuf = ss->lbufstart + 4;
+ ss->lprev = ss->lprevstart + 4;
+
for (;;) {
stream_cursor_write w;
@@ -326,9 +332,12 @@ s_CFE_process(stream_state * st, stream_cursor_read * pr,
if (ss->K != 0) {
/* In 2-D modes, swap the current and previous scan lines. */
byte *temp = ss->lbuf;
+ byte *temp1 = ss->lbufstart;
ss->lbuf = ss->lprev;
+ ss->lbufstart = ss->lprevstart;
ss->lprev = temp;
+ ss->lprevstart = temp1;
}
/* Note that the input buffer needs refilling. */
ss->read_count = raster;
@@ -382,7 +391,8 @@ s_CFE_process(stream_state * st, stream_cursor_read * pr,
/* Encode a 1-D scan line. */
/* Attempt to stop coverity thinking skip_white_pixels() taints lbuf:*/
-/* coverity[ -tainted_data_argument : arg-1 ] */
+/* coverity[ -tainted_data_return ] */
+/* coverity[ -tainted_data_argument arg-2 ] */
static void
cf_encode_1d(stream_CFE_state * ss, const byte * lbuf, stream_cursor_write * pw)
{
diff --git a/base/scfparam.c b/base/scfparam.c
index d95ae98d..9f77603b 100644
--- a/base/scfparam.c
+++ b/base/scfparam.c
@@ -73,7 +73,7 @@ s_CF_put_params(gs_param_list * plist, stream_CF_state * ss)
int code;
state = *ss;
- code = gs_param_read_items(plist, (void *)&state, s_CF_param_items);
+ code = gs_param_read_items(plist, (void *)&state, s_CF_param_items, NULL);
if (code >= 0 &&
(state.K < -cf_max_height || state.K > cf_max_height ||
state.Columns < 0 || state.Columns > cfe_max_width ||
diff --git a/base/scfx.h b/base/scfx.h
index a9e1e741..197d549b 100644
--- a/base/scfx.h
+++ b/base/scfx.h
@@ -40,9 +40,11 @@
int DecodedByteAlign;\
/* The init procedure sets the following. */\
uint raster;\
+ byte *lbufstart; /* current line buffer, including pre-buffer slop to prevent underruns */\
byte *lbuf; /* current scan line buffer */\
/* (only if decoding or 2-D encoding) */\
byte *lprev; /* previous scan line buffer (only if 2-D) */\
+ byte *lprevstart; /* current line buffer, including pre-buffer slop to prevent underruns */\
/* The following are updated dynamically. */\
int k_left /* number of next rows to encode in 2-D */\
/* (only if K > 0) */
@@ -67,7 +69,7 @@ typedef struct stream_CF_state_s {
(ss)->DecodedByteAlign = 1,\
(ss)->ErrsAsEOD = false,\
/* Clear pointers */\
- (ss)->lbuf = 0, (ss)->lprev = 0,\
+ (ss)->lbuf = (ss)->lbufstart = 0, (ss)->lprev = (ss)->lprevstart = 0,\
/* Clear errors */\
(ss)->error_string[0] = 0)
@@ -85,7 +87,7 @@ typedef struct stream_CFE_state_s {
#define private_st_CFE_state() /* in scfe.c */\
gs_private_st_ptrs3(st_CFE_state, stream_CFE_state, "CCITTFaxEncode state",\
- cfe_enum_ptrs, cfe_reloc_ptrs, lbuf, lprev, lcode)
+ cfe_enum_ptrs, cfe_reloc_ptrs, lbufstart, lprevstart, lcode)
#define s_CFE_set_defaults_inline(ss)\
(s_CF_set_defaults_inline(ss), (ss)->lcode = 0)
extern const stream_template s_CFE_template;
@@ -121,7 +123,7 @@ typedef struct stream_CFD_state_s {
#define private_st_CFD_state() /* in scfd.c */\
gs_private_st_ptrs2(st_CFD_state, stream_CFD_state, "CCITTFaxDecode state",\
- cfd_enum_ptrs, cfd_reloc_ptrs, lbuf, lprev)
+ cfd_enum_ptrs, cfd_reloc_ptrs, lbufstart, lprevstart)
#define s_CFD_set_defaults_inline(ss)\
s_CF_set_defaults_inline(ss)
extern const stream_template s_CFD_template;
diff --git a/base/scommon.h b/base/scommon.h
index d8bdda8c..542b960c 100644
--- a/base/scommon.h
+++ b/base/scommon.h
@@ -115,35 +115,28 @@ typedef union stream_cursor_s {
* This allows localized disabling of the "array bounds" compiler
* warning for this one specific case.
*/
-static inline void
-stream_cursor_read_init(stream_cursor_read *r, const byte *buf, size_t length)
-{
#ifdef __GNUC__
# pragma GCC diagnostic push
# pragma GCC diagnostic ignored "-Warray-bounds"
#endif
+static inline void
+stream_cursor_read_init(stream_cursor_read *r, const byte *buf, size_t length)
+{
/* starting pos for pointer is always one position back */
r->ptr = buf - 1;
r->limit = r->ptr + length;
-#ifdef __GNUC__
-# pragma GCC diagnostic pop
-#endif
}
static inline void
stream_cursor_write_init(stream_cursor_write *w, const byte *buf, size_t length)
{
-#ifdef __GNUC__
-# pragma GCC diagnostic push
-# pragma GCC diagnostic ignored "-Warray-bounds"
-#endif
/* starting pos for pointer is always one position back */
w->ptr = (byte *)buf - 1;
w->limit = (byte *)w->ptr + length;
+}
#ifdef __GNUC__
# pragma GCC diagnostic pop
#endif
-}
/*
* Define the prototype for the procedures known to both the generic
diff --git a/base/sdcparam.c b/base/sdcparam.c
index 18f663e4..74b8052b 100644
--- a/base/sdcparam.c
+++ b/base/sdcparam.c
@@ -434,11 +434,11 @@ int
s_DCT_put_params(gs_param_list * plist, stream_DCT_state * pdct)
{
int code =
- gs_param_read_items(plist, pdct, s_DCT_param_items);
+ gs_param_read_items(plist, pdct, s_DCT_param_items, NULL);
if (code < 0)
return code;
- code = gs_param_read_items(plist, pdct->data.common, jsd_param_items);
+ code = gs_param_read_items(plist, pdct->data.common, jsd_param_items, NULL);
if (code < 0)
return code;
if (pdct->data.common->Picky < 0 || pdct->data.common->Picky > 1 ||
diff --git a/base/sdeparam.c b/base/sdeparam.c
index 8eaf44cd..b9b33094 100644
--- a/base/sdeparam.c
+++ b/base/sdeparam.c
@@ -196,7 +196,7 @@ s_DCTE_put_params(gs_param_list * plist, stream_DCT_state * pdct)
* Required parameters for DCTEncode.
* (DCTDecode gets the equivalent info from the SOF marker.)
*/
- code = gs_param_read_items(plist, &params, s_DCTE_param_items);
+ code = gs_param_read_items(plist, &params, s_DCTE_param_items, NULL);
if (code < 0)
return code;
if (params.Columns <= 0 || params.Columns > 0xffff ||
@@ -277,6 +277,8 @@ s_DCTE_put_params(gs_param_list * plist, stream_DCT_state * pdct)
break;
}
/* Optional encoding-only parameters */
+ /* FIXME: This relies on the 'Markers' value in the param list
+ * being persistent enough. */
pdct->Markers.data = params.Markers.data;
pdct->Markers.size = params.Markers.size;
pdct->NoMarker = params.NoMarker;
diff --git a/base/sjpx_openjpeg.c b/base/sjpx_openjpeg.c
index bac505dd..deaccd80 100644
--- a/base/sjpx_openjpeg.c
+++ b/base/sjpx_openjpeg.c
@@ -236,7 +236,10 @@ static void sjpx_info_callback(const char *msg, void *ptr)
static void sjpx_warning_callback(const char *msg, void *ptr)
{
+#ifdef DEBUG
+ /* prevent too many messages during normal build */
dlprintf1("openjpeg warning: %s", msg);
+#endif
}
/* initialize the stream */
@@ -698,6 +701,14 @@ s_opjd_process(stream_state * ss, stream_cursor_read * pr,
if (in_size > 0)
{
+ if (state->PassThrough && state->PassThroughfn) {
+ if (state->PassThrough && state->PassThroughfn && !state->StartedPassThrough) {
+ state->StartedPassThrough = 1;
+ (state->PassThroughfn)(state->device, NULL, 1);
+ }
+ (state->PassThroughfn)(state->device, (byte *)pr->ptr + 1, (byte *)pr->limit - (byte *)pr->ptr);
+ }
+
/* buffer available data */
code = opj_lock(ss->memory);
if (code < 0) return code;
@@ -773,6 +784,10 @@ s_opjd_set_defaults(stream_state * ss) {
state->alpha = false;
state->colorspace = gs_jpx_cs_rgb;
+ state->StartedPassThrough = 0;
+ state->PassThrough = 0;
+ state->PassThroughfn = NULL;
+ state->device = (void *)NULL;
}
/* stream release.
@@ -783,6 +798,10 @@ s_opjd_release(stream_state *ss)
{
stream_jpxd_state *const state = (stream_jpxd_state *) ss;
+ if (state->PassThrough && state->PassThroughfn && state->StartedPassThrough) {
+ state->StartedPassThrough = 0;
+ (state->PassThroughfn)(state->device, NULL, 0);
+ }
/* empty stream or failed to accumulate */
if (state->codec == NULL)
return;
diff --git a/base/sjpx_openjpeg.h b/base/sjpx_openjpeg.h
index 0ee57b64..aa8ddee7 100644
--- a/base/sjpx_openjpeg.h
+++ b/base/sjpx_openjpeg.h
@@ -41,6 +41,9 @@ typedef struct stream_block_s
unsigned long fill;
} stream_block;
+#define JPXD_PassThrough(proc)\
+ int proc(void *d, byte *Buffer, int Size)
+
/* Stream state for the jpx codec using openjpeg
* We rely on our finalization call to free the
* associated handle and pointers.
@@ -68,6 +71,14 @@ typedef struct stream_jpxd_state_s
int *sign_comps; /* compensate for signed data (signed => unsigned) */
unsigned char *row_data;
+
+ int PassThrough; /* 0 or 1 */
+ bool StartedPassThrough; /* Don't signal multiple starts for the same decode */
+ JPXD_PassThrough((*PassThroughfn)); /* We don't want the stream code or
+ * JPEG code to have to handle devices
+ * so we use a function at the interpreter level
+ */
+ void *device; /* The device we need to send PassThrough data to */
} stream_jpxd_state;
extern const stream_template s_jpxd_template;
diff --git a/base/spngp.c b/base/spngp.c
index 90fe7be8..1180c148 100644
--- a/base/spngp.c
+++ b/base/spngp.c
@@ -76,6 +76,9 @@ s_pngp_init(stream_state * st, bool need_prev)
if (ss->Colors > s_PNG_max_Colors)
return ERRC; /* Too many colorants */
+ if (bits_per_row < 1)
+ return ERRC;
+
ss->bpp = (bits_per_pixel + 7) >> 3;
if (need_prev) {
prev_row = gs_alloc_bytes(st->memory, ss->bpp + ss->row_count,
diff --git a/base/stdint_.h b/base/stdint_.h
index fd425b44..555ec4a6 100644
--- a/base/stdint_.h
+++ b/base/stdint_.h
@@ -33,7 +33,7 @@
* but don't use the autoconf detection
*/
#ifndef HAVE_STDINT_H
-# ifdef __MACOS__
+# if defined(__MACOS__) || (defined(__APPLE__) && defined(__MACH__))
# define HAVE_STDINT_H
# endif
#endif
diff --git a/base/stream.c b/base/stream.c
index 2073a12a..6f68d7c2 100644
--- a/base/stream.c
+++ b/base/stream.c
@@ -112,6 +112,7 @@ s_init(stream *s, gs_memory_t * mem)
s->file_name.size = 0;
s->close_strm = false; /* default */
s->close_at_eod = true; /* default */
+ s->cbuf_string_memory = NULL;
}
stream *
s_alloc(gs_memory_t * mem, client_name_t cname)
@@ -125,6 +126,18 @@ s_alloc(gs_memory_t * mem, client_name_t cname)
s_init(s, mem);
return s;
}
+stream *
+s_alloc_immovable(gs_memory_t * mem, client_name_t cname)
+{
+ stream *s = gs_alloc_struct_immovable(mem, stream, &st_stream, cname);
+
+ if_debug2m('s', mem, "[s]alloc(%s) = "PRI_INTPTR"\n",
+ client_name_string(cname), (intptr_t) s);
+ if (s == 0)
+ return 0;
+ s_init(s, mem);
+ return s;
+}
/* Allocate a stream state and initialize it minimally. */
void
@@ -179,6 +192,7 @@ s_std_init(register stream * s, byte * ptr, uint len, const stream_procs * pp,
s->file = 0;
s->file_name.data = 0; /* in case stream is on stack */
s->file_name.size = 0;
+ s->cbuf_string_memory = NULL;
if (s->memory) {
if_debug4m('s', s->memory, "[s]init "PRI_INTPTR", buf="PRI_INTPTR", len=%u, modes=%d\n",
(intptr_t) s, (intptr_t) ptr, len, modes);
@@ -1016,6 +1030,10 @@ static int
stream_cursor_write *, bool);
/* Initialize a stream for reading a string. */
+/* String ownership retained by the caller, for example
+ Postscript string objects owned by the Postscript
+ interpreter
+ */
void
sread_string(register stream *s, const byte *ptr, uint len)
{
@@ -1027,9 +1045,31 @@ sread_string(register stream *s, const byte *ptr, uint len)
s_std_init(s, (byte *)ptr, len, &p, s_mode_read + s_mode_seek);
s->cbuf_string.data = (byte *)ptr;
s->cbuf_string.size = len;
+ s->cbuf_string_memory = NULL;
+ s->end_status = EOFC;
+ s->cursor.r.limit = s->cursor.w.limit;
+}
+
+/* The string ownership is transferred from caller to stream.
+ string_mem pointer must be allocator used to allocate the
+ "string" buffer.
+ */
+void
+sread_transient_string(register stream *s, gs_memory_t *string_mem, const byte *ptr, uint len)
+{
+ static const stream_procs p = {
+ s_string_available, s_string_read_seek, s_std_read_reset,
+ s_std_read_flush, s_std_null, s_string_read_process
+ };
+
+ s_std_init(s, (byte *)ptr, len, &p, s_mode_read + s_mode_seek);
+ s->cbuf_string.data = (byte *)ptr;
+ s->cbuf_string.size = len;
+ s->cbuf_string_memory = string_mem;
s->end_status = EOFC;
s->cursor.r.limit = s->cursor.w.limit;
}
+
/* Initialize a reusable stream for reading a string. */
static void
s_string_reusable_reset(stream *s)
@@ -1043,6 +1083,11 @@ s_string_reusable_flush(stream *s)
s->cursor.r.ptr = s->cursor.r.limit = s->cbuf + s->bsize - 1; /* just set to the end */
return 0;
}
+
+/* String ownership retained by the caller, for example
+ Postscript string objects owned by the Postscript
+ interpreter
+ */
void
sread_string_reusable(stream *s, const byte *ptr, uint len)
{
@@ -1060,6 +1105,27 @@ sread_string_reusable(stream *s, const byte *ptr, uint len)
s->close_at_eod = false;
}
+/* The string ownership is transferred from caller to stream.
+ string_mem pointer must be allocator used to allocate the
+ "string" buffer.
+ */
+void
+sread_transient_string_reusable(stream *s, gs_memory_t *string_mem, const byte *ptr, uint len)
+{
+ /*
+ * Note that s->procs.close is s_close_disable, to parallel
+ * file_close_disable.
+ */
+ static const stream_procs p = {
+ s_string_available, s_string_read_seek, s_string_reusable_reset,
+ s_string_reusable_flush, s_close_disable, s_string_read_process
+ };
+
+ sread_transient_string(s, string_mem, ptr, len);
+ s->procs = p;
+ s->close_at_eod = false;
+}
+
/* Return the number of available bytes when reading from a string. */
static int
s_string_available(stream *s, gs_offset_t *pl)
@@ -1231,15 +1297,23 @@ s_close_filters(stream **ps, stream *target)
while (*ps != target) {
stream *s = *ps;
gs_memory_t *mem = s->state->memory;
+ gs_memory_t *cbuf_string_memory = s->cbuf_string_memory;
byte *sbuf = s->cbuf;
+ byte *cbuf = s->cbuf_string.data;
stream *next = s->strm;
int status = sclose(s);
stream_state *ss = s->state; /* sclose may set this to s */
if (status < 0)
return status;
+
+ if (s->cbuf_string_memory != NULL) { /* stream owns string buffer, so free it */
+ gs_free_object(cbuf_string_memory, cbuf, "s_close_filters(cbuf)");
+ }
+
if (mem) {
- gs_free_object(mem, sbuf, "s_close_filters(buf)");
+ if (sbuf != cbuf)
+ gs_free_object(mem, sbuf, "s_close_filters(buf)");
gs_free_object(mem, s, "s_close_filters(stream)");
if (ss != (stream_state *)s)
gs_free_object(mem, ss, "s_close_filters(state)");
diff --git a/base/stream.h b/base/stream.h
index 04ef117d..ff6366dd 100644
--- a/base/stream.h
+++ b/base/stream.h
@@ -141,6 +141,7 @@ struct stream_s {
#define s_can_seek(s) (((s)->modes & s_mode_seek) != 0)
gs_string cbuf_string; /* cbuf/cbsize if cbuf is a string, */
/* 0/? if not */
+ gs_memory_t *cbuf_string_memory; /* If != NULL, stream owns the string buffer */
gs_offset_t position; /* file position of beginning of */
/* buffer */
stream_procs procs;
@@ -326,6 +327,7 @@ int spseek(stream *, gs_offset_t);
/* Allocate a stream or a stream state. */
stream *s_alloc(gs_memory_t *, client_name_t);
stream_state *s_alloc_state(gs_memory_t *, gs_memory_type_ptr_t, client_name_t);
+stream *s_alloc_immovable(gs_memory_t *, client_name_t);
/*
* Initialize a separately allocated stream or stream state, as if allocated
* by s_alloc[_state].
@@ -372,9 +374,23 @@ int file_close_finish(stream *);
int file_close_disable(stream *);
/* Create a stream on a string or a file. */
-void sread_string(stream *, const byte *, uint),
- sread_string_reusable(stream *, const byte *, uint),
- swrite_string(stream *, byte *, uint);
+/* String ownership retained by the caller, for example
+ Postscript string objects owned by the Postscript
+ interpreter
+ */
+void sread_string(stream *, const byte *, uint);
+void sread_string_reusable(stream *, const byte *, uint);
+
+/* The string ownership is transferred from caller to stream.
+ string_mem pointer must be allocator used to allocate the
+ "string" buffer.
+ */
+void
+sread_transient_string(stream *s, gs_memory_t *string_mem, const byte *ptr, uint len);
+void
+sread_transient_string_reusable(stream *s, gs_memory_t *string_mem, const byte *ptr, uint len);
+
+void swrite_string(stream *, byte *, uint);
void sread_file(stream *, gp_file *, byte *, uint),
swrite_file(stream *, gp_file *, byte *, uint);
int sappend_file(stream *, gp_file *, byte *, uint);
diff --git a/base/tesseract.mak b/base/tesseract.mak
index 9971c87b..048a7d70 100644
--- a/base/tesseract.mak
+++ b/base/tesseract.mak
@@ -1,5 +1,4 @@
TESSINCLUDES=\
- $(I_)$(TESSERACTDIR)$(_I)\
$(I_)$(TESSERACTDIR)/include$(_I)\
$(I_)$(TESSERACTDIR)/src/api$(_I)\
$(I_)$(TESSERACTDIR)/src/arch$(_I)\
@@ -24,7 +23,11 @@ TESSINCLUDES=\
# add -DDISABLED_LEGACY_ENGINE to TESSCXX
# empty TESSERACT_LEGACY
-TESSCXX = $(CXX) $(TESSINCLUDES) $(TESSCXXFLAGS) $(CCFLAGS) -DTESSERACT_IMAGEDATA_AS_PIX -DTESSERACT_DISABLE_DEBUG_FONTS -DGRAPHICS_DISABLED
+# We set -DCLUSTER when doing builds for our testing cluster. Unfortunately,
+# this conflicts with Tesseract's use of a CLUSTER type. We work around this
+# here by undefining CLUSTER for the tesseract portion of the build.
+
+TESSCXX = $(CXX) $(TESSINCLUDES) $(TESSCXXFLAGS) $(CCFLAGS) -DTESSERACT_IMAGEDATA_AS_PIX -DTESSERACT_DISABLE_DEBUG_FONTS -DGRAPHICS_DISABLED -UCLUSTER
#-DDISABLED_LEGACY_ENGINE
TESSOBJ = $(GLOBJDIR)$(D)tesseract_
TESSO_ = $(O_)$(TESSOBJ)
diff --git a/base/tessocr.cpp b/base/tessocr.cpp
index fec5979d..9aba76ab 100644
--- a/base/tessocr.cpp
+++ b/base/tessocr.cpp
@@ -1,3 +1,46 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* This file is the veneer between GS and Leptonica/Tesseract.
+ *
+ * Leptonica's memory handling is intercepted via
+ * leptonica_{malloc,free,calloc,realloc} (though the last of these
+ * is not used) and forwarded to the GS memory handlers. Leptonica
+ * only makes calls when we're calling it, hence we use a leptonica_mem
+ * global to store the current memory pointer in. This will clearly not
+ * play nicely with multi-threaded use of Ghostscript, but that seems
+ * unlikely with OCR.
+ *
+ * Tesseract is trickier. For a start it uses new/delete/new[]/delete[]
+ * rather than malloc free. That's OK, cos we can intercept this - see
+ * the #ifdef TESSERACT_CUSTOM_ALLOCATOR section at the end of this file
+ * for how.
+ *
+ * The larger problem is that on startup, there is lots of 'static init'
+ * done in tesseract, which involves the system calling new. That happens
+ * before we have even entered main, so it's impossible to use any other
+ * allocator other than malloc.
+ *
+ * For now, we'll live with this; I believe that most of the 'bulk'
+ * allocations (pixmaps etc) are done via Leptonica. If we have an integrator
+ * that really needs to avoid malloc/free, then the section of code enclosed
+ * in #ifdef TESSERACT_CUSTOM_ALLOCATOR at the end of this file can be used,
+ * and tesseract_malloc/tesseract_free can be changed as required.
+ */
+
+
#include "tesseract/baseapi.h"
extern "C"
@@ -36,43 +79,44 @@ typedef struct
} wrapped_api;
-void *leptonica_malloc(size_t blocksize)
+static gs_memory_t *leptonica_mem;
+
+void *leptonica_malloc(size_t size)
{
- void *ret = malloc(blocksize);
+ void *ret = gs_alloc_bytes(leptonica_mem, size, "leptonica_malloc");
#ifdef DEBUG_ALLOCS
- printf("%d LEPTONICA_MALLOC %d -> %p\n", event++, (int)blocksize, ret);
+ printf("%d LEPTONICA_MALLOC(%p) %d -> %p\n", event++, leptonica_mem, (int)size, ret);
fflush(stdout);
#endif
return ret;
}
-void *leptonica_calloc(size_t numelm, size_t elemsize)
+void leptonica_free(void *ptr)
{
- void *ret = calloc(numelm, elemsize);
#ifdef DEBUG_ALLOCS
- printf("%d LEPTONICA_CALLOC %d,%d -> %p\n", event++, (int)numelm, (int)elemsize, ret);
+ printf("%d LEPTONICA_FREE(%p) %p\n", event++, leptonica_mem, ptr);
fflush(stdout);
#endif
- return ret;
+ gs_free_object(leptonica_mem, ptr, "leptonica_free");
}
-void *leptonica_realloc(void *ptr, size_t blocksize)
+void *leptonica_calloc(size_t numelm, size_t elemsize)
{
- void *ret = realloc(ptr, blocksize);
+ void *ret = leptonica_malloc(numelm * elemsize);
+
+ if (ret)
+ memset(ret, 0, numelm * elemsize);
#ifdef DEBUG_ALLOCS
- printf("%d LEPTONICA_REALLOC %p,%d -> %p\n", event++, ptr, (int)blocksize, ret);
+ printf("%d LEPTONICA_CALLOC %d,%d -> %p\n", event++, (int)numelm, (int)elemsize, ret);
fflush(stdout);
#endif
return ret;
}
-void leptonica_free(void *ptr)
+void *leptonica_realloc(void *ptr, size_t blocksize)
{
-#ifdef DEBUG_ALLOCS
- printf("%d LEPTONICA_FREE %p\n", event++, ptr);
- fflush(stdout);
-#endif
- free(ptr);
+ /* Never called in our usage. */
+ return NULL;
}
/* Convert from gs format bitmaps to leptonica format bitmaps. */
@@ -98,27 +142,6 @@ static int convert2pix(l_uint32 *data, int w, int h, int raster)
return w + extra*4;
}
-static gs_memory_t *leptonica_mem;
-
-static void *my_leptonica_malloc(size_t size)
-{
- void *ret = gs_alloc_bytes(leptonica_mem, size, "leptonica_malloc");
-#ifdef DEBUG_ALLOCS
- printf("%d MY_LEPTONICA_MALLOC(%p) %d -> %p\n", event++, leptonica_mem, (int)size, ret);
- fflush(stdout);
-#endif
- return ret;
-}
-
-static void my_leptonica_free(void *ptr)
-{
-#ifdef DEBUG_ALLOCS
- printf("%d MY_LEPTONICA_FREE(%p) %p\n", event++, leptonica_mem, ptr);
- fflush(stdout);
-#endif
- gs_free_object(leptonica_mem, ptr, "leptonica_free");
-}
-
static bool
load_file(const char* filename, std::vector<char>* data) {
bool result = false;
@@ -276,7 +299,7 @@ ocr_init_api(gs_memory_t *mem, const char *language, int engine, void **state)
return gs_error_VMerror;
leptonica_mem = mem;
- setPixMemoryManager(my_leptonica_malloc, my_leptonica_free);
+ setPixMemoryManager(leptonica_malloc, leptonica_free);
wrapped->mem = mem;
wrapped->api = new tesseract::TessBaseAPI();
@@ -669,25 +692,54 @@ int ocr_bitmap_to_unicodes(void *state,
};
+/* The following code is disabled by default. If enabled, nothing
+ * should change, except integrators can tweak tesseract_malloc
+ * and tesseract_free as required to avoid calling the normal
+ * system malloc/free. */
+#ifdef TESSERACT_CUSTOM_ALLOCATOR
+
+static void *tesseract_malloc(size_t blocksize)
+{
+ void *ret;
+
+ ret = malloc(blocksize);
+#ifdef DEBUG_ALLOCS
+ printf("%d LEPTONICA_MALLOC %d -> %p\n", event++, (int)blocksize, ret);
+ fflush(stdout);
+#endif
+ return ret;
+}
+
+static void tesseract_free(void *ptr)
+{
+#ifdef DEBUG_ALLOCS
+ printf("%d LEPTONICA_FREE %p\n", event++, ptr);
+ fflush(stdout);
+#endif
+ free(ptr);
+}
+
/* Currently tesseract is the only C++ lib we have.
* We may need to revisit this if this changes.
*/
void *operator new(size_t size)
{
- return leptonica_malloc(size);
+ return tesseract_malloc(size);
}
void operator_delete(void *ptr)
{
- leptonica_free(ptr);
+ tesseract_free(ptr);
}
void *operator new[](size_t size)
{
- return leptonica_malloc(size);
+ return tesseract_malloc(size);
}
void operator delete[](void *ptr)
{
- leptonica_free(ptr);
+ tesseract_free(ptr);
}
+
+#endif
diff --git a/base/unix-dll.mak b/base/unix-dll.mak
index cae247ff..e83390c2 100644
--- a/base/unix-dll.mak
+++ b/base/unix-dll.mak
@@ -47,6 +47,10 @@ XPSSOC_XENAME=$(XPS_SO_BASE)c$(XE)
XPSSOC_XE=$(BINDIR)/$(XPSSOC_XENAME)
XPSSOC=$(BINDIR)/$(XPSSOC_XENAME)
+PDFSOC_XENAME=$(PDF_SO_BASE)c$(XE)
+PDFSOC_XE=$(BINDIR)/$(PDFSOC_XENAME)
+PDFSOC=$(BINDIR)/$(PDFSOC_XENAME)
+
GPDLSOC_XENAME=$(GPDL_SO_BASE)c$(XE)
GPDLSOC_XE=$(BINDIR)/$(GPDLSOC_XENAME)
GPDLSOC=$(BINDIR)/$(GPDLSOC_XENAME)
@@ -60,6 +64,7 @@ GSSOX=$(BINDIR)/$(GSSOX_XENAME)
GS_SONAME_BASE=lib$(GS_SO_BASE)
PCL_SONAME_BASE=lib$(PCL_SO_BASE)
XPS_SONAME_BASE=lib$(XPS_SO_BASE)
+PDF_SONAME_BASE=lib$(PDF_SO_BASE)
GPDL_SONAME_BASE=lib$(GPDL_SO_BASE)
# GNU/Linux
@@ -78,6 +83,10 @@ GS_DLLEXT=$(DLL_EXT)
#XPS_SONAME_MAJOR=$(XPS_SONAME_BASE)$(GS_SOEXT)$(SO_LIB_VERSION_SEPARATOR)$(GS_VERSION_MAJOR)$(GS_DLLEXT)
#XPS_SONAME_MAJOR_MINOR=$(XPS_SONAME_BASE)$(GS_SOEXT)$(SO_LIB_VERSION_SEPARATOR)$(GS_VERSION_MAJOR)$(SO_LIB_VERSION_SEPARATOR)$(GS_VERSION_MINOR)$(GS_DLLEXT)
+#PDF_SONAME=$(PDF_SONAME_BASE)$(GS_SOEXT)$(GS_DLLEXT)
+#PDF_SONAME_MAJOR=$(PDF_SONAME_BASE)$(GS_SOEXT)$(SO_LIB_VERSION_SEPARATOR)$(GS_VERSION_MAJOR)$(GS_DLLEXT)
+#PDF_SONAME_MAJOR_MINOR=$(PDF_SONAME_BASE)$(GS_SOEXT)$(SO_LIB_VERSION_SEPARATOR)$(GS_VERSION_MAJOR)$(SO_LIB_VERSION_SEPARATOR)$(GS_VERSION_MINOR)$(GS_DLLEXT)
+
#GPDL_SONAME=$(GPDL_SONAME_BASE)$(GS_SOEXT)$(GS_DLLEXT)
#GPDL_SONAME_MAJOR=$(GPDL_SONAME_BASE)$(GS_SOEXT)$(SO_LIB_VERSION_SEPARATOR)$(GS_VERSION_MAJOR)$(GS_DLLEXT)
#GPDL_SONAME_MAJOR_MINOR=$(GPDL_SONAME_BASE)$(GS_SOEXT)$(SO_LIB_VERSION_SEPARATOR)$(GS_VERSION_MAJOR)$(SO_LIB_VERSION_SEPARATOR)$(GS_VERSION_MINOR)$(GS_DLLEXT)
@@ -111,6 +120,10 @@ XPS_SO=$(BINDIR)/$(XPS_SONAME)
XPS_SO_MAJOR=$(BINDIR)/$(XPS_SONAME_MAJOR)
XPS_SO_MAJOR_MINOR=$(BINDIR)/$(XPS_SONAME_MAJOR_MINOR)
+PDF_SO=$(BINDIR)/$(PDF_SONAME)
+PDF_SO_MAJOR=$(BINDIR)/$(PDF_SONAME_MAJOR)
+PDF_SO_MAJOR_MINOR=$(BINDIR)/$(PDF_SONAME_MAJOR_MINOR)
+
GPDL_SO=$(BINDIR)/$(GPDL_SONAME)
GPDL_SO_MAJOR=$(BINDIR)/$(GPDL_SONAME_MAJOR)
GPDL_SO_MAJOR_MINOR=$(BINDIR)/$(GPDL_SONAME_MAJOR_MINOR)
@@ -143,6 +156,14 @@ $(XPS_SO_MAJOR): $(XPS_SO_MAJOR_MINOR) $(UNIX_DLL_MAK) $(MAKEDIRS)
$(RM_) $(XPS_SO_MAJOR)
ln -s $(XPS_SONAME_MAJOR_MINOR) $(XPS_SO_MAJOR)
+$(PDF_SO): $(PDF_SO_MAJOR) $(UNIX_DLL_MAK) $(MAKEDIRS)
+ $(RM_) $(PDF_SO)
+ ln -s $(PDF_SONAME_MAJOR_MINOR) $(PDF_SO)
+
+$(PDF_SO_MAJOR): $(PDF_SO_MAJOR_MINOR) $(UNIX_DLL_MAK) $(MAKEDIRS)
+ $(RM_) $(PDF_SO_MAJOR)
+ ln -s $(PDF_SONAME_MAJOR_MINOR) $(PDF_SO_MAJOR)
+
$(GPDL_SO): $(GPDL_SO_MAJOR) $(UNIX_DLL_MAK) $(MAKEDIRS)
$(RM_) $(GPDL_SO)
ln -s $(GPDL_SONAME_MAJOR_MINOR) $(GPDL_SO)
@@ -161,6 +182,9 @@ gpcl6-so-links-subtarget: $(PCL_SO) $(UNIX_DLL_MAK) $(MAKEDIRS)
gxps-so-links-subtarget: $(XPS_SO) $(UNIX_DLL_MAK) $(MAKEDIRS)
$(NO_OP)
+gpdf-so-links-subtarget: $(PDF_SO) $(UNIX_DLL_MAK) $(MAKEDIRS)
+ $(NO_OP)
+
gpdl-so-links-subtarget: $(GPDL_SO) $(UNIX_DLL_MAK) $(MAKEDIRS)
$(NO_OP)
@@ -183,8 +207,11 @@ $(PCLSOC_XE): gpcl6-so-links-subtarget $(UNIX_DLL_MAK) $(PLOBJ)$(REALMAIN_SRC).$
$(XPSSOC_XE): gxps-so-links-subtarget $(UNIX_DLL_MAK) $(PLOBJ)$(REALMAIN_SRC).$(OBJ) $(MAKEDIRS)
$(GLCC) -L$(BINDIR) $(LDFLAGS) $(O_) $(XPSSOC_XE) $(PLOBJ)$(REALMAIN_SRC).$(OBJ) -l$(XPS_SO_BASE)
-$(GPDLSOC_XE): gpdl-so-links-subtarget $(UNIX_DLL_MAK) $(PLOBJ)$(REALMAIN_SRC).$(OBJ) $(MAKEDIRS)
- $(GLCC) -L$(BINDIR) $(LDFLAGS) $(O_) $(GPDLSOC_XE) $(PLOBJ)$(REALMAIN_SRC).$(OBJ) -l$(GPDL_SO_BASE)
+$(PDFSOC_XE): gpdf-so-links-subtarget $(PLSRC)$(REALMAIN_SRC).c $(UNIX_DLL_MAK) $(MAKEDIRS)
+ $(GLCC) -g -o $(PDFSOC_XE) $(PLSRC)$(REALMAIN_SRC).c -L$(BINDIR) -l$(PDF_SO_BASE)
+
+$(GPDLSOC_XE): gpdl-so-links-subtarget $(PLSRC)$(REALMAIN_SRC).c $(UNIX_DLL_MAK) $(MAKEDIRS)
+ $(GLCC) -g -o $(GPDLSOC_XE) $(PLSRC)$(REALMAIN_SRC).c -L$(BINDIR) -l$(GPDL_SO_BASE)
gpcl6-so-loader: $(PCLSOC_XE)
$(NO_OP)
@@ -192,6 +219,9 @@ gpcl6-so-loader: $(PCLSOC_XE)
gxps-so-loader: $(XPSSOC_XE)
$(NO_OP)
+gpdf-so-loader: $(PDFSOC_XE)
+ $(NO_OP)
+
gpdl-so-loader: $(GPDLSOC_XE)
$(NO_OP)
@@ -209,6 +239,9 @@ gpcl6-so-strip:
gxps-so-strip:
$(STRIP_XE) $(STRIP_XE_OPTS) $(GXPS_XE)
+gpdf-so-strip:
+ $(STRIP_XE) $(STRIP_XE_OPTS) $(GPDF_XE)
+
gpdl-so-strip:
$(STRIP_XE)$(STRIP_XE_OPTS) $(GPDL_XE)
@@ -225,6 +258,7 @@ SODEFS=\
GS_XE=$(BINDIR)/$(GS_SONAME_MAJOR_MINOR) \
GPCL_XE=$(BINDIR)/$(PCL_SONAME_MAJOR_MINOR) \
GXPS_XE=$(BINDIR)/$(XPS_SONAME_MAJOR_MINOR) \
+ GPDF_XE=$(BINDIR)/$(PDF_SONAME_MAJOR_MINOR) \
GPDL_XE=$(BINDIR)/$(GPDL_SONAME_MAJOR_MINOR) \
DISPLAY_DEV=$(DD)display.dev \
BUILDDIRPREFIX=$(BUILDDIRPREFIX)
@@ -252,6 +286,7 @@ so-only:
$(MAKE) $(SUB_MAKE_OPTION) gs-so-links-subtarget \
$(PCL_TARGET)-so-links-subtarget \
$(XPS_TARGET)-so-links-subtarget \
+ $(PDF_TARGET)-so-links-subtarget \
$(GPDL_TARGET)-so-links-subtarget BUILDDIRPREFIX=$(SODIRPREFIX)
@@ -260,6 +295,7 @@ so-only-stripped:
$(MAKE) $(SUB_MAKE_OPTION) gs-so-links-subtarget \
$(PCL_TARGET)-so-links-subtarget \
$(XPS_TARGET)-so-links-subtarget \
+ $(PDF_TARGET)-so-links-subtarget \
$(GPDL_TARGET)-so-links-subtarget BUILDDIRPREFIX=$(SODIRPREFIX)
# Debug shared object
@@ -284,16 +320,16 @@ so-only-subtarget:
$(AUXDIR)/echogs$(XEAUX) $(AUXDIR)/genarch$(XEAUX)
$(MAKE) $(SUB_MAKE_OPTION) $(SODEFS) GENOPT='$(GENOPT)' GS_LDFLAGS='$(LDFLAGS) $(GS_LDFLAGS_SO)'\
PCL_LDFLAGS='$(LDFLAGS) $(PCL_LDFLAGS_SO)' XPS_LDFLAGS='$(LDFLAGS) $(XPS_LDFLAGS_SO)' \
- PDL_LDFLAGS='$(LDFLAGS) $(PDL_LDFLAGS_SO)' CFLAGS='$(CFLAGS_STANDARD) $(CFLAGS_SO) \
- $(GCFLAGS) $(AC_CFLAGS) $(XCFLAGS)' prefix=$(prefix)
+ PDL_LDFLAGS='$(LDFLAGS) $(PDL_LDFLAGS_SO)' PDF_LDFLAGS='$(LDFLAGS) $(PDF_LDFLAGS_SO)' \
+ CFLAGS='$(CFLAGS_STANDARD) $(CFLAGS_SO) $(GCFLAGS) $(AC_CFLAGS) $(XCFLAGS)' prefix=$(prefix)
so-only-stripped-subtarget: so-only-subtarget
- $(MAKE) $(SUB_MAKE_OPTION) $(SODEFS) gs-so-strip $(PCL_TARGET)-so-strip $(XPS_TARGET)-so-strip $(GPDL_TARGET)-so-strip
+ $(MAKE) $(SUB_MAKE_OPTION) $(SODEFS) gs-so-strip $(PCL_TARGET)-so-strip $(XPS_TARGET)-so-strip $(GPDL_TARGET)-so-strip$ (PDF_TARGET)-so-strip
so-subtarget: so-only-subtarget
$(MAKE) $(SUB_MAKE_OPTION) $(SODEFS_FINAL) GENOPT='$(GENOPT)' LDFLAGS='$(LDFLAGS)'\
CFLAGS='$(CFLAGS_STANDARD) $(GCFLAGS) $(AC_CFLAGS) $(XCFLAGS)' prefix=$(prefix)\
- $(GSSOC_XE) $(GSSOX_XE) $(PCL_TARGET)-so-loader $(XPS_TARGET)-so-loader $(GPDL_TARGET)-so-loader
+ $(GSSOC_XE) $(GSSOX_XE) $(PCL_TARGET)-so-loader $(XPS_TARGET)-so-loader $(GPDL_TARGET)-so-loader $(PDF_TARGET)-so-loader
install-so-gs:
$(MAKE) $(SUB_MAKE_OPTION) install-so-subtarget BUILDDIRPREFIX=$(SODIRPREFIX)
diff --git a/base/unix-end.mak b/base/unix-end.mak
index d837d9ea..9302ce96 100644
--- a/base/unix-end.mak
+++ b/base/unix-end.mak
@@ -43,6 +43,12 @@ gxps: .xpssubtarget $(UNIX_END_MAK)
gxpsclean: cleansub
$(NO_OP)
+gpdf: .pdfsubtarget $(UNIX_END_MAK)
+ $(NO_OP)
+
+gpdfclean: cleansub
+ $(NO_OP)
+
gpdl: .gpdlsubtarget $(UNIX_END_MAK)
$(NO_OP)
@@ -102,6 +108,12 @@ gxpspg:
gxpspgclean:
$(MAKE) $(PROFILEMAKEOPTS) cleansub
+gpdfpg:
+ $(MAKE) $(PROFILEMAKEOPTS) .pdfsubtarget
+
+gpdfpgclean:
+ $(MAKE) $(PROFILEMAKEOPTS) cleansub
+
gpdlpg:
$(MAKE) $(PROFILEMAKEOPTS) .gpdlsubtarget
@@ -145,6 +157,12 @@ gxpsdebug:
gxpsdebugclean:
$(MAKE) $(DEBUGMAKEOPTS) cleansub
+gpdfdebug:
+ $(MAKE) $(DEBUGMAKEOPTS) .pdfsubtarget
+
+gpdfdebugclean:
+ $(MAKE) $(DEBUGMAKEOPTS) cleansub
+
gpdldebug:
$(MAKE) $(DEBUGMAKEOPTS) .gpdlsubtarget
@@ -188,6 +206,9 @@ gpcl6memento:
gxpsmemento:
$(MAKE) $(MEMENTOMAKEOPTS) .xpssubtarget
+gpdfmemento:
+ $(MAKE) $(MEMENTOMAKEOPTS) .pdfsubtarget
+
gpdlmemento:
$(MAKE) $(MEMENTOMAKEOPTS) .gpdlsubtarget
@@ -218,6 +239,9 @@ gxpsmementovg:
gpdlmementovg:
$(MAKE) $(MEMENTOVGMAKEOPTS) .gpdlsubtarget
+gpdfmementovg:
+ $(MAKE) $(MEMENTOVGMAKEOPTS) .pdfsubtarget
+
mementovgclean:
$(MAKE) $(MEMENTOVGMAKEOPTS) cleansub
@@ -244,6 +268,9 @@ gpcl6sanitize:
gxpssanitize:
$(MAKE) $(SANITIZEMAKEOPTS) .xpssubtarget
+gpdfsanitize:
+ $(MAKE) $(SANITIZEMAKEOPTS) .pdfsubtarget
+
gpdlsanitize:
$(MAKE) $(SANITIZEMAKEOPTS) .gpdlsubtarget
@@ -273,6 +300,9 @@ gxpsvg:
gpdlvg:
$(MAKE) $(VGMAKEOPTS) .gpdlsubtarget
+gpdfvg:
+ $(MAKE) $(VGMAKEOPTS) .pdfsubtarget
+
vgclean:
$(MAKE) $(VGMAKEOPTS) cleansub
@@ -300,6 +330,9 @@ gxpsdebugvg:
gpdldebugvg:
$(MAKE) $(DEBUGVGMAKEOPTS) .gpdlsubtarget
+gpdfdebugvg:
+ $(MAKE) $(DEBUGVGMAKEOPTS) .pdfsubtarget
+
debugvgclean:
$(MAKE) $(DEBUGVGMAKEOPTS) cleansub
diff --git a/base/unix-gcc.mak b/base/unix-gcc.mak
index c8bc0659..0712aa27 100644
--- a/base/unix-gcc.mak
+++ b/base/unix-gcc.mak
@@ -53,6 +53,10 @@ XPSSRCDIR=./xps
XPSGENDIR=./$(BUILDDIRPREFIX)obj
XPSOBJDIR=./$(BUILDDIRPREFIX)obj
+PDFSRCDIR=./pdf
+PDFGENDIR=./$(BUILDDIRPREFIX)obj
+PDFOBJDIR=./$(BUILDDIRPREFIX)obj
+
GPDLSRCDIR=./gpdl
GPDLGENDIR=./$(BUILDDIRPREFIX)obj
GPDLOBJDIR=./$(BUILDDIRPREFIX)obj
@@ -173,6 +177,7 @@ GS_SO_BASE=gs
PCL=gpcl6
XPS=gxps
+PDF=gpdf
GPDL=gpdl
XE=
@@ -406,10 +411,12 @@ LDFLAGS= $(AC_LDFLAGS) $(XLDFLAGS)
GS_LDFLAGS=$(LDFLAGS)
PCL_LDFLAGS=$(LDFLAGS)
XPS_LDFLAGS=$(LDFLAGS)
+PDF_LDFLAGS=$(LDFLAGS)
GS_LDFLAGS_SO=-shared -Wl,$(LD_SET_DT_SONAME)$(LDFLAGS_SO_PREFIX)$(GS_SONAME_MAJOR)
PCL_LDFLAGS_SO=-shared -Wl,$(LD_SET_DT_SONAME)$(LDFLAGS_SO_PREFIX)$(PCL_SONAME_MAJOR)
XPS_LDFLAGS_SO=-shared -Wl,$(LD_SET_DT_SONAME)$(LDFLAGS_SO_PREFIX)$(XPS_SONAME_MAJOR)
+PDF_LDFLAGS_SO=-shared -Wl,$(LD_SET_DT_SONAME)$(LDFLAGS_SO_PREFIX)$(PDF_SONAME_MAJOR)
# Define any extra libraries to link into the executable.
# ISC Unix 2.2 wants -linet.
@@ -498,6 +505,8 @@ PCL_FEATURE_DEVS=$(PLOBJDIR)/pl.dev $(PLOBJDIR)/pjl.dev $(PXLOBJDIR)/pxl.dev $(P
XPS_FEATURE_DEVS=$(XPSOBJDIR)/pl.dev $(XPSOBJDIR)/xps.dev
+PDF_FEATURE_DEVS=$(PDFOBJDIR)/pl.dev $(PDFOBJDIR)/gpdf.dev
+
FEATURE_DEVS=$(GLD)pipe.dev $(GLD)gsnogc.dev $(GLD)htxlib.dev $(GLD)psl3lib.dev $(GLD)psl2lib.dev \
$(GLD)dps2lib.dev $(GLD)path1lib.dev $(GLD)patlib.dev $(GLD)psl2cs.dev $(GLD)rld.dev $(GLD)gxfapiu$(UFST_BRIDGE).dev\
$(GLD)ttflib.dev $(GLD)cielib.dev $(GLD)pipe.dev $(GLD)htxlib.dev $(GLD)sdct.dev $(GLD)libpng.dev\
@@ -622,6 +631,7 @@ include $(GLSRCDIR)/gs.mak
# are available
# include $(PLSRCDIR)$(D)plromfs.mak # plromfs.mak
# include $(XPSSRCDIR)$(D)xpsromfs.mak # xpsromfs.mak
+# include $(PDFSRCDIR)$(D)pdfromfs.mak # pdfromfs.mak
include $(PSSRCDIR)/psromfs.mak
include $(GLSRCDIR)/lib.mak
@@ -636,6 +646,8 @@ include $(PSSRCDIR)/int.mak
# include $(XPSSRCDIR)$(D)xps.mak # xps.mak
+# include $(PDFSRCDIR)$(D)pdf.mak # pdf.mak
+
# include $(GPDLSRCDIR)$(D)gpdl.mak # gpdl.mak
include $(GLSRCDIR)/freetype.mak
diff --git a/base/unixlink.mak b/base/unixlink.mak
index 4c65229e..ee91babd 100644
--- a/base/unixlink.mak
+++ b/base/unixlink.mak
@@ -227,6 +227,27 @@ $(GXPS_XE): $(ld_tr) $(xps_tr) $(REALMAIN_OBJ) $(MAIN_OBJ) $(XPS_TOP_OBJS) \
.xpssubtarget: $(GXPS_XE)
$(NO_OP)
+pdfldt_tr=$(PSOBJ)pdfldt.tr
+$(GPDF_XE): $(ld_tr) $(pdf_tr) $(REALMAIN_OBJ) $(MAIN_OBJ) $(PDF_TOP_OBJS) \
+ $(XOBJS) $(GLOBJDIR)/pdfromfs$(COMPILE_INITS).$(OBJ) \
+ $(INT_ARCHIVE_SOME) $(UNIXLINK_MAK)
+ $(ECHOGS_XE) -w $(pdfldt_tr) -n - $(CCLD) $(PDF_LDFLAGS) $(XLIBDIRS) -o $(GPDF_XE)
+ $(ECHOGS_XE) -a $(pdfldt_tr) -n -s $(PDF_TOP_OBJS) $(INT_ARCHIVE_SOME) $(XOBJS) -s
+ cat $(pdfld_tr) >> $(pdfldt_tr)
+ $(ECHOGS_XE) -a $(pdfldt_tr) -s - $(GLOBJDIR)/pdfromfs$(COMPILE_INITS).$(OBJ) $(REALMAIN_OBJ) $(MAIN_OBJ) $(EXTRALIBS) $(STDLIBS)
+ if [ x$(XLIBDIR) != x ]; then LD_RUN_PATH=$(XLIBDIR); export LD_RUN_PATH; fi; \
+ XCFLAGS= XINCLUDE= XLDFLAGS= XLIBDIRS= XLIBS= \
+ PCL_FEATURE_DEVS= DEVICE_DEVS= DEVICE_DEVS1= DEVICE_DEVS2= DEVICE_DEVS3= \
+ DEVICE_DEVS4= DEVICE_DEVS5= DEVICE_DEVS6= DEVICE_DEVS7= DEVICE_DEVS8= \
+ DEVICE_DEVS9= DEVICE_DEVS10= DEVICE_DEVS11= DEVICE_DEVS12= \
+ DEVICE_DEVS13= DEVICE_DEVS14= DEVICE_DEVS15= DEVICE_DEVS16= \
+ DEVICE_DEVS17= DEVICE_DEVS18= DEVICE_DEVS19= DEVICE_DEVS20= \
+ DEVICE_DEVS_EXTRA= \
+ sh <$(pdfldt_tr)
+
+.pdfsubtarget: $(GPDF_XE)
+ $(NO_OP)
+
gpdlldt_tr=$(PSOBJ)gpdlldt.tr
$(GPDL_XE): $(ld_tr) $(gpdl_tr) $(INT_ARCHIVE_ALL) $(REALMAIN_OBJ) $(MAIN_OBJ) \
$(GPDL_PSI_TOP_OBJS) $(PCL_PXL_TOP_OBJS) $(PSI_TOP_OBJ) $(XPS_TOP_OBJ) \
diff --git a/base/version.mak b/base/version.mak
index 88ea1634..45ee90f1 100644
--- a/base/version.mak
+++ b/base/version.mak
@@ -14,10 +14,10 @@
# Major, minor and patch version numbers.
GS_VERSION_MAJOR=9
-GS_VERSION_MINOR=54
+GS_VERSION_MINOR=55
GS_VERSION_PATCH=0
# Revision date: year x 10000 + month x 100 + day.
-GS_REVISIONDATE=20210330
+GS_REVISIONDATE=20210927
# Derived values
GS_VERSION=$(GS_VERSION_MAJOR)$(GS_VERSION_MINOR)$(GS_VERSION_PATCH)
GS_DOT_VERSION=$(GS_VERSION_MAJOR).$(GS_VERSION_MINOR).$(GS_VERSION_PATCH)
diff --git a/configure b/configure
index 49b9a969..cef01a2c 100755
--- a/configure
+++ b/configure
@@ -689,6 +689,7 @@ SO_LIB_EXT
X11_DEVS
INSTALL_SHARED
DYNAMIC_LIBS
+PDF_DYNAMIC_LDFLAGS
PDL_DYNAMIC_LDFLAGS
XPS_DYNAMIC_LDFLAGS
PCL_DYNAMIC_LDFLAGS
@@ -699,6 +700,9 @@ DYNAMIC_CFLAGS
GPDL_SONAME_MAJOR_MINOR
GPDL_SONAME_MAJOR
GPDL_SONAME
+PDF_SONAME_MAJOR_MINOR
+PDF_SONAME_MAJOR
+PDF_SONAME
XPS_SONAME_MAJOR_MINOR
XPS_SONAME_MAJOR
XPS_SONAME
@@ -720,6 +724,11 @@ COMPILE_INITS
GPDL_MAK
GPDL_TARGET
GPDL
+PDFROMFS_MAK
+GPDF_DEV
+PDF_MAK
+PDF_TARGET
+PDF
XPSROMFS_MAK
XPS_MAK
XPS_TARGET
@@ -959,6 +968,7 @@ with_x
with_gs
with_pcl
with_xps
+with_pdf
with_gpdl
enable_compile_inits
with_drivers
@@ -1675,6 +1685,8 @@ Optional Packages:
available, ignored otherwise) [[gpcl6]]
--with-xps=NAME name of the GhostXPS executible (if the source is
available, ignored otherwise) [[gxps]]
+ --with-pdf=NAME name of the Ghostpdf executible (if the source is
+ available, ignored otherwise) [[gpdf]]
--with-gpdl=NAME name of the GhostPDL executible (if the source is
available, ignored otherwise) [[gpdl]]
--with-drivers=LIST Drivers to support, separated by commas.
@@ -1710,7 +1722,9 @@ Optional Packages:
Default: ALL
--with-driversfile=FILE Drivers to support from file, separated by newlines.
--with-extract-dir=EXTRACT_DIR
-
+ Build with the specified Extract library. By default
+ we build with Extract automatically if
+ <ghostpdl-directory>/extract exists.
--with-fontpath set font search path for gs
--with-tessdata set tesseract data search path
--with-memory-alignment Allows setting minimum alignment for the memory
@@ -4791,7 +4805,7 @@ fi
# debug configurarion is available by default with "make debug"
-#AC_ARG_ENABLE([debug], AC_HELP_STRING([--enable-debug],
+#AC_ARG_ENABLE([debug], AS_HELP_STRING([--enable-debug],
# [turn on debugging]))
#if test x$enable_debug = xyes; then
# optflags_to_try="-g"
@@ -5460,13 +5474,10 @@ $as_echo "$ac_cv_c_bigendian" >&6; }
no)
BIGENDIAN=0 ;; #(
universal)
-
-$as_echo "#define AC_APPLE_UNIVERSAL_BUILD 1" >>confdefs.h
-
+ as_fn_error $? "Building of universal binaries is not implemented." "$LINENO" 5
;; #(
*)
- as_fn_error $? "unknown endianness
- presetting ac_cv_c_bigendian=no (or yes) will help" "$LINENO" 5 ;;
+ as_fn_error $? "Endian status cannot be determined" "$LINENO" 5 ;;
esac
@@ -5690,118 +5701,6 @@ fi
fi
-{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for ANSI C header files" >&5
-$as_echo_n "checking for ANSI C header files... " >&6; }
-if ${ac_cv_header_stdc+:} false; then :
- $as_echo_n "(cached) " >&6
-else
- cat confdefs.h - <<_ACEOF >conftest.$ac_ext
-/* end confdefs.h. */
-#include <stdlib.h>
-#include <stdarg.h>
-#include <string.h>
-#include <float.h>
-
-int
-main ()
-{
-
- ;
- return 0;
-}
-_ACEOF
-if ac_fn_c_try_compile "$LINENO"; then :
- ac_cv_header_stdc=yes
-else
- ac_cv_header_stdc=no
-fi
-rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
-
-if test $ac_cv_header_stdc = yes; then
- # SunOS 4.x string.h does not declare mem*, contrary to ANSI.
- cat confdefs.h - <<_ACEOF >conftest.$ac_ext
-/* end confdefs.h. */
-#include <string.h>
-
-_ACEOF
-if (eval "$ac_cpp conftest.$ac_ext") 2>&5 |
- $EGREP "memchr" >/dev/null 2>&1; then :
-
-else
- ac_cv_header_stdc=no
-fi
-rm -f conftest*
-
-fi
-
-if test $ac_cv_header_stdc = yes; then
- # ISC 2.0.2 stdlib.h does not declare free, contrary to ANSI.
- cat confdefs.h - <<_ACEOF >conftest.$ac_ext
-/* end confdefs.h. */
-#include <stdlib.h>
-
-_ACEOF
-if (eval "$ac_cpp conftest.$ac_ext") 2>&5 |
- $EGREP "free" >/dev/null 2>&1; then :
-
-else
- ac_cv_header_stdc=no
-fi
-rm -f conftest*
-
-fi
-
-if test $ac_cv_header_stdc = yes; then
- # /bin/cc in Irix-4.0.5 gets non-ANSI ctype macros unless using -ansi.
- if test "$cross_compiling" = yes; then :
- :
-else
- cat confdefs.h - <<_ACEOF >conftest.$ac_ext
-/* end confdefs.h. */
-#include <ctype.h>
-#include <stdlib.h>
-#if ((' ' & 0x0FF) == 0x020)
-# define ISLOWER(c) ('a' <= (c) && (c) <= 'z')
-# define TOUPPER(c) (ISLOWER(c) ? 'A' + ((c) - 'a') : (c))
-#else
-# define ISLOWER(c) \
- (('a' <= (c) && (c) <= 'i') \
- || ('j' <= (c) && (c) <= 'r') \
- || ('s' <= (c) && (c) <= 'z'))
-# define TOUPPER(c) (ISLOWER(c) ? ((c) | 0x40) : (c))
-#endif
-
-#define XOR(e, f) (((e) && !(f)) || (!(e) && (f)))
-int
-main ()
-{
- int i;
- for (i = 0; i < 256; i++)
- if (XOR (islower (i), ISLOWER (i))
- || toupper (i) != TOUPPER (i))
- return 2;
- return 0;
-}
-_ACEOF
-if ac_fn_c_try_run "$LINENO"; then :
-
-else
- ac_cv_header_stdc=no
-fi
-rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \
- conftest.$ac_objext conftest.beam conftest.$ac_ext
-fi
-
-fi
-fi
-{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_header_stdc" >&5
-$as_echo "$ac_cv_header_stdc" >&6; }
-if test $ac_cv_header_stdc = yes; then
-
-$as_echo "#define STDC_HEADERS 1" >>confdefs.h
-
-fi
-
for ac_header in errno.h fcntl.h limits.h malloc.h memory.h stdlib.h string.h strings.h sys/ioctl.h sys/param.h sys/time.h sys/times.h syslog.h unistd.h dirent.h ndir.h sys/dir.h sys/ndir.h inttypes.h
do :
as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh`
@@ -6023,41 +5922,6 @@ esac
fi
-{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether time.h and sys/time.h may both be included" >&5
-$as_echo_n "checking whether time.h and sys/time.h may both be included... " >&6; }
-if ${ac_cv_header_time+:} false; then :
- $as_echo_n "(cached) " >&6
-else
- cat confdefs.h - <<_ACEOF >conftest.$ac_ext
-/* end confdefs.h. */
-#include <sys/types.h>
-#include <sys/time.h>
-#include <time.h>
-
-int
-main ()
-{
-if ((struct tm *) 0)
-return 0;
- ;
- return 0;
-}
-_ACEOF
-if ac_fn_c_try_compile "$LINENO"; then :
- ac_cv_header_time=yes
-else
- ac_cv_header_time=no
-fi
-rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
-fi
-{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_header_time" >&5
-$as_echo "$ac_cv_header_time" >&6; }
-if test $ac_cv_header_time = yes; then
-
-$as_echo "#define TIME_WITH_SYS_TIME 1" >>confdefs.h
-
-fi
-
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether struct tm is in sys/time.h or time.h" >&5
$as_echo_n "checking whether struct tm is in sys/time.h or time.h... " >&6; }
if ${ac_cv_struct_tm+:} false; then :
@@ -6166,11 +6030,11 @@ fi
if test "$ac_cv_c_const" != yes; then
GCFLAGS="$GCFLAGS -Dconst="
fi
-if test "x$ac_cv_header_stdint_h" = xyes; then
+if test "x$ac_cv_header_stdint_h" = "xyes"; then
GCFLAGS="$GCFLAGS -DHAVE_STDINT_H=1"
fi
-if test "x$ac_cv_header_dirent_h" = xyes; then
+if test "x$ac_cv_header_dirent_h" = "xyes"; then
GCFLAGS="$GCFLAGS -DHAVE_DIRENT_H=1"
fi
@@ -6178,23 +6042,23 @@ if test "x$ac_cv_header_ndir_h" = xyes; then
GCFLAGS="$GCFLAGS -DHAVE_NDIR_H=1"
fi
-if test "x$ac_cv_header_sys_dir_h" = xyes; then
+if test "x$ac_cv_header_sys_dir_h" = "xyes"; then
GCFLAGS="$GCFLAGS -DHAVE_SYS_DIR_H=1"
fi
-if test "x$ac_cv_header_sys_ndir_h" = xyes; then
+if test "x$ac_cv_header_sys_ndir_h" = "xyes"; then
GCFLAGS="$GCFLAGS -DHAVE_SYS_NDIR_H=1"
fi
-if test "x$ac_cv_header_sys_time_h" = xyes; then
+if test "x$ac_cv_header_sys_time_h" = "xyes"; then
GCFLAGS="$GCFLAGS -DHAVE_SYS_TIME_H=1"
fi
-if test "x$ac_cv_header_sys_times_h" = xyes; then
+if test "x$ac_cv_header_sys_times_h" = "xyes"; then
GCFLAGS="$GCFLAGS -DHAVE_SYS_TIMES_H=1"
fi
-if test "x$ac_cv_header_inttypes_h" = xyes; then
+if test "x$ac_cv_header_inttypes_h" = "xyes"; then
GCFLAGS="$GCFLAGS -DHAVE_INTTYPES_H=1"
fi
@@ -6826,6 +6690,9 @@ TESSERACTINCLUDE=
TESSERACT_LIBS=
OCR_DEVS=
+OCR_DEVS_WARNING_LINE1=
+OCR_DEVS_WARNING_LINE2=
+
# Check whether --with-tesseract was given.
if test "${with_tesseract+set}" = set; then :
@@ -7138,7 +7005,7 @@ $as_echo_n "checking supported C++ compiler flags... " >&6; }
cat confdefs.h - <<_ACEOF >conftest.$ac_ext
/* end confdefs.h. */
-
+#include <cstdlib>
int
main ()
{
@@ -7157,27 +7024,33 @@ rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
CXXFLAGS="$old_cflags"
done
- CXXFLAGS="$save_cxxflags $CXXFLAGS_TO_USE"
+ if test x"$GXX" = x"no" || echo $CXXFLAGS_TO_USE | grep "std=c++17" ; then
+ if test x"$GXX" = x"no" ; then
+ OCR_DEVS_WARNING_LINE1="C++ compiler does not appear to be gcc or compatible, attempting to continue anyway"
+ OCR_DEVS_WARNING_LINE2="NOTE: that tesseract requires a C++17 compatible C++ compiler"
+ fi
+
+ CXXFLAGS="$save_cxxflags $CXXFLAGS_TO_USE"
- { $as_echo "$as_me:${as_lineno-$LINENO}: checking sse4.1 support" >&5
+ { $as_echo "$as_me:${as_lineno-$LINENO}: checking sse4.1 support" >&5
$as_echo_n "checking sse4.1 support... " >&6; }
- save_cxxflags=$CXXFLAGS
- TESS_CXXFLAGS="$CXXFLAGS"
- CXXFLAGS="$CXXFLAGS -msse4.1"
+ save_cxxflags=$CXXFLAGS
+ TESS_CXXFLAGS="$CXXFLAGS"
+ CXXFLAGS="$CXXFLAGS -msse4.1"
- TESS_SSE4_1=""
- cat confdefs.h - <<_ACEOF >conftest.$ac_ext
+ TESS_SSE4_1=""
+ cat confdefs.h - <<_ACEOF >conftest.$ac_ext
/* end confdefs.h. */
#include <emmintrin.h>
- #include <smmintrin.h>
+ #include <smmintrin.h>
int
main ()
{
__m128i input1;
- unsigned char buf1[128];
- input1 = _mm_loadu_si128((const __m128i *)buf1);
- input1 = _mm_hadd_epi32(input1, input1);
- return(0);
+ unsigned char buf1[128];
+ input1 = _mm_loadu_si128((const __m128i *)buf1);
+ input1 = _mm_hadd_epi32(input1, input1);
+ return(0);
;
return 0;
@@ -7191,29 +7064,29 @@ fi
rm -f core conftest.err conftest.$ac_objext \
conftest$ac_exeext conftest.$ac_ext
- if test "x$TESS_SSE4_1" != x; then
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
+ if test "x$TESS_SSE4_1" != x; then
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
$as_echo "yes" >&6; }
- TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_SSE4_1"
- else
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
+ TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_SSE4_1"
+ else
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
$as_echo "no" >&6; }
- fi
+ fi
- { $as_echo "$as_me:${as_lineno-$LINENO}: checking avx support" >&5
+ { $as_echo "$as_me:${as_lineno-$LINENO}: checking avx support" >&5
$as_echo_n "checking avx support... " >&6; }
- CXXFLAGS="$save_cxxflags -mavx"
+ CXXFLAGS="$save_cxxflags -mavx"
- TESS_AVX=""
- cat confdefs.h - <<_ACEOF >conftest.$ac_ext
+ TESS_AVX=""
+ cat confdefs.h - <<_ACEOF >conftest.$ac_ext
/* end confdefs.h. */
#include <immintrin.h>
int
main ()
{
__m256d input1 = _mm256_setzero_pd();
- input1 = _mm256_hadd_pd(input1, input1);
- return(0);
+ input1 = _mm256_hadd_pd(input1, input1);
+ return(0);
;
return 0;
}
@@ -7226,31 +7099,31 @@ fi
rm -f core conftest.err conftest.$ac_objext \
conftest$ac_exeext conftest.$ac_ext
- if test "x$TESS_AVX" != x; then
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
+ if test "x$TESS_AVX" != x; then
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
$as_echo "yes" >&6; }
- TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_AVX"
- else
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
+ TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_AVX"
+ else
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
$as_echo "no" >&6; }
- fi
+ fi
- { $as_echo "$as_me:${as_lineno-$LINENO}: checking avx2 support" >&5
+ { $as_echo "$as_me:${as_lineno-$LINENO}: checking avx2 support" >&5
$as_echo_n "checking avx2 support... " >&6; }
- CXXFLAGS="$save_cxxflags -mavx2"
+ CXXFLAGS="$save_cxxflags -mavx2"
- TESS_AVX2=""
- cat confdefs.h - <<_ACEOF >conftest.$ac_ext
+ TESS_AVX2=""
+ cat confdefs.h - <<_ACEOF >conftest.$ac_ext
/* end confdefs.h. */
#include <immintrin.h>
int
main ()
{
__m256i input1;
- unsigned char buf1[256];
- input1 = _mm256_loadu_si256((const __m256i *)buf1);
- input1 = _mm256_adds_epu8(input1, input1);
- return(0);
+ unsigned char buf1[256];
+ input1 = _mm256_loadu_si256((const __m256i *)buf1);
+ input1 = _mm256_adds_epu8(input1, input1);
+ return(0);
;
return 0;
}
@@ -7263,29 +7136,29 @@ fi
rm -f core conftest.err conftest.$ac_objext \
conftest$ac_exeext conftest.$ac_ext
- if test "x$TESS_AVX2" != x; then
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
+ if test "x$TESS_AVX2" != x; then
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
$as_echo "yes" >&6; }
- TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_AVX2"
- else
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
+ TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_AVX2"
+ else
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
$as_echo "no" >&6; }
- fi
+ fi
- { $as_echo "$as_me:${as_lineno-$LINENO}: checking fma support" >&5
+ { $as_echo "$as_me:${as_lineno-$LINENO}: checking fma support" >&5
$as_echo_n "checking fma support... " >&6; }
- CXXFLAGS="$save_cxxflags -mfma"
+ CXXFLAGS="$save_cxxflags -mfma"
- TESS_FMA=""
- cat confdefs.h - <<_ACEOF >conftest.$ac_ext
+ TESS_FMA=""
+ cat confdefs.h - <<_ACEOF >conftest.$ac_ext
/* end confdefs.h. */
#include <immintrin.h>
int
main ()
{
__m256d input1 = _mm256_setzero_pd();
- input1 = _mm256_fmadd_pd(input1, input1, input1);
- return(0);
+ input1 = _mm256_fmadd_pd(input1, input1, input1);
+ return(0);
;
return 0;
}
@@ -7298,28 +7171,28 @@ fi
rm -f core conftest.err conftest.$ac_objext \
conftest$ac_exeext conftest.$ac_ext
- if test "x$TESS_FMA" != x; then
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
+ if test "x$TESS_FMA" != x; then
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
$as_echo "yes" >&6; }
- TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_FMA"
- else
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
+ TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_FMA"
+ else
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
$as_echo "no" >&6; }
- fi
+ fi
- { $as_echo "$as_me:${as_lineno-$LINENO}: checking neon support" >&5
+ { $as_echo "$as_me:${as_lineno-$LINENO}: checking neon support" >&5
$as_echo_n "checking neon support... " >&6; }
- CXXFLAGS="$save_cxxflags -mfpu=neon -mcpu=cortex-a53"
+ CXXFLAGS="$save_cxxflags -mfpu=neon -mcpu=cortex-a53"
- TESS_NEON=""
- cat confdefs.h - <<_ACEOF >conftest.$ac_ext
+ TESS_NEON=""
+ cat confdefs.h - <<_ACEOF >conftest.$ac_ext
/* end confdefs.h. */
#include "arm_neon.h"
int
main ()
{
int32x4_t round = vdupq_n_s32(10);
- return(0);
+ return(0);
;
return 0;
}
@@ -7332,22 +7205,25 @@ fi
rm -f core conftest.err conftest.$ac_objext \
conftest$ac_exeext conftest.$ac_ext
- if test "x$TESS_NEON" != x; then
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
+ if test "x$TESS_NEON" != x; then
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
$as_echo "yes" >&6; }
- TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_NEON"
- else
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
+ TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_NEON"
+ else
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
$as_echo "no" >&6; }
- fi
+ fi
- CXXFLAGS="$save_cxxflags"
+ CXXFLAGS="$save_cxxflags"
- OCR_VERSION=1
- OCR_DEVS="\$(DD)ocr.dev \$(DD)hocr.dev \$(DD)pdfocr8.dev \$(DD)pdfocr24.dev \$(DD)pdfocr32.dev"
- LEPTONICAINCLUDE="include base/leptonica.mak"
- TESSERACTINCLUDE="include base/tesseract.mak"
- TESSERACT_LIBS="-lstdc++"
+ OCR_VERSION=1
+ OCR_DEVS="\$(DD)ocr.dev \$(DD)hocr.dev \$(DD)pdfocr8.dev \$(DD)pdfocr24.dev \$(DD)pdfocr32.dev"
+ LEPTONICAINCLUDE="include base/leptonica.mak"
+ TESSERACTINCLUDE="include base/tesseract.mak"
+ TESSERACT_LIBS="-lstdc++"
+ else
+ OCR_DEVS_WARNING_LINE1="OCR devices disabled due to incompatible compiler: tesseract requires a C++17 compatible compiler"
+ fi
fi
ac_ext=c
ac_cpp='$CPP $CPPFLAGS'
@@ -8942,7 +8818,7 @@ if test x"$SHARE_LIBTIFF" = x"0" ; then
if ! test -d "$LIBTIFFCONFDIR" ; then
mkdir "$LIBTIFFCONFDIR"
fi
- cd "$LIBTIFFCONFDIR" && "$absolute_source_path/$LIBTIFFDIR/configure" --disable-jbig --disable-lzma --disable-zstd --disable-webp $SUBCONFIG_OPTS
+ cd "$LIBTIFFCONFDIR" && "$absolute_source_path/$LIBTIFFDIR/configure" $GS_TIFF_CONFIGURE_OPTS --disable-jbig --disable-lzma --disable-zstd --disable-webp --disable-libdeflate $SUBCONFIG_OPTS
status=$?
if test $status -ne 0 ; then
as_fn_error $status "libtiff configure script failed" "$LINENO" 5
@@ -9385,6 +9261,50 @@ done
$as_echo "$as_me: WARNING: USING LOCAL CUPS SOURCE" >&2;}
SHARELCUPS=0
SHARELCUPSI=0
+ for ac_func in strlcat
+do :
+ ac_fn_c_check_func "$LINENO" "strlcat" "ac_cv_func_strlcat"
+if test "x$ac_cv_func_strlcat" = xyes; then :
+ cat >>confdefs.h <<_ACEOF
+#define HAVE_STRLCAT 1
+_ACEOF
+ CUPSCFLAGS="$CUPSCFLAGS -DHAVE_STRLCAT=1"
+fi
+done
+
+ for ac_func in strlcpy
+do :
+ ac_fn_c_check_func "$LINENO" "strlcpy" "ac_cv_func_strlcpy"
+if test "x$ac_cv_func_strlcpy" = xyes; then :
+ cat >>confdefs.h <<_ACEOF
+#define HAVE_STRLCPY 1
+_ACEOF
+ CUPSCFLAGS="$CUPSCFLAGS -DHAVE_STRLCPY=1"
+fi
+done
+
+ for ac_func in snprintf
+do :
+ ac_fn_c_check_func "$LINENO" "snprintf" "ac_cv_func_snprintf"
+if test "x$ac_cv_func_snprintf" = xyes; then :
+ cat >>confdefs.h <<_ACEOF
+#define HAVE_SNPRINTF 1
+_ACEOF
+ CUPSCFLAGS="$CUPSCFLAGS -DHAVE_SNPRINTF=1"
+fi
+done
+
+ for ac_func in vsnprintf
+do :
+ ac_fn_c_check_func "$LINENO" "vsnprintf" "ac_cv_func_vsnprintf"
+if test "x$ac_cv_func_vsnprintf" = xyes; then :
+ cat >>confdefs.h <<_ACEOF
+#define HAVE_VSNPRINTF 1
+_ACEOF
+ CUPSCFLAGS="$CUPSCFLAGS -DHAVE_VSNPRINTF=1"
+fi
+done
+
LCUPSBUILDTYPE=linux
LCUPSINCLUDE="include \$(GLSRCDIR)/lcups.mak"
LCUPSIINCLUDE="include \$(GLSRCDIR)/lcupsi.mak"
@@ -9968,7 +9888,7 @@ fi
rm -f core conftest.err conftest.$ac_objext \
conftest$ac_exeext conftest.$ac_ext
- #AC_ARG_ENABLE([sse4.2], AC_HELP_STRING([--disable-sse4.2],
+ #AC_ARG_ENABLE([sse4.2], AS_HELP_STRING([--disable-sse4.2],
# [Do not use sse4.2 instrinsics]), [
# if test "x$enable_sse4.2" = xno; then
# HAVE_SSE4_2=""
@@ -10012,7 +9932,7 @@ fi
rm -f core conftest.err conftest.$ac_objext \
conftest$ac_exeext conftest.$ac_ext
- #AC_ARG_ENABLE([sse4.2], AC_HELP_STRING([--disable-sse4.2],
+ #AC_ARG_ENABLE([sse4.2], AS_HELP_STRING([--disable-sse4.2],
# [Do not use sse4.2 instrinsics]), [
# if test "x$enable_sse4.2" = xno; then
# HAVE_SSE4_2=""
@@ -10052,7 +9972,7 @@ fi
rm -f core conftest.err conftest.$ac_objext \
conftest$ac_exeext conftest.$ac_ext
- #AC_ARG_ENABLE([neon], AC_HELP_STRING([--disable-neon],
+ #AC_ARG_ENABLE([neon], AS_HELP_STRING([--disable-neon],
# [Do not use neon instrinsics]), [
# if test "x$enable_neon" = xno; then
# HAVE_NEON=""
@@ -11105,6 +11025,42 @@ fi
+GPDF_DEV=
+PDF=
+PDF_MAK="\$(GLSRCDIR)\$(D)stub.mak"
+PDFROMFS_MAK="\$(GLSRCDIR)\$(D)stub.mak"
+
+if test x"$with_pdf" != x"no" ; then
+ if test -f $srcdir/pdf/pdf.mak; then
+
+# Check whether --with-pdf was given.
+if test "${with_pdf+set}" = set; then :
+ withval=$with_pdf; PDFEXE="$with_pdf"
+else
+ PDFEXE='gpdf'
+fi
+
+
+ if test -f $srcdir/pcl/pl/pl.mak && test x"$PCL_TARGET" != x"" ; then
+ PDF_TARGET=gpdf
+ PDF=$PDFEXE
+ else
+ PDF=no_gpdf
+ fi
+ CFLAGS="-DBUILD_PDF=1 -I$srcdir/pdf $CFLAGS"
+ GPDF_DEV="\$(PDFOBJDIR)\$(D)pdfi.dev"
+ PDF_MAK="\$(PDFSRCDIR)\$(D)pdf.mak"
+ PDFROMFS_MAK="\$(PDFSRCDIR)\$(D)pdfromfs.mak"
+ fi
+fi
+
+
+
+
+
+
+
+
GPDL=no_gpdl
GPDL_TARGET=
GPDL_TARGET_VAR=
@@ -11520,6 +11476,11 @@ PCL_SONAME_MAJOR_MINOR="lib\$(PCL${libname3}"
XPS_SONAME="lib\$(XPS${libname1}"
XPS_SONAME_MAJOR="lib\$(XPS${libname2}"
XPS_SONAME_MAJOR_MINOR="lib\$(XPS${libname3}"
+
+PDF_SONAME="lib\$(PDF${libname1}"
+PDF_SONAME_MAJOR="lib\$(PDF${libname2}"
+PDF_SONAME_MAJOR_MINOR="lib\$(PDF${libname3}"
+
GPDL_SONAME="lib\$(GPDL${libname1}"
GPDL_SONAME_MAJOR="lib\$(GPDL${libname2}"
GPDL_SONAME_MAJOR_MINOR="lib\$(GPDL${libname3}"
@@ -11547,6 +11508,7 @@ case $host in
PCL_DYNAMIC_LDFLAGS="-shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(PCL_SONAME_MAJOR)"
XPS_DYNAMIC_LDFLAGS="-shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(XPS_SONAME_MAJOR)"
PDL_DYNAMIC_LDFLAGS="-shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(GPDL_SONAME_MAJOR)"
+ PDF_DYNAMIC_LDFLAGS="-shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(PDF_SONAME_MAJOR)"
if test $GCC = yes; then
# GCC high level flag
DYNAMIC_LIBS="-rdynamic"
@@ -11580,6 +11542,9 @@ case $host in
XPS_SONAME="lib\$(XPS${libname1}"
XPS_SONAME_MAJOR="lib\$(XPS${libname3}"
XPS_SONAME_MAJOR_MINOR="lib\$(XPS${libname2}"
+ PDF_SONAME="lib\$(PDF${libname1}"
+ PDF_SONAME_MAJOR="lib\$(PDF${libname3}"
+ PDF_SONAME_MAJOR_MINOR="lib\$(PDF${libname2}"
GPDL_SONAME="lib\$(GPDL${libname1}"
GPDL_SONAME_MAJOR="lib\$(GPDL${libname3}"
GPDL_SONAME_MAJOR_MINOR="lib\$(GPDL${libname2}"
@@ -11616,6 +11581,7 @@ case $host in
PCL_DYNAMIC_LDFLAGS="-shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(PCL_SONAME_MAJOR)"
XPS_DYNAMIC_LDFLAGS="-shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(XPS_SONAME_MAJOR)"
PDL_DYNAMIC_LDFLAGS="-shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(GPDL_SONAME_MAJOR)"
+ PDF_DYNAMIC_LDFLAGS="-shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(PDF_SONAME_MAJOR)"
DYNAMIC_LIBS=""
SO_LIB_EXT=".so"
;;
@@ -11625,6 +11591,7 @@ case $host in
PCL_DYNAMIC_LDFLAGS="-dynamiclib -install_name $DARWIN_LDFLAGS_SO_PREFIX\$(PCL_SONAME_MAJOR_MINOR)"
XPS_DYNAMIC_LDFLAGS="-dynamiclib -install_name $DARWIN_LDFLAGS_SO_PREFIX\$(XPS_SONAME_MAJOR_MINOR)"
PDL_DYNAMIC_LDFLAGS="-dynamiclib -install_name $DARWIN_LDFLAGS_SO_PREFIX\$(GPDL_SONAME_MAJOR_MINOR)"
+ PDF_DYNAMIC_LDFLAGS="-dynamiclib -install_name $DARWIN_LDFLAGS_SO_PREFIX\$(PDF_SONAME_MAJOR_MINOR)"
DYNAMIC_LIBS=""
SO_LIB_EXT=".dylib"
;;
@@ -11644,6 +11611,7 @@ case $host in
PCL_DYNAMIC_LDFLAGS="-G -shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(PCL_SONAME_MAJOR) $_ldflags"
XPS_DYNAMIC_LDFLAGS="-G -shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(XPS_SONAME_MAJOR) $_ldflags"
PDL_DYNAMIC_LDFLAGS="-G -shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(GPDL_SONAME_MAJOR) $_ldflags"
+ PDF_DYNAMIC_LDFLAGS="-G -shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(PDF_SONAME_MAJOR)"
DYNAMIC_LIBS=""
SO_LIB_EXT=".so"
;;
@@ -11655,12 +11623,15 @@ case $host in
PCL_DYNAMIC_LDFLAGS="-shared -Wl,-brtl,-G -fPIC"
XPS_DYNAMIC_LDFLAGS="-shared -Wl,-brtl,-G -fPIC"
PDL_DYNAMIC_LDFLAGS="-shared -Wl,-brtl,-G -fPIC"
+ PDF_DYNAMIC_LDFLAGS="-shared -Wl,-brtl,-G -fPIC"
else
DYNAMIC_CFLAGS="$DYNAMIC_CFLAGS"
GCFLAGS="-Wl,-brtl -D_LARGE_FILES $GCFLAGS"
GS_DYNAMIC_LDFLAGS="-G -qmkshrobj -Wl,-brtl,-G"
PCL_DYNAMIC_LDFLAGS="-G -qmkshrobj -Wl,-brtl,-G"
XPS_DYNAMIC_LDFLAGS="-G -qmkshrobj -Wl,-brtl,-G"
+ PDL_DYNAMIC_LDFLAGS="-G -qmkshrobj -Wl,-brtl,-G"
+ PDF_DYNAMIC_LDFLAGS="-G -qmkshrobj -Wl,-brtl,-G"
fi
SO_LIB_EXT=".so"
;;
@@ -11692,6 +11663,11 @@ fi
+
+
+
+
+
# Check whether --enable-dynamic was given.
if test "${enable_dynamic+set}" = set; then :
enableval=$enable_dynamic;
@@ -11753,6 +11729,7 @@ fi
+
# Check whether --with-fontpath was given.
if test "${with_fontpath+set}" = set; then :
withval=$with_fontpath; fontpath="$withval"
@@ -12319,39 +12296,6 @@ test $ac_cv_func_memcmp_working = no && case " $LIBOBJS " in
esac
-{ $as_echo "$as_me:${as_lineno-$LINENO}: checking return type of signal handlers" >&5
-$as_echo_n "checking return type of signal handlers... " >&6; }
-if ${ac_cv_type_signal+:} false; then :
- $as_echo_n "(cached) " >&6
-else
- cat confdefs.h - <<_ACEOF >conftest.$ac_ext
-/* end confdefs.h. */
-#include <sys/types.h>
-#include <signal.h>
-
-int
-main ()
-{
-return *(signal (0, 0)) (0) == 1;
- ;
- return 0;
-}
-_ACEOF
-if ac_fn_c_try_compile "$LINENO"; then :
- ac_cv_type_signal=int
-else
- ac_cv_type_signal=void
-fi
-rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
-fi
-{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_type_signal" >&5
-$as_echo "$ac_cv_type_signal" >&6; }
-
-cat >>confdefs.h <<_ACEOF
-#define RETSIGTYPE $ac_cv_type_signal
-_ACEOF
-
-
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether lstat correctly handles trailing slash" >&5
$as_echo_n "checking whether lstat correctly handles trailing slash... " >&6; }
if ${ac_cv_func_lstat_dereferences_slashed_symlink+:} false; then :
@@ -12512,48 +12456,50 @@ fi
ALIGN_TEXT_PROG_INCS="\
-#include <stdio.h> \
-#include <stdlib.h>"
+#include <stdio.h>
+#include <stdlib.h>
+"
ALIGN_TEXT_PROG="\
- struct altest \
- { \
- char a; \
- int b; \
- long c; \
- long long d; \
- float e; \
- double f; \
- void *g; \
- }; \
- struct altest *a; \
- struct altest d; \
- char *b, *c, *lim; \
- int ret = 0; \
- c = b = malloc(64 * sizeof(struct altest)); \
- lim = b + (64 * sizeof(struct altest)); \
- do \
- { \
- b++; \
- if ((b >= lim) || \
- ((((unsigned int)b) & 4) == 0 && (((unsigned int)b) & 8) != 0)) \
- { \
- break; \
- } \
- } while(1); \
- if (b >= lim) \
- { \
- ret = -1; \
- } \
- else \
- { \
- a = (struct altest *)b; \
- b = a->g; \
- ret = 0; \
- } \
- free(c); \
- exit(ret);"
+ struct altest
+ {
+ char a;
+ int b;
+ long c;
+ long long d;
+ float e;
+ double f;
+ void *g;
+ };
+ struct altest *a;
+ struct altest d;
+ char *b, *c, *lim;
+ int ret = 0;
+ c = b = malloc(64 * sizeof(struct altest));
+ lim = b + (64 * sizeof(struct altest));
+ do
+ {
+ b++;
+ if ((b >= lim) ||
+ ((((unsigned int)b) & 4) == 0 && (((unsigned int)b) & 8) != 0))
+ {
+ break;
+ }
+ } while(1);
+ if (b >= lim)
+ {
+ ret = -1;
+ }
+ else
+ {
+ a = (struct altest *)b;
+ b = a->g;
+ ret = 0;
+ }
+ free(c);
+ exit(ret);
+"
GS_MEMPTR_ALIGNMENT=
@@ -13688,6 +13634,17 @@ $as_echo "$as_me: WARNING: Due to the --enable-threadsafe option, the following
echo "$NTS_EXCLUDES"
fi
+if test x"$OCR_DEVS_WARNING_LINE1" != x"" ; then
+ echo ""
+ { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $OCR_DEVS_WARNING_LINE1" >&5
+$as_echo "$as_me: WARNING: $OCR_DEVS_WARNING_LINE1" >&2;}
+ if test x"$OCR_DEVS_WARNING_LINE2" != x"" ; then
+ { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: $OCR_DEVS_WARNING_LINE2" >&5
+$as_echo "$as_me: WARNING: $OCR_DEVS_WARNING_LINE2" >&2;}
+ fi
+ echo ""
+fi
+
ac_config_files="$ac_config_files $CONFIG_FILES_LIST"
@@ -13837,7 +13794,6 @@ LTLIBOBJS=$ac_ltlibobjs
-
: "${CONFIG_STATUS=./config.status}"
ac_write_fail=0
ac_clean_files_save=$ac_clean_files
diff --git a/configure.ac b/configure.ac
index 1532609f..36b51f57 100644
--- a/configure.ac
+++ b/configure.ac
@@ -20,7 +20,7 @@ dnl Initialization and Versioning
dnl ------------------------------------------------
AC_INIT
-AC_PREREQ(2.63)
+AC_PREREQ([2.63])
AC_LANG(C)
AC_CONFIG_SRCDIR(psi/gs.c)
@@ -237,11 +237,11 @@ if test x"$host" != x"$build" ; then
fi
fi
-dnl --------------------------------------------------
+dnl --------------------------------------------------
dnl Allow excluding the contributed drivers
dnl --------------------------------------------------
-AC_ARG_ENABLE([contrib], AC_HELP_STRING([--disable-contrib], [Do not include contributed drivers]))
+AC_ARG_ENABLE([contrib], AS_HELP_STRING([--disable-contrib], [Do not include contributed drivers]))
CONTRIBINCLUDE="include $srcdir/contrib/contrib.mak"
INSTALL_CONTRIB="install-contrib-extras"
@@ -356,13 +356,13 @@ else
fi
AC_MSG_CHECKING([if compiler supports restrict])
-AC_TRY_COMPILE([
+AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[
#if defined(__STDC_VERSION__) && __STDC_VERSION__ == 199901L
void test (char * restrict p){}
#else
void test (char * __restrict p){}
#endif
-],[
+]], [[
#if defined(__STDC_VERSION__) && __STDC_VERSION__ == 199901L
char *restrict t;
#else
@@ -370,7 +370,7 @@ void test (char * __restrict p){}
#endif
test(t);
return 1;
- ],[
+ ]])],[
CFLAGS="$CFLAGS -DHAVE_RESTRICT=1"
if test x"$host" = x"$build" ; then
CFLAGSAUX="$CFLAGSAUX -DHAVE_RESTRICT=1"
@@ -384,7 +384,7 @@ void test (char * __restrict p){}
-AC_ARG_WITH([arch_h], AC_HELP_STRING([--with-arch_h=<arch.h to use>],
+AC_ARG_WITH([arch_h], AS_HELP_STRING([--with-arch_h=<arch.h to use>],
[Use a custom arch.h (must be an absolute path)]),[], [with_arch_h=])
ARCH_CONF_HEADER=
@@ -416,7 +416,7 @@ fi
AC_SUBST(ARCH_CONF_HEADER)
# debug configurarion is available by default with "make debug"
-#AC_ARG_ENABLE([debug], AC_HELP_STRING([--enable-debug],
+#AC_ARG_ENABLE([debug], AS_HELP_STRING([--enable-debug],
# [turn on debugging]))
#if test x$enable_debug = xyes; then
# optflags_to_try="-g"
@@ -430,28 +430,28 @@ old_cflags=$CFLAGS
for flag in $optflags_to_try; do
CFLAGS="$CFLAGS $flag"
- AC_TRY_COMPILE(, [return 0;], [
+ AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[return 0;]])],[
echo " $flag"
OPT_CFLAGS="$OPT_CFLAGS $flag"
- ])
+ ],[])
CFLAGS=$old_cflags
done
for flag in $cflags_to_try; do
CFLAGS="$CFLAGS $flag"
- AC_TRY_COMPILE(, [return 0;], [
+ AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[return 0;]])],[
echo " $flag"
GCFLAGS="$GCFLAGS $flag"
- ])
+ ],[])
CFLAGS=$old_cflags
done
old_cflags=$CFLAGS
for flag in $dbgflags_to_try; do
CFLAGS="$CFLAGS $flag"
- AC_TRY_COMPILE(, [return 0;], [
+ AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[return 0;]])],[
echo " $flag"
DBG_CFLAGS="$DBG_CFLAGS $flag"
- ])
+ ],[])
CFLAGS=$old_cflags
done
@@ -459,10 +459,10 @@ CFLAGS_VISIBILITY=""
for flag in $CC_VISIBILITY_FLAGS_TO_TRY; do
CFLAGS="$CFLAGS $flag"
- AC_TRY_COMPILE(, [return 0;], [
+ AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[return 0;]])],[
echo " $flag"
CFLAGS_VISIBILITY="$CFLAGS_VISIBILITY $flag"
- ])
+ ],[])
CFLAGS=$old_cflags
done
@@ -473,7 +473,7 @@ dnl check for sanitize support
dnl ----------------------------
AC_MSG_CHECKING([compiler/linker address santizer support])
-AC_ARG_WITH([sanitizer], AC_HELP_STRING([--with-sanitizer=@<:@address/memory@:>@],
+AC_ARG_WITH([sanitizer], AS_HELP_STRING([--with-sanitizer=@<:@address/memory@:>@],
[Sanitizer for 'sanitize' target (defaults to 'address')]),
[SANITIZER=$with_sanitizer], [SANITIZER=address])
@@ -524,7 +524,9 @@ dnl ----------------------------
dnl check for big/little endian
dnl ----------------------------
-AC_C_BIGENDIAN([BIGENDIAN=1], [BIGENDIAN=0])
+AC_C_BIGENDIAN([BIGENDIAN=1], [BIGENDIAN=0],
+ [AC_MSG_ERROR([Endian status cannot be determined])],
+ [AC_MSG_ERROR([Building of universal binaries is not implemented.])])
dnl --------------------------------------------------
dnl check for sse2 intrinsics
@@ -544,7 +546,7 @@ AC_LINK_IFELSE(
])],
[HAVE_SSE2="-DHAVE_SSE2"], [HAVE_SSE2=""])
-AC_ARG_ENABLE([sse2], AC_HELP_STRING([--disable-sse2],
+AC_ARG_ENABLE([sse2], AS_HELP_STRING([--disable-sse2],
[Do not use sse2 instrinsics]), [
if test "x$enable_sse2" = xno; then
HAVE_SSE2=""
@@ -563,7 +565,7 @@ CFLAGS=$save_cflags
dnl --------------------------------------------------
dnl Enable thread safe build
dnl --------------------------------------------------
-AC_ARG_ENABLE([threadsafe], AC_HELP_STRING([--enable-threadsafe],
+AC_ARG_ENABLE([threadsafe], AS_HELP_STRING([--enable-threadsafe],
[enable a thread safe build - NOTE: this will exclude non-threadsafe devices]))
if test x$enable_threadsafe = xyes ; then
CFLAGS="-DGS_THREADSAFE"
@@ -574,7 +576,6 @@ dnl Check for headers
dnl --------------------------------------------------
AC_HEADER_DIRENT
-AC_HEADER_STDC
AC_CHECK_HEADERS([errno.h fcntl.h limits.h malloc.h memory.h stdlib.h string.h strings.h sys/ioctl.h sys/param.h sys/time.h sys/times.h syslog.h unistd.h dirent.h ndir.h sys/dir.h sys/ndir.h inttypes.h])
dnl --------------------------------------------------
@@ -614,7 +615,6 @@ AC_TYPE_MODE_T
AC_TYPE_OFF_T
AC_TYPE_SIZE_T
AC_STRUCT_ST_BLOCKS
-AC_HEADER_TIME
AC_STRUCT_TM
dnl see if we're on a system that puts the *int*_t types
@@ -632,11 +632,11 @@ dnl the flags we care about
if test "$ac_cv_c_const" != yes; then
GCFLAGS="$GCFLAGS -Dconst="
fi
-if test "x$ac_cv_header_stdint_h" = xyes; then
+if test "x$ac_cv_header_stdint_h" = "xyes"; then
GCFLAGS="$GCFLAGS -DHAVE_STDINT_H=1"
fi
-if test "x$ac_cv_header_dirent_h" = xyes; then
+if test "x$ac_cv_header_dirent_h" = "xyes"; then
GCFLAGS="$GCFLAGS -DHAVE_DIRENT_H=1"
fi
@@ -644,23 +644,23 @@ if test "x$ac_cv_header_ndir_h" = xyes; then
GCFLAGS="$GCFLAGS -DHAVE_NDIR_H=1"
fi
-if test "x$ac_cv_header_sys_dir_h" = xyes; then
+if test "x$ac_cv_header_sys_dir_h" = "xyes"; then
GCFLAGS="$GCFLAGS -DHAVE_SYS_DIR_H=1"
fi
-if test "x$ac_cv_header_sys_ndir_h" = xyes; then
+if test "x$ac_cv_header_sys_ndir_h" = "xyes"; then
GCFLAGS="$GCFLAGS -DHAVE_SYS_NDIR_H=1"
fi
-if test "x$ac_cv_header_sys_time_h" = xyes; then
+if test "x$ac_cv_header_sys_time_h" = "xyes"; then
GCFLAGS="$GCFLAGS -DHAVE_SYS_TIME_H=1"
fi
-if test "x$ac_cv_header_sys_times_h" = xyes; then
+if test "x$ac_cv_header_sys_times_h" = "xyes"; then
GCFLAGS="$GCFLAGS -DHAVE_SYS_TIMES_H=1"
fi
-if test "x$ac_cv_header_inttypes_h" = xyes; then
+if test "x$ac_cv_header_inttypes_h" = "xyes"; then
GCFLAGS="$GCFLAGS -DHAVE_INTTYPES_H=1"
fi
@@ -779,7 +779,7 @@ SYNC="nosync"
PTHREAD_LIBS=""
RECURSIVE_MUTEXATTR=""
-AC_ARG_ENABLE([threading], AC_HELP_STRING([--disable-threading],
+AC_ARG_ENABLE([threading], AS_HELP_STRING([--disable-threading],
[disable support for multithreaded rendering]))
# if you haven't got pread/pwrite, we can't use multithreading
@@ -791,8 +791,7 @@ if test "x$HAVE_PREAD_PWRITE" != "x"; then
PTHREAD_LIBS="-lpthread"
])
AC_MSG_CHECKING([for recursive mutexes])
- AC_TRY_COMPILE([#include <pthread.h>],
- [
+ AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <pthread.h>]], [[
static int k = PTHREAD_MUTEX_RECURSIVE;
#ifndef pthread_mutexattr_settype
#ifdef __cplusplus
@@ -803,11 +802,8 @@ if test "x$HAVE_PREAD_PWRITE" != "x"; then
#endif
;
return 0;
- ],
- [RECURSIVE_MUTEXATTR="-DGS_RECURSIVE_MUTEXATTR=PTHREAD_MUTEX_RECURSIVE"
- mutex_result="PTHREAD_MUTEX_RECURSIVE"],
- [AC_TRY_COMPILE([#include <pthread.h>],
- [
+ ]])],[RECURSIVE_MUTEXATTR="-DGS_RECURSIVE_MUTEXATTR=PTHREAD_MUTEX_RECURSIVE"
+ mutex_result="PTHREAD_MUTEX_RECURSIVE"],[AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <pthread.h>]], [[
static int k = PTHREAD_MUTEX_RECURSIVE_NP;
#ifndef pthread_mutexattr_settype
#ifdef __cplusplus
@@ -818,9 +814,8 @@ if test "x$HAVE_PREAD_PWRITE" != "x"; then
#endif
;
return 0;
- ],
- [RECURSIVE_MUTEXATTR="-DGS_RECURSIVE_MUTEXATTR=PTHREAD_MUTEX_RECURSIVE_NP"
- mutex_result="PTHREAD_MUTEX_RECURSIVE_NP"])])
+ ]])],[RECURSIVE_MUTEXATTR="-DGS_RECURSIVE_MUTEXATTR=PTHREAD_MUTEX_RECURSIVE_NP"
+ mutex_result="PTHREAD_MUTEX_RECURSIVE_NP"],[])])
AC_MSG_RESULT($mutex_result)
fi
fi
@@ -838,7 +833,10 @@ TESSERACTINCLUDE=
TESSERACT_LIBS=
OCR_DEVS=
-AC_ARG_WITH([tesseract], AC_HELP_STRING([--without-tesseract],
+OCR_DEVS_WARNING_LINE1=
+OCR_DEVS_WARNING_LINE2=
+
+AC_ARG_WITH([tesseract], AS_HELP_STRING([--without-tesseract],
[do not try to use the Tesseract library for OCR]))
if test x$with_tesseract != xno; then
@@ -846,10 +844,7 @@ if test x$with_tesseract != xno; then
if test -d $srcdir/tesseract && test -d $srcdir/leptonica; then
AC_MSG_RESULT([yes])
AC_LANG_PUSH(C++)
- AC_TRY_COMPILE([],
- [return 0;],
- [HAVE_CXX_COMPILER=yes; AC_SUBST(CXX)],
- [HAVE_CXX_COMPILER=no])
+ AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[return 0;]])],[HAVE_CXX_COMPILER=yes; AC_SUBST(CXX)],[HAVE_CXX_COMPILER=no])
if test x$HAVE_CXX_COMPILER != xyes; then
AC_MSG_WARN([Disabling tesseract as no working C++ compiler])
elif test x$SYNC = xnosync ; then
@@ -864,127 +859,136 @@ if test x$with_tesseract != xno; then
for flag in $cxxflags_to_try ; do
CXXFLAGS="$CXXFLAGS $flag"
- AC_TRY_COMPILE(, [return 0;], [
+ AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <cstdlib>]], [[return 0;]])],[
echo " $flag"; CXXFLAGS_TO_USE="$CXXFLAGS_TO_USE $flag"
- ])
+ ],[])
CXXFLAGS="$old_cflags"
done
- CXXFLAGS="$save_cxxflags $CXXFLAGS_TO_USE"
-
- dnl --------------------------------------------------
- dnl check for sse4.1, avx, avx2 or fma
- dnl --------------------------------------------------
- AC_MSG_CHECKING([sse4.1 support])
- save_cxxflags=$CXXFLAGS
- TESS_CXXFLAGS="$CXXFLAGS"
- CXXFLAGS="$CXXFLAGS -msse4.1"
-
- TESS_SSE4_1=""
- AC_LINK_IFELSE(
- [AC_LANG_PROGRAM([#include <emmintrin.h>
- #include <smmintrin.h>],
- [__m128i input1;
- unsigned char buf1[[128]];
- input1 = _mm_loadu_si128((const __m128i *)buf1);
- input1 = _mm_hadd_epi32(input1, input1);
- return(0);
- ])],
- [TESS_SSE4_1="-msse4.1"],
- [TESS_SSE4_1=""])
-
- if test "x$TESS_SSE4_1" != x; then
- AC_MSG_RESULT(yes)
- TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_SSE4_1"
- else
- AC_MSG_RESULT(no)
- fi
+ if test x"$GXX" = x"no" || echo $CXXFLAGS_TO_USE | grep "std=c++17" ; then
+ if test x"$GXX" = x"no" ; then
+ OCR_DEVS_WARNING_LINE1="C++ compiler does not appear to be gcc or compatible, attempting to continue anyway"
+ OCR_DEVS_WARNING_LINE2="NOTE: that tesseract requires a C++17 compatible C++ compiler"
+ fi
- AC_MSG_CHECKING([avx support])
- CXXFLAGS="$save_cxxflags -mavx"
+ CXXFLAGS="$save_cxxflags $CXXFLAGS_TO_USE"
+
+ dnl --------------------------------------------------
+ dnl check for sse4.1, avx, avx2 or fma
+ dnl --------------------------------------------------
+ AC_MSG_CHECKING([sse4.1 support])
+ save_cxxflags=$CXXFLAGS
+ TESS_CXXFLAGS="$CXXFLAGS"
+ CXXFLAGS="$CXXFLAGS -msse4.1"
+
+ TESS_SSE4_1=""
+ AC_LINK_IFELSE(
+ [AC_LANG_PROGRAM([#include <emmintrin.h>
+ #include <smmintrin.h>],
+ [__m128i input1;
+ unsigned char buf1[[128]];
+ input1 = _mm_loadu_si128((const __m128i *)buf1);
+ input1 = _mm_hadd_epi32(input1, input1);
+ return(0);
+ ])],
+ [TESS_SSE4_1="-msse4.1"],
+ [TESS_SSE4_1=""])
+
+ if test "x$TESS_SSE4_1" != x; then
+ AC_MSG_RESULT(yes)
+ TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_SSE4_1"
+ else
+ AC_MSG_RESULT(no)
+ fi
- TESS_AVX=""
- AC_LINK_IFELSE(
- [AC_LANG_PROGRAM([#include <immintrin.h>],
- [__m256d input1 = _mm256_setzero_pd();
- input1 = _mm256_hadd_pd(input1, input1);
- return(0);])],
- [TESS_AVX="-mavx"],
- [TESS_AVX=""])
+ AC_MSG_CHECKING([avx support])
+ CXXFLAGS="$save_cxxflags -mavx"
- if test "x$TESS_AVX" != x; then
- AC_MSG_RESULT(yes)
- TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_AVX"
- else
- AC_MSG_RESULT(no)
- fi
+ TESS_AVX=""
+ AC_LINK_IFELSE(
+ [AC_LANG_PROGRAM([#include <immintrin.h>],
+ [__m256d input1 = _mm256_setzero_pd();
+ input1 = _mm256_hadd_pd(input1, input1);
+ return(0);])],
+ [TESS_AVX="-mavx"],
+ [TESS_AVX=""])
- AC_MSG_CHECKING([avx2 support])
- CXXFLAGS="$save_cxxflags -mavx2"
-
- TESS_AVX2=""
- AC_LINK_IFELSE(
- [AC_LANG_PROGRAM([#include <immintrin.h>],
- [__m256i input1;
- unsigned char buf1[[256]];
- input1 = _mm256_loadu_si256((const __m256i *)buf1);
- input1 = _mm256_adds_epu8(input1, input1);
- return(0);])],
- [TESS_AVX2="-mavx2"],
- [TESS_AVX2=""])
-
- if test "x$TESS_AVX2" != x; then
- AC_MSG_RESULT(yes)
- TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_AVX2"
- else
- AC_MSG_RESULT(no)
- fi
+ if test "x$TESS_AVX" != x; then
+ AC_MSG_RESULT(yes)
+ TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_AVX"
+ else
+ AC_MSG_RESULT(no)
+ fi
- AC_MSG_CHECKING([fma support])
- CXXFLAGS="$save_cxxflags -mfma"
+ AC_MSG_CHECKING([avx2 support])
+ CXXFLAGS="$save_cxxflags -mavx2"
+
+ TESS_AVX2=""
+ AC_LINK_IFELSE(
+ [AC_LANG_PROGRAM([#include <immintrin.h>],
+ [__m256i input1;
+ unsigned char buf1[[256]];
+ input1 = _mm256_loadu_si256((const __m256i *)buf1);
+ input1 = _mm256_adds_epu8(input1, input1);
+ return(0);])],
+ [TESS_AVX2="-mavx2"],
+ [TESS_AVX2=""])
+
+ if test "x$TESS_AVX2" != x; then
+ AC_MSG_RESULT(yes)
+ TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_AVX2"
+ else
+ AC_MSG_RESULT(no)
+ fi
- TESS_FMA=""
- AC_LINK_IFELSE(
- [AC_LANG_PROGRAM([#include <immintrin.h>],
- [__m256d input1 = _mm256_setzero_pd();
- input1 = _mm256_fmadd_pd(input1, input1, input1);
- return(0);])],
- [TESS_FMA="-mfma"],
- [TESS_FMA=""])
+ AC_MSG_CHECKING([fma support])
+ CXXFLAGS="$save_cxxflags -mfma"
- if test "x$TESS_FMA" != x; then
- AC_MSG_RESULT(yes)
- TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_FMA"
- else
- AC_MSG_RESULT(no)
- fi
+ TESS_FMA=""
+ AC_LINK_IFELSE(
+ [AC_LANG_PROGRAM([#include <immintrin.h>],
+ [__m256d input1 = _mm256_setzero_pd();
+ input1 = _mm256_fmadd_pd(input1, input1, input1);
+ return(0);])],
+ [TESS_FMA="-mfma"],
+ [TESS_FMA=""])
- AC_MSG_CHECKING([neon support])
- CXXFLAGS="$save_cxxflags -mfpu=neon -mcpu=cortex-a53"
+ if test "x$TESS_FMA" != x; then
+ AC_MSG_RESULT(yes)
+ TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_FMA"
+ else
+ AC_MSG_RESULT(no)
+ fi
- TESS_NEON=""
- AC_LINK_IFELSE(
- [AC_LANG_PROGRAM([#include "arm_neon.h"],
- [int32x4_t round = vdupq_n_s32(10);
- return(0);])],
- [TESS_NEON="-mfpu=neon -mcpu=cortex-a53 -D__ARM_NEON__"],
- [TESS_NEON=""])
+ AC_MSG_CHECKING([neon support])
+ CXXFLAGS="$save_cxxflags -mfpu=neon -mcpu=cortex-a53"
- if test "x$TESS_NEON" != x; then
- AC_MSG_RESULT(yes)
- TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_NEON"
- else
- AC_MSG_RESULT(no)
- fi
+ TESS_NEON=""
+ AC_LINK_IFELSE(
+ [AC_LANG_PROGRAM([#include "arm_neon.h"],
+ [int32x4_t round = vdupq_n_s32(10);
+ return(0);])],
+ [TESS_NEON="-mfpu=neon -mcpu=cortex-a53 -D__ARM_NEON__"],
+ [TESS_NEON=""])
- CXXFLAGS="$save_cxxflags"
+ if test "x$TESS_NEON" != x; then
+ AC_MSG_RESULT(yes)
+ TESS_CXXFLAGS="$TESS_CXXFLAGS -DHAVE_NEON"
+ else
+ AC_MSG_RESULT(no)
+ fi
+
+ CXXFLAGS="$save_cxxflags"
- OCR_VERSION=1
- OCR_DEVS="\$(DD)ocr.dev \$(DD)hocr.dev \$(DD)pdfocr8.dev \$(DD)pdfocr24.dev \$(DD)pdfocr32.dev"
- LEPTONICAINCLUDE="include base/leptonica.mak"
- TESSERACTINCLUDE="include base/tesseract.mak"
- TESSERACT_LIBS="-lstdc++"
+ OCR_VERSION=1
+ OCR_DEVS="\$(DD)ocr.dev \$(DD)hocr.dev \$(DD)pdfocr8.dev \$(DD)pdfocr24.dev \$(DD)pdfocr32.dev"
+ LEPTONICAINCLUDE="include base/leptonica.mak"
+ TESSERACTINCLUDE="include base/tesseract.mak"
+ TESSERACT_LIBS="-lstdc++"
+ else
+ OCR_DEVS_WARNING_LINE1="OCR devices disabled due to incompatible compiler: tesseract requires a C++17 compatible compiler"
+ fi
fi
AC_LANG_POP()
else
@@ -1008,7 +1012,7 @@ AC_SUBST(TESS_CXXFLAGS)
dnl Tests for iconv (Needed for OpenPrinting Vector, "opvp" output device)
AC_ARG_WITH(libiconv,
- [AC_HELP_STRING([--with-libiconv=@<:@no/gnu/native@:>@],
+ [AS_HELP_STRING([--with-libiconv=@<:@no/gnu/native@:>@],
[use the libiconv library])],,
[with_libiconv=maybe])
found_iconv=no
@@ -1051,7 +1055,7 @@ esac
dnl Check for libidn (needed for Unicode password support)
AC_ARG_WITH(libidn,
- [AC_HELP_STRING([--without-libidn],
+ [AS_HELP_STRING([--without-libidn],
[Do not use libidn to support Unicode passwords])],,
[with_libidn=maybe])
@@ -1096,7 +1100,7 @@ AC_SUBST(UTF8DEVS)
dnl Tests for libpaper (to determine system default paper size)
AC_ARG_WITH([libpaper],
- AC_HELP_STRING([--without-libpaper],
+ AS_HELP_STRING([--without-libpaper],
[disable libpaper support]))
if test x$with_libpaper != xno; then
AC_CHECK_LIB(paper, systempapername, [with_libpaper=yes],
@@ -1123,7 +1127,7 @@ dnl Fontconfig support
HAVE_FONTCONFIG=""
FONTCONFIG_CFLAGS=""
FONTCONFIG_LIBS=""
-AC_ARG_ENABLE([fontconfig], AC_HELP_STRING([--disable-fontconfig],
+AC_ARG_ENABLE([fontconfig], AS_HELP_STRING([--disable-fontconfig],
[Do not use fontconfig to list system fonts]))
if test "$enable_fontconfig" != "no"; then
# We MUST NOT use PKG_CHECK_MODULES since it is a) not a standard
@@ -1157,7 +1161,7 @@ dnl DBus support
HAVE_DBUS=""
DBUS_CFLAGS=""
DBUS_LIBS=""
-AC_ARG_ENABLE([dbus], AC_HELP_STRING([--disable-dbus],
+AC_ARG_ENABLE([dbus], AS_HELP_STRING([--disable-dbus],
[Do not use dbus to communicate with external services]))
if test "$enable_dbus" != "no"; then
if test "x$PKGCONFIG" != x; then
@@ -1185,7 +1189,7 @@ AC_SUBST(DBUS_CFLAGS)
AC_SUBST(DBUS_LIBS)
-AC_ARG_ENABLE([freetype], AC_HELP_STRING([--disable-freetype],
+AC_ARG_ENABLE([freetype], AS_HELP_STRING([--disable-freetype],
[Disable freetype for font rasterization]))
FT_BRIDGE=0
@@ -1203,7 +1207,7 @@ FAPIUFST_MAK="\$(GLSRCDIR)\$(D)stub.mak"
if test x"$enable_fapi" != xno; then
dnl UFST detection
- AC_ARG_WITH([ufst], AC_HELP_STRING([--with-ufst=UFST_ROOT_DIR],
+ AC_ARG_WITH([ufst], AS_HELP_STRING([--with-ufst=UFST_ROOT_DIR],
[Use UFST]),
[], [with_ufst=no])
@@ -1396,7 +1400,7 @@ fi
# this option is useful if you're cross-compiling and want to use
# your toolchain's zlib for $host but the local one for $build
-AC_ARG_WITH([local-zlib], AC_HELP_STRING([--without-local-zlib],
+AC_ARG_WITH([local-zlib], AS_HELP_STRING([--without-local-zlib],
[do not check for local zlib sources (has no effect on AUX toolchain when cross-building)]))
AC_MSG_CHECKING([for local zlib source])
@@ -1550,10 +1554,10 @@ AC_SUBST(LCMS2MTDIR)
dnl look for libtiff, it also requires lib
dnl png for the png output device; it also requires zlib
-AC_ARG_WITH([libtiff], AC_HELP_STRING([--without-libtiff],
+AC_ARG_WITH([libtiff], AS_HELP_STRING([--without-libtiff],
[disable use of libtiff]), with_libtiff=no)
-AC_ARG_WITH([system-libtiff], AC_HELP_STRING([--with-system-libtiff],
+AC_ARG_WITH([system-libtiff], AS_HELP_STRING([--with-system-libtiff],
[Force using the systems libtiff]),
[], [with_system_libtiff=check])
@@ -1667,12 +1671,10 @@ fi
CGLAGS_STORE=$CFLAGS
CFLAGS=-Wno-misleading-indentation
-AC_TRY_COMPILE([], [return 0;],
- [CFLAGS_NMI="-Wno-misleading-indentation"],[CFLAGS_NMI=""])
+AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[return 0;]])],[CFLAGS_NMI="-Wno-misleading-indentation"],[CFLAGS_NMI=""])
CFLAGS=-Wno-undef
-AC_TRY_COMPILE([], [return 0;],
- [CFLAGS_NUD="-Wno-undef"],[CFLAGS_NUD=""])
+AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[return 0;]])],[CFLAGS_NUD="-Wno-undef"],[CFLAGS_NUD=""])
CFLAGS=$CGLAGS_STORE
@@ -1682,7 +1684,7 @@ if test x"$SHARE_LIBTIFF" = x"0" ; then
if ! test -d "$LIBTIFFCONFDIR" ; then
mkdir "$LIBTIFFCONFDIR"
fi
- cd "$LIBTIFFCONFDIR" && "$absolute_source_path/$LIBTIFFDIR/configure" --disable-jbig --disable-lzma --disable-zstd --disable-webp $SUBCONFIG_OPTS
+ cd "$LIBTIFFCONFDIR" && "$absolute_source_path/$LIBTIFFDIR/configure" $GS_TIFF_CONFIGURE_OPTS --disable-jbig --disable-lzma --disable-zstd --disable-webp --disable-libdeflate $SUBCONFIG_OPTS
status=$?
if test $status -ne 0 ; then
AC_MSG_ERROR([libtiff configure script failed], $status)
@@ -1753,24 +1755,24 @@ AC_SUBST(EXPAT_CFLAGS)
AC_SUBST(EXPAT_LIBS)
dnl look for CUPS...
-AC_ARG_ENABLE([cups], AC_HELP_STRING([--disable-cups],
+AC_ARG_ENABLE([cups], AS_HELP_STRING([--disable-cups],
[Do not include CUPS support]))
-AC_ARG_WITH([pdftoraster], AC_HELP_STRING([--without-pdftoraster],
+AC_ARG_WITH([pdftoraster], AS_HELP_STRING([--without-pdftoraster],
[Do not include CUPS' pdftoraster filter]))
-AC_ARG_WITH([local-cups], AC_HELP_STRING([--with-local-cups],
+AC_ARG_WITH([local-cups], AS_HELP_STRING([--with-local-cups],
[Force using the GS supplied cups code - only useful for debugging]),
[with_local_cups=yes], [with_local_cups=no])
-AC_ARG_WITH([cups-serverbin], AC_HELP_STRING([--with-cups-serverbin],
+AC_ARG_WITH([cups-serverbin], AS_HELP_STRING([--with-cups-serverbin],
[override the "cups-config --serverbin" path]), CUPS_SERVERBIN="$withval", CUPS_SERVERBIN="")
-AC_ARG_WITH([cups-serverroot], AC_HELP_STRING([--with-cups-serverroot],
+AC_ARG_WITH([cups-serverroot], AS_HELP_STRING([--with-cups-serverroot],
[override the "cups-config --serverroot" path]), CUPS_SERVERROOT="$withval", CUPS_SERVERROOT="")
-AC_ARG_WITH([cups-datadir], AC_HELP_STRING([--with-cups-datadir],
+AC_ARG_WITH([cups-datadir], AS_HELP_STRING([--with-cups-datadir],
[override the "cups-config --datadir" path]), CUPS_DATADIR="$withval", CUPS_DATADIR="")
CUPSDEV=""
@@ -1882,6 +1884,10 @@ if ( test -f $srcdir/cups/gdevcups.c ); then
AC_MSG_WARN([USING LOCAL CUPS SOURCE])
SHARELCUPS=0
SHARELCUPSI=0
+ AC_CHECK_FUNCS([strlcat], [CUPSCFLAGS="$CUPSCFLAGS -DHAVE_STRLCAT=1"], [])
+ AC_CHECK_FUNCS([strlcpy], [CUPSCFLAGS="$CUPSCFLAGS -DHAVE_STRLCPY=1"], [])
+ AC_CHECK_FUNCS([snprintf], [CUPSCFLAGS="$CUPSCFLAGS -DHAVE_SNPRINTF=1"], [])
+ AC_CHECK_FUNCS([vsnprintf], [CUPSCFLAGS="$CUPSCFLAGS -DHAVE_VSNPRINTF=1"], [])
LCUPSBUILDTYPE=linux
LCUPSINCLUDE="include \$(GLSRCDIR)/lcups.mak"
LCUPSIINCLUDE="include \$(GLSRCDIR)/lcupsi.mak"
@@ -1911,7 +1917,7 @@ AC_SUBST(LCUPSIINCLUDE)
AC_SUBST(CUPSPDFTORASTER)
dnl look for IJS implementation
-AC_ARG_WITH([ijs], AC_HELP_STRING([--without-ijs],
+AC_ARG_WITH([ijs], AS_HELP_STRING([--without-ijs],
[disable IJS driver support]))
case $host in
@@ -1963,7 +1969,7 @@ JBIG2DEC_REQ=0.19
if test "x$JBIG2_DECODER" = x; then
dnl look for jbig2dec
- AC_ARG_WITH([jbig2dec], AC_HELP_STRING([--without-jbig2dec],
+ AC_ARG_WITH([jbig2dec], AS_HELP_STRING([--without-jbig2dec],
[disable JBIG2 decode support]))
if test x$with_jbig2dec != xno; then
AC_MSG_CHECKING([for local jbig2dec library source])
@@ -1978,12 +1984,12 @@ if test "x$JBIG2_DECODER" = x; then
for include in sys/types.h inttypes.h sys/inttypes.h sys/int_types.h ; do
AC_MSG_CHECKING([for uint32_t in $include])
- AC_TRY_COMPILE([#include <$include>], [uint32_t canary;], [
+ AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[#include <$include>]], [[uint32_t canary;]])],[
AC_MSG_RESULT([yes])
stdint_types_in="$include"
break;
- ], AC_MSG_RESULT([no])
- )
+ ],[AC_MSG_RESULT(no)
+ ])
done
case "$stdint_types_in" in
@@ -2095,7 +2101,7 @@ fi
AC_CHECK_DECL(lrintf, , [OPJ_LRINTF_SUBST="-D\"lrintf(a)\"=\"((long)(a+0.5))\"]",[[#include <math.h>]])
-AC_ARG_ENABLE([openjpeg], AC_HELP_STRING([--disable-openjpeg],
+AC_ARG_ENABLE([openjpeg], AS_HELP_STRING([--disable-openjpeg],
[Do not use OpenJPEG for JPX decoding]))
OPENJPEGDIR=$srcdir/openjpeg
@@ -2118,7 +2124,7 @@ if test "x$JPX_DECODER" = "x"; then
CFLAGS_old="$CFLAGS"
CFLAGS="-Wno-attributes"
- AC_TRY_COMPILE([], [return 0;], [JPX_AUTOCONF_CFLAGS="$JPX_AUTOCONF_CFLAGS -Wno-attributes"])
+ AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[return 0;]])],[JPX_AUTOCONF_CFLAGS="$JPX_AUTOCONF_CFLAGS -Wno-attributes"],[])
CFLAGS="$CFLAGS_old"
JPX_AUTOCONF_CFLAGS="$JPX_AUTOCONF_CFLAGS -DOPJ_STATIC -DMUTEX_pthread=0 $OPJ_LRINTF_SUBST -DUSE_JPIP -DUSE_OPENJPEG_JP2 $CFLAGS_OPJ_HAVE_STDINT_H $CFLAGS_OPJ_HAVE_INTTYPES_H $CFLAGS_OPJ_BIGENDIAN $CFLAGS_OPJ_HAVE_FSEEKO"
@@ -2165,7 +2171,7 @@ URF_DEVS=''
URF_INCLUDE=
URF_DEV=
SURFX_H=
-AC_ARG_WITH([urf], AC_HELP_STRING([--without-urf],
+AC_ARG_WITH([urf], AS_HELP_STRING([--without-urf],
[do not try to include URF support]))
if test x$with_urf != xno; then
@@ -2187,7 +2193,7 @@ AC_SUBST(URF_INCLUDE)
AC_SUBST(URF_DEV)
AC_SUBST(SURFX_H)
-AC_ARG_WITH([cal], AC_HELP_STRING([--without-cal],
+AC_ARG_WITH([cal], AS_HELP_STRING([--without-cal],
[do not try to use the CAL library for acceleration]))
CALSRCDIR=$srcdir/cal
@@ -2224,7 +2230,7 @@ if test x$WITH_CAL != x0; then
])],
[HAVE_SSE4_2="-DHAVE_SSE4_2"], [HAVE_SSE4_2=""])
- #AC_ARG_ENABLE([sse4.2], AC_HELP_STRING([--disable-sse4.2],
+ #AC_ARG_ENABLE([sse4.2], AS_HELP_STRING([--disable-sse4.2],
# [Do not use sse4.2 instrinsics]), [
# if test "x$enable_sse4.2" = xno; then
# HAVE_SSE4_2=""
@@ -2250,7 +2256,7 @@ if test x$WITH_CAL != x0; then
])],
[HAVE_AVX2="-DHAVE_AVX2"], [HAVE_AVX2=""])
- #AC_ARG_ENABLE([sse4.2], AC_HELP_STRING([--disable-sse4.2],
+ #AC_ARG_ENABLE([sse4.2], AS_HELP_STRING([--disable-sse4.2],
# [Do not use sse4.2 instrinsics]), [
# if test "x$enable_sse4.2" = xno; then
# HAVE_SSE4_2=""
@@ -2272,7 +2278,7 @@ if test x$WITH_CAL != x0; then
])],
[HAVE_NEON="-DHAVE_NEON"], [HAVE_NEON=""])
- #AC_ARG_ENABLE([neon], AC_HELP_STRING([--disable-neon],
+ #AC_ARG_ENABLE([neon], AS_HELP_STRING([--disable-neon],
# [Do not use neon instrinsics]), [
# if test "x$enable_neon" = xno; then
# HAVE_NEON=""
@@ -2311,7 +2317,7 @@ AC_SUBST(CAL_AVX2_CFLAGS)
AC_SUBST(CAL_NEON_CFLAGS)
dnl check if we can/should build the gtk loader
-AC_ARG_ENABLE([gtk], AC_HELP_STRING([--disable-gtk],
+AC_ARG_ENABLE([gtk], AS_HELP_STRING([--disable-gtk],
[Do not build the gtk loader]))
SOC_CFLAGS=""
SOC_LIBS=""
@@ -2417,7 +2423,7 @@ AC_SUBST(X_LIBS)
AC_SUBST(XLIBS)
dnl executible name
-AC_ARG_WITH([gs], AC_HELP_STRING([--with-gs=NAME],
+AC_ARG_WITH([gs], AS_HELP_STRING([--with-gs=NAME],
[name of the Ghostscript executible [[gs]]]),
[GS="$with_gs"],[GS='gs'])
AC_SUBST(GS)
@@ -2433,7 +2439,7 @@ PXL_MAK="\$(GLSRCDIR)\$(D)stub.mak"
if test x"$with_pcl" != x"no" ; then
if test -f $srcdir/pcl/pl/pl.mak; then
- AC_ARG_WITH([pcl], AC_HELP_STRING([--with-pcl=NAME],
+ AC_ARG_WITH([pcl], AS_HELP_STRING([--with-pcl=NAME],
[name of the GhostPCL executible (if the source is available, ignored otherwise) [[gpcl6]]]),
[PCL="$with_pcl"],[PCL='gpcl6'])
@@ -2465,7 +2471,7 @@ XPSROMFS_MAK="\$(GLSRCDIR)\$(D)stub.mak"
if test x"$with_xps" != x"no" ; then
if test x"$PCL_TARGET" != x ; then
if test -f $srcdir/xps/xps.mak; then
- AC_ARG_WITH([xps], AC_HELP_STRING([--with-xps=NAME],
+ AC_ARG_WITH([xps], AS_HELP_STRING([--with-xps=NAME],
[name of the GhostXPS executible (if the source is available, ignored otherwise) [[gxps]]]),
[XPS="$with_xps"],[XPS='gxps'])
@@ -2481,6 +2487,37 @@ AC_SUBST(XPS_TARGET)
AC_SUBST(XPS_MAK)
AC_SUBST(XPSROMFS_MAK)
+GPDF_DEV=
+PDF=
+PDF_MAK="\$(GLSRCDIR)\$(D)stub.mak"
+PDFROMFS_MAK="\$(GLSRCDIR)\$(D)stub.mak"
+
+if test x"$with_pdf" != x"no" ; then
+ if test -f $srcdir/pdf/pdf.mak; then
+ AC_ARG_WITH([pdf], AS_HELP_STRING([--with-pdf=NAME],
+ [name of the Ghostpdf executible (if the source is available, ignored otherwise) [[gpdf]]]),
+ [PDFEXE="$with_pdf"],[PDFEXE='gpdf'])
+
+ if test -f $srcdir/pcl/pl/pl.mak && test x"$PCL_TARGET" != x"" ; then
+ PDF_TARGET=gpdf
+ PDF=$PDFEXE
+ else
+ PDF=no_gpdf
+ fi
+ CFLAGS="-DBUILD_PDF=1 -I$srcdir/pdf $CFLAGS"
+ GPDF_DEV="\$(PDFOBJDIR)\$(D)pdfi.dev"
+ PDF_MAK="\$(PDFSRCDIR)\$(D)pdf.mak"
+ PDFROMFS_MAK="\$(PDFSRCDIR)\$(D)pdfromfs.mak"
+ fi
+fi
+AC_SUBST(PDF)
+AC_SUBST(PDF_TARGET)
+
+AC_SUBST(PDF_MAK)
+AC_SUBST(GPDF_DEV)
+AC_SUBST(PDFROMFS_MAK)
+
+
GPDL=no_gpdl
GPDL_TARGET=
GPDL_TARGET_VAR=
@@ -2490,7 +2527,7 @@ GPDL_MAK="\$(GLSRCDIR)\$(D)stub.mak"
if test "x$XPS_TARGET" != "x" && test "x$PCL_TARGET" != "x" ; then
if test -f $srcdir/gpdl/gpdl.mak; then
- AC_ARG_WITH([gpdl], AC_HELP_STRING([--with-gpdl=NAME],
+ AC_ARG_WITH([gpdl], AS_HELP_STRING([--with-gpdl=NAME],
[name of the GhostPDL executible (if the source is available, ignored otherwise) [[gpdl]]]),
[GPDL="$with_gpdl"],[GPDL='gpdl'])
@@ -2505,7 +2542,7 @@ AC_SUBST(GPDL_MAK)
dnl do we compile the postscript initialization files into Ghostscript?
COMPILE_INITS="1"
-AC_ARG_ENABLE([compile-inits], AC_HELP_STRING([--disable-compile-inits],
+AC_ARG_ENABLE([compile-inits], AS_HELP_STRING([--disable-compile-inits],
[Do not compile in initialization files]),[
if test "x$enable_compile_inits" = xno; then
COMPILE_INITS="0"
@@ -2601,7 +2638,9 @@ PS_DEVS='psdf psdcmyk psdrgb psdcmyk16 psdrgb16 pdfwrite ps2write eps2write bbox
# device.
#
AC_ARG_WITH([extract-dir],
- AC_HELP_STRING([--with-extract-dir=EXTRACT_DIR]),
+ AS_HELP_STRING([--with-extract-dir=EXTRACT_DIR],
+ [Build with the specified Extract library. By default we build with Extract automatically if <ghostpdl-directory>/extract exists.]
+ ),
[
EXTRACT_DIR="$withval"
AS_IF([test x"$EXTRACT_DIR" != x"no"],
@@ -2894,6 +2933,11 @@ PCL_SONAME_MAJOR_MINOR="lib\$(PCL${libname3}"
XPS_SONAME="lib\$(XPS${libname1}"
XPS_SONAME_MAJOR="lib\$(XPS${libname2}"
XPS_SONAME_MAJOR_MINOR="lib\$(XPS${libname3}"
+
+PDF_SONAME="lib\$(PDF${libname1}"
+PDF_SONAME_MAJOR="lib\$(PDF${libname2}"
+PDF_SONAME_MAJOR_MINOR="lib\$(PDF${libname3}"
+
GPDL_SONAME="lib\$(GPDL${libname1}"
GPDL_SONAME_MAJOR="lib\$(GPDL${libname2}"
GPDL_SONAME_MAJOR_MINOR="lib\$(GPDL${libname3}"
@@ -2904,7 +2948,7 @@ attr_hidden=
_ldflags=
AC_ARG_ENABLE([hidden-visibility],
- AC_HELP_STRING([--enable-hidden-visibility],
+ AS_HELP_STRING([--enable-hidden-visibility],
[hide all shared library symbols which are not part of its public API]),
[hide_symbols=yes])
@@ -2920,6 +2964,7 @@ case $host in
PCL_DYNAMIC_LDFLAGS="-shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(PCL_SONAME_MAJOR)"
XPS_DYNAMIC_LDFLAGS="-shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(XPS_SONAME_MAJOR)"
PDL_DYNAMIC_LDFLAGS="-shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(GPDL_SONAME_MAJOR)"
+ PDF_DYNAMIC_LDFLAGS="-shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(PDF_SONAME_MAJOR)"
if test $GCC = yes; then
# GCC high level flag
DYNAMIC_LIBS="-rdynamic"
@@ -2953,6 +2998,9 @@ case $host in
XPS_SONAME="lib\$(XPS${libname1}"
XPS_SONAME_MAJOR="lib\$(XPS${libname3}"
XPS_SONAME_MAJOR_MINOR="lib\$(XPS${libname2}"
+ PDF_SONAME="lib\$(PDF${libname1}"
+ PDF_SONAME_MAJOR="lib\$(PDF${libname3}"
+ PDF_SONAME_MAJOR_MINOR="lib\$(PDF${libname2}"
GPDL_SONAME="lib\$(GPDL${libname1}"
GPDL_SONAME_MAJOR="lib\$(GPDL${libname3}"
GPDL_SONAME_MAJOR_MINOR="lib\$(GPDL${libname2}"
@@ -2989,6 +3037,7 @@ case $host in
PCL_DYNAMIC_LDFLAGS="-shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(PCL_SONAME_MAJOR)"
XPS_DYNAMIC_LDFLAGS="-shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(XPS_SONAME_MAJOR)"
PDL_DYNAMIC_LDFLAGS="-shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(GPDL_SONAME_MAJOR)"
+ PDF_DYNAMIC_LDFLAGS="-shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(PDF_SONAME_MAJOR)"
DYNAMIC_LIBS=""
SO_LIB_EXT=".so"
;;
@@ -2998,6 +3047,7 @@ case $host in
PCL_DYNAMIC_LDFLAGS="-dynamiclib -install_name $DARWIN_LDFLAGS_SO_PREFIX\$(PCL_SONAME_MAJOR_MINOR)"
XPS_DYNAMIC_LDFLAGS="-dynamiclib -install_name $DARWIN_LDFLAGS_SO_PREFIX\$(XPS_SONAME_MAJOR_MINOR)"
PDL_DYNAMIC_LDFLAGS="-dynamiclib -install_name $DARWIN_LDFLAGS_SO_PREFIX\$(GPDL_SONAME_MAJOR_MINOR)"
+ PDF_DYNAMIC_LDFLAGS="-dynamiclib -install_name $DARWIN_LDFLAGS_SO_PREFIX\$(PDF_SONAME_MAJOR_MINOR)"
DYNAMIC_LIBS=""
SO_LIB_EXT=".dylib"
;;
@@ -3017,6 +3067,7 @@ case $host in
PCL_DYNAMIC_LDFLAGS="-G -shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(PCL_SONAME_MAJOR) $_ldflags"
XPS_DYNAMIC_LDFLAGS="-G -shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(XPS_SONAME_MAJOR) $_ldflags"
PDL_DYNAMIC_LDFLAGS="-G -shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(GPDL_SONAME_MAJOR) $_ldflags"
+ PDF_DYNAMIC_LDFLAGS="-G -shared -Wl,\$(LD_SET_DT_SONAME)\$(LDFLAGS_SO_PREFIX)\$(PDF_SONAME_MAJOR)"
DYNAMIC_LIBS=""
SO_LIB_EXT=".so"
;;
@@ -3028,12 +3079,15 @@ case $host in
PCL_DYNAMIC_LDFLAGS="-shared -Wl,-brtl,-G -fPIC"
XPS_DYNAMIC_LDFLAGS="-shared -Wl,-brtl,-G -fPIC"
PDL_DYNAMIC_LDFLAGS="-shared -Wl,-brtl,-G -fPIC"
+ PDF_DYNAMIC_LDFLAGS="-shared -Wl,-brtl,-G -fPIC"
else
DYNAMIC_CFLAGS="$DYNAMIC_CFLAGS"
GCFLAGS="-Wl,-brtl -D_LARGE_FILES $GCFLAGS"
GS_DYNAMIC_LDFLAGS="-G -qmkshrobj -Wl,-brtl,-G"
PCL_DYNAMIC_LDFLAGS="-G -qmkshrobj -Wl,-brtl,-G"
XPS_DYNAMIC_LDFLAGS="-G -qmkshrobj -Wl,-brtl,-G"
+ PDL_DYNAMIC_LDFLAGS="-G -qmkshrobj -Wl,-brtl,-G"
+ PDF_DYNAMIC_LDFLAGS="-G -qmkshrobj -Wl,-brtl,-G"
fi
SO_LIB_EXT=".so"
;;
@@ -3061,11 +3115,16 @@ AC_SUBST(PCL_SONAME_MAJOR_MINOR)
AC_SUBST(XPS_SONAME)
AC_SUBST(XPS_SONAME_MAJOR)
AC_SUBST(XPS_SONAME_MAJOR_MINOR)
+
+AC_SUBST(PDF_SONAME)
+AC_SUBST(PDF_SONAME_MAJOR)
+AC_SUBST(PDF_SONAME_MAJOR_MINOR)
+
AC_SUBST(GPDL_SONAME)
AC_SUBST(GPDL_SONAME_MAJOR)
AC_SUBST(GPDL_SONAME_MAJOR_MINOR)
-AC_ARG_ENABLE([dynamic], AC_HELP_STRING([--enable-dynamic],
+AC_ARG_ENABLE([dynamic], AS_HELP_STRING([--enable-dynamic],
[Enable dynamically loaded drivers]),
[
if test "x$enable_dynamic" != xno; then
@@ -3116,6 +3175,7 @@ AC_SUBST(GS_DYNAMIC_LDFLAGS)
AC_SUBST(PCL_DYNAMIC_LDFLAGS)
AC_SUBST(XPS_DYNAMIC_LDFLAGS)
AC_SUBST(PDL_DYNAMIC_LDFLAGS)
+AC_SUBST(PDF_DYNAMIC_LDFLAGS)
AC_SUBST(DYNAMIC_LIBS)
AC_SUBST(INSTALL_SHARED)
AC_SUBST(X11_DEVS)
@@ -3124,7 +3184,7 @@ AC_SUBST(DLL_EXT)
AC_SUBST(SO_LIB_VERSION_SEPARATOR)
dnl look for default font path...
-AC_ARG_WITH([fontpath], AC_HELP_STRING([--with-fontpath],
+AC_ARG_WITH([fontpath], AS_HELP_STRING([--with-fontpath],
[set font search path for gs]), fontpath="$withval", fontpath="")
dnl Fix "prefix" variable...
@@ -3160,7 +3220,7 @@ fi
AC_SUBST(fontpath)
dnl look for default tessdata...
-AC_ARG_WITH([tessdata], AC_HELP_STRING([--with-tessdata],
+AC_ARG_WITH([tessdata], AS_HELP_STRING([--with-tessdata],
[set tesseract data search path]), tessdata="$withval", tessdata="")
if test "x$tessdata" = "x"; then
@@ -3207,7 +3267,6 @@ dnl of these functions, so the checks are purely informational.
AC_FUNC_FORK
AC_FUNC_MALLOC
AC_FUNC_MEMCMP
-AC_TYPE_SIGNAL
AC_FUNC_STAT
AC_FUNC_VPRINTF
AC_CHECK_FUNCS([bzero dup2 floor gettimeofday memchr memmove memset mkdir mkfifo modf pow putenv rint setenv sqrt strchr strrchr strspn strstr])
@@ -3241,54 +3300,56 @@ dnl set memory manager's ptr alignment
dnl --------------------------------------------------
ALIGN_TEXT_PROG_INCS="\
-#include <stdio.h> \
-#include <stdlib.h>"
+#include <stdio.h>
+#include <stdlib.h>
+"
ALIGN_TEXT_PROG="\
- struct altest \
- { \
- char a; \
- int b; \
- long c; \
- long long d; \
- float e; \
- double f; \
- void *g; \
- }; \
- struct altest *a; \
- struct altest d; \
- char *b, *c, *lim; \
- int ret = 0; \
- c = b = malloc(64 * sizeof(struct altest)); \
- lim = b + (64 * sizeof(struct altest)); \
- do \
- { \
- b++; \
- if ((b >= lim) || \
- ((((unsigned int)b) & 4) == 0 && (((unsigned int)b) & 8) != 0)) \
- { \
- break; \
- } \
- } while(1); \
- if (b >= lim) \
- { \
- ret = -1; \
- } \
- else \
- { \
- a = (struct altest *)b; \
- b = a->g; \
- ret = 0; \
- } \
- free(c); \
- exit(ret);"
+ struct altest
+ {
+ char a;
+ int b;
+ long c;
+ long long d;
+ float e;
+ double f;
+ void *g;
+ };
+ struct altest *a;
+ struct altest d;
+ char *b, *c, *lim;
+ int ret = 0;
+ c = b = malloc(64 * sizeof(struct altest));
+ lim = b + (64 * sizeof(struct altest));
+ do
+ {
+ b++;
+ if ((b >= lim) ||
+ ((((unsigned int)b) & 4) == 0 && (((unsigned int)b) & 8) != 0))
+ {
+ break;
+ }
+ } while(1);
+ if (b >= lim)
+ {
+ ret = -1;
+ }
+ else
+ {
+ a = (struct altest *)b;
+ b = a->g;
+ ret = 0;
+ }
+ free(c);
+ exit(ret);
+"
GS_MEMPTR_ALIGNMENT=
AC_ARG_WITH(memory-alignment,
- [AC_HELP_STRING([--with-memory-alignment],
+ [AS_HELP_STRING([--with-memory-alignment],
[Allows setting minimum alignment for the memory manager (4 or 8 bytes]))],
[GS_MEMPTR_ALIGNMENT=$with_memory_alignment],[GS_MEMPTR_ALIGNMENT=check])
@@ -3356,7 +3417,7 @@ AC_LINK_IFELSE(
])],
[HAVE_BSWAP32="-DHAVE_BSWAP32"], [HAVE_BSWAP32=""])
-AC_ARG_ENABLE([bswap32], AC_HELP_STRING([--disable-bswap32],
+AC_ARG_ENABLE([bswap32], AS_HELP_STRING([--disable-bswap32],
[Do not use bswap32 instrinsic]), [
if test "x$enable_bswap32" = xno; then
HAVE_BSWAP32=""
@@ -3384,7 +3445,7 @@ AC_COMPILE_IFELSE(
])],
[HAVE_BYTESWAP_H="-DHAVE_BYTESWAP_H"], [HAVE_BYTESWAP_H=""])
-AC_ARG_ENABLE([byteswap-h], AC_HELP_STRING([--disable-byteswap-h],
+AC_ARG_ENABLE([byteswap-h], AS_HELP_STRING([--disable-byteswap-h],
[Do not use byteswap.h functions]), [
if test "x$enable_byteswap-h" = xno; then
HAVE_BYTESWAP_H=""
@@ -3403,7 +3464,7 @@ AC_SUBST(HAVE_BYTESWAP_H)
# feature set of GNU make. We still prefer GNU make,
# but......
# --------------------------------------------------
-AC_ARG_WITH([gnu-make], AC_HELP_STRING([--without-gnu-make],
+AC_ARG_WITH([gnu-make], AS_HELP_STRING([--without-gnu-make],
[disable GNU make features]), gnu_make=no)
if test "x$gnu_make" != "xno"; then
@@ -3444,7 +3505,7 @@ case $host in
;;
esac
-AC_ARG_WITH([exe-ext], AC_HELP_STRING([--with-exe-ext=EXT],
+AC_ARG_WITH([exe-ext], AS_HELP_STRING([--with-exe-ext=EXT],
[set the file name executable extension (must include any separator e.g. the period in ".exe")]),
[EXEEXT="$with_exe_ext"])
@@ -3464,7 +3525,7 @@ case $build in
;;
esac
-AC_ARG_WITH([aux-exe-ext], AC_HELP_STRING([--with-aux-exe-ext=EXT],
+AC_ARG_WITH([aux-exe-ext], AS_HELP_STRING([--with-aux-exe-ext=EXT],
[set the file name executable extension for auxiliary binaries (must include any separator e.g. the period in ".exe")]),
[AUXEXEEXT="$with_aux_exe_ext"])
@@ -3503,13 +3564,13 @@ if test $GCC = yes; then
CFLAGS_backup="$CFLAGS"
CFLAGSAUX_backup="$CFLAGSAUX"
CFLAGS="$CFLAGS -fno-strict-aliasing"
- AC_TRY_COMPILE(, [return 0;], [
+ AC_COMPILE_IFELSE([AC_LANG_PROGRAM([[]], [[return 0;]])],[
AC_MSG_RESULT([yes])
CFLAGS_backup="$CFLAGS"
if test x"$host" = x"$build" ; then
CFLAGSAUX_backup="$CFLAGSAUX -fno-strict-aliasing"
fi
- ])
+ ],[])
CFLAGS="$CFLAGS_backup"
CFLAGSAUX="$CFLAGSAUX_backup"
fi
@@ -3654,7 +3715,7 @@ fi
dnl --------------------------------------------------
dnl AUX tool options
dnl --------------------------------------------------
-AC_ARG_ENABLE([mkromfs-quiet], AC_HELP_STRING([--enable-mkromfs-quiet],
+AC_ARG_ENABLE([mkromfs-quiet], AS_HELP_STRING([--enable-mkromfs-quiet],
[Do not emit mkromfs verbose output]), [MKROMFS_FLAGS="-q $MKROMFS_FLAGS"])
AC_SUBST(MKROMFS_FLAGS)
@@ -3706,6 +3767,15 @@ if test "x$NTS_EXCLUDES" != "x" ; then
echo "$NTS_EXCLUDES"
fi
+if test x"$OCR_DEVS_WARNING_LINE1" != x"" ; then
+ echo ""
+ AC_MSG_WARN([$OCR_DEVS_WARNING_LINE1])
+ if test x"$OCR_DEVS_WARNING_LINE2" != x"" ; then
+ AC_MSG_WARN([$OCR_DEVS_WARNING_LINE2])
+ fi
+ echo ""
+fi
+
AC_CONFIG_FILES($CONFIG_FILES_LIST)
AC_OUTPUT
diff --git a/contrib/eplaser/gdevescv.c b/contrib/eplaser/gdevescv.c
index c7bd29e1..4150e81f 100644
--- a/contrib/eplaser/gdevescv.c
+++ b/contrib/eplaser/gdevescv.c
@@ -35,40 +35,10 @@
#include <stdlib.h> /* for abs() and free */
-/* Get this definition in before we read memento.h */
-static void
-unvectored_free(void *x)
-{
- free(x);
-}
-
-#if ( 6 > GS_VERSION_MAJOR )
-
-#include <string.h>
-#include <sys/utsname.h> /* for uname(2) */
-#include <ctype.h> /* for toupper(3) */
-
-#include "math_.h"
-#include "gx.h"
-#include "gserrors.h"
-#include "gsmatrix.h"
-#include "gsparam.h"
-#include "gxdevice.h"
-#include "gscspace.h"
-#include "gsutil.h"
-#include "gdevvec.h"
-#include "gdevpstr.h"
-#include "ghost.h"
-#include "gzstate.h"
-
-#include "gdevescv.h"
-#include "gspath.h"
-#include "gzpath.h"
-
-#else /* 6 <= GS_VERSION_MAJOR */
-
#include "math_.h"
+#ifndef _WIN32
#include <sys/utsname.h> /* for uname(2) */
+#endif
#include <ctype.h> /* for toupper(3) */
#include "time_.h"
@@ -79,14 +49,10 @@ unvectored_free(void *x)
#include "gxdevice.h"
#include "gdevvec.h"
-#if ( 7 >= GS_VERSION_MAJOR )
#include "gscspace.h"
-#endif
#include "gdevescv.h"
-#endif /* GS_VERSION_MAJOR */
-
#define ESCV_FORCEDRAWPATH 0 /* 0: correct LP-9200C path trouble. */
/* ---------------- Device definition ---------------- */
@@ -100,7 +66,7 @@ static dev_proc_copy_color(escv_copy_color);
static dev_proc_put_params(escv_put_params);
static dev_proc_get_params(escv_get_params);
static dev_proc_fill_mask(escv_fill_mask);
-static dev_proc_begin_image(escv_begin_image);
+static dev_proc_begin_typed_image(escv_begin_typed_image);
gs_public_st_suffix_add0_final(st_device_escv, gx_device_escv,
"gx_device_escv", device_escv_enum_ptrs, device_escv_reloc_ptrs,
@@ -110,18 +76,18 @@ gs_public_st_suffix_add0_final(st_device_escv, gx_device_escv,
** ͤ 0 Ȥ,׻꤫襨ꥢ
** 0.001 ȤƤ
*/
-#define escv_device_full_body(dtype, pprocs, dname, stype, w, h, xdpi, ydpi, \
+#define escv_device_full_body(dtype, init, dname, stype, w, h, xdpi, ydpi, \
ncomp, depth, mg, mc, dg, dc, lm, bm, rm, tm)\
- std_device_part1_(dtype, pprocs, dname, stype, open_init_closed),\
+ std_device_part1_(dtype, init, dname, stype, open_init_closed),\
dci_values(ncomp, depth, mg, mc, dg, dc),\
std_device_part2_(w, h, xdpi, ydpi),\
offset_margin_values(0.001, 0.001, lm, 0, 0, tm),\
std_device_part3_()
/* for ESC/Page (Monochrome) */
-#define esmv_device_full_body(dtype, pprocs, dname, stype, w, h, xdpi, ydpi, \
+#define esmv_device_full_body(dtype, init, dname, stype, w, h, xdpi, ydpi, \
ncomp, depth, mg, mc, dg, dc, lm, bm, rm, tm)\
- std_device_part1_(dtype, pprocs, dname, stype, open_init_closed),\
+ std_device_part1_(dtype, init, dname, stype, open_init_closed),\
dci_values(ncomp, depth, mg, mc, dg, dc),\
std_device_part2_(w, h, xdpi, ydpi),\
offset_margin_values(-lm * xdpi / 72.0, -tm * ydpi / 72.0, 5.0 / (MMETER_PER_INCH / POINT),\
@@ -129,83 +95,80 @@ gs_public_st_suffix_add0_final(st_device_escv, gx_device_escv,
std_device_part3_()
/* for ESC/Page-Color */
-#define escv_device_body(name) \
- escv_device_full_body(gx_device_escv, 0, name, \
- &st_device_escv,\
-/* width & height */ ESCPAGE_DEFAULT_WIDTH, ESCPAGE_DEFAULT_HEIGHT,\
-/* default resolution */ X_DPI, Y_DPI,\
-/* color info */ 3, 24, 255, 255, 256, 256,\
- ESCPAGE_LEFT_MARGIN_DEFAULT,\
- ESCPAGE_BOTTOM_MARGIN_DEFAULT,\
- ESCPAGE_RIGHT_MARGIN_DEFAULT,\
- ESCPAGE_TOP_MARGIN_DEFAULT)
+#define escv_device_body(name) \
+{\
+ escv_device_full_body(gx_device_escv, escv_initialize_device_procs,\
+ name, &st_device_escv,\
+/* width & height */ ESCPAGE_DEFAULT_WIDTH, ESCPAGE_DEFAULT_HEIGHT,\
+/* default resolution */X_DPI, Y_DPI,\
+/* color info */ 3, 24, 255, 255, 256, 256,\
+ ESCPAGE_LEFT_MARGIN_DEFAULT,\
+ ESCPAGE_BOTTOM_MARGIN_DEFAULT,\
+ ESCPAGE_RIGHT_MARGIN_DEFAULT,\
+ ESCPAGE_TOP_MARGIN_DEFAULT),\
+ { 0 },\
+ escv_init_code\
+}
/* for ESC/Page (Monochrome) */
-#define esmv_device_body(name) \
- esmv_device_full_body(gx_device_escv, 0, name, \
- &st_device_escv,\
-/* width & height */ ESCPAGE_DEFAULT_WIDTH, ESCPAGE_DEFAULT_HEIGHT,\
-/* default resolution */ X_DPI, Y_DPI,\
-/* color info */ 1, 8, 255, 255, 256, 256,\
- ESCPAGE_LEFT_MARGIN_DEFAULT,\
- ESCPAGE_BOTTOM_MARGIN_DEFAULT,\
- ESCPAGE_RIGHT_MARGIN_DEFAULT,\
- ESCPAGE_TOP_MARGIN_DEFAULT)
-
-#define escv_procs_part1 \
- escv_open, /* open_device */\
- gx_default_get_initial_matrix, /* get_initial_matrix */\
- NULL, /* sync_output */\
- escv_output_page, /* output_page */\
- escv_close /* close_device */
-
-#define escv_procs_part2 \
- gdev_vector_fill_rectangle, /* fill_rectangle */\
- NULL, /* tile_rectangle */\
- escv_copy_mono, /* dev_t_proc_copy_mono */\
- escv_copy_color, /* dev_t_proc_copy_color */\
- NULL, /* draw_line */\
- NULL, /* get_bits */\
- escv_get_params, /* dev_t_proc_get_params */\
- escv_put_params, /* dev_t_proc_put_params */\
- NULL, /* map_cmyk_color */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- gx_page_device_get_page_device, /* dev_t_proc_get_page_device */\
- NULL, /* get_alpha_bits */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- gdev_vector_fill_path, /* fill_path */\
- gdev_vector_stroke_path, /* stroke_path */\
- escv_fill_mask, /* fill_mask */\
- gdev_vector_fill_trapezoid, /* fill_trapezoid */\
- gdev_vector_fill_parallelogram, /* fill_parallelogram */\
- gdev_vector_fill_triangle, /* fill_triangle */\
- NULL, /****** WRONG ******/ /* draw_thin_line */\
- escv_begin_image, /* begin_image */\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL /******strip_copy_rop******/
+#define esmv_device_body(name) \
+{\
+ esmv_device_full_body(gx_device_escv, esmv_initialize_device_procs,\
+ name, &st_device_escv,\
+/* width & height */ ESCPAGE_DEFAULT_WIDTH, ESCPAGE_DEFAULT_HEIGHT,\
+/* default resolution */X_DPI, Y_DPI,\
+/* color info */ 1, 8, 255, 255, 256, 256,\
+ ESCPAGE_LEFT_MARGIN_DEFAULT,\
+ ESCPAGE_BOTTOM_MARGIN_DEFAULT,\
+ ESCPAGE_RIGHT_MARGIN_DEFAULT,\
+ ESCPAGE_TOP_MARGIN_DEFAULT),\
+ { 0 },\
+ esmv_init_code\
+}
+
+static void
+esc_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, escv_open);
+ set_dev_proc(dev, output_page, escv_output_page);
+ set_dev_proc(dev, close_device, escv_close);
+ set_dev_proc(dev, fill_rectangle, gdev_vector_fill_rectangle);
+ set_dev_proc(dev, copy_mono, escv_copy_mono);
+ set_dev_proc(dev, copy_color, escv_copy_color);
+ set_dev_proc(dev, get_params, escv_get_params);
+ set_dev_proc(dev, put_params, escv_put_params);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
+ set_dev_proc(dev, fill_path, gdev_vector_fill_path);
+ set_dev_proc(dev, stroke_path, gdev_vector_stroke_path);
+ set_dev_proc(dev, fill_mask, escv_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, gdev_vector_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, gdev_vector_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, gdev_vector_fill_triangle);
+ set_dev_proc(dev, begin_typed_image, escv_begin_typed_image);
+}
/* for ESC/Page-Color */
-#define escv_procs \
-{\
- escv_procs_part1,\
- gx_default_rgb_map_rgb_color, /* map_rgb_color */\
- gx_default_rgb_map_color_rgb, /* map_color_rgb */\
- escv_procs_part2\
+static void
+escv_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, map_rgb_color, gx_default_rgb_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_default_rgb_map_color_rgb);
+ set_dev_proc(dev, encode_color, gx_default_rgb_map_rgb_color);
+ set_dev_proc(dev, decode_color, gx_default_rgb_map_color_rgb);
+
+ esc_initialize_device_procs(dev);
}
/* for ESC/Page (Monochrome) */
-#define esmv_procs \
-{\
- escv_procs_part1,\
- gx_default_gray_map_rgb_color, /* map_rgb_color */\
- gx_default_gray_map_color_rgb, /* map_color_rgb */\
- escv_procs_part2\
+static void
+esmv_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, map_rgb_color, gx_default_gray_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_default_gray_map_color_rgb);
+ set_dev_proc(dev, encode_color, gx_default_gray_encode_color);
+ set_dev_proc(dev, decode_color, gx_default_gray_decode_color);
+
+ esc_initialize_device_procs(dev);
}
#define escv_init_code_common \
@@ -279,94 +242,62 @@ gs_public_st_suffix_add0_final(st_device_escv, gx_device_escv,
escv_init_code_common
/* for ESC/Page (Monochrome) */
-gx_device_escv far_data gs_epl2050_device ={esmv_device_body("epl2050"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_epl2050p_device={esmv_device_body("epl2050p"),esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_epl2120_device ={esmv_device_body("epl2120"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_epl2500_device ={esmv_device_body("epl2500"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_epl2750_device ={esmv_device_body("epl2750"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_epl5800_device ={esmv_device_body("epl5800"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_epl5900_device ={esmv_device_body("epl5900"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_epl6100_device ={esmv_device_body("epl6100"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_epl6200_device ={esmv_device_body("epl6200"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp1800_device ={esmv_device_body("lp1800"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp1900_device ={esmv_device_body("lp1900"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp2200_device ={esmv_device_body("lp2200"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp2400_device ={esmv_device_body("lp2400"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp2500_device ={esmv_device_body("lp2500"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp7500_device ={esmv_device_body("lp7500"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp7700_device ={esmv_device_body("lp7700"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp7900_device ={esmv_device_body("lp7900"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp8100_device ={esmv_device_body("lp8100"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp8300f_device ={esmv_device_body("lp8300f"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp8400f_device ={esmv_device_body("lp8400f"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp8600_device ={esmv_device_body("lp8600"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp8600f_device ={esmv_device_body("lp8600f"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp8700_device ={esmv_device_body("lp8700"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp8900_device ={esmv_device_body("lp8900"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp9000b_device ={esmv_device_body("lp9000b"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp9100_device ={esmv_device_body("lp9100"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp9200b_device ={esmv_device_body("lp9200b"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp9300_device ={esmv_device_body("lp9300"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp9400_device ={esmv_device_body("lp9400"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp9600_device ={esmv_device_body("lp9600"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lp9600s_device ={esmv_device_body("lp9600s"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_lps4500_device ={esmv_device_body("lps4500"), esmv_procs, esmv_init_code};
-gx_device_escv far_data gs_eplmono_device ={esmv_device_body(ESCPAGE_DEVICENAME_MONO), esmv_procs, esmv_init_code};
+gx_device_escv far_data gs_epl2050_device = esmv_device_body("epl2050");
+gx_device_escv far_data gs_epl2050p_device= esmv_device_body("epl2050p");
+gx_device_escv far_data gs_epl2120_device = esmv_device_body("epl2120");
+gx_device_escv far_data gs_epl2500_device = esmv_device_body("epl2500");
+gx_device_escv far_data gs_epl2750_device = esmv_device_body("epl2750");
+gx_device_escv far_data gs_epl5800_device = esmv_device_body("epl5800");
+gx_device_escv far_data gs_epl5900_device = esmv_device_body("epl5900");
+gx_device_escv far_data gs_epl6100_device = esmv_device_body("epl6100");
+gx_device_escv far_data gs_epl6200_device = esmv_device_body("epl6200");
+gx_device_escv far_data gs_lp1800_device = esmv_device_body("lp1800");
+gx_device_escv far_data gs_lp1900_device = esmv_device_body("lp1900");
+gx_device_escv far_data gs_lp2200_device = esmv_device_body("lp2200");
+gx_device_escv far_data gs_lp2400_device = esmv_device_body("lp2400");
+gx_device_escv far_data gs_lp2500_device = esmv_device_body("lp2500");
+gx_device_escv far_data gs_lp7500_device = esmv_device_body("lp7500");
+gx_device_escv far_data gs_lp7700_device = esmv_device_body("lp7700");
+gx_device_escv far_data gs_lp7900_device = esmv_device_body("lp7900");
+gx_device_escv far_data gs_lp8100_device = esmv_device_body("lp8100");
+gx_device_escv far_data gs_lp8300f_device = esmv_device_body("lp8300f");
+gx_device_escv far_data gs_lp8400f_device = esmv_device_body("lp8400f");
+gx_device_escv far_data gs_lp8600_device = esmv_device_body("lp8600");
+gx_device_escv far_data gs_lp8600f_device = esmv_device_body("lp8600f");
+gx_device_escv far_data gs_lp8700_device = esmv_device_body("lp8700");
+gx_device_escv far_data gs_lp8900_device = esmv_device_body("lp8900");
+gx_device_escv far_data gs_lp9000b_device = esmv_device_body("lp9000b");
+gx_device_escv far_data gs_lp9100_device = esmv_device_body("lp9100");
+gx_device_escv far_data gs_lp9200b_device = esmv_device_body("lp9200b");
+gx_device_escv far_data gs_lp9300_device = esmv_device_body("lp9300");
+gx_device_escv far_data gs_lp9400_device = esmv_device_body("lp9400");
+gx_device_escv far_data gs_lp9600_device = esmv_device_body("lp9600");
+gx_device_escv far_data gs_lp9600s_device = esmv_device_body("lp9600s");
+gx_device_escv far_data gs_lps4500_device = esmv_device_body("lps4500");
+gx_device_escv far_data gs_eplmono_device = esmv_device_body(ESCPAGE_DEVICENAME_MONO);
/* for ESC/Page-Color */
-gx_device_escv far_data gs_alc1900_device ={escv_device_body("alc1900"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_alc2000_device ={escv_device_body("alc2000"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_alc4000_device ={escv_device_body("alc4000"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_alc4100_device ={escv_device_body("alc4100"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_alc8500_device ={escv_device_body("alc8500"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_alc8600_device ={escv_device_body("alc8600"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_alc9100_device ={escv_device_body("alc9100"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_lp3000c_device ={escv_device_body("lp3000c"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_lp8000c_device ={escv_device_body("lp8000c"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_lp8200c_device ={escv_device_body("lp8200c"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_lp8300c_device ={escv_device_body("lp8300c"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_lp8500c_device ={escv_device_body("lp8500c"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_lp8800c_device ={escv_device_body("lp8800c"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_lp9000c_device ={escv_device_body("lp9000c"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_lp9200c_device ={escv_device_body("lp9200c"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_lp9500c_device ={escv_device_body("lp9500c"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_lp9800c_device ={escv_device_body("lp9800c"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_lps6500_device ={escv_device_body("lps6500"), escv_procs, escv_init_code};
-gx_device_escv far_data gs_eplcolor_device ={escv_device_body(ESCPAGE_DEVICENAME_COLOR), escv_procs, escv_init_code};
+gx_device_escv far_data gs_alc1900_device = escv_device_body("alc1900");
+gx_device_escv far_data gs_alc2000_device = escv_device_body("alc2000");
+gx_device_escv far_data gs_alc4000_device = escv_device_body("alc4000");
+gx_device_escv far_data gs_alc4100_device = escv_device_body("alc4100");
+gx_device_escv far_data gs_alc8500_device = escv_device_body("alc8500");
+gx_device_escv far_data gs_alc8600_device = escv_device_body("alc8600");
+gx_device_escv far_data gs_alc9100_device = escv_device_body("alc9100");
+gx_device_escv far_data gs_lp3000c_device = escv_device_body("lp3000c");
+gx_device_escv far_data gs_lp8000c_device = escv_device_body("lp8000c");
+gx_device_escv far_data gs_lp8200c_device = escv_device_body("lp8200c");
+gx_device_escv far_data gs_lp8300c_device = escv_device_body("lp8300c");
+gx_device_escv far_data gs_lp8500c_device = escv_device_body("lp8500c");
+gx_device_escv far_data gs_lp8800c_device = escv_device_body("lp8800c");
+gx_device_escv far_data gs_lp9000c_device = escv_device_body("lp9000c");
+gx_device_escv far_data gs_lp9200c_device = escv_device_body("lp9200c");
+gx_device_escv far_data gs_lp9500c_device = escv_device_body("lp9500c");
+gx_device_escv far_data gs_lp9800c_device = escv_device_body("lp9800c");
+gx_device_escv far_data gs_lps6500_device = escv_device_body("lps6500");
+gx_device_escv far_data gs_eplcolor_device= escv_device_body(ESCPAGE_DEVICENAME_COLOR);
/* Vector device implementation */
-#if ( 6 > GS_VERSION_MAJOR )
-static int escv_beginpage(P1(gx_device_vector * vdev));
-static int escv_setfillcolor(P2(gx_device_vector * vdev, const gx_drawing_color * pdc));
-static int escv_setstrokecolor(P2(gx_device_vector * vdev, const gx_drawing_color * pdc));
-static int escv_setdash(P4(gx_device_vector * vdev, const float *pattern,
- uint count, double offset));
-static int escv_setflat(P2(gx_device_vector * vdev, double flatness));
-static int escv_setlogop(P3(gx_device_vector * vdev, gs_logical_operation_t lop,
- gs_logical_operation_t diff));
-static int escv_vector_dorect(gx_device_vector * vdev, fixed x0, fixed y0, fixed x1,
- fixed y1, gx_path_type_t type);
-static int escv_vector_dopath(gx_device_vector * vdev, const gx_path * ppath,
- gx_path_type_t type);
-static int escv_beginpath(P2(gx_device_vector * vdev, gx_path_type_t type));
-static int escv_moveto(P6(gx_device_vector * vdev, double x0, double y0,
- double x, double y, gx_path_type_t type));
-static int escv_lineto(P6(gx_device_vector * vdev, double x0, double y0,
- double x, double y, gx_path_type_t type));
-static int escv_curveto(P10(gx_device_vector * vdev, double x0, double y0,
- double x1, double y1, double x2, double y2,
- double x3, double y3, gx_path_type_t type));
-static int escv_closepath(P6(gx_device_vector * vdev, double x, double y,
- double x_start, double y_start, gx_path_type_t type));
-
-static int escv_endpath(P2(gx_device_vector * vdev, gx_path_type_t type));
-static int escv_setlinewidth(gx_device_vector * vdev, double width);
-static int escv_setlinecap(gx_device_vector * vdev, gs_line_cap cap);
-static int escv_setlinejoin(gx_device_vector * vdev, gs_line_join join);
-static int escv_setmiterlimit(gx_device_vector * vdev, double limit);
-
-#else /* 6 <= GS_VERSION_MAJOR */
-
/* Page management */
static int escv_beginpage (gx_device_vector * vdev);
/* Imager state */
@@ -380,17 +311,12 @@ static int escv_setflat (gx_device_vector * vdev, double flatness);
static int escv_setlogop (gx_device_vector * vdev, gs_logical_operation_t lop,
gs_logical_operation_t diff);
/* Other state */
-#if ( 8 <= GS_VERSION_MAJOR )
static bool escv_can_handle_hl_color (gx_device_vector * vdev, const gs_gstate * pgs,
const gx_drawing_color * pdc);
static int escv_setfillcolor (gx_device_vector * vdev, const gs_gstate * pgs,
const gx_drawing_color * pdc);
static int escv_setstrokecolor (gx_device_vector * vdev, const gs_gstate * pgs,
const gx_drawing_color * pdc);
-#else
-static int escv_setfillcolor (gx_device_vector * vdev, const gx_drawing_color * pdc);
-static int escv_setstrokecolor (gx_device_vector * vdev, const gx_drawing_color * pdc);
-#endif
/* Paths */
/* dopath and dorect are normally defaulted */
static int escv_vector_dopath (gx_device_vector * vdev, const gx_path * ppath,
@@ -409,7 +335,6 @@ static int escv_closepath (gx_device_vector * vdev, double x0, double y0,
double x_start, double y_start, gx_path_type_t type);
static int escv_endpath (gx_device_vector * vdev, gx_path_type_t type);
-#endif /* GS_VERSION_MAJOR */
static const gx_device_vector_procs escv_vector_procs =
{
@@ -424,9 +349,7 @@ static const gx_device_vector_procs escv_vector_procs =
escv_setflat,
escv_setlogop,
/* Other state */
-#if ( 8 <= GS_VERSION_MAJOR )
escv_can_handle_hl_color, /* add gs815 */
-#endif
escv_setfillcolor, /* fill & stroke colors are the same */
escv_setstrokecolor,
/* Paths */
@@ -511,10 +434,7 @@ escv_range_check(gx_device * dev)
static int
escv_vector_dopath(gx_device_vector * vdev, const gx_path * ppath,
- gx_path_type_t type
-#if ( 6 <= GS_VERSION_MAJOR )
- , const gs_matrix *pmat
-#endif
+ gx_path_type_t type, const gs_matrix *pmat
)
{
gx_device_escv *pdev = (gx_device_escv *) vdev;
@@ -827,6 +747,9 @@ escv_checkpapersize(gx_device_vector * vdev)
static char *
get_sysname ( void )
{
+#ifdef _WIN32
+ return strdup("BOGUS");
+#else
char *result = NULL;
struct utsname utsn;
@@ -835,6 +758,7 @@ get_sysname ( void )
result = strdup (utsn.sysname);
}
return result;
+#endif
}
/* EPSON printer model name translation.
@@ -1032,8 +956,7 @@ escv_beginpage(gx_device_vector * vdev)
if (sysname)
{
lputs(s, sysname );
- /* Carefully avoid memento interfering here. */
- unvectored_free(sysname);
+ free(sysname);
sysname = NULL;
}
}
@@ -1320,19 +1243,6 @@ escv_setlinewidth(gx_device_vector * vdev, double width)
gx_device_escv *const pdev = (gx_device_escv *) vdev;
char obuf[64];
-#if GS_VERSION_MAJOR == 5
- /* Scale ݤƤΤ, Ghostscript 5.10/5.50 ΥХΤ */
- double xscale, yscale;
-
- xscale = fabs(igs->ctm.xx);
- yscale = fabs(igs->ctm.xy);
-
- if (xscale == 0 || yscale > xscale) /* if portrait */
- width = ceil(width * yscale);
- else
- width = ceil(width * xscale);
-#endif
-
if (width < 1) width = 1;
/* ESC/Page ǤüܹϣĤΥޥɤˤʤäƤ뤿ݻƤ */
@@ -1425,20 +1335,16 @@ escv_setmiterlimit(gx_device_vector * vdev, double limit)
return 0;
}
-#if ( 8 <= GS_VERSION_MAJOR )
static bool
escv_can_handle_hl_color(gx_device_vector * vdev, const gs_gstate * pgs,
const gx_drawing_color * pdc)
{
return false;
}
-#endif
static int
escv_setfillcolor(gx_device_vector * vdev,
-#if ( 8 <= GS_VERSION_MAJOR )
const gs_gstate * pgs,
-#endif
const gx_drawing_color * pdc)
{
stream *s = gdev_vector_stream(vdev);
@@ -1479,9 +1385,7 @@ escv_setfillcolor(gx_device_vector * vdev,
static int
escv_setstrokecolor(gx_device_vector * vdev,
-#if ( 8 <= GS_VERSION_MAJOR )
const gs_gstate * pgs,
-#endif
const gx_drawing_color * pdc)
{
stream *s = gdev_vector_stream(vdev);
@@ -1532,18 +1436,6 @@ escv_setdash(gx_device_vector * vdev, const float *pattern, uint count, double o
int i;
char obuf[64];
-#if GS_VERSION_MAJOR == 5
- float scale, xscale, yscale;
- /* Scale ݤƤΤ, Ghostscript 5.10/5.50 ΥХΤ */
- xscale = fabs(igs->ctm.xx);
- yscale = fabs(igs->ctm.xy);
-
- if (xscale == 0) /* if portrait */
- scale = yscale;
- else
- scale = xscale;
-#endif
-
if (count == 0){
/* */
lputs(s, ESC_GS "0;0lpG");
@@ -1555,13 +1447,7 @@ escv_setdash(gx_device_vector * vdev, const float *pattern, uint count, double o
if (count) {
if (count == 1) {
-#if GS_VERSION_MAJOR == 5
- (void)gs_sprintf(obuf, ESC_GS "1;%d;%ddlG",
- (int)(pattern[0] * scale / vdev->x_pixels_per_inch + 0.5),
- (int)(pattern[0] * scale / vdev->x_pixels_per_inch + 0.5));
-#else
(void)gs_sprintf(obuf, ESC_GS "1;%d;%ddlG", (int) pattern[0], (int) pattern[0]);
-#endif
lputs(s, obuf);
} else {
/* pattern ˣäԲĤȤֵ */
@@ -1571,12 +1457,7 @@ escv_setdash(gx_device_vector * vdev, const float *pattern, uint count, double o
lputs(s, ESC_GS "1");
for (i = 0; i < count; ++i) {
-#if GS_VERSION_MAJOR == 5
- (void)gs_sprintf(obuf, ";%d", (int)(pattern[i] * scale / vdev->x_pixels_per_inch + 0.5));
-
-#else
(void)gs_sprintf(obuf, ";%d", (int) pattern[i]);
-#endif
lputs(s, obuf);
}
lputs(s, "dlG");
@@ -2171,19 +2052,14 @@ escv_copy_mono(gx_device * dev, const byte * data,
gx_color_index c_color = 0;
char obuf[128];
int depth = 1;
-#if ( 8 <= GS_VERSION_MAJOR )
- /* FIXME! add for gs815 */
const gs_gstate * pgs = (const gs_gstate *)0;
-#endif
if (id != gs_no_id && zero == gx_no_color_index && one != gx_no_color_index && data_x == 0) {
gx_drawing_color dcolor;
color_set_pure(&dcolor, one);
escv_setfillcolor(vdev,
-#if ( 8 <= GS_VERSION_MAJOR )
pgs,
-#endif
&dcolor); /* FIXME! gs815 */
}
@@ -2269,9 +2145,7 @@ escv_copy_mono(gx_device * dev, const byte * data,
}
color_set_pure(&color, one);
code = gdev_vector_update_fill_color((gx_device_vector *) pdev,
-#if ( 8 <= GS_VERSION_MAJOR )
pgs,
-#endif
&color);
/* ̲ᤷʲο̵̣ */
@@ -2383,18 +2257,13 @@ escv_fill_mask(gx_device * dev,
gx_color_index color = gx_dc_pure_color(pdcolor);
char obuf[64];
-#if ( 8 <= GS_VERSION_MAJOR )
- /* FIXME! add for gs815 */
const gs_gstate * pgs = (const gs_gstate *)0;
-#endif
if (w <= 0 || h <= 0) return 0;
if (depth > 1 ||
gdev_vector_update_fill_color(vdev,
-#if ( 8 <= GS_VERSION_MAJOR )
pgs,
-#endif
pdcolor) < 0 ||
gdev_vector_update_clip_path(vdev, pcpath) < 0 ||
gdev_vector_update_log_op(vdev, lop) < 0
@@ -2494,23 +2363,25 @@ static const gx_image_enum_procs_t escv_image_enum_procs =
/* Start processing an image. */
static int
-escv_begin_image(gx_device * dev,
- const gs_gstate * pgs, const gs_image_t * pim,
- gs_image_format_t format, const gs_int_rect * prect,
- const gx_drawing_color * pdcolor, const gx_clip_path * pcpath,
- gs_memory_t * mem, gx_image_enum_common_t **pinfo)
+escv_begin_typed_image(gx_device *dev,
+ const gs_gstate *pgs,
+ const gs_matrix *pmat,
+ const gs_image_common_t *pic,
+ const gs_int_rect *prect,
+ const gx_drawing_color *pdcolor,
+ const gx_clip_path *pcpath,
+ gs_memory_t *mem,
+ gx_image_enum_common_t **pinfo)
{
+ const gs_image_t *pim = (const gs_image_t *)pic;
gx_device_vector *const vdev = (gx_device_vector *) dev;
gx_device_escv *const pdev = (gx_device_escv *) dev;
- stream *s = gdev_vector_stream((gx_device_vector *) pdev);
- gdev_vector_image_enum_t *pie =
- gs_alloc_struct(mem, gdev_vector_image_enum_t, &st_vector_image_enum, "escv_begin_image");
- const gs_color_space *pcs = pim->ColorSpace;
+ stream *s;
+ gdev_vector_image_enum_t *pie;
+ const gs_color_space *pcs;
gs_color_space_index index;
int num_components = 1;
- bool can_do = prect == 0 &&
- (pim->format == gs_image_format_chunky ||
- pim->format == gs_image_format_component_planar);
+ bool can_do;
gs_matrix imat;
int code;
@@ -2518,10 +2389,24 @@ escv_begin_image(gx_device * dev,
char obuf[128];
- if (pie == 0) return_error(gs_error_VMerror);
+ s = gdev_vector_stream((gx_device_vector *) pdev);
+ pie = gs_alloc_struct(mem, gdev_vector_image_enum_t,
+ &st_vector_image_enum, "escv_begin_typed_image");
+ if (pie == NULL) return_error(gs_error_VMerror);
pie->memory = mem;
- code = gdev_vector_begin_image(vdev, pgs, pim, format, prect,
- pdcolor, pcpath, mem, &escv_image_enum_procs, pie);
+
+ /* This code can only cope with type1 images. Anything else, we need
+ * to send to the default. */
+ if (pic->type->index != 1)
+ goto fallback;
+
+ can_do = prect == NULL &&
+ (pim->format == gs_image_format_chunky ||
+ pim->format == gs_image_format_component_planar);
+ pcs = pim->ColorSpace;
+ code = gdev_vector_begin_image(vdev, pgs, pim, pim->format, prect,
+ pdcolor, pcpath, mem,
+ &escv_image_enum_procs, pie);
if (code < 0) return code;
*pinfo = (gx_image_enum_common_t *) pie;
@@ -2551,8 +2436,10 @@ escv_begin_image(gx_device * dev,
}
}
if (!can_do) {
- return gx_default_begin_image(dev, pgs, pim, format, prect,
- pdcolor, pcpath, mem, &pie->default_info);
+fallback:
+ return gx_default_begin_typed_image(dev, pgs, pmat, pic, prect,
+ pdcolor, pcpath, mem,
+ &pie->default_info);
}
if (pim->ImageMask || (pim->BitsPerComponent == 1 && num_components == 1)) {
@@ -2573,7 +2460,9 @@ escv_begin_image(gx_device * dev,
if (code < 0)
return code;
- gs_matrix_multiply(&imat, &ctm_only(pgs), &imat);
+ if (pmat == NULL)
+ pmat = &ctm_only(pgs);
+ gs_matrix_multiply(&imat, pmat, &imat);
ty = imat.ty;
bx = imat.xx * pim->Width + imat.yx * pim->Height + imat.tx;
@@ -2667,15 +2556,9 @@ escv_begin_image(gx_device * dev,
/* Process the next piece of an image. */
static int
-#if GS_VERSION_MAJOR >= 6
escv_image_plane_data(gx_image_enum_common_t *info, const gx_image_plane_t *planes, int height, int *rows_used)
-#else
- escv_image_plane_data(gx_device *dev, gx_image_enum_common_t *info, const gx_image_plane_t *planes, int height)
-#endif
{
-#if GS_VERSION_MAJOR >= 6
gx_device *dev = info->dev;
-#endif
gx_device_vector *const vdev = (gx_device_vector *) dev;
gx_device_escv *const pdev = (gx_device_escv *) dev;
gdev_vector_image_enum_t *pie = (gdev_vector_image_enum_t *) info;
@@ -2691,10 +2574,8 @@ escv_image_plane_data(gx_image_enum_common_t *info, const gx_image_plane_t *plan
{
-#if GS_VERSION_MAJOR >= 6
if (height == 260)
height = 1;
-#endif
width_bytes = (pie->width * pie->bits_per_pixel / pdev->ncomp + 7) / 8 * pdev->ncomp;
tbyte = width_bytes * height;
buf = gs_alloc_bytes(vdev->memory, tbyte, "escv_image_data(buf)");
@@ -2881,15 +2762,9 @@ escv_image_plane_data(gx_image_enum_common_t *info, const gx_image_plane_t *plan
}
static int
-#if GS_VERSION_MAJOR >= 6
escv_image_end_image(gx_image_enum_common_t * info, bool draw_last)
-#else
- escv_image_end_image(gx_device *dev, gx_image_enum_common_t * info, bool draw_last)
-#endif
{
-#if GS_VERSION_MAJOR >= 6
gx_device *dev = info->dev;
-#endif
gx_device_vector *const vdev = (gx_device_vector *) dev;
gx_device_escv *const pdev = (gx_device_escv *) dev;
gdev_vector_image_enum_t *pie = (gdev_vector_image_enum_t *) info;
diff --git a/contrib/gdevadmp.c b/contrib/gdevadmp.c
index 6648dffe..9e3d74a4 100644
--- a/contrib/gdevadmp.c
+++ b/contrib/gdevadmp.c
@@ -119,7 +119,7 @@ static dev_proc_print_page(dmp_print_page);
/* Standard DMP device */
const gx_device_printer far_data gs_appledmp_device =
-prn_device(prn_bg_procs, "appledmp", /* The print_page proc is compatible with allowing bg printing */
+prn_device(gdev_prn_initialize_device_procs_mono_bg, "appledmp", /* The print_page proc is compatible with allowing bg printing */
85, /* width_10ths, 8.5" */
110, /* height_10ths, 11" */
120, 72, /* X_DPI, Y_DPI */
@@ -128,7 +128,7 @@ prn_device(prn_bg_procs, "appledmp", /* The print_page proc is compatible with a
/* lowrez Imagewriter device */
const gx_device_printer far_data gs_iwlo_device =
-prn_device(prn_bg_procs, "iwlo", /* The print_page proc is compatible with allowing bg printing */
+prn_device(gdev_prn_initialize_device_procs_mono_bg, "iwlo", /* The print_page proc is compatible with allowing bg printing */
85, /* width_10ths, 8.5" */
110, /* height_10ths, 11" */
160, 72, /* X_DPI, Y_DPI */
@@ -137,7 +137,7 @@ prn_device(prn_bg_procs, "iwlo", /* The print_page proc is compatible with allow
/* hirez Imagewriter device */
const gx_device_printer far_data gs_iwhi_device =
-prn_device(prn_bg_procs, "iwhi", /* The print_page proc is compatible with allowing bg printing */
+prn_device(gdev_prn_initialize_device_procs_mono_bg, "iwhi", /* The print_page proc is compatible with allowing bg printing */
85, /* width_10ths, 8.5" */
110, /* height_10ths, 11" */
160, 144, /* X_DPI, Y_DPI */
@@ -146,7 +146,7 @@ prn_device(prn_bg_procs, "iwhi", /* The print_page proc is compatible with allow
/* LQ hirez Imagewriter device */
const gx_device_printer far_data gs_iwlq_device =
-prn_device(prn_bg_procs, "iwlq", /* The print_page proc is compatible with allowing bg printing */
+prn_device(gdev_prn_initialize_device_procs_mono_bg, "iwlq", /* The print_page proc is compatible with allowing bg printing */
85, /* width_10ths, 8.5" */
110, /* height_10ths, 11" */
320, 216,
diff --git a/contrib/gdevbjc_.c b/contrib/gdevbjc_.c
index a661ba0d..a880aaa1 100644
--- a/contrib/gdevbjc_.c
+++ b/contrib/gdevbjc_.c
@@ -211,13 +211,22 @@ static media_t media_codes[] = {
/* ------------------------- 1 bit Monochrome ---------------------------- */
/***************************************************************************/
-static const gx_device_procs bjcmono_procs =
-prn_color_params_procs(gdev_prn_open, gdev_prn_output_page, gdev_prn_close,
- NULL, NULL,
- gdev_bjc_get_params, gdev_bjc_put_params);
+static void
+bjcmono_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, get_params, gdev_bjc_get_params);
+ set_dev_proc(dev, put_params, gdev_bjc_put_params);
+ set_dev_proc(dev, map_color_rgb, gx_default_w_b_map_color_rgb);
+ set_dev_proc(dev, map_rgb_color, gx_default_gray_fast_encode);
+ set_dev_proc(dev, encode_color, gx_default_gray_fast_encode);
+ set_dev_proc(dev, decode_color, gx_default_w_b_map_color_rgb);
+}
+
const gx_device_bjc_printer gs_bjcmono_device =
-bjc_device(bjcmono_procs, "bjcmono",
+bjc_device(bjcmono_initialize_device_procs, "bjcmono",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
(float)(3.4 / 25.4), (float)(7.0 / 25.4),
@@ -234,13 +243,23 @@ bjc_device(bjcmono_procs, "bjcmono",
/* -------------------------- 8 bit Grayscale ---------------------------- */
/***************************************************************************/
-static const gx_device_procs bjcgray_procs =
-prn_color_params_procs(gdev_prn_open, gdev_prn_output_page, gdev_prn_close,
- gx_default_gray_map_rgb_color, gx_default_gray_map_color_rgb,
- gdev_bjc_get_params, gdev_bjc_put_params);
+static void
+bjcgray_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray(dev);
+
+ set_dev_proc(dev, get_params, gdev_bjc_get_params);
+ set_dev_proc(dev, put_params, gdev_bjc_put_params);
+
+ /* The prn macros used in previous versions of the code leave
+ * encode_color and decode_color set to NULL (which are then rewritten
+ * by the system to the default. For compatibility we do the same. */
+ set_dev_proc(dev, encode_color, NULL);
+ set_dev_proc(dev, decode_color, NULL);
+}
const gx_device_bjc_printer gs_bjcgray_device =
-bjc_device(bjcgray_procs, "bjcgray",
+bjc_device(bjcgray_initialize_device_procs, "bjcgray",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
(float)(3.4 / 25.4), (float)(7.0 / 25.4),
@@ -257,13 +276,23 @@ bjc_device(bjcgray_procs, "bjcgray",
/* --------------------------- 3 bit CMYK Color -------------------------- */
/***************************************************************************/
-static const gx_device_procs bjc_cmykcolor_procs =
-bjc_cmyk_param_procs(gdev_prn_open, gdev_prn_output_page, gdev_prn_close,
- cmyk_1bit_map_color_rgb, cmyk_1bit_map_cmyk_color,
- gdev_bjc_get_params, gdev_bjc_put_params);
+static void
+bjccmyk_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_cmyk1(dev);
+
+ set_dev_proc(dev, get_params, gdev_bjc_get_params);
+ set_dev_proc(dev, put_params, gdev_bjc_put_params);
+
+ /* The prn macros used in previous versions of the code leave
+ * encode_color and decode_color set to NULL (which are then rewritten
+ * by the system to the default. For compatibility we do the same. */
+ set_dev_proc(dev, encode_color, NULL);
+ set_dev_proc(dev, decode_color, NULL);
+}
const gx_device_bjc_printer gs_bjccmyk_device =
-bjc_device(bjc_cmykcolor_procs, "bjccmyk",
+bjc_device(bjccmyk_initialize_device_procs, "bjccmyk",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
(float)(3.4 / 25.4), (float)(7.0 / 25.4),
@@ -280,13 +309,23 @@ bjc_device(bjc_cmykcolor_procs, "bjccmyk",
/* --------------------------- 24 bit TrueColor -------------------------- */
/***************************************************************************/
-static const gx_device_procs bjc_truecolor_procs =
-bjc_cmyk_param_procs(gdev_prn_open, gdev_prn_output_page, gdev_prn_close,
- cmyk_8bit_map_color_rgb, cmyk_8bit_map_cmyk_color,
- gdev_bjc_get_params, gdev_bjc_put_params);
+static void
+bjc_truecolor_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_cmyk8(dev);
+
+ set_dev_proc(dev, get_params, gdev_bjc_get_params);
+ set_dev_proc(dev, put_params, gdev_bjc_put_params);
+
+ /* The prn macros used in previous versions of the code leave
+ * encode_color and decode_color set to NULL (which are then rewritten
+ * by the system to the default. For compatibility we do the same. */
+ set_dev_proc(dev, encode_color, NULL);
+ set_dev_proc(dev, decode_color, NULL);
+}
const gx_device_bjc_printer gs_bjccolor_device =
-bjc_device(bjc_truecolor_procs, "bjccolor",
+bjc_device(bjc_truecolor_initialize_device_procs, "bjccolor",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
(float)(3.4 / 25.4), (float)(7.0 / 25.4),
diff --git a/contrib/gdevbjc_.h b/contrib/gdevbjc_.h
index b40c6fc4..fb6cfa5f 100644
--- a/contrib/gdevbjc_.h
+++ b/contrib/gdevbjc_.h
@@ -168,14 +168,6 @@ typedef struct gx_device_bjc_printer_s gx_device_bjc_printer;
bjc_device_margins(procs, dname, w10, h10, xdpi, ydpi,\
lm, tm, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page, def_ink)
-#define bjc_cmyk_param_procs(v_prn_open, v_prn_output_page, v_prn_close, \
- p_map_color_rgb, p_map_cmyk_color, \
- v_prn_get_params, v_prn_put_params)\
- {v_prn_open, NULL, NULL, v_prn_output_page, v_prn_close,\
- NULL, p_map_color_rgb, NULL, NULL, NULL, NULL, NULL, NULL,\
- v_prn_get_params, v_prn_put_params,\
- p_map_cmyk_color, NULL, NULL, NULL, gx_page_device_get_page_device}
-
/* There are the definitions of commands for the Canon BJC printers. */
#define BJC_BJL_CLEANING 0x00 /* "@Cleaning=1\n" */
diff --git a/contrib/gdevcd8.c b/contrib/gdevcd8.c
index 23532c0f..e6e9a942 100644
--- a/contrib/gdevcd8.c
+++ b/contrib/gdevcd8.c
@@ -701,26 +701,6 @@ typedef struct {
terminate_page\
}
-#define cmyk_colour_procs(proc_colour_open, proc_get_params, proc_put_params, \
- map_rgb_color, map_color_rgb, map_cmyk_color)\
-{ proc_colour_open,\
- gx_default_get_initial_matrix,\
- gx_default_sync_output,\
- gdev_prn_output_page,\
- gdev_prn_close,\
- map_rgb_color,\
- map_color_rgb,\
- NULL /* fill_rectangle */,\
- NULL /* tile_rectangle */,\
- NULL /* copy_mono */,\
- NULL /* copy_color */,\
- NULL /* draw_line */,\
- gx_default_get_bits,\
- proc_get_params,\
- proc_put_params,\
- map_cmyk_color\
-}
-
/* Printer-specific functions. Most printers are handled by the cdj850_xx()
* functions.
*/
@@ -788,61 +768,101 @@ static void
static void
cdnj500_terminate_page(gx_device_printer * pdev, gp_file * prn_stream);
-static const gx_device_procs cdj670_procs =
-cmyk_colour_procs(hp_colour_open, cdj850_get_params, cdj850_put_params,
- NULL, gdev_cmyk_map_color_rgb, gdev_cmyk_map_cmyk_color);
+/* This decoding to RGB and conversion to CMYK simulates what */
+/* gx_default_decode_color does without calling the map_color_rgb method. */
+static int
+cdj670_compatible_cmyk_decode_color(gx_device *dev, gx_color_index color, gx_color_value cv[4])
+{
+ int i, code = gdev_cmyk_map_color_rgb(dev, color, cv);
+ gx_color_value min_val = gx_max_color_value;
-static const gx_device_procs cdj850_procs =
-cmyk_colour_procs(hp_colour_open, cdj850_get_params, cdj850_put_params,
- NULL, gdev_cmyk_map_color_rgb, gdev_cmyk_map_cmyk_color);
+ for (i = 0; i < 3; i++) {
+ if ((cv[i] = gx_max_color_value - cv[i]) < min_val)
+ min_val = cv[i];
+ }
+ for (i = 0; i < 3; i++)
+ cv[i] -= min_val;
+ cv[3] = min_val;
-static const gx_device_procs cdj880_procs =
-cmyk_colour_procs(hp_colour_open, cdj850_get_params, cdj850_put_params,
- NULL, gdev_cmyk_map_color_rgb, gdev_cmyk_map_cmyk_color);
+ return code;
+}
-static const gx_device_procs cdj890_procs =
-cmyk_colour_procs(hp_colour_open, cdj850_get_params, cdj850_put_params,
- NULL, gdev_cmyk_map_color_rgb, gdev_cmyk_map_cmyk_color);
-static const gx_device_procs cdj1600_procs =
-cmyk_colour_procs(hp_colour_open, cdj850_get_params, cdj850_put_params,
- gdev_pcl_map_rgb_color, gdev_pcl_map_color_rgb, NULL);
+static void
+cdj670_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, hp_colour_open);
+ set_dev_proc(dev, map_rgb_color, gx_error_encode_color);
+ set_dev_proc(dev, map_color_rgb, gdev_cmyk_map_color_rgb);
+ set_dev_proc(dev, get_params, cdj850_get_params);
+ set_dev_proc(dev, put_params, cdj850_put_params);
+ set_dev_proc(dev, map_cmyk_color, gdev_cmyk_map_cmyk_color);
+ set_dev_proc(dev, encode_color, gdev_cmyk_map_cmyk_color);
+ set_dev_proc(dev, decode_color, cdj670_compatible_cmyk_decode_color);
+}
+
+static void
+cdj1600_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, hp_colour_open);
+ set_dev_proc(dev, map_rgb_color, gdev_pcl_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gdev_pcl_map_color_rgb);
+ set_dev_proc(dev, get_params, cdj850_get_params);
+ set_dev_proc(dev, put_params, cdj850_put_params);
+ set_dev_proc(dev, map_cmyk_color, gx_error_encode_color);
+ set_dev_proc(dev, encode_color, gdev_pcl_map_rgb_color);
+ set_dev_proc(dev, decode_color, gdev_pcl_map_color_rgb);
+}
-/* HP2200 and DNJ500 is a RGB printer */
-static const gx_device_procs chp2200_procs =
-cmyk_colour_procs(hp_colour_open, cdj850_get_params, cdj850_put_params,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb, NULL);
+static void
+chp2200_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, hp_colour_open);
+ set_dev_proc(dev, map_rgb_color, gx_default_rgb_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_default_rgb_map_color_rgb);
+ set_dev_proc(dev, get_params, cdj850_get_params);
+ set_dev_proc(dev, put_params, cdj850_put_params);
+ set_dev_proc(dev, map_cmyk_color, gx_error_encode_color);
+ set_dev_proc(dev, encode_color, gx_default_rgb_map_rgb_color);
+ set_dev_proc(dev, decode_color, gx_default_rgb_map_color_rgb);
+}
const gx_device_cdj850 gs_cdj670_device =
-cdj_850_device(cdj670_procs, "cdj670", 600, 600, 32, cdj850_print_page, 0,
+cdj_850_device(cdj670_initialize_device_procs, "cdj670", 600, 600, 32, cdj850_print_page, 0,
PRESENTATION, PLAIN_PAPER, 2, DJ670C, 9,
1.0, 0.0, 0.0, 0.0, 0.0, 1.0,
cdj850_start_raster_mode, cdj850_print_non_blank_lines,
cdj850_terminate_page);
const gx_device_cdj850 gs_cdj850_device =
-cdj_850_device(cdj850_procs, "cdj850", 600, 600, 32, cdj850_print_page, 0,
+cdj_850_device(cdj670_initialize_device_procs, "cdj850", 600, 600, 32, cdj850_print_page, 0,
PRESENTATION, PLAIN_PAPER, 4, DJ850C, 9,
1.0, 0.0, 0.0, 0.0, 0.0, 1.0,
cdj850_start_raster_mode, cdj850_print_non_blank_lines,
cdj850_terminate_page);
const gx_device_cdj850 gs_cdj880_device =
-cdj_850_device(cdj880_procs, "cdj880", 600, 600, 32, cdj850_print_page, 0,
+cdj_850_device(cdj670_initialize_device_procs, "cdj880", 600, 600, 32, cdj850_print_page, 0,
PRESENTATION, PLAIN_PAPER, 4, DJ880C, 2,
1.0, 0.0, 0.0, 0.0, 0.0, 1.0,
cdj880_start_raster_mode, cdj880_print_non_blank_lines,
cdj880_terminate_page);
const gx_device_cdj850 gs_cdj890_device =
-cdj_850_device(cdj890_procs, "cdj890", 600, 600, 32, cdj850_print_page, 0,
+cdj_850_device(cdj670_initialize_device_procs, "cdj890", 600, 600, 32, cdj850_print_page, 0,
PRESENTATION, PLAIN_PAPER, 4, DJ890C, 9,
1.0, 0.0, 0.0, 0.0, 0.0, 1.0,
cdj850_start_raster_mode, cdj850_print_non_blank_lines,
cdj850_terminate_page);
const gx_device_cdj850 gs_cdj1600_device =
-cdj_1600_device(cdj1600_procs, "cdj1600", 300, 300, 24, cdj850_print_page, 0,
+cdj_1600_device(cdj1600_initialize_device_procs, "cdj1600", 300, 300, 24, cdj850_print_page, 0,
PRESENTATION, PLAIN_PAPER, 2, DJ1600C, 3,
1.0, 0.0, 0.0, 0.0, 0.0, 1.0,
cdj1600_start_raster_mode, cdj1600_print_non_blank_lines,
@@ -850,7 +870,7 @@ cdj_1600_device(cdj1600_procs, "cdj1600", 300, 300, 24, cdj850_print_page, 0,
/* HP2200 does not need color matching and halftoning parameters */
const gx_device_cdj850 gs_chp2200_device =
-chp_2200_device(chp2200_procs, "chp2200", 300, 300, 24, chp2200_print_page, 0,
+chp_2200_device(chp2200_initialize_device_procs, "chp2200", 300, 300, 24, chp2200_print_page, 0,
NORMAL, PLAIN_PAPER, 0 /*unused*/, HP2200C, 10,
0.0, 0.0, 0.0, 0.0, 0.0, 0.0, /*all unused*/
chp2200_start_raster_mode, NULL /*unused*/,
@@ -858,7 +878,7 @@ chp_2200_device(chp2200_procs, "chp2200", 300, 300, 24, chp2200_print_page, 0,
/* DNJ500 does not need color matching and halftoning parameters */
const gx_device_cdj850 gs_cdnj500_device =
-chp_2200_device(chp2200_procs, "cdnj500", 300, 300, 24, cdnj500_print_page, 0,
+chp_2200_device(chp2200_initialize_device_procs, "cdnj500", 300, 300, 24, cdnj500_print_page, 0,
NORMAL, PLAIN_PAPER, 0 /*unused*/, DNJ500C, 10,
0.0, 0.0, 0.0, 0.0, 0.0, 0.0, /*all unused*/
cdnj500_start_raster_mode, NULL /*unused*/,
diff --git a/contrib/gdevdj9.c b/contrib/gdevdj9.c
index efbeaef5..29e66824 100644
--- a/contrib/gdevdj9.c
+++ b/contrib/gdevdj9.c
@@ -510,24 +510,39 @@ typedef struct
terminate_page\
}
-#define cmyk_colour_procs(proc_colour_open, proc_get_params, proc_put_params, \
- proc_colour_close, map_rgb_color, map_color_rgb, map_cmyk_color) {\
- proc_colour_open,\
- gx_default_get_initial_matrix,\
- gx_default_sync_output,\
- gdev_prn_output_page,\
- proc_colour_close,\
- map_rgb_color,\
- map_color_rgb,\
- NULL /* fill_rectangle */,\
- NULL /* tile_rectangle */,\
- NULL /* copy_mono */,\
- NULL /* copy_color */,\
- NULL /* draw_line */,\
- gx_default_get_bits,\
- proc_get_params,\
- proc_put_params,\
- map_cmyk_color\
+/* This decoding to RGB and conversion to CMYK simulates what */
+/* gx_default_decode_color does without calling the map_color_rgb method. */
+static int
+cdj970_compatible_cmyk_decode_color(gx_device *dev, gx_color_index color, gx_color_value cv[4])
+{
+ int i, code = gdev_cmyk_map_color_rgb(dev, color, cv);
+ gx_color_value min_val = gx_max_color_value;
+
+ for (i = 0; i < 3; i++) {
+ if ((cv[i] = gx_max_color_value - cv[i]) < min_val)
+ min_val = cv[i];
+ }
+ for (i = 0; i < 3; i++)
+ cv[i] -= min_val;
+ cv[3] = min_val;
+
+ return code;
+}
+
+static void
+cdj970_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, hp_colour_open);
+ set_dev_proc(dev, close_device, cdj970_close);
+ set_dev_proc(dev, map_rgb_color, gx_error_encode_color);
+ set_dev_proc(dev, map_color_rgb, gdev_cmyk_map_color_rgb);
+ set_dev_proc(dev, get_params, cdj970_get_params);
+ set_dev_proc(dev, put_params, cdj970_put_params);
+ set_dev_proc(dev, map_cmyk_color, gdev_cmyk_map_cmyk_color);
+ set_dev_proc(dev, encode_color, gdev_cmyk_map_cmyk_color);
+ set_dev_proc(dev, decode_color, cdj970_compatible_cmyk_decode_color);
}
static void
@@ -543,13 +558,9 @@ cdj970_print_non_blank_lines(gx_device_printer * pdev,
static void
cdj970_terminate_page(gx_device_printer * pdev, gp_file * prn_stream);
-static const gx_device_procs cdj970_procs =
-cmyk_colour_procs(hp_colour_open, cdj970_get_params, cdj970_put_params,
- cdj970_close, NULL, gdev_cmyk_map_color_rgb,
- gdev_cmyk_map_cmyk_color);
-
const gx_device_cdj970 gs_cdj970_device =
-cdj_970_device(cdj970_procs, "cdj970", 600, 600, 32, cdj970_print_page, 0,
+cdj_970_device(cdj970_initialize_device_procs, "cdj970",
+ 600, 600, 32, cdj970_print_page, 0,
NORMAL, PLAIN_PAPER, NONE, 4, DJ970C, 2,
1.0, 0.0, 0.0, 0.0, 0.0, 1.0,
cdj970_start_raster_mode, cdj970_print_non_blank_lines,
diff --git a/contrib/gdevgdi.c b/contrib/gdevgdi.c
index cdd148ba..cfe69a41 100644
--- a/contrib/gdevgdi.c
+++ b/contrib/gdevgdi.c
@@ -94,12 +94,17 @@ static dev_proc_open_device(gdi_open);
static dev_proc_close_device(gdi_close);
static dev_proc_print_page(gdi_print_page);
-static gx_device_procs prn_gdi_procs =
- prn_params_procs(gdi_open, gdev_prn_output_page, gdi_close,
- gdev_prn_get_params, gdev_prn_put_params);
+static void
+gdi_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, open_device, gdi_open);
+ set_dev_proc(dev, close_device, gdi_close);
+}
gx_device_printer far_data gs_gdi_device =
- prn_device(prn_gdi_procs, "gdi",
+ prn_device(gdi_initialize_device_procs, "gdi",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS, /* paper size (unit : 10/72 inch size) */
X_DPI2, Y_DPI2,
0.20, 0.25, 0.25, 0.25, /* margins filled in by gdi_open */
@@ -107,7 +112,7 @@ gx_device_printer far_data gs_gdi_device =
gdi_print_page);
gx_device_printer far_data gs_samsunggdi_device =
- prn_device(prn_gdi_procs, "samsunggdi",
+ prn_device(gdi_initialize_device_procs, "samsunggdi",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS, /* paper size (unit : 10/72 inch size) */
X_DPI2, Y_DPI2,
0.20, 0.25, 0.25, 0.25, /* margins filled in by gdi_open */
diff --git a/contrib/gdevhl12.c b/contrib/gdevhl12.c
index 9f4d617c..860d365a 100644
--- a/contrib/gdevhl12.c
+++ b/contrib/gdevhl12.c
@@ -159,12 +159,20 @@ static dev_proc_print_page_copies(hl1250_print_page_copies);
static dev_proc_get_params(hl1250_get_params);
static dev_proc_put_params(hl1250_put_params);
-static const gx_device_procs prn_hl1250_procs =
-prn_params_procs(hl1250_open, gdev_prn_output_page, hl1250_close,
- hl1250_get_params, hl1250_put_params);
+static void
+hl1250_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, open_device, hl1250_open);
+ set_dev_proc(dev, close_device, hl1250_close);
+ set_dev_proc(dev, get_params, hl1250_get_params);
+ set_dev_proc(dev, put_params, hl1250_put_params);
+}
#define hl1250_device_copies(dname, xdpi, ydpi)\
-{ prn_device_std_body_copies(gx_device_hl1250, prn_hl1250_procs,\
+{ prn_device_std_body_copies(gx_device_hl1250,\
+ hl1250_initialize_device_procs,\
dname,\
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,\
xdpi, ydpi,\
diff --git a/contrib/gdevln03.c b/contrib/gdevln03.c
index 88cf8a1f..c5f087e3 100644
--- a/contrib/gdevln03.c
+++ b/contrib/gdevln03.c
@@ -48,10 +48,16 @@ static int sixel_print_page(gx_device_printer *pdev, gp_file *prn_stream,
/* The device descriptor */
static dev_proc_output_page(sixel_output_page);
static dev_proc_print_page(ln03_print_page);
+
/* We have to supply our own procs, since we have to intercept */
/* output_page so we can open the printer in text mode. */
-static gx_device_procs sixel_procs =
- prn_procs(gdev_prn_open, sixel_output_page, gdev_prn_close);
+static void
+sixel_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, output_page, sixel_output_page);
+}
#ifdef A4
# define BOTTOM_MARGIN 0.5
@@ -59,7 +65,7 @@ static gx_device_procs sixel_procs =
# define BOTTOM_MARGIN 0.4
#endif
gx_device_printer gs_ln03_device =
- prn_device(sixel_procs, "ln03",
+ prn_device(sixel_initialize_device_procs, "ln03",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
300, 300, /* x_dpi, y_dpi */
0, BOTTOM_MARGIN, 0, 0, /* left, bottom, right, top margin */
@@ -96,7 +102,7 @@ ln03_print_page(gx_device_printer *pdev, gp_file *prn_stream)
*/
static dev_proc_print_page(dl2100_print_page);
gx_device_printer gs_dl2100_device =
- prn_device(sixel_procs, "dl2100",
+ prn_device(sixel_initialize_device_procs, "dl2100",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
300, 300, /* x_dpi, y_dpi */
0, 0, 0, 0, /* left, bottom, right, top margin */
@@ -121,7 +127,7 @@ dl2100_print_page(gx_device_printer *pdev, gp_file *prn_stream)
*/
static dev_proc_print_page(la50_print_page);
gx_device_printer gs_la50_device =
- prn_device(sixel_procs, "la50",
+ prn_device(sixel_initialize_device_procs, "la50",
85,
110,
144, 72,
@@ -148,7 +154,7 @@ la50_print_page(gx_device_printer *pdev, gp_file *prn_stream)
*/
static dev_proc_print_page(la70_print_page);
gx_device_printer gs_la70_device =
- prn_device(sixel_procs, "la70",
+ prn_device(sixel_initialize_device_procs, "la70",
85,
110,
144, 144,
@@ -174,7 +180,7 @@ la70_print_page(gx_device_printer *pdev, gp_file *prn_stream)
*/
static dev_proc_print_page(la75_print_page);
gx_device_printer gs_la75_device =
- prn_device(sixel_procs, "la75",
+ prn_device(sixel_initialize_device_procs, "la75",
85,
110,
144, 72,
@@ -201,7 +207,7 @@ la75_print_page(gx_device_printer *pdev, gp_file *prn_stream)
*/
static dev_proc_print_page(la75plus_print_page);
gx_device_printer gs_la75plus_device =
- prn_device(sixel_procs, "la75plus",
+ prn_device(sixel_initialize_device_procs, "la75plus",
85,
110,
180, 180,
@@ -235,7 +241,7 @@ la75plus_print_page(gx_device_printer *pdev, gp_file *prn_stream)
*/
static dev_proc_print_page(sxlcrt_print_page);
gx_device_printer gs_sxlcrt_device =
- prn_device(sixel_procs,
+ prn_device(sixel_initialize_device_procs,
"sxlcrt",
180,
110,
diff --git a/contrib/gdevlx32.c b/contrib/gdevlx32.c
index 7cbd2b97..4471e1a0 100644
--- a/contrib/gdevlx32.c
+++ b/contrib/gdevlx32.c
@@ -257,10 +257,20 @@ static int print_photo_page(pagedata *gendata);
*/
/* Device procedures */
-static gx_device_procs lxm3200_procs =
- prn_color_params_procs(lxm3200_open, gdev_prn_output_page, gdev_prn_close,
- lxm3200_map_rgb_color, lxm3200_map_color_rgb, lxm3200_get_params,
- lxm3200_put_params);
+static void
+lxm3200_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, lxm3200_open);
+ set_dev_proc(dev, map_rgb_color, lxm3200_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, lxm3200_map_color_rgb);
+ set_dev_proc(dev, get_params, lxm3200_get_params);
+ set_dev_proc(dev, put_params, lxm3200_put_params);
+ set_dev_proc(dev, map_cmyk_color, gx_error_encode_color);
+ set_dev_proc(dev, encode_color, lxm3200_map_rgb_color);
+ set_dev_proc(dev, decode_color, lxm3200_map_color_rgb);
+}
/* Define an extension (subclass) of gx_device_printer. */
struct lxm_device_s
@@ -308,7 +318,7 @@ struct lxm_device_s
lxm_device far_data gs_lxm3200_device =
{
prn_device_body(lxm_device,
- lxm3200_procs,
+ lxm3200_initialize_device_procs,
"lxm3200",
DEFAULT_WIDTH_10THS,
DEFAULT_HEIGHT_10THS,
diff --git a/contrib/gdevlx7.c b/contrib/gdevlx7.c
index 37f9697f..d4fb44a5 100644
--- a/contrib/gdevlx7.c
+++ b/contrib/gdevlx7.c
@@ -107,9 +107,14 @@ static dev_proc_get_params(lxm_get_params);
static dev_proc_put_params(lxm_put_params);
/* set up dispatch table. I follow gdevdjet in using gdev_prn_output_page */
-static const gx_device_procs lxm7000m_procs =
- prn_params_procs(gdev_prn_open, gdev_prn_output_page, gdev_prn_close,
- lxm_get_params, lxm_put_params);
+static void
+lxm7000m_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, get_params, lxm_get_params);
+ set_dev_proc(dev, put_params, lxm_put_params);
+}
/* The device descriptors */
@@ -140,7 +145,7 @@ typedef struct lxm_device_s { /* a sub-class of gx_device_printer */
#define LXR_1200 2
lxm_device far_data gs_lex7000_device = {
- prn_device_std_body(lxm_device, lxm7000m_procs, "lex7000",
+ prn_device_std_body(lxm_device, lxm7000m_initialize_device_procs, "lex7000",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
/* total width & height in 10x " - A4 or letter compiled in.
* may be overriden by -sPAPERSIZE=a4 of -sPAPERSIZE=letter
@@ -163,7 +168,7 @@ lxm_device far_data gs_lex7000_device = {
};
lxm_device far_data gs_lex5700_device = {
- prn_device_std_body(lxm_device, lxm7000m_procs, "lex5700",
+ prn_device_std_body(lxm_device, lxm7000m_initialize_device_procs, "lex5700",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
/* total width & height in 10x " - A4 or letter compiled in.
* may be overriden by -sPAPERSIZE=a4 of -sPAPERSIZE=letter
@@ -186,7 +191,7 @@ lxm_device far_data gs_lex5700_device = {
};
lxm_device far_data gs_lex3200_device = {
- prn_device_std_body(lxm_device, lxm7000m_procs, "lex3200",
+ prn_device_std_body(lxm_device, lxm7000m_initialize_device_procs, "lex3200",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
/* total width & height in 10x " - A4 or letter compiled in.
* may be overriden by -sPAPERSIZE=a4 of -sPAPERSIZE=letter
@@ -209,7 +214,7 @@ lxm_device far_data gs_lex3200_device = {
};
lxm_device far_data gs_lex2050_device = {
- prn_device_std_body(lxm_device, lxm7000m_procs, "lex2050",
+ prn_device_std_body(lxm_device, lxm7000m_initialize_device_procs, "lex2050",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
/* total width & height in 10x " - A4 or letter compiled in.
* may be overriden by -sPAPERSIZE=a4 of -sPAPERSIZE=letter
diff --git a/contrib/gdevmd2k.c b/contrib/gdevmd2k.c
index 86202774..826846f9 100644
--- a/contrib/gdevmd2k.c
+++ b/contrib/gdevmd2k.c
@@ -64,32 +64,27 @@ typedef struct gx_device_alps_s gx_device_alps;
#define dev_alps ((gx_device_alps *) pdev)
-static gx_device_procs alps_procs = {
- alps_open,
- gx_default_get_initial_matrix,
- NULL, /* sync_output */
- gdev_prn_output_page,
- gdev_prn_close,
- NULL, /* map_rgb_color,*/
- alps_map_color_rgb,
- NULL, /* fill_rectangle */
- NULL, /* tile_rectangle */
- NULL, /* copy_mono */
- NULL, /* copy_color */
- NULL, /* draw_line */
- NULL, /* get_bits */
- alps_get_params,
- alps_put_params,
- alps_map_cmyk_color,
- NULL, /* get_xfont_procs */
- NULL, /* get_xfont_device */
- NULL, /* map_rgb_alpha_color */
- gx_page_device_get_page_device /* get_page_device */
-};
+static void
+alps_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, alps_open);
+ set_dev_proc(dev, map_color_rgb, alps_map_color_rgb);
+ set_dev_proc(dev, get_params, alps_get_params);
+ set_dev_proc(dev, put_params, alps_put_params);
+ set_dev_proc(dev, map_cmyk_color, alps_map_cmyk_color);
+
+ /* The static init used in previous versions of the code leave
+ * encode_color and decode_color set to NULL (which are then rewritten
+ * by the system to the default. For compatibility we do the same. */
+ set_dev_proc(dev, encode_color, NULL);
+ set_dev_proc(dev, decode_color, NULL);
+}
#define alps_device(dname, print_page) \
{\
- prn_device_body(gx_device_alps, alps_procs, dname,\
+ prn_device_body(gx_device_alps, alps_initialize_device_procs, dname,\
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,\
600, 600,\
0, 0, 0, 0, /* margin */\
diff --git a/contrib/gdevop4w.c b/contrib/gdevop4w.c
index a92f6e63..4d5a38f5 100644
--- a/contrib/gdevop4w.c
+++ b/contrib/gdevop4w.c
@@ -94,12 +94,17 @@ static dev_proc_open_device(oki4w_open);
static dev_proc_close_device(oki4w_close);
static dev_proc_print_page(oki4w_print_page);
-static gx_device_procs prn_hp_procs =
- prn_params_procs(oki4w_open, gdev_prn_output_page, oki4w_close,
- gdev_prn_get_params, gdev_prn_put_params);
+static void
+oki4w_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, open_device, oki4w_open);
+ set_dev_proc(dev, close_device, oki4w_close);
+}
gx_device_printer far_data gs_oki4w_device =
- prn_device(prn_hp_procs, "oki4w",
+ prn_device(oki4w_initialize_device_procs, "oki4w",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins filled in by oki4w_open */
diff --git a/contrib/gdevxes.c b/contrib/gdevxes.c
index a10b89c8..0f2db969 100644
--- a/contrib/gdevxes.c
+++ b/contrib/gdevxes.c
@@ -48,8 +48,15 @@ static int sixel_print_page(gx_device_printer *pdev,
/* The device descriptor */
static dev_proc_output_page(sixel_output_page);
static dev_proc_print_page(xes_print_page);
-static gx_device_procs xes_procs =
- prn_procs(gdev_prn_open, sixel_output_page, gdev_prn_close);
+
+static void
+sixel_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, output_page, sixel_output_page);
+}
+
#ifdef A4
# define BOTTOM_MARGIN 0.5
@@ -60,7 +67,7 @@ static gx_device_procs xes_procs =
#endif
gx_device_printer gs_xes_device =
- prn_device(xes_procs, "xes",
+ prn_device(sixel_initialize_device_procs, "xes",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
300, 300, /* x_dpi, y_dpi */
0, BOTTOM_MARGIN, 0, 0, /* left, bottom, right, top margin */
diff --git a/contrib/japanese/gdev10v.c b/contrib/japanese/gdev10v.c
index f4c349d1..0bd3cec0 100644
--- a/contrib/japanese/gdev10v.c
+++ b/contrib/japanese/gdev10v.c
@@ -37,36 +37,8 @@ copies. */
No checking on resolutions are being made.
*/
-#if 0
-#define prn_matrix_procs(p_open, p_get_initial_matrix, p_output_page, p_close) {\
- p_open,\
- p_get_initial_matrix,\
- NULL, /* sync_output */\
- p_output_page,\
- p_close,\
- gdev_prn_map_rgb_color,\
- gdev_prn_map_color_rgb,\
- NULL, /* fill_rectangle */\
- NULL, /* tile_rectangle */\
- NULL, /* copy_mono */\
- NULL, /* copy_color */\
- NULL, /* draw_line */\
- NULL, /* get_bits */\
- gdev_prn_get_params,\
- gdev_prn_put_params,\
- NULL, /* map_cmyk_color */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- gx_page_device_get_page_device\
-}
-#endif
-
/* The device descriptor */
static dev_proc_print_page(bj10v_print_page);
-#if 0
-static dev_proc_get_initial_matrix(bj10v_get_initial_matrix);
-#endif
static int
bj10v_open(gx_device * pdev)
@@ -82,15 +54,37 @@ bj10v_open(gx_device * pdev)
#if 0
-gx_device_procs prn_bj10v_procs =
- prn_matrix_procs(gdev_prn_open, bj10v_get_initial_matrix,
- gdev_prn_output_page, gdev_prn_close);
+/* Shift the origin from the top left corner of the pysical page to the
+ first printable pixel, as defined by the top and left margins. */
+static void
+bj10v_get_initial_matrix(gx_device *dev, gs_matrix *pmat)
+{ gx_default_get_initial_matrix(dev, pmat);
+ pmat->tx -= dev_l_margin(dev) * dev->x_pixels_per_inch;
+ pmat->ty -= dev_t_margin(dev) * dev->y_pixels_per_inch;
+}
+
+static void
+bj10v_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, get_initial_matrix, bj10v_get_initial_matrix);
+}
+
+#else
+
+static void
+bj10v_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, open_device, bj10v_open);
+}
+
#endif
-gx_device_procs prn_bj10v_procs =
- prn_procs(bj10v_open, gdev_prn_output_page, gdev_prn_close);
gx_device_printer gs_bj10v_device =
- prn_device(prn_bj10v_procs, "bj10v",
+ prn_device(bj10v_initialize_device_procs, "bj10v",
DEFAULT_WIDTH_10THS, /* width_10ths */
DEFAULT_HEIGHT_10THS, /* height_10ths */
360, /* x_dpi */
@@ -99,7 +93,7 @@ gx_device_printer gs_bj10v_device =
1, bj10v_print_page);
gx_device_printer gs_bj10vh_device =
- prn_device(prn_bj10v_procs, "bj10vh",
+ prn_device(bj10v_initialize_device_procs, "bj10vh",
DEFAULT_WIDTH_10THS, /* width_10ths */
DEFAULT_HEIGHT_10THS, /* height_10ths */
360, /* x_dpi */
@@ -107,19 +101,6 @@ gx_device_printer gs_bj10vh_device =
0.134, 0.507, 0.166, 0.335, /* l, b, r, t margins */
1, bj10v_print_page);
-/* ------ Internal routines ------ */
-
-#if 0
-/* Shift the origin from the top left corner of the pysical page to the
- first printable pixel, as defined by the top and left margins. */
-static void
-bj10v_get_initial_matrix(gx_device *dev, gs_matrix *pmat)
-{ gx_default_get_initial_matrix(dev, pmat);
- pmat->tx -= dev_l_margin(dev) * dev->x_pixels_per_inch;
- pmat->ty -= dev_t_margin(dev) * dev->y_pixels_per_inch;
-}
-#endif
-
/* ---- Printer output routines ---- */
/* Note: Following code is stolen from gdevp201.c. On NEC PC9801 series,
diff --git a/contrib/japanese/gdevalps.c b/contrib/japanese/gdevalps.c
index 9d3122ac..c04f69ef 100644
--- a/contrib/japanese/gdevalps.c
+++ b/contrib/japanese/gdevalps.c
@@ -57,11 +57,16 @@ static dev_proc_print_page(md50m_print_page);
static dev_proc_print_page(md50e_print_page);
static dev_proc_print_page(md1xm_print_page);
-static gx_device_procs prn_md_procs =
- prn_procs(md_open, gdev_prn_output_page, gdev_prn_close);
+static void
+md_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, open_device, md_open);
+}
gx_device_printer far_data gs_md50Mono_device =
- prn_device(prn_md_procs, "md50Mono",
+ prn_device(md_initialize_device_procs, "md50Mono",
DEFAULT_WIDTH_10THS,
DEFAULT_HEIGHT_10THS,
600, /* x_dpi */
@@ -70,7 +75,7 @@ gx_device_printer far_data gs_md50Mono_device =
1, md50m_print_page);
gx_device_printer far_data gs_md50Eco_device =
- prn_device(prn_md_procs, "md50Eco",
+ prn_device(md_initialize_device_procs, "md50Eco",
DEFAULT_WIDTH_10THS,
DEFAULT_HEIGHT_10THS,
600, /* x_dpi */
@@ -79,7 +84,7 @@ gx_device_printer far_data gs_md50Eco_device =
1, md50e_print_page);
gx_device_printer far_data gs_md1xMono_device =
- prn_device(prn_md_procs, "md1xMono",
+ prn_device(md_initialize_device_procs, "md1xMono",
DEFAULT_WIDTH_10THS,
DEFAULT_HEIGHT_10THS,
600, /* x_dpi */
diff --git a/contrib/japanese/gdevespg.c b/contrib/japanese/gdevespg.c
index 2f182134..4ce7b718 100644
--- a/contrib/japanese/gdevespg.c
+++ b/contrib/japanese/gdevespg.c
@@ -42,19 +42,34 @@ static dev_proc_image_out(escpage_image_out);
static void escpage_printer_initialize(gx_device_printer * pdev, gp_file * fp, int);
static void escpage_paper_set(gx_device_printer * pdev, gp_file * fp);
-static gx_device_procs lp2000_prn_procs =
-lprn_procs(lp2000_open, gdev_prn_output_page, gdev_prn_close);
+static void
+lp2000_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, open_device, lp2000_open);
+ set_dev_proc(dev, get_params, lprn_get_params);
+ set_dev_proc(dev, put_params, lprn_put_params);
+}
-static gx_device_procs escpage_prn_procs =
-lprn_procs(escpage_open, gdev_prn_output_page, escpage_close);
+static void
+escpage_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, open_device, escpage_open);
+ set_dev_proc(dev, close_device, escpage_close);
+ set_dev_proc(dev, get_params, lprn_get_params);
+ set_dev_proc(dev, put_params, lprn_put_params);
+}
gx_device_lprn far_data gs_lp2000_device =
-lprn_device(gx_device_lprn, lp2000_prn_procs, "lp2000",
+lprn_device(gx_device_lprn, lp2000_initialize_device_procs, "lp2000",
DPI, DPI, 0.0, 0.0, 0.0, 0.0, 1,
lp2000_print_page_copies, escpage_image_out);
gx_device_lprn far_data gs_escpage_device =
-lprn_duplex_device(gx_device_lprn, escpage_prn_procs, "escpage",
+lprn_duplex_device(gx_device_lprn, escpage_initialize_device_procs, "escpage",
DPI, DPI, 0.0, 0.0, 0.0, 0.0, 1,
escpage_print_page_copies, escpage_image_out);
diff --git a/contrib/japanese/gdevfmlbp.c b/contrib/japanese/gdevfmlbp.c
index 0e0ab425..2de50e40 100644
--- a/contrib/japanese/gdevfmlbp.c
+++ b/contrib/japanese/gdevfmlbp.c
@@ -41,15 +41,16 @@ copies. */
/* The device descriptors */
static dev_proc_print_page(fmlbp_print_page);
-#ifdef FMLBP_NOADJUST_MARGIN
-#define PRNFMLBP prn_std_procs
+static void fmlbp_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+}
+
+#ifdef FMLBP_NOADJUST_MARGIN
+#define PRNFML_INIT fmlbp_initialize_device_procs
#else
/* Adjust margin for ghostscript 2.6.1 */
-#define PRNFMLBP prn_fmlbp_procs
-static dev_proc_get_initial_matrix(fmlbp_get_initial_matrix);
-gx_device_procs prn_fmlbp_procs =
- prn_matrix_procs(gdev_prn_open, fmlbp_get_initial_matrix,
- gdev_prn_output_page, gdev_prn_close);
+#define PRNFML_INIT fmlbp_initialize_device_procs_with_matrix
/* Shift the origin from the top left corner of the pysical page to the
first printable pixel, as defined by the top and left margins. */
@@ -60,10 +61,17 @@ fmlbp_get_initial_matrix(gx_device *dev, gs_matrix *pmat)
pmat->tx -= (dev->l_margin * dev->x_pixels_per_inch);
pmat->ty -= (dev->t_margin * dev->y_pixels_per_inch);
}
+
+static void fmlbp_initialize_device_procs_with_matrix(gx_device *dev)
+{
+ fmlbp_initialize_device_procs(dev);
+
+ set_dev_proc(dev, get_initial_matrix, fmlbp_get_initial_matrix);
+}
#endif/*FMLBP_NOADJUST_MARGIN*/
gx_device_printer gs_fmlbp_device =
- prn_device(PRNFMLBP, "fmlbp",
+ prn_device(PRNFML_INIT, "fmlbp",
DEFAULT_WIDTH_10THS_A4, /* width_10ths, 8.3" */
DEFAULT_HEIGHT_10THS_A4, /* height_10ths, 11.7" */
X_DPI, Y_DPI,
diff --git a/contrib/japanese/gdevfmpr.c b/contrib/japanese/gdevfmpr.c
index cd34d4fd..3e4aaefd 100644
--- a/contrib/japanese/gdevfmpr.c
+++ b/contrib/japanese/gdevfmpr.c
@@ -30,7 +30,7 @@ static dev_proc_print_page(fmpr_print_page);
/* The device descriptor */
gx_device_printer gs_fmpr_device =
- prn_device(prn_std_procs, "fmpr",
+ prn_device(gdev_prn_initialize_device_procs_mono, "fmpr",
DEFAULT_WIDTH_10THS,
DEFAULT_HEIGHT_10THS,
180, /* x_dpi */
diff --git a/contrib/japanese/gdevj100.c b/contrib/japanese/gdevj100.c
index f8a70179..8305e1c4 100644
--- a/contrib/japanese/gdevj100.c
+++ b/contrib/japanese/gdevj100.c
@@ -29,7 +29,7 @@ static dev_proc_print_page(jj100_print_page);
/* The device descriptor */
gx_device_printer gs_jj100_device =
- prn_device(prn_std_procs, "jj100",
+ prn_device(gdev_prn_initialize_device_procs_mono, "jj100",
82, /* width_10ths, 8.2" = 210mm(A4) */
115 /*113, 117*/, /* height_10ths, 11.7" = 297mm(A4) */
360, /* x_dpi */
diff --git a/contrib/japanese/gdevlbp3.c b/contrib/japanese/gdevlbp3.c
index 8cbc2ce8..8042d4db 100644
--- a/contrib/japanese/gdevlbp3.c
+++ b/contrib/japanese/gdevlbp3.c
@@ -15,7 +15,7 @@ static dev_proc_print_page(lbp310PrintPage);
static dev_proc_print_page(lbp320PrintPage);
gx_device_printer far_data gs_lbp310_device =
- prn_device(prn_std_procs,
+ prn_device(gdev_prn_initialize_device_procs_mono,
"lbp310",
DEFAULT_WIDTH_10THS,
DEFAULT_HEIGHT_10THS,
@@ -27,7 +27,7 @@ gx_device_printer far_data gs_lbp310_device =
1, lbp310PrintPage);
gx_device_printer far_data gs_lbp320_device =
- prn_device(prn_std_procs,
+ prn_device(gdev_prn_initialize_device_procs_mono,
"lbp320",
DEFAULT_WIDTH_10THS,
DEFAULT_HEIGHT_10THS,
diff --git a/contrib/japanese/gdevmjc.c b/contrib/japanese/gdevmjc.c
index b132167d..591f75fd 100644
--- a/contrib/japanese/gdevmjc.c
+++ b/contrib/japanese/gdevmjc.c
@@ -208,89 +208,74 @@ typedef struct gx_device_mj_s gx_device_mj;
(bpp == 32 ? 3 : 1), dns, r, g, b, k, drct, mcrwv, dtsz \
}
-#define mj_colour_procs(proc_colour_open, proc_get_params, proc_put_params)\
-{ proc_colour_open,\
- gx_default_get_initial_matrix,\
- gx_default_sync_output,\
- gdev_prn_output_page,\
- gdev_prn_close,\
- gdev_mjc_map_rgb_color,\
- gdev_mjc_map_color_rgb,\
- NULL, /* fill_rectangle */\
- NULL, /* tile_rectangle */\
- NULL, /* copy_mono */\
- NULL, /* copy_color */\
- NULL, /* draw_line */\
- gx_default_get_bits,\
- proc_get_params,\
- proc_put_params,\
- NULL, /* map_cmyk_color */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- NULL, /* get_page_device */\
- NULL, /* get_alpha_bits */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- NULL, /* fill_path */\
- NULL, /* stroke_path */\
- NULL, /* fill_mask */\
- NULL, /* fill_trapezoid */\
- NULL, /* fill_parallelogram */\
- NULL, /* fill_triangle */\
- NULL, /* draw_thin_line */\
- NULL, /* begin_image */\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL, /* strip_copy_rop, */\
- NULL, /* get_clipping_box */\
- NULL, /* begin_typed_image */\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- NULL, /* create_compositor */\
- NULL, /* get_hardware_params */\
- NULL, /* text_begin */\
- NULL, /* finish_copydevice */\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL, /* discard_transparency_layer */\
- NULL, /* get_color_mapping_procs */\
- NULL, /* get_color_comp_index */\
- gdev_mjc_encode_color,\
- gdev_mjc_decode_color\
+static void
+mj_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_rgb_color, gdev_mjc_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gdev_mjc_map_color_rgb);
+ set_dev_proc(dev, get_params, mj_get_params);
+ set_dev_proc(dev, encode_color, gdev_mjc_encode_color);
+ set_dev_proc(dev, decode_color, gdev_mjc_decode_color);
}
-static gx_device_procs mj700v2c_procs =
-mj_colour_procs(mj700v2c_open, mj_get_params, mj700v2c_put_params);
+static void
+mj700v2c_initialize_device_procs(gx_device *dev)
+{
+ mj_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, mj700v2c_open);
+ set_dev_proc(dev, put_params, mj700v2c_put_params);
+}
-static gx_device_procs mj500c_procs =
-mj_colour_procs(mj500c_open, mj_get_params, mj500c_put_params);
+static void
+mj500c_initialize_device_procs(gx_device *dev)
+{
+ mj_initialize_device_procs(dev);
-static gx_device_procs mj6000c_procs =
-mj_colour_procs(mj6000c_open, mj_get_params, mj700v2c_put_params);
+ set_dev_proc(dev, open_device, mj500c_open);
+ set_dev_proc(dev, put_params, mj500c_put_params);
+}
-static gx_device_procs mj8000c_procs =
-mj_colour_procs(mj8000c_open, mj_get_params, mj700v2c_put_params);
+static void
+mj6000c_initialize_device_procs(gx_device *dev)
+{
+ mj_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, mj6000c_open);
+ set_dev_proc(dev, put_params, mj700v2c_put_params);
+}
+
+static void
+mj8000c_initialize_device_procs(gx_device *dev)
+{
+ mj_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, mj8000c_open);
+ set_dev_proc(dev, put_params, mj700v2c_put_params);
+}
gx_device_mj far_data gs_mj700v2c_device =
-mjcmyk_device(mj700v2c_procs, "mj700v2c", 360, 360, BITSPERPIXEL,
- mj700v2c_print_page, 1024, 1024, 1024, 1024, 1024, 0, 1, 1);
+mjcmyk_device(mj700v2c_initialize_device_procs, "mj700v2c",
+ 360, 360, BITSPERPIXEL,
+ mj700v2c_print_page,
+ 1024, 1024, 1024, 1024, 1024, 0, 1, 1);
gx_device_mj far_data gs_mj500c_device =
-mjcmy_device(mj500c_procs, "mj500c", 360, 360, BITSPERPIXEL,
- mj500c_print_page, 1024, 1024, 1024, 1024, 1024, 0, 1, 1);
+mjcmy_device(mj500c_initialize_device_procs, "mj500c",
+ 360, 360, BITSPERPIXEL,
+ mj500c_print_page, 1024, 1024, 1024, 1024, 1024, 0, 1, 1);
gx_device_mj far_data gs_mj6000c_device =
-mjcmyk_device(mj6000c_procs, "mj6000c", 360, 360, BITSPERPIXEL,
- mj6000c_print_page, 1024, 1024, 1024, 1024, 1024, 0, 1, 1);
+mjcmyk_device(mj6000c_initialize_device_procs, "mj6000c",
+ 360, 360, BITSPERPIXEL,
+ mj6000c_print_page, 1024, 1024, 1024, 1024, 1024, 0, 1, 1);
gx_device_mj far_data gs_mj8000c_device =
-mjcmyk_device(mj8000c_procs, "mj8000c", 360, 360, BITSPERPIXEL,
- mj8000c_print_page, 1024, 1024, 1024, 1024, 1024, 0, 1, 1);
+mjcmyk_device(mj8000c_initialize_device_procs, "mj8000c",
+ 360, 360, BITSPERPIXEL,
+ mj8000c_print_page, 1024, 1024, 1024, 1024, 1024, 0, 1, 1);
/* Get the paper size code, based on width and height. */
static int
diff --git a/contrib/japanese/gdevml6.c b/contrib/japanese/gdevml6.c
index d8eaa1c3..9ea1fbb5 100644
--- a/contrib/japanese/gdevml6.c
+++ b/contrib/japanese/gdevml6.c
@@ -32,11 +32,17 @@ static dev_proc_open_device(ml600_open);
static dev_proc_close_device(ml600_close);
static dev_proc_print_page(ml600_print_page);
-static gx_device_procs ml600_procs =
- prn_procs(ml600_open, gdev_prn_output_page, ml600_close);
+static void
+ml600_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, open_device, ml600_open);
+ set_dev_proc(dev, close_device, ml600_close);
+}
gx_device_printer gs_ml600_device =
- prn_device(ml600_procs, "ml600",
+ prn_device(ml600_initialize_device_procs, "ml600",
83, /* width_10ths, 8.3" */
117, /* height_10ths, 11.7" */
600, 600,
diff --git a/contrib/japanese/gdevnpdl.c b/contrib/japanese/gdevnpdl.c
index 9deadaee..9c6d6bba 100644
--- a/contrib/japanese/gdevnpdl.c
+++ b/contrib/japanese/gdevnpdl.c
@@ -118,12 +118,19 @@ static dev_proc_print_page_copies(npdl_print_page_copies);
static dev_proc_put_params(npdl_put_params);
static dev_proc_image_out(npdl_image_out);
-static gx_device_procs npdl_prn_procs =
-prn_params_procs(npdl_open, gdev_prn_output_page, npdl_close,
- lprn_get_params, npdl_put_params);
+static void
+npdl_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, open_device, npdl_open);
+ set_dev_proc(dev, close_device, npdl_close);
+ set_dev_proc(dev, get_params, lprn_get_params);
+ set_dev_proc(dev, put_params, npdl_put_params);
+}
gx_device_lprn far_data gs_npdl_device =
-lprn_duplex_device(gx_device_lprn, npdl_prn_procs, "npdl",
+lprn_duplex_device(gx_device_lprn, npdl_initialize_device_procs, "npdl",
X_DPI, Y_DPI, /* default resolution */
0.0, 0.0, 0.0, 0.0, /* margins */
1, npdl_print_page_copies, npdl_image_out);
diff --git a/contrib/japanese/gdevp201.c b/contrib/japanese/gdevp201.c
index 1d3f4607..43fc8b97 100644
--- a/contrib/japanese/gdevp201.c
+++ b/contrib/japanese/gdevp201.c
@@ -41,7 +41,7 @@ static dev_proc_print_page(pr201_print_page);
/* The device descriptor */
gx_device_printer gs_pr201_device =
- prn_device(prn_std_procs, "pr201",
+ prn_device(gdev_prn_initialize_device_procs_mono, "pr201",
WIDTH,
HEIGHT,
160,
@@ -50,7 +50,7 @@ gx_device_printer gs_pr201_device =
1, pr201_print_page);
gx_device_printer gs_pr1000_device =
- prn_device(prn_std_procs, "pr1000",
+ prn_device(gdev_prn_initialize_device_procs_mono, "pr1000",
WIDTH,
HEIGHT,
240,
@@ -59,7 +59,7 @@ gx_device_printer gs_pr1000_device =
1, pr201_print_page);
gx_device_printer gs_pr150_device =
- prn_device(prn_std_procs, "pr150",
+ prn_device(gdev_prn_initialize_device_procs_mono, "pr150",
WIDTH,
HEIGHT,
320,
@@ -68,7 +68,7 @@ gx_device_printer gs_pr150_device =
1, pr201_print_page);
gx_device_printer gs_pr1000_4_device =
- prn_device(prn_std_procs, "pr1000_4",
+ prn_device(gdev_prn_initialize_device_procs, "pr1000_4",
WIDTH,
HEIGHT,
400,
@@ -130,6 +130,7 @@ pr201_print_page(gx_device_printer *pdev, gp_file *prn_stream)
int height;
int bits_per_column;
int bytes_per_column;
+ int bits_per_column_rounded_up;
int chunk_size;
byte *in, *out;
int lnum, skip;
@@ -154,12 +155,17 @@ pr201_print_page(gx_device_printer *pdev, gp_file *prn_stream)
height = pdev->height;
bits_per_column = head_pins;
bytes_per_column = bits_per_column / 8;
+ bits_per_column_rounded_up = (bits_per_column + 7 ) & ~7;
chunk_size = bits_per_column * line_size;
in = (byte *)
- gs_malloc(pdev->memory->non_gc_memory, bits_per_column, line_size, "pr201_print_page(in)");
+ gs_malloc(pdev->memory->non_gc_memory,
+ bits_per_column_rounded_up,
+ line_size, "pr201_print_page(in)");
out = (byte *)
- gs_malloc(pdev->memory->non_gc_memory, bits_per_column, line_size, "pr201_print_page(out)");
+ gs_malloc(pdev->memory->non_gc_memory,
+ bits_per_column_rounded_up,
+ line_size, "pr201_print_page(out)");
if(in == 0 || out == 0)
return -1;
@@ -177,6 +183,14 @@ pr201_print_page(gx_device_printer *pdev, gp_file *prn_stream)
gp_fprintf(pdev->file, "\033T%d" , lr_pitch);
/* 18/120 inch per line */
+ if (bits_per_column_rounded_up != bits_per_column) {
+ memset(in + bits_per_column * line_size, 0,
+ (bits_per_column_rounded_up - bits_per_column) *
+ line_size);
+ memset(out, 0,
+ bits_per_column_rounded_up * line_size);
+ }
+
/* Send Data to printer */
lnum = 0;
skip = 0;
diff --git a/contrib/japanese/gdevrpdl.c b/contrib/japanese/gdevrpdl.c
index d7e561f5..dbb0249c 100644
--- a/contrib/japanese/gdevrpdl.c
+++ b/contrib/japanese/gdevrpdl.c
@@ -34,11 +34,19 @@ static dev_proc_image_out(rpdl_image_out);
static void rpdl_printer_initialize(gx_device_printer * pdev, gp_file * prn_stream, int num_copies);
static void rpdl_paper_set(gx_device_printer * pdev, gp_file * prn_stream);
-static gx_device_procs rpdl_prn_procs =
-lprn_procs(rpdl_open, gdev_prn_output_page, rpdl_close);
+static void
+rpdl_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, open_device, rpdl_open);
+ set_dev_proc(dev, close_device, rpdl_close);
+ set_dev_proc(dev, get_params, lprn_get_params);
+ set_dev_proc(dev, put_params, lprn_put_params);
+}
gx_device_lprn far_data gs_rpdl_device =
-lprn_device(gx_device_lprn, rpdl_prn_procs, "rpdl",
+lprn_device(gx_device_lprn, rpdl_initialize_device_procs, "rpdl",
DPI, DPI, 0.0, 0.0, 0.0, 0.0, 1,
rpdl_print_page_copies, rpdl_image_out);
diff --git a/contrib/lips4/gdevl4r.c b/contrib/lips4/gdevl4r.c
index d8bcec7e..3b5100c4 100644
--- a/contrib/lips4/gdevl4r.c
+++ b/contrib/lips4/gdevl4r.c
@@ -99,24 +99,52 @@ struct gx_device_lips4_s {
lips4_params_common;
};
-static gx_device_procs lips2p_prn_procs =
-prn_params_procs(lips2p_open, gdev_prn_output_page, lips_close,
- lips_get_params, lips_put_params);
+static void
+lips2p_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
-static gx_device_procs lips3_prn_procs =
-prn_params_procs(lips3_open, gdev_prn_output_page, lips_close,
- lips_get_params, lips_put_params);
+ set_dev_proc(dev, open_device, lips2p_open);
+ set_dev_proc(dev, close_device, lips_close);
+ set_dev_proc(dev, get_params, lips_get_params);
+ set_dev_proc(dev, put_params, lips_put_params);
+};
-static gx_device_procs bjc880j_prn_color_procs =
-prn_params_procs(bjc880j_open, gdev_prn_output_page, lips_close,
- lips4_get_params, lips4_put_params);
+static void
+lips3_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
-static gx_device_procs lips4_prn_procs =
-prn_params_procs(lips4_open, gdev_prn_output_page, lips_close,
- lips4_get_params, lips4_put_params);
+ set_dev_proc(dev, open_device, lips3_open);
+ set_dev_proc(dev, close_device, lips_close);
+ set_dev_proc(dev, get_params, lips_get_params);
+ set_dev_proc(dev, put_params, lips_put_params);
+};
+
+static void
+bjc880j_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, open_device, bjc880j_open);
+ set_dev_proc(dev, close_device, lips_close);
+ set_dev_proc(dev, get_params, lips4_get_params);
+ set_dev_proc(dev, put_params, lips4_put_params);
+};
+
+static void
+lips4_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, open_device, lips4_open);
+ set_dev_proc(dev, close_device, lips_close);
+ set_dev_proc(dev, get_params, lips4_get_params);
+ set_dev_proc(dev, put_params, lips4_put_params);
+};
gx_device_lips far_data gs_lips2p_device =
-lips_device(gx_device_lips, lips2p_prn_procs, "lips2p",
+lips_device(gx_device_lips, lips2p_initialize_device_procs, "lips2p",
LIPS2P_DPI_DEFAULT,
LIPS2P_DPI_DEFAULT,
LIPS2P_LEFT_MARGIN_DEFAULT,
@@ -128,7 +156,7 @@ lips_device(gx_device_lips, lips2p_prn_procs, "lips2p",
LIPS_USERNAME_DEFAULT);
gx_device_lips far_data gs_lips3_device =
-lips_device(gx_device_lips, lips3_prn_procs, "lips3",
+lips_device(gx_device_lips, lips3_initialize_device_procs, "lips3",
LIPS3_DPI_DEFAULT,
LIPS3_DPI_DEFAULT,
LIPS3_LEFT_MARGIN_DEFAULT,
@@ -140,7 +168,7 @@ lips_device(gx_device_lips, lips3_prn_procs, "lips3",
LIPS_USERNAME_DEFAULT);
gx_device_lips4 far_data gs_bjc880j_device =
-lips4_device(gx_device_lips4, bjc880j_prn_color_procs, "bjc880j",
+lips4_device(gx_device_lips4, bjc880j_initialize_device_procs, "bjc880j",
BJC880J_DPI_DEFAULT,
BJC880J_DPI_DEFAULT,
BJC880J_LEFT_MARGIN_DEFAULT,
@@ -152,7 +180,7 @@ lips4_device(gx_device_lips4, bjc880j_prn_color_procs, "bjc880j",
LIPS_USERNAME_DEFAULT);
gx_device_lips4 far_data gs_lips4_device =
-lips4_device(gx_device_lips4, lips4_prn_procs, "lips4",
+lips4_device(gx_device_lips4, lips4_initialize_device_procs, "lips4",
LIPS4_DPI_DEFAULT,
LIPS4_DPI_DEFAULT,
LIPS4_LEFT_MARGIN_DEFAULT,
@@ -179,13 +207,8 @@ static int lips4c_output_page(gx_device_printer * pdev, gp_file * prn_stream);
static int lips_delta_encode(byte * inBuff, byte * prevBuff, byte * outBuff, byte * diffBuff, int Length);
static int lips_byte_cat(byte * TotalBuff, byte * Buff, int TotalLen, int Len);
static int lips_print_page_copies(gx_device_printer * pdev, gp_file * prn_stream, lips_printer_type ptype, int numcopies);
-#if GS_VERSION_MAJOR >= 8
static int lips_print_page_copies(gx_device_printer * pdev, gp_file * prn_stream, lips_printer_type ptype, int numcopies);
static int lips4type_print_page_copies(gx_device_printer * pdev, gp_file * prn_stream, int num_copies, int ptype);
-#else
-static int lips_print_page_copies(P4(gx_device_printer * pdev, gp_file * prn_stream, lips_printer_type ptype, int numcopies));
-static int lips_print_page_copies(P4(gx_device_printer * pdev, gp_file * prn_stream, lips_printer_type ptype, int numcopies));
-#endif
static int
lips2p_open(gx_device * pdev)
{
diff --git a/contrib/lips4/gdevl4v.c b/contrib/lips4/gdevl4v.c
index 47b3fd17..1cdc17c4 100644
--- a/contrib/lips4/gdevl4v.c
+++ b/contrib/lips4/gdevl4v.c
@@ -97,7 +97,7 @@ static dev_proc_copy_color(lips4v_copy_color);
static dev_proc_put_params(lips4v_put_params);
static dev_proc_get_params(lips4v_get_params);
static dev_proc_fill_mask(lips4v_fill_mask);
-static dev_proc_begin_image(lips4v_begin_image);
+static dev_proc_begin_typed_image(lips4v_begin_typed_image);
#define X_DPI 600
#define Y_DPI 600
@@ -145,7 +145,8 @@ gs_public_st_suffix_add0_final(st_device_lips4v, gx_device_lips4v,
std_device_part3_()
#define lips4v_device_body\
- lips_device_full_body(gx_device_lips4v, 0, "lips4v",\
+ lips_device_full_body(gx_device_lips4v,\
+ lips4v_initialize_device_procs, "lips4v",\
&st_device_lips4v,\
DEFAULT_WIDTH_10THS * X_DPI / 10,\
DEFAULT_HEIGHT_10THS * Y_DPI / 10,\
@@ -156,48 +157,34 @@ gs_public_st_suffix_add0_final(st_device_lips4v, gx_device_lips4v,
LIPS4_RIGHT_MARGIN_DEFAULT,\
LIPS4_TOP_MARGIN_DEFAULT)
-#define lips4v_procs\
- { lips4v_open,\
- gx_upright_get_initial_matrix,\
- NULL, /* sync_output */\
- lips4v_output_page,\
- lips4v_close,\
- gx_default_gray_map_rgb_color,\
- gx_default_gray_map_color_rgb,\
- gdev_vector_fill_rectangle,\
- NULL, /* tile_rectangle */\
- lips4v_copy_mono,\
- lips4v_copy_color,\
- NULL, /* draw_line */\
- NULL, /* get_bits */\
- lips4v_get_params,\
- lips4v_put_params,\
- NULL, /* map_cmyk_color */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- gx_page_device_get_page_device,\
- NULL, /* get_alpha_bits */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- gdev_vector_fill_path,\
- gdev_vector_stroke_path,\
- lips4v_fill_mask,\
- gdev_vector_fill_trapezoid,\
- gdev_vector_fill_parallelogram,\
- gdev_vector_fill_triangle,\
- NULL /****** WRONG ******/, /* draw_thin_line */\
- lips4v_begin_image,\
- NULL,\
- NULL,\
- NULL, /* strip_tile_rectangle */\
- NULL/******strip_copy_rop******/\
- }
+static void
+lips4v_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, lips4v_open);
+ set_dev_proc(dev, get_initial_matrix, gx_upright_get_initial_matrix);
+ set_dev_proc(dev, output_page, lips4v_output_page);
+ set_dev_proc(dev, close_device, lips4v_close);
+ set_dev_proc(dev, map_rgb_color, gx_default_gray_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_default_gray_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, gdev_vector_fill_rectangle);
+ set_dev_proc(dev, copy_mono, lips4v_copy_mono);
+ set_dev_proc(dev, copy_color, lips4v_copy_color);
+ set_dev_proc(dev, get_params, lips4v_get_params);
+ set_dev_proc(dev, put_params, lips4v_put_params);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
+ set_dev_proc(dev, fill_path, gdev_vector_fill_path);
+ set_dev_proc(dev, stroke_path, gdev_vector_stroke_path);
+ set_dev_proc(dev, fill_mask, lips4v_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, gdev_vector_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, gdev_vector_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, gdev_vector_fill_triangle);
+ set_dev_proc(dev, begin_typed_image, lips4v_begin_typed_image);
+ set_dev_proc(dev, get_bits_rectangle, gx_blank_get_bits_rectangle);
+}
gx_device_lips4v far_data gs_lips4v_device = {
lips4v_device_body,
- lips4v_procs,
+ { 0 },
vector_initial_values,
LIPS_CASSETFEED_DEFAULT,
LIPS_USERNAME_DEFAULT,
@@ -226,7 +213,6 @@ gx_device_lips4v far_data gs_lips4v_device = {
};
/* Vector device implementation */
-#if GS_VERSION_MAJOR >= 8
static int lips4v_beginpage(gx_device_vector * vdev);
static int lips4v_setfillcolor(gx_device_vector * vdev, const gs_gstate * pgs,
const gx_drawing_color * pdc);
@@ -258,43 +244,6 @@ lips4v_closepath(gx_device_vector * vdev, double x, double y, double x_start,
double y_start, gx_path_type_t type);
static int lips4v_endpath(gx_device_vector * vdev, gx_path_type_t type);
-#else
-static int lips4v_beginpage(P1(gx_device_vector * vdev));
-static int lips4v_setfillcolor(P2(gx_device_vector * vdev,
- const gx_drawing_color * pdc));
-static int lips4v_setstrokecolor(P2(gx_device_vector * vdev,
- const gx_drawing_color * pdc));
-static int lips4v_setdash(P4(gx_device_vector * vdev, const float *pattern,
- uint count, double offset));
-static int lips4v_setflat(P2(gx_device_vector * vdev, double flatness));
-static int
-lips4v_setlogop(P3
-
- (gx_device_vector * vdev, gs_logical_operation_t lop,
- gs_logical_operation_t diff));
-static int
-
-lips4v_beginpath(P2(gx_device_vector * vdev, gx_path_type_t type));
-static int
-lips4v_moveto(P6
- (gx_device_vector * vdev, double x0, double y0, double x,
- double y, gx_path_type_t type));
-static int
-lips4v_lineto(P6
- (gx_device_vector * vdev, double x0, double y0, double x,
- double y, gx_path_type_t type));
-static int
-lips4v_curveto(P10
- (gx_device_vector * vdev, double x0, double y0, double x1,
- double y1, double x2, double y2, double x3, double y3,
- gx_path_type_t type));
-static int
-lips4v_closepath(P6
- (gx_device_vector * vdev, double x, double y, double x_start,
- double y_start, gx_path_type_t type));
-
-static int lips4v_endpath(P2(gx_device_vector * vdev, gx_path_type_t type));
-#endif
static int lips4v_setlinewidth(gx_device_vector * vdev, double width);
static int lips4v_setlinecap(gx_device_vector * vdev, gs_line_cap cap);
static int lips4v_setlinejoin(gx_device_vector * vdev, gs_line_join join);
@@ -311,9 +260,7 @@ static const gx_device_vector_procs lips4v_vector_procs = {
lips4v_setflat,
lips4v_setlogop,
/* Other state */
-#if GS_VERSION_MAJOR >= 8
lips4v_can_handle_hl_color, /* can_handle_hl_color (dummy) */
-#endif
lips4v_setfillcolor, /* fill & stroke colors are the same */
lips4v_setstrokecolor,
/* Paths */
@@ -1070,13 +1017,8 @@ lips4v_setmiterlimit(gx_device_vector * vdev, double limit)
return 0;
}
-#if GS_VERSION_MAJOR >= 8
static int
lips4v_setfillcolor(gx_device_vector * vdev, const gs_gstate * pgs, const gx_drawing_color * pdc)
-#else
-static int
-lips4v_setfillcolor(gx_device_vector * vdev, const gx_drawing_color * pdc)
-#endif
{
if (!gx_dc_is_pure(pdc))
@@ -1138,13 +1080,8 @@ lips4v_setfillcolor(gx_device_vector * vdev, const gx_drawing_color * pdc)
return 0;
}
-#if GS_VERSION_MAJOR >= 8
static int
lips4v_setstrokecolor(gx_device_vector * vdev, const gs_gstate * pgs, const gx_drawing_color * pdc)
-#else
-static int
-lips4v_setstrokecolor(gx_device_vector * vdev, const gx_drawing_color * pdc)
-#endif
{
if (!gx_dc_is_pure(pdc))
return_error(gs_error_rangecheck);
@@ -1280,7 +1217,6 @@ lips4v_setlogop(gx_device_vector * vdev, gs_logical_operation_t lop,
return 0;
}
-#if GS_VERSION_MAJOR >= 8
/*--- added for Ghostscritp 8.15 ---*/
static int
lips4v_can_handle_hl_color(gx_device_vector * vdev, const gs_gstate * pgs1,
@@ -1288,7 +1224,6 @@ lips4v_can_handle_hl_color(gx_device_vector * vdev, const gs_gstate * pgs1,
{
return false; /* High level color is not implemented yet. */
}
-#endif
static int
lips4v_beginpath(gx_device_vector * vdev, gx_path_type_t type)
@@ -1438,21 +1373,15 @@ lips4v_open(gx_device * dev)
/****** WRONG ******/
vdev->vec_procs = &lips4v_vector_procs;
-#if GS_VERSION_MAJOR >= 8
- code = gdev_vector_open_file_options(vdev, 512,
+ code = gdev_vector_open_file_options(vdev, 512,
(VECTOR_OPEN_FILE_SEQUENTIAL|VECTOR_OPEN_FILE_BBOX));
-#else
- code = gdev_vector_open_file_bbox(vdev, 512, true);
-#endif
if (code < 0)
return code;
-#if GS_VERSION_MAJOR >= 8
- if (pdev->bbox_device != NULL) {
- if (pdev->bbox_device->memory == NULL)
- pdev->bbox_device->memory = gs_memory_stable(dev->memory);
- }
-#endif
+ if (pdev->bbox_device != NULL) {
+ if (pdev->bbox_device->memory == NULL)
+ pdev->bbox_device->memory = gs_memory_stable(dev->memory);
+ }
gdev_vector_init(vdev);
pdev->first_page = true;
@@ -1874,11 +1803,7 @@ lips4v_copy_mono(gx_device * dev, const byte * data,
gx_drawing_color dcolor;
color_set_pure(&dcolor, one);
-#if GS_VERSION_MAJOR >= 8
lips4v_setfillcolor(vdev, NULL, &dcolor);
-#else
- lips4v_setfillcolor(vdev, &dcolor);
-#endif
if (lips4v_copy_text_char(dev, data, raster, id, x, y, w, h) >= 0)
return 0;
@@ -1978,13 +1903,8 @@ lips4v_copy_mono(gx_device * dev, const byte * data,
}
color_set_pure(&color, one);
-#if GS_VERSION_MAJOR >= 8
code = gdev_vector_update_fill_color((gx_device_vector *) pdev,
NULL, &color);
-#else
- code = gdev_vector_update_fill_color((gx_device_vector *) pdev,
- &color);
-#endif
}
if (code < 0)
return 0;
@@ -2061,11 +1981,7 @@ lips4v_copy_color(gx_device * dev,
/* LIPS IV Ǥϥ졼ñ᡼顼̿
ƶΤǹꤷʤФʤʤ */
color_set_pure(&dcolor, vdev->black);
-#if GS_VERSION_MAJOR >= 8
lips4v_setfillcolor(vdev, NULL, &dcolor);
-#else
- lips4v_setfillcolor(vdev, &dcolor);
-#endif
} else {
if (pdev->TextMode) {
sputc(s, LIPS_CSI);
@@ -2131,11 +2047,7 @@ lips4v_fill_mask(gx_device * dev,
if (w <= 0 || h <= 0)
return 0;
if (depth > 1 ||
-#if GS_VERSION_MAJOR >= 8
gdev_vector_update_fill_color(vdev, NULL, pdcolor) < 0 ||
-#else
- gdev_vector_update_fill_color(vdev, pdcolor) < 0 ||
-#endif
gdev_vector_update_clip_path(vdev, pcpath) < 0 ||
gdev_vector_update_log_op(vdev, lop) < 0)
return gx_default_fill_mask(dev, data, data_x, raster, id,
@@ -2179,6 +2091,18 @@ lips4v_fill_mask(gx_device * dev,
byte *buf = gs_alloc_bytes(vdev->memory, num_bytes,
"lips4v_fill_mask(buf)");
+ /* This code seems suspect to me; we allocate a buffer
+ * rounding each line up to a multiple of 4, and then
+ * fill it without reference to this rounding. I suspect
+ * that each line should be padded, rather than all the
+ * data being crammed at the start, but I can't make that
+ * change in the absence of any way to test this. I will
+ * make do by adding the memset here so that any untouched
+ * bytes are at least consistently set to 0 to avoid
+ * indeterminisms (and valgrind errors). RJW */
+ if (width_bytes * h < num_bytes) {
+ memset(buf + width_bytes * h, 0, num_bytes - width_bytes * h);
+ }
for (i = 0; i < h; ++i) {
memcpy(buf + i * width_bytes, data + (data_x >> 3) + i * raster,
width_bytes);
@@ -2202,32 +2126,44 @@ static const gx_image_enum_procs_t lips4v_image_enum_procs = {
/* Start processing an image. */
static int
-lips4v_begin_image(gx_device * dev,
- const gs_gstate * pgs, const gs_image_t * pim,
- gs_image_format_t format, const gs_int_rect * prect,
- const gx_drawing_color * pdcolor,
- const gx_clip_path * pcpath, gs_memory_t * mem,
- gx_image_enum_common_t ** pinfo)
+lips4v_begin_typed_image(gx_device *dev,
+ const gs_gstate *pgs,
+ const gs_matrix *pmat,
+ const gs_image_common_t *pic,
+ const gs_int_rect *prect,
+ const gx_drawing_color *pdcolor,
+ const gx_clip_path *pcpath,
+ gs_memory_t *mem,
+ gx_image_enum_common_t **pinfo)
{
gx_device_vector *const vdev = (gx_device_vector *) dev;
gx_device_lips4v *const pdev = (gx_device_lips4v *) dev;
- gdev_vector_image_enum_t *pie =
- gs_alloc_struct(mem, gdev_vector_image_enum_t,
- &st_vector_image_enum, "lips4v_begin_image");
- const gs_color_space *pcs = pim->ColorSpace;
+ const gs_image_t *pim = (const gs_image_t *)pic;
+ gdev_vector_image_enum_t *pie;
+ const gs_color_space *pcs;
gs_color_space_index index = 0;
int num_components = 1;
- bool can_do = prect == 0 &&
- (pim->format == gs_image_format_chunky ||
-
- pim->format == gs_image_format_component_planar);
-
+ bool can_do;
int code;
+ pie = gs_alloc_struct(mem, gdev_vector_image_enum_t,
+ &st_vector_image_enum, "lips4v_begin_typed_image");
if (pie == 0)
return_error(gs_error_VMerror);
pie->memory = mem;
- code = gdev_vector_begin_image(vdev, pgs, pim, format, prect,
+
+ /* We can only cope with type 1 images here.*/
+ if (pic->type->index != 1) {
+ *pinfo = (gx_image_enum_common_t *) pie;
+ goto fallback;
+ }
+
+ pcs = pim->ColorSpace;
+ can_do = prect == NULL &&
+ (pim->format == gs_image_format_chunky ||
+ pim->format == gs_image_format_component_planar);
+
+ code = gdev_vector_begin_image(vdev, pgs, pim, pim->format, prect,
pdcolor, pcpath, mem,
&lips4v_image_enum_procs, pie);
if (code < 0)
@@ -2266,21 +2202,19 @@ lips4v_begin_image(gx_device * dev,
}
}
}
- if (!can_do)
- return gx_default_begin_image(dev, pgs, pim, format, prect,
- pdcolor, pcpath, mem,
- &pie->default_info);
+ if (!can_do) {
+fallback:
+ return gx_default_begin_typed_image(dev, pgs, pmat, pic, prect,
+ pdcolor, pcpath, mem,
+ &pie->default_info);
+ }
else if (index == gs_color_space_index_DeviceGray) {
gx_drawing_color dcolor;
/* LIPS IV Ǥϥ졼ñ᡼顼̿
ƶΤǹŪ˻ꤷʤФʤʤ */
color_set_pure(&dcolor, vdev->black);
-#if GS_VERSION_MAJOR >= 8
lips4v_setfillcolor(vdev, NULL, &dcolor);
-#else
- lips4v_setfillcolor(vdev, &dcolor);
-#endif
}
if (pim->ImageMask || (pim->BitsPerComponent == 1 && num_components == 1)) {
if (pim->Decode[0] > pim->Decode[1])
@@ -2305,7 +2239,9 @@ lips4v_begin_image(gx_device * dev,
if (code < 0)
return code;
- gs_matrix_multiply(&imat, &ctm_only(pgs), &imat);
+ if (pmat == NULL)
+ pmat = &ctm_only(pgs);
+ gs_matrix_multiply(&imat, pmat, &imat);
/*
[xx xy yx yy tx ty]
LIPS κɸϤѴԤʤ
@@ -2386,7 +2322,7 @@ lips4v_begin_image(gx_device * dev,
if (index == gs_color_space_index_DeviceGray)
lputs(s, "0");
else {
- if (format == gs_image_format_chunky) /* RGBRGBRGB... */
+ if (pim->format == gs_image_format_chunky) /* RGBRGBRGB... */
sputc(s, 0x3a);
else /* RRR...GGG...BBB... */
sputc(s, 0x3b);
diff --git a/contrib/lips4/gdevlprn.h b/contrib/lips4/gdevlprn.h
index 6b9245a7..4c066c5f 100644
--- a/contrib/lips4/gdevlprn.h
+++ b/contrib/lips4/gdevlprn.h
@@ -31,13 +31,8 @@
#include "gdevprn.h"
-#if GS_VERSION_MAJOR >= 8
#define lprn_dev_proc_image_out(proc)\
void proc(gx_device_printer *, gp_file *, int, int, int, int)
-#else
-#define lprn_dev_proc_image_out(proc)\
- void proc(P6(gx_device_printer *, gp_file *, int, int, int, int))
-#endif
#define dev_proc_image_out(proc) lprn_dev_proc_image_out(proc)
@@ -119,9 +114,6 @@
lp_duplex_device_body_rest_(print_page_copies, image_out)\
}
-#define lprn_procs(p_open, p_output_page, p_close)\
- prn_params_procs(p_open, p_output_page, p_close, lprn_get_params, lprn_put_params)
-
typedef struct _Bubble
{
struct _Bubble *next;
diff --git a/contrib/opvp/gdevopvp.c b/contrib/opvp/gdevopvp.c
index 70475add..844b46cd 100644
--- a/contrib/opvp/gdevopvp.c
+++ b/contrib/opvp/gdevopvp.c
@@ -170,12 +170,7 @@ static int oprp_open(gx_device *);
static void opvp_get_initial_matrix(gx_device *, gs_matrix *);
static int opvp_output_page(gx_device *, int, int);
static int opvp_close(gx_device *);
-#if GS_VERSION_MAJOR >= 8
static gx_color_index opvp_map_rgb_color(gx_device *, const gx_color_value *); /* modified for gs 8.15 */
-#else
-static gx_color_index opvp_map_rgb_color(gx_device *, gx_color_value,
- gx_color_value, gx_color_value);
-#endif
static int opvp_map_color_rgb(gx_device *, gx_color_index, gx_color_value *);
static int opvp_copy_mono(gx_device *, const byte *, int, int,
gx_bitmap_id, int, int, int, int,
@@ -221,14 +216,9 @@ static int opvp_setdash(gx_device_vector *, const float *, uint, double);
static int opvp_setflat(gx_device_vector *, double);
static int opvp_setlogop(gx_device_vector *, gs_logical_operation_t,
gs_logical_operation_t);
-#if GS_VERSION_MAJOR >= 8
static int opvp_can_handle_hl_color(gx_device_vector *, const gs_gstate *, const gx_drawing_color *);
static int opvp_setfillcolor(gx_device_vector *, const gs_gstate *, const gx_drawing_color *);
static int opvp_setstrokecolor(gx_device_vector *, const gs_gstate *,const gx_drawing_color *);
-#else
-static int opvp_setfillcolor(gx_device_vector *, const gx_drawing_color *);
-static int opvp_setstrokecolor(gx_device_vector *, const gx_drawing_color *);
-#endif
static int opvp_vector_dopath(gx_device_vector *, const gx_path *,
gx_path_type_t, const gs_matrix *);
static int opvp_vector_dorect(gx_device_vector *, fixed, fixed, fixed, fixed,
@@ -278,7 +268,7 @@ static dev_proc_get_params(oprp_get_params);
static dev_proc_put_params(opvp_put_params);
static dev_proc_put_params(oprp_put_params);
static dev_proc_fill_rectangle(opvp_fill_rectangle);
-static dev_proc_begin_image(opvp_begin_image);
+static dev_proc_begin_typed_image(opvp_begin_typed_image);
static image_enum_proc_plane_data(opvp_image_plane_data);
static image_enum_proc_end_image(opvp_image_end_image);
@@ -306,57 +296,35 @@ gs_public_st_suffix_add0_final(
NULL /* *docInfo */
/* device procs */
-#define opvp_procs \
-{\
- opvp_open,\
- opvp_get_initial_matrix,\
- NULL, /* sync_output */\
- opvp_output_page,\
- opvp_close,\
- opvp_map_rgb_color,\
- opvp_map_color_rgb,\
- opvp_fill_rectangle, /*gdev_vector_fill_rectangle,*/\
- NULL, /* tile_rectangle OBSOLETE */\
- opvp_copy_mono,\
- opvp_copy_color,\
- NULL, /* draw_line OBSOLETE */\
- NULL, /* get_bits */\
- opvp_get_params,\
- opvp_put_params,\
- NULL, /* map_cmyk_color */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- gx_page_device_get_page_device,\
- NULL, /* get_alpha_bits OBSOLETE */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- opvp_fill_path,\
- opvp_stroke_path,\
- opvp_fill_mask,\
- gdev_vector_fill_trapezoid,\
- gdev_vector_fill_parallelogram,\
- gdev_vector_fill_triangle,\
- NULL, /* draw_thin_line */\
- opvp_begin_image,\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL, /* strip_copy_rop */\
- NULL, /* get_clipping_box */\
- NULL, /* begin_typed_image */\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- NULL, /* create_compositor */\
- NULL, /* get_hardware_params */\
- NULL, /* text_begin */\
- NULL, /* finish_copydevice */\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL /* discard_transparency_layer */\
+static void
+opvp_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, opvp_open);
+ set_dev_proc(dev, get_initial_matrix, opvp_get_initial_matrix);
+ set_dev_proc(dev, output_page, opvp_output_page);
+ set_dev_proc(dev, close_device, opvp_close);
+ set_dev_proc(dev, map_rgb_color, opvp_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, opvp_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, opvp_fill_rectangle);
+ set_dev_proc(dev, copy_mono, opvp_copy_mono);
+ set_dev_proc(dev, copy_color, opvp_copy_color);
+ set_dev_proc(dev, get_params, opvp_get_params);
+ set_dev_proc(dev, put_params, opvp_put_params);
+ set_dev_proc(dev, fill_path, opvp_fill_path);
+ set_dev_proc(dev, stroke_path, opvp_stroke_path);
+ set_dev_proc(dev, fill_mask, opvp_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, gdev_vector_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, gdev_vector_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, gdev_vector_fill_triangle);
+ set_dev_proc(dev, begin_typed_image, opvp_begin_typed_image);
+
+ /* The static init used in previous versions of the code leave
+ * encode_color and decode_color set to NULL (which are then rewritten
+ * by the system to the default. For compatibility we do the same. */
+ set_dev_proc(dev, encode_color, NULL);
+ set_dev_proc(dev, decode_color, NULL);
}
/* vector procs */
@@ -373,9 +341,7 @@ static gx_device_vector_procs opvp_vector_procs =
opvp_setflat,
opvp_setlogop,
/* Other state */
-#if GS_VERSION_MAJOR >= 8
opvp_can_handle_hl_color, /* added for gs 8.15 */
-#endif
opvp_setfillcolor,
opvp_setstrokecolor,
/* Paths */
@@ -393,7 +359,7 @@ const gx_device_opvp gs_opvp_device =
{
std_device_dci_type_body(
gx_device_opvp,
- 0,
+ opvp_initialize_device_procs,
"opvp",
&st_device_opvp,
DEFAULT_WIDTH_10THS_A4 * X_DPI / 10,
@@ -406,27 +372,35 @@ const gx_device_opvp gs_opvp_device =
255,
256,
256
- ),
- opvp_procs
+ )
};
/* for inkjet */
-static gx_device_procs prn_oprp_procs =
- prn_color_params_procs(
- oprp_open,
- opvp_output_page,
- opvp_close,
- opvp_map_rgb_color,
- opvp_map_color_rgb,
- oprp_get_params,
- oprp_put_params
- );
+static void
+oprp_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, oprp_open);
+ set_dev_proc(dev, output_page, opvp_output_page);
+ set_dev_proc(dev, close_device, opvp_close);
+ set_dev_proc(dev, map_rgb_color, opvp_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, opvp_map_color_rgb);
+ set_dev_proc(dev, get_params, oprp_get_params);
+ set_dev_proc(dev, put_params, oprp_put_params);
+
+ /* The static init used in previous versions of the code leave
+ * encode_color and decode_color set to NULL (which are then rewritten
+ * by the system to the default. For compatibility we do the same. */
+ set_dev_proc(dev, encode_color, NULL);
+ set_dev_proc(dev, decode_color, NULL);
+}
const gx_device_oprp gs_oprp_device =
{
prn_device_std_margins_body(
gx_device_oprp,
- prn_oprp_procs,
+ oprp_initialize_device_procs,
"oprp",
DEFAULT_WIDTH_10THS_A4,
DEFAULT_HEIGHT_10THS_A4,
@@ -1931,11 +1905,9 @@ prepare_open(gx_device *dev)
dev->color_info.dither_grays = 256;
dev->color_info.dither_colors = 256;
}
-#if GS_VERSION_MAJOR >= 8
dev->procs.get_color_mapping_procs = NULL;
dev->procs.get_color_comp_index = NULL;
gx_device_fill_in_procs(dev);
-#endif
}
/* call Closerinter as dummy */
@@ -2050,13 +2022,11 @@ opvp_open(gx_device *dev)
}
rdev = (gx_device_oprp *)(dev);
pdev = (gx_device_opvp *)(dev);
-#if GS_VERSION_MAJOR >= 8
if (pdev->bbox_device != NULL) {
if (pdev->bbox_device->memory == NULL) {
pdev->bbox_device->memory = gs_memory_stable(dev->memory);
}
}
-#endif
outputFD = fileno(gp_get_file(pdev->file));
} else {
/* open printer device */
@@ -2479,17 +2449,9 @@ opvp_close(gx_device *dev)
/*
* map rgb color
*/
-#if GS_VERSION_MAJOR >= 8
static gx_color_index
opvp_map_rgb_color(gx_device *dev,
const gx_color_value *prgb /* modified for gs 8.15 */)
-#else
-static gx_color_index
-opvp_map_rgb_color(gx_device *dev,
- gx_color_value r,
- gx_color_value g,
- gx_color_value b)
-#endif
{
opvp_cspace_t cs;
uint c, m, y, k;
@@ -2499,12 +2461,10 @@ opvp_map_rgb_color(gx_device *dev,
opvp_result_t r;
#endif
-#if GS_VERSION_MAJOR >= 8
gx_color_value r, g, b; /* added for gs 8.15 */
r = prgb[0];
g = prgb[1];
b = prgb[2];
-#endif
#if ENABLE_SIMPLE_MODE
cs = colorSpace;
@@ -2565,31 +2525,19 @@ opvp_map_rgb_color(gx_device *dev,
;
break;
case OPVP_CSPACE_DEVICEGRAY:
-#if GS_VERSION_MAJOR >= 8
{
gx_color_value rgb[3];
rgb[0] = rgb[1] = rgb[2] = r;
return gx_default_gray_map_rgb_color(dev, rgb);
}
-#else
- return gx_default_gray_map_rgb_color(dev, r, g, b);
-#endif
break;
case OPVP_CSPACE_BW :
-#if GS_VERSION_MAJOR >= 8
return gx_default_b_w_map_rgb_color(dev, prgb);
-#else
- return gx_default_b_w_map_rgb_color(dev, r, g, b);
-#endif
break;
case OPVP_CSPACE_STANDARDRGB:
case OPVP_CSPACE_DEVICEKRGB:
default:
-#if GS_VERSION_MAJOR >= 8
return gx_default_rgb_map_rgb_color(dev, prgb);
-#else
- return gx_default_rgb_map_rgb_color(dev, r, g, b);
-#endif
break;
}
}
@@ -3584,11 +3532,7 @@ opvp_fill_mask(
{
if (vector) {
int code;
-#if GS_VERSION_MAJOR >= 8 /* for gs 8.15 */
code = gdev_vector_update_fill_color((gx_device_vector *)dev, NULL, pdcolor);
-#else
- code = gdev_vector_update_fill_color((gx_device_vector *)dev, pdcolor);
-#endif
if (code < 0) return code;
code = gdev_vector_update_clip_path((gx_device_vector *)dev, pcpath);
if (code < 0) return code;
@@ -3604,11 +3548,11 @@ opvp_fill_mask(
* begin image
*/
static int
-opvp_begin_image(
+opvp_begin_typed_image(
gx_device *dev,
const gs_gstate *pgs,
- const gs_image_t *pim,
- gs_image_format_t format,
+ const gs_matrix *pmat,
+ const gs_image_common_t *pic,
const gs_int_rect *prect,
const gx_drawing_color *pdcolor,
const gx_clip_path *pcpath,
@@ -3616,7 +3560,8 @@ opvp_begin_image(
gx_image_enum_common_t **pinfo)
{
gx_device_vector *vdev =(gx_device_vector *)dev;
- gdev_vector_image_enum_t *vinfo;
+ const gs_image_t *pim = (const gs_image_t *)pic;
+ gdev_vector_image_enum_t *vinfo = NULL;
gs_matrix mtx;
opvp_ctm_t ctm;
bool draw_image = false;
@@ -3628,16 +3573,13 @@ opvp_begin_image(
bool can_reverse = false;
int p;
float mag[2] = {1, 1};
- const gs_color_space *pcs = pim->ColorSpace;
+ const gs_color_space *pcs;
/* check if paths are too complex */
- if (!checkCPath(pcpath)) {
- return gx_default_begin_image(
- dev, pgs, pim, format,
- prect, pdcolor, pcpath,
- mem, pinfo);
- }
+ if (pic->type->index != 1 || !checkCPath(pcpath))
+ goto fallback;
+ pcs = pim->ColorSpace;
color_index = 0;
vinfo = gs_alloc_struct(mem, gdev_vector_image_enum_t,
@@ -3646,8 +3588,8 @@ opvp_begin_image(
if (vinfo) {
memcpy(imageDecode,pim->Decode,sizeof(pim->Decode));
- vinfo->memory =mem;
- code = gdev_vector_begin_image(vdev, pgs, pim, format, prect,
+ vinfo->memory = mem;
+ code = gdev_vector_begin_image(vdev, pgs, pim, pim->format, prect,
pdcolor, pcpath, mem,
&opvp_image_enum_procs,
vinfo);
@@ -3665,14 +3607,10 @@ opvp_begin_image(
if (color_index == gs_color_space_index_Indexed) {
base_color_index
= gs_color_space_indexed_base_space(pcs)->type->index;
- if (((pcs->params.indexed.hival + 1) > 256)
- || (bits_per_pixel != 8 && bits_per_pixel != 1)) {
- return gx_default_begin_image(
- dev, pgs, pim, format,
- prect, pdcolor, pcpath,
- mem, pinfo);
- } else if (base_color_index
- == gs_color_space_index_DeviceCMYK) {
+ if (((pcs->params.indexed.hival + 1) > 256) ||
+ (bits_per_pixel != 8 && bits_per_pixel != 1))
+ goto fallback;
+ if (base_color_index == gs_color_space_index_DeviceCMYK) {
/* for CMYK indexed color */
int count;
const unsigned char *p
@@ -3687,37 +3625,32 @@ opvp_begin_image(
byte2frac((*(p + 1 + (count * 4)))),
byte2frac((*(p + 2 + (count * 4)))),
byte2frac((*(p + 3 + (count * 4)))),
-#if GS_VERSION_MAJOR >= 9
pgs, rgb, mem);
-#else
- pgs, rgb);
-#endif
*(palette + 0 + (count * 3)) = frac2byte(rgb[0]);
*(palette + 1 + (count * 3)) = frac2byte(rgb[1]);
*(palette + 2 + (count * 3)) = frac2byte(rgb[2]);
}
bits_per_pixel = 24;
- } else if (base_color_index
- == gs_color_space_index_DeviceRGB ||
- base_color_index == gs_color_space_index_CIEABC) {
+ } else if (base_color_index ==
+ gs_color_space_index_DeviceRGB ||
+ base_color_index ==
+ gs_color_space_index_CIEABC) {
/* for RGB or CalRGB indexed color */
memcpy(palette, pcs->params.indexed.lookup.table.data,\
pcs->params.indexed.lookup.table.size);
bits_per_pixel = 24;
- } else if (base_color_index
- == gs_color_space_index_DeviceGray ||
- base_color_index == gs_color_space_index_CIEA) {
+ } else if (base_color_index ==
+ gs_color_space_index_DeviceGray ||
+ base_color_index ==
+ gs_color_space_index_CIEA) {
/* for Gray or CalGray indexed color */
memcpy(palette, pcs->params.indexed.lookup.table.data,\
pcs->params.indexed.lookup.table.size);
bits_per_pixel = 8;
} else {
/* except CMYK and RGB */
- return gx_default_begin_image(
- dev, pgs, pim, format,
- prect, pdcolor, pcpath,
- mem, pinfo);
+ goto fallback;
}
}
}
@@ -3730,7 +3663,9 @@ opvp_begin_image(
/* adjust matrix */
reverse_image = false;
ecode = gs_matrix_invert(&pim->ImageMatrix, &mtx);
- gs_matrix_multiply(&mtx, &ctm_only(pgs), &mtx);
+ if (pmat == NULL)
+ pmat = &ctm_only(pgs);
+ gs_matrix_multiply(&mtx, pmat, &mtx);
switch (FastImageMode) {
case FastImageNoCTM:
if ((mtx.xy==0)&&(mtx.yx==0)&& (mtx.yy>=0)) {
@@ -3963,8 +3898,7 @@ fallthrough:
if(apiEntry->opvpResetCTM) {
apiEntry->opvpResetCTM(printerContext); /* reset CTM */
}
- return gx_default_begin_image(dev, pgs, pim, format,
- prect, pdcolor, pcpath, mem, pinfo);
+ goto fallback;
}
}
@@ -3975,8 +3909,10 @@ fallthrough:
return ecode;
}
- return gx_default_begin_image(dev, pgs, pim, format, prect,
- pdcolor, pcpath, mem, pinfo);
+fallback:
+ gs_free_object(mem, vinfo, "opvp_end_image");
+ return gx_default_begin_typed_image(dev, pgs, pmat, pic, prect,
+ pdcolor, pcpath, mem, pinfo);
}
/*
@@ -4344,7 +4280,6 @@ opvp_image_plane_data(
}
}
}
-#if GS_VERSION_MAJOR >= 8
if (vinfo->bits_per_pixel == 24) { /* 24bit RGB color */
for (i = 0; i < height; i++) {
ptr = buf + raster_length * i;
@@ -4362,25 +4297,6 @@ opvp_image_plane_data(
}
}
}
-#else
- if (vinfo->bits_per_pixel == 24) { /* 24bit RGB color */
- for (i = 0; i < height; i++) {
- ptr = buf + raster_length * i;
- for (j = 0; j < vinfo->width; j++) {
- ptr[j*3+0] = frac2byte(gx_map_color_frac(pgs, byte2frac(ptr[j*3+0]), effective_transfer.colored.red));
- ptr[j*3+1] = frac2byte(gx_map_color_frac(pgs, byte2frac(ptr[j*3+1]), effective_transfer.colored.green));
- ptr[j*3+2] = frac2byte(gx_map_color_frac(pgs, byte2frac(ptr[j*3+2]), effective_transfer.colored.blue));
- }
- }
- } else if (vinfo->bits_per_pixel == 8) { /* 8bit Gray image */
- for (i = 0; i < height; i++) {
- ptr = buf + raster_length * i;
- for (j = 0; j < vinfo->width; j++) {
- ptr[j] = frac2byte(gx_map_color_frac(pgs, byte2frac(ptr[j]), effective_transfer.colored.gray));
- }
- }
- }
-#endif
/* call TansferDrawImage */
if (apiEntry->opvpTransferDrawImage) {
@@ -4721,29 +4637,22 @@ opvp_setlogop(
return 0;
}
-#if GS_VERSION_MAJOR >= 8
-/*--- added for Ghostscritp 8.15 ---*/
+/*--- added for Ghostscript 8.15 ---*/
static int
opvp_can_handle_hl_color(gx_device_vector * vdev,
const gs_gstate * pgs1, const gx_drawing_color * pdc)
{
return false; /* High level color is not implemented yet. */
}
-#endif
/*
* set fill color
*/
-#if GS_VERSION_MAJOR >= 8
static int
opvp_setfillcolor(
gx_device_vector *vdev,
const gs_gstate *pgs, /* added for gs 8.15 */
const gx_drawing_color *pdc)
-#else
-static int
-opvp_setfillcolor(gx_device_vector *vdev, const gx_drawing_color *pdc)
-#endif
{
gx_device_opvp *pdev = (gx_device_opvp *)vdev;
opvp_result_t r = -1;
@@ -4775,16 +4684,11 @@ opvp_setfillcolor(gx_device_vector *vdev, const gx_drawing_color *pdc)
/*
* set stroke color
*/
-#if GS_VERSION_MAJOR >= 8
static int
opvp_setstrokecolor(
gx_device_vector *vdev,
const gs_gstate *pgs, /* added for gs 8.15 */
const gx_drawing_color *pdc)
-#else
-static int
-opvp_setstrokecolor(gx_device_vector *vdev, const gx_drawing_color *pdc)
-#endif
{
gx_device_opvp *pdev = (gx_device_opvp *)vdev;
opvp_result_t r = -1;
diff --git a/contrib/pcl3/eprn/gdeveprn.h b/contrib/pcl3/eprn/gdeveprn.h
index e71799bd..b079d002 100644
--- a/contrib/pcl3/eprn/gdeveprn.h
+++ b/contrib/pcl3/eprn/gdeveprn.h
@@ -646,7 +646,6 @@ extern void eprn_set_media_flags(eprn_Device *dev, ms_MediaCode desired,
/*****************************************************************************/
-/* Device procedures */
extern dev_proc_open_device(eprn_open_device);
extern dev_proc_get_initial_matrix(eprn_get_initial_matrix);
extern dev_proc_output_page(eprn_output_page);
@@ -666,84 +665,6 @@ extern dev_proc_map_cmyk_color(eprn_map_cmyk_color_max);
extern dev_proc_map_cmyk_color(eprn_map_cmyk_color_glob);
extern dev_proc_fillpage(eprn_fillpage);
-/* Macro for initializing device procedure tables
-
- This macro corresponds to the macro prn_params_procs() which is used when
- basing a device directly on the prn device.
-
- If your device does not need all of the procedures in the argument list,
- use the following defaults:
- p_open: eprn_open_device
- p_close: eprn_close_device
- p_get_params: eprn_get_params
- p_put_params: eprn_put_params
- On the other hand, if your driver needs its own procedure in any of these
- cases its code must also call the appropriate default routine.
-*/
-#define eprn_procs_initdata(p_open, p_close, p_get_params, p_put_params) \
- p_open, /* open_device */ \
- eprn_get_initial_matrix, /* get_initial_matrix */ \
- NULL, /* sync_output */ \
- eprn_output_page, /* output_page */ \
- p_close, /* close_device */ \
- eprn_map_rgb_color_for_CMY_or_K, /* map_rgb_color */ \
- eprn_map_color_rgb, /* map_color_rgb */ \
- NULL, /* fill_rectangle */ \
- NULL, /* tile_rectangle */ \
- NULL, /* copy_mono */ \
- NULL, /* copy_color */ \
- NULL, /* draw_line */ \
- NULL, /* get_bits */ \
- p_get_params, /* get_params */ \
- p_put_params, /* put_params */ \
- eprn_map_cmyk_color_glob, /* map_cmyk_color */ \
- NULL, /* get_xfont_procs */ \
- NULL, /* get_xfont_device */ \
- NULL, /* map_rgb_alpha_color */ \
- gx_page_device_get_page_device, /* get_page_device */ \
- NULL, /* get_alpha_bits */ \
- NULL, /* copy_alpha */ \
- NULL, /* get_band */ \
- NULL, /* copy_rop */ \
- NULL, /* fill_path */ \
- NULL, /* stroke_path */ \
- NULL, /* fill_mask */ \
- NULL, /* fill_trapezoid */ \
- NULL, /* fill_parallelogram */ \
- NULL, /* fill_triangle */ \
- NULL, /* draw_thin_line */ \
- NULL, /* begin_image */ \
- NULL, /* image_data */ \
- NULL, /* end_image */ \
- NULL, /* strip_tile_rectangle */ \
- NULL, /* strip_copy_rop */ \
- NULL, /* get_clipping_box */ \
- NULL, /* begin_typed_image */ \
- NULL, /* get_bits_rectangle */ \
- NULL, /* map_color_rgb_alpha */ \
- NULL, /* create_compositor */ \
- NULL, /* get_hardware_params */ \
- NULL, /* text_begin */ \
- NULL, /* finish_copydevice */ \
- NULL, /* begin_transparency_group */ \
- NULL, /* end_transparency_group */ \
- NULL, /* begin_transparency_mask */ \
- NULL, /* end_transparency_mask */ \
- NULL, /* discard_transparency_layer */\
- NULL, /* get_color_mapping_procs */ \
- NULL, /* get_color_comp_index */ \
- NULL, /* encode_color */ \
- NULL, /* decode_color */ \
- NULL, /* pattern_manage */ \
- NULL, /* fill_rectangle_hl_color */ \
- NULL, /* include_color_space */ \
- NULL, /* fill_linear_color_scanline */\
- NULL, /* fill_linear_color_trapezoid */ \
- NULL, /* fill_linear_color_triangle */\
- NULL, /* update_spot_equivalent_colors */\
- NULL, /* ret_devn_params */ \
- eprn_fillpage /* fillpage */
- /* The remaining fields should be NULL. */
/*****************************************************************************/
diff --git a/contrib/pcl3/src/gdevpcl3.c b/contrib/pcl3/src/gdevpcl3.c
index 6b6468e0..5e3e8f80 100644
--- a/contrib/pcl3/src/gdevpcl3.c
+++ b/contrib/pcl3/src/gdevpcl3.c
@@ -92,10 +92,21 @@ static dev_proc_close_device(pcl3_close_device);
static dev_proc_get_params(pcl3_get_params);
static dev_proc_put_params(pcl3_put_params);
-/* Device procedure table */
-static gx_device_procs pcl3_procs = {
- eprn_procs_initdata(pcl3_open_device, pcl3_close_device, pcl3_get_params,
- pcl3_put_params)
+/* Device procedures */
+static void
+eprn_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, pcl3_open_device);
+ set_dev_proc(dev, get_initial_matrix, eprn_get_initial_matrix);
+ set_dev_proc(dev, close_device, pcl3_close_device);
+ set_dev_proc(dev, map_rgb_color, eprn_map_rgb_color_for_CMY_or_K);
+ set_dev_proc(dev, map_color_rgb, eprn_map_color_rgb);
+ set_dev_proc(dev, map_cmyk_color, eprn_map_cmyk_color_glob);
+ set_dev_proc(dev, get_params, pcl3_get_params);
+ set_dev_proc(dev, put_params, pcl3_put_params);
+ set_dev_proc(dev, fillpage, eprn_fillpage);
};
/* prn procedure implementations */
@@ -129,7 +140,7 @@ static void pcl3_flag_mismatch_reporter(
pcl3_Device gs_##dname##_device = { \
eprn_device_initdata( \
pcl3_Device, /* device type */ \
- pcl3_procs, /* static device procedure table */ \
+ eprn_initialize_device_procs, /* initialize dev_procs */ \
#dname, /* device name */ \
300.0, 300.0, /* horizontal and vertical resolution */\
pcl3_print_page, /* print page routine */ \
diff --git a/contrib/pcl3/src/pcl3opts.c b/contrib/pcl3/src/pcl3opts.c
index edd28ded..51e9cce3 100644
--- a/contrib/pcl3/src/pcl3opts.c
+++ b/contrib/pcl3/src/pcl3opts.c
@@ -754,6 +754,7 @@ static int action_CRD(gp_file *in, const pcl_Command *cmd, void *i) /* NLS: 30 *
for the reliability of the program! */
if (2 + buffer[1]*6 != cmd->i) {
emessage(30, "Illegal field length in Configure Raster Data command.\n");
+ free(buffer);
return -1;
}
diff --git a/cups/gdevcups.c b/cups/gdevcups.c
index 84c535fc..a9dbc142 100644
--- a/cups/gdevcups.c
+++ b/cups/gdevcups.c
@@ -312,94 +312,32 @@ typedef struct gx_device_cups_s
/* Used by cups_put_params(): */
} gx_device_cups;
-private gx_device_procs cups_procs =
+static void
+cups_initialize_device_procs(gx_device *dev)
{
- cups_open,
- cups_get_matrix,
- cups_sync_output,
- cups_output_page,
- cups_close,
+ set_dev_proc(dev, open_device, cups_open);
+ set_dev_proc(dev, get_initial_matrix, cups_get_matrix);
+ set_dev_proc(dev, sync_output, cups_sync_output);
+ set_dev_proc(dev, output_page, cups_output_page);
+ set_dev_proc(dev, close_device, cups_close);
#ifdef dev_t_proc_encode_color
- NULL, /* map_rgb_color */
- NULL, /* map_color_rgb */
+ set_dev_proc(dev, get_color_mapping_procs, cups_get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, cups_get_color_comp_index);
+ set_dev_proc(dev, encode_color, cups_encode_color);
+ set_dev_proc(dev, decode_color, cups_decode_color);
#else
- cups_map_rgb_color,
- cups_map_color_rgb,
-#endif /* dev_t_proc_encode_color */
- NULL, /* fill_rectangle */
- NULL, /* tile_rectangle */
- NULL, /* copy_mono */
- NULL, /* copy_color */
- NULL, /* draw_line */
- gx_default_get_bits,
- cups_get_params,
- cups_put_params,
-#ifdef dev_t_proc_encode_color
- NULL, /* map_cmyk_color */
-#else
- cups_map_cmyk_color,
-#endif /* dev_t_proc_encode_color */
- NULL, /* get_xfont_procs */
- NULL, /* get_xfont_device */
- NULL, /* map_rgb_alpha_color */
- gx_page_device_get_page_device,
- NULL, /* get_alpha_bits */
- NULL, /* copy_alpha */
- NULL, /* get_band */
- NULL, /* copy_rop */
- NULL, /* fill_path */
- NULL, /* stroke_path */
- NULL, /* fill_mask */
- NULL, /* fill_trapezoid */
- NULL, /* fill_parallelogram */
- NULL, /* fill_triangle */
- NULL, /* draw_thin_line */
- NULL, /* begin_image */
- NULL, /* image_data */
- NULL, /* end_image */
- NULL, /* strip_tile_rectangle */
- NULL, /* strip_copy_rop */
- NULL, /* get_clipping_box */
- NULL, /* begin_typed_image */
- NULL, /* get_bits_rectangle */
- NULL, /* map_color_rgb_alpha */
- NULL, /* create_compositor */
- NULL, /* get_hardware_params */
- NULL, /* text_begin */
- NULL, /* finish_copydevice */
- NULL, /* begin_transparency_group */
- NULL, /* end_transparency_group */
- NULL, /* begin_transparency_mask */
- NULL, /* end_transparency_mask */
- NULL, /* discard_transparency_layer */
-#ifdef dev_t_proc_encode_color
- cups_get_color_mapping_procs,
- cups_get_color_comp_index,
- cups_encode_color,
- cups_decode_color,
-#else
- NULL, /* get_color_mapping_procs */
- NULL, /* get_color_comp_index */
- NULL, /* encode_color */
- NULL, /* decode_color */
-#endif /* dev_t_proc_encode_color */
- NULL, /* pattern_manage */
- NULL, /* fill_rectangle_hl_color */
- NULL, /* include_color_space */
- NULL, /* fill_linear_color_scanline */
- NULL, /* fill_linear_color_trapezoid */
- NULL, /* fill_linear_color_triangle */
- NULL, /* update_spot_equivalent_colors */
- NULL, /* ret_devn_params */
- NULL, /* fillpage */
- NULL, /* push_transparency_state */
- NULL, /* pop_transparency_state */
- NULL, /* put_image */
- cups_spec_op
-};
+ set_dev_proc(dev, map_rgb_color, cups_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, cups_map_color_rgb);
+ set_dev_proc(dev, map_cmyk_color, cups_map_cmyk_color);
+#endif
+ set_dev_proc(dev, get_params, cups_get_params);
+ set_dev_proc(dev, put_params, cups_put_params);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
+ set_dev_proc(dev, dev_spec_op, cups_spec_op);
+}
-#define prn_device_body_copies(dtype, procs, dname, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_pages)\
- std_device_full_body_type(dtype, &procs, dname, &st_device_printer,\
+#define prn_device_body_copies(dtype, init, dname, w10, h10, xdpi, ydpi, lo, to, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_pages)\
+ std_device_full_body_type(dtype, init, dname, &st_device_printer,\
(int)((long)(w10) * (xdpi) / 10),\
(int)((long)(h10) * (ydpi) / 10),\
xdpi, ydpi,\
@@ -433,7 +371,7 @@ private gx_device_procs cups_procs =
#define gs_xxx_device(dname, mediaclass)\
prn_device_body_copies(gx_device_cups,/* type */\
- cups_procs, /* procedures */\
+ cups_initialize_device_procs,/* init */\
dname, /* device name */\
85, /* initial width */\
110, /* initial height */\
@@ -859,9 +797,10 @@ cups_get_color_comp_index(gx_device * pdev, const char * pname,
*/
private const gx_cm_color_map_procs * /* O - List of device procedures */
-cups_get_color_mapping_procs(const gx_device *pdev)
+cups_get_color_mapping_procs(const gx_device *pdev, const gx_device **tdev)
/* I - Device info */
{
+ *tdev = pdev;
return (&cups_color_mapping_procs);
}
#endif /* dev_t_proc_encode_color */
@@ -1254,7 +1193,7 @@ cups_map_cielab(double x, /* I - Raw color value */
*/
private void
-cups_map_cmyk(gx_device *pdev, /* I - Device info */
+cups_map_cmyk(const gx_device *pdev, /* I - Device info */
frac c, /* I - Cyan value */
frac m, /* I - Magenta value */
frac y, /* I - Yellow value */
@@ -1723,7 +1662,7 @@ cups_map_cmyk(gx_device *pdev, /* I - Device info */
*/
private void
-cups_map_gray(gx_device *pdev, /* I - Device info */
+cups_map_gray(const gx_device *pdev, /* I - Device info */
frac g, /* I - Grayscale value */
frac *out) /* O - Device colors */
{
@@ -1745,7 +1684,7 @@ cups_map_gray(gx_device *pdev, /* I - Device info */
*/
private void
-cups_map_rgb(gx_device *pdev,
+cups_map_rgb(const gx_device *pdev,
/* I - Device info */
const gs_gstate *pgs,/* I - Device state */
frac r, /* I - Red value */
@@ -4009,17 +3948,17 @@ cups_put_params(gx_device *pdev, /* I - Device info */
if (cups->landscape)
{
- width = (pdev->MediaSize[1] - pdev->HWMargins[1] - pdev->HWMargins[3]) *
- pdev->HWResolution[0] / 72.0f + 0.499f;
- height = (pdev->MediaSize[0] - pdev->HWMargins[0] - pdev->HWMargins[2]) *
- pdev->HWResolution[1] / 72.0f + 0.499f;
+ width = (int)((pdev->MediaSize[1] - pdev->HWMargins[1] - pdev->HWMargins[3]) *
+ pdev->HWResolution[0] / 72.0f + 0.499f);
+ height = (int)((pdev->MediaSize[0] - pdev->HWMargins[0] - pdev->HWMargins[2]) *
+ pdev->HWResolution[1] / 72.0f + 0.499f);
}
else
{
- width = (pdev->MediaSize[0] - pdev->HWMargins[0] - pdev->HWMargins[2]) *
- pdev->HWResolution[0] / 72.0f + 0.499f;
- height = (pdev->MediaSize[1] - pdev->HWMargins[1] - pdev->HWMargins[3]) *
- pdev->HWResolution[1] / 72.0f + 0.499f;
+ width = (int)((pdev->MediaSize[0] - pdev->HWMargins[0] - pdev->HWMargins[2]) *
+ pdev->HWResolution[0] / 72.0f + 0.499f);
+ height = (int)((pdev->MediaSize[1] - pdev->HWMargins[1] - pdev->HWMargins[3]) *
+ pdev->HWResolution[1] / 72.0f + 0.499f);
}
if (width <= 0 || height <= 0) {
@@ -4030,8 +3969,8 @@ cups_put_params(gx_device *pdev, /* I - Device info */
#ifdef CUPS_RASTER_SYNCv1
if (cups->header.cupsBorderlessScalingFactor > 1.0)
{
- width *= cups->header.cupsBorderlessScalingFactor;
- height *= cups->header.cupsBorderlessScalingFactor;
+ width = (int)(width * cups->header.cupsBorderlessScalingFactor);
+ height = (int)(height * cups->header.cupsBorderlessScalingFactor);
}
#endif /* CUPS_RASTER_SYNCv1 */
@@ -4086,8 +4025,8 @@ cups_put_params(gx_device *pdev, /* I - Device info */
* Set CUPS raster header values...
*/
- cups->header.HWResolution[0] = pdev->HWResolution[0];
- cups->header.HWResolution[1] = pdev->HWResolution[1];
+ cups->header.HWResolution[0] = (unsigned int)pdev->HWResolution[0];
+ cups->header.HWResolution[1] = (unsigned int)pdev->HWResolution[1];
#ifdef CUPS_RASTER_SYNCv1
@@ -4099,19 +4038,23 @@ cups_put_params(gx_device *pdev, /* I - Device info */
if ((sf = cups->header.cupsBorderlessScalingFactor) < 1.0)
sf = 1.0;
- cups->header.PageSize[0] = (cups_mediasize[1] * sf) + 0.5;
- cups->header.PageSize[1] = (cups_mediasize[0] * sf) + 0.5;
+ cups->header.PageSize[0] = (unsigned int)((cups_mediasize[1] * sf) + 0.5);
+ cups->header.PageSize[1] = (unsigned int)((cups_mediasize[0] * sf) + 0.5);
if (strcasecmp(cups->header.MediaClass, "PwgRaster") != 0)
{
- cups->header.Margins[0] = (cups_margins[1] * sf) + 0.5;
- cups->header.Margins[1] = (cups_margins[2] * sf) + 0.5;
- cups->header.ImagingBoundingBox[0] = (cups_margins[1] * sf) + 0.5;
- cups->header.ImagingBoundingBox[1] = (cups_margins[2] * sf) + 0.5;
- cups->header.ImagingBoundingBox[2] = ((cups_mediasize[1] -
- cups_margins[3]) * sf) + 0.5;
- cups->header.ImagingBoundingBox[3] = ((cups_mediasize[0] -
- cups_margins[0]) * sf) + 0.5;
+ cups->header.Margins[0] = (unsigned int)((cups_margins[1] * sf) + 0.5);
+ cups->header.Margins[1] = (unsigned int)((cups_margins[2] * sf) + 0.5);
+ cups->header.ImagingBoundingBox[0] =
+ (unsigned int)((cups_margins[1] * sf) + 0.5);
+ cups->header.ImagingBoundingBox[1] =
+ (unsigned int)((cups_margins[2] * sf) + 0.5);
+ cups->header.ImagingBoundingBox[2] =
+ (unsigned int)(((cups_mediasize[1] -
+ cups_margins[3]) * sf) + 0.5);
+ cups->header.ImagingBoundingBox[3] =
+ (unsigned int)(((cups_mediasize[0] -
+ cups_margins[0]) * sf) + 0.5);
cups->header.cupsImagingBBox[0] = cups_margins[1];
cups->header.cupsImagingBBox[1] = cups_margins[2];
cups->header.cupsImagingBBox[2] = cups_mediasize[1] - cups_margins[3];
@@ -4136,19 +4079,23 @@ cups_put_params(gx_device *pdev, /* I - Device info */
if ((sf = cups->header.cupsBorderlessScalingFactor) < 1.0)
sf = 1.0;
- cups->header.PageSize[0] = (cups_mediasize[0] * sf) + 0.5;
- cups->header.PageSize[1] = (cups_mediasize[1] * sf) + 0.5;
+ cups->header.PageSize[0] = (unsigned int)((cups_mediasize[0] * sf) + 0.5);
+ cups->header.PageSize[1] = (unsigned int)((cups_mediasize[1] * sf) + 0.5);
if (strcasecmp(cups->header.MediaClass, "PwgRaster") != 0)
{
cups->header.Margins[0] = (cups_margins[0] * sf) + 0.5;
cups->header.Margins[1] = (cups_margins[1] * sf) + 0.5;
- cups->header.ImagingBoundingBox[0] = (cups_margins[0] * sf) + 0.5;
- cups->header.ImagingBoundingBox[1] = (cups_margins[1] * sf) + 0.5;
- cups->header.ImagingBoundingBox[2] = ((cups_mediasize[0] -
- cups_margins[2]) * sf) + 0.5;
- cups->header.ImagingBoundingBox[3] = ((cups_mediasize[1] -
- cups_margins[3]) * sf) + 0.5;
+ cups->header.ImagingBoundingBox[0] =
+ (unsigned int)((cups_margins[0] * sf) + 0.5);
+ cups->header.ImagingBoundingBox[1] =
+ (unsigned int)((cups_margins[1] * sf) + 0.5);
+ cups->header.ImagingBoundingBox[2] =
+ (unsigned int)(((cups_mediasize[0] -
+ cups_margins[2]) * sf) + 0.5);
+ cups->header.ImagingBoundingBox[3] =
+ (unsigned int)(((cups_mediasize[1] -
+ cups_margins[3]) * sf) + 0.5);
cups->header.cupsImagingBBox[0] = cups_margins[0];
cups->header.cupsImagingBBox[1] = cups_margins[1];
cups->header.cupsImagingBBox[2] = cups_mediasize[0] - cups_margins[2];
diff --git a/demos/csharp/README.txt b/demos/csharp/README.txt
index 1665c7cd..e4ef3051 100644
--- a/demos/csharp/README.txt
+++ b/demos/csharp/README.txt
@@ -28,5 +28,6 @@ performance on rendering only the visible pages when PDF is the document source.
PCL and PS file formats are streamed and so cannot work in this manner without
a severe performance penalty.
+The Linux application is built using the make.sh bash script.
diff --git a/demos/csharp/api/ghostapi.cs b/demos/csharp/api/ghostapi.cs
index a3491fd7..7a563edc 100644
--- a/demos/csharp/api/ghostapi.cs
+++ b/demos/csharp/api/ghostapi.cs
@@ -1,4 +1,19 @@
-using System; /* IntPtr */
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System; /* IntPtr */
using System.Runtime.InteropServices; /* DLLImport */
namespace GhostAPI
@@ -42,13 +57,13 @@ namespace GhostAPI
public const int DISPLAY_COLORS_RGB = (1 << 2);
public const int DISPLAY_DEPTH_8 = (1 << 11);
public const int DISPLAY_LITTLEENDIAN = (1 << 16);
- public const int DISPLAY_BIGENDIAN = (0 << 16);
+ public const int DISPLAY_BIGENDIAN = (0 << 16);
}
- class ghostapi
+ class GSAPI
{
#if MONO
- private const string lib_dll = "libgpdl.so";
+ private const string lib_dll = "libgpdl.so";
#else
#if WIN64
#if !GHOSTPDL
@@ -64,8 +79,8 @@ namespace GhostAPI
#endif
#endif
#endif
- /* Callback proto for stdio */
- public delegate int gs_stdio_handler(IntPtr caller_handle, IntPtr buffer, int len);
+ /* Callback proto for stdio */
+ public delegate int gs_stdio_handler(IntPtr caller_handle, IntPtr buffer, int len);
/* Callback proto for poll function */
public delegate int gsPollHandler(IntPtr caller_handle);
@@ -185,7 +200,7 @@ namespace GhostAPI
[DllImport(lib_dll, EntryPoint = "gsapi_enumerate_params", CharSet = CharSet.Ansi,
CallingConvention = CallingConvention.StdCall)]
- public static extern int gsapi_enumerate_params(IntPtr instance, out IntPtr inter,
+ public static extern int gsapi_enumerate_params(IntPtr instance, out IntPtr iter,
out IntPtr key, IntPtr type);
[DllImport(lib_dll, EntryPoint = "gsapi_add_control_path", CharSet = CharSet.Ansi,
diff --git a/demos/csharp/api/ghostmono.cs b/demos/csharp/api/ghostmono.cs
index 850ff039..80723e0c 100644
--- a/demos/csharp/api/ghostmono.cs
+++ b/demos/csharp/api/ghostmono.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.Runtime.InteropServices; /* Marshaling */
using System.Threading;
using System.Collections.Generic; /* Use of List */
@@ -74,7 +89,7 @@ namespace GhostMono
}
}
- class ghostsharp
+ class GSMONO
{
public class GhostscriptException : Exception
{
@@ -153,7 +168,7 @@ namespace GhostMono
{
m_params.currpage += 1;
Gtk.Application.Invoke(delegate {
- gsPageRenderedMain(m_pagewidth, m_pageheight, m_pageraster, m_pageptr, m_params);
+ PageRenderedCallBack(m_pagewidth, m_pageheight, m_pageraster, m_pageptr, m_params);
});
return 0;
}
@@ -205,7 +220,7 @@ namespace GhostMono
private int stdin_callback(IntPtr handle, IntPtr pointer, int count)
{
- String output = Marshal.PtrToStringAnsi(pointer);
+ Marshal.PtrToStringAnsi(pointer);
return count;
}
@@ -216,7 +231,7 @@ namespace GhostMono
{
output = Marshal.PtrToStringAnsi(pointer);
Gtk.Application.Invoke(delegate {
- gsIOUpdateMain(output, count);
+ StdIOCallBack(output, count);
});
}
catch (Exception excep2)
@@ -232,7 +247,7 @@ namespace GhostMono
{
String output = Marshal.PtrToStringAnsi(pointer);
Gtk.Application.Invoke(delegate {
- gsIOUpdateMain(output, count);
+ StdIOCallBack(output, count);
});
return count;
@@ -252,26 +267,29 @@ namespace GhostMono
IntPtr ptr_display_struct;
/* Callbacks to Main */
- internal delegate void gsDLLProblem(String mess);
- internal event gsDLLProblem gsDLLProblemMain;
+ internal delegate void DLLProblem(String mess);
+ internal event DLLProblem DLLProblemCallBack;
- internal delegate void gsIOCallBackMain(String mess, int len);
- internal event gsIOCallBackMain gsIOUpdateMain;
+ internal delegate void StdIO(String mess, int len);
+ internal event StdIO StdIOCallBack;
- internal delegate void gsCallBackMain(gsThreadCallBack info);
- internal event gsCallBackMain gsUpdateMain;
+ internal delegate void Progress(gsThreadCallBack info);
+ internal event Progress ProgressCallBack;
- internal delegate void gsCallBackPageRenderedMain(int width, int height, int raster,
+ internal delegate void PageRendered(int width, int height, int raster,
IntPtr data, gsParamState_t state);
- internal event gsCallBackPageRenderedMain gsPageRenderedMain;
-
+ internal event PageRendered PageRenderedCallBack;
- /* From my understanding you cannot pin delegates. These need to be declared
+ /* From my understanding you cannot pin delegates. These need to be declared
* as members to keep a reference to the delegates and avoid their possible GC.
- * since the C# GC has no idea that GS has a reference to these items. */
- readonly gs_stdio_handler raise_stdin;
- readonly gs_stdio_handler raise_stdout;
- readonly gs_stdio_handler raise_stderr;
+ * since the C# GC has no idea that GS has a reference to these items. For some
+ * reason the Mono compiler throws a CS0414 warning about these not being assigned
+ * even though they are */
+#pragma warning disable 0414
+ GSAPI.gs_stdio_handler raise_stdin;
+ GSAPI.gs_stdio_handler raise_stdout;
+ GSAPI.gs_stdio_handler raise_stderr;
+#pragma warning restore 0414
/* Ghostscript display callback struct */
public struct display_callback_t
@@ -290,7 +308,8 @@ namespace GhostMono
public display_memalloc_del display_memalloc;
public display_memfree_del display_memfree;
};
- public ghostsharp()
+
+ public GSMONO()
{
m_worker = null;
gsInstance = IntPtr.Zero;
@@ -331,7 +350,7 @@ namespace GhostMono
gsThreadCallBack info = new gsThreadCallBack(true, 100, Params);
m_worker_busy = false;
Gtk.Application.Invoke(delegate {
- gsUpdateMain(info);
+ ProgressCallBack(info);
});
}
@@ -341,7 +360,7 @@ namespace GhostMono
/* Callback with progress */
gsThreadCallBack info = new gsThreadCallBack(false, percent, Params);
Gtk.Application.Invoke(delegate {
- gsUpdateMain(info);
+ ProgressCallBack(info);
});
}
@@ -349,7 +368,7 @@ namespace GhostMono
private void gsErrorReport(string message)
{
Gtk.Application.Invoke(delegate {
- gsDLLProblemMain(message);;
+ DLLProblemCallBack(message);;
});
m_worker_busy = false;
}
@@ -366,17 +385,17 @@ namespace GhostMono
try
{
- code = ghostapi.gsapi_new_instance(out gsInstance, IntPtr.Zero);
+ code = GSAPI.gsapi_new_instance(out gsInstance, IntPtr.Zero);
if (code < 0)
{
throw new GhostscriptException("gsFileSync: gsapi_new_instance error");
}
- code = ghostapi.gsapi_set_stdio(gsInstance, stdin_callback, stdout_callback, stderr_callback);
+ code = GSAPI.gsapi_set_stdio(gsInstance, stdin_callback, stdout_callback, stderr_callback);
if (code < 0)
{
throw new GhostscriptException("gsFileSync: gsapi_set_stdio error");
}
- code = ghostapi.gsapi_set_arg_encoding(gsInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
+ code = GSAPI.gsapi_set_arg_encoding(gsInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
if (code < 0)
{
throw new GhostscriptException("gsFileSync: gsapi_set_arg_encoding error");
@@ -397,8 +416,8 @@ namespace GhostMono
argPtrsStable = GCHandle.Alloc(argPtrs, GCHandleType.Pinned);
fullcommand = "Command Line: " + fullcommand + "\n";
- gsIOUpdateMain(fullcommand, fullcommand.Length);
- code = ghostapi.gsapi_init_with_args(gsInstance, num_params, argPtrsStable.AddrOfPinnedObject());
+ StdIOCallBack(fullcommand, fullcommand.Length);
+ code = GSAPI.gsapi_init_with_args(gsInstance, num_params, argPtrsStable.AddrOfPinnedObject());
if (code < 0 && code != gsConstants.E_QUIT)
{
throw new GhostscriptException("gsFileSync: gsapi_init_with_args error");
@@ -435,11 +454,11 @@ namespace GhostMono
}
argPtrsStable.Free();
- int code1 = ghostapi.gsapi_exit(gsInstance);
+ int code1 = GSAPI.gsapi_exit(gsInstance);
if ((code == 0) || (code == gsConstants.E_QUIT))
code = code1;
- ghostapi.gsapi_delete_instance(gsInstance);
+ GSAPI.gsapi_delete_instance(gsInstance);
in_params.return_code = code;
if ((code == 0) || (code == gsConstants.E_QUIT))
@@ -472,17 +491,17 @@ namespace GhostMono
try
{
- code = ghostapi.gsapi_new_instance(out gsInstance, IntPtr.Zero);
+ code = GSAPI.gsapi_new_instance(out gsInstance, IntPtr.Zero);
if (code < 0)
{
throw new GhostscriptException("gsFileAsync: gsapi_new_instance error");
}
- code = ghostapi.gsapi_set_stdio(gsInstance, stdin_callback, stdout_callback, stderr_callback);
+ code = GSAPI.gsapi_set_stdio(gsInstance, stdin_callback, stdout_callback, stderr_callback);
if (code < 0)
{
throw new GhostscriptException("gsFileAsync: gsapi_set_stdio error");
}
- code = ghostapi.gsapi_set_arg_encoding(gsInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
+ code = GSAPI.gsapi_set_arg_encoding(gsInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
if (code < 0)
{
throw new GhostscriptException("gsFileAsync: gsapi_set_arg_encoding error");
@@ -503,8 +522,8 @@ namespace GhostMono
argPtrsStable = GCHandle.Alloc(argPtrs, GCHandleType.Pinned);
fullcommand = "Command Line: " + fullcommand + "\n";
- gsIOUpdateMain(fullcommand, fullcommand.Length);
- code = ghostapi.gsapi_init_with_args(gsInstance, num_params, argPtrsStable.AddrOfPinnedObject());
+ StdIOCallBack(fullcommand, fullcommand.Length);
+ code = GSAPI.gsapi_init_with_args(gsInstance, num_params, argPtrsStable.AddrOfPinnedObject());
if (code < 0)
{
throw new GhostscriptException("gsFileAsync: gsapi_init_with_args error");
@@ -543,11 +562,11 @@ namespace GhostMono
}
argPtrsStable.Free();
- int code1 = ghostapi.gsapi_exit(gsInstance);
+ int code1 = GSAPI.gsapi_exit(gsInstance);
if ((code == 0) || (code == gsConstants.E_QUIT))
code = code1;
- ghostapi.gsapi_delete_instance(gsInstance);
+ GSAPI.gsapi_delete_instance(gsInstance);
Params.return_code = code;
if ((code == 0) || (code == gsConstants.E_QUIT))
@@ -586,7 +605,6 @@ namespace GhostMono
int exitcode = 0;
var Feed = new GCHandle();
var FeedPtr = new IntPtr();
- String[] strParams = new String[num_params];
FileStream fs = null;
bool cleanup = true;
@@ -596,24 +614,24 @@ namespace GhostMono
fs = new FileStream(Params.inputfile, FileMode.Open);
var len = (int)fs.Length;
- code = ghostapi.gsapi_new_instance(out gsInstance, IntPtr.Zero);
+ code = GSAPI.gsapi_new_instance(out gsInstance, IntPtr.Zero);
if (code < 0)
{
throw new GhostscriptException("gsBytesAsync: gsapi_new_instance error");
}
- code = ghostapi.gsapi_set_stdio(gsInstance, stdin_callback, stdout_callback, stderr_callback);
+ code = GSAPI.gsapi_set_stdio(gsInstance, stdin_callback, stdout_callback, stderr_callback);
if (code < 0)
{
throw new GhostscriptException("gsBytesAsync: gsapi_set_stdio error");
}
- code = ghostapi.gsapi_set_arg_encoding(gsInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
+ code = GSAPI.gsapi_set_arg_encoding(gsInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
if (code < 0)
{
throw new GhostscriptException("gsBytesAsync: gsapi_set_arg_encoding error");
}
/* Now convert our Strings to char* and get pinned handles to these.
- * This keeps the c# GC from moving stuff around on us */
+ * This keeps the c# GC from moving stuff around on us */
String fullcommand = "";
for (int k = 0; k < num_params; k++)
{
@@ -627,8 +645,8 @@ namespace GhostMono
argPtrsStable = GCHandle.Alloc(argPtrs, GCHandleType.Pinned);
fullcommand = "Command Line: " + fullcommand + "\n";
- gsIOUpdateMain(fullcommand, fullcommand.Length);
- code = ghostapi.gsapi_init_with_args(gsInstance, num_params, argPtrsStable.AddrOfPinnedObject());
+ StdIOCallBack(fullcommand, fullcommand.Length);
+ code = GSAPI.gsapi_init_with_args(gsInstance, num_params, argPtrsStable.AddrOfPinnedObject());
if (code < 0)
{
throw new GhostscriptException("gsBytesAsync: gsapi_init_with_args error");
@@ -645,9 +663,8 @@ namespace GhostMono
int count;
double perc;
int total = 0;
- int ret_code;
- ret_code = ghostapi.gsapi_run_string_begin(gsInstance, 0, ref exitcode);
+ GSAPI.gsapi_run_string_begin(gsInstance, 0, ref exitcode);
if (exitcode < 0)
{
code = exitcode;
@@ -656,7 +673,7 @@ namespace GhostMono
while ((count = fs.Read(Buffer, 0, gsConstants.GS_READ_BUFFER)) > 0)
{
- ret_code = ghostapi.gsapi_run_string_continue(gsInstance, FeedPtr, count, 0, ref exitcode);
+ GSAPI.gsapi_run_string_continue(gsInstance, FeedPtr, count, 0, ref exitcode);
if (exitcode < 0)
{
code = exitcode;
@@ -667,7 +684,7 @@ namespace GhostMono
perc = 100.0 * (double)total / (double)len;
gsProgressChanged(Params, (int)perc);
}
- ret_code = ghostapi.gsapi_run_string_end(gsInstance, 0, ref exitcode);
+ GSAPI.gsapi_run_string_end(gsInstance, 0, ref exitcode);
if (exitcode < 0)
{
code = exitcode;
@@ -716,11 +733,11 @@ namespace GhostMono
Feed.Free();
/* gs clean up */
- int code1 = ghostapi.gsapi_exit(gsInstance);
+ int code1 = GSAPI.gsapi_exit(gsInstance);
if ((code == 0) || (code == gsConstants.E_QUIT))
code = code1;
- ghostapi.gsapi_delete_instance(gsInstance);
+ GSAPI.gsapi_delete_instance(gsInstance);
Params.return_code = code;
if ((code == 0) || (code == gsConstants.E_QUIT))
@@ -758,25 +775,25 @@ namespace GhostMono
try
{
- code = ghostapi.gsapi_new_instance(out dispInstance, IntPtr.Zero);
+ code = GSAPI.gsapi_new_instance(out dispInstance, IntPtr.Zero);
if (code < 0)
{
throw new GhostscriptException("DisplayDeviceAsync: gsapi_new_instance error");
}
- code = ghostapi.gsapi_set_stdio(dispInstance, stdin_callback, stdout_callback, stderr_callback);
+ code = GSAPI.gsapi_set_stdio(dispInstance, stdin_callback, stdout_callback, stderr_callback);
if (code < 0)
{
throw new GhostscriptException("DisplayDeviceAsync: gsapi_set_stdio error");
}
- code = ghostapi.gsapi_set_arg_encoding(dispInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
+ code = GSAPI.gsapi_set_arg_encoding(dispInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
if (code < 0)
{
throw new GhostscriptException("DisplayDeviceAsync: gsapi_set_arg_encoding error");
}
- code = ghostapi.gsapi_set_display_callback(dispInstance, ptr_display_struct);
+ code = GSAPI.gsapi_set_display_callback(dispInstance, ptr_display_struct);
if (code < 0)
{
throw new GhostscriptException("DisplayDeviceAsync: gsapi_set_display_callback error");
@@ -793,8 +810,8 @@ namespace GhostMono
argPtrsStable = GCHandle.Alloc(argPtrs, GCHandleType.Pinned);
fullcommand = "Command Line: " + fullcommand + "\n";
- gsIOUpdateMain(fullcommand, fullcommand.Length);
- code = ghostapi.gsapi_init_with_args(dispInstance, num_params, argPtrsStable.AddrOfPinnedObject());
+ StdIOCallBack(fullcommand, fullcommand.Length);
+ code = GSAPI.gsapi_init_with_args(dispInstance, num_params, argPtrsStable.AddrOfPinnedObject());
if (code < 0)
{
throw new GhostscriptException("DisplayDeviceAsync: gsapi_init_with_args error");
@@ -820,7 +837,7 @@ namespace GhostMono
gsErrorReport("Exception: " + except.Message);
gsparams.result = GS_Result_t.gsFAILED;
if (dispInstance != IntPtr.Zero)
- ghostapi.gsapi_delete_instance(dispInstance);
+ GSAPI.gsapi_delete_instance(dispInstance);
dispInstance = IntPtr.Zero;
}
catch (Exception except)
@@ -828,7 +845,7 @@ namespace GhostMono
gsErrorReport("Exception: " + except.Message);
gsparams.result = GS_Result_t.gsFAILED;
if (dispInstance != IntPtr.Zero)
- ghostapi.gsapi_delete_instance(dispInstance);
+ GSAPI.gsapi_delete_instance(dispInstance);
dispInstance = IntPtr.Zero;
}
finally
@@ -915,7 +932,7 @@ namespace GhostMono
try
{
- if (ghostapi.gsapi_revision(ref vers, size) == 0)
+ if (GSAPI.gsapi_revision(ref vers, size) == 0)
{
String product = Marshal.PtrToStringAnsi(vers.product);
String output;
@@ -986,8 +1003,38 @@ namespace GhostMono
}
/* Launch a thread rendering all the pages with the display device
+ * to collect thumbnail images via init_with_args. */
+ public gsStatus DisplayDeviceRenderThumbs(String fileName, double zoom, bool aa)
+ {
+ gsParamState_t gsparams = new gsParamState_t();
+ int format = (gsConstants.DISPLAY_COLORS_RGB |
+ gsConstants.DISPLAY_DEPTH_8 |
+ gsConstants.DISPLAY_LITTLEENDIAN);
+ int resolution = (int)(72.0 * zoom + 0.5);
+ GS_Task_t task = GS_Task_t.DISPLAY_DEV_THUMBS_NON_PDF;
+
+ gsparams.args = new List<string>();
+ gsparams.args.Add("gs");
+ gsparams.args.Add("-dFirstPage=1"); /* To ensure gdevflp is setup */
+ gsparams.args.Add("-r" + resolution);
+ if (aa)
+ {
+ gsparams.args.Add("-dTextAlphaBits=4");
+ gsparams.args.Add("-dGraphicsAlphaBits=4");
+ }
+ gsparams.args.Add("-sDEVICE=display");
+ gsparams.args.Add("-dDisplayFormat=" + format);
+ gsparams.args.Add("-f");
+ gsparams.args.Add(fileName);
+ gsparams.task = task;
+ gsparams.currpage = 0;
+ m_params.currpage = 0;
+ return RunGhostscriptAsync(gsparams);
+ }
+
+ /* Launch a thread rendering all the pages with the display device
* to collect thumbnail images or full resolution. */
- public gsStatus gsDisplayDeviceRenderAll(String fileName, double zoom, bool aa, GS_Task_t task)
+ public gsStatus DisplayDeviceRenderAll(String fileName, double zoom, bool aa, GS_Task_t task)
{
gsParamState_t gsparams = new gsParamState_t();
int format = (gsConstants.DISPLAY_COLORS_RGB |
@@ -1017,10 +1064,9 @@ namespace GhostMono
return RunGhostscriptAsync(gsparams);
}
-
/* Launch a thread rendering a set of pages with the display device. For use with languages
that can be indexed via pages which include PDF and XPS */
- public gsStatus gsDisplayDeviceRenderPages(String fileName, int first_page, int last_page, double zoom)
+ public gsStatus DisplayDeviceRenderPages(String fileName, int first_page, int last_page, double zoom)
{
gsParamState_t gsparams = new gsParamState_t();
int format = (gsConstants.DISPLAY_COLORS_RGB |
@@ -1048,6 +1094,72 @@ namespace GhostMono
return RunGhostscriptAsync(gsparams);
}
+ /* Set up the display device ahead of time */
+ public gsParamState_t DisplayDeviceOpen()
+ {
+ int code;
+ gsParamState_t gsparams = new gsParamState_t();
+ gsparams.result = GS_Result_t.gsOK;
+
+ if (dispInstance != IntPtr.Zero)
+ return gsparams;
+
+ try
+ {
+ code = GSAPI.gsapi_new_instance(out dispInstance, IntPtr.Zero);
+ if (code < 0)
+ {
+ throw new GhostscriptException("DisplayDeviceOpen: gsapi_new_instance error");
+ }
+
+ code = GSAPI.gsapi_set_stdio(dispInstance, raise_stdin, raise_stdout, raise_stderr);
+ if (code < 0)
+ {
+ throw new GhostscriptException("DisplayDeviceOpen: gsapi_set_stdio error");
+ }
+
+ code = GSAPI.gsapi_set_arg_encoding(dispInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
+ if (code < 0)
+ {
+ throw new GhostscriptException("DisplayDeviceOpen: gsapi_set_arg_encoding error");
+ }
+
+ code = GSAPI.gsapi_set_display_callback(dispInstance, ptr_display_struct);
+ if (code < 0)
+ {
+ throw new GhostscriptException("DisplayDeviceOpen: gsapi_set_display_callback error");
+ }
+ }
+
+ catch (DllNotFoundException except)
+ {
+ DLLProblemCallBack("Exception: " + except.Message);
+ gsparams.result = GS_Result_t.gsFAILED;
+ }
+ catch (BadImageFormatException except)
+ {
+ DLLProblemCallBack("Exception: " + except.Message);
+ gsparams.result = GS_Result_t.gsFAILED;
+ }
+ catch (GhostscriptException except)
+ {
+ DLLProblemCallBack("Exception: " + except.Message);
+ gsparams.result = GS_Result_t.gsFAILED;
+ if (dispInstance != IntPtr.Zero)
+ GSAPI.gsapi_delete_instance(dispInstance);
+ dispInstance = IntPtr.Zero;
+ }
+ catch (Exception except)
+ {
+ DLLProblemCallBack("Exception: " + except.Message);
+ gsparams.result = GS_Result_t.gsFAILED;
+ if (dispInstance != IntPtr.Zero)
+ GSAPI.gsapi_delete_instance(dispInstance);
+ dispInstance = IntPtr.Zero;
+ }
+ return gsparams;
+ }
+
/* Close the display device and delete the instance */
public gsParamState_t DisplayDeviceClose()
{
@@ -1058,11 +1170,11 @@ namespace GhostMono
try
{
- int code1 = ghostapi.gsapi_exit(dispInstance);
+ int code1 = GSAPI.gsapi_exit(dispInstance);
if ((code == 0) || (code == gsConstants.E_QUIT))
code = code1;
- ghostapi.gsapi_delete_instance(dispInstance);
+ GSAPI.gsapi_delete_instance(dispInstance);
dispInstance = IntPtr.Zero;
}
@@ -1071,7 +1183,6 @@ namespace GhostMono
gsErrorReport("Exception: " + except.Message);
out_params.result = GS_Result_t.gsFAILED;
}
-
return out_params;
}
diff --git a/demos/csharp/api/ghostnet.cs b/demos/csharp/api/ghostnet.cs
index f033941f..ab1c44f2 100644
--- a/demos/csharp/api/ghostnet.cs
+++ b/demos/csharp/api/ghostnet.cs
@@ -1,10 +1,24 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.Runtime.InteropServices; /* Marshaling */
using System.ComponentModel; /* Background threading */
using System.Collections.Generic; /* Use of List */
using System.IO; /* Use of path */
using GhostAPI; /* Use of Ghostscript API */
-using ghostnet_wpf_example; /* For Print control */
namespace GhostNET
{
@@ -77,7 +91,7 @@ public class gsEventArgs : EventArgs
}
}
- class ghostsharp
+ class GSNET
{
public class GhostscriptException : Exception
{
@@ -167,7 +181,7 @@ public class gsEventArgs : EventArgs
private int display_page(IntPtr handle, IntPtr device, int copies, int flush)
{
m_params.currpage += 1;
- gsPageRenderedMain(m_pagewidth, m_pageheight, m_pageraster, m_pageptr, m_params);
+ PageRenderedCallBack(m_pagewidth, m_pageheight, m_pageraster, m_pageptr, m_params);
return 0;
}
@@ -220,24 +234,24 @@ public class gsEventArgs : EventArgs
private int stdout_callback(IntPtr handle, IntPtr pointer, int count)
{
- String output = null;
- try
- {
- output = Marshal.PtrToStringAnsi(pointer);
- }
- catch (Exception except)
- {
- var mess = except.Message;
- }
-
- try
- {
- gsIOUpdateMain(output, count);
- }
- catch (Exception excep2)
- {
- var mess = excep2.Message;
- }
+ String output = null;
+ try
+ {
+ output = Marshal.PtrToStringAnsi(pointer);
+ }
+ catch (Exception except)
+ {
+ var mess = except.Message;
+ }
+
+ try
+ {
+ StdIOCallBack(output, count);
+ }
+ catch (Exception excep2)
+ {
+ var mess = excep2.Message;
+ }
/* Callback for progress on XPS creation */
if (m_params.task == GS_Task_t.CREATE_XPS)
@@ -288,7 +302,7 @@ public class gsEventArgs : EventArgs
private int stderr_callback(IntPtr handle, IntPtr pointer, int count)
{
String output = Marshal.PtrToStringAnsi(pointer);
- gsIOUpdateMain(output, count);
+ StdIOCallBack(output, count);
return count;
}
@@ -302,33 +316,31 @@ public class gsEventArgs : EventArgs
int m_pageraster;
gsParamState_t m_displaystate;
-
display_callback_t m_display_callback;
IntPtr ptr_display_struct;
- /* Callbacks to Main */
- internal delegate void gsDLLProblem(String mess);
- internal event gsDLLProblem gsDLLProblemMain;
+ /* Callbacks to application */
+ internal delegate void DLLProblem(String mess);
+ internal event DLLProblem DLLProblemCallBack;
- internal delegate void gsIOCallBackMain(String mess, int len);
- internal event gsIOCallBackMain gsIOUpdateMain;
+ internal delegate void StdIO(String mess, int len);
+ internal event StdIO StdIOCallBack;
- internal delegate void gsCallBackMain(gsEventArgs info);
- internal event gsCallBackMain gsUpdateMain;
+ internal delegate void Progress(gsEventArgs info);
+ internal event Progress ProgressCallBack;
- internal delegate void gsCallBackPageRenderedMain(int width, int height, int raster,
+ internal delegate void PageRendered(int width, int height, int raster,
IntPtr data, gsParamState_t state);
- internal event gsCallBackPageRenderedMain gsPageRenderedMain;
+ internal event PageRendered PageRenderedCallBack;
-
/* From my understanding you cannot pin delegates. These need to be declared
* as members to keep a reference to the delegates and avoid their possible GC.
* since the C# GC has no idea that GS has a reference to these items. While the
- * methods themselves dont move, apparently the address of the translation code
+ * methods themselves don't move, apparently the address of the translation code
* is what is passed, and one of these abstractions can be GC or relocated. */
- ghostapi.gs_stdio_handler raise_stdin;
- ghostapi.gs_stdio_handler raise_stdout;
- ghostapi.gs_stdio_handler raise_stderr;
+ GSAPI.gs_stdio_handler raise_stdin;
+ GSAPI.gs_stdio_handler raise_stdout;
+ GSAPI.gs_stdio_handler raise_stderr;
/* Ghostscript display callback struct */
public struct display_callback_t
@@ -347,7 +359,8 @@ public class gsEventArgs : EventArgs
public display_memalloc_del display_memalloc;
public display_memfree_del display_memfree;
};
- public ghostsharp()
+
+ public GSNET()
{
m_worker = null;
gsInstance = IntPtr.Zero;
@@ -384,7 +397,6 @@ public class gsEventArgs : EventArgs
Marshal.StructureToPtr(m_display_callback, ptr_display_struct, false);
}
-
/* Callback upon worker all done */
private void gsCompleted(object sender, RunWorkerCompletedEventArgs e)
{
@@ -420,7 +432,7 @@ public class gsEventArgs : EventArgs
gsIOUpdateMain(this, bound, bound.Length);
gsIOUpdateMain(this, stack, stack.Length); */
String output = "Ghostscript DLL Invalid Access.";
- gsDLLProblemMain(output);
+ DLLProblemCallBack(output);
return;
}
switch (Params.task)
@@ -452,7 +464,7 @@ public class gsEventArgs : EventArgs
Value = (gsParamState_t)e.Result;
info = new gsEventArgs(true, 100, Value);
}
- gsUpdateMain(info);
+ ProgressCallBack(info);
}
/* Callback as worker progresses */
@@ -460,7 +472,7 @@ public class gsEventArgs : EventArgs
{
/* Callback with progress */
gsEventArgs info = new gsEventArgs(false, e.ProgressPercentage, (gsParamState_t) e.UserState);
- gsUpdateMain(info);
+ ProgressCallBack(info);
}
private gsParamState_t gsFileSync(gsParamState_t in_params)
{
@@ -474,17 +486,17 @@ public class gsEventArgs : EventArgs
try
{
- code = ghostapi.gsapi_new_instance(out gsInstance, IntPtr.Zero);
+ code = GSAPI.gsapi_new_instance(out gsInstance, IntPtr.Zero);
if (code < 0)
{
throw new GhostscriptException("gsFileSync: gsapi_new_instance error");
}
- code = ghostapi.gsapi_set_stdio(gsInstance, stdin_callback, stdout_callback, stderr_callback);
+ code = GSAPI.gsapi_set_stdio(gsInstance, stdin_callback, stdout_callback, stderr_callback);
if (code < 0)
{
throw new GhostscriptException("gsFileSync: gsapi_set_stdio error");
}
- code = ghostapi.gsapi_set_arg_encoding(gsInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
+ code = GSAPI.gsapi_set_arg_encoding(gsInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
if (code < 0)
{
throw new GhostscriptException("gsFileSync: gsapi_set_arg_encoding error");
@@ -505,8 +517,8 @@ public class gsEventArgs : EventArgs
argPtrsStable = GCHandle.Alloc(argPtrs, GCHandleType.Pinned);
fullcommand = "Command Line: " + fullcommand + "\n";
- gsIOUpdateMain(fullcommand, fullcommand.Length);
- code = ghostapi.gsapi_init_with_args(gsInstance, num_params, argPtrsStable.AddrOfPinnedObject());
+ StdIOCallBack(fullcommand, fullcommand.Length);
+ code = GSAPI.gsapi_init_with_args(gsInstance, num_params, argPtrsStable.AddrOfPinnedObject());
if (code < 0 && code != gsConstants.E_QUIT)
{
throw new GhostscriptException("gsFileSync: gsapi_init_with_args error");
@@ -514,23 +526,23 @@ public class gsEventArgs : EventArgs
}
catch (DllNotFoundException except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
in_params.result = GS_Result_t.gsFAILED;
cleanup = false;
}
catch (BadImageFormatException except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
in_params.result = GS_Result_t.gsFAILED;
cleanup = false;
}
catch (GhostscriptException except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
}
catch (Exception except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
}
finally
{
@@ -543,11 +555,11 @@ public class gsEventArgs : EventArgs
}
argPtrsStable.Free();
- int code1 = ghostapi.gsapi_exit(gsInstance);
+ int code1 = GSAPI.gsapi_exit(gsInstance);
if ((code == 0) || (code == gsConstants.E_QUIT))
code = code1;
- ghostapi.gsapi_delete_instance(gsInstance);
+ GSAPI.gsapi_delete_instance(gsInstance);
in_params.return_code = code;
if ((code == 0) || (code == gsConstants.E_QUIT))
@@ -578,24 +590,24 @@ public class gsEventArgs : EventArgs
try
{
- code = ghostapi.gsapi_new_instance(out gsInstance, IntPtr.Zero);
+ code = GSAPI.gsapi_new_instance(out gsInstance, IntPtr.Zero);
if (code < 0)
{
throw new GhostscriptException("gsFileAsync: gsapi_new_instance error");
}
- code = ghostapi.gsapi_set_stdio(gsInstance, stdin_callback, stdout_callback, stderr_callback);
+ code = GSAPI.gsapi_set_stdio(gsInstance, stdin_callback, stdout_callback, stderr_callback);
if (code < 0)
{
throw new GhostscriptException("gsFileAsync: gsapi_set_stdio error");
}
- code = ghostapi.gsapi_set_arg_encoding(gsInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
+ code = GSAPI.gsapi_set_arg_encoding(gsInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
if (code < 0)
{
throw new GhostscriptException("gsFileAsync: gsapi_set_arg_encoding error");
}
/* Now convert our Strings to char* and get pinned handles to these.
- * This keeps the c# GC from moving stuff around on us */
+ * This keeps the c# GC from moving stuff around on us */
String fullcommand = "";
for (int k = 0; k < num_params; k++)
{
@@ -609,8 +621,8 @@ public class gsEventArgs : EventArgs
argPtrsStable = GCHandle.Alloc(argPtrs, GCHandleType.Pinned);
fullcommand = "Command Line: " + fullcommand + "\n";
- gsIOUpdateMain(fullcommand, fullcommand.Length);
- code = ghostapi.gsapi_init_with_args(gsInstance, num_params, argPtrsStable.AddrOfPinnedObject());
+ StdIOCallBack(fullcommand, fullcommand.Length);
+ code = GSAPI.gsapi_init_with_args(gsInstance, num_params, argPtrsStable.AddrOfPinnedObject());
if (code < 0)
{
throw new GhostscriptException("gsFileAsync: gsapi_init_with_args error");
@@ -618,25 +630,25 @@ public class gsEventArgs : EventArgs
}
catch (DllNotFoundException except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
Params.result = GS_Result_t.gsFAILED;
cleanup = false;
e.Result = Params;
}
catch (BadImageFormatException except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
Params.result = GS_Result_t.gsFAILED;
cleanup = false;
e.Result = Params;
}
catch (GhostscriptException except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
}
catch (Exception except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
}
finally
{
@@ -649,11 +661,11 @@ public class gsEventArgs : EventArgs
}
argPtrsStable.Free();
- int code1 = ghostapi.gsapi_exit(gsInstance);
+ int code1 = GSAPI.gsapi_exit(gsInstance);
if ((code == 0) || (code == gsConstants.E_QUIT))
code = code1;
- ghostapi.gsapi_delete_instance(gsInstance);
+ GSAPI.gsapi_delete_instance(gsInstance);
Params.return_code = code;
if ((code == 0) || (code == gsConstants.E_QUIT))
@@ -697,24 +709,24 @@ public class gsEventArgs : EventArgs
fs = new FileStream(Params.inputfile, FileMode.Open);
var len = (int)fs.Length;
- code = ghostapi.gsapi_new_instance(out gsInstance, IntPtr.Zero);
+ code = GSAPI.gsapi_new_instance(out gsInstance, IntPtr.Zero);
if (code < 0)
{
throw new GhostscriptException("gsBytesAsync: gsapi_new_instance error");
}
- code = ghostapi.gsapi_set_stdio(gsInstance, stdin_callback, stdout_callback, stderr_callback);
+ code = GSAPI.gsapi_set_stdio(gsInstance, stdin_callback, stdout_callback, stderr_callback);
if (code < 0)
{
throw new GhostscriptException("gsBytesAsync: gsapi_set_stdio error");
}
- code = ghostapi.gsapi_set_arg_encoding(gsInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
+ code = GSAPI.gsapi_set_arg_encoding(gsInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
if (code < 0)
{
throw new GhostscriptException("gsBytesAsync: gsapi_set_arg_encoding error");
}
/* Now convert our Strings to char* and get pinned handles to these.
- * This keeps the c# GC from moving stuff around on us */
+ * This keeps the c# GC from moving stuff around on us */
String fullcommand = "";
for (int k = 0; k < num_params; k++)
{
@@ -728,8 +740,8 @@ public class gsEventArgs : EventArgs
argPtrsStable = GCHandle.Alloc(argPtrs, GCHandleType.Pinned);
fullcommand = "Command Line: " + fullcommand + "\n";
- gsIOUpdateMain(fullcommand, fullcommand.Length);
- code = ghostapi.gsapi_init_with_args(gsInstance, num_params, argPtrsStable.AddrOfPinnedObject());
+ StdIOCallBack(fullcommand, fullcommand.Length);
+ code = GSAPI.gsapi_init_with_args(gsInstance, num_params, argPtrsStable.AddrOfPinnedObject());
if (code < 0)
{
throw new GhostscriptException("gsBytesAsync: gsapi_init_with_args error");
@@ -748,7 +760,7 @@ public class gsEventArgs : EventArgs
int total = 0;
int ret_code;
- ret_code = ghostapi.gsapi_run_string_begin(gsInstance, 0, ref exitcode);
+ ret_code = GSAPI.gsapi_run_string_begin(gsInstance, 0, ref exitcode);
if (exitcode < 0)
{
code = exitcode;
@@ -757,7 +769,7 @@ public class gsEventArgs : EventArgs
while ((count = fs.Read(Buffer, 0, gsConstants.GS_READ_BUFFER)) > 0)
{
- ret_code = ghostapi.gsapi_run_string_continue(gsInstance, FeedPtr, count, 0, ref exitcode);
+ ret_code = GSAPI.gsapi_run_string_continue(gsInstance, FeedPtr, count, 0, ref exitcode);
if (exitcode < 0)
{
code = exitcode;
@@ -773,7 +785,7 @@ public class gsEventArgs : EventArgs
break;
}
}
- ret_code = ghostapi.gsapi_run_string_end(gsInstance, 0, ref exitcode);
+ ret_code = GSAPI.gsapi_run_string_end(gsInstance, 0, ref exitcode);
if (exitcode < 0)
{
code = exitcode;
@@ -783,26 +795,26 @@ public class gsEventArgs : EventArgs
}
catch (DllNotFoundException except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
Params.result = GS_Result_t.gsFAILED;
cleanup = false;
e.Result = Params;
}
catch (BadImageFormatException except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
Params.result = GS_Result_t.gsFAILED;
cleanup = false;
e.Result = Params;
}
catch (GhostscriptException except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
}
catch (Exception except)
{
/* Could be a file io issue */
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
Params.result = GS_Result_t.gsFAILED;
cleanup = false;
e.Result = Params;
@@ -822,11 +834,11 @@ public class gsEventArgs : EventArgs
Feed.Free();
/* gs clean up */
- int code1 = ghostapi.gsapi_exit(gsInstance);
+ int code1 = GSAPI.gsapi_exit(gsInstance);
if ((code == 0) || (code == gsConstants.E_QUIT))
code = code1;
- ghostapi.gsapi_delete_instance(gsInstance);
+ GSAPI.gsapi_delete_instance(gsInstance);
Params.return_code = code;
if ((code == 0) || (code == gsConstants.E_QUIT))
@@ -856,7 +868,7 @@ public class gsEventArgs : EventArgs
GCHandle pinParamLast = GCHandle.Alloc(param_last, GCHandleType.Pinned);
GCHandle firstValue = GCHandle.Alloc(first, GCHandleType.Pinned);
GCHandle lastValue = GCHandle.Alloc(last, GCHandleType.Pinned);
- code = ghostapi.gsapi_set_param(dispInstance, pinParamFirst.AddrOfPinnedObject(),
+ code = GSAPI.gsapi_set_param(dispInstance, pinParamFirst.AddrOfPinnedObject(),
firstValue.AddrOfPinnedObject(), gs_set_param_type.gs_spt_int | gs_set_param_type.gs_spt_more_to_come);
if (code < 0)
{
@@ -868,10 +880,10 @@ public class gsEventArgs : EventArgs
}
if (delay)
- code = ghostapi.gsapi_set_param(dispInstance, pinParamLast.AddrOfPinnedObject(),
+ code = GSAPI.gsapi_set_param(dispInstance, pinParamLast.AddrOfPinnedObject(),
lastValue.AddrOfPinnedObject(), gs_set_param_type.gs_spt_int | gs_set_param_type.gs_spt_more_to_come);
else
- code = ghostapi.gsapi_set_param(dispInstance, pinParamLast.AddrOfPinnedObject(),
+ code = GSAPI.gsapi_set_param(dispInstance, pinParamLast.AddrOfPinnedObject(),
lastValue.AddrOfPinnedObject(), gs_set_param_type.gs_spt_int);
pinParamFirst.Free();
@@ -901,7 +913,7 @@ public class gsEventArgs : EventArgs
GCHandle pinParamGraph = GCHandle.Alloc(param_graph, GCHandleType.Pinned);
GCHandle valueParam = GCHandle.Alloc(value, GCHandleType.Pinned);
- code = ghostapi.gsapi_set_param(dispInstance, pinParamText.AddrOfPinnedObject(),
+ code = GSAPI.gsapi_set_param(dispInstance, pinParamText.AddrOfPinnedObject(),
valueParam.AddrOfPinnedObject(), gs_set_param_type.gs_spt_int | gs_set_param_type.gs_spt_more_to_come);
if (code < 0)
{
@@ -911,10 +923,10 @@ public class gsEventArgs : EventArgs
throw new GhostscriptException("SetAA: gsapi_set_param error");
}
if (delay)
- code = ghostapi.gsapi_set_param(dispInstance, pinParamGraph.AddrOfPinnedObject(),
+ code = GSAPI.gsapi_set_param(dispInstance, pinParamGraph.AddrOfPinnedObject(),
valueParam.AddrOfPinnedObject(), gs_set_param_type.gs_spt_int | gs_set_param_type.gs_spt_more_to_come);
else
- code = ghostapi.gsapi_set_param(dispInstance, pinParamGraph.AddrOfPinnedObject(),
+ code = GSAPI.gsapi_set_param(dispInstance, pinParamGraph.AddrOfPinnedObject(),
valueParam.AddrOfPinnedObject(), gs_set_param_type.gs_spt_int);
pinParamText.Free();
@@ -938,10 +950,10 @@ public class gsEventArgs : EventArgs
GCHandle valueParam = GCHandle.Alloc(value, GCHandleType.Pinned);
if (delay)
- code = ghostapi.gsapi_set_param(dispInstance, pinParam.AddrOfPinnedObject(),
+ code = GSAPI.gsapi_set_param(dispInstance, pinParam.AddrOfPinnedObject(),
valueParam.AddrOfPinnedObject(), gs_set_param_type.gs_spt_parsed | gs_set_param_type.gs_spt_more_to_come);
else
- code = ghostapi.gsapi_set_param(dispInstance, pinParam.AddrOfPinnedObject(),
+ code = GSAPI.gsapi_set_param(dispInstance, pinParam.AddrOfPinnedObject(),
valueParam.AddrOfPinnedObject(), gs_set_param_type.gs_spt_parsed);
pinParam.Free();
@@ -971,7 +983,7 @@ public class gsEventArgs : EventArgs
{
gsparams.result = GS_Result_t.gsFAILED;
e.Result = gsparams;
- gsDLLProblemMain("Failure: Display device not initialized");
+ DLLProblemCallBack("Failure: Display device not initialized");
return;
}
@@ -1040,7 +1052,7 @@ public class gsEventArgs : EventArgs
byte[] fname = System.Text.Encoding.UTF8.GetBytes(fileName + "\0");
GCHandle pinfname = GCHandle.Alloc(fname, GCHandleType.Pinned);
- code = ghostapi.gsapi_run_file(dispInstance, pinfname.AddrOfPinnedObject(), 0, ref exitcode);
+ code = GSAPI.gsapi_run_file(dispInstance, pinfname.AddrOfPinnedObject(), 0, ref exitcode);
pinfname.Free();
if (exitcode < 0)
@@ -1051,7 +1063,7 @@ public class gsEventArgs : EventArgs
catch (GhostscriptException except)
{
gsparams.result = GS_Result_t.gsFAILED;
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
}
finally
{
@@ -1078,7 +1090,7 @@ public class gsEventArgs : EventArgs
{
gsparams.result = GS_Result_t.gsFAILED;
e.Result = gsparams;
- gsDLLProblemMain("Failure: Display device not initialized");
+ DLLProblemCallBack("Failure: Display device not initialized");
return;
}
@@ -1096,8 +1108,8 @@ public class gsEventArgs : EventArgs
argPtrsStable = GCHandle.Alloc(argPtrs, GCHandleType.Pinned);
fullcommand = "Command Line: " + fullcommand + "\n";
- gsIOUpdateMain(fullcommand, fullcommand.Length);
- code = ghostapi.gsapi_init_with_args(dispInstance, num_params, argPtrsStable.AddrOfPinnedObject());
+ StdIOCallBack(fullcommand, fullcommand.Length);
+ code = GSAPI.gsapi_init_with_args(dispInstance, num_params, argPtrsStable.AddrOfPinnedObject());
if (code < 0)
{
throw new GhostscriptException("DisplayDeviceAsync: gsapi_init_with_args error");
@@ -1106,26 +1118,26 @@ public class gsEventArgs : EventArgs
catch (DllNotFoundException except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
gsparams.result = GS_Result_t.gsFAILED;
cleanup = false;
e.Result = gsparams;
}
catch (BadImageFormatException except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
gsparams.result = GS_Result_t.gsFAILED;
cleanup = false;
e.Result = gsparams;
}
catch (GhostscriptException except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
gsparams.result = GS_Result_t.gsFAILED;
}
catch (Exception except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
gsparams.result = GS_Result_t.gsFAILED;
}
finally
@@ -1208,7 +1220,7 @@ public class gsEventArgs : EventArgs
try
{
- if (ghostapi.gsapi_revision(ref vers, size) == 0)
+ if (GSAPI.gsapi_revision(ref vers, size) == 0)
{
String product = Marshal.PtrToStringAnsi(vers.product);
String output;
@@ -1223,7 +1235,7 @@ public class gsEventArgs : EventArgs
}
catch (Exception except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
}
return null;
}
@@ -1256,7 +1268,8 @@ public class gsEventArgs : EventArgs
/* Launch a thread to create XPS document for windows printing */
public gsStatus CreateXPS(String fileName, int resolution, int num_pages,
- Print printsettings, int firstpage, int lastpage)
+ double width, double height, bool fit_page, int firstpage,
+ int lastpage)
{
gsParamState_t gsparams = new gsParamState_t();
gsparams.args = new List<string>();
@@ -1270,32 +1283,13 @@ public class gsEventArgs : EventArgs
gsparams.args.Add("-dFirstPage=" + firstpage.ToString());
gsparams.args.Add("-dLastPage=" + lastpage.ToString());
- if (printsettings != null)
- {
- double paperheight;
- double paperwidth;
+ gsparams.args.Add("-dDEVICEWIDTHPOINTS=" + Convert.ToInt32(width));
+ gsparams.args.Add("-dDEVICEHEIGHTPOINTS=" + Convert.ToInt32(height));
+ gsparams.args.Add("-dFIXEDMEDIA");
- if (printsettings.m_pagedetails.Landscape == true)
- {
- paperheight = printsettings.m_pagedetails.PrintableArea.Width;
- paperwidth = printsettings.m_pagedetails.PrintableArea.Height;
- }
- else
- {
- paperheight = printsettings.m_pagedetails.PrintableArea.Height;
- paperwidth = printsettings.m_pagedetails.PrintableArea.Width;
- }
-
- double width = paperwidth * 72.0 / 100.0;
- double height = paperheight * 72.0 / 100.0;
- gsparams.args.Add("-dDEVICEWIDTHPOINTS=" + width);
- gsparams.args.Add("-dDEVICEHEIGHTPOINTS=" + height);
- gsparams.args.Add("-dFIXEDMEDIA");
+ if (fit_page)
+ gsparams.args.Add("-dFitPage");
- /* Scale and translate and rotate if needed */
- if (printsettings.xaml_autofit.IsChecked == true)
- gsparams.args.Add("-dFitPage");
- }
gsparams.outputfile = Path.GetTempFileName();
gsparams.args.Add("-o");
gsparams.args.Add(gsparams.outputfile);
@@ -1326,7 +1320,7 @@ public class gsEventArgs : EventArgs
/* Run a file with the display device
* public gsStatus gsDsiplayDeviceRunFile() */
- public gsStatus gsDisplayDeviceRunFile(String fileName, double zoom, bool aa, int firstpage, int lastpage)
+ public gsStatus DisplayDeviceRunFile(String fileName, double zoom, bool aa, int firstpage, int lastpage)
{
gsParamState_t gsparams = new gsParamState_t();
@@ -1347,13 +1341,14 @@ public class gsEventArgs : EventArgs
/* Launch a thread rendering all the pages with the display device
* to collect thumbnail images via init_with_args. */
- public gsStatus gsDisplayDeviceRenderThumbs(String fileName, double zoom, bool aa, GS_Task_t task)
+ public gsStatus DisplayDeviceRenderThumbs(String fileName, double zoom, bool aa)
{
gsParamState_t gsparams = new gsParamState_t();
int format = (gsConstants.DISPLAY_COLORS_RGB |
gsConstants.DISPLAY_DEPTH_8 |
gsConstants.DISPLAY_LITTLEENDIAN);
int resolution = (int)(72.0 * zoom + 0.5);
+ GS_Task_t task = GS_Task_t.DISPLAY_DEV_THUMBS;
gsparams.args = new List<string>();
gsparams.args.Add("gs");
@@ -1375,8 +1370,8 @@ public class gsEventArgs : EventArgs
}
/* Launch a thread rendering a set of pages with the display device. For use with languages
- that can be indexed via pages which include PDF and XPS */
- public gsStatus gsDisplayDeviceRenderPages(String fileName, int first_page, int last_page, double zoom)
+ * that can be indexed via pages which include PDF and XPS */
+ public gsStatus DisplayDeviceRenderPages(String fileName, int first_page, int last_page, double zoom)
{
gsParamState_t gsparams = new gsParamState_t();
int format = (gsConstants.DISPLAY_COLORS_RGB |
@@ -1411,25 +1406,25 @@ public class gsEventArgs : EventArgs
try
{
- code = ghostapi.gsapi_new_instance(out dispInstance, IntPtr.Zero);
+ code = GSAPI.gsapi_new_instance(out dispInstance, IntPtr.Zero);
if (code < 0)
{
throw new GhostscriptException("DisplayDeviceOpen: gsapi_new_instance error");
}
- code = ghostapi.gsapi_set_stdio(dispInstance, raise_stdin, raise_stdout, raise_stderr);
+ code = GSAPI.gsapi_set_stdio(dispInstance, raise_stdin, raise_stdout, raise_stderr);
if (code < 0)
{
throw new GhostscriptException("DisplayDeviceOpen: gsapi_set_stdio error");
}
- code = ghostapi.gsapi_set_arg_encoding(dispInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
+ code = GSAPI.gsapi_set_arg_encoding(dispInstance, (int)gsEncoding.GS_ARG_ENCODING_UTF8);
if (code < 0)
{
throw new GhostscriptException("DisplayDeviceOpen: gsapi_set_arg_encoding error");
}
- code = ghostapi.gsapi_set_display_callback(dispInstance, ptr_display_struct);
+ code = GSAPI.gsapi_set_display_callback(dispInstance, ptr_display_struct);
if (code < 0)
{
throw new GhostscriptException("DisplayDeviceOpen: gsapi_set_display_callback error");
@@ -1438,28 +1433,28 @@ public class gsEventArgs : EventArgs
catch (DllNotFoundException except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
gsparams.result = GS_Result_t.gsFAILED;
}
catch (BadImageFormatException except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
gsparams.result = GS_Result_t.gsFAILED;
}
catch (GhostscriptException except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
gsparams.result = GS_Result_t.gsFAILED;
if (dispInstance != IntPtr.Zero)
- ghostapi.gsapi_delete_instance(dispInstance);
+ GSAPI.gsapi_delete_instance(dispInstance);
dispInstance = IntPtr.Zero;
}
catch (Exception except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
gsparams.result = GS_Result_t.gsFAILED;
if (dispInstance != IntPtr.Zero)
- ghostapi.gsapi_delete_instance(dispInstance);
+ GSAPI.gsapi_delete_instance(dispInstance);
dispInstance = IntPtr.Zero;
}
return gsparams;
@@ -1475,19 +1470,19 @@ public class gsEventArgs : EventArgs
try
{
- code = ghostapi.gsapi_exit(dispInstance);
+ code = GSAPI.gsapi_exit(dispInstance);
if (code < 0)
{
out_params.result = GS_Result_t.gsFAILED;
throw new GhostscriptException("DisplayDeviceClose: gsapi_exit error");
}
- ghostapi.gsapi_delete_instance(dispInstance);
+ GSAPI.gsapi_delete_instance(dispInstance);
}
catch (Exception except)
{
- gsDLLProblemMain("Exception: " + except.Message);
+ DLLProblemCallBack("Exception: " + except.Message);
out_params.result = GS_Result_t.gsFAILED;
}
diff --git a/demos/csharp/linux/gs_mono.sln b/demos/csharp/linux/gs_mono.sln
deleted file mode 100644
index c3a015a1..00000000
--- a/demos/csharp/linux/gs_mono.sln
+++ /dev/null
@@ -1,17 +0,0 @@
-
-Microsoft Visual Studio Solution File, Format Version 12.00
-# Visual Studio 15
-Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "gtk_viewer", "gtk_viewer\gtk_viewer.csproj", "{8941969C-A209-4109-AF7B-E4CF9D309B5B}"
-EndProject
-Global
- GlobalSection(SolutionConfigurationPlatforms) = preSolution
- Debug|x86 = Debug|x86
- Release|x86 = Release|x86
- EndGlobalSection
- GlobalSection(ProjectConfigurationPlatforms) = postSolution
- {8941969C-A209-4109-AF7B-E4CF9D309B5B}.Debug|x86.ActiveCfg = Debug|x86
- {8941969C-A209-4109-AF7B-E4CF9D309B5B}.Debug|x86.Build.0 = Debug|x86
- {8941969C-A209-4109-AF7B-E4CF9D309B5B}.Release|x86.ActiveCfg = Release|x86
- {8941969C-A209-4109-AF7B-E4CF9D309B5B}.Release|x86.Build.0 = Release|x86
- EndGlobalSection
-EndGlobal
diff --git a/demos/csharp/linux/gtk_viewer/Properties/AssemblyInfo.cs b/demos/csharp/linux/gtk_viewer/Properties/AssemblyInfo.cs
deleted file mode 100644
index a9d0d285..00000000
--- a/demos/csharp/linux/gtk_viewer/Properties/AssemblyInfo.cs
+++ /dev/null
@@ -1,26 +0,0 @@
-using System.Reflection;
-using System.Runtime.CompilerServices;
-
-// Information about this assembly is defined by the following attributes.
-// Change them to the values specific to your project.
-
-[assembly: AssemblyTitle("gs_mono_example")]
-[assembly: AssemblyDescription("")]
-[assembly: AssemblyConfiguration("")]
-[assembly: AssemblyCompany("")]
-[assembly: AssemblyProduct("")]
-[assembly: AssemblyCopyright("${AuthorCopyright}")]
-[assembly: AssemblyTrademark("")]
-[assembly: AssemblyCulture("")]
-
-// The assembly version has the format "{Major}.{Minor}.{Build}.{Revision}".
-// The form "{Major}.{Minor}.*" will automatically update the build and revision,
-// and "{Major}.{Minor}.{Build}.*" will update just the revision.
-
-[assembly: AssemblyVersion("1.0.*")]
-
-// The following attributes are used to specify the signing key for the assembly,
-// if desired. See the Mono documentation for more information about signing.
-
-//[assembly: AssemblyDelaySign(false)]
-//[assembly: AssemblyKeyFile("")]
diff --git a/demos/csharp/linux/gtk_viewer/gtk-gui/generated.cs b/demos/csharp/linux/gtk_viewer/gtk-gui/generated.cs
deleted file mode 100644
index 4842e95d..00000000
--- a/demos/csharp/linux/gtk_viewer/gtk-gui/generated.cs
+++ /dev/null
@@ -1,30 +0,0 @@
-
-// This file has been generated by the GUI designer. Do not modify.
-namespace Stetic
-{
- internal class Gui
- {
- private static bool initialized;
-
- internal static void Initialize(Gtk.Widget iconRenderer)
- {
- if ((Stetic.Gui.initialized == false))
- {
- Stetic.Gui.initialized = true;
- }
- }
- }
-
- internal class ActionGroups
- {
- public static Gtk.ActionGroup GetActionGroup(System.Type type)
- {
- return Stetic.ActionGroups.GetActionGroup(type.FullName);
- }
-
- public static Gtk.ActionGroup GetActionGroup(string name)
- {
- return null;
- }
- }
-}
diff --git a/demos/csharp/linux/gtk_viewer/gtk-gui/gtk_viewer.src.gsOutput.cs b/demos/csharp/linux/gtk_viewer/gtk-gui/gtk_viewer.src.gsOutput.cs
deleted file mode 100644
index 0eab65c6..00000000
--- a/demos/csharp/linux/gtk_viewer/gtk-gui/gtk_viewer.src.gsOutput.cs
+++ /dev/null
@@ -1,10 +0,0 @@
-
-namespace gtk_viewer.src
-{
- public partial class gsOutput
- {
- private void Build()
- {
- }
- }
-}
diff --git a/demos/csharp/linux/gtk_viewer/gtk-gui/gui.stetic b/demos/csharp/linux/gtk_viewer/gtk-gui/gui.stetic
deleted file mode 100644
index 172ba497..00000000
--- a/demos/csharp/linux/gtk_viewer/gtk-gui/gui.stetic
+++ /dev/null
@@ -1,18 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<stetic-interface>
- <configuration>
- <images-root-path>..</images-root-path>
- <target-gtk-version>2.12</target-gtk-version>
- </configuration>
- <import>
- <widget-library name="../bin/Debug/gtk_viewer.exe" internal="true" />
- </import>
- <widget class="Gtk.Window" id="gtk_viewer.src.gsOutput" design-size="400 300">
- <property name="MemberName" />
- <property name="Title" translatable="yes">gsOutput</property>
- <property name="WindowPosition">CenterOnParent</property>
- <child>
- <placeholder />
- </child>
- </widget>
-</stetic-interface> \ No newline at end of file
diff --git a/demos/csharp/linux/gtk_viewer/gtk_viewer.csproj b/demos/csharp/linux/gtk_viewer/gtk_viewer.csproj
deleted file mode 100644
index ee512951..00000000
--- a/demos/csharp/linux/gtk_viewer/gtk_viewer.csproj
+++ /dev/null
@@ -1,73 +0,0 @@
-<?xml version="1.0" encoding="utf-8"?>
-<Project DefaultTargets="Build" ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
- <PropertyGroup>
- <Configuration Condition=" '$(Configuration)' == '' ">Debug</Configuration>
- <Platform Condition=" '$(Platform)' == '' ">x86</Platform>
- <ProjectGuid>{8941969C-A209-4109-AF7B-E4CF9D309B5B}</ProjectGuid>
- <OutputType>WinExe</OutputType>
- <RootNamespace>gtk_viewer</RootNamespace>
- <AssemblyName>gtk_viewer</AssemblyName>
- <TargetFrameworkVersion>v4.7</TargetFrameworkVersion>
- </PropertyGroup>
- <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Debug|x86' ">
- <DebugSymbols>true</DebugSymbols>
- <DebugType>full</DebugType>
- <Optimize>false</Optimize>
- <OutputPath>bin\Debug</OutputPath>
- <DefineConstants>DEBUG;MONO</DefineConstants>
- <ErrorReport>prompt</ErrorReport>
- <WarningLevel>4</WarningLevel>
- <PlatformTarget>x64</PlatformTarget>
- <AllowUnsafeBlocks>true</AllowUnsafeBlocks>
- </PropertyGroup>
- <PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|x86' ">
- <Optimize>true</Optimize>
- <OutputPath>bin\Release</OutputPath>
- <DefineConstants>MONO</DefineConstants>
- <ErrorReport>prompt</ErrorReport>
- <WarningLevel>4</WarningLevel>
- <PlatformTarget>x64</PlatformTarget>
- <AllowUnsafeBlocks>true</AllowUnsafeBlocks>
- </PropertyGroup>
- <ItemGroup>
- <Reference Include="System" />
- <Reference Include="Mono.Posix" />
- <Reference Include="System.Drawing" />
- <Reference Include="Mono.CSharp" />
- <Reference Include="gtk-sharp, Version=2.12.0.0, Culture=neutral, PublicKeyToken=35e10195dab3c99f">
- <Package>gtk-sharp-2.0</Package>
- </Reference>
- <Reference Include="gdk-sharp, Version=2.12.0.0, Culture=neutral, PublicKeyToken=35e10195dab3c99f">
- <Package>gtk-sharp-2.0</Package>
- </Reference>
- <Reference Include="glib-sharp, Version=2.12.0.0, Culture=neutral, PublicKeyToken=35e10195dab3c99f">
- <Package>glib-sharp-2.0</Package>
- </Reference>
- </ItemGroup>
- <ItemGroup>
- <EmbeddedResource Include="gtk-gui\gui.stetic">
- <LogicalName>gui.stetic</LogicalName>
- </EmbeddedResource>
- </ItemGroup>
- <ItemGroup>
- <Compile Include="gtk-gui\generated.cs" />
- <Compile Include="Properties\AssemblyInfo.cs" />
- <Compile Include="src\MainWindow.cs" />
- <Compile Include="src\Program.cs" />
- <Compile Include="src\MainThumbRendering.cs" />
- <Compile Include="src\DocPage.cs" />
- <Compile Include="src\MainRender.cs" />
- <Compile Include="src\TempFile.cs" />
- <Compile Include="src\MainZoom.cs" />
- <Compile Include="..\..\api\ghostapi.cs">
- <Link>src\ghostapi.cs</Link>
- </Compile>
- <Compile Include="src\gsOutput.cs" />
- <Compile Include="gtk-gui\gtk_viewer.src.gsOutput.cs" />
- <Compile Include="..\..\api\ghostmono.cs">
- <Link>src\ghostmono.cs</Link>
- </Compile>
- </ItemGroup>
- <Import Project="$(MSBuildBinPath)\Microsoft.CSharp.targets" />
- <Import Project="packages\GtkSharp.3.22.25.98\build\GtkSharp.targets" Condition="Exists('packages\GtkSharp.3.22.25.98\build\GtkSharp.targets')" />
-</Project> \ No newline at end of file
diff --git a/demos/csharp/linux/gtk_viewer/gtk_viewer.sln b/demos/csharp/linux/gtk_viewer/gtk_viewer.sln
deleted file mode 100644
index 229145da..00000000
--- a/demos/csharp/linux/gtk_viewer/gtk_viewer.sln
+++ /dev/null
@@ -1,17 +0,0 @@
-
-Microsoft Visual Studio Solution File, Format Version 12.00
-# Visual Studio 15
-Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "gtk_viewer", "gtk_viewer.csproj", "{8941969C-A209-4109-AF7B-E4CF9D309B5B}"
-EndProject
-Global
- GlobalSection(SolutionConfigurationPlatforms) = preSolution
- Debug|x86 = Debug|x86
- Release|x86 = Release|x86
- EndGlobalSection
- GlobalSection(ProjectConfigurationPlatforms) = postSolution
- {8941969C-A209-4109-AF7B-E4CF9D309B5B}.Debug|x86.ActiveCfg = Debug|x86
- {8941969C-A209-4109-AF7B-E4CF9D309B5B}.Debug|x86.Build.0 = Debug|x86
- {8941969C-A209-4109-AF7B-E4CF9D309B5B}.Release|x86.ActiveCfg = Release|x86
- {8941969C-A209-4109-AF7B-E4CF9D309B5B}.Release|x86.Build.0 = Release|x86
- EndGlobalSection
-EndGlobal
diff --git a/demos/csharp/linux/gtk_viewer/make.sh b/demos/csharp/linux/gtk_viewer/make.sh
new file mode 100755
index 00000000..e7d86193
--- /dev/null
+++ b/demos/csharp/linux/gtk_viewer/make.sh
@@ -0,0 +1,18 @@
+#!/bin/bash
+# Build for gsmono gtk sample viewer
+# Note first do "make so" in ghostpdl
+# root directory to create libgpdl.so
+
+cp ../../../../sobin/libgpdl.so bin/libgpdl.so
+mcs -define:MONO -pkg:gtk-sharp-2.0 \
+ src/DocPage.cs \
+ src/gsOutput.cs \
+ src/MainRender.cs \
+ src/MainThumbRendering.cs \
+ src/MainWindow.cs \
+ src/MainZoom.cs \
+ src/Program.cs \
+ src/TempFile.cs \
+ ../../api/ghostapi.cs \
+ ../../api/ghostmono.cs \
+ -out:bin/gsMonoGtkViewer.exe
diff --git a/demos/csharp/linux/gtk_viewer/src/DocPage.cs b/demos/csharp/linux/gtk_viewer/src/DocPage.cs
index d1cb5493..13c41b9f 100644
--- a/demos/csharp/linux/gtk_viewer/src/DocPage.cs
+++ b/demos/csharp/linux/gtk_viewer/src/DocPage.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.ComponentModel;
using System.Collections.ObjectModel;
@@ -105,4 +120,4 @@ namespace gs_mono_example
{
}
}
-}
+} \ No newline at end of file
diff --git a/demos/csharp/linux/gtk_viewer/src/MainRender.cs b/demos/csharp/linux/gtk_viewer/src/MainRender.cs
index e4749f1c..f8c0d2e0 100644
--- a/demos/csharp/linux/gtk_viewer/src/MainRender.cs
+++ b/demos/csharp/linux/gtk_viewer/src/MainRender.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.Runtime;
using System.Runtime.InteropServices;
using GhostMono;
@@ -7,8 +22,6 @@ namespace gs_mono_example
{
public partial class MainWindow
{
- int m_firstpage;
- int m_lastpage;
int m_current_page;
Gtk.TreeIter m_tree_iter;
@@ -28,8 +41,6 @@ namespace gs_mono_example
return;
m_busy_render = true;
- m_firstpage = first_page;
- m_lastpage = last_page;
//m_ghostscript.gsDisplayDeviceRender(m_currfile, first_page + 1, last_page + 1, 1.0);
}
@@ -97,7 +108,7 @@ namespace gs_mono_example
RemoveProgressBar();
m_file_open = true;
- m_ghostscript.gsPageRenderedMain -= new ghostsharp.gsCallBackPageRenderedMain(gsPageRendered);
+ m_ghostscript.PageRenderedCallBack -= new GSMONO.PageRendered(gsPageRendered);
m_GtkaaCheck.Sensitive = true;
m_GtkZoomMinus.Sensitive = true;
m_GtkZoomPlus.Sensitive = true;
@@ -106,13 +117,12 @@ namespace gs_mono_example
/* Render all pages full resolution */
private void RenderMainFirst()
{
- m_firstpage = 1;
m_current_page = 0;
m_GtkimageStoreMain.GetIterFirst(out m_tree_iter);
m_busy_render = true;
- m_ghostscript.gsPageRenderedMain += new ghostsharp.gsCallBackPageRenderedMain(gsPageRendered);
+ m_ghostscript.PageRenderedCallBack += new GSMONO.PageRendered(gsPageRendered);
AddProgressBar("Rendering Pages");
- m_ghostscript.gsDisplayDeviceRenderAll(m_currfile, m_doczoom, m_aa, GS_Task_t.DISPLAY_DEV_NON_PDF);
+ m_ghostscript.DisplayDeviceRenderAll(m_currfile, m_doczoom, m_aa, GS_Task_t.DISPLAY_DEV_NON_PDF);
}
/* Render all, but only if not already busy, called via zoom or aa changes */
diff --git a/demos/csharp/linux/gtk_viewer/src/MainThumbRendering.cs b/demos/csharp/linux/gtk_viewer/src/MainThumbRendering.cs
index 0d64fa13..9e1b0bcc 100644
--- a/demos/csharp/linux/gtk_viewer/src/MainThumbRendering.cs
+++ b/demos/csharp/linux/gtk_viewer/src/MainThumbRendering.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.Collections.Generic;
using System.Runtime.InteropServices;
using GhostMono;
@@ -30,7 +45,7 @@ namespace gs_mono_example
private void ThumbsDone()
{
m_GtkProgressBar.Fraction = 1.0;
- m_ghostscript.gsPageRenderedMain -= new ghostsharp.gsCallBackPageRenderedMain(gsThumbRendered);
+ m_ghostscript.PageRenderedCallBack -= new GSMONO.PageRendered(gsThumbRendered);
m_numpages = m_thumbnails.Count;
if (m_numpages < 1)
{
@@ -82,10 +97,10 @@ namespace gs_mono_example
private void RenderThumbs()
{
AddProgressBar("Rendering Thumbs");
- m_ghostscript.gsPageRenderedMain +=
- new ghostsharp.gsCallBackPageRenderedMain(gsThumbRendered);
- m_ghostscript.gsDisplayDeviceRenderAll(m_currfile,
- Constants.SCALE_THUMB, false, GS_Task_t.DISPLAY_DEV_THUMBS_NON_PDF);
+ m_ghostscript.PageRenderedCallBack +=
+ new GSMONO.PageRendered(gsThumbRendered);
+ m_ghostscript.DisplayDeviceRenderThumbs(m_currfile,
+ Constants.SCALE_THUMB, false);
}
}
} \ No newline at end of file
diff --git a/demos/csharp/linux/gtk_viewer/src/MainWindow.cs b/demos/csharp/linux/gtk_viewer/src/MainWindow.cs
index f621cd47..5e8941f8 100644
--- a/demos/csharp/linux/gtk_viewer/src/MainWindow.cs
+++ b/demos/csharp/linux/gtk_viewer/src/MainWindow.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.Collections.Generic;
using Gtk;
using GhostMono;
@@ -38,7 +53,7 @@ namespace gs_mono_example
public partial class MainWindow : Gtk.Window
{
- ghostsharp m_ghostscript;
+ GSMONO m_ghostscript;
bool m_file_open;
String m_currfile;
String m_extension;
@@ -107,10 +122,10 @@ namespace gs_mono_example
public MainWindow() : base(Gtk.WindowType.Toplevel)
{
/* Set up ghostscript calls for progress update */
- m_ghostscript = new ghostsharp();
- m_ghostscript.gsUpdateMain += new ghostsharp.gsCallBackMain(gsProgress);
- m_ghostscript.gsIOUpdateMain += new ghostsharp.gsIOCallBackMain(gsIO);
- m_ghostscript.gsDLLProblemMain += new ghostsharp.gsDLLProblem(gsDLL);
+ m_ghostscript = new GSMONO();
+ m_ghostscript.ProgressCallBack += new GSMONO.Progress(gsProgress);
+ m_ghostscript.StdIOCallBack += new GSMONO.StdIO(gsIO);
+ m_ghostscript.DLLProblemCallBack += new GSMONO.DLLProblem(gsDLL);
DeleteEvent += delegate { Application.Quit(); };
@@ -546,7 +561,7 @@ namespace gs_mono_example
System.IO.File.Delete(m_currfile);
}
- var res = System.IO.File.Exists(tempfile.Filename);
+ System.IO.File.Exists(tempfile.Filename);
System.IO.File.Copy(tempfile.Filename, dialog.Filename);
}
catch (Exception except)
@@ -607,7 +622,6 @@ namespace gs_mono_example
/* launch a new process */
string path = System.Reflection.Assembly.GetExecutingAssembly().Location;
- Process p = new Process();
try
{
String name = dialog.Filename;
@@ -710,4 +724,4 @@ namespace gs_mono_example
m_tempfiles.Clear();
}
}
-}
+} \ No newline at end of file
diff --git a/demos/csharp/linux/gtk_viewer/src/MainZoom.cs b/demos/csharp/linux/gtk_viewer/src/MainZoom.cs
index 5d415351..1177b5b0 100644
--- a/demos/csharp/linux/gtk_viewer/src/MainZoom.cs
+++ b/demos/csharp/linux/gtk_viewer/src/MainZoom.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.Text.RegularExpressions;
namespace gs_mono_example
diff --git a/demos/csharp/linux/gtk_viewer/src/Program.cs b/demos/csharp/linux/gtk_viewer/src/Program.cs
index 7446f0bc..c6862901 100644
--- a/demos/csharp/linux/gtk_viewer/src/Program.cs
+++ b/demos/csharp/linux/gtk_viewer/src/Program.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using Gtk;
namespace gs_mono_example
@@ -22,4 +37,4 @@ namespace gs_mono_example
}
}
}
-}
+} \ No newline at end of file
diff --git a/demos/csharp/linux/gtk_viewer/src/TempFile.cs b/demos/csharp/linux/gtk_viewer/src/TempFile.cs
index c6c313de..b233b435 100644
--- a/demos/csharp/linux/gtk_viewer/src/TempFile.cs
+++ b/demos/csharp/linux/gtk_viewer/src/TempFile.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.IO;
/* A class to help in the management of temp files */
@@ -31,4 +46,4 @@ namespace gs_mono_example
}
}
}
-}
+} \ No newline at end of file
diff --git a/demos/csharp/linux/gtk_viewer/src/gsOutput.cs b/demos/csharp/linux/gtk_viewer/src/gsOutput.cs
index c74dc7a3..0952ee34 100644
--- a/demos/csharp/linux/gtk_viewer/src/gsOutput.cs
+++ b/demos/csharp/linux/gtk_viewer/src/gsOutput.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using Gtk;
namespace gs_mono_example
@@ -38,4 +53,4 @@ namespace gs_mono_example
}
}
-}
+} \ No newline at end of file
diff --git a/demos/csharp/windows/ghostnet_wpf_example/App.xaml.cs b/demos/csharp/windows/ghostnet_wpf_example/App.xaml.cs
index 79444fe4..7ca46e73 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/App.xaml.cs
+++ b/demos/csharp/windows/ghostnet_wpf_example/App.xaml.cs
@@ -1,9 +1,18 @@
-using System;
-using System.Collections.Generic;
-using System.Configuration;
-using System.Data;
-using System.Linq;
-using System.Threading.Tasks;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
using System.Windows;
namespace ghostnet_wpf_example
diff --git a/demos/csharp/windows/ghostnet_wpf_example/DocPage.cs b/demos/csharp/windows/ghostnet_wpf_example/DocPage.cs
index 93316d9d..b529b3c1 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/DocPage.cs
+++ b/demos/csharp/windows/ghostnet_wpf_example/DocPage.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.ComponentModel;
using System.Windows.Media.Imaging;
using System.Collections.ObjectModel;
@@ -94,7 +109,7 @@ namespace ghostnet_wpf_example
this.zoom = 0;
this.bitmap = null;
this.pagenum = -1;
- this.pagename = "";
+ this.pagename = " ";
}
public DocPage(int Height, int Width, double Zoom, BitmapSource BitMap, int PageNum, bool AA)
diff --git a/demos/csharp/windows/ghostnet_wpf_example/MainPrint.cs b/demos/csharp/windows/ghostnet_wpf_example/MainPrint.cs
index 40855ba0..28c5c6bb 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/MainPrint.cs
+++ b/demos/csharp/windows/ghostnet_wpf_example/MainPrint.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.Windows;
using System.Collections.Generic;
using System.Threading;
@@ -52,18 +67,41 @@ namespace ghostnet_wpf_example
string extension = System.IO.Path.GetExtension(m_currfile);
/* If file is already xps then gs need not do this */
- /* We are doing this based on the extension but like should do
+ /* We are doing this based on the extension but should do
* it based upon the content */
- if ( !(String.Equals(extension.ToUpper(),"XPS") || String.Equals(extension.ToUpper(), "OXPS")) )
+ if (!(String.Equals(extension.ToUpper(), "XPS") || String.Equals(extension.ToUpper(), "OXPS")))
{
m_printstatus.xaml_PrintProgress.Value = 0;
- if (m_ghostscript.CreateXPS(m_currfile, Constants.DEFAULT_GS_RES,
- last_page - first_page + 1, m_printcontrol, first_page, last_page) == gsStatus.GS_BUSY)
+ /* Extract needed information from print dialog and pass to GSNET */
+ if (m_printcontrol == null)
{
- ShowMessage(NotifyType_t.MESS_STATUS, "GS currently busy");
return;
}
+ else
+ {
+ double width;
+ double height;
+ bool fit_page = (m_printcontrol.xaml_autofit.IsChecked == true);
+
+ if (m_printcontrol.m_pagedetails.Landscape == true)
+ {
+ height = m_printcontrol.m_pagedetails.PrintableArea.Width * 72.0 / 100.0;
+ width = m_printcontrol.m_pagedetails.PrintableArea.Height * 72.0 / 100.0;
+ }
+ else
+ {
+ height = m_printcontrol.m_pagedetails.PrintableArea.Height * 72.0 / 100.0;
+ width = m_printcontrol.m_pagedetails.PrintableArea.Width * 72.0 / 100.0;
+ }
+
+ if (m_ghostscript.CreateXPS(m_currfile, Constants.DEFAULT_GS_RES,
+ last_page - first_page + 1, height, width, fit_page, first_page, last_page) == gsStatus.GS_BUSY)
+ {
+ ShowMessage(NotifyType_t.MESS_STATUS, "GS currently busy");
+ return;
+ }
+ }
}
else
PrintXPS(m_currfile, print_all, first_page, last_page, false);
@@ -82,7 +120,7 @@ namespace ghostnet_wpf_example
string path = System.Reflection.Assembly.GetExecutingAssembly().CodeBase;
try
{
- string Arguments = m_currfile + " print " + m_currpage + " " + m_numpages;
+ string Arguments = "\"" + m_currfile + "\"" + " print " + m_currpage + " " + m_numpages;
Process.Start(path, Arguments);
}
catch (InvalidOperationException)
diff --git a/demos/csharp/windows/ghostnet_wpf_example/MainRender.cs b/demos/csharp/windows/ghostnet_wpf_example/MainRender.cs
index 98661f98..5f0bdc78 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/MainRender.cs
+++ b/demos/csharp/windows/ghostnet_wpf_example/MainRender.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Runtime.InteropServices;
@@ -36,7 +51,7 @@ namespace ghostnet_wpf_example
return;
m_viewer_state = ViewerState_t.BUSY_RENDER;
- m_ghostscript.gsDisplayDeviceRunFile(m_currfile, m_doczoom, m_aa, real_first_page + 1, real_last_page + 1);
+ m_ghostscript.DisplayDeviceRunFile(m_currfile, m_doczoom, m_aa, real_first_page + 1, real_last_page + 1);
}
/* Callback from ghostscript with the rendered image. */
@@ -150,12 +165,12 @@ namespace ghostnet_wpf_example
{
m_doczoom = 1.0;
xaml_Zoomsize.Text = "100";
- m_ghostscript.gsPageRenderedMain += new ghostsharp.gsCallBackPageRenderedMain(gsPageRendered);
+ m_ghostscript.PageRenderedCallBack += new GSNET.PageRendered(gsPageRendered);
}
m_viewer_state = ViewerState_t.BUSY_RENDER;
(int first_page, int last_page) = GetVisiblePages();
- m_ghostscript.gsDisplayDeviceRunFile(m_currfile, m_doczoom, m_aa, first_page + 1, last_page + 1);
+ m_ghostscript.DisplayDeviceRunFile(m_currfile, m_doczoom, m_aa, first_page + 1, last_page + 1);
}
/* Render all pages full resolution. Used for single page files as
@@ -171,11 +186,11 @@ namespace ghostnet_wpf_example
{
m_doczoom = 1.0;
xaml_Zoomsize.Text = "100";
- m_ghostscript.gsPageRenderedMain += new ghostsharp.gsCallBackPageRenderedMain(gsPageRendered);
+ m_ghostscript.PageRenderedCallBack += new GSNET.PageRendered(gsPageRendered);
}
m_viewer_state = ViewerState_t.BUSY_RENDER;
- m_ghostscript.gsDisplayDeviceRunFile(m_currfile, m_doczoom, m_aa, -1, -1);
+ m_ghostscript.DisplayDeviceRunFile(m_currfile, m_doczoom, m_aa, -1, -1);
}
/* Called via zoom or aa changes */
diff --git a/demos/csharp/windows/ghostnet_wpf_example/MainThumbRendering.cs b/demos/csharp/windows/ghostnet_wpf_example/MainThumbRendering.cs
index 102bb764..b3f15a84 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/MainThumbRendering.cs
+++ b/demos/csharp/windows/ghostnet_wpf_example/MainThumbRendering.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.Collections.Generic;
using System.Windows.Media;
using System.Windows.Media.Imaging;
@@ -9,7 +24,7 @@ namespace ghostnet_wpf_example
{
public partial class MainWindow
{
- private static List<DocPage> m_thumbnails;
+ private static List<DocPage> m_thumbnails;
/* Assign current pages to blown up thumbnail images */
private void ThumbAssignMain(int page_num, int width, int height, double zoom_in, ref int offset)
@@ -67,7 +82,7 @@ namespace ghostnet_wpf_example
xaml_ThumbList.Items.Refresh();
xaml_ThumbGrid.Visibility = System.Windows.Visibility.Visible;
- m_ghostscript.gsPageRenderedMain -= new ghostsharp.gsCallBackPageRenderedMain(gsThumbRendered);
+ m_ghostscript.PageRenderedCallBack -= new GSNET.PageRendered(gsThumbRendered);
m_numpages = m_list_thumb.Count;
if (m_numpages < 1)
@@ -120,8 +135,8 @@ namespace ghostnet_wpf_example
xaml_RenderProgressText.Text = "Creating Thumbs";
xaml_ProgressGrid.Visibility = System.Windows.Visibility.Visible;
- m_ghostscript.gsPageRenderedMain += new ghostsharp.gsCallBackPageRenderedMain(gsThumbRendered);
- m_ghostscript.gsDisplayDeviceRenderThumbs(m_currfile, Constants.SCALE_THUMB, false, GS_Task_t.DISPLAY_DEV_THUMBS);
+ m_ghostscript.PageRenderedCallBack += new GSNET.PageRendered(gsThumbRendered);
+ m_ghostscript.DisplayDeviceRenderThumbs(m_currfile, Constants.SCALE_THUMB, false);
}
}
}
diff --git a/demos/csharp/windows/ghostnet_wpf_example/MainWindow.xaml b/demos/csharp/windows/ghostnet_wpf_example/MainWindow.xaml
index d4f752d4..381ef38a 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/MainWindow.xaml
+++ b/demos/csharp/windows/ghostnet_wpf_example/MainWindow.xaml
@@ -1,4 +1,20 @@
-<Window x:Class="ghostnet_wpf_example.MainWindow"
+<!--
+ Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+-->
+
+<Window x:Class="ghostnet_wpf_example.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
@@ -12,7 +28,7 @@
<StackPanel Margin="-20,0,0,0" Background="WhiteSmoke"/>
</ItemsPanelTemplate>
<DataTemplate x:Key="PageTemplate">
- <Canvas Tag="{Binding Path=pagename}" HorizontalAlignment="Center" VerticalAlignment="Top" Height="{Binding Height}" Width="{Binding Width}" Margin="0,0,0,0" ClipToBounds="True">
+ <Canvas Tag="{Binding PageName}" HorizontalAlignment="Center" VerticalAlignment="Top" Height="{Binding Height}" Width="{Binding Width}" Margin="0,0,0,0" ClipToBounds="True">
<Image Width="{Binding Width}" Height="{Binding Height}" Stretch="Fill" HorizontalAlignment="Center" Source="{Binding BitMap}">
<Image.BitmapEffect>
<DropShadowBitmapEffect Color="Black" Direction="-50" ShadowDepth="40" Softness=".7" />
diff --git a/demos/csharp/windows/ghostnet_wpf_example/MainWindow.xaml.cs b/demos/csharp/windows/ghostnet_wpf_example/MainWindow.xaml.cs
index f4b103b8..e96a65f0 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/MainWindow.xaml.cs
+++ b/demos/csharp/windows/ghostnet_wpf_example/MainWindow.xaml.cs
@@ -1,6 +1,20 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.Collections.Generic;
-using System.Linq;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Input;
@@ -102,7 +116,7 @@ namespace ghostnet_wpf_example
public partial class MainWindow : Window
{
- ghostsharp m_ghostscript;
+ GSNET m_ghostscript;
doc_t m_document_type;
bool m_doc_type_has_page_access;
String m_currfile;
@@ -136,15 +150,15 @@ namespace ghostnet_wpf_example
}
}
public MainWindow()
- {
- InitializeComponent();
+ {
+ InitializeComponent();
this.Closing += new System.ComponentModel.CancelEventHandler(Window_Closing);
/* Set up ghostscript calls for progress update */
- m_ghostscript = new ghostsharp();
- m_ghostscript.gsUpdateMain += new ghostsharp.gsCallBackMain(gsProgress);
- m_ghostscript.gsIOUpdateMain += new ghostsharp.gsIOCallBackMain(gsIO);
- m_ghostscript.gsDLLProblemMain += new ghostsharp.gsDLLProblem(gsDLL);
+ m_ghostscript = new GSNET();
+ m_ghostscript.ProgressCallBack+= new GSNET.Progress(gsProgress);
+ m_ghostscript.StdIOCallBack += new GSNET.StdIO(gsIO);
+ m_ghostscript.DLLProblemCallBack += new GSNET.DLLProblem(gsDLL);
m_ghostscript.DisplayDeviceOpen();
m_currpage = 0;
@@ -199,17 +213,18 @@ namespace ghostnet_wpf_example
m_viewer_state = ViewerState_t.PRINTING;
Print(filePath);
}
-
}
private void gsIO(String mess, int len)
{
m_gsoutput.Update(mess, len);
}
+
private void ShowGSMessage(object sender, RoutedEventArgs e)
{
m_gsoutput.Show();
}
+
private void gsDLL(String mess)
{
ShowMessage(NotifyType_t.MESS_STATUS, mess);
@@ -301,7 +316,6 @@ namespace ghostnet_wpf_example
}
}
- /* GS Result*/
public void GSResult(gsParamState_t gs_result)
{
TempFile tempfile = null;
@@ -389,8 +403,8 @@ namespace ghostnet_wpf_example
private void OpenFileCommand(object sender, ExecutedRoutedEventArgs e)
{
- OpenFile(sender, e);
- }
+ OpenFile(sender, e);
+ }
private void CleanUp()
{
@@ -424,7 +438,7 @@ namespace ghostnet_wpf_example
xaml_currPage.Text = "0";
CloseExtraWindows(false);
- m_ghostscript.gsPageRenderedMain -= new ghostsharp.gsCallBackPageRenderedMain(gsPageRendered);
+ m_ghostscript.PageRenderedCallBack -= new GSNET.PageRendered(gsPageRendered);
m_ghostscript.DisplayDeviceClose();
m_ghostscript.DisplayDeviceOpen();
m_viewer_state = ViewerState_t.NO_FILE;
@@ -508,7 +522,7 @@ namespace ghostnet_wpf_example
* progress as we distill the stream for PS or page by page for PDF */
string extension = System.IO.Path.GetExtension(FileName);
- /* We are doing this based on the extension but like should do
+ /* We are doing this based on the extension but should do
* it based upon the content */
switch (extension.ToUpper())
{
@@ -551,7 +565,6 @@ namespace ghostnet_wpf_example
m_document_type == doc_t.XPS ||
m_document_type == doc_t.PS)
{
-
MessageBoxResult result = MessageBox.Show("Would you like to distill this file?", "ghostnet", MessageBoxButton.YesNoCancel);
switch (result)
{
diff --git a/demos/csharp/windows/ghostnet_wpf_example/MainZoom.cs b/demos/csharp/windows/ghostnet_wpf_example/MainZoom.cs
index 08e270e2..9fcc5d56 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/MainZoom.cs
+++ b/demos/csharp/windows/ghostnet_wpf_example/MainZoom.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.Windows;
using System.Windows.Controls;
using System.Text.RegularExpressions;
diff --git a/demos/csharp/windows/ghostnet_wpf_example/PrintControl.xaml b/demos/csharp/windows/ghostnet_wpf_example/PrintControl.xaml
index cc7bb6b6..4dc7c5be 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/PrintControl.xaml
+++ b/demos/csharp/windows/ghostnet_wpf_example/PrintControl.xaml
@@ -1,4 +1,20 @@
-<Window x:Class="ghostnet_wpf_example.Print"
+<!--
+ Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+-->
+
+<Window x:Class="ghostnet_wpf_example.Print"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
diff --git a/demos/csharp/windows/ghostnet_wpf_example/PrintControl.xaml.cs b/demos/csharp/windows/ghostnet_wpf_example/PrintControl.xaml.cs
index bd5454b5..cf2973aa 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/PrintControl.xaml.cs
+++ b/demos/csharp/windows/ghostnet_wpf_example/PrintControl.xaml.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.Collections.Generic;
using System.Windows;
using System.Windows.Controls;
diff --git a/demos/csharp/windows/ghostnet_wpf_example/PrintStatus.xaml b/demos/csharp/windows/ghostnet_wpf_example/PrintStatus.xaml
index 7a40d169..2c5d091b 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/PrintStatus.xaml
+++ b/demos/csharp/windows/ghostnet_wpf_example/PrintStatus.xaml
@@ -1,4 +1,20 @@
-<Window x:Class="ghostnet_wpf_example.PrintStatus"
+<!--
+ Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+-->
+
+<Window x:Class="ghostnet_wpf_example.PrintStatus"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
diff --git a/demos/csharp/windows/ghostnet_wpf_example/PrintStatus.xaml.cs b/demos/csharp/windows/ghostnet_wpf_example/PrintStatus.xaml.cs
index 41480471..aca2e6bc 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/PrintStatus.xaml.cs
+++ b/demos/csharp/windows/ghostnet_wpf_example/PrintStatus.xaml.cs
@@ -1,16 +1,19 @@
-using System;
-using System.Collections.Generic;
-using System.Linq;
-using System.Text;
-using System.Threading.Tasks;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
using System.Windows;
-using System.Windows.Controls;
-using System.Windows.Data;
-using System.Windows.Documents;
-using System.Windows.Input;
-using System.Windows.Media;
-using System.Windows.Media.Imaging;
-using System.Windows.Shapes;
namespace ghostnet_wpf_example
{
diff --git a/demos/csharp/windows/ghostnet_wpf_example/TempFile.cs b/demos/csharp/windows/ghostnet_wpf_example/TempFile.cs
index db0c50cb..de7f5309 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/TempFile.cs
+++ b/demos/csharp/windows/ghostnet_wpf_example/TempFile.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.IO;
/* A class to help in the management of temp files */
diff --git a/demos/csharp/windows/ghostnet_wpf_example/XPSprint.cs b/demos/csharp/windows/ghostnet_wpf_example/XPSprint.cs
index f6934467..a1d03416 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/XPSprint.cs
+++ b/demos/csharp/windows/ghostnet_wpf_example/XPSprint.cs
@@ -1,3 +1,18 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
using System;
using System.Printing;
using System.Windows.Documents;
diff --git a/demos/csharp/windows/ghostnet_wpf_example/gsIO.cs b/demos/csharp/windows/ghostnet_wpf_example/gsIO.cs
index 0b2d0fd8..fdd1e759 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/gsIO.cs
+++ b/demos/csharp/windows/ghostnet_wpf_example/gsIO.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.ComponentModel;
namespace ghostnet_wpf_example
diff --git a/demos/csharp/windows/ghostnet_wpf_example/gsOutput.xaml b/demos/csharp/windows/ghostnet_wpf_example/gsOutput.xaml
index cb4261ba..28fc19b4 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/gsOutput.xaml
+++ b/demos/csharp/windows/ghostnet_wpf_example/gsOutput.xaml
@@ -1,4 +1,20 @@
-<Window x:Class="ghostnet_wpf_example.gsOutput"
+<!--
+ Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+-->
+
+<Window x:Class="ghostnet_wpf_example.gsOutput"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="Ghostscript Messages" Height="500" Width="500"
diff --git a/demos/csharp/windows/ghostnet_wpf_example/gsOutput.xaml.cs b/demos/csharp/windows/ghostnet_wpf_example/gsOutput.xaml.cs
index 01075cd2..e3bb76ae 100644
--- a/demos/csharp/windows/ghostnet_wpf_example/gsOutput.xaml.cs
+++ b/demos/csharp/windows/ghostnet_wpf_example/gsOutput.xaml.cs
@@ -1,4 +1,19 @@
-using System;
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+using System;
using System.Windows;
namespace ghostnet_wpf_example
diff --git a/demos/java/README.txt b/demos/java/README.txt
new file mode 100644
index 00000000..4781bb09
--- /dev/null
+++ b/demos/java/README.txt
@@ -0,0 +1,8 @@
+All README files assume that the user is using Java 8.
+
+On Windows, make sure the JDK is installed and the bin directory
+inside the installation folder is added to the PATH environment
+variable. This exposes command line programs to build Java
+applications.
+
+On Linux and Mac, OpenJDK 8 is used.
diff --git a/demos/java/gsjava/Manifest.md b/demos/java/gsjava/Manifest.md
new file mode 100644
index 00000000..de55435b
--- /dev/null
+++ b/demos/java/gsjava/Manifest.md
@@ -0,0 +1,2 @@
+Manifest-Version: 1.0
+Class-Path: ./ \ No newline at end of file
diff --git a/demos/java/gsjava/README.txt b/demos/java/gsjava/README.txt
index 07c55675..2b606be7 100644
--- a/demos/java/gsjava/README.txt
+++ b/demos/java/gsjava/README.txt
@@ -1,9 +1,3 @@
-Required libraries for this library:
-gpdldll64.dll
-gs_jni.dll
-
-Java Library:
-
This library contains direct bindings to Ghostscript as
well as several utility methods to make using the
Ghostscript calls easier.
@@ -25,7 +19,7 @@ are avaliable if needed. The Reference class acts as
a pointer parameter in a C function. An example use of this
is in gsapi_new_instance which takes a Reference<Long> as
a parameter. Calling the method would place the new
-Ghoscript instance in the Reference<Long>'s value field.
+Ghostscript instance in the Reference<Long>'s value field.
The com.artifex.gsjava.GSInstance is a
utility class. The GSInstance class stores an instance
@@ -34,26 +28,26 @@ class are named the same in which they are documented without
the need to pass the "instance" parameter through.
The com.artifex.gsjava.devices package contains several
-classes representing Ghoscript devices. Using the classes
+classes representing Ghostscript devices. Using the classes
in this package is the greatest amount of separation from
-using the raw Ghoscript calls and it requires no direct
+using the raw Ghostscript calls and it requires no direct
calls through the GSAPI class. All device classes in this
package are extensions of Device which provides a way
-of setting up a Ghoscript device and setting parameters.
+of setting up a Ghostscript device and setting parameters.
Subclasses have utility methods to set individual parameters
through method calls instead of using a String and parameter
type to specify the parameter name and type, respectively.
-Example code segment to set up an instance of Ghoscript:
+Example code segment to set up an instance of Ghostscript:
import com.artifex.gsjava.*;
import com.artifex.gsjava.util.*;
public static void main(String[] args) {
- // Stores a reference to the Ghoscript instance
+ // Stores a reference to the Ghostscript instance
Reference<Long> instanceReference = new Reference<>();
- // Creates a new Ghoscript instance with a NULL caller handle,
+ // Creates a new Ghostscript instance with a NULL caller handle,
// placing the instance into instanceReference
int code = GSAPI.gsapi_new_instance(instanceReference, GSAPI.GS_NULL);
@@ -67,71 +61,23 @@ public static void main(String[] args) {
// size in bytes.
long instance = instanceReference.getValue();
- // Deletes the Ghoscript instance
+ // Deletes the Ghostscript instance
GSAPI.gsapi_delete_instance(instance);
}
-C++ Library:
-
-This library builds to gs_jni.dll and uses the
-Java Native Interface (JNI) to bind the functions in
-the GSAPI class to Ghoscript as well as handling callbacks,
-exceptions, and references.
-
-The bindings in GSAPI are in the header com_artifex_gsjava_GSJAVA.h
-and the implementations are in com_artifex_gsjava_GSJAVA.cpp.
-
-Utility methods for throwing exceptions, setting fields, calling
-Java methods, and using the Reference<T> class are declared
-in jni_util.h.
-
-Example method explaining the implementation for
-gsapi_run_string_begin:
-
-
-/* JNIEnv *env - Provided the JNI. Allows interfacing into calling Java methods,
- * setting Java fields, etc. Different threads have different JNIEnv objects.
- *
- * jclass - Provided by the JNI. It represents the class calling this method.
- *
- * jlong instance - Instance to be passed to gsapi_run_string_begin
- *
- * jint userErrors - User errors to be passed to gsapi_run_string_begin
- *
- * jobject pExitCode - A Reference<Integer> object. This is always the case as the Java
- * code will not allow anything else to be passed. The value which Ghostscript returns
- * in the pExitCode parameter will be placed into here.
- */
-JNIEXPORT jint JNICALL Java_com_artifex_gsjava_GSAPI_gsapi_1run_1string_1begin
- (JNIEnv *env, jclass, jlong instance, jint userErrors, jobject pExitCode)
-{
- // Declares the exitCode parameter which will be passed as a pointer
- // to gsapi_run_string_begin
- int exitCode;
-
- // Different threads have different JNIEnv objects, so each time a JNI method
- // is called, this must be set so the Java callback methods can be called.
- callbacks::setJNIEnv(env);
-
- // Calls the Ghoscript call gsapi_run_string_begin
- int code = gsapi_run_string_begin((void *)instance, userErrors, &exitCode);
-
- // If the reference is not NULL, set the value of the reference to the exitCode returned
- // from Ghoscript. It must be converted to the wrapper type java.lang.Integer as Java does not support
- // primitive generic arguments (i.e. int, float, char, etc.)
- if (pExitCode)
- Reference::setValueField(env, pExitCode, toWrapperType(env, (jint)exitCode));
-
- // Return the error code returned by Ghostscript
- return code;
-}
+To build the library, build_linux.sh can be used on Linux,
+build_darwin.sh can be used on Mac, and build_win32.bat on Windows.
+
+All of these scripts do not compile Ghostscript. However,
+build_linux.sh and build_darwin.sh will compile the C++
+library unlike build_win32.bat.
Viewer:
-There is an eclipse project containing a viewer using the
-Java Ghostscript bindings in gsjava. The eclipse project is
-set up such that the gsjava eclipse project must be built
-to a jar file and used in the gsviewer eclipse project.
+There is an Eclipse project containing a viewer using the
+Java Ghostscript bindings in gsjava. The Eclipse project is
+set up such that the gsjava Eclipse project must be built
+to a jar file and used in the gsviewer Eclipse project.
The viewer is designed to load PDF documents, but can also
load other files like PostScript files and distill them into
@@ -139,11 +85,11 @@ a PDF document to be opened.
When the document is first loaded, every page is rendered at
a low resolution. These will be displayed as thumbnails on the
-left side. All loadingg is done in the com.artifex.gsjava.Document
+left side. All loading is done in the com.artifex.gsjava.Document
class. As the user changes the position of the viewport, the
viewer will dynamically load high resolution images based on
what page the user is viewing. This is done in the
com.artifex.gsviewer.ViewerController.SmartLoader class. This
also handles rendering zoomed images if necessary. Only pages
which need to be loaded at a high resolution are loaded, and
-zoomed pages are unloaded when no longer necessary to save memory. \ No newline at end of file
+zoomed pages are unloaded when no longer necessary to save memory.
diff --git a/demos/java/gsjava/build_darwin.sh b/demos/java/gsjava/build_darwin.sh
new file mode 100644
index 00000000..212dfb36
--- /dev/null
+++ b/demos/java/gsjava/build_darwin.sh
@@ -0,0 +1,62 @@
+#!/bin/bash
+
+mkdir -p bin
+
+echo "Compiling gs_jni C++ source..."
+
+cd "../jni/gs_jni"
+
+bash build_darwin.sh
+
+cd "../../gsjava"
+
+echo "Compiling gsjava Java source..."
+javac -sourcepath src/ -d bin/ \
+ "src/com/artifex/gsjava/GSAPI.java" \
+ "src/com/artifex/gsjava/GSInstance.java" \
+ \
+ "src/com/artifex/gsjava/util/AllocationError.java" \
+ "src/com/artifex/gsjava/util/ByteArrayReference.java" \
+ "src/com/artifex/gsjava/util/BytePointer.java" \
+ "src/com/artifex/gsjava/util/NativeArray.java" \
+ "src/com/artifex/gsjava/util/NativePointer.java" \
+ "src/com/artifex/gsjava/util/Reference.java" \
+ "src/com/artifex/gsjava/util/StringUtil.java" \
+ \
+ "src/com/artifex/gsjava/callbacks/DisplayCallback.java" \
+ "src/com/artifex/gsjava/callbacks/ICalloutFunction.java" \
+ "src/com/artifex/gsjava/callbacks/IPollFunction.java" \
+ "src/com/artifex/gsjava/callbacks/IStdErrFunction.java" \
+ "src/com/artifex/gsjava/callbacks/IStdInFunction.java" \
+ "src/com/artifex/gsjava/callbacks/IStdOutFunction.java" \
+ \
+ "src/com/artifex/gsjava/devices/BMPDevice.java" \
+ "src/com/artifex/gsjava/devices/Device.java" \
+ "src/com/artifex/gsjava/devices/DeviceInUseException.java" \
+ "src/com/artifex/gsjava/devices/DeviceNotSupportedException.java" \
+ "src/com/artifex/gsjava/devices/DisplayDevice.java" \
+ "src/com/artifex/gsjava/devices/EPSDevice.java" \
+ "src/com/artifex/gsjava/devices/FAXDevice.java" \
+ "src/com/artifex/gsjava/devices/FileDevice.java" \
+ "src/com/artifex/gsjava/devices/HighLevelDevice.java" \
+ "src/com/artifex/gsjava/devices/JPEGDevice.java" \
+ "src/com/artifex/gsjava/devices/OCRDevice.java" \
+ "src/com/artifex/gsjava/devices/PCXDevice.java" \
+ "src/com/artifex/gsjava/devices/PDFDevice.java" \
+ "src/com/artifex/gsjava/devices/PDFImageDevice.java" \
+ "src/com/artifex/gsjava/devices/PDFPostscriptDeviceFamily.java" \
+ "src/com/artifex/gsjava/devices/PNGDevice.java" \
+ "src/com/artifex/gsjava/devices/PNMDevice.java" \
+ "src/com/artifex/gsjava/devices/PostScriptDevice.java" \
+ "src/com/artifex/gsjava/devices/PSDDevice.java" \
+ "src/com/artifex/gsjava/devices/PXLDevice.java" \
+ "src/com/artifex/gsjava/devices/TextDevice.java" \
+ "src/com/artifex/gsjava/devices/TIFFDevice.java" \
+ "src/com/artifex/gsjava/devices/XPSDevice.java"
+
+cd bin
+
+echo "Packing gsjava JAR file..."
+jar cfm "../gsjava.jar" "../Manifest.md" "com/"
+
+cd .. \ No newline at end of file
diff --git a/demos/java/gsjava/build_linux.sh b/demos/java/gsjava/build_linux.sh
new file mode 100644
index 00000000..2866c07e
--- /dev/null
+++ b/demos/java/gsjava/build_linux.sh
@@ -0,0 +1,62 @@
+#!/bin/bash
+
+mkdir -p bin
+
+echo "Compiling gs_jni C++ source..."
+
+cd "../jni/gs_jni"
+
+bash build_linux.sh
+
+cd "../../gsjava"
+
+echo "Compiling gsjava Java source..."
+javac -sourcepath src/ -d bin/ \
+ "src/com/artifex/gsjava/GSAPI.java" \
+ "src/com/artifex/gsjava/GSInstance.java" \
+ \
+ "src/com/artifex/gsjava/util/AllocationError.java" \
+ "src/com/artifex/gsjava/util/ByteArrayReference.java" \
+ "src/com/artifex/gsjava/util/BytePointer.java" \
+ "src/com/artifex/gsjava/util/NativeArray.java" \
+ "src/com/artifex/gsjava/util/NativePointer.java" \
+ "src/com/artifex/gsjava/util/Reference.java" \
+ "src/com/artifex/gsjava/util/StringUtil.java" \
+ \
+ "src/com/artifex/gsjava/callbacks/DisplayCallback.java" \
+ "src/com/artifex/gsjava/callbacks/ICalloutFunction.java" \
+ "src/com/artifex/gsjava/callbacks/IPollFunction.java" \
+ "src/com/artifex/gsjava/callbacks/IStdErrFunction.java" \
+ "src/com/artifex/gsjava/callbacks/IStdInFunction.java" \
+ "src/com/artifex/gsjava/callbacks/IStdOutFunction.java" \
+ \
+ "src/com/artifex/gsjava/devices/BMPDevice.java" \
+ "src/com/artifex/gsjava/devices/Device.java" \
+ "src/com/artifex/gsjava/devices/DeviceInUseException.java" \
+ "src/com/artifex/gsjava/devices/DeviceNotSupportedException.java" \
+ "src/com/artifex/gsjava/devices/DisplayDevice.java" \
+ "src/com/artifex/gsjava/devices/EPSDevice.java" \
+ "src/com/artifex/gsjava/devices/FAXDevice.java" \
+ "src/com/artifex/gsjava/devices/FileDevice.java" \
+ "src/com/artifex/gsjava/devices/HighLevelDevice.java" \
+ "src/com/artifex/gsjava/devices/JPEGDevice.java" \
+ "src/com/artifex/gsjava/devices/OCRDevice.java" \
+ "src/com/artifex/gsjava/devices/PCXDevice.java" \
+ "src/com/artifex/gsjava/devices/PDFDevice.java" \
+ "src/com/artifex/gsjava/devices/PDFImageDevice.java" \
+ "src/com/artifex/gsjava/devices/PDFPostscriptDeviceFamily.java" \
+ "src/com/artifex/gsjava/devices/PNGDevice.java" \
+ "src/com/artifex/gsjava/devices/PNMDevice.java" \
+ "src/com/artifex/gsjava/devices/PostScriptDevice.java" \
+ "src/com/artifex/gsjava/devices/PSDDevice.java" \
+ "src/com/artifex/gsjava/devices/PXLDevice.java" \
+ "src/com/artifex/gsjava/devices/TextDevice.java" \
+ "src/com/artifex/gsjava/devices/TIFFDevice.java" \
+ "src/com/artifex/gsjava/devices/XPSDevice.java"
+
+cd bin
+
+echo "Packing gsjava JAR file..."
+jar cfm "../gsjava.jar" "../Manifest.md" "com/"
+
+cd .. \ No newline at end of file
diff --git a/demos/java/gsjava/build_win32.bat b/demos/java/gsjava/build_win32.bat
new file mode 100644
index 00000000..88757811
--- /dev/null
+++ b/demos/java/gsjava/build_win32.bat
@@ -0,0 +1,101 @@
+@echo off
+
+if not exist bin mkdir bin
+
+echo Compiling Java source...
+javac -sourcepath src\ -d bin^
+ src\com\artifex\gsjava\GSAPI.java^
+ src\com\artifex\gsjava\GSInstance.java^
+ ^
+ src\com\artifex\gsjava\util\AllocationError.java^
+ src\com\artifex\gsjava\util\ByteArrayReference.java^
+ src\com\artifex\gsjava\util\BytePointer.java^
+ src\com\artifex\gsjava\util\NativeArray.java^
+ src\com\artifex\gsjava\util\NativePointer.java^
+ src\com\artifex\gsjava\util\Reference.java^
+ src\com\artifex\gsjava\util\StringUtil.java^
+ ^
+ src\com\artifex\gsjava\callbacks\DisplayCallback.java^
+ src\com\artifex\gsjava\callbacks\ICalloutFunction.java^
+ src\com\artifex\gsjava\callbacks\IPollFunction.java^
+ src\com\artifex\gsjava\callbacks\IStdErrFunction.java^
+ src\com\artifex\gsjava\callbacks\IStdInFunction.java^
+ src\com\artifex\gsjava\callbacks\IStdOutFunction.java^
+ ^
+ src\com\artifex\gsjava\devices\BMPDevice.java^
+ src\com\artifex\gsjava\devices\Device.java^
+ src\com\artifex\gsjava\devices\DeviceInUseException.java^
+ src\com\artifex\gsjava\devices\DeviceNotSupportedException.java^
+ src\com\artifex\gsjava\devices\DisplayDevice.java^
+ src\com\artifex\gsjava\devices\EPSDevice.java^
+ src\com\artifex\gsjava\devices\FAXDevice.java^
+ src\com\artifex\gsjava\devices\FileDevice.java^
+ src\com\artifex\gsjava\devices\HighLevelDevice.java^
+ src\com\artifex\gsjava\devices\JPEGDevice.java^
+ src\com\artifex\gsjava\devices\OCRDevice.java^
+ src\com\artifex\gsjava\devices\PCXDevice.java^
+ src\com\artifex\gsjava\devices\PDFDevice.java^
+ src\com\artifex\gsjava\devices\PDFImageDevice.java^
+ src\com\artifex\gsjava\devices\PDFPostscriptDeviceFamily.java^
+ src\com\artifex\gsjava\devices\PNGDevice.java^
+ src\com\artifex\gsjava\devices\PNMDevice.java^
+ src\com\artifex\gsjava\devices\PostScriptDevice.java^
+ src\com\artifex\gsjava\devices\PSDDevice.java^
+ src\com\artifex\gsjava\devices\PXLDevice.java^
+ src\com\artifex\gsjava\devices\TextDevice.java^
+ src\com\artifex\gsjava\devices\TIFFDevice.java^
+ src\com\artifex\gsjava\devices\XPSDevice.java
+
+cd bin
+
+echo Packing JAR file...
+jar -cf ..\gsjava.jar^
+ com\artifex\gsjava\GSAPI.class^
+ com\artifex\gsjava\GSAPI$Revision.class^
+ com\artifex\gsjava\GSInstance.class^
+ com\artifex\gsjava\GSInstance$1.class^
+ com\artifex\gsjava\GSInstance$GSParam.class^
+ com\artifex\gsjava\GSInstance$ParamIterator.class^
+ ^
+ com\artifex\gsjava\util\AllocationError.class^
+ com\artifex\gsjava\util\ByteArrayReference.class^
+ com\artifex\gsjava\util\BytePointer.class^
+ com\artifex\gsjava\util\NativeArray.class^
+ com\artifex\gsjava\util\NativePointer.class^
+ com\artifex\gsjava\util\Reference.class^
+ com\artifex\gsjava\util\StringUtil.class^
+ ^
+ com\artifex\gsjava\callbacks\DisplayCallback.class^
+ com\artifex\gsjava\callbacks\ICalloutFunction.class^
+ com\artifex\gsjava\callbacks\IPollFunction.class^
+ com\artifex\gsjava\callbacks\IStdErrFunction.class^
+ com\artifex\gsjava\callbacks\IStdInFunction.class^
+ com\artifex\gsjava\callbacks\IStdOutFunction.class^
+ ^
+ com\artifex\gsjava\devices\BMPDevice.class^
+ com\artifex\gsjava\devices\Device.class^
+ com\artifex\gsjava\devices\Device$1.class^
+ com\artifex\gsjava\devices\Device$StdIO.class^
+ com\artifex\gsjava\devices\DeviceInUseException.class^
+ com\artifex\gsjava\devices\DeviceNotSupportedException.class^
+ com\artifex\gsjava\devices\DisplayDevice.class^
+ com\artifex\gsjava\devices\EPSDevice.class^
+ com\artifex\gsjava\devices\FAXDevice.class^
+ com\artifex\gsjava\devices\FileDevice.class^
+ com\artifex\gsjava\devices\HighLevelDevice.class^
+ com\artifex\gsjava\devices\JPEGDevice.class^
+ com\artifex\gsjava\devices\OCRDevice.class^
+ com\artifex\gsjava\devices\PCXDevice.class^
+ com\artifex\gsjava\devices\PDFDevice.class^
+ com\artifex\gsjava\devices\PDFImageDevice.class^
+ com\artifex\gsjava\devices\PDFPostscriptDeviceFamily.class^
+ com\artifex\gsjava\devices\PNGDevice.class^
+ com\artifex\gsjava\devices\PNMDevice.class^
+ com\artifex\gsjava\devices\PostScriptDevice.class^
+ com\artifex\gsjava\devices\PSDDevice.class^
+ com\artifex\gsjava\devices\PXLDevice.class^
+ com\artifex\gsjava\devices\TextDevice.class^
+ com\artifex\gsjava\devices\TIFFDevice.class^
+ com\artifex\gsjava\devices\XPSDevice.class
+
+cd .. \ No newline at end of file
diff --git a/demos/java/gsjava/src/com/artifex/gsjava/GSAPI.java b/demos/java/gsjava/src/com/artifex/gsjava/GSAPI.java
index f275e417..652d4356 100644
--- a/demos/java/gsjava/src/com/artifex/gsjava/GSAPI.java
+++ b/demos/java/gsjava/src/com/artifex/gsjava/GSAPI.java
@@ -11,6 +11,9 @@ import com.artifex.gsjava.callbacks.IStdOutFunction;
import com.artifex.gsjava.util.Reference;
import com.artifex.gsjava.util.StringUtil;
+import java.io.File;
+import com.artifex.gsjava.util.BytePointer;
+
/**
* Class which contains native bindings to Ghostscript via the JNI.
*
@@ -27,7 +30,27 @@ public class GSAPI {
* Registers the needed native libraries.
*/
private static void registerLibraries() {
- System.loadLibrary("gs_jni");
+ try {
+ // Try loading normally
+ System.loadLibrary("gs_jni");
+ } catch (UnsatisfiedLinkError e) {
+ // Load using absolute paths
+ if (System.getProperty("os.name").equalsIgnoreCase("Linux")) {
+ // Load on Linux
+ File libgpdl = new File("libgpdl.so");
+ System.load(libgpdl.getAbsolutePath());
+ File gsjni = new File("gs_jni.so");
+ System.load(gsjni.getAbsolutePath());
+ } else if (System.getProperty("os.name").equalsIgnoreCase("Mac OS X")) {
+ // Load on Mac
+ File libgpdl = new File("libgpdl.dylib");
+ System.load(libgpdl.getAbsolutePath());
+ File gsjni = new File("gs_jni.dylib");
+ System.load(gsjni.getAbsolutePath());
+ } else {
+ throw e;
+ }
+ }
}
/**
@@ -257,13 +280,13 @@ public class GSAPI {
return gsapi_run_file(instance, StringUtil.toNullTerminatedByteArray(fileName), userErrors, pExitCode);
}
- public static int gsapi_set_param(long instnace, String param, String value, int paramType) {
- return gsapi_set_param(instnace, StringUtil.toNullTerminatedByteArray(param),
+ public static int gsapi_set_param(long instance, String param, String value, int paramType) {
+ return gsapi_set_param(instance, StringUtil.toNullTerminatedByteArray(param),
StringUtil.toNullTerminatedByteArray(value), paramType);
}
- public static int gsapi_set_param(long instnace, String param, Object value, int paramType) {
- return gsapi_set_param(instnace, StringUtil.toNullTerminatedByteArray(param), value, paramType);
+ public static int gsapi_set_param(long instance, String param, Object value, int paramType) {
+ return gsapi_set_param(instance, StringUtil.toNullTerminatedByteArray(param), value, paramType);
}
public static int gsapi_get_param(long instance, String param, long value, int paramType) {
diff --git a/demos/java/gsjava/src/com/artifex/gsjava/util/NativePointer.java b/demos/java/gsjava/src/com/artifex/gsjava/util/NativePointer.java
index 222ade80..efe1a3e7 100644
--- a/demos/java/gsjava/src/com/artifex/gsjava/util/NativePointer.java
+++ b/demos/java/gsjava/src/com/artifex/gsjava/util/NativePointer.java
@@ -1,5 +1,7 @@
package com.artifex.gsjava.util;
+import java.io.File;
+
/**
* <p>The NativePointer class allows for direct non-managed memory
* allocations. The purpose of this class is to provide direct access
@@ -31,7 +33,27 @@ public class NativePointer {
* Registers the needed native libraries.
*/
private static void registerLibraries() {
- System.loadLibrary("gs_jni");
+ try {
+ // Try loading normally
+ System.loadLibrary("gs_jni");
+ } catch (UnsatisfiedLinkError e) {
+ // Load using absolute paths
+ if (System.getProperty("os.name").equalsIgnoreCase("Linux")) {
+ // Load on Linux
+ File libgpdl = new File("libgpdl.so");
+ System.load(libgpdl.getAbsolutePath());
+ File gsjni = new File("gs_jni.so");
+ System.load(gsjni.getAbsolutePath());
+ } else if (System.getProperty("os.name").equalsIgnoreCase("Mac OS X")) {
+ // Load on Mac
+ File libgpdl = new File("libgpdl.dylib");
+ System.load(libgpdl.getAbsolutePath());
+ File gsjni = new File("gs_jni.dylib");
+ System.load(gsjni.getAbsolutePath());
+ } else {
+ throw e;
+ }
+ }
}
public static final long NULL = 0x0L;
diff --git a/demos/java/gsviewer/Manifest.md b/demos/java/gsviewer/Manifest.md
new file mode 100644
index 00000000..77639479
--- /dev/null
+++ b/demos/java/gsviewer/Manifest.md
@@ -0,0 +1,3 @@
+Manifest-Version: 1.0
+Class-Path: gsjava.jar ./
+Main-Class: com.artifex.gsviewer.Main
diff --git a/demos/java/gsviewer/README.txt b/demos/java/gsviewer/README.txt
index 885edf1f..2808fed9 100644
--- a/demos/java/gsviewer/README.txt
+++ b/demos/java/gsviewer/README.txt
@@ -1,4 +1,70 @@
-required libraries in this directory:
+This project is a viewer designed to load PDF documents,
+but will also view other file types (like PostScript, XPS or PCL)
+by distilling them into PDF documents first.
+
+When the document is first loaded, every page is rendered at
+a low resolution. These will be displayed as thumbnails on the
+left side. All loading is done in the com.artifex.gsjava.Document
+class. As the user changes the position of the viewport, the
+viewer will dynamically load high resolution images based on
+what page the user is viewing. This is done in the
+com.artifex.gsviewer.ViewerController.SmartLoader class. This
+also handles rendering zoomed images if necessary. Only pages
+which need to be loaded at a high resolution are loaded, and
+zoomed pages are unloaded when no longer necessary to save memory.
+
+Required libraries in this directory for the viewer to work:
+
+-= WINDOWS =-
+
gpdldll64.dll
gs_jni.dll
-gsjava.jar \ No newline at end of file
+
+
+-= LINUX =-
+
+libgpdl.so (this would have been built as a link to another file, so
+it should be copied into this directory and renamed to libgpdl.so)
+gs_jni.so
+
+On Linux, when using OpenJDK, the property "assistive_technologies" may
+need to be modified for the Java code to build. It can be modified by
+editing the "accessibility.properties" file. This is located at:
+
+/etc/java-8-openjdk/accessibility.properties
+
+Additionally, to start the application, start_linux.sh should be executed as it
+sets up the shared library paths.
+
+
+-= MAC =-
+
+Same as Linux, except with .dylib extensions on all shared objects.
+
+start_darwin.sh should be used to start the application.
+
+
+Building:
+
+-= WINDOWS =-
+
+Ensure both gs_jni.dll and gpdldll64.dll. Then, run the build_win32.bat script.
+This will automatically build and copy gsjava.jar to this directory. To run,
+open gsviewer.jar either through File Explorer or in the command line through
+the following command:
+
+java -jar gsviewer.jar
+
+-= LINUX =-
+
+Ensure Ghostscript has been built.
+Run the build_linux.sh script. This will automatically build
+gs_jni.so, gsjava.jar, and copy the files to the needed
+directories. gsviewer.jar will be outputted in this directory.
+
+-= MAC =-
+
+Ensure Ghostscript has been built.
+Run the build_darwin.sh script. This will automatically build
+gs_jni.dylib, gsjava.jar, and copy the files to the needed
+directories. gsviewer.jar will be outputed in this directory.
diff --git a/demos/java/gsviewer/build_darwin.sh b/demos/java/gsviewer/build_darwin.sh
new file mode 100644
index 00000000..6c9d96c7
--- /dev/null
+++ b/demos/java/gsviewer/build_darwin.sh
@@ -0,0 +1,37 @@
+#!/bin/bash
+
+# build gsjava
+cd ../gsjava
+
+bash build_darwin.sh
+
+cd ../gsviewer
+
+cp ../gsjava/gsjava.jar gsjava.jar
+
+mkdir -p bin
+
+echo "Compiling gsviewer Java source..."
+javac -sourcepath src/ -d bin/ \
+ -classpath "../gsjava/bin" \
+ "src/com/artifex/gsviewer/DefaultUnhandledExceptionHandler.java" \
+ "src/com/artifex/gsviewer/Page.java" \
+ "src/com/artifex/gsviewer/Settings.java" \
+ "src/com/artifex/gsviewer/Document.java" \
+ "src/com/artifex/gsviewer/ImageUtil.java" \
+ "src/com/artifex/gsviewer/PageUpdateCallback.java" \
+ "src/com/artifex/gsviewer/StdIO.java" \
+ "src/com/artifex/gsviewer/GSFileFilter.java" \
+ "src/com/artifex/gsviewer/Main.java" \
+ "src/com/artifex/gsviewer/PDFFileFilter.java" \
+ "src/com/artifex/gsviewer/ViewerController.java" \
+ \
+ "src/com/artifex/gsviewer/gui/ScrollMap.java" \
+ "src/com/artifex/gsviewer/gui/SettingsDialog.java" \
+ "src/com/artifex/gsviewer/gui/ViewerGUIListener.java" \
+ "src/com/artifex/gsviewer/gui/ViewerWindow.java"
+
+cd bin
+
+echo "Packing gsviewer JAR file..."
+jar cfm "../gsviewer.jar" "../Manifest.md" "com/" \ No newline at end of file
diff --git a/demos/java/gsviewer/build_linux.sh b/demos/java/gsviewer/build_linux.sh
new file mode 100644
index 00000000..67b3e9cf
--- /dev/null
+++ b/demos/java/gsviewer/build_linux.sh
@@ -0,0 +1,37 @@
+#!/bin/bash
+
+# build gsjava
+cd ../gsjava
+
+bash build_linux.sh
+
+cd ../gsviewer
+
+cp ../gsjava/gsjava.jar gsjava.jar
+
+mkdir -p bin
+
+echo "Compiling gsviewer Java source..."
+javac -sourcepath src/ -d bin/ \
+ -classpath "../gsjava/bin" \
+ "src/com/artifex/gsviewer/DefaultUnhandledExceptionHandler.java" \
+ "src/com/artifex/gsviewer/Page.java" \
+ "src/com/artifex/gsviewer/Settings.java" \
+ "src/com/artifex/gsviewer/Document.java" \
+ "src/com/artifex/gsviewer/ImageUtil.java" \
+ "src/com/artifex/gsviewer/PageUpdateCallback.java" \
+ "src/com/artifex/gsviewer/StdIO.java" \
+ "src/com/artifex/gsviewer/GSFileFilter.java" \
+ "src/com/artifex/gsviewer/Main.java" \
+ "src/com/artifex/gsviewer/PDFFileFilter.java" \
+ "src/com/artifex/gsviewer/ViewerController.java" \
+ \
+ "src/com/artifex/gsviewer/gui/ScrollMap.java" \
+ "src/com/artifex/gsviewer/gui/SettingsDialog.java" \
+ "src/com/artifex/gsviewer/gui/ViewerGUIListener.java" \
+ "src/com/artifex/gsviewer/gui/ViewerWindow.java"
+
+cd bin
+
+echo "Packing gsviewer JAR file..."
+jar cfm "../gsviewer.jar" "../Manifest.md" "com/" \ No newline at end of file
diff --git a/demos/java/gsviewer/build_win32.bat b/demos/java/gsviewer/build_win32.bat
new file mode 100644
index 00000000..0e279e9f
--- /dev/null
+++ b/demos/java/gsviewer/build_win32.bat
@@ -0,0 +1,42 @@
+@echo off
+
+echo Build gsjava
+
+cd "..\gsjava"
+
+call build_win32
+
+cd "..\gsviewer"
+
+copy "..\gsjava\gsjava.jar" ".\gsjava.jar"
+
+echo Build gsviewer
+
+if not exist bin mkdir bin
+
+echo Compiling Java source...
+javac -sourcepath src\ -d bin\^
+ -classpath "..\gsjava\bin"^
+ "src\com\artifex\gsviewer\DefaultUnhandledExceptionHandler.java"^
+ "src\com\artifex\gsviewer\Page.java" ^
+ "src\com\artifex\gsviewer\Settings.java" ^
+ "src\com\artifex\gsviewer\Document.java" ^
+ "src\com\artifex\gsviewer\ImageUtil.java" ^
+ "src\com\artifex\gsviewer\PageUpdateCallback.java" ^
+ "src\com\artifex\gsviewer\StdIO.java" ^
+ "src\com\artifex\gsviewer\GSFileFilter.java" ^
+ "src\com\artifex\gsviewer\Main.java" ^
+ "src\com\artifex\gsviewer\PDFFileFilter.java" ^
+ "src\com\artifex\gsviewer\ViewerController.java" ^
+ ^
+ "src\com\artifex\gsviewer\gui\ScrollMap.java" ^
+ "src\com\artifex\gsviewer\gui\SettingsDialog.java" ^
+ "src\com\artifex\gsviewer\gui\ViewerGUIListener.java" ^
+ "src\com\artifex\gsviewer\gui\ViewerWindow.java"
+
+cd bin
+
+echo Packing JAR file...
+jar cfm "..\gsviewer.jar" "..\Manifest.md" com\
+
+cd.. \ No newline at end of file
diff --git a/demos/java/gsviewer/install_darwin.sh b/demos/java/gsviewer/install_darwin.sh
new file mode 100644
index 00000000..b6c58b86
--- /dev/null
+++ b/demos/java/gsviewer/install_darwin.sh
@@ -0,0 +1,11 @@
+#!bin/bash
+
+echo "Copy gs_jni.dylib"
+cp "../jni/gs_jni/gs_jni.dylib" "gs_jni.dylib"
+
+cd ../../../sobin
+
+echo "Copy libgpdl.dylib"
+cp $(readlink "libgpdl.dylib") "../demos/java/gsviewer"
+
+cd ../demos/java/gsviewer \ No newline at end of file
diff --git a/demos/java/gsviewer/install_linux.sh b/demos/java/gsviewer/install_linux.sh
new file mode 100644
index 00000000..4772d70a
--- /dev/null
+++ b/demos/java/gsviewer/install_linux.sh
@@ -0,0 +1,7 @@
+#!bin/bash
+
+cd ../jni/gs_jni
+
+bash install_linux.sh
+
+cd ../../gsviewer \ No newline at end of file
diff --git a/demos/java/gsviewer/src/com/artifex/gsviewer/Document.java b/demos/java/gsviewer/src/com/artifex/gsviewer/Document.java
index 6000d3e4..656ed3d1 100644
--- a/demos/java/gsviewer/src/com/artifex/gsviewer/Document.java
+++ b/demos/java/gsviewer/src/com/artifex/gsviewer/Document.java
@@ -579,8 +579,8 @@ public class Document implements List<Page> {
gsInstance.set_param("TextAlphaBits", 4, GS_SPT_INT);
gsInstance.set_param("GraphicsAlphaBits", 4, GS_SPT_INT);
} else {
- gsInstance.set_param("TextAlphaBits", 0, GS_SPT_INT);
- gsInstance.set_param("GraphicsAlphaBits", 0, GS_SPT_INT);
+ gsInstance.set_param("TextAlphaBits", 1, GS_SPT_INT);
+ gsInstance.set_param("GraphicsAlphaBits", 1, GS_SPT_INT);
}
this.pages = new ArrayList<>(documentLoader.images.size());
diff --git a/demos/java/gsviewer/src/com/artifex/gsviewer/Main.java b/demos/java/gsviewer/src/com/artifex/gsviewer/Main.java
index beecdd3b..775921af 100644
--- a/demos/java/gsviewer/src/com/artifex/gsviewer/Main.java
+++ b/demos/java/gsviewer/src/com/artifex/gsviewer/Main.java
@@ -7,6 +7,7 @@ import javax.swing.UIManager;
import javax.swing.UnsupportedLookAndFeelException;
import com.artifex.gsviewer.gui.ViewerWindow;
+import com.artifex.gsjava.util.BytePointer;
public class Main {
diff --git a/demos/java/gsviewer/start_darwin.sh b/demos/java/gsviewer/start_darwin.sh
new file mode 100644
index 00000000..9e4004bd
--- /dev/null
+++ b/demos/java/gsviewer/start_darwin.sh
@@ -0,0 +1,5 @@
+#!/bin/bash
+
+export LD_PRELOAD=./libgpdl.dylib
+
+java -jar gsviewer.jar \ No newline at end of file
diff --git a/demos/java/gsviewer/start_linux.sh b/demos/java/gsviewer/start_linux.sh
new file mode 100644
index 00000000..4ed9f514
--- /dev/null
+++ b/demos/java/gsviewer/start_linux.sh
@@ -0,0 +1,5 @@
+#!/bin/bash
+
+export LD_PRELOAD=/usr/lib/libgpdl.so.9
+
+java -jar gsviewer.jar \ No newline at end of file
diff --git a/demos/java/jni/gs_jni/README.txt b/demos/java/jni/gs_jni/README.txt
new file mode 100644
index 00000000..e38c34c0
--- /dev/null
+++ b/demos/java/jni/gs_jni/README.txt
@@ -0,0 +1,112 @@
+This library builds to gs_jni.dll and uses the
+Java Native Interface (JNI) to bind the functions in
+the GSAPI class to Ghostscript as well as handling callbacks,
+exceptions, and references.
+
+The bindings in GSAPI are in the header com_artifex_gsjava_GSJAVA.h
+and the implementations are in com_artifex_gsjava_GSJAVA.cpp.
+
+Utility methods for throwing exceptions, setting fields, calling
+Java methods, and using the Reference<T> class are declared
+in jni_util.h.
+
+To build, this project requires the header jni.h, which defines
+all JNI functions, and jni_md.h, which defines all system-specific
+integer types. Each of these headers requires a JDK install.
+
+The headers are typically found in the following directories:
+
+For Windows:
+
+jni.h:
+C:\Program Files\Java\<JDK Install>\include\jni.h
+
+jni_md.h:
+C:\Program Files\Java\<JDK Install>\include\win32\jni_md.h
+
+
+For Linux:
+
+jni.h:
+/lib/jvm/<JDK Install>/include/jni.h
+
+jni_md.h:
+/lib/jvm/<JDK Install>/include/linux/jni_md.h
+
+
+For Mac:
+
+jni.h:
+/Library/Java/JavaVirtualMachines/<JDK Install>/Contents/Home/include/jni.h
+
+jni_md.h:
+/Library/Java/JavaVirtualMachines/<JDK Install>/Contents/Home/include/darwin/jni_md.h
+
+So, a setup fully capable of building for any system should have an
+include directory resembling this, where each copy of jni_md.h comes
+from its respective system:
+
+* jni.h
+* win32\jni_md.h
+* linux/jni_md.h
+* darwin/jni_md.h
+
+To build on Windows,
+Ensure Ghostscript has already been built, and then open
+the gs_jni.sln (for Visual Studio 2019), and build the gs_jni
+project. This will compile to gs_jni.dll. For use in the Java interface,
+this DLL must be placed somewhere on the Java PATH. On Windows, this
+can be placed in the working directory, next to gsjava.jar (see
+..\..\gsjava\README.txt for information on how to build this).
+
+To build on Linux,
+Ensure Ghostscript has already been built, and then run
+the build_linux.sh script.
+
+To build on Mac,
+Ensure Ghostscript has already been built, and then run
+the build_darwin.sh script.
+
+Notes on function implementations and a brief introduction on
+how to use the JNI:
+
+Example method explaining the implementation for
+gsapi_run_string_begin:
+
+
+/* JNIEnv *env - Provided the JNI. Allows interfacing into calling Java methods,
+ * setting Java fields, etc. Different threads have different JNIEnv objects.
+ *
+ * jclass - Provided by the JNI. It represents the class calling this method.
+ *
+ * jlong instance - Instance to be passed to gsapi_run_string_begin
+ *
+ * jint userErrors - User errors to be passed to gsapi_run_string_begin
+ *
+ * jobject pExitCode - A Reference<Integer> object. This is always the case as the Java
+ * code will not allow anything else to be passed. The value which Ghostscript returns
+ * in the pExitCode parameter will be placed into here.
+ */
+JNIEXPORT jint JNICALL Java_com_artifex_gsjava_GSAPI_gsapi_1run_1string_1begin
+ (JNIEnv *env, jclass, jlong instance, jint userErrors, jobject pExitCode)
+{
+ // Declares the exitCode parameter which will be passed as a pointer
+ // to gsapi_run_string_begin
+ int exitCode;
+
+ // Different threads have different JNIEnv objects, so each time a JNI method
+ // is called, this must be set so the Java callback methods can be called.
+ callbacks::setJNIEnv(env);
+
+ // Calls the Ghostscript call gsapi_run_string_begin
+ int code = gsapi_run_string_begin((void *)instance, userErrors, &exitCode);
+
+ // If the reference is not NULL, set the value of the reference to the exitCode returned
+ // from Ghostscript. It must be converted to the wrapper type java.lang.Integer as Java does not support
+ // primitive generic arguments (i.e. int, float, char, etc.)
+ if (pExitCode)
+ Reference::setValueField(env, pExitCode, toWrapperType(env, (jint)exitCode));
+
+ // Return the error code returned by Ghostscript
+ return code;
+}
diff --git a/demos/java/jni/gs_jni/build_darwin.sh b/demos/java/jni/gs_jni/build_darwin.sh
new file mode 100644
index 00000000..81b10c01
--- /dev/null
+++ b/demos/java/jni/gs_jni/build_darwin.sh
@@ -0,0 +1,57 @@
+#!/bin/bash
+
+unset LD_LIBRARY_PATH
+
+mkdir -p obin
+
+echo "Compiling gs_jni C++ source..."
+
+echo "Compile callbacks.cpp"
+g++ -c -Wall -O3 -fPIC \
+ -std=c++14 \
+ -I./include \
+ -I./include/darwin \
+ -I./../../../../psi \
+ -I./../../../../devices \
+ "callbacks.cpp" \
+ -o "obin/callbacks.o"
+
+echo "Compile com_artifex_gsjava_GSAPI.cpp"
+g++ -c -Wall -O3 -fPIC \
+ -std=c++14 \
+ -I./include \
+ -I./include/darwin \
+ -I./../../../../psi \
+ -I./../../../../devices \
+ "com_artifex_gsjava_GSAPI.cpp" \
+ -o "obin/com_artifex_gsjava_GSAPI.o"
+
+echo "Compile com_artifex_gsjava_util_NativePointer.cpp"
+g++ -c -Wall -O3 -fPIC \
+ -std=c++14 \
+ -I./include \
+ -I./include/darwin \
+ -I./../../../../psi \
+ -I./../../../../devices \
+ "com_artifex_gsjava_util_NativePointer.cpp" \
+ -o "obin/com_artifex_gsjava_util_NativePointer.o"
+
+echo "Compile jni_util.cpp"
+g++ -c -Wall -O3 -fPIC \
+ -std=c++14 \
+ -I./include \
+ -I./include/darwin \
+ -I./../../../../psi \
+ -I./../../../../devices \
+ "jni_util.cpp" \
+ -o "obin/jni_util.o"
+
+echo "Link"
+g++ -dynamiclib -fPIC \
+ -Wl \
+ -o "gs_jni.dylib" \
+ "obin/callbacks.o" \
+ "obin/com_artifex_gsjava_GSAPI.o" \
+ "obin/com_artifex_gsjava_util_NativePointer.o" \
+ "obin/jni_util.o" \
+ "../../../../sobin/libgpdl.dylib" \ No newline at end of file
diff --git a/demos/java/jni/gs_jni/build_linux.sh b/demos/java/jni/gs_jni/build_linux.sh
new file mode 100644
index 00000000..974dfba3
--- /dev/null
+++ b/demos/java/jni/gs_jni/build_linux.sh
@@ -0,0 +1,57 @@
+#!/bin/bash
+
+unset LD_LIBRARY_PATH
+
+mkdir -p obin
+
+echo "Compiling gs_jni C++ source..."
+
+echo "Compile callbacks.cpp"
+g++ -c -Wall -O3 \
+ -std=c++14 \
+ -I./include \
+ -I./include/linux \
+ -I./../../../../psi \
+ -I./../../../../devices \
+ "callbacks.cpp" \
+ -o "obin/callbacks.o"
+
+echo "Compile com_artifex_gsjava_GSAPI.cpp"
+g++ -c -Wall -O3 \
+ -std=c++14 \
+ -I./include \
+ -I./include/linux \
+ -I./../../../../psi \
+ -I./../../../../devices \
+ "com_artifex_gsjava_GSAPI.cpp" \
+ -o "obin/com_artifex_gsjava_GSAPI.o"
+
+echo "Compile com_artifex_gsjava_util_NativePointer.cpp"
+g++ -c -Wall -O3 \
+ -std=c++14 \
+ -I./include \
+ -I./include/linux \
+ -I./../../../../psi \
+ -I./../../../../devices \
+ "com_artifex_gsjava_util_NativePointer.cpp" \
+ -o "obin/com_artifex_gsjava_util_NativePointer.o"
+
+echo "Compile jni_util.cpp"
+g++ -c -Wall -O3\
+ -std=c++14 \
+ -I./include \
+ -I./include/linux \
+ -I./../../../../psi \
+ -I./../../../../devices \
+ "jni_util.cpp" \
+ -o "obin/jni_util.o"
+
+echo "Link"
+g++ -shared \
+ -Wl,-soname,gs_jni.so \
+ -o "gs_jni.so" \
+ "obin/callbacks.o" \
+ "obin/com_artifex_gsjava_GSAPI.o" \
+ "obin/com_artifex_gsjava_util_NativePointer.o" \
+ "obin/jni_util.o" \
+ "../../../../sobin/libgpdl.so" \ No newline at end of file
diff --git a/demos/java/jni/gs_jni/callbacks.cpp b/demos/java/jni/gs_jni/callbacks.cpp
index a8ad2196..7826b328 100644
--- a/demos/java/jni/gs_jni/callbacks.cpp
+++ b/demos/java/jni/gs_jni/callbacks.cpp
@@ -174,7 +174,7 @@ int callbacks::display::displayOpenFunction(void *handle, void *device)
code = callIntMethod(g_env, g_displayCallback, "onDisplayOpen", DISPLAY_OPEN_SIG, (jlong)handle, (jlong)device);
CHECK_AND_RETURN(g_env);
}
- return 0;
+ return code;
}
int callbacks::display::displayPrecloseFunction(void *handle, void *device)
@@ -350,7 +350,18 @@ int callbacks::display::displayRectangleRequestFunction(void *handle, void *devi
Reference hRef = Reference(g_env, toWrapperType(g_env, (jint)*h));
code = callIntMethod(g_env, g_displayCallback, "onDisplayRectangleRequest", DISPLAY_RECTANGLE_REQUEST,
- (jlong)handle, (jlong)device, memoryRef, oxRef, oyRef, rasterRef, planeRasterRef, xRef, yRef, wRef, hRef);
+ (jlong)handle,
+ (jlong)device,
+ memoryRef.object(),
+ oxRef.object(),
+ oyRef.object(),
+ rasterRef.object(),
+ planeRasterRef.object(),
+ xRef.object(),
+ yRef.object(),
+ wRef.object(),
+ hRef.object()
+ );
*memory = (void *)memoryRef.longValue();
*ox = oxRef.intValue();
diff --git a/demos/java/jni/gs_jni/com_artifex_gsjava_GSAPI.cpp b/demos/java/jni/gs_jni/com_artifex_gsjava_GSAPI.cpp
index 7858112e..b28334e9 100644
--- a/demos/java/jni/gs_jni/com_artifex_gsjava_GSAPI.cpp
+++ b/demos/java/jni/gs_jni/com_artifex_gsjava_GSAPI.cpp
@@ -306,7 +306,6 @@ JNIEXPORT jint JNICALL Java_com_artifex_gsjava_GSAPI_gsapi_1set_1param
}
jboolean copy = false;
- int exitCode;
const char *cstring = (const char *)env->GetByteArrayElements(param, &copy);
callbacks::setJNIEnv(env);
@@ -326,7 +325,6 @@ JNIEXPORT jint JNICALL Java_com_artifex_gsjava_GSAPI_gsapi_1get_1param
}
jboolean copy = false;
- int exitCode;
const char *cstring = (const char *)env->GetByteArrayElements(param, &copy);
int ret = gsapi_get_param((void *)instance, cstring, (void *)value, (gs_set_param_type)paramType);
@@ -338,14 +336,13 @@ JNIEXPORT jint JNICALL Java_com_artifex_gsjava_GSAPI_gsapi_1get_1param_1once
(JNIEnv *env, jclass, jlong instance, jbyteArray param, jobject value, jint paramType)
{
jboolean copy = false;
- int exitCode;
const char *cstring = (const char *)env->GetByteArrayElements(param, &copy);
int bytes = gsapi_get_param((void *)instance, cstring, NULL, (gs_set_param_type)paramType);
if (bytes < 0)
return bytes;
- void *data = new char[bytes];
+ char *data = new char[bytes];
int code = gsapi_get_param((void *)instance, cstring, data, (gs_set_param_type)paramType);
if (code < 0)
{
diff --git a/demos/java/jni/gs_jni/com_artifex_gsjava_util_NativePointer.cpp b/demos/java/jni/gs_jni/com_artifex_gsjava_util_NativePointer.cpp
index b58c070c..04c435cb 100644
--- a/demos/java/jni/gs_jni/com_artifex_gsjava_util_NativePointer.cpp
+++ b/demos/java/jni/gs_jni/com_artifex_gsjava_util_NativePointer.cpp
@@ -47,7 +47,7 @@ JNIEXPORT jbyte JNICALL Java_com_artifex_gsjava_util_NativePointer_byteAtNative
JNIEXPORT void JNICALL Java_com_artifex_gsjava_util_NativePointer_setByteNative
(JNIEnv *, jclass, jlong address, jlong index, jbyte value)
{
- ((jbyte *)address)[index];
+ ((jbyte *)address)[index] = value;
}
JNIEXPORT jcharArray JNICALL Java_com_artifex_gsjava_util_NativePointer_charArrayNative
diff --git a/demos/java/jni/gs_jni/gs_jni.vcxproj b/demos/java/jni/gs_jni/gs_jni.vcxproj
index eae045e8..5febb0d2 100644
--- a/demos/java/jni/gs_jni/gs_jni.vcxproj
+++ b/demos/java/jni/gs_jni/gs_jni.vcxproj
@@ -91,7 +91,7 @@
<PrecompiledHeader>NotUsing</PrecompiledHeader>
<PrecompiledHeaderFile>
</PrecompiledHeaderFile>
- <AdditionalIncludeDirectories>$(SolutionDir)..\..\..\..\psi;$(SolutionDir)include;$(SolutionDir)..\..\..\..\..\ghostpdl\devices;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
+ <AdditionalIncludeDirectories>$(SolutionDir)include\win32;$(SolutionDir)..\..\..\..\psi;$(SolutionDir)include;$(SolutionDir)..\..\..\..\\devices;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
</ClCompile>
<Link>
<SubSystem>Windows</SubSystem>
@@ -112,7 +112,7 @@
<PrecompiledHeader>NotUsing</PrecompiledHeader>
<PrecompiledHeaderFile>
</PrecompiledHeaderFile>
- <AdditionalIncludeDirectories>$(SolutionDir)..\..\..\..\psi;$(SolutionDir)include;$(SolutionDir)..\..\..\..\..\ghostpdl\devices;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
+ <AdditionalIncludeDirectories>$(SolutionDir)include\win32;$(SolutionDir)..\..\..\..\psi;$(SolutionDir)include;$(SolutionDir)..\..\..\..\devices;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
</ClCompile>
<Link>
<SubSystem>Windows</SubSystem>
@@ -131,7 +131,7 @@
<PrecompiledHeader>NotUsing</PrecompiledHeader>
<PrecompiledHeaderFile>
</PrecompiledHeaderFile>
- <AdditionalIncludeDirectories>$(SolutionDir)..\..\..\..\psi;$(SolutionDir)include;$(SolutionDir)..\..\..\..\..\ghostpdl\devices;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
+ <AdditionalIncludeDirectories>$(SolutionDir)include\win32;$(SolutionDir)..\..\..\..\psi;$(SolutionDir)include;$(SolutionDir)..\..\..\..\devices;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
</ClCompile>
<Link>
<SubSystem>Windows</SubSystem>
@@ -152,7 +152,7 @@
<PrecompiledHeader>NotUsing</PrecompiledHeader>
<PrecompiledHeaderFile>
</PrecompiledHeaderFile>
- <AdditionalIncludeDirectories>$(SolutionDir)..\..\..\..\psi;$(SolutionDir)include;$(SolutionDir)..\..\..\..\..\ghostpdl\devices;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
+ <AdditionalIncludeDirectories>$(SolutionDir)include\win32;$(SolutionDir)..\..\..\..\psi;$(SolutionDir)include;$(SolutionDir)..\..\..\..\devices;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
</ClCompile>
<Link>
<SubSystem>Windows</SubSystem>
diff --git a/demos/java/jni/gs_jni/include/classfile_constants.h b/demos/java/jni/gs_jni/include/classfile_constants.h
deleted file mode 100644
index e5c20cd9..00000000
--- a/demos/java/jni/gs_jni/include/classfile_constants.h
+++ /dev/null
@@ -1,560 +0,0 @@
-/*
- * Copyright (c) 2004, 2012, Oracle and/or its affiliates. All rights reserved.
- * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- */
-
-#ifndef CLASSFILE_CONSTANTS_H
-#define CLASSFILE_CONSTANTS_H
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/* Classfile version number for this information */
-#define JVM_CLASSFILE_MAJOR_VERSION 52
-#define JVM_CLASSFILE_MINOR_VERSION 0
-
-/* Flags */
-
-enum {
- JVM_ACC_PUBLIC = 0x0001,
- JVM_ACC_PRIVATE = 0x0002,
- JVM_ACC_PROTECTED = 0x0004,
- JVM_ACC_STATIC = 0x0008,
- JVM_ACC_FINAL = 0x0010,
- JVM_ACC_SYNCHRONIZED = 0x0020,
- JVM_ACC_SUPER = 0x0020,
- JVM_ACC_VOLATILE = 0x0040,
- JVM_ACC_BRIDGE = 0x0040,
- JVM_ACC_TRANSIENT = 0x0080,
- JVM_ACC_VARARGS = 0x0080,
- JVM_ACC_NATIVE = 0x0100,
- JVM_ACC_INTERFACE = 0x0200,
- JVM_ACC_ABSTRACT = 0x0400,
- JVM_ACC_STRICT = 0x0800,
- JVM_ACC_SYNTHETIC = 0x1000,
- JVM_ACC_ANNOTATION = 0x2000,
- JVM_ACC_ENUM = 0x4000
-};
-
-/* Used in newarray instruction. */
-
-enum {
- JVM_T_BOOLEAN = 4,
- JVM_T_CHAR = 5,
- JVM_T_FLOAT = 6,
- JVM_T_DOUBLE = 7,
- JVM_T_BYTE = 8,
- JVM_T_SHORT = 9,
- JVM_T_INT = 10,
- JVM_T_LONG = 11
-};
-
-/* Constant Pool Entries */
-
-enum {
- JVM_CONSTANT_Utf8 = 1,
- JVM_CONSTANT_Unicode = 2, /* unused */
- JVM_CONSTANT_Integer = 3,
- JVM_CONSTANT_Float = 4,
- JVM_CONSTANT_Long = 5,
- JVM_CONSTANT_Double = 6,
- JVM_CONSTANT_Class = 7,
- JVM_CONSTANT_String = 8,
- JVM_CONSTANT_Fieldref = 9,
- JVM_CONSTANT_Methodref = 10,
- JVM_CONSTANT_InterfaceMethodref = 11,
- JVM_CONSTANT_NameAndType = 12,
- JVM_CONSTANT_MethodHandle = 15, // JSR 292
- JVM_CONSTANT_MethodType = 16, // JSR 292
- JVM_CONSTANT_InvokeDynamic = 18
-};
-
-/* JVM_CONSTANT_MethodHandle subtypes */
-enum {
- JVM_REF_getField = 1,
- JVM_REF_getStatic = 2,
- JVM_REF_putField = 3,
- JVM_REF_putStatic = 4,
- JVM_REF_invokeVirtual = 5,
- JVM_REF_invokeStatic = 6,
- JVM_REF_invokeSpecial = 7,
- JVM_REF_newInvokeSpecial = 8,
- JVM_REF_invokeInterface = 9
-};
-
-/* StackMapTable type item numbers */
-
-enum {
- JVM_ITEM_Top = 0,
- JVM_ITEM_Integer = 1,
- JVM_ITEM_Float = 2,
- JVM_ITEM_Double = 3,
- JVM_ITEM_Long = 4,
- JVM_ITEM_Null = 5,
- JVM_ITEM_UninitializedThis = 6,
- JVM_ITEM_Object = 7,
- JVM_ITEM_Uninitialized = 8
-};
-
-/* Type signatures */
-
-enum {
- JVM_SIGNATURE_ARRAY = '[',
- JVM_SIGNATURE_BYTE = 'B',
- JVM_SIGNATURE_CHAR = 'C',
- JVM_SIGNATURE_CLASS = 'L',
- JVM_SIGNATURE_ENDCLASS = ';',
- JVM_SIGNATURE_ENUM = 'E',
- JVM_SIGNATURE_FLOAT = 'F',
- JVM_SIGNATURE_DOUBLE = 'D',
- JVM_SIGNATURE_FUNC = '(',
- JVM_SIGNATURE_ENDFUNC = ')',
- JVM_SIGNATURE_INT = 'I',
- JVM_SIGNATURE_LONG = 'J',
- JVM_SIGNATURE_SHORT = 'S',
- JVM_SIGNATURE_VOID = 'V',
- JVM_SIGNATURE_BOOLEAN = 'Z'
-};
-
-/* Opcodes */
-
-enum {
- JVM_OPC_nop = 0,
- JVM_OPC_aconst_null = 1,
- JVM_OPC_iconst_m1 = 2,
- JVM_OPC_iconst_0 = 3,
- JVM_OPC_iconst_1 = 4,
- JVM_OPC_iconst_2 = 5,
- JVM_OPC_iconst_3 = 6,
- JVM_OPC_iconst_4 = 7,
- JVM_OPC_iconst_5 = 8,
- JVM_OPC_lconst_0 = 9,
- JVM_OPC_lconst_1 = 10,
- JVM_OPC_fconst_0 = 11,
- JVM_OPC_fconst_1 = 12,
- JVM_OPC_fconst_2 = 13,
- JVM_OPC_dconst_0 = 14,
- JVM_OPC_dconst_1 = 15,
- JVM_OPC_bipush = 16,
- JVM_OPC_sipush = 17,
- JVM_OPC_ldc = 18,
- JVM_OPC_ldc_w = 19,
- JVM_OPC_ldc2_w = 20,
- JVM_OPC_iload = 21,
- JVM_OPC_lload = 22,
- JVM_OPC_fload = 23,
- JVM_OPC_dload = 24,
- JVM_OPC_aload = 25,
- JVM_OPC_iload_0 = 26,
- JVM_OPC_iload_1 = 27,
- JVM_OPC_iload_2 = 28,
- JVM_OPC_iload_3 = 29,
- JVM_OPC_lload_0 = 30,
- JVM_OPC_lload_1 = 31,
- JVM_OPC_lload_2 = 32,
- JVM_OPC_lload_3 = 33,
- JVM_OPC_fload_0 = 34,
- JVM_OPC_fload_1 = 35,
- JVM_OPC_fload_2 = 36,
- JVM_OPC_fload_3 = 37,
- JVM_OPC_dload_0 = 38,
- JVM_OPC_dload_1 = 39,
- JVM_OPC_dload_2 = 40,
- JVM_OPC_dload_3 = 41,
- JVM_OPC_aload_0 = 42,
- JVM_OPC_aload_1 = 43,
- JVM_OPC_aload_2 = 44,
- JVM_OPC_aload_3 = 45,
- JVM_OPC_iaload = 46,
- JVM_OPC_laload = 47,
- JVM_OPC_faload = 48,
- JVM_OPC_daload = 49,
- JVM_OPC_aaload = 50,
- JVM_OPC_baload = 51,
- JVM_OPC_caload = 52,
- JVM_OPC_saload = 53,
- JVM_OPC_istore = 54,
- JVM_OPC_lstore = 55,
- JVM_OPC_fstore = 56,
- JVM_OPC_dstore = 57,
- JVM_OPC_astore = 58,
- JVM_OPC_istore_0 = 59,
- JVM_OPC_istore_1 = 60,
- JVM_OPC_istore_2 = 61,
- JVM_OPC_istore_3 = 62,
- JVM_OPC_lstore_0 = 63,
- JVM_OPC_lstore_1 = 64,
- JVM_OPC_lstore_2 = 65,
- JVM_OPC_lstore_3 = 66,
- JVM_OPC_fstore_0 = 67,
- JVM_OPC_fstore_1 = 68,
- JVM_OPC_fstore_2 = 69,
- JVM_OPC_fstore_3 = 70,
- JVM_OPC_dstore_0 = 71,
- JVM_OPC_dstore_1 = 72,
- JVM_OPC_dstore_2 = 73,
- JVM_OPC_dstore_3 = 74,
- JVM_OPC_astore_0 = 75,
- JVM_OPC_astore_1 = 76,
- JVM_OPC_astore_2 = 77,
- JVM_OPC_astore_3 = 78,
- JVM_OPC_iastore = 79,
- JVM_OPC_lastore = 80,
- JVM_OPC_fastore = 81,
- JVM_OPC_dastore = 82,
- JVM_OPC_aastore = 83,
- JVM_OPC_bastore = 84,
- JVM_OPC_castore = 85,
- JVM_OPC_sastore = 86,
- JVM_OPC_pop = 87,
- JVM_OPC_pop2 = 88,
- JVM_OPC_dup = 89,
- JVM_OPC_dup_x1 = 90,
- JVM_OPC_dup_x2 = 91,
- JVM_OPC_dup2 = 92,
- JVM_OPC_dup2_x1 = 93,
- JVM_OPC_dup2_x2 = 94,
- JVM_OPC_swap = 95,
- JVM_OPC_iadd = 96,
- JVM_OPC_ladd = 97,
- JVM_OPC_fadd = 98,
- JVM_OPC_dadd = 99,
- JVM_OPC_isub = 100,
- JVM_OPC_lsub = 101,
- JVM_OPC_fsub = 102,
- JVM_OPC_dsub = 103,
- JVM_OPC_imul = 104,
- JVM_OPC_lmul = 105,
- JVM_OPC_fmul = 106,
- JVM_OPC_dmul = 107,
- JVM_OPC_idiv = 108,
- JVM_OPC_ldiv = 109,
- JVM_OPC_fdiv = 110,
- JVM_OPC_ddiv = 111,
- JVM_OPC_irem = 112,
- JVM_OPC_lrem = 113,
- JVM_OPC_frem = 114,
- JVM_OPC_drem = 115,
- JVM_OPC_ineg = 116,
- JVM_OPC_lneg = 117,
- JVM_OPC_fneg = 118,
- JVM_OPC_dneg = 119,
- JVM_OPC_ishl = 120,
- JVM_OPC_lshl = 121,
- JVM_OPC_ishr = 122,
- JVM_OPC_lshr = 123,
- JVM_OPC_iushr = 124,
- JVM_OPC_lushr = 125,
- JVM_OPC_iand = 126,
- JVM_OPC_land = 127,
- JVM_OPC_ior = 128,
- JVM_OPC_lor = 129,
- JVM_OPC_ixor = 130,
- JVM_OPC_lxor = 131,
- JVM_OPC_iinc = 132,
- JVM_OPC_i2l = 133,
- JVM_OPC_i2f = 134,
- JVM_OPC_i2d = 135,
- JVM_OPC_l2i = 136,
- JVM_OPC_l2f = 137,
- JVM_OPC_l2d = 138,
- JVM_OPC_f2i = 139,
- JVM_OPC_f2l = 140,
- JVM_OPC_f2d = 141,
- JVM_OPC_d2i = 142,
- JVM_OPC_d2l = 143,
- JVM_OPC_d2f = 144,
- JVM_OPC_i2b = 145,
- JVM_OPC_i2c = 146,
- JVM_OPC_i2s = 147,
- JVM_OPC_lcmp = 148,
- JVM_OPC_fcmpl = 149,
- JVM_OPC_fcmpg = 150,
- JVM_OPC_dcmpl = 151,
- JVM_OPC_dcmpg = 152,
- JVM_OPC_ifeq = 153,
- JVM_OPC_ifne = 154,
- JVM_OPC_iflt = 155,
- JVM_OPC_ifge = 156,
- JVM_OPC_ifgt = 157,
- JVM_OPC_ifle = 158,
- JVM_OPC_if_icmpeq = 159,
- JVM_OPC_if_icmpne = 160,
- JVM_OPC_if_icmplt = 161,
- JVM_OPC_if_icmpge = 162,
- JVM_OPC_if_icmpgt = 163,
- JVM_OPC_if_icmple = 164,
- JVM_OPC_if_acmpeq = 165,
- JVM_OPC_if_acmpne = 166,
- JVM_OPC_goto = 167,
- JVM_OPC_jsr = 168,
- JVM_OPC_ret = 169,
- JVM_OPC_tableswitch = 170,
- JVM_OPC_lookupswitch = 171,
- JVM_OPC_ireturn = 172,
- JVM_OPC_lreturn = 173,
- JVM_OPC_freturn = 174,
- JVM_OPC_dreturn = 175,
- JVM_OPC_areturn = 176,
- JVM_OPC_return = 177,
- JVM_OPC_getstatic = 178,
- JVM_OPC_putstatic = 179,
- JVM_OPC_getfield = 180,
- JVM_OPC_putfield = 181,
- JVM_OPC_invokevirtual = 182,
- JVM_OPC_invokespecial = 183,
- JVM_OPC_invokestatic = 184,
- JVM_OPC_invokeinterface = 185,
- JVM_OPC_invokedynamic = 186,
- JVM_OPC_new = 187,
- JVM_OPC_newarray = 188,
- JVM_OPC_anewarray = 189,
- JVM_OPC_arraylength = 190,
- JVM_OPC_athrow = 191,
- JVM_OPC_checkcast = 192,
- JVM_OPC_instanceof = 193,
- JVM_OPC_monitorenter = 194,
- JVM_OPC_monitorexit = 195,
- JVM_OPC_wide = 196,
- JVM_OPC_multianewarray = 197,
- JVM_OPC_ifnull = 198,
- JVM_OPC_ifnonnull = 199,
- JVM_OPC_goto_w = 200,
- JVM_OPC_jsr_w = 201,
- JVM_OPC_MAX = 201
-};
-
-/* Opcode length initializer, use with something like:
- * unsigned char opcode_length[JVM_OPC_MAX+1] = JVM_OPCODE_LENGTH_INITIALIZER;
- */
-#define JVM_OPCODE_LENGTH_INITIALIZER { \
- 1, /* nop */ \
- 1, /* aconst_null */ \
- 1, /* iconst_m1 */ \
- 1, /* iconst_0 */ \
- 1, /* iconst_1 */ \
- 1, /* iconst_2 */ \
- 1, /* iconst_3 */ \
- 1, /* iconst_4 */ \
- 1, /* iconst_5 */ \
- 1, /* lconst_0 */ \
- 1, /* lconst_1 */ \
- 1, /* fconst_0 */ \
- 1, /* fconst_1 */ \
- 1, /* fconst_2 */ \
- 1, /* dconst_0 */ \
- 1, /* dconst_1 */ \
- 2, /* bipush */ \
- 3, /* sipush */ \
- 2, /* ldc */ \
- 3, /* ldc_w */ \
- 3, /* ldc2_w */ \
- 2, /* iload */ \
- 2, /* lload */ \
- 2, /* fload */ \
- 2, /* dload */ \
- 2, /* aload */ \
- 1, /* iload_0 */ \
- 1, /* iload_1 */ \
- 1, /* iload_2 */ \
- 1, /* iload_3 */ \
- 1, /* lload_0 */ \
- 1, /* lload_1 */ \
- 1, /* lload_2 */ \
- 1, /* lload_3 */ \
- 1, /* fload_0 */ \
- 1, /* fload_1 */ \
- 1, /* fload_2 */ \
- 1, /* fload_3 */ \
- 1, /* dload_0 */ \
- 1, /* dload_1 */ \
- 1, /* dload_2 */ \
- 1, /* dload_3 */ \
- 1, /* aload_0 */ \
- 1, /* aload_1 */ \
- 1, /* aload_2 */ \
- 1, /* aload_3 */ \
- 1, /* iaload */ \
- 1, /* laload */ \
- 1, /* faload */ \
- 1, /* daload */ \
- 1, /* aaload */ \
- 1, /* baload */ \
- 1, /* caload */ \
- 1, /* saload */ \
- 2, /* istore */ \
- 2, /* lstore */ \
- 2, /* fstore */ \
- 2, /* dstore */ \
- 2, /* astore */ \
- 1, /* istore_0 */ \
- 1, /* istore_1 */ \
- 1, /* istore_2 */ \
- 1, /* istore_3 */ \
- 1, /* lstore_0 */ \
- 1, /* lstore_1 */ \
- 1, /* lstore_2 */ \
- 1, /* lstore_3 */ \
- 1, /* fstore_0 */ \
- 1, /* fstore_1 */ \
- 1, /* fstore_2 */ \
- 1, /* fstore_3 */ \
- 1, /* dstore_0 */ \
- 1, /* dstore_1 */ \
- 1, /* dstore_2 */ \
- 1, /* dstore_3 */ \
- 1, /* astore_0 */ \
- 1, /* astore_1 */ \
- 1, /* astore_2 */ \
- 1, /* astore_3 */ \
- 1, /* iastore */ \
- 1, /* lastore */ \
- 1, /* fastore */ \
- 1, /* dastore */ \
- 1, /* aastore */ \
- 1, /* bastore */ \
- 1, /* castore */ \
- 1, /* sastore */ \
- 1, /* pop */ \
- 1, /* pop2 */ \
- 1, /* dup */ \
- 1, /* dup_x1 */ \
- 1, /* dup_x2 */ \
- 1, /* dup2 */ \
- 1, /* dup2_x1 */ \
- 1, /* dup2_x2 */ \
- 1, /* swap */ \
- 1, /* iadd */ \
- 1, /* ladd */ \
- 1, /* fadd */ \
- 1, /* dadd */ \
- 1, /* isub */ \
- 1, /* lsub */ \
- 1, /* fsub */ \
- 1, /* dsub */ \
- 1, /* imul */ \
- 1, /* lmul */ \
- 1, /* fmul */ \
- 1, /* dmul */ \
- 1, /* idiv */ \
- 1, /* ldiv */ \
- 1, /* fdiv */ \
- 1, /* ddiv */ \
- 1, /* irem */ \
- 1, /* lrem */ \
- 1, /* frem */ \
- 1, /* drem */ \
- 1, /* ineg */ \
- 1, /* lneg */ \
- 1, /* fneg */ \
- 1, /* dneg */ \
- 1, /* ishl */ \
- 1, /* lshl */ \
- 1, /* ishr */ \
- 1, /* lshr */ \
- 1, /* iushr */ \
- 1, /* lushr */ \
- 1, /* iand */ \
- 1, /* land */ \
- 1, /* ior */ \
- 1, /* lor */ \
- 1, /* ixor */ \
- 1, /* lxor */ \
- 3, /* iinc */ \
- 1, /* i2l */ \
- 1, /* i2f */ \
- 1, /* i2d */ \
- 1, /* l2i */ \
- 1, /* l2f */ \
- 1, /* l2d */ \
- 1, /* f2i */ \
- 1, /* f2l */ \
- 1, /* f2d */ \
- 1, /* d2i */ \
- 1, /* d2l */ \
- 1, /* d2f */ \
- 1, /* i2b */ \
- 1, /* i2c */ \
- 1, /* i2s */ \
- 1, /* lcmp */ \
- 1, /* fcmpl */ \
- 1, /* fcmpg */ \
- 1, /* dcmpl */ \
- 1, /* dcmpg */ \
- 3, /* ifeq */ \
- 3, /* ifne */ \
- 3, /* iflt */ \
- 3, /* ifge */ \
- 3, /* ifgt */ \
- 3, /* ifle */ \
- 3, /* if_icmpeq */ \
- 3, /* if_icmpne */ \
- 3, /* if_icmplt */ \
- 3, /* if_icmpge */ \
- 3, /* if_icmpgt */ \
- 3, /* if_icmple */ \
- 3, /* if_acmpeq */ \
- 3, /* if_acmpne */ \
- 3, /* goto */ \
- 3, /* jsr */ \
- 2, /* ret */ \
- 99, /* tableswitch */ \
- 99, /* lookupswitch */ \
- 1, /* ireturn */ \
- 1, /* lreturn */ \
- 1, /* freturn */ \
- 1, /* dreturn */ \
- 1, /* areturn */ \
- 1, /* return */ \
- 3, /* getstatic */ \
- 3, /* putstatic */ \
- 3, /* getfield */ \
- 3, /* putfield */ \
- 3, /* invokevirtual */ \
- 3, /* invokespecial */ \
- 3, /* invokestatic */ \
- 5, /* invokeinterface */ \
- 5, /* invokedynamic */ \
- 3, /* new */ \
- 2, /* newarray */ \
- 3, /* anewarray */ \
- 1, /* arraylength */ \
- 1, /* athrow */ \
- 3, /* checkcast */ \
- 3, /* instanceof */ \
- 1, /* monitorenter */ \
- 1, /* monitorexit */ \
- 0, /* wide */ \
- 4, /* multianewarray */ \
- 3, /* ifnull */ \
- 3, /* ifnonnull */ \
- 5, /* goto_w */ \
- 5 /* jsr_w */ \
-}
-
-#ifdef __cplusplus
-} /* extern "C" */
-#endif /* __cplusplus */
-
-#endif /* CLASSFILE_CONSTANTS */
diff --git a/demos/java/jni/gs_jni/include/jawt.h b/demos/java/jni/gs_jni/include/jawt.h
deleted file mode 100644
index f06e8071..00000000
--- a/demos/java/jni/gs_jni/include/jawt.h
+++ /dev/null
@@ -1,299 +0,0 @@
-/*
- * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved.
- * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- */
-
-#ifndef _JAVASOFT_JAWT_H_
-#define _JAVASOFT_JAWT_H_
-
-#include "jni.h"
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/*
- * AWT native interface (new in JDK 1.3)
- *
- * The AWT native interface allows a native C or C++ application a means
- * by which to access native structures in AWT. This is to facilitate moving
- * legacy C and C++ applications to Java and to target the needs of the
- * community who, at present, wish to do their own native rendering to canvases
- * for performance reasons. Standard extensions such as Java3D also require a
- * means to access the underlying native data structures of AWT.
- *
- * There may be future extensions to this API depending on demand.
- *
- * A VM does not have to implement this API in order to pass the JCK.
- * It is recommended, however, that this API is implemented on VMs that support
- * standard extensions, such as Java3D.
- *
- * Since this is a native API, any program which uses it cannot be considered
- * 100% pure java.
- */
-
-/*
- * AWT Native Drawing Surface (JAWT_DrawingSurface).
- *
- * For each platform, there is a native drawing surface structure. This
- * platform-specific structure can be found in jawt_md.h. It is recommended
- * that additional platforms follow the same model. It is also recommended
- * that VMs on Win32 and Solaris support the existing structures in jawt_md.h.
- *
- *******************
- * EXAMPLE OF USAGE:
- *******************
- *
- * In Win32, a programmer wishes to access the HWND of a canvas to perform
- * native rendering into it. The programmer has declared the paint() method
- * for their canvas subclass to be native:
- *
- *
- * MyCanvas.java:
- *
- * import java.awt.*;
- *
- * public class MyCanvas extends Canvas {
- *
- * static {
- * System.loadLibrary("mylib");
- * }
- *
- * public native void paint(Graphics g);
- * }
- *
- *
- * myfile.c:
- *
- * #include "jawt_md.h"
- * #include <assert.h>
- *
- * JNIEXPORT void JNICALL
- * Java_MyCanvas_paint(JNIEnv* env, jobject canvas, jobject graphics)
- * {
- * JAWT awt;
- * JAWT_DrawingSurface* ds;
- * JAWT_DrawingSurfaceInfo* dsi;
- * JAWT_Win32DrawingSurfaceInfo* dsi_win;
- * jboolean result;
- * jint lock;
- *
- * // Get the AWT
- * awt.version = JAWT_VERSION_1_3;
- * result = JAWT_GetAWT(env, &awt);
- * assert(result != JNI_FALSE);
- *
- * // Get the drawing surface
- * ds = awt.GetDrawingSurface(env, canvas);
- * assert(ds != NULL);
- *
- * // Lock the drawing surface
- * lock = ds->Lock(ds);
- * assert((lock & JAWT_LOCK_ERROR) == 0);
- *
- * // Get the drawing surface info
- * dsi = ds->GetDrawingSurfaceInfo(ds);
- *
- * // Get the platform-specific drawing info
- * dsi_win = (JAWT_Win32DrawingSurfaceInfo*)dsi->platformInfo;
- *
- * //////////////////////////////
- * // !!! DO PAINTING HERE !!! //
- * //////////////////////////////
- *
- * // Free the drawing surface info
- * ds->FreeDrawingSurfaceInfo(dsi);
- *
- * // Unlock the drawing surface
- * ds->Unlock(ds);
- *
- * // Free the drawing surface
- * awt.FreeDrawingSurface(ds);
- * }
- *
- */
-
-/*
- * JAWT_Rectangle
- * Structure for a native rectangle.
- */
-typedef struct jawt_Rectangle {
- jint x;
- jint y;
- jint width;
- jint height;
-} JAWT_Rectangle;
-
-struct jawt_DrawingSurface;
-
-/*
- * JAWT_DrawingSurfaceInfo
- * Structure for containing the underlying drawing information of a component.
- */
-typedef struct jawt_DrawingSurfaceInfo {
- /*
- * Pointer to the platform-specific information. This can be safely
- * cast to a JAWT_Win32DrawingSurfaceInfo on Windows or a
- * JAWT_X11DrawingSurfaceInfo on Solaris. On Mac OS X this is a
- * pointer to a NSObject that conforms to the JAWT_SurfaceLayers
- * protocol. See jawt_md.h for details.
- */
- void* platformInfo;
- /* Cached pointer to the underlying drawing surface */
- struct jawt_DrawingSurface* ds;
- /* Bounding rectangle of the drawing surface */
- JAWT_Rectangle bounds;
- /* Number of rectangles in the clip */
- jint clipSize;
- /* Clip rectangle array */
- JAWT_Rectangle* clip;
-} JAWT_DrawingSurfaceInfo;
-
-#define JAWT_LOCK_ERROR 0x00000001
-#define JAWT_LOCK_CLIP_CHANGED 0x00000002
-#define JAWT_LOCK_BOUNDS_CHANGED 0x00000004
-#define JAWT_LOCK_SURFACE_CHANGED 0x00000008
-
-/*
- * JAWT_DrawingSurface
- * Structure for containing the underlying drawing information of a component.
- * All operations on a JAWT_DrawingSurface MUST be performed from the same
- * thread as the call to GetDrawingSurface.
- */
-typedef struct jawt_DrawingSurface {
- /*
- * Cached reference to the Java environment of the calling thread.
- * If Lock(), Unlock(), GetDrawingSurfaceInfo() or
- * FreeDrawingSurfaceInfo() are called from a different thread,
- * this data member should be set before calling those functions.
- */
- JNIEnv* env;
- /* Cached reference to the target object */
- jobject target;
- /*
- * Lock the surface of the target component for native rendering.
- * When finished drawing, the surface must be unlocked with
- * Unlock(). This function returns a bitmask with one or more of the
- * following values:
- *
- * JAWT_LOCK_ERROR - When an error has occurred and the surface could not
- * be locked.
- *
- * JAWT_LOCK_CLIP_CHANGED - When the clip region has changed.
- *
- * JAWT_LOCK_BOUNDS_CHANGED - When the bounds of the surface have changed.
- *
- * JAWT_LOCK_SURFACE_CHANGED - When the surface itself has changed
- */
- jint (JNICALL *Lock)
- (struct jawt_DrawingSurface* ds);
- /*
- * Get the drawing surface info.
- * The value returned may be cached, but the values may change if
- * additional calls to Lock() or Unlock() are made.
- * Lock() must be called before this can return a valid value.
- * Returns NULL if an error has occurred.
- * When finished with the returned value, FreeDrawingSurfaceInfo must be
- * called.
- */
- JAWT_DrawingSurfaceInfo* (JNICALL *GetDrawingSurfaceInfo)
- (struct jawt_DrawingSurface* ds);
- /*
- * Free the drawing surface info.
- */
- void (JNICALL *FreeDrawingSurfaceInfo)
- (JAWT_DrawingSurfaceInfo* dsi);
- /*
- * Unlock the drawing surface of the target component for native rendering.
- */
- void (JNICALL *Unlock)
- (struct jawt_DrawingSurface* ds);
-} JAWT_DrawingSurface;
-
-/*
- * JAWT
- * Structure for containing native AWT functions.
- */
-typedef struct jawt {
- /*
- * Version of this structure. This must always be set before
- * calling JAWT_GetAWT()
- */
- jint version;
- /*
- * Return a drawing surface from a target jobject. This value
- * may be cached.
- * Returns NULL if an error has occurred.
- * Target must be a java.awt.Component (should be a Canvas
- * or Window for native rendering).
- * FreeDrawingSurface() must be called when finished with the
- * returned JAWT_DrawingSurface.
- */
- JAWT_DrawingSurface* (JNICALL *GetDrawingSurface)
- (JNIEnv* env, jobject target);
- /*
- * Free the drawing surface allocated in GetDrawingSurface.
- */
- void (JNICALL *FreeDrawingSurface)
- (JAWT_DrawingSurface* ds);
- /*
- * Since 1.4
- * Locks the entire AWT for synchronization purposes
- */
- void (JNICALL *Lock)(JNIEnv* env);
- /*
- * Since 1.4
- * Unlocks the entire AWT for synchronization purposes
- */
- void (JNICALL *Unlock)(JNIEnv* env);
- /*
- * Since 1.4
- * Returns a reference to a java.awt.Component from a native
- * platform handle. On Windows, this corresponds to an HWND;
- * on Solaris and Linux, this is a Drawable. For other platforms,
- * see the appropriate machine-dependent header file for a description.
- * The reference returned by this function is a local
- * reference that is only valid in this environment.
- * This function returns a NULL reference if no component could be
- * found with matching platform information.
- */
- jobject (JNICALL *GetComponent)(JNIEnv* env, void* platformInfo);
-
-} JAWT;
-
-/*
- * Get the AWT native structure. This function returns JNI_FALSE if
- * an error occurs.
- */
-_JNI_IMPORT_OR_EXPORT_
-jboolean JNICALL JAWT_GetAWT(JNIEnv* env, JAWT* awt);
-
-#define JAWT_VERSION_1_3 0x00010003
-#define JAWT_VERSION_1_4 0x00010004
-#define JAWT_VERSION_1_7 0x00010007
-
-#ifdef __cplusplus
-} /* extern "C" */
-#endif
-
-#endif /* !_JAVASOFT_JAWT_H_ */
diff --git a/demos/java/jni/gs_jni/include/jdwpTransport.h b/demos/java/jni/gs_jni/include/jdwpTransport.h
deleted file mode 100644
index 4f4b92ed..00000000
--- a/demos/java/jni/gs_jni/include/jdwpTransport.h
+++ /dev/null
@@ -1,259 +0,0 @@
-/*
- * Copyright (c) 2003, 2016, Oracle and/or its affiliates. All rights reserved.
- * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- */
-
-/*
- * Java Debug Wire Protocol Transport Service Provider Interface.
- */
-
-#ifndef JDWPTRANSPORT_H
-#define JDWPTRANSPORT_H
-
-#include "jni.h"
-
-enum {
- JDWPTRANSPORT_VERSION_1_0 = 0x00010000
-};
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-struct jdwpTransportNativeInterface_;
-
-struct _jdwpTransportEnv;
-
-#ifdef __cplusplus
-typedef _jdwpTransportEnv jdwpTransportEnv;
-#else
-typedef const struct jdwpTransportNativeInterface_ *jdwpTransportEnv;
-#endif /* __cplusplus */
-
-/*
- * Errors. Universal errors with JVMTI/JVMDI equivalents keep the
- * values the same.
- */
-typedef enum {
- JDWPTRANSPORT_ERROR_NONE = 0,
- JDWPTRANSPORT_ERROR_ILLEGAL_ARGUMENT = 103,
- JDWPTRANSPORT_ERROR_OUT_OF_MEMORY = 110,
- JDWPTRANSPORT_ERROR_INTERNAL = 113,
- JDWPTRANSPORT_ERROR_ILLEGAL_STATE = 201,
- JDWPTRANSPORT_ERROR_IO_ERROR = 202,
- JDWPTRANSPORT_ERROR_TIMEOUT = 203,
- JDWPTRANSPORT_ERROR_MSG_NOT_AVAILABLE = 204
-} jdwpTransportError;
-
-
-/*
- * Structure to define capabilities
- */
-typedef struct {
- unsigned int can_timeout_attach :1;
- unsigned int can_timeout_accept :1;
- unsigned int can_timeout_handshake :1;
- unsigned int reserved3 :1;
- unsigned int reserved4 :1;
- unsigned int reserved5 :1;
- unsigned int reserved6 :1;
- unsigned int reserved7 :1;
- unsigned int reserved8 :1;
- unsigned int reserved9 :1;
- unsigned int reserved10 :1;
- unsigned int reserved11 :1;
- unsigned int reserved12 :1;
- unsigned int reserved13 :1;
- unsigned int reserved14 :1;
- unsigned int reserved15 :1;
-} JDWPTransportCapabilities;
-
-
-/*
- * Structures to define packet layout.
- *
- * See: http://java.sun.com/j2se/1.5/docs/guide/jpda/jdwp-spec.html
- */
-
-enum {
- /*
- * If additional flags are added that apply to jdwpCmdPacket,
- * then debugLoop.c: reader() will need to be updated to
- * accept more than JDWPTRANSPORT_FLAGS_NONE.
- */
- JDWPTRANSPORT_FLAGS_NONE = 0x0,
- JDWPTRANSPORT_FLAGS_REPLY = 0x80
-};
-
-typedef struct {
- jint len;
- jint id;
- jbyte flags;
- jbyte cmdSet;
- jbyte cmd;
- jbyte *data;
-} jdwpCmdPacket;
-
-typedef struct {
- jint len;
- jint id;
- jbyte flags;
- jshort errorCode;
- jbyte *data;
-} jdwpReplyPacket;
-
-typedef struct {
- union {
- jdwpCmdPacket cmd;
- jdwpReplyPacket reply;
- } type;
-} jdwpPacket;
-
-/*
- * JDWP functions called by the transport.
- */
-typedef struct jdwpTransportCallback {
- void *(*alloc)(jint numBytes); /* Call this for all allocations */
- void (*free)(void *buffer); /* Call this for all deallocations */
-} jdwpTransportCallback;
-
-typedef jint (JNICALL *jdwpTransport_OnLoad_t)(JavaVM *jvm,
- jdwpTransportCallback *callback,
- jint version,
- jdwpTransportEnv** env);
-
-
-
-/* Function Interface */
-
-struct jdwpTransportNativeInterface_ {
- /* 1 : RESERVED */
- void *reserved1;
-
- /* 2 : Get Capabilities */
- jdwpTransportError (JNICALL *GetCapabilities)(jdwpTransportEnv* env,
- JDWPTransportCapabilities *capabilities_ptr);
-
- /* 3 : Attach */
- jdwpTransportError (JNICALL *Attach)(jdwpTransportEnv* env,
- const char* address,
- jlong attach_timeout,
- jlong handshake_timeout);
-
- /* 4: StartListening */
- jdwpTransportError (JNICALL *StartListening)(jdwpTransportEnv* env,
- const char* address,
- char** actual_address);
-
- /* 5: StopListening */
- jdwpTransportError (JNICALL *StopListening)(jdwpTransportEnv* env);
-
- /* 6: Accept */
- jdwpTransportError (JNICALL *Accept)(jdwpTransportEnv* env,
- jlong accept_timeout,
- jlong handshake_timeout);
-
- /* 7: IsOpen */
- jboolean (JNICALL *IsOpen)(jdwpTransportEnv* env);
-
- /* 8: Close */
- jdwpTransportError (JNICALL *Close)(jdwpTransportEnv* env);
-
- /* 9: ReadPacket */
- jdwpTransportError (JNICALL *ReadPacket)(jdwpTransportEnv* env,
- jdwpPacket *pkt);
-
- /* 10: Write Packet */
- jdwpTransportError (JNICALL *WritePacket)(jdwpTransportEnv* env,
- const jdwpPacket* pkt);
-
- /* 11: GetLastError */
- jdwpTransportError (JNICALL *GetLastError)(jdwpTransportEnv* env,
- char** error);
-
-};
-
-
-/*
- * Use inlined functions so that C++ code can use syntax such as
- * env->Attach("mymachine:5000", 10*1000, 0);
- *
- * rather than using C's :-
- *
- * (*env)->Attach(env, "mymachine:5000", 10*1000, 0);
- */
-struct _jdwpTransportEnv {
- const struct jdwpTransportNativeInterface_ *functions;
-#ifdef __cplusplus
-
- jdwpTransportError GetCapabilities(JDWPTransportCapabilities *capabilities_ptr) {
- return functions->GetCapabilities(this, capabilities_ptr);
- }
-
- jdwpTransportError Attach(const char* address, jlong attach_timeout,
- jlong handshake_timeout) {
- return functions->Attach(this, address, attach_timeout, handshake_timeout);
- }
-
- jdwpTransportError StartListening(const char* address,
- char** actual_address) {
- return functions->StartListening(this, address, actual_address);
- }
-
- jdwpTransportError StopListening(void) {
- return functions->StopListening(this);
- }
-
- jdwpTransportError Accept(jlong accept_timeout, jlong handshake_timeout) {
- return functions->Accept(this, accept_timeout, handshake_timeout);
- }
-
- jboolean IsOpen(void) {
- return functions->IsOpen(this);
- }
-
- jdwpTransportError Close(void) {
- return functions->Close(this);
- }
-
- jdwpTransportError ReadPacket(jdwpPacket *pkt) {
- return functions->ReadPacket(this, pkt);
- }
-
- jdwpTransportError WritePacket(const jdwpPacket* pkt) {
- return functions->WritePacket(this, pkt);
- }
-
- jdwpTransportError GetLastError(char** error) {
- return functions->GetLastError(this, error);
- }
-
-
-#endif /* __cplusplus */
-};
-
-#ifdef __cplusplus
-} /* extern "C" */
-#endif /* __cplusplus */
-
-#endif /* JDWPTRANSPORT_H */
diff --git a/demos/java/jni/gs_jni/include/jni.h b/demos/java/jni/gs_jni/include/jni.h
deleted file mode 100644
index 97b14d8a..00000000
--- a/demos/java/jni/gs_jni/include/jni.h
+++ /dev/null
@@ -1,1964 +0,0 @@
-/*
- * Copyright (c) 1996, 2013, Oracle and/or its affiliates. All rights reserved.
- * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- */
-
-/*
- * We used part of Netscape's Java Runtime Interface (JRI) as the starting
- * point of our design and implementation.
- */
-
-/******************************************************************************
- * Java Runtime Interface
- * Copyright (c) 1996 Netscape Communications Corporation. All rights reserved.
- *****************************************************************************/
-
-#ifndef _JAVASOFT_JNI_H_
-#define _JAVASOFT_JNI_H_
-
-#include <stdio.h>
-#include <stdarg.h>
-
-/* jni_md.h contains the machine-dependent typedefs for jbyte, jint
- and jlong */
-
-#ifdef _WIN32
-#include "win32/jni_md.h"
-#else
-#include "jni_md.h"
-#endif
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/*
- * JNI Types
- */
-
-#ifndef JNI_TYPES_ALREADY_DEFINED_IN_JNI_MD_H
-
-typedef unsigned char jboolean;
-typedef unsigned short jchar;
-typedef short jshort;
-typedef float jfloat;
-typedef double jdouble;
-
-typedef jint jsize;
-
-#ifdef __cplusplus
-
-class _jobject {};
-class _jclass : public _jobject {};
-class _jthrowable : public _jobject {};
-class _jstring : public _jobject {};
-class _jarray : public _jobject {};
-class _jbooleanArray : public _jarray {};
-class _jbyteArray : public _jarray {};
-class _jcharArray : public _jarray {};
-class _jshortArray : public _jarray {};
-class _jintArray : public _jarray {};
-class _jlongArray : public _jarray {};
-class _jfloatArray : public _jarray {};
-class _jdoubleArray : public _jarray {};
-class _jobjectArray : public _jarray {};
-
-typedef _jobject *jobject;
-typedef _jclass *jclass;
-typedef _jthrowable *jthrowable;
-typedef _jstring *jstring;
-typedef _jarray *jarray;
-typedef _jbooleanArray *jbooleanArray;
-typedef _jbyteArray *jbyteArray;
-typedef _jcharArray *jcharArray;
-typedef _jshortArray *jshortArray;
-typedef _jintArray *jintArray;
-typedef _jlongArray *jlongArray;
-typedef _jfloatArray *jfloatArray;
-typedef _jdoubleArray *jdoubleArray;
-typedef _jobjectArray *jobjectArray;
-
-#else
-
-struct _jobject;
-
-typedef struct _jobject *jobject;
-typedef jobject jclass;
-typedef jobject jthrowable;
-typedef jobject jstring;
-typedef jobject jarray;
-typedef jarray jbooleanArray;
-typedef jarray jbyteArray;
-typedef jarray jcharArray;
-typedef jarray jshortArray;
-typedef jarray jintArray;
-typedef jarray jlongArray;
-typedef jarray jfloatArray;
-typedef jarray jdoubleArray;
-typedef jarray jobjectArray;
-
-#endif
-
-typedef jobject jweak;
-
-typedef union jvalue {
- jboolean z;
- jbyte b;
- jchar c;
- jshort s;
- jint i;
- jlong j;
- jfloat f;
- jdouble d;
- jobject l;
-} jvalue;
-
-struct _jfieldID;
-typedef struct _jfieldID *jfieldID;
-
-struct _jmethodID;
-typedef struct _jmethodID *jmethodID;
-
-/* Return values from jobjectRefType */
-typedef enum _jobjectType {
- JNIInvalidRefType = 0,
- JNILocalRefType = 1,
- JNIGlobalRefType = 2,
- JNIWeakGlobalRefType = 3
-} jobjectRefType;
-
-
-#endif /* JNI_TYPES_ALREADY_DEFINED_IN_JNI_MD_H */
-
-/*
- * jboolean constants
- */
-
-#define JNI_FALSE 0
-#define JNI_TRUE 1
-
-/*
- * possible return values for JNI functions.
- */
-
-#define JNI_OK 0 /* success */
-#define JNI_ERR (-1) /* unknown error */
-#define JNI_EDETACHED (-2) /* thread detached from the VM */
-#define JNI_EVERSION (-3) /* JNI version error */
-#define JNI_ENOMEM (-4) /* not enough memory */
-#define JNI_EEXIST (-5) /* VM already created */
-#define JNI_EINVAL (-6) /* invalid arguments */
-
-/*
- * used in ReleaseScalarArrayElements
- */
-
-#define JNI_COMMIT 1
-#define JNI_ABORT 2
-
-/*
- * used in RegisterNatives to describe native method name, signature,
- * and function pointer.
- */
-
-typedef struct {
- char *name;
- char *signature;
- void *fnPtr;
-} JNINativeMethod;
-
-/*
- * JNI Native Method Interface.
- */
-
-struct JNINativeInterface_;
-
-struct JNIEnv_;
-
-#ifdef __cplusplus
-typedef JNIEnv_ JNIEnv;
-#else
-typedef const struct JNINativeInterface_ *JNIEnv;
-#endif
-
-/*
- * JNI Invocation Interface.
- */
-
-struct JNIInvokeInterface_;
-
-struct JavaVM_;
-
-#ifdef __cplusplus
-typedef JavaVM_ JavaVM;
-#else
-typedef const struct JNIInvokeInterface_ *JavaVM;
-#endif
-
-struct JNINativeInterface_ {
- void *reserved0;
- void *reserved1;
- void *reserved2;
-
- void *reserved3;
- jint (JNICALL *GetVersion)(JNIEnv *env);
-
- jclass (JNICALL *DefineClass)
- (JNIEnv *env, const char *name, jobject loader, const jbyte *buf,
- jsize len);
- jclass (JNICALL *FindClass)
- (JNIEnv *env, const char *name);
-
- jmethodID (JNICALL *FromReflectedMethod)
- (JNIEnv *env, jobject method);
- jfieldID (JNICALL *FromReflectedField)
- (JNIEnv *env, jobject field);
-
- jobject (JNICALL *ToReflectedMethod)
- (JNIEnv *env, jclass cls, jmethodID methodID, jboolean isStatic);
-
- jclass (JNICALL *GetSuperclass)
- (JNIEnv *env, jclass sub);
- jboolean (JNICALL *IsAssignableFrom)
- (JNIEnv *env, jclass sub, jclass sup);
-
- jobject (JNICALL *ToReflectedField)
- (JNIEnv *env, jclass cls, jfieldID fieldID, jboolean isStatic);
-
- jint (JNICALL *Throw)
- (JNIEnv *env, jthrowable obj);
- jint (JNICALL *ThrowNew)
- (JNIEnv *env, jclass clazz, const char *msg);
- jthrowable (JNICALL *ExceptionOccurred)
- (JNIEnv *env);
- void (JNICALL *ExceptionDescribe)
- (JNIEnv *env);
- void (JNICALL *ExceptionClear)
- (JNIEnv *env);
- void (JNICALL *FatalError)
- (JNIEnv *env, const char *msg);
-
- jint (JNICALL *PushLocalFrame)
- (JNIEnv *env, jint capacity);
- jobject (JNICALL *PopLocalFrame)
- (JNIEnv *env, jobject result);
-
- jobject (JNICALL *NewGlobalRef)
- (JNIEnv *env, jobject lobj);
- void (JNICALL *DeleteGlobalRef)
- (JNIEnv *env, jobject gref);
- void (JNICALL *DeleteLocalRef)
- (JNIEnv *env, jobject obj);
- jboolean (JNICALL *IsSameObject)
- (JNIEnv *env, jobject obj1, jobject obj2);
- jobject (JNICALL *NewLocalRef)
- (JNIEnv *env, jobject ref);
- jint (JNICALL *EnsureLocalCapacity)
- (JNIEnv *env, jint capacity);
-
- jobject (JNICALL *AllocObject)
- (JNIEnv *env, jclass clazz);
- jobject (JNICALL *NewObject)
- (JNIEnv *env, jclass clazz, jmethodID methodID, ...);
- jobject (JNICALL *NewObjectV)
- (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args);
- jobject (JNICALL *NewObjectA)
- (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args);
-
- jclass (JNICALL *GetObjectClass)
- (JNIEnv *env, jobject obj);
- jboolean (JNICALL *IsInstanceOf)
- (JNIEnv *env, jobject obj, jclass clazz);
-
- jmethodID (JNICALL *GetMethodID)
- (JNIEnv *env, jclass clazz, const char *name, const char *sig);
-
- jobject (JNICALL *CallObjectMethod)
- (JNIEnv *env, jobject obj, jmethodID methodID, ...);
- jobject (JNICALL *CallObjectMethodV)
- (JNIEnv *env, jobject obj, jmethodID methodID, va_list args);
- jobject (JNICALL *CallObjectMethodA)
- (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue * args);
-
- jboolean (JNICALL *CallBooleanMethod)
- (JNIEnv *env, jobject obj, jmethodID methodID, ...);
- jboolean (JNICALL *CallBooleanMethodV)
- (JNIEnv *env, jobject obj, jmethodID methodID, va_list args);
- jboolean (JNICALL *CallBooleanMethodA)
- (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue * args);
-
- jbyte (JNICALL *CallByteMethod)
- (JNIEnv *env, jobject obj, jmethodID methodID, ...);
- jbyte (JNICALL *CallByteMethodV)
- (JNIEnv *env, jobject obj, jmethodID methodID, va_list args);
- jbyte (JNICALL *CallByteMethodA)
- (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue *args);
-
- jchar (JNICALL *CallCharMethod)
- (JNIEnv *env, jobject obj, jmethodID methodID, ...);
- jchar (JNICALL *CallCharMethodV)
- (JNIEnv *env, jobject obj, jmethodID methodID, va_list args);
- jchar (JNICALL *CallCharMethodA)
- (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue *args);
-
- jshort (JNICALL *CallShortMethod)
- (JNIEnv *env, jobject obj, jmethodID methodID, ...);
- jshort (JNICALL *CallShortMethodV)
- (JNIEnv *env, jobject obj, jmethodID methodID, va_list args);
- jshort (JNICALL *CallShortMethodA)
- (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue *args);
-
- jint (JNICALL *CallIntMethod)
- (JNIEnv *env, jobject obj, jmethodID methodID, ...);
- jint (JNICALL *CallIntMethodV)
- (JNIEnv *env, jobject obj, jmethodID methodID, va_list args);
- jint (JNICALL *CallIntMethodA)
- (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue *args);
-
- jlong (JNICALL *CallLongMethod)
- (JNIEnv *env, jobject obj, jmethodID methodID, ...);
- jlong (JNICALL *CallLongMethodV)
- (JNIEnv *env, jobject obj, jmethodID methodID, va_list args);
- jlong (JNICALL *CallLongMethodA)
- (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue *args);
-
- jfloat (JNICALL *CallFloatMethod)
- (JNIEnv *env, jobject obj, jmethodID methodID, ...);
- jfloat (JNICALL *CallFloatMethodV)
- (JNIEnv *env, jobject obj, jmethodID methodID, va_list args);
- jfloat (JNICALL *CallFloatMethodA)
- (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue *args);
-
- jdouble (JNICALL *CallDoubleMethod)
- (JNIEnv *env, jobject obj, jmethodID methodID, ...);
- jdouble (JNICALL *CallDoubleMethodV)
- (JNIEnv *env, jobject obj, jmethodID methodID, va_list args);
- jdouble (JNICALL *CallDoubleMethodA)
- (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue *args);
-
- void (JNICALL *CallVoidMethod)
- (JNIEnv *env, jobject obj, jmethodID methodID, ...);
- void (JNICALL *CallVoidMethodV)
- (JNIEnv *env, jobject obj, jmethodID methodID, va_list args);
- void (JNICALL *CallVoidMethodA)
- (JNIEnv *env, jobject obj, jmethodID methodID, const jvalue * args);
-
- jobject (JNICALL *CallNonvirtualObjectMethod)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...);
- jobject (JNICALL *CallNonvirtualObjectMethodV)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- va_list args);
- jobject (JNICALL *CallNonvirtualObjectMethodA)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- const jvalue * args);
-
- jboolean (JNICALL *CallNonvirtualBooleanMethod)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...);
- jboolean (JNICALL *CallNonvirtualBooleanMethodV)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- va_list args);
- jboolean (JNICALL *CallNonvirtualBooleanMethodA)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- const jvalue * args);
-
- jbyte (JNICALL *CallNonvirtualByteMethod)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...);
- jbyte (JNICALL *CallNonvirtualByteMethodV)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- va_list args);
- jbyte (JNICALL *CallNonvirtualByteMethodA)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- const jvalue *args);
-
- jchar (JNICALL *CallNonvirtualCharMethod)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...);
- jchar (JNICALL *CallNonvirtualCharMethodV)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- va_list args);
- jchar (JNICALL *CallNonvirtualCharMethodA)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- const jvalue *args);
-
- jshort (JNICALL *CallNonvirtualShortMethod)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...);
- jshort (JNICALL *CallNonvirtualShortMethodV)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- va_list args);
- jshort (JNICALL *CallNonvirtualShortMethodA)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- const jvalue *args);
-
- jint (JNICALL *CallNonvirtualIntMethod)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...);
- jint (JNICALL *CallNonvirtualIntMethodV)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- va_list args);
- jint (JNICALL *CallNonvirtualIntMethodA)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- const jvalue *args);
-
- jlong (JNICALL *CallNonvirtualLongMethod)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...);
- jlong (JNICALL *CallNonvirtualLongMethodV)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- va_list args);
- jlong (JNICALL *CallNonvirtualLongMethodA)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- const jvalue *args);
-
- jfloat (JNICALL *CallNonvirtualFloatMethod)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...);
- jfloat (JNICALL *CallNonvirtualFloatMethodV)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- va_list args);
- jfloat (JNICALL *CallNonvirtualFloatMethodA)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- const jvalue *args);
-
- jdouble (JNICALL *CallNonvirtualDoubleMethod)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...);
- jdouble (JNICALL *CallNonvirtualDoubleMethodV)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- va_list args);
- jdouble (JNICALL *CallNonvirtualDoubleMethodA)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- const jvalue *args);
-
- void (JNICALL *CallNonvirtualVoidMethod)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID, ...);
- void (JNICALL *CallNonvirtualVoidMethodV)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- va_list args);
- void (JNICALL *CallNonvirtualVoidMethodA)
- (JNIEnv *env, jobject obj, jclass clazz, jmethodID methodID,
- const jvalue * args);
-
- jfieldID (JNICALL *GetFieldID)
- (JNIEnv *env, jclass clazz, const char *name, const char *sig);
-
- jobject (JNICALL *GetObjectField)
- (JNIEnv *env, jobject obj, jfieldID fieldID);
- jboolean (JNICALL *GetBooleanField)
- (JNIEnv *env, jobject obj, jfieldID fieldID);
- jbyte (JNICALL *GetByteField)
- (JNIEnv *env, jobject obj, jfieldID fieldID);
- jchar (JNICALL *GetCharField)
- (JNIEnv *env, jobject obj, jfieldID fieldID);
- jshort (JNICALL *GetShortField)
- (JNIEnv *env, jobject obj, jfieldID fieldID);
- jint (JNICALL *GetIntField)
- (JNIEnv *env, jobject obj, jfieldID fieldID);
- jlong (JNICALL *GetLongField)
- (JNIEnv *env, jobject obj, jfieldID fieldID);
- jfloat (JNICALL *GetFloatField)
- (JNIEnv *env, jobject obj, jfieldID fieldID);
- jdouble (JNICALL *GetDoubleField)
- (JNIEnv *env, jobject obj, jfieldID fieldID);
-
- void (JNICALL *SetObjectField)
- (JNIEnv *env, jobject obj, jfieldID fieldID, jobject val);
- void (JNICALL *SetBooleanField)
- (JNIEnv *env, jobject obj, jfieldID fieldID, jboolean val);
- void (JNICALL *SetByteField)
- (JNIEnv *env, jobject obj, jfieldID fieldID, jbyte val);
- void (JNICALL *SetCharField)
- (JNIEnv *env, jobject obj, jfieldID fieldID, jchar val);
- void (JNICALL *SetShortField)
- (JNIEnv *env, jobject obj, jfieldID fieldID, jshort val);
- void (JNICALL *SetIntField)
- (JNIEnv *env, jobject obj, jfieldID fieldID, jint val);
- void (JNICALL *SetLongField)
- (JNIEnv *env, jobject obj, jfieldID fieldID, jlong val);
- void (JNICALL *SetFloatField)
- (JNIEnv *env, jobject obj, jfieldID fieldID, jfloat val);
- void (JNICALL *SetDoubleField)
- (JNIEnv *env, jobject obj, jfieldID fieldID, jdouble val);
-
- jmethodID (JNICALL *GetStaticMethodID)
- (JNIEnv *env, jclass clazz, const char *name, const char *sig);
-
- jobject (JNICALL *CallStaticObjectMethod)
- (JNIEnv *env, jclass clazz, jmethodID methodID, ...);
- jobject (JNICALL *CallStaticObjectMethodV)
- (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args);
- jobject (JNICALL *CallStaticObjectMethodA)
- (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args);
-
- jboolean (JNICALL *CallStaticBooleanMethod)
- (JNIEnv *env, jclass clazz, jmethodID methodID, ...);
- jboolean (JNICALL *CallStaticBooleanMethodV)
- (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args);
- jboolean (JNICALL *CallStaticBooleanMethodA)
- (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args);
-
- jbyte (JNICALL *CallStaticByteMethod)
- (JNIEnv *env, jclass clazz, jmethodID methodID, ...);
- jbyte (JNICALL *CallStaticByteMethodV)
- (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args);
- jbyte (JNICALL *CallStaticByteMethodA)
- (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args);
-
- jchar (JNICALL *CallStaticCharMethod)
- (JNIEnv *env, jclass clazz, jmethodID methodID, ...);
- jchar (JNICALL *CallStaticCharMethodV)
- (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args);
- jchar (JNICALL *CallStaticCharMethodA)
- (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args);
-
- jshort (JNICALL *CallStaticShortMethod)
- (JNIEnv *env, jclass clazz, jmethodID methodID, ...);
- jshort (JNICALL *CallStaticShortMethodV)
- (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args);
- jshort (JNICALL *CallStaticShortMethodA)
- (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args);
-
- jint (JNICALL *CallStaticIntMethod)
- (JNIEnv *env, jclass clazz, jmethodID methodID, ...);
- jint (JNICALL *CallStaticIntMethodV)
- (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args);
- jint (JNICALL *CallStaticIntMethodA)
- (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args);
-
- jlong (JNICALL *CallStaticLongMethod)
- (JNIEnv *env, jclass clazz, jmethodID methodID, ...);
- jlong (JNICALL *CallStaticLongMethodV)
- (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args);
- jlong (JNICALL *CallStaticLongMethodA)
- (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args);
-
- jfloat (JNICALL *CallStaticFloatMethod)
- (JNIEnv *env, jclass clazz, jmethodID methodID, ...);
- jfloat (JNICALL *CallStaticFloatMethodV)
- (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args);
- jfloat (JNICALL *CallStaticFloatMethodA)
- (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args);
-
- jdouble (JNICALL *CallStaticDoubleMethod)
- (JNIEnv *env, jclass clazz, jmethodID methodID, ...);
- jdouble (JNICALL *CallStaticDoubleMethodV)
- (JNIEnv *env, jclass clazz, jmethodID methodID, va_list args);
- jdouble (JNICALL *CallStaticDoubleMethodA)
- (JNIEnv *env, jclass clazz, jmethodID methodID, const jvalue *args);
-
- void (JNICALL *CallStaticVoidMethod)
- (JNIEnv *env, jclass cls, jmethodID methodID, ...);
- void (JNICALL *CallStaticVoidMethodV)
- (JNIEnv *env, jclass cls, jmethodID methodID, va_list args);
- void (JNICALL *CallStaticVoidMethodA)
- (JNIEnv *env, jclass cls, jmethodID methodID, const jvalue * args);
-
- jfieldID (JNICALL *GetStaticFieldID)
- (JNIEnv *env, jclass clazz, const char *name, const char *sig);
- jobject (JNICALL *GetStaticObjectField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID);
- jboolean (JNICALL *GetStaticBooleanField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID);
- jbyte (JNICALL *GetStaticByteField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID);
- jchar (JNICALL *GetStaticCharField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID);
- jshort (JNICALL *GetStaticShortField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID);
- jint (JNICALL *GetStaticIntField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID);
- jlong (JNICALL *GetStaticLongField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID);
- jfloat (JNICALL *GetStaticFloatField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID);
- jdouble (JNICALL *GetStaticDoubleField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID);
-
- void (JNICALL *SetStaticObjectField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID, jobject value);
- void (JNICALL *SetStaticBooleanField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID, jboolean value);
- void (JNICALL *SetStaticByteField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID, jbyte value);
- void (JNICALL *SetStaticCharField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID, jchar value);
- void (JNICALL *SetStaticShortField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID, jshort value);
- void (JNICALL *SetStaticIntField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID, jint value);
- void (JNICALL *SetStaticLongField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID, jlong value);
- void (JNICALL *SetStaticFloatField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID, jfloat value);
- void (JNICALL *SetStaticDoubleField)
- (JNIEnv *env, jclass clazz, jfieldID fieldID, jdouble value);
-
- jstring (JNICALL *NewString)
- (JNIEnv *env, const jchar *unicode, jsize len);
- jsize (JNICALL *GetStringLength)
- (JNIEnv *env, jstring str);
- const jchar *(JNICALL *GetStringChars)
- (JNIEnv *env, jstring str, jboolean *isCopy);
- void (JNICALL *ReleaseStringChars)
- (JNIEnv *env, jstring str, const jchar *chars);
-
- jstring (JNICALL *NewStringUTF)
- (JNIEnv *env, const char *utf);
- jsize (JNICALL *GetStringUTFLength)
- (JNIEnv *env, jstring str);
- const char* (JNICALL *GetStringUTFChars)
- (JNIEnv *env, jstring str, jboolean *isCopy);
- void (JNICALL *ReleaseStringUTFChars)
- (JNIEnv *env, jstring str, const char* chars);
-
-
- jsize (JNICALL *GetArrayLength)
- (JNIEnv *env, jarray array);
-
- jobjectArray (JNICALL *NewObjectArray)
- (JNIEnv *env, jsize len, jclass clazz, jobject init);
- jobject (JNICALL *GetObjectArrayElement)
- (JNIEnv *env, jobjectArray array, jsize index);
- void (JNICALL *SetObjectArrayElement)
- (JNIEnv *env, jobjectArray array, jsize index, jobject val);
-
- jbooleanArray (JNICALL *NewBooleanArray)
- (JNIEnv *env, jsize len);
- jbyteArray (JNICALL *NewByteArray)
- (JNIEnv *env, jsize len);
- jcharArray (JNICALL *NewCharArray)
- (JNIEnv *env, jsize len);
- jshortArray (JNICALL *NewShortArray)
- (JNIEnv *env, jsize len);
- jintArray (JNICALL *NewIntArray)
- (JNIEnv *env, jsize len);
- jlongArray (JNICALL *NewLongArray)
- (JNIEnv *env, jsize len);
- jfloatArray (JNICALL *NewFloatArray)
- (JNIEnv *env, jsize len);
- jdoubleArray (JNICALL *NewDoubleArray)
- (JNIEnv *env, jsize len);
-
- jboolean * (JNICALL *GetBooleanArrayElements)
- (JNIEnv *env, jbooleanArray array, jboolean *isCopy);
- jbyte * (JNICALL *GetByteArrayElements)
- (JNIEnv *env, jbyteArray array, jboolean *isCopy);
- jchar * (JNICALL *GetCharArrayElements)
- (JNIEnv *env, jcharArray array, jboolean *isCopy);
- jshort * (JNICALL *GetShortArrayElements)
- (JNIEnv *env, jshortArray array, jboolean *isCopy);
- jint * (JNICALL *GetIntArrayElements)
- (JNIEnv *env, jintArray array, jboolean *isCopy);
- jlong * (JNICALL *GetLongArrayElements)
- (JNIEnv *env, jlongArray array, jboolean *isCopy);
- jfloat * (JNICALL *GetFloatArrayElements)
- (JNIEnv *env, jfloatArray array, jboolean *isCopy);
- jdouble * (JNICALL *GetDoubleArrayElements)
- (JNIEnv *env, jdoubleArray array, jboolean *isCopy);
-
- void (JNICALL *ReleaseBooleanArrayElements)
- (JNIEnv *env, jbooleanArray array, jboolean *elems, jint mode);
- void (JNICALL *ReleaseByteArrayElements)
- (JNIEnv *env, jbyteArray array, jbyte *elems, jint mode);
- void (JNICALL *ReleaseCharArrayElements)
- (JNIEnv *env, jcharArray array, jchar *elems, jint mode);
- void (JNICALL *ReleaseShortArrayElements)
- (JNIEnv *env, jshortArray array, jshort *elems, jint mode);
- void (JNICALL *ReleaseIntArrayElements)
- (JNIEnv *env, jintArray array, jint *elems, jint mode);
- void (JNICALL *ReleaseLongArrayElements)
- (JNIEnv *env, jlongArray array, jlong *elems, jint mode);
- void (JNICALL *ReleaseFloatArrayElements)
- (JNIEnv *env, jfloatArray array, jfloat *elems, jint mode);
- void (JNICALL *ReleaseDoubleArrayElements)
- (JNIEnv *env, jdoubleArray array, jdouble *elems, jint mode);
-
- void (JNICALL *GetBooleanArrayRegion)
- (JNIEnv *env, jbooleanArray array, jsize start, jsize l, jboolean *buf);
- void (JNICALL *GetByteArrayRegion)
- (JNIEnv *env, jbyteArray array, jsize start, jsize len, jbyte *buf);
- void (JNICALL *GetCharArrayRegion)
- (JNIEnv *env, jcharArray array, jsize start, jsize len, jchar *buf);
- void (JNICALL *GetShortArrayRegion)
- (JNIEnv *env, jshortArray array, jsize start, jsize len, jshort *buf);
- void (JNICALL *GetIntArrayRegion)
- (JNIEnv *env, jintArray array, jsize start, jsize len, jint *buf);
- void (JNICALL *GetLongArrayRegion)
- (JNIEnv *env, jlongArray array, jsize start, jsize len, jlong *buf);
- void (JNICALL *GetFloatArrayRegion)
- (JNIEnv *env, jfloatArray array, jsize start, jsize len, jfloat *buf);
- void (JNICALL *GetDoubleArrayRegion)
- (JNIEnv *env, jdoubleArray array, jsize start, jsize len, jdouble *buf);
-
- void (JNICALL *SetBooleanArrayRegion)
- (JNIEnv *env, jbooleanArray array, jsize start, jsize l, const jboolean *buf);
- void (JNICALL *SetByteArrayRegion)
- (JNIEnv *env, jbyteArray array, jsize start, jsize len, const jbyte *buf);
- void (JNICALL *SetCharArrayRegion)
- (JNIEnv *env, jcharArray array, jsize start, jsize len, const jchar *buf);
- void (JNICALL *SetShortArrayRegion)
- (JNIEnv *env, jshortArray array, jsize start, jsize len, const jshort *buf);
- void (JNICALL *SetIntArrayRegion)
- (JNIEnv *env, jintArray array, jsize start, jsize len, const jint *buf);
- void (JNICALL *SetLongArrayRegion)
- (JNIEnv *env, jlongArray array, jsize start, jsize len, const jlong *buf);
- void (JNICALL *SetFloatArrayRegion)
- (JNIEnv *env, jfloatArray array, jsize start, jsize len, const jfloat *buf);
- void (JNICALL *SetDoubleArrayRegion)
- (JNIEnv *env, jdoubleArray array, jsize start, jsize len, const jdouble *buf);
-
- jint (JNICALL *RegisterNatives)
- (JNIEnv *env, jclass clazz, const JNINativeMethod *methods,
- jint nMethods);
- jint (JNICALL *UnregisterNatives)
- (JNIEnv *env, jclass clazz);
-
- jint (JNICALL *MonitorEnter)
- (JNIEnv *env, jobject obj);
- jint (JNICALL *MonitorExit)
- (JNIEnv *env, jobject obj);
-
- jint (JNICALL *GetJavaVM)
- (JNIEnv *env, JavaVM **vm);
-
- void (JNICALL *GetStringRegion)
- (JNIEnv *env, jstring str, jsize start, jsize len, jchar *buf);
- void (JNICALL *GetStringUTFRegion)
- (JNIEnv *env, jstring str, jsize start, jsize len, char *buf);
-
- void * (JNICALL *GetPrimitiveArrayCritical)
- (JNIEnv *env, jarray array, jboolean *isCopy);
- void (JNICALL *ReleasePrimitiveArrayCritical)
- (JNIEnv *env, jarray array, void *carray, jint mode);
-
- const jchar * (JNICALL *GetStringCritical)
- (JNIEnv *env, jstring string, jboolean *isCopy);
- void (JNICALL *ReleaseStringCritical)
- (JNIEnv *env, jstring string, const jchar *cstring);
-
- jweak (JNICALL *NewWeakGlobalRef)
- (JNIEnv *env, jobject obj);
- void (JNICALL *DeleteWeakGlobalRef)
- (JNIEnv *env, jweak ref);
-
- jboolean (JNICALL *ExceptionCheck)
- (JNIEnv *env);
-
- jobject (JNICALL *NewDirectByteBuffer)
- (JNIEnv* env, void* address, jlong capacity);
- void* (JNICALL *GetDirectBufferAddress)
- (JNIEnv* env, jobject buf);
- jlong (JNICALL *GetDirectBufferCapacity)
- (JNIEnv* env, jobject buf);
-
- /* New JNI 1.6 Features */
-
- jobjectRefType (JNICALL *GetObjectRefType)
- (JNIEnv* env, jobject obj);
-};
-
-/*
- * We use inlined functions for C++ so that programmers can write:
- *
- * env->FindClass("java/lang/String")
- *
- * in C++ rather than:
- *
- * (*env)->FindClass(env, "java/lang/String")
- *
- * in C.
- */
-
-struct JNIEnv_ {
- const struct JNINativeInterface_ *functions;
-#ifdef __cplusplus
-
- jint GetVersion() {
- return functions->GetVersion(this);
- }
- jclass DefineClass(const char *name, jobject loader, const jbyte *buf,
- jsize len) {
- return functions->DefineClass(this, name, loader, buf, len);
- }
- jclass FindClass(const char *name) {
- return functions->FindClass(this, name);
- }
- jmethodID FromReflectedMethod(jobject method) {
- return functions->FromReflectedMethod(this,method);
- }
- jfieldID FromReflectedField(jobject field) {
- return functions->FromReflectedField(this,field);
- }
-
- jobject ToReflectedMethod(jclass cls, jmethodID methodID, jboolean isStatic) {
- return functions->ToReflectedMethod(this, cls, methodID, isStatic);
- }
-
- jclass GetSuperclass(jclass sub) {
- return functions->GetSuperclass(this, sub);
- }
- jboolean IsAssignableFrom(jclass sub, jclass sup) {
- return functions->IsAssignableFrom(this, sub, sup);
- }
-
- jobject ToReflectedField(jclass cls, jfieldID fieldID, jboolean isStatic) {
- return functions->ToReflectedField(this,cls,fieldID,isStatic);
- }
-
- jint Throw(jthrowable obj) {
- return functions->Throw(this, obj);
- }
- jint ThrowNew(jclass clazz, const char *msg) {
- return functions->ThrowNew(this, clazz, msg);
- }
- jthrowable ExceptionOccurred() {
- return functions->ExceptionOccurred(this);
- }
- void ExceptionDescribe() {
- functions->ExceptionDescribe(this);
- }
- void ExceptionClear() {
- functions->ExceptionClear(this);
- }
- void FatalError(const char *msg) {
- functions->FatalError(this, msg);
- }
-
- jint PushLocalFrame(jint capacity) {
- return functions->PushLocalFrame(this,capacity);
- }
- jobject PopLocalFrame(jobject result) {
- return functions->PopLocalFrame(this,result);
- }
-
- jobject NewGlobalRef(jobject lobj) {
- return functions->NewGlobalRef(this,lobj);
- }
- void DeleteGlobalRef(jobject gref) {
- functions->DeleteGlobalRef(this,gref);
- }
- void DeleteLocalRef(jobject obj) {
- functions->DeleteLocalRef(this, obj);
- }
-
- jboolean IsSameObject(jobject obj1, jobject obj2) {
- return functions->IsSameObject(this,obj1,obj2);
- }
-
- jobject NewLocalRef(jobject ref) {
- return functions->NewLocalRef(this,ref);
- }
- jint EnsureLocalCapacity(jint capacity) {
- return functions->EnsureLocalCapacity(this,capacity);
- }
-
- jobject AllocObject(jclass clazz) {
- return functions->AllocObject(this,clazz);
- }
- jobject NewObject(jclass clazz, jmethodID methodID, ...) {
- va_list args;
- jobject result;
- va_start(args, methodID);
- result = functions->NewObjectV(this,clazz,methodID,args);
- va_end(args);
- return result;
- }
- jobject NewObjectV(jclass clazz, jmethodID methodID,
- va_list args) {
- return functions->NewObjectV(this,clazz,methodID,args);
- }
- jobject NewObjectA(jclass clazz, jmethodID methodID,
- const jvalue *args) {
- return functions->NewObjectA(this,clazz,methodID,args);
- }
-
- jclass GetObjectClass(jobject obj) {
- return functions->GetObjectClass(this,obj);
- }
- jboolean IsInstanceOf(jobject obj, jclass clazz) {
- return functions->IsInstanceOf(this,obj,clazz);
- }
-
- jmethodID GetMethodID(jclass clazz, const char *name,
- const char *sig) {
- return functions->GetMethodID(this,clazz,name,sig);
- }
-
- jobject CallObjectMethod(jobject obj, jmethodID methodID, ...) {
- va_list args;
- jobject result;
- va_start(args,methodID);
- result = functions->CallObjectMethodV(this,obj,methodID,args);
- va_end(args);
- return result;
- }
- jobject CallObjectMethodV(jobject obj, jmethodID methodID,
- va_list args) {
- return functions->CallObjectMethodV(this,obj,methodID,args);
- }
- jobject CallObjectMethodA(jobject obj, jmethodID methodID,
- const jvalue * args) {
- return functions->CallObjectMethodA(this,obj,methodID,args);
- }
-
- jboolean CallBooleanMethod(jobject obj,
- jmethodID methodID, ...) {
- va_list args;
- jboolean result;
- va_start(args,methodID);
- result = functions->CallBooleanMethodV(this,obj,methodID,args);
- va_end(args);
- return result;
- }
- jboolean CallBooleanMethodV(jobject obj, jmethodID methodID,
- va_list args) {
- return functions->CallBooleanMethodV(this,obj,methodID,args);
- }
- jboolean CallBooleanMethodA(jobject obj, jmethodID methodID,
- const jvalue * args) {
- return functions->CallBooleanMethodA(this,obj,methodID, args);
- }
-
- jbyte CallByteMethod(jobject obj, jmethodID methodID, ...) {
- va_list args;
- jbyte result;
- va_start(args,methodID);
- result = functions->CallByteMethodV(this,obj,methodID,args);
- va_end(args);
- return result;
- }
- jbyte CallByteMethodV(jobject obj, jmethodID methodID,
- va_list args) {
- return functions->CallByteMethodV(this,obj,methodID,args);
- }
- jbyte CallByteMethodA(jobject obj, jmethodID methodID,
- const jvalue * args) {
- return functions->CallByteMethodA(this,obj,methodID,args);
- }
-
- jchar CallCharMethod(jobject obj, jmethodID methodID, ...) {
- va_list args;
- jchar result;
- va_start(args,methodID);
- result = functions->CallCharMethodV(this,obj,methodID,args);
- va_end(args);
- return result;
- }
- jchar CallCharMethodV(jobject obj, jmethodID methodID,
- va_list args) {
- return functions->CallCharMethodV(this,obj,methodID,args);
- }
- jchar CallCharMethodA(jobject obj, jmethodID methodID,
- const jvalue * args) {
- return functions->CallCharMethodA(this,obj,methodID,args);
- }
-
- jshort CallShortMethod(jobject obj, jmethodID methodID, ...) {
- va_list args;
- jshort result;
- va_start(args,methodID);
- result = functions->CallShortMethodV(this,obj,methodID,args);
- va_end(args);
- return result;
- }
- jshort CallShortMethodV(jobject obj, jmethodID methodID,
- va_list args) {
- return functions->CallShortMethodV(this,obj,methodID,args);
- }
- jshort CallShortMethodA(jobject obj, jmethodID methodID,
- const jvalue * args) {
- return functions->CallShortMethodA(this,obj,methodID,args);
- }
-
- jint CallIntMethod(jobject obj, jmethodID methodID, ...) {
- va_list args;
- jint result;
- va_start(args,methodID);
- result = functions->CallIntMethodV(this,obj,methodID,args);
- va_end(args);
- return result;
- }
- jint CallIntMethodV(jobject obj, jmethodID methodID,
- va_list args) {
- return functions->CallIntMethodV(this,obj,methodID,args);
- }
- jint CallIntMethodA(jobject obj, jmethodID methodID,
- const jvalue * args) {
- return functions->CallIntMethodA(this,obj,methodID,args);
- }
-
- jlong CallLongMethod(jobject obj, jmethodID methodID, ...) {
- va_list args;
- jlong result;
- va_start(args,methodID);
- result = functions->CallLongMethodV(this,obj,methodID,args);
- va_end(args);
- return result;
- }
- jlong CallLongMethodV(jobject obj, jmethodID methodID,
- va_list args) {
- return functions->CallLongMethodV(this,obj,methodID,args);
- }
- jlong CallLongMethodA(jobject obj, jmethodID methodID,
- const jvalue * args) {
- return functions->CallLongMethodA(this,obj,methodID,args);
- }
-
- jfloat CallFloatMethod(jobject obj, jmethodID methodID, ...) {
- va_list args;
- jfloat result;
- va_start(args,methodID);
- result = functions->CallFloatMethodV(this,obj,methodID,args);
- va_end(args);
- return result;
- }
- jfloat CallFloatMethodV(jobject obj, jmethodID methodID,
- va_list args) {
- return functions->CallFloatMethodV(this,obj,methodID,args);
- }
- jfloat CallFloatMethodA(jobject obj, jmethodID methodID,
- const jvalue * args) {
- return functions->CallFloatMethodA(this,obj,methodID,args);
- }
-
- jdouble CallDoubleMethod(jobject obj, jmethodID methodID, ...) {
- va_list args;
- jdouble result;
- va_start(args,methodID);
- result = functions->CallDoubleMethodV(this,obj,methodID,args);
- va_end(args);
- return result;
- }
- jdouble CallDoubleMethodV(jobject obj, jmethodID methodID,
- va_list args) {
- return functions->CallDoubleMethodV(this,obj,methodID,args);
- }
- jdouble CallDoubleMethodA(jobject obj, jmethodID methodID,
- const jvalue * args) {
- return functions->CallDoubleMethodA(this,obj,methodID,args);
- }
-
- void CallVoidMethod(jobject obj, jmethodID methodID, ...) {
- va_list args;
- va_start(args,methodID);
- functions->CallVoidMethodV(this,obj,methodID,args);
- va_end(args);
- }
- void CallVoidMethodV(jobject obj, jmethodID methodID,
- va_list args) {
- functions->CallVoidMethodV(this,obj,methodID,args);
- }
- void CallVoidMethodA(jobject obj, jmethodID methodID,
- const jvalue * args) {
- functions->CallVoidMethodA(this,obj,methodID,args);
- }
-
- jobject CallNonvirtualObjectMethod(jobject obj, jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jobject result;
- va_start(args,methodID);
- result = functions->CallNonvirtualObjectMethodV(this,obj,clazz,
- methodID,args);
- va_end(args);
- return result;
- }
- jobject CallNonvirtualObjectMethodV(jobject obj, jclass clazz,
- jmethodID methodID, va_list args) {
- return functions->CallNonvirtualObjectMethodV(this,obj,clazz,
- methodID,args);
- }
- jobject CallNonvirtualObjectMethodA(jobject obj, jclass clazz,
- jmethodID methodID, const jvalue * args) {
- return functions->CallNonvirtualObjectMethodA(this,obj,clazz,
- methodID,args);
- }
-
- jboolean CallNonvirtualBooleanMethod(jobject obj, jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jboolean result;
- va_start(args,methodID);
- result = functions->CallNonvirtualBooleanMethodV(this,obj,clazz,
- methodID,args);
- va_end(args);
- return result;
- }
- jboolean CallNonvirtualBooleanMethodV(jobject obj, jclass clazz,
- jmethodID methodID, va_list args) {
- return functions->CallNonvirtualBooleanMethodV(this,obj,clazz,
- methodID,args);
- }
- jboolean CallNonvirtualBooleanMethodA(jobject obj, jclass clazz,
- jmethodID methodID, const jvalue * args) {
- return functions->CallNonvirtualBooleanMethodA(this,obj,clazz,
- methodID, args);
- }
-
- jbyte CallNonvirtualByteMethod(jobject obj, jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jbyte result;
- va_start(args,methodID);
- result = functions->CallNonvirtualByteMethodV(this,obj,clazz,
- methodID,args);
- va_end(args);
- return result;
- }
- jbyte CallNonvirtualByteMethodV(jobject obj, jclass clazz,
- jmethodID methodID, va_list args) {
- return functions->CallNonvirtualByteMethodV(this,obj,clazz,
- methodID,args);
- }
- jbyte CallNonvirtualByteMethodA(jobject obj, jclass clazz,
- jmethodID methodID, const jvalue * args) {
- return functions->CallNonvirtualByteMethodA(this,obj,clazz,
- methodID,args);
- }
-
- jchar CallNonvirtualCharMethod(jobject obj, jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jchar result;
- va_start(args,methodID);
- result = functions->CallNonvirtualCharMethodV(this,obj,clazz,
- methodID,args);
- va_end(args);
- return result;
- }
- jchar CallNonvirtualCharMethodV(jobject obj, jclass clazz,
- jmethodID methodID, va_list args) {
- return functions->CallNonvirtualCharMethodV(this,obj,clazz,
- methodID,args);
- }
- jchar CallNonvirtualCharMethodA(jobject obj, jclass clazz,
- jmethodID methodID, const jvalue * args) {
- return functions->CallNonvirtualCharMethodA(this,obj,clazz,
- methodID,args);
- }
-
- jshort CallNonvirtualShortMethod(jobject obj, jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jshort result;
- va_start(args,methodID);
- result = functions->CallNonvirtualShortMethodV(this,obj,clazz,
- methodID,args);
- va_end(args);
- return result;
- }
- jshort CallNonvirtualShortMethodV(jobject obj, jclass clazz,
- jmethodID methodID, va_list args) {
- return functions->CallNonvirtualShortMethodV(this,obj,clazz,
- methodID,args);
- }
- jshort CallNonvirtualShortMethodA(jobject obj, jclass clazz,
- jmethodID methodID, const jvalue * args) {
- return functions->CallNonvirtualShortMethodA(this,obj,clazz,
- methodID,args);
- }
-
- jint CallNonvirtualIntMethod(jobject obj, jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jint result;
- va_start(args,methodID);
- result = functions->CallNonvirtualIntMethodV(this,obj,clazz,
- methodID,args);
- va_end(args);
- return result;
- }
- jint CallNonvirtualIntMethodV(jobject obj, jclass clazz,
- jmethodID methodID, va_list args) {
- return functions->CallNonvirtualIntMethodV(this,obj,clazz,
- methodID,args);
- }
- jint CallNonvirtualIntMethodA(jobject obj, jclass clazz,
- jmethodID methodID, const jvalue * args) {
- return functions->CallNonvirtualIntMethodA(this,obj,clazz,
- methodID,args);
- }
-
- jlong CallNonvirtualLongMethod(jobject obj, jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jlong result;
- va_start(args,methodID);
- result = functions->CallNonvirtualLongMethodV(this,obj,clazz,
- methodID,args);
- va_end(args);
- return result;
- }
- jlong CallNonvirtualLongMethodV(jobject obj, jclass clazz,
- jmethodID methodID, va_list args) {
- return functions->CallNonvirtualLongMethodV(this,obj,clazz,
- methodID,args);
- }
- jlong CallNonvirtualLongMethodA(jobject obj, jclass clazz,
- jmethodID methodID, const jvalue * args) {
- return functions->CallNonvirtualLongMethodA(this,obj,clazz,
- methodID,args);
- }
-
- jfloat CallNonvirtualFloatMethod(jobject obj, jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jfloat result;
- va_start(args,methodID);
- result = functions->CallNonvirtualFloatMethodV(this,obj,clazz,
- methodID,args);
- va_end(args);
- return result;
- }
- jfloat CallNonvirtualFloatMethodV(jobject obj, jclass clazz,
- jmethodID methodID,
- va_list args) {
- return functions->CallNonvirtualFloatMethodV(this,obj,clazz,
- methodID,args);
- }
- jfloat CallNonvirtualFloatMethodA(jobject obj, jclass clazz,
- jmethodID methodID,
- const jvalue * args) {
- return functions->CallNonvirtualFloatMethodA(this,obj,clazz,
- methodID,args);
- }
-
- jdouble CallNonvirtualDoubleMethod(jobject obj, jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jdouble result;
- va_start(args,methodID);
- result = functions->CallNonvirtualDoubleMethodV(this,obj,clazz,
- methodID,args);
- va_end(args);
- return result;
- }
- jdouble CallNonvirtualDoubleMethodV(jobject obj, jclass clazz,
- jmethodID methodID,
- va_list args) {
- return functions->CallNonvirtualDoubleMethodV(this,obj,clazz,
- methodID,args);
- }
- jdouble CallNonvirtualDoubleMethodA(jobject obj, jclass clazz,
- jmethodID methodID,
- const jvalue * args) {
- return functions->CallNonvirtualDoubleMethodA(this,obj,clazz,
- methodID,args);
- }
-
- void CallNonvirtualVoidMethod(jobject obj, jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- va_start(args,methodID);
- functions->CallNonvirtualVoidMethodV(this,obj,clazz,methodID,args);
- va_end(args);
- }
- void CallNonvirtualVoidMethodV(jobject obj, jclass clazz,
- jmethodID methodID,
- va_list args) {
- functions->CallNonvirtualVoidMethodV(this,obj,clazz,methodID,args);
- }
- void CallNonvirtualVoidMethodA(jobject obj, jclass clazz,
- jmethodID methodID,
- const jvalue * args) {
- functions->CallNonvirtualVoidMethodA(this,obj,clazz,methodID,args);
- }
-
- jfieldID GetFieldID(jclass clazz, const char *name,
- const char *sig) {
- return functions->GetFieldID(this,clazz,name,sig);
- }
-
- jobject GetObjectField(jobject obj, jfieldID fieldID) {
- return functions->GetObjectField(this,obj,fieldID);
- }
- jboolean GetBooleanField(jobject obj, jfieldID fieldID) {
- return functions->GetBooleanField(this,obj,fieldID);
- }
- jbyte GetByteField(jobject obj, jfieldID fieldID) {
- return functions->GetByteField(this,obj,fieldID);
- }
- jchar GetCharField(jobject obj, jfieldID fieldID) {
- return functions->GetCharField(this,obj,fieldID);
- }
- jshort GetShortField(jobject obj, jfieldID fieldID) {
- return functions->GetShortField(this,obj,fieldID);
- }
- jint GetIntField(jobject obj, jfieldID fieldID) {
- return functions->GetIntField(this,obj,fieldID);
- }
- jlong GetLongField(jobject obj, jfieldID fieldID) {
- return functions->GetLongField(this,obj,fieldID);
- }
- jfloat GetFloatField(jobject obj, jfieldID fieldID) {
- return functions->GetFloatField(this,obj,fieldID);
- }
- jdouble GetDoubleField(jobject obj, jfieldID fieldID) {
- return functions->GetDoubleField(this,obj,fieldID);
- }
-
- void SetObjectField(jobject obj, jfieldID fieldID, jobject val) {
- functions->SetObjectField(this,obj,fieldID,val);
- }
- void SetBooleanField(jobject obj, jfieldID fieldID,
- jboolean val) {
- functions->SetBooleanField(this,obj,fieldID,val);
- }
- void SetByteField(jobject obj, jfieldID fieldID,
- jbyte val) {
- functions->SetByteField(this,obj,fieldID,val);
- }
- void SetCharField(jobject obj, jfieldID fieldID,
- jchar val) {
- functions->SetCharField(this,obj,fieldID,val);
- }
- void SetShortField(jobject obj, jfieldID fieldID,
- jshort val) {
- functions->SetShortField(this,obj,fieldID,val);
- }
- void SetIntField(jobject obj, jfieldID fieldID,
- jint val) {
- functions->SetIntField(this,obj,fieldID,val);
- }
- void SetLongField(jobject obj, jfieldID fieldID,
- jlong val) {
- functions->SetLongField(this,obj,fieldID,val);
- }
- void SetFloatField(jobject obj, jfieldID fieldID,
- jfloat val) {
- functions->SetFloatField(this,obj,fieldID,val);
- }
- void SetDoubleField(jobject obj, jfieldID fieldID,
- jdouble val) {
- functions->SetDoubleField(this,obj,fieldID,val);
- }
-
- jmethodID GetStaticMethodID(jclass clazz, const char *name,
- const char *sig) {
- return functions->GetStaticMethodID(this,clazz,name,sig);
- }
-
- jobject CallStaticObjectMethod(jclass clazz, jmethodID methodID,
- ...) {
- va_list args;
- jobject result;
- va_start(args,methodID);
- result = functions->CallStaticObjectMethodV(this,clazz,methodID,args);
- va_end(args);
- return result;
- }
- jobject CallStaticObjectMethodV(jclass clazz, jmethodID methodID,
- va_list args) {
- return functions->CallStaticObjectMethodV(this,clazz,methodID,args);
- }
- jobject CallStaticObjectMethodA(jclass clazz, jmethodID methodID,
- const jvalue *args) {
- return functions->CallStaticObjectMethodA(this,clazz,methodID,args);
- }
-
- jboolean CallStaticBooleanMethod(jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jboolean result;
- va_start(args,methodID);
- result = functions->CallStaticBooleanMethodV(this,clazz,methodID,args);
- va_end(args);
- return result;
- }
- jboolean CallStaticBooleanMethodV(jclass clazz,
- jmethodID methodID, va_list args) {
- return functions->CallStaticBooleanMethodV(this,clazz,methodID,args);
- }
- jboolean CallStaticBooleanMethodA(jclass clazz,
- jmethodID methodID, const jvalue *args) {
- return functions->CallStaticBooleanMethodA(this,clazz,methodID,args);
- }
-
- jbyte CallStaticByteMethod(jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jbyte result;
- va_start(args,methodID);
- result = functions->CallStaticByteMethodV(this,clazz,methodID,args);
- va_end(args);
- return result;
- }
- jbyte CallStaticByteMethodV(jclass clazz,
- jmethodID methodID, va_list args) {
- return functions->CallStaticByteMethodV(this,clazz,methodID,args);
- }
- jbyte CallStaticByteMethodA(jclass clazz,
- jmethodID methodID, const jvalue *args) {
- return functions->CallStaticByteMethodA(this,clazz,methodID,args);
- }
-
- jchar CallStaticCharMethod(jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jchar result;
- va_start(args,methodID);
- result = functions->CallStaticCharMethodV(this,clazz,methodID,args);
- va_end(args);
- return result;
- }
- jchar CallStaticCharMethodV(jclass clazz,
- jmethodID methodID, va_list args) {
- return functions->CallStaticCharMethodV(this,clazz,methodID,args);
- }
- jchar CallStaticCharMethodA(jclass clazz,
- jmethodID methodID, const jvalue *args) {
- return functions->CallStaticCharMethodA(this,clazz,methodID,args);
- }
-
- jshort CallStaticShortMethod(jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jshort result;
- va_start(args,methodID);
- result = functions->CallStaticShortMethodV(this,clazz,methodID,args);
- va_end(args);
- return result;
- }
- jshort CallStaticShortMethodV(jclass clazz,
- jmethodID methodID, va_list args) {
- return functions->CallStaticShortMethodV(this,clazz,methodID,args);
- }
- jshort CallStaticShortMethodA(jclass clazz,
- jmethodID methodID, const jvalue *args) {
- return functions->CallStaticShortMethodA(this,clazz,methodID,args);
- }
-
- jint CallStaticIntMethod(jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jint result;
- va_start(args,methodID);
- result = functions->CallStaticIntMethodV(this,clazz,methodID,args);
- va_end(args);
- return result;
- }
- jint CallStaticIntMethodV(jclass clazz,
- jmethodID methodID, va_list args) {
- return functions->CallStaticIntMethodV(this,clazz,methodID,args);
- }
- jint CallStaticIntMethodA(jclass clazz,
- jmethodID methodID, const jvalue *args) {
- return functions->CallStaticIntMethodA(this,clazz,methodID,args);
- }
-
- jlong CallStaticLongMethod(jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jlong result;
- va_start(args,methodID);
- result = functions->CallStaticLongMethodV(this,clazz,methodID,args);
- va_end(args);
- return result;
- }
- jlong CallStaticLongMethodV(jclass clazz,
- jmethodID methodID, va_list args) {
- return functions->CallStaticLongMethodV(this,clazz,methodID,args);
- }
- jlong CallStaticLongMethodA(jclass clazz,
- jmethodID methodID, const jvalue *args) {
- return functions->CallStaticLongMethodA(this,clazz,methodID,args);
- }
-
- jfloat CallStaticFloatMethod(jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jfloat result;
- va_start(args,methodID);
- result = functions->CallStaticFloatMethodV(this,clazz,methodID,args);
- va_end(args);
- return result;
- }
- jfloat CallStaticFloatMethodV(jclass clazz,
- jmethodID methodID, va_list args) {
- return functions->CallStaticFloatMethodV(this,clazz,methodID,args);
- }
- jfloat CallStaticFloatMethodA(jclass clazz,
- jmethodID methodID, const jvalue *args) {
- return functions->CallStaticFloatMethodA(this,clazz,methodID,args);
- }
-
- jdouble CallStaticDoubleMethod(jclass clazz,
- jmethodID methodID, ...) {
- va_list args;
- jdouble result;
- va_start(args,methodID);
- result = functions->CallStaticDoubleMethodV(this,clazz,methodID,args);
- va_end(args);
- return result;
- }
- jdouble CallStaticDoubleMethodV(jclass clazz,
- jmethodID methodID, va_list args) {
- return functions->CallStaticDoubleMethodV(this,clazz,methodID,args);
- }
- jdouble CallStaticDoubleMethodA(jclass clazz,
- jmethodID methodID, const jvalue *args) {
- return functions->CallStaticDoubleMethodA(this,clazz,methodID,args);
- }
-
- void CallStaticVoidMethod(jclass cls, jmethodID methodID, ...) {
- va_list args;
- va_start(args,methodID);
- functions->CallStaticVoidMethodV(this,cls,methodID,args);
- va_end(args);
- }
- void CallStaticVoidMethodV(jclass cls, jmethodID methodID,
- va_list args) {
- functions->CallStaticVoidMethodV(this,cls,methodID,args);
- }
- void CallStaticVoidMethodA(jclass cls, jmethodID methodID,
- const jvalue * args) {
- functions->CallStaticVoidMethodA(this,cls,methodID,args);
- }
-
- jfieldID GetStaticFieldID(jclass clazz, const char *name,
- const char *sig) {
- return functions->GetStaticFieldID(this,clazz,name,sig);
- }
- jobject GetStaticObjectField(jclass clazz, jfieldID fieldID) {
- return functions->GetStaticObjectField(this,clazz,fieldID);
- }
- jboolean GetStaticBooleanField(jclass clazz, jfieldID fieldID) {
- return functions->GetStaticBooleanField(this,clazz,fieldID);
- }
- jbyte GetStaticByteField(jclass clazz, jfieldID fieldID) {
- return functions->GetStaticByteField(this,clazz,fieldID);
- }
- jchar GetStaticCharField(jclass clazz, jfieldID fieldID) {
- return functions->GetStaticCharField(this,clazz,fieldID);
- }
- jshort GetStaticShortField(jclass clazz, jfieldID fieldID) {
- return functions->GetStaticShortField(this,clazz,fieldID);
- }
- jint GetStaticIntField(jclass clazz, jfieldID fieldID) {
- return functions->GetStaticIntField(this,clazz,fieldID);
- }
- jlong GetStaticLongField(jclass clazz, jfieldID fieldID) {
- return functions->GetStaticLongField(this,clazz,fieldID);
- }
- jfloat GetStaticFloatField(jclass clazz, jfieldID fieldID) {
- return functions->GetStaticFloatField(this,clazz,fieldID);
- }
- jdouble GetStaticDoubleField(jclass clazz, jfieldID fieldID) {
- return functions->GetStaticDoubleField(this,clazz,fieldID);
- }
-
- void SetStaticObjectField(jclass clazz, jfieldID fieldID,
- jobject value) {
- functions->SetStaticObjectField(this,clazz,fieldID,value);
- }
- void SetStaticBooleanField(jclass clazz, jfieldID fieldID,
- jboolean value) {
- functions->SetStaticBooleanField(this,clazz,fieldID,value);
- }
- void SetStaticByteField(jclass clazz, jfieldID fieldID,
- jbyte value) {
- functions->SetStaticByteField(this,clazz,fieldID,value);
- }
- void SetStaticCharField(jclass clazz, jfieldID fieldID,
- jchar value) {
- functions->SetStaticCharField(this,clazz,fieldID,value);
- }
- void SetStaticShortField(jclass clazz, jfieldID fieldID,
- jshort value) {
- functions->SetStaticShortField(this,clazz,fieldID,value);
- }
- void SetStaticIntField(jclass clazz, jfieldID fieldID,
- jint value) {
- functions->SetStaticIntField(this,clazz,fieldID,value);
- }
- void SetStaticLongField(jclass clazz, jfieldID fieldID,
- jlong value) {
- functions->SetStaticLongField(this,clazz,fieldID,value);
- }
- void SetStaticFloatField(jclass clazz, jfieldID fieldID,
- jfloat value) {
- functions->SetStaticFloatField(this,clazz,fieldID,value);
- }
- void SetStaticDoubleField(jclass clazz, jfieldID fieldID,
- jdouble value) {
- functions->SetStaticDoubleField(this,clazz,fieldID,value);
- }
-
- jstring NewString(const jchar *unicode, jsize len) {
- return functions->NewString(this,unicode,len);
- }
- jsize GetStringLength(jstring str) {
- return functions->GetStringLength(this,str);
- }
- const jchar *GetStringChars(jstring str, jboolean *isCopy) {
- return functions->GetStringChars(this,str,isCopy);
- }
- void ReleaseStringChars(jstring str, const jchar *chars) {
- functions->ReleaseStringChars(this,str,chars);
- }
-
- jstring NewStringUTF(const char *utf) {
- return functions->NewStringUTF(this,utf);
- }
- jsize GetStringUTFLength(jstring str) {
- return functions->GetStringUTFLength(this,str);
- }
- const char* GetStringUTFChars(jstring str, jboolean *isCopy) {
- return functions->GetStringUTFChars(this,str,isCopy);
- }
- void ReleaseStringUTFChars(jstring str, const char* chars) {
- functions->ReleaseStringUTFChars(this,str,chars);
- }
-
- jsize GetArrayLength(jarray array) {
- return functions->GetArrayLength(this,array);
- }
-
- jobjectArray NewObjectArray(jsize len, jclass clazz,
- jobject init) {
- return functions->NewObjectArray(this,len,clazz,init);
- }
- jobject GetObjectArrayElement(jobjectArray array, jsize index) {
- return functions->GetObjectArrayElement(this,array,index);
- }
- void SetObjectArrayElement(jobjectArray array, jsize index,
- jobject val) {
- functions->SetObjectArrayElement(this,array,index,val);
- }
-
- jbooleanArray NewBooleanArray(jsize len) {
- return functions->NewBooleanArray(this,len);
- }
- jbyteArray NewByteArray(jsize len) {
- return functions->NewByteArray(this,len);
- }
- jcharArray NewCharArray(jsize len) {
- return functions->NewCharArray(this,len);
- }
- jshortArray NewShortArray(jsize len) {
- return functions->NewShortArray(this,len);
- }
- jintArray NewIntArray(jsize len) {
- return functions->NewIntArray(this,len);
- }
- jlongArray NewLongArray(jsize len) {
- return functions->NewLongArray(this,len);
- }
- jfloatArray NewFloatArray(jsize len) {
- return functions->NewFloatArray(this,len);
- }
- jdoubleArray NewDoubleArray(jsize len) {
- return functions->NewDoubleArray(this,len);
- }
-
- jboolean * GetBooleanArrayElements(jbooleanArray array, jboolean *isCopy) {
- return functions->GetBooleanArrayElements(this,array,isCopy);
- }
- jbyte * GetByteArrayElements(jbyteArray array, jboolean *isCopy) {
- return functions->GetByteArrayElements(this,array,isCopy);
- }
- jchar * GetCharArrayElements(jcharArray array, jboolean *isCopy) {
- return functions->GetCharArrayElements(this,array,isCopy);
- }
- jshort * GetShortArrayElements(jshortArray array, jboolean *isCopy) {
- return functions->GetShortArrayElements(this,array,isCopy);
- }
- jint * GetIntArrayElements(jintArray array, jboolean *isCopy) {
- return functions->GetIntArrayElements(this,array,isCopy);
- }
- jlong * GetLongArrayElements(jlongArray array, jboolean *isCopy) {
- return functions->GetLongArrayElements(this,array,isCopy);
- }
- jfloat * GetFloatArrayElements(jfloatArray array, jboolean *isCopy) {
- return functions->GetFloatArrayElements(this,array,isCopy);
- }
- jdouble * GetDoubleArrayElements(jdoubleArray array, jboolean *isCopy) {
- return functions->GetDoubleArrayElements(this,array,isCopy);
- }
-
- void ReleaseBooleanArrayElements(jbooleanArray array,
- jboolean *elems,
- jint mode) {
- functions->ReleaseBooleanArrayElements(this,array,elems,mode);
- }
- void ReleaseByteArrayElements(jbyteArray array,
- jbyte *elems,
- jint mode) {
- functions->ReleaseByteArrayElements(this,array,elems,mode);
- }
- void ReleaseCharArrayElements(jcharArray array,
- jchar *elems,
- jint mode) {
- functions->ReleaseCharArrayElements(this,array,elems,mode);
- }
- void ReleaseShortArrayElements(jshortArray array,
- jshort *elems,
- jint mode) {
- functions->ReleaseShortArrayElements(this,array,elems,mode);
- }
- void ReleaseIntArrayElements(jintArray array,
- jint *elems,
- jint mode) {
- functions->ReleaseIntArrayElements(this,array,elems,mode);
- }
- void ReleaseLongArrayElements(jlongArray array,
- jlong *elems,
- jint mode) {
- functions->ReleaseLongArrayElements(this,array,elems,mode);
- }
- void ReleaseFloatArrayElements(jfloatArray array,
- jfloat *elems,
- jint mode) {
- functions->ReleaseFloatArrayElements(this,array,elems,mode);
- }
- void ReleaseDoubleArrayElements(jdoubleArray array,
- jdouble *elems,
- jint mode) {
- functions->ReleaseDoubleArrayElements(this,array,elems,mode);
- }
-
- void GetBooleanArrayRegion(jbooleanArray array,
- jsize start, jsize len, jboolean *buf) {
- functions->GetBooleanArrayRegion(this,array,start,len,buf);
- }
- void GetByteArrayRegion(jbyteArray array,
- jsize start, jsize len, jbyte *buf) {
- functions->GetByteArrayRegion(this,array,start,len,buf);
- }
- void GetCharArrayRegion(jcharArray array,
- jsize start, jsize len, jchar *buf) {
- functions->GetCharArrayRegion(this,array,start,len,buf);
- }
- void GetShortArrayRegion(jshortArray array,
- jsize start, jsize len, jshort *buf) {
- functions->GetShortArrayRegion(this,array,start,len,buf);
- }
- void GetIntArrayRegion(jintArray array,
- jsize start, jsize len, jint *buf) {
- functions->GetIntArrayRegion(this,array,start,len,buf);
- }
- void GetLongArrayRegion(jlongArray array,
- jsize start, jsize len, jlong *buf) {
- functions->GetLongArrayRegion(this,array,start,len,buf);
- }
- void GetFloatArrayRegion(jfloatArray array,
- jsize start, jsize len, jfloat *buf) {
- functions->GetFloatArrayRegion(this,array,start,len,buf);
- }
- void GetDoubleArrayRegion(jdoubleArray array,
- jsize start, jsize len, jdouble *buf) {
- functions->GetDoubleArrayRegion(this,array,start,len,buf);
- }
-
- void SetBooleanArrayRegion(jbooleanArray array, jsize start, jsize len,
- const jboolean *buf) {
- functions->SetBooleanArrayRegion(this,array,start,len,buf);
- }
- void SetByteArrayRegion(jbyteArray array, jsize start, jsize len,
- const jbyte *buf) {
- functions->SetByteArrayRegion(this,array,start,len,buf);
- }
- void SetCharArrayRegion(jcharArray array, jsize start, jsize len,
- const jchar *buf) {
- functions->SetCharArrayRegion(this,array,start,len,buf);
- }
- void SetShortArrayRegion(jshortArray array, jsize start, jsize len,
- const jshort *buf) {
- functions->SetShortArrayRegion(this,array,start,len,buf);
- }
- void SetIntArrayRegion(jintArray array, jsize start, jsize len,
- const jint *buf) {
- functions->SetIntArrayRegion(this,array,start,len,buf);
- }
- void SetLongArrayRegion(jlongArray array, jsize start, jsize len,
- const jlong *buf) {
- functions->SetLongArrayRegion(this,array,start,len,buf);
- }
- void SetFloatArrayRegion(jfloatArray array, jsize start, jsize len,
- const jfloat *buf) {
- functions->SetFloatArrayRegion(this,array,start,len,buf);
- }
- void SetDoubleArrayRegion(jdoubleArray array, jsize start, jsize len,
- const jdouble *buf) {
- functions->SetDoubleArrayRegion(this,array,start,len,buf);
- }
-
- jint RegisterNatives(jclass clazz, const JNINativeMethod *methods,
- jint nMethods) {
- return functions->RegisterNatives(this,clazz,methods,nMethods);
- }
- jint UnregisterNatives(jclass clazz) {
- return functions->UnregisterNatives(this,clazz);
- }
-
- jint MonitorEnter(jobject obj) {
- return functions->MonitorEnter(this,obj);
- }
- jint MonitorExit(jobject obj) {
- return functions->MonitorExit(this,obj);
- }
-
- jint GetJavaVM(JavaVM **vm) {
- return functions->GetJavaVM(this,vm);
- }
-
- void GetStringRegion(jstring str, jsize start, jsize len, jchar *buf) {
- functions->GetStringRegion(this,str,start,len,buf);
- }
- void GetStringUTFRegion(jstring str, jsize start, jsize len, char *buf) {
- functions->GetStringUTFRegion(this,str,start,len,buf);
- }
-
- void * GetPrimitiveArrayCritical(jarray array, jboolean *isCopy) {
- return functions->GetPrimitiveArrayCritical(this,array,isCopy);
- }
- void ReleasePrimitiveArrayCritical(jarray array, void *carray, jint mode) {
- functions->ReleasePrimitiveArrayCritical(this,array,carray,mode);
- }
-
- const jchar * GetStringCritical(jstring string, jboolean *isCopy) {
- return functions->GetStringCritical(this,string,isCopy);
- }
- void ReleaseStringCritical(jstring string, const jchar *cstring) {
- functions->ReleaseStringCritical(this,string,cstring);
- }
-
- jweak NewWeakGlobalRef(jobject obj) {
- return functions->NewWeakGlobalRef(this,obj);
- }
- void DeleteWeakGlobalRef(jweak ref) {
- functions->DeleteWeakGlobalRef(this,ref);
- }
-
- jboolean ExceptionCheck() {
- return functions->ExceptionCheck(this);
- }
-
- jobject NewDirectByteBuffer(void* address, jlong capacity) {
- return functions->NewDirectByteBuffer(this, address, capacity);
- }
- void* GetDirectBufferAddress(jobject buf) {
- return functions->GetDirectBufferAddress(this, buf);
- }
- jlong GetDirectBufferCapacity(jobject buf) {
- return functions->GetDirectBufferCapacity(this, buf);
- }
- jobjectRefType GetObjectRefType(jobject obj) {
- return functions->GetObjectRefType(this, obj);
- }
-
-#endif /* __cplusplus */
-};
-
-typedef struct JavaVMOption {
- char *optionString;
- void *extraInfo;
-} JavaVMOption;
-
-typedef struct JavaVMInitArgs {
- jint version;
-
- jint nOptions;
- JavaVMOption *options;
- jboolean ignoreUnrecognized;
-} JavaVMInitArgs;
-
-typedef struct JavaVMAttachArgs {
- jint version;
-
- char *name;
- jobject group;
-} JavaVMAttachArgs;
-
-/* These will be VM-specific. */
-
-#define JDK1_2
-#define JDK1_4
-
-/* End VM-specific. */
-
-struct JNIInvokeInterface_ {
- void *reserved0;
- void *reserved1;
- void *reserved2;
-
- jint (JNICALL *DestroyJavaVM)(JavaVM *vm);
-
- jint (JNICALL *AttachCurrentThread)(JavaVM *vm, void **penv, void *args);
-
- jint (JNICALL *DetachCurrentThread)(JavaVM *vm);
-
- jint (JNICALL *GetEnv)(JavaVM *vm, void **penv, jint version);
-
- jint (JNICALL *AttachCurrentThreadAsDaemon)(JavaVM *vm, void **penv, void *args);
-};
-
-struct JavaVM_ {
- const struct JNIInvokeInterface_ *functions;
-#ifdef __cplusplus
-
- jint DestroyJavaVM() {
- return functions->DestroyJavaVM(this);
- }
- jint AttachCurrentThread(void **penv, void *args) {
- return functions->AttachCurrentThread(this, penv, args);
- }
- jint DetachCurrentThread() {
- return functions->DetachCurrentThread(this);
- }
-
- jint GetEnv(void **penv, jint version) {
- return functions->GetEnv(this, penv, version);
- }
- jint AttachCurrentThreadAsDaemon(void **penv, void *args) {
- return functions->AttachCurrentThreadAsDaemon(this, penv, args);
- }
-#endif
-};
-
-#ifdef _JNI_IMPLEMENTATION_
-#define _JNI_IMPORT_OR_EXPORT_ JNIEXPORT
-#else
-#define _JNI_IMPORT_OR_EXPORT_ JNIIMPORT
-#endif
-_JNI_IMPORT_OR_EXPORT_ jint JNICALL
-JNI_GetDefaultJavaVMInitArgs(void *args);
-
-_JNI_IMPORT_OR_EXPORT_ jint JNICALL
-JNI_CreateJavaVM(JavaVM **pvm, void **penv, void *args);
-
-_JNI_IMPORT_OR_EXPORT_ jint JNICALL
-JNI_GetCreatedJavaVMs(JavaVM **, jsize, jsize *);
-
-/* Defined by native libraries. */
-JNIEXPORT jint JNICALL
-JNI_OnLoad(JavaVM *vm, void *reserved);
-
-JNIEXPORT void JNICALL
-JNI_OnUnload(JavaVM *vm, void *reserved);
-
-#define JNI_VERSION_1_1 0x00010001
-#define JNI_VERSION_1_2 0x00010002
-#define JNI_VERSION_1_4 0x00010004
-#define JNI_VERSION_1_6 0x00010006
-#define JNI_VERSION_1_8 0x00010008
-
-#ifdef __cplusplus
-} /* extern "C" */
-#endif /* __cplusplus */
-
-#endif /* !_JAVASOFT_JNI_H_ */
diff --git a/demos/java/jni/gs_jni/include/jvmti.h b/demos/java/jni/gs_jni/include/jvmti.h
deleted file mode 100644
index e8de8585..00000000
--- a/demos/java/jni/gs_jni/include/jvmti.h
+++ /dev/null
@@ -1,2533 +0,0 @@
-/*
- * Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved.
- * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- */
-
- /* AUTOMATICALLY GENERATED FILE - DO NOT EDIT */
-
-
- /* Include file for the Java(tm) Virtual Machine Tool Interface */
-
-#ifndef _JAVA_JVMTI_H_
-#define _JAVA_JVMTI_H_
-
-#include "jni.h"
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-enum {
- JVMTI_VERSION_1 = 0x30010000,
- JVMTI_VERSION_1_0 = 0x30010000,
- JVMTI_VERSION_1_1 = 0x30010100,
- JVMTI_VERSION_1_2 = 0x30010200,
-
- JVMTI_VERSION = 0x30000000 + (1 * 0x10000) + (2 * 0x100) + 1 /* version: 1.2.1 */
-};
-
-JNIEXPORT jint JNICALL
-Agent_OnLoad(JavaVM *vm, char *options, void *reserved);
-
-JNIEXPORT jint JNICALL
-Agent_OnAttach(JavaVM* vm, char* options, void* reserved);
-
-JNIEXPORT void JNICALL
-Agent_OnUnload(JavaVM *vm);
-
- /* Forward declaration of the environment */
-
-struct _jvmtiEnv;
-
-struct jvmtiInterface_1_;
-
-#ifdef __cplusplus
-typedef _jvmtiEnv jvmtiEnv;
-#else
-typedef const struct jvmtiInterface_1_ *jvmtiEnv;
-#endif /* __cplusplus */
-
-/* Derived Base Types */
-
-typedef jobject jthread;
-typedef jobject jthreadGroup;
-typedef jlong jlocation;
-struct _jrawMonitorID;
-typedef struct _jrawMonitorID *jrawMonitorID;
-typedef struct JNINativeInterface_ jniNativeInterface;
-
- /* Constants */
-
-
- /* Thread State Flags */
-
-enum {
- JVMTI_THREAD_STATE_ALIVE = 0x0001,
- JVMTI_THREAD_STATE_TERMINATED = 0x0002,
- JVMTI_THREAD_STATE_RUNNABLE = 0x0004,
- JVMTI_THREAD_STATE_BLOCKED_ON_MONITOR_ENTER = 0x0400,
- JVMTI_THREAD_STATE_WAITING = 0x0080,
- JVMTI_THREAD_STATE_WAITING_INDEFINITELY = 0x0010,
- JVMTI_THREAD_STATE_WAITING_WITH_TIMEOUT = 0x0020,
- JVMTI_THREAD_STATE_SLEEPING = 0x0040,
- JVMTI_THREAD_STATE_IN_OBJECT_WAIT = 0x0100,
- JVMTI_THREAD_STATE_PARKED = 0x0200,
- JVMTI_THREAD_STATE_SUSPENDED = 0x100000,
- JVMTI_THREAD_STATE_INTERRUPTED = 0x200000,
- JVMTI_THREAD_STATE_IN_NATIVE = 0x400000,
- JVMTI_THREAD_STATE_VENDOR_1 = 0x10000000,
- JVMTI_THREAD_STATE_VENDOR_2 = 0x20000000,
- JVMTI_THREAD_STATE_VENDOR_3 = 0x40000000
-};
-
- /* java.lang.Thread.State Conversion Masks */
-
-enum {
- JVMTI_JAVA_LANG_THREAD_STATE_MASK = JVMTI_THREAD_STATE_TERMINATED | JVMTI_THREAD_STATE_ALIVE | JVMTI_THREAD_STATE_RUNNABLE | JVMTI_THREAD_STATE_BLOCKED_ON_MONITOR_ENTER | JVMTI_THREAD_STATE_WAITING | JVMTI_THREAD_STATE_WAITING_INDEFINITELY | JVMTI_THREAD_STATE_WAITING_WITH_TIMEOUT,
- JVMTI_JAVA_LANG_THREAD_STATE_NEW = 0,
- JVMTI_JAVA_LANG_THREAD_STATE_TERMINATED = JVMTI_THREAD_STATE_TERMINATED,
- JVMTI_JAVA_LANG_THREAD_STATE_RUNNABLE = JVMTI_THREAD_STATE_ALIVE | JVMTI_THREAD_STATE_RUNNABLE,
- JVMTI_JAVA_LANG_THREAD_STATE_BLOCKED = JVMTI_THREAD_STATE_ALIVE | JVMTI_THREAD_STATE_BLOCKED_ON_MONITOR_ENTER,
- JVMTI_JAVA_LANG_THREAD_STATE_WAITING = JVMTI_THREAD_STATE_ALIVE | JVMTI_THREAD_STATE_WAITING | JVMTI_THREAD_STATE_WAITING_INDEFINITELY,
- JVMTI_JAVA_LANG_THREAD_STATE_TIMED_WAITING = JVMTI_THREAD_STATE_ALIVE | JVMTI_THREAD_STATE_WAITING | JVMTI_THREAD_STATE_WAITING_WITH_TIMEOUT
-};
-
- /* Thread Priority Constants */
-
-enum {
- JVMTI_THREAD_MIN_PRIORITY = 1,
- JVMTI_THREAD_NORM_PRIORITY = 5,
- JVMTI_THREAD_MAX_PRIORITY = 10
-};
-
- /* Heap Filter Flags */
-
-enum {
- JVMTI_HEAP_FILTER_TAGGED = 0x4,
- JVMTI_HEAP_FILTER_UNTAGGED = 0x8,
- JVMTI_HEAP_FILTER_CLASS_TAGGED = 0x10,
- JVMTI_HEAP_FILTER_CLASS_UNTAGGED = 0x20
-};
-
- /* Heap Visit Control Flags */
-
-enum {
- JVMTI_VISIT_OBJECTS = 0x100,
- JVMTI_VISIT_ABORT = 0x8000
-};
-
- /* Heap Reference Enumeration */
-
-typedef enum {
- JVMTI_HEAP_REFERENCE_CLASS = 1,
- JVMTI_HEAP_REFERENCE_FIELD = 2,
- JVMTI_HEAP_REFERENCE_ARRAY_ELEMENT = 3,
- JVMTI_HEAP_REFERENCE_CLASS_LOADER = 4,
- JVMTI_HEAP_REFERENCE_SIGNERS = 5,
- JVMTI_HEAP_REFERENCE_PROTECTION_DOMAIN = 6,
- JVMTI_HEAP_REFERENCE_INTERFACE = 7,
- JVMTI_HEAP_REFERENCE_STATIC_FIELD = 8,
- JVMTI_HEAP_REFERENCE_CONSTANT_POOL = 9,
- JVMTI_HEAP_REFERENCE_SUPERCLASS = 10,
- JVMTI_HEAP_REFERENCE_JNI_GLOBAL = 21,
- JVMTI_HEAP_REFERENCE_SYSTEM_CLASS = 22,
- JVMTI_HEAP_REFERENCE_MONITOR = 23,
- JVMTI_HEAP_REFERENCE_STACK_LOCAL = 24,
- JVMTI_HEAP_REFERENCE_JNI_LOCAL = 25,
- JVMTI_HEAP_REFERENCE_THREAD = 26,
- JVMTI_HEAP_REFERENCE_OTHER = 27
-} jvmtiHeapReferenceKind;
-
- /* Primitive Type Enumeration */
-
-typedef enum {
- JVMTI_PRIMITIVE_TYPE_BOOLEAN = 90,
- JVMTI_PRIMITIVE_TYPE_BYTE = 66,
- JVMTI_PRIMITIVE_TYPE_CHAR = 67,
- JVMTI_PRIMITIVE_TYPE_SHORT = 83,
- JVMTI_PRIMITIVE_TYPE_INT = 73,
- JVMTI_PRIMITIVE_TYPE_LONG = 74,
- JVMTI_PRIMITIVE_TYPE_FLOAT = 70,
- JVMTI_PRIMITIVE_TYPE_DOUBLE = 68
-} jvmtiPrimitiveType;
-
- /* Heap Object Filter Enumeration */
-
-typedef enum {
- JVMTI_HEAP_OBJECT_TAGGED = 1,
- JVMTI_HEAP_OBJECT_UNTAGGED = 2,
- JVMTI_HEAP_OBJECT_EITHER = 3
-} jvmtiHeapObjectFilter;
-
- /* Heap Root Kind Enumeration */
-
-typedef enum {
- JVMTI_HEAP_ROOT_JNI_GLOBAL = 1,
- JVMTI_HEAP_ROOT_SYSTEM_CLASS = 2,
- JVMTI_HEAP_ROOT_MONITOR = 3,
- JVMTI_HEAP_ROOT_STACK_LOCAL = 4,
- JVMTI_HEAP_ROOT_JNI_LOCAL = 5,
- JVMTI_HEAP_ROOT_THREAD = 6,
- JVMTI_HEAP_ROOT_OTHER = 7
-} jvmtiHeapRootKind;
-
- /* Object Reference Enumeration */
-
-typedef enum {
- JVMTI_REFERENCE_CLASS = 1,
- JVMTI_REFERENCE_FIELD = 2,
- JVMTI_REFERENCE_ARRAY_ELEMENT = 3,
- JVMTI_REFERENCE_CLASS_LOADER = 4,
- JVMTI_REFERENCE_SIGNERS = 5,
- JVMTI_REFERENCE_PROTECTION_DOMAIN = 6,
- JVMTI_REFERENCE_INTERFACE = 7,
- JVMTI_REFERENCE_STATIC_FIELD = 8,
- JVMTI_REFERENCE_CONSTANT_POOL = 9
-} jvmtiObjectReferenceKind;
-
- /* Iteration Control Enumeration */
-
-typedef enum {
- JVMTI_ITERATION_CONTINUE = 1,
- JVMTI_ITERATION_IGNORE = 2,
- JVMTI_ITERATION_ABORT = 0
-} jvmtiIterationControl;
-
- /* Class Status Flags */
-
-enum {
- JVMTI_CLASS_STATUS_VERIFIED = 1,
- JVMTI_CLASS_STATUS_PREPARED = 2,
- JVMTI_CLASS_STATUS_INITIALIZED = 4,
- JVMTI_CLASS_STATUS_ERROR = 8,
- JVMTI_CLASS_STATUS_ARRAY = 16,
- JVMTI_CLASS_STATUS_PRIMITIVE = 32
-};
-
- /* Event Enable/Disable */
-
-typedef enum {
- JVMTI_ENABLE = 1,
- JVMTI_DISABLE = 0
-} jvmtiEventMode;
-
- /* Extension Function/Event Parameter Types */
-
-typedef enum {
- JVMTI_TYPE_JBYTE = 101,
- JVMTI_TYPE_JCHAR = 102,
- JVMTI_TYPE_JSHORT = 103,
- JVMTI_TYPE_JINT = 104,
- JVMTI_TYPE_JLONG = 105,
- JVMTI_TYPE_JFLOAT = 106,
- JVMTI_TYPE_JDOUBLE = 107,
- JVMTI_TYPE_JBOOLEAN = 108,
- JVMTI_TYPE_JOBJECT = 109,
- JVMTI_TYPE_JTHREAD = 110,
- JVMTI_TYPE_JCLASS = 111,
- JVMTI_TYPE_JVALUE = 112,
- JVMTI_TYPE_JFIELDID = 113,
- JVMTI_TYPE_JMETHODID = 114,
- JVMTI_TYPE_CCHAR = 115,
- JVMTI_TYPE_CVOID = 116,
- JVMTI_TYPE_JNIENV = 117
-} jvmtiParamTypes;
-
- /* Extension Function/Event Parameter Kinds */
-
-typedef enum {
- JVMTI_KIND_IN = 91,
- JVMTI_KIND_IN_PTR = 92,
- JVMTI_KIND_IN_BUF = 93,
- JVMTI_KIND_ALLOC_BUF = 94,
- JVMTI_KIND_ALLOC_ALLOC_BUF = 95,
- JVMTI_KIND_OUT = 96,
- JVMTI_KIND_OUT_BUF = 97
-} jvmtiParamKind;
-
- /* Timer Kinds */
-
-typedef enum {
- JVMTI_TIMER_USER_CPU = 30,
- JVMTI_TIMER_TOTAL_CPU = 31,
- JVMTI_TIMER_ELAPSED = 32
-} jvmtiTimerKind;
-
- /* Phases of execution */
-
-typedef enum {
- JVMTI_PHASE_ONLOAD = 1,
- JVMTI_PHASE_PRIMORDIAL = 2,
- JVMTI_PHASE_START = 6,
- JVMTI_PHASE_LIVE = 4,
- JVMTI_PHASE_DEAD = 8
-} jvmtiPhase;
-
- /* Version Interface Types */
-
-enum {
- JVMTI_VERSION_INTERFACE_JNI = 0x00000000,
- JVMTI_VERSION_INTERFACE_JVMTI = 0x30000000
-};
-
- /* Version Masks */
-
-enum {
- JVMTI_VERSION_MASK_INTERFACE_TYPE = 0x70000000,
- JVMTI_VERSION_MASK_MAJOR = 0x0FFF0000,
- JVMTI_VERSION_MASK_MINOR = 0x0000FF00,
- JVMTI_VERSION_MASK_MICRO = 0x000000FF
-};
-
- /* Version Shifts */
-
-enum {
- JVMTI_VERSION_SHIFT_MAJOR = 16,
- JVMTI_VERSION_SHIFT_MINOR = 8,
- JVMTI_VERSION_SHIFT_MICRO = 0
-};
-
- /* Verbose Flag Enumeration */
-
-typedef enum {
- JVMTI_VERBOSE_OTHER = 0,
- JVMTI_VERBOSE_GC = 1,
- JVMTI_VERBOSE_CLASS = 2,
- JVMTI_VERBOSE_JNI = 4
-} jvmtiVerboseFlag;
-
- /* JLocation Format Enumeration */
-
-typedef enum {
- JVMTI_JLOCATION_JVMBCI = 1,
- JVMTI_JLOCATION_MACHINEPC = 2,
- JVMTI_JLOCATION_OTHER = 0
-} jvmtiJlocationFormat;
-
- /* Resource Exhaustion Flags */
-
-enum {
- JVMTI_RESOURCE_EXHAUSTED_OOM_ERROR = 0x0001,
- JVMTI_RESOURCE_EXHAUSTED_JAVA_HEAP = 0x0002,
- JVMTI_RESOURCE_EXHAUSTED_THREADS = 0x0004
-};
-
- /* Errors */
-
-typedef enum {
- JVMTI_ERROR_NONE = 0,
- JVMTI_ERROR_INVALID_THREAD = 10,
- JVMTI_ERROR_INVALID_THREAD_GROUP = 11,
- JVMTI_ERROR_INVALID_PRIORITY = 12,
- JVMTI_ERROR_THREAD_NOT_SUSPENDED = 13,
- JVMTI_ERROR_THREAD_SUSPENDED = 14,
- JVMTI_ERROR_THREAD_NOT_ALIVE = 15,
- JVMTI_ERROR_INVALID_OBJECT = 20,
- JVMTI_ERROR_INVALID_CLASS = 21,
- JVMTI_ERROR_CLASS_NOT_PREPARED = 22,
- JVMTI_ERROR_INVALID_METHODID = 23,
- JVMTI_ERROR_INVALID_LOCATION = 24,
- JVMTI_ERROR_INVALID_FIELDID = 25,
- JVMTI_ERROR_NO_MORE_FRAMES = 31,
- JVMTI_ERROR_OPAQUE_FRAME = 32,
- JVMTI_ERROR_TYPE_MISMATCH = 34,
- JVMTI_ERROR_INVALID_SLOT = 35,
- JVMTI_ERROR_DUPLICATE = 40,
- JVMTI_ERROR_NOT_FOUND = 41,
- JVMTI_ERROR_INVALID_MONITOR = 50,
- JVMTI_ERROR_NOT_MONITOR_OWNER = 51,
- JVMTI_ERROR_INTERRUPT = 52,
- JVMTI_ERROR_INVALID_CLASS_FORMAT = 60,
- JVMTI_ERROR_CIRCULAR_CLASS_DEFINITION = 61,
- JVMTI_ERROR_FAILS_VERIFICATION = 62,
- JVMTI_ERROR_UNSUPPORTED_REDEFINITION_METHOD_ADDED = 63,
- JVMTI_ERROR_UNSUPPORTED_REDEFINITION_SCHEMA_CHANGED = 64,
- JVMTI_ERROR_INVALID_TYPESTATE = 65,
- JVMTI_ERROR_UNSUPPORTED_REDEFINITION_HIERARCHY_CHANGED = 66,
- JVMTI_ERROR_UNSUPPORTED_REDEFINITION_METHOD_DELETED = 67,
- JVMTI_ERROR_UNSUPPORTED_VERSION = 68,
- JVMTI_ERROR_NAMES_DONT_MATCH = 69,
- JVMTI_ERROR_UNSUPPORTED_REDEFINITION_CLASS_MODIFIERS_CHANGED = 70,
- JVMTI_ERROR_UNSUPPORTED_REDEFINITION_METHOD_MODIFIERS_CHANGED = 71,
- JVMTI_ERROR_UNMODIFIABLE_CLASS = 79,
- JVMTI_ERROR_NOT_AVAILABLE = 98,
- JVMTI_ERROR_MUST_POSSESS_CAPABILITY = 99,
- JVMTI_ERROR_NULL_POINTER = 100,
- JVMTI_ERROR_ABSENT_INFORMATION = 101,
- JVMTI_ERROR_INVALID_EVENT_TYPE = 102,
- JVMTI_ERROR_ILLEGAL_ARGUMENT = 103,
- JVMTI_ERROR_NATIVE_METHOD = 104,
- JVMTI_ERROR_CLASS_LOADER_UNSUPPORTED = 106,
- JVMTI_ERROR_OUT_OF_MEMORY = 110,
- JVMTI_ERROR_ACCESS_DENIED = 111,
- JVMTI_ERROR_WRONG_PHASE = 112,
- JVMTI_ERROR_INTERNAL = 113,
- JVMTI_ERROR_UNATTACHED_THREAD = 115,
- JVMTI_ERROR_INVALID_ENVIRONMENT = 116,
- JVMTI_ERROR_MAX = 116
-} jvmtiError;
-
- /* Event IDs */
-
-typedef enum {
- JVMTI_MIN_EVENT_TYPE_VAL = 50,
- JVMTI_EVENT_VM_INIT = 50,
- JVMTI_EVENT_VM_DEATH = 51,
- JVMTI_EVENT_THREAD_START = 52,
- JVMTI_EVENT_THREAD_END = 53,
- JVMTI_EVENT_CLASS_FILE_LOAD_HOOK = 54,
- JVMTI_EVENT_CLASS_LOAD = 55,
- JVMTI_EVENT_CLASS_PREPARE = 56,
- JVMTI_EVENT_VM_START = 57,
- JVMTI_EVENT_EXCEPTION = 58,
- JVMTI_EVENT_EXCEPTION_CATCH = 59,
- JVMTI_EVENT_SINGLE_STEP = 60,
- JVMTI_EVENT_FRAME_POP = 61,
- JVMTI_EVENT_BREAKPOINT = 62,
- JVMTI_EVENT_FIELD_ACCESS = 63,
- JVMTI_EVENT_FIELD_MODIFICATION = 64,
- JVMTI_EVENT_METHOD_ENTRY = 65,
- JVMTI_EVENT_METHOD_EXIT = 66,
- JVMTI_EVENT_NATIVE_METHOD_BIND = 67,
- JVMTI_EVENT_COMPILED_METHOD_LOAD = 68,
- JVMTI_EVENT_COMPILED_METHOD_UNLOAD = 69,
- JVMTI_EVENT_DYNAMIC_CODE_GENERATED = 70,
- JVMTI_EVENT_DATA_DUMP_REQUEST = 71,
- JVMTI_EVENT_MONITOR_WAIT = 73,
- JVMTI_EVENT_MONITOR_WAITED = 74,
- JVMTI_EVENT_MONITOR_CONTENDED_ENTER = 75,
- JVMTI_EVENT_MONITOR_CONTENDED_ENTERED = 76,
- JVMTI_EVENT_RESOURCE_EXHAUSTED = 80,
- JVMTI_EVENT_GARBAGE_COLLECTION_START = 81,
- JVMTI_EVENT_GARBAGE_COLLECTION_FINISH = 82,
- JVMTI_EVENT_OBJECT_FREE = 83,
- JVMTI_EVENT_VM_OBJECT_ALLOC = 84,
- JVMTI_MAX_EVENT_TYPE_VAL = 84
-} jvmtiEvent;
-
-
- /* Pre-Declarations */
-struct _jvmtiThreadInfo;
-typedef struct _jvmtiThreadInfo jvmtiThreadInfo;
-struct _jvmtiMonitorStackDepthInfo;
-typedef struct _jvmtiMonitorStackDepthInfo jvmtiMonitorStackDepthInfo;
-struct _jvmtiThreadGroupInfo;
-typedef struct _jvmtiThreadGroupInfo jvmtiThreadGroupInfo;
-struct _jvmtiFrameInfo;
-typedef struct _jvmtiFrameInfo jvmtiFrameInfo;
-struct _jvmtiStackInfo;
-typedef struct _jvmtiStackInfo jvmtiStackInfo;
-struct _jvmtiHeapReferenceInfoField;
-typedef struct _jvmtiHeapReferenceInfoField jvmtiHeapReferenceInfoField;
-struct _jvmtiHeapReferenceInfoArray;
-typedef struct _jvmtiHeapReferenceInfoArray jvmtiHeapReferenceInfoArray;
-struct _jvmtiHeapReferenceInfoConstantPool;
-typedef struct _jvmtiHeapReferenceInfoConstantPool jvmtiHeapReferenceInfoConstantPool;
-struct _jvmtiHeapReferenceInfoStackLocal;
-typedef struct _jvmtiHeapReferenceInfoStackLocal jvmtiHeapReferenceInfoStackLocal;
-struct _jvmtiHeapReferenceInfoJniLocal;
-typedef struct _jvmtiHeapReferenceInfoJniLocal jvmtiHeapReferenceInfoJniLocal;
-struct _jvmtiHeapReferenceInfoReserved;
-typedef struct _jvmtiHeapReferenceInfoReserved jvmtiHeapReferenceInfoReserved;
-union _jvmtiHeapReferenceInfo;
-typedef union _jvmtiHeapReferenceInfo jvmtiHeapReferenceInfo;
-struct _jvmtiHeapCallbacks;
-typedef struct _jvmtiHeapCallbacks jvmtiHeapCallbacks;
-struct _jvmtiClassDefinition;
-typedef struct _jvmtiClassDefinition jvmtiClassDefinition;
-struct _jvmtiMonitorUsage;
-typedef struct _jvmtiMonitorUsage jvmtiMonitorUsage;
-struct _jvmtiLineNumberEntry;
-typedef struct _jvmtiLineNumberEntry jvmtiLineNumberEntry;
-struct _jvmtiLocalVariableEntry;
-typedef struct _jvmtiLocalVariableEntry jvmtiLocalVariableEntry;
-struct _jvmtiParamInfo;
-typedef struct _jvmtiParamInfo jvmtiParamInfo;
-struct _jvmtiExtensionFunctionInfo;
-typedef struct _jvmtiExtensionFunctionInfo jvmtiExtensionFunctionInfo;
-struct _jvmtiExtensionEventInfo;
-typedef struct _jvmtiExtensionEventInfo jvmtiExtensionEventInfo;
-struct _jvmtiTimerInfo;
-typedef struct _jvmtiTimerInfo jvmtiTimerInfo;
-struct _jvmtiAddrLocationMap;
-typedef struct _jvmtiAddrLocationMap jvmtiAddrLocationMap;
-
- /* Function Types */
-
-typedef void (JNICALL *jvmtiStartFunction)
- (jvmtiEnv* jvmti_env, JNIEnv* jni_env, void* arg);
-
-typedef jint (JNICALL *jvmtiHeapIterationCallback)
- (jlong class_tag, jlong size, jlong* tag_ptr, jint length, void* user_data);
-
-typedef jint (JNICALL *jvmtiHeapReferenceCallback)
- (jvmtiHeapReferenceKind reference_kind, const jvmtiHeapReferenceInfo* reference_info, jlong class_tag, jlong referrer_class_tag, jlong size, jlong* tag_ptr, jlong* referrer_tag_ptr, jint length, void* user_data);
-
-typedef jint (JNICALL *jvmtiPrimitiveFieldCallback)
- (jvmtiHeapReferenceKind kind, const jvmtiHeapReferenceInfo* info, jlong object_class_tag, jlong* object_tag_ptr, jvalue value, jvmtiPrimitiveType value_type, void* user_data);
-
-typedef jint (JNICALL *jvmtiArrayPrimitiveValueCallback)
- (jlong class_tag, jlong size, jlong* tag_ptr, jint element_count, jvmtiPrimitiveType element_type, const void* elements, void* user_data);
-
-typedef jint (JNICALL *jvmtiStringPrimitiveValueCallback)
- (jlong class_tag, jlong size, jlong* tag_ptr, const jchar* value, jint value_length, void* user_data);
-
-typedef jint (JNICALL *jvmtiReservedCallback)
- ();
-
-typedef jvmtiIterationControl (JNICALL *jvmtiHeapObjectCallback)
- (jlong class_tag, jlong size, jlong* tag_ptr, void* user_data);
-
-typedef jvmtiIterationControl (JNICALL *jvmtiHeapRootCallback)
- (jvmtiHeapRootKind root_kind, jlong class_tag, jlong size, jlong* tag_ptr, void* user_data);
-
-typedef jvmtiIterationControl (JNICALL *jvmtiStackReferenceCallback)
- (jvmtiHeapRootKind root_kind, jlong class_tag, jlong size, jlong* tag_ptr, jlong thread_tag, jint depth, jmethodID method, jint slot, void* user_data);
-
-typedef jvmtiIterationControl (JNICALL *jvmtiObjectReferenceCallback)
- (jvmtiObjectReferenceKind reference_kind, jlong class_tag, jlong size, jlong* tag_ptr, jlong referrer_tag, jint referrer_index, void* user_data);
-
-typedef jvmtiError (JNICALL *jvmtiExtensionFunction)
- (jvmtiEnv* jvmti_env, ...);
-
-typedef void (JNICALL *jvmtiExtensionEvent)
- (jvmtiEnv* jvmti_env, ...);
-
-
- /* Structure Types */
-struct _jvmtiThreadInfo {
- char* name;
- jint priority;
- jboolean is_daemon;
- jthreadGroup thread_group;
- jobject context_class_loader;
-};
-struct _jvmtiMonitorStackDepthInfo {
- jobject monitor;
- jint stack_depth;
-};
-struct _jvmtiThreadGroupInfo {
- jthreadGroup parent;
- char* name;
- jint max_priority;
- jboolean is_daemon;
-};
-struct _jvmtiFrameInfo {
- jmethodID method;
- jlocation location;
-};
-struct _jvmtiStackInfo {
- jthread thread;
- jint state;
- jvmtiFrameInfo* frame_buffer;
- jint frame_count;
-};
-struct _jvmtiHeapReferenceInfoField {
- jint index;
-};
-struct _jvmtiHeapReferenceInfoArray {
- jint index;
-};
-struct _jvmtiHeapReferenceInfoConstantPool {
- jint index;
-};
-struct _jvmtiHeapReferenceInfoStackLocal {
- jlong thread_tag;
- jlong thread_id;
- jint depth;
- jmethodID method;
- jlocation location;
- jint slot;
-};
-struct _jvmtiHeapReferenceInfoJniLocal {
- jlong thread_tag;
- jlong thread_id;
- jint depth;
- jmethodID method;
-};
-struct _jvmtiHeapReferenceInfoReserved {
- jlong reserved1;
- jlong reserved2;
- jlong reserved3;
- jlong reserved4;
- jlong reserved5;
- jlong reserved6;
- jlong reserved7;
- jlong reserved8;
-};
-union _jvmtiHeapReferenceInfo {
- jvmtiHeapReferenceInfoField field;
- jvmtiHeapReferenceInfoArray array;
- jvmtiHeapReferenceInfoConstantPool constant_pool;
- jvmtiHeapReferenceInfoStackLocal stack_local;
- jvmtiHeapReferenceInfoJniLocal jni_local;
- jvmtiHeapReferenceInfoReserved other;
-};
-struct _jvmtiHeapCallbacks {
- jvmtiHeapIterationCallback heap_iteration_callback;
- jvmtiHeapReferenceCallback heap_reference_callback;
- jvmtiPrimitiveFieldCallback primitive_field_callback;
- jvmtiArrayPrimitiveValueCallback array_primitive_value_callback;
- jvmtiStringPrimitiveValueCallback string_primitive_value_callback;
- jvmtiReservedCallback reserved5;
- jvmtiReservedCallback reserved6;
- jvmtiReservedCallback reserved7;
- jvmtiReservedCallback reserved8;
- jvmtiReservedCallback reserved9;
- jvmtiReservedCallback reserved10;
- jvmtiReservedCallback reserved11;
- jvmtiReservedCallback reserved12;
- jvmtiReservedCallback reserved13;
- jvmtiReservedCallback reserved14;
- jvmtiReservedCallback reserved15;
-};
-struct _jvmtiClassDefinition {
- jclass klass;
- jint class_byte_count;
- const unsigned char* class_bytes;
-};
-struct _jvmtiMonitorUsage {
- jthread owner;
- jint entry_count;
- jint waiter_count;
- jthread* waiters;
- jint notify_waiter_count;
- jthread* notify_waiters;
-};
-struct _jvmtiLineNumberEntry {
- jlocation start_location;
- jint line_number;
-};
-struct _jvmtiLocalVariableEntry {
- jlocation start_location;
- jint length;
- char* name;
- char* signature;
- char* generic_signature;
- jint slot;
-};
-struct _jvmtiParamInfo {
- char* name;
- jvmtiParamKind kind;
- jvmtiParamTypes base_type;
- jboolean null_ok;
-};
-struct _jvmtiExtensionFunctionInfo {
- jvmtiExtensionFunction func;
- char* id;
- char* short_description;
- jint param_count;
- jvmtiParamInfo* params;
- jint error_count;
- jvmtiError* errors;
-};
-struct _jvmtiExtensionEventInfo {
- jint extension_event_index;
- char* id;
- char* short_description;
- jint param_count;
- jvmtiParamInfo* params;
-};
-struct _jvmtiTimerInfo {
- jlong max_value;
- jboolean may_skip_forward;
- jboolean may_skip_backward;
- jvmtiTimerKind kind;
- jlong reserved1;
- jlong reserved2;
-};
-struct _jvmtiAddrLocationMap {
- const void* start_address;
- jlocation location;
-};
-
-typedef struct {
- unsigned int can_tag_objects : 1;
- unsigned int can_generate_field_modification_events : 1;
- unsigned int can_generate_field_access_events : 1;
- unsigned int can_get_bytecodes : 1;
- unsigned int can_get_synthetic_attribute : 1;
- unsigned int can_get_owned_monitor_info : 1;
- unsigned int can_get_current_contended_monitor : 1;
- unsigned int can_get_monitor_info : 1;
- unsigned int can_pop_frame : 1;
- unsigned int can_redefine_classes : 1;
- unsigned int can_signal_thread : 1;
- unsigned int can_get_source_file_name : 1;
- unsigned int can_get_line_numbers : 1;
- unsigned int can_get_source_debug_extension : 1;
- unsigned int can_access_local_variables : 1;
- unsigned int can_maintain_original_method_order : 1;
- unsigned int can_generate_single_step_events : 1;
- unsigned int can_generate_exception_events : 1;
- unsigned int can_generate_frame_pop_events : 1;
- unsigned int can_generate_breakpoint_events : 1;
- unsigned int can_suspend : 1;
- unsigned int can_redefine_any_class : 1;
- unsigned int can_get_current_thread_cpu_time : 1;
- unsigned int can_get_thread_cpu_time : 1;
- unsigned int can_generate_method_entry_events : 1;
- unsigned int can_generate_method_exit_events : 1;
- unsigned int can_generate_all_class_hook_events : 1;
- unsigned int can_generate_compiled_method_load_events : 1;
- unsigned int can_generate_monitor_events : 1;
- unsigned int can_generate_vm_object_alloc_events : 1;
- unsigned int can_generate_native_method_bind_events : 1;
- unsigned int can_generate_garbage_collection_events : 1;
- unsigned int can_generate_object_free_events : 1;
- unsigned int can_force_early_return : 1;
- unsigned int can_get_owned_monitor_stack_depth_info : 1;
- unsigned int can_get_constant_pool : 1;
- unsigned int can_set_native_method_prefix : 1;
- unsigned int can_retransform_classes : 1;
- unsigned int can_retransform_any_class : 1;
- unsigned int can_generate_resource_exhaustion_heap_events : 1;
- unsigned int can_generate_resource_exhaustion_threads_events : 1;
- unsigned int : 7;
- unsigned int : 16;
- unsigned int : 16;
- unsigned int : 16;
- unsigned int : 16;
- unsigned int : 16;
-} jvmtiCapabilities;
-
-
- /* Event Definitions */
-
-typedef void (JNICALL *jvmtiEventReserved)(void);
-
-
-typedef void (JNICALL *jvmtiEventBreakpoint)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jmethodID method,
- jlocation location);
-
-typedef void (JNICALL *jvmtiEventClassFileLoadHook)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jclass class_being_redefined,
- jobject loader,
- const char* name,
- jobject protection_domain,
- jint class_data_len,
- const unsigned char* class_data,
- jint* new_class_data_len,
- unsigned char** new_class_data);
-
-typedef void (JNICALL *jvmtiEventClassLoad)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jclass klass);
-
-typedef void (JNICALL *jvmtiEventClassPrepare)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jclass klass);
-
-typedef void (JNICALL *jvmtiEventCompiledMethodLoad)
- (jvmtiEnv *jvmti_env,
- jmethodID method,
- jint code_size,
- const void* code_addr,
- jint map_length,
- const jvmtiAddrLocationMap* map,
- const void* compile_info);
-
-typedef void (JNICALL *jvmtiEventCompiledMethodUnload)
- (jvmtiEnv *jvmti_env,
- jmethodID method,
- const void* code_addr);
-
-typedef void (JNICALL *jvmtiEventDataDumpRequest)
- (jvmtiEnv *jvmti_env);
-
-typedef void (JNICALL *jvmtiEventDynamicCodeGenerated)
- (jvmtiEnv *jvmti_env,
- const char* name,
- const void* address,
- jint length);
-
-typedef void (JNICALL *jvmtiEventException)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jmethodID method,
- jlocation location,
- jobject exception,
- jmethodID catch_method,
- jlocation catch_location);
-
-typedef void (JNICALL *jvmtiEventExceptionCatch)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jmethodID method,
- jlocation location,
- jobject exception);
-
-typedef void (JNICALL *jvmtiEventFieldAccess)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jmethodID method,
- jlocation location,
- jclass field_klass,
- jobject object,
- jfieldID field);
-
-typedef void (JNICALL *jvmtiEventFieldModification)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jmethodID method,
- jlocation location,
- jclass field_klass,
- jobject object,
- jfieldID field,
- char signature_type,
- jvalue new_value);
-
-typedef void (JNICALL *jvmtiEventFramePop)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jmethodID method,
- jboolean was_popped_by_exception);
-
-typedef void (JNICALL *jvmtiEventGarbageCollectionFinish)
- (jvmtiEnv *jvmti_env);
-
-typedef void (JNICALL *jvmtiEventGarbageCollectionStart)
- (jvmtiEnv *jvmti_env);
-
-typedef void (JNICALL *jvmtiEventMethodEntry)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jmethodID method);
-
-typedef void (JNICALL *jvmtiEventMethodExit)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jmethodID method,
- jboolean was_popped_by_exception,
- jvalue return_value);
-
-typedef void (JNICALL *jvmtiEventMonitorContendedEnter)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jobject object);
-
-typedef void (JNICALL *jvmtiEventMonitorContendedEntered)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jobject object);
-
-typedef void (JNICALL *jvmtiEventMonitorWait)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jobject object,
- jlong timeout);
-
-typedef void (JNICALL *jvmtiEventMonitorWaited)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jobject object,
- jboolean timed_out);
-
-typedef void (JNICALL *jvmtiEventNativeMethodBind)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jmethodID method,
- void* address,
- void** new_address_ptr);
-
-typedef void (JNICALL *jvmtiEventObjectFree)
- (jvmtiEnv *jvmti_env,
- jlong tag);
-
-typedef void (JNICALL *jvmtiEventResourceExhausted)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jint flags,
- const void* reserved,
- const char* description);
-
-typedef void (JNICALL *jvmtiEventSingleStep)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jmethodID method,
- jlocation location);
-
-typedef void (JNICALL *jvmtiEventThreadEnd)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread);
-
-typedef void (JNICALL *jvmtiEventThreadStart)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread);
-
-typedef void (JNICALL *jvmtiEventVMDeath)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env);
-
-typedef void (JNICALL *jvmtiEventVMInit)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread);
-
-typedef void (JNICALL *jvmtiEventVMObjectAlloc)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env,
- jthread thread,
- jobject object,
- jclass object_klass,
- jlong size);
-
-typedef void (JNICALL *jvmtiEventVMStart)
- (jvmtiEnv *jvmti_env,
- JNIEnv* jni_env);
-
- /* Event Callback Structure */
-
-typedef struct {
- /* 50 : VM Initialization Event */
- jvmtiEventVMInit VMInit;
- /* 51 : VM Death Event */
- jvmtiEventVMDeath VMDeath;
- /* 52 : Thread Start */
- jvmtiEventThreadStart ThreadStart;
- /* 53 : Thread End */
- jvmtiEventThreadEnd ThreadEnd;
- /* 54 : Class File Load Hook */
- jvmtiEventClassFileLoadHook ClassFileLoadHook;
- /* 55 : Class Load */
- jvmtiEventClassLoad ClassLoad;
- /* 56 : Class Prepare */
- jvmtiEventClassPrepare ClassPrepare;
- /* 57 : VM Start Event */
- jvmtiEventVMStart VMStart;
- /* 58 : Exception */
- jvmtiEventException Exception;
- /* 59 : Exception Catch */
- jvmtiEventExceptionCatch ExceptionCatch;
- /* 60 : Single Step */
- jvmtiEventSingleStep SingleStep;
- /* 61 : Frame Pop */
- jvmtiEventFramePop FramePop;
- /* 62 : Breakpoint */
- jvmtiEventBreakpoint Breakpoint;
- /* 63 : Field Access */
- jvmtiEventFieldAccess FieldAccess;
- /* 64 : Field Modification */
- jvmtiEventFieldModification FieldModification;
- /* 65 : Method Entry */
- jvmtiEventMethodEntry MethodEntry;
- /* 66 : Method Exit */
- jvmtiEventMethodExit MethodExit;
- /* 67 : Native Method Bind */
- jvmtiEventNativeMethodBind NativeMethodBind;
- /* 68 : Compiled Method Load */
- jvmtiEventCompiledMethodLoad CompiledMethodLoad;
- /* 69 : Compiled Method Unload */
- jvmtiEventCompiledMethodUnload CompiledMethodUnload;
- /* 70 : Dynamic Code Generated */
- jvmtiEventDynamicCodeGenerated DynamicCodeGenerated;
- /* 71 : Data Dump Request */
- jvmtiEventDataDumpRequest DataDumpRequest;
- /* 72 */
- jvmtiEventReserved reserved72;
- /* 73 : Monitor Wait */
- jvmtiEventMonitorWait MonitorWait;
- /* 74 : Monitor Waited */
- jvmtiEventMonitorWaited MonitorWaited;
- /* 75 : Monitor Contended Enter */
- jvmtiEventMonitorContendedEnter MonitorContendedEnter;
- /* 76 : Monitor Contended Entered */
- jvmtiEventMonitorContendedEntered MonitorContendedEntered;
- /* 77 */
- jvmtiEventReserved reserved77;
- /* 78 */
- jvmtiEventReserved reserved78;
- /* 79 */
- jvmtiEventReserved reserved79;
- /* 80 : Resource Exhausted */
- jvmtiEventResourceExhausted ResourceExhausted;
- /* 81 : Garbage Collection Start */
- jvmtiEventGarbageCollectionStart GarbageCollectionStart;
- /* 82 : Garbage Collection Finish */
- jvmtiEventGarbageCollectionFinish GarbageCollectionFinish;
- /* 83 : Object Free */
- jvmtiEventObjectFree ObjectFree;
- /* 84 : VM Object Allocation */
- jvmtiEventVMObjectAlloc VMObjectAlloc;
-} jvmtiEventCallbacks;
-
-
- /* Function Interface */
-
-typedef struct jvmtiInterface_1_ {
-
- /* 1 : RESERVED */
- void *reserved1;
-
- /* 2 : Set Event Notification Mode */
- jvmtiError (JNICALL *SetEventNotificationMode) (jvmtiEnv* env,
- jvmtiEventMode mode,
- jvmtiEvent event_type,
- jthread event_thread,
- ...);
-
- /* 3 : RESERVED */
- void *reserved3;
-
- /* 4 : Get All Threads */
- jvmtiError (JNICALL *GetAllThreads) (jvmtiEnv* env,
- jint* threads_count_ptr,
- jthread** threads_ptr);
-
- /* 5 : Suspend Thread */
- jvmtiError (JNICALL *SuspendThread) (jvmtiEnv* env,
- jthread thread);
-
- /* 6 : Resume Thread */
- jvmtiError (JNICALL *ResumeThread) (jvmtiEnv* env,
- jthread thread);
-
- /* 7 : Stop Thread */
- jvmtiError (JNICALL *StopThread) (jvmtiEnv* env,
- jthread thread,
- jobject exception);
-
- /* 8 : Interrupt Thread */
- jvmtiError (JNICALL *InterruptThread) (jvmtiEnv* env,
- jthread thread);
-
- /* 9 : Get Thread Info */
- jvmtiError (JNICALL *GetThreadInfo) (jvmtiEnv* env,
- jthread thread,
- jvmtiThreadInfo* info_ptr);
-
- /* 10 : Get Owned Monitor Info */
- jvmtiError (JNICALL *GetOwnedMonitorInfo) (jvmtiEnv* env,
- jthread thread,
- jint* owned_monitor_count_ptr,
- jobject** owned_monitors_ptr);
-
- /* 11 : Get Current Contended Monitor */
- jvmtiError (JNICALL *GetCurrentContendedMonitor) (jvmtiEnv* env,
- jthread thread,
- jobject* monitor_ptr);
-
- /* 12 : Run Agent Thread */
- jvmtiError (JNICALL *RunAgentThread) (jvmtiEnv* env,
- jthread thread,
- jvmtiStartFunction proc,
- const void* arg,
- jint priority);
-
- /* 13 : Get Top Thread Groups */
- jvmtiError (JNICALL *GetTopThreadGroups) (jvmtiEnv* env,
- jint* group_count_ptr,
- jthreadGroup** groups_ptr);
-
- /* 14 : Get Thread Group Info */
- jvmtiError (JNICALL *GetThreadGroupInfo) (jvmtiEnv* env,
- jthreadGroup group,
- jvmtiThreadGroupInfo* info_ptr);
-
- /* 15 : Get Thread Group Children */
- jvmtiError (JNICALL *GetThreadGroupChildren) (jvmtiEnv* env,
- jthreadGroup group,
- jint* thread_count_ptr,
- jthread** threads_ptr,
- jint* group_count_ptr,
- jthreadGroup** groups_ptr);
-
- /* 16 : Get Frame Count */
- jvmtiError (JNICALL *GetFrameCount) (jvmtiEnv* env,
- jthread thread,
- jint* count_ptr);
-
- /* 17 : Get Thread State */
- jvmtiError (JNICALL *GetThreadState) (jvmtiEnv* env,
- jthread thread,
- jint* thread_state_ptr);
-
- /* 18 : Get Current Thread */
- jvmtiError (JNICALL *GetCurrentThread) (jvmtiEnv* env,
- jthread* thread_ptr);
-
- /* 19 : Get Frame Location */
- jvmtiError (JNICALL *GetFrameLocation) (jvmtiEnv* env,
- jthread thread,
- jint depth,
- jmethodID* method_ptr,
- jlocation* location_ptr);
-
- /* 20 : Notify Frame Pop */
- jvmtiError (JNICALL *NotifyFramePop) (jvmtiEnv* env,
- jthread thread,
- jint depth);
-
- /* 21 : Get Local Variable - Object */
- jvmtiError (JNICALL *GetLocalObject) (jvmtiEnv* env,
- jthread thread,
- jint depth,
- jint slot,
- jobject* value_ptr);
-
- /* 22 : Get Local Variable - Int */
- jvmtiError (JNICALL *GetLocalInt) (jvmtiEnv* env,
- jthread thread,
- jint depth,
- jint slot,
- jint* value_ptr);
-
- /* 23 : Get Local Variable - Long */
- jvmtiError (JNICALL *GetLocalLong) (jvmtiEnv* env,
- jthread thread,
- jint depth,
- jint slot,
- jlong* value_ptr);
-
- /* 24 : Get Local Variable - Float */
- jvmtiError (JNICALL *GetLocalFloat) (jvmtiEnv* env,
- jthread thread,
- jint depth,
- jint slot,
- jfloat* value_ptr);
-
- /* 25 : Get Local Variable - Double */
- jvmtiError (JNICALL *GetLocalDouble) (jvmtiEnv* env,
- jthread thread,
- jint depth,
- jint slot,
- jdouble* value_ptr);
-
- /* 26 : Set Local Variable - Object */
- jvmtiError (JNICALL *SetLocalObject) (jvmtiEnv* env,
- jthread thread,
- jint depth,
- jint slot,
- jobject value);
-
- /* 27 : Set Local Variable - Int */
- jvmtiError (JNICALL *SetLocalInt) (jvmtiEnv* env,
- jthread thread,
- jint depth,
- jint slot,
- jint value);
-
- /* 28 : Set Local Variable - Long */
- jvmtiError (JNICALL *SetLocalLong) (jvmtiEnv* env,
- jthread thread,
- jint depth,
- jint slot,
- jlong value);
-
- /* 29 : Set Local Variable - Float */
- jvmtiError (JNICALL *SetLocalFloat) (jvmtiEnv* env,
- jthread thread,
- jint depth,
- jint slot,
- jfloat value);
-
- /* 30 : Set Local Variable - Double */
- jvmtiError (JNICALL *SetLocalDouble) (jvmtiEnv* env,
- jthread thread,
- jint depth,
- jint slot,
- jdouble value);
-
- /* 31 : Create Raw Monitor */
- jvmtiError (JNICALL *CreateRawMonitor) (jvmtiEnv* env,
- const char* name,
- jrawMonitorID* monitor_ptr);
-
- /* 32 : Destroy Raw Monitor */
- jvmtiError (JNICALL *DestroyRawMonitor) (jvmtiEnv* env,
- jrawMonitorID monitor);
-
- /* 33 : Raw Monitor Enter */
- jvmtiError (JNICALL *RawMonitorEnter) (jvmtiEnv* env,
- jrawMonitorID monitor);
-
- /* 34 : Raw Monitor Exit */
- jvmtiError (JNICALL *RawMonitorExit) (jvmtiEnv* env,
- jrawMonitorID monitor);
-
- /* 35 : Raw Monitor Wait */
- jvmtiError (JNICALL *RawMonitorWait) (jvmtiEnv* env,
- jrawMonitorID monitor,
- jlong millis);
-
- /* 36 : Raw Monitor Notify */
- jvmtiError (JNICALL *RawMonitorNotify) (jvmtiEnv* env,
- jrawMonitorID monitor);
-
- /* 37 : Raw Monitor Notify All */
- jvmtiError (JNICALL *RawMonitorNotifyAll) (jvmtiEnv* env,
- jrawMonitorID monitor);
-
- /* 38 : Set Breakpoint */
- jvmtiError (JNICALL *SetBreakpoint) (jvmtiEnv* env,
- jmethodID method,
- jlocation location);
-
- /* 39 : Clear Breakpoint */
- jvmtiError (JNICALL *ClearBreakpoint) (jvmtiEnv* env,
- jmethodID method,
- jlocation location);
-
- /* 40 : RESERVED */
- void *reserved40;
-
- /* 41 : Set Field Access Watch */
- jvmtiError (JNICALL *SetFieldAccessWatch) (jvmtiEnv* env,
- jclass klass,
- jfieldID field);
-
- /* 42 : Clear Field Access Watch */
- jvmtiError (JNICALL *ClearFieldAccessWatch) (jvmtiEnv* env,
- jclass klass,
- jfieldID field);
-
- /* 43 : Set Field Modification Watch */
- jvmtiError (JNICALL *SetFieldModificationWatch) (jvmtiEnv* env,
- jclass klass,
- jfieldID field);
-
- /* 44 : Clear Field Modification Watch */
- jvmtiError (JNICALL *ClearFieldModificationWatch) (jvmtiEnv* env,
- jclass klass,
- jfieldID field);
-
- /* 45 : Is Modifiable Class */
- jvmtiError (JNICALL *IsModifiableClass) (jvmtiEnv* env,
- jclass klass,
- jboolean* is_modifiable_class_ptr);
-
- /* 46 : Allocate */
- jvmtiError (JNICALL *Allocate) (jvmtiEnv* env,
- jlong size,
- unsigned char** mem_ptr);
-
- /* 47 : Deallocate */
- jvmtiError (JNICALL *Deallocate) (jvmtiEnv* env,
- unsigned char* mem);
-
- /* 48 : Get Class Signature */
- jvmtiError (JNICALL *GetClassSignature) (jvmtiEnv* env,
- jclass klass,
- char** signature_ptr,
- char** generic_ptr);
-
- /* 49 : Get Class Status */
- jvmtiError (JNICALL *GetClassStatus) (jvmtiEnv* env,
- jclass klass,
- jint* status_ptr);
-
- /* 50 : Get Source File Name */
- jvmtiError (JNICALL *GetSourceFileName) (jvmtiEnv* env,
- jclass klass,
- char** source_name_ptr);
-
- /* 51 : Get Class Modifiers */
- jvmtiError (JNICALL *GetClassModifiers) (jvmtiEnv* env,
- jclass klass,
- jint* modifiers_ptr);
-
- /* 52 : Get Class Methods */
- jvmtiError (JNICALL *GetClassMethods) (jvmtiEnv* env,
- jclass klass,
- jint* method_count_ptr,
- jmethodID** methods_ptr);
-
- /* 53 : Get Class Fields */
- jvmtiError (JNICALL *GetClassFields) (jvmtiEnv* env,
- jclass klass,
- jint* field_count_ptr,
- jfieldID** fields_ptr);
-
- /* 54 : Get Implemented Interfaces */
- jvmtiError (JNICALL *GetImplementedInterfaces) (jvmtiEnv* env,
- jclass klass,
- jint* interface_count_ptr,
- jclass** interfaces_ptr);
-
- /* 55 : Is Interface */
- jvmtiError (JNICALL *IsInterface) (jvmtiEnv* env,
- jclass klass,
- jboolean* is_interface_ptr);
-
- /* 56 : Is Array Class */
- jvmtiError (JNICALL *IsArrayClass) (jvmtiEnv* env,
- jclass klass,
- jboolean* is_array_class_ptr);
-
- /* 57 : Get Class Loader */
- jvmtiError (JNICALL *GetClassLoader) (jvmtiEnv* env,
- jclass klass,
- jobject* classloader_ptr);
-
- /* 58 : Get Object Hash Code */
- jvmtiError (JNICALL *GetObjectHashCode) (jvmtiEnv* env,
- jobject object,
- jint* hash_code_ptr);
-
- /* 59 : Get Object Monitor Usage */
- jvmtiError (JNICALL *GetObjectMonitorUsage) (jvmtiEnv* env,
- jobject object,
- jvmtiMonitorUsage* info_ptr);
-
- /* 60 : Get Field Name (and Signature) */
- jvmtiError (JNICALL *GetFieldName) (jvmtiEnv* env,
- jclass klass,
- jfieldID field,
- char** name_ptr,
- char** signature_ptr,
- char** generic_ptr);
-
- /* 61 : Get Field Declaring Class */
- jvmtiError (JNICALL *GetFieldDeclaringClass) (jvmtiEnv* env,
- jclass klass,
- jfieldID field,
- jclass* declaring_class_ptr);
-
- /* 62 : Get Field Modifiers */
- jvmtiError (JNICALL *GetFieldModifiers) (jvmtiEnv* env,
- jclass klass,
- jfieldID field,
- jint* modifiers_ptr);
-
- /* 63 : Is Field Synthetic */
- jvmtiError (JNICALL *IsFieldSynthetic) (jvmtiEnv* env,
- jclass klass,
- jfieldID field,
- jboolean* is_synthetic_ptr);
-
- /* 64 : Get Method Name (and Signature) */
- jvmtiError (JNICALL *GetMethodName) (jvmtiEnv* env,
- jmethodID method,
- char** name_ptr,
- char** signature_ptr,
- char** generic_ptr);
-
- /* 65 : Get Method Declaring Class */
- jvmtiError (JNICALL *GetMethodDeclaringClass) (jvmtiEnv* env,
- jmethodID method,
- jclass* declaring_class_ptr);
-
- /* 66 : Get Method Modifiers */
- jvmtiError (JNICALL *GetMethodModifiers) (jvmtiEnv* env,
- jmethodID method,
- jint* modifiers_ptr);
-
- /* 67 : RESERVED */
- void *reserved67;
-
- /* 68 : Get Max Locals */
- jvmtiError (JNICALL *GetMaxLocals) (jvmtiEnv* env,
- jmethodID method,
- jint* max_ptr);
-
- /* 69 : Get Arguments Size */
- jvmtiError (JNICALL *GetArgumentsSize) (jvmtiEnv* env,
- jmethodID method,
- jint* size_ptr);
-
- /* 70 : Get Line Number Table */
- jvmtiError (JNICALL *GetLineNumberTable) (jvmtiEnv* env,
- jmethodID method,
- jint* entry_count_ptr,
- jvmtiLineNumberEntry** table_ptr);
-
- /* 71 : Get Method Location */
- jvmtiError (JNICALL *GetMethodLocation) (jvmtiEnv* env,
- jmethodID method,
- jlocation* start_location_ptr,
- jlocation* end_location_ptr);
-
- /* 72 : Get Local Variable Table */
- jvmtiError (JNICALL *GetLocalVariableTable) (jvmtiEnv* env,
- jmethodID method,
- jint* entry_count_ptr,
- jvmtiLocalVariableEntry** table_ptr);
-
- /* 73 : Set Native Method Prefix */
- jvmtiError (JNICALL *SetNativeMethodPrefix) (jvmtiEnv* env,
- const char* prefix);
-
- /* 74 : Set Native Method Prefixes */
- jvmtiError (JNICALL *SetNativeMethodPrefixes) (jvmtiEnv* env,
- jint prefix_count,
- char** prefixes);
-
- /* 75 : Get Bytecodes */
- jvmtiError (JNICALL *GetBytecodes) (jvmtiEnv* env,
- jmethodID method,
- jint* bytecode_count_ptr,
- unsigned char** bytecodes_ptr);
-
- /* 76 : Is Method Native */
- jvmtiError (JNICALL *IsMethodNative) (jvmtiEnv* env,
- jmethodID method,
- jboolean* is_native_ptr);
-
- /* 77 : Is Method Synthetic */
- jvmtiError (JNICALL *IsMethodSynthetic) (jvmtiEnv* env,
- jmethodID method,
- jboolean* is_synthetic_ptr);
-
- /* 78 : Get Loaded Classes */
- jvmtiError (JNICALL *GetLoadedClasses) (jvmtiEnv* env,
- jint* class_count_ptr,
- jclass** classes_ptr);
-
- /* 79 : Get Classloader Classes */
- jvmtiError (JNICALL *GetClassLoaderClasses) (jvmtiEnv* env,
- jobject initiating_loader,
- jint* class_count_ptr,
- jclass** classes_ptr);
-
- /* 80 : Pop Frame */
- jvmtiError (JNICALL *PopFrame) (jvmtiEnv* env,
- jthread thread);
-
- /* 81 : Force Early Return - Object */
- jvmtiError (JNICALL *ForceEarlyReturnObject) (jvmtiEnv* env,
- jthread thread,
- jobject value);
-
- /* 82 : Force Early Return - Int */
- jvmtiError (JNICALL *ForceEarlyReturnInt) (jvmtiEnv* env,
- jthread thread,
- jint value);
-
- /* 83 : Force Early Return - Long */
- jvmtiError (JNICALL *ForceEarlyReturnLong) (jvmtiEnv* env,
- jthread thread,
- jlong value);
-
- /* 84 : Force Early Return - Float */
- jvmtiError (JNICALL *ForceEarlyReturnFloat) (jvmtiEnv* env,
- jthread thread,
- jfloat value);
-
- /* 85 : Force Early Return - Double */
- jvmtiError (JNICALL *ForceEarlyReturnDouble) (jvmtiEnv* env,
- jthread thread,
- jdouble value);
-
- /* 86 : Force Early Return - Void */
- jvmtiError (JNICALL *ForceEarlyReturnVoid) (jvmtiEnv* env,
- jthread thread);
-
- /* 87 : Redefine Classes */
- jvmtiError (JNICALL *RedefineClasses) (jvmtiEnv* env,
- jint class_count,
- const jvmtiClassDefinition* class_definitions);
-
- /* 88 : Get Version Number */
- jvmtiError (JNICALL *GetVersionNumber) (jvmtiEnv* env,
- jint* version_ptr);
-
- /* 89 : Get Capabilities */
- jvmtiError (JNICALL *GetCapabilities) (jvmtiEnv* env,
- jvmtiCapabilities* capabilities_ptr);
-
- /* 90 : Get Source Debug Extension */
- jvmtiError (JNICALL *GetSourceDebugExtension) (jvmtiEnv* env,
- jclass klass,
- char** source_debug_extension_ptr);
-
- /* 91 : Is Method Obsolete */
- jvmtiError (JNICALL *IsMethodObsolete) (jvmtiEnv* env,
- jmethodID method,
- jboolean* is_obsolete_ptr);
-
- /* 92 : Suspend Thread List */
- jvmtiError (JNICALL *SuspendThreadList) (jvmtiEnv* env,
- jint request_count,
- const jthread* request_list,
- jvmtiError* results);
-
- /* 93 : Resume Thread List */
- jvmtiError (JNICALL *ResumeThreadList) (jvmtiEnv* env,
- jint request_count,
- const jthread* request_list,
- jvmtiError* results);
-
- /* 94 : RESERVED */
- void *reserved94;
-
- /* 95 : RESERVED */
- void *reserved95;
-
- /* 96 : RESERVED */
- void *reserved96;
-
- /* 97 : RESERVED */
- void *reserved97;
-
- /* 98 : RESERVED */
- void *reserved98;
-
- /* 99 : RESERVED */
- void *reserved99;
-
- /* 100 : Get All Stack Traces */
- jvmtiError (JNICALL *GetAllStackTraces) (jvmtiEnv* env,
- jint max_frame_count,
- jvmtiStackInfo** stack_info_ptr,
- jint* thread_count_ptr);
-
- /* 101 : Get Thread List Stack Traces */
- jvmtiError (JNICALL *GetThreadListStackTraces) (jvmtiEnv* env,
- jint thread_count,
- const jthread* thread_list,
- jint max_frame_count,
- jvmtiStackInfo** stack_info_ptr);
-
- /* 102 : Get Thread Local Storage */
- jvmtiError (JNICALL *GetThreadLocalStorage) (jvmtiEnv* env,
- jthread thread,
- void** data_ptr);
-
- /* 103 : Set Thread Local Storage */
- jvmtiError (JNICALL *SetThreadLocalStorage) (jvmtiEnv* env,
- jthread thread,
- const void* data);
-
- /* 104 : Get Stack Trace */
- jvmtiError (JNICALL *GetStackTrace) (jvmtiEnv* env,
- jthread thread,
- jint start_depth,
- jint max_frame_count,
- jvmtiFrameInfo* frame_buffer,
- jint* count_ptr);
-
- /* 105 : RESERVED */
- void *reserved105;
-
- /* 106 : Get Tag */
- jvmtiError (JNICALL *GetTag) (jvmtiEnv* env,
- jobject object,
- jlong* tag_ptr);
-
- /* 107 : Set Tag */
- jvmtiError (JNICALL *SetTag) (jvmtiEnv* env,
- jobject object,
- jlong tag);
-
- /* 108 : Force Garbage Collection */
- jvmtiError (JNICALL *ForceGarbageCollection) (jvmtiEnv* env);
-
- /* 109 : Iterate Over Objects Reachable From Object */
- jvmtiError (JNICALL *IterateOverObjectsReachableFromObject) (jvmtiEnv* env,
- jobject object,
- jvmtiObjectReferenceCallback object_reference_callback,
- const void* user_data);
-
- /* 110 : Iterate Over Reachable Objects */
- jvmtiError (JNICALL *IterateOverReachableObjects) (jvmtiEnv* env,
- jvmtiHeapRootCallback heap_root_callback,
- jvmtiStackReferenceCallback stack_ref_callback,
- jvmtiObjectReferenceCallback object_ref_callback,
- const void* user_data);
-
- /* 111 : Iterate Over Heap */
- jvmtiError (JNICALL *IterateOverHeap) (jvmtiEnv* env,
- jvmtiHeapObjectFilter object_filter,
- jvmtiHeapObjectCallback heap_object_callback,
- const void* user_data);
-
- /* 112 : Iterate Over Instances Of Class */
- jvmtiError (JNICALL *IterateOverInstancesOfClass) (jvmtiEnv* env,
- jclass klass,
- jvmtiHeapObjectFilter object_filter,
- jvmtiHeapObjectCallback heap_object_callback,
- const void* user_data);
-
- /* 113 : RESERVED */
- void *reserved113;
-
- /* 114 : Get Objects With Tags */
- jvmtiError (JNICALL *GetObjectsWithTags) (jvmtiEnv* env,
- jint tag_count,
- const jlong* tags,
- jint* count_ptr,
- jobject** object_result_ptr,
- jlong** tag_result_ptr);
-
- /* 115 : Follow References */
- jvmtiError (JNICALL *FollowReferences) (jvmtiEnv* env,
- jint heap_filter,
- jclass klass,
- jobject initial_object,
- const jvmtiHeapCallbacks* callbacks,
- const void* user_data);
-
- /* 116 : Iterate Through Heap */
- jvmtiError (JNICALL *IterateThroughHeap) (jvmtiEnv* env,
- jint heap_filter,
- jclass klass,
- const jvmtiHeapCallbacks* callbacks,
- const void* user_data);
-
- /* 117 : RESERVED */
- void *reserved117;
-
- /* 118 : RESERVED */
- void *reserved118;
-
- /* 119 : RESERVED */
- void *reserved119;
-
- /* 120 : Set JNI Function Table */
- jvmtiError (JNICALL *SetJNIFunctionTable) (jvmtiEnv* env,
- const jniNativeInterface* function_table);
-
- /* 121 : Get JNI Function Table */
- jvmtiError (JNICALL *GetJNIFunctionTable) (jvmtiEnv* env,
- jniNativeInterface** function_table);
-
- /* 122 : Set Event Callbacks */
- jvmtiError (JNICALL *SetEventCallbacks) (jvmtiEnv* env,
- const jvmtiEventCallbacks* callbacks,
- jint size_of_callbacks);
-
- /* 123 : Generate Events */
- jvmtiError (JNICALL *GenerateEvents) (jvmtiEnv* env,
- jvmtiEvent event_type);
-
- /* 124 : Get Extension Functions */
- jvmtiError (JNICALL *GetExtensionFunctions) (jvmtiEnv* env,
- jint* extension_count_ptr,
- jvmtiExtensionFunctionInfo** extensions);
-
- /* 125 : Get Extension Events */
- jvmtiError (JNICALL *GetExtensionEvents) (jvmtiEnv* env,
- jint* extension_count_ptr,
- jvmtiExtensionEventInfo** extensions);
-
- /* 126 : Set Extension Event Callback */
- jvmtiError (JNICALL *SetExtensionEventCallback) (jvmtiEnv* env,
- jint extension_event_index,
- jvmtiExtensionEvent callback);
-
- /* 127 : Dispose Environment */
- jvmtiError (JNICALL *DisposeEnvironment) (jvmtiEnv* env);
-
- /* 128 : Get Error Name */
- jvmtiError (JNICALL *GetErrorName) (jvmtiEnv* env,
- jvmtiError error,
- char** name_ptr);
-
- /* 129 : Get JLocation Format */
- jvmtiError (JNICALL *GetJLocationFormat) (jvmtiEnv* env,
- jvmtiJlocationFormat* format_ptr);
-
- /* 130 : Get System Properties */
- jvmtiError (JNICALL *GetSystemProperties) (jvmtiEnv* env,
- jint* count_ptr,
- char*** property_ptr);
-
- /* 131 : Get System Property */
- jvmtiError (JNICALL *GetSystemProperty) (jvmtiEnv* env,
- const char* property,
- char** value_ptr);
-
- /* 132 : Set System Property */
- jvmtiError (JNICALL *SetSystemProperty) (jvmtiEnv* env,
- const char* property,
- const char* value);
-
- /* 133 : Get Phase */
- jvmtiError (JNICALL *GetPhase) (jvmtiEnv* env,
- jvmtiPhase* phase_ptr);
-
- /* 134 : Get Current Thread CPU Timer Information */
- jvmtiError (JNICALL *GetCurrentThreadCpuTimerInfo) (jvmtiEnv* env,
- jvmtiTimerInfo* info_ptr);
-
- /* 135 : Get Current Thread CPU Time */
- jvmtiError (JNICALL *GetCurrentThreadCpuTime) (jvmtiEnv* env,
- jlong* nanos_ptr);
-
- /* 136 : Get Thread CPU Timer Information */
- jvmtiError (JNICALL *GetThreadCpuTimerInfo) (jvmtiEnv* env,
- jvmtiTimerInfo* info_ptr);
-
- /* 137 : Get Thread CPU Time */
- jvmtiError (JNICALL *GetThreadCpuTime) (jvmtiEnv* env,
- jthread thread,
- jlong* nanos_ptr);
-
- /* 138 : Get Timer Information */
- jvmtiError (JNICALL *GetTimerInfo) (jvmtiEnv* env,
- jvmtiTimerInfo* info_ptr);
-
- /* 139 : Get Time */
- jvmtiError (JNICALL *GetTime) (jvmtiEnv* env,
- jlong* nanos_ptr);
-
- /* 140 : Get Potential Capabilities */
- jvmtiError (JNICALL *GetPotentialCapabilities) (jvmtiEnv* env,
- jvmtiCapabilities* capabilities_ptr);
-
- /* 141 : RESERVED */
- void *reserved141;
-
- /* 142 : Add Capabilities */
- jvmtiError (JNICALL *AddCapabilities) (jvmtiEnv* env,
- const jvmtiCapabilities* capabilities_ptr);
-
- /* 143 : Relinquish Capabilities */
- jvmtiError (JNICALL *RelinquishCapabilities) (jvmtiEnv* env,
- const jvmtiCapabilities* capabilities_ptr);
-
- /* 144 : Get Available Processors */
- jvmtiError (JNICALL *GetAvailableProcessors) (jvmtiEnv* env,
- jint* processor_count_ptr);
-
- /* 145 : Get Class Version Numbers */
- jvmtiError (JNICALL *GetClassVersionNumbers) (jvmtiEnv* env,
- jclass klass,
- jint* minor_version_ptr,
- jint* major_version_ptr);
-
- /* 146 : Get Constant Pool */
- jvmtiError (JNICALL *GetConstantPool) (jvmtiEnv* env,
- jclass klass,
- jint* constant_pool_count_ptr,
- jint* constant_pool_byte_count_ptr,
- unsigned char** constant_pool_bytes_ptr);
-
- /* 147 : Get Environment Local Storage */
- jvmtiError (JNICALL *GetEnvironmentLocalStorage) (jvmtiEnv* env,
- void** data_ptr);
-
- /* 148 : Set Environment Local Storage */
- jvmtiError (JNICALL *SetEnvironmentLocalStorage) (jvmtiEnv* env,
- const void* data);
-
- /* 149 : Add To Bootstrap Class Loader Search */
- jvmtiError (JNICALL *AddToBootstrapClassLoaderSearch) (jvmtiEnv* env,
- const char* segment);
-
- /* 150 : Set Verbose Flag */
- jvmtiError (JNICALL *SetVerboseFlag) (jvmtiEnv* env,
- jvmtiVerboseFlag flag,
- jboolean value);
-
- /* 151 : Add To System Class Loader Search */
- jvmtiError (JNICALL *AddToSystemClassLoaderSearch) (jvmtiEnv* env,
- const char* segment);
-
- /* 152 : Retransform Classes */
- jvmtiError (JNICALL *RetransformClasses) (jvmtiEnv* env,
- jint class_count,
- const jclass* classes);
-
- /* 153 : Get Owned Monitor Stack Depth Info */
- jvmtiError (JNICALL *GetOwnedMonitorStackDepthInfo) (jvmtiEnv* env,
- jthread thread,
- jint* monitor_info_count_ptr,
- jvmtiMonitorStackDepthInfo** monitor_info_ptr);
-
- /* 154 : Get Object Size */
- jvmtiError (JNICALL *GetObjectSize) (jvmtiEnv* env,
- jobject object,
- jlong* size_ptr);
-
- /* 155 : Get Local Instance */
- jvmtiError (JNICALL *GetLocalInstance) (jvmtiEnv* env,
- jthread thread,
- jint depth,
- jobject* value_ptr);
-
-} jvmtiInterface_1;
-
-struct _jvmtiEnv {
- const struct jvmtiInterface_1_ *functions;
-#ifdef __cplusplus
-
-
- jvmtiError Allocate(jlong size,
- unsigned char** mem_ptr) {
- return functions->Allocate(this, size, mem_ptr);
- }
-
- jvmtiError Deallocate(unsigned char* mem) {
- return functions->Deallocate(this, mem);
- }
-
- jvmtiError GetThreadState(jthread thread,
- jint* thread_state_ptr) {
- return functions->GetThreadState(this, thread, thread_state_ptr);
- }
-
- jvmtiError GetCurrentThread(jthread* thread_ptr) {
- return functions->GetCurrentThread(this, thread_ptr);
- }
-
- jvmtiError GetAllThreads(jint* threads_count_ptr,
- jthread** threads_ptr) {
- return functions->GetAllThreads(this, threads_count_ptr, threads_ptr);
- }
-
- jvmtiError SuspendThread(jthread thread) {
- return functions->SuspendThread(this, thread);
- }
-
- jvmtiError SuspendThreadList(jint request_count,
- const jthread* request_list,
- jvmtiError* results) {
- return functions->SuspendThreadList(this, request_count, request_list, results);
- }
-
- jvmtiError ResumeThread(jthread thread) {
- return functions->ResumeThread(this, thread);
- }
-
- jvmtiError ResumeThreadList(jint request_count,
- const jthread* request_list,
- jvmtiError* results) {
- return functions->ResumeThreadList(this, request_count, request_list, results);
- }
-
- jvmtiError StopThread(jthread thread,
- jobject exception) {
- return functions->StopThread(this, thread, exception);
- }
-
- jvmtiError InterruptThread(jthread thread) {
- return functions->InterruptThread(this, thread);
- }
-
- jvmtiError GetThreadInfo(jthread thread,
- jvmtiThreadInfo* info_ptr) {
- return functions->GetThreadInfo(this, thread, info_ptr);
- }
-
- jvmtiError GetOwnedMonitorInfo(jthread thread,
- jint* owned_monitor_count_ptr,
- jobject** owned_monitors_ptr) {
- return functions->GetOwnedMonitorInfo(this, thread, owned_monitor_count_ptr, owned_monitors_ptr);
- }
-
- jvmtiError GetOwnedMonitorStackDepthInfo(jthread thread,
- jint* monitor_info_count_ptr,
- jvmtiMonitorStackDepthInfo** monitor_info_ptr) {
- return functions->GetOwnedMonitorStackDepthInfo(this, thread, monitor_info_count_ptr, monitor_info_ptr);
- }
-
- jvmtiError GetCurrentContendedMonitor(jthread thread,
- jobject* monitor_ptr) {
- return functions->GetCurrentContendedMonitor(this, thread, monitor_ptr);
- }
-
- jvmtiError RunAgentThread(jthread thread,
- jvmtiStartFunction proc,
- const void* arg,
- jint priority) {
- return functions->RunAgentThread(this, thread, proc, arg, priority);
- }
-
- jvmtiError SetThreadLocalStorage(jthread thread,
- const void* data) {
- return functions->SetThreadLocalStorage(this, thread, data);
- }
-
- jvmtiError GetThreadLocalStorage(jthread thread,
- void** data_ptr) {
- return functions->GetThreadLocalStorage(this, thread, data_ptr);
- }
-
- jvmtiError GetTopThreadGroups(jint* group_count_ptr,
- jthreadGroup** groups_ptr) {
- return functions->GetTopThreadGroups(this, group_count_ptr, groups_ptr);
- }
-
- jvmtiError GetThreadGroupInfo(jthreadGroup group,
- jvmtiThreadGroupInfo* info_ptr) {
- return functions->GetThreadGroupInfo(this, group, info_ptr);
- }
-
- jvmtiError GetThreadGroupChildren(jthreadGroup group,
- jint* thread_count_ptr,
- jthread** threads_ptr,
- jint* group_count_ptr,
- jthreadGroup** groups_ptr) {
- return functions->GetThreadGroupChildren(this, group, thread_count_ptr, threads_ptr, group_count_ptr, groups_ptr);
- }
-
- jvmtiError GetStackTrace(jthread thread,
- jint start_depth,
- jint max_frame_count,
- jvmtiFrameInfo* frame_buffer,
- jint* count_ptr) {
- return functions->GetStackTrace(this, thread, start_depth, max_frame_count, frame_buffer, count_ptr);
- }
-
- jvmtiError GetAllStackTraces(jint max_frame_count,
- jvmtiStackInfo** stack_info_ptr,
- jint* thread_count_ptr) {
- return functions->GetAllStackTraces(this, max_frame_count, stack_info_ptr, thread_count_ptr);
- }
-
- jvmtiError GetThreadListStackTraces(jint thread_count,
- const jthread* thread_list,
- jint max_frame_count,
- jvmtiStackInfo** stack_info_ptr) {
- return functions->GetThreadListStackTraces(this, thread_count, thread_list, max_frame_count, stack_info_ptr);
- }
-
- jvmtiError GetFrameCount(jthread thread,
- jint* count_ptr) {
- return functions->GetFrameCount(this, thread, count_ptr);
- }
-
- jvmtiError PopFrame(jthread thread) {
- return functions->PopFrame(this, thread);
- }
-
- jvmtiError GetFrameLocation(jthread thread,
- jint depth,
- jmethodID* method_ptr,
- jlocation* location_ptr) {
- return functions->GetFrameLocation(this, thread, depth, method_ptr, location_ptr);
- }
-
- jvmtiError NotifyFramePop(jthread thread,
- jint depth) {
- return functions->NotifyFramePop(this, thread, depth);
- }
-
- jvmtiError ForceEarlyReturnObject(jthread thread,
- jobject value) {
- return functions->ForceEarlyReturnObject(this, thread, value);
- }
-
- jvmtiError ForceEarlyReturnInt(jthread thread,
- jint value) {
- return functions->ForceEarlyReturnInt(this, thread, value);
- }
-
- jvmtiError ForceEarlyReturnLong(jthread thread,
- jlong value) {
- return functions->ForceEarlyReturnLong(this, thread, value);
- }
-
- jvmtiError ForceEarlyReturnFloat(jthread thread,
- jfloat value) {
- return functions->ForceEarlyReturnFloat(this, thread, value);
- }
-
- jvmtiError ForceEarlyReturnDouble(jthread thread,
- jdouble value) {
- return functions->ForceEarlyReturnDouble(this, thread, value);
- }
-
- jvmtiError ForceEarlyReturnVoid(jthread thread) {
- return functions->ForceEarlyReturnVoid(this, thread);
- }
-
- jvmtiError FollowReferences(jint heap_filter,
- jclass klass,
- jobject initial_object,
- const jvmtiHeapCallbacks* callbacks,
- const void* user_data) {
- return functions->FollowReferences(this, heap_filter, klass, initial_object, callbacks, user_data);
- }
-
- jvmtiError IterateThroughHeap(jint heap_filter,
- jclass klass,
- const jvmtiHeapCallbacks* callbacks,
- const void* user_data) {
- return functions->IterateThroughHeap(this, heap_filter, klass, callbacks, user_data);
- }
-
- jvmtiError GetTag(jobject object,
- jlong* tag_ptr) {
- return functions->GetTag(this, object, tag_ptr);
- }
-
- jvmtiError SetTag(jobject object,
- jlong tag) {
- return functions->SetTag(this, object, tag);
- }
-
- jvmtiError GetObjectsWithTags(jint tag_count,
- const jlong* tags,
- jint* count_ptr,
- jobject** object_result_ptr,
- jlong** tag_result_ptr) {
- return functions->GetObjectsWithTags(this, tag_count, tags, count_ptr, object_result_ptr, tag_result_ptr);
- }
-
- jvmtiError ForceGarbageCollection() {
- return functions->ForceGarbageCollection(this);
- }
-
- jvmtiError IterateOverObjectsReachableFromObject(jobject object,
- jvmtiObjectReferenceCallback object_reference_callback,
- const void* user_data) {
- return functions->IterateOverObjectsReachableFromObject(this, object, object_reference_callback, user_data);
- }
-
- jvmtiError IterateOverReachableObjects(jvmtiHeapRootCallback heap_root_callback,
- jvmtiStackReferenceCallback stack_ref_callback,
- jvmtiObjectReferenceCallback object_ref_callback,
- const void* user_data) {
- return functions->IterateOverReachableObjects(this, heap_root_callback, stack_ref_callback, object_ref_callback, user_data);
- }
-
- jvmtiError IterateOverHeap(jvmtiHeapObjectFilter object_filter,
- jvmtiHeapObjectCallback heap_object_callback,
- const void* user_data) {
- return functions->IterateOverHeap(this, object_filter, heap_object_callback, user_data);
- }
-
- jvmtiError IterateOverInstancesOfClass(jclass klass,
- jvmtiHeapObjectFilter object_filter,
- jvmtiHeapObjectCallback heap_object_callback,
- const void* user_data) {
- return functions->IterateOverInstancesOfClass(this, klass, object_filter, heap_object_callback, user_data);
- }
-
- jvmtiError GetLocalObject(jthread thread,
- jint depth,
- jint slot,
- jobject* value_ptr) {
- return functions->GetLocalObject(this, thread, depth, slot, value_ptr);
- }
-
- jvmtiError GetLocalInstance(jthread thread,
- jint depth,
- jobject* value_ptr) {
- return functions->GetLocalInstance(this, thread, depth, value_ptr);
- }
-
- jvmtiError GetLocalInt(jthread thread,
- jint depth,
- jint slot,
- jint* value_ptr) {
- return functions->GetLocalInt(this, thread, depth, slot, value_ptr);
- }
-
- jvmtiError GetLocalLong(jthread thread,
- jint depth,
- jint slot,
- jlong* value_ptr) {
- return functions->GetLocalLong(this, thread, depth, slot, value_ptr);
- }
-
- jvmtiError GetLocalFloat(jthread thread,
- jint depth,
- jint slot,
- jfloat* value_ptr) {
- return functions->GetLocalFloat(this, thread, depth, slot, value_ptr);
- }
-
- jvmtiError GetLocalDouble(jthread thread,
- jint depth,
- jint slot,
- jdouble* value_ptr) {
- return functions->GetLocalDouble(this, thread, depth, slot, value_ptr);
- }
-
- jvmtiError SetLocalObject(jthread thread,
- jint depth,
- jint slot,
- jobject value) {
- return functions->SetLocalObject(this, thread, depth, slot, value);
- }
-
- jvmtiError SetLocalInt(jthread thread,
- jint depth,
- jint slot,
- jint value) {
- return functions->SetLocalInt(this, thread, depth, slot, value);
- }
-
- jvmtiError SetLocalLong(jthread thread,
- jint depth,
- jint slot,
- jlong value) {
- return functions->SetLocalLong(this, thread, depth, slot, value);
- }
-
- jvmtiError SetLocalFloat(jthread thread,
- jint depth,
- jint slot,
- jfloat value) {
- return functions->SetLocalFloat(this, thread, depth, slot, value);
- }
-
- jvmtiError SetLocalDouble(jthread thread,
- jint depth,
- jint slot,
- jdouble value) {
- return functions->SetLocalDouble(this, thread, depth, slot, value);
- }
-
- jvmtiError SetBreakpoint(jmethodID method,
- jlocation location) {
- return functions->SetBreakpoint(this, method, location);
- }
-
- jvmtiError ClearBreakpoint(jmethodID method,
- jlocation location) {
- return functions->ClearBreakpoint(this, method, location);
- }
-
- jvmtiError SetFieldAccessWatch(jclass klass,
- jfieldID field) {
- return functions->SetFieldAccessWatch(this, klass, field);
- }
-
- jvmtiError ClearFieldAccessWatch(jclass klass,
- jfieldID field) {
- return functions->ClearFieldAccessWatch(this, klass, field);
- }
-
- jvmtiError SetFieldModificationWatch(jclass klass,
- jfieldID field) {
- return functions->SetFieldModificationWatch(this, klass, field);
- }
-
- jvmtiError ClearFieldModificationWatch(jclass klass,
- jfieldID field) {
- return functions->ClearFieldModificationWatch(this, klass, field);
- }
-
- jvmtiError GetLoadedClasses(jint* class_count_ptr,
- jclass** classes_ptr) {
- return functions->GetLoadedClasses(this, class_count_ptr, classes_ptr);
- }
-
- jvmtiError GetClassLoaderClasses(jobject initiating_loader,
- jint* class_count_ptr,
- jclass** classes_ptr) {
- return functions->GetClassLoaderClasses(this, initiating_loader, class_count_ptr, classes_ptr);
- }
-
- jvmtiError GetClassSignature(jclass klass,
- char** signature_ptr,
- char** generic_ptr) {
- return functions->GetClassSignature(this, klass, signature_ptr, generic_ptr);
- }
-
- jvmtiError GetClassStatus(jclass klass,
- jint* status_ptr) {
- return functions->GetClassStatus(this, klass, status_ptr);
- }
-
- jvmtiError GetSourceFileName(jclass klass,
- char** source_name_ptr) {
- return functions->GetSourceFileName(this, klass, source_name_ptr);
- }
-
- jvmtiError GetClassModifiers(jclass klass,
- jint* modifiers_ptr) {
- return functions->GetClassModifiers(this, klass, modifiers_ptr);
- }
-
- jvmtiError GetClassMethods(jclass klass,
- jint* method_count_ptr,
- jmethodID** methods_ptr) {
- return functions->GetClassMethods(this, klass, method_count_ptr, methods_ptr);
- }
-
- jvmtiError GetClassFields(jclass klass,
- jint* field_count_ptr,
- jfieldID** fields_ptr) {
- return functions->GetClassFields(this, klass, field_count_ptr, fields_ptr);
- }
-
- jvmtiError GetImplementedInterfaces(jclass klass,
- jint* interface_count_ptr,
- jclass** interfaces_ptr) {
- return functions->GetImplementedInterfaces(this, klass, interface_count_ptr, interfaces_ptr);
- }
-
- jvmtiError GetClassVersionNumbers(jclass klass,
- jint* minor_version_ptr,
- jint* major_version_ptr) {
- return functions->GetClassVersionNumbers(this, klass, minor_version_ptr, major_version_ptr);
- }
-
- jvmtiError GetConstantPool(jclass klass,
- jint* constant_pool_count_ptr,
- jint* constant_pool_byte_count_ptr,
- unsigned char** constant_pool_bytes_ptr) {
- return functions->GetConstantPool(this, klass, constant_pool_count_ptr, constant_pool_byte_count_ptr, constant_pool_bytes_ptr);
- }
-
- jvmtiError IsInterface(jclass klass,
- jboolean* is_interface_ptr) {
- return functions->IsInterface(this, klass, is_interface_ptr);
- }
-
- jvmtiError IsArrayClass(jclass klass,
- jboolean* is_array_class_ptr) {
- return functions->IsArrayClass(this, klass, is_array_class_ptr);
- }
-
- jvmtiError IsModifiableClass(jclass klass,
- jboolean* is_modifiable_class_ptr) {
- return functions->IsModifiableClass(this, klass, is_modifiable_class_ptr);
- }
-
- jvmtiError GetClassLoader(jclass klass,
- jobject* classloader_ptr) {
- return functions->GetClassLoader(this, klass, classloader_ptr);
- }
-
- jvmtiError GetSourceDebugExtension(jclass klass,
- char** source_debug_extension_ptr) {
- return functions->GetSourceDebugExtension(this, klass, source_debug_extension_ptr);
- }
-
- jvmtiError RetransformClasses(jint class_count,
- const jclass* classes) {
- return functions->RetransformClasses(this, class_count, classes);
- }
-
- jvmtiError RedefineClasses(jint class_count,
- const jvmtiClassDefinition* class_definitions) {
- return functions->RedefineClasses(this, class_count, class_definitions);
- }
-
- jvmtiError GetObjectSize(jobject object,
- jlong* size_ptr) {
- return functions->GetObjectSize(this, object, size_ptr);
- }
-
- jvmtiError GetObjectHashCode(jobject object,
- jint* hash_code_ptr) {
- return functions->GetObjectHashCode(this, object, hash_code_ptr);
- }
-
- jvmtiError GetObjectMonitorUsage(jobject object,
- jvmtiMonitorUsage* info_ptr) {
- return functions->GetObjectMonitorUsage(this, object, info_ptr);
- }
-
- jvmtiError GetFieldName(jclass klass,
- jfieldID field,
- char** name_ptr,
- char** signature_ptr,
- char** generic_ptr) {
- return functions->GetFieldName(this, klass, field, name_ptr, signature_ptr, generic_ptr);
- }
-
- jvmtiError GetFieldDeclaringClass(jclass klass,
- jfieldID field,
- jclass* declaring_class_ptr) {
- return functions->GetFieldDeclaringClass(this, klass, field, declaring_class_ptr);
- }
-
- jvmtiError GetFieldModifiers(jclass klass,
- jfieldID field,
- jint* modifiers_ptr) {
- return functions->GetFieldModifiers(this, klass, field, modifiers_ptr);
- }
-
- jvmtiError IsFieldSynthetic(jclass klass,
- jfieldID field,
- jboolean* is_synthetic_ptr) {
- return functions->IsFieldSynthetic(this, klass, field, is_synthetic_ptr);
- }
-
- jvmtiError GetMethodName(jmethodID method,
- char** name_ptr,
- char** signature_ptr,
- char** generic_ptr) {
- return functions->GetMethodName(this, method, name_ptr, signature_ptr, generic_ptr);
- }
-
- jvmtiError GetMethodDeclaringClass(jmethodID method,
- jclass* declaring_class_ptr) {
- return functions->GetMethodDeclaringClass(this, method, declaring_class_ptr);
- }
-
- jvmtiError GetMethodModifiers(jmethodID method,
- jint* modifiers_ptr) {
- return functions->GetMethodModifiers(this, method, modifiers_ptr);
- }
-
- jvmtiError GetMaxLocals(jmethodID method,
- jint* max_ptr) {
- return functions->GetMaxLocals(this, method, max_ptr);
- }
-
- jvmtiError GetArgumentsSize(jmethodID method,
- jint* size_ptr) {
- return functions->GetArgumentsSize(this, method, size_ptr);
- }
-
- jvmtiError GetLineNumberTable(jmethodID method,
- jint* entry_count_ptr,
- jvmtiLineNumberEntry** table_ptr) {
- return functions->GetLineNumberTable(this, method, entry_count_ptr, table_ptr);
- }
-
- jvmtiError GetMethodLocation(jmethodID method,
- jlocation* start_location_ptr,
- jlocation* end_location_ptr) {
- return functions->GetMethodLocation(this, method, start_location_ptr, end_location_ptr);
- }
-
- jvmtiError GetLocalVariableTable(jmethodID method,
- jint* entry_count_ptr,
- jvmtiLocalVariableEntry** table_ptr) {
- return functions->GetLocalVariableTable(this, method, entry_count_ptr, table_ptr);
- }
-
- jvmtiError GetBytecodes(jmethodID method,
- jint* bytecode_count_ptr,
- unsigned char** bytecodes_ptr) {
- return functions->GetBytecodes(this, method, bytecode_count_ptr, bytecodes_ptr);
- }
-
- jvmtiError IsMethodNative(jmethodID method,
- jboolean* is_native_ptr) {
- return functions->IsMethodNative(this, method, is_native_ptr);
- }
-
- jvmtiError IsMethodSynthetic(jmethodID method,
- jboolean* is_synthetic_ptr) {
- return functions->IsMethodSynthetic(this, method, is_synthetic_ptr);
- }
-
- jvmtiError IsMethodObsolete(jmethodID method,
- jboolean* is_obsolete_ptr) {
- return functions->IsMethodObsolete(this, method, is_obsolete_ptr);
- }
-
- jvmtiError SetNativeMethodPrefix(const char* prefix) {
- return functions->SetNativeMethodPrefix(this, prefix);
- }
-
- jvmtiError SetNativeMethodPrefixes(jint prefix_count,
- char** prefixes) {
- return functions->SetNativeMethodPrefixes(this, prefix_count, prefixes);
- }
-
- jvmtiError CreateRawMonitor(const char* name,
- jrawMonitorID* monitor_ptr) {
- return functions->CreateRawMonitor(this, name, monitor_ptr);
- }
-
- jvmtiError DestroyRawMonitor(jrawMonitorID monitor) {
- return functions->DestroyRawMonitor(this, monitor);
- }
-
- jvmtiError RawMonitorEnter(jrawMonitorID monitor) {
- return functions->RawMonitorEnter(this, monitor);
- }
-
- jvmtiError RawMonitorExit(jrawMonitorID monitor) {
- return functions->RawMonitorExit(this, monitor);
- }
-
- jvmtiError RawMonitorWait(jrawMonitorID monitor,
- jlong millis) {
- return functions->RawMonitorWait(this, monitor, millis);
- }
-
- jvmtiError RawMonitorNotify(jrawMonitorID monitor) {
- return functions->RawMonitorNotify(this, monitor);
- }
-
- jvmtiError RawMonitorNotifyAll(jrawMonitorID monitor) {
- return functions->RawMonitorNotifyAll(this, monitor);
- }
-
- jvmtiError SetJNIFunctionTable(const jniNativeInterface* function_table) {
- return functions->SetJNIFunctionTable(this, function_table);
- }
-
- jvmtiError GetJNIFunctionTable(jniNativeInterface** function_table) {
- return functions->GetJNIFunctionTable(this, function_table);
- }
-
- jvmtiError SetEventCallbacks(const jvmtiEventCallbacks* callbacks,
- jint size_of_callbacks) {
- return functions->SetEventCallbacks(this, callbacks, size_of_callbacks);
- }
-
- jvmtiError SetEventNotificationMode(jvmtiEventMode mode,
- jvmtiEvent event_type,
- jthread event_thread,
- ...) {
- return functions->SetEventNotificationMode(this, mode, event_type, event_thread);
- }
-
- jvmtiError GenerateEvents(jvmtiEvent event_type) {
- return functions->GenerateEvents(this, event_type);
- }
-
- jvmtiError GetExtensionFunctions(jint* extension_count_ptr,
- jvmtiExtensionFunctionInfo** extensions) {
- return functions->GetExtensionFunctions(this, extension_count_ptr, extensions);
- }
-
- jvmtiError GetExtensionEvents(jint* extension_count_ptr,
- jvmtiExtensionEventInfo** extensions) {
- return functions->GetExtensionEvents(this, extension_count_ptr, extensions);
- }
-
- jvmtiError SetExtensionEventCallback(jint extension_event_index,
- jvmtiExtensionEvent callback) {
- return functions->SetExtensionEventCallback(this, extension_event_index, callback);
- }
-
- jvmtiError GetPotentialCapabilities(jvmtiCapabilities* capabilities_ptr) {
- return functions->GetPotentialCapabilities(this, capabilities_ptr);
- }
-
- jvmtiError AddCapabilities(const jvmtiCapabilities* capabilities_ptr) {
- return functions->AddCapabilities(this, capabilities_ptr);
- }
-
- jvmtiError RelinquishCapabilities(const jvmtiCapabilities* capabilities_ptr) {
- return functions->RelinquishCapabilities(this, capabilities_ptr);
- }
-
- jvmtiError GetCapabilities(jvmtiCapabilities* capabilities_ptr) {
- return functions->GetCapabilities(this, capabilities_ptr);
- }
-
- jvmtiError GetCurrentThreadCpuTimerInfo(jvmtiTimerInfo* info_ptr) {
- return functions->GetCurrentThreadCpuTimerInfo(this, info_ptr);
- }
-
- jvmtiError GetCurrentThreadCpuTime(jlong* nanos_ptr) {
- return functions->GetCurrentThreadCpuTime(this, nanos_ptr);
- }
-
- jvmtiError GetThreadCpuTimerInfo(jvmtiTimerInfo* info_ptr) {
- return functions->GetThreadCpuTimerInfo(this, info_ptr);
- }
-
- jvmtiError GetThreadCpuTime(jthread thread,
- jlong* nanos_ptr) {
- return functions->GetThreadCpuTime(this, thread, nanos_ptr);
- }
-
- jvmtiError GetTimerInfo(jvmtiTimerInfo* info_ptr) {
- return functions->GetTimerInfo(this, info_ptr);
- }
-
- jvmtiError GetTime(jlong* nanos_ptr) {
- return functions->GetTime(this, nanos_ptr);
- }
-
- jvmtiError GetAvailableProcessors(jint* processor_count_ptr) {
- return functions->GetAvailableProcessors(this, processor_count_ptr);
- }
-
- jvmtiError AddToBootstrapClassLoaderSearch(const char* segment) {
- return functions->AddToBootstrapClassLoaderSearch(this, segment);
- }
-
- jvmtiError AddToSystemClassLoaderSearch(const char* segment) {
- return functions->AddToSystemClassLoaderSearch(this, segment);
- }
-
- jvmtiError GetSystemProperties(jint* count_ptr,
- char*** property_ptr) {
- return functions->GetSystemProperties(this, count_ptr, property_ptr);
- }
-
- jvmtiError GetSystemProperty(const char* property,
- char** value_ptr) {
- return functions->GetSystemProperty(this, property, value_ptr);
- }
-
- jvmtiError SetSystemProperty(const char* property,
- const char* value) {
- return functions->SetSystemProperty(this, property, value);
- }
-
- jvmtiError GetPhase(jvmtiPhase* phase_ptr) {
- return functions->GetPhase(this, phase_ptr);
- }
-
- jvmtiError DisposeEnvironment() {
- return functions->DisposeEnvironment(this);
- }
-
- jvmtiError SetEnvironmentLocalStorage(const void* data) {
- return functions->SetEnvironmentLocalStorage(this, data);
- }
-
- jvmtiError GetEnvironmentLocalStorage(void** data_ptr) {
- return functions->GetEnvironmentLocalStorage(this, data_ptr);
- }
-
- jvmtiError GetVersionNumber(jint* version_ptr) {
- return functions->GetVersionNumber(this, version_ptr);
- }
-
- jvmtiError GetErrorName(jvmtiError error,
- char** name_ptr) {
- return functions->GetErrorName(this, error, name_ptr);
- }
-
- jvmtiError SetVerboseFlag(jvmtiVerboseFlag flag,
- jboolean value) {
- return functions->SetVerboseFlag(this, flag, value);
- }
-
- jvmtiError GetJLocationFormat(jvmtiJlocationFormat* format_ptr) {
- return functions->GetJLocationFormat(this, format_ptr);
- }
-
-#endif /* __cplusplus */
-};
-
-
-#ifdef __cplusplus
-} /* extern "C" */
-#endif /* __cplusplus */
-
-#endif /* !_JAVA_JVMTI_H_ */ \ No newline at end of file
diff --git a/demos/java/jni/gs_jni/include/jvmticmlr.h b/demos/java/jni/gs_jni/include/jvmticmlr.h
deleted file mode 100644
index a9c88f36..00000000
--- a/demos/java/jni/gs_jni/include/jvmticmlr.h
+++ /dev/null
@@ -1,115 +0,0 @@
-/*
- * Copyright (c) 2010, Oracle and/or its affiliates. All rights reserved.
- * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- */
-
-/*
- * This header file defines the data structures sent by the VM
- * through the JVMTI CompiledMethodLoad callback function via the
- * "void * compile_info" parameter. The memory pointed to by the
- * compile_info parameter may not be referenced after returning from
- * the CompiledMethodLoad callback. These are VM implementation
- * specific data structures that may evolve in future releases. A
- * JVMTI agent should interpret a non-NULL compile_info as a pointer
- * to a region of memory containing a list of records. In a typical
- * usage scenario, a JVMTI agent would cast each record to a
- * jvmtiCompiledMethodLoadRecordHeader, a struct that represents
- * arbitrary information. This struct contains a kind field to indicate
- * the kind of information being passed, and a pointer to the next
- * record. If the kind field indicates inlining information, then the
- * agent would cast the record to a jvmtiCompiledMethodLoadInlineRecord.
- * This record contains an array of PCStackInfo structs, which indicate
- * for every pc address what are the methods on the invocation stack.
- * The "methods" and "bcis" fields in each PCStackInfo struct specify a
- * 1-1 mapping between these inlined methods and their bytecode indices.
- * This can be used to derive the proper source lines of the inlined
- * methods.
- */
-
-#ifndef _JVMTI_CMLR_H_
-#define _JVMTI_CMLR_H_
-
-enum {
- JVMTI_CMLR_MAJOR_VERSION_1 = 0x00000001,
- JVMTI_CMLR_MINOR_VERSION_0 = 0x00000000,
-
- JVMTI_CMLR_MAJOR_VERSION = 0x00000001,
- JVMTI_CMLR_MINOR_VERSION = 0x00000000
-
- /*
- * This comment is for the "JDK import from HotSpot" sanity check:
- * version: 1.0.0
- */
-};
-
-typedef enum {
- JVMTI_CMLR_DUMMY = 1,
- JVMTI_CMLR_INLINE_INFO = 2
-} jvmtiCMLRKind;
-
-/*
- * Record that represents arbitrary information passed through JVMTI
- * CompiledMethodLoadEvent void pointer.
- */
-typedef struct _jvmtiCompiledMethodLoadRecordHeader {
- jvmtiCMLRKind kind; /* id for the kind of info passed in the record */
- jint majorinfoversion; /* major and minor info version values. Init'ed */
- jint minorinfoversion; /* to current version value in jvmtiExport.cpp. */
-
- struct _jvmtiCompiledMethodLoadRecordHeader* next;
-} jvmtiCompiledMethodLoadRecordHeader;
-
-/*
- * Record that gives information about the methods on the compile-time
- * stack at a specific pc address of a compiled method. Each element in
- * the methods array maps to same element in the bcis array.
- */
-typedef struct _PCStackInfo {
- void* pc; /* the pc address for this compiled method */
- jint numstackframes; /* number of methods on the stack */
- jmethodID* methods; /* array of numstackframes method ids */
- jint* bcis; /* array of numstackframes bytecode indices */
-} PCStackInfo;
-
-/*
- * Record that contains inlining information for each pc address of
- * an nmethod.
- */
-typedef struct _jvmtiCompiledMethodLoadInlineRecord {
- jvmtiCompiledMethodLoadRecordHeader header; /* common header for casting */
- jint numpcs; /* number of pc descriptors in this nmethod */
- PCStackInfo* pcinfo; /* array of numpcs pc descriptors */
-} jvmtiCompiledMethodLoadInlineRecord;
-
-/*
- * Dummy record used to test that we can pass records with different
- * information through the void pointer provided that they can be cast
- * to a jvmtiCompiledMethodLoadRecordHeader.
- */
-
-typedef struct _jvmtiCompiledMethodLoadDummyRecord {
- jvmtiCompiledMethodLoadRecordHeader header; /* common header for casting */
- char message[50];
-} jvmtiCompiledMethodLoadDummyRecord;
-
-#endif
diff --git a/demos/java/jni/gs_jni/include/win32/bridge/AccessBridgeCallbacks.h b/demos/java/jni/gs_jni/include/win32/bridge/AccessBridgeCallbacks.h
deleted file mode 100644
index df5035b8..00000000
--- a/demos/java/jni/gs_jni/include/win32/bridge/AccessBridgeCallbacks.h
+++ /dev/null
@@ -1,96 +0,0 @@
-/*
- * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
- * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- */
-
-/*
- * AccessBridgeCallbacks.h 1.17 05/03/21
- */
-
-/*
- * Header file defining callback typedefs for Windows routines
- * which are called from Java (responding to events, etc.).
- */
-
-#ifndef __AccessBridgeCallbacks_H__
-#define __AccessBridgeCallbacks_H__
-
-#include <jni.h>
-#include "AccessBridgePackages.h"
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-typedef void (*AccessBridge_PropertyChangeFP) (long vmID, JOBJECT64 event, JOBJECT64 source,
- wchar_t *property, wchar_t *oldValue, wchar_t *newValue);
-
-typedef void (*AccessBridge_JavaShutdownFP) (long vmID);
-typedef void (*AccessBridge_JavaShutdownFP) (long vmID);
-
-typedef void (*AccessBridge_FocusGainedFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-typedef void (*AccessBridge_FocusLostFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-
-typedef void (*AccessBridge_CaretUpdateFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-
-typedef void (*AccessBridge_MouseClickedFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-typedef void (*AccessBridge_MouseEnteredFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-typedef void (*AccessBridge_MouseExitedFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-typedef void (*AccessBridge_MousePressedFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-typedef void (*AccessBridge_MouseReleasedFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-
-typedef void (*AccessBridge_MenuCanceledFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-typedef void (*AccessBridge_MenuDeselectedFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-typedef void (*AccessBridge_MenuSelectedFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-typedef void (*AccessBridge_PopupMenuCanceledFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-typedef void (*AccessBridge_PopupMenuWillBecomeInvisibleFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-typedef void (*AccessBridge_PopupMenuWillBecomeVisibleFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-
-typedef void (*AccessBridge_PropertyNameChangeFP) (long vmID, JOBJECT64 event, JOBJECT64 source,
- wchar_t *oldName, wchar_t *newName);
-typedef void (*AccessBridge_PropertyDescriptionChangeFP) (long vmID, JOBJECT64 event, JOBJECT64 source,
- wchar_t *oldDescription, wchar_t *newDescription);
-typedef void (*AccessBridge_PropertyStateChangeFP) (long vmID, JOBJECT64 event, JOBJECT64 source,
- wchar_t *oldState, wchar_t *newState);
-typedef void (*AccessBridge_PropertyValueChangeFP) (long vmID, JOBJECT64 event, JOBJECT64 source,
- wchar_t *oldValue, wchar_t *newValue);
-typedef void (*AccessBridge_PropertySelectionChangeFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-typedef void (*AccessBridge_PropertyTextChangeFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-typedef void (*AccessBridge_PropertyCaretChangeFP) (long vmID, JOBJECT64 event, JOBJECT64 source,
- int oldPosition, int newPosition);
-typedef void (*AccessBridge_PropertyVisibleDataChangeFP) (long vmID, JOBJECT64 event, JOBJECT64 source);
-typedef void (*AccessBridge_PropertyChildChangeFP) (long vmID, JOBJECT64 event, JOBJECT64 source,
- JOBJECT64 oldChild, JOBJECT64 newChild);
-typedef void (*AccessBridge_PropertyActiveDescendentChangeFP) (long vmID, JOBJECT64 event,
- JOBJECT64 source,
- JOBJECT64 oldActiveDescendent,
- JOBJECT64 newActiveDescendent);
-
-typedef void (*AccessBridge_PropertyTableModelChangeFP) (long vmID, JOBJECT64 event, JOBJECT64 src,
- wchar_t *oldValue, wchar_t *newValue);
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif
diff --git a/demos/java/jni/gs_jni/include/win32/bridge/AccessBridgeCalls.c b/demos/java/jni/gs_jni/include/win32/bridge/AccessBridgeCalls.c
deleted file mode 100644
index 36866481..00000000
--- a/demos/java/jni/gs_jni/include/win32/bridge/AccessBridgeCalls.c
+++ /dev/null
@@ -1,1131 +0,0 @@
-/*
- * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
- * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- */
-
-/*
- * @(#)AccessBridgeCalls.c 1.25 05/08/22
- */
-
-/*
- * Wrapper functions around calls to the AccessBridge DLL
- */
-
-
-#include <windows.h>
-#include <jni.h>
-
-
-//#define ACCESSBRIDGE_32
-//#define ACCESSBRIDGE_64
-
-#include "AccessBridgeCalls.h"
-#include "AccessBridgeDebug.h"
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
- HINSTANCE theAccessBridgeInstance;
- AccessBridgeFPs theAccessBridge;
-
- BOOL theAccessBridgeInitializedFlag = FALSE;
-
-#define LOAD_FP(result, type, name) \
- PrintDebugString("LOAD_FP loading: %s ...", name); \
- if ((theAccessBridge.result = \
- (type) GetProcAddress(theAccessBridgeInstance, name)) == (type) 0) { \
- PrintDebugString("LOAD_FP failed: %s", name); \
- return FALSE; \
- }
-
- BOOL initializeAccessBridge() {
-
-#ifdef ACCESSBRIDGE_ARCH_32 // For 32bit AT new bridge
- theAccessBridgeInstance = LoadLibrary("WINDOWSACCESSBRIDGE-32");
-#else
-#ifdef ACCESSBRIDGE_ARCH_64 // For 64bit AT new bridge
- theAccessBridgeInstance = LoadLibrary("WINDOWSACCESSBRIDGE-64");
-#else // legacy
- theAccessBridgeInstance = LoadLibrary("WINDOWSACCESSBRIDGE");
-#endif
-#endif
- if (theAccessBridgeInstance != 0) {
- LOAD_FP(Windows_run, Windows_runFP, "Windows_run");
-
- LOAD_FP(SetJavaShutdown, SetJavaShutdownFP, "setJavaShutdownFP");
- LOAD_FP(SetFocusGained, SetFocusGainedFP, "setFocusGainedFP");
- LOAD_FP(SetFocusLost, SetFocusLostFP, "setFocusLostFP");
-
- LOAD_FP(SetCaretUpdate, SetCaretUpdateFP, "setCaretUpdateFP");
-
- LOAD_FP(SetMouseClicked, SetMouseClickedFP, "setMouseClickedFP");
- LOAD_FP(SetMouseEntered, SetMouseEnteredFP, "setMouseEnteredFP");
- LOAD_FP(SetMouseExited, SetMouseExitedFP, "setMouseExitedFP");
- LOAD_FP(SetMousePressed, SetMousePressedFP, "setMousePressedFP");
- LOAD_FP(SetMouseReleased, SetMouseReleasedFP, "setMouseReleasedFP");
-
- LOAD_FP(SetMenuCanceled, SetMenuCanceledFP, "setMenuCanceledFP");
- LOAD_FP(SetMenuDeselected, SetMenuDeselectedFP, "setMenuDeselectedFP");
- LOAD_FP(SetMenuSelected, SetMenuSelectedFP, "setMenuSelectedFP");
- LOAD_FP(SetPopupMenuCanceled, SetPopupMenuCanceledFP, "setPopupMenuCanceledFP");
- LOAD_FP(SetPopupMenuWillBecomeInvisible, SetPopupMenuWillBecomeInvisibleFP, "setPopupMenuWillBecomeInvisibleFP");
- LOAD_FP(SetPopupMenuWillBecomeVisible, SetPopupMenuWillBecomeVisibleFP, "setPopupMenuWillBecomeVisibleFP");
-
- LOAD_FP(SetPropertyNameChange, SetPropertyNameChangeFP, "setPropertyNameChangeFP");
- LOAD_FP(SetPropertyDescriptionChange, SetPropertyDescriptionChangeFP, "setPropertyDescriptionChangeFP");
- LOAD_FP(SetPropertyStateChange, SetPropertyStateChangeFP, "setPropertyStateChangeFP");
- LOAD_FP(SetPropertyValueChange, SetPropertyValueChangeFP, "setPropertyValueChangeFP");
- LOAD_FP(SetPropertySelectionChange, SetPropertySelectionChangeFP, "setPropertySelectionChangeFP");
- LOAD_FP(SetPropertyTextChange, SetPropertyTextChangeFP, "setPropertyTextChangeFP");
- LOAD_FP(SetPropertyCaretChange, SetPropertyCaretChangeFP, "setPropertyCaretChangeFP");
- LOAD_FP(SetPropertyVisibleDataChange, SetPropertyVisibleDataChangeFP, "setPropertyVisibleDataChangeFP");
- LOAD_FP(SetPropertyChildChange, SetPropertyChildChangeFP, "setPropertyChildChangeFP");
- LOAD_FP(SetPropertyActiveDescendentChange, SetPropertyActiveDescendentChangeFP, "setPropertyActiveDescendentChangeFP");
-
- LOAD_FP(SetPropertyTableModelChange, SetPropertyTableModelChangeFP, "setPropertyTableModelChangeFP");
-
- LOAD_FP(ReleaseJavaObject, ReleaseJavaObjectFP, "releaseJavaObject");
- LOAD_FP(GetVersionInfo, GetVersionInfoFP, "getVersionInfo");
-
- LOAD_FP(IsJavaWindow, IsJavaWindowFP, "isJavaWindow");
- LOAD_FP(IsSameObject, IsSameObjectFP, "isSameObject");
- LOAD_FP(GetAccessibleContextFromHWND, GetAccessibleContextFromHWNDFP, "getAccessibleContextFromHWND");
- LOAD_FP(getHWNDFromAccessibleContext, getHWNDFromAccessibleContextFP, "getHWNDFromAccessibleContext");
-
- LOAD_FP(GetAccessibleContextAt, GetAccessibleContextAtFP, "getAccessibleContextAt");
- LOAD_FP(GetAccessibleContextWithFocus, GetAccessibleContextWithFocusFP, "getAccessibleContextWithFocus");
- LOAD_FP(GetAccessibleContextInfo, GetAccessibleContextInfoFP, "getAccessibleContextInfo");
- LOAD_FP(GetAccessibleChildFromContext, GetAccessibleChildFromContextFP, "getAccessibleChildFromContext");
- LOAD_FP(GetAccessibleParentFromContext, GetAccessibleParentFromContextFP, "getAccessibleParentFromContext");
-
- /* begin AccessibleTable */
- LOAD_FP(getAccessibleTableInfo, getAccessibleTableInfoFP, "getAccessibleTableInfo");
- LOAD_FP(getAccessibleTableCellInfo, getAccessibleTableCellInfoFP, "getAccessibleTableCellInfo");
-
- LOAD_FP(getAccessibleTableRowHeader, getAccessibleTableRowHeaderFP, "getAccessibleTableRowHeader");
- LOAD_FP(getAccessibleTableColumnHeader, getAccessibleTableColumnHeaderFP, "getAccessibleTableColumnHeader");
-
- LOAD_FP(getAccessibleTableRowDescription, getAccessibleTableRowDescriptionFP, "getAccessibleTableRowDescription");
- LOAD_FP(getAccessibleTableColumnDescription, getAccessibleTableColumnDescriptionFP, "getAccessibleTableColumnDescription");
-
- LOAD_FP(getAccessibleTableRowSelectionCount, getAccessibleTableRowSelectionCountFP,
- "getAccessibleTableRowSelectionCount");
- LOAD_FP(isAccessibleTableRowSelected, isAccessibleTableRowSelectedFP,
- "isAccessibleTableRowSelected");
- LOAD_FP(getAccessibleTableRowSelections, getAccessibleTableRowSelectionsFP,
- "getAccessibleTableRowSelections");
-
- LOAD_FP(getAccessibleTableColumnSelectionCount, getAccessibleTableColumnSelectionCountFP,
- "getAccessibleTableColumnSelectionCount");
- LOAD_FP(isAccessibleTableColumnSelected, isAccessibleTableColumnSelectedFP,
- "isAccessibleTableColumnSelected");
- LOAD_FP(getAccessibleTableColumnSelections, getAccessibleTableColumnSelectionsFP,
- "getAccessibleTableColumnSelections");
-
- LOAD_FP(getAccessibleTableRow, getAccessibleTableRowFP,
- "getAccessibleTableRow");
- LOAD_FP(getAccessibleTableColumn, getAccessibleTableColumnFP,
- "getAccessibleTableColumn");
- LOAD_FP(getAccessibleTableIndex, getAccessibleTableIndexFP,
- "getAccessibleTableIndex");
-
- /* end AccessibleTable */
-
- /* AccessibleRelationSet */
- LOAD_FP(getAccessibleRelationSet, getAccessibleRelationSetFP, "getAccessibleRelationSet");
-
- /* AccessibleHypertext */
- LOAD_FP(getAccessibleHypertext, getAccessibleHypertextFP, "getAccessibleHypertext");
- LOAD_FP(activateAccessibleHyperlink, activateAccessibleHyperlinkFP, "activateAccessibleHyperlink");
- LOAD_FP(getAccessibleHyperlinkCount, getAccessibleHyperlinkCountFP, "getAccessibleHyperlinkCount");
- LOAD_FP(getAccessibleHypertextExt, getAccessibleHypertextExtFP, "getAccessibleHypertextExt");
- LOAD_FP(getAccessibleHypertextLinkIndex, getAccessibleHypertextLinkIndexFP, "getAccessibleHypertextLinkIndex");
- LOAD_FP(getAccessibleHyperlink, getAccessibleHyperlinkFP, "getAccessibleHyperlink");
-
- /* Accessible KeyBinding, Icon and Action */
- LOAD_FP(getAccessibleKeyBindings, getAccessibleKeyBindingsFP, "getAccessibleKeyBindings");
- LOAD_FP(getAccessibleIcons, getAccessibleIconsFP, "getAccessibleIcons");
- LOAD_FP(getAccessibleActions, getAccessibleActionsFP, "getAccessibleActions");
- LOAD_FP(doAccessibleActions, doAccessibleActionsFP, "doAccessibleActions");
-
- /* AccessibleText */
- LOAD_FP(GetAccessibleTextInfo, GetAccessibleTextInfoFP, "getAccessibleTextInfo");
- LOAD_FP(GetAccessibleTextItems, GetAccessibleTextItemsFP, "getAccessibleTextItems");
- LOAD_FP(GetAccessibleTextSelectionInfo, GetAccessibleTextSelectionInfoFP, "getAccessibleTextSelectionInfo");
- LOAD_FP(GetAccessibleTextAttributes, GetAccessibleTextAttributesFP, "getAccessibleTextAttributes");
- LOAD_FP(GetAccessibleTextRect, GetAccessibleTextRectFP, "getAccessibleTextRect");
- LOAD_FP(GetAccessibleTextLineBounds, GetAccessibleTextLineBoundsFP, "getAccessibleTextLineBounds");
- LOAD_FP(GetAccessibleTextRange, GetAccessibleTextRangeFP, "getAccessibleTextRange");
-
- LOAD_FP(GetCurrentAccessibleValueFromContext, GetCurrentAccessibleValueFromContextFP, "getCurrentAccessibleValueFromContext");
- LOAD_FP(GetMaximumAccessibleValueFromContext, GetMaximumAccessibleValueFromContextFP, "getMaximumAccessibleValueFromContext");
- LOAD_FP(GetMinimumAccessibleValueFromContext, GetMinimumAccessibleValueFromContextFP, "getMinimumAccessibleValueFromContext");
-
- LOAD_FP(AddAccessibleSelectionFromContext, AddAccessibleSelectionFromContextFP, "addAccessibleSelectionFromContext");
- LOAD_FP(ClearAccessibleSelectionFromContext, ClearAccessibleSelectionFromContextFP, "clearAccessibleSelectionFromContext");
- LOAD_FP(GetAccessibleSelectionFromContext, GetAccessibleSelectionFromContextFP, "getAccessibleSelectionFromContext");
- LOAD_FP(GetAccessibleSelectionCountFromContext, GetAccessibleSelectionCountFromContextFP, "getAccessibleSelectionCountFromContext");
- LOAD_FP(IsAccessibleChildSelectedFromContext, IsAccessibleChildSelectedFromContextFP, "isAccessibleChildSelectedFromContext");
- LOAD_FP(RemoveAccessibleSelectionFromContext, RemoveAccessibleSelectionFromContextFP, "removeAccessibleSelectionFromContext");
- LOAD_FP(SelectAllAccessibleSelectionFromContext, SelectAllAccessibleSelectionFromContextFP, "selectAllAccessibleSelectionFromContext");
-
- LOAD_FP(setTextContents, setTextContentsFP, "setTextContents");
- LOAD_FP(getParentWithRole, getParentWithRoleFP, "getParentWithRole");
- LOAD_FP(getTopLevelObject, getTopLevelObjectFP, "getTopLevelObject");
- LOAD_FP(getParentWithRoleElseRoot, getParentWithRoleElseRootFP, "getParentWithRoleElseRoot");
- LOAD_FP(getObjectDepth, getObjectDepthFP, "getObjectDepth");
- LOAD_FP(getActiveDescendent, getActiveDescendentFP, "getActiveDescendent");
-
- // additional methods for Teton
- LOAD_FP(getVirtualAccessibleName, getVirtualAccessibleNameFP, "getVirtualAccessibleName");
- LOAD_FP(requestFocus, requestFocusFP, "requestFocus");
- LOAD_FP(selectTextRange, selectTextRangeFP, "selectTextRange");
- LOAD_FP(getTextAttributesInRange, getTextAttributesInRangeFP, "getTextAttributesInRange");
- LOAD_FP(getVisibleChildrenCount, getVisibleChildrenCountFP, "getVisibleChildrenCount");
- LOAD_FP(getVisibleChildren, getVisibleChildrenFP, "getVisibleChildren");
- LOAD_FP(setCaretPosition, setCaretPositionFP, "setCaretPosition");
- LOAD_FP(getCaretLocation, getCaretLocationFP, "getCaretLocation");
-
- LOAD_FP(getEventsWaiting, getEventsWaitingFP, "getEventsWaiting");
-
- theAccessBridge.Windows_run();
-
- theAccessBridgeInitializedFlag = TRUE;
- PrintDebugString("theAccessBridgeInitializedFlag = TRUE");
- return TRUE;
- } else {
- return FALSE;
- }
- }
-
-
- BOOL shutdownAccessBridge() {
- BOOL result;
- DWORD error;
- theAccessBridgeInitializedFlag = FALSE;
- if (theAccessBridgeInstance != (HANDLE) 0) {
- result = FreeLibrary(theAccessBridgeInstance);
- if (result != TRUE) {
- error = GetLastError();
- }
- return TRUE;
- }
- return FALSE;
- }
-
-
- void SetJavaShutdown(AccessBridge_JavaShutdownFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetJavaShutdown(fp);
- }
- }
-
- void SetFocusGained(AccessBridge_FocusGainedFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetFocusGained(fp);
- }
- }
-
- void SetFocusLost(AccessBridge_FocusLostFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetFocusLost(fp);
- }
- }
-
-
- void SetCaretUpdate(AccessBridge_CaretUpdateFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetCaretUpdate(fp);
- }
- }
-
-
- void SetMouseClicked(AccessBridge_MouseClickedFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetMouseClicked(fp);
- }
- }
-
- void SetMouseEntered(AccessBridge_MouseEnteredFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetMouseEntered(fp);
- }
- }
-
- void SetMouseExited(AccessBridge_MouseExitedFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetMouseExited(fp);
- }
- }
-
- void SetMousePressed(AccessBridge_MousePressedFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetMousePressed(fp);
- }
- }
-
- void SetMouseReleased(AccessBridge_MouseReleasedFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetMouseReleased(fp);
- }
- }
-
-
- void SetMenuCanceled(AccessBridge_MenuCanceledFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetMenuCanceled(fp);
- }
- }
-
- void SetMenuDeselected(AccessBridge_MenuDeselectedFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetMenuDeselected(fp);
- }
- }
-
- void SetMenuSelected(AccessBridge_MenuSelectedFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetMenuSelected(fp);
- }
- }
-
- void SetPopupMenuCanceled(AccessBridge_PopupMenuCanceledFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetPopupMenuCanceled(fp);
- }
- }
-
- void SetPopupMenuWillBecomeInvisible(AccessBridge_PopupMenuWillBecomeInvisibleFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetPopupMenuWillBecomeInvisible(fp);
- }
- }
-
- void SetPopupMenuWillBecomeVisible(AccessBridge_PopupMenuWillBecomeVisibleFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetPopupMenuWillBecomeVisible(fp);
- }
- }
-
-
- void SetPropertyNameChange(AccessBridge_PropertyNameChangeFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetPropertyNameChange(fp);
- }
- }
-
- void SetPropertyDescriptionChange(AccessBridge_PropertyDescriptionChangeFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetPropertyDescriptionChange(fp);
- }
- }
-
- void SetPropertyStateChange(AccessBridge_PropertyStateChangeFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetPropertyStateChange(fp);
- }
- }
-
- void SetPropertyValueChange(AccessBridge_PropertyValueChangeFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetPropertyValueChange(fp);
- }
- }
-
- void SetPropertySelectionChange(AccessBridge_PropertySelectionChangeFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetPropertySelectionChange(fp);
- }
- }
-
- void SetPropertyTextChange(AccessBridge_PropertyTextChangeFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetPropertyTextChange(fp);
- }
- }
-
- void SetPropertyCaretChange(AccessBridge_PropertyCaretChangeFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetPropertyCaretChange(fp);
- }
- }
-
- void SetPropertyVisibleDataChange(AccessBridge_PropertyVisibleDataChangeFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetPropertyVisibleDataChange(fp);
- }
- }
-
- void SetPropertyChildChange(AccessBridge_PropertyChildChangeFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetPropertyChildChange(fp);
- }
- }
-
- void SetPropertyActiveDescendentChange(AccessBridge_PropertyActiveDescendentChangeFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetPropertyActiveDescendentChange(fp);
- }
- }
-
- void SetPropertyTableModelChange(AccessBridge_PropertyTableModelChangeFP fp) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SetPropertyTableModelChange(fp);
- }
- }
-
- /**
- * General routines
- */
- void ReleaseJavaObject(long vmID, Java_Object object) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.ReleaseJavaObject(vmID, object);
- }
- }
-
- BOOL GetVersionInfo(long vmID, AccessBridgeVersionInfo *info) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetVersionInfo(vmID, info);
- }
- return FALSE;
- }
-
-
- /**
- * Window routines
- */
- BOOL IsJavaWindow(HWND window) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- BOOL ret ;
- ret = theAccessBridge.IsJavaWindow(window);
- return ret ;
-
- }
- return FALSE;
- }
-
-
- /**
- * Returns the virtual machine ID and AccessibleContext for a top-level window
- */
- BOOL GetAccessibleContextFromHWND(HWND target, long *vmID, AccessibleContext *ac) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetAccessibleContextFromHWND(target, vmID, ac);
- }
- return FALSE;
- }
-
- /**
- * Returns the HWND from the AccessibleContext of a top-level window. Returns 0
- * on error or if the AccessibleContext does not refer to a top-level window.
- */
- HWND getHWNDFromAccessibleContext(long vmID, JOBJECT64 accesibleContext) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getHWNDFromAccessibleContext(vmID, accesibleContext);
- }
- return (HWND)0;
- }
-
- /**
- * returns whether two objects are the same
- */
- BOOL IsSameObject(long vmID, JOBJECT64 obj1, JOBJECT64 obj2) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.IsSameObject(vmID, obj1, obj2);
- }
- return FALSE;
- }
-
- /**
- * Sets editable text contents. The AccessibleContext must implement AccessibleEditableText and
- * be editable. The maximum text length is MAX_STRING_SIZE - 1.
- * Returns whether successful
- */
- BOOL setTextContents (const long vmID, const AccessibleContext accessibleContext, const wchar_t *text) {
-
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.setTextContents(vmID, accessibleContext, text);
- }
- return FALSE;
- }
-
- /**
- * Returns the Accessible Context with the specified role that is the
- * ancestor of a given object. The role is one of the role strings
- * defined in AccessBridgePackages.h
- * If there is no ancestor object that has the specified role,
- * returns (AccessibleContext)0.
- */
- AccessibleContext getParentWithRole (const long vmID, const AccessibleContext accessibleContext,
- const wchar_t *role) {
-
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getParentWithRole(vmID, accessibleContext, role);
- }
- return (AccessibleContext)0;
- }
-
- /**
- * Returns the Accessible Context with the specified role that is the
- * ancestor of a given object. The role is one of the role strings
- * defined in AccessBridgePackages.h. If an object with the specified
- * role does not exist, returns the top level object for the Java Window.
- * Returns (AccessibleContext)0 on error.
- */
- AccessibleContext getParentWithRoleElseRoot (const long vmID, const AccessibleContext accessibleContext,
- const wchar_t *role) {
-
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getParentWithRoleElseRoot(vmID, accessibleContext, role);
- }
- return (AccessibleContext)0;
- }
-
- /**
- * Returns the Accessible Context for the top level object in
- * a Java Window. This is same Accessible Context that is obtained
- * from GetAccessibleContextFromHWND for that window. Returns
- * (AccessibleContext)0 on error.
- */
- AccessibleContext getTopLevelObject (const long vmID, const AccessibleContext accessibleContext) {
-
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getTopLevelObject(vmID, accessibleContext);
- }
- return (AccessibleContext)0;
- }
-
- /**
- * Returns how deep in the object hierarchy a given object is.
- * The top most object in the object hierarchy has an object depth of 0.
- * Returns -1 on error.
- */
- int getObjectDepth (const long vmID, const AccessibleContext accessibleContext) {
-
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getObjectDepth(vmID, accessibleContext);
- }
- return -1;
- }
-
- /**
- * Returns the Accessible Context of the current ActiveDescendent of an object.
- * This method assumes the ActiveDescendent is the component that is currently
- * selected in a container object.
- * Returns (AccessibleContext)0 on error or if there is no selection.
- */
- AccessibleContext getActiveDescendent (const long vmID, const AccessibleContext accessibleContext) {
-
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getActiveDescendent(vmID, accessibleContext);
- }
- return (AccessibleContext)0;
- }
-
-
- /**
- * Accessible Context routines
- */
- BOOL GetAccessibleContextAt(long vmID, AccessibleContext acParent,
- jint x, jint y, AccessibleContext *ac) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetAccessibleContextAt(vmID, acParent, x, y, ac);
- }
- return FALSE;
- }
-
- BOOL GetAccessibleContextWithFocus(HWND window, long *vmID, AccessibleContext *ac) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetAccessibleContextWithFocus(window, vmID, ac);
- }
- return FALSE;
- }
-
- BOOL GetAccessibleContextInfo(long vmID, AccessibleContext ac, AccessibleContextInfo *info) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetAccessibleContextInfo(vmID, ac, info);
- }
- return FALSE;
- }
-
- AccessibleContext GetAccessibleChildFromContext(long vmID, AccessibleContext ac, jint index) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetAccessibleChildFromContext(vmID, ac, index);
- }
- return (AccessibleContext) 0;
- }
-
- AccessibleContext GetAccessibleParentFromContext(long vmID, AccessibleContext ac) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetAccessibleParentFromContext(vmID, ac);
- }
- return (AccessibleContext) 0;
- }
-
- /* begin AccessibleTable routines */
-
- /*
- * get information about an AccessibleTable
- */
- BOOL getAccessibleTableInfo(long vmID, AccessibleContext acParent, AccessibleTableInfo *tableInfo) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleTableInfo(vmID, acParent, tableInfo);
- }
- return FALSE;
- }
-
- /*
- * get information about an AccessibleTable cell
- */
- BOOL getAccessibleTableCellInfo(long vmID, AccessibleTable accessibleTable,
- jint row, jint column, AccessibleTableCellInfo *tableCellInfo) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleTableCellInfo(vmID, accessibleTable, row, column, tableCellInfo);
- }
- return FALSE;
- }
-
- /*
- * get information about an AccessibleTable row header
- */
- BOOL getAccessibleTableRowHeader(long vmID, AccessibleContext acParent, AccessibleTableInfo *tableInfo) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleTableRowHeader(vmID, acParent, tableInfo);
- }
- return FALSE;
- }
-
- /*
- * get information about an AccessibleTable column header
- */
- BOOL getAccessibleTableColumnHeader(long vmID, AccessibleContext acParent, AccessibleTableInfo *tableInfo) {
-
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleTableColumnHeader(vmID, acParent, tableInfo);
- }
- return FALSE;
- }
-
- /*
- * return a description of an AccessibleTable row header
- */
- AccessibleContext getAccessibleTableRowDescription(long vmID, AccessibleContext acParent, jint row) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleTableRowDescription(vmID, acParent, row);
- }
- return (AccessibleContext)0;
- }
-
- /*
- * return a description of an AccessibleTable column header
- */
- AccessibleContext getAccessibleTableColumnDescription(long vmID, AccessibleContext acParent, jint column) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleTableColumnDescription(vmID, acParent, column);
- }
- return (AccessibleContext)0;
- }
-
- /*
- * return the number of rows selected in an AccessibleTable
- */
- jint getAccessibleTableRowSelectionCount(long vmID, AccessibleTable table) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleTableRowSelectionCount(vmID, table);
- }
- return -1;
- }
-
- /*
- * return whether a row is selected in an AccessibleTable
- */
- BOOL isAccessibleTableRowSelected(long vmID, AccessibleTable table, jint row) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.isAccessibleTableRowSelected(vmID, table, row);
- }
- return FALSE;
- }
-
- /*
- * get an array of selected rows in an AccessibleTable
- */
- BOOL getAccessibleTableRowSelections(long vmID, AccessibleTable table, jint count, jint *selections) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleTableRowSelections(vmID, table, count, selections);
- }
- return FALSE;
- }
-
- /*
- * return the number of columns selected in an AccessibleTable
- */
- jint getAccessibleTableColumnSelectionCount(long vmID, AccessibleTable table) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleTableColumnSelectionCount(vmID, table);
- }
- return -1;
- }
-
- /*
- * return whether a column is selected in an AccessibleTable
- */
- BOOL isAccessibleTableColumnSelected(long vmID, AccessibleTable table, jint column) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.isAccessibleTableColumnSelected(vmID, table, column);
- }
- return FALSE;
- }
-
- /*
- * get an array of columns selected in an AccessibleTable
- */
- BOOL getAccessibleTableColumnSelections(long vmID, AccessibleTable table, jint count, jint *selections) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleTableColumnSelections(vmID, table, count, selections);
- }
- return FALSE;
- }
-
- /*
- * return the row number for a cell at a given index
- */
- jint
- getAccessibleTableRow(long vmID, AccessibleTable table, jint index) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleTableRow(vmID, table, index);
- }
- return -1;
- }
-
- /*
- * return the column number for a cell at a given index
- */
- jint
- getAccessibleTableColumn(long vmID, AccessibleTable table, jint index) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleTableColumn(vmID, table, index);
- }
- return -1;
- }
-
- /*
- * return the index of a cell at a given row and column
- */
- jint
- getAccessibleTableIndex(long vmID, AccessibleTable table, jint row, jint column) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleTableIndex(vmID, table, row, column);
- }
- return -1;
- }
-
- /* end AccessibleTable routines */
-
-
- /**
- * Accessible Text routines
- */
- BOOL GetAccessibleTextInfo(long vmID, AccessibleText at, AccessibleTextInfo *textInfo, jint x, jint y) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetAccessibleTextInfo(vmID, at, textInfo, x, y);
- }
- return FALSE;
- }
-
- BOOL GetAccessibleTextItems(long vmID, AccessibleText at, AccessibleTextItemsInfo *textItems, jint index) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetAccessibleTextItems(vmID, at, textItems, index);
- }
- return FALSE;
- }
-
- BOOL GetAccessibleTextSelectionInfo(long vmID, AccessibleText at, AccessibleTextSelectionInfo *textSelection) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetAccessibleTextSelectionInfo(vmID, at, textSelection);
- }
- return FALSE;
- }
-
- BOOL GetAccessibleTextAttributes(long vmID, AccessibleText at, jint index, AccessibleTextAttributesInfo *attributes) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetAccessibleTextAttributes(vmID, at, index, attributes);
- }
- return FALSE;
- }
-
- BOOL GetAccessibleTextRect(long vmID, AccessibleText at, AccessibleTextRectInfo *rectInfo, jint index) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetAccessibleTextRect(vmID, at, rectInfo, index);
- }
- return FALSE;
- }
-
- BOOL GetAccessibleTextLineBounds(long vmID, AccessibleText at, jint index, jint *startIndex, jint *endIndex) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetAccessibleTextLineBounds(vmID, at, index, startIndex, endIndex);
- }
- return FALSE;
- }
-
- BOOL GetAccessibleTextRange(long vmID, AccessibleText at, jint start, jint end, wchar_t *text, short len) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetAccessibleTextRange(vmID, at, start, end, text, len);
- }
- return FALSE;
- }
-
- /**
- * AccessibleRelationSet routines
- */
- BOOL getAccessibleRelationSet(long vmID, AccessibleContext accessibleContext,
- AccessibleRelationSetInfo *relationSetInfo) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleRelationSet(vmID, accessibleContext, relationSetInfo);
- }
- return FALSE;
- }
-
- /**
- * AccessibleHypertext routines
- */
-
- // Gets AccessibleHypertext for an AccessibleContext
- BOOL getAccessibleHypertext(long vmID, AccessibleContext accessibleContext,
- AccessibleHypertextInfo *hypertextInfo) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleHypertext(vmID, accessibleContext, hypertextInfo);
- }
- return FALSE;
- }
-
- // Activates an AccessibleHyperlink for an AccessibleContext
- BOOL activateAccessibleHyperlink(long vmID, AccessibleContext accessibleContext,
- AccessibleHyperlink accessibleHyperlink) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.activateAccessibleHyperlink(vmID, accessibleContext, accessibleHyperlink);
- }
- return FALSE;
- }
-
- /*
- * Returns the number of hyperlinks in a component
- * Maps to AccessibleHypertext.getLinkCount.
- * Returns -1 on error.
- */
- jint getAccessibleHyperlinkCount(const long vmID,
- const AccessibleContext accessibleContext) {
-
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleHyperlinkCount(vmID, accessibleContext);
- }
- return -1;
- }
-
- /*
- * This method is used to iterate through the hyperlinks in a component. It
- * returns hypertext information for a component starting at hyperlink index
- * nStartIndex. No more than MAX_HYPERLINKS AccessibleHypertextInfo objects will
- * be returned for each call to this method.
- * returns FALSE on error.
- */
- BOOL getAccessibleHypertextExt(const long vmID,
- const AccessibleContext accessibleContext,
- const jint nStartIndex,
- /* OUT */ AccessibleHypertextInfo *hypertextInfo) {
-
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleHypertextExt(vmID,
- accessibleContext,
- nStartIndex,
- hypertextInfo);
- }
- return FALSE;
- }
-
- /*
- * Returns the index into an array of hyperlinks that is associated with
- * a character index in document;
- * Maps to AccessibleHypertext.getLinkIndex.
- * Returns -1 on error.
- */
- jint getAccessibleHypertextLinkIndex(const long vmID,
- const AccessibleHypertext hypertext,
- const jint nIndex) {
-
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleHypertextLinkIndex(vmID,
- hypertext,
- nIndex);
- }
- return -1;
- }
-
- /*
- * Returns the nth hyperlink in a document.
- * Maps to AccessibleHypertext.getLink.
- * Returns -1 on error
- */
- BOOL getAccessibleHyperlink(const long vmID,
- const AccessibleHypertext hypertext,
- const jint nIndex,
- /* OUT */ AccessibleHyperlinkInfo *hyperlinkInfo) {
-
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleHyperlink(vmID,
- hypertext,
- nIndex,
- hyperlinkInfo);
- }
- return FALSE;
- }
-
-
- /* Accessible KeyBindings, Icons and Actions */
- BOOL getAccessibleKeyBindings(long vmID, AccessibleContext accessibleContext,
- AccessibleKeyBindings *keyBindings) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleKeyBindings(vmID, accessibleContext, keyBindings);
- }
- return FALSE;
- }
-
- BOOL getAccessibleIcons(long vmID, AccessibleContext accessibleContext,
- AccessibleIcons *icons) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleIcons(vmID, accessibleContext, icons);
- }
- return FALSE;
- }
-
- BOOL getAccessibleActions(long vmID, AccessibleContext accessibleContext,
- AccessibleActions *actions) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getAccessibleActions(vmID, accessibleContext, actions);
- }
- return FALSE;
- }
-
- BOOL doAccessibleActions(long vmID, AccessibleContext accessibleContext,
- AccessibleActionsToDo *actionsToDo, jint *failure) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.doAccessibleActions(vmID, accessibleContext, actionsToDo, failure);
- }
- return FALSE;
- }
-
- /**
- * Accessible Value routines
- */
- BOOL GetCurrentAccessibleValueFromContext(long vmID, AccessibleValue av, wchar_t *value, short len) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetCurrentAccessibleValueFromContext(vmID, av, value, len);
- }
- return FALSE;
- }
-
- BOOL GetMaximumAccessibleValueFromContext(long vmID, AccessibleValue av, wchar_t *value, short len) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetMaximumAccessibleValueFromContext(vmID, av, value, len);
- }
- return FALSE;
- }
-
- BOOL GetMinimumAccessibleValueFromContext(long vmID, AccessibleValue av, wchar_t *value, short len) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetMinimumAccessibleValueFromContext(vmID, av, value, len);
- }
- return FALSE;
- }
-
-
- /**
- * Accessible Selection routines
- */
- void addAccessibleSelectionFromContext(long vmID, AccessibleSelection as, int i) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.AddAccessibleSelectionFromContext(vmID, as, i);
- }
- }
-
- void clearAccessibleSelectionFromContext(long vmID, AccessibleSelection as) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.ClearAccessibleSelectionFromContext(vmID, as);
- }
- }
-
- JOBJECT64 GetAccessibleSelectionFromContext(long vmID, AccessibleSelection as, int i) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetAccessibleSelectionFromContext(vmID, as, i);
- }
- return (JOBJECT64) 0;
- }
-
- int GetAccessibleSelectionCountFromContext(long vmID, AccessibleSelection as) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.GetAccessibleSelectionCountFromContext(vmID, as);
- }
- return -1;
- }
-
- BOOL IsAccessibleChildSelectedFromContext(long vmID, AccessibleSelection as, int i) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.IsAccessibleChildSelectedFromContext(vmID, as, i);
- }
- return FALSE;
- }
-
- void RemoveAccessibleSelectionFromContext(long vmID, AccessibleSelection as, int i) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.RemoveAccessibleSelectionFromContext(vmID, as, i);
- }
- }
-
- void SelectAllAccessibleSelectionFromContext(long vmID, AccessibleSelection as) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- theAccessBridge.SelectAllAccessibleSelectionFromContext(vmID, as);
- }
- }
-
- /**
- * Additional methods for Teton
- */
-
- /**
- * Gets the AccessibleName for a component based upon the JAWS algorithm. Returns
- * whether successful.
- *
- * Bug ID 4916682 - Implement JAWS AccessibleName policy
- */
- BOOL getVirtualAccessibleName(const long vmID, const AccessibleContext accessibleContext,
- wchar_t *name, int len) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getVirtualAccessibleName(vmID, accessibleContext, name, len);
- }
- return FALSE;
- }
-
- /**
- * Request focus for a component. Returns whether successful;
- *
- * Bug ID 4944757 - requestFocus method needed
- */
- BOOL requestFocus(const long vmID, const AccessibleContext accessibleContext) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.requestFocus(vmID, accessibleContext);
- }
- return FALSE;
- }
-
- /**
- * Selects text between two indices. Selection includes the text at the start index
- * and the text at the end index. Returns whether successful;
- *
- * Bug ID 4944758 - selectTextRange method needed
- */
- BOOL selectTextRange(const long vmID, const AccessibleContext accessibleContext,
- const int startIndex, const int endIndex) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.selectTextRange(vmID, accessibleContext, startIndex, endIndex);
- }
- return FALSE;
- }
-
- /**
- * Get text attributes between two indices. The attribute list includes the text at the
- * start index and the text at the end index. Returns whether successful;
- *
- * Bug ID 4944761 - getTextAttributes between two indices method needed
- */
- BOOL getTextAttributesInRange(const long vmID, const AccessibleContext accessibleContext,
- const int startIndex, const int endIndex,
- AccessibleTextAttributesInfo *attributes, short *len) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getTextAttributesInRange(vmID, accessibleContext, startIndex,
- endIndex, attributes, len);
- }
- return FALSE;
- }
-
- /**
- * Returns the number of visible children of a component. Returns -1 on error.
- *
- * Bug ID 4944762- getVisibleChildren for list-like components needed
- */
- int getVisibleChildrenCount(const long vmID, const AccessibleContext accessibleContext) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getVisibleChildrenCount(vmID, accessibleContext);
- }
- return FALSE;
- }
-
- /**
- * Gets the visible children of an AccessibleContext. Returns whether successful;
- *
- * Bug ID 4944762- getVisibleChildren for list-like components needed
- */
- BOOL getVisibleChildren(const long vmID, const AccessibleContext accessibleContext,
- const int startIndex, VisibleChildrenInfo *visibleChildrenInfo) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getVisibleChildren(vmID, accessibleContext, startIndex,
- visibleChildrenInfo);
- }
- return FALSE;
- }
-
- /**
- * Set the caret to a text position. Returns whether successful;
- *
- * Bug ID 4944770 - setCaretPosition method needed
- */
- BOOL setCaretPosition(const long vmID, const AccessibleContext accessibleContext,
- const int position) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.setCaretPosition(vmID, accessibleContext, position);
- }
- return FALSE;
- }
-
- /**
- * Gets the text caret location
- */
- BOOL getCaretLocation(long vmID, AccessibleContext ac, AccessibleTextRectInfo *rectInfo, jint index) {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getCaretLocation(vmID, ac, rectInfo, index);
- }
- return FALSE;
- }
-
- /**
- * Gets the number of events waiting to fire
- */
- int getEventsWaiting() {
- if (theAccessBridgeInitializedFlag == TRUE) {
- return theAccessBridge.getEventsWaiting();
- }
- return FALSE;
- }
-
-#ifdef __cplusplus
-}
-#endif
diff --git a/demos/java/jni/gs_jni/include/win32/bridge/AccessBridgeCalls.h b/demos/java/jni/gs_jni/include/win32/bridge/AccessBridgeCalls.h
deleted file mode 100644
index ad007400..00000000
--- a/demos/java/jni/gs_jni/include/win32/bridge/AccessBridgeCalls.h
+++ /dev/null
@@ -1,706 +0,0 @@
-/*
- * Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
- * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- */
-
-/*
- * Wrapper functions around calls to the AccessBridge DLL
- */
-
-#include <windows.h>
-#include <jni.h>
-#include "AccessBridgeCallbacks.h"
-#include "AccessBridgePackages.h"
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#define null NULL
-
- typedef JOBJECT64 AccessibleContext;
- typedef JOBJECT64 AccessibleText;
- typedef JOBJECT64 AccessibleValue;
- typedef JOBJECT64 AccessibleSelection;
- typedef JOBJECT64 Java_Object;
- typedef JOBJECT64 PropertyChangeEvent;
- typedef JOBJECT64 FocusEvent;
- typedef JOBJECT64 CaretEvent;
- typedef JOBJECT64 MouseEvent;
- typedef JOBJECT64 MenuEvent;
- typedef JOBJECT64 AccessibleTable;
- typedef JOBJECT64 AccessibleHyperlink;
- typedef JOBJECT64 AccessibleHypertext;
-
-
- typedef void (*Windows_runFP) ();
-
- typedef void (*SetPropertyChangeFP) (AccessBridge_PropertyChangeFP fp);
-
- typedef void (*SetJavaShutdownFP) (AccessBridge_JavaShutdownFP fp);
- typedef void (*SetFocusGainedFP) (AccessBridge_FocusGainedFP fp);
- typedef void (*SetFocusLostFP) (AccessBridge_FocusLostFP fp);
-
- typedef void (*SetCaretUpdateFP) (AccessBridge_CaretUpdateFP fp);
-
- typedef void (*SetMouseClickedFP) (AccessBridge_MouseClickedFP fp);
- typedef void (*SetMouseEnteredFP) (AccessBridge_MouseEnteredFP fp);
- typedef void (*SetMouseExitedFP) (AccessBridge_MouseExitedFP fp);
- typedef void (*SetMousePressedFP) (AccessBridge_MousePressedFP fp);
- typedef void (*SetMouseReleasedFP) (AccessBridge_MouseReleasedFP fp);
-
- typedef void (*SetMenuCanceledFP) (AccessBridge_MenuCanceledFP fp);
- typedef void (*SetMenuDeselectedFP) (AccessBridge_MenuDeselectedFP fp);
- typedef void (*SetMenuSelectedFP) (AccessBridge_MenuSelectedFP fp);
- typedef void (*SetPopupMenuCanceledFP) (AccessBridge_PopupMenuCanceledFP fp);
- typedef void (*SetPopupMenuWillBecomeInvisibleFP) (AccessBridge_PopupMenuWillBecomeInvisibleFP fp);
- typedef void (*SetPopupMenuWillBecomeVisibleFP) (AccessBridge_PopupMenuWillBecomeVisibleFP fp);
-
- typedef void (*SetPropertyNameChangeFP) (AccessBridge_PropertyNameChangeFP fp);
- typedef void (*SetPropertyDescriptionChangeFP) (AccessBridge_PropertyDescriptionChangeFP fp);
- typedef void (*SetPropertyStateChangeFP) (AccessBridge_PropertyStateChangeFP fp);
- typedef void (*SetPropertyValueChangeFP) (AccessBridge_PropertyValueChangeFP fp);
- typedef void (*SetPropertySelectionChangeFP) (AccessBridge_PropertySelectionChangeFP fp);
- typedef void (*SetPropertyTextChangeFP) (AccessBridge_PropertyTextChangeFP fp);
- typedef void (*SetPropertyCaretChangeFP) (AccessBridge_PropertyCaretChangeFP fp);
- typedef void (*SetPropertyVisibleDataChangeFP) (AccessBridge_PropertyVisibleDataChangeFP fp);
- typedef void (*SetPropertyChildChangeFP) (AccessBridge_PropertyChildChangeFP fp);
- typedef void (*SetPropertyActiveDescendentChangeFP) (AccessBridge_PropertyActiveDescendentChangeFP fp);
-
- typedef void (*SetPropertyTableModelChangeFP) (AccessBridge_PropertyTableModelChangeFP fp);
-
- typedef void (*ReleaseJavaObjectFP) (long vmID, Java_Object object);
-
- typedef BOOL (*GetVersionInfoFP) (long vmID, AccessBridgeVersionInfo *info);
-
- typedef BOOL (*IsJavaWindowFP) (HWND window);
- typedef BOOL (*IsSameObjectFP) (long vmID, JOBJECT64 obj1, JOBJECT64 obj2);
- typedef BOOL (*GetAccessibleContextFromHWNDFP) (HWND window, long *vmID, AccessibleContext *ac);
- typedef HWND (*getHWNDFromAccessibleContextFP) (long vmID, AccessibleContext ac);
-
- typedef BOOL (*GetAccessibleContextAtFP) (long vmID, AccessibleContext acParent,
- jint x, jint y, AccessibleContext *ac);
- typedef BOOL (*GetAccessibleContextWithFocusFP) (HWND window, long *vmID, AccessibleContext *ac);
- typedef BOOL (*GetAccessibleContextInfoFP) (long vmID, AccessibleContext ac, AccessibleContextInfo *info);
- typedef AccessibleContext (*GetAccessibleChildFromContextFP) (long vmID, AccessibleContext ac, jint i);
- typedef AccessibleContext (*GetAccessibleParentFromContextFP) (long vmID, AccessibleContext ac);
-
- /* begin AccessibleTable */
- typedef BOOL (*getAccessibleTableInfoFP) (long vmID, AccessibleContext ac, AccessibleTableInfo *tableInfo);
- typedef BOOL (*getAccessibleTableCellInfoFP) (long vmID, AccessibleTable accessibleTable,
- jint row, jint column, AccessibleTableCellInfo *tableCellInfo);
-
- typedef BOOL (*getAccessibleTableRowHeaderFP) (long vmID, AccessibleContext acParent, AccessibleTableInfo *tableInfo);
- typedef BOOL (*getAccessibleTableColumnHeaderFP) (long vmID, AccessibleContext acParent, AccessibleTableInfo *tableInfo);
-
- typedef AccessibleContext (*getAccessibleTableRowDescriptionFP) (long vmID, AccessibleContext acParent, jint row);
- typedef AccessibleContext (*getAccessibleTableColumnDescriptionFP) (long vmID, AccessibleContext acParent, jint column);
-
- typedef jint (*getAccessibleTableRowSelectionCountFP) (long vmID, AccessibleTable table);
- typedef BOOL (*isAccessibleTableRowSelectedFP) (long vmID, AccessibleTable table, jint row);
- typedef BOOL (*getAccessibleTableRowSelectionsFP) (long vmID, AccessibleTable table, jint count,
- jint *selections);
-
- typedef jint (*getAccessibleTableColumnSelectionCountFP) (long vmID, AccessibleTable table);
- typedef BOOL (*isAccessibleTableColumnSelectedFP) (long vmID, AccessibleTable table, jint column);
- typedef BOOL (*getAccessibleTableColumnSelectionsFP) (long vmID, AccessibleTable table, jint count,
- jint *selections);
-
- typedef jint (*getAccessibleTableRowFP) (long vmID, AccessibleTable table, jint index);
- typedef jint (*getAccessibleTableColumnFP) (long vmID, AccessibleTable table, jint index);
- typedef jint (*getAccessibleTableIndexFP) (long vmID, AccessibleTable table, jint row, jint column);
- /* end AccessibleTable */
-
- /* AccessibleRelationSet */
- typedef BOOL (*getAccessibleRelationSetFP) (long vmID, AccessibleContext accessibleContext,
- AccessibleRelationSetInfo *relationSetInfo);
-
- /* AccessibleHypertext */
- typedef BOOL (*getAccessibleHypertextFP)(long vmID, AccessibleContext accessibleContext,
- AccessibleHypertextInfo *hypertextInfo);
-
- typedef BOOL (*activateAccessibleHyperlinkFP)(long vmID, AccessibleContext accessibleContext,
- AccessibleHyperlink accessibleHyperlink);
-
- typedef jint (*getAccessibleHyperlinkCountFP)(const long vmID,
- const AccessibleContext accessibleContext);
-
- typedef BOOL (*getAccessibleHypertextExtFP) (const long vmID,
- const AccessibleContext accessibleContext,
- const jint nStartIndex,
- AccessibleHypertextInfo *hypertextInfo);
-
- typedef jint (*getAccessibleHypertextLinkIndexFP)(const long vmID,
- const AccessibleHypertext hypertext,
- const jint nIndex);
-
- typedef BOOL (*getAccessibleHyperlinkFP)(const long vmID,
- const AccessibleHypertext hypertext,
- const jint nIndex,
- AccessibleHyperlinkInfo *hyperlinkInfo);
-
-
- /* Accessible KeyBindings, Icons and Actions */
- typedef BOOL (*getAccessibleKeyBindingsFP)(long vmID, AccessibleContext accessibleContext,
- AccessibleKeyBindings *keyBindings);
-
- typedef BOOL (*getAccessibleIconsFP)(long vmID, AccessibleContext accessibleContext,
- AccessibleIcons *icons);
-
- typedef BOOL (*getAccessibleActionsFP)(long vmID, AccessibleContext accessibleContext,
- AccessibleActions *actions);
-
- typedef BOOL (*doAccessibleActionsFP)(long vmID, AccessibleContext accessibleContext,
- AccessibleActionsToDo *actionsToDo, jint *failure);
-
-
- /* AccessibleText */
-
- typedef BOOL (*GetAccessibleTextInfoFP) (long vmID, AccessibleText at, AccessibleTextInfo *textInfo, jint x, jint y);
- typedef BOOL (*GetAccessibleTextItemsFP) (long vmID, AccessibleText at, AccessibleTextItemsInfo *textItems, jint index);
- typedef BOOL (*GetAccessibleTextSelectionInfoFP) (long vmID, AccessibleText at, AccessibleTextSelectionInfo *textSelection);
- typedef BOOL (*GetAccessibleTextAttributesFP) (long vmID, AccessibleText at, jint index, AccessibleTextAttributesInfo *attributes);
- typedef BOOL (*GetAccessibleTextRectFP) (long vmID, AccessibleText at, AccessibleTextRectInfo *rectInfo, jint index);
- typedef BOOL (*GetAccessibleTextLineBoundsFP) (long vmID, AccessibleText at, jint index, jint *startIndex, jint *endIndex);
- typedef BOOL (*GetAccessibleTextRangeFP) (long vmID, AccessibleText at, jint start, jint end, wchar_t *text, short len);
-
- typedef BOOL (*GetCurrentAccessibleValueFromContextFP) (long vmID, AccessibleValue av, wchar_t *value, short len);
- typedef BOOL (*GetMaximumAccessibleValueFromContextFP) (long vmID, AccessibleValue av, wchar_t *value, short len);
- typedef BOOL (*GetMinimumAccessibleValueFromContextFP) (long vmID, AccessibleValue av, wchar_t *value, short len);
-
- typedef void (*AddAccessibleSelectionFromContextFP) (long vmID, AccessibleSelection as, int i);
- typedef void (*ClearAccessibleSelectionFromContextFP) (long vmID, AccessibleSelection as);
- typedef JOBJECT64 (*GetAccessibleSelectionFromContextFP) (long vmID, AccessibleSelection as, int i);
- typedef int (*GetAccessibleSelectionCountFromContextFP) (long vmID, AccessibleSelection as);
- typedef BOOL (*IsAccessibleChildSelectedFromContextFP) (long vmID, AccessibleSelection as, int i);
- typedef void (*RemoveAccessibleSelectionFromContextFP) (long vmID, AccessibleSelection as, int i);
- typedef void (*SelectAllAccessibleSelectionFromContextFP) (long vmID, AccessibleSelection as);
-
- /* Utility methods */
-
- typedef BOOL (*setTextContentsFP) (const long vmID, const AccessibleContext ac, const wchar_t *text);
- typedef AccessibleContext (*getParentWithRoleFP) (const long vmID, const AccessibleContext ac, const wchar_t *role);
- typedef AccessibleContext (*getParentWithRoleElseRootFP) (const long vmID, const AccessibleContext ac, const wchar_t *role);
- typedef AccessibleContext (*getTopLevelObjectFP) (const long vmID, const AccessibleContext ac);
- typedef int (*getObjectDepthFP) (const long vmID, const AccessibleContext ac);
- typedef AccessibleContext (*getActiveDescendentFP) (const long vmID, const AccessibleContext ac);
-
-
- typedef BOOL (*getVirtualAccessibleNameFP) (const long vmID, const AccessibleContext accessibleContext,
- wchar_t *name, int len);
-
- typedef BOOL (*requestFocusFP) (const long vmID, const AccessibleContext accessibleContext);
-
- typedef BOOL (*selectTextRangeFP) (const long vmID, const AccessibleContext accessibleContext,
- const int startIndex, const int endIndex);
-
- typedef BOOL (*getTextAttributesInRangeFP) (const long vmID, const AccessibleContext accessibleContext,
- const int startIndex, const int endIndex,
- AccessibleTextAttributesInfo *attributes, short *len);
-
- typedef int (*getVisibleChildrenCountFP) (const long vmID, const AccessibleContext accessibleContext);
-
- typedef BOOL (*getVisibleChildrenFP) (const long vmID, const AccessibleContext accessibleContext,
- const int startIndex, VisibleChildrenInfo *children);
-
- typedef BOOL (*setCaretPositionFP) (const long vmID, const AccessibleContext accessibleContext, const int position);
-
- typedef BOOL (*getCaretLocationFP) (long vmID, AccessibleContext ac, AccessibleTextRectInfo *rectInfo, jint index);
-
- typedef int (*getEventsWaitingFP) ();
-
- typedef struct AccessBridgeFPsTag {
- Windows_runFP Windows_run;
-
- SetPropertyChangeFP SetPropertyChange;
-
- SetJavaShutdownFP SetJavaShutdown;
- SetFocusGainedFP SetFocusGained;
- SetFocusLostFP SetFocusLost;
-
- SetCaretUpdateFP SetCaretUpdate;
-
- SetMouseClickedFP SetMouseClicked;
- SetMouseEnteredFP SetMouseEntered;
- SetMouseExitedFP SetMouseExited;
- SetMousePressedFP SetMousePressed;
- SetMouseReleasedFP SetMouseReleased;
-
- SetMenuCanceledFP SetMenuCanceled;
- SetMenuDeselectedFP SetMenuDeselected;
- SetMenuSelectedFP SetMenuSelected;
- SetPopupMenuCanceledFP SetPopupMenuCanceled;
- SetPopupMenuWillBecomeInvisibleFP SetPopupMenuWillBecomeInvisible;
- SetPopupMenuWillBecomeVisibleFP SetPopupMenuWillBecomeVisible;
-
- SetPropertyNameChangeFP SetPropertyNameChange;
- SetPropertyDescriptionChangeFP SetPropertyDescriptionChange;
- SetPropertyStateChangeFP SetPropertyStateChange;
- SetPropertyValueChangeFP SetPropertyValueChange;
- SetPropertySelectionChangeFP SetPropertySelectionChange;
- SetPropertyTextChangeFP SetPropertyTextChange;
- SetPropertyCaretChangeFP SetPropertyCaretChange;
- SetPropertyVisibleDataChangeFP SetPropertyVisibleDataChange;
- SetPropertyChildChangeFP SetPropertyChildChange;
- SetPropertyActiveDescendentChangeFP SetPropertyActiveDescendentChange;
-
- SetPropertyTableModelChangeFP SetPropertyTableModelChange;
-
- ReleaseJavaObjectFP ReleaseJavaObject;
- GetVersionInfoFP GetVersionInfo;
-
- IsJavaWindowFP IsJavaWindow;
- IsSameObjectFP IsSameObject;
- GetAccessibleContextFromHWNDFP GetAccessibleContextFromHWND;
- getHWNDFromAccessibleContextFP getHWNDFromAccessibleContext;
-
- GetAccessibleContextAtFP GetAccessibleContextAt;
- GetAccessibleContextWithFocusFP GetAccessibleContextWithFocus;
- GetAccessibleContextInfoFP GetAccessibleContextInfo;
- GetAccessibleChildFromContextFP GetAccessibleChildFromContext;
- GetAccessibleParentFromContextFP GetAccessibleParentFromContext;
-
- getAccessibleTableInfoFP getAccessibleTableInfo;
- getAccessibleTableCellInfoFP getAccessibleTableCellInfo;
-
- getAccessibleTableRowHeaderFP getAccessibleTableRowHeader;
- getAccessibleTableColumnHeaderFP getAccessibleTableColumnHeader;
-
- getAccessibleTableRowDescriptionFP getAccessibleTableRowDescription;
- getAccessibleTableColumnDescriptionFP getAccessibleTableColumnDescription;
-
- getAccessibleTableRowSelectionCountFP getAccessibleTableRowSelectionCount;
- isAccessibleTableRowSelectedFP isAccessibleTableRowSelected;
- getAccessibleTableRowSelectionsFP getAccessibleTableRowSelections;
-
- getAccessibleTableColumnSelectionCountFP getAccessibleTableColumnSelectionCount;
- isAccessibleTableColumnSelectedFP isAccessibleTableColumnSelected;
- getAccessibleTableColumnSelectionsFP getAccessibleTableColumnSelections;
-
- getAccessibleTableRowFP getAccessibleTableRow;
- getAccessibleTableColumnFP getAccessibleTableColumn;
- getAccessibleTableIndexFP getAccessibleTableIndex;
-
- getAccessibleRelationSetFP getAccessibleRelationSet;
-
- getAccessibleHypertextFP getAccessibleHypertext;
- activateAccessibleHyperlinkFP activateAccessibleHyperlink;
- getAccessibleHyperlinkCountFP getAccessibleHyperlinkCount;
- getAccessibleHypertextExtFP getAccessibleHypertextExt;
- getAccessibleHypertextLinkIndexFP getAccessibleHypertextLinkIndex;
- getAccessibleHyperlinkFP getAccessibleHyperlink;
-
- getAccessibleKeyBindingsFP getAccessibleKeyBindings;
- getAccessibleIconsFP getAccessibleIcons;
- getAccessibleActionsFP getAccessibleActions;
- doAccessibleActionsFP doAccessibleActions;
-
- GetAccessibleTextInfoFP GetAccessibleTextInfo;
- GetAccessibleTextItemsFP GetAccessibleTextItems;
- GetAccessibleTextSelectionInfoFP GetAccessibleTextSelectionInfo;
- GetAccessibleTextAttributesFP GetAccessibleTextAttributes;
- GetAccessibleTextRectFP GetAccessibleTextRect;
- GetAccessibleTextLineBoundsFP GetAccessibleTextLineBounds;
- GetAccessibleTextRangeFP GetAccessibleTextRange;
-
- GetCurrentAccessibleValueFromContextFP GetCurrentAccessibleValueFromContext;
- GetMaximumAccessibleValueFromContextFP GetMaximumAccessibleValueFromContext;
- GetMinimumAccessibleValueFromContextFP GetMinimumAccessibleValueFromContext;
-
- AddAccessibleSelectionFromContextFP AddAccessibleSelectionFromContext;
- ClearAccessibleSelectionFromContextFP ClearAccessibleSelectionFromContext;
- GetAccessibleSelectionFromContextFP GetAccessibleSelectionFromContext;
- GetAccessibleSelectionCountFromContextFP GetAccessibleSelectionCountFromContext;
- IsAccessibleChildSelectedFromContextFP IsAccessibleChildSelectedFromContext;
- RemoveAccessibleSelectionFromContextFP RemoveAccessibleSelectionFromContext;
- SelectAllAccessibleSelectionFromContextFP SelectAllAccessibleSelectionFromContext;
-
- setTextContentsFP setTextContents;
- getParentWithRoleFP getParentWithRole;
- getTopLevelObjectFP getTopLevelObject;
- getParentWithRoleElseRootFP getParentWithRoleElseRoot;
- getObjectDepthFP getObjectDepth;
- getActiveDescendentFP getActiveDescendent;
-
- getVirtualAccessibleNameFP getVirtualAccessibleName;
- requestFocusFP requestFocus;
- selectTextRangeFP selectTextRange;
- getTextAttributesInRangeFP getTextAttributesInRange;
- getVisibleChildrenCountFP getVisibleChildrenCount;
- getVisibleChildrenFP getVisibleChildren;
- setCaretPositionFP setCaretPosition;
- getCaretLocationFP getCaretLocation;
-
- getEventsWaitingFP getEventsWaiting;
-
- } AccessBridgeFPs;
-
-
- /**
- * Initialize the world
- */
- BOOL initializeAccessBridge();
- BOOL shutdownAccessBridge();
-
- /**
- * Window routines
- */
- BOOL IsJavaWindow(HWND window);
-
- // Returns the virtual machine ID and AccessibleContext for a top-level window
- BOOL GetAccessibleContextFromHWND(HWND target, long *vmID, AccessibleContext *ac);
-
- // Returns the HWND from the AccessibleContext of a top-level window
- HWND getHWNDFromAccessibleContext(long vmID, AccessibleContext ac);
-
-
- /**
- * Event handling routines
- */
- void SetJavaShutdown(AccessBridge_JavaShutdownFP fp);
- void SetFocusGained(AccessBridge_FocusGainedFP fp);
- void SetFocusLost(AccessBridge_FocusLostFP fp);
-
- void SetCaretUpdate(AccessBridge_CaretUpdateFP fp);
-
- void SetMouseClicked(AccessBridge_MouseClickedFP fp);
- void SetMouseEntered(AccessBridge_MouseEnteredFP fp);
- void SetMouseExited(AccessBridge_MouseExitedFP fp);
- void SetMousePressed(AccessBridge_MousePressedFP fp);
- void SetMouseReleased(AccessBridge_MouseReleasedFP fp);
-
- void SetMenuCanceled(AccessBridge_MenuCanceledFP fp);
- void SetMenuDeselected(AccessBridge_MenuDeselectedFP fp);
- void SetMenuSelected(AccessBridge_MenuSelectedFP fp);
- void SetPopupMenuCanceled(AccessBridge_PopupMenuCanceledFP fp);
- void SetPopupMenuWillBecomeInvisible(AccessBridge_PopupMenuWillBecomeInvisibleFP fp);
- void SetPopupMenuWillBecomeVisible(AccessBridge_PopupMenuWillBecomeVisibleFP fp);
-
- void SetPropertyNameChange(AccessBridge_PropertyNameChangeFP fp);
- void SetPropertyDescriptionChange(AccessBridge_PropertyDescriptionChangeFP fp);
- void SetPropertyStateChange(AccessBridge_PropertyStateChangeFP fp);
- void SetPropertyValueChange(AccessBridge_PropertyValueChangeFP fp);
- void SetPropertySelectionChange(AccessBridge_PropertySelectionChangeFP fp);
- void SetPropertyTextChange(AccessBridge_PropertyTextChangeFP fp);
- void SetPropertyCaretChange(AccessBridge_PropertyCaretChangeFP fp);
- void SetPropertyVisibleDataChange(AccessBridge_PropertyVisibleDataChangeFP fp);
- void SetPropertyChildChange(AccessBridge_PropertyChildChangeFP fp);
- void SetPropertyActiveDescendentChange(AccessBridge_PropertyActiveDescendentChangeFP fp);
-
- void SetPropertyTableModelChange(AccessBridge_PropertyTableModelChangeFP fp);
-
-
- /**
- * General routines
- */
- void ReleaseJavaObject(long vmID, Java_Object object);
- BOOL GetVersionInfo(long vmID, AccessBridgeVersionInfo *info);
- HWND GetHWNDFromAccessibleContext(long vmID, JOBJECT64 accesibleContext);
-
- /**
- * Accessible Context routines
- */
- BOOL GetAccessibleContextAt(long vmID, AccessibleContext acParent,
- jint x, jint y, AccessibleContext *ac);
- BOOL GetAccessibleContextWithFocus(HWND window, long *vmID, AccessibleContext *ac);
- BOOL GetAccessibleContextInfo(long vmID, AccessibleContext ac, AccessibleContextInfo *info);
- AccessibleContext GetAccessibleChildFromContext(long vmID, AccessibleContext ac, jint index);
- AccessibleContext GetAccessibleParentFromContext(long vmID, AccessibleContext ac);
-
- /**
- * Accessible Text routines
- */
- BOOL GetAccessibleTextInfo(long vmID, AccessibleText at, AccessibleTextInfo *textInfo, jint x, jint y);
- BOOL GetAccessibleTextItems(long vmID, AccessibleText at, AccessibleTextItemsInfo *textItems, jint index);
- BOOL GetAccessibleTextSelectionInfo(long vmID, AccessibleText at, AccessibleTextSelectionInfo *textSelection);
- BOOL GetAccessibleTextAttributes(long vmID, AccessibleText at, jint index, AccessibleTextAttributesInfo *attributes);
- BOOL GetAccessibleTextRect(long vmID, AccessibleText at, AccessibleTextRectInfo *rectInfo, jint index);
- BOOL GetAccessibleTextLineBounds(long vmID, AccessibleText at, jint index, jint *startIndex, jint *endIndex);
- BOOL GetAccessibleTextRange(long vmID, AccessibleText at, jint start, jint end, wchar_t *text, short len);
-
- /* begin AccessibleTable routines */
- BOOL getAccessibleTableInfo(long vmID, AccessibleContext acParent, AccessibleTableInfo *tableInfo);
-
- BOOL getAccessibleTableCellInfo(long vmID, AccessibleTable accessibleTable, jint row, jint column,
- AccessibleTableCellInfo *tableCellInfo);
-
- BOOL getAccessibleTableRowHeader(long vmID, AccessibleContext acParent, AccessibleTableInfo *tableInfo);
- BOOL getAccessibleTableColumnHeader(long vmID, AccessibleContext acParent, AccessibleTableInfo *tableInfo);
-
- AccessibleContext getAccessibleTableRowDescription(long vmID, AccessibleContext acParent, jint row);
- AccessibleContext getAccessibleTableColumnDescription(long vmID, AccessibleContext acParent, jint column);
-
- jint getAccessibleTableRowSelectionCount(long vmID, AccessibleTable table);
- BOOL isAccessibleTableRowSelected(long vmID, AccessibleTable table, jint row);
- BOOL getAccessibleTableRowSelections(long vmID, AccessibleTable table, jint count, jint *selections);
-
- jint getAccessibleTableColumnSelectionCount(long vmID, AccessibleTable table);
- BOOL isAccessibleTableColumnSelected(long vmID, AccessibleTable table, jint column);
- BOOL getAccessibleTableColumnSelections(long vmID, AccessibleTable table, jint count, jint *selections);
-
- jint getAccessibleTableRow(long vmID, AccessibleTable table, jint index);
- jint getAccessibleTableColumn(long vmID, AccessibleTable table, jint index);
- jint getAccessibleTableIndex(long vmID, AccessibleTable table, jint row, jint column);
- /* end AccessibleTable */
-
- /* ----- AccessibleRelationSet routines */
- BOOL getAccessibleRelationSet(long vmID, AccessibleContext accessibleContext,
- AccessibleRelationSetInfo *relationSetInfo);
-
- /* ----- AccessibleHypertext routines */
-
- /*
- * Returns hypertext information associated with a component.
- */
- BOOL getAccessibleHypertext(long vmID, AccessibleContext accessibleContext,
- AccessibleHypertextInfo *hypertextInfo);
-
- /*
- * Requests that a hyperlink be activated.
- */
- BOOL activateAccessibleHyperlink(long vmID, AccessibleContext accessibleContext,
- AccessibleHyperlink accessibleHyperlink);
-
- /*
- * Returns the number of hyperlinks in a component
- * Maps to AccessibleHypertext.getLinkCount.
- * Returns -1 on error.
- */
- jint getAccessibleHyperlinkCount(const long vmID,
- const AccessibleHypertext hypertext);
-
- /*
- * This method is used to iterate through the hyperlinks in a component. It
- * returns hypertext information for a component starting at hyperlink index
- * nStartIndex. No more than MAX_HYPERLINKS AccessibleHypertextInfo objects will
- * be returned for each call to this method.
- * Returns FALSE on error.
- */
- BOOL getAccessibleHypertextExt(const long vmID,
- const AccessibleContext accessibleContext,
- const jint nStartIndex,
- /* OUT */ AccessibleHypertextInfo *hypertextInfo);
-
- /*
- * Returns the index into an array of hyperlinks that is associated with
- * a character index in document; maps to AccessibleHypertext.getLinkIndex
- * Returns -1 on error.
- */
- jint getAccessibleHypertextLinkIndex(const long vmID,
- const AccessibleHypertext hypertext,
- const jint nIndex);
-
- /*
- * Returns the nth hyperlink in a document
- * Maps to AccessibleHypertext.getLink.
- * Returns FALSE on error
- */
- BOOL getAccessibleHyperlink(const long vmID,
- const AccessibleHypertext hypertext,
- const jint nIndex,
- /* OUT */ AccessibleHyperlinkInfo *hyperlinkInfo);
-
- /* Accessible KeyBindings, Icons and Actions */
-
- /*
- * Returns a list of key bindings associated with a component.
- */
- BOOL getAccessibleKeyBindings(long vmID, AccessibleContext accessibleContext,
- AccessibleKeyBindings *keyBindings);
-
- /*
- * Returns a list of icons associate with a component.
- */
- BOOL getAccessibleIcons(long vmID, AccessibleContext accessibleContext,
- AccessibleIcons *icons);
-
- /*
- * Returns a list of actions that a component can perform.
- */
- BOOL getAccessibleActions(long vmID, AccessibleContext accessibleContext,
- AccessibleActions *actions);
-
- /*
- * Request that a list of AccessibleActions be performed by a component.
- * Returns TRUE if all actions are performed. Returns FALSE
- * when the first requested action fails in which case "failure"
- * contains the index of the action that failed.
- */
- BOOL doAccessibleActions(long vmID, AccessibleContext accessibleContext,
- AccessibleActionsToDo *actionsToDo, jint *failure);
-
-
-
- /* Additional utility methods */
-
- /*
- * Returns whether two object references refer to the same object.
- */
- BOOL IsSameObject(long vmID, JOBJECT64 obj1, JOBJECT64 obj2);
-
- /**
- * Sets editable text contents. The AccessibleContext must implement AccessibleEditableText and
- * be editable. The maximum text length that can be set is MAX_STRING_SIZE - 1.
- * Returns whether successful
- */
- BOOL setTextContents (const long vmID, const AccessibleContext accessibleContext, const wchar_t *text);
-
- /**
- * Returns the Accessible Context with the specified role that is the
- * ancestor of a given object. The role is one of the role strings
- * defined in AccessBridgePackages.h
- * If there is no ancestor object that has the specified role,
- * returns (AccessibleContext)0.
- */
- AccessibleContext getParentWithRole (const long vmID, const AccessibleContext accessibleContext,
- const wchar_t *role);
-
- /**
- * Returns the Accessible Context with the specified role that is the
- * ancestor of a given object. The role is one of the role strings
- * defined in AccessBridgePackages.h. If an object with the specified
- * role does not exist, returns the top level object for the Java Window.
- * Returns (AccessibleContext)0 on error.
- */
- AccessibleContext getParentWithRoleElseRoot (const long vmID, const AccessibleContext accessibleContext,
- const wchar_t *role);
-
- /**
- * Returns the Accessible Context for the top level object in
- * a Java Window. This is same Accessible Context that is obtained
- * from GetAccessibleContextFromHWND for that window. Returns
- * (AccessibleContext)0 on error.
- */
- AccessibleContext getTopLevelObject (const long vmID, const AccessibleContext accessibleContext);
-
- /**
- * Returns how deep in the object hierarchy a given object is.
- * The top most object in the object hierarchy has an object depth of 0.
- * Returns -1 on error.
- */
- int getObjectDepth (const long vmID, const AccessibleContext accessibleContext);
-
- /**
- * Returns the Accessible Context of the current ActiveDescendent of an object.
- * This method assumes the ActiveDescendent is the component that is currently
- * selected in a container object.
- * Returns (AccessibleContext)0 on error or if there is no selection.
- */
- AccessibleContext getActiveDescendent (const long vmID, const AccessibleContext accessibleContext);
-
- /**
- /**
- * Accessible Value routines
- */
- BOOL GetCurrentAccessibleValueFromContext(long vmID, AccessibleValue av, wchar_t *value, short len);
- BOOL GetMaximumAccessibleValueFromContext(long vmID, AccessibleValue av, wchar_t *value, short len);
- BOOL GetMinimumAccessibleValueFromContext(long vmID, AccessibleValue av, wchar_t *value, short len);
-
- /**
- * Accessible Selection routines
- */
- void AddAccessibleSelectionFromContext(long vmID, AccessibleSelection as, int i);
- void ClearAccessibleSelectionFromContext(long vmID, AccessibleSelection as);
- JOBJECT64 GetAccessibleSelectionFromContext(long vmID, AccessibleSelection as, int i);
- int GetAccessibleSelectionCountFromContext(long vmID, AccessibleSelection as);
- BOOL IsAccessibleChildSelectedFromContext(long vmID, AccessibleSelection as, int i);
- void RemoveAccessibleSelectionFromContext(long vmID, AccessibleSelection as, int i);
- void SelectAllAccessibleSelectionFromContext(long vmID, AccessibleSelection as);
-
- /**
- * Additional methods for Teton
- */
-
- /**
- * Gets the AccessibleName for a component based upon the JAWS algorithm. Returns
- * whether successful.
- *
- * Bug ID 4916682 - Implement JAWS AccessibleName policy
- */
- BOOL getVirtualAccessibleName(const long vmID, const AccessibleContext accessibleContext,
- wchar_t *name, int len);
-
- /**
- * Request focus for a component. Returns whether successful.
- *
- * Bug ID 4944757 - requestFocus method needed
- */
- BOOL requestFocus(const long vmID, const AccessibleContext accessibleContext);
-
- /**
- * Selects text between two indices. Selection includes the text at the start index
- * and the text at the end index. Returns whether successful.
- *
- * Bug ID 4944758 - selectTextRange method needed
- */
- BOOL selectTextRange(const long vmID, const AccessibleContext accessibleContext, const int startIndex,
- const int endIndex);
-
- /**
- * Get text attributes between two indices. The attribute list includes the text at the
- * start index and the text at the end index. Returns whether successful;
- *
- * Bug ID 4944761 - getTextAttributes between two indices method needed
- */
- BOOL getTextAttributesInRange(const long vmID, const AccessibleContext accessibleContext,
- const int startIndex, const int endIndex,
- AccessibleTextAttributesInfo *attributes, short *len);
-
- /**
- * Returns the number of visible children of a component. Returns -1 on error.
- *
- * Bug ID 4944762- getVisibleChildren for list-like components needed
- */
- int getVisibleChildrenCount(const long vmID, const AccessibleContext accessibleContext);
-
- /**
- * Gets the visible children of an AccessibleContext. Returns whether successful.
- *
- * Bug ID 4944762- getVisibleChildren for list-like components needed
- */
- BOOL getVisibleChildren(const long vmID, const AccessibleContext accessibleContext,
- const int startIndex,
- VisibleChildrenInfo *visibleChildrenInfo);
-
- /**
- * Set the caret to a text position. Returns whether successful.
- *
- * Bug ID 4944770 - setCaretPosition method needed
- */
- BOOL setCaretPosition(const long vmID, const AccessibleContext accessibleContext,
- const int position);
-
- /**
- * Gets the text caret location
- */
- BOOL getCaretLocation(long vmID, AccessibleContext ac,
- AccessibleTextRectInfo *rectInfo, jint index);
-
- /**
- * Gets the number of events waiting to fire
- */
- int getEventsWaiting();
-
-#ifdef __cplusplus
-}
-#endif
diff --git a/demos/java/jni/gs_jni/include/win32/bridge/AccessBridgePackages.h b/demos/java/jni/gs_jni/include/win32/bridge/AccessBridgePackages.h
deleted file mode 100644
index 478f7c63..00000000
--- a/demos/java/jni/gs_jni/include/win32/bridge/AccessBridgePackages.h
+++ /dev/null
@@ -1,2215 +0,0 @@
-/*
- * Copyright (c) 2005, 2014, Oracle and/or its affiliates. All rights reserved.
- * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- */
-
-/*
- * Header file for packages of paramaters passed between Java Accessibility
- * and native Assistive Technologies
- */
-
-#ifndef __AccessBridgePackages_H__
-#define __AccessBridgePackages_H__
-
-#include <jni.h>
-#include <windows.h>
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-#ifdef ACCESSBRIDGE_ARCH_LEGACY
-typedef jobject JOBJECT64;
-typedef HWND ABHWND64;
-#define ABHandleToLong
-#define ABLongToHandle
-#else
-typedef jlong JOBJECT64;
-typedef long ABHWND64;
-#define ABHandleToLong HandleToLong
-#define ABLongToHandle LongToHandle
-#endif
-
-#define MAX_BUFFER_SIZE 10240
-#define MAX_STRING_SIZE 1024
-#define SHORT_STRING_SIZE 256
-
- // object types
- typedef JOBJECT64 AccessibleContext;
- typedef JOBJECT64 AccessibleText;
- typedef JOBJECT64 AccessibleValue;
- typedef JOBJECT64 AccessibleSelection;
- typedef JOBJECT64 Java_Object;
- typedef JOBJECT64 PropertyChangeEvent;
- typedef JOBJECT64 FocusEvent;
- typedef JOBJECT64 CaretEvent;
- typedef JOBJECT64 MouseEvent;
- typedef JOBJECT64 MenuEvent;
- typedef JOBJECT64 AccessibleTable;
- typedef JOBJECT64 AccessibleHyperlink;
- typedef JOBJECT64 AccessibleHypertext;
-
- /**
- ******************************************************
- * Java event types
- ******************************************************
- */
-
-#define cPropertyChangeEvent (jlong) 1 // 1
-#define cFocusGainedEvent (jlong) 2 // 2
-#define cFocusLostEvent (jlong) 4 // 4
-#define cCaretUpdateEvent (jlong) 8 // 8
-#define cMouseClickedEvent (jlong) 16 // 10
-#define cMouseEnteredEvent (jlong) 32 // 20
-#define cMouseExitedEvent (jlong) 64 // 40
-#define cMousePressedEvent (jlong) 128 // 80
-#define cMouseReleasedEvent (jlong) 256 // 100
-#define cMenuCanceledEvent (jlong) 512 // 200
-#define cMenuDeselectedEvent (jlong) 1024 // 400
-#define cMenuSelectedEvent (jlong) 2048 // 800
-#define cPopupMenuCanceledEvent (jlong) 4096 // 1000
-#define cPopupMenuWillBecomeInvisibleEvent (jlong) 8192 // 2000
-#define cPopupMenuWillBecomeVisibleEvent (jlong) 16384 // 4000
-#define cJavaShutdownEvent (jlong) 32768 // 8000
-
- /**
- ******************************************************
- * Accessible Roles
- * Defines all AccessibleRoles in Local.US
- ******************************************************
- */
-
- /**
- * Object is used to alert the user about something.
- */
-#define ACCESSIBLE_ALERT L"alert"
-
- /**
- * The header for a column of data.
- */
-#define ACCESSIBLE_COLUMN_HEADER L"column header"
-
- /**
- * Object that can be drawn into and is used to trap
- * events.
- * see ACCESSIBLE_FRAME
- * see ACCESSIBLE_GLASS_PANE
- * see ACCESSIBLE_LAYERED_PANE
- */
-#define ACCESSIBLE_CANVAS L"canvas"
-
- /**
- * A list of choices the user can select from. Also optionally
- * allows the user to enter a choice of their own.
- */
-#define ACCESSIBLE_COMBO_BOX L"combo box"
-
- /**
- * An iconified internal frame in a DESKTOP_PANE.
- * see ACCESSIBLE_DESKTOP_PANE
- * see ACCESSIBLE_INTERNAL_FRAME
- */
-#define ACCESSIBLE_DESKTOP_ICON L"desktop icon"
-
- /**
- * A frame-like object that is clipped by a desktop pane. The
- * desktop pane, internal frame, and desktop icon objects are
- * often used to create multiple document interfaces within an
- * application.
- * see ACCESSIBLE_DESKTOP_ICON
- * see ACCESSIBLE_DESKTOP_PANE
- * see ACCESSIBLE_FRAME
- */
-#define ACCESSIBLE_INTERNAL_FRAME L"internal frame"
-
- /**
- * A pane that supports internal frames and
- * iconified versions of those internal frames.
- * see ACCESSIBLE_DESKTOP_ICON
- * see ACCESSIBLE_INTERNAL_FRAME
- */
-#define ACCESSIBLE_DESKTOP_PANE L"desktop pane"
-
- /**
- * A specialized pane whose primary use is inside a DIALOG
- * see ACCESSIBLE_DIALOG
- */
-#define ACCESSIBLE_OPTION_PANE L"option pane"
-
- /**
- * A top level window with no title or border.
- * see ACCESSIBLE_FRAME
- * see ACCESSIBLE_DIALOG
- */
-#define ACCESSIBLE_WINDOW L"window"
-
- /**
- * A top level window with a title bar, border, menu bar, etc. It is
- * often used as the primary window for an application.
- * see ACCESSIBLE_DIALOG
- * see ACCESSIBLE_CANVAS
- * see ACCESSIBLE_WINDOW
- */
-#define ACCESSIBLE_FRAME L"frame"
-
- /**
- * A top level window with title bar and a border. A dialog is similar
- * to a frame, but it has fewer properties and is often used as a
- * secondary window for an application.
- * see ACCESSIBLE_FRAME
- * see ACCESSIBLE_WINDOW
- */
-#define ACCESSIBLE_DIALOG L"dialog"
-
- /**
- * A specialized dialog that lets the user choose a color.
- */
-#define ACCESSIBLE_COLOR_CHOOSER L"color chooser"
-
-
- /**
- * A pane that allows the user to navigate through
- * and select the contents of a directory. May be used
- * by a file chooser.
- * see ACCESSIBLE_FILE_CHOOSER
- */
-#define ACCESSIBLE_DIRECTORY_PANE L"directory pane"
-
- /**
- * A specialized dialog that displays the files in the directory
- * and lets the user select a file, browse a different directory,
- * or specify a filename. May use the directory pane to show the
- * contents of a directory.
- * see ACCESSIBLE_DIRECTORY_PANE
- */
-#define ACCESSIBLE_FILE_CHOOSER L"file chooser"
-
- /**
- * An object that fills up space in a user interface. It is often
- * used in interfaces to tweak the spacing between components,
- * but serves no other purpose.
- */
-#define ACCESSIBLE_FILLER L"filler"
-
- /**
- * A hypertext anchor
- */
-#define ACCESSIBLE_HYPERLINK L"hyperlink"
-
- /**
- * A small fixed size picture, typically used to decorate components.
- */
-#define ACCESSIBLE_ICON L"icon"
-
- /**
- * An object used to present an icon or short string in an interface.
- */
-#define ACCESSIBLE_LABEL L"label"
-
- /**
- * A specialized pane that has a glass pane and a layered pane as its
- * children.
- * see ACCESSIBLE_GLASS_PANE
- * see ACCESSIBLE_LAYERED_PANE
- */
-#define ACCESSIBLE_ROOT_PANE L"root pane"
-
- /**
- * A pane that is guaranteed to be painted on top
- * of all panes beneath it.
- * see ACCESSIBLE_ROOT_PANE
- * see ACCESSIBLE_CANVAS
- */
-#define ACCESSIBLE_GLASS_PANE L"glass pane"
-
- /**
- * A specialized pane that allows its children to be drawn in layers,
- * providing a form of stacking order. This is usually the pane that
- * holds the menu bar as well as the pane that contains most of the
- * visual components in a window.
- * see ACCESSIBLE_GLASS_PANE
- * see ACCESSIBLE_ROOT_PANE
- */
-#define ACCESSIBLE_LAYERED_PANE L"layered pane"
-
- /**
- * An object that presents a list of objects to the user and allows the
- * user to select one or more of them. A list is usually contained
- * within a scroll pane.
- * see ACCESSIBLE_SCROLL_PANE
- * see ACCESSIBLE_LIST_ITEM
- */
-#define ACCESSIBLE_LIST L"list"
-
- /**
- * An object that presents an element in a list. A list is usually
- * contained within a scroll pane.
- * see ACCESSIBLE_SCROLL_PANE
- * see ACCESSIBLE_LIST
- */
-#define ACCESSIBLE_LIST_ITEM L"list item"
-
- /**
- * An object usually drawn at the top of the primary dialog box of
- * an application that contains a list of menus the user can choose
- * from. For example, a menu bar might contain menus for "File,"
- * "Edit," and "Help."
- * see ACCESSIBLE_MENU
- * see ACCESSIBLE_POPUP_MENU
- * see ACCESSIBLE_LAYERED_PANE
- */
-#define ACCESSIBLE_MENU_BAR L"menu bar"
-
- /**
- * A temporary window that is usually used to offer the user a
- * list of choices, and then hides when the user selects one of
- * those choices.
- * see ACCESSIBLE_MENU
- * see ACCESSIBLE_MENU_ITEM
- */
-#define ACCESSIBLE_POPUP_MENU L"popup menu"
-
- /**
- * An object usually found inside a menu bar that contains a list
- * of actions the user can choose from. A menu can have any object
- * as its children, but most often they are menu items, other menus,
- * or rudimentary objects such as radio buttons, check boxes, or
- * separators. For example, an application may have an "Edit" menu
- * that contains menu items for "Cut" and "Paste."
- * see ACCESSIBLE_MENU_BAR
- * see ACCESSIBLE_MENU_ITEM
- * see ACCESSIBLE_SEPARATOR
- * see ACCESSIBLE_RADIO_BUTTON
- * see ACCESSIBLE_CHECK_BOX
- * see ACCESSIBLE_POPUP_MENU
- */
-#define ACCESSIBLE_MENU L"menu"
-
- /**
- * An object usually contained in a menu that presents an action
- * the user can choose. For example, the "Cut" menu item in an
- * "Edit" menu would be an action the user can select to cut the
- * selected area of text in a document.
- * see ACCESSIBLE_MENU_BAR
- * see ACCESSIBLE_SEPARATOR
- * see ACCESSIBLE_POPUP_MENU
- */
-#define ACCESSIBLE_MENU_ITEM L"menu item"
-
- /**
- * An object usually contained in a menu to provide a visual
- * and logical separation of the contents in a menu. For example,
- * the "File" menu of an application might contain menu items for
- * "Open," "Close," and "Exit," and will place a separator between
- * "Close" and "Exit" menu items.
- * see ACCESSIBLE_MENU
- * see ACCESSIBLE_MENU_ITEM
- */
-#define ACCESSIBLE_SEPARATOR L"separator"
-
- /**
- * An object that presents a series of panels (or page tabs), one at a
- * time, through some mechanism provided by the object. The most common
- * mechanism is a list of tabs at the top of the panel. The children of
- * a page tab list are all page tabs.
- * see ACCESSIBLE_PAGE_TAB
- */
-#define ACCESSIBLE_PAGE_TAB_LIST L"page tab list"
-
- /**
- * An object that is a child of a page tab list. Its sole child is
- * the panel that is to be presented to the user when the user
- * selects the page tab from the list of tabs in the page tab list.
- * see ACCESSIBLE_PAGE_TAB_LIST
- */
-#define ACCESSIBLE_PAGE_TAB L"page tab"
-
- /**
- * A generic container that is often used to group objects.
- */
-#define ACCESSIBLE_PANEL L"panel"
-
- /**
- * An object used to indicate how much of a task has been completed.
- */
-#define ACCESSIBLE_PROGRESS_BAR L"progress bar"
-
- /**
- * A text object used for passwords, or other places where the
- * text contents is not shown visibly to the user
- */
-#define ACCESSIBLE_PASSWORD_TEXT L"password text"
-
- /**
- * An object the user can manipulate to tell the application to do
- * something.
- * see ACCESSIBLE_CHECK_BOX
- * see ACCESSIBLE_TOGGLE_BUTTON
- * see ACCESSIBLE_RADIO_BUTTON
- */
-#define ACCESSIBLE_PUSH_BUTTON L"push button"
-
- /**
- * A specialized push button that can be checked or unchecked, but
- * does not provide a separate indicator for the current state.
- * see ACCESSIBLE_PUSH_BUTTON
- * see ACCESSIBLE_CHECK_BOX
- * see ACCESSIBLE_RADIO_BUTTON
- */
-#define ACCESSIBLE_TOGGLE_BUTTON L"toggle button"
-
- /**
- * A choice that can be checked or unchecked and provides a
- * separate indicator for the current state.
- * see ACCESSIBLE_PUSH_BUTTON
- * see ACCESSIBLE_TOGGLE_BUTTON
- * see ACCESSIBLE_RADIO_BUTTON
- */
-#define ACCESSIBLE_CHECK_BOX L"check box"
-
- /**
- * A specialized check box that will cause other radio buttons in the
- * same group to become unchecked when this one is checked.
- * see ACCESSIBLE_PUSH_BUTTON
- * see ACCESSIBLE_TOGGLE_BUTTON
- * see ACCESSIBLE_CHECK_BOX
- */
-#define ACCESSIBLE_RADIO_BUTTON L"radio button"
-
- /**
- * The header for a row of data.
- */
-#define ACCESSIBLE_ROW_HEADER L"row header"
-
- /**
- * An object that allows a user to incrementally view a large amount
- * of information. Its children can include scroll bars and a viewport.
- * see ACCESSIBLE_SCROLL_BAR
- * see ACCESSIBLE_VIEWPORT
- */
-#define ACCESSIBLE_SCROLL_PANE L"scroll pane"
-
- /**
- * An object usually used to allow a user to incrementally view a
- * large amount of data. Usually used only by a scroll pane.
- * see ACCESSIBLE_SCROLL_PANE
- */
-#define ACCESSIBLE_SCROLL_BAR L"scroll bar"
-
- /**
- * An object usually used in a scroll pane. It represents the portion
- * of the entire data that the user can see. As the user manipulates
- * the scroll bars, the contents of the viewport can change.
- * see ACCESSIBLE_SCROLL_PANE
- */
-#define ACCESSIBLE_VIEWPORT L"viewport"
-
- /**
- * An object that allows the user to select from a bounded range. For
- * example, a slider might be used to select a number between 0 and 100.
- */
-#define ACCESSIBLE_SLIDER L"slider"
-
- /**
- * A specialized panel that presents two other panels at the same time.
- * Between the two panels is a divider the user can manipulate to make
- * one panel larger and the other panel smaller.
- */
-#define ACCESSIBLE_SPLIT_PANE L"split pane"
-
- /**
- * An object used to present information in terms of rows and columns.
- * An example might include a spreadsheet application.
- */
-#define ACCESSIBLE_TABLE L"table"
-
- /**
- * An object that presents text to the user. The text is usually
- * editable by the user as opposed to a label.
- * see ACCESSIBLE_LABEL
- */
-#define ACCESSIBLE_TEXT L"text"
-
- /**
- * An object used to present hierarchical information to the user.
- * The individual nodes in the tree can be collapsed and expanded
- * to provide selective disclosure of the tree's contents.
- */
-#define ACCESSIBLE_TREE L"tree"
-
- /**
- * A bar or palette usually composed of push buttons or toggle buttons.
- * It is often used to provide the most frequently used functions for an
- * application.
- */
-#define ACCESSIBLE_TOOL_BAR L"tool bar"
-
- /**
- * An object that provides information about another object. The
- * accessibleDescription property of the tool tip is often displayed
- * to the user in a small L"help bubble" when the user causes the
- * mouse to hover over the object associated with the tool tip.
- */
-#define ACCESSIBLE_TOOL_TIP L"tool tip"
-
- /**
- * An AWT component, but nothing else is known about it.
- * see ACCESSIBLE_SWING_COMPONENT
- * see ACCESSIBLE_UNKNOWN
- */
-#define ACCESSIBLE_AWT_COMPONENT L"awt component"
-
- /**
- * A Swing component, but nothing else is known about it.
- * see ACCESSIBLE_AWT_COMPONENT
- * see ACCESSIBLE_UNKNOWN
- */
-#define ACCESSIBLE_SWING_COMPONENT L"swing component"
-
- /**
- * The object contains some Accessible information, but its role is
- * not known.
- * see ACCESSIBLE_AWT_COMPONENT
- * see ACCESSIBLE_SWING_COMPONENT
- */
-#define ACCESSIBLE_UNKNOWN L"unknown"
-
- /**
- * A STATUS_BAR is an simple component that can contain
- * multiple labels of status information to the user.
- */
-#define ACCESSIBLE_STATUS_BAR L"status bar"
-
- /**
- * A DATE_EDITOR is a component that allows users to edit
- * java.util.Date and java.util.Time objects
- */
-#define ACCESSIBLE_DATE_EDITOR L"date editor"
-
- /**
- * A SPIN_BOX is a simple spinner component and its main use
- * is for simple numbers.
- */
-#define ACCESSIBLE_SPIN_BOX L"spin box"
-
- /**
- * A FONT_CHOOSER is a component that lets the user pick various
- * attributes for fonts.
- */
-#define ACCESSIBLE_FONT_CHOOSER L"font chooser"
-
- /**
- * A GROUP_BOX is a simple container that contains a border
- * around it and contains components inside it.
- */
-#define ACCESSIBLE_GROUP_BOX L"group box"
-
- /**
- * A text header
- */
-#define ACCESSIBLE_HEADER L"header"
-
- /**
- * A text footer
- */
-#define ACCESSIBLE_FOOTER L"footer"
-
- /**
- * A text paragraph
- */
-#define ACCESSIBLE_PARAGRAPH L"paragraph"
-
- /**
- * A ruler is an object used to measure distance
- */
-#define ACCESSIBLE_RULER L"ruler"
-
- /**
- * A role indicating the object acts as a formula for
- * calculating a value. An example is a formula in
- * a spreadsheet cell.
- */
-#define ACCESSIBLE_EDITBAR L"editbar"
-
- /**
- * A role indicating the object monitors the progress
- * of some operation.
- */
-#define PROGRESS_MONITOR L"progress monitor"
-
-
- /**
- ******************************************************
- * Accessibility event types
- ******************************************************
- */
-
-#define cPropertyNameChangeEvent (jlong) 1 // 1
-#define cPropertyDescriptionChangeEvent (jlong) 2 // 2
-#define cPropertyStateChangeEvent (jlong) 4 // 4
-#define cPropertyValueChangeEvent (jlong) 8 // 8
-#define cPropertySelectionChangeEvent (jlong) 16 // 10
-#define cPropertyTextChangeEvent (jlong) 32 // 20
-#define cPropertyCaretChangeEvent (jlong) 64 // 40
-#define cPropertyVisibleDataChangeEvent (jlong) 128 // 80
-#define cPropertyChildChangeEvent (jlong) 256 // 100
-#define cPropertyActiveDescendentChangeEvent (jlong) 512 // 200
-#define cPropertyTableModelChangeEvent (jlong) 1024 // 400
-
- /**
- ******************************************************
- * optional AccessibleContext interfaces
- *
- * This version of the bridge reuses the accessibleValue
- * field in the AccessibleContextInfo struct to represent
- * additional optional interfaces that are supported by
- * the Java AccessibleContext. This is backwardly compatable
- * because the old accessibleValue was set to the BOOL
- * value TRUE (i.e., 1) if the AccessibleValue interface is
- * supported.
- ******************************************************
- */
-
-#define cAccessibleValueInterface (jlong) 1 // 1 << 1 (TRUE)
-#define cAccessibleActionInterface (jlong) 2 // 1 << 2
-#define cAccessibleComponentInterface (jlong) 4 // 1 << 3
-#define cAccessibleSelectionInterface (jlong) 8 // 1 << 4
-#define cAccessibleTableInterface (jlong) 16 // 1 << 5
-#define cAccessibleTextInterface (jlong) 32 // 1 << 6
-#define cAccessibleHypertextInterface (jlong) 64 // 1 << 7
-
-
- /**
- ******************************************************
- * Accessibility information bundles
- ******************************************************
- */
-
- typedef struct AccessBridgeVersionInfoTag {
- wchar_t VMversion[SHORT_STRING_SIZE]; // output of "java -version"
- wchar_t bridgeJavaClassVersion[SHORT_STRING_SIZE]; // version of the AccessBridge.class
- wchar_t bridgeJavaDLLVersion[SHORT_STRING_SIZE]; // version of JavaAccessBridge.dll
- wchar_t bridgeWinDLLVersion[SHORT_STRING_SIZE]; // version of WindowsAccessBridge.dll
- } AccessBridgeVersionInfo;
-
-
- typedef struct AccessibleContextInfoTag {
- wchar_t name[MAX_STRING_SIZE]; // the AccessibleName of the object
- wchar_t description[MAX_STRING_SIZE]; // the AccessibleDescription of the object
-
- wchar_t role[SHORT_STRING_SIZE]; // localized AccesibleRole string
- wchar_t role_en_US[SHORT_STRING_SIZE]; // AccesibleRole string in the en_US locale
- wchar_t states[SHORT_STRING_SIZE]; // localized AccesibleStateSet string (comma separated)
- wchar_t states_en_US[SHORT_STRING_SIZE]; // AccesibleStateSet string in the en_US locale (comma separated)
-
- jint indexInParent; // index of object in parent
- jint childrenCount; // # of children, if any
-
- jint x; // screen coords in pixels
- jint y; // "
- jint width; // pixel width of object
- jint height; // pixel height of object
-
- BOOL accessibleComponent; // flags for various additional
- BOOL accessibleAction; // Java Accessibility interfaces
- BOOL accessibleSelection; // FALSE if this object doesn't
- BOOL accessibleText; // implement the additional interface
- // in question
-
- // BOOL accessibleValue; // old BOOL indicating whether AccessibleValue is supported
- BOOL accessibleInterfaces; // new bitfield containing additional interface flags
-
- } AccessibleContextInfo;
-
-
-
- // AccessibleText packages
- typedef struct AccessibleTextInfoTag {
- jint charCount; // # of characters in this text object
- jint caretIndex; // index of caret
- jint indexAtPoint; // index at the passsed in point
- } AccessibleTextInfo;
-
- typedef struct AccessibleTextItemsInfoTag {
- wchar_t letter;
- wchar_t word[SHORT_STRING_SIZE];
- wchar_t sentence[MAX_STRING_SIZE];
- } AccessibleTextItemsInfo;
-
- typedef struct AccessibleTextSelectionInfoTag {
- jint selectionStartIndex;
- jint selectionEndIndex;
- wchar_t selectedText[MAX_STRING_SIZE];
- } AccessibleTextSelectionInfo;
-
- typedef struct AccessibleTextRectInfoTag {
- jint x; // bounding rect of char at index
- jint y; // "
- jint width; // "
- jint height; // "
- } AccessibleTextRectInfo;
-
- // standard attributes for text; note: tabstops are not supported
- typedef struct AccessibleTextAttributesInfoTag {
- BOOL bold;
- BOOL italic;
- BOOL underline;
- BOOL strikethrough;
- BOOL superscript;
- BOOL subscript;
-
- wchar_t backgroundColor[SHORT_STRING_SIZE];
- wchar_t foregroundColor[SHORT_STRING_SIZE];
- wchar_t fontFamily[SHORT_STRING_SIZE];
- jint fontSize;
-
- jint alignment;
- jint bidiLevel;
-
- jfloat firstLineIndent;
- jfloat leftIndent;
- jfloat rightIndent;
- jfloat lineSpacing;
- jfloat spaceAbove;
- jfloat spaceBelow;
-
- wchar_t fullAttributesString[MAX_STRING_SIZE];
- } AccessibleTextAttributesInfo;
-
- /**
- ******************************************************
- * IPC management typedefs
- ******************************************************
- */
-
-#define cMemoryMappedNameSize 255
-
- /**
- * sent by the WindowsDLL -> the memory-mapped file is setup
- *
- */
- typedef struct MemoryMappedFileCreatedPackageTag {
-// HWND bridgeWindow; // redundant, but easier to get to here...
- ABHWND64 bridgeWindow; // redundant, but easier to get to here...
- char filename[cMemoryMappedNameSize];
- } MemoryMappedFileCreatedPackage;
-
-
-
-
- /**
- * sent when a new JavaVM attaches to the Bridge
- *
- */
- typedef struct JavaVMCreatedPackageTag {
- ABHWND64 bridgeWindow;
- long vmID;
- } JavaVMCreatedPackage;
-
- /**
- * sent when a JavaVM detatches from the Bridge
- *
- */
- typedef struct JavaVMDestroyedPackageTag {
- ABHWND64 bridgeWindow;
- } JavaVMDestroyedPackage;
-
- /**
- * sent when a new AT attaches to the Bridge
- *
- */
- typedef struct WindowsATCreatedPackageTag {
- ABHWND64 bridgeWindow;
- } WindowsATCreatedPackage;
-
- /**
- * sent when an AT detatches from the Bridge
- *
- */
- typedef struct WindowsATDestroyedPackageTag {
- ABHWND64 bridgeWindow;
- } WindowsATDestroyedPackage;
-
-
- /**
- * sent by JVM Bridges in response to a WindowsATCreate
- * message; saying "howdy, welcome to the neighborhood"
- *
- */
- typedef struct JavaVMPresentNotificationPackageTag {
- ABHWND64 bridgeWindow;
- long vmID;
- } JavaVMPresentNotificationPackage;
-
- /**
- * sent by AT Bridges in response to a JavaVMCreate
- * message; saying "howdy, welcome to the neighborhood"
- *
- */
- typedef struct WindowsATPresentNotificationPackageTag {
- ABHWND64 bridgeWindow;
- } WindowsATPresentNotificationPackage;
-
-
- /**
- ******************************************************
- * Core packages
- ******************************************************
- */
-
- typedef struct ReleaseJavaObjectPackageTag {
- long vmID;
- JOBJECT64 object;
- } ReleaseJavaObjectPackage;
-
- typedef struct GetAccessBridgeVersionPackageTag {
- long vmID; // can't get VM info w/out a VM!
- AccessBridgeVersionInfo rVersionInfo;
- } GetAccessBridgeVersionPackage;
-
- typedef struct IsSameObjectPackageTag {
- long vmID;
- JOBJECT64 obj1;
- JOBJECT64 obj2;
- jboolean rResult;
- } IsSameObjectPackage;
-
- /**
- ******************************************************
- * Windows packages
- ******************************************************
- */
-
- typedef struct IsJavaWindowPackageTag {
- jint window;
- jboolean rResult;
- } IsJavaWindowPackage;
-
- typedef struct GetAccessibleContextFromHWNDPackageTag {
- jint window;
- long rVMID;
- JOBJECT64 rAccessibleContext;
- } GetAccessibleContextFromHWNDPackage;
-
- typedef struct GetHWNDFromAccessibleContextPackageTag {
- JOBJECT64 accessibleContext;
- ABHWND64 rHWND;
- } GetHWNDFromAccessibleContextPackage;
-
- /**
-******************************************************
-* AccessibleContext packages
-******************************************************
-*/
-
- typedef struct GetAccessibleContextAtPackageTag {
- jint x;
- jint y;
- long vmID;
- JOBJECT64 AccessibleContext; // look within this AC
- JOBJECT64 rAccessibleContext;
- } GetAccessibleContextAtPackage;
-
- typedef struct GetAccessibleContextWithFocusPackageTag {
- long rVMID;
- JOBJECT64 rAccessibleContext;
- } GetAccessibleContextWithFocusPackage;
-
- typedef struct GetAccessibleContextInfoPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- AccessibleContextInfo rAccessibleContextInfo;
- } GetAccessibleContextInfoPackage;
-
- typedef struct GetAccessibleChildFromContextPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- jint childIndex;
- JOBJECT64 rAccessibleContext;
- } GetAccessibleChildFromContextPackage;
-
- typedef struct GetAccessibleParentFromContextPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- JOBJECT64 rAccessibleContext;
- } GetAccessibleParentFromContextPackage;
-
- /**
-******************************************************
-* AccessibleTable packages
-******************************************************
-*/
-
-#define MAX_TABLE_SELECTIONS 64
-
- // table information
- typedef struct AccessibleTableInfoTag {
- JOBJECT64 caption; // AccesibleContext
- JOBJECT64 summary; // AccessibleContext
- jint rowCount;
- jint columnCount;
- JOBJECT64 accessibleContext;
- JOBJECT64 accessibleTable;
- } AccessibleTableInfo;
-
- typedef struct GetAccessibleTableInfoPackageTag {
- long vmID;
- JOBJECT64 accessibleContext;
- AccessibleTableInfo rTableInfo;
- } GetAccessibleTableInfoPackage;
-
- // table cell information
- typedef struct AccessibleTableCellInfoTag {
- JOBJECT64 accessibleContext;
- jint index;
- jint row;
- jint column;
- jint rowExtent;
- jint columnExtent;
- jboolean isSelected;
- } AccessibleTableCellInfo;
-
- typedef struct GetAccessibleTableCellInfoPackageTag {
- long vmID;
- JOBJECT64 accessibleTable;
- jint row;
- jint column;
- AccessibleTableCellInfo rTableCellInfo;
- } GetAccessibleTableCellInfoPackage;
-
- typedef struct GetAccessibleTableRowHeaderPackageTag {
- long vmID;
- JOBJECT64 accessibleContext;
- AccessibleTableInfo rTableInfo;
- } GetAccessibleTableRowHeaderPackage;
-
- typedef struct GetAccessibleTableColumnHeaderPackageTag {
- long vmID;
- JOBJECT64 accessibleContext;
- AccessibleTableInfo rTableInfo;
- } GetAccessibleTableColumnHeaderPackage;
-
- typedef struct GetAccessibleTableRowDescriptionPackageTag {
- long vmID;
- JOBJECT64 accessibleContext;
- jint row;
- JOBJECT64 rAccessibleContext;
- } GetAccessibleTableRowDescriptionPackage;
-
- typedef struct GetAccessibleTableColumnDescriptionPackageTag {
- long vmID;
- JOBJECT64 accessibleContext;
- jint column;
- JOBJECT64 rAccessibleContext;
- } GetAccessibleTableColumnDescriptionPackage;
-
- typedef struct GetAccessibleTableRowSelectionCountPackageTag {
- long vmID;
- JOBJECT64 accessibleTable;
- jint rCount;
- } GetAccessibleTableRowSelectionCountPackage;
-
- typedef struct IsAccessibleTableRowSelectedPackageTag {
- long vmID;
- JOBJECT64 accessibleTable;
- jint row;
- jboolean rResult;
- } IsAccessibleTableRowSelectedPackage;
-
- typedef struct GetAccessibleTableRowSelectionsPackageTag {
- long vmID;
- JOBJECT64 accessibleTable;
- jint count;
- jint rSelections[MAX_TABLE_SELECTIONS];
- } GetAccessibleTableRowSelectionsPackage;
-
- typedef struct GetAccessibleTableColumnSelectionCountPackageTag {
- long vmID;
- JOBJECT64 accessibleTable;
- jint rCount;
- } GetAccessibleTableColumnSelectionCountPackage;
-
- typedef struct IsAccessibleTableColumnSelectedPackageTag {
- long vmID;
- JOBJECT64 accessibleTable;
- jint column;
- jboolean rResult;
- } IsAccessibleTableColumnSelectedPackage;
-
- typedef struct GetAccessibleTableColumnSelectionsPackageTag {
- long vmID;
- JOBJECT64 accessibleTable;
- jint count;
- jint rSelections[MAX_TABLE_SELECTIONS];
- } GetAccessibleTableColumnSelectionsPackage;
-
-
- typedef struct GetAccessibleTableRowPackageTag {
- long vmID;
- JOBJECT64 accessibleTable;
- jint index;
- jint rRow;
- } GetAccessibleTableRowPackage;
-
- typedef struct GetAccessibleTableColumnPackageTag {
- long vmID;
- JOBJECT64 accessibleTable;
- jint index;
- jint rColumn;
- } GetAccessibleTableColumnPackage;
-
- typedef struct GetAccessibleTableIndexPackageTag {
- long vmID;
- JOBJECT64 accessibleTable;
- jint row;
- jint column;
- jint rIndex;
- } GetAccessibleTableIndexPackage;
-
-
- /**
- ******************************************************
- * AccessibleRelationSet packages
- ******************************************************
- */
-
-#define MAX_RELATION_TARGETS 25
-#define MAX_RELATIONS 5
-
- typedef struct AccessibleRelationInfoTag {
- wchar_t key[SHORT_STRING_SIZE];
- jint targetCount;
- JOBJECT64 targets[MAX_RELATION_TARGETS]; // AccessibleContexts
- } AccessibleRelationInfo;
-
- typedef struct AccessibleRelationSetInfoTag {
- jint relationCount;
- AccessibleRelationInfo relations[MAX_RELATIONS];
- } AccessibleRelationSetInfo;
-
- typedef struct GetAccessibleRelationSetPackageTag {
- long vmID;
- JOBJECT64 accessibleContext;
- AccessibleRelationSetInfo rAccessibleRelationSetInfo;
- } GetAccessibleRelationSetPackage;
-
- /**
- ******************************************************
- * AccessibleHypertext packagess
- ******************************************************
- */
-
-#define MAX_HYPERLINKS 64 // maximum number of hyperlinks returned
-
- // hyperlink information
- typedef struct AccessibleHyperlinkInfoTag {
- wchar_t text[SHORT_STRING_SIZE]; // the hyperlink text
- jint startIndex; //index in the hypertext document where the link begins
- jint endIndex; //index in the hypertext document where the link ends
- JOBJECT64 accessibleHyperlink; // AccessibleHyperlink object
- } AccessibleHyperlinkInfo;
-
- // hypertext information
- typedef struct AccessibleHypertextInfoTag {
- jint linkCount; // number of hyperlinks
- AccessibleHyperlinkInfo links[MAX_HYPERLINKS]; // the hyperlinks
- JOBJECT64 accessibleHypertext; // AccessibleHypertext object
- } AccessibleHypertextInfo;
-
- // struct for sending a message to get the hypertext for an AccessibleContext
- typedef struct GetAccessibleHypertextPackageTag {
- long vmID; // the virtual machine ID
- JOBJECT64 accessibleContext; // AccessibleContext with hypertext
- AccessibleHypertextInfo rAccessibleHypertextInfo; // returned hypertext
- } GetAccessibleHypertextPackage;
-
- // struct for sending an message to activate a hyperlink
- typedef struct ActivateAccessibleHyperlinkPackageTag {
- long vmID; // the virtual machine ID
- JOBJECT64 accessibleContext; // AccessibleContext containing the link
- JOBJECT64 accessibleHyperlink; // the link to activate
- BOOL rResult; // hyperlink activation return value
- } ActivateAccessibleHyperlinkPackage;
-
- // struct for sending a message to get the number of hyperlinks in a component
- typedef struct GetAccessibleHyperlinkCountPackageTag {
- long vmID; // the virtual machine ID
- JOBJECT64 accessibleContext; // AccessibleContext containing AccessibleHypertext
- jint rLinkCount; // link count return value
- } GetAccessibleHyperlinkCountPackage;
-
- // struct for sending a message to get the hypertext for an AccessibleContext
- // starting at a specified index in the document
- typedef struct GetAccessibleHypertextExtPackageTag {
- long vmID; // the virtual machine ID
- JOBJECT64 accessibleContext; // AccessibleContext with hypertext
- jint startIndex; // start index in document
- AccessibleHypertextInfo rAccessibleHypertextInfo; // returned hypertext
- BOOL rSuccess; // whether call succeeded
- } GetAccessibleHypertextExtPackage;
-
- // struct for sending a message to get the nth hyperlink in a document;
- // maps to AccessibleHypertext.getLink
- typedef struct GetAccessibleHyperlinkPackageTag {
- long vmID; // the virtual machine ID
- JOBJECT64 hypertext; // AccessibleHypertext
- jint linkIndex; // hyperlink index
- AccessibleHyperlinkInfo rAccessibleHyperlinkInfo; // returned hyperlink
- } GetAccessibleHyperlinkPackage;
-
- // struct for sending a message to get the index into an array
- // of hyperlinks that is associated with a character index in a
- // document; maps to AccessibleHypertext.getLinkIndex
- typedef struct GetAccessibleHypertextLinkIndexPackageTag {
- long vmID; // the virtual machine ID
- JOBJECT64 hypertext; // AccessibleHypertext
- jint charIndex; // character index in document
- jint rLinkIndex; // returned hyperlink index
- } GetAccessibleHypertextLinkIndexPackage;
-
- /**
- ******************************************************
- * Accessible Key Bindings packages
- ******************************************************
- */
-
-#define MAX_KEY_BINDINGS 10
-
- // keyboard character modifiers
-#define ACCESSIBLE_SHIFT_KEYSTROKE 1
-#define ACCESSIBLE_CONTROL_KEYSTROKE 2
-#define ACCESSIBLE_META_KEYSTROKE 4
-#define ACCESSIBLE_ALT_KEYSTROKE 8
-#define ACCESSIBLE_ALT_GRAPH_KEYSTROKE 16
-#define ACCESSIBLE_BUTTON1_KEYSTROKE 32
-#define ACCESSIBLE_BUTTON2_KEYSTROKE 64
-#define ACCESSIBLE_BUTTON3_KEYSTROKE 128
-#define ACCESSIBLE_FKEY_KEYSTROKE 256 // F key pressed, character contains 1-24
-#define ACCESSIBLE_CONTROLCODE_KEYSTROKE 512 // Control code key pressed, character contains control code.
-
-// The supported control code keys are:
-#define ACCESSIBLE_VK_BACK_SPACE 8
-#define ACCESSIBLE_VK_DELETE 127
-#define ACCESSIBLE_VK_DOWN 40
-#define ACCESSIBLE_VK_END 35
-#define ACCESSIBLE_VK_HOME 36
-#define ACCESSIBLE_VK_INSERT 155
-#define ACCESSIBLE_VK_KP_DOWN 225
-#define ACCESSIBLE_VK_KP_LEFT 226
-#define ACCESSIBLE_VK_KP_RIGHT 227
-#define ACCESSIBLE_VK_KP_UP 224
-#define ACCESSIBLE_VK_LEFT 37
-#define ACCESSIBLE_VK_PAGE_DOWN 34
-#define ACCESSIBLE_VK_PAGE_UP 33
-#define ACCESSIBLE_VK_RIGHT 39
-#define ACCESSIBLE_VK_UP 38
-
- // a key binding associates with a component
- typedef struct AccessibleKeyBindingInfoTag {
- jchar character; // the key character
- jint modifiers; // the key modifiers
- } AccessibleKeyBindingInfo;
-
- // all of the key bindings associated with a component
- typedef struct AccessibleKeyBindingsTag {
- int keyBindingsCount; // number of key bindings
- AccessibleKeyBindingInfo keyBindingInfo[MAX_KEY_BINDINGS];
- } AccessibleKeyBindings;
-
- // struct to get the key bindings associated with a component
- typedef struct GetAccessibleKeyBindingsPackageTag {
- long vmID; // the virtual machine id
- JOBJECT64 accessibleContext; // the component
- AccessibleKeyBindings rAccessibleKeyBindings; // the key bindings
- } GetAccessibleKeyBindingsPackage;
-
- /**
-******************************************************
-* AccessibleIcon packages
-******************************************************
-*/
-#define MAX_ICON_INFO 8
-
- // an icon assocated with a component
- typedef struct AccessibleIconInfoTag {
- wchar_t description[SHORT_STRING_SIZE]; // icon description
- jint height; // icon height
- jint width; // icon width
- } AccessibleIconInfo;
-
- // all of the icons associated with a component
- typedef struct AccessibleIconsTag {
- jint iconsCount; // number of icons
- AccessibleIconInfo iconInfo[MAX_ICON_INFO]; // the icons
- } AccessibleIcons;
-
- // struct to get the icons associated with a component
- typedef struct GetAccessibleIconsPackageTag {
- long vmID; // the virtual machine id
- JOBJECT64 accessibleContext; // the component
- AccessibleIcons rAccessibleIcons; // the icons
- } GetAccessibleIconsPackage;
-
-
- /**
-******************************************************
-* AccessibleAction packages
-******************************************************
-*/
-#define MAX_ACTION_INFO 256
-#define MAX_ACTIONS_TO_DO 32
-
- // an action assocated with a component
- typedef struct AccessibleActionInfoTag {
- wchar_t name[SHORT_STRING_SIZE]; // action name
- } AccessibleActionInfo;
-
- // all of the actions associated with a component
- typedef struct AccessibleActionsTag {
- jint actionsCount; // number of actions
- AccessibleActionInfo actionInfo[MAX_ACTION_INFO]; // the action information
- } AccessibleActions;
-
- // struct for requesting the actions associated with a component
- typedef struct GetAccessibleActionsPackageTag {
- long vmID;
- JOBJECT64 accessibleContext; // the component
- AccessibleActions rAccessibleActions; // the actions
- } GetAccessibleActionsPackage;
-
- // list of AccessibleActions to do
- typedef struct AccessibleActionsToDoTag {
- jint actionsCount; // number of actions to do
- AccessibleActionInfo actions[MAX_ACTIONS_TO_DO];// the accessible actions to do
- } AccessibleActionsToDo;
-
- // struct for sending an message to do one or more actions
- typedef struct DoAccessibleActionsPackageTag {
- long vmID; // the virtual machine ID
- JOBJECT64 accessibleContext; // component to do the action
- AccessibleActionsToDo actionsToDo; // the accessible actions to do
- BOOL rResult; // action return value
- jint failure; // index of action that failed if rResult is FALSE
- } DoAccessibleActionsPackage;
-
- /**
-******************************************************
-* AccessibleText packages
-******************************************************
-*/
-
- typedef struct GetAccessibleTextInfoPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- jint x;
- jint y;
- AccessibleTextInfo rTextInfo;
- } GetAccessibleTextInfoPackage;
-
- typedef struct GetAccessibleTextItemsPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- jint index;
- AccessibleTextItemsInfo rTextItemsInfo;
- } GetAccessibleTextItemsPackage;
-
- typedef struct GetAccessibleTextSelectionInfoPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- AccessibleTextSelectionInfo rTextSelectionItemsInfo;
- } GetAccessibleTextSelectionInfoPackage;
-
- typedef struct GetAccessibleTextAttributeInfoPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- jint index;
- AccessibleTextAttributesInfo rAttributeInfo;
- } GetAccessibleTextAttributeInfoPackage;
-
- typedef struct GetAccessibleTextRectInfoPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- jint index;
- AccessibleTextRectInfo rTextRectInfo;
- } GetAccessibleTextRectInfoPackage;
-
- typedef struct GetCaretLocationPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- jint index;
- AccessibleTextRectInfo rTextRectInfo;
- } GetCaretLocationPackage;
-
- typedef struct GetAccessibleTextLineBoundsPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- jint index;
- jint rLineStart;
- jint rLineEnd;
- } GetAccessibleTextLineBoundsPackage;
-
- typedef struct GetAccessibleTextRangePackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- jint start;
- jint end;
- wchar_t rText[MAX_BUFFER_SIZE];
- } GetAccessibleTextRangePackage;
-
- /**
-******************************************************
-*
-* Utility method packages
-******************************************************
-*/
-
- typedef struct SetTextContentsPackageTag {
- long vmID;
- JOBJECT64 accessibleContext; // the text field
- wchar_t text[MAX_STRING_SIZE]; // the text
- BOOL rResult;
- } SetTextContentsPackage;
-
- typedef struct GetParentWithRolePackageTag {
- long vmID;
- JOBJECT64 accessibleContext;
- wchar_t role[SHORT_STRING_SIZE]; // one of Accessible Roles above
- JOBJECT64 rAccessibleContext;
- } GetParentWithRolePackage;
-
- typedef struct GetTopLevelObjectPackageTag {
- long vmID;
- JOBJECT64 accessibleContext;
- JOBJECT64 rAccessibleContext;
- } GetTopLevelObjectPackage;
-
- typedef struct GetParentWithRoleElseRootPackageTag {
- long vmID;
- JOBJECT64 accessibleContext;
- wchar_t role[SHORT_STRING_SIZE]; // one of Accessible Roles above
- JOBJECT64 rAccessibleContext;
- } GetParentWithRoleElseRootPackage;
-
- typedef struct GetObjectDepthPackageTag {
- long vmID;
- JOBJECT64 accessibleContext;
- jint rResult;
- } GetObjectDepthPackage;
-
- typedef struct GetActiveDescendentPackageTag {
- long vmID;
- JOBJECT64 accessibleContext;
- JOBJECT64 rAccessibleContext;
- } GetActiveDescendentPackage;
-
- /**
-******************************************************
-* AccessibleValue packages
-******************************************************
-*/
-
- typedef struct GetCurrentAccessibleValueFromContextPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- wchar_t rValue[SHORT_STRING_SIZE];
- } GetCurrentAccessibleValueFromContextPackage;
-
- typedef struct GetMaximumAccessibleValueFromContextPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- wchar_t rValue[SHORT_STRING_SIZE];
- } GetMaximumAccessibleValueFromContextPackage;
-
- typedef struct GetMinimumAccessibleValueFromContextPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- wchar_t rValue[SHORT_STRING_SIZE];
- } GetMinimumAccessibleValueFromContextPackage;
-
-
- /**
-******************************************************
-* AccessibleSelection packages
-******************************************************
-*/
-
- typedef struct AddAccessibleSelectionFromContextPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- jint index;
- } AddAccessibleSelectionFromContextPackage;
-
- typedef struct ClearAccessibleSelectionFromContextPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- } ClearAccessibleSelectionFromContextPackage;
-
- typedef struct GetAccessibleSelectionFromContextPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- jint index;
- JOBJECT64 rAccessibleContext;
- } GetAccessibleSelectionFromContextPackage;
-
- typedef struct GetAccessibleSelectionCountFromContextPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- jint rCount;
- } GetAccessibleSelectionCountFromContextPackage;
-
- typedef struct IsAccessibleChildSelectedFromContextPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- jint index;
- jboolean rResult;
- } IsAccessibleChildSelectedFromContextPackage;
-
- typedef struct RemoveAccessibleSelectionFromContextPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- jint index;
- } RemoveAccessibleSelectionFromContextPackage;
-
- typedef struct SelectAllAccessibleSelectionFromContextPackageTag {
- long vmID;
- JOBJECT64 AccessibleContext;
- } SelectAllAccessibleSelectionFromContextPackage;
-
-
- /**
-******************************************************
-* Java Event Notification Registration packages
-******************************************************
-*/
-
- typedef struct AddJavaEventNotificationPackageTag {
- jlong type;
- //HWND DLLwindow;
- ABHWND64 DLLwindow;
- } AddJavaEventNotificationPackage;
-
- typedef struct RemoveJavaEventNotificationPackageTag {
- jlong type;
- //HWND DLLwindow;
- ABHWND64 DLLwindow;
- } RemoveJavaEventNotificationPackage;
-
-
- /**
-******************************************************
-* Accessibility Event Notification Registration packages
-******************************************************
-*/
-
- typedef struct AddAccessibilityEventNotificationPackageTag {
- jlong type;
- //HWND DLLwindow;
- ABHWND64 DLLwindow;
- } AddAccessibilityEventNotificationPackage;
-
- typedef struct RemoveAccessibilityEventNotificationPackageTag {
- jlong type;
- //HWND DLLwindow;
- ABHWND64 DLLwindow;
- } RemoveAccessibilityEventNotificationPackage;
-
-
- /**
-******************************************************
-* Accessibility Property Change Event packages
-******************************************************
-*/
-
- typedef struct PropertyCaretChangePackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- jint oldPosition;
- jint newPosition;
- } PropertyCaretChangePackage;
-
- typedef struct PropertyDescriptionChangePackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- wchar_t oldDescription[SHORT_STRING_SIZE];
- wchar_t newDescription[SHORT_STRING_SIZE];
- } PropertyDescriptionChangePackage;
-
- typedef struct PropertyNameChangePackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- wchar_t oldName[SHORT_STRING_SIZE];
- wchar_t newName[SHORT_STRING_SIZE];
- } PropertyNameChangePackage;
-
- typedef struct PropertySelectionChangePackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } PropertySelectionChangePackage;
-
- typedef struct PropertyStateChangePackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- wchar_t oldState[SHORT_STRING_SIZE];
- wchar_t newState[SHORT_STRING_SIZE];
- } PropertyStateChangePackage;
-
- typedef struct PropertyTextChangePackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } PropertyTextChangePackage;
-
- typedef struct PropertyValueChangePackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- wchar_t oldValue[SHORT_STRING_SIZE];
- wchar_t newValue[SHORT_STRING_SIZE];
- } PropertyValueChangePackage;
-
- typedef struct PropertyVisibleDataChangePackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } PropertyVisibleDataChangePackage;
-
- typedef struct PropertyChildChangePackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- JOBJECT64 oldChildAccessibleContext;
- JOBJECT64 newChildAccessibleContext;
- } PropertyChildChangePackage;
-
- typedef struct PropertyActiveDescendentChangePackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- JOBJECT64 oldActiveDescendentAccessibleContext;
- JOBJECT64 newActiveDescendentAccessibleContext;
- } PropertyActiveDescendentChangePackage;
-
-
- // String format for newValue is:
- // "type" one of "INSERT", "UPDATE" or "DELETE"
- // "firstRow"
- // "lastRow"
- // "firstColumn"
- // "lastColumn"
- //
- // oldValue is currently unused
- //
- typedef struct PropertyTableModelChangePackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- wchar_t oldValue[SHORT_STRING_SIZE];
- wchar_t newValue[SHORT_STRING_SIZE];
- } PropertyTableModelChangePackage;
-
-
- /**
-******************************************************
-* Property Change Event packages
-******************************************************
-*/
-
- /*
- typedef struct PropertyChangePackageTag {
- long vmID;
- jobject Event;
- jobject AccessibleContextSource;
- char propertyName[SHORT_STRING_SIZE];
- char oldValue[SHORT_STRING_SIZE]; // PropertyChangeEvent().getOldValue().toString()
- char newValue[SHORT_STRING_SIZE]; // PropertyChangeEvent().getNewValue().toString()
- } PropertyChangePackage;
- */
-
- /*
- * Java shutdown event package
- */
- typedef struct JavaShutdownPackageTag {
- long vmID;
- } JavaShutdownPackage;
-
-
- /**
-******************************************************
-* Focus Event packages
-******************************************************
-*/
-
- typedef struct FocusGainedPackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } FocusGainedPackage;
-
- typedef struct FocusLostPackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } FocusLostPackage;
-
-
- /**
-******************************************************
-* Caret Event packages
-******************************************************
-*/
-
- typedef struct CaretUpdatePackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } CaretUpdatePackage;
-
-
- /**
-******************************************************
-* Mouse Event packages
-******************************************************
-*/
-
- typedef struct MouseClickedPackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } MouseClickedPackage;
-
- typedef struct MouseEnteredPackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } MouseEnteredPackage;
-
- typedef struct MouseExitedPackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } MouseExitedPackage;
-
- typedef struct MousePressedPackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } MousePressedPackage;
-
- typedef struct MouseReleasedPackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } MouseReleasedPackage;
-
-
- /**
-******************************************************
-* Menu/PopupMenu Event packages
-******************************************************
-*/
-
- typedef struct MenuCanceledPackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } MenuCanceledPackage;
-
- typedef struct MenuDeselectedPackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } MenuDeselectedPackage;
-
- typedef struct MenuSelectedPackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } MenuSelectedPackage;
-
-
- typedef struct PopupMenuCanceledPackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } PopupMenuCanceledPackage;
-
- typedef struct PopupMenuWillBecomeInvisiblePackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } PopupMenuWillBecomeInvisiblePackage;
-
- typedef struct PopupMenuWillBecomeVisiblePackageTag {
- long vmID;
- JOBJECT64 Event;
- JOBJECT64 AccessibleContextSource;
- } PopupMenuWillBecomeVisiblePackage;
-
- /**
-******************************************************
-* Additional methods for Teton
-******************************************************
-*/
-
- /**
- * Gets the AccessibleName for a component based upon the JAWS algorithm. Returns
- * whether successful.
- *
- * Bug ID 4916682 - Implement JAWS AccessibleName policy
- */
- typedef struct GetVirtualAccessibleNamePackageTag {
- long vmID;
- AccessibleContext accessibleContext;
- wchar_t rName[MAX_STRING_SIZE];
- int len;
- } GetVirtualAccessibleNamePackage;
-
- /**
- * Request focus for a component. Returns whether successful;
- *
- * Bug ID 4944757 - requestFocus method needed
- */
- typedef struct RequestFocusPackageTag {
- long vmID;
- AccessibleContext accessibleContext;
- } RequestFocusPackage;
-
- /**
- * Selects text between two indices. Selection includes the text at the start index
- * and the text at the end index. Returns whether successful;
- *
- * Bug ID 4944758 - selectTextRange method needed
- */
- typedef struct SelectTextRangePackageTag {
- long vmID;
- AccessibleContext accessibleContext;
- jint startIndex;
- jint endIndex;
- } SelectTextRangePackage;
-
- /**
- * Gets the number of contiguous characters with the same attributes.
- *
- * Bug ID 4944761 - getTextAttributes between two indices method needed
- */
- typedef struct GetTextAttributesInRangePackageTag {
- long vmID;
- AccessibleContext accessibleContext;
- jint startIndex; // start index (inclusive)
- jint endIndex; // end index (inclusive)
- AccessibleTextAttributesInfo attributes; // character attributes to match
- short rLength; // number of contiguous characters with matching attributes
- } GetTextAttributesInRangePackage;
-
-#define MAX_VISIBLE_CHILDREN 256
-
- // visible children information
- typedef struct VisibleChildenInfoTag {
- int returnedChildrenCount; // number of children returned
- AccessibleContext children[MAX_VISIBLE_CHILDREN]; // the visible children
- } VisibleChildrenInfo;
-
- // struct for sending a message to get the number of visible children
- typedef struct GetVisibleChildrenCountPackageTag {
- long vmID; // the virtual machine ID
- JOBJECT64 accessibleContext; // AccessibleContext of parent component
- jint rChildrenCount; // visible children count return value
- } GetVisibleChildrenCountPackage;
-
- // struct for sending a message to get the hypertext for an AccessibleContext
- // starting at a specified index in the document
- typedef struct GetVisibleChildrenPackageTag {
- long vmID; // the virtual machine ID
- JOBJECT64 accessibleContext; // AccessibleContext of parent component
- jint startIndex; // start index for retrieving children
- VisibleChildrenInfo rVisibleChildrenInfo; // returned info
- BOOL rSuccess; // whether call succeeded
- } GetVisibleChildrenPackage;
-
- /**
- * Set the caret to a text position. Returns whether successful;
- *
- * Bug ID 4944770 - setCaretPosition method needed
- */
- typedef struct SetCaretPositionPackageTag {
- long vmID;
- AccessibleContext accessibleContext;
- jint position;
- } SetCaretPositionPackage;
-
-
- /**
- ******************************************************
- * Wrapping up all of the packages
- ******************************************************
- */
-
- /**
- * What is the type of this package
- */
- typedef enum PackageType {
-
- cMemoryMappedFileCreatedPackage = 0x11000,
-
- // many of these will go away...
- cJavaVMCreatedPackage = 0x10000,
- cJavaVMDestroyedPackage,
- cWindowsATCreatedPackage,
- cWindowsATDestroyedPackage,
- cJavaVMPresentNotificationPackage,
- cWindowsATPresentNotificationPackage,
-
- cReleaseJavaObjectPackage = 1,
- cGetAccessBridgeVersionPackage = 2,
-
- cGetAccessibleContextFromHWNDPackage = 0x10,
- cIsJavaWindowPackage,
- cGetHWNDFromAccessibleContextPackage,
-
- cGetAccessibleContextAtPackage = 0x100,
- cGetAccessibleContextWithFocusPackage,
- cGetAccessibleContextInfoPackage,
- cGetAccessibleChildFromContextPackage,
- cGetAccessibleParentFromContextPackage,
- cIsSameObjectPackage,
-
- cGetAccessibleTextInfoPackage = 0x200,
- cGetAccessibleTextItemsPackage,
- cGetAccessibleTextSelectionInfoPackage,
- cGetAccessibleTextAttributeInfoPackage,
- cGetAccessibleTextRectInfoPackage,
- cGetAccessibleTextLineBoundsPackage,
- cGetAccessibleTextRangePackage,
-
- cGetCurrentAccessibleValueFromContextPackage = 0x300,
- cGetMaximumAccessibleValueFromContextPackage,
- cGetMinimumAccessibleValueFromContextPackage,
-
- cAddAccessibleSelectionFromContextPackage = 0x400,
- cClearAccessibleSelectionFromContextPackage,
- cGetAccessibleSelectionFromContextPackage,
- cGetAccessibleSelectionCountFromContextPackage,
- cIsAccessibleChildSelectedFromContextPackage,
- cRemoveAccessibleSelectionFromContextPackage,
- cSelectAllAccessibleSelectionFromContextPackage,
-
- cAddJavaEventNotificationPackage = 0x900,
- cRemoveJavaEventNotificationPackage,
- cAddAccessibilityEventNotificationPackage,
- cRemoveAccessibilityEventNotificationPackage,
-
- cPropertyChangePackage = 0x1000,
-
- cJavaShutdownPackage = 0x1010,
- cFocusGainedPackage,
- cFocusLostPackage,
-
- cCaretUpdatePackage = 0x1020,
-
- cMouseClickedPackage = 0x1030,
- cMouseEnteredPackage,
- cMouseExitedPackage,
- cMousePressedPackage,
- cMouseReleasedPackage,
-
- cMenuCanceledPackage = 0x1040,
- cMenuDeselectedPackage,
- cMenuSelectedPackage,
- cPopupMenuCanceledPackage,
- cPopupMenuWillBecomeInvisiblePackage,
- cPopupMenuWillBecomeVisiblePackage,
-
- cPropertyCaretChangePackage = 0x1100,
- cPropertyDescriptionChangePackage,
- cPropertyNameChangePackage,
- cPropertySelectionChangePackage,
- cPropertyStateChangePackage,
- cPropertyTextChangePackage,
- cPropertyValueChangePackage,
- cPropertyVisibleDataChangePackage,
- cPropertyChildChangePackage,
- cPropertyActiveDescendentChangePackage,
-
-
- // AccessibleTable
- cGetAccessibleTableInfoPackage = 0x1200,
- cGetAccessibleTableCellInfoPackage,
-
- cGetAccessibleTableRowHeaderPackage,
- cGetAccessibleTableColumnHeaderPackage,
-
- cGetAccessibleTableRowDescriptionPackage,
- cGetAccessibleTableColumnDescriptionPackage,
-
- cGetAccessibleTableRowSelectionCountPackage,
- cIsAccessibleTableRowSelectedPackage,
- cGetAccessibleTableRowSelectionsPackage,
-
- cGetAccessibleTableColumnSelectionCountPackage,
- cIsAccessibleTableColumnSelectedPackage,
- cGetAccessibleTableColumnSelectionsPackage,
-
- cGetAccessibleTableRowPackage,
- cGetAccessibleTableColumnPackage,
- cGetAccessibleTableIndexPackage,
-
- cPropertyTableModelChangePackage,
-
-
- // AccessibleRelationSet
- cGetAccessibleRelationSetPackage = 0x1300,
-
- // AccessibleHypertext
- cGetAccessibleHypertextPackage = 0x1400,
- cActivateAccessibleHyperlinkPackage,
- cGetAccessibleHyperlinkCountPackage,
- cGetAccessibleHypertextExtPackage,
- cGetAccessibleHypertextLinkIndexPackage,
- cGetAccessibleHyperlinkPackage,
-
- // Accessible KeyBinding, Icon and Action
- cGetAccessibleKeyBindingsPackage = 0x1500,
- cGetAccessibleIconsPackage,
- cGetAccessibleActionsPackage,
- cDoAccessibleActionsPackage,
-
- // Utility methods
- cSetTextContentsPackage = 0x1600,
- cGetParentWithRolePackage,
- cGetTopLevelObjectPackage,
- cGetParentWithRoleElseRootPackage,
- cGetObjectDepthPackage,
- cGetActiveDescendentPackage,
-
- // Additional methods for Teton
- cGetVirtualAccessibleNamePackage = 0x1700,
- cRequestFocusPackage,
- cSelectTextRangePackage,
- cGetTextAttributesInRangePackage,
- cGetSameTextAttributesInRangePackage,
- cGetVisibleChildrenCountPackage,
- cGetVisibleChildrenPackage,
- cSetCaretPositionPackage,
- cGetCaretLocationPackage
-
-
- } PackageType;
-
-
- /**
- * Union of all package contents
- */
- typedef union AllPackagesTag {
-
- // Initial Rendezvous packages
- MemoryMappedFileCreatedPackage memoryMappedFileCreatedPackage;
-
- JavaVMCreatedPackage javaVMCreatedPackage;
- JavaVMDestroyedPackage javaVMDestroyedPackage;
- WindowsATCreatedPackage windowsATCreatedPackage;
- WindowsATDestroyedPackage windowsATDestroyedPackage;
- JavaVMPresentNotificationPackage javaVMPresentNotificationPackage;
- WindowsATPresentNotificationPackage windowsATPresentNotificationPackage;
-
- // Core packages
- ReleaseJavaObjectPackage releaseJavaObject;
- GetAccessBridgeVersionPackage getAccessBridgeVersion;
-
- // Window packages
- GetAccessibleContextFromHWNDPackage getAccessibleContextFromHWND;
- GetHWNDFromAccessibleContextPackage getHWNDFromAccessibleContext;
-
- // AccessibleContext packages
- GetAccessibleContextAtPackage getAccessibleContextAt;
- GetAccessibleContextWithFocusPackage getAccessibleContextWithFocus;
- GetAccessibleContextInfoPackage getAccessibleContextInfo;
- GetAccessibleChildFromContextPackage getAccessibleChildFromContext;
- GetAccessibleParentFromContextPackage getAccessibleParentFromContext;
-
- // AccessibleText packages
- GetAccessibleTextInfoPackage getAccessibleTextInfo;
- GetAccessibleTextItemsPackage getAccessibleTextItems;
- GetAccessibleTextSelectionInfoPackage getAccessibleTextSelectionInfo;
- GetAccessibleTextAttributeInfoPackage getAccessibleTextAttributeInfo;
- GetAccessibleTextRectInfoPackage getAccessibleTextRectInfo;
- GetAccessibleTextLineBoundsPackage getAccessibleTextLineBounds;
- GetAccessibleTextRangePackage getAccessibleTextRange;
-
- // AccessibleValue packages
- GetCurrentAccessibleValueFromContextPackage getCurrentAccessibleValueFromContext;
- GetMaximumAccessibleValueFromContextPackage getMaximumAccessibleValueFromContext;
- GetMinimumAccessibleValueFromContextPackage getMinimumAccessibleValueFromContext;
-
- // AccessibleSelection packages
- AddAccessibleSelectionFromContextPackage addAccessibleSelectionFromContext;
- ClearAccessibleSelectionFromContextPackage clearAccessibleSelectionFromContext;
- GetAccessibleSelectionFromContextPackage getAccessibleSelectionFromContext;
- GetAccessibleSelectionCountFromContextPackage getAccessibleSelectionCountFromContext;
- IsAccessibleChildSelectedFromContextPackage isAccessibleChildSelectedFromContext;
- RemoveAccessibleSelectionFromContextPackage removeAccessibleSelectionFromContext;
- SelectAllAccessibleSelectionFromContextPackage selectAllAccessibleSelectionFromContext;
-
- // Event Notification Registration packages
- AddJavaEventNotificationPackage addJavaEventNotification;
- RemoveJavaEventNotificationPackage removeJavaEventNotification;
- AddAccessibilityEventNotificationPackage addAccessibilityEventNotification;
- RemoveAccessibilityEventNotificationPackage removeAccessibilityEventNotification;
-
- // Event contents packages
- // PropertyChangePackage propertyChange;
- PropertyCaretChangePackage propertyCaretChangePackage;
- PropertyDescriptionChangePackage propertyDescriptionChangePackage;
- PropertyNameChangePackage propertyNameChangePackage;
- PropertySelectionChangePackage propertySelectionChangePackage;
- PropertyStateChangePackage propertyStateChangePackage;
- PropertyTextChangePackage propertyTextChangePackage;
- PropertyValueChangePackage propertyValueChangePackage;
- PropertyVisibleDataChangePackage propertyVisibleDataChangePackage;
- PropertyChildChangePackage propertyChildChangePackage;
- PropertyActiveDescendentChangePackage propertyActiveDescendentChangePackage;
-
- PropertyTableModelChangePackage propertyTableModelChangePackage;
-
- JavaShutdownPackage JavaShutdown;
- FocusGainedPackage focusGained;
- FocusLostPackage focusLost;
-
- CaretUpdatePackage caretUpdate;
-
- MouseClickedPackage mouseClicked;
- MouseEnteredPackage mouseEntered;
- MouseExitedPackage mouseExited;
- MousePressedPackage mousePressed;
- MouseReleasedPackage mouseReleased;
-
- MenuCanceledPackage menuCanceled;
- MenuDeselectedPackage menuDeselected;
- MenuSelectedPackage menuSelected;
- PopupMenuCanceledPackage popupMenuCanceled;
- PopupMenuWillBecomeInvisiblePackage popupMenuWillBecomeInvisible;
- PopupMenuWillBecomeVisiblePackage popupMenuWillBecomeVisible;
-
- // AccessibleRelationSet
- GetAccessibleRelationSetPackage getAccessibleRelationSet;
-
- // AccessibleHypertext
- GetAccessibleHypertextPackage _getAccessibleHypertext;
- ActivateAccessibleHyperlinkPackage _activateAccessibleHyperlink;
- GetAccessibleHyperlinkCountPackage _getAccessibleHyperlinkCount;
- GetAccessibleHypertextExtPackage _getAccessibleHypertextExt;
- GetAccessibleHypertextLinkIndexPackage _getAccessibleHypertextLinkIndex;
- GetAccessibleHyperlinkPackage _getAccessibleHyperlink;
-
- // Accessible KeyBinding, Icon and Action
- GetAccessibleKeyBindingsPackage getAccessibleKeyBindings;
- GetAccessibleIconsPackage getAccessibleIcons;
- GetAccessibleActionsPackage getAccessibleActions;
- DoAccessibleActionsPackage doAccessibleActions;
-
- // utility methods
- SetTextContentsPackage _setTextContents;
- GetParentWithRolePackage _getParentWithRole;
- GetTopLevelObjectPackage _getTopLevelObject;
- GetParentWithRoleElseRootPackage _getParentWithRoleElseRoot;
- GetObjectDepthPackage _getObjectDepth;
- GetActiveDescendentPackage _getActiveDescendent;
-
- // Additional methods for Teton
- GetVirtualAccessibleNamePackage _getVirtualAccessibleName;
- RequestFocusPackage _requestFocus;
- SelectTextRangePackage _selectTextRange;
- GetTextAttributesInRangePackage _getTextAttributesInRange;
- GetVisibleChildrenCountPackage _getVisibleChildrenCount;
- GetVisibleChildrenPackage _getVisibleChildren;
- SetCaretPositionPackage _setCaretPosition;
-
- } AllPackages;
-
-
- /**
- * Union of all Java-initiated package contents
- */
- typedef union JavaInitiatedPackagesTag {
-
- // Initial Rendezvous packages
- JavaVMCreatedPackage javaVMCreatedPackage;
- JavaVMDestroyedPackage javaVMDestroyedPackage;
- JavaVMPresentNotificationPackage javaVMPresentNotificationPackage;
-
- // Event contents packages
- PropertyCaretChangePackage propertyCaretChangePackage;
- PropertyDescriptionChangePackage propertyDescriptionChangePackage;
- PropertyNameChangePackage propertyNameChangePackage;
- PropertySelectionChangePackage propertySelectionChangePackage;
- PropertyStateChangePackage propertyStateChangePackage;
- PropertyTextChangePackage propertyTextChangePackage;
- PropertyValueChangePackage propertyValueChangePackage;
- PropertyVisibleDataChangePackage propertyVisibleDataChangePackage;
- PropertyChildChangePackage propertyChildChangePackage;
- PropertyActiveDescendentChangePackage propertyActiveDescendentChangePackage;
-
- PropertyTableModelChangePackage propertyTableModelChangePackage;
-
- JavaShutdownPackage JavaShutdown;
- FocusGainedPackage focusGained;
- FocusLostPackage focusLost;
-
- CaretUpdatePackage caretUpdate;
-
- MouseClickedPackage mouseClicked;
- MouseEnteredPackage mouseEntered;
- MouseExitedPackage mouseExited;
- MousePressedPackage mousePressed;
- MouseReleasedPackage mouseReleased;
-
- MenuCanceledPackage menuCanceled;
- MenuDeselectedPackage menuDeselected;
- MenuSelectedPackage menuSelected;
- PopupMenuCanceledPackage popupMenuCanceled;
- PopupMenuWillBecomeInvisiblePackage popupMenuWillBecomeInvisible;
- PopupMenuWillBecomeVisiblePackage popupMenuWillBecomeVisible;
-
- } JavaInitiatedPackages;
-
-
- /**
- * Union of all Windows-initiated package contents
- */
- typedef union WindowsInitiatedPackagesTag {
-
- // Initial Rendezvous packages
- MemoryMappedFileCreatedPackage memoryMappedFileCreatedPackage;
-
- WindowsATCreatedPackage windowsATCreatedPackage;
- WindowsATDestroyedPackage windowsATDestroyedPackage;
- WindowsATPresentNotificationPackage windowsATPresentNotificationPackage;
-
- // Core packages
- ReleaseJavaObjectPackage releaseJavaObject;
- GetAccessBridgeVersionPackage getAccessBridgeVersion;
-
- // Window packages
- GetAccessibleContextFromHWNDPackage getAccessibleContextFromHWND;
- GetHWNDFromAccessibleContextPackage getHWNDFromAccessibleContext;
-
- // AccessibleContext packages
- GetAccessibleContextAtPackage getAccessibleContextAt;
- GetAccessibleContextWithFocusPackage getAccessibleContextWithFocus;
- GetAccessibleContextInfoPackage getAccessibleContextInfo;
- GetAccessibleChildFromContextPackage getAccessibleChildFromContext;
- GetAccessibleParentFromContextPackage getAccessibleParentFromContext;
-
- // AccessibleText packages
- GetAccessibleTextInfoPackage getAccessibleTextInfo;
- GetAccessibleTextItemsPackage getAccessibleTextItems;
- GetAccessibleTextSelectionInfoPackage getAccessibleTextSelectionInfo;
- GetAccessibleTextAttributeInfoPackage getAccessibleTextAttributeInfo;
- GetAccessibleTextRectInfoPackage getAccessibleTextRectInfo;
- GetAccessibleTextLineBoundsPackage getAccessibleTextLineBounds;
- GetAccessibleTextRangePackage getAccessibleTextRange;
-
- // AccessibleValue packages
- GetCurrentAccessibleValueFromContextPackage getCurrentAccessibleValueFromContext;
- GetMaximumAccessibleValueFromContextPackage getMaximumAccessibleValueFromContext;
- GetMinimumAccessibleValueFromContextPackage getMinimumAccessibleValueFromContext;
-
- // AccessibleSelection packages
- AddAccessibleSelectionFromContextPackage addAccessibleSelectionFromContext;
- ClearAccessibleSelectionFromContextPackage clearAccessibleSelectionFromContext;
- GetAccessibleSelectionFromContextPackage getAccessibleSelectionFromContext;
- GetAccessibleSelectionCountFromContextPackage getAccessibleSelectionCountFromContext;
- IsAccessibleChildSelectedFromContextPackage isAccessibleChildSelectedFromContext;
- RemoveAccessibleSelectionFromContextPackage removeAccessibleSelectionFromContext;
- SelectAllAccessibleSelectionFromContextPackage selectAllAccessibleSelectionFromContext;
-
- // Event Notification Registration packages
- AddJavaEventNotificationPackage addJavaEventNotification;
- RemoveJavaEventNotificationPackage removeJavaEventNotification;
- AddAccessibilityEventNotificationPackage addAccessibilityEventNotification;
- RemoveAccessibilityEventNotificationPackage removeAccessibilityEventNotification;
-
- // AccessibleTable
- GetAccessibleTableInfoPackage _getAccessibleTableInfo;
- GetAccessibleTableCellInfoPackage _getAccessibleTableCellInfo;
-
- GetAccessibleTableRowHeaderPackage _getAccessibleTableRowHeader;
- GetAccessibleTableColumnHeaderPackage _getAccessibleTableColumnHeader;
-
- GetAccessibleTableRowDescriptionPackage _getAccessibleTableRowDescription;
- GetAccessibleTableColumnDescriptionPackage _getAccessibleTableColumnDescription;
-
- GetAccessibleTableRowSelectionCountPackage _getAccessibleTableRowSelectionCount;
- IsAccessibleTableRowSelectedPackage _isAccessibleTableRowSelected;
- GetAccessibleTableRowSelectionsPackage _getAccessibleTableRowSelections;
-
- GetAccessibleTableColumnSelectionCountPackage _getAccessibleTableColumnSelectionCount;
- IsAccessibleTableColumnSelectedPackage _isAccessibleTableColumnSelected;
- GetAccessibleTableColumnSelectionsPackage _getAccessibleTableColumnSelections;
-
- GetAccessibleTableRowPackage _getAccessibleTableRow;
- GetAccessibleTableColumnPackage _getAccessibleTableColumn;
- GetAccessibleTableIndexPackage _getAccessibleTableIndex;
-
- // AccessibleRelationSet
- GetAccessibleRelationSetPackage _getAccessibleRelationSet;
-
- // Accessible KeyBindings, Icons and Actions
- GetAccessibleKeyBindingsPackage _getAccessibleKeyBindings;
- GetAccessibleIconsPackage _getAccessibleIcons;
- GetAccessibleActionsPackage _getAccessibleActions;
- DoAccessibleActionsPackage _doAccessibleActions;
-
-
- IsSameObjectPackage _isSameObject;
-
- // utility methods
- SetTextContentsPackage _setTextContents;
- GetParentWithRolePackage _getParentWithRole;
- GetTopLevelObjectPackage _getTopLevelObject;
- GetParentWithRoleElseRootPackage _getParentWithRoleElseRoot;
- GetObjectDepthPackage _getObjectDepth;
- GetActiveDescendentPackage _getActiveDescendent;
-
- // Additional methods for Teton
- GetVirtualAccessibleNamePackage _getVirtualAccessibleName;
- RequestFocusPackage _requestFocus;
- SelectTextRangePackage _selectTextRange;
- GetTextAttributesInRangePackage _getTextAttributesInRange;
- GetVisibleChildrenCountPackage _getVisibleChildrenCount;
- GetVisibleChildrenPackage _getVisibleChildren;
- SetCaretPositionPackage _setCaretPosition;
-
-
- } WindowsInitiatedPackages;
-
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif
diff --git a/demos/java/jni/gs_jni/include/win32/jawt_md.h b/demos/java/jni/gs_jni/include/win32/jawt_md.h
deleted file mode 100644
index 66e7256a..00000000
--- a/demos/java/jni/gs_jni/include/win32/jawt_md.h
+++ /dev/null
@@ -1,59 +0,0 @@
-/*
- * Copyright (c) 1999, Oracle and/or its affiliates. All rights reserved.
- * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- */
-
-#ifndef _JAVASOFT_JAWT_MD_H_
-#define _JAVASOFT_JAWT_MD_H_
-
-#include <windows.h>
-#include "jawt.h"
-
-#ifdef __cplusplus
-extern "C" {
-#endif
-
-/*
- * Win32-specific declarations for AWT native interface.
- * See notes in jawt.h for an example of use.
- */
-typedef struct jawt_Win32DrawingSurfaceInfo {
- /* Native window, DDB, or DIB handle */
- union {
- HWND hwnd;
- HBITMAP hbitmap;
- void* pbits;
- };
- /*
- * This HDC should always be used instead of the HDC returned from
- * BeginPaint() or any calls to GetDC().
- */
- HDC hdc;
- HPALETTE hpalette;
-} JAWT_Win32DrawingSurfaceInfo;
-
-#ifdef __cplusplus
-}
-#endif
-
-#endif /* !_JAVASOFT_JAWT_MD_H_ */
diff --git a/demos/java/jni/gs_jni/include/win32/jni_md.h b/demos/java/jni/gs_jni/include/win32/jni_md.h
deleted file mode 100644
index 38080013..00000000
--- a/demos/java/jni/gs_jni/include/win32/jni_md.h
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * Copyright (c) 1996, 1998, Oracle and/or its affiliates. All rights reserved.
- * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms.
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- *
- */
-
-#ifndef _JAVASOFT_JNI_MD_H_
-#define _JAVASOFT_JNI_MD_H_
-
-#define JNIEXPORT __declspec(dllexport)
-#define JNIIMPORT __declspec(dllimport)
-#define JNICALL __stdcall
-
-typedef long jint;
-typedef __int64 jlong;
-typedef signed char jbyte;
-
-#endif /* !_JAVASOFT_JNI_MD_H_ */
diff --git a/demos/java/jni/gs_jni/install_linux.sh b/demos/java/jni/gs_jni/install_linux.sh
new file mode 100644
index 00000000..1626c212
--- /dev/null
+++ b/demos/java/jni/gs_jni/install_linux.sh
@@ -0,0 +1,7 @@
+#!bin/bash
+
+echo "Copy libgpdl.so -> /usr/lib/libgpdl.so"
+sudo cp -L "../../../../sobin/libgpdl.so" "/usr/lib/libgpdl.so"
+
+echo "Copy gs_jni.so -> /usr/lib/gs_jni.so"
+sudo cp "gs_jni.so" "/usr/lib/gs_jni.so" \ No newline at end of file
diff --git a/demos/java/jni/gs_jni/jni_util.cpp b/demos/java/jni/gs_jni/jni_util.cpp
index 0a99f8bc..74852a95 100644
--- a/demos/java/jni/gs_jni/jni_util.cpp
+++ b/demos/java/jni/gs_jni/jni_util.cpp
@@ -2,7 +2,7 @@
#include <exception>
#include <string.h>
-#include <varargs.h>
+#include <stdarg.h>
#include <string>
using namespace util;
@@ -451,7 +451,8 @@ jint util::throwNoClassDefError(JNIEnv *env, const char *message)
exClass = env->FindClass(className);
if (exClass == NULL)
- throw std::exception("Failed to find java.lang.NoClassDefFoundError");
+ return -2;
+ //throw std::exception("Failed to find java.lang.NoClassDefFoundError");
return env->ThrowNew(exClass, message);
}
@@ -558,7 +559,7 @@ void util::freeClassName(const char *className)
delete[] className;
}
-util::Reference::Reference(JNIEnv *env) : Reference(m_env, NULL)
+util::Reference::Reference(JNIEnv *env) : Reference(env, NULL)
{
}
diff --git a/demos/python/gsapi.py b/demos/python/gsapi.py
index ea2fa6bb..6dfeb95b 100755
--- a/demos/python/gsapi.py
+++ b/demos/python/gsapi.py
@@ -1,10 +1,12 @@
#! /usr/bin/env python3
'''
-Python version of the C API in psi/iapi.h, using ctypes.
+Python version of the C API in psi/iapi.h.
Overview:
+ Implemented using Python's ctypes module.
+
All functions have the same name as the C function that they wrap.
Functions raise a GSError exception if the underlying function returned a
@@ -15,12 +17,38 @@ Overview:
See examples.py for sample usage.
-Usage:
+Example usage:
+
+ On Linux/OpenBSD/MacOS:
+ Build the ghostscript shared library:
+ make sodebug
+
+ Run gsapi.py as a test script:
+ GSAPI_LIBDIR=sodebugbin ./demos/python/gsapi.py
+
+ On Windows:
+ Build ghostscript dll, for example:
+ devenv.com windows/GhostPDL.sln /Build Debug /Project ghostscript
+
+ Run gsapi.py as a test script in a cmd.exe window:
+ set GSAPI_LIBDIR=debugbin&& python ./demos/python/gsapi.py
+
+ Run gsapi.py as a test script in a PowerShell window:
+ cmd /C "set GSAPI_LIBDIR=debugbin&& python ./demos/python/gsapi.py"
+
+Specifying the Ghostscript shared library:
- make sodebug
- LD_LIBRARY_PATH=sodebugbin ./demos/python/gsapi.py
+ Two environmental variables can be used to specify where to find the
+ Ghostscript shared library.
- On Windows perform Release build (x64 or Win32).
+ GSAPI_LIB sets the exact path of the ghostscript shared library, else
+ GSAPI_LIBDIR sets the directory containing the ghostscript shared
+ library. If neither is defined we will use the OS's default location(s) for
+ shared libraries.
+
+ If GSAPI_LIB is not defined, the leafname of the shared library is inferred
+ from the OS type - libgs.so on Unix, libgs.dylib on MacOS, gsdll64.dll on
+ Windows 64.
Requirements:
@@ -43,23 +71,36 @@ Limitations as of 2020-07-21:
'''
import ctypes
+import os
import platform
import sys
-if platform.system() in ('Linux', 'OpenBSD'):
- _libgs = ctypes.CDLL('libgs.so')
-
-elif platform.system() == 'Windows':
- if sys.maxsize == 2**31 - 1:
- _libgs = ctypes.CDLL('../../bin/gpdldll32.dll')
- elif sys.maxsize == 2**63 - 1:
- _libgs = ctypes.CDLL('../../bin/gpdldll64.dll')
+_lib = os.environ.get('GSAPI_LIB')
+if not _lib:
+ if platform.system() in ('Linux', 'OpenBSD'):
+ _lib = 'libgs.so'
+ elif platform.system() == 'Darwin':
+ _lib = 'libgs.dylib'
+ elif platform.system() == 'Windows':
+ if sys.maxsize == 2**31 - 1:
+ _lib = 'gsdll32.dll'
+ elif sys.maxsize == 2**63 - 1:
+ _lib = 'gsdll64.dll'
+ else:
+ raise Exception('Unrecognised sys.maxsize=0x%x' % sys.maxsize)
else:
- raise Exception('Unrecognised sys.maxsize=0x%x' % sys.maxsize)
+ raise Exception('Unrecognised platform.system()=%s' % platform.system())
+
+ _libdir = os.environ.get('GSAPI_LIBDIR')
+ if _libdir:
+ _lib = os.path.join(_libdir, _lib)
-else:
- raise Exception('Unrecognised platform.system()=%s' % platform.system())
+try:
+ _libgs = ctypes.CDLL(_lib)
+except Exception as e:
+ print('gsapi.py: Failed to load Ghostscript library "%s".' % _lib)
+ raise
class GSError(Exception):
@@ -90,7 +131,7 @@ class gsapi_revision_t:
def gsapi_revision():
'''
- Returns (e, r) where <r> is a gsapi_revision_t.
+ Returns a gsapi_revision_t.
'''
# [unicode: we assume that underlying gsapi_revision() returns utf-8
# strings.]
@@ -107,9 +148,14 @@ def gsapi_revision():
return r
-def gsapi_new_instance(caller_handle):
+def gsapi_new_instance(caller_handle=None):
'''
- Returns (e, instance).
+ Returns an <instance> to be used with other gsapi_*() functions.
+
+ caller_handle:
+ Typically unused, but is passed to callbacks e.g. via
+ gsapi_set_stdio(). Must be convertable to a C void*, so None or an
+ integer is ok but other types such as strings will fail.
'''
instance = ctypes.c_void_p()
e = _libgs.gsapi_new_instance(
@@ -130,8 +176,11 @@ def gsapi_delete_instance(instance):
def gsapi_set_stdio(instance, stdin_fn, stdout_fn, stderr_fn):
'''
stdin_fn:
- If not None, will be called with (caller_handle, text, len_)
- where <text> is a ctypes.LP_c_char of length <len_>.
+ If not None, will be called with (caller_handle, text, len_):
+ caller_handle:
+ As passed originally to gsapi_new_instance().
+ text:
+ A ctypes.LP_c_char of length <len_>.
[todo: wrap this to be easier to use from Python?]
@@ -173,6 +222,12 @@ def gsapi_set_stdio(instance, stdin_fn, stdout_fn, stderr_fn):
def gsapi_set_poll(instance, poll_fn):
+ '''
+ poll_fn:
+ Will be called with (caller_handle) where <caller_handle> is as passed
+ to gsapi_new_instance().
+ Not tested.
+ '''
poll_fn2 = _poll_fn(poll_fn)
e = _libgs.gsapi_set_poll(instance, poll_fn2)
if e < 0:
@@ -215,6 +270,10 @@ class display_callback:
def gsapi_set_display_callback(instance, callback):
+ '''
+ callback:
+ Must be a <display_callback> instance.
+ '''
assert isinstance(callback, display_callback)
callback2 = _display_callback()
callback2.size = ctypes.sizeof(callback2)
@@ -235,6 +294,10 @@ def gsapi_set_display_callback(instance, callback):
def gsapi_set_default_device_list(instance, list_):
+ '''
+ list_:
+ Must be a string.
+ '''
# [unicode: we assume that underlying gsapi_set_default_device_list() is
# expecting list_ to be in utf-8 encoding.]
assert isinstance(list_, str)
@@ -246,7 +309,7 @@ def gsapi_set_default_device_list(instance, list_):
def gsapi_get_default_device_list(instance):
'''
- Returns (e, list) where <list> is a string.
+ Returns a string.
'''
# [unicode: we assume underlying gsapi_get_default_device_list() returns
# strings encoded as latin-1.]
@@ -268,6 +331,13 @@ GS_ARG_ENCODING_UTF16LE = 2
def gsapi_set_arg_encoding(instance, encoding):
+ '''
+ encoding:
+ Must be one of:
+ GS_ARG_ENCODING_LOCAL
+ GS_ARG_ENCODING_UTF8
+ GS_ARG_ENCODING_UTF16LE
+ '''
assert encoding in (
GS_ARG_ENCODING_LOCAL,
GS_ARG_ENCODING_UTF8,
@@ -286,6 +356,10 @@ def gsapi_set_arg_encoding(instance, encoding):
def gsapi_init_with_args(instance, args):
+ '''
+ args:
+ A list/tuple of strings.
+ '''
# [unicode: we assume that underlying gsapi_init_with_args()
# expects strings in args[] to be encoded in encoding set by
# gsapi_set_arg_encoding().]
@@ -305,7 +379,7 @@ def gsapi_init_with_args(instance, args):
def gsapi_run_string_begin(instance, user_errors):
'''
- Returns (e, exit_code).
+ Returns <exit_code>.
'''
pexit_code = ctypes.c_int()
e = _libgs.gsapi_run_string_begin(instance, user_errors, ctypes.byref(pexit_code))
@@ -321,7 +395,7 @@ def gsapi_run_string_continue(instance, str_, user_errors):
We don't raise exception for gs_error_NeedInput.
- Returns exit_code.
+ Returns <exit_code>.
'''
if isinstance(str_, str):
str_ = str_.encode('utf-8')
@@ -344,7 +418,7 @@ def gsapi_run_string_continue(instance, str_, user_errors):
def gsapi_run_string_end(instance, user_errors):
'''
- Returns (e, exit_code).
+ Returns <exit_code>.
'''
pexit_code = ctypes.c_int()
e = _libgs.gsapi_run_string_end(
@@ -362,11 +436,9 @@ def gsapi_run_string_with_length(instance, str_, length, user_errors):
<str_> should be either a python string or a bytes object. If the former,
it is converted into a bytes object using utf-8 encoding.
- Returns (e, exit_code).
+ Returns <exit_code>.
'''
- e = gsapi_run_string(instance, str_[:length], user_errors)
- if e < 0:
- raise GSError(e)
+ return gsapi_run_string(instance, str_[:length], user_errors)
def gsapi_run_string(instance, str_, user_errors):
@@ -374,7 +446,7 @@ def gsapi_run_string(instance, str_, user_errors):
<str_> should be either a python string or a bytes object. If the former,
it is converted into a bytes object using utf-8 encoding.
- Returns (e, exit_code).
+ Returns <exit_code>.
'''
if isinstance(str_, str):
str_ = str_.encode('utf-8')
@@ -395,7 +467,7 @@ def gsapi_run_string(instance, str_, user_errors):
def gsapi_run_file(instance, filename, user_errors):
'''
- Returns (e, exit_code).
+ Returns <exit_code>.
'''
# [unicode: we assume that underlying gsapi_run_file() expects <filename>
# to be encoded in encoding set by gsapi_set_arg_encoding().]
@@ -930,7 +1002,7 @@ if __name__ == '__main__':
revision = gsapi_revision()
print('libgs.gsapi_revision() ok: %s' % revision)
- instance = gsapi_new_instance(1)
+ instance = gsapi_new_instance()
print('gsapi_new_instance() ok: %s' % instance)
gsapi_set_arg_encoding(instance, GS_ARG_ENCODING_UTF8)
diff --git a/devices/devs.mak b/devices/devs.mak
index dced3bf4..484e0e36 100644
--- a/devices/devs.mak
+++ b/devices/devs.mak
@@ -658,40 +658,32 @@ $(DEVOBJ)gdevpsdu.$(OBJ) : $(DEVVECSRC)gdevpsdu.c $(GXERR)\
# Plain text writer
-gdevagl_h=$(DEVVECSRC)gdevagl.h
-
-txtwrite_=$(DEVOBJ)gdevtxtw.$(OBJ) $(DEVOBJ)gdevagl.$(OBJ) $(DEVOBJ)doc_common.$(OBJ)
+txtwrite_=$(DEVOBJ)gdevtxtw.$(OBJ) $(DEVOBJ)doc_common.$(OBJ)
$(DD)txtwrite.dev : $(ECHOGS_XE) $(txtwrite_) $(GDEV)\
- $(gdevagl_h) $(DEVS_MAK) $(MAKEDIRS)
+ $(gsagl_h) $(DEVS_MAK) $(MAKEDIRS)
$(SETDEV2) $(DD)txtwrite $(txtwrite_)
$(DEVOBJ)gdevtxtw.$(OBJ) : $(DEVVECSRC)gdevtxtw.c $(GDEV) $(gdevkrnlsclass_h) \
$(memory__h) $(string__h) $(gp_h) $(gsparam_h) $(gsutil_h) \
$(gsdevice_h) $(gxfont_h) $(gxfont0_h) $(gstext_h) $(gxfcid_h)\
- $(gxgstate_h) $(gxpath_h) $(gdevagl_h) $(DEVS_MAK) $(MAKEDIRS) $(DEVVECSRC)doc_common.h
+ $(gxgstate_h) $(gxpath_h) $(gsagl_h) $(DEVS_MAK) $(DEVVECSRC)doc_common.h $(MAKEDIRS)
$(DEVCC) $(DEVO_)gdevtxtw.$(OBJ) $(C_) $(DEVVECSRC)gdevtxtw.c
-$(DEVOBJ)gdevagl.$(OBJ) : $(DEVVECSRC)gdevagl.c $(GDEV)\
- $(gdevagl_h) $(DEVS_MAK) $(MAKEDIRS)
- $(DEVCC) $(DEVO_)gdevagl.$(OBJ) $(C_) $(DEVVECSRC)gdevagl.c
-
-
# Docx writer
-gdevagl_h=$(DEVVECSRC)gdevagl.h
-
-docxwrite_=$(DEVOBJ)gdevdocxw.$(OBJ) $(DEVOBJ)gdevagl.$(OBJ) $(DEVOBJ)doc_common.$(OBJ)
+docxwrite_=$(DEVOBJ)gdevdocxw.$(OBJ) $(DEVOBJ)doc_common.$(OBJ)
-$(DD)docxwrite.dev : $(ECHOGS_XE) $(docxwrite_) $(GDEV)\
- $(gdevagl_h) $(DEVS_MAK) $(MAKEDIRS) $(EXTRACT_OBJS)
+$(DD)docxwrite.dev : $(ECHOGS_XE) $(docxwrite_) $(GLD)gsagl.dev $(GDEV)\
+ $(gsagl_h) $(DEVS_MAK) $(EXTRACT_OBJS) $(MAKEDIRS)
$(SETDEV2) $(DD)docxwrite $(docxwrite_) $(EXTRACT_OBJS)
+ $(ADDMOD) $(DD)docxwrite -include $(GLD)gsagl
$(DEVOBJ)gdevdocxw.$(OBJ) : $(DEVVECSRC)gdevdocxw.c $(GDEV) $(gdevkrnlsclass_h) \
$(memory__h) $(string__h) $(gp_h) $(gsparam_h) $(gsutil_h) \
$(gsdevice_h) $(gxfont_h) $(gxfont0_h) $(gstext_h) $(gxfcid_h)\
- $(gxgstate_h) $(gxpath_h) $(gdevagl_h) $(DEVS_MAK) $(MAKEDIRS) \
- $(DEVVECSRC)doc_common.h
+ $(gxgstate_h) $(gxpath_h) $(gsagl_h) $(DEVS_MAK) \
+ $(DEVVECSRC)doc_common.h $(MAKEDIRS)
$(DEVCC) $(DEVO_)gdevdocxw.$(OBJ) $(C_) $(DEVVECSRC)gdevdocxw.c
# Shared code used by txtwrite and docxwrite.
@@ -699,7 +691,7 @@ $(DEVOBJ)gdevdocxw.$(OBJ) : $(DEVVECSRC)gdevdocxw.c $(GDEV) $(gdevkrnlsclass_h)
$(DEVOBJ)doc_common.$(OBJ) : $(DEVVECSRC)doc_common.c $(GDEV) $(gdevkrnlsclass_h) \
$(memory__h) $(string__h) $(gp_h) $(gsparam_h) $(gsutil_h) \
$(gsdevice_h) $(gxfont_h) $(gxfont0_h) $(gstext_h) $(gxfcid_h)\
- $(gxgstate_h) $(gxpath_h) $(gdevagl_h) $(DEVS_MAK) $(MAKEDIRS) $(DEVVECSRC)doc_common.h
+ $(gxgstate_h) $(gxpath_h) $(gsagl_h) $(DEVS_MAK) $(DEVVECSRC)doc_common.h $(MAKEDIRS)
$(DEVCC) $(DEVO_)doc_common.$(OBJ) $(C_) $(DEVVECSRC)doc_common.c
@@ -713,7 +705,7 @@ pdfwrite4_=$(DEVOBJ)gdevpdfi.$(OBJ) $(DEVOBJ)gdevpdfj.$(OBJ) $(DEVOBJ)gdevpdfk.$
pdfwrite5_=$(DEVOBJ)gdevpdfm.$(OBJ)
pdfwrite6_=$(DEVOBJ)gdevpdfo.$(OBJ) $(DEVOBJ)gdevpdfp.$(OBJ) $(DEVOBJ)gdevpdft.$(OBJ)
pdfwrite7_=$(DEVOBJ)gdevpdfr.$(OBJ)
-pdfwrite8_=$(DEVOBJ)gdevpdfu.$(OBJ) $(DEVOBJ)gdevpdfv.$(OBJ) $(DEVOBJ)gdevagl.$(OBJ)
+pdfwrite8_=$(DEVOBJ)gdevpdfu.$(OBJ) $(DEVOBJ)gdevpdfv.$(OBJ)
pdfwrite9_=$(DEVOBJ)gsflip.$(OBJ)
pdfwrite10_=$(DEVOBJ)scantab.$(OBJ) $(DEVOBJ)sfilter2.$(OBJ)
pdfwrite_=$(pdfwrite1_) $(pdfwrite2_) $(pdfwrite3_) $(pdfwrite4_)\
@@ -743,7 +735,7 @@ $(DD)eps2write.dev : $(DD)pdfwrite.dev $(GDEV) \
$(DD)pdfwrite.dev : $(ECHOGS_XE) $(pdfwrite_)\
$(GLD)cmyklib.dev $(GLD)cfe.dev $(GLD)lzwe.dev\
$(GLD)rle.dev $(GLD)sdcte.dev $(GLD)sdeparam.dev $(GLD)smd5.dev\
- $(GLD)szlibe.dev $(GLD)psdf.dev $(GLD)sarc4.dev $(DD)pdtext.dev $(GDEV) \
+ $(GLD)szlibe.dev $(GLD)psdf.dev $(GLD)gsagl.dev $(GLD)sarc4.dev $(DD)pdtext.dev $(GDEV) \
$(DEVS_MAK) $(MAKEDIRS)
$(SETDEV2) $(DD)pdfwrite $(pdfwrite1_)
$(ADDMOD) $(DD)pdfwrite $(pdfwrite2_)
@@ -759,7 +751,7 @@ $(DD)pdfwrite.dev : $(ECHOGS_XE) $(pdfwrite_)\
$(ADDMOD) $(DD)pdfwrite -include $(GLD)cmyklib $(GLD)cfe $(GLD)lzwe
$(ADDMOD) $(DD)pdfwrite -include $(GLD)rle $(GLD)sdcte $(GLD)sdeparam
$(ADDMOD) $(DD)pdfwrite -include $(GLD)smd5 $(GLD)szlibe $(GLD)sarc4.dev
- $(ADDMOD) $(DD)pdfwrite -include $(GLD)psdf
+ $(ADDMOD) $(DD)pdfwrite -include $(GLD)psdf $(GLD)gsagl
$(ADDMOD) $(DD)pdfwrite -include $(DD)pdtext
gdevpdfb_h=$(DEVVECSRC)gdevpdfb.h
@@ -875,7 +867,7 @@ $(DEVOBJ)gdevpdfu.$(OBJ) : $(DEVVECSRC)gdevpdfu.c $(GXERR)\
$(sa85x_h) $(scfx_h) $(sdct_h) $(slzwx_h) $(spngpx_h)\
$(srlx_h) $(sarc4_h) $(smd5_h) $(sstring_h) $(strimpl_h) $(szlibx_h)\
$(strmio_h) \
- $(opdfread_h) $(gdevagl_h) $(gs_mro_e_h) $(gs_mgl_e_h) \
+ $(opdfread_h) $(gsagl_h) $(gs_mro_e_h) $(gs_mgl_e_h) \
$(DEVS_MAK) $(MAKEDIRS)
$(GDEVLWFJB2JPXCC) $(DEVO_)gdevpdfu.$(OBJ) $(C_) $(DEVVECSRC)gdevpdfu.c
diff --git a/devices/extract.mak b/devices/extract.mak
index 5e186e08..74f1f29c 100644
--- a/devices/extract.mak
+++ b/devices/extract.mak
@@ -1,37 +1,64 @@
+# Copyright (C) 2001-2021 Artifex Software, Inc.
+# All Rights Reserved.
+#
+# This software is provided AS-IS with no warranty, either express or
+# implied.
+#
+# This software is distributed under license and may not be copied,
+# modified or distributed except as expressly authorized under the terms
+# of the license contained in the file LICENSE in this distribution.
+#
+# Refer to licensing information at http://www.artifex.com or contact
+# Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+# CA 94945, U.S.A., +1(415)492-9861, for further information.
+#
+
extract_cc = $(CC) $(CCFLAGS) $(I_)$(EXTRACT_DIR)/include$(_I) $(I_)$(ZSRCDIR)$(_I) $(O_)
extract_out_prefix = $(GLOBJDIR)$(D)extract_
-$(extract_out_prefix)alloc.$(OBJ): $(EXTRACT_DIR)/src/alloc.c
+$(extract_out_prefix)alloc.$(OBJ): $(EXTRACT_DIR)/src/alloc.c $(MAKEDIRS)
$(extract_cc)$@ $(C_) $(EXTRACT_DIR)/src/alloc.c
-$(extract_out_prefix)astring.$(OBJ): $(EXTRACT_DIR)/src/astring.c
+$(extract_out_prefix)astring.$(OBJ): $(EXTRACT_DIR)/src/astring.c $(MAKEDIRS)
$(extract_cc)$@ $(C_) $(EXTRACT_DIR)/src/astring.c
-$(extract_out_prefix)buffer.$(OBJ): $(EXTRACT_DIR)/src/buffer.c
+$(extract_out_prefix)buffer.$(OBJ): $(EXTRACT_DIR)/src/buffer.c $(MAKEDIRS)
$(extract_cc)$@ $(C_) $(EXTRACT_DIR)/src/buffer.c
-$(extract_out_prefix)docx.$(OBJ): $(EXTRACT_DIR)/src/docx.c
+$(extract_out_prefix)docx.$(OBJ): $(EXTRACT_DIR)/src/docx.c $(MAKEDIRS)
$(extract_cc)$@ $(C_) $(EXTRACT_DIR)/src/docx.c
-$(extract_out_prefix)docx_template.$(OBJ): $(EXTRACT_DIR)/src/docx_template.c
+$(extract_out_prefix)docx_template.$(OBJ): $(EXTRACT_DIR)/src/docx_template.c $(MAKEDIRS)
$(extract_cc)$@ $(C_) $(EXTRACT_DIR)/src/docx_template.c
-$(extract_out_prefix)extract.$(OBJ): $(EXTRACT_DIR)/src/extract.c
+$(extract_out_prefix)extract.$(OBJ): $(EXTRACT_DIR)/src/extract.c $(MAKEDIRS)
$(extract_cc)$@ $(C_) $(EXTRACT_DIR)/src/extract.c
-$(extract_out_prefix)join.$(OBJ): $(EXTRACT_DIR)/src/join.c
+$(extract_out_prefix)join.$(OBJ): $(EXTRACT_DIR)/src/join.c $(MAKEDIRS)
$(extract_cc)$@ $(C_) $(EXTRACT_DIR)/src/join.c
-$(extract_out_prefix)mem.$(OBJ): $(EXTRACT_DIR)/src/mem.c
+$(extract_out_prefix)mem.$(OBJ): $(EXTRACT_DIR)/src/mem.c $(MAKEDIRS)
$(extract_cc)$@ $(C_) $(EXTRACT_DIR)/src/mem.c
-$(extract_out_prefix)outf.$(OBJ): $(EXTRACT_DIR)/src/outf.c
+$(extract_out_prefix)odt.$(OBJ): $(EXTRACT_DIR)/src/odt.c $(MAKEDIRS)
+ $(extract_cc)$@ $(C_) $(EXTRACT_DIR)/src/odt.c
+
+$(extract_out_prefix)odt_template.$(OBJ): $(EXTRACT_DIR)/src/odt_template.c $(MAKEDIRS)
+ $(extract_cc)$@ $(C_) $(EXTRACT_DIR)/src/odt_template.c
+
+$(extract_out_prefix)outf.$(OBJ): $(EXTRACT_DIR)/src/outf.c $(MAKEDIRS)
$(extract_cc)$@ $(C_) $(EXTRACT_DIR)/src/outf.c
-$(extract_out_prefix)xml.$(OBJ): $(EXTRACT_DIR)/src/xml.c
+$(extract_out_prefix)sys.$(OBJ): $(EXTRACT_DIR)/src/sys.c $(MAKEDIRS)
+ $(extract_cc)$@ $(C_) $(EXTRACT_DIR)/src/sys.c
+
+$(extract_out_prefix)text.$(OBJ): $(EXTRACT_DIR)/src/text.c $(MAKEDIRS)
+ $(extract_cc)$@ $(C_) $(EXTRACT_DIR)/src/text.c
+
+$(extract_out_prefix)xml.$(OBJ): $(EXTRACT_DIR)/src/xml.c $(MAKEDIRS)
$(extract_cc)$@ $(C_) $(EXTRACT_DIR)/src/xml.c
-$(extract_out_prefix)zip.$(OBJ): $(EXTRACT_DIR)/src/zip.c
+$(extract_out_prefix)zip.$(OBJ): $(EXTRACT_DIR)/src/zip.c $(MAKEDIRS)
$(extract_cc)$@ $(C_) $(EXTRACT_DIR)/src/zip.c
EXTRACT_OBJS = \
@@ -43,6 +70,10 @@ EXTRACT_OBJS = \
$(extract_out_prefix)extract.$(OBJ) \
$(extract_out_prefix)join.$(OBJ) \
$(extract_out_prefix)mem.$(OBJ) \
+ $(extract_out_prefix)odt.$(OBJ) \
+ $(extract_out_prefix)odt_template.$(OBJ) \
$(extract_out_prefix)outf.$(OBJ) \
+ $(extract_out_prefix)sys.$(OBJ) \
+ $(extract_out_prefix)text.$(OBJ) \
$(extract_out_prefix)xml.$(OBJ) \
$(extract_out_prefix)zip.$(OBJ) \
diff --git a/devices/gdev3852.c b/devices/gdev3852.c
index 1b3377b2..7d50b4df 100644
--- a/devices/gdev3852.c
+++ b/devices/gdev3852.c
@@ -39,14 +39,23 @@ Modified by L. Peter Deutsch <ghost@aladdin.com> 1999-01-10 to remove _ss
/* Should = 96 (KMG) */
#define LINE_SIZE ((X_DPI * 86 / 10 + 63) / 64 * 8)
+static void
+jetp3852_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, output_page, gdev_prn_bg_output_page);
+ set_dev_proc(dev, map_rgb_color, gdev_pcl_3bit_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gdev_pcl_3bit_map_color_rgb);
+ set_dev_proc(dev, encode_color, gdev_pcl_3bit_map_rgb_color);
+ set_dev_proc(dev, decode_color, gdev_pcl_3bit_map_color_rgb);
+}
+
/* The device descriptor */
static dev_proc_print_page(jetp3852_print_page);
/* Since the 'print_page' does not change the device, this device can print in the background */
-static gx_device_procs jetp3852_procs =
- prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- gdev_pcl_3bit_map_rgb_color, gdev_pcl_3bit_map_color_rgb);
const gx_device_printer far_data gs_jetp3852_device =
- prn_device(jetp3852_procs, "jetp3852",
+ prn_device(jetp3852_initialize_device_procs, "jetp3852",
86, /* width_10ths, 8.6" (?) */
110, /* height_10ths, 11" */
X_DPI, Y_DPI,
diff --git a/devices/gdev4081.c b/devices/gdev4081.c
index 70bfbb51..fd72fdff 100644
--- a/devices/gdev4081.c
+++ b/devices/gdev4081.c
@@ -22,7 +22,8 @@
/* The device descriptor */
static dev_proc_print_page(r4081_print_page);
const gx_device_printer far_data gs_r4081_device =
- prn_device(prn_bg_procs, "r4081", /* The print_page proc is compatible with allowing bg printing */
+ /* The print_page proc is compatible with allowing bg printing */
+ prn_device(gdev_prn_initialize_device_procs_mono_bg, "r4081",
85, /* width_10ths, 8.5" */
110, /* height_10ths, 11" */
X_DPI, Y_DPI,
diff --git a/devices/gdev4693.c b/devices/gdev4693.c
index baa975c5..7e730777 100644
--- a/devices/gdev4693.c
+++ b/devices/gdev4693.c
@@ -22,13 +22,21 @@ static dev_proc_print_page(t4693d_print_page);
static dev_proc_map_rgb_color(gdev_t4693d_map_rgb_color);
static dev_proc_map_color_rgb(gdev_t4693d_map_color_rgb);
-/* Since the print_page doesn't alter the device, this device can print in the background */
-static gx_device_procs t4693d_procs =
- prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- gdev_t4693d_map_rgb_color, gdev_t4693d_map_color_rgb);
+static void
+t4693d_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+ set_dev_proc(dev, output_page, gdev_prn_bg_output_page);
+ set_dev_proc(dev, map_rgb_color, gdev_t4693d_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gdev_t4693d_map_color_rgb);
+ set_dev_proc(dev, encode_color, gdev_t4693d_map_rgb_color);
+ set_dev_proc(dev, decode_color, gdev_t4693d_map_color_rgb);
+}
+
+/* Since the print_page doesn't alter the device, this device can print in the background */
#define t4693d_prn_device(name,depth,max_rgb) {prn_device_body( \
- gx_device_printer,t4693d_procs,name, \
+ gx_device_printer,t4693d_initialize_device_procs,name, \
WIDTH_10THS, HEIGHT_10THS, X_DPI, Y_DPI, 0.25, 0.25, 0.25, 0.25, \
3,depth,max_rgb,max_rgb,max_rgb + 1,max_rgb + 1, \
t4693d_print_page)}
diff --git a/devices/gdev8510.c b/devices/gdev8510.c
index af9fcf8f..534435c0 100644
--- a/devices/gdev8510.c
+++ b/devices/gdev8510.c
@@ -24,7 +24,8 @@
/* The device descriptor */
static dev_proc_print_page(m8510_print_page);
const gx_device_printer far_data gs_m8510_device =
- prn_device(prn_bg_procs, "m8510", /* The print_page proc is compatible with allowing bg printing */
+ /* The print_page proc is compatible with allowing bg printing */
+ prn_device(gdev_prn_initialize_device_procs_mono_bg, "m8510",
85, /* width_10ths, 8.5" */
110, /* height_10ths, 11" */
160, /* x_dpi */
diff --git a/devices/gdevatx.c b/devices/gdevatx.c
index 1836edf6..b3f7497c 100644
--- a/devices/gdevatx.c
+++ b/devices/gdevatx.c
@@ -43,7 +43,8 @@ static dev_proc_print_page(atx24_print_page);
static dev_proc_print_page(atx38_print_page);
#define ATX_DEVICE(dname, w10, h10, dpi, lrm, btm, print_page)\
- prn_device_margins(prn_std_procs, dname, w10, h10, dpi, dpi, 0, 0,\
+ prn_device_margins(gdev_prn_initialize_device_procs_mono, dname,\
+ w10, h10, dpi, dpi, 0, 0,\
lrm, btm, lrm, btm, 1, print_page)
const gx_device_printer gs_atx23_device = /* real width = 576 pixels */
diff --git a/devices/gdevbit.c b/devices/gdevbit.c
index 600bfdd2..952af9e9 100644
--- a/devices/gdevbit.c
+++ b/devices/gdevbit.c
@@ -43,12 +43,14 @@ static dev_proc_put_params(bittag_put_params);
static dev_proc_create_buf_device(bittag_create_buf_device);
static dev_proc_fillpage(bittag_fillpage);
static dev_proc_map_rgb_color(bit_mono_map_color);
+static dev_proc_decode_color(bit_mono_decode_color);
#if 0 /* unused */
static dev_proc_map_rgb_color(bit_forcemono_map_rgb_color);
#endif
static dev_proc_map_rgb_color(bitrgb_rgb_map_rgb_color);
static dev_proc_map_color_rgb(bit_map_color_rgb);
static dev_proc_map_cmyk_color(bit_map_cmyk_color);
+static dev_proc_decode_color(bit_map_color_cmyk);
static dev_proc_get_params(bit_get_params);
static dev_proc_put_params(bit_put_params);
static dev_proc_print_page(bit_print_page);
@@ -57,74 +59,15 @@ static dev_proc_put_image(bit_put_image);
static dev_proc_dev_spec_op(bit_dev_spec_op);
dev_proc_get_color_comp_index(gx_default_DevRGB_get_color_comp_index);
-#define bit_procs(encode_color)\
-{ gdev_prn_open,\
- gx_default_get_initial_matrix,\
- NULL, /* sync_output */\
- /* Since the print_page doesn't alter the device, this device can print in the background */\
- gdev_prn_bg_output_page,\
- gdev_prn_close,\
- encode_color, /* map_rgb_color */\
- bit_map_color_rgb, /* map_color_rgb */\
- NULL, /* fill_rectangle */\
- NULL, /* tile_rectangle */\
- NULL, /* copy_mono */\
- NULL, /* copy_color */\
- NULL, /* draw_line */\
- NULL, /* get_bits */\
- bit_get_params,\
- bit_put_params,\
- encode_color, /* map_cmyk_color */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- gx_page_device_get_page_device, /* get_page_device */\
- NULL, /* get_alpha_bits */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- NULL, /* fill_path */\
- NULL, /* stroke_path */\
- NULL, /* fill_mask */\
- NULL, /* fill_trapezoid */\
- NULL, /* fill_parallelogram */\
- NULL, /* fill_triangle */\
- NULL, /* draw_thin_line */\
- NULL, /* begin_image */\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL, /* strip_copy_rop */\
- NULL, /* get_clipping_box */\
- NULL, /* begin_typed_image */\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- NULL, /* create_compositor */\
- NULL, /* get_hardware_params */\
- NULL, /* text_begin */\
- NULL, /* finish_copydevice */\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL, /* discard_transparency_layer */\
- NULL, /* get_color_mapping_procs */\
- NULL, /* get_color_comp_index */\
- encode_color, /* encode_color */\
- bit_map_color_rgb, /* decode_color */\
- NULL, /* pattern_manage */\
- NULL, /* fill_rectangle_hl_color */\
- NULL, /* include_color_space */\
- NULL, /* fill_linear_color_scanline */\
- NULL, /* fill_linear_color_trapezoid */\
- NULL, /* fill_linear_color_triangle */\
- NULL, /* update_spot_equivalent_colors */\
- NULL, /* ret_devn_params */\
- NULL, /* fillpage */\
- NULL, /* push_transparency_state */\
- NULL, /* pop_transparency_state */\
- NULL, /* put_image */\
- bit_dev_spec_op\
+static void
+bit_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, map_color_rgb, bit_map_color_rgb);
+ set_dev_proc(dev, get_params, bit_get_params);
+ set_dev_proc(dev, put_params, bit_put_params);
+ set_dev_proc(dev, dev_spec_op, bit_dev_spec_op);
}
/*
@@ -144,110 +87,86 @@ struct gx_device_bit_s {
};
typedef struct gx_device_bit_s gx_device_bit;
-static const gx_device_procs bitmono_procs =
-bit_procs(bit_mono_map_color);
+static void
+bitmono_initialize_device_procs(gx_device *dev)
+{
+ bit_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_rgb_color, bit_mono_map_color);
+ set_dev_proc(dev, map_cmyk_color, bit_mono_map_color);
+ set_dev_proc(dev, encode_color, bit_mono_map_color);
+ set_dev_proc(dev, decode_color, bit_mono_decode_color);
+}
+
const gx_device_bit gs_bit_device =
-{prn_device_body(gx_device_bit, bitmono_procs, "bit",
+{prn_device_body(gx_device_bit, bitmono_initialize_device_procs, "bit",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
1, 1, 1, 0, 2, 1, bit_print_page)
};
-static const gx_device_procs bitrgb_procs =
-bit_procs(bitrgb_rgb_map_rgb_color);
+static void
+bitrgb_initialize_device_procs(gx_device *dev)
+{
+ bit_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_rgb_color, bitrgb_rgb_map_rgb_color);
+ set_dev_proc(dev, map_cmyk_color, bitrgb_rgb_map_rgb_color);
+ set_dev_proc(dev, encode_color, bitrgb_rgb_map_rgb_color);
+ set_dev_proc(dev, decode_color, bit_map_color_rgb);
+}
+
const gx_device_bit gs_bitrgb_device =
-{prn_device_body(gx_device_bit, bitrgb_procs, "bitrgb",
+{prn_device_body(gx_device_bit, bitrgb_initialize_device_procs, "bitrgb",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
3, 4, 1, 1, 2, 2, bit_print_page)
};
-static const gx_device_procs bitcmyk_procs =
-bit_procs(bit_map_cmyk_color);
+static void
+bitcmyk_initialize_device_procs(gx_device *dev)
+{
+ bit_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_rgb_color, bit_map_cmyk_color);
+ set_dev_proc(dev, map_cmyk_color, bit_map_cmyk_color);
+ set_dev_proc(dev, encode_color, bit_map_cmyk_color);
+ set_dev_proc(dev, decode_color, bit_map_color_cmyk);
+}
+
const gx_device_bit gs_bitcmyk_device =
-{prn_device_body(gx_device_bit, bitcmyk_procs, "bitcmyk",
+{prn_device_body(gx_device_bit, bitcmyk_initialize_device_procs, "bitcmyk",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
4, 4, 1, 1, 2, 2, bit_print_page)
};
-static const gx_device_procs bitrgbtags_procs =
- {
- bittag_open, /* open_device */
- gx_default_get_initial_matrix, /* initial_matrix */
- ((void *)0), /* sync_output */
- gdev_prn_output_page, /* output page */
- gdev_prn_close, /* close_device */
- bittag_rgb_map_rgb_color, /* map rgb color */
- bittag_map_color_rgb, /* map color rgb */
- ((void *)0), /* fill_rectangle */
- ((void *)0), /* tile rectangle */
- ((void *)0), /* copy mono */
- ((void *)0), /* copy color */
- ((void *)0), /* obsolete draw line */
- ((void *)0), /* get_bits */
- gdev_prn_get_params, /* get params */
- bittag_put_params, /* put params */
- bittag_rgb_map_rgb_color, /* map_cmyk_color */
- ((void *)0), /* get_xfonts */
- ((void *)0), /* get_xfont_device */
- ((void *)0), /* map_rgb_alpha_color */
- gx_page_device_get_page_device, /* get_page_device */
- ((void *)0), /* get_alpha_bits */
- ((void *)0), /* copy_alpha */
- ((void *)0), /* get_band */
- ((void *)0), /* copy_rop */
- ((void *)0), /* fill_path */
- ((void *)0), /* stroke_path */
- ((void *)0), /* fill_mask */
- ((void *)0), /* fill_trapezoid */
- ((void *)0), /* fill_parallelogram */
- ((void *)0), /* fill_triangle */
- ((void *)0), /* draw_thin_line */
- ((void *)0), /* begin_image */
- ((void *)0), /* image_data */
- ((void *)0), /* end_image */
- ((void *)0), /* strip_tile_rectangle */
- ((void *)0), /* strip_copy_rop */
- ((void *)0), /* get_clipping_box */
- ((void *)0), /* begin_typed_image */
- ((void *)0), /* get_bits_rectangle */
- ((void *)0), /* map_color_rgb_alpha */
- ((void *)0), /* create_compositor */
- ((void *)0), /* get_hardware_params */
- ((void *)0), /* text_begin */
- ((void *)0), /* finish_copydevice */
- ((void *)0), /* begin_transparency_group */
- ((void *)0), /* end_transparency_group */
- ((void *)0), /* begin_transparency_mask */
- ((void *)0), /* end_transparency_mask */
- ((void *)0), /* discard_transparency_layer */
- bittag_get_color_mapping_procs, /* get_color_mapping_procs */
- gx_default_DevRGB_get_color_comp_index, /* get_color_comp_index */
- bittag_rgb_map_rgb_color, /* encode_color */
- bittag_map_color_rgb, /* decode_color */
- ((void *)0), /* pattern_manage */
- ((void *)0), /* fill_rectangle_hl_color */
- ((void *)0), /* include_color_space */
- ((void *)0), /* fill_linear_color_scanline */
- ((void *)0), /* fill_linear_color_trapezoid */
- ((void *)0), /* fill_linear_color_triangle */
- ((void *)0), /* update_spot_equivalent_colors */
- ((void *)0), /* ret_devn_params */
- bittag_fillpage, /* fillpage */
- ((void *)0), /* push_transparency_state */
- ((void *)0), /* pop_transparency_state */
- bit_put_image, /* put_image */
- bit_dev_spec_op /* dev_spec_op */
- };
+static void
+bitrgbtags_initialize_device_procs(gx_device *dev)
+{
+ bit_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, bittag_open);
+ set_dev_proc(dev, map_rgb_color, bittag_rgb_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, bittag_map_color_rgb);
+ set_dev_proc(dev, get_params, gdev_prn_get_params);
+ set_dev_proc(dev, put_params, bittag_put_params);
+ set_dev_proc(dev, map_cmyk_color, bittag_rgb_map_rgb_color);
+ set_dev_proc(dev, get_color_mapping_procs, bittag_get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, gx_default_DevRGB_get_color_comp_index);
+ set_dev_proc(dev, encode_color, bittag_rgb_map_rgb_color);
+ set_dev_proc(dev, decode_color, bittag_map_color_rgb);
+ set_dev_proc(dev, fillpage, bittag_fillpage);
+ set_dev_proc(dev, put_image, bit_put_image);
+}
const gx_device_bit gs_bitrgbtags_device =
{
sizeof(gx_device_bit),
- &bitrgbtags_procs,
+ bitrgbtags_initialize_device_procs,
"bitrgbtags",
0, /* memory */
&st_device_printer,
@@ -277,7 +196,7 @@ const gx_device_bit gs_bitrgbtags_device =
{ 8, 8, 8, 8 }, /* comp bits */
{ 0xFF0000, 0x00FF00, 0x0000FF, 0xFF000000 }, /* comp mask */
( "DeviceRGBT" ), /* color model name */
- GX_CINFO_OPMODE_UNKNOWN, /* overprint mode */
+ GX_CINFO_OPMSUPPORTED_UNKNOWN, /* overprint mode */
0, /* process comps */
0 /* icc_locations */
},
@@ -375,13 +294,13 @@ const gx_device_bit gs_bitrgbtags_device =
};
static void
-cmyk_cs_to_rgb_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+cmyk_cs_to_rgb_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
color_cmyk_to_rgb(c, m, y, k, NULL, out, dev->memory);
}
static void
-private_rgb_cs_to_rgb_cm(gx_device * dev, const gs_gstate *pgs,
+private_rgb_cs_to_rgb_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
out[0] = r;
@@ -390,7 +309,7 @@ private_rgb_cs_to_rgb_cm(gx_device * dev, const gs_gstate *pgs,
}
static void
-gray_cs_to_rgb_cm(gx_device * dev, frac gray, frac out[])
+gray_cs_to_rgb_cm(const gx_device * dev, frac gray, frac out[])
{
out[0] = out[1] = out[2] = gray;
}
@@ -400,8 +319,9 @@ static const gx_cm_color_map_procs bittag_DeviceRGB_procs = {
};
static const gx_cm_color_map_procs *
-bittag_get_color_mapping_procs(const gx_device *dev)
+bittag_get_color_mapping_procs(const gx_device *dev, const gx_device **map_dev)
{
+ *map_dev = dev;
return &bittag_DeviceRGB_procs;
}
@@ -447,6 +367,19 @@ bit_mono_map_color(gx_device * dev, const gx_color_value cv[])
return (bpc == 1 ? gx_max_color_value - gray : gray) >> drop;
}
+static int
+bit_mono_decode_color(gx_device * dev, gx_color_index color, gx_color_value *cv)
+{
+ int bpc = dev->color_info.depth;
+ int max = (1<<bpc)-1;
+
+ if (bpc == 1)
+ cv[0] = -((gx_color_value)color ^ 1);
+ else
+ cv[0] = color * gx_max_color_value / max;
+ return 0;
+}
+
#if 0 /* unused */
/* Map RGB to gray shade. */
/* Only used in CMYK mode when put_params has set ForceMono=1 */
@@ -557,6 +490,19 @@ bit_map_cmyk_color(gx_device * dev, const gx_color_value cv[])
}
static int
+bit_map_color_cmyk(gx_device * dev, gx_color_index color, gx_color_value *cv)
+{
+ int bpc = dev->color_info.depth / 4;
+ int max = (1<<bpc)-1;
+
+ cv[0] = (color>>(3*bpc)) * gx_max_color_value / max;
+ cv[1] = (color>>(2*bpc)) * gx_max_color_value / max;
+ cv[2] = (color>>(1*bpc)) * gx_max_color_value / max;
+ cv[3] = (color>>(0*bpc)) * gx_max_color_value / max;
+ return 0;
+}
+
+static int
bittag_open(gx_device * pdev)
{
gx_device_printer *ppdev = (gx_device_printer *)pdev;
diff --git a/devices/gdevbj10.c b/devices/gdevbj10.c
index 9468552a..09dd3835 100644
--- a/devices/gdevbj10.c
+++ b/devices/gdevbj10.c
@@ -106,12 +106,17 @@ static dev_proc_open_device(bj200_open);
static dev_proc_print_page(bj10e_print_page);
-static gx_device_procs prn_bj200_procs =
/* Since the print_page doesn't alter the device, this device can print in the background */
- prn_procs(bj200_open, gdev_prn_bg_output_page, gdev_prn_close);
+static void
+bj200_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono_bg(dev);
+
+ set_dev_proc(dev, open_device, bj200_open);
+}
const gx_device_printer far_data gs_bj200_device =
- prn_device(prn_bj200_procs, "bj200",
+ prn_device(bj200_initialize_device_procs, "bj200",
DEFAULT_WIDTH_10THS,
DEFAULT_HEIGHT_10THS,
360, /* x_dpi */
@@ -142,11 +147,16 @@ const gx_device_printer far_data gs_bj200_device =
static dev_proc_open_device(bj10e_open);
-static gx_device_procs prn_bj10e_procs =
- prn_procs(bj10e_open, gdev_prn_output_page, gdev_prn_close);
+static void
+bj10e_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono_bg(dev);
+
+ set_dev_proc(dev, open_device, bj10e_open);
+}
const gx_device_printer far_data gs_bj10e_device =
- prn_device(prn_bj10e_procs, "bj10e",
+ prn_device(bj10e_initialize_device_procs, "bj10e",
DEFAULT_WIDTH_10THS,
DEFAULT_HEIGHT_10THS,
360, /* x_dpi */
diff --git a/devices/gdevbmp.c b/devices/gdevbmp.c
index 52a13374..f74f4516 100644
--- a/devices/gdevbmp.c
+++ b/devices/gdevbmp.c
@@ -26,7 +26,8 @@ static dev_proc_print_page(bmp_cmyk_print_page);
/* Monochrome. */
const gx_device_printer gs_bmpmono_device =
-prn_device(prn_bg_procs, "bmpmono", /* The print_page proc is compatible with allowing bg printing */
+/* The print_page proc is compatible with allowing bg printing */
+prn_device(gdev_prn_initialize_device_procs_mono_bg, "bmpmono",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -36,11 +37,17 @@ prn_device(prn_bg_procs, "bmpmono", /* The print_page proc is compatible with al
/* (Uses a fixed palette of 256 gray levels.) */
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs bmpgray_procs =
-prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- gx_default_gray_map_rgb_color, gx_default_gray_map_color_rgb);
+static void
+bmpgray_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray_bg(dev);
+
+ set_dev_proc(dev, encode_color, gx_default_8bit_map_gray_color);
+ set_dev_proc(dev, decode_color, gx_default_8bit_map_color_gray);
+}
+
const gx_device_printer gs_bmpgray_device = {
- prn_device_body(gx_device_printer, bmpgray_procs, "bmpgray",
+ prn_device_body(gx_device_printer, bmpgray_initialize_device_procs, "bmpgray",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -50,17 +57,14 @@ const gx_device_printer gs_bmpgray_device = {
/* 1-bit-per-plane separated CMYK color. */
/* Since the print_page doesn't alter the device, this device can print in the background */
-#define bmp_cmyk_procs(p_map_color_rgb, p_map_cmyk_color)\
- gdev_prn_open, NULL, NULL, gdev_prn_bg_output_page, gdev_prn_close,\
- NULL, p_map_color_rgb, NULL, NULL, NULL, NULL, NULL, NULL,\
- gdev_prn_get_params, gdev_prn_put_params,\
- p_map_cmyk_color, NULL, NULL, NULL, gx_page_device_get_page_device
-
-static const gx_device_procs bmpsep1_procs = {
- bmp_cmyk_procs(cmyk_1bit_map_color_rgb, cmyk_1bit_map_cmyk_color)
-};
+static void
+bmpsep1_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_cmyk1_bg(dev);
+}
+
const gx_device_printer gs_bmpsep1_device = {
- prn_device_body(gx_device_printer, bmpsep1_procs, "bmpsep1",
+ prn_device_body(gx_device_printer, bmpsep1_initialize_device_procs, "bmpsep1",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0,0,0,0, /* margins */
@@ -68,12 +72,14 @@ const gx_device_printer gs_bmpsep1_device = {
};
/* 8-bit-per-plane separated CMYK color. */
+static void
+bmpsep8_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_cmyk8_bg(dev);
+}
-static const gx_device_procs bmpsep8_procs = {
- bmp_cmyk_procs(cmyk_8bit_map_color_rgb, cmyk_8bit_map_cmyk_color)
-};
const gx_device_printer gs_bmpsep8_device = {
- prn_device_body(gx_device_printer, bmpsep8_procs, "bmpsep8",
+ prn_device_body(gx_device_printer, bmpsep8_initialize_device_procs, "bmpsep8",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0,0,0,0, /* margins */
@@ -83,11 +89,19 @@ const gx_device_printer gs_bmpsep8_device = {
/* 4-bit planar (EGA/VGA-style) color. */
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs bmp16_procs =
-prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- pc_4bit_map_rgb_color, pc_4bit_map_color_rgb);
+static void
+bmp16_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_cmyk8_bg(dev);
+
+ set_dev_proc(dev, map_rgb_color, pc_4bit_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, pc_4bit_map_color_rgb);
+ set_dev_proc(dev, encode_color, pc_4bit_map_rgb_color);
+ set_dev_proc(dev, decode_color, pc_4bit_map_color_rgb);
+}
+
const gx_device_printer gs_bmp16_device = {
- prn_device_body(gx_device_printer, bmp16_procs, "bmp16",
+ prn_device_body(gx_device_printer, bmp16_initialize_device_procs, "bmp16",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -98,11 +112,19 @@ const gx_device_printer gs_bmp16_device = {
/* (Uses a fixed palette of 3,3,2 bits.) */
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs bmp256_procs =
-prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- pc_8bit_map_rgb_color, pc_8bit_map_color_rgb);
+static void
+bmp256_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, map_rgb_color, pc_8bit_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, pc_8bit_map_color_rgb);
+ set_dev_proc(dev, encode_color, pc_8bit_map_rgb_color);
+ set_dev_proc(dev, decode_color, pc_8bit_map_color_rgb);
+}
+
const gx_device_printer gs_bmp256_device = {
- prn_device_body(gx_device_printer, bmp256_procs, "bmp256",
+ prn_device_body(gx_device_printer, bmp256_initialize_device_procs, "bmp256",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -112,23 +134,33 @@ const gx_device_printer gs_bmp256_device = {
/* 24-bit color. */
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs bmp16m_procs =
-prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- bmp_map_16m_rgb_color, bmp_map_16m_color_rgb);
+static void
+bmp16m_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, map_rgb_color, bmp_map_16m_rgb_color);
+ set_dev_proc(dev, map_color_rgb, bmp_map_16m_color_rgb);
+ set_dev_proc(dev, encode_color, bmp_map_16m_rgb_color);
+ set_dev_proc(dev, decode_color, bmp_map_16m_color_rgb);
+}
+
const gx_device_printer gs_bmp16m_device =
-prn_device(bmp16m_procs, "bmp16m",
+prn_device(bmp16m_initialize_device_procs, "bmp16m",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
24, bmp_print_page);
/* 32-bit CMYK color (outside the BMP specification). */
+static void
+bmp32b_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_cmyk8_bg(dev);
+}
-static const gx_device_procs bmp32b_procs = {
- bmp_cmyk_procs(cmyk_8bit_map_color_rgb, gx_default_cmyk_map_cmyk_color)
-};
const gx_device_printer gs_bmp32b_device =
-prn_device(bmp32b_procs, "bmp32b",
+prn_device(bmp32b_initialize_device_procs, "bmp32b",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
diff --git a/devices/gdevccr.c b/devices/gdevccr.c
index 451cb82c..03fcfa59 100644
--- a/devices/gdevccr.c
+++ b/devices/gdevccr.c
@@ -80,8 +80,8 @@ typedef struct gx_device_ccr_s gx_device_ccr;
#define DEFAULT_HEIGHT_10THS_A3 165
/* Macro for generating ccr device descriptors. */
-#define ccr_prn_device(procs, dev_name, margin, num_comp, depth, max_gray, max_rgb, print_page)\
-{ prn_device_body(gx_device_ccr, procs, dev_name,\
+#define ccr_prn_device(init, dev_name, margin, num_comp, depth, max_gray, max_rgb, print_page)\
+{ prn_device_body(gx_device_ccr, init, dev_name,\
DEFAULT_WIDTH_10THS_A3, DEFAULT_HEIGHT_10THS_A3, X_DPI, Y_DPI,\
margin, margin, margin, margin,\
num_comp, depth, max_gray, max_rgb, max_gray + 1, max_rgb + 1,\
@@ -96,14 +96,22 @@ static dev_proc_map_color_rgb(ccr_map_color_rgb);
static dev_proc_print_page(ccr_print_page);
/* The device procedures */
-/* Since the print_page doesn't alter the device, this device can print in the background */
-static gx_device_procs ccr_procs =
- prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- ccr_map_rgb_color, ccr_map_color_rgb);
+static void
+ccr_initialize_device_procs(gx_device *dev)
+{
+ /* Since the print_page doesn't alter the device, this device can
+ * print in the background */
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, map_rgb_color, ccr_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, ccr_map_color_rgb);
+ set_dev_proc(dev, encode_color, ccr_map_rgb_color);
+ set_dev_proc(dev, decode_color, ccr_map_color_rgb);
+}
/* The device descriptors themselves */
gx_device_ccr far_data gs_ccr_device =
- ccr_prn_device(ccr_procs, "ccr", 0.2, 3, 8, 1, 1,
+ ccr_prn_device(ccr_initialize_device_procs, "ccr", 0.2, 3, 8, 1, 1,
ccr_print_page);
/* ------ Color mapping routines ------ */
diff --git a/devices/gdevcdj.c b/devices/gdevcdj.c
index 49b30df6..6908067b 100644
--- a/devices/gdevcdj.c
+++ b/devices/gdevcdj.c
@@ -253,6 +253,8 @@ static dev_proc_map_rgb_color (gdev_cmyk_map_rgb_color);
static dev_proc_map_rgb_color (gdev_pcl_map_rgb_color);
static dev_proc_map_color_rgb (gdev_pcl_map_color_rgb);
static dev_proc_decode_color (gdev_cmyk_map_color_cmyk);
+static dev_proc_encode_color (gdev_pcl_map_gray_color);
+static dev_proc_decode_color (gdev_pcl_map_color_gray);
/* Print-page, parameters and miscellaneous procedures */
static dev_proc_open_device(dj500c_open);
@@ -404,22 +406,22 @@ typedef struct {
/* The basic structure for all printers. Note the presence of the cmyk, depth
and correct fields even if soem are not used by all printers. */
-#define prn_colour_device_body(dtype, procs, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page, cmyk, correct)\
- prn_device_body(dtype, procs, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page), cmyk, depth /* default */, correct
+#define prn_colour_device_body(dtype, init, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page, cmyk, correct)\
+ prn_device_body(dtype, init, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, ncomp, depth, mg, mc, dg, dc, print_page), cmyk, depth /* default */, correct
/* Note: the computation of color_info values here must match */
/* the computation in the cdj_set_bpp procedure below. */
-#define prn_hp_colour_device(dtype, procs, dev_name, x_dpi, y_dpi, bpp, print_page, correct)\
- prn_colour_device_body(dtype, procs, dev_name,\
+#define prn_hp_colour_device(dtype, init, dev_name, x_dpi, y_dpi, bpp, print_page, correct)\
+ prn_colour_device_body(dtype, init, dev_name,\
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS, x_dpi, y_dpi, 0, 0, 0, 0,\
(bpp == 32 ? 4 : (bpp == 1 || bpp == 8) ? 1 : 3), bpp,\
(bpp >= 8 ? 255 : 1), (bpp >= 8 ? 255 : bpp > 1 ? 1 : 0),\
(bpp >= 8 ? 256 : 2), (bpp >= 8 ? 256 : bpp > 1 ? 2 : 0),\
print_page, 0 /* cmyk */, correct)
-#define prn_cmyk_colour_device(dtype, procs, dev_name, x_dpi, y_dpi, bpp, print_page, correct)\
- prn_colour_device_body(dtype, procs, dev_name,\
+#define prn_cmyk_colour_device(dtype, init, dev_name, x_dpi, y_dpi, bpp, print_page, correct)\
+ prn_colour_device_body(dtype, init, dev_name,\
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS, x_dpi, y_dpi, 0, 0, 0, 0,\
((bpp == 1 || bpp == 4) ? 1 : 4), bpp,\
(bpp > 8 ? 255 : 1), (1 << (bpp >> 2)) - 1, /* max_gray, max_color */\
@@ -429,210 +431,227 @@ typedef struct {
#define bjc_device(dtype, p, d, x, y, b, pp, c) \
prn_cmyk_colour_device(dtype, p, d, x, y, b, pp, c)
-#define cdj_device(procs, dev_name, x_dpi, y_dpi, bpp, print_page, correction, shingling, depletion)\
-{ prn_hp_colour_device(gx_device_cdj, procs, dev_name, x_dpi, y_dpi, bpp, print_page, correction),\
+#define cdj_device(init, dev_name, x_dpi, y_dpi, bpp, print_page, correction, shingling, depletion)\
+{ prn_hp_colour_device(gx_device_cdj, init, dev_name, x_dpi, y_dpi, bpp, print_page, correction),\
shingling,\
depletion\
}
-#define pjxl_device(procs, dev_name, x_dpi, y_dpi, bpp, print_page, printqual, rendertype)\
-{ prn_hp_colour_device(gx_device_pjxl, procs, dev_name, x_dpi, y_dpi, bpp, print_page, 0), \
+#define pjxl_device(init, dev_name, x_dpi, y_dpi, bpp, print_page, printqual, rendertype)\
+{ prn_hp_colour_device(gx_device_pjxl, init, dev_name, x_dpi, y_dpi, bpp, print_page, 0), \
printqual,\
rendertype\
}
-#define pj_device(procs, dev_name, x_dpi, y_dpi, bpp, print_page)\
-{ prn_hp_colour_device(gx_device_pj, procs, dev_name, x_dpi, y_dpi, bpp, print_page, 0) }
+#define pj_device(init, dev_name, x_dpi, y_dpi, bpp, print_page)\
+{ prn_hp_colour_device(gx_device_pj, init, dev_name, x_dpi, y_dpi, bpp, print_page, 0) }
-#define bjc600_device(procs, dev_name, x_dpi, y_dpi, bpp, print_page, t, mf, mt, mws, mw, pq, dt, cc, pc, mp) \
-{ bjc_device(gx_device_bjc600, procs, dev_name, x_dpi, y_dpi, bpp, print_page, 0),\
+#define bjc600_device(init, dev_name, x_dpi, y_dpi, bpp, print_page, t, mf, mt, mws, mw, pq, dt, cc, pc, mp) \
+{ bjc_device(gx_device_bjc600, init, dev_name, x_dpi, y_dpi, bpp, print_page, 0),\
t, 0., { mf, mt, mws, mw, pq, dt, cc, pc, mp }\
}
-#define bjc800_device(procs, dev_name, x_dpi, y_dpi, bpp, print_page, t, mf, mt, mws, mw, pq, dt, cc, pc) \
-{ bjc_device(gx_device_bjc800, procs, dev_name, x_dpi, y_dpi, bpp, print_page, 0),\
+#define bjc800_device(init, dev_name, x_dpi, y_dpi, bpp, print_page, t, mf, mt, mws, mw, pq, dt, cc, pc) \
+{ bjc_device(gx_device_bjc800, init, dev_name, x_dpi, y_dpi, bpp, print_page, 0),\
t, 0., { mf, mt, mws, mw, pq, dt, cc, pc }\
}
/* Since the print_page doesn't alter the device, this device can print in the background */
-#define hp_colour_procs(proc_colour_open, proc_get_params, proc_put_params) {\
- proc_colour_open,\
- gx_default_get_initial_matrix,\
- gx_default_sync_output,\
- gdev_prn_bg_output_page,\
- gdev_prn_close,\
- gdev_pcl_map_rgb_color,\
- gdev_pcl_map_color_rgb,\
- NULL, /* fill_rectangle */\
- NULL, /* tile_rectangle */\
- NULL, /* copy_mono */\
- NULL, /* copy_color */\
- NULL, /* draw_line */\
- gx_default_get_bits,\
- proc_get_params,\
- proc_put_params\
+static void
+hp_colour_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, map_rgb_color, gdev_pcl_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gdev_pcl_map_color_rgb);
+ set_dev_proc(dev, get_params, cdj_get_params);
+ set_dev_proc(dev, put_params, cdj_put_params);
+
+ if (dev->color_info.num_components == 1) {
+ set_dev_proc(dev, encode_color, gdev_pcl_map_gray_color);
+ set_dev_proc(dev, decode_color, gdev_pcl_map_color_gray);
+ } else {
+ set_dev_proc(dev, encode_color, gdev_pcl_map_rgb_color);
+ set_dev_proc(dev, decode_color, gdev_pcl_map_color_rgb);
+ }
}
-/* Since the print_page doesn't alter the device, this device can print in the background */
-#define cmyk_colour_procs(proc_colour_open, proc_get_params, proc_put_params) {\
- proc_colour_open,\
- gx_default_get_initial_matrix,\
- gx_default_sync_output,\
- gdev_prn_bg_output_page,\
- gdev_prn_close,\
- NULL /* map_rgb_color */,\
- NULL /* map_color_rgb */,\
- NULL /* fill_rectangle */,\
- NULL /* tile_rectangle */,\
- NULL /* copy_mono */,\
- NULL /* copy_color */,\
- NULL /* draw_line */,\
- gx_default_get_bits,\
- proc_get_params,\
- proc_put_params,\
- gdev_cmyk_map_cmyk_color,\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- NULL, /* get_page_device */\
- NULL, /* get_alpha_bits */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- NULL, /* fill_path */\
- NULL, /* stroke_path */\
- NULL, /* fill_mask */\
- NULL, /* fill_trapezoid */\
- NULL, /* fill_parallelogram */\
- NULL, /* fill_triangle */\
- NULL, /* draw_thin_line */\
- NULL, /* begin_image */\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL, /* strip_copy_rop */\
- NULL, /* get_clipping_box */\
- NULL, /* begin_typed_image */\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- NULL, /* create_compositor */\
- NULL, /* get_hardware_params */\
- NULL, /* text_begin */\
- NULL, /* finish_copydevice */\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL, /* discard_transparency_layer */\
- NULL, /* get_color_mapping_procs */\
- NULL, /* get_color_comp_index */\
- gdev_cmyk_map_cmyk_color, /* encode_color */\
- gdev_cmyk_map_color_cmyk /* decode_color */\
-}
-
-static gx_device_procs cdj500_procs =
-hp_colour_procs(dj500c_open, cdj_get_params, cdj_put_params);
-
-static gx_device_procs cdj550_procs =
-hp_colour_procs(dj550c_open, cdj_get_params, cdj_put_params);
+static void
+cdj500_initialize_device_procs(gx_device *dev)
+{
+ hp_colour_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, dj500c_open);
+}
+
+static void
+cdj550_initialize_device_procs(gx_device *dev)
+{
+ hp_colour_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, dj550c_open);
+}
#ifdef USE_CDJ550_CMYK
-static gx_device_procs cdj550cmyk_procs =
-cmyk_colour_procs(dj550c_open, cdj_get_params, cdj_put_params);
+static void
+cdj550cmyk_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, open_device, dj550c_open);
+ set_dev_proc(dev, get_params, cdj_get_params);
+ set_dev_proc(dev, put_params, cdj_put_params);
+ set_dev_proc(dev, map_cmyk_color, gdev_cmyk_map_cmyk_color);
+ set_dev_proc(dev, encode_color, gdev_cmyk_map_cmyk_color);
+ set_dev_proc(dev, decode_color, gdev_cmyk_map_color_cmyk);
+}
#endif
-static gx_device_procs dj505j_procs =
-hp_colour_procs(dj505j_open, cdj_get_params, cdj_put_params);
+static void
+dj505j_initialize_device_procs(gx_device *dev)
+{
+ hp_colour_initialize_device_procs(dev);
-static gx_device_procs dnj650c_procs =
-hp_colour_procs(dnj650c_open, cdj_get_params, cdj_put_params);
+ set_dev_proc(dev, open_device, dj505j_open);
+}
-static gx_device_procs lj4dith_procs =
-hp_colour_procs(lj4dith_open, cdj_get_params, cdj_put_params);
+static void
+dnj650c_initialize_device_procs(gx_device *dev)
+{
+ hp_colour_initialize_device_procs(dev);
-static gx_device_procs pj_procs =
-hp_colour_procs(pj_open, gdev_prn_get_params, pj_put_params);
+ set_dev_proc(dev, open_device, dnj650c_open);
+}
-static gx_device_procs pjxl_procs =
-hp_colour_procs(pjxl_open, pjxl_get_params, pjxl_put_params);
+static void
+lj4dith_initialize_device_procs(gx_device *dev)
+{
+ hp_colour_initialize_device_procs(dev);
-static gx_device_procs pjxl300_procs =
-hp_colour_procs(pjxl300_open, pjxl_get_params, pjxl_put_params);
+ set_dev_proc(dev, open_device, lj4dith_open);
+}
-static gx_device_procs bjc_procs =
-cmyk_colour_procs(bjc_open, bjc_get_params, bjc_put_params);
+static void
+pj_initialize_device_procs(gx_device *dev)
+{
+ hp_colour_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, pj_open);
+ set_dev_proc(dev, get_params, gdev_prn_get_params);
+ set_dev_proc(dev, put_params, pj_put_params);
+}
+
+static void
+pjxl_initialize_device_procs(gx_device *dev)
+{
+ hp_colour_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, pjxl_open);
+ set_dev_proc(dev, get_params, pjxl_get_params);
+ set_dev_proc(dev, put_params, pjxl_put_params);
+}
-static gx_device_procs escp_procs =
-hp_colour_procs(escp_open, ep_get_params, ep_put_params);
+static void
+pjxl300_initialize_device_procs(gx_device *dev)
+{
+ hp_colour_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, pjxl300_open);
+ set_dev_proc(dev, get_params, pjxl_get_params);
+ set_dev_proc(dev, put_params, pjxl_put_params);
+}
+
+static void
+bjc_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, open_device, bjc_open);
+ set_dev_proc(dev, get_params, bjc_get_params);
+ set_dev_proc(dev, put_params, bjc_put_params);
+ set_dev_proc(dev, map_cmyk_color, gdev_cmyk_map_cmyk_color);
+ set_dev_proc(dev, encode_color, gdev_cmyk_map_cmyk_color);
+ set_dev_proc(dev, decode_color, gdev_cmyk_map_color_cmyk);
+}
+
+static void
+escp_initialize_device_procs(gx_device *dev)
+{
+ hp_colour_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, escp_open);
+ set_dev_proc(dev, get_params, ep_get_params);
+ set_dev_proc(dev, put_params, ep_put_params);
+}
gx_device_cdj far_data gs_cdjmono_device =
-cdj_device(cdj500_procs, "cdjmono", 300, 300, 1,
+cdj_device(cdj500_initialize_device_procs, "cdjmono", 300, 300, 1,
dj500c_print_page, 4, 0, 1);
gx_device_cdj far_data gs_cdeskjet_device =
-cdj_device(cdj500_procs, "cdeskjet", 300, 300, 24,
+cdj_device(cdj500_initialize_device_procs, "cdeskjet", 300, 300, 24,
dj500c_print_page, 4, 2, 1);
gx_device_cdj far_data gs_cdjcolor_device =
-cdj_device(cdj500_procs, "cdjcolor", 300, 300, 24,
+cdj_device(cdj500_initialize_device_procs, "cdjcolor", 300, 300, 24,
dj500c_print_page, 4, 2, 1);
gx_device_cdj far_data gs_cdj500_device =
-cdj_device(cdj500_procs, "cdj500", 300, 300, BITSPERPIXEL,
+cdj_device(cdj500_initialize_device_procs, "cdj500", 300, 300, BITSPERPIXEL,
dj500c_print_page, 4, 2, 1);
gx_device_cdj far_data gs_cdj550_device =
-cdj_device(cdj550_procs, "cdj550", 300, 300, BITSPERPIXEL,
+cdj_device(cdj550_initialize_device_procs, "cdj550", 300, 300, BITSPERPIXEL,
dj550c_print_page, 0, 2, 1);
#ifdef USE_CDJ550_CMYK
gx_device_cdj far_data gs_cdj550cmyk_device = {
- prn_cmyk_colour_device(cdj550cmyk_procs, "cdj550cmyk", 300, 300,
+ prn_cmyk_colour_device(cdj550cmyk_initialize_device_procs, "cdj550cmyk", 300, 300,
BITSPERPIXEL, dj550c_print_page, 0), 2, 1
};
#endif
gx_device_cdj far_data gs_picty180_device =
-cdj_device(cdj550_procs, "picty180", 300, 300, BITSPERPIXEL,
+cdj_device(cdj550_initialize_device_procs, "picty180", 300, 300, BITSPERPIXEL,
picty180_print_page, 0, 2, 1);
gx_device_cdj far_data gs_dj505j_device =
-cdj_device(dj505j_procs, "dj505j", 300, 300, 1,
+cdj_device(dj505j_initialize_device_procs, "dj505j", 300, 300, 1,
dj505j_print_page, 4, 0, 1);
gx_device_pj far_data gs_declj250_device =
-pj_device(pj_procs, "declj250", 180, 180, BITSPERPIXEL,
+pj_device(pj_initialize_device_procs, "declj250", 180, 180, BITSPERPIXEL,
declj250_print_page);
gx_device_cdj far_data gs_dnj650c_device =
-cdj_device(dnj650c_procs, "dnj650c", 300, 300, BITSPERPIXEL,
+cdj_device(dnj650c_initialize_device_procs, "dnj650c", 300, 300, BITSPERPIXEL,
dnj650c_print_page, 0, 2, 1);
gx_device_cdj far_data gs_lj4dith_device =
-cdj_device(lj4dith_procs, "lj4dith", 600, 600, 8,
+cdj_device(lj4dith_initialize_device_procs, "lj4dith", 600, 600, 8,
lj4dith_print_page, 4, 0, 1);
gx_device_cdj far_data gs_lj4dithp_device =
-cdj_device(lj4dith_procs, "lj4dithp", 600, 600, 8,
+cdj_device(lj4dith_initialize_device_procs, "lj4dithp", 600, 600, 8,
lj4dithp_print_page, 4, 0, 1);
gx_device_pj far_data gs_pj_device =
-pj_device(pj_procs, "pj", 180, 180, BITSPERPIXEL,
+pj_device(pj_initialize_device_procs, "pj", 180, 180, BITSPERPIXEL,
pj_print_page);
gx_device_pjxl far_data gs_pjxl_device =
-pjxl_device(pjxl_procs, "pjxl", 180, 180, BITSPERPIXEL,
+pjxl_device(pjxl_initialize_device_procs, "pjxl", 180, 180, BITSPERPIXEL,
pjxl_print_page, 0, 0);
gx_device_pjxl far_data gs_pjxl300_device =
-pjxl_device(pjxl300_procs, "pjxl300", 300, 300, BITSPERPIXEL,
+pjxl_device(pjxl300_initialize_device_procs, "pjxl300", 300, 300, BITSPERPIXEL,
pjxl300_print_page, 0, 0);
gx_device_cdj far_data gs_escp_device =
-cdj_device(escp_procs, "escp", 360, 360, 8,
+cdj_device(escp_initialize_device_procs, "escp", 360, 360, 8,
escp_print_page, 0, 0, 1);
gx_device_cdj far_data gs_escpc_device =
-cdj_device(escp_procs, "escpc", 360, 360, 24,
+cdj_device(escp_initialize_device_procs, "escpc", 360, 360, 24,
escp_print_page, 0, 0, 1);
/* Args of bjc drivers are manualFeed, mediaType, printQuality, printColor,
@@ -640,7 +659,7 @@ cdj_device(escp_procs, "escpc", 360, 360, 24,
gx_device_bjc600 far_data gs_bjc600_device =
bjc600_device(
- bjc_procs,
+ bjc_initialize_device_procs,
BJC_BJC600,
BJC600_DEFAULT_RESOLUTION,
BJC600_DEFAULT_RESOLUTION,
@@ -659,7 +678,7 @@ gx_device_bjc600 far_data gs_bjc600_device =
gx_device_bjc800 far_data gs_bjc800_device =
bjc800_device(
- bjc_procs,
+ bjc_initialize_device_procs,
BJC_BJC800,
BJC800_DEFAULT_RESOLUTION,
BJC800_DEFAULT_RESOLUTION,
@@ -3052,6 +3071,96 @@ gdev_pcl_map_color_rgb(gx_device *pdev, gx_color_index color,
return 0;
}
+static gx_color_index
+gdev_pcl_map_gray_color(gx_device *pdev, const gx_color_value cv[])
+{
+ gx_color_value r = cv[0];
+ if (gx_color_value_to_byte(r) == 0xff)
+ return (gx_color_index)0; /* white */
+ else {
+ int correction = cprn_device->correction;
+ gx_color_value c = gx_max_color_value - r;
+ gx_color_value m = gx_max_color_value - r;
+
+ /* Colour correction for better blacks when using the colour ink
+ * cartridge (on the DeskJet 500C only). We reduce the cyan component
+ * by some fraction (eg. 4/5) to correct the slightly greenish cast
+ * resulting from an equal mix of the three inks */
+ if (correction && c > 0) {
+ c = ((c >> shift) * (c * correction)) /
+ ((c * (correction + 1)) >> shift);
+ }
+
+ switch (pdev->color_info.depth) {
+ case 1:
+ return (c > gx_max_color_value / 2 ?
+ (gx_color_index)1 : (gx_color_index)0);
+ case 8:
+ if (pdev->color_info.num_components >= 3)
+ return (gx_color_value_to_1bit(c) +
+ (gx_color_value_to_1bit(c) << 1) +
+ (gx_color_value_to_1bit(c) << 2));
+ else
+ return ((((ulong)c * red_weight +
+ (ulong)m * (green_weight + blue_weight))
+ >> (gx_color_value_bits + 2)));
+ case 16:
+ /* FIXME: Simple truncation is not ideal. Should round really. */
+ return (gx_color_value_to_5bits(c) +
+ (gx_color_value_to_6bits(c) << 5) +
+ (gx_color_value_to_5bits(c) << 11));
+ case 24:
+ return (gx_color_value_to_byte(c) +
+ (gx_color_value_to_byte(c) << 8) +
+ ((ulong)gx_color_value_to_byte(c) << 16));
+ case 32:
+ return ((ulong)gx_color_value_to_byte(c) << 24);
+ }
+ }
+ return (gx_color_index)0; /* This never happens */
+}
+
+static int
+gdev_pcl_map_color_gray(gx_device *pdev, gx_color_index color,
+ gx_color_value *cv)
+{
+ /* For the moment, we simply ignore any black correction */
+ switch (pdev->color_info.depth) {
+ case 1:
+ cv[0] = -((gx_color_value)color ^ 1);
+ break;
+ case 8:
+ if (pdev->color_info.num_components >= 3)
+ { gx_color_value c = (gx_color_value)color ^ 7;
+ cv[0] = -(c & 1);
+ }
+ else
+ { gx_color_value value = (gx_color_value)color ^ 0xff;
+ cv[0] = (value << 8) + value;
+ }
+ break;
+ case 16:
+ { gx_color_value c = (gx_color_value)color ^ 0xffff;
+ gx_color_value value = (c >> 6) & 0x3f;
+ cv[0] = ((value << 10) + (value << 4) + (value >> 2))
+ >> (16 - gx_color_value_bits);
+ }
+ break;
+ case 24:
+ { gx_color_index c = color ^ 0xffffff;
+ cv[0] = gx_color_value_from_byte((gx_color_value)(c >> 16));
+ }
+ break;
+ case 32:
+#define gx_maxcol gx_color_value_from_byte(gx_color_value_to_byte(gx_max_color_value))
+ { gx_color_value w = gx_maxcol - gx_color_value_from_byte(color >> 24);
+ cv[0] = w;
+ }
+ break;
+ }
+ return 0;
+}
+
/*
* Convert and expand scanlines:
*
diff --git a/devices/gdevcfax.c b/devices/gdevcfax.c
index cd3dc15c..a8fc3bd6 100644
--- a/devices/gdevcfax.c
+++ b/devices/gdevcfax.c
@@ -28,12 +28,19 @@ static dev_proc_close_device(cfax_prn_close);
/* an additional "end of document" signature after the last */
/* "end page" signature */
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs gdev_cfax_std_procs =
- prn_params_procs(gdev_prn_open, gdev_prn_bg_output_page, cfax_prn_close,
- gdev_fax_get_params, gdev_fax_put_params);
+static void
+cfax_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono_bg(dev);
+
+ set_dev_proc(dev, close_device, cfax_prn_close);
+ set_dev_proc(dev, get_params, gdev_fax_get_params);
+ set_dev_proc(dev, put_params, gdev_fax_put_params);
+}
const gx_device_fax gs_cfax_device = {
- FAX_DEVICE_BODY(gx_device_fax, gdev_cfax_std_procs, "cfax", cfax_print_page)
+ FAX_DEVICE_BODY(gx_device_fax, cfax_initialize_device_procs,
+ "cfax", cfax_print_page)
};
/* ---------------- SFF output ----------------- */
diff --git a/devices/gdevchameleon.c b/devices/gdevchameleon.c
index 20abe218..6d7ba87c 100644
--- a/devices/gdevchameleon.c
+++ b/devices/gdevchameleon.c
@@ -59,78 +59,24 @@ struct gx_device_chameleon_s {
};
typedef struct gx_device_chameleon_s gx_device_chameleon;
-static const gx_device_procs chameleon_procs =
-{ gdev_prn_open,
- gx_default_get_initial_matrix,
- NULL, /* sync_output */
- /* Since the print_page doesn't alter the device, this device can print in the background */
- gdev_prn_bg_output_page,
- gdev_prn_close,
- chameleon_rgb_encode_color, /* map_rgb_color */
- chameleon_rgb_decode_color, /* map_color_rgb */
- NULL, /* fill_rectangle */
- NULL, /* tile_rectangle */
- NULL, /* copy_mono */
- NULL, /* copy_color */
- NULL, /* draw_line */
- NULL, /* get_bits */
- chameleon_get_params,
- chameleon_put_params,
- chameleon_rgb_encode_color, /* map_cmyk_color */
- NULL, /* get_xfont_procs */
- NULL, /* get_xfont_device */
- NULL, /* map_rgb_alpha_color */
- gx_page_device_get_page_device, /* get_page_device */
- NULL, /* get_alpha_bits */
- NULL, /* copy_alpha */
- NULL, /* get_band */
- NULL, /* copy_rop */
- NULL, /* fill_path */
- NULL, /* stroke_path */
- NULL, /* fill_mask */
- NULL, /* fill_trapezoid */
- NULL, /* fill_parallelogram */
- NULL, /* fill_triangle */
- NULL, /* draw_thin_line */
- NULL, /* begin_image */
- NULL, /* image_data */
- NULL, /* end_image */
- NULL, /* strip_tile_rectangle */
- NULL, /* strip_copy_rop */
- NULL, /* get_clipping_box */
- NULL, /* begin_typed_image */
- NULL, /* get_bits_rectangle */
- NULL, /* map_color_rgb_alpha */
- NULL, /* create_compositor */
- NULL, /* get_hardware_params */
- NULL, /* text_begin */
- NULL, /* finish_copydevice */
- NULL, /* begin_transparency_group */
- NULL, /* end_transparency_group */
- NULL, /* begin_transparency_mask */
- NULL, /* end_transparency_mask */
- NULL, /* discard_transparency_layer */
- NULL, /* get_color_mapping_procs */
- NULL, /* get_color_comp_index */
- chameleon_rgb_encode_color,/* encode_color */
- chameleon_rgb_decode_color, /* decode_color */
- NULL, /* pattern_manage */
- NULL, /* fill_rectangle_hl_color */
- NULL, /* include_color_space */
- NULL, /* fill_linear_color_scanline */
- NULL, /* fill_linear_color_trapezoid */
- NULL, /* fill_linear_color_triangle */
- NULL, /* update_spot_equivalent_colors */
- NULL, /* ret_devn_params */
- NULL, /* fillpage */
- NULL, /* push_transparency_state */
- NULL, /* pop_transparency_state */
- NULL, /* put_image */
- chameleon_spec_op /* dev_spec_op */
-};
+static void
+chameleon_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, map_rgb_color, chameleon_rgb_encode_color);
+ set_dev_proc(dev, map_color_rgb, chameleon_rgb_decode_color);
+ set_dev_proc(dev, get_params, chameleon_get_params);
+ set_dev_proc(dev, put_params, chameleon_put_params);
+ set_dev_proc(dev, map_cmyk_color, chameleon_rgb_encode_color);
+ set_dev_proc(dev, encode_color, chameleon_rgb_encode_color);
+ set_dev_proc(dev, decode_color, chameleon_rgb_decode_color);
+ set_dev_proc(dev, dev_spec_op, chameleon_spec_op);
+}
const gx_device_chameleon gs_chameleon_device =
-{prn_device_body(gx_device_chameleon, chameleon_procs, "chameleon",
+{prn_device_body(gx_device_chameleon, chameleon_initialize_device_procs,
+ "chameleon",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
diff --git a/devices/gdevcif.c b/devices/gdevcif.c
index 66a44013..40f8a8aa 100644
--- a/devices/gdevcif.c
+++ b/devices/gdevcif.c
@@ -33,8 +33,9 @@
/* The device descriptor */
static dev_proc_print_page(cif_print_page);
+/* The print_page proc is compatible with allowing bg printing */
const gx_device_printer far_data gs_cif_device =
- prn_device(prn_bg_procs, "cif", /* The print_page proc is compatible with allowing bg printing */
+ prn_device(gdev_prn_initialize_device_procs_mono_bg, "cif",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0,0,0,0,
diff --git a/devices/gdevclj.c b/devices/gdevclj.c
index 5edac41e..4d4d9c71 100644
--- a/devices/gdevclj.c
+++ b/devices/gdevclj.c
@@ -515,38 +515,32 @@ xit:
}
/* CLJ device methods */
-#define CLJ_PROCS(get_params, put_params)\
- gdev_prn_open, /* open_device */\
- clj_get_initial_matrix, /* get_initial matrix */\
- NULL, /* sync_output */\
-/* Since the print_page doesn't alter the device, this device can print in the background */\
- gdev_prn_bg_output_page, /* output_page */\
- gdev_prn_close, /* close_device */\
- gdev_pcl_3bit_map_rgb_color, /* map_rgb_color */\
- gdev_pcl_3bit_map_color_rgb, /* map_color_rgb */\
- NULL, /* fill_rectangle */\
- NULL, /* tile_rectangle */\
- NULL, /* copy_mono */\
- NULL, /* copy_color */\
- NULL, /* obsolete draw_line */\
- NULL, /* get_bits */\
- get_params, /* get_params */\
- put_params, /* put_params */\
- NULL, /* map_cmyk_color */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- gx_page_device_get_page_device /* get_page_device */
-
-static gx_device_procs cljet5_procs = {
- CLJ_PROCS(clj_get_params, clj_put_params)
-};
+static void
+clj_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, get_initial_matrix, clj_get_initial_matrix);
+ set_dev_proc(dev, map_rgb_color, gdev_pcl_3bit_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gdev_pcl_3bit_map_color_rgb);
+ set_dev_proc(dev, encode_color, gdev_pcl_3bit_map_rgb_color);
+ set_dev_proc(dev, decode_color, gdev_pcl_3bit_map_color_rgb);
+}
+
+static void
+cljet5_initialize_device_procs(gx_device *dev)
+{
+ clj_initialize_device_procs(dev);
+
+ set_dev_proc(dev, get_params, clj_get_params);
+ set_dev_proc(dev, put_params, clj_put_params);
+}
/* CLJ device structure */
-#define CLJ_DEVICE_BODY(procs, dname, rotated)\
+#define CLJ_DEVICE_BODY(init, dname, rotated)\
prn_device_body(\
gx_device_clj,\
- procs, /* procedures */\
+ init, /* initialize */\
dname, /* device name */\
110, /* width - will be overridden subsequently */\
85, /* height - will be overridden subsequently */\
@@ -562,7 +556,7 @@ static gx_device_procs cljet5_procs = {
rotated /* rotated - may be overridden subsequently */
gx_device_clj gs_cljet5_device = {
- CLJ_DEVICE_BODY(cljet5_procs, "cljet5", 0 /*false*/)
+ CLJ_DEVICE_BODY(cljet5_initialize_device_procs, "cljet5", 0 /*false*/)
};
/* ---------------- Driver with page rotation ---------------- */
@@ -677,11 +671,16 @@ clj_pr_put_params(
}
/* CLJ device methods -- se above for CLJ_PROCS */
-static gx_device_procs cljet5pr_procs = {
- CLJ_PROCS(clj_pr_get_params, clj_pr_put_params)
-};
+static void
+cljet5pr_initialize_device_procs(gx_device *dev)
+{
+ clj_initialize_device_procs(dev);
+
+ set_dev_proc(dev, get_params, clj_pr_get_params);
+ set_dev_proc(dev, put_params, clj_pr_put_params);
+}
/* CLJ device structure -- see above for CLJ_DEVICE_BODY */
gx_device_clj gs_cljet5pr_device = {
- CLJ_DEVICE_BODY(cljet5pr_procs, "cljet5pr", 1 /*true*/)
+ CLJ_DEVICE_BODY(cljet5pr_initialize_device_procs, "cljet5pr", 1 /*true*/)
};
diff --git a/devices/gdevcljc.c b/devices/gdevcljc.c
index bf8a4b82..5ef8c8b8 100644
--- a/devices/gdevcljc.c
+++ b/devices/gdevcljc.c
@@ -82,16 +82,17 @@ out:
return code;
}
-/* CLJ device methods */
/* Since the print_page doesn't alter the device, this device can print in the background */
-static gx_device_procs cljc_procs =
-prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb);
+static void
+cljet5c_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_rgb_bg(dev);
+}
/* the CLJ device */
const gx_device_printer gs_cljet5c_device =
{
- prn_device_body(gx_device_printer, cljc_procs, "cljet5c",
+ prn_device_body(gx_device_printer, cljet5c_initialize_device_procs, "cljet5c",
85, 110, X_DPI, Y_DPI,
0.167, 0.167,
0.167, 0.167,
diff --git a/devices/gdevcmykog.c b/devices/gdevcmykog.c
index dcd1a4a4..513a56f5 100644
--- a/devices/gdevcmykog.c
+++ b/devices/gdevcmykog.c
@@ -522,7 +522,7 @@ cmykog_process(void *arg_, gx_device *dev_, gx_device *bdev, const gs_int_rect *
my_rect.p.y = 0;
my_rect.q.x = w;
my_rect.q.y = h;
- code = dev_proc(bdev, get_bits_rectangle)(bdev, &my_rect, &buffer->params, NULL);
+ code = dev_proc(bdev, get_bits_rectangle)(bdev, &my_rect, &buffer->params);
if (code < 0)
return code;
@@ -718,73 +718,21 @@ prn_done:
/* Finally, the device definition itself */
-#define device_procs(get_color_mapping_procs)\
-{ cmykog_open, /* open device */\
- gx_default_get_initial_matrix, /* initialize matrix */\
- NULL, /* sync_output */\
- gdev_prn_bg_output_page, /* output_page */\
- cmykog_close, /* close */\
- NULL, /* map_rgb_color - not used */\
- NULL, /* map_color_rgb - not used */\
- NULL, /* fill_rectangle */\
- NULL, /* tile_rectangle */\
- NULL, /* copy_mono */\
- NULL, /* copy_color */\
- NULL, /* draw_line */\
- NULL, /* get_bits */\
- gx_devn_prn_get_params, /* get_params */\
- cmykog_put_params, /* put_params */\
- NULL, /* map_cmyk_color - not used */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- gx_page_device_get_page_device, /* get_page_device */\
- NULL, /* get_alpha_bits */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- NULL, /* fill_path */\
- NULL, /* stroke_path */\
- NULL, /* fill_mask */\
- NULL, /* fill_trapezoid */\
- NULL, /* fill_parallelogram */\
- NULL, /* fill_triangle */\
- NULL, /* draw_thin_line */\
- NULL, /* begin_image */\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL, /* strip_copy_rop */\
- NULL, /* get_clipping_box */\
- NULL, /* begin_typed_image */\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- NULL, /* create_compositor */\
- NULL, /* get_hardware_params */\
- NULL, /* text_begin */\
- NULL, /* finish_copydevice */\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL, /* discard_transparency_layer */\
- gx_devn_prn_get_color_mapping_procs,/* get_color_mapping_procs */\
- cmykog_get_color_comp_index, /* get_color_comp_index */\
- gx_devn_prn_encode_color, /* encode_color */\
- gx_devn_prn_decode_color, /* decode_color */\
- NULL, /* pattern_manage */\
- NULL, /* fill_rectangle_hl_color */\
- NULL, /* include_color_space */\
- NULL, /* fill_linear_color_scanline */\
- NULL, /* fill_linear_color_trapezoid */\
- NULL, /* fill_linear_color_triangle */\
- NULL, /* update_spot_equivalent_colors */\
- gx_devn_prn_ret_devn_params, /* ret_devn_params */\
- NULL, /* fillpage */\
- NULL, /* push_transparency_state */\
- NULL, /* pop_transparency_state */\
- NULL, /* put_image */\
- cmykog_dev_spec_op /* dev_spec_op */\
+static void
+psdcmykog_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, open_device, cmykog_open);
+ set_dev_proc(dev, close_device, cmykog_close);
+ set_dev_proc(dev, get_params, gx_devn_prn_get_params);
+ set_dev_proc(dev, put_params, cmykog_put_params);
+ set_dev_proc(dev, get_color_mapping_procs, gx_devn_prn_get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, cmykog_get_color_comp_index);
+ set_dev_proc(dev, encode_color, gx_devn_prn_encode_color);
+ set_dev_proc(dev, decode_color, gx_devn_prn_decode_color);
+ set_dev_proc(dev, ret_devn_params, gx_devn_prn_ret_devn_params);
+ set_dev_proc(dev, dev_spec_op, cmykog_dev_spec_op);
}
fixed_colorant_name DevCMYKOGComponents[] = {
@@ -819,11 +767,9 @@ fixed_colorant_name DevCMYKOGComponents[] = {
/*
* PSDCMYKOG 8bits
*/
-static const gx_device_procs cmykog_procs = device_procs(get_cmykog_spot_color_mapping_procs);
-
const gx_device_cmykog gs_psdcmykog_device =
{
- CMYKOG_DEVICE(cmykog_procs, "psdcmykog", 6, GX_CINFO_POLARITY_SUBTRACTIVE, 48, 255, 255, "DeviceCMYK", 600, 600),
+ CMYKOG_DEVICE(psdcmykog_initialize_device_procs, "psdcmykog", 6, GX_CINFO_POLARITY_SUBTRACTIVE, 48, 255, 255, "DeviceCMYK", 600, 600),
/* device specific parameters */
{ 8, /* Bits per color - must match ncomp, depth, etc. above */
DevCMYKOGComponents, /* Names of color model colorants */
diff --git a/devices/gdevcslw.c b/devices/gdevcslw.c
index 8744f668..0e178e28 100644
--- a/devices/gdevcslw.c
+++ b/devices/gdevcslw.c
@@ -29,15 +29,17 @@ typedef ulong word;
static dev_proc_print_page(coslw_print_page);
+/* The print_page proc is compatible with allowing bg printing */
const gx_device_printer gs_coslw2p_device =
-prn_device(prn_bg_procs, "coslw2p", /* The print_page proc is compatible with allowing bg printing */
+prn_device(gdev_prn_initialize_device_procs_mono_bg, "coslw2p",
200, 400, /* 2 inches wide */
128, 128, /* 5 dots per mm */
0, 0, 0, 0,
1, coslw_print_page);
+/* The print_page proc is compatible with allowing bg printing */
const gx_device_printer gs_coslwxl_device =
-prn_device(prn_bg_procs, "coslwxl", /* The print_page proc is compatible with allowing bg printing */
+prn_device(gdev_prn_initialize_device_procs_mono_bg, "coslwxl",
200, 400, /* 2 inches wide */
204, 204, /* 8 dots per mm */
0, 0, 0, 0,
diff --git a/devices/gdevdfax.c b/devices/gdevdfax.c
index d113fd07..99e6af35 100644
--- a/devices/gdevdfax.c
+++ b/devices/gdevdfax.c
@@ -42,11 +42,17 @@ struct gx_device_dfax_s {
typedef struct gx_device_dfax_s gx_device_dfax;
/* Since the print_page doesn't alter the device, this device can print in the background */
-static gx_device_procs dfax_procs =
- prn_procs(dfax_prn_open, gdev_prn_bg_output_page_seekable, gdev_prn_close);
+static void
+dfax_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono_bg(dev);
+
+ set_dev_proc(dev, open_device, dfax_prn_open);
+ set_dev_proc(dev, output_page, gdev_prn_bg_output_page_seekable);
+}
gx_device_dfax far_data gs_dfaxlow_device =
-{ prn_device_std_body(gx_device_dfax, dfax_procs, "dfaxlow",
+{ prn_device_std_body(gx_device_dfax, dfax_initialize_device_procs, "dfaxlow",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI/2,
0,0,0,0, /* margins */
@@ -54,7 +60,7 @@ gx_device_dfax far_data gs_dfaxlow_device =
};
gx_device_dfax far_data gs_dfaxhigh_device =
-{ prn_device_std_body(gx_device_dfax, dfax_procs, "dfaxhigh",
+{ prn_device_std_body(gx_device_dfax, dfax_initialize_device_procs, "dfaxhigh",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0,0,0,0, /* margins */
diff --git a/devices/gdevdjet.c b/devices/gdevdjet.c
index 402e8aaa..1ded0813 100644
--- a/devices/gdevdjet.c
+++ b/devices/gdevdjet.c
@@ -115,14 +115,26 @@ static dev_proc_get_params(hpjet_get_params);
static dev_proc_put_params(hpjet_put_params);
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs prn_hp_procs =
-prn_params_procs(hpjet_open, gdev_prn_bg_output_page, hpjet_close,
- hpjet_get_params, hpjet_put_params);
+static void
+hpjet_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono_bg(dev);
+
+ set_dev_proc(dev, open_device, hpjet_open);
+ set_dev_proc(dev, close_device, hpjet_close);
+ set_dev_proc(dev, get_params, hpjet_get_params);
+ set_dev_proc(dev, put_params, hpjet_put_params);
+}
/* Since the print_page doesn't alter the device, this device can print in the background */
-static gx_device_procs prn_ljet4pjl_procs =
-prn_params_procs(hpjet_open, gdev_prn_bg_output_page, ljet4pjl_close,
- gdev_prn_get_params, gdev_prn_put_params);
+static void
+ljet4pjl_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono_bg(dev);
+
+ set_dev_proc(dev, open_device, hpjet_open);
+ set_dev_proc(dev, close_device, ljet4pjl_close);
+}
typedef struct gx_device_hpjet_s gx_device_hpjet;
@@ -136,98 +148,98 @@ struct gx_device_hpjet_s {
bool Tumble;
};
-#define HPJET_DEVICE(procs, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, color_bits, print_page_copies)\
- { prn_device_std_margins_body_copies(gx_device_hpjet, procs, dname, \
+#define HPJET_DEVICE(init, dname, w10, h10, xdpi, ydpi, lm, bm, rm, tm, color_bits, print_page_copies)\
+ { prn_device_std_margins_body_copies(gx_device_hpjet, init, dname, \
w10, h10, xdpi, ydpi, lm, tm, lm, bm, rm, tm, color_bits, \
print_page_copies), \
0, false, false, false, false }
const gx_device_hpjet gs_deskjet_device =
-HPJET_DEVICE(prn_hp_procs, "deskjet",
+HPJET_DEVICE(hpjet_initialize_device_procs, "deskjet",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins filled in by hpjet_open */
1, djet_print_page_copies);
const gx_device_hpjet gs_djet500_device =
-HPJET_DEVICE(prn_hp_procs, "djet500",
+HPJET_DEVICE(hpjet_initialize_device_procs, "djet500",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins filled in by hpjet_open */
1, djet500_print_page_copies);
const gx_device_hpjet gs_fs600_device =
-HPJET_DEVICE(prn_hp_procs, "fs600",
+HPJET_DEVICE(hpjet_initialize_device_procs, "fs600",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI2, Y_DPI2,
0.23, 0.0, 0.23, 0.04, /* margins */
1, fs600_print_page_copies);
const gx_device_hpjet gs_laserjet_device =
-HPJET_DEVICE(prn_hp_procs, "laserjet",
+HPJET_DEVICE(hpjet_initialize_device_procs, "laserjet",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0.05, 0.25, 0.55, 0.25, /* margins */
1, ljet_print_page_copies);
const gx_device_hpjet gs_ljetplus_device =
-HPJET_DEVICE(prn_hp_procs, "ljetplus",
+HPJET_DEVICE(hpjet_initialize_device_procs, "ljetplus",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0.05, 0.25, 0.55, 0.25, /* margins */
1, ljetplus_print_page_copies);
const gx_device_hpjet gs_ljet2p_device =
-HPJET_DEVICE(prn_hp_procs, "ljet2p",
+HPJET_DEVICE(hpjet_initialize_device_procs, "ljet2p",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0.25, 0.25, 0.25, 0.0, /* margins */
1, ljet2p_print_page_copies);
const gx_device_hpjet gs_ljet3_device =
-HPJET_DEVICE(prn_hp_procs, "ljet3",
+HPJET_DEVICE(hpjet_initialize_device_procs, "ljet3",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0.20, 0.25, 0.25, 0.25, /* margins */
1, ljet3_print_page_copies);
const gx_device_hpjet gs_ljet3d_device =
-HPJET_DEVICE(prn_hp_procs, "ljet3d",
+HPJET_DEVICE(hpjet_initialize_device_procs, "ljet3d",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0.20, 0.25, 0.25, 0.25, /* margins */
1, ljet3d_print_page_copies);
const gx_device_hpjet gs_ljet4_device =
-HPJET_DEVICE(prn_hp_procs, "ljet4",
+HPJET_DEVICE(hpjet_initialize_device_procs, "ljet4",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI2, Y_DPI2,
0, 0, 0, 0, /* margins */
1, ljet4_print_page_copies);
const gx_device_hpjet gs_ljet4d_device =
-HPJET_DEVICE(prn_hp_procs, "ljet4d",
+HPJET_DEVICE(hpjet_initialize_device_procs, "ljet4d",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI2, Y_DPI2,
0, 0, 0, 0, /* margins */
1, ljet4d_print_page_copies);
const gx_device_hpjet gs_lp2563_device =
-HPJET_DEVICE(prn_hp_procs, "lp2563",
+HPJET_DEVICE(hpjet_initialize_device_procs, "lp2563",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
1, lp2563_print_page_copies);
const gx_device_hpjet gs_oce9050_device =
-HPJET_DEVICE(prn_hp_procs, "oce9050",
+HPJET_DEVICE(hpjet_initialize_device_procs, "oce9050",
24 * 10, 24 * 10, /* 24 inch roll (can print 32" also) */
400, 400, /* 400 dpi */
0, 0, 0, 0, /* margins */
1, oce9050_print_page_copies);
const gx_device_printer gs_ljet4pjl_device =
-prn_device_copies(prn_ljet4pjl_procs, "ljet4pjl",
+prn_device_copies(ljet4pjl_initialize_device_procs, "ljet4pjl",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI2, Y_DPI2,
0, 0, 0, 0, /* margins */
diff --git a/devices/gdevdjtc.c b/devices/gdevdjtc.c
index 34bb030d..c9603af5 100644
--- a/devices/gdevdjtc.c
+++ b/devices/gdevdjtc.c
@@ -40,12 +40,19 @@
static dev_proc_print_page(djet500c_print_page);
/* Since the print_page doesn't alter the device, this device can print in the background */
-static gx_device_procs djet500c_procs =
- prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- gdev_pcl_3bit_map_rgb_color, gdev_pcl_3bit_map_color_rgb);
+static void
+djet500c_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, map_rgb_color, gdev_pcl_3bit_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gdev_pcl_3bit_map_color_rgb);
+ set_dev_proc(dev, encode_color, gdev_pcl_3bit_map_rgb_color);
+ set_dev_proc(dev, decode_color, gdev_pcl_3bit_map_color_rgb);
+}
const gx_device_printer far_data gs_djet500c_device =
- prn_device(djet500c_procs, "djet500c",
+ prn_device(djet500c_initialize_device_procs, "djet500c",
85, /* width_10ths, 8.5" */
120, /* height_10ths, 12" */
X_DPI, Y_DPI,
diff --git a/devices/gdevdm24.c b/devices/gdevdm24.c
index 08cad67f..e476514a 100644
--- a/devices/gdevdm24.c
+++ b/devices/gdevdm24.c
@@ -25,7 +25,8 @@
/* Driver for NEC P6 */
static dev_proc_print_page (necp6_print_page);
const gx_device_printer far_data gs_necp6_device =
- prn_device (prn_bg_procs, "necp6", /* The print_page proc is compatible with allowing bg printing */
+ /* The print_page proc is compatible with allowing bg printing */
+ prn_device (gdev_prn_initialize_device_procs_mono_bg, "necp6",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
360, 360,
0, 0, 0.5, 0, /* margins */
@@ -35,7 +36,8 @@ const gx_device_printer far_data gs_necp6_device =
/* I've tested this driver on a BJ300 with LQ850 emulation and there it produce correct 360x360dpi output. */
static dev_proc_print_page (lq850_print_page);
const gx_device_printer gs_lq850_device =
- prn_device (prn_bg_procs, "lq850", /* The print_page proc is compatible with allowing bg printing */
+ /* The print_page proc is compatible with allowing bg printing */
+ prn_device (gdev_prn_initialize_device_procs_mono_bg, "lq850",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
360, 360,
0, 0, 0.5, 0, /* margins */
diff --git a/devices/gdevdsp.c b/devices/gdevdsp.c
index 10cfd85e..d772ccfd 100644
--- a/devices/gdevdsp.c
+++ b/devices/gdevdsp.c
@@ -91,10 +91,10 @@ static dev_proc_map_color_rgb(display_map_color_rgb_bgr24);
static dev_proc_fill_rectangle(display_fill_rectangle);
static dev_proc_copy_mono(display_copy_mono);
static dev_proc_copy_color(display_copy_color);
-static dev_proc_get_bits(display_get_bits);
+static dev_proc_get_bits_rectangle(display_get_bits_rectangle);
static dev_proc_get_params(display_get_params);
static dev_proc_put_params(display_put_params);
-static dev_proc_finish_copydevice(display_finish_copydevice);
+static dev_proc_initialize_device_procs(display_initialize_device_procs);
static dev_proc_get_color_mapping_procs(display_separation_get_color_mapping_procs);
static dev_proc_get_color_comp_index(display_separation_get_color_comp_index);
@@ -105,76 +105,8 @@ static dev_proc_ret_devn_params(display_ret_devn_params);
static dev_proc_dev_spec_op(display_spec_op);
static dev_proc_fill_rectangle_hl_color(display_fill_rectangle_hl_color);
-static const gx_device_procs display_procs =
-{
- display_open,
- display_get_initial_matrix,
- display_sync_output,
- display_output_page,
- display_close,
- gx_default_w_b_map_rgb_color,
- gx_default_w_b_map_color_rgb,
- NULL, /* display_fill_rectangle - will be inserted later */
- NULL, /* tile rectangle */
- NULL, /* display_copy_mono - will be inserted later */
- NULL, /* display_copy_color - will be inserted later */
- NULL, /* draw line */
- NULL, /* display_get_bits - will be inserted later */
- display_get_params,
- display_put_params,
- gx_default_cmyk_map_cmyk_color, /* map_cmyk_color */
- gx_default_get_xfont_procs,
- NULL, /* get_xfont_device */
- NULL, /* map_rgb_alpha_color */
- gx_page_device_get_page_device,
- /* extra entries */
- NULL, /* get_alpha_bits */
- NULL, /* copy_alpha */
- NULL, /* get_band */
- NULL, /* copy_rop */
- NULL, /* fill_path */
- NULL, /* stroke_path */
- NULL, /* fill_mask */
- NULL, /* fill_trapezoid */
- NULL, /* fill_parallelogram */
- NULL, /* fill_triangle */
- NULL, /* draw_thin_line */
- NULL, /* begin_image */
- NULL, /* image_data */
- NULL, /* end_image */
- NULL, /* strip_tile_rectangle */
- NULL, /* strip_copy_rop */
- NULL, /* get_clipping_box */
- NULL, /* begin_typed_image */
- NULL, /* get_bits_rectangle */
- NULL, /* map_color_rgb_alpha */
- NULL, /* create_compositor */
- NULL, /* get_hardware_params */
- NULL, /* text_begin */
- display_finish_copydevice, /* finish_copydevice */
- NULL, /* begin_transparency_group */
- NULL, /* end_transparency_group */
- NULL, /* begin_transparency_mask */
- NULL, /* end_transparency_mask */
- NULL, /* discard_transparency_layer */
- NULL, /* get_color_mapping_procs */
- NULL, /* get_color_comp_index */
- NULL, /* encode_color */
- NULL, /* decode_color */
- NULL, /* pattern_manage */
- display_fill_rectangle_hl_color, /* fill_rectangle_hl_color */\
- NULL, /* include_color_space */\
- NULL, /* fill_linear_color_scanline */\
- NULL, /* fill_linear_color_trapezoid */\
- NULL, /* fill_linear_color_triangle */\
- display_update_spot_equivalent_colors, /* update_spot_equivalent_colors */
- display_ret_devn_params, /* ret_devn_params */\
- NULL, /* fillpage */\
- NULL, /* push_transparency_state */\
- NULL, /* pop_transparency_state */\
- NULL, /* put_image */\
- display_spec_op /* dev_spec_op */\
-};
+extern dev_proc_open_device(clist_open);
+extern dev_proc_close_device(clist_close);
/* GC descriptor */
public_st_device_display();
@@ -200,10 +132,12 @@ RELOC_PTRS_END
const gx_device_display gs_display_device =
{
- std_device_std_body_type(gx_device_display, &display_procs, "display",
- &st_device_display,
- INITIAL_WIDTH, INITIAL_HEIGHT,
- INITIAL_RESOLUTION, INITIAL_RESOLUTION),
+ std_device_std_body_type(gx_device_display,
+ display_initialize_device_procs,
+ "display",
+ &st_device_display,
+ INITIAL_WIDTH, INITIAL_HEIGHT,
+ INITIAL_RESOLUTION, INITIAL_RESOLUTION),
{0}, /* std_procs */
GX_CLIST_MUTATABLE_DEVICE_DEFAULTS,
NULL, /* callback */
@@ -427,7 +361,7 @@ display_output_page(gx_device * dev, int copies, int flush)
params.original_y = oy;
params.raster = raster;
code = dev_proc(ddev, get_bits_rectangle)((gx_device *)ddev,
- &rect, &params, NULL);
+ &rect, &params);
if (code < 0)
break;
}
@@ -879,12 +813,13 @@ display_copy_color(gx_device * dev,
}
static int
-display_get_bits(gx_device * dev, int y, byte * str, byte ** actual_data)
+display_get_bits_rectangle(gx_device * dev, const gs_int_rect *rect,
+ gs_get_bits_params_t *params)
{
gx_device_display *ddev = (gx_device_display *) dev;
if (ddev->callback == NULL)
return gs_error_Fatal;
- return ddev->mutated_procs.get_bits(dev, y, str, actual_data);
+ return ddev->mutated_procs.get_bits_rectangle(dev, rect, params);
}
static int
@@ -1211,9 +1146,7 @@ display_put_params(gx_device * dev, gs_param_list * plist)
return 0;
}
-/* Clean up the instance after making a copy. */
-int
-display_finish_copydevice(gx_device *dev, const gx_device *from_dev)
+static int display_initialize_device(gx_device *dev)
{
gx_device_display *ddev = (gx_device_display *) dev;
@@ -1227,12 +1160,33 @@ display_finish_copydevice(gx_device *dev, const gx_device *from_dev)
return 0;
}
+static void
+display_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, initialize_device, display_initialize_device);
+ set_dev_proc(dev, open_device, display_open);
+ set_dev_proc(dev, get_initial_matrix, display_get_initial_matrix);
+ set_dev_proc(dev, sync_output, display_sync_output);
+ set_dev_proc(dev, output_page, display_output_page);
+ set_dev_proc(dev, close_device, display_close);
+ set_dev_proc(dev, map_rgb_color, gx_default_w_b_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_default_w_b_map_color_rgb);
+ set_dev_proc(dev, get_params, display_get_params);
+ set_dev_proc(dev, put_params, display_put_params);
+ set_dev_proc(dev, map_cmyk_color, gx_default_cmyk_map_cmyk_color);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
+ set_dev_proc(dev, fill_rectangle_hl_color, display_fill_rectangle_hl_color);
+ set_dev_proc(dev, update_spot_equivalent_colors, display_update_spot_equivalent_colors);
+ set_dev_proc(dev, ret_devn_params, display_ret_devn_params);
+ set_dev_proc(dev, dev_spec_op, display_spec_op);
+}
+
/*
* The following procedures are used to map the standard color spaces into
* the separation color components for the display device.
*/
static void
-display_separation_gray_cs_to_cmyk_cm(gx_device * dev, frac gray, frac out[])
+display_separation_gray_cs_to_cmyk_cm(const gx_device * dev, frac gray, frac out[])
{
int * map =
(int *)(&((gx_device_display *) dev)->devn_params.separation_order_map);
@@ -1241,7 +1195,7 @@ display_separation_gray_cs_to_cmyk_cm(gx_device * dev, frac gray, frac out[])
}
static void
-display_separation_rgb_cs_to_cmyk_cm(gx_device * dev,
+display_separation_rgb_cs_to_cmyk_cm(const gx_device * dev,
const gs_gstate *pgs, frac r, frac g, frac b, frac out[])
{
int * map =
@@ -1251,7 +1205,7 @@ display_separation_rgb_cs_to_cmyk_cm(gx_device * dev,
}
static void
-display_separation_cmyk_cs_to_cmyk_cm(gx_device * dev,
+display_separation_cmyk_cs_to_cmyk_cm(const gx_device * dev,
frac c, frac m, frac y, frac k, frac out[])
{
const int * map =
@@ -1267,8 +1221,9 @@ static const gx_cm_color_map_procs display_separation_cm_procs = {
};
static const gx_cm_color_map_procs *
-display_separation_get_color_mapping_procs(const gx_device * dev)
+display_separation_get_color_mapping_procs(const gx_device * dev, const gx_device **map_dev)
{
+ *map_dev = dev;
return &display_separation_cm_procs;
}
@@ -1493,7 +1448,7 @@ display_free_bitmap(gx_device_display * ddev)
gx_device_clist_common * const pcldev = &pclist_dev->common;
gx_device_clist_reader * const pcrdev = &pclist_dev->reader;
/* Close cmd list device & point to the storage */
- (*gs_clist_device_procs.close_device)( (gx_device *)pcldev );
+ clist_close( (gx_device *)pcldev );
ddev->buf = NULL;
ddev->buffer_space = 0;
@@ -1603,6 +1558,9 @@ display_create_buf_device(gx_device **pbdev, gx_device *target, int y,
dev_t_proc_dev_spec_op((*orig_dso), gx_device) = dev_proc(mdev, dev_spec_op);
/* The following is a special hack for setting up printer devices. */
assign_dev_procs(mdev, mdproto);
+ mdev->initialize_device_procs = mdproto->initialize_device_procs;
+ mdev->initialize_device_procs((gx_device *)mdev);
+ /* We know mdev->procs.initialize_device is NULL. */
/* Do not override the dev_spec_op! */
dev_proc(mdev, dev_spec_op) = orig_dso;
check_device_separable((gx_device *)mdev);
@@ -1750,8 +1708,13 @@ display_alloc_bitmap(gx_device_display * ddev, gx_device * param_dev)
&display_buf_procs,
ddev->orig_procs.dev_spec_op,
MIN_BUFFER_SPACE);
- if (ccode >= 0)
- ddev->procs = gs_clist_device_procs;
+ if (ccode >= 0) {
+ ddev->initialize_device_procs = clist_initialize_device_procs;
+ ddev->initialize_device_procs((gx_device *)ddev);
+ /* ddev->initialize() has already been done, and does not
+ * need to redone for the clist. */
+ gx_device_fill_in_procs((gx_device *)ddev);
+ }
} else {
/* Set up as PageMode. */
gx_device *bdev = (gx_device *)ddev;
@@ -1781,12 +1744,8 @@ display_alloc_bitmap(gx_device_display * ddev, gx_device * param_dev)
COPY_PROC(get_params);
COPY_PROC(put_params);
COPY_PROC(map_cmyk_color);
- COPY_PROC(get_xfont_procs);
- COPY_PROC(get_xfont_device);
- COPY_PROC(map_rgb_alpha_color);
set_dev_proc(ddev, get_page_device, gx_page_device_get_page_device);
COPY_PROC(get_clipping_box);
- COPY_PROC(map_color_rgb_alpha);
COPY_PROC(get_hardware_params);
COPY_PROC(get_color_mapping_procs);
COPY_PROC(get_color_comp_index);
@@ -1806,7 +1765,7 @@ display_alloc_bitmap(gx_device_display * ddev, gx_device * param_dev)
ddev->procs.fill_rectangle = display_fill_rectangle;
ddev->procs.copy_mono = display_copy_mono;
ddev->procs.copy_color = display_copy_color;
- ddev->procs.get_bits = display_get_bits;
+ ddev->procs.get_bits_rectangle = display_get_bits_rectangle;
}
/* In command list mode, we've already opened the device. */
@@ -1972,11 +1931,11 @@ set_color_info(gx_device_color_info * pdci, DISPLAY_MODEL model,
*/
static void
set_color_procs(gx_device * pdev,
- dev_t_proc_encode_color((*encode_color), gx_device),
- dev_t_proc_decode_color((*decode_color), gx_device),
- dev_t_proc_get_color_mapping_procs((*get_color_mapping_procs), gx_device),
- dev_t_proc_get_color_comp_index((*get_color_comp_index), gx_device),
- dev_t_proc_fill_rectangle_hl_color((*fill_hl_color), gx_device))
+ dev_proc_encode_color((*encode_color)),
+ dev_proc_decode_color((*decode_color)),
+ dev_proc_get_color_mapping_procs((*get_color_mapping_procs)),
+ dev_proc_get_color_comp_index((*get_color_comp_index)),
+ dev_proc_fill_rectangle_hl_color((*fill_hl_color)))
{
pdev->procs.get_color_mapping_procs = get_color_mapping_procs;
pdev->procs.get_color_comp_index = get_color_comp_index;
diff --git a/devices/gdevepsc.c b/devices/gdevepsc.c
index 5818eac8..21519141 100644
--- a/devices/gdevepsc.c
+++ b/devices/gdevepsc.c
@@ -143,12 +143,20 @@ epson_map_color_rgb(gx_device * dev, gx_color_index color,
static dev_proc_print_page(epsc_print_page);
/* Since the print_page doesn't alter the device, this device can print in the background */
-static gx_device_procs epson_procs =
-prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- epson_map_rgb_color, epson_map_color_rgb);
+static void
+epson_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, map_rgb_color, epson_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, epson_map_color_rgb);
+ set_dev_proc(dev, encode_color, epson_map_rgb_color);
+ set_dev_proc(dev, decode_color, epson_map_color_rgb);
+}
const gx_device_printer far_data gs_epsonc_device =
-prn_device(epson_procs, "epsonc",
+prn_device(epson_initialize_device_procs,
+ "epsonc",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0.25, 0, /* margins */
diff --git a/devices/gdevepsn.c b/devices/gdevepsn.c
index bea4b2c0..0c204d5e 100644
--- a/devices/gdevepsn.c
+++ b/devices/gdevepsn.c
@@ -101,35 +101,43 @@ static dev_proc_print_page(ibmpro_print_page);
/* Standard Epson device */
const gx_device_printer far_data gs_epson_device =
- prn_device(prn_bg_procs, "epson", /* The print_page proc is compatible with allowing bg printing */
- DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
- X_DPI, Y_DPI,
- 0.25, 0.02, 0.25, 0.4, /* margins */
- 1, epson_print_page);
+ /* The print_page proc is compatible with allowing bg printing */
+ prn_device(gdev_prn_initialize_device_procs_mono_bg,
+ "epson",
+ DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
+ X_DPI, Y_DPI,
+ 0.25, 0.02, 0.25, 0.4, /* margins */
+ 1, epson_print_page);
/* Mid-res (interleaved, 1 pass per line) 9-pin device */
const gx_device_printer far_data gs_eps9mid_device =
- prn_device(prn_bg_procs, "eps9mid", /* The print_page proc is compatible with allowing bg printing */
- DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
- X_DPI, 3*Y_BASERES,
- 0.2, 0.0, 0, 0.0, /* margins */
- 1, eps9mid_print_page);
+ /* The print_page proc is compatible with allowing bg printing */
+ prn_device(gdev_prn_initialize_device_procs_mono_bg,
+ "eps9mid",
+ DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
+ X_DPI, 3*Y_BASERES,
+ 0.2, 0.0, 0, 0.0, /* margins */
+ 1, eps9mid_print_page);
/* High-res (interleaved) 9-pin device */
const gx_device_printer far_data gs_eps9high_device =
- prn_device(prn_bg_procs, "eps9high", /* The print_page proc is compatible with allowing bg printing */
- DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
- X_DPI, 3*Y_BASERES,
- 0.2, 0.0, 0.0, 0.0, /* margins */
- 1, eps9high_print_page);
+ /* The print_page proc is compatible with allowing bg printing */
+ prn_device(gdev_prn_initialize_device_procs_mono_bg,
+ "eps9high",
+ DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
+ X_DPI, 3*Y_BASERES,
+ 0.2, 0.0, 0.0, 0.0, /* margins */
+ 1, eps9high_print_page);
/* IBM ProPrinter device */
const gx_device_printer far_data gs_ibmpro_device =
- prn_device(prn_bg_procs, "ibmpro", /* The print_page proc is compatible with allowing bg printing */
- DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
- X_DPI, Y_DPI,
- 0.2, 0.0, 0.0, 0.0, /* margins */
- 1, ibmpro_print_page);
+ /* The print_page proc is compatible with allowing bg printing */
+ prn_device(gdev_prn_initialize_device_procs_mono_bg,
+ "ibmpro",
+ DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
+ X_DPI, Y_DPI,
+ 0.2, 0.0, 0.0, 0.0, /* margins */
+ 1, ibmpro_print_page);
/* ------ Driver procedures ------ */
diff --git a/devices/gdevescp.c b/devices/gdevescp.c
index f111785a..6c525087 100644
--- a/devices/gdevescp.c
+++ b/devices/gdevescp.c
@@ -87,7 +87,8 @@ static dev_proc_print_page(escp2_print_page);
/* Stylus 800 device */
const gx_device_printer far_data gs_st800_device =
- prn_device(prn_bg_procs, "st800", /* The print_page proc is compatible with allowing bg printing */
+ /* The print_page proc is compatible with allowing bg printing */
+ prn_device(gdev_prn_initialize_device_procs_mono_bg, "st800",
DEFAULT_WIDTH_10THS,
DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
@@ -96,7 +97,8 @@ const gx_device_printer far_data gs_st800_device =
/* AP3250 device */
const gx_device_printer far_data gs_ap3250_device =
- prn_device(prn_bg_procs, "ap3250", /* The print_page proc is compatible with allowing bg printing */
+ /* The print_page proc is compatible with allowing bg printing */
+ prn_device(gdev_prn_initialize_device_procs_mono_bg, "ap3250",
DEFAULT_WIDTH_10THS,
DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
diff --git a/devices/gdevfax.c b/devices/gdevfax.c
index f85d8392..0356dbba 100644
--- a/devices/gdevfax.c
+++ b/devices/gdevfax.c
@@ -27,13 +27,19 @@ static dev_proc_print_page(faxg4_print_page);
/* Define procedures that adjust the paper size. */
/* Since the print_page doesn't alter the device, this device can print in the background */
-const gx_device_procs gdev_fax_std_procs =
- prn_params_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- gdev_fax_get_params, gdev_fax_put_params);
+static void
+fax_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono_bg(dev);
+
+ set_dev_proc(dev, open_device, gdev_prn_open);
+ set_dev_proc(dev, get_params, gdev_fax_get_params);
+ set_dev_proc(dev, put_params, gdev_fax_put_params);
+}
#define FAX_DEVICE(dname, print_page)\
{\
- FAX_DEVICE_BODY(gx_device_fax, gdev_fax_std_procs, dname, print_page)\
+ FAX_DEVICE_BODY(gx_device_fax, fax_initialize_device_procs, dname, print_page)\
}
const gx_device_fax gs_faxg3_device =
diff --git a/devices/gdevfax.h b/devices/gdevfax.h
index 73a668e6..9f7a748e 100644
--- a/devices/gdevfax.h
+++ b/devices/gdevfax.h
@@ -56,7 +56,6 @@ typedef struct gx_device_fax_s {
dev_proc_open_device(gdev_fax_open);
dev_proc_get_params(gdev_fax_get_params); /* adds AdjustWidth, MinFeatureSize */
dev_proc_put_params(gdev_fax_put_params); /* adds AdjustWidth, MinFeatureSize */
-extern const gx_device_procs gdev_fax_std_procs;
/* Other procedures */
void gdev_fax_init_state(stream_CFE_state *ss, const gx_device_fax *fdev);
diff --git a/devices/gdevfpng.c b/devices/gdevfpng.c
index 324cbd28..d57df8f8 100644
--- a/devices/gdevfpng.c
+++ b/devices/gdevfpng.c
@@ -107,80 +107,18 @@ fpng_dev_spec_op(gx_device *pdev, int dev_spec_op, void *data, int size)
/* 24-bit color. */
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs fpng_procs =
+static void
+fpng_initialize_device_procs(gx_device *dev)
{
- gdev_prn_open,
- NULL, /* get_initial_matrix */
- NULL, /* sync_output */
- gdev_prn_bg_output_page,
- gdev_prn_close,
- gx_default_rgb_map_rgb_color,
- gx_default_rgb_map_color_rgb,
- NULL, /* fill_rectangle */
- NULL, /* tile_rectangle */
- NULL, /* copy_mono */
- NULL, /* copy_color */
- NULL, /* draw_line */
- NULL, /* get_bits */
- fpng_get_params,
- fpng_put_params,
- NULL, /* map_cmyk_color */
- NULL, /* get_xfont_procs */
- NULL, /* get_xfont_device */
- NULL, /* map_rgb_alpha_color */
- gx_page_device_get_page_device,
- NULL, /* get_alpha_bits */
- NULL, /* copy_alpha */
- NULL, /* get_band */
- NULL, /* copy_rop */
- NULL, /* fill_path */
- NULL, /* stroke_path */
- NULL, /* fill_mask */
- NULL, /* fill_trapezoid */
- NULL, /* fill_parallelogram */
- NULL, /* fill_triangle */
- NULL, /* draw_thin_line */
- NULL, /* begin_image */
- NULL, /* image_data */
- NULL, /* end_image */
- NULL, /* strip_tile_rectangle */
- NULL, /* strip_copy_rop, */
- NULL, /* get_clipping_box */
- NULL, /* begin_typed_image */
- NULL, /* get_bits_rectangle */
- NULL, /* map_color_rgb_alpha */
- NULL, /* create_compositor */
- NULL, /* get_hardware_params */
- NULL, /* text_begin */
- NULL, /* finish_copydevice */
- NULL, /* begin_transparency_group */
- NULL, /* end_transparency_group */
- NULL, /* begin_transparency_mask */
- NULL, /* end_transparency_mask */
- NULL, /* discard_transparency_layer */
- NULL, /* get_color_mapping_procs */
- NULL, /* get_color_comp_index */
- NULL, /* encode_color */
- NULL, /* decode_color */
- NULL, /* pattern_manage */
- NULL, /* fill_rectangle_hl_color */
- NULL, /* include_color_space */
- NULL, /* fill_linear_color_scanline */
- NULL, /* fill_linear_color_trapezoid */
- NULL, /* fill_linear_color_triangle */
- NULL, /* update_spot_equivalent_colors */
- NULL, /* ret_devn_params */
- NULL, /* fillpage */
- NULL, /* push_transparency_state */
- NULL, /* pop_transparency_state */
- NULL, /* put_image */
- fpng_dev_spec_op, /* dev_spec_op */
- NULL, /* copy plane */
- gx_default_get_profile, /* get_profile */
- gx_default_set_graphics_type_tag /* set_graphics_type_tag */
-};
+ gdev_prn_initialize_device_procs_rgb_bg(dev);
+
+ set_dev_proc(dev, get_params, fpng_get_params);
+ set_dev_proc(dev, put_params, fpng_put_params);
+ set_dev_proc(dev, dev_spec_op, fpng_dev_spec_op);
+}
+
const gx_device_fpng gs_fpng_device =
-{prn_device_body(gx_device_fpng, fpng_procs, "fpng",
+{prn_device_body(gx_device_fpng, fpng_initialize_device_procs, "fpng",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -318,7 +256,7 @@ static int fpng_process(void *arg, gx_device *dev, gx_device *bdev, const gs_int
my_rect.p.y = 0;
my_rect.q.x = w;
my_rect.q.y = h;
- code = dev_proc(bdev, get_bits_rectangle)(bdev, &my_rect, &params, NULL);
+ code = dev_proc(bdev, get_bits_rectangle)(bdev, &my_rect, &params);
if (code < 0)
return code;
diff --git a/devices/gdevhl7x.c b/devices/gdevhl7x.c
index c2f1eaa1..14b64097 100644
--- a/devices/gdevhl7x.c
+++ b/devices/gdevhl7x.c
@@ -248,12 +248,17 @@ static dev_proc_close_device(hl7x0_close);
static dev_proc_print_page(hl720_print_page);
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs prn_hl_procs =
- prn_params_procs(hl7x0_open, gdev_prn_bg_output_page, hl7x0_close,
- gdev_prn_get_params, gdev_prn_put_params);
+static void
+hl7x0_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono_bg(dev);
+
+ set_dev_proc(dev, open_device, hl7x0_open);
+ set_dev_proc(dev, close_device, hl7x0_close);
+}
const gx_device_printer far_data gs_hl7x0_device =
- prn_device(prn_hl_procs, "hl7x0",
+ prn_device(hl7x0_initialize_device_procs, "hl7x0",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins filled in by hl7x0_open */
diff --git a/devices/gdevicov.c b/devices/gdevicov.c
index 91e98d6e..e138cbe9 100644
--- a/devices/gdevicov.c
+++ b/devices/gdevicov.c
@@ -166,42 +166,16 @@ static int cov_write_page_ink(gx_device_printer *pdev, gp_file *file)
return (code > 0) ? ecode : 0;
}
-static const gx_device_procs cov_procs =
-{
- gdev_prn_open,
- NULL, /* get_initial_matrix */
- NULL, /* sync_output */
- /* Since the print_page doesn't alter the device, this device can print in the background */
- gdev_prn_bg_output_page,
- gdev_prn_close,
- NULL, /* map_rgb_color */
- cmyk_8bit_map_color_rgb,
- NULL, /* fill_rectangle */
- NULL, /* tile_rectangle */
- NULL, /* copy_mono */
- NULL, /* copy_color */
- NULL, /* draw_line */
- NULL, /* get_bits */
- gdev_prn_get_params,
- gdev_prn_put_params,
- cmyk_8bit_map_cmyk_color,
- NULL, /* get_xfont_procs */
- NULL, /* get_xfont_device */
- NULL, /* map_rgb_alpha_color */
- gx_page_device_get_page_device
-};
-
const gx_device_printer gs_inkcov_device = prn_device(
- cov_procs, "inkcov",
+ gdev_prn_initialize_device_procs_cmyk8_bg, "inkcov",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
75, 75, /* dpi */
0, 0, 0, 0, /* margins */
32, cov_write_page);
const gx_device_printer gs_ink_cov_device = prn_device(
- cov_procs, "ink_cov",
+ gdev_prn_initialize_device_procs_cmyk8_bg, "ink_cov",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
75, 75, /* dpi */
0, 0, 0, 0, /* margins */
32, cov_write_page_ink);
-
diff --git a/devices/gdevifno.c b/devices/gdevifno.c
index 22d5837f..3a34cc19 100644
--- a/devices/gdevifno.c
+++ b/devices/gdevifno.c
@@ -81,14 +81,22 @@ gs_private_st_suffix_add1_final(st_inferno_device, inferno_device,
"inferno_device", inferno_device_enum_ptrs, inferno_device_reloc_ptrs,
gx_device_finalize, st_device_printer, p9color);
-static const gx_device_procs inferno_procs =
- prn_color_params_procs(inferno_open, gdev_prn_output_page, inferno_close,
- inferno_rgb2cmap, inferno_cmap2rgb,
- gdev_prn_get_params, gdev_prn_put_params);
+static void
+inferno_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, inferno_open);
+ set_dev_proc(dev, close_device, inferno_close);
+ set_dev_proc(dev, map_rgb_color, inferno_rgb2cmap);
+ set_dev_proc(dev, map_color_rgb, inferno_cmap2rgb);
+ set_dev_proc(dev, encode_color, inferno_rgb2cmap);
+ set_dev_proc(dev, decode_color, inferno_cmap2rgb);
+}
inferno_device far_data gs_inferno_device =
-{ prn_device_stype_body(inferno_device, inferno_procs, "inferno",
- &st_inferno_device,
+{ prn_device_stype_body(inferno_device, inferno_initialize_device_procs,
+ "inferno", &st_inferno_device,
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0,0,0,0, /* margins */
diff --git a/devices/gdevijs.c b/devices/gdevijs.c
index 884ea54a..0252e3b5 100644
--- a/devices/gdevijs.c
+++ b/devices/gdevijs.c
@@ -90,7 +90,8 @@ static dev_proc_close_device(gsijs_close);
static dev_proc_output_page(gsijs_output_page);
static dev_proc_get_params(gsijs_get_params);
static dev_proc_put_params(gsijs_put_params);
-static dev_proc_finish_copydevice(gsijs_finish_copydevice);
+static dev_proc_initialize_device_procs(gsijs_initialize_device_procs);
+static dev_proc_initialize_device(gsijs_initialize_device);
/* Following definitions are for krgb support. */
static dev_proc_create_buf_device(gsijs_create_buf_device);
@@ -100,53 +101,6 @@ static dev_proc_fill_mask(gsijs_fill_mask);
static dev_proc_fill_path(gsijs_fill_path);
static dev_proc_stroke_path(gsijs_stroke_path);
-static const gx_device_procs gsijs_procs = {
- gsijs_open,
- NULL, /* get_initial_matrix */
- NULL, /* sync_output */
- gsijs_output_page,
- gsijs_close,
- gx_default_rgb_map_rgb_color,
- gx_default_rgb_map_color_rgb,
- NULL, /* fill_rectangle */
- NULL, /* tile_rectangle */
- NULL, /* copy_mono */
- NULL, /* copy_color */
- NULL, /* draw_line */
- NULL, /* get_bits */
- gsijs_get_params,
- gsijs_put_params,
- NULL, /* map_cmyk_color */
- NULL, /* get_xfont_procs */
- NULL, /* get_xfont_device */
- NULL, /* map_rgb_alpha_color */
- gx_page_device_get_page_device,
- NULL, /* get_alpha_bits */
- NULL, /* copy_alpha */
- NULL, /* get_band */
- NULL, /* copy_rop */
- NULL, /* fill_path */
- NULL, /* stroke_path */
- NULL, /* fill_mask */
- NULL, /* fill_trapezoid */
- NULL, /* fill_parallelogram */
- NULL, /* fill_triangle */
- NULL, /* draw_thin_line */
- NULL, /* begin_image */
- NULL, /* image_data */
- NULL, /* end_image */
- NULL, /* strip_tile_rectangle */
- NULL, /* strip_copy_rop, */
- NULL, /* get_clipping_box */
- NULL, /* begin_typed_image */
- NULL, /* get_bits_rectangle */
- NULL, /* map_color_rgb_alpha */
- NULL, /* create_compositor */
- NULL, /* get_hardware_params */
- NULL, /* text_begin */
- gsijs_finish_copydevice
-};
-
typedef struct gx_device_ijs_s gx_device_ijs;
/* The device descriptor */
@@ -189,7 +143,9 @@ struct gx_device_ijs_s {
gx_device_ijs gs_ijs_device =
{
- prn_device_std_body(gx_device_ijs, gsijs_procs, "ijs",
+ prn_device_std_body(gx_device_ijs,
+ gsijs_initialize_device_procs,
+ "ijs",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
DEFAULT_DPI, DEFAULT_DPI,
0, 0, 0, 0,
@@ -481,7 +437,6 @@ static int gsijs_k_get_bits(gx_device_printer * pdev, int y, byte ** actual_data
int y1=raster*(y-(band_height*band_number));
*actual_data = ijsdev->k_band+y1;
-
return 0;
}
@@ -928,25 +883,33 @@ gsijs_open(gx_device *dev)
/* Finish device initialization. */
static int
-gsijs_finish_copydevice(gx_device *dev, const gx_device *from_dev)
+gsijs_initialize_device(gx_device *dev)
{
- int code;
static const char rgb[] = "DeviceRGB";
gx_device_ijs *ijsdev = (gx_device_ijs *)dev;
- code = gx_default_finish_copydevice(dev, from_dev);
- if(code < 0)
- return code;
-
if (!ijsdev->ColorSpace) {
ijsdev->ColorSpace = gs_malloc(ijsdev->memory, sizeof(rgb), 1,
- "gsijs_finish_copydevice");
+ "gsijs_initialize");
if (!ijsdev->ColorSpace)
return gs_note_error(gs_error_VMerror);
ijsdev->ColorSpace_size = sizeof(rgb);
memcpy(ijsdev->ColorSpace, rgb, sizeof(rgb));
}
- return code;
+ return 0;
+}
+
+static void
+gsijs_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, initialize_device, gsijs_initialize_device);
+ set_dev_proc(dev, open_device, gsijs_open);
+ set_dev_proc(dev, output_page, gsijs_output_page);
+ set_dev_proc(dev, close_device, gsijs_close);
+ set_dev_proc(dev, map_rgb_color, gx_default_rgb_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_default_rgb_map_color_rgb);
+ set_dev_proc(dev, get_params, gsijs_get_params);
+ set_dev_proc(dev, put_params, gsijs_put_params);
}
/* Close the gsijs driver */
diff --git a/devices/gdevimgn.c b/devices/gdevimgn.c
index 1abde294..a0a29745 100644
--- a/devices/gdevimgn.c
+++ b/devices/gdevimgn.c
@@ -228,14 +228,20 @@ static dev_proc_open_device(imagen_prn_open);
static dev_proc_close_device(imagen_prn_close);
/* Since the print_page doesn't alter the device, this device can print in the background */
-gx_device_procs imagen_procs =
- prn_procs(imagen_prn_open, gdev_prn_bg_output_page, imagen_prn_close);
+static void
+imagen_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono_bg(dev);
+
+ set_dev_proc(dev, open_device, imagen_prn_open);
+ set_dev_proc(dev, close_device, imagen_prn_close);
+}
#define ppdev ((gx_device_printer *)pdev)
/*-------------------------------------------*/
const gx_device_printer far_data gs_imagen_device =
- prn_device(/*prn_std_procs*/ imagen_procs,
+ prn_device(imagen_initialize_device_procs,
"imagen",
WIDTH_10THS,
HEIGHT_10THS,
diff --git a/devices/gdevjpeg.c b/devices/gdevjpeg.c
index eee3abd0..87ba3c4c 100644
--- a/devices/gdevjpeg.c
+++ b/devices/gdevjpeg.c
@@ -50,6 +50,7 @@ static dev_proc_put_params(jpeg_put_params);
static dev_proc_print_page(jpeg_print_page);
static dev_proc_map_color_rgb(jpegcmyk_map_color_rgb);
static dev_proc_map_cmyk_color(jpegcmyk_map_cmyk_color);
+static dev_proc_decode_color(jpegcmyk_decode_color);
/* ------ The device descriptors ------ */
@@ -63,33 +64,18 @@ static dev_proc_map_cmyk_color(jpegcmyk_map_cmyk_color);
/* 24-bit color */
-static const gx_device_procs jpeg_procs =
+static void
+jpeg_initialize_device_procs(gx_device *dev)
{
- gdev_prn_open,
- jpeg_get_initial_matrix, /* get_initial_matrix */
- NULL, /* sync_output */
-/* Since the print_page doesn't alter the device, this device can print in the background */
- gdev_prn_bg_output_page,
- gdev_prn_close,
- gx_default_rgb_map_rgb_color,/* map_rgb_color */
- gx_default_rgb_map_color_rgb,
- NULL, /* fill_rectangle */
- NULL, /* tile_rectangle */
- NULL, /* copy_mono */
- NULL, /* copy_color */
- NULL, /* draw_line */
- NULL, /* get_bits */
- jpeg_get_params,
- jpeg_put_params,
- NULL,
- NULL, /* get_xfont_procs */
- NULL, /* get_xfont_device */
- NULL, /* map_rgb_alpha_color */
- gx_page_device_get_page_device
-};
+ gdev_prn_initialize_device_procs_rgb_bg(dev);
+
+ set_dev_proc(dev, get_initial_matrix, jpeg_get_initial_matrix);
+ set_dev_proc(dev, get_params, jpeg_get_params);
+ set_dev_proc(dev, put_params, jpeg_put_params);
+}
const gx_device_jpeg gs_jpeg_device =
-{prn_device_std_body(gx_device_jpeg, jpeg_procs, "jpeg",
+{prn_device_std_body(gx_device_jpeg, jpeg_initialize_device_procs, "jpeg",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI, 0, 0, 0, 0, 24, jpeg_print_page),
0, /* JPEGQ: 0 indicates not specified */
@@ -101,33 +87,20 @@ const gx_device_jpeg gs_jpeg_device =
/* 8-bit gray */
-static const gx_device_procs jpeggray_procs =
+static void
+jpeggray_initialize_device_procs(gx_device *dev)
{
- gdev_prn_open,
- jpeg_get_initial_matrix, /* get_initial_matrix */
- NULL, /* sync_output */
-/* Since the print_page doesn't alter the device, this device can print in the background */
- gdev_prn_bg_output_page,
- gdev_prn_close,
- gx_default_gray_map_rgb_color,/* map_rgb_color */
- gx_default_gray_map_color_rgb,
- NULL, /* fill_rectangle */
- NULL, /* tile_rectangle */
- NULL, /* copy_mono */
- NULL, /* copy_color */
- NULL, /* draw_line */
- NULL, /* get_bits */
- jpeg_get_params,
- jpeg_put_params,
- NULL,
- NULL, /* get_xfont_procs */
- NULL, /* get_xfont_device */
- NULL, /* map_rgb_alpha_color */
- gx_page_device_get_page_device
-};
+ gdev_prn_initialize_device_procs_gray_bg(dev);
+
+ set_dev_proc(dev, get_initial_matrix, jpeg_get_initial_matrix);
+ set_dev_proc(dev, get_params, jpeg_get_params);
+ set_dev_proc(dev, put_params, jpeg_put_params);
+ set_dev_proc(dev, encode_color, gx_default_8bit_map_gray_color);
+ set_dev_proc(dev, decode_color, gx_default_8bit_map_color_gray);
+}
const gx_device_jpeg gs_jpeggray_device =
-{prn_device_body(gx_device_jpeg, jpeggray_procs, "jpeggray",
+{prn_device_body(gx_device_jpeg, jpeggray_initialize_device_procs, "jpeggray",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI, 0, 0, 0, 0,
1, 8, 255, 0, 256, 0,
@@ -138,34 +111,26 @@ const gx_device_jpeg gs_jpeggray_device =
{ 0.0, 0.0 }, /* translation 0 */
GX_DOWNSCALER_PARAMS_DEFAULTS
};
+
/* 32-bit CMYK */
-static const gx_device_procs jpegcmyk_procs =
-{ gdev_prn_open,
- gx_default_get_initial_matrix,
-/* Since the print_page doesn't alter the device, this device can print in the background */
- NULL, /* sync_output */
- gdev_prn_bg_output_page,
- gdev_prn_close,
- NULL,
- jpegcmyk_map_color_rgb,
- NULL, /* fill_rectangle */
- NULL, /* tile_rectangle */
- NULL, /* copy_mono */
- NULL, /* copy_color */
- NULL, /* draw_line */
- NULL, /* get_bits */
- jpeg_get_params,
- jpeg_put_params,
- jpegcmyk_map_cmyk_color,
- NULL, /* get_xfont_procs */
- NULL, /* get_xfont_device */
- NULL, /* map_rgb_alpha_color */
- gx_page_device_get_page_device /* get_page_device */
-};
+static void
+jpegcmyk_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, get_initial_matrix, jpeg_get_initial_matrix);
+ set_dev_proc(dev, map_color_rgb, jpegcmyk_map_color_rgb);
+ set_dev_proc(dev, get_params, jpeg_get_params);
+ set_dev_proc(dev, put_params, jpeg_put_params);
+ set_dev_proc(dev, map_cmyk_color, jpegcmyk_map_cmyk_color);
+
+ set_dev_proc(dev, encode_color, jpegcmyk_map_cmyk_color);
+ set_dev_proc(dev, decode_color, jpegcmyk_decode_color);
+}
const gx_device_jpeg gs_jpegcmyk_device =
-{prn_device_std_body(gx_device_jpeg, jpegcmyk_procs, "jpegcmyk",
+{prn_device_std_body(gx_device_jpeg, jpegcmyk_initialize_device_procs, "jpegcmyk",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI, 0, 0, 0, 0, 32, jpeg_print_page),
0, /* JPEGQ: 0 indicates not specified */
@@ -205,6 +170,19 @@ jpegcmyk_map_cmyk_color(gx_device * dev, const gx_color_value cv[])
return (color == gx_no_color_index ? color ^ 1 : color);
}
+static int
+jpegcmyk_decode_color(gx_device * dev, gx_color_index color,
+ gx_color_value cv[4])
+{
+ color = ~color;
+ cv[0] = gx_color_value_from_byte(0xff & (color>>24));
+ cv[1] = gx_color_value_from_byte(0xff & (color>>16));
+ cv[2] = gx_color_value_from_byte(0xff & (color>>8));
+ cv[3] = gx_color_value_from_byte(0xff & color);
+
+ return 0;
+}
+
/* Get parameters. */
static int
jpeg_get_params(gx_device * dev, gs_param_list * plist)
@@ -578,4 +556,3 @@ jpeg_print_page(gx_device_printer * pdev, gp_file * prn_stream)
gs_free_object(mem, in, "jpeg_print_page(in)");
return code;
}
-
diff --git a/devices/gdevl31s.c b/devices/gdevl31s.c
index 9a32d434..8832c13a 100644
--- a/devices/gdevl31s.c
+++ b/devices/gdevl31s.c
@@ -79,14 +79,18 @@ static dev_proc_print_page_copies(lj3100sw_print_page_copies);
static dev_proc_close_device(lj3100sw_close);
/* Since the print_page doesn't alter the device, this device can print in the background */
-static gx_device_procs prn_lj3100sw_procs =
- prn_params_procs(gdev_prn_open, gdev_prn_bg_output_page, lj3100sw_close,
- gdev_prn_get_params, gdev_prn_put_params);
+static void
+lj3100sw_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono_bg(dev);
+
+ set_dev_proc(dev, close_device, lj3100sw_close);
+}
/* workaround to emulate the missing prn_device_margins_copies macro */
#define gx_default_print_page_copies lj3100sw_print_page_copies
gx_device_printer far_data gs_lj3100sw_device =
- prn_device_margins/*_copies*/(prn_lj3100sw_procs, "lj3100sw",
+ prn_device_margins/*_copies*/(lj3100sw_initialize_device_procs, "lj3100sw",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
XCORRECTION, YCORRECTION,
diff --git a/devices/gdevlbp8.c b/devices/gdevlbp8.c
index a53b2461..fbbbf697 100644
--- a/devices/gdevlbp8.c
+++ b/devices/gdevlbp8.c
@@ -48,15 +48,17 @@ static dev_proc_print_page(lips3_print_page);
#endif
const gx_device_printer far_data gs_lbp8_device =
- prn_device(prn_bg_procs, "lbp8", /* The print_page proc is compatible with allowing bg printing */
+ /* The print_page proc is compatible with allowing bg printing */
+ prn_device(gdev_prn_initialize_device_procs_mono_bg, "lbp8",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0.16, 0.2, 0.32, 0.21, /* margins: left, bottom, right, top */
1, lbp8_print_page);
#ifdef NOCONTRIB
+/* The print_page proc is compatible with allowing bg printing */
const gx_device_printer far_data gs_lips3_device =
- prn_device(prn_bg_procs, "lips3", /* The print_page proc is compatible with allowing bg printing */
+ prn_device(gdev_prn_initialize_device_procs_mono_bg, "lips3",
82, /* width_10ths, 8.3" */
117, /* height_10ths, 11.7" */
X_DPI, Y_DPI,
diff --git a/devices/gdevlj56.c b/devices/gdevlj56.c
index ed022c0c..d92032ea 100644
--- a/devices/gdevlj56.c
+++ b/devices/gdevlj56.c
@@ -42,24 +42,36 @@ static dev_proc_close_device(ljet5_close);
static dev_proc_print_page(ljet5_print_page);
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs ljet5_procs =
-prn_procs(ljet5_open, gdev_prn_bg_output_page, ljet5_close);
+static void
+ljet5_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono_bg(dev);
+
+ set_dev_proc(dev, open_device, ljet5_open);
+ set_dev_proc(dev, close_device, ljet5_close);
+}
const gx_device_printer gs_lj5mono_device =
-prn_device(ljet5_procs, "lj5mono",
+prn_device(ljet5_initialize_device_procs, "lj5mono",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0,
1, ljet5_print_page);
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs lj5gray_procs =
-prn_color_procs(ljet5_open, gdev_prn_bg_output_page, ljet5_close,
- gx_default_gray_map_rgb_color,
- gx_default_gray_map_color_rgb);
+static void
+lj5gray_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray_bg(dev);
+
+ set_dev_proc(dev, open_device, ljet5_open);
+ set_dev_proc(dev, close_device, ljet5_close);
+ set_dev_proc(dev, encode_color, gx_default_gray_encode_color);
+ set_dev_proc(dev, decode_color, gx_default_gray_decode_color);
+}
const gx_device_printer gs_lj5gray_device = {
- prn_device_body(gx_device_printer, lj5gray_procs, "lj5gray",
+ prn_device_body(gx_device_printer, lj5gray_initialize_device_procs, "lj5gray",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0,
diff --git a/devices/gdevlp8k.c b/devices/gdevlp8k.c
index 8083db8a..6794e741 100644
--- a/devices/gdevlp8k.c
+++ b/devices/gdevlp8k.c
@@ -168,8 +168,9 @@ Oleg Fat'yanov <faty1@rlem.titech.ac.jp>
static dev_proc_print_page(lp8000_print_page);
+/* The print_page proc is compatible with allowing bg printing */
gx_device_printer far_data gs_lp8000_device =
- prn_device(prn_bg_procs, "lp8000", /* The print_page proc is compatible with allowing bg printing */
+ prn_device(gdev_prn_initialize_device_procs_mono_bg, "lp8000",
DEFAULT_WIDTH_10THS,
DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
diff --git a/devices/gdevlxm.c b/devices/gdevlxm.c
index 4f9bfca1..1e6f8e51 100644
--- a/devices/gdevlxm.c
+++ b/devices/gdevlxm.c
@@ -40,9 +40,14 @@ static dev_proc_put_params(lxm_put_params);
/* set up dispatch table. I follow gdevdjet in using gdev_prn_output_page */
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs lxm5700m_procs =
- prn_params_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- lxm_get_params, lxm_put_params);
+static void
+lxm5700m_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono_bg(dev);
+
+ set_dev_proc(dev, get_params, lxm_get_params);
+ set_dev_proc(dev, put_params, lxm_put_params);
+}
/* The device descriptors */
@@ -55,7 +60,7 @@ typedef struct lxm_device_s { /* a sub-class of gx_device_printer */
/* Standard lxm5700m device */
lxm_device far_data gs_lxm5700m_device = {
- prn_device_std_body(lxm_device, lxm5700m_procs, "lxm5700m",
+ prn_device_std_body(lxm_device, lxm5700m_initialize_device_procs, "lxm5700m",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
600, 600, /* x dpi, y dpi */
0.2, 0.0, 0.0, 0.0, /* margins */
diff --git a/devices/gdevmeds.c b/devices/gdevmeds.c
index 08ca0aa4..a6be3629 100644
--- a/devices/gdevmeds.c
+++ b/devices/gdevmeds.c
@@ -24,9 +24,9 @@
#include "gdevmeds.h"
-#define CM * 0.01
-#define INCH * 0.0254
-#define TOLERANCE 0.1 CM
+#define CM * 0.01f
+#define INCH * 0.0254f
+#define TOLERANCE 0.1f CM
static const struct {
const char* name;
@@ -35,40 +35,40 @@ static const struct {
float priority;
} media[] = {
#define X(name, width, height) {name, width, height, 1 / (width * height)}
- X("a0", 83.9611 CM, 118.816 CM),
- X("a1", 59.4078 CM, 83.9611 CM),
- X("a2", 41.9806 CM, 59.4078 CM),
- X("a3", 29.7039 CM, 41.9806 CM),
- X("a4", 20.9903 CM, 29.7039 CM),
- X("a5", 14.8519 CM, 20.9903 CM),
- X("a6", 10.4775 CM, 14.8519 CM),
- X("a7", 7.40833 CM, 10.4775 CM),
- X("a8", 5.22111 CM, 7.40833 CM),
- X("a9", 3.70417 CM, 5.22111 CM),
- X("a10", 2.61056 CM, 3.70417 CM),
+ X("a0", 83.9611f CM, 118.816f CM),
+ X("a1", 59.4078f CM, 83.9611f CM),
+ X("a2", 41.9806f CM, 59.4078f CM),
+ X("a3", 29.7039f CM, 41.9806f CM),
+ X("a4", 20.9903f CM, 29.7039f CM),
+ X("a5", 14.8519f CM, 20.9903f CM),
+ X("a6", 10.4775f CM, 14.8519f CM),
+ X("a7", 7.40833f CM, 10.4775f CM),
+ X("a8", 5.22111f CM, 7.40833f CM),
+ X("a9", 3.70417f CM, 5.22111f CM),
+ X("a10", 2.61056f CM, 3.70417f CM),
X("archA", 9 INCH, 12 INCH),
X("archB", 12 INCH, 18 INCH),
X("archC", 18 INCH, 24 INCH),
X("archD", 24 INCH, 36 INCH),
X("archE", 36 INCH, 48 INCH),
- X("b0", 100.048 CM, 141.393 CM),
- X("b1", 70.6967 CM, 100.048 CM),
- X("b2", 50.0239 CM, 70.6967 CM),
- X("b3", 35.3483 CM, 50.0239 CM),
- X("b4", 25.0119 CM, 35.3483 CM),
- X("b5", 17.6742 CM, 25.0119 CM),
- X("flsa", 8.5 INCH, 13 INCH),
- X("flse", 8.5 INCH, 13 INCH),
- X("halfletter", 5.5 INCH, 8.5 INCH),
+ X("b0", 100.048f CM, 141.393f CM),
+ X("b1", 70.6967f CM, 100.048f CM),
+ X("b2", 50.0239f CM, 70.6967f CM),
+ X("b3", 35.3483f CM, 50.0239f CM),
+ X("b4", 25.0119f CM, 35.3483f CM),
+ X("b5", 17.6742f CM, 25.0119f CM),
+ X("flsa", 8.5f INCH, 13 INCH),
+ X("flse", 8.5f INCH, 13 INCH),
+ X("halfletter", 5.5f INCH, 8.5f INCH),
X("ledger", 17 INCH, 11 INCH),
- X("legal", 8.5 INCH, 14 INCH),
- X("letter", 8.5 INCH, 11 INCH),
- X("note", 7.5 INCH, 10 INCH),
- X("executive", 7.25 INCH, 10.5 INCH),
- X("com10", 4.125 INCH, 9.5 INCH),
+ X("legal", 8.5f INCH, 14 INCH),
+ X("letter", 8.5f INCH, 11 INCH),
+ X("note", 7.5f INCH, 10 INCH),
+ X("executive", 7.25f INCH, 10.5f INCH),
+ X("com10", 4.125f INCH, 9.5f INCH),
X("dl", 11 CM, 22 CM),
- X("c5", 16.2 CM, 22.9 CM),
- X("monarch", 3.875 INCH, 7.5 INCH)};
+ X("c5", 16.2f CM, 22.9f CM),
+ X("monarch", 3.875f INCH, 7.5f INCH)};
int select_medium(gx_device_printer *pdev, const char **available, int default_index)
{
diff --git a/devices/gdevmgr.c b/devices/gdevmgr.c
index a2d9b4d1..f1dfcf7b 100644
--- a/devices/gdevmgr.c
+++ b/devices/gdevmgr.c
@@ -66,31 +66,64 @@ static dev_proc_print_page(cmgrN_print_page);
/* The device procedures */
/* Since the print_page doesn't alter the device, this device can print in the background */
-static gx_device_procs mgr_procs =
- prn_procs(gdev_mgr_open, gdev_prn_bg_output_page, gdev_prn_close);
-static gx_device_procs mgrN_procs =
- prn_color_procs(gdev_mgr_open, gdev_prn_bg_output_page, gdev_prn_close,
- gx_default_gray_map_rgb_color, gx_default_gray_map_color_rgb);
-static gx_device_procs cmgr4_procs =
- prn_color_procs(gdev_mgr_open, gdev_prn_bg_output_page, gdev_prn_close,
- pc_4bit_map_rgb_color, pc_4bit_map_color_rgb);
-static gx_device_procs cmgr8_procs =
- prn_color_procs(gdev_mgr_open, gdev_prn_bg_output_page, gdev_prn_close,
- mgr_8bit_map_rgb_color, mgr_8bit_map_color_rgb);
+static void
+mgr_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono_bg(dev);
+
+ set_dev_proc(dev, open_device, gdev_mgr_open);
+
+ set_dev_proc(dev, encode_color, gx_default_b_w_mono_encode_color);
+ set_dev_proc(dev, decode_color, gx_default_b_w_mono_decode_color);
+}
+
+static void
+mgrN_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray_bg(dev);
+
+ set_dev_proc(dev, open_device, gdev_mgr_open);
+ set_dev_proc(dev, encode_color, gx_default_gray_encode_color);
+ set_dev_proc(dev, decode_color, gx_default_gray_decode_color);
+}
+
+static void
+cmgr4_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, open_device, gdev_mgr_open);
+ set_dev_proc(dev, map_rgb_color, pc_4bit_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, pc_4bit_map_color_rgb);
+ set_dev_proc(dev, encode_color, pc_4bit_map_rgb_color);
+ set_dev_proc(dev, decode_color, pc_4bit_map_color_rgb);
+}
+
+static void
+cmgr8_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, open_device, gdev_mgr_open);
+ set_dev_proc(dev, map_rgb_color, mgr_8bit_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, mgr_8bit_map_color_rgb);
+ set_dev_proc(dev, encode_color, mgr_8bit_map_rgb_color);
+ set_dev_proc(dev, decode_color, mgr_8bit_map_color_rgb);
+}
/* The device descriptors themselves */
gx_device_mgr far_data gs_mgrmono_device =
- mgr_prn_device( mgr_procs, "mgrmono", 1, 1, 1, 1, 0, 2, 0, mgr_print_page);
+ mgr_prn_device( mgr_initialize_device_procs, "mgrmono", 1, 1, 1, 1, 0, 2, 0, mgr_print_page);
gx_device_mgr far_data gs_mgrgray2_device =
- mgr_prn_device(mgrN_procs, "mgrgray2",1, 8, 2, 255, 0, 4, 0, mgrN_print_page);
+ mgr_prn_device(mgrN_initialize_device_procs, "mgrgray2",1, 8, 2, 255, 0, 4, 0, mgrN_print_page);
gx_device_mgr far_data gs_mgrgray4_device =
- mgr_prn_device(mgrN_procs, "mgrgray4",1, 8, 4, 255, 0,16, 0, mgrN_print_page);
+ mgr_prn_device(mgrN_initialize_device_procs, "mgrgray4",1, 8, 4, 255, 0,16, 0, mgrN_print_page);
gx_device_mgr far_data gs_mgrgray8_device =
- mgr_prn_device(mgrN_procs, "mgrgray8",1, 8, 8, 255, 0, 0, 0, mgrN_print_page);
+ mgr_prn_device(mgrN_initialize_device_procs, "mgrgray8",1, 8, 8, 255, 0, 0, 0, mgrN_print_page);
gx_device_mgr far_data gs_mgr4_device =
- mgr_prn_device(cmgr4_procs, "mgr4", 3, 8, 4, 1, 1, 2, 2, cmgrN_print_page);
+ mgr_prn_device(cmgr4_initialize_device_procs, "mgr4", 3, 8, 4, 1, 1, 2, 2, cmgrN_print_page);
gx_device_mgr far_data gs_mgr8_device =
- mgr_prn_device(cmgr8_procs, "mgr8", 3, 8, 8, 255, 255, 6, 5, cmgrN_print_page);
+ mgr_prn_device(cmgr8_initialize_device_procs, "mgr8", 3, 8, 8, 255, 255, 6, 5, cmgrN_print_page);
/* ------ Internal routines ------ */
@@ -239,14 +272,19 @@ mgrN_print_page(gx_device_printer *pdev, gp_file *pstream)
break;
case 4:
- for (i = 0,dp = data, bp = cur.data; i < mgr_line_size; i++) {
+ {
+ int size = mgr_line_size - (bdev->width & 1);
+ for (i = 0,dp = data, bp = cur.data; i < size; i++) {
*dp = mgr->bgreybacktable[*(bp++) >> 4] << 4;
*(dp++) |= mgr->bgreybacktable[*(bp++) >> 4];
}
+ if (bdev->width & 1) {
+ *dp = mgr->bgreybacktable[*(bp++) >> 4] << 4;
+ }
if ( gp_fwrite(data, sizeof(byte), mgr_line_size, pstream) < mgr_line_size )
return_error(gs_error_ioerror);
break;
-
+ }
case 8:
for (i = 0,bp = cur.data; i < mgr_line_size; i++, bp++)
*bp = mgr->bgrey256backtable[*bp];
diff --git a/devices/gdevmiff.c b/devices/gdevmiff.c
index 7919f7a5..3bf74a18 100644
--- a/devices/gdevmiff.c
+++ b/devices/gdevmiff.c
@@ -27,11 +27,14 @@
static dev_proc_print_page(miff24_print_page);
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs miff24_procs =
-prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb);
+static void
+miff24_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_rgb_bg(dev);
+}
+
const gx_device_printer gs_miff24_device =
-prn_device(miff24_procs, "miff24",
+prn_device(miff24_initialize_device_procs, "miff24",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
diff --git a/devices/gdevn533.c b/devices/gdevn533.c
index aa4ebef3..3ca4142e 100644
--- a/devices/gdevn533.c
+++ b/devices/gdevn533.c
@@ -46,11 +46,18 @@ static dev_proc_open_device(nwp533_open);
static dev_proc_print_page(nwp533_print_page);
static dev_proc_close_device(nwp533_close);
/* Since the print_page doesn't alter the device, this device can print in the background */
-static gx_device_procs nwp533_procs =
- prn_procs(nwp533_open, gdev_prn_bg_output_page_seekable, nwp533_close);
+static void
+nwp533_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono_bg(dev);
+
+ set_dev_proc(dev, open_device, nwp533_open);
+ set_dev_proc(dev, output_page, gdev_prn_bg_output_page_seekable);
+ set_dev_proc(dev, close_device, nwp533_close);
+}
const gx_device_printer far_data gs_nwp533_device =
- prn_device(nwp533_procs, "nwp533",
+ prn_device(mwp533_initialize_device_procs, "nwp533",
PAPER_XDOTS * 10.0 / DPI, /* width_10ths */
PAPER_YDOTS * 10.0 / DPI, /* height_10ths */
DPI, /* x_dpi */
diff --git a/devices/gdevo182.c b/devices/gdevo182.c
index ce57db05..8a1000c5 100644
--- a/devices/gdevo182.c
+++ b/devices/gdevo182.c
@@ -63,8 +63,9 @@ the graphics data can't match any Okidata commands
static dev_proc_print_page(oki_print_page);
+/* The print_page proc is compatible with allowing bg printing */
const gx_device_printer far_data gs_oki182_device =
- prn_device(prn_bg_procs, "oki182", /* The print_page proc is compatible with allowing bg printing */
+ prn_device(gdev_prn_initialize_device_procs_mono_bg, "oki182",
80, /* width_10ths, 8.0" */
110, /* height_10ths, 11" */
72, /* x_dpi */
diff --git a/devices/gdevocr.c b/devices/gdevocr.c
index cd1efeb1..88c759c4 100644
--- a/devices/gdevocr.c
+++ b/devices/gdevocr.c
@@ -50,15 +50,22 @@ struct gx_device_ocr_s {
};
/* 8-bit gray bitmap -> UTF8 OCRd text */
+static void
+ocr_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray_bg(dev);
+
+ set_dev_proc(dev, open_device, ocr_open);
+ set_dev_proc(dev, close_device, ocr_close);
+ set_dev_proc(dev, get_params, ocr_get_params);
+ set_dev_proc(dev, put_params, ocr_put_params);
+ set_dev_proc(dev, encode_color, gx_default_8bit_map_gray_color);
+ set_dev_proc(dev, decode_color, gx_default_8bit_map_color_gray);
+}
-static const gx_device_procs ocr_procs =
-prn_color_params_procs(ocr_open, gdev_prn_bg_output_page, ocr_close,
- gx_default_gray_map_rgb_color,
- gx_default_gray_map_color_rgb,
- ocr_get_params, ocr_put_params);
const gx_device_ocr gs_ocr_device =
{
- prn_device_body(gx_device_ocr, ocr_procs, "ocr",
+ prn_device_body(gx_device_ocr, ocr_initialize_device_procs, "ocr",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -67,15 +74,22 @@ const gx_device_ocr gs_ocr_device =
};
/* 8-bit gray bitmap -> HTML OCRd text */
+static void
+hocr_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray_bg(dev);
+
+ set_dev_proc(dev, open_device, ocr_open);
+ set_dev_proc(dev, close_device, hocr_close);
+ set_dev_proc(dev, get_params, ocr_get_params);
+ set_dev_proc(dev, put_params, ocr_put_params);
+ set_dev_proc(dev, encode_color, gx_default_8bit_map_gray_color);
+ set_dev_proc(dev, decode_color, gx_default_8bit_map_color_gray);
+}
-static const gx_device_procs hocr_procs =
-prn_color_params_procs(ocr_open, gdev_prn_bg_output_page, hocr_close,
- gx_default_gray_map_rgb_color,
- gx_default_gray_map_color_rgb,
- ocr_get_params, ocr_put_params);
const gx_device_ocr gs_hocr_device =
{
- prn_device_body(gx_device_ocr, hocr_procs, "hocr",
+ prn_device_body(gx_device_ocr, hocr_initialize_device_procs, "hocr",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
diff --git a/devices/gdevokii.c b/devices/gdevokii.c
index f9eaf6a8..214ee596 100644
--- a/devices/gdevokii.c
+++ b/devices/gdevokii.c
@@ -73,8 +73,9 @@
static dev_proc_print_page(okiibm_print_page);
/* Okidata IBM device */
+/* The print_page proc is compatible with allowing bg printing */
const gx_device_printer far_data gs_okiibm_device =
- prn_device(prn_bg_procs, "okiibm", /* The print_page proc is compatible with allowing bg printing */
+ prn_device(gdev_prn_initialize_device_procs_mono_bg, "okiibm",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0.25, 0.0, 0.25, 0.0, /* margins */
diff --git a/devices/gdevpbm.c b/devices/gdevpbm.c
index 9bba6889..19e5ade0 100644
--- a/devices/gdevpbm.c
+++ b/devices/gdevpbm.c
@@ -110,10 +110,10 @@ typedef struct gx_device_pbm_s gx_device_pbm;
}
/* For all but PBM, we need our own color mapping and alpha procedures. */
-static dev_proc_map_rgb_color(pgm_map_rgb_color);
-static dev_proc_map_rgb_color(ppm_map_rgb_color);
-static dev_proc_map_color_rgb(pgm_map_color_rgb);
-static dev_proc_map_color_rgb(ppm_map_color_rgb);
+static dev_proc_encode_color(pgm_encode_color);
+static dev_proc_encode_color(pnm_encode_color);
+static dev_proc_decode_color(pgm_decode_color);
+static dev_proc_decode_color(ppm_decode_color);
static dev_proc_map_cmyk_color(pkm_map_cmyk_color);
static dev_proc_map_color_rgb(pkm_map_color_rgb);
static dev_proc_get_params(ppm_get_params);
@@ -140,96 +140,153 @@ static dev_proc_print_page(pnmcmyk_print_page);
/* The device procedures */
-/* See gdevprn.h for the template for the following. */
-#define pgpm_procs(p_open, p_get_params, p_map_rgb_color, p_map_color_rgb, p_map_cmyk_color) {\
- p_open, NULL, NULL, ppm_output_page, gdev_prn_close,\
- p_map_rgb_color, p_map_color_rgb, NULL, NULL, NULL, NULL, NULL, NULL,\
- p_get_params, ppm_put_params,\
- p_map_cmyk_color, NULL, NULL, NULL, gx_page_device_get_page_device\
+static void
+pbm_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, encode_color, gx_default_b_w_mono_encode_color);
+ set_dev_proc(dev, decode_color, gx_default_b_w_mono_decode_color);
+ set_dev_proc(dev, put_params, ppm_put_params);
+ set_dev_proc(dev, output_page, ppm_output_page);
+}
+
+static void
+ppm_initialize_device_procs(gx_device *dev)
+{
+ pbm_initialize_device_procs(dev);
+
+ set_dev_proc(dev, get_params, ppm_get_params);
+ set_dev_proc(dev, map_rgb_color, gx_default_rgb_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, ppm_decode_color);
+ set_dev_proc(dev, encode_color, gx_default_rgb_map_rgb_color);
+ set_dev_proc(dev, decode_color, ppm_decode_color);
+ set_dev_proc(dev, open_device, ppm_open);
+}
+
+static void
+pgm_initialize_device_procs(gx_device *dev)
+{
+ pbm_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_rgb_color, pgm_encode_color);
+ set_dev_proc(dev, map_color_rgb, pgm_decode_color);
+ set_dev_proc(dev, encode_color, pgm_encode_color);
+ set_dev_proc(dev, decode_color, pgm_decode_color);
+ set_dev_proc(dev, open_device, ppm_open);
+}
+
+static void
+pnm_initialize_device_procs(gx_device *dev)
+{
+ ppm_initialize_device_procs(dev);
+
+ set_dev_proc(dev, encode_color, pnm_encode_color);
+ set_dev_proc(dev, decode_color, ppm_decode_color);
+}
+
+static void
+pkm_initialize_device_procs(gx_device *dev)
+{
+ ppm_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_rgb_color, NULL);
+ set_dev_proc(dev, decode_color, cmyk_1bit_map_color_rgb);
+ set_dev_proc(dev, encode_color, cmyk_1bit_map_cmyk_color);
+}
+
+static void
+pam32_initialize_device_procs(gx_device *dev)
+{
+ ppm_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_rgb_color, NULL);
+ set_dev_proc(dev, map_color_rgb, cmyk_8bit_map_color_rgb);
+ set_dev_proc(dev, map_cmyk_color, cmyk_8bit_map_cmyk_color);
+ set_dev_proc(dev, decode_color, cmyk_8bit_map_color_cmyk);
+ set_dev_proc(dev, encode_color, cmyk_8bit_map_cmyk_color);
}
-static const gx_device_procs pbm_procs =
- pgpm_procs(gdev_prn_open, gdev_prn_get_params,
- gdev_prn_map_rgb_color, gdev_prn_map_color_rgb, NULL);
-static const gx_device_procs pgm_procs =
- pgpm_procs(ppm_open, gdev_prn_get_params,
- pgm_map_rgb_color, pgm_map_color_rgb, NULL);
-static const gx_device_procs ppm_procs =
- pgpm_procs(ppm_open, ppm_get_params,
- gx_default_rgb_map_rgb_color, ppm_map_color_rgb, NULL);
-static const gx_device_procs pnm_procs =
- pgpm_procs(ppm_open, ppm_get_params,
- ppm_map_rgb_color, ppm_map_color_rgb, NULL);
-static const gx_device_procs pkm_procs =
- pgpm_procs(ppm_open, ppm_get_params,
- NULL, cmyk_1bit_map_color_rgb, cmyk_1bit_map_cmyk_color);
-static const gx_device_procs pam_procs =
- pgpm_procs(ppm_open, ppm_get_params,
- NULL, cmyk_8bit_map_color_rgb, cmyk_8bit_map_cmyk_color);
-static const gx_device_procs pnmcmyk_procs =
- pgpm_procs(pnmcmyk_open, ppm_get_params,
- NULL, cmyk_8bit_map_color_rgb, cmyk_8bit_map_cmyk_color);
+static void
+pam4_initialize_device_procs(gx_device *dev)
+{
+ ppm_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_rgb_color, NULL);
+ set_dev_proc(dev, map_color_rgb, NULL);
+ set_dev_proc(dev, map_cmyk_color, cmyk_1bit_map_cmyk_color);
+ set_dev_proc(dev, decode_color, cmyk_1bit_map_color_cmyk);
+ set_dev_proc(dev, encode_color, cmyk_1bit_map_cmyk_color);
+}
+
+static void
+pnmcmyk_initialize_device_procs(gx_device *dev)
+{
+ pam32_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, pnmcmyk_open);
+}
/* The device descriptors themselves */
const gx_device_pbm gs_pbm_device =
-pbm_prn_device(pbm_procs, "pbm", '1', 0, 1, 1, 1, 0, 0,
+pbm_prn_device(pbm_initialize_device_procs, "pbm", '1', 0, 1, 1, 1, 0, 0,
X_DPI, Y_DPI, pbm_print_page);
const gx_device_pbm gs_pbmraw_device =
-pbm_prn_device(pbm_procs, "pbmraw", '4', 1, 1, 1, 1, 1, 0,
+pbm_prn_device(pbm_initialize_device_procs, "pbmraw", '4', 1, 1, 1, 1, 1, 0,
X_DPI, Y_DPI, pbm_print_page);
const gx_device_pbm gs_pgm_device =
-pbm_prn_device(pgm_procs, "pgm", '2', 0, 1, 8, 255, 0, 0,
+pbm_prn_device(pgm_initialize_device_procs, "pgm", '2', 0, 1, 8, 255, 0, 0,
X_DPI, Y_DPI, pgm_print_page);
const gx_device_pbm gs_pgmraw_device =
-pbm_prn_device(pgm_procs, "pgmraw", '5', 1, 1, 8, 255, 0, 0,
+pbm_prn_device(pgm_initialize_device_procs, "pgmraw", '5', 1, 1, 8, 255, 0, 0,
X_DPI, Y_DPI, pgm_print_page);
const gx_device_pbm gs_pgnm_device =
-pbm_prn_device(pgm_procs, "pgnm", '2', 0, 1, 8, 255, 0, 1,
+pbm_prn_device(pgm_initialize_device_procs, "pgnm", '2', 0, 1, 8, 255, 0, 1,
X_DPI, Y_DPI, pgm_print_page);
const gx_device_pbm gs_pgnmraw_device =
-pbm_prn_device(pgm_procs, "pgnmraw", '5', 1, 1, 8, 255, 0, 1,
+pbm_prn_device(pgm_initialize_device_procs, "pgnmraw", '5', 1, 1, 8, 255, 0, 1,
X_DPI, Y_DPI, pgm_print_page);
const gx_device_pbm gs_ppm_device =
-pbm_prn_device(ppm_procs, "ppm", '3', 0, 3, 24, 255, 255, 0,
+pbm_prn_device(ppm_initialize_device_procs, "ppm", '3', 0, 3, 24, 255, 255, 0,
X_DPI, Y_DPI, ppm_print_page);
const gx_device_pbm gs_ppmraw_device =
-pbm_prn_device(ppm_procs, "ppmraw", '6', 1, 3, 24, 255, 255, 0,
+pbm_prn_device(ppm_initialize_device_procs, "ppmraw", '6', 1, 3, 24, 255, 255, 0,
X_DPI, Y_DPI, ppm_print_page);
const gx_device_pbm gs_pnm_device =
-pbm_prn_device(pnm_procs, "pnm", '3', 0, 3, 24, 255, 255, 1,
+pbm_prn_device(pnm_initialize_device_procs, "pnm", '3', 0, 3, 24, 255, 255, 1,
X_DPI, Y_DPI, ppm_print_page);
const gx_device_pbm gs_pnmraw_device =
-pbm_prn_device(pnm_procs, "pnmraw", '6', 1, 3, 24, 255, 255, 1,
+pbm_prn_device(pnm_initialize_device_procs, "pnmraw", '6', 1, 3, 24, 255, 255, 1,
X_DPI, Y_DPI, ppm_print_page);
const gx_device_pbm gs_pkm_device =
-pbm_prn_device(pkm_procs, "pkm", '3', 0, 4, 4, 1, 1, 0,
+pbm_prn_device(pkm_initialize_device_procs, "pkm", '3', 0, 4, 4, 1, 1, 0,
X_DPI, Y_DPI, pkm_print_page);
const gx_device_pbm gs_pkmraw_device =
-pbm_prn_device(pkm_procs, "pkmraw", '6', 1, 4, 4, 1, 1, 0,
+pbm_prn_device(pkm_initialize_device_procs, "pkmraw", '6', 1, 4, 4, 1, 1, 0,
X_DPI, Y_DPI, pkm_print_page);
const gx_device_pbm gs_pksm_device =
-pbm_prn_device(pkm_procs, "pksm", '1', 0, 4, 4, 1, 1, 0,
+pbm_prn_device(pkm_initialize_device_procs, "pksm", '1', 0, 4, 4, 1, 1, 0,
X_DPI, Y_DPI, psm_print_page);
const gx_device_pbm gs_pksmraw_device =
-pbm_prn_device(pkm_procs, "pksmraw", '4', 1, 4, 4, 1, 1, 0,
+pbm_prn_device(pkm_initialize_device_procs, "pksmraw", '4', 1, 4, 4, 1, 1, 0,
X_DPI, Y_DPI, psm_print_page);
const gx_device_pbm gs_pamcmyk32_device =
-pbm_prn_device(pam_procs, "pamcmyk32", '7', 1, 4, 32, 255, 255, 0,
+pbm_prn_device(pam32_initialize_device_procs, "pamcmyk32", '7', 1, 4, 32, 255, 255, 0,
X_DPI, Y_DPI, pam_print_page);
const gx_device_pbm gs_pnmcmyk_device =
-pbm_prn_device(pnmcmyk_procs, "pnmcmyk", '7', 1, 4, 32, 255, 255, 0, /* optimize false since this relies on GrayDetection */
+pbm_prn_device(pnmcmyk_initialize_device_procs, "pnmcmyk", '7', 1, 4, 32, 255, 255, 0, /* optimize false since this relies on GrayDetection */
X_DPI, Y_DPI, pnmcmyk_print_page); /* May output PGM, magic = 5 */
const gx_device_pbm gs_pamcmyk4_device =
-pbm_prn_device(pam_procs, "pamcmyk4", '7', 1, 4, 4, 1, 1, 0,
+pbm_prn_device(pam4_initialize_device_procs, "pamcmyk4", '7', 1, 4, 4, 1, 1, 0,
X_DPI, Y_DPI, pam4_print_page);
/* Also keep the old device name so anyone using it won't be surprised */
const gx_device_pbm gs_pam_device =
-pbm_prn_device(pam_procs, "pam", '7', 1, 4, 32, 255, 255, 0,
+pbm_prn_device(pam32_initialize_device_procs, "pam", '7', 1, 4, 32, 255, 255, 0,
X_DPI, Y_DPI, pam_print_page);
/* Plan 9 bitmaps default to 100 dpi. */
const gx_device_pbm gs_plan9bm_device =
-pbm_prn_device(pbm_procs, "plan9bm", '9', 1, 1, 1, 1, 1, 1,
+pbm_prn_device(pbm_initialize_device_procs, "plan9bm", '9', 1, 1, 1, 1, 1, 1,
100, 100, pbm_print_page);
/* ------ Initialization ------ */
@@ -253,7 +310,7 @@ ppm_set_dev_procs(gx_device * pdev)
if (bdev->color_info.depth == 4) {
set_dev_proc(pdev, map_color_rgb, cmyk_1bit_map_color_rgb);
set_dev_proc(pdev, map_cmyk_color, cmyk_1bit_map_cmyk_color);
- } else if (bdev->magic == 7) {
+ } else if (bdev->magic == '7') {
set_dev_proc(pdev, map_color_rgb, cmyk_8bit_map_color_rgb);
set_dev_proc(pdev, map_cmyk_color, cmyk_8bit_map_cmyk_color);
} else {
@@ -327,22 +384,10 @@ ppm_output_page(gx_device * pdev, int num_copies, int flush)
/* Map an RGB color to a PGM gray value. */
/* Keep track of whether the image is black-and-white or gray. */
static gx_color_index
-pgm_map_rgb_color(gx_device * pdev, const gx_color_value cv[])
-{ /* We round the value rather than truncating it. */
+pgm_encode_color(gx_device * pdev, const gx_color_value cv[])
+{
gx_color_value gray;
- /* TO_DO_DEVICEN - Kludge to emulate pre DeviceN math errors */
-#if 1
- gx_color_value r, g, b;
-
- r = cv[0]; g = cv[0]; b = cv[0];
- gray = ((r * (ulong) lum_red_weight) +
- (g * (ulong) lum_green_weight) +
- (b * (ulong) lum_blue_weight) +
- (lum_all_weights / 2)) / lum_all_weights
- * pdev->color_info.max_gray / gx_max_color_value;
-#else /* Should be ... */
gray = cv[0] * pdev->color_info.max_gray / gx_max_color_value;
-#endif
if (!(gray == 0 || gray == pdev->color_info.max_gray)) {
gx_device_pbm * const bdev = (gx_device_pbm *)pdev;
@@ -354,15 +399,13 @@ pgm_map_rgb_color(gx_device * pdev, const gx_color_value cv[])
/* Map a PGM gray value back to an RGB color. */
static int
-pgm_map_color_rgb(gx_device * dev, gx_color_index color,
- gx_color_value prgb[3])
+pgm_decode_color(gx_device * dev, gx_color_index color,
+ gx_color_value *pgray)
{
gx_color_value gray =
color * gx_max_color_value / dev->color_info.max_gray;
- prgb[0] = gray;
- prgb[1] = gray;
- prgb[2] = gray;
+ pgray[0] = gray;
return 0;
}
@@ -394,7 +437,7 @@ gx_old_default_rgb_map_rgb_color(gx_device * dev,
/* Map an RGB color to a PPM color tuple. */
/* Keep track of whether the image is black-and-white, gray, or colored. */
static gx_color_index
-ppm_map_rgb_color(gx_device * pdev, const gx_color_value cv[])
+pnm_encode_color(gx_device * pdev, const gx_color_value cv[])
{
gx_device_pbm * const bdev = (gx_device_pbm *)pdev;
gx_color_index color =
@@ -412,8 +455,8 @@ ppm_map_rgb_color(gx_device * pdev, const gx_color_value cv[])
/* Map a PPM color tuple back to an RGB color. */
static int
-ppm_map_color_rgb(gx_device * dev, gx_color_index color,
- gx_color_value prgb[3])
+ppm_decode_color(gx_device * dev, gx_color_index color,
+ gx_color_value prgb[3])
{
uint bitspercolor = dev->color_info.depth / 3;
uint colormask = (1 << bitspercolor) - 1;
diff --git a/devices/gdevpcx.c b/devices/gdevpcx.c
index 1515d411..93f2abf5 100644
--- a/devices/gdevpcx.c
+++ b/devices/gdevpcx.c
@@ -35,12 +35,21 @@
static dev_proc_print_page(pcxmono_print_page);
/* Use the default RGB->color map, so we get black=0, white=1. */
+
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs pcxmono_procs =
-prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- gx_default_map_rgb_color, gx_default_map_color_rgb);
+static void
+pcxmono_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, map_rgb_color, gx_default_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_default_map_color_rgb);
+ set_dev_proc(dev, encode_color, gx_default_map_rgb_color);
+ set_dev_proc(dev, decode_color, gx_default_map_color_rgb);
+}
+
const gx_device_printer gs_pcxmono_device =
-prn_device(pcxmono_procs, "pcxmono",
+prn_device(pcxmono_initialize_device_procs, "pcxmono",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -51,11 +60,16 @@ prn_device(pcxmono_procs, "pcxmono",
static dev_proc_print_page(pcx256_print_page);
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs pcxgray_procs =
-prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- gx_default_gray_map_rgb_color, gx_default_gray_map_color_rgb);
+static void
+pcxgray_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray_bg(dev);
+ set_dev_proc(dev, encode_color, gx_default_8bit_map_gray_color);
+ set_dev_proc(dev, decode_color, gx_default_8bit_map_color_gray);
+}
+
const gx_device_printer gs_pcxgray_device =
-{prn_device_body(gx_device_printer, pcxgray_procs, "pcxgray",
+{prn_device_body(gx_device_printer, pcxgray_initialize_device_procs, "pcxgray",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -67,11 +81,19 @@ const gx_device_printer gs_pcxgray_device =
static dev_proc_print_page(pcx16_print_page);
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs pcx16_procs =
-prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- pc_4bit_map_rgb_color, pc_4bit_map_color_rgb);
+static void
+pcx16_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, map_rgb_color, pc_4bit_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, pc_4bit_map_color_rgb);
+ set_dev_proc(dev, encode_color, pc_4bit_map_rgb_color);
+ set_dev_proc(dev, decode_color, pc_4bit_map_color_rgb);
+}
+
const gx_device_printer gs_pcx16_device =
-{prn_device_body(gx_device_printer, pcx16_procs, "pcx16",
+{prn_device_body(gx_device_printer, pcx16_initialize_device_procs, "pcx16",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -82,11 +104,19 @@ const gx_device_printer gs_pcx16_device =
/* (Uses a fixed palette of 3,3,2 bits.) */
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs pcx256_procs =
-prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- pc_8bit_map_rgb_color, pc_8bit_map_color_rgb);
+static void
+pcx256_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, map_rgb_color, pc_8bit_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, pc_8bit_map_color_rgb);
+ set_dev_proc(dev, encode_color, pc_8bit_map_rgb_color);
+ set_dev_proc(dev, decode_color, pc_8bit_map_color_rgb);
+}
+
const gx_device_printer gs_pcx256_device =
-{prn_device_body(gx_device_printer, pcx256_procs, "pcx256",
+{prn_device_body(gx_device_printer, pcx256_initialize_device_procs, "pcx256",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -98,11 +128,14 @@ const gx_device_printer gs_pcx256_device =
static dev_proc_print_page(pcx24b_print_page);
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs pcx24b_procs =
-prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb);
+static void
+pcx24b_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_rgb_bg(dev);
+}
+
const gx_device_printer gs_pcx24b_device =
-prn_device(pcx24b_procs, "pcx24b",
+prn_device(pcx24b_initialize_device_procs, "pcx24b",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -112,32 +145,14 @@ prn_device(pcx24b_procs, "pcx24b",
static dev_proc_print_page(pcxcmyk_print_page);
-static const gx_device_procs pcxcmyk_procs =
+static void
+pcxcmyk_initialize_device_procs(gx_device *dev)
{
- gdev_prn_open,
- NULL, /* get_initial_matrix */
- NULL, /* sync_output */
-/* Since the print_page doesn't alter the device, this device can print in the background */
- gdev_prn_bg_output_page,
- gdev_prn_close,
- NULL, /* map_rgb_color */
- cmyk_1bit_map_color_rgb,
- NULL, /* fill_rectangle */
- NULL, /* tile_rectangle */
- NULL, /* copy_mono */
- NULL, /* copy_color */
- NULL, /* draw_line */
- NULL, /* get_bits */
- gdev_prn_get_params,
- gdev_prn_put_params,
- cmyk_1bit_map_cmyk_color,
- NULL, /* get_xfont_procs */
- NULL, /* get_xfont_device */
- NULL, /* map_rgb_alpha_color */
- gx_page_device_get_page_device
-};
+ gdev_prn_initialize_device_procs_cmyk1_bg(dev);
+}
+
const gx_device_printer gs_pcxcmyk_device =
-{prn_device_body(gx_device_printer, pcxcmyk_procs, "pcxcmyk",
+{prn_device_body(gx_device_printer, pcxcmyk_initialize_device_procs, "pcxcmyk",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -373,6 +388,10 @@ pcx_write_page(gx_device_printer * pdev, gp_file * file, pcx_header * phdr,
{
byte *pend = plane + rsize;
int shift;
+ /* We'll have a run of full 32bit words,
+ * followed by some sets of stray 4-bits. */
+ int stray = pdev->width & 7;
+ byte *fend = row + ((pdev->width & ~7)>>1);
for (shift = 0; shift < 4; shift++) {
register byte *from, *to;
@@ -380,7 +399,7 @@ pcx_write_page(gx_device_printer * pdev, gp_file * file, pcx_header * phdr,
register int bleft = bright << 4;
for (from = row, to = plane;
- from < end; from += 4
+ from < fend; from += 4
) {
*to++ =
(from[0] & bleft ? 0x80 : 0) |
@@ -392,9 +411,21 @@ pcx_write_page(gx_device_printer * pdev, gp_file * file, pcx_header * phdr,
(from[3] & bleft ? 0x02 : 0) |
(from[3] & bright ? 0x01 : 0);
}
- /* We might be one byte short of rsize. */
- if (to < pend)
+ if (stray) {
+ byte v = (from[0] & bleft ? 0x80 : 0);
+ if (stray > 1) v |= from[0] & bright ? 0x40 : 0;
+ if (stray > 2) v |= from[1] & bleft ? 0x20 : 0;
+ if (stray > 3) v |= from[1] & bright ? 0x10 : 0;
+ if (stray > 4) v |= from[2] & bleft ? 0x08 : 0;
+ if (stray > 5) v |= from[2] & bright ? 0x04 : 0;
+ if (stray > 6) v |= from[3] & bleft ? 0x02 : 0;
+ *to++ = v;
+ }
+ /* Continue to 'raster' rather than width. */
+ while (to < pend) {
*to = to[-1];
+ to++;
+ }
pcx_write_rle(plane, pend, 1, file);
}
}
diff --git a/devices/gdevpdfimg.c b/devices/gdevpdfimg.c
index 7d04755b..81e7a48e 100644
--- a/devices/gdevpdfimg.c
+++ b/devices/gdevpdfimg.c
@@ -57,19 +57,23 @@ int PCLm_close(gx_device * pdev);
/* ------ The pdfimage8 device ------ */
-
-static const gx_device_procs pdfimage8_procs =
-prn_color_params_procs(pdf_image_open,
- gdev_prn_output_page_seekable,
- pdf_image_close,
- gx_default_gray_map_rgb_color,
- gx_default_gray_map_color_rgb,
- pdf_image_get_params_downscale,
- pdf_image_put_params_downscale);
+static void
+pdfimage8_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray(dev);
+
+ set_dev_proc(dev, open_device, pdf_image_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page);
+ set_dev_proc(dev, close_device, pdf_image_close);
+ set_dev_proc(dev, get_params, pdf_image_get_params_downscale);
+ set_dev_proc(dev, put_params, pdf_image_put_params_downscale);
+ set_dev_proc(dev, encode_color, gx_default_8bit_map_gray_color);
+ set_dev_proc(dev, decode_color, gx_default_8bit_map_color_gray);
+}
const gx_device_pdf_image gs_pdfimage8_device = {
prn_device_body(gx_device_pdf_image,
- pdfimage8_procs,
+ pdfimage8_initialize_device_procs,
"pdfimage8",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
600, 600, /* 600 dpi by default */
@@ -86,19 +90,21 @@ const gx_device_pdf_image gs_pdfimage8_device = {
};
/* ------ The pdfimage24 device ------ */
+static void
+pdfimage24_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_rgb(dev);
-static const gx_device_procs pdfimage24_procs =
-prn_color_params_procs(pdf_image_open,
- gdev_prn_output_page_seekable,
- pdf_image_close,
- gx_default_rgb_map_rgb_color,
- gx_default_rgb_map_color_rgb,
- pdf_image_get_params_downscale,
- pdf_image_put_params_downscale);
+ set_dev_proc(dev, open_device, pdf_image_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page);
+ set_dev_proc(dev, close_device, pdf_image_close);
+ set_dev_proc(dev, get_params, pdf_image_get_params_downscale);
+ set_dev_proc(dev, put_params, pdf_image_put_params_downscale);
+}
const gx_device_pdf_image gs_pdfimage24_device = {
prn_device_body(gx_device_pdf_image,
- pdfimage24_procs,
+ pdfimage24_initialize_device_procs,
"pdfimage24",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
600, 600, /* 600 dpi by default */
@@ -115,17 +121,21 @@ const gx_device_pdf_image gs_pdfimage24_device = {
};
/* ------ The pdfimage32 device ------ */
+static void
+pdfimage32_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_cmyk8(dev);
-static const gx_device_procs pdfimage32_procs = {
- pdf_image_open, NULL, NULL, gdev_prn_output_page_seekable, pdf_image_close,
- NULL, cmyk_8bit_map_color_cmyk, NULL, NULL, NULL, NULL, NULL, NULL,
- pdf_image_get_params_downscale_cmyk, pdf_image_put_params_downscale_cmyk,
- cmyk_8bit_map_cmyk_color, NULL, NULL, NULL, gx_page_device_get_page_device
-};
+ set_dev_proc(dev, open_device, pdf_image_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page);
+ set_dev_proc(dev, close_device, pdf_image_close);
+ set_dev_proc(dev, get_params, pdf_image_get_params_downscale_cmyk);
+ set_dev_proc(dev, put_params, pdf_image_put_params_downscale_cmyk);
+}
const gx_device_pdf_image gs_pdfimage32_device = {
prn_device_body(gx_device_pdf_image,
- pdfimage32_procs,
+ pdfimage32_initialize_device_procs,
"pdfimage32",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
600, 600, /* 600 dpi by default */
@@ -280,10 +290,11 @@ static int gdev_pdf_image_begin_page(gx_device_pdf_image *pdf_dev,
current = current->next;
current->next = page;
}
- page->ImageObjectNumber = (pdf_dev->NumPages * 4) + PDFIMG_STATIC_OBJS + pdf_dev->ocr.file_objects;
+ page->ImageObjectNumber = (pdf_dev->NumPages * PDFIMG_OBJS_PER_PAGE) + PDFIMG_STATIC_OBJS + pdf_dev->ocr.file_objects;
page->LengthObjectNumber = page->ImageObjectNumber + 1;
page->PageStreamObjectNumber = page->LengthObjectNumber + 1;
page->PageDictObjectNumber = page->PageStreamObjectNumber + 1;
+ page->PageLengthObjectNumber = page->PageDictObjectNumber + 1;
page->ImageOffset = stell(pdf_dev->strm);
pdf_dev->StripHeight = pdf_dev->height;
@@ -436,6 +447,7 @@ pdf_image_downscale_and_print_page(gx_device_printer *dev,
pdfimage_page *page = pdf_dev->Pages;
char Buffer[1024];
stream *s = pdf_dev->strm;
+ gs_offset_t len;
if (page == NULL)
return_error(gs_error_undefined);
@@ -568,7 +580,7 @@ pdf_image_downscale_and_print_page(gx_device_printer *dev,
page->PageStreamOffset = stell(pdf_dev->strm);
pprintd1(pdf_dev->strm, "%d 0 obj\n", page->PageStreamObjectNumber);
- stream_puts(pdf_dev->strm, "<<\n/Filter/FlateDecode/Length \n>>\nstream\n");
+ pprintd1(pdf_dev->strm, "<<\n/Filter/FlateDecode/Length %d 0 R\n>>\nstream\n", page->PageLengthObjectNumber);
stream_pos = stell(pdf_dev->strm);
encode((gx_device *)pdf_dev, &pdf_dev->strm, &s_zlibE_template, pdf_dev->memory->non_gc_memory);
if (pdf_dev->ocr.end_page)
@@ -581,15 +593,12 @@ pdf_image_downscale_and_print_page(gx_device_printer *dev,
pdf_dev->ocr.end_page(pdf_dev);
}
s_close_filters(&pdf_dev->strm, s);
- {
- gs_offset_t pos = stell(pdf_dev->strm);
- gs_offset_t len = pos - stream_pos;
- sseek(pdf_dev->strm, stream_pos - 21);
- pprintd1(pdf_dev->strm, "%d", (int)len);
- sseek(pdf_dev->strm, pos);
- }
+ len = stell(pdf_dev->strm) - stream_pos;
stream_puts(pdf_dev->strm, "\nendstream\nendobj\n");
+ page->PageLengthOffset = stell(pdf_dev->strm);
+ pprintd2(pdf_dev->strm, "%d 0 obj\n%d\nendobj\n", page->PageLengthObjectNumber, len);
+
page->PageDictOffset = stell(pdf_dev->strm);
pprintd1(pdf_dev->strm, "%d 0 obj\n", page->PageDictObjectNumber);
pprintd1(pdf_dev->strm, "<<\n/Contents %d 0 R\n", page->PageStreamObjectNumber);
@@ -766,7 +775,7 @@ static int pdf_image_finish_file(gx_device_pdf_image *pdf_dev, int PCLm)
if (PCLm)
pprintd1(pdf_dev->strm, "xref\n0 %d\n0000000000 65536 f \n", pdf_dev->NextObject);
else
- pprintd1(pdf_dev->strm, "xref\n0 %d\n0000000000 65536 f \n", (pdf_dev->NumPages * 4) + PDFIMG_STATIC_OBJS + pdf_dev->ocr.file_objects);
+ pprintd1(pdf_dev->strm, "xref\n0 %d\n0000000000 65536 f \n", (pdf_dev->NumPages * PDFIMG_OBJS_PER_PAGE) + PDFIMG_STATIC_OBJS + pdf_dev->ocr.file_objects);
write_xref_entry(pdf_dev->strm, pdf_dev->RootOffset);
write_xref_entry(pdf_dev->strm, pdf_dev->PagesOffset);
write_xref_entry(pdf_dev->strm, pdf_dev->InfoOffset);
@@ -785,9 +794,10 @@ static int pdf_image_finish_file(gx_device_pdf_image *pdf_dev, int PCLm)
write_xref_entry(pdf_dev->strm, page->LengthOffset);
write_xref_entry(pdf_dev->strm, page->PageStreamOffset);
write_xref_entry(pdf_dev->strm, page->PageDictOffset);
+ write_xref_entry(pdf_dev->strm, page->PageLengthOffset);
page = page->next;
}
- pprintd1(pdf_dev->strm, "trailer\n<<\n/Size %d\n/Root 1 0 R\n/ID [", (pdf_dev->NumPages * 4) + PDFIMG_STATIC_OBJS + pdf_dev->ocr.file_objects);
+ pprintd1(pdf_dev->strm, "trailer\n<<\n/Size %d\n/Root 1 0 R\n/ID [", (pdf_dev->NumPages * PDFIMG_OBJS_PER_PAGE) + PDFIMG_STATIC_OBJS + pdf_dev->ocr.file_objects);
pdf_compute_fileID(pdf_dev, fileID, CreationDate, Title, Producer);
write_fileID(pdf_dev->strm, (const byte *)&fileID, 16);
write_fileID(pdf_dev->strm, (const byte *)&fileID, 16);
@@ -888,7 +898,7 @@ pdf_image_print_page(gx_device_printer * pdev, gp_file * file)
int
pdf_image_open(gx_device *pdev)
{
- gx_device_pdf_image *ppdev = (gx_device_pdf_image *)pdev;
+ gx_device_pdf_image *ppdev;
int code;
bool update_procs = false;
@@ -899,6 +909,7 @@ pdf_image_open(gx_device *pdev)
while(pdev->child)
pdev = pdev->child;
+ ppdev = (gx_device_pdf_image *)pdev;
ppdev->file = NULL;
ppdev->Pages = NULL;
ppdev->NumPages = 0;
@@ -918,7 +929,7 @@ pdf_image_open(gx_device *pdev)
gx_copy_device_procs(pdev->parent, pdev, &gs_flp_device);
}
if (ppdev->OpenOutputFile)
- code = gdev_prn_open_printer_seekable(pdev, 1, true);
+ code = gdev_prn_open_printer(pdev, 1);
return code;
}
@@ -973,6 +984,12 @@ pdf_image_get_some_params(gx_device * dev, gs_param_list * plist, int which)
if (ecode < 0)
return ecode;
+ ecode = param_write_bool(plist, "Tumble", &pdf_dev->Tumble);
+ if (ecode < 0)
+ return ecode;
+ ecode = param_write_bool(plist, "Tumble2", &pdf_dev->Tumble2);
+ if (ecode < 0)
+ return ecode;
ecode = param_write_int(plist, "StripHeight", &pdf_dev->StripHeight);
if (ecode < 0)
return ecode;
@@ -1024,6 +1041,18 @@ pdf_image_put_some_params(gx_device * dev, gs_param_list * plist, int which)
gs_param_string comprstr;
const char *param_name;
+ code = param_read_bool(plist, param_name = "Tumble", &pdf_dev->Tumble);
+ if (code < 0) {
+ errprintf(pdf_dev->memory, "Invalid Tumble setting\n");
+ param_signal_error(plist, param_name, ecode);
+ return code;
+ }
+ code = param_read_bool(plist, param_name = "Tumble2", &pdf_dev->Tumble2);
+ if (code < 0) {
+ errprintf(pdf_dev->memory, "Invalid Tumble2 setting\n");
+ param_signal_error(plist, param_name, ecode);
+ return code;
+ }
code = param_read_int(plist, param_name = "StripHeight", &pdf_dev->StripHeight);
if (code < 0) {
errprintf(pdf_dev->memory, "Invalid StripHeight setting\n");
@@ -1098,31 +1127,69 @@ pdf_image_put_params_downscale_cmyk_ets(gx_device * dev, gs_param_list * plist)
return pdf_image_put_some_params(dev, plist, 7);
}
+void
+PCLm_get_initial_matrix(gx_device * dev, register gs_matrix * pmat)
+{
+ gx_device_pdf_image *pdev = (gx_device_pdf_image *)dev;
+
+ gx_default_get_initial_matrix(dev, pmat);
+
+ if (pdev->Duplex && (pdev->NumPages & 1)) {
+ /* Duplexing and we are on the back of the page. */
+ if (pdev->Tumble) {
+ if (pdev->Tumble2) {
+ /* Rotate by 180 degrees and flip on X. */
+ pmat->xx = pmat->xx;
+ pmat->xy = -pmat->xy;
+ pmat->yx = -pmat->yx;
+ pmat->yy = -pmat->yy;
+ pmat->ty = pdev->height - pmat->ty;
+ } else {
+ /* Rotate by 180 degrees */
+ pmat->xx = -pmat->xx;
+ pmat->xy = -pmat->xy;
+ pmat->yx = -pmat->yx;
+ pmat->yy = -pmat->yy;
+ pmat->tx = pdev->width - pmat->tx;
+ pmat->ty = pdev->height - pmat->ty;
+ }
+ } else if (pdev->Tumble2) {
+ /* Flip on X */
+ pmat->xx = -pmat->xx;
+ pmat->yx = -pmat->yx;
+ pmat->tx = pdev->width - pmat->tx;
+ }
+ }
+}
+
/* ------ The PCLm device ------ */
+static void
+PCLm_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_rgb(dev);
+
+ set_dev_proc(dev, open_device, PCLm_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page);
+ set_dev_proc(dev, get_initial_matrix, PCLm_get_initial_matrix);
+ set_dev_proc(dev, close_device, PCLm_close);
+ set_dev_proc(dev, get_params, pdf_image_get_params_downscale);
+ set_dev_proc(dev, put_params, pdf_image_put_params_downscale);
+}
static dev_proc_print_page(PCLm_print_page);
-static const gx_device_procs PCLm_procs =
-prn_color_params_procs(PCLm_open,
- gdev_prn_output_page_seekable,
- PCLm_close,
- gx_default_rgb_map_rgb_color,
- gx_default_rgb_map_color_rgb,
- pdf_image_get_params_downscale,
- pdf_image_put_params_downscale);
-
const gx_device_pdf_image gs_PCLm_device = {
- prn_device_body(gx_device_pdf_image,
- PCLm_procs,
- "pclm",
- DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
- 600, 600, /* 600 dpi by default */
- 0, 0, 0, 0, /* Margins */
- 3, /* num components */
- 24, /* bits per sample */
- 255, 255, 256, 256,
- PCLm_print_page),
- 3,
+ prn_device_body_duplex(gx_device_pdf_image,
+ PCLm_initialize_device_procs,
+ "pclm",
+ DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
+ 600, 600, /* 600 dpi by default */
+ 0, 0, 0, 0, /* Margins */
+ 3, /* num components */
+ 24, /* bits per sample */
+ 255, 255, 256, 256,
+ PCLm_print_page),
+ 3,
GX_DOWNSCALER_PARAMS_DEFAULTS,
16, /* StripHeight */
0.0, /* QFactor */
@@ -1210,7 +1277,7 @@ PCLm_open_temp_stream(gx_device_pdf_image *pdev, PCLm_temp_file_t *ptf)
int
PCLm_open(gx_device *pdev)
{
- gx_device_pdf_image *ppdev = (gx_device_pdf_image *)pdev;
+ gx_device_pdf_image *ppdev;
int code;
bool update_procs = false;
@@ -1221,6 +1288,7 @@ PCLm_open(gx_device *pdev)
while(pdev->child)
pdev = pdev->child;
+ ppdev = (gx_device_pdf_image *)pdev;
memset(&ppdev->ocr, 0, sizeof(ppdev->ocr));
ppdev->file = NULL;
ppdev->Pages = NULL;
@@ -1241,7 +1309,7 @@ PCLm_open(gx_device *pdev)
gx_copy_device_procs(pdev->parent, pdev, &gs_flp_device);
}
if (ppdev->OpenOutputFile)
- code = gdev_prn_open_printer_seekable(pdev, 1, true);
+ code = gdev_prn_open_printer(pdev, 1);
if(code < 0)
return code;
@@ -1329,7 +1397,7 @@ static int gdev_PCLm_begin_page(gx_device_pdf_image *pdf_dev,
stream_puts(pdf_dev->strm, "%PDF-1.3\n");
stream_puts(pdf_dev->strm, "%PCLm 1.0\n");
pdf_dev->Pages = page;
- pdf_dev->NextObject = 3;
+ pdf_dev->NextObject = 4;
} else {
pdfimage_page *current = pdf_dev->Pages;
while(current->next)
diff --git a/devices/gdevpdfimg.h b/devices/gdevpdfimg.h
index 322c1622..9201fa2c 100644
--- a/devices/gdevpdfimg.h
+++ b/devices/gdevpdfimg.h
@@ -25,6 +25,11 @@
*/
#define PDFIMG_STATIC_OBJS 4
#define OCR_MAX_FILE_OBJECTS 8
+/* This is the number of objects per page: 1: the image object,
+ * 2: the length object for the image object, 3: the page stream
+ * object. 4: the page dict object, 5: the length object for
+ * the page stream object. */
+#define PDFIMG_OBJS_PER_PAGE 5
typedef struct pdfimage_page_s {
int ImageObjectNumber;
@@ -35,6 +40,8 @@ typedef struct pdfimage_page_s {
gs_offset_t PageStreamOffset;
int PageDictObjectNumber;
gs_offset_t PageDictOffset;
+ int PageLengthObjectNumber;
+ gs_offset_t PageLengthOffset;
void *next;
} pdfimage_page;
@@ -67,6 +74,9 @@ typedef struct gx_device_pdf_image_s {
PCLm_temp_file_t temp_stream;
int NextObject;
+ int Tumble;
+ int Tumble2;
+
/* OCR data */
struct {
char language[1024];
diff --git a/devices/gdevpdfocr.c b/devices/gdevpdfocr.c
index afc73ff2..8dd5a599 100644
--- a/devices/gdevpdfocr.c
+++ b/devices/gdevpdfocr.c
@@ -142,19 +142,23 @@ pdfocr_get_params_downscale(gx_device * dev, gs_param_list * plist)
}
/* ------ The pdfocr8 device ------ */
-
-static const gx_device_procs pdfocr8_procs =
-prn_color_params_procs(pdf_ocr_open,
- gdev_prn_output_page_seekable,
- pdf_ocr_close,
- gx_default_gray_map_rgb_color,
- gx_default_gray_map_color_rgb,
- pdfocr_get_params_downscale,
- pdfocr_put_params_downscale);
+static void
+pdfocr8_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray(dev);
+
+ set_dev_proc(dev, open_device, pdf_ocr_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page_seekable);
+ set_dev_proc(dev, close_device, pdf_ocr_close);
+ set_dev_proc(dev, get_params, pdfocr_get_params_downscale);
+ set_dev_proc(dev, put_params, pdfocr_put_params_downscale);
+ set_dev_proc(dev, encode_color, gx_default_8bit_map_gray_color);
+ set_dev_proc(dev, decode_color, gx_default_8bit_map_color_gray);
+}
const gx_device_pdf_image gs_pdfocr8_device = {
prn_device_body(gx_device_pdf_image,
- pdfocr8_procs,
+ pdfocr8_initialize_device_procs,
"pdfocr8",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
600, 600, /* 600 dpi by default */
@@ -171,19 +175,21 @@ const gx_device_pdf_image gs_pdfocr8_device = {
};
/* ------ The pdfocr24 device ------ */
+static void
+pdfocr24_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_rgb(dev);
-static const gx_device_procs pdfocr24_procs =
-prn_color_params_procs(pdf_ocr_open,
- gdev_prn_output_page_seekable,
- pdf_ocr_close,
- gx_default_rgb_map_rgb_color,
- gx_default_rgb_map_color_rgb,
- pdfocr_get_params_downscale,
- pdfocr_put_params_downscale);
+ set_dev_proc(dev, open_device, pdf_ocr_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page_seekable);
+ set_dev_proc(dev, close_device, pdf_ocr_close);
+ set_dev_proc(dev, get_params, pdfocr_get_params_downscale);
+ set_dev_proc(dev, put_params, pdfocr_put_params_downscale);
+}
const gx_device_pdf_image gs_pdfocr24_device = {
prn_device_body(gx_device_pdf_image,
- pdfocr24_procs,
+ pdfocr24_initialize_device_procs,
"pdfocr24",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
600, 600, /* 600 dpi by default */
@@ -200,17 +206,23 @@ const gx_device_pdf_image gs_pdfocr24_device = {
};
/* ------ The pdfocr32 device ------ */
-
-static const gx_device_procs pdfocr32_procs = {
- pdf_ocr_open, NULL, NULL, gdev_prn_output_page_seekable, pdf_ocr_close,
- NULL, cmyk_8bit_map_color_cmyk, NULL, NULL, NULL, NULL, NULL, NULL,
- pdfocr_get_params_downscale_cmyk, pdfocr_put_params_downscale_cmyk,
- cmyk_8bit_map_cmyk_color, NULL, NULL, NULL, gx_page_device_get_page_device
-};
+static void
+pdfocr32_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_cmyk8(dev);
+
+ set_dev_proc(dev, open_device, pdf_ocr_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page_seekable);
+ set_dev_proc(dev, close_device, pdf_ocr_close);
+ set_dev_proc(dev, get_params, pdfocr_get_params_downscale_cmyk);
+ set_dev_proc(dev, put_params, pdfocr_put_params_downscale_cmyk);
+ set_dev_proc(dev, decode_color, cmyk_8bit_map_color_cmyk);
+ set_dev_proc(dev, encode_color, cmyk_8bit_map_cmyk_color);
+}
const gx_device_pdf_image gs_pdfocr32_device = {
prn_device_body(gx_device_pdf_image,
- pdfocr32_procs,
+ pdfocr32_initialize_device_procs,
"pdfocr32",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
600, 600, /* 600 dpi by default */
diff --git a/devices/gdevpe.c b/devices/gdevpe.c
index b4d462f3..228408b4 100644
--- a/devices/gdevpe.c
+++ b/devices/gdevpe.c
@@ -50,22 +50,17 @@ dev_proc_close_device(pe_close);
dev_proc_fill_rectangle(pe_fill_rectangle);
dev_proc_copy_mono(pe_copy_mono);
-static gx_device_procs pe_procs =
-{ pe_open,
- NULL, /* get_initial_matrix */
- NULL, /* sync_output */
- NULL, /* output_page */
- pe_close,
- NULL, /* map_rgb_color */
- NULL, /* map_color_rgb */
- pe_fill_rectangle,
- NULL, /* tile_rectangle */
- pe_copy_mono,
- NULL /* copy_color */
-};
+static void
+pe_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, pe_open);
+ set_dev_proc(dev, close_device, pe_close);
+ set_dev_proc(dev, fill_rectangle, pe_fill_rectangle);
+ set_dev_proc(dev, copy_mono, pe_copy_mono);
+}
gx_device_pe far_data gs_pe_device =
-{ std_device_std_body(gx_device_pe, &pe_procs, "pe",
+{ std_device_std_body(gx_device_pe, pe_initialize_device_procs, "pe",
XSIZE, YSIZE, XPPI, YPPI),
{ 0 }, /* std_procs */
DEFAULT_ADDRESS, DEFAULT_REGISTERS
diff --git a/devices/gdevperm.c b/devices/gdevperm.c
index 80afdf48..56ef5cb5 100644
--- a/devices/gdevperm.c
+++ b/devices/gdevperm.c
@@ -57,66 +57,22 @@ struct gx_device_perm_s {
};
typedef struct gx_device_perm_s gx_device_perm_t;
-static const gx_device_procs perm_procs = {
- gdev_prn_open,
- NULL,
-/* Since the print_page doesn't alter the device, this device can print in the background */
- NULL,
- gdev_prn_bg_output_page,
- gdev_prn_close,
- NULL,
- NULL,
- NULL, /* fill_rectangle */
- NULL, /* tile_rectangle */
- NULL, /* copy_mono */
- NULL, /* copy_color */
- NULL, /* draw_line */
- NULL, /* get_bits */
- perm_get_params, /* get_params */
- perm_put_params, /* put_params */
- NULL, /* map_cmyk_color - not used */
- NULL, /* get_xfont_procs */
- NULL, /* get_xfont_device */
- NULL, /* map_rgb_alpha_color */
- gx_page_device_get_page_device, /* get_page_device */
- NULL, /* get_alpha_bits */
- NULL, /* copy_alpha */
- NULL, /* get_band */
- NULL, /* copy_rop */
- NULL, /* fill_path */
- NULL, /* stroke_path */
- NULL, /* fill_mask */
- NULL, /* fill_trapezoid */
- NULL, /* fill_parallelogram */
- NULL, /* fill_triangle */
- NULL, /* draw_thin_line */
- NULL, /* begin_image */
- NULL, /* image_data */
- NULL, /* end_image */
- NULL, /* strip_tile_rectangle */
- NULL, /* strip_copy_rop */
- NULL, /* get_clipping_box */
- NULL, /* begin_typed_image */
- NULL, /* get_bits_rectangle */
- NULL, /* map_color_rgb_alpha */
- NULL, /* create_compositor */
- NULL, /* get_hardware_params */
- NULL, /* text_begin */
- NULL, /* finish_copydevice */
- NULL, /* begin_transparency_group */
- NULL, /* end_transparency_group */
- NULL, /* begin_transparency_mask */
- NULL, /* end_transparency_mask */
- NULL, /* discard_transparency_layer */
- perm_get_color_mapping_procs, /* get_color_mapping_procs */
- perm_get_color_comp_index,
- perm_encode_color, /* encode_color */
- perm_decode_color /* decode_color */
-
-};
+static void
+perm_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, get_params, perm_get_params);
+ set_dev_proc(dev, put_params, perm_put_params);
+ set_dev_proc(dev, get_color_mapping_procs, perm_get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, perm_get_color_comp_index);
+ set_dev_proc(dev, encode_color, perm_encode_color);
+ set_dev_proc(dev, decode_color, perm_decode_color);
+}
const gx_device_perm_t gs_perm_device = {
- prn_device_body_extended(gx_device_perm_t, perm_procs, "permute",
+ prn_device_body_extended(gx_device_perm_t,
+ perm_initialize_device_procs, "permute",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS, 72, 72,
0, 0, 0, 0,
GX_DEVICE_COLOR_MAX_COMPONENTS, 4,
diff --git a/devices/gdevphex.c b/devices/gdevphex.c
index 7afc6ba3..2c832da6 100644
--- a/devices/gdevphex.c
+++ b/devices/gdevphex.c
@@ -1007,19 +1007,19 @@ static const HFUNCS htable[ MAXHTONE ] = {
* The definition is based on GS macros, the only real stuff that we
* define here are the photoex_ functions.
*/
-static const gx_device_procs photoex_device_procs = prn_color_params_procs_enc_dec(
-
- photoex_open, /* Opens the device */
-/* Since the print_page doesn't alter the device, this device can print in the background */
- gdev_prn_bg_output_page,
- gdev_prn_close,
- photoex_map_rgb_color, /* Maps an RGB pixel to device colour */
- photoex_map_color_rgb, /* Maps device colour back to RGB */
- photoex_get_params, /* Gets device parameters */
- photoex_put_params, /* Puts device parameters */
- photoex_encode_color,
- photoex_decode_color
-);
+static void
+photoex_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, open_device, photoex_open);
+ set_dev_proc(dev, map_rgb_color, photoex_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, photoex_map_color_rgb);
+ set_dev_proc(dev, get_params, photoex_get_params);
+ set_dev_proc(dev, put_params, photoex_put_params);
+ set_dev_proc(dev, encode_color, photoex_encode_color);
+ set_dev_proc(dev, decode_color, photoex_decode_color);
+}
/*
* Device descriptor structure - this is what GhostScript looks
@@ -1034,7 +1034,7 @@ gx_photoex_device far_data gs_photoex_device = {
prn_device_body(
gx_photoex_device, /* Device struct type */
- photoex_device_procs, /* Procedure table */
+ photoex_initialize_device_procs, /* Initialize proc */
"photoex", /* Name of the device */
DEFAULT_WIDTH_10THS, /* Default width */
DEFAULT_HEIGHT_10THS, /* Default height */
diff --git a/devices/gdevpjet.c b/devices/gdevpjet.c
index 8df438f5..ea6576c0 100644
--- a/devices/gdevpjet.c
+++ b/devices/gdevpjet.c
@@ -30,29 +30,38 @@ static dev_proc_print_page(paintjet_print_page);
static dev_proc_print_page(pjetxl_print_page);
static int pj_common_print_page(gx_device_printer *, gp_file *, int, const char *);
/* Since the print_page doesn't alter the device, this device can print in the background */
-static gx_device_procs paintjet_procs =
- prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- gdev_pcl_3bit_map_rgb_color, gdev_pcl_3bit_map_color_rgb);
+static void
+paintjet_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, map_rgb_color, gdev_pcl_3bit_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gdev_pcl_3bit_map_color_rgb);
+
+ /* The prn macros used in previous versions of the code leave
+ * encode_color and decode_color set to NULL (which are then rewritten
+ * by the system to the default. For compatibility we do the same. */
+ set_dev_proc(dev, encode_color, gdev_pcl_3bit_map_rgb_color);
+ set_dev_proc(dev, decode_color, gdev_pcl_3bit_map_color_rgb);
+}
+
const gx_device_printer far_data gs_lj250_device =
- prn_device(paintjet_procs, "lj250",
+ prn_device(paintjet_initialize_device_procs, "lj250",
85, /* width_10ths, 8.5" */
110, /* height_10ths, 11" */
X_DPI, Y_DPI,
0.25, 0, 0.25, 0, /* margins */
3, lj250_print_page);
const gx_device_printer far_data gs_paintjet_device =
- prn_device(paintjet_procs, "paintjet",
+ prn_device(paintjet_initialize_device_procs, "paintjet",
85, /* width_10ths, 8.5" */
110, /* height_10ths, 11" */
X_DPI, Y_DPI,
0.25, 0, 0.25, 0, /* margins */
3, paintjet_print_page);
-/* Since the print_page doesn't alter the device, this device can print in the background */
-static gx_device_procs pjetxl_procs =
- prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- gdev_pcl_3bit_map_rgb_color, gdev_pcl_3bit_map_color_rgb);
+
const gx_device_printer far_data gs_pjetxl_device =
- prn_device(pjetxl_procs, "pjetxl",
+ prn_device(paintjet_initialize_device_procs, "pjetxl",
85, /* width_10ths, 8.5" */
110, /* height_10ths, 11" */
X_DPI, Y_DPI,
diff --git a/devices/gdevplan.c b/devices/gdevplan.c
index bf9a81e5..0ce82cda 100644
--- a/devices/gdevplan.c
+++ b/devices/gdevplan.c
@@ -77,93 +77,79 @@ static int planr_print_page(gx_device_printer * pdev, gp_file * pstream);
/* The device procedures */
-/* See gdevprn.h for the template for the following. */
-#define pgpm_procs(p_color_rgb, encode_color, decode_color) {\
- plan_open,\
- NULL, /* get_initial_matrix */ \
- NULL, /* sync output */ \
- /* Since the print_page doesn't alter the device, this device can print in the background */\
- gdev_prn_bg_output_page, \
- plan_close,\
- NULL, /* map_rgb_color */ \
- p_color_rgb, /* map_color_rgb */ \
- NULL, /* fill_rectangle */ \
- NULL, /* tile_rectangle */ \
- NULL, /* copy_mono */ \
- NULL, /* copy_color */ \
- NULL, /* draw_line */ \
- NULL, /* get_bits */ \
- gdev_prn_get_params, \
- gdev_prn_put_params,\
- NULL, /* map_cmyk_color */ \
- NULL, /* get_xfont_procs */ \
- NULL, /* get_xfont_device */ \
- NULL, /* map_rgb_alpha_color */ \
- gx_page_device_get_page_device, \
- NULL, /* get_alpha_bits */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- NULL, /* fill_path */\
- NULL, /* stroke_path */\
- NULL, /* fill_mask */\
- NULL, /* fill_trapezoid */\
- NULL, /* fill_parallelogram */\
- NULL, /* fill_triangle */\
- NULL, /* draw_thin_line */\
- NULL, /* begin_image */\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL, /* strip_copy_rop */\
- NULL, /* get_clipping_box */\
- NULL, /* begin_typed_image */\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- NULL, /* create_compositor */\
- NULL, /* get_hardware_params */\
- NULL, /* text_begin */\
- NULL, /* finish_copydevice */\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL, /* discard_transparency_layer */\
- NULL, /* get_color_mapping_procs */\
- NULL, /* get_color_comp_index */\
- encode_color, /* encode_color */\
- decode_color, /* decode_color */\
- NULL, /* pattern_manage */\
- NULL, /* fill_rectangle_hl_color */\
- NULL, /* include_color_space */\
- NULL, /* fill_linear_color_scanline */\
- NULL, /* fill_linear_color_trapezoid */\
- NULL, /* fill_linear_color_triangle */\
- NULL, /* update spot */\
- NULL, /* DevN params */\
- NULL, /* fill page */\
- NULL, /* push_transparency_state */\
- NULL, /* pop_transparency_state */\
- NULL, /* put_image */\
- NULL /* dev_spec_op */\
+static void
+plan_base_initialize_device_procs(gx_device *dev,
+ dev_proc_map_color_rgb(map_color_rgb),
+ dev_proc_encode_color(encode_color),
+ dev_proc_decode_color(decode_color))
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, plan_open);
+ set_dev_proc(dev, close_device, plan_close);
+ set_dev_proc(dev, map_color_rgb, map_color_rgb);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
+ set_dev_proc(dev, encode_color, encode_color);
+ set_dev_proc(dev, decode_color, decode_color);
+}
+
+static void
+planm_initialize_device_procs(gx_device *dev)
+{
+ plan_base_initialize_device_procs(dev,
+ gdev_prn_map_color_rgb,
+ gdev_prn_map_rgb_color,
+ gdev_prn_map_color_rgb);
+}
+
+static void
+plang_initialize_device_procs(gx_device *dev)
+{
+ plan_base_initialize_device_procs(dev,
+ plang_decode_color,
+ plang_encode_color,
+ plang_decode_color);
+}
+
+static void
+plan_initialize_device_procs(gx_device *dev)
+{
+ plan_base_initialize_device_procs(dev,
+ plan_decode_color,
+ gx_default_rgb_map_rgb_color,
+ plan_decode_color);
}
-static const gx_device_procs planm_procs =
- pgpm_procs(gdev_prn_map_color_rgb, gdev_prn_map_rgb_color, gdev_prn_map_color_rgb);
-static const gx_device_procs plang_procs =
- pgpm_procs(plang_decode_color, plang_encode_color, plang_decode_color);
-static const gx_device_procs plan_procs =
- pgpm_procs(plan_decode_color, gx_default_rgb_map_rgb_color, plan_decode_color);
-static const gx_device_procs planc_procs =
- pgpm_procs(planc_map_color_rgb, planc_encode_color, planc_decode_color);
-static const gx_device_procs plank_procs =
- pgpm_procs(planc_map_color_rgb, planc_encode_color, planc_decode_color);
-static const gx_device_procs planr_procs =
- pgpm_procs(plan_decode_color, gx_default_rgb_map_rgb_color, plan_decode_color);
+static void
+planc_initialize_device_procs(gx_device *dev)
+{
+ plan_base_initialize_device_procs(dev,
+ planc_map_color_rgb,
+ planc_encode_color,
+ planc_decode_color);
+}
+
+static void
+plank_initialize_device_procs(gx_device *dev)
+{
+ plan_base_initialize_device_procs(dev,
+ planc_map_color_rgb,
+ planc_encode_color,
+ planc_decode_color);
+}
+
+static void
+planr_initialize_device_procs(gx_device *dev)
+{
+ plan_base_initialize_device_procs(dev,
+ plan_decode_color,
+ gx_default_rgb_map_rgb_color,
+ plan_decode_color);
+}
/* Macro for generating device descriptors. */
-#define plan_prn_device(procs, dev_name, num_comp, depth, max_gray, max_rgb, print_page) \
-{ prn_device_body(gx_device_printer, procs, dev_name,\
+#define plan_prn_device(init, dev_name, num_comp, depth, max_gray, max_rgb, print_page) \
+{ prn_device_body(gx_device_printer, init, dev_name,\
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS, X_DPI, Y_DPI,\
0, 0, 0, 0,\
num_comp, depth, max_gray, max_rgb, max_gray + 1, max_rgb + 1,\
@@ -172,17 +158,23 @@ static const gx_device_procs planr_procs =
/* The device descriptors themselves */
const gx_device_printer gs_plan_device =
- plan_prn_device(plan_procs, "plan", 3, 24, 255, 255, plan_print_page);
+ plan_prn_device(plan_initialize_device_procs, "plan",
+ 3, 24, 255, 255, plan_print_page);
const gx_device_printer gs_plang_device =
- plan_prn_device(plang_procs, "plang", 1, 8, 255, 0, plang_print_page);
+ plan_prn_device(plang_initialize_device_procs, "plang",
+ 1, 8, 255, 0, plang_print_page);
const gx_device_printer gs_planm_device =
- plan_prn_device(planm_procs, "planm", 1, 1, 1, 0, planm_print_page);
+ plan_prn_device(planm_initialize_device_procs, "planm",
+ 1, 1, 1, 0, planm_print_page);
const gx_device_printer gs_plank_device =
- plan_prn_device(plank_procs, "plank", 4, 4, 1, 1, plank_print_page);
+ plan_prn_device(plank_initialize_device_procs, "plank",
+ 4, 4, 1, 1, plank_print_page);
const gx_device_printer gs_planc_device =
- plan_prn_device(planc_procs, "planc", 4, 32, 255, 255, planc_print_page);
+ plan_prn_device(planc_initialize_device_procs, "planc",
+ 4, 32, 255, 255, planc_print_page);
const gx_device_printer gs_planr_device =
- plan_prn_device(planr_procs, "planr", 3, 3, 1, 1, planr_print_page);
+ plan_prn_device(planr_initialize_device_procs, "planr",
+ 3, 3, 1, 1, planr_print_page);
/* ------ Initialization ------ */
@@ -523,7 +515,7 @@ plan_print_page_loop(gx_device_printer * pdev, int log2bits, int numComps,
else
options |= GB_PACKING_PLANAR;
for (lnum = 0; lnum < pdev->height; lnum++) {
- gs_int_rect *unread, rect;
+ gs_int_rect rect;
gs_get_bits_params_t params;
rect.p.x = 0;
@@ -533,7 +525,7 @@ plan_print_page_loop(gx_device_printer * pdev, int log2bits, int numComps,
memset(&params, 0, sizeof(params));
params.options = options;
params.x_offset = 0;
- code = (*dev_proc(pdev, get_bits_rectangle))((gx_device *)pdev, &rect, &params,&unread);
+ code = (*dev_proc(pdev, get_bits_rectangle))((gx_device *)pdev, &rect, &params);
if (code < 0)
break;
#ifdef DEBUG_DUMP
diff --git a/devices/gdevplib.c b/devices/gdevplib.c
index f1bf6598..e4288717 100644
--- a/devices/gdevplib.c
+++ b/devices/gdevplib.c
@@ -267,87 +267,62 @@ static int plibk_print_page(gx_device_printer * pdev, gp_file * pstream);
/* The device procedures */
-/* See gdevprn.h for the template for the following. */
-#define pgpm_procs(p_color_rgb, p_encode_color, p_decode_color) {\
- plib_open,\
- NULL, /* get_initial_matrix */ \
- NULL, /* sync output */ \
- /* Since the print_page doesn't alter the device, this device can print in the background */\
- gdev_prn_bg_output_page, \
- plib_close,\
- NULL, /* map_rgb_color */ \
- p_color_rgb, /* map_color_rgb */ \
- NULL, /* fill_rectangle */ \
- NULL, /* tile_rectangle */ \
- NULL, /* copy_mono */ \
- NULL, /* copy_color */ \
- NULL, /* draw_line */ \
- NULL, /* get_bits */ \
- gdev_prn_get_params, \
- plib_put_params,\
- NULL, /* map_cmyk_color */ \
- NULL, /* get_xfont_procs */ \
- NULL, /* get_xfont_device */ \
- NULL, /* map_rgb_alpha_color */ \
- gx_page_device_get_page_device, \
- NULL, /* get_alpha_bits */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- NULL, /* fill_path */\
- NULL, /* stroke_path */\
- NULL, /* fill_mask */\
- NULL, /* fill_trapezoid */\
- NULL, /* fill_parallelogram */\
- NULL, /* fill_triangle */\
- NULL, /* draw_thin_line */\
- NULL, /* begin_image */\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL, /* strip_copy_rop */\
- NULL, /* get_clipping_box */\
- NULL, /* begin_typed_image */\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- NULL, /* create_compositor */\
- NULL, /* get_hardware_params */\
- NULL, /* text_begin */\
- NULL, /* finish_copydevice */\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL, /* discard_transparency_layer */\
- NULL, /* get_color_mapping_procs */\
- NULL, /* get_color_comp_index */\
- p_encode_color, /* encode_color */\
- p_decode_color, /* decode_color */\
- NULL, /* pattern_manage */\
- NULL, /* fill_rectangle_hl_color */\
- NULL, /* include_color_space */\
- NULL, /* fill_linear_color_scanline */\
- NULL, /* fill_linear_color_trapezoid */\
- NULL, /* fill_linear_color_triangle */\
- NULL, /* update spot */\
- NULL, /* DevN params */\
- NULL, /* fill page */\
- NULL, /* push_transparency_state */\
- NULL, /* pop_transparency_state */\
- NULL, /* put_image */\
- NULL /* dev_spec_op */\
-}
-
-static const gx_device_procs plibm_procs =
- pgpm_procs(NULL, gdev_prn_map_rgb_color, gdev_prn_map_color_rgb);
-static const gx_device_procs plibg_procs =
- pgpm_procs(NULL, plibg_encode_color, plibg_decode_color);
-static const gx_device_procs plib_procs =
- pgpm_procs(NULL, gx_default_rgb_map_rgb_color, plib_decode_color);
-static const gx_device_procs plibc_procs =
- pgpm_procs(plibc_map_color_rgb, plibc_encode_color, plibc_decode_color);
-static const gx_device_procs plibk_procs =
- pgpm_procs(plibc_map_color_rgb, plibc_encode_color, plibc_decode_color);
+static void
+plib_base_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, open_device, plib_open);
+ set_dev_proc(dev, close_device, plib_close);
+ set_dev_proc(dev, put_params, plib_put_params);
+}
+
+static void
+plibm_initialize_device_procs(gx_device *dev)
+{
+ plib_base_initialize_device_procs(dev);
+
+ set_dev_proc(dev, encode_color, gdev_prn_map_rgb_color);
+ set_dev_proc(dev, decode_color, gdev_prn_map_color_rgb);
+}
+
+static void
+plibg_initialize_device_procs(gx_device *dev)
+{
+ plib_base_initialize_device_procs(dev);
+
+ set_dev_proc(dev, encode_color, plibg_encode_color);
+ set_dev_proc(dev, decode_color, plibg_decode_color);
+}
+
+static void
+plib_initialize_device_procs(gx_device *dev)
+{
+ plib_base_initialize_device_procs(dev);
+
+ set_dev_proc(dev, encode_color, gx_default_rgb_map_rgb_color);
+ set_dev_proc(dev, decode_color, plib_decode_color);
+}
+
+static void
+plibc_initialize_device_procs(gx_device *dev)
+{
+ plib_base_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_color_rgb, plibc_map_color_rgb);
+ set_dev_proc(dev, encode_color, plibc_encode_color);
+ set_dev_proc(dev, decode_color, plibc_decode_color);
+}
+
+static void
+plibk_initialize_device_procs(gx_device *dev)
+{
+ plib_base_initialize_device_procs(dev);
+
+ set_dev_proc(dev, map_color_rgb, plibc_map_color_rgb);
+ set_dev_proc(dev, encode_color, plibc_encode_color);
+ set_dev_proc(dev, decode_color, plibc_decode_color);
+}
/* Macro for generating device descriptors. */
/* Ideally we'd use something like:
@@ -361,8 +336,8 @@ static const gx_device_procs plibk_procs =
* But that doesn't let us override the band space params. So we have to do
* it the large way.
*/
-#define plib_prn_device(procs, dev_name, num_comp, depth, max_gray, max_rgb, print_page) \
-{ std_device_full_body_type(gx_device_plib, &procs, dev_name, &st_device_printer,\
+#define plib_prn_device(init, dev_name, num_comp, depth, max_gray, max_rgb, print_page) \
+{ std_device_full_body_type(gx_device_plib, init, dev_name, &st_device_printer,\
(int)((float)(DEFAULT_WIDTH_10THS) * (X_DPI) / 10 + 0.5),\
(int)((float)(DEFAULT_HEIGHT_10THS) * (Y_DPI) / 10 + 0.5),\
X_DPI, Y_DPI,\
@@ -375,15 +350,20 @@ static const gx_device_procs plibk_procs =
/* The device descriptors themselves */
const gx_device_plib gs_plib_device =
- plib_prn_device(plib_procs, "plib", 3, 24, 255, 255, plib_print_page);
+ plib_prn_device(plib_initialize_device_procs, "plib",
+ 3, 24, 255, 255, plib_print_page);
const gx_device_plib gs_plibg_device =
- plib_prn_device(plibg_procs, "plibg", 1, 8, 255, 0, plibg_print_page);
+ plib_prn_device(plibg_initialize_device_procs, "plibg",
+ 1, 8, 255, 0, plibg_print_page);
const gx_device_plib gs_plibm_device =
- plib_prn_device(plibm_procs, "plibm", 1, 1, 1, 0, plibm_print_page);
+ plib_prn_device(plibm_initialize_device_procs, "plibm",
+ 1, 1, 1, 0, plibm_print_page);
const gx_device_plib gs_plibk_device =
- plib_prn_device(plibk_procs, "plibk", 4, 4, 1, 1, plibk_print_page);
+ plib_prn_device(plibk_initialize_device_procs, "plibk",
+ 4, 4, 1, 1, plibk_print_page);
const gx_device_plib gs_plibc_device =
- plib_prn_device(plibc_procs, "plibc", 4, 32, 255, 255, plibc_print_page);
+ plib_prn_device(plibc_initialize_device_procs, "plibc",
+ 4, 32, 255, 255, plibc_print_page);
/* ------ Initialization ------ */
@@ -621,7 +601,7 @@ plib_setup_buf_device(gx_device *bdev, byte *buffer, int bytes_per_line,
static int
plib_get_bits_rectangle_mem(gx_device *pdev, const gs_int_rect *prect,
- gs_get_bits_params_t *params, gs_int_rect **pprect)
+ gs_get_bits_params_t *params)
{
gx_device_memory *mdev = (gx_device_memory *)pdev;
int x = prect->p.x, y = prect->p.y, h = prect->q.y - y;
@@ -643,7 +623,7 @@ plib_get_bits_rectangle_mem(gx_device *pdev, const gs_int_rect *prect,
if (code >= 0)
return code;
}
- return mem_get_bits_rectangle(pdev, prect, params, pprect);
+ return mem_get_bits_rectangle(pdev, prect, params);
}
static int
@@ -891,7 +871,7 @@ plib_print_page_loop(gx_device_printer * pdev, int log2bits, int numComps,
dump_start(pdev->width, pdev->height, numComps, log2bits, pstream);
#endif
for (lnum = 0; lnum < pdev->height; lnum += bandHeight) {
- gs_int_rect *unread, rect;
+ gs_int_rect rect;
gs_get_bits_params_t params;
rect.p.x = 0;
@@ -909,7 +889,7 @@ plib_print_page_loop(gx_device_printer * pdev, int log2bits, int numComps,
GB_COLORS_NATIVE |
GB_ALPHA_NONE;
params.x_offset = 0;
- code = (*dev_proc(pdev, get_bits_rectangle))((gx_device *)pdev, &rect, &params,&unread);
+ code = (*dev_proc(pdev, get_bits_rectangle))((gx_device *)pdev, &rect, &params);
if (code < 0)
break;
#ifdef DEBUG_DUMP
diff --git a/devices/gdevpng.c b/devices/gdevpng.c
index 4833efb1..5d353a12 100644
--- a/devices/gdevpng.c
+++ b/devices/gdevpng.c
@@ -93,7 +93,7 @@ struct gx_device_png_s {
const gx_device_png gs_pngmono_device =
{ /* The print_page proc is compatible with allowing bg printing */
- prn_device_body(gx_device_png, prn_bg_procs, "pngmono",
+ prn_device_body(gx_device_png, gdev_prn_initialize_device_procs_mono_bg, "pngmono",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -105,11 +105,19 @@ const gx_device_png gs_pngmono_device =
/* 4-bit planar (EGA/VGA-style) color. */
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs png16_procs =
-prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- pc_4bit_map_rgb_color, pc_4bit_map_color_rgb);
+static void
+png16_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, map_rgb_color, pc_4bit_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, pc_4bit_map_color_rgb);
+ set_dev_proc(dev, encode_color, pc_4bit_map_rgb_color);
+ set_dev_proc(dev, decode_color, pc_4bit_map_color_rgb);
+}
+
const gx_device_png gs_png16_device = {
- prn_device_body(gx_device_png, png16_procs, "png16",
+ prn_device_body(gx_device_png, png16_initialize_device_procs, "png16",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -121,11 +129,19 @@ const gx_device_png gs_png16_device = {
/* (Uses a fixed palette of 3,3,2 bits.) */
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs png256_procs =
-prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- pc_8bit_map_rgb_color, pc_8bit_map_color_rgb);
+static void
+png256_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, map_rgb_color, pc_8bit_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, pc_8bit_map_color_rgb);
+ set_dev_proc(dev, encode_color, pc_8bit_map_rgb_color);
+ set_dev_proc(dev, decode_color, pc_8bit_map_color_rgb);
+}
+
const gx_device_png gs_png256_device = {
- prn_device_body(gx_device_png, png256_procs, "png256",
+ prn_device_body(gx_device_png, png256_initialize_device_procs, "png256",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -136,13 +152,19 @@ const gx_device_png gs_png256_device = {
/* 8-bit gray */
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs pnggray_procs =
-prn_color_params_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- gx_default_gray_map_rgb_color,
- gx_default_gray_map_color_rgb,
- png_get_params_downscale, png_put_params_downscale);
+static void
+pnggray_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray_bg(dev);
+
+ set_dev_proc(dev, get_params, png_get_params_downscale);
+ set_dev_proc(dev, put_params, png_put_params_downscale);
+ set_dev_proc(dev, encode_color, gx_default_8bit_map_gray_color);
+ set_dev_proc(dev, decode_color, gx_default_8bit_map_color_gray);
+}
+
const gx_device_png gs_pnggray_device =
-{prn_device_body(gx_device_png, pnggray_procs, "pnggray",
+{prn_device_body(gx_device_png, pnggray_initialize_device_procs, "pnggray",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -153,14 +175,19 @@ const gx_device_png gs_pnggray_device =
/* Monochrome (with error diffusion) */
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs pngmonod_procs =
-prn_color_params_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- gx_default_gray_map_rgb_color,
- gx_default_gray_map_color_rgb,
- png_get_params_downscale_mfs,
- png_put_params_downscale_mfs);
+static void
+pngmonod_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray_bg(dev);
+
+ set_dev_proc(dev, get_params, png_get_params_downscale_mfs);
+ set_dev_proc(dev, put_params, png_put_params_downscale_mfs);
+ set_dev_proc(dev, encode_color, gx_default_8bit_map_gray_color);
+ set_dev_proc(dev, decode_color, gx_default_8bit_map_color_gray);
+}
+
const gx_device_png gs_pngmonod_device =
-{prn_device_body(gx_device_png, pngmonod_procs, "pngmonod",
+{prn_device_body(gx_device_png, pngmonod_initialize_device_procs, "pngmonod",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -171,13 +198,23 @@ const gx_device_png gs_pngmonod_device =
/* 24-bit color. */
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs png16m_procs =
-prn_color_params_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- gx_default_rgb_map_rgb_color,
- gx_default_rgb_map_color_rgb,
- png_get_params_downscale, png_put_params_downscale);
+static void
+png16m_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_rgb_bg(dev);
+
+ set_dev_proc(dev, get_params, png_get_params_downscale);
+ set_dev_proc(dev, put_params, png_put_params_downscale);
+
+ /* The prn macros used in previous versions of the code leave
+ * encode_color and decode_color set to NULL (which are then rewritten
+ * by the system to the default. For compatibility we do the same. */
+ set_dev_proc(dev, encode_color, gx_default_rgb_map_rgb_color);
+ set_dev_proc(dev, decode_color, gx_default_rgb_map_color_rgb);
+}
+
const gx_device_png gs_png16m_device =
-{prn_device_body(gx_device_png, png16m_procs, "png16m",
+{prn_device_body(gx_device_png, png16m_initialize_device_procs, "png16m",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -187,12 +224,21 @@ const gx_device_png gs_png16m_device =
/* 48 bit color. */
+static void
+png48_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_rgb_bg(dev);
+
+ /* The prn macros used in previous versions of the code leave
+ * encode_color and decode_color set to NULL (which are then rewritten
+ * by the system to the default. For compatibility we do the same. */
+ set_dev_proc(dev, encode_color, gx_default_rgb_map_rgb_color);
+ set_dev_proc(dev, decode_color, gx_default_rgb_map_color_rgb);
+}
+
/* Since the print_page doesn't alter the device, this device can print in the background */
-static const gx_device_procs png48_procs =
-prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb);
const gx_device_png gs_png48_device =
-{prn_device_body(gx_device_png, png48_procs, "png48",
+{prn_device_body(gx_device_png, png48_initialize_device_procs, "png48",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -215,79 +261,30 @@ struct gx_device_pngalpha_s {
gx_downscaler_params downscale;
int background;
};
-static const gx_device_procs pngalpha_procs =
+
+static void
+pngalpha_initialize_device_procs(gx_device *dev)
{
- pngalpha_open,
- NULL, /* get_initial_matrix */
- NULL, /* sync_output */
- /* Since the print_page doesn't alter the device, this device can print in the background */
- gdev_prn_bg_output_page,
- gdev_prn_close,
- pngalpha_encode_color, /* map_rgb_color */
- pngalpha_decode_color, /* map_color_rgb */
- NULL, /* fill_rectangle */
- NULL, /* tile_rectangle */
- NULL, /* copy_mono */
- NULL, /* copy_color */
- NULL, /* draw_line */
- NULL, /* get_bits */
- pngalpha_get_params,
- pngalpha_put_params,
- NULL, /* map_cmyk_color */
- NULL, /* get_xfont_procs */
- NULL, /* get_xfont_device */
- NULL, /* map_rgb_alpha_color */
- gx_page_device_get_page_device,
- NULL, /* get_alpha_bits */
- pngalpha_copy_alpha,
- NULL, /* get_band */
- NULL, /* copy_rop */
- NULL, /* fill_path */
- NULL, /* stroke_path */
- NULL, /* fill_mask */
- NULL, /* fill_trapezoid */
- NULL, /* fill_parallelogram */
- NULL, /* fill_triangle */
- NULL, /* draw_thin_line */
- NULL, /* begin_image */
- NULL, /* image_data */
- NULL, /* end_image */
- NULL, /* strip_tile_rectangle */
- NULL, /* strip_copy_rop, */
- NULL, /* get_clipping_box */
- NULL, /* begin_typed_image */
- NULL, /* get_bits_rectangle */
- NULL, /* map_color_rgb_alpha */
- NULL, /* create_compositor */
- NULL, /* get_hardware_params */
- NULL, /* text_begin */
- NULL, /* finish_copydevice */
- NULL, /* begin_transparency_group */
- NULL, /* end_transparency_group */
- NULL, /* begin_transparency_mask */
- NULL, /* end_transparency_mask */
- NULL, /* discard_transparency_layer */
- gx_default_DevRGB_get_color_mapping_procs,
- gx_default_DevRGB_get_color_comp_index,
- pngalpha_encode_color,
- pngalpha_decode_color,
- NULL, /* pattern_manage */
- NULL, /* fill_rectangle_hl_color */
- NULL, /* include_color_space */
- NULL, /* fill_linear_color_scanline */
- NULL, /* fill_linear_color_trapezoid */
- NULL, /* fill_linear_color_triangle */
- NULL, /* update_spot_equivalent_colors */
- NULL, /* ret_devn_params */
- pngalpha_fillpage,
- NULL, /* push_transparency_state */
- NULL, /* pop_transparency_state */
- pngalpha_put_image,
- pngalpha_spec_op /* dev_spec_op */\
-};
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, open_device, pngalpha_open);
+ set_dev_proc(dev, map_rgb_color, pngalpha_encode_color);
+ set_dev_proc(dev, map_color_rgb, pngalpha_decode_color);
+ set_dev_proc(dev, encode_color, pngalpha_encode_color);
+ set_dev_proc(dev, decode_color, pngalpha_decode_color);
+ set_dev_proc(dev, get_params, pngalpha_get_params);
+ set_dev_proc(dev, put_params, pngalpha_put_params);
+ set_dev_proc(dev, copy_alpha, pngalpha_copy_alpha);
+ set_dev_proc(dev, get_color_mapping_procs, gx_default_DevRGB_get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, gx_default_DevRGB_get_color_comp_index);
+ set_dev_proc(dev, fillpage, pngalpha_fillpage);
+ set_dev_proc(dev, put_image, pngalpha_put_image);
+ set_dev_proc(dev, dev_spec_op, pngalpha_spec_op);
+}
const gx_device_pngalpha gs_pngalpha_device = {
- std_device_part1_(gx_device_pngalpha, &pngalpha_procs, "pngalpha",
+ std_device_part1_(gx_device_pngalpha,
+ pngalpha_initialize_device_procs, "pngalpha",
&st_device_printer, open_init_closed),
/* color_info */
{3 /* max components */,
@@ -305,7 +302,7 @@ const gx_device_pngalpha gs_pngalpha_device = {
{ 0 } /* component bits */,
{ 0 } /* component mask */,
"DeviceRGB" /* process color name */,
- GX_CINFO_OPMODE_UNKNOWN /* opmode */,
+ GX_CINFO_OPMSUPPORTED_UNKNOWN /* opmsupported */,
0 /* process_cmps */,
0 /* icc_locations */
},
@@ -975,6 +972,8 @@ pngalpha_copy_alpha(gx_device * dev, const byte * data, int data_x,
int code = 0;
gx_color_value color_cv[GX_DEVICE_COLOR_MAX_COMPONENTS];
int ry;
+ gs_int_rect rect;
+ gs_get_bits_params_t params;
fit_copy(dev, data, data_x, raster, id, x, y, width, height);
row = data;
@@ -986,6 +985,10 @@ pngalpha_copy_alpha(gx_device * dev, const byte * data, int data_x,
goto out;
}
(*dev_proc(dev, decode_color)) (dev, color, color_cv);
+ rect.p.x = 0;
+ rect.q.x = dev->width;
+ params.x_offset = 0;
+ params.raster = bitmap_raster(dev->width * dev->color_info.depth);
for (ry = y; ry < y + height; row += raster, ++ry) {
byte *line;
int sx, rx;
@@ -995,9 +998,19 @@ pngalpha_copy_alpha(gx_device * dev, const byte * data, int data_x,
byte l_dbyte = ((l_dbit) ? (byte)(*(l_dptr) & (0xff00 >> (l_dbit))) : 0);
int l_xprev = x;
- code = (*dev_proc(dev, get_bits)) (dev, ry, lin, &line);
+ rect.p.y = ry;
+ rect.q.y = ry+1;
+
+ params.options = (GB_ALIGN_ANY |
+ (GB_RETURN_COPY | GB_RETURN_POINTER) |
+ GB_OFFSET_0 |
+ GB_RASTER_STANDARD | GB_PACKING_CHUNKY |
+ GB_COLORS_NATIVE | GB_ALPHA_NONE);
+ params.data[0] = lin;
+ code = (*dev_proc(dev, get_bits_rectangle))(dev, &rect, &params);
if (code < 0)
break;
+ line = params.data[0];
for (sx = data_x, rx = x; sx < data_x + width; ++sx, ++rx) {
gx_color_index previous = gx_no_color_index;
gx_color_index composite;
diff --git a/devices/gdevpsd.c b/devices/gdevpsd.c
index 03495ae0..3c9f6b01 100644
--- a/devices/gdevpsd.c
+++ b/devices/gdevpsd.c
@@ -148,77 +148,23 @@ gs_private_st_composite_final(st_psd_device, psd_device,
"psd_device", psd_device_enum_ptrs, psd_device_reloc_ptrs,
psd_device_finalize);
-/*
- * Macro definition for psd device procedures
- */
-#define device_procs(get_color_mapping_procs, params)\
-{ psd_prn_open,\
- gx_default_get_initial_matrix,\
- NULL, /* sync_output */\
- /* Since the print_page doesn't alter the device, this device can print in the background */\
- gdev_prn_bg_output_page, /* output_page */\
- psd_prn_close, /* close */\
- NULL, /* map_rgb_color - not used */\
- psd_map_color_rgb, /* map_color_rgb */\
- NULL, /* fill_rectangle */\
- NULL, /* tile_rectangle */\
- NULL, /* copy_mono */\
- NULL, /* copy_color */\
- NULL, /* draw_line */\
- NULL, /* get_bits */\
- psd_get_##params, /* get_params */\
- psd_put_##params, /* put_params */\
- NULL, /* map_cmyk_color - not used */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- gx_page_device_get_page_device, /* get_page_device */\
- NULL, /* get_alpha_bits */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- NULL, /* fill_path */\
- NULL, /* stroke_path */\
- NULL, /* fill_mask */\
- NULL, /* fill_trapezoid */\
- NULL, /* fill_parallelogram */\
- NULL, /* fill_triangle */\
- NULL, /* draw_thin_line */\
- NULL, /* begin_image */\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL, /* strip_copy_rop */\
- NULL, /* get_clipping_box */\
- NULL, /* begin_typed_image */\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- NULL, /* create_compositor */\
- NULL, /* get_hardware_params */\
- NULL, /* text_begin */\
- NULL, /* finish_copydevice */\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL, /* discard_transparency_layer */\
- get_color_mapping_procs, /* get_color_mapping_procs */\
- psd_get_color_comp_index, /* get_color_comp_index */\
- gx_devn_prn_encode_color, /* encode_color */\
- gx_devn_prn_decode_color, /* decode_color */\
- NULL, /* pattern_manage */\
- NULL, /* fill_rectangle_hl_color */\
- NULL, /* include_color_space */\
- NULL, /* fill_linear_color_scanline */\
- NULL, /* fill_linear_color_trapezoid */\
- NULL, /* fill_linear_color_triangle */\
- gx_devn_prn_update_spot_equivalent_colors, /* update_spot_equivalent_colors */\
- gx_devn_prn_ret_devn_params, /* ret_devn_params */\
- NULL, /* fillpage */\
- NULL, /* push_transparency_state */\
- NULL, /* pop_transparency_state */\
- NULL, /* put_image */\
- psd_spec_op /* dev_spec_op */\
+static void
+psd_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, open_device, psd_prn_open);
+ set_dev_proc(dev, close_device, psd_prn_close);
+ set_dev_proc(dev, map_color_rgb, psd_map_color_rgb);
+ set_dev_proc(dev, get_params, psd_get_params);
+ set_dev_proc(dev, put_params, psd_put_params);
+ set_dev_proc(dev, get_color_mapping_procs, get_psdrgb_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, psd_get_color_comp_index);
+ set_dev_proc(dev, encode_color, gx_devn_prn_encode_color);
+ set_dev_proc(dev, decode_color, gx_devn_prn_decode_color);
+ set_dev_proc(dev, update_spot_equivalent_colors, gx_devn_prn_update_spot_equivalent_colors);
+ set_dev_proc(dev, ret_devn_params, gx_devn_prn_ret_devn_params);
+ set_dev_proc(dev, dev_spec_op, psd_spec_op);
}
#define psd_device_body(procs, dname, ncomp, pol, depth, mg, mc, sl, cn)\
@@ -243,12 +189,9 @@ gs_private_st_composite_final(st_psd_device, psd_device,
/*
* PSD device with RGB process color model.
*/
-static const gx_device_procs spot_rgb_procs =
- device_procs(get_psdrgb_color_mapping_procs, params);
-
const psd_device gs_psdrgb_device =
{
- psd_device_body(spot_rgb_procs, "psdrgb", 3, GX_CINFO_POLARITY_ADDITIVE, 24, 255, 255, GX_CINFO_SEP_LIN, "DeviceRGB"),
+ psd_device_body(psd_initialize_device_procs, "psdrgb", 3, GX_CINFO_POLARITY_ADDITIVE, 24, 255, 255, GX_CINFO_SEP_LIN, "DeviceRGB"),
/* devn_params specific parameters */
{ 8, /* Bits per color - must match ncomp, depth, etc. above */
DeviceRGBComponents, /* Names of color model colorants */
@@ -269,7 +212,7 @@ const psd_device gs_psdrgb_device =
const psd_device gs_psdrgb16_device =
{
- psd_device_body(spot_rgb_procs, "psdrgb16", 3, GX_CINFO_POLARITY_ADDITIVE, 48, 65535, 65535, GX_CINFO_SEP_LIN, "DeviceRGB"),
+ psd_device_body(psd_initialize_device_procs, "psdrgb16", 3, GX_CINFO_POLARITY_ADDITIVE, 48, 65535, 65535, GX_CINFO_SEP_LIN, "DeviceRGB"),
/* devn_params specific parameters */
{ 16, /* Bits per color - must match ncomp, depth, etc. above */
DeviceRGBComponents, /* Names of color model colorants */
@@ -291,12 +234,19 @@ const psd_device gs_psdrgb16_device =
/*
* PSD device with CMYK process color model and spot color support.
*/
-static const gx_device_procs spot_cmyk_procs
- = device_procs(get_psd_color_mapping_procs, params_cmyk);
+static void
+psdcmyk_initialize_device_procs(gx_device *dev)
+{
+ psd_initialize_device_procs(dev);
+
+ set_dev_proc(dev, get_params, psd_get_params_cmyk);
+ set_dev_proc(dev, put_params, psd_put_params_cmyk);
+ set_dev_proc(dev, get_color_mapping_procs, get_psd_color_mapping_procs);
+}
const psd_device gs_psdcmyk_device =
{
- psd_device_body(spot_cmyk_procs, "psdcmyk",
+ psd_device_body(psdcmyk_initialize_device_procs, "psdcmyk",
ARCH_SIZEOF_GX_COLOR_INDEX, /* Number of components - need a nominal 1 bit for each */
GX_CINFO_POLARITY_SUBTRACTIVE,
ARCH_SIZEOF_GX_COLOR_INDEX * 8, /* 8 bits per component (albeit in planes) */
@@ -321,7 +271,7 @@ const psd_device gs_psdcmyk_device =
const psd_device gs_psdcmyk16_device =
{
- psd_device_body(spot_cmyk_procs, "psdcmyk16",
+ psd_device_body(psdcmyk_initialize_device_procs, "psdcmyk16",
ARCH_SIZEOF_GX_COLOR_INDEX, /* Number of components - need a nominal 1 bit for each */
GX_CINFO_POLARITY_SUBTRACTIVE,
ARCH_SIZEOF_GX_COLOR_INDEX * 16, /* 8 bits per component (albeit in planes) */
@@ -351,48 +301,15 @@ psd_prn_open(gx_device * pdev)
psd_device *pdev_psd = (psd_device *) pdev;
int code;
int k;
- bool force_pdf, force_ps;
cmm_dev_profile_t *profile_struct;
#ifdef TEST_PAD_AND_ALIGN
pdev->pad = 5;
pdev->log2_align_mod = 6;
#endif
-
- /* There are 2 approaches to the use of a DeviceN ICC output profile.
- One is to simply limit our device to only output the colorants
- defined in the output ICC profile. The other is to use the
- DeviceN ICC profile to color manage those N colorants and
- to let any other separations pass through unmolested. The define
- LIMIT_TO_ICC sets the option to limit our device to only the ICC
- colorants defined by -sICCOutputColors (or to the ones that are used
- as default names if ICCOutputColors is not used). The pass through option
- (LIMIT_TO_ICC set to 0) makes life a bit more difficult since we don't
- know if the page_spot_colors overlap with any spot colorants that exist
- in the DeviceN ICC output profile. Hence we don't know how many planes
- to use for our device. This is similar to the issue when processing
- a PostScript file. So that I remember, the cases are
- DeviceN Profile? limit_icc Result
- 0 0 force_pdf 0 force_ps 0 (no effect)
- 0 0 force_pdf 0 force_ps 0 (no effect)
- 1 0 force_pdf 0 force_ps 1 (colorants not known)
- 1 1 force_pdf 1 force_ps 0 (colorants known)
- */
code = dev_proc(pdev, get_profile)((gx_device *)pdev, &profile_struct);
- if (profile_struct->spotnames == NULL) {
- force_pdf = false;
- force_ps = false;
- } else {
-#if LIMIT_TO_ICC
- force_pdf = true;
- force_ps = false;
-#else
- force_pdf = false;
- force_ps = true;
-#endif
- }
- pdev_psd->warning_given = false;
+ pdev_psd->warning_given = false;
/* For the planar device we need to set up the bit depth of each plane.
For other devices this is handled in check_device_separable where
we compute the bit shift for the components etc. */
@@ -406,20 +323,29 @@ psd_prn_open(gx_device * pdev)
Update things so that we only output separations for the
inks on that page. */
if (pdev->color_info.polarity == GX_CINFO_POLARITY_SUBTRACTIVE) {
- if ((pdev_psd->devn_params.page_spot_colors >= 0 || force_pdf) && !force_ps) {
- if (force_pdf) {
- /* Use the information that is in the ICC profle. We will be here
- anytime that we have limited ourselves to a fixed number
- of colorants specified by the DeviceN ICC profile */
+ if (pdev_psd->devn_params.page_spot_colors >= 0) {
+
+ /* PDF case, as the page spot colors are known. */
+ if (profile_struct->spotnames != NULL) {
+
+ /* PDF case, NCLR ICC profile with spot names. The ICC spots
+ will use up some of the max_spots values. If max_spots is
+ too small to accomodate even the ICC spots, throw an error */
+ if (profile_struct->spotnames->count - 4 > pdev_psd->max_spots ||
+ profile_struct->spotnames->count < 4 ||
+ profile_struct->spotnames->count <
+ profile_struct->device_profile[0]->num_comps) {
+ gs_warn("ICC profile colorant names count error");
+ return_error(gs_error_rangecheck);
+ }
pdev->color_info.num_components =
- (pdev_psd->devn_params.separations.num_separations
- + pdev_psd->devn_params.num_std_colorant_names);
+ (profile_struct->spotnames->count
+ + pdev_psd->devn_params.page_spot_colors);
if (pdev->color_info.num_components > pdev->color_info.max_components)
pdev->color_info.num_components = pdev->color_info.max_components;
- /* Limit us only to the ICC colorants */
- pdev->color_info.max_components = pdev->color_info.num_components;
} else {
- /* Use the information that is in the page spot color. We should
+
+ /* Use the information that is in the page spot color. We should
be here if we are processing a PDF and we do not have a DeviceN
ICC profile specified for output */
if (!(pdev_psd->lock_colorants)) {
@@ -431,11 +357,17 @@ psd_prn_open(gx_device * pdev)
}
}
} else {
+
/* We do not know how many spots may occur on the page.
For this reason we go ahead and allocate the maximum that we
have available. Note, lack of knowledge only occurs in the case
- of PS files. With PDF we know a priori the number of spot
- colorants. */
+ of PS files. With PDF we know a priori the number of spot
+ colorants. However, the first time the device is opened,
+ pdev_psd->devn_params.page_spot_colors is -1 even if we are
+ dealing with a PDF file, so we will first find ourselves here,
+ which will set num_comp based upon max_spots + 4. If -dMaxSpots
+ was set (Default is GS_SOFT_MAX_SPOTS which is 10),
+ it is made use of here. */
if (!(pdev_psd->lock_colorants)) {
int num_comp = pdev_psd->max_spots + 4; /* Spots + CMYK */
if (num_comp > GS_CLIENT_COLOR_MAX_COMPONENTS)
@@ -466,20 +398,20 @@ psd_prn_open(gx_device * pdev)
psdgray device
*/
static void
-gray_cs_to_psdgray_cm(gx_device * dev, frac gray, frac out[])
+gray_cs_to_psdgray_cm(const gx_device * dev, frac gray, frac out[])
{
out[0] = gray;
}
static void
-rgb_cs_to_psdgray_cm(gx_device * dev, const gs_gstate *pgs,
+rgb_cs_to_psdgray_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
out[0] = color_rgb_to_gray(r, g, b, NULL);
}
static void
-cmyk_cs_to_psdgray_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+cmyk_cs_to_psdgray_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
out[0] = color_cmyk_to_gray(c, m, y, k, NULL);
}
@@ -489,7 +421,7 @@ cmyk_cs_to_psdgray_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[
* the color components for the psdrgb device.
*/
static void
-gray_cs_to_psdrgb_cm(gx_device * dev, frac gray, frac out[])
+gray_cs_to_psdrgb_cm(const gx_device * dev, frac gray, frac out[])
{
int i = ((psd_device *)dev)->devn_params.separations.num_separations;
@@ -499,7 +431,7 @@ gray_cs_to_psdrgb_cm(gx_device * dev, frac gray, frac out[])
}
static void
-rgb_cs_to_psdrgb_cm(gx_device * dev, const gs_gstate *pgs,
+rgb_cs_to_psdrgb_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
int i = ((psd_device *)dev)->devn_params.separations.num_separations;
@@ -512,7 +444,7 @@ rgb_cs_to_psdrgb_cm(gx_device * dev, const gs_gstate *pgs,
}
static void
-cmyk_cs_to_psdrgb_cm(gx_device * dev,
+cmyk_cs_to_psdrgb_cm(const gx_device * dev,
frac c, frac m, frac y, frac k, frac out[])
{
int i = ((psd_device *)dev)->devn_params.separations.num_separations;
@@ -525,7 +457,7 @@ cmyk_cs_to_psdrgb_cm(gx_device * dev,
/* Color mapping routines for the psdcmyk device */
static void
-gray_cs_to_psdcmyk_cm(gx_device * dev, frac gray, frac out[])
+gray_cs_to_psdcmyk_cm(const gx_device * dev, frac gray, frac out[])
{
int * map = ((psd_device *) dev)->devn_params.separation_order_map;
@@ -533,7 +465,7 @@ gray_cs_to_psdcmyk_cm(gx_device * dev, frac gray, frac out[])
}
static void
-rgb_cs_to_psdcmyk_cm(gx_device * dev, const gs_gstate *pgs,
+rgb_cs_to_psdcmyk_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
int * map = ((psd_device *) dev)->devn_params.separation_order_map;
@@ -542,10 +474,10 @@ rgb_cs_to_psdcmyk_cm(gx_device * dev, const gs_gstate *pgs,
}
static void
-cmyk_cs_to_psdcmyk_cm(gx_device * dev,
+cmyk_cs_to_psdcmyk_cm(const gx_device * dev,
frac c, frac m, frac y, frac k, frac out[])
{
- const gs_devn_params *devn = gx_devn_prn_ret_devn_params(dev);
+ const gs_devn_params *devn = gx_devn_prn_ret_devn_params_const(dev);
const int *map = devn->separation_order_map;
int j;
@@ -578,7 +510,7 @@ cmyk_cs_to_psdcmyk_cm(gx_device * dev,
}
static void
-cmyk_cs_to_spotn_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+cmyk_cs_to_spotn_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
psd_device *xdev = (psd_device *)dev;
int n = xdev->devn_params.separations.num_separations;
@@ -597,7 +529,7 @@ cmyk_cs_to_spotn_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
in[2] = frac2ushort(y);
in[3] = frac2ushort(k);
- gscms_transform_color(dev, link, &(in[0]),
+ gscms_transform_color_const(dev, link, &(in[0]),
&(tmp[0]), 2);
for (i = 0; i < outn; i++)
@@ -617,13 +549,13 @@ cmyk_cs_to_spotn_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
}
static void
-gray_cs_to_spotn_cm(gx_device * dev, frac gray, frac out[])
+gray_cs_to_spotn_cm(const gx_device * dev, frac gray, frac out[])
{
cmyk_cs_to_spotn_cm(dev, 0, 0, 0, (frac)(frac_1 - gray), out);
}
static void
-rgb_cs_to_spotn_cm(gx_device * dev, const gs_gstate *pgs,
+rgb_cs_to_spotn_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
psd_device *xdev = (psd_device *)dev;
@@ -641,7 +573,7 @@ rgb_cs_to_spotn_cm(gx_device * dev, const gs_gstate *pgs,
in[1] = frac2ushort(g);
in[2] = frac2ushort(b);
- gscms_transform_color(dev, link, &(in[0]),
+ gscms_transform_color_const(dev, link, &(in[0]),
&(tmp[0]), 2);
for (i = 0; i < outn; i++)
@@ -679,16 +611,18 @@ static const gx_cm_color_map_procs psdN_procs = {
* to color model conversion routines.
*/
static const gx_cm_color_map_procs *
-get_psdrgb_color_mapping_procs(const gx_device * dev)
+get_psdrgb_color_mapping_procs(const gx_device * dev, const gx_device **map_dev)
{
+ *map_dev = dev;
return &psdRGB_procs;
}
static const gx_cm_color_map_procs *
-get_psd_color_mapping_procs(const gx_device * dev)
+get_psd_color_mapping_procs(const gx_device * dev, const gx_device **map_dev)
{
const psd_device *xdev = (const psd_device *)dev;
+ *map_dev = dev;
if (xdev->color_model == psd_DEVICE_RGB)
return &psdRGB_procs;
else if (xdev->color_model == psd_DEVICE_CMYK)
@@ -919,7 +853,34 @@ psd_setup(psd_write_ctx *xc, gx_devn_prn_device *dev, gp_file *file, int w, int
}
}
} else {
- xc->num_channels += dev->devn_params.separations.num_separations;
+ /* No order specified, map them alpabetically */
+ /* This isn't at all speed critical -- only runs once per page and */
+ /* there are never very many spot colors, so just search in a loop */
+ byte *prev = " ";
+ int prev_size = 1;
+
+ xc->num_channels += xc->n_extra_channels;
+ for (i=xc->base_num_channels; i < xc->num_channels; i++) {
+ int j;
+ byte* curr = "\377";
+ int curr_size = 1;
+
+ for (j=xc->base_num_channels; j < xc->num_channels; j++) {
+ const devn_separation_name *separation_name;
+
+ separation_name = &(dev->devn_params.separations.names[j - xc->base_num_channels]);
+ if (strncmp(separation_name->data, curr, min(curr_size, separation_name->size)) < 0) {
+ if (strncmp(separation_name->data, prev, min(prev_size, separation_name->size)) > 0) {
+ xc->chnl_to_position[i] = j;
+ xc->chnl_to_orig_sep[i] = j;
+ curr = separation_name->data;
+ curr_size = separation_name->size;
+ }
+ }
+ }
+ prev = curr; /* next color has to sort after this one */
+ prev_size = curr_size;
+ }
}
}
return 0;
@@ -1238,7 +1199,7 @@ psd_write_image_data(psd_write_ctx *xc, gx_device_printer *pdev)
code = gs_note_error(gs_error_ioerror);
goto cleanup;
}
- }
+ }
}
cleanup:
diff --git a/devices/gdevpsd.h b/devices/gdevpsd.h
index a10e4ec7..21073305 100644
--- a/devices/gdevpsd.h
+++ b/devices/gdevpsd.h
@@ -31,7 +31,6 @@ typedef struct {
int chnl_to_orig_sep[GX_DEVICE_COLOR_MAX_COMPONENTS];
/* Map output channel number to gx_color_index position. */
int chnl_to_position[GX_DEVICE_COLOR_MAX_COMPONENTS];
-
/* byte offset of image data */
int image_data_off;
} psd_write_ctx;
diff --git a/devices/gdevrinkj.c b/devices/gdevrinkj.c
index a49ee1c0..b1144392 100644
--- a/devices/gdevrinkj.c
+++ b/devices/gdevrinkj.c
@@ -126,71 +126,26 @@ typedef struct rinkj_device_s {
char setup_fn[256];
} rinkj_device;
-/*
- * Macro definition for DeviceN procedures
- */
-#define device_procs(get_color_mapping_procs)\
-{ gdev_prn_open,\
- gx_default_get_initial_matrix,\
- NULL, /* sync_output */\
- /* Since the print_page doesn't alter the device, this device can print in the background */\
- gdev_prn_bg_output_page, /* output_page */\
- rinkj_close_device, /* close */\
- NULL, /* map_rgb_color - not used */\
- rinkj_map_color_rgb, /* map_color_rgb */\
- NULL, /* fill_rectangle */\
- NULL, /* tile_rectangle */\
- NULL, /* copy_mono */\
- NULL, /* copy_color */\
- NULL, /* draw_line */\
- NULL, /* get_bits */\
- rinkj_get_params, /* get_params */\
- rinkj_put_params, /* put_params */\
- NULL, /* map_cmyk_color - not used */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- gx_page_device_get_page_device, /* get_page_device */\
- NULL, /* get_alpha_bits */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- NULL, /* fill_path */\
- NULL, /* stroke_path */\
- NULL, /* fill_mask */\
- NULL, /* fill_trapezoid */\
- NULL, /* fill_parallelogram */\
- NULL, /* fill_triangle */\
- NULL, /* draw_thin_line */\
- NULL, /* begin_image */\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL, /* strip_copy_rop */\
- NULL, /* get_clipping_box */\
- NULL, /* begin_typed_image */\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- NULL, /* create_compositor */\
- NULL, /* get_hardware_params */\
- NULL, /* text_begin */\
- NULL, /* finish_copydevice */\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL, /* discard_transparency_layer */\
- get_color_mapping_procs, /* get_color_mapping_procs */\
- rinkj_get_color_comp_index, /* get_color_comp_index */\
- rinkj_encode_color, /* encode_color */\
- rinkj_decode_color /* decode_color */\
+static void
+spot_cmyk_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, gdev_prn_open);
+ set_dev_proc(dev, output_page, gdev_prn_bg_output_page);
+ set_dev_proc(dev, close_device, rinkj_close_device);
+ set_dev_proc(dev, map_color_rgb, rinkj_map_color_rgb);
+ set_dev_proc(dev, get_params, rinkj_get_params);
+ set_dev_proc(dev, put_params, rinkj_put_params);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
+ set_dev_proc(dev, get_color_mapping_procs, get_rinkj_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, rinkj_get_color_comp_index);
+ set_dev_proc(dev, encode_color, rinkj_encode_color);
+ set_dev_proc(dev, decode_color, rinkj_decode_color);
}
-static const gx_device_procs spot_cmyk_procs = device_procs(get_rinkj_color_mapping_procs);
-
const rinkj_device gs_rinkj_device =
{
- prn_device_body_extended(rinkj_device, spot_cmyk_procs, "rinkj",
+ prn_device_body_extended(rinkj_device,
+ spot_cmyk_initialize_device_procs, "rinkj",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI, /* X and Y hardware resolution */
0, 0, 0, 0, /* margins */
@@ -218,7 +173,7 @@ const rinkj_device gs_rinkj_device =
* the color components for the spotrgb device.
*/
static void
-gray_cs_to_spotrgb_cm(gx_device * dev, frac gray, frac out[])
+gray_cs_to_spotrgb_cm(const gx_device * dev, frac gray, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
int i = ((rinkj_device *)dev)->separation_names.num_names;
@@ -229,7 +184,7 @@ gray_cs_to_spotrgb_cm(gx_device * dev, frac gray, frac out[])
}
static void
-rgb_cs_to_spotrgb_cm(gx_device * dev, const gs_gstate *pgs,
+rgb_cs_to_spotrgb_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
@@ -243,7 +198,7 @@ rgb_cs_to_spotrgb_cm(gx_device * dev, const gs_gstate *pgs,
}
static void
-cmyk_cs_to_spotrgb_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+cmyk_cs_to_spotrgb_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
int i = ((rinkj_device *)dev)->separation_names.num_names;
@@ -254,7 +209,7 @@ cmyk_cs_to_spotrgb_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[
}
static void
-gray_cs_to_spotcmyk_cm(gx_device * dev, frac gray, frac out[])
+gray_cs_to_spotcmyk_cm(const gx_device * dev, frac gray, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
int i = ((rinkj_device *)dev)->separation_names.num_names;
@@ -266,7 +221,7 @@ gray_cs_to_spotcmyk_cm(gx_device * dev, frac gray, frac out[])
}
static void
-rgb_cs_to_spotcmyk_cm(gx_device * dev, const gs_gstate *pgs,
+rgb_cs_to_spotcmyk_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
@@ -280,7 +235,7 @@ rgb_cs_to_spotcmyk_cm(gx_device * dev, const gs_gstate *pgs,
}
static void
-cmyk_cs_to_spotcmyk_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+cmyk_cs_to_spotcmyk_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
rinkj_device *rdev = (rinkj_device *)dev;
@@ -296,7 +251,7 @@ cmyk_cs_to_spotcmyk_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out
};
static void
-cmyk_cs_to_spotn_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+cmyk_cs_to_spotn_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
rinkj_device *rdev = (rinkj_device *)dev;
@@ -313,7 +268,7 @@ cmyk_cs_to_spotn_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
};
static void
-gray_cs_to_spotn_cm(gx_device * dev, frac gray, frac out[])
+gray_cs_to_spotn_cm(const gx_device * dev, frac gray, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
@@ -321,7 +276,7 @@ gray_cs_to_spotn_cm(gx_device * dev, frac gray, frac out[])
}
static void
-rgb_cs_to_spotn_cm(gx_device * dev, const gs_gstate *pgs,
+rgb_cs_to_spotn_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
@@ -350,10 +305,11 @@ static const gx_cm_color_map_procs spotN_procs = {
*/
static const gx_cm_color_map_procs *
-get_rinkj_color_mapping_procs(const gx_device * dev)
+get_rinkj_color_mapping_procs(const gx_device * dev, const gx_device **tdev)
{
const rinkj_device *rdev = (const rinkj_device *)dev;
+ *tdev = dev;
if (rdev->color_model == RINKJ_DEVICE_RGB)
return &spotRGB_procs;
else if (rdev->color_model == RINKJ_DEVICE_CMYK)
diff --git a/devices/gdevsj48.c b/devices/gdevsj48.c
index 9a004446..edbeab82 100644
--- a/devices/gdevsj48.c
+++ b/devices/gdevsj48.c
@@ -39,8 +39,9 @@
/* The device descriptor */
static dev_proc_print_page(sj48_print_page);
+/* The print_page proc is compatible with allowing bg printing */
gx_device_printer far_data gs_sj48_device =
- prn_device(prn_bg_procs, "sj48", /* The print_page proc is compatible with allowing bg printing */
+ prn_device(gdev_prn_initialize_device_procs_mono_bg, "sj48",
80, /* width_10ths, 8" */
105, /* height_10ths, 10.5" */
360, /* x_dpi */
@@ -80,8 +81,8 @@ gx_device_printer far_data gs_sj48_device =
static int
sj48_print_page(gx_device_printer *pdev, gp_file *prn_stream)
{ int line_size = gx_device_raster((gx_device *)pdev, 0);
- int xres = pdev->x_pixels_per_inch;
- int yres = pdev->y_pixels_per_inch;
+ int xres = (int)pdev->x_pixels_per_inch;
+ int yres = (int)pdev->y_pixels_per_inch;
int mode = (yres == 180 ?
(xres == 180 ? 39 : 40) :
(xres == 180 ? 71 : 72));
diff --git a/devices/gdevsnfb.c b/devices/gdevsnfb.c
index 6ffc7ba4..156a7a42 100644
--- a/devices/gdevsnfb.c
+++ b/devices/gdevsnfb.c
@@ -27,10 +27,19 @@ typedef long off_t;
static dev_proc_open_device(sonyfb_open);
static dev_proc_output_page(sonyfb_output_page);
static dev_proc_close_device(sonyfb_close);
-static gx_device_procs sonyfb_procs =
- prn_procs(sonyfb_open, sonyfb_output_page, sonyfb_close);
+
+static void
+sonyfb_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono_bg(dev);
+
+ set_dev_proc(dev, open_device, sonyfb_open);
+ set_dev_proc(dev, output_page, sonyfb_output_page);
+ set_dev_proc(dev, close_device, sonyfb_close);
+}
+
const gx_device_printer far_data gs_sonyfb_device =
- prn_device(sonyfb_procs, "sonyfb",
+ prn_device(sonyfb_initialize_device_procs, "sonyfb",
102.4, /* width_10ths */
103.2, /* height_10ths */
100, /* x_dpi */
diff --git a/devices/gdevstc.c b/devices/gdevstc.c
index 5d8bf425..b4e8c9f4 100644
--- a/devices/gdevstc.c
+++ b/devices/gdevstc.c
@@ -112,43 +112,44 @@ static dev_proc_put_params(stc_put_params);
*/
/* routines for monochrome monochrome modi */
-static dev_proc_map_rgb_color(stc_map_gray_color);
-static dev_proc_map_color_rgb(stc_map_color_gray);
+static dev_proc_map_rgb_color(stc_gray_map_rgb_color);
+static dev_proc_map_color_rgb(stc_gray_map_color_rgb);
+static dev_proc_decode_color(stc_gray_decode_color);
+static dev_proc_encode_color(stc_gray_encode_color);
/* routines for RGB-Modi */
-static dev_proc_map_rgb_color(stc_map_rgb_color);
-static dev_proc_map_color_rgb(stc_map_color_rgb);
+static dev_proc_map_rgb_color(stc_rgb_map_rgb_color);
+static dev_proc_map_color_rgb(stc_rgb_map_color_rgb);
/* routines for general CMYK-Modi */
-static dev_proc_map_cmyk_color(stc_map_cmyk_color);
-static dev_proc_map_color_rgb(stc_map_color_cmyk);
+static dev_proc_map_cmyk_color(stc_cmyk_map_cmyk_color);
+static dev_proc_map_color_rgb(stc_cmyk_map_color_rgb);
+static dev_proc_decode_color(stc_cmyk_decode_color);
/* routines for 10Bit/Component CMYK */
-static dev_proc_map_cmyk_color(stc_map_cmyk10_color);
-static dev_proc_map_color_rgb(stc_map_color_cmyk10);
+static dev_proc_map_cmyk_color(stc_cmyk10_map_cmyk_color);
+static dev_proc_map_color_rgb(stc_cmyk10_map_color_rgb);
+static dev_proc_decode_color(stc_cmyk10_decode_color);
/***
*** Table of Device-Procedures
***/
-static gx_device_procs stcolor_procs = {
- stc_open,
- gx_default_get_initial_matrix,
- gx_default_sync_output,
- /* Since the print_page doesn't alter the device, this device can print in the background */
- gdev_prn_bg_output_page,
- stc_close,
- NULL,
- stc_map_color_cmyk,
- NULL, /* fill_rectangle */
- NULL, /* tile_rectangle */
- NULL, /* copy_mono */
- NULL, /* copy_color */
- NULL, /* draw_line */
- gx_default_get_bits,
- stc_get_params,
- stc_put_params,
- stc_map_cmyk_color
-};
+static void
+stcolor_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, stc_open);
+ set_dev_proc(dev, get_initial_matrix, gx_default_get_initial_matrix);
+ set_dev_proc(dev, sync_output, gx_default_sync_output);
+ set_dev_proc(dev, output_page, gdev_prn_bg_output_page);
+ set_dev_proc(dev, close_device, stc_close);
+ set_dev_proc(dev, decode_color, stc_cmyk_decode_color);
+ set_dev_proc(dev, encode_color, stc_cmyk_map_cmyk_color);
+ set_dev_proc(dev, map_color_rgb, stc_cmyk_map_color_rgb);
+ set_dev_proc(dev, get_bits_rectangle, gx_default_get_bits_rectangle);
+ set_dev_proc(dev, get_params, stc_get_params);
+ set_dev_proc(dev, put_params, stc_put_params);
+ set_dev_proc(dev, map_cmyk_color, stc_cmyk_map_cmyk_color);
+}
/***
*** A local dummy-array for extvals
@@ -160,7 +161,7 @@ static float defext[] = { 0.0, 1.0 };
*** Main device-control structure
***/
stcolor_device far_data gs_stcolor_device = {
- prn_device_body(stcolor_device, stcolor_procs, "stcolor",
+ prn_device_body(stcolor_device, stcolor_initialize_device_procs, "stcolor",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
STC_L_MARGIN,STC_B_MARGIN,STC_R_MARGIN,STC_T_MARGIN,
@@ -1797,54 +1798,52 @@ stc_open(gx_device *pdev) /* setup margins & arrays */
switch(sd->color_info.num_components) { /* Establish color-procs */
case 1:
sd->color_info.polarity = GX_CINFO_POLARITY_ADDITIVE;
- set_dev_proc(sd,map_rgb_color, stc_map_gray_color);
- set_dev_proc(sd,map_cmyk_color,gx_default_map_cmyk_color);
- set_dev_proc(sd,map_color_rgb, stc_map_color_gray);
- set_dev_proc(sd,encode_color, stc_map_gray_color);
- set_dev_proc(sd,decode_color, stc_map_color_gray);
+ set_dev_proc(sd, map_rgb_color, stc_gray_map_rgb_color);
+ set_dev_proc(sd, map_cmyk_color, gx_default_map_cmyk_color);
+ set_dev_proc(sd, map_color_rgb, stc_gray_map_color_rgb);
+ set_dev_proc(sd, encode_color, stc_gray_encode_color);
+ set_dev_proc(sd, decode_color, stc_gray_decode_color);
set_dev_proc(sd, get_color_mapping_procs,
- gx_default_DevGray_get_color_mapping_procs);
+ gx_default_DevGray_get_color_mapping_procs);
set_dev_proc(sd, get_color_comp_index,
- gx_default_DevGray_get_color_comp_index );
+ gx_default_DevGray_get_color_comp_index );
cv[0] = cv[1] = cv[2] = gx_max_color_value;
- white = stc_map_gray_color((gx_device *) sd, cv);
+ white = stc_gray_map_rgb_color((gx_device *) sd, cv);
break;
case 3:
sd->color_info.polarity = GX_CINFO_POLARITY_ADDITIVE;
- set_dev_proc(sd,map_rgb_color, stc_map_rgb_color);
- set_dev_proc(sd,map_cmyk_color,gx_default_map_cmyk_color);
- set_dev_proc(sd,map_color_rgb, stc_map_color_rgb);
- set_dev_proc(sd,encode_color, stc_map_rgb_color);
- set_dev_proc(sd,decode_color, stc_map_color_rgb);
+ set_dev_proc(sd, map_rgb_color, stc_rgb_map_rgb_color);
+ set_dev_proc(sd, map_cmyk_color, gx_default_map_cmyk_color);
+ set_dev_proc(sd, map_color_rgb, stc_rgb_map_color_rgb);
+ set_dev_proc(sd, encode_color, stc_rgb_map_rgb_color);
+ set_dev_proc(sd, decode_color, stc_rgb_map_color_rgb);
set_dev_proc(sd, get_color_mapping_procs,
- gx_default_DevRGB_get_color_mapping_procs);
+ gx_default_DevRGB_get_color_mapping_procs);
set_dev_proc(sd, get_color_comp_index,
- gx_default_DevRGB_get_color_comp_index );
+ gx_default_DevRGB_get_color_comp_index );
cv[0] = cv[1] = cv[2] = gx_max_color_value;
- white = stc_map_rgb_color((gx_device *) sd, cv);
+ white = stc_rgb_map_rgb_color((gx_device *) sd, cv);
break;
default:
sd->color_info.polarity = GX_CINFO_POLARITY_SUBTRACTIVE;
- set_dev_proc(sd,map_rgb_color, gx_default_map_rgb_color);
+ set_dev_proc(sd, map_rgb_color, gx_default_map_rgb_color);
set_dev_proc(sd, get_color_mapping_procs,
- gx_default_DevCMYK_get_color_mapping_procs);
+ gx_default_DevCMYK_get_color_mapping_procs);
set_dev_proc(sd, get_color_comp_index,
- gx_default_DevCMYK_get_color_comp_index );
+ gx_default_DevCMYK_get_color_comp_index );
if(sd->stc.flags & STCCMYK10) {
- set_dev_proc(sd,map_cmyk_color,stc_map_cmyk10_color);
- set_dev_proc(sd,map_color_rgb, stc_map_color_cmyk10);
- set_dev_proc(sd,encode_color,stc_map_cmyk10_color);
- set_dev_proc(sd,decode_color, stc_map_color_cmyk10);
- cv[0] = cv[1] = cv[2] = cv[3] = 0;
- white = stc_map_cmyk10_color((gx_device *) sd, cv);
+ set_dev_proc(sd, map_cmyk_color, stc_cmyk10_map_cmyk_color);
+ set_dev_proc(sd, map_color_rgb, stc_cmyk10_map_color_rgb);
+ set_dev_proc(sd, encode_color, stc_cmyk10_map_cmyk_color);
+ set_dev_proc(sd, decode_color, stc_cmyk10_decode_color);
} else {
- set_dev_proc(sd,map_cmyk_color,stc_map_cmyk_color);
- set_dev_proc(sd,map_color_rgb, stc_map_color_cmyk);
- set_dev_proc(sd,encode_color,stc_map_cmyk_color);
- set_dev_proc(sd,decode_color, stc_map_color_cmyk);
- cv[0] = cv[1] = cv[2] = cv[3] = 0;
- white = stc_map_cmyk_color((gx_device *) sd,cv);
+ set_dev_proc(sd, map_cmyk_color, stc_cmyk_map_cmyk_color);
+ set_dev_proc(sd, map_color_rgb, stc_cmyk_map_color_rgb);
+ set_dev_proc(sd, encode_color, stc_cmyk_map_cmyk_color);
+ set_dev_proc(sd, decode_color, stc_cmyk_decode_color);
}
+ cv[0] = cv[1] = cv[2] = cv[3] = 0;
+ white = dev_proc(sd, map_cmyk_color)((gx_device *) sd, cv);
break; /* Establish color-procs */
}
@@ -2020,7 +2019,7 @@ stc_expand(stcolor_device *sd,int i,gx_color_index col)
*** color-mapping of gray-scales
***/
static gx_color_index
-stc_map_gray_color(gx_device *pdev, const gx_color_value cv[])
+stc_gray_map_rgb_color(gx_device *pdev, const gx_color_value cv[])
{
stcolor_device *sd = (stcolor_device *) pdev;
@@ -2065,8 +2064,27 @@ stc_map_gray_color(gx_device *pdev, const gx_color_value cv[])
return rv;
}
+static gx_color_index
+stc_gray_encode_color(gx_device *pdev, const gx_color_value cv[])
+{
+
+ stcolor_device *sd = (stcolor_device *) pdev;
+ gx_color_index rv;
+ gx_color_value r = cv[0];
+
+ rv = gx_max_color_value - r;
+
+ if(( sd->stc.bits == 8) &&
+ ((sd->stc.dither->flags & STC_TYPE) == STC_BYTE))
+ rv = stc_truncate1(sd,0,(gx_color_value)rv);
+ else
+ rv = stc_truncate(sd,0,(gx_color_value)rv);
+
+ return rv;
+}
+
static int
-stc_map_color_gray(gx_device *pdev, gx_color_index color,gx_color_value prgb[3])
+stc_gray_map_color_rgb(gx_device *pdev, gx_color_index color,gx_color_value prgb[3])
{
stcolor_device *sd = (stcolor_device *) pdev;
gx_color_index l = ((gx_color_index)1<<sd->stc.bits)-1;
@@ -2077,11 +2095,21 @@ stc_map_color_gray(gx_device *pdev, gx_color_index color,gx_color_value prgb[3])
return 0;
}
+static int
+stc_gray_decode_color(gx_device *pdev, gx_color_index color,gx_color_value prgb[1])
+{
+ stcolor_device *sd = (stcolor_device *) pdev;
+ gx_color_index l = ((gx_color_index)1<<sd->stc.bits)-1;
+
+ prgb[0] = gx_max_color_value - stc_expand(sd,0,color & l);
+
+ return 0;
+}
/***
*** color-mapping of rgb-values
***/
static gx_color_index
-stc_map_rgb_color(gx_device *pdev, const gx_color_value cv[])
+stc_rgb_map_rgb_color(gx_device *pdev, const gx_color_value cv[])
{
stcolor_device *sd = (stcolor_device *) pdev;
@@ -2131,7 +2159,7 @@ stc_map_rgb_color(gx_device *pdev, const gx_color_value cv[])
}
static int
-stc_map_color_rgb(gx_device *pdev, gx_color_index color,gx_color_value prgb[3])
+stc_rgb_map_color_rgb(gx_device *pdev, gx_color_index color,gx_color_value prgb[3])
{
stcolor_device *sd = (stcolor_device *) pdev;
@@ -2149,7 +2177,7 @@ stc_map_color_rgb(gx_device *pdev, gx_color_index color,gx_color_value prgb[3])
*** color-mapping of cmyk-values
***/
static gx_color_index
-stc_map_cmyk_color(gx_device *pdev, const gx_color_value cv[])
+stc_cmyk_map_cmyk_color(gx_device *pdev, const gx_color_value cv[])
{
stcolor_device *sd = (stcolor_device *) pdev;
@@ -2243,7 +2271,7 @@ stc_map_cmyk_color(gx_device *pdev, const gx_color_value cv[])
/* Modified to be a "decode_color" routine */
static int
-stc_map_color_cmyk(gx_device *pdev, gx_color_index color,gx_color_value cv[4])
+stc_cmyk_decode_color(gx_device *pdev, gx_color_index color, gx_color_value cv[4])
{
stcolor_device *sd = (stcolor_device *) pdev;
@@ -2264,11 +2292,37 @@ stc_map_color_cmyk(gx_device *pdev, gx_color_index color,gx_color_value cv[4])
return 0;
}
+static int
+stc_cmyk_map_color_rgb(gx_device *pdev, gx_color_index color, gx_color_value cv[3])
+{
+
+ stcolor_device *sd = (stcolor_device *) pdev;
+ int shift = sd->color_info.depth == 32 ? 8 : sd->stc.bits;
+ gx_color_index l = ((gx_color_index)1<<sd->stc.bits)-1;
+ gx_color_value c,m,y,k;
+
+ k = stc_expand(sd,3, color & l); color >>= shift;
+ y = stc_expand(sd,2, color & l); color >>= shift;
+ m = stc_expand(sd,1, color & l); color >>= shift;
+ c = stc_expand(sd,0, color & l);
+
+ k = gx_max_color_value - k;
+ c = (k < c) ? 0 : k - c;
+ m = (k < m) ? 0 : k - m;
+ y = (k < c) ? 0 : k - c;
+
+ cv[0] = c;
+ cv[1] = m;
+ cv[2] = y;
+
+ return 0;
+}
+
/***
*** color-mapping of cmyk10-values
***/
static gx_color_index
-stc_map_cmyk10_color(gx_device *pdev, const gx_color_value cv[])
+stc_cmyk10_map_cmyk_color(gx_device *pdev, const gx_color_value cv[])
{
stcolor_device *sd = (stcolor_device *) pdev;
@@ -2401,8 +2455,8 @@ stc_map_cmyk10_color(gx_device *pdev, const gx_color_value cv[])
}
static int
-stc_map_color_cmyk10(gx_device *pdev, gx_color_index color,
- gx_color_value cv[3])
+stc_cmyk10_decode_color(gx_device *pdev, gx_color_index color,
+ gx_color_value cv[4])
{
stcolor_device *sd = (stcolor_device *) pdev;
@@ -2448,6 +2502,59 @@ stc_map_color_cmyk10(gx_device *pdev, gx_color_index color,
cv[0] = c;
cv[1] = m;
cv[2] = y;
+ cv[3] = 0;
+
+ return 0;
+}
+
+static int
+stc_cmyk10_map_color_rgb(gx_device *pdev, gx_color_index color,
+ gx_color_value cv[3])
+{
+
+ stcolor_device *sd = (stcolor_device *) pdev;
+ gx_color_value c,m,y;
+
+/*
+ * We may need some swapping
+ */
+#if !ARCH_IS_BIG_ENDIAN
+ union { stc_pixel cv; byte bv[4]; } ui,uo;
+ ui.cv = color;
+ uo.bv[0] = ui.bv[3];
+ uo.bv[1] = ui.bv[2];
+ uo.bv[2] = ui.bv[1];
+ uo.bv[3] = ui.bv[0];
+ color = uo.cv;
+#endif
+
+ c = stc_expand(sd,3,(color>>2)&0x3ff);
+
+ /* cast the 64 bit switch argument to work around broken HPUX 10 cc */
+ switch((int)(color & 3)) {
+ case 0:
+ m = stc_expand(sd,1,(color>>22) & 0x3ff);
+ y = stc_expand(sd,2,(color>>12) & 0x3ff);
+ break;
+ case 1:
+ m = c;
+ c = stc_expand(sd,0,(color>>22) & 0x3ff);
+ y = stc_expand(sd,2,(color>>12) & 0x3ff);
+ break;
+ case 2:
+ y = c;
+ c = stc_expand(sd,0,(color>>22) & 0x3ff);
+ m = stc_expand(sd,1,(color>>12) & 0x3ff);
+ break;
+ default:
+ m = c;
+ y = c;
+ break;
+ }
+
+ cv[0] = gx_max_color_value - c;
+ cv[1] = gx_max_color_value - m;
+ cv[2] = gx_max_color_value - y;
return 0;
}
diff --git a/devices/gdevtfax.c b/devices/gdevtfax.c
index d7abc954..531eb964 100644
--- a/devices/gdevtfax.c
+++ b/devices/gdevtfax.c
@@ -54,14 +54,23 @@ struct gx_device_tfax_s {
typedef struct gx_device_tfax_s gx_device_tfax;
/* Define procedures that adjust the paper size. */
-static const gx_device_procs gdev_tfax_std_procs =
/* FIXME: From initial analysis this is NOT safe for bg_printing, but might be fixable */
- prn_params_procs(tfax_open, gdev_prn_output_page_seekable, tfax_close,
- tfax_get_params, tfax_put_params);
+static void
+tfax_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_mono(dev);
+
+ set_dev_proc(dev, open_device, tfax_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page_seekable);
+ set_dev_proc(dev, close_device, tfax_close);
+ set_dev_proc(dev, get_params, tfax_get_params);
+ set_dev_proc(dev, put_params, tfax_put_params);
+}
+
#define TFAX_DEVICE(dname, print_page, compr)\
{\
- FAX_DEVICE_BODY(gx_device_tfax, gdev_tfax_std_procs, dname, print_page),\
+ FAX_DEVICE_BODY(gx_device_tfax, tfax_initialize_device_procs, dname, print_page),\
TIFF_DEFAULT_STRIP_SIZE /* strip size byte count */,\
ARCH_IS_BIG_ENDIAN /* default to native endian (i.e. use big endian iff the platform is so*/,\
false, /* default to not using bigtiff */\
@@ -258,7 +267,7 @@ static dev_proc_print_page(tifflzw_print_page);
static dev_proc_print_page(tiffpack_print_page);
const gx_device_tfax gs_tifflzw_device = {
- prn_device_std_body(gx_device_tfax, gdev_tfax_std_procs, "tifflzw",
+ prn_device_std_body(gx_device_tfax, tfax_initialize_device_procs, "tifflzw",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
@@ -274,7 +283,7 @@ const gx_device_tfax gs_tifflzw_device = {
};
const gx_device_tfax gs_tiffpack_device = {
- prn_device_std_body(gx_device_tfax, gdev_tfax_std_procs, "tiffpack",
+ prn_device_std_body(gx_device_tfax, tfax_initialize_device_procs, "tiffpack",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* margins */
diff --git a/devices/gdevtfnx.c b/devices/gdevtfnx.c
index e7c7f0fe..e09a56ce 100644
--- a/devices/gdevtfnx.c
+++ b/devices/gdevtfnx.c
@@ -39,17 +39,32 @@ static dev_proc_print_page(tiff_rgb_print_page);
/* FIXME: From initial analysis this is NOT safe for bg_printing, but might be fixable */
-static const gx_device_procs tiff12_procs =
-prn_color_params_procs(tiff_open, gdev_prn_output_page_seekable, tiff_close,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb,
- tiff_get_params, tiff_put_params);
-static const gx_device_procs tiff24_procs =
-prn_color_params_procs(tiff_open, gdev_prn_output_page_seekable, tiff_close,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb,
- tiff_get_params, tiff_put_params);
+static void
+tiff12_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_rgb(dev);
+
+ set_dev_proc(dev, open_device, tiff_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page_seekable);
+ set_dev_proc(dev, close_device, tiff_close);
+ set_dev_proc(dev, get_params, tiff_get_params);
+ set_dev_proc(dev, put_params, tiff_put_params);
+}
+
+static void
+tiff24_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_rgb(dev);
+
+ set_dev_proc(dev, open_device, tiff_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page_seekable);
+ set_dev_proc(dev, close_device, tiff_close);
+ set_dev_proc(dev, get_params, tiff_get_params);
+ set_dev_proc(dev, put_params, tiff_put_params);
+}
const gx_device_tiff gs_tiff12nc_device = {
- prn_device_std_body(gx_device_tiff, tiff12_procs, "tiff12nc",
+ prn_device_std_body(gx_device_tiff, tiff12_initialize_device_procs, "tiff12nc",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0,
@@ -65,7 +80,7 @@ const gx_device_tiff gs_tiff12nc_device = {
};
const gx_device_tiff gs_tiff24nc_device = {
- prn_device_std_body(gx_device_tiff, tiff24_procs, "tiff24nc",
+ prn_device_std_body(gx_device_tiff, tiff24_initialize_device_procs, "tiff24nc",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0,
@@ -81,7 +96,7 @@ const gx_device_tiff gs_tiff24nc_device = {
};
const gx_device_tiff gs_tiff48nc_device = {
- prn_device_std_body(gx_device_tiff, tiff24_procs, "tiff48nc",
+ prn_device_std_body(gx_device_tiff, tiff24_initialize_device_procs, "tiff48nc",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0,
diff --git a/devices/gdevtifs.c b/devices/gdevtifs.c
index d72549f5..b937d0e3 100644
--- a/devices/gdevtifs.c
+++ b/devices/gdevtifs.c
@@ -558,8 +558,6 @@ tiff_downscale_and_print_page(gx_device_printer *dev, TIFF *tif,
if (code < 0)
return code;
- if (num_comps == 4)
- params->trap_w = params->trap_h = 1;
if (tfdev->icclink == NULL) {
code = gx_downscaler_init(&ds, (gx_device *)dev,
8, bpc, num_comps,
diff --git a/devices/gdevtknk.c b/devices/gdevtknk.c
index 7ea92326..bbc977dd 100644
--- a/devices/gdevtknk.c
+++ b/devices/gdevtknk.c
@@ -32,9 +32,16 @@ static dev_proc_map_rgb_color(tekink_map_rgb_color);
static dev_proc_map_color_rgb(tekink_map_color_rgb);
static dev_proc_print_page(tekink_print_page);
/* Since the print_page doesn't alter the device, this device can print in the background */
-static gx_device_procs tekink_procs =
- prn_color_procs(gdev_prn_open, gdev_prn_bg_output_page, gdev_prn_close,
- tekink_map_rgb_color, tekink_map_color_rgb);
+static void
+tekink_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_bg(dev);
+
+ set_dev_proc(dev, map_rgb_color, tekink_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, tekink_map_color_rgb);
+ set_dev_proc(dev, encode_color, tekink_map_rgb_color);
+ set_dev_proc(dev, decode_color, tekink_map_color_rgb);
+}
/*
Device descriptor for the Tek 4696.
@@ -43,7 +50,7 @@ static gx_device_procs tekink_procs =
aspect ratio is close to sqrt(2).
*/
const gx_device_printer far_data gs_tek4696_device =
- prn_device(tekink_procs,"tek4696",
+ prn_device(tekink_initialize_device_procs,"tek4696",
85,120, /* Page size in 10th of inches */
120,120, /* Resolution in DPI */
0.0,0.0,0.0,0.0, /* Margins */
diff --git a/devices/gdevtrac.c b/devices/gdevtrac.c
index 7fff3862..c3ad6dc7 100644
--- a/devices/gdevtrac.c
+++ b/devices/gdevtrac.c
@@ -260,33 +260,6 @@ trace_draw_thin_line(gx_device * dev,
}
static int
-trace_strip_tile_rectangle(gx_device * dev, const gx_strip_bitmap * tiles,
- int x, int y, int w, int h,
- gx_color_index color0, gx_color_index color1,
- int px, int py)
-{
- dmprintf6(dev->memory,"strip_tile_rectangle(x=%d, y=%d, w=%d, h=%d, colors=(0x%lx,0x%lx),\n",
- x, y, w, h, (ulong)color0, (ulong)color1);
- dmprintf8(dev->memory," size=(%d,%d) shift %u, rep=(%u,%u) shift %u, phase=(%d,%d))\n",
- tiles->size.x, tiles->size.y, tiles->shift,
- tiles->rep_width, tiles->rep_height, tiles->rep_shift, px, py);
- return 0;
-}
-
-static int
-trace_strip_copy_rop(gx_device * dev, const byte * sdata, int sourcex,
- uint sraster, gx_bitmap_id id,
- const gx_color_index * scolors,
- const gx_strip_bitmap * textures,
- const gx_color_index * tcolors,
- int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
-{
- dmputs(dev->memory,"**strip_copy_rop**\n");
- return 0;
-}
-
-static int
trace_strip_copy_rop2(gx_device * dev, const byte * sdata, int sourcex,
uint sraster, gx_bitmap_id id,
const gx_color_index * scolors,
@@ -447,8 +420,7 @@ static const gs_text_enum_procs_t trace_text_procs = {
static int
trace_text_begin(gx_device * dev, gs_gstate * pgs,
const gs_text_params_t * text, gs_font * font,
- gx_path * path, const gx_device_color * pdcolor,
- const gx_clip_path * pcpath, gs_memory_t * memory,
+ const gx_clip_path * pcpath,
gs_text_enum_t ** ppenum)
{
static const char *const tags[sizeof(text->operation) * 8] = {
@@ -463,6 +435,8 @@ trace_text_begin(gx_device * dev, gs_gstate * pgs,
int i;
gs_text_enum_t *pte;
int code;
+ const gx_device_color * pdcolor = gs_currentdevicecolor_inline(pgs);
+ gx_path * path = pgs->path;
dmputs(dev->memory,"text_begin(");
for (i = 0; i < countof(tags); ++i)
@@ -526,7 +500,7 @@ trace_text_begin(gx_device * dev, gs_gstate * pgs,
rc_alloc_struct_1(pte, gs_text_enum_t, &st_gs_text_enum, memory,
goto dflt, "trace_text_begin");
code = gs_text_enum_init(pte, &trace_text_procs, dev, pgs, text, font,
- path, pdcolor, pcpath, memory);
+ path, pcpath, memory);
if (code < 0)
goto dfree;
if ((text->operation & (TEXT_DO_CHARWIDTH | TEXT_RETURN_WIDTH)) &&
@@ -596,14 +570,41 @@ trace_text_begin(gx_device * dev, gs_gstate * pgs,
gs_free_object(memory, pte, "trace_text_begin");
dflt:
dmputs(dev->memory,") DEFAULTED\n");
- return gx_default_text_begin(dev, pgs, text, font, path, pdcolor,
- pcpath, memory, ppenum);
+ return gx_default_text_begin(dev, pgs, text, font,
+ pcpath, ppenum);
}
/* ---------------- The device definition ---------------- */
-#define TRACE_DEVICE_BODY(dname, ncomp, depth, map_rgb_color, map_color_rgb, map_cmyk_color, map_rgb_alpha_color)\
- std_device_dci_body(gx_device, 0, dname,\
+static void
+tr_base_initialize_device_procs(gx_device *dev,
+ dev_proc_map_rgb_color((*map_rgb_color)),
+ dev_proc_map_color_rgb((*map_color_rgb)),
+ dev_proc_map_cmyk_color((*map_cmyk_color)))
+{
+ set_dev_proc(dev, map_rgb_color, map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, trace_fill_rectangle);
+ set_dev_proc(dev, copy_mono, trace_copy_mono);
+ set_dev_proc(dev, copy_color, trace_copy_color);
+ set_dev_proc(dev, map_cmyk_color, map_cmyk_color);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
+ set_dev_proc(dev, copy_alpha, trace_copy_alpha);
+ set_dev_proc(dev, fill_path, trace_fill_path);
+ set_dev_proc(dev, stroke_path, trace_stroke_path);
+ set_dev_proc(dev, fill_mask, trace_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, trace_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, trace_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, trace_fill_triangle);
+ set_dev_proc(dev, draw_thin_line, trace_draw_thin_line);
+ set_dev_proc(dev, strip_tile_rectangle, trace_strip_tile_rectangle);
+ set_dev_proc(dev, begin_typed_image, trace_begin_typed_image);
+ set_dev_proc(dev, text_begin, trace_text_begin);
+ set_dev_proc(dev, strip_copy_rop2, trace_strip_copy_rop2);
+}
+
+#define TRACE_DEVICE_BODY(dname, ncomp, depth, init)\
+ std_device_dci_body(gx_device, init, dname,\
DEFAULT_WIDTH_10THS * X_DPI / 10,\
DEFAULT_HEIGHT_10THS * Y_DPI / 10,\
X_DPI, Y_DPI, ncomp, depth,\
@@ -611,93 +612,41 @@ trace_text_begin(gx_device * dev, gs_gstate * pgs,
(ncomp > 1 ? (1 << (depth / ncomp)) - 1 : 0),\
1 << (depth / ncomp),\
(ncomp > 1 ? 1 << (depth / ncomp) : 1)),\
-{\
- NULL, /* open_device */\
- NULL, /* get_initial_matrix */\
- NULL, /* sync_output */\
- NULL, /* output_page */\
- NULL, /* close_device */\
- map_rgb_color, /* differs */\
- map_color_rgb, /* differs */\
- trace_fill_rectangle,\
- NULL, /* tile_rectangle */\
- trace_copy_mono,\
- trace_copy_color,\
- NULL, /* draw_line */\
- NULL, /* get_bits */\
- NULL, /* get_params */\
- NULL, /* put_params */\
- map_cmyk_color, /* differs */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- map_rgb_alpha_color, /* differs */\
- gx_page_device_get_page_device,\
- NULL, /* get_alpha_bits */\
- trace_copy_alpha,\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- trace_fill_path,\
- trace_stroke_path,\
- trace_fill_mask,\
- trace_fill_trapezoid,\
- trace_fill_parallelogram,\
- trace_fill_triangle,\
- trace_draw_thin_line,\
- NULL, /* begin_image */\
- NULL, /* image_data */\
- NULL, /* end_image */\
- trace_strip_tile_rectangle,\
- trace_strip_copy_rop,\
- NULL, /* get_clipping_box */\
- trace_begin_typed_image,\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- NULL, /* create_compositor */\
- NULL, /* get_hardware_params */\
- trace_text_begin,\
- NULL, /* finish_copydevice */\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL, /* discard_transparency_layer */\
- NULL, /* get_color_mapping_procs */\
- NULL, /* get_color_comp_index */\
- NULL, /* encode_color */\
- NULL, /* decode_color */\
- NULL, /* pattern_manage */\
- NULL, /* fill_rectangle_hl_color */\
- NULL, /* include_color_space */\
- NULL, /* fill_linear_color_scanline */\
- NULL, /* fill_linear_color_trapezoid */\
- NULL, /* fill_linear_color_triangle */\
- NULL, /* update_spot_equivalent_colors */\
- NULL, /* ret_devn_params */\
- NULL, /* fillpage */\
- NULL, /* push_transparency_state */\
- NULL, /* pop_transparency_state */\
- NULL, /* put_image */\
- NULL, /* dev_spec_op */\
- NULL, /* copy_planes */\
- NULL, /* get_profile */\
- NULL, /* set_graphics_type_tag */\
- trace_strip_copy_rop2\
+}
+
+static void
+tr_mono_initialize_device_procs(gx_device *dev)
+{
+ tr_base_initialize_device_procs(dev,
+ gx_default_b_w_map_rgb_color,
+ gx_default_b_w_map_color_rgb, NULL);
+
}
const gx_device gs_tr_mono_device = {
- TRACE_DEVICE_BODY("tr_mono", 1, 1,
- gx_default_b_w_map_rgb_color,
- gx_default_b_w_map_color_rgb, NULL, NULL)
+ TRACE_DEVICE_BODY("tr_mono", 1, 1, tr_mono_initialize_device_procs)
};
+static void
+tr_rgb_initialize_device_procs(gx_device *dev)
+{
+ tr_base_initialize_device_procs(dev,
+ gx_default_rgb_map_rgb_color,
+ gx_default_rgb_map_color_rgb, NULL);
+}
+
const gx_device gs_tr_rgb_device = {
- TRACE_DEVICE_BODY("tr_rgb", 3, 24,
- gx_default_rgb_map_rgb_color,
- gx_default_rgb_map_color_rgb, NULL, NULL)
+ TRACE_DEVICE_BODY("tr_rgb", 3, 24, tr_rgb_initialize_device_procs)
};
+static void
+tr_cmyk_initialize_device_procs(gx_device *dev)
+{
+ tr_base_initialize_device_procs(dev,
+ NULL, cmyk_1bit_map_color_rgb,
+ cmyk_1bit_map_cmyk_color);
+}
+
const gx_device gs_tr_cmyk_device = {
- TRACE_DEVICE_BODY("tr_cmyk", 4, 4,
- NULL, cmyk_1bit_map_color_rgb,
- cmyk_1bit_map_cmyk_color, NULL)
+ TRACE_DEVICE_BODY("tr_cmyk", 4, 4, tr_cmyk_initialize_device_procs)
};
diff --git a/devices/gdevtsep.c b/devices/gdevtsep.c
index 1a52aede..10d3b633 100644
--- a/devices/gdevtsep.c
+++ b/devices/gdevtsep.c
@@ -31,6 +31,8 @@
* from 32-bit CMYK internal rendering)
*/
+/* #define PPM_COMBINED_OUTPUT */ /* Uncomment to get PPM output similar to pknraw */
+
#include "stdint_.h" /* for tiff.h */
#include "gdevtifs.h"
#include "gdevprn.h"
@@ -50,9 +52,6 @@
#include "gsicc_cache.h"
#include "gxdevsop.h"
#include "gsicc.h"
-#ifdef WITH_CAL
-#include "cal.h"
-#endif
/*
* Some of the code in this module is based upon the gdevtfnx.c module.
@@ -72,14 +71,22 @@
static dev_proc_print_page(tiffgray_print_page);
/* FIXME: From initial analysis this is NOT safe for bg_printing, but might be fixable */
-
-static const gx_device_procs tiffgray_procs =
-prn_color_params_procs(tiff_open, gdev_prn_output_page_seekable, tiff_close,
- gx_default_gray_map_rgb_color, gx_default_gray_map_color_rgb,
- tiff_get_params, tiff_put_params);
+static void
+tiffgray_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray(dev);
+
+ set_dev_proc(dev, open_device, tiff_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page_seekable);
+ set_dev_proc(dev, close_device, tiff_close);
+ set_dev_proc(dev, get_params, tiff_get_params);
+ set_dev_proc(dev, put_params, tiff_put_params);
+ set_dev_proc(dev, encode_color, gx_default_8bit_map_gray_color);
+ set_dev_proc(dev, decode_color, gx_default_8bit_map_color_gray);
+}
const gx_device_tiff gs_tiffgray_device = {
- prn_device_body(gx_device_tiff, tiffgray_procs, "tiffgray",
+ prn_device_body(gx_device_tiff, tiffgray_initialize_device_procs, "tiffgray",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* Margins */
@@ -109,18 +116,23 @@ dev_proc_open_device(tiff_open_s);
static dev_proc_print_page(tiffscaled_print_page);
static int tiff_set_icc_color_fields(gx_device_printer *pdev);
-static const gx_device_procs tiffscaled_procs =
-prn_color_params_procs(tiff_open,
- gdev_prn_output_page_seekable,
- tiff_close,
- gx_default_gray_map_rgb_color,
- gx_default_gray_map_color_rgb,
- tiff_get_params_downscale,
- tiff_put_params_downscale);
+static void
+tiffscaled_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray(dev);
+
+ set_dev_proc(dev, open_device, tiff_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page_seekable);
+ set_dev_proc(dev, close_device, tiff_close);
+ set_dev_proc(dev, get_params, tiff_get_params_downscale);
+ set_dev_proc(dev, put_params, tiff_put_params_downscale);
+ set_dev_proc(dev, encode_color, gx_default_8bit_map_gray_color);
+ set_dev_proc(dev, decode_color, gx_default_8bit_map_color_gray);
+}
const gx_device_tiff gs_tiffscaled_device = {
prn_device_body(gx_device_tiff,
- tiffscaled_procs,
+ tiffscaled_initialize_device_procs,
"tiffscaled",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
600, 600, /* 600 dpi by default */
@@ -143,20 +155,24 @@ const gx_device_tiff gs_tiffscaled_device = {
static dev_proc_print_page(tiffscaled8_print_page);
-static const gx_device_procs tiffscaled8_procs = {
- tiff_open_s, NULL, NULL, gdev_prn_output_page_seekable, tiff_close,
- gx_default_gray_map_rgb_color, gx_default_gray_map_color_rgb, NULL, NULL,
- NULL, NULL, NULL, NULL, tiff_get_params_downscale, tiff_put_params_downscale,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
- NULL, NULL, tiffscaled_spec_op
-};
+static void
+tiffscaled8_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_gray(dev);
+
+ set_dev_proc(dev, open_device, tiff_open_s);
+ set_dev_proc(dev, output_page, gdev_prn_output_page_seekable);
+ set_dev_proc(dev, close_device, tiff_close);
+ set_dev_proc(dev, get_params, tiff_get_params_downscale);
+ set_dev_proc(dev, put_params, tiff_put_params_downscale);
+ set_dev_proc(dev, dev_spec_op, tiffscaled_spec_op);
+ set_dev_proc(dev, encode_color, gx_default_8bit_map_gray_color);
+ set_dev_proc(dev, decode_color, gx_default_8bit_map_color_gray);
+}
const gx_device_tiff gs_tiffscaled8_device = {
prn_device_body(gx_device_tiff,
- tiffscaled8_procs,
+ tiffscaled8_initialize_device_procs,
"tiffscaled8",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
600, 600, /* 600 dpi by default */
@@ -179,20 +195,24 @@ const gx_device_tiff gs_tiffscaled8_device = {
static dev_proc_print_page(tiffscaled24_print_page);
-static const gx_device_procs tiffscaled24_procs = {
- tiff_open_s, NULL, NULL, gdev_prn_output_page_seekable, tiff_close,
- gx_default_rgb_map_rgb_color, gx_default_rgb_map_color_rgb, NULL, NULL,
- NULL, NULL, NULL, NULL, tiff_get_params_downscale, tiff_put_params_downscale,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
- NULL, NULL, tiffscaled_spec_op
-};
+static void
+tiffscaled24_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_rgb(dev);
+
+ set_dev_proc(dev, open_device, tiff_open_s);
+ set_dev_proc(dev, output_page, gdev_prn_output_page_seekable);
+ set_dev_proc(dev, close_device, tiff_close);
+ set_dev_proc(dev, get_params, tiff_get_params_downscale);
+ set_dev_proc(dev, put_params, tiff_put_params_downscale);
+ set_dev_proc(dev, dev_spec_op, tiffscaled_spec_op);
+ set_dev_proc(dev, encode_color, gx_default_rgb_map_rgb_color);
+ set_dev_proc(dev, decode_color, gx_default_rgb_map_color_rgb);
+}
const gx_device_tiff gs_tiffscaled24_device = {
prn_device_body(gx_device_tiff,
- tiffscaled24_procs,
+ tiffscaled24_initialize_device_procs,
"tiffscaled24",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
600, 600, /* 600 dpi by default */
@@ -215,20 +235,24 @@ const gx_device_tiff gs_tiffscaled24_device = {
static dev_proc_print_page(tiffscaled32_print_page);
-static const gx_device_procs tiffscaled32_procs = {
- tiff_open_s, NULL, NULL, gdev_prn_output_page_seekable, tiff_close,
- NULL, cmyk_8bit_map_color_cmyk, NULL, NULL, NULL, NULL, NULL, NULL,
- tiff_get_params_downscale_cmyk, tiff_put_params_downscale_cmyk,
- cmyk_8bit_map_cmyk_color, NULL, NULL, NULL, gx_page_device_get_page_device,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
- NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, tiffscaled_spec_op
-};
+static void
+tiffscaled32_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_cmyk8(dev);
+
+ set_dev_proc(dev, open_device, tiff_open_s);
+ set_dev_proc(dev, output_page, gdev_prn_output_page_seekable);
+ set_dev_proc(dev, close_device, tiff_close);
+ set_dev_proc(dev, get_params, tiff_get_params_downscale_cmyk);
+ set_dev_proc(dev, put_params, tiff_put_params_downscale_cmyk);
+ set_dev_proc(dev, dev_spec_op, tiffscaled_spec_op);
+ set_dev_proc(dev, encode_color, cmyk_8bit_map_cmyk_color);
+ set_dev_proc(dev, decode_color, cmyk_8bit_map_color_cmyk);
+}
const gx_device_tiff gs_tiffscaled32_device = {
prn_device_body(gx_device_tiff,
- tiffscaled32_procs,
+ tiffscaled32_initialize_device_procs,
"tiffscaled32",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
600, 600, /* 600 dpi by default */
@@ -251,16 +275,21 @@ const gx_device_tiff gs_tiffscaled32_device = {
static dev_proc_print_page(tiffscaled4_print_page);
-static const gx_device_procs tiffscaled4_procs = {
- tiff_open, NULL, NULL, gdev_prn_output_page_seekable, tiff_close,
- NULL, cmyk_8bit_map_color_cmyk, NULL, NULL, NULL, NULL, NULL, NULL,
- tiff_get_params_downscale_cmyk_ets, tiff_put_params_downscale_cmyk_ets,
- cmyk_8bit_map_cmyk_color, NULL, NULL, NULL, gx_page_device_get_page_device
-};
+static void
+tiffscaled4_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_cmyk8(dev);
+
+ set_dev_proc(dev, open_device, tiff_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page_seekable);
+ set_dev_proc(dev, close_device, tiff_close);
+ set_dev_proc(dev, get_params, tiff_get_params_downscale_cmyk_ets);
+ set_dev_proc(dev, put_params, tiff_put_params_downscale_cmyk_ets);
+}
const gx_device_tiff gs_tiffscaled4_device = {
prn_device_body(gx_device_tiff,
- tiffscaled4_procs,
+ tiffscaled4_initialize_device_procs,
"tiffscaled4",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
600, 600, /* 600 dpi by default */
@@ -519,20 +548,22 @@ tiffsep_spec_op(gx_device *dev_, int op, void *data, int datasize)
static dev_proc_print_page(tiffcmyk_print_page);
-#define cmyk_procs(p_map_color_rgb, p_map_cmyk_color)\
- tiff_open, NULL, NULL, gdev_prn_output_page_seekable, tiff_close,\
- NULL, p_map_color_rgb, NULL, NULL, NULL, NULL, NULL, NULL,\
- tiff_get_params, tiff_put_params,\
- p_map_cmyk_color, NULL, NULL, NULL, gx_page_device_get_page_device
-
/* 8-bit-per-plane separated CMYK color. */
-static const gx_device_procs tiffcmyk_procs = {
- cmyk_procs(cmyk_8bit_map_color_cmyk, cmyk_8bit_map_cmyk_color)
-};
+static void
+tiffcmyk_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_cmyk8(dev);
+
+ set_dev_proc(dev, open_device, tiff_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page_seekable);
+ set_dev_proc(dev, close_device, tiff_close);
+ set_dev_proc(dev, get_params, tiff_get_params);
+ set_dev_proc(dev, put_params, tiff_put_params);
+}
const gx_device_tiff gs_tiff32nc_device = {
- prn_device_body(gx_device_tiff, tiffcmyk_procs, "tiff32nc",
+ prn_device_body(gx_device_tiff, tiffcmyk_initialize_device_procs, "tiff32nc",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* Margins */
@@ -549,12 +580,20 @@ const gx_device_tiff gs_tiff32nc_device = {
/* 16-bit-per-plane separated CMYK color. */
-static const gx_device_procs tiff64nc_procs = {
- cmyk_procs(cmyk_16bit_map_color_cmyk, cmyk_16bit_map_cmyk_color)
-};
+static void
+tiff64_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs_cmyk16(dev);
+
+ set_dev_proc(dev, open_device, tiff_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page_seekable);
+ set_dev_proc(dev, close_device, tiff_close);
+ set_dev_proc(dev, get_params, tiff_get_params);
+ set_dev_proc(dev, put_params, tiff_put_params);
+}
const gx_device_tiff gs_tiff64nc_device = {
- prn_device_body(gx_device_tiff, tiff64nc_procs, "tiff64nc",
+ prn_device_body(gx_device_tiff, tiff64_initialize_device_procs, "tiff64nc",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI,
0, 0, 0, 0, /* Margins */
@@ -611,11 +650,12 @@ static dev_proc_encode_color(tiffsep_encode_color);
static dev_proc_decode_color(tiffsep_decode_color);
static dev_proc_update_spot_equivalent_colors(tiffsep_update_spot_equivalent_colors);
static dev_proc_ret_devn_params(tiffsep_ret_devn_params);
+static dev_proc_ret_devn_params_const(tiffsep_ret_devn_params_const);
static dev_proc_open_device(tiffsep1_prn_open);
static dev_proc_close_device(tiffsep1_prn_close);
-static dev_proc_put_params(tiffsep1_put_params);
static dev_proc_print_page(tiffsep1_print_page);
-static dev_proc_fill_path(sep1_fill_path);
+static dev_proc_encode_color(tiffsep1_encode_color);
+static dev_proc_decode_color(tiffsep1_decode_color);
/* common to tiffsep and tiffsepo1 */
#define tiffsep_devices_common\
@@ -637,28 +677,20 @@ static dev_proc_fill_path(sep1_fill_path);
gx_downscaler_params downscale;\
gs_devn_params devn_params; /* DeviceN generated parameters */\
equivalent_cmyk_color_params equiv_cmyk_colors;\
- bool warning_given /* avoid issuing lots of warnings */
+ bool warning_given; /* avoid issuing lots of warnings */\
+ gp_file *comp_file; /* Underlying file for tiff_comp */\
+ TIFF *tiff_comp; /* tiff file for comp file */\
+ gsicc_link_t *icclink /* link profile if we are doing post rendering */
/*
* A structure definition for a DeviceN type device
*/
typedef struct tiffsep_device_s {
tiffsep_devices_common;
- gp_file *comp_file; /* Underlying file for tiff_comp */
- TIFF *tiff_comp; /* tiff file for comp file */
- gsicc_link_t *icclink; /* link profile if we are doing post rendering */
} tiffsep_device;
-/* threshold array structure */
-typedef struct threshold_array_s {
- int dheight, dwidth;
- byte *dstart;
-} threshold_array_t;
-
typedef struct tiffsep1_device_s {
tiffsep_devices_common;
- threshold_array_t thresholds[GX_DEVICE_COLOR_MAX_COMPONENTS + 1]; /* one extra for Default */
- dev_t_proc_fill_path((*fill_path), gx_device); /* we forward to here */
} tiffsep1_device;
/* GC procedures */
@@ -701,80 +733,37 @@ gs_private_st_composite_final(st_tiffsep_device, tiffsep_device,
"tiffsep_device", tiffsep_device_enum_ptrs, tiffsep_device_reloc_ptrs,
tiffsep_device_finalize);
-/*
- * Macro definition for tiffsep device procedures
- */
-#define sep_device_procs(open, close, encode_color, decode_color, update_spot_colors,put_params, fill_path) \
-{ open,\
- gx_default_get_initial_matrix,\
- NULL, /* sync_output */\
- gdev_prn_output_page_seekable, /* output_page */\
- close, /* close */\
- NULL, /* map_rgb_color - not used */\
- tiffsep_decode_color, /* map_color_rgb */\
- NULL, /* fill_rectangle */\
- NULL, /* tile_rectangle */\
- NULL, /* copy_mono */\
- NULL, /* copy_color */\
- NULL, /* draw_line */\
- NULL, /* get_bits */\
- tiffsep_get_params, /* get_params */\
- put_params, /* put_params */\
- NULL, /* map_cmyk_color - not used */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- gx_page_device_get_page_device, /* get_page_device */\
- NULL, /* get_alpha_bits */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- fill_path, /* fill_path */\
- NULL, /* stroke_path */\
- NULL, /* fill_mask */\
- NULL, /* fill_trapezoid */\
- NULL, /* fill_parallelogram */\
- NULL, /* fill_triangle */\
- NULL, /* draw_thin_line */\
- NULL, /* begin_image */\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL, /* strip_copy_rop */\
- NULL, /* get_clipping_box */\
- NULL, /* begin_typed_image */\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- NULL, /* create_compositor */\
- NULL, /* get_hardware_params */\
- NULL, /* text_begin */\
- NULL, /* finish_copydevice */\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL, /* discard_transparency_layer */\
- tiffsep_get_color_mapping_procs,/* get_color_mapping_procs */\
- tiffsep_get_color_comp_index, /* get_color_comp_index */\
- encode_color, /* encode_color */\
- decode_color, /* decode_color */\
- NULL, /* pattern_manage */\
- NULL, /* fill_rectangle_hl_color */\
- NULL, /* include_color_space */\
- NULL, /* fill_linear_color_scanline */\
- NULL, /* fill_linear_color_trapezoid */\
- NULL, /* fill_linear_color_triangle */\
- update_spot_colors, /* update_spot_equivalent_colors */\
- tiffsep_ret_devn_params, /* ret_devn_params */\
- NULL, /* fillpage */\
- NULL, /* push_transparency_state */\
- NULL, /* pop_transparency_state */\
- NULL, /* put_image */\
- tiffsep_spec_op /* dev_spec_op */\
+static void
+tiffsep_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, tiffsep_prn_open);
+ set_dev_proc(dev, close_device, tiffsep_prn_close);
+ set_dev_proc(dev, map_color_rgb, tiffsep_decode_color);
+ set_dev_proc(dev, get_params, tiffsep_get_params);
+ set_dev_proc(dev, put_params, tiffsep_put_params);
+ set_dev_proc(dev, get_color_mapping_procs, tiffsep_get_color_mapping_procs);
+ set_dev_proc(dev, get_color_comp_index, tiffsep_get_color_comp_index);
+ set_dev_proc(dev, encode_color, tiffsep_encode_color);
+ set_dev_proc(dev, decode_color, tiffsep_decode_color);
+ set_dev_proc(dev, update_spot_equivalent_colors, tiffsep_update_spot_equivalent_colors);
+ set_dev_proc(dev, ret_devn_params, tiffsep_ret_devn_params);
+ set_dev_proc(dev, dev_spec_op, tiffsep_spec_op);
}
+static void
+tiffsep1_initialize_device_procs(gx_device *dev)
+{
+ tiffsep_initialize_device_procs(dev);
+ set_dev_proc(dev, open_device, tiffsep1_prn_open);
+ set_dev_proc(dev, close_device, tiffsep1_prn_close);
+ set_dev_proc(dev, encode_color, tiffsep1_encode_color);
+ set_dev_proc(dev, decode_color, tiffsep1_decode_color);
+ set_dev_proc(dev, map_color_rgb, cmyk_1bit_map_color_rgb);
+}
-#define tiffsep_devices_body(dtype, procs, dname, ncomp, pol, depth, mg, mc, sl, cn, print_page, compr)\
+#define tiffsep_devices_body(dtype, procs, dname, ncomp, pol, depth, mg, mc, sl, cn, print_page, compr, bpc)\
std_device_full_body_type_extended(dtype, &procs, dname,\
&st_tiffsep_device,\
(int)((long)(DEFAULT_WIDTH_10THS) * (X_DPI) / 10),\
@@ -801,7 +790,7 @@ gs_private_st_composite_final(st_tiffsep_device, tiffsep_device,
false, /* PrintSpotCMYK */\
compr /* COMPRESSION_* */,\
TIFF_DEFAULT_STRIP_SIZE,/* MaxStripSize */\
- 8, /* BitsPerComponent */\
+ bpc, /* BitsPerComponent */\
GS_SOFT_MAX_SPOTS, /* max_spots */\
false, /* Colorants not locked */\
GX_DOWNSCALER_PARAMS_DEFAULTS
@@ -811,19 +800,11 @@ gs_private_st_composite_final(st_tiffsep_device, tiffsep_device,
/*
* TIFF devices with CMYK process color model and spot color support.
*/
-static const gx_device_procs spot_cmyk_procs =
- sep_device_procs(tiffsep_prn_open, tiffsep_prn_close, tiffsep_encode_color, tiffsep_decode_color,
- tiffsep_update_spot_equivalent_colors, tiffsep_put_params, NULL);
-
-static const gx_device_procs spot1_cmyk_procs =
- sep_device_procs(tiffsep1_prn_open, tiffsep1_prn_close, tiffsep_encode_color, tiffsep_decode_color,
- tiffsep_update_spot_equivalent_colors, tiffsep1_put_params, sep1_fill_path);
-
const tiffsep_device gs_tiffsep_device =
{
- tiffsep_devices_body(tiffsep_device, spot_cmyk_procs, "tiffsep", ARCH_SIZEOF_GX_COLOR_INDEX, GX_CINFO_POLARITY_SUBTRACTIVE, GCIB, MAX_COLOR_VALUE, MAX_COLOR_VALUE, GX_CINFO_SEP_LIN, "DeviceCMYK", tiffsep_print_page, COMPRESSION_LZW),
+ tiffsep_devices_body(tiffsep_device, tiffsep_initialize_device_procs, "tiffsep", ARCH_SIZEOF_GX_COLOR_INDEX, GX_CINFO_POLARITY_SUBTRACTIVE, GCIB, MAX_COLOR_VALUE, MAX_COLOR_VALUE, GX_CINFO_SEP_LIN, "DeviceCMYK", tiffsep_print_page, COMPRESSION_LZW, 8),
/* devn_params specific parameters */
- { 8, /* Ignored - Bits per color */
+ { 8, /* Bits per color */
DeviceCMYKComponents, /* Names of color model colorants */
4, /* Number colorants for CMYK */
0, /* MaxSeparations has not been specified */
@@ -838,9 +819,9 @@ const tiffsep_device gs_tiffsep_device =
const tiffsep1_device gs_tiffsep1_device =
{
- tiffsep_devices_body(tiffsep1_device, spot1_cmyk_procs, "tiffsep1", ARCH_SIZEOF_GX_COLOR_INDEX, GX_CINFO_POLARITY_SUBTRACTIVE, GCIB, MAX_COLOR_VALUE, MAX_COLOR_VALUE, GX_CINFO_SEP_LIN, "DeviceCMYK", tiffsep1_print_page, COMPRESSION_CCITTFAX4),
+ tiffsep_devices_body(tiffsep1_device, tiffsep1_initialize_device_procs, "tiffsep1", ARCH_SIZEOF_GX_COLOR_INDEX, GX_CINFO_POLARITY_SUBTRACTIVE, GCIB, 1, 1, GX_CINFO_SEP_LIN, "DeviceCMYK", tiffsep1_print_page, COMPRESSION_CCITTFAX4, 1),
/* devn_params specific parameters */
- { 8, /* Ignored - Bits per color */
+ { 1, /* Bits per color */
DeviceCMYKComponents, /* Names of color model colorants */
4, /* Number colorants for CMYK */
0, /* MaxSeparations has not been specified */
@@ -851,35 +832,16 @@ const tiffsep1_device gs_tiffsep1_device =
},
{ true }, /* equivalent CMYK colors for spot colors */
false, /* warning_given */
- { {0} }, /* threshold arrays */
- 0, /* fill_path */
};
-#undef NC
-#undef SL
-#undef ENCODE_COLOR
-#undef DECODE_COLOR
-
-static const uint32_t bit_order[32]={
-#if ARCH_IS_BIG_ENDIAN
- 0x80000000, 0x40000000, 0x20000000, 0x10000000, 0x08000000, 0x04000000, 0x02000000, 0x01000000,
- 0x00800000, 0x00400000, 0x00200000, 0x00100000, 0x00080000, 0x00040000, 0x00020000, 0x00010000,
- 0x00008000, 0x00004000, 0x00002000, 0x00001000, 0x00000800, 0x00000400, 0x00000200, 0x00000100,
- 0x00000080, 0x00000040, 0x00000020, 0x00000010, 0x00000008, 0x00000004, 0x00000002, 0x00000001
-#else
- 0x00000080, 0x00000040, 0x00000020, 0x00000010, 0x00000008, 0x00000004, 0x00000002, 0x00000001,
- 0x00008000, 0x00004000, 0x00002000, 0x00001000, 0x00000800, 0x00000400, 0x00000200, 0x00000100,
- 0x00800000, 0x00400000, 0x00200000, 0x00100000, 0x00080000, 0x00040000, 0x00020000, 0x00010000,
- 0x80000000, 0x40000000, 0x20000000, 0x10000000, 0x08000000, 0x04000000, 0x02000000, 0x01000000
-#endif
- };
+#undef GCIB
/*
* The following procedures are used to map the standard color spaces into
* the color components for the tiffsep device.
*/
static void
-tiffsep_gray_cs_to_cm(gx_device * dev, frac gray, frac out[])
+tiffsep_gray_cs_to_cm(const gx_device * dev, frac gray, frac out[])
{
int * map = ((tiffsep_device *) dev)->devn_params.separation_order_map;
@@ -887,7 +849,7 @@ tiffsep_gray_cs_to_cm(gx_device * dev, frac gray, frac out[])
}
static void
-tiffsep_rgb_cs_to_cm(gx_device * dev, const gs_gstate *pgs,
+tiffsep_rgb_cs_to_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
int * map = ((tiffsep_device *) dev)->devn_params.separation_order_map;
@@ -896,10 +858,10 @@ tiffsep_rgb_cs_to_cm(gx_device * dev, const gs_gstate *pgs,
}
static void
-tiffsep_cmyk_cs_to_cm(gx_device * dev,
+tiffsep_cmyk_cs_to_cm(const gx_device * dev,
frac c, frac m, frac y, frac k, frac out[])
{
- const gs_devn_params *devn = tiffsep_ret_devn_params(dev);
+ const gs_devn_params *devn = tiffsep_ret_devn_params_const(dev);
const int *map = devn->separation_order_map;
int j;
@@ -943,8 +905,9 @@ static const gx_cm_color_map_procs tiffsep_cm_procs = {
* to color model conversion routines.
*/
static const gx_cm_color_map_procs *
-tiffsep_get_color_mapping_procs(const gx_device * dev)
+tiffsep_get_color_mapping_procs(const gx_device * dev, const gx_device **tdev)
{
+ *tdev = dev;
return &tiffsep_cm_procs;
}
@@ -1013,6 +976,14 @@ tiffsep_ret_devn_params(gx_device * dev)
return &pdev->devn_params;
}
+static const gs_devn_params *
+tiffsep_ret_devn_params_const (const gx_device * dev)
+{
+ const tiffsep_device * pdev = (const tiffsep_device *)dev;
+
+ return &pdev->devn_params;
+}
+
/* Get parameters. We provide a default CRD. */
static int
tiffsep_get_params(gx_device * pdev, gs_param_list * plist)
@@ -1127,10 +1098,6 @@ tiffsep_put_params(gx_device * pdev, gs_param_list * plist)
param_signal_error(plist, param_name, code);
return code;
}
- /* Because pdevn->BitsPerComponent is ignored for tiffsep(1) we have to get
- * the value based on whether we're called from tiffsep or tiffsep1
- */
- bpc = (dev_proc(pdev, put_params) == tiffsep1_put_params) ? 1 : 8;
if (!tiff_compression_allowed(pdevn->Compression, bpc)) {
errprintf(pdevn->memory, "Invalid compression setting for this bitdepth\n");
@@ -1197,29 +1164,9 @@ tiffsep_put_params(gx_device * pdev, gs_param_list * plist)
return(code);
}
-static int
-tiffsep1_put_params(gx_device * pdev, gs_param_list * plist)
-{
- tiffsep1_device * const tfdev = (tiffsep1_device *) pdev;
- int code;
-
- if ((code = tiffsep_put_params(pdev, plist)) < 0)
- return code;
-
- /* put_params may have changed the fill_path proc -- we need it set to ours */
- if (dev_proc(pdev, fill_path) != sep1_fill_path) {
- tfdev->fill_path = dev_proc(pdev, fill_path);
- set_dev_proc(pdev, fill_path, sep1_fill_path);
- }
- return code;
-
-}
-
static void build_comp_to_sep_map(tiffsep_device *, short *);
static int number_output_separations(int, int, int, int);
static int create_separation_file_name(tiffsep_device *, char *, uint, int, bool);
-static int sep1_ht_order_to_thresholds(gx_device *pdev, const gs_gstate *pgs);
-dev_proc_fill_path(clist_fill_path);
/* Open the tiffsep1 device. This will now be using planar buffers so that
we are not limited to 64 bit chunky */
@@ -1259,8 +1206,8 @@ tiffsep1_prn_open(gx_device * pdev)
for (k = 0; k < GS_CLIENT_COLOR_MAX_COMPONENTS; k++) {
pdev_sep->devn_params.separation_order_map[k] = k;
}
- pdev->color_info.depth = pdev->color_info.num_components *
- pdev_sep->devn_params.bitspercomponent;
+ pdev->color_info.depth = bpc_to_depth(pdev->color_info.num_components,
+ pdev_sep->devn_params.bitspercomponent);
pdev->color_info.separable_and_linear = GX_CINFO_SEP_LIN;
code = gdev_prn_open_planar(pdev, true);
while (pdev->child)
@@ -1271,11 +1218,6 @@ tiffsep1_prn_open(gx_device * pdev)
ppdev->file = NULL;
pdev->icc_struct->supports_devn = true;
- /* gdev_prn_open_planae may have changed the fill_path proc -- we need it set to ours */
- if (dev_proc(pdev, fill_path) != sep1_fill_path) {
- pdev_sep->fill_path = pdev->procs.fill_path;
- set_dev_proc(pdev, fill_path, sep1_fill_path);
- }
return code;
}
@@ -1310,6 +1252,7 @@ tiffsep1_prn_close(gx_device * pdev)
goto done;
}
+#ifndef PPM_COMBINED_OUTPUT /* Only delete the default file if it isn't our pppraw output */
/* If we are doing separate pages, delete the old default file */
if (parsed.iodev == iodev_default(pdev->memory)) { /* filename includes "%nnd" */
char *compname = (char *)gs_alloc_bytes(pdev->memory, gp_file_name_sizeof, "tiffsep1_prn_close(compname)");
@@ -1333,6 +1276,7 @@ tiffsep1_prn_close(gx_device * pdev)
}
gs_free_object(pdev->memory, compname, "tiffsep1_prn_close(compname)");
}
+#endif
build_comp_to_sep_map((tiffsep_device *)tfdev, map_comp_to_sep);
/* Close the separation files */
@@ -1366,24 +1310,6 @@ done:
return code;
}
-
-static int
-sep1_fill_path(gx_device * pdev, const gs_gstate * pgs,
- gx_path * ppath, const gx_fill_params * params,
- const gx_device_color * pdevc, const gx_clip_path * pcpath)
-{
- tiffsep1_device * const tfdev = (tiffsep1_device *)pdev;
-
- /* If we haven't already converted the ht into thresholds, do it now */
- if( tfdev->thresholds[0].dstart == NULL) {
- int code = sep1_ht_order_to_thresholds(pdev, pgs);
-
- if (code < 0)
- return code;
- }
- return (tfdev->fill_path)( pdev, pgs, ppath, params, pdevc, pcpath);
-}
-
/*
* This routine will check to see if the color component name match those
* that are available amoung the current device's color components.
@@ -1648,45 +1574,13 @@ tiffsep_prn_open(gx_device * pdev)
gx_device_printer *ppdev = (gx_device_printer *)pdev;
tiffsep_device *pdev_sep = (tiffsep_device *) pdev;
int code, k;
- bool force_pdf, force_ps;
cmm_dev_profile_t *profile_struct;
gsicc_rendering_param_t rendering_params;
/* Use our own warning and error message handlers in libtiff */
tiff_set_handlers();
- /* There are 2 approaches to the use of a DeviceN ICC output profile.
- One is to simply limit our device to only output the colorants
- defined in the output ICC profile. The other is to use the
- DeviceN ICC profile to color manage those N colorants and
- to let any other separations pass through unmolested. The define
- LIMIT_TO_ICC sets the option to limit our device to only the ICC
- colorants defined by -sICCOutputColors (or to the ones that are used
- as default names if ICCOutputColors is not used). The pass through option
- (LIMIT_TO_ICC set to 0) makes life a bit more difficult since we don't
- know if the page_spot_colors overlap with any spot colorants that exist
- in the DeviceN ICC output profile. Hence we don't know how many planes
- to use for our device. This is similar to the issue when processing
- a PostScript file. So that I remember, the cases are
- DeviceN Profile? limit_icc Result
- 0 0 force_pdf 0 force_ps 0 (no effect)
- 0 0 force_pdf 0 force_ps 0 (no effect)
- 1 0 force_pdf 0 force_ps 1 (colorants not known)
- 1 1 force_pdf 1 force_ps 0 (colorants known)
- */
code = dev_proc(pdev, get_profile)((gx_device *)pdev, &profile_struct);
- if (profile_struct->spotnames == NULL) {
- force_pdf = false;
- force_ps = false;
- } else {
-#if LIMIT_TO_ICC
- force_pdf = true;
- force_ps = false;
-#else
- force_pdf = false;
- force_ps = true;
-#endif
- }
/* For the planar device we need to set up the bit depth of each plane.
For other devices this is handled in check_device_separable where
@@ -1698,21 +1592,31 @@ tiffsep_prn_open(gx_device * pdev)
/* With planar the depth can be more than 64. Update the color
info to reflect the proper depth and number of planes */
pdev_sep->warning_given = false;
- if ((pdev_sep->devn_params.page_spot_colors >= 0 || force_pdf) && !force_ps) {
- if (force_pdf) {
- /* Use the information that is in the ICC profle. We will be here
- anytime that we have limited ourselves to a fixed number
- of colorants specified by the DeviceN ICC profile */
+ if (pdev_sep->devn_params.page_spot_colors >= 0) {
+
+ /* PDF case, as the page spot colors are known. */
+ if (profile_struct->spotnames != NULL) {
+
+ /* PDF case, NCLR ICC profile with spot names. The ICC spots
+ will use up some of the max_spots values. If max_spots is
+ too small to accomodate even the ICC spots, throw an error */
+ if (profile_struct->spotnames->count - 4 > pdev_sep->max_spots ||
+ profile_struct->spotnames->count < 4 ||
+ profile_struct->spotnames->count <
+ profile_struct->device_profile[0]->num_comps) {
+ gs_warn("ICC profile colorant names count error");
+ return_error(gs_error_rangecheck);
+ }
pdev->color_info.num_components =
- (pdev_sep->devn_params.separations.num_separations
- + pdev_sep->devn_params.num_std_colorant_names);
+ (profile_struct->spotnames->count
+ + pdev_sep->devn_params.page_spot_colors);
if (pdev->color_info.num_components > pdev->color_info.max_components)
pdev->color_info.num_components = pdev->color_info.max_components;
- /* Limit us only to the ICC colorants */
- pdev->color_info.max_components = pdev->color_info.num_components;
} else {
- /* Do not allow the spot count to update if we have specified the
- colorants already */
+
+ /* Use the information that is in the page spot color. We should
+ be here if we are processing a PDF and we do not have a DeviceN
+ ICC profile specified for output */
if (!(pdev_sep->lock_colorants)) {
pdev->color_info.num_components =
(pdev_sep->devn_params.page_spot_colors
@@ -1725,8 +1629,13 @@ tiffsep_prn_open(gx_device * pdev)
/* We do not know how many spots may occur on the page.
For this reason we go ahead and allocate the maximum that we
have available. Note, lack of knowledge only occurs in the case
- of PS files. With PDF we know a priori the number of spot
- colorants. */
+ of PS files. With PDF we know a priori the number of spot
+ colorants. However, the first time the device is opened,
+ pdev_sep->devn_params.page_spot_colors is -1 even if we are
+ dealing with a PDF file, so we will first find ourselves here,
+ which will set num_comp based upon max_spots + 4. If -dMaxSpots
+ was set (Default is GS_SOFT_MAX_SPOTS which is 10) ,
+ it is made use of here. */
if (!(pdev_sep->lock_colorants)) {
int num_comp = pdev_sep->max_spots + 4; /* Spots + CMYK */
if (num_comp > GS_CLIENT_COLOR_MAX_COMPONENTS)
@@ -2090,60 +1999,6 @@ build_cmyk_raster_line_fromplanar_4bpc(gs_get_bits_params_t *params, byte * dest
}
}
-static int
-sep1_ht_order_to_thresholds(gx_device *pdev, const gs_gstate *pgs)
-{
- tiffsep1_device * const tfdev = (tiffsep1_device *)pdev;
- gs_memory_t *mem = pdev->memory;
- int code;
-
- /* If we have thresholds, clear the pointers */
- if( tfdev->thresholds[0].dstart != NULL) {
- tfdev->thresholds[0].dstart = NULL;
- } else {
- int nc, j;
- gx_ht_order *d_order;
- threshold_array_t *dptr;
-
- if (pgs->dev_ht == NULL) {
- emprintf(mem, "sep1_order_to_thresholds: no dev_ht available\n");
- return_error(gs_error_rangecheck); /* error condition */
- }
- nc = pgs->dev_ht->num_comp;
- for( j=0; j<nc; j++ ) {
- int x, y;
-
- d_order = &(pgs->dev_ht->components[j].corder);
- dptr = &(tfdev->thresholds[j]);
- /* In order to use the function from gsht.c we need to set the color_info */
- /* values it uses to reflect the eventual 1-bit output, not contone */
- pdev->color_info.dither_grays = pdev->color_info.dither_colors = 2;
- pdev->color_info.polarity = GX_CINFO_POLARITY_ADDITIVE;
- code = gx_ht_construct_threshold(d_order, pdev, pgs, j);
- if( code < 0 ) {
- emprintf(mem,
- "sep1_order_to_thresholds: conversion to thresholds failed.\n");
- return_error(code); /* error condition */
- }
- pdev->color_info.dither_grays = pdev->color_info.dither_colors = 256;
- pdev->color_info.polarity = GX_CINFO_POLARITY_SUBTRACTIVE;
- /* Invert the thresholds so we (almost) match pbmraw dithered output */
- for (y=0; y<d_order->full_height; y++) {
- byte *s = d_order->threshold;
- int s_offset = y * d_order->width;
-
- for (x=0; x<d_order->width; x++) {
- s[s_offset + x] = 256 - s[s_offset + x];
- }
- }
- dptr->dstart = d_order->threshold;
- dptr->dwidth = d_order->width;
- dptr->dheight = d_order->full_height;
- }
- }
- return 0;
-}
-
/*
* This function prints out CMYK value with separation name for every
* separation. Where the original alternate colour space was DeviceCMYK, and the output
@@ -2167,31 +2022,24 @@ print_cmyk_equivalent_colors(tiffsep_device *tfdev, int num_comp, cmyk_composite
for (comp_num = 0; comp_num < num_comp; comp_num++) {
int sep_num = tfdev->devn_params.separation_order_map[comp_num];
- if (sep_num < tfdev->devn_params.num_std_colorant_names) {
- if (gp_file_name_sizeof < strlen(tfdev->devn_params.std_colorant_names[sep_num])) {
- if (name)
- gs_free_object(tfdev->memory, name, "tiffsep_print_cmyk_equivalent_colors(name)");
- return_error(gs_error_rangecheck);
- }
- strcpy(name, tfdev->devn_params.std_colorant_names[sep_num]);
- } else {
+ if (sep_num >= tfdev->devn_params.num_std_colorant_names) {
sep_num -= tfdev->devn_params.num_std_colorant_names;
if (gp_file_name_sizeof < tfdev->devn_params.separations.names[sep_num].size) {
if (name)
gs_free_object(tfdev->memory, name, "tiffsep_print_cmyk_equivalent_colors(name)");
return_error(gs_error_rangecheck);
}
-
- memcpy(name, (char *)tfdev->devn_params.separations.names[sep_num].data, tfdev->devn_params.separations.names[sep_num].size);
+ memcpy(name,
+ (char *)tfdev->devn_params.separations.names[sep_num].data,
+ tfdev->devn_params.separations.names[sep_num].size);
name[tfdev->devn_params.separations.names[sep_num].size] = '\0';
+ dmlprintf5(tfdev->memory, "%%%%SeparationColor: \"%s\" 100%% ink = %hd %hd %hd %hd CMYK\n",
+ name,
+ cmyk_map[comp_num].c,
+ cmyk_map[comp_num].m,
+ cmyk_map[comp_num].y,
+ cmyk_map[comp_num].k);
}
-
- dmlprintf5(tfdev->memory, "%%%%SeparationColor: \"%s\" 100%% ink = %hd %hd %hd %hd CMYK\n",
- name,
- cmyk_map[comp_num].c,
- cmyk_map[comp_num].m,
- cmyk_map[comp_num].y,
- cmyk_map[comp_num].k);
}
if (name) {
@@ -2215,11 +2063,10 @@ tiffsep_print_page(gx_device_printer * pdev, gp_file * file)
int num_std_colorants = tfdev->devn_params.num_std_colorant_names;
int num_order = tfdev->devn_params.num_separation_order_names;
int num_spot = tfdev->devn_params.separations.num_separations;
- int num_comp, comp_num, sep_num, code = 0, code1 = 0;
+ int num_comp, comp_num, code = 0, code1 = 0;
cmyk_composite_map cmyk_map[GX_DEVICE_COLOR_MAX_COMPONENTS];
char *name = NULL;
bool double_f = false;
- int base_filename_length = length_base_file_name(tfdev, &double_f);
int save_depth = pdev->color_info.depth;
int save_numcomps = pdev->color_info.num_components;
const char *fmt;
@@ -2235,21 +2082,6 @@ tiffsep_print_page(gx_device_printer * pdev, gp_file * file)
if (!name)
return_error(gs_error_VMerror);
- /* Print the names of the spot colors */
- if (num_order == 0) {
- for (sep_num = 0; sep_num < num_spot; sep_num++) {
- copy_separation_name(tfdev, name,
- gp_file_name_sizeof - base_filename_length - SUFFIX_SIZE, sep_num, 0);
- dmlprintf1(pdev->memory, "%%%%SeparationName: %s", name);
- dmlprintf4(pdev->memory, " CMYK = [ %d %d %d %d ]\n",
- tfdev->equiv_cmyk_colors.color[sep_num].c,
- tfdev->equiv_cmyk_colors.color[sep_num].m,
- tfdev->equiv_cmyk_colors.color[sep_num].y,
- tfdev->equiv_cmyk_colors.color[sep_num].k
- );
- }
- }
-
/*
* Since different pages may have different spot colors, if this is for a
* page after Page 1, we require that each output file is unique with a "fmt"
@@ -2372,7 +2204,7 @@ tiffsep_print_page(gx_device_printer * pdev, gp_file * file)
}
}
- build_cmyk_map((gx_device*) tfdev, num_comp, &tfdev->equiv_cmyk_colors, cmyk_map);
+ build_cmyk_map((gx_device *)tfdev, num_comp, &tfdev->equiv_cmyk_colors, cmyk_map);
if (tfdev->PrintSpotCMYK) {
code = print_cmyk_equivalent_colors(tfdev, num_comp, cmyk_map);
if (code < 0) {
@@ -2578,26 +2410,6 @@ done:
return code;
}
-#ifdef WITH_CAL
-static void
-ht_callback(cal_halftone_data_t *ht, void *arg)
-{
- tiffsep1_device *tfdev = (tiffsep1_device *)arg;
- int num_std_colorants = tfdev->devn_params.num_std_colorant_names;
- int num_order = tfdev->devn_params.num_separation_order_names;
- int num_spot = tfdev->devn_params.separations.num_separations;
- int comp_num;
- int num_comp = number_output_separations(tfdev->color_info.num_components,
- num_std_colorants, num_order, num_spot);
- /* Deliberately cast away const, cos tifflib has a bad interface. */
- unsigned char *data = (unsigned char *)ht->data;
-
- for (comp_num = 0; comp_num < num_comp; comp_num++) {
- TIFFWriteScanline(tfdev->tiff[comp_num], &data[ht->raster*comp_num], ht->y, 0);
- }
-}
-#endif
-
/*
* Output the image data for the tiff separation (tiffsep1) device. The data
* for the tiffsep1 device is written in separate planes to separate files.
@@ -2613,6 +2425,8 @@ tiffsep1_print_page(gx_device_printer * pdev, gp_file * file)
int num_order = tfdev->devn_params.num_separation_order_names;
int num_spot = tfdev->devn_params.separations.num_separations;
int num_comp, comp_num, code = 0, code1 = 0;
+ bool double_f = false;
+ int base_filename_length = length_base_file_name((tiffsep_device *)tfdev, &double_f);
short map_comp_to_sep[GX_DEVICE_COLOR_MAX_COMPONENTS];
char *name = NULL;
int save_depth = pdev->color_info.depth;
@@ -2620,9 +2434,7 @@ tiffsep1_print_page(gx_device_printer * pdev, gp_file * file)
const char *fmt;
gs_parsed_file_name_t parsed;
int non_encodable_count = 0;
-
- if (tfdev->thresholds[0].dstart == NULL)
- return_error(gs_error_rangecheck);
+ cmyk_composite_map cmyk_map[GX_DEVICE_COLOR_MAX_COMPONENTS];
name = (char *)gs_alloc_bytes(pdev->memory, gp_file_name_sizeof, "tiffsep1_print_page(name)");
if (!name)
@@ -2630,6 +2442,20 @@ tiffsep1_print_page(gx_device_printer * pdev, gp_file * file)
build_comp_to_sep_map((tiffsep_device *)tfdev, map_comp_to_sep);
+ /* Print the names of the spot colors */
+ if (num_order == 0) {
+ for (comp_num = 0; comp_num < num_spot; comp_num++) {
+ copy_separation_name((tiffsep_device *)tfdev, name,
+ gp_file_name_sizeof - base_filename_length - SUFFIX_SIZE, comp_num, 0);
+ dmlprintf1(pdev->memory, "%%%%SeparationName: %s", name);
+ dmlprintf4(pdev->memory, " CMYK = [ %d %d %d %d ]\n",
+ tfdev->equiv_cmyk_colors.color[comp_num].c,
+ tfdev->equiv_cmyk_colors.color[comp_num].m,
+ tfdev->equiv_cmyk_colors.color[comp_num].y,
+ tfdev->equiv_cmyk_colors.color[comp_num].k
+ );
+ }
+ }
/*
* Since different pages may have different spot colors, if this is for a
* page after Page 1, we require that each output file is unique with a "fmt"
@@ -2650,23 +2476,27 @@ tiffsep1_print_page(gx_device_printer * pdev, gp_file * file)
/* If the output file is on disk and the name contains a page #, */
/* then delete the previous file. */
if (pdev->file != NULL && parsed.iodev == iodev_default(pdev->memory) && fmt) {
- long count1 = pdev->PageCount;
char *compname = (char *)gs_alloc_bytes(pdev->memory, gp_file_name_sizeof, "tiffsep1_print_page(compname)");
if (!compname) {
code = gs_note_error(gs_error_VMerror);
goto done;
}
+#ifndef PPM_COMBINED_OUTPUT
+ {
+ long count1 = pdev->PageCount;
- gx_device_close_output_file((gx_device *)pdev, pdev->fname, pdev->file);
- pdev->file = NULL;
+ gx_device_close_output_file((gx_device *)pdev, pdev->fname, pdev->file);
+ pdev->file = NULL;
+ while (*fmt != 'l' && *fmt != '%')
+ --fmt;
+ if (*fmt == 'l')
+ gs_sprintf(compname, parsed.fname, count1);
+ else
+ gs_sprintf(compname, parsed.fname, (int)count1);
+ parsed.iodev->procs.delete_file(parsed.iodev, compname);
+ }
+#endif /* PPM_COMBINED_OUTPUT */
- while (*fmt != 'l' && *fmt != '%')
- --fmt;
- if (*fmt == 'l')
- gs_sprintf(compname, parsed.fname, count1);
- else
- gs_sprintf(compname, parsed.fname, (int)count1);
- parsed.iodev->procs.delete_file(parsed.iodev, compname);
/* we always need an open printer (it will get deleted in tiffsep1_prn_close */
code = gdev_prn_open_printer((gx_device *)pdev, 1);
@@ -2675,10 +2505,16 @@ tiffsep1_print_page(gx_device_printer * pdev, gp_file * file)
goto done;
}
}
-
/* Set up the separation output files */
- num_comp = number_output_separations( tfdev->color_info.num_components,
- num_std_colorants, num_order, num_spot);
+ num_comp = number_output_separations(tfdev->color_info.num_components,
+ num_std_colorants, num_order, num_spot);
+ build_cmyk_map((gx_device *)tfdev, num_comp, &tfdev->equiv_cmyk_colors, cmyk_map);
+ if (tfdev->PrintSpotCMYK) {
+ code = print_cmyk_equivalent_colors((tiffsep_device *)tfdev, num_comp, cmyk_map);
+ if (code < 0) {
+ goto done;
+ }
+ }
for (comp_num = 0; comp_num < num_comp; comp_num++ ) {
int sep_num = map_comp_to_sep[comp_num];
@@ -2708,7 +2544,7 @@ tiffsep1_print_page(gx_device_printer * pdev, gp_file * file)
}
}
- pdev->color_info.depth = 8; /* Create files for 8 bit gray */
+ pdev->color_info.depth = 1;
pdev->color_info.num_components = 1;
code = tiff_set_fields_for_printer(pdev, tfdev->tiff[comp_num], 1, 0, tfdev->write_datetime);
tiff_set_gray_fields(pdev, tfdev->tiff[comp_num], 1, tfdev->Compression, tfdev->MaxStripSize);
@@ -2721,51 +2557,15 @@ tiffsep1_print_page(gx_device_printer * pdev, gp_file * file)
} /* end initialization of separation files */
- { /* Get the expanded contone line, halftone and write out the dithered separations */
+ { /* Get the halftoned line and write out the separations */
byte *planes[GS_CLIENT_COLOR_MAX_COMPONENTS];
int width = tfdev->width;
- int raster_plane = bitmap_raster(width * 8);
- int dithered_raster = ((7 + width) / 8) + ARCH_SIZEOF_LONG;
- int pixel, y;
+ int raster_plane = bitmap_raster(width);
+ int y;
gs_get_bits_params_t params;
gs_int_rect rect;
- uint32_t *dithered_line = NULL;
-
-#ifdef WITH_CAL
- cal_context *cal = pdev->memory->gs_lib_ctx->core->cal_ctx;
- cal_halftone *cal_ht = NULL;
- cal_matrix matrix = { 1.0f, 0.0f, 0.0f, 1.0f, 0.0f, 0.0f };
-
- cal_ht = cal_halftone_init(cal,
- pdev->memory->non_gc_memory,
- pdev->width,
- pdev->height,
- &matrix,
- comp_num,
- NULL,
- 0,
- 0,
- pdev->width,
- pdev->height,
- 0);
- if (cal_ht != NULL) {
- for (comp_num = 0; comp_num < num_comp; comp_num++)
- if (cal_halftone_add_screen(cal,
- pdev->memory->non_gc_memory,
- cal_ht,
- 0,
- tfdev->thresholds[comp_num].dwidth,
- tfdev->thresholds[comp_num].dheight,
- 0,
- 0,
- tfdev->thresholds[comp_num].dstart) < 0)
- goto cal_fail;
- } else
-#endif
- /* the dithered_line is assumed to be 32-bit aligned by the alloc */
- dithered_line = (uint32_t *)gs_alloc_bytes(pdev->memory, dithered_raster,
- "tiffsep1_print_page");
+ /* the line is assumed to be 32-bit aligned by the alloc */
memset(planes, 0, sizeof(*planes) * GS_CLIENT_COLOR_MAX_COMPONENTS);
/* Return planar data */
@@ -2785,15 +2585,6 @@ tiffsep1_print_page(gx_device_printer * pdev, gp_file * file)
}
}
-#ifdef WITH_CAL
- if (code < 0 || (cal_ht == NULL && dithered_line == NULL)) {
-#else
- if (code < 0 || dithered_line == NULL) {
-#endif
- code = gs_note_error(gs_error_VMerror);
- goto cleanup;
- }
-
for (comp_num = 0; comp_num < num_comp; comp_num++ )
TIFFCheckpointDirectory(tfdev->tiff[comp_num]);
@@ -2806,86 +2597,77 @@ tiffsep1_print_page(gx_device_printer * pdev, gp_file * file)
/* We have to reset the pointers since get_bits_rect will have moved them */
for (comp_num = 0; comp_num < num_comp; comp_num++)
params.data[comp_num] = planes[comp_num];
- code = (*dev_proc(pdev, get_bits_rectangle))((gx_device *)pdev, &rect, &params, NULL);
+ code = (*dev_proc(pdev, get_bits_rectangle))((gx_device *)pdev, &rect, &params);
if (code < 0)
break;
-#ifdef WITH_CAL
- if(cal_ht != NULL) {
- if (cal_halftone_process_planar(cal_ht,
- pdev->memory->non_gc_memory,
- (const byte * const *)&params.data[0],
- ht_callback,
- tfdev) < 0)
- goto cal_fail;
- } else
-#endif
- /* Dither the separation and write it out */
+ /* write it out */
for (comp_num = 0; comp_num < num_comp; comp_num++ ) {
-
-/***** #define SKIP_HALFTONING_FOR_TIMING *****/ /* uncomment for timing test */
-#ifndef SKIP_HALFTONING_FOR_TIMING
-
- /*
- * Define 32-bit writes by default. Testing shows that while this is more
- * complex code, it runs measurably and consistently faster than the more
- * obvious 8-bit code. The 8-bit code is kept to help future optimization
- * efforts determine what affects tight loop optimization. Subtracting the
- * time when halftoning is skipped shows that the 32-bit halftoning is
- * 27% faster.
- */
-#define USE_32_BIT_WRITES
- byte *thresh_line_base = tfdev->thresholds[comp_num].dstart +
- ((y % tfdev->thresholds[comp_num].dheight) *
- tfdev->thresholds[comp_num].dwidth) ;
- byte *thresh_ptr = thresh_line_base;
- byte *thresh_limit = thresh_ptr + tfdev->thresholds[comp_num].dwidth;
+ int i;
byte *src = params.data[comp_num];
-#ifdef USE_32_BIT_WRITES
- uint32_t *dest = dithered_line;
- uint32_t val = 0;
- const uint32_t *mask = &bit_order[0];
-#else /* example 8-bit code */
- byte *dest = dithered_line;
- byte val = 0;
- byte mask = 0x80;
-#endif /* USE_32_BIT_WRITES */
-
- for (pixel = 0; pixel < width; pixel++, src++) {
-#ifdef USE_32_BIT_WRITES
- if (*src < *thresh_ptr++)
- val |= *mask;
- if (++mask == &(bit_order[32])) {
- *dest++ = val;
- val = 0;
- mask = &bit_order[0];
- }
-#else /* example 8-bit code */
- if (*src < *thresh_ptr++)
- val |= mask;
- mask >>= 1;
- if (mask == 0) {
- *dest++ = val;
- val = 0;
- mask = 0x80;
- }
-#endif /* USE_32_BIT_WRITES */
- if (thresh_ptr >= thresh_limit)
- thresh_ptr = thresh_line_base;
- } /* end src pixel loop - collect last bits if any */
- /* the following relies on their being enough 'pad' in dithered_line */
-#ifdef USE_32_BIT_WRITES
- if (mask != &bit_order[0]) {
- *dest = val;
+
+ /* TIFF 1-bit is additive, invert the data */
+ for (i=0; i<raster_plane; i++)
+ *src++ ^= 0xff; /* invert the data */
+ src = params.data[comp_num];
+ TIFFWriteScanline(tfdev->tiff[comp_num], src, y, 0);
+ } /* end component loop */
+#ifdef PPM_COMBINED_OUTPUT
+ {
+ int i;
+
+ if (y == 0) {
+ gp_fprintf(pdev->file, "P6\n");
+ gp_fprintf(pdev->file, "# Image generated by %s (device=pkmraw)\n", gs_product);
+ gp_fprintf(pdev->file, "%d %d\n255\n", pdev->width, pdev->height);
}
-#else /* example 8-bit code */
- if (mask != 0x80) {
- *dest = val;
+ for (i=0; i<pdev->width; i += 8) {
+ int b, ib = i>>3;
+ byte C = *((byte *)(params.data[0]) + ib);
+ byte M = *((byte *)(params.data[1]) + ib);
+ byte Y = *((byte *)(params.data[2]) + ib);
+ byte K = *((byte *)(params.data[3]) + ib);
+ byte mask = 128;
+
+ for (b=7; b >= 0; b--) {
+ byte RGB[3];
+
+ if (i + (8-b) > pdev->width)
+ break;
+ if ((K & mask) != 0) {
+ RGB[0] = (C & mask) == 0 ? 0 : 255;
+ RGB[1] = (M & mask) == 0 ? 0 : 255;
+ RGB[2] = (Y & mask) == 0 ? 0 : 255;
+ } else {
+ RGB[0] = RGB[1] = RGB[2] = 0;
+ }
+ /* If there are any spot colors, add them in proportionally to this dot */
+ if (num_comp > 4) {
+ uint64_t SPOT[4] = { 0, 0, 0, 0 }; /* accumulate frac colorants */
+ int s;
+ uint64_t denom_scale = frac_1 * (num_comp - 3) / 255;
+
+ for (s=4; s<num_comp; s++) {
+ if ((*((byte *)(params.data[s]) + ib) & mask) == 0) {
+ SPOT[0] += cmyk_map[s].c;
+ SPOT[1] += cmyk_map[s].m;
+ SPOT[2] += cmyk_map[s].y;
+ SPOT[3] += cmyk_map[s].k;
+ }
+ }
+ for (s=0; s<4; s++)
+ SPOT[s] /= denom_scale; /* map to 0..255 range */
+ RGB[0] = RGB[0] > SPOT[0] + SPOT[3] ? RGB[0] -= SPOT[0] + SPOT[3] : 0;
+ RGB[1] = RGB[1] > SPOT[1] + SPOT[3] ? RGB[1] -= SPOT[1] + SPOT[3] : 0;
+ RGB[2] = RGB[2] > SPOT[2] + SPOT[3] ? RGB[2] -= SPOT[2] + SPOT[3] : 0;
+ }
+ gp_fwrite(RGB, 3, 1, pdev->file);
+ mask >>= 1;
+ }
}
-#endif /* USE_32_BIT_WRITES */
-#endif /* SKIP_HALFTONING_FOR_TIMING */
- TIFFWriteScanline(tfdev->tiff[comp_num], (tdata_t)dithered_line, y, 0);
- } /* end component loop */
+ gp_fflush(pdev->file);
+ }
+#endif /* PPM_COMBINED_OUTPUT */
}
/* Update the strip data */
for (comp_num = 0; comp_num < num_comp; comp_num++ ) {
@@ -2908,17 +2690,7 @@ tiffsep1_print_page(gx_device_printer * pdev, gp_file * file)
}
code = code1;
-#ifdef WITH_CAL
- if(0) {
-cal_fail:
- code = gs_error_unknownerror;
- }
- cal_halftone_fin(cal_ht, pdev->memory->non_gc_memory);
-#endif
-
/* free any allocations and exit with code */
-cleanup:
- gs_free_object(pdev->memory, dithered_line, "tiffsep1_print_page");
for (comp_num = 0; comp_num < num_comp; comp_num++) {
gs_free_object(pdev->memory, planes[comp_num], "tiffsep1_print_page");
}
@@ -2937,6 +2709,39 @@ done:
return code;
}
+/*
+ * Encode a list of colorant values into a gx_color_index_value.
+ */
+static gx_color_index
+tiffsep1_encode_color(gx_device *dev, const gx_color_value colors[])
+{
+ gx_color_index color = 0;
+ int i = 0;
+ int ncomp = dev->color_info.num_components;
+
+ for (; i < ncomp; i++) {
+ color <<= 1;
+ color |= colors[i] == gx_max_color_value;
+ }
+ return (color == gx_no_color_index ? color ^ 1 : color);
+}
+
+/*
+ * Decode a gx_color_index value back to a list of colorant values.
+ */
+static int
+tiffsep1_decode_color(gx_device * dev, gx_color_index color, gx_color_value * out)
+{
+ int i = 0;
+ int ncomp = dev->color_info.num_components;
+
+ for (; i < ncomp; i++) {
+ out[ncomp - i - 1] = (color & 1) ? gx_max_color_value : 0;
+ color >>= 1;
+ }
+ return 0;
+}
+
/* The tiffscaled contone devices have to be able to change their color model
to allow a more flexible use of the post render ICC profile with the output
intent. For example, if we are wanting to render to a CMYK intermediate
@@ -2969,24 +2774,25 @@ tiff_open_s(gx_device *pdev)
memset(&(pdev->procs), 0, sizeof(pdev->procs));
switch (pdev->icc_struct->device_profile[GS_DEFAULT_DEVICE_PROFILE]->num_comps) {
case 1:
- pdev->procs = tiffscaled8_procs;
+ pdev->initialize_device_procs = tiffscaled8_initialize_device_procs;
pdev->color_info.dither_colors = 0;
pdev->color_info.max_color = 0;
break;
case 3:
- pdev->procs = tiffscaled24_procs;
+ pdev->initialize_device_procs = tiffscaled24_initialize_device_procs;
pdev->color_info.dither_colors = 0;
pdev->color_info.max_color = 0;
break;
case 4:
- pdev->procs = tiffscaled32_procs;
+ pdev->initialize_device_procs = tiffscaled32_initialize_device_procs;
pdev->color_info.dither_colors = 256;
pdev->color_info.max_color = 255;
break;
}
+ pdev->initialize_device_procs(pdev);
+ /* We know pdev->procs.initialize_device is NULL */
check_device_separable(pdev);
gx_device_fill_in_procs(pdev);
}
return tiff_open(pdev);
}
-
diff --git a/devices/gdevupd.c b/devices/gdevupd.c
index badc8041..66359847 100644
--- a/devices/gdevupd.c
+++ b/devices/gdevupd.c
@@ -90,6 +90,7 @@ There are two compile-time options for this driver:
#include "gdevprn.h" /** Printer-superclass header */
#include "gsparam.h" /** For the Parameter-Handling (optional) */
+#include "gxgetbit.h"
#include <stdlib.h> /** for rand */
#include <limits.h> /** for INT_MIN */
@@ -209,33 +210,21 @@ static int upd_procs_map( upd_device *udev);
/* Prototype of the Device-Structure (the only thing exported!) */
/* ------------------------------------------------------------------- */
-/**
-"uniprint" needs a procedure-table of its own, since it provides several
-optional procedures. Simpler-Drivers (e.g. non-color-drivers) may use
-prn_std_procs instead of defining their own procedure-table.
-*/
-
#define upd_set_dev_proc(dev, p, proc) \
((dev)->std_procs.p = (dev)->orig_procs.p = (proc))
-static gx_device_procs upd_procs = { /** Table of procedures */
- upd_open, /** open-function, upd-special */
- gx_default_get_initial_matrix, /** retrieve matrix */
- gx_default_sync_output, /** sync display */
- gdev_prn_output_page, /** superclass-print (calls back) */
- upd_close, /** close-function, upd-special */
- gx_default_map_rgb_color, /** RGB-mapping */
- gx_default_map_color_rgb, /** reverse mapping */
- NULL, /** fill_rectangle */
- NULL, /** tile_rectangle */
- NULL, /** copy_mono */
- NULL, /** copy_color */
- NULL, /** draw_line */
- gx_default_get_bits, /** reads scanlines, e.g. for the driver */
- upd_get_params, /** Export parameters, upd-special */
- upd_put_params, /** Import parameters, upd-special */
- gx_default_map_cmyk_color /** KCMY-mapping */
-}; /** */
+static void
+upd_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, upd_open);
+ set_dev_proc(dev, output_page, gdev_prn_output_page);
+ set_dev_proc(dev, close_device, upd_close);
+ set_dev_proc(dev, map_rgb_color, gx_default_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_default_map_color_rgb);
+ set_dev_proc(dev, get_params, upd_get_params);
+ set_dev_proc(dev, put_params, upd_put_params);
+ set_dev_proc(dev, map_cmyk_color, gx_default_map_cmyk_color);
+}
/**
The prototype-instance of the device-structure _must_ have the name
@@ -256,7 +245,7 @@ and the reader might directly skip to the section titled
*/
upd_device far_data gs_uniprint_device = { /** */
- prn_device_body(upd_device, upd_procs, /** The Type and Procedures */
+ prn_device_body(upd_device, upd_initialize_device_procs, /** The Type and Init Proc */
"uniprint", /** External name of the Device */
DEFAULT_WIDTH_10THS, /** X-Size (1/10") */
DEFAULT_HEIGHT_10THS, /** Y-Size (1/10") */
@@ -1035,6 +1024,8 @@ upd_print_page(gx_device_printer *pdev, gp_file *out)
const upd_p upd = udev->upd;
const int *const ints = upd ? upd->ints : NULL;
int error,need,yfill;
+ gs_int_rect rect;
+ gs_get_bits_params_t params;
#if UPD_SIGNAL /* variables required for signal-handling only */
void (*oldint )(int) = NULL;
@@ -1102,6 +1093,11 @@ upd_print_page(gx_device_printer *pdev, gp_file *out)
upd->ixpass = 0;
upd->icomp = -1; /* Enforces initial selection */
upd->lf = -1; /* Enforces initial selection */
+
+ rect.p.x = 0;
+ rect.q.x = pdev->width;
+ params.x_offset = 0;
+ params.raster = bitmap_raster(pdev->width * pdev->color_info.depth);
/*
* Main Loop
*/
@@ -1118,14 +1114,24 @@ upd_print_page(gx_device_printer *pdev, gp_file *out)
if(upd->gsheight > upd->yscnbuf) {
- if(0 > (*dev_proc(udev,get_bits))((gx_device *) udev,
- upd->yscnbuf,upd->gsbuf,&upd->gsscan)) {
+ rect.p.y = upd->yscnbuf;
+ rect.q.y = upd->yscnbuf+1;
+
+ params.options = (GB_ALIGN_ANY |
+ (GB_RETURN_COPY | GB_RETURN_POINTER) |
+ GB_OFFSET_0 |
+ GB_RASTER_STANDARD | GB_PACKING_CHUNKY |
+ GB_COLORS_NATIVE | GB_ALPHA_NONE);
+ params.data[0] = upd->gsbuf;
+ if(0 > (*dev_proc(udev,get_bits_rectangle))((gx_device *) udev,
+ &rect,&params)) {
#if UPD_MESSAGES & UPD_M_WARNING
errprintf(udev->memory, "get_bits aborted with error, yscnbuf = %4d\n",
upd->yscnbuf);
#endif
break;
}
+ upd->gsscan = params.data[0];
} else {
memset(upd->gsscan = upd->gsbuf,0,upd->ngsbuf);
diff --git a/devices/gdevwpr2.c b/devices/gdevwpr2.c
index c91e82a1..eeb94896 100644
--- a/devices/gdevwpr2.c
+++ b/devices/gdevwpr2.c
@@ -147,10 +147,20 @@ static dev_proc_put_params(win_pr2_put_params);
static int win_pr2_set_bpp(gx_device * dev, int depth);
-static const gx_device_procs win_pr2_procs =
-prn_color_params_procs(win_pr2_open, gdev_prn_output_page, win_pr2_close,
- win_pr2_map_rgb_color, win_pr2_map_color_rgb,
- win_pr2_get_params, win_pr2_put_params);
+static void
+win_pr2_initialize_device_procs(gx_device *dev)
+{
+ gdev_prn_initialize_device_procs(dev);
+
+ set_dev_proc(dev, open_device, win_pr2_open);
+ set_dev_proc(dev, close_device, win_pr2_close);
+ set_dev_proc(dev, map_rgb_color, win_pr2_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, win_pr2_map_color_rgb);
+ set_dev_proc(dev, get_params, win_pr2_get_params);
+ set_dev_proc(dev, put_params, win_pr2_put_params);
+ set_dev_proc(dev, encode_color, win_pr2_map_rgb_color);
+ set_dev_proc(dev, decode_color, win_pr2_map_color_rgb);
+}
#define PARENT_WINDOW HWND_DESKTOP
BOOL CALLBACK CancelDlgProc(HWND, UINT, WPARAM, LPARAM);
@@ -197,8 +207,11 @@ struct gx_device_win_pr2_s {
gx_device_win_pr2 far_data gs_mswinpr2_device =
{
- prn_device_std_body(gx_device_win_pr2, win_pr2_procs, "mswinpr2",
- DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS, 72.0, 72.0,
+ prn_device_std_body(gx_device_win_pr2,
+ win_pr2_initialize_device_procs,
+ "mswinpr2",
+ DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
+ 72.0, 72.0,
0, 0, 0, 0,
0, win_pr2_print_page), /* depth = 0 */
0, /* hdcprn */
diff --git a/devices/gdevx.c b/devices/gdevx.c
index 438af172..ee5aedcb 100644
--- a/devices/gdevx.c
+++ b/devices/gdevx.c
@@ -52,106 +52,12 @@ static void update_do_flush(gx_device_X *);
static void do_flush_text(gx_device_X *);
/* Driver procedures */
-/* (External procedures are declared in gdevx.h.) */
-/*extern int gdev_x_open(gx_device_X *);*/
-static dev_proc_open_device(x_open);
-static dev_proc_get_initial_matrix(x_get_initial_matrix);
-static dev_proc_sync_output(x_sync);
-static dev_proc_output_page(x_output_page);
-/*extern int gdev_x_close(gx_device_X *);*/
-static dev_proc_close_device(x_close);
-/*extern dev_proc_map_rgb_color(gdev_x_map_rgb_color);*/
-/*extern dev_proc_map_color_rgb(gdev_x_map_color_rgb);*/
-static dev_proc_fill_rectangle(x_fill_rectangle);
-static dev_proc_copy_mono(x_copy_mono);
-static dev_proc_copy_color(x_copy_color);
-/*extern dev_proc_get_params(gdev_x_get_params);*/
-/*extern dev_proc_put_params(gdev_x_put_params);*/
-static dev_proc_get_page_device(x_get_page_device);
-static dev_proc_strip_tile_rectangle(x_strip_tile_rectangle);
-static dev_proc_get_bits_rectangle(x_get_bits_rectangle);
-/*extern dev_proc_get_xfont_procs(gdev_x_finish_copydevice);*/
-static dev_proc_fillpage(x_fillpage);
/* The device descriptor */
#define x_device(this_device, dev_body) \
const gx_device_X this_device = { \
dev_body, \
- { /* std_procs */ \
- x_open, \
- x_get_initial_matrix, \
- x_sync, \
- x_output_page, \
- x_close, \
- gdev_x_map_rgb_color, \
- gdev_x_map_color_rgb, \
- x_fill_rectangle, \
- NULL, /* tile_rectangle */ \
- x_copy_mono, \
- x_copy_color, \
- NULL, /* draw_line */ \
- NULL, /* get_bits */ \
- gdev_x_get_params, \
- gdev_x_put_params, \
- NULL, /* map_cmyk_color */ \
- NULL, \
- NULL, /* get_xfont_device */ \
- NULL, /* map_rgb_alpha_color */ \
- x_get_page_device, \
- NULL, /* get_alpha_bits */ \
- NULL, /* copy_alpha */ \
- NULL, /* get_band */ \
- NULL, /* copy_rop */ \
- NULL, /* fill_path */ \
- NULL, /* stroke_path */ \
- NULL, /* fill_mask */ \
- NULL, /* fill_trapezoid */ \
- NULL, /* fill_parallelogram */ \
- NULL, /* fill_triangle */ \
- NULL, /* draw_thin_line */ \
- NULL, /* begin_image */ \
- NULL, /* image_data */ \
- NULL, /* end_image */ \
- x_strip_tile_rectangle, \
- NULL, /* strip_copy_rop */ \
- NULL, /* get_clipping_box */ \
- NULL, /* begin_typed_image */ \
- x_get_bits_rectangle, \
- NULL, /* map_color_rgb_alpha */ \
- NULL, /* create_compositor */ \
- NULL, /* get_hardware_params */ \
- NULL, /* text_begin */ \
- gdev_x_finish_copydevice, \
- NULL, /* begin_transparency_group */ \
- NULL, /* end_transparency_group */ \
- NULL, /* begin_transparency_mask */ \
- NULL, /* end_transparency_mask */ \
- NULL, /* discard_transparency_layer */ \
- NULL, /* get_color_mapping_procs */ \
- NULL, /* get_color_comp_index */ \
- NULL, /* encode_color */ \
- NULL, /* decode_color */ \
- NULL, /* pattern_manage */ \
- NULL, /* fill_rectangle_hl_color */ \
- NULL, /* include_color_space */ \
- NULL, /* fill_linear_color_scanline */ \
- NULL, /* fill_linear_color_trapezoid */ \
- NULL, /* fill_linear_color_triangle */ \
- NULL, /* update_spot_equivalent_colors */ \
- NULL, /* ret_devn_params */ \
- x_fillpage, /* fillpage */ \
- NULL, /* push_transparency_state */ \
- NULL, /* pop_transparency_state */ \
- NULL, /* put_image */ \
- NULL, /* dev_spec_op */ \
- NULL, /* copy_planes */ \
- NULL, /* get_profile */ \
- NULL, /* set_graphics_type_tag */ \
- NULL, \
- NULL, \
- NULL, \
- NULL \
- }, \
+ { 0 },\
gx_device_bbox_common_initial(0 /*false*/, 1 /*true*/, 1 /*true*/), \
0 /*false*/, /* is_buffered */ \
1 /*true*/, /* IsPageDevice */ \
@@ -256,14 +162,18 @@ gs_public_st_suffix_add1_final(st_device_X, gx_device_X,
x_finalize, st_device_bbox, buffer);
x_device(gs_x11_device,
- std_device_color_stype_body(gx_device_X, 0, "x11", &st_device_X,
+ std_device_color_stype_body(gx_device_X,
+ gdev_x_initialize_device_procs,
+ "x11", &st_device_X,
FAKE_RES * DEFAULT_WIDTH_10THS / 10,
FAKE_RES * DEFAULT_HEIGHT_10THS / 10, /* x and y extent (nominal) */
FAKE_RES, FAKE_RES, /* x and y density (nominal) */
24, 255, 256 ))
x_device(gs_x11alpha_device,
- std_device_dci_alpha_type_body(gx_device_X, 0, "x11alpha", &st_device_X,
+ std_device_dci_alpha_type_body(gx_device_X,
+ gdev_x_initialize_device_procs,
+ "x11alpha", &st_device_X,
FAKE_RES * DEFAULT_WIDTH_10THS / 10,
FAKE_RES * DEFAULT_HEIGHT_10THS / 10, /* x and y extent (nominal) */
FAKE_RES, FAKE_RES, /* x and y density (nominal) */
@@ -284,7 +194,7 @@ GC gc, XImage * pi, int sx, int sy, int dx, int dy, unsigned w, unsigned h);
END
/* Open the device. Most of the code is in gdevxini.c. */
-static int
+int
x_open(gx_device * dev)
{
gx_device_X *xdev = (gx_device_X *) dev;
@@ -310,7 +220,7 @@ x_open(gx_device * dev)
}
/* Close the device. */
-static int
+int
x_close(gx_device * dev)
{
gx_device_X *xdev = (gx_device_X *) dev;
@@ -321,7 +231,7 @@ x_close(gx_device * dev)
/* Get initial matrix for X device. */
/* This conflicts seriously with the code for page devices; */
/* we only do it if Ghostview is active. */
-static void
+void
x_get_initial_matrix(gx_device * dev, gs_matrix * pmat)
{
gx_device_X *xdev = (gx_device_X *) dev;
@@ -339,7 +249,7 @@ x_get_initial_matrix(gx_device * dev, gs_matrix * pmat)
}
/* Synchronize the display with the commands already given. */
-static int
+int
x_sync(gx_device * dev)
{
gx_device_X *xdev = (gx_device_X *) dev;
@@ -366,7 +276,7 @@ gdev_x_send_event(gx_device_X *xdev, Atom msg)
}
/* Output "page" */
-static int
+int
x_output_page(gx_device * dev, int num_copies, int flush)
{
gx_device_X *xdev = (gx_device_X *) dev;
@@ -389,7 +299,7 @@ x_output_page(gx_device * dev, int num_copies, int flush)
}
/* Fill a rectangle with a color. */
-static int
+int
x_fill_rectangle(gx_device * dev,
int x, int y, int w, int h, gx_color_index gscolor)
{
@@ -420,7 +330,7 @@ x_fill_rectangle(gx_device * dev,
}
/* Copy a monochrome bitmap. */
-static int
+int
x_copy_mono(gx_device * dev,
const byte * base, int sourcex, int raster, gx_bitmap_id id,
int x, int y, int w, int h,
@@ -642,7 +552,8 @@ x_copy_image(gx_device_X * xdev, const byte * base, int sourcex, int raster,
}
return 0;
}
-static int
+
+int
x_copy_color(gx_device * dev,
const byte * base, int sourcex, int raster, gx_bitmap_id id,
int x, int y, int w, int h)
@@ -662,14 +573,14 @@ x_copy_color(gx_device * dev,
/* Get the page device. We reimplement this so that we can make this */
/* device be a page device conditionally. */
-static gx_device *
+gx_device *
x_get_page_device(gx_device * dev)
{
return (((gx_device_X *) dev)->IsPageDevice ? dev : (gx_device *) 0);
}
/* Tile a rectangle. */
-static int
+int
x_strip_tile_rectangle(gx_device * dev, const gx_strip_bitmap * tiles,
int x, int y, int w, int h,
gx_color_index zero, gx_color_index one,
@@ -751,9 +662,9 @@ x_strip_tile_rectangle(gx_device * dev, const gx_strip_bitmap * tiles,
}
/* Read bits back from the screen. */
-static int
+int
x_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
- gs_get_bits_params_t * params, gs_int_rect ** unread)
+ gs_get_bits_params_t * params)
{
gx_device_X *xdev = (gx_device_X *) dev;
int depth = dev->color_info.depth;
@@ -785,7 +696,7 @@ x_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
!(options & GB_RASTER_ALL)
)
return
- gx_default_get_bits_rectangle(dev, prect, params, unread);
+ gx_default_get_bits_rectangle(dev, prect, params);
params->options =
GB_COLORS_NATIVE | GB_ALPHA_NONE | GB_PACKING_CHUNKY |
GB_RETURN_COPY | GB_OFFSET_0 |
@@ -805,22 +716,6 @@ x_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
} else
update_do_flush(xdev);
/*
- * If we want a list of unread rectangles, turn on graphics
- * exposures, and accept exposure events.
- */
- /******
- ****** FOLLOWING IS WRONG. XGetImage DOES NOT GENERATE
- ****** EXPOSURE EVENTS.
- ******/
-#if GET_IMAGE_EXPOSURES
- if (unread) {
- XSetGraphicsExposures(xdev->dpy, xdev->gc, True);
- XGetWindowAttributes(xdev->dpy, xdev->win, &attributes);
- XSelectInput(xdev->dpy, xdev->win,
- attributes.your_event_mask | ExposureMask);
- }
-#endif /* GET_IMAGE_EXPOSURES */
- /*
* The X library doesn't provide any way to specify the desired
* bit or byte ordering for the result, so we may have to swap the
* bit or byte order.
@@ -898,56 +793,13 @@ x_get_bits_rectangle(gx_device * dev, const gs_int_rect * prect,
}
XDestroyImage(image);
}
- if (unread) {
-#if GET_IMAGE_EXPOSURES
- XEvent event;
-#endif /* GET_IMAGE_EXPOSURES */
-
- *unread = 0;
-#if GET_IMAGE_EXPOSURES
- /* Read any exposure events. */
- XWindowEvent(xdev->dpy, xdev->win, ExposureMask, &event);
- if (event.type == GraphicsExpose) {
- gs_int_rect *rects = (gs_int_rect *)
- gs_alloc_bytes(dev->memory, sizeof(gs_int_rect),
- "x_get_bits_rectangle");
- int num_rects = 0;
-
- for (;;) {
- if (rects == 0) {
- code = gs_note_error(gs_error_VMerror);
- break;
- }
-#define xevent (*(XGraphicsExposeEvent *)&event)
- rects[num_rects].q.x = xevent.width +
- (rects[num_rects].p.x = xevent.x);
- rects[num_rects].q.y = xevent.height +
- (rects[num_rects].p.y = xevent.y);
- ++num_rects;
- if (!xevent.count)
- break;
-#undef xevent
- rects = gs_resize_object(dev->memory, rects,
- (num_rects + 1) * sizeof(gs_int_rect),
- "x_get_bits_rectangle");
- }
- if (code >= 0) {
- *unread = rects;
- code = num_rects;
- }
- }
- /* Restore the window state. */
- XSetGraphicsExposures(xdev->dpy, xdev->gc, False);
- XSelectInput(xdev->dpy, xdev->win, attributes.your_event_mask);
-#endif /* GET_IMAGE_EXPOSURES */
- }
return code;
}
/* Supplying a fillpage prevents the erasepage optimisation
device being installed.
*/
-static int
+int
x_fillpage(gx_device *dev, gs_gstate * pgs, gx_device_color *pdevc)
{
return gx_default_fillpage(dev, pgs, pdevc);
diff --git a/devices/gdevx.h b/devices/gdevx.h
index b35d4d85..5e352f3f 100644
--- a/devices/gdevx.h
+++ b/devices/gdevx.h
@@ -227,6 +227,19 @@ dev_proc_map_rgb_color(gdev_x_map_rgb_color); /* gdevxcmp.c */
dev_proc_map_color_rgb(gdev_x_map_color_rgb); /* gdevxcmp.c */
dev_proc_get_params(gdev_x_get_params); /* gdevxini.c */
dev_proc_put_params(gdev_x_put_params); /* gdevxini.c */
-dev_proc_finish_copydevice(gdev_x_finish_copydevice); /* gdevxini.c */
+dev_proc_initialize_device_procs(gdev_x_initialize_device_procs); /* gdevxini.c */
+dev_proc_open_device(x_open);
+dev_proc_get_initial_matrix(x_get_initial_matrix);
+dev_proc_sync_output(x_sync);
+dev_proc_output_page(x_output_page);
+dev_proc_close_device(x_close);
+dev_proc_fill_rectangle(x_fill_rectangle);
+dev_proc_copy_mono(x_copy_mono);
+dev_proc_copy_color(x_copy_color);
+dev_proc_get_page_device(x_get_page_device);
+dev_proc_strip_tile_rectangle(x_strip_tile_rectangle);
+dev_proc_get_bits_rectangle(x_get_bits_rectangle);
+dev_proc_fillpage(x_fillpage);
+
#endif /* gdevx_INCLUDED */
diff --git a/devices/gdevxalt.c b/devices/gdevxalt.c
index 0290c8c6..34157d4a 100644
--- a/devices/gdevxalt.c
+++ b/devices/gdevxalt.c
@@ -26,6 +26,7 @@
#include "gsdevice.h" /* for gs_copydevice */
#include "gdevx.h"
#include "gsbitops.h"
+#include "gxgetbit.h"
void
gs_shared_init(void);
@@ -117,7 +118,9 @@ x_forward_output_page(gx_device * dev, int num_copies, int flush)
if ((code = get_dev_target(&tdev, dev)) < 0)
return code;
- return (*dev_proc(tdev, output_page)) (tdev, num_copies, flush);
+ code = (*dev_proc(tdev, output_page)) (tdev, num_copies, flush);
+ dev->PageCount = tdev->PageCount;
+ return code;
}
static int
@@ -295,18 +298,20 @@ x_forward_copy_color(gx_device * dev, const byte * base, int sourcex,
}
static int
-x_forward_get_bits(gx_device * dev, int y, byte * str, byte ** actual_data)
+x_forward_get_bits_rectangle(gx_device * dev, const gs_int_rect *prect,
+ gs_get_bits_params_t *params)
{
gx_device *tdev;
int code;
if ((code = get_dev_target(&tdev, dev)) < 0)
return code;
- return (*dev_proc(tdev, get_bits)) (tdev, y, str, actual_data);
+ return (*dev_proc(tdev, get_bits_rectangle)) (tdev, prect, params);
}
static int
-x_wrap_get_bits(gx_device * dev, int y, byte * str, byte ** actual_data)
+x_wrap_get_bits_rectangle(gx_device * dev, const gs_int_rect *prect,
+ gs_get_bits_params_t *params)
{
int depth = dev->color_info.depth;
gx_device *tdev;
@@ -330,9 +335,17 @@ x_wrap_get_bits(gx_device * dev, int y, byte * str, byte ** actual_data)
int xi;
int sbit;
- byte *l_dptr = str;
+ byte *l_dptr = params->data[0];
int l_dbit = 0;
byte l_dbyte = 0;
+ gs_int_rect rect;
+ int y;
+
+ if ((~params->options & GB_RETURN_COPY) ||
+ !(params->options & (GB_OFFSET_0 | GB_OFFSET_SPECIFIED)) ||
+ !(params->options & (GB_RASTER_STANDARD | GB_RASTER_SPECIFIED))
+ )
+ return_error(gs_error_rangecheck);
if ((code = get_dev_target(&tdev, dev)) < 0)
return code;
@@ -343,53 +356,70 @@ x_wrap_get_bits(gx_device * dev, int y, byte * str, byte ** actual_data)
row = gs_alloc_bytes(mem, dsize, "x_wrap_get_bits");
if (row == 0)
return_error(gs_error_VMerror);
- code = (*dev_proc(tdev, get_bits)) (tdev, y, row, &base);
- if (code < 0)
- goto gx;
- for (sbit = 0, xi = 0; xi < width; sbit += sdepth, ++xi) {
- const byte *sptr = base + (sbit >> 3);
- gx_color_index pixel;
- gx_color_value rgb[3];
- int i;
-
- if (sdepth <= 8)
- pixel = (*sptr >> (8 - sdepth - (sbit & 7))) & smask;
- else {
- pixel = 0;
- for (i = 0; i < sdepth; i += 8, ++sptr)
- pixel = (pixel << 8) + *sptr;
- }
- if (pixel != pixel_in) {
- (*dev_proc(tdev, map_color_rgb))(tdev, pixel, rgb);
- pixel_in = pixel;
- if (dev->color_info.num_components <= 3)
- pixel_out = (*dev_proc(dev, map_rgb_color))(dev, rgb);
+ rect.p.x = prect->p.x;
+ rect.q.x = prect->q.x;
+ for (y = prect->p.y; y < prect->q.y; y++)
+ {
+ gs_get_bits_params_t lparams;
+ rect.p.y = y;
+ rect.q.y = y+1;
+ lparams.options = GB_ALIGN_ANY |
+ GB_RETURN_COPY |
+ GB_OFFSET_0 | GB_RASTER_STANDARD |
+ GB_PACKING_CHUNKY |
+ GB_COLORS_NATIVE | GB_ALPHA_NONE;
+ lparams.raster = 0;
+ lparams.data[0] = row;
+ lparams.x_offset = 0;
+ code = (*dev_proc(tdev, get_bits_rectangle))(tdev, &rect, &lparams);
+ if (code < 0)
+ break;
+ base = lparams.data[0];
+ for (sbit = 0, xi = 0; xi < width; sbit += sdepth, ++xi) {
+ const byte *sptr = base + (sbit >> 3);
+ gx_color_index pixel;
+ gx_color_value rgb[3];
+ int i;
+
+ if (sdepth <= 8)
+ pixel = (*sptr >> (8 - sdepth - (sbit & 7))) & smask;
else {
- /* Convert RGB to CMYK. */
- gx_color_value c = gx_max_color_value - rgb[0];
- gx_color_value m = gx_max_color_value - rgb[1];
- gx_color_value y = gx_max_color_value - rgb[2];
- gx_color_value k = (c < m ? min(c, y) : min(m, y));
-
- gx_color_value cmyk[4];
- cmyk[0] = c - k; cmyk[1] = m - k; cmyk[2] = y - k; cmyk[3] = k;
- pixel_out = (*dev_proc(dev, map_cmyk_color))(dev, cmyk);
+ pixel = 0;
+ for (i = 0; i < sdepth; i += 8, ++sptr)
+ pixel = (pixel << 8) + *sptr;
+ }
+ if (pixel != pixel_in) {
+ (*dev_proc(tdev, map_color_rgb))(tdev, pixel, rgb);
+ pixel_in = pixel;
+ if (dev->color_info.num_components <= 3)
+ pixel_out = (*dev_proc(dev, map_rgb_color))(dev, rgb);
+ else {
+ /* Convert RGB to CMYK. */
+ gx_color_value c = gx_max_color_value - rgb[0];
+ gx_color_value m = gx_max_color_value - rgb[1];
+ gx_color_value y = gx_max_color_value - rgb[2];
+ gx_color_value k = (c < m ? min(c, y) : min(m, y));
+
+ gx_color_value cmyk[4];
+ cmyk[0] = c - k; cmyk[1] = m - k; cmyk[2] = y - k; cmyk[3] = k;
+ pixel_out = (*dev_proc(dev, map_cmyk_color))(dev, cmyk);
+ }
+ }
+ if (sizeof(pixel_out) > 4) {
+ if (sample_store_next64(pixel_out, &l_dptr,
+ &l_dbit, depth, &l_dbyte) < 0)
+ return_error(gs_error_rangecheck);
+ }
+ else {
+ if (sample_store_next32(pixel_out, &l_dptr,
+ &l_dbit, depth, &l_dbyte) < 0)
+ return_error(gs_error_rangecheck);
}
}
- if (sizeof(pixel_out) > 4) {
- if (sample_store_next64(pixel_out, &l_dptr, &l_dbit, depth, &l_dbyte) < 0)
- return_error(gs_error_rangecheck);
- }
- else {
- if (sample_store_next32(pixel_out, &l_dptr, &l_dbit, depth, &l_dbyte) < 0)
- return_error(gs_error_rangecheck);
- }
+ sample_store_flush(l_dptr, l_dbit, l_dbyte);
}
- sample_store_flush(l_dptr, l_dbit, l_dbyte);
-gx:
gs_free_object(mem, row, "x_wrap_get_bits");
- if (actual_data)
- *actual_data = str;
+
return code;
}
@@ -547,35 +577,30 @@ static dev_proc_map_cmyk_color(x_cmyk_map_cmyk_color);
/* Extended device procedures */
static dev_proc_map_color_rgb(x_cmyk_alt_map_color);
-/* The device descriptor */
-static const gx_device_procs x_cmyk_procs = {
- x_cmyk_open,
- gx_forward_get_initial_matrix,
- x_forward_sync_output,
- x_forward_output_page,
- x_wrap_close,
- NULL, /* map_rgb_color */
- x_wrap_map_color_rgb,
- x_wrap_fill_rectangle,
- gx_default_tile_rectangle,
- x_wrap_copy_mono,
- x_wrap_copy_color,
- gx_default_draw_line,
- x_wrap_get_bits,
- x_wrap_get_params,
- x_cmyk_put_params,
- x_cmyk_map_cmyk_color,
- gx_forward_get_xfont_procs,
- gx_forward_get_xfont_device,
- NULL, /* map_rgb_alpha_color */
- gx_forward_get_page_device,
- gx_forward_get_alpha_bits,
- NULL /* copy_alpha */
-};
+static void
+x_cmyk_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, x_cmyk_open);
+ set_dev_proc(dev, get_initial_matrix, gx_forward_get_initial_matrix);
+ set_dev_proc(dev, sync_output, x_forward_sync_output);
+ set_dev_proc(dev, output_page, x_forward_output_page);
+ set_dev_proc(dev, close_device, x_wrap_close);
+ set_dev_proc(dev, map_color_rgb, x_wrap_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, x_wrap_fill_rectangle);
+ set_dev_proc(dev, copy_mono, x_wrap_copy_mono);
+ set_dev_proc(dev, copy_color, x_wrap_copy_color);
+ set_dev_proc(dev, get_bits_rectangle, x_wrap_get_bits_rectangle);
+ set_dev_proc(dev, get_params, x_wrap_get_params);
+ set_dev_proc(dev, put_params, x_cmyk_put_params);
+ set_dev_proc(dev, map_cmyk_color, x_cmyk_map_cmyk_color);
+ set_dev_proc(dev, get_page_device, gx_forward_get_page_device);
+ set_dev_proc(dev, get_alpha_bits, gx_forward_get_alpha_bits);
+}
/* The instances are public. */
const gx_device_X_wrapper gs_x11cmyk_device = {
- std_device_dci_type_body(gx_device_X_wrapper, &x_cmyk_procs, "x11cmyk",
+ std_device_dci_type_body(gx_device_X_wrapper,
+ x_cmyk_initialize_device_procs, "x11cmyk",
&st_device_X_wrapper,
FAKE_RES * 85 / 10, FAKE_RES * 11, /* x and y extent (nominal) */
FAKE_RES, FAKE_RES, /* x and y density (nominal) */
@@ -583,7 +608,8 @@ const gx_device_X_wrapper gs_x11cmyk_device = {
X_WRAPPER_DATA(x_cmyk_alt_map_color)
};
const gx_device_X_wrapper gs_x11cmyk2_device = {
- std_device_dci_type_body(gx_device_X_wrapper, &x_cmyk_procs, "x11cmyk2",
+ std_device_dci_type_body(gx_device_X_wrapper,
+ x_cmyk_initialize_device_procs, "x11cmyk2",
&st_device_X_wrapper,
FAKE_RES * 85 / 10, FAKE_RES * 11, /* x and y extent (nominal) */
FAKE_RES, FAKE_RES, /* x and y density (nominal) */
@@ -591,7 +617,8 @@ const gx_device_X_wrapper gs_x11cmyk2_device = {
X_WRAPPER_DATA(x_cmyk_alt_map_color)
};
const gx_device_X_wrapper gs_x11cmyk4_device = {
- std_device_dci_type_body(gx_device_X_wrapper, &x_cmyk_procs, "x11cmyk4",
+ std_device_dci_type_body(gx_device_X_wrapper,
+ x_cmyk_initialize_device_procs, "x11cmyk4",
&st_device_X_wrapper,
FAKE_RES * 85 / 10, FAKE_RES * 11, /* x and y extent (nominal) */
FAKE_RES, FAKE_RES, /* x and y density (nominal) */
@@ -599,7 +626,8 @@ const gx_device_X_wrapper gs_x11cmyk4_device = {
X_WRAPPER_DATA(x_cmyk_alt_map_color)
};
const gx_device_X_wrapper gs_x11cmyk8_device = {
- std_device_dci_type_body(gx_device_X_wrapper, &x_cmyk_procs, "x11cmyk8",
+ std_device_dci_type_body(gx_device_X_wrapper,
+ x_cmyk_initialize_device_procs, "x11cmyk8",
&st_device_X_wrapper,
FAKE_RES * 85 / 10, FAKE_RES * 11, /* x and y extent (nominal) */
FAKE_RES, FAKE_RES, /* x and y density (nominal) */
@@ -679,34 +707,29 @@ x_cmyk_map_cmyk_color(gx_device * dev, const gx_color_value cv[])
static dev_proc_map_color_rgb(x_mono_alt_map_color);
/* The device descriptor */
-static const gx_device_procs x_mono_procs = {
- x_wrap_open,
- gx_forward_get_initial_matrix,
- x_forward_sync_output,
- x_forward_output_page,
- x_wrap_close,
- gx_default_b_w_map_rgb_color,
- x_wrap_map_color_rgb,
- x_wrap_fill_rectangle,
- gx_default_tile_rectangle,
- x_wrap_copy_mono,
- gx_default_copy_color, /* this is fast for the 1-bit case */
- gx_default_draw_line,
- x_wrap_get_bits,
- x_wrap_get_params,
- x_wrap_put_params,
- gx_default_map_cmyk_color,
- gx_forward_get_xfont_procs,
- gx_forward_get_xfont_device,
- NULL, /* map_rgb_alpha_color */
- gx_forward_get_page_device,
- gx_forward_get_alpha_bits,
- NULL /* copy_alpha */
-};
+static void
+x_mono_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, x_wrap_open);
+ set_dev_proc(dev, get_initial_matrix, gx_forward_get_initial_matrix);
+ set_dev_proc(dev, sync_output, x_forward_sync_output);
+ set_dev_proc(dev, output_page, x_forward_output_page);
+ set_dev_proc(dev, close_device, x_wrap_close);
+ set_dev_proc(dev, map_rgb_color, gx_default_b_w_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, x_wrap_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, x_wrap_fill_rectangle);
+ set_dev_proc(dev, copy_mono, x_wrap_copy_mono);
+ set_dev_proc(dev, get_bits_rectangle, x_wrap_get_bits_rectangle);
+ set_dev_proc(dev, get_params, x_wrap_get_params);
+ set_dev_proc(dev, put_params, x_wrap_put_params);
+ set_dev_proc(dev, get_page_device, gx_forward_get_page_device);
+ set_dev_proc(dev, get_alpha_bits, gx_forward_get_alpha_bits);
+}
/* The instance is public. */
const gx_device_X_wrapper gs_x11mono_device = {
- std_device_dci_type_body(gx_device_X_wrapper, &x_mono_procs, "x11mono",
+ std_device_dci_type_body(gx_device_X_wrapper,
+ x_mono_initialize_device_procs, "x11mono",
&st_device_X_wrapper,
FAKE_RES * 85 / 10, FAKE_RES * 11, /* x and y extent (nominal) */
FAKE_RES, FAKE_RES, /* x and y density (nominal) */
@@ -729,34 +752,30 @@ x_mono_alt_map_color(gx_device * dev, gx_color_index color,
static dev_proc_map_color_rgb(x_gray_alt_map_color);
/* The device descriptor */
-static const gx_device_procs x_gray_procs = {
- x_wrap_open,
- gx_forward_get_initial_matrix,
- x_forward_sync_output,
- x_forward_output_page,
- x_wrap_close,
- gx_default_gray_map_rgb_color,
- x_wrap_map_color_rgb,
- x_wrap_fill_rectangle,
- gx_default_tile_rectangle,
- x_wrap_copy_mono,
- x_wrap_copy_color,
- gx_default_draw_line,
- x_wrap_get_bits,
- x_wrap_get_params,
- x_wrap_put_params,
- gx_default_map_cmyk_color,
- gx_forward_get_xfont_procs,
- gx_forward_get_xfont_device,
- NULL, /* map_rgb_alpha_color */
- gx_forward_get_page_device,
- gx_forward_get_alpha_bits,
- NULL /* copy_alpha */
-};
+static void
+x_gray_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, x_wrap_open);
+ set_dev_proc(dev, get_initial_matrix, gx_forward_get_initial_matrix);
+ set_dev_proc(dev, sync_output, x_forward_sync_output);
+ set_dev_proc(dev, output_page, x_forward_output_page);
+ set_dev_proc(dev, close_device, x_wrap_close);
+ set_dev_proc(dev, map_rgb_color, gx_default_gray_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, x_wrap_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, x_wrap_fill_rectangle);
+ set_dev_proc(dev, copy_mono, x_wrap_copy_mono);
+ set_dev_proc(dev, copy_color, x_wrap_copy_color);
+ set_dev_proc(dev, get_bits_rectangle, x_wrap_get_bits_rectangle);
+ set_dev_proc(dev, get_params, x_wrap_get_params);
+ set_dev_proc(dev, put_params, x_wrap_put_params);
+ set_dev_proc(dev, get_page_device, gx_forward_get_page_device);
+ set_dev_proc(dev, get_alpha_bits, gx_forward_get_alpha_bits);
+}
/* The instances are public. */
const gx_device_X_wrapper gs_x11gray2_device = {
- std_device_dci_type_body(gx_device_X_wrapper, &x_gray_procs, "x11gray2",
+ std_device_dci_type_body(gx_device_X_wrapper,
+ x_gray_initialize_device_procs, "x11gray2",
&st_device_X_wrapper,
FAKE_RES * 85 / 10, FAKE_RES * 11, /* x and y extent (nominal) */
FAKE_RES, FAKE_RES, /* x and y density (nominal) */
@@ -765,7 +784,8 @@ const gx_device_X_wrapper gs_x11gray2_device = {
};
const gx_device_X_wrapper gs_x11gray4_device = {
- std_device_dci_type_body(gx_device_X_wrapper, &x_gray_procs, "x11gray4",
+ std_device_dci_type_body(gx_device_X_wrapper,
+ x_gray_initialize_device_procs, "x11gray4",
&st_device_X_wrapper,
FAKE_RES * 85 / 10, FAKE_RES * 11, /* x and y extent (nominal) */
FAKE_RES, FAKE_RES, /* x and y density (nominal) */
@@ -785,21 +805,6 @@ x_gray_alt_map_color(gx_device * dev, gx_color_index color,
/* Device procedures */
-/* We encode a complemented alpha value in the top 8 bits of the */
-/* device color. */
-static gx_color_index
-x_alpha_map_rgb_alpha_color(gx_device * dev,
- gx_color_value r, gx_color_value g, gx_color_value b, gx_color_value alpha)
-{
- gx_color_index color;
- gx_color_value cv[3];
- byte abyte = alpha >> (gx_color_value_bits - 8);
- cv[0] = r; cv[1] = g; cv[2] = b;
- color = gx_forward_map_rgb_color(dev, cv);
- return (abyte == 0 ? (gx_color_index)0xff << 24 :
- ((gx_color_index) (abyte ^ 0xff) << 24) + color);
-}
-
/* ---------------- Permuted RGB16/32 procedures ---------------- */
/* Device procedures */
@@ -810,35 +815,36 @@ static dev_proc_map_color_rgb(x_rg16x_alt_map_color);
static dev_proc_map_color_rgb(x_rg32x_alt_map_color);
/* The device descriptor */
-#define RGBX_PROCS(map_rgb_proc)\
- x_wrap_open,\
- gx_forward_get_initial_matrix,\
- x_forward_sync_output,\
- x_forward_output_page,\
- x_wrap_close,\
- map_rgb_proc, /* differs */\
- x_wrap_map_color_rgb,\
- x_wrap_fill_rectangle,\
- gx_default_tile_rectangle,\
- x_wrap_copy_mono,\
- x_forward_copy_color,\
- gx_default_draw_line,\
- x_forward_get_bits,\
- x_wrap_get_params,\
- x_wrap_put_params,\
- gx_forward_map_cmyk_color,\
- gx_forward_get_xfont_procs,\
- gx_forward_get_xfont_device,\
- x_alpha_map_rgb_alpha_color,\
- gx_forward_get_page_device,\
- gx_default_get_alpha_bits,\
- gx_default_copy_alpha
-
-static const gx_device_procs x_rg16x_procs = {
- RGBX_PROCS(x_rg16x_map_rgb_color)
-};
+static void
+rgbx_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, x_wrap_open);
+ set_dev_proc(dev, get_initial_matrix, gx_forward_get_initial_matrix);
+ set_dev_proc(dev, sync_output, x_forward_sync_output);
+ set_dev_proc(dev, output_page, x_forward_output_page);
+ set_dev_proc(dev, close_device, x_wrap_close);
+ set_dev_proc(dev, map_color_rgb, x_wrap_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, x_wrap_fill_rectangle);
+ set_dev_proc(dev, copy_mono, x_wrap_copy_mono);
+ set_dev_proc(dev, copy_color, x_forward_copy_color);
+ set_dev_proc(dev, get_bits_rectangle, x_forward_get_bits_rectangle);
+ set_dev_proc(dev, get_params, x_wrap_get_params);
+ set_dev_proc(dev, put_params, x_wrap_put_params);
+ set_dev_proc(dev, map_cmyk_color, gx_forward_map_cmyk_color);
+ set_dev_proc(dev, get_page_device, gx_forward_get_page_device);
+}
+
+static void
+x_rg16x_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, map_rgb_color, x_rg16x_map_rgb_color);
+
+ rgbx_initialize_device_procs(dev);
+}
+
const gx_device_X_wrapper gs_x11rg16x_device = {
- std_device_dci_type_body(gx_device_X_wrapper, &x_rg16x_procs, "x11rg16x",
+ std_device_dci_type_body(gx_device_X_wrapper,
+ x_rg16x_initialize_device_procs, "x11rg16x",
&st_device_X_wrapper,
FAKE_RES * 85 / 10, FAKE_RES * 11, /* x and y extent (nominal) */
FAKE_RES, FAKE_RES, /* x and y density (nominal) */
@@ -846,11 +852,17 @@ const gx_device_X_wrapper gs_x11rg16x_device = {
X_WRAPPER_DATA(x_rg16x_alt_map_color)
};
-static const gx_device_procs x_rg32x_procs = {
- RGBX_PROCS(x_rg32x_map_rgb_color)
-};
+static void
+x_rg32x_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, map_rgb_color, x_rg32x_map_rgb_color);
+
+ rgbx_initialize_device_procs(dev);
+}
+
const gx_device_X_wrapper gs_x11rg32x_device = {
- std_device_dci_type_body(gx_device_X_wrapper, &x_rg32x_procs, "x11rg32x",
+ std_device_dci_type_body(gx_device_X_wrapper,
+ x_rg32x_initialize_device_procs, "x11rg32x",
&st_device_X_wrapper,
FAKE_RES * 85 / 10, FAKE_RES * 11, /* x and y extent (nominal) */
FAKE_RES, FAKE_RES, /* x and y density (nominal) */
diff --git a/devices/gdevxcf.c b/devices/gdevxcf.c
index 18ff322e..744af138 100644
--- a/devices/gdevxcf.c
+++ b/devices/gdevxcf.c
@@ -135,71 +135,36 @@ typedef struct xcf_device_s {
/*
* Macro definition for DeviceN procedures
*/
-#define device_procs(get_color_mapping_procs)\
-{ gdev_prn_open,\
- gx_default_get_initial_matrix,\
- NULL, /* sync_output */\
- /* Since the print_page doesn't alter the device, this device can print in the background */\
- gdev_prn_bg_output_page, /* output_page */\
- xcf_prn_close, /* close */\
- NULL, /* map_rgb_color - not used */\
- xcf_map_color_rgb, /* map_color_rgb */\
- NULL, /* fill_rectangle */\
- NULL, /* tile_rectangle */\
- NULL, /* copy_mono */\
- NULL, /* copy_color */\
- NULL, /* draw_line */\
- NULL, /* get_bits */\
- xcf_get_params, /* get_params */\
- xcf_put_params, /* put_params */\
- NULL, /* map_cmyk_color - not used */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- gx_page_device_get_page_device, /* get_page_device */\
- NULL, /* get_alpha_bits */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- NULL, /* fill_path */\
- NULL, /* stroke_path */\
- NULL, /* fill_mask */\
- NULL, /* fill_trapezoid */\
- NULL, /* fill_parallelogram */\
- NULL, /* fill_triangle */\
- NULL, /* draw_thin_line */\
- NULL, /* begin_image */\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL, /* strip_copy_rop */\
- NULL, /* get_clipping_box */\
- NULL, /* begin_typed_image */\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- NULL, /* create_compositor */\
- NULL, /* get_hardware_params */\
- NULL, /* text_begin */\
- NULL, /* finish_copydevice */\
- NULL, /* begin_transparency_group */\
- NULL, /* end_transparency_group */\
- NULL, /* begin_transparency_mask */\
- NULL, /* end_transparency_mask */\
- NULL, /* discard_transparency_layer */\
- get_color_mapping_procs, /* get_color_mapping_procs */\
- xcf_get_color_comp_index, /* get_color_comp_index */\
- xcf_encode_color, /* encode_color */\
- xcf_decode_color /* decode_color */\
+static void
+xcf_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, gdev_prn_open);
+ set_dev_proc(dev, output_page, gdev_prn_bg_output_page);
+ set_dev_proc(dev, close_device, xcf_prn_close);
+ set_dev_proc(dev, map_color_rgb, xcf_map_color_rgb);
+ set_dev_proc(dev, get_params, xcf_get_params);
+ set_dev_proc(dev, put_params, xcf_put_params);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
+ set_dev_proc(dev, get_color_comp_index, xcf_get_color_comp_index);
+ set_dev_proc(dev, encode_color, xcf_encode_color);
+ set_dev_proc(dev, decode_color, xcf_decode_color);
+}
+
+static void
+spot_rgb_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, get_color_mapping_procs, get_spotrgb_color_mapping_procs);
+
+ xcf_initialize_device_procs(dev);
}
/*
* Example device with RGB and spot color support
*/
-static const gx_device_procs spot_rgb_procs = device_procs(get_spotrgb_color_mapping_procs);
-
const xcf_device gs_xcf_device =
{
- prn_device_body_extended(xcf_device, spot_rgb_procs, "xcf",
+ prn_device_body_extended(xcf_device,
+ spot_rgb_initialize_device_procs, "xcf",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI, /* X and Y hardware resolution */
0, 0, 0, 0, /* margins */
@@ -219,11 +184,18 @@ const xcf_device gs_xcf_device =
{0} /* SeparationOrder names */
};
-static const gx_device_procs spot_cmyk_procs = device_procs(get_xcf_color_mapping_procs);
+static void
+spot_cmyk_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, get_color_mapping_procs, get_xcf_color_mapping_procs);
+
+ xcf_initialize_device_procs(dev);
+}
const xcf_device gs_xcfcmyk_device =
{
- prn_device_body_extended(xcf_device, spot_cmyk_procs, "xcfcmyk",
+ prn_device_body_extended(xcf_device,
+ spot_cmyk_initialize_device_procs, "xcfcmyk",
DEFAULT_WIDTH_10THS, DEFAULT_HEIGHT_10THS,
X_DPI, Y_DPI, /* X and Y hardware resolution */
0, 0, 0, 0, /* margins */
@@ -248,7 +220,7 @@ const xcf_device gs_xcfcmyk_device =
* the color components for the spotrgb device.
*/
static void
-gray_cs_to_spotrgb_cm(gx_device * dev, frac gray, frac out[])
+gray_cs_to_spotrgb_cm(const gx_device * dev, frac gray, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
int i = ((xcf_device *)dev)->separation_names.num_names;
@@ -259,7 +231,7 @@ gray_cs_to_spotrgb_cm(gx_device * dev, frac gray, frac out[])
}
static void
-rgb_cs_to_spotrgb_cm(gx_device * dev, const gs_gstate *pgs,
+rgb_cs_to_spotrgb_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
@@ -273,7 +245,7 @@ rgb_cs_to_spotrgb_cm(gx_device * dev, const gs_gstate *pgs,
}
static void
-cmyk_cs_to_spotrgb_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+cmyk_cs_to_spotrgb_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
int i = ((xcf_device *)dev)->separation_names.num_names;
@@ -284,7 +256,7 @@ cmyk_cs_to_spotrgb_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[
}
static void
-gray_cs_to_spotcmyk_cm(gx_device * dev, frac gray, frac out[])
+gray_cs_to_spotcmyk_cm(const gx_device * dev, frac gray, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
int i = ((xcf_device *)dev)->separation_names.num_names;
@@ -296,7 +268,7 @@ gray_cs_to_spotcmyk_cm(gx_device * dev, frac gray, frac out[])
}
static void
-rgb_cs_to_spotcmyk_cm(gx_device * dev, const gs_gstate *pgs,
+rgb_cs_to_spotcmyk_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
@@ -310,7 +282,7 @@ rgb_cs_to_spotcmyk_cm(gx_device * dev, const gs_gstate *pgs,
}
static void
-cmyk_cs_to_spotcmyk_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+cmyk_cs_to_spotcmyk_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
xcf_device *xdev = (xcf_device *)dev;
@@ -326,7 +298,7 @@ cmyk_cs_to_spotcmyk_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out
}
static void
-cmyk_cs_to_spotn_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
+cmyk_cs_to_spotn_cm(const gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
xcf_device *xdev = (xcf_device *)dev;
@@ -345,7 +317,7 @@ cmyk_cs_to_spotn_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
in[2] = frac2ushort(y);
in[3] = frac2ushort(k);
- gscms_transform_color(dev, link, &(in[0]), &(tmp[0]), 2);
+ gscms_transform_color_const(dev, link, &(in[0]), &(tmp[0]), 2);
for (i = 0; i < outn; i++)
out[i] = ushort2frac(tmp[i]);
for (; i < n + 4; i++)
@@ -363,7 +335,7 @@ cmyk_cs_to_spotn_cm(gx_device * dev, frac c, frac m, frac y, frac k, frac out[])
}
static void
-gray_cs_to_spotn_cm(gx_device * dev, frac gray, frac out[])
+gray_cs_to_spotn_cm(const gx_device * dev, frac gray, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
@@ -371,7 +343,7 @@ gray_cs_to_spotn_cm(gx_device * dev, frac gray, frac out[])
}
static void
-rgb_cs_to_spotn_cm(gx_device * dev, const gs_gstate *pgs,
+rgb_cs_to_spotn_cm(const gx_device * dev, const gs_gstate *pgs,
frac r, frac g, frac b, frac out[])
{
/* TO_DO_DEVICEN This routine needs to include the effects of the SeparationOrder array */
@@ -389,7 +361,7 @@ rgb_cs_to_spotn_cm(gx_device * dev, const gs_gstate *pgs,
in[1] = frac2ushort(g);
in[2] = frac2ushort(b);
- gscms_transform_color(dev, link, &(in[0]), &(tmp[0]), 2);
+ gscms_transform_color_const(dev, link, &(in[0]), &(tmp[0]), 2);
for (i = 0; i < outn; i++)
out[i] = ushort2frac(tmp[i]);
@@ -421,24 +393,27 @@ static const gx_cm_color_map_procs spotN_procs = {
* to color model conversion routines.
*/
static const gx_cm_color_map_procs *
-get_spotrgb_color_mapping_procs(const gx_device * dev)
+get_spotrgb_color_mapping_procs(const gx_device * dev, const gx_device **tdev)
{
+ *tdev = dev;
return &spotRGB_procs;
}
#if 0
static const gx_cm_color_map_procs *
-get_spotcmyk_color_mapping_procs(const gx_device * dev)
+get_spotcmyk_color_mapping_procs(const gx_device * dev, const gx_device **tdev)
{
+ *tdev = dev;
return &spotCMYK_procs;
}
#endif
static const gx_cm_color_map_procs *
-get_xcf_color_mapping_procs(const gx_device * dev)
+get_xcf_color_mapping_procs(const gx_device * dev, const gx_device **tdev)
{
const xcf_device *xdev = (const xcf_device *)dev;
+ *tdev = dev;
if (xdev->color_model == XCF_DEVICE_RGB)
return &spotRGB_procs;
else if (xdev->color_model == XCF_DEVICE_CMYK)
diff --git a/devices/gdevxini.c b/devices/gdevxini.c
index 82032cd6..1944c9a9 100644
--- a/devices/gdevxini.c
+++ b/devices/gdevxini.c
@@ -567,7 +567,11 @@ x_set_buffer(gx_device_X * xdev)
*/
gs_memory_t *mem = gs_memory_stable(xdev->memory);
bool buffered = xdev->space_params.MaxBitmap > 0;
- const gx_device_procs *procs;
+ union {
+ gx_device dev;
+ gx_device_bbox bbox;
+ gx_device_X x11;
+ } tempdev;
setup:
if (buffered) {
@@ -645,7 +649,7 @@ x_set_buffer(gx_device_X * xdev)
}
xdev->white = gx_device_white((gx_device *)xdev);
xdev->black = gx_device_black((gx_device *)xdev);
- procs = &gs_bbox_device.procs;
+ tempdev.bbox = gs_bbox_device;
} else {
/* Not buffering. Release the buffer and memory device. */
gs_free_object(mem, xdev->buffer, "buffer");
@@ -656,10 +660,12 @@ x_set_buffer(gx_device_X * xdev)
gx_device_set_target((gx_device_forward *)xdev->target, NULL);
gx_device_set_target((gx_device_forward *)xdev, NULL);
xdev->is_buffered = false;
- procs = &gs_x11_device.procs;
+ tempdev.x11 = gs_x11_device;
}
- if (dev_proc(xdev, fill_rectangle) != procs->fill_rectangle) {
-#define COPY_PROC(p) set_dev_proc(xdev, p, procs->p)
+ tempdev.dev.initialize_device_procs(&tempdev.dev);
+ if (dev_proc(xdev, fill_rectangle) != tempdev.dev.procs.fill_rectangle) {
+#define COPY_PROC(p) set_dev_proc(xdev, p, tempdev.dev.procs.p)
+ COPY_PROC(initialize_device);
COPY_PROC(fill_rectangle);
COPY_PROC(copy_mono);
COPY_PROC(copy_color);
@@ -672,7 +678,6 @@ x_set_buffer(gx_device_X * xdev)
COPY_PROC(fill_triangle);
COPY_PROC(draw_thin_line);
COPY_PROC(strip_tile_rectangle);
- COPY_PROC(strip_copy_rop);
COPY_PROC(begin_typed_image);
COPY_PROC(text_begin);
#undef COPY_PROC
@@ -753,10 +758,8 @@ gdev_x_clear_window(gx_device_X * xdev)
xdev->colors_or = xdev->colors_and = xdev->background;
}
-
-/* Clean up the instance after making a copy. */
-int
-gdev_x_finish_copydevice(gx_device *dev, const gx_device *from_dev)
+static int
+x_initialize_device(gx_device *dev)
{
gx_device_X *xdev = (gx_device_X *) dev;
@@ -779,13 +782,34 @@ gdev_x_finish_copydevice(gx_device *dev, const gx_device *from_dev)
/* Reset pointer-related parameters. */
xdev->is_buffered = false;
- /* See x_set_buffer for why we do this: */
- set_dev_proc(xdev, fill_rectangle,
- dev_proc(&gs_x11_device, fill_rectangle));
return 0;
}
+
+/* (External procedures are declared in gdevx.h.) */
+void
+gdev_x_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, initialize_device, x_initialize_device);
+ set_dev_proc(dev, open_device, x_open);
+ set_dev_proc(dev, get_initial_matrix, x_get_initial_matrix);
+ set_dev_proc(dev, sync_output, x_sync);
+ set_dev_proc(dev, output_page, x_output_page);
+ set_dev_proc(dev, close_device, x_close);
+ set_dev_proc(dev, map_rgb_color, gdev_x_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gdev_x_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, x_fill_rectangle);
+ set_dev_proc(dev, copy_mono, x_copy_mono);
+ set_dev_proc(dev, copy_color, x_copy_color);
+ set_dev_proc(dev, get_params, gdev_x_get_params);
+ set_dev_proc(dev, put_params, gdev_x_put_params);
+ set_dev_proc(dev, get_page_device, x_get_page_device);
+ set_dev_proc(dev, strip_tile_rectangle, x_strip_tile_rectangle);
+ set_dev_proc(dev, get_bits_rectangle, x_get_bits_rectangle);
+ set_dev_proc(dev, fillpage, x_fillpage);
+}
+
/* ---------------- Get/put parameters ---------------- */
/* Get the device parameters. See below. */
@@ -975,4 +999,4 @@ gdev_x_close(gx_device_X *xdev)
xdev->space_params.MaxBitmap = MaxBitmap;
return 0;
-} \ No newline at end of file
+}
diff --git a/devices/gxfcopy.c b/devices/gxfcopy.c
index 4f2ca6fd..72235693 100644
--- a/devices/gxfcopy.c
+++ b/devices/gxfcopy.c
@@ -826,11 +826,6 @@ compare_glyphs(const gs_font *cfont, const gs_font *ofont, gs_glyph *glyphs,
return code1;
if (info0.num_pieces != info1.num_pieces)
return 0;
- if (info0.width[WMode].x != info1.width[WMode].x ||
- info0.width[WMode].y != info1.width[WMode].y)
- return 0;
- if (WMode && (info0.v.x != info1.v.x || info0.v.y != info1.v.y))
- return 0;
if (info0.num_pieces > 0) {
if(level > 5)
return_error(gs_error_rangecheck); /* abnormal glyph recursion */
@@ -2289,6 +2284,10 @@ int gs_free_copied_font(gs_font *font)
}
gs_free_object(mem, copied0->cidata.FDArray, "free copied CIDFont FDArray");
copied0->cidata.FDArray = 0;
+ gs_free_string(mem, (byte *)copied0->cidata.common.CIDSystemInfo.Registry.data, copied0->cidata.common.CIDSystemInfo.Registry.size, "Free copied Registry");
+ gs_free_string(mem, (byte *)copied0->cidata.common.CIDSystemInfo.Ordering.data, copied0->cidata.common.CIDSystemInfo.Ordering.size, "Free copied Registry");
+ copied0->cidata.common.CIDSystemInfo.Registry.data = copied0->cidata.common.CIDSystemInfo.Ordering.data = NULL;
+ copied0->cidata.common.CIDSystemInfo.Registry.size = copied0->cidata.common.CIDSystemInfo.Ordering.size = 0;
}
if (font->FontType == ft_CID_TrueType) {
diff --git a/devices/rinkj/evenbetter-rll.c b/devices/rinkj/evenbetter-rll.c
index ac03960f..49de26da 100644
--- a/devices/rinkj/evenbetter-rll.c
+++ b/devices/rinkj/evenbetter-rll.c
@@ -15,12 +15,6 @@
/* Testbed implementation of Even Better Screening. */
-
-/*
- * Code in this module is covered by US Patents 5,055,942 and
- * 5,917,614, and corresponding international patents.
- */
-
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
diff --git a/devices/vector/doc_common.c b/devices/vector/doc_common.c
index 50123f8f..c7d38836 100644
--- a/devices/vector/doc_common.c
+++ b/devices/vector/doc_common.c
@@ -3,7 +3,7 @@
#include "gxfont.h"
#include "gserrors.h"
#include "gxfcid.h"
-#include "gdevagl.h"
+#include "gsagl.h"
#include "gxdevcli.h"
#include "gxgstate.h"
diff --git a/devices/vector/gdevdocxw.c b/devices/vector/gdevdocxw.c
index c9be4757..54ab5be7 100644
--- a/devices/vector/gdevdocxw.c
+++ b/devices/vector/gdevdocxw.c
@@ -30,7 +30,7 @@
#include "gxfcid.h"
#include "gxgstate.h"
#include "gxpath.h"
-#include "gdevagl.h"
+#include "gsagl.h"
#include "gxdevsop.h"
#include "gzpath.h"
#include "gdevkrnlsclass.h" /* 'standard' built in subclasses, currently First/Last Page and obejct filter */
@@ -117,7 +117,7 @@ static dev_proc_put_params(docxwrite_put_params);
static dev_proc_fill_path(docxwrite_fill_path);
static dev_proc_stroke_path(docxwrite_stroke_path);
static dev_proc_text_begin(docxwrite_text_begin);
-static dev_proc_strip_copy_rop(docxwrite_strip_copy_rop);
+static dev_proc_strip_copy_rop2(docxwrite_strip_copy_rop2);
static dev_proc_dev_spec_op(docxwrite_dev_spec_op);
@@ -144,86 +144,35 @@ typedef struct {
private_st_textw_text_enum();
+static void
+docxwrite_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, docxwrite_open_device);
+ set_dev_proc(dev, output_page, docxwrite_output_page);
+ set_dev_proc(dev, close_device, docxwrite_close_device);
+ set_dev_proc(dev, fill_rectangle, docxwrite_fill_rectangle);
+ set_dev_proc(dev, get_params, docxwrite_get_params);
+ set_dev_proc(dev, put_params, docxwrite_put_params);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
+ set_dev_proc(dev, fill_path, docxwrite_fill_path);
+ set_dev_proc(dev, stroke_path, docxwrite_stroke_path);
+ set_dev_proc(dev, strip_copy_rop2, docxwrite_strip_copy_rop2);
+ set_dev_proc(dev, composite, gx_null_composite);
+ set_dev_proc(dev, text_begin, docxwrite_text_begin);
+ set_dev_proc(dev, dev_spec_op, docxwrite_dev_spec_op);
+}
+
const gx_device_docxwrite_t gs_docxwrite_device =
{
/* Define the device as 8-bit gray scale to avoid computing halftones. */
- std_device_dci_body(gx_device_docxwrite_t, 0, "docxwrite",
+ std_device_dci_body(gx_device_docxwrite_t,
+ docxwrite_initialize_device_procs,
+ "docxwrite",
DEFAULT_WIDTH_10THS * X_DPI / 10,
DEFAULT_HEIGHT_10THS * Y_DPI / 10,
X_DPI, Y_DPI,
1, 8, 255, 0, 256, 1),
- {docxwrite_open_device,
- NULL, /*gx_upright_get_initial_matrix,*/
- NULL, /*gx_default_sync_output,*/
- docxwrite_output_page,
- docxwrite_close_device,
- NULL, /*gx_default_gray_map_rgb_color,*/
- NULL, /*gx_default_gray_map_color_rgb,*/
- docxwrite_fill_rectangle, /* Can't be NULL and there is no gx_default_fill_rectangle! */
- NULL, /*gx_default_tile_rectangle,*/
- NULL, /*gx_default_copy_mono,*/
- NULL, /*gx_default_copy_color,*/
- NULL, /*gx_default_draw_line,*/
- NULL, /*gx_default_get_bits,*/
- docxwrite_get_params,
- docxwrite_put_params,
- NULL, /*gx_default_map_cmyk_color,*/
- NULL, /*gx_default_get_xfont_procs,*/
- NULL, /*gx_default_get_xfont_device,*/
- NULL, /*gx_default_map_rgb_alpha_color,*/
- gx_page_device_get_page_device, /*gx_page_device_get_page_device,*/
- NULL, /* get_alpha_bits */
- NULL, /*gx_default_copy_alpha,*/
- NULL, /* get_band */
- NULL, /* copy_rop */
- docxwrite_fill_path,
- docxwrite_stroke_path,
- NULL, /*gx_default_fill_mask,*/
- NULL, /*gx_default_fill_trapezoid,*/
- NULL, /*gx_default_fill_parallelogram,*/
- NULL, /*gx_default_fill_triangle,*/
- NULL, /*gx_default_draw_thin_line,*/
- NULL, /* begin image */
- NULL, /* image_data */
- NULL, /* end_image */
- NULL, /*gx_default_strip_tile_rectangle,*/
- docxwrite_strip_copy_rop,
- NULL, /* get_clipping_box */
- NULL, /* docxwrite_begin_typed_image */
- NULL, /* get_bits_rectangle */
- NULL, /*gx_default_map_color_rgb_alpha,*/
- gx_null_create_compositor,
- NULL, /* get_hardware_params */
- docxwrite_text_begin,
- NULL, /* finish_copydevice */
- NULL, /* begin_transparency_group */
- NULL, /* end_transparency_group */
- NULL, /* begin_transparency_mask */
- NULL, /* end_transparency_mask */
- NULL, /* discard_transparency_layer */
- NULL, /* get_color_mapping_procs */
- NULL, /* get_color_comp_index */
- NULL, /* encode_color */
- NULL, /* decode_color */
- NULL, /* pattern manager */
- NULL, /* fill_rectangle_hl_color */
- NULL, /* include_color_space */
- NULL, /* fill_linear_color_scanline */
- NULL, /* fill_linear_color_trapezoid */
- NULL, /* fill_linear_color_triangle */
- NULL, /* update_spot_equivalent_colors */
- NULL, /* ret_devn_params */
- NULL, /* fillpage */
- NULL, /* push_transparency_state */
- NULL, /* pop_transparency_state */
- NULL, /* put_image */
- docxwrite_dev_spec_op, /* dev_spec_op */
- NULL, /* copy_planes */
- NULL, /* get_profile */
- NULL, /* set_graphics_type_tag */
- NULL, /* strip_copy_rop2 */
- NULL /* strip_tile_rect_devn */
- },
+ { 0 }, /* procs */
{ 0 }, /* Page Data */
0, /* Output FILE * */
0, /* TextFormat */
@@ -314,7 +263,7 @@ docxwrite_open_device(gx_device * dev)
}
extract_alloc_exp_min(tdev->alloc, 64);
- if (extract_begin(tdev->alloc, &tdev->extract)) {
+ if (extract_begin(tdev->alloc, extract_format_DOCX, &tdev->extract)) {
code = s_errno_to_gs();
goto end;
}
@@ -423,7 +372,7 @@ docxwrite_output_page(gx_device * dev, int num_copies, int flush)
if (tdev->file_per_page) {
/* Create a new extract_t for the next page. */
extract_end(&tdev->extract);
- if (extract_begin(tdev->alloc, &tdev->extract)) {
+ if (extract_begin(tdev->alloc, extract_format_DOCX, &tdev->extract)) {
code = s_errno_to_gs();
goto end;
}
@@ -482,14 +431,15 @@ docxwrite_strip_tile_rectangle(gx_device * dev, const gx_strip_bitmap * tiles,
}
static int
-docxwrite_strip_copy_rop(gx_device * dev,
+docxwrite_strip_copy_rop2(gx_device * dev,
const byte * sdata, int sourcex, uint sraster,
gx_bitmap_id id,
const gx_color_index * scolors,
const gx_strip_bitmap * textures,
const gx_color_index * tcolors,
int x, int y, int w, int h,
- int phase_x, int phase_y, gs_logical_operation_t lop)
+ int phase_x, int phase_y, gs_logical_operation_t lop,
+ uint plane_height)
{
return 0;
}*/
@@ -736,7 +686,7 @@ docx_update_text_state(docx_list_entry_t *ppts,
gs_matrix smat, tmat;
float size;
int mask = 0;
- int code = gx_path_current_point(penum->path, &cpt);
+ int code = gx_path_current_point(gs_text_enum_path(penum), &cpt);
if (code < 0)
return code;
@@ -1190,7 +1140,7 @@ textw_text_process(gs_text_enum_t *pte)
return code;
/* Fall back to the default implementation. */
code = gx_default_text_begin(pte->dev, pte->pgs, &pte->text, pte->current_font,
- pte->path, pte->pdcolor, pte->pcpath, pte->memory, &pte_fallback);
+ pte->pcpath, &pte_fallback);
if (code < 0)
return code;
penum->pte_fallback = pte_fallback;
@@ -1291,13 +1241,14 @@ static const gs_text_enum_procs_t textw_text_procs = {
static int
docxwrite_text_begin(gx_device * dev, gs_gstate * pgs,
const gs_text_params_t * text, gs_font * font,
- gx_path * path, const gx_device_color * pdcolor,
const gx_clip_path * pcpath,
- gs_memory_t * mem, gs_text_enum_t ** ppenum)
+ gs_text_enum_t ** ppenum)
{
gx_device_docxwrite_t *const tdev = (gx_device_docxwrite_t *) dev;
docxw_text_enum_t *penum;
int code;
+ gx_path *path = pgs->path;
+ gs_memory_t * mem = pgs->memory;
/* If this is a stringwidth, we must let the default graphics library code handle it
* in case there is no current point (this can happen if this is the first operation
@@ -1308,8 +1259,8 @@ docxwrite_text_begin(gx_device * dev, gs_gstate * pgs,
*/
if ((!(text->operation & TEXT_DO_DRAW) && pgs->text_rendering_mode != 3)
|| path == 0 || !path_position_valid(path))
- return gx_default_text_begin(dev, pgs, text, font, path, pdcolor,
- pcpath, mem, ppenum);
+ return gx_default_text_begin(dev, pgs, text, font,
+ pcpath, ppenum);
/* Allocate and initialize one of our text enumerators. */
rc_alloc_struct_1(penum, docxw_text_enum_t, &st_textw_text_enum, mem,
return_error(gs_error_VMerror), "gdev_textw_text_begin");
@@ -1328,7 +1279,7 @@ docxwrite_text_begin(gx_device * dev, gs_gstate * pgs,
memset(penum->text_state, 0x00, sizeof(docx_list_entry_t));
code = gs_text_enum_init((gs_text_enum_t *)penum, &textw_text_procs,
- dev, pgs, text, font, path, pdcolor, pcpath, mem);
+ dev, pgs, text, font, pcpath, mem);
if (code < 0) {
/* Belt and braces; I'm not certain this is required, but its safe */
gs_free(tdev->memory, penum->text_state, 1, sizeof(docx_list_entry_t), "txtwrite free text state");
@@ -1337,7 +1288,7 @@ docxwrite_text_begin(gx_device * dev, gs_gstate * pgs,
return code;
}
- code = gx_path_current_point(penum->path, &penum->origin);
+ code = gx_path_current_point(gs_text_enum_path(penum), &penum->origin);
if (code != 0)
return code;
@@ -1347,14 +1298,15 @@ docxwrite_text_begin(gx_device * dev, gs_gstate * pgs,
}
static int
-docxwrite_strip_copy_rop(gx_device * dev,
+docxwrite_strip_copy_rop2(gx_device * dev,
const byte * sdata, int sourcex, uint sraster,
gx_bitmap_id id,
const gx_color_index * scolors,
const gx_strip_bitmap * textures,
const gx_color_index * tcolors,
int x, int y, int w, int h,
- int phase_x, int phase_y, gs_logical_operation_t lop)
+ int phase_x, int phase_y, gs_logical_operation_t lop,
+ uint plane_height)
{
return 0;
}
diff --git a/devices/vector/gdevpdf.c b/devices/vector/gdevpdf.c
index 35dc6dc2..9ab562c7 100644
--- a/devices/vector/gdevpdf.c
+++ b/devices/vector/gdevpdf.c
@@ -220,6 +220,40 @@ static dev_proc_close_device(pdf_close);
/* ---------------- Device prototype ---------------- */
+static void
+pdfwrite_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, pdf_open);
+ set_dev_proc(dev, get_initial_matrix, gx_upright_get_initial_matrix);
+ set_dev_proc(dev, output_page, pdf_output_page);
+ set_dev_proc(dev, close_device, pdf_close);
+ set_dev_proc(dev, map_rgb_color, gx_default_rgb_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_default_rgb_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, gdev_pdf_fill_rectangle);
+ set_dev_proc(dev, copy_mono, gdev_pdf_copy_mono);
+ set_dev_proc(dev, copy_color, gdev_pdf_copy_color);
+ set_dev_proc(dev, get_params, gdev_pdf_get_params);
+ set_dev_proc(dev, put_params, gdev_pdf_put_params);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
+ set_dev_proc(dev, fill_path, gdev_pdf_fill_path);
+ set_dev_proc(dev, stroke_path, gdev_pdf_stroke_path);
+ set_dev_proc(dev, fill_mask, gdev_pdf_fill_mask);
+ set_dev_proc(dev, strip_tile_rectangle, gdev_pdf_strip_tile_rectangle);
+ set_dev_proc(dev, begin_typed_image, gdev_pdf_begin_typed_image);
+ set_dev_proc(dev, get_bits_rectangle, psdf_get_bits_rectangle);
+ set_dev_proc(dev, composite, gdev_pdf_composite);
+ set_dev_proc(dev, text_begin, gdev_pdf_text_begin);
+ set_dev_proc(dev, begin_transparency_group, gdev_pdf_begin_transparency_group);
+ set_dev_proc(dev, end_transparency_group, gdev_pdf_end_transparency_group);
+ set_dev_proc(dev, begin_transparency_mask ,gdev_pdf_begin_transparency_mask);
+ set_dev_proc(dev, end_transparency_mask, gdev_pdf_end_transparency_mask);
+ set_dev_proc(dev, fill_rectangle_hl_color, gdev_pdf_fill_rectangle_hl_color);
+ set_dev_proc(dev, include_color_space, gdev_pdf_include_color_space);
+ set_dev_proc(dev, fillpage, gdev_pdf_fillpage);
+ set_dev_proc(dev, dev_spec_op, gdev_pdf_dev_spec_op);
+ set_dev_proc(dev, fill_stroke_path, gdev_pdf_fill_stroke_path);
+}
+
#define PDF_DEVICE_NAME "pdfwrite"
#define PDF_DEVICE_IDENT gs_pdfwrite_device
#define PDF_DEVICE_MaxInlineImageSize 4000
@@ -1089,6 +1123,15 @@ round_box_coord(double xy)
{
return (int)(xy * 100 + 0.5) / 100.0;
}
+static int check_annot_in_named(void *client_data, const byte *key_data, uint key_size, const cos_value_t *value)
+{
+ cos_value_t *v = (cos_value_t *)client_data;
+
+ if (value->contents.object == v->contents.object)
+ return 1;
+ return 0;
+}
+
static int
pdf_write_page(gx_device_pdf *pdev, int page_num)
{
@@ -1411,8 +1454,16 @@ pdf_write_page(gx_device_pdf *pdev, int page_num)
e = cos_array_element_first(page->Annots);
while (e != NULL) {
next = cos_array_element_next(e, &index, &value);
- if (value->contents.object != NULL)
- value->contents.object->id = 0;
+ if (value->contents.object != NULL) {
+ /* Check to see if this is a local named object, if it is do not
+ * zero the ID! This object has not yet been written, because it
+ * is a named object it can be modified after creation. We must
+ * allow the named object code to write out the object and free it.
+ */
+ if (cos_dict_forall(pdev->local_named_objects, (void *)value,
+ check_annot_in_named) == 0)
+ value->contents.object->id = 0;
+ }
e = next;
}
COS_FREE(page->Annots, "pdf_write_page(Annots)");
@@ -2602,6 +2653,18 @@ pdf_close(gx_device * dev)
return_error(gs_error_undefined);
dev->is_open = false;
+ if (pdev->initial_pattern_states != NULL) {
+ int pdepth = 0;
+
+ while (pdev->initial_pattern_states[pdepth] != 0x00) {
+ gs_free_object(pdev->pdf_memory->non_gc_memory, pdev->initial_pattern_states[pdepth], "Freeing dangling pattern state");
+ pdev->initial_pattern_states[pdepth] = NULL;
+ pdepth++;
+ }
+ gs_free_object(pdev->pdf_memory->non_gc_memory, pdev->initial_pattern_states, "Freeing dangling pattern state stack");
+ pdev->initial_pattern_states = NULL;
+ }
+
if (pdev->Catalog)
Catalog_id = pdev->Catalog->id;
if (pdev->Info)
diff --git a/devices/vector/gdevpdfb.h b/devices/vector/gdevpdfb.h
index c0c3d220..daa6ba0a 100644
--- a/devices/vector/gdevpdfb.h
+++ b/devices/vector/gdevpdfb.h
@@ -27,88 +27,14 @@
#ifdef PDF_DEVICE_NAME
const gx_device_pdf PDF_DEVICE_IDENT =
-{std_device_dci_type_body(gx_device_pdf, 0, PDF_DEVICE_NAME,
+{std_device_dci_type_body(gx_device_pdf, pdfwrite_initialize_device_procs,
+ PDF_DEVICE_NAME,
&st_device_pdfwrite,
DEFAULT_WIDTH_10THS * X_DPI / 10,
DEFAULT_HEIGHT_10THS * Y_DPI / 10,
X_DPI, Y_DPI,
3, 24, 255, 255, 256, 256),
- {pdf_open,
- gx_upright_get_initial_matrix,
- NULL, /* sync_output */
- pdf_output_page,
- pdf_close,
- gx_default_rgb_map_rgb_color,
- gx_default_rgb_map_color_rgb,
- gdev_pdf_fill_rectangle,
- NULL, /* tile_rectangle */
- gdev_pdf_copy_mono,
- gdev_pdf_copy_color,
- NULL, /* draw_line */
- psdf_get_bits, /* get_bits */
- gdev_pdf_get_params,
- gdev_pdf_put_params,
- NULL, /* map_cmyk_color */
- NULL, /* get_xfont_procs */
- NULL, /* get_xfont_device */
- NULL, /* map_rgb_alpha_color */
- gx_page_device_get_page_device,
- NULL, /* get_alpha_bits */
- NULL, /* copy_alpha */
- NULL, /* get_band */
- NULL, /* copy_rop */
- gdev_pdf_fill_path,
- gdev_pdf_stroke_path,
- gdev_pdf_fill_mask,
- NULL, /* fill_trapezoid */
- NULL, /* fill_parallelogram */
- NULL, /* fill_triangle */
- NULL, /* draw_thin_line */
- NULL, /* begin_image */
- NULL, /* image_data */
- NULL, /* end_image */
- gdev_pdf_strip_tile_rectangle,
- NULL, /* strip_copy_rop */
- NULL, /* get_clipping_box */
- gdev_pdf_begin_typed_image,
- psdf_get_bits_rectangle, /* get_bits_rectangle */
- NULL, /* map_color_rgb_alpha */
- gdev_pdf_create_compositor, /* create_compositor */
- NULL, /* get_hardware_params */
- gdev_pdf_text_begin,
- NULL, /* finish_copydevice */
- gdev_pdf_begin_transparency_group, /* begin_transparency_group */
- gdev_pdf_end_transparency_group, /* end_transparency_group */
- gdev_pdf_begin_transparency_mask, /* begin_transparency_mask */
- gdev_pdf_end_transparency_mask, /* end_transparency_mask */
- NULL, /* discard_transparency_layer */
- NULL, /* get_color_mapping_procs */
- NULL, /* get_color_comp_index */
- NULL, /* encode_color */
- NULL, /* decode_color */
- NULL, /* pattern_manage */
- gdev_pdf_fill_rectangle_hl_color, /* fill_rectangle_hl_color */
- gdev_pdf_include_color_space, /* include_color_space */
- NULL, /* fill_linear_color_scanline */
- NULL, /* fill_linear_color_trapezoid */
- NULL, /* fill_linear_color_triangle */
- NULL, /* update_spot_equivalent_colors */
- NULL, /* ret_devn_params */
- gdev_pdf_fillpage, /* fillpage */
- NULL, /* push_transparency_state */
- NULL, /* pop_transparency_state */
- NULL, /* put_image */
- gdev_pdf_dev_spec_op, /* dev_spec_op */
- NULL, /* copy_planes */
- NULL, /* get_profile */
- NULL, /* set_graphics_type_tag */
- NULL, /* strip_copy_rop2 */
- NULL, /* strip_tile_rect_devn */
- NULL, /* copy_alpha_hl_color */
- NULL, /* process_page */
- NULL, /* transform_pixel_region */
- gdev_pdf_fill_stroke_path /* fill_stroke_path */
- },
+ { 0 },
psdf_initial_values(PSDF_VERSION_INITIAL, 0 /*false */ ), /* (!ASCII85EncodePages) */
0, /* pdf_font_dir */
PDF_FOR_OPDFREAD, /* is_ps2write */
@@ -309,7 +235,8 @@ const gx_device_pdf PDF_DEVICE_IDENT =
NULL, /* OCRUnicode */
0, /* OCR_char_code */
0, /* OCR_glyph */
- NULL /* ocr_glyphs */
+ NULL, /* ocr_glyphs */
+ 0 /* initial_pattern_state */
};
#else
diff --git a/devices/vector/gdevpdfd.c b/devices/vector/gdevpdfd.c
index 32f75555..c7cad3e5 100644
--- a/devices/vector/gdevpdfd.c
+++ b/devices/vector/gdevpdfd.c
@@ -181,6 +181,47 @@ pdf_dorect(gx_device_vector * vdev, fixed x0, fixed y0, fixed x1, fixed y1,
ymin -= d;
ymax += d;
}
+ if (pdev->PDFA == 1) {
+ /* Check values, and decide how to proceed based on PDFACompatibilitylevel */
+ if (x0 < xmin || y0 < ymin || x1 - x0 > xmax || y1 - y0 >ymax) {
+ switch(pdev->PDFACompatibilityPolicy) {
+ case 0:
+ emprintf(pdev->memory,
+ "Required co-ordinate outside valid range for PDF/A-1, reverting to normal PDF output.\n");
+ pdev->AbortPDFAX = true;
+ pdev->PDFA = 0;
+ break;
+ case 1:
+ emprintf(pdev->memory,
+ "Required co-ordinate outside valid range for PDF/A-1, clamping to valid range, output may be incorrect.\n");
+ /*
+ * Clamp coordinates to avoid tripping over Acrobat Reader's limit
+ * of 32K on user coordinate values, which was adopted by the PDF/A-1 spec.
+ */
+ if (x0 < xmin)
+ x0 = xmin;
+
+ if (y0 < ymin)
+ y0 = ymin;
+
+ /* We used to clamp x1 and y1 here, but actually, because this is a rectangle
+ * we don't need to do that, we need to clamp the *difference* between x0,x1
+ * and y0,y1 to keep it inside the Acrobat 4 or 5 limits.
+ */
+ if (x1 - x0 > xmax)
+ x1 = x0 + xmax;
+ if (y1 - y0 > ymax)
+ y1 = y0 + ymax;
+ break;
+ default:
+ case 2:
+ emprintf(pdev->memory,
+ "Required co-ordinate outside valid range for PDF/A-1, aborting.\n");
+ return_error(gs_error_limitcheck);
+ break;
+ }
+ }
+ }
return psdf_dorect(vdev, x0, y0, x1, y1, type);
}
@@ -780,6 +821,38 @@ pdf_put_clip_path(gx_device_pdf * pdev, const gx_clip_path * pcpath)
}
/*
+ * Compute the scaling to ensure that user coordinates for a path are within
+ * PDF/A-1 valid range. Return true if scaling was needed. In this case, the
+ * CTM will be multiplied by *pscale, and all coordinates will be divided by
+ * *pscale.
+ */
+static bool
+make_rect_scaling(const gx_device_pdf *pdev, const gs_fixed_rect *bbox,
+ double prescale, double *pscale)
+{
+ double bmin, bmax;
+
+ if (pdev->PDFA != 1) {
+ *pscale = 1;
+ return false;
+ }
+
+ bmin = min(bbox->p.x / pdev->scale.x, bbox->p.y / pdev->scale.y) * prescale;
+ bmax = max(bbox->q.x / pdev->scale.x, bbox->q.y / pdev->scale.y) * prescale;
+ if (bmin <= int2fixed(-MAX_USER_COORD) ||
+ bmax > int2fixed(MAX_USER_COORD)
+ ) {
+ /* Rescale the path. */
+ *pscale = max(bmin / int2fixed(-MAX_USER_COORD),
+ bmax / int2fixed(MAX_USER_COORD));
+ return true;
+ } else {
+ *pscale = 1;
+ return false;
+ }
+}
+
+/*
* Prepare a fill with a color anc a clipping path.
* Return 1 if there is nothing to paint.
* Changes *box to the clipping box.
@@ -1543,22 +1616,24 @@ gdev_pdf_fill_path(gx_device * dev, const gs_gstate * pgs, gx_path * ppath,
pi.saved = pgs2;
code = gx_path_bbox(ppath, &bbox);
if (code < 0)
- return code;
+ goto image_exit;
rect_intersect(bbox, box);
code = gx_dc_pattern2_get_bbox(pdcolor, &bbox1);
if (code < 0)
- return code;
+ goto image_exit;
if (code)
rect_intersect(bbox, bbox1);
- if (bbox.p.x >= bbox.q.x || bbox.p.y >= bbox.q.y)
- return 0;
+ if (bbox.p.x >= bbox.q.x || bbox.p.y >= bbox.q.y) {
+ code = 0;
+ goto image_exit;
+ }
sx = fixed2int(bbox.p.x);
sy = fixed2int(bbox.p.y);
gs_make_identity(&m);
rect_size.x = fixed2int(bbox.q.x + fixed_half) - sx;
rect_size.y = fixed2int(bbox.q.y + fixed_half) - sy;
if (rect_size.x == 0 || rect_size.y == 0)
- return 0;
+ goto image_exit;
m.tx = (float)sx;
m.ty = (float)sy;
cvd.path_offset.x = sx;
@@ -1614,6 +1689,7 @@ gdev_pdf_fill_path(gx_device * dev, const gs_gstate * pgs, gx_path * ppath,
stream_puts(pdev->strm, "Q Q\n");
pdf_remove_masked_image_converter(pdev, &cvd, need_mask);
gs_setmatrix((gs_gstate *)pgs, &save_ctm);
+image_exit:
gs_gstate_free(pgs2);
return code;
}
@@ -1622,6 +1698,8 @@ gdev_pdf_fill_path(gx_device * dev, const gs_gstate * pgs, gx_path * ppath,
return code;
{
stream *s = pdev->strm;
+ double scale;
+ gs_matrix smat, *psmat = NULL;
gs_path_enum cenum;
gdev_vector_dopath_state_t state;
@@ -1634,11 +1712,19 @@ gdev_pdf_fill_path(gx_device * dev, const gs_gstate * pgs, gx_path * ppath,
pprintg1(s, "%g i\n", params->flatness);
pdev->state.flatness = params->flatness;
}
+ if (make_rect_scaling(pdev, &box1, 1.0, &scale)) {
+ gs_make_scaling(pdev->scale.x * scale, pdev->scale.y * scale,
+ &smat);
+ pdf_put_matrix(pdev, "q ", &smat, "cm\n");
+ psmat = &smat;
+ }
code = pdf_write_path(pdev, (gs_path_enum *)&cenum, &state, (gx_path *)ppath, 0, gx_path_type_fill | gx_path_type_optimize, NULL);
if (code < 0)
return code;
stream_puts(s, (params->rule < 0 ? "f\n" : "f*\n"));
+ if (psmat != NULL)
+ stream_puts(pdev->strm, "Q\n");
}
return 0;
}
@@ -1652,9 +1738,10 @@ gdev_pdf_stroke_path(gx_device * dev, const gs_gstate * pgs,
gx_device_pdf *pdev = (gx_device_pdf *) dev;
stream *s;
int code;
- double scale;
+ double scale, path_scale;
bool set_ctm;
gs_matrix mat;
+ double prescale = 1;
gs_fixed_rect bbox;
gs_path_enum cenum;
gdev_vector_dopath_state_t state;
@@ -1740,6 +1827,20 @@ gdev_pdf_stroke_path(gx_device * dev, const gs_gstate * pgs,
scale = fabs(pgs->ctm.xx + pgs->ctm.xy + pgs->ctm.yx + pgs->ctm.yy) /* Using the non-zero coeff. */
/ sqrt(2); /* Empirically from Adobe. */
}
+ if (set_ctm && pdev->PDFA == 1) {
+ /*
+ * We want a scaling factor that will bring the largest reasonable
+ * user coordinate within bounds. We choose a factor based on the
+ * minor axis of the transformation. Thanks to Raph Levien for
+ * the following formula.
+ */
+ double a = mat.xx, b = mat.xy, c = mat.yx, d = mat.yy;
+ double u = fabs(a * d - b * c);
+ double v = a * a + b * b + c * c + d * d;
+ double minor = (sqrt(v + 2 * u) - sqrt(v - 2 * u)) * 0.5;
+
+ prescale = (minor == 0 || minor > 1 ? 1 : 1 / minor);
+ }
gx_path_bbox(ppath, &bbox);
{
/* Check whether a painting appears inside the clipping box.
@@ -1772,6 +1873,15 @@ gdev_pdf_stroke_path(gx_device * dev, const gs_gstate * pgs,
if (stroke_bbox.q.x < stroke_bbox.p.x || stroke_bbox.q.y < stroke_bbox.p.y)
return 0;
}
+ if (make_rect_scaling(pdev, &bbox, prescale, &path_scale)) {
+ scale /= path_scale;
+ if (set_ctm)
+ gs_matrix_scale(&mat, path_scale, path_scale, &mat);
+ else {
+ gs_make_scaling(path_scale, path_scale, &mat);
+ set_ctm = true;
+ }
+ }
code = gdev_vector_prepare_stroke((gx_device_vector *)pdev, pgs, params,
pdcolor, scale);
if (code < 0)
@@ -1838,7 +1948,8 @@ gdev_pdf_fill_stroke_path(gx_device *dev, const gs_gstate *pgs, gx_path *ppath,
} else {
bool set_ctm;
gs_matrix mat;
- double scale;
+ double scale, path_scale;
+ double prescale = 1;
gs_fixed_rect bbox;
gs_path_enum cenum;
gdev_vector_dopath_state_t state;
@@ -1901,6 +2012,20 @@ gdev_pdf_fill_stroke_path(gx_device *dev, const gs_gstate *pgs, gx_path *ppath,
scale = fabs(pgs->ctm.xx + pgs->ctm.xy + pgs->ctm.yx + pgs->ctm.yy) /* Using the non-zero coeff. */
/ sqrt(2); /* Empirically from Adobe. */
}
+ if (pdev->PDFA == 1 && set_ctm) {
+ /*
+ * We want a scaling factor that will bring the largest reasonable
+ * user coordinate within bounds. We choose a factor based on the
+ * minor axis of the transformation. Thanks to Raph Levien for
+ * the following formula.
+ */
+ double a = mat.xx, b = mat.xy, c = mat.yx, d = mat.yy;
+ double u = fabs(a * d - b * c);
+ double v = a * a + b * b + c * c + d * d;
+ double minor = (sqrt(v + 2 * u) - sqrt(v - 2 * u)) * 0.5;
+
+ prescale = (minor == 0 || minor > 1 ? 1 : 1 / minor);
+ }
gx_path_bbox(ppath, &bbox);
{
/* Check whether a painting appears inside the clipping box.
@@ -1933,6 +2058,15 @@ gdev_pdf_fill_stroke_path(gx_device *dev, const gs_gstate *pgs, gx_path *ppath,
if (stroke_bbox.q.x < stroke_bbox.p.x || stroke_bbox.q.y < stroke_bbox.p.y)
return 0;
}
+ if (make_rect_scaling(pdev, &bbox, prescale, &path_scale)) {
+ scale /= path_scale;
+ if (set_ctm)
+ gs_matrix_scale(&mat, path_scale, path_scale, &mat);
+ else {
+ gs_make_scaling(path_scale, path_scale, &mat);
+ set_ctm = true;
+ }
+ }
code = pdf_setfillcolor((gx_device_vector *)pdev, pgs, pdcolor_fill);
if (code == gs_error_rangecheck) {
@@ -1987,6 +2121,8 @@ gdev_pdf_fill_rectangle_hl_color(gx_device *dev, const gs_fixed_rect *rect,
int code;
gs_fixed_rect box1 = *rect, box = box1;
gx_device_pdf *pdev = (gx_device_pdf *) dev;
+ double scale;
+ gs_matrix smat, *psmat = NULL;
const bool convert_to_image = (pdev->CompatibilityLevel <= 1.2 &&
gx_dc_is_pattern2_color(pdcolor));
@@ -2005,9 +2141,16 @@ gdev_pdf_fill_rectangle_hl_color(gx_device *dev, const gs_fixed_rect *rect,
rect_intersect(box1, box);
if (box1.p.x > box1.q.x || box1.p.y > box1.q.y)
return 0; /* outside the clipping path */
+ if (make_rect_scaling(pdev, &box1, 1.0, &scale)) {
+ gs_make_scaling(pdev->scale.x * scale, pdev->scale.y * scale, &smat);
+ pdf_put_matrix(pdev, "q ", &smat, "cm\n");
+ psmat = &smat;
+ }
pprintg4(pdev->strm, "%g %g %g %g re f\n",
- fixed2float(box1.p.x), fixed2float(box1.p.y),
- fixed2float(box1.q.x - box1.p.x) , fixed2float(box1.q.y - box1.p.y));
+ fixed2float(box1.p.x) / scale, fixed2float(box1.p.y) / scale,
+ fixed2float(box1.q.x - box1.p.x) / scale, fixed2float(box1.q.y - box1.p.y) / scale);
+ if (psmat != NULL)
+ stream_puts(pdev->strm, "Q\n");
if (pdev->Eps2Write) {
gs_rect *Box;
diff --git a/devices/vector/gdevpdfg.c b/devices/vector/gdevpdfg.c
index f08acb7c..6feec8b0 100644
--- a/devices/vector/gdevpdfg.c
+++ b/devices/vector/gdevpdfg.c
@@ -215,9 +215,9 @@ pdf_viewer_state_from_gs_gstate_aux(pdf_viewer_state *pvs, const gs_gstate *pgs)
pvs->strokeconstantalpha = pgs->strokeconstantalpha;
pvs->alphaisshape = pgs->alphaisshape;
pvs->blend_mode = pgs->blend_mode;
- pvs->halftone_id = (pgs->dev_ht != 0 ? pgs->dev_ht->id : 0);
- pvs->black_generation_id = (pgs->black_generation != 0 ? pgs->black_generation->id : 0);
- pvs->undercolor_removal_id = (pgs->undercolor_removal != 0 ? pgs->undercolor_removal->id : 0);
+ pvs->halftone_id = (pgs->dev_ht[HT_OBJTYPE_DEFAULT] != NULL ? pgs->dev_ht[HT_OBJTYPE_DEFAULT]->id : 0);
+ pvs->black_generation_id = (pgs->black_generation != NULL ? pgs->black_generation->id : 0);
+ pvs->undercolor_removal_id = (pgs->undercolor_removal != NULL ? pgs->undercolor_removal->id : 0);
pvs->overprint_mode = 0;
pvs->flatness = pgs->flatness;
pvs->smoothness = pgs->smoothness;
@@ -2713,7 +2713,7 @@ pdf_update_halftone(gx_device_pdf *pdev, const gs_gstate *pgs,
char *hts)
{
const gs_halftone *pht = pgs->halftone;
- const gx_device_halftone *pdht = pgs->dev_ht;
+ const gx_device_halftone *pdht = pgs->dev_ht[HT_OBJTYPE_DEFAULT];
int code;
long id;
@@ -2749,7 +2749,7 @@ pdf_update_halftone(gx_device_pdf *pdev, const gs_gstate *pgs,
if (code < 0)
return code;
gs_sprintf(hts, "%ld 0 R", id);
- pdev->halftone_id = pgs->dev_ht->id;
+ pdev->halftone_id = pgs->dev_ht[HT_OBJTYPE_DEFAULT]->id;
return code;
}
@@ -2910,22 +2910,24 @@ pdf_update_alpha(gx_device_pdf *pdev, const gs_gstate *pgs,
pdev->state.strokeconstantalpha != pgs->strokeconstantalpha ||
pdev->state.fillconstantalpha != pgs->fillconstantalpha) {
- pdev->state.strokeconstantalpha = pgs->strokeconstantalpha;
- pdev->state.fillconstantalpha = pgs->fillconstantalpha;
- pdev->state.alphaisshape = pgs->alphaisshape;
-
code = pdf_open_gstate(pdev, ppres);
if (code < 0)
return code;
+
code = cos_dict_put_c_key_bool(resource_dict(*ppres), "/AIS", pgs->alphaisshape);
if (code < 0)
return code;
+ pdev->state.alphaisshape = pgs->alphaisshape;
code = cos_dict_put_c_key_real(resource_dict(*ppres), "/CA", pgs->strokeconstantalpha);
if (code < 0)
return code;
- return cos_dict_put_c_key_real(resource_dict(*ppres), "/ca", pgs->fillconstantalpha);
- } else
- return 0;
+ pdev->state.strokeconstantalpha = pgs->strokeconstantalpha;
+ code = cos_dict_put_c_key_real(resource_dict(*ppres), "/ca", pgs->fillconstantalpha);
+ if (code < 0)
+ return code;
+ pdev->state.fillconstantalpha = pgs->fillconstantalpha;
+ }
+ return 0;
}
/*
@@ -2986,7 +2988,7 @@ pdf_prepare_drawing(gx_device_pdf *pdev, const gs_gstate *pgs,
hts[0] = trs[0] = bgs[0] = ucrs[0] = 0;
if (pdev->params.PreserveHalftoneInfo &&
- pdev->halftone_id != pgs->dev_ht->id &&
+ pdev->halftone_id != pgs->dev_ht[HT_OBJTYPE_DEFAULT]->id &&
!pdev->PDFX
) {
code = pdf_update_halftone(pdev, pgs, hts);
diff --git a/devices/vector/gdevpdfi.c b/devices/vector/gdevpdfi.c
index 08e217fa..82e8f7a2 100644
--- a/devices/vector/gdevpdfi.c
+++ b/devices/vector/gdevpdfi.c
@@ -80,6 +80,7 @@ typedef struct pdf_image_enum_s {
gs_matrix mat;
gs_color_space_index initial_colorspace;
int JPEG_PassThrough;
+ int JPX_PassThrough;
} pdf_image_enum;
gs_private_st_composite(st_pdf_image_enum, pdf_image_enum, "pdf_image_enum",
pdf_image_enum_enum_ptrs, pdf_image_enum_reloc_ptrs);
@@ -1115,6 +1116,7 @@ pdf_begin_typed_image(gx_device_pdf *pdev, const gs_gstate * pgs,
* should get the data. But lets get the simple code working first.
*/
pdev->JPEG_PassThrough = 0;
+ pdev->JPX_PassThrough = 0;
pdev->image_mask_is_SMask = false;
if (pdev->CompatibilityLevel < 1.2 ||
(prect && !(prect->p.x == 0 && prect->p.y == 0 &&
@@ -1128,6 +1130,7 @@ pdf_begin_typed_image(gx_device_pdf *pdev, const gs_gstate * pgs,
case IMAGE3X_IMAGETYPE:
pdev->JPEG_PassThrough = 0;
+ pdev->JPX_PassThrough = 0;
if (pdev->CompatibilityLevel < 1.4 ||
(prect && !(prect->p.x == 0 && prect->p.y == 0 &&
prect->q.x == ((const gs_image3x_t *)pic)->Width &&
@@ -1195,6 +1198,7 @@ pdf_begin_typed_image(gx_device_pdf *pdev, const gs_gstate * pgs,
* the image.
*/
pdev->JPEG_PassThrough = 0;
+ pdev->JPX_PassThrough = 0;
use_fallback = 0;
code = convert_type4_to_masked_image(pdev, pgs, pic, prect, pdcolor,
pcpath, mem,pinfo);
@@ -1207,6 +1211,7 @@ pdf_begin_typed_image(gx_device_pdf *pdev, const gs_gstate * pgs,
}
}
pdev->JPEG_PassThrough = 0;
+ pdev->JPX_PassThrough = 0;
code = convert_type4_image(pdev, pgs, pmat, pic, prect, pdcolor,
pcpath, mem, pinfo, context, image, pnamed);
if (code < 0)
@@ -1447,12 +1452,16 @@ pdf_begin_typed_image(gx_device_pdf *pdev, const gs_gstate * pgs,
if (code < 0)
goto fail_and_fallback;
+ if (pdev->CompatibilityLevel < 1.5)
+ pdev->JPX_PassThrough = 0;
+
if (!convert_to_process_colors)
{
gs_color_space_index csi;
if (pdev->params.TransferFunctionInfo == tfi_Apply && pdev->transfer_not_identity && !is_mask) {
pdev->JPEG_PassThrough = 0;
+ pdev->JPX_PassThrough = 0;
csi = gs_color_space_get_index(image[0].pixel.ColorSpace);
if (csi == gs_color_space_index_Indexed) {
csi = gs_color_space_get_index(image[0].pixel.ColorSpace->base_space);
@@ -1503,7 +1512,7 @@ pdf_begin_typed_image(gx_device_pdf *pdev, const gs_gstate * pgs,
}
/* If we are not preserving the colour space unchanged, then we can't pass through JPEG */
else
- pdev->JPEG_PassThrough = 0;
+ pdev->JPEG_PassThrough = pdev->JPX_PassThrough = 0;
/* Code below here deals with setting up the multiple data stream writing.
* We can have up to 4 stream writers, which we keep in an array. We must
@@ -1518,6 +1527,7 @@ pdf_begin_typed_image(gx_device_pdf *pdev, const gs_gstate * pgs,
*/
if (in_line) {
pdev->JPEG_PassThrough = 0;
+ pdev->JPX_PassThrough = 0;
code = new_setup_lossless_filters((gx_device_psdf *) pdev,
&pie->writer.binary[0],
&image[0].pixel, in_line, convert_to_process_colors, (gs_matrix *)pmat, (gs_gstate *)pgs);
@@ -1559,7 +1569,7 @@ pdf_begin_typed_image(gx_device_pdf *pdev, const gs_gstate * pgs,
image[0].pixel.ColorSpace = pcs_device;
}
- if (pdev->JPEG_PassThrough) {
+ if (pdev->JPEG_PassThrough || pdev->JPX_PassThrough) {
/* if (pie->writer.alt_writer_count > 1) {
s_close_filters(&pie->writer.binary[0].strm, uncompressed);
memset(pie->writer.binary + 1, 0, sizeof(pie->writer.binary[1]));
@@ -1569,6 +1579,7 @@ pdf_begin_typed_image(gx_device_pdf *pdev, const gs_gstate * pgs,
pie->writer.alt_writer_count = 1;
}
pie->JPEG_PassThrough = pdev->JPEG_PassThrough;
+ pie->JPX_PassThrough = pdev->JPX_PassThrough;
if (pie->writer.alt_writer_count > 1) {
code = pdf_make_alt_stream(pdev, &pie->writer.binary[1]);
@@ -1681,6 +1692,7 @@ pdf_begin_typed_image(gx_device_pdf *pdev, const gs_gstate * pgs,
/* Do the fallback */
if (use_fallback) {
pdev->JPEG_PassThrough = 0;
+ pdev->JPX_PassThrough = 0;
code = gx_default_begin_typed_image
((gx_device *)pdev, pgs, pmat, pic, prect, pdcolor, pcpath, mem, pinfo);
}
@@ -1789,7 +1801,7 @@ pdf_image_plane_data(gx_image_enum_common_t * info,
pdf_image_enum *pie = (pdf_image_enum *) info;
int i;
- if (pie->JPEG_PassThrough) {
+ if (pie->JPEG_PassThrough || pie->JPX_PassThrough) {
pie->rows_left -= height;
*rows_used = height;
return !pie->rows_left;
@@ -2291,6 +2303,81 @@ check_unsubstituted1(gx_device_pdf * pdev, pdf_resource_t *pres0)
return ppat->substitute != NULL;
}
+static int reset_gstate_for_pattern(gx_device_pdf * pdev, gs_gstate *destination, gs_gstate *source)
+{
+ if (pdev->vg_initial_set) {
+ destination->strokeconstantalpha = source->strokeconstantalpha;
+ source->strokeconstantalpha = pdev->vg_initial.strokeconstantalpha;
+ destination->fillconstantalpha = source->fillconstantalpha;
+ source->fillconstantalpha = pdev->vg_initial.fillconstantalpha;
+ if (destination->set_transfer.red != NULL)
+ destination->set_transfer.red->id = (source->set_transfer.red != NULL ? source->set_transfer.red->id : 0);
+ if (destination->set_transfer.green != NULL)
+ destination->set_transfer.green->id = (source->set_transfer.green != NULL ? source->set_transfer.green->id : 0);
+ if (destination->set_transfer.blue != NULL)
+ destination->set_transfer.blue->id = (source->set_transfer.blue != NULL ? source->set_transfer.blue->id : 0);
+ if (destination->set_transfer.gray != NULL)
+ destination->set_transfer.gray->id = (source->set_transfer.gray != NULL ? source->set_transfer.gray->id : 0);
+ if (source->set_transfer.red != NULL)
+ source->set_transfer.red->id = pdev->vg_initial.transfer_ids[0];
+ if (source->set_transfer.green != NULL)
+ source->set_transfer.green->id = pdev->vg_initial.transfer_ids[1];
+ if (source->set_transfer.blue != NULL)
+ source->set_transfer.blue->id = pdev->vg_initial.transfer_ids[2];
+ if (source->set_transfer.gray != NULL)
+ source->set_transfer.gray->id = pdev->vg_initial.transfer_ids[3];
+ destination->alphaisshape = source->alphaisshape;
+ source->alphaisshape = pdev->vg_initial.alphaisshape;
+ destination->blend_mode = source->blend_mode;
+ source->blend_mode = pdev->vg_initial.blend_mode;
+ if (destination->black_generation != NULL)
+ destination->black_generation->id = (source->black_generation != NULL ? source->black_generation->id : 0);
+ if (source->black_generation != NULL)
+ source->black_generation->id = pdev->vg_initial.black_generation_id;
+ if (destination->undercolor_removal != NULL)
+ destination->undercolor_removal->id = (source->undercolor_removal != NULL ? source->undercolor_removal->id : 0);
+ if (source->undercolor_removal != NULL)
+ source->undercolor_removal->id = pdev->vg_initial.undercolor_removal_id;
+ destination->overprint_mode = source->overprint_mode;
+ source->overprint_mode = pdev->vg_initial.overprint_mode;
+ destination->flatness = source->flatness;
+ source->flatness = pdev->vg_initial.flatness;
+ destination->smoothness = source->smoothness;
+ source->smoothness = pdev->vg_initial.smoothness;
+ destination->flatness = source->flatness;
+ source->flatness = pdev->vg_initial.flatness;
+ destination->text_knockout = source->text_knockout;
+ source->text_knockout = pdev->vg_initial.text_knockout;
+ destination->stroke_adjust = source->stroke_adjust;
+ source->stroke_adjust = pdev->vg_initial.stroke_adjust;
+ destination->line_params.half_width = source->line_params.half_width;
+ source->line_params.half_width = pdev->vg_initial.line_params.half_width;
+ destination->line_params.start_cap = source->line_params.start_cap;
+ source->line_params.start_cap = pdev->vg_initial.line_params.start_cap;
+ destination->line_params.end_cap = source->line_params.end_cap;
+ source->line_params.end_cap = pdev->vg_initial.line_params.end_cap;
+ destination->line_params.dash_cap = source->line_params.dash_cap;
+ source->line_params.dash_cap = pdev->vg_initial.line_params.dash_cap;
+ destination->line_params.join = source->line_params.join;
+ source->line_params.join = pdev->vg_initial.line_params.join;
+ destination->line_params.curve_join = source->line_params.curve_join;
+ source->line_params.curve_join = pdev->vg_initial.line_params.curve_join;
+ destination->line_params.miter_limit = source->line_params.miter_limit;
+ source->line_params.miter_limit = pdev->vg_initial.line_params.miter_limit;
+ destination->line_params.miter_check = source->line_params.miter_check;
+ source->line_params.miter_check = pdev->vg_initial.line_params.miter_check;
+ destination->line_params.dot_length = source->line_params.dot_length;
+ source->line_params.dot_length = pdev->vg_initial.line_params.dot_length;
+ destination->line_params.dot_length_absolute = source->line_params.dot_length_absolute;
+ source->line_params.dot_length_absolute = pdev->vg_initial.line_params.dot_length_absolute;
+ destination->line_params.dot_orientation = source->line_params.dot_orientation;
+ source->line_params.dot_orientation = pdev->vg_initial.line_params.dot_orientation;
+ memcpy(&destination->line_params.dash, &source->line_params.dash, sizeof(source->line_params.dash));
+ memcpy(&source->line_params.dash, &pdev->vg_initial.line_params.dash, sizeof(source->line_params.dash));
+ }
+ return 0;
+}
+
/*
The device specific operations - just pattern management.
See gxdevcli.h about return codes.
@@ -2304,6 +2391,8 @@ gdev_pdf_dev_spec_op(gx_device *pdev1, int dev_spec_op, void *data, int size)
gx_bitmap_id id = (gx_bitmap_id)size;
switch (dev_spec_op) {
+ case gxdso_supports_pattern_transparency:
+ return 1;
case gxdso_pattern_can_accum:
return 1;
case gxdso_pdf_form_name:
@@ -2608,10 +2697,50 @@ gdev_pdf_dev_spec_op(gx_device *pdev1, int dev_spec_op, void *data, int size)
code = pdf_check_soft_mask(pdev, (gs_gstate *)pgs);
if (code < 0)
return code;
+ if (pdev->context == PDF_IN_NONE) {
+ code = pdf_open_page(pdev, PDF_IN_STREAM);
+ if (code < 0)
+ return code;
+ }
+ code = pdf_prepare_fill_stroke(pdev, (gs_gstate *)pgs, false);
+ if (code < 0)
+ return code;
+ if (pdev->PatternDepth == 0 && pdev->initial_pattern_states != NULL) {
+ int pdepth = 0;
+
+ while (pdev->initial_pattern_states[pdepth] != 0x00) {
+ gs_free_object(pdev->pdf_memory->non_gc_memory, pdev->initial_pattern_states[pdepth], "Freeing dangling pattern state");
+ pdev->initial_pattern_states[pdepth] = NULL;
+ pdepth++;
+ }
+ gs_free_object(pdev->pdf_memory->non_gc_memory, pdev->initial_pattern_states, "Freeing dangling pattern state stack");
+ }
+
+ {
+ gs_gstate **new_states;
+ int pdepth;
+
+ new_states = (gs_gstate **)gs_alloc_bytes(pdev->pdf_memory->non_gc_memory, sizeof(gs_gstate *) * (pdev->PatternDepth + 2), "pattern initial graphics state stack");
+ memset(new_states, 0x00, sizeof(gs_gstate *) * (pdev->PatternDepth + 2));
+ for (pdepth = 0; pdepth < pdev->PatternDepth;pdepth++)
+ new_states[pdepth] = pdev->initial_pattern_states[pdepth];
+ gs_free_object(pdev->pdf_memory->non_gc_memory, pdev->initial_pattern_states, "Freeing old pattern state stack");
+ pdev->initial_pattern_states = new_states;
+ }
+ pdev->initial_pattern_states[pdev->PatternDepth] = (gs_gstate *)gs_alloc_bytes(pdev->pdf_memory->non_gc_memory, sizeof(gs_gstate), "pattern initial graphics state");
+ if (pdev->initial_pattern_states[pdev->PatternDepth] == NULL)
+ return code;
+ memset(pdev->initial_pattern_states[pdev->PatternDepth], 0x00, sizeof(gs_gstate));
+
+ reset_gstate_for_pattern(pdev, pdev->initial_pattern_states[pdev->PatternDepth], pgs);
code = pdf_enter_substream(pdev, resourcePattern, id, &pres, false,
pdev->CompressStreams);
- if (code < 0)
+ if (code < 0) {
+ gs_free_object(pdev->pdf_memory->non_gc_memory, pdev->initial_pattern_states[pdev->PatternDepth], "Freeing dangling pattern state");
+ pdev->initial_pattern_states[pdev->PatternDepth] = NULL;
return code;
+ }
+
/* We have started a new substream, to avoid confusing the 'saved viewer state'
* (the stack of pdfwrite's saved copies of graophics states) we need to reset the
* soft_mask_id, which is the ID of the SMask we have already created in the pdfwrite
@@ -2622,8 +2751,11 @@ gdev_pdf_dev_spec_op(gx_device *pdev1, int dev_spec_op, void *data, int size)
pdev->state.soft_mask_id = pgs->soft_mask_id;
pres->rid = id;
code = pdf_store_pattern1_params(pdev, pres, pinst);
- if (code < 0)
+ if (code < 0) {
+ gs_free_object(pdev->pdf_memory->non_gc_memory, pdev->initial_pattern_states[pdev->PatternDepth], "Freeing dangling pattern state");
+ pdev->initial_pattern_states[pdev->PatternDepth] = NULL;
return code;
+ }
/* Scale the coordinate system, because object handlers assume so. See none_to_stream. */
pprintg2(pdev->strm, "%g 0 0 %g 0 0 cm\n",
72.0 / pdev->HWResolution[0], 72.0 / pdev->HWResolution[1]);
@@ -2632,43 +2764,68 @@ gdev_pdf_dev_spec_op(gx_device *pdev1, int dev_spec_op, void *data, int size)
}
return 1;
case gxdso_pattern_finish_accum:
- if (pdev->CompatibilityLevel <= 1.7) {
- if (pdev->substream_Resources == NULL) {
- pdev->substream_Resources = cos_dict_alloc(pdev, "pdf_pattern(Resources)");
- if (pdev->substream_Resources == NULL)
- return_error(gs_error_VMerror);
+ {
+ pattern_accum_param_s *param = (pattern_accum_param_s *)data;
+ gs_gstate *pgs = param->graphics_state;
+
+ if (pdev->CompatibilityLevel <= 1.7) {
+ if (pdev->substream_Resources == NULL) {
+ pdev->substream_Resources = cos_dict_alloc(pdev, "pdf_pattern(Resources)");
+ if (pdev->substream_Resources == NULL)
+ return_error(gs_error_VMerror);
+ }
+ code = pdf_add_procsets(pdev->substream_Resources, pdev->procsets);
+ if (code < 0) {
+ gs_free_object(pdev->pdf_memory->non_gc_memory, pdev->initial_pattern_states[pdev->PatternDepth], "Freeing dangling pattern state");
+ pdev->initial_pattern_states[pdev->PatternDepth] = NULL;
+ return code;
+ }
}
- code = pdf_add_procsets(pdev->substream_Resources, pdev->procsets);
- if (code < 0)
+ pres = pres1 = pdev->accumulating_substream_resource;
+ code = pdf_exit_substream(pdev);
+ if (code < 0) {
+ gs_free_object(pdev->pdf_memory->non_gc_memory, pdev->initial_pattern_states[pdev->PatternDepth], "Freeing dangling pattern state");
+ pdev->initial_pattern_states[pdev->PatternDepth] = NULL;
return code;
- }
- pres = pres1 = pdev->accumulating_substream_resource;
- code = pdf_exit_substream(pdev);
- if (code < 0)
- return code;
- if (pdev->substituted_pattern_count > 300 &&
- pdev->substituted_pattern_drop_page != pdev->next_page) { /* arbitrary */
- pdf_drop_resources(pdev, resourcePattern, check_unsubstituted1);
- pdev->substituted_pattern_count = 0;
- pdev->substituted_pattern_drop_page = pdev->next_page;
- }
- code = pdf_find_same_resource(pdev, resourcePattern, &pres, check_unsubstituted2);
- if (code < 0)
- return code;
- if (code > 0) {
- pdf_pattern_t *ppat = (pdf_pattern_t *)pres1;
-
- code = pdf_cancel_resource(pdev, pres1, resourcePattern);
- if (code < 0)
+ }
+ if (pdev->substituted_pattern_count > 300 &&
+ pdev->substituted_pattern_drop_page != pdev->next_page) { /* arbitrary */
+ pdf_drop_resources(pdev, resourcePattern, check_unsubstituted1);
+ pdev->substituted_pattern_count = 0;
+ pdev->substituted_pattern_drop_page = pdev->next_page;
+ }
+ code = pdf_find_same_resource(pdev, resourcePattern, &pres, check_unsubstituted2);
+ if (code < 0) {
+ gs_free_object(pdev->pdf_memory->non_gc_memory, pdev->initial_pattern_states[pdev->PatternDepth], "Freeing dangling pattern state");
+ pdev->initial_pattern_states[pdev->PatternDepth] = NULL;
return code;
- /* Do not remove pres1, because it keeps the substitution. */
- ppat->substitute = (pdf_pattern_t *)pres;
- pres->where_used |= pdev->used_mask;
- pdev->substituted_pattern_count++;
- } else if (pres->object->id < 0)
- pdf_reserve_object_id(pdev, pres, 0);
- pdev->PatternDepth--;
- pdev->PatternsSinceForm--;
+ }
+ if (code > 0) {
+ pdf_pattern_t *ppat = (pdf_pattern_t *)pres1;
+
+ code = pdf_cancel_resource(pdev, pres1, resourcePattern);
+ if (code < 0) {
+ gs_free_object(pdev->pdf_memory->non_gc_memory, pdev->initial_pattern_states[pdev->PatternDepth], "Freeing dangling pattern state");
+ pdev->initial_pattern_states[pdev->PatternDepth] = NULL;
+ return code;
+ }
+ /* Do not remove pres1, because it keeps the substitution. */
+ ppat->substitute = (pdf_pattern_t *)pres;
+ pres->where_used |= pdev->used_mask;
+ pdev->substituted_pattern_count++;
+ } else if (pres->object->id < 0)
+ pdf_reserve_object_id(pdev, pres, 0);
+ reset_gstate_for_pattern(pdev, pgs, pdev->initial_pattern_states[pdev->PatternDepth - 1]);
+ gs_free_object(pdev->pdf_memory->non_gc_memory, pdev->initial_pattern_states[pdev->PatternDepth - 1], "Freeing dangling pattern state");
+ pdev->initial_pattern_states[pdev->PatternDepth - 1] = NULL;
+ if (pdev->PatternDepth == 1) {
+ gs_free_object(pdev->pdf_memory->non_gc_memory, pdev->initial_pattern_states, "Freeing dangling pattern state");
+ pdev->initial_pattern_states = NULL;
+ }
+
+ pdev->PatternDepth--;
+ pdev->PatternsSinceForm--;
+ }
return 1;
case gxdso_pattern_load:
pres = pdf_find_resource_by_gs_id(pdev, resourcePattern, id);
@@ -2728,6 +2885,29 @@ gdev_pdf_dev_spec_op(gx_device *pdev1, int dev_spec_op, void *data, int size)
pdev->PassThroughWriter = 0;
return 0;
break;
+ case gxdso_JPX_passthrough_query:
+ pdev->JPX_PassThrough = pdev->params.PassThroughJPXImages;
+ return 1;
+ break;
+ case gxdso_JPX_passthrough_begin:
+ return 0;
+ break;
+ case gxdso_JPX_passthrough_data:
+ if (pdev->JPX_PassThrough && pdev->PassThroughWriter)
+ {
+ uint ignore;
+ if (sputs(pdev->PassThroughWriter,
+ data, size,
+ &ignore) < 0)
+ return_error(gs_error_ioerror);
+ }
+ return 0;
+ break;
+ case gxdso_JPX_passthrough_end:
+ pdev->JPX_PassThrough = 0;
+ pdev->PassThroughWriter = 0;
+ return 0;
+ break;
case gxdso_event_info:
{
dev_param_req_t *request = (dev_param_req_t *)data;
diff --git a/devices/vector/gdevpdfj.c b/devices/vector/gdevpdfj.c
index 6140d4d6..02692510 100644
--- a/devices/vector/gdevpdfj.c
+++ b/devices/vector/gdevpdfj.c
@@ -412,6 +412,9 @@ pdf_begin_image_data(gx_device_pdf * pdev, pdf_image_writer * piw,
if (pdev->JPEG_PassThrough) {
CHECK(cos_dict_put_c_strings(pcd, "/Filter", "/DCTDecode"));
}
+ if (pdev->JPX_PassThrough) {
+ CHECK(cos_dict_put_c_strings(pcd, "/Filter", "/JPXDecode"));
+ }
return code;
}
diff --git a/devices/vector/gdevpdfm.c b/devices/vector/gdevpdfm.c
index ba00700a..902c17ac 100644
--- a/devices/vector/gdevpdfm.c
+++ b/devices/vector/gdevpdfm.c
@@ -879,6 +879,8 @@ pdfmark_put_ao_pairs(gx_device_pdf * pdev, cos_dict_t *pcd,
i = 2;
if (Dest.size > 5 && Dest.data[2] == 0x00 && Dest.data[3] == 0x00)
i += 2;
+ /* If it has preceeding NULLs, then it has a terminating NULL as well, get rid of that too */
+ Dest.size--;
}
if (Dest.data[i] == '/') {
@@ -1931,6 +1933,31 @@ pdfmark_PAGELABEL(gx_device_pdf * pdev, gs_param_string * pairs, uint count,
return 0;
}
+static int is_XMP_Key(gs_param_string *param)
+{
+ if (pdf_key_eq(param, "/Title"))
+ return 1;
+ if (pdf_key_eq(param, "/Author"))
+ return 1;
+ if (pdf_key_eq(param, "/Subject"))
+ return 1;
+ if (pdf_key_eq(param, "/Keywords"))
+ return 1;
+ if (pdf_key_eq(param, "/Creator"))
+ return 1;
+ if (pdf_key_eq(param, "/Producer"))
+ return 1;
+ /* These two aren't string data types and so won't affect anything
+ * in the DOCINFO pdfmark, which is the only client for this code currently
+ * but we may want to use this in future for other purposed.
+ */
+ if (pdf_key_eq(param, "/CreationDate"))
+ return 1;
+ if (pdf_key_eq(param, "/ModDate"))
+ return 1;
+ return 0;
+}
+
/* DOCINFO pdfmark */
static int
pdfmark_DOCINFO(gx_device_pdf * pdev, gs_param_string * pairs, uint count,
@@ -1954,7 +1981,7 @@ pdfmark_DOCINFO(gx_device_pdf * pdev, gs_param_string * pairs, uint count,
continue;
}
- if (pdev->PDFA !=0) {
+ if (pdev->PDFA !=0 && is_XMP_Key(pair)) {
const gs_param_string *p = pairs + i + 1;
bool abort = false;
diff --git a/devices/vector/gdevpdfp.c b/devices/vector/gdevpdfp.c
index e78d9596..42fa1c52 100644
--- a/devices/vector/gdevpdfp.c
+++ b/devices/vector/gdevpdfp.c
@@ -595,28 +595,13 @@ gdev_pdf_put_params_impl(gx_device * dev, const gx_device_pdf * save_dev, gs_par
case 1:
break;
}
- { /* HACK : gs_param_list_s::memory is documented in gsparam.h as
- "for allocating coerced arrays". Not sure why zputdeviceparams
- sets it to the current memory space, while the device
- assumes to store them in the device's memory space.
- As a hackish workaround we temporary replace it here.
- Doing so because we don't want to change the global code now
- because we're unable to test it with all devices.
- Bug 688531 "Segmentation fault running pdfwrite from 219-01.ps".
-
- This solution to be reconsidered after fixing
- the bug 688533 "zputdeviceparams specifies a wrong memory space.".
- */
- gs_memory_t *mem = plist->memory;
-
- plist->memory = pdev->pdf_memory;
- code = gs_param_read_items(plist, pdev, pdf_param_items);
+ {
+ code = gs_param_read_items(plist, pdev, pdf_param_items, pdev->pdf_memory);
if (code < 0 || (code = param_read_bool(plist, "ForOPDFRead", &ForOPDFRead)) < 0)
{
}
if (code == 0 && !pdev->is_ps2write && !(locked && pdev->params.LockDistillerParams))
pdev->ForOPDFRead = ForOPDFRead;
- plist->memory = mem;
}
if (code < 0)
ecode = code;
diff --git a/devices/vector/gdevpdft.c b/devices/vector/gdevpdft.c
index 8b5a2094..5b8af68d 100644
--- a/devices/vector/gdevpdft.c
+++ b/devices/vector/gdevpdft.c
@@ -401,7 +401,7 @@ pdf_set_blend_params(gs_gstate * pgs, gx_device_pdf * dev,
}
int
-gdev_pdf_create_compositor(gx_device *dev,
+gdev_pdf_composite(gx_device *dev,
gx_device **pcdev, const gs_composite_t *pct,
gs_gstate *pgs, gs_memory_t *memory, gx_device *cdev)
{
@@ -451,7 +451,7 @@ gdev_pdf_create_compositor(gx_device *dev,
}
return 0;
}
- return psdf_create_compositor(dev, pcdev, pct, pgs, memory, cdev);
+ return psdf_composite(dev, pcdev, pct, pgs, memory, cdev);
}
/* We're not sure why the folllowing device methods are never called.
diff --git a/devices/vector/gdevpdfu.c b/devices/vector/gdevpdfu.c
index 325af7c2..ec4a8165 100644
--- a/devices/vector/gdevpdfu.c
+++ b/devices/vector/gdevpdfu.c
@@ -39,9 +39,9 @@
#include "sstring.h"
#include "strmio.h"
#include "szlibx.h"
+#include "gsagl.h"
#include "opdfread.h"
-#include "gdevagl.h"
#include "gs_mgl_e.h"
#include "gs_mro_e.h"
diff --git a/devices/vector/gdevpdfv.c b/devices/vector/gdevpdfv.c
index 6b3c5c97..0159169c 100644
--- a/devices/vector/gdevpdfv.c
+++ b/devices/vector/gdevpdfv.c
@@ -250,6 +250,9 @@ pdf_store_pattern1_params(gx_device_pdf *pdev, pdf_resource_t *pres,
} else {
smat = smat2;
}
+ if ((smat.xx == 0.0 && smat.yy == 0.0) && (smat.xy == 0.0 && smat.yx == 0.0))
+ return_error(gs_error_undefinedresult);
+
if (pdev->ForOPDFRead) {
if (pdev->PatternDepth) {
gs_matrix_multiply(&smat, &pdev->AccumulatedPatternMatrix, &smat2);
@@ -360,6 +363,9 @@ pdf_put_uncolored_pattern(gx_device_pdf *pdev, const gx_drawing_color *pdc,
if (code < 0)
return code;
*ppres = pdf_find_resource_by_gs_id(pdev, resourcePattern, pdc->mask.id);
+ if (*ppres == NULL)
+ return_error(gs_error_undefined);
+
*ppres = pdf_substitute_pattern(*ppres);
if (!pdev->AR4_save_bug && pdev->CompatibilityLevel <= 1.3) {
/* We reconnized AR4 behavior as reserving "q Q" stack elements
diff --git a/devices/vector/gdevpdfx.h b/devices/vector/gdevpdfx.h
index 2db4f77a..d5dfd756 100644
--- a/devices/vector/gdevpdfx.h
+++ b/devices/vector/gdevpdfx.h
@@ -45,7 +45,13 @@
* Acrobat 4 is now more than 20 years old, lets just drop support for it. The
* PDF specification never had this limit, just Adobe's software.
*/
-/* #define MAX_USER_COORD 16300 */
+/* 31/05/2021 However, it transpires that the PDF/A-1 specification adopted the
+ * implementation limits of Acrobat 5 as part of the specification. So we need
+ * to handle that, but we don't need to limit ourselves to the more restrictive
+ * Acrobat 4 limit of 16384 ( MAX_USER_COORD 16300), we can use 32767. THis is only
+ * used when creating PDF/A-1 files.
+ */
+#define MAX_USER_COORD 32700
/* ---------------- Statically allocated sizes ---------------- */
/* These should really be dynamic.... */
@@ -946,6 +952,7 @@ struct gx_device_pdf_s {
gs_char OCR_char_code; /* Passes the current character code from text processing to the image processing code when rendering glyph bitmaps for OCR */
gs_glyph OCR_glyph; /* Passes the current glyph code from text processing to the image processing code when rendering glyph bitmaps for OCR */
ocr_glyph_t *ocr_glyphs; /* Records bitmaps and other data from text processing when doing OCR */
+ gs_gstate **initial_pattern_states;
};
#define is_in_page(pdev)\
@@ -1019,7 +1026,7 @@ dev_proc_fill_rectangle_hl_color(gdev_pdf_fill_rectangle_hl_color);
/* In gdevpdfv.c */
dev_proc_include_color_space(gdev_pdf_include_color_space);
/* In gdevpdft.c */
-dev_proc_create_compositor(gdev_pdf_create_compositor);
+dev_proc_composite(gdev_pdf_composite);
dev_proc_begin_transparency_group(gdev_pdf_begin_transparency_group);
dev_proc_end_transparency_group(gdev_pdf_end_transparency_group);
dev_proc_begin_transparency_mask(gdev_pdf_begin_transparency_mask);
diff --git a/devices/vector/gdevpdtb.c b/devices/vector/gdevpdtb.c
index c0a148c3..42ef43e4 100644
--- a/devices/vector/gdevpdtb.c
+++ b/devices/vector/gdevpdtb.c
@@ -349,7 +349,18 @@ pdf_base_font_alloc(gx_device_pdf *pdev, pdf_base_font_t **ppbfont,
* this is required for PCL, see 'pdf_free_pdf_font_cache' in gdevpdf.c
* for further details.
*/
+ pdev->pdf_font_dir->global_glyph_code = font->dir->global_glyph_code;
+
pbfont->copied->dir = pbfont->complete->dir = pdev->pdf_font_dir;
+
+ if (pbfont->copied->FontType == ft_CID_encrypted) {
+ gs_font_cid0 *copied0 = (gs_font_cid0 *)pbfont->copied;
+ int i;
+ for (i = 0; i < copied0->cidata.FDArray_size; ++i) {
+ ((gs_font *)copied0->cidata.FDArray[i])->dir = pdev->pdf_font_dir;
+ }
+ }
+
pbfont->is_standard = is_standard;
if (pfname->size > 0) {
font_name.data = pfname->chars;
diff --git a/devices/vector/gdevpdtc.c b/devices/vector/gdevpdtc.c
index c2b76b7c..81d66dd5 100644
--- a/devices/vector/gdevpdtc.c
+++ b/devices/vector/gdevpdtc.c
@@ -54,10 +54,11 @@ process_composite_text(gs_text_enum_t *pte, void *vbuf, uint bsize)
gs_char chr, char_code = 0x0badf00d, space_char = GS_NO_CHAR;
int buf_index = 0;
bool return_width = (penum->text.operation & TEXT_RETURN_WIDTH);
+ gx_path *path = gs_text_enum_path(penum);
str.data = buf;
if (return_width) {
- code = gx_path_current_point(penum->path, &penum->origin);
+ code = gx_path_current_point(path, &penum->origin);
if (code < 0)
return code;
}
@@ -432,8 +433,9 @@ scan_cmap_text(pdf_text_enum_t *pte, void *vbuf)
gs_font *subfont = NULL;
gs_point wxy;
bool font_change = 0;
+ gx_path *path = gs_text_enum_path(pte);
- code = gx_path_current_point(pte->path, &pte->origin);
+ code = gx_path_current_point(path, &pte->origin);
if (code < 0)
return code;
do {
@@ -449,6 +451,8 @@ scan_cmap_text(pdf_text_enum_t *pte, void *vbuf)
break_xy_index = scan.xy_index;
code = font->procs.next_char_glyph(&scan, &chr, &glyph);
if (code == 2) { /* end of string */
+ if (subfont == NULL)
+ subfont = scan.fstack.items[scan.fstack.depth].font;
done = true;
break;
}
@@ -770,6 +774,7 @@ scan_cmap_text(pdf_text_enum_t *pte, void *vbuf)
str.data = scan.text.data.bytes;
pdsubf = pdsubf0;
pte->text.operation = save_op;
+ pte->text.data.glyphs = save_data;
}
pte->current_font = subfont0;
if (!subfont0 || !pdsubf0)
diff --git a/devices/vector/gdevpdte.c b/devices/vector/gdevpdte.c
index 7a6b145e..592205fd 100644
--- a/devices/vector/gdevpdte.c
+++ b/devices/vector/gdevpdte.c
@@ -616,8 +616,9 @@ process_text_estimate_bbox(pdf_text_enum_t *pte, gs_font_base *font,
gs_fixed_point origin;
gs_matrix m;
int xy_index = pte->xy_index, info_flags = 0;
+ gx_path *path = gs_text_enum_path(pte);
- code = gx_path_current_point(pte->path, &origin);
+ code = gx_path_current_point(path, &origin);
if (code < 0)
return code;
m = ctm_only(pte->pgs);
@@ -829,6 +830,7 @@ pdf_process_string(pdf_text_enum_t *penum, gs_string *pstr,
int accepted;
gs_rect text_bbox = {{0, 0}, {0, 0}}, glyphs_bbox = {{10000,10000}, {0,0}};
unsigned int operation = text->operation;
+ gx_path *path = gs_text_enum_path(penum);
code = pdf_obtain_font_resource(penum, pstr, &pdfont);
if (code < 0)
@@ -836,7 +838,7 @@ pdf_process_string(pdf_text_enum_t *penum, gs_string *pstr,
if (pfmat == 0)
pfmat = &font->FontMatrix;
if (text->operation & TEXT_RETURN_WIDTH) {
- code = gx_path_current_point(penum->path, &penum->origin);
+ code = gx_path_current_point(path, &penum->origin);
if (code < 0)
return code;
}
@@ -872,7 +874,7 @@ pdf_process_string(pdf_text_enum_t *penum, gs_string *pstr,
gs_fixed_point origin;
gs_point p0, p1, p2, p3;
- code = gx_path_current_point(penum->path, &origin);
+ code = gx_path_current_point(path, &origin);
if (code < 0)
goto done;
@@ -1016,7 +1018,7 @@ pdf_process_string(pdf_text_enum_t *penum, gs_string *pstr,
gs_fixed_point origin;
gs_point p0, p1, p2, p3;
- code = gx_path_current_point(penum->path, &origin);
+ code = gx_path_current_point(path, &origin);
if (code < 0)
return code;
@@ -1622,6 +1624,20 @@ process_text_modify_width(pdf_text_enum_t *pte, gs_font *font,
if (code < 0)
return_error(gs_error_unregistered);
gs_distance_transform(dpt.x, dpt.y, &ctm_only(pte->pgs), &wanted);
+
+ gs_distance_transform(((font->WMode && !cw.ignore_wmode) ? 0 : ppts->values.character_spacing),
+ ((font->WMode && !cw.ignore_wmode) ? ppts->values.character_spacing : 0),
+ &ppts->values.matrix, &tpt);
+ wanted.x += tpt.x;
+ wanted.y += tpt.y;
+
+ if (chr == space_char && (!pte->single_byte_space || decoded_bytes == 1)) {
+ gs_distance_transform(((font->WMode && !cw.ignore_wmode)? 0 : ppts->values.word_spacing),
+ ((font->WMode && !cw.ignore_wmode) ? ppts->values.word_spacing : 0),
+ &ppts->values.matrix, &tpt);
+ wanted.x += tpt.x;
+ wanted.y += tpt.y;
+ }
} else {
pdev->text->text_state->can_use_TJ = true;
gs_distance_transform(cw.real_width.xy.x * ppts->values.size,
diff --git a/devices/vector/gdevpdts.c b/devices/vector/gdevpdts.c
index ec946ac4..4b3de5e1 100644
--- a/devices/vector/gdevpdts.c
+++ b/devices/vector/gdevpdts.c
@@ -67,7 +67,7 @@ gs_private_st_ptrs2(st_pdf_text_state, pdf_text_state_t, "pdf_text_state_t",
* pdf_append_chars.) Requires pts->buffer.count_chars > 0.
*/
static int
-append_text_move(pdf_text_state_t *pts, double dw)
+append_text_move(gx_device_pdf *pdev, pdf_text_state_t *pts, double dw)
{
int count = pts->buffer.count_moves;
int pos = pts->buffer.count_chars;
@@ -81,6 +81,10 @@ append_text_move(pdf_text_state_t *pts, double dw)
rounded = floor(dw + 0.5);
if (fabs(dw - rounded) < 0.001)
dw = rounded;
+ if (pdev->PDFA == 1 && dw < -MAX_USER_COORD) {
+ /* PDF/A-1 limit on co-ordinates */
+ return -1;
+ }
if (dw != 0) {
if (count == MAX_TEXT_BUFFER_MOVES)
return -1;
@@ -168,11 +172,47 @@ add_text_delta_move(gx_device_pdf *pdev, const gs_matrix *pmat)
* for the xhow and once for the Width override. Otherwise, we do
* want to use TJ as it makes for smaller files.
*/
- if (pts->can_use_TJ && dnotw == 0 && pts->buffer.count_chars > 0) {
+ if (pts->can_use_TJ && dnotw == 0 && pts->buffer.count_chars > 0 &&
+ /*
+ * Acrobat Reader limits the magnitude of user-space
+ * coordinates. Also, AR apparently doesn't handle large
+ * positive movement values (negative X displacements), even
+ * though the PDF Reference says this bug was fixed in AR3.
+ *
+ * Old revisions used the upper threshold 1000 for tdw,
+ * but it appears too big when a font sets a too big
+ * character width in setcachedevice. Particularly this happens
+ * with a Type 3 font generated by Aldus Freehand 4.0
+ * to represent a texture - see bug #687051.
+ * The problem is that when the Widths is multiplied
+ * to the font size, the viewer represents the result
+ * with insufficient fraction bits to represent the precise width.
+ * We work around that problem here restricting tdw
+ * with a smaller threshold 990. Our intention is to
+ * disable Tj when the real glyph width appears smaller
+ * than 1% of the width specified in setcachedevice.
+ * A Td instruction will be generated instead.
+ * Note that the value 990 is arbitrary and may need a
+ * further adjustment.
+ */
+ /* Revised the above. It seems unreasonable to use a fixed
+ * value which is not based on the point size, when the problem is
+ * caused by a large point size being multiplied by the width. The
+ * original fix also caused bitmap fonts (from PCL and other sources)
+ * to fail to use kerning, as these fonts are scaled to 1 point and
+ * therefore use large kerning values. Instead we check the kerned value
+ * multiplied by the point size of the font.
+ */
+ (((tdw >= -MAX_USER_COORD && (tdw * pts->in.size) < MAX_USER_COORD) || pdev->PDFA != 1))
+ ) {
/* Use TJ. */
int code;
- code = append_text_move(pts, tdw);
+ if (tdw < MAX_USER_COORD || pdev->PDFA != 1)
+ code = append_text_move(pdev, pts, tdw);
+ else
+ return -1;
+
if (code >= 0)
goto finish;
}
diff --git a/devices/vector/gdevpdtt.c b/devices/vector/gdevpdtt.c
index 952f41db..3091a18d 100644
--- a/devices/vector/gdevpdtt.c
+++ b/devices/vector/gdevpdtt.c
@@ -517,20 +517,22 @@ pdf_prepare_text_drawing(gx_device_pdf *const pdev, gs_text_enum_t *pte)
int
gdev_pdf_text_begin(gx_device * dev, gs_gstate * pgs,
const gs_text_params_t *text, gs_font * font,
- gx_path * path0, const gx_device_color * pdcolor,
const gx_clip_path * pcpath,
- gs_memory_t * mem, gs_text_enum_t ** ppte)
+ gs_text_enum_t ** ppte)
{
gx_device_pdf *const pdev = (gx_device_pdf *)dev;
- gx_path *path = path0;
+ gx_path *path0 = pgs->path;
+ gx_path *path = ((text->operation & TEXT_DO_NONE) &&
+ !(text->operation & TEXT_RETURN_WIDTH) ? NULL : path0);
pdf_text_enum_t *penum;
int code, user_defined = 0;
+ gs_memory_t * mem = pgs->memory;
/* should we "flatten" the font to "normal" marking operations */
if (pdev->FlattenFonts) {
font->dir->ccache.upper = 0;
- return gx_default_text_begin(dev, pgs, text, font, path, pdcolor,
- pcpath, mem, ppte);
+ return gx_default_text_begin(dev, pgs, text, font,
+ pcpath, ppte);
}
/* Track the dominant text rotation. */
@@ -588,7 +590,7 @@ gdev_pdf_text_begin(gx_device * dev, gs_gstate * pgs,
penum->cgp = NULL;
penum->output_char_code = GS_NO_CHAR;
code = gs_text_enum_init((gs_text_enum_t *)penum, &pdf_text_procs,
- dev, pgs, text, font, path, pdcolor, pcpath, mem);
+ dev, pgs, text, font, pcpath, mem);
if (code < 0) {
gs_free_object(mem, penum, "gdev_pdf_text_begin");
return code;
@@ -625,11 +627,11 @@ gdev_pdf_text_begin(gx_device * dev, gs_gstate * pgs,
} else if ((!(text->operation & TEXT_DO_DRAW) && pgs->text_rendering_mode != 3)
|| path == 0 || !path_position_valid(path)
|| pdev->type3charpath)
- return gx_default_text_begin(dev, pgs, text, font, path, pdcolor,
- pcpath, mem, ppte);
+ return gx_default_text_begin(dev, pgs, text, font,
+ pcpath, ppte);
else if (text->operation & TEXT_DO_ANY_CHARPATH)
- return gx_default_text_begin(dev, pgs, text, font, path, pdcolor,
- pcpath, mem, ppte);
+ return gx_default_text_begin(dev, pgs, text, font,
+ pcpath, ppte);
}
if (!pdev->ForOPDFRead) {
@@ -652,7 +654,7 @@ gdev_pdf_text_begin(gx_device * dev, gs_gstate * pgs,
penum->returned.current_glyph = GS_NO_GLYPH;
penum->output_char_code = GS_NO_CHAR;
code = gs_text_enum_init((gs_text_enum_t *)penum, &pdf_text_procs,
- dev, pgs, text, font, path, pdcolor, pcpath, mem);
+ dev, pgs, text, font, pcpath, mem);
penum->k_text_release = 1; /* early release of black_text_state */
if (code < 0) {
@@ -2450,7 +2452,7 @@ pdf_update_text_state(pdf_text_process_state_t *ppts,
float size;
float c_s = 0, w_s = 0;
int mask = 0;
- int code = gx_path_current_point(penum->path, &cpt);
+ int code = gx_path_current_point(gs_text_enum_path(penum), &cpt);
if (code < 0)
return code;
@@ -2909,14 +2911,14 @@ pdf_default_text_begin(gs_text_enum_t *pte, const gs_text_params_t *text,
text1.operation |= TEXT_DO_DRAW;
}
return gx_default_text_begin(pte->dev, pte->pgs, &text1, pte->current_font,
- pte->path, pte->pdcolor, pte->pcpath,
- pte->memory, ppte);
+ pte->pcpath, ppte);
}
static int install_PS_charproc_accumulator(gx_device_pdf *pdev, gs_text_enum_t *pte,
gs_text_enum_t *pte_default, pdf_text_enum_t *const penum)
{
int code;
+ const gx_device_color * pdcolor = gs_currentdevicecolor_inline(pte->pgs);
penum->returned.current_char = pte_default->returned.current_char;
penum->returned.current_glyph = pte_default->returned.current_glyph;
@@ -2946,7 +2948,7 @@ static int install_PS_charproc_accumulator(gx_device_pdf *pdev, gs_text_enum_t *
pdev->width *= 100;
pdev->height *= 100;
- pdf_viewer_state_from_gs_gstate(pdev, pte->pgs, pte->pdcolor);
+ pdf_viewer_state_from_gs_gstate(pdev, pte->pgs, pdcolor);
/* Set line params to unallowed values so that
they'll synchronize with writing them out on the first use.
Doing so because PDF viewer inherits them from the
@@ -2999,6 +3001,7 @@ static int install_charproc_accumulator(gx_device_pdf *pdev, gs_text_enum_t *pte
gs_text_enum_t *pte_default, pdf_text_enum_t *const penum)
{
int code;
+ const gx_device_color * pdcolor = gs_currentdevicecolor_inline(pte->pgs);
pdev->charproc_ctm = penum->pgs->ctm;
if ((penum->current_font->FontType == ft_user_defined ||
@@ -3019,7 +3022,7 @@ static int install_charproc_accumulator(gx_device_pdf *pdev, gs_text_enum_t *pte
if (code < 0)
return code;
- pdf_viewer_state_from_gs_gstate(pdev, pte->pgs, pte->pdcolor);
+ pdf_viewer_state_from_gs_gstate(pdev, pte->pgs, pdcolor);
/* Set line params to unallowed values so that
they'll synchronize with writing them out on the first use.
Doing so because PDF viewer inherits them from the
diff --git a/devices/vector/gdevpdtw.c b/devices/vector/gdevpdtw.c
index 19438685..0647db66 100644
--- a/devices/vector/gdevpdtw.c
+++ b/devices/vector/gdevpdtw.c
@@ -239,8 +239,7 @@ pdf_write_simple_contents(gx_device_pdf *pdev,
if (code < 0)
return code;
pprints1(s, "/Subtype/%s>>\n",
- (pdfont->FontType == ft_TrueType ? "TrueType" :
- pdfont->u.simple.s.type1.is_MM_instance ? "MMType1" : "Type1"));
+ (pdfont->FontType == ft_TrueType ? "TrueType" : "Type1"));
pdf_end_separate(pdev, resourceFont);
if (diff_id) {
mark_font_descriptor_symbolic(pdfont);
diff --git a/devices/vector/gdevpsdf.h b/devices/vector/gdevpsdf.h
index 700278e2..8f5d6ad8 100644
--- a/devices/vector/gdevpsdf.h
+++ b/devices/vector/gdevpsdf.h
@@ -174,6 +174,7 @@ typedef struct psdf_distiller_params_s {
int MaxSubsetPct;
bool SubsetFonts;
bool PassThroughJPEGImages;
+ bool PassThroughJPXImages;
gs_param_string PSDocOptions;
gs_param_string_array PSPageOptions;
} psdf_distiller_params;
@@ -267,6 +268,8 @@ extern const stream_template s_zlibE_template;
#define psdf_JPEGPassThrough_param_defaults\
1 /* PassThroughJPEGImages */
+#define psdf_JPXPassThrough_param_defaults\
+ 1 /* PassThroughJPXImages */
#define psdf_PSOption_param_defaults\
{0}, /* PSDocOptions */\
@@ -292,6 +295,7 @@ typedef enum {
bool HaveCIDSystem;\
double ParamCompatibilityLevel;\
bool JPEG_PassThrough;\
+ bool JPX_PassThrough;\
psdf_distiller_params params
typedef struct gx_device_psdf_s {
@@ -307,12 +311,14 @@ typedef struct gx_device_psdf_s {
false,\
1.3,\
0,\
+ 0,\
{ psdf_general_param_defaults(ascii),\
psdf_color_image_param_defaults,\
psdf_gray_image_param_defaults,\
psdf_mono_image_param_defaults,\
psdf_font_param_defaults,\
psdf_JPEGPassThrough_param_defaults,\
+ psdf_JPXPassThrough_param_defaults,\
psdf_PSOption_param_defaults\
}
/* st_device_psdf is never instantiated per se, but we still need to */
@@ -508,11 +514,10 @@ int psdf_set_color(gx_device_vector *vdev, const gx_drawing_color *pdc,
/* Round a double value to a specified precision. */
double psdf_round(double v, int precision, int radix);
-/* stubs to disable get_bits, get_bits_rectangle */
-dev_proc_get_bits(psdf_get_bits);
+/* stub to disable get_bits_rectangle */
dev_proc_get_bits_rectangle(psdf_get_bits_rectangle);
/* intercept and ignore overprint compositor creation */
-dev_proc_create_compositor(psdf_create_compositor);
+dev_proc_composite(psdf_composite);
#endif /* gdevpsdf_INCLUDED */
diff --git a/devices/vector/gdevpsdi.c b/devices/vector/gdevpsdi.c
index 8ac9735a..955e06b2 100644
--- a/devices/vector/gdevpsdi.c
+++ b/devices/vector/gdevpsdi.c
@@ -269,7 +269,7 @@ setup_image_compression(psdf_binary_writer *pbw, const psdf_image_params *pdip,
templat = lossless_template;
if (dict != NULL) /* Some interpreters don't supply filter parameters. */
gs_c_param_list_read(dict); /* ensure param list is in read mode */
- if (templat == 0 || pdev->JPEG_PassThrough) /* no compression */
+ if (templat == 0 || pdev->JPEG_PassThrough || pdev->JPX_PassThrough) /* no compression */
return 0;
if (pim->Width < 200 && pim->Height < 200) /* Prevent a fixed overflow. */
if (pim->Width * pim->Height * Colors * pim->BitsPerComponent <= 160)
@@ -886,8 +886,10 @@ new_setup_image_filters(gx_device_psdf * pdev, psdf_binary_writer * pbw,
resolution = resolutiony;
}
- if (bpc != bpc_out)
+ if (bpc != bpc_out) {
pdev->JPEG_PassThrough = 0;
+ pdev->JPX_PassThrough = 0;
+ }
if (ncomp == 1 && pim->ColorSpace && pim->ColorSpace->type->index != gs_color_space_index_Indexed) {
/* Monochrome, gray, or mask */
@@ -906,6 +908,7 @@ new_setup_image_filters(gx_device_psdf * pdev, psdf_binary_writer * pbw,
params.Dict = pdev->params.GrayImage.Dict;
}
pdev->JPEG_PassThrough = 0;
+ pdev->JPX_PassThrough = 0;
code = setup_downsampling(pbw, &params, pim, pgs, resolution, lossless);
} else {
code = setup_image_compression(pbw, &params, pim, pgs, lossless);
@@ -919,6 +922,7 @@ new_setup_image_filters(gx_device_psdf * pdev, psdf_binary_writer * pbw,
params.Depth = (colour_conversion ? 8 : bpc_out);
if (do_downsample(&params, pim, resolution)) {
pdev->JPEG_PassThrough = 0;
+ pdev->JPX_PassThrough = 0;
code = setup_downsampling(pbw, &params, pim, pgs, resolution, lossless);
} else {
code = setup_image_compression(pbw, &params, pim, pgs, lossless);
diff --git a/devices/vector/gdevpsdp.c b/devices/vector/gdevpsdp.c
index d995dc5c..fc944539 100644
--- a/devices/vector/gdevpsdp.c
+++ b/devices/vector/gdevpsdp.c
@@ -243,6 +243,7 @@ static const gs_param_item_t psdf_param_items[] = {
pi("MaxSubsetPct", gs_param_type_int, MaxSubsetPct),
pi("SubsetFonts", gs_param_type_bool, SubsetFonts),
pi("PassThroughJPEGImages", gs_param_type_bool, PassThroughJPEGImages),
+ pi("PassThroughJPXImages", gs_param_type_bool, PassThroughJPXImages),
#undef pi
gs_param_item_end
@@ -905,12 +906,12 @@ psdf_put_image_params(const gx_device_psdf * pdev, gs_param_list * plist,
* Since this procedure can be called before the device is open,
* we must use pdev->memory rather than pdev->v_memory.
*/
- gs_memory_t *mem = pdev->memory;
+ gs_memory_t *mem = gs_memory_stable(pdev->memory);
gs_param_name pname;
/* Skip AutoFilter for mono images. */
const gs_param_item_t *items =
(pnames->items[0].key == 0 ? pnames->items + 1 : pnames->items);
- int code = gs_param_read_items(plist, params, items);
+ int code = gs_param_read_items(plist, params, items, mem);
if (code < 0)
ecode = code;
@@ -1124,7 +1125,7 @@ gdev_psdf_put_params(gx_device * dev, gs_param_list * plist)
/* General parameters. */
- code = gs_param_read_items(plist, &params, psdf_param_items);
+ code = gs_param_read_items(plist, &params, psdf_param_items, NULL);
if (code < 0)
return code;
diff --git a/devices/vector/gdevpsdu.c b/devices/vector/gdevpsdu.c
index c4957691..210e224a 100644
--- a/devices/vector/gdevpsdu.c
+++ b/devices/vector/gdevpsdu.c
@@ -468,23 +468,14 @@ psdf_end_binary(psdf_binary_writer * pbw)
/* ---------------- Overprint, Get Bits ---------------- */
/*
- * High level devices cannot perform get_bits or get_bits_rectangle
+ * High level devices cannot perform get_bits_rectangle
* operations, for obvious reasons.
*/
int
-psdf_get_bits(gx_device * dev, int y, byte * data, byte ** actual_data)
-{
- emprintf(dev->memory,
- "Can't set GraphicsAlphaBits or TextAlphaBits with a vector device.\n");
- return_error(gs_error_unregistered);
-}
-
-int
psdf_get_bits_rectangle(
gx_device * dev,
const gs_int_rect * prect,
- gs_get_bits_params_t * params,
- gs_int_rect ** unread )
+ gs_get_bits_params_t * params )
{
emprintf(dev->memory,
"Can't set GraphicsAlphaBits or TextAlphaBits with a vector device.\n");
@@ -499,7 +490,7 @@ psdf_get_bits_rectangle(
* compositor.
*/
int
-psdf_create_compositor(
+psdf_composite(
gx_device * dev,
gx_device ** pcdev,
const gs_composite_t * pct,
@@ -511,5 +502,5 @@ psdf_create_compositor(
*pcdev = dev;
return 0;
}
- return gx_default_create_compositor(dev, pcdev, pct, pgs, mem, cdev);
+ return gx_default_composite(dev, pcdev, pct, pgs, mem, cdev);
}
diff --git a/devices/vector/gdevpx.c b/devices/vector/gdevpx.c
index 2002219d..fad8727c 100644
--- a/devices/vector/gdevpx.c
+++ b/devices/vector/gdevpx.c
@@ -122,8 +122,8 @@ gs_public_st_suffix_add0_final(st_device_pclxl, gx_device_pclxl,
device_pclxl_reloc_ptrs, gx_device_finalize,
st_device_vector);
-#define pclxl_device_body(dname, depth)\
- std_device_dci_type_body(gx_device_pclxl, 0, dname, &st_device_pclxl,\
+#define pclxl_device_body(dname, depth, init)\
+ std_device_dci_type_body(gx_device_pclxl, init, dname, &st_device_pclxl,\
DEFAULT_WIDTH_10THS * X_DPI / 10,\
DEFAULT_HEIGHT_10THS * Y_DPI / 10,\
X_DPI, Y_DPI,\
@@ -143,59 +143,57 @@ static dev_proc_get_params(pclxl_get_params);
static dev_proc_put_params(pclxl_put_params);
/*static dev_proc_draw_thin_line(pclxl_draw_thin_line); */
-static dev_proc_begin_image(pclxl_begin_image);
-static dev_proc_strip_copy_rop(pclxl_strip_copy_rop);
-
-#define pclxl_device_procs(map_rgb_color, map_color_rgb)\
-{\
- pclxl_open_device,\
- NULL, /* get_initial_matrix */\
- NULL, /* sync_output */\
- pclxl_output_page,\
- pclxl_close_device,\
- map_rgb_color, /* differs */\
- map_color_rgb, /* differs */\
- gdev_vector_fill_rectangle,\
- NULL, /* tile_rectangle */\
- pclxl_copy_mono,\
- pclxl_copy_color,\
- NULL, /* draw_line */\
- NULL, /* get_bits */\
- pclxl_get_params,\
- pclxl_put_params,\
- NULL, /* map_cmyk_color */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- gx_page_device_get_page_device,\
- NULL, /* get_alpha_bits */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- gdev_vector_fill_path,\
- gdev_vector_stroke_path,\
- pclxl_fill_mask,\
- gdev_vector_fill_trapezoid,\
- gdev_vector_fill_parallelogram,\
- gdev_vector_fill_triangle,\
- NULL /****** WRONG ******/, /* draw_thin_line */\
- pclxl_begin_image,\
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- pclxl_strip_copy_rop\
+static dev_proc_begin_typed_image(pclxl_begin_typed_image);
+static dev_proc_strip_copy_rop2(pclxl_strip_copy_rop2);
+
+static void
+pclxl_initialize_device_procs(gx_device *dev,
+ dev_proc_map_rgb_color(map_rgb_color),
+ dev_proc_map_color_rgb(map_color_rgb))
+{
+ set_dev_proc(dev, open_device, pclxl_open_device);
+ set_dev_proc(dev, output_page, pclxl_output_page);
+ set_dev_proc(dev, close_device, pclxl_close_device);
+ set_dev_proc(dev, map_rgb_color, map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, gdev_vector_fill_rectangle);
+ set_dev_proc(dev, copy_mono, pclxl_copy_mono);
+ set_dev_proc(dev, copy_color, pclxl_copy_color);
+ set_dev_proc(dev, get_params, pclxl_get_params);
+ set_dev_proc(dev, put_params, pclxl_put_params);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
+ set_dev_proc(dev, fill_path, gdev_vector_fill_path);
+ set_dev_proc(dev, stroke_path, gdev_vector_stroke_path);
+ set_dev_proc(dev, fill_mask, pclxl_fill_mask);
+ set_dev_proc(dev, fill_trapezoid, gdev_vector_fill_trapezoid);
+ set_dev_proc(dev, fill_parallelogram, gdev_vector_fill_parallelogram);
+ set_dev_proc(dev, fill_triangle, gdev_vector_fill_triangle);
+ set_dev_proc(dev, begin_typed_image, pclxl_begin_typed_image);
+ set_dev_proc(dev, strip_copy_rop2, pclxl_strip_copy_rop2);
+}
+
+static void
+pxlmono_initialize_device_procs(gx_device *dev)
+{
+ pclxl_initialize_device_procs(dev,
+ gx_default_gray_map_rgb_color,
+ gx_default_gray_map_color_rgb);
+}
+
+static void
+pxlcolor_initialize_device_procs(gx_device *dev)
+{
+ pclxl_initialize_device_procs(dev,
+ gx_default_rgb_map_rgb_color,
+ gx_default_rgb_map_color_rgb);
}
const gx_device_pclxl gs_pxlmono_device = {
- pclxl_device_body("pxlmono", 8),
- pclxl_device_procs(gx_default_gray_map_rgb_color,
- gx_default_gray_map_color_rgb)
+ pclxl_device_body("pxlmono", 8, pxlmono_initialize_device_procs)
};
const gx_device_pclxl gs_pxlcolor_device = {
- pclxl_device_body("pxlcolor", 24),
- pclxl_device_procs(gx_default_rgb_map_rgb_color,
- gx_default_rgb_map_color_rgb)
+ pclxl_device_body("pxlcolor", 24, pxlcolor_initialize_device_procs)
};
/* ---------------- Other utilities ---------------- */
@@ -1973,25 +1971,27 @@ pclxl_fill_mask(gx_device * dev,
/* Do a RasterOp. */
static int
-pclxl_strip_copy_rop(gx_device * dev, const byte * sdata, int sourcex,
+pclxl_strip_copy_rop2(gx_device * dev, const byte * sdata, int sourcex,
uint sraster, gx_bitmap_id id,
const gx_color_index * scolors,
const gx_strip_bitmap * textures,
const gx_color_index * tcolors,
int x, int y, int width, int height,
- int phase_x, int phase_y, gs_logical_operation_t lop)
+ int phase_x, int phase_y, gs_logical_operation_t lop,
+ uint plane_height)
{
lop = lop_sanitize(lop);
/* Improvements possible here using PXL ROP3
for some combinations of args; use gx_default for now */
if (!rop3_uses_D(lop)) /* gx_default() cannot cope with D ops */
- return gx_default_strip_copy_rop(dev, sdata, sourcex,
- sraster, id,
- scolors,
- textures,
- tcolors,
- x, y, width, height,
- phase_x, phase_y, lop);
+ return gx_default_strip_copy_rop2(dev, sdata, sourcex,
+ sraster, id,
+ scolors,
+ textures,
+ tcolors,
+ x, y, width, height,
+ phase_x, phase_y, lop,
+ plane_height);
return 0;
}
@@ -2018,30 +2018,39 @@ gs_private_st_suffix_add2(st_pclxl_image_enum, pclxl_image_enum_t,
/* Start processing an image. */
static int
-pclxl_begin_image(gx_device * dev,
- const gs_gstate * pgs, const gs_image_t * pim,
- gs_image_format_t format, const gs_int_rect * prect,
+pclxl_begin_typed_image(gx_device * dev,
+ const gs_gstate * pgs,
+ const gs_matrix *pmat,
+ const gs_image_common_t * pic,
+ const gs_int_rect * prect,
const gx_drawing_color * pdcolor,
const gx_clip_path * pcpath, gs_memory_t * mem,
gx_image_enum_common_t ** pinfo)
{
gx_device_vector *const vdev = (gx_device_vector *) dev;
gx_device_pclxl *const xdev = (gx_device_pclxl *) dev;
- const gs_color_space *pcs = pim->ColorSpace;
+ const gs_image_t *pim = (const gs_image_t *)pic;
+ const gs_color_space *pcs;
pclxl_image_enum_t *pie;
byte *row_data;
int num_rows;
uint row_raster;
+ int bits_per_pixel;
+ gs_matrix mat;
+ int code;
+ /* We only cope with image type 1 here. */
+ if (pic->type->index != 1)
+ goto use_default;
+
+ pcs = pim->ColorSpace;
/*
* Following should divide by num_planes, but we only handle chunky
* images, i.e., num_planes = 1.
*/
- int bits_per_pixel =
+ bits_per_pixel =
(pim->ImageMask ? 1 :
pim->BitsPerComponent * gs_color_space_num_components(pcs));
- gs_matrix mat;
- int code;
/*
* Check whether we can handle this image. PCL XL 1.0 and 2.0 only
@@ -2050,7 +2059,9 @@ pclxl_begin_image(gx_device * dev,
code = gs_matrix_invert(&pim->ImageMatrix, &mat);
if (code < 0)
goto use_default;
- gs_matrix_multiply(&mat, &ctm_only(pgs), &mat);
+ if (pmat == NULL)
+ pmat = &ctm_only(pgs);
+ gs_matrix_multiply(&mat, pmat, &mat);
if (pclxl_nontrivial_transfer(pgs))
goto use_default;
@@ -2095,7 +2106,7 @@ pclxl_begin_image(gx_device * dev,
bits_per_pixel != 8 && bits_per_pixel != 24 &&
bits_per_pixel != 32))
&& !(pclxl_can_icctransform(pim) && xdev->iccTransform))) ||
- format != gs_image_format_chunky || pim->Interpolate || prect)
+ pim->format != gs_image_format_chunky || pim->Interpolate || prect)
goto use_default;
row_raster = (bits_per_pixel * pim->Width + 7) >> 3;
num_rows = MAX_ROW_DATA / row_raster;
@@ -2111,7 +2122,7 @@ pclxl_begin_image(gx_device * dev,
code = gs_note_error(gs_error_VMerror);
goto fail;
}
- code = gdev_vector_begin_image(vdev, pgs, pim, format, prect,
+ code = gdev_vector_begin_image(vdev, pgs, pim, pim->format, prect,
pdcolor, pcpath, mem,
&pclxl_image_enum_procs,
(gdev_vector_image_enum_t *) pie);
@@ -2332,8 +2343,8 @@ pclxl_begin_image(gx_device * dev,
pclxl_set_color_space(xdev, eGray);
else
pclxl_set_color_space(xdev, eRGB);
- return gx_default_begin_image(dev, pgs, pim, format, prect,
- pdcolor, pcpath, mem, pinfo);
+ return gx_default_begin_typed_image(dev, pgs, pmat, pic, prect,
+ pdcolor, pcpath, mem, pinfo);
}
/* Write one strip of an image, from pie->rows.first_y to pie->y. */
diff --git a/devices/vector/gdevtxtw.c b/devices/vector/gdevtxtw.c
index 687581d5..cbe2b19e 100644
--- a/devices/vector/gdevtxtw.c
+++ b/devices/vector/gdevtxtw.c
@@ -30,7 +30,7 @@
#include "gxfcid.h"
#include "gxgstate.h"
#include "gxpath.h"
-#include "gdevagl.h"
+#include "gsagl.h"
#include "gxdevsop.h"
#include "gzpath.h"
#include "gdevkrnlsclass.h" /* 'standard' built in subclasses, currently First/Last Page and obejct filter */
@@ -112,7 +112,7 @@ static dev_proc_put_params(txtwrite_put_params);
static dev_proc_fill_path(txtwrite_fill_path);
static dev_proc_stroke_path(txtwrite_stroke_path);
static dev_proc_text_begin(txtwrite_text_begin);
-static dev_proc_strip_copy_rop(txtwrite_strip_copy_rop);
+static dev_proc_strip_copy_rop2(txtwrite_strip_copy_rop2);
static dev_proc_dev_spec_op(txtwrite_dev_spec_op);
@@ -145,86 +145,34 @@ typedef struct textw_text_enum_s {
private_st_textw_text_enum();
+static void
+txtwrite_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, open_device, txtwrite_open_device);
+ set_dev_proc(dev, output_page, txtwrite_output_page);
+ set_dev_proc(dev, close_device, txtwrite_close_device);
+ set_dev_proc(dev, fill_rectangle, txtwrite_fill_rectangle);
+ set_dev_proc(dev, get_params, txtwrite_get_params);
+ set_dev_proc(dev, put_params, txtwrite_put_params);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
+ set_dev_proc(dev, fill_path, txtwrite_fill_path);
+ set_dev_proc(dev, stroke_path, txtwrite_stroke_path);
+ set_dev_proc(dev, strip_copy_rop2, txtwrite_strip_copy_rop2);
+ set_dev_proc(dev, composite, gx_null_composite);
+ set_dev_proc(dev, text_begin, txtwrite_text_begin);
+ set_dev_proc(dev, dev_spec_op, txtwrite_dev_spec_op);
+}
+
const gx_device_txtwrite_t gs_txtwrite_device =
{
/* Define the device as 8-bit gray scale to avoid computing halftones. */
- std_device_dci_body(gx_device_txtwrite_t, 0, "txtwrite",
+ std_device_dci_body(gx_device_txtwrite_t,
+ txtwrite_initialize_device_procs, "txtwrite",
DEFAULT_WIDTH_10THS * X_DPI / 10,
DEFAULT_HEIGHT_10THS * Y_DPI / 10,
X_DPI, Y_DPI,
1, 8, 255, 0, 256, 1),
- {txtwrite_open_device,
- NULL, /*gx_upright_get_initial_matrix,*/
- NULL, /*gx_default_sync_output,*/
- txtwrite_output_page,
- txtwrite_close_device,
- NULL, /*gx_default_gray_map_rgb_color,*/
- NULL, /*gx_default_gray_map_color_rgb,*/
- txtwrite_fill_rectangle, /* Can't be NULL and there is no gx_default_fill_rectangle! */
- NULL, /*gx_default_tile_rectangle,*/
- NULL, /*gx_default_copy_mono,*/
- NULL, /*gx_default_copy_color,*/
- NULL, /*gx_default_draw_line,*/
- NULL, /*gx_default_get_bits,*/
- txtwrite_get_params,
- txtwrite_put_params,
- NULL, /*gx_default_map_cmyk_color,*/
- NULL, /*gx_default_get_xfont_procs,*/
- NULL, /*gx_default_get_xfont_device,*/
- NULL, /*gx_default_map_rgb_alpha_color,*/
- gx_page_device_get_page_device, /*gx_page_device_get_page_device,*/
- NULL, /* get_alpha_bits */
- NULL, /*gx_default_copy_alpha,*/
- NULL, /* get_band */
- NULL, /* copy_rop */
- txtwrite_fill_path,
- txtwrite_stroke_path,
- NULL, /*gx_default_fill_mask,*/
- NULL, /*gx_default_fill_trapezoid,*/
- NULL, /*gx_default_fill_parallelogram,*/
- NULL, /*gx_default_fill_triangle,*/
- NULL, /*gx_default_draw_thin_line,*/
- NULL, /* begin image */
- NULL, /* image_data */
- NULL, /* end_image */
- NULL, /*gx_default_strip_tile_rectangle,*/
- txtwrite_strip_copy_rop,
- NULL, /* get_clipping_box */
- NULL, /* txtwrite_begin_typed_image */
- NULL, /* get_bits_rectangle */
- NULL, /*gx_default_map_color_rgb_alpha,*/
- gx_null_create_compositor,
- NULL, /* get_hardware_params */
- txtwrite_text_begin,
- NULL, /* finish_copydevice */
- NULL, /* begin_transparency_group */
- NULL, /* end_transparency_group */
- NULL, /* begin_transparency_mask */
- NULL, /* end_transparency_mask */
- NULL, /* discard_transparency_layer */
- NULL, /* get_color_mapping_procs */
- NULL, /* get_color_comp_index */
- NULL, /* encode_color */
- NULL, /* decode_color */
- NULL, /* pattern manager */
- NULL, /* fill_rectangle_hl_color */
- NULL, /* include_color_space */
- NULL, /* fill_linear_color_scanline */
- NULL, /* fill_linear_color_trapezoid */
- NULL, /* fill_linear_color_triangle */
- NULL, /* update_spot_equivalent_colors */
- NULL, /* ret_devn_params */
- NULL, /* fillpage */
- NULL, /* push_transparency_state */
- NULL, /* pop_transparency_state */
- NULL, /* put_image */
- txtwrite_dev_spec_op, /* dev_spec_op */
- NULL, /* copy_planes */
- NULL, /* get_profile */
- NULL, /* set_graphics_type_tag */
- NULL, /* strip_copy_rop2 */
- NULL /* strip_tile_rect_devn */
- },
+ { 0 }, /* proc table */
{ 0 }, /* Page Data */
{ 0 }, /* Output Filename */
0, /* Output FILE * */
@@ -1090,14 +1038,15 @@ txtwrite_strip_tile_rectangle(gx_device * dev, const gx_strip_bitmap * tiles,
}
static int
-txtwrite_strip_copy_rop(gx_device * dev,
+txtwrite_strip_copy_rop2(gx_device * dev,
const byte * sdata, int sourcex, uint sraster,
gx_bitmap_id id,
const gx_color_index * scolors,
const gx_strip_bitmap * textures,
const gx_color_index * tcolors,
int x, int y, int w, int h,
- int phase_x, int phase_y, gs_logical_operation_t lop)
+ int phase_x, int phase_y, gs_logical_operation_t lop,
+ uint plane_height)
{
return 0;
}*/
@@ -1344,7 +1293,7 @@ txt_update_text_state(text_list_entry_t *ppts,
gs_matrix smat, tmat;
float size;
int mask = 0;
- int code = gx_path_current_point(penum->path, &cpt);
+ int code = gx_path_current_point(gs_text_enum_path(penum), &cpt);
if (code < 0)
return code;
@@ -1957,7 +1906,7 @@ textw_text_process(gs_text_enum_t *pte)
return code;
/* Fall back to the default implementation. */
code = gx_default_text_begin(pte->dev, pte->pgs, &pte->text, pte->current_font,
- pte->path, pte->pdcolor, pte->pcpath, pte->memory, &pte_fallback);
+ pte->pcpath, &pte_fallback);
if (code < 0)
return code;
penum->pte_fallback = pte_fallback;
@@ -2033,16 +1982,26 @@ textw_text_release(gs_text_enum_t *pte, client_name_t cname)
gx_device_txtwrite_t *const tdev = (gx_device_txtwrite_t *) pte->dev;
/* Free the working buffer where the Unicode was assembled from the enumerated text */
- if (penum->TextBuffer)
+ if (penum->TextBuffer) {
gs_free(tdev->memory, penum->TextBuffer, 1, penum->TextBufferIndex, "txtwrite free temporary text buffer");
- if (penum->Widths)
+ penum->TextBuffer = NULL;
+ }
+ if (penum->Widths) {
gs_free(tdev->memory, penum->Widths, sizeof(float), pte->text.size, "txtwrite free temporary widths array");
- if (penum->Advs)
+ penum->Widths = NULL;
+ }
+ if (penum->Advs) {
gs_free(tdev->memory, penum->Advs, 1, penum->TextBufferIndex, "txtwrite free temporary text buffer");
- if (penum->GlyphWidths)
+ penum->Advs = NULL;
+ }
+ if (penum->GlyphWidths) {
gs_free(tdev->memory, penum->GlyphWidths, 1, penum->TextBufferIndex, "txtwrite free temporary text buffer");
- if (penum->SpanDeltaX)
+ penum->GlyphWidths = NULL;
+ }
+ if (penum->SpanDeltaX) {
gs_free(tdev->memory, penum->SpanDeltaX, 1, penum->TextBufferIndex, "txtwrite free temporary text buffer");
+ penum->SpanDeltaX = NULL;
+ }
/* If this is copied away when we complete the text enumeration succesfully, then
* we set the pointer to NULL, if we get here with it non-NULL , then there was
* an error.
@@ -2059,6 +2018,7 @@ textw_text_release(gs_text_enum_t *pte, client_name_t cname)
if (penum->text_state->FontName)
gs_free(tdev->memory, penum->text_state->FontName, 1, penum->TextBufferIndex, "txtwrite free temporary font name copy");
gs_free(tdev->memory, penum->text_state, 1, sizeof(penum->text_state), "txtwrite free text state");
+ penum->text_state = NULL;
}
}
@@ -2078,13 +2038,14 @@ static const gs_text_enum_procs_t textw_text_procs = {
static int
txtwrite_text_begin(gx_device * dev, gs_gstate * pgs,
const gs_text_params_t * text, gs_font * font,
- gx_path * path, const gx_device_color * pdcolor,
const gx_clip_path * pcpath,
- gs_memory_t * mem, gs_text_enum_t ** ppenum)
+ gs_text_enum_t ** ppenum)
{
gx_device_txtwrite_t *const tdev = (gx_device_txtwrite_t *) dev;
textw_text_enum_t *penum;
int code;
+ gx_path *path = pgs->path;
+ gs_memory_t * mem = pgs->memory;
/* If this is a stringwidth, we must let the default graphics library code handle it
* in case there is no current point (this can happen if this is the first operation
@@ -2095,8 +2056,8 @@ txtwrite_text_begin(gx_device * dev, gs_gstate * pgs,
*/
if ((!(text->operation & TEXT_DO_DRAW) && pgs->text_rendering_mode != 3)
|| path == 0 || !path_position_valid(path))
- return gx_default_text_begin(dev, pgs, text, font, path, pdcolor,
- pcpath, mem, ppenum);
+ return gx_default_text_begin(dev, pgs, text, font,
+ pcpath, ppenum);
/* Allocate and initialize one of our text enumerators. */
rc_alloc_struct_1(penum, textw_text_enum_t, &st_textw_text_enum, mem,
return_error(gs_error_VMerror), "gdev_textw_text_begin");
@@ -2107,6 +2068,9 @@ txtwrite_text_begin(gx_device * dev, gs_gstate * pgs,
penum->TextBuffer = NULL;
penum->TextBufferIndex = 0;
penum->Widths = NULL;
+ penum->Advs = NULL;
+ penum->GlyphWidths = NULL;
+ penum->SpanDeltaX = NULL;
penum->pte_fallback = NULL;
penum->d1_width = 0;
penum->d1_width_set = false;
@@ -2118,7 +2082,7 @@ txtwrite_text_begin(gx_device * dev, gs_gstate * pgs,
memset(penum->text_state, 0x00, sizeof(text_list_entry_t));
code = gs_text_enum_init((gs_text_enum_t *)penum, &textw_text_procs,
- dev, pgs, text, font, path, pdcolor, pcpath, mem);
+ dev, pgs, text, font, pcpath, mem);
if (code < 0) {
/* Belt and braces; I'm not certain this is required, but its safe */
gs_free(tdev->memory, penum->text_state, 1, sizeof(text_list_entry_t), "txtwrite free text state");
@@ -2127,7 +2091,7 @@ txtwrite_text_begin(gx_device * dev, gs_gstate * pgs,
return code;
}
- code = gx_path_current_point(penum->path, &penum->origin);
+ code = gx_path_current_point(gs_text_enum_path(penum), &penum->origin);
if (code != 0)
return code;
@@ -2137,14 +2101,15 @@ txtwrite_text_begin(gx_device * dev, gs_gstate * pgs,
}
static int
-txtwrite_strip_copy_rop(gx_device * dev,
+txtwrite_strip_copy_rop2(gx_device * dev,
const byte * sdata, int sourcex, uint sraster,
gx_bitmap_id id,
const gx_color_index * scolors,
const gx_strip_bitmap * textures,
const gx_color_index * tcolors,
int x, int y, int w, int h,
- int phase_x, int phase_y, gs_logical_operation_t lop)
+ int phase_x, int phase_y, gs_logical_operation_t lop,
+ uint plane_height)
{
return 0;
}
diff --git a/devices/vector/gdevxps.c b/devices/vector/gdevxps.c
index c435cd47..c946f322 100644
--- a/devices/vector/gdevxps.c
+++ b/devices/vector/gdevxps.c
@@ -198,8 +198,8 @@ gs_public_st_suffix_add1_final(st_device_xps, gx_device_xps,
"gx_device_xps", device_xps_enum_ptrs, device_xps_reloc_ptrs,
gx_device_finalize, st_device_vector, xps_pie);
-#define xps_device_body(dname, depth)\
- std_device_dci_type_body(gx_device_xps, 0, dname, &st_device_xps, \
+#define xps_device_body(dname, depth, init)\
+ std_device_dci_type_body(gx_device_xps, init, dname, &st_device_xps, \
DEFAULT_WIDTH_10THS * X_DPI / 10, \
DEFAULT_HEIGHT_10THS * Y_DPI / 10, \
X_DPI, Y_DPI, \
@@ -214,63 +214,41 @@ static dev_proc_get_params(xps_get_params);
static dev_proc_put_params(xps_put_params);
static dev_proc_fill_path(gdev_xps_fill_path);
static dev_proc_stroke_path(gdev_xps_stroke_path);
-static dev_proc_finish_copydevice(xps_finish_copydevice);
-static dev_proc_begin_image(xps_begin_image);
-
-#define xps_device_procs \
-{ \
- xps_open_device, \
- NULL, /* get_initial_matrix */\
- NULL, /* sync_output */\
- xps_output_page,\
- xps_close_device,\
- gx_default_rgb_map_rgb_color,\
- gx_default_rgb_map_color_rgb,\
- gdev_vector_fill_rectangle,\
- NULL, /* tile_rectangle */\
- NULL, /* copy_mono */\
- NULL, /* copy_color */\
- NULL, /* draw_line */\
- NULL, /* get_bits */\
- xps_get_params,\
- xps_put_params,\
- NULL, /* map_cmyk_color */\
- NULL, /* get_xfont_procs */\
- NULL, /* get_xfont_device */\
- NULL, /* map_rgb_alpha_color */\
- gx_page_device_get_page_device,\
- NULL, /* get_alpha_bits */\
- NULL, /* copy_alpha */\
- NULL, /* get_band */\
- NULL, /* copy_rop */\
- gdev_xps_fill_path,\
- gdev_xps_stroke_path,\
- NULL, /* fill_mask */\
- NULL, /* gdev_vector_fill_trapezoid, */ \
- NULL, /* gdev_vector_fill_parallelogram */ \
- NULL, /* gdev_vector_fill_triangle */ \
- NULL, /* draw_thin_line */\
- xps_begin_image, /* begin_image */ \
- NULL, /* image_data */\
- NULL, /* end_image */\
- NULL, /* strip_tile_rectangle */\
- NULL, /* strip_copy_rop */\
- NULL, /* get_clipping_box */\
- NULL, /* begin_typed_image */\
- NULL, /* get_bits_rectangle */\
- NULL, /* map_color_rgb_alpha */\
- NULL, /* create_compositor */\
- NULL, /* get_hardware_params */\
- NULL, /* text_begin */\
- xps_finish_copydevice,\
- NULL,\
-}
+static dev_proc_initialize_device_procs(xps_initialize_device_procs);
+static dev_proc_begin_typed_image(xps_begin_typed_image);
const gx_device_xps gs_xpswrite_device = {
- xps_device_body("xpswrite", 24),
- xps_device_procs
+ xps_device_body("xpswrite", 24, xps_initialize_device_procs),
};
+static int
+xps_initialize_device(gx_device *dev)
+{
+ gx_device_xps *xps = (gx_device_xps*)dev;
+
+ memset(xps->PrinterName, 0x00, MAXPRINTERNAME);
+
+ return 0;
+}
+
+static void
+xps_initialize_device_procs(gx_device *dev)
+{
+ set_dev_proc(dev, initialize_device, xps_initialize_device);
+ set_dev_proc(dev, open_device, xps_open_device);
+ set_dev_proc(dev, output_page, xps_output_page);
+ set_dev_proc(dev, close_device, xps_close_device);
+ set_dev_proc(dev, map_rgb_color, gx_default_rgb_map_rgb_color);
+ set_dev_proc(dev, map_color_rgb, gx_default_rgb_map_color_rgb);
+ set_dev_proc(dev, fill_rectangle, gdev_vector_fill_rectangle);
+ set_dev_proc(dev, get_params, xps_get_params);
+ set_dev_proc(dev, put_params, xps_put_params);
+ set_dev_proc(dev, get_page_device, gx_page_device_get_page_device);
+ set_dev_proc(dev, fill_path, gdev_xps_fill_path);
+ set_dev_proc(dev, stroke_path, gdev_xps_stroke_path);
+ set_dev_proc(dev, begin_typed_image, xps_begin_typed_image);
+}
+
/* Vector device procedures */
static int
xps_beginpage(gx_device_vector *vdev);
@@ -1321,14 +1299,6 @@ xps_put_params(gx_device *dev, gs_param_list *plist)
return code;
}
-static int xps_finish_copydevice(gx_device *dev, const gx_device *from_dev)
-{
- gx_device_xps *xps = (gx_device_xps*)dev;
-
- memset(xps->PrinterName, 0x00, MAXPRINTERNAME);
- return 0;
-}
-
static int
set_state_color(gx_device_vector *vdev, const gx_drawing_color *pdc, gx_color_index *color)
{
@@ -1898,15 +1868,20 @@ xps_write_profile(const gs_gstate *pgs, char *name, cmm_profile_t *profile, gx_d
}
static int
-xps_begin_image(gx_device *dev, const gs_gstate *pgs,
- const gs_image_t *pim, gs_image_format_t format,
- const gs_int_rect *prect, const gx_drawing_color *pdcolor,
- const gx_clip_path *pcpath, gs_memory_t *mem,
- gx_image_enum_common_t **pinfo)
+xps_begin_typed_image(gx_device *dev,
+ const gs_gstate *pgs,
+ const gs_matrix *pmat,
+ const gs_image_common_t *pic,
+ const gs_int_rect *prect,
+ const gx_drawing_color *pdcolor,
+ const gx_clip_path *pcpath,
+ gs_memory_t *mem,
+ gx_image_enum_common_t **pinfo)
{
gx_device_vector *vdev = (gx_device_vector *)dev;
gx_device_xps *xdev = (gx_device_xps *)dev;
- gs_color_space *pcs = pim->ColorSpace;
+ const gs_image_t *pim = (const gs_image_t *)pic;
+ gs_color_space *pcs;
xps_image_enum_t *pie = NULL;
xps_icc_data_t *icc_data;
gs_matrix mat;
@@ -1922,6 +1897,10 @@ xps_begin_image(gx_device *dev, const gs_gstate *pgs,
gsicc_rendering_param_t rendering_params;
bool force8bit = false;
+ if (pic->type->index != 1)
+ goto use_default;
+
+ pcs = pim->ColorSpace;
/* No image mask yet. Also, need a color space */
if (pcs == NULL || ((const gs_image1_t *)pim)->ImageMask)
goto use_default;
@@ -1939,8 +1918,10 @@ xps_begin_image(gx_device *dev, const gs_gstate *pgs,
if (gs_matrix_invert(&pim->ImageMatrix, &mat) < 0)
goto use_default;
+ if (pmat == NULL)
+ pmat = &ctm_only(pgs);
if (pgs)
- gs_matrix_multiply(&mat, &ctm_only(pgs), &mat);
+ gs_matrix_multiply(&mat, pmat, &mat);
pie = gs_alloc_struct(mem, xps_image_enum_t, &st_xps_image_enum,
"xps_begin_image");
@@ -2078,7 +2059,7 @@ xps_begin_image(gx_device *dev, const gs_gstate *pgs,
if (pgs == NULL)
return(gs_error_invalidaccess);
- code = gdev_vector_begin_image(vdev, pgs, pim, format, prect,
+ code = gdev_vector_begin_image(vdev, pgs, pim, pim->format, prect,
pdcolor, pcpath, mem, &xps_image_enum_procs,
(gdev_vector_image_enum_t *)pie);
if (code < 0)
@@ -2147,8 +2128,8 @@ xps_begin_image(gx_device *dev, const gs_gstate *pgs,
return 0;
use_default:
- return gx_default_begin_image(dev, pgs, pim, format, prect,
- pdcolor, pcpath, mem, pinfo);
+ return gx_default_begin_typed_image(dev, pgs, pmat, pic, prect,
+ pdcolor, pcpath, mem, pinfo);
}
/* Handles conversion from decoded DeviceN, Sep or Indexed space to Device color
@@ -2329,6 +2310,7 @@ xps_image_end_image(gx_image_enum_common_t * info, bool draw_last)
/* Add the image relationship */
code = xps_add_image_relationship(pie);
+ gs_free_object(pie->memory, pie, "xps_image_end_image");
exit:
return code;
}
diff --git a/doc/API.htm b/doc/API.htm
index 5bbb9ec5..982c6434 100644
--- a/doc/API.htm
+++ b/doc/API.htm
@@ -1771,7 +1771,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>
<p>
-<small>Ghostscript version 9.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/C-style.htm b/doc/C-style.htm
index c600eac6..7d90c34d 100644
--- a/doc/C-style.htm
+++ b/doc/C-style.htm
@@ -1609,7 +1609,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>
<p>
-<small>Ghostscript version 9.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Commprod.htm b/doc/Commprod.htm
index 6b12e305..594e4f8d 100644
--- a/doc/Commprod.htm
+++ b/doc/Commprod.htm
@@ -279,7 +279,7 @@ of the license contained in the file LICENSE in this distribution. For more info
http://www.artifex.com/licensing/or contact Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato, CA 94945, U.S.A., +1(415)492-9861.</p>
<p>
-<small>Ghostscript version 9.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/DLL.htm b/doc/DLL.htm
index ce120ad2..878fce4b 100644
--- a/doc/DLL.htm
+++ b/doc/DLL.htm
@@ -766,7 +766,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Deprecated.htm b/doc/Deprecated.htm
index 4edc729d..721406e3 100644
--- a/doc/Deprecated.htm
+++ b/doc/Deprecated.htm
@@ -5763,7 +5763,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Develop.htm b/doc/Develop.htm
index 0e546f54..14b912a1 100644
--- a/doc/Develop.htm
+++ b/doc/Develop.htm
@@ -1046,7 +1046,7 @@ virtual procedure in the device color, either <code>fill_rectangle</code>
or <code>fill_mask</code> to actually paint pixels. For rectangle fills,
pure colors call the device's <code>fill_rectangle</code> procedure;
halftones and tiled Patterns call the device's
-<code>tile_rectangle</code>; shaded Patterns, and painting operations
+<code>strip_tile_rectangle</code>; shaded Patterns, and painting operations
that involve a RasterOp, do something more complicated.
<dl>
@@ -4754,7 +4754,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Devices.htm b/doc/Devices.htm
index c1048e59..e1629f51 100644
--- a/doc/Devices.htm
+++ b/doc/Devices.htm
@@ -322,6 +322,8 @@ page.</dd>
</pre>
</blockquote>
+<p>In commercial builds, the <code>png16m</code> device will accept a <code>-dDeskew</code> option to automatically detect/correct skew when generating output bitmaps.</p>
+
<h3><a name="JFIF"></a>JPEG file format (JFIF)</h3>
<p>
@@ -543,6 +545,9 @@ device(s) 2 additional &quot;special&quot; ratios
are available, 32 and 34. 32 provides a 3:2 downscale (so from 300 to
200 dpi, say). 34 produces a 3:4 upscale (so from 300 to 400 dpi, say).</p>
+<p>In commercial builds, with 8 bit per component output, the <code>-dDeskew</code> option
+can be used to automatically detect/correct skew when generating output bitmaps.</p>
+
<p>The <code>tiffscaled</code> and <code>tiffscaled4</code> devices
can optionally use Even Toned Screening, rather than simple Floyd Steinberg
error diffusion. This patented technique gives better quality at the
@@ -605,6 +610,7 @@ The <code>tiffscaled24</code> device renders internally at the specified resolut
(set by <code>-dDownScaleFactor</code>= described below). The compression can be set using
-sCompression= as described below.</dd>
+<p>In commercial builds, the <code>-dDeskew</code> option can be used to automatically detect/correct skew when generating output bitmaps.</p>
<a name="tiffscaled32"></a><dt><code>tiffscaled32</code></dt>
<dd>
@@ -613,6 +619,8 @@ The <code>tiffscaled32</code> device renders internally at the specified resolut
(set by <code>-dDownScaleFactor</code>= described below). The compression can be set using
-sCompression= as described below.</dd>
+<p>In commercial builds, the <code>-dDeskew</code> option can be used to automatically detect/correct skew when generating output bitmaps.</p>
+
</dl>
</blockquote>
@@ -905,6 +913,8 @@ format for the &quotOutputFile&quot (or &quot-o&quot) file name parameter (see
to output multiple pages to a single PSD file (i.e. without the &quot%d&quot format) will
result in an <code>ioerror</code> Postscript error.</p>
+<p>In commercial builds, for the <code>psdcmyk</code> and <code>psdrgb</code> devices, the <code>-dDeskew</code> option can be used to automatically detect/correct skew when generating output bitmaps.</p>
+
<h3><a name="PDFimage"></a>PDF image output</h3>
<p>
@@ -923,6 +933,7 @@ PDF files with a colour depth of 8 (Gray), 24 (RGB) or 32 (CMYK), the PCLm devic
These are all implemented as 'downscale' devices, which means they can implement page level
anti-aliasing using the <code>-dDownScaleFactor</code> switch.
</p>
+
<blockquote>
<dl>
<dt><code>-dDownScaleFactor=</code><b><em>integer</em></b></dt>
@@ -936,6 +947,8 @@ anti-aliasing using the <code>-dDownScaleFactor</code> switch.
</blockquote>
</blockquote>
+<p>In commercial builds, the <code>-dDeskew</code> option can be used to automatically detect/correct skew when generating the output file.</p>
+
<p>
The type of compression used for the image data can also be selected using the <code>-sCompression</code> switch.
Valid compression types are <code>None</code>, <code>LZW</code>, <code>Flate</code>, <code>JPEG</code>
@@ -943,13 +956,24 @@ and <code>RLE</code>.Note that LZW is not supported on PCLm (not valid) and None
on PCLm for debugging purposes.
</p>
<p>
-Finally, the PCLm device supports the <code>-dStripHeight</code> switch to set the vertical height
-of the strips of image content, as required by the specification.
+For JPEG compression the devices support both the JPEGQ and QFactor switches as documented for the <a href="#JFIF">JPEG</a> file format device.
</p>
-
<p>
-For JPEG compression the devices support both the JPEGQ and QFactor switches as documented for the <a href="#JFIF">JPEG</a> file format device.
+In addition, the PCLm device supports some other parameters. Firstly, the
+<code>-dStripHeight</code> switch to set the vertical height
+of the strips of image content, as required by the specification.
</p>
+<p>Secondly, the standard postscript <code>-dDuplex</code> and
+<code>-dTumble</code>switches are supported, in that if both are
+set to true, every verso page (i.e. all even pages) will be
+rotated by 180 degrees.</p>
+
+<p>As an extension to this, a <code>-dTumble2</code> parameter is
+also supported that will add an additional X-axis flip for every
+verso page. Thus <code>-dDuplex=true -dTumble=false -dTumble2=true</code>
+will result in verso pages being flipped horizontally, and
+<code>-dDuplex=true -dTumble=true -dTumble2=true</code> will result
+in verso pages being flipped vertically.</p>
<hr>
@@ -2146,7 +2170,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Drivers.htm b/doc/Drivers.htm
index 47c5b052..577564ba 100644
--- a/doc/Drivers.htm
+++ b/doc/Drivers.htm
@@ -244,21 +244,20 @@ href="../devices/gdevdjet.c">gdevdjet.c</a> are good examples of this approach.<
A device is represented by a structure divided into three parts:</p>
<ul>
-<li>procedures that are (normally) shared by all instances of each device;</li>
-
<li>parameters that are present in all devices but may be different for
-each device or instance; and</li>
+each device or instance;</li>
+
+<li>an initialize_device_procs procedure; and</li>
<li>device-specific parameters that may be different for each instance.</li>
</ul>
<p>
-Normally the procedure structure is defined and initialized at compile
-time. A prototype of the parameter structure (including both generic and
+A prototype of the parameter structure (including both generic and
device-specific parameters) is defined and initialized at compile time, but
-is copied and filled in when an instance of the device is created. Both of
-these structures should be declared as <code>const</code>, but for backward
-compatibility reasons the latter is not.</p>
+is copied and filled in when an instance of the device is created. This
+structure should be declared as <code>const</code>, but for backward
+compatibility reasons it is not.</p>
<p>
The <code>gx_device_common</code> macro defines the common structure
@@ -275,7 +274,7 @@ href="../base/gdevprn.h">gdevprn.h</a>.</p>
} smurf_device;
smurf_device gs_smurf_device = {
<b><em>... macro for generic parameter values ...,</em></b>
- { <b><em>... procedures ...</em></b> }, /* std_procs */
+ <b><em>initialize_device_procs,</em></b>
<b><em>... device-specific parameter values if any ...</em></b>
};</pre>
</blockquote>
@@ -285,6 +284,49 @@ The device structure instance <b>must</b> have the name
name used in <code>contrib.mak</code>. <code>gx_device_common</code>
is a macro consisting only of the element definitions. </p>
<p>
+The <code>initialize_device_procs</code> function pointer is called when
+the device is created. Its sole job is to initialize the entries in
+the device procedure table. On entry, the device procedure table will
+be full of NULL pointers. On exit, any NULLs left in the table will be
+filled in with pointers to the default routines. Therefore, the routine
+should set any non-default entries itself.
+<p>
+Devices that are (in object-oriented terms) derived from 'base' classes
+(for instance a new printer device that derives from the <code>prn</code>
+device) can call provided helper functions for setting the standard
+functions for that base class.
+<p>
+For example, if the smurf device was a printer device, its
+<code>initialize_device_procs</code> procedure might look like:</p>
+<blockquote>
+<pre>static void smurf_initialize_device_procs(gx_device *dev) {
+ /* We are derived from a prn device, and can print in the background */
+ gdev_prn_initialize_bg(dev);
+
+ /* Override functions for our specifics */
+ set_dev_proc(dev, map_color_rgb, smurf_map_color_rgb);
+ set_dev_proc(dev, map_rgb_color, smurf_map_rgb_color);
+ ...
+}</pre>
+</blockquote>
+<p>
+The initialize procedure function pointer does not live in the in the
+device procedure table (and as such is statically initialized at compile
+time). Nonetheless, we refer to this as being a device procedure in the
+rest of the discussion here.
+<p>
+Note that the <code>initialize_device_procs</code> function may be called
+with a pointer to a <code>gx_device</code> rather than to the derived
+device class. This happens frequently when one device wants to obtain
+the prototype of another to copy device procedures around. Initialization
+of items in the device other than device procs should therefore be
+reserved for the <code>initialize_device</code> device procedure.
+<p>
+The use of the initialize procedure is new to Ghostscript 9.55. Previous
+versions used a statically initialized table of device procedures. We
+changed to a dynamically initialized system to more easily cope with
+future changes to the device procedures.
+<p>
All the device procedures are called with the device as the first argument.
Since each device type is actually a different structure type, the device
procedures must be declared as taking a <code>gx_device&nbsp;*</code> as
@@ -1093,8 +1135,8 @@ the same way.</p>
<p>As from Ghostscript 9.11 onwards, a new device function, <tt>process_page</tt>
has been introduced to solve this. A printer driver will be called via the
<tt>print_page</tt> or <tt>print_page_copies</tt> entry point as before, but
-rather than requesting a scan line or rectangle of pixels at a time (by
-calling <tt>get_bits</tt> or <tt>get_bits_rectangle</tt> respectively), the
+rather than requesting a rectangle of pixels at a time (by
+calling <tt>get_bits_rectangle</tt>), the
driver can now invite Ghostscript to "process the page" in whatever sized
chunks it chooses.</p>
@@ -1221,23 +1263,31 @@ help accelerate devices such as <tt>pdfwrite</tt> or <tt>ps2write</tt>.</p>
Most of the procedures that a driver may implement are optional. If a
device doesn't supply an optional procedure <code>WXYZ</code>, the entry
in the procedure structure may be either <code>gx_default_WXYZ</code>,
-for instance <code>gx_default_tile_rectangle</code>, or
+for instance <code>gx_default_strip_tile_rectangle</code>, or
<code>NULL</code> or 0. (The device procedure must also call the
<code>gx_default_</code> procedure if it doesn't implement the function
-for particular values of the arguments.) Since C compilers supply 0 as the
-value for omitted structure elements, this convention means that statically
-initialized procedure structures continue to work even if new (optional)
+for particular values of the arguments.) Since, by construction,
+device procedure entries are set to 0 at creation time, ones that are
+not explicitly initialised will continue to work even if new (optional)
members are added.</p>
<h3><a name="Life_cycle"></a>Life cycle</h3>
<p>
+When a device is first created, it will have an empty device procs
+table. The system will call the device's <code>initialize_device_procs</code>
+function pointer to fill out this table. This operation can never fail.</p>
+
+<p>NOTE: This operation is also used for creating temporary 'prototype'
+devices for copying device procedures from.</p>
+
+<p>
A device instance begins life in a closed state. In this state, no output
operations will occur. Only the following procedures may be called:</p>
<blockquote><code>
+initialize_device<br>
open_device<br>
-finish_copydevice<br>
get_initial_matrix<br>
get_params<br>
put_params<br>
@@ -1281,6 +1331,30 @@ level at the time the instance was created.</li>
<h3><a name="Open_close"></a>Open, close, sync, copy</h3>
<dl>
+<dt><code>void (*initialize_device_procs)(gx_device *dev)</code></dt> <dd>Called
+once a new device instance has been created. The function should initialize
+the device procedure tables. This cannot fail.
+<b>NOTE</b>: Clients should rarely need to call a device's
+<code>initialize_device_procs</code> procedure: this procedure is mostly used
+by the internal device creation code. The sole exception here is when
+a device implementation wishes to copy device function pointers from another
+device; then a blank <code>gx_device</code> can be created, and
+<code>initialize_device_procs</code> can be used to fill out the device procs
+table so it can be copied from.</dd>
+</dl>
+
+<dl>
+<dt><code>int (*initialize_device)(gx_device *dev)</code> <b><em>[OPTIONAL</em></b></dt>
+<dd>Called once a new device instance has been created and the device procs
+table has been initialized. This function should perform the minimum
+initialization to any internal device state required. If the initial setup
+fails, this procedure should return an error; the new instance will be freed.
+<b>NOTE</b>: Clients should never call a device's <code>initialize_device</code>
+procedure: this procedure is only intended for use by the internal device
+creation code.</dd>
+</dl>
+
+<dl>
<dt><code>int (*open_device)(gx_device *)</code> <b><em>[OPTIONAL]</em></b></dt>
<dd>Open the device: do any initialization associated with making the device
instance valid. This must be done before any output to the device. The
@@ -1290,20 +1364,6 @@ always call <code>gs_opendevice</code> instead.</dd>
</dl>
<dl>
-<dt><code>int (*finish_copydevice)(gx_device *dev, const gx_device
-*from_dev)</code> <b><em>[OPTIONAL]</em></b></dt> <dd>Perform any cleanup
-required after <code>copydevice</code> has created a new device instance
-by copying <code>from_dev</code>. If the copy operation should not be
-allowed, this procedure should return an error; the copy will be freed. The
-default implementation allows copying the device prototype, but does not
-allow copying device instances, because instances may contain internal
-pointers that should not be shared between copies, and there is no way to
-determine this from outside the device. <b>NOTE</b>: Clients should never
-call a device's <code>finish_copydevice</code> procedure: this procedure
-is only intended for use by <code>gs_copydevice[2]</code>. </dd>
-</dl>
-
-<dl>
<dt><code>void (*get_initial_matrix)(gx_device *, gs_matrix *)</code> <b><em>[OPTIONAL]</em></b> </dt>
<dd>Construct the initial transformation matrix mapping user coordinates
(nominally 1/72 inch per unit) to device coordinates. The default
@@ -1436,19 +1496,30 @@ supported by the device.</p>
<dl>
<dt><code>const gx_cm_color_map_procs&nbsp;* get_color_mapping_procs(const
-gx_device&nbsp;* dev)</code> <b><em>[OPTIONAL]</em></b> </dt>
-<dd>This procedure returns a list of three procedures. These procedures
-are used to translate values in either Gray, RGB, or CMYK color spaces
-into device colorant values. A separate procedure is not required for the
-DeviceN and Separation color spaces since these already represent
-device colorants.</dd>
+gx_device&nbsp;* dev, const gx_device&nbsp;** tdev)</code> <b><em>[OPTIONAL]</em></b> </dt>
+<dd>This procedure returns a list of three procedures, together with the
+device to pass to them. These procedures are used to translate values in
+either Gray, RGB, or CMYK color spaces into device colorant values. A
+separate procedure is not required for the DeviceN and Separation color
+spaces since these already represent device colorants.</dd>
+
+<p>In many cases, the device returned in <code>tdev</code> will be the
+same as <code>dev</code>, but the caller should not rely on this. For
+cases where we have a chain of devices (perhaps because of a subclass
+or compositor device having been introduced internally as part of the
+rendering process), the actual device that needs to do the color mapping
+may be a child device of the original one. In such cases <code>tdev</code>
+will be returned as a different value to <code>dev</code>.
+</p>
<p>
The default procedure returns a list of procedures based upon
<code>color_info.num_components</code>. These procedures are appropriate
for DeviceGray, DeviceRGB, or DeviceCMYK process color model devices. A
procedure must be defined if another process color model is used by the
-device or spot colors are to be supported.</p>
+device or spot colors are to be supported. All these procedures take a
+<code>gx_device</code> pointer; these should be called with the value
+returned in <code>tdev</code> NOT the initial value of <code>dev</code>.</p>
</dl>
<dl>
@@ -1477,54 +1548,13 @@ the values in <code>color_info.depth</code> and
</dl>
<dl>
-<dt><code>gx_color_index (*map_rgb_alpha_color)(gx_device&nbsp;*,
-gx_color_value&nbsp;red, gx_color_value&nbsp;green,
-gx_color_value&nbsp;blue, gx_color_value&nbsp;alpha)</code> <b><em>[OPTIONAL]</em></b></dt>
-<dd>Map a RGB color and an opacity value to a device color. The range of
-legal values of the RGB and alpha arguments is 0 to
-<code>gx_max_color_value</code>; <code>alpha</code> = 0 means
-transparent, <code>alpha</code> = <code>gx_max_color_value</code>
-means fully opaque. The default is to use the
-<code>encode_color</code> procedure and ignore alpha.</dd>
-
-<p>
-Note that if a driver implements <code>map_rgb_alpha_color</code>, it
-must also implement <code>encode_color</code>, and must implement them
-in such a way that
-<code>map_rgb_alpha_color(dev,&nbsp;r,&nbsp;g,&nbsp;b,&nbsp;gx_max_color_value)</code>
-returns the same value as
-<code>encode_color(dev,&nbsp;CV)</code>. </p>
-</dl>
-
-<dl>
-<dt><code>int (*map_color_rgb_alpha)(gx_device&nbsp;*,
-gx_color_index&nbsp;color, gx_color_value&nbsp;rgba[4])</code>
-<b><em>[OPTIONAL]</em></b></dt>
-<dd>Map a device color code to RGB and alpha values. The default
-implementation calls <code>map_color_rgb</code> and fills in
-<code>gx_max_color_value</code> for alpha.</dd>
-
-<p>
-Note that if a driver implements <code>map_color_rgb_alpha</code>, it
-must also implement <code>decode_color</code>, and must implement them
-in such a way that the first 3 values returned by
-<code>map_color_rgb_alpha</code> are the same as the values returned by
-<code>decode_color</code>.</p>
-
-<p>
-Note that only RGB devices currently support variable opacity; alpha is ignored
-on other devices. The PDF 1.4 transparency features are supported on all devices. </p>
-</dl>
-
-<dl>
<dt><code>typedef&nbsp;enum&nbsp;{&nbsp;go_text,
go_graphics&nbsp;}&nbsp;graphic_object_type;&nbsp;int
(*get_alpha_bits)(gx_device&nbsp;*dev,
-graphic_object_type&nbsp;type)</code> <b><em>[OPTIONAL] [OBSOLETE]</em></b></dt>
-<dd>This procedure is no longer used: it is replaced by the
-color_info.anti_alias member of the driver structure. However, it still
-appears in the driver procedure vector for backward compatibility. It
-should never be called, and drivers should not implement it.</dd>
+graphic_object_type&nbsp;type)</code> <b><em>[OPTIONAL]</em></b></dt>
+<dd>This procedure returns the number of bits to use for anti-aliasing.
+The default implementation simply returns the color_info.anti_alias
+member of the driver structure.</dd>
</dl>
<dl>
@@ -1601,21 +1631,6 @@ efficiently is very important.</p>
</dl>
<dl>
-<dt><code>int (*tile_rectangle)(gx_device&nbsp;*,
-const&nbsp;gx_tile_bitmap&nbsp;*tile, int&nbsp;x, int&nbsp;y,
-int&nbsp;width, int&nbsp;height, gx_color_index&nbsp;color0,
-gx_color_index&nbsp;color1, int&nbsp;phase_x, int&nbsp;phase_y)</code>
-<b><em>[OPTIONAL] [OBSOLETE]</em></b></dt>
-<dd>This procedure is still supported, but has been superseded by
-<code>strip_tile_rectangle</code>. New drivers should implement
-<code>strip_tile_rectangle</code>; if they cannot cope with non-zero
-shift values, they should test for this explicitly and call the default
-implementation (<code>gx_default_strip_tile_rectangle</code>) if
-shift&nbsp;!=&nbsp;0. Clients should call
-<code>strip_tile_rectangle</code>, not <code>tile_rectangle</code>.</dd>
-</dl>
-
-<dl>
<dt><code>int (*strip_tile_rectangle)(gx_device&nbsp;*,
const&nbsp;gx_strip_bitmap&nbsp;*tile, int&nbsp;x, int&nbsp;y,
int&nbsp;width, int&nbsp;height, gx_color_index&nbsp;color0,
@@ -1691,7 +1706,7 @@ than or equal to the plane_height.</dd>
<p>
We do not provide a separate procedure for tiling with a pixmap; instead,
-<code>tile_rectangle</code> can also take colored tiles. This is
+<code>strip_tile_rectangle</code> can also take colored tiles. This is
indicated by the <code>color0</code> and <code>color1</code>
arguments' both being <code>gx_no_color_index</code>. In this case, as
for <code>copy_color</code>, the <code>raster</code> and
@@ -1818,13 +1833,19 @@ than a gx_color_index.</dd>
</dl>
<dl>
-<dt><code>int (*create_compositor)(dev_t&nbsp;*dev,
+<dt><code>int (*composite)(dev_t&nbsp;*dev,
gx_device_t&nbsp;**pcdev, const&nbsp;gs_composite_t&nbsp;*pcte,
const&nbsp;gs_imager_state&nbsp;*pis, gs_memory_t&nbsp;*memory)</code>
<b><em>[OPTIONAL]</em></b> </dt>
-<dd>Create a new device (called a "compositing device" or "compositor")
-that will composite data written to it with the device's existing data,
+<dd>Requests that a device perform a compositing operation; the device
+should composite data written to it with the device's existing data,
according to the compositing function defined by <code>*pcte</code>.
+If a device cannot perform such an operation itself, it will create a
+compositor device to wrap itself that will perform such operations for
+it. Accordingly, the caller must watch the return values from this
+function to understand if a new device has been created to which future
+calls should be made.
+<p>
Devices will normally implement this in one of the following standard ways:</dd>
<ul>
@@ -1883,370 +1904,11 @@ even if the underlying device doesn't.</p>
<p>
Closing a compositor frees all of its storage, including the compositor
-itself. However, since the <code>create_compositor</code> call may
+itself. However, since the <code>composite</code> call may
return the same device, clients must check for this case, and only call the
close procedure if a separate device was created.</p>
</dl>
-<p>
-<font size="+1">
-<b><em>[strip_]copy_rop WILL BE SUPERSEDED BY COMPOSITORS</em></b>
-</font></p>
-
-<dl>
-<dt><code>int (*copy_rop)(gx_device&nbsp;*dev,
-const&nbsp;byte&nbsp;*sdata, int&nbsp;sourcex, uint&nbsp;sraster,
-gx_bitmap_id&nbsp;id, const&nbsp;gx_color_index&nbsp;*scolors,
-const&nbsp;gx_tile_bitmap&nbsp;*texture,
-const&nbsp;gx_color_index&nbsp;*tcolors, int&nbsp;x, int&nbsp;y,
-int&nbsp;width, int&nbsp;height, int&nbsp;phase_x, int&nbsp;phase_y,
-int&nbsp;command)</code> <b><em>[OPTIONAL]</em></b></dt>
-<dd>This procedure is still supported, but has been superseded by
-<code>strip_copy_rop</code>. New drivers should implement
-<code>strip_copy_rop</code>; if they cannot cope with non-zero shift
-values in the texture, they should test for this explicitly and call the
-default implementation (<code>gx_default_strip_copy_rop</code>) if
-shift&nbsp;!=&nbsp;0. Clients should call <code>strip_copy_rop</code>,
-not <code>copy_rop</code>.</dd>
-</dl>
-
-<dl>
-<dt><code>int (*strip_copy_rop)(gx_device&nbsp;*dev,
-const&nbsp;byte&nbsp;*sdata, int&nbsp;sourcex, uint&nbsp;sraster,
-gx_bitmap_id&nbsp;id, const&nbsp;gx_color_index&nbsp;*scolors,
-const&nbsp;gx_strip_bitmap&nbsp;*texture,
-const&nbsp;gx_color_index&nbsp;*tcolors, int&nbsp;x, int&nbsp;y,
-int&nbsp;width, int&nbsp;height, int&nbsp;phase_x, int&nbsp;phase_y,
-int&nbsp;command)</code> <b><em>[OPTIONAL]</em></b></dt>
-<dd>Combine an optional source image <b>S</b> (as for
-<code>copy_mono</code> or <code>copy_color</code>) and an optional
-texture <b>T</b> (a tile, as for <code>tile_rectangle</code>) with the
-existing bitmap or pixmap <b>D</b> held by the driver, pixel by pixel,
-using any 3-input Boolean operation as modified by "transparency" flags:
-schematically, set <b>D&nbsp;=&nbsp;f(D,S,T)</b>, computing <b>f</b> in RGB
-space rather than using actual device pixel values. <b>S</b> and <b>T</b>
-may each (independently) be a solid color, a bitmap with "foreground" and
-"background" colors, or a pixmap. This is a complex (and currently rather
-slow) operation. The arguments are as follows:</dd>
-
-<blockquote><table>
-<tr valign="top"> <td><code>dev</code></td>
- <td>&nbsp;</td>
- <td>the device, as for all driver procedures</td></tr>
-<tr valign="top"> <td><code>sdata</code>, <code>sourcex</code>, <code>sraster</code>, <code>id</code>, <code>scolors</code></td>
- <td>&nbsp;</td>
- <td>specify <b>S</b>, <a href="#S_spec">see below</a></td></tr>
-<tr valign="top"> <td><code>texture</code>, <code>tcolors</code></td>
- <td>&nbsp;</td>
- <td>specify <b>T</b>, <a href="#T_spec">see below</a></td></tr>
-<tr valign="top"> <td><code>x</code>, <code>y</code>, <code>width</code>, <code>height</code></td>
- <td>&nbsp;</td>
- <td>as for the other copy and fill procedures</td></tr>
-<tr valign="top"> <td><code>phase_x</code>, <code>phase_y</code></td>
- <td>&nbsp;</td>
- <td>part of <b>T</b> specification, <a href="#T_spec">see below</a></td></tr>
-<tr valign="top"> <td><code>command</code></td>
- <td>&nbsp;</td>
- <td><a href="#F_spec">see below</a></td></tr>
-</table></blockquote>
-</dl>
-
-<h5><a name="S_spec"></a>The source specification S</h5>
-
-<p>
-As noted above, the source <b>S</b> may be a solid color, a bitmap, or a
-pixmap. If <b>S</b> is a solid color:</p>
-
-<ul>
-<li><code>sdata</code>, <code>sourcex</code>,
-<code>sraster</code>, and <code>id</code> are irrelevant.</li>
-
-<li><code>scolors</code> points to two <code>gx_color_index</code>
-values; <code>scolors[0]</code> = <code>scolors[1]</code> = the
-color.</li>
-</ul>
-
-<p>
-If <b>S</b> is a bitmap:</p>
-
-<ul>
-<li><code>sdata</code>, <code>sourcex</code>,
-<code>sraster</code>, and <code>id</code> arguments are as for
-<code>copy_mono</code> or <code>copy_color</code>
-(<code>data</code>, <code>data_x</code>, <code>raster</code>,
-<code>id</code>), and specify a source bitmap.</li>
-
-<li><code>scolors</code> points to two <code>gx_color_index</code>
-values; <code>scolors[0]</code> is the background color (the color
-corresponding to 0-bits in the bitmap), <code>scolors[1]</code> is the
-foreground color (the color corresponding to 1-bits in the bitmap).</li>
-</ul>
-
-<p>
-If <b>S</b> is a pixmap:</p>
-
-<ul>
-<li><code>sdata</code>, <code>sourcex</code>,
-<code>sraster</code>, and <code>id</code> arguments are as for
-<code>copy_mono</code> or <code>copy_color</code>
-(<code>data</code>, <code>data_x</code>, <code>raster</code>,
-<code>id</code>), and specify a source pixmap whose depth is the same as
-the depth of the destination.</li>
-
-<li><code>scolors</code> is <code>NULL</code>.</li>
-</ul>
-
-<p>
-Note that if the source is a bitmap with background=0 and foreground=1, and
-the destination is 1 bit deep, then the source can be treated as a pixmap
-(scolors=<code>NULL</code>).</p>
-
-<h5><a name="T_spec"></a>The texture specification T</h5>
-
-<p>
-Similar to the source, the texture <b>T</b> may be a solid color, a bitmap,
-or a pixmap. If <b>T</b> is a solid color:</p>
-
-<ul>
-<li>The texture pointer is irrelevant.</li>
-
-<li><code>tcolors</code> points to two <code>gx_color_index</code>
-values; <code>tcolors[0]</code> = <code>tcolors[1]</code> = the
-color.</li>
-</ul>
-
-<p>
-If <b>T</b> is a bitmap:</p>
-
-<ul>
-<li>The texture argument points to a <code>gx_tile_bitmap</code>, as for
-the <code>tile_rectangle</code> procedure. Similarly,
-<code>phase_x</code> and <code>phase_y</code> specify the offset of
-the texture relative to the device coordinate system origin, again as for
-<code>tile_rectangle</code>. The tile is a bitmap (1 bit per pixel).</li>
-
-<li><code>tcolors</code> points to two <code>gx_color_index</code>
-values; <code>tcolors[0]</code> is the background color (the color
-corresponding to 0-bits in the bitmap), <code>tcolors[1]</code> is the
-foreground color (the color corresponding to 1-bits in the bitmap).</li>
-</ul>
-
-<p>
-If <b>T</b> is a pixmap:</p>
-
-<ul>
-<li>The texture argument points to a <code>gx_tile_bitmap</code> whose
-depth is the same as the depth of the destination.</li>
-
-<li>tcolors is <code>NULL</code>.</li>
-</ul>
-
-<p>
-Again, if the texture is a bitmap with background=0 and foreground=1, and
-the destination depth is 1, the texture bitmap can be treated as a pixmap
-(tcolors=<code>NULL</code>).</p>
-
-<p>
-Note that while a source bitmap or pixmap has the same width and height as
-the destination, a texture bitmap or pixmap has its own width and height
-specified in the <code>gx_tile_bitmap</code> structure, and is
-replicated or clipped as needed.</p>
-
-<h5><a name="F_spec"></a>The function specification f</h5>
-
-<p>
-"Command" indicates the raster operation and transparency as follows:</p>
-
-<blockquote><table>
-<tr valign="bottom">
- <th colspan ="3">Bits</th>
-</tr>
-<tr valign="top"> <td>7-0</td>
- <td>&nbsp;</td>
- <td>raster op</td></tr>
-<tr valign="top"> <td>8</td>
- <td>&nbsp;</td>
- <td>0 if source opaque, 1 if source transparent</td></tr>
-<tr valign="top"> <td>9</td>
- <td>&nbsp;</td>
- <td>0 if texture opaque, 1 if texture transparent</td></tr>
-<tr valign="top"> <td>10</td>
- <td>&nbsp;</td>
- <td>1 if pdf transparency is in use, 0 otherwise. This makes no
-difference to the rendering, but forces the raster operation to be considered
- non-idempotent by internal routines.</td></tr>
-<tr valign="top"> <td>11</td>
- <td>&nbsp;</td>
- <td>1 if the target of this operation is a specific plane, rather
-than all planes. The plane in question is given by bits 13 upwards. This
-is only used by the planar device.</td></tr>
-<tr valign="top"> <td>12-</td>
- <td>&nbsp;</td>
- <td>If bit 11 = 1, then bits 12 upwards give the plane number to
- operate on. Otherwise, should be set to 0.</td></tr>
-</table></blockquote>
-
-<p>In general most devices should just check to see that bits they do not
-handle (11 and above typically) are zero, and should jump to the default
- implementation, or return an error otherwise.</p>
-
-<p>
-The raster operation follows the Microsoft and H-P specification. It is an
-8-element truth table that specifies the output value for each of the
-possible 2&times;2&times;2 input values as follows:</p>
-
-<blockquote><table>
-<tr valign="bottom">
- <th>Bit</th>
- <th>&nbsp;</th>
- <th>Texture</th>
- <th>&nbsp;</th>
- <th>Source</th>
- <th>&nbsp;</th>
- <th>Destination</th></tr>
-<tr valign="top"> <td align="center">7</td>
- <td>&nbsp;</td>
- <td align="center">1</td>
- <td>&nbsp;</td>
- <td align="center">1</td>
- <td>&nbsp;</td>
- <td align="center">1</td></tr>
-<tr valign="top"> <td align="center">6</td>
- <td>&nbsp;</td>
- <td align="center">1</td>
- <td>&nbsp;</td>
- <td align="center">1</td>
- <td>&nbsp;</td>
- <td align="center">0</td></tr>
-<tr valign="top"> <td align="center">5</td>
- <td>&nbsp;</td>
- <td align="center">1</td>
- <td>&nbsp;</td>
- <td align="center">0</td>
- <td>&nbsp;</td>
- <td align="center">1</td></tr>
-<tr valign="top"> <td align="center">4</td>
- <td>&nbsp;</td>
- <td align="center">1</td>
- <td>&nbsp;</td>
- <td align="center">0</td>
- <td>&nbsp;</td>
- <td align="center">0</td></tr>
-<tr valign="top"> <td align="center">3</td>
- <td>&nbsp;</td>
- <td align="center">0</td>
- <td>&nbsp;</td>
- <td align="center">1</td>
- <td>&nbsp;</td>
- <td align="center">1</td></tr>
-<tr valign="top"> <td align="center">2</td>
- <td>&nbsp;</td>
- <td align="center">0</td>
- <td>&nbsp;</td>
- <td align="center">1</td>
- <td>&nbsp;</td>
- <td align="center">0</td></tr>
-<tr valign="top"> <td align="center">1</td>
- <td>&nbsp;</td>
- <td align="center">0</td>
- <td>&nbsp;</td>
- <td align="center">0</td>
- <td>&nbsp;</td>
- <td align="center">1</td></tr>
-<tr valign="top"> <td align="center">0</td>
- <td>&nbsp;</td>
- <td align="center">0</td>
- <td>&nbsp;</td>
- <td align="center">0</td>
- <td>&nbsp;</td>
- <td align="center">0</td></tr>
-</table></blockquote>
-
-<p>
-Transparency affects the output in the following way. A source or texture
-pixel is considered transparent if its value is all 1s (for instance, 1 for
-bitmaps, <tt>0xffffff</tt> for 24-bit RGB pixmaps) <b><em>and</em></b> the
-corresponding transparency bit is set in the command. For each pixel, the
-result of the Boolean operation is written into the destination iff neither
-the source nor the texture pixel is transparent. (Note that the HP
-RasterOp specification, on which this is based, specifies that if the
-source and texture are both all 1s and the command specifies transparent
-source and opaque texture, the result <b><em>should</em></b> be written in
- the output. We think this is an error in the documentation.) </p>
-
-<h5><a name="Compositing_notes"></a>Notes</h5>
-
-<p>
-<code>copy_rop</code> is defined to operate on pixels in RGB space,
-again following the HP and Microsoft specification. For devices that
-don't use RGB (or gray-scale with black = 0, white = all 1s) as their
-native color representation, the implementation of <code>copy_rop</code>
-must convert to RGB or gray space, do the operation, and convert back (or
-do the equivalent of this). Here are the <code>copy_rop</code>
-equivalents of the most important previous imaging calls. We assume the
-declaration: </p>
-
-<blockquote><code>
-static const gx_color_index white2[2] = { 1, 1 };
-</code></blockquote>
-
-<p>
-Note that <code>rop3_S</code> may be replaced by any other Boolean operation.
-For monobit devices, we assume that black = 1.</p>
-
-<blockquote>
-<pre>/* For all devices: */
-(*fill_rectangle)(dev, x, y, w, h, color) ==&gt;
-
- { gx_color_index colors[2];
- colors[0] = colors[1] = color;
- (*dev_proc(dev, copy_rop))(dev, NULL, 0, 0, gx_no_bitmap_id, colors,
- NULL, colors /*irrelevant*/,
- x, y, w, h, 0, 0, rop3_S);
- }
-
-/* For black-and-white devices only: */
-(*copy_mono)(dev, base, sourcex, sraster, id,
- x, y, w, h, (gx_color_index)0, (gx_color_index)1) ==&gt;
-
- (*dev_proc(dev, copy_rop))(dev, base, sourcex, sraster, id, NULL,
- NULL, white2 /*irrelevant*/,
- x, y, w, h, 0, 0, rop3_S);
-
-/* For color devices, where neither color0 nor color1 is gx_no_color_index: */
-(*copy_mono)(dev, base, sourcex, sraster, id,
- x, y, w, h, color0, color1) ==&gt;
-
- { gx_color_index colors[2];
- colors[0] = color0, colors[1] = color1;
- (*dev_proc(dev, copy_rop))(dev, base, sourcex, sraster, id, colors,
- NULL, white2 /*irrelevant*/,
- x, y, w, h, 0, 0, rop3_S);
- }
-
-/* For black-and-white devices only: */
-(*copy_mono)(dev, base, sourcex, sraster, id,
- x, y, w, h, gx_no_color_index, (gx_color_index)1) ==&gt;
-
- (*dev_proc(dev, copy_rop))(dev, base, sourcex, sraster, id, NULL,
- NULL, white2 /*irrelevant*/,
- x, y, w, h, 0, 0,
- rop3_S | lop_S_transparent);
-
-/* For all devices: */
-(*copy_color)(dev, base, sourcex, sraster, id,
- x, y, w, h) ==&gt; [same as first copy_mono above]
-
-/* For black-and-white devices only: */
-(*tile_rectangle)(dev, tile, x, y, w, h,
- (gx_color_index)0, (gx_color_index)1, px, py) ==&gt;
-
- (*dev_proc(dev, copy_rop))(dev, NULL, 0, 0, gx_no_bitmap_id,
- white2 /*irrelevant*/,
- tile, NULL,
- x, y, w, h, px, py, rop3_T)
-</pre></blockquote>
-
<h3><a name="Polygon_level_drawing"></a>Polygon-level drawing</h3>
<p>
@@ -2307,15 +1969,6 @@ gs_logical_operation_t&nbsp;lop)</code> <b><em>[OPTIONAL]</em></b></dt>
<dd>Draw a one-pixel-wide line from <em>(fx0,fy0)</em> to
<em>(fx1,fy1)</em>.</dd>
-<dt><code>int (*draw_line)(gx_device&nbsp;*dev, int&nbsp;x0, int&nbsp;y0,
-int&nbsp;x1, int&nbsp;y1, gx_color_index&nbsp;color)</code>
-<b><em>[OPTIONAL] [OBSOLETE]</em></b></dt>
-<dd>This procedure is no longer used: it is replaced by the draw_thin_line
-procedure. However, still appears in the driver procedure vector for
-backward compatibility. It should never be called, and drivers should not
-implement it.</dd>
-</dl>
-
<h3><a name="Linear_color_drawing"></a>Linear color drawing</h3>
<p>
@@ -2580,9 +2233,131 @@ with the given color and logical operation. The clip path pointer may be
<code>NULL</code>, meaning do not clip. The parameters
<code>data</code>, ..., <code>height</code> are as for
<code>copy_mono</code>; depth is as for <code>copy_alpha</code>;
-command is as for <code>copy_rop</code>.</dd>
+command is as below.</dd>
</dl>
+<h5><a name="F_spec"></a>The function specification f</h5>
+
+<p>
+"Command" indicates the raster operation and transparency as follows:</p>
+
+<blockquote><table>
+<tr valign="bottom">
+ <th colspan ="3">Bits</th>
+</tr>
+<tr valign="top"> <td>7-0</td>
+ <td>&nbsp;</td>
+ <td>raster op</td></tr>
+<tr valign="top"> <td>8</td>
+ <td>&nbsp;</td>
+ <td>0 if source opaque, 1 if source transparent</td></tr>
+<tr valign="top"> <td>9</td>
+ <td>&nbsp;</td>
+ <td>0 if texture opaque, 1 if texture transparent</td></tr>
+<tr valign="top"> <td>10</td>
+ <td>&nbsp;</td>
+ <td>1 if pdf transparency is in use, 0 otherwise. This makes no
+difference to the rendering, but forces the raster operation to be considered
+ non-idempotent by internal routines.</td></tr>
+<tr valign="top"> <td>11</td>
+ <td>&nbsp;</td>
+ <td>1 if the target of this operation is a specific plane, rather
+than all planes. The plane in question is given by bits 13 upwards. This
+is only used by the planar device.</td></tr>
+<tr valign="top"> <td>12-</td>
+ <td>&nbsp;</td>
+ <td>If bit 11 = 1, then bits 12 upwards give the plane number to
+ operate on. Otherwise, should be set to 0.</td></tr>
+</table></blockquote>
+
+<p>In general most devices should just check to see that bits they do not
+handle (11 and above typically) are zero, and should jump to the default
+ implementation, or return an error otherwise.</p>
+
+<p>
+The raster operation follows the Microsoft and H-P specification. It is an
+8-element truth table that specifies the output value for each of the
+possible 2&times;2&times;2 input values as follows:</p>
+
+<blockquote><table>
+<tr valign="bottom">
+ <th>Bit</th>
+ <th>&nbsp;</th>
+ <th>Texture</th>
+ <th>&nbsp;</th>
+ <th>Source</th>
+ <th>&nbsp;</th>
+ <th>Destination</th></tr>
+<tr valign="top"> <td align="center">7</td>
+ <td>&nbsp;</td>
+ <td align="center">1</td>
+ <td>&nbsp;</td>
+ <td align="center">1</td>
+ <td>&nbsp;</td>
+ <td align="center">1</td></tr>
+<tr valign="top"> <td align="center">6</td>
+ <td>&nbsp;</td>
+ <td align="center">1</td>
+ <td>&nbsp;</td>
+ <td align="center">1</td>
+ <td>&nbsp;</td>
+ <td align="center">0</td></tr>
+<tr valign="top"> <td align="center">5</td>
+ <td>&nbsp;</td>
+ <td align="center">1</td>
+ <td>&nbsp;</td>
+ <td align="center">0</td>
+ <td>&nbsp;</td>
+ <td align="center">1</td></tr>
+<tr valign="top"> <td align="center">4</td>
+ <td>&nbsp;</td>
+ <td align="center">1</td>
+ <td>&nbsp;</td>
+ <td align="center">0</td>
+ <td>&nbsp;</td>
+ <td align="center">0</td></tr>
+<tr valign="top"> <td align="center">3</td>
+ <td>&nbsp;</td>
+ <td align="center">0</td>
+ <td>&nbsp;</td>
+ <td align="center">1</td>
+ <td>&nbsp;</td>
+ <td align="center">1</td></tr>
+<tr valign="top"> <td align="center">2</td>
+ <td>&nbsp;</td>
+ <td align="center">0</td>
+ <td>&nbsp;</td>
+ <td align="center">1</td>
+ <td>&nbsp;</td>
+ <td align="center">0</td></tr>
+<tr valign="top"> <td align="center">1</td>
+ <td>&nbsp;</td>
+ <td align="center">0</td>
+ <td>&nbsp;</td>
+ <td align="center">0</td>
+ <td>&nbsp;</td>
+ <td align="center">1</td></tr>
+<tr valign="top"> <td align="center">0</td>
+ <td>&nbsp;</td>
+ <td align="center">0</td>
+ <td>&nbsp;</td>
+ <td align="center">0</td>
+ <td>&nbsp;</td>
+ <td align="center">0</td></tr>
+</table></blockquote>
+
+<p>
+Transparency affects the output in the following way. A source or texture
+pixel is considered transparent if its value is all 1s (for instance, 1 for
+bitmaps, <tt>0xffffff</tt> for 24-bit RGB pixmaps) <b><em>and</em></b> the
+corresponding transparency bit is set in the command. For each pixel, the
+result of the Boolean operation is written into the destination iff neither
+the source nor the texture pixel is transparent. (Note that the HP
+RasterOp specification, on which this is based, specifies that if the
+source and texture are both all 1s and the command specifies transparent
+source and opaque texture, the result <b><em>should</em></b> be written in
+ the output. We think this is an error in the documentation.) </p>
+
<h4><a name="Images"></a>Images</h4>
<p>
@@ -2747,15 +2522,16 @@ follows:</p>
</blockquote>
<dl>
-<dt><code>int (*begin_image)(gx_device&nbsp;*dev,
-const&nbsp;gs_imager_state&nbsp;*pis, const&nbsp;gs_image_t&nbsp;*pim,
-gs_image_format_t&nbsp;format, gs_int_rect&nbsp;*prect,
+<dt><code>int (*begin_typed_image)(gx_device&nbsp;*dev,
+const&nbsp;gs_imager_state&nbsp;*pis, const&nbsp;gs_matrix&nbsp;*pmat,
+const&nbsp;gs_image_common_t&nbsp;*pim, gs_int_rect&nbsp;*prect,
const&nbsp;gx_drawing_color&nbsp;*pdcolor,
const&nbsp;gx_clip_path&nbsp;*pcpath, gs_memory_t&nbsp;*memory,
gx_image_enum_common_t&nbsp;**pinfo)</code> <b><em>[OPTIONAL]</em></b></dt>
-<dd>Begin the transmission of an image. Zero or more calls of
-<code>image_plane_data</code> will follow, and then a call of
-<code>end_image</code>. The parameters of <code>begin_image</code>
+<dd>Begin the transmission of an image. Zero or more calls of the
+ <code>image_plane_data</code> function supplied in the returned image
+ enumerator will follow, and then a call of
+<code>end_image</code>. The parameters of <code>begin_typed_image</code>
are as follows:</dd>
<blockquote><table>
@@ -2764,16 +2540,19 @@ are as follows:</dd>
<td>pointer to an imager state. The only relevant elements of the
imager state are the CTM (coordinate transformation matrix),
the logical operation (<code>RasterOp</code> or
- transparency), and the color rendering information.</td></tr>
+ transparency), and the color rendering information. For
+ mask images, if <code>pmat</code> is not NULL and the color is pure,
+ <code>pis</code> may be NULL.</td></tr>
+<tr valign="top"> <td><code>pmat</code></td>
+ <td>&nbsp;</td>
+ <td>pointer to a <code>gs_matrix</code> structure that
+ defines the image transformation matrix. If <code>pis</code> is non-NULL,
+ and <code>pmat</code> is NULL, then the <code>ctm</code> from <code>pis</code>
+ should be used.</td></tr>
<tr valign="top"> <td><code>pim</code></td>
<td>&nbsp;</td>
<td>pointer to the <code>gs_image_t</code> structure that
defines the image parameters</td></tr>
-<tr valign="top"> <td><code>format</code></td>
- <td>&nbsp;</td>
- <td>defines how pixels are represented for
- <code>image_plane_data</code>. See the description of
- <code>image_plane_data</code> below</td></tr>
<tr valign="top"> <td><code>prect</code></td>
<td>&nbsp;</td>
<td>if not <code>NULL</code>, defines a subrectangle of the
@@ -2798,12 +2577,12 @@ are as follows:</dd>
</table></blockquote>
<p>
-<code>begin_image</code> is expected to allocate a structure for its
+<code>begin_typed_image</code> is expected to allocate a structure for its
bookkeeping needs, using the allocator defined by the memory parameter, and
-return it in <code>*pinfo</code>. <code>begin_image</code> should not assume that
+return it in <code>*pinfo</code>. <code>begin_typed_image</code> should not assume that
the structures in <code>*pim</code>, <code>*prect</code>, or
<code>*pdcolor</code> will survive the call on
-<code>begin_image</code> (except for the color space in
+<code>begin_typed_image</code> (except for the color space in
<code>*pim-&gt;ColorSpace</code>): it should copy any necessary parts of
them into its own bookkeeping structure. It may, however, assume that
<code>*pis</code>, <code>*pcpath</code>, and of course
@@ -2811,33 +2590,14 @@ them into its own bookkeeping structure. It may, however, assume that
is called.</p>
<p>
-<code>begin_image</code> returns 0 normally, or 1 if the image does not
-need any data. In the latter case, <code>begin_image</code> does not
+<code>begin_typed_image</code> returns 0 normally, or 1 if the image does not
+need any data. In the latter case, <code>begin_typed_image</code> does not
allocate an enumeration structure.</p>
</dl>
-<dl>
-<dt><code>int (*begin_typed_image)(gx_device&nbsp;*dev,
-const&nbsp;gs_imager_state&nbsp;*pis, const&nbsp;gs_matrix&nbsp;*pmat,
-const&nbsp;gs_image_common_t&nbsp;*pim, gs_int_rect&nbsp;*prect,
-const&nbsp;gx_drawing_color&nbsp;*pdcolor,
-const&nbsp;gx_clip_path&nbsp;*pcpath, gs_memory_t&nbsp;*memory,
-gx_image_enum_common_t&nbsp;**pinfo)</code> <b><em>[OPTIONAL]</em></b></dt>
-<dd>This has the same function as <code>begin_image</code>, except</dd>
-<ul>
-<li>The image may be of any <code>ImageType</code>, not only
-<code>image_type_simple</code> (1);</li>
-
-<li>The image format is included in the image structure, not supplied as a
-separate argument;</li>
-
-<li>The optional <code>pmat</code> argument provides a matrix that
-substitutes for the one in the imager state;</li>
-
-<li>For mask images, if <code>pmat</code> is not <code>NULL</code>
-and the color is pure, <code>pis</code> may be <code>NULL</code>.</li>
-</ul>
-</dl>
+<p>
+The format of the image (how pixels are represented) is given by
+<code>pim-&gt;format</code>.</p>
<p>
The actual transmission of data uses the procedures in the enumeration
@@ -2914,7 +2674,7 @@ bool&nbsp;draw_last)</code></dt>
<dd>Finish processing an image, either because all data have been supplied
or because the caller has decided to abandon this image.
<code>end_image</code> may be called at any time after
-<code>begin_image</code>. It should free the info structure and any
+<code>begin_typed_image</code>. It should free the info structure and any
subsidiary structures. If <code>draw_last</code> is true, it should
finish drawing any buffered lines of the image.</dd>
</dl>
@@ -2923,14 +2683,14 @@ finish drawing any buffered lines of the image.</dd>
<p>
While there will almost never be more than one image enumeration in
-progress -- that is, after a <code>begin_image</code>,
+progress -- that is, after a <code>begin_typed_image</code>,
<code>end_image</code> will almost always be called before the next
-<code>begin_image</code> -- driver code should not rely on this
+<code>begin_typed_image</code> -- driver code should not rely on this
property; in particular, it should store all information regarding the
image in the info structure, not in the driver structure.</p>
<p>
-Note that if <code>begin_[typed_]image</code> saves its parameters in
+Note that if <code>begin_typed_image</code> saves its parameters in
the info structure, it can decide on each call whether to use its own
algorithms or to use the default implementation. (It may need to call
<code>gx_default_begin</code>/<code>end_image</code> partway
@@ -2947,9 +2707,8 @@ optional.</p>
<dl>
<dt><code>int (*text_begin)(gx_device&nbsp;*dev,
gs_imager_state&nbsp;*pis, const&nbsp;gs_text_params_t&nbsp;*text,
-gs_font&nbsp;*font, gx_path&nbsp;*path,
-const&nbsp;gx_device_color&nbsp;*pdcolor,
-const&nbsp;gx_clip_path&nbsp;*pcpath, gs_memory_t&nbsp;*memory,
+gs_font&nbsp;*font,
+const&nbsp;gx_clip_path&nbsp;*pcpath,
gs_text_enum_t&nbsp;**ppte)</code> <b><em>[OPTIONAL]</em></b></dt>
<p></p><dd>
@@ -2973,26 +2732,11 @@ follows:</dd>
<tr valign="top"> <td><code>font</code></td>
<td>&nbsp;</td>
<td>Defines the font for drawing.</td></tr>
-<tr valign="top"> <td><code>path</code></td>
- <td>&nbsp;</td>
- <td>Defines the path where the character outline will be appended
- (if the text operation includes <code>TEXT_DO_...PATH</code>),
- and whose current point indicates where drawing should occur
- and will be updated by the string width (unless the text
- operation includes <code>TEXT_DO_NONE</code>).</td>
-<tr valign="top"> <td><code>pdcolor</code></td>
- <td>&nbsp;</td>
- <td>Defines the drawing color for the text. Only relevant if
- the text operation includes <code>TEXT_DO_DRAW</code>.</td></tr>
<tr valign="top"> <td><code>pcpath</code></td>
<td>&nbsp;</td>
<td>If not <code>NULL</code>, defines an optional clipping path.
Only relevant if the text operation includes
<code>TEXT_DO_DRAW</code>.</td></tr>
-<tr valign="top"> <td><code>memory</code></td>
- <td>&nbsp;</td>
- <td>Defines the allocator to be used for allocating bookkeeping
- information.</td></tr>
<tr valign="top"> <td><code>ppte</code></td>
<td>&nbsp;</td>
<td>The implementation should return a pointer to its state
@@ -3001,12 +2745,26 @@ follows:</dd>
<p>
<code>text_begin</code> must allocate a structure for its bookkeeping
-needs, using the allocator defined by the <code>memory</code> parameter,
+needs, using the allocator used by the graphics state,
and return it in <code>*ppte</code>. <code>text_begin</code> may
assume that the structures passed as parameters will survive until text
processing is complete.</p>
<p>
+If the text operation includes <code>TEXT_DO...PATH</code> then the
+character outline will be appended to the current path in the
+<code>pgs</code>. The current point of that path indicates where
+drawing should occur and will be updated by the string width
+(unless the text operation includes <code>TEXT_DO_NONE</code>).</p>
+
+<p>If the text operation includes <code>TEXT_DO_DRAW</code> then
+the text color will be taken from the current colour in the graphics
+state. (Otherwise no colour is required).</p>
+
+<p>The bookkeeping information will be allocated using the memory
+allocator from the graphics state.</p>
+
+<p>
Clients should not call the driver <code>text_begin</code> procedure
directly. Instead, they should call <code>gx_device_text_begin</code>,
which takes the same parameters and also initializes certain common elements
@@ -3093,8 +2851,7 @@ if the glyph can't be translated to Unicode.</p>
<dl>
<dt><code>int (*get_bits_rectangle)(gx_device&nbsp;*dev,
-const&nbsp;gs_int_rect&nbsp;*prect, gs_get_bits_params_t&nbsp;*params,
-gs_int_rect&nbsp;**unread)</code> <b><em>[OPTIONAL]</em></b></dt>
+const&nbsp;gs_int_rect&nbsp;*prect, gs_get_bits_params_t&nbsp;*params)</code> <b><em>[OPTIONAL]</em></b></dt>
<p><dd>
Read a rectangle of bits back from the device. The <code>params</code>
@@ -3209,49 +2966,6 @@ in each scan line are undefined. If the implementation returns pointers to
the data, it stores them into <code>data[0]</code> or
<code>data[</code><b><em>0..N-1</em></b><code>]</code>.</p>
-<p>
-If not all the source data are available (for example, because the source
-was a partially obscured window and backing store was not available or not
-used), or if the rectangle does not fall completely within the device's
-coordinate system, any unread bits are undefined, and the value returned
-depends on whether unread is <code>NULL</code>. If unread is
-<code>NULL</code>, return <code>gs_error_ioerror</code>; in this case,
-some bits may or may not have been read. If unread is not
-<code>NULL</code>, allocate (using <code>dev</code>-&gt;memory) and
-fill in a list of rectangles that could not be read, store the pointer to
-the list in <code>*unread</code>, and return the number of rectangles; in
-this case, all bits not listed in the rectangle list have been read back
-properly. The list is not sorted in any particular order, but the
-rectangles do not overlap. Note that the rectangle list may cover a
-superset of the region actually obscured: for example, a lazy implementation
-could return a single rectangle that was the bounding box of the region.</p>
-</dl>
-
-<dl>
-<dt><code>int (*get_bits)(gx_device&nbsp;*dev, int&nbsp;y,
-byte&nbsp;*data, byte&nbsp;**actual_data)</code>
-<b><em>[OPTIONAL]</em></b></dt>
-<dd>Read scan line <code>y</code> of bits back from the device into the
-area starting at data. This call is functionally equivalent to</dd>
-
-<blockquote>
-<pre>(*get_bits_rectangle)
- (dev, {0, y, dev-&gt;width, y+1},
- {(GB_ALIGN_ANY | (GB_RETURN_COPY | GB_RETURN_POINTER) | GB_OFFSET_0 |
- GB_RASTER_STANDARD | GB_FORMAT_CHUNKY | GB_COLORS_NATIVE |
- GB_ALPHA_NONE),
- {data}})</pre></blockquote>
-
-<p>
-with the returned value of
-<code>params</code>-&gt;<code>data[0]</code> stored in
-<code>*actual_data</code>, and will in fact be implemented this way if
-the device defines a <code>get_bits_rectangle</code> procedure and does
-not define one for <code>get_bits</code>. (If
-<code>actual_data</code> is <code>NULL</code>,
-<code>GB_RETURN_POINTER</code> is omitted from the options.)</p>
-</dl>
-
<h3><a name="Parameters"></a>Parameters</h3>
<p>
@@ -3402,32 +3116,6 @@ processed and stored.
</dd>
</dl></blockquote>
-<h3><a name="External_fonts"></a>External fonts</h3>
-
-<p>
-Drivers may include the ability to display text. More precisely, they may
-supply a set of procedures that in turn implement some font and text
-handling capabilities, described in <a href="Xfonts.htm">a separate
-document</a>. The link between the two is the driver procedure that
-supplies the font and text procedures:</p>
-
-<dl>
-<dt><code>xfont_procs&nbsp;*(*get_xfont_procs)(gx_device&nbsp;*dev)</code> <b><em>[OPTIONAL]</em></b></dt>
-<dd>Return a structure of procedures for handling external fonts and text
-display. A <code>NULL</code> value means that this driver doesn't
-provide this capability.</dd>
-</dl>
-
-<p>
-For technical reasons, a second procedure is also needed:</p>
-
-<dl>
-<dt><code>gx_device&nbsp;*(*get_xfont_device)(gx_device&nbsp;*dev)</code> <b><em>[OPTIONAL]</em></b></dt>
-<dd>Return the device that implements <code>get_xfont_procs</code> in a
-non-default way for this device, if any. Except for certain special
-internal devices, this is always the device argument.</dd>
-</dl>
-
<h3><a name="Page_devices"></a>Page devices</h3>
<dl>
@@ -3684,7 +3372,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Fonts.htm b/doc/Fonts.htm
index bfc948df..ac8a6da2 100644
--- a/doc/Fonts.htm
+++ b/doc/Fonts.htm
@@ -360,7 +360,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/GPDL.htm b/doc/GPDL.htm
index 20bc722d..9c37af4a 100644
--- a/doc/GPDL.htm
+++ b/doc/GPDL.htm
@@ -578,7 +578,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>
<p>
-<small>Ghostscript version 9.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/GS9_Color_Management.pdf b/doc/GS9_Color_Management.pdf
index 1fef5528..66b4f548 100644
--- a/doc/GS9_Color_Management.pdf
+++ b/doc/GS9_Color_Management.pdf
Binary files differ
diff --git a/doc/History9.htm b/doc/History9.htm
index bede0e58..5002c9bf 100644
--- a/doc/History9.htm
+++ b/doc/History9.htm
@@ -69,6 +69,7 @@ TOC to see how to edit it for visual conciseness.
<h2>Table of contents</h2>
<blockquote><ul>
+<li><a href="#Version9.55.0">Version 9.55.0 (2021-09-27)</a>
<li><a href="#Version9.54.0">Version 9.54.0 (2021-03-19)</a>
<li><a href="#Version9.53.3">Version 9.53.3 (2020-10-01)</a>
<li><a href="#Version9.52">Version 9.52 (2020-03-19)</a>
@@ -101,24 +102,6 @@ TOC to see how to edit it for visual conciseness.
<!-- [1.3 begin hint] ====================================================== -->
-<p>
-This document is a record of changes in Ghostscript releases numbered 9.xx.
-For earlier versions, see the the history documents:
-
-<blockquote>
-<a href="History8.htm">History of Ghostscript versions 8.n</a><br>
-<a href="History7.htm">History of Ghostscript versions 7.n</a><br>
-<a href="History6.htm">History of Ghostscript versions 6.n</a><br>
-<a href="History5.htm">History of Ghostscript versions 5.n</a><br>
-<a href="History4.htm">History of Ghostscript versions 4.n</a><br>
-<a href="History3.htm">History of Ghostscript versions 3.n</a><br>
-<a href="History2.htm">History of Ghostscript versions 2.n</a><br>
-
-</li>
-<li>
-<p>We <a href="History1.htm">History of Ghostscript versions 1.n</a>
-</blockquote>
-
<p>For other information, see the <a href="Readme.htm">Ghostscript
<p>See <a href="https://www.ghostscript.com/ocr.html">Enabling OCR</a> for more details.
<p>See <a href="https://www.ghostscript.com/ocr.html">Enabling OCR</a> for more details.
@@ -131,36 +114,50 @@ overview</a>.
<!-- [1.0 end visible header] ============================================== -->
<!-- [2.0 begin contents] ================================================== -->
-<h2><a name="Version9.54.0"></a>Version 9.54.0 (2021-03-19)</h2>
-<p>The 9.54.0 release is a maintenance release, and also adds new functionality.
-<br>
+<h2><a name="Version9.55.0"></a>Version 9.55.0 (2021-09-27)</h2>
<p> Highlights in this release include:
<ul>
+<p>This release includes the fix for the <code>%pipe%</code> security issue (CVE-2021-3781).
+</li>
+<li>
+<p><b>New PDF Interpreter:</b> This is an entirely new implementation written in C (rather than
+PostScript, as before). For a full discussion of this change and reasons for it see:
+<a href="https://ghostscript.com/pdfi.html">Changes Coming to the PDF Interpreter</a>.
+<p>In this (9.55.0) release, the new PDF interpreter is disabled by default in Ghostscript,
+but can be used by specifying <code>-dNEWPDF</code>. We hope to make it the default in 9.56.0, and
+fully deprecate the PostScript implementation shortly after that (depending on the feedback
+we get).
+<p>This also allows us to offer a new executable (<code>gpdf</code>, or <code>gpdfwin??.exe</code>
+on Windows) which is <i>purely</i> for PDF input. For this release, those new binaries are not included
+in the "install" make targets, nor in the Windows installers (they will be from 9.56.0 onwards).
+<p>We would ask that as many users as possible take the opportunity to test with the new PDF implementation
+(i.e. using <code>-dNEWPDF</code> on your gs command line), and discuss any problems with us, before
+the new implementation becomes the default.
+</li>
+<li>
+<p>The pdfwrite device now supports &quot;passthrough&quot; for JPX/JPG2000 data images (as well as the
+already supported JPEG/DCT Encoded). That means that if no rescaling or color conversion of the image data
+is required, the encoded/compressed image data from the input file will be written unchanged to the output,
+preventing potential image degradation caused by decompressing and recompressing.
+</li>
<li>
-<p>Overprint simulation is now available to all output devices, allowing
-quality previewing/proofing of PostScript and PDF jobs that rely on overprint.
-See the <code>-dOverprint</code> option documentation in:
-<a href="Use.htm#Overprint">Overprint</a>
+<p>The Ghostscript/GhostPDL demo apps for C, C#, Java and Python have all had improvements and the
+C#/Java/Python language bindings have now been documented, see <a href="language-bindings/index.html">Ghostscript Language Bindings</a>
</li>
<li>
-<p>The &quot;docxwrite&quot; device adds the ability to output to Microsoft Word
-&quot;docx&quot; (it currently only handles text).
-See: <a href="VectorDevices.htm#DOCX">docxwrite</a>
+<p>The Zugferd compliant PDF generating definitions (<code>lib/zugferd.ps</code>) have been updated and expanded to support the
+current version (2.1.1) of the Zugferd spec, and optionally different versions of the specification.
</li>
<li>
-<p>The pdfwrite device is now capable of using the Tesseract OCR engine when it is
-built into Ghostscript to improve searchability and copy and paste functionality when
-the input lacks the metadata for that purpose. See: <a href="VectorDevices.htm#UseOCR">UseOCR</a>
+<p>The PCL/m output devices now support Duplex/Tumble.
</li>
<li>
-<p>Ghostscript/GhostPDL now includes a &quot;map text to black&quot;
-function, where text drawn by an input job (except when drawn using a
-Type 3 font) can be forced to draw in solid black. See:
-<a href="Use.htm#BlackText">BlackText</a>
+<p>The internal support for &quot;n-up&quot; style simple imposition (introduced in 9.54.0) has been extended and improved
+for better support across all input formats.
</li>
<li>
-<p>Ghostscript/GhostPDL now supports simple N-up imposition &quot;internally&quot;. See:
-<a href="Use.htm#NupControl">NupControl</a>
+<p>Ghostscript now supports object specific halftone - for example, different halftones can be specified for text and
+images, reflecting the differing needs of rendering those two types of object.
</li>
<li>
<p>Our efforts in code hygiene and maintainability continue.
@@ -183,12 +180,25 @@ community demand for the feature.
</ul>
<p>For a list of open issues, or to report problems,
please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-<h3><a name="9.54.0_Incompatible_changes"></a>Incompatible changes</h3>
+<h3><a name="9.55.0_Incompatible_changes"></a>Incompatible changes</h3>
<h4>Included below are incompatible changes from recent releases (the
specific release in question listed in parentheses). We include these,
for now, as we are aware that not everyone upgrades with every release.</h4>
<ul>
<li>
+<p>(9.55.0) Changes to the <code>device API</code>. This will affect developers and maintainers of
+Ghostscript devices. Firstly, and most importantly, the way device-specific "procs" are specified has
+been rewritten to make it (we think!) clearer and less confusing. See
+<a href="Drivers.htm">The Interface between Ghostscript and Device Drivers</a> and
+<a href="https://www.notion.so/artifexsoftware/The-Great-Device-Rework-Of-2021-94092fe1395d4a088b91462f0ca5038a">The Great Device Rework Of 2021</a>
+for more details.
+</li>
+<li>
+<p>(9.55.0) The command line options <code>-sGraphicsICCProfile=___</code>, <code>-dGraphicsIntent=#</code>, <code>-dGraphicsBlackPt=#</code>,
+<code>-dGraphicsKPreserve=#</code> have been changed to <code>-sVectorICCProfile=___</code>, <code>-dVectorIntent=#</code>, <code>-dVectorBlackPt=#</code>,
+<code>-dVectorKPreserve=#</code>.
+</li>
+<li>
<p>(9.53.0) As of 9.53.0, we have (re-)introduced the patch level to the version number,
this helps facilitate a revised policy on handling security related issues.
<p><strong>Note for GSView Users:</strong>The patch level addition breaks GSView 5 (it is
@@ -196,13 +206,6 @@ hardcoded to check for versions <code>704-999</code>. It is possible, but not gu
a GSView update might be forthcoming to resolve this.
</li>
<li>
-<p>(9.52) As of 9.52, the Windows binaries released by the Ghostscript development
-team are built with Microsoft Visual Studio 2019. As a result, Microsoft Windows XP and
-earlier are no longer supported by these binaries. This does not imply we are, or will
-start relying upon features only available in VS2019, so the <code>nmake</code> Makefiles
-will continue to allow older Visual Studio versions (back to VS2005) to build Ghostscript.
-</li>
-<li>
<p>(9.52) <code>-dALLOWPSTRANSPARENCY</code>: The transparency compositor (and related
features), whilst we are improving it, remains sensitive to being driven correctly, and
incorrect use can have unexpected/undefined results. Hence, as part of improving security
@@ -213,9 +216,9 @@ As we made "SAFER" the default mode, that became unacceptable, hence the new opt
<li>
<p>(9.50) There are a couple of subtle incompatibilities between the old and new SAFER
implementations. Firstly, as mentioned in the 9.50 release notes, SAFER now leaves
-standard Postcript functionality unchanged (except for the file access limitations).
-Secondly, the interaction with <code>save</code>&sol;<code>restore</code> operations,
-see <a href="Use.htm#Safer">SAFER</a>.
+standard PostScript functionality unchanged (except for the file access limitations).
+Secondly, the interaction with <code>save</code>&sol;<code>restore</code> operations
+has changed. See <a href="Use.htm#Safer">SAFER</a>.
<p><strong>Important Note for Windows Users</strong>:
<br>
The file/path pattern matching is case sensitive, even on Windows. This is a
@@ -228,250434 +231,20 @@ in that it now supports (although does not enforce) case sensitivity.
only non-standard and undocumented operators. Nevertheless, it is possible that
any integrations or utilities that rely on those non-standard and undocumented
operators may stop working or may change behaviour.
-<p>If you encounter such a case, please contact us (either the #ghostscript IRC channel,
+<p>If you encounter such a case, please contact us (<a href="https://discord.gg/H9GXKwyPvY">Discord<a>,
+<a href="https://web.libera.chat/#ghostscript">#ghostscript IRC channel</a>,
or the gs-devel mailing list would be best), and we'll work with you to either find an
alternative solution or return the previous functionality, if there is genuinely no other
option.
</li>
</ul>
-<h3><a name="9.54.0_changelog"></a>Changelog</h3>
-<p><strong>2021-03-29 12:09: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=28f5ec9d1b374449c89f7200e87ba855a97ebdd2">28f5ec9d1b374449c89f7200e87ba855a97ebdd2</a>
-<blockquote>
-<p>
- Bug 703741: clear xstate_change flag on gsave<br>
-<br>
- xstate_change is used (partly) to track whether ExtGState parameters have<br>
- changed since the last &quot;q&quot; op, and thus whether we need to set them back again<br>
- (for the benefit of the pdf14 compositor) on the &quot;Q&quot; op.<br>
-<br>
- Previously, the flag was inherited by the &quot;new&quot; gstate created by a gsave,<br>
- so we could end up trying to reset the ExGState params at the wrong point.<br>
-<br>
- This is especially problematic with internally triggered gsave/grestore for,<br>
- for example, rendering glyphs, or accumulating patterns, etc.<br>
-<br>
- In other words, we currently can end up with a sequence like:<br>
-<br>
- q<br>
- &lt;change ExtGState params&gt; &lt;- set the xstate_change flag<br>
- q &lt;- flag still set<br>
- q &lt;- flag still set<br>
- Q &lt;- reset the ExtGState params, flag still set<br>
- Q &lt;- reset the ExtGState params, flag still set<br>
- Q &lt;- reset the ExtGState params, restores to gstate without flag set<br>
-<br>
- Whereas what we want is:<br>
-<br>
- q<br>
- &lt;change ExtGState params&gt; &lt;- sets the xstate_change flag<br>
- q &lt;- flag not set (still set in a gstate lower down the stack)<br>
- q &lt;- flag not set (still set in a gstate lower down the stack)<br>
- Q<br>
- Q &lt;- this returns the gstate with the flag to the top of the gstate stack<br>
- Q &lt;- reset the ExtGState params, restores to gstate without flag set<br>
-<br>
- So, reset the flag during the gsave.<br>
-<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-24 13:07:41 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=906f906617067aaf42e4e995cc63acdf9bded7c0">906f906617067aaf42e4e995cc63acdf9bded7c0</a>
-<blockquote>
-<p>
- pdfwrite - fix FastWebView with multiple put_params() calls<br>
-<br>
- When testing this I must have used a setup which either set the<br>
- OutputFile before setting FastWebView, or set them simultaneously. If we<br>
- have the two assignments in different calls, and the first call is not<br>
- to set OutputFile, then the assignment of FastWebView will not work.<br>
-<br>
- This is because we didn't check whether OutputFile was set before<br>
- checking if it was seekable, obviously a NULL file is not seekable! This<br>
- caused us to reset 'Linearize'. The subsequent call to set OutputFile<br>
- could not re-enable Linearize, and so linearization would not be<br>
- enabled.<br>
-<br>
- The fix here is simply to check that pdev-&gt;flle is not NULL before<br>
- checking if it is seekable.<br>
-<br>
-devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-20 20:00:33 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49a8691f19e9d7d1370f157d0cd423b4b5d5a526">49a8691f19e9d7d1370f157d0cd423b4b5d5a526</a>
-<blockquote>
-<p>
- Fix a performance regression introduced by commit 813b5f48e8<br>
-<br>
- The fix is to keep the PageUsesOverprint parameter in the device<br>
- dictionary, not in the outer dictionary, and use it from there.<br>
-<br>
- It isn't understood why storing in the outer dictionary causes such a<br>
- substantial performance hit, but profiling shows that the time comes<br>
- from &quot;dstack_find_name_by_index&quot;. The performance hit showed up with<br>
- j9_acrobat.pdf of the performance test suite (about 8%).<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-22 09:51:06 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db2a48697289ae2d53aeb3bbbf82276f0e85a134">db2a48697289ae2d53aeb3bbbf82276f0e85a134</a>
-<blockquote>
-<p>
- Automate tesseract build compatibility with clang++<br>
-<br>
- On MacOS (at least), clang++ requires the addition of the -std=c++17 to enable<br>
- support of the features that tesseract uses.<br>
-<br>
- Also, on Linux (at least) clang++ requires -stdlib=libstdc++ in order to<br>
- pickup a usable stdc++ library.<br>
-<br>
- So, tweak configure to test whether the compiler accepts the options to do both<br>
- the above, and if so, add them to the CXXFLAGS used to build tesseract.<br>
-<br>
- In addition, in configure, pickup CXXFLAGS so custom options can be set on the<br>
- configure command line.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-22 09:12:19 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f40d70eeb5194a51fc585cb9ac9037c12557a826">f40d70eeb5194a51fc585cb9ac9037c12557a826</a>
-<blockquote>
-<p>
- Tweak gitlog2changelog.py to exclude the per-commit file list<br>
-<br>
-toolbin/gitlog2changelog.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-22 12:09:55 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a7db3c313f4c3e0e5ea87510b0d353b4441368f">4a7db3c313f4c3e0e5ea87510b0d353b4441368f</a>
-<blockquote>
-<p>
- Add /utf-8 command to TESSCXXFLAGS in msvc.mak.<br>
-<br>
- Suggested by Akira Kakuto. I don't need this myself, but then my<br>
- default windows codepage is probably different to Akira's. Adding<br>
- this shouldn't cause any problems.<br>
-<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-22 09:11:11 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=73c5567d62b6e9278818c3077c1c3ea3b5ee43ee">73c5567d62b6e9278818c3077c1c3ea3b5ee43ee</a>
-<blockquote>
-<p>
- Update change log post-9.54.0rc1<br>
-<br>
-doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-19 16:14:33 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=26009e688cf4275c252a9e060f30f006c1f1b9de">26009e688cf4275c252a9e060f30f006c1f1b9de</a>
-<blockquote>
-<p>
- Fix crash in display device (seen with apitest.c).<br>
-<br>
- When calculating the size for the display, we setup a<br>
- fake gx_device_memory to call the calculation routine<br>
- with. Because we hadn't initialised the graphics_type_tag<br>
- sometimes it would incorrectly assume there was 1 more<br>
- plane than there should be.<br>
-<br>
- In calculating the required size, it would therefore add<br>
- in bitmap_raster(plane[i].depth * width) more bytes for<br>
- that plane. If plane[i].depth was negative, this would<br>
- cause the amount of memory we allocate to shrink, and<br>
- accordingly, we'd allocate too little memory.<br>
-<br>
- The fix is to ensure that the fake device is always<br>
- zero'd to start with.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-19 13:39: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=42d688a1c90685d2123540416c60bcdf6b0db7dc">42d688a1c90685d2123540416c60bcdf6b0db7dc</a>
-<blockquote>
-<p>
- Update man pages to reflect SAFER is now the default.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-19 13:13:21 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=48a8946f886b18b182868a9866b4927f80860510">48a8946f886b18b182868a9866b4927f80860510</a>
-<blockquote>
-<p>
- Erasepage optimisation - fix invalid device ordering assumption<br>
-<br>
- The erasepage optimisation device, when checking to see whether the<br>
- underlying device permitted optimisaton, was assuming that its own child<br>
- would always be the 'final' device. If we have a chain of subclass<br>
- devices this might not be true.<br>
-<br>
- Run down the chain to the fist non-subclass device and check that<br>
- instead. In future this should be replaced by a spec_op or something<br>
- but this resolves the problem for now.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-19 09:51:25 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a96257ec48dc13a1404990c4a473db88545dcc71">a96257ec48dc13a1404990c4a473db88545dcc71</a>
-<blockquote>
-<p>
- Update dates, and changelog for 9.54.0rc1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-16 09:24:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=905d82cc03d74a69a850eac16596267ed96473a5">905d82cc03d74a69a850eac16596267ed96473a5</a>
-<blockquote>
-<p>
- Update dates and changelog for 9.54.0 rc1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-18 15:39:30 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=38a768a651fd4d11a6c27792067f59713f141634">38a768a651fd4d11a6c27792067f59713f141634</a>
-<blockquote>
-<p>
- Drop DynaLab special bbox stretching of metrics<br>
-<br>
- For historical reasons relating to glyph caching the zchar42_set_cache<br>
- code used the minimum and maximum of the glyph bounding box and font<br>
- bounding box when setting the metrics of a glyph.<br>
-<br>
- This was done for DynaLab (one of the FreeType 'tricky' font types),<br>
- because these fonts abuse the TrueType 'hinting' mechanism.<br>
- Unfortunately this results in the wrong origin 1 being sent to<br>
- setcachedevice2, and hence CDevProc when the font is vertically<br>
- oriented.<br>
-<br>
- We no longer use this function for clipping, and the remaining client<br>
- pdfwrite doesn't use it for clipping but very much does use it for<br>
- gathering font metrics, so it is vital that these be correct.<br>
-<br>
- Since it's only used by pdfwrite, and testing suggests that DynaLab<br>
- fonts are not a problem for this, the code has been removed here. If<br>
- it should ever prove to be required then we should check the Font to<br>
- see if it is a DynaLab font. MuPDF has a function is_dynalab() for this<br>
- and we should use that if we prove to need it.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-17 20:18:44 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=109cae320d32df84b26d668bc03b0068be4482f4">109cae320d32df84b26d668bc03b0068be4482f4</a>
-<blockquote>
-<p>
- Fix bug 703704: Matte in SMask is indirect reference.<br>
-<br>
- Thanks to Peter Cherepanov for this fix. This also catches /null Matte<br>
- entries.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-17 15:33:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bd711e60fb48e0dbedd40742dde58ac1e85a91ec">bd711e60fb48e0dbedd40742dde58ac1e85a91ec</a>
-<blockquote>
-<p>
- Make --disable-threads incompatible with including OCR<br>
-<br>
- Tesseract requires threading, even though Ghostscript doesn't actually call any<br>
- of the parts of tesseract that use threading, there is no sensible way to<br>
- leave it out.<br>
-<br>
- So, throw an error if --disable-threads is used when tesseract/leptonica is<br>
- present. The error includes a note to use &quot;--without-tesseract&quot; to avoid the<br>
- error.<br>
-<br>
- Also, fix a typo from a03ce3d6a130c843cb4dd91b7e767706973b4e22<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-17 11:06: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=157aab06770e5b0f3255e45866d578cac8ff861d">157aab06770e5b0f3255e45866d578cac8ff861d</a>
-<blockquote>
-<p>
- Pick up C++ compiler from configure script<br>
-<br>
- Rather than rely on the GNU make predefine.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-16 17:48:43 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef8fc3115ea0361db31599400129c0e980f79ab1">ef8fc3115ea0361db31599400129c0e980f79ab1</a>
-<blockquote>
-<p>
- Rejig clist_mutate_to_clist for Coverity.<br>
-<br>
- Coverity spotted us accessing *the_memory without having checked<br>
- that the_memory != NULL first.<br>
-<br>
- In fixing that, I've taken the chance to tidy up the function a bit.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-15 13:09:13 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e0611db144ac91c7b1825f94d100b7505a33a5c">0e0611db144ac91c7b1825f94d100b7505a33a5c</a>
-<blockquote>
-<p>
- Fix merge error causing CAL SEGVs.<br>
-<br>
- We were detecting plugins as being old format. This only shows up<br>
- in testing with CAL.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-11 14:59:05 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c60ca5e897375dcd3afbb886fba8808e2e09e12">1c60ca5e897375dcd3afbb886fba8808e2e09e12</a>
-<blockquote>
-<p>
- Update copyright to 2021<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-11 15:14:21 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=628909cfa7b776c81461c511a88ee002ec51fcdb">628909cfa7b776c81461c511a88ee002ec51fcdb</a>
-<blockquote>
-<p>
- Bug 703414 : Halftone artifacts<br>
-<br>
- There are two different representations of the turn-on-sequence<br>
- in GS. One of them uses an array of unsigned short integers that<br>
- indicate what bits get turned on. The array stores an address<br>
- offset into the bitmap tile that is created for a particular level.<br>
- The decision to use this representation is made in gsht.c<br>
- in the gx_ht_alloc_theshold_order method and is based upon the<br>
- width and height of the threshold array which indicates the total<br>
- number of addresses or offsets into the tile to reference which<br>
- bits get turned on in the tile by the turn-on-sequence. The tiles<br>
- themselves however are forced to have their rows raster aligned meaning<br>
- that if w*h &lt;= 65535 the offsets into the tile dots can be larger<br>
- than 65535, which will not fit in the short turn-on-sequence array.<br>
- The code uses a different representation for the TOS if the number<br>
- of elements is less than 2000. Then it stores a pointer to a structure<br>
- for every element. That is the &quot;default&quot; implementation. Here<br>
- a uint (32-bit) implementation is added for cases where the tile is<br>
- larger than 65536 (e.g. bigger than 256 x 256). The implementation is<br>
- the same as the ushort case, but just uses four byte offsets for the TOS.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-11 16:46:13 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9ba7e720143cc11bfd54c26a548860e738b97dfc">9ba7e720143cc11bfd54c26a548860e738b97dfc</a>
-<blockquote>
-<p>
- Fix SEGV with -sNupControl=1x2 to pbmraw -r300 Bug693331.pdf<br>
-<br>
- This was due to the pdf14 getting confused during clist playback when the<br>
- 'master' page contained more than one nested page with transparency. Each of<br>
- the nested pages would PUSH, then POP the pdf14 compositor, but since the pdf14<br>
- compositor remains as the current device, the first POP 'disables' the pdf14<br>
- compositor and the subsequent PUSH 'recreates' the pdf14 device in active<br>
- compositing mode. The problem was that the 'recreate' did not perform all of<br>
- the setup of color_info, cmap_procs, and device procs needed for all of the<br>
- subsequent clist playback through the compositor.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-10 17:48:37 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aa26ed7d8cf0edda3db6c15dc7947ee8bea5ba3d">aa26ed7d8cf0edda3db6c15dc7947ee8bea5ba3d</a>
-<blockquote>
-<p>
- Add additional debug for halftones<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-11 19:25:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3f1195b0523a1d3c8b80a47d7101e31954770767">3f1195b0523a1d3c8b80a47d7101e31954770767</a>
-<blockquote>
-<p>
- Bug 703687: Fix logic for alpha bits in do_fill_stroke()<br>
-<br>
- We can only do the GraphicsAlphaBits anti-aliasing if we are drawing with a<br>
- &quot;pure&quot; color (or a DeviceN color). Basically, not a pattern.<br>
-<br>
- For fill_stroke that means checking for the fill and stroke colors, but the<br>
- conditional was erroneously using &quot;or&quot; rather than &quot;and&quot; - so if either<br>
- color was pure, we'd try to use the alpha buffer, causing incorrect results.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-11 13:09: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=224cafab373865f96f49ac186012bad63b99ff3b">224cafab373865f96f49ac186012bad63b99ff3b</a>
-<blockquote>
-<p>
- Bug 703324 - restore fill state after fill+stroke path operation<br>
-<br>
- The file in bug 703324 fills and strokes a rectangle ('B' operator)<br>
- and sets the fill constant alpha to 1, and the stroke constant alpha<br>
- to 0, so that the stroke is not drawn. Pointless but that's what it<br>
- does.<br>
-<br>
- It then draws some text.<br>
-<br>
- Now the clist maintains an 'opacity' member, which is set and reset by<br>
- (amongst other things) looking at the fill and stroke alpha values. When<br>
- we do a fill+stroke we set the opacity to the fill alpha, and do the<br>
- fill, then we set it to the stroke alpha and draw the stroke.<br>
-<br>
- We then do an 'image_fill_masked' operation to draw the text bitmaps.<br>
- This device method does not take a graphics state as a parameter and so<br>
- is unable to set the opacity in the device based on the fill alpha. It<br>
- simply uses whatever opacity is current at the time. Because the<br>
- fill+stroke left this at the 'stroke' alpha, this is applied to the text<br>
- which (because the alpha is 0) is then not drawn.<br>
-<br>
- In addition the graphics state fill constant alpha value was left with<br>
- the wrong value, but fixing that wasn't sufficient. However we should<br>
- do both, and this commit resets the fill constant alpha in the graphics<br>
- state and recalculates the 'opacity'.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-11 17:05:37 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e2f1611a14000d6a2927ac49a865e5a954dd88b2">e2f1611a14000d6a2927ac49a865e5a954dd88b2</a>
-<blockquote>
-<p>
- Extract clist setup code from prn and display device.<br>
-<br>
- Move to a common clist_mutatable function.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-11 18:38:18 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d15d0ea0873ca27d4f3410d18603bfd0ad890fd5">d15d0ea0873ca27d4f3410d18603bfd0ad890fd5</a>
-<blockquote>
-<p>
- Fix exports for GPL DLL.<br>
-<br>
- This was preventing api_test working on windows.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-11 17:08:00 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=08215797e95bb9db1c19e42b644829afb04a43ca">08215797e95bb9db1c19e42b644829afb04a43ca</a>
-<blockquote>
-<p>
- Fix MSVC warning.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-11 17:07:11 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3657ca38aec1e0b77e9b6c9aae62f03e212475b3">3657ca38aec1e0b77e9b6c9aae62f03e212475b3</a>
-<blockquote>
-<p>
- Fix some comment typos.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-11 08:58:30 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=becd66c4064abad46a2c1d2f35710555362a1502">becd66c4064abad46a2c1d2f35710555362a1502</a>
-<blockquote>
-<p>
- Fix bug 703681. Illegal Mask for image in PDF.<br>
-<br>
- Thanks to Peter Cherepanov for this fix. Check for the type of the Mask<br>
- entry, and ignore it (with an Error message) if not array or dictionary.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-11 15:10:21 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a30569c455b412e2f5ee05ad7df69059886f0a7e">a30569c455b412e2f5ee05ad7df69059886f0a7e</a>
-<blockquote>
-<p>
- Fix ordering of operators in FitPage<br>
-<br>
- Bug #703685 &quot;Crash when using -dPDFFitPage&quot;<br>
-<br>
- The 'cvi' in pdf_PDF2PS_matrix in pdf_main.ps here was meant (I think)<br>
- to apply to the /Rotate value from the page dictionary, but instead<br>
- was applied to the divisor, 90, which isn't needed because 90 is<br>
- obviously already an integer.<br>
-<br>
- If the PDF file (illegally) had a floating point number then the cvi<br>
- should convert it to an integer, so we need to move the cvi so that it<br>
- applies to the /Rotate value.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-10 09:11:08 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91dd2c391c7c68c172d387bd7d2e5904296b68f5">91dd2c391c7c68c172d387bd7d2e5904296b68f5</a>
-<blockquote>
-<p>
- Fix rangecheck from pdf_info when -dDumpXML is used and lines are &gt; 256 bytes.<br>
-<br>
- Just dump the XML metadata rather than trying to suppress blank lines.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-10 01:38:44 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8d4390862d0391430efd65e2bb5f9336231d4ff2">8d4390862d0391430efd65e2bb5f9336231d4ff2</a>
-<blockquote>
-<p>
- Bug 703653: jbig2dec: Use correct freeing function for JBIG2 images.<br>
-<br>
- When jbig2_image_compose() errors out, remember to release all allocated<br>
- pattern images. Previously the most recently allocated image would not<br>
- be release.<br>
-<br>
- Finally remember to free the array of images itself.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-09 19:48:59 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6ba75df38529d3c3d9c57cb9c99429d36ee3072">f6ba75df38529d3c3d9c57cb9c99429d36ee3072</a>
-<blockquote>
-<p>
- Slightly tidy the tessocr.h interface.<br>
-<br>
- Delete an unused function, and move the ocr and hocr functions<br>
- to using ocr_init_api and ocr_fin_api as the others do.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-04 21:14:46 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d2bf7b009922bef2efdbc3d0c8dcfe5d3a8cdb0">4d2bf7b009922bef2efdbc3d0c8dcfe5d3a8cdb0</a>
-<blockquote>
-<p>
- Fix Bug 703648. Commit 00e7143ce9 caused this to surface by changing allocator.<br>
-<br>
- The clist_make_accum_device previously used the target device's allocator which<br>
- was 'system' VM, and commit 00e7143ce9 changed it to use 'local' VM which is<br>
- subject to save/restore. The sample file resutled in an extra rc_decrement of<br>
- the device on page 4 (from gx_pattern_accum_finalize during the restore).<br>
-<br>
- Fix this by using 'stable_memory' (from the mem allocator passed in) prevents<br>
- the restore from affecting the pattern-clist accumulator.<br>
-<br>
- Note the simple command line to reproduce is:<br>
- bin/gs -r1200 -sDEVICE=pgmraw -dBufferSpace=16m -o /dev/null \<br>
- Ad_Quark.ps Ad_Quark.ps Ad_Quark.ps<br>
- which results in &quot;corrupted double-linked list&quot;<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-09 09:35: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=62c5e1b5b6079cabf9008f12f7e038c413dda2d0">62c5e1b5b6079cabf9008f12f7e038c413dda2d0</a>
-<blockquote>
-<p>
- Prevent segfault from -Z^ debug output.<br>
-<br>
- Tripped over this while trying to use it for reference count debug.<br>
- Tested on linux and Windows. No more hackish than the other constants<br>
- in this function.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-09 12:13:35 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e8ae31abf5a2b365f086d3ccf34f64c47503f565">e8ae31abf5a2b365f086d3ccf34f64c47503f565</a>
-<blockquote>
-<p>
- Fix documentation for moved display device test.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-09 11:54: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=8747ffd4e32faab3fd08b48bc443d4094ae21a5f">8747ffd4e32faab3fd08b48bc443d4094ae21a5f</a>
-<blockquote>
-<p>
- Documentation fix - gdevdsp.h is no longer in base<br>
-<br>
- The links to gdevdsp.h in use.htm were (mostly) referencing base when<br>
- in fact the file is in the devices sub-directory.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-01 18:28: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=a5185dc45dd8c1981fbe5f46a0577ec0378bf449">a5185dc45dd8c1981fbe5f46a0577ec0378bf449</a>
-<blockquote>
-<p>
- Fix compositor operation with subclassing.<br>
-<br>
- Compositors/PS2Write/Subclassing/Clist interact badly, due to the need<br>
- for the subclass code to 'tightly' wrap the original device, rather<br>
- than wrapping the created compositor.<br>
-<br>
- Use a new gxdso to handle the insertion of the device lower down the<br>
- device chain.<br>
-<br>
- This frees the subclass device of the need to know how to insert itself<br>
- into different types of device.<br>
-<br>
- Unfortuntely, the pdf14clist devices, when popped, assume that they<br>
- tightly wrap the actual clist device. This causes SEGVs when there<br>
- is actually a subclass device in the way.<br>
-<br>
- Accordingly, we update that code to find the correct clist device<br>
- in the stack, by using a new gxdso added for this purpose.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-04 09:27:34 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8fe5fb55424ebcc3ed66e8ce9a0fbfaac57aaa85">8fe5fb55424ebcc3ed66e8ce9a0fbfaac57aaa85</a>
-<blockquote>
-<p>
- Do not allow psd devices to change color model<br>
-<br>
- This keeps the psdcmyk device cmyk based and the psdrgb device rgb based.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-03 13:08:34 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8d95baab43318d1feecb70ee326734a883545484">8d95baab43318d1feecb70ee326734a883545484</a>
-<blockquote>
-<p>
- Fix erasepage_optimization device to allow for other subclass devices.<br>
-<br>
- The epo device assumed that it was the current device, then checked the child<br>
- of that device to decide if it could optimize. If another subclass device was<br>
- the current device the decision could be invalid.<br>
-<br>
- Note that the comparison of the child's fillpage proc is not ideal, but the<br>
- change to that is more involved and risky, and left for a subsequent change.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-01 10:26:57 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a3dd047a07ed3f24bd388b72432990d9cd508fb">7a3dd047a07ed3f24bd388b72432990d9cd508fb</a>
-<blockquote>
-<p>
- Fix page independence logic on the examples PostScript files.<br>
-<br>
- Back in 2001, commit f78b0481 added save/restore around the examples files,<br>
- but did not follow the recommendations from the PostScript Language Reference<br>
- Manual about save/restore and page independence and Technical note #5001.<br>
- The PLRM states (in section 3.7.3): &quot;Each page has a save at the beginning<br>
- and a restore at the end, immediately before the showpage operator.&quot;<br>
-<br>
- This fixes the files, and allows them to work properly with usage that<br>
- expects correct page independence including -sNupControl=WxH and the use<br>
- of setpagedevice BeginPage/EndPage actions.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-28 08:20:57 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d9a13c96f9ac0cfcaaa843b7e51780de114cf48a">d9a13c96f9ac0cfcaaa843b7e51780de114cf48a</a>
-<blockquote>
-<p>
- NupControl improvements to prevent save/restore problems.<br>
-<br>
- The NupControl string needs to be a reference counted to work with save/<br>
- restore, and when the parameter is changed the new value needs to be<br>
- propagated to children devices. The structure containing the string is<br>
- adpated (simplified slightly) from the PageList implementation.<br>
-<br>
- Note that the parents and children references must be included in the ref_count<br>
- when the NupControl structure is updated (example if 'epo' is installed, when<br>
- it uninstalls itself, cannot free the the structure when it does rc_decrement).<br>
-<br>
- Minor comment change to devices/gdevbit.c to change NupList to NupControl.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-03 10:29:33 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=648a17ed91e089c11621053201c97c93304086c9">648a17ed91e089c11621053201c97c93304086c9</a>
-<blockquote>
-<p>
- Update gen_ordered to provide improved debug output<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-03 12:28:02 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=359cf3ce11c32a5c05c24028d8785902799cb2fc">359cf3ce11c32a5c05c24028d8785902799cb2fc</a>
-<blockquote>
-<p>
- Add another nmake variant.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-02 15:26:24 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f74dcd064d5de5e13ad907d7ac270bc82bb7858b">f74dcd064d5de5e13ad907d7ac270bc82bb7858b</a>
-<blockquote>
-<p>
- Extract build: Ensure zlib is used as an include path for extract.<br>
-<br>
- Without this, the Windows build fails, and (presumably) the linux<br>
- build is picking up the system zlib.h.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-02 16:33:13 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4698574e2711da90888915f0c5a7dc4644153689">4698574e2711da90888915f0c5a7dc4644153689</a>
-<blockquote>
-<p>
- History/News updates<br>
-<br>
- And add an html link target for BlackText<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-02 09:21:58 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=590d3744111e267e2cebc09f3f7f98e6410704be">590d3744111e267e2cebc09f3f7f98e6410704be</a>
-<blockquote>
-<p>
- Update changelog and dates for 9.54.0 RC 1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-02 15:25:21 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db7f4bfc013549b22d8c30fbb75fc639bfb35799">db7f4bfc013549b22d8c30fbb75fc639bfb35799</a>
-<blockquote>
-<p>
- MSVC build: Detect and use 'extract' directory if it exists.<br>
-<br>
- This can be overridden by setting EXTRACT_DIR.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-02 12:20:24 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f11ff15600c9d6ed8032f671f2e693388d01cc1">4f11ff15600c9d6ed8032f671f2e693388d01cc1</a>
-<blockquote>
-<p>
- Check for extract in a &quot;default&quot; location<br>
-<br>
- i.e. ghostpdl/extract<br>
-<br>
- as well as still allowing --with-extract-dir for custom locations.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-02 12:23: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=6ac61452f9717536430a315fc832b5c64b3c02eb">6ac61452f9717536430a315fc832b5c64b3c02eb</a>
-<blockquote>
-<p>
- Fix tessocr.cpp building on linux.<br>
-<br>
- Missing include file.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-02 09:17:53 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6425f74266dd66f6064dc8f24d0b827e39a18855">6425f74266dd66f6064dc8f24d0b827e39a18855</a>
-<blockquote>
-<p>
- Tweaks and corrections for News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-01 11:17:29 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59eea43bf3f3e09182c0457d94b91c347f54bfbd">59eea43bf3f3e09182c0457d94b91c347f54bfbd</a>
-<blockquote>
-<p>
- Fix seg faults in subclassing<br>
-<br>
- Commit a754bd375a625368567947b1e1b77ce3e5c06a3f fixed a different class<br>
- of seg faults, but unfortunately removed a crucial line of code.<br>
-<br>
- When the child device has pushed a compositor, we still need to check<br>
- to see if the compositor is pointing at the child device. If it is not<br>
- then the compositor must have pushed more than a single device, so it<br>
- is not safe to behave as if the target of the compositor is our child<br>
- device.<br>
-<br>
- Originally I had hoped to walk down the forwarding devices until we<br>
- reach our device, but the actual behaviour of the pdf14 device in<br>
- combination with the clist, when the final device is ps2write renders<br>
- that all but impossible, as well as unnecessary.<br>
-<br>
- In this case the compositor action starts by defining a new device,<br>
- It then pushes a pdf14_accum device (there are 3, one per device space)<br>
- it then pushes the pdf14clist device in front of that. Finally it turns<br>
- the device it first created into a forwarding device, and points its<br>
- target at the original device.<br>
-<br>
- So we return with 3 new devices pushed, not just one. However, the<br>
- final forwarding device is in fact forwarding to the subclassing device<br>
- and the device reference counting magic is applied to the forwarding<br>
- device, which means we don't need to dance around with the references<br>
- to the subclassing device and child.<br>
-<br>
- We could detect this condition by checking the name of the target device<br>
- of the pdf14clist forwarding device, but that isn't really any better<br>
- than simply assuming that the compositor takes care of inserting new<br>
- devices correctly. The pdf14_accum devices are not forwarding devices,<br>
- they store the pdf14 device in a member called saved_pdev14, so we can't<br>
- readily follow that either. Finally there is no way to determine if a<br>
- device is a forwarding device, or a gx_device_pdf14_accum type which<br>
- limits the amount of checking we cna perform.<br>
-<br>
- This is an interim commit to work around the problem, because we are<br>
- about to do a release. A better fix which eliminates all (we hope)<br>
- of the hidden assumptions and magic knowledge in the code here<br>
- will be committed shortly, but may be too risky for the release.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-01 14:35:15 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=109fb95822a5c4fa6d7dc99ed120149acafd8341">109fb95822a5c4fa6d7dc99ed120149acafd8341</a>
-<blockquote>
-<p>
- Edit release highlights text<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-01 11:58: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=79d04193b05200e1dd606c583c0b4e0b46520217">79d04193b05200e1dd606c583c0b4e0b46520217</a>
-<blockquote>
-<p>
- Tidy up/add labels for URL destinations<br>
-<br>
- A few in VectorDevices.htm were wrong, and I added one in that file and a couple<br>
- in Use.htm for convenience.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-03-01 13:01:02 +0000
-</strong>
-<br>Julian Smith &lt;julian.smith@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a3a11e8e9a1420702867afdd555dff62ab7ba20">6a3a11e8e9a1420702867afdd555dff62ab7ba20</a>
-<blockquote>
-<p>
- doc/VectorDevices.htm: added information about DOCX device.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-25 09:36:18 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa775ffdd2ab6dff3b3178f9d36975308eeb9893">fa775ffdd2ab6dff3b3178f9d36975308eeb9893</a>
-<blockquote>
-<p>
- Add documentation for NupControl (N-up printing) feature.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-27 14:51:38 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f06760e64c088ea24cd6a41c07cb459ecc690b05">f06760e64c088ea24cd6a41c07cb459ecc690b05</a>
-<blockquote>
-<p>
- Add Colorant name for HalftoneType 5 components to -Zh output<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-26 08:03:56 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e30bb81fae075519db85af1bc7fb1658891627d">1e30bb81fae075519db85af1bc7fb1658891627d</a>
-<blockquote>
-<p>
- Bug 703273: Prioritise Nonsymbolic over Symbolic font flag<br>
-<br>
- The font in this PDF has it descriptor flags set to 36, that is bit 3 (Symbolic)<br>
- and bit 6 (Nonsymbolic) are both set. Since the two flags are mutually exclusive<br>
- this is clearly broken!<br>
-<br>
- Previously, we only test the Symbolic flag, since !Symbolic should imply<br>
- Nonsymbolic, which caused us to use the wrong encoding scheme.<br>
-<br>
- Now, we'll act on the Symbolic flag iff the Nonsymbolic flag is not set.<br>
-<br>
- (Originally a mupdf report, that also exhibited in Ghostscript).<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-26 09:38:27 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5d0bd867b7d9fce50119adeae293568375fa8847">5d0bd867b7d9fce50119adeae293568375fa8847</a>
-<blockquote>
-<p>
- Fix a few typos in the documentation of UseOCR for pdfwrite<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-22 19:57:35 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1aa6a230ecc56ee3cb02459fbf6fc5e400e26eba">1aa6a230ecc56ee3cb02459fbf6fc5e400e26eba</a>
-<blockquote>
-<p>
- Bug 703265: Tweak create_compositor device method.<br>
-<br>
- Update create_compositor device method, so that it always returns<br>
- the compositor device (or the leaf device if there is no specific<br>
- compositor device). The device now returns 1 if we created a<br>
- compositor device to wrap the given device.<br>
-<br>
- This should enable us to identify exactly the cases where forwarding<br>
- devices need to update which device they forward to.<br>
-<br>
- In particular, this allows us to remove the horribly fragile code<br>
- in apply_create_compositor in gxclrast.c, and to ensure that we<br>
- correctly identify the 'new compositor' case.<br>
-<br>
- This avoids us sending stuff to the wrong device, and having to<br>
- cope with a slew of warnings.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-25 09:16: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=8bc7ba4ba7df15310d406d5a1d8f6b755b04d13b">8bc7ba4ba7df15310d406d5a1d8f6b755b04d13b</a>
-<blockquote>
-<p>
- Update dates/docs for 9.54.0 RC1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-22 18:53: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=5fc905ca8f04aa2a1088c3af635fd38bf9c8c3a0">5fc905ca8f04aa2a1088c3af635fd38bf9c8c3a0</a>
-<blockquote>
-<p>
- Remove Luratech integration code/makefiles<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-22 14:11:46 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af92546c044b18a1796e269aba58c246ca977290">af92546c044b18a1796e269aba58c246ca977290</a>
-<blockquote>
-<p>
- Change GS_PRODUCT string, and dates for release<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-22 10:32:13 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1430230bdf35928e5fb75eba631db3e5b89ce845">1430230bdf35928e5fb75eba631db3e5b89ce845</a>
-<blockquote>
-<p>
- Bug 703589: handle overlapping ranges in TTF format 4 cmaps<br>
-<br>
- The fonts embedded in this file contain a large number of overlapping/repeated<br>
- ranges in the format 4 cmap table definition - which is *strictly* not permitted<br>
- according to the spec.<br>
-<br>
- For example:<br>
- scode=117 ecode=117<br>
- scode=117 ecode=117<br>
- scode=118 ecode=118<br>
- scode=118 ecode=118<br>
- scode=119 ecode=119<br>
- scode=119 ecode=119<br>
- scode=120 ecode=120<br>
- scode=120 ecode=120<br>
- scode=121 ecode=121<br>
- scode=121 ecode=121<br>
-<br>
- Turns out, other consumers use the *first* mapping they encounter where, because<br>
- we use a Postscript dictionary to store the cmap table, later definitions<br>
- overwrite earlier ones.<br>
-<br>
- Resolved by checking if the key already exists in the dictionary, and not<br>
- overwriting it if it does.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-10 09:35: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=9c7347c8e1bb146b9ae27b35b8207e10a7c5dc43">9c7347c8e1bb146b9ae27b35b8207e10a7c5dc43</a>
-<blockquote>
-<p>
- Bug 703326: Create a new clip path for clist typed image handling<br>
-<br>
- Stupid fuzzing file uses a Type 3 font with a sampled image in the glyph<br>
- proc. The image uses a procedure as a data source. The glyph proc does<br>
- gsave, and the image data source procedure does a grestore. So by the time we<br>
- clean up the image &quot;samples&quot;, the gstate and the clip path it contains have<br>
- gone. So the image enumerator's reference to the clip path is left dangling.<br>
-<br>
- Copying, rather than referencing, that clip path solves the crash.<br>
-<br>
- Fixes oss-fuzz issue: 26987<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-19 17:34:35 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c7a78d3e2ae6a3053827e915735e29eb16e12ba">2c7a78d3e2ae6a3053827e915735e29eb16e12ba</a>
-<blockquote>
-<p>
- Catch potential NULL derefence in gdev_prn_close.<br>
-<br>
- Thanks to Robin for spotting this.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-19 11:02:40 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fc5aa3b392cbd7c879b049d805a2afd158a05eb6">fc5aa3b392cbd7c879b049d805a2afd158a05eb6</a>
-<blockquote>
-<p>
- Fix buffer overrun in ASCIIHexEncode<br>
-<br>
- This exhibited as a memory corruption error (buffer overrun) in pdfi.<br>
-<br>
- The ASCIIHexEncode filter is required to write linfeed characters to the<br>
- output at least every 80 (output characters). Ghostscript chooses to do<br>
- so every 64 characters. So every 64 characters the filter emits a<br>
- linefeed, crucially without checking whether there is room in the<br>
- output buffer.<br>
-<br>
- In order to determine how many linefeed characters we are going to need<br>
- to write into any given output buffer we divide the number of characters<br>
- in the output buffer by 65 (64 characters + linefeed), taking into<br>
- account any character slaready emiitted (stored as 'count' in the stream<br>
- state). We subtract that from the size of the output buffer, in order<br>
- to ensure that there is enough spare space for the linefeeds.<br>
-<br>
- Unfortunately, this is not sufficient. Consider an output buffer 194<br>
- bytes in size, on the first pass. We divide that by 65, which tells us<br>
- that 2 complete buffers will fit, so we need to reserve space in the<br>
- output for 2 bytes. We subtract 2 from the count, giving 192, We then<br>
- proceed to write the output data. We write 64 bytes of data, then a<br>
- linefeed, then 64 bytes of data, then a linefeed, then 64 bytes of data.<br>
- Total 194 bytes.<br>
-<br>
- At this point we have exhausted the output buffer, but because we have<br>
- written 64 bytes, we unconditionally write a linefeed. This is written<br>
- one byte beyond the end of the buffer.<br>
-<br>
- There are many ways to address this but I've chosen to change the<br>
- divisor from 65 to 64. This may mean that occasionally we will write one<br>
- input character (2 output characters) less than the maximum possible<br>
- to the output, but it will prevent the possibility of a buffer overrun.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-18 17:59:26 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d4c0981839bb2194040a9d15c8772e266ae235e3">d4c0981839bb2194040a9d15c8772e266ae235e3</a>
-<blockquote>
-<p>
- Fix bug 703557. Replace .sort procedure for use in SAFER mode<br>
-<br>
- Thanks to Peter Cherepanov for this patch.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-18 08:19:45 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a32419cebfe2db81aa5e838b95e5770241a22fb1">a32419cebfe2db81aa5e838b95e5770241a22fb1</a>
-<blockquote>
-<p>
- Add Page Spot color list to output info<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-18 08:07:22 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=32c912d6d6b12956f69056c0e7f3050c5aabf2d4">32c912d6d6b12956f69056c0e7f3050c5aabf2d4</a>
-<blockquote>
-<p>
- Address Coverity 365984 -- 'code' variable set but not used before changed.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-18 15:52:00 +0000
-</strong>
-<br>Julian Smith &lt;julian.smith@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4fa213b9cd6f310bc6dd236ecce2d549ed3c5a55">4fa213b9cd6f310bc6dd236ecce2d549ed3c5a55</a>
-<blockquote>
-<p>
- devices/vector/gdevdocxw.c: default to spacing=0 when calling extract_process().<br>
-<br>
- This gives better output, e.g. for zlib.3.pdf.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-16 15:13:40 +0000
-</strong>
-<br>Julian Smith &lt;julian.smith@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cda1ad8f402829c4677f73d8f805b119632dad5f">cda1ad8f402829c4677f73d8f805b119632dad5f</a>
-<blockquote>
-<p>
- devices/vector/gdevdocxw.c: fixed creation of .docx when not using file-per-page.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-16 15:01:27 +0000
-</strong>
-<br>Julian Smith &lt;julian.smith@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e9c31c3b6660d50afbca498ceddf0179ca2540c">4e9c31c3b6660d50afbca498ceddf0179ca2540c</a>
-<blockquote>
-<p>
- toolbin/localcluster/clusterpush.pl: have rsync expand links if product is extractgs.<br>
-<br>
- This allows one to have ghostpdl:extract be a soft link, e.g.:<br>
- extract -&gt; ../mupdf/thirdparty/extract<br>
-<br>
- Also use rsync -i instead of -v if $(verbose) is set so that one can see<br>
- exactly what files are being transferred etc.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-16 14:58:47 +0000
-</strong>
-<br>Julian Smith &lt;julian.smith@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=895c5bc12814d4106a106afaddea5dcdd2d0519d">895c5bc12814d4106a106afaddea5dcdd2d0519d</a>
-<blockquote>
-<p>
- toolbin/localcluster/clusterpush.pl: fix exclude of extract binaries within ghostpdl.<br>
-<br>
- The previous exclude arg only worked when extract directory was<br>
- thirdparty/extract inside mupdf (typically a submodule).<br>
-<br>
- Also added exclusion of extract/test/generated/ to avoid locally-generated<br>
- files being uploaded.<br>
-<br>
- Restored exclude of /src/build/ because needed for product=extract.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-16 14:55:36 +0000
-</strong>
-<br>Julian Smith &lt;julian.smith@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e06b811daafbc95487727f88b9ec7398a250963">2e06b811daafbc95487727f88b9ec7398a250963</a>
-<blockquote>
-<p>
- psi/msvc.mak: remove 'Not building with extract' diagnostic.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-18 16:44: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=fafb962c4f57b4b7d8e724414e3762f209099b99">fafb962c4f57b4b7d8e724414e3762f209099b99</a>
-<blockquote>
-<p>
- Windows gpcl6/ufst project: use better/correct targets<br>
-<br>
- Firstly, the recursive call to nmake was using the wrong target name (an<br>
- internal use target), so fix that to use the &quot;real&quot; target.<br>
-<br>
- Secondly, give the &quot;real&quot; target a better name, more in keeping with other<br>
- equivalents.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-18 09:51:01 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a3cfccc2401222818dd4d587fd5c695811427bc4">a3cfccc2401222818dd4d587fd5c695811427bc4</a>
-<blockquote>
-<p>
- Initialise some PDF-specific portions of the graphics state<br>
-<br>
- The text rendering matrix and text line matrix, which are PDF-specific,<br>
- were not being initialised when the graphics state was created. This<br>
- should not be a problem in normal operation because the PDF interpreter<br>
- should always initialise them before use.<br>
-<br>
- However, during development on pdfi it did show up so this commit<br>
- initialises the matrices to the identity.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-17 23:01:03 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=72fcae41c44e4cf33e57b34b748521a00612be21">72fcae41c44e4cf33e57b34b748521a00612be21</a>
-<blockquote>
-<p>
- Bug 703578 : XPS to PDF missing stroke<br>
-<br>
- Caused by my &quot;fix&quot; for the pattern issue. I was inadvertently setting<br>
- ca and CA to 0 during the gradient strokes.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-17 13:05:35 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=331fcb49b62a615976711cccdd3ff9796152a323">331fcb49b62a615976711cccdd3ff9796152a323</a>
-<blockquote>
-<p>
- Fix bug 703245: bitmap size exceeds buffer.<br>
-<br>
- The pdf14 compositor changes the color depth to 8 for a SMask, but the<br>
- compositor actions were not being put in all the bands needed. In this<br>
- case the copy_color_alpha was output from the interpolation logic because<br>
- the image gridfitting expanded the image. Fix it by expanding the top and<br>
- bottom limits for the &quot;temp_cropping&quot; which controls the RECT loop writing<br>
- the compositor info to the bands.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-17 19:32:11 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8608819c8531174290d6075ad5747bd0b0f32d4b">8608819c8531174290d6075ad5747bd0b0f32d4b</a>
-<blockquote>
-<p>
- Bug 703577: Correctly initialise texture data pointer.<br>
-<br>
- The ROP in use was failing to initialise the texture data pointer.<br>
- Amazing that this doesn't show more problems.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-17 08:16:25 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a28c4d3d22156086db3b53011824a88847d114e1">a28c4d3d22156086db3b53011824a88847d114e1</a>
-<blockquote>
-<p>
- Minor improvement to gx_ht_construct_threshold debug<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-16 22:35:57 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a3df79b2b0e0725753a0eac84fb205341cc9fed">7a3df79b2b0e0725753a0eac84fb205341cc9fed</a>
-<blockquote>
-<p>
- Bug 703404: XPS to pdfwrite patterns<br>
-<br>
- Patterns that are filled with glyphs and then subsequently<br>
- filled with another pattern (Visual brush in XPS) was not<br>
- working when going to pdfwrite due to the fact that<br>
- gs_text_begin gets called by the XPS interpreter<br>
- before we have finished the pattern fill of the glyph.<br>
- This ends up referencing the pattern that is not done<br>
- which ends badly for high level patterns. Instead<br>
- if we are already in a high level pattern, set the color<br>
- to just a gray. Then after the gs_text_begin, the XPS<br>
- interpreter sets the brush to the visual brush which is<br>
- subsequently collected. Fixing this, has revealed another<br>
- XPS to PDF bug where we are not doing shading fills of glyphs<br>
- correctly (at least when dealing with patterns).<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-17 17:28: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=66200b6fafe8b4de6fd11d1b38ccb85eb3d37d83">66200b6fafe8b4de6fd11d1b38ccb85eb3d37d83</a>
-<blockquote>
-<p>
- Add the cup &quot;images&quot; directory back so the docs work<br>
-<br>
- The cups source has shtml documentation dotted through it, and that references<br>
- images in the &quot;images&quot; directory (which we removed originally, thinking it<br>
- wasn't necessary).<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-17 16:04:27 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=82dce7f8f6b5218f7943eadff0f01d0e278850fa">82dce7f8f6b5218f7943eadff0f01d0e278850fa</a>
-<blockquote>
-<p>
- Update lcms2mt to lcms2 2.12.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-16 14:28: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=5882f2d765a9348c6f6e2cc45353a06924930c88">5882f2d765a9348c6f6e2cc45353a06924930c88</a>
-<blockquote>
-<p>
- Chunk allocator was using unsigned int rather than size_t.<br>
-<br>
- Both in the main allocator routine and in the structures. Solved<br>
- here.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-15 17:22:28 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a634d187722befab735da23957d938f156b6cf8f">a634d187722befab735da23957d938f156b6cf8f</a>
-<blockquote>
-<p>
- Change macro names to be less confusing.<br>
-<br>
- The graphics state contains pairs of color/colorspaces. The 0th ones<br>
- are known as 'current' ones. The 1st ones have historically been known<br>
- as 'alt' ones.<br>
-<br>
- This nomenclature is held to be confusing, as 'alternate'<br>
- colors/colorspaces mean something quite different. We therefore update<br>
- the macros etc to refer to these as 'swapped' ones, which fits better<br>
- into our usage.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-15 16:26:18 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a67862f2f7ec3826ac1f55947ebdbfe740c1829f">a67862f2f7ec3826ac1f55947ebdbfe740c1829f</a>
-<blockquote>
-<p>
- Fix 'cast away const' warning in gdevplnx.c<br>
-<br>
- We do this by splitting gstate_clone into gstate_clone_for_gsave<br>
- and gstate_clone_for_gstate. The latter can have the source gstate<br>
- as being const, as you'd expect.<br>
-<br>
- This enables gs_gstate_copy to similarly take a const gstate, as<br>
- you'd expect.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-15 17:09:20 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4618b1dea2e55fa0a39f8fa216e4965785ed8d21">4618b1dea2e55fa0a39f8fa216e4965785ed8d21</a>
-<blockquote>
-<p>
- Squash warnings in gdevwpr2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-15 16:24:41 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83118eaa3e8733d8755eef21b3b404ce0ee97123">83118eaa3e8733d8755eef21b3b404ce0ee97123</a>
-<blockquote>
-<p>
- Add cs_adjust_altcounts_icc.<br>
-<br>
- This enables us to avoid swapping colors twice in every<br>
- gstate_clone.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-16 19:58:28 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=564e9365b8803903d077cd7deca247e65d8f7a29">564e9365b8803903d077cd7deca247e65d8f7a29</a>
-<blockquote>
-<p>
- Memento fix: Memento_strdup was inconsistently defined.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-15 19:09:50 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f95b2611921546b424d899a5828341f6c4c9a52a">f95b2611921546b424d899a5828341f6c4c9a52a</a>
-<blockquote>
-<p>
- Add 'extractmu' and 'extractgs' to clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-09 17:48:35 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eff4e8fca8ebbc75b00e7c1d2e672d17090b2222">eff4e8fca8ebbc75b00e7c1d2e672d17090b2222</a>
-<blockquote>
-<p>
- Quell Memento warnings in debug non-Memento builds.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-15 12:34:05 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=19baed479febdc6372c7b3fccf6e97d71fca1b95">19baed479febdc6372c7b3fccf6e97d71fca1b95</a>
-<blockquote>
-<p>
- Squash warnings in DEBUG code in gsalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-11 09:27: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=1efe1f702f9723dec2803395cf4679593987c422">1efe1f702f9723dec2803395cf4679593987c422</a>
-<blockquote>
-<p>
- Bug 703550: handle escaped percent chars in file access controls<br>
-<br>
- The separating devices make a (fairly blunt) effort to avoid attempting to use<br>
- proscribed characters in file names for separations (for example, '/', '\',<br>
- etc). As part of this some characters can be replaced with escaped percent<br>
- chars - so the single percent character survives a later call to a formatted<br>
- string function (sprintf).<br>
-<br>
- This ended up foxing the file access validation code which added the fully<br>
- escaped file name string to the permit write table, but later attempted to<br>
- validate a file name post sprintf, where the escaping had been undone.<br>
-<br>
- So, add code to remove escape '%' characters before adding the string to the<br>
- file access permit lists.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-12 14:33:58 +0000
-</strong>
-<br>Peter Cherepanov &lt;sphinx.pinastri@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0ca4ae94020a1e3b48c337759ccb9fc0b3af61ec">0ca4ae94020a1e3b48c337759ccb9fc0b3af61ec</a>
-<blockquote>
-<p>
- Bug 702910: Fix mkromfs for THREADSAFE build<br>
-<br>
- Since local versions of errprintf_nomem() and errprintf() are mostly<br>
- identical, we can just call errprintf() with a dummy mem argument.<br>
-<br>
- The &quot;mem&quot; argument for errprintf() inside GhostPDL is used to ensure<br>
- the error prints are directed to/through the correct gs_lib_ctx<br>
- instance for the current thread<br>
-<br>
- This is safe because, mkromfs is only using during the build, and won't<br>
- ever implement threading, thus has no need to worry about the extra<br>
- parameter.<br>
-<br>
- (slightly tweaked patch to keep working without THREADSAFE)<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-12 14:30:44 +0000
-</strong>
-<br>Peter Cherepanov &lt;sphinx.pinastri@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=28d3245fbaff5f6edc74fe3fc21237d69672e947">28d3245fbaff5f6edc74fe3fc21237d69672e947</a>
-<blockquote>
-<p>
- Bug 703294: Fix Ghostscript build for Android<br>
-<br>
- Header files shifted around so that the redefinition of printf happens<br>
- after cdefs.<br>
-<br>
- Also removes redundant CONTDEVH definition from contrib/contrib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-23 14:09:31 +0000
-</strong>
-<br>Julian Smith &lt;julian.smith@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b151406bbf22fb9001895f856168166f2ecf7fe2">b151406bbf22fb9001895f856168166f2ecf7fe2</a>
-<blockquote>
-<p>
- Added docxwrite device; uses extract library to write docx output.<br>
-<br>
- Summary:<br>
- This adds a new docxwrite device which generates docx files.<br>
-<br>
- Unlike the txtwrite device, we don't output xml for later use by<br>
- extract-exe or store information about spans in arrays. Instead we call<br>
- extract functions such as extract_add_char() directly.<br>
-<br>
- Code changes:<br>
- Have moved txtwrite and docxwrite common code into new devices/vector/doc_common.{c,h}.<br>
-<br>
- Shared types and functions are currently:<br>
- txt_glyph_width_t<br>
- txt_glyph_widths_t<br>
- txt_glyph_widths()<br>
- txt_get_unicode()<br>
- txt_char_widths_to_uts()<br>
- txt_calculate_text_size()<br>
-<br>
- Building:<br>
- By default we do not build with Extract and there will be no docxwrite<br>
- device in the final executables.<br>
-<br>
- To build with Extract, specify the location of the extract checkout to<br>
- build and link with.<br>
-<br>
- Unix:<br>
- ./autogen.sh --with-extract-dir=&lt;extract-dir&gt;<br>
-<br>
- Windows:<br>
- Set environmental variable EXTRACT_DIR=&lt;extract-dir&gt; when building,<br>
- e.g.:<br>
- EXTRACT_DIR=&lt;extract-dir&gt; devenv.com windows/GhostPDL.sln /Build Debug /Project ghostscript<br>
-<br>
- On both Unix and Windows we exit with an error message if the specified<br>
- location does not exist.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-12 03:39:30 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=833dc8c9ffde58f001308b303c8d7956107633a1">833dc8c9ffde58f001308b303c8d7956107633a1</a>
-<blockquote>
-<p>
- Fix build failure with HAVE_VALGRIND and not PACIFY_VALGRIND<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-12 15:25:56 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=180419375973b9ce4664286a67106d712260ef7f">180419375973b9ce4664286a67106d712260ef7f</a>
-<blockquote>
-<p>
- Remove .setpdfwrite from the documentation<br>
-<br>
- Deprecated in 9.50 removed in the next release (9.54)<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-12 10:34: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=7861fcad13c497728189feafb41cd57b5b50ea25">7861fcad13c497728189feafb41cd57b5b50ea25</a>
-<blockquote>
-<p>
- oss-fuzz 30715: Check stack limits after function evaluation.<br>
-<br>
- During function result sampling, after the callout to the Postscript<br>
- interpreter, make sure there is enough stack space available before pushing<br>
- or popping entries.<br>
-<br>
- In thise case, the Postscript procedure for the &quot;function&quot; is totally invalid<br>
- (as a function), and leaves the op stack in an unrecoverable state (as far as<br>
- function evaluation is concerned). We end up popping more entries off the<br>
- stack than are available.<br>
-<br>
- To cope, add in stack limit checking to throw an appropriate error when this<br>
- happens.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-11 22:32:50 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea1624205c8e1ca936bd38a6095a0dd1880e7287">ea1624205c8e1ca936bd38a6095a0dd1880e7287</a>
-<blockquote>
-<p>
- Fix hang condition detected on Windows release build.<br>
-<br>
- The NupControl commit changed 'gx_device_set_hwsize_from_media' to call the<br>
- dev_spec_op of the parent device, but the body of the while loop to find the<br>
- uppermost parent could hang.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-11 11:12:34 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=76b7cdd9c407afc5c620dbfb79770bb5583cf532">76b7cdd9c407afc5c620dbfb79770bb5583cf532</a>
-<blockquote>
-<p>
- Pad PDF14 buffer allocations when building with CAL.<br>
-<br>
- This allows for SSE/AVX to overread slightly when reading<br>
- 16 bytes at a time.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-10 18:07:07 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5e44d6709642727ee524cccd2b5ab09f2e48572">b5e44d6709642727ee524cccd2b5ab09f2e48572</a>
-<blockquote>
-<p>
- oss-fuzz 30795: handle remap_color failure in clist_begin_typed_image<br>
-<br>
- In this case &quot;remap_color&quot; is gx_concretize_ICC() and the link profile<br>
- creation fails. Previously we were ignoring the error, and trying to use the<br>
- resulting (invalid) color space.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-09 14:17: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=7351373f5e3e8d9cd8c75be7d176570f95bd7c97">7351373f5e3e8d9cd8c75be7d176570f95bd7c97</a>
-<blockquote>
-<p>
- Add a VS project to build gpcl6 with ufst<br>
-<br>
- (stemmed from Bug 703415)<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-09 14:08:54 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a92c21b4a842cfa90134eb46544d142cc4c13d0">7a92c21b4a842cfa90134eb46544d142cc4c13d0</a>
-<blockquote>
-<p>
- Bug 702362: &quot;make soinstall&quot; install GhostPDL<br>
-<br>
- If available, have &quot;soinstall&quot; the libs and binaries for gpcl6, gxps and<br>
- gpdl.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-10 16:46:16 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2abffa72c2ac815df38927431744232ae421d42d">2abffa72c2ac815df38927431744232ae421d42d</a>
-<blockquote>
-<p>
- Fix CAL CFLAGS.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-10 16:03:40 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7395ad17d12b0c8b420fd7a8d139baf52d9791e0">7395ad17d12b0c8b420fd7a8d139baf52d9791e0</a>
-<blockquote>
-<p>
- Update docs.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-10 14:24:24 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a469b14c88409b96614e6b8abe2b645078ded3a">7a469b14c88409b96614e6b8abe2b645078ded3a</a>
-<blockquote>
-<p>
- Bug 703555 : Seg fault in pdf14_dev_spec_op<br>
-<br>
- So the issue is that the pdf14 clist device was not<br>
- doing its clean-up and set to forwarding when there was an<br>
- abort for the device sent by the interpreter.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-10 14:44:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9699aea5cf6491106a2ad1be260d9eb2e85903c3">9699aea5cf6491106a2ad1be260d9eb2e85903c3</a>
-<blockquote>
-<p>
- Remove .setpdfwrite<br>
-<br>
- This has basically done nothing for years and in September 2019 I<br>
- added a warning message that it was deprecated and would be removed.<br>
-<br>
- Time to make good on that promise.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-03 09:25:37 -0700
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6f6c88f92f98d0f8340c29201c7536ec1a521efd">6f6c88f92f98d0f8340c29201c7536ec1a521efd</a>
-<blockquote>
-<p>
- Sort tifftop.c dependency on jpeg headers<br>
-<br>
- Spotted in testing the Apple M1 Mac builds<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-07 19:19: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=141e5067e40d25ed3aa191589d4a325941efa57a">141e5067e40d25ed3aa191589d4a325941efa57a</a>
-<blockquote>
-<p>
- pdfwrite - don't try to linearize when the output file is not seekabkle<br>
-<br>
- No bug report. The linearization (-dFastWebView) 'feature' of pdfwrite<br>
- relies upon being able to seek in the output file. If we can't do that<br>
- then we can't linearize the file.<br>
-<br>
- If linearization is enabled, check the output file is seekable; if it<br>
- is not then warn the user and abort linearization.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-07 15:04: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=4ab5dd6c004a252e64f26d6238799004f70d4a35">4ab5dd6c004a252e64f26d6238799004f70d4a35</a>
-<blockquote>
-<p>
- pdfwrite - further checks on Title for PDF/A<br>
-<br>
- Bug #703486 &quot;PDF containing just a JPEG converted to PDF/A-1b fails rule 6.7.3-1&quot;<br>
-<br>
- The PDF file, produced by ImageMagick 7 has a /Title in the Document<br>
- Information dictionary which appears to be UTF-16BE encoded, but is<br>
- lacking the BOM. It also has a 2-byte NULL appended which seems likely<br>
- to be an error as well (PDF strings are not NULL-terminated).<br>
-<br>
- This is valid (if not useful) as a string with PDFDocEncoding, though<br>
- Acrobat displays an empty string in the Document Properties, but when<br>
- converted to a text string for the output Document Information<br>
- dictionary, and a UTF-8 string for the XMP, the two strings are not<br>
- byte-for-byte identical, resulting in a PDF/A validation error.<br>
-<br>
- Add some more checking for character codes which will result in UTF-8<br>
- and PDFDocEncoding strings which do not match (anything outside the<br>
- range 0x20 to 0x7F, or escaped).<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-06 12:56:36 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7e8b585e7577044dc1d6a9a36d715be12fc2524c">7e8b585e7577044dc1d6a9a36d715be12fc2524c</a>
-<blockquote>
-<p>
- Fix bug 703487. pageusesoverprint needs self-reference check for Parent.<br>
-<br>
- Ken's fix for bug 698372 is needed in the procedure that I added to check<br>
- for overprint usage.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-14 18:26:21 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=813b5f48e845d528d3070d9168aa51035a614c1c">813b5f48e845d528d3070d9168aa51035a614c1c</a>
-<blockquote>
-<p>
- Bug 695925: Implement overprint simulation for all devices<br>
-<br>
- This adds the capability to simulate overprint including that of<br>
- spot colors for all devices including gray and RGB devices. This<br>
- is achieved by having the PDF interpreter look if overprint<br>
- is present, the seting of -dOverprint (/simulate /enable /disable),<br>
- if the page has transparency, and if the page has spot colors. Depending upon<br>
- the color model of the device, and if transparency is present,<br>
- a special push of the pdf14 device may occur. The pdf14 device<br>
- buffer collects the data in a CMYK or CMYK+spots buffer and the<br>
- put_image method in the pdf14 device will map the buffer to<br>
- the target device color space. The code was tested with<br>
- devices that support and do not support spot colors, those that<br>
- support and do not support alpha channels, tag based devices,<br>
- gray, RGB, and CMYK devices. A special test file to check<br>
- multiple cases was added to the regression suite. By default<br>
- -dOverprint is set to /enable, which should result in the existing<br>
- behavior where by RGB and Gray devices do no show overprint or spot<br>
- colors and CMYK devices will handle CMYK overprinting and separation<br>
- devices will show spots and overprint of all colorants. With<br>
- -dOverprint set to /disable no device will show overprinting. With<br>
- -dOverprint set to /simulate all devices will show overprint and<br>
- spot colors. Ray Johnston did the work in the interpreter as<br>
- well as the device parameter default setup. I did the pdf14 device<br>
- changes and testing. Changes in a variety of locations were required<br>
- due to the fact that new combinations were encountered, for example<br>
- we had cases where devn colors were being used with a device that<br>
- supports tags (bitrgbtags device and pdf14 compositor setup for CMYK+spots).<br>
-<br>
- One file:<br>
- tests_private/xps/xpsfts-a4/fts_34xx.xps.pdf ppmraw 72 now produces<br>
- an error. This file should have been throwing an error all<br>
- along but was being quietly swallowed. Acrobat will not open<br>
- the created pdf file and throws and error. I will open a bug<br>
- for the issue as it is a problem with the XPS interpreter.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-05 11:59: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=0bd6877f480a84657696a80adc13f9c5485dd996">0bd6877f480a84657696a80adc13f9c5485dd996</a>
-<blockquote>
-<p>
- Remove vestigial documentation<br>
-<br>
- The NOCCFONTS feature was removed some years back and the documentation<br>
- removed from fonts.htm, but a vestige remained in use.htm.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-04 16:34:58 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8cac642a1caf0ff821b2f1f83ee322a1cffc9a3e">8cac642a1caf0ff821b2f1f83ee322a1cffc9a3e</a>
-<blockquote>
-<p>
- oss-fuzz 22842: sanity check the claimed number of objects in a PDF<br>
-<br>
- This test case is a file that we identify as a broken PDF, and attempt to<br>
- repair.<br>
-<br>
- As part of trying to repair the xref, we an extremely large value integer which<br>
- we take to mean the number of objects in the file, and then attempt to loop<br>
- over them. The result is, in practice, an endless loop.<br>
-<br>
- On the basis that the very barest PDF object:<br>
- 1 0 obj<br>
- endobj<br>
-<br>
- takes 15 bytes to define, we add a check: if the number of claimed objects is<br>
- greater than the number of bytes in the file divided by 15, then the number<br>
- is not to be trusted, and we dicard it.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-04 13:42: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=180f35cecf582c0cd321e5d5cd8e11c4304ec519">180f35cecf582c0cd321e5d5cd8e11c4304ec519</a>
-<blockquote>
-<p>
- oss-fuzz 25846: Store &quot;printable&quot; refs for errors<br>
-<br>
- When we get an op/dict/exec stack overflow error, we take a copy of the stack<br>
- in question, and store it in an array (or as much of it as we feasibly can).<br>
- That allows us to clear enough stack space to allow the error handler(s) to run<br>
- without losing the information needed to report the error.<br>
-<br>
- With the exec stack, however, that can (and usually does) include references to<br>
- &quot;internal&quot; objects, which are really just pointers to arbitrary C structures,<br>
- (t_struct and t_astruct ref types). Those can contain pointers referencing<br>
- objects of unrelated and uncertain lifespans, so persistent storage of them is<br>
- potentially problematic.<br>
-<br>
- So, when we create that array representation, replace every t_struct and<br>
- t_astruct object with a printable string representation.<br>
-<br>
- This isn't a big problem for speed because a) exec stack overflow is a rare<br>
- error b) for exec stack overflow, we already have to traverse the objects<br>
- checking for another condition, and c) we already do (basically) the same<br>
- conversion considerably later, for the benefit of the error handler.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-04 09:05: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=a9a440babc49ed54d0086cd9e5faa9bdd3452e51">a9a440babc49ed54d0086cd9e5faa9bdd3452e51</a>
-<blockquote>
-<p>
- Fix build failure<br>
-<br>
- gsparamx.c is now required in the &quot;base&quot; configuration, since it contains<br>
- function(s) now being called from gsdparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-04 08:30: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=f9583327eeaf733cf44eb02790994308d4b9e91b">f9583327eeaf733cf44eb02790994308d4b9e91b</a>
-<blockquote>
-<p>
- Fix Coverity ID C366347<br>
-<br>
- Removing some code revealed a pre-existing pointless operation; we were<br>
- setting the render mode twice.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-03 16:38:39 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6665826ff3b0ec30e3c084c5b550006a2b7c9bf5">6665826ff3b0ec30e3c084c5b550006a2b7c9bf5</a>
-<blockquote>
-<p>
- txtwrite - fix a load of memory leaks<br>
-<br>
- Noticed while working on some bug reports. The memory cleanup hadn't<br>
- been updated when a bunch of members were added to the tracking data.<br>
-<br>
- In addition the font name was allocated and recorded (and then over<br>
- written on the next pass) for every character in the text. Oops!<br>
-<br>
- All these are fixed here. I've run a couple of hundred random PDF<br>
- files from our test repository with memory leak checking and found<br>
- no leaks.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-02 19:15:44 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4021e019eaccffb809595b90d04626f337f5e237">4021e019eaccffb809595b90d04626f337f5e237</a>
-<blockquote>
-<p>
- Bug 703452: Add type checks for error dicts<br>
-<br>
- This is, at best, a theoretical problem now, but for extra safety, ensure the<br>
- values we read back from systemdict for the /gserrordict and /errordict keys<br>
- are actually dictionary objects before looking up the error key in them.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-02 19:06:12 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=32867dfea274afaf5e335ec8f2691b4cfed88b78">32867dfea274afaf5e335ec8f2691b4cfed88b78</a>
-<blockquote>
-<p>
- Bug 703454: Handle multiple CharString definitions<br>
-<br>
- The test file for this has a number of Type 1 fonts whose CharStrings<br>
- dictionary definitions contain more than one entry for several glyph names.<br>
- According to Postscript rules (which Type 1 fonts are supposed to follow),<br>
- defining a key/value pair for which the key already exists in the dictionary<br>
- should overwrite the earlier value - i.e. the later definition takes<br>
- precedence.<br>
-<br>
- It appears that the non-Postscript based implementations used in other<br>
- PDF consumers do not honor that, and the earlier definition ends up taking<br>
- precedence.<br>
-<br>
- To work around various other PDF embedded Type 1 font breakages, we push an<br>
- extra dictionary onto the dict stack which contains definitions for missing<br>
- procedures, and various other &quot;fixups&quot;.<br>
-<br>
- To work around this problem, we add a new definition of the Postscript &quot;def&quot;<br>
- operator which, *only* for the CharStrings dictionary, will not allow existing<br>
- keys to have their values replaced.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-01 10:22:03 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c23d68c1e8da7a4e4134b143f147427092b3d2f2">c23d68c1e8da7a4e4134b143f147427092b3d2f2</a>
-<blockquote>
-<p>
- Replace -dSimulateOverprint boolean with multi-valued -dOverprint<br>
-<br>
- Internally the name is changed to &quot;overprint_control&quot; which has enum values<br>
- of gs_overprint_control_t. This is in preparation for Michael Vrhel's<br>
- overprint simulation implementation.<br>
-<br>
- Documentation of the change and the new parameter specifics added to the<br>
- doc/Use.htm file. Also added change to gs_init.ps so that command line use<br>
- of -dSimulateOverprint=true maps to -dOverprint=/enable and similarly,<br>
- -dSimulateOverprint=false maps to -dOverprint=/disable with a warning.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-01 09:44:14 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=322d21b4c04d2f64583630de4b190ce8d3b0721d">322d21b4c04d2f64583630de4b190ce8d3b0721d</a>
-<blockquote>
-<p>
- Fix building mkromfs in a memento build<br>
-<br>
- Adding malloc_.h to gp_ntfs.c means it gets the memento redefinitions of<br>
- malloc/free. That causes missing symbols errors when gp_ntfs.c is used in the<br>
- mkromfs build. So (as we do for other such cases) add those missing symbols<br>
- to mkromfs.c.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-01 16:21:24 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=41130dd35b2dc43b07600b51d7c9fab466e8bf6c">41130dd35b2dc43b07600b51d7c9fab466e8bf6c</a>
-<blockquote>
-<p>
- PDF interpreter - work around broken ObjStms (again)<br>
-<br>
- Bug #703448 &quot; Ghostscript can't read files that poppler, mupdf and Firefox and others can read&quot;<br>
-<br>
- The problem is in an OObjStm, a compressed representation of various<br>
- PDF objects. In the example file the ObjStm returns a lone 'mark'<br>
- object for one of the compressed objects, which is not legal.<br>
-<br>
- This appears to be the font T1_2 on page 87.<br>
-<br>
- The mark confuses our counting of the returned objects and that leads<br>
- to the interpreter falling in a heap.<br>
-<br>
- There's no trivial way to address this, so I've chosen to use the<br>
- approach used for error handling in other places; push a specific name<br>
- onto the stack, and then use that instead of a mark to delimit the<br>
- portion of the stack of interest.<br>
-<br>
- Obviously nothing is going to rescue the broken font; but since this is<br>
- a PDF file which has been OCR'ed I don't think this is a problem as we<br>
- will not to try to use it for rendering as the text is all 'drawn' in<br>
- text rendering mode 3 (neither fill nor stroke).<br>
-<br>
- Because we keep using this I've also added a couple of utility procedures<br>
- CountToKey and ClearToKey, which work similarly to countomark and<br>
- cleartomark. Because I wanted to be able to detect a missing key on the<br>
- stack CountToKey returns a boolean, not just a number.<br>
-<br>
- I've also used that approach around the verify_page_tree call so that<br>
- we don't end up with a pile of junk on the stack if it should fall<br>
- over similar errors in future.<br>
-<br>
- Finally I tested with the customer supplied file which originally<br>
- inspired the changes in resolveobjectstream to detect the last kind of<br>
- broken ObjStm and that file continues to work.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-01 14:47:07 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6c2b025f820dd06cb94014ed5f040ddb203f97d">a6c2b025f820dd06cb94014ed5f040ddb203f97d</a>
-<blockquote>
-<p>
- Update tesseract build for latest versions.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-02-01 13:14:24 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ce2fcde6d32586ef468fd56121ffd7d66d03b613">ce2fcde6d32586ef468fd56121ffd7d66d03b613</a>
-<blockquote>
-<p>
- Fix leptonica compilation due to removed file.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-06 11:23:35 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dfed81f5a657a67f672777389bff70d6d31253f7">dfed81f5a657a67f672777389bff70d6d31253f7</a>
-<blockquote>
-<p>
- A customer (#584) file exposed a problem with Link handling<br>
-<br>
- Thanks to Ken Sharp for this fix. He discovered that if annotsetcolor<br>
- returns false, the annotation did not return false.<br>
-<br>
- This occurred with the test file received from that customer on 9/1/2020<br>
-<br>
- Note delayed commit due to proximity to release.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-30 15:45:34 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5bbb4c7e686ddfb28b27e0a790dabef6338ffa6d">5bbb4c7e686ddfb28b27e0a790dabef6338ffa6d</a>
-<blockquote>
-<p>
- txtwrite - fully initialise a structure<br>
-<br>
- Bug #702960 &quot;Valgrind error in clamp_poin_aux on txtwrite device&quot;<br>
-<br>
- Initialise all members of the structure to 0.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-30 11:00: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=d787dad3cd310788ea7201eb2fe1fff9a0a263c2">d787dad3cd310788ea7201eb2fe1fff9a0a263c2</a>
-<blockquote>
-<p>
- txtwrite - Address some memory handling problems<br>
-<br>
- Bug #703143 &quot;segfault in ps2txt with certain large file&quot;<br>
-<br>
- There are two problems here; firstly the textw_text_release()<br>
- function is called *from* gs_text_release, and should not be calling<br>
- that function. This was the initial cause of the seg fault.<br>
-<br>
- Secondly the txtwrite custom text enumerator was not declaring the<br>
- 'pte_fallback' text enumerator member, which meant that it could be<br>
- relocated without updating the txtwrite text enumerator, leading to<br>
- seg faults further through the processing.<br>
-<br>
- This resolves the seg faults on the supplied test file for me, but there<br>
- are still memory problems (memory leaks in fact) revealed by running<br>
- under Memento. I'll address these in a later commit or commits.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-28 04:09:20 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e21027b895f3ba6abda70cefb8facbc772bd7ea9">e21027b895f3ba6abda70cefb8facbc772bd7ea9</a>
-<blockquote>
-<p>
- Better fix for psdcmyk indeterminisms.<br>
-<br>
- When calculating buffer sizes, we now take the presence/absence of<br>
- tags into account. This must be copied into the temporary device<br>
- structure from the target.<br>
-<br>
- Simply setting it to 0 will stop the indeterminisms, but will give<br>
- problems with potential future devices (psdcmyktags?).<br>
-<br>
- Accordingly, I've removed the memset, and copied the value, meaning<br>
- we can rely on valgrind to help spot such problems in future.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-28 09:31: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=a448691e97cc4b4b7040e8c7d7a39e13eedfc0c2">a448691e97cc4b4b7040e8c7d7a39e13eedfc0c2</a>
-<blockquote>
-<p>
- oss-fuzz 27399: Handle NaN and Inf in object type conversions<br>
-<br>
- In the core of cvs detect unrepresentable floating point numbers and throw<br>
- an error (note: not using fpclassify or similar because they are C99 additions).<br>
-<br>
- If we hit such a case, throw an error, in this case undefinedresult - we<br>
- cannot use rangecheck because that gets special handling which also triggers<br>
- the uninitialized value error.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-27 12:53:35 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=66a8ec27ede82a353cb2775c4be1904aca529b2a">66a8ec27ede82a353cb2775c4be1904aca529b2a</a>
-<blockquote>
-<p>
- Init mdev struct to 0 on stack -- fix psdcmyk non-determinism<br>
-<br>
- Big giant structure full of random stuff is probably not a good idea....<br>
-<br>
- This hopefully fixes non-determinisms seen in pdfi psdcmyk device.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-27 13:14:10 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2679ddae53883ba3c7129846494d921151527a74">2679ddae53883ba3c7129846494d921151527a74</a>
-<blockquote>
-<p>
- More jpeg passthrough error case fixes.<br>
-<br>
- Ensure that on an error return, we communicate the end of JPEG passthrough to<br>
- the (potential) recipient(s) of the data.<br>
-<br>
- Basically, we need to ensure that JPEG passthrough is completed before the<br>
- last time we return from s_DCTD_process for the current stream - i.e. whether<br>
- it is an EOD condition, or an error condition.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-27 09:51:59 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5d59986af2b7df560b85ccf54a491eb632022439">5d59986af2b7df560b85ccf54a491eb632022439</a>
-<blockquote>
-<p>
- Close down JPEG passthrough when finalizing DCT decoding.<br>
-<br>
- This doesn't seem too cause any problems with Ghostscript, but it<br>
- is implicated in seg faults in pdfi. Probably because the pdfwrite<br>
- streams are in a faulty state.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-10 10:17:35 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3eb6b9866aa1dae4c2778b450cc99b29e9d11d7e">3eb6b9866aa1dae4c2778b450cc99b29e9d11d7e</a>
-<blockquote>
-<p>
- Implement Nup subclass device to support nesting images on a page.<br>
-<br>
- By using a subclassing device to intercept a few of the device procs<br>
- (get_initial_matrix, output_page, fillpage, put_params, close_device, and<br>
- dev_spec_op) pages can be placed on to a page that is eventually output.<br>
-<br>
- This initial implementation scales the pages on the 'nest' as defined<br>
- by -sNupControl parameter that is a string of the form &quot;HxV&quot; where H<br>
- and V are integers controlling nesting across (H) and down (V) the page.<br>
-<br>
- All pages on the nest are the same size/orientation as the first page of<br>
- the nest, and if a different PageSize is encountered, any pages on the<br>
- current nest will be output before starting a new nest.<br>
-<br>
- In gx_device_set_hwsize_from_media dev_spec_op is used to prevent changing<br>
- the device width and height (HWSize) for PageSize or .MediaSize params.<br>
-<br>
- This requires that the graphics library should not assume that HWSize is<br>
- derived from PageSize and HWResolution, but it allows the intial clip_path<br>
- for the nested pages to be set from the MediaSize, Margins, and HWMargins<br>
- in gx_default_clip_box.<br>
-<br>
- There are a few files that have differences with the 'psdcmyk' devices when<br>
- tested with -sNupControl=1x1:<br>
- Bug688584.ps: Page 6 missing graphics,related to SeparationOrder usage.<br>
- (a bug will be opened for this once this is committed).<br>
- Bug692517.ps: subclass device barely switches to clist mode for 72.0<br>
- (don't care, page mode still works for larger MaxBitmap),<br>
-<br>
- tests_private/pdf/PDFIA1.7_SUBSET/CATX2975.pdf.ppmraw.300.0..gs<br>
- (seems to be a progression on page 9)<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-25 19:04:55 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7f52ae74a19bf1076ebfb9ed1695b0077fc70ee7">7f52ae74a19bf1076ebfb9ed1695b0077fc70ee7</a>
-<blockquote>
-<p>
- Bug 703320: Export cmsCloneTransformChangingFormats<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-25 16:33:26 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=181672f2faccccfd613837d0e60610301a1816ea">181672f2faccccfd613837d0e60610301a1816ea</a>
-<blockquote>
-<p>
- Bug 703378: Error handling for memory failures in gstate<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-25 11:24:46 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=14c51e628fc78f43aa9360ad94c359085583bec5">14c51e628fc78f43aa9360ad94c359085583bec5</a>
-<blockquote>
-<p>
- Coverity 365590 Parameter set but not used.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-23 12:03: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=730d1c410e38500f98ae11cad42d8672521588b4">730d1c410e38500f98ae11cad42d8672521588b4</a>
-<blockquote>
-<p>
- Initialize the current_glyph entry in pdfwrite text enumerator<br>
-<br>
- Also address a compiler warning about &quot;operation&quot; might be unintialised at<br>
- line 3682.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-23 09:36:09 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=054d35268592bba2434dffdb3b36e4ad224adcf0">054d35268592bba2434dffdb3b36e4ad224adcf0</a>
-<blockquote>
-<p>
- Guard against indirect /Length in an XRef stream<br>
-<br>
- Bug #703372 &quot;Unable to find Trailer&quot;<br>
-<br>
- The file has an XRef stream (a compressed cross-reference), where the<br>
- /Length of the stream is itself an indirect object. We can't dereference<br>
- the Length, because to do so we would need to look up its object number<br>
- in the cross-reference!<br>
-<br>
- Oddly the PDF specification does not state that the /Length must be a<br>
- direct object.<br>
-<br>
- This commit wraps the code which retrieves the /Length in a stopped and<br>
- if it fails we fall back to the assumption that the length is invalid<br>
- and apply our normal recovery strategy.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-21 09:52:31 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=98669b8da7d1dd925a1e3bc0bc785cffcb12acab">98669b8da7d1dd925a1e3bc0bc785cffcb12acab</a>
-<blockquote>
-<p>
- Fix PDF 'colorspacespotcolors' to handle uncolored Patterns.<br>
-<br>
- Michael Vrhel noticed that the PageSpotColor count was wrong for test<br>
- file Bug694385.pdf, finding the &quot;Dieline&quot; Separation, but missing the<br>
- &quot;PANTONE 378 C&quot; Separation that was the underlying colorspace for an<br>
- uncolored Pattern.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-16 22:37:13 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d020a4e75e351d1de387d13edebffc36ab54c6d5">d020a4e75e351d1de387d13edebffc36ab54c6d5</a>
-<blockquote>
-<p>
- Fixes/changes to default subclass device procedures.<br>
-<br>
- The 'output_page' should pull the PageCount from the child device (that<br>
- is the only real fix.)<br>
-<br>
- The other changes are to get rid of all of the return statements that<br>
- cannot be reached. The 'else' is retained as a comment /* else */ in<br>
- case someone can't figure that out. It is sort of surprisng that we<br>
- don't get 'statement cannot be reached' messages out of any compiler or<br>
- static analysis tool.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-20 20:54:10 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc676010ad929da40db4c89810ede2f5c4a0ed7b">cc676010ad929da40db4c89810ede2f5c4a0ed7b</a>
-<blockquote>
-<p>
- Implement strip_tile_rect_devn for pdf14 device<br>
-<br>
- The default strip_tile_rect_devn method returns an error<br>
- and has a comment that the method is only implemented<br>
- for devices that support devn, which the comment says<br>
- are only the memory planar devices. However, the pdf14 device<br>
- also supports devn colors and has to be able to handle<br>
- pattern tiles that have spot colors. When such files<br>
- are encountered, the interpreter will just report an error in<br>
- the file and continue on its way if we are in non-clist mode.<br>
- When in clist mode, the error will cause ghostscript to stop<br>
- execution.<br>
-<br>
- This implementation borrows heavily from gx_default_strip_tile_rectangle<br>
- to deal with all the logic of where we are on the tile,<br>
- it then borrows heavily from pdf14_copy_mono but<br>
- using devn colors and dealing with the case of<br>
- one of the colors possibly being gx_no_color_index.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-21 13:00:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=47ec79f910892810d0d72116667d9487093d5c34">47ec79f910892810d0d72116667d9487093d5c34</a>
-<blockquote>
-<p>
- Add malloc_.h to gp_ntfs.c<br>
-<br>
- Bug #703310 &quot;gp_ntfs.c uses malloc but does not include &quot;malloc_.h&quot;&quot;<br>
-<br>
- There doesn't seem to be a problem with adding malloc_.h to the C file<br>
- it matches what we do with other files, doesn't produce any warnings<br>
- and passes regression testing.<br>
-<br>
- Using WIN32_LEAN_AND_MEAN however causes the compiler to fail with a<br>
- number of errors, so we won't be adding that. The nature of the errors<br>
- look like these would be difficult to solve and the benefit of this<br>
- preprocessor directive is moot, even Microsoft insiders describe it<br>
- as 'largely useless'.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-19 11:15: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=5c540233af993678154914eede088a42039ae745">5c540233af993678154914eede088a42039ae745</a>
-<blockquote>
-<p>
- libtiff build fail in old VS versions<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-17 20:01:08 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be18309f3ce815c21ce858527515e7765d672a9b">be18309f3ce815c21ce858527515e7765d672a9b</a>
-<blockquote>
-<p>
- Fix issues with windows C# demos/csharp/api/ghostnet.cs<br>
-<br>
- Make sure to explicitly tell C# that the callback delegates will use a Cdecl<br>
- calling convention, which means that the caller (in this case the ghostscript)<br>
- will clean the stack. Also some minor changes to the project settings.<br>
- The default for debug is to use gpdldllxx.dll while the release versions will<br>
- use gsddllxx.dll just to help with the testing. Finally, make sure to *always*<br>
- copy the dll from the appropriate gs directory, even when the C# application<br>
- did not need to do a build (as it was already built)<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-15 15:13:05 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b9ad2c23e6fd1f7cf0c4889504ac1642f077b660">b9ad2c23e6fd1f7cf0c4889504ac1642f077b660</a>
-<blockquote>
-<p>
- Tifflib fix: Thunder RLE can fail to decode last run.<br>
-<br>
- GPDL decode of tests_private/tiff/text.tif gives valgrind errors<br>
- due to the &quot;thunder decode&quot; failing to extract the last run of<br>
- bytes.<br>
-<br>
- The logic in the decoder, presumably intended to spot overruns of<br>
- data is incorrect, in that runs that end at the end of a row<br>
- (npixels == maxpixels) will not be decoded.<br>
-<br>
- Fix this by limiting 'n', the number of pixels to copy. Note that<br>
- npixels is updated by the 'unlimited' value to ensure the error<br>
- reporting at the end of the loop still works.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-15 12:26: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=4e956a2ee5137812007a7862a6eb8fddd9b709d2">4e956a2ee5137812007a7862a6eb8fddd9b709d2</a>
-<blockquote>
-<p>
- Update libtiff to 4.2.0<br>
-<br>
- And then re-apply: ef66198ade77d5d551b3045cd36bed81c0b04f54<br>
-<br>
- Changes to libtiff for gpdl.<br>
-<br>
- 1) Ensure that libtiff doesn't mess with 'boolean' in GS builds<br>
- on Windows. Without this, the jpeg structures used by our JPEG<br>
- lib build are different in size when called from gs and libtiff,<br>
- resulting in runtime errors.<br>
-<br>
- 2) Update libtiff so that it can correctly call into the jpeg<br>
- library so that memory operations happen from our pools, not<br>
- malloc/free. Slightly horrid in that this is more complex with<br>
- OJPEG than JPEG files.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-01 19:05:40 -0500
-</strong>
-<br>Rob Boehne &lt;robb@datalogics.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=35035761ffe178284c4ef9fc2ef75a4843e64a63">35035761ffe178284c4ef9fc2ef75a4843e64a63</a>
-<blockquote>
-<p>
- Bug 703339: Fix libtiff name clash on AIX<br>
-<br>
- Patch grabbed from upstream:<br>
-<br>
- https://gitlab.com/libtiff/libtiff/-/commit/31ca59cb047353d7edf66d04fe052861b180e42d<br>
-<br>
- Rename itrunc to fix name clash with a different itrunc in math.h on AIX.<br>
-<br>
- Fixes issue #189<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-15 12:10:58 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=364a3883326b90bf078d488909ba3203450da3d3">364a3883326b90bf078d488909ba3203450da3d3</a>
-<blockquote>
-<p>
- Bug 703301: Fix logic error in display device structure checks.<br>
-<br>
- Thanks to Pino Toscano for spotting this.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-14 19:45:33 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f9723a92bcb3ab1de8f5cf16da5b5e6c807eeda2">f9723a92bcb3ab1de8f5cf16da5b5e6c807eeda2</a>
-<blockquote>
-<p>
- Bug 703336: Fix GPL crash with jpg input on 64bit windows.<br>
-<br>
- The Jpeg code uses setjmp/longjmp for error handling. On Windows at<br>
- least, in 64bit builds, jmpbufs need to be 16 byte aligned. This is<br>
- generally achieved by malloc blocks being 16 byte aligned, and<br>
- structures have their offsets calculated so that their contents lie<br>
- at appropriate positions.<br>
-<br>
- Unfortunately, our malloc routines only align to 8 byte aligned.<br>
-<br>
- We therefore bend the jpgtop.c code to align the jmpbuf manually.<br>
-<br>
- Similar tricks are required in the pngtop.c code, which also uses<br>
- setjmp/longjmp, but a slightly different approach has to be taken<br>
- as the png routine allocates the structure with the callback in<br>
- itself, so we don't get to align just that. Instead, we modify the<br>
- allocation routines that we provide to pnglib so that blocks are<br>
- correctly padded.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-14 16:42: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=496d1d927acfe2460b69552f372f9ec7a411a172">496d1d927acfe2460b69552f372f9ec7a411a172</a>
-<blockquote>
-<p>
- Improve memory device bitmap size calculation in tagged planar cases.<br>
-<br>
- The planar calculations for memory device sizes were failing to take<br>
- the presence of tags into account. Fix those calculations here.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-14 13:31: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=6376e75907ab7eff2248236333a10489cfad3787">6376e75907ab7eff2248236333a10489cfad3787</a>
-<blockquote>
-<p>
- Remove paths stored in --permit-file* when sanitising.<br>
-<br>
- Bug #703338 &quot;Hide permitted paths from invocation comment&quot;<br>
-<br>
- As noted in the bug report, the --permit-file* control arguments are<br>
- not replaced with '?' when sanitising the arguments. This leads to an<br>
- information leak with the 'Invocation' comment emitted by pdfwrite.<br>
-<br>
- This commit adds checking for the -- switches and sanitises the<br>
- permit-file* cases.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-13 13:03:22 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f11882a4b09beb0d74f88df759841cb49ed63683">f11882a4b09beb0d74f88df759841cb49ed63683</a>
-<blockquote>
-<p>
- MSVC: Yet another nmake version.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-12 22:11:13 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79decaf7eca50a7dc6201dc86ef487ee1e7563f9">79decaf7eca50a7dc6201dc86ef487ee1e7563f9</a>
-<blockquote>
-<p>
- Fix GhostPDL TIFF reader to be able to handle tiff32nc output.<br>
-<br>
- The PHOTOMETRIC_SEPARATED case would only handle num_comps == 3, but the<br>
- tiff32c device creates 4 component images with PHOTOMETRIC_SEPARATED.<br>
- Allowing 3 or 4 components works.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-07 17:24:44 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=904c546962cb749fa8136130612e1c0a9cf558af">904c546962cb749fa8136130612e1c0a9cf558af</a>
-<blockquote>
-<p>
- Add CMYK equivalent colorants for Separation Spot colors to tiffsep device.<br>
-<br>
- This may be useful information -- adding the equivalent colors for the Spot<br>
- color names.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-07 17:32:12 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34ec1a4deb5275280184346ef877e6984da59da8">34ec1a4deb5275280184346ef877e6984da59da8</a>
-<blockquote>
-<p>
- Fix pdf_info.ps &quot;write-doc-string&quot; to handle names as well as strings.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-09 10:32:36 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ead8676f2b8686605b8f6976da4de677d99d39e0">ead8676f2b8686605b8f6976da4de677d99d39e0</a>
-<blockquote>
-<p>
- Fix yet another version number handling ommission<br>
-<br>
- From the introduction of the patch level to the version number.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-06 16:23:05 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a081833ac163dd6d6b404b679cf086f125847ef8">a081833ac163dd6d6b404b679cf086f125847ef8</a>
-<blockquote>
-<p>
- oss-fuzz 26175: propagate error for invalid arc4 key<br>
-<br>
- Also, precautionary initialisation of a couple of variables in the arc4 stream<br>
- state.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-04 10:38: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=b0b1b89c767809c05abbe118c47875743438580c">b0b1b89c767809c05abbe118c47875743438580c</a>
-<blockquote>
-<p>
- oss-fuzz 27985: Initialize the glyph lengths array<br>
-<br>
- Just memset to 0x00, so in the event of an error, we don't later use the memory<br>
- uninitialized.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-06 16:22:15 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=62a98980772fde394c99e92bfc9c18d5407c06e1">62a98980772fde394c99e92bfc9c18d5407c06e1</a>
-<blockquote>
-<p>
- Update for another version of MSVC.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-05 11:25: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=b01bdd87eb96b3d8db7ef2727d5a6ab7b122b8fc">b01bdd87eb96b3d8db7ef2727d5a6ab7b122b8fc</a>
-<blockquote>
-<p>
- Update openjpeg to 2.4.0<br>
-<br>
- Fixes:bugs 703275, 703276, 703277, 703278, 703279, 703280, 703281.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-05 09:01:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc2f67265d1508a6cf953470ef7b2a0d9a1a14e3">cc2f67265d1508a6cf953470ef7b2a0d9a1a14e3</a>
-<blockquote>
-<p>
- Update freetype to 2.10.4 (for real, this time!)<br>
-<br>
- (with zlib &quot;Diagnostic functions&quot; hack/fix in freetype/src/zutil.h)<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2021-01-01 17:50: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=6b4c229d4bf4bcccf8000611caaef59f859d04a6">6b4c229d4bf4bcccf8000611caaef59f859d04a6</a>
-<blockquote>
-<p>
- Build apitest demo with -DCLUSTER.<br>
-<br>
- This ensures that pdfwrite doesn't put timestamps in the<br>
- produced PDF files, which means the md5sums are consistent.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-16 15:50:09 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=01194f9c8a0f2df53ad8f1815bfadc10ad247ba7">01194f9c8a0f2df53ad8f1815bfadc10ad247ba7</a>
-<blockquote>
-<p>
- PDF interpreter - check type of Group entries in Form XObjects<br>
-<br>
- Bug #703271 &quot;Using oitsample to convert some pdf files to tif errors out with &quot;The export process timed out.&quot;&quot;<br>
-<br>
- This is for the larger (205 pages) of the two files. The file is badly<br>
- broken, 3 fonts point to objects which are not dictionaries but are<br>
- simply integers. In addition at least one of the Form XObjects has a<br>
- Group entry which also points to an object which is an integer, not a<br>
- dictionary.<br>
-<br>
- The Group was corrupting the operand stack leading to later errors. This<br>
- commit checks the type of the Group (and the BBox since we're making<br>
- changes anyway) and simply aborts the Group if the type is incorrect.<br>
-<br>
- Obviously this is going to lead to incorrect output, but at least we<br>
- can carry on to later pages.<br>
-<br>
- Note that Acrobat throws errors on pages 168, 169 and 171-175 of this<br>
- file and renders blank pages for them, so the file is clearly very badly<br>
- broken.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-16 09:56:40 +0000
-</strong>
-<br>Julian Smith &lt;julian.smith@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eef97dac4d6d6e88319c17af4f739e7d899776f3">eef97dac4d6d6e88319c17af4f739e7d899776f3</a>
-<blockquote>
-<p>
- base/memento.h: fix Memento_listBlockInfo macro - needs to take one argument.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-15 17:42:35 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9912c583aba35b68e251a73861ead44b0dbd91b4">9912c583aba35b68e251a73861ead44b0dbd91b4</a>
-<blockquote>
-<p>
- Add Memento_blockInfo(void *addr).<br>
-<br>
- Show the history for a block.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-15 16:46:56 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e1dfb92cc593cd27ed593ffcc3a79711b7504563">e1dfb92cc593cd27ed593ffcc3a79711b7504563</a>
-<blockquote>
-<p>
- PDF interpreter - handle indirect objects in Encrypt dictionary<br>
-<br>
- Bug #703272 &quot;This PDF files converts to tiff using the oitsample program, but the font turns from English to what looks like chinese&quot;<br>
-<br>
- The Encrypt dictionary and the subsidiary StdCF dictionary are stored<br>
- as indirect objects (presumably in order to make the file larger). The<br>
- decryption code wasn't expecting that.<br>
-<br>
- Add code to dereference the objects. While we're here, add code to check<br>
- the types of the objects and ensure they are correct, and throw an<br>
- error if they are not.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-11 11:19: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=4d91c6ad3e76e19f36d23a50dce253fbbc7d0560">4d91c6ad3e76e19f36d23a50dce253fbbc7d0560</a>
-<blockquote>
-<p>
- Update CFF strings &quot;known&quot; encoding in C<br>
-<br>
- There were a few missing strings.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-11 10:55: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=87eed438b0cffba111371c25e1d169163f310465">87eed438b0cffba111371c25e1d169163f310465</a>
-<blockquote>
-<p>
- Reintroduce and update cff std strings &quot;encoding&quot; PS file<br>
-<br>
- and move it to &quot;lib&quot; since we don't actually use it in Postscript any more.<br>
-<br>
- It's only used if we ever need to regenerate the C representation of &quot;known<br>
- encodings&quot;.<br>
-<br>
- Also, update to include missing strings.<br>
-<br>
- Finally, fix the tool that relies on this &quot;encoding&quot; - .namestring is no<br>
- longer exposed as a Postscript operator, so define a local equivalent. And<br>
- update the example invocation in the comments<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-14 20:15:25 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bcd9f9d0126d07dc6f93e47618baa6d23fcaf1c2">bcd9f9d0126d07dc6f93e47618baa6d23fcaf1c2</a>
-<blockquote>
-<p>
- Mask off the transparency bits from the rop value<br>
-<br>
- before we use it as an index into a 256 entry rop table.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-15 09:10:55 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0fa1513841981e7d3bc4da11c93edeeedd452b72">0fa1513841981e7d3bc4da11c93edeeedd452b72</a>
-<blockquote>
-<p>
- Fax Decode filter - add a simple sanity check<br>
-<br>
- I have a test file (source unknown) e249869cf6a250726711c21fda42763c_signal_sigsegv_a418b9_5694_4827.pdf<br>
- which has a number of type 3 bitmap glyphs with invalid CCITTFaxDecode<br>
- parameters. The (optional) Columns key in the dictionary has an<br>
- associated value of 2^32-1 in one case and an even larger value in<br>
- another.<br>
-<br>
- The new pdfi interpreter causes a seg fault in the CCITTFaxDecoder<br>
- because this breaks a 32-bit signed integer on Windows, causing the<br>
- 'raster' value to be negative, when added to the memory pointer this<br>
- causes us to try and read from before the beginning of the data buffer.<br>
-<br>
- Ghostscript's PDF interpreter doesn't trigger this because it fails<br>
- much earlier and doesn't try to execute these glyphs but I'm certain<br>
- it would be possible to modify the file so that it did.<br>
-<br>
- Adding a simple negative check and throwing an error if it is, resolves<br>
- the problem.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-11 11:45:34 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d8dd6797ba52cd8af28839d1f5f2a4a5fca055d7">d8dd6797ba52cd8af28839d1f5f2a4a5fca055d7</a>
-<blockquote>
-<p>
- Fix -dAntidropuoutDownscaler for non-masked images.<br>
-<br>
- The masked image case set the polarity needed in order for the<br>
- ISpecialDownScale image interpolation to work, but the ordinary images<br>
- did not set the 'pol' leaving it set to GX_CINFO_POLARITY_UNKNOWN.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-14 08:39:50 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6166768c6e963b0fe28ccdb266629443e521381">c6166768c6e963b0fe28ccdb266629443e521381</a>
-<blockquote>
-<p>
- Fix bug 703270: Wrong path for PostScript helper file in ps2epsi<br>
-<br>
- In the change mentioned in the bug, rather than rely on the LIBPATH<br>
- search method, the ps2epsi script assumed that pd2epsi.ps would be<br>
- in the same directory as the 'gs' executable, which is not correct.<br>
-<br>
- Change to use bare 'ps2epsi.ps' so that it will be found on the<br>
- LIBPATH as instialled by: make install<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-12 10:31:50 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3f16ba6aa7c12ee469736f3c8e2205be81087f2a">3f16ba6aa7c12ee469736f3c8e2205be81087f2a</a>
-<blockquote>
-<p>
- PDF interpreter - improve commit for bug #703217<br>
-<br>
- In the event that the execution of a Form XObject for a transparency<br>
- Group consumed more operands than were pushed, we left the number<br>
- of operands on the stack. This just cleans up the stack.<br>
-<br>
- The file for bug #697655, with the pdfwrite device, is the only known<br>
- case of this, and the file fails with pdfwrite anyway, so this is not a<br>
- truly vital fix, but its best to tidy up.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-12 09:29: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=96e881edc16d7ffe562f8e46354a16275008fe08">96e881edc16d7ffe562f8e46354a16275008fe08</a>
-<blockquote>
-<p>
- Have Git ignore some more directories<br>
-<br>
- Add debugobjrt, memobj64 and windows./vs to the ignore list for Git.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-10 11:01:55 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1be0cd16079c34c05b790683ea76b790486989b">d1be0cd16079c34c05b790683ea76b790486989b</a>
-<blockquote>
-<p>
- pdfwrite - fix another memory leak on an error path<br>
-<br>
- Again this does not exhibit with the garbage-collecting memory allocator,<br>
- discovered by Nancy while working on pdfi.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-08 11:27:10 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=733a8f209ecce61f31621ab87d1d1a81f4935602">733a8f209ecce61f31621ab87d1d1a81f4935602</a>
-<blockquote>
-<p>
- Bug 70716: ETS code clean up.<br>
-<br>
- Add checking for memory allocation failures, static code analysis findings,<br>
- and issue mentioned in 701716. Also update windows project to VS2019.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-08 15:35:28 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a1b4377ffe877fcd3ec2832ca670833cc45adb7a">a1b4377ffe877fcd3ec2832ca670833cc45adb7a</a>
-<blockquote>
-<p>
- pdfwrite - fix memory leak on error path<br>
-<br>
- When writing outlines via a pdfmark, if the code failed for any reason<br>
- then we would leak various objects. As usual this is cleaned up for us<br>
- by the garbage collector when running in PostScript but leaks when we<br>
- aren't using the garbage collector.<br>
-<br>
- There are likely to be many, many more paths that leak like this, the<br>
- only way to find them is going to be a complete audit of the pdfwrite<br>
- source, which would be a major undertaking. For now we'll fix them as<br>
- we find them.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-08 09:35:26 +0000
-</strong>
-<br>Peter Cherepanov &lt;sphinx.pinastri@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a5ed5d0f3fd955bc5d0b1dbb18e63636f697a76">7a5ed5d0f3fd955bc5d0b1dbb18e63636f697a76</a>
-<blockquote>
-<p>
- PDF Interpreter - Clean up stack after Form Xobject for transparency Group<br>
-<br>
- Bug #703217 &quot;Error: /typecheck in /--pdfshowpage_finish--&quot;<br>
-<br>
- This is basically the patch supplied by Peter Cherepanov, which uses<br>
- the existing mechanism for restoring the stack to a count stored<br>
- before the execution of the Form XObject.<br>
-<br>
- However, Peter's patch caused a regression with the file for bug 697655<br>
- when run with pdfwrite, because that file consumes more operands from the<br>
- stack than it should, leading to us trying to pop -1 elements.<br>
-<br>
- This commit only pops a positive number of objects, and has a slightly<br>
- different error text.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-07 09:25:05 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb78a833aeb27ddd59a88c799fde1e939fb43e5a">fb78a833aeb27ddd59a88c799fde1e939fb43e5a</a>
-<blockquote>
-<p>
- Fix bug 702786: Ignore null node in Page tree<br>
-<br>
- Thanks to Peter Cherepanov for this analysis and the patch,<br>
-<br>
- The sample file has an element in the /Pages array that cannot be resolved,<br>
- and following the PDF spec is interpreted as null.<br>
-<br>
- This patch makes Ghostscript ignore null nodes in the page tree. In turn,<br>
- this causes a missing page error, which was considered a fatal error before.<br>
-<br>
- -dPDFSTOPONERROR causes Ghostscript to not proceed with this broken file.<br>
-<br>
- Regression testing shows no differences with other files.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-07 16:43:37 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f4ef8bb9684bcc7d07c83b8ffabb607046930a7d">f4ef8bb9684bcc7d07c83b8ffabb607046930a7d</a>
-<blockquote>
-<p>
- pdfwrite - Limit XUID to 16 values and don't emit it for subset fonts<br>
-<br>
- Bug 703225 &quot;The document breaks after repeated processing&quot;<br>
-<br>
- As noted by Peter Cherepanov, we currently preserve the XUID in the font<br>
- when writing it out from pdfwrite, and the PDF interpreter extends any<br>
- existing XUID (or adds a new one) every time we process the file.<br>
-<br>
- The PLRM documents an Adobe limitation of 16 entries in an XUID array<br>
- and it appears Acrobat has the same limitation.<br>
-<br>
- This commit adds new flags to the type 1 and type 2 font writers so that<br>
- we only write an XUID when we are *not* subsetting the font (as the use<br>
- of an XUID on two different subset fonts would be incorrect). It also<br>
- only emits the first 16 values from an XUID even if we aren't subsetting<br>
- the font.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-07 09:59:35 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7bfb672daea29645ee40c0facbd5f2eec7cf58e7">7bfb672daea29645ee40c0facbd5f2eec7cf58e7</a>
-<blockquote>
-<p>
- pdfwrite - fix memory leak when converting names into references<br>
-<br>
- When writing certain kinds of metadata from pdfmarks we need to convert<br>
- a named object into an indirect reference. The code for doing this<br>
- assumed that the gs_param_string array was arranged so that each<br>
- gs_param_string's data member pointed to an individually allocated<br>
- chunk of memory, so it was safe to replace it.<br>
-<br>
- This had 2 problems; firstly the original data buffer was not freed,<br>
- leading to memory leaks. Secondly, and more seriously, not all<br>
- gs_param_string_arrays are organised this way. Sometimes the array<br>
- has a single data pointer containing all the entries sequentially,<br>
- each member of the array is a gs_param_string where the data member<br>
- points into a location in the string. We cannot free and reallocate<br>
- the data members from that kind of string array.<br>
-<br>
- SO this commit modifies the code to make a new copy of the data in the<br>
- param_string_array in the format expected by the remaining code, and<br>
- frees the copied data afterwards. This fixes the meory leak and avoids<br>
- the potential crashes caused by the incorrect assumption.<br>
-<br>
- Note that the assumption in the code is true when the input is from the<br>
- PostScript interpreter, but is not true for the input from pdfi and<br>
- obviously potentially any other front-end.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-04 15:07:31 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6dbcee4e0b4868843938233eb2c37c927f674d69">6dbcee4e0b4868843938233eb2c37c927f674d69</a>
-<blockquote>
-<p>
- Update MSVC makefiles.<br>
-<br>
- Firstly, another version of nmake to cope with. In fixing this, I<br>
- note that we haven't been setting MS_TOOLSET_VERSION in some cases.<br>
- For building from the IDE this evidently doesn't matter, but I suspect<br>
- it is required for building using nmake. Add those back in.<br>
-<br>
- Thanks also to Julian for spotting that the logic to cope with<br>
- &quot;Community&quot; vs &quot;Professional&quot; editions was failing due to extra<br>
- quotes. Fixed here.<br>
-<br>
- Also, msvclib.mak hadn't been updated for VS2017 or VS2019. Copy<br>
- the relevant sections across. Possibly we should pull this code out<br>
- to a separate file that we can !include so we only have to maintain<br>
- it in one place.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-01 18:06: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=fb1a336ac4d2613a63dc0b6054f20f9a8a467fe9">fb1a336ac4d2613a63dc0b6054f20f9a8a467fe9</a>
-<blockquote>
-<p>
- Bug 694692: Handle custom left-sidebearing values.<br>
-<br>
- Ghostscript was ending up ignoring LSB values read from Metrics dictionaries.<br>
-<br>
- This stemmed from some confusion about Freetype's incremental interface<br>
- API get_metrics call. We had taken the references to &quot;overriding&quot; the metrics<br>
- to mean it allowed for custom metrics to be passed into (and back out of)<br>
- Freetype. That is not the case: it is intended to allow integrations supporting<br>
- &quot;incomplete&quot; (primarily TrueType) fonts, such as PCL/XL embedded TTFs, that are<br>
- permitted to omit certain tables - specifically, in this case, the hmtx and vmtx<br>
- tables.<br>
-<br>
- So, this drops that approach, and applies custom LSB values in our code.<br>
-<br>
- Coincidentally, this also makes gs somewhat immune from a pending change in<br>
- Freetype related to that get_metrics call.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-27 12:17:36 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fce9bcfbda7acdf758fe6fb5264bb1e78eb39039">fce9bcfbda7acdf758fe6fb5264bb1e78eb39039</a>
-<blockquote>
-<p>
- FAPI: fix applying offsets for glyph paths<br>
-<br>
- If the renderer doesn't deal with replacing metrics, we apply an offset to the<br>
- glyph before we pass it back into Ghostscript....<br>
-<br>
- Except we weren't doing it for outline glyphs. Shouldn't (currently) affect<br>
- freetype, but nevertheless....<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-03 11:42:27 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=596394e2cdff74488fb53fc818d7f5ca4d3ac1da">596394e2cdff74488fb53fc818d7f5ca4d3ac1da</a>
-<blockquote>
-<p>
- Address a compiler warning from 2ed1184b7513<br>
-<br>
- If unrolling the just created, incomplete save state fails we are out of safe<br>
- options to carry on, so throw a fatal error.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-20 13:07:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2ed1184b75132c1ef10cfeec2415f13eaefc7f9e">2ed1184b75132c1ef10cfeec2415f13eaefc7f9e</a>
-<blockquote>
-<p>
- oss-fuzz 27011: Improve handling of error during a &quot;save&quot;.<br>
-<br>
- Previously, in the event of an error during a Postscript save operation, we<br>
- could end up leaving a half formed save object in existence. If the error<br>
- happened during the gs_gsave_for_save() function, that could end up leaving<br>
- the graphics state cleanup &quot;out of sync&quot; with the save state cleanup at the<br>
- final virtual memory cleanup as we shut down.<br>
-<br>
- To resolve that, destroy the partially formed save state at the point of the<br>
- error. This also means tweaking dorestore() to handle unrolling a save state<br>
- without the graphics state reference in it.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-09 15:27:57 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=634d9c76a6c4c92273c7994cd228e01e263b9d7c">634d9c76a6c4c92273c7994cd228e01e263b9d7c</a>
-<blockquote>
-<p>
- oss fuzz 27304: validate glyph offset against stream size<br>
-<br>
- When we retrieve a glyph offset, check it is within the size of the sfnt data<br>
- and if it is not, throw an error.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-02 15:10: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=97152401c7d4490be8f8112829ea440b95411702">97152401c7d4490be8f8112829ea440b95411702</a>
-<blockquote>
-<p>
- Bug 703214 - treat some kinds of free objects as not free<br>
-<br>
- The file in Bug 703214 has been edited incrementally a number of times.<br>
- The bug is actually the creation of the initial file, which declares<br>
- its xref table as having a section 7 entries long starting at object<br>
- 1.<br>
-<br>
- In fact, as is normal, the xref table starts at object 0 with the free<br>
- entry at the start of the linked list. Because of the incorrect<br>
- subsection header though, a PDF consumer should read this as being<br>
- object 1, not object 0.<br>
-<br>
- Obviously *all* the objects are then incorrect.<br>
-<br>
- The incremental updates then redefined very object *except* object 1.<br>
- The result of this is that these objects are all correctly defined. The<br>
- file then attempts to render object 1, which is free. Acrobat can deal<br>
- with this, which must mean it is ignoring the 'free' status of the<br>
- object and reading the 'next free object' value as if it were the offset<br>
- of the object.<br>
-<br>
- Because the next free object is 0, and object 1 is the first object in<br>
- the PDF file, and the preceding line is a comment, this actually works<br>
- though I'm pretty certain its only by sheer luck, it really should not<br>
- work at all.<br>
-<br>
- Unfortunately, because of the way the the PDF interpreter reads PDF<br>
- files and stores xref entires, we cannot easily detect an attempt to<br>
- use a 'free' object and try to treat it as non-free. We have to do this<br>
- upfront when we read the xref table. Because this is such a fluke and I<br>
- believe not likely to be repeatable, I've tried to keep the condition<br>
- for ignoring the free flag as tight as possible; The generation number<br>
- must be exactly 65535 (the canonical value for the head of the free<br>
- list), and the object number must be not zero. In this case only we<br>
- will store the 'next free object number' as an offset.<br>
-<br>
- If the object is truly free then either it is unused (in which case we<br>
- will not use the xref entry) or it should have been superseded by a<br>
- later incremental update, in which case we still won't use this entry.<br>
- The only way we could try to use this entry is if the PDF file attempts<br>
- to use a free entry.<br>
-<br>
- This might change some handling of other broken files.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-02 00:48: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=ed946acb20ec03426d35b0d9341c551e7e459184">ed946acb20ec03426d35b0d9341c551e7e459184</a>
-<blockquote>
-<p>
- LGTM: Reduce goto use in zsort_continue.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-02 00:22:20 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4633ebbca0c9690003aebc9f4661c232c61cecdd">4633ebbca0c9690003aebc9f4661c232c61cecdd</a>
-<blockquote>
-<p>
- LGTM fix: Reduce goto use in s_hex_process.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-01 12:56:09 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4cbe8fa61a3dc7bb8f9e425024b79a66950664ec">4cbe8fa61a3dc7bb8f9e425024b79a66950664ec</a>
-<blockquote>
-<p>
- ;Bug 703208 Make changes from bug 703164 gsicc_lcms2mt.c over to gsicc_lcms2.c<br>
-<br>
- Thanks to Stefano Rivera for catching this.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-01 10:25:06 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ab2d212dba1475647508b085feb5ee93ea678f8">4ab2d212dba1475647508b085feb5ee93ea678f8</a>
-<blockquote>
-<p>
- LGTM: Reduce gotos in s_LZWD_process<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-12-01 09:39:42 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cea43d89382fc253f64a7b942722a636080e8138">cea43d89382fc253f64a7b942722a636080e8138</a>
-<blockquote>
-<p>
- pdfwrite - fix memory leak with high level forms<br>
-<br>
- As usual this does not exhibit with Ghostscript, because of garbage<br>
- collection, and was observed with pdfi.<br>
-<br>
- We transferred ownership of the form object to the local named<br>
- resources dictionary, and removed the resource from the XObject chain<br>
- of stored resources, but we didn't free the actual resource structure.<br>
-<br>
- Rejigged the code order slightly because we need the resource for a<br>
- few purposes before we transfer ownership and free it. Also fixed a<br>
- typo and a misleading string (only used for debug purposes in each case)<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-30 12:44:25 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cbe110579288e1d54afd5fecd0abe6e59fe49caa">cbe110579288e1d54afd5fecd0abe6e59fe49caa</a>
-<blockquote>
-<p>
- Bug 698848 Fix mismatch of color space and number of components in JPEG2000<br>
-<br>
- Peter Cherepanov and Ray Johnston had earlier patches. This fix builds<br>
- on those and runs cleanly on our test files including Bug694909, which<br>
- had an odd unknown cs jp2k image.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-30 13:21:22 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=080a23c44808a93fa27ba2d4dfdf8d8748a8e84a">080a23c44808a93fa27ba2d4dfdf8d8748a8e84a</a>
-<blockquote>
-<p>
- Fix bug 703198: SEGV's with psdcmykog device and --saved-pages-test<br>
-<br>
- This was a reference of a missing icc_table caused by the band count not<br>
- being adjusted during saved-page playback as it was during writing. The<br>
- orig_spec_op in the gx_device_printer structure was being set to the<br>
- gdev_prn_spec_op, but this did not call the target device's spec_op, so<br>
- it did not get the result from gxdso_adjust_bandheight that was needed.<br>
-<br>
- Caused by commit 8df410c26.<br>
-<br>
- Also clean up a left over extern in gxclrect.c (not related to the fix).<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-30 10:41:20 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=50a9fad340a659e64c5dbc74125b97e16cf529de">50a9fad340a659e64c5dbc74125b97e16cf529de</a>
-<blockquote>
-<p>
- Bug 703197 : Seg fault in close of x windows<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-28 13:37: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=6c94917b4a36c19b30dc451f03715ec2c257d2e5">6c94917b4a36c19b30dc451f03715ec2c257d2e5</a>
-<blockquote>
-<p>
- lgtm fixes: Fix previous fix to s_A85E_process.<br>
-<br>
- continue in a do { } while (0); doesn't work.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-01 15:58: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=bac9c5d2ed82390da058653afbac0d9e29e9bd3f">bac9c5d2ed82390da058653afbac0d9e29e9bd3f</a>
-<blockquote>
-<p>
- Searching for a marker in a stream, honor alignment<br>
-<br>
- When searching for markers in a stream buffer, we were &quot;seeking&quot; to the point<br>
- in the buffer, and casting to either a byte, ushort or a uint to make the<br>
- value comparison. But we cannot do that on SPARC because of the strict<br>
- alignment on that hardware.<br>
-<br>
- So, we have to &quot;unpack&quot; the individual bytes from the stream to do the value<br>
- comparison.<br>
-<br>
- Note: there are slightly confusing comments in the code that mention being<br>
- &quot;on a 16 bit boundary&quot; and &quot;on a 32 bit boundary&quot; - that's referring to the<br>
- offset into the buffer, *not* the actual memory address alignment.<br>
-<br>
- Found in testing on Solaris/SPARC<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-27 14:59:40 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3d33e44d3d014ee78a4505c37b244957066d7b12">3d33e44d3d014ee78a4505c37b244957066d7b12</a>
-<blockquote>
-<p>
- Fix memory leak with copied type 1 fonts.<br>
-<br>
- If we copy a type 1 font (for the benefit of the pdfwrite family of<br>
- devices) then we make a copy of the Subrs and GSubrs as well, but the<br>
- routine to free the copied font wasn't freeing those copies.<br>
-<br>
- This isn't normally obvious because these are garbage collected, found<br>
- while checking pdfi.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-27 10:19: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=fec1090d129630c23f425c6aae5a4a1308a973da">fec1090d129630c23f425c6aae5a4a1308a973da</a>
-<blockquote>
-<p>
- LGTM: Rejig s_A85E_process for goto's.<br>
-<br>
- All gotos are now forwards.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-27 11:14:07 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c3b29a81c5cb0859ea567657c646b06f7df4039">2c3b29a81c5cb0859ea567657c646b06f7df4039</a>
-<blockquote>
-<p>
- Fix compiler warning<br>
-<br>
- Explicitly cast gx_device_null pointer to a gx_device pointer.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-26 16:23:17 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f789ded2e122578af6e9e0350e487e7ff89e74ae">f789ded2e122578af6e9e0350e487e7ff89e74ae</a>
-<blockquote>
-<p>
- Ensure the nulldevice has a proper set of device methods<br>
-<br>
- gs_make_null_device uses the gs_null_device structure to create an<br>
- instance of the nulldevice, but it did not call gx_device_fill_in_procs<br>
- to set the device methods which are left as NULL in the declaration.<br>
-<br>
- Since all device methods (except fill_rectangle) are expected to be<br>
- real functions, not NULL, many places in the code do not check that<br>
- the device method is not NULL before calling it. This could (and in<br>
- pdfi did) lead to us attempting to execute 0x00 causing seg faults.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-24 18:20:39 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9aa09cbca96e722568be76c2de35b41ee9881ba5">9aa09cbca96e722568be76c2de35b41ee9881ba5</a>
-<blockquote>
-<p>
- lgtm: Rejig gotos in gs_type2_interpret.<br>
-<br>
- All gotos are now forwards. No change to actual operation of code.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-25 10:11:16 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db51437d7799576dadeb91014b483d57a39e98ae">db51437d7799576dadeb91014b483d57a39e98ae</a>
-<blockquote>
-<p>
- Coverity 364047: Structurally dead code.<br>
-<br>
- The previous fix to gs_type1_interpret to make lgtm happy has upset<br>
- Coverity. Coverity (incorrectly) believes that some code is now<br>
- structurally dead, when actually there is a goto jumping into it.<br>
-<br>
- I think we can make both happy by moving the code to the location of<br>
- the last goto.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-25 08:07:28 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=09377ecc18f952fa7e29c1c884f5fcb493809577">09377ecc18f952fa7e29c1c884f5fcb493809577</a>
-<blockquote>
-<p>
- pdfwrite - fix a compiler warning<br>
-<br>
- remove a now unused variable<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-24 19:56:49 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e912ff13757dcff888319f78c05297b4fde8359">8e912ff13757dcff888319f78c05297b4fde8359</a>
-<blockquote>
-<p>
- pdfwrite - fix 2 memory leaks with metadata<br>
-<br>
- Discovered with pdfi. There is a temporary buffer which wasn't being<br>
- freed.<br>
-<br>
- A more complex problem involves the Metadata value stored in the<br>
- Catalog dictionary. A long comment describes why this is not freed as<br>
- an 'otherResource', but experience contradicts the comment, the<br>
- Metadata value is not freed along with the Catalog object.<br>
-<br>
- I've altered this here to solve the memory leak but this may need more<br>
- investigation.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-23 01:10: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=437c020e8f99f429b3b95f11c47ef452b7da287b">437c020e8f99f429b3b95f11c47ef452b7da287b</a>
-<blockquote>
-<p>
- LGTM fixes: Rejig gs_type1_interpret to avoid backward gotos.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-23 00:27: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=63fc05354eae86931f5949086b1b11641f3e23c0">63fc05354eae86931f5949086b1b11641f3e23c0</a>
-<blockquote>
-<p>
- LGTM: fn_PtCr_evaluate: Simplify gotos.<br>
-<br>
- All gotos are now forwards.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-20 00:28:58 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c5ae96a828fa459c0093c578ddbfefe0ce0da5de">c5ae96a828fa459c0093c578ddbfefe0ce0da5de</a>
-<blockquote>
-<p>
- Rework cf_decode_2d to minimise gotos.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-19 19:26:22 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d6498f19173bf3213c289e3e4480e7eb0ee9868">0d6498f19173bf3213c289e3e4480e7eb0ee9868</a>
-<blockquote>
-<p>
- Reduce use of goto within cf_decode_1d.<br>
-<br>
- All gotos are now forwards. Hopefully this should assuage LGTM.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-21 12:26:40 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=42ab76c9eb52d5c7dd5f96e0bbee495b84c9d3de">42ab76c9eb52d5c7dd5f96e0bbee495b84c9d3de</a>
-<blockquote>
-<p>
- First Page/Last Page - fix a memory leak<br>
-<br>
- This doesn't exhibit on regular Ghostscript due to garbage collection,<br>
- noticed it while running a Memento build of pdfi to track down a<br>
- different memory leak.<br>
-<br>
- We allocate the enumerator in flp_begin_typed_image() and so we need<br>
- to free it in flp_image_end_image.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-20 11:45:50 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bd48c43be5f736393372dffbad627ed6fc486238">bd48c43be5f736393372dffbad627ed6fc486238</a>
-<blockquote>
-<p>
- Bug 703164: Endian issues with CMM<br>
-<br>
- The interface code to the CMM was corrected to indicate when a<br>
- endian swap was needed on the data. This should only occur<br>
- in the case when we are dealing with transparency buffers<br>
- during the put image blending operation that may include<br>
- a color conversion. The final blend bakes the data as BE<br>
- so if we are on a LE machine, the CMM will need to know to<br>
- swap the bytes (assuming the pdf14 device is using 16bit buffers).<br>
-<br>
- The code was rewritten to make it clear that this setting is no<br>
- BE vs LE but simply an endian swap. That was a source of confusion.<br>
-<br>
- Revealed in this testing was the lack of some proper error<br>
- reporting during buffer conversions, which were fixed.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-20 16:01:33 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bccfeb0626074ca7cf2a60b194509b8b94b38327">bccfeb0626074ca7cf2a60b194509b8b94b38327</a>
-<blockquote>
-<p>
- Memento: Workaround VS2008 not having va_copy.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-20 15:34: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=e2e50a951f3f06c48d908ea8f095e2d7ae2ee5e9">e2e50a951f3f06c48d908ea8f095e2d7ae2ee5e9</a>
-<blockquote>
-<p>
- Bug 703161: Fix unknown error when interpolating transparent imagemasks.<br>
-<br>
- Patch from Alex Cherepanov.<br>
-<br>
- Add a dev_spec_op to check for whether copy_alpha is disabled or not.<br>
- Clist devices with transparency disable it. Use this to bolster the<br>
- decision made in mask_suitable_for_interpolation.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-20 12:35:59 +0000
-</strong>
-<br>Julian Smith &lt;julian.smith@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=86ed012049f58ef01d02c18b8f16c6f343be30db">86ed012049f58ef01d02c18b8f16c6f343be30db</a>
-<blockquote>
-<p>
- demos/python: removed old unused code.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-19 19:08:04 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e83bc652ee4776b2c51878267f1c6f5aef0447db">e83bc652ee4776b2c51878267f1c6f5aef0447db</a>
-<blockquote>
-<p>
- LGTM: Suppress warnings about gotos.<br>
-<br>
- In these functions, for implementing state machines, gotos are<br>
- inevitable.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-19 18:43:25 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cae348d95825d65319a5127f39a954bf68de9ca3">cae348d95825d65319a5127f39a954bf68de9ca3</a>
-<blockquote>
-<p>
- Rejig dict_find so that gotos are all forwards.<br>
-<br>
- Hopefully this will make lgtm happier.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-19 17:50:04 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5e23e7e9daab8498db642fc8ac241ba7f00a157b">5e23e7e9daab8498db642fc8ac241ba7f00a157b</a>
-<blockquote>
-<p>
- LGTM: Attempt to avoid &quot;Expression has no effect&quot; warnings.<br>
-<br>
- Some calls may be NOPs in the lgtm tests, but might not be in<br>
- other builds. Attempt to label them as such.<br>
-<br>
- Possibly we may need to label the call sites rather than the<br>
- functions themselves.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-19 13:26:12 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=905dc88bb9fb75e39dd81ff0268215a1305d94c0">905dc88bb9fb75e39dd81ff0268215a1305d94c0</a>
-<blockquote>
-<p>
- Change init values of PreserveEPSInfo and ParseDSCCommentsForDocInfo<br>
-<br>
- This is needed for pdfi.<br>
-<br>
- The docs (VectorDevices.htm) say these will defaulted to 'true' and<br>
- the gs/PostScript code sets them to true, but they were initialized to<br>
- false in the device itself.<br>
-<br>
- The only place these variables are actually used is in<br>
- pdf_document_metadata() where they are tested to decide whether to<br>
- emit the Metadata.<br>
-<br>
- This change makes no difference for gs and gs/pdf, but it will cause<br>
- gpcl to start including Metadata in its pdfwrite output.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-17 11:24:28 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=385c2f5d06ec9f99be83d64e83b05296caa20051">385c2f5d06ec9f99be83d64e83b05296caa20051</a>
-<blockquote>
-<p>
- Fix bug 703142: typecheck error caused by Length value with decimal point<br>
-<br>
- Thanks to Peter Cherepanov for this patch.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-17 17:55:48 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c1a5382ab783cbae9fd5e069abcc89cb4195e89a">c1a5382ab783cbae9fd5e069abcc89cb4195e89a</a>
-<blockquote>
-<p>
- Bug 703027: Tweak previous fix.<br>
-<br>
- The previous fix was incomplete; the bounds for the overflow<br>
- check were incorrect. Corrected here.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-17 13:32:10 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=658ddea8bc15f4ab7dd4cf1ff151828b9ce957f9">658ddea8bc15f4ab7dd4cf1ff151828b9ce957f9</a>
-<blockquote>
-<p>
- Bug 703027: Avoid Infinite loop.<br>
-<br>
- The problem here is that the scale is so large that the width<br>
- overflows what will fit in an int, and becomes negative.<br>
-<br>
- Harden the code by watching for such overflows, and abandoning<br>
- interpolation if this happens.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-17 11:47:31 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0716daba34064520c2ae0a49edb88095aaceac3c">0716daba34064520c2ae0a49edb88095aaceac3c</a>
-<blockquote>
-<p>
- Update makefiles for new nmake version.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-15 19:59:15 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f82f5a5e381f18a76d7099611202a281e61f343f">f82f5a5e381f18a76d7099611202a281e61f343f</a>
-<blockquote>
-<p>
- Fix bug 703088. ASAN reports read outside allocated buffer of an image.<br>
-<br>
- There was an area in gx_begin_image3_generic setup for bug 700538 to<br>
- detect rangecheck but it did not check all extremes. Note that this<br>
- stems from an absurd CTM in the PDF: 548.0 0 0 -1.43262569e+37 0 0 cm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-16 16:13:53 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e2d58de146abc7bbb5b4f420086b57e500e9181">0e2d58de146abc7bbb5b4f420086b57e500e9181</a>
-<blockquote>
-<p>
- Fix lgtm issue: int * int used as a size_t.<br>
-<br>
- int * int can overflow, before being promoted. Best to promote one of<br>
- the ints to a size_t before the operation, so we don't lose any bits.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-16 15:37:00 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8acc8cf60d99cbd6c9da7c7fd7c2636b09e70624">8acc8cf60d99cbd6c9da7c7fd7c2636b09e70624</a>
-<blockquote>
-<p>
- Tweak memento.c handling of memento.h header.<br>
-<br>
- Intended to remove differences between all the different versions<br>
- of memento.<br>
-<br>
- Rather than manually editing memento.c as we copy it between<br>
- gs/mupdf/extract we now have a MEMENTO_MUPDF_HACKS define to<br>
- enable the mupdf specific changes (currently just where we find<br>
- the header file).<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-16 15:10:51 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b06da3dc08682c57001b3686af38eee0a49cb407">b06da3dc08682c57001b3686af38eee0a49cb407</a>
-<blockquote>
-<p>
- Bug 703146: Fix assert in scan converter.<br>
-<br>
- This is caused by lines changing in x position by more than 1&lt;&lt;31,<br>
- and hence the sign bit of an int being confusing. (e.g. the difference<br>
- between 0x7fffffff and 0x80000000 is positive, but appears negative<br>
- when held in an int). Use an unsigned int instead.<br>
-<br>
- This doesn't affect normal operation as the value is promoted to an<br>
- int64_t before being used.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-16 10:32:06 +0000
-</strong>
-<br>Julian Smith &lt;julian.smith@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1f56cb0a80f9c0485ff224831c4db497da647c0a">1f56cb0a80f9c0485ff224831c4db497da647c0a</a>
-<blockquote>
-<p>
- base/memento.c: fix coverity warnings about need to call va_end().<br>
-<br>
- We now call va_end() for each va_list that we create with va_start() or<br>
- va_copy().<br>
-<br>
- We don't call va_end() for va_list's that are passed in as a function<br>
- argument.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-13 22:39:26 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=07ff645bd83474f01c4fdb658df04f2626bafd7d">07ff645bd83474f01c4fdb658df04f2626bafd7d</a>
-<blockquote>
-<p>
- Bug 702952: Minor fixes to conversion to V2 ICC Profile<br>
-<br>
- The byte padding calculation was wrong and the padded bytes<br>
- were being left uninitialized. In addition, the profile dump<br>
- debug code had bit-rotted.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-13 16:45:31 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f0e2607a2c31f71a469c993b7c6c76db900ca5b1">f0e2607a2c31f71a469c993b7c6c76db900ca5b1</a>
-<blockquote>
-<p>
- Update Memento to match MuPDF and Extract.<br>
-<br>
- Mostly this is pulling in enhancements from Julian Smith.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-13 09:02:07 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f585295725c43827544352852a8ed2a357395b9">2f585295725c43827544352852a8ed2a357395b9</a>
-<blockquote>
-<p>
- Fix Coverity ID 363850<br>
-<br>
- Correct a return to actually return a value (no match found).<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-12 15:12:07 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6b1ee0c65a8caf8f81d2534402af945d2916feb7">6b1ee0c65a8caf8f81d2534402af945d2916feb7</a>
-<blockquote>
-<p>
- pdfwrite - fix OCR processing<br>
-<br>
- We were not correctly updating the operation and size variables after<br>
- we had captured the bitmaps leading the code to error out and drop<br>
- content.<br>
-<br>
- Also, if the OCR engine initialisation fails, don't throw an error,<br>
- just do nothing. Throwing an error results in us falling back to<br>
- rendering the text as bitmaps.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-25 13:56: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=75e260886473a74a8d8ec133b0bae9fdee30818b">75e260886473a74a8d8ec133b0bae9fdee30818b</a>
-<blockquote>
-<p>
- Squashed commit of pdfwrite_ocr branch.<br>
-<br>
- This introduces OCR operation to the pdfwrite device.<br>
-<br>
- The full development history can be seen on the pdfwrite_ocr branch.<br>
-<br>
- The list of individual commits is as follows:<br>
-<br>
- --------------------------------------------<br>
- Interim commit for pdfwrite+OCR<br>
-<br>
- This is the initial framework for pdfwrite to send a bitmap of a glyph<br>
- to an OCR engine in order to generate a Unicode code point for it.<br>
-<br>
- This code must not be used as-is, in particular it prevents the function<br>
- gs_font_map_glyph_to_unicode from functioning properly in the absence<br>
- of OCR software, and the conenction between pdfwrite and the OCR engine<br>
- is not present.<br>
-<br>
- We need to add either compile-time or run-time detection of an OCR<br>
- engine and only use on if present, as well as some control to decide<br>
- when to use OCR. We might always use OCR, or only when there is no<br>
- Glyph2Unicode dictionary available, or simply when all other fallbacks<br>
- fail.<br>
-<br>
- --------------------------------------------<br>
- Hook Tesseract up to pdfwrite.<br>
-<br>
- --------------------------------------------<br>
- More work on pdfwrite + OCR<br>
-<br>
- Reset the stage of the state machine after processing a returned value<br>
-<br>
- Set the unicode value used by the ToUnicode processing from the value<br>
- returned by OCR.<br>
-<br>
- Much more complex than previously thought; process_text_return_width()<br>
- processes all the contents of the text in the enumerator on the first<br>
- pass, because its trying to decide if we can use a fast case (all<br>
- widths are default) or not.<br>
-<br>
- This means that if we want to jump out an OCR a glyph, we need to track<br>
- which index in the string process_text_return_width was dealing with,<br>
- rather than the text enumerator index. Fortunately we are already<br>
- using a copy of the enumerator to run the glyph, so we simply need<br>
- to capture the index and set the copied enumerator index from it.<br>
-<br>
- --------------------------------------------<br>
- Tweak Tesseract build to include legacy engine.<br>
-<br>
- Actually making use of the legacy engine requires a different set<br>
- of eng.traineddata be used, and for the engine to be selected away<br>
- from LSTM.<br>
-<br>
- Suitable traineddata can be found here, for instance (open the link,<br>
- and click the download button):<br>
-<br>
- https://github.com/tesseract-ocr/tessdata/blob/master/eng.traineddata<br>
-<br>
- --------------------------------------------<br>
- Add OCRLanguage and OCREngine parameters to pdfwrite.<br>
-<br>
- --------------------------------------------<br>
- Add gs_param_list_dump() debug function.<br>
-<br>
- --------------------------------------------<br>
- Improve use of pdfwrite with OCR<br>
-<br>
- Rework the pdfwrite OCR code extensively in order to create a large<br>
- 'strip' bitmap from a number of glyphs in a single call to the text<br>
- routine. The hope is that this will provide better context for<br>
- Tesseract and improved recognition.<br>
-<br>
- Due to the way that text enumerators work, and the requirement to exit<br>
- to the PostScript interpreter in order to render glyph bitmaps, I've had<br>
- to abandon efforts to run as a fully 'on demand' system. We can't wait<br>
- until we find a glyph with no Unicode value and then try to render all<br>
- the glyphs up to that point (and all the following ones as well). It is<br>
- probably possible to do this but it would mean rewriting the text<br>
- processing code which is quite hideous enough as it is.<br>
-<br>
- So now we render each glyph in the text string, and store them in a<br>
- linked list. When we're done with the text we free the memory. If we<br>
- find a glyph with no Unicode value then on the first pass we take the<br>
- list of glyphs, create a big bitmap from them and send it to Tesseract.<br>
- That should then return all the character codes, which we keep. On<br>
- subsequent missing Unicode values we consult the stored list.<br>
-<br>
- We need to deal specially with space glyphs (which make no marks) as<br>
- Tesseract (clearly!) can't spot those.<br>
-<br>
- Modify makefile (devs.mak) so that we have a preprocessor flag we can<br>
- use for conditional compilation. Currently OCR_VERSION is 0 for no OCR,<br>
- 1 for Tesseract, there may be higher numbers in future.<br>
-<br>
- Add a new function to the OCR interface to process and return multiple<br>
- glyphs at once from a bitmap. Don't delete the code for a single bitmap<br>
- because we may want to use that in future enhancements.<br>
-<br>
- If we don't get the expected number of characters back from the OCR<br>
- engine then we currently abort the processing. Future enhancements;<br>
- fall back to using a single bitmap instead of a strip of text, if we get<br>
- *more* characters than expected, check for ligatures (fi, ffi etc).<br>
-<br>
- Even if we've already seen a glyph, if we have not yet assigned it a<br>
- Unicode value then attempt to OCR it. So if we fail a character in one<br>
- place we may be able to recognise it in another. This requires new code<br>
- in gsfcmap.c to determine if we have a Unicode code point assigned.<br>
-<br>
- Make all the relevant code, especially the params code, only compile<br>
- if OCR is enabled (Tesseract and Leptonica present and built).<br>
-<br>
- Remove some debugging print code.<br>
-<br>
- Add documentation<br>
-<br>
- --------------------------------------------<br>
- Remove vestiges of earlier OCR attempt<br>
-<br>
- Trying to identify each glyph bitmap individually didn't work as well<br>
- and is replaced by the new 'all the characters in the text operation'<br>
- approach. There were a few vestiges of the old approach lying around<br>
- and one of them was causing problems when OCR was not enabled. Remove<br>
- all of that cruft here.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-11 15:34:31 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8aa60c55d789c9c4d9e600162a1233a2da7ba516">8aa60c55d789c9c4d9e600162a1233a2da7ba516</a>
-<blockquote>
-<p>
- Fix bug 703125: -dNOINTERPOLATE leaves 'true' boolean on the stack.<br>
-<br>
- Thanks to Peter Cherepanov for spotting this. This patch is slightly<br>
- different to his in that it makes -dNOINTERPOLATE=false enable interpolation<br>
- at the default level (the original patch and the old code would have<br>
- disabled interpolation even with 'false'. This version makes the NOINTEPOLATE<br>
- and DOINTERPOLATE options operate more symmetrically, however it is sort of<br>
- moot since both of these options are intended to be replaced by the better<br>
- control on image interpolation provided by -dInterpolateControl=#<br>
-<br>
- Operation tested with fts_17_1712.pdf using the various command line options.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-10 23:38:08 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d1f774ccf8d3c96dc9a40d317e1448cb5a6475a">7d1f774ccf8d3c96dc9a40d317e1448cb5a6475a</a>
-<blockquote>
-<p>
- Bug 701804: Fix for device that causes buffer overflows<br>
-<br>
- This contributed device is odd how it changes its color model.<br>
- Unfortunately it does not change the ICC profile. This mismatch<br>
- between the ICC profile and the color information that is<br>
- being changed by the device causes all sorts of problems. This<br>
- should fix the issue.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-11 12:22:39 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d3a0d4c4c5e6c7c1662094500f25c11b27016268">d3a0d4c4c5e6c7c1662094500f25c11b27016268</a>
-<blockquote>
-<p>
- MSVC: Add sanitize configurations/targets.<br>
-<br>
- While we have 64bit configurations, these will only work for 32<br>
- bit builds at the moment, due to MSVC not supporting 64bit builds.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-10 13:00:49 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c2fa28dbaa4c238eba4c8236d7da3a12113b734c">c2fa28dbaa4c238eba4c8236d7da3a12113b734c</a>
-<blockquote>
-<p>
- PDF interpreter - fix searching for missing Resources in parent object<br>
-<br>
- Bug #703105 &quot;PDF file gives &quot;Unable to determine object number...&quot; and output is missing some images.&quot;<br>
-<br>
- As per the bug thread; the PDF file has annotations which are deeply<br>
- nested forms. The final form stream draws an Image XObject but the<br>
- Form dictionary does not contain a /Resources dictionary so we are unable<br>
- to resolve the name.<br>
-<br>
- The form which calls the final form *does* define the missing XObject,<br>
- this is pretty clearly illegal but Acrobat copes with it. In fact the<br>
- Ghostscript PDF interpreter has code to deal with it too, but there<br>
- was a bug in it, it pops an object that was never pushed, resulting in<br>
- the code being unable to find the resource.<br>
-<br>
- Fixed very simple here. Also uploaded the simplified file for this bug<br>
- and the file for the original bug (700493) to the test repository.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-09 15:39:41 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a7452d624e9ef8f284869a2943b3751ecb6dbd6">9a7452d624e9ef8f284869a2943b3751ecb6dbd6</a>
-<blockquote>
-<p>
- toolbin/localcluster/clusterpush.pl: exclude extract's src/build.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-09 13:53:46 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5a3812294b479fbae21e7d0fa3e1c6e0887fe51e">5a3812294b479fbae21e7d0fa3e1c6e0887fe51e</a>
-<blockquote>
-<p>
- api_test: Simplify pointer hiding.<br>
-<br>
- We can get pointer reuse that can vary from run to run, so we<br>
- resort to just using null/non-null pointer hiding.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-09 13:31:23 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=40d306bf6707c365996eb1d41782ca3f063311d0">40d306bf6707c365996eb1d41782ca3f063311d0</a>
-<blockquote>
-<p>
- ps2write - fix use of /.HWMargins with ps2write output<br>
-<br>
- Bug #703017 &quot;When print a file created with pdf2ps command with a PDF driver, the image shifts to the upper right as the number of pages increases.&quot;<br>
-<br>
- The bug report here is, unfortunately, insufficient to duplicate and<br>
- resolve the problem. The missing information was supplied quite<br>
- independently by the user 'vyvup' on the #ghostscript IRC channel. See<br>
- the #ghostscript logs at around 08:45 on November 9th 2020.<br>
-<br>
- https://ghostscript.com/irclogs/20201109.html<br>
-<br>
- The important missing information is that the device must have the<br>
- Ghostscript-specific page device key /.HWMargins set. When this is set<br>
- and has non-zero values the offsets are applied cumulatively on every<br>
- page by the code in pdfread.ps. This is because we set up the page<br>
- 'view' before we save the current setup in the ps2write dictionary<br>
- under the 'pagesave' key. When we restore back to that at the end of the<br>
- page it therefore does not remove the translation applied to account<br>
- for the /.HWMargins.<br>
-<br>
- Here we just shift the save so that it occurs before we apply the page<br>
- size setup.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-07 13:14:06 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cceb68900b433e7ce518619b9dd2ceb01c4fed9d">cceb68900b433e7ce518619b9dd2ceb01c4fed9d</a>
-<blockquote>
-<p>
- Fix bug 688166. EPS DSC comment processing not terminating properly.<br>
-<br>
- The example files of this bug do not have %%EndComments before other<br>
- BoundingBox comments which confuse the image placement logic resulting<br>
- in a blank page.<br>
-<br>
- This patch, provided by Peter Cherepanov, fixes the problem by stopping<br>
- the DSC processing when (%%BeginProlog) (%%BeginSetup) or %%EndComments<br>
- is encountered.<br>
-<br>
- Cluster regression passes, showing only 1 file that rotates differently<br>
- when -dEPSFitPage is used (just to insure that DSC processing is OK).<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-06 16:31:11 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=abe5348a1de7793a5d4d6ecfa4d054e5f94731de">abe5348a1de7793a5d4d6ecfa4d054e5f94731de</a>
-<blockquote>
-<p>
- apitest: Hide pointer values in output.<br>
-<br>
- This should enable the runtests values to be consistent.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-06 11:18:47 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f6d9adb2e1cf6d7043c1de6168fee42dcb2cb8f">2f6d9adb2e1cf6d7043c1de6168fee42dcb2cb8f</a>
-<blockquote>
-<p>
- Bug 702005 : rectfill and transparency<br>
-<br>
- If we end up in the rectfill operation and we have transparency<br>
- make sure that we take the path that uses gs_fill to ensure that<br>
- pdf14_fill_path is executed, which will update the marking parameters.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-07 00:33:46 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=63281fa98f6df0864315a9fc78ef436a6d96f90a">63281fa98f6df0864315a9fc78ef436a6d96f90a</a>
-<blockquote>
-<p>
- jbig2dec: Add casts to silence a compiler warning.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-05 21:24:13 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2a427e4dfb0b74f121b846e7d08e8c80db0f5f37">2a427e4dfb0b74f121b846e7d08e8c80db0f5f37</a>
-<blockquote>
-<p>
- Bug 703087: CIEBased color space with overprint<br>
-<br>
- If the source space is CIEBased PS type, then be<br>
- sure to use the equivalent ICC color space in<br>
- determining the overprint drawn components.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-05 12:40:00 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0132ddfb73e316303fe382aed939f1145052d15c">0132ddfb73e316303fe382aed939f1145052d15c</a>
-<blockquote>
-<p>
- Bug 703086 -- Disable trying to preserve Movie annotations<br>
-<br>
- Movie annotations are not implemented. This fix just disables the attempt to<br>
- preserve them, so that the pdfwrite output will be valid.<br>
-<br>
- This file has a /Movie annotation that references a local file that<br>
- isn't included in the PDF, so it will never play properly anyway.<br>
-<br>
- The annotation tries to reference a stream in its /Poster entry (for<br>
- the image preview of the Movie), and this was not being handled<br>
- correctly.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-03 22:00:17 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bdf7cf8b6c7c97531aac14e16b9d2c16775ae8c8">bdf7cf8b6c7c97531aac14e16b9d2c16775ae8c8</a>
-<blockquote>
-<p>
- Fix Bug 702034. Missing image to DeviceN devices.<br>
-<br>
- The file from Bug 693300 has a blank image when going to DeviceN devices<br>
- such as psdcmyk and tiffsep. The CompatibleOverprint blend mode must be<br>
- set before the transparency group is pushed.<br>
-<br>
- Add a .special_op for SupportsDevn to let the PostScript PDF interpreter<br>
- detect that the device supports separations.<br>
-<br>
- Make sure the mark fill rect for the knockout case handles<br>
- the hybrid case of additive process colors with subtractive spots<br>
- and overprint.<br>
-<br>
- And make sure the group that is pushed in gstrans.c for text knockouts<br>
- uses compatible overprint if needed.<br>
-<br>
- Ray did the PS parts and Michael did the pdf14dev parts.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-04 09:10:26 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e6d34e7d08dac91b5b3b858c23e186a0d3bcbefc">e6d34e7d08dac91b5b3b858c23e186a0d3bcbefc</a>
-<blockquote>
-<p>
- pdfwrite - Fix potential seg faults with ColorConversionStrategy<br>
-<br>
- Bug #702885 &quot; ICC profile management can lead to a crash due to lack of reference counting of profiles&quot; ICC profile management can lead to a crash due to lack of reference counting of profiles<br>
-<br>
- See the bug report for details, this commit removes the dereference of<br>
- the ICC profile as recommended by Michael in that thread.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-03 15:21:46 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=10036de9c385d900f2ec0312908954ab77664438">10036de9c385d900f2ec0312908954ab77664438</a>
-<blockquote>
-<p>
- Update clusterpush.pl for extract jobs.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-11-03 09:24:37 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b4c9f0004f950a7f55fff5777c6fa0d74d1f54bd">b4c9f0004f950a7f55fff5777c6fa0d74d1f54bd</a>
-<blockquote>
-<p>
- Fix bug 702957, 702971. PageList problems with PDF input files.<br>
-<br>
- Thanks to Peter Cherepanov for this fix.<br>
-<br>
- The page skipping was caused by not disabling the PageHabdler in<br>
- even or odd page selection modes due to a typo (Pagelist instead of<br>
- PageList). The PDF interpreter fed only the odd (or even pages),<br>
- and then the PageHandler also skipped every other page.<br>
-<br>
- Also correct log messages and associated operand stack mess-up.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-31 18:38: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=3f191b620de1b1cdead14305aac09ad49340828f">3f191b620de1b1cdead14305aac09ad49340828f</a>
-<blockquote>
-<p>
- Fix another SEGV with BGPrint due to device_unsubclass<br>
-<br>
- The printer device needs to have the bg_print structure external to the<br>
- device so that when the device is freed the bg_print communication area<br>
- shared with the thread doesn't get freed. This is similar to the clist<br>
- band_range_list issue.<br>
-<br>
- The SEGV was seen with 15-01.BIN as it unsubclasses the PCL_Mono_Palette<br>
- gs_pcl_mono_palette_device device.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-31 10:48:22 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8df410c269150bce143d3b8875ac9d60a013d206">8df410c269150bce143d3b8875ac9d60a013d206</a>
-<blockquote>
-<p>
- Set orig_spec_op for printer class devices so it forwards properly.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-29 15:15:00 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c5a8a34dd741936469f0500cfebe364d8a1fdc3">2c5a8a34dd741936469f0500cfebe364d8a1fdc3</a>
-<blockquote>
-<p>
- FIx SEGV with gx_device_unsubclass when child is a clist device.<br>
-<br>
- The 'band_range_list' was a structure of two pointers within the device<br>
- (gx_device_clist_writer) so when it was copied, the 'ccl' pointer could<br>
- point to the band_range_list structure in the child device. This pointer<br>
- would no longer be valid when the child device was freed as the device<br>
- unsubclass did.<br>
-<br>
- Detected with 15-01.BIN as it called gx_device_unsubclass for the PCL_mono<br>
- subclass device. With -Z@ the band_range_list would be overwritten with<br>
- (known, but invalid pointer) data resulting in the SEGV.<br>
-<br>
- Cured by putting the band_range_list into the clist_writer 'data' area.<br>
- This area is not GC'ed and since it points into other memory in the<br>
- clist writer 'cbuf' area, it is internal to the clist writer.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-26 20:45:48 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9848e66c0687645ed533e50557c233bf196ec9b9">9848e66c0687645ed533e50557c233bf196ec9b9</a>
-<blockquote>
-<p>
- Make gs_next_ids thread safe by using the core-&gt;monitor.<br>
-<br>
- This cures data races with gs_next_ids seen with helgrind and BGPrint<br>
- and/or NumRenderingThreads.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-26 18:36:16 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eec6fd158ee477facfb4bf9edd4e99506c195732">eec6fd158ee477facfb4bf9edd4e99506c195732</a>
-<blockquote>
-<p>
- Pacify helgrind so that gs_heap_status is thread safe.<br>
-<br>
- The 'heap_available' is documented as a 'snapshot', but is not a<br>
- thead risk. This change locks around the collection of the info to<br>
- be returned in the gs_memory_status structure.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-15 08:51:08 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=13ed12281b6b60804172a6844081a9ea3e067d2d">13ed12281b6b60804172a6844081a9ea3e067d2d</a>
-<blockquote>
-<p>
- Fix problem with BGPrint and multi-threaded rendering caused by commit cca27988<br>
-<br>
- The unconditional call to enable multi-threaded rendering during set up of the<br>
- gx_device_printer as a clist caused the SEGV of bug 702181, but enabling<br>
- multi-threaded rendering here isn't correct since it is usually done when we<br>
- output the page (gdev_prn_output_page_aux). The problem is that BGPrint would<br>
- setup a new clist device to render the page, but needs to enable multi-threaded<br>
- rendering for the background clist device. Do this if NumRenderThreads &gt; 0.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-22 13:10:04 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ceaf92815302863a8c86fcfcf2347e0118dd3a5">4ceaf92815302863a8c86fcfcf2347e0118dd3a5</a>
-<blockquote>
-<p>
- Fix gp_file allocations to use thread_safe_memory.<br>
-<br>
- The gpmisc.c does allocations for gp_file objects and buffers used by<br>
- gp_fprintf, as well as gp_validate_path_len. The helgrind run with<br>
- -dBGPrint -dNumRenderingThreads=4 and PCL input showed up the gp_fprintf<br>
- problem since the clist rendering would call gp_fprintf using the same<br>
- allocator (PCL's chunk allocator which is non_gc_memory). The chunk<br>
- allocator is intentionally not thread safe (for performance).<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-28 12:17:23 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=033ed8bf196b1cddd681a9b32d9398bf6bc02d24">033ed8bf196b1cddd681a9b32d9398bf6bc02d24</a>
-<blockquote>
-<p>
- Bug 702671: Make sure X11 device cleans up with closure<br>
-<br>
- The issue is that the pdf14 device will close and reopen the<br>
- target device under certain cases and the X11 devices were not<br>
- cleaning themselves up sufficiently. Also added a finalize<br>
- method where the call to XCloseDisplay should actually be made.<br>
-<br>
- The pdf14 device does this close and open dance to ensure that<br>
- the page_has_transparency parameter will be set in the device.<br>
- It is possible that we could end up in the pdf14 device<br>
- push without page_has_transparency if the call is done from<br>
- Postscript code. The PDF interpreter<br>
- always sets the page_has_transparency value before doing the<br>
- push so this should not be a problem with PDF.<br>
-<br>
- Thanks to Chris Liddell for helping with this.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-29 10:43:46 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36568c21f45ed0686abec8316f56bc171ab416a8">36568c21f45ed0686abec8316f56bc171ab416a8</a>
-<blockquote>
-<p>
- Add /Type /Outlines to Outlines entry for pdfwrite<br>
-<br>
- This is technically required, but appears to be harmless to omit it.<br>
- However, since the fix is trivial, I have fixed it.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-29 15:49:11 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=14a3807f1a13d7a4fed1b1ef24852d55a4361431">14a3807f1a13d7a4fed1b1ef24852d55a4361431</a>
-<blockquote>
-<p>
- Fix ios build script and headers<br>
-<br>
- The predefined headers for the ios build were missing the size_t updates.<br>
-<br>
- We also don't want to try using CAL with ios (at least, for the moment).<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-28 17:07:20 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=10ff34748a56d521b5a901c11edb4b6408a2860a">10ff34748a56d521b5a901c11edb4b6408a2860a</a>
-<blockquote>
-<p>
- Fix an option typo: &quot;nonredundnat&quot; -&gt; &quot;nonredundant&quot;<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-28 15:31:28 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ddd5cf4ddcfba1a3e85708b75efa0d8f8f4156f6">ddd5cf4ddcfba1a3e85708b75efa0d8f8f4156f6</a>
-<blockquote>
-<p>
- pdfwrite - fix Type 4 Chroma-keyed images with Colour Conversion<br>
-<br>
- Bug #702698 &quot;convert Grayscale error in output&quot;<br>
-<br>
- Images with a /Mask where the Mask is a range of values, and hence a<br>
- chroma-keyed image, as opposed to the Mask being an external Image<br>
- Mask, and therefore a stencil cannot be preserved as such when we are<br>
- colour converting.<br>
-<br>
- There is no reliable way to be certain that the colour of the image<br>
- samples after conversion and the converted Mask values will relate in<br>
- the same way. Its entirely possible for multiple RGB values to map to<br>
- the same gray value for instance, and if that happens to be a masked<br>
- value then pixels will be masked which were not originally.<br>
-<br>
- This commit checks the ColorConversionStrategy and if it is not<br>
- LeaveColorUnchanged then we further examine the Mask. If the Mask is a<br>
- range of values then we consider the colour space of the image.<br>
-<br>
- If ColorConversionStrategy is not LeaveColorunchanged and the image has<br>
- a range of values and it is not in the target colour space, then we<br>
- cannot preserve it. In this case we fall back to either preserving the<br>
- image, and creating a clip path from the chroma key and the image<br>
- samples, or (if Version &lt; 1.3) we fall right back to writing each image<br>
- sample as a filled rectangle.<br>
-<br>
- This does, of course, result in larger output.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-13 08:16: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=81ed663a4a81a265afecbc7b7c7835ba4f5f24e1">81ed663a4a81a265afecbc7b7c7835ba4f5f24e1</a>
-<blockquote>
-<p>
- Change default ShowAcroForm to true to match Adobe Acrobat.<br>
-<br>
- Change it and the documentation. It may be that older Acrobat defaulted to<br>
- ignoring AcroForm, but current Adobe doesn't.<br>
-<br>
- Also fix pdf_draw draw_form_field to match check in pdf_main process_trailer_attrs<br>
- for the file from Bug 692447 which has null entries in Fields array.<br>
-<br>
- Fix indentation in pdf_main process_trailer_attrs area that processes<br>
- AcroForm dict.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-17 12:52:36 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8313e4f30bef7c50711cd503c3037184a7850d51">8313e4f30bef7c50711cd503c3037184a7850d51</a>
-<blockquote>
-<p>
- Fix Bug702995: Inconsistent auto-rotation of EPS with EPSFitPage.<br>
-<br>
- We need to defer the EPSFitPage scaling, centering and rotation until<br>
- after both the the %%BoundingBox and/or the %%HiResBoundingBox have been<br>
- processed. Doing one after the other results in slight rounding diffs<br>
- depending on the resolution. Change to save the value (prefering the<br>
- HiResBoundingBox) and do the scaling/translate/rotate only once when<br>
- %%EndComments is processed.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-13 08:21:05 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=76359f0c03e8b4d8db7359d521865894ac7a4592">76359f0c03e8b4d8db7359d521865894ac7a4592</a>
-<blockquote>
-<p>
- Fix bug 702951. Valgrind error in image_render_interpolate_landscape_icc<br>
-<br>
- Make the same adjustment in image_render_interpolate_landscape_icc() as<br>
- was done in image_render_interpolate_icc() by the commit a936cf76.<br>
-<br>
- Thanks to Peter Cherepanov for this bug report and the patch. Regression<br>
- testing looks fine and the previous code looks like it would bump the<br>
- p_cm_interp value twice in some cases previously.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-23 08:54: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=9cdacf4e5efcf7b92ff7a02158a47ac04cc12fa7">9cdacf4e5efcf7b92ff7a02158a47ac04cc12fa7</a>
-<blockquote>
-<p>
- Revise font dir global_glyph_code callback API<br>
-<br>
- The global_glyph_code callback API relies on the name table being avaiable in<br>
- the gs_lib_ctx and accessible via the gs_memory_t object.<br>
-<br>
- This is not something that is true, nor can we make it true, for pdfi. Because<br>
- pdfi is required to integrate with the Postscript interpreter, we cannot have<br>
- the gs_lib_ctx &quot;top_of_system&quot; pointer point to the pdfi context.<br>
-<br>
- So, change the global_glyph_code API so it takes a gs_font pointer, instead of<br>
- a gs_memory_t pointer. The Postscript implementation will work exactly the same,<br>
- just accessing the gs_memory_t through the gs_font pointer.<br>
-<br>
- But it allows pdfi to grab it's own context through the gs_font &quot;client_data&quot;<br>
- pointer.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-20 11:20: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=17cec404918eb458b63aba71fe680264f2a00179">17cec404918eb458b63aba71fe680264f2a00179</a>
-<blockquote>
-<p>
- Update freetype to 2.10.4<br>
-<br>
- Also includes:<br>
- Work around a change in the zlib API for 1.2.11<br>
-<br>
- where it's used in the Freetype/zlib interface debugging code.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-21 16:11:23 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=660aa7a7eaeca446d97332ae1655a3612c9bcfe6">660aa7a7eaeca446d97332ae1655a3612c9bcfe6</a>
-<blockquote>
-<p>
- Add error check on gx_device_text_begin return_error<br>
-<br>
- gx_device_text_begin may return an error if there is still<br>
- work to be done on a pattern device. Catch that before<br>
- the check on *ppte, which will not be a valid value in this<br>
- case.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-22 17:20: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=7670751b807e369e4bb768cce2812a8d8719b8fa">7670751b807e369e4bb768cce2812a8d8719b8fa</a>
-<blockquote>
-<p>
- Fix typos in comments of zugferd program<br>
-<br>
- As (mostly) spotted by Lisa Fenn, fix comments in typos and messages.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-21 19:20: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=b231780b739720451e8d6517b2e97a07908b7469">b231780b739720451e8d6517b2e97a07908b7469</a>
-<blockquote>
-<p>
- lcms2: automatically align blocks appropriately on sparc.<br>
-<br>
- The sparc architecture requires pointers within structures to<br>
- be at 64bit alignment, even if they are 32bit pointers.<br>
-<br>
- LCMS2 allows for this by having a CMS_PTR_ALIGNMENT symbol<br>
- that can be predefined. If it's not predefined, it defaults to<br>
- sizeof(void *).<br>
-<br>
- We update the source here so that when building for sparc, it<br>
- defaults to 8. This shouldn't affect gs, as it sets the value<br>
- via configure/make. I believe our lcms2 repo as used in MuPDF<br>
- is autogenerated from this though, and this will help us there.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-20 12:38:24 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=337be82addaaf8740b60e2a0cf354ae96d46468f">337be82addaaf8740b60e2a0cf354ae96d46468f</a>
-<blockquote>
-<p>
- Correct OCR docs for multiple languages.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-20 09:49: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=41ef9a0bc36b9db7115fbe9623f989bfb47bbade">41ef9a0bc36b9db7115fbe9623f989bfb47bbade</a>
-<blockquote>
-<p>
- Bug 702985: drop use of FT_CALLBACK_DEF() def<br>
-<br>
- From 2.10.3, Freetype disappeared the FT_CALLBACK_DEF() macro, which is what<br>
- we used when defining our callbacks from Freetype.<br>
-<br>
- No guidance forthcoming from the Freetype developer who made those changes,<br>
- so change to explicitly declaring the callbacks file static.<br>
-<br>
- Should fix the reported build failures.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-31 11:07:18 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3b2f9c53c8e5cebcf80a4158684b820d9a0a2f73">3b2f9c53c8e5cebcf80a4158684b820d9a0a2f73</a>
-<blockquote>
-<p>
- devices/vector/gdevtxtw.c: updated extract output to match mupdf.<br>
-<br>
- Text extraction now works for Python2.pdf and zlib.3.pdf.<br>
-<br>
- Added GlyphWidths[] and SpanDeltaX[] arrays, containing information required<br>
- for generating intermediate format used by extract system.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-30 13:09:51 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=de5cb392ad32d4e44646b144f435ad186f3dbabe">de5cb392ad32d4e44646b144f435ad186f3dbabe</a>
-<blockquote>
-<p>
- doc/VectorDevices.htm: added brief info about txtwrite TextFormat=4.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-19 16:34:32 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5c115ea0d27640b2a3940410c6eeef9e7d17f178">5c115ea0d27640b2a3940410c6eeef9e7d17f178</a>
-<blockquote>
-<p>
- Fix indeterminisms within halftoned rendering.<br>
-<br>
- When checking for pdf14 being in an opaque state, we check to see<br>
- whether we are either constructing an SMask or are within an<br>
- SMask. We need to use a dev spec op for this, as we might be within<br>
- a clipper device, and so not actually be directly a pdf14 device.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-19 11:24:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5fc95757e3f732d5806a9a74967d70571eec91db">5fc95757e3f732d5806a9a74967d70571eec91db</a>
-<blockquote>
-<p>
- New file - program to assist in creating ZUGFeRD electronic invoices<br>
-<br>
- While documenting the process for creating a ZUGFeRD invoice from a PDF<br>
- file and an XML invoice it became clear to me that it was beyond any<br>
- reasonable expectation of a user to be able to use it unaided. So this<br>
- program assists in the creation of a ZUGFeRD document.<br>
-<br>
- The program requires two command line parameters; -sZUGFeRDProfile=<br>
- which contains a fully qualified path to an appropriate (correct colour<br>
- space) ICC profile, and -sZUGFeRDXMLFile= which contains a fully<br>
- qualified path to the XML invoice file.<br>
-<br>
- Example command line is in the comments, and a usage message if the user<br>
- fails to provide either of the required elements. Obviously the user<br>
- must also set -dPDFA=3 and -sColorConversionStrategy in order to create<br>
- a valid PDF/A-3b file.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-14 11:28:56 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23afb36c6d8c5368a7df09718b872f83c510cab7">23afb36c6d8c5368a7df09718b872f83c510cab7</a>
-<blockquote>
-<p>
- Bug 702891 and Bug 700593 Fix pdf14 device color procs<br>
-<br>
- The pdf14 color mapping procs clearly had some issues as they are reading uninitialized<br>
- memory and using transfer functions that would not make sense with changing<br>
- color spaces. Also, the soft mask should not be going through the effective_transfer.<br>
- It has its own transfer function to deal with. Careful reading of the PDF spec revealed<br>
- that the transfer function is only to be used if the color being drawn is opaque. It<br>
- states that this is true if the blend mode is normal, stroke and fill alpha are 1.0, and<br>
- no soft mask is present. Also, an image that has a soft mask does not use the transfer<br>
- function. These changes resulted in a lot of diffs. I reviewed them and<br>
- did some checking of color values to verify things are ok.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-14 15:05:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fceb46d81b0277b335481368dcc5a62e6383575e">fceb46d81b0277b335481368dcc5a62e6383575e</a>
-<blockquote>
-<p>
- PDF interpreter (with pdfwrite) - another non-square scaling stroke fix<br>
-<br>
- Bug #702946 &quot;Ghostscript creates PDF originals with black stripes&quot;<br>
-<br>
- This is another case of the problem in bug #702900, The commit to fix<br>
- that problem (d5494de2cab28b91ba360d15b8afffef50a3f421) fixed four<br>
- places in the code, but missed a fifth place because it is distant from<br>
- the other four. The offending procedure is setstrokeforTrpreservation.<br>
-<br>
- This commit adds the required code to that location to go along with the<br>
- other four, at the same time:<br>
-<br>
- 1) Move the actual code to calculate the width into a procedure<br>
- 2) Have all 5 places use that procedure<br>
- 3) Improve the non-square calculation (hypotenuse/2 instead of hypotenuse)<br>
- 4) Add some 'tolerance' to the equality test.<br>
-<br>
- The tolerance is because both the test file here and in 702900 have a<br>
- CTM which is minutely non-square. In this case the c and y scaling<br>
- differ by less than 0.0001. The intention of this code is actually to<br>
- deal with non-square resolutions, rather than non-square CTM, and it<br>
- does so by calculating the hypotenuse of a triangle where the x an y<br>
- values are the linewidth in each direction. In fact the hypotenuse/2<br>
- seems a closer approximation. But in any event its incorrect, better to<br>
- simply use the linewidth if the difference between the two is not very<br>
- large. (eventually, with pdfi, we will probably do away with this<br>
- horrible kludge entirely)<br>
-<br>
- This causes minor but useful progressions in the test suite files<br>
- Bug695841.pdf, clipping_image_problem.pdf and<br>
- sumatra/712_-_image_not_displaying.pdf. most notably the latter.<br>
-<br>
- It also produces slightly less bold output for the test file here,<br>
- which Acrobat shows as matching precisely with the original.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-07 17:41:36 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6ce09aa5c9ed0c66c597478a2c4fb75aa25267f">c6ce09aa5c9ed0c66c597478a2c4fb75aa25267f</a>
-<blockquote>
-<p>
- Revert &quot;Remove deprecated opvp/oprp devices from default build&quot;<br>
-<br>
- This reverts commit 66c2469c7d4543f32d6dc93edf1d649e809b8419.<br>
-<br>
- A user got in touch to say that he maintains a printer driver &quot;back end&quot; that<br>
- uses the opvp device. So reinstating it - at least we know it's getting<br>
- tested.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-12 13:19:09 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5af4f31bcda18c6fb7d14501c0a22697a7f49ac0">5af4f31bcda18c6fb7d14501c0a22697a7f49ac0</a>
-<blockquote>
-<p>
- Update tesseract traineddata loader with new path search.<br>
-<br>
- First, we look in TESSDATA_PREFIX (if defined).<br>
-<br>
- If not found there, we look in ROMFS (in tessdata).<br>
-<br>
- If not found there, we look at the configured &quot;tessdata&quot; path<br>
- (which defaults to ${datadir}/tessdata). (${datadir} defaults to<br>
- ${prefix}/share on unix, and ${gsrootdir} on windows.)<br>
-<br>
- If not found there, we look in the current directory.<br>
-<br>
- Update doc/Devices.html (and fix some indexing).<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-13 11:05: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=848077c4f7b8b9131263b483ba90b05e0ee4e9d2">848077c4f7b8b9131263b483ba90b05e0ee4e9d2</a>
-<blockquote>
-<p>
- pdfwrite - reorder code to change evaluation order of image parameters<br>
-<br>
- Bug #702961 &quot;GS produces significantly larger PDFs with same settings as Adobe Distiller&quot;<br>
-<br>
- This is a problem with the interaction of various image parameters. The<br>
- relevant options are PassThroughJPEGImages, ColorConversionStrategy and<br>
- AutoFilterColorImages.<br>
-<br>
- Because PassThroughJPEGImages is true, we don't set up a compression<br>
- filter (we don't want to apply compression to a DCT compressed data<br>
- stream). But ColorConversionStrategy is /sRGB, so we then turn off the<br>
- PassThroughJPEGImages (we cannot change the colour model and still<br>
- pass through the original data, obviously). Ordinarily the compression<br>
- chooser would then select a compression based on the result, but<br>
- AutoFilterColorImages is false, so the compression chooser is disabled.<br>
-<br>
- The result is that we write uncompressed image data to the file.<br>
-<br>
- By reordering the code so that we check the ColorConversionStrategy<br>
- earlier we can turn off PassThroughJPEGImages before selecting the<br>
- initial compression which means that this p[articular sequence of<br>
- options will then work as expected.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-26 12:05:46 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=02e3169b57724f63ce01c994d39c20647be5c20b">02e3169b57724f63ce01c994d39c20647be5c20b</a>
-<blockquote>
-<p>
- Bug 702192 Map text to black<br>
-<br>
- Map all text to black. This is achieved by altering the<br>
- color space to DeviceGray with a fill of black during<br>
- gs_text_begin. When gs_text_release occurs, the color space<br>
- is restored. This will only occur with the option -dBlackText<br>
- and if the text is actually to be drawn.<br>
-<br>
- When going to a raster device, the stroke and stroke fill of<br>
- the text is handled with a stroke or stroke fill command.<br>
- My original plan of storing the old color spaces and client<br>
- color in the text enumerator will not work in this<br>
- situation as it the enumerator will have already been<br>
- destroyed when the stroke or stroke/fill command occurs.<br>
- For this reason I store the old color space information<br>
- for the current and alternate color spaces<br>
- in the graphic state. The structure holding the information<br>
- is garbage collected as it is holding objects that may be<br>
- garbage collected. We also need to know if the target<br>
- was a high level device like pdfwrite, as that device<br>
- will handle the fill AND stroke, and we will need to restore<br>
- the color space when we tear down the text enumerator.<br>
-<br>
- gs_text_release needed to have the pgs added as a parameter<br>
- to allow the possible release of the blacktext structure<br>
- when the text is released from the other languages. This<br>
- did not seem to be too big of an issue as gs_text_begin<br>
- passes the pgs also. If the pgs is not available, NULL can<br>
- be passed, and that is done in several locations.<br>
-<br>
- A new special op was added to let us avoid doing the black<br>
- text setting if we are constructing a soft mask. If we did not<br>
- do this the mask could result in the loss of the text.<br>
-<br>
- Finally, Type 3 fonts will NOT be affected by this process.<br>
- Type 3 fonts are often used for actual graphic logos etc.<br>
- Ken Sharp suggested we not have them affected by this setting.<br>
- There were also issues with trying to do type 3 fonts in<br>
- in that the PDF interpreter does some color space settings<br>
- of its state when dealing with type 3 fonts and this put the<br>
- interpreter's state out of sync with the graphic library state.<br>
-<br>
- This was tested with a forced setting of black text enabled.<br>
- No seg faults or errors occurred. There were obviously a lot<br>
- of differences reported (over 33,000). All the images that were available<br>
- to me with bmpcmp were gone through. Problems were found<br>
- and addressed (the soft mask issue for example was found,<br>
- as were issues with color spaces not getting properly restored).<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-12 16:10: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=1ff2ddac001612df3d54b504b49f6ee8e0685be7">1ff2ddac001612df3d54b504b49f6ee8e0685be7</a>
-<blockquote>
-<p>
- PostScript interpreter - add a new IdiomSet for PPI 'ColorUtils'<br>
-<br>
- Bug #702964 &quot;EPS file hangs with pdfwrite&quot;<br>
-<br>
- This is not related to the hang, but to the remaining problem with this<br>
- file and pdfwrite.<br>
-<br>
- When using pdfwrite with PassThroughJPEGImages the output is incorrect.<br>
- The reason is that the PostScript program processes the JPEG compressed<br>
- data, turning a 4-component CMYK image into a single component gray<br>
- image.<br>
-<br>
- Obviously if we pass through the original CMYK data, but declare the<br>
- image a DeviceGray the result is incorrect.<br>
-<br>
- The only way to deal with this is to turn off the feature. There's no<br>
- simple way to do this in pdfwrite (where we normally decide to turn it<br>
- off, for downsampling etc) without disabling it for a number of other<br>
- useful cases. So instead add a new IdiomSet which replaces part of the<br>
- PPI ColorUtils ProcSet with a redefined procedure which turns off the<br>
- PassThroughJEPGImages feature if the ProcSet forces Gray output.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-12 16:05:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=447d30a88cf38d623c9afa783ff0a16b98f9e4ff">447d30a88cf38d623c9afa783ff0a16b98f9e4ff</a>
-<blockquote>
-<p>
- pdfwrite - Terminate pass-through images when we have read enough data<br>
-<br>
- Bug #702964 &quot;EPS file hangs with pdfwrite&quot;<br>
-<br>
- This is only a partial fix for the bug report, the remaining problem<br>
- is addressed in a following commit.<br>
-<br>
- The problem here is that the EPS file includes a ProcSet which processes<br>
- the JPEG compressed data. It does so using a procedural DataSource for<br>
- the image operator. Unfortunately the procedure fails to spot that<br>
- readstring returns 0 bytes and identify this as en EOD. Instead it<br>
- continues to try and read data, which continuously fails.<br>
-<br>
- While the cause of the hang is in the PostScript program, it does not<br>
- normally exhibit because the image operator ceases to read data from the<br>
- DataSource when it has read enough samples to satisfy the declared<br>
- Width/Height/BPC. An oversight in the pass-through code meant that the<br>
- image operator wasn't properly terminating even when enough data had<br>
- been supplied.<br>
-<br>
- This commit correctly returns either 0 (require more data) or not-zero<br>
- (enough data read) so that the operator terminates.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-12 13:18:16 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d4777d3bfa3fe17297d52eb318b4b93e1b0485b6">d4777d3bfa3fe17297d52eb318b4b93e1b0485b6</a>
-<blockquote>
-<p>
- Update makefile for tesseract changes.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-12 08:10: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=965f842329e697a945a40ba1ff9a578612bf9f16">965f842329e697a945a40ba1ff9a578612bf9f16</a>
-<blockquote>
-<p>
- Coverity ID 363024: Check gs_sprintf() retrn value<br>
-<br>
- before we use it.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-07 14:14:37 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b2a7564bc80f61095e7dd3024f1ce51026366909">b2a7564bc80f61095e7dd3024f1ce51026366909</a>
-<blockquote>
-<p>
- Add/remove paths to permit-file-read automatically for tesseract.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-07 11:50: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=1bbd20f2f099c63e5d325979e43182b617e9fb3a">1bbd20f2f099c63e5d325979e43182b617e9fb3a</a>
-<blockquote>
-<p>
- Fix Tesseract build glitches.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-02 15:03: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=9666e6206135b637b7545f074a25969972662252">9666e6206135b637b7545f074a25969972662252</a>
-<blockquote>
-<p>
- Squash a compiler warning (uninitialized variable)<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-02 14:52: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=5e85cde6eb20fc1f6ae13c69f80cc800cbacf164">5e85cde6eb20fc1f6ae13c69f80cc800cbacf164</a>
-<blockquote>
-<p>
- &quot;Address&quot; subscript -1 is outside array bounds warning<br>
-<br>
- There is no immediate prospect of resolving the underlying issue: that the<br>
- stream code requires the data pointer in the &quot;cursor&quot; to be initialised to the<br>
- address one byte *before* the beginning of the actual buffer.<br>
-<br>
- We also do not want to disable the array bounds warning completely, as that<br>
- risks missing real mistakes.<br>
-<br>
- So, define a static inline function which does the offending pointer assignment,<br>
- and disable the warning locally, for only that function. Then have everywhere<br>
- that uses such a buffer setup call that function, rather than do the assignment<br>
- itself.<br>
-<br>
- At the moment, it is only disabled for gcc (and compatible) compilers, we can<br>
- add others if/as required.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-01 16:06: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=fd902c6702ef81008d7c91b09a0723661c0f9201">fd902c6702ef81008d7c91b09a0723661c0f9201</a>
-<blockquote>
-<p>
- oss-fuzz 23946: Move buffer bounds check to *before* using it!<br>
-<br>
- ASCII85Decode filter: We correctly bounds check the buffer size, but dumbly<br>
- were doing so *after* we'd used the relevant indices into the buffer. Change<br>
- that order, and add another check.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-17 08:26: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=aaeccfffecee65225dabac32689a15a239d01681">aaeccfffecee65225dabac32689a15a239d01681</a>
-<blockquote>
-<p>
- Change order of compiler options for third party libs<br>
-<br>
- Move the compiler parameters around so the third party lib specific -I options<br>
- come first - hopefully meaning we'll favor any included headers over those in<br>
- the system include path(s).<br>
-<br>
- This assumes the compiler searched include directives given on the command line<br>
- left to right. Apparently this used to be a problem, I've not found a recent<br>
- compiler that breaks that assumption (yet!).<br>
-<br>
- This applies to: expat, freetype, ijs, jbig2dec, jpeg, jpegxr, openjpeg, png<br>
- tiff and zlib<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-16 18:58:05 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=978df385c36ee4d65c9144924d0224243a5ebb71">978df385c36ee4d65c9144924d0224243a5ebb71</a>
-<blockquote>
-<p>
- Added PDL_DYNAMIC_LDFLAGS to $host *bsd* section<br>
-<br>
- to match the other platforms.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-16 18:49:42 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=477d315af46d9a7932108135137adc7aebfc77fe">477d315af46d9a7932108135137adc7aebfc77fe</a>
-<blockquote>
-<p>
- Use pkg-config to get CFLAGS for libidn<br>
-<br>
- We already get the libs, missing the CFLAGS (mainly the -I) was just an<br>
- omission.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-28 12:54: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=c97c4ebb08474e1fbd9a3a6db71da52330f2d67b">c97c4ebb08474e1fbd9a3a6db71da52330f2d67b</a>
-<blockquote>
-<p>
- Bring master up to date 9.53.x branch<br>
-<br>
- Docs/dates/version for 9.53.3<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-01 10:18:33 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f7646980a69dc3b302b0640220347b9865f49d0e">f7646980a69dc3b302b0640220347b9865f49d0e</a>
-<blockquote>
-<p>
- Fix preserving Line annotations without AP<br>
-<br>
- This only affects the pdfwrite device.<br>
-<br>
- It was rescaling the /L entry for no apparent reason, which meant the<br>
- Line annotations rendered incorrectly when they had no AP.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-01 19:01: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=df537046c2130be285b213b5d0478159d1c5b16d">df537046c2130be285b213b5d0478159d1c5b16d</a>
-<blockquote>
-<p>
- Initialise a variable to silence a compiler warning<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-01 18:01:00 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dee305c09cb60af041c0cc0b301f5fa8347eccc2">dee305c09cb60af041c0cc0b301f5fa8347eccc2</a>
-<blockquote>
-<p>
- Update makefiles for another version of nmake.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-01 09:15:37 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1039ade1c0e0066f03a22598edb327648f59d578">1039ade1c0e0066f03a22598edb327648f59d578</a>
-<blockquote>
-<p>
- Squash a couple of compiler warnings.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-10-01 15:48: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=61e227ed7bcdddd652f32f14539702773fcbcf33">61e227ed7bcdddd652f32f14539702773fcbcf33</a>
-<blockquote>
-<p>
- pdfimage devices - fix %Invocation and add /Info dictionary<br>
-<br>
- I'd thought that we had missed off the %Invocation from the PDF output<br>
- of the PDF image devices, but in fact it was only that the pdfocr<br>
- devices had it emitted in a surprising place in the file.<br>
-<br>
- That's fixed here just by moving when we write it so that its location<br>
- is consistent between the devices.<br>
-<br>
- Moved some definitions common to both pdfimage and pdfocr from the<br>
- device's .c files to the pdfimage.h file.<br>
-<br>
- Added emission of a very basic /Info dictionary. To facilitate future<br>
- enhancements the number of 'static' (ie predefined) objects has been<br>
- turned into a #define and we use that wherever possible instead of the<br>
- previous hard-coded magic number. Because of the font objects required<br>
- for pdfocr, and the fact that they refer to each other, these still<br>
- don't use the #define and will have to be manually adjusted if we ever<br>
- change this again.<br>
-<br>
- Acrobat ignores the /Info dictionary, apparently it only reads the XML<br>
- /Metadata values (at least in modern versions), so adding the Info<br>
- dictionary doesn't help. Creating the XMP metadata is unfortunately<br>
- quite complicated, we'd need to steal quite a bit of code from pdfwrite<br>
- and at the moment I think its more trouble than its worth. I may change<br>
- my mind in future.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-29 20:16: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=6290ce42ac84767a84ddc949c9348a194477ab9b">6290ce42ac84767a84ddc949c9348a194477ab9b</a>
-<blockquote>
-<p>
- Bug 702948: Ensure initial bitmap cache sizes are properly aligned<br>
-<br>
- Now that the allocations from the bitmap cache are aligned to the platform's<br>
- required alignment, see commit:<br>
-<br>
- 260c443bc14cdffa4d94e14c3a57e35bebee3a5b<br>
-<br>
- We also want the initial size of the memory pool used by the cache to be<br>
- &quot;aligned&quot;.<br>
-<br>
- This is so that code that attempts to identify cache entries to evict by<br>
- requesting a size equal to the entire size of cache memory pool doesn't get an<br>
- unexpected failure, because we've rounded up that allocation request to a value<br>
- larger than the entire size of the memory pool.<br>
-<br>
- Because we don't expect an error to be possible at that point, a crash can<br>
- occur.<br>
-<br>
- Of the &quot;normal&quot; platforms we use, this only exhibits on Win32 because that is<br>
- the only platform where the align_bitmap_mod we use is less than the<br>
- obj_align_mod used for the memory managers.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-28 20:10:16 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6f2518cd3331d7a64c79d533d525299683a57ac">c6f2518cd3331d7a64c79d533d525299683a57ac</a>
-<blockquote>
-<p>
- Fix icc profile reference counting in transparency compositor<br>
-<br>
- Found during Windows testing for a release.<br>
-<br>
- The full test file for<br>
- https://bugs.ghostscript.com/show_bug.cgi?id=693365<br>
-<br>
- would cause Ghostscript to crash due to an ICC profile being freed whilst a<br>
- reference was still being held for it. That was not counting up a reference<br>
- count when restoring the device profile back to a previous value.<br>
-<br>
- Fixing that introduced a leak for other profiles. And that turned out to be<br>
- not decrementing the reference count when replacing a device profile.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-28 10:21: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=660af5758360293e5c041ebf4500144c54521fc8">660af5758360293e5c041ebf4500144c54521fc8</a>
-<blockquote>
-<p>
- Work around for (I think) a VS2019 optimiser bug<br>
-<br>
- VS2019 release builds crash with the input file from bug 702916 and several<br>
- other files, in copied_glyph_slot() because the pointer retrieved and stored<br>
- in *pslot is non-sensical.<br>
-<br>
- Debug/Profile builds and optimised builds with earler VS versions don't show<br>
- the problem.<br>
-<br>
- Adding debug code to assign the calculated index to an interim unsigned integer<br>
- variable also cause the problem to go away.<br>
-<br>
- So, use that as a workaround.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-28 10:20:26 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1a606b57f6eb9a38d355dcf8766f63be6140d42c">1a606b57f6eb9a38d355dcf8766f63be6140d42c</a>
-<blockquote>
-<p>
- Fix some casting confusion for special glyph CID/index values<br>
-<br>
- And a whitespace/indentation issue.<br>
-<br>
- Noticed in passing....<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-24 10:28:07 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aca94c29896f51198a98b1d3e831f7710295ee8c">aca94c29896f51198a98b1d3e831f7710295ee8c</a>
-<blockquote>
-<p>
- First Page Last Page: Add strictly mono increasing error check<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-25 13:03: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=0cec771833490249af508823914be8b7d6931fbe">0cec771833490249af508823914be8b7d6931fbe</a>
-<blockquote>
-<p>
- Fix Bug 702941 - Mispelled PDF interpreter variable name.<br>
-<br>
- s/RepiredAnError/RepairedAnError/ A simple typo that was missed because<br>
- we did not have a test file with a format error to trigger this code.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-25 12:40:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=260c443bc14cdffa4d94e14c3a57e35bebee3a5b">260c443bc14cdffa4d94e14c3a57e35bebee3a5b</a>
-<blockquote>
-<p>
- Bug 702938: Allocating cached glyphs, account for alignment<br>
-<br>
- For efficiency, the glyph cache allocates &quot;large&quot; blocks of memory into which<br>
- it parcels out offsets for individual glyph cache bitmaps, as required.<br>
-<br>
- Since cached glyphs are usually fairly small, and potentially can be short<br>
- lived, this saves the overheads of &quot;full&quot; memory for every cached glyph.<br>
-<br>
- Unfortunately, in calculating the offsets for the cached glyph, it was failing<br>
- to account for the required alignment of the system. In any environment that<br>
- strictly enforces aligned memory accesses, this will potentially cause a bus<br>
- error.<br>
-<br>
- In this case, it was switching the gs_glyph type to a 64 bit type that triggered<br>
- the issue. But any changed to the contents of the cached_char struct could have<br>
- resulted in it happening.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-24 15:27:10 -0700
-</strong>
-<br>evrhel &lt;ethanvrhel@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9e7fcb56612746fa93f8d76fa4cb8ecc72f43f30">9e7fcb56612746fa93f8d76fa4cb8ecc72f43f30</a>
-<blockquote>
-<p>
- Squashed commit of the java-demo branch:<br>
-<br>
- commit 385a750c39e3112f4b640f8dbfea28fbad9885a2<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Sun Sep 13 14:42:08 2020 -0700<br>
-<br>
- Added several devices, updated documentation, and README.txt.<br>
-<br>
- commit 64fad0d5035ccf7394c1863e369b108ca471b5fb<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Wed Sep 9 15:30:58 2020 -0700<br>
-<br>
- Worked on PDFPostscriptDeviceFamily implementation<br>
-<br>
- Added all of the parameter types specified in<br>
- https://ghostscript.com/doc/current/VectorDevices.htm for<br>
- PDF/Postscript devices.<br>
-<br>
- Added several devices, updated documentation, and README.txt.<br>
-<br>
- commit fc6593654f7d1e114d8fd0a8b2da89224e193c92<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Wed Sep 9 14:19:25 2020 -0700<br>
-<br>
- Added missing Settings class to viewer<br>
-<br>
- commit ea92fe4f172911dfe79e8423bd7b98d14d585393<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Wed Sep 9 14:19:25 2020 -0700<br>
-<br>
- Added missing Settings class to viewer<br>
-<br>
- commit 792ddf8525e903e55bf668b41b84f002ef4757cb<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Sat Sep 5 14:04:44 2020 -0700<br>
-<br>
- Added more implementations of Device class<br>
-<br>
- commit 4f2056eafb633f5e4aa9f6ac3bed99247110f556<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Sun Aug 30 16:11:20 2020 -0700<br>
-<br>
- Added device classes to allow easy device manipulation<br>
-<br>
- New abstract classes Device and FileDevice and several subclasses<br>
- to allow easy modification and output to devices.<br>
-<br>
- commit ea360f254e7638b37529b8db105f0a2b9b7e722f<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Mon Aug 24 21:16:56 2020 -0700<br>
-<br>
- Updated to newer Ghostscript version and fixed a bug<br>
-<br>
- Updated to the newest Ghostscript version and fixed an<br>
- ArrayIndexOutOfBoundsException bug when unloading zoomed pages.<br>
-<br>
- commit 34c47909939b4e85f18e2fc03088203c51bba292<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Sun Aug 23 15:58:44 2020 -0700<br>
-<br>
- Added better documentation<br>
-<br>
- commit eda31b70496337caefd0dc912c5a0850de769147<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Thu Aug 20 14:36:48 2020 -0700<br>
-<br>
- Updated how zooming is handled<br>
-<br>
- Zooming is now done through the SmartLoader and is no longer<br>
- a separate operation. Fixed an issue when the SmartLoader could<br>
- become out of date due to the condition variable being signaled<br>
- before the SmartLoader had finished.<br>
-<br>
- commit 5b08d9eadfe64d87cf26869c47a2a5f78755dd4b<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Wed Aug 19 17:38:34 2020 -0700<br>
-<br>
- Implemented distilling documents<br>
-<br>
- Users now have the option to distill a document if the desired<br>
- input is not a PDF.<br>
-<br>
- commit 4a78a968777521f23fefaeb277d378b9dc08b555<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Tue Aug 18 15:04:09 2020 -0700<br>
-<br>
- Fixed zooming and some other bugs in the viewer<br>
-<br>
- Zooming in on documents in the viewer no longer causes a crash.<br>
- Fixed a bug where documents would not display after being loaded.<br>
- Fixed a bug where closing a document when none was loaded would<br>
- crash.<br>
- Fixed a bug where gsapi_delete_instance would cause a crash.<br>
-<br>
- commit 9c9190192c1acdafbf4e9f277dba9e2079046cc7<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Sun Aug 16 16:28:44 2020 -0700<br>
-<br>
- Fixed JNI bugs and began updating viewer to use one GS instance<br>
-<br>
- Fixed JNI crashes when Ghostscript calls were made from different<br>
- threads. Migrated loading low res and high res images from using<br>
- multiple instances to using one global instance.<br>
-<br>
- commit fbe9a961e7fef31c79cfd8ed857643ad00798af8<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Sat Aug 15 14:36:34 2020 -0700<br>
-<br>
- Added init_with_args to the test code in Main.java<br>
-<br>
- commit 96ede7306ce8d71be3016e7d708c801c5718fdfe<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Sat Aug 15 14:33:40 2020 -0700<br>
-<br>
- Fixed a small error in test code in Main.java<br>
-<br>
- commit dcb1141da6901f0c42336861428cf13f6cc9b202<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Sat Aug 15 14:13:23 2020 -0700<br>
-<br>
- Finished updating to newer Ghostscript functions<br>
-<br>
- Replaced all Reference objects in Ghostcript calls in Java<br>
- and JNI to Reference&lt;T&gt;. Iteration over parameters now must be<br>
- done through GSInstance instead of creating an explicit iterator.<br>
-<br>
- commit aa9288fa60aa6030b88f909ac494b388737e1748<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Thu Aug 13 16:00:51 2020 -0700<br>
-<br>
- Finished implementing the rest of Ghostscript functions in Java<br>
-<br>
- All GS functions are now able to be called through GSAPI. Fixed<br>
- a possible memory leak related to exception checking in C++.<br>
-<br>
- commit b02df334fdbc14fb1ed4d75bcaddcf7091391ee7<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Thu Aug 13 12:49:33 2020 -0700<br>
-<br>
- Got gsapi_enumerate_params working in Java<br>
-<br>
- Got gsapi_enumerate_params working and added a utility class<br>
- to do the same work as gsapi_enumerate_params with a Java<br>
- iterator.<br>
-<br>
- commit 502baba9568406ce923944f693728af30c81473e<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Wed Aug 12 16:25:54 2020 -0700<br>
-<br>
- Got gsapi_set_param working<br>
-<br>
- Renamed java function to gsapi_set_param_once to distinguish from<br>
- the actual Ghostscript call. This method does the call to<br>
- gsapi_set_param twice in native code and is used to make it easier<br>
- to use the function in Java.<br>
-<br>
- commit 614c55f1989d04178c916db56cfc38753918097e<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Wed Aug 12 13:30:07 2020 -0700<br>
-<br>
- Worked on implementing new Ghoscript methods in Java<br>
-<br>
- Wrote out all native method signatures in Java and C++. Workekd<br>
- on gsapi_add_control_path and associated helper methods.<br>
-<br>
- commit 08cd824e589cf9cdd4848b9b3606898ac7141c9f<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Tue Aug 11 16:32:08 2020 -0700<br>
-<br>
- Worked on improving References in C++ code<br>
-<br>
- commit de7f2303372bed8b19ca401392151cba7f2ab013<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Tue Aug 11 13:58:54 2020 -0700<br>
-<br>
- Progress on updating Java bindings to newest version.<br>
-<br>
- Added some of the new methods, but currently none work.<br>
-<br>
- commit bcf2db77c8c106b1b3d80d647b0fe04201d9c645<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Mon Aug 10 14:08:42 2020 -0700<br>
-<br>
- Fixed some errors related to loading pages too fast<br>
-<br>
- An error would occasionally be thrown in the SmartLoader having to<br>
- do with the Document being modified while in the SmartLoader, causing<br>
- an error. Reconfigured how the SmartLoader handles documents and<br>
- is started and stopped.<br>
-<br>
- commit cb2be4f3b0635efd4616f567389b19a7351d078b<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Mon Aug 3 15:41:20 2020 -0700<br>
-<br>
- Added thread safety to the viewer.<br>
-<br>
- The viewer now ensures that no more than one ghostscript call is<br>
- happening at the same time and has multiple options for controlling<br>
- the behavior if multiple operations are attempting to be called.<br>
- Also began work on a utility class to make Ghostscript calls easier<br>
- by having a class carry around a instance and a caller handle.<br>
-<br>
- commit f81dfc177f71d0d12b38371fae54b45e158833ce<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Sat Aug 1 17:16:43 2020 -0700<br>
-<br>
- Progress on improving concurrency<br>
-<br>
- Added better exception handling. Began progress on handling<br>
- concurrent operations better.<br>
-<br>
- commit e0f4af0e59580dabca01cb9b932185475d4032a8<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Sat Aug 1 14:48:37 2020 -0700<br>
-<br>
- Viewer now will load a higher resolution image on zoom.<br>
-<br>
- The high resolution image loads correctly, but the viewer does<br>
- not correctly load the right page when in a zoom other than 1x.<br>
-<br>
- commit 843914f25b1a58841bac94e5df8cded8b47dd948<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Wed Jul 29 15:40:14 2020 -0700<br>
-<br>
- Optimizations to page loader<br>
-<br>
- Page loader now only loads around where the use is viewing and<br>
- does not load pages unless the user actually navigates to those<br>
- pages.<br>
-<br>
- commit 458f93f005920b9ca58bed67178dba26cd6d8a18<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Wed Jul 29 14:13:44 2020 -0700<br>
-<br>
- Progress on viewer<br>
-<br>
- Optimizations and easier user interface as well as basic zooming<br>
- implemented.<br>
-<br>
- commit ab65f0672d2be5f5c312b229af66d8d028661d08<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Mon Jul 27 15:12:45 2020 -0700<br>
-<br>
- Various bug fixes in viewer<br>
-<br>
- Added utility methods in ViewerWindow.java to help with changing<br>
- pages and zoom levels. Added framework for zooming pages.<br>
-<br>
- commit e3e7dbac2b5b271a4d4225ebae34d36f603b8a07<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Fri Jul 24 14:03:54 2020 -0700<br>
-<br>
- Got viewer working<br>
-<br>
- Viewer now works and can open files. Still does not &quot;smartly&quot;<br>
- target pages which the use is directly viewing or take<br>
- advantage of file-specific properties. It instead loads all<br>
- the pages' high-resolution images in order.<br>
-<br>
- commit f1441ed36302f75d94cf4aa4a8047150bf5b7585<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Thu Jul 23 18:57:52 2020 -0700<br>
-<br>
- Basic viewer working<br>
-<br>
- The viewer has basic capabilities, but still lacks loading<br>
- high resolution images, spacing components, and resizing correctly.<br>
-<br>
- commit ea3eecbc30b1a4a4747dfd2818262c2f6eea112c<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Thu Jul 23 16:13:13 2020 -0700<br>
-<br>
- Worked on creating GUI<br>
-<br>
- Added GUI (generated using NetBeans). Added support for callbacks<br>
- into the GUI specifically related to the wanted viewer operations.<br>
-<br>
- commit cb15f051db01135cf1eef8df6a8cfb53cb5ff840<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Wed Jul 22 16:24:13 2020 -0700<br>
-<br>
- Progress on Document class for handling a documentLoader<br>
-<br>
- Document class is a list of Pages which stores a low-resolution image<br>
- and a high-resolution image. The low-resolution image should always<br>
- be loaded while the high-resolution can be unloaded to save memory<br>
- usage.<br>
-<br>
- commit 99fa4ae3667cd58d6f2a72f01d1b9410929f4847<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Tue Jul 21 15:19:10 2020 -0700<br>
-<br>
- Converted original Java project to be used as a JAR library<br>
-<br>
- The original project should be compiled as a JAR library and<br>
- where needed, should be placed alongside the required native<br>
- libraries to run. The executable Java project has been moved<br>
- to the gsviewer project.<br>
-<br>
- commit 80dd426da705c160b79a57a161c5d95c3a57aca6<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Tue Jul 21 15:01:18 2020 -0700<br>
-<br>
- Colors now being displayed correctly after getting image<br>
-<br>
- Fixed drawing colors coming from ghostscript. Next: need to migrate<br>
- the current project into a jar file instead of a runnable application.<br>
- The viewer will use the Java library.<br>
-<br>
- commit 06a50542391c3f0ad64f20a0ae6a1f63d9aa61e0<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Mon Jul 20 17:10:36 2020 -0700<br>
-<br>
- Fixes to display callback and C++ and added window to display images<br>
-<br>
- Fixed Java methods not being found in C++ and added a window class<br>
- to start displaying images.<br>
-<br>
- commit 4b0e69075619f7c4ef8df850d0e85d125e2b67da<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Fri Jul 17 16:02:37 2020 -0700<br>
-<br>
- Implemented NativePointer methods in C++ and updated onDisplayPage<br>
-<br>
- onDisplayPage now uses a BytePointer object for the pimage parameter<br>
- to interface into native memory.<br>
-<br>
- commit 0d24844082f6c566af417ad35b394e3fd591c38e<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Fri Jul 17 15:03:06 2020 -0700<br>
-<br>
- Added new Java class allowing native access to memory blocks<br>
-<br>
- Added NativePointer and NativeArray as two base classes for low-level<br>
- memory-access alongside other classes to assist with this.<br>
-<br>
- commit 9643091f698293181dcb484e04e96d19df12950a<br>
- Author: Ethan Vrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Thu Jul 16 17:01:53 2020 -0700<br>
-<br>
- Security improvements in native code<br>
-<br>
- Fixed multiple points where the program could crash<br>
- and instead returned NULL and/or threw a (safer) Java<br>
- exception.<br>
-<br>
- commit fdade3eedc6469edd3da510bd648a39fdb9f9a93<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Tue Jul 14 15:52:22 2020 -0700<br>
-<br>
- Fixed how display_callback was being passed to Ghostscript<br>
-<br>
- The display_callback device did not have the correct values regarding its size,<br>
- major version, and minor version. Furthermore, the display_device structure<br>
- was not being dynamically allocated and ended up being freed too early.<br>
-<br>
- commit 5a3e822ca0e076708bed843a2578a18eebb37f3d<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Sun Jul 12 15:17:16 2020 -0700<br>
-<br>
- Fixed some bugs related to stdio<br>
-<br>
- Fixed stdio bugs and added some more utility methods to make calling<br>
- ghostscript functions easier in Java.<br>
-<br>
- commit 88fad771fcd4024a538f4bf6f6819d62d8180440<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Sat Jul 11 14:29:58 2020 -0700<br>
-<br>
- Completed JNI bindings to Ghostscript<br>
-<br>
- Added implementations for StdIO and display callback, and added<br>
- some testing in main().<br>
-<br>
- commit bb197f9ae65b39bf55ae6fd932203e514472ff8f<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Fri Jul 10 14:06:07 2020 -0700<br>
-<br>
- Finished writing JNI bindings.<br>
-<br>
- Finished writing JNI bindings and added more utility methods to<br>
- help with setting Reference objects in Java.<br>
-<br>
- commit 8a0074ea3624921cd8ff98684e5efa2fc0b4d5ce<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Thu Jul 9 18:27:52 2020 -0700<br>
-<br>
- Progress on linking Ghostscript functions to Java<br>
-<br>
- Added support for more functions and finished implementing display<br>
- callback functions.<br>
-<br>
- commit 32fee0e8ea1d82897ff4d2a3ce4b9ba92a680cd3<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Wed Jul 8 19:39:27 2020 -0700<br>
-<br>
- Worked on implementing display_callback in Java<br>
-<br>
- Added utility methods in C++ code to help with calling functions,<br>
- setting fields, and creating objects. Started to implement the functions<br>
- defined in display_callback.<br>
-<br>
- commit fe751db5f899c3e59c961d65ec013f307adef8f9<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Tue Jul 7 17:31:18 2020 -0700<br>
-<br>
- Implemented Ghostscript functions in Java in the C++ project<br>
-<br>
- Created a new C++ project which allows for Java calls into Ghostscript.<br>
- Current working functions are gsapi_revision, gsapi_new_instance, and gsapi_delete_instance.<br>
- gsapi_set_stdio_with_handle and gsapi_set_stdio are untested.<br>
-<br>
- commit 4c2bf73539f440bf8f6b45d85820cc84df2e6b28<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Tue Jul 7 14:52:47 2020 -0700<br>
-<br>
- Finished writing ghostscript api signatures in GSAPI.java<br>
-<br>
- commit 4850223d252d6e245104c42fafc0190b91177be2<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Mon Jul 6 18:16:15 2020 -0700<br>
-<br>
- Progress on creating the JNI bindings to Ghostscript.<br>
-<br>
- Started GSAPI class to store exported Ghostscript functions. Added error constants and declared<br>
- gsapi_revision, gsapi_new_instance, gsapi_delete_instance, gsapi_set_stdio_with_handle,<br>
- gsapi_set_stdio, gsapi_set_poll_with_handle, gsapi_set_poll, and gsapi_set_display_callback bindings.<br>
- Added multiple callback interfaces and a Java representation of struct display_callback_s.<br>
-<br>
- commit 8da16a603b124c15ce4dc7c7fccc97f711d75fb2<br>
- Author: evrhel &lt;ethanvrhel@gmail.com&gt;<br>
- Date: Mon Jul 6 15:18:32 2020 -0700<br>
-<br>
- Java demo: Initial commit with README<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-24 12:34:18 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f9c59a2875e4a5cd2b2160cfc507966795e0787">4f9c59a2875e4a5cd2b2160cfc507966795e0787</a>
-<blockquote>
-<p>
- Fix error in token parsing in pdfwrite<br>
-<br>
- I am trying to use a hex string &lt;XXXXXXXX&gt; in pdfi.<br>
- The code had a bug in it (probably because the ps code never generates<br>
- a hex string?) that was incrementing the token to be 1 longer than it<br>
- should have been. Logic was just mangled.<br>
-<br>
- I also simplified it to to take out the goto, which was egregious in<br>
- this case. Just put in two lines of code where it belongs, instead of<br>
- a goto to those two lines of code... (really?)<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-24 19:08: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=82aceb33f2521854bc781bdf0f47cbfe32d6ece8">82aceb33f2521854bc781bdf0f47cbfe32d6ece8</a>
-<blockquote>
-<p>
- Remove links to ghostscript.com/release_history.html<br>
-<br>
- That page is now gone.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-24 17:10:21 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=921f2737a72e64d9c8113fc9418422ab185cb60f">921f2737a72e64d9c8113fc9418422ab185cb60f</a>
-<blockquote>
-<p>
- Remove dead end links from Readme.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-24 16:59:20 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e36e62c0631f73627ff3caec5752eefe37a14948">e36e62c0631f73627ff3caec5752eefe37a14948</a>
-<blockquote>
-<p>
- Allow configure caller to choose a sanitizer<br>
-<br>
- Our &quot;sanitize&quot; target just uses address sanitizer.<br>
-<br>
- With this commit, we'll still default to address, but the caller can do:<br>
- --with-santizer=memory<br>
-<br>
- to opt for the &quot;memory&quot; sanitizer instead.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-24 10:00:39 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c210bb3d2a0c6131ebeedc44c1d8cc6fc92fb08f">c210bb3d2a0c6131ebeedc44c1d8cc6fc92fb08f</a>
-<blockquote>
-<p>
- Fix compiler warnings<br>
-<br>
- (unused variables)<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-23 20:20: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=d7d05e0ef54662054e038b421795e6e7dedd1e4a">d7d05e0ef54662054e038b421795e6e7dedd1e4a</a>
-<blockquote>
-<p>
- Bug 702920: Fix type confusion in new param type code.<br>
-<br>
- In a few cases we were using the wrong element in the union to read the<br>
- value back from the param list (and to range check the values).<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-24 08:19: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=038df4baf368196942cd32aedcd29e4916a190c8">038df4baf368196942cd32aedcd29e4916a190c8</a>
-<blockquote>
-<p>
- WhatIsGS.htm updates from Lisa F<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-23 17:12:54 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d178fa10548d101a248e3ec3fc6ddcf5bf044692">d178fa10548d101a248e3ec3fc6ddcf5bf044692</a>
-<blockquote>
-<p>
- XPS Interp: Fix missing initialization in XPS page reversal<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-23 14:18: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=b53045b45866fe5b41e9ca6b4fe8318f14178d3d">b53045b45866fe5b41e9ca6b4fe8318f14178d3d</a>
-<blockquote>
-<p>
- Fix a compiler warning<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-23 13:14: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=6a1f7167cf45d23c4e1faec3ef37fb4b9e5d7a53">6a1f7167cf45d23c4e1faec3ef37fb4b9e5d7a53</a>
-<blockquote>
-<p>
- pdfwrite - fix memory leak with annotations<br>
-<br>
- Annotations are somewhat odd and don't quite fit the scheme of other<br>
- cos objects. Each annotation is created as a dictionary, which is<br>
- stored in the Annots array (also a cos object)) of the page.<br>
-<br>
- But we write the annots out to the file immediately, and free the<br>
- dictionary contents at that time. We cannot, however, free the dict<br>
- cos object, because we need the object number to write the Annots<br>
- array in the page dictionary, which we only do when writing the page<br>
- dictionary.<br>
-<br>
- So at the end of the page the annots array contains a number of empty<br>
- dictionaries. We free the array, which would free the dictionary<br>
- contents (except there are none) but it does *not* free the dictionaries<br>
- because they have an ID......<br>
-<br>
- So when we free the Annots array, we first need to set the ID of each<br>
- of the dictionary objects it contains to 0, so that the dictionary<br>
- will also be freed.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-22 10:31:09 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ff586fa9e51ac7fdb306ff7b616d7cf23ed754d">5ff586fa9e51ac7fdb306ff7b616d7cf23ed754d</a>
-<blockquote>
-<p>
- Fix PolyLine annotation for pdfwrite device<br>
-<br>
- This implementation was missing, just copy-pasted the default for it.<br>
-<br>
- It was going through a code path that I think only works for Widgets.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-26 16:53:36 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9bfaeeace268f6a59f325e12efab9fb8273f64e0">9bfaeeace268f6a59f325e12efab9fb8273f64e0</a>
-<blockquote>
-<p>
- XPS interpreter: Have interpreter handle page range processing<br>
-<br>
- This has the obvious benefit that the interpreter will skip processing<br>
- pages except those that lie in the FirstPage LastPage range.<br>
- If the PageList is used, the XPS interpreter will create a new<br>
- list of linked pages to process. The XPS interpreter handles all<br>
- the PageList cases currently implemented by the PDF interpreter<br>
- including even and odd. In addition, the XPS interpreter will handle<br>
- backward indexing (e.g. 100-1), as well as starting from last page<br>
- to another page (e.g. -2 which means from last page to second page),<br>
- and page repeats (e.g. 1,2,1,2,1,2 or 1-3,3-1 or 1-,-1 which is<br>
- do page 1 to end and end to page 1) Also, setting -dFirstPage=4<br>
- -dLastPage=1 will create pages 4,3,2,1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-16 17:33: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=c4e79952b42ebccb669063e053e3d7ce0f88cc22">c4e79952b42ebccb669063e053e3d7ce0f88cc22</a>
-<blockquote>
-<p>
- Fix compile failure due to missing header.<br>
-<br>
- A user reported (privately) that a pre-release of an upcoming XCode release<br>
- fails to compile due to a missing prototype/declation of abs() in the jpegxr<br>
- code. It's clearly a simple omission, as several files use abs() and do include<br>
- the relevant header.<br>
-<br>
- So adding it here.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-22 11:18:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=71bbd0f12f48e1300a1e768483b5999099243f8d">71bbd0f12f48e1300a1e768483b5999099243f8d</a>
-<blockquote>
-<p>
- Bug 702810: fix fapi buffer size parameter types<br>
-<br>
- The buffer size parameters for the fapi callbacks used to be unsigned short,<br>
- but were changed to ints a while back. The calls for the (g)subr data in<br>
- Type 2/CFF fonts hadn't had the casts to ushort removed, causing the values<br>
- to be trucated.<br>
-<br>
- There was also a Postscript/FAPI internal function that had not had the<br>
- buffer length parameter changed to int.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-22 11:11: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=a5aa22546b191b9465b2d6f6aa00c2ad591238af">a5aa22546b191b9465b2d6f6aa00c2ad591238af</a>
-<blockquote>
-<p>
- Remove pointless 'recopying' of CFF (g)subr strings<br>
-<br>
- For some reason, the Type 2 font serialisation (used for reassembling font<br>
- streams to pass to freetype) was using the FAPI callback to read the<br>
- (g)subr string data into it's main buffer, but then called the writing<br>
- function to write data to the buffer, using its own buffer as input -<br>
- effectively overwriting the bytes with the same bytes.<br>
-<br>
- The only purpose (it seems) was to move the current stream position forward by<br>
- the appropriate amount.<br>
-<br>
- Change it so we simply move the &quot;current position&quot; pointer on by the correct<br>
- offset.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-22 08:58:31 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3abfca2a925427962ed644872057f75c44afc0d8">3abfca2a925427962ed644872057f75c44afc0d8</a>
-<blockquote>
-<p>
- Fix memory leak in pcl pdfmark implementation<br>
-<br>
- The memory allocated by param_write_string_array() was never being<br>
- released.<br>
-<br>
- (Note: the cluster doesn't test this code path currently)<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-22 15:43: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=652c71e0f7766f3696330f654abf01c79a5493f2">652c71e0f7766f3696330f654abf01c79a5493f2</a>
-<blockquote>
-<p>
- Updates to 'WhatIsGS.htm' document from Lisa.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-22 08:25:36 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b7a413e2d28540ca0113af1c783532ecea6f6ba0">b7a413e2d28540ca0113af1c783532ecea6f6ba0</a>
-<blockquote>
-<p>
- pdfwrite - remove erroneous free from cos_dict_put_copy<br>
-<br>
- Nancy discovered this one while working on annotations for pdfi. The<br>
- code here would attempt to free the memory pointing to the key name<br>
- which is passed as an argument to the function, if the *dictionary*<br>
- properties were set to free dictionary keys.<br>
-<br>
- Obviously the function argument is not the same thing as the key stored<br>
- in the dictionary, so even at first inspection this looks incorrect.<br>
-<br>
- The key is supplied (much higher up) from a param list, because the pdfi<br>
- code uses C param lists, where the data is stored in a single large<br>
- allocation, it is not possible to free an individual key and causes a<br>
- crash.<br>
-<br>
- Ghostscript gets away with this for two reasons; firstly it uses a<br>
- stack param list (which is basically a ref param list) where each key<br>
- is stored in its own allocation. Secondly the key is not actually<br>
- allocated, its an entry in the interpreter name table. So when the<br>
- code in cos_dict_put_copy 'frees' the memory, nothing actually happens,<br>
- the memory manager just notes that the memory is unused now. This<br>
- avoids double freeing the memory which would otherwise happen.<br>
-<br>
- So essentially this code is wrong, and we've been getting away with by<br>
- sheer luck for decades.<br>
-<br>
- I tested the modification extensively, including memory leak checks with<br>
- many files run through pdfwrite and can find no problems with simply<br>
- removing the line of code.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-21 22:16: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=bbd106e8f9345296cb5b5a452487bda603d54173">bbd106e8f9345296cb5b5a452487bda603d54173</a>
-<blockquote>
-<p>
- oss-fuzz 23637: Fix error code confusion<br>
-<br>
- Confusion of error codes meant we were allocating space for glyph data,<br>
- but never copying the data into it. Thus the memory sanitizer error.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-21 15:14: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=42480ab92d9d31e7dc204e8f916165cc02480387">42480ab92d9d31e7dc204e8f916165cc02480387</a>
-<blockquote>
-<p>
- Fix segfaults in UFST - use correct font name<br>
-<br>
- Omission from commit: a10a03a4c9713b38c4cfcd07f0ba3c722778aae0<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-20 16:35: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=7aff7d6a30544929de9d2f4bd775fb17303b86ff">7aff7d6a30544929de9d2f4bd775fb17303b86ff</a>
-<blockquote>
-<p>
- Fix Coverity ID 362083 &amp; 362084<br>
-<br>
- After the fixes for crashes with invalid filenames, Coverity can now<br>
- detect a potential NULL stream pointer (would have been uninitialised<br>
- previously).<br>
-<br>
- Prevent the code trying to write to that stream, thereby dereferencing<br>
- it.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-18 23:18:41 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef118c5edc71ac6575260918d062e91ed3f8f067">ef118c5edc71ac6575260918d062e91ed3f8f067</a>
-<blockquote>
-<p>
- XPSWrite: Fix memory leaks and page resource relations<br>
-<br>
- The page resource relations information tells which of the<br>
- resources are used for each page. The information was not<br>
- getting written out correctly for the multi-page case. The<br>
- Microsoft viewer is very fussy about this and would not<br>
- display some pages, even though the item is in the resources.<br>
-<br>
- Made sure that each page writes out the proper relations to the<br>
- resources and that no duplicate relations are written.<br>
-<br>
- Also fixed memory leaks from the zip file information not getting<br>
- freed as well as some TIFF client information.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-18 15:53: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=4dcbbd26d92a25705a1b835573faada8aa225448">4dcbbd26d92a25705a1b835573faada8aa225448</a>
-<blockquote>
-<p>
- Fix a compiler warning by initialising a variable<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-18 15:16:46 +0100
-</strong>
-<br>Peter Cherepanov &lt;sphinx.pinastri@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5425a7f56d0cb424370af82f18c3416a728f18ff">5425a7f56d0cb424370af82f18c3416a728f18ff</a>
-<blockquote>
-<p>
- PDF interpreter &amp; pdfwrite - better detection of per-page output<br>
-<br>
- Bug #702791 &quot;%d vs. %03d and pdfmark destination page ... points beyond the last ...&quot;<br>
-<br>
- The PostScript code in the PDF interpreter which looks for<br>
- file-per-page output, in order to drop Outlines and Dests was<br>
- only checking for %d not variants liek %03d. This could lead<br>
- to warnings about the Destination being dropped.<br>
-<br>
- The code provided by Peter checks for an odd number of '%'<br>
- characters instead. This isn't the same test as pdfwrite uses<br>
- but that is in C and not immediately available in PostScript.<br>
-<br>
- Since we plan eventually to drop the PostScript implementation<br>
- of the PDF interpreter and move to a C version, this is fine<br>
- for the interim.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-18 14:17: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=4c58ce8f26096122eff7783da38a679a3ecd96c4">4c58ce8f26096122eff7783da38a679a3ecd96c4</a>
-<blockquote>
-<p>
- pdfwrite - fix a number of seg faults when opening output file fails<br>
-<br>
- While investigating bug #702791 I discovered a number of ways to make<br>
- the opening of the output file fail (combinations of illegal characters)<br>
- which subsequently caused pdfwrite to seg fault.<br>
-<br>
- This commit addresses these.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-17 16:37: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=cf49e978b9324866f61acce6b3cf399b356af6fb">cf49e978b9324866f61acce6b3cf399b356af6fb</a>
-<blockquote>
-<p>
- Fix tesseract traineddata links in documentation.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-17 15:34: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=d5494de2cab28b91ba360d15b8afffef50a3f421">d5494de2cab28b91ba360d15b8afffef50a3f421</a>
-<blockquote>
-<p>
- PDF interpreter with pdfwrite fix non-square scaling stroked text<br>
-<br>
- Bug #702900 &quot;pdfwrite device causes bold text output&quot;<br>
-<br>
- The PDF interpreter has special code for dealing with line widths and<br>
- stroked text, this is because we do not preserve the CTM in the input<br>
- through to the output in pdfwrite.<br>
-<br>
- What we need to do is figure out what line width with an identity CTM<br>
- would draw a line the same width as the current line width and CTM.<br>
- Normally pdfwrite takes care of this itself, but until relatively<br>
- recently it did not have access to the textmatrix, only the CTM. But for<br>
- text, by the time we get to the point of emitting the text,, the CTM<br>
- already includes the Text matrix (Tm).<br>
-<br>
- So the PDF interpreter (which does have the CTM before the TM is<br>
- applied) calculates a line width and sets that before sending the text.<br>
-<br>
- However, when the scaling was non-square we were not doing that, leading<br>
- pdfwrite to emit the unscaled linewidth. Intriguingly we have no files<br>
- in the test suite for which this is a problem, all the files where the<br>
- CTM is non-square it is also close to the identity so not visibly<br>
- incorrect.<br>
-<br>
- The file here, however, has a non-identity CTM which is slightly<br>
- non-square when the text is rendered, and very far from the identity.<br>
-<br>
- Since we can't tell which scaling to use for the linewidth we 'fudge'<br>
- it by using the transformed x and y values of the linewidth, as two<br>
- sides of a triangle, then calculating the hypotenuse. Obviously this<br>
- won't work for seriously skewed matrices but it seems unlikely we<br>
- could calculate a reasonable linewidth for that anyway.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-26 16:50:51 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b81a73c34e48a547dd881f07aa046646a472e13c">b81a73c34e48a547dd881f07aa046646a472e13c</a>
-<blockquote>
-<p>
- C# API: Fix a few minor issues related to printing<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-16 10:05:51 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c035cc51926dbda7f013b7611d0cdddda986a47d">c035cc51926dbda7f013b7611d0cdddda986a47d</a>
-<blockquote>
-<p>
- Clarify documentation<br>
-<br>
- It wasn't clear that the PJL implementation of pdfmark and<br>
- setdistillerparams required the PJL line to terminate with a linefeed<br>
- (specifically a linefeed, not a carriage return). Update the document<br>
- to make this clear.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-16 07:48: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=d9369a388ae987b63d66fdd557f95b0073547846">d9369a388ae987b63d66fdd557f95b0073547846</a>
-<blockquote>
-<p>
- Bug 702904: Another fix to check for shared libjpeg/libtiff<br>
-<br>
- We cannot combine shared and not shared libjpeg and libtiff - they either both<br>
- need to be &quot;local&quot; or both shared, and configure checks that and fails when<br>
- the two are incompatible.<br>
-<br>
- However, that check would fail when either libjpeg or libtiff were not being<br>
- included at all. Since it is libtiff that is the &quot;problem&quot; for this<br>
- compatibility, now check if TIFF is included, and if not, skip the check.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-25 16:47:10 +0100
-</strong>
-<br>ChrisL &lt;cliddell@salvor-openbsd.lan&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=24808eae80f0def1aeb7f727980d5e0852d3d0e0">24808eae80f0def1aeb7f727980d5e0852d3d0e0</a>
-<blockquote>
-<p>
- Fix the OpenBSD build<br>
-<br>
- Whilst hopefully not breaking the buildroot build.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-14 16:52:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d08c3225879c0714217a7defd6f57f8a16ef615">7d08c3225879c0714217a7defd6f57f8a16ef615</a>
-<blockquote>
-<p>
- Bug 702901: initialize directory for tiff configure<br>
-<br>
- Previously the directory in which to run the libtiff configure script was<br>
- initialised to an empty string, but that, in some toolchains, resulted in an<br>
- error due to &quot;unsafe header/library path used in cross-compilation&quot;.<br>
-<br>
- So initialise it something benign instead.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-14 11:12:16 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=996d05b6f5010afda4b47b20ed4b8e1ee364402b">996d05b6f5010afda4b47b20ed4b8e1ee364402b</a>
-<blockquote>
-<p>
- oss-fuzz 25486: Initialise device colors in graphics state<br>
-<br>
- Not all devices/color models require all the entries in a device color, so<br>
- sometimes they don't get set, in this case, the &quot;phase&quot; entry. Trouble is,<br>
- the clist code uses phase in a conditional.<br>
-<br>
- Initialise the dev_color so, in such cases, we're not hitting a UMR condition.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-11 18:33:42 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=19ed8a965c016eda56057e29dfc373d1af87ca55">19ed8a965c016eda56057e29dfc373d1af87ca55</a>
-<blockquote>
-<p>
- oss-fuzz 25485: Validate Type 1 font hinting paramters.<br>
-<br>
- BlueValues, OtherBlues, FamilyBlues and FamilyOtherBlues are all made of up<br>
- pairs of values packed into arrays. Obviously, valid arrays for those must have<br>
- an even number of entries.<br>
-<br>
- Ensuring they do, and erroring out should they not, prevents us from accessing<br>
- off the end of the valid values, and encountering a UMR condition.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-11 15:08: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=542e32e6aa630ad909c39304ba4e48870695781e">542e32e6aa630ad909c39304ba4e48870695781e</a>
-<blockquote>
-<p>
- oss-fuzz 25480: CFF - cope with &quot;empty&quot; float number.<br>
-<br>
- If a CFF stream encoded a fractional number with no content (i.e. starting op<br>
- code, imediately followed by an ending op code), we were still trying to<br>
- parse meaning out of the emtpy temporary buffer. So, check we have actually<br>
- decoded bytes from the stream, before converting to a floating point value.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-11 14:45: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=f4aae0832544e76d148db9eb52a24c34a416b56c">f4aae0832544e76d148db9eb52a24c34a416b56c</a>
-<blockquote>
-<p>
- oss-fuzz 25474: Check the length of Coords in shading dict<br>
-<br>
- We weren't checking if the length of Coords array for shading was valid, meaning<br>
- we could end up using uninitialised entries in an array.<br>
-<br>
- Check it, and throw an error if it's invalid.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-14 14:32: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=378e2071d77fad65ba0fe3beed974d1efbe180ac">378e2071d77fad65ba0fe3beed974d1efbe180ac</a>
-<blockquote>
-<p>
- Fix crashes with pdfwrite, TrueType input fonts and Windows 64-bit build<br>
-<br>
- With the change to 64-bits unconditionally for gs_glyph we can now<br>
- define GS_MIN_CID_GLYPH in 64-bit terms.<br>
-<br>
- Previously we were using the architecture size of a long_long to<br>
- determine which define to use, and we do not define long_long on Windows<br>
- leading to us using an essentially 32-bit definition. This caused<br>
- indexing off the end of an array in copied_glyph_slot()<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-14 09:40: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=f0d19bf181a156d011dba422ae4d165b36b0af7e">f0d19bf181a156d011dba422ae4d165b36b0af7e</a>
-<blockquote>
-<p>
- Bug 702897: Fix shared libtiff/libjpeg check<br>
-<br>
- For various reasons we cannot combine shared and not shared libjpeg and<br>
- libtiff - they either both need to be &quot;local&quot; or both shared.<br>
-<br>
- But the check for that compatibility was triggered during the recursive<br>
- configure call when setting up for cross compiling.<br>
-<br>
- Skip the check for that recursive configure call.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-10 16:18: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=98379bb2752c64f47cc1de9f6f3c973b2c69562c">98379bb2752c64f47cc1de9f6f3c973b2c69562c</a>
-<blockquote>
-<p>
- Bring changelog changes onto master from gs9.53.0<br>
-<br>
- (Tweak History9.htm with jbig2dec updates)<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-10 17:27:47 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=24cfe91c81b831d6d23fe0a1008285407a7adeb2">24cfe91c81b831d6d23fe0a1008285407a7adeb2</a>
-<blockquote>
-<p>
- Fix Coverity issue 361428.<br>
-<br>
- Don't strlen a possibly NULL path. Shouldn't ever be a problem,<br>
- but doesn't hurt to be safe.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-10 17:25:02 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1bd520eff4d5b8474d5aa962434dd398beb65dcc">1bd520eff4d5b8474d5aa962434dd398beb65dcc</a>
-<blockquote>
-<p>
- Fix Coverity issue 361836.<br>
-<br>
- Check return code.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-10 17:23: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=367dec7fb70f08603e37de5e1e07731a21fb4b73">367dec7fb70f08603e37de5e1e07731a21fb4b73</a>
-<blockquote>
-<p>
- Fix Coverity issue 361837.<br>
-<br>
- Check return codes properly.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-10 17:19:34 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=198846d0d28b0f462dc84d12f00f82d3d1d069db">198846d0d28b0f462dc84d12f00f82d3d1d069db</a>
-<blockquote>
-<p>
- Fix Coverity issue 361838.<br>
-<br>
- All destructors should accept NULL.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-10 22:47:09 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a4a8406ff4618234095fc8ed4d6e8b313a5260e4">a4a8406ff4618234095fc8ed4d6e8b313a5260e4</a>
-<blockquote>
-<p>
- Bug 702884: Require jbig2dec 0.19 when building ghostscript.<br>
-<br>
- In practice this has been required since commit<br>
- 9b5008aa2bc1c6a6acb2c6f90d1ef8d6bad9e66a.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-10 22:41:20 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=224ffe421044b6cff107bcb3e0460aac7e029c56">224ffe421044b6cff107bcb3e0460aac7e029c56</a>
-<blockquote>
-<p>
- Update jbig2dec stuff for 0.19 release.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-10 15:42:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=89ff7003acfdc52e3d3bcca930de6961f33ae927">89ff7003acfdc52e3d3bcca930de6961f33ae927</a>
-<blockquote>
-<p>
- pdfwrite - fix image downsampling when the input is a 16-bit image<br>
-<br>
- Bug #702868 &quot;Segmentation fault when using dPDFSETTINGS&quot;<br>
-<br>
- The problem is to do with image downsampling, and 16 bit images. When<br>
- the input image has 16 bits per component, and is sufficiently high<br>
- resolution on output that it triggers image downsampling, in this case<br>
- the image downsampling setup can't deal with the input. In addition we<br>
- *already* deal with 16-bit input by explicitly adding a filter to<br>
- reduce the input from 16 bits to 8, so its not necessary for the<br>
- downsampling code to do this.<br>
-<br>
- So fix it simply by altering the colour depth form 16 to 8 in the<br>
- params we pass to the setup code.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-18 10:23: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=3441872e7e7e5e269d242605dbc0f47c024120a9">3441872e7e7e5e269d242605dbc0f47c024120a9</a>
-<blockquote>
-<p>
- Bring master up to date with 9.53.0 doc changes<br>
-<br>
- Update docs, version, dates, product family<br>
-<br>
- for 9.53.0 RC1<br>
-<br>
- Fox typos and stuff in the release highlights<br>
-<br>
- Update dates'n'docs for 9.53.0.RC2<br>
-<br>
- Docs and dates for 9.53.0<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-10 11:58:13 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=12ca7092b5b1cdd9e9d1fe3497e033bb01751a1a">12ca7092b5b1cdd9e9d1fe3497e033bb01751a1a</a>
-<blockquote>
-<p>
- Correct fix for stack smashing.<br>
-<br>
- Commit 4d9fa68df &quot;Fix stack smashing in blending code.&quot; was the<br>
- wrong fix (and indeed didn't work in the weekly tests).<br>
-<br>
- We therefore back that out, and add the correct fix.<br>
-<br>
- When using a temporary array to allow us to Hue blend, we need<br>
- that array to be large enough to cope with all the components<br>
- we might have, including spots.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-09 15:05:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b2b45b74b4272092ca46d0210b0076a618b7979a">b2b45b74b4272092ca46d0210b0076a618b7979a</a>
-<blockquote>
-<p>
- Strip trailing whitespace from html files<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-09 14:47:30 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a23ca3a97bcef0663d8855dc26f1a5041f2a5d4">6a23ca3a97bcef0663d8855dc26f1a5041f2a5d4</a>
-<blockquote>
-<p>
- Strip trailing whitespace from makefiles.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-09 18:40:56 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d9fa68df46a876e60d9677eafee66b0c596d8ab">4d9fa68df46a876e60d9677eafee66b0c596d8ab</a>
-<blockquote>
-<p>
- Fix stack smashing in blending code.<br>
-<br>
- Page 17 of:<br>
-<br>
- gs -Ilib -sOutputFile=out%d.psd -dGraphicsAlphaBits=4<br>
- -dTextAlphaBits=4 -dMaxBitmap=400000000 -sDEVICE=psdcmyk<br>
- -r72 -Z: -sDEFAULTPAPERSIZE=letter -dNOPAUSE -dBATCH -K2000000<br>
- -dClusterJob -dJOBSERVER<br>
- ../tests_private/comparefiles/Altona_Technical_v20_x4.pdf<br>
-<br>
- crashes, due to do_pdf14_copy_alpha_color calling<br>
- art_blend_luminosity_cmyk_8 and art_blend_saturation_cmyk_8<br>
- with a temporary array of size 4, with n_chan=5.<br>
-<br>
- The reason for this is because we are forgetting to allow for the tag<br>
- plane. Fixed here.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-09 14:12:57 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9695dd9f5352abc2ba49174447824f474f06ada6">9695dd9f5352abc2ba49174447824f474f06ada6</a>
-<blockquote>
-<p>
- Remove prototype for non-existent function.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-09 12:46:51 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=81a0e93a723fe057d9ba56a2bf072e6b7adc2a7e">81a0e93a723fe057d9ba56a2bf072e6b7adc2a7e</a>
-<blockquote>
-<p>
- Strip trailing whitespace from .c and .h files.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-09 11:50: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=9bd47d0ed0d012301e28e288a366408fa6aba386">9bd47d0ed0d012301e28e288a366408fa6aba386</a>
-<blockquote>
-<p>
- Bug 702871: Fix GraphicsAlphaBits + Fill/Stroke issue.<br>
-<br>
- When we flush the alphabuffer, mapped_start and mapped_height are<br>
- both set to zero. When we refill it, mapped_height is set to<br>
- non-zero. USUALLY mapped_start is set to non-zero too, but it can<br>
- be set to zero when we are close to the bottom of the page.<br>
-<br>
- Hence we should test for mapped_height != 0, rather than both<br>
- mapped_height and mapped_start being non-zero.<br>
-<br>
- So the 'quick hack' that Chris used is actually correct.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-07 19:19:10 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7222ff74e7d1249c06c163bc8b33ef5b485e8864">7222ff74e7d1249c06c163bc8b33ef5b485e8864</a>
-<blockquote>
-<p>
- Remove deprecated device-like image handling procedures.<br>
-<br>
- 22 years is probably long enough warning.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-07 18:53:00 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f8e7df3adf63221d70cfff54aec9c56ffbd5385">8f8e7df3adf63221d70cfff54aec9c56ffbd5385</a>
-<blockquote>
-<p>
- Rejig PCL/PXL to call graphics library rather than device functions.<br>
-<br>
- Also remove pl_begin_image2/pl_image_data2/pl_end_image2 etc<br>
- functions - might as well just call direct. This leaves pldraw.c and<br>
- pldraw.h empty, so remove them.<br>
-<br>
- Also, take the opportunity to fix some potential cleanup problems.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-08 14:24:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8b805ceb6fe15bd835a48dac227b85da401d7a81">8b805ceb6fe15bd835a48dac227b85da401d7a81</a>
-<blockquote>
-<p>
- pdfwrite - fix error handling with broken type 3 fonts<br>
-<br>
- The test file tests_private\pdf\customer394\problems\normal_537.pdf has<br>
- a Type 3 font with a CharStrings entry where the value is not a<br>
- dictionary, it is the null object.<br>
-<br>
- When trying to capture the outlines of the glyphs in order to rebuild a<br>
- type 3 font in the output PDF file, pdfwrite detects the error. However<br>
- due to an oversight when writing the code, the graphics state is not<br>
- correctly preserved.<br>
-<br>
- This is because if an error occurs in gs_text_process it unwinds the<br>
- graphics state stack back to the level stored in the text enumerator<br>
- at the start of the text processing. But complete_charproc() then<br>
- proceeds to do another gs_grestore (and the code incorrectly did yet<br>
- another gs_grestore as well!). This results in the graphics save level<br>
- being different on exit form text processing to the state on entry.<br>
-<br>
- Remarkably this doesn't seem to cause a problem, except for the new pdfi<br>
- interpreter, where the gs_grestore restores back to a point before the<br>
- type 3 font was present in the graphics state. This leads to the type<br>
- 3 font having a reference count of 1 at the end of processing and the<br>
- font and all its contents leaking.<br>
-<br>
- Fix it by updating the 'level' stored in the enumerator actually being<br>
- used by gs_text_process (which, because this is for capturing glyphs,<br>
- is not the same enumerator as used by pdf_text_process). Also remove<br>
- the spurious extra gs_grestore in the error clause.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-07 19:58:09 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e8a6f1d98300fd06965dbdccd82a746adeb05b72">e8a6f1d98300fd06965dbdccd82a746adeb05b72</a>
-<blockquote>
-<p>
- Fix type slipup in OCR params handling.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-07 09:54: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=2202026393550166416b4fd28daaa4f667a77301">2202026393550166416b4fd28daaa4f667a77301</a>
-<blockquote>
-<p>
- Fix memory leak with clip device and image width/height = 0<br>
-<br>
- When rendering masked images we can create a clip device in order to do<br>
- the actual masking before passing the result to the final device.<br>
-<br>
- After creating the device we store it in a 'gs_image_common_enum' for<br>
- later use. We then proceed to initialise the main image enumerator in<br>
- gs_image_common_init().<br>
-<br>
- As an optimisation, if the image width or height is 0, we don't waste<br>
- any time processing it but simply end the image and exit.<br>
-<br>
- However, if we had created a clip device, we did not free that device<br>
- leading to a memory leak.<br>
-<br>
- This commit simply 'un-retains' the device causing it to be freed.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-03 16:20: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=2c2fab370060e84b55c74c1c99fa1a8046a5b4f8">2c2fab370060e84b55c74c1c99fa1a8046a5b4f8</a>
-<blockquote>
-<p>
- Font copying - fix memory leak<br>
-<br>
- When copying a glyph for a copied font, if we encountered the same glyph<br>
- twice, with the same name, we simply replaced the name in the name table<br>
- of the copied font. If there was already an entry then it would leak.<br>
-<br>
- Note that a second instance of the glyph with a different name would<br>
- end up in the extra names table and doesn't leak.<br>
-<br>
- Fix the leak by freeing the existing string copy if we have a new one.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-02 13:50: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=bc0403425e55309fbf372a7ebc66037d74e140d8">bc0403425e55309fbf372a7ebc66037d74e140d8</a>
-<blockquote>
-<p>
- pdfwrite - add a new method to detect pdfmark-capable devices<br>
-<br>
- The existing method to determine if the current device is capable of<br>
- processing pdfmark operations only works in PostScript. Since pdfmark<br>
- is a PostScript operator this isn't unreasonable, but we need a way for<br>
- the pdfi interpreter to know that a device is capable of handling<br>
- pdfmarks, because some information from the current interpreter is<br>
- passed that way (eg DOCINFO).<br>
-<br>
- Add a new parameter &quot;PdfmarkCapable&quot; which can be retrieved via a<br>
- spec_op. Any device capable of handling pdfmarks (via put_param calls)<br>
- must return true for this parameter.<br>
-<br>
- Update the current PDF interpreter to use this instead of the PostScript<br>
- method.<br>
-<br>
- Note: the ps2write device is *not* PdfmarkCapable.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-31 14:29:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=54304275c68abdf131d2e4f511bcc7475f611b30">54304275c68abdf131d2e4f511bcc7475f611b30</a>
-<blockquote>
-<p>
- oss-fuzz 23113: Bounds check buffer in gs_scan_token()<br>
-<br>
- To handle malformed/multiply negated numbers (e.g. &quot;---1&quot;) in PDF files,<br>
- the number scanning code skips over multiple leading minus signs (*only* for<br>
- PDFs), but code skipping the minus signs did not bounds check the buffer, so<br>
- could rattle off the end.<br>
-<br>
- Unfortunately, where this happens, there is no way for us to differentiate<br>
- between a (malformed) token that straddles a buffer boundary, or a (strange!)<br>
- token that is the entire buffer.<br>
-<br>
- As the code in question is only active for PDF interpreting, and the Postscript<br>
- PDF interpreter uses the &quot;token&quot; operator to tokenize stream contents, we can<br>
- assume (in this case) the buffer is the entire token.<br>
-<br>
- So, in the event we hit the end of the buffer without reaching something other<br>
- than a '-' then reset the buffer pointer, and &quot;retry&quot; it as a name.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-31 09:39: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=86f8c00204342436a09d7fac2ea6d0bb551b9118">86f8c00204342436a09d7fac2ea6d0bb551b9118</a>
-<blockquote>
-<p>
- CID 361525: Protect from NULL pointer deref (z_fontenum)<br>
-<br>
- In reality, the NULL pointer dereference here is not actually possible (barring<br>
- memory corruption issues), but the checks are trivial, the code only runs<br>
- at most once per job, enumerating the fonts is the slow part of the process,<br>
- rather than the linked list management, and it seems easiest to just placate<br>
- Coverity.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-31 13:48: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=0b9dbbc38d1d0e5593452337b6a45431053a1ba0">0b9dbbc38d1d0e5593452337b6a45431053a1ba0</a>
-<blockquote>
-<p>
- Fix crash with copied TrueType fonts and pdfwrite<br>
-<br>
- When freeing a copied font we now test for the data pointer being<br>
- non-NULL instead of checking the size of the string. This was because<br>
- we would still create strings for glyphs with a length of 0 and using<br>
- the size meant we would not free those strings, leading to a memory<br>
- leak.<br>
-<br>
- However this causes problems (only for 0 length data) with TrueType<br>
- fonts regarding ownership. We avoid this by not allocating any memory<br>
- for 0 length string data.<br>
-<br>
- We do need to fill in the remaining elements of the copied glyph though.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-28 08:56:23 +0100
-</strong>
-<br>Peter Cherepanov &lt;sphinx.pinastri@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0ab8e25b94c837c6128fff791b2a99486b1ee73c">0ab8e25b94c837c6128fff791b2a99486b1ee73c</a>
-<blockquote>
-<p>
- Bug 702620: Fix linked list creation in z_fontenum<br>
-<br>
- Fixes memory leak.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-28 09:31:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9bd1cdde34a49e6c0b885db5e258a41a4fccda52">9bd1cdde34a49e6c0b885db5e258a41a4fccda52</a>
-<blockquote>
-<p>
- Bug 702837 typo in warning message<br>
-<br>
- Thanks to Herbert Voss for spotting this. Fixed the typo and updated the<br>
- version number in the warning from 9.53 to 9.53.0 to match the actual<br>
- version and patch number of the release (the decision to add the patch<br>
- level was taken after the original commit)<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-27 20:35: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=1f6172705bb2811986175d72484705d68995fdd1">1f6172705bb2811986175d72484705d68995fdd1</a>
-<blockquote>
-<p>
- Bug 700404: Make Windows usertime be CPU time, not elapsed time.<br>
-<br>
- Thanks to Peter Cherepanov for this patch (and his patience in having<br>
- it accepted). Tested with VS 2005, 2008, 2015 and 2019.<br>
-<br>
- WIth this change Windows operates like linux. Note that usertime always<br>
- returns 0 the first time it is called (refer to commit cc156631). This<br>
- is a bit confusing, but is intentional.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-27 12:19:53 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49c4fa7e6c1a750ed976c7f1f46e3f8474249993">49c4fa7e6c1a750ed976c7f1f46e3f8474249993</a>
-<blockquote>
-<p>
- Fix pdfwrite memory leak in pattern clists<br>
-<br>
- This is for non-GC interpreters only.<br>
-<br>
- This code is very convoluted, but I think the -&gt;retained flag can be<br>
- used to see if it's okay to safely free the memory.<br>
-<br>
- In the case of patterns, for at least some cases the ctile wasn't<br>
- in the cache so it didn't free anything in gx_pattern_cache_free_entry().<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-27 13:54:33 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=94c344c43b274c86f529916085e02d7dc50d5edb">94c344c43b274c86f529916085e02d7dc50d5edb</a>
-<blockquote>
-<p>
- Bug 702785: Add UTF-8 encoding for strings in Info dict to pdf_info.ps<br>
-<br>
- Thanks to Peter Cherepanov for this change.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-26 10:15:58 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d7a70f69851a071eb9dfe7a968e2cb2f6302f1ba">d7a70f69851a071eb9dfe7a968e2cb2f6302f1ba</a>
-<blockquote>
-<p>
- Bug 702806: Performance decreases throughout file, PS to PDF<br>
-<br>
- A sample file of 1,000 pages from the customer allowed us to reproduce<br>
- the issue. The file creates MANY fonts (3,398 over the 1,000 pages),<br>
- and the font_cache list (not really a cache) would have the newest<br>
- created fonts at the head of the list, but later pages would use<br>
- fonts created earlier that were at the end of the list.<br>
-<br>
- Fix this by moving the found font to the head of the list (MRU).<br>
- On this file, the time on a fast machine went from 152 to 65 seconds<br>
- and the times for pages does not show the growth seen originally.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-27 15:31: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=225de4d2960f187a49521097a4235872d94a8fb3">225de4d2960f187a49521097a4235872d94a8fb3</a>
-<blockquote>
-<p>
- pdfwrite - fix memory leak in copied font<br>
-<br>
- This really should have been fixed by an earlier commit, but it had a<br>
- dumb error. We were freeing cfdata-&gt;names after we'd checked the<br>
- first entry in the table, instead of checking *every* entry in the<br>
- table first. In fact the memory was already freed blow so we didn't<br>
- need this at all.<br>
-<br>
- In addition the code to free extra_names was inside the loop and didn't<br>
- need to be as its a linked list not an array. So move it outside where<br>
- it will only execute once. Should be a tiny bit faster.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-27 14:11: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=53c10bd88f272c25fc5475dc63ea55140b9616db">53c10bd88f272c25fc5475dc63ea55140b9616db</a>
-<blockquote>
-<p>
- pdfwrite - fix several memory leaks with colour spaces<br>
-<br>
- The colour space creation code uses pdf_string_to_cos_name() quite<br>
- frequently, and it often then passes the resulting cos_value_t to<br>
- functions such as cos_array_put and cos_dict_put.<br>
-<br>
- The basic 'put' functions actually copy scalar objects when they are<br>
- put in an array or dictionary (but they don't copy other composite<br>
- objects!) so we need to free the object created by<br>
- pdf_string_to_cos_name() after we've 'put' it.<br>
-<br>
- The only function to do that is cos_value_free() but that (unreasonably)<br>
- requires a cos_object_t parameter, even though the cos_value may not<br>
- be in a cos_object. Since the only use for the cos_object is to<br>
- retrieve a memory_t pointer in order to free the data used, we can<br>
- simply replace the cos_object_t * with a gs_memory_t * and use that<br>
- directly.<br>
-<br>
- This meant a few places needed to change where cos_value_free() was<br>
- already being used.<br>
-<br>
- After that I rationalised the code in gdevpdfc.c to some extent. Instead<br>
- of the existing mixture of *_put() and *_put_no_copy() calls I've chosen<br>
- to use *_put() calls throughout and then explicitly free the data which<br>
- has supposedly been copied.<br>
-<br>
- We could have used _nop_copy() throughout but that would have meant<br>
- checking the return value and freeing the original data if the copy<br>
- failed. It seems simpler just to unconditionally free the original<br>
- data.<br>
-<br>
- In one place we also need to check that the original data was not NULL<br>
- and that it was a scalar type. This is because (as noted above) if it<br>
- isn't a scalar type the *_put() functions *don't* copy the value, so we<br>
- don't want to free the original data in this case as it has been<br>
- transferred to the cos_object.<br>
-<br>
- Nancy did most of the original work on discovering the actual memory leak<br>
- here, and suggesting the basic fix, so many thanks!<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-27 14:00:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=73856faec1a4e1ed7d4099ec4a05f30d53c7c429">73856faec1a4e1ed7d4099ec4a05f30d53c7c429</a>
-<blockquote>
-<p>
- pdfwrite - fix memory leak when allocation of a base font fails<br>
-<br>
- When the allocation of a PDF base font (pbfont) fails we were only<br>
- freeing the memory used by the structure, not any of the components<br>
- stored in it.<br>
-<br>
- There are quite a few subsidiary elements which need to be free and<br>
- there is already code to handle this, but its bundled up in<br>
- pdf_font_descripto_free(). So to make this easier, break out the code<br>
- to free the base font from pdf_fotn_descriptor_free() into its own<br>
- routine, pdf_base_font_free() and call that from both<br>
- pdf_font_descriptor_free() and pdf_base_font_alloc().<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-27 13:57:21 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=346ea731a43062662e57038aceea28859de51be6">346ea731a43062662e57038aceea28859de51be6</a>
-<blockquote>
-<p>
- pdfwrite - fix memory leak when gs_copy_font fails<br>
-<br>
- If we can't copy the /.notdef glyph into a font we fail (its a<br>
- requirement for a valid font in a PDF file to have at least a /.notdef).<br>
-<br>
- If that happened we did not free the newly made copy of the font. Fix<br>
- that by freeing the copy.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-25 15:17:45 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=367c3858886d1c43b75e3ea48f770d80db800d15">367c3858886d1c43b75e3ea48f770d80db800d15</a>
-<blockquote>
-<p>
- Add OCREngine parameter.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-27 12:33:35 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=30c56c669b05dd09518fad60a8f0ae8de4bcf186">30c56c669b05dd09518fad60a8f0ae8de4bcf186</a>
-<blockquote>
-<p>
- Add runtests to clustermaster.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-26 16:11:27 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a5a9da62c49f1881186b2528f45f3ef846ad70ed">a5a9da62c49f1881186b2528f45f3ef846ad70ed</a>
-<blockquote>
-<p>
- Add Makefile for api_test<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-26 12:44:03 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a69fc03408010df05732af7da229b64a181b7edf">a69fc03408010df05732af7da229b64a181b7edf</a>
-<blockquote>
-<p>
- Fix api_test.c for compiling on Linux.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-25 14:17: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=99a34d86e93eb482c12c2143a31cfc227042dcf9">99a34d86e93eb482c12c2143a31cfc227042dcf9</a>
-<blockquote>
-<p>
- Fix memory leak in pdfwrite images with errors in them.<br>
-<br>
- This was only a problem in non-GC interpreters (e.g. pdfi)<br>
-<br>
- This was an error that specifically affected images that got an<br>
- error during the first row (so data_height == 0).<br>
-<br>
- Added pdf_end_abort_image() to abort an image without writing it.<br>
- Also make sure to clean up the streams.<br>
-<br>
- Sample file: Bug 688023 test_out.pdf<br>
- Also: tests/pdf/Jbig2_042_13.pdf<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-24 17:43:05 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3812280c5b021b16cce184b7aa6981d51a6ee5be">3812280c5b021b16cce184b7aa6981d51a6ee5be</a>
-<blockquote>
-<p>
- Bug 702761: Improve handline of PS file with many large ReusableStreams<br>
-<br>
- This file, with its original, non-optimal, method collected 1,000 ReusableStream<br>
- files, each of which was 7.5Mb, stored as 1,000 arrays of 180 40,000 byte strings.<br>
- As the file progressed, the load on the GC (garbage collector) to mark-and-sweep<br>
- all of those strings got slower and slower.<br>
-<br>
- This change collects the strings in the array of strings into a single large<br>
- string (up to max_string_size, currently 16Mb), so the load on the GC is cut<br>
- down to finding and freeing the array-of-strings since the last GC, and the<br>
- (at most) 1,000 strings, one for each ReusableStreamDecode &quot;file&quot; object.<br>
-<br>
- The submitter has already accepted the change to avoid storing the expanded<br>
- raw Image data, but there are other usages of ReusableStreamDecode that may<br>
- be used with large files (e.g. streamed PDF input files) that can benefit<br>
- from not loading down the GC.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-25 12:16:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e9104765e434280d4de3c781dfa5b9bebd5a524f">e9104765e434280d4de3c781dfa5b9bebd5a524f</a>
-<blockquote>
-<p>
- pdfwrite - fix another memory leak<br>
-<br>
- When we close down pdfwrite we check the stack of saved gstates to<br>
- see if there are any dash patterns to be freed. We must check the<br>
- entire potential stack, not just to the current level, in case we<br>
- allocated a dash pattern copy at a deeper level than we were at when<br>
- we exited.<br>
-<br>
- Because dash_patttern is allocated in non-gc memory this leak affects<br>
- all interpreters.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-25 12:13:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e59bed1d7e3481e74168fdaa0b3e1293acc30d2b">e59bed1d7e3481e74168fdaa0b3e1293acc30d2b</a>
-<blockquote>
-<p>
- pdfwrite - more memory leak fixes with fonts<br>
-<br>
- When we free a font copy we need to:<br>
-<br>
- 1) Free the client_data 'names' array as well as the strings it contains<br>
- 2) Free the extra_names linked list.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-24 22:41:41 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fc3184789d23b42ba7ded18b2626c59e7d176624">fc3184789d23b42ba7ded18b2626c59e7d176624</a>
-<blockquote>
-<p>
- C# API demo. Make printing (creation of XPS content) a different process<br>
-<br>
- Since we are limited to one instance, we will go ahead and launch a different<br>
- process which will be handed arguments to do the printing, which involves the<br>
- creation of XPS content via the xpswrite device which is then fed through<br>
- the Windows XPS printing pipeline.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-24 10:01: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=e7d5f25fc87573361cf5ec3a533021562659bff2">e7d5f25fc87573361cf5ec3a533021562659bff2</a>
-<blockquote>
-<p>
- C# API. Minor cleanup of viewer demo application.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-24 18:55:30 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad0678d3d34948eb7c316b5511ffdb098e3afab2">ad0678d3d34948eb7c316b5511ffdb098e3afab2</a>
-<blockquote>
-<p>
- Fix Tesseract traineddata file loading.<br>
-<br>
- If it was finding any Tesseract data in ROM it was then not looking<br>
- for files.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-21 18:44:33 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f26bb372f3c2d8e564074c08943b60682bc8ed8c">f26bb372f3c2d8e564074c08943b60682bc8ed8c</a>
-<blockquote>
-<p>
- Fix gs_main_set_language_param to escape encapsulation.<br>
-<br>
- If we are running in JOBSERVER mode, then postscript can't set stuff<br>
- into systemdict while in a job. We need to exit the encapsulation,<br>
- set the param, then reenter.<br>
-<br>
- (Contrary to my memory, dnit_job does not exit the encapsulation - or<br>
- rather it does, but it unsets the device, and then immediately reenters<br>
- encapsulation again.)<br>
-<br>
- Thanks are due to Ray for identifying the problem, and to Chris<br>
- for being a sounding board.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-21 18:57: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=302aa9db9f03c2d0795ec8a8c249571bf86cd555">302aa9db9f03c2d0795ec8a8c249571bf86cd555</a>
-<blockquote>
-<p>
- Tidy up setting user params for PDF processing<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-21 18:50: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=6153b859d1fd3780cb95d20f678843ab1ba470a1">6153b859d1fd3780cb95d20f678843ab1ba470a1</a>
-<blockquote>
-<p>
- PDF interp: Consolidate disabling of page handler device<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-24 09:24: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=9daf042fd7bb19e93388d89d9686a2fa4496f382">9daf042fd7bb19e93388d89d9686a2fa4496f382</a>
-<blockquote>
-<p>
- Coverity 361429: move &quot;break&quot; to correct place.<br>
-<br>
- We had to add the outputfile to the &quot;control&quot; file permission list (as well<br>
- as write), but for the &quot;pipe&quot; case, I accidentally added the call after the<br>
- break out of loop that checks for a pipe.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-20 18:31:00 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e3540010069071c8f9d52d2486067940a23b6e3">2e3540010069071c8f9d52d2486067940a23b6e3</a>
-<blockquote>
-<p>
- Rejig gs_pattern1_make_pattern TilingType != 2 behaviour.<br>
-<br>
- Firstly, we change the rounding on bbw so as to give minimum<br>
- distortion to the pattern size.<br>
-<br>
- Secondly, we scale the contents to avoid either nasty gaps around<br>
- the edges, or lost content around the edges.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-20 17:46:13 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb6a8352a2ba5b1c5b866b27638db4eaf2acac0f">fb6a8352a2ba5b1c5b866b27638db4eaf2acac0f</a>
-<blockquote>
-<p>
- Whitespace/Layout changes to gs_pattern1_make_pattern.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-19 19:24:19 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3e74ad126ee3983c634b8254dec0fc3b6544f0bd">3e74ad126ee3983c634b8254dec0fc3b6544f0bd</a>
-<blockquote>
-<p>
- Rejig internals of gs_pattern1_make_pattern.<br>
-<br>
- Previously we called &quot;compute_inst_matrix&quot; once at the start, then<br>
- maybe either called it again (if we ADJUST_SCALE_BY_GS_TRADITION)<br>
- or manually did part of it (retransforming the bbox) (if we<br>
- ADJUST_AS_ADOBE).<br>
-<br>
- Due to the vagaries of floating point, we can't be sure that<br>
- retransforming the bbox will give exactly the same result (as<br>
- our attempt to move the bbox onto a pixel origin may result<br>
- in future transformations may give x +/- epsilon rather x,<br>
- for example). Consequently, when we retransform, follow the<br>
- same procedure as we did before.<br>
-<br>
- This produces some diffs. We choose to accept these (minor) diffs<br>
- to give us consistent results.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-19 19:15:00 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a3e7fa93b5f6afe7d74bf7c654dec1cff1adb76d">a3e7fa93b5f6afe7d74bf7c654dec1cff1adb76d</a>
-<blockquote>
-<p>
- Simplify parameter passing in compute_inst_matrix.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-24 14:40: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=65942618d083d49467f3dd6d9a802e94c6ae0796">65942618d083d49467f3dd6d9a802e94c6ae0796</a>
-<blockquote>
-<p>
- pdfwrite - fix another type 3 memory leak this time with CharProcs<br>
-<br>
- CharProcs are a cos object, not a simple byte array, so when we free<br>
- them we need to use cos_free() not gs_free_object().<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-24 14:38: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=2fdd3c0b9140dd8bd5a9b9bfdcc5ba4683a6eea0">2fdd3c0b9140dd8bd5a9b9bfdcc5ba4683a6eea0</a>
-<blockquote>
-<p>
- pdfwrite - fix memory leak with type 3 fonts<br>
-<br>
- When freeing type 3 font *resources* (ie the copy pdfwrite keeps to<br>
- write into the PDF file) we were not freeing some of the allocated<br>
- objects, the 'cached' array and the Resources (which are a dictionary<br>
- and so need to be freed by cos_free).<br>
-<br>
- Include gdevpdfo.h for the definition of cos_free()<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-24 09:01: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=a7cd4bbf979f2ecbaf19485cbfef42dcb179a927">a7cd4bbf979f2ecbaf19485cbfef42dcb179a927</a>
-<blockquote>
-<p>
- pdfwrite - fix some typos in comments<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-24 09:01: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=c5ae29c5b4ae5d4d9488842275d229b39f445bf1">c5ae29c5b4ae5d4d9488842275d229b39f445bf1</a>
-<blockquote>
-<p>
- Coverity ID 361427 fix uninitialised variable.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-22 13:57:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3f04eaa6230cfe22b944bde4eaeed6c3087d5189">3f04eaa6230cfe22b944bde4eaeed6c3087d5189</a>
-<blockquote>
-<p>
- pdfwrite - fix numerous font-related memory leaks<br>
-<br>
- The pdfwrite device was originally written to do all its memory<br>
- management via garbage collection, Unfortunately this leads to numerous<br>
- memory leaks when using an interpreter which doesn't implement a<br>
- garbage collecting memory model. Currently that's everything except<br>
- the PostScript interpreter.<br>
-<br>
- Many of these leaks cannot be exercised by anything except the<br>
- PostScript interpreter (and the new pdfi interpreter) but I think some<br>
- certainly could be.<br>
-<br>
- Don't increment the 'subst' structure when copying a TrueType CIDFont,<br>
- this leads to the structure never being freed.<br>
-<br>
- The code to free the 'subst' CID when freeing a TrueType CIDFont was<br>
- incorrect, leading to memory crashes (previously it was simply never<br>
- executed, and leaked).<br>
-<br>
- When increasing the size of the CIDMap entry for a TrueType CIDFont,<br>
- free the memory used by the original map after copying the data and<br>
- before overwriting the stored pointer.<br>
-<br>
- When freeing a copied font, if the font is a TrueType CIDFont decrement<br>
- the 'subst_CID_on_WMode' member so that it gets freed.<br>
-<br>
- When freeing a copied font, use the copied glyph data 'data' member<br>
- rather than the 'size' member to decide if we should free the data.<br>
- Sometimes we allocate memory for a size of 0.<br>
-<br>
- When freeing a copied font, if we created a names array for the glyphs<br>
- we need to free the string copies of the names we created as well.<br>
-<br>
- When freeing a copied font, if the CIDFMap entry has been created we<br>
- must free that too.<br>
-<br>
- When dropping a 'complete' font copy because we won't be using it, do<br>
- not simply set the pointer to NULL but actually call code to free the<br>
- copied font properly.<br>
-<br>
- When freeing a pdfwrite copy of a base font, if the CIDSet member has<br>
- been allocated we need to free it.<br>
-<br>
- When adding to the pdfwrite font cache, if the glyph_usage and<br>
- real_widths members have already been allocated we must free them before<br>
- assigning newly allocated memory.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-21 12:16:26 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8fcc3e370c3aca71691d48c92d57d7c2ca80672d">8fcc3e370c3aca71691d48c92d57d7c2ca80672d</a>
-<blockquote>
-<p>
- C# API: Addition of gsapi_get_param and gsapi_set_param<br>
-<br>
- Preliminary use of these. Which has revealed issues in GPDL with first page<br>
- last page use for PDF files.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-21 11:13: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=d55c0edd6c1671d3a09a6061a81e25c0d414cc3f">d55c0edd6c1671d3a09a6061a81e25c0d414cc3f</a>
-<blockquote>
-<p>
- More version number fixes<br>
-<br>
- The code to retrieve the Ghostscript paths from the Windows Registry<br>
- was generating a key based on the version number, but since we added the<br>
- patch the generation was incorrect.<br>
-<br>
- Since this is the third (!) case of this, scan the code for any usage of<br>
- gs_version, gs_version_number, GS_VERSION, GS_VERSION_NUMBER,<br>
- gs_revision, gs_revision_number, GS_REVISION and GS_REVISION_NUMBER.<br>
-<br>
- This reveals two more places, neither serious but we might as well fix<br>
- them while we're here.<br>
-<br>
- Thanks to Akira Kakuto for finding this problem and suggesting a patch.<br>
- I chose to use the code we were already using in two other places, just<br>
- for consistency, but the supplied patch was equally good.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-20 14:46:07 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34259c34410f7903981d61f1fc9c0b00fd9b3ed1">34259c34410f7903981d61f1fc9c0b00fd9b3ed1</a>
-<blockquote>
-<p>
- Fix memory leak in freeing dash_pattern from pdfwrite device state<br>
-<br>
- The vgstack_depth = 0 still means that the entry needs to be freed.<br>
- (off by one error)<br>
-<br>
- This was a leak in both gs and pdfi<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-20 18:33:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fae04c94708feb693e7582a9707ca2791e30334e">fae04c94708feb693e7582a9707ca2791e30334e</a>
-<blockquote>
-<p>
- Delete binary files from lcms2mt tree<br>
-<br>
- There were left over binary libraries, remove them.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-20 17:19: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=3920a727fb19e19f597e518610ce2416d08cb75f">3920a727fb19e19f597e518610ce2416d08cb75f</a>
-<blockquote>
-<p>
- Fix pdfwrite &quot;%d&quot; mode with file permissions<br>
-<br>
- Firstly, in gx_device_delete_output_file the iodev pointer was being passed<br>
- to the delete_method incorrectly (passing a pointer to that pointer). Thus<br>
- when we attempted to use that to confirm permission to delete the file, it<br>
- crashed. Credit to Ken for finding that.<br>
-<br>
- Secondly, due to the way pdfwrite works, when running with an output file per<br>
- page, it creates the current output file immediately it has completed writing<br>
- the previous one. Thus, it has to delete that partial file on exit.<br>
-<br>
- Previously, the output file was not added to the &quot;control&quot; permission list,<br>
- so an attempt to delete it would result in an error. So add the output file<br>
- to the &quot;control&quot; as well as &quot;write&quot; list.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-13 09:47:09 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cb93fa6079796d99b3fb3cfbdd0b919f57d34f58">cb93fa6079796d99b3fb3cfbdd0b919f57d34f58</a>
-<blockquote>
-<p>
- Fix memory leaks associated with pdfwrite, type3x images<br>
-<br>
- These leaks are only an issue for non-GC interpreters such as pdfi.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-19 14:31: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=ac67c85c93703d6883f6d32a6996f33a51293640">ac67c85c93703d6883f6d32a6996f33a51293640</a>
-<blockquote>
-<p>
- Bug702727 -- Fix rc counting of penum-&gt;pcs for image1 and image4<br>
-<br>
- This relates to the structure gx_image_enum_s which is used by image1<br>
- and image4.<br>
-<br>
- The fix is unfortunately scattered around the code, but I think I found<br>
- appropriate places. It is ugly because type1 and type4 images<br>
- apparently share a lot of the same code, so the module layers are not<br>
- as they should be.<br>
-<br>
- Need to increment and decrement the rc since the enum struct wants to<br>
- keep it around (especially in gs where it literally goes back out into<br>
- the gs interpreter between when the enum is built and when it is<br>
- used!).<br>
-<br>
- This is part of cleaning up memory leaks for non-GC interpreters<br>
- (pdfi).<br>
-<br>
- Changed the pcs entry in the enum struct to not be const, since it<br>
- needs to be reference counted.<br>
-<br>
- Cleaned up an unrelated compiler warning in gxidata.c<br>
- There are also some unrelated whitespace changes.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-20 13:53: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=d434639da425b6172fe1230bbc331ec057daff6f">d434639da425b6172fe1230bbc331ec057daff6f</a>
-<blockquote>
-<p>
- Trim trailing white space<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-20 12:12: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=3808bc680a35b6a19b75555539f66fdd874138f5">3808bc680a35b6a19b75555539f66fdd874138f5</a>
-<blockquote>
-<p>
- txtwrite - improve CIDFont handling<br>
-<br>
- The calculation of the font size for modes 0 &amp; 1 was incorrect when the<br>
- font was a CIDFont. The size calculation relied upon the FontMatrix of<br>
- the type 0 font and did not consider the descendant.<br>
-<br>
- For PDF files we can ignore the type 0 font and simply use the<br>
- descendant font matrix. For PostScript input we will probably have to<br>
- be more careful so this is an interim fix for PDF input only.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-20 12:10: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=39a9388184d1788d48e35c47a3e92a4411d106f7">39a9388184d1788d48e35c47a3e92a4411d106f7</a>
-<blockquote>
-<p>
- PDF interpreter - reject non-dictionary /Annots array entries<br>
-<br>
- Bug #702745 &quot;Error: /typecheck in --runpdf--&quot;<br>
-<br>
- The PDF file has an invalid /Annots array entry:<br>
-<br>
- 5 0 obj<br>
- &lt;&lt;/Annots[5 0 41 0 R]<br>
-<br>
- The entries should be dictionaries or indirect references to<br>
- dictionaries, integers aren't valid. This causes a typecheck error when<br>
- trying to read keys from the dictionary.<br>
-<br>
- This commit checks that the entry is a dictionary before trying to<br>
- process it; if it isn't we raise a warning and ignore it.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-20 09:12: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=c935055b6b5d20fceb6175877bee9b529dddb199">c935055b6b5d20fceb6175877bee9b529dddb199</a>
-<blockquote>
-<p>
- Fix PDF /Producer for new patch level<br>
-<br>
- Bug #702772 &quot;Strange /Producer attribute&quot;<br>
-<br>
- The change to include a patch level for Ghostscript in the gs_revision<br>
- value wasn't being reflected in the code to generate the version<br>
- number used in the PDF /Producer string.<br>
-<br>
- Copied the code from printf_program_ident() in base/gsmisc.c to the<br>
- code in pdf_store_default_Producer() and commented both pieces of code<br>
- to note the existence of each other so that in future hopefully we won't<br>
- forget to keep them in sync.<br>
-<br>
- Thanks to Peter Cherepanov for spotting the flaw.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-19 11:49:39 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d07b9485b2bb3a70552aee9407fcff8fa52698df">d07b9485b2bb3a70552aee9407fcff8fa52698df</a>
-<blockquote>
-<p>
- Fix memory leak in pdf_begin_typed_image()<br>
-<br>
- Need to decrement the ColorSpace before overwriting it.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-19 11:38:03 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=99e437e619fbd3d91242cba98cc462dadb9a5b8e">99e437e619fbd3d91242cba98cc462dadb9a5b8e</a>
-<blockquote>
-<p>
- Fix some compiler warnings<br>
-<br>
- This also has some whitespace changes -- not my fault! :)<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-18 14:49:41 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a111d7316b0cb2dea8f840e8387fc47b9e252c36">a111d7316b0cb2dea8f840e8387fc47b9e252c36</a>
-<blockquote>
-<p>
- Refactor pdf_begin_typed_image()<br>
-<br>
- Mainly just cleaning up the error handling so it all exits at the<br>
- bottom.<br>
-<br>
- Reduced the amount of duplicate code.<br>
-<br>
- Fixed a bunch of memory leaks that would only happen on error<br>
- paths.<br>
-<br>
- Broke out the Eps2Write code to reduce size of main function a bit.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-18 11:15:26 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ccf8a357a8fce8998ad8d4ab5abb3a4c6b63374">4ccf8a357a8fce8998ad8d4ab5abb3a4c6b63374</a>
-<blockquote>
-<p>
- Fix one of several memory leaks in pdfwrite images<br>
-<br>
- The leak is in non-GC interpreters such as pdfi.<br>
-<br>
- This is a 1600 line function. I think it is in drastic need of<br>
- refactoring in order to be maintainable.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-19 18:21: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=cc90efbe4abce945e36a68876218a46606b84015">cc90efbe4abce945e36a68876218a46606b84015</a>
-<blockquote>
-<p>
- Tweak type1 pattern code to remove some needless fabs.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-18 23:23: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=ec2699f50aa3ada4ef2c477c7577331a3950bcc8">ec2699f50aa3ada4ef2c477c7577331a3950bcc8</a>
-<blockquote>
-<p>
- Fix Bug 702381: Hang due to cyclic PDF resources.<br>
-<br>
- The loop is caused by a circular /ParentResources attribute.<br>
- This branch of code is triggered by an error in the sample file:<br>
- misplaced /Form resources in a Type 3 font. This font has /Resource<br>
- dictionaries added to /CharProcs entries rather than the font dictionary.<br>
-<br>
- Note that this patch fixes the hang issue, but does not correct the<br>
- issue of not being able to find the correct resource (in the CharProc)<br>
- so that the file still output does not match Adobe (mupdf has that<br>
- same issue).<br>
-<br>
- Thanks to Peter Cherepanov for this patch.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-17 15:44: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=9619c8fc8d1e2548c737adfb7f6b8b15d49d20a4">9619c8fc8d1e2548c737adfb7f6b8b15d49d20a4</a>
-<blockquote>
-<p>
- Bug 702744: Add windows utf-8 handling for unlink and rename.<br>
-<br>
- To do this, we introduce gp_unlink and gp_rename, and call those<br>
- as appropriate.<br>
-<br>
- Also, make gp_open_scratch_file add the file to the permit list.<br>
- When such a file is closed, it will be deleted from the permit list.<br>
-<br>
- It will also be removed from the permit list if the file is deleted<br>
- using the PS deletefile operator.<br>
-<br>
- On closedown, if scratch files haven't been deleted, then we'll<br>
- delete them as part of the closedown of gs_lib_ctx.<br>
-<br>
- This means that 'purging' the control lists must not remove scratch<br>
- file paths from the list.<br>
-<br>
- Also, ensure that gsapi callers can't maliciously (or accidentally)<br>
- remove scratch path paths from the list so as to leave them around<br>
- after closedown.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-18 10:18: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=df245b46c1a5290239b2932e2a5d1bdeae710c48">df245b46c1a5290239b2932e2a5d1bdeae710c48</a>
-<blockquote>
-<p>
- Bump version number<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-28 12:54: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=5f75977a0da7b8e92f2b8241440c43cc44863f63">5f75977a0da7b8e92f2b8241440c43cc44863f63</a>
-<blockquote>
-<p>
- Docs/dates/version for 9.53.3<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-24 08:19: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=c876777dcadbb0acbc8cc887e94360c6f5adbc0d">c876777dcadbb0acbc8cc887e94360c6f5adbc0d</a>
-<blockquote>
-<p>
- WhatIsGS.htm updates from Lisa F<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-29 20:16: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=be33716b4a6d42f9bd5a5485514dbaeb9e9524b2">be33716b4a6d42f9bd5a5485514dbaeb9e9524b2</a>
-<blockquote>
-<p>
- Bug 702948: Ensure initial bitmap cache sizes are properly aligned<br>
-<br>
- Now that the allocations from the bitmap cache are aligned to the platform's<br>
- required alignment, see commit:<br>
-<br>
- 260c443bc14cdffa4d94e14c3a57e35bebee3a5b<br>
-<br>
- We also want the initial size of the memory pool used by the cache to be<br>
- &quot;aligned&quot;.<br>
-<br>
- This is so that code that attempts to identify cache entries to evict by<br>
- requesting a size equal to the entire size of cache memory pool doesn't get an<br>
- unexpected failure, because we've rounded up that allocation request to a value<br>
- larger than the entire size of the memory pool.<br>
-<br>
- Because we don't expect an error to be possible at that point, a crash can<br>
- occur.<br>
-<br>
- Of the &quot;normal&quot; platforms we use, this only exhibits on Win32 because that is<br>
- the only platform where the align_bitmap_mod we use is less than the<br>
- obj_align_mod used for the memory managers.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-28 20:10:16 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=27824a749775a233725cf3f302ce8156c478f7e1">27824a749775a233725cf3f302ce8156c478f7e1</a>
-<blockquote>
-<p>
- Fix icc profile reference counting in transparency compositor<br>
-<br>
- Found during Windows testing for a release.<br>
-<br>
- The full test file for<br>
- https://bugs.ghostscript.com/show_bug.cgi?id=693365<br>
-<br>
- would cause Ghostscript to crash due to an ICC profile being freed whilst a<br>
- reference was still being held for it. That was not counting up a reference<br>
- count when restoring the device profile back to a previous value.<br>
-<br>
- Fixing that introduced a leak for other profiles. And that turned out to be<br>
- not decrementing the reference count when replacing a device profile.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-28 10:21: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=d2fa2e186a6cdbdc011a44275532e2f1071111ec">d2fa2e186a6cdbdc011a44275532e2f1071111ec</a>
-<blockquote>
-<p>
- Work around for (I think) a VS2019 optimiser bug<br>
-<br>
- VS2019 release builds crash with the input file from bug 702916 and several<br>
- other files, in copied_glyph_slot() because the pointer retrieved and stored<br>
- in *pslot is non-sensical.<br>
-<br>
- Debug/Profile builds and optimised builds with earler VS versions don't show<br>
- the problem.<br>
-<br>
- Adding debug code to assign the calculated index to an interim unsigned integer<br>
- variable also cause the problem to go away.<br>
-<br>
- So, use that as a workaround.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-28 10:20:26 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd36db788b73674e9a18803f451ed910ddd66dba">cd36db788b73674e9a18803f451ed910ddd66dba</a>
-<blockquote>
-<p>
- Fix some casting confusion for special glyph CID/index values<br>
-<br>
- And a whitespace/indentation issue.<br>
-<br>
- Noticed in passing....<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-25 13:03: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=787be772d87089ee8224b17ba50ac4adccc75ffe">787be772d87089ee8224b17ba50ac4adccc75ffe</a>
-<blockquote>
-<p>
- Fix Bug 702941 - Mispelled PDF interpreter variable name.<br>
-<br>
- s/RepiredAnError/RepairedAnError/ A simple typo that was missed because<br>
- we did not have a test file with a format error to trigger this code.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-25 08:41:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f9cce5953cae92014ef6652894c183080dd5d19">4f9cce5953cae92014ef6652894c183080dd5d19</a>
-<blockquote>
-<p>
- Version, doc and date updates for 9.53.2<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-25 12:40:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=167c75d35336fcfe7c94cf5fb0258406443cdc6b">167c75d35336fcfe7c94cf5fb0258406443cdc6b</a>
-<blockquote>
-<p>
- Bug 702938: Allocating cached glyphs, account for alignment<br>
-<br>
- For efficiency, the glyph cache allocates &quot;large&quot; blocks of memory into which<br>
- it parcels out offsets for individual glyph cache bitmaps, as required.<br>
-<br>
- Since cached glyphs are usually fairly small, and potentially can be short<br>
- lived, this saves the overheads of &quot;full&quot; memory for every cached glyph.<br>
-<br>
- Unfortunately, in calculating the offsets for the cached glyph, it was failing<br>
- to account for the required alignment of the system. In any environment that<br>
- strictly enforces aligned memory accesses, this will potentially cause a bus<br>
- error.<br>
-<br>
- In this case, it was switching the gs_glyph type to a 64 bit type that triggered<br>
- the issue. But any changed to the contents of the cached_char struct could have<br>
- resulted in it happening.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-24 19:08: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=104dffc4aec03598257c14ab33b292c8e7149d59">104dffc4aec03598257c14ab33b292c8e7149d59</a>
-<blockquote>
-<p>
- Remove links to ghostscript.com/release_history.html<br>
-<br>
- That page is now gone.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-24 17:10:21 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1c4631aa8910f6da923367984491fc2b883d7a0">b1c4631aa8910f6da923367984491fc2b883d7a0</a>
-<blockquote>
-<p>
- Remove dead end links from Readme.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-23 20:20: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=334f24a4a8529f8476dfe74dd2b47f1274269263">334f24a4a8529f8476dfe74dd2b47f1274269263</a>
-<blockquote>
-<p>
- Bug 702920: Fix type confusion in new param type code.<br>
-<br>
- In a few cases we were using the wrong element in the union to read the<br>
- value back from the param list (and to range check the values).<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-15 08:51:08 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab2505e19cf36ffc780f6824a50c8e7eacf7af8f">ab2505e19cf36ffc780f6824a50c8e7eacf7af8f</a>
-<blockquote>
-<p>
- Fix problem with BGPrint and multi-threaded rendering caused by commit cca27988<br>
-<br>
- The unconditional call to enable multi-threaded rendering during set up of the<br>
- gx_device_printer as a clist caused the SEGV of bug 702181, but enabling<br>
- multi-threaded rendering here isn't correct since it is usually done when we<br>
- output the page (gdev_prn_output_page_aux). The problem is that BGPrint would<br>
- setup a new clist device to render the page, but needs to enable multi-threaded<br>
- rendering for the background clist device. Do this if NumRenderThreads &gt; 0.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-22 13:10:04 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a7d7b4f9ea347de35cbbec69a58c3a0a43fda447">a7d7b4f9ea347de35cbbec69a58c3a0a43fda447</a>
-<blockquote>
-<p>
- Fix gp_file allocations to use thread_safe_memory.<br>
-<br>
- The gpmisc.c does allocations for gp_file objects and buffers used by<br>
- gp_fprintf, as well as gp_validate_path_len. The helgrind run with<br>
- -dBGPrint -dNumRenderingThreads=4 and PCL input showed up the gp_fprintf<br>
- problem since the clist rendering would call gp_fprintf using the same<br>
- allocator (PCL's chunk allocator which is non_gc_memory). The chunk<br>
- allocator is intentionally not thread safe (for performance).<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-23 07:39:04 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a3f5d5ab9cc94ee433dafb5331519855f6671e6">7a3f5d5ab9cc94ee433dafb5331519855f6671e6</a>
-<blockquote>
-<p>
- Temporarily disable BGPrint for pcl, xps and gpdl.<br>
-<br>
- In order to safely allow for a 9.53.2 patch release that fixes BGPrint<br>
- with NumRenderingThreads while the issues with PCL and friends are<br>
- fixed, just ignore BGPrint in pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-16 07:48: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=7250256e29355b1ceccd06b3b937b7d0e739d1f7">7250256e29355b1ceccd06b3b937b7d0e739d1f7</a>
-<blockquote>
-<p>
- Bug 702904: Another fix to check for shared libjpeg/libtiff<br>
-<br>
- We cannot combine shared and not shared libjpeg and libtiff - they either both<br>
- need to be &quot;local&quot; or both shared, and configure checks that and fails when<br>
- the two are incompatible.<br>
-<br>
- However, that check would fail when either libjpeg or libtiff were not being<br>
- included at all. Since it is libtiff that is the &quot;problem&quot; for this<br>
- compatibility, now check if TIFF is included, and if not, skip the check.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-25 16:47:10 +0100
-</strong>
-<br>ChrisL &lt;cliddell@salvor-openbsd.lan&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1264b6debb1d48e2b9ea0eae8fda86c04f4def9d">1264b6debb1d48e2b9ea0eae8fda86c04f4def9d</a>
-<blockquote>
-<p>
- Fix the OpenBSD build<br>
-<br>
- Whilst hopefully not breaking the buildroot build.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-14 16:52:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6011a3d8096c51ae795b436f17b141cceba4d77b">6011a3d8096c51ae795b436f17b141cceba4d77b</a>
-<blockquote>
-<p>
- Bug 702901: initialize directory for tiff configure<br>
-<br>
- Previously the directory in which to run the libtiff configure script was<br>
- initialised to an empty string, but that, in some toolchains, resulted in an<br>
- error due to &quot;unsafe header/library path used in cross-compilation&quot;.<br>
-<br>
- So initialise it something benign instead.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-24 09:01: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=0712379d88c2697fef35e60107bf0201a5f1a790">0712379d88c2697fef35e60107bf0201a5f1a790</a>
-<blockquote>
-<p>
- Coverity ID 361427 fix uninitialised variable.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-14 14:12:23 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=09763e4d082755436bb36bbef912193357058535">09763e4d082755436bb36bbef912193357058535</a>
-<blockquote>
-<p>
- Update docs for 9.53.1 release<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-14 14:32: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=6d1440b2dabde655a2fe48ddbf0c09a82de4d423">6d1440b2dabde655a2fe48ddbf0c09a82de4d423</a>
-<blockquote>
-<p>
- Fix crashes with pdfwrite, TrueType input fonts and Windows 64-bit build<br>
-<br>
- With the change to 64-bits unconditionally for gs_glyph we can now<br>
- define GS_MIN_CID_GLYPH in 64-bit terms.<br>
-<br>
- Previously we were using the architecture size of a long_long to<br>
- determine which define to use, and we do not define long_long on Windows<br>
- leading to us using an essentially 32-bit definition. This caused<br>
- indexing off the end of an array in copied_glyph_slot()<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-14 09:40: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=e54e9c5eaebc0bf06e57f754a3c16278de412459">e54e9c5eaebc0bf06e57f754a3c16278de412459</a>
-<blockquote>
-<p>
- Bug 702897: Fix shared libtiff/libjpeg check<br>
-<br>
- For various reasons we cannot combine shared and not shared libjpeg and<br>
- libtiff - they either both need to be &quot;local&quot; or both shared.<br>
-<br>
- But the check for that compatibility was triggered during the recursive<br>
- configure call when setting up for cross compiling.<br>
-<br>
- Skip the check for that recursive configure call.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-10 16:18: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=f157ed49512438c95635e6340933bbcb14cea524">f157ed49512438c95635e6340933bbcb14cea524</a>
-<blockquote>
-<p>
- Tweak History9.htm with jbig2dec updates<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-10 22:47:09 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a5ace846c8af91d047e59c87722d0c36e79e5d3">9a5ace846c8af91d047e59c87722d0c36e79e5d3</a>
-<blockquote>
-<p>
- Bug 702884: Require jbig2dec 0.19 when building ghostscript.<br>
-<br>
- In practice this has been required since commit<br>
- 9b5008aa2bc1c6a6acb2c6f90d1ef8d6bad9e66a.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-10 22:41:20 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=53db58bd227c80375f00135045d36b66868732f4">53db58bd227c80375f00135045d36b66868732f4</a>
-<blockquote>
-<p>
- Update jbig2dec stuff for 0.19 release.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-10 08:49:46 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1af88d327daa9392f5c6542dc7e247ddab7c9b0b">1af88d327daa9392f5c6542dc7e247ddab7c9b0b</a>
-<blockquote>
-<p>
- Docs and dates for 9.53.0<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-09 11:50: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=45884ca68488ac470b894702bdd8da232743d8e4">45884ca68488ac470b894702bdd8da232743d8e4</a>
-<blockquote>
-<p>
- Bug 702871: Fix GraphicsAlphaBits + Fill/Stroke issue.<br>
-<br>
- When we flush the alphabuffer, mapped_start and mapped_height are<br>
- both set to zero. When we refill it, mapped_height is set to<br>
- non-zero. USUALLY mapped_start is set to non-zero too, but it can<br>
- be set to zero when we are close to the bottom of the page.<br>
-<br>
- Hence we should test for mapped_height != 0, rather than both<br>
- mapped_height and mapped_start being non-zero.<br>
-<br>
- So the 'quick hack' that Chris used is actually correct.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-28 09:31:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ba6aa1d7253e8ecd7cd796c95306f1203f70879">4ba6aa1d7253e8ecd7cd796c95306f1203f70879</a>
-<blockquote>
-<p>
- Bug 702837 typo in warning message<br>
-<br>
- Thanks to Herbert Voss for spotting this. Fixed the typo and updated the<br>
- version number in the warning from 9.53 to 9.53.0 to match the actual<br>
- version and patch number of the release (the decision to add the patch<br>
- level was taken after the original commit)<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-27 09:35: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=bd6b59984ad713d2b1d48f3b81bf1e631bf9ee2b">bd6b59984ad713d2b1d48f3b81bf1e631bf9ee2b</a>
-<blockquote>
-<p>
- Update dates'n'docs for 9.53.0.RC2<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-24 18:55:30 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=197eb511b5d81a662f801333709199495abe61cf">197eb511b5d81a662f801333709199495abe61cf</a>
-<blockquote>
-<p>
- Fix Tesseract traineddata file loading.<br>
-<br>
- If it was finding any Tesseract data in ROM it was then not looking<br>
- for files.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-24 09:24: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=cb279d8a0e356542f6829ed429269ce07ec838a9">cb279d8a0e356542f6829ed429269ce07ec838a9</a>
-<blockquote>
-<p>
- Coverity 361429: move &quot;break&quot; to correct place.<br>
-<br>
- We had to add the outputfile to the &quot;control&quot; file permission list (as well<br>
- as write), but for the &quot;pipe&quot; case, I accidentally added the call after the<br>
- break out of loop that checks for a pipe.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-21 18:50: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=bad72741aad21b17a3965673f3e7949a2fc7c256">bad72741aad21b17a3965673f3e7949a2fc7c256</a>
-<blockquote>
-<p>
- PDF interp: Consolidate disabling of page handler device<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-21 11:13: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=60bbe61efc97c208f31c2d2d617753232ed1881d">60bbe61efc97c208f31c2d2d617753232ed1881d</a>
-<blockquote>
-<p>
- More version number fixes<br>
-<br>
- The code to retrieve the Ghostscript paths from the Windows Registry<br>
- was generating a key based on the version number, but since we added the<br>
- patch the generation was incorrect.<br>
-<br>
- Since this is the third (!) case of this, scan the code for any usage of<br>
- gs_version, gs_version_number, GS_VERSION, GS_VERSION_NUMBER,<br>
- gs_revision, gs_revision_number, GS_REVISION and GS_REVISION_NUMBER.<br>
-<br>
- This reveals two more places, neither serious but we might as well fix<br>
- them while we're here.<br>
-<br>
- Thanks to Akira Kakuto for finding this problem and suggesting a patch.<br>
- I chose to use the code we were already using in two other places, just<br>
- for consistency, but the supplied patch was equally good.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-21 08:14: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=45baf1a5b71c2ddad8e16ae2f895c4244e6af9e6">45baf1a5b71c2ddad8e16ae2f895c4244e6af9e6</a>
-<blockquote>
-<p>
- Fox typos and stuff in the release highlights<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-20 18:33:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=58ea17fd3032584e04f4e844e2d9991af87f114e">58ea17fd3032584e04f4e844e2d9991af87f114e</a>
-<blockquote>
-<p>
- Delete binary files from lcms2mt tree<br>
-<br>
- There were left over binary libraries, remove them.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-20 17:19: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=2ddd9d68bb0831ec8c9dd5e4e2e94bb44f8e5028">2ddd9d68bb0831ec8c9dd5e4e2e94bb44f8e5028</a>
-<blockquote>
-<p>
- Fix pdfwrite &quot;%d&quot; mode with file permissions<br>
-<br>
- Firstly, in gx_device_delete_output_file the iodev pointer was being passed<br>
- to the delete_method incorrectly (passing a pointer to that pointer). Thus<br>
- when we attempted to use that to confirm permission to delete the file, it<br>
- crashed. Credit to Ken for finding that.<br>
-<br>
- Secondly, due to the way pdfwrite works, when running with an output file per<br>
- page, it creates the current output file immediately it has completed writing<br>
- the previous one. Thus, it has to delete that partial file on exit.<br>
-<br>
- Previously, the output file was not added to the &quot;control&quot; permission list,<br>
- so an attempt to delete it would result in an error. So add the output file<br>
- to the &quot;control&quot; as well as &quot;write&quot; list.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-18 10:23: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=a12a526799a32c9fc17c7f6c5f37e21246e2d4e7">a12a526799a32c9fc17c7f6c5f37e21246e2d4e7</a>
-<blockquote>
-<p>
- Update docs, version, dates, product family<br>
-<br>
- for 9.53.0 RC1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-20 09:12: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=f797ac99d0b0a337b5a57c37cdd026f4a9dbf897">f797ac99d0b0a337b5a57c37cdd026f4a9dbf897</a>
-<blockquote>
-<p>
- Fix PDF /Producer for new patch level<br>
-<br>
- Bug #702772 &quot;Strange /Producer attribute&quot;<br>
-<br>
- The change to include a patch level for Ghostscript in the gs_revision<br>
- value wasn't being reflected in the code to generate the version<br>
- number used in the PDF /Producer string.<br>
-<br>
- Copied the code from printf_program_ident() in base/gsmisc.c to the<br>
- code in pdf_store_default_Producer() and commented both pieces of code<br>
- to note the existence of each other so that in future hopefully we won't<br>
- forget to keep them in sync.<br>
-<br>
- Thanks to Peter Cherepanov for spotting the flaw.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-18 23:23: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=ec82d2aa95dc8eb764483ff9011585bfc47a0f1b">ec82d2aa95dc8eb764483ff9011585bfc47a0f1b</a>
-<blockquote>
-<p>
- Fix Bug 702381: Hang due to cyclic PDF resources.<br>
-<br>
- The loop is caused by a circular /ParentResources attribute.<br>
- This branch of code is triggered by an error in the sample file:<br>
- misplaced /Form resources in a Type 3 font. This font has /Resource<br>
- dictionaries added to /CharProcs entries rather than the font dictionary.<br>
-<br>
- Note that this patch fixes the hang issue, but does not correct the<br>
- issue of not being able to find the correct resource (in the CharProc)<br>
- so that the file still output does not match Adobe (mupdf has that<br>
- same issue).<br>
-<br>
- Thanks to Peter Cherepanov for this patch.<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-17 15:44: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=a01320e4d57d984f5bf65126534dbb3c33b416a4">a01320e4d57d984f5bf65126534dbb3c33b416a4</a>
-<blockquote>
-<p>
- Bug 702744: Add windows utf-8 handling for unlink and rename.<br>
-<br>
- To do this, we introduce gp_unlink and gp_rename, and call those<br>
- as appropriate.<br>
-<br>
- Also, make gp_open_scratch_file add the file to the permit list.<br>
- When such a file is closed, it will be deleted from the permit list.<br>
-<br>
- It will also be removed from the permit list if the file is deleted<br>
- using the PS deletefile operator.<br>
-<br>
- On closedown, if scratch files haven't been deleted, then we'll<br>
- delete them as part of the closedown of gs_lib_ctx.<br>
-<br>
- This means that 'purging' the control lists must not remove scratch<br>
- file paths from the list.<br>
-<br>
- Also, ensure that gsapi callers can't maliciously (or accidentally)<br>
- remove scratch path paths from the list so as to leave them around<br>
- after closedown.<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-<h3><a name="9.53.3_changelog"></a>Changelog</h3>
-<p><strong>2020-09-28 12:54: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=1da1144e165aa1643a440e45f238c2301982bf79">1da1144e165aa1643a440e45f238c2301982bf79</a>
-<blockquote>
-<p>
- Docs/dates/version for 9.53.3<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/version.mak<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/Internal.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>2020-09-29 20:16: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=ae7767cd15946cd4058037acf965848a5bd5cb33">ae7767cd15946cd4058037acf965848a5bd5cb33</a>
-<blockquote>
-<p>
- Bug 702948: Ensure initial bitmap cache sizes are properly aligned<br>
-<br>
- Now that the allocations from the bitmap cache are aligned to the platform's<br>
- required alignment, see commit:<br>
-<br>
- 260c443bc14cdffa4d94e14c3a57e35bebee3a5b<br>
-<br>
- We also want the initial size of the memory pool used by the cache to be<br>
- &quot;aligned&quot;.<br>
-<br>
- This is so that code that attempts to identify cache entries to evict by<br>
- requesting a size equal to the entire size of cache memory pool don't get an<br>
- unexpected failure, because we've rounded up that allocation request to a value<br>
- larger than the entire size of the memory pool.<br>
-<br>
- Because we don't expect an error to be possible at that point, a crash can<br>
- occur.<br>
-<br>
- Of the &quot;normal&quot; platforms we use, this only exhibits on Win32 because that is<br>
- the only platform where the align_bitmap_mod we use is less than the<br>
- obj_align_mod used for the memory managers.<br>
-<br>
-base/gxccman.c<br>
-base/gxclist.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-28 20:10:16 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=27824a749775a233725cf3f302ce8156c478f7e1">27824a749775a233725cf3f302ce8156c478f7e1</a>
-<blockquote>
-<p>
- Fix icc profile reference counting in transparency compositor<br>
-<br>
- Found during Windows testing for a release.<br>
-<br>
- The full test file for<br>
- https://bugs.ghostscript.com/show_bug.cgi?id=693365<br>
-<br>
- would cause Ghostscript to crash due to an ICC profile being freed whilst a<br>
- reference was still being held for it. That was not counting up a reference<br>
- count when restoring the device profile back to a previous value.<br>
-<br>
- Fixing that introduced a leak for other profiles. And that turned out to be<br>
- not decrementing the reference count when replacing a device profile.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-28 10:21: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=d2fa2e186a6cdbdc011a44275532e2f1071111ec">d2fa2e186a6cdbdc011a44275532e2f1071111ec</a>
-<blockquote>
-<p>
- Work around for (I think) a VS2019 optimiser bug<br>
-<br>
- VS2019 release builds crash with the input file from bug 702916 and several<br>
- other files, in copied_glyph_slot() because the pointer retrieved and stored<br>
- in *pslot is non-sensical.<br>
-<br>
- Debug/Profile builds and optimised builds with earler VS versions don't show<br>
- the problem.<br>
-<br>
- Adding debug code to assign the calculated index to an interim unsigned integer<br>
- variable also cause the problem to go away.<br>
-<br>
- So, use that as a workaround.<br>
-<br>
-devices/gxfcopy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-28 10:20:26 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd36db788b73674e9a18803f451ed910ddd66dba">cd36db788b73674e9a18803f451ed910ddd66dba</a>
-<blockquote>
-<p>
- Fix some casting confusion for special glyph CID/index values<br>
-<br>
- And a whitespace/indentation issue.<br>
-<br>
- Noticed in passing....<br>
-<br>
-base/gsccode.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-25 13:03: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=787be772d87089ee8224b17ba50ac4adccc75ffe">787be772d87089ee8224b17ba50ac4adccc75ffe</a>
-<blockquote>
-<p>
- Fix Bug 702941 - Mispelled PDF interpreter variable name.<br>
-<br>
- s/RepiredAnError/RepairedAnError/ A simple typo that was missed because<br>
- we did not have a test file with a format error to trigger this code.<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-25 08:41:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6b2b35fbbc230be106190c3948b14553410c29e0">6b2b35fbbc230be106190c3948b14553410c29e0</a>
-<blockquote>
-<p>
- Version, doc and date updates for 9.53.2<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/version.mak<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/Internal.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>2020-09-25 12:40:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=167c75d35336fcfe7c94cf5fb0258406443cdc6b">167c75d35336fcfe7c94cf5fb0258406443cdc6b</a>
-<blockquote>
-<p>
- Bug 702938: Allocating cached glyphs, account for alignment<br>
-<br>
- For efficiency, the glyph cache allocates &quot;large&quot; blocks of memory into which<br>
- it parcels out offsets for individual glyph cache bitmaps, as required.<br>
-<br>
- Since cached glyphs are usually fairly small, and potentially can be short<br>
- lived, this saves the overheads of &quot;full&quot; memory for every cached glyph.<br>
-<br>
- Unfortunately, in calculating the offsets for the cached glyph, it was failing<br>
- to account for the required alignment of the system. In any environment that<br>
- strictly enforces aligned memory accesses, this will potentially cause a bus<br>
- error.<br>
-<br>
- In this case, it was switching the gs_glyph type to a 64 bit type that triggered<br>
- the issue. But any changed to the contents of the cached_char struct could have<br>
- resulted in it happening.<br>
-<br>
-base/gxbcache.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-24 17:10:21 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1c4631aa8910f6da923367984491fc2b883d7a0">b1c4631aa8910f6da923367984491fc2b883d7a0</a>
-<blockquote>
-<p>
- Remove dead end links from Readme.htm<br>
-<br>
-doc/Readme.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-23 20:20: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=334f24a4a8529f8476dfe74dd2b47f1274269263">334f24a4a8529f8476dfe74dd2b47f1274269263</a>
-<blockquote>
-<p>
- Bug 702920: Fix type confusion in new param type code.<br>
-<br>
- In a few cases we were using the wrong element in the union to read the<br>
- value back from the param list (and to range check the values).<br>
-<br>
-base/gsparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-15 08:51:08 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab2505e19cf36ffc780f6824a50c8e7eacf7af8f">ab2505e19cf36ffc780f6824a50c8e7eacf7af8f</a>
-<blockquote>
-<p>
- Fix problem with BGPrint and multi-threaded rendering caused by commit cca27988<br>
-<br>
- The unconditional call to enable multi-threaded rendering during set up of the<br>
- gx_device_printer as a clist caused the SEGV of bug 702181, but enabling<br>
- multi-threaded rendering here isn't correct since it is usually done when we<br>
- output the page (gdev_prn_output_page_aux). The problem is that BGPrint would<br>
- setup a new clist device to render the page, but needs to enable multi-threaded<br>
- rendering for the background clist device. Do this if NumRenderThreads &gt; 0.<br>
-<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-22 13:10:04 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a7d7b4f9ea347de35cbbec69a58c3a0a43fda447">a7d7b4f9ea347de35cbbec69a58c3a0a43fda447</a>
-<blockquote>
-<p>
- Fix gp_file allocations to use thread_safe_memory.<br>
-<br>
- The gpmisc.c does allocations for gp_file objects and buffers used by<br>
- gp_fprintf, as well as gp_validate_path_len. The helgrind run with<br>
- -dBGPrint -dNumRenderingThreads=4 and PCL input showed up the gp_fprintf<br>
- problem since the clist rendering would call gp_fprintf using the same<br>
- allocator (PCL's chunk allocator which is non_gc_memory). The chunk<br>
- allocator is intentionally not thread safe (for performance).<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-23 07:39:04 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a3f5d5ab9cc94ee433dafb5331519855f6671e6">7a3f5d5ab9cc94ee433dafb5331519855f6671e6</a>
-<blockquote>
-<p>
- Temporarily disable BGPrint for pcl, xps and gpdl.<br>
-<br>
- In order to safely allow for a 9.53.2 patch release that fixes BGPrint<br>
- with NumRenderingThreads while the issues with PCL and friends are<br>
- fixed, just ignore BGPrint in pcl/pl/plmain.c<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-16 07:48: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=7250256e29355b1ceccd06b3b937b7d0e739d1f7">7250256e29355b1ceccd06b3b937b7d0e739d1f7</a>
-<blockquote>
-<p>
- Bug 702904: Another fix to check for shared libjpeg/libtiff<br>
-<br>
- We cannot combine shared and not shared libjpeg and libtiff - they either both<br>
- need to be &quot;local&quot; or both shared, and configure checks that and fails when<br>
- the two are incompatible.<br>
-<br>
- However, that check would fail when either libjpeg or libtiff were not being<br>
- included at all. Since it is libtiff that is the &quot;problem&quot; for this<br>
- compatibility, now check if TIFF is included, and if not, skip the check.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-25 16:47:10 +0100
-</strong>
-<br>ChrisL &lt;cliddell@salvor-openbsd.lan&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1264b6debb1d48e2b9ea0eae8fda86c04f4def9d">1264b6debb1d48e2b9ea0eae8fda86c04f4def9d</a>
-<blockquote>
-<p>
- Fix the OpenBSD build<br>
-<br>
- Whilst hopefully not breaking the buildroot build.<br>
-<br>
-Makefile.in<br>
-base/freetype.mak<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-14 16:52:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6011a3d8096c51ae795b436f17b141cceba4d77b">6011a3d8096c51ae795b436f17b141cceba4d77b</a>
-<blockquote>
-<p>
- Bug 702901: initialize directory for tiff configure<br>
-<br>
- Previously the directory in which to run the libtiff configure script was<br>
- initialised to an empty string, but that, in some toolchains, resulted in an<br>
- error due to &quot;unsafe header/library path used in cross-compilation&quot;.<br>
-<br>
- So initialise it something benign instead.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-24 09:01: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=0712379d88c2697fef35e60107bf0201a5f1a790">0712379d88c2697fef35e60107bf0201a5f1a790</a>
-<blockquote>
-<p>
- Coverity ID 361427 fix uninitialised variable.<br>
-<br>
-base/gdevflp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-14 14:32: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=6d1440b2dabde655a2fe48ddbf0c09a82de4d423">6d1440b2dabde655a2fe48ddbf0c09a82de4d423</a>
-<blockquote>
-<p>
- Fix crashes with pdfwrite, TrueType input fonts and Windows 64-bit build<br>
-<br>
- With the change to 64-bits unconditionally for gs_glyph we can now<br>
- define GS_MIN_CID_GLYPH in 64-bit terms.<br>
-<br>
- Previously we were using the architecture size of a long_long to<br>
- determine which define to use, and we do not define long_long on Windows<br>
- leading to us using an essentially 32-bit definition. This caused<br>
- indexing off the end of an array in copied_glyph_slot()<br>
-<br>
-base/gsccode.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-14 09:40: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=e54e9c5eaebc0bf06e57f754a3c16278de412459">e54e9c5eaebc0bf06e57f754a3c16278de412459</a>
-<blockquote>
-<p>
- Bug 702897: Fix shared libtiff/libjpeg check<br>
-<br>
- For various reasons we cannot combine shared and not shared libjpeg and<br>
- libtiff - they either both need to be &quot;local&quot; or both shared.<br>
-<br>
- But the check for that compatibility was triggered during the recursive<br>
- configure call when setting up for cross compiling.<br>
-<br>
- Skip the check for that recursive configure call.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-10 22:47:09 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a5ace846c8af91d047e59c87722d0c36e79e5d3">9a5ace846c8af91d047e59c87722d0c36e79e5d3</a>
-<blockquote>
-<p>
- Bug 702884: Require jbig2dec 0.19 when building ghostscript.<br>
-<br>
- In practice this has been required since commit<br>
- 9b5008aa2bc1c6a6acb2c6f90d1ef8d6bad9e66a.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-10 22:41:20 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=53db58bd227c80375f00135045d36b66868732f4">53db58bd227c80375f00135045d36b66868732f4</a>
-<blockquote>
-<p>
- Update jbig2dec stuff for 0.19 release.<br>
-<br>
-jbig2dec/CHANGES<br>
-jbig2dec/jbig2.h<br>
-jbig2dec/jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-09-09 11:50: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=45884ca68488ac470b894702bdd8da232743d8e4">45884ca68488ac470b894702bdd8da232743d8e4</a>
-<blockquote>
-<p>
- Bug 702871: Fix GraphicsAlphaBits + Fill/Stroke issue.<br>
-<br>
- When we flush the alphabuffer, mapped_start and mapped_height are<br>
- both set to zero. When we refill it, mapped_height is set to<br>
- non-zero. USUALLY mapped_start is set to non-zero too, but it can<br>
- be set to zero when we are close to the bottom of the page.<br>
-<br>
- Hence we should test for mapped_height != 0, rather than both<br>
- mapped_height and mapped_start being non-zero.<br>
-<br>
- So the 'quick hack' that Chris used is actually correct.<br>
-<br>
-base/gdevabuf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-28 09:31:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ba6aa1d7253e8ecd7cd796c95306f1203f70879">4ba6aa1d7253e8ecd7cd796c95306f1203f70879</a>
-<blockquote>
-<p>
- Bug 702837 typo in warning message<br>
-<br>
- Thanks to Herbert Voss for spotting this. Fixed the typo and updated the<br>
- version number in the warning from 9.53 to 9.53.0 to match the actual<br>
- version and patch number of the release (the decision to add the patch<br>
- level was taken after the original commit)<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-24 18:55:30 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=197eb511b5d81a662f801333709199495abe61cf">197eb511b5d81a662f801333709199495abe61cf</a>
-<blockquote>
-<p>
- Fix Tesseract traineddata file loading.<br>
-<br>
- If it was finding any Tesseract data in ROM it was then not looking<br>
- for files.<br>
-<br>
-base/tessocr.cpp<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-24 09:24: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=cb279d8a0e356542f6829ed429269ce07ec838a9">cb279d8a0e356542f6829ed429269ce07ec838a9</a>
-<blockquote>
-<p>
- Coverity 361429: move &quot;break&quot; to correct place.<br>
-<br>
- We had to add the outputfile to the &quot;control&quot; file permission list (as well<br>
- as write), but for the &quot;pipe&quot; case, I accidentally added the call after the<br>
- break out of loop that checks for a pipe.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-21 18:50: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=bad72741aad21b17a3965673f3e7949a2fc7c256">bad72741aad21b17a3965673f3e7949a2fc7c256</a>
-<blockquote>
-<p>
- PDF interp: Consolidate disabling of page handler device<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-21 11:13: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=60bbe61efc97c208f31c2d2d617753232ed1881d">60bbe61efc97c208f31c2d2d617753232ed1881d</a>
-<blockquote>
-<p>
- More version number fixes<br>
-<br>
- The code to retrieve the Ghostscript paths from the Windows Registry<br>
- was generating a key based on the version number, but since we added the<br>
- patch the generation was incorrect.<br>
-<br>
- Since this is the third (!) case of this, scan the code for any usage of<br>
- gs_version, gs_version_number, GS_VERSION, GS_VERSION_NUMBER,<br>
- gs_revision, gs_revision_number, GS_REVISION and GS_REVISION_NUMBER.<br>
-<br>
- This reveals two more places, neither serious but we might as well fix<br>
- them while we're here.<br>
-<br>
- Thanks to Akira Kakuto for finding this problem and suggesting a patch.<br>
- I chose to use the code we were already using in two other places, just<br>
- for consistency, but the supplied patch was equally good.<br>
-<br>
-base/gp_wgetv.c<br>
-devices/gdevpdfimg.c<br>
-devices/gdevpng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-21 08:14: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=45baf1a5b71c2ddad8e16ae2f895c4244e6af9e6">45baf1a5b71c2ddad8e16ae2f895c4244e6af9e6</a>
-<blockquote>
-<p>
- Fox typos and stuff in the release highlights<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-20 18:33:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=58ea17fd3032584e04f4e844e2d9991af87f114e">58ea17fd3032584e04f4e844e2d9991af87f114e</a>
-<blockquote>
-<p>
- Delete binary files from lcms2mt tree<br>
-<br>
- There were left over binary libraries, remove them.<br>
-<br>
-lcms2mt/Lib/MS/lcms2_fast_float_plugin.lib<br>
-lcms2mt/Lib/MS/lcms2_static.lib<br>
-lcms2mt/Lib/MS/lcms2mt_fast_float_plugin.lib<br>
-lcms2mt/Lib/MS/lcms2mt_static.lib<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-20 17:19: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=2ddd9d68bb0831ec8c9dd5e4e2e94bb44f8e5028">2ddd9d68bb0831ec8c9dd5e4e2e94bb44f8e5028</a>
-<blockquote>
-<p>
- Fix pdfwrite &quot;%d&quot; mode with file permissions<br>
-<br>
- Firstly, in gx_device_delete_output_file the iodev pointer was being passed<br>
- to the delete_method incorrectly (passing a pointer to that pointer). Thus<br>
- when we attempted to use that to confirm permission to delete the file, it<br>
- crashed. Credit to Ken for finding that.<br>
-<br>
- Secondly, due to the way pdfwrite works, when running with an output file per<br>
- page, it creates the current output file immediately it has completed writing<br>
- the previous one. Thus, it has to delete that partial file on exit.<br>
-<br>
- Previously, the output file was not added to the &quot;control&quot; permission list,<br>
- so an attempt to delete it would result in an error. So add the output file<br>
- to the &quot;control&quot; as well as &quot;write&quot; list.<br>
-<br>
-base/gsdevice.c<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-18 10:23: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=dee56822c0c9989fdf0115dab79842ad116c14f3">dee56822c0c9989fdf0115dab79842ad116c14f3</a>
-<blockquote>
-<p>
- Update version, dates, product family<br>
-<br>
- for 9.53.0 RC1<br>
-<br>
-base/gscdefs.h<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/Internal.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>2020-08-20 09:12: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=f797ac99d0b0a337b5a57c37cdd026f4a9dbf897">f797ac99d0b0a337b5a57c37cdd026f4a9dbf897</a>
-<blockquote>
-<p>
- Fix PDF /Producer for new patch level<br>
-<br>
- Bug #702772 &quot;Strange /Producer attribute&quot;<br>
-<br>
- The change to include a patch level for Ghostscript in the gs_revision<br>
- value wasn't being reflected in the code to generate the version<br>
- number used in the PDF /Producer string.<br>
-<br>
- Copied the code from printf_program_ident() in base/gsmisc.c to the<br>
- code in pdf_store_default_Producer() and commented both pieces of code<br>
- to note the existence of each other so that in future hopefully we won't<br>
- forget to keep them in sync.<br>
-<br>
- Thanks to Peter Cherepanov for spotting the flaw.<br>
-<br>
-base/gsmisc.c<br>
-devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-18 23:23: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=ec82d2aa95dc8eb764483ff9011585bfc47a0f1b">ec82d2aa95dc8eb764483ff9011585bfc47a0f1b</a>
-<blockquote>
-<p>
- Fix Bug 702381: Hang due to cyclic PDF resources.<br>
-<br>
- The loop is caused by a circular /ParentResources attribute.<br>
- This branch of code is triggered by an error in the sample file:<br>
- misplaced /Form resources in a Type 3 font. This font has /Resource<br>
- dictionaries added to /CharProcs entries rather than the font dictionary.<br>
-<br>
- Note that this patch fixes the hang issue, but does not correct the<br>
- issue of not being able to find the correct resource (in the CharProc)<br>
- so that the file still output does not match Adobe (mupdf has that<br>
- same issue).<br>
-<br>
- Thanks to Peter Cherepanov for this patch.<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-17 15:44: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=a01320e4d57d984f5bf65126534dbb3c33b416a4">a01320e4d57d984f5bf65126534dbb3c33b416a4</a>
-<blockquote>
-<p>
- Bug 702744: Add windows utf-8 handling for unlink and rename.<br>
-<br>
- To do this, we introduce gp_unlink and gp_rename, and call those<br>
- as appropriate.<br>
-<br>
- Also, make gp_open_scratch_file add the file to the permit list.<br>
- When such a file is closed, it will be deleted from the permit list.<br>
-<br>
- It will also be removed from the permit list if the file is deleted<br>
- using the PS deletefile operator.<br>
-<br>
- On closedown, if scratch files haven't been deleted, then we'll<br>
- delete them as part of the closedown of gs_lib_ctx.<br>
-<br>
- This means that 'purging' the control lists must not remove scratch<br>
- file paths from the list.<br>
-<br>
- Also, ensure that gsapi callers can't maliciously (or accidentally)<br>
- remove scratch path paths from the list so as to leave them around<br>
- after closedown.<br>
-<br>
-base/gp.h<br>
-base/gp_mswin.c<br>
-base/gp_os2.c<br>
-base/gp_os2fs.c<br>
-base/gp_os2pr.c<br>
-base/gp_unifs.c<br>
-base/gp_vms.c<br>
-base/gp_winfs.c<br>
-base/gpmisc.c<br>
-base/gsiodev.c<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-base/mkromfs.c<br>
-base/winlib.mak<br>
-pcl/pl/pjparse.c<br>
-psi/imain.c<br>
-psi/zfile.c<br>
-xps/xpsjxr.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-11 14:41: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=0e98e2a27ed19fcc138215afe17ab1a173aeed7b">0e98e2a27ed19fcc138215afe17ab1a173aeed7b</a>
-<blockquote>
-<p>
- Add patch version to version number<br>
-<br>
- This makes it easier to issue patch releases for security problems.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/gsmisc.c<br>
-base/version.mak<br>
-devices/gdevtifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-17 13:14: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=7cfa8d364797aed267285124a32b5cc5e1cd4794">7cfa8d364797aed267285124a32b5cc5e1cd4794</a>
-<blockquote>
-<p>
- Bug 702360: Allow @loader_path on darwin so build<br>
-<br>
- As this is change in behaviour, it's optional. The configure script now<br>
- uses (if set) a environment variable called &quot;DARWIN_LDFLAGS_SO_PREFIX&quot; -<br>
- included &quot;DARWIN&quot; because it only applies to DARWIN derived systems.<br>
-<br>
- This allows the caller to use:<br>
- ./configure DARWIN_LDFLAGS_SO_PREFIX=&quot;@loader_path/&quot;<br>
-<br>
- Thus meaning the build will use loader_path rather than &quot;@executable_path&quot;.<br>
-<br>
- Configuring/building without that environment variable will retain the current<br>
- behaviour.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-15 11:10: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=ffbd883cd13883ace8fb424a8a7c447084ea5fac">ffbd883cd13883ace8fb424a8a7c447084ea5fac</a>
-<blockquote>
-<p>
- Enhance First/LastPage processing<br>
-<br>
- Previously the FirstPage and LastPage processing device did not allow<br>
- any means to reset the PageCount. This was because Ghostscript's<br>
- command line processing does not permit changing non-PostScript<br>
- controls (interpreter and some device parameters) after the first file<br>
- has been run.<br>
-<br>
- GPDL however, has a new mechanism 'set_param' which can be used<br>
- programmatically, and that does permit for device and interpreter<br>
- parameters to be altered after the initial file has been processed.<br>
-<br>
- To allow for this the gdevflp device now processes parameters itself<br>
- instead of relying on the underlying device to do so. The parameters<br>
- FirstPage, LastPage, PageList and DisablePageHandler now all reset the<br>
- page count to 0 when they are encountered. This means that, using gpdl,<br>
- it is possible to select a set of pages from one file, then select a<br>
- different set of pages from a second file. Sending any of these<br>
- parameters (except, obviously DisablePageHandler) also now automatically<br>
- enables the device again ie it sets DisablePageHandler to false.<br>
-<br>
- It is not, unfortunately, possible to load the gdevflp device at any<br>
- time except when the underlying device is initially opened. This means<br>
- that if any file is to be processed using gdevflp the first file must<br>
- use one of the parameters, in order to load gdevflp. The simplest<br>
- solution is simply to set -dFirstPage=1 which will load the device and<br>
- run all the pages from the file.<br>
-<br>
- This commit also includes a minor change to the PDF interpreter. Because<br>
- the PDF interpreter (currently) handles subsets of pages itself, it<br>
- does not want the first/last page device to be active, so it<br>
- disables the device by sending a 'DisablePageHandler' to it. However<br>
- (because of the GS command line, as described in the first paragraph) it<br>
- did not bother to re-enable the device. So here we add a line to<br>
- re-enable the device after processing is complete.<br>
-<br>
- This is probably superfluous now that sending the params will re-enable<br>
- the gdevflp device anyway, but it should make the intention plain.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-base/gdevflp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-14 10:47:04 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=604646154201c1ecd7000a04fd33778d95b6aeac">604646154201c1ecd7000a04fd33778d95b6aeac</a>
-<blockquote>
-<p>
- Bug 702725 Maintain spot colors when overprint mismatch in process CS<br>
-<br>
- If the process color space does not match the source color space (for example<br>
- drawing an RGB image to a CMYK device) and overprint is true, then we should<br>
- still retain the spot colorants assuming the device supports them.<br>
-<br>
-base/gscspace.c<br>
-base/gscspace.h<br>
-base/gsicc.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-14 12:40:37 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a02c4496e0c41f5db492e3e549ad06254676dd0e">a02c4496e0c41f5db492e3e549ad06254676dd0e</a>
-<blockquote>
-<p>
- demos/python/gsapi.py: match new handling of bool by gsapi_set_param().<br>
-<br>
-demos/python/gsapi.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-14 16:32: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=99c90d8d20d4be6113016154119dc102c18c986b">99c90d8d20d4be6113016154119dc102c18c986b</a>
-<blockquote>
-<p>
- Update api_test.<br>
-<br>
- Fix proper expectation of return codes when setting params.<br>
-<br>
- Fix alignment of memory buffers for display buffer test. md5sums<br>
- of generated files now match properly.<br>
-<br>
-demos/c/api_test.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-14 16:30:37 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=067b1ee4b45ee31d251bb796b30079866465ce42">067b1ee4b45ee31d251bb796b30079866465ce42</a>
-<blockquote>
-<p>
- Fix stray error during param to string conversions.<br>
-<br>
-base/gsparaml.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-14 13:14:26 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8eaac9486822db53d3a903ec8638dd83f6677782">8eaac9486822db53d3a903ec8638dd83f6677782</a>
-<blockquote>
-<p>
- Add a couple of files missing from VS Solution.<br>
-<br>
-windows/ghostscript.vcxproj<br>
-windows/ghostscript.vcxproj.filters<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-14 13:05:14 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=043a9629cfc27d743b5125584753fd15e462d772">043a9629cfc27d743b5125584753fd15e462d772</a>
-<blockquote>
-<p>
- Update gsapi_set_params to use an &quot;int *&quot; for booleans.<br>
-<br>
-doc/API.htm<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-14 11:10: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=d7e8ea24060997ea5f4be1808b45117fe59b9ead">d7e8ea24060997ea5f4be1808b45117fe59b9ead</a>
-<blockquote>
-<p>
- Bug 702611: Fix tiff_from_filep to handle subclassing<br>
-<br>
- tiff_from_filep() creates a tiffio structure, which contains a pointer to the<br>
- tiff device. If the device has been subclassed, however, that is the transient<br>
- copy of the tiff device, and not the memory used by the &quot;real&quot; device, as<br>
- pointed to by the graphics state.<br>
-<br>
- Since we only use the device to get to the gs_memory_t pointer, just store that<br>
- instead.<br>
-<br>
-base/gstiffio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-13 11:15:01 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ae3d32942f4f976e89faff65c4e2fbcf4c6d5068">ae3d32942f4f976e89faff65c4e2fbcf4c6d5068</a>
-<blockquote>
-<p>
- Fix memory leak associated with pdfwrite, type3x images<br>
-<br>
- This leak is only an issue for non-GC interpreters such as pdfi<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-13 10:38: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=3f2408d5ac786ac1c0a837b600f4ef3be9be0332">3f2408d5ac786ac1c0a837b600f4ef3be9be0332</a>
-<blockquote>
-<p>
- graphics library- clean up streams used as DataSource for functions<br>
-<br>
- The graphics library doesn't close streams which are supplied as<br>
- the DataSource for type 0 functions, leading to a memory leak in pdfi<br>
- because we create memory streams (and hence allocate buffers) for this<br>
- kind of input.<br>
-<br>
- Add code to close the stream (if present) when the type 0 function is<br>
- freed. There may be future work required here and in other function<br>
- types.<br>
-<br>
-base/gsfunc0.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-12 15:15:25 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0694e6e708ccab305524b64692403308f62f2652">0694e6e708ccab305524b64692403308f62f2652</a>
-<blockquote>
-<p>
- More API.htm fixes<br>
-<br>
- Found by Ethan Vrhel.<br>
-<br>
-doc/API.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-11 13:53: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=5066e260483660b8c13caab141fd34f5844298c7">5066e260483660b8c13caab141fd34f5844298c7</a>
-<blockquote>
-<p>
- Improve client memory handling for colour spaces and patterns<br>
-<br>
- Colour spaces have had a client_data member for some time (only used<br>
- with Pantone colour replacement) but no means to signal to the client<br>
- that a colour space was going to be freed.<br>
-<br>
- In addition, its terribly hard for an interpreter which uses complex<br>
- colour spaces (such as Separation and DeviceN, for Patterns see below)<br>
- to reliably track when a colour space is freed.<br>
-<br>
- This commit adds a new 'interpreter_data' pointer to hold data allocated<br>
- by the interpreter which is associated with a colour space. We also add<br>
- an 'interpreter_free_cspace_proc' to be called when a colour space is<br>
- about to be freed. This gives the interpreter an opportunity to clean<br>
- up the memory it has associated with the colour space.<br>
-<br>
- Similarly pattern instances (as opposed to Pattern colour spaces) have<br>
- long had a client_data member, which was previously stored in the<br>
- 'template' (which is a terrible misnomer) for both type 1 and type 2<br>
- patterns. However there was no procedure to notify the client when the<br>
- pattern was freed! The PCL interpreter (which was the only one using<br>
- this type of pattern) dealt with this by replacing the 'free' routine<br>
- in the structure with its own routine which first freed the client data<br>
- and then called the original free routine. This seems like a hack.<br>
-<br>
- This commit moves the client_data out of the pattern instance and into<br>
- the pattern structure proper. It also adds a 'notfy_free' member which<br>
- holds a pointer to a function to be called when a pattern is freed. This<br>
- gives the client a reliable opportunity to clean up the client_data.<br>
-<br>
- These changes involve updating the PostScript, PCL and XPS interpreters<br>
- to point to the new location of the client_data, as well as similar<br>
- changes in the graphics library. pixmap patterns now use the notify_free<br>
- functio0n instead of patching over the structure's free routine.<br>
-<br>
-base/gscspace.c<br>
-base/gscspace.h<br>
-base/gspcolor.c<br>
-base/gspcolor.h<br>
-base/gsptype1.c<br>
-base/gsptype1.h<br>
-pcl/pxl/pxink.c<br>
-psi/zpcolor.c<br>
-psi/zshade.c<br>
-xps/xpstile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-12 10:46:32 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e0529567af14fbbbd397b79ad9579d97799abfa5">e0529567af14fbbbd397b79ad9579d97799abfa5</a>
-<blockquote>
-<p>
- Update Makefiles for new MSVC version.<br>
-<br>
-base/msvclib.mak<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-11 16:09: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=2228dad8c8649a120fd68d707824be1a06c87ee8">2228dad8c8649a120fd68d707824be1a06c87ee8</a>
-<blockquote>
-<p>
- Fix missing bits and errors in API.htm<br>
-<br>
-doc/API.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-08 10:02:18 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e52f3fccbbb81a4cc0e26837dea4359bda774d3c">e52f3fccbbb81a4cc0e26837dea4359bda774d3c</a>
-<blockquote>
-<p>
- Fix Bug 702472: Array contents scrambled with writeobject/printobject<br>
-<br>
- Thanks to Peter Cherepanov for this patch.<br>
-<br>
- The mix-up of the nested arrays was caused by depth-first traversal of<br>
- the array tree and assignment of offsets to subsidiary arrays that assumed<br>
- width-first traversal. Switching to width-first traversal in all cases is<br>
- the easiest way to fix the problem.<br>
-<br>
- Additionally, access to the list of arrays is now implemented with the<br>
- -index- operator that has constant complexity, rather than with -roll-<br>
- that has linear complexity. So the whole process now has linear complexity<br>
- rather than quadratic.<br>
-<br>
- The total number of arrays in the exported object is arbitrarily limited to<br>
- 64K. This prevents memory exhaustion when exported object has circular<br>
- references, but should not hinder real world usage, if any.<br>
-<br>
- Following the original implementation, equal names are not merged and<br>
- exported separately.<br>
-<br>
- NOTE:<br>
- A Ghostscript extension, support of dictionaries in binary object sequence<br>
- has been removed. Following the recent trend of cleaning up non-standard<br>
- features.<br>
-<br>
- Dictionary support is not yet removed from the C part. Contrary to PLRM,<br>
- Adobe can parse binary object sequences with a non-zero tag in the top<br>
- object. This feature is not yet added. Sequences that contain zero<br>
- length names can be exported but cannot be imported due a conflict with<br>
- accessing the user name index. This is a design flaw in PostScript.<br>
-<br>
-Resource/Init/gs_btokn.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-10 13:51:43 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9ff6690610a44be40b938ac948d2d0e96852fac2">9ff6690610a44be40b938ac948d2d0e96852fac2</a>
-<blockquote>
-<p>
- demos/python/gsapi.py: added support for gsapi_get_param() and gsapi_enumerate_params().<br>
-<br>
- Also:<br>
- Wrote some very crude tests of new fns.<br>
- Extended gsapi_set_param() to take optional &lt;type_&gt; arg.<br>
- Fixed error in handling of word size on 64-bit Windows.<br>
-<br>
-demos/python/gsapi.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-11 16:13: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=fbe65ad97b583611ad854941927aa4b5a6642c55">fbe65ad97b583611ad854941927aa4b5a6642c55</a>
-<blockquote>
-<p>
- Swap order of arguments in gsapi_set_param/gsapi_get_param.<br>
-<br>
- This should play nicer with python.<br>
-<br>
-demos/c/api_test.c<br>
-doc/API.htm<br>
-doc/GPDL.htm<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-10 18:29: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=4a98669de4caf9ac9598ba28633979c78f31d884">4a98669de4caf9ac9598ba28633979c78f31d884</a>
-<blockquote>
-<p>
- Fix gsapi_get_param behaviour on 'not found'.<br>
-<br>
- Now we return gs_error_undefined if a value is not found.<br>
-<br>
-doc/API.htm<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plmain.c<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-07 18:07:08 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=826f4411a7e879f0891728c0d38c82c516ae34d7">826f4411a7e879f0891728c0d38c82c516ae34d7</a>
-<blockquote>
-<p>
- Bug 702607: Fix (and IMPROVE the maintainability of) EPSFitPage<br>
-<br>
- Thanks to Peter Cherepanov for this excellent PostScript code to perform<br>
- the scale and rotate FitPage. It is well designed and well documented and<br>
- much more understandable than the previous.<br>
-<br>
-Resource/Init/gs_epsf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-07 18:29:16 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=18caff3cdf2158e7642ded330bbaf14469863c7e">18caff3cdf2158e7642ded330bbaf14469863c7e</a>
-<blockquote>
-<p>
- Update .def files with new gsapi functions.<br>
-<br>
-psi/gsdll2.def<br>
-psi/gsdll32.def<br>
-psi/gsdll32metro.def<br>
-psi/gsdll64.def<br>
-psi/gsdll64metro.def<br>
-psi/gsdllARM32metro.def<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-04 19:45:27 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f5692b9c78f0a9fb92c2019d509b80e08a19636">4f5692b9c78f0a9fb92c2019d509b80e08a19636</a>
-<blockquote>
-<p>
- Update api_test: test enumeration of parameters.<br>
-<br>
-demos/c/api_test.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-07 18:01:37 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e66ab52ed2d65ad6989e73b8c6c797faced8343a">e66ab52ed2d65ad6989e73b8c6c797faced8343a</a>
-<blockquote>
-<p>
- Improve gs_param to string functions.<br>
-<br>
- size_t's and int64_t's were being displayed wrong due to a typo<br>
- in my use of the PRI macros.<br>
-<br>
- Allow strings to be returned as human readable strings rather than<br>
- hexstrings.<br>
-<br>
-base/gsparaml.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-07 15:18: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=c5b0d528b9e3cbbeadeaba4e7f2e6958cc2a99a6">c5b0d528b9e3cbbeadeaba4e7f2e6958cc2a99a6</a>
-<blockquote>
-<p>
- Add gsapi_enumerate_params functions.<br>
-<br>
-doc/API.htm<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-psi/iminst.h<br>
-psi/psapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-08 09:32: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=0c2e9b65fbc6a7b813fbf96e59d01bd8ffc776e4">0c2e9b65fbc6a7b813fbf96e59d01bd8ffc776e4</a>
-<blockquote>
-<p>
- Coverity 361226: Add missing break.<br>
-<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-07 18:00:58 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d65d008f20c1cefb27f9ee2f40bcde268050cd6e">d65d008f20c1cefb27f9ee2f40bcde268050cd6e</a>
-<blockquote>
-<p>
- Fix typo in default param handling.<br>
-<br>
- PageList should be a string, not a name.<br>
-<br>
-base/gsdparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-06 07:44:07 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=249da10b83dd8ed287877e6d21fa3ca3658aadea">249da10b83dd8ed287877e6d21fa3ca3658aadea</a>
-<blockquote>
-<p>
- Add gstate param to client callback<br>
-<br>
- This is needed for the pdfi interpreter.<br>
-<br>
-base/gsstate.c<br>
-base/gxstate.h<br>
-pcl/pcl/pctop.c<br>
-pcl/pxl/pxgstate.c<br>
-psi/zgstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-04 19:45:27 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=419fe20af3bdf203f980f41bd92189c7a76b32ba">419fe20af3bdf203f980f41bd92189c7a76b32ba</a>
-<blockquote>
-<p>
- Update api_test.<br>
-<br>
- Test param getting, and resolution changing.<br>
-<br>
-demos/c/api_test.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-06 15:23:50 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d01489255d8b5e1733ac1d664cbc1fbf206319e9">d01489255d8b5e1733ac1d664cbc1fbf206319e9</a>
-<blockquote>
-<p>
- Fix bug in param array coercion.<br>
-<br>
- If we're going to autoconvert an int array to a float array,<br>
- make sure we label the final array as being floats, otherwise<br>
- we run the risk of converting it again!<br>
-<br>
-base/gscparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-06 13:30:45 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=afac1313514a34b47bd7f3f441c6ec0ef169fccc">afac1313514a34b47bd7f3f441c6ec0ef169fccc</a>
-<blockquote>
-<p>
- Tidy printing of floating point numbers in get_params.<br>
-<br>
-base/gsparaml.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-06 13:30: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=afbecca968cf0701da25cc7ec8ceba9075aad0f8">afbecca968cf0701da25cc7ec8ceba9075aad0f8</a>
-<blockquote>
-<p>
- Parse #xx in param names correctly (for gsapi_set_param).<br>
-<br>
-base/gsparaml.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-06 12:02: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=783049405b39fb48f84d4ddee478e4ea10631c3d">783049405b39fb48f84d4ddee478e4ea10631c3d</a>
-<blockquote>
-<p>
- Support arrays of names in the param passing code.<br>
-<br>
-base/gsparaml.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-05 18:48: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=d1d44a90cf94338fec8ccf73338767ddb07a2254">d1d44a90cf94338fec8ccf73338767ddb07a2254</a>
-<blockquote>
-<p>
- Update docs for set_param/get_param and -p.<br>
-<br>
-doc/API.htm<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-05 16:16:39 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34703d722359c7547c532a3e24d2cd81c3f332f5">34703d722359c7547c532a3e24d2cd81c3f332f5</a>
-<blockquote>
-<p>
- Trigger an initgraphics on every usage of -p within gs.<br>
-<br>
- This enables us to set the resolution and have it reflected.<br>
-<br>
-psi/iapi.c<br>
-psi/imainarg.c<br>
-psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-05 13:44:51 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=932dc770a270ff7c70e899f953df9e9c72620d47">932dc770a270ff7c70e899f953df9e9c72620d47</a>
-<blockquote>
-<p>
- Update gpdl to accept -d/-s/-p after filenames.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-05 13:18:00 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d94506a1a9442bd3cc51b94eb5f6a16a12588f2">4d94506a1a9442bd3cc51b94eb5f6a16a12588f2</a>
-<blockquote>
-<p>
- Add -pNAME=STRING options to gs and gpdl to accept parsed params.<br>
-<br>
- This means we no longer need to rely on using -c and passing<br>
- postscript fragments to configure (for example) pdfwrite.<br>
-<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-04 19:44: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=fe0c022fbc1906a48b5a03704d9337751b26be8a">fe0c022fbc1906a48b5a03704d9337751b26be8a</a>
-<blockquote>
-<p>
- Add gsapi_get_param<br>
-<br>
-base/gsparam.h<br>
-base/gsparam2.c<br>
-base/gsparaml.c<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-psi/psapi.c<br>
-psi/psapi.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-05 16:52: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=3a8f4eca0284294c05a471a99263d22032db84b6">3a8f4eca0284294c05a471a99263d22032db84b6</a>
-<blockquote>
-<p>
- Bug 702606: Fix downsampler failing to initialise with pdfwrite.<br>
-<br>
- Some of the params were being left unset. My mistake when I added<br>
- them.<br>
-<br>
-devices/vector/gdevpsdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-03 12:53: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=c935b86d261d91ee04b5bf5f95028473d4af3735">c935b86d261d91ee04b5bf5f95028473d4af3735</a>
-<blockquote>
-<p>
- Fix infinite loop in ialloc_validate_memory tracing the freelist.<br>
-<br>
- Found in a DEBUG build running the file from Bug 702586 using:<br>
- -sDEVICE=ppmraw -o x.ppm Bug702586.pdf<br>
- Hangs after printing the error message:<br>
- GPL Ghostscript GIT PRERELEASE 9.53: Unrecoverable error, exit code 1<br>
-<br>
- Fixed by adding a check for self-reference and break out of the loop.<br>
-<br>
- At some point, someone may want to look at how we get this freelist<br>
- problem.<br>
-<br>
-psi/ilocate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-04 12:32:20 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ae588a57abccc598d74cb664c117ef339a42c1ba">ae588a57abccc598d74cb664c117ef339a42c1ba</a>
-<blockquote>
-<p>
- Coverity 361222: Add missing break.<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-03 13:57:39 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=341da1a6c41d71344f7ea32505f9ce82c1177e99">341da1a6c41d71344f7ea32505f9ce82c1177e99</a>
-<blockquote>
-<p>
- Avoid gsapi_set_param within a gsapi_runstring.<br>
-<br>
- Also, avoid gsapi_run_file within a gsapi_runstring.<br>
-<br>
-pcl/pl/plmain.c<br>
-psi/iminst.h<br>
-psi/psapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-08-03 13:17:30 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1337dc425e1d032c0eeef26d530b096930432f4">d1337dc425e1d032c0eeef26d530b096930432f4</a>
-<blockquote>
-<p>
- Update header dependencies<br>
-<br>
-base/lib.mak<br>
-base/tiff.mak<br>
-devices/dcontrib.mak<br>
-devices/devs.mak<br>
-devices/gdevpdfimg.h<br>
-psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-30 19:16:13 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bf6884134c244c4766d13c76264fa4372eab4056">bf6884134c244c4766d13c76264fa4372eab4056</a>
-<blockquote>
-<p>
- gsapi_set_param improvements.<br>
-<br>
- Allow for a 'parsed' param type; this leverages the functions in<br>
- gsparaml.c to parse an input string into a param list, coping<br>
- with dictionaries and arrays.<br>
-<br>
- We update those functions to improve behaviour on more exotically<br>
- formed numbers (&quot;- 0.3e-10&quot; etc), on 'tricksy' inputs (e.g.<br>
- &quot;&lt;&lt; /Foo (&gt;&gt;) &gt;&gt;&quot; etc) and to cope without relying on whitespace<br>
- (e.g. &quot;&lt;&lt;/Foo/Bar/Baz[1 0]/Fizz&lt;1234&gt;/Bang(A)&gt;&gt;&quot; etc).<br>
-<br>
- Update pl_implementation set_param entrypoint so that the language<br>
- interface itself is based upon param lists, rather than typed<br>
- params.<br>
-<br>
- Update both implementations of gsapi_set_params so that if<br>
- we are too early in the setup process stuff goes into the list<br>
- and is held until we have devices/languages to pass it to. Also<br>
- add a flag to allow for 'more to come' so that we can effectively<br>
- set multiple params at once.<br>
-<br>
-base/gsparam.h<br>
-base/gsparaml.c<br>
-demos/c/api_test.c<br>
-demos/c/api_test.vcxproj<br>
-gpdl/psitop.c<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pl/pltop.c<br>
-pcl/pl/pltop.h<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-psi/imain.c<br>
-psi/imain.h<br>
-psi/iminst.h<br>
-psi/psapi.c<br>
-psi/psapi.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-31 10:13:27 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49a4fede913a12a61fd6649898cf5999030f4b69">49a4fede913a12a61fd6649898cf5999030f4b69</a>
-<blockquote>
-<p>
- Fix Bug 702598: Ghostscript will not open SECURED PDF that Adobe opens.<br>
-<br>
- It's not really clear that this is a valid PDF since it does not conform to<br>
- one comment in the spec related to AuthEvent with StmF and StrF /Identity,<br>
- but since Adobe opens this we now open PDF's with AuthEvent specified as<br>
- something other than /DocOpen and BOTH StrF and StmF /Identity. We look<br>
- in the /CF &quot;StdCF&quot; dictionary for the AuthEvent. As per the spec., if<br>
- AuthEvent is not present, assume DocOpen, and if StmF or StrF are not<br>
- present, we default to /Identity.<br>
-<br>
- Thanks to Ken Sharp for the initial work on this.<br>
-<br>
-Resource/Init/pdf_sec.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-30 14:23:23 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e3c4d64fe28ffc1361995de034beaeb2a9a7b206">e3c4d64fe28ffc1361995de034beaeb2a9a7b206</a>
-<blockquote>
-<p>
- Fix warning message re: gs_smoothness<br>
-<br>
-base/gsstate.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-30 14:22:09 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=28452533cab466bef9437ee393140695dabc5f9c">28452533cab466bef9437ee393140695dabc5f9c</a>
-<blockquote>
-<p>
- Fix memory leak with non-GC overprint device<br>
-<br>
- This memory leak only matters in non-GC (reference-counted) interpreters<br>
- such as pdfi.<br>
-<br>
- There was an extra reference count after creating and then setting the<br>
- overprint device. This change decrements the rc so that it will be 1<br>
- when exiting this function, allowing it to be properly freed later.<br>
-<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-30 16:18:44 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a1441168f346cefd28e6336f6fbb3b310540dbff">a1441168f346cefd28e6336f6fbb3b310540dbff</a>
-<blockquote>
-<p>
- Changed gsapi.py to raise exceptions instead of returning error number<br>
-<br>
- gsapi.py:<br>
- Generate exceptions instead of returning error codes.<br>
- Added python versions of gs_error_* codes.<br>
-<br>
- examples.py:<br>
- Updated to match new API.<br>
- Re-raise import error if 'import gsapi' fails.<br>
- Patched up calls of run_gpdl() to pass in_filename because passing None<br>
- caused underlying C to return an error.<br>
- Marked as executable.<br>
- Look for input files relative to top of ghospdl checkout (found using<br>
- __file__).<br>
-<br>
-demos/python/examples.py<br>
-demos/python/gsapi.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-29 17:27:31 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=868200752e41adacc9d027092eba7be2db572b00">868200752e41adacc9d027092eba7be2db572b00</a>
-<blockquote>
-<p>
- demos/python/gsapi.py: added detection of OS to import correct libgs.so/gpdldll*.dll.<br>
-<br>
-demos/python/gsapi.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-29 07:25:58 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=54842402fafb0bfc9e4ab2031dbe82e7593f5d08">54842402fafb0bfc9e4ab2031dbe82e7593f5d08</a>
-<blockquote>
-<p>
- devices/vector/gdevtxtw.c: Added TextFormat=4 for extract system.<br>
-<br>
- We now retain glyph advance values, and fixed handling of extra widths.<br>
-<br>
- Added .Advs arrays to text_list_entry_s and textw_text_enum_s so that<br>
- we can store the original width of glyph before any additions due to<br>
- TEXT_ADD_TO_ALL_WIDTHS. E.g. this allows one to determine whether glyphs are<br>
- actually not adjacent.<br>
-<br>
- Added TextFormat=4 for generating data suitable for extract system.<br>
-<br>
- txtwrite_process_plain_text:<br>
- Don't preserve gs_point dpt across iterations - this was cumlatively<br>
- adding additions from TEXT_ADD_TO_SPACE_WIDTH, giving incorrect<br>
- positioning. Instead we reset dpt back to {0,0} at the start of each<br>
- iteration.<br>
-<br>
- extract_text_output():<br>
- New, implements TextFormat=4. Writes similar information to<br>
- decorated_text_output() with TextFormat=0, but also specifies advance value<br>
- for each char.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-29 13:19:02 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7e28caf03348229390e8aa3cf6395e3a13fab0b3">7e28caf03348229390e8aa3cf6395e3a13fab0b3</a>
-<blockquote>
-<p>
- Fix minor items in python demo<br>
-<br>
- Remove ;'s at some line endings (a hard habit to break).<br>
- Add try catch around import process. Update README<br>
-<br>
-demos/python/README.txt<br>
-demos/python/examples.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-29 14:39:46 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d802303d48d2cb7ac7be157865588b2416e8e633">d802303d48d2cb7ac7be157865588b2416e8e633</a>
-<blockquote>
-<p>
- Add gs_param list parsing functions.<br>
-<br>
- Actually, steal the existing functions from the PJL code,<br>
- move them into the graphics library, and refactor slightly.<br>
-<br>
- 2 functions; the first one, gs_param_list_add_tokens reads<br>
- a string of key/value pairs and adds them to the list.<br>
-<br>
- The second one, gs_param_list_add_parsed_value takes a key<br>
- and a string for the value, and just adds that pair to the<br>
- list.<br>
-<br>
-base/gsparam.h<br>
-base/gsparaml.c<br>
-base/lib.mak<br>
-pcl/pl/plparams.c<br>
-windows/ghostscript.vcxproj<br>
-windows/ghostscript.vcxproj.filters<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-29 11:29: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=423a04cd8bb7f12ffc127bfb30630348d98694b4">423a04cd8bb7f12ffc127bfb30630348d98694b4</a>
-<blockquote>
-<p>
- Coverity 361150: Check return values for abuf_flush().<br>
-<br>
- I foolishly checked the return value from abuf_flush() in new<br>
- code, which has made Coverity wake up and start complaining<br>
- about these older ones.<br>
-<br>
-base/gdevabuf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-25 08:29: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=89bba350f5724b034753c4febfc559afad835d5c">89bba350f5724b034753c4febfc559afad835d5c</a>
-<blockquote>
-<p>
- Defeat ICC component validation for nullpage device<br>
-<br>
- Further to commit 4a3441bdde7060ecc9048bf391977412a82063a8, it turns out that,<br>
- in practice, we can't completely ignore the ICC profile device parameters,<br>
- parameters that have an immediate effect on the device are also validated during<br>
- put_params and thus, for those, validation can still fail.<br>
-<br>
- Using gxdso_supports_devn allows us to defeat the profile component validation,<br>
- but nullpage is not a DeviceN device, hence that could cause confusion.<br>
-<br>
- Using a dedicated gxdso_skip_icc_component_validation allows us to be more<br>
- selective about when to short circuit those tests, and avoid confusion.<br>
-<br>
- This is required for gpdl as Postscript initialisation is slightly different<br>
- compared to regular Ghostscript - the nulldevice remains in play all through<br>
- Postscript initialisation (rather than being replaced with the device<br>
- specified by the command arguments part way through initialisation).<br>
-<br>
-base/gdevmpla.c<br>
-base/gdevnfwd.c<br>
-base/gdevp14.c<br>
-base/gsicc_manage.c<br>
-base/gxclrect.c<br>
-base/gxdevsop.h<br>
-devices/gdevcmykog.c<br>
-devices/gdevdsp.c<br>
-devices/gdevpsd.c<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-27 12:46: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=9beae99074655cf78729d5e26862f00cea11b109">9beae99074655cf78729d5e26862f00cea11b109</a>
-<blockquote>
-<p>
- Ensure we can call dev_spec_op as soon as device is created<br>
-<br>
- Since we can legitimately want to interrogate a device for its capabilities and<br>
- preferences right from its creation, ensure the dev_spec_op is valid as soon<br>
- as the device is created.<br>
-<br>
-base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-28 21:36:11 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6179b719348c1622352b55d66599ba26cfba9d3d">6179b719348c1622352b55d66599ba26cfba9d3d</a>
-<blockquote>
-<p>
- Add Python examples and README<br>
-<br>
- Also fix typos in C# README<br>
-<br>
-demos/csharp/README.txt<br>
-demos/python/README.txt<br>
-demos/python/examples.py<br>
-demos/python/gsapi.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-28 17:52:11 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c001ce438ef9fd0171104ac49afa110e39edb03e">c001ce438ef9fd0171104ac49afa110e39edb03e</a>
-<blockquote>
-<p>
- Bug 702587: Fix alpha buffer issue with fill/stroke operations.<br>
-<br>
- The &quot;alphabits&quot; devices work by an alpha buffer being inserted<br>
- into the device chain before graphical operations. This intercepts<br>
- drawing device calls, 'saves' the color, and then converts the<br>
- call into a fill of a monochrome mask.<br>
-<br>
- Only a small 'window' of mask is ever held in memory at once. When<br>
- the drawing moves out of the range of that window, the window is<br>
- flushed (conceptually the mask is scaled down, and then that scaled<br>
- representation is filled with the saved color).<br>
-<br>
- Any &quot;stragglers&quot; (i.e. unwritten back bits of mask) are flushed at<br>
- the end of the graphical operation.<br>
-<br>
- When using fill/stroke, the existing code fails to notice the<br>
- color in use being changed. This means the last 'window' of<br>
- fill can end up being written in the color intended for 'stroke'.<br>
-<br>
- We therefore update the fill/stroke logic to check for the color<br>
- changing. (We check for 'unflushed data' and 'color has changed').<br>
-<br>
-base/gdevabuf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-27 12:43: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=45b122117e937bb36da2ef03ea590c90ebcd2de9">45b122117e937bb36da2ef03ea590c90ebcd2de9</a>
-<blockquote>
-<p>
- pdfwrite - free ICCBased profile streams to prevent memory leak<br>
-<br>
- An oversight in memory cleanup in pdfwrite.<br>
-<br>
- ICCBased colour space arrays contain a reference (must be a reference)<br>
- to a stream dictionary where the stream data is the profile. Because the<br>
- stream dictionary is a reference, it must have an ID (a pdf index). This<br>
- means that when we free the colour space array we do not free the stream<br>
- dictionary element contained within it.<br>
-<br>
- We don't free objects with a non-zero ID because these are assumed to be<br>
- a type of resource, and tracked via the resource chains, but in the<br>
- case of ICC profiles we were not adding them to a resource chain.<br>
-<br>
- Fixed here by adding ICC profile streams to the 'resourceOther' chain<br>
- so that they are freed on exit.<br>
-<br>
-devices/vector/gdevpdfk.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-25 10:52: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=55088a6e12775eeae1d19bf9a6db641566ea0c8f">55088a6e12775eeae1d19bf9a6db641566ea0c8f</a>
-<blockquote>
-<p>
- pdfwrite - review use of sclose().<br>
-<br>
- The stream interface essentially leaves the buffer management in the<br>
- hands of the creator; sclose() does not free the stream buffer, but it<br>
- does set the pointer in the stream state to NULL.<br>
-<br>
- This can be problematic; if the only reference we have to the original<br>
- buffer is the pointer in the stream state, then we must copy the pointer<br>
- before calling sclose() and then free the buffer afterwards.<br>
-<br>
- s_close_filters() does this BUT it can't know whether a given buffer<br>
- was allocated in memory, from the C heap or some other fixed allocation.<br>
- It simply frees all the buffers. Obviously this can cause problems if<br>
- we use it indiscriminately.<br>
-<br>
- I've reviewed all the places pdfwrite uses sclose() and where we can<br>
- use s_close_filters() I've modified the code to do so (to avoid memory<br>
- leaks in non-GC memory allocators). Where we must not attempt to free<br>
- the buffer I've left the sclose() but commented on the reason.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfc.c<br>
-devices/vector/gdevpdfo.c<br>
-devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-22 09:57:54 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5d499272b95a6b890a1397e11d20937de000d31b">5d499272b95a6b890a1397e11d20937de000d31b</a>
-<blockquote>
-<p>
- Bug 702582, CVE 2020-15900 Memory Corruption in Ghostscript 9.52<br>
-<br>
- Fix the 'rsearch' calculation for the 'post' size to give the correct<br>
- size. Previous calculation would result in a size that was too large,<br>
- and could underflow to max uint32_t. Also fix 'rsearch' to return the<br>
- correct 'pre' string with empty string match.<br>
-<br>
- A future change may 'undefine' this undocumented, non-standard operator<br>
- during initialization as we do with the many other non-standard internal<br>
- PostScript operators and procedures.<br>
-<br>
-psi/zstring.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-24 14:03:51 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f77f99702c9c8418b9516056d5f4280105beafc4">f77f99702c9c8418b9516056d5f4280105beafc4</a>
-<blockquote>
-<p>
- demos/python/gsapi.py: improved encoding/decoding of strings.<br>
-<br>
- Set global _encoding to the encoding passed to gsapi_set_arg_encoding(), and<br>
- use it where expected by the underlying C code.<br>
-<br>
- gsapi_set_stdio():<br>
- Pass bytes object to stdout and stderr callbacks for convenience, and<br>
- document what expectations are.<br>
-<br>
- gsapi_run_string*():<br>
- Accept str or bytes; encode the former into bytes using utf-8 encoding.<br>
-<br>
-demos/python/gsapi.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-22 18:41:05 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=269f880585dd2c6b3f716668b05f4c911214356b">269f880585dd2c6b3f716668b05f4c911214356b</a>
-<blockquote>
-<p>
- configure.ac: avoid pathological shell glob expansion in CFLAGS_SANITIZE.<br>
-<br>
- Specifying a command-line arg with lots of '*' characters that aren't intended<br>
- to match any filenames, can stress the shell's glob code.<br>
-<br>
- OpenBSD's ksh gets very slow, for example (e.g. 20m vs 45s in bash).<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-24 17:52: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=dd1114e8ac0508ada6959c7ffcf6433b5bebe0cf">dd1114e8ac0508ada6959c7ffcf6433b5bebe0cf</a>
-<blockquote>
-<p>
- make pdf_end_encrypt static<br>
-<br>
-devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-24 15:26: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=0752757bca7979ed23e6e4fc3cf0772a49fb86c2">0752757bca7979ed23e6e4fc3cf0772a49fb86c2</a>
-<blockquote>
-<p>
- pdfwrite - fix memory leak with sclose<br>
-<br>
- The stream code is hideous and full of surprised to trap the unwary. In<br>
- this case sclose() has the unexpected side-effect of setting the stream<br>
- buffer to NULL before returning, so we cannot free it afterwards.<br>
-<br>
- s_close_filters deals with this for us by taking a pointer to the<br>
- buffer and calling gs_free_object on it after the stream is closed, so<br>
- we really need to do that (or mimic the same thing ourselves).<br>
-<br>
- We could do s_close_filters(s, s-&gt;strm) to just close each filter in<br>
- turn, but I've chosen to just walk down the filter chain for each<br>
- filter we added, and then close them all up to that point.<br>
-<br>
- This means changing pdf_end_encrypt() so that instead of closing the<br>
- stream (with the potential memory leak) we just signal whether the<br>
- calling code should close the encryption filter.<br>
-<br>
-devices/vector/gdevpdfu.c<br>
-devices/vector/gdevpdfx.h<br>
-devices/vector/gdevpdti.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-24 09:42: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=4837ddb473d3109fe2108b2ac2aa12a8bf5a0b4e">4837ddb473d3109fe2108b2ac2aa12a8bf5a0b4e</a>
-<blockquote>
-<p>
- Have gsapi_run_file() handle access controls<br>
-<br>
- Previously, gsapi_run_file() required the caller to add the file to be<br>
- processed to the permit read file list. We'll now add the file to the permit<br>
- read list, execute the file, and remove it from the list without the caller<br>
- having to do so.<br>
-<br>
-pcl/pl/plapi.c<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-22 14:01:14 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3244573621b1daa2997fbea0c13ce7f891b42203">3244573621b1daa2997fbea0c13ce7f891b42203</a>
-<blockquote>
-<p>
- Fix pdfwrite memory leak when doing multi-page output<br>
-<br>
- When doing multiple page output (i.e. page-%0d.pdf or whatever) there<br>
- was a memory leak because it was attempting to short-circuit things and<br>
- just delete the last (blank) page, but there was a ton of stuff that<br>
- never got freed in that case.<br>
-<br>
- This change sets a flag for the condition and then processes the whole<br>
- page (which hopefully doesn't do much because it is empty), including<br>
- freeing everything. Then it just deletes the file at the end instead<br>
- of at the beginning of the function.<br>
-<br>
- This function (pdf_close()) is over 1000 lines and really needs to be<br>
- refactored for maintainability.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-22 12:24:05 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=90f0f92bf6bf9c346cd3f74adaa42a7c8a3702cb">90f0f92bf6bf9c346cd3f74adaa42a7c8a3702cb</a>
-<blockquote>
-<p>
- Fix memory leak in pdfwrite device<br>
-<br>
- This appears to only be a memory leak for non-garbage-collected interpreters<br>
- such as pdfi.<br>
-<br>
- sclose() calls s_disable() which sets s-&gt;cbuf to 0.<br>
- But it also calls client callbacks that might do things with cbuf first, so<br>
- it will crash if we free it before calling sclose().<br>
- Side-effects galore! :(<br>
-<br>
- Anyway, we save the pointer before doing the sclose() so we can<br>
- properly free it afterwards.<br>
-<br>
-devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-23 12:51:20 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a3441bdde7060ecc9048bf391977412a82063a8">4a3441bdde7060ecc9048bf391977412a82063a8</a>
-<blockquote>
-<p>
- Have nullpage ignore ICC parameters<br>
-<br>
- We want nullpage to be (largely) a bitbucket device, but ICC profile<br>
- parameters that require a specific color model could cause it to error.<br>
-<br>
- Force nullpage to ignore changes to the device ICC profiles. Since it cannot<br>
- ever produce output, it has no effect in normal operation.<br>
-<br>
-base/gdevnfwd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-23 13:15:20 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a0288377aa1952f8bb3c3739e0d119635280f31c">a0288377aa1952f8bb3c3739e0d119635280f31c</a>
-<blockquote>
-<p>
- gpdl: Don't report -h or --help as failures.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-21 14:50:13 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36bec547acf7b799d09f0433b25b059153712839">36bec547acf7b799d09f0433b25b059153712839</a>
-<blockquote>
-<p>
- demos/python/gsapi.py: removed requirement for python-3.7.<br>
-<br>
- Removed use of collections module, and instead use hand-written classes, which<br>
- are clearer and don't require python-3.7.<br>
-<br>
-demos/python/gsapi.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-21 08:19:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d2b10ba71b40f261350e4ffc1f808381e81544d">1d2b10ba71b40f261350e4ffc1f808381e81544d</a>
-<blockquote>
-<p>
- Fix Coverity ID 360929<br>
-<br>
- Remove some pointless code, over-enthusiastic copy/paste error.<br>
-<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-20 16:41:37 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e2efdde6b718098f0d35763bb094833a766af479">e2efdde6b718098f0d35763bb094833a766af479</a>
-<blockquote>
-<p>
- Fix two minor issues in python API demo<br>
-<br>
-demos/python/gsapi.py<br>
-demos/python/jlib.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-20 16:32:42 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=217b8d292a1098ee56ab52b57bce3e32920b55d4">217b8d292a1098ee56ab52b57bce3e32920b55d4</a>
-<blockquote>
-<p>
- Demo Viewers: Add readme for csharp example.<br>
-<br>
- Also minor fixes in Windows application.<br>
-<br>
-demos/csharp/README.txt<br>
-demos/csharp/api/ghostnet.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/MainWindow.xaml.cs<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-20 16:02:31 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4aa0fb2f264f196bb9a07f9d03f7b2da3e89abec">4aa0fb2f264f196bb9a07f9d03f7b2da3e89abec</a>
-<blockquote>
-<p>
- Linux Demo Viewer : Fix few issues found with testing<br>
-<br>
- Race condition between gs thread and ui thread. Also<br>
- issues with zoom factors.<br>
-<br>
-demos/csharp/api/ghostmono.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainWindow.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainZoom.cs<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-20 14:42: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=b6622b9b2e95e20febe283035328569211413ac4">b6622b9b2e95e20febe283035328569211413ac4</a>
-<blockquote>
-<p>
- Demo Viewer: Delete unused file. Minor code fix in wpf viewer.<br>
-<br>
-demos/csharp/linux/gtk_viewer/src/gsIO.cs<br>
-demos/csharp/linux/gtk_viewer/src/gsOutput.xaml.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/MainWindow.xaml.cs<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-20 14:32:59 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4c6a3e9b8c87aadc6a50c457d8cf7190fafef59c">4c6a3e9b8c87aadc6a50c457d8cf7190fafef59c</a>
-<blockquote>
-<p>
- Linux Demo Viewer: Complete various lingering tasks<br>
-<br>
- Add proper closure of current file. Add launching of new<br>
- process when another file is opened. Fix issue in<br>
- distilling process.<br>
-<br>
-demos/csharp/api/ghostapi.cs<br>
-demos/csharp/api/ghostmono.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainRender.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainThumbRendering.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainWindow.cs<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-20 11:14:42 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ed82512ecb34f9b51461383755e061e881c269c9">ed82512ecb34f9b51461383755e061e881c269c9</a>
-<blockquote>
-<p>
- graphics library - initialise more members of the graphics state<br>
-<br>
- When creating a graphics state and when calling gs_initgraphics() the<br>
- code was not initialising several members of the graphics state. Mainly<br>
- these were the new members introduced some time back to allow the PDF<br>
- interpreter to track the PDF graphics state.<br>
-<br>
- For consistency, and simpler implementation in pdfi, its better to<br>
- specifically initialise the state, especially those members which<br>
- should not default to 0.<br>
-<br>
- This causes a few tiny diffs with XPS (because the XPS interpeter,<br>
- unlike the PS and PDF interpreters) did not set a couple of members<br>
- which are, nevertheless, used when rendering (smoothness and<br>
- accuratecurves). Smoothness (which affects gradient fills) is now<br>
- initialised to 0.02 instead of 1 (so much smoother) and accuratecurves<br>
- is now true instead of false.<br>
-<br>
-base/gsstate.c<br>
-base/gxgstate.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-19 23:21:25 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=45d1994b40289b4ca7bf2d6504081ddcc4d68f14">45d1994b40289b4ca7bf2d6504081ddcc4d68f14</a>
-<blockquote>
-<p>
- Linux Demo Viewer: Distiller work.<br>
-<br>
- Everything is hooked in and running. For some odd reason the tmp<br>
- file generated in the distilling process is 0 bytes. Will<br>
- dig further to see why the file is not getting written. API<br>
- seems happy as can be... very odd.<br>
-<br>
-demos/csharp/api/ghostapi.cs<br>
-demos/csharp/api/ghostmono.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainWindow.cs<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-18 17:02:46 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6466211fec0c44ce29e7cd094465d2ed4f351ef1">6466211fec0c44ce29e7cd094465d2ed4f351ef1</a>
-<blockquote>
-<p>
- Linux Demo Viewer: Progress at last.<br>
-<br>
- Many thing that should have been simple were complicated<br>
- in the poorly documented world of C# mono development.<br>
- Just need to do a bit more clean up and hook in the<br>
- distilling option for PS.<br>
-<br>
-demos/csharp/api/ghostmono.cs<br>
-demos/csharp/linux/gtk_viewer/gtk_viewer.csproj<br>
-demos/csharp/linux/gtk_viewer/gtk_viewer.sln<br>
-demos/csharp/linux/gtk_viewer/src/MainRender.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainThumbRendering.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainWindow.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainZoom.cs<br>
-demos/csharp/linux/gtk_viewer/src/Program.cs<br>
-demos/csharp/linux/gtk_viewer/src/gsOutput.cs<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-15 16:48:25 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0f59de6b3daab30d405ee5c5c4ac943c26721622">0f59de6b3daab30d405ee5c5c4ac943c26721622</a>
-<blockquote>
-<p>
- Linux Demo Viewer: Various updates to try to get threading working<br>
-<br>
-demos/csharp/linux/gtk_viewer/src/DocPage.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainRender.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainThumbRendering.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainWindow.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainZoom.cs<br>
-demos/csharp/linux/gtk_viewer/src/Program.cs<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-15 16:42:57 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=42b49069c0f87406dcd796183ba719d45dd8ce69">42b49069c0f87406dcd796183ba719d45dd8ce69</a>
-<blockquote>
-<p>
- Mono GTK requires a different type of threading call<br>
-<br>
- In Windows .NET one can use the BackgroundWorker event handler.<br>
- Unfortunately the completed event does not call back on the<br>
- correct thread. This one uses methods suggested by the mono<br>
- GTK documentation. Keeping both versions for examples.<br>
-<br>
-demos/csharp/api/ghostmono.cs<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-17 13:44: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=69593c399cbd445b51b4a7bf7d1ccc36604f2c37">69593c399cbd445b51b4a7bf7d1ccc36604f2c37</a>
-<blockquote>
-<p>
- graphics library - initialise some gstate members appropriately<br>
-<br>
- The members are (I think) all part of the PDF graphics state rather than<br>
- the PostScript graphics state. These members are normally initialised<br>
- by the (PostScript) PDF interpreter but when we are running the new<br>
- pdfi interpreter inside Ghostscript we want to inherit the contents of<br>
- the graphics state, not overwrite them, so we do not initialise these.<br>
-<br>
- This leads to problems; because the values are never initialised in this<br>
- case, and (for example) the text horizontal scaling remains at 0 when<br>
- it should be 100. Since we set the Text Rendering Matrix partially by<br>
- multiplying by that value, this can lead to a degenerate matrix and<br>
- cause text not to appear. In addition it causes ps2write output to be<br>
- incorrect and throw an error.<br>
-<br>
- This commit does nothing with regular Ghostscript, but with GS+pdfi it<br>
- fixes hundreds of errors in ps2write tests and results in at least some<br>
- files drawing some content. At least one of these files is still not<br>
- correct (it is with pdfi alone) so there is clearly more to do here.<br>
-<br>
- This reduces the number of errors testing GS+pdfi to 475 which is<br>
- 447 errors less than Ghostscript alone.<br>
-<br>
-base/gxgstate.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-08 10:51:21 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c735180bed16fa7e0525640670a4ee082700b770">c735180bed16fa7e0525640670a4ee082700b770</a>
-<blockquote>
-<p>
- Change default pdfwrite.params.OPM to be 0<br>
-<br>
- It is already set this way by gs distillerparams, but this makes it<br>
- match to make it easier for pdfi.<br>
-<br>
- (This is just a hack at this point, need a general solution for pdfi)<br>
-<br>
-devices/vector/gdevpsdf.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-16 09:15: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=630d427ab701c582c576a54f2b02f44ddae4a3f6">630d427ab701c582c576a54f2b02f44ddae4a3f6</a>
-<blockquote>
-<p>
- Bug 702560: Honour PDFSTOPONERROR with broken form dict<br>
-<br>
- Commit 409db64c5519 added support for form XObject dictionaries with a /Contents<br>
- key for the content stream, rather than the form dict being the stream dict.<br>
-<br>
- As that is contrary to the spec, this commit makes that case trigger an error<br>
- when -dPDFSTOPONERROR is used.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-16 08:14: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=409db64c55198b0126c4afebd74eb26d8d7d57ed">409db64c55198b0126c4afebd74eb26d8d7d57ed</a>
-<blockquote>
-<p>
- Bug 702560: Cope with (broken) form with &quot;Contents&quot;<br>
-<br>
- The file for this bug has a form which contains a /Contents key for the content<br>
- stream, rather than the /Form dictionary being a stream dictionary itself.<br>
-<br>
- This is contrary to the spec, but Acrobat displays it without complaint.<br>
-<br>
- Note: Acrobat pre-flight lists the resource to reference the form object<br>
- as &quot;missing&quot;, and yet renders the form contents anyway.<br>
-<br>
- Also note: we have a test file in the test suite that also includes &quot;/Contents&quot;<br>
- key, which is a metadata string, so we have to explicitly check that the value<br>
- for the &quot;/Contents&quot; key is a stream dictionary.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-14 14:03:41 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c184fcbcc23a196a6d6a26648e52d9f3372ac46b">c184fcbcc23a196a6d6a26648e52d9f3372ac46b</a>
-<blockquote>
-<p>
- Fix problem introduced by commit 6a3c36f8 with multi-threaded rendering.<br>
-<br>
- That commit changed the allocation requirement in clist_init_states, but didn't<br>
- change the corresponding calculation that is supposed to match. Make this a<br>
- function so that both will agree going forward.<br>
-<br>
-base/gxclist.c<br>
-base/gxclist.h<br>
-base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-15 15:25:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3786f7cb0c4ccf3442beafdf186dbc6835da8ae3">3786f7cb0c4ccf3442beafdf186dbc6835da8ae3</a>
-<blockquote>
-<p>
- pdfwrite - write FontMatrix for FDArray of a CFF CIDFont<br>
-<br>
- Bug #702556 &quot;pdfwrite produces an invalid pdf file&quot;<br>
-<br>
- The description is incorrect here, the PDF file is not invalid. The<br>
- input PostScript file has been created by converting a PDF file using<br>
- Poppler.<br>
-<br>
- The original PDF file contains a number of CIDFonts, all with CFF<br>
- outlines, and the conversion, for reasons best known to itself, moves<br>
- the FontMatrix out of the CFF font and into the CIDFont. This isn't<br>
- possible with PDF, so pdfwrite is forced to move the FontMatrix from<br>
- the CIDFont back into the CFF font.<br>
-<br>
- Unfortunately we were not writing the FontMatrix out at the FDArray<br>
- level of the CFF CIDFont, leading to text 1000 times too large.<br>
-<br>
- Fixed here by writing the FontMatrix for each font in the FDArray.<br>
-<br>
-devices/vector/gdevpsf2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-14 13:56:24 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ec2c321c890114af532cb69e913462d56fd4f4f">5ec2c321c890114af532cb69e913462d56fd4f4f</a>
-<blockquote>
-<p>
- Fix bug 702559: Patterns + overprint on 16 bit-per-component devicen devices.<br>
-<br>
- The 'blank_unmasked_bits' needed to handle 16 bit per component (deep) planes.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-14 13:52:45 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d23a584e66c103f43a1de2b1d327bcf196c5972a">d23a584e66c103f43a1de2b1d327bcf196c5972a</a>
-<blockquote>
-<p>
- Fix bug 702557: oknown missing in paint_form check for Group.<br>
-<br>
- Yet another case where indirect objects were not being handled.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-14 10:42: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=868b71c7df45571088e2ff7fcde666b2534d03f0">868b71c7df45571088e2ff7fcde666b2534d03f0</a>
-<blockquote>
-<p>
- pdfwrite - move TwoByteToUnicode variable out of union<br>
-<br>
- Discovered while working on the new PDF interpreter and the test file<br>
- BCL_Easy.pdf with pdfwrite.<br>
-<br>
- The TwoByteToUnicode flag was stored in the 'simple' structure in the<br>
- encoding union. However, that flag is altered by the addition of<br>
- ToUnicode code points, and that is *not* limited to simple encodings,<br>
- we also alter it for CIDFonts. If we alter the flag we are, in effect,<br>
- corrupting members of the union in the case where we are using a<br>
- different structure in the union.<br>
-<br>
- This showed up as corrupting the CMapName member of the type0 structure<br>
- when built for 64-bit. It didn't exhibit with regular Ghostscript<br>
- because that uses the ToUnicode CMap from the input, and only has a<br>
- 2-byte Unicode value, the pdfi version currently returns a 4-byte<br>
- code point.<br>
-<br>
- Nevertheless, this clearly shows that the potential for problems is<br>
- there, so to avoid this in future move the flag out of the union and<br>
- into the main pdf_font_resource_s structure.<br>
-<br>
-devices/vector/gdevpdte.c<br>
-devices/vector/gdevpdtf.c<br>
-devices/vector/gdevpdtf.h<br>
-devices/vector/gdevpdtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-14 10:35: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=bb1fcf280916311b4e38dfc438399aaebf9c8698">bb1fcf280916311b4e38dfc438399aaebf9c8698</a>
-<blockquote>
-<p>
- Move declaration of a variable to function prolog.<br>
-<br>
-base/simscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-03 06:38:12 -0400
-</strong>
-<br>Ken Brown &lt;kbrown@cornell.edu&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8690eed13e3f343fde0d78a5c9bb0108b7f88d41">8690eed13e3f343fde0d78a5c9bb0108b7f88d41</a>
-<blockquote>
-<p>
- Bug 702464: Fix Cygwin build<br>
-<br>
- Commit 327dc89 made many changes to the Cygwin build of ghostscript,<br>
- most of which were wrong. (They treated Cygwin as though it were<br>
- Windows.) One of those changes caused the problem on x86_64 Cygwin<br>
- reported here:<br>
-<br>
- https://sourceware.org/pipermail/cygwin/2020-June/245070.html<br>
-<br>
- This patch restores the Cygwin build to its former state and also<br>
- makes a couple of small tweaks.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-10 09:44:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=857b4a2c5cb7d8ce8798caf623134b77e9f5c447">857b4a2c5cb7d8ce8798caf623134b77e9f5c447</a>
-<blockquote>
-<p>
- Bug 702553: Broken handling of 1.0 TTF cmap case<br>
-<br>
- A (clearly!) fairly little used path through the TTF cmap table handling code<br>
- for PDF files had bitrotted to the point where we ended up trying to create<br>
- a Type 42 font (from a TTF) which didn't have a CharStrings dictionary.<br>
-<br>
- Specifically, this is the case where we're using a 1.0 cmap table, and the<br>
- source PDF font's Encoding object does not contain a Differences key.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-09 22:20:32 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=13c04693416d0fbf0d614509cabce71e7399207e">13c04693416d0fbf0d614509cabce71e7399207e</a>
-<blockquote>
-<p>
- WPF demo: Make changes introduced due to needs of mono project<br>
-<br>
-demos/csharp/windows/ghostnet_wpf_example/MainRender.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/MainThumbRendering.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/MainWindow.xaml.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/ghostnet_simple_viewer.csproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-09 22:08:08 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=279f4835e1ab58653665e9024aaf58032c0591d7">279f4835e1ab58653665e9024aaf58032c0591d7</a>
-<blockquote>
-<p>
- Linux Demo Viewer: Pages now rendering.<br>
-<br>
- AA working. Need to add zoom, page navigation, track down a few<br>
- crashing issues.<br>
-<br>
-demos/csharp/api/ghostnet.cs<br>
-demos/csharp/linux/gtk_viewer/gtk-gui/gtk_viewer.src.gsOutput.cs<br>
-demos/csharp/linux/gtk_viewer/gtk_viewer.csproj<br>
-demos/csharp/linux/gtk_viewer/src/DocPage.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainRender.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainThumbRendering.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainWindow.cs<br>
-demos/csharp/linux/gtk_viewer/src/gsOutput.cs<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-08 22:36:25 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2260ba90c0e70f38f2fef96baf8b1b972eef2940">2260ba90c0e70f38f2fef96baf8b1b972eef2940</a>
-<blockquote>
-<p>
- Linux Demo Viewer: StdIO output working<br>
-<br>
- Thumbnail images created. Need to populate into UI next.<br>
-<br>
-demos/csharp/linux/gtk_viewer/src/MainThumbRendering.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainWindow.cs<br>
-demos/csharp/linux/gtk_viewer/src/gsOutput.cs<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-08 17:42:56 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fcef740cdba16732a16f83a180404c458a075abc">fcef740cdba16732a16f83a180404c458a075abc</a>
-<blockquote>
-<p>
- Progress on the UI design.<br>
-<br>
- Made design similar to what was done for the WPF application.<br>
- stdio callbacks from GS are working so hopefully will have pages<br>
- rendered shortly.<br>
-<br>
-demos/csharp/linux/gtk_viewer/gtk-gui/gtk_viewer.src.gsOutput.cs<br>
-demos/csharp/linux/gtk_viewer/gtk_viewer.csproj<br>
-demos/csharp/linux/gtk_viewer/src/MainThumbRendering.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainWindow.cs<br>
-demos/csharp/linux/gtk_viewer/src/gsOutput.cs<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-07 21:54:08 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=057a39eb4e3f859d293c1e98e1005c82da31024c">057a39eb4e3f859d293c1e98e1005c82da31024c</a>
-<blockquote>
-<p>
- csharp/linux: Initial commit of mono gtk csharp project<br>
-<br>
- Many of the files are variants of the wpf project from windows.<br>
- These projects share the same API files to ghostscript, but the<br>
- mono UI related objects have to change since mono does not support<br>
- WPF. This is just an initial commit to get something in place.<br>
-<br>
-demos/csharp/linux/gs_mono.sln<br>
-demos/csharp/linux/gtk_viewer/Properties/AssemblyInfo.cs<br>
-demos/csharp/linux/gtk_viewer/gtk-gui/generated.cs<br>
-demos/csharp/linux/gtk_viewer/gtk-gui/gtk_viewer.src.gsOutput.cs<br>
-demos/csharp/linux/gtk_viewer/gtk-gui/gui.stetic<br>
-demos/csharp/linux/gtk_viewer/gtk_viewer.csproj<br>
-demos/csharp/linux/gtk_viewer/src/DocPage.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainRender.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainThumbRendering.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainWindow.cs<br>
-demos/csharp/linux/gtk_viewer/src/MainZoom.cs<br>
-demos/csharp/linux/gtk_viewer/src/Program.cs<br>
-demos/csharp/linux/gtk_viewer/src/TempFile.cs<br>
-demos/csharp/linux/gtk_viewer/src/gsIO.cs<br>
-demos/csharp/linux/gtk_viewer/src/gsOutput.cs<br>
-demos/csharp/linux/gtk_viewer/src/gsOutput.xaml.cs<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-09 11:14:46 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e88ba0a1ee23911172222ee6ad7c2e3c9ea205a4">e88ba0a1ee23911172222ee6ad7c2e3c9ea205a4</a>
-<blockquote>
-<p>
- Fix Coverity issue: sizeof(byte **) vs sizeof(byte *)<br>
-<br>
- *Apparently* sizeof(byte *) and sizeof(byte **) might be different.<br>
- I can't think of a case where that's true, but I am indeed using<br>
- the wrong one.<br>
-<br>
- Fix it here.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-08 16:41:11 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da755f7ee3da900a504a3265c64fb08c93a41eac">da755f7ee3da900a504a3265c64fb08c93a41eac</a>
-<blockquote>
-<p>
- Bug 688990: Reimplementation of image mask scaling.<br>
-<br>
- Aiming for a better match to Adobe's reference implementation.<br>
-<br>
- Patch supplied by Peter Cherepanov. Many Thanks!<br>
-<br>
-base/lib.mak<br>
-base/simscale.c<br>
-base/simscale.h<br>
-base/simscale_foo.c<br>
-base/simscale_foo.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-08 18:52:44 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc596ad6dd030f192416086370bd54e8059589d4">cc596ad6dd030f192416086370bd54e8059589d4</a>
-<blockquote>
-<p>
- lgtm.com issue: Fix potential overflow in mkromfs.<br>
-<br>
- We know that we only ever call this splitting the ROMFS into 4,<br>
- so it's never going to overflow, but lgtm.com can't know that.<br>
- Add a check to keep the number down to a sane size to keep it<br>
- happy.<br>
-<br>
-base/mkromfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-08 15:50:11 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b0c208a555ed89139395a6ed0d8dce70d81cde09">b0c208a555ed89139395a6ed0d8dce70d81cde09</a>
-<blockquote>
-<p>
- Bug 691452: Add missing dependencies.<br>
-<br>
- Patch from Peter Cherepanov. Many thanks!<br>
-<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-08 07:22:06 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=000de1419225213fce7d06de0f1982cd79e4e141">000de1419225213fce7d06de0f1982cd79e4e141</a>
-<blockquote>
-<p>
- Update CAL makefile to pass correct compiler flags.<br>
-<br>
-base/cal.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-08 00:03:56 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79d9c45db7ce0ee075254bbfa8235d2996869fb1">79d9c45db7ce0ee075254bbfa8235d2996869fb1</a>
-<blockquote>
-<p>
- Bug 702517: Fix overenthusiastic checking for NULL.<br>
-<br>
- Patch from Peter Cherepanov. Many thanks.<br>
-<br>
-devices/gdevmgr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-03 17:16:10 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c5a246ebe922e94df2e5f5cdd7d01ca86762cb3">6c5a246ebe922e94df2e5f5cdd7d01ca86762cb3</a>
-<blockquote>
-<p>
- Rename displaydev_test to api_test.<br>
-<br>
- Move it into the new &quot;demos&quot; directory, and expand it to cope<br>
- with testing run_string too.<br>
-<br>
-demos/c/ReadMe.txt<br>
-demos/c/api_test.c<br>
-demos/c/api_test.vcxproj<br>
-demos/c/api_test.vcxproj.filters<br>
-toolbin/displaydev_test.vcxproj.filters<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-07 12:55:42 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db8f3a277d0ae43cf5cffea16ee1c9149d4eb3de">db8f3a277d0ae43cf5cffea16ee1c9149d4eb3de</a>
-<blockquote>
-<p>
- Extend gpdl to cope with being fed PDFs via run_string.<br>
-<br>
- More generally, we can now cope with any language implementation<br>
- requesting that data being fed in via run_string should be<br>
- buffered up and then fed in via run_file instead, so formats that<br>
- require seeking can cope.<br>
-<br>
- We add a new gs_error_NeedFile error code. If a run_string<br>
- implementation returns this, the calling gpdl layers captures<br>
- the unused incoming data into an internal &quot;buffered_file&quot; object.<br>
-<br>
- When we reach run_string_end, we then register a new filing<br>
- system with gs_add_fs() to allow this buffered file to be found.<br>
- We then run that file using the standard run_file mechanism.<br>
- Then we remove that filing system, and free the buffered file.<br>
-<br>
- The only implementation that currently uses this is the<br>
- postscript one, which is amended to skip over leading whitespace<br>
- and comments, looking for a PDF header.<br>
-<br>
- XPS already has a mechanism in it for collating data<br>
- into a file using run_string, but this was broken (due to<br>
- process_eof not being called). Fixed here, but still using its<br>
- own mechanism rather than gs_error_NeedFile for now.<br>
-<br>
-base/gserrors.h<br>
-doc/GPDL.htm<br>
-gpdl/psitop.c<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-07 16:09:18 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6eb675b18b8234256bb37190fd35243eab369e36">6eb675b18b8234256bb37190fd35243eab369e36</a>
-<blockquote>
-<p>
- Tweak gsapi for gpdl to match gs.<br>
-<br>
- The gpdl implementation of gsapi differed in the &quot;run_string&quot;<br>
- arguments from the original gs implementation. Add the extra<br>
- parameters here to make the two look identical.<br>
-<br>
-doc/GPDL.htm<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-pcl/pl/realmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-07 14:56: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=24c9b3834b29e8a0eaa6dd78712ef1306049b479">24c9b3834b29e8a0eaa6dd78712ef1306049b479</a>
-<blockquote>
-<p>
- Tweak gp_file veneers.<br>
-<br>
- This allows for implementations to have more NULL function pointers,<br>
- and hence to be simpler.<br>
-<br>
-base/gp.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-06 11:04: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=0a9ec5e7fa81cf3f67f001bfcac2575611e49d85">0a9ec5e7fa81cf3f67f001bfcac2575611e49d85</a>
-<blockquote>
-<p>
- Fix bug 702530: Spurious circular reference error message from PDF interpreter<br>
-<br>
- The safe_recursive function comments described popping the copy of the dict<br>
- made for recursion (to allow multiple references at the same level), but the<br>
- code did not implement that.<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-06 15:44: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=f2e2e3c1bb24887bce699821a3da1f8b3bbd12be">f2e2e3c1bb24887bce699821a3da1f8b3bbd12be</a>
-<blockquote>
-<p>
- Remove the dmprt device<br>
-<br>
- It has code which triggers security warnings, it has not built as it stands<br>
- since before 8.71 (so &gt;10 years) and has significant (segfaulting) problems<br>
- when modified to successfully build.<br>
-<br>
- Since it cannot have been used (and no one has complained) in over ten years,<br>
- we're removing it.<br>
-<br>
-contrib/contrib.mak<br>
-contrib/japanese/dmp_init.ps<br>
-contrib/japanese/dmp_site.ps<br>
-contrib/japanese/doc/gdevdmpr.txt<br>
-contrib/japanese/dviprlib.c<br>
-contrib/japanese/escp_24.src<br>
-contrib/japanese/gdevdmpr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-03 13:52: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=61cbcfe94512ebd9316ff3c0d7ffaee06e226bc2">61cbcfe94512ebd9316ff3c0d7ffaee06e226bc2</a>
-<blockquote>
-<p>
- Add/fix documentation for .begintransparencymaskgroup/.endtransparencymask<br>
-<br>
-doc/Language.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-06 12:13:09 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0296da79f0f215322a1445c35f7343344806c08b">0296da79f0f215322a1445c35f7343344806c08b</a>
-<blockquote>
-<p>
- Fix spot color handling of display device.<br>
-<br>
- The device icc_struct needs to be initialised before we try to<br>
- use it.<br>
-<br>
-devices/devs.mak<br>
-devices/gdevdsp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-07 12:51:45 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2398bdb09fa80498a57ab54815e85d326506b509">2398bdb09fa80498a57ab54815e85d326506b509</a>
-<blockquote>
-<p>
- Fix silly typo in gs_remove_fs.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-07 12:51: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=dbe3a897df38c94c0c2af5b6ad5c4ee9a1c0ffe5">dbe3a897df38c94c0c2af5b6ad5c4ee9a1c0ffe5</a>
-<blockquote>
-<p>
- Add a 'const' to gp_file_alloc.<br>
-<br>
- This enables it to be called in some circumstances where we only<br>
- have a const gs_memory_t.<br>
-<br>
-base/gp.h<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-06 12:35: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=87be031c6039d5f6d9bc960a9aefd442dded3e92">87be031c6039d5f6d9bc960a9aefd442dded3e92</a>
-<blockquote>
-<p>
- Fix Coverity 360266: Unchecked return value.<br>
-<br>
- By the time we get here, we are guaranteed to be fatally failing.<br>
- Checking the return value can't alter what we are returning.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-03 18:37:13 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8549a5c5af77ee512dea0a43a82bf7612a861237">8549a5c5af77ee512dea0a43a82bf7612a861237</a>
-<blockquote>
-<p>
- Fix stray change in doc/API.htm<br>
-<br>
-doc/API.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-03 18:29:48 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aafbb943f1298a75058485fc0c277edfd7ef4048">aafbb943f1298a75058485fc0c277edfd7ef4048</a>
-<blockquote>
-<p>
- Fixes for displaydev_test.<br>
-<br>
- In 64bit builds, we expect the display device to fail when asked<br>
- to align to a multiple of 4.<br>
-<br>
- Also, correct detection of failures.<br>
-<br>
-toolbin/displaydev_test.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-03 17:14: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=5410cc1d64a2082dcd0e037d1ccefdbf68894198">5410cc1d64a2082dcd0e037d1ccefdbf68894198</a>
-<blockquote>
-<p>
- Fix infinite recursion in display device.<br>
-<br>
- If the device was a clist device, and was opened/closed repeatedly,<br>
- the wrong 'base' dev_spec_op could be stored.<br>
-<br>
-devices/gdevdsp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-03 15:45:49 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c2b0b6d61e62b9d490e9e3fcc24efb64c06f2a14">c2b0b6d61e62b9d490e9e3fcc24efb64c06f2a14</a>
-<blockquote>
-<p>
- Fix gpdl run_string API to properly detect language.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-03 12:06: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=a3cf573c2e72daf75c64d7b3a09e544f6e027244">a3cf573c2e72daf75c64d7b3a09e544f6e027244</a>
-<blockquote>
-<p>
- pdfwrite - when copying clip path, cater for differing allocators<br>
-<br>
- This is for pdfi when run under Ghostscript; the pdfwrite device keeps<br>
- a copy of the current clip path when it writes it to the output. But<br>
- the code (gx_cpath_to_path) relies on gx_path_asign_preserve and that<br>
- function specifically states that the allocators for the two paths<br>
- must be the same.<br>
-<br>
- In the case of pdfi under GS, the path is created using the pdfi memory<br>
- allocator (its created by the pdfi interpreter), but the copied path<br>
- is allocated using the device allocator, which is derived from the<br>
- PostScript interpreter. The result of this is that pdfwrite can still<br>
- be pointing to a path which was allocated by pdfi and can disappear<br>
- when the pdfi interpreter exits, leaving a dangling pointer. Since the<br>
- path is subject to garbage collection (allocated with the PostScript<br>
- interpreter allocator) this causes a crash as soon as any kind of<br>
- grbage collection takes place.<br>
-<br>
- Fortunately there's a simple function call 'gx_path_unshare' which will<br>
- copy the segments after assignment and we can check the allocators to<br>
- see if they are the same and us this function if they are not.<br>
-<br>
- Fixes the remaining (currently) seg faults with pdf when running inside<br>
- Ghostscript.<br>
-<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-02 15:38:27 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20757da77706d4227cd7268113bbffbe7716a6fc">20757da77706d4227cd7268113bbffbe7716a6fc</a>
-<blockquote>
-<p>
- Introduce demos folder with csharp and python API examples<br>
-<br>
- Current csharp demo shows creation of wpf viewer. Goal will<br>
- be to next show a Linux viewer using mono and the same API file.<br>
- Python demo/API brought over from toolbin.<br>
-<br>
-demos/csharp/api/ghostapi.cs<br>
-demos/csharp/api/ghostnet.cs<br>
-demos/csharp/windows/ghostnet.sln<br>
-demos/csharp/windows/ghostnet_wpf_example/About.xaml<br>
-demos/csharp/windows/ghostnet_wpf_example/About.xaml.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/App.config<br>
-demos/csharp/windows/ghostnet_wpf_example/App.xaml<br>
-demos/csharp/windows/ghostnet_wpf_example/App.xaml.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/DocPage.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/MainPrint.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/MainRender.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/MainThumbRendering.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/MainWindow.xaml<br>
-demos/csharp/windows/ghostnet_wpf_example/MainWindow.xaml.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/MainZoom.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/PrintControl.xaml<br>
-demos/csharp/windows/ghostnet_wpf_example/PrintControl.xaml.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/Properties/AssemblyInfo.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/Properties/Resources.Designer.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/Properties/Resources.resx<br>
-demos/csharp/windows/ghostnet_wpf_example/Properties/Settings.Designer.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/Properties/Settings.settings<br>
-demos/csharp/windows/ghostnet_wpf_example/TempFile.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/XPSprint.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/ghostnet_simple_viewer.csproj<br>
-demos/csharp/windows/ghostnet_wpf_example/gsIO.cs<br>
-demos/csharp/windows/ghostnet_wpf_example/gsOutput.xaml<br>
-demos/csharp/windows/ghostnet_wpf_example/gsOutput.xaml.cs<br>
-demos/python/gsapi.py<br>
-demos/python/gsapiwrap.py<br>
-demos/python/jlib.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-02 15:02: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=ade938cc74549ffc8d58b0c1fd5e9be7f5429855">ade938cc74549ffc8d58b0c1fd5e9be7f5429855</a>
-<blockquote>
-<p>
- Add missing methods to API.htm<br>
-<br>
-doc/API.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-02 12:21:33 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=62d83a31f7f20910eeb5938873c62e890c9d2b3a">62d83a31f7f20910eeb5938873c62e890c9d2b3a</a>
-<blockquote>
-<p>
- Make -dSimulateOverprint=false work with transparency<br>
-<br>
- When the source file has transparency and overprint, avoid doing<br>
- the compatible overprint mode if overprint is specified to<br>
- be disabled. Thanks to Ray Johnston for helping with the PS<br>
- in pdf_main.ps<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-25 10:52:19 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=00e7143ce97a3d983a223c7d69f74f995d8e267d">00e7143ce97a3d983a223c7d69f74f995d8e267d</a>
-<blockquote>
-<p>
- Pass memory to clist_make_accum_device()<br>
-<br>
- Change function args to propagate the memory type of the graphics<br>
- state to clist_make_accum_device to create device with it.<br>
-<br>
- Also, make sure the dev-&gt;bandlist_memory (used for freeing 'data') is<br>
- allocated in the mem-&gt;non_gc_memory instead of the parent device's<br>
- (fixes crash in gpdl/pcl that was introduced).<br>
-<br>
- That will mean pdfi and gs/pdfi get non-gc, and gs gets gc.<br>
-<br>
- There was a bug in gs/pdfi where the clist-pattern device was in gc<br>
- memory and it was getting freed when pdfi was still using it.<br>
-<br>
- This should fix a segfault in: tests_private/comparefiles/Bug688396.pdf<br>
-<br>
-base/gxclist.c<br>
-base/gxclist.h<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-01 17:16:41 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=60d740278fc7f7b719482ae0dd4a59743025444d">60d740278fc7f7b719482ae0dd4a59743025444d</a>
-<blockquote>
-<p>
- toolbin/gsapi.py: fixed stray ';' character.<br>
-<br>
-toolbin/gsapi.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-01 14:00:17 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=07047636c74555d22c87fd7f05535b57e681a35d">07047636c74555d22c87fd7f05535b57e681a35d</a>
-<blockquote>
-<p>
- toolbin/gsapi.py: added example of how to build .so and run.<br>
-<br>
-toolbin/gsapi.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-07-01 13:59:56 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9900ecb043f3c138160f7d78d32af9967ea09b64">9900ecb043f3c138160f7d78d32af9967ea09b64</a>
-<blockquote>
-<p>
- devices/vector/gdevtxtw.c: fixed build if TRACE_TXTWRITE defined.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-30 15:38:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f3c50e50d6ffd9b4fd98f0215e78d7659bf0bdc3">f3c50e50d6ffd9b4fd98f0215e78d7659bf0bdc3</a>
-<blockquote>
-<p>
- Whitespace fixes<br>
-<br>
-doc/API.htm<br>
-psi/dw32c.def<br>
-psi/dw64c.def<br>
-psi/dwmain32.def<br>
-psi/dwmain64.def<br>
-psi/dwsetup.def<br>
-psi/dwuninst.def<br>
-psi/gsdll32.def<br>
-psi/gsdll32metro.def<br>
-psi/gsdll64.def<br>
-psi/gsdll64metro.def<br>
-psi/gsdllARM32metro.def<br>
-psi/gsos2.def<br>
-toolbin/gsapi.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-30 13:58: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=a1cf59357b6945fdac87afa76e2afd56bb3c1206">a1cf59357b6945fdac87afa76e2afd56bb3c1206</a>
-<blockquote>
-<p>
- Slight tweak to the FAPI API<br>
-<br>
- The previous Font API update had a slight mistake: for non-CID fonts, we'd pass<br>
- GS_NO_GLYPH in place of the actually CID/GID into the &quot;fapi_set_cache&quot; call<br>
- back.<br>
-<br>
- That worked fine because, for Postscript (and currrent PDF) non-CID fonts use<br>
- the glyph name, not a character code, and the other interpreters do not<br>
- need a character for that callback.<br>
-<br>
- We'll now pass the glyph index for non-CID fonts, and the<br>
- glyph index + GS_MIN_CID_GLYPH (as is conventional for gs) - and that allows<br>
- the fapi_set_cache call back to differentiate between CID and non-CID fonts.<br>
-<br>
- For the new PDF interpreter (pdfi) we actually do need the character code, to<br>
- correctly handle Truetype fonts. So fixing the graphics lib and associated code<br>
- on master, so the pdfi branch can also work.<br>
-<br>
-base/gxfapi.c<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-30 09:27: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=71d0b343a3f20d298b9abbe6261bcb01ecb48dcb">71d0b343a3f20d298b9abbe6261bcb01ecb48dcb</a>
-<blockquote>
-<p>
- Improve eps2write<br>
-<br>
- Bug #702521 &quot;eps2write hygiene enhancements&quot;<br>
-<br>
- If processing a multi-page input file, throw an error on the second<br>
- page and write a message explaining the problem.<br>
-<br>
- Encapsulate the 'global configuration' switches which affect the prolog<br>
- processing, and are written from the ps2write device, in a dictionary<br>
- because EPS files should not affect the current dictionary. Read those<br>
- parameters back from the dictionary when establishing the EPS file's<br>
- own dictionary, ensuring that a dictionary is actually present.<br>
-<br>
- Use the global configuration to determine whether to install a custom<br>
- error handler. If its an EPS file, then don't.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfu.c<br>
-devices/vector/opdfread.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-29 12:04:05 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d286e365c298b30fc8f0d74979779c18cf4d28f5">d286e365c298b30fc8f0d74979779c18cf4d28f5</a>
-<blockquote>
-<p>
- A few more changes to the API.htm docs.<br>
-<br>
-doc/API.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-29 10:51:57 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=50a60d8421f3e64828790ec4588727fdc41c4d58">50a60d8421f3e64828790ec4588727fdc41c4d58</a>
-<blockquote>
-<p>
- Fix minor issues in API.htm<br>
-<br>
-doc/API.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-29 13:15:35 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=95e5e879c3a3fea42a97e942b53a6914ed7ccfc2">95e5e879c3a3fea42a97e942b53a6914ed7ccfc2</a>
-<blockquote>
-<p>
- int_gstate_alloc() error handling<br>
-<br>
- If we fail to allocate even the graphics libaray graphics state, bail out<br>
- immediately.<br>
-<br>
-psi/zgstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-23 09:22:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea7818b8bb62b1df4f81e4dc752ccda54cc3d59c">ea7818b8bb62b1df4f81e4dc752ccda54cc3d59c</a>
-<blockquote>
-<p>
- UMR fix: parameters for overprint compositor<br>
-<br>
- Discovered while investigating (red herring) indeterminacy problems with<br>
- eci_altona-test-suite-v2_technical2_x4.pdf<br>
-<br>
- Reported by both valgrind and MSAN.<br>
-<br>
-base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-26 20:05: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=71962c6ed1e0bdf41e604a8014b93889f9d07ee5">71962c6ed1e0bdf41e604a8014b93889f9d07ee5</a>
-<blockquote>
-<p>
- Squash warnings seen in Windows 64 bit build.<br>
-<br>
-base/gp_msprn.c<br>
-base/gp_mswin.c<br>
-base/gp_winfs.c<br>
-base/gsalloc.c<br>
-base/gsmemory.c<br>
-base/gxclist.c<br>
-base/gxi12bit.c<br>
-base/gxicolor.c<br>
-devices/gdevcdj.c<br>
-devices/gdevupd.c<br>
-devices/vector/gdevpdtb.c<br>
-ijs/ijs_exec_win.c<br>
-psi/idict.c<br>
-psi/inamedef.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-26 19:11: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=b68604731130f5493d2ecd5ae627b1bae9624c64">b68604731130f5493d2ecd5ae627b1bae9624c64</a>
-<blockquote>
-<p>
- Update Makefile for new version of tesseract.<br>
-<br>
-base/tesseract.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-26 19:08:39 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad2418e6dc8afa7c7278d6687c77791026f98228">ad2418e6dc8afa7c7278d6687c77791026f98228</a>
-<blockquote>
-<p>
- Fix callouts being allocated/deallocated with the wrong gs_memory_t.<br>
-<br>
- This didn't matter for gs, but for gpdl, it could cause problems<br>
- on shutdown.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-02 16:29:32 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=135f2ceaa84fb0a058ba781a451c65b95230e49a">135f2ceaa84fb0a058ba781a451c65b95230e49a</a>
-<blockquote>
-<p>
- Have bmpcmp return EXIT_FAILURE if it can not compare<br>
-<br>
-toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-26 16:15: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=c022554c30f680c464f1026dc96c2450867da73c">c022554c30f680c464f1026dc96c2450867da73c</a>
-<blockquote>
-<p>
- Remove displaydev_test project from GhostPDL.sln.<br>
-<br>
- It should never have been added in git. I added it locally and<br>
- then it slipped through and got committed by accidently.<br>
-<br>
-windows/GhostPDL.sln<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-26 16:12:33 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=622f4ea8ecc9b677165121d0c093632b9ea00c67">622f4ea8ecc9b677165121d0c093632b9ea00c67</a>
-<blockquote>
-<p>
- Don't let psapi_new_instance trample libctx-&gt;stdio functions.<br>
-<br>
- For GS builds this doesn't matter, as psapi_new_instance is called<br>
- before users of the API get to set their own versions. With GPDL<br>
- builds, the call to psapi_new_instance is deferred to the point<br>
- where the API user may have already set their own functions.<br>
-<br>
-psi/psapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-26 16:10:42 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f886898e23483e82866148d6b564faf281490ba">4f886898e23483e82866148d6b564faf281490ba</a>
-<blockquote>
-<p>
- Avoid using bool in gslibctx.h.<br>
-<br>
- Ghostscript relies on bool being 'int'. Unfortunately, this header<br>
- is included from various C++ files that use bool as char. Accordingly<br>
- the easiest fix is to avoid using bool in these structure definitions.<br>
-<br>
-base/gslibctx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-25 12:29:01 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=969370ba1dbcf767bae97fda6a3c066b04439c76">969370ba1dbcf767bae97fda6a3c066b04439c76</a>
-<blockquote>
-<p>
- Fix refcnt's on the colorspace in clist<br>
-<br>
- In the case where the colorspace was modified (read_set_color_space)<br>
- there was a memory leak.<br>
-<br>
- This was because the old code just freed pcs, but if the color had<br>
- changed, then gs_state.color[0].color_space and [1].color_space are no<br>
- longer the same. This way we track the references to them separately<br>
- and free them separately.<br>
-<br>
- pcs doesn't get its own ref, because it is always the same as<br>
- gs_gstate.color[0].color_space.<br>
-<br>
- This fixes memory leaks that only show up in the case that the memory<br>
- is not garbage-collected, such as in pdfi.<br>
-<br>
-base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-25 19:15: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=305b9fa7334fc0cd1f45585b8449b0c2c7517559">305b9fa7334fc0cd1f45585b8449b0c2c7517559</a>
-<blockquote>
-<p>
- Fix leak of non-deregistered callback handlers on shutdown.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-25 17:08: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=59bd5d853cec55497486ad4fb2f253a92e4da3cc">59bd5d853cec55497486ad4fb2f253a92e4da3cc</a>
-<blockquote>
-<p>
- Fix typos in GPDL.htm.<br>
-<br>
-doc/GPDL.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-25 16:39: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=1615ace33ebb93d8c5faae8a440ab96f06f5f0fe">1615ace33ebb93d8c5faae8a440ab96f06f5f0fe</a>
-<blockquote>
-<p>
- Add documentation for GPDL.<br>
-<br>
-doc/GPDL.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-25 15:13:47 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=35f6a9d9e2838069b5ba250cf26d016bc5ad3635">35f6a9d9e2838069b5ba250cf26d016bc5ad3635</a>
-<blockquote>
-<p>
- GPDL whitespace fixes.<br>
-<br>
-pcl/pl/pjparsei.c<br>
-pcl/pxl/pxtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-25 15:12:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a9bd94535682bd75bbaa18da42129e49046f3838">a9bd94535682bd75bbaa18da42129e49046f3838</a>
-<blockquote>
-<p>
- Remove unused remnants from gpdl/pngtop.c<br>
-<br>
-gpdl/pngtop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-25 15:12:26 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f5b28fa033b4837f3cc28943f5c022bf48ca39d4">f5b28fa033b4837f3cc28943f5c022bf48ca39d4</a>
-<blockquote>
-<p>
- GPDL: Remove &quot;min_input_size&quot; from pl_interp_characteristics_t<br>
-<br>
- Never used.<br>
-<br>
-gpdl/jbig2top.c<br>
-gpdl/jp2ktop.c<br>
-gpdl/jpgtop.c<br>
-gpdl/pngtop.c<br>
-gpdl/psitop.c<br>
-gpdl/pwgtop.c<br>
-gpdl/tifftop.c<br>
-pcl/pcl/pctop.c<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/pltop.h<br>
-pcl/pxl/pxtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-23 10:56: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=ae5bcb6df4b9aa4337a93d5ce8c8152ea4494941">ae5bcb6df4b9aa4337a93d5ce8c8152ea4494941</a>
-<blockquote>
-<p>
- Simple test app for driving the display device.<br>
-<br>
-toolbin/displaydev_test.c<br>
-toolbin/displaydev_test.vcxproj<br>
-toolbin/displaydev_test.vcxproj.filters<br>
-windows/GhostPDL.sln<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-16 14:31:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eed3bad23510e59278bdaa5f7d0ab01fc1a1c21b">eed3bad23510e59278bdaa5f7d0ab01fc1a1c21b</a>
-<blockquote>
-<p>
- Display device revamp.<br>
-<br>
- Move display device over to being based upon a &quot;clist_mutatable&quot;<br>
- device. Existing claimants won't see any difference.<br>
-<br>
- New claimants can provide additional callbacks so they can drive<br>
- it in 'rectangle request' mode.<br>
-<br>
-devices/gdevdsp.c<br>
-devices/gdevdsp.h<br>
-devices/gdevdsp2.h<br>
-doc/API.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-12 13:00: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=04e937862eaa7e66bb9a87109874112cd354bf6f">04e937862eaa7e66bb9a87109874112cd354bf6f</a>
-<blockquote>
-<p>
- Remove clist &quot;is_printer&quot; field.<br>
-<br>
- Currently, the clist has an &quot;is_printer&quot; field, which is used to<br>
- tell it how to forward dev_spec_op calls. This seems evil to me;<br>
- a base class should not really need to know what class is being<br>
- derived from it to know how to behave.<br>
-<br>
- Instead, introduce a function pointer that says where<br>
- dev_spec_ops should be forwarded to.<br>
-<br>
-base/gdevprn.c<br>
-base/gxclist.c<br>
-base/gxclist.h<br>
-base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-11 12:47:58 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f697ed393a3f0cfffbf82b1f679cf6667b06611c">f697ed393a3f0cfffbf82b1f679cf6667b06611c</a>
-<blockquote>
-<p>
- Refactor 'clist mutatable devices' from prn ones.<br>
-<br>
- Devices that have to mutate to be clist ones need to be setup<br>
- in a particular way. After the standard gx_device header, they<br>
- are padded out to a large enough size that the clist header<br>
- fields can fit in. Then the device specific fields follow.<br>
-<br>
- gdev_prn devices are the standard example of this. In order<br>
- to more easily allow other devices to work in the same way,<br>
- we refactor the padding/clist specific fields out into new<br>
- macros.<br>
-<br>
-base/gdevprn.c<br>
-base/gdevprn.h<br>
-base/gxclist.c<br>
-base/gxclist.h<br>
-devices/gdevbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-11 12:04: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=aae141b7849700a3b99a9222e09ed6ebaff5c61b">aae141b7849700a3b99a9222e09ed6ebaff5c61b</a>
-<blockquote>
-<p>
- Refactor gdev_space_params slightly.<br>
-<br>
- The gdev_space_params structure is also known as gdev_prn_space_params,<br>
- which is slightly misleading as there is nothing prn specific about<br>
- it.<br>
-<br>
- Rename all uses of gdev_prn_space_params within the code to be<br>
- gdev_space_params. Leave gdev_prn_space_params defined as a typedef<br>
- so that any customer code will not be affected.<br>
-<br>
- Rename compare_gdev_prn_space_params to be gdev_space_params_cmp<br>
- to better reflect its non-prn-specific nature. Make it non-static<br>
- and move it to gsdevice.c.<br>
-<br>
-base/gdevprn.c<br>
-base/gdevprn.h<br>
-base/gsdevice.c<br>
-base/gxdevcli.h<br>
-cups/gdevcups.c<br>
-devices/gdevcdj.c<br>
-devices/gdevijs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-22 10:06:58 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f40f4b1aca7a7f75ecf83469892478311ca21e1">8f40f4b1aca7a7f75ecf83469892478311ca21e1</a>
-<blockquote>
-<p>
- Update Planar device to allow for easy &quot;interleaved&quot; operation.<br>
-<br>
-base/gdevmem.c<br>
-base/gdevmpla.c<br>
-base/gdevmpla.h<br>
-base/gxdevmem.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-19 19:04:53 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22f5f898d49443df82c13bd683fbff61005485c2">22f5f898d49443df82c13bd683fbff61005485c2</a>
-<blockquote>
-<p>
- Improve get_bits_rectangle for planar case.<br>
-<br>
- The implementation of get_bits_rectangle to read planar data from<br>
- a planar device, only implements GB_RETURN_POINTER. If this isn't<br>
- in the request (i.e. the caller uses GB_RETURN_COPY to get a copy<br>
- of the data in its own buffers), then it cannot cope.<br>
-<br>
- Here we extend the routine to try to use a GB_RETURN_POINTER<br>
- request internally, and to copy the returned data into the<br>
- callers buffers.<br>
-<br>
- Callers are of course already free to do this operation themselves,<br>
- but this avoids the needless repetition of the code in every<br>
- caller.<br>
-<br>
-base/gdevmpla.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-04 19:27: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=4438e3e5bc4dfc9e46fc86d86d912171ec582a4e">4438e3e5bc4dfc9e46fc86d86d912171ec582a4e</a>
-<blockquote>
-<p>
- Rework display device &quot;DisplayHandle&quot; passing.<br>
-<br>
- Add gsapi_{,de}register_callout API. This allows integrators<br>
- to register handlers for &quot;callouts&quot; from gs devices.<br>
-<br>
- The first example of such a callout is the display device.<br>
- Previously, this has relied on the gsapi_set_display_callback<br>
- API to pass a pointer to a structure into the core, from where<br>
- it was hackily poked into the display device structure.<br>
-<br>
- Instead, we now have the display device &quot;callout&quot; to registered<br>
- handlers to get the structure and the handle to use.<br>
-<br>
- The legacy API is maintained by the API level implementing<br>
- a handler to return the display callback in response to the<br>
- devices callout.<br>
-<br>
- The code to do the 'poking' of the display device has therefore<br>
- been removed, and replaced by code that checks to see if an<br>
- opened device needs reopening after init, if so, opens/closes it.<br>
-<br>
-base/gsdevice.c<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-base/gxdevcli.h<br>
-base/gxdevsop.h<br>
-devices/gdevdsp.c<br>
-devices/gdevdsp.h<br>
-devices/gdevdsp2.h<br>
-doc/API.htm<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plmain.c<br>
-psi/gsdll2.def<br>
-psi/gsdll32.def<br>
-psi/gsdll32metro.def<br>
-psi/gsdll64.def<br>
-psi/gsdll64metro.def<br>
-psi/gsdllARM32metro.def<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-psi/idisp.c<br>
-psi/idisp.h<br>
-psi/imain.c<br>
-psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-22 17:04:02 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7e427246abb151cde9154783775acfaa776b502e">7e427246abb151cde9154783775acfaa776b502e</a>
-<blockquote>
-<p>
- Simple Spot color test file.<br>
-<br>
-examples/spots.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-19 15:05:34 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=63d4ce589086609178160857452dbe3ca6ec0361">63d4ce589086609178160857452dbe3ca6ec0361</a>
-<blockquote>
-<p>
- Tweak mem device; use NULL rather than 0.<br>
-<br>
-base/gdevmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-20 19:08: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=5123260e329a44db83edf4b1378cb7101632f7eb">5123260e329a44db83edf4b1378cb7101632f7eb</a>
-<blockquote>
-<p>
- Fix Bug 701852. Problems with the plane_extract device.<br>
-<br>
- First, the plane_begin_typed_image function used the gs_gstate_copy_temp,<br>
- but since this was allocated as a st_gs_gstate, and the reference counts<br>
- were not handled (as the comment describes), freeing that object would<br>
- decrement the ref_counts, causing premature free of objects.<br>
-<br>
- Remove this dangerous function.<br>
-<br>
- Change to use gs_gstate_copy so we have a proper gs_gstate structure.<br>
-<br>
- Using gs_gstate_copy from a clist playback gstate requires that we have<br>
- client colors and device colors in the color[0] and color[1] elements.<br>
- Allocate, and initialize these, then free upon exit from clist_playback.<br>
-<br>
- Also, the mem device underlying the plane_extract device needs to be<br>
- retained so that it is not prematurely freed.<br>
-<br>
-base/gdevplnx.c<br>
-base/gsgstate.c<br>
-base/gxclrast.c<br>
-base/gxgstate.h<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-24 15:57:18 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2d69b876807bb66889e7d89ad39649aded72901e">2d69b876807bb66889e7d89ad39649aded72901e</a>
-<blockquote>
-<p>
- Tweak gpdl parameter handling.<br>
-<br>
- Reorder some bits (to make checking against gs easier).<br>
-<br>
- Add handling for --help (same as -h).<br>
-<br>
- Add handling for -v. List languages supported in version<br>
- and usage output.<br>
-<br>
- Add handling for -q. Rely on the fact that -q is the same as -dQUIET.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-24 13:45:30 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8433ecd5c9bee10a767293c886644fc91f6d7d4d">8433ecd5c9bee10a767293c886644fc91f6d7d4d</a>
-<blockquote>
-<p>
- Fix gs command line parsing to handle --unknown<br>
-<br>
- Previously &quot;--unknown&quot; would have been treated like &quot;--&quot;.<br>
-<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-23 16:34:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a50c9e8d1819c5273a5f6d46137dc527382fabb1">a50c9e8d1819c5273a5f6d46137dc527382fabb1</a>
-<blockquote>
-<p>
- Typo: ps2weite -&gt; ps2write<br>
-<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-23 01:36:02 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea495beece2c461d6561e3d5780d40e77603abc9">ea495beece2c461d6561e3d5780d40e77603abc9</a>
-<blockquote>
-<p>
- jbig2dec: Free result object upon error allocating referred to segments.<br>
-<br>
-jbig2dec/jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-23 01:27:25 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e0c1b3c8162898eaa46640cae98be34642704e3c">e0c1b3c8162898eaa46640cae98be34642704e3c</a>
-<blockquote>
-<p>
- jbig2dec: Fix memory leak caused by failing to allocate arithmetic coding context.<br>
-<br>
-jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-18 22:02:27 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=554b67a6f3ba5e6c78b35f94ab3f57e96b1a3dee">554b67a6f3ba5e6c78b35f94ab3f57e96b1a3dee</a>
-<blockquote>
-<p>
- Bug 702505. Annotations with BlendMode (/BM) failed as PDF is opened.<br>
-<br>
- The check for transparency in the page would fail with 'typecheck' because<br>
- the operand stack was not properly cleaned once the /BM was detected.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-19 07:55: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=c287d823671769a45c3b0c4a7f16a10fc5e7cb5a">c287d823671769a45c3b0c4a7f16a10fc5e7cb5a</a>
-<blockquote>
-<p>
- Coverity 359871, 359872: un-init variable and conditional always true<br>
-<br>
- A return code could remain unset in an otherwise successful completion of the<br>
- function.<br>
-<br>
- The new FAPI interface switch from using a signed value of -1 to the &quot;standard&quot;<br>
- special value of GS_NO_CHAR, and I missed a case of that - since GS_NO_CHAR is<br>
- positive, the existing test of &gt;= 0 was flagged as always true.<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-18 19:34: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=57885b1ab496d12d4b6e7ee6a98144e5b040afa1">57885b1ab496d12d4b6e7ee6a98144e5b040afa1</a>
-<blockquote>
-<p>
- Allow the First/LastPage device page count to be reset<br>
-<br>
- If we get a DisablePageHandler parameter setting to &quot;false&quot; (i.e. enabling the<br>
- filtering) then start counting pages from there.<br>
-<br>
- This allows more intuitive control over extracting specific pages from multiple<br>
- input files.<br>
-<br>
-base/gdevflp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-18 19:26:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=99d5046ebd2998eb550a66677142186b00071b73">99d5046ebd2998eb550a66677142186b00071b73</a>
-<blockquote>
-<p>
- Improve PageList device param handling<br>
-<br>
- The error handing when reading the PageList parameter did not match the rest of<br>
- the code in gx_default_put_params() - record the error, but carry on.<br>
-<br>
- Secondly, the original implementation never accounted for the possibility of<br>
- &quot;unsetting&quot; the PageList. This is possible by sending an empty string.<br>
-<br>
-base/gsdparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-16 19:01:25 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e21dc926e2a2214ab8ae830b984057994d139a1c">e21dc926e2a2214ab8ae830b984057994d139a1c</a>
-<blockquote>
-<p>
- toolbin/gsapi.py: python version of psi/iapi.h, using ctypes.<br>
-<br>
-toolbin/gsapi.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-25 12:50:32 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=74d47eada1e07862c3af7bbb214edd6cf94e0164">74d47eada1e07862c3af7bbb214edd6cf94e0164</a>
-<blockquote>
-<p>
- In clusterpush, exclude sodebugobj and /build.<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-15 11:41:30 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e29a4c0affe3e7b66ff19d70e0d2abbc1e7fdf21">e29a4c0affe3e7b66ff19d70e0d2abbc1e7fdf21</a>
-<blockquote>
-<p>
- Added experimental swig wrapper for gsapi.<br>
-<br>
-toolbin/gsapiwrap.py<br>
-toolbin/jlib.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-21 18:16:28 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=31157290172feea1817d6e69c5064d025a9ab45c">31157290172feea1817d6e69c5064d025a9ab45c</a>
-<blockquote>
-<p>
- Changed gsapi_set_default_device_list() to take const char* arg, not char*.<br>
-<br>
- This allows SWIG to work, and also tightens up the API.<br>
-<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-21 14:48:12 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b953e588fb74a73b997d11412a2878f4cdfcdfb">9b953e588fb74a73b997d11412a2878f4cdfcdfb</a>
-<blockquote>
-<p>
- Improve test for error in s_stdout_write_process().<br>
-<br>
- Detect error case where outwrite() incorrectly returns &gt; count, so we can avoid<br>
- incrementing pr-&gt;ptr beyond bounds of array.<br>
-<br>
-psi/ziodevsc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-09 19:17:55 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fcd9967f93151c49cefe437f6f0bdb1f047d68cc">fcd9967f93151c49cefe437f6f0bdb1f047d68cc</a>
-<blockquote>
-<p>
- Avoid leak in pcl_process() by calling pcl_complete_raster() if returning error.<br>
-<br>
- Fixes:<br>
-<br>
- MEMENTO_FAILAT=18536 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ../tests_private/pcl/pcl5cfts/fts.2180<br>
-<br>
- pcl/pcl/pcparse.c<br>
-<br>
-pcl/pcl/pcparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-04 16:14:20 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0a4f6d6cb3efda8f0b334c0b04457362b00dac1b">0a4f6d6cb3efda8f0b334c0b04457362b00dac1b</a>
-<blockquote>
-<p>
- Revisions to FAPI (error handling etc).<br>
-<br>
- A lot of the FAPI methods made no account for errors (i.e. a call to return an<br>
- unsigned 16 bit value would return an unsigned short int). In various places<br>
- that meant we ended up using unlikely (in practice, impossible, yet still<br>
- &quot;valid&quot;) values to indicate an error condition.<br>
-<br>
- This commit changes those calls to have a conventional Ghostscript &quot;int&quot;<br>
- return value and (mostly) take pointer to the storage into which they should<br>
- write their value. We can now return meaninful error codes.<br>
-<br>
- Secondly, in several places, the FAPI methods and code used integers to store<br>
- character codes, cids, gids etc. This is less than ideal because we potentially<br>
- have to handle 4 byte codes (especially for gids), and we also use some<br>
- special 64 bit values (when available) for specific meanings. There were<br>
- several workarounds for that, in various places.<br>
-<br>
- This commit also changes the FAPI API and code to the gs_glyph type for all<br>
- such values, removing the need for those workarounds<br>
-<br>
-base/fapi_ft.c<br>
-base/fapibstm.c<br>
-base/fapiufst.c<br>
-base/gxfapi.c<br>
-base/gxfapi.h<br>
-base/write_t1.c<br>
-base/write_t2.c<br>
-pcl/pl/plfapi.c<br>
-psi/zfapi.c<br>
-xps/xpsfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-28 11:04:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8384e88e02cefa3de112546838a752d7f0a7a5c1">8384e88e02cefa3de112546838a752d7f0a7a5c1</a>
-<blockquote>
-<p>
- Make gs_char and gs_glyph explicitly 64 bit types<br>
-<br>
-base/gsccode.h<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-16 16:50: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=0339cbecea80d8a835b316b56d1c75a6fb850e52">0339cbecea80d8a835b316b56d1c75a6fb850e52</a>
-<blockquote>
-<p>
- oss-fuzz 23440: check string lengths for PDF decryption<br>
-<br>
- to avoid Use-of-uninitialized-value problems.<br>
-<br>
-psi/zpdf_r6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-11 11:54: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=889df15d7c69e1fc90c6491f574352cacf9bc065">889df15d7c69e1fc90c6491f574352cacf9bc065</a>
-<blockquote>
-<p>
- oss-fuzz 22182: validate glyph offset/length values<br>
-<br>
- Check if the glyph offset and offset + length are larger than the size of the<br>
- font stream before we can use it.<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-11 11:53: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=e61000344e40930aa229be5aa5cb9d31958bcb6d">e61000344e40930aa229be5aa5cb9d31958bcb6d</a>
-<blockquote>
-<p>
- Truetype: Tweak a conditional for signed/unsigned compare<br>
-<br>
-base/gstype42.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-16 14:14: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=0e50ac9dfcff795ec69cb646eea151bd57f0dd1c">0e50ac9dfcff795ec69cb646eea151bd57f0dd1c</a>
-<blockquote>
-<p>
- Fix letter `te` in in Nimbus Sans Bold(Italic)<br>
-<br>
- Update from URW++ (2020/05/26).<br>
-<br>
- See:<br>
- https://github.com/ArtifexSoftware/urw-base35-fonts/issues/28<br>
- https://bugs.launchpad.net/ubuntu/+source/fonts-urw-base35/+bug/1871377<br>
-<br>
- The glyph outline was much too wide, as well as the advance width being too<br>
- large.<br>
-<br>
- Note: a number of test files show tiny rounding differences - this is normal<br>
- when these fonts get regenerated.<br>
-<br>
-Resource/Font/NimbusSans-BoldItalic<br>
-Resource/Font/NimbusSans-Italic<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-15 18:37:57 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a189c020b1eb34a043c086b89bbb1caa86cc01f5">a189c020b1eb34a043c086b89bbb1caa86cc01f5</a>
-<blockquote>
-<p>
- When building on arm64 with gcc, disable libpng's neon optimizations.<br>
-<br>
- Bug 702486 - Ghostscript 9.52 does not build on arm64<br>
-<br>
- Ghostscript 9.52 with the libraries which it is including builds<br>
- perfectly on i386, amd64, s390x, and armhf, but not on ppc64el<br>
- and arm64. Problem are internal optimizations in the libpng<br>
- shipped with Ghostscript.<br>
-<br>
- For ppc64el the problem was already solved after the 9.52<br>
- release:<br>
-<br>
- http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c9bd8e0aa4<br>
- https://bugs.ghostscript.com/show_bug.cgi?id=702236<br>
-<br>
- This fix is for arm64 is Based on this and on a similar fix for<br>
- arm64 on another free software project<br>
-<br>
- https://github.com/imagemin/optipng-bin/issues/97<br>
-<br>
- This makes it also build on arm64, but it is not tested whether<br>
- it still correctly works on arm64 after the fix.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-13 12:11: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=9984b482e5c41427f69be32752b649d44eccd3cd">9984b482e5c41427f69be32752b649d44eccd3cd</a>
-<blockquote>
-<p>
- More work on gs_get_colorname_string<br>
-<br>
- Commit 14c70d4e9 was, unfortunately, insufficient for the new PDF<br>
- interpreter. The gs_lib_ctx pointer does not give us access back to the<br>
- interpreter context, only to the *PostScript* interpreter name table.<br>
-<br>
- So instead we now pass a graphics state pointer to<br>
- gs_get_colorname_string(). This is only used for halftones currently,<br>
- and even future use seems likely to be limited to objects like colour<br>
- spaces, which are of course contained in a graphics state, so this<br>
- seems relatviely future proof.<br>
-<br>
- For PostScript the graphics state contains a memory_t pointer which we<br>
- can use to get to the PostScript name table. For the PDF interpreter<br>
- we already store some state in the 'client_data' of the graphics state<br>
- and we will extend that to include a pointer to the interpreter context<br>
- which will allow us to get the string from its name table.<br>
-<br>
-base/gscspace.h<br>
-base/gsncdummy.c<br>
-base/gxht.h<br>
-devices/vector/gdevpdfg.c<br>
-psi/zht2.c<br>
-psi/zht2.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-12 10:37: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=14c70d4e91db4b13273a48004fada094e8f8090d">14c70d4e91db4b13273a48004fada094e8f8090d</a>
-<blockquote>
-<p>
- Improve usage of 'get_colorname_string'<br>
-<br>
- This function is supplied to a couple of places, and stored. Its<br>
- purpose is to retrieve a string for a colour plane, given an 'index'.<br>
- The index is an entry in the interpreter's name table.<br>
-<br>
- The implementations of get_colorname_string take a memory_t pointer<br>
- and then use that to get a pointer to the interpreter, which they need<br>
- because the interpreter context is where the name table is stored.<br>
-<br>
- The problem with the existing usage is that we were supplying the<br>
- device's memory_t pointer. However, if the halftone or colour space had<br>
- been created by a different interpreter to the device (which can happen<br>
- if we are running the PDF interpreter inside the PostScript interpreter)<br>
- then the interpreter context would be incorrect.<br>
-<br>
- We can solve this easily enough by using the colour space or halftone<br>
- memory pointer. This is much safer since we can reasonably assume that<br>
- the interpreter which created the object is the same one which stored<br>
- the colour name in its name table.<br>
-<br>
-base/gsncdummy.c<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-10 10:38: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=825d6807a72b68a2faf11fc37f89b1b75967d727">825d6807a72b68a2faf11fc37f89b1b75967d727</a>
-<blockquote>
-<p>
- Bug 702476: Don't rely on null terminated strings<br>
-<br>
- gs strings are not necessarily null terminted (especially so when created by the<br>
- Postscript interpreter). So, when parsing a file name and deciding whether it's<br>
- a &quot;device&quot; (e.g. &quot;%ram%&quot;) or a device + file name/path, don't rely on the string<br>
- being null terminate.<br>
-<br>
-base/gsfname.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-08 09:25:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0ae681ab1fd3475995418d00da1ccfe374f069cc">0ae681ab1fd3475995418d00da1ccfe374f069cc</a>
-<blockquote>
-<p>
- oss-fuzz 22752: handle broken loca table.<br>
-<br>
- Previously, the code did not differentiate between an empty loca table, a<br>
- missing loca table and a broken loca table.<br>
-<br>
- We'll now do so and, in particular, with a broken loca table (in this case,<br>
- one with only 1 entry) we'll initialize the single entry to avoid later code<br>
- accessing unitialized memory.<br>
-<br>
-base/gstype42.c<br>
-base/gxfont42.h<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-08 14:49: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=9e85e7a9518aa19964f1f8d30d3175ef8c3b950f">9e85e7a9518aa19964f1f8d30d3175ef8c3b950f</a>
-<blockquote>
-<p>
- oss-fuzz 21643: Bounds check a pointer before accessing it.<br>
-<br>
- In this case, immediately after a buffer refill, (as is &quot;normal&quot; for gs stream<br>
- buffers) the pointers starts one byte *before* the actual buffer, the state on<br>
- reentry meant we'd drop straight to trying dereference the pointer.<br>
-<br>
- This just ensures the pointer gets moved on before we try to use it.<br>
-<br>
-base/seexec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-10 10:16:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a4edd8320a5076bb52d1be7c061910b3b78718e0">a4edd8320a5076bb52d1be7c061910b3b78718e0</a>
-<blockquote>
-<p>
- pdfwrite - don't error out on skipped images<br>
-<br>
- Bug #702471 &quot;eps to pdf OK in 9.50, but failed in 9.51 and 9.52&quot;<br>
-<br>
- Some encode filters, in this case DCTEncode, can throw an error on exit<br>
- (premature EOD) if we never write any data to them. This can happen<br>
- when pdfwrite sets up to write an image to the output file, but we<br>
- never actually write the image, because it is being 'skipped'.<br>
-<br>
- Images can be skipped because they are fully clipped out, unfortunately<br>
- we can't detect this before we execute begin_typed_image or we could<br>
- avoid a lot of setup.<br>
-<br>
- Anyway, when we get to end_image, if we skipped the image then don't<br>
- take any notice of errors when closing the filters used to write the<br>
- image data to the PDF file.<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-09 15:14:02 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d68f56e25110ba3baf03553c2d1839febc02dbdb">d68f56e25110ba3baf03553c2d1839febc02dbdb</a>
-<blockquote>
-<p>
- Add docs for missing parts of gsapi.<br>
-<br>
- Add docs for gsapi_set_param (and update the code to cope with<br>
- long/int64_t/size_t's in line with the core code).<br>
-<br>
- Add docs for path control functions.<br>
-<br>
-doc/API.htm<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/pltop.h<br>
-psi/iapi.h<br>
-psi/psapi.c<br>
-psi/psapi.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-08 20:36:34 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b9a4616cdf710c79f575adb33b331cb495461d93">b9a4616cdf710c79f575adb33b331cb495461d93</a>
-<blockquote>
-<p>
- Add documentation for gsapi_set_{stdio,poll}_with_handle.<br>
-<br>
- Missed from earlier commit.<br>
-<br>
-doc/API.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-07 09:45:57 -0700
-</strong>
-<br>ray &lt;Ray.Johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=748edd2fd75c684d63486eded71ad20254de6f4c">748edd2fd75c684d63486eded71ad20254de6f4c</a>
-<blockquote>
-<p>
- Fix Bug 702383 - Segfault due to mis-use of PostScript transparency.<br>
-<br>
- The fix for Bug 698306 fixed that case, but this case showed that the double<br>
- calls to .pushpdf14devicefilter still could cause problems. Another patch<br>
- already resolved calling transparency operations WITHOUT pushing the pdf14<br>
- device (for Bug 702327).<br>
-<br>
- Also undefine the PostScript transparency operators to (maybe) prevent<br>
- misuse if -dALLOWPSTRANSPARENCY is not specified.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-05 14:51:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=560ff82b0bc782465aa4591b2953954d7cf5608c">560ff82b0bc782465aa4591b2953954d7cf5608c</a>
-<blockquote>
-<p>
- Fix a bounds check in FAPI<br>
-<br>
- Using less than or equal to should have been less than.<br>
-<br>
- Found while investigating an oss-fuzz issue.<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-04 16:57: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=7502a26f082e71e05df33dcd1dff66655f088673">7502a26f082e71e05df33dcd1dff66655f088673</a>
-<blockquote>
-<p>
- Add documentation for OCR devices.<br>
-<br>
-doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-25 13:32:26 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb492c353084600d94877f7157840d24dd7f9301">eb492c353084600d94877f7157840d24dd7f9301</a>
-<blockquote>
-<p>
- Update lcms2mt to lcms2-2.10rc2.<br>
-<br>
-lcms2mt/AUTHORS<br>
-lcms2mt/COPYING<br>
-lcms2mt/ChangeLog<br>
-lcms2mt/Lib/MS/lcms2_fast_float_plugin.lib<br>
-lcms2mt/Lib/MS/lcms2_static.lib<br>
-lcms2mt/Lib/MS/lcms2mt_fast_float_plugin.lib<br>
-lcms2mt/Lib/MS/lcms2mt_static.lib<br>
-lcms2mt/Makefile.am<br>
-lcms2mt/Makefile.in<br>
-lcms2mt/Projects/BorlandC_5.5/lcms2mt.rc<br>
-lcms2mt/Projects/BorlandC_5.5/lcmsdll.lk<br>
-lcms2mt/Projects/VC2013/lcms2mt.rc<br>
-lcms2mt/Projects/VC2013/lcms2mt.sln<br>
-lcms2mt/Projects/VC2013/lcms2mt_DLL/lcms2mt_DLL.vcxproj<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/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/VC2019/jpegicc/jpegicc.vcxproj<br>
-lcms2mt/Projects/VC2019/jpegicc/jpegicc.vcxproj.filters<br>
-lcms2mt/Projects/VC2019/lcms2mt.rc<br>
-lcms2mt/Projects/VC2019/lcms2mt.sln<br>
-lcms2mt/Projects/VC2019/lcms2mt_DLL/lcms2mt_DLL.vcxproj<br>
-lcms2mt/Projects/VC2019/lcms2mt_DLL/lcms2mt_DLL.vcxproj.filters<br>
-lcms2mt/Projects/VC2019/lcms2mt_static/lcms2mt_static.vcxproj<br>
-lcms2mt/Projects/VC2019/lcms2mt_static/lcms2mt_static.vcxproj.filters<br>
-lcms2mt/Projects/VC2019/linkicc/linkicc.vcxproj<br>
-lcms2mt/Projects/VC2019/linkicc/linkicc.vcxproj.filters<br>
-lcms2mt/Projects/VC2019/psicc/psicc.vcxproj<br>
-lcms2mt/Projects/VC2019/psicc/psicc.vcxproj.filters<br>
-lcms2mt/Projects/VC2019/resource.h<br>
-lcms2mt/Projects/VC2019/testbed/testbed.vcxproj<br>
-lcms2mt/Projects/VC2019/testbed/testbed.vcxproj.filters<br>
-lcms2mt/Projects/VC2019/tiffdiff/tiffdiff.vcxproj<br>
-lcms2mt/Projects/VC2019/tiffdiff/tiffdiff.vcxproj.filters<br>
-lcms2mt/Projects/VC2019/tifficc/tifficc.vcxproj<br>
-lcms2mt/Projects/VC2019/tifficc/tifficc.vcxproj.filters<br>
-lcms2mt/Projects/VC2019/transicc/transicc.vcxproj<br>
-lcms2mt/Projects/VC2019/transicc/transicc.vcxproj.filters<br>
-lcms2mt/Projects/cppcheck/lcms2mt.cppcheck<br>
-lcms2mt/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.pbxproj<br>
-lcms2mt/README.1ST<br>
-lcms2mt/aclocal.m4<br>
-lcms2mt/config.guess<br>
-lcms2mt/configure<br>
-lcms2mt/configure.ac<br>
-lcms2mt/doc/LittleCMS2.10 API.pdf<br>
-lcms2mt/doc/LittleCMS2.10 Plugin API.pdf<br>
-lcms2mt/doc/LittleCMS2.10 tutorial.pdf<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/include/Makefile.in<br>
-lcms2mt/include/lcms2mt.h<br>
-lcms2mt/include/lcms2mt_plugin.h<br>
-lcms2mt/plugins/README.1ST<br>
-lcms2mt/plugins/fast_float/COPYING.GPL3<br>
-lcms2mt/plugins/fast_float/Makefile<br>
-lcms2mt/plugins/fast_float/Projects/VC2019/lcms2mt_fast_float_plugin.vcxproj<br>
-lcms2mt/plugins/fast_float/Projects/VC2019/lcms2mt_fast_float_plugin.vcxproj.filters<br>
-lcms2mt/plugins/fast_float/Projects/VC2019/lcms2mt_fast_float_plugin.vcxproj.user<br>
-lcms2mt/plugins/fast_float/Projects/VC2019/lcms2mt_fast_float_plugin_testbed.vcxproj<br>
-lcms2mt/plugins/fast_float/Projects/VC2019/lcms2mt_fast_float_plugin_testbed.vcxproj.filters<br>
-lcms2mt/plugins/fast_float/Projects/VC2019/lcms2mt_fast_float_plugin_testbed.vcxproj.user<br>
-lcms2mt/plugins/fast_float/doc/LittleCMS fast float extensions 1.0.pdf<br>
-lcms2mt/plugins/fast_float/include/Makefile.am<br>
-lcms2mt/plugins/fast_float/include/lcms2mt_fast_float.h<br>
-lcms2mt/plugins/fast_float/src/Makefile.am<br>
-lcms2mt/plugins/fast_float/src/fast_16_tethra.c<br>
-lcms2mt/plugins/fast_float/src/fast_8_curves.c<br>
-lcms2mt/plugins/fast_float/src/fast_8_matsh.c<br>
-lcms2mt/plugins/fast_float/src/fast_8_tethra.c<br>
-lcms2mt/plugins/fast_float/src/fast_float_15bits.c<br>
-lcms2mt/plugins/fast_float/src/fast_float_15mats.c<br>
-lcms2mt/plugins/fast_float/src/fast_float_cmyk.c<br>
-lcms2mt/plugins/fast_float/src/fast_float_curves.c<br>
-lcms2mt/plugins/fast_float/src/fast_float_internal.h<br>
-lcms2mt/plugins/fast_float/src/fast_float_matsh.c<br>
-lcms2mt/plugins/fast_float/src/fast_float_separate.c<br>
-lcms2mt/plugins/fast_float/src/fast_float_sup.c<br>
-lcms2mt/plugins/fast_float/src/fast_float_tethra.c<br>
-lcms2mt/plugins/fast_float/testbed/Makefile.am<br>
-lcms2mt/plugins/fast_float/testbed/fast_float_testbed.c<br>
-lcms2mt/plugins/fast_float/testbed/test0.icc<br>
-lcms2mt/plugins/fast_float/testbed/test1.icc<br>
-lcms2mt/plugins/fast_float/testbed/test2.icc<br>
-lcms2mt/plugins/fast_float/testbed/test3.icc<br>
-lcms2mt/plugins/fast_float/testbed/test5.icc<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/lcms2_internal.h<br>
-lcms2mt/src/lcms2mt.def<br>
-lcms2mt/testbed/Makefile.am<br>
-lcms2mt/testbed/Makefile.in<br>
-lcms2mt/testbed/new.icc<br>
-lcms2mt/testbed/testcms2.c<br>
-lcms2mt/testbed/testcms2.h<br>
-lcms2mt/testbed/testplugin.c<br>
-lcms2mt/testbed/zoo_icc.c<br>
-lcms2mt/utils/common/utils.h<br>
-lcms2mt/utils/common/vprf.c<br>
-lcms2mt/utils/jpgicc/Makefile.am<br>
-lcms2mt/utils/jpgicc/Makefile.in<br>
-lcms2mt/utils/jpgicc/jpgicc.c<br>
-lcms2mt/utils/linkicc/Makefile.am<br>
-lcms2mt/utils/linkicc/Makefile.in<br>
-lcms2mt/utils/linkicc/linkicc.c<br>
-lcms2mt/utils/psicc/Makefile.am<br>
-lcms2mt/utils/psicc/Makefile.in<br>
-lcms2mt/utils/psicc/psicc.c<br>
-lcms2mt/utils/samples/Makefile.am<br>
-lcms2mt/utils/tificc/Makefile.am<br>
-lcms2mt/utils/tificc/Makefile.in<br>
-lcms2mt/utils/tificc/tifdiff.c<br>
-lcms2mt/utils/tificc/tificc.c<br>
-lcms2mt/utils/transicc/Makefile.am<br>
-lcms2mt/utils/transicc/Makefile.in<br>
-lcms2mt/utils/transicc/transicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-03 19:41: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=a83716a1657df0a63aafa6582f47a93315aa61a6">a83716a1657df0a63aafa6582f47a93315aa61a6</a>
-<blockquote>
-<p>
- Add skew detection/correction to downscaler.<br>
-<br>
-base/cal.mak<br>
-base/gxdownscale.c<br>
-base/gxdownscale.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-04 14:21:24 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7867660a69bcc8624f0524ab56d86001d79e5b8d">7867660a69bcc8624f0524ab56d86001d79e5b8d</a>
-<blockquote>
-<p>
- Update doc/gdevds32.c to track updated downscaler API.<br>
-<br>
-doc/gdevds32.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-04 13:20: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=1db215120db50db418b199ff364e17feba681f14">1db215120db50db418b199ff364e17feba681f14</a>
-<blockquote>
-<p>
- Fix a couple of benign compiler warnings<br>
-<br>
- Firstly a missing include file.<br>
-<br>
- Secondly we were using a utility function from pdfwrite, and obviously<br>
- not including the .h file. We really shouldn't be hauling in bits of<br>
- pdfwrite, so instead duplicate the (miniscule) bit of functionality we<br>
- want.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-25 17:36: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=278f9a53ed507f9109380ee4210fb860b35b1811">278f9a53ed507f9109380ee4210fb860b35b1811</a>
-<blockquote>
-<p>
- txtwrite - better processing of text in type 3 fonts<br>
-<br>
- Previously we were not able to accumulate the widths of text in a type<br>
- 3 font. This code leverages (again) off the code in pdfwrite to exit<br>
- to the interpreter, run the type 3 CharProc, and pick up the glyph<br>
- advance width in setcachedevice.<br>
-<br>
- This gives us better output for type 3 fonts, as we no longer<br>
- think that consecutive text is in the same position.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-03 16:54: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=feee7e6afd34ff3c1fa0c30ec024be25f1a61c1e">feee7e6afd34ff3c1fa0c30ec024be25f1a61c1e</a>
-<blockquote>
-<p>
- Rework downscaler initialisation.<br>
-<br>
- Pass the downscaler parameters into the downscaler init routines,<br>
- rather than explicit values.<br>
-<br>
- This reduces the size of the API, and means that future additions<br>
- to the structure will automatically be passed through.<br>
-<br>
-base/gxdownscale.c<br>
-base/gxdownscale.h<br>
-devices/gdevchameleon.c<br>
-devices/gdevjpeg.c<br>
-devices/gdevocr.c<br>
-devices/gdevpdfimg.c<br>
-devices/gdevpng.c<br>
-devices/gdevpsd.c<br>
-devices/gdevtifs.c<br>
-devices/gdevtifs.h<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-24 14:13:39 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7322ef87546c55b29056c1d96d8bdbb7f3ba53ef">7322ef87546c55b29056c1d96d8bdbb7f3ba53ef</a>
-<blockquote>
-<p>
- Tesseract based OCR devices.<br>
-<br>
- pdfocr8/24/32, ocr and hocr devices.<br>
-<br>
- Use OCRLanguage to set languages to use (&quot;eng&quot; by default).<br>
-<br>
-Makefile.in<br>
-base/endianness.h<br>
-base/gsiorom.c<br>
-base/gxiodev.h<br>
-base/leptonica.mak<br>
-base/lib.mak<br>
-base/msvccmd.mak<br>
-base/ocr.mak<br>
-base/tess_version.h<br>
-base/tesseract.mak<br>
-base/tessocr.cpp<br>
-base/tessocr.h<br>
-base/unix-gcc.mak<br>
-base/winlib.mak<br>
-configure.ac<br>
-devices/devs.mak<br>
-devices/gdevocr.c<br>
-devices/gdevpdfimg.c<br>
-devices/gdevpdfimg.h<br>
-devices/gdevpdfocr.c<br>
-psi/msvc.mak<br>
-windows/ghostscript.vcxproj<br>
-windows/ghostscript.vcxproj.filters<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-03 18:32:56 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ff02973645a9aff2caf1bcd3032f119995e0d63f">ff02973645a9aff2caf1bcd3032f119995e0d63f</a>
-<blockquote>
-<p>
- Fix coverity 359151.<br>
-<br>
- Check ds-&gt;dev is non NULL before dereferencing it.<br>
-<br>
-base/gxdownscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-02 19:24:50 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=89f3dba59d801dd7c586d81d996ea8d641e1018a">89f3dba59d801dd7c586d81d996ea8d641e1018a</a>
-<blockquote>
-<p>
- Add yet another version of nmake to makefile.<br>
-<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-02 19:23:30 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=df31667a82d8320d25c15f9eaf14fbb33a4ba0a1">df31667a82d8320d25c15f9eaf14fbb33a4ba0a1</a>
-<blockquote>
-<p>
- Bug 702446: Fix CAL halftoning.<br>
-<br>
- Looks like cal was interpretting halftone X phase in the wrong<br>
- direction.<br>
-<br>
-base/gximono.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-02 12:09:53 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0006f8715f5f5d83a7823dc9f41c76a1bdf9b0f7">0006f8715f5f5d83a7823dc9f41c76a1bdf9b0f7</a>
-<blockquote>
-<p>
- Add lcms2mt files into build_bmpcmp.sh<br>
-<br>
-toolbin/build_bmpcmp.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-02 11:59:44 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b9916ac2feec23b6c91e4c5d425dde0a73b1462d">b9916ac2feec23b6c91e4c5d425dde0a73b1462d</a>
-<blockquote>
-<p>
- Add missing line feeds on error messages in bmpcmp<br>
-<br>
-toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-06-01 22:47:36 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e3bbb3b93bcdade889b36641508f25929968089e">e3bbb3b93bcdade889b36641508f25929968089e</a>
-<blockquote>
-<p>
- Add CIELAB comparison to bmpcmp<br>
-<br>
- Adding the option -l will perform the difference in CIELAB<br>
- color space, provided the application was built with a CMM and<br>
- the source files were tiff files that had embedded ICC profiles.<br>
-<br>
- It is necessary to use a threshold &gt; 0 and a window &gt; 1.<br>
-<br>
- The threshold should be interpreted as dE^2 (a Euclidean norm squared<br>
- term is used as opposed to the L infinity norm used for the other<br>
- color spaces)<br>
-<br>
- As a rule of thumb, dE^2 = 9 is barely noticeable in a side by side<br>
- solid color. Colors in complex images are going to require a larger<br>
- threshold.<br>
-<br>
- This adds lcms2mt to the visual studio project. COLOR_MANAGED<br>
-<br>
-toolbin/bmpcmp.c<br>
-toolbin/bmpcmp.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-29 17:30:45 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb9959b60a9b3947c091ab867616385ac3fc7794">bb9959b60a9b3947c091ab867616385ac3fc7794</a>
-<blockquote>
-<p>
- Refactor downscaler.<br>
-<br>
- Originally the downscaler would just get the bits it wanted from<br>
- either get_bits or get_bits_rectangle.<br>
-<br>
- Then we extended the downscaler to integrate ClapTrap, which means<br>
- it may have to get its scanlines from that. This was done hackily.<br>
-<br>
- Now, we are pondering integrating scan/skew, which means there will<br>
- be a third possible source, and they might be used in different<br>
- combinations.<br>
-<br>
- To simplify everything we introduce a &quot;gx_downscaler_liner&quot; mechanism<br>
- which wraps up getting a single line of data, and move to using<br>
- that everywhere. Adding scan/skew should then plug in using this<br>
- much more neatly.<br>
-<br>
-base/gxdownscale.c<br>
-base/gxdownscale.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-29 17:22:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba2fdf5517af3bcd8a613fda84c532307d1e7024">ba2fdf5517af3bcd8a613fda84c532307d1e7024</a>
-<blockquote>
-<p>
- Fix memory leaks in tiffsep.<br>
-<br>
- Calling TIFFCleanup doesn't close the underlying tiffio. Call<br>
- TIFFClose instead.<br>
-<br>
- Now the tiff io close handler is actually called, be careful<br>
- not to close the underlying file twice.<br>
-<br>
- Finally, actually remember to close the comp file.<br>
-<br>
-base/gstiffio.c<br>
-devices/gdevtifs.c<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-29 17:16:00 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=052a91b91d3d339dca3ce69bcb81faee9b8ff647">052a91b91d3d339dca3ce69bcb81faee9b8ff647</a>
-<blockquote>
-<p>
- Claptrap: Fix us overrunning components in the planar case.<br>
-<br>
-base/claptrap-planar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-30 19:38: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=2e4f5bdc708eaceecbce264184bc31f9b5fec107">2e4f5bdc708eaceecbce264184bc31f9b5fec107</a>
-<blockquote>
-<p>
- Coverity ID 359131 and 359130<br>
-<br>
- Remove some dead code after the commit which removed the ancient<br>
- Acrobat 4 &amp; 5 compatibility hacks.<br>
-<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-27 11:50:08 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a608d40b2d6d4a062857e23060c243a4b10aac69">a608d40b2d6d4a062857e23060c243a4b10aac69</a>
-<blockquote>
-<p>
- Hacky fix for Memento leak in pcl_execute_macro().<br>
-<br>
- Fixes the six remaining leaks after prev commit in:<br>
- MEMENTO_FAILAT=15796 ./ghostpdl/membin/gpcl6 -sDEVICE=pbmraw -o /dev/null tests_private/pcl/pcl5cfts/fts.2180<br>
-<br>
-pcl/pcl/pcmacros.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-29 16:19:46 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be333874ffd55024ce640bf8d4347dabff162be1">be333874ffd55024ce640bf8d4347dabff162be1</a>
-<blockquote>
-<p>
- Improvements to pcl_do_resets().<br>
-<br>
- From Henry; we now do pcl_reset_permanent on all items if we get an error.<br>
-<br>
- This fixes all but 6 of the memento leaks in:<br>
- MEMENTO_FAILAT=15796 ./ghostpdl/membin/gpcl6 -sDEVICE=pbmraw -o /dev/null tests_private/pcl/pcl5cfts/fts.2180<br>
-<br>
-pcl/pcl/pcommand.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-28 13:07: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=3156b0aa8ac4e9ef440c169799658da249eb41c9">3156b0aa8ac4e9ef440c169799658da249eb41c9</a>
-<blockquote>
-<p>
- pdfwrite - remove Acrobat 4 &amp; 5 work arounds<br>
-<br>
- Acrobat 4 had a limit of around =/- 16,320 on real numbers (despite the<br>
- reference stating it was +/- 32,7670, Acrobat 5 had a limit of 32,767.<br>
- These are implementation limits, not architectural limits, and since<br>
- co-ordinates are expressed as real numbers they place limits on the<br>
- position of objects on the page.<br>
-<br>
- Its clear from Bug #702436 that the clamping used by pdfwrite is not<br>
- comprehensive; several paths are emitted that use co-ordinates outside<br>
- the permitted range.<br>
-<br>
- Since the implementation is flawed, and the newest of the 2 versions<br>
- (Acrobat 5) has been obselete for 15 years, it seems pointless to try<br>
- and improve this clamping. Instead this commit removes it entirely.<br>
-<br>
- This removes a number of places where we test values and do some<br>
- multiplication, so there should be a (probably immeasurable) performance<br>
- gain from this. In addition the accuracy should be (very slightly)<br>
- improved because there should be less problems with rounding errors.<br>
-<br>
- This causes a large number of files to demonstrate single pixel shifts<br>
- of a few glyphs, due to changes in rounding. In general these are very<br>
- minor progressions, though a few could be seen to be equally minor<br>
- regressions. Since these mostly (and in the case of regressions,<br>
- entirely) occur at low resolution I believe this is acceptable.<br>
-<br>
- One file, Bug694385, when sent to ps2write, exhibits a marked<br>
- progression. This is because the clamping wasn't limited to the pdfwrite<br>
- device, even though it was inappropriate to limit the ps2write output<br>
- this way. A good deal of content is now included, where it was previously<br>
- elided.<br>
-<br>
-devices/vector/gdevpdfd.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdfx.h<br>
-devices/vector/gdevpdts.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-27 16:53: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=f8a0afa4029b33d3174a31fd562a0102644c9c9e">f8a0afa4029b33d3174a31fd562a0102644c9c9e</a>
-<blockquote>
-<p>
- pdfwrite - fix clamping for Acrobat 4 and 5 limits<br>
-<br>
- Bug #702436 &quot;With -dCompatibilityLevel=1.4, gs -sDEVICE=pdfwrite corrupts the contents&quot;<br>
-<br>
- This isn't 'corruption'. Acrobat 4 and 5 have some serious limitations<br>
- on the maximum value a real number can take. Since co-ordinates are real<br>
- numbers this limits the area which can be addressed on the media.<br>
-<br>
- The example file is very large and, using the default resolution of 720<br>
- dpi, some of the content has co-ordinates outside the region which can<br>
- be addressed by old versions of Acrobat.<br>
-<br>
- In practice we can see that many parts of our output no longer limit<br>
- themselves to these values anyway, so we shjould remove this archaic<br>
- limitation.<br>
-<br>
- In the meantime we can work around this specific case by noting that the<br>
- clip is rectangular, and will be emitted as a 're' operation, so<br>
- clamping all 4 co-ordinates is inappropriate. We need to clamp the llx<br>
- and lly co-ordinates, but then its the width and height we need to limit<br>
- rather than the urx and ury co-ordinates.<br>
-<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-26 18: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=b53ad834b8cddfc55e2297e3d34ff834926a25ff">b53ad834b8cddfc55e2297e3d34ff834926a25ff</a>
-<blockquote>
-<p>
- documentation - update man/ps2pdf.1<br>
-<br>
- Replace reference to ps2pdf.htm with VectorDevices.htm<br>
-<br>
-man/ps2pdf.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-26 13:04:09 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6667495f56bc670322f607de419fe7e48434d3c6">6667495f56bc670322f607de419fe7e48434d3c6</a>
-<blockquote>
-<p>
- Fix memento leak in hpgl_process_buffer().<br>
-<br>
- The fix is to make hpgl_free_stick_fonts() call<br>
- pl_font_glyph_width_cache_remove_nodes().<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=22007 ./ghostpdl/membin/gpcl6 -sDEVICE=pbmraw -o /dev/null tests_private/pcl/pcl5cfts/fts.1640<br>
-<br>
- Also fixes many later leaks.<br>
-<br>
-pcl/pcl/pglabel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-25 18:41:24 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e8dd08e6c9e721c993d28bb36e107f81d16ce0a">1e8dd08e6c9e721c993d28bb36e107f81d16ce0a</a>
-<blockquote>
-<p>
- Fix leak after error in accum_fill_rectangle()<br>
-<br>
- Fixes:<br>
- ./ghostpdl/membin/gpcl6 -sDEVICE=pbmraw -o /dev/null tests_private/pcl/pcl5cfts/fts.1552<br>
-<br>
-base/gxacpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-25 11:59:52 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=776cf430dd1a96a7da33c0d33af9a6dd42bffec0">776cf430dd1a96a7da33c0d33af9a6dd42bffec0</a>
-<blockquote>
-<p>
- Fix memory leak on error in bitmap_paint() and its callers.<br>
-<br>
- Previously, bitmap_paint() would free its 'gs_image_enum * pen' arg, but caller<br>
- image_PaintProc() could also attempt to free this in one error path.<br>
-<br>
- So have changed bitmap_paint() to only free what it allocates - call<br>
- gs_image_cleanup() instead of gs_image_cleanup_and_free_enum(); and patched<br>
- its two callers, mask_PaintProc() and image_PaintProc(), to add calls to<br>
- gs_free_object(pen).<br>
-<br>
- Fixes leak in:<br>
- MEMENTO_FAILAT=15601 ./ghostpdl/membin/gpcl6 -sDEVICE=pbmraw -o /dev/null tests_private/pcl/pcl5cfts/fts.0954<br>
-<br>
-base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-25 11:59:19 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=815cbc244257f224eca799413ee64b17b62ffb4a">815cbc244257f224eca799413ee64b17b62ffb4a</a>
-<blockquote>
-<p>
- Fix error handling in image_render_interpolate_icc().<br>
-<br>
- Need to return gs_error_VMerror if gs_alloc_bytes() returns NULL.<br>
-<br>
- Fixes segv in:<br>
- MEMENTO_FAILAT=15601 ./ghostpdl/membin/gpcl6 -sDEVICE=pbmraw -o /dev/null tests_private/pcl/pcl5cfts/fts.0954<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-22 08:26:34 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3227677f842a1060d29acc53465c6a9c76f7d48b">3227677f842a1060d29acc53465c6a9c76f7d48b</a>
-<blockquote>
-<p>
- Fix Bug702327: PS transparency operations before PUSH_DEVICE causes problems.<br>
-<br>
- Add check to make sure PUSH_DEVICE is the first pdf14 compositor action<br>
- before allowing any other operation for page mode and clist mode.<br>
-<br>
-base/gdevp14.c<br>
-base/gxclist.c<br>
-base/gxclist.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-23 14:16:51 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b4310ff9719fdafb840972649a4eb94a88165e66">b4310ff9719fdafb840972649a4eb94a88165e66</a>
-<blockquote>
-<p>
- ps2write - ignore (most) text rendering modes with type 3 fonts<br>
-<br>
- Bug #702233 &quot;ps2 stroked text mitre problem&quot;<br>
-<br>
- The PDF specification says that Tr (text rendering modes) are not<br>
- applied to type 3 fonts.<br>
-<br>
- The PDF interpreter normally caters for this by not converting the<br>
- glyphs to paths and applying the operation(s) but simply rendering the<br>
- text.<br>
-<br>
- However, when the destination is pdfwrite or ps2write, we don't apply<br>
- the text rendering mode operations, we simply leave it up to the device<br>
- to deal with. Ordinarily this works well, but ps2write had no provision<br>
- for the special handling of type 3 fonts, and so was applying the text<br>
- rendering mode to those fonts too, resulting in incorrect output.<br>
-<br>
- This commit adds code to the PostScript output of ps2write; this checks<br>
- the font type and does not apply the text rendering mode if the font<br>
- type is 3. With one exception; if the text rendering mode is 3 (neither<br>
- stroke nor fill) then we *do* apply it, because Acrobat does and if we<br>
- don't apply it then we draw text that Acrobat does not.<br>
-<br>
-devices/vector/opdfread.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-22 11:25:43 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d3ca982177aff19331b72a226664e281feede2c">4d3ca982177aff19331b72a226664e281feede2c</a>
-<blockquote>
-<p>
- Fix tiff bmpcmp to organize image data upside right for windows<br>
-<br>
-toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-22 13:38:23 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e1354dbd1cfc7692b7559a3f4c7f86900e513edc">e1354dbd1cfc7692b7559a3f4c7f86900e513edc</a>
-<blockquote>
-<p>
- Bug 702431: Don't cast a unsigned long to an unsigned int<br>
-<br>
- When allocating the pixmap for a display device, we were casting the unsigned<br>
- long bitmap size to an unsigned int, meaning on LP64 (where a long is 64 bits)<br>
- we could end up truncating the value.<br>
-<br>
- Change it to cast to a size_t.<br>
-<br>
- Ultimately, we'll want to change the display device structure to store a size_t<br>
- rather than unsigned long, but that will mean changing the display device's<br>
- public API.<br>
-<br>
-devices/gdevdsp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-21 11:12:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b4cda2ee4cbdf045e05b9832fd93f6a1a5cc3bb6">b4cda2ee4cbdf045e05b9832fd93f6a1a5cc3bb6</a>
-<blockquote>
-<p>
- Remove the last of TURBO C support.<br>
-<br>
- Most of the TURBO C support went away years ago, and we've had no complaints,<br>
- so remove the rest.<br>
-<br>
-base/malloc_.h<br>
-base/memory_.h<br>
-base/stdpre.h<br>
-psi/store.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-22 14:24: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=7d6d69ff17c43664482fe0dc34676a46ba551d93">7d6d69ff17c43664482fe0dc34676a46ba551d93</a>
-<blockquote>
-<p>
- pdfwrite - rewrite the PSPageOptions code to use non-GC memory<br>
-<br>
- Bug #702370 &quot;PSPageOption injecting unwanted characters&quot;<br>
-<br>
- As Peter rightly comments in the bug this is due to the contents of the<br>
- param_string_array not being enumerated when the array pointer is<br>
- enumerated.<br>
-<br>
- This seems to be a general problem, but we seem to get away with it for<br>
- NeverEmbed and AlwaysEmbed (which are handled in a much more complex<br>
- fashion) so I've chosen to leave those alone for now.<br>
-<br>
- For PSPageOptions this commit creates a new gs_param_string_array and<br>
- new strings for each of the strings in the param_list. These are<br>
- allocated in non-GC memory and the pdfwrite device has complete control<br>
- over their lifetime now.<br>
-<br>
- We no longer numerate the member for GC (because it should not be GC'ed)<br>
- and we free the array and its contents when we close the device.<br>
-<br>
- This resolves the problem for me.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpsdf.h<br>
-devices/vector/gdevpsdp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-21 16:24:41 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=548fa474def31ddeb2864554ad0698bd53b13ea0">548fa474def31ddeb2864554ad0698bd53b13ea0</a>
-<blockquote>
-<p>
- Add shell script to build bmpcmp with tiff and png support<br>
-<br>
-toolbin/build_bmpcmp.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-20 18:15:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6955a325826e84c77723bab03046c801930801df">6955a325826e84c77723bab03046c801930801df</a>
-<blockquote>
-<p>
- Extend gsapi interface with _with_handle variants for callbacks.<br>
-<br>
- This allows us to specify specific caller_handles for each<br>
- callback type rather than using a default one specified at<br>
- gs instance creation time. The old functions still work.<br>
-<br>
-base/gp_mspol.c<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-base/strmio.c<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-psi/gsdll2.def<br>
-psi/gsdll32.def<br>
-psi/gsdll32metro.def<br>
-psi/gsdll64.def<br>
-psi/gsdll64metro.def<br>
-psi/gsdllARM32metro.def<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-psi/psapi.c<br>
-psi/ziodevsc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-21 08:21: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=b0d2c264eb53c1838957151f1e18abfd1f17dd54">b0d2c264eb53c1838957151f1e18abfd1f17dd54</a>
-<blockquote>
-<p>
- Bug 702225(pt2): Check fontconfig is new enough.<br>
-<br>
- Turns out FC_VARIABLE is a fairly new addition to fontconfig's search<br>
- parameters (&lt;= 2.12.6 doesn't have it &gt;=2.13.1 does), so add preprocessor<br>
- conditions so we'll only use when fontconfig is new enough.<br>
-<br>
-base/gp_unix.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-20 16:23:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=627942b74af81c1b9b76b07dba6e4ce6234a4ab6">627942b74af81c1b9b76b07dba6e4ce6234a4ab6</a>
-<blockquote>
-<p>
- Fix the Windows top makefile when using UFST<br>
-<br>
- If the user chose to specify the build flags for using UFST directly on the<br>
- nmake command line (rather than using the predefined UFST build target), we'd<br>
- end up disabling Freetype, which has not been supported for some time.<br>
-<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-20 15:17:10 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=619e7f46c9c760879409f9efaa4b3e798986538e">619e7f46c9c760879409f9efaa4b3e798986538e</a>
-<blockquote>
-<p>
- lgtm.com fixes: float * float -&gt; double.<br>
-<br>
- Make casting explicit. Ideally we'd cast one of the floats to a<br>
- double to start with, so the multiplication happens in doubles,<br>
- but that produces lots of diffs.<br>
-<br>
-base/gspaint.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-20 11:39:08 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e27d7babcbbbee07fe9c458228d941ce3b4f8890">e27d7babcbbbee07fe9c458228d941ce3b4f8890</a>
-<blockquote>
-<p>
- Fix typo introduced in copy/paste<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-19 12:18:29 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c9142412c3ec52e2fcb42053706352a9ee5d9a74">c9142412c3ec52e2fcb42053706352a9ee5d9a74</a>
-<blockquote>
-<p>
- Add tiff to bmpcmp<br>
-<br>
- This upgrades the VS solution to 2019 for the bmpcmp project. Fixes a couple<br>
- minor issues that existed with some of the project configurations and add<br>
- tiff support.<br>
-<br>
-toolbin/bmpcmp.c<br>
-toolbin/bmpcmp.sln<br>
-toolbin/bmpcmp.vcproj<br>
-toolbin/bmpcmp.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-20 14:45: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=cf15813c35a75067e828608c665dae30999f8dd5">cf15813c35a75067e828608c665dae30999f8dd5</a>
-<blockquote>
-<p>
- Update Acrobat2Tiff to VS2019<br>
-<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff.sln<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff.vb<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff.vbproj<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Application.Designer.vb<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Resources.Designer.vb<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Settings.Designer.vb<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-20 16:02: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=8c7bd787defa071c96289b7da9397f673fddb874">8c7bd787defa071c96289b7da9397f673fddb874</a>
-<blockquote>
-<p>
- txtwrite - address memory problems<br>
-<br>
- Bug #702229 &quot; txtwrite: use after free in 9.51 on some files (regression from 9.50)&quot;<br>
- Also bug #702346 and the earlier report #701877.<br>
-<br>
- The problems occur because its possible for a single character code in<br>
- a PDF file to map to more than a single Unicode code point. In the case<br>
- of the file for 701877 the character code maps to 'f' and 'i' (it is an<br>
- fi ligature).<br>
-<br>
- The code should deal with this, but we need to ensure we are using the<br>
- correct index. In addition, if we do get more Unicode code points than<br>
- we expected, we need to set the widths of the 'extra' code points to<br>
- zero (we only want to consider the width of the original character).<br>
-<br>
- This does mean increasing the size of the Widths array to cater for<br>
- the possibility of more entries on output than there were on input.<br>
-<br>
- While working on it I noticed that the Unicode remapping on little-<br>
- endian machines was reversing the order of the Unicode values, when<br>
- there was more than a single code point returned, so fixed that at<br>
- the same time.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-20 12:44:45 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be741930a01176ba8cfea1310866a1a1c69fa71c">be741930a01176ba8cfea1310866a1a1c69fa71c</a>
-<blockquote>
-<p>
- Add yet another nmake version to the MSVC makefile.<br>
-<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-20 11:23:18 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a10a03a4c9713b38c4cfcd07f0ba3c722778aae0">a10a03a4c9713b38c4cfcd07f0ba3c722778aae0</a>
-<blockquote>
-<p>
- Rejig plftable.h<br>
-<br>
- Rather than repeatedly including the same header to get multiple<br>
- versions of the font table built in, build the font table just<br>
- once with all the information in it.<br>
-<br>
- This should be smaller (fractionally), and stop lgtm.com complaining.<br>
-<br>
-pcl/pcl/pcfontpg.c<br>
-pcl/pcl/pcfsel.c<br>
-pcl/pl/plftable.c<br>
-pcl/pl/plftable.h<br>
-pcl/pl/pllfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-20 12:15:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ffbaace78bacb0421ae11c5a8fdef51cbd829218">ffbaace78bacb0421ae11c5a8fdef51cbd829218</a>
-<blockquote>
-<p>
- Tweak fapiufst code to build with UFST 7.1.x<br>
-<br>
-base/fapiufst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-19 16:20: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=7e7fa21f9e378303df8d8529cc3a94676e433f40">7e7fa21f9e378303df8d8529cc3a94676e433f40</a>
-<blockquote>
-<p>
- Exclude &quot;variable fonts&quot; from fontconfig search<br>
-<br>
- Since we cannot used (and later skip over errors caused by) TTF variable<br>
- fonts (a sort of illigitimate offspring of Multiple Master and TTF!) we<br>
- may as well filter them out of our fontconfig search criteria.<br>
-<br>
- Patch suggested by zdohnal@redhat.com<br>
-<br>
-base/gp_unix.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-19 18:43:48 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9f1b19d0634ad611dc73a8c05c13c88f42cb8730">9f1b19d0634ad611dc73a8c05c13c88f42cb8730</a>
-<blockquote>
-<p>
- lgtm fixes: float * float -&gt; double<br>
-<br>
- When we do float * float, and then use the result in a context<br>
- where a double is expected, we implicitly cast the result of the<br>
- multiplication to be a double. This means we can overflow<br>
- the range of floats during the initial multiplication, when the<br>
- result would quite easily fit into a float.<br>
-<br>
- It's better to cast to double to start with, then do the<br>
- multiplication (at the cost of potentially being slower - but<br>
- not really that much slower these days).<br>
-<br>
- In some cases I've opted NOT to change the operations (merely to<br>
- make the casting explicit) so as to minimise diffs.<br>
-<br>
-base/gdevp14.c<br>
-base/gshtscr.c<br>
-base/gxshade.c<br>
-base/gxstroke.c<br>
-pcl/pxl/pxpaint.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-19 19:45: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=173e301c9908cf4656c462a89a146f7f1f5664f8">173e301c9908cf4656c462a89a146f7f1f5664f8</a>
-<blockquote>
-<p>
- Fix &quot;integer constant overflow&quot; warning.<br>
-<br>
-base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-18 13:16: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=ef0bc2a843783af2e5d76dadf801063ab6c785ef">ef0bc2a843783af2e5d76dadf801063ab6c785ef</a>
-<blockquote>
-<p>
- Improve font copying for new PDF interpeter with pdfwrite<br>
-<br>
- Since this commit:<br>
-<br>
- http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=12c071547d<br>
-<br>
- The 'copied font' stored by pdfwrite has maintained a pointer to the<br>
- interpreter's 'dir' (FontDirectory) and used it to mark the names in<br>
- the interpreter name table during GC pointer enumeration.<br>
-<br>
- This doesn't work if the interpreter is pdfi and its working inside<br>
- the Ghostscript PostScript interpreter, because the enumeration can<br>
- take place after the pdfi interpreter has been destroyed. Its also not<br>
- necessary in this case, because the pdfi name table can't be relocated.<br>
-<br>
- But for complex reasons (see the lengthy comment in the code) it has a<br>
- small but useful benefit when pdfwrite is being driven directly by the<br>
- PostScript interpreter.<br>
-<br>
- In order to avoid losing that benefit, we now only store a pointer to<br>
- the interpreter's 'dir' member, and only mark the names during<br>
- enumeration, if the memory allocator of the font is a garbage-collecting<br>
- allocator.<br>
-<br>
-devices/gxfcopy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-18 13:20:10 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=63df5adcad39572f94a0448c09598641c89f58db">63df5adcad39572f94a0448c09598641c89f58db</a>
-<blockquote>
-<p>
- lgtm.com fix: int * int may overflow before being converted to size_t.<br>
-<br>
-base/gxdownscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-15 13:06:19 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c170fa2fc7dfe79dced44d7b628129e5bc7dd045">c170fa2fc7dfe79dced44d7b628129e5bc7dd045</a>
-<blockquote>
-<p>
- lgtm.com fixes: Don't define external functions in local scope.<br>
-<br>
-base/gxpcmap.c<br>
-pcl/pxl/pxfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-15 12:54:35 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f8529a27e1c1768bd79ff19dfa7a29790ce9e275">f8529a27e1c1768bd79ff19dfa7a29790ce9e275</a>
-<blockquote>
-<p>
- lgtm.com: Add comment to empty conditional block to stop warning.<br>
-<br>
-base/mkromfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-15 12:36:00 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=53b712ea02903910a19980b28fbf8ae6fc5bdade">53b712ea02903910a19980b28fbf8ae6fc5bdade</a>
-<blockquote>
-<p>
- lgtm.com fixes: Avoid shadowing params with local vars.<br>
-<br>
-base/ets.c<br>
-base/gdevmem.c<br>
-base/gsfcmap1.c<br>
-pcl/pcl/rtraster.c<br>
-pcl/pl/pjparse.c<br>
-psi/imain.c<br>
-psi/zchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-15 11:43:13 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8d9df30a48ac272e92666d52fef62580aacabfd7">8d9df30a48ac272e92666d52fef62580aacabfd7</a>
-<blockquote>
-<p>
- Bug 702248: Spelling problem in error message.<br>
-<br>
-Resource/Init/pdf_rbld.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-15 11:48:54 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=349d37844880567be4630e07c0518f6671300fc6">349d37844880567be4630e07c0518f6671300fc6</a>
-<blockquote>
-<p>
- lgtm.com: Fix &quot;comparison is always false&quot; warning.<br>
-<br>
-psi/ziodev.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-15 11:48: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=2f768243df42031a3f37f256678e34c1ac97fdde">2f768243df42031a3f37f256678e34c1ac97fdde</a>
-<blockquote>
-<p>
- lgtm.com fixes: Multiplication of narrow type in wider context.<br>
-<br>
-base/claptrap-init.c<br>
-base/gdevdrop.c<br>
-base/gdevprn.c<br>
-base/gsfunc.c<br>
-base/gsicc_monitorcm.c<br>
-base/gxccache.c<br>
-base/gxclip2.c<br>
-base/gxclipm.c<br>
-base/gxclread.c<br>
-base/gxclrect.c<br>
-base/gxdownscale.c<br>
-base/gxfapi.c<br>
-base/gxhtbit.c<br>
-base/gxidata.c<br>
-base/gxipixel.c<br>
-base/gxshade4.c<br>
-base/sjbig2.c<br>
-base/sjbig2.h<br>
-pcl/pcl/pcsfont.c<br>
-pcl/pl/plchar.c<br>
-pcl/pxl/pximage.c<br>
-psi/zfapi.c<br>
-xps/xpsimage.c<br>
-xps/xpsjxr.c<br>
-xps/xpspng.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-14 21:00:34 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b380ebb41878645d0d7bb2b07155667acac4fa99">b380ebb41878645d0d7bb2b07155667acac4fa99</a>
-<blockquote>
-<p>
- lgtm.com fixes: Fix cases where comparisons are constant.<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevp14.c<br>
-base/gen_ordered.c<br>
-base/gscsepr.c<br>
-base/gsmisc.c<br>
-base/gstiffio.c<br>
-base/gxcmap.c<br>
-base/gxdownscale.c<br>
-base/mkromfs.c<br>
-base/ttfmain.c<br>
-pcl/pl/realmain.c<br>
-pcl/pxl/pxfont.c<br>
-pcl/pxl/pxink.c<br>
-psi/imain.c<br>
-psi/ireclaim.c<br>
-psi/iscannum.c<br>
-psi/zcolor.c<br>
-psi/zfont.c<br>
-psi/zfsample.c<br>
-psi/zfunc4.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-13 16:52:42 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d578f2517bbc6261a0cf31f8e2e88b2990241c0a">d578f2517bbc6261a0cf31f8e2e88b2990241c0a</a>
-<blockquote>
-<p>
- Fix 702400: Indeterminate SEGV due to GC confusion.<br>
-<br>
- The GC 'clump_locate' macro relied on PTR_BETWEEN (yes, also a macro)<br>
- but on Windows MSC_VER caused pointers to be compared using only the<br>
- low 32-bits (unsigned long is 32-bits on Windows, even 64-bit).<br>
-<br>
- Depending on addresses, and when the GC ran, this could result in the<br>
- GC logic being confused about addresses. This change works with 32-bit<br>
- Windows as well as 64-bit (and may not work with TURBOC on an OLD<br>
- CPU with segment+offset addresses, but so what?).<br>
-<br>
-base/stdpre.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-13 10:20:29 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d703f355af5292e61dcd641332e249873ab5fb8a">d703f355af5292e61dcd641332e249873ab5fb8a</a>
-<blockquote>
-<p>
- Bug702398 -- Fix several annotation w/no AP bugs<br>
-<br>
- 1) In the case of an annotation with no BS or Border, the code was simply<br>
- incorrect, causing an error that meant the annotation didn't render.<br>
-<br>
- 2) annotation wasn't rendering if atan got error<br>
-<br>
- Found this for a PolyLine case, but also fixed it for Line, just in case.<br>
-<br>
- 3) Fix 1st LE in Polyline<br>
-<br>
- It was calculating dx,dy backwards, so the angle was off by 180 degrees.<br>
-<br>
- 4) Set the color for PolyLine annotation<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-13 11:31:57 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d767c9e3297623e6708fe1c6dcab0583989ef63c">d767c9e3297623e6708fe1c6dcab0583989ef63c</a>
-<blockquote>
-<p>
- Assuage C++'s demands for whitespace in string literal concats.<br>
-<br>
-base/stdint_.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-11 18:05:50 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0ccf0e77b1ee8e10335c2a80ddb180c9b5a4f5b6">0ccf0e77b1ee8e10335c2a80ddb180c9b5a4f5b6</a>
-<blockquote>
-<p>
- lgtm.com fixes: Narrow multiply -&gt; wider result.<br>
-<br>
-base/gsfcmap.c<br>
-base/gxhintn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-12 13:58: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=bad9f11895cbb4c0f53b7b0ef8f3502789d81315">bad9f11895cbb4c0f53b7b0ef8f3502789d81315</a>
-<blockquote>
-<p>
- graphics library - improve gx_cpath_copy<br>
-<br>
- This function does not, currently, appear to be called from anywhere.<br>
- For the new PDF interpreter we'd like to use it to copy the clip path(s)<br>
- from the PostScript environment to the PDF environment, but there's a<br>
- problem.<br>
-<br>
- The problem is that the structures defining the list of rectangles are<br>
- allocated using the same memory allocator as the source clip path, but<br>
- when we come to free them, the destructor uses the memory allocator of<br>
- the clip list. So if the destination clip path was using a different<br>
- allocator from the source clip path, we will use the wrong allocator to<br>
- try and free the memory.<br>
-<br>
- Chris thinks this may be an attempt to cope with stack-based allocations<br>
- of the clip path where the allocator is NULL. So to cope with that<br>
- we use the existing code (allocator from the source clip path) if the<br>
- destination clip path's allocator is NULL (stack based) and we use the<br>
- destination clip path's allocator otherwise.<br>
-<br>
-base/gxcpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-11 11:08:26 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ae6b0b0e768f618728f66580227fffc92896903c">ae6b0b0e768f618728f66580227fffc92896903c</a>
-<blockquote>
-<p>
- Remove &quot;magic numbers&quot; from profile type selection<br>
-<br>
-base/gdevp14.c<br>
-base/gscms.h<br>
-base/gsequivc.c<br>
-base/gsicc.c<br>
-base/gsicc_cache.c<br>
-base/gsicc_manage.c<br>
-base/gstext.c<br>
-base/gxclthrd.c<br>
-base/gxcmap.c<br>
-base/gxiscale.c<br>
-devices/gdevjpeg.c<br>
-devices/gdevpdfimg.c<br>
-devices/gdevpng.c<br>
-devices/gdevtfnx.c<br>
-devices/gdevtifs.c<br>
-devices/gdevtsep.c<br>
-devices/vector/gdevxps.c<br>
-psi/zicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-07 10:43:54 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2bb52bc877645068977c17c8a433e5b959b51eba">2bb52bc877645068977c17c8a433e5b959b51eba</a>
-<blockquote>
-<p>
- Spot overprint in RGB Blend color spaces<br>
-<br>
- If the blending color space is RGB based,<br>
- special consideration must be made for doing<br>
- overprint with separation and devicen color spaces.<br>
-<br>
- In particular if we are going out to a separation<br>
- device we could have RGB+spot support but not<br>
- if the separation color was a process name like<br>
- Cyan.<br>
-<br>
- Also implement the missing gxdso_pdf14_sep_device<br>
- special operation.<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevp14.c<br>
-base/gscdevn.c<br>
-base/gscspace.h<br>
-base/gsstate.c<br>
-base/gstext.c<br>
-base/gxblend.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-11 15:41:09 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a7def309186f123008dcedfc0a6b07b6328c9c13">a7def309186f123008dcedfc0a6b07b6328c9c13</a>
-<blockquote>
-<p>
- lgtm.com: configuration file fixes.<br>
-<br>
-.lgtm.yml<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-11 00:57:18 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f03b3f51957fcaab6b953ba79bb32d2096ad49b">4f03b3f51957fcaab6b953ba79bb32d2096ad49b</a>
-<blockquote>
-<p>
- lgtm.com fixes: Avoid narrow mult cast to longer type.<br>
-<br>
- Avoid masking overflows through relying on implicit casting.<br>
-<br>
-base/gdevabuf.c<br>
-base/gdevdflt.c<br>
-base/gdevp14.c<br>
-base/gen_ordered.c<br>
-base/gsfcmap.c<br>
-base/gsfunc0.c<br>
-base/gsht.c<br>
-base/gshtscr.c<br>
-base/gsicc_create.c<br>
-base/gsptype1.c<br>
-base/gxblend1.c<br>
-base/gxdownscale.c<br>
-base/gxht_thresh.c<br>
-base/gxicolor.c<br>
-base/gximono.c<br>
-base/gxiscale.c<br>
-base/gxpcmap.c<br>
-base/sidscale.c<br>
-base/siscale.c<br>
-base/sjpx_openjpeg.c<br>
-devices/gdevdm24.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpsds.c<br>
-pcl/pcl/pglfill.c<br>
-pcl/pxl/pxpaint.c<br>
-xps/xpstiff.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-10 12:31:02 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4c305cb14b76bebfe0e147bcd90f4cc2ec7482ac">4c305cb14b76bebfe0e147bcd90f4cc2ec7482ac</a>
-<blockquote>
-<p>
- Add lgtm configuration file.<br>
-<br>
-.lgtm.yml<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-10 12:19:48 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b89ef860f52a6ca9696559c39104feba41e1de8">9b89ef860f52a6ca9696559c39104feba41e1de8</a>
-<blockquote>
-<p>
- lgtm.com fixes: gpdl tweaks.<br>
-<br>
-gpdl/jpgtop.c<br>
-gpdl/pngtop.c<br>
-gpdl/psitop.c<br>
-gpdl/tifftop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-09 17:42:37 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b778f827810b9f14c758334dd94f3f8df4d27bd4">b778f827810b9f14c758334dd94f3f8df4d27bd4</a>
-<blockquote>
-<p>
- lgtm.com fix: Use | not || when combining bitflags.<br>
-<br>
-base/gxclpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-09 17:49: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=c2dbf6acdc8b86cc0d74ff74d222720558ceb397">c2dbf6acdc8b86cc0d74ff74d222720558ceb397</a>
-<blockquote>
-<p>
- lgtm.com fix: Remove code for duplicated &quot;if&quot; condition.<br>
-<br>
-toolbin/halftone/ETS/ipview.html<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-09 17:45: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=d9b37029db10bdeaf5eaee00bac2eb0653644c77">d9b37029db10bdeaf5eaee00bac2eb0653644c77</a>
-<blockquote>
-<p>
- lgtm.com tweak: Make it clear that something isn't a typo.<br>
-<br>
- Use &quot;INTERPATCH_PADDING != 0&quot; rather than &quot;INTERPATCH_PADDING&quot; to<br>
- avoid the appearance of a typo.<br>
-<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-09 17:38:24 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8836aca9a03b99fc6f0ceb3994dbb78d442d634a">8836aca9a03b99fc6f0ceb3994dbb78d442d634a</a>
-<blockquote>
-<p>
- lgtm.com: Miscellaneous fixes in support scripts.<br>
-<br>
- Remove unused local variables, correct semicolon usage. Avoid<br>
- &quot;return fn()&quot; where fn always returns None.<br>
-<br>
-pcl/tools/check_deps.py<br>
-pcl/tools/makeromttf.py<br>
-pcl/tools/pxlasm.py<br>
-pcl/tools/pxldis.py<br>
-pcl/tools/revlist.py<br>
-psi/msvc.mak<br>
-toolbin/gitlog2changelog.py<br>
-toolbin/halftone/ETS/ipview.html<br>
-toolbin/ocheck.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-09 12:35:27 +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=8620f18686d3350590894590264f4cd71ef3dccb">8620f18686d3350590894590264f4cd71ef3dccb</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV during pjl_set_init_from_defaults.<br>
-<br>
- Prevent SEGV by propagating all error codes.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=25933 ./membin/gpcl6 -sDEVICE=pbmraw -dMaxBitmap=2000 -o /dev/null ./tests_private/pcl/pcl5efts/fts.0051<br>
-<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/pjparse.h<br>
-pcl/pl/pjparsei.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-08 21:50: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=9e553991e4c99814eb342d83b4fb42b5af457390">9e553991e4c99814eb342d83b4fb42b5af457390</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent numerous memory leaks.<br>
-<br>
- Prevent memory leaks by propagating error codes and freeing loose objects.<br>
-<br>
- Also resolve some compiler warnings.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=19484 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5efts/fts.0051<br>
-<br>
-base/gscspace.c<br>
-base/gxclrast.c<br>
-base/gxcpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-08 14:50:08 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a0a3ac239e990a76e937710dce75f3ace1e25be7">a0a3ac239e990a76e937710dce75f3ace1e25be7</a>
-<blockquote>
-<p>
- lgtm.com issue: Add some missing &quot;repeat include&quot; guards.<br>
-<br>
-base/gximdecode.h<br>
-contrib/lips4/gdevlips.h<br>
-contrib/lips4/gdevlprn.h<br>
-devices/rinkj/evenbetter-rll.h<br>
-devices/rinkj/rinkj-byte-stream.h<br>
-devices/rinkj/rinkj-config.h<br>
-devices/rinkj/rinkj-device.h<br>
-devices/rinkj/rinkj-dither.h<br>
-devices/rinkj/rinkj-epson870.h<br>
-devices/rinkj/rinkj-screen-eb.h<br>
-devices/vector/gdevagl.h<br>
-devices/vector/gdevpdfg.h<br>
-ijs/ijs.h<br>
-ijs/ijs_client.h<br>
-jbig2dec/jbig2.h<br>
-lcms2mt/include/lcms2mt.h<br>
-lcms2mt/include/lcms2mt_plugin.h<br>
-lcms2mt/src/lcms2_internal.h<br>
-pcl/pcl/pgfdata.h<br>
-pcl/pl/plfapi.h<br>
-pcl/pl/plparams.h<br>
-pcl/pl/plufstlp.h<br>
-pcl/pl/plvocab.h<br>
-pcl/pxl/pxbfont.h<br>
-xps/ghostxps.h<br>
-xps/xpsfapi.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-08 12:23:26 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1883e1010c35da56bc47ad439b9e45401a3060da">1883e1010c35da56bc47ad439b9e45401a3060da</a>
-<blockquote>
-<p>
- lgtm.com fix: Remove duplicate keys from enumeration.<br>
-<br>
-pcl/tools/pxlasm.py<br>
-pcl/tools/pxldis.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-07 18:30:02 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=95fe80c3c670f1f5200c21ea8df3e6139b711acc">95fe80c3c670f1f5200c21ea8df3e6139b711acc</a>
-<blockquote>
-<p>
- lgtm.com fixes: Fix comparison of narrow loop var with wider limit.<br>
-<br>
-base/gxcmap.c<br>
-base/ttfmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-07 18:14: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=7592dd988af75e40f0e449e17905751a5117e4f5">7592dd988af75e40f0e449e17905751a5117e4f5</a>
-<blockquote>
-<p>
- Fix implicit declaration of var in ETS support script.<br>
-<br>
-toolbin/halftone/ETS/ipview.html<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-07 18:12:30 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=de1f4bc1918fe1a972c3e8119f3c24266aff4cc4">de1f4bc1918fe1a972c3e8119f3c24266aff4cc4</a>
-<blockquote>
-<p>
- Fix missing comma in pxlasm.py<br>
-<br>
-pcl/tools/pxlasm.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-07 17:48:08 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa4eb803adf41c0353fd7efbb4b45321eb2dec06">fa4eb803adf41c0353fd7efbb4b45321eb2dec06</a>
-<blockquote>
-<p>
- Tweak stream.h to avoid the use of &quot;template&quot;.<br>
-<br>
- &quot;template&quot; is a reserved word in C++, and so this header won't<br>
- compile when included from a .cpp file.<br>
-<br>
-base/stream.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-06 18:01:07 +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=efd0b47fe66a99097e200d76be1a4846ae2ef692">efd0b47fe66a99097e200d76be1a4846ae2ef692</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent memory leak in gx_path_assign_free.<br>
-<br>
- Prevent memory leak by freeing path on all errors.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=16246 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.2120<br>
-<br>
-base/gxpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-06 12:11:05 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6d7c22dd453515d3f3f74af695a08abed26f657b">6d7c22dd453515d3f3f74af695a08abed26f657b</a>
-<blockquote>
-<p>
- lgtm.com fixes for ghostscript.<br>
-<br>
- Avoid using the same header include guard in more than one file.<br>
-<br>
- Use the correct format specifier in a printf-like error string<br>
- in lcms2mt.<br>
-<br>
-contrib/gdevbjc_.h<br>
-lcms2mt/src/cmsio0.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-03 19:04:42 +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=1ad7ac685aa07b1dceb0bf9e28e68a47492fb920">1ad7ac685aa07b1dceb0bf9e28e68a47492fb920</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV in hpgl_LB.<br>
-<br>
- Prevent SEGV by cleanly freeing stick fonts on all errors.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=15422 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.1920<br>
-<br>
-pcl/pcl/pglabel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-04 10:29:06 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c34c60394ebf68356866c6160fd0f7dfa1c4d0ce">c34c60394ebf68356866c6160fd0f7dfa1c4d0ce</a>
-<blockquote>
-<p>
- Coverity 957905<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-04 08:31: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=54e26f03a7403112463ad69874be9ab66cc4c863">54e26f03a7403112463ad69874be9ab66cc4c863</a>
-<blockquote>
-<p>
- PDF interpreter - minor fixes<br>
-<br>
- Remove what looks like a left-over debugging print, make a couple of<br>
- indenting fixes.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-02 23:31: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=92dc0f411477a0b920eea64ab305e60d2755ac9d">92dc0f411477a0b920eea64ab305e60d2755ac9d</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent memory leaks in hpgl_fill_polyfill_background.<br>
-<br>
- The code has been refactored to always call grestore to balance the gsave.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=19724 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.1890<br>
-<br>
-pcl/pcl/pgdraw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-02 12:58:21 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=160d2d57ebbe610b770206f6f9773d9300ca97f9">160d2d57ebbe610b770206f6f9773d9300ca97f9</a>
-<blockquote>
-<p>
- Coverity 357907<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-02 12:25:59 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5b96425e2414dfb130490bf0da2a5e03da099951">5b96425e2414dfb130490bf0da2a5e03da099951</a>
-<blockquote>
-<p>
- Fix mistake in debug print variable count<br>
-<br>
-base/gstrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-02 09:26:05 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1407aa54f6c2df62d432a9b895a0001e62defcd8">1407aa54f6c2df62d432a9b895a0001e62defcd8</a>
-<blockquote>
-<p>
- Coverity 357906<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-02 13:33:04 +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=339ddd9dba998b82d4b71bdaee456ee80408c24f">339ddd9dba998b82d4b71bdaee456ee80408c24f</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent memory leaks in hpgl_print_symbol_mode_char.<br>
-<br>
- The code has been refactored to always call grestore to balance the gsave. The label buffer must<br>
- always be destroyed if it was successfully initialised.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=18349 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.1850<br>
-<br>
-pcl/pcl/pglabel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-01 16:24:38 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8c432810d36e24613b84f8506ab3929f9d13e612">8c432810d36e24613b84f8506ab3929f9d13e612</a>
-<blockquote>
-<p>
- Squashed commit of the page_group branch<br>
-<br>
- The issue this branch is trying to solve is to ensure<br>
- that the alpha blending occurs in the proper page group<br>
- color space. If the page group is CMYK and the device is<br>
- RGB then the final alpha blend must occur prior to the<br>
- color conversion. Currently with the head code this is<br>
- not the case. This work required a significant rework<br>
- of how the transparency group pop occurred since if it<br>
- is the final group, the blend will not occur until the<br>
- put_image operation. The group color handling was<br>
- completely reworked and simplified. The reworked code<br>
- now maintains a group_color object that is related to<br>
- its own color rather than the parent as before.<br>
-<br>
- In addition, during the push_device operation, a buffer<br>
- is not created. Previously an entire page buffer was<br>
- created. If we have a page group that is smaller than<br>
- the whole page, this will save us in space. The downside<br>
- of this is that we need to ensure we have a buffer in place<br>
- when the first drawing operation occurs.<br>
-<br>
- There were several issues with the bitrgbtags devices as<br>
- well as the pngalpha and psdcmyk16 devices that had to<br>
- be considered during the put_image operation.<br>
- operation<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gsicc_cache.c<br>
-base/gstparam.h<br>
-base/gstrans.c<br>
-base/gstrans.h<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-base/gxdevsop.h<br>
-devices/devs.mak<br>
-devices/gdevpng.c<br>
-devices/vector/gdevpdft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-05-01 12:17: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=d41990615baaee9bba6ce7ae3e5a025a71744c51">d41990615baaee9bba6ce7ae3e5a025a71744c51</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV in pcl_pattern_RF.<br>
-<br>
- The call to pl_dict_put will free the pattern if an error occurs so the pcl_pattern_free_pattern<br>
- is not required. Freeing the pattern data is now handled here to prevent leaks and also to<br>
- prevent double freeing.<br>
-<br>
- Two typos were also cleared up.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=15000 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.1816<br>
-<br>
-pcl/pcl/pcuptrn.c<br>
-pcl/pcl/pglfill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-29 20:43:17 +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=8ba1ead91f1c051df75302dc49531d9f2497ef51">8ba1ead91f1c051df75302dc49531d9f2497ef51</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV in hpgl_LB.<br>
-<br>
- Update code to propagate error codes correctly and and clean up stick fonts.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=17298 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.1640<br>
-<br>
-pcl/pcl/pglabel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-30 08:33: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=2844006034232cb95fdd295d7fedf5fed8390a8e">2844006034232cb95fdd295d7fedf5fed8390a8e</a>
-<blockquote>
-<p>
- PDF interpreter Ignore non-array Annots<br>
-<br>
- Yet another customer file, so no bug report.<br>
-<br>
- The supplied file is badly broken in several different ways. Most of<br>
- these Ghostscript already coped with but the file contains a new fault<br>
- we haven't seen before. The same object is referenced by different pages<br>
- once as a Font dictionary and once as an Annots array.<br>
-<br>
- Since the object is actually a font dictionary, the page referencing it<br>
- as an array fails with an error, because it has the wrong type.<br>
-<br>
- This commit simply ignores such errors and carries on, emitting the<br>
- usual warning. Its a little involved as there are several places where<br>
- we need to check the type of the object.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-28 14:49:14 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=45920485627a943f07eea0c5b1243b5eb540b498">45920485627a943f07eea0c5b1243b5eb540b498</a>
-<blockquote>
-<p>
- clusterpush.pl: added excludes for mupdf's mupdfwrap.py.<br>
-<br>
- Also add mudrawpy product.<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-27 11:04:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1b4c3669a20cb2b63e49300b03082b189acfe347">1b4c3669a20cb2b63e49300b03082b189acfe347</a>
-<blockquote>
-<p>
- Bug 702364: Fix missing echogs dependencies<br>
-<br>
-contrib/contrib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-27 10:36: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=9d2de2ee4c3858095d8dfb05cc7d113bf40d81c1">9d2de2ee4c3858095d8dfb05cc7d113bf40d81c1</a>
-<blockquote>
-<p>
- Rename devices/contrib.mak to devices/dcontrib.mak<br>
-<br>
- because we also have contrib/contrib.mak<br>
-<br>
-Makefile.in<br>
-base/unix-gcc.mak<br>
-base/winlib.mak<br>
-devices/dcontrib.mak<br>
-toolbin/headercompile.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-27 10:20:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f210e4c009f7d401767336a264c2e4b9cf668216">f210e4c009f7d401767336a264c2e4b9cf668216</a>
-<blockquote>
-<p>
- Bug 702349: Fix symbol clash between lcms2mt and lcms2<br>
-<br>
- Shared library (libgs) with lcms2mt could clash if the calling app also<br>
- included lcms2.<br>
-<br>
- Using gcc (or compatible) this builds lcms2mt using the -fvisibility=hidden<br>
- option, so symbols are not exported.<br>
-<br>
-Makefile.in<br>
-base/lcms2mt.mak<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-23 18:23:17 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7c96228899ea05b40cdb31dc5a4c3f61aa0d39e6">7c96228899ea05b40cdb31dc5a4c3f61aa0d39e6</a>
-<blockquote>
-<p>
- Fix Bug 702014: ps2epsi problems (regression?).<br>
-<br>
- The ps2epsi and ps2epsi.ps were quite a mess, and relied on non-standard<br>
- operators only available with -dNOSAFER since we made SAFER the default.<br>
- Even running ps2epsi with -dNOSAFER (by export GS_OPTIONS=-dNOSAFER)<br>
- had problems -- it could not even convert examples/colorcir.ps to EPSI<br>
- (throwing an error about colorcirsave). Both of the aforementioned<br>
- files are replaced with this commit, and the ps2epsi.bat and ps2epsi.cmd<br>
- are updated to use the new ps2epsi.ps file<br>
-<br>
- Also, input files with multiple pages were never correct since the preview<br>
- was derived only from the first page. The ps2epsi.ps checks if the file is<br>
- already an EPSF, then don't use eps2write on the input, but warn if the<br>
- %%Pages comment indicates that there is more than a single page.<br>
-<br>
- Note that -dNOOUTERSAVE is needed in the invocation so that if we use<br>
- eps2write, the 'restore' will close the device and write the tempfile<br>
- with the EPSF.<br>
-<br>
- Then ps2epsi.ps reads the input file, capturing the BBox, stops after<br>
- %%EndComments, removes any existing preview, constructs a new preview<br>
- using the 'bit' device with appropriate parameters, writes the preview<br>
- in the EPSI Preview format (using writehexstring) and then copies the<br>
- remainder of the EPSF file to the output.<br>
-<br>
- The ps2epsi.ps has some checking for valid invocation, since someone<br>
- may try to use it without the scripts.<br>
-<br>
- Since all of the actual conversion is done by the ps2epsi.ps, this change<br>
- makes windows and linux produce equivalent files.<br>
-<br>
-lib/ps2epsi<br>
-lib/ps2epsi.bat<br>
-lib/ps2epsi.cmd<br>
-lib/ps2epsi.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-23 18:22:15 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=01b1eb1ef43952026ed8bf8728744522abfbfc19">01b1eb1ef43952026ed8bf8728744522abfbfc19</a>
-<blockquote>
-<p>
- Fix gssetgs.bat to use either 32 or 64 bit executables (64-bit preferred).<br>
-<br>
-lib/gssetgs.bat<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-24 14:13:54 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f69f7a2c8b05c3f8a4e14d30453dcb599ca8b64d">f69f7a2c8b05c3f8a4e14d30453dcb599ca8b64d</a>
-<blockquote>
-<p>
- Update msvc.mak to allow for new nmake version.<br>
-<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-23 11:42:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a46e31d5005cf136679ac7c54cb91d91654710d">6a46e31d5005cf136679ac7c54cb91d91654710d</a>
-<blockquote>
-<p>
- Document that gsapi_set_stdio doesn't affect devices<br>
-<br>
- Using -sOutputFile=%stdout (counterintuitively) does not direct device output<br>
- to the stdout handler callback set by gsapi_set_stdio().<br>
-<br>
-doc/API.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-17 16:22:06 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=60a535f9f49fece2761a1c0c8069f87f7514182c">60a535f9f49fece2761a1c0c8069f87f7514182c</a>
-<blockquote>
-<p>
- Bug 702335: jbig2dec: Refill input buffer upon failure to parse segment header.<br>
-<br>
- Before commit 2b2dcf4ccf401ed210f03c858b304994749fd2b3 there was<br>
- a debug message when attempting to parse a a segment header and<br>
- the data supplied to jbig2dec was not enough. Commit 2b2dcf4<br>
- incorrectly changed the debug message into a fatal error message,<br>
- due misinterpreting the message text as something that warranted<br>
- a fatal error.<br>
-<br>
- When data was supplied in chunks to jbig2_data_in() in repeated<br>
- calls such that a segment header's referred-to segment numbers<br>
- field straddled a chunk boundary then jbig2dec would indicate a<br>
- fatal error. The file in bug 702335 caused this to happen.<br>
-<br>
- Instead jbig2dec should be asking the caller for more data so<br>
- that the entire segment header can be parsed during a single call<br>
- to jbig2_data_in().<br>
-<br>
- By convering the fatal error back to a a debug message the problem<br>
- is resolved. The message itself is also rewored to clearly<br>
- indicate that the situation is non-fatal and that the caller will<br>
- be asked to provide more data.<br>
-<br>
-jbig2dec/jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-16 05:05:21 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=85b1119bb3493608b1e84acfaa7b27a6e5259b43">85b1119bb3493608b1e84acfaa7b27a6e5259b43</a>
-<blockquote>
-<p>
- Fix URF filter configuration code.<br>
-<br>
- I was missing some quoting.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-15 10:22: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=d845756b28a9cdadaf5374cc4fa130963ea65adc">d845756b28a9cdadaf5374cc4fa130963ea65adc</a>
-<blockquote>
-<p>
- PDF interpreter - reject insane Tc values early<br>
-<br>
- No bug report, the file is from a customer and confidential.<br>
-<br>
- The file has been created by a bfo.com product, but then additionally<br>
- modified by an unknown application. The problem is that the file<br>
- contains this sequence:<br>
-<br>
- 1 0 0 0.999999 21.6 9.900086 cm<br>
- /R3 9 Tf -2147483647 Tc -0.39301 Tw<br>
- 4.8 -21.95 Td<br>
- [( )]TJ<br>
-<br>
- The parameter supplied to Tc is clearly mad. Not invalid but it attempts<br>
- to move the current point (after drawing the space) by 2,147,483,647<br>
- unscaled text units. This works out at around 471 miles. Given that this<br>
- value is the maximum negative 32-bit integer (0xFFFFFFFF) I doubt this<br>
- is actually intentional.<br>
-<br>
- The scaling by the CTM causes a limitcheck error when trying to draw<br>
- the text. We could fix this by running the TJ in a stopped context<br>
- but that would be expensive performance-wise because TJ is a very common<br>
- operator.<br>
-<br>
- Instead this commit checks that the result of Tc, when scaled by the<br>
- CTM, will fit into our fixed-point representation. If it does not then<br>
- we throw an error there and then. The PDF interpreter then catches that<br>
- during the Tc operator (which is less commonly used than TJ) and emits<br>
- a warning, while ignoring the Tc value.<br>
-<br>
- This may, of course, result in incorrect output, though it seems<br>
- unlikely given the size of the numbers involved, which is why we give<br>
- the user a warning.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-10 15:35:02 -0700
-</strong>
-<br>ray &lt;Ray.Johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b503c46c124cf5aaa82a71e28f624f2ef2b71e71">b503c46c124cf5aaa82a71e28f624f2ef2b71e71</a>
-<blockquote>
-<p>
- Bug 702320: Valgrind complains about UMR.<br>
-<br>
- The file for this bug does show that the stroke_color stack based struct<br>
- in not initialized. Init fill_color and stroke_color. This is probably a<br>
- bug tail from the fill_stroke commit.<br>
-<br>
- Also explicitly set 'zeros' to 0 to clarify the expected contents.<br>
-<br>
-base/gxclbits.c<br>
-base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-10 18:04:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1b08043d16bb10d939e858ea8d650807301d6e05">1b08043d16bb10d939e858ea8d650807301d6e05</a>
-<blockquote>
-<p>
- Remove some errant remains of Google analytics<br>
-<br>
- The GA runes are now added by Apache when files are served from casper.<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/Internal.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>2020-04-10 11:11: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=8f52736b546329ae2e3ad760f722eac0dec6994e">8f52736b546329ae2e3ad760f722eac0dec6994e</a>
-<blockquote>
-<p>
- Update/augment ETS source copyrights<br>
-<br>
-base/ets.c<br>
-base/ets.h<br>
-base/ets_tm.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-09 18:07:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cbb82ba4baaa2a9da11c603d742a58a51c4e50e1">cbb82ba4baaa2a9da11c603d742a58a51c4e50e1</a>
-<blockquote>
-<p>
- Update copyright to 2020<br>
-<br>
-Resource/CIDFont/ArtifexBullet<br>
-Resource/ColorSpace/DefaultCMYK<br>
-Resource/ColorSpace/DefaultGray<br>
-Resource/ColorSpace/DefaultRGB<br>
-Resource/ColorSpace/TrivialCMYK<br>
-Resource/ColorSpace/sGray<br>
-Resource/ColorSpace/sRGB<br>
-Resource/Decoding/FCO_Dingbats<br>
-Resource/Decoding/FCO_Symbol<br>
-Resource/Decoding/FCO_Unicode<br>
-Resource/Decoding/FCO_Wingdings<br>
-Resource/Decoding/Latin1<br>
-Resource/Decoding/StandardEncoding<br>
-Resource/Decoding/Unicode<br>
-Resource/Encoding/CEEncoding<br>
-Resource/Encoding/ExpertEncoding<br>
-Resource/Encoding/ExpertSubsetEncoding<br>
-Resource/Encoding/NotDefEncoding<br>
-Resource/Encoding/Wingdings<br>
-Resource/Init/FCOfontmap-PCLPS2<br>
-Resource/Init/Fontmap.GS<br>
-Resource/Init/gs_agl.ps<br>
-Resource/Init/gs_btokn.ps<br>
-Resource/Init/gs_cff.ps<br>
-Resource/Init/gs_cidcm.ps<br>
-Resource/Init/gs_ciddc.ps<br>
-Resource/Init/gs_cidfm.ps<br>
-Resource/Init/gs_cidfn.ps<br>
-Resource/Init/gs_cidtt.ps<br>
-Resource/Init/gs_cmap.ps<br>
-Resource/Init/gs_cspace.ps<br>
-Resource/Init/gs_dbt_e.ps<br>
-Resource/Init/gs_diskn.ps<br>
-Resource/Init/gs_dps1.ps<br>
-Resource/Init/gs_dps2.ps<br>
-Resource/Init/gs_dscp.ps<br>
-Resource/Init/gs_epsf.ps<br>
-Resource/Init/gs_fapi.ps<br>
-Resource/Init/gs_fntem.ps<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_frsd.ps<br>
-Resource/Init/gs_icc.ps<br>
-Resource/Init/gs_il1_e.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_ll3.ps<br>
-Resource/Init/gs_mex_e.ps<br>
-Resource/Init/gs_mgl_e.ps<br>
-Resource/Init/gs_mro_e.ps<br>
-Resource/Init/gs_pdf_e.ps<br>
-Resource/Init/gs_pdfwr.ps<br>
-Resource/Init/gs_res.ps<br>
-Resource/Init/gs_resmp.ps<br>
-Resource/Init/gs_setpd.ps<br>
-Resource/Init/gs_statd.ps<br>
-Resource/Init/gs_std_e.ps<br>
-Resource/Init/gs_sym_e.ps<br>
-Resource/Init/gs_trap.ps<br>
-Resource/Init/gs_ttf.ps<br>
-Resource/Init/gs_typ32.ps<br>
-Resource/Init/gs_typ42.ps<br>
-Resource/Init/gs_type1.ps<br>
-Resource/Init/gs_wan_e.ps<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>
-Resource/SubstCID/CNS1-WMode<br>
-Resource/SubstCID/GB1-WMode<br>
-Resource/SubstCID/Japan1-WMode<br>
-Resource/SubstCID/Korea1-WMode<br>
-arch/arch_autoconf.h.in<br>
-arch/windows-arm-msvc.h<br>
-arch/windows-x64-msvc.h<br>
-arch/windows-x86-msvc.h<br>
-base/all-arch.mak<br>
-base/assert_.h<br>
-base/bench.c<br>
-base/bobbin.c<br>
-base/bobbin.h<br>
-base/claptrap-impl.h<br>
-base/claptrap.c<br>
-base/claptrap.h<br>
-base/ctype_.h<br>
-base/dirent_.h<br>
-base/dos_.h<br>
-base/echogs.c<br>
-base/errno_.h<br>
-base/ets.h<br>
-base/ets_tm.h<br>
-base/expat.mak<br>
-base/fapi_bs.mak<br>
-base/fapi_ft.c<br>
-base/fapibstm.c<br>
-base/fapiufst.c<br>
-base/fcntl_.h<br>
-base/freetype.mak<br>
-base/gconf.c<br>
-base/gconf.h<br>
-base/gdbflags.h<br>
-base/gdebug.h<br>
-base/gdevabuf.c<br>
-base/gdevbbox.c<br>
-base/gdevbbox.h<br>
-base/gdevdbit.c<br>
-base/gdevdcrd.c<br>
-base/gdevdcrd.h<br>
-base/gdevddrw.c<br>
-base/gdevddrw.h<br>
-base/gdevdevn.c<br>
-base/gdevdevn.h<br>
-base/gdevdevnprn.h<br>
-base/gdevdflt.c<br>
-base/gdevdgbr.c<br>
-base/gdevdrop.c<br>
-base/gdevdsha.c<br>
-base/gdevemap.c<br>
-base/gdevepo.c<br>
-base/gdevepo.h<br>
-base/gdevflp.c<br>
-base/gdevflp.h<br>
-base/gdevhit.c<br>
-base/gdevkrnlsclass.c<br>
-base/gdevkrnlsclass.h<br>
-base/gdevm1.c<br>
-base/gdevm16.c<br>
-base/gdevm2.c<br>
-base/gdevm24.c<br>
-base/gdevm32.c<br>
-base/gdevm4.c<br>
-base/gdevm40.c<br>
-base/gdevm48.c<br>
-base/gdevm56.c<br>
-base/gdevm64.c<br>
-base/gdevm8.c<br>
-base/gdevmem.c<br>
-base/gdevmem.h<br>
-base/gdevmpla.c<br>
-base/gdevmpla.h<br>
-base/gdevmplt.c<br>
-base/gdevmplt.h<br>
-base/gdevmr1.c<br>
-base/gdevmr2n.c<br>
-base/gdevmr8n.c<br>
-base/gdevmrop.h<br>
-base/gdevmrun.c<br>
-base/gdevmrun.h<br>
-base/gdevmx.c<br>
-base/gdevnfwd.c<br>
-base/gdevoflt.c<br>
-base/gdevoflt.h<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gdevpccm.c<br>
-base/gdevpccm.h<br>
-base/gdevpipe.c<br>
-base/gdevplnx.c<br>
-base/gdevplnx.h<br>
-base/gdevppla.c<br>
-base/gdevppla.h<br>
-base/gdevprn.c<br>
-base/gdevprn.h<br>
-base/gdevpxat.h<br>
-base/gdevpxen.h<br>
-base/gdevpxop.h<br>
-base/gdevrops.c<br>
-base/gdevsclass.c<br>
-base/gdevsclass.h<br>
-base/gdevvec.c<br>
-base/gdevvec.h<br>
-base/gen_ordered.c<br>
-base/gen_ordered.h<br>
-base/genarch.c<br>
-base/genconf.c<br>
-base/gendev.c<br>
-base/genht.c<br>
-base/gp.h<br>
-base/gp_dosfe.c<br>
-base/gp_dosfs.c<br>
-base/gp_dvx.c<br>
-base/gp_getnv.c<br>
-base/gp_mktmp.c<br>
-base/gp_msdll.c<br>
-base/gp_msdos.c<br>
-base/gp_mshdl.c<br>
-base/gp_mslib.c<br>
-base/gp_mspol.c<br>
-base/gp_msprn.c<br>
-base/gp_mswin.c<br>
-base/gp_mswin.h<br>
-base/gp_nsync.c<br>
-base/gp_ntfs.c<br>
-base/gp_nxpsprn.c<br>
-base/gp_os2.c<br>
-base/gp_os2.h<br>
-base/gp_os2fs.c<br>
-base/gp_os2pr.c<br>
-base/gp_os9.c<br>
-base/gp_paper.c<br>
-base/gp_psync.c<br>
-base/gp_stdia.c<br>
-base/gp_stdin.c<br>
-base/gp_strdl.c<br>
-base/gp_unifn.c<br>
-base/gp_unifs.c<br>
-base/gp_unix.c<br>
-base/gp_upapr.c<br>
-base/gp_vms.c<br>
-base/gp_wgetv.c<br>
-base/gp_win32.c<br>
-base/gp_winfs.c<br>
-base/gp_winfs2.c<br>
-base/gp_wpapr.c<br>
-base/gp_wsync.c<br>
-base/gp_wutf8.c<br>
-base/gp_wxpsprn.cpp<br>
-base/gpcheck.h<br>
-base/gpgetenv.h<br>
-base/gpmisc.c<br>
-base/gpmisc.h<br>
-base/gpsync.h<br>
-base/gs.mak<br>
-base/gs_dll_call.h<br>
-base/gs_mgl_e.h<br>
-base/gs_mro_e.h<br>
-base/gsalloc.c<br>
-base/gsalloc.h<br>
-base/gsargs.c<br>
-base/gsargs.h<br>
-base/gsbitcom.c<br>
-base/gsbitmap.h<br>
-base/gsbitops.c<br>
-base/gsbitops.h<br>
-base/gsbittab.c<br>
-base/gsbittab.h<br>
-base/gsccode.h<br>
-base/gsccolor.h<br>
-base/gscdef.c<br>
-base/gscdefs.h<br>
-base/gscdevn.c<br>
-base/gscdevn.h<br>
-base/gscedata.c<br>
-base/gscedata.h<br>
-base/gscencs.c<br>
-base/gscencs.h<br>
-base/gschar.c<br>
-base/gschar.h<br>
-base/gschar0.c<br>
-base/gscicach.c<br>
-base/gscicach.h<br>
-base/gscie.c<br>
-base/gscie.h<br>
-base/gsciemap.c<br>
-base/gscindex.h<br>
-base/gsclipsr.c<br>
-base/gsclipsr.h<br>
-base/gscms.h<br>
-base/gscolor.c<br>
-base/gscolor.h<br>
-base/gscolor1.c<br>
-base/gscolor1.h<br>
-base/gscolor2.c<br>
-base/gscolor2.h<br>
-base/gscolor3.c<br>
-base/gscolor3.h<br>
-base/gscompt.h<br>
-base/gscoord.c<br>
-base/gscoord.h<br>
-base/gscparam.c<br>
-base/gscpixel.c<br>
-base/gscpixel.h<br>
-base/gscpm.h<br>
-base/gscrd.c<br>
-base/gscrd.h<br>
-base/gscrdp.c<br>
-base/gscrdp.h<br>
-base/gscrypt1.c<br>
-base/gscrypt1.h<br>
-base/gscscie.c<br>
-base/gscsel.h<br>
-base/gscsepr.c<br>
-base/gscsepr.h<br>
-base/gscspace.c<br>
-base/gscspace.h<br>
-base/gscssub.c<br>
-base/gscssub.h<br>
-base/gsdcolor.h<br>
-base/gsdevice.c<br>
-base/gsdevice.h<br>
-base/gsdevmem.c<br>
-base/gsdll.h<br>
-base/gsdllwin.h<br>
-base/gsdparam.c<br>
-base/gsdps1.c<br>
-base/gsdsrc.c<br>
-base/gsdsrc.h<br>
-base/gsequivc.c<br>
-base/gsequivc.h<br>
-base/gserrors.h<br>
-base/gsexit.h<br>
-base/gsfcid.c<br>
-base/gsfcid2.c<br>
-base/gsfcmap.c<br>
-base/gsfcmap.h<br>
-base/gsfcmap1.c<br>
-base/gsflip.c<br>
-base/gsflip.h<br>
-base/gsfname.c<br>
-base/gsfname.h<br>
-base/gsfont.c<br>
-base/gsfont.h<br>
-base/gsfont0.c<br>
-base/gsfont0c.c<br>
-base/gsform1.h<br>
-base/gsftopts.h<br>
-base/gsfunc.c<br>
-base/gsfunc.h<br>
-base/gsfunc0.c<br>
-base/gsfunc0.h<br>
-base/gsfunc3.c<br>
-base/gsfunc3.h<br>
-base/gsfunc4.c<br>
-base/gsfunc4.h<br>
-base/gsgc.h<br>
-base/gsgcache.c<br>
-base/gsgcache.h<br>
-base/gsgdata.c<br>
-base/gsgdata.h<br>
-base/gsgstate.c<br>
-base/gsgstate.h<br>
-base/gshsb.c<br>
-base/gshsb.h<br>
-base/gsht.c<br>
-base/gsht.h<br>
-base/gsht1.c<br>
-base/gsht1.h<br>
-base/gshtscr.c<br>
-base/gshtx.c<br>
-base/gshtx.h<br>
-base/gsicc.c<br>
-base/gsicc.h<br>
-base/gsicc_cache.c<br>
-base/gsicc_cache.h<br>
-base/gsicc_cms.h<br>
-base/gsicc_create.c<br>
-base/gsicc_create.h<br>
-base/gsicc_lcms2.c<br>
-base/gsicc_lcms2mt.c<br>
-base/gsicc_manage.c<br>
-base/gsicc_manage.h<br>
-base/gsicc_monitorcm.c<br>
-base/gsicc_nocm.c<br>
-base/gsicc_profilecache.c<br>
-base/gsicc_profilecache.h<br>
-base/gsicc_replacecm.c<br>
-base/gsimage.c<br>
-base/gsimage.h<br>
-base/gsimpath.c<br>
-base/gsinit.c<br>
-base/gsio.h<br>
-base/gsiodev.c<br>
-base/gsiodevs.c<br>
-base/gsiodisk.c<br>
-base/gsioram.c<br>
-base/gsiorom.c<br>
-base/gsiorom.h<br>
-base/gsipar3x.h<br>
-base/gsiparam.h<br>
-base/gsiparm3.h<br>
-base/gsiparm4.h<br>
-base/gsjconf.h<br>
-base/gsjmorec.h<br>
-base/gslib.c<br>
-base/gslib.h<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-base/gsline.c<br>
-base/gsline.h<br>
-base/gslparam.h<br>
-base/gsmalloc.c<br>
-base/gsmalloc.h<br>
-base/gsmatrix.c<br>
-base/gsmatrix.h<br>
-base/gsmchunk.c<br>
-base/gsmchunk.h<br>
-base/gsmd5.c<br>
-base/gsmd5.h<br>
-base/gsmdebug.h<br>
-base/gsmemory.c<br>
-base/gsmemory.h<br>
-base/gsmemraw.h<br>
-base/gsmemret.c<br>
-base/gsmemret.h<br>
-base/gsmisc.c<br>
-base/gsnamecl.c<br>
-base/gsnamecl.h<br>
-base/gsncdummy.c<br>
-base/gsncdummy.h<br>
-base/gsnogc.c<br>
-base/gsnogc.h<br>
-base/gsnotify.c<br>
-base/gsnotify.h<br>
-base/gsovrc.c<br>
-base/gsovrc.h<br>
-base/gspaint.c<br>
-base/gspaint.h<br>
-base/gsparam.c<br>
-base/gsparam.h<br>
-base/gsparam2.c<br>
-base/gsparams.c<br>
-base/gsparams.h<br>
-base/gsparamx.c<br>
-base/gsparamx.h<br>
-base/gspath.c<br>
-base/gspath.h<br>
-base/gspath1.c<br>
-base/gspath2.h<br>
-base/gspcolor.c<br>
-base/gspcolor.h<br>
-base/gspenum.h<br>
-base/gspmdrv.c<br>
-base/gspmdrv.h<br>
-base/gspmdrv.rc<br>
-base/gsptype1.c<br>
-base/gsptype1.h<br>
-base/gsptype2.c<br>
-base/gsptype2.h<br>
-base/gsrect.h<br>
-base/gsrefct.h<br>
-base/gsromfs0.c<br>
-base/gsrop.c<br>
-base/gsrop.h<br>
-base/gsroprun.c<br>
-base/gsroprun1.h<br>
-base/gsroprun24.h<br>
-base/gsroprun8.h<br>
-base/gsropt.h<br>
-base/gsroptab.c<br>
-base/gsserial.c<br>
-base/gsserial.h<br>
-base/gsshade.c<br>
-base/gsshade.h<br>
-base/gssprintf.h<br>
-base/gsstate.c<br>
-base/gsstate.h<br>
-base/gsstrl.h<br>
-base/gsstrtok.h<br>
-base/gsstruct.h<br>
-base/gsstype.h<br>
-base/gstext.c<br>
-base/gstext.h<br>
-base/gstiffio.c<br>
-base/gstiffio.h<br>
-base/gstparam.h<br>
-base/gstrans.c<br>
-base/gstrans.h<br>
-base/gstrap.c<br>
-base/gstrap.h<br>
-base/gstype1.c<br>
-base/gstype1.h<br>
-base/gstype2.c<br>
-base/gstype42.c<br>
-base/gstypes.h<br>
-base/gsuid.h<br>
-base/gsutil.c<br>
-base/gsutil.h<br>
-base/gswin.rc<br>
-base/gsxfont.h<br>
-base/gx.h<br>
-base/gxacpath.c<br>
-base/gxalloc.h<br>
-base/gxalpha.h<br>
-base/gxarith.h<br>
-base/gxband.h<br>
-base/gxbcache.c<br>
-base/gxbcache.h<br>
-base/gxbitfmt.h<br>
-base/gxbitmap.h<br>
-base/gxbitops.h<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-base/gxccache.c<br>
-base/gxccman.c<br>
-base/gxcdevn.h<br>
-base/gxchar.c<br>
-base/gxchar.h<br>
-base/gxchrout.c<br>
-base/gxchrout.h<br>
-base/gxcht.c<br>
-base/gxcid.h<br>
-base/gxcie.h<br>
-base/gxcindex.h<br>
-base/gxclbits.c<br>
-base/gxcldev.h<br>
-base/gxclfile.c<br>
-base/gxclimag.c<br>
-base/gxclio.h<br>
-base/gxclip.c<br>
-base/gxclip.h<br>
-base/gxclip2.c<br>
-base/gxclip2.h<br>
-base/gxclipm.c<br>
-base/gxclipm.h<br>
-base/gxclipsr.h<br>
-base/gxclist.c<br>
-base/gxclist.h<br>
-base/gxcllzw.c<br>
-base/gxclmem.c<br>
-base/gxclmem.h<br>
-base/gxclpage.c<br>
-base/gxclpage.h<br>
-base/gxclpath.c<br>
-base/gxclpath.h<br>
-base/gxclrast.c<br>
-base/gxclread.c<br>
-base/gxclrect.c<br>
-base/gxclthrd.c<br>
-base/gxclthrd.h<br>
-base/gxclutil.c<br>
-base/gxclzlib.c<br>
-base/gxcmap.c<br>
-base/gxcmap.h<br>
-base/gxcolor2.h<br>
-base/gxcomp.h<br>
-base/gxcoord.h<br>
-base/gxcpath.c<br>
-base/gxcpath.h<br>
-base/gxcspace.h<br>
-base/gxctable.c<br>
-base/gxctable.h<br>
-base/gxcvalue.h<br>
-base/gxdcconv.c<br>
-base/gxdcconv.h<br>
-base/gxdcolor.c<br>
-base/gxdcolor.h<br>
-base/gxdda.h<br>
-base/gxdevbuf.h<br>
-base/gxdevcli.h<br>
-base/gxdevice.h<br>
-base/gxdevmem.h<br>
-base/gxdevndi.c<br>
-base/gxdevrop.h<br>
-base/gxdevsop.h<br>
-base/gxdht.h<br>
-base/gxdhtres.h<br>
-base/gxdhtserial.c<br>
-base/gxdhtserial.h<br>
-base/gxdither.h<br>
-base/gxdownscale.c<br>
-base/gxdownscale.h<br>
-base/gxdtfill.h<br>
-base/gxfapi.c<br>
-base/gxfapi.h<br>
-base/gxfapiu.c<br>
-base/gxfapiu.h<br>
-base/gxfarith.h<br>
-base/gxfcache.h<br>
-base/gxfcid.h<br>
-base/gxfcmap.h<br>
-base/gxfcmap1.h<br>
-base/gxfill.c<br>
-base/gxfill.h<br>
-base/gxfillsl.h<br>
-base/gxfilltr.h<br>
-base/gxfillts.h<br>
-base/gxfixed.h<br>
-base/gxfmap.h<br>
-base/gxfont.h<br>
-base/gxfont0.h<br>
-base/gxfont0c.h<br>
-base/gxfont1.h<br>
-base/gxfont42.h<br>
-base/gxfrac.h<br>
-base/gxftype.h<br>
-base/gxfunc.h<br>
-base/gxgetbit.h<br>
-base/gxgstate.h<br>
-base/gxhintn.c<br>
-base/gxhintn.h<br>
-base/gxhintn1.c<br>
-base/gxhldevc.c<br>
-base/gxhldevc.h<br>
-base/gxht.c<br>
-base/gxht.h<br>
-base/gxht_thresh.c<br>
-base/gxht_thresh.h<br>
-base/gxhtbit.c<br>
-base/gxhttile.h<br>
-base/gxhttype.h<br>
-base/gxi12bit.c<br>
-base/gxi16bit.c<br>
-base/gxiclass.h<br>
-base/gxicolor.c<br>
-base/gxidata.c<br>
-base/gxifast.c<br>
-base/gximag3x.c<br>
-base/gximag3x.h<br>
-base/gximage.c<br>
-base/gximage.h<br>
-base/gximage1.c<br>
-base/gximage3.c<br>
-base/gximage3.h<br>
-base/gximage4.c<br>
-base/gximask.c<br>
-base/gximask.h<br>
-base/gximdecode.c<br>
-base/gximono.c<br>
-base/gxiodev.h<br>
-base/gxiparam.h<br>
-base/gxipixel.c<br>
-base/gxiscale.c<br>
-base/gxline.h<br>
-base/gxlum.h<br>
-base/gxmatrix.h<br>
-base/gxmclip.c<br>
-base/gxmclip.h<br>
-base/gxobj.h<br>
-base/gxoprect.c<br>
-base/gxoprect.h<br>
-base/gxp1fill.c<br>
-base/gxp1impl.h<br>
-base/gxpaint.c<br>
-base/gxpaint.h<br>
-base/gxpath.c<br>
-base/gxpath.h<br>
-base/gxpath2.c<br>
-base/gxpcache.h<br>
-base/gxpcmap.c<br>
-base/gxpcolor.h<br>
-base/gxpcopy.c<br>
-base/gxpdash.c<br>
-base/gxpflat.c<br>
-base/gxrplane.h<br>
-base/gxsample.c<br>
-base/gxsample.h<br>
-base/gxsamplp.h<br>
-base/gxscanc.c<br>
-base/gxscanc.h<br>
-base/gxshade.c<br>
-base/gxshade.h<br>
-base/gxshade1.c<br>
-base/gxshade4.c<br>
-base/gxshade4.h<br>
-base/gxshade6.c<br>
-base/gxstate.h<br>
-base/gxstdio.h<br>
-base/gxstroke.c<br>
-base/gxsync.c<br>
-base/gxsync.h<br>
-base/gxtext.h<br>
-base/gxtmap.h<br>
-base/gxttf.h<br>
-base/gxttfb.c<br>
-base/gxttfb.h<br>
-base/gxtype1.c<br>
-base/gxtype1.h<br>
-base/gxxfont.h<br>
-base/gzacpath.h<br>
-base/gzcpath.h<br>
-base/gzht.h<br>
-base/gzline.h<br>
-base/gzpath.h<br>
-base/gzspotan.c<br>
-base/gzspotan.h<br>
-base/gzstate.h<br>
-base/ijs.mak<br>
-base/instcopy<br>
-base/jbig2.mak<br>
-base/jerror_.h<br>
-base/jmemcust.c<br>
-base/jmemcust.h<br>
-base/jpeg.mak<br>
-base/jpegxr.mak<br>
-base/lcms2.mak<br>
-base/lcms2mt.mak<br>
-base/lcups.mak<br>
-base/lcupsi.mak<br>
-base/ldf_jb2.mak<br>
-base/lib.mak<br>
-base/locale_.h<br>
-base/lwf_jp2.mak<br>
-base/malloc_.h<br>
-base/math_.h<br>
-base/memento.c<br>
-base/memento.h<br>
-base/memory_.h<br>
-base/mkromfs.c<br>
-base/msvccmd.mak<br>
-base/msvclib.mak<br>
-base/msvctail.mak<br>
-base/openjpeg.mak<br>
-base/openvms.mak<br>
-base/openvms.mmk<br>
-base/pack_ps.c<br>
-base/pcwin.mak<br>
-base/pipe_.h<br>
-base/png.mak<br>
-base/png_.h<br>
-base/ramfs.c<br>
-base/ramfs.h<br>
-base/sa85d.c<br>
-base/sa85d.h<br>
-base/sa85x.h<br>
-base/saes.c<br>
-base/saes.h<br>
-base/sarc4.c<br>
-base/sarc4.h<br>
-base/sbcp.c<br>
-base/sbcp.h<br>
-base/sbtx.h<br>
-base/scanchar.h<br>
-base/scantab.c<br>
-base/scf.h<br>
-base/scfd.c<br>
-base/scfdgen.c<br>
-base/scfdtab.c<br>
-base/scfe.c<br>
-base/scfetab.c<br>
-base/scfparam.c<br>
-base/scfx.h<br>
-base/scommon.h<br>
-base/sdcparam.c<br>
-base/sdcparam.h<br>
-base/sdct.h<br>
-base/sdctc.c<br>
-base/sdctd.c<br>
-base/sdcte.c<br>
-base/sddparam.c<br>
-base/sdeparam.c<br>
-base/seexec.c<br>
-base/setjmp_.h<br>
-base/sfilter.h<br>
-base/sfilter1.c<br>
-base/sfilter2.c<br>
-base/sfxboth.c<br>
-base/sfxcommon.c<br>
-base/sfxfd.c<br>
-base/sfxstdio.c<br>
-base/shc.c<br>
-base/shc.h<br>
-base/sidscale.c<br>
-base/sidscale.h<br>
-base/siinterp.c<br>
-base/siinterp.h<br>
-base/simscale.c<br>
-base/simscale.h<br>
-base/siscale.c<br>
-base/siscale.h<br>
-base/siscale_cal.c<br>
-base/sisparam.h<br>
-base/sjbig2.c<br>
-base/sjbig2.h<br>
-base/sjbig2_luratech.c<br>
-base/sjbig2_luratech.h<br>
-base/sjpeg.h<br>
-base/sjpegc.c<br>
-base/sjpegd.c<br>
-base/sjpege.c<br>
-base/sjpx_luratech.c<br>
-base/sjpx_luratech.h<br>
-base/sjpx_none.c<br>
-base/sjpx_openjpeg.c<br>
-base/sjpx_openjpeg.h<br>
-base/slzwc.c<br>
-base/slzwd.c<br>
-base/slzwe.c<br>
-base/slzwx.h<br>
-base/smd5.c<br>
-base/smd5.h<br>
-base/smtf.h<br>
-base/spdiff.c<br>
-base/spdiffx.h<br>
-base/spngp.c<br>
-base/spngpx.h<br>
-base/spprint.c<br>
-base/spprint.h<br>
-base/spsdf.c<br>
-base/spsdf.h<br>
-base/srdline.h<br>
-base/srld.c<br>
-base/srle.c<br>
-base/srlx.h<br>
-base/ssha2.c<br>
-base/ssha2.h<br>
-base/sstring.c<br>
-base/sstring.h<br>
-base/stat_.h<br>
-base/std.h<br>
-base/stdint_.h<br>
-base/stdio_.h<br>
-base/stdpre.h<br>
-base/stream.c<br>
-base/stream.h<br>
-base/strimpl.h<br>
-base/string_.h<br>
-base/strmio.c<br>
-base/strmio.h<br>
-base/stub.mak<br>
-base/szlibc.c<br>
-base/szlibd.c<br>
-base/szlibe.c<br>
-base/szlibx.h<br>
-base/szlibxx.h<br>
-base/tiff.mak<br>
-base/time_.h<br>
-base/ttcalc.c<br>
-base/ttcalc.h<br>
-base/ttcommon.h<br>
-base/ttconf.h<br>
-base/ttconfig.h<br>
-base/ttfinp.c<br>
-base/ttfinp.h<br>
-base/ttfmain.c<br>
-base/ttfmemd.c<br>
-base/ttfmemd.h<br>
-base/ttfoutl.h<br>
-base/ttfsfnt.h<br>
-base/ttinterp.c<br>
-base/ttinterp.h<br>
-base/ttload.c<br>
-base/ttload.h<br>
-base/ttmisc.h<br>
-base/ttobjs.c<br>
-base/ttobjs.h<br>
-base/tttables.h<br>
-base/tttype.h<br>
-base/tttypes.h<br>
-base/ugcclib.mak<br>
-base/unistd_.h<br>
-base/unix-aux.mak<br>
-base/unix-dll.mak<br>
-base/unix-end.mak<br>
-base/unix-gcc.mak<br>
-base/unixansi.mak<br>
-base/unixhead.mak<br>
-base/unixinst.mak<br>
-base/unixlink.mak<br>
-base/valgrind.h<br>
-base/version.mak<br>
-base/vms_x_fix.h<br>
-base/vmsmath.h<br>
-base/windows_.h<br>
-base/winlib.mak<br>
-base/winplat.mak<br>
-base/winrtsup.cpp<br>
-base/winrtsup.h<br>
-base/wrfont.c<br>
-base/wrfont.h<br>
-base/write_t1.c<br>
-base/write_t1.h<br>
-base/write_t2.c<br>
-base/write_t2.h<br>
-base/x_.h<br>
-base/zlib.mak<br>
-configure.ac<br>
-contrib/gdevadmp.c<br>
-devices/contrib.mak<br>
-devices/devs.mak<br>
-devices/gdev3852.c<br>
-devices/gdev4081.c<br>
-devices/gdev8510.c<br>
-devices/gdev8bcm.c<br>
-devices/gdev8bcm.h<br>
-devices/gdevatx.c<br>
-devices/gdevbit.c<br>
-devices/gdevbj10.c<br>
-devices/gdevbjc.h<br>
-devices/gdevbjcl.c<br>
-devices/gdevbjcl.h<br>
-devices/gdevbmp.c<br>
-devices/gdevbmp.h<br>
-devices/gdevbmpc.c<br>
-devices/gdevccr.c<br>
-devices/gdevcdj.c<br>
-devices/gdevcfax.c<br>
-devices/gdevchameleon.c<br>
-devices/gdevcif.c<br>
-devices/gdevclj.c<br>
-devices/gdevcljc.c<br>
-devices/gdevcmykog.c<br>
-devices/gdevcslw.c<br>
-devices/gdevdfax.c<br>
-devices/gdevdjet.c<br>
-devices/gdevdjtc.c<br>
-devices/gdevdljm.c<br>
-devices/gdevdljm.h<br>
-devices/gdevdm24.c<br>
-devices/gdevdsp.c<br>
-devices/gdevdsp.h<br>
-devices/gdevdsp2.h<br>
-devices/gdevepsc.c<br>
-devices/gdevepsn.c<br>
-devices/gdevescp.c<br>
-devices/gdevfax.c<br>
-devices/gdevfax.h<br>
-devices/gdevfpng.c<br>
-devices/gdevhl7x.c<br>
-devices/gdevicov.c<br>
-devices/gdevijs.c<br>
-devices/gdevimgn.c<br>
-devices/gdevjbig2.c<br>
-devices/gdevjpeg.c<br>
-devices/gdevjpx.c<br>
-devices/gdevl31s.c<br>
-devices/gdevlbp8.c<br>
-devices/gdevlj56.c<br>
-devices/gdevlp8k.c<br>
-devices/gdevlxm.c<br>
-devices/gdevmeds.c<br>
-devices/gdevmeds.h<br>
-devices/gdevmgr.c<br>
-devices/gdevmgr.h<br>
-devices/gdevmiff.c<br>
-devices/gdevn533.c<br>
-devices/gdevo182.c<br>
-devices/gdevokii.c<br>
-devices/gdevpbm.c<br>
-devices/gdevpcl.c<br>
-devices/gdevpcl.h<br>
-devices/gdevpcx.c<br>
-devices/gdevpdfimg.c<br>
-devices/gdevpe.c<br>
-devices/gdevperm.c<br>
-devices/gdevphex.c<br>
-devices/gdevpjet.c<br>
-devices/gdevplan.c<br>
-devices/gdevplib.c<br>
-devices/gdevplib.h<br>
-devices/gdevpm.h<br>
-devices/gdevpng.c<br>
-devices/gdevpsd.c<br>
-devices/gdevpsd.h<br>
-devices/gdevpsim.c<br>
-devices/gdevpxut.c<br>
-devices/gdevpxut.h<br>
-devices/gdevrinkj.c<br>
-devices/gdevsj48.c<br>
-devices/gdevsnfb.c<br>
-devices/gdevsppr.c<br>
-devices/gdevstc.c<br>
-devices/gdevstc.h<br>
-devices/gdevstc1.c<br>
-devices/gdevstc2.c<br>
-devices/gdevstc3.c<br>
-devices/gdevstc4.c<br>
-devices/gdevtfax.c<br>
-devices/gdevtfax.h<br>
-devices/gdevtfnx.c<br>
-devices/gdevtifs.c<br>
-devices/gdevtifs.h<br>
-devices/gdevtknk.c<br>
-devices/gdevtrac.c<br>
-devices/gdevtsep.c<br>
-devices/gdevupd.c<br>
-devices/gdevwpr2.c<br>
-devices/gdevx.c<br>
-devices/gdevx.h<br>
-devices/gdevxalt.c<br>
-devices/gdevxcf.c<br>
-devices/gdevxcmp.c<br>
-devices/gdevxcmp.h<br>
-devices/gdevxini.c<br>
-devices/gdevxres.c<br>
-devices/gxfcopy.c<br>
-devices/gxfcopy.h<br>
-devices/minftrsz.c<br>
-devices/minftrsz.h<br>
-devices/rinkj/evenbetter-rll.c<br>
-devices/rinkj/evenbetter-rll.h<br>
-devices/rinkj/rinkj-byte-stream.c<br>
-devices/rinkj/rinkj-byte-stream.h<br>
-devices/rinkj/rinkj-config.c<br>
-devices/rinkj/rinkj-config.h<br>
-devices/rinkj/rinkj-device.c<br>
-devices/rinkj/rinkj-device.h<br>
-devices/rinkj/rinkj-dither.c<br>
-devices/rinkj/rinkj-dither.h<br>
-devices/rinkj/rinkj-epson870.c<br>
-devices/rinkj/rinkj-epson870.h<br>
-devices/rinkj/rinkj-screen-eb.c<br>
-devices/rinkj/rinkj-screen-eb.h<br>
-devices/vector/gdevagl.c<br>
-devices/vector/gdevagl.h<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfb.c<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfc.c<br>
-devices/vector/gdevpdfc.h<br>
-devices/vector/gdevpdfd.c<br>
-devices/vector/gdevpdfe.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfg.h<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdfj.c<br>
-devices/vector/gdevpdfk.c<br>
-devices/vector/gdevpdfm.c<br>
-devices/vector/gdevpdfo.c<br>
-devices/vector/gdevpdfo.h<br>
-devices/vector/gdevpdfp.c<br>
-devices/vector/gdevpdfr.c<br>
-devices/vector/gdevpdft.c<br>
-devices/vector/gdevpdfu.c<br>
-devices/vector/gdevpdfv.c<br>
-devices/vector/gdevpdfx.h<br>
-devices/vector/gdevpdt.c<br>
-devices/vector/gdevpdt.h<br>
-devices/vector/gdevpdtb.c<br>
-devices/vector/gdevpdtb.h<br>
-devices/vector/gdevpdtc.c<br>
-devices/vector/gdevpdtd.c<br>
-devices/vector/gdevpdtd.h<br>
-devices/vector/gdevpdte.c<br>
-devices/vector/gdevpdtf.c<br>
-devices/vector/gdevpdtf.h<br>
-devices/vector/gdevpdti.c<br>
-devices/vector/gdevpdti.h<br>
-devices/vector/gdevpdts.c<br>
-devices/vector/gdevpdts.h<br>
-devices/vector/gdevpdtt.c<br>
-devices/vector/gdevpdtt.h<br>
-devices/vector/gdevpdtv.c<br>
-devices/vector/gdevpdtv.h<br>
-devices/vector/gdevpdtw.c<br>
-devices/vector/gdevpdtw.h<br>
-devices/vector/gdevpdtx.h<br>
-devices/vector/gdevpsdf.h<br>
-devices/vector/gdevpsdi.c<br>
-devices/vector/gdevpsdp.c<br>
-devices/vector/gdevpsds.c<br>
-devices/vector/gdevpsds.h<br>
-devices/vector/gdevpsdu.c<br>
-devices/vector/gdevpsf.h<br>
-devices/vector/gdevpsf1.c<br>
-devices/vector/gdevpsf2.c<br>
-devices/vector/gdevpsfm.c<br>
-devices/vector/gdevpsft.c<br>
-devices/vector/gdevpsfu.c<br>
-devices/vector/gdevpsfx.c<br>
-devices/vector/gdevpsu.c<br>
-devices/vector/gdevpsu.h<br>
-devices/vector/gdevpx.c<br>
-devices/vector/gdevtxtw.c<br>
-devices/vector/gdevxps.c<br>
-devices/vector/opdfread.ps<br>
-devices/vector/whitelst.c<br>
-devices/vector/whitelst.h<br>
-doc/API.htm<br>
-doc/C-style.htm<br>
-doc/Commprod.htm<br>
-doc/DLL.htm<br>
-doc/Deprecated.htm<br>
-doc/Devices.htm<br>
-doc/Drivers.htm<br>
-doc/Fonts.htm<br>
-doc/History9.htm<br>
-doc/Install.htm<br>
-doc/Internal.htm<br>
-doc/Language.htm<br>
-doc/Lib.htm<br>
-doc/Make.htm<br>
-doc/Ps-style.htm<br>
-doc/Ps2epsi.htm<br>
-doc/Psfiles.htm<br>
-doc/Readme.htm<br>
-doc/Release.htm<br>
-doc/Source.htm<br>
-doc/Unix-lpr.htm<br>
-doc/Use.htm<br>
-doc/VectorDevices.htm<br>
-doc/WhatIsGS.htm<br>
-gpdl/gpdl.mak<br>
-gpdl/jbig2top.c<br>
-gpdl/jp2ktop.c<br>
-gpdl/jpgtop.c<br>
-gpdl/pngtop.c<br>
-gpdl/psitop.c<br>
-gpdl/pspcl6_gcc.mak<br>
-gpdl/pspcl6_msvc.mak<br>
-gpdl/pwgtop.c<br>
-gpdl/tifftop.c<br>
-ijs/Makefile.am<br>
-ijs/configure.ac<br>
-ijs/ijs.c<br>
-ijs/ijs.h<br>
-ijs/ijs_client.c<br>
-ijs/ijs_client.h<br>
-ijs/ijs_client_example.c<br>
-ijs/ijs_exec_unix.c<br>
-ijs/ijs_exec_win.c<br>
-ijs/ijs_server.c<br>
-ijs/ijs_server_example.c<br>
-ijs/unistd_.h<br>
-ios/ios_arch-arm.h<br>
-ios/ios_arch-x86.h<br>
-jbig2dec/config_win32.h<br>
-jbig2dec/jbig2.c<br>
-jbig2dec/jbig2.h<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_generic.h<br>
-jbig2dec/jbig2_halftone.c<br>
-jbig2dec/jbig2_halftone.h<br>
-jbig2dec/jbig2_huffman.c<br>
-jbig2dec/jbig2_huffman.h<br>
-jbig2dec/jbig2_hufftab.c<br>
-jbig2dec/jbig2_hufftab.h<br>
-jbig2dec/jbig2_image.c<br>
-jbig2dec/jbig2_image.h<br>
-jbig2dec/jbig2_image_pbm.c<br>
-jbig2dec/jbig2_image_png.c<br>
-jbig2dec/jbig2_image_rw.h<br>
-jbig2dec/jbig2_mmr.c<br>
-jbig2dec/jbig2_mmr.h<br>
-jbig2dec/jbig2_page.c<br>
-jbig2dec/jbig2_page.h<br>
-jbig2dec/jbig2_priv.h<br>
-jbig2dec/jbig2_refinement.c<br>
-jbig2dec/jbig2_refinement.h<br>
-jbig2dec/jbig2_segment.c<br>
-jbig2dec/jbig2_segment.h<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-jbig2dec/jbig2_symbol_dict.h<br>
-jbig2dec/jbig2_text.c<br>
-jbig2dec/jbig2_text.h<br>
-jbig2dec/jbig2dec.c<br>
-jbig2dec/memcmp.c<br>
-jbig2dec/os_types.h<br>
-jbig2dec/pbm2png.c<br>
-lib/FCOfontmap-PCLPS3<br>
-lib/FCOfontmap-PS3<br>
-lib/Fontmap.ATB<br>
-lib/Fontmap.ATM<br>
-lib/Fontmap.OS2<br>
-lib/Fontmap.SGI<br>
-lib/Fontmap.Sol<br>
-lib/Fontmap.Ult<br>
-lib/Fontmap.VMS<br>
-lib/align.ps<br>
-lib/caption.ps<br>
-lib/cat.ps<br>
-lib/cid2code.ps<br>
-lib/docie.ps<br>
-lib/font2pcl.ps<br>
-lib/gs_ce_e.ps<br>
-lib/gs_il2_e.ps<br>
-lib/gs_kanji.ps<br>
-lib/gs_ksb_e.ps<br>
-lib/gs_lgo_e.ps<br>
-lib/gs_lgx_e.ps<br>
-lib/gs_wl1_e.ps<br>
-lib/gs_wl2_e.ps<br>
-lib/gs_wl5_e.ps<br>
-lib/gslp.ps<br>
-lib/gsnup.ps<br>
-lib/image-qa.ps<br>
-lib/jispaper.ps<br>
-lib/lines.ps<br>
-lib/mkcidfm.ps<br>
-lib/pdf2dsc.ps<br>
-lib/pdf_info.ps<br>
-lib/pfbtopfa.ps<br>
-lib/ppath.ps<br>
-lib/pphs.ps<br>
-lib/prfont.ps<br>
-lib/ps2ai.ps<br>
-lib/ps2epsi.ps<br>
-lib/rollconv.ps<br>
-lib/stcinfo.ps<br>
-lib/stcolor.ps<br>
-lib/stocht.ps<br>
-lib/traceimg.ps<br>
-lib/traceop.ps<br>
-lib/uninfo.ps<br>
-lib/viewcmyk.ps<br>
-lib/viewgif.ps<br>
-lib/viewmiff.ps<br>
-lib/viewpbm.ps<br>
-lib/viewpcx.ps<br>
-lib/viewps2a.ps<br>
-lib/viewraw.ps<br>
-lib/viewrgb.ps<br>
-lib/winmaps.ps<br>
-lib/zeroline.ps<br>
-pcl/pcl/pcbiptrn.c<br>
-pcl/pcl/pcbiptrn.h<br>
-pcl/pcl/pccid.c<br>
-pcl/pcl/pccid.h<br>
-pcl/pcl/pccolor.c<br>
-pcl/pcl/pccoord.h<br>
-pcl/pcl/pccprint.c<br>
-pcl/pcl/pccsbase.c<br>
-pcl/pcl/pccsbase.h<br>
-pcl/pcl/pcdict.h<br>
-pcl/pcl/pcdither.c<br>
-pcl/pcl/pcdither.h<br>
-pcl/pcl/pcdraw.c<br>
-pcl/pcl/pcdraw.h<br>
-pcl/pcl/pcfont.c<br>
-pcl/pcl/pcfont.h<br>
-pcl/pcl/pcfontpg.c<br>
-pcl/pcl/pcfontst.h<br>
-pcl/pcl/pcfrgrnd.c<br>
-pcl/pcl/pcfrgrnd.h<br>
-pcl/pcl/pcfsel.c<br>
-pcl/pcl/pcfsel.h<br>
-pcl/pcl/pcht.c<br>
-pcl/pcl/pcht.h<br>
-pcl/pcl/pcident.c<br>
-pcl/pcl/pcident.h<br>
-pcl/pcl/pcimpl.c<br>
-pcl/pcl/pcindxed.c<br>
-pcl/pcl/pcindxed.h<br>
-pcl/pcl/pcjob.c<br>
-pcl/pcl/pcl.mak<br>
-pcl/pcl/pcl_top.mak<br>
-pcl/pcl/pclookup.c<br>
-pcl/pcl/pclookup.h<br>
-pcl/pcl/pcmacros.c<br>
-pcl/pcl/pcmisc.c<br>
-pcl/pcl/pcmtx3.c<br>
-pcl/pcl/pcmtx3.h<br>
-pcl/pcl/pcommand.c<br>
-pcl/pcl/pcommand.h<br>
-pcl/pcl/pcpage.c<br>
-pcl/pcl/pcpage.h<br>
-pcl/pcl/pcpalet.c<br>
-pcl/pcl/pcpalet.h<br>
-pcl/pcl/pcparam.h<br>
-pcl/pcl/pcparse.c<br>
-pcl/pcl/pcparse.h<br>
-pcl/pcl/pcpatrn.c<br>
-pcl/pcl/pcpatrn.h<br>
-pcl/pcl/pcpattyp.h<br>
-pcl/pcl/pcpatxfm.c<br>
-pcl/pcl/pcpatxfm.h<br>
-pcl/pcl/pcrect.c<br>
-pcl/pcl/pcsfont.c<br>
-pcl/pcl/pcstate.h<br>
-pcl/pcl/pcstatus.c<br>
-pcl/pcl/pcsymbol.c<br>
-pcl/pcl/pcsymbol.h<br>
-pcl/pcl/pctext.c<br>
-pcl/pcl/pctop.c<br>
-pcl/pcl/pctop.h<br>
-pcl/pcl/pctpm.h<br>
-pcl/pcl/pcuptrn.c<br>
-pcl/pcl/pcuptrn.h<br>
-pcl/pcl/pcursor.c<br>
-pcl/pcl/pcursor.h<br>
-pcl/pcl/pcwhtidx.c<br>
-pcl/pcl/pcwhtidx.h<br>
-pcl/pcl/pcxfmst.h<br>
-pcl/pcl/pgchar.c<br>
-pcl/pcl/pgcolor.c<br>
-pcl/pcl/pgconfig.c<br>
-pcl/pcl/pgdraw.c<br>
-pcl/pcl/pgdraw.h<br>
-pcl/pcl/pgfdata.c<br>
-pcl/pcl/pgfdata.h<br>
-pcl/pcl/pgfont.c<br>
-pcl/pcl/pgfont.h<br>
-pcl/pcl/pgframe.c<br>
-pcl/pcl/pggeom.c<br>
-pcl/pcl/pggeom.h<br>
-pcl/pcl/pginit.c<br>
-pcl/pcl/pginit.h<br>
-pcl/pcl/pglabel.c<br>
-pcl/pcl/pglfill.c<br>
-pcl/pcl/pgmand.h<br>
-pcl/pcl/pgmisc.c<br>
-pcl/pcl/pgmisc.h<br>
-pcl/pcl/pgparse.c<br>
-pcl/pcl/pgpoly.c<br>
-pcl/pcl/pgstate.h<br>
-pcl/pcl/pgvector.c<br>
-pcl/pcl/rtgmode.c<br>
-pcl/pcl/rtgmode.h<br>
-pcl/pcl/rtmisc.c<br>
-pcl/pcl/rtmisc.h<br>
-pcl/pcl/rtraster.c<br>
-pcl/pcl/rtraster.h<br>
-pcl/pcl/rtrstcmp.c<br>
-pcl/pcl/rtrstcmp.h<br>
-pcl/pcl/rtrstst.h<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/pjparse.h<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/pjtop.c<br>
-pcl/pl/pjtop.h<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plalloc.c<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plchar.c<br>
-pcl/pl/plchar.h<br>
-pcl/pl/pldebug.h<br>
-pcl/pl/pldict.c<br>
-pcl/pl/pldict.h<br>
-pcl/pl/pldraw.c<br>
-pcl/pl/pldraw.h<br>
-pcl/pl/plfapi.c<br>
-pcl/pl/plfapi.h<br>
-pcl/pl/plfont.c<br>
-pcl/pl/plfont.h<br>
-pcl/pl/plftable.c<br>
-pcl/pl/plftable.h<br>
-pcl/pl/plht.c<br>
-pcl/pl/plht.h<br>
-pcl/pl/plimpl.c<br>
-pcl/pl/pllfont.c<br>
-pcl/pl/pllfont.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pl/plparams.c<br>
-pcl/pl/plparams.h<br>
-pcl/pl/plparse.h<br>
-pcl/pl/plromfs.mak<br>
-pcl/pl/plsymbol.c<br>
-pcl/pl/plsymbol.h<br>
-pcl/pl/pltop.c<br>
-pcl/pl/pltop.h<br>
-pcl/pl/pluchar.c<br>
-pcl/pl/plufont.c<br>
-pcl/pl/plufstlp.c<br>
-pcl/pl/plufstlp.h<br>
-pcl/pl/plufstlp1.c<br>
-pcl/pl/plulfont.c<br>
-pcl/pl/plvalue.c<br>
-pcl/pl/plvalue.h<br>
-pcl/pl/plvocab.c<br>
-pcl/pl/plvocab.h<br>
-pcl/pl/plwimg.c<br>
-pcl/pl/plwimg.h<br>
-pcl/pl/plwmainc.c<br>
-pcl/pl/plwreg.c<br>
-pcl/pl/plwreg.h<br>
-pcl/pl/plwres.h<br>
-pcl/pl/realmain.c<br>
-pcl/pxl/pxasm.ps<br>
-pcl/pxl/pxattr.h<br>
-pcl/pxl/pxbfont.c<br>
-pcl/pxl/pxbfont.h<br>
-pcl/pxl/pxbfont.ps<br>
-pcl/pxl/pxcet.txt<br>
-pcl/pxl/pxdict.h<br>
-pcl/pxl/pxdiff.txt<br>
-pcl/pxl/pxenum.h<br>
-pcl/pxl/pxerrors.c<br>
-pcl/pxl/pxerrors.h<br>
-pcl/pxl/pxffont.c<br>
-pcl/pxl/pxfont.c<br>
-pcl/pxl/pxfont.h<br>
-pcl/pxl/pxfts.txt<br>
-pcl/pxl/pxgstate.c<br>
-pcl/pxl/pxgstate.h<br>
-pcl/pxl/pximage.c<br>
-pcl/pxl/pximpl.c<br>
-pcl/pxl/pxink.c<br>
-pcl/pxl/pxl.mak<br>
-pcl/pxl/pxlib.txt<br>
-pcl/pxl/pxoper.h<br>
-pcl/pxl/pxpaint.c<br>
-pcl/pxl/pxparse.c<br>
-pcl/pxl/pxparse.h<br>
-pcl/pxl/pxptable.c<br>
-pcl/pxl/pxptable.h<br>
-pcl/pxl/pxpthr.c<br>
-pcl/pxl/pxpthr.h<br>
-pcl/pxl/pxsessio.c<br>
-pcl/pxl/pxspec.txt<br>
-pcl/pxl/pxstate.c<br>
-pcl/pxl/pxstate.h<br>
-pcl/pxl/pxstream.c<br>
-pcl/pxl/pxsymbol.ps<br>
-pcl/pxl/pxsymbol.psc<br>
-pcl/pxl/pxsymbol.psh<br>
-pcl/pxl/pxtag.h<br>
-pcl/pxl/pxtop.c<br>
-pcl/pxl/pxvalue.c<br>
-pcl/pxl/pxvalue.h<br>
-pcl/tools/pxlasm.py<br>
-pcl/tools/pxldis.py<br>
-pcl/tools/suite.tcl<br>
-psi/bfont.h<br>
-psi/btoken.h<br>
-psi/dmmain.c<br>
-psi/dmmain.r<br>
-psi/dpmain.c<br>
-psi/dscparse.c<br>
-psi/dscparse.h<br>
-psi/dstack.h<br>
-psi/dwdll.c<br>
-psi/dwdll.h<br>
-psi/dwimg.c<br>
-psi/dwimg.h<br>
-psi/dwmain.c<br>
-psi/dwmain.rc<br>
-psi/dwmainc.c<br>
-psi/dwnodll.c<br>
-psi/dwreg.c<br>
-psi/dwreg.h<br>
-psi/dwres.h<br>
-psi/dwtext.c<br>
-psi/dwtext.h<br>
-psi/dwtrace.c<br>
-psi/dwtrace.h<br>
-psi/dxmain.c<br>
-psi/dxmainc.c<br>
-psi/estack.h<br>
-psi/files.h<br>
-psi/ghost.h<br>
-psi/gs.c<br>
-psi/gsdll.c<br>
-psi/gsdll2.rc<br>
-psi/gsdll32.rc<br>
-psi/gserver.c<br>
-psi/gsos2.rc<br>
-psi/ialloc.c<br>
-psi/ialloc.h<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-psi/iastate.h<br>
-psi/iastruct.h<br>
-psi/ibnum.c<br>
-psi/ibnum.h<br>
-psi/ichar.h<br>
-psi/ichar1.h<br>
-psi/icharout.h<br>
-psi/icid.h<br>
-psi/icie.h<br>
-psi/icolor.h<br>
-psi/iconf.c<br>
-psi/iconf.h<br>
-psi/icontext.c<br>
-psi/icontext.h<br>
-psi/icremap.h<br>
-psi/icsmap.h<br>
-psi/icstate.h<br>
-psi/iddict.h<br>
-psi/iddstack.h<br>
-psi/idebug.c<br>
-psi/idebug.h<br>
-psi/idict.c<br>
-psi/idict.h<br>
-psi/idictdef.h<br>
-psi/idicttpl.h<br>
-psi/idisp.c<br>
-psi/idisp.h<br>
-psi/idosave.h<br>
-psi/idparam.c<br>
-psi/idparam.h<br>
-psi/idsdata.h<br>
-psi/idstack.c<br>
-psi/idstack.h<br>
-psi/ierrors.h<br>
-psi/iesdata.h<br>
-psi/iestack.h<br>
-psi/ifapi.h<br>
-psi/ifcid.h<br>
-psi/ifilter.h<br>
-psi/ifilter2.h<br>
-psi/ifont.h<br>
-psi/ifont1.h<br>
-psi/ifont2.h<br>
-psi/ifont42.h<br>
-psi/ifrpred.h<br>
-psi/ifunc.h<br>
-psi/ifwpred.h<br>
-psi/igc.c<br>
-psi/igc.h<br>
-psi/igcref.c<br>
-psi/igcstr.c<br>
-psi/igcstr.h<br>
-psi/igstate.h<br>
-psi/iht.h<br>
-psi/iimage.h<br>
-psi/iinit.c<br>
-psi/iinit.h<br>
-psi/ilevel.h<br>
-psi/ilocate.c<br>
-psi/imain.c<br>
-psi/imain.h<br>
-psi/imainarg.c<br>
-psi/imainarg.h<br>
-psi/imemory.h<br>
-psi/iminst.h<br>
-psi/iname.c<br>
-psi/iname.h<br>
-psi/inamedef.h<br>
-psi/inameidx.h<br>
-psi/inames.h<br>
-psi/inamestr.h<br>
-psi/inobtokn.c<br>
-psi/inouparm.c<br>
-psi/int.mak<br>
-psi/interp.c<br>
-psi/interp.h<br>
-psi/iosdata.h<br>
-psi/iostack.h<br>
-psi/ipacked.h<br>
-psi/iparam.c<br>
-psi/iparam.h<br>
-psi/iparray.h<br>
-psi/ipcolor.h<br>
-psi/iplugin.c<br>
-psi/iplugin.h<br>
-psi/ireclaim.c<br>
-psi/iref.h<br>
-psi/isave.c<br>
-psi/isave.h<br>
-psi/iscan.c<br>
-psi/iscan.h<br>
-psi/iscanbin.c<br>
-psi/iscanbin.h<br>
-psi/iscannum.c<br>
-psi/iscannum.h<br>
-psi/isdata.h<br>
-psi/isstate.h<br>
-psi/istack.c<br>
-psi/istack.h<br>
-psi/istkparm.h<br>
-psi/istream.h<br>
-psi/istruct.h<br>
-psi/itoken.h<br>
-psi/iutil.c<br>
-psi/iutil.h<br>
-psi/iutil2.c<br>
-psi/iutil2.h<br>
-psi/ivmem2.h<br>
-psi/ivmspace.h<br>
-psi/main.h<br>
-psi/mkfilelt.cpp<br>
-psi/msvc.mak<br>
-psi/msvc32.mak<br>
-psi/msvc64.mak<br>
-psi/nsisinst.nsi<br>
-psi/oparc.h<br>
-psi/opcheck.h<br>
-psi/opdef.h<br>
-psi/oper.h<br>
-psi/opextern.h<br>
-psi/os2.mak<br>
-psi/ostack.h<br>
-psi/psapi.c<br>
-psi/psapi.h<br>
-psi/psromfs.mak<br>
-psi/store.h<br>
-psi/zalg.c<br>
-psi/zarith.c<br>
-psi/zarray.c<br>
-psi/zbfont.c<br>
-psi/zbseq.c<br>
-psi/zcfont.c<br>
-psi/zchar.c<br>
-psi/zchar1.c<br>
-psi/zchar2.c<br>
-psi/zchar32.c<br>
-psi/zchar42.c<br>
-psi/zchar42.h<br>
-psi/zcharout.c<br>
-psi/zcharx.c<br>
-psi/zcid.c<br>
-psi/zcie.c<br>
-psi/zcie.h<br>
-psi/zcolor.c<br>
-psi/zcolor.h<br>
-psi/zcolor1.c<br>
-psi/zcolor2.c<br>
-psi/zcolor3.c<br>
-psi/zcontrol.c<br>
-psi/zcrd.c<br>
-psi/zcsindex.c<br>
-psi/zcspixel.c<br>
-psi/zcssepr.c<br>
-psi/zdevcal.c<br>
-psi/zdevice.c<br>
-psi/zdevice2.c<br>
-psi/zdfilter.c<br>
-psi/zdict.c<br>
-psi/zdouble.c<br>
-psi/zdps1.c<br>
-psi/zdscpars.c<br>
-psi/zfaes.c<br>
-psi/zfapi.c<br>
-psi/zfarc4.c<br>
-psi/zfbcp.c<br>
-psi/zfcid.c<br>
-psi/zfcid0.c<br>
-psi/zfcid1.c<br>
-psi/zfcmap.c<br>
-psi/zfdctd.c<br>
-psi/zfdcte.c<br>
-psi/zfdecode.c<br>
-psi/zfile.c<br>
-psi/zfile.h<br>
-psi/zfile1.c<br>
-psi/zfileio.c<br>
-psi/zfilter.c<br>
-psi/zfilter2.c<br>
-psi/zfimscale.c<br>
-psi/zfjbig2.c<br>
-psi/zfjpx.c<br>
-psi/zfmd5.c<br>
-psi/zfont.c<br>
-psi/zfont0.c<br>
-psi/zfont1.c<br>
-psi/zfont2.c<br>
-psi/zfont32.c<br>
-psi/zfont42.c<br>
-psi/zfontenum.c<br>
-psi/zform.c<br>
-psi/zfproc.c<br>
-psi/zfrsd.c<br>
-psi/zfrsd.h<br>
-psi/zfsample.c<br>
-psi/zfsha2.c<br>
-psi/zfunc.c<br>
-psi/zfunc.h<br>
-psi/zfunc0.c<br>
-psi/zfunc3.c<br>
-psi/zfunc4.c<br>
-psi/zfzlib.c<br>
-psi/zgeneric.c<br>
-psi/zgstate.c<br>
-psi/zht.c<br>
-psi/zht1.c<br>
-psi/zht2.c<br>
-psi/zht2.h<br>
-psi/zicc.c<br>
-psi/zicc.h<br>
-psi/zimage.c<br>
-psi/zimage3.c<br>
-psi/ziodev.c<br>
-psi/ziodev2.c<br>
-psi/ziodevsc.c<br>
-psi/zmath.c<br>
-psi/zmatrix.c<br>
-psi/zmedia2.c<br>
-psi/zmisc.c<br>
-psi/zmisc1.c<br>
-psi/zmisc2.c<br>
-psi/zmisc3.c<br>
-psi/zncdummy.c<br>
-psi/zpacked.c<br>
-psi/zpaint.c<br>
-psi/zpath.c<br>
-psi/zpath1.c<br>
-psi/zpcolor.c<br>
-psi/zpdf_r6.c<br>
-psi/zpdfops.c<br>
-psi/zrelbit.c<br>
-psi/zshade.c<br>
-psi/zstack.c<br>
-psi/zstring.c<br>
-psi/zsysvm.c<br>
-psi/ztoken.c<br>
-psi/ztrans.c<br>
-psi/ztrap.c<br>
-psi/ztype.c<br>
-psi/zupath.c<br>
-psi/zusparam.c<br>
-psi/zutf8.c<br>
-psi/zvmem.c<br>
-psi/zvmem2.c<br>
-psi/zwinutf8.c<br>
-toolbin/GenSubstCID.ps<br>
-toolbin/afmutil.py<br>
-toolbin/color/icc_creator/ICC_Creator/CIELAB.h<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_Creator.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_Creator.h<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.h<br>
-toolbin/color/icc_creator/ICC_Creator/icc_create.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/icc_create.h<br>
-toolbin/color/icc_creator/README.txt<br>
-toolbin/encs2c.ps<br>
-toolbin/errlist.tcl<br>
-toolbin/extractFonts.ps<br>
-toolbin/extractICCprofiles.ps<br>
-toolbin/gen_ldf_jb2.py<br>
-toolbin/genfontmap.ps<br>
-toolbin/gitlog2changelog.py<br>
-toolbin/gsmake.tcl<br>
-toolbin/halftone/gen_ordered/gen_ordered_main.c<br>
-toolbin/halftone/gen_stochastic/gen_stochastic.c<br>
-toolbin/headers.tcl<br>
-toolbin/jpxtopdf.c<br>
-toolbin/leaks.tcl<br>
-toolbin/makehist.tcl<br>
-toolbin/memory.py<br>
-toolbin/ocheck.py<br>
-toolbin/pre.tcl<br>
-toolbin/precheck.tcl<br>
-toolbin/split_changelog.py<br>
-toolbin/suite.tcl<br>
-toolbin/tests/build_revision.py<br>
-toolbin/tests/check_all.py<br>
-toolbin/tests/check_comments.py<br>
-toolbin/tests/check_dirs.py<br>
-toolbin/tests/check_docrefs.py<br>
-toolbin/tests/cmpi.py<br>
-toolbin/tests/compare_checksumdb.py<br>
-toolbin/tests/compare_checksums.py<br>
-toolbin/tests/dump_checksum.py<br>
-toolbin/tests/dump_checksum_plus.py<br>
-toolbin/tests/dump_checksum_raw.py<br>
-toolbin/tests/fuzzy.c<br>
-toolbin/tests/get_baseline_log.py<br>
-toolbin/tests/get_baselines.py<br>
-toolbin/tests/gscheck_all.py<br>
-toolbin/tests/gscheck_fuzzypdf.py<br>
-toolbin/tests/gscheck_pdfwrite.py<br>
-toolbin/tests/gscheck_raster.py<br>
-toolbin/tests/gscheck_testfiles.py<br>
-toolbin/tests/gsconf.py<br>
-toolbin/tests/gsparamsets.py<br>
-toolbin/tests/gssum.py<br>
-toolbin/tests/gstestgs.py<br>
-toolbin/tests/gstestutils.py<br>
-toolbin/tests/gsutil.py<br>
-toolbin/tests/make_baselinedb.py<br>
-toolbin/tests/make_testdb.py<br>
-toolbin/tests/make_two_pdfversions<br>
-toolbin/tests/make_two_versions<br>
-toolbin/tests/myoptparse.py<br>
-toolbin/tests/rasterdb.py<br>
-toolbin/tests/revert_baseline<br>
-toolbin/tests/revert_pdfbaseline<br>
-toolbin/tests/run_nightly.py<br>
-toolbin/tests/run_parallel<br>
-toolbin/tests/run_regression.py<br>
-toolbin/tests/testdiff.py<br>
-toolbin/tests/update_baseline.py<br>
-toolbin/tests/update_specific<br>
-toolbin/tmake.tcl<br>
-xps/ghostxps.h<br>
-xps/xps.mak<br>
-xps/xpsanalyze.c<br>
-xps/xpscff.c<br>
-xps/xpscolor.c<br>
-xps/xpscommon.c<br>
-xps/xpscrc.c<br>
-xps/xpsdoc.c<br>
-xps/xpsfapi.c<br>
-xps/xpsfapi.h<br>
-xps/xpsfont.c<br>
-xps/xpsglyphs.c<br>
-xps/xpsgradient.c<br>
-xps/xpshash.c<br>
-xps/xpsimage.c<br>
-xps/xpsjpeg.c<br>
-xps/xpsjxr.c<br>
-xps/xpsmem.c<br>
-xps/xpsopacity.c<br>
-xps/xpspage.c<br>
-xps/xpspath.c<br>
-xps/xpspng.c<br>
-xps/xpsresource.c<br>
-xps/xpsromfs.mak<br>
-xps/xpstiff.c<br>
-xps/xpstile.c<br>
-xps/xpstop.c<br>
-xps/xpsttf.c<br>
-xps/xpsutf.c<br>
-xps/xpsvisual.c<br>
-xps/xpsxml.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-09 09:40: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=87688cd48fb52c305e159b785bd184232426a766">87688cd48fb52c305e159b785bd184232426a766</a>
-<blockquote>
-<p>
- Bug 702322: fix uninitalized data reads<br>
-<br>
- gs_scan_token() keeps a local copy of the scanner state, and copies from and to<br>
- the scanner state that is passed into it. There are several code paths that<br>
- can leave some important entries in the structure uninitalized when we copy the<br>
- local copy to the parameter.<br>
-<br>
- This just ensures those specific entries are always set to *something* sane.<br>
-<br>
-psi/iscan.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-09 09:07: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=c96962212ed44463b3bd5cf34f3f790e9d14cd0b">c96962212ed44463b3bd5cf34f3f790e9d14cd0b</a>
-<blockquote>
-<p>
- Clarify path matching for SAFER controls<br>
-<br>
- Make it explicit that the 'form' of the paths (e.g. absolute vs relative) must<br>
- match between --permit-file-* paramters and the actual path used to reference<br>
- the file<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-08 16:06: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=ebabebad34a3811230b7bfe351eface7f5efc8a9">ebabebad34a3811230b7bfe351eface7f5efc8a9</a>
-<blockquote>
-<p>
- PostScript interpreter - don't leave A85Decode pdf_rules uninitialised<br>
-<br>
- Bug #702319 &quot;Read of uninitialized value according to valgrind...&quot;<br>
-<br>
- There are a number of other bugs which relate to this particular problem:<br>
- 690976, 692983 and 693485. The problem has come about as a cumulative<br>
- result of working on these bugs.<br>
-<br>
- Starting with commit :<br>
- http://git.ghostscript.com/?p=ghostpdl.git;a=commit;h=e0ecca32ecd12dae3310fac4b65dc224031c85a2<br>
- for bug 690976 a new flag 'pdf_rules' was added to the Ascii85Decode<br>
- state. This is initialised from the dictionary operand in PostScript<br>
- by zA85D() in zfdecode.c. When this flag is true the ASCII85Decode<br>
- filter will silently accept just '~' as a valid termination for a string<br>
- (should be '~&gt;').<br>
-<br>
- However this is not the only way to initialise an Ascii85Decode filter,<br>
- the PostScript token scanner can also use s_A85D_init_inline() which<br>
- does not initialise the flag. From this point we have the potential<br>
- for testing an unitialised variable in s_A85D_process(), if we get an<br>
- encoded string which terminates with a '~' and the filter was<br>
- instantiated from PostScript.<br>
-<br>
- When fixing bug 692983, this commit:<br>
- http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d561224d1495321d40012230abbcf835b298f557<br>
-<br>
- Alex specifically added a comment that pdf_rules must not be initialised<br>
- in s_A85D_init_inline() but didn't say why! The reason is that the<br>
- regular stream initialisation code (s_A85D-init) also uses this inline<br>
- function, so if it altered pdf_rules it would overwrite the value<br>
- previously set by zA85D().<br>
-<br>
- Since the initialisation is done in two places, the only way to fix this<br>
- is to initialise pdf_rules in gs_scan_token() which this commit duly<br>
- does. I've also added comments in s_A85D_init_inline to explain more<br>
- clearly *why* pdf_rules must not be initialised here.<br>
-<br>
-base/sa85d.h<br>
-psi/iscan.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-31 08:26:37 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=668917a10e7eada030f7d2dddec9f579fddeed3d">668917a10e7eada030f7d2dddec9f579fddeed3d</a>
-<blockquote>
-<p>
- Change MaxLocalVM and MaxGlobalVM to be size_t instead of 'long'<br>
-<br>
- The sizeof long differs between 64-bit Windows and linux, and<br>
- Robin changed the Max values for other params to be size_t in<br>
- commit d7961033. This change extends that to the other memory<br>
- size related params.<br>
-<br>
- Also fix vm_threshold to be int64_t, not size_t since that<br>
- corresponds to the parameter setting in zusparam.c. This is<br>
- also limited to the max signed value that corresponds to<br>
- size_t (MAX_VM_THRESHOLD) in case size_t is &lt; 64 bits.<br>
-<br>
-base/gsalloc.c<br>
-base/gsalloc.h<br>
-base/std.h<br>
-psi/ireclaim.c<br>
-psi/ivmem2.h<br>
-psi/zusparam.c<br>
-psi/zvmem2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-05 12:24:36 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d8ed6363166841dcb067d7adc6ad6b52a1b1f90c">d8ed6363166841dcb067d7adc6ad6b52a1b1f90c</a>
-<blockquote>
-<p>
- jbig2dec: Initiate variable before avoids using uninited data during cleanup.<br>
-<br>
- Fixes OSS-fuzz issue 21571.<br>
- Also fixes Coverity CID 355467.<br>
-<br>
- Thanks to OSS-fuzz for reporting.<br>
-<br>
-jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-27 05:41:07 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc6b8098b52db7e1a9b20c1ef6f1006555c04b1b">dc6b8098b52db7e1a9b20c1ef6f1006555c04b1b</a>
-<blockquote>
-<p>
- jbig2dec: Adjust number of bytes consumed by MMR decoder.<br>
-<br>
- The MMR decoder pre-buffers up to 32 bits of encoded input data in a word<br>
- buffer before they are consumed by the MMR decoder. Once bits are consumed, the<br>
- pre-buffer will be filled up with more input data. When filling up the buffer<br>
- the decoder would previously stay clear of reading data belonging to succeeding<br>
- segments, but still indicated that it consumed those bytes it never read. Once<br>
- finished the MMR decoder lied to the caller by propagating the incorrect number<br>
- of consumed bytes. The caller subtracted the consumed number of bytes from the<br>
- size and end up in underflow causing the next MMR decoding to first read input<br>
- data at the wrong location, later ending up attempting to read outside the MMR<br>
- encoded input buffer.<br>
-<br>
- Now, the MMR decoder keeps track of how many bits it has consumed and<br>
- accurately rounds this number up to a whole number of bytes to the caller.<br>
-<br>
- Fixes OSS-fuzz issue 17855.<br>
-<br>
- Thanks to OSS-fuzz for reporting.<br>
-<br>
-jbig2dec/jbig2_mmr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-26 14:20:11 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f14f35c6e3218554cd351b848447cfa83b3c4256">f14f35c6e3218554cd351b848447cfa83b3c4256</a>
-<blockquote>
-<p>
- jbig2dec: Plug leak of image upon error.<br>
-<br>
- Fixes OSS-Fuzz issue 17513.<br>
-<br>
- Thanks to OSS-fuzz for reporting.<br>
-<br>
-jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-25 01:12:52 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d293095a593f7106e16027fb9782324ee7bb36f8">d293095a593f7106e16027fb9782324ee7bb36f8</a>
-<blockquote>
-<p>
- jbig2dec: Need to store local copy of error message.<br>
-<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-02 13:06: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=6728387b7f4b803ea5a26eb220ce24e4ff65e710">6728387b7f4b803ea5a26eb220ce24e4ff65e710</a>
-<blockquote>
-<p>
- PDF interpreter - Fix incorrect CIDFontType2 with Type1C descendants<br>
-<br>
- Customer bug report. The file contains a CIDFont declared like this:<br>
-<br>
- 16 0 obj<br>
- &lt;&lt;<br>
- ...<br>
- /Subtype /CIDFontType2<br>
- ...<br>
- &gt;&gt;<br>
-<br>
- The /Subtype /CIDFontType2 means that the font is a CIDFont with<br>
- TrueType outlines. However the actual font:<br>
-<br>
- 10 0 obj<br>
- &lt;&lt;<br>
- /Subtype /Type1C<br>
- /Length 49432<br>
- /Length1 49432<br>
- &gt;&gt;<br>
-<br>
- is a Type1C (Compact Font Format) font. The PDF file is, quite simply,<br>
- incorrect. The Subtype should be /CIDFontType0. Interestingly we already<br>
- have code in the CIDFontType2 case to handle an incorrect value of<br>
- Subtype being set to /CIDFontType0 so this is the reverse case.<br>
-<br>
- If we discover we are reading a Type1C font, and the parent is a CIDFont<br>
- with a Subtype of CIDFontType2, then change the parent dictionary to<br>
- have a Subtype of /CIDFOntType0C and read the font as a CIDFont.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-01 19:48: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=1c363593d7880b305e5da0cae8964bf090af3e61">1c363593d7880b305e5da0cae8964bf090af3e61</a>
-<blockquote>
-<p>
- Speed up gx_get_bits_std_to_native.<br>
-<br>
- We don't need to fetch the color_mapping_procs for every pixel;<br>
- just once will do.<br>
-<br>
-base/gdevdgbr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-04-01 14:27:33 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=85225cda5e2b2d557942c6ff13887e418eccb6cc">85225cda5e2b2d557942c6ff13887e418eccb6cc</a>
-<blockquote>
-<p>
- Remove pgs-&gt;alpha<br>
-<br>
- The alpha value in the graphic state is not used and will<br>
- only lead to confusion for people working on transparency.<br>
-<br>
-base/gdevp14.c<br>
-base/gsalpha.c<br>
-base/gsalpha.h<br>
-base/gsstate.c<br>
-base/gxclpath.c<br>
-base/gxcmap.c<br>
-base/gxgstate.h<br>
-base/lib.mak<br>
-windows/ghostscript.vcxproj<br>
-windows/ghostscript.vcxproj.filters<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-31 15:17:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=295bcef3b977c12885e30fdbae326f63d0771caa">295bcef3b977c12885e30fdbae326f63d0771caa</a>
-<blockquote>
-<p>
- Squash 'set but unused' warning in gdevcups.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-31 14:59:04 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a32c6fdce5fab7d5918d02d30a4cf6696af58db3">a32c6fdce5fab7d5918d02d30a4cf6696af58db3</a>
-<blockquote>
-<p>
- Squash some compiler warnings.<br>
-<br>
-base/gsicc_cache.c<br>
-base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-31 13:00:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4dd43e9ca448777bbd585ef3ce97e9cf593f395d">4dd43e9ca448777bbd585ef3ce97e9cf593f395d</a>
-<blockquote>
-<p>
- Coverity 355259: Avoid &quot;Failure to restore&quot; warning from coverity.<br>
-<br>
- Coverity complains that pgs-&gt;fillconstantalpha isn't restored<br>
- before the file exits. While we're not too fussed about what<br>
- happens to it in an error condition, simply hoisting a couple<br>
- of lines up a bit solves the problem and should shut it up.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-30 19:01: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=32805b5689be664f9b76502669775baa53f55677">32805b5689be664f9b76502669775baa53f55677</a>
-<blockquote>
-<p>
- Redefine deprecated .setopacityalpha and .setshapealpha<br>
-<br>
- .setopacityalpha and .setshapealpha have been replaced with<br>
- .setfillconstantalpha/.setstrokeconstantalpha and .setalphaisshape, operators<br>
- which actually do what PDF requires.<br>
-<br>
- As an interim measure, to allow users that rely on these operators some time<br>
- to adjust, define versions of .setopacityalpha and .setshapealpha which<br>
- approximate what the old implementations did.<br>
-<br>
- As with the rest of the transparency operators they only exist when gs is<br>
- given the -dALLOWPSTRANSPARENCY option. Also, they are in pdf_main.ps just so<br>
- they grouped in proximity to where the rest of the ALLOWPSTRANSPARENCY logic is<br>
- implemented.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-30 09:59:23 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3ff82b33f24ed54c2d3bb88ec31da7d2f9fd2765">3ff82b33f24ed54c2d3bb88ec31da7d2f9fd2765</a>
-<blockquote>
-<p>
- Fail configure with unsupported shared tiff/jpeg combo<br>
-<br>
- With the changes to support consuming the various TIFF input forms, we cannot<br>
- support all combinations of mixing share and local libtiff and libjpeg.<br>
-<br>
- For simplicity just reject mixing those configs.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-25 14:00: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=6756b355c238c319fe66087dece15174e62f9f15">6756b355c238c319fe66087dece15174e62f9f15</a>
-<blockquote>
-<p>
- Fix shared libtiff and libjpeg build<br>
-<br>
- When building with shared libs, we should not try to include our custom libjpeg<br>
- memory management context into the TIFF reader implementation context.<br>
-<br>
-gpdl/gpdl.mak<br>
-gpdl/tifftop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-30 14:47:25 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b8bda01581b94e9159533460cfe79436f4d5ac21">b8bda01581b94e9159533460cfe79436f4d5ac21</a>
-<blockquote>
-<p>
- Coverity 94826 Add missing offset to buffer size used for clist cmd.<br>
-<br>
-base/gxclpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-29 15:32:36 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b09cbe8e577fb14504932dc8d9096187ec4e0840">b09cbe8e577fb14504932dc8d9096187ec4e0840</a>
-<blockquote>
-<p>
- Fix infinite loop in PDF interpreter 'pagespotcolors' procedure<br>
-<br>
- The file tests_private/pdf/uploads/poc1_pdf_gs.pdf has the single page<br>
- Parent object as itself. This only showed up with &quot;DeviceN&quot; devices that<br>
- search the PDF for the number of spot colorants on the page.<br>
-<br>
- Note that this file is broken in other respects since it has a /Count<br>
- of 9 pages, but only a single page. This change also adds handling for<br>
- the //null object returned when a page isn't found since there isn't<br>
- actually a second page, and adds an error message when this is the case.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-30 12:24:45 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4dde07159da5786570ad4f8d2b7b3c0b828802ab">4dde07159da5786570ad4f8d2b7b3c0b828802ab</a>
-<blockquote>
-<p>
- Coverity 141130 Initialize shape and alpha of group for image.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-30 19:51:57 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=baa1a80f7824e26fb31f5f5f782980518b6cbfd9">baa1a80f7824e26fb31f5f5f782980518b6cbfd9</a>
-<blockquote>
-<p>
- Coverity 355259: Fix precedence of assignment/comparison.<br>
-<br>
- This was leading to code being thought of as being unreachable.<br>
-<br>
-base/gxstroke.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-30 10:45:25 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22a31bda026deb8e3748f25bc2cf3b46263e689c">22a31bda026deb8e3748f25bc2cf3b46263e689c</a>
-<blockquote>
-<p>
- Update doc to deprecate transparency PS methods<br>
-<br>
-doc/Language.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-27 13:54:02 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a3c36f8c5e83448f5d1e5f24ee01c0e80a92877">6a3c36f8c5e83448f5d1e5f24ee01c0e80a92877</a>
-<blockquote>
-<p>
- Fix Bug 702177: VMerrors with some BufferSpace and/or -K limits.<br>
-<br>
- Interestingly, the two examples given in the bug succeed on Windows 64<br>
- but don't on linux. The difference is due to an 8 byte difference in the<br>
- size of gx_clist_state (the per band writer state). In the case of the<br>
- Bug690546.pdf file, the space left in the BufferSpace area after the<br>
- logic increased it was only 2,200 bytes on linux, but was 12k bytes on<br>
- Windows (it made an extra pass through the automatic &quot;increase space&quot;<br>
- loop in gdev_prn_setup_as_command_list. Fix the calculation in<br>
- clist_init_states so that the amount of extra space corresponds to the<br>
- amount expected by clist command writing (data_bits_size + cmd_largest_size)<br>
- rather than the insufficient and arbitrary &quot;100&quot;.<br>
-<br>
- Note that although the Bug692057.pdf returned VMerror from cmd_put_list_op, the<br>
- 'fallback; method of gx_default_strip_tile_rectangle still produces the SAME<br>
- raster from psdcmyk16 and does not change the performance or clist file size<br>
- Robin's commit cbee0840 fixed this case.<br>
-<br>
-base/gxclist.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-27 14:46:05 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d12d2085b5bd08ca1e813d97f3f7f7e630e791a0">d12d2085b5bd08ca1e813d97f3f7f7e630e791a0</a>
-<blockquote>
-<p>
- Squashed commit of the opacity_shape branch<br>
-<br>
- This commit removes shape.alpha and opacity.alpha from the<br>
- graphic state. This involved removal of methods in the<br>
- postscript based PDF interpreter, changes in the pdf14 device,<br>
- changes in pdfwrite, the XPS interpreter, and the PS<br>
- transparency test file that is present in examples and on<br>
- the cluster. The goal of this commit was to avoid<br>
- confusion and conflicts between shape.alpha opacity.alpha and<br>
- the stroke and fill alpha values (CA ca). This change<br>
- resulted in progressions in the XPS file. There were changes<br>
- in a couple PDF files that required some investigation. In<br>
- particular, the change in the dashed lines of Bug694981.pdf. Robin<br>
- and I looked at this. Robin determined it was due to<br>
- differences in stroke_add and stroke_fill not giving identical results.<br>
- In the end, the new output looks closer the what AR provides.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-Resource/Init/pdf_main.ps<br>
-Resource/Init/pdf_ops.ps<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gstparam.h<br>
-base/gstrans.c<br>
-base/gstrans.h<br>
-base/gxblend.c<br>
-base/gxclimag.c<br>
-base/gxclpath.c<br>
-base/gxclpath.h<br>
-base/gxclrast.c<br>
-base/gxgstate.h<br>
-devices/vector/gdevpdft.c<br>
-examples/transparency_example.ps<br>
-psi/ztrans.c<br>
-xps/xpscolor.c<br>
-xps/xpsgradient.c<br>
-xps/xpsimage.c<br>
-xps/xpsopacity.c<br>
-xps/xpspath.c<br>
-xps/xpstile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-27 15:28:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1241ea6848d254de9a9dbcb8c8edf10a59761d1d">1241ea6848d254de9a9dbcb8c8edf10a59761d1d</a>
-<blockquote>
-<p>
- PDF interpreter - cope with Form XObjects leaving junk on the stack<br>
-<br>
- No bug report, customer supplied file. The file has a Form XObject<br>
- where the stream ends:<br>
-<br>
- /Image20 Do Q<br>
- EMC Tendstream<br>
-<br>
- which is clearly invalid. This leaves a T lying around which gets<br>
- converted to a name and remains on the stack. When we come to complete<br>
- the form processing we expect that the stack will be clean, because it<br>
- isn't we end up corrupting an internal variable, which causes the<br>
- *next* Form XObject to fail.<br>
-<br>
- We cope with this here by adding code to check the objects on the stack<br>
- and remove them one by one until we get back to a dictionary which<br>
- contains a name we expect to find (because we pushed it on entry to the<br>
- procedure) or run out of stack objects in which case we will throw an<br>
- error.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-26 19:50:51 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f3e37d28f6a76cb7cfc2a291aeb98b8f1c6ba178">f3e37d28f6a76cb7cfc2a291aeb98b8f1c6ba178</a>
-<blockquote>
-<p>
- Add murun to the list of products for clusterpush.pl<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-26 07:21:57 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3df1313a6ef334d9c6da2fcd78347fb5eb7a3859">3df1313a6ef334d9c6da2fcd78347fb5eb7a3859</a>
-<blockquote>
-<p>
- Fix CID 355224. Non-zero return code not possible, but Coverity doesn't get it.<br>
-<br>
-base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-24 10:15:39 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=748b5c3c86779dc0cf4ccc144530cf37f692375e">748b5c3c86779dc0cf4ccc144530cf37f692375e</a>
-<blockquote>
-<p>
- Rejig &quot;fast&quot; stroking of miter joins.<br>
-<br>
- This spins out of Bug 702196, though it's not strictly speaking<br>
- related. Bug 702196 deals with lines being incorrectly recognised<br>
- as being &quot;thin&quot;. Thin lines aren't mitred. When we fix the<br>
- erroneous classification of lines as thin, this causes more<br>
- lines to be mitre joined than before. This in turn exposes<br>
- the bug that we (partially) fix here.<br>
-<br>
- gs -sDEVICE=pdfwrite -o out.pdf tests_private/ps/ps3cet/11-28.PS<br>
-<br>
- gs -sDEVICE=png16m -o out%d.png -r300 -dMaxBitmap=2G out.pdf<br>
-<br>
- Page 4 of the output shows strange mitre extrusions from the edge<br>
- of paths.<br>
-<br>
- Investigation shows the file is 'strokepath'ing the path (with<br>
- mitre joins), and the stroking the resultant path (again with<br>
- mitre joins). The initial 'strokepath' conversion includes little<br>
- &quot;wedges&quot; of path internally to give the &quot;underjoin&quot; in the path.<br>
- When restroked, due to the mitre join still being set, these<br>
- wedges turn into spikes.<br>
-<br>
- The fix, implemented here, is to revise the way we do mitre joins.<br>
- For paths stroked using the &quot;fast&quot; code, with miter joins, we<br>
- perform slightly more complicated calculations at each join. This<br>
- allows us to do the joins by moving the existing points of the<br>
- paths 'inline'. This removes the need for the 'wedges', and<br>
- actually gives us a much cleaner path overall.<br>
-<br>
- This *should* help with pathological scan conversion cases too,<br>
- because it means we will have fewer 'sleepers' in the 'train<br>
- tracks' when strokepath is used.<br>
-<br>
- This may not kick in in all cases where we'd like it to, because<br>
- for some files, we use 'traditional' stroking, and so don't<br>
- execute this code. One way around this would be to change<br>
- gs_strokepath to disable 'traditional' filling in the presence<br>
- of mitre joins, but that produces strange effects, so we're<br>
- leaving it for now.<br>
-<br>
-base/gxstroke.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-18 15:11: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=9dc0eb31d79bf819c97420aaf2f6fc5cf3a52c10">9dc0eb31d79bf819c97420aaf2f6fc5cf3a52c10</a>
-<blockquote>
-<p>
- Bug 702196: Fix incorrect detection of &quot;thin&quot; lines while stroking.<br>
-<br>
- When stroking lines, we spot whether a line is 'thin' (i.e. the<br>
- perpendicular width of the line is less than 1 pixel), and handle<br>
- those cases specially by using custom 'thin line' routines. This<br>
- gives more pleasing results than slavishly following the 'any part<br>
- of a pixel' rule.<br>
-<br>
- The current code makes this determination in 2 places. Firstly,<br>
- we calculate 'always_thin', by scaling the perpendicular vector<br>
- and seeing if all possible lines will be 'thin'. Secondly, in<br>
- the case when we aren't 'always_thin', we calculate it for each<br>
- line segment in turn by calling 'width_is_thin'.<br>
-<br>
- Unfortunately, the threshold used for the simple early rejection<br>
- test in 'width_is_thin' is wrong. Rather than checking against<br>
- 0.5, we should be checking against sqrt(1/8). This causes lines<br>
- near 45 degrees to be improperly treated as thin. This is a<br>
- simple fix.<br>
-<br>
- This gives lots of progressions - so many that you wonder how we<br>
- never spotted this before.<br>
-<br>
- Unfortunately, buried in these progressions, there are a few files<br>
- which, while improved, are still imperfect.<br>
-<br>
- In some files, that use 'non-uniform' scales, (such as<br>
- (53 0 0 21 0 0 )) a stroke of constant width can 'pop' between<br>
- thick and thin as we move around the path; a near vertical<br>
- line segment may be thin, whereas a near horizontal line segment<br>
- might be thick due to the difference in scale. This is visually<br>
- jarring.<br>
-<br>
- To fix this, therefore, we'd need to modify the width_is_thin<br>
- testing in non-uniform cases, so that it gives us the same results<br>
- all the way around. Doing this would be complex, and ultimately<br>
- actually ends up equivalent to us just relying on &quot;always_thin&quot;<br>
- (with the exception of strictly vertical and horizontal line<br>
- segements). We therefore disable the non-orthogonal test in<br>
- 'width_is_thin' entirely.<br>
-<br>
-base/gxstroke.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-24 16:49:13 -0700
-</strong>
-<br>ray &lt;Ray.Johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d49dbf133ac49d09d626bab08ee92835a50a646a">d49dbf133ac49d09d626bab08ee92835a50a646a</a>
-<blockquote>
-<p>
- Fix bug 702182: VMerror due to leaks in pattern cache due to locking.<br>
-<br>
- If the tile being loaded by the clist reader was already in the cache and<br>
- was locked, the slot would be re-loaded (with the same tile) without freeing<br>
- up the previously loaded tile. It would be nicer to be able to skip reading<br>
- the tile in this case, but we need to consume the data from the clist sequence,<br>
- so just unlock it so it can be freed, then re-load it (presumably setting the<br>
- lock again).<br>
-<br>
-base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-24 18:09: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=1258814b0532f06217cbfaffc5254c9645f69b42">1258814b0532f06217cbfaffc5254c9645f69b42</a>
-<blockquote>
-<p>
- Don't delete copied libjpeg source files after use<br>
-<br>
- For reasons I'm not totally convinced are still valid, we copy the libpeg source<br>
- files into the build directory (normally 'obj') and compile them from there,<br>
- then delete them.<br>
-<br>
- This apparently causes problems with oss-fuzz coverage builds, and it also makes<br>
- debugging a pain, because the source files don't exist where the debug info<br>
- thinks they should.<br>
-<br>
-base/jpeg.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-24 15:22: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=0ec0004cb9366002dbd97f40c32d8da6d33c1904">0ec0004cb9366002dbd97f40c32d8da6d33c1904</a>
-<blockquote>
-<p>
- Remove unused base/gsalphac.[ch]<br>
-<br>
- This was the compositing device used for Display Postscript/NeXT specific<br>
- alpha blending. Since we haven't supported DPS properly for many years, and<br>
- officially dropped it completely a couple of years ago, and this compositing<br>
- device has not been included in the build for several years....<br>
-<br>
- ....just delete the files and remove references to them.<br>
-<br>
-base/gsalphac.c<br>
-base/gsalphac.h<br>
-doc/Develop.htm<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript.vcxproj<br>
-windows/ghostscript.vcxproj.filters<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-24 15:19: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=1c9bd8e0aa41e69c4bd46a6c553320d97af1ce7c">1c9bd8e0aa41e69c4bd46a6c553320d97af1ce7c</a>
-<blockquote>
-<p>
- Disable PPC optimisations in libpng<br>
-<br>
- Since we don't include the libpng source file with the PowerPC optimizations<br>
- in our build, and it only applies to reading, which we don't rely on, just<br>
- disable calling the optimizations.<br>
-<br>
- Cures a linker error on PowerPCle platforms<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-23 15:27:37 -0700
-</strong>
-<br>ray &lt;Ray.Johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cca279886b3bbb4d3af5768880565c9f7b372c08">cca279886b3bbb4d3af5768880565c9f7b372c08</a>
-<blockquote>
-<p>
- Fix Bug 702181: SEGV when BufferSpace is at or above -K alloc limit<br>
-<br>
- The issue with this file is that one of the pages is done in page mode because<br>
- it was so small, but the 'resize' call when doing page 2 was not checking the<br>
- allocation request against the limit, so the malloc would succeed, but the very<br>
- next (and all subsequent) allocations would fail. The gdev_prn_allocate would<br>
- capture the ecode, but would still call the clist_enable_multi_thread_render<br>
- resulting in the SEGV.<br>
-<br>
- Add the check in the gs_heap_resize_object function, and make sure and leave<br>
- the 'monitor' after failure, then don't call clist_enable_multi_thread if the<br>
- resize failed.<br>
-<br>
-base/gdevprn.c<br>
-base/gsmalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-20 10:26:17 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=886347337de7e121e3e1ffa348aa74856c8290ed">886347337de7e121e3e1ffa348aa74856c8290ed</a>
-<blockquote>
-<p>
- Bug 702190: Set CFLAGS and CFLAGSAUX separately in Makefile<br>
-<br>
- Building with -DGS_NO_FILESYSTEM allows support for environment without a<br>
- proper file system, by stubbing out the gp_ calls that would normally access<br>
- the file system.<br>
-<br>
- Obviously, for Ghostscript to function, that means it requires its resource<br>
- and initialisation files to be built into the binary in the ROMFS.<br>
-<br>
- A problem arises if you include the -DGS_NO_FILESYSTEM CFLAG when building the<br>
- mkromfs utility, which creates the ROMFS, since denying it access to the file<br>
- system results in an empty ROMFS. Previously, setting CFLAGS to include<br>
- -DGS_NO_FILESYSTEM when calling configure resulted in that flag being applied to<br>
- the main build, and the auxiliary tools build (including mkromfs), unless the<br>
- build specified was a cross-compilation.<br>
-<br>
- This splits the CFLAGS and CFLAGSAUX so they are set separately in the Makefile<br>
- so configure can filter out unwanted flags from the auxtools flags.<br>
-<br>
- Currently, the only one being filtered is -DGS_NO_FILESYSTEM<br>
-<br>
-Makefile.in<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-19 16:19:57 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7710a398e132e13f9e0ff2f83188cbe7d2b59b1f">7710a398e132e13f9e0ff2f83188cbe7d2b59b1f</a>
-<blockquote>
-<p>
- Bug 702115: use the offical method to detect gcc<br>
-<br>
- In the early days of autoconf there was no defined way to check if the selected<br>
- compiler was gcc (or compatible) or not. Projects used the autoconf internal<br>
- shell variable ac_cv_prog_gcc to get that info.<br>
-<br>
- autoconf introduced the GCC shell variable as the official way to know (a long<br>
- time ago), and we never revised our configure.ac to reflect that.<br>
-<br>
- This does so.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-19 16:12:46 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=66c2469c7d4543f32d6dc93edf1d649e809b8419">66c2469c7d4543f32d6dc93edf1d649e809b8419</a>
-<blockquote>
-<p>
- Remove deprecated opvp/oprp devices from default build<br>
-<br>
- They can currently be reinstated with --with-openprinting<br>
-<br>
- That option does not appear in the --help output because we want people to have<br>
- to ask us about it, so we know if people actually use opvp/oprp, and still<br>
- need them.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-23 09:07:36 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fedfb0e00755d9529d15751650864d304708f0e1">fedfb0e00755d9529d15751650864d304708f0e1</a>
-<blockquote>
-<p>
- Remove analytics stuff.<br>
-<br>
- Analytics and cookie stuff will be added at serve time by Apache.<br>
-<br>
- See /etc/apache2/sites-available/ghostscript.com-le-ssl.conf for more info<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/Internal.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>2020-03-21 18:08:43 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d98ab1f82e64e11db6478c4ff3e3bcffcc69836e">d98ab1f82e64e11db6478c4ff3e3bcffcc69836e</a>
-<blockquote>
-<p>
- jbig2dec: Cast literal to avoid shifting outside of valid range.<br>
-<br>
- Fixes Coverity CID 355175.<br>
-<br>
-jbig2dec/jbig2_arith_iaid.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-21 16:49:33 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1677b6c0d7b090ad7691e766d4809f9badeecd20">1677b6c0d7b090ad7691e766d4809f9badeecd20</a>
-<blockquote>
-<p>
- jbig2dec: Record stream errors in separate struct field.<br>
-<br>
- Previously the number of remaining bytes in a read word (&gt;= 0) and the error<br>
- state (&lt; 0) was stored in the same int field. Fixing signedness conversion<br>
- warnings changed the type of the field to an unsigned field. The error state<br>
- should have been stored separately at that time but it was overlooked. In this<br>
- commit the error state is separated out into its own field.<br>
-<br>
- Fixes Coverity CID 355176.<br>
-<br>
-jbig2dec/jbig2_arith.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-21 15:59:21 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a80f7f12e7a2fb0caa1ea9ac6fa8981cc539a1bc">a80f7f12e7a2fb0caa1ea9ac6fa8981cc539a1bc</a>
-<blockquote>
-<p>
- jbig2dec: Use correct define for maxium value of type.<br>
-<br>
- Fixes Coverity CID 355177.<br>
-<br>
-jbig2dec/jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-21 16:20:28 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f0c17451afb66e6fcf3bd453490b4b9d2b06b42">4f0c17451afb66e6fcf3bd453490b4b9d2b06b42</a>
-<blockquote>
-<p>
- jbig2dec: Fix two overlooked warnings.<br>
-<br>
- While working to fix all warnings seen when -Wsign-conversion is<br>
- enabled, these two warnings were accidentally introduced by commit<br>
- ff53af0d4ff9291aa5039522f5553a2850dd569d and not noticed in the<br>
- avalanche of warnings emitted due to -Wsign-conversion. This commit<br>
- changes the indicies to the type of the limit variable, fixing the<br>
- warnings.<br>
-<br>
-jbig2dec/jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-21 10:00:42 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a45d7217c8c1578475ee9204d1f4ad46520f44d1">a45d7217c8c1578475ee9204d1f4ad46520f44d1</a>
-<blockquote>
-<p>
- PDF interpreter - swallow errors reading ICC profiles and continue<br>
-<br>
- Bug #702240 &quot;Invalid ICC profile aborts PDF ineterpretation&quot;<br>
-<br>
- The file contains an ICCbased space which references an embedded ICC<br>
- profile, which is Flate compressed. The compressed stream has been<br>
- corrupted and cannot be decompressed.<br>
-<br>
- This causes the colour space code to throw an ioerror and terminate<br>
- interpretation, Acrobat (as usual) doesn't even give a warning.<br>
-<br>
- This commit checks for an error creating the ReusableStreamDecode and<br>
- if it fails sets the Data Source in the stream dictionary to null. We<br>
- will later use the /N value in the stream dictionary to set a reasonable<br>
- fallback space (in this case CMYK).<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-12 02:54:08 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b2fc96b3ffc1c9d3d39b3d0ce27bf8abba7b8cf">9b2fc96b3ffc1c9d3d39b3d0ce27bf8abba7b8cf</a>
-<blockquote>
-<p>
- jbig2dec: Fix signedness conversions.<br>
-<br>
-jbig2dec/jbig2.c<br>
-jbig2dec/jbig2_arith.c<br>
-jbig2dec/jbig2_arith_iaid.c<br>
-jbig2dec/jbig2_huffman.c<br>
-jbig2dec/jbig2_priv.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-12 00:27:13 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f2613ed2159e8efc6b5b593e668a00d8bea9ace8">f2613ed2159e8efc6b5b593e668a00d8bea9ace8</a>
-<blockquote>
-<p>
- jbig2dec: Use uint32_t when counting segments.<br>
-<br>
-jbig2dec/jbig2.c<br>
-jbig2dec/jbig2_priv.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-12 00:26:59 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ff53af0d4ff9291aa5039522f5553a2850dd569d">ff53af0d4ff9291aa5039522f5553a2850dd569d</a>
-<blockquote>
-<p>
- jbig2dec: Always use uint32_t when counting pages.<br>
-<br>
-jbig2dec/jbig2.c<br>
-jbig2dec/jbig2_page.c<br>
-jbig2dec/jbig2_priv.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-11 20:56:06 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6073e803bd652cd8fdb17f6be6beea05a13fd4f0">6073e803bd652cd8fdb17f6be6beea05a13fd4f0</a>
-<blockquote>
-<p>
- jbig2dec: Handle errors from reading jbig2 streams.<br>
-<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-11 20:55:51 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e9b5185c889266c9a3d6f25c9df558d41335d46">1e9b5185c889266c9a3d6f25c9df558d41335d46</a>
-<blockquote>
-<p>
- jbig2dec: Use size_t for string length.<br>
-<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-11 18:42:26 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc3f780ee3c9e43f34ba1c0b1101b41c58b40710">dc3f780ee3c9e43f34ba1c0b1101b41c58b40710</a>
-<blockquote>
-<p>
- jbig2dec: Avoid formatting error messages twice in error callback.<br>
-<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-11 16:35:53 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b5008aa2bc1c6a6acb2c6f90d1ef8d6bad9e66a">9b5008aa2bc1c6a6acb2c6f90d1ef8d6bad9e66a</a>
-<blockquote>
-<p>
- jbig2dec: Pass segment numbers as unsigned values to error callback.<br>
-<br>
- According to the JBIG2 specification segments numbers are 32 bit unsigned<br>
- integer. Previously any segment numbers larger than INT32_MAX would be passed<br>
- as negative numbers.<br>
-<br>
- Some parts of the decoder do not yet know, or do not have access to the<br>
- currently decoded segment number, and this needs to be specially indicated.<br>
- Therefore jbig2dec appropriates the unlikely segment number 0xffffffff to<br>
- indicate an unknown segment number.<br>
-<br>
- This is a change of the public API.<br>
-<br>
-base/sjbig2.c<br>
-gpdl/jbig2top.c<br>
-jbig2dec/jbig2.c<br>
-jbig2dec/jbig2.h<br>
-jbig2dec/jbig2_arith.c<br>
-jbig2dec/jbig2_arith_iaid.c<br>
-jbig2dec/jbig2_arith_int.c<br>
-jbig2dec/jbig2_halftone.c<br>
-jbig2dec/jbig2_huffman.c<br>
-jbig2dec/jbig2_image.c<br>
-jbig2dec/jbig2_mmr.c<br>
-jbig2dec/jbig2_page.c<br>
-jbig2dec/jbig2_priv.h<br>
-jbig2dec/jbig2_refinement.c<br>
-jbig2dec/jbig2_segment.c<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-17 01:48:00 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea9b3a676a516a603fabb593085d14a67356db6f">ea9b3a676a516a603fabb593085d14a67356db6f</a>
-<blockquote>
-<p>
- Bug 701721: jbig2dec: Fix under/overflow handling in arithmetic integer decoder.<br>
-<br>
- The previous detection logic caused GCC's -Wlogical-op to trip.<br>
- Not only that, but the detection logic never took into account<br>
- that underflow is not possible (the worst case is V == INT32_MIN,<br>
- but offset is always &gt; 0, so underflow cannot happen), nor take<br>
- varying offset values into account (hardcoded limits meant that<br>
- the offset was ignored even if it could not cause an overflow),<br>
- but instead could cause non-clamped values to be emitted.<br>
-<br>
- This corrected logic adheres to the Annex A. Table A.1 in the specification.<br>
-<br>
-jbig2dec/jbig2_arith_int.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-01 18:08:34 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=92faea67b31570e84b978a77b43c8f38bdad7bd4">92faea67b31570e84b978a77b43c8f38bdad7bd4</a>
-<blockquote>
-<p>
- jbig2dec: Avoid warning by copying bytes instead of characters.<br>
-<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-29 17:10:00 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f20fc43d80e31780935be96393800cc1fac8ac50">f20fc43d80e31780935be96393800cc1fac8ac50</a>
-<blockquote>
-<p>
- jbig2dec: Enable warnings for signedness in comparisons.<br>
-<br>
-jbig2dec/configure.ac.in<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-29 12:09:40 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5947fb2f1c022982e82406639517ebacae8d5cf6">5947fb2f1c022982e82406639517ebacae8d5cf6</a>
-<blockquote>
-<p>
- jbig2dec: Address all signedness comparison issues.<br>
-<br>
-jbig2dec/jbig2_arith.c<br>
-jbig2dec/jbig2_arith_iaid.c<br>
-jbig2dec/jbig2_arith_iaid.h<br>
-jbig2dec/jbig2_halftone.c<br>
-jbig2dec/jbig2_halftone.h<br>
-jbig2dec/jbig2_huffman.c<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-29 12:09:22 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9394be6a45aea026f61900e1cb661a30db192c15">9394be6a45aea026f61900e1cb661a30db192c15</a>
-<blockquote>
-<p>
- jbig2dec: Remove trailing whitespace.<br>
-<br>
-jbig2dec/CHANGES<br>
-jbig2dec/autogen.sh<br>
-jbig2dec/configure.ac.in<br>
-jbig2dec/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-29 16:26:53 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1899ce3f1844cf941d19c38fc8de8f126bf7419d">1899ce3f1844cf941d19c38fc8de8f126bf7419d</a>
-<blockquote>
-<p>
- jbig2dec: Avoid passing NULL buffer to snprintf().<br>
-<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-15 17:07:27 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4239ceeb4dd39e2ac183a01877b62761ae13bae4">4239ceeb4dd39e2ac183a01877b62761ae13bae4</a>
-<blockquote>
-<p>
- jbig2dec: Avoid artificially limiting jbig2dec.<br>
-<br>
- Commit 7366747076f3b75def52079bd4d5021539a16394 fixes bug 694949 by<br>
- adding an artificial limit (that does not come from the JBIG2<br>
- specification) to the sizes of generic regions compared with the image<br>
- they will be composed onto. A problem with such artificial limits is<br>
- that they are arbitrary. This is exemplified by the changes in<br>
- 0d21a58ab12b9584faa54baa48ce0dab350af53e to make jbig2dec not error<br>
- out on commonly occurring images. It is impossible to know whether<br>
- this updated limit is enough, or whether an even large generic region<br>
- in a JBIG2 image will be found in the future.<br>
-<br>
- Instead of imposing these kinds of limits, jbig2dec should attempt to<br>
- decode any JBIG2 image given to it. If the user wants to limit the<br>
- amount of memory jbig2dec may use for decoding any JBIG2 image, this<br>
- is a better way of implicitly limiting image sizes.<br>
-<br>
-jbig2dec/configure.ac.in<br>
-jbig2dec/jbig2_generic.c<br>
-jbig2dec/snprintf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-15 19:01:05 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd1ef5475a3bda7a97851abc679c75e2ee64dec3">cd1ef5475a3bda7a97851abc679c75e2ee64dec3</a>
-<blockquote>
-<p>
- Bug 702165: jbig2dec: Treat end of stream as fatal error, and remember errors.<br>
-<br>
- * Treat reading beyond end of stream in arithmetic decoder as a fatal error.<br>
-<br>
- * Remember previously encountered stream errors in arithmetic decoder.<br>
-<br>
- * Ignore trailing bytes after terminating marker code in stream.<br>
-<br>
-jbig2dec/jbig2_arith.c<br>
-jbig2dec/jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-15 18:12:31 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=30842ee99923fa10a7301494fd08b998e7acf57b">30842ee99923fa10a7301494fd08b998e7acf57b</a>
-<blockquote>
-<p>
- jbig2dec: Add overflow detection for IAID context size.<br>
-<br>
-jbig2dec/jbig2_arith_iaid.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-15 17:58:40 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=17e84cb1a4903fab26b5fc5d2e4805a1097f5a33">17e84cb1a4903fab26b5fc5d2e4805a1097f5a33</a>
-<blockquote>
-<p>
- jbig2dec: Let arithmetic decoder and the underlying stream report errors.<br>
-<br>
- When a called function indicates an error, the caller should print warnings.<br>
- Since the arithmetic decoder now uses the normal way of reporting errors,<br>
- the callers of the decoder are changed to report warnings.<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_int.c<br>
-jbig2dec/jbig2_generic.c<br>
-jbig2dec/jbig2_huffman.c<br>
-jbig2dec/jbig2_priv.h<br>
-jbig2dec/jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-15 17:31:48 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=716560bf5f2bc4b821ca6924ec648ca4949826bb">716560bf5f2bc4b821ca6924ec648ca4949826bb</a>
-<blockquote>
-<p>
- jbig2dec: Handle under-/overflow detection and messaging better.<br>
-<br>
- Previously SYMWIDTH was capped too early in order to prevent underflow<br>
- Moreover TOTWIDTH was allowed to overflow.<br>
-<br>
- Now the value DW is checked compared to SYMWIDTH, preventing over<br>
- underflow and overflow at the correct limits, and an overflow<br>
- check has been added for TOTWIDTH.<br>
-<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-16 22:56:06 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cf43daf9f8381a9accf36d12bad2324d021ec8c6">cf43daf9f8381a9accf36d12bad2324d021ec8c6</a>
-<blockquote>
-<p>
- jbig2dec: Use unsigned suffix when defining UINT32_MAX.<br>
-<br>
- Also move UINT32_MAX/INT32_MAX to internal header so they are defined<br>
- (the same) in every jbig2 source code file.<br>
-<br>
-jbig2dec/jbig2_arith_int.c<br>
-jbig2dec/jbig2_generic.c<br>
-jbig2dec/jbig2_image.c<br>
-jbig2dec/jbig2_mmr.c<br>
-jbig2dec/jbig2_page.c<br>
-jbig2dec/jbig2_priv.h<br>
-jbig2dec/jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-15 17:19:12 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a47257407ee8938051f14da81890869a5ade0c26">a47257407ee8938051f14da81890869a5ade0c26</a>
-<blockquote>
-<p>
- jbig2dec: Keep type of index and array length the same.<br>
-<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-15 16:57:23 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b610aebdd36d939a878e336c255c734b4432e023">b610aebdd36d939a878e336c255c734b4432e023</a>
-<blockquote>
-<p>
- jbig2dec: Add more references to specification.<br>
-<br>
-jbig2dec/jbig2_arith.c<br>
-jbig2dec/jbig2_arith_iaid.c<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-15 15:52:26 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d4dc797e4a65871134f6a244cb8421a33fe91360">d4dc797e4a65871134f6a244cb8421a33fe91360</a>
-<blockquote>
-<p>
- jbig2dec: Add command line option to limit memory usage.<br>
-<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-15 15:52:06 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a64ec1a232aa675e75d71da2632c6fca9a7fddcf">a64ec1a232aa675e75d71da2632c6fca9a7fddcf</a>
-<blockquote>
-<p>
- jbig2dec: Mention all long options in usage and manpage.<br>
-<br>
-jbig2dec/jbig2dec.1<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-15 15:45:47 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3f01ab3739773db83040d8c2a7c3562b9103ed4e">3f01ab3739773db83040d8c2a7c3562b9103ed4e</a>
-<blockquote>
-<p>
- jbig2dec: Separate command line tool error callback state from parameters.<br>
-<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-05 03:31:43 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e4dd74c63031c705b3b6938fdac6b69e6317f00a">e4dd74c63031c705b3b6938fdac6b69e6317f00a</a>
-<blockquote>
-<p>
- Propagate errors when closing pipe.<br>
-<br>
-base/gdevpipe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-17 15:52:20 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=97ad9c044a1d3f87b16b2be754e088e49cc1f398">97ad9c044a1d3f87b16b2be754e088e49cc1f398</a>
-<blockquote>
-<p>
- Bring master up to date 9.52 release branch<br>
-<br>
- Add references to the 64 bit windows exes<br>
-<br>
- Release notes for 9.52 release<br>
-<br>
- Version, dates etc for 9.52 release<br>
-<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/Internal.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>2020-03-19 08:12: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=c126cabcc5760aec6458b97729c78c821e24d122">c126cabcc5760aec6458b97729c78c821e24d122</a>
-<blockquote>
-<p>
- Bump version prior to 9.52 release<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-18 10:40:39 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ba3000d394406331c8e49c87e1d6494887c4e98">7ba3000d394406331c8e49c87e1d6494887c4e98</a>
-<blockquote>
-<p>
- CID: 355082. Fix comparison of size_t &lt; 0.<br>
-<br>
- Now we're using param_read_size_t, we no longer need to check<br>
- for the returned value being &lt; 0. This check is pickled into<br>
- the coertion code contained within that function.<br>
-<br>
-base/gsdparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-17 00:44:02 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4cbc36fe4546bce70537bc65541f65b4d7259a5b">4cbc36fe4546bce70537bc65541f65b4d7259a5b</a>
-<blockquote>
-<p>
- Bug 702151: Avoid truncating pointers in debug code.<br>
-<br>
- Introduce a PRI_INTPTR and use that to consistently display<br>
- pointers. We avoid using %p, as that displays inconsistently<br>
- between platforms. Sometimes it does 0x%x, sometimes just %x.<br>
-<br>
-base/gdevdrop.c<br>
-base/gdevnfwd.c<br>
-base/gdevprn.c<br>
-base/gsalloc.c<br>
-base/gschar0.c<br>
-base/gscie.c<br>
-base/gsciemap.c<br>
-base/gscspace.c<br>
-base/gsfcmap1.c<br>
-base/gsfont.c<br>
-base/gsht.c<br>
-base/gsicc_cache.c<br>
-base/gsicc_manage.c<br>
-base/gsicc_profilecache.c<br>
-base/gsimage.c<br>
-base/gsmalloc.c<br>
-base/gsmchunk.c<br>
-base/gsmemory.c<br>
-base/gsmisc.c<br>
-base/gsrefct.h<br>
-base/gsstate.c<br>
-base/gsstruct.h<br>
-base/gstrans.c<br>
-base/gstype1.c<br>
-base/gstype2.c<br>
-base/gxacpath.c<br>
-base/gxalloc.h<br>
-base/gxbcache.c<br>
-base/gxccache.c<br>
-base/gxccman.c<br>
-base/gxclist.c<br>
-base/gxclmem.c<br>
-base/gxclread.c<br>
-base/gxclthrd.c<br>
-base/gxclutil.c<br>
-base/gxcpath.c<br>
-base/gxcpath.h<br>
-base/gxfill.c<br>
-base/gxfillsl.h<br>
-base/gxht.c<br>
-base/gxpath.c<br>
-base/gxpcmap.c<br>
-base/scfd.c<br>
-base/scfe.c<br>
-base/sfxfd.c<br>
-base/sfxstdio.c<br>
-base/stdint_.h<br>
-base/stream.c<br>
-base/szlibc.c<br>
-devices/gdevfax.c<br>
-devices/gdevx.c<br>
-psi/ialloc.c<br>
-psi/idebug.c<br>
-psi/idict.c<br>
-psi/idicttpl.h<br>
-psi/idstack.c<br>
-psi/igc.c<br>
-psi/igcref.c<br>
-psi/igcstr.c<br>
-psi/iinit.c<br>
-psi/ilocate.c<br>
-psi/imain.c<br>
-psi/imainarg.c<br>
-psi/iname.c<br>
-psi/interp.c<br>
-psi/isave.c<br>
-psi/iutil.c<br>
-psi/zcie.c<br>
-psi/zcontrol.c<br>
-psi/zvmem.c<br>
-xps/xpshash.c<br>
-xps/xpsresource.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-12 17:22:36 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d7961033ee224fc5d2c96a16bea3f3399dd29561">d7961033ee224fc5d2c96a16bea3f3399dd29561</a>
-<blockquote>
-<p>
- Add support for 64bit and size_t paramaters.<br>
-<br>
- Cope with both int64_t's and size_t's with appropriate<br>
- rangechecks when casting will cause problems.<br>
-<br>
- -d values on the command line are read as int64_t's.<br>
-<br>
- If we ever find outselves wanting to assign a size_t where<br>
- the 63rd bit matters, then we may have to rethink this :)<br>
-<br>
- We also change various params (such as MaxBitmap, MaxPatternBitmap<br>
- etc) to be size_t's. This affects the device structure itself.<br>
-<br>
-base/gsdparam.c<br>
-base/gslib.c<br>
-base/gsparam.c<br>
-base/gsparam.h<br>
-base/gsparam2.c<br>
-base/gsparams.c<br>
-base/gxdevcli.h<br>
-base/gxpcache.h<br>
-base/gxpcmap.c<br>
-base/gxpcolor.h<br>
-base/spprint.c<br>
-base/spprint.h<br>
-base/spsdf.c<br>
-devices/vector/gdevpsdp.c<br>
-pcl/pl/plmain.c<br>
-psi/imainarg.c<br>
-psi/iparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-15 14:48:29 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e1b322c8ca8f08b5af398a912c511dc041cd9c86">e1b322c8ca8f08b5af398a912c511dc041cd9c86</a>
-<blockquote>
-<p>
- Fix bug 702142: SMask profile 'swap' could cause clist to use wrong profile<br>
-<br>
- The SMask 'swap' of profiles for the 'default' colorspaces in the icc_manager<br>
- was not being detected by the clist logic since the colorspace id was still<br>
- set to the cs_Device*_id value (1, 3, or 4).<br>
-<br>
- The fix is to have the clist writing check for unknown color_space check BOTH<br>
- the color_space.id and the color_space.space, and flag 'unknown' if either<br>
- differed. The color_space.space includes the icc_profile info.<br>
-<br>
- This results in a few progressions as well as fixing the file of this bug.<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-14 15:07: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=0fad2491ae5d9dae39807266b6f0f2584a02bdd8">0fad2491ae5d9dae39807266b6f0f2584a02bdd8</a>
-<blockquote>
-<p>
- Bug 702217: Reinstate dynamic libs LDFLAGS for MacOS<br>
-<br>
- With the significant revamp of the platform detection functions in configure<br>
- the LDFLAGS for building the gs shared library on MacOS went astray. This<br>
- puts them back in.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-16 09:06:16 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aaf5edb15fceaae962569bae30eb4633480c1d15">aaf5edb15fceaae962569bae30eb4633480c1d15</a>
-<blockquote>
-<p>
- Repair device subclassing after fill+stroke commit<br>
-<br>
- Bug 702221 &quot;Ghostscript 9.51 - SIGFPE when -dFirstPage or -dLastPage is set&quot;<br>
-<br>
- The fill+stroke commit had an error with the default method for handling<br>
- fill_stroke_path which passed the subclassing device as a parameter to<br>
- the child, instead of passing the child device. This caused seg faults,<br>
- floating point exceptions, hangs, and possibly other problems.<br>
-<br>
- In addition the object filtering device had been modified to pass the<br>
- fill+stroke method to the default handler, instead of checking to see<br>
- if vector operations should be dropped.<br>
-<br>
- This commit fixes both problems.<br>
-<br>
-base/gdevoflt.c<br>
-base/gdevsclass.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-14 10:56: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=b5682afdd022f0c1f1a20f83568300655bc27bfe">b5682afdd022f0c1f1a20f83568300655bc27bfe</a>
-<blockquote>
-<p>
- Add ARCH_MAX_SIZE_T to configure's arch.h prototype<br>
-<br>
-arch/arch_autoconf.h.in<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-14 10:53:15 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=09d359ca87e47cac31c7f1466250b3299818ce86">09d359ca87e47cac31c7f1466250b3299818ce86</a>
-<blockquote>
-<p>
- Don't fail on missing freetype for auxtools run<br>
-<br>
- When cross compiling, we shouldn't fail the recursive call to configure if<br>
- there's no freetype - since it's not required for auxtools.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-13 18:57:30 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bba815fd5ab0427b96ad2f2d6d96e7d69b4964ad">bba815fd5ab0427b96ad2f2d6d96e7d69b4964ad</a>
-<blockquote>
-<p>
- Bug 702191. Change Tr modes 2 and 6 to use fill_stroke operation.<br>
-<br>
- Thanks to Ken Sharp who made the change to the PDF interpreter pdf_ops.ps.<br>
- This showed a few files that had SEGV. This was due to both the fill and<br>
- stroke having pattern colors where the pattern bits did not fit in the cache.<br>
- The stroke color could eject the fill pattern from the cache. The fix is to<br>
- lock the fill pattern in the cache as well as the stroke pattern (and unlock<br>
- it as well after the fill_stroke).<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-base/gspaint.c<br>
-psi/dwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-13 13:01:23 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3353e8f68c8b4b13db8f712e3d01503d9043df65">3353e8f68c8b4b13db8f712e3d01503d9043df65</a>
-<blockquote>
-<p>
- pdfwrite - fix previous commit<br>
-<br>
- commit 2a691356aeb538388ecbf0cafdf422bde771bad0 accidentally left a<br>
- debugging hack in place, which would lead to lots of files including<br>
- a ToUnicode CMap when that wasn't necessary, fix it here.<br>
-<br>
-devices/vector/gdevpdtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-13 11:10:50 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2a691356aeb538388ecbf0cafdf422bde771bad0">2a691356aeb538388ecbf0cafdf422bde771bad0</a>
-<blockquote>
-<p>
- pdfwrite - preserve ToUnicode CMaps with non-standard mappings<br>
-<br>
- Bug #702201 &quot;pdfwrite changes ligature&quot;<br>
-<br>
- The title is incorrect, pdfwrite does not 'change ligature'. The PDF<br>
- file uses an ffi ligature glyph from the embedded font, but the<br>
- ToUnicode CMap does not map that to U+FB03, it maps it to 3 Unicode<br>
- code points; f, f and i.<br>
-<br>
- When we emit a simple font we check its Encoding to see if it needs a<br>
- ToUnicode CMap, if it doesn't then we don't emit one. Because all the<br>
- glyphs in this font are named, and have standard names, we don't need to<br>
- emit a ToUnicode CMap and so we don't (keeps the file size down).<br>
-<br>
- However, that means that PDF consumers will map the ligature glyph to a<br>
- ligature ffi when copy/pasting (it has no other effect).<br>
-<br>
- Here we check the Unicode code points as they are added to the internal<br>
- record. If any of them is not 2 bytes long, then its not a standard<br>
- mapping (simple fonts can only map to a single point). In that case we<br>
- note the exception and when we come to write the font, in the code that<br>
- checks the Encoding to see if we need to write a ToUnicode, we check<br>
- this value, if we've seen a multiple code point in the ToUnicode CMap<br>
- then we don't elide it, we embed the one we picked up.<br>
-<br>
- This is not actually a bug IMO, there's nothing wrong with the mapping<br>
- as it stands because an ffi glyph in the document really should map to<br>
- a single Unicode code point ffi ligature. However, the creator of the<br>
- PDF file obviously didn't want that, so we;ll now honour it.<br>
-<br>
- NB this only affects the emission of a ToUnicode CMap, which is only<br>
- used for copy/paste/search. The PDF contents are not affected by this<br>
- commit.<br>
-<br>
-devices/vector/gdevpdte.c<br>
-devices/vector/gdevpdtf.c<br>
-devices/vector/gdevpdtf.h<br>
-devices/vector/gdevpdtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-13 08:16:34 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0bb921da9e702375618aa5fe7e85bf589e9a0108">0bb921da9e702375618aa5fe7e85bf589e9a0108</a>
-<blockquote>
-<p>
- Tiny tweak to release notes<br>
-<br>
- to say &quot;in the 9.50 release notes&quot; rather than &quot;above&quot;.<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 11:37: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=6018c8989f1c670d0b8c44d79438faa68dbe5a06">6018c8989f1c670d0b8c44d79438faa68dbe5a06</a>
-<blockquote>
-<p>
- Bring master up to date with 9.51 release branch<br>
-<br>
- Dates etc for 9.51 RC1<br>
-<br>
- Plus prelim changelog<br>
-<br>
- Dates, changelog etc for 9.51rc2<br>
-<br>
- Add mention of deprecating/removing opvp/oprp devices<br>
-<br>
- Dates/logs for 9.51 release candidate 3<br>
-<br>
- Dates, changelog etc for 9.51 release<br>
-<br>
-Makefile.in<br>
-base/version.mak<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/Internal.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>
-psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-12 17:46: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=e61555d8b960f1a87664fc378f4ce63619a762aa">e61555d8b960f1a87664fc378f4ce63619a762aa</a>
-<blockquote>
-<p>
- Change 9.28 to 9.50 in the SAFER section<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-11 15:48:13 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b2d084d01a22261281fc35e990efc46dde6ea8f9">b2d084d01a22261281fc35e990efc46dde6ea8f9</a>
-<blockquote>
-<p>
- Improve debugging error messages in fontconfig code.<br>
-<br>
- Change the order we retrieve values, so we get FC_FILE (which *should* always<br>
- succeed) first. Thus we can use that in subsequent DEBUG messages, giving<br>
- slightly more useful diagnostics.<br>
-<br>
-base/gp_unix.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-11 13:18:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=09a575f0fdc6edde7e42f325167318a1b199839f">09a575f0fdc6edde7e42f325167318a1b199839f</a>
-<blockquote>
-<p>
- (fontconfig) Don't stop enumerating fonts on error.<br>
-<br>
- We only want to finish enumerating the fontconfig fonts list once the list<br>
- is exhausted, not when an individual font gives an error.<br>
-<br>
- In the event a font gives an error, skip it and move on.<br>
-<br>
-base/gp_unix.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-05 13:12:12 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=32fde6e59a76fa7bcc7c3b977a77b871a740f568">32fde6e59a76fa7bcc7c3b977a77b871a740f568</a>
-<blockquote>
-<p>
- More problems with TTF &quot;notdef&quot; glyphs<br>
-<br>
- The font in this file is questionable according to the spec. The spec says GID 0<br>
- in a TTF *must* be the &quot;notdef&quot; glyph which, traditionally, is a hollow<br>
- rectangle glyph. This contradicts what Postscript and PDF expect which is that<br>
- the .notdef glyph will be non-marking.<br>
-<br>
- The problem is many PDF embedded TTF fonts ignore this, and populate GID 0 with<br>
- a &quot;meaningful&quot; glyph rather than an actual notdef.<br>
-<br>
- Previously, the fonts that did this were all ones that used MS Unicode cmap<br>
- tables and hence we used that to determine whether to image GID 0 or not in<br>
- TTFs.<br>
-<br>
- This file does not use a Unicode cmap, but rather an Apple cmap table. In this<br>
- case, the cmap table maps every character code to GID 0, GID 0 being the only<br>
- glyph defined in the font.<br>
-<br>
- So, tweak the heuristic so that in the event we have what *looks* like a<br>
- notdef, we'll look up the character code in the TTF cmap table, and if<br>
- the cmap table maps that code to GID 0, then we'll image the glyph.<br>
- Otherwise, we will force it to be non-marking.<br>
-<br>
- (Bug 702167)<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-09 07:08: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=3f7832e4b9568e70bdf3bb32c877c4bf5e9dc3b4">3f7832e4b9568e70bdf3bb32c877c4bf5e9dc3b4</a>
-<blockquote>
-<p>
- PS interpreter - another 64-bit integer fix<br>
-<br>
- Bug #702197 &quot;Integer overflowin --for-- on Windows&quot;<br>
-<br>
- Both the limit and the control variable were being passed to types<br>
- which truncated values when long or int were not 64-bit types.<br>
-<br>
-psi/zcontrol.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-09 05:22:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a0c0303127e4dba3fdc244cf3d75684e5cc8358">9a0c0303127e4dba3fdc244cf3d75684e5cc8358</a>
-<blockquote>
-<p>
- PS interpreter - fix cvrs with 64-bit integers<br>
-<br>
- Bug #702195 &quot;Integer overflow in cvrs on Windows&quot;<br>
-<br>
- Another 64-bit integer fix, we were casting the result of the radix<br>
- calculation through a long which on Windows is not 64-bit (on Linux it<br>
- is), leading to truncation o the result.<br>
-<br>
- Fixed by casting through ps_uint instead. We also need to check for<br>
- CPSI mode here as we must use a 32-bit intermediate integer if we are in<br>
- CPSI mode and emit a rangecheck if the integer overflows 32 bits.<br>
-<br>
-psi/ztype.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-08 00:26:16 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=56840269a9df474a029f12ce8e4e41bb2abea313">56840269a9df474a029f12ce8e4e41bb2abea313</a>
-<blockquote>
-<p>
- PS interpreter some 64-bit integer fixes<br>
-<br>
- Bug #702194 &quot;cvi produces incorrect results&quot;<br>
-<br>
- This was simply caused by a cast through long. However its not enough<br>
- merely to change the cast, we must also check for running in CPSI mode<br>
- and throw an error if the returned integer cannot be represented in a<br>
- 32-bit word, for compatibility with test suites.<br>
-<br>
- In addition (see bug #702134) when exp throws an undefinedresult error<br>
- delay setting the stack variable until after we have tested the result,<br>
- so that we do not end up returning a INF on the stack, as is done in<br>
- other code paths which check for NaN and INF.<br>
-<br>
- Thirdly; in div cater for the case of an integer divided by a real and<br>
- check the result for NaN and INF (as the other cases do). This now<br>
- properly throws an error and does not return NaN or INF on the stack.<br>
-<br>
-psi/zarith.c<br>
-psi/zmath.c<br>
-psi/ztype.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-05 09:58:47 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=933a09069dea35d570694e157013f272995ca5c4">933a09069dea35d570694e157013f272995ca5c4</a>
-<blockquote>
-<p>
- Fix Raspbian build failure with mm_constant_zeros.<br>
-<br>
- Moved 'static __m128i mm_constant_zeros' inside MM_SETUP macro definition, so<br>
- it only appears if MM_SETUP() is actually used.<br>
-<br>
-base/gsroprun.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-03 16:56:59 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=417b80ba6b16de181b2eb2fe5ca2e04565228f5f">417b80ba6b16de181b2eb2fe5ca2e04565228f5f</a>
-<blockquote>
-<p>
- Bug 702166: Image pattern phase mismatch when using clist<br>
-<br>
- The gxclimag.c code, when it does 'cmd_put_drawing_color' was not updating<br>
- the tile_phase. The Kanji text set the tile_phase to 100, but the begin_image<br>
- was supposed to be 0,0 but the writer was not performing the set_tile_phase.<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-04 17:42:04 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2a3b9b17cc32401b45382c42e081733d4f6d1a62">2a3b9b17cc32401b45382c42e081733d4f6d1a62</a>
-<blockquote>
-<p>
- Cups device: Windows: avoid using an uninitialised mutex.<br>
-<br>
-cups/libs/cups/globals.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-03 16:40:31 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cbee08400ca895bb5f52de6cf8cb44ba59cc5fd8">cbee08400ca895bb5f52de6cf8cb44ba59cc5fd8</a>
-<blockquote>
-<p>
- Bug 702177: Avoid SEGV on low memory in cmd_put_halftone.<br>
-<br>
- Ensure that cmd_put_list_op cannot return NULL without<br>
- setting an error code.<br>
-<br>
-base/gxclutil.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-03 11:53:28 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e9dc0327b8458ed7c3f1ca07870c7e54dbef6aa4">e9dc0327b8458ed7c3f1ca07870c7e54dbef6aa4</a>
-<blockquote>
-<p>
- Simplify change to clusterpush.pl for ifilters.<br>
-<br>
- No need to keep filters and ifilters separately as we pass<br>
- them through with &quot;filter=&quot; and &quot;ifilter=&quot; intact.<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-03 10:55:43 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa944725e4b3ca01e7a63608a2b5afc320d9a4d2">fa944725e4b3ca01e7a63608a2b5afc320d9a4d2</a>
-<blockquote>
-<p>
- Add support to clusterpush.pl for ifilter.<br>
-<br>
- Needs tweaks within the cluster too, so don't try using<br>
- this immediately!<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-03 10:02:57 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab41133a6852dbb3cecdfd19ccd4737f27d7be28">ab41133a6852dbb3cecdfd19ccd4737f27d7be28</a>
-<blockquote>
-<p>
- Avoid potential Memento leak in gs_lib_ctx_set_icc_directory().<br>
-<br>
- Return gs_error_VMerror after alloc failure, not -1. This doesn't fix a<br>
- known memento squeeze test case, but returning -1 after alloc failure breaks<br>
- gs_main_finit()'s cleanup and leaks blocks.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-03 09:47:52 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a07bf9d0dee6c44865c25ed8c36cf68150301b39">a07bf9d0dee6c44865c25ed8c36cf68150301b39</a>
-<blockquote>
-<p>
- Fixed Memento leak in gs_seticcdirectory().<br>
-<br>
- Return gs_error_VMerror instead of -1, after alloc failure. This enables<br>
- gs_main_finit() to clean up properly.<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=111090 ./ghostpdl/membin/gs -sDEVICE=bit -o /dev/null examples/text_graphic_image.pdf<br>
-<br>
-base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-02 20:05:57 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=05ebf9f3c38ff9b15f54122c682f88ee9dd9d55e">05ebf9f3c38ff9b15f54122c682f88ee9dd9d55e</a>
-<blockquote>
-<p>
- Avoid compiler warning for MM_SETUP() __m128i mm_constant_ones.<br>
-<br>
- This avoids warning about mm_constant_ones being used uninitialised.<br>
-<br>
- Generated code for release build is unchanged.<br>
-<br>
-base/gsroprun.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 17:12:23 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=612ca06e4a41db0f0023827c878a55423500237e">612ca06e4a41db0f0023827c878a55423500237e</a>
-<blockquote>
-<p>
- minor fix to toolbin/squeeze2text.py to cope with no input.<br>
-<br>
-toolbin/squeeze2text.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-02 19:13:07 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=968216b16318407a179e7907dd5d6d2ebc54bb25">968216b16318407a179e7907dd5d6d2ebc54bb25</a>
-<blockquote>
-<p>
- Fix typo in 16bit saturation blending code.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-02 17:10:43 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c5687fef9709b04dd96957677ff9accd16ee1f7">2c5687fef9709b04dd96957677ff9accd16ee1f7</a>
-<blockquote>
-<p>
- Fix 16bit blending problem.<br>
-<br>
- Seen with:<br>
-<br>
- gs -sDEVICE=psdcmyk16 -o out%d.psd -r72 -dMaxBitmap=2000M<br>
- tests_private/pdf/forms/v1.5/proxy_vol_1_number_1_1.pdf<br>
-<br>
- on page 3.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-27 12:08:22 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=155894abeb41e90f9e2c8cb942269c2a2e1a6018">155894abeb41e90f9e2c8cb942269c2a2e1a6018</a>
-<blockquote>
-<p>
- Reimplement saturation blendmode.<br>
-<br>
- To test the results of deep color rendering, we ran a psdcmyk vs<br>
- psdcmyk16 comparison. This showed differences on page 17 of the<br>
- Altona_technical_v20_x4.pdf file in one patch. Simplifying the<br>
- file showed that the saturation blend mode was showing a<br>
- significant difference in one tile.<br>
-<br>
- Saturation blend mode is defined to not make any changes if we<br>
- are writing over a pure grey color (as there is no 'hue' for<br>
- it to saturate). You'd expect that the blending function would be<br>
- continuous (i.e. that a small peturbation of the background color<br>
- should only produce a small peturbation in the output), but this<br>
- is NOT the case around pure greys.<br>
-<br>
- The example in the tested file, shows that psdcmyk is called with<br>
- 7a, 7a, 7a, which therefore leaves the background unchanged. For<br>
- psdcmyk16, it's called with 7a01 7a03 7a01, which therefore does<br>
- NOT leave the background unchanged. Testing by changing the 8 bit<br>
- inputs to 7b 7a 7b (a small peturbation), gives output of 99 64 99<br>
- (a large change).<br>
-<br>
- So, actually, the results given seem reasonable in that case.<br>
-<br>
- HOWEVER, in investigating what now seems to be a red herring, I<br>
- believe I've spotted a problem in the implementation. The scaling<br>
- of the components subtracts y when it should be subtracting minb.<br>
-<br>
- The only way I could actually work that out though, was to completely<br>
- reimplement the code, and optimise it. I believe the new code is<br>
- slightly clearer (in that it follows the spec more explicitly) and<br>
- possibly slightly more performant, so I am committing that rather<br>
- than attempting to patch the existing code.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-02 11:04:32 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=549a133dfcbdf2b3b028134d287d334f8fd623fd">549a133dfcbdf2b3b028134d287d334f8fd623fd</a>
-<blockquote>
-<p>
- Fix 64bit non-console windows build.<br>
-<br>
- The creation of the text window was truncating the pointer to<br>
- long (32bit) size. No idea how we've been getting away with this<br>
- in the past. I can only assume this has been exposed by<br>
- differences in the runtime lib with vs2019 as compared to<br>
- earlier versions.<br>
-<br>
-psi/dwtext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-28 10:34:12 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1a4e859544336c9034c49bd9f735529401422961">1a4e859544336c9034c49bd9f735529401422961</a>
-<blockquote>
-<p>
- Remove trailing white space from a prior commit<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 17:16:26 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa1bc6dce44b6fc69e9852553aec4b7a419d0d9c">fa1bc6dce44b6fc69e9852553aec4b7a419d0d9c</a>
-<blockquote>
-<p>
- Bug 702155 Alternate tint transform and shadings<br>
-<br>
- Add option to match AR shadings for corner case, which<br>
- is not as detailed in the PDF specification.<br>
-<br>
- If the source space is DeviceN or Separation and the<br>
- colorants are not supported (i.e. if we are using the alternate tint<br>
- transform) the interpolation should occur in the source space to<br>
- accommodate non-linear tint transform functions.<br>
- e.g. We had a case where the transform function<br>
- was an increasing staircase. Including that function in the<br>
- gradient smoothness calculation gave us severe quantization. AR on<br>
- the other hand is doing the interpolation in device color space<br>
- and has a smooth result for that case. So AR is not following the spec. The<br>
- bit below solves the issues for Type 4 and Type 5 shadings as<br>
- this will avoid interpolations in source space. Type 6 and Type 7 will still<br>
- have interpolations in the source space even if pfs-&gt;cs_always_linear == true.<br>
- So the approach below does not solve those issues. To do that<br>
- without changing the shading code, we could make a linear<br>
- approximation to the alternate tint transform, which would<br>
- ensure smoothness like what AR provides.<br>
-<br>
-base/gxshade.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-27 07:46:32 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=55222ef42e6574967810f8591ea308dbfc81b0a4">55222ef42e6574967810f8591ea308dbfc81b0a4</a>
-<blockquote>
-<p>
- Fix differences seen between page mode and clist mode exposed by commit b3a73575<br>
-<br>
- The code in gxipixel.c skips gridfitting if fill_adjust is 0, but the clist<br>
- writer logic wasn't updating the fill_adjust, so the reader could have the<br>
- wrong value. Seen with fts_25_2505 and fts_25_2506 which have an image with<br>
- SMask and also have large text (non-cached, so painted with fill) preceding<br>
- (drawn under) the image. Text is drawn with fill_adjust 0.<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 09:10:20 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8539dd741abec3d5b8e4417e512ae0847224f7a0">8539dd741abec3d5b8e4417e512ae0847224f7a0</a>
-<blockquote>
-<p>
- Fixes needed for pdfi after fill/stroke -- check for null pattern<br>
-<br>
- Change to test for pgs-&gt;colours.pattern.p_tile to be NULL before<br>
- attempting to dereference it.<br>
-<br>
- pdfi has a 'null' pattern frequently, which didn't seem to matter before the<br>
- fill/stroke changes, but does matter now.<br>
-<br>
- I think the gs/pdf implementation sets up a specific &quot;null&quot; pattern<br>
- that gets around this issue, but currently pdfi does not do this.<br>
- Maybe it should?<br>
-<br>
-base/gspaint.c<br>
-base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 15:22:04 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b6bd379a249b81213db5fdecf29ed11f2ce00e9e">b6bd379a249b81213db5fdecf29ed11f2ce00e9e</a>
-<blockquote>
-<p>
- Fix signed issue in 16bit alpha blending fill_rectangle routines.<br>
-<br>
- As seen by the central spot in the pink region of page 1 of:<br>
-<br>
- gs -sDEVICE=psdcmyk16 -o out%d.psd -dMaxBitmap=2000M<br>
- tests_private/pdf/pdf_1.7_ATS_EXXPA1DC_PDFACT.pdf<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 15:09:35 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b942845ee596dbcf37cf2af2381f0b298b962317">b942845ee596dbcf37cf2af2381f0b298b962317</a>
-<blockquote>
-<p>
- pdfwrite - Fix indeterminism with QL shading tests<br>
-<br>
- When creating a new colour space to put in a PDF file we perform various<br>
- tests to see if its a space we have already written, to prevent writing<br>
- duplicate spaces (we perform similar tests for most resources).<br>
-<br>
- In some cases, when we write the resource to a file, we create an MD5<br>
- hash and compare those to see if the resources are the same. In the<br>
- case of colour spaces, however, they are retained in memory and so we<br>
- use a different method. We 'serialise' the colour space. This is not the<br>
- same as writing it to the PDF file, and its a graphics library thing not<br>
- a pdfwrite function. Basically this writes out the content of the<br>
- various C structures. The stream we use is an in-memory stream.<br>
-<br>
- Unfortunately, for Separation colour spaces, there was a fault in the<br>
- function which writes the colour space name, and it was writing out<br>
- the bytes forming the address of the name instead of the actual string.<br>
-<br>
- This could, very rarely, mean that we would mis-identify a new colour<br>
- space as being the same as an old colour space, and so would reuse the<br>
- old space instead of creating a new one.<br>
-<br>
- I've checked the DeviceN code and it does not suffer the same problem.<br>
-<br>
-base/gscsepr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 13:03:56 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=988cfb770d12441dfef9002f799757e5cd869e48">988cfb770d12441dfef9002f799757e5cd869e48</a>
-<blockquote>
-<p>
- Fix the overflow case in 16 bit saturation blending.<br>
-<br>
- As seen with the second apple of the bottom row of page 1<br>
- of:<br>
-<br>
- gs -sDEVICE=psdcmyk16 -r72 -o out%d.psd -dMaxBitmap=2000M<br>
- ../tests_private/pdf/PDF_1.7_ATS/AIX4G1C3.pdf<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 17:10:51 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=293e2b7f6298a6049254d18250d4f82f78ac2978">293e2b7f6298a6049254d18250d4f82f78ac2978</a>
-<blockquote>
-<p>
- Fix for bug 702150: make pl_main_run_file_utf8() check for error from s_process_read_buf().<br>
-<br>
- Avoids infinite loop in:<br>
- ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null .<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 18:24:55 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=342229c7533310f9a46fbfd7a7dd2eaa976746f0">342229c7533310f9a46fbfd7a7dd2eaa976746f0</a>
-<blockquote>
-<p>
- minor improvements to toolbin/squeeze2text.py.<br>
-<br>
-toolbin/squeeze2text.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 08:25:13 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd0961426d3e1718c17fa226f3c2c06f7eb296ce">dd0961426d3e1718c17fa226f3c2c06f7eb296ce</a>
-<blockquote>
-<p>
- CID 354310: Remove pointless unsigned comparison with 0.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 08:11: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=fae43bf37f78a2eef5a4418f428c41bdfd8a2738">fae43bf37f78a2eef5a4418f428c41bdfd8a2738</a>
-<blockquote>
-<p>
- CID 354291: Add error handling for inability to allocate<br>
-<br>
- Coverity complained about setting dash.pattern = NULL and &quot;Passing &quot;&amp;dash&quot;<br>
- to &quot;gstate_copy_dash&quot;, which dereferences null &quot;dash.pattern&quot; which is either<br>
- wrong, or *very* misleading. We assume that it means that gx_set_dash() *may*<br>
- access that pointer.<br>
-<br>
- In truth, this can never happen in these circumstances.<br>
-<br>
- Nevertheless, in gx_set_dash() is we have a NULL mem (allocator) pointer and the<br>
- dash pattern pointer is NULL at the point we have to copy into it, then throw<br>
- an error.<br>
-<br>
-base/gsline.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 19:59:03 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b3a7357594634fbd89a4cbf782d094289628acd6">b3a7357594634fbd89a4cbf782d094289628acd6</a>
-<blockquote>
-<p>
- Fix bug 702139 - clist clipping bug.<br>
-<br>
- When characters are filled as paths, the fill_adjust may be set to 0.<br>
- Clip paths are supposed to match fill paths, i.e. the 'any part of pixel'<br>
- rule, so we need fill_adjust of 0.5 (not 0). The most foolproof way to fix<br>
- this is to set it in the reader when processing 'begin_clip' and restore<br>
- it when handling the end_clip.<br>
-<br>
- There are many progressions with this change, but it also exposes some<br>
- cases where the change in clipping allows other elements to be seen that<br>
- were previously hidden. Those few instances are minor and mostly seem to<br>
- occur when page mode differs from clist mode. Examination of some of those<br>
- cases shows that the clip path with clist mode now matches page mode and<br>
- other elements (e.g. images) differ in extent between page and clist mode.<br>
-<br>
-base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 19:39:50 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea7aa02cc5c540c3332e0d4e81209a920360d45e">ea7aa02cc5c540c3332e0d4e81209a920360d45e</a>
-<blockquote>
-<p>
- Fix gx_default_copy_alpha_hl_color for 16 bit operation.<br>
-<br>
- The code to write the composite data back to buffers to be sent<br>
- to copy_alpha was getting the first byte of each 16 bit pair<br>
- wrong in the 16bit data case.<br>
-<br>
- Also, when we 'restart' after skipping a zero byte in the 16bit<br>
- case we need to skip 2 bytes per pixel, not one.<br>
-<br>
- This can be seen when running:<br>
-<br>
- gs -r72 -o out%d.psd -sDEVICE=psdcmyk16 -dMaxBitmap=2000M<br>
- ../tests_private/comparefiles/js.pdf<br>
-<br>
-base/gdevdbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 18:19:07 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d720180603fcd3853436fb002c6ff9c7fc956b27">d720180603fcd3853436fb002c6ff9c7fc956b27</a>
-<blockquote>
-<p>
- Fix psdcmyk16 blending issue.<br>
-<br>
- Use uint32_t rather than int to avoid signedness issues.<br>
-<br>
- Seen in the psdcmyk16 page mode rendering of<br>
-<br>
- tests_private/comparefiles/Bug692766.pdf<br>
-<br>
- (bad colors in 4th rgb circle intersection test).<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 15:57:36 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f038b63bc2fab4a71191583d36b1894ae3576f5">8f038b63bc2fab4a71191583d36b1894ae3576f5</a>
-<blockquote>
-<p>
- Fix coverity issues 354292 and 354293.<br>
-<br>
- Don't bother testing an unsigned value for clipping against 0.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 08:58:32 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ed426e9202e04e7d90194d92daedf9a12610b9f9">ed426e9202e04e7d90194d92daedf9a12610b9f9</a>
-<blockquote>
-<p>
- Replace 0 with NULL for pointer validation/setting.<br>
-<br>
- Also make validation an explicit comparison with NULL i.e.:<br>
- &quot;if (mem != NULL)&quot; rather than &quot;if (mem)&quot;.<br>
-<br>
-base/gsline.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 17:30:54 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b6fc7f2b05fa3cb7b120b05dbfa68a90da731a30">b6fc7f2b05fa3cb7b120b05dbfa68a90da731a30</a>
-<blockquote>
-<p>
- Add support for multiple squeezes in one run.<br>
-<br>
- E.g. MEMENTO_SQUEEZES=115867-1..+3,119928-1..+3 ...<br>
-<br>
- This is equivalent running multiple times with MEMENTO_FAILAT set to 115866,<br>
- 115867, 11588, 119927, 119928, 119929.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 10:38:53 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc6f92959507212b83130a24dd40b330e8ca9634">cc6f92959507212b83130a24dd40b330e8ca9634</a>
-<blockquote>
-<p>
- Fix for MEMENTO_FAILAT=119928: only call gs_grestoreall_for_restore() if vmsave-&gt;gsave not NULL.<br>
-<br>
- Also fix error cleanup in gs_gsave_for_save(), otherwise this fix breaks<br>
- previous fix for MEMENTO_FAILAT=115802.<br>
-<br>
- [Thanks to chrisl for this and various other recent fixes.]<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=119928 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-base/gsstate.c<br>
-psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 11:21:53 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c2a030517d269b020c99bcf754cefccb556ad7bd">c2a030517d269b020c99bcf754cefccb556ad7bd</a>
-<blockquote>
-<p>
- toolbin/squeeze2text.py: improve log output.<br>
-<br>
- With -p, if there is gap in 'Memory squeezing @ &lt;N&gt;' output (because of calls<br>
- to free()), output next &lt;N&gt;.<br>
-<br>
- Also flush log output to avoid looking like we've hung.<br>
-<br>
-toolbin/squeeze2text.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 21:00:21 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bab28178da29dabd691f7dee11ab5de62e329aa7">bab28178da29dabd691f7dee11ab5de62e329aa7</a>
-<blockquote>
-<p>
- Fix issue with fts_14_1416.pdf and psdcmyk16<br>
-<br>
- This was missed in the fix. Affected only 16 bit devices.<br>
-<br>
- http://git.ghostscript.com/?p=ghostpdl.git;a=commit;h=b1ac0686eea6adcf2db8cabf7858796494b4459d<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 20:05:49 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a2d4a7715f465911f174a8e764ab40b40455dd68">a2d4a7715f465911f174a8e764ab40b40455dd68</a>
-<blockquote>
-<p>
- Fix Ink names leaking.<br>
-<br>
- The cause of the leak was a typo in gx_final_DeviceN.<br>
-<br>
- Once this is fixed, we hit a problem where ink names are set<br>
- to be a pointer to a static empty string, which can't be<br>
- freed. Change to using NULL to mean empty ink name.<br>
-<br>
-base/gscdevn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 12:01:43 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6d678da952f7f4a19fb8b9e12f8cb8013d31f04d">6d678da952f7f4a19fb8b9e12f8cb8013d31f04d</a>
-<blockquote>
-<p>
- Memento/Valgrind tweak.<br>
-<br>
- Ensure we mark the contents of a block readable before we<br>
- look for pointers in it, and don't overrun the end.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 12:57:28 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=44f00686cbaea612747c336dc201ae3f682cc81b">44f00686cbaea612747c336dc201ae3f682cc81b</a>
-<blockquote>
-<p>
- Squash some unused variable warnings.<br>
-<br>
-base/claptrap-planar.c<br>
-base/gp_unifs.c<br>
-base/gxclpath.c<br>
-gpdl/tifftop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 12:14: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=26c2173179946ec8f70445f5941a4a20e707af88">26c2173179946ec8f70445f5941a4a20e707af88</a>
-<blockquote>
-<p>
- pdf14_{fill_stroke_path,clist_fill_stroke_path_pattern_setup} cleanups.<br>
-<br>
- Use a nicer method of breaking const (to avoid warnings). Ensure<br>
- that we always put everything back as it was when we leave the<br>
- functions, even if we have an error.<br>
-<br>
- Remove needless cleanup code to handle functions that can never<br>
- return an error to us returning an error.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 12:35:30 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a8839dbb536440bce927c4cb4977643495eee26a">a8839dbb536440bce927c4cb4977643495eee26a</a>
-<blockquote>
-<p>
- pdf14_clist_fill_stroke_path_pattern_setup overprint fix.<br>
-<br>
- Only enable CompatibleOverprint for the stroke part of stroke/fill<br>
- patterns if we are in a subtractive space.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 11:24:28 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3e84f1e1b0c52bd55145e35f8ddc0d5b8d1b65c5">3e84f1e1b0c52bd55145e35f8ddc0d5b8d1b65c5</a>
-<blockquote>
-<p>
- Squash some warnings with gs_swapcolors_quick breaking const.<br>
-<br>
- At various places in the code, we call gs_swapcolors_quick where<br>
- we only have a const pgs.<br>
-<br>
- Properly, we should copy the pgs to a non-const pgs, and then use<br>
- that, but that would be a performance hit.<br>
-<br>
- In all cases, we change the graphics state, then restore it before<br>
- exit, so effectively it is const over the entire call of the<br>
- enclosing procedure.<br>
-<br>
- Rather than having lots of small hacky casts removing const, we<br>
- push the const breakage into gs_swapcolors_quick itself where we<br>
- do it in the &quot;approved&quot; way using a union.<br>
-<br>
-base/gdevp14.c<br>
-base/gsstate.c<br>
-base/gxfill.c<br>
-base/gxgstate.h<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 10:10:25 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b61365607b75d456943f95360bff101c288ba555">b61365607b75d456943f95360bff101c288ba555</a>
-<blockquote>
-<p>
- Avoid floating point in gxblend.c<br>
-<br>
- Use fixed point in preference.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 08:23:59 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f8cd087b8a7b8c9b5cf5b8fd4d29e237f6103c7b">f8cd087b8a7b8c9b5cf5b8fd4d29e237f6103c7b</a>
-<blockquote>
-<p>
- Implement OPM tracking in pdfwrite<br>
-<br>
- More than somewhat to my surprise, the release testing of 9.51 revealed<br>
- that pdfwrite was not tracking the state of overprint mode (OPM). It<br>
- could be set by setdistillerparams, and in no other way.<br>
-<br>
- This commit adds tracking the OPM in the graphics state, removes the<br>
- old overprint_mode variable from the device, but preserves the ability<br>
- to alter the OPM using setdistillerparms.<br>
-<br>
- This also alters the initial state of OPM, the distiller params<br>
- reference states that the 'factory default' of OPM is 1, but the PDF<br>
- Reference says that the initial state of OPM is 0. We need to start<br>
- with the correct setting of OPM so we change it form 1 to 0<br>
- in gs_pdfwr.ps.<br>
-<br>
- In passing, cast a const gs_gstate * to a gs_gstate * when used by<br>
- gs_swapcolours_quick, in order to avoid a compiler warning.<br>
-<br>
- This causes a small number of progressions in files using OPM (which is<br>
- rare, its even rarer to actually alter it during the course of the file)<br>
-<br>
-Resource/Init/gs_pdfwr.ps<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfd.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 16:24:12 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1ac0686eea6adcf2db8cabf7858796494b4459d">b1ac0686eea6adcf2db8cabf7858796494b4459d</a>
-<blockquote>
-<p>
- Bug 702117 Knockout groups containing non-isolated groups<br>
-<br>
- So this ended up being rather complicated. The first issue was that<br>
- we were not setting the backdrop properly for non-isolated groups that<br>
- reside in knockout groups. When that was fixed, it was revealed that we<br>
- were not doing the recompositing operation for non-isolated knockout groups. This meant<br>
- that the backdrop was getting applied twice effectively (once in the original<br>
- fill and then again when the group was popped). The only file that showed<br>
- this issue was the crazy Altona page with the many overlapping groups. Customer<br>
- file added to provide a clearer case in the regression tests.<br>
-<br>
-base/gdevp14.c<br>
-base/gxblend.c<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 17:09:41 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ac299b11d53cf1d174a8351290918b536aa5859">4ac299b11d53cf1d174a8351290918b536aa5859</a>
-<blockquote>
-<p>
- Fix MEMENTO_FAILAT=115867 - segv in i_unregister_root() after failure in i_register_root().<br>
-<br>
- In pl_main_delete_instance(), don't call gs_unregister_root() if<br>
- minst-&gt;device_root is NULL.<br>
-<br>
- Also in pl_top_create_device(), check return from<br>
- gs_register_struct_root(). But this doesn't appear to make any difference to<br>
- the handling of the memento error.<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=115867 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 16:51:56 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9022073cb754ace5923c08e81d3b8d0be352abd9">9022073cb754ace5923c08e81d3b8d0be352abd9</a>
-<blockquote>
-<p>
- Fix deep color group compose issue.<br>
-<br>
- In commit bb7d57e84e9fe I reordered parameters to keep 8/16<br>
- branches consistent, and missed one case.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 15:27:07 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7c8c6c4ba0df88b5cbc4c0e8dab5f643a133603e">7c8c6c4ba0df88b5cbc4c0e8dab5f643a133603e</a>
-<blockquote>
-<p>
- Remove needless &quot;isolated&quot; parameter from pdf14_mark_rect routines.<br>
-<br>
- The value was carefully plumbed through (only in the 8bit case) in<br>
- a recent commit, but was never actually used. Remove it a) because<br>
- it's pointless passing a variable we don't use, and b) because it's<br>
- another difference between 8 and 16 bit versions.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 15:21:30 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c3c922510f0498d68d7a369f0ffd70379e3d5359">c3c922510f0498d68d7a369f0ffd70379e3d5359</a>
-<blockquote>
-<p>
- Fix typing mistake in 16bit transparency.<br>
-<br>
- When promoting from 8 to 16 bit, shape and src_alpha become<br>
- uint16_ts rather than bytes.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 15:06:38 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=713c776695f7a18cfd326e84fdef0b2911770609">713c776695f7a18cfd326e84fdef0b2911770609</a>
-<blockquote>
-<p>
- Fix more overprint problems with deep color transparency.<br>
-<br>
- Again, overprint changes to the 8 bit paths had not been<br>
- pulled across to the 16 bit path.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-19 07:10:40 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=075abaaa9ffa03af26bed1a32d3e5114511ee786">075abaaa9ffa03af26bed1a32d3e5114511ee786</a>
-<blockquote>
-<p>
- Added toolbin/squeeze2text.py, for processing output from MEMENTO_SQUEEZEAT=...<br>
-<br>
- An alternative to squeeze2html.pl, outputing just summary information.<br>
-<br>
-toolbin/squeeze2text.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 11:18:11 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fbcf5865f688201fba239c5dde0078e6733538c4">fbcf5865f688201fba239c5dde0078e6733538c4</a>
-<blockquote>
-<p>
- Fix for MEMENTO_FAILAT=115802: make gs_gsave_for_save() call gs_gsave() so it can restore after error.<br>
-<br>
- Previously, zsave() called gs_gsave_for_save() then gs_gsave(), but if<br>
- gs_gsave() failed we ended up with SEGV in finalise code.<br>
-<br>
- To allow zsave() to restore things after gs_gsave() failure, we would need to<br>
- add an include of base/gxgstate.h.<br>
-<br>
- Instead we remove the call of gs_gsave() from zsave() and append it to<br>
- gs_gsave_for_save(), where things can be easily restored if it fails.<br>
-<br>
- [There are no other callers of gs_gsave_for_save().]<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=115802 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-base/gsstate.c<br>
-psi/zvmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-18 09:44:51 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=356e24a53c60710ecfee991bb91cd503e3d9873b">356e24a53c60710ecfee991bb91cd503e3d9873b</a>
-<blockquote>
-<p>
- Avoid leaks if we get alloc failure when closing down (found by memento).<br>
-<br>
- In gs_main_finit(), ignore gs_error_VMerror from interp_reclaim(). Such error<br>
- ultimately comes from gs_vmreclaim() calling context_state_load(), but the<br>
- missing info doesn't seem to be required for gs_main_finit() to carry on.<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=147801 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 17:40:51 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e1257c1f03a4b16794d0c2df035b7ed8685a4254">e1257c1f03a4b16794d0c2df035b7ed8685a4254</a>
-<blockquote>
-<p>
- Fix image_color_icc_prep to properly align planar buffers.<br>
-<br>
-base/gxicolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 10:50:10 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ee682a20c494e8f1c65a7a95470252df6d9cdf4">5ee682a20c494e8f1c65a7a95470252df6d9cdf4</a>
-<blockquote>
-<p>
- Enable CAL for gxicolor halftoning.<br>
-<br>
- Looks like the calling code was unfinished, and the build<br>
- changes were not done.<br>
-<br>
- Also, squash some warnings.<br>
-<br>
-base/gxicolor.c<br>
-base/gximono.c<br>
-base/lib.mak<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-17 15:57:47 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d26e2d1c628d88263c4d946bdaf2145a438a1416">d26e2d1c628d88263c4d946bdaf2145a438a1416</a>
-<blockquote>
-<p>
- Ensure the memory entry in a cloned gstate is correct.<br>
-<br>
- In theory, we could end up cloning a graphics state with one allocator, then<br>
- assigning the &quot;memory&quot; entry in the cloned state to that of the state we are<br>
- cloning.<br>
-<br>
- In practice the two have (so far) been the same, but that is not guaranteed.<br>
-<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-14 11:08:57 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1faa24d998afa6ce98279f26514fe14edbd62e8e">1faa24d998afa6ce98279f26514fe14edbd62e8e</a>
-<blockquote>
-<p>
- Fix segfault cleaning up after gstate clone failure.<br>
-<br>
- For me this happens with MEMENTO_FAILAT=112447 and for Julian it happens with<br>
- MEMENTO_FAILAT=115905.<br>
-<br>
- Basically, the order of events was that we'd allocate a new gstate, copy the<br>
- contents of the existing gstate to the new one, then copy the dash pattern<br>
- (which could fail) and copy the &quot;client_data&quot; (which could and, in this case,<br>
- did fail). When either of those failed, we'd jump to the error handling and<br>
- exit with the error.<br>
-<br>
- The problem is that, by jumping to the &quot;fail&quot; label, we skip over all the code<br>
- that fixes up the reference counts (and various other things) to account for<br>
- the newly created gstate.<br>
-<br>
- This commit reorders things so we allocate the gstate, copy the client data,<br>
- copy the dash pattern, *then* assign the contents of the old gstate to the new<br>
- one, and carry on. Thus, by the time the gstate contents are copied, the<br>
- function cannot fail, and everything is sure to be correctly setup.<br>
-<br>
- In the event that either the dash pattern or the client data fail to allocate,<br>
- the new gstate is still filled with NULLs, except for the subset of<br>
- &quot;gs_gstate_parts&quot; which are allocated and setup correctly so we can safely<br>
- free the graphics state object before returning the error.<br>
-<br>
- Also, use NULL for pointer validation instead of 0.<br>
-<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-18 17:43:18 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f51ae6f4bf85dfa5be4b48a1a46ac69c653500c3">f51ae6f4bf85dfa5be4b48a1a46ac69c653500c3</a>
-<blockquote>
-<p>
- Make sure pattern fills use proper alpha settings<br>
-<br>
- Fix for regression of fts_28_2804.pdf pdfwrite output rendering<br>
- with fill-stroke commit. This also fixes the rendering of fts_25_2526.pdf<br>
- Bug 702033. Required a minor change in the XPS interpreter to make<br>
- sure that patterns did not have their opacity double applied.<br>
-<br>
-base/gdevp14.c<br>
-xps/xpstile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-19 17:20:09 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59806f121beba543de6d78a1b5765919bce9b2cb">59806f121beba543de6d78a1b5765919bce9b2cb</a>
-<blockquote>
-<p>
- Bug 702105: Premature EOF Infinite loop in interpolated imagemask stream.<br>
-<br>
- Fix supplied by Peter Cherepanov. Many thanks.<br>
-<br>
-base/simscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-19 16:58:06 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f860dbd9e699fcef50018fbd7cf84565237d78a3">f860dbd9e699fcef50018fbd7cf84565237d78a3</a>
-<blockquote>
-<p>
- Fix &quot;blue gradients&quot; seen with psdrgb device.<br>
-<br>
- Since the fill/stroke commit went in, some files have been showing<br>
- gradients in the wrong colours. For instance this one, spotted in<br>
- release testing:<br>
-<br>
- gs -sDEVICE=psdrgb -r72 -dMaxBitmap=2000M -o out%d.psd<br>
- ../tests_private/comparefiles/Layout.pdf<br>
-<br>
- Bisecting the fill/stroke branch back, it seems the commit that<br>
- caused it is the one that stops psdrgb using 'devn' colors.<br>
-<br>
- This causes gradients to drop to using the color_info.comp_bits and<br>
- comp_shift information, which the psd devices don't fill in.<br>
-<br>
- The fix here is to make psd_prn_open call the standard function for<br>
- setting up these values.<br>
-<br>
-devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 14:48:05 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ddccae87e67a4ea101f289549e2d1692b0230509">ddccae87e67a4ea101f289549e2d1692b0230509</a>
-<blockquote>
-<p>
- Bug701972 -- fix pdfwrite image downscaling bug<br>
-<br>
- Calculate the bits on the row using the input image width,<br>
- not the output image width.<br>
-<br>
- I had to add an extra argument to a few functions to propagate the info<br>
- down to where it is needed.<br>
-<br>
- Note obscure case involving calling psdf_setup_image_to_mask_filter()<br>
- for a Type 4 image and CompatibilityLevel &lt; 1.3. This change just<br>
- adds the extra input_width arg, which doesn't change whatever it was<br>
- doing before. If there is a bug lurking here, it seems unlikely<br>
- anybody cares?<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpsdf.h<br>
-devices/vector/gdevpsdi.c<br>
-devices/vector/gdevpsds.c<br>
-devices/vector/gdevpsds.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 09:22:55 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e2eaa8324ee4428de337ae3c31a695e68ede75b">4e2eaa8324ee4428de337ae3c31a695e68ede75b</a>
-<blockquote>
-<p>
- Set the BitsPerComponent for alt stream in pdfwrite<br>
-<br>
- Add this to the image[1] code where it was missing<br>
-<br>
- This fixes bug where compressed images were correct, but if<br>
- -dEncodeGrayImages=false was used, then they were truncated.<br>
-<br>
- This is related to trimmed/rescaled image for Bug701972.<br>
- See the sample trim-nobug.pdf attached to that bug.<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-18 19:25:24 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=76fb18bc255a88cab5fbb2410b411e580f53486d">76fb18bc255a88cab5fbb2410b411e580f53486d</a>
-<blockquote>
-<p>
- Bug 702131: Fix overprint in additive spaces.<br>
-<br>
- We should only enter CompatibleOverprint blend mode if we<br>
- are in an subtractive space. This stops pdf14 trying to honour<br>
- drawn_comps even in additive spaces.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-14 14:02:24 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f1b16fe2d0c6f23923fd26d03544030bc285365a">f1b16fe2d0c6f23923fd26d03544030bc285365a</a>
-<blockquote>
-<p>
- Fix bug 702079: SEGV with clist and PCL caused by wrong color in images.<br>
-<br>
- The clist_image_plane_data function was called with the dev_color for a band<br>
- being type &lt;pattern&gt; when the image had type &lt;pure&gt;, but the code was not<br>
- calling cmd_put_drawing_color to update the bands for the image because uses_color<br>
- was false. Add rop3_uses_S(pgs0&gt;log_op) as well as (||) rop3_uses_T(pgs-&gt;log_op)<br>
- when CombineWitColor is true.<br>
- Note that extra calls to cmd_put_drawing_color before an image are low cost<br>
- and do nothing if the current device color is already the same.<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-18 09:48:07 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=646007af056447fefd61eabfcdae85bfd6017d24">646007af056447fefd61eabfcdae85bfd6017d24</a>
-<blockquote>
-<p>
- Bug 702128 : clist pdf14 overprint state<br>
-<br>
- This change ensures that gxdso_overprint_active<br>
- gets the proper state information.<br>
-<br>
- When the clist writer is active with the pdf14 device, the writer maintains<br>
- the current overprint state (as the writer has no access to the pdf14 member variables)<br>
- and must know what to put in the clist.<br>
-<br>
- When the clist writer is not present (i.e. page mode), the pdf14 device<br>
- maintains the information.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-18 11:46: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=6ace930c11984e64aded98f1ff8db47104424354">6ace930c11984e64aded98f1ff8db47104424354</a>
-<blockquote>
-<p>
- Bug 702068 continued: Fix smasked images with masks.<br>
-<br>
- Release testing has shown up another case that needs help.<br>
-<br>
- gs/bin -sDEVICE=ppmraw -o out.ppm -r300 -dMaxBitmap=1G<br>
- tests_private/pdf/sumatra/1901_-_tiling_inconsistencies.pdf<br>
-<br>
- This shows horizontal white lines in the &quot;Next&quot; &quot;Up&quot; &quot;Previous&quot;<br>
- images at the top of the page.<br>
-<br>
- Investigation shows this is due to the images having Masks as well<br>
- as SMasks.<br>
-<br>
- The Mask image is run to a 1 bit memory device, which means that<br>
- the gxdso to check if we are in an SMask doesn't work. We work<br>
- around this by introducing a new flag to gs_pixel_image_common<br>
- that we can set to indicate that we are within an smask. We set<br>
- this when we set the masked image up (using the gxdso), and check<br>
- it when we come to do the gridfitting.<br>
-<br>
-base/gsiparam.h<br>
-base/gxclrast.c<br>
-base/gximage.c<br>
-base/gximage3.c<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-17 19:31:50 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb7d57e84e9fe615832b2d5811f4c9cd4d443cd1">bb7d57e84e9fe615832b2d5811f4c9cd4d443cd1</a>
-<blockquote>
-<p>
- Sync deep colour blending with recent changes to 8 bit blending.<br>
-<br>
- Release testing reveals problems with deep color blending and<br>
- overprint. This is because changes were made to the 8bit<br>
- branches of gxblend.c that weren't fully reflected in the<br>
- 16bit branches.<br>
-<br>
- Reapply those changes here.<br>
-<br>
- While we're at it, address some other minor code cleanups,<br>
- including keeping the ordering of parameters the same between 8<br>
- and 16 bit to avoid confusion in future.<br>
-<br>
- The command that showed the inital problem was:<br>
-<br>
- bin/gswin32c.exe -o out.psd -sDEVICE=psdcmyk16 tests_private/comparefiles/Bug695916.pdf<br>
-<br>
- where the image of the Earth did not appear.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-17 13:27:10 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e51ba18f031c4b5f6a14c0a559391fe30f409dd1">e51ba18f031c4b5f6a14c0a559391fe30f409dd1</a>
-<blockquote>
-<p>
- Bug 702130: Fix JPEG memory failure problems.<br>
-<br>
- The SEGV reported by Memento squeezing (which oddly is at 113600<br>
- for me, rather than Julian's higher number) is caused by jpeglib<br>
- calling 'mem_term' on something that failed to 'mem_init'.<br>
-<br>
- The fix is to use gs_memory_chunk_unwrap rather than target/release,<br>
- and to check whether mem == cmem to see whether that actually did<br>
- unwrap.<br>
-<br>
- This runs us into a further problem, where we are freeing the<br>
- custom memory descriptor using a gc memory pointer, where it was<br>
- allocated using a non gc one.<br>
-<br>
- Rather than just changing the free to use the non gc one, we take<br>
- the opportunity to ensure that ALL the blocks are in non gc memory.<br>
- JPEGlib will take poorly to its memory being gc'd away, and none<br>
- of it needs to subject to gc.<br>
-<br>
- Credit goes largely to Chris for this fix.<br>
-<br>
-base/sjpegc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-14 18:44:53 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=55a7a41998f35ae23aedf2fdb83698dde1453d58">55a7a41998f35ae23aedf2fdb83698dde1453d58</a>
-<blockquote>
-<p>
- Bug 702124 (continued): Avoid FP errors leading to empty pattern cells.<br>
-<br>
- The limited accuracy of floats can cause pattern cells to appear to<br>
- be empty when they are not.<br>
-<br>
- Avoid adding the (often large) tx and ty components in until after we<br>
- have calculated the width/heights.<br>
-<br>
-base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-14 18:43:00 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=182d5c10ed11570dd08e6203d832e06a73853f17">182d5c10ed11570dd08e6203d832e06a73853f17</a>
-<blockquote>
-<p>
- Bug 702124: Avoid VMerror when a pattern cell height is 0.<br>
-<br>
- We detect buffer_height == 0 and take it to mean that we can't<br>
- get a large enough buffer for even a single scanline. Actually<br>
- it can mean that the pattern cell was empty, which gives a<br>
- spurious error.<br>
-<br>
-base/gxmclip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-14 17:08:12 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f5b7acb59c4f2e88591aab9f355813e0b7b68db5">f5b7acb59c4f2e88591aab9f355813e0b7b68db5</a>
-<blockquote>
-<p>
- Fix segv after memento squeeze in psdf_DCT_filter().<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=117152 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-devices/vector/gdevpsdu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 14:54:42 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9fd069e5c91126e78b51625c72d884615370098c">9fd069e5c91126e78b51625c72d884615370098c</a>
-<blockquote>
-<p>
- Fixed double free after alloc failure in gs_lib_ctx_set_icc_directory*() (found by memento).<br>
-<br>
- After we've freed p_ctx-&gt;profiledir we need to set it to NULL otherwise if we<br>
- return an error it will be freed a second time when we close down.<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=101810 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 11:12:37 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d86e9d8251e142ab9aae9f50923414c0c18bf1d3">d86e9d8251e142ab9aae9f50923414c0c18bf1d3</a>
-<blockquote>
-<p>
- Fixed leak on error in gs_fapi_ufst_init() (found by memento).<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=22 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-base/fapiufst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 19:48: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=d7d68f45bfc227f7c7a6fdd5f8ef078bbf7ca77f">d7d68f45bfc227f7c7a6fdd5f8ef078bbf7ca77f</a>
-<blockquote>
-<p>
- Bug 702121: PCL performance degradation<br>
-<br>
- Henry chased the cause down to commit b399f84, an attempt to<br>
- fix Bug 700624. Looking at that code now, it has a silly typo<br>
- in it, that was causing it not be triggered in cases when it<br>
- should have been. Fixed here.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 11:11:40 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b58e9010ce17bce450e4c042b93bafc460b9d94a">b58e9010ce17bce450e4c042b93bafc460b9d94a</a>
-<blockquote>
-<p>
- Alternative fix for leaks after error in gs_main_init_with_args01()<br>
-<br>
- When memory squeezing gpdl, Julian found leaks in the gpdl<br>
- startup of the postscript interpreter when allocations failed<br>
- in gs_main_init_with_args01().<br>
-<br>
- Here, we fix the problem by making the psitop.c layer within gpdl<br>
- call the appropriate shutdown code when we catch the error. This<br>
- moves gpdl to being consistent with other users of the gs_main<br>
- layer.<br>
-<br>
- Memento memory squeezing around the point of failure (event 2035)<br>
- now shows this to be OK.<br>
-<br>
- MEMENTO_SQUEEZEAT=2034 ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-gpdl/psitop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 18:47:37 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5fc8e7c0b656d4e2be8f5e316121f06039c35273">5fc8e7c0b656d4e2be8f5e316121f06039c35273</a>
-<blockquote>
-<p>
- Revert &quot;Fix leaks after error in gs_main_init_with_args01() (found by memento).&quot;<br>
-<br>
- This reverts commit f35924926cb35f08be5a12ded4a00eb2f42aed3e.<br>
-<br>
- When memory squeezing gpdl, Julian found leaks in the gpdl<br>
- startup of the postscript interpreter when allocations failed<br>
- in gs_main_init_with_args01().<br>
-<br>
- The initial fix attempted was to make gs_main_init_with_args01()<br>
- closedown the interpreter on such errors. This worked for the<br>
- tested cases, but hid problems with non-memory related errors<br>
- (such as not being able to open a file specified on the command<br>
- line) when called by gs (rather than gpdl).<br>
-<br>
- The change attempted resulted in gs_main_finit() being called<br>
- twice as gs (and other users of the gs_main APIs) expect to have<br>
- to call gs_main_finit() to shut down after gs_main_init_with_args01()<br>
- returns an error code.<br>
-<br>
- The real problem is that gpdl is not doing this in the same way as<br>
- other callers.<br>
-<br>
- The gs_main layer has existed for donkeys years, so it's probably<br>
- best that we just take it as fixed and don't require callers to<br>
- start changing stuff now.<br>
-<br>
- Accordingly, I am reverting the attempted fix here, and will<br>
- try a different fix for it that only affects gpdl shortly.<br>
-<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 16:48:21 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd5f21df6c710664ff0ba3f100ca5283d9367ed8">cd5f21df6c710664ff0ba3f100ca5283d9367ed8</a>
-<blockquote>
-<p>
- Bug 702116 Avoid NULL dereference<br>
-<br>
- In certain cases if the source color space is separation or deviceN<br>
- and we are doing image interpolation with the use of fast color option<br>
- there was a potential dereference of a NULL pointer since the color<br>
- space will not have an ICC profile.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-11 16:48:24 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1f6b351a5048b5a14d52431c833da6ed3386a7bf">1f6b351a5048b5a14d52431c833da6ed3386a7bf</a>
-<blockquote>
-<p>
- Change to improve memory and speed (Bug 702099)<br>
-<br>
- As described in the bug, the patch to disable high-level images in<br>
- pattern-clists when Interpolate is true is no longer needed (hasn't<br>
- been since 2015), and it causes the memory and performance problems<br>
- with this type of file.<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 15:10:54 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c5883877d1dc7abbd7600eb688f7cf4ad34db0cc">c5883877d1dc7abbd7600eb688f7cf4ad34db0cc</a>
-<blockquote>
-<p>
- Bug 702114 non-isolated group in knockout group<br>
-<br>
- Make sure to use the parents backdrop as our backdrop when we<br>
- push a non-isolated group that resides in a knockout group.<br>
- Note though that this apparently is not the case if we are<br>
- constructing a soft mask.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 10:54:47 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=06a08fca00194531df25652b46eca8f8e4dfd7cc">06a08fca00194531df25652b46eca8f8e4dfd7cc</a>
-<blockquote>
-<p>
- Bug 702113 Softmask with transfer function<br>
-<br>
- In a couple spots we look at the value of the background value<br>
- of the softmask to decide if we really need the softmask in<br>
- areas outside the group bounding box. These checks were not<br>
- considering the impact of the transfer function.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 10:22:32 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6fc5cbc5bc57ae2c47d1276f1ea0c0f16017b4bb">6fc5cbc5bc57ae2c47d1276f1ea0c0f16017b4bb</a>
-<blockquote>
-<p>
- Bump version number pending 9.51 release<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/gscdefs.h<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-19 08:14:27 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e49830f8efdbc3a9f4e8acaf708b68a742f515aa">e49830f8efdbc3a9f4e8acaf708b68a742f515aa</a>
-<blockquote>
-<p>
- Version, dates etc for 9.52 release<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/version.mak<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/Internal.htm<br>
-doc/Language.htm<br>
-doc/Lib.htm<br>
-doc/Make.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>2020-03-17 15:54: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=0cade062486c0ae9c883970dea1c555a8ffcff84">0cade062486c0ae9c883970dea1c555a8ffcff84</a>
-<blockquote>
-<p>
- Release notes for 9.52 release<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-17 15:52:20 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c76b5f64e0525e4ddf9e5c311a1b75fe738298dc">c76b5f64e0525e4ddf9e5c311a1b75fe738298dc</a>
-<blockquote>
-<p>
- Add references to the 64 bit windows exes<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-14 15:07: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=eec073529fb8dc0c3bb6d612b61bf483d135c9cf">eec073529fb8dc0c3bb6d612b61bf483d135c9cf</a>
-<blockquote>
-<p>
- Bug 702217: Reinstate dynamic libs LDFLAGS for MacOS<br>
-<br>
- With the significant revamp of the platform detection functions in configure<br>
- the LDFLAGS for building the gs shared library on MacOS went astray. This<br>
- puts them back in.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-16 09:06:16 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a9cd9959372b9f14b493b87df57664ea831c5d80">a9cd9959372b9f14b493b87df57664ea831c5d80</a>
-<blockquote>
-<p>
- Repair device subclassing after fill+stroke commit<br>
-<br>
- Bug 702221 &quot;Ghostscript 9.51 - SIGFPE when -dFirstPage or -dLastPage is set&quot;<br>
-<br>
- The fill+stroke commit had an error with the default method for handling<br>
- fill_stroke_path which passed the subclassing device as a parameter to<br>
- the child, instead of passing the child device. This caused seg faults,<br>
- floating point exceptions, hangs, and possibly other problems.<br>
-<br>
- In addition the object filtering device had been modified to pass the<br>
- fill+stroke method to the default handler, instead of checking to see<br>
- if vector operations should be dropped.<br>
-<br>
- This commit fixes both problems.<br>
-<br>
-base/gdevoflt.c<br>
-base/gdevsclass.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-14 10:56: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=f712440a2f251ae06277ec4a5ffe8ce7599aa4d8">f712440a2f251ae06277ec4a5ffe8ce7599aa4d8</a>
-<blockquote>
-<p>
- Add ARCH_MAX_SIZE_T to configure's arch.h prototype<br>
-<br>
-arch/arch_autoconf.h.in<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-14 10:53:15 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=214d16924543fb3116a031463052e8b0eff3f1ae">214d16924543fb3116a031463052e8b0eff3f1ae</a>
-<blockquote>
-<p>
- Don't fail on missing freetype for auxtools run<br>
-<br>
- When cross compiling, we shouldn't fail the recursive call to configure if<br>
- there's no freetype - since it's not required for auxtools.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-12 11:49:11 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b02467bd535d50d221e4f7c371867603f5368f36">b02467bd535d50d221e4f7c371867603f5368f36</a>
-<blockquote>
-<p>
- Dates, changelog etc for 9.51 release<br>
-<br>
-base/gscdefs.h<br>
-base/version.mak<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/Internal.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>2020-03-02 17:10:43 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=15f5f8bad503e9d3e63db9c3ca395deffd6b1e20">15f5f8bad503e9d3e63db9c3ca395deffd6b1e20</a>
-<blockquote>
-<p>
- Fix 16bit blending problem.<br>
-<br>
- Seen with:<br>
-<br>
- gs -sDEVICE=psdcmyk16 -o out%d.psd -r72 -dMaxBitmap=2000M<br>
- tests_private/pdf/forms/v1.5/proxy_vol_1_number_1_1.pdf<br>
-<br>
- on page 3.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-02 11: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=d5809b79052b20c723700cce75e7e1543a3ddc23">d5809b79052b20c723700cce75e7e1543a3ddc23</a>
-<blockquote>
-<p>
- Dates/logs for 9.51 release candidate 3<br>
-<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/Internal.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>2020-03-02 11:04:32 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6e3e9238bb5cf7fe44c3c845be286a3314ed905">f6e3e9238bb5cf7fe44c3c845be286a3314ed905</a>
-<blockquote>
-<p>
- Fix 64bit non-console windows build.<br>
-<br>
- The creation of the text window was truncating the pointer to<br>
- long (32bit) size. No idea how we've been getting away with this<br>
- in the past. I can only assume this has been exposed by<br>
- differences in the runtime lib with vs2019 as compared to<br>
- earlier versions.<br>
-<br>
-psi/dwtext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-02 09:02: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=ffe0e5cf33feee7672e5f4281f0c0b0ff66bddda">ffe0e5cf33feee7672e5f4281f0c0b0ff66bddda</a>
-<blockquote>
-<p>
- Add mention of deprecating/removing opvp/oprp devices<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-28 08:30:36 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a1478a72a3ccb8564c2b1c5c87d3dbe23a5ffff2">a1478a72a3ccb8564c2b1c5c87d3dbe23a5ffff2</a>
-<blockquote>
-<p>
- Dates, changelog etc for 9.51rc2<br>
-<br>
-base/gscdefs.h<br>
-base/version.mak<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/Internal.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>2020-02-26 15:22:04 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dbaddcf6e251229a1506f2df33844365df39de44">dbaddcf6e251229a1506f2df33844365df39de44</a>
-<blockquote>
-<p>
- Fix signed issue in 16bit alpha blending fill_rectangle routines.<br>
-<br>
- As seen by the central spot in the pink region of page 1 of:<br>
-<br>
- gs -sDEVICE=psdcmyk16 -o out%d.psd -dMaxBitmap=2000M<br>
- tests_private/pdf/pdf_1.7_ATS_EXXPA1DC_PDFACT.pdf<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 15:09:35 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ad8020c3cb63345dd76119e8978c3353940a68e">4ad8020c3cb63345dd76119e8978c3353940a68e</a>
-<blockquote>
-<p>
- pdfwrite - Fix indeterminism with QL shading tests<br>
-<br>
- When creating a new colour space to put in a PDF file we perform various<br>
- tests to see if its a space we have already written, to prevent writing<br>
- duplicate spaces (we perform similar tests for most resources).<br>
-<br>
- In some cases, when we write the resource to a file, we create an MD5<br>
- hash and compare those to see if the resources are the same. In the<br>
- case of colour spaces, however, they are retained in memory and so we<br>
- use a different method. We 'serialise' the colour space. This is not the<br>
- same as writing it to the PDF file, and its a graphics library thing not<br>
- a pdfwrite function. Basically this writes out the content of the<br>
- various C structures. The stream we use is an in-memory stream.<br>
-<br>
- Unfortunately, for Separation colour spaces, there was a fault in the<br>
- function which writes the colour space name, and it was writing out<br>
- the bytes forming the address of the name instead of the actual string.<br>
-<br>
- This could, very rarely, mean that we would mis-identify a new colour<br>
- space as being the same as an old colour space, and so would reuse the<br>
- old space instead of creating a new one.<br>
-<br>
- I've checked the DeviceN code and it does not suffer the same problem.<br>
-<br>
-base/gscsepr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 13:03:56 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3cb8b3a403450d617b2b96ec0349bb99ce0d8379">3cb8b3a403450d617b2b96ec0349bb99ce0d8379</a>
-<blockquote>
-<p>
- Fix the overflow case in 16 bit saturation blending.<br>
-<br>
- As seen with the second apple of the bottom row of page 1<br>
- of:<br>
-<br>
- gs -sDEVICE=psdcmyk16 -r72 -o out%d.psd -dMaxBitmap=2000M<br>
- ../tests_private/pdf/PDF_1.7_ATS/AIX4G1C3.pdf<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 17:10:51 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5d4305e916d3f75492d03dfd79ab1aaedf9545e3">5d4305e916d3f75492d03dfd79ab1aaedf9545e3</a>
-<blockquote>
-<p>
- Fix for bug 702150: make pl_main_run_file_utf8() check for error from s_process_read_buf().<br>
-<br>
- Avoids infinite loop in:<br>
- ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null .<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 18:24:55 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c6efee0f594ad29394bf8a303f21d85dcb1d70a">2c6efee0f594ad29394bf8a303f21d85dcb1d70a</a>
-<blockquote>
-<p>
- minor improvements to toolbin/squeeze2text.py.<br>
-<br>
-toolbin/squeeze2text.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 08:25:13 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef5dfe7e3b3858bdfb20c168b4818c4d65fb932f">ef5dfe7e3b3858bdfb20c168b4818c4d65fb932f</a>
-<blockquote>
-<p>
- CID 354310: Remove pointless unsigned comparison with 0.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 08:11: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=29335f43967a0f089d6f2f37883a22f1516f7bde">29335f43967a0f089d6f2f37883a22f1516f7bde</a>
-<blockquote>
-<p>
- CID 354291: Add error handling for inability to allocate<br>
-<br>
- Coverity complained about setting dash.pattern = NULL and &quot;Passing &quot;&amp;dash&quot;<br>
- to &quot;gstate_copy_dash&quot;, which dereferences null &quot;dash.pattern&quot; which is either<br>
- wrong, or *very* misleading. We assume that it means that gx_set_dash() *may*<br>
- access that pointer.<br>
-<br>
- In truth, this can never happen in these circumstances.<br>
-<br>
- Nevertheless, in gx_set_dash() is we have a NULL mem (allocator) pointer and the<br>
- dash pattern pointer is NULL at the point we have to copy into it, then throw<br>
- an error.<br>
-<br>
-base/gsline.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 19:59:03 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d0889b9fcf3a5d5012fad021b4c53828879016e">1d0889b9fcf3a5d5012fad021b4c53828879016e</a>
-<blockquote>
-<p>
- Fix bug 702139 - clist clipping bug.<br>
-<br>
- When characters are filled as paths, the fill_adjust may be set to 0.<br>
- Clip paths are supposed to match fill paths, i.e. the 'any part of pixel'<br>
- rule, so we need fill_adjust of 0.5 (not 0). The most foolproof way to fix<br>
- this is to set it in the reader when processing 'begin_clip' and restore<br>
- it when handling the end_clip.<br>
-<br>
- There are many progressions with this change, but it also exposes some<br>
- cases where the change in clipping allows other elements to be seen that<br>
- were previously hidden. Those few instances are minor and mostly seem to<br>
- occur when page mode differs from clist mode. Examination of some of those<br>
- cases shows that the clip path with clist mode now matches page mode and<br>
- other elements (e.g. images) differ in extent between page and clist mode.<br>
-<br>
-base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 19:39:50 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=86f81e9b799b66207c699768616a6e3ba3c311c3">86f81e9b799b66207c699768616a6e3ba3c311c3</a>
-<blockquote>
-<p>
- Fix gx_default_copy_alpha_hl_color for 16 bit operation.<br>
-<br>
- The code to write the composite data back to buffers to be sent<br>
- to copy_alpha was getting the first byte of each 16 bit pair<br>
- wrong in the 16bit data case.<br>
-<br>
- Also, when we 'restart' after skipping a zero byte in the 16bit<br>
- case we need to skip 2 bytes per pixel, not one.<br>
-<br>
- This can be seen when running:<br>
-<br>
- gs -r72 -o out%d.psd -sDEVICE=psdcmyk16 -dMaxBitmap=2000M<br>
- ../tests_private/comparefiles/js.pdf<br>
-<br>
-base/gdevdbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 18:19:07 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=635303ca7d8a36b3dabc9afbd9132f4b9a36dce5">635303ca7d8a36b3dabc9afbd9132f4b9a36dce5</a>
-<blockquote>
-<p>
- Fix psdcmyk16 blending issue.<br>
-<br>
- Use uint32_t rather than int to avoid signedness issues.<br>
-<br>
- Seen in the psdcmyk16 page mode rendering of<br>
-<br>
- tests_private/comparefiles/Bug692766.pdf<br>
-<br>
- (bad colors in 4th rgb circle intersection test).<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 15:57:36 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a00c75369e082798d82202a2b64d8e4b484d0c11">a00c75369e082798d82202a2b64d8e4b484d0c11</a>
-<blockquote>
-<p>
- Fix coverity issues 354292 and 354293.<br>
-<br>
- Don't bother testing an unsigned value for clipping against 0.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 08:58:32 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=32f3d6703a7e5c6582c066837783c6697e98b1ca">32f3d6703a7e5c6582c066837783c6697e98b1ca</a>
-<blockquote>
-<p>
- Replace 0 with NULL for pointer validation/setting.<br>
-<br>
- Also make validation an explicit comparison with NULL i.e.:<br>
- &quot;if (mem != NULL)&quot; rather than &quot;if (mem)&quot;.<br>
-<br>
-base/gsline.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 17:30:54 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c1002cc251907e702fd5db9dc81365a964816c6">6c1002cc251907e702fd5db9dc81365a964816c6</a>
-<blockquote>
-<p>
- Add support for multiple squeezes in one run.<br>
-<br>
- E.g. MEMENTO_SQUEEZES=115867-1..+3,119928-1..+3 ...<br>
-<br>
- This is equivalent running multiple times with MEMENTO_FAILAT set to 115866,<br>
- 115867, 11588, 119927, 119928, 119929.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 10:38:53 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39557bd53eee75a8b8f762457ce57a5437e79d6c">39557bd53eee75a8b8f762457ce57a5437e79d6c</a>
-<blockquote>
-<p>
- Fix for MEMENTO_FAILAT=119928: only call gs_grestoreall_for_restore() if vmsave-&gt;gsave not NULL.<br>
-<br>
- Also fix error cleanup in gs_gsave_for_save(), otherwise this fix breaks<br>
- previous fix for MEMENTO_FAILAT=115802.<br>
-<br>
- [Thanks to chrisl for this and various other recent fixes.]<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=119928 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-base/gsstate.c<br>
-psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 11:21:53 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=60507d492507817bb5ae14a17a01d19c50d41e0a">60507d492507817bb5ae14a17a01d19c50d41e0a</a>
-<blockquote>
-<p>
- toolbin/squeeze2text.py: improve log output.<br>
-<br>
- With -p, if there is gap in 'Memory squeezing @ &lt;N&gt;' output (because of calls<br>
- to free()), output next &lt;N&gt;.<br>
-<br>
- Also flush log output to avoid looking like we've hung.<br>
-<br>
-toolbin/squeeze2text.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 21:00:21 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3a9ea36465e97ce729c5ab26dc8e0d1435b7b246">3a9ea36465e97ce729c5ab26dc8e0d1435b7b246</a>
-<blockquote>
-<p>
- Fix issue with fts_14_1416.pdf and psdcmyk16<br>
-<br>
- This was missed in the fix. Affected only 16 bit devices.<br>
-<br>
- http://git.ghostscript.com/?p=ghostpdl.git;a=commit;h=b1ac0686eea6adcf2db8cabf7858796494b4459d<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 20:05:49 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f3320f9b6214907d24a4a9f77638b199aa95f8e">8f3320f9b6214907d24a4a9f77638b199aa95f8e</a>
-<blockquote>
-<p>
- Fix Ink names leaking.<br>
-<br>
- The cause of the leak was a typo in gx_final_DeviceN.<br>
-<br>
- Once this is fixed, we hit a problem where ink names are set<br>
- to be a pointer to a static empty string, which can't be<br>
- freed. Change to using NULL to mean empty ink name.<br>
-<br>
-base/gscdevn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 12:01:43 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b28d57e7422d2d4df8c805342ad01dfc6c6e1232">b28d57e7422d2d4df8c805342ad01dfc6c6e1232</a>
-<blockquote>
-<p>
- Memento/Valgrind tweak.<br>
-<br>
- Ensure we mark the contents of a block readable before we<br>
- look for pointers in it, and don't overrun the end.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 12:57:28 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0822ac2a5f1f02315a783504fccf615a55cf494f">0822ac2a5f1f02315a783504fccf615a55cf494f</a>
-<blockquote>
-<p>
- Squash some unused variable warnings.<br>
-<br>
-base/claptrap-planar.c<br>
-base/gp_unifs.c<br>
-base/gxclpath.c<br>
-gpdl/tifftop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 12:14: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=82a2d6356858c0a4ab9ff7fa294c0380d04aa9e3">82a2d6356858c0a4ab9ff7fa294c0380d04aa9e3</a>
-<blockquote>
-<p>
- pdf14_{fill_stroke_path,clist_fill_stroke_path_pattern_setup} cleanups.<br>
-<br>
- Use a nicer method of breaking const (to avoid warnings). Ensure<br>
- that we always put everything back as it was when we leave the<br>
- functions, even if we have an error.<br>
-<br>
- Remove needless cleanup code to handle functions that can never<br>
- return an error to us returning an error.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 12:35:30 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1ff23ccf08707af544de59d6c59971d0c17098c">b1ff23ccf08707af544de59d6c59971d0c17098c</a>
-<blockquote>
-<p>
- pdf14_clist_fill_stroke_path_pattern_setup overprint fix.<br>
-<br>
- Only enable CompatibleOverprint for the stroke part of stroke/fill<br>
- patterns if we are in a subtractive space.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 11:24:28 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=389324fd827e1172eb358b616a32af5fcb2633f6">389324fd827e1172eb358b616a32af5fcb2633f6</a>
-<blockquote>
-<p>
- Squash some warnings with gs_swapcolors_quick breaking const.<br>
-<br>
- At various places in the code, we call gs_swapcolors_quick where<br>
- we only have a const pgs.<br>
-<br>
- Properly, we should copy the pgs to a non-const pgs, and then use<br>
- that, but that would be a performance hit.<br>
-<br>
- In all cases, we change the graphics state, then restore it before<br>
- exit, so effectively it is const over the entire call of the<br>
- enclosing procedure.<br>
-<br>
- Rather than having lots of small hacky casts removing const, we<br>
- push the const breakage into gs_swapcolors_quick itself where we<br>
- do it in the &quot;approved&quot; way using a union.<br>
-<br>
-base/gdevp14.c<br>
-base/gsstate.c<br>
-base/gxfill.c<br>
-base/gxgstate.h<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 10:10:25 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=449433ff6689c603a56186dbde5721f6139aa939">449433ff6689c603a56186dbde5721f6139aa939</a>
-<blockquote>
-<p>
- Avoid floating point in gxblend.c<br>
-<br>
- Use fixed point in preference.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 08:23:59 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6badfb362efe0fb4f0c3df106a33ecd5b0265ef7">6badfb362efe0fb4f0c3df106a33ecd5b0265ef7</a>
-<blockquote>
-<p>
- Implement OPM tracking in pdfwrite<br>
-<br>
- More than somewhat to my surprise, the release testing of 9.51 revealed<br>
- that pdfwrite was not tracking the state of overprint mode (OPM). It<br>
- could be set by setdistillerparams, and in no other way.<br>
-<br>
- This commit adds tracking the OPM in the graphics state, removes the<br>
- old overprint_mode variable from the device, but preserves the ability<br>
- to alter the OPM using setdistillerparms.<br>
-<br>
- This also alters the initial state of OPM, the distiller params<br>
- reference states that the 'factory default' of OPM is 1, but the PDF<br>
- Reference says that the initial state of OPM is 0. We need to start<br>
- with the correct setting of OPM so we change it form 1 to 0<br>
- in gs_pdfwr.ps.<br>
-<br>
- In passing, cast a const gs_gstate * to a gs_gstate * when used by<br>
- gs_swapcolours_quick, in order to avoid a compiler warning.<br>
-<br>
- This causes a small number of progressions in files using OPM (which is<br>
- rare, its even rarer to actually alter it during the course of the file)<br>
-<br>
-Resource/Init/gs_pdfwr.ps<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfd.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 16:24:12 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3dc65600d6d4eb060398f06f148cfe4f07a82439">3dc65600d6d4eb060398f06f148cfe4f07a82439</a>
-<blockquote>
-<p>
- Bug 702117 Knockout groups containing non-isolated groups<br>
-<br>
- So this ended up being rather complicated. The first issue was that<br>
- we were not setting the backdrop properly for non-isolated groups that<br>
- reside in knockout groups. When that was fixed, it was revealed that we<br>
- were not doing the recompositing operation for non-isolated knockout groups. This meant<br>
- that the backdrop was getting applied twice effectively (once in the original<br>
- fill and then again when the group was popped). The only file that showed<br>
- this issue was the crazy Altona page with the many overlapping groups. Customer<br>
- file added to provide a clearer case in the regression tests.<br>
-<br>
-base/gdevp14.c<br>
-base/gxblend.c<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 17:09:41 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=416baca7c4bcf0b1794b7b1647250bf09adaee9d">416baca7c4bcf0b1794b7b1647250bf09adaee9d</a>
-<blockquote>
-<p>
- Fix MEMENTO_FAILAT=115867 - segv in i_unregister_root() after failure in i_register_root().<br>
-<br>
- In pl_main_delete_instance(), don't call gs_unregister_root() if<br>
- minst-&gt;device_root is NULL.<br>
-<br>
- Also in pl_top_create_device(), check return from<br>
- gs_register_struct_root(). But this doesn't appear to make any difference to<br>
- the handling of the memento error.<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=115867 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 16:51:56 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4eb54af16c69ef36371291bd43f853865adea1eb">4eb54af16c69ef36371291bd43f853865adea1eb</a>
-<blockquote>
-<p>
- Fix deep color group compose issue.<br>
-<br>
- In commit bb7d57e84e9fe I reordered parameters to keep 8/16<br>
- branches consistent, and missed one case.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 15:27:07 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a2276988137021618bb3ca440aba50e126160bcd">a2276988137021618bb3ca440aba50e126160bcd</a>
-<blockquote>
-<p>
- Remove needless &quot;isolated&quot; parameter from pdf14_mark_rect routines.<br>
-<br>
- The value was carefully plumbed through (only in the 8bit case) in<br>
- a recent commit, but was never actually used. Remove it a) because<br>
- it's pointless passing a variable we don't use, and b) because it's<br>
- another difference between 8 and 16 bit versions.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 15:21:30 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9ddcae93fe1629e81d36b17b7fec9de787b411cc">9ddcae93fe1629e81d36b17b7fec9de787b411cc</a>
-<blockquote>
-<p>
- Fix typing mistake in 16bit transparency.<br>
-<br>
- When promoting from 8 to 16 bit, shape and src_alpha become<br>
- uint16_ts rather than bytes.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 15:06:38 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7de8fe5a49df0f9154fa707a934e39c012c3cc2a">7de8fe5a49df0f9154fa707a934e39c012c3cc2a</a>
-<blockquote>
-<p>
- Fix more overprint problems with deep color transparency.<br>
-<br>
- Again, overprint changes to the 8 bit paths had not been<br>
- pulled across to the 16 bit path.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-19 07:10:40 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2d3f8c01231d52a5595e2727b31b8044188a5af8">2d3f8c01231d52a5595e2727b31b8044188a5af8</a>
-<blockquote>
-<p>
- Added toolbin/squeeze2text.py, for processing output from MEMENTO_SQUEEZEAT=...<br>
-<br>
- An alternative to squeeze2html.pl, outputing just summary information.<br>
-<br>
-toolbin/squeeze2text.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 11:18:11 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=777d79315e0094bef83d241bc0d5683ea6775a55">777d79315e0094bef83d241bc0d5683ea6775a55</a>
-<blockquote>
-<p>
- Fix for MEMENTO_FAILAT=115802: make gs_gsave_for_save() call gs_gsave() so it can restore after error.<br>
-<br>
- Previously, zsave() called gs_gsave_for_save() then gs_gsave(), but if<br>
- gs_gsave() failed we ended up with SEGV in finalise code.<br>
-<br>
- To allow zsave() to restore things after gs_gsave() failure, we would need to<br>
- add an include of base/gxgstate.h.<br>
-<br>
- Instead we remove the call of gs_gsave() from zsave() and append it to<br>
- gs_gsave_for_save(), where things can be easily restored if it fails.<br>
-<br>
- [There are no other callers of gs_gsave_for_save().]<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=115802 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-base/gsstate.c<br>
-psi/zvmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-18 09:44:51 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6db4560f1e31bb92321894e0d008d310aa600097">6db4560f1e31bb92321894e0d008d310aa600097</a>
-<blockquote>
-<p>
- Avoid leaks if we get alloc failure when closing down (found by memento).<br>
-<br>
- In gs_main_finit(), ignore gs_error_VMerror from interp_reclaim(). Such error<br>
- ultimately comes from gs_vmreclaim() calling context_state_load(), but the<br>
- missing info doesn't seem to be required for gs_main_finit() to carry on.<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=147801 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 17:40:51 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb726fb4d2597cfcd4986dd9c105cf1ab71d09e3">eb726fb4d2597cfcd4986dd9c105cf1ab71d09e3</a>
-<blockquote>
-<p>
- Fix image_color_icc_prep to properly align planar buffers.<br>
-<br>
-base/gxicolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 10:50:10 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e01371e00caa8f5d08ef150a6f594c93ca495be2">e01371e00caa8f5d08ef150a6f594c93ca495be2</a>
-<blockquote>
-<p>
- Enable CAL for gxicolor halftoning.<br>
-<br>
- Looks like the calling code was unfinished, and the build<br>
- changes were not done.<br>
-<br>
- Also, squash some warnings.<br>
-<br>
-base/gxicolor.c<br>
-base/gximono.c<br>
-base/lib.mak<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-17 15:57:47 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c4e7cddc4d053f2850e697696e2498180547961a">c4e7cddc4d053f2850e697696e2498180547961a</a>
-<blockquote>
-<p>
- Ensure the memory entry in a cloned gstate is correct.<br>
-<br>
- In theory, we could end up cloning a graphics state with one allocator, then<br>
- assigning the &quot;memory&quot; entry in the cloned state to that of the state we are<br>
- cloning.<br>
-<br>
- In practice the two have (so far) been the same, but that is not guaranteed.<br>
-<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-14 11:08:57 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=239e70cd02491bab1cce9092c07c959427358646">239e70cd02491bab1cce9092c07c959427358646</a>
-<blockquote>
-<p>
- Fix segfault cleaning up after gstate clone failure.<br>
-<br>
- For me this happens with MEMENTO_FAILAT=112447 and for Julian it happens with<br>
- MEMENTO_FAILAT=115905.<br>
-<br>
- Basically, the order of events was that we'd allocate a new gstate, copy the<br>
- contents of the existing gstate to the new one, then copy the dash pattern<br>
- (which could fail) and copy the &quot;client_data&quot; (which could and, in this case,<br>
- did fail). When either of those failed, we'd jump to the error handling and<br>
- exit with the error.<br>
-<br>
- The problem is that, by jumping to the &quot;fail&quot; label, we skip over all the code<br>
- that fixes up the reference counts (and various other things) to account for<br>
- the newly created gstate.<br>
-<br>
- This commit reorders things so we allocate the gstate, copy the client data,<br>
- copy the dash pattern, *then* assign the contents of the old gstate to the new<br>
- one, and carry on. Thus, by the time the gstate contents are copied, the<br>
- function cannot fail, and everything is sure to be correctly setup.<br>
-<br>
- In the event that either the dash pattern or the client data fail to allocate,<br>
- the new gstate is still filled with NULLs, except for the subset of<br>
- &quot;gs_gstate_parts&quot; which are allocated and setup correctly so we can safely<br>
- free the graphics state object before returning the error.<br>
-<br>
- Also, use NULL for pointer validation instead of 0.<br>
-<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-18 17:43:18 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db5b51109ddee39b17b2ff2c2ac12f41a70785ef">db5b51109ddee39b17b2ff2c2ac12f41a70785ef</a>
-<blockquote>
-<p>
- Make sure pattern fills use proper alpha settings<br>
-<br>
- Fix for regression of fts_28_2804.pdf pdfwrite output rendering<br>
- with fill-stroke commit. This also fixes the rendering of fts_25_2526.pdf<br>
- Bug 702033. Required a minor change in the XPS interpreter to make<br>
- sure that patterns did not have their opacity double applied.<br>
-<br>
-base/gdevp14.c<br>
-xps/xpstile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-19 17:20:09 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cddd44e1bfcdaba1c289c3d83645613d136e5e3e">cddd44e1bfcdaba1c289c3d83645613d136e5e3e</a>
-<blockquote>
-<p>
- Bug 702105: Premature EOF Infinite loop in interpolated imagemask stream.<br>
-<br>
- Fix supplied by Peter Cherepanov. Many thanks.<br>
-<br>
-base/simscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-19 16:58:06 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59089ab66b3faaa683bb3aeb0bf856b7aa284f9b">59089ab66b3faaa683bb3aeb0bf856b7aa284f9b</a>
-<blockquote>
-<p>
- Fix &quot;blue gradients&quot; seen with psdrgb device.<br>
-<br>
- Since the fill/stroke commit went in, some files have been showing<br>
- gradients in the wrong colours. For instance this one, spotted in<br>
- release testing:<br>
-<br>
- gs -sDEVICE=psdrgb -r72 -dMaxBitmap=2000M -o out%d.psd<br>
- ../tests_private/comparefiles/Layout.pdf<br>
-<br>
- Bisecting the fill/stroke branch back, it seems the commit that<br>
- caused it is the one that stops psdrgb using 'devn' colors.<br>
-<br>
- This causes gradients to drop to using the color_info.comp_bits and<br>
- comp_shift information, which the psd devices don't fill in.<br>
-<br>
- The fix here is to make psd_prn_open call the standard function for<br>
- setting up these values.<br>
-<br>
-devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 14:48:05 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=25cd0c72b98f9efc6968254d1e3a2f33ec376369">25cd0c72b98f9efc6968254d1e3a2f33ec376369</a>
-<blockquote>
-<p>
- Bug701972 -- fix pdfwrite image downscaling bug<br>
-<br>
- Calculate the bits on the row using the input image width,<br>
- not the output image width.<br>
-<br>
- I had to add an extra argument to a few functions to propagate the info<br>
- down to where it is needed.<br>
-<br>
- Note obscure case involving calling psdf_setup_image_to_mask_filter()<br>
- for a Type 4 image and CompatibilityLevel &lt; 1.3. This change just<br>
- adds the extra input_width arg, which doesn't change whatever it was<br>
- doing before. If there is a bug lurking here, it seems unlikely<br>
- anybody cares?<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpsdf.h<br>
-devices/vector/gdevpsdi.c<br>
-devices/vector/gdevpsds.c<br>
-devices/vector/gdevpsds.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 09:22:55 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e9523603ac713e365702b81c228edcaaac667dc4">e9523603ac713e365702b81c228edcaaac667dc4</a>
-<blockquote>
-<p>
- Set the BitsPerComponent for alt stream in pdfwrite<br>
-<br>
- Add this to the image[1] code where it was missing<br>
-<br>
- This fixes bug where compressed images were correct, but if<br>
- -dEncodeGrayImages=false was used, then they were truncated.<br>
-<br>
- This is related to trimmed/rescaled image for Bug701972.<br>
- See the sample trim-nobug.pdf attached to that bug.<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-18 19:25:24 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=924f7ea07c7773a3b1510c6206c9a34227e4b39e">924f7ea07c7773a3b1510c6206c9a34227e4b39e</a>
-<blockquote>
-<p>
- Bug 702131: Fix overprint in additive spaces.<br>
-<br>
- We should only enter CompatibleOverprint blend mode if we<br>
- are in an subtractive space. This stops pdf14 trying to honour<br>
- drawn_comps even in additive spaces.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-14 14:02:24 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d98b553c829fad94cd4338910468d2b1b6ee64f7">d98b553c829fad94cd4338910468d2b1b6ee64f7</a>
-<blockquote>
-<p>
- Fix bug 702079: SEGV with clist and PCL caused by wrong color in images.<br>
-<br>
- The clist_image_plane_data function was called with the dev_color for a band<br>
- being type &lt;pattern&gt; when the image had type &lt;pure&gt;, but the code was not<br>
- calling cmd_put_drawing_color to update the bands for the image because uses_color<br>
- was false. Add rop3_uses_S(pgs0&gt;log_op) as well as (||) rop3_uses_T(pgs-&gt;log_op)<br>
- when CombineWitColor is true.<br>
- Note that extra calls to cmd_put_drawing_color before an image are low cost<br>
- and do nothing if the current device color is already the same.<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-18 09:48:07 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f55464d5c1640075a67a8b50557a48766783e08">4f55464d5c1640075a67a8b50557a48766783e08</a>
-<blockquote>
-<p>
- Bug 702128 : clist pdf14 overprint state<br>
-<br>
- This change ensures that gxdso_overprint_active<br>
- gets the proper state information.<br>
-<br>
- When the clist writer is active with the pdf14 device, the writer maintains<br>
- the current overprint state (as the writer has no access to the pdf14 member variables)<br>
- and must know what to put in the clist.<br>
-<br>
- When the clist writer is not present (i.e. page mode), the pdf14 device<br>
- maintains the information.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-18 11:46: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=f1887408860910c19c980f05fd0f8fc93b5f06a1">f1887408860910c19c980f05fd0f8fc93b5f06a1</a>
-<blockquote>
-<p>
- Bug 702068 continued: Fix smasked images with masks.<br>
-<br>
- Release testing has shown up another case that needs help.<br>
-<br>
- gs/bin -sDEVICE=ppmraw -o out.ppm -r300 -dMaxBitmap=1G<br>
- tests_private/pdf/sumatra/1901_-_tiling_inconsistencies.pdf<br>
-<br>
- This shows horizontal white lines in the &quot;Next&quot; &quot;Up&quot; &quot;Previous&quot;<br>
- images at the top of the page.<br>
-<br>
- Investigation shows this is due to the images having Masks as well<br>
- as SMasks.<br>
-<br>
- The Mask image is run to a 1 bit memory device, which means that<br>
- the gxdso to check if we are in an SMask doesn't work. We work<br>
- around this by introducing a new flag to gs_pixel_image_common<br>
- that we can set to indicate that we are within an smask. We set<br>
- this when we set the masked image up (using the gxdso), and check<br>
- it when we come to do the gridfitting.<br>
-<br>
-base/gsiparam.h<br>
-base/gxclrast.c<br>
-base/gximage.c<br>
-base/gximage3.c<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-17 19:31:50 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=51a0be1a6ac3bae2dc1b8bcdd91f58f76b9132c9">51a0be1a6ac3bae2dc1b8bcdd91f58f76b9132c9</a>
-<blockquote>
-<p>
- Sync deep colour blending with recent changes to 8 bit blending.<br>
-<br>
- Release testing reveals problems with deep color blending and<br>
- overprint. This is because changes were made to the 8bit<br>
- branches of gxblend.c that weren't fully reflected in the<br>
- 16bit branches.<br>
-<br>
- Reapply those changes here.<br>
-<br>
- While we're at it, address some other minor code cleanups,<br>
- including keeping the ordering of parameters the same between 8<br>
- and 16 bit to avoid confusion in future.<br>
-<br>
- The command that showed the inital problem was:<br>
-<br>
- bin/gswin32c.exe -o out.psd -sDEVICE=psdcmyk16 tests_private/comparefiles/Bug695916.pdf<br>
-<br>
- where the image of the Earth did not appear.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-17 13:27:10 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b7faa941d09db8856378e45d4f5c81b5f93e5f90">b7faa941d09db8856378e45d4f5c81b5f93e5f90</a>
-<blockquote>
-<p>
- Bug 702130: Fix JPEG memory failure problems.<br>
-<br>
- The SEGV reported by Memento squeezing (which oddly is at 113600<br>
- for me, rather than Julian's higher number) is caused by jpeglib<br>
- calling 'mem_term' on something that failed to 'mem_init'.<br>
-<br>
- The fix is to use gs_memory_chunk_unwrap rather than target/release,<br>
- and to check whether mem == cmem to see whether that actually did<br>
- unwrap.<br>
-<br>
- This runs us into a further problem, where we are freeing the<br>
- custom memory descriptor using a gc memory pointer, where it was<br>
- allocated using a non gc one.<br>
-<br>
- Rather than just changing the free to use the non gc one, we take<br>
- the opportunity to ensure that ALL the blocks are in non gc memory.<br>
- JPEGlib will take poorly to its memory being gc'd away, and none<br>
- of it needs to subject to gc.<br>
-<br>
- Credit goes largely to Chris for this fix.<br>
-<br>
-base/sjpegc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-14 18:44:53 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=619c0231952c20cc14f0eaf603e0cb01aa937eff">619c0231952c20cc14f0eaf603e0cb01aa937eff</a>
-<blockquote>
-<p>
- Bug 702124 (continued): Avoid FP errors leading to empty pattern cells.<br>
-<br>
- The limited accuracy of floats can cause pattern cells to appear to<br>
- be empty when they are not.<br>
-<br>
- Avoid adding the (often large) tx and ty components in until after we<br>
- have calculated the width/heights.<br>
-<br>
-base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-14 18:43:00 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8edb1b1e7bb84ff4598819fe078eb0ed2c4948d5">8edb1b1e7bb84ff4598819fe078eb0ed2c4948d5</a>
-<blockquote>
-<p>
- Bug 702124: Avoid VMerror when a pattern cell height is 0.<br>
-<br>
- We detect buffer_height == 0 and take it to mean that we can't<br>
- get a large enough buffer for even a single scanline. Actually<br>
- it can mean that the pattern cell was empty, which gives a<br>
- spurious error.<br>
-<br>
-base/gxmclip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-14 17:08:12 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6beaf42d25f3969b6dc3d8e1b1795017708000c5">6beaf42d25f3969b6dc3d8e1b1795017708000c5</a>
-<blockquote>
-<p>
- Fix segv after memento squeeze in psdf_DCT_filter().<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=117152 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-devices/vector/gdevpsdu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 14:54:42 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8d052b3de78b8034daed23e668758c76a8d8c478">8d052b3de78b8034daed23e668758c76a8d8c478</a>
-<blockquote>
-<p>
- Fixed double free after alloc failure in gs_lib_ctx_set_icc_directory*() (found by memento).<br>
-<br>
- After we've freed p_ctx-&gt;profiledir we need to set it to NULL otherwise if we<br>
- return an error it will be freed a second time when we close down.<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=101810 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 11:12:37 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dbde03ca37da96a94f4b7a6f0ba22a47a7bc2cb1">dbde03ca37da96a94f4b7a6f0ba22a47a7bc2cb1</a>
-<blockquote>
-<p>
- Fixed leak on error in gs_fapi_ufst_init() (found by memento).<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=22 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-base/fapiufst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 19:48: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=08695f8ccebb0d25eb2a5933ecee92281eefc1be">08695f8ccebb0d25eb2a5933ecee92281eefc1be</a>
-<blockquote>
-<p>
- Bug 702121: PCL performance degradation<br>
-<br>
- Henry chased the cause down to commit b399f84, an attempt to<br>
- fix Bug 700624. Looking at that code now, it has a silly typo<br>
- in it, that was causing it not be triggered in cases when it<br>
- should have been. Fixed here.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 11:11:40 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e2cdef26db058e84c2cf4dff5f638e669f961b52">e2cdef26db058e84c2cf4dff5f638e669f961b52</a>
-<blockquote>
-<p>
- Alternative fix for leaks after error in gs_main_init_with_args01()<br>
-<br>
- When memory squeezing gpdl, Julian found leaks in the gpdl<br>
- startup of the postscript interpreter when allocations failed<br>
- in gs_main_init_with_args01().<br>
-<br>
- Here, we fix the problem by making the psitop.c layer within gpdl<br>
- call the appropriate shutdown code when we catch the error. This<br>
- moves gpdl to being consistent with other users of the gs_main<br>
- layer.<br>
-<br>
- Memento memory squeezing around the point of failure (event 2035)<br>
- now shows this to be OK.<br>
-<br>
- MEMENTO_SQUEEZEAT=2034 ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-gpdl/psitop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 18:47:37 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bbecd13cc34f3dcdcedd726e7de12c988da9794a">bbecd13cc34f3dcdcedd726e7de12c988da9794a</a>
-<blockquote>
-<p>
- Revert &quot;Fix leaks after error in gs_main_init_with_args01() (found by memento).&quot;<br>
-<br>
- This reverts commit f35924926cb35f08be5a12ded4a00eb2f42aed3e.<br>
-<br>
- When memory squeezing gpdl, Julian found leaks in the gpdl<br>
- startup of the postscript interpreter when allocations failed<br>
- in gs_main_init_with_args01().<br>
-<br>
- The initial fix attempted was to make gs_main_init_with_args01()<br>
- closedown the interpreter on such errors. This worked for the<br>
- tested cases, but hid problems with non-memory related errors<br>
- (such as not being able to open a file specified on the command<br>
- line) when called by gs (rather than gpdl).<br>
-<br>
- The change attempted resulted in gs_main_finit() being called<br>
- twice as gs (and other users of the gs_main APIs) expect to have<br>
- to call gs_main_finit() to shut down after gs_main_init_with_args01()<br>
- returns an error code.<br>
-<br>
- The real problem is that gpdl is not doing this in the same way as<br>
- other callers.<br>
-<br>
- The gs_main layer has existed for donkeys years, so it's probably<br>
- best that we just take it as fixed and don't require callers to<br>
- start changing stuff now.<br>
-<br>
- Accordingly, I am reverting the attempted fix here, and will<br>
- try a different fix for it that only affects gpdl shortly.<br>
-<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-11 16:48:24 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=68be233f36feb045e442a18c4f4e4d2ced52b197">68be233f36feb045e442a18c4f4e4d2ced52b197</a>
-<blockquote>
-<p>
- Change to improve memory and speed (Bug 702099)<br>
-<br>
- As described in the bug, the patch to disable high-level images in<br>
- pattern-clists when Interpolate is true is no longer needed (hasn't<br>
- been since 2015), and it causes the memory and performance problems<br>
- with this type of file.<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 15:10:54 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2dea734a6184668511758fe1929a1d3166df85b6">2dea734a6184668511758fe1929a1d3166df85b6</a>
-<blockquote>
-<p>
- Bug 702114 non-isolated group in knockout group<br>
-<br>
- Make sure to use the parents backdrop as our backdrop when we<br>
- push a non-isolated group that resides in a knockout group.<br>
- Note though that this apparently is not the case if we are<br>
- constructing a soft mask.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 10:54:47 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9af467b71198710bc42509e00b730a716b8e4828">9af467b71198710bc42509e00b730a716b8e4828</a>
-<blockquote>
-<p>
- Bug 702113 Softmask with transfer function<br>
-<br>
- In a couple spots we look at the value of the background value<br>
- of the softmask to decide if we really need the softmask in<br>
- areas outside the group bounding box. These checks were not<br>
- considering the impact of the transfer function.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 11:37: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=b6d36e3205a8b065014b3965cb3c8269408309ca">b6d36e3205a8b065014b3965cb3c8269408309ca</a>
-<blockquote>
-<p>
- Dates etc for 9.51 RC1<br>
-<br>
- Plus prelim changelog<br>
-<br>
-Makefile.in<br>
-base/gscdefs.h<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/Internal.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>
-psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-
-
-
-<h2><a name="Version9.52"></a>Version 9.52 (2020-03-19)</h2>
-<p> Highlights in this release include:
-<ul>
-<li>
-<p>The 9.52 release replaces the 9.51 release, after a problem was reported with 9.51
-which warranted the quick turnaround. Thus, like 9.51, 9.52 is primarily a maintenance
-release, consolidating the changes we introduced in 9.50.
-</li>
-<li>
-<p>We have continued our work on code hygiene for this release, with a focus on the
-static analysis tool Coverity (from <a href="https://www.synopsys.com">Synopsys, Inc</a>)
-and we have now adopted a policy of maintaining zero Coverity issues in the
-Ghostscript/GhostPDL source base.
-</li>
-<li>
-<p><b>IMPORTANT:</b> In consultation with a representative of
-(<a href="http://www.openprinting.org">OpenPrinting</a>) it is
-our intention to deprecate and, in the not distant future, remove the
-OpenPrinting Vector/Raster Printer Drivers (that is, the <code>opvp</code>
-and <code>oprp</code> devices).
-<p> If you rely on either of these devices, <b><i>please</i></b> get in touch with
-us, so we can discuss your use case, and revise our plans accordingly.
-</li>
-<li>
-<p>IMPORTANT: We have forked LittleCMS2 into LittleCMS2mt (the "mt" indicating "multi-thread").
-LCMS2 is not thread safe, and cannot be made thread safe without breaking the ABI. Our fork
-will be thread safe, and include performance enhancements (these changes have all be been
-offered and rejected upstream). We will maintain compatibility between Ghostscript and LCMS2
-for a time, but not in perpetuity. If there is sufficient interest, our fork will be
-available as its own package separately from Ghostscript (and MuPDF).
-</li>
-<li>
-<p>The usual round of bug fixes, compatibility changes, and incremental improvements.
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-<h3><a name="9.52_Incompatible_changes"></a>Incompatible changes</h3>
-<h4>Included below are incompatible changes from recent releases (the
-specific release in question listed in parentheses). We include these,
-for now, as we are aware that not everyone upgrades with every release.</h4>
-<ul>
-<li>
-<p>(9.52) As of 9.52, the Windows binaries released by the Ghostscript development
-team are built with Microsoft Visual Studio 2019. As a result Microsoft Windows XP and
-earlier are no longer supported by these binaries. This does not imply we are, or will
-start relying upon features only available in VS2019, so the <code>nmake</code> Makefiles
-will continue to allow older Visual Studio versions (back to VS2005) to build Ghostscript.
-</li>
-<li>
-<p>(9.52) <code>-dALLOWPSTRANSPARENCY</code>: The transparency compositor (and related
-features), whilst we are improving it, remains sensitive to being driven correctly, and
-incorrect use can have unexpected/undefined results. Hence, as part of improving security
-we limited access to these operators, originally using the <code>-dSAFER</code> feature.
-As we made "SAFER" the default mode, that became unacceptable, hence the new option
-<code>-dALLOWPSTRANSPARENCY</code> which enables access to the operators.
-</li>
-<li>
-<p>(9.50) There are a couple of subtle incompatibilities between the old and new SAFER
-implementations. Firstly, as mentioned in the 9.50 release notes, SAFER now leaves
-standard Postcript functionality unchanged (except for the file access limitations).
-Secondly, the interaction with <code>save</code>&sol;<code>restore</code> operations,
-see <a href="Use.htm#Safer">SAFER</a>.
-<p><strong>Important Note for Windows Users</strong>:
-<br>
-The file/path pattern matching is case sensitive, even on Windows. This is a
-change in behaviour compared to the old code which, on Windows, was case
-<i>in</i>sensitive. This is in recognition of changes in Windows behaviour,
-in that it now supports (although does not enforce) case sensitivity.
-</li>
-<li>
-<p>(9.27) The process of &quot;tidying&quot; the Postscript name space should have removed
-only non-standard and undocumented operators. Nevertheless, it is possible that
-any integrations or utilities that rely on those non-standard and undocumented
-operators may stop working, or may change behaviour.
-<p>If you encounter such a case, please contact us (either the #ghostscript IRC channel,
-or the gs-devel mailing list would be best), and we'll work with you to either find an
-alternative solution or return the previous functionality, if there is genuinely no other
-option.
-<p>One case we know this has occurred is GSView 5 (and earlier). GSView 5 support for PDF
-files relied upon internal use only features which are no longer available. GSView 5 will
-still work as previously for Postscript files. For PDF files, users are encouraged to look
-at <a href="https://www.mupdf.com">MuPDF</a>.
-</li>
-</ul>
-<h3><a name="9.52_changelog"></a>Changelog</h3>
-
-<p><strong>2020-03-14 15:07: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=eec073529fb8dc0c3bb6d612b61bf483d135c9cf">eec073529fb8dc0c3bb6d612b61bf483d135c9cf</a>
-<blockquote>
-<p>
- Bug 702217: Reinstate dynamic libs LDFLAGS for MacOS<br>
-<br>
- With the significant revamp of the platform detection functions in configure<br>
- the LDFLAGS for building the gs shared library on MacOS went astray. This<br>
- puts them back in.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-16 09:06:16 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a9cd9959372b9f14b493b87df57664ea831c5d80">a9cd9959372b9f14b493b87df57664ea831c5d80</a>
-<blockquote>
-<p>
- Repair device subclassing after fill+stroke commit<br>
-<br>
- Bug 702221 &quot;Ghostscript 9.51 - SIGFPE when -dFirstPage or -dLastPage is set&quot;<br>
-<br>
- The fill+stroke commit had an error with the default method for handling<br>
- fill_stroke_path which passed the subclassing device as a parameter to<br>
- the child, instead of passing the child device. This caused seg faults,<br>
- floating point exceptions, hangs, and possibly other problems.<br>
-<br>
- In addition the object filtering device had been modified to pass the<br>
- fill+stroke method to the default handler, instead of checking to see<br>
- if vector operations should be dropped.<br>
-<br>
- This commit fixes both problems.<br>
-<br>
-base/gdevoflt.c<br>
-base/gdevsclass.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-14 10:56: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=f712440a2f251ae06277ec4a5ffe8ce7599aa4d8">f712440a2f251ae06277ec4a5ffe8ce7599aa4d8</a>
-<blockquote>
-<p>
- Add ARCH_MAX_SIZE_T to configure's arch.h prototype<br>
-<br>
-arch/arch_autoconf.h.in<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-14 10:53:15 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=214d16924543fb3116a031463052e8b0eff3f1ae">214d16924543fb3116a031463052e8b0eff3f1ae</a>
-<blockquote>
-<p>
- Don't fail on missing freetype for auxtools run<br>
-<br>
- When cross compiling, we shouldn't fail the recursive call to configure if<br>
- there's no freetype - since it's not required for auxtools.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-02 17:10:43 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=15f5f8bad503e9d3e63db9c3ca395deffd6b1e20">15f5f8bad503e9d3e63db9c3ca395deffd6b1e20</a>
-<blockquote>
-<p>
- Fix 16bit blending problem.<br>
-<br>
- Seen with:<br>
-<br>
- gs -sDEVICE=psdcmyk16 -o out%d.psd -r72 -dMaxBitmap=2000M<br>
- tests_private/pdf/forms/v1.5/proxy_vol_1_number_1_1.pdf<br>
-<br>
- on page 3.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-02 11:04:32 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6e3e9238bb5cf7fe44c3c845be286a3314ed905">f6e3e9238bb5cf7fe44c3c845be286a3314ed905</a>
-<blockquote>
-<p>
- Fix 64bit non-console windows build.<br>
-<br>
- The creation of the text window was truncating the pointer to<br>
- long (32bit) size. No idea how we've been getting away with this<br>
- in the past. I can only assume this has been exposed by<br>
- differences in the runtime lib with vs2019 as compared to<br>
- earlier versions.<br>
-<br>
-psi/dwtext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-03-02 09:02: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=ffe0e5cf33feee7672e5f4281f0c0b0ff66bddda">ffe0e5cf33feee7672e5f4281f0c0b0ff66bddda</a>
-<blockquote>
-<p>
- Add mention of deprecating/removing opvp/oprp devices<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 15:22:04 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dbaddcf6e251229a1506f2df33844365df39de44">dbaddcf6e251229a1506f2df33844365df39de44</a>
-<blockquote>
-<p>
- Fix signed issue in 16bit alpha blending fill_rectangle routines.<br>
-<br>
- As seen by the central spot in the pink region of page 1 of:<br>
-<br>
- gs -sDEVICE=psdcmyk16 -o out%d.psd -dMaxBitmap=2000M<br>
- tests_private/pdf/pdf_1.7_ATS_EXXPA1DC_PDFACT.pdf<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 15:09:35 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ad8020c3cb63345dd76119e8978c3353940a68e">4ad8020c3cb63345dd76119e8978c3353940a68e</a>
-<blockquote>
-<p>
- pdfwrite - Fix indeterminism with QL shading tests<br>
-<br>
- When creating a new colour space to put in a PDF file we perform various<br>
- tests to see if its a space we have already written, to prevent writing<br>
- duplicate spaces (we perform similar tests for most resources).<br>
-<br>
- In some cases, when we write the resource to a file, we create an MD5<br>
- hash and compare those to see if the resources are the same. In the<br>
- case of colour spaces, however, they are retained in memory and so we<br>
- use a different method. We 'serialise' the colour space. This is not the<br>
- same as writing it to the PDF file, and its a graphics library thing not<br>
- a pdfwrite function. Basically this writes out the content of the<br>
- various C structures. The stream we use is an in-memory stream.<br>
-<br>
- Unfortunately, for Separation colour spaces, there was a fault in the<br>
- function which writes the colour space name, and it was writing out<br>
- the bytes forming the address of the name instead of the actual string.<br>
-<br>
- This could, very rarely, mean that we would mis-identify a new colour<br>
- space as being the same as an old colour space, and so would reuse the<br>
- old space instead of creating a new one.<br>
-<br>
- I've checked the DeviceN code and it does not suffer the same problem.<br>
-<br>
-base/gscsepr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 13:03:56 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3cb8b3a403450d617b2b96ec0349bb99ce0d8379">3cb8b3a403450d617b2b96ec0349bb99ce0d8379</a>
-<blockquote>
-<p>
- Fix the overflow case in 16 bit saturation blending.<br>
-<br>
- As seen with the second apple of the bottom row of page 1<br>
- of:<br>
-<br>
- gs -sDEVICE=psdcmyk16 -r72 -o out%d.psd -dMaxBitmap=2000M<br>
- ../tests_private/pdf/PDF_1.7_ATS/AIX4G1C3.pdf<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 17:10:51 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5d4305e916d3f75492d03dfd79ab1aaedf9545e3">5d4305e916d3f75492d03dfd79ab1aaedf9545e3</a>
-<blockquote>
-<p>
- Fix for bug 702150: make pl_main_run_file_utf8() check for error from s_process_read_buf().<br>
-<br>
- Avoids infinite loop in:<br>
- ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null .<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 18:24:55 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c6efee0f594ad29394bf8a303f21d85dcb1d70a">2c6efee0f594ad29394bf8a303f21d85dcb1d70a</a>
-<blockquote>
-<p>
- minor improvements to toolbin/squeeze2text.py.<br>
-<br>
-toolbin/squeeze2text.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 08:25:13 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef5dfe7e3b3858bdfb20c168b4818c4d65fb932f">ef5dfe7e3b3858bdfb20c168b4818c4d65fb932f</a>
-<blockquote>
-<p>
- CID 354310: Remove pointless unsigned comparison with 0.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-26 08:11: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=29335f43967a0f089d6f2f37883a22f1516f7bde">29335f43967a0f089d6f2f37883a22f1516f7bde</a>
-<blockquote>
-<p>
- CID 354291: Add error handling for inability to allocate<br>
-<br>
- Coverity complained about setting dash.pattern = NULL and &quot;Passing &quot;&amp;dash&quot;<br>
- to &quot;gstate_copy_dash&quot;, which dereferences null &quot;dash.pattern&quot; which is either<br>
- wrong, or *very* misleading. We assume that it means that gx_set_dash() *may*<br>
- access that pointer.<br>
-<br>
- In truth, this can never happen in these circumstances.<br>
-<br>
- Nevertheless, in gx_set_dash() is we have a NULL mem (allocator) pointer and the<br>
- dash pattern pointer is NULL at the point we have to copy into it, then throw<br>
- an error.<br>
-<br>
-base/gsline.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 19:59:03 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d0889b9fcf3a5d5012fad021b4c53828879016e">1d0889b9fcf3a5d5012fad021b4c53828879016e</a>
-<blockquote>
-<p>
- Fix bug 702139 - clist clipping bug.<br>
-<br>
- When characters are filled as paths, the fill_adjust may be set to 0.<br>
- Clip paths are supposed to match fill paths, i.e. the 'any part of pixel'<br>
- rule, so we need fill_adjust of 0.5 (not 0). The most foolproof way to fix<br>
- this is to set it in the reader when processing 'begin_clip' and restore<br>
- it when handling the end_clip.<br>
-<br>
- There are many progressions with this change, but it also exposes some<br>
- cases where the change in clipping allows other elements to be seen that<br>
- were previously hidden. Those few instances are minor and mostly seem to<br>
- occur when page mode differs from clist mode. Examination of some of those<br>
- cases shows that the clip path with clist mode now matches page mode and<br>
- other elements (e.g. images) differ in extent between page and clist mode.<br>
-<br>
-base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 19:39:50 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=86f81e9b799b66207c699768616a6e3ba3c311c3">86f81e9b799b66207c699768616a6e3ba3c311c3</a>
-<blockquote>
-<p>
- Fix gx_default_copy_alpha_hl_color for 16 bit operation.<br>
-<br>
- The code to write the composite data back to buffers to be sent<br>
- to copy_alpha was getting the first byte of each 16 bit pair<br>
- wrong in the 16bit data case.<br>
-<br>
- Also, when we 'restart' after skipping a zero byte in the 16bit<br>
- case we need to skip 2 bytes per pixel, not one.<br>
-<br>
- This can be seen when running:<br>
-<br>
- gs -r72 -o out%d.psd -sDEVICE=psdcmyk16 -dMaxBitmap=2000M<br>
- ../tests_private/comparefiles/js.pdf<br>
-<br>
-base/gdevdbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 18:19:07 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=635303ca7d8a36b3dabc9afbd9132f4b9a36dce5">635303ca7d8a36b3dabc9afbd9132f4b9a36dce5</a>
-<blockquote>
-<p>
- Fix psdcmyk16 blending issue.<br>
-<br>
- Use uint32_t rather than int to avoid signedness issues.<br>
-<br>
- Seen in the psdcmyk16 page mode rendering of<br>
-<br>
- tests_private/comparefiles/Bug692766.pdf<br>
-<br>
- (bad colors in 4th rgb circle intersection test).<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 15:57:36 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a00c75369e082798d82202a2b64d8e4b484d0c11">a00c75369e082798d82202a2b64d8e4b484d0c11</a>
-<blockquote>
-<p>
- Fix coverity issues 354292 and 354293.<br>
-<br>
- Don't bother testing an unsigned value for clipping against 0.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-25 08:58:32 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=32f3d6703a7e5c6582c066837783c6697e98b1ca">32f3d6703a7e5c6582c066837783c6697e98b1ca</a>
-<blockquote>
-<p>
- Replace 0 with NULL for pointer validation/setting.<br>
-<br>
- Also make validation an explicit comparison with NULL i.e.:<br>
- &quot;if (mem != NULL)&quot; rather than &quot;if (mem)&quot;.<br>
-<br>
-base/gsline.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 17:30:54 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c1002cc251907e702fd5db9dc81365a964816c6">6c1002cc251907e702fd5db9dc81365a964816c6</a>
-<blockquote>
-<p>
- Add support for multiple squeezes in one run.<br>
-<br>
- E.g. MEMENTO_SQUEEZES=115867-1..+3,119928-1..+3 ...<br>
-<br>
- This is equivalent running multiple times with MEMENTO_FAILAT set to 115866,<br>
- 115867, 11588, 119927, 119928, 119929.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 10:38:53 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39557bd53eee75a8b8f762457ce57a5437e79d6c">39557bd53eee75a8b8f762457ce57a5437e79d6c</a>
-<blockquote>
-<p>
- Fix for MEMENTO_FAILAT=119928: only call gs_grestoreall_for_restore() if vmsave-&gt;gsave not NULL.<br>
-<br>
- Also fix error cleanup in gs_gsave_for_save(), otherwise this fix breaks<br>
- previous fix for MEMENTO_FAILAT=115802.<br>
-<br>
- [Thanks to chrisl for this and various other recent fixes.]<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=119928 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-base/gsstate.c<br>
-psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 11:21:53 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=60507d492507817bb5ae14a17a01d19c50d41e0a">60507d492507817bb5ae14a17a01d19c50d41e0a</a>
-<blockquote>
-<p>
- toolbin/squeeze2text.py: improve log output.<br>
-<br>
- With -p, if there is gap in 'Memory squeezing @ &lt;N&gt;' output (because of calls<br>
- to free()), output next &lt;N&gt;.<br>
-<br>
- Also flush log output to avoid looking like we've hung.<br>
-<br>
-toolbin/squeeze2text.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 21:00:21 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3a9ea36465e97ce729c5ab26dc8e0d1435b7b246">3a9ea36465e97ce729c5ab26dc8e0d1435b7b246</a>
-<blockquote>
-<p>
- Fix issue with fts_14_1416.pdf and psdcmyk16<br>
-<br>
- This was missed in the fix. Affected only 16 bit devices.<br>
-<br>
- http://git.ghostscript.com/?p=ghostpdl.git;a=commit;h=b1ac0686eea6adcf2db8cabf7858796494b4459d<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 20:05:49 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f3320f9b6214907d24a4a9f77638b199aa95f8e">8f3320f9b6214907d24a4a9f77638b199aa95f8e</a>
-<blockquote>
-<p>
- Fix Ink names leaking.<br>
-<br>
- The cause of the leak was a typo in gx_final_DeviceN.<br>
-<br>
- Once this is fixed, we hit a problem where ink names are set<br>
- to be a pointer to a static empty string, which can't be<br>
- freed. Change to using NULL to mean empty ink name.<br>
-<br>
-base/gscdevn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 12:01:43 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b28d57e7422d2d4df8c805342ad01dfc6c6e1232">b28d57e7422d2d4df8c805342ad01dfc6c6e1232</a>
-<blockquote>
-<p>
- Memento/Valgrind tweak.<br>
-<br>
- Ensure we mark the contents of a block readable before we<br>
- look for pointers in it, and don't overrun the end.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 12:57:28 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0822ac2a5f1f02315a783504fccf615a55cf494f">0822ac2a5f1f02315a783504fccf615a55cf494f</a>
-<blockquote>
-<p>
- Squash some unused variable warnings.<br>
-<br>
-base/claptrap-planar.c<br>
-base/gp_unifs.c<br>
-base/gxclpath.c<br>
-gpdl/tifftop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 12:14: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=82a2d6356858c0a4ab9ff7fa294c0380d04aa9e3">82a2d6356858c0a4ab9ff7fa294c0380d04aa9e3</a>
-<blockquote>
-<p>
- pdf14_{fill_stroke_path,clist_fill_stroke_path_pattern_setup} cleanups.<br>
-<br>
- Use a nicer method of breaking const (to avoid warnings). Ensure<br>
- that we always put everything back as it was when we leave the<br>
- functions, even if we have an error.<br>
-<br>
- Remove needless cleanup code to handle functions that can never<br>
- return an error to us returning an error.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 12:35:30 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1ff23ccf08707af544de59d6c59971d0c17098c">b1ff23ccf08707af544de59d6c59971d0c17098c</a>
-<blockquote>
-<p>
- pdf14_clist_fill_stroke_path_pattern_setup overprint fix.<br>
-<br>
- Only enable CompatibleOverprint for the stroke part of stroke/fill<br>
- patterns if we are in a subtractive space.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 11:24:28 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=389324fd827e1172eb358b616a32af5fcb2633f6">389324fd827e1172eb358b616a32af5fcb2633f6</a>
-<blockquote>
-<p>
- Squash some warnings with gs_swapcolors_quick breaking const.<br>
-<br>
- At various places in the code, we call gs_swapcolors_quick where<br>
- we only have a const pgs.<br>
-<br>
- Properly, we should copy the pgs to a non-const pgs, and then use<br>
- that, but that would be a performance hit.<br>
-<br>
- In all cases, we change the graphics state, then restore it before<br>
- exit, so effectively it is const over the entire call of the<br>
- enclosing procedure.<br>
-<br>
- Rather than having lots of small hacky casts removing const, we<br>
- push the const breakage into gs_swapcolors_quick itself where we<br>
- do it in the &quot;approved&quot; way using a union.<br>
-<br>
-base/gdevp14.c<br>
-base/gsstate.c<br>
-base/gxfill.c<br>
-base/gxgstate.h<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 10:10:25 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=449433ff6689c603a56186dbde5721f6139aa939">449433ff6689c603a56186dbde5721f6139aa939</a>
-<blockquote>
-<p>
- Avoid floating point in gxblend.c<br>
-<br>
- Use fixed point in preference.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-24 08:23:59 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6badfb362efe0fb4f0c3df106a33ecd5b0265ef7">6badfb362efe0fb4f0c3df106a33ecd5b0265ef7</a>
-<blockquote>
-<p>
- Implement OPM tracking in pdfwrite<br>
-<br>
- More than somewhat to my surprise, the release testing of 9.51 revealed<br>
- that pdfwrite was not tracking the state of overprint mode (OPM). It<br>
- could be set by setdistillerparams, and in no other way.<br>
-<br>
- This commit adds tracking the OPM in the graphics state, removes the<br>
- old overprint_mode variable from the device, but preserves the ability<br>
- to alter the OPM using setdistillerparms.<br>
-<br>
- This also alters the initial state of OPM, the distiller params<br>
- reference states that the 'factory default' of OPM is 1, but the PDF<br>
- Reference says that the initial state of OPM is 0. We need to start<br>
- with the correct setting of OPM so we change it form 1 to 0<br>
- in gs_pdfwr.ps.<br>
-<br>
- In passing, cast a const gs_gstate * to a gs_gstate * when used by<br>
- gs_swapcolours_quick, in order to avoid a compiler warning.<br>
-<br>
- This causes a small number of progressions in files using OPM (which is<br>
- rare, its even rarer to actually alter it during the course of the file)<br>
-<br>
-Resource/Init/gs_pdfwr.ps<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfd.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 16:24:12 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3dc65600d6d4eb060398f06f148cfe4f07a82439">3dc65600d6d4eb060398f06f148cfe4f07a82439</a>
-<blockquote>
-<p>
- Bug 702117 Knockout groups containing non-isolated groups<br>
-<br>
- So this ended up being rather complicated. The first issue was that<br>
- we were not setting the backdrop properly for non-isolated groups that<br>
- reside in knockout groups. When that was fixed, it was revealed that we<br>
- were not doing the recompositing operation for non-isolated knockout groups. This meant<br>
- that the backdrop was getting applied twice effectively (once in the original<br>
- fill and then again when the group was popped). The only file that showed<br>
- this issue was the crazy Altona page with the many overlapping groups. Customer<br>
- file added to provide a clearer case in the regression tests.<br>
-<br>
-base/gdevp14.c<br>
-base/gxblend.c<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 17:09:41 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=416baca7c4bcf0b1794b7b1647250bf09adaee9d">416baca7c4bcf0b1794b7b1647250bf09adaee9d</a>
-<blockquote>
-<p>
- Fix MEMENTO_FAILAT=115867 - segv in i_unregister_root() after failure in i_register_root().<br>
-<br>
- In pl_main_delete_instance(), don't call gs_unregister_root() if<br>
- minst-&gt;device_root is NULL.<br>
-<br>
- Also in pl_top_create_device(), check return from<br>
- gs_register_struct_root(). But this doesn't appear to make any difference to<br>
- the handling of the memento error.<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=115867 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 16:51:56 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4eb54af16c69ef36371291bd43f853865adea1eb">4eb54af16c69ef36371291bd43f853865adea1eb</a>
-<blockquote>
-<p>
- Fix deep color group compose issue.<br>
-<br>
- In commit bb7d57e84e9fe I reordered parameters to keep 8/16<br>
- branches consistent, and missed one case.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 15:27:07 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a2276988137021618bb3ca440aba50e126160bcd">a2276988137021618bb3ca440aba50e126160bcd</a>
-<blockquote>
-<p>
- Remove needless &quot;isolated&quot; parameter from pdf14_mark_rect routines.<br>
-<br>
- The value was carefully plumbed through (only in the 8bit case) in<br>
- a recent commit, but was never actually used. Remove it a) because<br>
- it's pointless passing a variable we don't use, and b) because it's<br>
- another difference between 8 and 16 bit versions.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 15:21:30 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9ddcae93fe1629e81d36b17b7fec9de787b411cc">9ddcae93fe1629e81d36b17b7fec9de787b411cc</a>
-<blockquote>
-<p>
- Fix typing mistake in 16bit transparency.<br>
-<br>
- When promoting from 8 to 16 bit, shape and src_alpha become<br>
- uint16_ts rather than bytes.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 15:06:38 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7de8fe5a49df0f9154fa707a934e39c012c3cc2a">7de8fe5a49df0f9154fa707a934e39c012c3cc2a</a>
-<blockquote>
-<p>
- Fix more overprint problems with deep color transparency.<br>
-<br>
- Again, overprint changes to the 8 bit paths had not been<br>
- pulled across to the 16 bit path.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-19 07:10:40 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2d3f8c01231d52a5595e2727b31b8044188a5af8">2d3f8c01231d52a5595e2727b31b8044188a5af8</a>
-<blockquote>
-<p>
- Added toolbin/squeeze2text.py, for processing output from MEMENTO_SQUEEZEAT=...<br>
-<br>
- An alternative to squeeze2html.pl, outputing just summary information.<br>
-<br>
-toolbin/squeeze2text.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-20 11:18:11 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=777d79315e0094bef83d241bc0d5683ea6775a55">777d79315e0094bef83d241bc0d5683ea6775a55</a>
-<blockquote>
-<p>
- Fix for MEMENTO_FAILAT=115802: make gs_gsave_for_save() call gs_gsave() so it can restore after error.<br>
-<br>
- Previously, zsave() called gs_gsave_for_save() then gs_gsave(), but if<br>
- gs_gsave() failed we ended up with SEGV in finalise code.<br>
-<br>
- To allow zsave() to restore things after gs_gsave() failure, we would need to<br>
- add an include of base/gxgstate.h.<br>
-<br>
- Instead we remove the call of gs_gsave() from zsave() and append it to<br>
- gs_gsave_for_save(), where things can be easily restored if it fails.<br>
-<br>
- [There are no other callers of gs_gsave_for_save().]<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=115802 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-base/gsstate.c<br>
-psi/zvmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-18 09:44:51 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6db4560f1e31bb92321894e0d008d310aa600097">6db4560f1e31bb92321894e0d008d310aa600097</a>
-<blockquote>
-<p>
- Avoid leaks if we get alloc failure when closing down (found by memento).<br>
-<br>
- In gs_main_finit(), ignore gs_error_VMerror from interp_reclaim(). Such error<br>
- ultimately comes from gs_vmreclaim() calling context_state_load(), but the<br>
- missing info doesn't seem to be required for gs_main_finit() to carry on.<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=147801 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 17:40:51 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb726fb4d2597cfcd4986dd9c105cf1ab71d09e3">eb726fb4d2597cfcd4986dd9c105cf1ab71d09e3</a>
-<blockquote>
-<p>
- Fix image_color_icc_prep to properly align planar buffers.<br>
-<br>
-base/gxicolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 10:50:10 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e01371e00caa8f5d08ef150a6f594c93ca495be2">e01371e00caa8f5d08ef150a6f594c93ca495be2</a>
-<blockquote>
-<p>
- Enable CAL for gxicolor halftoning.<br>
-<br>
- Looks like the calling code was unfinished, and the build<br>
- changes were not done.<br>
-<br>
- Also, squash some warnings.<br>
-<br>
-base/gxicolor.c<br>
-base/gximono.c<br>
-base/lib.mak<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-17 15:57:47 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c4e7cddc4d053f2850e697696e2498180547961a">c4e7cddc4d053f2850e697696e2498180547961a</a>
-<blockquote>
-<p>
- Ensure the memory entry in a cloned gstate is correct.<br>
-<br>
- In theory, we could end up cloning a graphics state with one allocator, then<br>
- assigning the &quot;memory&quot; entry in the cloned state to that of the state we are<br>
- cloning.<br>
-<br>
- In practice the two have (so far) been the same, but that is not guaranteed.<br>
-<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-14 11:08:57 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=239e70cd02491bab1cce9092c07c959427358646">239e70cd02491bab1cce9092c07c959427358646</a>
-<blockquote>
-<p>
- Fix segfault cleaning up after gstate clone failure.<br>
-<br>
- For me this happens with MEMENTO_FAILAT=112447 and for Julian it happens with<br>
- MEMENTO_FAILAT=115905.<br>
-<br>
- Basically, the order of events was that we'd allocate a new gstate, copy the<br>
- contents of the existing gstate to the new one, then copy the dash pattern<br>
- (which could fail) and copy the &quot;client_data&quot; (which could and, in this case,<br>
- did fail). When either of those failed, we'd jump to the error handling and<br>
- exit with the error.<br>
-<br>
- The problem is that, by jumping to the &quot;fail&quot; label, we skip over all the code<br>
- that fixes up the reference counts (and various other things) to account for<br>
- the newly created gstate.<br>
-<br>
- This commit reorders things so we allocate the gstate, copy the client data,<br>
- copy the dash pattern, *then* assign the contents of the old gstate to the new<br>
- one, and carry on. Thus, by the time the gstate contents are copied, the<br>
- function cannot fail, and everything is sure to be correctly setup.<br>
-<br>
- In the event that either the dash pattern or the client data fail to allocate,<br>
- the new gstate is still filled with NULLs, except for the subset of<br>
- &quot;gs_gstate_parts&quot; which are allocated and setup correctly so we can safely<br>
- free the graphics state object before returning the error.<br>
-<br>
- Also, use NULL for pointer validation instead of 0.<br>
-<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-18 17:43:18 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db5b51109ddee39b17b2ff2c2ac12f41a70785ef">db5b51109ddee39b17b2ff2c2ac12f41a70785ef</a>
-<blockquote>
-<p>
- Make sure pattern fills use proper alpha settings<br>
-<br>
- Fix for regression of fts_28_2804.pdf pdfwrite output rendering<br>
- with fill-stroke commit. This also fixes the rendering of fts_25_2526.pdf<br>
- Bug 702033. Required a minor change in the XPS interpreter to make<br>
- sure that patterns did not have their opacity double applied.<br>
-<br>
-base/gdevp14.c<br>
-xps/xpstile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-19 17:20:09 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cddd44e1bfcdaba1c289c3d83645613d136e5e3e">cddd44e1bfcdaba1c289c3d83645613d136e5e3e</a>
-<blockquote>
-<p>
- Bug 702105: Premature EOF Infinite loop in interpolated imagemask stream.<br>
-<br>
- Fix supplied by Peter Cherepanov. Many thanks.<br>
-<br>
-base/simscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-19 16:58:06 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59089ab66b3faaa683bb3aeb0bf856b7aa284f9b">59089ab66b3faaa683bb3aeb0bf856b7aa284f9b</a>
-<blockquote>
-<p>
- Fix &quot;blue gradients&quot; seen with psdrgb device.<br>
-<br>
- Since the fill/stroke commit went in, some files have been showing<br>
- gradients in the wrong colours. For instance this one, spotted in<br>
- release testing:<br>
-<br>
- gs -sDEVICE=psdrgb -r72 -dMaxBitmap=2000M -o out%d.psd<br>
- ../tests_private/comparefiles/Layout.pdf<br>
-<br>
- Bisecting the fill/stroke branch back, it seems the commit that<br>
- caused it is the one that stops psdrgb using 'devn' colors.<br>
-<br>
- This causes gradients to drop to using the color_info.comp_bits and<br>
- comp_shift information, which the psd devices don't fill in.<br>
-<br>
- The fix here is to make psd_prn_open call the standard function for<br>
- setting up these values.<br>
-<br>
-devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 14:48:05 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=25cd0c72b98f9efc6968254d1e3a2f33ec376369">25cd0c72b98f9efc6968254d1e3a2f33ec376369</a>
-<blockquote>
-<p>
- Bug701972 -- fix pdfwrite image downscaling bug<br>
-<br>
- Calculate the bits on the row using the input image width,<br>
- not the output image width.<br>
-<br>
- I had to add an extra argument to a few functions to propagate the info<br>
- down to where it is needed.<br>
-<br>
- Note obscure case involving calling psdf_setup_image_to_mask_filter()<br>
- for a Type 4 image and CompatibilityLevel &lt; 1.3. This change just<br>
- adds the extra input_width arg, which doesn't change whatever it was<br>
- doing before. If there is a bug lurking here, it seems unlikely<br>
- anybody cares?<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpsdf.h<br>
-devices/vector/gdevpsdi.c<br>
-devices/vector/gdevpsds.c<br>
-devices/vector/gdevpsds.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 09:22:55 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e9523603ac713e365702b81c228edcaaac667dc4">e9523603ac713e365702b81c228edcaaac667dc4</a>
-<blockquote>
-<p>
- Set the BitsPerComponent for alt stream in pdfwrite<br>
-<br>
- Add this to the image[1] code where it was missing<br>
-<br>
- This fixes bug where compressed images were correct, but if<br>
- -dEncodeGrayImages=false was used, then they were truncated.<br>
-<br>
- This is related to trimmed/rescaled image for Bug701972.<br>
- See the sample trim-nobug.pdf attached to that bug.<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-18 19:25:24 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=924f7ea07c7773a3b1510c6206c9a34227e4b39e">924f7ea07c7773a3b1510c6206c9a34227e4b39e</a>
-<blockquote>
-<p>
- Bug 702131: Fix overprint in additive spaces.<br>
-<br>
- We should only enter CompatibleOverprint blend mode if we<br>
- are in an subtractive space. This stops pdf14 trying to honour<br>
- drawn_comps even in additive spaces.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-14 14:02:24 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d98b553c829fad94cd4338910468d2b1b6ee64f7">d98b553c829fad94cd4338910468d2b1b6ee64f7</a>
-<blockquote>
-<p>
- Fix bug 702079: SEGV with clist and PCL caused by wrong color in images.<br>
-<br>
- The clist_image_plane_data function was called with the dev_color for a band<br>
- being type &lt;pattern&gt; when the image had type &lt;pure&gt;, but the code was not<br>
- calling cmd_put_drawing_color to update the bands for the image because uses_color<br>
- was false. Add rop3_uses_S(pgs0&gt;log_op) as well as (||) rop3_uses_T(pgs-&gt;log_op)<br>
- when CombineWitColor is true.<br>
- Note that extra calls to cmd_put_drawing_color before an image are low cost<br>
- and do nothing if the current device color is already the same.<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-18 09:48:07 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f55464d5c1640075a67a8b50557a48766783e08">4f55464d5c1640075a67a8b50557a48766783e08</a>
-<blockquote>
-<p>
- Bug 702128 : clist pdf14 overprint state<br>
-<br>
- This change ensures that gxdso_overprint_active<br>
- gets the proper state information.<br>
-<br>
- When the clist writer is active with the pdf14 device, the writer maintains<br>
- the current overprint state (as the writer has no access to the pdf14 member variables)<br>
- and must know what to put in the clist.<br>
-<br>
- When the clist writer is not present (i.e. page mode), the pdf14 device<br>
- maintains the information.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-18 11:46: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=f1887408860910c19c980f05fd0f8fc93b5f06a1">f1887408860910c19c980f05fd0f8fc93b5f06a1</a>
-<blockquote>
-<p>
- Bug 702068 continued: Fix smasked images with masks.<br>
-<br>
- Release testing has shown up another case that needs help.<br>
-<br>
- gs/bin -sDEVICE=ppmraw -o out.ppm -r300 -dMaxBitmap=1G<br>
- tests_private/pdf/sumatra/1901_-_tiling_inconsistencies.pdf<br>
-<br>
- This shows horizontal white lines in the &quot;Next&quot; &quot;Up&quot; &quot;Previous&quot;<br>
- images at the top of the page.<br>
-<br>
- Investigation shows this is due to the images having Masks as well<br>
- as SMasks.<br>
-<br>
- The Mask image is run to a 1 bit memory device, which means that<br>
- the gxdso to check if we are in an SMask doesn't work. We work<br>
- around this by introducing a new flag to gs_pixel_image_common<br>
- that we can set to indicate that we are within an smask. We set<br>
- this when we set the masked image up (using the gxdso), and check<br>
- it when we come to do the gridfitting.<br>
-<br>
-base/gsiparam.h<br>
-base/gxclrast.c<br>
-base/gximage.c<br>
-base/gximage3.c<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-17 19:31:50 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=51a0be1a6ac3bae2dc1b8bcdd91f58f76b9132c9">51a0be1a6ac3bae2dc1b8bcdd91f58f76b9132c9</a>
-<blockquote>
-<p>
- Sync deep colour blending with recent changes to 8 bit blending.<br>
-<br>
- Release testing reveals problems with deep color blending and<br>
- overprint. This is because changes were made to the 8bit<br>
- branches of gxblend.c that weren't fully reflected in the<br>
- 16bit branches.<br>
-<br>
- Reapply those changes here.<br>
-<br>
- While we're at it, address some other minor code cleanups,<br>
- including keeping the ordering of parameters the same between 8<br>
- and 16 bit to avoid confusion in future.<br>
-<br>
- The command that showed the inital problem was:<br>
-<br>
- bin/gswin32c.exe -o out.psd -sDEVICE=psdcmyk16 tests_private/comparefiles/Bug695916.pdf<br>
-<br>
- where the image of the Earth did not appear.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-17 13:27:10 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b7faa941d09db8856378e45d4f5c81b5f93e5f90">b7faa941d09db8856378e45d4f5c81b5f93e5f90</a>
-<blockquote>
-<p>
- Bug 702130: Fix JPEG memory failure problems.<br>
-<br>
- The SEGV reported by Memento squeezing (which oddly is at 113600<br>
- for me, rather than Julian's higher number) is caused by jpeglib<br>
- calling 'mem_term' on something that failed to 'mem_init'.<br>
-<br>
- The fix is to use gs_memory_chunk_unwrap rather than target/release,<br>
- and to check whether mem == cmem to see whether that actually did<br>
- unwrap.<br>
-<br>
- This runs us into a further problem, where we are freeing the<br>
- custom memory descriptor using a gc memory pointer, where it was<br>
- allocated using a non gc one.<br>
-<br>
- Rather than just changing the free to use the non gc one, we take<br>
- the opportunity to ensure that ALL the blocks are in non gc memory.<br>
- JPEGlib will take poorly to its memory being gc'd away, and none<br>
- of it needs to subject to gc.<br>
-<br>
- Credit goes largely to Chris for this fix.<br>
-<br>
-base/sjpegc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-14 18:44:53 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=619c0231952c20cc14f0eaf603e0cb01aa937eff">619c0231952c20cc14f0eaf603e0cb01aa937eff</a>
-<blockquote>
-<p>
- Bug 702124 (continued): Avoid FP errors leading to empty pattern cells.<br>
-<br>
- The limited accuracy of floats can cause pattern cells to appear to<br>
- be empty when they are not.<br>
-<br>
- Avoid adding the (often large) tx and ty components in until after we<br>
- have calculated the width/heights.<br>
-<br>
-base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-14 18:43:00 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8edb1b1e7bb84ff4598819fe078eb0ed2c4948d5">8edb1b1e7bb84ff4598819fe078eb0ed2c4948d5</a>
-<blockquote>
-<p>
- Bug 702124: Avoid VMerror when a pattern cell height is 0.<br>
-<br>
- We detect buffer_height == 0 and take it to mean that we can't<br>
- get a large enough buffer for even a single scanline. Actually<br>
- it can mean that the pattern cell was empty, which gives a<br>
- spurious error.<br>
-<br>
-base/gxmclip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-14 17:08:12 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6beaf42d25f3969b6dc3d8e1b1795017708000c5">6beaf42d25f3969b6dc3d8e1b1795017708000c5</a>
-<blockquote>
-<p>
- Fix segv after memento squeeze in psdf_DCT_filter().<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=117152 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-devices/vector/gdevpsdu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 14:54:42 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8d052b3de78b8034daed23e668758c76a8d8c478">8d052b3de78b8034daed23e668758c76a8d8c478</a>
-<blockquote>
-<p>
- Fixed double free after alloc failure in gs_lib_ctx_set_icc_directory*() (found by memento).<br>
-<br>
- After we've freed p_ctx-&gt;profiledir we need to set it to NULL otherwise if we<br>
- return an error it will be freed a second time when we close down.<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=101810 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 11:12:37 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dbde03ca37da96a94f4b7a6f0ba22a47a7bc2cb1">dbde03ca37da96a94f4b7a6f0ba22a47a7bc2cb1</a>
-<blockquote>
-<p>
- Fixed leak on error in gs_fapi_ufst_init() (found by memento).<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=22 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-base/fapiufst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 19:48: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=08695f8ccebb0d25eb2a5933ecee92281eefc1be">08695f8ccebb0d25eb2a5933ecee92281eefc1be</a>
-<blockquote>
-<p>
- Bug 702121: PCL performance degradation<br>
-<br>
- Henry chased the cause down to commit b399f84, an attempt to<br>
- fix Bug 700624. Looking at that code now, it has a silly typo<br>
- in it, that was causing it not be triggered in cases when it<br>
- should have been. Fixed here.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 11:11:40 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e2cdef26db058e84c2cf4dff5f638e669f961b52">e2cdef26db058e84c2cf4dff5f638e669f961b52</a>
-<blockquote>
-<p>
- Alternative fix for leaks after error in gs_main_init_with_args01()<br>
-<br>
- When memory squeezing gpdl, Julian found leaks in the gpdl<br>
- startup of the postscript interpreter when allocations failed<br>
- in gs_main_init_with_args01().<br>
-<br>
- Here, we fix the problem by making the psitop.c layer within gpdl<br>
- call the appropriate shutdown code when we catch the error. This<br>
- moves gpdl to being consistent with other users of the gs_main<br>
- layer.<br>
-<br>
- Memento memory squeezing around the point of failure (event 2035)<br>
- now shows this to be OK.<br>
-<br>
- MEMENTO_SQUEEZEAT=2034 ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-gpdl/psitop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-13 18:47:37 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bbecd13cc34f3dcdcedd726e7de12c988da9794a">bbecd13cc34f3dcdcedd726e7de12c988da9794a</a>
-<blockquote>
-<p>
- Revert &quot;Fix leaks after error in gs_main_init_with_args01() (found by memento).&quot;<br>
-<br>
- This reverts commit f35924926cb35f08be5a12ded4a00eb2f42aed3e.<br>
-<br>
- When memory squeezing gpdl, Julian found leaks in the gpdl<br>
- startup of the postscript interpreter when allocations failed<br>
- in gs_main_init_with_args01().<br>
-<br>
- The initial fix attempted was to make gs_main_init_with_args01()<br>
- closedown the interpreter on such errors. This worked for the<br>
- tested cases, but hid problems with non-memory related errors<br>
- (such as not being able to open a file specified on the command<br>
- line) when called by gs (rather than gpdl).<br>
-<br>
- The change attempted resulted in gs_main_finit() being called<br>
- twice as gs (and other users of the gs_main APIs) expect to have<br>
- to call gs_main_finit() to shut down after gs_main_init_with_args01()<br>
- returns an error code.<br>
-<br>
- The real problem is that gpdl is not doing this in the same way as<br>
- other callers.<br>
-<br>
- The gs_main layer has existed for donkeys years, so it's probably<br>
- best that we just take it as fixed and don't require callers to<br>
- start changing stuff now.<br>
-<br>
- Accordingly, I am reverting the attempted fix here, and will<br>
- try a different fix for it that only affects gpdl shortly.<br>
-<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-11 16:48:24 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=68be233f36feb045e442a18c4f4e4d2ced52b197">68be233f36feb045e442a18c4f4e4d2ced52b197</a>
-<blockquote>
-<p>
- Change to improve memory and speed (Bug 702099)<br>
-<br>
- As described in the bug, the patch to disable high-level images in<br>
- pattern-clists when Interpolate is true is no longer needed (hasn't<br>
- been since 2015), and it causes the memory and performance problems<br>
- with this type of file.<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 15:10:54 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2dea734a6184668511758fe1929a1d3166df85b6">2dea734a6184668511758fe1929a1d3166df85b6</a>
-<blockquote>
-<p>
- Bug 702114 non-isolated group in knockout group<br>
-<br>
- Make sure to use the parents backdrop as our backdrop when we<br>
- push a non-isolated group that resides in a knockout group.<br>
- Note though that this apparently is not the case if we are<br>
- constructing a soft mask.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 10:54:47 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9af467b71198710bc42509e00b730a716b8e4828">9af467b71198710bc42509e00b730a716b8e4828</a>
-<blockquote>
-<p>
- Bug 702113 Softmask with transfer function<br>
-<br>
- In a couple spots we look at the value of the background value<br>
- of the softmask to decide if we really need the softmask in<br>
- areas outside the group bounding box. These checks were not<br>
- considering the impact of the transfer function.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 11:37: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=9557cdc0b00894bc4c2c1fccb1f19c33fd7eb499">9557cdc0b00894bc4c2c1fccb1f19c33fd7eb499</a>
-<blockquote>
-<p>
- Dates etc for 9.51 RC1<br>
-<br>
-Makefile.in<br>
-base/gscdefs.h<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/Internal.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>
-psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-11 11:11:47 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad317d8d436f3ae282597631464313666451747f">ad317d8d436f3ae282597631464313666451747f</a>
-<blockquote>
-<p>
- Fix bug 702060: clip_transform_pixel_region was ignoring the 'transpose' flag.<br>
-<br>
-base/gxclip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 00:24:25 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c6bfa12cccb726974aa1c3ad5c4887600f7331d">1c6bfa12cccb726974aa1c3ad5c4887600f7331d</a>
-<blockquote>
-<p>
- Update jbig2dec stuff for 0.18 release.<br>
-<br>
-jbig2dec/CHANGES<br>
-jbig2dec/jbig2.h<br>
-jbig2dec/jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-12 00:27:41 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=70f094ae147afdbbcfcff3351f3ec13db6a84c42">70f094ae147afdbbcfcff3351f3ec13db6a84c42</a>
-<blockquote>
-<p>
- jbig2dec: Sync memento from ghostscript.<br>
-<br>
-jbig2dec/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-10 16:19:49 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f35924926cb35f08be5a12ded4a00eb2f42aed3e">f35924926cb35f08be5a12ded4a00eb2f42aed3e</a>
-<blockquote>
-<p>
- Fix leaks after error in gs_main_init_with_args01() (found by memento).<br>
-<br>
- Fixes various memento failures starting with:<br>
- MEMENTO_FAILAT=2034 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-10 16:11:31 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2704441705cb115b352350252480dbb2505d9767">2704441705cb115b352350252480dbb2505d9767</a>
-<blockquote>
-<p>
- Memento: show backtrace when we start failing.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-10 16:11:06 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c736329f36c2258011162c97eec59818fb6f147e">c736329f36c2258011162c97eec59818fb6f147e</a>
-<blockquote>
-<p>
- Fixed segv after alloc failure in ps_impl_allocate_interp_instance() (found by memento).<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=2017 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-gpdl/psitop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-10 16:00:29 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f1cb9e832424a1185fe081e2238b2ba42f805318">f1cb9e832424a1185fe081e2238b2ba42f805318</a>
-<blockquote>
-<p>
- Fixed leak in xps_impl_allocate_interp_instance() (found by memento).<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=2011 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-10 15:40:01 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59dba1a5a0f2d45c18249697b3429c250ae7311a">59dba1a5a0f2d45c18249697b3429c250ae7311a</a>
-<blockquote>
-<p>
- Fixed segv on error in gs_cspace_new_scrgb() (found by memento).<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=2006 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-base/gscspace.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-10 15:30:18 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=95378885483aa68969417c84e59be4eb1ad0f05e">95378885483aa68969417c84e59be4eb1ad0f05e</a>
-<blockquote>
-<p>
- Fixed segv on error in gsicc_set_iccsmaskprofile() (found by memento).<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=1951 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-10 12:21:24 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=691d2e37fc9f06bf6fb0ed009a880f4d40a86f48">691d2e37fc9f06bf6fb0ed009a880f4d40a86f48</a>
-<blockquote>
-<p>
- Fixed leak on error in xps_impl_allocate_interp_instance() (found by memento).<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=1938 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-10 11:40:59 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=450eb91a0af4901b1f9a259cc69d8976113cbadb">450eb91a0af4901b1f9a259cc69d8976113cbadb</a>
-<blockquote>
-<p>
- Fix error handling in xps_impl_allocate_interp_instance() (detected by memento).<br>
-<br>
- Handle error from gs_font_dir_alloc(), and moved all cleanup to end.<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=1937 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-10 11:21:37 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=33130c86c4d46bafe7613e3b4b114481c30d17ad">33130c86c4d46bafe7613e3b4b114481c30d17ad</a>
-<blockquote>
-<p>
- Fix segv in gsicc_alloc_link() error handling (detected by memento).<br>
-<br>
- Set up placeholder values in *result before trying to set result-&gt;lock, so that<br>
- gs_free_object() works without segv.<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=431 LD_LIBRARY_PATH=../libbacktrace/.libs ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-07 19:01:01 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da2759cd587e2a67134db469cb143643469f09f5">da2759cd587e2a67134db469cb143643469f09f5</a>
-<blockquote>
-<p>
- Fix leak on error in gsicc_profile_new() (detected by memento).<br>
-<br>
- Fixes:<br>
- MEMENTO_FAILAT=369 ./membin/gpdl -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
-base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-07 19:38:55 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0ddc921923d36c19480223f3d92c19aee03df961">0ddc921923d36c19480223f3d92c19aee03df961</a>
-<blockquote>
-<p>
- Pull in a couple of memento fixes from Sebastian.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-29 16:59:29 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=df70f85ce3f5dd300b5ce75b348e78dff528c2f4">df70f85ce3f5dd300b5ce75b348e78dff528c2f4</a>
-<blockquote>
-<p>
- jbig2dec: Invite user to define MEMENTO in CFLAGS.<br>
-<br>
- Previously we invited the user to define MEMENTO in jbig2_priv.h.<br>
- The problem with doing that is that the flag is enabled for all .c<br>
- modules, except memento.c. This implies that while memento's wrapper<br>
- functions are called, the versions being called are the ones that<br>
- have memento features disabled.<br>
-<br>
- Setting CFLAGS=-DMEMENTO while configuring/building is the better<br>
- option as CFLAGS will affect all .c modules.<br>
-<br>
-jbig2dec/jbig2_priv.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-29 16:55:51 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20009c9e35eca1d66f0c1d2fadb9956304692156">20009c9e35eca1d66f0c1d2fadb9956304692156</a>
-<blockquote>
-<p>
- jbig2dec: Fix compilation issues with memento build.<br>
-<br>
-jbig2dec/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-17 12:11:54 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5fde8364de28bc44965a57f1dd0190c0966bccb4">5fde8364de28bc44965a57f1dd0190c0966bccb4</a>
-<blockquote>
-<p>
- jbig2dec: Fix memento interfering with allocator callback names.<br>
-<br>
- Memento changes the names of the callbacks when they are set, but<br>
- not when the structure is defined in the command line tool. Work<br>
- around this by including memento prior to the structure being<br>
- defined so that memento changes the names in both places.<br>
-<br>
- The alternative would be changing the jbig2dec API yet again.<br>
-<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-08 03:18:09 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22665fbc3ff92c46952b07fcb99b8102e0fabde5">22665fbc3ff92c46952b07fcb99b8102e0fabde5</a>
-<blockquote>
-<p>
- jbig2dec: Sync memento from ghostscript.<br>
-<br>
-jbig2dec/memento.c<br>
-jbig2dec/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-11 01:51:19 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ebe1bfef330f4568c6ef394571cf800604dff277">ebe1bfef330f4568c6ef394571cf800604dff277</a>
-<blockquote>
-<p>
- Bug 702097: Import security fixes for OpenJPEG.<br>
-<br>
- Upstream has merged two security fixes. At the moment there is<br>
- no new upstream release, so we merge the two fixes downstream:<br>
-<br>
- * Fix for upstream issue #1228, registered as CVE-2020-6851:<br>
- https://github.com/uclouvain/openjpeg/commit/024b8407392cb0b82b04b58ed256094ed5799e04<br>
- &quot;opj_j2k_update_image_dimensions(): reject images whose coordinates are beyond INT_MAX (fixes #1228)&quot;<br>
-<br>
- * Fix for upstream issue #1231, registered as CVE-2020-8112:<br>
- https://github.com/uclouvain/openjpeg/commit/05f9b91e60debda0e83977e5e63b2e66486f7074<br>
- &quot;opj_tcd_init_tile(): avoid integer overflow<br>
- That could lead to later assertion failures.<br>
- Fixes #1231 / CVE-2020-8112&quot;<br>
-<br>
-openjpeg/src/lib/openjp2/j2k.c<br>
-openjpeg/src/lib/openjp2/tcd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-06 11:47:48 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6d8dcf8448235895759fb7e3268105c4092a194">c6d8dcf8448235895759fb7e3268105c4092a194</a>
-<blockquote>
-<p>
- clusterpush.pl: exclude all *-bin and *-obj directories.<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-07 14:27:12 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e507f7e272cfe94099ed6a395a3fa584d56fd3aa">e507f7e272cfe94099ed6a395a3fa584d56fd3aa</a>
-<blockquote>
-<p>
- Fixed memento leak when squeezed in gs_main_init1().<br>
-<br>
- Fixes leaked blocks in:<br>
- MEMENTO_FAILAT=202 ./membin/gs -sDEVICE=bit -o /dev/null examples/tiger.eps<br>
-<br>
- Also in context_state_alloc(), ensure pcst-&gt;memory is valid even if we return<br>
- an error.<br>
-<br>
-psi/icontext.c<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-07 12:33:56 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e9f7fc153d92cbed9a4f1fcf60778176888625d">0e9f7fc153d92cbed9a4f1fcf60778176888625d</a>
-<blockquote>
-<p>
- Bug 702100: Followup: Fix arch.h for OS-X to include size_t changes.<br>
-<br>
- Our fix for Bug 702100 meant we were using newly defined size_t<br>
- limits from arch.h. While these were generated correctly for<br>
- things using arch.h, they were missed out of one of the<br>
- pregenerated files in the arch directory, namely the OS-X one.<br>
-<br>
- Add those back here.<br>
-<br>
- Thanks to Peter Skarpetis for reporting this.<br>
-<br>
-arch/osx-x86-x86_64-ppc-gcc.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-06 15:08:55 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e193b5dc14a6029b2648a5712c154499d819186f">e193b5dc14a6029b2648a5712c154499d819186f</a>
-<blockquote>
-<p>
- Bug 702100: Fix memory limit to be based on size_t not long.<br>
-<br>
- I missed this when converting from longs to size_ts. This<br>
- resulted on different maximums for linux and windows 64bit<br>
- builds, due to the different size of longs on those two<br>
- platforms.<br>
-<br>
- Update the debugging printfs to make use of the PRIdSIZE macros<br>
- rather than truncating.<br>
-<br>
-base/gsalloc.c<br>
-base/gsmalloc.c<br>
-base/std.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-06 14:39:10 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3ac7d3c0ed5a339c8e2fe25c43feac92b9813b1b">3ac7d3c0ed5a339c8e2fe25c43feac92b9813b1b</a>
-<blockquote>
-<p>
- Sync memento between mupdf and gs.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-06 13:02:33 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d185c5afea23e937edda368491d382650001f5b4">d185c5afea23e937edda368491d382650001f5b4</a>
-<blockquote>
-<p>
- Memento: Remove MEMENTO_SQUEEZE_BUILD from the code.<br>
-<br>
- Rather than relying on building with MEMENTO_SQUEEZE_BUILD,<br>
- instead nobble the pthread based threading functions themselves<br>
- to check Memento_squeezing in MEMENTO builds.<br>
-<br>
- a) This means less pollution of the code overall as the changes<br>
- are restricted to just one module.<br>
-<br>
- b) This will stop me forgetting to build with MEMENTO_SQUEEZE_BUILD<br>
- and not understanding the results - EVERY SINGLE TIME.<br>
-<br>
- c) It means a single MEMENTO build can be used both for<br>
- memory squeezing (of single-threaded runs) and normal memento<br>
- testing (of both single- and multi-threaded runs).<br>
-<br>
-base/gp_psync.c<br>
-base/gsicc_cache.c<br>
-base/gsicc_lcms2.c<br>
-base/gsicc_lcms2mt.c<br>
-base/gsicc_manage.c<br>
-base/gslibctx.c<br>
-base/gsmalloc.c<br>
-base/memento.c<br>
-base/memento.h<br>
-base/sjpx_openjpeg.c<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-06 11:06:38 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f40471ba6312a89cda81c23c1690dfbdbbc2722f">f40471ba6312a89cda81c23c1690dfbdbbc2722f</a>
-<blockquote>
-<p>
- Fix MEMENTO_FAILAT=352 in gsicc_cache_new()<br>
-<br>
- Ensure that result's fields are initialised before we attempt to allocate<br>
- result-&gt;lock. Otherwise if the latter fails and we attempt to clean up,<br>
- icc_linkcache_finalize() will get a SEGV.<br>
-<br>
-base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-31 20:22:11 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=37fae2058eb7216c60801dfdbd5b9c987446866a">37fae2058eb7216c60801dfdbd5b9c987446866a</a>
-<blockquote>
-<p>
- Re-apply fix for bug 700088 lost in openjpeg 2.3.1 upgrade.<br>
-<br>
- The original commit message read:<br>
-<br>
- Bug 700088: Report error if all wanted J2K components are not decoded.<br>
-<br>
- Ghostscript used to attempt to use even the undecoded components.<br>
- The source code for upstream's opj_decompress tool avoided this by<br>
- a workaround along with a comment indicating that this ought to be<br>
- done in the library (so all clients, e.g. Ghostscript will benefit<br>
- from it). With this commit the library will error out if not all<br>
- requested components are successfully decoded. Thus Ghostscript<br>
- will no longer crash.<br>
-<br>
- Reported in https://github.com/uclouvain/openjpeg/issues/1158<br>
- sent upstream in https://github.com/uclouvain/openjpeg/pull/1164<br>
- and finally committed in e66125fe260deee49fdf6e9978d9bd29871dd5bb<br>
-<br>
-openjpeg/src/lib/openjp2/j2k.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-05 11:53:57 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=56e3ed1abc84ef0c8a718b458a5734b016e7b8cc">56e3ed1abc84ef0c8a718b458a5734b016e7b8cc</a>
-<blockquote>
-<p>
- jbig2dec: Simplify jbig2_arith_decode.<br>
-<br>
- Previously we passed in an int * to get errors back, and<br>
- used the return code for 0 or 1. Now we use the return code<br>
- for 0, 1 or -ve for error.<br>
-<br>
- This saves between 1% and 2% of gs runtime for decoding<br>
- tests/pdf/Jbig2_042_06.pdf.<br>
-<br>
-jbig2dec/jbig2_arith.c<br>
-jbig2dec/jbig2_arith.h<br>
-jbig2dec/jbig2_arith_iaid.c<br>
-jbig2dec/jbig2_arith_int.c<br>
-jbig2dec/jbig2_generic.c<br>
-jbig2dec/jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-04 11:10:41 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db24ea3579f2fb6feef7eef98b7163ce6879ef98">db24ea3579f2fb6feef7eef98b7163ce6879ef98</a>
-<blockquote>
-<p>
- Bug 702068 continued: Revised handling of images within smasks.<br>
-<br>
- In an earlier commit, (Jan 27th, f6f8b8de) I updated the gridfitting<br>
- logic so that Images within SMask definitions were gridfitted. This<br>
- solved the original complaint.<br>
-<br>
- Sadly, this caused problems with other things (thanks to Ken for<br>
- spotting them). Files sometimes use an image in an smask, and then<br>
- another &quot;matching&quot; image masked by that smask. The upshot of my<br>
- new code was that we'd treat them differently. 'Stretching' the<br>
- SMasked image, and not stretching the underlying image could cause<br>
- moire effects.<br>
-<br>
- The solution, implemented here, is to apply gridfitting to images<br>
- both in SMask definitions and usage.<br>
-<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gxdevsop.h<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-03 11:06:48 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=93ff4543685f8692db40a8911ad4605124b3433c">93ff4543685f8692db40a8911ad4605124b3433c</a>
-<blockquote>
-<p>
- jbig2dec: Fix OSS-Fuzz issue 20493<br>
-<br>
- The maximum x gbat works out as 126, where GBW is 32.<br>
- This makes right = GBW - gmax huge. Clip the value to<br>
- avoid problems.<br>
-<br>
- Thanks for OSS-Fuzz for reporting.<br>
-<br>
-jbig2dec/jbig2_arith.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-04 11:33:02 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a8572b92d6839abc60ecce6fae7a23b8b3a6bbbd">a8572b92d6839abc60ecce6fae7a23b8b3a6bbbd</a>
-<blockquote>
-<p>
- Fix test of uninitialised value in halftone screens<br>
-<br>
- This is a result of bug #702077 and commit :<br>
- http://git.ghostscript.com/?p=ghostpdl.git;a=commit;h=f434497caaf2624caabbbc62f36b745e096e95b5<br>
-<br>
- There's nothing wrong with the commit, but a 64-bit release build on<br>
- Linux, using the customer file and 720 dpi, resulted in an infinite<br>
- loop. Valgrind suggested this was due to an uninitialised variable.<br>
-<br>
- The problem here was that the code assumed that the first iteration<br>
- looking for the best match would succeed. However, because the halftone<br>
- has a Frequency of 1 the value of 'W' exceeded the maximum of a short,<br>
- which led to use running round the loop without finding a valid halftone.<br>
-<br>
- Because we didn't find a valid halftone we would not set phcp to the<br>
- values in 'p' (which is set by gx_compute_cell_values) and so we would<br>
- test phcp-&gt;C which was uninitialised, and could end up going round the<br>
- loop retrying with different values of rt endlessly.<br>
-<br>
- This commit simply short-circuits this by checking to see if we have<br>
- at least one valid match (rt is not 1) or that we have set phcp to p<br>
- (better is true). If we have done neither of these, then exit<br>
- immediately with an error to prevent testing phcp-&gt;C.<br>
-<br>
-base/gshtscr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-03 16:29:59 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b439a0a33f637254a831b3e76525002df3d41774">b439a0a33f637254a831b3e76525002df3d41774</a>
-<blockquote>
-<p>
- jbig2dec: Fix OSS-Fuzz issue 20505.<br>
-<br>
- Previous code could overflow if w &gt;= 2^32 - 32, breaking behaviour of 'if'<br>
- statements and causing incorrect behaviour (including assert failures).<br>
-<br>
- The fix is due to sebras - change expressions such as (x + 32 &gt; w) to (w - x &lt;<br>
- 32) to avoid overflow for very large w. (We know at all times that x &lt;= w.)<br>
-<br>
- Thanks for OSS-Fuzz for reporting.<br>
-<br>
-jbig2dec/jbig2_mmr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-03 11:06:48 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ece7a0b952d5dbca2a04682f38199444cb1ea16f">ece7a0b952d5dbca2a04682f38199444cb1ea16f</a>
-<blockquote>
-<p>
- jbig2dec: Fix OSS-Fuzz issue 20493<br>
-<br>
- The maximum x gbat works out as 126, where GBW is 32.<br>
- This makes right = GBW - gmax huge. Clip the value to<br>
- avoid problems.<br>
-<br>
- Thanks for OSS-Fuzz for reporting.<br>
-<br>
-jbig2dec/jbig2_generic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-03 10:54:09 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f434497caaf2624caabbbc62f36b745e096e95b5">f434497caaf2624caabbbc62f36b745e096e95b5</a>
-<blockquote>
-<p>
- PDF interpreter - don't abort stream on halftone errors<br>
-<br>
- Bug #702077 &quot;Rangecheck error @720 dpi in sethalftone with SimpleDot&quot;<br>
-<br>
- The supplied PDF file has a legal but stupid Halftone, it has a type 5<br>
- halftone that does not specify a child halftone for each ink, for those<br>
- inks that it does specify it uses the same halftone for all of them, and<br>
- the child haftone has a /Frequency and /Angle of 1.<br>
-<br>
- Chris suggests this is a Harlequin Rip specific halftone which is<br>
- intended not to be used, but to be replaced by something in the rip. Of<br>
- course this means that the PDF file is now device-specific because any<br>
- conforming PDF consumer which halftones should use the crazy halftone<br>
- in the file which will lead to terrible output.<br>
-<br>
- However, poor quality isn't the complaint here, its the fact that we<br>
- simply cannot create a halftone tile large enough to produce a 1 lpi<br>
- screen at 720 dpi, so we throw an error.<br>
-<br>
- I believe this is a reasonable error, so I'm not going to try and<br>
- change it. Instead this commit runs sethalftone in a stopped context<br>
- and, if it fails, does not abort the current content stream but instead<br>
- emits a warning and carries on.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-02-03 10:15:30 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a32a890b95355165cbaf79ff679c2f774b41d26">6a32a890b95355165cbaf79ff679c2f774b41d26</a>
-<blockquote>
-<p>
- Update msvc.mak to cope with new nmake version.<br>
-<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-30 19:08:55 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a3bc57e11d62227a73e9d86d804966740a6a2196">a3bc57e11d62227a73e9d86d804966740a6a2196</a>
-<blockquote>
-<p>
- Fix SEGV with -ZB debug in gx_image1_plane_data<br>
-<br>
- Discovered while debugging. If the buffer is used &quot;in place&quot; without<br>
- copying, the 'buffer' pointer in the debug loop would be NULL. Instead<br>
- use the penum-&gt;buffer.<br>
-<br>
-base/gxidata.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-29 15:34:58 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c5a25063d6041902442334f633840bd8660451e">1c5a25063d6041902442334f633840bd8660451e</a>
-<blockquote>
-<p>
- Further optimisations to jbig2_decode_generic functions.<br>
-<br>
- Carry 'window' of pixel data across scanlines, and read<br>
- samples from it.<br>
-<br>
- Write pixel data back in whole bytes rather than single bits.<br>
- Sadly, for cases where the adaptive pixels are non-standard we<br>
- need to write back after every pixel in case the adaptive<br>
- pixels read from it.<br>
-<br>
- Profiling shows the time spent in the hotspot with jbig2_042_08.pdf<br>
- drops from 56% to 43% with this optimisation.<br>
-<br>
- Particular thanks to Sebastian for spotting various issues with<br>
- this.<br>
-<br>
-jbig2dec/jbig2_generic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-29 15:21:53 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e84a5f7ca660af4de1afb5bce79f6262b44ebd1">0e84a5f7ca660af4de1afb5bce79f6262b44ebd1</a>
-<blockquote>
-<p>
- Solve warnings in jbig2_image.h.<br>
-<br>
- Move some static inlines into the only file they are called<br>
- from rather than having them in the header.<br>
-<br>
-jbig2dec/jbig2_generic.c<br>
-jbig2dec/jbig2_image.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-30 09:39:40 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e852e56f0413d5ecb70a83fc03d78ad4a0561433">e852e56f0413d5ecb70a83fc03d78ad4a0561433</a>
-<blockquote>
-<p>
- More 'trailing white space' fixes.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-30 09:12: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=97868a9e6c787ea988f43952ae5d4236e142db13">97868a9e6c787ea988f43952ae5d4236e142db13</a>
-<blockquote>
-<p>
- Fix trailing white spaces in a number of places.<br>
-<br>
- Since I use the Git commit hooks to verify no white space problems I<br>
- can't merge master into the pdfi branch without first fixing these.<br>
-<br>
-base/gp_unifs.c<br>
-base/gscolor2.c<br>
-base/gscspace.c<br>
-base/gsovrc.c<br>
-base/gxblend.c<br>
-base/gxccache.c<br>
-base/gxclthrd.c<br>
-contrib/gdevlx32.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-29 15:10:06 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3b2ae21ca594934728f623667db1a002286193ea">3b2ae21ca594934728f623667db1a002286193ea</a>
-<blockquote>
-<p>
- Fix plane_strip_copy_rop() to use correct color depth when processing the plane.<br>
-<br>
- Temporarily change mdev-&gt;color_info.depth to mdev-&gt;planes[plane].depth<br>
- so that things work when we process the plane. E.g. this fixes bug where<br>
- mem_gray8_rgb24_strip_copy_rop() was overwriting into the line_ptrs[] array.<br>
-<br>
- Fixes segv in:<br>
- ./bin/gs -sOutputFile=foo -dGraphicsAlphaBits=4 -dTextAlphaBits=4 -dMaxBitmap=10000 -sDEVICE=psdrgb -r300 -Z: -sDEFAULTPAPERSIZE=letter -dNOPAUSE -dBATCH -K2000000 -dClusterJob -dJOBSERVER ../fts_27_2709.pdf<br>
-<br>
-base/gdevmpla.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-27 15:50:44 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6f8b8de526266eebd850e43bf1d0037b6f62e4c">f6f8b8de526266eebd850e43bf1d0037b6f62e4c</a>
-<blockquote>
-<p>
- Bug 702068: Fix 'cracks' appearing around transparently blended regions.<br>
-<br>
- As part of rendering SMasks, we take the bbox for the region, and round<br>
- it up to make the buffer in pdf14. If (as is frequently the case) the<br>
- SMask contents are an image, the PS rendering of that image can result<br>
- in it rounding DOWN (due to &quot;any part of a pixel&quot; vs &quot;pixel centre<br>
- covered&quot;). This can result in 'cracks' around the edge of smasked<br>
- groups.<br>
-<br>
- The fix, implemented here, is to extend the logic that &quot;gridfits&quot;<br>
- images within pattern accumulator to also cover smasks.<br>
-<br>
- To make this work we add a new gx_dev_spec_op to detect whether we are<br>
- in an smask definition.<br>
-<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gxdevsop.h<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-29 12:40:14 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e22376d9226b02ac8cb7951264dae2f3c1bc0b7f">e22376d9226b02ac8cb7951264dae2f3c1bc0b7f</a>
-<blockquote>
-<p>
- jbig2dec: Fix OSS-Fuzz issue 20358<br>
-<br>
- Avoid a signed/unsigned comparison which was implicitly casting<br>
- gmax=-1 to unsigned, and hence making right larger than it should<br>
- have been.<br>
-<br>
- Apply similar fixes to equivalent places in the code.<br>
-<br>
-jbig2dec/jbig2_generic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-29 11:00:18 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc48809733f2eec9ab96c012f62c9dd3a7c06c90">dc48809733f2eec9ab96c012f62c9dd3a7c06c90</a>
-<blockquote>
-<p>
- Tweak stdpre.h's definition of inline.<br>
-<br>
- Ensure it's actually set when possible, in particular for<br>
- VS.<br>
-<br>
-base/stdpre.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-28 17:54:28 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2450ea4feb89996e1107bb79d44a049bab5b971e">2450ea4feb89996e1107bb79d44a049bab5b971e</a>
-<blockquote>
-<p>
- MSVC makefile tweaks for VS2019.<br>
-<br>
- Spot a new version of nmake, as supplied with the latest version<br>
- of the platform tools.<br>
-<br>
- Cope with both Community and Professional versions of VS2019.<br>
-<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-29 10:00:39 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cb456c92a550e1af70a4e268b2f5b02f2df5b8c6">cb456c92a550e1af70a4e268b2f5b02f2df5b8c6</a>
-<blockquote>
-<p>
- Fix jbig2dec compilation when inline is not defined.<br>
-<br>
- VS 2008 defines __inline but not inline, later versions of Visual Studio<br>
- do define inline, but apparently also permit __inline (presumably for<br>
- backwards compatibility).<br>
-<br>
- Since we now use inline for performance purposes in jbig2_image.h its<br>
- vital that inline is defined. Here we modify the win32 config file to<br>
- define inline in terms of __inline for VS 2008 and above, unless inline<br>
- is already defined in which case we use it as is. For VS 2005<br>
- Ghostscript defines inline as nothing, so we do the same.<br>
-<br>
- Finally, add a last-ditch definition of inline (as nothing) to jbig2.h<br>
- to cover any build environment where inline is still undefined, so that<br>
- the code will at least compile.<br>
-<br>
-jbig2dec/config_win32.h<br>
-jbig2dec/jbig2.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-29 05:04:34 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=440dca503ee663290227334415f0c482e87b4ad7">440dca503ee663290227334415f0c482e87b4ad7</a>
-<blockquote>
-<p>
- Bug 702041: Recognize pre-multiplied alpha when decoding with OpenJPEG.<br>
-<br>
- The bug's attached PDF has an annotation where the apperance stream consists of<br>
- a JPEG2000 image with a softmask embedded in the image data (SMaskInData is<br>
- non-zero). The JPEG2000 bitstream provides all three RGB channels and has both<br>
- non-pre-multiplied and pre-multiplied alpha. The last alpha channel defined in<br>
- the bitstream happens to be the pre-multiplied alpha. Having more than than a<br>
- single alpha channel is not allowed according to PDF 2.0 if SMaskInData is<br>
- non-zero. So the JPEG2000 bitstream (and by inference the PDF file) is arguably<br>
- broken.<br>
-<br>
- Adobe Acrobat renders the annotation as a mostly transparent image consisting<br>
- of a few hand-scribbled lines, but Ghostscript renders the annotation as a<br>
- solid black square. So a workaround to match Acrobat is needed even if the PDF<br>
- is broken.<br>
-<br>
- OpenJPEG hides that the JPEG2000 bitstream has multiple alpha channels by<br>
- discarding all alpha channels except the last one defined, so Ghostscript can<br>
- only get at the pre-multipled alpha channel. Previously the OpenJPEG glue layer<br>
- therefore didn't recognize any alpha channels at all. The PDF interpreter has<br>
- its own JPX cdef header decoder in Resources/Init/pdf_draw.ps and it _did_<br>
- recognize that the file contained an alpha channel. This mismatch between the<br>
- OpenJPEG glue layer and the PDF interpreter meant that no alpha channel data<br>
- was propagated to the transparency compositor. It assumed that the alpha<br>
- channel was fully opaque and because the RGB channels are all zero the<br>
- annotation was rendered as a solid black square.<br>
-<br>
- Now that pre-multiplied alpha channels are recognized both in the OpenJPEG glue<br>
- layer and in the PDF interpreter the pre-multiplied alpha channel data which<br>
- contains the hand-scribbling is propagated to the transparency compositor which<br>
- therefore can render the annotation similar to Acrobat.<br>
-<br>
-base/sjpx_openjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-28 10:48:34 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e529d11fa270f8a40ebc2512cfb19cf8d3b0e50">0e529d11fa270f8a40ebc2512cfb19cf8d3b0e50</a>
-<blockquote>
-<p>
- Remove &quot;STANDARD_SLOW_VERSION&quot; define from openjpeg makefile.<br>
-<br>
- This was added (apparently) to workaround a bug causing SEGVs<br>
- in the optimised code. Sadly, this also halves the speed of the<br>
- code.<br>
-<br>
- We have updated openjpeg since, so it shouldn't be necessary.<br>
- Tests with the cluster seem to bear this out.<br>
-<br>
-base/openjpeg.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-28 17:35:37 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9156c43b44b64c3928d2ef20f15d56bd44c6f897">9156c43b44b64c3928d2ef20f15d56bd44c6f897</a>
-<blockquote>
-<p>
- gpdl: Update j2k reading code to spot modified header.<br>
-<br>
- The JP2K spec says we should spot &quot;jP &quot;, where previously<br>
- we'd only been spotting &quot;jP\1a\1a&quot;. No idea where that<br>
- latter one came from, but presumably we've been seeing it<br>
- in some files. Make the code cope with both.<br>
-<br>
-gpdl/jp2ktop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-27 11:05:38 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=85cf3b3a7befbed4811d9460dc6a4637f929f8ab">85cf3b3a7befbed4811d9460dc6a4637f929f8ab</a>
-<blockquote>
-<p>
- Fix bug 702065: Multiple rendering threads run slower.<br>
-<br>
- The image_render_color_DeviceN would remap colors using gx_remap_ICC<br>
- which would get the link from the icclink_cache every time. This would<br>
- temporarily lock the mutex for the cache which apparently caused delays.<br>
-<br>
- This would only occur in devices that support spot colors, when the page<br>
- used transparency due to gx_device_uses_std_cmap_procs returning false in<br>
- this case.<br>
-<br>
- The change refactors gx_remap_ICC to produce gx_remap_ICC_with_link that<br>
- can be used by image_render_color_DeviceN with an icc_link that is retained<br>
- in the image enum. The gs_image_class_4_color function is changed to get the<br>
- icc_link for the image_enum before checking the for std cmap procs so that<br>
- it will be available during image_render_color_DeviceN.<br>
-<br>
-base/gsicc.c<br>
-base/gsicc.h<br>
-base/gxicolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-28 10:47:04 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fe9e85d882ade3ebd55c4da0baf1f10d4bb8542d">fe9e85d882ade3ebd55c4da0baf1f10d4bb8542d</a>
-<blockquote>
-<p>
- Remove stray defines from CAL makefile.<br>
-<br>
- When I created the CAL makefile, I copied bits of it from elsewhere.<br>
- I obviously copied in a few stray defines. Remove those.<br>
-<br>
-base/cal.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-27 13:07:00 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad285b8ae3e1871db43d35e87f49e1d099eaf047">ad285b8ae3e1871db43d35e87f49e1d099eaf047</a>
-<blockquote>
-<p>
- Fix devn code that failed to check for allocation returning NULL<br>
-<br>
- Discovered while fixing Coverity CID 353647. pdf14_spot_get_color_comp_index<br>
- failed to check, and since that code was copied from code in this file,<br>
- it had the same problem.<br>
-<br>
-base/gdevdevn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-27 13:01:28 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6efb69c6ae71b10b492ca194f92bfae17310c481">6efb69c6ae71b10b492ca194f92bfae17310c481</a>
-<blockquote>
-<p>
- Fix Coverity ID 353647: Possible out of bounds access<br>
-<br>
- The testing where separations were added in pdf14_spot_get_color_comp_index<br>
- was wrong since it failed to take into account the process colorants.<br>
-<br>
- Also I found that the allocation of sep_name was not checked for NULL which<br>
- could lead to dreferencing location 0 if the allocation failed. Note that<br>
- there were other instances of this in gdevdevn.c which will be fixed in a<br>
- separate commit.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-23 11:19:45 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=089bff145f277d66afe4a3d9e19441aeccaed235">089bff145f277d66afe4a3d9e19441aeccaed235</a>
-<blockquote>
-<p>
- Fix bug 702062: Opacity being applied twice.<br>
-<br>
- If an image has an SMask, the alpha was applied twice, during painting of<br>
- the transparency group and again when the transparencygroup was popped.<br>
- Thanks to Michael Vrhel for the analysis and suggested cure.<br>
-<br>
- If the device has PreserveSMask (e.g., pdfwrite) the SMask will be processed<br>
- by the device and we should not push the group, nor change the opacity.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-27 10:12:24 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=17411adec88c3a846c10cb583cb261f50ca878d6">17411adec88c3a846c10cb583cb261f50ca878d6</a>
-<blockquote>
-<p>
- Fix OSS-Fuzz issue 20332: buffer overflow in jbig2_image_compose.<br>
-<br>
- With extreme values of x/y/w/h we can get overflow. Test for this<br>
- and exit safely.<br>
-<br>
- Thanks for OSS-Fuzz for reporting.<br>
-<br>
-jbig2dec/jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-23 14:45:15 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=430b6a3eacd9648d029887081e99b3a3f0bba3c7">430b6a3eacd9648d029887081e99b3a3f0bba3c7</a>
-<blockquote>
-<p>
- Further optimisation to jbig2_decode_generic_template0_TPGDON.<br>
-<br>
- When the &quot;standard&quot; values for gbat are used, the pixel lookups<br>
- simplify nicely. Optimise for this case.<br>
-<br>
- This brings the time spent in this function down to 17% (from 22%)<br>
- for JBig2_042_08.pdf.<br>
-<br>
-jbig2dec/jbig2_generic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-23 12:55:27 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=94d8ea178fa7c36ad7b844d6d0912b6e090a35e2">94d8ea178fa7c36ad7b844d6d0912b6e090a35e2</a>
-<blockquote>
-<p>
- Further optimisations to jbig2_decode_generic_template0_TPGDON.<br>
-<br>
- Add a function to get a 'run' of pixels, and call that.<br>
-<br>
- This takes the time spent in this function from 29% to 22% for<br>
- Jbig2_042_08.pdf.<br>
-<br>
-jbig2dec/jbig2_generic.c<br>
-jbig2dec/jbig2_image.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-23 12:09:08 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=124ef6a255de0a2816cce32c4fba0852eac1beb3">124ef6a255de0a2816cce32c4fba0852eac1beb3</a>
-<blockquote>
-<p>
- jbig2dec: Optimise jbig2_decode_generic_template0_TPGDON<br>
-<br>
- Decodes of JBig2_042_08.pdf (the worst comparing file to<br>
- luratech in terms of time) show significant time in that<br>
- function (45%). With this patch that drops to 29%.<br>
-<br>
-jbig2dec/jbig2_generic.c<br>
-jbig2dec/jbig2_image.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-25 19:05:09 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a2f9e74ece1690520cb77d7761cf0a5ddaa98474">a2f9e74ece1690520cb77d7761cf0a5ddaa98474</a>
-<blockquote>
-<p>
- Coverity 94484: try different spacing in coverity annotation.<br>
-<br>
-base/gsbitcom.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-24 18:08:22 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34518a9aeaece63d97eda9b802824581846e289e">34518a9aeaece63d97eda9b802824581846e289e</a>
-<blockquote>
-<p>
- jbig2dec: Fix whitespace issues from jbig2_image.c<br>
-<br>
- Introduced because I edited this in MuPDF and copied it back across.<br>
-<br>
-jbig2dec/jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-24 18:00:13 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c1565a04a938408fe31c862f10ef91f9ab5a14b1">c1565a04a938408fe31c862f10ef91f9ab5a14b1</a>
-<blockquote>
-<p>
- jbig2dec: reintroduce gcc attribute that got dropped by accident.<br>
-<br>
-jbig2dec/jbig2_priv.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-24 17:04:27 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a2e8041383100db54d1ea949d1b2648330f5188a">a2e8041383100db54d1ea949d1b2648330f5188a</a>
-<blockquote>
-<p>
- Coverity 94484: added some asserts derived from bits_compress_scaled()'s preconditions.<br>
-<br>
- These are enough to demonstrate to the reader that Coverity 94484's<br>
- negative_shift warning is spurious - in_shift_initial cannot be negative.<br>
-<br>
-base/gsbitcom.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-23 17:12:55 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=409baa5cc81b8d184dceb52c06c9a80c5dcd61d6">409baa5cc81b8d184dceb52c06c9a80c5dcd61d6</a>
-<blockquote>
-<p>
- Coverity 94484: added annotation to avoid negative_shift issue.<br>
-<br>
-base/gsbitcom.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-22 12:24:43 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=77b7cce9253863ac48ef6eb9821880250c7e1307">77b7cce9253863ac48ef6eb9821880250c7e1307</a>
-<blockquote>
-<p>
- jbig2dec/jbig2_mmr.c: optimised jbig2_find_changing_element().<br>
-<br>
- This was a hotspot after optimsation of jbig2_compose_image.<br>
-<br>
- Rather than step through each bit in turn, we now look 8, 16 and 32-bit at a<br>
- time.<br>
-<br>
-jbig2dec/jbig2_mmr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-23 10:39:30 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=079117d95a3f07587624d6fd9ca388b300d0759e">079117d95a3f07587624d6fd9ca388b300d0759e</a>
-<blockquote>
-<p>
- jbig2dec: Insert missing &quot;inline&quot; in templating.<br>
-<br>
- When using static inline templating to optimise a file, it's<br>
- generally best to actually use static inline, and not just<br>
- static.<br>
-<br>
-jbig2dec/jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-23 10:39:04 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f8e918106400220ffe21aef6ef1d491a42991475">f8e918106400220ffe21aef6ef1d491a42991475</a>
-<blockquote>
-<p>
- Squash some double -&gt; fixed warnings.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-21 18:16:37 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1b3c83af56412a06eeade1ea26a4db10de923a5">b1b3c83af56412a06eeade1ea26a4db10de923a5</a>
-<blockquote>
-<p>
- Optimise jbig2_compose_image.<br>
-<br>
- Work at byte level rather than bit level, and use static inline<br>
- templating methods to generate optimised versions for each<br>
- different operator.<br>
-<br>
-jbig2dec/jbig2_image.c<br>
-jbig2dec/jbig2_priv.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-22 09:54:25 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bd73d0c1d0c42fd1671b56f1277b5e9f25391907">bd73d0c1d0c42fd1671b56f1277b5e9f25391907</a>
-<blockquote>
-<p>
- Bug 702052: MaxSpots &gt; 58 caused exception with tiffsep device.<br>
-<br>
- The MaxSpots devn parameter was allowed to be set according the the<br>
- capability of the tiffsep device (up to 60), but an array to hold the<br>
- equivalent CMYK parameter information was not that large. Get rid of<br>
- the MAX_DEVICE_PROCESS_COLORS #define and use the device num_std_colorants<br>
- and color_info.max_components to determine the maximum number of spot<br>
- colorants possible for this and PageSpotColors and update the Devices.htm<br>
- document to reflect the actual limit.<br>
-<br>
- Also to reduce potential mischief, add range check error limits on the<br>
- DeviceN params based on the device component support, not the absolute max.<br>
-<br>
-base/gdevdevn.c<br>
-base/gdevdevn.h<br>
-doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-22 17:53:24 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8d548e306ae773e228dba331e614dd4cca2c56c7">8d548e306ae773e228dba331e614dd4cca2c56c7</a>
-<blockquote>
-<p>
- Bug 702057: Avoid division by zero in old scan converter.<br>
-<br>
-base/gxdtfill.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-21 11:19:33 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba331d45f8e5be7723ff7bca9450f09c28910464">ba331d45f8e5be7723ff7bca9450f09c28910464</a>
-<blockquote>
-<p>
- Bug 702053: Overprint precision issue<br>
-<br>
- AR assumes for the purposes of overprint mode that a color<br>
- value that is less that 0.5/255 is essentially zero. Also<br>
- fix an issue in the Compatible overprint blend mode when<br>
- overprint mode is enabled.<br>
-<br>
-base/gscspace.c<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-21 17:41:52 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d6569b95a29bf86dbdca0bc95e095acaad003525">d6569b95a29bf86dbdca0bc95e095acaad003525</a>
-<blockquote>
-<p>
- Fix segfaults in transparent patterns with -Z@<br>
-<br>
- One gc'ed member (buf) of the structure for patterns with transparency was not<br>
- being initialised after allocation, meaning a debug build (which adds a<br>
- validation step to the garbager) would attempt to follow an uninitialised<br>
- pointer.<br>
-<br>
- Adding the relevant initialisation meant almost identical code in two places,<br>
- so use the pre-existing function insteading of duplicating the code.<br>
-<br>
- Segfaults spotted in weekly debug-Z@ test.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-20 17:01: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=a0df672b0b65110d81f1e143b2e3681d660df8d2">a0df672b0b65110d81f1e143b2e3681d660df8d2</a>
-<blockquote>
-<p>
- Bug 702054: Fix threaded render segfault with shared ICC profiles<br>
-<br>
- When creating the devices for individual rendering threads, if we cannot share<br>
- the ICC profiles, we also cannot share the device icc_struct. In such a case,<br>
- have each rendering thread device also create its own icc_struct.<br>
-<br>
-base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-20 14:23:50 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=df228c8f42962d696861cfc79f7b114ac887d3c4">df228c8f42962d696861cfc79f7b114ac887d3c4</a>
-<blockquote>
-<p>
- Coverity 341118: avoid stat()/opendir() race in gp_enumerate_files_next_impl().<br>
-<br>
-base/gp_unifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-20 12:32:26 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=30f86d215ac5abba5cfe86f0307d642274b850e4">30f86d215ac5abba5cfe86f0307d642274b850e4</a>
-<blockquote>
-<p>
- Coverity 350947: check return from gdev_prn_get_bits().<br>
-<br>
- Also changed some fns from void to int so we can propogate any error.<br>
-<br>
-contrib/gdevlx32.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-20 12:31:00 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bf2fcdc76fe0cec69e48f82e10144441b498a6b2">bf2fcdc76fe0cec69e48f82e10144441b498a6b2</a>
-<blockquote>
-<p>
- Coverity 94484: assert that shift is &gt;= 0.<br>
-<br>
- Have ran gs on 6,000 test files with some code that aborts if this shift is<br>
- -ve, and nothing failed.<br>
-<br>
-base/gsbitcom.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-17 12:58:14 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=144077b38b07119a0a5293ff8f3fc9e44f2813e1">144077b38b07119a0a5293ff8f3fc9e44f2813e1</a>
-<blockquote>
-<p>
- Bug 702049: Handle format strings in pipe OutputFiles<br>
-<br>
- When we implemented the new file access controls, we didn't realise that piped<br>
- output files could include formatted strings: &quot;|md5sum &gt; %03d.txt&quot;, for example.<br>
-<br>
- This just tweaks the gs_add_control_path() logic so it will go through both<br>
- the formatted string section *and* the pipe output section (rather than one or<br>
- the other).<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-17 11:32:10 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb8c4e0dbc304e404a09e9e6f9551e1e504822bb">bb8c4e0dbc304e404a09e9e6f9551e1e504822bb</a>
-<blockquote>
-<p>
- Improve handling of current directory permissions<br>
-<br>
- Tweak the file access permissions code to allow file names with a current<br>
- directory prefix to match &quot;bare&quot; file names - i.e. &quot;file.ps&quot; == &quot;./file.ps&quot;.<br>
-<br>
- This improves compatibility with the &quot;-P&quot; command line option, as well as<br>
- better matching user expectations.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-15 16:05: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=05d44f258a727d86b9d7d9cbe04e43f3e741a636">05d44f258a727d86b9d7d9cbe04e43f3e741a636</a>
-<blockquote>
-<p>
- Bug 702037: Handle empty path from PDF text clip modes<br>
-<br>
- When using one of the clipping Tr modes (4 to 7), if there is no valid<br>
- current point (i.e. no glyphs have been drawn, and no other previous operation<br>
- has established a current point), Acrobat ignores the operation, whilst gs was<br>
- treating that (as in Postscript) as an empty clip.<br>
-<br>
- We now check for a valid current point before calling clip during the ET<br>
- handling.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-16 09:33:47 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dfdf07b07d4fd83fc606d50eaa7132fc9ea7a1ce">dfdf07b07d4fd83fc606d50eaa7132fc9ea7a1ce</a>
-<blockquote>
-<p>
- Coverity 353342: supposed Null pointer dereferences in gxclpath.c<br>
-<br>
- Strange that it griped about passing pdevc_stroke to cmd_put_drawing_color,<br>
- but not earlier where it was passed to gx_default_fill_stroke_path.<br>
- Fix (hopefully) by checking for NULL color pointers before ANY use.<br>
-<br>
-base/gxclpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-15 12:23:21 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=27a3bf0bc16f492538434a9b1bfdbd588e29cedc">27a3bf0bc16f492538434a9b1bfdbd588e29cedc</a>
-<blockquote>
-<p>
- Fix coverity CID 353343.<br>
-<br>
- Remove ppcs. When the code was changed to write the pgs-&gt;color[0],<br>
- the ppcs param was never removed.<br>
-<br>
-base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-15 12:08:22 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39eff9a56b2077d1a9adb48dfefd38e5e94b59c6">39eff9a56b2077d1a9adb48dfefd38e5e94b59c6</a>
-<blockquote>
-<p>
- Make -dUseFastColor occur even when source color space is ICC based<br>
-<br>
- The exception will be the CIELAB color space, the PS CIE color spaces,<br>
- named color, and DeviceN ICC profiles.<br>
-<br>
-base/gsicc_cache.c<br>
-base/gsicc_manage.c<br>
-base/gsicc_manage.h<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-15 11:33:45 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1b7690cdd644fd690c2480a88da62be6131e79ab">1b7690cdd644fd690c2480a88da62be6131e79ab</a>
-<blockquote>
-<p>
- Coverity 353370 dead code removal<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-15 13:42:33 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4872417c26e9133e1f39fc5f9a361053aaee87a7">4872417c26e9133e1f39fc5f9a361053aaee87a7</a>
-<blockquote>
-<p>
- Coverity 350199: mark cf_encode_2d() as not tainting &lt;lbuf&gt; buffer.<br>
-<br>
- After annotating cf_encode_1d(), this coverity issue appears to have changed<br>
- to worrying about cf_encode_2d(). Would have expected a new issue to have been<br>
- generated.<br>
-<br>
-base/scfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-15 11:09:53 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c58f4c538404527cac25b549453f5b805652b445">c58f4c538404527cac25b549453f5b805652b445</a>
-<blockquote>
-<p>
- Fix dependency for custom freetype config header<br>
-<br>
- I'd missed the dependency to make sure the required directories were created<br>
- before attempting to copy the custom header into one of those directories.<br>
-<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-14 11:05:22 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22618fc2fde49c8fc24ed7e88e98f9677e689c85">22618fc2fde49c8fc24ed7e88e98f9677e689c85</a>
-<blockquote>
-<p>
- Coverity 350199: Final attempt to convince coverity that cf_encode_1d() doesn't taint lbuf.<br>
-<br>
-base/scfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-13 13:42: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=d824fb03a6653856dfe6e304bab8fe67a2c8f1f9">d824fb03a6653856dfe6e304bab8fe67a2c8f1f9</a>
-<blockquote>
-<p>
- Bug 689279: Disable bitmap glyphs in freetype<br>
-<br>
- The font in the XPS file has both outline and bitmap glyphs, and with such fonts<br>
- freetype ends up marking them as &quot;bitmap&quot; and &quot;non-scalable&quot; fonts, so when we<br>
- attempt to set a size for glyph scaling not equivalent to the included bitmaps,<br>
- freetype throws an error.<br>
-<br>
- The file works with (a default build) of mupdf because mupdf disables freetype's<br>
- bitmap font support at build time. It is not possible to force freetype to<br>
- ignore bitmap glyphs at run time.<br>
-<br>
- This commit adopts a similar approach to mupdf, and disables bitmap glyph<br>
- support using a custom options header file.<br>
-<br>
-base/freetype.mak<br>
-base/gsftopts.h<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-13 09:54:41 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=67559bed1c0dceb2a1a59be0349e3465a1361743">67559bed1c0dceb2a1a59be0349e3465a1361743</a>
-<blockquote>
-<p>
- Fix error handling issue found by Coverity<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-13 18:18:57 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=defe1d994b52100f535cb9e6a7e6a4f4255d2b2b">defe1d994b52100f535cb9e6a7e6a4f4255d2b2b</a>
-<blockquote>
-<p>
- Coverity 350199: another attempt to quieten coverity.<br>
-<br>
- Will clean up annotations once we've found one that works.<br>
-<br>
-base/scfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-13 16:48:32 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3704918f3a987e95e7d06fc025de2dce04bab5e8">3704918f3a987e95e7d06fc025de2dce04bab5e8</a>
-<blockquote>
-<p>
- Coverity 350199: further attempt to quieten coverity using -tainted_data_sink tag.<br>
-<br>
-base/scfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-12 15:43:51 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ad96e96f1f929e444fdb0e220d2b05c1dde1bf1">4ad96e96f1f929e444fdb0e220d2b05c1dde1bf1</a>
-<blockquote>
-<p>
- Fix defects reported from fill-stroke3 merge<br>
-<br>
-base/gdevp14.c<br>
-base/gscspace.c<br>
-base/gsovrc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-11 12:14:48 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=05c41c0dedaa512419f15798cbc3da92b6a90bbc">05c41c0dedaa512419f15798cbc3da92b6a90bbc</a>
-<blockquote>
-<p>
- Squashed commit fill-stroke3 branch<br>
-<br>
- This branch had several contributors including Robin Watts,<br>
- Ken Sharp and Ray Johnston.<br>
-<br>
- The intent was to add a &quot;fill and stroke&quot; path device method<br>
- to ensure we get proper rendering when doing fill/stroke<br>
- methods with overprint and transparency. In addition,<br>
- adding the method made it possible for pdfwrite to match<br>
- the original pdf source file if it also had fill/stroke methods.<br>
-<br>
- The interaction with overprint and transparency led to significant<br>
- changes in parts of the code related to those sections. In particular,<br>
- overprint was reworked to ensure that the overprint compositor and<br>
- the transparency compositor were aware if it was to be using<br>
- the overprint drawn_comps for stroke or for fill. The code was<br>
- rewritten so that the overprint compositor actions only occurred when<br>
- an actual operation occurred (e.g. fill, stroke, image, text) as opposed<br>
- to every time that the overprint graphic state values changed.<br>
-<br>
- When there is a fill-stroke operation with transparency, depending upon the<br>
- graphic state values, a non-isolated knockout group may be pushed. From this,<br>
- an issue with knockout groups within knockout groups was revealed, which was<br>
- related to the backdrop selection. The backdrop selection code was simplified.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-base/gdbflags.h<br>
-base/gdevdflt.c<br>
-base/gdevepo.c<br>
-base/gdevflp.c<br>
-base/gdevmem.h<br>
-base/gdevmplt.c<br>
-base/gdevnfwd.c<br>
-base/gdevoflt.c<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gdevsclass.c<br>
-base/gdevsclass.h<br>
-base/gscdevn.c<br>
-base/gscolor.c<br>
-base/gscolor2.c<br>
-base/gscolor3.c<br>
-base/gscpixel.c<br>
-base/gscsepr.c<br>
-base/gscspace.c<br>
-base/gscspace.h<br>
-base/gsdcolor.h<br>
-base/gsdevice.c<br>
-base/gsdparam.c<br>
-base/gsdps1.c<br>
-base/gsicc.c<br>
-base/gsicc_manage.c<br>
-base/gsimage.c<br>
-base/gsovrc.c<br>
-base/gsovrc.h<br>
-base/gspaint.c<br>
-base/gspaint.h<br>
-base/gspath.c<br>
-base/gspcolor.c<br>
-base/gsptype1.c<br>
-base/gsptype2.c<br>
-base/gsstate.c<br>
-base/gstext.c<br>
-base/gstrans.h<br>
-base/gxblend.c<br>
-base/gxblend1.c<br>
-base/gxccache.c<br>
-base/gxclimag.c<br>
-base/gxclip.c<br>
-base/gxclip.h<br>
-base/gxclipm.c<br>
-base/gxclist.c<br>
-base/gxclist.h<br>
-base/gxclpath.c<br>
-base/gxclpath.h<br>
-base/gxclrast.c<br>
-base/gxclrect.c<br>
-base/gxcmap.c<br>
-base/gxdevcli.h<br>
-base/gxdevice.h<br>
-base/gxdevsop.h<br>
-base/gxfill.c<br>
-base/gxgstate.h<br>
-base/gxpaint.c<br>
-base/gxpaint.h<br>
-base/gxpath.h<br>
-base/gxpath2.c<br>
-base/gxpcmap.c<br>
-base/gxpcolor.h<br>
-base/gxstroke.c<br>
-base/lib.mak<br>
-devices/gdevpsd.c<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfd.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfg.h<br>
-devices/vector/gdevpdfx.h<br>
-lcms2mt/ChangeLog<br>
-lcms2mt/Projects/VC2010/lcms2mt.rc<br>
-lcms2mt/config.guess<br>
-psi/int.mak<br>
-psi/zcolor.c<br>
-psi/zpaint.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-10 16:50:08 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5faf010d8e043d77ff10f3deee466e9fb2dc7b7e">5faf010d8e043d77ff10f3deee466e9fb2dc7b7e</a>
-<blockquote>
-<p>
- Bug 702032: Fix overflow problem in scan converter.<br>
-<br>
- Very wide regions to be filled (&gt; 0x80000000) can cause problems<br>
- with overflow in clipping calculations, causing regions to be<br>
- filled 'the wrong way' (i.e. from -ve to x rather than from x to<br>
- +ve).<br>
-<br>
- Fix this by tweaking calculations to promote to 64bit 1 step<br>
- earlier than before.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-10 11:56:54 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=419f528cf8625a7e2989068324e962c498c255ef">419f528cf8625a7e2989068324e962c498c255ef</a>
-<blockquote>
-<p>
- Coverity 94984: disabled code that had no affect other than to cause a coverity issue.<br>
-<br>
-contrib/gdevgdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-09 17:14:57 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e3c394504318a9a6774d65c386842d3f568126ce">e3c394504318a9a6774d65c386842d3f568126ce</a>
-<blockquote>
-<p>
- Coverity 94488: improved detection of uninitialised Jbig2HuffmanEntry.<br>
-<br>
- When checking for an incorrect uninitialised entry, test for /either/ of<br>
- &lt;flags&gt; and &lt;PREFLEN&gt; being -1.<br>
-<br>
- Previously we tested for /all/ of &lt;flags&gt;, &lt;PREFLEN&gt; and &lt;entry-&gt;u.RANGELOW&gt;<br>
- being -1, which made coverity think that the following code could be run with<br>
- PREFLEN=-1, which then triggers issue about illegal shifts.<br>
-<br>
- [It seems that &lt;entry-&gt;u.RANGELOW&gt; can be -1 in normal operation, so have<br>
- excluded from the new test.]<br>
-<br>
-jbig2dec/jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-09 15:09:58 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a9c19743cf5bc787ebbcbbff58c5cce0c923d0cc">a9c19743cf5bc787ebbcbbff58c5cce0c923d0cc</a>
-<blockquote>
-<p>
- Coverity 94740: added /* Fall through. */ comment.<br>
-<br>
-contrib/lips4/gdevl4r.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-09 15:07:21 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ee0bc7749eb7c2726bb593637de7653e2b62f10">7ee0bc7749eb7c2726bb593637de7653e2b62f10</a>
-<blockquote>
-<p>
- Coverity 94747: removed 'if' with duplicate code.<br>
-<br>
-contrib/lips4/gdevl4v.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-09 14:40:54 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ccd8370b09531128634b3f5bab76b1de426ab116">ccd8370b09531128634b3f5bab76b1de426ab116</a>
-<blockquote>
-<p>
- Coverity 94809: added /* Fall through. */ comment.<br>
-<br>
-contrib/eplaser/gdevescv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-09 14:26:05 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f563ab707b6068a653fb917974fb1e6a88c068d8">f563ab707b6068a653fb917974fb1e6a88c068d8</a>
-<blockquote>
-<p>
- Coverity 121439: use gx_color_index instead of uint, to avoid overflow when shifting.<br>
-<br>
-contrib/pcl3/eprn/eprnrend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-09 14:21:01 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3acc9babb87048dda29ab766ca41750fc6f58eaf">3acc9babb87048dda29ab766ca41750fc6f58eaf</a>
-<blockquote>
-<p>
- Coverity 94905: disabled code that had no affect other than to cause a coverity issue.<br>
-<br>
-contrib/gdevgdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-09 11:32:11 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bd6f5232dbaaa372b9fdcdb98134af8096c807be">bd6f5232dbaaa372b9fdcdb98134af8096c807be</a>
-<blockquote>
-<p>
- Coverity 95087: use cast to indicate intermediate integer division is expected.<br>
-<br>
-contrib/japanese/gdevmjc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-09 12:17: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=78773b740b3c0095fb4c5df59390f0eea84a6a49">78773b740b3c0095fb4c5df59390f0eea84a6a49</a>
-<blockquote>
-<p>
- Docs: Fix a link to a long gone file.<br>
-<br>
- Reword the &quot;What if I'm writing documentation?&quot; so it makes some sense.<br>
-<br>
-doc/Readme.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-17 15:50:13 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1075fd1caba19e642c9713c3a07961c0a3f0f88d">1075fd1caba19e642c9713c3a07961c0a3f0f88d</a>
-<blockquote>
-<p>
- Improve the English in section on Unicode TTFs<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-08 12:13:35 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af1fe01f44f528fb1322cfcf1b48aa5e1aa76059">af1fe01f44f528fb1322cfcf1b48aa5e1aa76059</a>
-<blockquote>
-<p>
- Coverity 95007: propogate error from eprn_check_colour_info().<br>
-<br>
-contrib/pcl3/eprn/gdeveprn.c<br>
-contrib/pcl3/eprn/gdeveprn.h<br>
-contrib/pcl3/src/gdevpcl3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-08 14:25:52 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e0a0c0ca0e16e8b598a7839011df4c3374ab561d">e0a0c0ca0e16e8b598a7839011df4c3374ab561d</a>
-<blockquote>
-<p>
- clusterpush.pl: also exclude luratech* directories.<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-08 13:08:07 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aba372d8efa1ffdb11a496474f519b0015b31031">aba372d8efa1ffdb11a496474f519b0015b31031</a>
-<blockquote>
-<p>
- Coverity 94665: removed unnecessary if and refactored expression.<br>
-<br>
-contrib/gdevdj9.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-08 13:04:41 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5e1685812864cfde94a5c0daee0cae3307078aa7">5e1685812864cfde94a5c0daee0cae3307078aa7</a>
-<blockquote>
-<p>
- Coverity 94713: added {...} to match indentation.<br>
-<br>
-contrib/lips4/gdevl4v.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-08 13:02:35 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3b727b709f40d6b93e874680ab307aa124de5422">3b727b709f40d6b93e874680ab307aa124de5422</a>
-<blockquote>
-<p>
- Coverity 94729: oki4w_print_page()'s compress_code is always 2.<br>
-<br>
- Simplified code accordingly, and removed static fn oki_compress() as no longer<br>
- referenced.<br>
-<br>
-contrib/gdevop4w.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-08 12:41:57 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e4edd2161b4b7f3ccb23a90a8ca90dccffd078c">4e4edd2161b4b7f3ccb23a90a8ca90dccffd078c</a>
-<blockquote>
-<p>
- Coverity 94757: avoid 'if (foo) return code; return code;' construct.<br>
-<br>
- This code is slightly odd, and didn't want to make major changes, so have ended<br>
- up with odd-looking extended expression whose actual value we ignore.<br>
-<br>
-contrib/gdevbjc_.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-08 12:31:50 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cef68e9a0ca0be10f08e415785f8b8fac37d7828">cef68e9a0ca0be10f08e415785f8b8fac37d7828</a>
-<blockquote>
-<p>
- Coverity 94778: added missing {...}.<br>
-<br>
-contrib/lips4/gdevl4v.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-08 12:28:15 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c517f26773cd3a63f029b1bf6e275b227e3af5e8">c517f26773cd3a63f029b1bf6e275b227e3af5e8</a>
-<blockquote>
-<p>
- Coverity 94811: added break in switch block.<br>
-<br>
-contrib/gdevlx32.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-08 12:25:54 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0c84b20c653444310c979a5df78542e9671a6692">0c84b20c653444310c979a5df78542e9671a6692</a>
-<blockquote>
-<p>
- Coverity 94846: don't dereference &lt;data&gt; without checking it isn't NULL.<br>
-<br>
-contrib/pcl3/src/pclgen.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-08 12:18:02 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=87c48dabcdb64262fc0d24ed81b38d28e7545cb2">87c48dabcdb64262fc0d24ed81b38d28e7545cb2</a>
-<blockquote>
-<p>
- Coverity 95006: improved use preprocessor to hopefully fix this warning.<br>
-<br>
-contrib/opvp/gdevopvp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-08 11:58:50 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4c1e5ac5d9def3cbe25c52c63a3d5ba11f2603ac">4c1e5ac5d9def3cbe25c52c63a3d5ba11f2603ac</a>
-<blockquote>
-<p>
- Coverity 121439: avoid overflow when shifting.<br>
-<br>
-contrib/pcl3/eprn/eprnrend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-08 11:58:14 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f71ebb708947e57eaf7cd33b319ec0676e03ba2e">f71ebb708947e57eaf7cd33b319ec0676e03ba2e</a>
-<blockquote>
-<p>
- Coverity 121442: avoid overflow when shifting.<br>
-<br>
-contrib/opvp/gdevopvp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-08 11:41:50 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4bb071925d68398f8efb493c6b529e897a9bc356">4bb071925d68398f8efb493c6b529e897a9bc356</a>
-<blockquote>
-<p>
- Coverity 350199: fix coverity annotation arg number.<br>
-<br>
-base/scfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-07 19:43:07 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d24553cea74bda19ae7e3dd5a60302fdc49d1fb2">d24553cea74bda19ae7e3dd5a60302fdc49d1fb2</a>
-<blockquote>
-<p>
- Fix indentation problems in examples in API.htm<br>
-<br>
-doc/API.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-06 16:30:17 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=147591b7a8390d0e98418851b60ac67e659cf2f1">147591b7a8390d0e98418851b60ac67e659cf2f1</a>
-<blockquote>
-<p>
- PDF interpreter - don't abort on errors in JBIG2 globals<br>
-<br>
- This was due to Julian's work on comparing jbig2dec with Luratech.<br>
-<br>
- The test file 'normal_716.pdf' and the cluster test file<br>
- jbig2_null_segments_and_glyphs.pdf throw errors when trying to read<br>
- the JBIG2 globals dictionary. Luratech doesn't cache the globals, while<br>
- jbig2dec does, and the problem was that jbig2dec was returning an error<br>
- at a point where the PDF interpreter wasn't able to ignore it, while<br>
- Luratech deferred the error to a later point, at a time when the<br>
- interpreter could, and did, ignore it.<br>
-<br>
- This meant that Luratech continued to render any further content on the<br>
- page while jbig2dec did not, resulting in diffs.<br>
-<br>
- This commit simply runs the global context extraction in a stopped<br>
- context. If it fails we clean up the stack and exit, which (effectively)<br>
- defers the error to the same point as the Luratech decoder.<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-06 12:56: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=9a2414c7f88ef07cb9297bdeb3236cdba44c25ad">9a2414c7f88ef07cb9297bdeb3236cdba44c25ad</a>
-<blockquote>
-<p>
- Bug 702018: Fix CAL build crash in tiffsep1.<br>
-<br>
- The SSE code for CAL currently only copes with a maximum of 4<br>
- planes. Ensure the device falls back to non-CAL code in such<br>
- cases.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-06 11:40:37 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1085ead1dd22e3908c341df160a722e71a9c7cfe">1085ead1dd22e3908c341df160a722e71a9c7cfe</a>
-<blockquote>
-<p>
- Fix VS2019 project getting many x64 builds wrong.<br>
-<br>
-windows/GhostPDL.sln<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-06 08:22:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c53f9d984015b65bf234d65befa552fe9d18c886">c53f9d984015b65bf234d65befa552fe9d18c886</a>
-<blockquote>
-<p>
- Bug 702019: fix dependencies for cups devs and gdevp14<br>
-<br>
- Any &quot;printer&quot; device depends on the low level 'page' device (page.dev),<br>
- unaccountably, the cups devices (cups and pwgraster) did not have that<br>
- dependency in the makefiles.<br>
-<br>
- Also, the PDF transparency compositor now (and for some time) has also depended<br>
- upon page.dev, so update the makefiles for that, too.<br>
-<br>
-base/lib.mak<br>
-devices/devs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-04 20:04:03 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1aa5fdfdbea4c55445ee1bdbe08b822a1bd7a8c">d1aa5fdfdbea4c55445ee1bdbe08b822a1bd7a8c</a>
-<blockquote>
-<p>
- Further refinement for Bug 701880. Make tiffsep better match pbmraw<br>
-<br>
- The previous change attempted to fix the y-phase, but this was not a<br>
- 180 degree rotation, so it caused the primary angle of the pattern to<br>
- shift by 90 degrees. A better correspondence is achieved by inverting<br>
- the polarity of the thresholds. This is slightly &quot;darker&quot; than pbmraw<br>
- but the angle and phase matches pbmraw closely.<br>
-<br>
- Note that the phase using the CAL module does not match the non-CAL<br>
- or pbmraw, but the angle of the pattern does match.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-03 09:56:29 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=372c862f2050d82248316f54156e5bb33dd7520a">372c862f2050d82248316f54156e5bb33dd7520a</a>
-<blockquote>
-<p>
- Fix Bug 701845. The devicen device would confuse transparency.<br>
-<br>
- The devicen device defines 32-bit depth, but 0 components and no<br>
- standard process colors or names. This confused the pdf14 device into<br>
- writing a clist with 1-component (gray), but then because the icc_profile<br>
- had 4 components, would try and use 4 component when reading.<br>
-<br>
- Fix by making it 32-bit CMYK, and also fix to write a valid PCX by<br>
- converting the 32-bit CMYK to 24-bit RGB on output. PCX cannot handle<br>
- 32-bit CMYK. Prior to this, 32-bit CMYK would fail showpage with a<br>
- rangecheck error.<br>
-<br>
-base/gdevdevn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-03 15:51:00 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9608d275bd750b189dd52681791f31617a640817">9608d275bd750b189dd52681791f31617a640817</a>
-<blockquote>
-<p>
- Use CAL halftoning in tiffsep1 post processing.<br>
-<br>
- A quick back to back test with/without cal using:<br>
-<br>
- bin/gswin32c.exe -sDEVICE=tiffsep1 -o out.tif -r600 -dMaxBitmap=80000000<br>
- examples/tiger.eps<br>
-<br>
- shows timings of 1.142s vs 1.297s on my machine.<br>
-<br>
-devices/devs.mak<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-03 15:52:41 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59ed026565b5be1bd055d0fbd1b066b8c07274e0">59ed026565b5be1bd055d0fbd1b066b8c07274e0</a>
-<blockquote>
-<p>
- Squash warnings (dropped from earlier commit).<br>
-<br>
- These warnings were supposed to have been squashed a few<br>
- commits ago, but somehow got lost in a rebase. Thus they<br>
- were mentioned in the commit message, but didn't make it<br>
- in.<br>
-<br>
- Avoid problems with 'errno' being a special thing that<br>
- shouldn't be used as a parameter name.<br>
-<br>
- Explicitly cast time_t to long for printing.<br>
-<br>
-base/gsioram.c<br>
-base/mkromfs.c<br>
-base/pack_ps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-03 10:21:18 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d7d012bfe6c8f248db8b8474743618c53318ce40">d7d012bfe6c8f248db8b8474743618c53318ce40</a>
-<blockquote>
-<p>
- PDF interpreter - increase robustness in face of invalid annotations<br>
-<br>
- Bug #702016 &quot;Invalid annotation causing an error&quot;<br>
-<br>
- The PDF file has an annotation where the creating application has<br>
- inserted the appearance stream directly into the annotation dictionary.<br>
- This breaks the code which attempts to parse the annotation dictionary<br>
- from an indirect reference into a dictionary object.<br>
-<br>
- This commit tries to recover from such egregiously broken situations by<br>
- running the 'oforce' in a stopped context. This is complicated firstly<br>
- by the fact that we parse the annotation dictionary in two places, once<br>
- to check it for the presence of transparency and once to actually draw<br>
- it (if we are rendering annotations).<br>
-<br>
- In addition, the code could potentially leave anything on the stack, so<br>
- we can't use a mark/cleartomark pair to tidy up. Instead, use a<br>
- (hopefully) unique name object, create it on the stack and in the case<br>
- of an error, unwind the stack back to the expected name.<br>
-<br>
- Finally, report the error to the user in a more or less meaningnful way.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-13 12:40:44 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=92031bd1fb9084088a657b7d83339bf499dcc7d2">92031bd1fb9084088a657b7d83339bf499dcc7d2</a>
-<blockquote>
-<p>
- Update Visual Studio solution to VS2019.<br>
-<br>
- Our belief is that this should work in all versions of VS from<br>
- 2010 onwards.<br>
-<br>
- By moving to VS2019, we lose support totally for Windows XP prior<br>
- to SP3. If this is a problem, either build using the Makefile, or<br>
- pull the old VS2005 solution out of git and use that. If customers<br>
- find this to be a problem, we can maintain the old VS2005 solution<br>
- alongside the new one with minimal effort.<br>
-<br>
- Default builds lose support for Windows XP SP3/Windows Server 2003,<br>
- but the new &quot;ReleaseXP&quot;, &quot;DebugXP&quot; and &quot;MementoXP&quot; configurations<br>
- will target these platforms (assuming the v141 tools have been<br>
- installed too).<br>
-<br>
- These &quot;XP&quot; binaries will be build into {,debug,mem}objxp directories<br>
- and will produce binaries with an 'XP' suffix: i.e.<br>
- {,debug,mem}bin/{gs,gpcl6,gxps,gpdl}win{32,32}{,c}xp.exe.<br>
-<br>
-psi/msvc.mak<br>
-windows/All.vcxproj<br>
-windows/GhostPDL.sln<br>
-windows/ghostpcl.vcxproj<br>
-windows/ghostpcl.vcxproj.filters<br>
-windows/ghostpdl.vcxproj<br>
-windows/ghostpdl.vcxproj.filters<br>
-windows/ghostscript.vcxproj<br>
-windows/ghostscript.vcxproj.filters<br>
-windows/ghostxps.vcxproj<br>
-windows/ghostxps.vcxproj.filters<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-16 18:18:47 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=10d2678613d5a93bedc094a62b1b98972871f464">10d2678613d5a93bedc094a62b1b98972871f464</a>
-<blockquote>
-<p>
- Tweak windows Makefiles to know about VS2017 and VS2019.<br>
-<br>
- These builds have only been tested with &quot;DEVSTUDIO=&quot; (i.e.<br>
- relying on the paths to the compilers etc having been set up<br>
- in advance, such as happens when building from within the IDE<br>
- using the supplied solution). Logic has been added for<br>
- command like nmake builds, but this hasn't been tested.<br>
-<br>
- Update the makefiles to avoid using flags that aren't supported<br>
- in later versions.<br>
-<br>
-base/msvccmd.mak<br>
-base/msvclib.mak<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2020-01-02 11:01: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=00cd7c475b173e5cdce7e1e4ff3f0880e1e70583">00cd7c475b173e5cdce7e1e4ff3f0880e1e70583</a>
-<blockquote>
-<p>
- Squash warnings<br>
-<br>
- Don't define STRICT multiple times.<br>
-<br>
- Explicitly cast time_t's in printfs.<br>
-<br>
- Avoid warnings due to errno being a #defined thing.<br>
-<br>
-base/windows_.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-26 13:14:43 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bf689ee0bff720f202ebc98f301c765f34e2c1fa">bf689ee0bff720f202ebc98f301c765f34e2c1fa</a>
-<blockquote>
-<p>
- Bug 701880: tiffsep1 threshold_from_order caused dots in full white.<br>
-<br>
- For patterns with &gt; 256 dots, threshold_from_order would put in 0 value<br>
- cells which would then always be imaged. Change this device to (finally)<br>
- use the gx_ht_construct_threshold used by the fast_ht thresholding code<br>
- so that it should match the other devices, such as pbmraw.<br>
-<br>
- Also vertically invert the use of the threshold array to match the dots<br>
- of the other devices.<br>
-<br>
- Add missing dependencies for gdevtsep.c in devs.mak<br>
-<br>
-devices/devs.mak<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-19 09:22:32 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=97ac0f6ef4010e0a49bf6f8f4515c32a5695df68">97ac0f6ef4010e0a49bf6f8f4515c32a5695df68</a>
-<blockquote>
-<p>
- PDF interpreter -- take out manually drawn rectfill<br>
-<br>
- We can now just draw the rectangle directly with rectfill.<br>
- Whatever issue ken ran into 5 years ago no longer applies.<br>
-<br>
- See also Bug 693731<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-18 14:46:26 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=719bf1f2c4104d933767d37e62489535e8ba9a17">719bf1f2c4104d933767d37e62489535e8ba9a17</a>
-<blockquote>
-<p>
- pdfwrite - use correct FontFile key<br>
-<br>
- This was found as part of bug #701997, even if we set -dCompatibilityLevel<br>
- to 1.1, so that type 1 fonts are not converted to type 2 (1c, CFF) we<br>
- would still write out a FontFile3 key, instead of the correct<br>
- FontFile key.<br>
-<br>
- Ghostscript doesn't care about this, but Acrobat refuses to parse the<br>
- font from the file when it has the wrong FontFile key.<br>
-<br>
- The test we were using was incorrect anyway, we were checking<br>
- ResourcesBeforeUsgae and we should have been checking HaveCFF because<br>
- if HaveCFF is true we would convert type 1 to CFF, and if it isn't we<br>
- wouldn't.<br>
-<br>
-devices/vector/gdevpdtb.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-16 09:52: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=bb47dd4128481c2e62bbd6b5e354da8299f2f16b">bb47dd4128481c2e62bbd6b5e354da8299f2f16b</a>
-<blockquote>
-<p>
- PDF interpreter - use PDFDocEncoding for fonts in text annotations<br>
-<br>
- Bug #701889 &quot;&quot;<br>
-<br>
- We were often not applying PDFDocEncoding to fonts when we used them to<br>
- draw text for annotations. This commit re-encodes the selected font<br>
- which will give a better result.<br>
-<br>
- We probably should also check for UTF16-BE text and use the FallBack<br>
- CIDFont in that case, but we'll wait for an example before trying to<br>
- code that.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-14 19:13:27 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c3b184c41144a2650e5520643bbb1cff42c18acc">c3b184c41144a2650e5520643bbb1cff42c18acc</a>
-<blockquote>
-<p>
- PDF interpreter - fix line ending positions on Line annotations<br>
-<br>
- Bug #701889 &quot;Annotation objects missing or incorrectly interpreted when appearance stream missing&quot;<br>
-<br>
- The calculation of the position of the line ending was incorrect, and<br>
- we were applying the wrong LE entry to each end of the line.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-14 15:24:57 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1246085e17ee35928f737f1fbf69d69fe6b7a2ae">1246085e17ee35928f737f1fbf69d69fe6b7a2ae</a>
-<blockquote>
-<p>
- PDF interpreter - Add arrows to /CL lines in FreeText annotations<br>
-<br>
- Bug #701889 &quot;Annotation objects missing or incorrectly interpreted when appearance stream missing&quot;<br>
-<br>
- Add arrowheads to the ends of callout lines.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-13 15:13:58 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=acccfd2fe90e25534e7d492ca2378dc32269e48e">acccfd2fe90e25534e7d492ca2378dc32269e48e</a>
-<blockquote>
-<p>
- PDF interpreter - Fix multi-line FreeText annotation with /Rotate 270<br>
-<br>
- The calculation of the 'width' of the container for the text was<br>
- incorrect, as was the starting x co-ordinate. Fixed here.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-13 11:55: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=5e5f7b41c080bdbd15fac5afbd09052a83e81a01">5e5f7b41c080bdbd15fac5afbd09052a83e81a01</a>
-<blockquote>
-<p>
- PDF interpreter - apply /C to more annotation types<br>
-<br>
- Bug #701889 &quot;Annotation objects missing or incorrectly interpreted when appearance stream missing&quot;<br>
-<br>
- Seems we also need to apply the /C colour to Polygon, Square and Circle<br>
- annotations before drawing them.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-13 11:23:28 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4940c5cb80916017d3ee0c9b53475323cf5ebbd6">4940c5cb80916017d3ee0c9b53475323cf5ebbd6</a>
-<blockquote>
-<p>
- PDF interpreter - more annotation improvements<br>
-<br>
- Bug #701889 &quot;Annotation objects missing or incorrectly interpreted when appearance stream missing&quot;<br>
-<br>
- Apply the /RD array (if present) to the annotation /Rect before using<br>
- the Rect to draw the border.<br>
-<br>
- We were using the /C array in drawborder to set the colour before<br>
- stroking the border, there are two problems with this; firstly the /C<br>
- array is not used to specify a border colour, secondly we need to set<br>
- the colour for certain objects irrespective of whether they have a<br>
- border.<br>
-<br>
- Remove annotsetcolor from drawborder and apply it to Squiggly, Strikeout,<br>
- Underline, Highlight, Line and Ink annotations in order to set the<br>
- colour before drawing the annotation. The specification says that this<br>
- is used for; the border of a Link annotation, the title bar of a<br>
- pop-up annotation's pop-up and the background of the annotation's icon<br>
- when closed, but in fact Acrobat also uses it to set the colour for all<br>
- the annotation types listed above.<br>
-<br>
- There may still be more work needing done here, but this matches all the<br>
- test cases I currently have.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-12 17:04:17 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d95dd7a23f25e73042f3c8e6043c83285387d0a1">d95dd7a23f25e73042f3c8e6043c83285387d0a1</a>
-<blockquote>
-<p>
- PDF interpreter - apply RD array to Circle, Square and FreeText, apply Rotate to FreeText<br>
-<br>
- Bug #701889 &quot;Annotation objects missing or incorrectly interpreted when appearance stream missing&quot;<br>
-<br>
- The /RD array makes certain kinds of annotations be drawn in a smaller<br>
- area. Although the spec does not mention it, Acrobat applies the<br>
- /Rotate key if found to the text in a FreeText annotation.<br>
-<br>
- Still more to do on the text; we are nto fitting the text correctly<br>
- when Rotate is 270, not certain why. Also we are not drawing Borders<br>
- when we should, some text is missing and text is in the wrong colour<br>
- (due to not applying /DS)<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-12 19:47:18 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f25987c838ea9437b60f8b3b93f90e187013b641">f25987c838ea9437b60f8b3b93f90e187013b641</a>
-<blockquote>
-<p>
- Tweak CAL makefile to include new intrinsics headers in dependencies.<br>
-<br>
-base/cal.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-12 15:44:30 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=321cf6026a05e31140a87cc83a2653b048550df4">321cf6026a05e31140a87cc83a2653b048550df4</a>
-<blockquote>
-<p>
- Fix arch.h dependency in cal build.<br>
-<br>
- This was causing parallel makes of CAL enabled builds to<br>
- fail.<br>
-<br>
-base/cal.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-29 17:48: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=b6f6adb5448fda1f33db4c92c030709618e4ee54">b6f6adb5448fda1f33db4c92c030709618e4ee54</a>
-<blockquote>
-<p>
- Support for YCbCr, LogL, LOGLUV and paletted TIFFs.<br>
-<br>
- YCbCr TIFFs have to use TIFFRGBAImage as for the old JPEG<br>
- encapsulation.<br>
-<br>
-gpdl/tifftop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-28 22:32:43 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ae1cee743e56a7b654d9dbb2ea88ed90d48d298d">ae1cee743e56a7b654d9dbb2ea88ed90d48d298d</a>
-<blockquote>
-<p>
- Further fixes for GPDL TIFF.<br>
-<br>
- Support JPEG encoded TIFFs (both old and new formats).<br>
-<br>
- Old JPEG format requires the whole image to be decoded to an<br>
- RGBAImage in memory at once; looks like that's just a limitation<br>
- of libtiff. This is particularly annoying because it looks like<br>
- the internals of libtiff are prepared to do scanline extraction<br>
- as you'd hope, but aren't exposed to the outside world.<br>
-<br>
-base/msvclib.mak<br>
-base/tiff.mak<br>
-configure.ac<br>
-gpdl/gpdl.mak<br>
-gpdl/tifftop.c<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-12 17:26:02 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef66198ade77d5d551b3045cd36bed81c0b04f54">ef66198ade77d5d551b3045cd36bed81c0b04f54</a>
-<blockquote>
-<p>
- Changes to libtiff for gpdl.<br>
-<br>
- 1) Ensure that libtiff doesn't mess with 'boolean' in GS builds<br>
- on Windows. Without this, the jpeg structures used by our JPEG<br>
- lib build are different in size when called from gs and libtiff,<br>
- resulting in runtime errors.<br>
-<br>
- 2) Update libtiff so that it can correctly call into the jpeg<br>
- library so that memory operations happen from our pools, not<br>
- malloc/free. Slightly horrid in that this is more complex with<br>
- OJPEG than JPEG files.<br>
-<br>
-tiff/libtiff/tif_jpeg.c<br>
-tiff/libtiff/tif_ojpeg.c<br>
-tiff/libtiff/tif_open.c<br>
-tiff/libtiff/tiffio.h<br>
-tiff/libtiff/tiffiop.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-28 10:52:49 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0c248ced8997dfe8f253a07fc6cc5f47837ca12e">0c248ced8997dfe8f253a07fc6cc5f47837ca12e</a>
-<blockquote>
-<p>
- Fixes for GPDL TIFF support.<br>
-<br>
- Support tiled TIFFs, planar TIFFs, and TIFFs where the resolution<br>
- isn't properly specified.<br>
-<br>
-gpdl/tifftop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-12 14:33:27 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=76bd0d75823a571130f340ab6231e064d1f997f7">76bd0d75823a571130f340ab6231e064d1f997f7</a>
-<blockquote>
-<p>
- Move pdf_info.ps into lib (from toolbin)<br>
-<br>
- And add it to the list of files to install on Unix systems.<br>
-<br>
- Also, tweak the comments in pdf_info.ps to reflect its new home.<br>
-<br>
-base/unixinst.mak<br>
-lib/pdf_info.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-12 14:26:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e39d57f23585b6fe71db5433dc205459be7a3c22">e39d57f23585b6fe71db5433dc205459be7a3c22</a>
-<blockquote>
-<p>
- Tweak to handle .shellarguments throwing an error<br>
-<br>
- .shellarguments for quite some time has thrown an undefined error if Ghostscript<br>
- is not invoked with the '--' option, so handle that.<br>
-<br>
-toolbin/pdf_info.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-12 14:16: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=72f6dd34cd0732cb7cdd9246d5063fc0f70ce79b">72f6dd34cd0732cb7cdd9246d5063fc0f70ce79b</a>
-<blockquote>
-<p>
- Add hex string representation of font names<br>
-<br>
- Mainly CIDFonts come up with multibyte characters in their names, hence making<br>
- the normal Postscript string pretty meaningless. This adds a hex string<br>
- representation which can be used in Fontmap.GS or cidfmap for subsitution.<br>
-<br>
-toolbin/pdf_info.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-12 13:07:46 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bcb6fb284fcbe776d9ddd44f98d196da7df2c054">bcb6fb284fcbe776d9ddd44f98d196da7df2c054</a>
-<blockquote>
-<p>
- Add NDEBUG to the optimised build flags<br>
-<br>
- Without that, asserts get included in an optimised build, which we don't want.<br>
-<br>
-base/unix-gcc.mak<br>
-base/unixansi.mak<br>
-configure.ac<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-10 15:37: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=044848a1752273471e9deab826045eca82030d62">044848a1752273471e9deab826045eca82030d62</a>
-<blockquote>
-<p>
- Reinstate basic regular expression compatibility<br>
-<br>
- In Basic Regular Expressions `+' is an ordinary character, use `*' instead.<br>
-<br>
- This also maintains consistency with the equivalent code a few lines above in<br>
- the file.<br>
-<br>
-jbig2dec/autogen.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-09 03:00:42 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=35828fce7ad795c546831520b7a57ef233453b43">35828fce7ad795c546831520b7a57ef233453b43</a>
-<blockquote>
-<p>
- txtwrite - don't close the device on media size changes<br>
-<br>
- Bug #701971 &quot;txtwrite incomplete for certain files and differs when stdout versus file is output&quot;<br>
-<br>
- The problem is nothing to do with stdout vs file. The difference is due<br>
- to the fact that the input PDF file has multiple pages with different<br>
- media sizes. When the media size is changed the default put_params()<br>
- method closes and reopens the device. When the txtwrite device is<br>
- closed it closes its output file. Re-opening the device opens a new<br>
- file, if the filename doesn not have a %d then the sam file is opened<br>
- which will of course truncate it.<br>
-<br>
- Writing to stdout obviously doesn't have this behaviour when the output<br>
- file is closed.<br>
-<br>
- We don't need to close the txtwrite device when the media size changes<br>
- so here we patch the 'is_open' flag to prevent the default method<br>
- from closing the device.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-06 21:45: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=b46142c94bde32f620bda18e3bc5912fbf999446">b46142c94bde32f620bda18e3bc5912fbf999446</a>
-<blockquote>
-<p>
- Bug 701973: Fix gssprintf.c includes for PRI macros<br>
-<br>
- The header inclusion in gssprintf.c meant the definitions of the PRI macros<br>
- for string formatting could be inconsistent with other source files.<br>
-<br>
- Adding the appropriate headers in the correct order resolves that issue.<br>
-<br>
-base/gssprintf.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-06 21:44:13 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a4c78f01d9a1bd9862b575f33aa48afddd167005">a4c78f01d9a1bd9862b575f33aa48afddd167005</a>
-<blockquote>
-<p>
- Fix configure based build for post-Sun Solaris releases<br>
-<br>
-base/stdint_.h<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-07 15:02: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=3bf992e26006c8af9e137822159eb7c7540462c0">3bf992e26006c8af9e137822159eb7c7540462c0</a>
-<blockquote>
-<p>
- PDF interpreter - Accept /ColorSpace as well as /CS in group attribute dictionary<br>
-<br>
- Again, no bug report, the customer has asked that the file be kept<br>
- confidential<br>
-<br>
- The problem is due to a group attribute dictionary for an SMask. The<br>
- dictionary is required to contain a /CS (colour space) entry in order<br>
- to correctly set the background. In this case, however, the dictionary<br>
- contains a /ColorSpace entry.<br>
-<br>
- I've chosen to implement treating the /ColorSpace as a /CS entry, this<br>
- is not what Acrobat does, but mimicking Acrobat's behaviour is more or<br>
- less impossible for us. We do emit a warning.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-06 18:43:28 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=539fe73419fdf00ffd7747a2cf890e56bc6f0504">539fe73419fdf00ffd7747a2cf890e56bc6f0504</a>
-<blockquote>
-<p>
- PDF interpreter - cope with legal but sub-optimal indirect /Pattern<br>
-<br>
- No bug, the report is from a customer who wants the file to be treated<br>
- confidentially.<br>
-<br>
- The files uses a Pattern colour space, which it defines in a highly<br>
- peculiar fashion:<br>
-<br>
- stream<br>
- ....<br>
- /CS0 cs /P0 scn<br>
-<br>
- ....<br>
- endstream<br>
-<br>
- CS0 is defined as:<br>
- /CS0 22 0 R<br>
-<br>
- and object 22 is:<br>
-<br>
- 22 0 obj<br>
- [ 23 0 R ]<br>
- endobj<br>
-<br>
- 23 0 obj<br>
- /Pattern<br>
- endobj<br>
-<br>
- The PDF interpreter wasn't prepared to handle the name being an indirect<br>
- reference.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 09:54:53 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5dfca9b93a17806e11d54068a6e5b9705f3b6bc6">5dfca9b93a17806e11d54068a6e5b9705f3b6bc6</a>
-<blockquote>
-<p>
- Fix problem with setup_trans being undone by grestore<br>
-<br>
- Noticed with text from Bug688728.pdf, but the offending method was<br>
- also an issue with 'sh' and 'image' operations where the setup_trans<br>
- invocation was withing a gsave ... grestore. The BlendMode and other<br>
- graphics state parameters would be reset by the grestore.<br>
-<br>
- Also some places could get errors from pathbbox and/or strokepath<br>
- due to a non-invertable matrix, so errors from these now just emit<br>
- an empty bbox [ 0 0 0 0 ].<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-Resource/Init/pdf_main.ps<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-05 12:50:26 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fbd776580b26bdf27bcf5778dea94b446c786f67">fbd776580b26bdf27bcf5778dea94b446c786f67</a>
-<blockquote>
-<p>
- Coverity ID 351435: reduce buffer size passed to strncat()<br>
-<br>
- Fixes an (unlikely) potential buffer overflow<br>
-<br>
-base/gp_unix.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-04 12:23: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=53ab3ecee8a60d412c2bf1406340bf9cb228e106">53ab3ecee8a60d412c2bf1406340bf9cb228e106</a>
-<blockquote>
-<p>
- Bug 701969: Fix fontconfig path permissions handling<br>
-<br>
- The paths from fontconfig to be added to the permit file reading list was not<br>
- having the trailing directory separator added to indicate we want to allow<br>
- the directory to be read.<br>
-<br>
- Also, tweak the path/filename splitting (for the permit file read list) when<br>
- parsing the cidfmap so it matches the improved version in gs_fonts.ps<br>
-<br>
-Resource/Init/gs_cidfm.ps<br>
-base/gp_unix.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-02 18:24:09 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c25d59001421845d0ff74735388d450d62b459d5">c25d59001421845d0ff74735388d450d62b459d5</a>
-<blockquote>
-<p>
- PDF interpreter - improve /Polygon annotation appearance creation<br>
-<br>
- Bug #701889 &quot;Annotation objects missing or incorrectly interpreted when appearance missing&quot;<br>
-<br>
- Another case of failing to stroke the border of an annotation if it had<br>
- no interior colour. We still don't support the 'Cloudy' Border Effect.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-02 17:59:34 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=11f6202373fc546cc10d08acfb5ca0463df20437">11f6202373fc546cc10d08acfb5ca0463df20437</a>
-<blockquote>
-<p>
- PDF interpreter - generate callout (/CL) lines for FreeText annots<br>
-<br>
- Bug #701889 &quot;Annotation objects missing or incorrectly interpreted when appearance is missing&quot;<br>
-<br>
- FreeText annotations can have a /CL (callout) entry, which defines a<br>
- line to be drawn to the point referenced by the text.<br>
-<br>
- This is a first pass at the problem, Acrobat generates arrow heads for<br>
- the callout lines, this patch does not.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-02 17:19: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=182e228cee6b30c6e2f00d8abd20a6791d44323f">182e228cee6b30c6e2f00d8abd20a6791d44323f</a>
-<blockquote>
-<p>
- PDF interpreter - improve /Square annotation appearance creation<br>
-<br>
- Bug #701889 &quot;Annotation objects missing or incorrectly interpreted when appearance stream missing&quot;<br>
-<br>
- First of probably several changes. In this case we were failing to<br>
- stroke the border of a /Square annotation if it had no interior colour<br>
- (we did not render the annotation at all).<br>
-<br>
- In addition, when element 3 of the Border array was 0 we were still<br>
- drawing a Border, which we should not do (this didn't show up until we<br>
- fixed the problem above).<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-01 22:04: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=c535c0c879162ccd7c88c5b8cc6c3a0847c0babe">c535c0c879162ccd7c88c5b8cc6c3a0847c0babe</a>
-<blockquote>
-<p>
- Create devdevs.tr correctly<br>
-<br>
- devdevs.tr is an interim list of output and core library &quot;devs&quot; that gets<br>
- created and then used, ultimately, to create the gconfig.h header file<br>
- (which has the bulid configuration of the graphics library), and the linker<br>
- scripts.<br>
-<br>
- When devdevs.tr required creation, we were always appending to the file (if it<br>
- already existed), not overwriting it, meaning the list would grow indefinitely,<br>
- and contain duplicates.<br>
-<br>
- This looks like a typo: the first line of devdevs.tr creation used a '-a'<br>
- echogs paramater, rather than the '-w' parameter.<br>
-<br>
- I think this should solve the problem.<br>
-<br>
-base/gs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-12-01 21:55: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=aa4fa650fa837a6f7b22caad33699bbbf9156bc1">aa4fa650fa837a6f7b22caad33699bbbf9156bc1</a>
-<blockquote>
-<p>
- Bug 701957: Explicitly disable webp and ztsd for libtiff<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-29 08:42:15 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c2b492ad627bdcb476fa3cd15a1c31cc3b6b788d">c2b492ad627bdcb476fa3cd15a1c31cc3b6b788d</a>
-<blockquote>
-<p>
- Fix typo (inadvertent paste) in devices/gdevjbig2.c from f63270230 commit<br>
-<br>
-devices/gdevjbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-29 14:40:47 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8636935ac086f56464f0541ed735f1016f2c3895">8636935ac086f56464f0541ed735f1016f2c3895</a>
-<blockquote>
-<p>
- Coverity 94659: removed cp_num - was allocated but never actually used.<br>
-<br>
-contrib/opvp/gdevopvp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-29 14:35:25 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a3f284624a68dcb1ecb72dcf307b42d194e78de1">a3f284624a68dcb1ecb72dcf307b42d194e78de1</a>
-<blockquote>
-<p>
- Coverity 94653: fixed incorrect if() that was logically dead code.<br>
-<br>
-contrib/lips4/gdevl4v.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-29 14:15:57 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ff02f8741f71830e7a4795645680a16b9d7ae106">ff02f8741f71830e7a4795645680a16b9d7ae106</a>
-<blockquote>
-<p>
- Coverity 94652: return error from opvp_image_plane_data() rather than segv.<br>
-<br>
-contrib/opvp/gdevopvp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-29 12:40:02 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f977255de00bb71f5c2627b8692912bb3263ee48">f977255de00bb71f5c2627b8692912bb3263ee48</a>
-<blockquote>
-<p>
- Coverity 94645: added '/* Fall through. */ comments to switch statements.<br>
-<br>
- This should convince Coverity that the fall-through's are intentional.<br>
-<br>
-contrib/lips4/gdevl4r.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-29 12:38:10 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f877f5bc792206085f9edf4143983d4156fb3ae5">f877f5bc792206085f9edf4143983d4156fb3ae5</a>
-<blockquote>
-<p>
- Coverity 94638: added '/* Fall through. */ comments to switch statements.<br>
-<br>
- This should convince Coverity that the fall-through's are intentional.<br>
-<br>
-contrib/gdevmd2k.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-29 12:33:51 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39286afa21126c193fcd0f3ccc0800f7c0662ed0">39286afa21126c193fcd0f3ccc0800f7c0662ed0</a>
-<blockquote>
-<p>
- Coverity 94616: added '/* Fall through. */ comments to switch statements<br>
-<br>
- This should convince Coverity that the fall-through's are intentional.<br>
-<br>
-contrib/gdevgdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-29 12:30:57 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c899fc1100f21f6e24096375e2daac26b23f33b">1c899fc1100f21f6e24096375e2daac26b23f33b</a>
-<blockquote>
-<p>
- Coverity 94608: added '/* Fall through. */ comments to switch statements.<br>
-<br>
- This should convince Coverity that the fall-through's are intentional.<br>
-<br>
-contrib/lips4/gdevl4v.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-29 12:10:19 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=adbf399b79b3e6b645e98acd53f42f9fd5ca9174">adbf399b79b3e6b645e98acd53f42f9fd5ca9174</a>
-<blockquote>
-<p>
- Coverity 94601: avoid out-of-bounds access of gendata-&gt;dev-&gt;hoffset[] if newhead &lt; 0.<br>
-<br>
-contrib/gdevlx32.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-29 11:41:05 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d04fe90a4c3b82e1286a1b341cdb89a96625715">1d04fe90a4c3b82e1286a1b341cdb89a96625715</a>
-<blockquote>
-<p>
- Coverity 94490: check return codes in opvp_fill_mask().<br>
-<br>
-contrib/opvp/gdevopvp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-28 18:26:56 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fbd78a0467afb2c66a41d55ee9b3aee0a7a01d7b">fbd78a0467afb2c66a41d55ee9b3aee0a7a01d7b</a>
-<blockquote>
-<p>
- Coverity 94511: Use full range of frac when source is 8-bit.<br>
-<br>
- Essentially we use frac2byte() and byte2frac(), instead of frac2cv() and<br>
- cv2frac(). This ensures we use full range of frac with the transfer fns.<br>
-<br>
- Note that this change is untested. It is based on observation and discussion<br>
- between gs develpoers. This code has not been modified since initial import.<br>
-<br>
-contrib/opvp/gdevopvp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-28 17:00:08 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a537e5bd4252abdbdc3f90dfdce8dc9fb621b38d">a537e5bd4252abdbdc3f90dfdce8dc9fb621b38d</a>
-<blockquote>
-<p>
- Coverity 94505: converted macros into static fns.<br>
-<br>
- This should avoid Coverity worrying about bits 8-15 always being zero in a call<br>
- of write_short().<br>
-<br>
-contrib/gdevmd2k.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-28 16:34:49 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=35e0c3f70ba2646b4bdfb41663a708a8594eeb68">35e0c3f70ba2646b4bdfb41663a708a8594eeb68</a>
-<blockquote>
-<p>
- Coverity 94553: fixed possible copy&amp;paste error in lips4_image_out().<br>
-<br>
- Use Len_rle instead of Len inside RLE block.<br>
-<br>
-contrib/lips4/gdevl4r.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-28 16:08:23 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=792c922fc83aed63090fb37ffc823e75ec8f9c5c">792c922fc83aed63090fb37ffc823e75ec8f9c5c</a>
-<blockquote>
-<p>
- Coverity 95077: fixed various scan-build issues with contrib/japanese/gdevmjc.c.<br>
-<br>
- Some of these will correspond to coverity issues also.<br>
-<br>
-contrib/japanese/gdevmjc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-28 15:44:05 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=efff831b1f3a00c69a32b4edd48614d583f9034a">efff831b1f3a00c69a32b4edd48614d583f9034a</a>
-<blockquote>
-<p>
- Coverity 95077: removed unused assignment to &lt;H&gt; variable.<br>
-<br>
-contrib/japanese/gdevmjc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-28 12:05:43 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=94190ff3e48c36a8538a3aba252e2b56909f6984">94190ff3e48c36a8538a3aba252e2b56909f6984</a>
-<blockquote>
-<p>
- Coverity 95034: avoid warnings about ignoring return from gs_note_error().<br>
-<br>
-contrib/pcl3/src/gdevpcl3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-28 11:32:14 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c9f669385954f205d395cbacb2b611d659b3ebf9">c9f669385954f205d395cbacb2b611d659b3ebf9</a>
-<blockquote>
-<p>
- Coverity 350199: add '-tainted_data_return' annotation.<br>
-<br>
- This makes this annotation match what has worked elsewhere.<br>
-<br>
-base/scfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-28 14:36:52 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fd2b1946fe5a4a8c029324c15f9bd606a489f543">fd2b1946fe5a4a8c029324c15f9bd606a489f543</a>
-<blockquote>
-<p>
- Include the source file libtiff webp compression support<br>
-<br>
- If the webp lib is available, it could cause linker failures if we don't<br>
- include the source file.<br>
-<br>
-base/tiff.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-28 11:29: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=874ef8cf7f0af2efae3d7fb6598013be5d277384">874ef8cf7f0af2efae3d7fb6598013be5d277384</a>
-<blockquote>
-<p>
- Enable jpeg support in libtiff if possible<br>
-<br>
-base/tiff.mak<br>
-configure.ac<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-27 15:29:04 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=15f3faeffff7d1b2658b824262314091f7af088b">15f3faeffff7d1b2658b824262314091f7af088b</a>
-<blockquote>
-<p>
- Coverity 95034: move code so that we have one less call to pcl_cm_is_differential().<br>
-<br>
- fixes scan-build issue, e.g.:<br>
- scan-build -o ../scan-build-out make sanitize<br>
-<br>
-contrib/pcl3/src/gdevpcl3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-27 15:27:25 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6e8c15137a70012776c1b163d7480e1a2cc7c61b">6e8c15137a70012776c1b163d7480e1a2cc7c61b</a>
-<blockquote>
-<p>
- Coverity 95034: removed use of guard() macro.<br>
-<br>
- Instead use static fn to convert error codes, with explicit inline code.<br>
-<br>
-contrib/pcl3/src/gdevpcl3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-27 14:29:41 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7e1c4da27805ab9b545bc8ab5b0747c37b69454c">7e1c4da27805ab9b545bc8ab5b0747c37b69454c</a>
-<blockquote>
-<p>
- Coverity 95034: refactor pcl3_print_page() to avoid leaks.<br>
-<br>
-contrib/pcl3/src/gdevpcl3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-27 13:11:29 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1df794e69d9f29dae215e50cf328ccad40fe29e8">1df794e69d9f29dae215e50cf328ccad40fe29e8</a>
-<blockquote>
-<p>
- Coverity 95027: fix off-by-one when bounds-checking against LIPS_MEDIACHAR_MAX.<br>
-<br>
-contrib/lips4/gdevl4r.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-27 12:52:17 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e9ccb4139c5f3fb89a5f4d6554e73323dbf73641">e9ccb4139c5f3fb89a5f4d6554e73323dbf73641</a>
-<blockquote>
-<p>
- Coverity 94957: Call dlclose() to avoid leaks of handles from dlopen().<br>
-<br>
-contrib/opvp/gdevopvp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-27 11:39:28 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e4dcc70672b447df52b0a3c7976ab6ece280841e">e4dcc70672b447df52b0a3c7976ab6ece280841e</a>
-<blockquote>
-<p>
- Coverity 350199: mark cf_encode_1d() as not tainting lbuf.<br>
-<br>
- This may work better than the previous annotation.<br>
-<br>
-base/scfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-26 12:04:54 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=334132f45320ef35b54032c053c100d07e02ec98">334132f45320ef35b54032c053c100d07e02ec98</a>
-<blockquote>
-<p>
- Fix problems seen with m8510 device and improve gdev_prn_copy_scan_lines<br>
-<br>
- Previous patch made this device pay attention to return code from the<br>
- gdev_prn_copy_scan_lines, which caused the all_devices test to get an error.<br>
-<br>
- Also this device would get an ioerror if the page width was not a multiple<br>
- of 8. Fix m8510_output_run to round up when setting out_end, bullet proof<br>
- check of count so we don't try and print with a negative count.<br>
-<br>
- Also fix gdev_prn_copy_scan_lines to return count == 0 if the starting<br>
- line is past the end of the page, and fill lines past end of page with<br>
- zeroes if the count did not fill it (or if there was an error from<br>
- gdev_prn_get_bits).<br>
-<br>
-base/gdevprn.c<br>
-devices/gdev8510.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-26 14:43:58 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23b4705f975ee0d4288ad47e62ffb8737ced48a8">23b4705f975ee0d4288ad47e62ffb8737ced48a8</a>
-<blockquote>
-<p>
- GPDL PNG support<br>
-<br>
-gpdl/gpdl.mak<br>
-gpdl/jp2ktop.c<br>
-gpdl/pngtop.c<br>
-pcl/pl/plimpl.c<br>
-windows/ghostpdl.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-26 14:35:05 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b772aaf901a3cd37baf5c06eb141c689829bf673">b772aaf901a3cd37baf5c06eb141c689829bf673</a>
-<blockquote>
-<p>
- Bug 701949: Add 'omitEOD' flag to RLE compressor and use for PXL.<br>
-<br>
- It turns out that some printers (Samsung ML-2250 and Canon<br>
- ImageRunner iRC2380i at least) object to the EOD byte appearing<br>
- in RLE data in PXL streams.<br>
-<br>
- Ken kindly checked the PXL spec for me, and found that: &quot;The PXL<br>
- spec does say a control code of -128 is ignored and not included<br>
- in the decompressed data and the byte following a control byte<br>
- of 128 (I assume they mean -128 here) is treated as the next<br>
- control byte. And PCL only uses RLE data for images, so they do<br>
- know how much data they expect.&quot;<br>
-<br>
- Thus, the conclusion we reached is that PCL/PXL don't need<br>
- (indeed, really does not want) the EOD byte.<br>
-<br>
- The Postscript spec clearly defines the EOD byte though. Rather<br>
- than break the streams for postscript, we introduce a flag<br>
- 'omitEOD' that can be set for the encoder when we want to produce<br>
- a stream for use with PCL/PXL.<br>
-<br>
-base/srle.c<br>
-base/srlx.h<br>
-devices/vector/gdevpx.c<br>
-psi/zfilter.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-27 13:27: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=c9ed069d86f291dc3118ee96f76765432ac478e3">c9ed069d86f291dc3118ee96f76765432ac478e3</a>
-<blockquote>
-<p>
- Update thirdparty.htm to reflect updated libs<br>
-<br>
-doc/thirdparty.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-26 14:39: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=79ac3f84060fbd5447219264ab0bcf89c7caa2cf">79ac3f84060fbd5447219264ab0bcf89c7caa2cf</a>
-<blockquote>
-<p>
- Update Freetype to 2.4.10<br>
-<br>
- Plus makefile updates to support it<br>
-<br>
- Bug 701288: Handle SEAC ligature glyph metrics correctly.<br>
-<br>
- As originally intended, a Type 1 SEAC charstring would be used for an accented<br>
- glyph (like an a-caron, or u-umlaut) where the advance with of the SEAC glyph<br>
- is the same as that of the 'base' glyph ('a' or 'u').<br>
-<br>
- It this case, it is not uncommon for the SEAC to skip using an (H)SBW op code<br>
- and rely on the one from the base glyph.<br>
-<br>
- But out of spec fonts also use SEAC glyphs ligature glyphs (like 'oe' or 'fi'),<br>
- and in those cases the overall advance width is greater than that of the 'base'<br>
- glyph.<br>
-<br>
- In this case, we have to allow for the SEAC glyph having included an (H)SBW and<br>
- if it has, retain those values, rather than those from the base glyph.<br>
-<br>
- Rename file and make file change to match<br>
-<br>
- Avoids file name clash with freetype 2.4.10<br>
-<br>
- Work around a change in the zlib API for 1.2.11<br>
-<br>
- where it's used in the Freetype/zlib interface debugging code.<br>
-<br>
-base/freetype.mak<br>
-base/lcupsi.mak<br>
-cups/libs/filter/cupsraster.c<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/ChangeLog.29<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/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/README<br>
-freetype/builds/mac/freetype-Info.plist<br>
-freetype/builds/mac/ftmac.c<br>
-freetype/builds/modules.mk<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.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-sh<br>
-freetype/builds/unix/install.mk<br>
-freetype/builds/unix/ltmain.sh<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/LIBS.OPT_IA64<br>
-freetype/builds/vms/_LINK.OPT_IA64<br>
-freetype/builds/vms/ftconfig.h<br>
-freetype/builds/vms/ftsystem.c<br>
-freetype/builds/vms/vmslib.dat<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.sln<br>
-freetype/builds/windows/vc2005/freetype.vcproj<br>
-freetype/builds/windows/vc2005/index.html<br>
-freetype/builds/windows/vc2008/freetype.sln<br>
-freetype/builds/windows/vc2008/freetype.vcproj<br>
-freetype/builds/windows/vc2008/index.html<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.sln<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/DOCGUIDE<br>
-freetype/docs/INSTALL<br>
-freetype/docs/INSTALL.ANY<br>
-freetype/docs/INSTALL.CROSS<br>
-freetype/docs/INSTALL.GNU<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/README<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/reference/site/404.html<br>
-freetype/docs/reference/site/assets/fonts/font-awesome.css<br>
-freetype/docs/reference/site/assets/fonts/material-icons.css<br>
-freetype/docs/reference/site/assets/fonts/specimen/FontAwesome.ttf<br>
-freetype/docs/reference/site/assets/fonts/specimen/FontAwesome.woff<br>
-freetype/docs/reference/site/assets/fonts/specimen/FontAwesome.woff2<br>
-freetype/docs/reference/site/assets/fonts/specimen/MaterialIcons-Regular.ttf<br>
-freetype/docs/reference/site/assets/fonts/specimen/MaterialIcons-Regular.woff<br>
-freetype/docs/reference/site/assets/fonts/specimen/MaterialIcons-Regular.woff2<br>
-freetype/docs/reference/site/assets/images/favicon.png<br>
-freetype/docs/reference/site/assets/images/icons/bitbucket.1b09e088.svg<br>
-freetype/docs/reference/site/assets/images/icons/github.f0b8504a.svg<br>
-freetype/docs/reference/site/assets/images/icons/gitlab.6dd19c00.svg<br>
-freetype/docs/reference/site/assets/javascripts/application.d9aa80ab.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.da.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.de.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.du.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.es.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.fi.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.fr.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.hu.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.it.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.ja.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.jp.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.multi.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.nl.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.no.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.pt.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.ro.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.ru.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.stemmer.support.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.sv.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.th.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/lunr.tr.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/tinyseg.js<br>
-freetype/docs/reference/site/assets/javascripts/lunr/wordcut.js<br>
-freetype/docs/reference/site/assets/javascripts/modernizr.1f0bcf2b.js<br>
-freetype/docs/reference/site/assets/stylesheets/application-palette.224b79ff.css<br>
-freetype/docs/reference/site/assets/stylesheets/application.982221ab.css<br>
-freetype/docs/reference/site/ft2-auto_hinter.html<br>
-freetype/docs/reference/site/ft2-base_interface.html<br>
-freetype/docs/reference/site/ft2-basic_types.html<br>
-freetype/docs/reference/site/ft2-bdf_fonts.html<br>
-freetype/docs/reference/site/ft2-bitmap_handling.html<br>
-freetype/docs/reference/site/ft2-bzip2.html<br>
-freetype/docs/reference/site/ft2-cache_subsystem.html<br>
-freetype/docs/reference/site/ft2-cff_driver.html<br>
-freetype/docs/reference/site/ft2-cid_fonts.html<br>
-freetype/docs/reference/site/ft2-color_management.html<br>
-freetype/docs/reference/site/ft2-computations.html<br>
-freetype/docs/reference/site/ft2-error_code_values.html<br>
-freetype/docs/reference/site/ft2-error_enumerations.html<br>
-freetype/docs/reference/site/ft2-font_formats.html<br>
-freetype/docs/reference/site/ft2-gasp_table.html<br>
-freetype/docs/reference/site/ft2-glyph_management.html<br>
-freetype/docs/reference/site/ft2-glyph_stroker.html<br>
-freetype/docs/reference/site/ft2-glyph_variants.html<br>
-freetype/docs/reference/site/ft2-gx_validation.html<br>
-freetype/docs/reference/site/ft2-gzip.html<br>
-freetype/docs/reference/site/ft2-header_file_macros.html<br>
-freetype/docs/reference/site/ft2-header_inclusion.html<br>
-freetype/docs/reference/site/ft2-incremental.html<br>
-freetype/docs/reference/site/ft2-index.html<br>
-freetype/docs/reference/site/ft2-layer_management.html<br>
-freetype/docs/reference/site/ft2-lcd_rendering.html<br>
-freetype/docs/reference/site/ft2-list_processing.html<br>
-freetype/docs/reference/site/ft2-lzw.html<br>
-freetype/docs/reference/site/ft2-mac_specific.html<br>
-freetype/docs/reference/site/ft2-module_management.html<br>
-freetype/docs/reference/site/ft2-multiple_masters.html<br>
-freetype/docs/reference/site/ft2-ot_validation.html<br>
-freetype/docs/reference/site/ft2-outline_processing.html<br>
-freetype/docs/reference/site/ft2-parameter_tags.html<br>
-freetype/docs/reference/site/ft2-pcf_driver.html<br>
-freetype/docs/reference/site/ft2-pfr_fonts.html<br>
-freetype/docs/reference/site/ft2-properties.html<br>
-freetype/docs/reference/site/ft2-quick_advance.html<br>
-freetype/docs/reference/site/ft2-raster.html<br>
-freetype/docs/reference/site/ft2-sfnt_names.html<br>
-freetype/docs/reference/site/ft2-sizes_management.html<br>
-freetype/docs/reference/site/ft2-system_interface.html<br>
-freetype/docs/reference/site/ft2-t1_cid_driver.html<br>
-freetype/docs/reference/site/ft2-truetype_engine.html<br>
-freetype/docs/reference/site/ft2-truetype_tables.html<br>
-freetype/docs/reference/site/ft2-tt_driver.html<br>
-freetype/docs/reference/site/ft2-type1_tables.html<br>
-freetype/docs/reference/site/ft2-user_allocation.html<br>
-freetype/docs/reference/site/ft2-version.html<br>
-freetype/docs/reference/site/ft2-winfnt_fonts.html<br>
-freetype/docs/reference/site/images/favico.ico<br>
-freetype/docs/reference/site/index.html<br>
-freetype/docs/reference/site/javascripts/extra.js<br>
-freetype/docs/reference/site/search/search_index.json<br>
-freetype/docs/reference/site/sitemap.xml<br>
-freetype/docs/reference/site/sitemap.xml.gz<br>
-freetype/docs/reference/site/stylesheets/extra.css<br>
-freetype/docs/release<br>
-freetype/include/freetype/config/ftconfig.h<br>
-freetype/include/freetype/config/ftheader.h<br>
-freetype/include/freetype/config/ftmodule.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/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/ftchapters.h<br>
-freetype/include/freetype/ftcid.h<br>
-freetype/include/freetype/ftcolor.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/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/fthash.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/internal/wofftypes.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/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/afangles.h<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/ftcolor.c<br>
-freetype/src/base/ftdbgmem.c<br>
-freetype/src/base/ftdebug.c<br>
-freetype/src/base/fterrors.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/fthash.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/bdf.h<br>
-freetype/src/bdf/bdfdrivr.c<br>
-freetype/src/bdf/bdfdrivr.h<br>
-freetype/src/bdf/bdferror.h<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/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/infblock.c<br>
-freetype/src/gzip/infcodes.c<br>
-freetype/src/gzip/inflate.c<br>
-freetype/src/gzip/rules.mk<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/pcf.h<br>
-freetype/src/pcf/pcfdrivr.c<br>
-freetype/src/pcf/pcfdrivr.h<br>
-freetype/src/pcf/pcferror.h<br>
-freetype/src/pcf/pcfread.c<br>
-freetype/src/pcf/pcfutil.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/sfwoff.c<br>
-freetype/src/sfnt/sfwoff.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/ttcolr.c<br>
-freetype/src/sfnt/ttcolr.h<br>
-freetype/src/sfnt/ttcpal.c<br>
-freetype/src/sfnt/ttcpal.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/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>2019-11-26 17:45:08 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36cbd382b160ee4951d1911f85a4fa0723dd8db3">36cbd382b160ee4951d1911f85a4fa0723dd8db3</a>
-<blockquote>
-<p>
- Update openjpeg to 2.3.1<br>
-<br>
-openjpeg/.gitignore<br>
-openjpeg/.travis.yml<br>
-openjpeg/CHANGELOG.md<br>
-openjpeg/INSTALL.md<br>
-openjpeg/NEWS.md<br>
-openjpeg/appveyor.yml<br>
-openjpeg/doc/Doxyfile.dox.cmake.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/CMakeLists.txt<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/image.c<br>
-openjpeg/src/lib/openjp2/j2k.c<br>
-openjpeg/src/lib/openjp2/jp2.c<br>
-openjpeg/src/lib/openjp2/openjpeg.h<br>
-openjpeg/src/lib/openjp2/opj_intmath.h<br>
-openjpeg/src/lib/openjp2/pi.c<br>
-openjpeg/src/lib/openjp2/t1.c<br>
-openjpeg/src/lib/openjp2/t2.c<br>
-openjpeg/src/lib/openjp2/tcd.c<br>
-openjpeg/src/lib/openjp2/thread.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-26 13:19: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=107babf6d3652ed9bcf26b20823ac935ba86634b">107babf6d3652ed9bcf26b20823ac935ba86634b</a>
-<blockquote>
-<p>
- Update expat to 2.2.9<br>
-<br>
- And small makefile tweak to support it.<br>
-<br>
-base/expat.mak<br>
-expat/CMake.README<br>
-expat/CMakeLists.txt<br>
-expat/Changes<br>
-expat/ConfigureChecks.cmake<br>
-expat/Makefile.am<br>
-expat/Makefile.in<br>
-expat/README.md<br>
-expat/acinclude.m4<br>
-expat/aclocal.m4<br>
-expat/cmake/expat-config.cmake.in<br>
-expat/cmake/mingw-toolchain.cmake<br>
-expat/configure<br>
-expat/configure.ac<br>
-expat/conftools/ac_c_bigendian_cross.m4<br>
-expat/conftools/ar-lib<br>
-expat/conftools/ax-append-compile-flags.m4<br>
-expat/conftools/ax-append-flag.m4<br>
-expat/conftools/ax-append-link-flags.m4<br>
-expat/conftools/ax-check-compile-flag.m4<br>
-expat/conftools/ax-check-link-flag.m4<br>
-expat/conftools/ax-require-defined.m4<br>
-expat/conftools/config.guess<br>
-expat/conftools/config.sub<br>
-expat/conftools/expatcfg-compiler-supports-visibility.m4<br>
-expat/conftools/install-sh<br>
-expat/conftools/ltmain.sh<br>
-expat/conftools/missing<br>
-expat/doc/Makefile.am<br>
-expat/doc/Makefile.in<br>
-expat/doc/reference.html<br>
-expat/examples/Makefile.in<br>
-expat/examples/elements.c<br>
-expat/examples/elements.vcxproj<br>
-expat/examples/elements.vcxproj.filters<br>
-expat/examples/outline.c<br>
-expat/examples/outline.vcxproj<br>
-expat/examples/outline.vcxproj.filters<br>
-expat/expat.sln<br>
-expat/expat_config.h<br>
-expat/expat_config.h.cmake<br>
-expat/expat_config.h.in<br>
-expat/fix-xmltest-log.sh<br>
-expat/lib/Makefile.am<br>
-expat/lib/Makefile.in<br>
-expat/lib/asciitab.h<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.vcxproj<br>
-expat/lib/expat_static.vcxproj.filters<br>
-expat/lib/expatw.vcxproj<br>
-expat/lib/expatw.vcxproj.filters<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/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/test-driver-wrapper.sh<br>
-expat/tests/Makefile.in<br>
-expat/tests/benchmark/Makefile.in<br>
-expat/tests/benchmark/benchmark.c<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/structdata.c<br>
-expat/tests/structdata.h<br>
-expat/tests/xmltest.sh<br>
-expat/win32/README.txt<br>
-expat/win32/build_expat_iss.bat<br>
-expat/win32/expat.iss<br>
-expat/xmlwf/Makefile.am<br>
-expat/xmlwf/Makefile.in<br>
-expat/xmlwf/codepage.c<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/xmltchar.h<br>
-expat/xmlwf/xmlurl.h<br>
-expat/xmlwf/xmlwf.c<br>
-expat/xmlwf/xmlwf.vcxproj<br>
-expat/xmlwf/xmlwf.vcxproj.filters<br>
-expat/xmlwf/xmlwf_helpgen.py<br>
-expat/xmlwf/xmlwf_helpgen.sh<br>
-expat/xmlwf/xmlwin32url.cxx<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-26 13:13:11 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f25387684b5df27653e7f89a67e04d6151b92d02">f25387684b5df27653e7f89a67e04d6151b92d02</a>
-<blockquote>
-<p>
- Update libpng to 1.6.37<br>
-<br>
-base/png.mak<br>
-libpng/ANNOUNCE<br>
-libpng/AUTHORS<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/TRADEMARK<br>
-libpng/aclocal.m4<br>
-libpng/arm/arm_init.c<br>
-libpng/arm/filter_neon.S<br>
-libpng/arm/filter_neon_intrinsics.c<br>
-libpng/arm/palette_neon_intrinsics.c<br>
-libpng/autogen.sh<br>
-libpng/compile<br>
-libpng/config.guess<br>
-libpng/config.h.in<br>
-libpng/config.sub<br>
-libpng/configure<br>
-libpng/configure.ac<br>
-libpng/contrib/conftest/pngcp.dfa<br>
-libpng/contrib/examples/iccfrompng.c<br>
-libpng/contrib/examples/pngpixel.c<br>
-libpng/contrib/gregbook/readpng2.c<br>
-libpng/contrib/libtests/makepng.c<br>
-libpng/contrib/libtests/pngimage.c<br>
-libpng/contrib/libtests/pngstest.c<br>
-libpng/contrib/libtests/pngunknown.c<br>
-libpng/contrib/libtests/pngvalid.c<br>
-libpng/contrib/libtests/readpng.c<br>
-libpng/contrib/libtests/tarith.c<br>
-libpng/contrib/libtests/timepng.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/newcc<br>
-libpng/contrib/pngminus/CHANGES.txt<br>
-libpng/contrib/pngminus/CMakeLists.txt<br>
-libpng/contrib/pngminus/LICENSE.txt<br>
-libpng/contrib/pngminus/Makefile<br>
-libpng/contrib/pngminus/README.txt<br>
-libpng/contrib/pngminus/makefile.std<br>
-libpng/contrib/pngminus/makefile.tc3<br>
-libpng/contrib/pngminus/png2pnm.bat<br>
-libpng/contrib/pngminus/png2pnm.c<br>
-libpng/contrib/pngminus/png2pnm.sh<br>
-libpng/contrib/pngminus/pngminus.bat<br>
-libpng/contrib/pngminus/pngminus.sh<br>
-libpng/contrib/pngminus/pnm2png.bat<br>
-libpng/contrib/pngminus/pnm2png.c<br>
-libpng/contrib/pngminus/pnm2png.sh<br>
-libpng/contrib/pngsuite/README<br>
-libpng/contrib/pngsuite/bad_interlace_conversions.txt<br>
-libpng/contrib/pngsuite/ibasn0g08.png<br>
-libpng/contrib/pngsuite/ibasn0g16.png<br>
-libpng/contrib/pngsuite/ibasn2c08.png<br>
-libpng/contrib/pngsuite/ibasn2c16.png<br>
-libpng/contrib/pngsuite/ibasn3p08.png<br>
-libpng/contrib/pngsuite/ibasn4a08.png<br>
-libpng/contrib/pngsuite/ibasn4a16.png<br>
-libpng/contrib/pngsuite/ibasn6a08.png<br>
-libpng/contrib/pngsuite/ibasn6a16.png<br>
-libpng/contrib/pngsuite/iftbbn2c16.png<br>
-libpng/contrib/pngsuite/iftbbn3p08.png<br>
-libpng/contrib/pngsuite/iftbgn2c16.png<br>
-libpng/contrib/pngsuite/iftbgn3p08.png<br>
-libpng/contrib/pngsuite/iftbrn2c08.png<br>
-libpng/contrib/pngsuite/iftbwn0g16.png<br>
-libpng/contrib/pngsuite/iftbwn3p08.png<br>
-libpng/contrib/pngsuite/iftbyn3p08.png<br>
-libpng/contrib/pngsuite/iftp0n0g08.png<br>
-libpng/contrib/pngsuite/iftp0n2c08.png<br>
-libpng/contrib/pngsuite/iftp0n3p08.png<br>
-libpng/contrib/pngsuite/iftp1n3p08.png<br>
-libpng/contrib/pngsuite/interlaced/README<br>
-libpng/contrib/pngsuite/interlaced/ibasn0g01.png<br>
-libpng/contrib/pngsuite/interlaced/ibasn0g02.png<br>
-libpng/contrib/pngsuite/interlaced/ibasn0g04.png<br>
-libpng/contrib/pngsuite/interlaced/ibasn3p01.png<br>
-libpng/contrib/pngsuite/interlaced/ibasn3p02.png<br>
-libpng/contrib/pngsuite/interlaced/ibasn3p04.png<br>
-libpng/contrib/pngsuite/interlaced/iftbbn0g01.png<br>
-libpng/contrib/pngsuite/interlaced/iftbbn0g02.png<br>
-libpng/contrib/pngsuite/interlaced/iftbbn0g04.png<br>
-libpng/contrib/powerpc-vsx/README<br>
-libpng/contrib/powerpc-vsx/linux_aux.c<br>
-libpng/contrib/testpngs/makepngs.sh<br>
-libpng/contrib/tools/chkfmt<br>
-libpng/contrib/tools/makesRGB.c<br>
-libpng/contrib/tools/pngcp.c<br>
-libpng/contrib/tools/pngfix.c<br>
-libpng/contrib/visupng/PngFile.c<br>
-libpng/contrib/visupng/PngFile.h<br>
-libpng/contrib/visupng/VisualPng.c<br>
-libpng/depcomp<br>
-libpng/example.c<br>
-libpng/install-sh<br>
-libpng/intel/filter_sse2_intrinsics.c<br>
-libpng/intel/intel_init.c<br>
-libpng/libpng-manual.txt<br>
-libpng/libpng.3<br>
-libpng/libpngpf.3<br>
-libpng/mips/filter_msa_intrinsics.c<br>
-libpng/mips/mips_init.c<br>
-libpng/missing<br>
-libpng/png.5<br>
-libpng/png.c<br>
-libpng/png.h<br>
-libpng/pngconf.h<br>
-libpng/pngdebug.h<br>
-libpng/pngerror.c<br>
-libpng/pngget.c<br>
-libpng/pnginfo.h<br>
-libpng/pngmem.c<br>
-libpng/pngpread.c<br>
-libpng/pngpriv.h<br>
-libpng/pngread.c<br>
-libpng/pngrio.c<br>
-libpng/pngrtran.c<br>
-libpng/pngrutil.c<br>
-libpng/pngset.c<br>
-libpng/pngstruct.h<br>
-libpng/pngtest.c<br>
-libpng/pngtrans.c<br>
-libpng/pngwio.c<br>
-libpng/pngwrite.c<br>
-libpng/pngwtran.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/visualc71/README.txt<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/descrip.mms<br>
-libpng/scripts/libpng-config-head.in<br>
-libpng/scripts/libpng.pc.in<br>
-libpng/scripts/makefile.32sunu<br>
-libpng/scripts/makefile.64sunu<br>
-libpng/scripts/makefile.bor<br>
-libpng/scripts/makefile.cegcc<br>
-libpng/scripts/makefile.clang<br>
-libpng/scripts/makefile.clang-asan<br>
-libpng/scripts/makefile.darwin<br>
-libpng/scripts/makefile.freebsd<br>
-libpng/scripts/makefile.gcc<br>
-libpng/scripts/makefile.gcc-asan<br>
-libpng/scripts/makefile.hp64<br>
-libpng/scripts/makefile.hpgcc<br>
-libpng/scripts/makefile.hpux<br>
-libpng/scripts/makefile.knr<br>
-libpng/scripts/makefile.linux<br>
-libpng/scripts/makefile.linux-opt<br>
-libpng/scripts/makefile.mips<br>
-libpng/scripts/makefile.msc<br>
-libpng/scripts/makefile.msys<br>
-libpng/scripts/makefile.ne12bsd<br>
-libpng/scripts/makefile.netbsd<br>
-libpng/scripts/makefile.openbsd<br>
-libpng/scripts/makefile.sco<br>
-libpng/scripts/makefile.sggcc<br>
-libpng/scripts/makefile.sgi<br>
-libpng/scripts/makefile.so9<br>
-libpng/scripts/makefile.solaris<br>
-libpng/scripts/makefile.solaris-x86<br>
-libpng/scripts/makefile.std<br>
-libpng/scripts/makefile.sunos<br>
-libpng/scripts/makefile.tc3<br>
-libpng/scripts/options.awk<br>
-libpng/scripts/pnglibconf.dfa<br>
-libpng/scripts/pnglibconf.h.prebuilt<br>
-libpng/scripts/symbols.def<br>
-libpng/test-driver<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-26 12:13:13 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9282c39e6150befd80793b3221864c9f1f814b66">9282c39e6150befd80793b3221864c9f1f814b66</a>
-<blockquote>
-<p>
- Update libtiff to 4.1.0<br>
-<br>
- Add in portability changes to tiffiop.h<br>
-<br>
- Portability tiffiop.h<br>
-<br>
- Remove globals from tif_pixarlog.c<br>
-<br>
-tiff/CMakeLists.txt<br>
-tiff/ChangeLog<br>
-tiff/HOWTO-RELEASE<br>
-tiff/Makefile.am<br>
-tiff/Makefile.in<br>
-tiff/Makefile.vc<br>
-tiff/README.md<br>
-tiff/README.vms<br>
-tiff/RELEASE-DATE<br>
-tiff/SConstruct<br>
-tiff/TODO<br>
-tiff/VERSION<br>
-tiff/aclocal.m4<br>
-tiff/build/Makefile.in<br>
-tiff/config/compile<br>
-tiff/config/config.guess<br>
-tiff/config/config.sub<br>
-tiff/config/depcomp<br>
-tiff/config/install-sh<br>
-tiff/config/ltmain.sh<br>
-tiff/config/missing<br>
-tiff/config/mkinstalldirs<br>
-tiff/config/test-driver<br>
-tiff/configure<br>
-tiff/configure.ac<br>
-tiff/configure.com<br>
-tiff/contrib/Makefile.in<br>
-tiff/contrib/addtiffo/Makefile.in<br>
-tiff/contrib/addtiffo/addtiffo.c<br>
-tiff/contrib/addtiffo/tif_overview.c<br>
-tiff/contrib/addtiffo/tif_ovrcache.c<br>
-tiff/contrib/dbs/Makefile.in<br>
-tiff/contrib/dbs/tiff-bi.c<br>
-tiff/contrib/dbs/tiff-grayscale.c<br>
-tiff/contrib/dbs/tiff-palette.c<br>
-tiff/contrib/dbs/tiff-rgb.c<br>
-tiff/contrib/dbs/xtiff/Makefile.in<br>
-tiff/contrib/dbs/xtiff/xtiff.c<br>
-tiff/contrib/iptcutil/Makefile.in<br>
-tiff/contrib/iptcutil/iptcutil.c<br>
-tiff/contrib/mfs/Makefile.in<br>
-tiff/contrib/pds/Makefile.in<br>
-tiff/contrib/pds/README<br>
-tiff/contrib/pds/tif_imageiter.c<br>
-tiff/contrib/pds/tif_imageiter.h<br>
-tiff/contrib/pds/tif_pdsdirread.c<br>
-tiff/contrib/pds/tif_pdsdirwrite.c<br>
-tiff/contrib/ras/Makefile.in<br>
-tiff/contrib/ras/tif2ras.c<br>
-tiff/contrib/stream/Makefile.in<br>
-tiff/contrib/tags/Makefile.in<br>
-tiff/contrib/tags/README<br>
-tiff/contrib/tags/xtif_dir.c<br>
-tiff/contrib/win_dib/Makefile.in<br>
-tiff/contrib/win_dib/Makefile.w95<br>
-tiff/contrib/win_dib/README.tiff2dib<br>
-tiff/contrib/win_dib/Tiffile.cpp<br>
-tiff/html/Makefile.am<br>
-tiff/html/Makefile.in<br>
-tiff/html/addingtags.html<br>
-tiff/html/bugs.html<br>
-tiff/html/build.html<br>
-tiff/html/document.html<br>
-tiff/html/images.html<br>
-tiff/html/images/Makefile.in<br>
-tiff/html/index.html<br>
-tiff/html/libtiff.html<br>
-tiff/html/man/Makefile.in<br>
-tiff/html/man/TIFFReadDirectory.3tiff.html<br>
-tiff/html/man/TIFFWriteDirectory.3tiff.html<br>
-tiff/html/man/TIFFmemory.3tiff.html<br>
-tiff/html/v3.4beta007.html<br>
-tiff/html/v3.4beta016.html<br>
-tiff/html/v3.4beta018.html<br>
-tiff/html/v3.4beta024.html<br>
-tiff/html/v3.4beta028.html<br>
-tiff/html/v3.4beta029.html<br>
-tiff/html/v3.4beta031.html<br>
-tiff/html/v3.4beta032.html<br>
-tiff/html/v3.4beta033.html<br>
-tiff/html/v3.4beta034.html<br>
-tiff/html/v3.4beta035.html<br>
-tiff/html/v3.4beta036.html<br>
-tiff/html/v3.5.1.html<br>
-tiff/html/v3.5.2.html<br>
-tiff/html/v3.5.3.html<br>
-tiff/html/v3.5.4.html<br>
-tiff/html/v3.5.5.html<br>
-tiff/html/v3.5.6-beta.html<br>
-tiff/html/v3.5.7.html<br>
-tiff/html/v3.6.0.html<br>
-tiff/html/v3.6.1.html<br>
-tiff/html/v3.7.0.html<br>
-tiff/html/v3.7.0alpha.html<br>
-tiff/html/v3.7.0beta.html<br>
-tiff/html/v3.7.0beta2.html<br>
-tiff/html/v3.7.1.html<br>
-tiff/html/v3.7.2.html<br>
-tiff/html/v3.7.3.html<br>
-tiff/html/v3.7.4.html<br>
-tiff/html/v3.8.0.html<br>
-tiff/html/v3.8.1.html<br>
-tiff/html/v3.8.2.html<br>
-tiff/html/v3.9.0beta.html<br>
-tiff/html/v3.9.1.html<br>
-tiff/html/v3.9.2.html<br>
-tiff/html/v4.0.0.html<br>
-tiff/html/v4.0.1.html<br>
-tiff/html/v4.0.10.html<br>
-tiff/html/v4.0.2.html<br>
-tiff/html/v4.0.3.html<br>
-tiff/html/v4.0.4.html<br>
-tiff/html/v4.0.4beta.html<br>
-tiff/html/v4.0.5.html<br>
-tiff/html/v4.0.6.html<br>
-tiff/html/v4.0.7.html<br>
-tiff/html/v4.0.8.html<br>
-tiff/html/v4.0.9.html<br>
-tiff/html/v4.1.0.html<br>
-tiff/libtiff/CMakeLists.txt<br>
-tiff/libtiff/Makefile.am<br>
-tiff/libtiff/Makefile.in<br>
-tiff/libtiff/Makefile.vc<br>
-tiff/libtiff/SConstruct<br>
-tiff/libtiff/libtiff.def<br>
-tiff/libtiff/mkg3states.c<br>
-tiff/libtiff/t4.h<br>
-tiff/libtiff/tif_aux.c<br>
-tiff/libtiff/tif_close.c<br>
-tiff/libtiff/tif_codec.c<br>
-tiff/libtiff/tif_color.c<br>
-tiff/libtiff/tif_compress.c<br>
-tiff/libtiff/tif_config.h.cmake.in<br>
-tiff/libtiff/tif_config.h.in<br>
-tiff/libtiff/tif_config.wince.h<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_dumpmode.c<br>
-tiff/libtiff/tif_error.c<br>
-tiff/libtiff/tif_extension.c<br>
-tiff/libtiff/tif_fax3.c<br>
-tiff/libtiff/tif_fax3.h<br>
-tiff/libtiff/tif_flush.c<br>
-tiff/libtiff/tif_getimage.c<br>
-tiff/libtiff/tif_jbig.c<br>
-tiff/libtiff/tif_jpeg.c<br>
-tiff/libtiff/tif_luv.c<br>
-tiff/libtiff/tif_lzma.c<br>
-tiff/libtiff/tif_lzw.c<br>
-tiff/libtiff/tif_next.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_predict.h<br>
-tiff/libtiff/tif_print.c<br>
-tiff/libtiff/tif_read.c<br>
-tiff/libtiff/tif_stream.cxx<br>
-tiff/libtiff/tif_strip.c<br>
-tiff/libtiff/tif_swab.c<br>
-tiff/libtiff/tif_thunder.c<br>
-tiff/libtiff/tif_tile.c<br>
-tiff/libtiff/tif_unix.c<br>
-tiff/libtiff/tif_version.c<br>
-tiff/libtiff/tif_warning.c<br>
-tiff/libtiff/tif_webp.c<br>
-tiff/libtiff/tif_win32.c<br>
-tiff/libtiff/tif_write.c<br>
-tiff/libtiff/tif_zip.c<br>
-tiff/libtiff/tif_zstd.c<br>
-tiff/libtiff/tiff.h<br>
-tiff/libtiff/tiffconf.h.cmake.in<br>
-tiff/libtiff/tiffconf.h.in<br>
-tiff/libtiff/tiffconf.vc.h<br>
-tiff/libtiff/tiffconf.wince.h<br>
-tiff/libtiff/tiffio.h<br>
-tiff/libtiff/tiffio.hxx<br>
-tiff/libtiff/tiffiop.h<br>
-tiff/libtiff/tiffvers.h<br>
-tiff/m4/libtool.m4<br>
-tiff/man/Makefile.in<br>
-tiff/man/TIFFClose.3tiff<br>
-tiff/man/TIFFDataWidth.3tiff<br>
-tiff/man/TIFFError.3tiff<br>
-tiff/man/TIFFFieldDataType.3tiff<br>
-tiff/man/TIFFFieldName.3tiff<br>
-tiff/man/TIFFFieldPassCount.3tiff<br>
-tiff/man/TIFFFieldReadCount.3tiff<br>
-tiff/man/TIFFFieldTag.3tiff<br>
-tiff/man/TIFFFieldWriteCount.3tiff<br>
-tiff/man/TIFFFlush.3tiff<br>
-tiff/man/TIFFGetField.3tiff<br>
-tiff/man/TIFFOpen.3tiff<br>
-tiff/man/TIFFPrintDirectory.3tiff<br>
-tiff/man/TIFFRGBAImage.3tiff<br>
-tiff/man/TIFFReadDirectory.3tiff<br>
-tiff/man/TIFFReadEncodedStrip.3tiff<br>
-tiff/man/TIFFReadEncodedTile.3tiff<br>
-tiff/man/TIFFReadRGBAImage.3tiff<br>
-tiff/man/TIFFReadRGBAStrip.3tiff<br>
-tiff/man/TIFFReadRGBATile.3tiff<br>
-tiff/man/TIFFReadRawStrip.3tiff<br>
-tiff/man/TIFFReadRawTile.3tiff<br>
-tiff/man/TIFFReadScanline.3tiff<br>
-tiff/man/TIFFReadTile.3tiff<br>
-tiff/man/TIFFSetDirectory.3tiff<br>
-tiff/man/TIFFSetField.3tiff<br>
-tiff/man/TIFFWarning.3tiff<br>
-tiff/man/TIFFWriteDirectory.3tiff<br>
-tiff/man/TIFFWriteEncodedStrip.3tiff<br>
-tiff/man/TIFFWriteEncodedTile.3tiff<br>
-tiff/man/TIFFWriteRawStrip.3tiff<br>
-tiff/man/TIFFWriteRawTile.3tiff<br>
-tiff/man/TIFFWriteScanline.3tiff<br>
-tiff/man/TIFFWriteTile.3tiff<br>
-tiff/man/TIFFbuffer.3tiff<br>
-tiff/man/TIFFcodec.3tiff<br>
-tiff/man/TIFFcolor.3tiff<br>
-tiff/man/TIFFmemory.3tiff<br>
-tiff/man/TIFFquery.3tiff<br>
-tiff/man/TIFFsize.3tiff<br>
-tiff/man/TIFFstrip.3tiff<br>
-tiff/man/TIFFswab.3tiff<br>
-tiff/man/TIFFtile.3tiff<br>
-tiff/man/fax2ps.1<br>
-tiff/man/fax2tiff.1<br>
-tiff/man/libtiff.3tiff<br>
-tiff/man/pal2rgb.1<br>
-tiff/man/ppm2tiff.1<br>
-tiff/man/raw2tiff.1<br>
-tiff/man/tiff2bw.1<br>
-tiff/man/tiff2pdf.1<br>
-tiff/man/tiff2ps.1<br>
-tiff/man/tiff2rgba.1<br>
-tiff/man/tiffcmp.1<br>
-tiff/man/tiffcp.1<br>
-tiff/man/tiffcrop.1<br>
-tiff/man/tiffdither.1<br>
-tiff/man/tiffdump.1<br>
-tiff/man/tiffgt.1<br>
-tiff/man/tiffinfo.1<br>
-tiff/man/tiffmedian.1<br>
-tiff/man/tiffset.1<br>
-tiff/man/tiffsplit.1<br>
-tiff/nmake.opt<br>
-tiff/port/CMakeLists.txt<br>
-tiff/port/Makefile.am<br>
-tiff/port/Makefile.in<br>
-tiff/port/Makefile.vc<br>
-tiff/port/_strtol.h<br>
-tiff/port/_strtoul.h<br>
-tiff/port/dummy.c<br>
-tiff/port/getopt.c<br>
-tiff/port/lfind.c<br>
-tiff/port/libport.h<br>
-tiff/port/snprintf.c<br>
-tiff/port/strcasecmp.c<br>
-tiff/port/strtol.c<br>
-tiff/port/strtoll.c<br>
-tiff/port/strtoul.c<br>
-tiff/port/strtoull.c<br>
-tiff/test/CMakeLists.txt<br>
-tiff/test/Makefile.am<br>
-tiff/test/Makefile.in<br>
-tiff/test/ascii_tag.c<br>
-tiff/test/check_tag.c<br>
-tiff/test/common.sh<br>
-tiff/test/custom_dir.c<br>
-tiff/test/defer_strile_loading.c<br>
-tiff/test/defer_strile_writing.c<br>
-tiff/test/fax2tiff.sh<br>
-tiff/test/images/README.txt<br>
-tiff/test/images/lzw-single-strip.tiff<br>
-tiff/test/images/miniswhite-1c-1b.g3<br>
-tiff/test/long_tag.c<br>
-tiff/test/raw_decode.c<br>
-tiff/test/refs/o-tiff2ps-EPS1.ps<br>
-tiff/test/refs/o-tiff2ps-PS1.ps<br>
-tiff/test/refs/o-tiff2ps-PS2.ps<br>
-tiff/test/refs/o-tiff2ps-PS3.ps<br>
-tiff/test/rewrite_tag.c<br>
-tiff/test/short_tag.c<br>
-tiff/test/strip.c<br>
-tiff/test/strip_rw.c<br>
-tiff/test/test_arrays.c<br>
-tiff/test/test_arrays.h<br>
-tiff/test/testtypes.c<br>
-tiff/test/tiff2ps-EPS1.sh<br>
-tiff/test/tiff2ps-PS1.sh<br>
-tiff/test/tiff2ps-PS2.sh<br>
-tiff/test/tiff2ps-PS3.sh<br>
-tiff/test/tiffcp-lzw-scanline-decode.sh<br>
-tiff/test/tifftest.h<br>
-tiff/tools/CMakeLists.txt<br>
-tiff/tools/Makefile.in<br>
-tiff/tools/Makefile.vc<br>
-tiff/tools/fax2ps.c<br>
-tiff/tools/fax2tiff.c<br>
-tiff/tools/pal2rgb.c<br>
-tiff/tools/ppm2tiff.c<br>
-tiff/tools/raw2tiff.c<br>
-tiff/tools/rgb2ycbcr.c<br>
-tiff/tools/thumbnail.c<br>
-tiff/tools/tiff2bw.c<br>
-tiff/tools/tiff2pdf.c<br>
-tiff/tools/tiff2ps.c<br>
-tiff/tools/tiff2rgba.c<br>
-tiff/tools/tiffcmp.c<br>
-tiff/tools/tiffcp.c<br>
-tiff/tools/tiffcrop.c<br>
-tiff/tools/tiffdither.c<br>
-tiff/tools/tiffdump.c<br>
-tiff/tools/tiffgt.c<br>
-tiff/tools/tiffinfo.c<br>
-tiff/tools/tiffmedian.c<br>
-tiff/tools/tiffset.c<br>
-tiff/tools/tiffsplit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-25 15:14:51 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aa13e1a3fac84ada2b676f9c5fcffb30f5df74dd">aa13e1a3fac84ada2b676f9c5fcffb30f5df74dd</a>
-<blockquote>
-<p>
- Coverity 351088: check for errors in px_begin_error_page().<br>
-<br>
- Had to change px_begin_error_page()'s API to use out-parameter, so that return<br>
- value is error code.<br>
-<br>
-pcl/pxl/pxerrors.c<br>
-pcl/pxl/pxerrors.h<br>
-pcl/pxl/pxtop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-25 14:42:05 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34fc5a7613eea288a8426d3be425c93647954668">34fc5a7613eea288a8426d3be425c93647954668</a>
-<blockquote>
-<p>
- Coverity 351086: Fix out-of-bounds access to score[2].<br>
-<br>
-gpdl/psitop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-25 19:48:50 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a570a05622cb178c031db64711b412cf640038b2">a570a05622cb178c031db64711b412cf640038b2</a>
-<blockquote>
-<p>
- Coverity 350201, 350191: Add some notes to the code.<br>
-<br>
- Coverity spots that pdf14_fill_path checks for ppath being<br>
- NULL in one branch, hence assumes that it can be NULL in all<br>
- cases. Furthermore it spots that it is passed into<br>
- gx_default_fill_path, which can in some circumstances, dereference<br>
- it without checking it first.<br>
-<br>
- The reason for this is that fill_path can permissibly be called<br>
- with a NULL path if we want to fill the given clipping path. This<br>
- is only used for shadings and patterns, which is exactly the case<br>
- checked for within gx_default_fill_path and pdf14_fill_path.<br>
-<br>
- We'll resolve this with a 'false positive' in Coverity, but have<br>
- added the comments for the benefit of future readers.<br>
-<br>
- Coverity spots the same thing in pdf14_stroke_path, but there it<br>
- really makes no sense for ppath to be NULL, so just eliminate the<br>
- check.<br>
-<br>
- Credit to Julian Smith for the investigation on this.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-25 18:30:33 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fee6b609fbb8d1f0744f98ee3bf930c1fd733660">fee6b609fbb8d1f0744f98ee3bf930c1fd733660</a>
-<blockquote>
-<p>
- Fix indeterminism in gdevp201.c<br>
-<br>
- The printers herein read 1bpp data from gs, and then compressed<br>
- in terms of bytes. For the case where w%8 != 0, we'd have<br>
- uninitialised bits. Solve this by masking the last byte of each<br>
- line as appropriate.<br>
-<br>
- Also, ensure that we don't 'overread' lines, check the return<br>
- code from the get_bits call, and blank any lines of the buffer<br>
- required to bring us up to a multiple of the stripe height.<br>
-<br>
-contrib/japanese/gdevp201.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-25 09:44:29 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f3b0a9e346a97b23f1f7e016944be514c8b0ec78">f3b0a9e346a97b23f1f7e016944be514c8b0ec78</a>
-<blockquote>
-<p>
- Fix indeterminism in gdevatx.c<br>
-<br>
- The compression used by this device relies on compressing pairs of<br>
- bytes; as such we have to be careful that when we offset to the end<br>
- of the line we don't move inot uninitialised data.<br>
-<br>
- We fix this here by blanking an extra byte, and being smarter about<br>
- where we start the search for trailing empties from.<br>
-<br>
- This should resolve the differences we see in the all-devs test.<br>
-<br>
-devices/gdevatx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-25 16:12: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=8a589c19d62884388cb9eff7d12bfba568e667ca">8a589c19d62884388cb9eff7d12bfba568e667ca</a>
-<blockquote>
-<p>
- Fix incorrect transform in gpdl/pwgtop.c<br>
-<br>
-gpdl/pwgtop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-22 19:43:46 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79e11b98dc078fcd92cda588ab6157a4aa14d0f0">79e11b98dc078fcd92cda588ab6157a4aa14d0f0</a>
-<blockquote>
-<p>
- Add Jpeg2000 &quot;language&quot; interpreter for gpdl.<br>
-<br>
-gpdl/gpdl.mak<br>
-gpdl/jp2ktop.c<br>
-pcl/pl/plimpl.c<br>
-windows/ghostpdl.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-25 15:59:00 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=113792dd347ac7b9436b9517aca91e1153fb230d">113792dd347ac7b9436b9517aca91e1153fb230d</a>
-<blockquote>
-<p>
- Ensure oki4w device properly closes device.<br>
-<br>
- This was causing indetermisms in cluster runs.<br>
-<br>
-contrib/gdevop4w.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-25 14:50:05 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=12eef95ef9ed7a086ca02f06ef93acce9c9a2676">12eef95ef9ed7a086ca02f06ef93acce9c9a2676</a>
-<blockquote>
-<p>
- Remove FIXME and associated dead code in pwgtop.c<br>
-<br>
- This should solve coverity 351087.<br>
-<br>
-gpdl/pwgtop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-25 14:46:56 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab089bf9511ccaa30a33d6e269ab0dae98ff5517">ab089bf9511ccaa30a33d6e269ab0dae98ff5517</a>
-<blockquote>
-<p>
- Fix coverity #351085; toff_t's are unsigned.<br>
-<br>
- The tiff lib uses a 'seek' function that apes 'fseek' in that<br>
- it takes a whence field. In order for the whence field to be<br>
- useful for 'SEEK_SET' (and half the cases of SEEK_CURR), it<br>
- needs to be able to take negative offsets. The tiff seek<br>
- function only passes positive offsets though as it uses an<br>
- unsigned type.<br>
-<br>
- It is therefore pointless to test against 0.<br>
-<br>
-gpdl/tifftop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-22 15:31:47 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e056194328312f724089d52398e88c5a6a2fe277">e056194328312f724089d52398e88c5a6a2fe277</a>
-<blockquote>
-<p>
- Windows installer: offer to uninstall previous installations<br>
-<br>
- If the installer detects previous gs installations (from the registry keys), an<br>
- additional page will appear in the installer, giving the user the option of<br>
- uninstalling each existing installation in turn - it allows uninstall a given<br>
- install, not uninstall it, or cancel out of uninstalling the remaining ones.<br>
-<br>
-psi/nsisinst.nsi<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-22 18:12:11 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e9ff39ee82680ea1719ddf99cf3809e26df0c946">e9ff39ee82680ea1719ddf99cf3809e26df0c946</a>
-<blockquote>
-<p>
- Coverity 351050: avoid buffer overflow warning.<br>
-<br>
- For simplicity, have used a temp four-character buffer filled in by<br>
- parse_file_access_string(), then snprintf() to append gp_fmode_binary_suffix<br>
- safely.<br>
-<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-22 18:08:05 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=354715346deed252ef7db53160b61d04bd630a2f">354715346deed252ef7db53160b61d04bd630a2f</a>
-<blockquote>
-<p>
- Coverity 351049: avoid buffer overflow warning.<br>
-<br>
- We're actually safe because gp_fmode_binary_suffix is max one-character long,<br>
- but Coverity doesn't know that.<br>
-<br>
-base/gxclfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-22 18:05:35 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b8c8a6410658fdfe57ad5de4ae57fdc4cbece2ab">b8c8a6410658fdfe57ad5de4ae57fdc4cbece2ab</a>
-<blockquote>
-<p>
- Coverity 351048: avoid buffer overflow warning.<br>
-<br>
- We're actually safe because gp_fmode_binary_suffix is max one-character long,<br>
- but Coverity doesn't know that.<br>
-<br>
-base/gxclist.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-22 17:45:51 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=882793bc7f35f21f7857e216966c0b777140a87c">882793bc7f35f21f7857e216966c0b777140a87c</a>
-<blockquote>
-<p>
- Coverity 350209: fix bad return path in handle_dash_c().<br>
-<br>
- Also refactored a little.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-22 10:43:43 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f611a6c45fafbea495206773eccf3028cfb4765">8f611a6c45fafbea495206773eccf3028cfb4765</a>
-<blockquote>
-<p>
- Bug 701625 Treat CMY color space as additive<br>
-<br>
- Our support of CMY devices is currently not ideal with<br>
- respect to proper color management and the transparency<br>
- imaging model as described in Bug 697965. My plan is<br>
- to make a psd cmy based device and get things working<br>
- properly in terms of spot colors and ICC color management.<br>
- This will take a bit of effort and likely have a bug<br>
- tail. For now for Bug 701625 an easy solution is to<br>
- treat the color space as additive. In this case, the<br>
- output looks reasonable.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-22 11:42:29 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f734274b455c321a4089d8ee7efa7511656ae9c6">f734274b455c321a4089d8ee7efa7511656ae9c6</a>
-<blockquote>
-<p>
- Removed gp_fprintf(pstream, &quot;&quot;) call that has no affect.<br>
-<br>
- This was causing gcc warning because gp_fprintf() is now checked by gcc for<br>
- printf format warnings.<br>
-<br>
-devices/gdevmgr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 18:39:21 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=17a947dcc56fee115d7b416de7648289b04185f8">17a947dcc56fee115d7b416de7648289b04185f8</a>
-<blockquote>
-<p>
- Fix some -W -Wall warnings about printf format type mismatches.<br>
-<br>
-contrib/gdevhl12.c<br>
-jbig2dec/jbig2.c<br>
-jbig2dec/jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 17:47:53 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cbd8765cc2e5d67eae3d412a7584f37a9e02f2e9">cbd8765cc2e5d67eae3d412a7584f37a9e02f2e9</a>
-<blockquote>
-<p>
- Bug 701932: fixed up head dependencies for pxstate_h.<br>
-<br>
-pcl/pxl/pxl.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 17:16:27 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3ee9bb6efff8929ff8df4fb7ca42001c2aeacdf6">3ee9bb6efff8929ff8df4fb7ca42001c2aeacdf6</a>
-<blockquote>
-<p>
- Coverity 350198: fixed jbig2_error() printf format / type mismatches.<br>
-<br>
- Unfortunately stdint_.h isn't available to jbig2dec code so we can't use<br>
- PRIdSIZE. Have instead used %li with a cast to long.<br>
-<br>
- [This commit addresses all printf warnings from gcc -W -Wall; it probably fixes<br>
- multiple similar coverity issues.]<br>
-<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 17:11:43 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=67a59c12667bbdddf67e78d9496f94b34d55e702">67a59c12667bbdddf67e78d9496f94b34d55e702</a>
-<blockquote>
-<p>
- Coverity 350195: check return from process_row().<br>
-<br>
-pcl/pcl/rtraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 17:01:55 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3819f5121013dd93dd3653475e686d8f6df9b068">3819f5121013dd93dd3653475e686d8f6df9b068</a>
-<blockquote>
-<p>
- Coverity 350189: explicitly ignore return from hpgl_arg_c_int().<br>
-<br>
- We already initialised variable 'type', and we don't mind whether<br>
- hpgl_arg_c_int() changes it before we switch on it. So cast hpgl_arg_c_int()'s<br>
- return to void to stop Coverity from warning.<br>
-<br>
-pcl/pcl/pgconfig.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 16:52:32 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3b8f96dbe2dc0ab0cdbbf076cdb88e21c91639a5">3b8f96dbe2dc0ab0cdbbf076cdb88e21c91639a5</a>
-<blockquote>
-<p>
- Coverity 350185: fix printf format type mismatch.<br>
-<br>
- Unfortunately stdint_.h isn't available to jbig2dec code so we can't use<br>
- PRIdSIZE. Have instead used %li with a cast to long.<br>
-<br>
-jbig2dec/jbig2_generic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 16:49:51 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b31b05c2db5967c00d0b08023167935bbb3d015">4b31b05c2db5967c00d0b08023167935bbb3d015</a>
-<blockquote>
-<p>
- If gcc, make gcc check jbig2_error()'s format string agrees with types of parameters.<br>
-<br>
-jbig2dec/jbig2_priv.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 16:23:32 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1098cdd54a46dca9ca976b750ba25d0b714dfd9f">1098cdd54a46dca9ca976b750ba25d0b714dfd9f</a>
-<blockquote>
-<p>
- Add a --enable-mkromfs-quiet configure option.<br>
-<br>
- Sets MKROMFS_FLAGS=-q and pass to all invocations of mkromfs.<br>
-<br>
- [Makefile.in and configure.ac changes by chrisl]<br>
-<br>
-Makefile.in<br>
-base/lib.mak<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 12:52:41 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1f60fa73b7c6b5acfae75b6e4a1fede2b75ea1c4">1f60fa73b7c6b5acfae75b6e4a1fede2b75ea1c4</a>
-<blockquote>
-<p>
- mkromfs: added -q option to reduce verbose diagnostics.<br>
-<br>
-base/mkromfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-15 16:45:33 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3e01cc30c90094bcbef2966f1048c504e6b5361e">3e01cc30c90094bcbef2966f1048c504e6b5361e</a>
-<blockquote>
-<p>
- configure.ac: add -W -Wall to sanitize builds if supported.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 13:41:37 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b93f218d418827b689c61b37941ffd4eef0c0d84">b93f218d418827b689c61b37941ffd4eef0c0d84</a>
-<blockquote>
-<p>
- Mark gp_fprintf() with gcc's __attribute__ ((format (__printf__, 2, 3))).<br>
-<br>
- This makes gcc check types match the format string.<br>
-<br>
-base/gp.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 13:40:45 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=87cd6160bf654a164469e75a9df7cc7b690b5aaa">87cd6160bf654a164469e75a9df7cc7b690b5aaa</a>
-<blockquote>
-<p>
- Coverity 350172: fix gp_fprintf() call to use PRIdSIZE for ptrdiff_t.<br>
-<br>
-contrib/japanese/gdevp201.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 12:24:48 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=53a370b272a89df418ea563f1abde7d774579105">53a370b272a89df418ea563f1abde7d774579105</a>
-<blockquote>
-<p>
- Coverity 350169: avoid buffer overflow when writing to cups-&gt;pageSizeRequested.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-20 19:30:55 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7fe9289f10c47fe7557375c23b54cd87e521d11c">7fe9289f10c47fe7557375c23b54cd87e521d11c</a>
-<blockquote>
-<p>
- Bug 701932: moved more global_* into px_state_s.<br>
-<br>
- Specifically:<br>
-<br>
- gs_point global_char_shear;<br>
- gs_point global_char_scale;<br>
- float global_char_bold_value;<br>
- float global_char_angle;<br>
-<br>
-pcl/pxl/pxpthr.c<br>
-pcl/pxl/pxstate.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-20 19:16:48 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=810c897c51e28dcdd589e1561af36769e72e0893">810c897c51e28dcdd589e1561af36769e72e0893</a>
-<blockquote>
-<p>
- Bug 701932: moved more global_* into px_state_s.<br>
-<br>
- Specifically:<br>
-<br>
- static pcl_parser_state_t global_pcl_parser_state;<br>
- static hpgl_parser_state_t global_gl_parser_state;<br>
- static bool global_this_pass_contiguous = false;<br>
- static bool global_pass_first = true;<br>
-<br>
-pcl/pxl/pxparse.c<br>
-pcl/pxl/pxpthr.c<br>
-pcl/pxl/pxpthr.h<br>
-pcl/pxl/pxstate.c<br>
-pcl/pxl/pxstate.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-20 17:39:58 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d48555f7777a983e0d15972f3838bb5583e20657">d48555f7777a983e0d15972f3838bb5583e20657</a>
-<blockquote>
-<p>
- Bug 701932: moved global_pcs into px_state_s.<br>
-<br>
-pcl/pxl/pxpthr.c<br>
-pcl/pxl/pxpthr.h<br>
-pcl/pxl/pxsessio.c<br>
-pcl/pxl/pxstate.c<br>
-pcl/pxl/pxstate.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-20 12:42:16 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4db291eb31b4dc8c6864e438acdd9283c3347671">4db291eb31b4dc8c6864e438acdd9283c3347671</a>
-<blockquote>
-<p>
- Coverity 350170: cope with -ve from gs_vsprintf().<br>
-<br>
-pcl/pcl/pcstatus.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-22 13:02: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=0bc5d53fa1c0d7832008d1ae8e0e6804bf5f9e9e">0bc5d53fa1c0d7832008d1ae8e0e6804bf5f9e9e</a>
-<blockquote>
-<p>
- Windows (un)installer: Fix case for registry key removal<br>
-<br>
-psi/nsisinst.nsi<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-22 10:30:14 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=efafc6f95b0bfedf63efafc55416846974a67bcc">efafc6f95b0bfedf63efafc55416846974a67bcc</a>
-<blockquote>
-<p>
- &quot;Promote&quot; gpdl from experimental to actual product<br>
-<br>
- Really, add gpdl to the default targets list.<br>
-<br>
-Makefile.in<br>
-base/gs.mak<br>
-base/unix-gcc.mak<br>
-configure.ac<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-22 11:49:02 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0243f6288ca26b2985f0778040feebae7322ac0b">0243f6288ca26b2985f0778040feebae7322ac0b</a>
-<blockquote>
-<p>
- Coverity ID 94736<br>
-<br>
- This was partially addressed in a previous commit (2 years ago) but<br>
- because the 'contrib' folder wasn't included in the ananlysis, this<br>
- second instance of the same problem didn't show up.<br>
-<br>
-contrib/gdevcd8.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 15:18:29 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d9d92ab6b774914d81f63c8e19d78e4022ad9976">d9d92ab6b774914d81f63c8e19d78e4022ad9976</a>
-<blockquote>
-<p>
- Bug 701357: Fix color document<br>
-<br>
- Getting proper encoding of _ character requires use of<br>
- [T1]{fontenc} and lmodern.<br>
-<br>
-doc/GS9_Color_Management.pdf<br>
-doc/GS9_Color_Management.tex<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 14:06:50 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0129596f6cf2d090ed46f9a9c8189ab60b56735f">0129596f6cf2d090ed46f9a9c8189ab60b56735f</a>
-<blockquote>
-<p>
- Bug 700929: Pass object type rendering intent settings to pdf14 device<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 18:45:55 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e0c2e4d8f43d6e83a0a04e6d2c350d2d7fc1e7a6">e0c2e4d8f43d6e83a0a04e6d2c350d2d7fc1e7a6</a>
-<blockquote>
-<p>
- gpdl: Fixup some warnings.<br>
-<br>
-gpdl/gpdl.mak<br>
-gpdl/jpgtop.c<br>
-gpdl/pwgtop.c<br>
-gpdl/tifftop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-20 19:02:47 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23ea32bf2bd205c44c9a7979b3a187199e47da59">23ea32bf2bd205c44c9a7979b3a187199e47da59</a>
-<blockquote>
-<p>
- gpdl: Add 'jbig2' language implementation.<br>
-<br>
-gpdl/gpdl.mak<br>
-gpdl/jbig2top.c<br>
-pcl/pl/plimpl.c<br>
-windows/ghostpdl.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-20 19:01:31 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0c30c4cda3c2487ce52f79a952e3d0febef1d8bd">0c30c4cda3c2487ce52f79a952e3d0febef1d8bd</a>
-<blockquote>
-<p>
- Remove some dead code/variables from tifftop.c<br>
-<br>
-gpdl/tifftop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 11:20:49 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7043e985298f75291e1fc25ad272140be31ffe6d">7043e985298f75291e1fc25ad272140be31ffe6d</a>
-<blockquote>
-<p>
- Ghostscript Bug 701324. Improved robustness of lcms2mt<br>
-<br>
- lcmsmt will give up if it can't find the perceptual MLUT.<br>
- This fix will have it check to see if the colorimetric or<br>
- saturation intents are present also.<br>
-<br>
-lcms2mt/src/cmsio1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 10:45:59 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aa30c0798d32decfd99ff8149553221917d4301e">aa30c0798d32decfd99ff8149553221917d4301e</a>
-<blockquote>
-<p>
- Use gp_fwrite instead of fwrite.<br>
-<br>
-base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 08:40:02 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4640b5abd48430bfc76cc4e98cd626aa64075537">4640b5abd48430bfc76cc4e98cd626aa64075537</a>
-<blockquote>
-<p>
- Bug 701717 Remove redundant check.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-19 15:40: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=9189e54333d33104a0de8aa92b1c5a7662762048">9189e54333d33104a0de8aa92b1c5a7662762048</a>
-<blockquote>
-<p>
- JBIG2_CFLAGS/JPX_CFLAGS handling and remove commented out code<br>
-<br>
- The JBIG2_CFLAGS and JPX_CFLAGS allow a user to tweak the CFLAGS specific to<br>
- the JBIG2 and JPX/JPEG2000 decoders respectively.<br>
-<br>
- There was also some commented out code that, with the above tweak, is no<br>
- longer required to be there.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-06 13:29:19 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=84a1bd8c73d740022877a5911851b8521ecc7458">84a1bd8c73d740022877a5911851b8521ecc7458</a>
-<blockquote>
-<p>
- Bug 701440: only include libs calling pkg-config for freetype<br>
-<br>
- Only have the -l options, not the -L ones because they confuse genconf<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-06 12:43: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=aaea09a9a0e357b2784536b8476f4ab4fee19b64">aaea09a9a0e357b2784536b8476f4ab4fee19b64</a>
-<blockquote>
-<p>
- Allow configure to set size etc for size_t in arch.h<br>
-<br>
-arch/arch_autoconf.h.in<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-06 11:30:17 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=64a35dc73ee8256421b1dd2760be0c73c05eadb8">64a35dc73ee8256421b1dd2760be0c73c05eadb8</a>
-<blockquote>
-<p>
- Bug 701439: use pkg-config for libidn<br>
-<br>
- If pkg-config is available, and knows about libidn, use it to get the CFLAGS and<br>
- LIBS, otherwise fall back to the AC_CHECK_LIB/AC_CHECK_HEADER method<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-06 10:44: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=317c0154a8141b8dde6e303f1e18a95e01f8ee33">317c0154a8141b8dde6e303f1e18a95e01f8ee33</a>
-<blockquote>
-<p>
- Bug 701689: CPPFLAGS for aux tools when cross-compiling<br>
-<br>
- Introduce CPPFLAGSAUX<br>
-<br>
- Credit to Marvin Schmidt<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-29 12:45:17 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c7c6043bde1517e8fd6d645d7c34142aec462248">c7c6043bde1517e8fd6d645d7c34142aec462248</a>
-<blockquote>
-<p>
- Spaces should be tab<br>
-<br>
-base/gs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-21 10:45: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=2d84ecc57837785b566ebd9d5909ba9edc9d697f">2d84ecc57837785b566ebd9d5909ba9edc9d697f</a>
-<blockquote>
-<p>
- Use caller defined pkg-config and cups-config unconditionally<br>
-<br>
- In an effort to better handle cross-compilation, we use a check combining<br>
- AC_PATH_TOOL() and AC_PATH_PROG() - where AC_CHECK_TOOL() will first attempt to<br>
- find the requested tool *with* a target-triplet prefix (for example,<br>
- &quot;x86_64-linux-gnu-pkg-config&quot;) and if that fails, it will fall back to the<br>
- unadorned tool (e.g. &quot;pkg-config&quot;). If we are cross-compiling, and both<br>
- AC_PATH_TOOL() and AC_PATH_PROG() return the same value, we assume that<br>
- AC_PATH_TOOL() has fallen back to the default, non-cross-compile version, and we<br>
- disable using the given tool.<br>
-<br>
- We do this for both pkg-config and cups-config.<br>
-<br>
- This does not work well for every cross-compile environment, however, since not<br>
- all use the convention of the target triplet prefix.<br>
-<br>
- We already allowed the caller to specify both a pkg-config and cups-config to<br>
- use, but we still applied the above outlined test.<br>
-<br>
- Now, when the tool is explicitly specified, do *not* do the<br>
- AC_PATH_TOOL()/AC_PATH_PROG(), assume the caller knows what they are doing, and<br>
- just go ahead and use it.<br>
-<br>
- Additionally, for cups-config, if the caller explicitly specified a cups-config,<br>
- and/or explicitly set --enable-cups then make not finding the cups libraries a<br>
- configure hard fail. By default, we'll still just warn, and exclude the cups<br>
- devices.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-18 09:46:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=327dc8943c0aac1c7be7a1fb6e93346b61cd0900">327dc8943c0aac1c7be7a1fb6e93346b61cd0900</a>
-<blockquote>
-<p>
- Bug #699331: better support for cross-compiling<br>
-<br>
- This is mainly moving from using uname to identify the the target platform,<br>
- to using the 'host' value to identify the target platform, and 'host' and<br>
- 'build' values to know when we're cross-compiling.<br>
-<br>
- There are also a couple of tweaks related to cross-compiling to MSYS.<br>
-<br>
- Also, make double sure API symbols are always visible. This affects builds with<br>
- gcc and compatible compilers.<br>
-<br>
- Remove use of $cross_compiling variable<br>
-<br>
- Credit to djcj for most of the changes<br>
-<br>
-.gitignore<br>
-Makefile.in<br>
-autogen.sh<br>
-base/gp_unix.c<br>
-base/gsutil.c<br>
-base/lib.mak<br>
-base/unix-dll.mak<br>
-configure.ac<br>
-pcl/pl/pjparse.c<br>
-psi/iapi.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 14:58: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=e20cd8d8fc1f40bf4218c18e545ca4ddb175c348">e20cd8d8fc1f40bf4218c18e545ca4ddb175c348</a>
-<blockquote>
-<p>
- Remove gprf device from Windows makefile<br>
-<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-21 11:05:36 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a56ef4aed70a50bcd7731b61e59850e98d08a4d">7a56ef4aed70a50bcd7731b61e59850e98d08a4d</a>
-<blockquote>
-<p>
- Ensure paths from Fontmap end in a directory separator<br>
-<br>
- Since it's normal for multiple font files to be grouped together in a directory,<br>
- we strip the file name off, and add just the directory to the permit read list,<br>
- rather than flood the list with every font file.<br>
-<br>
- The problem is, we weren't appending the directory separator character showing<br>
- the directory was reading permitted.<br>
-<br>
- This commit does that.<br>
-<br>
- Also, add extra detail to the documentation about this aspect of file<br>
- permissions lists.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-doc/Fonts.htm<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-20 15:24:28 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5e60fc862a73898ce048730d0c23c00b9ddb5578">5e60fc862a73898ce048730d0c23c00b9ddb5578</a>
-<blockquote>
-<p>
- Bug 701660 Trans. Text knockout missing ET<br>
-<br>
- The file has contents that look like this<br>
-<br>
- BT<br>
- stuff<br>
- BT<br>
- stuff<br>
- ET<br>
-<br>
- more stuff<br>
-<br>
- The first BT meets the conditions to push the text group.<br>
- Unfortunately it is missing the ET, so the group is never popped.<br>
- These fixes will make sure that if we are in a text group and<br>
- encounter another BT we popped the current text group.<br>
-<br>
-base/gdevp14.c<br>
-base/gstrans.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-20 13:15:18 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d7118262b44939688c9143c278b8c76c6c620171">d7118262b44939688c9143c278b8c76c6c620171</a>
-<blockquote>
-<p>
- Remove trailing whitespace<br>
-<br>
-gpdl/tifftop.c<br>
-pcl/pcl/pcfrgrnd.c<br>
-pcl/pxl/pxpthr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-20 12:32:06 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=31c4abe348de980ff7922e28f05cc3f788fab29a">31c4abe348de980ff7922e28f05cc3f788fab29a</a>
-<blockquote>
-<p>
- Remove gproof device.<br>
-<br>
-configure.ac<br>
-devices/devs.mak<br>
-devices/gdevgprf.c<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-20 11:04:43 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1a5a05cf164f6657e3cc52f6fa31524ed190b981">1a5a05cf164f6657e3cc52f6fa31524ed190b981</a>
-<blockquote>
-<p>
- Coverity 95049: stop coverity taints for jbig2_get_int16() etc.<br>
-<br>
-jbig2dec/jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-20 10:34:33 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a26c1ee0ef8db26ba79f6804a4f09e1c88cb234">9a26c1ee0ef8db26ba79f6804a4f09e1c88cb234</a>
-<blockquote>
-<p>
- Coverity 350210: removed superflous extra param to jbig2_error().<br>
-<br>
-jbig2dec/jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-20 10:24:09 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9d8f69e1e37475775917e71ba9bf82b7a2098942">9d8f69e1e37475775917e71ba9bf82b7a2098942</a>
-<blockquote>
-<p>
- Coverity 350166: stop coverity taint warnings for get_u32_big_endian().<br>
-<br>
-base/gsiorom.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-20 10:19:46 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=09d9c492f135ceeb6d95323c1b340b1fc03f15ad">09d9c492f135ceeb6d95323c1b340b1fc03f15ad</a>
-<blockquote>
-<p>
- Coverity 341108: removed special coverity comment that didn't work.<br>
-<br>
-base/gp_unifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-20 10:13:03 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d79e80b43f388d1e9dd53d86466e04bdb2e6be25">d79e80b43f388d1e9dd53d86466e04bdb2e6be25</a>
-<blockquote>
-<p>
- Coverity 102214: stop coverity worrying about pl_get_int16() etc.<br>
-<br>
- These fns use byte swapping, which makes coverity think that they return<br>
- tainted data, and also that they taint the input buffer.<br>
-<br>
-pcl/pl/plvalue.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-19 17:58:10 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b74cf2eff085b9270d26818e9064450ac4da41f9">b74cf2eff085b9270d26818e9064450ac4da41f9</a>
-<blockquote>
-<p>
- Coverity 350199: try to stop coverity from thinking skip_white_pixels() taints buffer.<br>
-<br>
-base/scfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-19 17:30:52 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=763a96187a286432e3c90b564a2031278e3688d0">763a96187a286432e3c90b564a2031278e3688d0</a>
-<blockquote>
-<p>
- Coverity 350190, 350208: make raster unsigned, to avoid sign extension issue.<br>
-<br>
-base/gsovrc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-19 19:13:40 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1759596a7499d27e3d289bbff4c45f9206ad4798">1759596a7499d27e3d289bbff4c45f9206ad4798</a>
-<blockquote>
-<p>
- Followon to fix for bug 701877.<br>
-<br>
- This changes the 'extern' definitions for<br>
- {Single,Double,Treble,Quad}GlyphList to be more correct. This<br>
- enables us to use the simple castless form in the initialisations.<br>
- This works nicely in Visual Studio, and will hopefully assuage<br>
- Coverity.<br>
-<br>
-devices/vector/gdevpdfu.c<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-19 16:35:50 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c5eb242fa82585aa21371919ca4a7a2d4d4effc3">c5eb242fa82585aa21371919ca4a7a2d4d4effc3</a>
-<blockquote>
-<p>
- Make sure blend mode is passed to tile with pdfi<br>
-<br>
-base/gxpcmap.c<br>
-base/gxpcolor.h<br>
-psi/zpcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-19 18:13:08 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=69bdf79e10370ed16a17a346690fd630272f7346">69bdf79e10370ed16a17a346690fd630272f7346</a>
-<blockquote>
-<p>
- gpdl: Add tiff &quot;interpreter&quot; to gpdl.<br>
-<br>
-Makefile.in<br>
-configure.ac<br>
-gpdl/gpdl.mak<br>
-gpdl/tifftop.c<br>
-pcl/pl/plimpl.c<br>
-psi/msvc.mak<br>
-windows/ghostpdl.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-19 18:11:55 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5956ac8be8c923ad9e9fd3045724a5579cf4dce">b5956ac8be8c923ad9e9fd3045724a5579cf4dce</a>
-<blockquote>
-<p>
- gpdl: Fix compiler flags for pwgtop.c<br>
-<br>
- Don't need to pass the JPEG include directory here.<br>
-<br>
-gpdl/gpdl.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-19 18:10: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=0329372164611fdff22f8c02201ff1fbbf94aae7">0329372164611fdff22f8c02201ff1fbbf94aae7</a>
-<blockquote>
-<p>
- gpdl: Fix jpeg/pwg behaviour with varying resolutions.<br>
-<br>
- I thought this worked before, but tests revealed that it was<br>
- broken.<br>
-<br>
-gpdl/jpgtop.c<br>
-gpdl/pwgtop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-18 11:36:30 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd8747382f47393efd0f0013700a8294c0ded15c">cd8747382f47393efd0f0013700a8294c0ded15c</a>
-<blockquote>
-<p>
- Slight reorganisation of gpdl interpreter files.<br>
-<br>
- Rather than having each different &quot;language&quot; have a 'top' file<br>
- in gpdl/foo/footop.c, move them to be gpdl/foo.c. Extra directories<br>
- seem overkill at this point, and it simplifies the Makefile<br>
- slightly.<br>
-<br>
- Also, rename IMG to JPG.<br>
-<br>
-Makefile.in<br>
-gpdl/gpdl.mak<br>
-gpdl/jpgtop.c<br>
-gpdl/psitop.c<br>
-gpdl/pwgtop.c<br>
-pcl/pl/plimpl.c<br>
-windows/ghostpdl.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-19 16:40:16 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e1b7dbc95945ef2afa38faeebfda56830f2762ab">e1b7dbc95945ef2afa38faeebfda56830f2762ab</a>
-<blockquote>
-<p>
- Coverity 350182: check for error before dereferencing ptr from gs_cspace_build_ICC().<br>
-<br>
- This allows us to remove the check for pcs == NULL after pcs has already been<br>
- dereferenced, which was the coverity issue.<br>
-<br>
- Also fixed gs_cspace_build_ICC() to return gs_error_VMerror if<br>
- gs_cspace_alloc() fails - was returning zero with *ppcspace out-param set to<br>
- NULL. Have checked that all callers don't rely on the out-param being NULL to<br>
- indicate error. Though some of them make no checks at all.<br>
-<br>
-base/gdevp14.c<br>
-base/gsicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-19 16:07:23 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e93430d762400247cdc4550be403a1f7c291112d">e93430d762400247cdc4550be403a1f7c291112d</a>
-<blockquote>
-<p>
- Coverity 350180: change gp_fmode_binary_suffix from char[] to char*.<br>
-<br>
- Am hoping this will persuade Coverity that it is zero-terminated and not<br>
- zero-length, and thus safe to pass to strncat().<br>
-<br>
-base/gp.h<br>
-base/gp_dosfs.c<br>
-base/gp_ntfs.c<br>
-base/gp_os2fs.c<br>
-base/gp_unifn.c<br>
-base/gp_vms.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-19 15:19:16 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb2c2fbbc96b1f2de8e454ecb2adf3e58ddb52c3">bb2c2fbbc96b1f2de8e454ecb2adf3e58ddb52c3</a>
-<blockquote>
-<p>
- Coverity 341108: disable mktemp() SECURE_TEMP issue, as mkstemp() not available.<br>
-<br>
-base/gp_unifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-19 14:50:01 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a4c44cc7579ab80a1d49d721fad48e1ed9bbe976">a4c44cc7579ab80a1d49d721fad48e1ed9bbe976</a>
-<blockquote>
-<p>
- Coverity 323321: remove unused goto label and 'code' variable from template_mem_transform_pixel_region_render_landscape().<br>
-<br>
- The label and variable appear to have been copied from a similar function, but<br>
- they are never used, and actually it looks like this fn can't fail.<br>
-<br>
-base/gdevdrop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-19 13:06:48 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f804ebfa526bd36a808319225488fe9de416f350">f804ebfa526bd36a808319225488fe9de416f350</a>
-<blockquote>
-<p>
- Coverity: add additional annotation to jbig2_get_uint32().<br>
-<br>
- Coverity thinks that jbig2_get_uint32() taints the buffer that it is passed,<br>
- which causes coverity issues in calling code.<br>
-<br>
- So this commit adds an addional coverity annotation to ensure the buffer is not<br>
- tainted.<br>
-<br>
- Am not 100% sure how to specify multiple annotations, but apparently doing<br>
- things like '// coverity[ foo, bar ]' does not work, so we put the new<br>
- annotation in a separate comment.<br>
-<br>
-jbig2dec/jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-19 12:26:18 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ff87e872888da0f5cfd392b3f8b90fa7ad0e27c">7ff87e872888da0f5cfd392b3f8b90fa7ad0e27c</a>
-<blockquote>
-<p>
- Fix the Lexmark contributed device<br>
-<br>
- Bug #701905 &quot;heap-buffer-overflow at contrib/gdevlx32.c:1509 in convbuf&quot;<br>
-<br>
- The problem here is actually much earlier. In encode_bw_buf() there is a<br>
- comment (line 1771) about starting before the first non-white pixels<br>
- in order to &quot;give the head a little more room to accelerate properly&quot;.<br>
-<br>
- If the first non-white pixel is less than 3 pixels from the left edge<br>
- of the raster, this will cause the calculation of 'left' to become<br>
- negative. It seems to me this will immediately corrupt the data. In<br>
- addition right is calculated in a similar fashion, if right is also<br>
- close to the right edge of the raster, then we can end up with numcols<br>
- being more than the width of the raster.<br>
-<br>
- This argument is passed to convbuf() and that tries to read off the end<br>
- of the input data, because numcols exceeds the bytes in the raster.<br>
-<br>
- I'm pretty dubious about this whole piece of code but since I don't<br>
- have a printer to test with I'm reluctant to make major changes. This<br>
- commit simply clamps left to 0 and right to the right edge of the<br>
- raster. The comment implies that the extra spacing probably isn't useful<br>
- and certainly suggests that removing it won't be harmful.<br>
-<br>
-contrib/gdevlx32.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-18 17:36:54 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7e50bda19813d11555ff1ab4f7cb5c3e55ff0653">7e50bda19813d11555ff1ab4f7cb5c3e55ff0653</a>
-<blockquote>
-<p>
- Coverity 341025: removed unreachable line of code.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-18 17:34:49 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=05cfc3afb00404ddfd3c1eac635f369491995e5b">05cfc3afb00404ddfd3c1eac635f369491995e5b</a>
-<blockquote>
-<p>
- Coverity 331894: check return from gs_bbox_transform().<br>
-<br>
-pcl/pl/plchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-18 17:32:05 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=81e179af142575eab21633b2023e752e1e244c9a">81e179af142575eab21633b2023e752e1e244c9a</a>
-<blockquote>
-<p>
- Coverity 331893: check return code from gs_bbox_transform().<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-18 17:28:42 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d57aff5bbdb206f00e4b0cb3b324616be10d358e">d57aff5bbdb206f00e4b0cb3b324616be10d358e</a>
-<blockquote>
-<p>
- Coverity 323321: avoid dead code.<br>
-<br>
-base/gdevdrop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-18 15:24:44 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3aa36ebc3df83d339695fff58a73332d5304c47d">3aa36ebc3df83d339695fff58a73332d5304c47d</a>
-<blockquote>
-<p>
- Coverity 323317, 323320: avoid dead code.<br>
-<br>
- Fixes coverity errors for transform_pixel_region_render_landscape() and<br>
- transform_pixel_region_render_skew().<br>
-<br>
-base/gdevdflt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-18 14:49:38 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a1a4e8ad165e678d3affab483460ec8b926d5dd">4a1a4e8ad165e678d3affab483460ec8b926d5dd</a>
-<blockquote>
-<p>
- Coverity 261213: make pxPassthrough_pcl_state_nonpage_exceptions() check return from pcl_set_graphics_state().<br>
-<br>
- Also changed pxPassthrough_pcl_state_nonpage_exceptions() to return an int, and<br>
- made all of its callers check the return value.<br>
-<br>
-pcl/pxl/pxpthr.c<br>
-pcl/pxl/pxpthr.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-18 14:38:10 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1ee350a81d5799785ab53b3eece6e853cc4c607b">1ee350a81d5799785ab53b3eece6e853cc4c607b</a>
-<blockquote>
-<p>
- Coverity 261210: wrap call of pcl_mark_page_for_path() in hpgl_call().<br>
-<br>
-pcl/pcl/pgdraw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-18 12:31:33 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=884690a576e16043e674efb9d047a00760ac8443">884690a576e16043e674efb9d047a00760ac8443</a>
-<blockquote>
-<p>
- Coverity 135902: remove support for USE_MAP_TYPE_IN_SPECIFICATION.<br>
-<br>
- We now always treat map type 0 as map type 1. As suggested by henrystyles.<br>
-<br>
- This will fix coverity issue.<br>
-<br>
-pcl/pcl/pctext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-18 12:20:17 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9763a006f7c566e92f60e799fb2270c09807e9c8">9763a006f7c566e92f60e799fb2270c09807e9c8</a>
-<blockquote>
-<p>
- Coverity 135902: Fixed indentation in char_is_printable().<br>
-<br>
- This commit has no output from 'git diff -w', and is in preparation for next<br>
- commit that fixes coverity issue.<br>
-<br>
-pcl/pcl/pctext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-15 16:55:22 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd84fd3a36d0ef809ed697ed12f1bb04655a0388">dd84fd3a36d0ef809ed697ed12f1bb04655a0388</a>
-<blockquote>
-<p>
- Coverity 102254: avoid integer division when calculating double value.<br>
-<br>
- It's possible that this could alter behaviour, but clusterpush showed no<br>
- additional regressions.<br>
-<br>
-pcl/pcl/pctext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-18 12:08:38 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a631e0d40337da58ba596a9499b71c1d7888c9d5">a631e0d40337da58ba596a9499b71c1d7888c9d5</a>
-<blockquote>
-<p>
- Coverity 126570: build_foreground(): return error if pindexed is NULL.<br>
-<br>
- Previously we would dereference pindexed which would inevitably SEGV.<br>
-<br>
-pcl/pcl/pcfrgrnd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-18 11:25:16 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6fbd278d11e9ea567ea2dce0c7aa02e706d9a9e2">6fbd278d11e9ea567ea2dce0c7aa02e706d9a9e2</a>
-<blockquote>
-<p>
- Coverity: try using C++ comment style for 'coverity[ -tainted_data_return ]'<br>
-<br>
- E.g. for:<br>
- https://scan4.coverity.com/reports.htm#v46841/p11408/fileInstanceId=69767421&amp;defectInstanceId=11904740&amp;mergedDefectId=95049<br>
-<br>
-jbig2dec/jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-18 14:55:29 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e05d0e17c75adab181413c8bf5bf6760c76683e4">e05d0e17c75adab181413c8bf5bf6760c76683e4</a>
-<blockquote>
-<p>
- 'fix' buffer overrun in eps9mid device leading to SEGV<br>
-<br>
- Bug #701853 &quot;Segmentation fault at base/gsbitops.c:121 in bits_fill_rectangle&quot;<br>
-<br>
- The actual fault here is considerably earlier in the actual sequence of<br>
- execution.<br>
-<br>
- The device(s) check for consecutive unchanged raster lines, and only<br>
- emit new lines when two lines differ. In addition under some conditions<br>
- the device can 'consolidate' runs by OR'ing the data in a raster with<br>
- the same data in the next raster (I don't understand why this is needed)<br>
-<br>
- In order to ensure that there is sufficient data (24 rasters) for the<br>
- process to complete safely the raster data is copied into a buffer which<br>
- is allocated large enough, and is set to zero if less lines than 24 are<br>
- read from the device.<br>
-<br>
- However the code doing the OR'ing wasn't using this memory, it was using<br>
- the single scan line pulled from the device to check whether consecutive<br>
- lines are the same. This caused it to run off the end of that buffer and<br>
- overwrite the 'line_ptrs' member of the device structure. *Much* later<br>
- we would attempt to use the corrupted data and that would cause a SEGV.<br>
-<br>
- fixed by making the code OR'ing the lines use the workign buffer, as<br>
- (I think) it should.<br>
-<br>
-devices/gdevepsn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-17 19:48:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da03855bf9ca18eab05d4ac870d73f457758a77f">da03855bf9ca18eab05d4ac870d73f457758a77f</a>
-<blockquote>
-<p>
- txtwrite - fix buffer overflow<br>
-<br>
- Bug #701877 &quot;heap-buffer-overflow at devices/vector/gdevtxtw.c:2114 in txt_add_fragment&quot;<br>
-<br>
- We were trying to read too many entries from the enumerator 'Widths'<br>
- array, because we were reading the number of Unicode code points,<br>
- instead of the number of character codes.<br>
-<br>
- At the same time.....<br>
-<br>
- re-instate the code which uses &amp; on the glyph lists and casts them to<br>
- appropriate pointers. While gcc happily works with the code that was<br>
- modified to make Coverity happy, Visual Studio absolutely does not.<br>
- In order to make Visual Studio happy we do need the crazy pointers and<br>
- casting. I think this is wrong, but this way works on both compilers<br>
- and I couldn't find any other construction which did.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-16 10:00:58 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0aa9d4f8237f7a0b459fc567e76ab8f0c4c2eebd">0aa9d4f8237f7a0b459fc567e76ab8f0c4c2eebd</a>
-<blockquote>
-<p>
- Coverity ID 350946<br>
-<br>
- Not checking the return from gdev_prn_get_bits in two places<br>
-<br>
- Again, no way for me to see this CID on the Coverity web interface.<br>
-<br>
-contrib/gdevlx7.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-16 09:55: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=ea274a722040b1186374a96d61715ae96d58c36b">ea274a722040b1186374a96d61715ae96d58c36b</a>
-<blockquote>
-<p>
- Coverity IDs 350943, 350942 and 350947<br>
-<br>
- Not checking the return value from gdev_prn_get_bits() in three places.<br>
-<br>
- Again, cannot see this on the Coverity web interface.<br>
-<br>
-contrib/gdevlx32.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-16 09:52:40 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3a913d9dc801508b19a8d5605e785852e1bfb082">3a913d9dc801508b19a8d5605e785852e1bfb082</a>
-<blockquote>
-<p>
- Coverity ID 350944<br>
-<br>
- Not checking the return value from gdev_prn_get_bits()<br>
-<br>
- Slightly worryingly, I have the email from Coverity describing this<br>
- as a new issue, but I cannot persuade the Coverity web interface to<br>
- display it.<br>
-<br>
-contrib/gdevmd2k.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-16 09:48:23 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8bf3152fe37368b49dcd23535a407c632d7157d2">8bf3152fe37368b49dcd23535a407c632d7157d2</a>
-<blockquote>
-<p>
- Coverity IDs 350945 and 350948<br>
-<br>
- In these routines code can only ever be 0 (OK) or 1 (error). So instead<br>
- of testing for code &lt; 0 we need to test for code &gt; 0 for an error.<br>
-<br>
-devices/gdevicov.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-16 09:31:32 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5a4c29eeea1f0b63cc0b2fff3a1ca0f5b2d143b6">5a4c29eeea1f0b63cc0b2fff3a1ca0f5b2d143b6</a>
-<blockquote>
-<p>
- Coverity IDs 350163, 350949<br>
-<br>
- previous fix for 350163 missed additional unchecked use of xps_fseek()<br>
-<br>
- In addition; copying the cleanup code was not a complete fix, because<br>
- the existing cleanup code had a resource leak which Coverity did not<br>
- previously complain about.....<br>
-<br>
- Fix that too<br>
-<br>
-xps/xpsjxr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-15 18:50:56 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7fc7881b00a43fe1017e593846a0baf28e8837db">7fc7881b00a43fe1017e593846a0baf28e8837db</a>
-<blockquote>
-<p>
- Add simple PWG &quot;interpreter&quot; for gpdl.<br>
-<br>
-base/spwgd.c<br>
-gpdl/gpdl.mak<br>
-gpdl/pwg/pwgtop.c<br>
-pcl/pl/plimpl.c<br>
-windows/ghostpdl.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-15 18:49: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=161adc70e0d6625618c5a6afcb5e04161acc2e2c">161adc70e0d6625618c5a6afcb5e04161acc2e2c</a>
-<blockquote>
-<p>
- Squash a warning about an ininitialised variable.<br>
-<br>
-jpegxr/cw_emit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-15 18:48:55 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b8de03bdb8696517bff0259e827ece4f5746663c">b8de03bdb8696517bff0259e827ece4f5746663c</a>
-<blockquote>
-<p>
- Squash a float -&gt; int warning.<br>
-<br>
-contrib/japanese/gdevlbp3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-15 18:48:26 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=58bee0ad2c67888a52fa02e31de3120673525fda">58bee0ad2c67888a52fa02e31de3120673525fda</a>
-<blockquote>
-<p>
- Squash a double -&gt; float warning.<br>
-<br>
-contrib/gdevdj9.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-13 18:08:20 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=372e4f29d3fcbfeaa83a5ee8cc530cbb948edab7">372e4f29d3fcbfeaa83a5ee8cc530cbb948edab7</a>
-<blockquote>
-<p>
- Squash a warning in gdevcif due to dropping const.<br>
-<br>
-devices/gdevcif.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-15 17:30:23 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=194c53ed02d657159a7be894b6d4b54ce1f435d4">194c53ed02d657159a7be894b6d4b54ce1f435d4</a>
-<blockquote>
-<p>
- Coverity ID 350163 unchecked return value<br>
-<br>
- Check the return value of xps_fseek and throw an error if it fails.<br>
-<br>
-xps/xpsjxr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-15 12:32:50 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83c6e520ee6eddeaa1e548e519eb1b42941e3153">83c6e520ee6eddeaa1e548e519eb1b42941e3153</a>
-<blockquote>
-<p>
- Coverity 102206: use snprintf() to avoid unsafe strcpy() and strcat().<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-15 12:24:36 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=76c088b2b5468c1551c4636dc9d20f5b1ea5da36">76c088b2b5468c1551c4636dc9d20f5b1ea5da36</a>
-<blockquote>
-<p>
- Coverity 102205: cast ushort to final expression type (long) before bit-shift, to avoid sign extension.<br>
-<br>
-pcl/pl/pllfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-15 11:49:17 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b51e2be557128054b0f1e8f6eb4c3b7de506cca2">b51e2be557128054b0f1e8f6eb4c3b7de506cca2</a>
-<blockquote>
-<p>
- Coverity 102204: cast byte to long to avoid possible sign extension.<br>
-<br>
-pcl/pcl/pcwhtidx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-15 11:30:34 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd95eb235f00a600f8b8b99b8929e597283fa96c">dd95eb235f00a600f8b8b99b8929e597283fa96c</a>
-<blockquote>
-<p>
- Coverity 102189: removed less-than-zero comparison of unsigned.<br>
-<br>
-pcl/pl/plfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-15 11:27:53 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=95706a3ced4f1cfa50b2ea48f0095ed9423bafe5">95706a3ced4f1cfa50b2ea48f0095ed9423bafe5</a>
-<blockquote>
-<p>
- Coverity 102173: removed unnecessary comparisons against hpgl_rm_character.<br>
-<br>
-pcl/pcl/pgdraw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-15 14:22:04 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5f24a32f0cc4513dfb9825900d561b3a6771b87c">5f24a32f0cc4513dfb9825900d561b3a6771b87c</a>
-<blockquote>
-<p>
- Coverity ID 350216 - prevent dangling pointer<br>
-<br>
- The variable pdcs is declared an immediately initialised to be<br>
- dsc-&gt;dcs2. Coverity correctly points out that if dsc-&gt;page_count is 1<br>
- we enter dsc_alloc_string, which can call dsc_reset() where,<br>
- if dsc-&gt;dcs2 is set, it will be freed and dsc-&gt;dcs2 will be set to<br>
- Null, leaving pdcs dangling.<br>
-<br>
- By deferring the assignment of pdcs until it is actuallused we can<br>
- be certain that it is valid.<br>
-<br>
-psi/dscparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-15 13:28: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=de9dc99614f86e4aaa0a447766a58447e76ca8c1">de9dc99614f86e4aaa0a447766a58447e76ca8c1</a>
-<blockquote>
-<p>
- Attempted fix for Coverity ID 350194<br>
-<br>
- Thanks to Robin for pointing me at the right bit of code.<br>
-<br>
- There was a pointer cast and address of (&amp;) on an array which was<br>
- already a pointer. This is, of course, silly, so remove the cast and<br>
- &amp;.<br>
-<br>
- At the same time, the quad_glyph_list was using signed shorts to hold<br>
- the Unicode points, when it should have been using unsigned shorts, so<br>
- fix that here too.<br>
-<br>
-devices/vector/gdevagl.h<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-15 08:26:36 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0ea433a1a172298eda11203d698ce6fe69be58d2">0ea433a1a172298eda11203d698ce6fe69be58d2</a>
-<blockquote>
-<p>
- Support CIDFSubstFont being a path/file<br>
-<br>
- Preivously, to use a custom CIDFont substitute in a custom location, it was<br>
- necessary to both both CIDFSubstPath (for the location) and CIDFSubstFont<br>
- (the file name).<br>
-<br>
- We'll now check the CIDFSubstFont value and if it looks like it includes a path<br>
- (i.e. contains a directory/file separator string) then we'll use it as is,<br>
- ignoring the CIDFSubstPath<br>
-<br>
-Resource/Init/gs_cidfm.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-14 13:22:11 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=51aff033bdc8744adfd86ce8b35ef00f23621de2">51aff033bdc8744adfd86ce8b35ef00f23621de2</a>
-<blockquote>
-<p>
- Bug 701903: (ps2write) clean up image enumerator streams.<br>
-<br>
- At the end of an image (especially if the &quot;end&quot; is because of an error<br>
- condition) make sure we clean up any streams created for the handling of the<br>
- image data.<br>
-<br>
- This saves leaving the streams around for gc to cleanup, and avoids a problem<br>
- where a special purpose stream (for color images) holds a reference to a<br>
- color space and graphics state either or both of which could be freed by a<br>
- Postscript restore before the garbager gets called to deal with unreferenced<br>
- objects.<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-14 11:20:40 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=33f4f0c0ba5449fd535061e785090bc57849ae51">33f4f0c0ba5449fd535061e785090bc57849ae51</a>
-<blockquote>
-<p>
- PDF interpreter - don't ignore SUBSTFONT<br>
-<br>
- The PDF interpreter attempts to find a 'better' match for missing fonts<br>
- by using a list of TrueType mappings (eg ArialMT, CourierNew) and a<br>
- list of mappings (gs_font.ps, /.substitutefaces)<br>
-<br>
- Failing to find a match there it attempts to use the FontDescriptor<br>
- Flags if present. As far as I can see that basically means we use<br>
- Times-Roman for serif fonts and Helvetica for sans serif.<br>
-<br>
- This commit checks to see if SUBSTFONT is set. If it is we ignore all<br>
- this nonsense and simply use the substitute font the user told us to.<br>
- Otherwise we continue as before.<br>
-<br>
- The diff is actually very simple, but the routine was very large so<br>
- I decided to move the actual substitution code out into a separate<br>
- function, to simplify the logic in pdffindfont which makes the<br>
- differences appear substantial. All that has really changed is that the<br>
- code to do the substitution, after checking for the existence of a<br>
- FontDescriptor, checks to see if SUBSTFONT is defined. If it is we<br>
- behave as if the font had no FontDescriptor and use the normal font<br>
- substitution machinery.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-07 15:36:55 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=98a8b291b135d49ffca23d9a289786971cf33a12">98a8b291b135d49ffca23d9a289786971cf33a12</a>
-<blockquote>
-<p>
- img language implementation<br>
-<br>
- JPEGs only at this point.<br>
-<br>
-Makefile.in<br>
-gpdl/gpdl.mak<br>
-gpdl/image/imagetop.c<br>
-pcl/pl/plimpl.c<br>
-psi/msvc.mak<br>
-windows/ghostpdl.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-07 15:36:55 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91b104936ec55b3f1f22673d7e286ff67e4e2475">91b104936ec55b3f1f22673d7e286ff67e4e2475</a>
-<blockquote>
-<p>
- Public build changes to accommodate private URF support.<br>
-<br>
- This includes build rubrik for devices to generate URF files<br>
- (urfgray, urfrgb, urfcmyk), a decompression filter for the<br>
- rle variant used in URF files and a urf &quot;language&quot; interpreter<br>
- implementation for gpdl.<br>
-<br>
- Note, this is only the build framework for these things. The<br>
- actual implementation code lives in the private 'urf'<br>
- git module, and will be activated automatically as part of<br>
- the build if it is in position at configure time.<br>
-<br>
-Makefile.in<br>
-base/lib.mak<br>
-base/unix-gcc.mak<br>
-configure.ac<br>
-devices/devs.mak<br>
-gpdl/gpdl.mak<br>
-pcl/pl/plimpl.c<br>
-psi/int.mak<br>
-psi/msvc.mak<br>
-psi/zfilter.c<br>
-windows/ghostpdl.vcproj<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-13 16:35:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af558a708b40a78eef9c0bc5b2ae229d771a3537">af558a708b40a78eef9c0bc5b2ae229d771a3537</a>
-<blockquote>
-<p>
- pdfwrite - Fix XMP emission<br>
-<br>
- Bug #701895 &quot;Ghostscript should leave the rdf:description rdf:about attribute empty (XMP Metadata)&quot;<br>
-<br>
- See the bug thread, it appears this value should be empty and this<br>
- commit makes that change.<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-11 20:14:36 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f63270230f329c6e89375af18d2bf2930421174a">f63270230f329c6e89375af18d2bf2930421174a</a>
-<blockquote>
-<p>
- Fix devices that ignore return codes from gdev_prn get_bits &amp; copy_scan_lines<br>
-<br>
- Discovered these when working on bug 701845 'devicen' device. Checking<br>
- uncovered a plethora of other places that used one of these functions<br>
- assuming success.<br>
-<br>
- Also the gdev_prn_copy_scan_lines had places that assumed the return code<br>
- was a valid line_count, so if negative, could memset many lines in front of<br>
- an allocated buffer.<br>
-<br>
- The code in a few of these usages is strange, and we don't have a way to<br>
- check them, so this may not match the original intent.<br>
-<br>
- Also, while perusing all of these files, check devices for alloc's that<br>
- assume success and fix them (usually return gs_error_VMerror).<br>
-<br>
-base/gdevdevn.c<br>
-devices/gdev3852.c<br>
-devices/gdev4081.c<br>
-devices/gdev4693.c<br>
-devices/gdev8510.c<br>
-devices/gdevatx.c<br>
-devices/gdevbit.c<br>
-devices/gdevbj10.c<br>
-devices/gdevbmp.c<br>
-devices/gdevccr.c<br>
-devices/gdevcdj.c<br>
-devices/gdevcfax.c<br>
-devices/gdevcif.c<br>
-devices/gdevclj.c<br>
-devices/gdevcljc.c<br>
-devices/gdevdjtc.c<br>
-devices/gdevdm24.c<br>
-devices/gdevepsc.c<br>
-devices/gdevepsn.c<br>
-devices/gdevescp.c<br>
-devices/gdevgprf.c<br>
-devices/gdevhl7x.c<br>
-devices/gdevicov.c<br>
-devices/gdevifno.c<br>
-devices/gdevimgn.c<br>
-devices/gdevjbig2.c<br>
-devices/gdevjpx.c<br>
-devices/gdevl31s.c<br>
-devices/gdevlbp8.c<br>
-devices/gdevlj56.c<br>
-devices/gdevlp8k.c<br>
-devices/gdevlxm.c<br>
-devices/gdevmgr.c<br>
-devices/gdevn533.c<br>
-devices/gdevokii.c<br>
-devices/gdevpbm.c<br>
-devices/gdevpdfimg.c<br>
-devices/gdevperm.c<br>
-devices/gdevphex.c<br>
-devices/gdevpjet.c<br>
-devices/gdevpsim.c<br>
-devices/gdevrinkj.c<br>
-devices/gdevsppr.c<br>
-devices/gdevstc.c<br>
-devices/gdevtifs.c<br>
-devices/gdevtknk.c<br>
-devices/gdevtsep.c<br>
-devices/gdevwpr2.c<br>
-devices/gdevxcf.c<br>
-devices/gdevxcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-13 13:51:27 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=97277fcf0f70d482481ac329ce473e5687e7a935">97277fcf0f70d482481ac329ce473e5687e7a935</a>
-<blockquote>
-<p>
- Bug 701906: Fix duplicate call to tiff_from_filep() that caused leak of TIFF object.<br>
-<br>
- The code in tiff_rgb_print_page() did tfdev-&gt;tif = tiff_from_filep(), but<br>
- then calls gdev_tiff_begin_page() which does the same thing, overwriting the<br>
- original tfdev-&gt;tif.<br>
-<br>
- Also changed tiff12_print_page() as it looks to have the same problem.<br>
-<br>
- This fixes:<br>
- ./sanbin/gs -dBATCH -dNOPAUSE -dSAFER -sOutputFile=tmp -sDEVICE=tiff48nc ../bug-701906.pdf<br>
-<br>
-devices/gdevtfnx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-13 14:03:25 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6690c60c3e1be875134150fa4909bff0de7d583f">6690c60c3e1be875134150fa4909bff0de7d583f</a>
-<blockquote>
-<p>
- pdfwrite - For PDF input, copy any UserUnit to the output<br>
-<br>
- If the input is PDF, and the input file uses the ugly UserUnit hack to<br>
- work around MediaBox limits in Acrobat, and the CompatibilityLevel of<br>
- the output is at least PDF 1.6, then do not apply the UserUnit to the<br>
- MediaBox and do not scale the content. Instead pass the value of<br>
- UserUnit to the pdfwrite device and insert it into the output page.<br>
-<br>
- We use a special_op to inquire whether the device would like us to pass<br>
- it the UserUnit. The pdfwrite device checks the current PDF level<br>
- being emitted and either returns true, or false if too low a level is<br>
- requested.<br>
-<br>
- If it returns true the PDF interpreter does not apply the UserUnit<br>
- scaling but instead uses a second special_op to inform the device what<br>
- of the value of UserUnit.<br>
-<br>
- The pdfwrite device adds any non-unity value of UserUnit to the page<br>
- dictionary when emitting it.<br>
-<br>
- If -dNoUserUnit is set we neither apply the UserUnit scaling nor pass it<br>
- to the device.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-Resource/Init/pdf_main.ps<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfp.c<br>
-devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-12 15:51:23 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9e1d2f76cabf84576424af0c38dceef5881c2b21">9e1d2f76cabf84576424af0c38dceef5881c2b21</a>
-<blockquote>
-<p>
- jbig2_hd_new(): return error if params-&gt;GRAYMAX is large enough that N wraps to zero.<br>
-<br>
- This was noticed when investigating coverity warnings about params-&gt;GRAYMAX<br>
- being tainted.<br>
-<br>
-jbig2dec/jbig2_halftone.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-12 15:48:50 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e6d0fcd87934f01d4fb3c3029558fea134fbd086">e6d0fcd87934f01d4fb3c3029558fea134fbd086</a>
-<blockquote>
-<p>
- Attempt to quieten coverity complaints about tainted data from jbig2_get_int32() and jbig2_get_uint32().<br>
-<br>
- E.g. see Coverity p11408:94824.<br>
-<br>
-jbig2dec/jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-12 11:22:41 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d11a43b64a2e623aebdfa34f8ee992887dc5b2b2">d11a43b64a2e623aebdfa34f8ee992887dc5b2b2</a>
-<blockquote>
-<p>
- Coverity p11408:350203: Stop coverity overflow warning about array of floats.<br>
-<br>
- &amp;lutatobparts-&gt;matrix-&gt;cu.u points to something the size of three floats,<br>
- but add_matrixwithbias() takes pointer to nine floats, which makes coverity<br>
- complain.<br>
-<br>
- This fix changes things so that we pass a pointer to something nine floats in<br>
- size, which satisfies coverity.<br>
-<br>
-base/gsicc_create.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-12 10:29: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=24ec06a27df63297796a379c95ee5d4b39040410">24ec06a27df63297796a379c95ee5d4b39040410</a>
-<blockquote>
-<p>
- Bug 701894: fix the '--' and co options<br>
-<br>
- The --, -+ and -@ need to add the file argument to the permit read list<br>
- before attempting to open and interpret them.<br>
-<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-11 13:45:59 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=592fb032180aac0fc22a7c860ef116b38da8ca71">592fb032180aac0fc22a7c860ef116b38da8ca71</a>
-<blockquote>
-<p>
- Coverity p11408:350214: fix use of uninitialised 'file'.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-11 13:41:29 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7da60037b788bec4217f6ee7017e238f541714ae">7da60037b788bec4217f6ee7017e238f541714ae</a>
-<blockquote>
-<p>
- Coverity p11408:350217: avoid memcpy() with same buffers.<br>
-<br>
-pcl/pcl/pcindxed.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-11 12:44:26 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=658e14023fa84232c569ecc5528b77fd35bcf290">658e14023fa84232c569ecc5528b77fd35bcf290</a>
-<blockquote>
-<p>
- Coverity p11408:350197: fix issue by initialising 'file' to NULL.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-11 11:17:57 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=11f8439f49a3704bb4506e02382a0e697e5edf8e">11f8439f49a3704bb4506e02382a0e697e5edf8e</a>
-<blockquote>
-<p>
- Coverity p11408:350178: Stop coverity overflow warning about array of floats.<br>
-<br>
-base/gsicc_create.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-11 12:00:20 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a1747b9267b4aac28e256820c5cea37af299af86">a1747b9267b4aac28e256820c5cea37af299af86</a>
-<blockquote>
-<p>
- Make lack of freetype a hard error<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-24 10:09: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=37a322fb93c5cd1e96a4cad2ffccdc397f7c0ea5">37a322fb93c5cd1e96a4cad2ffccdc397f7c0ea5</a>
-<blockquote>
-<p>
- Reinstate Apple devices (gdevadmp.c) as contrib devices<br>
-<br>
-configure.ac<br>
-contrib/contrib.mak<br>
-contrib/gdevadmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-11 10:21:13 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aad7bcab6a3aedc4e2bfecd7b1e6bf893c299d0e">aad7bcab6a3aedc4e2bfecd7b1e6bf893c299d0e</a>
-<blockquote>
-<p>
- Better solution for commit 68aeff88e95c<br>
-<br>
- This is a simplified (and fixed) solution for the problem addressed in commit<br>
- 68aeff88e95c: instead of assiging to the 'fixed' type, then converting to<br>
- ufixed (wrongly, in the original commit), just go straight to ufixed.<br>
-<br>
- This solves coverity issues: 350493 and 350492<br>
-<br>
-base/gxhintn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-11 10:42:11 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2de09275898086e903a19812fd78e73381f7e71e">2de09275898086e903a19812fd78e73381f7e71e</a>
-<blockquote>
-<p>
- Bug 695873: reverse search to auto-set GenericResourceDir<br>
-<br>
- A -I path like:<br>
-<br>
- /path/to/Resources/share/ghostscript/9.15/Resource/Init<br>
-<br>
- Would cause us to wrongly set GenericResourceDir and the ICCProfilesDir because<br>
- in both cases we'd search the path for the string 'Resource', and end up using:<br>
-<br>
- /path/to/Resource<br>
-<br>
- To work better, this uses the new and non-standard rsearch operator to search<br>
- the path backwards.<br>
-<br>
- I opted not to include the trailing directory separator at this stage because<br>
- that complicates matters with platforms that uses different directory<br>
- separators (Unix vs Windows vs OpenVMS, for example)<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-09 12:51:05 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c198ac5dcb26fadc53074525cabb413e5395cdba">c198ac5dcb26fadc53074525cabb413e5395cdba</a>
-<blockquote>
-<p>
- Clear out gs_gstate at the start of clist playback.<br>
-<br>
- There are some elements of the (stack based) gs_gstate that were not being<br>
- set by either GS_STATE_INIT_VALUES_CLIST, or gs_gstate_initialize, so set<br>
- the entire structure to 0 before setting the values we care about. This<br>
- was prompted by a customer that has made modifications to the clist playback<br>
- that relied on gs_gstate.color[0/1].color_space being NULL or valid, but<br>
- since it is so quick and only happens once per band, go ahead and do it.<br>
-<br>
-base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-09 10:27:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7174b69e6c0027277fe1a9ece341c3380fe7979d">7174b69e6c0027277fe1a9ece341c3380fe7979d</a>
-<blockquote>
-<p>
- Fix PDF 2.0 /Square annotation appearance generation<br>
-<br>
- All the routines to generate annotation appearances are supposed to<br>
- return a boolean value indicating whether an annotation has a valid<br>
- Appearance (returns true, caller must run the appearance stream) or<br>
- the appearance has been generated (false, caller must not attempt to<br>
- run the appearance stream).<br>
-<br>
- The /Square annotation was failing to return false if there was no<br>
- appearance and one had been generated.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-08 17:40:37 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba5b47dc979ca1590f280f482d432705e9b535bf">ba5b47dc979ca1590f280f482d432705e9b535bf</a>
-<blockquote>
-<p>
- Coverity p11408:350177: avoid use of uninitialised state.start.x.<br>
-<br>
- Probably not a problem in practise because we can't get gs_pe_closepat without<br>
- earlier gs_pe_moveto or similar.<br>
-<br>
-base/gdevvec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-08 17:21:38 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a3401e5e4f5828c67d7c65f77a3bb0106753649">4a3401e5e4f5828c67d7c65f77a3bb0106753649</a>
-<blockquote>
-<p>
- Coverity p11408:350167: fixed use of uninitialised gp_file*.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-08 16:40:00 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f44249d69a36fa7233504bdb137af9ff5008ec37">f44249d69a36fa7233504bdb137af9ff5008ec37</a>
-<blockquote>
-<p>
- Coverity Coverity p11408:350165: try to stop coverity warning about array of floats.<br>
-<br>
- Coverity complains about passing &amp;float to something that assumes it is<br>
- float[9]. Trying explicit cast of base object to float*.<br>
-<br>
-base/gsicc_create.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-08 16:25:01 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2029235dc8997314c1925e5786212a6c7331f0cf">2029235dc8997314c1925e5786212a6c7331f0cf</a>
-<blockquote>
-<p>
- Coverity p11408:350164: only call memcpy() if buffers are different.<br>
-<br>
- We could use memmove() instead, but this makes things a little clearer.<br>
-<br>
-pcl/pcl/pcindxed.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-08 12:31:08 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5605c6c6a9677013560a6a3c947f4b100eae4e09">5605c6c6a9677013560a6a3c947f4b100eae4e09</a>
-<blockquote>
-<p>
- Coverity p11408:350160: attempt to avoid coverity issues when calling pl_dict_put().<br>
-<br>
- Coverity doesn't like hard-coded 32 for the size of 'short<br>
- unicode_fontname[16]', so use sizeof().<br>
-<br>
-pcl/pl/pllfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-08 15:13:50 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=95151ae3c3c63100bc7ae958f59b8096e7a0f211">95151ae3c3c63100bc7ae958f59b8096e7a0f211</a>
-<blockquote>
-<p>
- Improve handling of microscopic fonts with text rendering mode 3<br>
-<br>
- Bug #701875 &quot;empty TIFF-file is generated when using -r300, correct output with -r72&quot;<br>
-<br>
- In the past we've seen PDF producers set the text rendering mode to 3<br>
- and then (goodness knows why) set a CTM where one of the scale factors<br>
- is 0. In this case the scale factor isn't 0 but its absolutely minute,<br>
- 5.3x10-6.<br>
-<br>
- This evades our existing code, so here we improve it; we check to see<br>
- if the CTM scales in either direction by a really small amount instead<br>
- of 0 (0.000001).<br>
-<br>
- In addition, we previously tried to patch up the CTM and use it anyway<br>
- but really this is only going to make sense is one scale factor is<br>
- tiny (or 0) and the other is sensible. If that's not the case then<br>
- any displacement due to drawing the text will also be tiny. So lets<br>
- simply ignore it.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-08 12:47:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0f7653fd4f1d1c5bf36719efcd8464eafcd46faf">0f7653fd4f1d1c5bf36719efcd8464eafcd46faf</a>
-<blockquote>
-<p>
- Bug 701870: Use object number from Font rather than FontDescriptor<br>
-<br>
- In case where two CIDFont /Font objects share a /FontDescriptor, because the<br>
- /Font objects can contain different details like /CIDSystemInfo contents and<br>
- /CIDToGIDMap, if we use the object number from the /FontDescriptor to validate<br>
- the instance of the font we should use, we can end up reusing a (Postscript)<br>
- font when we shouldn't. This can result in garbled or missing glyphs.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-08 12:08: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=6882df85d37819d849476cf2b4822a90e64d9b24">6882df85d37819d849476cf2b4822a90e64d9b24</a>
-<blockquote>
-<p>
- Add a couple of FIXMEs to the xps interpreter.<br>
-<br>
-xps/xpsimage.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-08 12:08:24 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b7fac758d046c82d65fa69dd2c4bc0f1cf9712bc">b7fac758d046c82d65fa69dd2c4bc0f1cf9712bc</a>
-<blockquote>
-<p>
- Remove unused gpdlpsi.mak file.<br>
-<br>
-gpdl/psi/gpdlpsi.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-08 11:32:41 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=328d27b3cccc89c4ff60529106489a9a635f0f72">328d27b3cccc89c4ff60529106489a9a635f0f72</a>
-<blockquote>
-<p>
- Bug 701854: bj10v_print_page(): increase buffer by one byte to give space for sentinel.<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -r928 -sOutputFile=tmp -sDEVICE=bj10v ../bug-701854.ps<br>
-<br>
-contrib/japanese/gdev10v.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-07 10:08: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=68aeff88e95ccfd1af430fe180597d624ad9f47e">68aeff88e95ccfd1af430fe180597d624ad9f47e</a>
-<blockquote>
-<p>
- Old Type 1 hinter: protect against signed overflow<br>
-<br>
- To avoid overflow during hinting, we tweak the balance of the size of the<br>
- coordinates and the scaling in the hinter (this is only dealing with coords<br>
- so large that hinting is largely pointless anyway).<br>
-<br>
- But the code that does that didn't protect against signed overflow in the<br>
- starting coordinates.<br>
-<br>
- This is a naive protection to prevent an infinite (or near so) loop, but<br>
- a) it's old code that shouldn't be in use anymore, and b) in practice it will<br>
- make no difference to rendering with coordinates that large.<br>
-<br>
-base/gxhintn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-06 14:17: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=713645137a2fc483e5509bfd0f92d7311faeb614">713645137a2fc483e5509bfd0f92d7311faeb614</a>
-<blockquote>
-<p>
- Some more transparency ops doc tweaks<br>
-<br>
-doc/Language.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-07 16:55:15 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c3af6e12e4448b519d2b48c2047c0c83b3cf082">6c3af6e12e4448b519d2b48c2047c0c83b3cf082</a>
-<blockquote>
-<p>
- Coverity issue 102147:323319: transform_pixel_region_render_skew(): don't return pointer to local data.<br>
-<br>
-base/gdevdflt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-07 16:18:32 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=66878fb30f37b06a532fdce39991f31642cdb09b">66878fb30f37b06a532fdce39991f31642cdb09b</a>
-<blockquote>
-<p>
- Bug 701856: fix bad bracketting in original fix.<br>
-<br>
-devices/gdevepsn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-07 16:13:06 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=76db3df8090127482960b742f15831e59816a05e">76db3df8090127482960b742f15831e59816a05e</a>
-<blockquote>
-<p>
- Coverity issue 102147: initialise gx_device_color::type.<br>
-<br>
- Might fix Coverity issue in base/gxiscale.c.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-07 12:34:24 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9caccf9f09e06324f07822cc55e1737d881c6eb3">9caccf9f09e06324f07822cc55e1737d881c6eb3</a>
-<blockquote>
-<p>
- Bug 701856: fixed buffer overflow in devices/gdevepsn.c.<br>
-<br>
- Need to protect aginst overflow with high x_dpi when using local<br>
- graphics_modes_24[] or graphics_modes_9[] arrays.<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -dBATCH -dNOPAUSE -r914 -sOutputFile=tmp -sDEVICE=eps9high ../bug-701856.pdf<br>
-<br>
-devices/gdevepsn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-07 11:57:35 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=018003614ad80910ca2c009eb1d523e8015756bc">018003614ad80910ca2c009eb1d523e8015756bc</a>
-<blockquote>
-<p>
- Bug 701849: Fix buffer overflow in devices/gdevhl7x.c.<br>
-<br>
- High values of pdev-&gt;x_pixels_per_inch result in Summary::pageWidth being<br>
- greater than Summary::previousData's fixed size of 1500 bytes, which causes<br>
- buffer overflow in resetPreviousData() (and possibly other places too).<br>
-<br>
- So have changed to initSummary() to allocate Summary::previousData using<br>
- gs_malloc(), and added freeSummary() to clean up.<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -r968 -dFitPage -dUseCropBox -sPAPERSIZE=legal -sOutputFile=tmp -sDEVICE=hl7x0 ../bug-701849.pdf<br>
-<br>
-devices/gdevhl7x.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-06 15:25:12 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7da3de0c7662491fa2a0b6f5a638848bcf13a5fa">7da3de0c7662491fa2a0b6f5a638848bcf13a5fa</a>
-<blockquote>
-<p>
- Bug 701847: make pj_common_print_page() work with any line_size.<br>
-<br>
- Much of the code used to be hard-coded for fixed LINE_SIZE.<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -dBATCH -dNOPAUSE -sOutputFile=tmp -sDEVICE=lj250 ../bug-701847.pdf<br>
-<br>
-devices/gdevpjet.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-06 14:44:13 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=494eeedf73d13fac5710e56f3a8fb2e7e2379d73">494eeedf73d13fac5710e56f3a8fb2e7e2379d73</a>
-<blockquote>
-<p>
- Bug 701846: fix use of uninitialised data in clj_media_size().<br>
-<br>
- If param_read_float_array() fails, fres.data[] is unset. The values to use are<br>
- always in res[].<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -dBATCH -dNOPAUSE -dSAFER -dFIXEDMEDIA -sOutputFile=tmp -sDEVICE=cljet5pr ../bug-701846.pdf<br>
-<br>
-devices/gdevclj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-06 12:41:28 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f6bc662909ab79e8fbe9822afb36e8a0eafc2b7">4f6bc662909ab79e8fbe9822afb36e8a0eafc2b7</a>
-<blockquote>
-<p>
- Bug 701844: fixed output buffer size worst case in lp8000_print_page().<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -dBATCH -dNOPAUSE -dSAFER -dFIXEDMEDIA -sPAPERSIZE=legal -sOutputFile=tmp -sDEVICE=lp8000 ../bug-701844.pdf<br>
-<br>
-devices/gdevlp8k.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-06 16:46: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=ce681338646435ca064ab2d1b8bde1614e5ed3f1">ce681338646435ca064ab2d1b8bde1614e5ed3f1</a>
-<blockquote>
-<p>
- PDF interpreter - preserve colour space on Image XObjects with Do<br>
-<br>
- No bug number the customer file is large and looks confidential.<br>
-<br>
- The problem is that the PDF file sets a custom colour space, then<br>
- draws an image, the image is in a different colour space (DeviceRGB),<br>
- the file then sets a new colour in the original space.<br>
-<br>
- The PDF interpreter was changing the colour space in order to draw<br>
- the image, but was not resetting it afterwards, which meant that the<br>
- attempt to set the colour failed as the colour space was inappropriate.<br>
-<br>
- I'm *amazed* this hasn't arisen before, its so clearly wrong.<br>
-<br>
- This commit gets the colour space before executing the image, and puts<br>
- it back again afterwards. We have to be careful to do the restoration<br>
- in a stopped context because this code can be called when drawing a<br>
- glyph, and we are not permitted to change colour space while in an<br>
- uncoloured glyph, it throws an error.<br>
-<br>
- In addition, the appearance generation for /Square annotations (and<br>
- other types) was setting the colour space to white and filling the<br>
- annotation rectangle, even if the /IC (Interior Color) key was not<br>
- present. Acrobat appears not to do this so I've modified the code to<br>
- not fill the annotation if there is no /IC in the annotation dictionary.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-06 11:56:07 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e713293de84b689c4ab358f3e110ea54aa81925">4e713293de84b689c4ab358f3e110ea54aa81925</a>
-<blockquote>
-<p>
- Bug 701843: avoid divide by zero in devices/gdevepsc.c:epsc_print_page().<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -dBATCH -dNOPAUSE -dSAFER -r8 -dNOCIE -dFitPage -sOutputFile=tmp -sDEVICE=epsonc ../bug-701843.pdf<br>
-<br>
-devices/gdevepsc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-06 11:46:10 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f70ab2044429fe4b991801476ea3f4b4a5c0cdf4">f70ab2044429fe4b991801476ea3f4b4a5c0cdf4</a>
-<blockquote>
-<p>
- Bug 701843: avoid divide by zero caused by custom resolution being too low.<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -dBATCH -dNOPAUSE -dSAFER -r8 -dNOCIE -dFitPage -sOutputFile=tmp -sDEVICE=eps9mid ../bug-701843.pdf<br>
-<br>
-devices/gdevepsn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-06 11:18:55 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ce2afc4f02617dee51f3322ae8386c4b46047c18">ce2afc4f02617dee51f3322ae8386c4b46047c18</a>
-<blockquote>
-<p>
- Bug 701842: avoid buffer overflow in lxm5700m_print_page().<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -dBATCH -sOutputFile=tmp -sDEVICE=lxm5700m ../bug-701842.ps<br>
-<br>
-devices/gdevlxm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-05 18:18:50 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=027c546e0dd11e0526f1780a7f3c2c66acffe209">027c546e0dd11e0526f1780a7f3c2c66acffe209</a>
-<blockquote>
-<p>
- Bug 701842: Fix misindexing in gxicolor.c<br>
-<br>
- We were incorrectly decrementing position per-component, rather<br>
- than per-pixel (in 2 places).<br>
-<br>
- Also, take care of some whitespace oddities.<br>
-<br>
-base/gxicolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-05 15:02:23 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1159afbcad927e1a32008b0ab87e257fc21da8e2">1159afbcad927e1a32008b0ab87e257fc21da8e2</a>
-<blockquote>
-<p>
- Ensure strncpy() terminates when called from pjl_parsed_filename_to_string().<br>
-<br>
- Passing strlen()+1 to strncpy() ensures that it will terminate the<br>
- string. Possibly not required here because the code always terminates the<br>
- string, but this might fix coverity issue 102147.<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-05 14:59:56 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=67b4efc310af7bf9d30f84a70c6b9858ab138e3d">67b4efc310af7bf9d30f84a70c6b9858ab138e3d</a>
-<blockquote>
-<p>
- Bug 701809: Fix out oob access in transform_pixel_region.<br>
-<br>
- When collating pixels to write out using copy_color,<br>
- we can only write within our array. Clip maxx/minx accordingly.<br>
-<br>
-base/gdevdflt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-05 14:54:22 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=02c566b4b5f3f60ff8ebd7f4523722c39c2d72e7">02c566b4b5f3f60ff8ebd7f4523722c39c2d72e7</a>
-<blockquote>
-<p>
- Memento: Unlock a block with valgrind before checking it.<br>
-<br>
- This avoids false positives on closedown.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-05 13:36:04 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f38c6b08c6582872af25fc669a5fd3bde9f32753">f38c6b08c6582872af25fc669a5fd3bde9f32753</a>
-<blockquote>
-<p>
- Bug 701831: fixed buffer overflow in bjc_compress().<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -dBATCH -dNOPAUSE -sOutputFile=tmp -sDEVICE=bjc800 ../bug-701831.ps<br>
-<br>
-devices/gdevcdj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-05 12:03:23 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b25cad42dc869e8e9d7ea58adae2c8baba0ee25d">b25cad42dc869e8e9d7ea58adae2c8baba0ee25d</a>
-<blockquote>
-<p>
- Bug 701830: avoid buffer overflow in lips_rle_encode().<br>
-<br>
- Worst case for lips_rle_encode() is 2*Length+2, so adjust corresponding alloc<br>
- to match.<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -dBATCH -dNOPAUSE -r489 -dFitPage -sOutputFile=tmp -sDEVICE=lips4 ../bug-701830.eps<br>
-<br>
-contrib/lips4/gdevl4r.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-05 10:49:58 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e7118494be4162b8c2c06d8b7d4cb2d7ebb57f61">e7118494be4162b8c2c06d8b7d4cb2d7ebb57f61</a>
-<blockquote>
-<p>
- Add -dALLOWPSTRANSPARENCY to the documentation.<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-05 09:45:27 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=485904772c5f0aa1140032746e5a0abfc40f4cef">485904772c5f0aa1140032746e5a0abfc40f4cef</a>
-<blockquote>
-<p>
- Bug 701841: remove .forceput from /.charkeys<br>
-<br>
- When loading Type 1 or Truetype fonts from disk, we attempt to extend the glyph<br>
- name table to include all identifiable glyph names from the Adobe Glyph List.<br>
-<br>
- In the case of Type 1 fonts, the font itself (almost always) marks the<br>
- CharStrings dictionary as read-only, hence we have to use .forceput for that<br>
- case.<br>
-<br>
- But for Truetype fonts, the CharStrings dictionary is created internally and is<br>
- not read-only until *after* we have fully populated it (including the extended<br>
- glyph names from the AGL), hence there is no need for .forceput, and no need to<br>
- carry the security risk of using it.<br>
-<br>
- Replace with regular put.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-04 14:23:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=94d8955cb7725eb5f3557ddc02310c76124fdd1a">94d8955cb7725eb5f3557ddc02310c76124fdd1a</a>
-<blockquote>
-<p>
- Bug 701818: better handling of error during PS/PDF image<br>
-<br>
- In the xps device, if an error occurred after xps_begin_image() but before<br>
- xps_image_end_image(), *if* the Postscript had called 'restore' as part of the<br>
- error handling, the image enumerator would have been freed (by the restore)<br>
- despite the xps device still holding a reference to it.<br>
-<br>
- Simply changing to an allocator unaffected save/restore doesn't work because<br>
- the enumerator holds references to other objects (graphics state, color space,<br>
- possibly others) whose lifespans are inherently controlled by save/restore.<br>
-<br>
- So, add a finalize method for the XPS device's image enumerator<br>
- (xps_image_enum_finalize()) which takes over cleaning up the memory it allocates<br>
- and also deals with cleaning up references from the device to the enumerator<br>
- and from the enumerator to the device.<br>
-<br>
-devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 15:30:19 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39b4cdb491c3e09434f5d2b9c334a898fb569850">39b4cdb491c3e09434f5d2b9c334a898fb569850</a>
-<blockquote>
-<p>
- Update docs for current state of transparency ops<br>
-<br>
-doc/Language.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 10:19: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=d1eac80695b2c6f2a85942a82518715549541969">d1eac80695b2c6f2a85942a82518715549541969</a>
-<blockquote>
-<p>
- Add the ability to allow transparency ops in Postscript<br>
-<br>
- -dALLOWPSTRANSPARENCY on the command line will prevent the undefining of the<br>
- non-standard gs Postscript transparency operators.<br>
-<br>
- Driving these operators in the wrong way can cause undefined behavior, hence<br>
- not allowing them normally.<br>
-<br>
- Also, use a better condition for dropping the transparency ops in:<br>
- examples/transparency_example.ps<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/pdf_main.ps<br>
-examples/transparency_example.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-05 08:50: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=27409d99b069e434c6863f43456cf8985bbdf7f8">27409d99b069e434c6863f43456cf8985bbdf7f8</a>
-<blockquote>
-<p>
- Fix the quad glyph table<br>
-<br>
- This might fix Coverity ID 350194. Even if it doesn't it is incorrect<br>
- so fix the initialisation of the table.<br>
-<br>
-devices/vector/gdevagl.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-05 08:48:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=407c98a38c3a6ac1681144ed45cc2f4fc374c91f">407c98a38c3a6ac1681144ed45cc2f4fc374c91f</a>
-<blockquote>
-<p>
- txtwrite - guard against using GS_NO_GLYPH to retrieve Unicode values<br>
-<br>
- Bug 701822 &quot;Segmentation fault at psi/iname.c:296 in names_index_ref&quot;<br>
-<br>
- Avoid using a glyph with the value GS_NO_GLYPH to retrieve a glyph<br>
- name or Unicode code point from the glyph ID, as this is not a valid<br>
- ID.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-psi/zbfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-04 16:12:04 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af004276fd8f6c305727183c159b83021020f7d6">af004276fd8f6c305727183c159b83021020f7d6</a>
-<blockquote>
-<p>
- Bug 701829: ep_print_image(): protect against memcmp() beyond buffer.<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -dBATCH -dNOPAUSE -r12 -sOutputFile=tmp -sDEVICE=escp ../bug-701829.pdf<br>
-<br>
-devices/gdevcdj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-01 11:55:23 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f73e8b4d578e69a17f452fa60d2130c5faaefd6">4f73e8b4d578e69a17f452fa60d2130c5faaefd6</a>
-<blockquote>
-<p>
- Fix bugs 701787, 701806, 701810. Problems with cdj970 device.<br>
-<br>
- As Robin mentioned in bug 701787, the device was changing resolution AFTER<br>
- the device had been opened and all of the buffers configured.<br>
-<br>
- Move the &quot;one time&quot; initial setup into the open function, leaving the code<br>
- to write the header in the print_page function. Presumably that only needs<br>
- to be written once even if there are multiple pages.<br>
-<br>
- Also add a check for valid resolutions since it appears that the intent was<br>
- to have the &quot;Quality&quot; parameter set up 300 or 600 dpi. Other deskjet devices<br>
- have this type of check.<br>
-<br>
- Add a gs_closedevice if the Quality is changed since this will change the<br>
- resolution and thus the page buffer geometry.<br>
-<br>
- Lastly, fix cdj970_put_params so that errors are not ignored for all but the<br>
- last (which happened to be BlackCorrect).<br>
-<br>
- These changes prevent the bugs cited, but remain untested except for some<br>
- parameter testing to make sure bad values don't cause memory violations. It<br>
- does seem that some parameter values that are out of range (like Quality) are<br>
- ignored, but that may be intentional.<br>
-<br>
-contrib/gdevdj9.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-04 15:32:04 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eaba1d97b62831b42c51840cc8ee2bc4576c942e">eaba1d97b62831b42c51840cc8ee2bc4576c942e</a>
-<blockquote>
-<p>
- Bug 701828: make dot24_print_page() return error instead of divide by zero.<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -dBATCH -dNOPAUSE -dSAFER -r2 -sOutputFile=tmp -sDEVICE=necp6 ../bug-701828.pdf<br>
-<br>
-devices/gdevdm24.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-04 13:00:04 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6f7464dddc689386668a38b92dfd03cc1b38a10">a6f7464dddc689386668a38b92dfd03cc1b38a10</a>
-<blockquote>
-<p>
- Bug 701827: fixed incorrect buffer expansion in lxm5700m_print_page().<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -dBATCH -dNOPAUSE -r425 -dFitPage -sOutputFile=tmp -sDEVICE=lxm5700m ../bug-701827.eps<br>
-<br>
-devices/gdevlxm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-04 12:30:33 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2793769ff107d8d22dadd30c6e68cd781b569550">2793769ff107d8d22dadd30c6e68cd781b569550</a>
-<blockquote>
-<p>
- Bug 701819: fixed ordering in if expression to avoid out-of-bounds access.<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -dBATCH -dNOPAUSE -r965 -sOutputFile=tmp -sDEVICE=pcx16 ../bug-701819.pdf<br>
-<br>
-devices/gdevpcx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-01 18:09:30 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=366ad48d076c1aa4c8f83c65011258a04e348207">366ad48d076c1aa4c8f83c65011258a04e348207</a>
-<blockquote>
-<p>
- Bug 701815: avoid uninitialised bytes being &gt;7, which broke indexing.<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -dBATCH -dNOPAUSE -sOutputFile=tmp -sDEVICE=jetp3852 ../bug-701815.pdf<br>
-<br>
-devices/gdev3852.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-01 14:55:16 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ec065fd285f8064ac34cc160106dd730569ebc75">ec065fd285f8064ac34cc160106dd730569ebc75</a>
-<blockquote>
-<p>
- Clear eol padding bits in &quot;atx&quot; devices.<br>
-<br>
- This upsets the blank line detection and therefore can randomly<br>
- change the output.<br>
-<br>
-devices/gdevatx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-01 14:26: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=e4dce29961108c6fef5c02bf4d5e527b265bf8d8">e4dce29961108c6fef5c02bf4d5e527b265bf8d8</a>
-<blockquote>
-<p>
- Mask eol padding bits for pngmono device in CLUSTER builds.<br>
-<br>
-devices/gdevpng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-01 14:24:08 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9076e48cf91ba6bf4e939b0562c53e6cbb62282e">9076e48cf91ba6bf4e939b0562c53e6cbb62282e</a>
-<blockquote>
-<p>
- Fix previous planm eol masking fix.<br>
-<br>
- The previous attempt to fix the masking of eol padding bits<br>
- for planm would have failed in the width == multiple of 8 case.<br>
- Also make it dependent on CLUSTER here.<br>
-<br>
-devices/gdevplan.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-01 12:38:41 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1126deff06d81d4fa1975ea0ed3a3b64e9cf0661">1126deff06d81d4fa1975ea0ed3a3b64e9cf0661</a>
-<blockquote>
-<p>
- Update &quot;planm&quot; device to clear eol padding bits.<br>
-<br>
- This should avoid md5 changes in the alldevs cluster test.<br>
-<br>
-devices/gdevplan.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-01 12:22:55 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bcb881e566d90ae43648085ff1edfdcddcd6eb50">bcb881e566d90ae43648085ff1edfdcddcd6eb50</a>
-<blockquote>
-<p>
- Fix &quot;cif&quot; device in CLUSTER builds.<br>
-<br>
- Use a hardcoded &quot;clusterout&quot; filename for embedding rather<br>
- than the real one in CLUSTER builds. This stops the md5sum<br>
- from changing randomly.<br>
-<br>
-devices/gdevcif.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-11-01 10:26: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=aadb53eb834b3def3ef68d78865ff87a68901804">aadb53eb834b3def3ef68d78865ff87a68901804</a>
-<blockquote>
-<p>
- Tiffsep and Tiffsep1 - abort on multi-page input wtithout %d OutputFile<br>
-<br>
- Bug #701821 &quot;Segmentation fault at tiff//libtiff/tif_dirinfo.c:513 in TIFFFindField&quot;<br>
-<br>
- The tiffsep and tiffsep1 only set 'code' to an error when an attempt is<br>
- made to write a second output file without using %d in the OutputFile<br>
- specification.<br>
-<br>
- This causes problems later when attempting to process the files. The<br>
- devices should exit without trying to further process the pages under<br>
- these conditions and this commit returns immediately on error.<br>
-<br>
- The other devices like this already return immediately on error, it<br>
- looks like the code here was copied between devices without realising<br>
- that the tiffsep and tiffsep1 devices didn't exit when the error<br>
- condition was set.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 19:47:13 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9c196bb7f6873b4fe43a649fc87cba363c6af8e5">9c196bb7f6873b4fe43a649fc87cba363c6af8e5</a>
-<blockquote>
-<p>
- Fix devicen device for new file security world.<br>
-<br>
- Again, update the code to allow spot files to be written.<br>
-<br>
-base/gdevdevn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 19:24:44 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6e36c29b69b4d15aac872e37303dcf9cb8d7739">a6e36c29b69b4d15aac872e37303dcf9cb8d7739</a>
-<blockquote>
-<p>
- Update spotcmyk device for new file access security.<br>
-<br>
- This device writes the data to a file, then reads it back in,<br>
- and writes out various spot &quot;.pcx&quot; files. Accordingly we<br>
- need to make the file readable too, and then make the .pcx<br>
- files writable.<br>
-<br>
-base/gdevdevn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 18:21: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=dbdb5f8527007b482d4e6037b558dbf3e6a06d3a">dbdb5f8527007b482d4e6037b558dbf3e6a06d3a</a>
-<blockquote>
-<p>
- Fix spurious rangechecks from cljet5pr device.<br>
-<br>
- The device would rangecheck whenever it was called with a<br>
- param list that didn't contain HWResolution. Now, if it's<br>
- not given an HWResolution, look at the device's current<br>
- value.<br>
-<br>
-devices/gdevclj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 17:42:48 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f5673b5a50f141440329c62ee5b53eefcd585a3f">f5673b5a50f141440329c62ee5b53eefcd585a3f</a>
-<blockquote>
-<p>
- pdfimg: Avoid ID's varying by filename in CLUSTER builds.<br>
-<br>
- This was upsetting the alldevs runs.<br>
-<br>
-devices/gdevpdfimg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 17:01:42 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5bc53eb7223f8999882a5d8e2e35c27fe7a0b57">b5bc53eb7223f8999882a5d8e2e35c27fe7a0b57</a>
-<blockquote>
-<p>
- Bug 701788: added comment about asn/valgrind detecting leaks in fontconfig.<br>
-<br>
-base/gp_unix.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 16:22: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=255eef0a7d9d24962ebbcbb4b1858e44b803f16b">255eef0a7d9d24962ebbcbb4b1858e44b803f16b</a>
-<blockquote>
-<p>
- mgr4 device: clear any unused trailing bits for each line.<br>
-<br>
- This avoids valgrind errors and varying md5sums in the alldevs<br>
- cluster test.<br>
-<br>
-devices/gdevmgr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 16:21:06 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=351a2251b4a80fa31ac15229036318b01d124532">351a2251b4a80fa31ac15229036318b01d124532</a>
-<blockquote>
-<p>
- Squash warning caused by previous fix.<br>
-<br>
- Include the correct header for 'free' before using it.<br>
-<br>
-contrib/eplaser/gdevescv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 13:12:47 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f54414c8b15b2c27d1dcadd92cfe84f6d15f18dc">f54414c8b15b2c27d1dcadd92cfe84f6d15f18dc</a>
-<blockquote>
-<p>
- Bug 701808: return error from okiibm_print_page1() if x_dpi too high.<br>
-<br>
- Avoids asan error in:<br>
- ./sanbin/gs -dBATCH -dNOPAUSE -dSAFER -r599 -sOutputFile=tmp -sDEVICE=okiibm ../bug-701808.pdf<br>
-<br>
-devices/gdevokii.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 15:36:22 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=464107095e614d54417ffd2bedbdc852efee0961">464107095e614d54417ffd2bedbdc852efee0961</a>
-<blockquote>
-<p>
- Update lbp8 device to not use a fixed sized buffer for line data.<br>
-<br>
-devices/gdevlbp8.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 14:25:25 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5eaccd845c9957dff754ebfdde417fe5d82e5e82">5eaccd845c9957dff754ebfdde417fe5d82e5e82</a>
-<blockquote>
-<p>
- Update vdb.pl script to latest version.<br>
-<br>
-toolbin/vdb.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 14:17:38 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d998f17c495a12b04904113ff676c7427089883">0d998f17c495a12b04904113ff676c7427089883</a>
-<blockquote>
-<p>
- Fix gdevescv for operation with Memento.<br>
-<br>
- Blocks returned by system malloc can't be freed by Memento_free.<br>
-<br>
- Also, avoid a problem in CLUSTER builds.<br>
-<br>
-contrib/eplaser/gdevescv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 11:55:38 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=714e8995cd582d418276915cbbec3c70711fb19e">714e8995cd582d418276915cbbec3c70711fb19e</a>
-<blockquote>
-<p>
- Bug 701807: avoid buffer overflow in tiff12_print_page().<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -r650 -sOutputFile=tmp -sDEVICE=tiff12nc ../bug-701807.pdf<br>
-<br>
-devices/gdevtfnx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 10:33:10 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c64d06deea998199a0e30180fd884286b4b2256c">c64d06deea998199a0e30180fd884286b4b2256c</a>
-<blockquote>
-<p>
- Nobble various uses of &quot;time&quot; in the code in CLUSTER builds.<br>
-<br>
- This causes the bjccolor device at least to give indeterminate<br>
- results. Nobbling the rest won't hurt.<br>
-<br>
-contrib/eplaser/gdevescv.c<br>
-contrib/gdevbjca.c<br>
-devices/gdevpdfimg.c<br>
-devices/gdevtifs.c<br>
-devices/vector/gdevpdfe.c<br>
-devices/vector/gdevpsu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 10:31:24 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bf72f1a3dd5392ee8291e3b1518a0c2c5dc6ba39">bf72f1a3dd5392ee8291e3b1518a0c2c5dc6ba39</a>
-<blockquote>
-<p>
- Fix valgrind problems with gdevbjca.c<br>
-<br>
- 2 problems here. Firstly, we could access off the end of a row<br>
- while looking for runs. Change the indexing to fix this.<br>
-<br>
- Secondly, we could overrun our gamma tables due to unexpectedly<br>
- large values. Add some clamping.<br>
-<br>
-contrib/gdevbjca.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 10:29:32 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa7f0cde80ce734ddc22bde34d121c1be5c7deb4">fa7f0cde80ce734ddc22bde34d121c1be5c7deb4</a>
-<blockquote>
-<p>
- Fix various incorrect casts in contrib devices.<br>
-<br>
- Various contrib devices cast a gx_color_index (a 32 or 64<br>
- bit value typically containing 24 bits of data) down to<br>
- a gx_color_value before manipulating it. This is a typo,<br>
- copied into several places in the code. Correct it here.<br>
-<br>
-contrib/gdevcd8.c<br>
-contrib/gdevdj9.c<br>
-contrib/japanese/gdevmjc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-31 10:17:09 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f1fd4a73480c5a2f900b1541b45a62ffcc75e12d">f1fd4a73480c5a2f900b1541b45a62ffcc75e12d</a>
-<blockquote>
-<p>
- Fix warnings when building contrib on windows.<br>
-<br>
- MSVC is much more sensitive to casting types than gcc is, it<br>
- seems. Accordingly avoid making doubles when we want floats, and<br>
- make all casts down to int (or byte) explicit.<br>
-<br>
-base/gxdevice.h<br>
-contrib/gdevbjc_.c<br>
-contrib/gdevbjc_.h<br>
-contrib/gdevcd8.c<br>
-contrib/gdevdj9.c<br>
-contrib/gdevgdi.c<br>
-contrib/gdevln03.c<br>
-contrib/gdevlx32.c<br>
-contrib/gdevmd2k.c<br>
-contrib/gdevop4w.c<br>
-contrib/japanese/gdev10v.c<br>
-contrib/japanese/gdevalps.c<br>
-contrib/japanese/gdevespg.c<br>
-contrib/japanese/gdevmjc.c<br>
-contrib/japanese/gdevnpdl.c<br>
-contrib/japanese/gdevrpdl.c<br>
-contrib/lips4/gdevl4r.c<br>
-contrib/lips4/gdevlips.h<br>
-contrib/pcl3/eprn/mediasize.c<br>
-contrib/pcl3/eprn/mediasize.h<br>
-contrib/pcl3/src/gdevpcl3.c<br>
-contrib/pcl3/src/pclcap.c<br>
-contrib/pcl3/src/pclgen.c<br>
-devices/gdevphex.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-30 17:40:18 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=67a101f3eb888bc651cc13bfb06280a669a84967">67a101f3eb888bc651cc13bfb06280a669a84967</a>
-<blockquote>
-<p>
- Fix contrib.mak to work on windows.<br>
-<br>
- Building Debug-contrib|win32 will currently attempt to run<br>
- contrib.mak 3 times due to poor commenting out of make lines.<br>
- For me, this manifested itself as new instances of Visual<br>
- Studio starting up and attempting to &quot;upgrade&quot; the makefile.<br>
-<br>
-contrib/contrib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-29 17:16: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=4fcbece468706e0e89ed2856729b2ccacbc112be">4fcbece468706e0e89ed2856729b2ccacbc112be</a>
-<blockquote>
-<p>
- Avoid some devices dying due to inappropriate resolutions.<br>
-<br>
-contrib/japanese/gdev10v.c<br>
-contrib/japanese/gdevalps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-29 16:01:39 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=19cebe708b9ee3d9e0f8bcdd79dbc6ef9ddc70d2">19cebe708b9ee3d9e0f8bcdd79dbc6ef9ddc70d2</a>
-<blockquote>
-<p>
- Avoid division by zero with bj10v device.<br>
-<br>
- When called with a low resolution, we can end up dividing by zero.<br>
- Spot this in the open call and give a rangecheck error.<br>
-<br>
-contrib/japanese/gdev10v.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-29 17:28:53 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=849e74e5ab450dd581942192da7101e0664fa5af">849e74e5ab450dd581942192da7101e0664fa5af</a>
-<blockquote>
-<p>
- Bug 701799: avoid out-of-range array access in mj_color_correct().<br>
-<br>
- Code is obscure, so this fix merely avoids out-of-range access in the simplest<br>
- way possible, without understanding what the code is trying to do.<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -sOutputFile=tmp -sDEVICE=mj6000c ../bug-701799.pdf<br>
-<br>
-contrib/japanese/gdevmjc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-29 16:49:13 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=89f58f1aa95b3482cadf6977da49457194ee5358">89f58f1aa95b3482cadf6977da49457194ee5358</a>
-<blockquote>
-<p>
- Bug 701794: check for x_dpi out of range in epsc_print_page().<br>
-<br>
- Avoids out-of-bounds of local arrays graphics_modes_9 and graphics_modes_24.<br>
-<br>
- Larger diff than would like, because can't return error from within<br>
- declarations in old-style C.<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -r680 -sOutputFile=tmp -sDEVICE=epsonc ../bug-701794.pdf<br>
-<br>
-devices/gdevepsc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-29 16:20:56 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=863ada11f9a942a622a581312e2be022d9e2a6f7">863ada11f9a942a622a581312e2be022d9e2a6f7</a>
-<blockquote>
-<p>
- Bug 701793: check we are within buffer before comparing buffer contents.<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -sOutputFile=tmp -sDEVICE=mj700v2c ../bug-701793.pdf<br>
-<br>
-contrib/japanese/gdevmjc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-29 15:49:25 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9f39ed4a92578a020ae10459643e1fe72573d134">9f39ed4a92578a020ae10459643e1fe72573d134</a>
-<blockquote>
-<p>
- Bug 701792: Avoid going beyond buffer in GetNumSameData() and GetNumWrongData().<br>
-<br>
- GetNumSameData() compared buffer contents before checking that we are still<br>
- within bounds of buffer, which caused the bug.<br>
-<br>
- Have made similar fix to GetNumWrongData() because it has similar error.<br>
-<br>
- Fixes address sanitizer error in:<br>
- ./sanbin/gs -sOutputFile=tmp -sDEVICE=lips4v ../bug-701792.pdf<br>
-<br>
-contrib/lips4/gdevlips.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-29 14:13:25 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d31e25ed5b130499e0d880e4609b1b4824699768">d31e25ed5b130499e0d880e4609b1b4824699768</a>
-<blockquote>
-<p>
- Bug 701788: include space for string terminator in call to malloc in cif_print_page().<br>
-<br>
- Fixes ./sanbin/gs -sOutputFile=tmp -sDEVICE=cif ../bug-701788.pdf<br>
-<br>
-devices/gdevcif.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-28 17:29: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=6e6c69487094b877bc56fcc07b9840f6e5b95925">6e6c69487094b877bc56fcc07b9840f6e5b95925</a>
-<blockquote>
-<p>
- Bug #701803, fix missing Greek symbols.<br>
-<br>
- New symbol set ISO/IEC 8859-7 Latin/Greek alphabet added.<br>
-<br>
-pcl/pl/plsymbol.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-28 10:37:46 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7870f4951bcc6a153f317e3439e14d0e929fd231">7870f4951bcc6a153f317e3439e14d0e929fd231</a>
-<blockquote>
-<p>
- Bug 701795: Segv due to image mask issue<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-28 14:56:56 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e6b2518ed4b130ad649b96bf914558e642e414d">1e6b2518ed4b130ad649b96bf914558e642e414d</a>
-<blockquote>
-<p>
- clusterpush.pl: also exclude sanbin and sanobj directories.<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-28 14:41:35 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a2df79b5fdf97e1e33503634910ad08672bcee39">a2df79b5fdf97e1e33503634910ad08672bcee39</a>
-<blockquote>
-<p>
- Added support for MEMENTO_BREAKAT, equivalent to (gdb) call Memento_breakAt(...).<br>
-<br>
- It can be more convenient to specify this on the command line rather than<br>
- manually stop in gdb.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-28 14:37:48 +0000
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=450da26a76286a8342ec0864b3d113856709f8f6">450da26a76286a8342ec0864b3d113856709f8f6</a>
-<blockquote>
-<p>
- Bug 701785: fixed sanitizer heap-buffer-overflow in lprn_is_black().<br>
-<br>
- In contrib/lips4/gdevlprn.c:lprn_is_black(), it seems that bpl is not<br>
- necessarily a multiple of lprn-&gt;nBw, so we need to explicitly avoid straying<br>
- into the next line's data.<br>
-<br>
- This also avoids accessing beyond our buffer if we are already on the last<br>
- line, and so fixes the sanitizer error.<br>
-<br>
- Fixes:<br>
- ./sanbin/gs -sOutputFile=tmp -sDEVICE=lips2p ../bug-701785.pdf<br>
-<br>
-contrib/lips4/gdevlprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-27 19:44:35 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=93cb0c0adbd9bcfefd021d59c472388f67d3300d">93cb0c0adbd9bcfefd021d59c472388f67d3300d</a>
-<blockquote>
-<p>
- Fix Bug 701786: jetp3852 stack corruption caused by width/resolution<br>
-<br>
- This &quot;contrib&quot; driver has a questionable design where it collects the raster<br>
- data from the graphics library into a stack based array, but the size of the<br>
- array cannot accomodate high resolutions or wide pages. Issue an error and<br>
- fail (without stack corruption).<br>
-<br>
-devices/gdev3852.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-26 17:14: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=2c2dc335c212750e0fb8ae157063bc06cafa8d3e">2c2dc335c212750e0fb8ae157063bc06cafa8d3e</a>
-<blockquote>
-<p>
- Color Laserjet device - properly check params<br>
-<br>
- Bug #701796 &quot;Segmentation fault at devices/gdevclj.c:269 in clj_media_size&quot;<br>
-<br>
- The test in clj_media_size() as incorrect, it didn't signal an error if<br>
- there was no HWResolution in the param list. This left the parameter<br>
- 'fres' undefined leading to a potential invalid memory read, or a<br>
- divide-by-zero error.<br>
-<br>
- This commit returns an error if we get a param list with no HWResolution<br>
- I'm not absolutely certain if this is correct, but at least signalling<br>
- an error is better than a seg fault.<br>
-<br>
-devices/gdevclj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-26 15:43: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=bfeff28bb56ee4424ac78619792c18bf4f5104ef">bfeff28bb56ee4424ac78619792c18bf4f5104ef</a>
-<blockquote>
-<p>
- Coverity ID #126579 take 2<br>
-<br>
- Commit 13b3c67366aef69beed5f9c7e058c59a03714997 addressed this, but<br>
- there were 2 instances and that only fixed one. Fix the other here.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-26 15:04: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=aba3375ac24f8e02659d9b1eb9093909618cdb9f">aba3375ac24f8e02659d9b1eb9093909618cdb9f</a>
-<blockquote>
-<p>
- Prevent a heap-buffer overrun<br>
-<br>
- Bug #701791 &quot;global-buffer-overflow at devices/gdevpjet.c:177 in pj_common_print_page&quot;<br>
-<br>
- We were not setting the unused bytes at the end of a line to 0, which<br>
- later caused us to read uninitialised data from the line, and attempt<br>
- to use that as the index into an 8-byte table. If the uninitialised<br>
- data was greater than 16 then we would read off the end of the table.<br>
-<br>
- Its 'probably' benign since we aren't using tis data, and we probably<br>
- won't try to read from an invalid address, but its poor practice and<br>
- its easily fixed. Setting the buffer to 0x00 before we start ensures<br>
- that any padding bytes are in the valid range for the table.<br>
-<br>
-devices/gdevpjet.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-25 18:48:05 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b9e86a33b237740df682369300f1a9507dc63c5">4b9e86a33b237740df682369300f1a9507dc63c5</a>
-<blockquote>
-<p>
- Memento: Fix annoyance with %p<br>
-<br>
- Windows displays %p without a leading 0x. Linux adds a leading 0x.<br>
- Use a macro to give consistent results on all platforms.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-25 13:52: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=17ad4a12dd40799655b71a93de1209a6a0f24204">17ad4a12dd40799655b71a93de1209a6a0f24204</a>
-<blockquote>
-<p>
- Coverity issues: Assignment of overlapping union members<br>
-<br>
- Strictly speaking assigning one element of union to another, overlapping<br>
- element of a different size is undefined behavior, hence assign to intermediate<br>
- variables before setting the other element in the union.<br>
-<br>
- Coverity #: 350159, 350173, 350205, 350176, 350215, 350192<br>
-<br>
-base/gsfunc4.c<br>
-base/gsparam.c<br>
-pcl/pcl/pgparse.c<br>
-psi/zfont2.c<br>
-psi/ztype.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-25 13: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=62a1c3cdbb374d2f90b00f7aa276be50961c580a">62a1c3cdbb374d2f90b00f7aa276be50961c580a</a>
-<blockquote>
-<p>
- Tweak the section on building with Visual Studio<br>
-<br>
-doc/Make.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-24 10:15:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e80779ae9f53fac617d1416f7075a1b1b7f7688c">e80779ae9f53fac617d1416f7075a1b1b7f7688c</a>
-<blockquote>
-<p>
- Reduce confusion about contrib.mak dependency<br>
-<br>
- We have two contri.mak files, one in devices/ and one in contrib/, both have<br>
- dependency declarations:<br>
- CONTRIB_MAK=...<br>
-<br>
- This changes the devices/contrib.mak to use:<br>
- DCONTRIB_MAK=...<br>
-<br>
- Prepending the 'D' to avoid the two getting muddled.<br>
-<br>
-devices/contrib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-25 13:53: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=9ae928f80e70e04e89f0c36a7b58332fb0a9b19d">9ae928f80e70e04e89f0c36a7b58332fb0a9b19d</a>
-<blockquote>
-<p>
- Fix CAL ETS compiler flags.<br>
-<br>
-base/cal.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-24 15:04:58 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9001678252cc6c4e45251db70b83daae39b7d4ec">9001678252cc6c4e45251db70b83daae39b7d4ec</a>
-<blockquote>
-<p>
- Bug 697545 (Memory Squeezing): fixed hpgl_polyfill_using_current_line_type() leak on error.<br>
-<br>
- Need to always call hpgl_grestore().<br>
-<br>
- Fixes this leak:<br>
- MEMENTO_FAILAT=15840 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ../pcl5cfts/fts.1552<br>
-<br>
-pcl/pcl/pgdraw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-24 08:31:38 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d6746f08c592057dfd3abe1b957c8b23971508cc">d6746f08c592057dfd3abe1b957c8b23971508cc</a>
-<blockquote>
-<p>
- Memento tweaks: libbacktrace warning/instructions.<br>
-<br>
- If we can't load libbacktrace.so, give a warning that backtraces<br>
- will be cryptic.<br>
-<br>
- Add info to memento.h about where people can get libbacktrace<br>
- from, how to build it, and where to install it.<br>
-<br>
- Also add some code from Julian Smith to call gdb to extract<br>
- backtrace data; this doesn't work for me, so it's disabled<br>
- by default for now.<br>
-<br>
-base/memento.c<br>
-base/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-23 13:29:38 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=de22d4d177a5911310d4af0777e87a8809a1622c">de22d4d177a5911310d4af0777e87a8809a1622c</a>
-<blockquote>
-<p>
- Change pdf implementation to use CalGray and CalRGB<br>
-<br>
- It was previously mapping these to DeviceGray and DeviceRGB for some<br>
- reason.<br>
-<br>
- See tests_private/pdf/PDF_1.7_FTS/fts_08_0829.pdf for example where this<br>
- matters.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-21 17:37: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=a1cd6ee4a3724fbf70718483aa702c7af0f0a6cc">a1cd6ee4a3724fbf70718483aa702c7af0f0a6cc</a>
-<blockquote>
-<p>
- Use CAL implementation of ETS in WITH_CAL builds.<br>
-<br>
-base/cal.mak<br>
-base/ets.h<br>
-base/gxdownscale.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-27 11:16:23 +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=a44d0ce727f2095fbbedb8bf6b1e062fca3c8f01">a44d0ce727f2095fbbedb8bf6b1e062fca3c8f01</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent memory leaks in gx_cpath_assign_preserve.<br>
-<br>
- Update functionality to propagate error codes correctly and release path segments.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=15840 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.1552<br>
-<br>
-base/gxacpath.c<br>
-base/gxcpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-26 15:08: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=4637eeae2415b593d84bb60dbac5369eb2ecc54b">4637eeae2415b593d84bb60dbac5369eb2ecc54b</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent memory leaks in hpgl_LB.<br>
-<br>
- Update code to propagate error codes correctly and prevent font leaks.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=19935 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.1480<br>
-<br>
-pcl/pcl/pglabel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-26 11:49:08 +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=dc3b7d7f6882e1ed1ff41083ff22893efc5c5afa">dc3b7d7f6882e1ed1ff41083ff22893efc5c5afa</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent memory leaks in hpgl_EP.<br>
-<br>
- Update code to propagate error codes correctly and prevent graphic state leaks.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=15166 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.1470<br>
-<br>
-base/gxstroke.c<br>
-pcl/pcl/pgpoly.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-23 14:08:02 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3ff1490e231c8b02ce77386a75f23ac76e97cc29">3ff1490e231c8b02ce77386a75f23ac76e97cc29</a>
-<blockquote>
-<p>
- Bug 697545 (Memory Squeezing): fixed owl.pcl leak in hpgl_draw_current_path().<br>
-<br>
- In pcl/pcl/pgdraw.c:hpgl_draw_current_path() case hpgl_char_fill_edge, ensure<br>
- that we call hpgl_grestore() before looking at error from (*fill) (pgs).<br>
-<br>
- Fixes leak at 10093 in:<br>
- MEMENTO_SQUEEZEAT=1 membin/gpcl6 -sDEVICE=bit -o /dev/null pcl/examples/owl.pcl<br>
-<br>
-pcl/pcl/pgdraw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-23 15:08:29 +0100
-</strong>
-<br>Julian Smith &lt;jules@op59.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ce07cab3d1e9e38401cfaddd0312bd06f48422b">5ce07cab3d1e9e38401cfaddd0312bd06f48422b</a>
-<blockquote>
-<p>
- Fix hpgl_call_and_check() macro to not define &lt;code&gt; local variable.<br>
-<br>
- This can conflict with surrounding code. Use &lt;hpgl_call_and_check_code&gt;<br>
- instead, which should be unique enough.<br>
-<br>
-pcl/pcl/pgmisc.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-23 10:02: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=1bb7a148bc6a4e4a8736d27a937465aab95069e5">1bb7a148bc6a4e4a8736d27a937465aab95069e5</a>
-<blockquote>
-<p>
- Revision for a34130a136fa that will actually work<br>
-<br>
- The Coverity report was misleading, and I missed a compiler warning with<br>
- commit a34130a136fa.<br>
-<br>
- This resolves the compiler warning, and should keep coverity happy.<br>
-<br>
-base/gstype42.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-23 09:39: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=6d7243cea061373f592a6d9113626393ff0eb7d8">6d7243cea061373f592a6d9113626393ff0eb7d8</a>
-<blockquote>
-<p>
- Coverity ID 350179: Add buffer size check for string<br>
-<br>
- Before we append chars to a string buffer, check it's large enough<br>
-<br>
-base/genconf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-23 09:22:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a34130a136fa9a61af3991224438dbf31b834767">a34130a136fa9a61af3991224438dbf31b834767</a>
-<blockquote>
-<p>
- Coverity ID 350219: Fix mistake in TTF post table handling<br>
-<br>
- Mistakenly passing a pointer into a macro, rather than the variable.<br>
-<br>
-base/gstype42.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-11 10:20:04 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5573498b2d9abe918794d377729edeab6b28e1fb">5573498b2d9abe918794d377729edeab6b28e1fb</a>
-<blockquote>
-<p>
- Add arch.h dependency for CAL.<br>
-<br>
-base/cal.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-21 15:12:57 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a7fe4b47d438c78af0fc03adf030d465cfe0ba4f">a7fe4b47d438c78af0fc03adf030d465cfe0ba4f</a>
-<blockquote>
-<p>
- Apply DOPS to &quot;bare&quot; PS operator in PDF's<br>
-<br>
- PDF 1.2 defined a PS operator that could be used in streams to execute<br>
- PostScript. This went away with PDF 1.3 2nd edition spec., but Ghostscript<br>
- retained the functionality. In commit e7086fc6 we disabled the execution<br>
- of Subtype /PS streams (requiring -dDOPS to enable them), but the &quot;PS&quot;<br>
- operator, that sends PostScript strings to the underlying Postscript<br>
- interpreter remained unaffected, leading to Bug 700176 exploit.<br>
-<br>
- This patch also disables the &quot;PS&quot; operator unless -dDOPS is specified.<br>
- Using -dDOPS is *NOT* recommended, although the fixes for Bug700176<br>
- should prevent that particular exploit.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-22 10:57: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=b4521b891de48d7f62be739d02749c4aeca2fde8">b4521b891de48d7f62be739d02749c4aeca2fde8</a>
-<blockquote>
-<p>
- Fix dvipdf script<br>
-<br>
- Bug #701771 &quot;dvipdf script broken&quot;<br>
-<br>
- Apparently the script requires a trailing '-'<br>
-<br>
-lib/dvipdf<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-22 09:32: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=7c836caa3e05a286ac56f39ed45dab65eb979ee9">7c836caa3e05a286ac56f39ed45dab65eb979ee9</a>
-<blockquote>
-<p>
- Update genfontmap.ps for SAFER default<br>
-<br>
- Bug #701766 &quot; genfontmap.ps Unrecoverable error, exit code 1&quot;<br>
-<br>
- The genfontmap.ps program, supplied as part of the support tools in<br>
- 'toolbin' rather than Ghostscript proper, relies on the non-standard<br>
- PostScript extension operator '.sort'.<br>
-<br>
- As part of the security hardening, as many non-standard operators as<br>
- possible were removed from Ghostscript when SAFER is set, including<br>
- .sort, and with version 9.50 SAFER becomes the default.<br>
-<br>
- This commit simply updates the genfontmap.ps program to check that it<br>
- is being run with NOSAFER, emits a warning and exits if this is not the<br>
- case. Also update the comments to indicate why we are doing this.<br>
-<br>
-toolbin/genfontmap.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-17 11:51: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=95e76aad97b1b1c2da51f7fc7e904168fadb1399">95e76aad97b1b1c2da51f7fc7e904168fadb1399</a>
-<blockquote>
-<p>
- Remove the 136 LL3 font set fontmap files<br>
-<br>
- The fontmap for the type 1 136 set is now in the repo with the font files<br>
-<br>
-lib/Fontmap.URW-136.T1<br>
-lib/Fontmap.URW-136.TT<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-17 11:39: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=164db4ba0d766e591884079d6fb21ab63829549d">164db4ba0d766e591884079d6fb21ab63829549d</a>
-<blockquote>
-<p>
- Fontmap: cope better with bare filename maps<br>
-<br>
- We don't automatically add FontResourceDir to the libfile search path, so a<br>
- name to plain file name mapping will only work if the directory containing the<br>
- file is explicitly added to the search path. For example:<br>
-<br>
- /Dingbats (d050000l.pfb) ;<br>
-<br>
- With this change, in addition to the search path and the bare file name, we'll<br>
- also try opening the file in the FontResourceDir, so users can use such custom<br>
- mappings simply by adding the font files to the FontResourceDir (usually:<br>
- Resource/Font).<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-19 11:06: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=618c3867b8edec9d0ea757949c926d4290995ac7">618c3867b8edec9d0ea757949c926d4290995ac7</a>
-<blockquote>
-<p>
- Pattern handling- relax a heuristic<br>
-<br>
- Bug #701753 &quot;Error reading a content stream&quot; with pdf using Type3 font&quot;<br>
-<br>
- This file uses a type 3 font with a FontMatrix more usually found in<br>
- type 1 font; [0.001 0 0 0.001 0 0]. It is also a coloured font, and<br>
- uses a Pattern colour space with a Shading function to colour the text.<br>
-<br>
- The Pattern cell, when scaled by the Font Matrix, results in a mapping<br>
- of the step matrix to device space where the matrix determinant is less<br>
- than 1/1,000,000. We detect this as a degenerate matrix and throw an<br>
- error.<br>
-<br>
- Acrobat renders an empty page.<br>
-<br>
- So relax this heuristic further from 10^-6 to 10^-9, this allows the<br>
- file to render and doesn't cause any changes in our regression tests.<br>
-<br>
- Of course, at this cell size, the pattern renders blank, just as it<br>
- does with Acrobat.<br>
-<br>
-base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-16 08:18:59 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7acf36de36e6972be8a892078d214eea8e311cdd">7acf36de36e6972be8a892078d214eea8e311cdd</a>
-<blockquote>
-<p>
- Fix bug 699457: Parameter range checking wrong (would not spot bad values).<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-16 08:04:34 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1170f928cc98b64a26edc275b66f081be9079cbb">1170f928cc98b64a26edc275b66f081be9079cbb</a>
-<blockquote>
-<p>
- Fix bug 701719: Parens seem wrong -- fixed for clarity.<br>
-<br>
-base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-16 16:12: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=928ae0dbcf9a2307bb33ba8d2abd83274fc34a7d">928ae0dbcf9a2307bb33ba8d2abd83274fc34a7d</a>
-<blockquote>
-<p>
- Change a URL string to a an href link in the footers.<br>
-<br>
-doc/API.htm<br>
-doc/C-style.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/Internal.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/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/thirdparty.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-16 06:52: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=65dbe88e660adcfba315fe559fcd7fd97628ee49">65dbe88e660adcfba315fe559fcd7fd97628ee49</a>
-<blockquote>
-<p>
- Fix bug 701718: Use separate 'if' in clist_fillpage.<br>
-<br>
- The intent was to return the error code if clist_close_writer_and_init_reader<br>
- failed, THEN run clist_finish_page and similarly return if that fails.<br>
-<br>
-base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-16 06:43:04 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e22ef03cdd31263ba1266f3d53aef7be4467e405">e22ef03cdd31263ba1266f3d53aef7be4467e405</a>
-<blockquote>
-<p>
- Fix bug 701715. Problem in thresh_remap.c binary output.<br>
-<br>
- I never use binary output -- just -p for PostScript output, so this<br>
- was untested.<br>
-<br>
-toolbin/halftone/thresh_remap/thresh_remap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-15 11:39: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=8a3309451ded2335b7f7ab5ebf1c19eebad8b32c">8a3309451ded2335b7f7ab5ebf1c19eebad8b32c</a>
-<blockquote>
-<p>
- Bring master up to date with 9.50 branch<br>
-<br>
- docs, dates etc<br>
-<br>
- Dates and versions for 9.28 RC 1<br>
-<br>
- Date for 9.28 rc2<br>
-<br>
- Doc updates, changelog, news etc<br>
-<br>
- Update to note explicitly case sensitivity on Windsows<br>
-<br>
- In News.htm and History9.htm<br>
-<br>
- Dates, docs, etc for 9.28 rc3<br>
-<br>
- Dates and docs for 9.28 rc4<br>
-<br>
- Small changelog tweak<br>
-<br>
- Change version to 9.50<br>
-<br>
- Update changelog<br>
-<br>
- Fix a mistake in the news section<br>
-<br>
- Dates etc for 9.50 release<br>
-<br>
- Plus a comment on going to 9.50, rather than 9.28.<br>
-<br>
-base/version.mak<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/Internal.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>2019-10-15 09:27: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=ac5c8747c9f9e2710a315ff25d41a7b9a592b583">ac5c8747c9f9e2710a315ff25d41a7b9a592b583</a>
-<blockquote>
-<p>
- Version number, to dovetail with release<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-14 18:29: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=e7488d8a4d2bb48d6285d4ba3db1539206f0e67f">e7488d8a4d2bb48d6285d4ba3db1539206f0e67f</a>
-<blockquote>
-<p>
- Have warning honor -dQUIET<br>
-<br>
- Have the warning about calling .lockfileaccess or .setsafe when the controls are<br>
- already in place honor the -dQUIET/-q command line params.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-14 18:07: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=75275c5c001699b32dfdc1d7d7977c8c4c9f2c80">75275c5c001699b32dfdc1d7d7977c8c4c9f2c80</a>
-<blockquote>
-<p>
- Add words about .currentpathcontrolstate operator<br>
-<br>
-doc/Language.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-14 10:20:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=74e468866b53e1a11d641549841b06027266ce39">74e468866b53e1a11d641549841b06027266ce39</a>
-<blockquote>
-<p>
- Update docs on SAFER<br>
-<br>
- to reflect that SAFER is now the default, and remove the comments about making<br>
- SAFER the default &quot;in the future&quot;.<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-11 15:10: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=72ab3591097a2e5ae5201f4a28d3560b019a1019">72ab3591097a2e5ae5201f4a28d3560b019a1019</a>
-<blockquote>
-<p>
- PDF interpreter - handle ObjStm with contents which are non-delimited<br>
-<br>
- No bug number, confidential file supplied by a customer.<br>
-<br>
- This is in the same area as commit<br>
- d9889892feaac3ca09f85d9bbdc001b1aec50cc3<br>
-<br>
- In this case the file is actually completely valid and exposes a flaw<br>
- in our processing of ObjStm streams. We 'tokenise' the entire contents<br>
- of the ObjStm, for performance reasons, when we first need to read an<br>
- object from it. This caused problems if we read too many objects which<br>
- was dealt with in the commit above.<br>
-<br>
- In this case, however, what we have is objects which do not have any<br>
- delimiter, so the tokeniser carries straight on, instead of stopping<br>
- when it reaches the end of the object (as given by the difference<br>
- between successive offsets). For example, if we have three null objects<br>
- then the (decompressed) stream would read nullnullnull, each object<br>
- has a different offset and the length of each is given by subtracting<br>
- one offset from the next.<br>
-<br>
- What we were reading was, literally, nullnullnull which of course is not<br>
- legal.<br>
-<br>
- This commit leverages off the code in the commit to fix the extra<br>
- objects and uses the same approach, we set up a ReusableStream on the<br>
- decompressed ObjStm so we can seek around in it, then read each object<br>
- by seeking to the offset, setting up a SubFileDecode (so we stop at the<br>
- end of the object) and reading the object.<br>
-<br>
- That works as well for this case, albeit with a (negligible in this<br>
- case) performance penalty). We check at the end of reading the objects<br>
- individually, and if we don't have enough objects then we raise a<br>
- warning.<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-11 12:06: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=fbe920c86d42919620a425d0933d9dcbfaa1c3cb">fbe920c86d42919620a425d0933d9dcbfaa1c3cb</a>
-<blockquote>
-<p>
- PDF interpreter - do not unconditionally restore state in update_alpha<br>
-<br>
- Bug #701644 &quot;Error: /unregistered in --.pdfexectoken--&quot;<br>
-<br>
- The problem is caused by the insanely complicated (and inefficient)<br>
- way the file is constructed. We have a SMask in a Group, which is<br>
- enclosed within another Group.<br>
-<br>
- When we call start a transparency mask we call pdf_prepare_drawing()<br>
- which calls pdf_update_alpha(). Crucially this is called after we have<br>
- entered a substream for an enclosing Group, but it does not begin a<br>
- new substream.<br>
-<br>
- However, pdf_update_alpha() assumes that if the smask_id has changed<br>
- then a new viewer state has been saved, and the first thing it does<br>
- is restore that state. If no such state has been saved (as here) then<br>
- the code to restore the viewer state sees this as an error (which it is)<br>
-<br>
- We fix this by checking to see if a viewer state has been pushed before<br>
- trying to restore to it.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-10 17:13: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=9dddc61852d012b867e0353c7897b9c5301e17e6">9dddc61852d012b867e0353c7897b9c5301e17e6</a>
-<blockquote>
-<p>
- PDF interpreter - Ignore invalid MediaBox array<br>
-<br>
- Again, no bug, the specimen file is a confidential customer file.<br>
-<br>
- The file contains, on page 60, an invalid MediaBox:<br>
-<br>
- /MediaBox[ 0 0 612 792 0 0 720 917]<br>
-<br>
- The 8 values were unloaded onto the stack, but only 4 were consumed<br>
- leading to errors later in processing. This commit checks the length<br>
- of the array and if it isn't exactly 4 then it exits and uses the<br>
- current page size instead.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-10 15:51:13 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d305e46c4af1af14dfe79f7ebab6d2edf168f068">d305e46c4af1af14dfe79f7ebab6d2edf168f068</a>
-<blockquote>
-<p>
- PDF interpreter - match observed Acrobat processing of Widget annots<br>
-<br>
- No bug for this, arising from a customer file.<br>
-<br>
- It appears Acrobat does not render Widget annotations unless the<br>
- annotation dictionary contains a /FT and a /T key, either directly in<br>
- the annotation dictionary or inherited from a Form Definition Field<br>
- dictionary (via the AcroForm /Fields entry).<br>
-<br>
- This commit checks annotations to see if they are Widgets, then checks<br>
- to see if both /FT sand /T are present. If either is missing we walk<br>
- back up the FDF heirarchy using the /Parent key, storing any FT or T<br>
- keys in the annotation dictionary as we go.<br>
-<br>
- We don't actually care what the associated values are, we only care if<br>
- they keys are present, so reversing the lookup is acceptable here.<br>
-<br>
- We then re-test the annotation dictionary for the presence of both keys<br>
- and if either is missing we do not render the annotation.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-10 10:15: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=797ddfc6ef5f0cdfba664f550fe57acc43f309bb">797ddfc6ef5f0cdfba664f550fe57acc43f309bb</a>
-<blockquote>
-<p>
- Fix the logic for permitted directories<br>
-<br>
- The logic to match a permitted path ending in a directory separator with any<br>
- file in that directory (but only that directory) was wrong, causing us to<br>
- reject such cases.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-10 09:29: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=d45d594ea5660976a21106ea864eb879801827b1">d45d594ea5660976a21106ea864eb879801827b1</a>
-<blockquote>
-<p>
- ps2write - restore missing %%PageTrailer comment<br>
-<br>
- Bug #701659 &quot;Missing %%PageTrailer commen&quot;<br>
-<br>
- An oversight in commit 96c381cce28c27eac182549441a6c5025b0dcdd6<br>
- caused the comment to be omitted.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-09 16:45: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=34774ab185f17186b26949f5fee118dee9114d3a">34774ab185f17186b26949f5fee118dee9114d3a</a>
-<blockquote>
-<p>
- PDF interpreter - fix /None case of Line Ending style<br>
-<br>
- Bug #701622 &quot;pdfwrite device fails with annotation appearance&quot;<br>
-<br>
- This is, in fact, nothing at all to do with pdfwrite. The problem is<br>
- that, when generating an Appearance stream for a /Line Annotation which<br>
- is defined without an Appearance stream, the /None line ending style<br>
- was not popping the copy of the annotation dictionary.<br>
-<br>
- This led to an error in the annotation. If a previous annotation used<br>
- transparency, then this would cause the compositor to get confused,<br>
- because we would start the transparency in the Line annotation, but<br>
- the error meant we would not close the transparency group.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-07 00:02: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=b2c1beac237865bde26c7fa921d24d17ecda6fab">b2c1beac237865bde26c7fa921d24d17ecda6fab</a>
-<blockquote>
-<p>
- pdfwrite - preserve rendering intent<br>
-<br>
- bug #701487 &quot;Renedring intent not preserved by pdfwrite&quot;<br>
-<br>
- The pdfwrite device was not previously handling rendering intent changes<br>
- this commit adds a rendering_intent member to the pdfwrite device<br>
- structure, initialises it to 1 (absolute colorimetric) and then tracks<br>
- changes to the graphics state, emitting /RI entries in ExtGSatet<br>
- dictionaries as required.<br>
-<br>
- This shows a number of small progressions in the test suite, and marked<br>
- progressions with icc_v4_profile.pdf and icc_rendering_intent.pdf.<br>
-<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-06 17:42: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=faef233630240edfc3ad9f5ea154b5b32ed51c75">faef233630240edfc3ad9f5ea154b5b32ed51c75</a>
-<blockquote>
-<p>
- pdfwrite - Use CA and ca for text with transparency<br>
-<br>
- Bug #701631 &quot;pdfwrite: mishandling of alphas with Text render mode 2&quot;<br>
-<br>
- The problem is in both the PDF interpreter and pdfwrite. In the past<br>
- the PDF interpreter has never been able to create a fill+stroke<br>
- primitive, because PostScript doesn't support that. However we added<br>
- the ability for pdfwrite to maintain text rendering modes, for reasons<br>
- of quality, which breaks that assumption.<br>
-<br>
- Although we added the stroke and fill constant alpha to the C graphics<br>
- state when we moved the PDF graphics state into the C graphics state,<br>
- nothing actually ever used them. Instead the PDF interpreter sets a<br>
- single 'opacity' alpha channel, based on whether the current operation<br>
- is a stroke or a fill. Because we could not emit a combined operation<br>
- this worked as we would set the opacity separately for each operation.<br>
-<br>
- Of course for pdfwrite this doesn't work, and looking to the future<br>
- when the fill+stroke primitive is available in the graphics library,<br>
- we will need to do away with the opacity.alpha and properly use the<br>
- fill and stroke alphas stored in the graphics state. For now, however,<br>
- we need to continue to use the opacity.alpha, but when we are handling<br>
- text (in pdfwrite) actually use the values of stroke and fill alpha<br>
- instead of opacity.alpha.<br>
-<br>
- So add a 'for_text' boolean to all the routines whihch need to set or<br>
- update the alpha, and when writing the ExtGState, if we are handling<br>
- text then use CA and ca instead of opacity.alpha.<br>
-<br>
- This has also mean altering the XPS interpreter so that it sets the<br>
- stroke and fill alphas as well as opacity.alpha, otherwise pdfwrite<br>
- doesn't know which value to use for text operations.<br>
-<br>
-devices/vector/gdevpdfd.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfg.h<br>
-devices/vector/gdevpdft.c<br>
-devices/vector/gdevpdts.c<br>
-devices/vector/gdevpdtt.c<br>
-xps/xpscolor.c<br>
-xps/xpsimage.c<br>
-xps/xpsopacity.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-05 14:49:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=21a10f9e2cb9134c351fd568fc73222f2917e159">21a10f9e2cb9134c351fd568fc73222f2917e159</a>
-<blockquote>
-<p>
- PDF interpreter - Improve PreserveAnnots<br>
-<br>
- PreserveAnnots currenlty works in conjunction with ShowAnnotTypes, but<br>
- We should really have a separate control for this.<br>
-<br>
- This commit adds a new /PreserveAnnotTypses (must be set from PostScript<br>
- in the same way as ShowAnnotTypes). PreserveAnnots and PreserveAnnotTypes<br>
- only work with a device which can preserve Annotations (currently this<br>
- is the pdfwrite device only).<br>
-<br>
- If the device supports Annotation preservation, and PreserveAnnots is<br>
- true (the default0 then for each annotation we consult the Types array,<br>
- if the annotation is to be preserved then we pass it to the device. If<br>
- not, then we pass the annotation to the 'draw' routines which will<br>
- render teh annotation instead.<br>
-<br>
- Using the two separate controls allows us to selectively control, by<br>
- type, whther annotations are preserved, rendered, or simply ignored<br>
- altogether.<br>
-<br>
- Also fix an omission, and some typos, in the documentation for<br>
- ShowAnnots in Use.htm<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-doc/Use.htm<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-07 18:41: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=61c489110685f7cab8cbbbca7b15d9b5cb2463d0">61c489110685f7cab8cbbbca7b15d9b5cb2463d0</a>
-<blockquote>
-<p>
- Bug 701657: Allocate &quot;memory&quot; device in immovable gc memory<br>
-<br>
- Devices are supposed to be allocated in memory that cannot relocate (i.e.<br>
- non-gc memory or an immovable allocation). The memory device accessible from<br>
- Postscript (makeimagedevice/makewordimagedevice) was being created in regular,<br>
- relocatable gc memory.<br>
-<br>
- This caused an invalid memory access when cleaning up subclassed devices, as the<br>
- one device in the chain may have moved. So switch to using an immovable<br>
- allocation.<br>
-<br>
-base/gsdevmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-01 10:35: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=2d990b065c228802b3913602b4309165e42c08e9">2d990b065c228802b3913602b4309165e42c08e9</a>
-<blockquote>
-<p>
- Fix memory corruption setting a halftone<br>
-<br>
- When setting a new halftone in the graphics state, we try to re-use the data<br>
- from the existing device halftone.<br>
-<br>
- The problem is that the device halftone can have higher component indices than<br>
- there are components in the new halftone we are creating. In this case, we can<br>
- end up writing off the end of the components array for the new halftone<br>
- structure.<br>
-<br>
- Simply check that the new halftone has enough components before doing the<br>
- duplication.<br>
-<br>
-base/gsht.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-30 13:40: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=f03bac8ec2dabfff5583bf6afdd2b77f1885f8ef">f03bac8ec2dabfff5583bf6afdd2b77f1885f8ef</a>
-<blockquote>
-<p>
- pdfwrite - don't honour /Producer key in DOCINFO pdfmark<br>
-<br>
- Bug #701639 &quot;pdfwrite should not honour the /Producer key in DOCINFO pdfmark&quot;<br>
-<br>
- The Producer in the document information dictionary (and XML Metadata)<br>
- is defined quite clearly as the application which produced the PDF file<br>
- from its native format.<br>
-<br>
- Ghostscript uses the Producer key (if present in the pdfmark) to set<br>
- the Producer, but it should not do so. Adobe Acrobat Distiller (at<br>
- least the end user version) does not permit this value to be altered.<br>
-<br>
- On reflection we can see why; in the case of a problem with a PDF file<br>
- its important to know which application created it, and we should not<br>
- let PostScript obscure that (we already do not pass the Producer<br>
- information on when the input is PDF).<br>
-<br>
- The code did already attempt to overwrite any Producer string which<br>
- contained 'Distiller' (I have no idea why) and that code contained an<br>
- error which could lead to an invalid Document Information dictionary<br>
- being created.<br>
-<br>
- This commit removes the ability for DOCINFO pdfmarks to alter the<br>
- Producer, which obviously fixes the bug.<br>
-<br>
- However..... it is actually important for our commercial customers to<br>
- be able to set this value. A problem with a PDF file created by one of<br>
- our customer's products should be reported to that customer, not us, as<br>
- we will not be able to investigate the problem while our customer<br>
- should be able to. At the very least our customer will know how to<br>
- retrieve the configuration of Ghostscript being used.<br>
-<br>
- So permit the commercial version of Ghostscript to set the /Producer<br>
- from a pdfmark.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-27 13:26:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=77f79475fd0419d16f1efe7812a44a9720fef10b">77f79475fd0419d16f1efe7812a44a9720fef10b</a>
-<blockquote>
-<p>
- Bug 701634: Correctly handle file name of &quot;\0&quot;<br>
-<br>
- Attempting to open a file with a filename string starting with a NULL<br>
- character should be treated the same as if the string was zero length.<br>
-<br>
- Not doing so created a broken file object leading to several operations<br>
- resulting in a segfault.<br>
-<br>
- Also, add cleanup in the event of such an error, freeing memory allocated in<br>
- preparing the gs stream object.<br>
-<br>
-base/sfxcommon.c<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-27 00:05:37 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef597bf4a05814a97d05866868f9b96b98746ae9">ef597bf4a05814a97d05866868f9b96b98746ae9</a>
-<blockquote>
-<p>
- Correct Memento usage example in header.<br>
-<br>
-base/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-26 10:47:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7db398d549a03ff5d37ec991eb60f01378eac88d">7db398d549a03ff5d37ec991eb60f01378eac88d</a>
-<blockquote>
-<p>
- Revised comment for 8992f00edfd1c39154c013489de2a01d2e9a92ee<br>
-<br>
- Make it clearer why the revised behaviour is required.<br>
-<br>
-base/gstiffio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-26 09:34: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=8992f00edfd1c39154c013489de2a01d2e9a92ee">8992f00edfd1c39154c013489de2a01d2e9a92ee</a>
-<blockquote>
-<p>
- Bug 701313: Disable libtiff callbacks when libtiff is shared<br>
-<br>
- It seems that libtiff uses global variables to store the error/warning callbacks<br>
- so if two callers in the exe are using the libtiff shared lib, very bad things<br>
- happen (usually a segfault).<br>
-<br>
- So, if that's how we're linked, set the callbacks to NULL.<br>
-<br>
-base/gstiffio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-03 18:37: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=6293a99abfdc73b8881b2090cd7b01a1fbef5370">6293a99abfdc73b8881b2090cd7b01a1fbef5370</a>
-<blockquote>
-<p>
- Fix pdf14_accum for DeviceN target devices such as display<br>
-<br>
- Also fix display device for DeviceN (-dDisplayFormat=16#a0800).<br>
- Not sure when, but it had bit-rotted.<br>
-<br>
- The pdf14_accum device now has the DeviceN devn_params available since<br>
- it now includes gx_devn_prn_device_common (rather than gx_prn_device_common).<br>
- A pdf14_accum_CMYKSpot device is added that is used when the target device<br>
- has more than 4 components. The pdf14_accum_CMYKSpot keeps the target device<br>
- (e.g. display) device equiv_cmyk_colors and devn_params updated as the clist<br>
- is being written.<br>
-<br>
-base/gdevp14.c<br>
-base/gscdevn.c<br>
-base/lib.mak<br>
-devices/gdevdsp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-25 04:57: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=74787042b3259d51538d31556c38239d72539e3f">74787042b3259d51538d31556c38239d72539e3f</a>
-<blockquote>
-<p>
- Run toolbin/headercompile.pl and update dependencies in Makefiles.<br>
-<br>
- Move the definition of x_pixel within the headers to ensure<br>
- gdevcmp.h stands alone.<br>
-<br>
- Include a ufst header to ensure that gxfapiu.h stands alone.<br>
-<br>
-base/gxfapiu.h<br>
-base/lib.mak<br>
-base/tiff.mak<br>
-devices/contrib.mak<br>
-devices/devs.mak<br>
-devices/gdevx.h<br>
-devices/gdevxcmp.h<br>
-psi/int.mak<br>
-toolbin/headercompile.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-25 14:35:00 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb7802dc979aaa0e9e43310de0f1e8dcc7b31b2c">eb7802dc979aaa0e9e43310de0f1e8dcc7b31b2c</a>
-<blockquote>
-<p>
- Bug 578865: Fix typo<br>
-<br>
- Fix typo in previous commit.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-19 12:07:00 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=73bd448d2ebabad9ee31053abf897325a639cba1">73bd448d2ebabad9ee31053abf897325a639cba1</a>
-<blockquote>
-<p>
- Bug 578865: Push transparency group for non idempotent shadings.<br>
-<br>
- Shadings that write the same pixels more than once can be<br>
- rendered incorrectly for blendmodes that aren't idempotent<br>
- (or for non solid opacities). In such cases, push a transparency<br>
- group so that the shading can be written just once, and<br>
- then safely blended.<br>
-<br>
- Note that this doesn't capture shadings that are rendered<br>
- via zshfill.<br>
-<br>
-base/gdevp14.c<br>
-base/gstparam.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 18:52:16 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d1d6dc851e23edb36ac6e5db1bdf0edbba262bd">1d1d6dc851e23edb36ac6e5db1bdf0edbba262bd</a>
-<blockquote>
-<p>
- Knockout groups should knockout the group alpha (and shape) too.<br>
-<br>
- When marking within a knockout group, for each pixel we mark, we<br>
- throw away the current colorant values in the destination, and<br>
- base the calculations of the new colorant values on the stored<br>
- backdrop values.<br>
-<br>
- We were failing to do this for the group alpha and shape<br>
- calculations. This could lead to the group alpha getting out of<br>
- sync with the actual colorant values. We were seeing this with<br>
- shadings (particularly gradient shadings) where the shadings<br>
- paint some pixels more than once.<br>
-<br>
- This becomes much more obvious with the forthcoming commit to<br>
- use knockout groups for shadings with either transparency or<br>
- non-idempotent blend modes.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-24 15:48: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=05e794d14a2853c45a08d5c49d50d1fa5cadaf6c">05e794d14a2853c45a08d5c49d50d1fa5cadaf6c</a>
-<blockquote>
-<p>
- Cope with .setsafe(global) being called when already 'SAFER'<br>
-<br>
- As we default to SAFER file controls now, we want to cope with .setsafe and<br>
- .setsafeglobal being called either when already SAFER, or called multiple times.<br>
-<br>
- This means adding a .currentpathcontrolstate operator so we don't try to<br>
- influence the path control lists after control is activated.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-24 09:18: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=5ca729649efc3b041237b8b45bd2d011b70143ff">5ca729649efc3b041237b8b45bd2d011b70143ff</a>
-<blockquote>
-<p>
- tiffsep(1): Cope with .tiff ending as well as .tif<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 20:04:49 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1daff4546ae8fae46fc4acb8b0bef013753488a">d1daff4546ae8fae46fc4acb8b0bef013753488a</a>
-<blockquote>
-<p>
- Recast validate to use gs_file_name_check_separator.<br>
-<br>
- Avoid using gp_file_name_directory_separator, as windows can<br>
- have 2 different directory separators.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 18:05:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3f4fc81482ecfef51adb4af98f6ac214c7e64bdb">3f4fc81482ecfef51adb4af98f6ac214c7e64bdb</a>
-<blockquote>
-<p>
- Remove spurious call to gp_validate_path_len()...<br>
-<br>
- ...in gx_device_open_output_file()<br>
-<br>
- There is no need to validate the path in gx_device_open_output_file() as it will<br>
- be done at a lower level (gp_fopen) for paths that require it (we only validate<br>
- *after* the Postscript style %device% paths have been expanded into 'real'<br>
- paths).<br>
-<br>
- This also interacts badly with the revised handling of formatted string<br>
- file names, hence remove it.<br>
-<br>
-base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 17:56: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=f874c5b9d2d5a3798dc00e53149c4a470ce5da01">f874c5b9d2d5a3798dc00e53149c4a470ce5da01</a>
-<blockquote>
-<p>
- Fix tiffsep(1) interaction with file permissions lists<br>
-<br>
- The previous solution didn't quite work, when using formatted strings for<br>
- output file names (i.e. output-%d.tif).<br>
-<br>
- This adds a dedicated gs_remove_outputfile_control_path() to mirror<br>
- gs_add_outputfile_control_path() and uses those for the dynamic adding and<br>
- removing of separation output file names.<br>
-<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 17:11:47 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a1c253838b0e1ccbadc5c0bdb6e3bde59b3b00a1">a1c253838b0e1ccbadc5c0bdb6e3bde59b3b00a1</a>
-<blockquote>
-<p>
- Update path validation to accept multiple *'s as special case.<br>
-<br>
- Previously we interpretted multiple *'s as meaning the same as<br>
- single *'s. Now we use them to mean &quot;just those chars that<br>
- might be created by the use of a %...{d,x,u,i,o,X} format<br>
- specifier&quot;.<br>
-<br>
-base/gpmisc.c<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 16:41:09 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3147ffb314f344520fb22c8bc57d4afcdc3c9c62">3147ffb314f344520fb22c8bc57d4afcdc3c9c62</a>
-<blockquote>
-<p>
- Improve OutputFile handling of %d etc.<br>
-<br>
- Only accept %d (and friends) (as opposed to anything starting with %).<br>
- Only accept legal combinations of flags/widths/precision etc.<br>
- Generate a more conservative wildcard.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 09:25:27 +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=a38bf66e8e041f21ebb25492e576262a55b318b1">a38bf66e8e041f21ebb25492e576262a55b318b1</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent memory leaks and SEGV in pcl_font_header.<br>
-<br>
- Update pcl_font_header to avoid freeing uninitialised font structure and also<br>
- double freeing the font.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=17247 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0573<br>
-<br>
-pcl/pcl/pcsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-22 20:11:00 +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=893018e1c7aca3218555701208cc41daee34b8c4">893018e1c7aca3218555701208cc41daee34b8c4</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent memory leaks in pcl_execute_macro.<br>
-<br>
- Prevent memory leaks on error.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=15270 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.1100<br>
-<br>
-pcl/pcl/pcmacros.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-20 12:38:02 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=adc3adfdf30f625444203a7c624c3fa123cfddd2">adc3adfdf30f625444203a7c624c3fa123cfddd2</a>
-<blockquote>
-<p>
- Slight improvement to &quot;permit-file-***&quot; parameter documentation.<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-20 11:17:53 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=829bfe72c69091da7f0d7c1243a7647114619070">829bfe72c69091da7f0d7c1243a7647114619070</a>
-<blockquote>
-<p>
- Fix tiffsep and tiffsep1 with new file access control and SAFER mode<br>
-<br>
- The tiffsep and tiffsep1 synthesize output file names with the outputfile<br>
- and the separation color name, but the 'open' of these filenames would<br>
- fail since they were not included on the permit_file_writing list.<br>
- Add the full filename before opening, and remove the names after closing.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-20 11:53:10 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=baad48ab4b35dc9edf0317a1773d9efc7631f2d7">baad48ab4b35dc9edf0317a1773d9efc7631f2d7</a>
-<blockquote>
-<p>
- Squash stupid const warning.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-20 19:42: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=3aa9b059018bb49ddf67a87ddd87e01157143b99">3aa9b059018bb49ddf67a87ddd87e01157143b99</a>
-<blockquote>
-<p>
- Squash some &quot;const&quot; warnings.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-19 11:51:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a09321624369d215a733fb991bf48c300c90107a">a09321624369d215a733fb991bf48c300c90107a</a>
-<blockquote>
-<p>
- Remove some needlessly passed parameters.<br>
-<br>
- For I am a bear of tiny brain, and such things confuse me.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-20 17:49:57 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=02108ce46f9beafbfa733598164a6ad254ada7ca">02108ce46f9beafbfa733598164a6ad254ada7ca</a>
-<blockquote>
-<p>
- Fix &quot;permit-file-xxxx&quot; handling.<br>
-<br>
- Ray spotted that gs_add_explicit_control_path was adding 17<br>
- to arg before using it. 17 happens to be the right amount<br>
- to add for &quot;--permit-file-read=&quot;, but the wrong amount for<br>
- write/control/all.<br>
-<br>
- Update the code to call it with the correct arg pointer<br>
- to start with.<br>
-<br>
- Also, update a couple of routines to cope with being called<br>
- with NULL strings.<br>
-<br>
- Also use enum values in switch rather than 0, 1, 2.<br>
-<br>
-base/gslibctx.c<br>
-pcl/pl/plmain.c<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-18 20:40:42 +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=c0df83637a6234f804bef5a7ef31fe1bc5b66d78">c0df83637a6234f804bef5a7ef31fe1bc5b66d78</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV in append_macro.<br>
-<br>
- Prevent SEGV if append_macro is called with a NULL pointer and safe guarded<br>
- calls to chunk_resize_object and chunk_object_size. Also resolved leak when<br>
- resetting macros.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=14839 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.1060<br>
-<br>
-base/gsmchunk.c<br>
-pcl/pcl/pcmacros.c<br>
-pcl/pcl/pcparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-19 11:02: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=071b96290c5e524291bb33b132e2cea3efd5f98e">071b96290c5e524291bb33b132e2cea3efd5f98e</a>
-<blockquote>
-<p>
- Make missing jbig2 decoder fatal error.<br>
-<br>
- If we have neither Luratech nor jbig2dec, have configure fail, unless<br>
- explicitly run with --without-jbig2dec<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-18 17:18:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d9889892feaac3ca09f85d9bbdc001b1aec50cc3">d9889892feaac3ca09f85d9bbdc001b1aec50cc3</a>
-<blockquote>
-<p>
- PDF interpreter - handle ObjStm containing more objects than declared<br>
-<br>
- There's no bug number for this one, I can't easily create a reduced file<br>
- without inadvertently fixing the problem, and I don't want to put the<br>
- customer file into Bugzilla.<br>
-<br>
- The problem is that the file contains an ObjStm (a compressed stream<br>
- containing a sequence of PDF objects) which contains more objects than<br>
- the stream declares. Not only that, but the extra object is neither the<br>
- first nor the last object, so its not trivial to ignore.<br>
-<br>
- Most consumers handle ObjStm constructs by using the 'catalog' at the<br>
- head of the stream to find the offset of each object in the stream and<br>
- then reposition to that object and read a single PDF object (note that<br>
- objects in an ObjStm do not begin with 'obj' and do not end with<br>
- 'endobj') which is IMO putting a lot of faith in the consumer's<br>
- ability to detect a single object.<br>
-<br>
- For performance reasons Ghostscript's PDF interpreter reads *all* the<br>
- objects in the ObjStm immediately and stores them, thus trading memory<br>
- use for performance (we only need to read and decompress the objects<br>
- once). This approach is totally defeated when there are more objects<br>
- than expected, because we don't know which object relates to which<br>
- object number (no 'x y obj' in an ObjStm).<br>
-<br>
- In this commit we spot the discrepancy; if there are too few objects we<br>
- exit immediately with an error (technically we could do something about<br>
- this too, provided the missing object is never used). If there are extra<br>
- objects then we move to a fallback.<br>
-<br>
- We discard all the objects we've read, then use the offsets in the<br>
- 'catalog' to calculate the position and length of each object in the<br>
- ObjStm. We position the file pointer to the start of the object and<br>
- use a SubFileDecode filter to limit the number of bytes read to the<br>
- difference between the offsets. We then use the existing code to read<br>
- all the objects in that stream. If we get more than one then we discard<br>
- all but the first.<br>
-<br>
- Repeat the above until we reach the last object in the catalog; that has<br>
- no known length so just read from there to the end of the stream.<br>
-<br>
- The complications are all around getting the objects on the stack in<br>
- the order expected by the code which follows, and defines the actual<br>
- objects.<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-18 14:28:32 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=107aae1f353db3b62f8b714c5100ec7bc180f2fb">107aae1f353db3b62f8b714c5100ec7bc180f2fb</a>
-<blockquote>
-<p>
- Tri/QuadriLinear changes for lcms2mt.<br>
-<br>
- Add a mechanism so that we can force lcms2mt to use<br>
- TriLinear (or QuadriLinear) interpolation for specific<br>
- transforms. This is primarily useful so we can get<br>
- &quot;best case&quot; transforms which we can use as a baseline<br>
- for our accelerations.<br>
-<br>
- The use of TriLinear/QuadriLinear is governed by a new<br>
- cmsFLAG bit, passed in to link creation. Unfortunately,<br>
- these flag bits are not passed all the way down to where<br>
- we actually need them. To avoid having to add an extra<br>
- flags argument in many places, I stash the flags in a<br>
- new field in the cmsContext. This is safe, if not entirely<br>
- pretty, as each context will only be used in a single<br>
- thread at a time. If this was a function used for more<br>
- than just testing, we'd consider doing it in the neater<br>
- (but more invasive) way.<br>
-<br>
-lcms2mt/include/lcms2mt.h<br>
-lcms2mt/src/cmscnvrt.c<br>
-lcms2mt/src/cmsintrp.c<br>
-lcms2mt/src/cmsopt.c<br>
-lcms2mt/src/lcms2_internal.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-16 11:32:33 +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=0b05dca78aaa456ba7b55b853917a4ae68a6fd38">0b05dca78aaa456ba7b55b853917a4ae68a6fd38</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent memory leaks in show_char_background.<br>
-<br>
- Prevent memory leaks on error and then later releasing graphic state.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=15988 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0891<br>
-<br>
-pcl/pcl/pctext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-17 10:37:58 +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=f40631e7592ed1287b2121840b3345acb1bdb1a8">f40631e7592ed1287b2121840b3345acb1bdb1a8</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent leak in gx_image_enum_begin.<br>
-<br>
- Prevent leak in gx_image_enum_begin by freeing clip_dev.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=15565 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0954<br>
-<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-17 09:02:49 +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=91d18aec6a19a0d3b341701d10355278f4703fdd">91d18aec6a19a0d3b341701d10355278f4703fdd</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV in download_pcl_pattern.<br>
-<br>
- The pattern is consumed by pl_dict_put during errors so remove second attempt to free it.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=15501 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0954<br>
-<br>
-pcl/pcl/pcuptrn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-17 11:42: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=8c5348ae5fc35b449aa68eb6668cb6cbc6f345e0">8c5348ae5fc35b449aa68eb6668cb6cbc6f345e0</a>
-<blockquote>
-<p>
- Fix file permissions interaction with '@' command line<br>
-<br>
- If an options file (prefixed '@' on the command line) followed something that<br>
- required initialising the Postscript interpreter (such as a '-c' option),<br>
- opening the file would potentially fail because file permissions had been<br>
- activated by the interpreter.<br>
-<br>
- Add and remove the file from the permit reading list before attempting to open<br>
- it.<br>
-<br>
-base/gsargs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-16 15:10:46 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=955c431ab611efd9a74e62a762cdc1ab9f64e14a">955c431ab611efd9a74e62a762cdc1ab9f64e14a</a>
-<blockquote>
-<p>
- Add explicit &quot;flush&quot; after warning message.<br>
-<br>
- The warning messages could get trampled on (due to buffering) by messages on<br>
- stderr, flushing ensures the warning is emitted as intended.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-13 09:33:20 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b3ed0ea5d07005e64badfb9212911a725fefb94">2b3ed0ea5d07005e64badfb9212911a725fefb94</a>
-<blockquote>
-<p>
- Have .setsafe/.setsafeglobal undefine operators<br>
-<br>
- In SAFER, we undefine certain delicate operators (mostly transparency related<br>
- ones), but we weren't doing so if SAFER was enabled using .setsafe<br>
-<br>
- This means some rejigging to keep NOSAFER and DELAYBIND working.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-12 14:23: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=b3a1114d04a82e534d915b125eb34de21317993a">b3a1114d04a82e534d915b125eb34de21317993a</a>
-<blockquote>
-<p>
- If set, add PCLFONTSOURCE value to permit_file_reading list<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-11 13:07: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=0350a0ab56e7b180d62af9423313d6c70345b386">0350a0ab56e7b180d62af9423313d6c70345b386</a>
-<blockquote>
-<p>
- Bug 701561: 'reduce' paths before adding to permit lists<br>
-<br>
- Before attempting to open files, we pre-process the requested file name to<br>
- remove surplus/unnecessary elements: i.e. './././file' would be reduced to just<br>
- './file', or '../dir/../dir/../dir/file' would be reduced to '../dir/file'.<br>
-<br>
- The 'reduced' path is what we try to open, hence it is also what we check<br>
- against the file permissions list before we allow files to be accessed.<br>
-<br>
- That being so, we should also 'reduce' paths as we add them to the permissions<br>
- lists - thus the permissions list creation and checking are consistent.<br>
-<br>
-base/gslibctx.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-15 12:18:48 +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=511260d72a4b6df9bd2ba48e022f7c3921b547cb">511260d72a4b6df9bd2ba48e022f7c3921b547cb</a>
-<blockquote>
-<p>
- Bug 697545 : Propagate error codes from pcl_break_underline correctly.<br>
-<br>
- The code has been updated to correctly propagate error codes from all<br>
- instances of pcl_break_underline.<br>
-<br>
-pcl/pcl/pccprint.c<br>
-pcl/pcl/pcfont.h<br>
-pcl/pcl/pcpage.c<br>
-pcl/pcl/pcpatrn.c<br>
-pcl/pcl/pcpatxfm.c<br>
-pcl/pcl/pctext.c<br>
-pcl/pcl/pcursor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-11 14:10:27 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c917d64d73fae679d445b233662e0ef4480078f6">c917d64d73fae679d445b233662e0ef4480078f6</a>
-<blockquote>
-<p>
- Fix Bug 696333. Allow large bitmaps in clist when writing tile cache.<br>
-<br>
- When writing bits to update the tile cache, we don't need to restrict to<br>
- a single command buffer as with the copy_mono and copy_color commands.<br>
-<br>
- Progressions on:<br>
- tests_private/comparefiles/Bug694385.pdf.psdcmyk.300.1..gs<br>
- tests_private/pdf/sumatra/2028_-_invisible_patterns.pdf.psdcmyk.300.1..gs<br>
- tests_private/ps/ps3cet/09-47B.PS.pdf.pkmraw.300.0..gs_pdf<br>
- tests_private/ps/ps3fts/176-01.ps.psdcmyk.300.1..gs<br>
-<br>
-base/gxclbits.c<br>
-base/gxcldev.h<br>
-base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-12 10:37:42 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d79d17251261637b672f8518144ffffc42e1eb0e">d79d17251261637b672f8518144ffffc42e1eb0e</a>
-<blockquote>
-<p>
- Fix SEGV with flp device and PCL with clist mode and large BandHeight.<br>
-<br>
- If the 'clist_init' fails initially (with rangecheck) due to the buffer<br>
- space too small for the BandHeight specified, we loop in the caller after<br>
- increasing the buffer size, but clist_init left &quot;is_open&quot; false when failing.<br>
- Add save_is_open in gdev_prn_setup_as_command_list so that we can restore it<br>
- if the clist_init eventually suceeds.<br>
-<br>
- The SEGV was with image_data because re-opening the flp device reset the<br>
- &quot;obsolete&quot; procs to the default, so flp_image_data was replaced by the<br>
- gx_default_image_data, but no begin_image had been performed (flp_begin_image<br>
- skipped this since we were not yet at the FirstPage).<br>
-<br>
-base/gdevprn.c<br>
-base/gxclist.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-16 18:53:49 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8b0ed52ead9605cae14939362dbf9cdf22b9746c">8b0ed52ead9605cae14939362dbf9cdf22b9746c</a>
-<blockquote>
-<p>
- Update jbig2dec stuff for 0.17 release.<br>
-<br>
-jbig2dec/CHANGES<br>
-jbig2dec/jbig2.h<br>
-jbig2dec/jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-16 18:48:36 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79e2d671b672f3bc4cca09808dd683b71eff702a">79e2d671b672f3bc4cca09808dd683b71eff702a</a>
-<blockquote>
-<p>
- jbig2dec: Use the same contact information everywhere.<br>
-<br>
-jbig2dec/README<br>
-jbig2dec/configure.ac.in<br>
-jbig2dec/jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-16 16:12:32 +0100
-</strong>
-<br>Paul Vojta &lt;vojta@math.berkely.edu&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7e49d51de2b14f9a4ca873135ba3c8d7aa56256f">7e49d51de2b14f9a4ca873135ba3c8d7aa56256f</a>
-<blockquote>
-<p>
- Documentation - fix some typos<br>
-<br>
- Bug #701589 &quot;Minor documentation problems in 9.28-rc2&quot;<br>
-<br>
- Thanks to Paul Vojta for pointing these out. Unfortunately we cannot use the<br>
- supplied patch, as it includes alterations to History9.htm, which is auto-<br>
- generated from the commit logs. The remaining changes are applied here.<br>
-<br>
-doc/Language.htm<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-11 12:18: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=e3d2cd4b2f13573962105d1761e7bb58d5f079c9">e3d2cd4b2f13573962105d1761e7bb58d5f079c9</a>
-<blockquote>
-<p>
- Bug 701563: pdfwrite annotation pdfmark /Border key<br>
-<br>
- Despite the spec saying the values for the /Border key are in user space<br>
- coordinates, Distiller appears to pass the values through to the output PDF<br>
- untouched (no rescaling - unlike the values for /Rect, also in user space,<br>
- according to the spec, which it does scale/translate). Ghostscript/pdfwrite<br>
- did scale the /Border values.<br>
-<br>
- This just changes pdfwrite to write the values out unchanged.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-16 09:56: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=4ca426a86125b7bf2f52c00fbba1cef1395ea011">4ca426a86125b7bf2f52c00fbba1cef1395ea011</a>
-<blockquote>
-<p>
- Documentation - add a note about SAFER for PDF/X ICC profiles<br>
-<br>
- Bug #701553 &quot;Examples of PDF/X and PDF/A conversion should be updated for Ghostscript 9.28&quot;<br>
-<br>
- ICC profiles required for PDF/X and PDF/A output need to be readable<br>
- in order to work when -dSAFER is true (the new default). This wasn't<br>
- clear from the documentation, so add a note about it.<br>
-<br>
- As noted in the bug report, it is possible to embed the profile in the<br>
- PostScript code, but as Chris says this is probably beyond reasonable<br>
- expectations of the average user; they simply won't change the example<br>
- and will then complain that it isn't correct. Users capable of making<br>
- this work almost certainly have enough knowledge to realise they can<br>
- do this instead of making the profile readable.<br>
-<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-13 10:28:37 +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=e0238104296a361d2dfcc678075e32f4c2070c52">e0238104296a361d2dfcc678075e32f4c2070c52</a>
-<blockquote>
-<p>
- Bug 697545 : Propagate error codes from pcl_set_cap_x and pcl_set_cap_y correctly.<br>
-<br>
- The code has been updated to correctly propagate error codes from all instances<br>
- of pcl_set_cap_x and pcl_set_cap_y.<br>
-<br>
-pcl/pcl/pcfontpg.c<br>
-pcl/pcl/pcjob.c<br>
-pcl/pcl/pcpage.c<br>
-pcl/pcl/pcsfont.c<br>
-pcl/pcl/pcstatus.c<br>
-pcl/pcl/pcursor.c<br>
-pcl/pcl/pcursor.h<br>
-pcl/pcl/rtgmode.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-12 07:59:03 +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=29f3e8d45595f443170bf13290404be4d34b5a2e">29f3e8d45595f443170bf13290404be4d34b5a2e</a>
-<blockquote>
-<p>
- Bug 697545 : Propagate error codes from pcl_do_CR and pcl_do_LF correctly.<br>
-<br>
- The code has been updated to correctly propagate error codes from all instances<br>
- of pcl_do_CR and pcl_do_LF.<br>
-<br>
-pcl/pcl/pcfontpg.c<br>
-pcl/pcl/pcparse.c<br>
-pcl/pcl/pctext.c<br>
-pcl/pcl/pcursor.c<br>
-pcl/pcl/pcursor.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-12 19:41:47 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=afe11ca136aa173541ed0df09b8c189d2344f381">afe11ca136aa173541ed0df09b8c189d2344f381</a>
-<blockquote>
-<p>
- Fix various printer devices to properly call spec ops.<br>
-<br>
- Various printer devices (psd, psdcmykog, tiffsep, tiffscaled)<br>
- were passing the spec ops on to gx_default_dev_spec_op rather<br>
- than gdev_prn_dev_spec_op.<br>
-<br>
- The most obvious implication of this was that we'd sometimes<br>
- get a warning about printer devices having a private spec op.<br>
-<br>
-devices/gdevcmykog.c<br>
-devices/gdevpsd.c<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-12 17:09:50 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3b2ad1f24d2e9705481f9feb6835aa3e851726ac">3b2ad1f24d2e9705481f9feb6835aa3e851726ac</a>
-<blockquote>
-<p>
- Bug 701568 followup: Fix RLE compressor.<br>
-<br>
- The previous fix to the RLE compressor reveals an additional<br>
- existing issue to do with us not checking whether we have<br>
- space in the buffer to write the EOD byte.<br>
-<br>
- Fixed here.<br>
-<br>
-base/srle.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-12 09:35: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=68c7275d4a580dca6c0ed3798f3717eea3513403">68c7275d4a580dca6c0ed3798f3717eea3513403</a>
-<blockquote>
-<p>
- Bug 701568: Fix gdevpx.c RLE stream handling.<br>
-<br>
- The current code in pclxl_write_image_data_RLE passes<br>
- lines of data to the RLE compression routine. It tells<br>
- each invocation of that routine that this is the &quot;last&quot;<br>
- block of data, when clearly it is not.<br>
-<br>
- Accordingly, the compression routine inserts the &quot;EOD&quot; byte<br>
- into the stream, and returns EOFC.<br>
-<br>
- Independently of the return value used, having multiple EOD<br>
- bytes in the data is clearly wrong. Update the caller to only<br>
- pass &quot;last&quot; in for the last block.<br>
-<br>
- The code still returns EOFC at the end of the data, so update<br>
- this final call to accept (indeed, expect) that return value<br>
- there.<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-10 14:22:32 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=13a560a4d13d51e4dd9f7dd48b27a6ebe681f877">13a560a4d13d51e4dd9f7dd48b27a6ebe681f877</a>
-<blockquote>
-<p>
- Update CAL makefile for NEON cms functions (correction)<br>
-<br>
- Add NEON flags and includes.<br>
-<br>
-base/cal.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-10 14:22:32 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=61cff6434022bb4c444bd500da0628302abfb35e">61cff6434022bb4c444bd500da0628302abfb35e</a>
-<blockquote>
-<p>
- Update CAL makefile for NEON cms functions.<br>
-<br>
-base/cal.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-10 20:26:38 +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=be793aa94180e06135fd7fec36b6f6ab9ab67519">be793aa94180e06135fd7fec36b6f6ab9ab67519</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent memory leaks in gx_image_enum_begin.<br>
-<br>
- Prevent memory leaks on error and then later releasing graphic state.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=15242 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0720<br>
-<br>
-base/gxipixel.c<br>
-pcl/pcl/pcparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-09 21:41: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=08c1e576fc09fcc7fdf5cd935d91fdfea1e7f0f9">08c1e576fc09fcc7fdf5cd935d91fdfea1e7f0f9</a>
-<blockquote>
-<p>
- Bug 697545 : Propagate error code in pcl_enter_graphics_mode.<br>
-<br>
- Propagate error code in pcl_enter_graphics_mode to prevent trying to use an<br>
- uninitialised variable later leading to SEGV.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=15210 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0720<br>
-<br>
-pcl/pcl/rtgmode.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-10 09:04: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=8675b40266cbf9771a08f4178a6009cfd17e0ba1">8675b40266cbf9771a08f4178a6009cfd17e0ba1</a>
-<blockquote>
-<p>
- Fix bug 701550, problem with forall on strings.<br>
-<br>
- Hard to believe, but this problem has existed since at least version 3.33.<br>
- The 'string_continue' function altered the size which was used to decide if<br>
- there were still characters to be processed BEFORE invoking the 'push(#)' macro.<br>
- If the 'push(1)' encountered a full stack segment, it would return stackoverflow<br>
- so that the operand stack could be extended. This meant that the decision to<br>
- stop enumerating the string would end early (depending on how many times the<br>
- stackoverflow occurred).<br>
-<br>
- Usually the procedure of the forall would either consume the character (reducing<br>
- the stack), or add an element to the stack triggering the stack extension before<br>
- the next execution of string_continue, but -c &quot;401 string { dup } forall count =&quot;<br>
- results in only 800 stack elements (rather than 802 as expected).<br>
-<br>
-psi/zgeneric.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-08 13:30:52 +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=d9e1d9474e5e21fe8ed9a451b91c48233e629eee">d9e1d9474e5e21fe8ed9a451b91c48233e629eee</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent memory leaks and memory corruption.<br>
-<br>
- Prevent several memory leaks in pcl_enter_graphics_mode by releasing graphic state.<br>
- Also prevent memory corruption by propagating error code from pcl_set_drawing_color.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=14648 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0861.new<br>
-<br>
-pcl/pcl/pcdraw.c<br>
-pcl/pcl/rtgmode.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-09 14:19:33 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bc48c29c5e86e6c528e23140c71ecfb58588333f">bc48c29c5e86e6c528e23140c71ecfb58588333f</a>
-<blockquote>
-<p>
- Optimise Eval{5,6,7,8}Inputs{,Float}.<br>
-<br>
- Only use 1 Temporary array, and avoid needless work in the<br>
- 0xFFFF cases.<br>
-<br>
-lcms2mt/src/cmsintrp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-09 11:03: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=63e1fd40674a4f89f6593098cf100382061753e5">63e1fd40674a4f89f6593098cf100382061753e5</a>
-<blockquote>
-<p>
- Tweak Eval4InputsFloat for speed.<br>
-<br>
- Move to the Pentachoronal Interpolation algorithm.<br>
-<br>
-lcms2mt/src/cmsintrp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-06 18:04: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=1cc72912138544dcf00ed0dbc77ceaf47de04e91">1cc72912138544dcf00ed0dbc77ceaf47de04e91</a>
-<blockquote>
-<p>
- Tweak Eval4Inputs for speed.<br>
-<br>
- In coding the SSE version for CAL, I spotted a slightly<br>
- preferable test that allows us to capture some special<br>
- cases for free. These special cases accelerate some<br>
- useful cases including:<br>
-<br>
- * C=M=Y=K (such as when all 0 = white?)<br>
- * C=M=Y (such as when pure black)<br>
- * M=Y=K (possibly useful in case we ever have profiles that<br>
- store K first).<br>
-<br>
-lcms2mt/src/cmsintrp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-06 17:10: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=3f46434c0fe3707f53a825f39fa1bab8c0875c03">3f46434c0fe3707f53a825f39fa1bab8c0875c03</a>
-<blockquote>
-<p>
- Update CAL initialisation to register second lcms2mt plugin.<br>
-<br>
- The first plugin deals with transformations. The second deals<br>
- with interpolation.<br>
-<br>
-base/gsicc_lcms2mt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-13 01:35:36 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5e5ed8620f348e0fa619171d6f05a966a4bcf83">b5e5ed8620f348e0fa619171d6f05a966a4bcf83</a>
-<blockquote>
-<p>
- jbig2dec: Validate coordinates when add image onto page.<br>
-<br>
- Detected by Coverity in CID 94850.<br>
-<br>
-jbig2dec/jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-12 18:55:16 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ccc1a52f59194193450747e41006982d322c43a5">ccc1a52f59194193450747e41006982d322c43a5</a>
-<blockquote>
-<p>
- jbig2dec: Avoid extending page image beyond INT_MAX pixels high.<br>
-<br>
- Detected by Coverity in CID 95080.<br>
-<br>
-jbig2dec/jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-12 18:52:44 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=758951f873b4b80de3c11294c3bc76ca0d6144d7">758951f873b4b80de3c11294c3bc76ca0d6144d7</a>
-<blockquote>
-<p>
- jbig2dec: Validate range of Huffman Table range values.<br>
-<br>
- Detected by Coverity in CID 94835.<br>
-<br>
-jbig2dec/jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-07 13:29:40 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd815dfe5e8db6e997466765218c80bb54902234">cd815dfe5e8db6e997466765218c80bb54902234</a>
-<blockquote>
-<p>
- jbig2dec: Avoid double checks for negative coordinates.<br>
-<br>
- Negative coordinates are already handled prior in the function<br>
- by falling back to the unoptimized case.<br>
-<br>
- This was detected by Coverity in CID 303984 and CID 303985.<br>
-<br>
-jbig2dec/jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-03 02:27:40 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1ae9b9b92bfa6fef04a50b8f27c3dc6e9e03fba0">1ae9b9b92bfa6fef04a50b8f27c3dc6e9e03fba0</a>
-<blockquote>
-<p>
- jbig2dec: A small collection of code cleanups.<br>
-<br>
- * Refer to Jbig2ArithCx for memsetting in case it ever changes.<br>
- * Fix typo.<br>
- * Avoid using local variable when unnecessary.<br>
-<br>
-jbig2dec/jbig2.c<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-21 15:02:14 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=14cc5cb07861b8bd8c3a2cfd1d7ac21dd98fa202">14cc5cb07861b8bd8c3a2cfd1d7ac21dd98fa202</a>
-<blockquote>
-<p>
- jbig2dec: Add all ubc test files.<br>
-<br>
-jbig2dec/test_jbig2dec.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-14 03:27:31 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49a6ff2b166a4cda4d7b8c9d8192bb6f419c7ca3">49a6ff2b166a4cda4d7b8c9d8192bb6f419c7ca3</a>
-<blockquote>
-<p>
- Bug 701197: jbig2dec: Fix incorrectly computed halftone skip mask.<br>
-<br>
- Halftone regions using a skip mask and negative horizontal grid origin<br>
- offsets caused issues due to multiplying signed and unsigned integers.<br>
- The mixed types expression was computed unsigned unsigned arithmetic<br>
- before being converted back to a signed integer. This meant that an<br>
- expected negative value became positive.<br>
-<br>
- Several of the test files mentioned in the README rendered incorrectly,<br>
- e.g. 200-6-45.jb2. With this fix all files render correctly again.<br>
-<br>
-jbig2dec/jbig2_halftone.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-14 15:09:12 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8719833a6a4242880ad8b81cb8fe19e03667af52">8719833a6a4242880ad8b81cb8fe19e03667af52</a>
-<blockquote>
-<p>
- jbig2dec: Avoid duplicate declarations of Huffman tables in test code.<br>
-<br>
- This is done by moving the tables into a separate compilation module and<br>
- declaring the tables extern in the header file that is used elsewhere.<br>
-<br>
-base/jbig2.mak<br>
-jbig2dec/Makefile.am<br>
-jbig2dec/Makefile.unix<br>
-jbig2dec/jbig2_hufftab.c<br>
-jbig2dec/jbig2_hufftab.h<br>
-jbig2dec/msvc.mak<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-14 14:51:01 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d75727a7fd5efb2245c7b0d0b33ee8611446c150">d75727a7fd5efb2245c7b0d0b33ee8611446c150</a>
-<blockquote>
-<p>
- jbig2dec: Fix leak of huffman decoder state in test code.<br>
-<br>
-jbig2dec/jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-14 14:50:09 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b3f859987f152e13ab141143234f686749f2caf7">b3f859987f152e13ab141143234f686749f2caf7</a>
-<blockquote>
-<p>
- jbig2dec: Declare internal data array static.<br>
-<br>
-jbig2dec/jbig2_arith.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-14 14:47:44 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49fa7d21bc555a96e19318b56301185f12f68c55">49fa7d21bc555a96e19318b56301185f12f68c55</a>
-<blockquote>
-<p>
- jbig2dec: Fix leak of log message in command line tool.<br>
-<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-21 15:02:02 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=314250a3126243a228249ebf1e6272c0beaec9d6">314250a3126243a228249ebf1e6272c0beaec9d6</a>
-<blockquote>
-<p>
- jbig2dec: Verify file hashes of test files during testing.<br>
-<br>
- Previously jbig2dec would accept any file with the same name.<br>
-<br>
-jbig2dec/test_jbig2dec.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-14 14:49:21 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a9b92d33e7ed5e06d0728d6a1be771d8b464c50e">a9b92d33e7ed5e06d0728d6a1be771d8b464c50e</a>
-<blockquote>
-<p>
- jbig2dec: Expect test files to reside inside jbig2dec directory.<br>
-<br>
-jbig2dec/test_jbig2dec.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-14 15:18:45 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8b3ffd237746e2bab2867ad460e8635a79cd5916">8b3ffd237746e2bab2867ad460e8635a79cd5916</a>
-<blockquote>
-<p>
- jbig2dec: Indent test code by spaces like the rest of the code.<br>
-<br>
-jbig2dec/test_jbig2dec.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-14 22:18:14 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e957c0b1afc6d2d705c9d075fc55db2de5df854">2e957c0b1afc6d2d705c9d075fc55db2de5df854</a>
-<blockquote>
-<p>
- jbig2dec: Make tests expect that some test files return white image.<br>
-<br>
- Previously these tests would just error out and jbig2dec would not<br>
- return any output file at all. Now, jbig2dec parses as much as<br>
- possible, while emitting warning/error messages. In the case of a<br>
- few of the test files the end result is a white image.<br>
-<br>
-jbig2dec/test_jbig2dec.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-14 15:15:53 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c5c3a1f14c85582d09ab58f55b1fd83435b6562">1c5c3a1f14c85582d09ab58f55b1fd83435b6562</a>
-<blockquote>
-<p>
- jbig2dec: Indent Makefiles with tabs like the rest of the Makefiles.<br>
-<br>
-base/jbig2.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-03 23:54: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=5a6832ca60dfc34cb9a0680590cbd086f528fd22">5a6832ca60dfc34cb9a0680590cbd086f528fd22</a>
-<blockquote>
-<p>
- Implement HyperPentahedral interpolation within lcms2mt.<br>
-<br>
- This accelerates conversions from 4 component spaces, such as<br>
- CMYK.<br>
-<br>
-base/gxfill.c<br>
-lcms2mt/src/cmsintrp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-31 20:22:11 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c6d485f4ba59072fba1a73f8f61071b00d7a7e6">1c6d485f4ba59072fba1a73f8f61071b00d7a7e6</a>
-<blockquote>
-<p>
- Bug 700088: Report error if all wanted J2K components are not decoded.<br>
-<br>
- Ghostscript used to attempt to use even the undecoded components.<br>
- The source code for upstream's opj_decompress tool avoided this by<br>
- a workaround along with a comment indicating that this ought to be<br>
- done in the library (so all clients, e.g. Ghostscript will benefit<br>
- from it). With this commit the library will error out if not all<br>
- requested components are successfully decoded. Thus Ghostscript<br>
- will no longer crash.<br>
-<br>
- Reported in https://github.com/uclouvain/openjpeg/issues/1158<br>
- sent upstream in https://github.com/uclouvain/openjpeg/pull/1164<br>
- and finally committed in e66125fe260deee49fdf6e9978d9bd29871dd5bb<br>
-<br>
-openjpeg/src/bin/jp2/opj_decompress.c<br>
-openjpeg/src/lib/openjp2/j2k.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-03 12:34:55 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b7d32c453538bee41c34f8a77a3feb1dcc0ce759">b7d32c453538bee41c34f8a77a3feb1dcc0ce759</a>
-<blockquote>
-<p>
- Undo commit 95f7befcec1b30fd5014c8ad616485d32901ce33 for release<br>
-<br>
- Proper handling of the page group color space is going to require<br>
- a more complex solution whereby we ensure that we do the final<br>
- alpha blending in the page group color space and not the target<br>
- device color space.<br>
-<br>
-base/gstrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-03 08:52:16 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=40934a68930a1d6a41a26df694e1e50fe3c60202">40934a68930a1d6a41a26df694e1e50fe3c60202</a>
-<blockquote>
-<p>
- Add -sBlendColorProfile into Use.htm<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-03 18:15:56 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e63504054baea4275af88e95418b5282c4394685">e63504054baea4275af88e95418b5282c4394685</a>
-<blockquote>
-<p>
- Avoid potential UMR with arg checking in arg sanitization code.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-02 17:16:45 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cfdb64eec150da48dea5063b14ae7596e6b7050a">cfdb64eec150da48dea5063b14ae7596e6b7050a</a>
-<blockquote>
-<p>
- Proper fix for deep color overprint.<br>
-<br>
- The previous fix confused memset and memcpy. Properly write the<br>
- (native endian) 16 bit color values into the big endian buffer.<br>
-<br>
-base/gsovrc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-02 12:59:33 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eeeb033d21f22b128900ebc998668c87be725f7d">eeeb033d21f22b128900ebc998668c87be725f7d</a>
-<blockquote>
-<p>
- Fix deep color mattes.<br>
-<br>
- As seen with the content vanishing when rendering<br>
- tests_private/pdf/sumatra/uninitialized_value_with_JPX_images.pdf<br>
- to psdcmyk16. The Softmask on the image has a Matte of [1,1,1]<br>
- and the calculations in the current code overflow, meaning that<br>
- it comes out as completely white.<br>
-<br>
- We resort to 64bit to avoid the overflow. Mattes are vanishingly<br>
- rare, so speed shouldn't be an issue. We can revisit if we ever<br>
- find a case that matters.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-31 12:45:47 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5569e2b2057a25ff1fe0b2b5106e71f2b5142f5c">5569e2b2057a25ff1fe0b2b5106e71f2b5142f5c</a>
-<blockquote>
-<p>
- Update overprint hl_color code to cope with 16bit devices too.<br>
-<br>
-base/gsovrc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-31 12:16:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=51dbfc90fdc681f4500b498cec52056fb0d2224b">51dbfc90fdc681f4500b498cec52056fb0d2224b</a>
-<blockquote>
-<p>
- Fix deep color transparency overprint.<br>
-<br>
- The component copy loop at the end of the blend could fail to copy<br>
- enough entries.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-30 15:16:34 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e48a71a99beb5870edadf0754e2c3bcf6a86f87">1e48a71a99beb5870edadf0754e2c3bcf6a86f87</a>
-<blockquote>
-<p>
- Avoid overflow in deep color luminosity calculations.<br>
-<br>
- Resort to 64bit as scale calculations are not constrained<br>
- to the usual 16bit range.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-29 10:02: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=59660b5d998b53df383192aee71b7439a424be47">59660b5d998b53df383192aee71b7439a424be47</a>
-<blockquote>
-<p>
- Fix clearing of the drag and drop file list<br>
-<br>
- Because we have to store the list of file names from drag and drop events, in<br>
- order to correctly add and remove them from the permit file read list, we also<br>
- want to clear the lists before we destroy the &quot;text&quot; window object.<br>
-<br>
- The problem is, this happens after we shutdown Ghostscript and unload the dll.<br>
-<br>
- This moves that clearing of the list into function that we call before we<br>
- shut down.<br>
-<br>
-psi/dwmain.c<br>
-psi/dwtext.c<br>
-psi/dwtext.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-28 10:14: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=94742723659fb4bba6b50ad29123d4ff38a9ebd6">94742723659fb4bba6b50ad29123d4ff38a9ebd6</a>
-<blockquote>
-<p>
- Fix path permissions added from cidfmap.<br>
-<br>
- From the cidfmap, we accumulate a list of unique directory paths a we process<br>
- cidfmap and then add them - when I did that code, I forgot that to allow access<br>
- to the directory, we need a trailing directory separator.<br>
-<br>
- Add that before calling .addcontrolpath<br>
-<br>
-Resource/Init/gs_cidfm.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 16:49: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=4135d3b50a66dc67eb7f4f4ad360fdf703783141">4135d3b50a66dc67eb7f4f4ad360fdf703783141</a>
-<blockquote>
-<p>
- Fix font file finding with -P<br>
-<br>
- In trying to reproduce the issue that inspired commit dea69cd04964, I noticed<br>
- that font file searching wasn't working correctly with -P specified on the<br>
- command line.<br>
-<br>
- Previously, it could just end up with us not finding a font we should have, but<br>
- with dea69cd04964 it would result in a typecheck error.<br>
-<br>
- This ensures the stack is always how it should be after the findlibfile<br>
- call<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-22 16:10:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b9ab0d54ab2299b3db94e57f45cfc52f6045e62">2b9ab0d54ab2299b3db94e57f45cfc52f6045e62</a>
-<blockquote>
-<p>
- Make it clear: file/path matching is always case sensitive<br>
-<br>
- even on Windows.<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-29 19:50:08 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc2cbb8c78acdff736a966eb40ca22a6a7c52b26">cc2cbb8c78acdff736a966eb40ca22a6a7c52b26</a>
-<blockquote>
-<p>
- Fix overflow in 16bit blending calculations.<br>
-<br>
- The blending code uses the following construction in<br>
- several places:<br>
-<br>
- src_scale = ...; /* a value between 0 and 0x10000 */<br>
- tmp = (y-z) * src_scale + 0x8000;<br>
- foo = x + (tmp&gt;&gt;16);<br>
-<br>
- Where x,y,z, are all expected to be in the 0...0xffff range.<br>
-<br>
- Due to y-z having a sign bit, this can overflow a 32 bit tmp.<br>
-<br>
- We therefore sacrifice a bit of accuracy in src_scale to get<br>
- correctness.<br>
-<br>
-base/gxblend.c<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-28 14:13:27 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8c5059661a48e2e17d0f15c7c6936510192728b6">8c5059661a48e2e17d0f15c7c6936510192728b6</a>
-<blockquote>
-<p>
- Remove outdated FIXME's.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-28 12:50: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=f531552c99a04f003412f7a83d4661e927f88d40">f531552c99a04f003412f7a83d4661e927f88d40</a>
-<blockquote>
-<p>
- Bug 701446: Avoid divide by zero in shading.<br>
-<br>
- The previous commit for this bug was enough to solve the problem<br>
- for ppmraw, but not, it seems, for other devices. This addresses<br>
- the division by zero more directly.<br>
-<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 20:13:02 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=25f7cb4da347610dd49bd8001746605f1a29caa8">25f7cb4da347610dd49bd8001746605f1a29caa8</a>
-<blockquote>
-<p>
- Fix deep color transparency saturation blending.<br>
-<br>
- Problem seen with:<br>
-<br>
- tests_private/pdf/PDF_1.7_FTS/fts_25_2513.pdf.psdcmyk16.300.1<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 17:45:57 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b9e4b4e4d97a2f0c32596fed0342fb83773a56c2">b9e4b4e4d97a2f0c32596fed0342fb83773a56c2</a>
-<blockquote>
-<p>
- Bug 701446: Avoid division by zero in gx_shade_trapezoid<br>
-<br>
- Remove some incorrect clipping code.<br>
-<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 15:54: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=0d46b4f51b5efba7e72b7d45517d0fba642477aa">0d46b4f51b5efba7e72b7d45517d0fba642477aa</a>
-<blockquote>
-<p>
- Exit early from gx_shade_trapezoid in more cases.<br>
-<br>
- A zero height trap isn't plotted, so we can bail out early in<br>
- that case.<br>
-<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-26 17:02: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=42f386a85d3998310f0317501b54780ffbe6dc6b">42f386a85d3998310f0317501b54780ffbe6dc6b</a>
-<blockquote>
-<p>
- Fix deep colour transparency &quot;uncompositing&quot;.<br>
-<br>
- Uncompositing a group uses a scale factor that is greater in range<br>
- than we'd like; we need to resort to 64bit to do this to avoid<br>
- losing accuracy.<br>
-<br>
- This solves problems seen in:<br>
-<br>
- tests_private/comparefiles/Bug689918.pdf.psdcmyk16.300.1<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 14:26: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=dea69cd04964b27a08c8b340476d58031cb9e517">dea69cd04964b27a08c8b340476d58031cb9e517</a>
-<blockquote>
-<p>
- Handle relative FONTPATH values<br>
-<br>
- Prior to 9.21 (specifically: 8abd22010eb4db0fb1b10e430d5f5d83e015ef70), relative<br>
- paths for FONTPATH worked, but did so due to a logic fault with how we search<br>
- for &quot;lib&quot; files.<br>
-<br>
- When attempting to open file names specified on the command line, we used a<br>
- flag set in the command line handling (starting_arg_file) to know whether the<br>
- lib file searching logic should try to open the file name directly (as well as<br>
- trying the file combined with each path in the search path).<br>
-<br>
- In versions prior to commit 8abd22010eb4 that flag (starting_arg_file) could<br>
- remain set to true, even after the command line file(s) had been opened. This<br>
- represented a (minor) security risk. Commit 8abd22010eb4 ensured the flag was<br>
- properly (re)set, and that caused relative paths for FONTPATH stopped working.<br>
-<br>
- Rather than reintroduce the security risk, update the code that checks whether<br>
- the font files exist so it explicitly tries the file name directly, rather than<br>
- assuming .libfile (or findlibfile, in this case) does that automatically.<br>
-<br>
- Also remove an extraneous (but benign) dup of the font name.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 15:27: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=5d10fde23ccd74c2721e4870c5914fe7373a7816">5d10fde23ccd74c2721e4870c5914fe7373a7816</a>
-<blockquote>
-<p>
- pdfwrite - fix corner case with Color Conversion<br>
-<br>
- Bug #701456 &quot;Ghostscript creates broken PDF file after color conversion&quot;<br>
-<br>
- The test file is, essentially weird. The image on page 3 is not a single<br>
- image, its a series of images, all of which are in a /Indexed /DeviceRGB<br>
- colour space.<br>
-<br>
- In addition, these images are drawn on *top* of another set of images<br>
- (thereby completely obscuring them). These images are also drawn in<br>
- /Indexed /DeviceRGB. However, these images are in fact monochrome, the<br>
- Indexed space consists of 2 colours. This means that (highly unusually)<br>
- we have a DeviceRGB image with 1 Bit Per Component.<br>
-<br>
- This caused problems for the pdfwrite compression filter chooser because<br>
- it chose (and configured) a compression scheme suitable for 1 BPC data<br>
- and then actually output 8 BPC data. This led to the compression filter<br>
- writing too little data.<br>
-<br>
- Fix this here by setting the BPC to 8 if we are doing colour conversion,<br>
- and have the colour conversion setup code use the original value in the<br>
- image enumerator (the conversion code *does* need to know the input is<br>
- 1 BPC).<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 11:36: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=02c252f00e7bbc9a9a23d0a0996e88ba1839f127">02c252f00e7bbc9a9a23d0a0996e88ba1839f127</a>
-<blockquote>
-<p>
- PDF interpreter - more /Mask strangeness in Acrobat<br>
-<br>
- Bug #701468 &quot; More weirdness with images containing invalid /Mask values&quot;<br>
-<br>
- In order to render this file as per Acrobat, we need to ignore the /Mask<br>
- array. However, in order to render bug 689717 correctly we need to fix<br>
- the /Mask array.<br>
-<br>
- Both cases are 1 BitsPerComponent DeviceGray images, the only difference<br>
- is the actual /Mask values. Bug 689717 has [255 255] while 701468 has<br>
- [243 255]. We can differentiate based on whether we have DeviceGray<br>
- 1 BPC image, where the Mask values are not the same. In the case they<br>
- are different we use the existing technique of calculating the maximum<br>
- value and using that (for both, so there is no range). Where there is a<br>
- range (ie not a single colour) this is clearly unusable in a 2-colour<br>
- image, so ignore the /Mask altogether.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-26 15:28:33 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3554f0fc4dadebad2e816adbd7cf4a548f76de74">3554f0fc4dadebad2e816adbd7cf4a548f76de74</a>
-<blockquote>
-<p>
- Fix deep colour knockout logic.<br>
-<br>
- Problem seen with:<br>
-<br>
- tests_private/pdf/PDF_1.7_FTS/fts_25_2507.pdf.psdcmyk16.72.0<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-26 14:34:46 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5280581fd0c075da7dc0632937e294a9fa3fe736">5280581fd0c075da7dc0632937e294a9fa3fe736</a>
-<blockquote>
-<p>
- Squash a couple of warnings.<br>
-<br>
-base/gdevmem.c<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-26 14:01:39 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e872508d683302b556a160004a9ca3d64e7b4f1">2e872508d683302b556a160004a9ca3d64e7b4f1</a>
-<blockquote>
-<p>
- Fix SoftLight blending in deep color transparency.<br>
-<br>
- As seen with:<br>
-<br>
- gs -sDEVICE=psdcmyk16 -r72 -dMaxBitmap=80000000 -o out.psd<br>
- tests_private/pdf/PDF_1.7_FTS/fts_09_0919.pdf<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-26 11:28:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1fe43c3ba4423631129925d789c936b9e461d1d6">1fe43c3ba4423631129925d789c936b9e461d1d6</a>
-<blockquote>
-<p>
- Fix problems with pngalpha and deep color transparency filling.<br>
-<br>
- The pngalpha device is created with a depth of 32, with 3 color<br>
- components; this was confusing pdf14 into thinking that more<br>
- than 8 bits per color were being used, and so deep color buffers<br>
- were required.<br>
-<br>
- To fix this we update the logic to be smarter; in cases where we<br>
- don't have a clear determination based on bits alone, we look<br>
- at the max_color and max_gray values. Because this code is now<br>
- more complex than before, we pull it into a shared function.<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevmem.c<br>
-base/gdevp14.c<br>
-base/gdevprn.c<br>
-base/gsptype1.c<br>
-base/gstrans.c<br>
-base/gxclthrd.c<br>
-base/gxdevcli.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-23 15:06: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=0ac36b1eb87a919d3df19b7fb555d277d959396b">0ac36b1eb87a919d3df19b7fb555d277d959396b</a>
-<blockquote>
-<p>
- Fix deep color transparency issue.<br>
-<br>
- Fix overflow in art_pdf_composite_knockout_16, seen in:<br>
-<br>
- tests_private/comparefiles/Bug690546.pdf.psdcmyk16.72.0<br>
-<br>
-base/gdevp14.c<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-22 18:24:49 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cda2b1e057951dc4687c4d2ad489100d1ea6ea4b">cda2b1e057951dc4687c4d2ad489100d1ea6ea4b</a>
-<blockquote>
-<p>
- Fix deep color transparent pattern problems.<br>
-<br>
- Transparency buffers are held as native endian. Pattern cache<br>
- tiles are held as big endian. When we make pattern cache tiles<br>
- from transparency buffers we therefore need a conversion.<br>
-<br>
-base/gdevp14.c<br>
-base/gxblend.c<br>
-base/gxp1fill.c<br>
-base/gxpcolor.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-25 19:35:14 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e220de447dc5cc79a00e8bb57b69c6ea242fe75">4e220de447dc5cc79a00e8bb57b69c6ea242fe75</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Do not output LUTs with CUPS_DEBUG set<br>
-<br>
- This change lets complete LUTs in the debug output only be listed when<br>
- CUPS_DEBUG2 is set and not already with CUPS_DEBUG.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-25 19:08:52 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=30575d50af5f8dd17ef20ccbbf2b2d8afae51589">30575d50af5f8dd17ef20ccbbf2b2d8afae51589</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Prefer the page size requested by user<br>
-<br>
- Without special scaling/cropping options (&quot;fit-to-page&quot;, &quot;fill&quot;,<br>
- &quot;crop-to-fit΅, ...) PDF and PostScript files printed with CUPS will be<br>
- printed with the page sizes of the document's pages and not the size<br>
- requested by the user via the &quot;PageSize&quot; or &quot;media&quot; option. This<br>
- allows correct printing of jobs with differently sized pages on<br>
- printers which have the appropriate sizes loaded without need of<br>
- manual intervention. Therefore the CUPS output device is matching each<br>
- input page against the sizes listed in the PPD to generate a correct<br>
- page geometry for the printer for each page.<br>
-<br>
- Problem is if there are several equally-sized page size entries in the<br>
- PPD. Without further guiding always the first match is used, making<br>
- access to special functions provided by the others (like<br>
- full-bleed/borderless printing) inaccessible.<br>
-<br>
- This commit adds the functionality of the user-requested page size<br>
- (via &quot;PageSize&quot; or &quot;media&quot; option) being preferred under the matching<br>
- page sizes, so that if for example a user selects a full-bleed version<br>
- of the desired page size and sends a photo, the photo gets rendered<br>
- and printed with the page geometry which the PPD reports for the<br>
- full-bleed version.<br>
-<br>
- Nothing changes if the size of the user-requested page size does not<br>
- match the size of the input page at all.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-25 12:45:27 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3283e6d5ce389f5b6d5ebf4adb309b1259a5fe1d">3283e6d5ce389f5b6d5ebf4adb309b1259a5fe1d</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Small fix on size matching improvements<br>
-<br>
- This is a fix for one little oversight on the changes to support matching<br>
- the input page size against the imageable areas of the PPD's page sizes.<br>
-<br>
- This completes the fix of bug 701438.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-24 23:11:10 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3e09cede82a3b8c5c7a6e30a5934336f20dfa1f8">3e09cede82a3b8c5c7a6e30a5934336f20dfa1f8</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Improved page size matching with PPD<br>
-<br>
- Applied the following improvements for finding the correct page size<br>
- of the PPD file for the input page:<br>
-<br>
- - Do not try to match by page size name, the input files do not<br>
- contain page size names.<br>
-<br>
- - Do not only match the input page size against the actual media sizes<br>
- reported by the PPD but also to the imageable areas. Media size match<br>
- is preferred but if there is no media size match, we accept also<br>
- a match of the imageable area. In case of a match of the imageable<br>
- area we position the input page in the imageable area of the output<br>
- page.<br>
-<br>
- - More debug output.<br>
-<br>
- - In case of a custom page size (no match with PPD sizes) the page<br>
- size name in the CUPS Raster output is a correct &quot;Custom.XXXxYYY&quot;<br>
- and not the default page size name.<br>
-<br>
- This should fix bug #701438.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-23 18:09:32 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2d6bb6e69feb0a75be98d03f550258d4b7540aef">2d6bb6e69feb0a75be98d03f550258d4b7540aef</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Reduced page size comparison tolerances<br>
-<br>
- Before each page gets rendered its size is compared to the page sizes<br>
- of the PPD file to select the actual page size for the output. Reduced<br>
- the tolerances from 7% for the long edge and 5% for the short edge to<br>
- 1%, as before easily wrong sizes got picked (See also bug 701438).<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-23 10:11: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=5ab40cc018d8ac76758cebc7b4962e9b19fffc86">5ab40cc018d8ac76758cebc7b4962e9b19fffc86</a>
-<blockquote>
-<p>
- Windows Installer: cope with COMPILE_INITS=0<br>
-<br>
- We default to COMPILE_INITS=1, and that was the only case that the installer<br>
- handled - i.e. building the installer with COMPILE_INITS=0 would install an<br>
- executable that wouldn't work without extra action (-I.. or similar).<br>
-<br>
- This changes the installer compiler invocation, and the installer creation<br>
- so it behaves as it does now with COMPILE_INITS=1, but with COMPILE_INITS=0 the<br>
- installer will write the path to Resource/Init into the GS_LIB registry<br>
- key.<br>
-<br>
-psi/nsisinst.nsi<br>
-psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-22 23:30:34 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=863d77f731c6144dcf139e06e64a857754d8327f">863d77f731c6144dcf139e06e64a857754d8327f</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Produce more debug output<br>
-<br>
- When building with CUPS_DEBUG now debug output for the process of<br>
- matching the page geometry with the PPD file's page sizes is<br>
- produced.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-22 08:58:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=24478335925f891673160893513fac43b0334c48">24478335925f891673160893513fac43b0334c48</a>
-<blockquote>
-<p>
- Handle explicit '\' escaping in path matching<br>
-<br>
- As well as having to cope with both '/' and '\' as directory separators on<br>
- Windows, it turns out we also need to cope with the backslash separator being<br>
- explicitly escaped (&quot;\\&quot;) - the explicit is added by the Postcript path<br>
- templating code in gs_init.ps.<br>
-<br>
- I don't want to change templating code because that would likely have<br>
- implications in a lot of other places.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-22 10:51: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=7c9794ee644a904527006922e4fc387ad33be2a4">7c9794ee644a904527006922e4fc387ad33be2a4</a>
-<blockquote>
-<p>
- Better CMYK conversion for bmpcmp<br>
-<br>
-toolbin/bmpcmp.c<br>
-toolbin/bmpcmptab.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-21 17:49:32 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=079ea7d9e0c713a7834fc8f08d52ce42e6a03666">079ea7d9e0c713a7834fc8f08d52ce42e6a03666</a>
-<blockquote>
-<p>
- Update bmpcmp.c to read psdrgb rather than psdbgr.<br>
-<br>
-toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-21 15:33: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=935408d6205742e40471b18d7f0f1fe4febc437c">935408d6205742e40471b18d7f0f1fe4febc437c</a>
-<blockquote>
-<p>
- Fix commit ec0b35fed3de: &quot;Handle directory separators...&quot;<br>
-<br>
- The logic in the above fix was wrong.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-21 14:28:20 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4041906852365a602c2f9e011703e4174bdc8040">4041906852365a602c2f9e011703e4174bdc8040</a>
-<blockquote>
-<p>
- Bug 701451: Fix clist color_usage calculations for shadings.<br>
-<br>
- Or rather, don't attempt to calculate them badly, and just<br>
- use the safe &quot;all colors&quot; value.<br>
-<br>
-base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-21 10:10:51 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd1b1cacadac2479e291efe611979bdc1b3bdb19">cd1b1cacadac2479e291efe611979bdc1b3bdb19</a>
-<blockquote>
-<p>
- PDF interpreter - review .forceput security<br>
-<br>
- Bug #701450 &quot;Safer Mode Bypass by .forceput Exposure in .pdfexectoken&quot;<br>
-<br>
- By abusing the error handler it was possible to get the PDFDEBUG portion<br>
- of .pdfexectoken, which uses .forceput left readable.<br>
-<br>
- Add an executeonly appropriately to make sure that clause isn't readable<br>
- no mstter what.<br>
-<br>
- Review all the uses of .forceput searching for similar cases, add<br>
- executeonly as required to secure those. All cases in the PostScript<br>
- support files seem to be covered already.<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>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-21 10:56: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=ec0b35fed3de9f313c7c992844daac5f3f28618d">ec0b35fed3de9f313c7c992844daac5f3f28618d</a>
-<blockquote>
-<p>
- Handle directory separators in access control matching<br>
-<br>
- On Windows, we end up dealing with a mishmash of &quot;/&quot; and &quot;\&quot; as directory<br>
- separators, so a simple equality check isn't sufficient.<br>
-<br>
- Since there is already (platform specific) function for checking whether a<br>
- string (or part thereof) is a directory separation, use it.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 21:50:18 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=453ef45209143ecf3c3e25dafd9fbe6698e2c5a1">453ef45209143ecf3c3e25dafd9fbe6698e2c5a1</a>
-<blockquote>
-<p>
- Disable use of alternate tint transform ICC profile<br>
-<br>
- A prior commit introduced the use of color management<br>
- if the DeviceN or Separation device had an ICC profile<br>
- associated with the colorants. While there is an argument<br>
- for doing this, it is not the standard behavior seen in<br>
- AR. Disabling for now and will likely turn this into a<br>
- command line option.<br>
-<br>
-base/gxcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 18:48:49 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc656558a289fa28dbb491d70478fd18973b287a">cc656558a289fa28dbb491d70478fd18973b287a</a>
-<blockquote>
-<p>
- Fix crashes in RAW_DUMP debug code.<br>
-<br>
- Dump the buffer before freeing the device, or the pointer will no<br>
- longer be valid.<br>
-<br>
- Also, don't access through ppatdev14 when we know it's NULL.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 18:47:09 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=633c454261c95e3d1771ad93b7bd6c481119c0d0">633c454261c95e3d1771ad93b7bd6c481119c0d0</a>
-<blockquote>
-<p>
- Fix deep color transparency pattern copying problem.<br>
-<br>
- The following test:<br>
-<br>
- tests/pdf/pattrans_solid_nonrect.pdf.psdcmyk16.300.1..gs<br>
-<br>
- among others, was showing problems, due to us treating the offset<br>
- as bytes rather than shorts.<br>
-<br>
-base/gxp1fill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 14:29:33 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=69b066540069330a8a046039b93e1dcadecfa153">69b066540069330a8a046039b93e1dcadecfa153</a>
-<blockquote>
-<p>
- Avoid signed overflow in deep transparency calculations.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 12:24: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=825f77eabdbfaa9d566d38c4b2be918143cd5778">825f77eabdbfaa9d566d38c4b2be918143cd5778</a>
-<blockquote>
-<p>
- Fix overflow in deep color blending.<br>
-<br>
- Multiplying a 16bit unsigned value with a 16 bit signed value<br>
- in a 32bit int means we lose the sign bit. Sacrifice a bit of<br>
- accuracy to avoid that.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 10:10: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=885444fcbe10dc42787ecb76686c8ee4dd33bf33">885444fcbe10dc42787ecb76686c8ee4dd33bf33</a>
-<blockquote>
-<p>
- make .forceput inaccessible<br>
-<br>
- Bug #701343, #701344, #701345<br>
-<br>
- More defensive programming. We don't want people to access .forecput<br>
- even though it is no longer sufficient to bypass SAFER. The exploit<br>
- in #701343 didn't work anyway because of earlier work to stop the error<br>
- handler being used, but nevertheless, prevent access to .forceput from<br>
- .setuserparams2.<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_pdfwr.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-19 10:03:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9dae3b271e781c076e49d94dc8590ed95e3f38c9">9dae3b271e781c076e49d94dc8590ed95e3f38c9</a>
-<blockquote>
-<p>
- Handle drag'n'drop file name/paths<br>
-<br>
- Because we now run by default with the file access permission active,<br>
- we need to do additional work for Windows drag and drop files, so they don't<br>
- throw an invalidaccess error (since we implement drag and drop by sending<br>
- characters to the gs console to do '(file) run').<br>
-<br>
- The problem is, we cannot add the file to read list, send the characters to the<br>
- console, and remove the file from the read list because, although SendMessage()<br>
- blocks until the message is handles, WriteConsoleInput() does not block until<br>
- the console buffers are consumed (i.e. it is asynchronous). So, there is no<br>
- certainty when the final SendMessage() in WM_DROPFILES case is finished that<br>
- Ghostcript will actually have run the file.<br>
-<br>
- So, we create a list of dropped file names, add them to the permit read list,<br>
- when the next WM_DROPFILES event happens, or a WM_DESTROY event, we drop<br>
- file names from the permit read list before, if necessary, adding the current<br>
- ones.<br>
-<br>
-psi/dwimg.c<br>
-psi/dwmain.c<br>
-psi/dwmainc.c<br>
-psi/dwtext.c<br>
-psi/dwtext.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-16 15:43:32 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c18c7092e8945dcd932226bfea790c842ae21a0">6c18c7092e8945dcd932226bfea790c842ae21a0</a>
-<blockquote>
-<p>
- Squash warnings in claptrap.<br>
-<br>
- Thanks to William Bader for highlighting these.<br>
-<br>
-base/claptrap-planar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-16 15:28:49 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=89f63112bd8ef15ba7df1fca5b962561c1f756c8">89f63112bd8ef15ba7df1fca5b962561c1f756c8</a>
-<blockquote>
-<p>
- Squash warning in gdevpsd.c<br>
-<br>
- Thanks to William Bader for spotting this.<br>
-<br>
-devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-16 13:08:14 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f74553992b28ca536d62aa93cf9208bb7aa670b3">f74553992b28ca536d62aa93cf9208bb7aa670b3</a>
-<blockquote>
-<p>
- Squash some compiler warnings.<br>
-<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-devices/gdevpdfimg.c<br>
-devices/vector/gdevpdfu.c<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-16 11:45:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=924f701fdc990ac981fb08c4f6c21c668b8b74ef">924f701fdc990ac981fb08c4f6c21c668b8b74ef</a>
-<blockquote>
-<p>
- Fix X11 device ICC profile memory leaks<br>
-<br>
- When the x11 devices are running in &quot;buffered mode&quot; (i.e. we render to a<br>
- pixmap, then blit the pixmap to the X11 Window), we create a memory device<br>
- which actually does the rendering.<br>
-<br>
- The memory device takes a reference to the ICC profiles from the x11 device<br>
- and it is reference counted.<br>
-<br>
- Firstly, we always incremented the reference count, ignoring the posibility<br>
- that we were resizing an existing memory device rather than creating a new one.<br>
-<br>
- Secondly, when shutting down the x11 device, we ignored posibility that<br>
- buffering was in force, and failed to free the memory device - most of the<br>
- memory was hoovered up by the garbager, but the ICC profile data isn't in<br>
- gc memory, hence showing a leak.<br>
-<br>
- So, fix the memory device ICC reference counting, and reconfigure the device<br>
- as non-buffering before we shut it down.<br>
-<br>
-devices/gdevxini.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-15 17:06: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=79350a5f0fc9514746f34ff0820f0b6a89f67117">79350a5f0fc9514746f34ff0820f0b6a89f67117</a>
-<blockquote>
-<p>
- Add -dNOSAFER for Windows installer cidfmap creation<br>
-<br>
-psi/nsisinst.nsi<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-15 11:35: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=443e60cd379c3a8b5fca89b59280573b2c651e33">443e60cd379c3a8b5fca89b59280573b2c651e33</a>
-<blockquote>
-<p>
- Bump the version number for release.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-15 14:36: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=f1ae75eb9d43d9773915ab66b0c97086d0252257">f1ae75eb9d43d9773915ab66b0c97086d0252257</a>
-<blockquote>
-<p>
- ps2write - don't password encrypt PostScript output!<br>
-<br>
- Noticed while testing the args commit; if we set -sOwnerPassword (to<br>
- create a password-protected PDF file), but select (e)ps2write as the<br>
- device, then the resulting PostScript file would have all the streams<br>
- (in a PDF sense) encrypted with PDF password encryption.<br>
-<br>
- Unsurprisingly, this result in a completely unusable PostScript file.<br>
- Lets not permit that....<br>
-<br>
-devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-15 10:03: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=d2897b976cf065874516f9f8e2a040965b2a384b">d2897b976cf065874516f9f8e2a040965b2a384b</a>
-<blockquote>
-<p>
- Remove RC string for real release<br>
-<br>
-base/gscdefs.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-15 08:54:21 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=18eedc30986ed2dfaf2357c0b0ca962532ace896">18eedc30986ed2dfaf2357c0b0ca962532ace896</a>
-<blockquote>
-<p>
- Dates etc for 9.50 release<br>
-<br>
- Plus a comment on going to 9.50, rather than 9.28.<br>
-<br>
-base/version.mak<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/Internal.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>2019-10-15 08:48: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=80f8dff6c57620dd5acae9ebc5b9ab64674b88f0">80f8dff6c57620dd5acae9ebc5b9ab64674b88f0</a>
-<blockquote>
-<p>
- Fix a mistake in the news section<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-14 18:29: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=24a66f42d67d83714ad971347488c0246e3e8f7c">24a66f42d67d83714ad971347488c0246e3e8f7c</a>
-<blockquote>
-<p>
- Have warning honor -dQUIET<br>
-<br>
- Have the warning about calling .lockfileaccess or .setsafe when the controls are<br>
- already in place honor the -dQUIET/-q command line params.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-14 18:10: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=dad10464de52d344287843ca872b56c8e7f33ccb">dad10464de52d344287843ca872b56c8e7f33ccb</a>
-<blockquote>
-<p>
- Update changelog<br>
-<br>
-doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-14 18:07: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=f2e2a3fe85d64cabde82d0f6eb982643bc6e8427">f2e2a3fe85d64cabde82d0f6eb982643bc6e8427</a>
-<blockquote>
-<p>
- Add words about .currentpathcontrolstate operator<br>
-<br>
-doc/Language.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-14 10:28: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=ad5b08d8be2e7a91599d3bbbc6aa841144662239">ad5b08d8be2e7a91599d3bbbc6aa841144662239</a>
-<blockquote>
-<p>
- Change version to 9.50<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/version.mak<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/Internal.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>2019-10-14 10:20:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1937e14f17e5de54b57d0e911e828639d197a08c">1937e14f17e5de54b57d0e911e828639d197a08c</a>
-<blockquote>
-<p>
- Update docs on SAFER<br>
-<br>
- to reflect that SAFER is now the default, and remove the comments about making<br>
- SAFER the default &quot;in the future&quot;.<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-10 09:29: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=9c63f39ead4aab30addf213f0ab6843ac87b56cf">9c63f39ead4aab30addf213f0ab6843ac87b56cf</a>
-<blockquote>
-<p>
- ps2write - restore missing %%PageTrailer comment<br>
-<br>
- Bug #701659 &quot;Missing %%PageTrailer commen&quot;<br>
-<br>
- An oversight in commit 96c381cce28c27eac182549441a6c5025b0dcdd6<br>
- caused the comment to be omitted.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-07 18:41: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=1d89e1aa9cf65e5345a1f009b6d317db024719fe">1d89e1aa9cf65e5345a1f009b6d317db024719fe</a>
-<blockquote>
-<p>
- Bug 701657: Allocate &quot;memory&quot; device in immovable gc memory<br>
-<br>
- Devices are supposed to be allocated in memory that cannot relocate (i.e.<br>
- non-gc memory or an immovable allocation). The memory device accessible from<br>
- Postscript (makeimagedevice/makewordimagedevice) was being created in regular,<br>
- relocatable gc memory.<br>
-<br>
- This caused an invalid memory access when cleaning up subclassed devices, as the<br>
- one device in the chain may have moved. So switch to using an immovable<br>
- allocation.<br>
-<br>
-base/gsdevmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-02 00:01:17 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=458f715b0d59278f0788e0c89ee5eb04d48871ef">458f715b0d59278f0788e0c89ee5eb04d48871ef</a>
-<blockquote>
-<p>
- Update jbig2dec stuff for 0.17 release.<br>
-<br>
-jbig2dec/CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-01 10:35: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=f8ba9e017cdfab836f62853629d75f484127342e">f8ba9e017cdfab836f62853629d75f484127342e</a>
-<blockquote>
-<p>
- Fix memory corruption setting a halftone<br>
-<br>
- When setting a new halftone in the graphics state, we try to re-use the data<br>
- from the existing device halftone.<br>
-<br>
- The problem is that the device halftone can have higher component indices than<br>
- there are components in the new halftone we are creating. In this case, we can<br>
- end up writing off the end of the components array for the new halftone<br>
- structure.<br>
-<br>
- Simply check that the new halftone has enough components before doing the<br>
- duplication.<br>
-<br>
-base/gsht.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-30 13:40: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=1681c7ebb5a338002d5f7dd8da9bffda675f0656">1681c7ebb5a338002d5f7dd8da9bffda675f0656</a>
-<blockquote>
-<p>
- pdfwrite - don't honour /Producer key in DOCINFO pdfmark<br>
-<br>
- Bug #701639 &quot;pdfwrite should not honour the /Producer key in DOCINFO pdfmark&quot;<br>
-<br>
- The Producer in the document information dictionary (and XML Metadata)<br>
- is defined quite clearly as the application which produced the PDF file<br>
- from its native format.<br>
-<br>
- Ghostscript uses the Producer key (if present in the pdfmark) to set<br>
- the Producer, but it should not do so. Adobe Acrobat Distiller (at<br>
- least the end user version) does not permit this value to be altered.<br>
-<br>
- On reflection we can see why; in the case of a problem with a PDF file<br>
- its important to know which application created it, and we should not<br>
- let PostScript obscure that (we already do not pass the Producer<br>
- information on when the input is PDF).<br>
-<br>
- The code did already attempt to overwrite any Producer string which<br>
- contained 'Distiller' (I have no idea why) and that code contained an<br>
- error which could lead to an invalid Document Information dictionary<br>
- being created.<br>
-<br>
- This commit removes the ability for DOCINFO pdfmarks to alter the<br>
- Producer, which obviously fixes the bug.<br>
-<br>
- However..... it is actually important for our commercial customers to<br>
- be able to set this value. A problem with a PDF file created by one of<br>
- our customer's products should be reported to that customer, not us, as<br>
- we will not be able to investigate the problem while our customer<br>
- should be able to. At the very least our customer will know how to<br>
- retrieve the configuration of Ghostscript being used.<br>
-<br>
- So permit the commercial version of Ghostscript to set the /Producer<br>
- from a pdfmark.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-30 09:16: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=a27af00c8727ec4eaf0f4730963b8a81aab8590d">a27af00c8727ec4eaf0f4730963b8a81aab8590d</a>
-<blockquote>
-<p>
- Small changelog tweak<br>
-<br>
-doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-30 08:33:08 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=84864d86363a3e5b53f4b75fae7c850c2c22e5ee">84864d86363a3e5b53f4b75fae7c850c2c22e5ee</a>
-<blockquote>
-<p>
- Dates and docs for 9.28 rc4<br>
-<br>
-base/gscdefs.h<br>
-base/version.mak<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/Internal.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>2019-09-27 13:26:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=55fef678a69b921b548d5e1ffb93d9162fedfdc3">55fef678a69b921b548d5e1ffb93d9162fedfdc3</a>
-<blockquote>
-<p>
- Bug 701634: Correctly handle file name of &quot;\0&quot;<br>
-<br>
- Attempting to open a file with a filename string starting with a NULL<br>
- character should be treated the same as if the string was zero length.<br>
-<br>
- Not doing so created a broken file object leading to several operations<br>
- resulting in a segfault.<br>
-<br>
- Also, add cleanup in the event of such an error, freeing memory allocated in<br>
- preparing the gs stream object.<br>
-<br>
-base/sfxcommon.c<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-26 10:47:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=51e6a6103f9fa51e14c737e134bcef8a3daf7ef8">51e6a6103f9fa51e14c737e134bcef8a3daf7ef8</a>
-<blockquote>
-<p>
- Revised comment for 8992f00edfd1c39154c013489de2a01d2e9a92ee<br>
-<br>
- Make it clearer why the revised behaviour is required.<br>
-<br>
-base/gstiffio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-26 09:34: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=833fc0371d2ca44ca603b2fd1a42fa1ef820f7eb">833fc0371d2ca44ca603b2fd1a42fa1ef820f7eb</a>
-<blockquote>
-<p>
- Bug 701313: Disable libtiff callbacks when libtiff is shared<br>
-<br>
- It seems that libtiff uses global variables to store the error/warning callbacks<br>
- so if two callers in the exe are using the libtiff shared lib, very bad things<br>
- happen (usually a segfault).<br>
-<br>
- So, if that's how we're linked, set the callbacks to NULL.<br>
-<br>
-base/gstiffio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-24 15:48: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=cfd109650c2328300b21f7e5853c0e4bec669876">cfd109650c2328300b21f7e5853c0e4bec669876</a>
-<blockquote>
-<p>
- Cope with .setsafe(global) being called when already 'SAFER'<br>
-<br>
- As we default to SAFER file controls now, we want to cope with .setsafe and<br>
- .setsafeglobal being called either when already SAFER, or called multiple times.<br>
-<br>
- This means adding a .currentpathcontrolstate operator so we don't try to<br>
- influence the path control lists after control is activated.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-24 09:18: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=45013b96f1e7ef06c64028122ec8870f3a71335d">45013b96f1e7ef06c64028122ec8870f3a71335d</a>
-<blockquote>
-<p>
- tiffsep(1): Cope with .tiff ending as well as .tif<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 20:04:49 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6aea104cc48170a4064a12e89c72a898c6bd5967">6aea104cc48170a4064a12e89c72a898c6bd5967</a>
-<blockquote>
-<p>
- Recast validate to use gs_file_name_check_separator.<br>
-<br>
- Avoid using gp_file_name_directory_separator, as windows can<br>
- have 2 different directory separators.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 18:05:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f1a661c69f78ea42828f94fe829163d20bcf7706">f1a661c69f78ea42828f94fe829163d20bcf7706</a>
-<blockquote>
-<p>
- Remove spurious call to gp_validate_path_len()...<br>
-<br>
- ...in gx_device_open_output_file()<br>
-<br>
- There is no need to validate the path in gx_device_open_output_file() as it will<br>
- be done at a lower level (gp_fopen) for paths that require it (we only validate<br>
- *after* the Postscript style %device% paths have been expanded into 'real'<br>
- paths).<br>
-<br>
- This also interacts badly with the revised handling of formatted string<br>
- file names, hence remove it.<br>
-<br>
-base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 17:56: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=eed7d85ac16ae516e1c4e51bcdea3924a973da5e">eed7d85ac16ae516e1c4e51bcdea3924a973da5e</a>
-<blockquote>
-<p>
- Fix tiffsep(1) interaction with file permissions lists<br>
-<br>
- The previous solution didn't quite work, when using formatted strings for<br>
- output file names (i.e. output-%d.tif).<br>
-<br>
- This adds a dedicated gs_remove_outputfile_control_path() to mirror<br>
- gs_add_outputfile_control_path() and uses those for the dynamic adding and<br>
- removing of separation output file names.<br>
-<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 17:11:47 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=76ca3dd29559dd72da3f154e2ba18f86cd46fff6">76ca3dd29559dd72da3f154e2ba18f86cd46fff6</a>
-<blockquote>
-<p>
- Update path validation to accept multiple *'s as special case.<br>
-<br>
- Previously we interpretted multiple *'s as meaning the same as<br>
- single *'s. Now we use them to mean &quot;just those chars that<br>
- might be created by the use of a %...{d,x,u,i,o,X} format<br>
- specifier&quot;.<br>
-<br>
-base/gpmisc.c<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 16:41:09 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dfc93423545c8a9a927b1f240ba4bdc22b39f0b6">dfc93423545c8a9a927b1f240ba4bdc22b39f0b6</a>
-<blockquote>
-<p>
- Improve OutputFile handling of %d etc.<br>
-<br>
- Only accept %d (and friends) (as opposed to anything starting with %).<br>
- Only accept legal combinations of flags/widths/precision etc.<br>
- Generate a more conservative wildcard.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-20 12:38:02 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd3db03d3e04c9146b596280d6da76cec23f60a6">cd3db03d3e04c9146b596280d6da76cec23f60a6</a>
-<blockquote>
-<p>
- Slight improvement to &quot;permit-file-***&quot; parameter documentation.<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-20 11:17:53 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4baa696cc3498ae834052440f9f9d9fc0b8ad122">4baa696cc3498ae834052440f9f9d9fc0b8ad122</a>
-<blockquote>
-<p>
- Fix tiffsep and tiffsep1 with new file access control and SAFER mode<br>
-<br>
- The tiffsep and tiffsep1 synthesize output file names with the outputfile<br>
- and the separation color name, but the 'open' of these filenames would<br>
- fail since they were not included on the permit_file_writing list.<br>
- Add the full filename before opening, and remove the names after closing.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-20 11:53:10 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=41d79063acee7244f5990d2a8e19c567e24051af">41d79063acee7244f5990d2a8e19c567e24051af</a>
-<blockquote>
-<p>
- Squash stupid const warning.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-20 19:42: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=b58f45daa9007f482a49132cbfaa47c8b86ce7d5">b58f45daa9007f482a49132cbfaa47c8b86ce7d5</a>
-<blockquote>
-<p>
- Squash some &quot;const&quot; warnings.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-20 17:49:57 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e7039d7a83a7e35b8b41d59d7fb9a8b4fda7fb0">0e7039d7a83a7e35b8b41d59d7fb9a8b4fda7fb0</a>
-<blockquote>
-<p>
- Fix &quot;permit-file-xxxx&quot; handling.<br>
-<br>
- Ray spotted that gs_add_explicit_control_path was adding 17<br>
- to arg before using it. 17 happens to be the right amount<br>
- to add for &quot;--permit-file-read=&quot;, but the wrong amount for<br>
- write/control/all.<br>
-<br>
- Update the code to call it with the correct arg pointer<br>
- to start with.<br>
-<br>
- Also, update a couple of routines to cope with being called<br>
- with NULL strings.<br>
-<br>
- Also use enum values in switch rather than 0, 1, 2.<br>
-<br>
-base/gslibctx.c<br>
-pcl/pl/plmain.c<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-19 11:02: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=18316aba11fafc57ee77dbd7774b2c88b964a9d9">18316aba11fafc57ee77dbd7774b2c88b964a9d9</a>
-<blockquote>
-<p>
- Make missing jbig2 decoder fatal error.<br>
-<br>
- If we have neither Luratech nor jbig2dec, have configure fail, unless<br>
- explicitly run with --without-jbig2dec<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-18 09:24: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=569a551f2a57f6e6c1e692f6b834c765dcbe7cfa">569a551f2a57f6e6c1e692f6b834c765dcbe7cfa</a>
-<blockquote>
-<p>
- Dates, docs, etc for 9.28 rc3<br>
-<br>
-base/gscdefs.h<br>
-base/version.mak<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/Internal.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>2019-09-17 11:42: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=2ff44c7c8a09dd1c6b7cd750323ee4087b5cebc5">2ff44c7c8a09dd1c6b7cd750323ee4087b5cebc5</a>
-<blockquote>
-<p>
- Fix file permissions interaction with '@' command line<br>
-<br>
- If an options file (prefixed '@' on the command line) followed something that<br>
- required initialising the Postscript interpreter (such as a '-c' option),<br>
- opening the file would potentially fail because file permissions had been<br>
- activated by the interpreter.<br>
-<br>
- Add and remove the file from the permit reading list before attempting to open<br>
- it.<br>
-<br>
-base/gsargs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-12 14:23: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=3695b7f576c607bd3627e6e28dc982fdf68b1b32">3695b7f576c607bd3627e6e28dc982fdf68b1b32</a>
-<blockquote>
-<p>
- If set, add PCLFONTSOURCE value to permit_file_reading list<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-11 13:07: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=4196e26a9cf3c8afd6c069a789ac649019ae096a">4196e26a9cf3c8afd6c069a789ac649019ae096a</a>
-<blockquote>
-<p>
- Bug 701561: 'reduce' paths before adding to permit lists<br>
-<br>
- Before attempting to open files, we pre-process the requested file name to<br>
- remove surplus/unnecessary elements: i.e. './././file' would be reduced to just<br>
- './file', or '../dir/../dir/../dir/file' would be reduced to '../dir/file'.<br>
-<br>
- The 'reduced' path is what we try to open, hence it is also what we check<br>
- against the file permissions list before we allow files to be accessed.<br>
-<br>
- That being so, we should also 'reduce' paths as we add them to the permissions<br>
- lists - thus the permissions list creation and checking are consistent.<br>
-<br>
-base/gslibctx.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-11 14:10:27 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3d55799ea64088e08fc2783012957035c77a66ca">3d55799ea64088e08fc2783012957035c77a66ca</a>
-<blockquote>
-<p>
- Fix Bug 696333. Allow large bitmaps in clist when writing tile cache.<br>
-<br>
- When writing bits to update the tile cache, we don't need to restrict to<br>
- a single command buffer as with the copy_mono and copy_color commands.<br>
-<br>
- Progressions on:<br>
- tests_private/comparefiles/Bug694385.pdf.psdcmyk.300.1..gs<br>
- tests_private/pdf/sumatra/2028_-_invisible_patterns.pdf.psdcmyk.300.1..gs<br>
- tests_private/ps/ps3cet/09-47B.PS.pdf.pkmraw.300.0..gs_pdf<br>
- tests_private/ps/ps3fts/176-01.ps.psdcmyk.300.1..gs<br>
-<br>
-base/gxclbits.c<br>
-base/gxcldev.h<br>
-base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-12 10:37:42 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1613502f83ddba352cc8e98e7dd3182c9d7732bc">1613502f83ddba352cc8e98e7dd3182c9d7732bc</a>
-<blockquote>
-<p>
- Fix SEGV with flp device and PCL with clist mode and large BandHeight.<br>
-<br>
- If the 'clist_init' fails initially (with rangecheck) due to the buffer<br>
- space too small for the BandHeight specified, we loop in the caller after<br>
- increasing the buffer size, but clist_init left &quot;is_open&quot; false when failing.<br>
- Add save_is_open in gdev_prn_setup_as_command_list so that we can restore it<br>
- if the clist_init eventually suceeds.<br>
-<br>
- The SEGV was with image_data because re-opening the flp device reset the<br>
- &quot;obsolete&quot; procs to the default, so flp_image_data was replaced by the<br>
- gx_default_image_data, but no begin_image had been performed (flp_begin_image<br>
- skipped this since we were not yet at the FirstPage).<br>
-<br>
-base/gdevprn.c<br>
-base/gxclist.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-16 18:53:49 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f2d03f59e04a053c14285d8dbdd869bf9a4435e7">f2d03f59e04a053c14285d8dbdd869bf9a4435e7</a>
-<blockquote>
-<p>
- Update jbig2dec stuff for 0.17 release.<br>
-<br>
-jbig2dec/CHANGES<br>
-jbig2dec/jbig2.h<br>
-jbig2dec/jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-16 18:48:36 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8da8fbaeb6074161bc3a9b22e89265f5942db0d9">8da8fbaeb6074161bc3a9b22e89265f5942db0d9</a>
-<blockquote>
-<p>
- jbig2dec: Use the same contact information everywhere.<br>
-<br>
-jbig2dec/README<br>
-jbig2dec/configure.ac.in<br>
-jbig2dec/jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-16 16:12:32 +0100
-</strong>
-<br>Paul Vojta &lt;vojta@math.berkely.edu&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c6e19334062d12189612b84f53fe393a7808f74">6c6e19334062d12189612b84f53fe393a7808f74</a>
-<blockquote>
-<p>
- Documentation - fix some typos<br>
-<br>
- Bug #701589 &quot;Minor documentation problems in 9.28-rc2&quot;<br>
-<br>
- Thanks to Paul Vojta for pointing these out. Unfortunately we cannot use the<br>
- supplied patch, as it includes alterations to History9.htm, which is auto-<br>
- generated from the commit logs. The remaining changes are applied here.<br>
-<br>
-doc/Language.htm<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-11 12:18: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=90bdf83d696562e4136b8f565cac06cc32b161ae">90bdf83d696562e4136b8f565cac06cc32b161ae</a>
-<blockquote>
-<p>
- Bug 701563: pdfwrite annotation pdfmark /Border key<br>
-<br>
- Despite the spec saying the values for the /Border key are in user space<br>
- coordinates, Distiller appears to pass the values through to the output PDF<br>
- untouched (no rescaling - unlike the values for /Rect, also in user space,<br>
- according to the spec, which it does scale/translate). Ghostscript/pdfwrite<br>
- did scale the /Border values.<br>
-<br>
- This just changes pdfwrite to write the values out unchanged.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-16 09:56: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=a9e997cb97a274bebfc028e8831a43d6f66be0f9">a9e997cb97a274bebfc028e8831a43d6f66be0f9</a>
-<blockquote>
-<p>
- Documentation - add a note about SAFER for PDF/X ICC profiles<br>
-<br>
- Bug #701553 &quot;Examples of PDF/X and PDF/A conversion should be updated for Ghostscript 9.28&quot;<br>
-<br>
- ICC profiles required for PDF/X and PDF/A output need to be readable<br>
- in order to work when -dSAFER is true (the new default). This wasn't<br>
- clear from the documentation, so add a note about it.<br>
-<br>
- As noted in the bug report, it is possible to embed the profile in the<br>
- PostScript code, but as Chris says this is probably beyond reasonable<br>
- expectations of the average user; they simply won't change the example<br>
- and will then complain that it isn't correct. Users capable of making<br>
- this work almost certainly have enough knowledge to realise they can<br>
- do this instead of making the profile readable.<br>
-<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-12 19:41:47 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cea41505580dfe55234bd4972fbb09af5e2e6bb8">cea41505580dfe55234bd4972fbb09af5e2e6bb8</a>
-<blockquote>
-<p>
- Fix various printer devices to properly call spec ops.<br>
-<br>
- Various printer devices (psd, psdcmykog, tiffsep, tiffscaled)<br>
- were passing the spec ops on to gx_default_dev_spec_op rather<br>
- than gdev_prn_dev_spec_op.<br>
-<br>
- The most obvious implication of this was that we'd sometimes<br>
- get a warning about printer devices having a private spec op.<br>
-<br>
-devices/gdevcmykog.c<br>
-devices/gdevpsd.c<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-12 17:09:50 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=89f3d6001728678755aca8c5a02e57bba72a0813">89f3d6001728678755aca8c5a02e57bba72a0813</a>
-<blockquote>
-<p>
- Bug 701568 followup: Fix RLE compressor.<br>
-<br>
- The previous fix to the RLE compressor reveals an additional<br>
- existing issue to do with us not checking whether we have<br>
- space in the buffer to write the EOD byte.<br>
-<br>
- Fixed here.<br>
-<br>
-base/srle.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-12 09:35: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=f394c0722d3415ba03f57dc32dcd8484d3173b62">f394c0722d3415ba03f57dc32dcd8484d3173b62</a>
-<blockquote>
-<p>
- Bug 701568: Fix gdevpx.c RLE stream handling.<br>
-<br>
- The current code in pclxl_write_image_data_RLE passes<br>
- lines of data to the RLE compression routine. It tells<br>
- each invocation of that routine that this is the &quot;last&quot;<br>
- block of data, when clearly it is not.<br>
-<br>
- Accordingly, the compression routine inserts the &quot;EOD&quot; byte<br>
- into the stream, and returns EOFC.<br>
-<br>
- Independently of the return value used, having multiple EOD<br>
- bytes in the data is clearly wrong. Update the caller to only<br>
- pass &quot;last&quot; in for the last block.<br>
-<br>
- The code still returns EOFC at the end of the data, so update<br>
- this final call to accept (indeed, expect) that return value<br>
- there.<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-10 09:04: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=6cd0b941d86fe54b7e818e563dc702a147bab95a">6cd0b941d86fe54b7e818e563dc702a147bab95a</a>
-<blockquote>
-<p>
- Fix bug 701550, problem with forall on strings.<br>
-<br>
- Hard to believe, but this problem has existed since at least version 3.33.<br>
- The 'string_continue' function altered the size which was used to decide if<br>
- there were still characters to be processed BEFORE invoking the 'push(#)' macro.<br>
- If the 'push(1)' encountered a full stack segment, it would return stackoverflow<br>
- so that the operand stack could be extended. This meant that the decision to<br>
- stop enumerating the string would end early (depending on how many times the<br>
- stackoverflow occurred).<br>
-<br>
- Usually the procedure of the forall would either consume the character (reducing<br>
- the stack), or add an element to the stack triggering the stack extension before<br>
- the next execution of string_continue, but -c &quot;401 string { dup } forall count =&quot;<br>
- results in only 800 stack elements (rather than 802 as expected).<br>
-<br>
-psi/zgeneric.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-15 15:54: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=f560f3c468ac187eca8cd55ee46a46e2924e0924">f560f3c468ac187eca8cd55ee46a46e2924e0924</a>
-<blockquote>
-<p>
- Doc updates, changelog, news etc<br>
-<br>
- Update to note explicitly case sensitivity on Windsows<br>
-<br>
- In News.htm and History9.htm<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-05 09:09: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=cc86598152465c85dfca5ba265608931672f730f">cc86598152465c85dfca5ba265608931672f730f</a>
-<blockquote>
-<p>
- Date for 9.28 rc2<br>
-<br>
-base/gscdefs.h<br>
-base/version.mak<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/Internal.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-10-31 20:22:11 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=350a5cd8b7bddee3fa914c914dd40a685fed54e7">350a5cd8b7bddee3fa914c914dd40a685fed54e7</a>
-<blockquote>
-<p>
- Bug 700088: Report error if all wanted J2K components are not decoded.<br>
-<br>
- Ghostscript used to attempt to use even the undecoded components.<br>
- The source code for upstream's opj_decompress tool avoided this by<br>
- a workaround along with a comment indicating that this ought to be<br>
- done in the library (so all clients, e.g. Ghostscript will benefit<br>
- from it). With this commit the library will error out if not all<br>
- requested components are successfully decoded. Thus Ghostscript<br>
- will no longer crash.<br>
-<br>
- Reported in https://github.com/uclouvain/openjpeg/issues/1158<br>
- sent upstream in https://github.com/uclouvain/openjpeg/pull/1164<br>
- and finally committed in e66125fe260deee49fdf6e9978d9bd29871dd5bb<br>
-<br>
-openjpeg/src/bin/jp2/opj_decompress.c<br>
-openjpeg/src/lib/openjp2/j2k.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-03 12:34:55 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b944e875baed62e718eee8e7ad2b351cd4f4aa07">b944e875baed62e718eee8e7ad2b351cd4f4aa07</a>
-<blockquote>
-<p>
- Undo commit 95f7befcec1b30fd5014c8ad616485d32901ce33 for release<br>
-<br>
- Proper handling of the page group color space is going to require<br>
- a more complex solution whereby we ensure that we do the final<br>
- alpha blending in the page group color space and not the target<br>
- device color space.<br>
-<br>
-base/gstrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-03 08:52:16 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ebfe16357f3484209e69d6788cc52b20dbdb81a0">ebfe16357f3484209e69d6788cc52b20dbdb81a0</a>
-<blockquote>
-<p>
- Add -sBlendColorProfile into Use.htm<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-03 18:15:56 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bbdfaa56b00f2ba556476f0265e65e4ad370f641">bbdfaa56b00f2ba556476f0265e65e4ad370f641</a>
-<blockquote>
-<p>
- Avoid potential UMR with arg checking in arg sanitization code.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-02 17:16:45 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=00d4696ea2de6c48a57d5a4ce0c3bbfd99201e3a">00d4696ea2de6c48a57d5a4ce0c3bbfd99201e3a</a>
-<blockquote>
-<p>
- Proper fix for deep color overprint.<br>
-<br>
- The previous fix confused memset and memcpy. Properly write the<br>
- (native endian) 16 bit color values into the big endian buffer.<br>
-<br>
-base/gsovrc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-02 12:59:33 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6d448b3fe616fdc2ba1e52766c9a4417e4e738f">c6d448b3fe616fdc2ba1e52766c9a4417e4e738f</a>
-<blockquote>
-<p>
- Fix deep color mattes.<br>
-<br>
- As seen with the content vanishing when rendering<br>
- tests_private/pdf/sumatra/uninitialized_value_with_JPX_images.pdf<br>
- to psdcmyk16. The Softmask on the image has a Matte of [1,1,1]<br>
- and the calculations in the current code overflow, meaning that<br>
- it comes out as completely white.<br>
-<br>
- We resort to 64bit to avoid the overflow. Mattes are vanishingly<br>
- rare, so speed shouldn't be an issue. We can revisit if we ever<br>
- find a case that matters.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-31 12:45:47 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4c1f255c2e825ab5e0a3d0f7bfa88538c7cbb912">4c1f255c2e825ab5e0a3d0f7bfa88538c7cbb912</a>
-<blockquote>
-<p>
- Update overprint hl_color code to cope with 16bit devices too.<br>
-<br>
-base/gsovrc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-31 12:16:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=373787ee145e906c8d19d5ccda84b4f267db2010">373787ee145e906c8d19d5ccda84b4f267db2010</a>
-<blockquote>
-<p>
- Fix deep color transparency overprint.<br>
-<br>
- The component copy loop at the end of the blend could fail to copy<br>
- enough entries.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-30 15:16:34 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=361c4dd1e18ca0675173c0ad0104ffb910e93bb4">361c4dd1e18ca0675173c0ad0104ffb910e93bb4</a>
-<blockquote>
-<p>
- Avoid overflow in deep color luminosity calculations.<br>
-<br>
- Resort to 64bit as scale calculations are not constrained<br>
- to the usual 16bit range.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-29 10:02: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=51d57fafbdc021c8c73475db505156f77e96ce39">51d57fafbdc021c8c73475db505156f77e96ce39</a>
-<blockquote>
-<p>
- Fix clearing of the drag and drop file list<br>
-<br>
- Because we have to store the list of file names from drag and drop events, in<br>
- order to correctly add and remove them from the permit file read list, we also<br>
- want to clear the lists before we destroy the &quot;text&quot; window object.<br>
-<br>
- The problem is, this happens after we shutdown Ghostscript and unload the dll.<br>
-<br>
- This moves that clearing of the list into function that we call before we<br>
- shut down.<br>
-<br>
-psi/dwmain.c<br>
-psi/dwtext.c<br>
-psi/dwtext.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-28 10:14: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=ad0532e379a9eb6eb8a6fc0a6305679b25cd9ecb">ad0532e379a9eb6eb8a6fc0a6305679b25cd9ecb</a>
-<blockquote>
-<p>
- Fix path permissions added from cidfmap.<br>
-<br>
- From the cidfmap, we accumulate a list of unique directory paths a we process<br>
- cidfmap and then add them - when I did that code, I forgot that to allow access<br>
- to the directory, we need a trailing directory separator.<br>
-<br>
- Add that before calling .addcontrolpath<br>
-<br>
-Resource/Init/gs_cidfm.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 16:49: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=f0fedf1f77a9fe70627355b45fdb809e83df3568">f0fedf1f77a9fe70627355b45fdb809e83df3568</a>
-<blockquote>
-<p>
- Fix font file finding with -P<br>
-<br>
- In trying to reproduce the issue that inspired commit dea69cd04964, I noticed<br>
- that font file searching wasn't working correctly with -P specified on the<br>
- command line.<br>
-<br>
- Previously, it could just end up with us not finding a font we should have, but<br>
- with dea69cd04964 it would result in a typecheck error.<br>
-<br>
- This ensures the stack is always how it should be after the findlibfile<br>
- call<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-22 16:10:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5c28996d19d5e10cb177e72c47037ec0c7b3e4d5">5c28996d19d5e10cb177e72c47037ec0c7b3e4d5</a>
-<blockquote>
-<p>
- Make it clear: file/path matching is always case sensitive<br>
-<br>
- even on Windows.<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-29 19:50:08 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=24532ce9371fd1f69dd343cbd6ac8187a86c5c96">24532ce9371fd1f69dd343cbd6ac8187a86c5c96</a>
-<blockquote>
-<p>
- Fix overflow in 16bit blending calculations.<br>
-<br>
- The blending code uses the following construction in<br>
- several places:<br>
-<br>
- src_scale = ...; /* a value between 0 and 0x10000 */<br>
- tmp = (y-z) * src_scale + 0x8000;<br>
- foo = x + (tmp&gt;&gt;16);<br>
-<br>
- Where x,y,z, are all expected to be in the 0...0xffff range.<br>
-<br>
- Due to y-z having a sign bit, this can overflow a 32 bit tmp.<br>
-<br>
- We therefore sacrifice a bit of accuracy in src_scale to get<br>
- correctness.<br>
-<br>
-base/gxblend.c<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-28 14:13:27 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ca52028b90a09d056190548c41ae0b9a9fbadb4e">ca52028b90a09d056190548c41ae0b9a9fbadb4e</a>
-<blockquote>
-<p>
- Remove outdated FIXME's.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-28 12:50: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=bd59dc145252282d8f586c36082e63a0eba95c15">bd59dc145252282d8f586c36082e63a0eba95c15</a>
-<blockquote>
-<p>
- Bug 701446: Avoid divide by zero in shading.<br>
-<br>
- The previous commit for this bug was enough to solve the problem<br>
- for ppmraw, but not, it seems, for other devices. This addresses<br>
- the division by zero more directly.<br>
-<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 20:13:02 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a32a379933f4ba27ff1ad5734ec8c24c42eb513">9a32a379933f4ba27ff1ad5734ec8c24c42eb513</a>
-<blockquote>
-<p>
- Fix deep color transparency saturation blending.<br>
-<br>
- Problem seen with:<br>
-<br>
- tests_private/pdf/PDF_1.7_FTS/fts_25_2513.pdf.psdcmyk16.300.1<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 17:45:57 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=68af4dbc7ca2d6bfdbe938b840799cb8883c973e">68af4dbc7ca2d6bfdbe938b840799cb8883c973e</a>
-<blockquote>
-<p>
- Bug 701446: Avoid division by zero in gx_shade_trapezoid<br>
-<br>
- Remove some incorrect clipping code.<br>
-<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 15:54: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=4be058791ae19131f19a8303364be53619abc280">4be058791ae19131f19a8303364be53619abc280</a>
-<blockquote>
-<p>
- Exit early from gx_shade_trapezoid in more cases.<br>
-<br>
- A zero height trap isn't plotted, so we can bail out early in<br>
- that case.<br>
-<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-26 17:02: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=9423e84178071f16b83d18412b22b0b479b1938b">9423e84178071f16b83d18412b22b0b479b1938b</a>
-<blockquote>
-<p>
- Fix deep colour transparency &quot;uncompositing&quot;.<br>
-<br>
- Uncompositing a group uses a scale factor that is greater in range<br>
- than we'd like; we need to resort to 64bit to do this to avoid<br>
- losing accuracy.<br>
-<br>
- This solves problems seen in:<br>
-<br>
- tests_private/comparefiles/Bug689918.pdf.psdcmyk16.300.1<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 14:26: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=131768114453972469296658b795406b79630538">131768114453972469296658b795406b79630538</a>
-<blockquote>
-<p>
- Handle relative FONTPATH values<br>
-<br>
- Prior to 9.21 (specifically: 8abd22010eb4db0fb1b10e430d5f5d83e015ef70), relative<br>
- paths for FONTPATH worked, but did so due to a logic fault with how we search<br>
- for &quot;lib&quot; files.<br>
-<br>
- When attempting to open file names specified on the command line, we used a<br>
- flag set in the command line handling (starting_arg_file) to know whether the<br>
- lib file searching logic should try to open the file name directly (as well as<br>
- trying the file combined with each path in the search path).<br>
-<br>
- In versions prior to commit 8abd22010eb4 that flag (starting_arg_file) could<br>
- remain set to true, even after the command line file(s) had been opened. This<br>
- represented a (minor) security risk. Commit 8abd22010eb4 ensured the flag was<br>
- properly (re)set, and that caused relative paths for FONTPATH stopped working.<br>
-<br>
- Rather than reintroduce the security risk, update the code that checks whether<br>
- the font files exist so it explicitly tries the file name directly, rather than<br>
- assuming .libfile (or findlibfile, in this case) does that automatically.<br>
-<br>
- Also remove an extraneous (but benign) dup of the font name.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 15:27: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=98310063bdbe8c67bcfe84e2c648cfa286a05738">98310063bdbe8c67bcfe84e2c648cfa286a05738</a>
-<blockquote>
-<p>
- pdfwrite - fix corner case with Color Conversion<br>
-<br>
- Bug #701456 &quot;Ghostscript creates broken PDF file after color conversion&quot;<br>
-<br>
- The test file is, essentially weird. The image on page 3 is not a single<br>
- image, its a series of images, all of which are in a /Indexed /DeviceRGB<br>
- colour space.<br>
-<br>
- In addition, these images are drawn on *top* of another set of images<br>
- (thereby completely obscuring them). These images are also drawn in<br>
- /Indexed /DeviceRGB. However, these images are in fact monochrome, the<br>
- Indexed space consists of 2 colours. This means that (highly unusually)<br>
- we have a DeviceRGB image with 1 Bit Per Component.<br>
-<br>
- This caused problems for the pdfwrite compression filter chooser because<br>
- it chose (and configured) a compression scheme suitable for 1 BPC data<br>
- and then actually output 8 BPC data. This led to the compression filter<br>
- writing too little data.<br>
-<br>
- Fix this here by setting the BPC to 8 if we are doing colour conversion,<br>
- and have the colour conversion setup code use the original value in the<br>
- image enumerator (the conversion code *does* need to know the input is<br>
- 1 BPC).<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 11:36: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=aee3b922087674ddd7c64444988018fafc3da127">aee3b922087674ddd7c64444988018fafc3da127</a>
-<blockquote>
-<p>
- PDF interpreter - more /Mask strangeness in Acrobat<br>
-<br>
- Bug #701468 &quot; More weirdness with images containing invalid /Mask values&quot;<br>
-<br>
- In order to render this file as per Acrobat, we need to ignore the /Mask<br>
- array. However, in order to render bug 689717 correctly we need to fix<br>
- the /Mask array.<br>
-<br>
- Both cases are 1 BitsPerComponent DeviceGray images, the only difference<br>
- is the actual /Mask values. Bug 689717 has [255 255] while 701468 has<br>
- [243 255]. We can differentiate based on whether we have DeviceGray<br>
- 1 BPC image, where the Mask values are not the same. In the case they<br>
- are different we use the existing technique of calculating the maximum<br>
- value and using that (for both, so there is no range). Where there is a<br>
- range (ie not a single colour) this is clearly unusable in a 2-colour<br>
- image, so ignore the /Mask altogether.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-26 15:28:33 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad22dcaa078fd16f2ac395f65b6ad87ba24c8903">ad22dcaa078fd16f2ac395f65b6ad87ba24c8903</a>
-<blockquote>
-<p>
- Fix deep colour knockout logic.<br>
-<br>
- Problem seen with:<br>
-<br>
- tests_private/pdf/PDF_1.7_FTS/fts_25_2507.pdf.psdcmyk16.72.0<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-26 14:34:46 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4cda7bfc8cc8c5c4dcd36167191012aa379100ac">4cda7bfc8cc8c5c4dcd36167191012aa379100ac</a>
-<blockquote>
-<p>
- Squash a couple of warnings.<br>
-<br>
-base/gdevmem.c<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-26 14:01:39 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b5166b5c65703abb02c15a31c9f8341f54d1470">7b5166b5c65703abb02c15a31c9f8341f54d1470</a>
-<blockquote>
-<p>
- Fix SoftLight blending in deep color transparency.<br>
-<br>
- As seen with:<br>
-<br>
- gs -sDEVICE=psdcmyk16 -r72 -dMaxBitmap=80000000 -o out.psd<br>
- tests_private/pdf/PDF_1.7_FTS/fts_09_0919.pdf<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-26 11:28:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5875be5edeb034787a11760c9330cac039f13044">5875be5edeb034787a11760c9330cac039f13044</a>
-<blockquote>
-<p>
- Fix problems with pngalpha and deep color transparency filling.<br>
-<br>
- The pngalpha device is created with a depth of 32, with 3 color<br>
- components; this was confusing pdf14 into thinking that more<br>
- than 8 bits per color were being used, and so deep color buffers<br>
- were required.<br>
-<br>
- To fix this we update the logic to be smarter; in cases where we<br>
- don't have a clear determination based on bits alone, we look<br>
- at the max_color and max_gray values. Because this code is now<br>
- more complex than before, we pull it into a shared function.<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevmem.c<br>
-base/gdevp14.c<br>
-base/gdevprn.c<br>
-base/gsptype1.c<br>
-base/gstrans.c<br>
-base/gxclthrd.c<br>
-base/gxdevcli.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-23 15:06: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=6e7283fa5bcea9ffbe4bb9da440dd8fa4820e4d6">6e7283fa5bcea9ffbe4bb9da440dd8fa4820e4d6</a>
-<blockquote>
-<p>
- Fix deep color transparency issue.<br>
-<br>
- Fix overflow in art_pdf_composite_knockout_16, seen in:<br>
-<br>
- tests_private/comparefiles/Bug690546.pdf.psdcmyk16.72.0<br>
-<br>
-base/gdevp14.c<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-22 18:24:49 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=628c9741323ea69b0be8e4008a81b1db3d644ab8">628c9741323ea69b0be8e4008a81b1db3d644ab8</a>
-<blockquote>
-<p>
- Fix deep color transparent pattern problems.<br>
-<br>
- Transparency buffers are held as native endian. Pattern cache<br>
- tiles are held as big endian. When we make pattern cache tiles<br>
- from transparency buffers we therefore need a conversion.<br>
-<br>
-base/gdevp14.c<br>
-base/gxblend.c<br>
-base/gxp1fill.c<br>
-base/gxpcolor.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-25 19:35:14 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be4da9d67cbec784be740086681f96a63496ae48">be4da9d67cbec784be740086681f96a63496ae48</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Do not output LUTs with CUPS_DEBUG set<br>
-<br>
- This change lets complete LUTs in the debug output only be listed when<br>
- CUPS_DEBUG2 is set and not already with CUPS_DEBUG.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-25 19:08:52 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e28c843e56d1be4638bf9d84a499794534ea0d9">0e28c843e56d1be4638bf9d84a499794534ea0d9</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Prefer the page size requested by user<br>
-<br>
- Without special scaling/cropping options (&quot;fit-to-page&quot;, &quot;fill&quot;,<br>
- &quot;crop-to-fit΅, ...) PDF and PostScript files printed with CUPS will be<br>
- printed with the page sizes of the document's pages and not the size<br>
- requested by the user via the &quot;PageSize&quot; or &quot;media&quot; option. This<br>
- allows correct printing of jobs with differently sized pages on<br>
- printers which have the appropriate sizes loaded without need of<br>
- manual intervention. Therefore the CUPS output device is matching each<br>
- input page against the sizes listed in the PPD to generate a correct<br>
- page geometry for the printer for each page.<br>
-<br>
- Problem is if there are several equally-sized page size entries in the<br>
- PPD. Without further guiding always the first match is used, making<br>
- access to special functions provided by the others (like<br>
- full-bleed/borderless printing) inaccessible.<br>
-<br>
- This commit adds the functionality of the user-requested page size<br>
- (via &quot;PageSize&quot; or &quot;media&quot; option) being preferred under the matching<br>
- page sizes, so that if for example a user selects a full-bleed version<br>
- of the desired page size and sends a photo, the photo gets rendered<br>
- and printed with the page geometry which the PPD reports for the<br>
- full-bleed version.<br>
-<br>
- Nothing changes if the size of the user-requested page size does not<br>
- match the size of the input page at all.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-25 12:45:27 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a5ccd009fd632e058b4f0bc2849cfc293b39d1f2">a5ccd009fd632e058b4f0bc2849cfc293b39d1f2</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Small fix on size matching improvements<br>
-<br>
- This is a fix for one little oversight on the changes to support matching<br>
- the input page size against the imageable areas of the PPD's page sizes.<br>
-<br>
- This completes the fix of bug 701438.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-24 23:11:10 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a0284b5ac8c59014eab90c5a5ec388cd1676b79d">a0284b5ac8c59014eab90c5a5ec388cd1676b79d</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Improved page size matching with PPD<br>
-<br>
- Applied the following improvements for finding the correct page size<br>
- of the PPD file for the input page:<br>
-<br>
- - Do not try to match by page size name, the input files do not<br>
- contain page size names.<br>
-<br>
- - Do not only match the input page size against the actual media sizes<br>
- reported by the PPD but also to the imageable areas. Media size match<br>
- is preferred but if there is no media size match, we accept also<br>
- a match of the imageable area. In case of a match of the imageable<br>
- area we position the input page in the imageable area of the output<br>
- page.<br>
-<br>
- - More debug output.<br>
-<br>
- - In case of a custom page size (no match with PPD sizes) the page<br>
- size name in the CUPS Raster output is a correct &quot;Custom.XXXxYYY&quot;<br>
- and not the default page size name.<br>
-<br>
- This should fix bug #701438.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-23 18:09:32 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ee43ff891b51f0ccec3ba38d538d3e23441ed439">ee43ff891b51f0ccec3ba38d538d3e23441ed439</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Reduced page size comparison tolerances<br>
-<br>
- Before each page gets rendered its size is compared to the page sizes<br>
- of the PPD file to select the actual page size for the output. Reduced<br>
- the tolerances from 7% for the long edge and 5% for the short edge to<br>
- 1%, as before easily wrong sizes got picked (See also bug 701438).<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-23 10:11: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=0311b61d5df67cd98e2c2d23ef3cec1cc4faa800">0311b61d5df67cd98e2c2d23ef3cec1cc4faa800</a>
-<blockquote>
-<p>
- Windows Installer: cope with COMPILE_INITS=0<br>
-<br>
- We default to COMPILE_INITS=1, and that was the only case that the installer<br>
- handled - i.e. building the installer with COMPILE_INITS=0 would install an<br>
- executable that wouldn't work without extra action (-I.. or similar).<br>
-<br>
- This changes the installer compiler invocation, and the installer creation<br>
- so it behaves as it does now with COMPILE_INITS=1, but with COMPILE_INITS=0 the<br>
- installer will write the path to Resource/Init into the GS_LIB registry<br>
- key.<br>
-<br>
-psi/nsisinst.nsi<br>
-psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-22 23:30:34 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=137a0bda39f861600488b5a11c63914854c454c8">137a0bda39f861600488b5a11c63914854c454c8</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Produce more debug output<br>
-<br>
- When building with CUPS_DEBUG now debug output for the process of<br>
- matching the page geometry with the PPD file's page sizes is<br>
- produced.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-22 08:58:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=09b53ebdc674f9f6e7a9c445e92617312dd93ab3">09b53ebdc674f9f6e7a9c445e92617312dd93ab3</a>
-<blockquote>
-<p>
- Handle explicit '\' escaping in path matching<br>
-<br>
- As well as having to cope with both '/' and '\' as directory separators on<br>
- Windows, it turns out we also need to cope with the backslash separator being<br>
- explicitly escaped (&quot;\\&quot;) - the explicit is added by the Postcript path<br>
- templating code in gs_init.ps.<br>
-<br>
- I don't want to change templating code because that would likely have<br>
- implications in a lot of other places.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-22 10:51: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=f1692a288f1a17930f0b71e540908398a17d5366">f1692a288f1a17930f0b71e540908398a17d5366</a>
-<blockquote>
-<p>
- Better CMYK conversion for bmpcmp<br>
-<br>
-toolbin/bmpcmp.c<br>
-toolbin/bmpcmptab.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-21 17:49:32 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c8aaf3b7bc4232997d434170827fffd6887fc88f">c8aaf3b7bc4232997d434170827fffd6887fc88f</a>
-<blockquote>
-<p>
- Update bmpcmp.c to read psdrgb rather than psdbgr.<br>
-<br>
-toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-21 15:33: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=9ba1827e220cd49a6732c04fcf3e55a268014377">9ba1827e220cd49a6732c04fcf3e55a268014377</a>
-<blockquote>
-<p>
- Fix commit ec0b35fed3de: &quot;Handle directory separators...&quot;<br>
-<br>
- The logic in the above fix was wrong.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-21 14:28:20 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d0206d2b118b26f6d87ba8f09d077eba417e4c9">7d0206d2b118b26f6d87ba8f09d077eba417e4c9</a>
-<blockquote>
-<p>
- Bug 701451: Fix clist color_usage calculations for shadings.<br>
-<br>
- Or rather, don't attempt to calculate them badly, and just<br>
- use the safe &quot;all colors&quot; value.<br>
-<br>
-base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-21 10:10:51 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=320ec9672b987a765324f89450de08b70aafbcd3">320ec9672b987a765324f89450de08b70aafbcd3</a>
-<blockquote>
-<p>
- PDF interpreter - review .forceput security<br>
-<br>
- Bug #701450 &quot;Safer Mode Bypass by .forceput Exposure in .pdfexectoken&quot;<br>
-<br>
- By abusing the error handler it was possible to get the PDFDEBUG portion<br>
- of .pdfexectoken, which uses .forceput left readable.<br>
-<br>
- Add an executeonly appropriately to make sure that clause isn't readable<br>
- no mstter what.<br>
-<br>
- Review all the uses of .forceput searching for similar cases, add<br>
- executeonly as required to secure those. All cases in the PostScript<br>
- support files seem to be covered already.<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>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-21 10:56: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=e5660f15f5fd4615254acec7ed403b4a7984cb09">e5660f15f5fd4615254acec7ed403b4a7984cb09</a>
-<blockquote>
-<p>
- Handle directory separators in access control matching<br>
-<br>
- On Windows, we end up dealing with a mishmash of &quot;/&quot; and &quot;\&quot; as directory<br>
- separators, so a simple equality check isn't sufficient.<br>
-<br>
- Since there is already (platform specific) function for checking whether a<br>
- string (or part thereof) is a directory separation, use it.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 21:50:18 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=596e9baa1b24b0a9dac4d8bad1ea80cd23dcab79">596e9baa1b24b0a9dac4d8bad1ea80cd23dcab79</a>
-<blockquote>
-<p>
- Disable use of alternate tint transform ICC profile<br>
-<br>
- A prior commit introduced the use of color management<br>
- if the DeviceN or Separation device had an ICC profile<br>
- associated with the colorants. While there is an argument<br>
- for doing this, it is not the standard behavior seen in<br>
- AR. Disabling for now and will likely turn this into a<br>
- command line option.<br>
-<br>
-base/gxcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 18:48:49 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7547a2fc593e3a0bb8ea72f661389cd908c382f7">7547a2fc593e3a0bb8ea72f661389cd908c382f7</a>
-<blockquote>
-<p>
- Fix crashes in RAW_DUMP debug code.<br>
-<br>
- Dump the buffer before freeing the device, or the pointer will no<br>
- longer be valid.<br>
-<br>
- Also, don't access through ppatdev14 when we know it's NULL.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 18:47:09 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=421727ed068b3f41fdbd9657d759397610fe8821">421727ed068b3f41fdbd9657d759397610fe8821</a>
-<blockquote>
-<p>
- Fix deep color transparency pattern copying problem.<br>
-<br>
- The following test:<br>
-<br>
- tests/pdf/pattrans_solid_nonrect.pdf.psdcmyk16.300.1..gs<br>
-<br>
- among others, was showing problems, due to us treating the offset<br>
- as bytes rather than shorts.<br>
-<br>
-base/gxp1fill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 14:29:33 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f9052f1debff2168d5a2606fa35bcaaf6f6f2ec7">f9052f1debff2168d5a2606fa35bcaaf6f6f2ec7</a>
-<blockquote>
-<p>
- Avoid signed overflow in deep transparency calculations.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 12:24: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=898c9e5f06bb44ec3fd262b47eeaa5028e18773f">898c9e5f06bb44ec3fd262b47eeaa5028e18773f</a>
-<blockquote>
-<p>
- Fix overflow in deep color blending.<br>
-<br>
- Multiplying a 16bit unsigned value with a 16 bit signed value<br>
- in a 32bit int means we lose the sign bit. Sacrifice a bit of<br>
- accuracy to avoid that.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 10:10: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=85c9d6de80ba57deeee289238aa1c0202f584c3c">85c9d6de80ba57deeee289238aa1c0202f584c3c</a>
-<blockquote>
-<p>
- make .forceput inaccessible<br>
-<br>
- Bug #701343, #701344, #701345<br>
-<br>
- More defensive programming. We don't want people to access .forecput<br>
- even though it is no longer sufficient to bypass SAFER. The exploit<br>
- in #701343 didn't work anyway because of earlier work to stop the error<br>
- handler being used, but nevertheless, prevent access to .forceput from<br>
- .setuserparams2.<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_pdfwr.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-19 10:03:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3ba6d871c70398cfbd15b619127bf13ddea13282">3ba6d871c70398cfbd15b619127bf13ddea13282</a>
-<blockquote>
-<p>
- Handle drag'n'drop file name/paths<br>
-<br>
- Because we now run by default with the file access permission active,<br>
- we need to do additional work for Windows drag and drop files, so they don't<br>
- throw an invalidaccess error (since we implement drag and drop by sending<br>
- characters to the gs console to do '(file) run').<br>
-<br>
- The problem is, we cannot add the file to read list, send the characters to the<br>
- console, and remove the file from the read list because, although SendMessage()<br>
- blocks until the message is handles, WriteConsoleInput() does not block until<br>
- the console buffers are consumed (i.e. it is asynchronous). So, there is no<br>
- certainty when the final SendMessage() in WM_DROPFILES case is finished that<br>
- Ghostcript will actually have run the file.<br>
-<br>
- So, we create a list of dropped file names, add them to the permit read list,<br>
- when the next WM_DROPFILES event happens, or a WM_DESTROY event, we drop<br>
- file names from the permit read list before, if necessary, adding the current<br>
- ones.<br>
-<br>
-psi/dwimg.c<br>
-psi/dwmain.c<br>
-psi/dwmainc.c<br>
-psi/dwtext.c<br>
-psi/dwtext.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-16 15:43:32 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d2e36e8ef01546aaee0cd0531fbc0fa932b23b99">d2e36e8ef01546aaee0cd0531fbc0fa932b23b99</a>
-<blockquote>
-<p>
- Squash warnings in claptrap.<br>
-<br>
- Thanks to William Bader for highlighting these.<br>
-<br>
-base/claptrap-planar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-16 15:28:49 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e34d5606835fc587e222b80bf9cac1bc40c4790b">e34d5606835fc587e222b80bf9cac1bc40c4790b</a>
-<blockquote>
-<p>
- Squash warning in gdevpsd.c<br>
-<br>
- Thanks to William Bader for spotting this.<br>
-<br>
-devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-16 13:08:14 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f416b415e8e3a25446b66bf1a6253f86be0366de">f416b415e8e3a25446b66bf1a6253f86be0366de</a>
-<blockquote>
-<p>
- Squash some compiler warnings.<br>
-<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-devices/gdevpdfimg.c<br>
-devices/vector/gdevpdfu.c<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-15 11:39: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=9ead927968ff8104e1a81df1590fced74927639d">9ead927968ff8104e1a81df1590fced74927639d</a>
-<blockquote>
-<p>
- Dates and versions for 9.28 RC 1<br>
-<br>
-base/gscdefs.h<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/Internal.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>2019-08-15 11:35: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=ae7dea2b9bd068f61b6aef312a7f4cbc9860cac3">ae7dea2b9bd068f61b6aef312a7f4cbc9860cac3</a>
-<blockquote>
-<p>
- Revision date<br>
-<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-15 17:06: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=2f8e2423c860e89b325675dc1311819179740c76">2f8e2423c860e89b325675dc1311819179740c76</a>
-<blockquote>
-<p>
- Add -dNOSAFER for Windows installer cidfmap creation<br>
-<br>
-psi/nsisinst.nsi<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-15 14:36: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=226fb24dbe4f844b8c7531be3eccc2bfae1a103d">226fb24dbe4f844b8c7531be3eccc2bfae1a103d</a>
-<blockquote>
-<p>
- ps2write - don't password encrypt PostScript output!<br>
-<br>
- Noticed while testing the args commit; if we set -sOwnerPassword (to<br>
- create a password-protected PDF file), but select (e)ps2write as the<br>
- device, then the resulting PostScript file would have all the streams<br>
- (in a PDF sense) encrypted with PDF password encryption.<br>
-<br>
- Unsurprisingly, this result in a completely unusable PostScript file.<br>
- Lets not permit that....<br>
-<br>
-devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-<h2><a name="Version9.50"></a>Version 9.50 (2019-10-15)</h2>
-<p> Highlights in this release include:
-<ul>
-<li>
-<p>The change to version 9.50 (rather than the intended 9.28) follows recognition
-of the extent and importance of the file access control redesign/reimplementation
-outlined below.
-</li>
-<li>
-<p>The file access control capability (enable with <code>-dSAFER</code>) has been
-completely rewritten, with a ground-up rethink of the design. For more details,
-see: <a href="Use.htm#Safer">SAFER</a>.
-<p>It is important to note that <code>-dSAFER</code> now <strong>only</strong> enables
-the file access controls, and no longer applies restrictions to standard Postscript
-functionality (specifically, restrictions on <code>setpagedevice</code>. If your
-application relies on these Postscript restrictions, see <a href="Use.htm#OldSafer">OLDSAFER</a>,
-and please get in touch, as we do plan to remove those Postscript restrictions
-unless we have reason not to.
-<p><strong>IMPORTANT:</strong> File access controls are now enabled by default. In
-order to run Ghostscript without these controls, see <a href="Use.htm#NoSafer">NOSAFER</a>
-</li>
-<p><strong>Important Note for Windows Users</strong>: See below under
-<a href="#28_Incompatible_changes">Incompatible Changes</a>
-<li>
-<p>IMPORTANT: We are in the process of forking LittleCMS. LCMS2 is not thread safe, and
-cannot be made thread safe without breaking the ABI. Our fork will be thread safe, and include
-performance enhancements (these changes have all be been offered and rejected upstream). We
-will maintain compatibility between Ghostscript and LCMS2 for a time, but not in perpetuity.
-Our fork will be available as its own package separately from Ghostscript (and MuPDF).
-</li>
-<li>
-<p>The usual round of bug fixes, compatibility changes, and incremental improvements.
-</li>
-<li>
-<p>Special thanks to Akira Kakuto, Paul Wessel, William Bader, Nelson H. F. Beebe and
-everyone else who put time and effort into testing this new release.
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-<h3><a name="9.50_Incompatible_changes"></a>Incompatible changes</h3>
-<ul>
-<li>
-<p>There are a couple of subtle incompatibilities between the old and new SAFER
-implementations. Firstly, as mentioned above, SAFER now leaves standard Postcript
-functionality unchanged (except for the file access limitations). Secondly,
-the interaction with <code>save</code>&sol;<code>restore</code> operations, see
-<a href="Use.htm#Safer">SAFER</a>.
-<p><strong>Important Note for Windows Users</strong>:
-<br>
-The file/path pattern matching is case sensitive, even on Windows. This is a
-change in behaviour compared to the old code which, on Windows, was case
-<i>in</i>sensitive. This is in recognition of changes in Windows behaviour,
-in that it now supports (although does not enforce) case sensitivity.
-</li>
-<li>
-<p>The following is not strictly speaking new to 9.50, as not much has changed since
-9.27 in this area, but for those who don't upgrade with every release:
-<p>The process of &quot;tidying&quot; the Postscript name space should have removed
-only non-standard and undocumented operators. Nevertheless, it is possible that
-any integrations or utilities that rely on those non-standard and undocumented
-operators may stop working, or may change behaviour.
-<p>If you encounter such a case, please contact us (either the #ghostscript IRC channel,
-or the gs-devel mailing list would be best), and we'll work with you to either find an
-alternative solution or return the previous functionality, if there is genuinely no other
-option.
-<p>One case we know this has occurred is GSView 5 (and earlier). GSView 5 support for PDF
-files relied upon internal use only features which are no longer available. GSView 5 will
-still work as previously for Postscript files. For PDF files, users are encouraged to look
-at <a href="https://www.mupdf.com">MuPDF</a>.
-</li>
-</ul>
-<h3><a name="9.50_changelog"></a>Changelog</h3>
-<p><strong>2019-10-14 18:07: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=f2e2a3fe85d64cabde82d0f6eb982643bc6e8427">f2e2a3fe85d64cabde82d0f6eb982643bc6e8427</a>
-<blockquote>
-<p>
- Add words about .currentpathcontrolstate operator<br>
-<br>
-doc/Language.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-14 10:28: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=ad5b08d8be2e7a91599d3bbbc6aa841144662239">ad5b08d8be2e7a91599d3bbbc6aa841144662239</a>
-<blockquote>
-<p>
- Change version to 9.50<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/version.mak<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/Internal.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>2019-10-14 10:20:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1937e14f17e5de54b57d0e911e828639d197a08c">1937e14f17e5de54b57d0e911e828639d197a08c</a>
-<blockquote>
-<p>
- Update docs on SAFER<br>
-<br>
- to reflect that SAFER is now the default, and remove the comments about making<br>
- SAFER the default &quot;in the future&quot;.<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-10 09:29: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=9c63f39ead4aab30addf213f0ab6843ac87b56cf">9c63f39ead4aab30addf213f0ab6843ac87b56cf</a>
-<blockquote>
-<p>
- ps2write - restore missing %%PageTrailer comment<br>
-<br>
- Bug #701659 &quot;Missing %%PageTrailer commen&quot;<br>
-<br>
- An oversight in commit 96c381cce28c27eac182549441a6c5025b0dcdd6<br>
- caused the comment to be omitted.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-07 18:41: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=1d89e1aa9cf65e5345a1f009b6d317db024719fe">1d89e1aa9cf65e5345a1f009b6d317db024719fe</a>
-<blockquote>
-<p>
- Bug 701657: Allocate &quot;memory&quot; device in immovable gc memory<br>
-<br>
- Devices are supposed to be allocated in memory that cannot relocate (i.e.<br>
- non-gc memory or an immovable allocation). The memory device accessible from<br>
- Postscript (makeimagedevice/makewordimagedevice) was being created in regular,<br>
- relocatable gc memory.<br>
-<br>
- This caused an invalid memory access when cleaning up subclassed devices, as the<br>
- one device in the chain may have moved. So switch to using an immovable<br>
- allocation.<br>
-<br>
-base/gsdevmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-02 00:01:17 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=458f715b0d59278f0788e0c89ee5eb04d48871ef">458f715b0d59278f0788e0c89ee5eb04d48871ef</a>
-<blockquote>
-<p>
- Update jbig2dec stuff for 0.17 release.<br>
-<br>
-jbig2dec/CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-10-01 10:35: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=f8ba9e017cdfab836f62853629d75f484127342e">f8ba9e017cdfab836f62853629d75f484127342e</a>
-<blockquote>
-<p>
- Fix memory corruption setting a halftone<br>
-<br>
- When setting a new halftone in the graphics state, we try to re-use the data<br>
- from the existing device halftone.<br>
-<br>
- The problem is that the device halftone can have higher component indices than<br>
- there are components in the new halftone we are creating. In this case, we can<br>
- end up writing off the end of the components array for the new halftone<br>
- structure.<br>
-<br>
- Simply check that the new halftone has enough components before doing the<br>
- duplication.<br>
-<br>
-base/gsht.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-30 13:40: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=1681c7ebb5a338002d5f7dd8da9bffda675f0656">1681c7ebb5a338002d5f7dd8da9bffda675f0656</a>
-<blockquote>
-<p>
- pdfwrite - don't honour /Producer key in DOCINFO pdfmark<br>
-<br>
- Bug #701639 &quot;pdfwrite should not honour the /Producer key in DOCINFO pdfmark&quot;<br>
-<br>
- The Producer in the document information dictionary (and XML Metadata)<br>
- is defined quite clearly as the application which produced the PDF file<br>
- from its native format.<br>
-<br>
- Ghostscript uses the Producer key (if present in the pdfmark) to set<br>
- the Producer, but it should not do so. Adobe Acrobat Distiller (at<br>
- least the end user version) does not permit this value to be altered.<br>
-<br>
- On reflection we can see why; in the case of a problem with a PDF file<br>
- its important to know which application created it, and we should not<br>
- let PostScript obscure that (we already do not pass the Producer<br>
- information on when the input is PDF).<br>
-<br>
- The code did already attempt to overwrite any Producer string which<br>
- contained 'Distiller' (I have no idea why) and that code contained an<br>
- error which could lead to an invalid Document Information dictionary<br>
- being created.<br>
-<br>
- This commit removes the ability for DOCINFO pdfmarks to alter the<br>
- Producer, which obviously fixes the bug.<br>
-<br>
- However..... it is actually important for our commercial customers to<br>
- be able to set this value. A problem with a PDF file created by one of<br>
- our customer's products should be reported to that customer, not us, as<br>
- we will not be able to investigate the problem while our customer<br>
- should be able to. At the very least our customer will know how to<br>
- retrieve the configuration of Ghostscript being used.<br>
-<br>
- So permit the commercial version of Ghostscript to set the /Producer<br>
- from a pdfmark.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-30 09:16: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=a27af00c8727ec4eaf0f4730963b8a81aab8590d">a27af00c8727ec4eaf0f4730963b8a81aab8590d</a>
-<blockquote>
-<p>
- Small changelog tweak<br>
-<br>
-doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-27 13:26:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b0574cdb5b427690ac8d95679930c9f6cc1bdffb">b0574cdb5b427690ac8d95679930c9f6cc1bdffb</a>
-<blockquote>
-<p>
- Bug 701634: Correctly handle file name of &quot;\0&quot;<br>
-<br>
- Attempting to open a file with a filename string starting with a NULL<br>
- character should be treated the same as if the string was zero length.<br>
-<br>
- Not doing so created a broken file object leading to several operations<br>
- resulting in a segfault.<br>
-<br>
- Also, add cleanup in the event of such an error, freeing memory allocated in<br>
- preparing the gs stream object.<br>
-<br>
-base/sfxcommon.c<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-26 10:47:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cce67ebf4c209ae3cbcc671e944596c64a3d7fc9">cce67ebf4c209ae3cbcc671e944596c64a3d7fc9</a>
-<blockquote>
-<p>
- Revised comment for 8992f00edfd1c39154c013489de2a01d2e9a92ee<br>
-<br>
- Make it clearer why the revised behaviour is required.<br>
-<br>
-base/gstiffio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-26 09:34: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=24c9f7f4a8d3e85e572094b4aedddbeeb02d5ef1">24c9f7f4a8d3e85e572094b4aedddbeeb02d5ef1</a>
-<blockquote>
-<p>
- Bug 701313: Disable libtiff callbacks when libtiff is shared<br>
-<br>
- It seems that libtiff uses global variables to store the error/warning callbacks<br>
- so if two callers in the exe are using the libtiff shared lib, very bad things<br>
- happen (usually a segfault).<br>
-<br>
- So, if that's how we're linked, set the callbacks to NULL.<br>
-<br>
-base/gstiffio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-24 15:48: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=c40963eb024265ab28f4f897401ad7a050ca9425">c40963eb024265ab28f4f897401ad7a050ca9425</a>
-<blockquote>
-<p>
- Cope with .setsafe(global) being called when already 'SAFER'<br>
-<br>
- As we default to SAFER file controls now, we want to cope with .setsafe and<br>
- .setsafeglobal being called either when already SAFER, or called multiple times.<br>
-<br>
- This means adding a .currentpathcontrolstate operator so we don't try to<br>
- influence the path control lists after control is activated.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-24 09:18: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=7d70bd4338291c99234dd0078b5cdc85178c0540">7d70bd4338291c99234dd0078b5cdc85178c0540</a>
-<blockquote>
-<p>
- tiffsep(1): Cope with .tiff ending as well as .tif<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 20:04:49 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f713b99e1a626ba4b7b1be8cc715043bb4e0f0a">2f713b99e1a626ba4b7b1be8cc715043bb4e0f0a</a>
-<blockquote>
-<p>
- Recast validate to use gs_file_name_check_separator.<br>
-<br>
- Avoid using gp_file_name_directory_separator, as windows can<br>
- have 2 different directory separators.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 18:05:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=31df729a821d1683381493b96c2ecced9da1e5e2">31df729a821d1683381493b96c2ecced9da1e5e2</a>
-<blockquote>
-<p>
- Remove spurious call to gp_validate_path_len()...<br>
-<br>
- ...in gx_device_open_output_file()<br>
-<br>
- There is no need to validate the path in gx_device_open_output_file() as it will<br>
- be done at a lower level (gp_fopen) for paths that require it (we only validate<br>
- *after* the Postscript style %device% paths have been expanded into 'real'<br>
- paths).<br>
-<br>
- This also interacts badly with the revised handling of formatted string<br>
- file names, hence remove it.<br>
-<br>
-base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 17:56: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=ca553d6d3ec0fa1455cf400629e08db90658aa85">ca553d6d3ec0fa1455cf400629e08db90658aa85</a>
-<blockquote>
-<p>
- Fix tiffsep(1) interaction with file permissions lists<br>
-<br>
- The previous solution didn't quite work, when using formatted strings for<br>
- output file names (i.e. output-%d.tif).<br>
-<br>
- This adds a dedicated gs_remove_outputfile_control_path() to mirror<br>
- gs_add_outputfile_control_path() and uses those for the dynamic adding and<br>
- removing of separation output file names.<br>
-<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 17:11:47 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=205e2f529e6da569ec764ebb4aeddc41c66a8860">205e2f529e6da569ec764ebb4aeddc41c66a8860</a>
-<blockquote>
-<p>
- Update path validation to accept multiple *'s as special case.<br>
-<br>
- Previously we interpretted multiple *'s as meaning the same as<br>
- single *'s. Now we use them to mean &quot;just those chars that<br>
- might be created by the use of a %...{d,x,u,i,o,X} format<br>
- specifier&quot;.<br>
-<br>
-base/gpmisc.c<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-23 16:41:09 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd19ec5348723a5c70ff728911f856caa518166b">dd19ec5348723a5c70ff728911f856caa518166b</a>
-<blockquote>
-<p>
- Improve OutputFile handling of %d etc.<br>
-<br>
- Only accept %d (and friends) (as opposed to anything starting with %).<br>
- Only accept legal combinations of flags/widths/precision etc.<br>
- Generate a more conservative wildcard.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-20 12:38:02 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da7486fc4b00eee956200d45fb340dc62c8e3bcb">da7486fc4b00eee956200d45fb340dc62c8e3bcb</a>
-<blockquote>
-<p>
- Slight improvement to &quot;permit-file-***&quot; parameter documentation.<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-20 11:17:53 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0222263e4fe03b29e9eb4141f7866fa8261d416a">0222263e4fe03b29e9eb4141f7866fa8261d416a</a>
-<blockquote>
-<p>
- Fix tiffsep and tiffsep1 with new file access control and SAFER mode<br>
-<br>
- The tiffsep and tiffsep1 synthesize output file names with the outputfile<br>
- and the separation color name, but the 'open' of these filenames would<br>
- fail since they were not included on the permit_file_writing list.<br>
- Add the full filename before opening, and remove the names after closing.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-20 11:53:10 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=41d79063acee7244f5990d2a8e19c567e24051af">41d79063acee7244f5990d2a8e19c567e24051af</a>
-<blockquote>
-<p>
- Squash stupid const warning.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-20 19:42: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=b58f45daa9007f482a49132cbfaa47c8b86ce7d5">b58f45daa9007f482a49132cbfaa47c8b86ce7d5</a>
-<blockquote>
-<p>
- Squash some &quot;const&quot; warnings.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-20 17:49:57 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e7039d7a83a7e35b8b41d59d7fb9a8b4fda7fb0">0e7039d7a83a7e35b8b41d59d7fb9a8b4fda7fb0</a>
-<blockquote>
-<p>
- Fix &quot;permit-file-xxxx&quot; handling.<br>
-<br>
- Ray spotted that gs_add_explicit_control_path was adding 17<br>
- to arg before using it. 17 happens to be the right amount<br>
- to add for &quot;--permit-file-read=&quot;, but the wrong amount for<br>
- write/control/all.<br>
-<br>
- Update the code to call it with the correct arg pointer<br>
- to start with.<br>
-<br>
- Also, update a couple of routines to cope with being called<br>
- with NULL strings.<br>
-<br>
- Also use enum values in switch rather than 0, 1, 2.<br>
-<br>
-base/gslibctx.c<br>
-pcl/pl/plmain.c<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-19 11:02: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=18316aba11fafc57ee77dbd7774b2c88b964a9d9">18316aba11fafc57ee77dbd7774b2c88b964a9d9</a>
-<blockquote>
-<p>
- Make missing jbig2 decoder fatal error.<br>
-<br>
- If we have neither Luratech nor jbig2dec, have configure fail, unless<br>
- explicitly run with --without-jbig2dec<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-18 09:24: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=0557d5d6628279fc526e9d87f05433800ce1b025">0557d5d6628279fc526e9d87f05433800ce1b025</a>
-<blockquote>
-<p>
- Dates etc for 9.28 rc3<br>
-<br>
-base/gscdefs.h<br>
-base/version.mak<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/Internal.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>2019-09-17 11:42: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=2ff44c7c8a09dd1c6b7cd750323ee4087b5cebc5">2ff44c7c8a09dd1c6b7cd750323ee4087b5cebc5</a>
-<blockquote>
-<p>
- Fix file permissions interaction with '@' command line<br>
-<br>
- If an options file (prefixed '@' on the command line) followed something that<br>
- required initialising the Postscript interpreter (such as a '-c' option),<br>
- opening the file would potentially fail because file permissions had been<br>
- activated by the interpreter.<br>
-<br>
- Add and remove the file from the permit reading list before attempting to open<br>
- it.<br>
-<br>
-base/gsargs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-12 14:23: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=3695b7f576c607bd3627e6e28dc982fdf68b1b32">3695b7f576c607bd3627e6e28dc982fdf68b1b32</a>
-<blockquote>
-<p>
- If set, add PCLFONTSOURCE value to permit_file_reading list<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-11 13:07: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=4196e26a9cf3c8afd6c069a789ac649019ae096a">4196e26a9cf3c8afd6c069a789ac649019ae096a</a>
-<blockquote>
-<p>
- Bug 701561: 'reduce' paths before adding to permit lists<br>
-<br>
- Before attempting to open files, we pre-process the requested file name to<br>
- remove surplus/unnecessary elements: i.e. './././file' would be reduced to just<br>
- './file', or '../dir/../dir/../dir/file' would be reduced to '../dir/file'.<br>
-<br>
- The 'reduced' path is what we try to open, hence it is also what we check<br>
- against the file permissions list before we allow files to be accessed.<br>
-<br>
- That being so, we should also 'reduce' paths as we add them to the permissions<br>
- lists - thus the permissions list creation and checking are consistent.<br>
-<br>
-base/gslibctx.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-11 14:10:27 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3d55799ea64088e08fc2783012957035c77a66ca">3d55799ea64088e08fc2783012957035c77a66ca</a>
-<blockquote>
-<p>
- Fix Bug 696333. Allow large bitmaps in clist when writing tile cache.<br>
-<br>
- When writing bits to update the tile cache, we don't need to restrict to<br>
- a single command buffer as with the copy_mono and copy_color commands.<br>
-<br>
- Progressions on:<br>
- tests_private/comparefiles/Bug694385.pdf.psdcmyk.300.1..gs<br>
- tests_private/pdf/sumatra/2028_-_invisible_patterns.pdf.psdcmyk.300.1..gs<br>
- tests_private/ps/ps3cet/09-47B.PS.pdf.pkmraw.300.0..gs_pdf<br>
- tests_private/ps/ps3fts/176-01.ps.psdcmyk.300.1..gs<br>
-<br>
-base/gxclbits.c<br>
-base/gxcldev.h<br>
-base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-12 10:37:42 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1613502f83ddba352cc8e98e7dd3182c9d7732bc">1613502f83ddba352cc8e98e7dd3182c9d7732bc</a>
-<blockquote>
-<p>
- Fix SEGV with flp device and PCL with clist mode and large BandHeight.<br>
-<br>
- If the 'clist_init' fails initially (with rangecheck) due to the buffer<br>
- space too small for the BandHeight specified, we loop in the caller after<br>
- increasing the buffer size, but clist_init left &quot;is_open&quot; false when failing.<br>
- Add save_is_open in gdev_prn_setup_as_command_list so that we can restore it<br>
- if the clist_init eventually suceeds.<br>
-<br>
- The SEGV was with image_data because re-opening the flp device reset the<br>
- &quot;obsolete&quot; procs to the default, so flp_image_data was replaced by the<br>
- gx_default_image_data, but no begin_image had been performed (flp_begin_image<br>
- skipped this since we were not yet at the FirstPage).<br>
-<br>
-base/gdevprn.c<br>
-base/gxclist.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-16 18:53:49 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f2d03f59e04a053c14285d8dbdd869bf9a4435e7">f2d03f59e04a053c14285d8dbdd869bf9a4435e7</a>
-<blockquote>
-<p>
- Update jbig2dec stuff for 0.17 release.<br>
-<br>
-jbig2dec/CHANGES<br>
-jbig2dec/jbig2.h<br>
-jbig2dec/jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-16 18:48:36 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8da8fbaeb6074161bc3a9b22e89265f5942db0d9">8da8fbaeb6074161bc3a9b22e89265f5942db0d9</a>
-<blockquote>
-<p>
- jbig2dec: Use the same contact information everywhere.<br>
-<br>
-jbig2dec/README<br>
-jbig2dec/configure.ac.in<br>
-jbig2dec/jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-16 16:12:32 +0100
-</strong>
-<br>Paul Vojta &lt;vojta@math.berkely.edu&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c6e19334062d12189612b84f53fe393a7808f74">6c6e19334062d12189612b84f53fe393a7808f74</a>
-<blockquote>
-<p>
- Documentation - fix some typos<br>
-<br>
- Bug #701589 &quot;Minor documentation problems in 9.28-rc2&quot;<br>
-<br>
- Thanks to Paul Vojta for pointing these out. Unfortunately we cannot use the<br>
- supplied patch, as it includes alterations to History9.htm, which is auto-<br>
- generated from the commit logs. The remaining changes are applied here.<br>
-<br>
-doc/Language.htm<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-11 12:18: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=90bdf83d696562e4136b8f565cac06cc32b161ae">90bdf83d696562e4136b8f565cac06cc32b161ae</a>
-<blockquote>
-<p>
- Bug 701563: pdfwrite annotation pdfmark /Border key<br>
-<br>
- Despite the spec saying the values for the /Border key are in user space<br>
- coordinates, Distiller appears to pass the values through to the output PDF<br>
- untouched (no rescaling - unlike the values for /Rect, also in user space,<br>
- according to the spec, which it does scale/translate). Ghostscript/pdfwrite<br>
- did scale the /Border values.<br>
-<br>
- This just changes pdfwrite to write the values out unchanged.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-16 09:56: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=a9e997cb97a274bebfc028e8831a43d6f66be0f9">a9e997cb97a274bebfc028e8831a43d6f66be0f9</a>
-<blockquote>
-<p>
- Documentation - add a note about SAFER for PDF/X ICC profiles<br>
-<br>
- Bug #701553 &quot;Examples of PDF/X and PDF/A conversion should be updated for Ghostscript 9.28&quot;<br>
-<br>
- ICC profiles required for PDF/X and PDF/A output need to be readable<br>
- in order to work when -dSAFER is true (the new default). This wasn't<br>
- clear from the documentation, so add a note about it.<br>
-<br>
- As noted in the bug report, it is possible to embed the profile in the<br>
- PostScript code, but as Chris says this is probably beyond reasonable<br>
- expectations of the average user; they simply won't change the example<br>
- and will then complain that it isn't correct. Users capable of making<br>
- this work almost certainly have enough knowledge to realise they can<br>
- do this instead of making the profile readable.<br>
-<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-12 19:41:47 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cea41505580dfe55234bd4972fbb09af5e2e6bb8">cea41505580dfe55234bd4972fbb09af5e2e6bb8</a>
-<blockquote>
-<p>
- Fix various printer devices to properly call spec ops.<br>
-<br>
- Various printer devices (psd, psdcmykog, tiffsep, tiffscaled)<br>
- were passing the spec ops on to gx_default_dev_spec_op rather<br>
- than gdev_prn_dev_spec_op.<br>
-<br>
- The most obvious implication of this was that we'd sometimes<br>
- get a warning about printer devices having a private spec op.<br>
-<br>
-devices/gdevcmykog.c<br>
-devices/gdevpsd.c<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-12 17:09:50 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=89f3d6001728678755aca8c5a02e57bba72a0813">89f3d6001728678755aca8c5a02e57bba72a0813</a>
-<blockquote>
-<p>
- Bug 701568 followup: Fix RLE compressor.<br>
-<br>
- The previous fix to the RLE compressor reveals an additional<br>
- existing issue to do with us not checking whether we have<br>
- space in the buffer to write the EOD byte.<br>
-<br>
- Fixed here.<br>
-<br>
-base/srle.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-12 09:35: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=f394c0722d3415ba03f57dc32dcd8484d3173b62">f394c0722d3415ba03f57dc32dcd8484d3173b62</a>
-<blockquote>
-<p>
- Bug 701568: Fix gdevpx.c RLE stream handling.<br>
-<br>
- The current code in pclxl_write_image_data_RLE passes<br>
- lines of data to the RLE compression routine. It tells<br>
- each invocation of that routine that this is the &quot;last&quot;<br>
- block of data, when clearly it is not.<br>
-<br>
- Accordingly, the compression routine inserts the &quot;EOD&quot; byte<br>
- into the stream, and returns EOFC.<br>
-<br>
- Independently of the return value used, having multiple EOD<br>
- bytes in the data is clearly wrong. Update the caller to only<br>
- pass &quot;last&quot; in for the last block.<br>
-<br>
- The code still returns EOFC at the end of the data, so update<br>
- this final call to accept (indeed, expect) that return value<br>
- there.<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-10 09:04: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=6cd0b941d86fe54b7e818e563dc702a147bab95a">6cd0b941d86fe54b7e818e563dc702a147bab95a</a>
-<blockquote>
-<p>
- Fix bug 701550, problem with forall on strings.<br>
-<br>
- Hard to believe, but this problem has existed since at least version 3.33.<br>
- The 'string_continue' function altered the size which was used to decide if<br>
- there were still characters to be processed BEFORE invoking the 'push(#)' macro.<br>
- If the 'push(1)' encountered a full stack segment, it would return stackoverflow<br>
- so that the operand stack could be extended. This meant that the decision to<br>
- stop enumerating the string would end early (depending on how many times the<br>
- stackoverflow occurred).<br>
-<br>
- Usually the procedure of the forall would either consume the character (reducing<br>
- the stack), or add an element to the stack triggering the stack extension before<br>
- the next execution of string_continue, but -c &quot;401 string { dup } forall count =&quot;<br>
- results in only 800 stack elements (rather than 802 as expected).<br>
-<br>
-psi/zgeneric.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-15 15:54: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=e62f684be3d80bb5599a669ddca3ee1b544100d8">e62f684be3d80bb5599a669ddca3ee1b544100d8</a>
-<blockquote>
-<p>
- Doc updates, changelog, news etc<br>
-<br>
- Update to note explicitly case sensitivity on Windsows<br>
-<br>
- In News.htm and History9.htm<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-05 09:09: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=cc86598152465c85dfca5ba265608931672f730f">cc86598152465c85dfca5ba265608931672f730f</a>
-<blockquote>
-<p>
- Date for 9.28 rc2<br>
-<br>
-base/gscdefs.h<br>
-base/version.mak<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/Internal.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-10-31 20:22:11 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=350a5cd8b7bddee3fa914c914dd40a685fed54e7">350a5cd8b7bddee3fa914c914dd40a685fed54e7</a>
-<blockquote>
-<p>
- Bug 700088: Report error if all wanted J2K components are not decoded.<br>
-<br>
- Ghostscript used to attempt to use even the undecoded components.<br>
- The source code for upstream's opj_decompress tool avoided this by<br>
- a workaround along with a comment indicating that this ought to be<br>
- done in the library (so all clients, e.g. Ghostscript will benefit<br>
- from it). With this commit the library will error out if not all<br>
- requested components are successfully decoded. Thus Ghostscript<br>
- will no longer crash.<br>
-<br>
- Reported in https://github.com/uclouvain/openjpeg/issues/1158<br>
- sent upstream in https://github.com/uclouvain/openjpeg/pull/1164<br>
- and finally committed in e66125fe260deee49fdf6e9978d9bd29871dd5bb<br>
-<br>
-openjpeg/src/bin/jp2/opj_decompress.c<br>
-openjpeg/src/lib/openjp2/j2k.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-03 12:34:55 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b944e875baed62e718eee8e7ad2b351cd4f4aa07">b944e875baed62e718eee8e7ad2b351cd4f4aa07</a>
-<blockquote>
-<p>
- Undo commit 95f7befcec1b30fd5014c8ad616485d32901ce33 for release<br>
-<br>
- Proper handling of the page group color space is going to require<br>
- a more complex solution whereby we ensure that we do the final<br>
- alpha blending in the page group color space and not the target<br>
- device color space.<br>
-<br>
-base/gstrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-03 08:52:16 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ebfe16357f3484209e69d6788cc52b20dbdb81a0">ebfe16357f3484209e69d6788cc52b20dbdb81a0</a>
-<blockquote>
-<p>
- Add -sBlendColorProfile into Use.htm<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-03 18:15:56 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bbdfaa56b00f2ba556476f0265e65e4ad370f641">bbdfaa56b00f2ba556476f0265e65e4ad370f641</a>
-<blockquote>
-<p>
- Avoid potential UMR with arg checking in arg sanitization code.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-02 17:16:45 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=00d4696ea2de6c48a57d5a4ce0c3bbfd99201e3a">00d4696ea2de6c48a57d5a4ce0c3bbfd99201e3a</a>
-<blockquote>
-<p>
- Proper fix for deep color overprint.<br>
-<br>
- The previous fix confused memset and memcpy. Properly write the<br>
- (native endian) 16 bit color values into the big endian buffer.<br>
-<br>
-base/gsovrc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-09-02 12:59:33 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6d448b3fe616fdc2ba1e52766c9a4417e4e738f">c6d448b3fe616fdc2ba1e52766c9a4417e4e738f</a>
-<blockquote>
-<p>
- Fix deep color mattes.<br>
-<br>
- As seen with the content vanishing when rendering<br>
- tests_private/pdf/sumatra/uninitialized_value_with_JPX_images.pdf<br>
- to psdcmyk16. The Softmask on the image has a Matte of [1,1,1]<br>
- and the calculations in the current code overflow, meaning that<br>
- it comes out as completely white.<br>
-<br>
- We resort to 64bit to avoid the overflow. Mattes are vanishingly<br>
- rare, so speed shouldn't be an issue. We can revisit if we ever<br>
- find a case that matters.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-31 12:45:47 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4c1f255c2e825ab5e0a3d0f7bfa88538c7cbb912">4c1f255c2e825ab5e0a3d0f7bfa88538c7cbb912</a>
-<blockquote>
-<p>
- Update overprint hl_color code to cope with 16bit devices too.<br>
-<br>
-base/gsovrc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-31 12:16:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=373787ee145e906c8d19d5ccda84b4f267db2010">373787ee145e906c8d19d5ccda84b4f267db2010</a>
-<blockquote>
-<p>
- Fix deep color transparency overprint.<br>
-<br>
- The component copy loop at the end of the blend could fail to copy<br>
- enough entries.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-30 15:16:34 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=361c4dd1e18ca0675173c0ad0104ffb910e93bb4">361c4dd1e18ca0675173c0ad0104ffb910e93bb4</a>
-<blockquote>
-<p>
- Avoid overflow in deep color luminosity calculations.<br>
-<br>
- Resort to 64bit as scale calculations are not constrained<br>
- to the usual 16bit range.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-29 10:02: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=51d57fafbdc021c8c73475db505156f77e96ce39">51d57fafbdc021c8c73475db505156f77e96ce39</a>
-<blockquote>
-<p>
- Fix clearing of the drag and drop file list<br>
-<br>
- Because we have to store the list of file names from drag and drop events, in<br>
- order to correctly add and remove them from the permit file read list, we also<br>
- want to clear the lists before we destroy the &quot;text&quot; window object.<br>
-<br>
- The problem is, this happens after we shutdown Ghostscript and unload the dll.<br>
-<br>
- This moves that clearing of the list into function that we call before we<br>
- shut down.<br>
-<br>
-psi/dwmain.c<br>
-psi/dwtext.c<br>
-psi/dwtext.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-28 10:14: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=ad0532e379a9eb6eb8a6fc0a6305679b25cd9ecb">ad0532e379a9eb6eb8a6fc0a6305679b25cd9ecb</a>
-<blockquote>
-<p>
- Fix path permissions added from cidfmap.<br>
-<br>
- From the cidfmap, we accumulate a list of unique directory paths a we process<br>
- cidfmap and then add them - when I did that code, I forgot that to allow access<br>
- to the directory, we need a trailing directory separator.<br>
-<br>
- Add that before calling .addcontrolpath<br>
-<br>
-Resource/Init/gs_cidfm.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 16:49: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=f0fedf1f77a9fe70627355b45fdb809e83df3568">f0fedf1f77a9fe70627355b45fdb809e83df3568</a>
-<blockquote>
-<p>
- Fix font file finding with -P<br>
-<br>
- In trying to reproduce the issue that inspired commit dea69cd04964, I noticed<br>
- that font file searching wasn't working correctly with -P specified on the<br>
- command line.<br>
-<br>
- Previously, it could just end up with us not finding a font we should have, but<br>
- with dea69cd04964 it would result in a typecheck error.<br>
-<br>
- This ensures the stack is always how it should be after the findlibfile<br>
- call<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-22 16:10:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5c28996d19d5e10cb177e72c47037ec0c7b3e4d5">5c28996d19d5e10cb177e72c47037ec0c7b3e4d5</a>
-<blockquote>
-<p>
- Make it clear: file/path matching is always case sensitive<br>
-<br>
- even on Windows.<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-29 19:50:08 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=24532ce9371fd1f69dd343cbd6ac8187a86c5c96">24532ce9371fd1f69dd343cbd6ac8187a86c5c96</a>
-<blockquote>
-<p>
- Fix overflow in 16bit blending calculations.<br>
-<br>
- The blending code uses the following construction in<br>
- several places:<br>
-<br>
- src_scale = ...; /* a value between 0 and 0x10000 */<br>
- tmp = (y-z) * src_scale + 0x8000;<br>
- foo = x + (tmp&gt;&gt;16);<br>
-<br>
- Where x,y,z, are all expected to be in the 0...0xffff range.<br>
-<br>
- Due to y-z having a sign bit, this can overflow a 32 bit tmp.<br>
-<br>
- We therefore sacrifice a bit of accuracy in src_scale to get<br>
- correctness.<br>
-<br>
-base/gxblend.c<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-28 14:13:27 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ca52028b90a09d056190548c41ae0b9a9fbadb4e">ca52028b90a09d056190548c41ae0b9a9fbadb4e</a>
-<blockquote>
-<p>
- Remove outdated FIXME's.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-28 12:50: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=bd59dc145252282d8f586c36082e63a0eba95c15">bd59dc145252282d8f586c36082e63a0eba95c15</a>
-<blockquote>
-<p>
- Bug 701446: Avoid divide by zero in shading.<br>
-<br>
- The previous commit for this bug was enough to solve the problem<br>
- for ppmraw, but not, it seems, for other devices. This addresses<br>
- the division by zero more directly.<br>
-<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 20:13:02 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a32a379933f4ba27ff1ad5734ec8c24c42eb513">9a32a379933f4ba27ff1ad5734ec8c24c42eb513</a>
-<blockquote>
-<p>
- Fix deep color transparency saturation blending.<br>
-<br>
- Problem seen with:<br>
-<br>
- tests_private/pdf/PDF_1.7_FTS/fts_25_2513.pdf.psdcmyk16.300.1<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 17:45:57 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=68af4dbc7ca2d6bfdbe938b840799cb8883c973e">68af4dbc7ca2d6bfdbe938b840799cb8883c973e</a>
-<blockquote>
-<p>
- Bug 701446: Avoid division by zero in gx_shade_trapezoid<br>
-<br>
- Remove some incorrect clipping code.<br>
-<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 15:54: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=4be058791ae19131f19a8303364be53619abc280">4be058791ae19131f19a8303364be53619abc280</a>
-<blockquote>
-<p>
- Exit early from gx_shade_trapezoid in more cases.<br>
-<br>
- A zero height trap isn't plotted, so we can bail out early in<br>
- that case.<br>
-<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-26 17:02: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=9423e84178071f16b83d18412b22b0b479b1938b">9423e84178071f16b83d18412b22b0b479b1938b</a>
-<blockquote>
-<p>
- Fix deep colour transparency &quot;uncompositing&quot;.<br>
-<br>
- Uncompositing a group uses a scale factor that is greater in range<br>
- than we'd like; we need to resort to 64bit to do this to avoid<br>
- losing accuracy.<br>
-<br>
- This solves problems seen in:<br>
-<br>
- tests_private/comparefiles/Bug689918.pdf.psdcmyk16.300.1<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 14:26: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=131768114453972469296658b795406b79630538">131768114453972469296658b795406b79630538</a>
-<blockquote>
-<p>
- Handle relative FONTPATH values<br>
-<br>
- Prior to 9.21 (specifically: 8abd22010eb4db0fb1b10e430d5f5d83e015ef70), relative<br>
- paths for FONTPATH worked, but did so due to a logic fault with how we search<br>
- for &quot;lib&quot; files.<br>
-<br>
- When attempting to open file names specified on the command line, we used a<br>
- flag set in the command line handling (starting_arg_file) to know whether the<br>
- lib file searching logic should try to open the file name directly (as well as<br>
- trying the file combined with each path in the search path).<br>
-<br>
- In versions prior to commit 8abd22010eb4 that flag (starting_arg_file) could<br>
- remain set to true, even after the command line file(s) had been opened. This<br>
- represented a (minor) security risk. Commit 8abd22010eb4 ensured the flag was<br>
- properly (re)set, and that caused relative paths for FONTPATH stopped working.<br>
-<br>
- Rather than reintroduce the security risk, update the code that checks whether<br>
- the font files exist so it explicitly tries the file name directly, rather than<br>
- assuming .libfile (or findlibfile, in this case) does that automatically.<br>
-<br>
- Also remove an extraneous (but benign) dup of the font name.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 15:27: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=98310063bdbe8c67bcfe84e2c648cfa286a05738">98310063bdbe8c67bcfe84e2c648cfa286a05738</a>
-<blockquote>
-<p>
- pdfwrite - fix corner case with Color Conversion<br>
-<br>
- Bug #701456 &quot;Ghostscript creates broken PDF file after color conversion&quot;<br>
-<br>
- The test file is, essentially weird. The image on page 3 is not a single<br>
- image, its a series of images, all of which are in a /Indexed /DeviceRGB<br>
- colour space.<br>
-<br>
- In addition, these images are drawn on *top* of another set of images<br>
- (thereby completely obscuring them). These images are also drawn in<br>
- /Indexed /DeviceRGB. However, these images are in fact monochrome, the<br>
- Indexed space consists of 2 colours. This means that (highly unusually)<br>
- we have a DeviceRGB image with 1 Bit Per Component.<br>
-<br>
- This caused problems for the pdfwrite compression filter chooser because<br>
- it chose (and configured) a compression scheme suitable for 1 BPC data<br>
- and then actually output 8 BPC data. This led to the compression filter<br>
- writing too little data.<br>
-<br>
- Fix this here by setting the BPC to 8 if we are doing colour conversion,<br>
- and have the colour conversion setup code use the original value in the<br>
- image enumerator (the conversion code *does* need to know the input is<br>
- 1 BPC).<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-27 11:36: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=aee3b922087674ddd7c64444988018fafc3da127">aee3b922087674ddd7c64444988018fafc3da127</a>
-<blockquote>
-<p>
- PDF interpreter - more /Mask strangeness in Acrobat<br>
-<br>
- Bug #701468 &quot; More weirdness with images containing invalid /Mask values&quot;<br>
-<br>
- In order to render this file as per Acrobat, we need to ignore the /Mask<br>
- array. However, in order to render bug 689717 correctly we need to fix<br>
- the /Mask array.<br>
-<br>
- Both cases are 1 BitsPerComponent DeviceGray images, the only difference<br>
- is the actual /Mask values. Bug 689717 has [255 255] while 701468 has<br>
- [243 255]. We can differentiate based on whether we have DeviceGray<br>
- 1 BPC image, where the Mask values are not the same. In the case they<br>
- are different we use the existing technique of calculating the maximum<br>
- value and using that (for both, so there is no range). Where there is a<br>
- range (ie not a single colour) this is clearly unusable in a 2-colour<br>
- image, so ignore the /Mask altogether.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-26 15:28:33 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad22dcaa078fd16f2ac395f65b6ad87ba24c8903">ad22dcaa078fd16f2ac395f65b6ad87ba24c8903</a>
-<blockquote>
-<p>
- Fix deep colour knockout logic.<br>
-<br>
- Problem seen with:<br>
-<br>
- tests_private/pdf/PDF_1.7_FTS/fts_25_2507.pdf.psdcmyk16.72.0<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-26 14:34:46 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4cda7bfc8cc8c5c4dcd36167191012aa379100ac">4cda7bfc8cc8c5c4dcd36167191012aa379100ac</a>
-<blockquote>
-<p>
- Squash a couple of warnings.<br>
-<br>
-base/gdevmem.c<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-26 14:01:39 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b5166b5c65703abb02c15a31c9f8341f54d1470">7b5166b5c65703abb02c15a31c9f8341f54d1470</a>
-<blockquote>
-<p>
- Fix SoftLight blending in deep color transparency.<br>
-<br>
- As seen with:<br>
-<br>
- gs -sDEVICE=psdcmyk16 -r72 -dMaxBitmap=80000000 -o out.psd<br>
- tests_private/pdf/PDF_1.7_FTS/fts_09_0919.pdf<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-26 11:28:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5875be5edeb034787a11760c9330cac039f13044">5875be5edeb034787a11760c9330cac039f13044</a>
-<blockquote>
-<p>
- Fix problems with pngalpha and deep color transparency filling.<br>
-<br>
- The pngalpha device is created with a depth of 32, with 3 color<br>
- components; this was confusing pdf14 into thinking that more<br>
- than 8 bits per color were being used, and so deep color buffers<br>
- were required.<br>
-<br>
- To fix this we update the logic to be smarter; in cases where we<br>
- don't have a clear determination based on bits alone, we look<br>
- at the max_color and max_gray values. Because this code is now<br>
- more complex than before, we pull it into a shared function.<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevmem.c<br>
-base/gdevp14.c<br>
-base/gdevprn.c<br>
-base/gsptype1.c<br>
-base/gstrans.c<br>
-base/gxclthrd.c<br>
-base/gxdevcli.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-23 15:06: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=6e7283fa5bcea9ffbe4bb9da440dd8fa4820e4d6">6e7283fa5bcea9ffbe4bb9da440dd8fa4820e4d6</a>
-<blockquote>
-<p>
- Fix deep color transparency issue.<br>
-<br>
- Fix overflow in art_pdf_composite_knockout_16, seen in:<br>
-<br>
- tests_private/comparefiles/Bug690546.pdf.psdcmyk16.72.0<br>
-<br>
-base/gdevp14.c<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-22 18:24:49 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=628c9741323ea69b0be8e4008a81b1db3d644ab8">628c9741323ea69b0be8e4008a81b1db3d644ab8</a>
-<blockquote>
-<p>
- Fix deep color transparent pattern problems.<br>
-<br>
- Transparency buffers are held as native endian. Pattern cache<br>
- tiles are held as big endian. When we make pattern cache tiles<br>
- from transparency buffers we therefore need a conversion.<br>
-<br>
-base/gdevp14.c<br>
-base/gxblend.c<br>
-base/gxp1fill.c<br>
-base/gxpcolor.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-25 19:35:14 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be4da9d67cbec784be740086681f96a63496ae48">be4da9d67cbec784be740086681f96a63496ae48</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Do not output LUTs with CUPS_DEBUG set<br>
-<br>
- This change lets complete LUTs in the debug output only be listed when<br>
- CUPS_DEBUG2 is set and not already with CUPS_DEBUG.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-25 19:08:52 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e28c843e56d1be4638bf9d84a499794534ea0d9">0e28c843e56d1be4638bf9d84a499794534ea0d9</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Prefer the page size requested by user<br>
-<br>
- Without special scaling/cropping options (&quot;fit-to-page&quot;, &quot;fill&quot;,<br>
- &quot;crop-to-fit΅, ...) PDF and PostScript files printed with CUPS will be<br>
- printed with the page sizes of the document's pages and not the size<br>
- requested by the user via the &quot;PageSize&quot; or &quot;media&quot; option. This<br>
- allows correct printing of jobs with differently sized pages on<br>
- printers which have the appropriate sizes loaded without need of<br>
- manual intervention. Therefore the CUPS output device is matching each<br>
- input page against the sizes listed in the PPD to generate a correct<br>
- page geometry for the printer for each page.<br>
-<br>
- Problem is if there are several equally-sized page size entries in the<br>
- PPD. Without further guiding always the first match is used, making<br>
- access to special functions provided by the others (like<br>
- full-bleed/borderless printing) inaccessible.<br>
-<br>
- This commit adds the functionality of the user-requested page size<br>
- (via &quot;PageSize&quot; or &quot;media&quot; option) being preferred under the matching<br>
- page sizes, so that if for example a user selects a full-bleed version<br>
- of the desired page size and sends a photo, the photo gets rendered<br>
- and printed with the page geometry which the PPD reports for the<br>
- full-bleed version.<br>
-<br>
- Nothing changes if the size of the user-requested page size does not<br>
- match the size of the input page at all.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-25 12:45:27 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a5ccd009fd632e058b4f0bc2849cfc293b39d1f2">a5ccd009fd632e058b4f0bc2849cfc293b39d1f2</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Small fix on size matching improvements<br>
-<br>
- This is a fix for one little oversight on the changes to support matching<br>
- the input page size against the imageable areas of the PPD's page sizes.<br>
-<br>
- This completes the fix of bug 701438.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-24 23:11:10 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a0284b5ac8c59014eab90c5a5ec388cd1676b79d">a0284b5ac8c59014eab90c5a5ec388cd1676b79d</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Improved page size matching with PPD<br>
-<br>
- Applied the following improvements for finding the correct page size<br>
- of the PPD file for the input page:<br>
-<br>
- - Do not try to match by page size name, the input files do not<br>
- contain page size names.<br>
-<br>
- - Do not only match the input page size against the actual media sizes<br>
- reported by the PPD but also to the imageable areas. Media size match<br>
- is preferred but if there is no media size match, we accept also<br>
- a match of the imageable area. In case of a match of the imageable<br>
- area we position the input page in the imageable area of the output<br>
- page.<br>
-<br>
- - More debug output.<br>
-<br>
- - In case of a custom page size (no match with PPD sizes) the page<br>
- size name in the CUPS Raster output is a correct &quot;Custom.XXXxYYY&quot;<br>
- and not the default page size name.<br>
-<br>
- This should fix bug #701438.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-23 18:09:32 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ee43ff891b51f0ccec3ba38d538d3e23441ed439">ee43ff891b51f0ccec3ba38d538d3e23441ed439</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Reduced page size comparison tolerances<br>
-<br>
- Before each page gets rendered its size is compared to the page sizes<br>
- of the PPD file to select the actual page size for the output. Reduced<br>
- the tolerances from 7% for the long edge and 5% for the short edge to<br>
- 1%, as before easily wrong sizes got picked (See also bug 701438).<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-23 10:11: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=0311b61d5df67cd98e2c2d23ef3cec1cc4faa800">0311b61d5df67cd98e2c2d23ef3cec1cc4faa800</a>
-<blockquote>
-<p>
- Windows Installer: cope with COMPILE_INITS=0<br>
-<br>
- We default to COMPILE_INITS=1, and that was the only case that the installer<br>
- handled - i.e. building the installer with COMPILE_INITS=0 would install an<br>
- executable that wouldn't work without extra action (-I.. or similar).<br>
-<br>
- This changes the installer compiler invocation, and the installer creation<br>
- so it behaves as it does now with COMPILE_INITS=1, but with COMPILE_INITS=0 the<br>
- installer will write the path to Resource/Init into the GS_LIB registry<br>
- key.<br>
-<br>
-psi/nsisinst.nsi<br>
-psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-22 23:30:34 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=137a0bda39f861600488b5a11c63914854c454c8">137a0bda39f861600488b5a11c63914854c454c8</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output device: Produce more debug output<br>
-<br>
- When building with CUPS_DEBUG now debug output for the process of<br>
- matching the page geometry with the PPD file's page sizes is<br>
- produced.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-22 08:58:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=09b53ebdc674f9f6e7a9c445e92617312dd93ab3">09b53ebdc674f9f6e7a9c445e92617312dd93ab3</a>
-<blockquote>
-<p>
- Handle explicit '\' escaping in path matching<br>
-<br>
- As well as having to cope with both '/' and '\' as directory separators on<br>
- Windows, it turns out we also need to cope with the backslash separator being<br>
- explicitly escaped (&quot;\\&quot;) - the explicit is added by the Postcript path<br>
- templating code in gs_init.ps.<br>
-<br>
- I don't want to change templating code because that would likely have<br>
- implications in a lot of other places.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-22 10:51: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=f1692a288f1a17930f0b71e540908398a17d5366">f1692a288f1a17930f0b71e540908398a17d5366</a>
-<blockquote>
-<p>
- Better CMYK conversion for bmpcmp<br>
-<br>
-toolbin/bmpcmp.c<br>
-toolbin/bmpcmptab.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-21 17:49:32 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c8aaf3b7bc4232997d434170827fffd6887fc88f">c8aaf3b7bc4232997d434170827fffd6887fc88f</a>
-<blockquote>
-<p>
- Update bmpcmp.c to read psdrgb rather than psdbgr.<br>
-<br>
-toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-21 15:33: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=9ba1827e220cd49a6732c04fcf3e55a268014377">9ba1827e220cd49a6732c04fcf3e55a268014377</a>
-<blockquote>
-<p>
- Fix commit ec0b35fed3de: &quot;Handle directory separators...&quot;<br>
-<br>
- The logic in the above fix was wrong.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-21 14:28:20 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d0206d2b118b26f6d87ba8f09d077eba417e4c9">7d0206d2b118b26f6d87ba8f09d077eba417e4c9</a>
-<blockquote>
-<p>
- Bug 701451: Fix clist color_usage calculations for shadings.<br>
-<br>
- Or rather, don't attempt to calculate them badly, and just<br>
- use the safe &quot;all colors&quot; value.<br>
-<br>
-base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-21 10:10:51 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=320ec9672b987a765324f89450de08b70aafbcd3">320ec9672b987a765324f89450de08b70aafbcd3</a>
-<blockquote>
-<p>
- PDF interpreter - review .forceput security<br>
-<br>
- Bug #701450 &quot;Safer Mode Bypass by .forceput Exposure in .pdfexectoken&quot;<br>
-<br>
- By abusing the error handler it was possible to get the PDFDEBUG portion<br>
- of .pdfexectoken, which uses .forceput left readable.<br>
-<br>
- Add an executeonly appropriately to make sure that clause isn't readable<br>
- no mstter what.<br>
-<br>
- Review all the uses of .forceput searching for similar cases, add<br>
- executeonly as required to secure those. All cases in the PostScript<br>
- support files seem to be covered already.<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>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-21 10:56: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=e5660f15f5fd4615254acec7ed403b4a7984cb09">e5660f15f5fd4615254acec7ed403b4a7984cb09</a>
-<blockquote>
-<p>
- Handle directory separators in access control matching<br>
-<br>
- On Windows, we end up dealing with a mishmash of &quot;/&quot; and &quot;\&quot; as directory<br>
- separators, so a simple equality check isn't sufficient.<br>
-<br>
- Since there is already (platform specific) function for checking whether a<br>
- string (or part thereof) is a directory separation, use it.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 21:50:18 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=596e9baa1b24b0a9dac4d8bad1ea80cd23dcab79">596e9baa1b24b0a9dac4d8bad1ea80cd23dcab79</a>
-<blockquote>
-<p>
- Disable use of alternate tint transform ICC profile<br>
-<br>
- A prior commit introduced the use of color management<br>
- if the DeviceN or Separation device had an ICC profile<br>
- associated with the colorants. While there is an argument<br>
- for doing this, it is not the standard behavior seen in<br>
- AR. Disabling for now and will likely turn this into a<br>
- command line option.<br>
-<br>
-base/gxcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 18:48:49 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7547a2fc593e3a0bb8ea72f661389cd908c382f7">7547a2fc593e3a0bb8ea72f661389cd908c382f7</a>
-<blockquote>
-<p>
- Fix crashes in RAW_DUMP debug code.<br>
-<br>
- Dump the buffer before freeing the device, or the pointer will no<br>
- longer be valid.<br>
-<br>
- Also, don't access through ppatdev14 when we know it's NULL.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 18:47:09 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=421727ed068b3f41fdbd9657d759397610fe8821">421727ed068b3f41fdbd9657d759397610fe8821</a>
-<blockquote>
-<p>
- Fix deep color transparency pattern copying problem.<br>
-<br>
- The following test:<br>
-<br>
- tests/pdf/pattrans_solid_nonrect.pdf.psdcmyk16.300.1..gs<br>
-<br>
- among others, was showing problems, due to us treating the offset<br>
- as bytes rather than shorts.<br>
-<br>
-base/gxp1fill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 14:29:33 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f9052f1debff2168d5a2606fa35bcaaf6f6f2ec7">f9052f1debff2168d5a2606fa35bcaaf6f6f2ec7</a>
-<blockquote>
-<p>
- Avoid signed overflow in deep transparency calculations.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 12:24: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=898c9e5f06bb44ec3fd262b47eeaa5028e18773f">898c9e5f06bb44ec3fd262b47eeaa5028e18773f</a>
-<blockquote>
-<p>
- Fix overflow in deep color blending.<br>
-<br>
- Multiplying a 16bit unsigned value with a 16 bit signed value<br>
- in a 32bit int means we lose the sign bit. Sacrifice a bit of<br>
- accuracy to avoid that.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-20 10:10: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=85c9d6de80ba57deeee289238aa1c0202f584c3c">85c9d6de80ba57deeee289238aa1c0202f584c3c</a>
-<blockquote>
-<p>
- make .forceput inaccessible<br>
-<br>
- Bug #701343, #701344, #701345<br>
-<br>
- More defensive programming. We don't want people to access .forecput<br>
- even though it is no longer sufficient to bypass SAFER. The exploit<br>
- in #701343 didn't work anyway because of earlier work to stop the error<br>
- handler being used, but nevertheless, prevent access to .forceput from<br>
- .setuserparams2.<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_pdfwr.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-19 10:03:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3ba6d871c70398cfbd15b619127bf13ddea13282">3ba6d871c70398cfbd15b619127bf13ddea13282</a>
-<blockquote>
-<p>
- Handle drag'n'drop file name/paths<br>
-<br>
- Because we now run by default with the file access permission active,<br>
- we need to do additional work for Windows drag and drop files, so they don't<br>
- throw an invalidaccess error (since we implement drag and drop by sending<br>
- characters to the gs console to do '(file) run').<br>
-<br>
- The problem is, we cannot add the file to read list, send the characters to the<br>
- console, and remove the file from the read list because, although SendMessage()<br>
- blocks until the message is handles, WriteConsoleInput() does not block until<br>
- the console buffers are consumed (i.e. it is asynchronous). So, there is no<br>
- certainty when the final SendMessage() in WM_DROPFILES case is finished that<br>
- Ghostcript will actually have run the file.<br>
-<br>
- So, we create a list of dropped file names, add them to the permit read list,<br>
- when the next WM_DROPFILES event happens, or a WM_DESTROY event, we drop<br>
- file names from the permit read list before, if necessary, adding the current<br>
- ones.<br>
-<br>
-psi/dwimg.c<br>
-psi/dwmain.c<br>
-psi/dwmainc.c<br>
-psi/dwtext.c<br>
-psi/dwtext.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-16 15:43:32 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d2e36e8ef01546aaee0cd0531fbc0fa932b23b99">d2e36e8ef01546aaee0cd0531fbc0fa932b23b99</a>
-<blockquote>
-<p>
- Squash warnings in claptrap.<br>
-<br>
- Thanks to William Bader for highlighting these.<br>
-<br>
-base/claptrap-planar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-16 15:28:49 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e34d5606835fc587e222b80bf9cac1bc40c4790b">e34d5606835fc587e222b80bf9cac1bc40c4790b</a>
-<blockquote>
-<p>
- Squash warning in gdevpsd.c<br>
-<br>
- Thanks to William Bader for spotting this.<br>
-<br>
-devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-16 13:08:14 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f416b415e8e3a25446b66bf1a6253f86be0366de">f416b415e8e3a25446b66bf1a6253f86be0366de</a>
-<blockquote>
-<p>
- Squash some compiler warnings.<br>
-<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-devices/gdevpdfimg.c<br>
-devices/vector/gdevpdfu.c<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-15 11:39: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=9ead927968ff8104e1a81df1590fced74927639d">9ead927968ff8104e1a81df1590fced74927639d</a>
-<blockquote>
-<p>
- Dates and versions for 9.28 RC 1<br>
-<br>
-base/gscdefs.h<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/Internal.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>2019-08-15 11:35: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=ae7dea2b9bd068f61b6aef312a7f4cbc9860cac3">ae7dea2b9bd068f61b6aef312a7f4cbc9860cac3</a>
-<blockquote>
-<p>
- Revision date<br>
-<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-15 17:06: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=2f8e2423c860e89b325675dc1311819179740c76">2f8e2423c860e89b325675dc1311819179740c76</a>
-<blockquote>
-<p>
- Add -dNOSAFER for Windows installer cidfmap creation<br>
-<br>
-psi/nsisinst.nsi<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-15 14:36: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=226fb24dbe4f844b8c7531be3eccc2bfae1a103d">226fb24dbe4f844b8c7531be3eccc2bfae1a103d</a>
-<blockquote>
-<p>
- ps2write - don't password encrypt PostScript output!<br>
-<br>
- Noticed while testing the args commit; if we set -sOwnerPassword (to<br>
- create a password-protected PDF file), but select (e)ps2write as the<br>
- device, then the resulting PostScript file would have all the streams<br>
- (in a PDF sense) encrypted with PDF password encryption.<br>
-<br>
- Unsurprisingly, this result in a completely unusable PostScript file.<br>
- Lets not permit that....<br>
-<br>
-devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-13 14:43: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=fd14a8e3701a7f75d758a1e536bcafbddeb70289">fd14a8e3701a7f75d758a1e536bcafbddeb70289</a>
-<blockquote>
-<p>
- Document the new SAFER/file access controls<br>
-<br>
- The documentation for the old SAFER remains in place (noted as deprecated) until<br>
- we actually remove it. Document accessing the old SAFER functionality<br>
- (-dOLDSAFER).<br>
-<br>
- Generally, tidy up the HTML/formatting of the parameter and operator lists<br>
- in Use.htm and Language.htm - mainly making indenting even and consistent.<br>
-<br>
- List .setpdfwrite as deprecated<br>
-<br>
- Include setting the target of the first parameter of gsapi_new_instance() to<br>
- NULL before calling it, and fix the examples in API.htm<br>
-<br>
-doc/API.htm<br>
-doc/Language.htm<br>
-doc/Use.htm<br>
-doc/VectorDevices.htm<br>
-doc/style.css<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-13 14:40: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=79a06b45e784e6839b2b2129cd2620ea606254e1">79a06b45e784e6839b2b2129cd2620ea606254e1</a>
-<blockquote>
-<p>
- Enable new 'SAFER' protection by default.<br>
-<br>
- We'll now run by default with file access controls enabled. SAFER (and<br>
- .setsafe) now *only* enables file access controls. The old SAFER functionality<br>
- is (temporarily) available by specifying &quot;-dSAFER -dOLDSAFER&quot; on the command<br>
- line, or &quot;-dOLDSAFER&quot; before the call to .setsafe.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-13 08:28:06 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9883f2a931407503778bb94948b47480eff858b2">9883f2a931407503778bb94948b47480eff858b2</a>
-<blockquote>
-<p>
- Add null file to the permit writing list<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-12 12:21: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=7abf720f46dd9ff6018b7f29141ba0573016d59d">7abf720f46dd9ff6018b7f29141ba0573016d59d</a>
-<blockquote>
-<p>
- Use enum values for shutting down the file access lists<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-09 14:43: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=d86ecec686d77e69f7c4a10df9da8c4cd8336a03">d86ecec686d77e69f7c4a10df9da8c4cd8336a03</a>
-<blockquote>
-<p>
- Tweak to better handle undefined transparency ops<br>
-<br>
-examples/transparency_example.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-08 10:46: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=7ca1bb5794997e0dba059a5be6f85a9eaefc915d">7ca1bb5794997e0dba059a5be6f85a9eaefc915d</a>
-<blockquote>
-<p>
- Fix gs_add_explicit_control_path()<br>
-<br>
- it was always adding to the &quot;read&quot; list, rather than the list requested by the<br>
- parameter.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-08 10:33: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=34dac4d2a1b195536fcb9d796168cd1360c0e500">34dac4d2a1b195536fcb9d796168cd1360c0e500</a>
-<blockquote>
-<p>
- Don't bind and undefine .copytree<br>
-<br>
- .copytree is a Postscript proc that calls itself recursively, hence we cannot<br>
- bind it nor undefine it.<br>
-<br>
-Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-06 09:32: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=4d53f6ee868205c76950027e76a27f0278513a39">4d53f6ee868205c76950027e76a27f0278513a39</a>
-<blockquote>
-<p>
- Tweak the interaction of file permissions and -I<br>
-<br>
- The new file permissions code differentiates between 'path', 'path/' and<br>
- 'path/*', whilst the old -I code did not.<br>
-<br>
- This slightly modifies how the -I stuff drives the file permissions stuff so it<br>
- works (more) like the previous -I behaviour.<br>
-<br>
- The remaining difference is that the new code always treats '*' as a wildcard,<br>
- where the old code would permit '*' as a 'real' character in a path.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-15 09:52:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=00af0eb11b82c4dfddbe91bcb70caed2e61a1cc8">00af0eb11b82c4dfddbe91bcb70caed2e61a1cc8</a>
-<blockquote>
-<p>
- pdfwrite/ps2write/pdfimage - record args used<br>
-<br>
- Following on from commit 813d7e96c8733f85d59a62732171cf7cedfc087d this<br>
- adds functionality to the pdfwrite and pdfimage families of devices to<br>
- actually write the args that were used to generate the output file into<br>
- the final output file, as comments.<br>
-<br>
- Output files are somewhat larger with this commit, but only very small<br>
- files are in any way significantly larger. We do have a number of such<br>
- files in our test suite which exhibit larger output ( &gt; 5%increase).<br>
-<br>
-devices/gdevpdfimg.c<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfu.c<br>
-devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-12 16:30:46 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=813d7e96c8733f85d59a62732171cf7cedfc087d">813d7e96c8733f85d59a62732171cf7cedfc087d</a>
-<blockquote>
-<p>
- Capture args to feed to pdfwrite.<br>
-<br>
- To facilitate debugging, we want a way to pickle the gs invocation<br>
- used into device output (for devices that want it).<br>
-<br>
- We therefore amend the argument processing logic to pass arguments<br>
- to gs_lib_ctx, where they will are 'sanitized' and stored in a list.<br>
- This list can then be accessed by a device.<br>
-<br>
- We are careful to sanitize the args so as not to reveal paths or<br>
- secret passwords/code etc. Essentially we never store any filenames<br>
- or string values stored (except for certain whitelisted -s options).<br>
-<br>
- It is likely that we'll want to expand the whitelisted values in<br>
- future.<br>
-<br>
-base/gsargs.c<br>
-base/gsargs.h<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-pcl/pl/plmain.c<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-14 16:47: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=8ba95fb06387572160fee5e4c1e51d972401566e">8ba95fb06387572160fee5e4c1e51d972401566e</a>
-<blockquote>
-<p>
- Fix gs_lib_ctx memory calls to use the correct memory pointer.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-14 08:03:45 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ddddd71785d058b036775566d36d6848c9817f80">ddddd71785d058b036775566d36d6848c9817f80</a>
-<blockquote>
-<p>
- Fix -F____ and -f____ to actually run the file ____.<br>
-<br>
- Commit 7ecbfda9 broke -F completely since it requires the file to run to<br>
- immediately follow the switch, and -f____ use to run the file, but since<br>
- gs_add_control_path returns 0 as long as there was no error, the code<br>
- never called argproc. Also, argproc already does the add_control_path<br>
- and remove_control_path, so simplify -f and -F code.<br>
-<br>
- Also gs_add_outputfile_control_path was ignoring the return code when<br>
- adding the full pipe string as a path, so fix it.<br>
-<br>
- Note that plmain ignores the return code from gs_remove_control_path,<br>
- but that should be OK.<br>
-<br>
-base/gslibctx.c<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-12 13:53:29 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3eb2b1337260a17274588d377032e1f9953062fd">3eb2b1337260a17274588d377032e1f9953062fd</a>
-<blockquote>
-<p>
- Squash double -&gt; int warning message with explicit cast.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-13 11:54: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=8b5af0e2db28be36d96de97eb1a145d5716ffea3">8b5af0e2db28be36d96de97eb1a145d5716ffea3</a>
-<blockquote>
-<p>
- Tweak lcms to optimise the pipeline before consulting plugins.<br>
-<br>
- This allows us to recognise identity transforms before selecting<br>
- one of our optimised lookup functions. Firstly, however optimised<br>
- our code is, we aren't going to beat the identity code. Secondly,<br>
- lcms doesn't calculate the tables for identity transforms, so<br>
- our code can fall in a heap here.<br>
-<br>
-lcms2mt/src/cmsxform.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-13 16:05: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=15d95340389f0f46bd214803ec19685c0a738a0e">15d95340389f0f46bd214803ec19685c0a738a0e</a>
-<blockquote>
-<p>
- Deprecate .setpdfwrite<br>
-<br>
- The .setpdfwrite operator nowadays does nothing more than increase the<br>
- VM threshold, which is relatively pointless so we're going to remove it.<br>
-<br>
- In this commit; add a warning message to the .setpdfwrite operator so<br>
- that anyone using it will be warned. Remove usage from the various<br>
- shell scripts we provide.<br>
-<br>
-Resource/Init/gs_pdfwr.ps<br>
-lib/dvipdf<br>
-lib/ps2pdfwr<br>
-lib/ps2pdfxx.bat<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-12 16:06:21 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8cc13d54850af14a07e72f73cca20e96ed01fd03">8cc13d54850af14a07e72f73cca20e96ed01fd03</a>
-<blockquote>
-<p>
- PDF interpreter - ignore visibility of annotations for devices which support them<br>
-<br>
- No bug for this, arose from a Stack Overflow question, but its a FAQ<br>
- as well.<br>
-<br>
- It used to be the case that the PDF interpreter would (and should)<br>
- render files containing annotations with the Print and NoView flags<br>
- differently, depending on whether the destination was to be rendered<br>
- or sent to a high level device. This is controlled with the -dPrinted<br>
- flag to determine whether annotations should be treated as for a Print<br>
- device or a View device.<br>
-<br>
- This doesn't make a lot of sense for pdfwrite though. We really want to<br>
- keep the Annotation 'as is' and let the viewer or printer of the output<br>
- PDF file deal with it.<br>
-<br>
- In the past we've moved the annotation handling for pdfwrite and,<br>
- technically, for any device which directly supports annotations from<br>
- 'drawannot' to 'preserveannot'. Now that we've done that, it makes some<br>
- sense to have the 'preserveannot' code no longer check the annotation's<br>
- visibility, but simply preserve it as you would expect. NOTE we do check<br>
- the visibility state of annotations that we don't know how to handle.<br>
- These will not be preserved as annotations, but will be drawn into the<br>
- page contents, so we don't want to render any which should be invisible.<br>
- Such annotations are still affected by -dPritned.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-09 15:57: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=368bc91bf0bba66f31204e1ee57da7c9b70b32bb">368bc91bf0bba66f31204e1ee57da7c9b70b32bb</a>
-<blockquote>
-<p>
- pdfwrite - fix a minor error<br>
-<br>
- I don't think this causes any actual problems, but the correct return<br>
- should be 0, not an error, when we can't find a Pattern resource.<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-09 15:56: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=9a871de445eaed295748a3b489e138e87b9e0b65">9a871de445eaed295748a3b489e138e87b9e0b65</a>
-<blockquote>
-<p>
- Transparency compositor - forward unhandled special_ops to target device<br>
-<br>
- Noticed while doing earlier work. The pdf14 device only passed on a few<br>
- specific gxdso_ special_op types to the target device, the remainder<br>
- were sent to the default handler. This seems wrong and caused problems<br>
- for my new gxdso at the time. Instead of it going through the pdf14<br>
- device and ending up at pdfwrite (or the default handler for other<br>
- devices) it was always going to the default handler and never making<br>
- it to pdfwrite when rendering transparency.<br>
-<br>
- The pdf14 device should instead handle any gxdso_ special_ops that vary<br>
- depending on rendering. For instance the JPEG passthrough should *not*<br>
- be passed to the target device, the pdf14 device needs to have the<br>
- uncompressed image data to render it to the compositor buffer.<br>
-<br>
- This commit adds handlers for such gxdso_ special ops, and passes all<br>
- the remaining unhandled ones to the target device for processing.<br>
-<br>
- For some reason this causes diffs in halftones, I have no idea why. but<br>
- they don't seem like problems.<br>
-<br>
-base/gdevp14.c<br>
-base/gxdevsop.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-09 17:14:42 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1ca2c331684ca2912c431771d1aac8bc5cb42e76">1ca2c331684ca2912c431771d1aac8bc5cb42e76</a>
-<blockquote>
-<p>
- Fix line endings (file had some '\r' line endings).<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-08 09:07: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=e9e253e1dbc87d6ef772936130076e1ba3b81867">e9e253e1dbc87d6ef772936130076e1ba3b81867</a>
-<blockquote>
-<p>
- pdfwrite - don't permit fallback font substitution with PDF/A<br>
-<br>
- Bug #701373 &quot;PDFA fails to validate by Preflight&quot;<br>
-<br>
- The inptu is a PDF file which is missing two fonts, Helvetica and<br>
- Calibri. For both fonts we use /Helvetica as a substitute. For the<br>
- missing Helvetica font this is correct, but for the missing Calibri font<br>
- this leads to problem when creating PDF/A otuput files.<br>
-<br>
- Firstly, we now have two different fonts, with differing /Widths which<br>
- are potentially attempting to reference the same glyphs from a single<br>
- font. Secondly, no matter what we do, the /Widths from the Calibri font<br>
- are not going to match the actual glyph metrics from Helvetica.<br>
-<br>
- Since there is no possible way to deal with the second problem, because<br>
- either the metrics won't match the /Widths, or the text will be misplaced<br>
- if we use Widths that are not those from Calibri, there is no point in<br>
- trying to tackle the first problem.<br>
-<br>
- So here we introduce a new special_op 'EventInfo' which passes a single<br>
- name to the device. The name is the name of the event which occurred. For<br>
- now this can only be 'SubstitutedFont'. The only device which handles<br>
- this event is pdfwrite, all other devices simply ignore it. The pdfwrite<br>
- device checks to see if it is creating a PDF/A otuptu file, and if it is<br>
- then it emits a warnign and aborts the production of PDF/A.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-base/gdevdflt.c<br>
-base/gdevp14.c<br>
-base/gxdevsop.h<br>
-devices/vector/gdevpdfi.c<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-14 16:52:28 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=009d44b855dcda9d0d9ecf5ca20944504648eebe">009d44b855dcda9d0d9ecf5ca20944504648eebe</a>
-<blockquote>
-<p>
- CompatibleOverprint Mode<br>
-<br>
- Ray did the interpreter work on this and Michael did the graphics<br>
- library portion.<br>
-<br>
- For the interpreter:<br>
- When OP is set, change to CompatibleOverprint mode, but don't push a<br>
- transparency group or change opacityalpha when the current blendmode<br>
- is Normal or Compatible. This was determined based on the note on page<br>
- 568 of the PDF 1.7 spec (section 7.6.3 in the area titled &quot;Compatibility<br>
- with Opaque Printing&quot;). It states:<br>
-<br>
- Note: It is not necessary to create such an implicit transparency<br>
- group if the current blend mode is Normal; simply substituting<br>
- the CompatibleOverprint blend mode while painting the object<br>
- produces equivalent results. There are some additional cases in<br>
- which the implicit transparency group can be optimized out.<br>
-<br>
- After painting, if the group was pushed, pop the group, and restore the<br>
- opacityalpha and shapealpha,then restore the blendmode (if it was<br>
- CompatibleOverprint).<br>
-<br>
- NB, we don't attempt to optimize any other groups hinted at in<br>
- Adobe's comment.<br>
-<br>
- In addition, if we are going to an output device that handles transparency<br>
- compositor actions do not do any of the above stuff.<br>
-<br>
- For the graphics library:<br>
- When doing blending in non-isolated groups with compatible overprint<br>
- the non-drawn colors must be corrected during the fill rectangles to<br>
- ensure that the proper amount is maintained with the changing group<br>
- alpha values. This is poorly documented in the specification.<br>
- In addition, the spec is poorly written in terms of how the blend<br>
- computation is performed for overprint compatible.<br>
-<br>
- The spec claims the following:<br>
-<br>
- If the overprint mode is 1 (nonzero overprint mode) and the<br>
- current color space and group color space are both DeviceCMYK,<br>
- then only process color components with nonzero values replace<br>
- the corresponding component values of the backdrop. All other<br>
- component values leave the existing backdrop value unchanged.<br>
- That is, the value of the blend function B(Cb,Cs) is the source<br>
- component cs for any process (DeviceCMYK) color component whose<br>
- (subtractive) color value is nonzero; otherwise it is the<br>
- backdrop component cb. For spot color components, the value is<br>
- always cb.<br>
-<br>
- The equation for compositing is<br>
-<br>
- ar*Cr = (1-as)*Cb + as*[(1-ab)*Cs+ab*B(Cb,Cs)]<br>
-<br>
- Now if I simply set B(cb,cs) to cb for the case when the<br>
- DevieCMYK value (with opm true) is zero I get<br>
-<br>
- ar*Cr = (1-as)*Cb + as*[(1-ab)*Cs+ab*Cb]<br>
-<br>
- But what I am seeing with AR is<br>
- ar*Cr = (1-as)*Cb + as*[(1-ab)*Cb+ab*Cb] = (1-as)*Cb + as*Cb = Cb<br>
- which is what I think we want.<br>
-<br>
- The description in the spec is confusing as it says<br>
- &quot;then only process color components with nonzero values replace<br>
- the corresponding component values of the backdrop. All other<br>
- component values leave the existing backdrop value unchanged&quot;<br>
-<br>
- which makes sense for overprinting,<br>
-<br>
- vs.<br>
-<br>
- &quot;That is, the value of the blend function B(Cb,Cs) is the source<br>
- component cs for any process (DeviceCMYK) color component whose<br>
- (subtractive) color value is nonzero; otherwise it is the<br>
- backdrop component cb.&quot;<br>
-<br>
- Which is NOT the same thing as leaving the backdrop unchanged<br>
- with the compositing equation<br>
- ar*Cr = (1-as)*Cb + as*[(1-ab)*Cs+ab*B(Cb,Cs)]<br>
-<br>
- For this to work, we need to carry out the operation during<br>
- the mixing of the source with the blend result. Essentially<br>
- replacing that mixing with the color we have here.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-Resource/Init/pdf_main.ps<br>
-Resource/Init/pdf_ops.ps<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gstrans.h<br>
-base/gxblend.c<br>
-base/gxclpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-07 10:24: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=d8f05309d5e54b6e75c2b78af9c0bcf5f62b493c">d8f05309d5e54b6e75c2b78af9c0bcf5f62b493c</a>
-<blockquote>
-<p>
- Bug 701308: Fix clip transpose logic that resulted in garbled output.<br>
-<br>
- This seems like it should have showed up earlier, but when the clip<br>
- rectangle list was transposed, the _t1 and _s1 clip_fill_rectangle_<br>
- functions were confused about the coordinates being sent to the target<br>
- device fill_rectangle.<br>
-<br>
- Also during debug, I found that if the clip list consisted of more than<br>
- a single rectangle, clip_get_clipping_box was only using the first rect,<br>
- rather than accumulating the outer_box for the entire list.<br>
-<br>
-base/gxclip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-06 12:44:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ff856d0c44ce7d3f4d204f4a405857a6a6672a80">ff856d0c44ce7d3f4d204f4a405857a6a6672a80</a>
-<blockquote>
-<p>
- pdfwrite - handle nested Patterns inside a transparency Group<br>
-<br>
- Bug #701181 &quot;Incorrect output after ghostscript processing of a PDF file&quot;<br>
-<br>
- The PDF file is constructed in a somewhat sub-optimal fashion. Each<br>
- background square 'grid' is a Form, each Form draws the content by<br>
- filling the area with a solid colour, and then drawing white lines<br>
- across it. The white lines (actually rectangles) are drawn using a<br>
- Pattern.<br>
-<br>
- So far so good, however the Pattern simply executes a Form, that Form<br>
- then fills another rectangle, with another Pattern, its this final<br>
- pattern which does the drawing.<br>
-<br>
- This is two levels of indirection more than required.<br>
-<br>
- Normally this isn't a problem because we don't attempt to preserve<br>
- Forms from PDF files (and this is one example of why we don't). But....<br>
- If the file involves transparency Groups, then we must use a Form<br>
- XObject for the Group.<br>
-<br>
- In this case the CTM of the first pattern is the CTM of the 'enclosing<br>
- context', ie the Form, but the CTM of the second pattern is also the<br>
- CTM of the 'enclosing context', but now that means the first pattern,<br>
- not the Group.<br>
-<br>
- To cater for this we track the number of patterns defined since the last<br>
- Form definition. If its 0 (ie this is the first pattern since a Form<br>
- definition) then we just use the CTM. If its greatre than 0, however,<br>
- then we 'undo' the scaling applied by pdfwrite, in order to get back to<br>
- the CTM of the enclosing pattern.<br>
-<br>
- Its possible that more extreme examples (patterns inside patterns<br>
- inside groups inside patterns inside groups) might still not be entirely<br>
- correct, but we have no examples of this (Patterns inside patterns are<br>
- relatively rare). If we find any we can revisit this.<br>
-<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdft.c<br>
-devices/vector/gdevpdfv.c<br>
-devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-05 17:50:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f69b63a3dc3bb7671df956587fe2520f8badab88">f69b63a3dc3bb7671df956587fe2520f8badab88</a>
-<blockquote>
-<p>
- PDF interpreter - cope with strangely constructed Pages trees<br>
-<br>
- Bug #700953 &quot;Error: /execstackoverflow in --.systemvar--&quot;<br>
-<br>
- The pre-interpretation scan of the Pages tree looking for loops in the<br>
- tree structure uses recursion; if a Pages tree is badly constructed it<br>
- is possible to recurse enough times to cause an overflow of the exec<br>
- stack.<br>
-<br>
- We can cope with this by aborting the scan and continuing to interpret<br>
- and render the PDF file, because the regular processing of PDF file<br>
- doesn't use recursion.<br>
-<br>
- Of course, this does mean that we lose the check for loops in the Pages<br>
- tree (at least, loops beyond the point where we overflow the exec stack)<br>
- but both conditions are rare, so I think its worth doing.<br>
-<br>
- We do still raise a warning.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-05 10:05:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fd915a81c605a52f58855bd233c19aaa373b2f69">fd915a81c605a52f58855bd233c19aaa373b2f69</a>
-<blockquote>
-<p>
- pdfwrite - improve CIDFont generation<br>
-<br>
- Bug 701010 &quot;Low Printer VM and gswinc32.exe crashing on postscript file with Korean text&quot;<br>
-<br>
- The problem in this case is that the PostScript uses a CIDFont with two<br>
- descendant fonts. PDF only permits a single descendant font in a CIDFont<br>
- so pdfwrite can't simply copy the font 'as is'.<br>
-<br>
- Instead we create a type 0 font (CIDFont) for each descendant and switch<br>
- between them as required.<br>
-<br>
- The problem here is that the code for retrieving an existing Type 0<br>
- CIDFont for a given descendant in the PostScript assumed that the name<br>
- of the CIDFont would be of the form /FontName-CMapName, and the font<br>
- we have here does not match that.<br>
-<br>
- In fact, I'm not at all sure that this is *ever* the case, certainly<br>
- none of our test files seem to exercise this (bearing in mind that its<br>
- the Type 0 CIDFont generated by pdfwrite that we are checking against<br>
- and I can see no code that created a name of that form).<br>
-<br>
- So what was happening was that every time the PostScript CIDFont<br>
- switched descendants, we generated a new Yype 0 font, along with all the<br>
- attendant structures, such as a ToUnicode CMap (256kB on its own). In<br>
- fact the first line of text in the file switches descendants 26 times,<br>
- leading to us creating something like 21 MB of extra font information.<br>
-<br>
- We now extend the check so that if the name is not FontName-CMapName we<br>
- check the FontName and the CMap Name (which we do also store) separately<br>
- and if they match we reuse the existing Type 0 font.<br>
-<br>
- The supplied test file now runs to completion, all 217 pages, with a<br>
- peak memory usage of ~22.8MB whereas it previously exhausted memory,<br>
- using ~2GB, at page 111. In addition the resulting PDF file is around<br>
- 95% smaller and the performance is noticeably improved on this file.<br>
-<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-02 15:18:26 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5b85ddd19a8420a1bd2d5529325be35d78e94234">5b85ddd19a8420a1bd2d5529325be35d78e94234</a>
-<blockquote>
-<p>
- Bug 701394: protect use of .forceput with executeonly<br>
-<br>
-Resource/Init/gs_type1.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-31 13:34:06 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3ed82a40fd4b49728c79955319b6d67d1e092006">3ed82a40fd4b49728c79955319b6d67d1e092006</a>
-<blockquote>
-<p>
- Add a way to record the selected cmap<br>
-<br>
- (for the pdfi branch)<br>
-<br>
-base/fapi_ft.c<br>
-base/gxfapi.h<br>
-pcl/pl/plfapi.c<br>
-psi/zfapi.c<br>
-xps/xpsfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-08-01 08:55: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=1eb609f130c397144702097f4d987f3b956770f9">1eb609f130c397144702097f4d987f3b956770f9</a>
-<blockquote>
-<p>
- Add 'post' table name lookup to TTF in graphics lib<br>
-<br>
- Make Mac Roman glyph ordering available to 'clients'<br>
-<br>
- (in support of the pdfi branch)<br>
-<br>
-base/gstype42.c<br>
-base/gxfont42.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-31 15:04: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=788958decad94b7b3f7a478cfb57724323041bf5">788958decad94b7b3f7a478cfb57724323041bf5</a>
-<blockquote>
-<p>
- Fix Separation and DeviceN Alternate colour space generation<br>
-<br>
- Bug #701369 &quot;PB with Pantone color in pdfwrite&quot;<br>
-<br>
- When converting to a specified colour space, if we encounter a DeviceN<br>
- or Separation space, we leave the spot inks in place but change the<br>
- alternate space to the defined colour conversion space, and generate a<br>
- new tint transform which approximates the original colours.<br>
-<br>
- However there was a logical error in the code, which only became<br>
- apparent if TransferFunctionInfo was set to something other than 'Apply'<br>
-<br>
- Normally this doesn't happen, but commit<br>
- 2e68cc460dbe349f68b81082ff7344db48eb4820 changed the behvaiour when<br>
- we are doing colour conversion to prevent us trying to apply a transfer<br>
- function to a SMask, which we can't do.<br>
-<br>
- This then exposed the fact that we were not copying the concretized<br>
- samples to the client_colour structure, but we were reading them *back*<br>
- from the client_colour structure to set the low and high values in the<br>
- generated tint transform function.<br>
-<br>
- The solution is to copy the components from the concretized colour<br>
- outside the if clause testing the TransferFunctionInfo.<br>
-<br>
- This fix continues to work properly with the file from bug #700052<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-24 12:36:35 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4367024d102c6363ba7536227790564466ec9ddc">4367024d102c6363ba7536227790564466ec9ddc</a>
-<blockquote>
-<p>
- Fix debug PDF14_OPCODE_NAMES -- PDF14_BEGIN_TRANS_PAGE_GROUP was missing.<br>
-<br>
-base/gstrans.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-23 14:48:32 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a8e9c6f7bd45531a1b01eb0d697a6dc48cde2b0">9a8e9c6f7bd45531a1b01eb0d697a6dc48cde2b0</a>
-<blockquote>
-<p>
- Add arm option to clusterpush.pl<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-22 12:18: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=4de965abeddf859b91937314bc7e86de25acb729">4de965abeddf859b91937314bc7e86de25acb729</a>
-<blockquote>
-<p>
- Bug #701339, fixes total pattern length of 0.<br>
-<br>
- Fallback to the default path code if the total pattern length is 0.<br>
- This can happen because PCL XL represents pattern length elements as<br>
- integers not floats.<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-22 19:33:44 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a628e509caf40ddec3d016dd9ff6379f12be7cc1">a628e509caf40ddec3d016dd9ff6379f12be7cc1</a>
-<blockquote>
-<p>
- Ensure pdf14_put_image linebuf is long enough to avoid overrun.<br>
-<br>
- The assumption is that we can write in 32byte lumps, so we may<br>
- overrun the actual amount we need by 28 bytes. Allow for this.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-21 16:26: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=4d8b6c57ef7272d41fb389a4dc9546f078ba3b2d">4d8b6c57ef7272d41fb389a4dc9546f078ba3b2d</a>
-<blockquote>
-<p>
- Rework CAL cflags.<br>
-<br>
- Cope with building for machines that have SSE4.2, but not AVX2,<br>
- that crash on SSE4.2 code compiled with the -mavx2 flag.<br>
-<br>
-Makefile.in<br>
-base/cal.mak<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-22 13:07: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=909a87a15b5f8fede1f6bfeac2005327a7ca1601">909a87a15b5f8fede1f6bfeac2005327a7ca1601</a>
-<blockquote>
-<p>
- Permit extra widths on space glyphs (PDF Tw value) even for xyshow<br>
-<br>
- For the benefit of the pdfi interpreter. With the PDF in PostScript<br>
- current interpreter, we apply Widths using a cshow procedure. The pdfi<br>
- interpreter instead uses the x_widths and y_widths arrays, intended for<br>
- use with the PostScript xyshow operator instead.<br>
-<br>
- However, the existing code doesn't add the extra width to space glyphs<br>
- if we have TEXT_REPLACE_WIDTHS set (ie an xyshow).<br>
-<br>
- Here we move the code for the additional width out of the 'else'<br>
- clause in show_move() so that we always have the value available. We<br>
- then apply the dx and/or dy values in both cases.<br>
-<br>
- We also need to relax the 'invalid' checking which is performed at a<br>
- higher level in the code (gx_device_text_begin) because this combination<br>
- is explicitly barred there and returns an error.<br>
-<br>
-base/gstext.h<br>
-base/gxchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-20 11:34:46 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=239d9035a011c212b015951bb2d75114ba11bee0">239d9035a011c212b015951bb2d75114ba11bee0</a>
-<blockquote>
-<p>
- Add cal operation to clusterpush.pl<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-20 19:34:00 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d4dcb839b679a01f38aac2156c2bb87a819b0d4">0d4dcb839b679a01f38aac2156c2bb87a819b0d4</a>
-<blockquote>
-<p>
- Squash warnings in CAL build.<br>
-<br>
-base/gxblend.c<br>
-base/gximono.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-18 15:47:54 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e5faf407dcb7c9679537313cebd55a747098f6f8">e5faf407dcb7c9679537313cebd55a747098f6f8</a>
-<blockquote>
-<p>
- Bug 701296: Fix Interpolation in Indexed spaces with UseFastColor<br>
-<br>
- The get_color_handler logic was being called with pcs = Indexed, and<br>
- so doing pcs = pcs-&gt;base_space. Then it was checking that pcs == the<br>
- concrete space, seeing that it was, and deciding it could then use<br>
- the device colors direct. The problem is that pcs-&gt;base_space is a<br>
- greyscale space, so when running to (say) an rgb output, we have the<br>
- wrong color data.<br>
-<br>
- We now check for the number of components being as we expect, and<br>
- for the space being one of our 'default' ones before choosing to<br>
- take the 'fast' route.<br>
-<br>
-base/gsicc_manage.c<br>
-base/gsicc_manage.h<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-17 10:25:45 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c0e588f679fca92d92045049fd60846b57da899c">c0e588f679fca92d92045049fd60846b57da899c</a>
-<blockquote>
-<p>
- Fix crash when RAW_PATTERN_DUMP is enabled<br>
-<br>
- RAW_PATTERN_DUMP is used to help debug pattern issues.<br>
- Crash introduced when changes were made to file i/o.<br>
- Easy to overlook since this is rarely enabled.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-07-26 14: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=c7499c426c0307880e9a34a577492d99a976c15b">c7499c426c0307880e9a34a577492d99a976c15b</a>
-<blockquote>
-<p>
- Introduce CAL based transparency accelerations.<br>
-<br>
- Authored by Michael Vrhel.<br>
-<br>
-base/cal.mak<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gstrans.c<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-07-03 11:36:07 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2533344c1bad749e81c3cef91e770ba4ea5a1a1d">2533344c1bad749e81c3cef91e770ba4ea5a1a1d</a>
-<blockquote>
-<p>
- Introduce CAL based SSE4.2 and AVX2 optimisations.<br>
-<br>
- Authored by Michael Vrhel.<br>
-<br>
-base/cal.mak<br>
-base/gsicc_lcms2mt.c<br>
-base/gxicolor.c<br>
-base/lib.mak<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-17 07:14:21 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2682485aefb808e5dca7191b980aa83880821dcc">2682485aefb808e5dca7191b980aa83880821dcc</a>
-<blockquote>
-<p>
- Update configure for CAL to spot AVX2 as well.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-16 12:04:04 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=58d1db5850d470856f8c83af9a573b9c5c18e519">58d1db5850d470856f8c83af9a573b9c5c18e519</a>
-<blockquote>
-<p>
- Move cal_context into gs_lib_ctx core.<br>
-<br>
- This avoids us having to repeatedly init/fin the CAL lib.<br>
-<br>
-base/gdevdrop.c<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-base/gxicolor.c<br>
-base/gxidata.c<br>
-base/gximage.h<br>
-base/gximono.c<br>
-base/lib.mak<br>
-base/siscale_cal.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-17 10:19:47 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=47cd6503f34921c840df7c96faa9d957603521e7">47cd6503f34921c840df7c96faa9d957603521e7</a>
-<blockquote>
-<p>
- Bug 701323: Skip oversize TIFF checks in BigTIFF mode.<br>
-<br>
- If we have -dUseBigTIFF, then we don't need to check that<br>
- we don't exceed 4Gig.<br>
-<br>
- This appears to work, but I don't have any code that will<br>
- actually load and show me a &gt;4Gig TIFF!<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-15 18:43:04 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=efce71ac4d500231296d1c84f62077666e0966a1">efce71ac4d500231296d1c84f62077666e0966a1</a>
-<blockquote>
-<p>
- Fix SEGV seen in saved-pages-test run.<br>
-<br>
- The following job:<br>
-<br>
- membin/gs -Ilib -sOutputFile=out.%04d.psd --saved-pages-test<br>
- -dMaxBitmap=10000 -sDEVICE=psdrgb -r300 -Z: -sDEFAULTPAPERSIZE=letter<br>
- -dNOPAUSE -dBATCH -K2000000 -dClusterJob -dJOBSERVER<br>
- /home/regression/cluster/tests_private/comparefiles/Bug691425.pdf<br>
-<br>
- SEGVs due to a buffer overrun.<br>
-<br>
- We are attempting to copy a list of up to GX_DEVICE_MAX_SEPARATIONS<br>
- spot colors for the page into a list that's only GX_SOFT_MAX_SPOTS<br>
- long.<br>
-<br>
- We just extend the storage here to cope.<br>
-<br>
-base/gxclist.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-15 11:50:27 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=105891fadfa649a7b0e3196cc6b0a9865fbf3cac">105891fadfa649a7b0e3196cc6b0a9865fbf3cac</a>
-<blockquote>
-<p>
- Fix SEGV seen in -dUseCIEColor testing.<br>
-<br>
- The following test fails with a SEGV in overnight testing:<br>
-<br>
- tests_private/ps/ps3cet/30-07.PS.psdcmyk.300.1<br>
-<br>
- I can reproduce the problem with this call:<br>
-<br>
- membin/gs -Ilib -sOutputFile=out.%d.psd -dUseCIEColor -dMaxBitmap=10000<br>
- -sDEVICE=psdcmyk -r300 -Z: -sDEFAULTPAPERSIZE=letter -dNOPAUSE -dBATCH<br>
- -K2000000 -dClusterJob -dJOBSERVER -dCETMODE %rom%Resource/Init/gs_cet.ps<br>
- tests_private/ps/ps3cet/30-07.PS<br>
-<br>
- (with a hacked version of Memento so that blocks aren't all put into<br>
- their own chunk).<br>
-<br>
- The problem is that when a shading is built it contains a set of<br>
- params, one of which is a reference to the cie_joint_caches<br>
- structure. This structure is held in a chunk of memory allocated<br>
- from pgs-&gt;memory. This entire chunk of memory goes away when an<br>
- l2restore happens. The built shading, however, is referenced by<br>
- a PS object that can (and does) outlive this.<br>
-<br>
- When a gc happens, it follows the pointer as part of the enumeration<br>
- and crashes due to it having been freed already.<br>
-<br>
- The fix implemented here, is to add a new graphics lib entrypoint<br>
- that returns a reference to a copy of the current caches, allocated<br>
- in a given memory space; we use that to get a reference to the<br>
- caches in the same memory space (and hence with the same lifespan<br>
- as) the shading.<br>
-<br>
-base/gscie.c<br>
-base/gscie.h<br>
-psi/zshade.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-12 16:53:58 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7e9df44328a8a6796a83331a4ab5f9b31091a02c">7e9df44328a8a6796a83331a4ab5f9b31091a02c</a>
-<blockquote>
-<p>
- Fix SEGV with psdcmykog device and files with &gt; 7 spots.<br>
-<br>
- Example invocation:<br>
-<br>
- membin/gs -Ilib -sOutputFile=out.%d.psd -dMaxBitmap=10000<br>
- -sDEVICE=psdcmykog -r600 -Z: -sDEFAULTPAPERSIZE=letter<br>
- -dNOPAUSE -dBATCH -K2000000 -dClusterJob -dJOBSERVER<br>
- ./tests_private/comparefiles/Bug693541.pdf<br>
-<br>
- The PDF14 buffers are set up to have dev-&gt;color_info.num_components<br>
- planes. When these buffers are written into, components 0 to num_spots-1<br>
- inclusive are written. If num_spots &gt; num_components, we overwrite<br>
- data.<br>
-<br>
- Devices such as psdcmyk expand num_components to accomodate the<br>
- number of spots found on the page. Devices such as psdcmykog<br>
- do not; they stick with the number of spots they know about to<br>
- start with (i.e. 2).<br>
-<br>
- Accordingly, if we run a file through with (say) 11 spots on the<br>
- page, with a psdcmykog device, the pdf14 device is setup with<br>
- num_comps = 7 (6+alpha), but the number of spots is taken as<br>
- the number of spots on the page (11), and thus we have memory<br>
- overwrites.<br>
-<br>
- The fix attempted here is to set the number of spots to be<br>
- num_comps - number_of_standard_comps.<br>
-<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-03 20:24: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=6b0aab1de02cfc44515ff05f70be066bcac7f504">6b0aab1de02cfc44515ff05f70be066bcac7f504</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent memory leaks in transfer_raster_row.<br>
-<br>
- Prevent several memory leaks in transfer_raster_row by releasing graphic state.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=15010 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0670<br>
-<br>
-pcl/pcl/rtraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-10 14:19: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=3bce47c5094c4e200d2200ebd1b081a4dd943215">3bce47c5094c4e200d2200ebd1b081a4dd943215</a>
-<blockquote>
-<p>
- Fix CAL halftoning crash due to unaligned data buffer.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-09 14:00: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=0c6f6eb9bd630d594aae0ef7b58aa75253bf52ed">0c6f6eb9bd630d594aae0ef7b58aa75253bf52ed</a>
-<blockquote>
-<p>
- Reference count image colorspaces in XPS.<br>
-<br>
- This avoids leaks.<br>
-<br>
-xps/xpsanalyze.c<br>
-xps/xpscolor.c<br>
-xps/xpsglyphs.c<br>
-xps/xpsgradient.c<br>
-xps/xpsimage.c<br>
-xps/xpsjpeg.c<br>
-xps/xpsjxr.c<br>
-xps/xpspath.c<br>
-xps/xpspng.c<br>
-xps/xpstiff.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-08 19:40: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=ab4cea734dca75cde0ad5d39ad2964c9343e8c91">ab4cea734dca75cde0ad5d39ad2964c9343e8c91</a>
-<blockquote>
-<p>
- XPS: Avoid leaking scanline buffer on jpeg decompression.<br>
-<br>
-xps/xpsjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-08 11:33: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=5c1311ed4dbfb159c9b2304c26b9311834a72bd4">5c1311ed4dbfb159c9b2304c26b9311834a72bd4</a>
-<blockquote>
-<p>
- Remove a couple of macros<br>
-<br>
-base/gxchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-08 19:20:18 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a116672f813da107719df28057b624ce434e163c">a116672f813da107719df28057b624ce434e163c</a>
-<blockquote>
-<p>
- Fix leak of buffer from scaler.<br>
-<br>
- This was being hidden by gc, but shows up in xps.<br>
-<br>
-base/siscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-08 17:30: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=23f28069c8b342cc03de65d8b90029a4b3548010">23f28069c8b342cc03de65d8b90029a4b3548010</a>
-<blockquote>
-<p>
- Really fix CAL makeflags for NEON and SSE.<br>
-<br>
-Makefile.in<br>
-base/cal.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-08 17:29:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c0d136b659b6e54017f57877068206bee62e1fa1">c0d136b659b6e54017f57877068206bee62e1fa1</a>
-<blockquote>
-<p>
- Fix typo in PRI definitions.<br>
-<br>
-base/stdint_.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-08 16:49: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=f0c043ead481dd780c916ddd088baf7abe2a2665">f0c043ead481dd780c916ddd088baf7abe2a2665</a>
-<blockquote>
-<p>
- pdfwrite - fix a memory leak<br>
-<br>
- pcs is a local variable and when it goes out of scope if it still holds<br>
- a reference to the colour space, it will leak.<br>
-<br>
-devices/vector/gdevpdfb.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-08 16:38:09 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a77d1aef180a2dce12cefc039f7fc3dffd69af98">a77d1aef180a2dce12cefc039f7fc3dffd69af98</a>
-<blockquote>
-<p>
- Fix CAL NEON detection.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-08 15:46: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=c454bf4c1e6eb6d64508234dbdd6f29ceea184c3">c454bf4c1e6eb6d64508234dbdd6f29ceea184c3</a>
-<blockquote>
-<p>
- Bug 701284: Fix more path leakages, this time in pdf14.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-08 14:58: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=0ca58b97aa19d25ede275cc6447dc32815205263">0ca58b97aa19d25ede275cc6447dc32815205263</a>
-<blockquote>
-<p>
- Bug 701284: Fix clipping path memory leaks<br>
-<br>
-base/gxclrast.c<br>
-base/gxcpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-06 18:34:47 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9d410dc41277401d48f4dd94dd50391c4a4c79b0">9d410dc41277401d48f4dd94dd50391c4a4c79b0</a>
-<blockquote>
-<p>
- Fix CAL builds to pass appropriate compiler flags<br>
-<br>
-Makefile.in<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-05 19:36:34 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c734f19d7780cac16b89ced9924ad18bf1c1b380">c734f19d7780cac16b89ced9924ad18bf1c1b380</a>
-<blockquote>
-<p>
- Fix memory leak in pdf14_tile_pattern_fill in non-GC languages.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-05 19:35:58 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d181151975f0ee13162cc03865c0cc5f58931823">d181151975f0ee13162cc03865c0cc5f58931823</a>
-<blockquote>
-<p>
- Fix memory leaks seen in XPS; pattern cache and start_part.<br>
-<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-05 19:35: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=f19453e0f1ced6eb0273f4eabc4e618553c49925">f19453e0f1ced6eb0273f4eabc4e618553c49925</a>
-<blockquote>
-<p>
- xps_free_font wasn't freeing font-&gt;data causing leaks.<br>
-<br>
-xps/xpsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-05 19:34:56 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e05305f8d8e6222250f18daf9b437b7faee8ebee">e05305f8d8e6222250f18daf9b437b7faee8ebee</a>
-<blockquote>
-<p>
- Destructors should cope with NULL.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-04 18:52:08 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd2bd7b4ca1886a4f3c58afbdacbb93831c57e1b">dd2bd7b4ca1886a4f3c58afbdacbb93831c57e1b</a>
-<blockquote>
-<p>
- Bug 701284: Fix leak of pdf14device in xps.<br>
-<br>
- The pdf14device is created and then &quot;retained&quot;. This is required<br>
- for gs, because postscript can call &quot;currentdevice&quot; and get a<br>
- non reference counted pointer to a device. It is cleared up<br>
- correctly because of gc.<br>
-<br>
- Other languages have no gc, and so leak. The fix is to enable<br>
- those languages to get the pdf14device &quot;unretained&quot;. We add an<br>
- graphics lib call to allow this to happen.<br>
-<br>
- Transparent Patterns also create pdf14devices, which are again<br>
- retained, despite not needing to be. In gs this causes no problems<br>
- as they are cleared by the restore, but in other languages they<br>
- leak. We make them unretained here, with no ill effects.<br>
-<br>
-base/gstrans.c<br>
-base/gstrans.h<br>
-base/gxpcmap.c<br>
-psi/zpcolor.c<br>
-psi/ztrans.c<br>
-xps/xpspage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-04 08:47: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=47a4fab32690cd2f0aba92f37fc7f03b4069460a">47a4fab32690cd2f0aba92f37fc7f03b4069460a</a>
-<blockquote>
-<p>
- Bug 701288: Handle SEAC ligature glyph metrics correctly.<br>
-<br>
- As originally intended, a Type 1 SEAC charstring would be used for an accented<br>
- glyph (like an a-caron, or u-umlaut) where the advance with of the SEAC glyph<br>
- is the same as that of the 'base' glyph ('a' or 'u').<br>
-<br>
- It this case, it is not uncommon for the SEAC to skip using an (H)SBW op code<br>
- and rely on the one from the base glyph.<br>
-<br>
- But out of spec fonts also use SEAC glyphs ligature glyphs (like 'oe' or 'fi'),<br>
- and in those cases the overall advance width is greater than that of the 'base'<br>
- glyph.<br>
-<br>
- In this case, we have to allow for the SEAC glyph having included an (H)SBW and<br>
- if it has, retain those values, rather than those from the base glyph.<br>
-<br>
-freetype/src/psaux/psintrp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-02 17:15: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=491a1637f11c84ad47d83d35eba510ac6d0c47f0">491a1637f11c84ad47d83d35eba510ac6d0c47f0</a>
-<blockquote>
-<p>
- Move to size_t in allocations.<br>
-<br>
-base/gsalloc.c<br>
-base/gsalloc.h<br>
-base/gsmalloc.c<br>
-base/gsmalloc.h<br>
-base/gsmchunk.c<br>
-base/gsmdebug.h<br>
-base/gsmemory.c<br>
-base/gsmemory.h<br>
-base/gsmemret.c<br>
-base/gsnogc.c<br>
-base/gsstype.h<br>
-base/gxalloc.h<br>
-base/gxobj.h<br>
-base/mkromfs.c<br>
-psi/ilocate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-03 18:16:25 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=25fbeb3e1f4ba5ca7ecafd7a24b7be4079113e7c">25fbeb3e1f4ba5ca7ecafd7a24b7be4079113e7c</a>
-<blockquote>
-<p>
- Squash warning in compile time assert.<br>
-<br>
-psi/iapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-03 18:01: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=7dfee126567be1859f4ca1637c256b4179a571b8">7dfee126567be1859f4ca1637c256b4179a571b8</a>
-<blockquote>
-<p>
- Fix missing const with fs_file_open_printer.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-03 18:00: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=378fd9840e957c3a160665483cc537d6f6e860bf">378fd9840e957c3a160665483cc537d6f6e860bf</a>
-<blockquote>
-<p>
- Squash some build warnings with debug prints.<br>
-<br>
-base/gsicc_cache.c<br>
-base/gsicc_profilecache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-03 15:39: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=e3dd119d53361d09fa30ca13cce4a97869ba0f8d">e3dd119d53361d09fa30ca13cce4a97869ba0f8d</a>
-<blockquote>
-<p>
- Add printf format specifier macros for size_t.<br>
-<br>
- Sadly, it is not enough to have definitions that match<br>
- the sizes; gcc will give a warning if the types don't match.<br>
-<br>
-base/stdint_.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-03 15:23:46 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=761a8b513a28a9c4f4f1e83150556e7407f0d74a">761a8b513a28a9c4f4f1e83150556e7407f0d74a</a>
-<blockquote>
-<p>
- Add size_t definitions to genarch.<br>
-<br>
-arch/windows-arm-msvc.h<br>
-arch/windows-x64-msvc.h<br>
-arch/windows-x86-msvc.h<br>
-base/genarch.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-27 16:48: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=d306e93d487a6539804c6343986bcbca2ecc37a8">d306e93d487a6539804c6343986bcbca2ecc37a8</a>
-<blockquote>
-<p>
- Rework ROP transparency<br>
-<br>
- Rework ROP behaviour with transparency based upon the results<br>
- from roptest.pxl seen on an HP printer.<br>
-<br>
- The old style ROP transparency code used to treat white pixels<br>
- as special. The new style code does everything in boolean logic<br>
- by modifying the ROP that is used when S or T pixels are set to<br>
- be transparent.<br>
-<br>
- This enables us to rip out several cases from the ROP<br>
- processing loops, as we never need to check for transparent<br>
- pixel values anymore.<br>
-<br>
-base/gdevdrop.c<br>
-base/gdevmpla.c<br>
-base/gdevmr1.c<br>
-base/gdevmr2n.c<br>
-base/gdevmr8n.c<br>
-base/gdevmrop.h<br>
-base/gdevplnx.c<br>
-base/gsroprun.c<br>
-base/gsroprun24.h<br>
-base/gsroprun8.h<br>
-base/gsropt.h<br>
-base/gxdcolor.c<br>
-base/gxipixel.c<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-26 18:51: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=054f4df9b5f8bb09c252841f0c3256b9adc60f0a">054f4df9b5f8bb09c252841f0c3256b9adc60f0a</a>
-<blockquote>
-<p>
- Add another couple of SSE ROP cases.<br>
-<br>
-base/gsroprun.c<br>
-base/gsroprun8.h<br>
-base/gsropt.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-11 17:57: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=82e2843149b32e61cfde7861ac67a51014538f4f">82e2843149b32e61cfde7861ac67a51014538f4f</a>
-<blockquote>
-<p>
- ROP optimisation: Fold 24bpp ROPs down to 8 bit where possible.<br>
-<br>
- This increases line length.<br>
-<br>
-base/gsroprun.c<br>
-base/gsroprun8.h<br>
-base/gsropt.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-02 17:29:54 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=470897e484fb0bfaa8553e0ccd5b9db91eda008b">470897e484fb0bfaa8553e0ccd5b9db91eda008b</a>
-<blockquote>
-<p>
- Avoid warning due to casting int to double.<br>
-<br>
- Use size_t properly, and no call to abs is required.<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-02 17:14:33 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c986cd9f93008992344d2cd5be224af13e1c980">6c986cd9f93008992344d2cd5be224af13e1c980</a>
-<blockquote>
-<p>
- Squish an annoying implicit cast warning.<br>
-<br>
- Do it explicitly.<br>
-<br>
-base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-02 17:13:48 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=45e765e59a45b46dcb05e8c729689a7c0574a48c">45e765e59a45b46dcb05e8c729689a7c0574a48c</a>
-<blockquote>
-<p>
- Fix some warnings caused by the gs FS api commit.<br>
-<br>
-base/gp.h<br>
-base/gp_dvx.c<br>
-base/gp_msprn.c<br>
-base/gp_mswin.c<br>
-base/gp_os2.c<br>
-base/gp_os2.h<br>
-base/gp_os9.c<br>
-base/gp_unix.c<br>
-base/gp_winfs2.c<br>
-base/gslibctx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-01 21:31:03 +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=f209fb3a0f50cd0a9974d8627a4ac7f358f60c8a">f209fb3a0f50cd0a9974d8627a4ac7f358f60c8a</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV in check_pattern_rendering.<br>
-<br>
- Prevent SEGV by checking for check_pattern_rendering being called with NULL pattern.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=16764 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0825<br>
-<br>
-pcl/pcl/pcpatrn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-01 21:08: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=e6c50c878d622974e7bb2438327e5363b9419875">e6c50c878d622974e7bb2438327e5363b9419875</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV due to double freeing.<br>
-<br>
- On error pl_dict_put now consumes the new value so these extra calls<br>
- to free memory are no longer needed.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=1987 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0825<br>
-<br>
-pcl/pcl/pcsymbol.c<br>
-pcl/pl/pllfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-02 15:36: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=5ef3a531d00715c2b8bcfd38401515d4f60bfec5">5ef3a531d00715c2b8bcfd38401515d4f60bfec5</a>
-<blockquote>
-<p>
- Rejig order of operations from commit 47b1b7f971a76<br>
-<br>
- I'd forgotten that setcolorspace would blow away the current color, so we need<br>
- to get two sets of current color values, before setting the fill and stroke<br>
- color spaces, and then setting the file and stroke colors.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-24 13:23:34 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=93fc44b3426cd771ee0a9358da805cd2ac93a649">93fc44b3426cd771ee0a9358da805cd2ac93a649</a>
-<blockquote>
-<p>
- Fix gsapi exposure through the DLL.<br>
-<br>
- Lots of functions that should have been exposed, weren't.<br>
-<br>
-psi/dpmain.c<br>
-psi/dwdll.c<br>
-psi/dwdll.h<br>
-psi/gsdll32.def<br>
-psi/gsdll32metro.def<br>
-psi/gsdll64.def<br>
-psi/gsdll64metro.def<br>
-psi/gsdllARM32metro.def<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-19 18:43:33 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e6966d10ec319a25ad91e4aa53a783edede7b62b">e6966d10ec319a25ad91e4aa53a783edede7b62b</a>
-<blockquote>
-<p>
- Add gsapi call to introduce new 'Filing Systems' to gs.<br>
-<br>
- Still to do - Example?<br>
-<br>
-base/gdevpipe.c<br>
-base/gp.h<br>
-base/gp_mshdl.c<br>
-base/gp_msprn.c<br>
-base/gp_os2pr.c<br>
-base/gpmisc.c<br>
-base/gsdevice.c<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-base/stdpre.h<br>
-doc/API.htm<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-02 11:12: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=e585a31732e966f1508b64f04cacbaf8ede65c68">e585a31732e966f1508b64f04cacbaf8ede65c68</a>
-<blockquote>
-<p>
- Fix an out-of-date comment about devices in gstates<br>
-<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-02 11:06:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=47b1b7f971a760ff311bf3c3d8a02e2a2d53ac7d">47b1b7f971a760ff311bf3c3d8a02e2a2d53ac7d</a>
-<blockquote>
-<p>
- PDF interp: use initgraphics for initial color(space)<br>
-<br>
- Previously, the PDF interpreter explicitly set the initial color and color space<br>
- for each page ('0 g 0 G') despite initgraphics being called, and also setting<br>
- the color(space)s correctly.<br>
-<br>
- Unfortunately, removing that completely causes problems with pdfwrite's<br>
- transparency handling, so we reuse the already installed values in place<br>
- of explicitly setting absolute values.<br>
-<br>
- This should allow for preview-latex's (slightly hacky) method of custom coloring<br>
- 'special' PDFs for previewing.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-25 10:43: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=94cc50cf64e0899c5d415e6ac1e6ea725fc13502">94cc50cf64e0899c5d415e6ac1e6ea725fc13502</a>
-<blockquote>
-<p>
- Fix DELAYBIND<br>
-<br>
- We now undefine a *lot* of non-standard/internal operators (and other things) as<br>
- we go, and often we rely on bind to ensure that the names are replaced with the<br>
- operator objects rather than names.<br>
-<br>
- This falls over when DELAYBIND is in force, and the call to .bindnow happens<br>
- *after* the undefining occurs.<br>
-<br>
- To solve this, all the undefining happens through a procedure: .addtoundeflist.<br>
-<br>
- Under normal operation, that simply undefines as we go, and things work the same<br>
- as always.<br>
-<br>
- Under DELAYBIND .addtoundeflist accumulates a list of names to undefine, and the<br>
- dictionaries from where they should be removed, and on the .bindnow call, then<br>
- .applyundeflist is called which rattles through the lists removing the names<br>
- from the dictionaries.<br>
-<br>
-Resource/Init/gs_btokn.ps<br>
-Resource/Init/gs_cet.ps<br>
-Resource/Init/gs_cidfn.ps<br>
-Resource/Init/gs_dps2.ps<br>
-Resource/Init/gs_epsf.ps<br>
-Resource/Init/gs_fapi.ps<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_img.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_ll3.ps<br>
-Resource/Init/gs_res.ps<br>
-Resource/Init/gs_resmp.ps<br>
-Resource/Init/gs_setpd.ps<br>
-Resource/Init/gs_ttf.ps<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-02 10:36: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=871b8d8d5a26205a7a3c05ea9abf060a272fd6fb">871b8d8d5a26205a7a3c05ea9abf060a272fd6fb</a>
-<blockquote>
-<p>
- Tweak path access control logic<br>
-<br>
- Correctly handle the difference between permitted paths of the forms:<br>
- 'path', 'path/' and 'path/*'.<br>
-<br>
- The previous code effectively treated 'path/' and 'path/*' the same.<br>
-<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-20 12:24: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=1b83ee86dc775a9d7972d94041e226893983b264">1b83ee86dc775a9d7972d94041e226893983b264</a>
-<blockquote>
-<p>
- File access control: handle non-null terminated paths<br>
-<br>
- Add an access control checking API call that can take a non-null terminated<br>
- string (i.e. takes a string and length).<br>
-<br>
- The reason being the strings returned from gp_enumerate_files* are not null<br>
- terminated, and we need to filter them by permissions.<br>
-<br>
-base/gp.h<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-07-01 15:27: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=56158b2c2d8fb9bd5e5bbb9be645fb88231c4898">56158b2c2d8fb9bd5e5bbb9be645fb88231c4898</a>
-<blockquote>
-<p>
- Fix buffer overrun in mswinpr2 device<br>
-<br>
- Bug #701281 &quot;ACTIONABLE_HEAP_CORRUPTION when try print with -sOutputFile&quot;<br>
-<br>
- The mswinprs2 device uses the very old 16-bit GetProfileStringW() API<br>
- call to get the 'Devices' in order to look for a specified printer.<br>
-<br>
- The code however assumes that the buffer length passed is in bytes, and<br>
- in fact it should be in wchar_. This means that a sufficiently large<br>
- Devices section could overrun the buffer, as it thinks there are more<br>
- wchar_t available than there are.<br>
-<br>
- in addition, if the section is very large we could run out of space in<br>
- the string altogether, and then would be unable to find the designated<br>
- printer.<br>
-<br>
- This commit alters the code so that the length passed to GetProfileStringW<br>
- is in wchar_t and also examines the returned length. If the returned<br>
- length indicates possible truncation of the return, then we free the<br>
- buffer, increase its size by 4Kb and try again. Repeatedly until we<br>
- either exhaust memory or get a large enough buffer.<br>
-<br>
-devices/gdevwpr2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-18 21:21:10 +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=90ae60d1669ebf01228d05cdb58c248a2f971d07">90ae60d1669ebf01228d05cdb58c248a2f971d07</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent memory leaks in pcl_define_symbol_set.<br>
-<br>
- Cleanup symbol set for all error returns.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=15206 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0460<br>
-<br>
-pcl/pcl/pcsymbol.c<br>
-pcl/pl/pldict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-25 15:28: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=12ffa0f40b6849d97c1e4dc49287bca56f513f7f">12ffa0f40b6849d97c1e4dc49287bca56f513f7f</a>
-<blockquote>
-<p>
- pdfwrite - fix an error path<br>
-<br>
- This turned up while working on the PDF interpreter in C. Previously we<br>
- had no examples which exercised this error pathway, because it was only<br>
- used by PCL and none of our PCL examples threw an error here.<br>
-<br>
- If we've started accumulating a CharProc, then we have started a pdf<br>
- substream. If we get an error, then we need to terminate that substream<br>
- before returning (the caller can't know that the substream was begun).<br>
-<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-11 19:04: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=4f59b4dc4f512839fd73718de535da99c6085da3">4f59b4dc4f512839fd73718de535da99c6085da3</a>
-<blockquote>
-<p>
- First steps for using SSE for ROPs.<br>
-<br>
-base/gsroprun.c<br>
-base/gsroprun8.h<br>
-base/gsropt.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-04-19 12:45:14 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=140a9359f3cc6739c7caf0796430bc3112cb3cd5">140a9359f3cc6739c7caf0796430bc3112cb3cd5</a>
-<blockquote>
-<p>
- Initial import of CAL.<br>
-<br>
-Makefile.in<br>
-base/cal.mak<br>
-base/gdevdrop.c<br>
-base/gs.mak<br>
-base/gxicolor.c<br>
-base/gxidata.c<br>
-base/gximage.h<br>
-base/gximono.c<br>
-base/gxiscale.c<br>
-base/lib.mak<br>
-base/siscale_cal.c<br>
-base/sisparam.h<br>
-base/unix-gcc.mak<br>
-base/winlib.mak<br>
-configure.ac<br>
-psi/msvc.mak<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-24 16:35: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=dd75f619d0ae98e21e30ad89d2e7d2cd4277cc2e">dd75f619d0ae98e21e30ad89d2e7d2cd4277cc2e</a>
-<blockquote>
-<p>
- Preparatory work for the PDF interpreter in C<br>
-<br>
- Currently the pdfwrite device assumes that a font with FontType 3<br>
- (ft_user_defined) *will* require an exit to the interpreter. The<br>
- CharProc capture is set up so that this happens in a complicated dance.<br>
-<br>
- When we have the PDF interpreted in C we do not need to exit to the<br>
- interpreter, and so we need to capture the CharProc in the same way we<br>
- do for PCL 'user defined' fonts (eg the HPGL stick font and PCL bitmap<br>
- fonts).<br>
-<br>
- Obviously to be able to do this we need to be able to differentiate<br>
- between a PostScript type 3 font (or a type 3 font built by the PostScript<br>
- PDF interpreter) and a type 3 font built by the C PDF interpreter. So<br>
- the first thing we do is add a new ft_PDF_user_defined font tyep.<br>
-<br>
- Then update the graphics library so that it treats the PDF type 3 font<br>
- in exactly the same way as it does a PostScript type 3 font.<br>
-<br>
- In the pdfwrite device, in general we want to treat a PDF type 3 font<br>
- as being the same as a PS type 3.<br>
-<br>
- Finally, in pdf_text_process() the bulk of the real work. If we have a<br>
- ft_PDF_user_defined font, then set 'early_accumulator' which means we<br>
- push the accumulator early, because we won't need to exit to the<br>
- interpreter. This means that in the 'early_accumulator' branch we need<br>
- to account for the possibility that the text operation won't be a<br>
- 'TEXT_FROM_CHARS' (it always is for PCL, which is why this didn't need<br>
- to be handled before). There was also some bad error handling in here,<br>
- we do a gs_gsave() which is undone by a gs_grestore() in comp[ete_charproc()<br>
- but if we had an error before that we would not undo the gs_gsave whhich<br>
- could lead to ridiculous levels of nested gsaves.<br>
-<br>
-base/gstext.c<br>
-base/gxchar.c<br>
-base/gxftype.h<br>
-base/gxpaint.c<br>
-devices/vector/gdevpdtc.c<br>
-devices/vector/gdevpdtd.c<br>
-devices/vector/gdevpdte.c<br>
-devices/vector/gdevpdtf.c<br>
-devices/vector/gdevpdti.c<br>
-devices/vector/gdevpdts.c<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-22 10:49: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=9055511a9ca3600ee8680ea2b35b2f31f708bd40">9055511a9ca3600ee8680ea2b35b2f31f708bd40</a>
-<blockquote>
-<p>
- Improve -dFILTERIMAGE<br>
-<br>
- Previously if we were supplied too much image data, we could read off<br>
- the end of the supplied data and consume input that should have been<br>
- interpreted.<br>
-<br>
- This limits the consumption of data so that we don't read more than we<br>
- expected.<br>
-<br>
- NB! We still don't support type 3 images, as that requires us to process<br>
- 2 images at once.<br>
-<br>
-base/gdevoflt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-19 19:11: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=4f3f5aeb40be1562f05864705b0a04fbccae6fec">4f3f5aeb40be1562f05864705b0a04fbccae6fec</a>
-<blockquote>
-<p>
- Remove unused gsapi functions.<br>
-<br>
- gsapi_get_device_memory and gsapi_set_device aren't used, so<br>
- do away with them.<br>
-<br>
-psi/dwdll.h<br>
-psi/dwnodll.c<br>
-psi/gsdll2.def<br>
-psi/gsdll32.def<br>
-psi/gsdll32metro.def<br>
-psi/gsdll64.def<br>
-psi/gsdll64metro.def<br>
-psi/gsdllARM32metro.def<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-19 18:43:09 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c1500bb8ed62224e8b372fca76ed8e411cc447d1">c1500bb8ed62224e8b372fca76ed8e411cc447d1</a>
-<blockquote>
-<p>
- More gp_file vs FILE fixes.<br>
-<br>
-base/gp_vms.c<br>
-contrib/pcl3/src/pcl3opts.c<br>
-contrib/pscolor/test.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-20 19:22: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=ae73b49631e657b5ed5c3bf7936febf64a3f8b3c">ae73b49631e657b5ed5c3bf7936febf64a3f8b3c</a>
-<blockquote>
-<p>
- Fix Indexed 'install' procedure<br>
-<br>
- The Install procedure for Indexed spaces was calling the 'install'<br>
- procedure for its base space. This is incorrect. Colour spaces are<br>
- supposed to be set from the lowest (most 'base') to the highest. So the<br>
- Indexed space's base space should already be set, and installed. Trying<br>
- to set it again is a bad thing and can cause Seg Faults.<br>
-<br>
- However, the PCL interpreter relies on the Indexed space doing this,<br>
- contrary to the expected behaviour it does not set the base space before<br>
- setting the Indexed space, and relies on the Indexed space to 'install'<br>
- the base space.<br>
-<br>
- Setting the base space caused unexpected (and inexplicable) differences<br>
- in halftoned output. I 'suspect' that this is because it sets the three<br>
- initial components of pgs-&gt;color[0].ccolor, whereas the previous code<br>
- only resulted in setting the initial value.<br>
-<br>
- So instead, call the base space's 'install' procedure directly, this<br>
- doesn't set the colour values (which gs_setcolorspace does) and results<br>
- in no differences.<br>
-<br>
- For me this resolves the crashes that were being seen in the 32-bit<br>
- builds of Ghostscript and shows no differences.<br>
-<br>
-base/gscolor2.c<br>
-pcl/pcl/pcindxed.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-19 15:14:46 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=108dd018b746d33ad06a7ee863fae56cbeb1fd80">108dd018b746d33ad06a7ee863fae56cbeb1fd80</a>
-<blockquote>
-<p>
- &quot;Fix&quot; contrib and test uses of gp_fopen.<br>
-<br>
- Here we fix a lot of contrib devices that had been broken by the<br>
- changes to gp_file. I believe they all should work OK now.<br>
-<br>
- One of the routines was calling lib_fopen in an unsupported way; this<br>
- can't easily be fixed, so we just call gp_fopen instead now.<br>
-<br>
- We also &quot;fix&quot; some test code that was calling gp_fopen and then doing<br>
- things that we can't easily do with a gp_file *. This code has reverted<br>
- to using FILE *'s and fopen - this might cause issues on compilation as<br>
- this code is untested, but it's better than compiling to give code that<br>
- crashes.<br>
-<br>
-base/gp_vms.c<br>
-contrib/japanese/dviprlib.c<br>
-contrib/japanese/dviprlib.h<br>
-contrib/japanese/gdevdmpr.c<br>
-contrib/pscolor/test.c<br>
-devices/vector/gdevtxtw.c<br>
-psi/gserver.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-19 12:51: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=2c6484de7376ce4e24d87f1eb4c6f76360c9b928">2c6484de7376ce4e24d87f1eb4c6f76360c9b928</a>
-<blockquote>
-<p>
- Fix debug code to call gp_fopen correctly.<br>
-<br>
- These were missed during the conversion to gp_file.<br>
-<br>
-base/gdevp14.c<br>
-base/gsicc_create.c<br>
-base/gsicc_lcms2.c<br>
-base/gsicc_lcms2mt.c<br>
-base/gsicc_manage.c<br>
-base/gsicc_manage.h<br>
-base/gsroprun.c<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-19 09:42: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=b38aad870c573f7cafe99a95c3b931c1dc6cd132">b38aad870c573f7cafe99a95c3b931c1dc6cd132</a>
-<blockquote>
-<p>
- Remove some debug code<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-18 10:54: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=d4d7d6948e41c2573b47645191dbb7e3877f0597">d4d7d6948e41c2573b47645191dbb7e3877f0597</a>
-<blockquote>
-<p>
- Fix up some coverity issues, and other warnings<br>
-<br>
- CIDs: 341120, 341119, 341118, 341117, 341116, 341115, 341114, 341113, 341112,<br>
- 341111, 341110, 341109, 341108, 341107, 341106, 341105, 341104, 341103, 341102,<br>
- 341101.<br>
-<br>
- Mostly examples of gp_fseek and sscanf ignoring return values.<br>
-<br>
-base/gp_unifs.c<br>
-base/mkromfs.c<br>
-contrib/pcl3/eprn/pagecount.c<br>
-contrib/pcl3/src/gdevpcl3.c<br>
-contrib/pcl3/src/pclgen.c<br>
-contrib/pcl3/src/pclgen.h<br>
-devices/gdevdfax.c<br>
-devices/gdevpsd.c<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevxps.c<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/plmain.c<br>
-psi/imainarg.c<br>
-psi/iutil.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-14 09:10: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=29da5d218dac7e0975c03a81982fdc33b5eba20d">29da5d218dac7e0975c03a81982fdc33b5eba20d</a>
-<blockquote>
-<p>
- Make sure font Decoding is in the correct VM mode<br>
-<br>
-Resource/Init/gs_fntem.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-14 09:10: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=35b8b94e3ac3cced1b415c92b091c6959240755e">35b8b94e3ac3cced1b415c92b091c6959240755e</a>
-<blockquote>
-<p>
- Remove stray exec and some pointless immediate evaluations<br>
-<br>
-Resource/Init/gs_fapi.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-14 09:16: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=adc94490502a360c3bdf8843888f784d57066c0e">adc94490502a360c3bdf8843888f784d57066c0e</a>
-<blockquote>
-<p>
- PDF interpreter - improve repair of broken PDF files<br>
-<br>
- If a file had a startxref token which was not followed by any further<br>
- actual tokens (eg nothing but % comment lines) then the repair code<br>
- failed to account for this, and ended up trying to pop non-existent<br>
- objects from the stack.<br>
-<br>
- This is because the code did not test the result of the 'token' operator<br>
- to ensure that a token had been read, it assumed one would be. In this<br>
- commit we check the result and, if its 'false' (no token read) we don't<br>
- attempt to pop the non-existent token from the stack, but instead follow<br>
- the existing error path and resort to scanning the PDF file for the<br>
- trailer dictionary.<br>
-<br>
- In addition to fixing the customer reported file, this also fixes the<br>
- existing test suite file<br>
-<br>
- tests_private/pdf/sumatra/repairing_leaks_object.pdf<br>
-<br>
-Resource/Init/pdf_rbld.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-12 15:35: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=8522db03fde6b1b514beed9d66faa839f24ebdc4">8522db03fde6b1b514beed9d66faa839f24ebdc4</a>
-<blockquote>
-<p>
- Make .pdfexectoken not an operator<br>
-<br>
- In a previously round of security fixes, I made .pdfexectoken an operator. That<br>
- turns out to cause problems because we (normally) attempt to recover from errors<br>
- in PDF files, so we don't want .pdfexectoken to cleanup the stacks in the event<br>
- of an error.<br>
-<br>
- In addition, the original problem this solved is solved in a more robust way<br>
- (executeonly on the transient procedures).<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-11 20:29:53 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=094b9caade51b718a20b8d326fff9e0f93166cd4">094b9caade51b718a20b8d326fff9e0f93166cd4</a>
-<blockquote>
-<p>
- Bug 698777: jbig2dec: Update information in README.<br>
-<br>
-jbig2dec/README<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-10 17:22:04 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20a6ddad3cd42796c913ab94583fc0f0e5870281">20a6ddad3cd42796c913ab94583fc0f0e5870281</a>
-<blockquote>
-<p>
- Fix gpdl SAFER operation.<br>
-<br>
- -sOutputFile=foo was having the pass set as &quot;=foo&quot; due to<br>
- me forgetting to increment the pointer. This resulted in<br>
- many thousands of errors in the weekly SAFER test.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-10 16:24: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=ee8ab38bab473ff1457e7f966b2733f0c829bcb1">ee8ab38bab473ff1457e7f966b2733f0c829bcb1</a>
-<blockquote>
-<p>
- PDF interpreter - don't execute newpath when ending text blocks<br>
-<br>
- Bug 701178 - &quot;PDF missing two bounding boxes on process&quot;<br>
-<br>
- The missing rectangles are defind in the content stream between a<br>
- number of BT/ET text blocks, and only finally stroked after all the<br>
- text has been emitted.<br>
-<br>
- Because we execute a newpath when ending a text block (to avoid dangling<br>
- path elements from text), and prior path elements are lost.<br>
-<br>
- This commit only executes a newpath when the text rendering mode is one<br>
- of the 'clip' modes, as that is handled differently, and we need the<br>
- newpath.<br>
-<br>
- Its a pretty poor way to output the paths, and I suspect that it would<br>
- likely run into trouble with the text clipping modes, but since those<br>
- aren't used here its hard to tell.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-07 13:58:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8eaa0856399c9b621db17e96c8f7be1e0241ab8b">8eaa0856399c9b621db17e96c8f7be1e0241ab8b</a>
-<blockquote>
-<p>
- Fix AES-256 decryption when using owner key<br>
-<br>
- The code for computing the decryption key for AES-256 encrypted PDF<br>
- files was incorrect. When computing the validation check we correctly<br>
- used the owner key if it was supplied, but for computing the actual<br>
- decryption key we always treated the supplied password as the user<br>
- password.<br>
-<br>
-psi/zpdf_r6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-05 09:55: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=b31fb3c0cd7ab223d870fa1e0fb231d911b19984">b31fb3c0cd7ab223d870fa1e0fb231d911b19984</a>
-<blockquote>
-<p>
- Modify the new gp_file API so that gp_fread etc match fread<br>
-<br>
- The new gp_fread() and gp_fwrite() have a parameter list which (more or<br>
- less) matches the list for the C run-time functions fread() and fwrite()<br>
-<br>
- However, the return values do not match the returned values from the<br>
- C runtime functions. This is because, internally, the gp_file structure<br>
- has function pointers which only take 3 parameters instead of 4. This<br>
- is handled by multiplying the size of the record by the number of records<br>
- to be read/written, and then reading that many bytes.<br>
-<br>
- Since the underlying functions are (at this time) the C runtime functions<br>
- this means that th returned value becomes the number of bytes read<br>
- (or written) instead of the number of *records* read/written.<br>
-<br>
- This commit modifies that internal API so that the gp_file member<br>
- functions take 4 parameters (thus matching both gp_fread and fread)<br>
- and pass them to the underlying functions. The return value is then<br>
- the number of records, as expected.<br>
-<br>
- Should we ever encounter an implementation which doesn't match the<br>
- C runtime fread() we could implement it by multiplying the size by the<br>
- count (as was done prior to this commit) and then, assuming the return<br>
- value was the number of bytes read, dividing the return value by the<br>
- size, in order to retrieve the number of records read.<br>
-<br>
-base/gp.h<br>
-base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-07 12:11:57 +0100
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ee8864ae09ff0017e5503bde1f5b52538759babc">ee8864ae09ff0017e5503bde1f5b52538759babc</a>
-<blockquote>
-<p>
- Ensure that separation CMYK source colors managed<br>
-<br>
- This is the separation version of the DeviceN commit<br>
-<br>
- http://git.ghostscript.com/?p=ghostpdl.git;a=commit;h=0b9c45fa86f7736e7fec170a135efa83636283ba<br>
-<br>
-base/gdevp14.c<br>
-base/gscsepr.c<br>
-base/gsequivc.c<br>
-base/gxcmap.c<br>
-base/gxcmap.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-01 11:09: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=d5e123d42718370c144a62ba10a7b715cc88b81a">d5e123d42718370c144a62ba10a7b715cc88b81a</a>
-<blockquote>
-<p>
- Graphics library - match gsaves with grestores<br>
-<br>
- Auditing as part of the pdfi work, when the graphics library executes<br>
- a gs_gsave() it should match it with a gs_grestore(), even in the case<br>
- of an error.<br>
-<br>
- In addition, if gs_setcolorspace failed in image_PaintProc() it would<br>
- leak the pattern enumerator. Because this is only called from PCL<br>
- the memory is not garbage collected.<br>
-<br>
-base/gsptype1.c<br>
-base/gxchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-03 18:28:18 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c9a832653a91ddcdd1220fe9fbbc58839eade4aa">c9a832653a91ddcdd1220fe9fbbc58839eade4aa</a>
-<blockquote>
-<p>
- Fix leak in gs_lib_ctx_fin.<br>
-<br>
- When freeing gs_lib_ctx, don't remove the mem-&gt;gs_lib_ctx pointers<br>
- until after we have finished using them. This avoids a leak.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-06-03 14:19:54 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b052ff372bbd325676d2e1a57dfd71c33c9f677">7b052ff372bbd325676d2e1a57dfd71c33c9f677</a>
-<blockquote>
-<p>
- Update gpdl with new file access permissions.<br>
-<br>
- This basically involves duplicating the changes from Chris'<br>
- gs commit. Part of this promotes a couple of static functions<br>
- to being global ones so both implementations can call them.<br>
-<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-pcl/pl/plmain.c<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-29 15:56: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=650c49424529fca922519ee9cdf2086eee5cfb70">650c49424529fca922519ee9cdf2086eee5cfb70</a>
-<blockquote>
-<p>
- Fix broken DEBUG build. Add standalone gs_log_error to mkromfs.c<br>
-<br>
- This function is invoked for DEBUG builds by gs_note_error. We define<br>
- an equivalent local version so we don't have to include gsmisc.obj<br>
- (as for other utility functions such as outprintf).<br>
-<br>
-base/mkromfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-29 13:20: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=f5c0159d993418a8900a84e5fd946e83bdaeec73">f5c0159d993418a8900a84e5fd946e83bdaeec73</a>
-<blockquote>
-<p>
- Fix dfaxhigh/low device with new gp_file API.<br>
-<br>
- Arose in the &quot;all devices&quot; cluster test<br>
-<br>
-devices/gdevdfax.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-07 11:30: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=7ecbfda92b4c8dbf6f6c2bf8fc82020a29219eff">7ecbfda92b4c8dbf6f6c2bf8fc82020a29219eff</a>
-<blockquote>
-<p>
- Add use of new file access permissions to PS interp<br>
-<br>
- (this is a squash of several commits from filesec branch)<br>
-<br>
- Use errno to indicate invalidfileaccess<br>
-<br>
- Integrate fontconfig with file access controls<br>
-<br>
- fontconfig API has a call to retrieve all the directories about which fontconfig<br>
- knows, so we can get those, and add them to the paths from which we're permitted<br>
- to read.<br>
-<br>
- Add (most of) the Postscript &quot;managed&quot; paths....<br>
-<br>
- ...to the access controls.<br>
-<br>
- GenericResourceDir, ICCProfilesDir (reading) and temporary file directories for<br>
- read/write/control.<br>
-<br>
- Add paths/files from C to the file access controls<br>
-<br>
- The -I paths, environment variables and build time paths.<br>
-<br>
- The command line specified output file, permit writing.<br>
-<br>
- Lastly, the command line specified input file is added to the readable list,<br>
- interpreted, and then removed from the list.<br>
-<br>
- Add the FONTPATH path list to permit read access control list.<br>
-<br>
- I opted to do this in Postscript because the list is (normally) a colon<br>
- separated list of paths, which we split into an array of paths (in Postscript) -<br>
- it seems sensible to do this only once, both for storage and permissions.<br>
-<br>
- Add a non-standard string 'reverse search&quot; operator<br>
-<br>
- The search operator searches for the first occurrence of a character code in a<br>
- string (i.e. searches forwards from the start of the string), 'rsearch' finds<br>
- the last instance of a character code (i.e. search backwards from the end of<br>
- the string).<br>
-<br>
- Fix gp_open_scratch_file_rm for access permissions<br>
-<br>
- i.e. the same as gp_open_scratch_file<br>
-<br>
- Handle clist file 'rewind' failures<br>
-<br>
- 'Rewinding' clist files may involved closing and recreating the temporary files,<br>
- which conceivably can fail, but the clist procs rewind method was a void<br>
- function, so couldn't return an error.<br>
-<br>
- It now can, and does return an error, and we handle the error.<br>
-<br>
- Add file permissions support for piped output.<br>
-<br>
- Paths from Fontmap to PermitReading list<br>
-<br>
- cidfmap paths, add to PermitReading list<br>
-<br>
- Add command line options for path access control addition<br>
-<br>
- --permit-file-read<br>
- --permit-file-write<br>
- --permit-file-control<br>
- --permit-file-all<br>
-<br>
- They all take a separated list of paths (the usual platform specific ':' or ';'<br>
- separator), and to the respective access control lists - the final 'all' option<br>
- adds the paths to all the control lists.<br>
-<br>
- Add file access control to the 'gp_stat' method.<br>
-<br>
- This is complicated by the need to add the memory allocator context to the<br>
- gp_stat parameters. To facilitate this, I've added a gs_memory_t pointer to the<br>
- gx_io_device structure, which is set during the io device initialisation at<br>
- startup.<br>
-<br>
- mkromfs: Add dummy gp_stat_impl for Windows - saves quite a bit of pointless<br>
- build upheaval<br>
-<br>
- Add file access protection to file enumeration.<br>
-<br>
- The low level implementation of Postscript's filenameforall (*_enumerate_files)<br>
- needs to also honour file access protection.<br>
-<br>
- This is has been complicated by requiring a gs_memory_t to be available where<br>
- it wasn't previously (in order to access the gs_lib_ctx and the file permissions<br>
- lists therein).<br>
-<br>
- Temp<br>
-<br>
-Resource/Init/gs_cidfm.ps<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_init.ps<br>
-base/gdevpipe.c<br>
-base/gp.h<br>
-base/gp_dosfe.c<br>
-base/gp_mshdl.c<br>
-base/gp_msprn.c<br>
-base/gp_mswin.c<br>
-base/gp_ntfs.c<br>
-base/gp_os2fs.c<br>
-base/gp_os2pr.c<br>
-base/gp_unifs.c<br>
-base/gp_unix.c<br>
-base/gp_vms.c<br>
-base/gpmisc.c<br>
-base/gsiodev.c<br>
-base/gsiodevs.c<br>
-base/gsiodisk.c<br>
-base/gsioram.c<br>
-base/gsiorom.c<br>
-base/gxclfile.c<br>
-base/gxclio.h<br>
-base/gxclist.c<br>
-base/gxclmem.c<br>
-base/gxclread.c<br>
-base/gxiodev.h<br>
-base/gxp1fill.c<br>
-base/lib.mak<br>
-base/mkromfs.c<br>
-base/stat_.h<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/pllfont.c<br>
-psi/imain.c<br>
-psi/imainarg.c<br>
-psi/zdevcal.c<br>
-psi/zfile.c<br>
-psi/ziodev.c<br>
-psi/ziodev2.c<br>
-psi/ziodevsc.c<br>
-psi/zstring.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-07 18:03:00 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9de16a6637b73e35f79d2d622de403b24e6502f2">9de16a6637b73e35f79d2d622de403b24e6502f2</a>
-<blockquote>
-<p>
- Move FILE * operations behind new gp_file * API.<br>
-<br>
- (squash of commits from filesec branch)<br>
-<br>
- Most of this commit is donkeywork conversions of calls from<br>
- FILE * -&gt; gp_file *, fwrite -&gt; gp_fwrite etc. Pretty much every<br>
- device is touched, along with the clist and parsing code.<br>
-<br>
- The more interesting changes are within gp.h (where the actual<br>
- new API is defined), gpmisc.c (where the basic implementations<br>
- live), and the platform specific levels (gp_mswin.c, gp_unifs.c<br>
- etc where the platform specific implementations have been<br>
- tweaked/renamed).<br>
-<br>
- File opening path validation<br>
-<br>
- All file opening routines now call a central routine for<br>
- path validation.<br>
-<br>
- This then consults new entries in gs_lib_ctx to see if validation<br>
- is enabled or not. If so, it validates the paths by seeing if<br>
- they match.<br>
-<br>
- Simple C level functions for adding/removing/clearing paths, exposed<br>
- through the gsapi level.<br>
-<br>
- Add 2 postscript operators for path control.<br>
-<br>
- &lt;name&gt; &lt;string&gt; .addcontrolpath -<br>
-<br>
- Add the given &lt;string&gt; (path) to the list of paths for<br>
- controlset &lt;name&gt;, where &lt;name&gt; can be:<br>
- /PermitFileReading<br>
- /PermitFileWriting<br>
- /PermitFileControl<br>
- (Anything else -&gt; rangecheck)<br>
-<br>
- - .activatepathcontrol -<br>
-<br>
- Enable path control. At this point PS cannot make any<br>
- more changes, and all file access is checked.<br>
-<br>
-base/gdebug.h<br>
-base/gdevdevn.c<br>
-base/gdevp14.c<br>
-base/gdevpccm.c<br>
-base/gdevpccm.h<br>
-base/gdevpipe.c<br>
-base/gdevprn.c<br>
-base/gdevprn.h<br>
-base/gdevvec.c<br>
-base/gdevvec.h<br>
-base/gp.h<br>
-base/gp_dosfs.c<br>
-base/gp_dvx.c<br>
-base/gp_mshdl.c<br>
-base/gp_msprn.c<br>
-base/gp_mswin.c<br>
-base/gp_ntfs.c<br>
-base/gp_os2.c<br>
-base/gp_os2fs.c<br>
-base/gp_os2pr.c<br>
-base/gp_os9.c<br>
-base/gp_unifs.c<br>
-base/gp_unix.c<br>
-base/gp_vms.c<br>
-base/gp_win32.c<br>
-base/gp_winfs.c<br>
-base/gp_winfs2.c<br>
-base/gpmisc.c<br>
-base/gpmisc.h<br>
-base/gsargs.c<br>
-base/gsargs.h<br>
-base/gsdevice.c<br>
-base/gsicc_create.c<br>
-base/gsicc_lcms2.c<br>
-base/gsicc_lcms2mt.c<br>
-base/gsicc_manage.c<br>
-base/gsinit.c<br>
-base/gsiodev.c<br>
-base/gsiodevs.c<br>
-base/gsiodisk.c<br>
-base/gsioram.c<br>
-base/gsiorom.c<br>
-base/gslib.h<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-base/gsmemory.h<br>
-base/gsmisc.c<br>
-base/gsroprun.c<br>
-base/gstiffio.c<br>
-base/gstiffio.h<br>
-base/gxblend.c<br>
-base/gxblend1.c<br>
-base/gxclfile.c<br>
-base/gxdevice.h<br>
-base/gxiodev.h<br>
-base/gxpcmap.c<br>
-base/lib.mak<br>
-base/msvctail.mak<br>
-base/sfxcommon.c<br>
-base/sfxfd.c<br>
-base/sfxstdio.c<br>
-base/stdpre.h<br>
-base/stream.h<br>
-base/tiff.mak<br>
-base/winlib.mak<br>
-contrib/contrib.mak<br>
-contrib/eplaser/gdevescv.c<br>
-contrib/gdevbjc_.c<br>
-contrib/gdevbjc_.h<br>
-contrib/gdevbjca.c<br>
-contrib/gdevcd8.c<br>
-contrib/gdevdj9.c<br>
-contrib/gdevgdi.c<br>
-contrib/gdevhl12.c<br>
-contrib/gdevln03.c<br>
-contrib/gdevlx32.c<br>
-contrib/gdevlx7.c<br>
-contrib/gdevmd2k.c<br>
-contrib/gdevop4w.c<br>
-contrib/gdevxes.c<br>
-contrib/japanese/dviprlib.c<br>
-contrib/japanese/gdev10v.c<br>
-contrib/japanese/gdevalps.c<br>
-contrib/japanese/gdevdmpr.c<br>
-contrib/japanese/gdevespg.c<br>
-contrib/japanese/gdevfmlbp.c<br>
-contrib/japanese/gdevfmpr.c<br>
-contrib/japanese/gdevj100.c<br>
-contrib/japanese/gdevlbp3.c<br>
-contrib/japanese/gdevmjc.c<br>
-contrib/japanese/gdevml6.c<br>
-contrib/japanese/gdevnpdl.c<br>
-contrib/japanese/gdevp201.c<br>
-contrib/japanese/gdevrpdl.c<br>
-contrib/lips4/gdevl4r.c<br>
-contrib/lips4/gdevl4v.c<br>
-contrib/lips4/gdevlprn.c<br>
-contrib/lips4/gdevlprn.h<br>
-contrib/opvp/gdevopvp.c<br>
-contrib/pcl3/eprn/eprnparm.c<br>
-contrib/pcl3/eprn/gdeveprn.c<br>
-contrib/pcl3/eprn/pagecount.c<br>
-contrib/pcl3/eprn/pagecount.h<br>
-contrib/pcl3/src/gdevpcl3.c<br>
-contrib/pcl3/src/pcl3opts.c<br>
-contrib/pcl3/src/pclgen.c<br>
-contrib/pcl3/src/pclgen.h<br>
-contrib/pcl3/src/pclscan.c<br>
-cups/gdevcups.c<br>
-devices/contrib.mak<br>
-devices/devs.mak<br>
-devices/gdev3852.c<br>
-devices/gdev4081.c<br>
-devices/gdev4693.c<br>
-devices/gdev8510.c<br>
-devices/gdevatx.c<br>
-devices/gdevbit.c<br>
-devices/gdevbj10.c<br>
-devices/gdevbmp.c<br>
-devices/gdevbmp.h<br>
-devices/gdevbmpc.c<br>
-devices/gdevccr.c<br>
-devices/gdevcdj.c<br>
-devices/gdevcfax.c<br>
-devices/gdevchameleon.c<br>
-devices/gdevcif.c<br>
-devices/gdevclj.c<br>
-devices/gdevcljc.c<br>
-devices/gdevcmykog.c<br>
-devices/gdevcslw.c<br>
-devices/gdevdfax.c<br>
-devices/gdevdjet.c<br>
-devices/gdevdjtc.c<br>
-devices/gdevdljm.c<br>
-devices/gdevdljm.h<br>
-devices/gdevdm24.c<br>
-devices/gdevepsc.c<br>
-devices/gdevepsn.c<br>
-devices/gdevescp.c<br>
-devices/gdevfax.c<br>
-devices/gdevfax.h<br>
-devices/gdevfpng.c<br>
-devices/gdevgprf.c<br>
-devices/gdevhl7x.c<br>
-devices/gdevicov.c<br>
-devices/gdevifno.c<br>
-devices/gdevijs.c<br>
-devices/gdevimgn.c<br>
-devices/gdevjbig2.c<br>
-devices/gdevjpeg.c<br>
-devices/gdevjpx.c<br>
-devices/gdevl31s.c<br>
-devices/gdevlbp8.c<br>
-devices/gdevlj56.c<br>
-devices/gdevlp8k.c<br>
-devices/gdevlxm.c<br>
-devices/gdevmgr.c<br>
-devices/gdevmiff.c<br>
-devices/gdevn533.c<br>
-devices/gdevo182.c<br>
-devices/gdevokii.c<br>
-devices/gdevpbm.c<br>
-devices/gdevpcx.c<br>
-devices/gdevpdfimg.c<br>
-devices/gdevperm.c<br>
-devices/gdevphex.c<br>
-devices/gdevpjet.c<br>
-devices/gdevplan.c<br>
-devices/gdevplib.c<br>
-devices/gdevpng.c<br>
-devices/gdevpsd.c<br>
-devices/gdevpsd.h<br>
-devices/gdevpsim.c<br>
-devices/gdevpxut.c<br>
-devices/gdevpxut.h<br>
-devices/gdevrinkj.c<br>
-devices/gdevsj48.c<br>
-devices/gdevstc.c<br>
-devices/gdevtfax.c<br>
-devices/gdevtfax.h<br>
-devices/gdevtfnx.c<br>
-devices/gdevtifs.c<br>
-devices/gdevtifs.h<br>
-devices/gdevtknk.c<br>
-devices/gdevtsep.c<br>
-devices/gdevupd.c<br>
-devices/gdevwpr2.c<br>
-devices/gdevxcf.c<br>
-devices/rinkj/rinkj-byte-stream.c<br>
-devices/rinkj/rinkj-byte-stream.h<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfo.c<br>
-devices/vector/gdevpdfp.c<br>
-devices/vector/gdevpdfu.c<br>
-devices/vector/gdevpdfx.h<br>
-devices/vector/gdevpsu.c<br>
-devices/vector/gdevpsu.h<br>
-devices/vector/gdevpx.c<br>
-devices/vector/gdevtxtw.c<br>
-devices/vector/gdevxps.c<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pl/plparams.c<br>
-pcl/pl/pltop.h<br>
-psi/files.h<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-psi/imain.c<br>
-psi/imain.h<br>
-psi/imainarg.c<br>
-psi/imainarg.h<br>
-psi/iminst.h<br>
-psi/int.mak<br>
-psi/psapi.c<br>
-psi/zfile.c<br>
-windows/ghostscript.vcproj<br>
-xps/ghostxps.h<br>
-xps/xpsjxr.c<br>
-xps/xpstop.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-28 16:08:26 +0100
-</strong>
-<br>Chris Lidell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=808021913baf763e07cc9eabc3716bfa507380ff">808021913baf763e07cc9eabc3716bfa507380ff</a>
-<blockquote>
-<p>
- Bug 701083(2): Write the new key/value to DecodeParms<br>
-<br>
- There was a lengthy block of code that handled PDFs with buggy DCTDecode<br>
- dictionaries with a missing, or incorrect Height entry. Since we now have a<br>
- second key/value needing added to the DecodeParms and in two places, I've<br>
- split that into a more general procedure, so we can add multiple new keys in<br>
- one step.<br>
-<br>
- This is used to add/patch the Height key, and add the new ErrsAsEOD key<br>
- (telling the CCITT fax decode filter to treat an error as a EOD).<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-27 19:00: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=1a344ed8506e46e77a0c58aed57de69ce8f54a20">1a344ed8506e46e77a0c58aed57de69ce8f54a20</a>
-<blockquote>
-<p>
- Bug 701083: Add key to treat errors as end of data when decoding images.<br>
-<br>
- This specifically only applies to the CCITT decode filter at the<br>
- moment, but the key will be in place for all image decoders to look<br>
- at if required.<br>
-<br>
- A following commit will cause the PDF interpreter to set this key<br>
- in the DecodeParms.<br>
-<br>
-base/scfd.c<br>
-base/scfparam.c<br>
-base/scfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-27 15:33: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=c1739dcc6a8ceda1a5091c1b7dc8bb4870c6c76b">c1739dcc6a8ceda1a5091c1b7dc8bb4870c6c76b</a>
-<blockquote>
-<p>
- Fix a couple more compiler warnings.<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-24 14:32: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=e2e83fb18feeae8786c16c0c309f9c1efdea2614">e2e83fb18feeae8786c16c0c309f9c1efdea2614</a>
-<blockquote>
-<p>
- Bug 700956: don't free text enumerator in error condition<br>
-<br>
- Some errors mean the graphics library will decrement the reference count,<br>
- potentially freeing, the text enumerator. So, on return to the interpreter<br>
- don't try to free it.<br>
-<br>
- In these cases we can safely rely on the garbager to clean up the memory if the<br>
- graphics library didn't.<br>
-<br>
-psi/zchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-24 09:50: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=f8b9b5d02f2ba59256c92f6015eda02cb5d16c9e">f8b9b5d02f2ba59256c92f6015eda02cb5d16c9e</a>
-<blockquote>
-<p>
- Fix a trivial (probably benign) compiler warning<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-23 11:09: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=c1844f1adbd7e1b215dde46d6211a84af5cea8a4">c1844f1adbd7e1b215dde46d6211a84af5cea8a4</a>
-<blockquote>
-<p>
- Fix FONTPATH font file enumeration<br>
-<br>
- As part of improving security, we had replaced the reference using the name<br>
- .scanfontheaders to find the array of headers for file types to scan with<br>
- the immediatetly evaluated //.scanfontheaders in gs_fonts.ps<br>
-<br>
- That doesn't work correctly because the array is redefined multiple times<br>
- as we add support for various font types during initialisation.<br>
-<br>
- Fix it by replacing the immediate evaluation with explicitly using the name key<br>
- /.scanfontheaders to pull the array from systemdict.<br>
-<br>
-Resource/Init/gs_cff.ps<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-23 11:18:06 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e42161d209e220aa84615b0af7efc7507f0f5397">e42161d209e220aa84615b0af7efc7507f0f5397</a>
-<blockquote>
-<p>
- Fix crash when the default font can't be found.<br>
-<br>
- Making .loadfontloop into an operator messes up the error condition recovery<br>
- when we've had to fall back to the default font, and even that is not<br>
- available (i.e. when GenericResourceDir is set to somewhere that isn't actually<br>
- a viable resource directory).<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-22 19:07:07 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c2d78d6fd563bb3137991ce9f74ec2379e0de9aa">c2d78d6fd563bb3137991ce9f74ec2379e0de9aa</a>
-<blockquote>
-<p>
- Remove unnecessary but harmless conditional from the last commit.<br>
-<br>
-pcl/pcl/pctop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-22 13:36:31 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=690adf6efb53e61e965e6f37cd78b060b2fdb233">690adf6efb53e61e965e6f37cd78b060b2fdb233</a>
-<blockquote>
-<p>
- Fix bug 701045 - infinite loop in pcl parser.<br>
-<br>
- The recent work to remove the specialized PL cursor code and replace<br>
- it with streams removed end of data detection PCL depended on. End of<br>
- data is now detected by the PCL parser by requiring a minimum number<br>
- of bytes on the next call to the parser. If the required number of<br>
- bytes are not provided the parser signals end of data by advancing the<br>
- read pointer to the end of the buffer.<br>
-<br>
- The change precipitated some reorganization in how RTL is initialized,<br>
- as well.<br>
-<br>
-pcl/pcl/pcl.mak<br>
-pcl/pcl/pcmacros.c<br>
-pcl/pcl/pcparse.c<br>
-pcl/pcl/pcparse.h<br>
-pcl/pcl/pcsfont.c<br>
-pcl/pcl/pctop.c<br>
-pcl/pxl/pxpthr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-28 17:21:02 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1058e51507f4dfb483c104dd83e77375e62181b4">1058e51507f4dfb483c104dd83e77375e62181b4</a>
-<blockquote>
-<p>
- Fix bug #700844, crash with very long font path.<br>
-<br>
- A long font path, specified by setting the environment variable<br>
- PCLFONTSOURCE, resulted in buffer overflows in both PJL and PCL. Also,<br>
- simplify the logic to load fonts in PCL because it is not<br>
- necessary to parse a path list, a single path has been already been<br>
- parsed in PJL.<br>
-<br>
- Related coverity id's addressed with this change are: 102193, 102206,<br>
- 102208, and 102210.<br>
-<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/pllfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-11 11:18:23 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a5637d2248501998ca9bb16bc51c93dd15a2d0d">7a5637d2248501998ca9bb16bc51c93dd15a2d0d</a>
-<blockquote>
-<p>
- Remove unnecessary include file left from a test.<br>
-<br>
-pcl/pl/plfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-22 18:04: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=3a9bb467fa9ff18ca398081c32edddc6732ce75e">3a9bb467fa9ff18ca398081c32edddc6732ce75e</a>
-<blockquote>
-<p>
- Add gpdl to default products for clusterpush.pl<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-22 17:58:25 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=979f09479916c799d5df30df85c6caa30f86bffc">979f09479916c799d5df30df85c6caa30f86bffc</a>
-<blockquote>
-<p>
- Add nopdfwrite to clusterpush.pl<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-21 07:39:49 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd4be3eb2b28ff67dc3ee6e636bf7024bf9d1003">dd4be3eb2b28ff67dc3ee6e636bf7024bf9d1003</a>
-<blockquote>
-<p>
- Add check for gs_error_handled for pattern handling<br>
-<br>
- Some clients (specifically gpdfi) can now return gs_error_handled if<br>
- they already took care of everything in the PaintProc call. In this<br>
- case, just do all the cleanup as for any other error, but it's not<br>
- really an error, so return error code 0.<br>
-<br>
- This wll be needed for pdfi when merged in, should have no affect on current<br>
- code.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-20 12:32:13 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b925a84a9cbbeabba391d50f08b7064688298c2">2b925a84a9cbbeabba391d50f08b7064688298c2</a>
-<blockquote>
-<p>
- Add gsapi_set_param to iapi.h as well.<br>
-<br>
- This keeps the gs and gpdl implementations of gsapi in sync.<br>
-<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-20 13:07:13 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8aa6f8ce98e19ddc1a30b924169abf091748c1a9">8aa6f8ce98e19ddc1a30b924169abf091748c1a9</a>
-<blockquote>
-<p>
- Fix warnings in pjparse.c<br>
-<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/pl.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-17 18:51:13 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b932ec31114e4e7a7ace0089cb87ddb70dc7732f">b932ec31114e4e7a7ace0089cb87ddb70dc7732f</a>
-<blockquote>
-<p>
- Add gsapi_set_param to gpdl gsapi.<br>
-<br>
- This takes an enumerated type and values, to allow programmatic<br>
- setting equivalent to -d and -s on the command line.<br>
-<br>
- These should only be called between jobs, and then with care.<br>
-<br>
- Values are set in the device parameters and then passed to each<br>
- language implementation in turn.<br>
-<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pl/pltop.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-16 19:59:58 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc9c23ed944f653e384fd12fbaf6328e8bab8a33">dc9c23ed944f653e384fd12fbaf6328e8bab8a33</a>
-<blockquote>
-<p>
- PJL GSSET and GSSETSTRING<br>
-<br>
- Add GSSET and GSSETSTRING PCL commands for setting device<br>
- parameters/language parameters from PJL.<br>
-<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-18 13:52:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=85c99aa093d4e26b9f40c0a4eb686a7f5b2b2d64">85c99aa093d4e26b9f40c0a4eb686a7f5b2b2d64</a>
-<blockquote>
-<p>
- pdfwrite - fix ColorConversionStrategy<br>
-<br>
- No bug number, this arose from a question asked on Stack Overflow.<br>
-<br>
- At some point I removed the enumerated value ccs_UseDeviceDependentColor<br>
- but I failed to remove the name &quot;UseDeviceDependentColor&quot; from the<br>
- list of strategy names. This meant that setting ColorConversionStrategy<br>
- to anything except LeaveColorUnchanged was 'out by 1' in the enumerated<br>
- data type.<br>
-<br>
- This led (for example) to Gray being treated as RGB for the purposes<br>
- of the output colour space.<br>
-<br>
-devices/vector/gdevpsdf.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-08 08:19:55 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=95f7befcec1b30fd5014c8ad616485d32901ce33">95f7befcec1b30fd5014c8ad616485d32901ce33</a>
-<blockquote>
-<p>
- Make sure transparency page group is isolated<br>
-<br>
- Per the spec, the page group should be treated as an isolated<br>
- group. This allows the page group to specify a blending color space.<br>
- This resulted in over 90 pages of bmpcmp diffs. I went over all<br>
- of them. They are progressions. Most are very minor color differences<br>
- as we end up doing the blending and drawings in different color spaces<br>
- compared to prior to the commit<br>
-<br>
-base/gstrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-17 14:37:30 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ebe7cd2b5a7a000c5ebf0bfa061f872faaf098e3">ebe7cd2b5a7a000c5ebf0bfa061f872faaf098e3</a>
-<blockquote>
-<p>
- Handle trans group knockouts properly if page group is isolated<br>
-<br>
- Page groups by definition have to be isolated. A fix for this to<br>
- ensure that the proper group color space is used for the page group<br>
- revealed a problem when the source PDF actually indicated the page<br>
- group was isolated. This led to an incorrect selection of subsequent<br>
- backdrops for any knockout groups contained.<br>
-<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-17 11:20: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=ee8a1c574198351d3ec1b181428d3d0159b4f80a">ee8a1c574198351d3ec1b181428d3d0159b4f80a</a>
-<blockquote>
-<p>
- PDF interpreter - ignore errors in some faulty FreeText annotations<br>
-<br>
- Bug #701058 &quot;Can not convert pdf to tiff&quot;<br>
-<br>
- The PDF file has a FreeText annotation with no appearance stream and<br>
- faults in the Annotation dictionary.<br>
-<br>
- Firstly (not perhaps strictly a fault) the /Contents key has a string<br>
- value with nothing in it. This isn't exactly an error, but it makes the<br>
- annotation pointless.<br>
-<br>
- More seriously the /DA key contains:<br>
-<br>
- (//Helvetica 12 Tf 0 g)<br>
-<br>
- The double // on the font name means we end up with an empty name<br>
- on the stack, which causes errors.<br>
-<br>
- In this commit:<br>
-<br>
- Execute the DA processing in a stopped context, so that if it fails we<br>
- don't throw an error.<br>
-<br>
- Surround the DA processing with a mark so that we can clear the stack if<br>
- it leaves anything behind.<br>
-<br>
- Surround all of that with a 'gstate...setgstate' or 'gstate...pop'. If<br>
- we get an error this allows us to restore the graphics state to the<br>
- point before we did the DA processing. If we didn't get an error then<br>
- we can just discard the saved gstate.<br>
-<br>
- Finally, check the length of the Contents string. If its 0, don't even<br>
- try to draw it. If its more than 0, but less than 4, then don't attempt<br>
- to check for UTF16 (2 byte BOM + 2 bytes for character means a minimum<br>
- of 4 bytes).<br>
-<br>
- This results in slightly different output from pdfwrite with one file,<br>
- tests_private/pdf/sumatra/1331_-_prints_garbled.pdf, which results in<br>
- very small (single pixel) differences at 72 dpi.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-17 09:15: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=2b4f54e13d9a5346e1c4c0a3a577d27065e67313">2b4f54e13d9a5346e1c4c0a3a577d27065e67313</a>
-<blockquote>
-<p>
- Remove the redundant -E and -A command line params<br>
-<br>
- The functionality for both are now (and have been for a *long* time!) accessed<br>
- via -Z# and -Z@ respectively.<br>
-<br>
- This solves a clash for -E with the other language implementations.<br>
-<br>
-doc/Use.htm<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-11 09:24: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=29fc52982904f7b24349f7fe369f614b3081ce90">29fc52982904f7b24349f7fe369f614b3081ce90</a>
-<blockquote>
-<p>
- DeviceN - handle out of memory errors<br>
-<br>
- When altering the DeviceN colour space handling in the PostScript<br>
- interpreter to use C strings instead of name indices, I neglected to<br>
- consider the possibility of a failure to allocate memory for the string.<br>
-<br>
- This commit just catches the fault and returns a VM error to the<br>
- interpreter.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-10 14:49:29 +0100
-</strong>
-<br>i3v &lt;i3v@mail.ru&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=55d04ff91a70a2cba1a1c15407c94f936c5f91f4">55d04ff91a70a2cba1a1c15407c94f936c5f91f4</a>
-<blockquote>
-<p>
- Documentation - fix various typos in VectorDevices.htm<br>
-<br>
- Bug #701021 &quot;Typos in VectorDevices.htm&quot;<br>
-<br>
- Fixes supplied by 'i3v'.<br>
-<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-10 09:32:26 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3db10c55b3ef621770bf6e93dfc1605e766adef2">3db10c55b3ef621770bf6e93dfc1605e766adef2</a>
-<blockquote>
-<p>
- Improve test for PS resources in romfs<br>
-<br>
- Previously, although we always built a romfs, building gs with COMPILE_INITS=0<br>
- meant we included a romfs which was devoid of content, and an attempt to find<br>
- the status of the device would return 'gs_error_unregistered'. We used this<br>
- to determine whether to automatically add '%rom%Resource/Init' to the default<br>
- search path.<br>
-<br>
- In the gpdl case (for the sake of PCL and XPS), we always have a usable romfs<br>
- (even with COMPILE_INITS=0) for the ICC profiles, so the above test gave a<br>
- false positive: gs would add the romfs to the search path, despite there being<br>
- no usable Postscript resources in it.<br>
-<br>
- So, revise the test to explicitly check for Resource/Init/gs_init.ps on the<br>
- romfs. If the romfs is, indeed, empty, it will still return<br>
- 'gs_error_unregistered', but in the gpdl case, it will return<br>
- 'gs_error_undefinedfilename', and we correctly skip adding the romfs path to<br>
- the search paths for Postscript resources<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-08 13:23:26 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d2809b15153eedbbe1bfb43fc259bf674e353f42">d2809b15153eedbbe1bfb43fc259bf674e353f42</a>
-<blockquote>
-<p>
- Add an (interim) --enable-gpdl configure option<br>
-<br>
- This adds gpdl to the default target list for make.<br>
-<br>
- Mainly to get the .so build usable without having edit the makefiles.<br>
-<br>
- This will be deprecated when gpdl is always in the default target list.<br>
-<br>
-Makefile.in<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-09 09:49:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d0d7b8d3866aecafac3601ebd9b4b5d83f4fbe91">d0d7b8d3866aecafac3601ebd9b4b5d83f4fbe91</a>
-<blockquote>
-<p>
- Fix some compiler warnings<br>
-<br>
- and remove some #if directives accidentally included in a commit<br>
-<br>
-base/gscdevn.c<br>
-devices/vector/gdevpdfc.c<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-08 14:28: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=86a81b823950c712ac03e0139449045a81672d01">86a81b823950c712ac03e0139449045a81672d01</a>
-<blockquote>
-<p>
- pdfwrite - extend DeviceN attributes dictionary generation<br>
-<br>
- Now that we cater for the /Process dictionary in a DeviceN attributes<br>
- dictionary (and the Subtype) we need to emit those from pdfwrite too.<br>
-<br>
-devices/vector/gdevpdfc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-08 14:27: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=2019db2e552653bd0c27377d500de1041c9fd0bc">2019db2e552653bd0c27377d500de1041c9fd0bc</a>
-<blockquote>
-<p>
- PostScript colour space handling<br>
-<br>
- We were not catering for a /Subtype in a DeviceN attributes dictionary<br>
- having a value which is a string type not a name type. I can't quite<br>
- see how we are ending up with a string type here, since the PDF file<br>
- has it as a name, but it does. Dealing with both resolves many errors.<br>
-<br>
- The second change is more far-reaching; when processing an attributes<br>
- dictionary for a DeviceN colour space we may need to create colour<br>
- spaces for the Process dictionary /ColorSpace and for any of the entries<br>
- in the Colorants dictionary. We were doing that by calling<br>
- zsetcolorspace() which mostly works well, however there is one<br>
- optimisation which can cause a problem; if the target space is the same<br>
- as the current *interpreter* colour space, then zsetcolorspace()<br>
- simply returns.<br>
-<br>
- The problem is that if we are halfway through processing a DeviceN<br>
- space then we haven't set the interpreter space to the new colour space<br>
- array yet which can mean that we incorrectly detect one of the target<br>
- spaces as being the same as the current space. This leads to us trying<br>
- to use the current space in the graphics state (the DeviceN space) as<br>
- the target space, with unfortunate consequences.<br>
-<br>
- So create a new version of zsetcolorspace which doesn't do that<br>
- optimisation and use that when processing the various target spaces in<br>
- the DeviceN attributes dictionary.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-07 12:52:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d75869134c69963406500b536fb1bb1c97c8621">0d75869134c69963406500b536fb1bb1c97c8621</a>
-<blockquote>
-<p>
- Separation - change ink name to be a C string instead of name index<br>
-<br>
- As indicated in previous commits, change the stored ink name in the<br>
- colour space structure params.separation from a numeric value<br>
- (gs_separation_name) into a C string.<br>
-<br>
- We never have to pass these back to the interpreter, so we allocate the<br>
- storage using the non-GC allocater.<br>
-<br>
-base/gscdevn.c<br>
-base/gscsepr.c<br>
-base/gscspace.h<br>
-base/gsequivc.c<br>
-base/gsicc_cache.c<br>
-base/gxcmap.c<br>
-devices/vector/gdevpdfc.c<br>
-devices/vector/gdevpdfg.c<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-06 16:51: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=97253bf54a701d5e433378df953e066d009afde0">97253bf54a701d5e433378df953e066d009afde0</a>
-<blockquote>
-<p>
- DeviceN - change ink names to be C strings instead of name indices<br>
-<br>
- As indicated in previous commits, change the stored ink names in the<br>
- colour space structure params.device_n from numeric values<br>
- (gs_separation_name) into C strings.<br>
-<br>
- We never have to pass these back to the interpreter, so we allocate the<br>
- storage using the non-GC allocater, which simplifies things for the<br>
- array which used to store the indices and now stores the pointers to the<br>
- C strings.<br>
-<br>
-base/gscdevn.c<br>
-base/gscspace.h<br>
-base/gsequivc.c<br>
-base/gsicc_cache.c<br>
-base/gsicc_manage.c<br>
-base/gxcmap.c<br>
-devices/vector/gdevpdfc.c<br>
-devices/vector/gdevpdfg.c<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-07 19:54:57 +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=880a700f691f444c483053f48b3c0b0f3a920883">880a700f691f444c483053f48b3c0b0f3a920883</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV caused by double freeing.<br>
-<br>
- Prevent running finalize for devices with a custom finalize.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=1767 ./membin/gpcl6 -sDEVICE=pbmraw -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0270<br>
-<br>
-base/gdevdflt.c<br>
-base/gspaint.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-02 08:00:46 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=284ba1a6491088ab8ea9985f5df882c43bd3ca12">284ba1a6491088ab8ea9985f5df882c43bd3ca12</a>
-<blockquote>
-<p>
- Use deviceN attributes process color color space<br>
-<br>
- If the DeviceN color space includes an attributes entry and<br>
- it has a process color space, and the color space is of the proper<br>
- type use that as the source color for the process components. If<br>
- instead the alternate tint transform color space is the correct type<br>
- use that as a hint. If neither work then set to the defined default_cmyk<br>
- source color space. If all fail due to issues with ICC profiles then<br>
- the CMYK source process colorants will pass through to the output device.<br>
-<br>
-base/gdevp14.c<br>
-base/gscdevn.c<br>
-base/gsequivc.c<br>
-base/gsicc.c<br>
-base/gxcmap.c<br>
-base/gxcmap.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-06 13:46:42 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=754b4eb77d24ff0273b530aa748bbf925b715d9c">754b4eb77d24ff0273b530aa748bbf925b715d9c</a>
-<blockquote>
-<p>
- Ensure correct memory allocation of Colorant strings<br>
-<br>
- I'm not happy with using ref_to_string() as it doesn't seem to behave<br>
- entirely as I would expect, so modify the code to explicitly allocate<br>
- the memory used to store the Colorant name.<br>
-<br>
- Also fix a compiler warning.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-06 09:10:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=76022c9c27a0f4031553cf3a5eb2c009b26b19be">76022c9c27a0f4031553cf3a5eb2c009b26b19be</a>
-<blockquote>
-<p>
- DeviceN - store C strings for Colorant names, not name indices<br>
-<br>
- For DeviceN spaces with an attributes dictionary containing a<br>
- Colorants dictionary we were storing the Colorant names as a name index<br>
- (index into the interpreter name table). Additionally we store a<br>
- procedure callback to recover the C string from the name index.<br>
-<br>
- This is problematic for several reasons; firstly it requires all the<br>
- interpreters to either have a name table or some close equivalent so<br>
- that a C string can be recovered from a numeric value.<br>
-<br>
- Secondly the lifetime of the string is divorced from the lifetime of the<br>
- C structure using it. Because there's no easy way for the interpreter to<br>
- know when the graphics library has freed the colour space structure<br>
- the interpreter is forced to retain the relationship between the name<br>
- index and the C string until the job is completed.<br>
-<br>
- Both of these will be problems for the new PDF interpreter, so this is<br>
- step 1 in altering this. After this we will still need to change the<br>
- storage of the DeviceN and Separation ink names, which are handled the<br>
- same way.<br>
-<br>
-base/gscdevn.c<br>
-base/gscdevn.h<br>
-base/gxcdevn.h<br>
-devices/vector/gdevpdfc.c<br>
-devices/vector/gdevpdfg.c<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-03 17:35:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8b407511d2fad0108a76c6b46dc54a1770ea3ade">8b407511d2fad0108a76c6b46dc54a1770ea3ade</a>
-<blockquote>
-<p>
- fix commit c2d50885614481ebf542578e69ce4bcbbfea6532<br>
-<br>
- don't retest code, and fix some compiler warnings<br>
-<br>
-base/gscdevn.h<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-03 13:27:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c2d50885614481ebf542578e69ce4bcbbfea6532">c2d50885614481ebf542578e69ce4bcbbfea6532</a>
-<blockquote>
-<p>
- DeviceN - handle attributes Subtype and cleaning up<br>
-<br>
- Previously we were ignoring the /Subtype in the attributes dictionary<br>
- of a DeviceN colour space (if attributes were present). We may need to<br>
- be able to tell the difference (now that we handle /Process) because<br>
- the values associated with the process components must be stored in<br>
- their natural form (eg subtractive for CMYK, additive for RGB) when<br>
- the Subtype is NChannel.<br>
-<br>
- The remainder of the commit tidies up naming; previously we had a<br>
- structure called gs_devicen_attributes, which was used to store the<br>
- Colorants entry form an attributes dictionary. Since we now handle<br>
- other aspects of the attributes dictionary as well, this was misleading<br>
- so the structure has been renamed throughout as gs_devicen_colorant<br>
- (since each structure defines only one colorant, the plural name was<br>
- also misleading). Apparently pdfwrite is the only client for this<br>
- currently anyway.<br>
-<br>
- Finally, moved the 'devn_process_space' from the general graphics<br>
- state colour space structure into the DeviceN params structure, as its<br>
- only relevant to DeviceN (and indeed only a DeviceN with an attributes<br>
- dictionary which contains a /Process entry)<br>
-<br>
-base/gscdevn.c<br>
-base/gscdevn.h<br>
-base/gscspace.c<br>
-base/gscspace.h<br>
-base/gxcdevn.h<br>
-devices/vector/gdevpdfc.c<br>
-devices/vector/gdevpdfg.c<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-02 16:40:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22d88ad48409a130007976ae26536cc9d99c16d9">22d88ad48409a130007976ae26536cc9d99c16d9</a>
-<blockquote>
-<p>
- Fix an oversight in DeviceN attributes processing<br>
-<br>
- If we have no Colorants entry we still want to check for a Process<br>
- entry, but to do so we need to signal to setcolorspace_cont(), the<br>
- routine which calls this one, that we do want to keep processing the<br>
- colour space.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-02 13:12: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=7c70031f8be95585bcf439d12e552d386e4e2125">7c70031f8be95585bcf439d12e552d386e4e2125</a>
-<blockquote>
-<p>
- Capture the /Components from a DeviceN /Process dictionary<br>
-<br>
- Following on from commit 5e84879db91fdc8569a85a394def391695152720 and<br>
- Michael's commit c6ac30d231946062b41c56df375b240583e75b35 this adds<br>
- code to check for the existence of a /Process dictionary in the<br>
- attributes dictionary (if present) of a DeviceN colour space.<br>
-<br>
- Also fixed/added a few comments to the existing code and did some<br>
- tidying up of error return handling.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-01 10:06:41 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6ac30d231946062b41c56df375b240583e75b35">c6ac30d231946062b41c56df375b240583e75b35</a>
-<blockquote>
-<p>
- Add holder for process color names in DeviceN color space parameters<br>
-<br>
- As part of the work to use the DeviceN attributes process dictionary<br>
- we need to have a place to store the colorant names. They will<br>
- be stored as an array of C strings in the pcs-&gt;params.device_n structure.<br>
- This commit adds them to the structure and frees them during the color<br>
- space finalization.<br>
-<br>
-base/gscdevn.c<br>
-base/gscspace.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-01 17:49: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=5e84879db91fdc8569a85a394def391695152720">5e84879db91fdc8569a85a394def391695152720</a>
-<blockquote>
-<p>
- Process DeviceN attributes dictionary, /Process dictionary, /ColorSpace<br>
-<br>
- PostScript PDF interpreter changes; retrieve the Process dictionary<br>
- from the DeviceN attributes dictionary (if present). Extract the<br>
- ColorSpace, resolve the ColorSpace (turns any references into actual<br>
- objects), and store the result back in the Process dictionary. Finally<br>
- store the Process dictionary in the attributes dictionary which we<br>
- pass to setcolorspace.<br>
-<br>
- PostScript interpreter, C changes; add a new 'stage' for DeviceN<br>
- colour space handling. In stage 3, check for the existence of an<br>
- attributes dictionary, then a /Process dictionary, and a /ColorSpace<br>
- entry. Retrieve the entry. Set up a new continuation procedure<br>
- 'devicenprocess_cont'. The continuation procedure calls zsetcolorspace()<br>
- to set the /ColorSpace as the current space. On returning, retrieve<br>
- the current color space, attach it to the DeviceN graphics state colour<br>
- space and finish.<br>
-<br>
- Still to do; process /Components, add the equivalent code to pdfi,<br>
- check pdfwrite to see if we can handle this. Tidy up comments.<br>
- Committing now so Michael can carry on with the CMS work.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-05-01 13:17:25 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6742ad7d26dc7bb8cc33aef9f96f86d892d4a424">6742ad7d26dc7bb8cc33aef9f96f86d892d4a424</a>
-<blockquote>
-<p>
- Valgrind: image_render_interpolate_landscape_icc.<br>
-<br>
- Don't color convert the unprocessed margins of the buffer.<br>
- These areas are never inited, so a warning is given. No<br>
- harm is done as they are never actually rendered, but it's<br>
- faster and cleaner to skip them too.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-30 15:13:25 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=04db6ace1fb97dcef79d9bdbb01a1c8a63c55d88">04db6ace1fb97dcef79d9bdbb01a1c8a63c55d88</a>
-<blockquote>
-<p>
- Add a devn_process_space to color gs_color_space_s<br>
-<br>
- This is in preparation for having the process color<br>
- space as defined in the DeviceN (NChannel) Process<br>
- dictionary.<br>
-<br>
-base/gscspace.c<br>
-base/gscspace.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-30 11:49:07 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e1f9edfcafc3f73f43b85afacb8d788f7e573cf6">e1f9edfcafc3f73f43b85afacb8d788f7e573cf6</a>
-<blockquote>
-<p>
- Add methods to detect pure process colors in Sep and DeviceN color spaces<br>
-<br>
- When the colors in the separation or Devicen color space consist all of<br>
- one particular process color model, we would like to consider the use<br>
- of the alternate tint transform color space as an indication of the intent<br>
- for these color spaces (assuming the attributes information was not there).<br>
- For example, if we had a DeviceN color space<br>
- of [Cyan Magenta] and the alternate tint transform color space was a<br>
- CMYK ICC color space, that would be a hint that we should treat the color<br>
- as being in that space. This commit provides us with the information as<br>
- to the colorants all being in one particular process space which is<br>
- a requirement.<br>
-<br>
-base/gscdevn.c<br>
-base/gscsepr.c<br>
-base/gscspace.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-30 15:26:11 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b380b655b64a37a77b98dab881ff0aad0c62586e">b380b655b64a37a77b98dab881ff0aad0c62586e</a>
-<blockquote>
-<p>
- Nobble pdfwrite genrated /ID entries in cluster tests.<br>
-<br>
- Avoid having the /ID values depend on the output filename<br>
- in cluster testing. This should allow us to compare the<br>
- results of pdfwriting between gs and gpdl. It also removes<br>
- one more thing to get right when trying to manually reproduce<br>
- cluster results.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-30 10:40:20 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fd5758e4d55c510fa4ad0047c10b13cf928cfb74">fd5758e4d55c510fa4ad0047c10b13cf928cfb74</a>
-<blockquote>
-<p>
- Make pdfwrite fileID calculations consistent on cluster.<br>
-<br>
- Nobble the timing calculations under CLUSTER builds, so<br>
- we get consistent results.<br>
-<br>
- Also, move to using realtime, rather than usertime (as the goal<br>
- is to have something different each time).<br>
-<br>
-devices/gdevpdfimg.c<br>
-devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-29 17:58:42 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=35c40cdaa2f79432f01733d3f69f95947db5d60b">35c40cdaa2f79432f01733d3f69f95947db5d60b</a>
-<blockquote>
-<p>
- Change implementation of gsicc_support_named_color<br>
-<br>
- gsicc_support_named_color now will have available all the names<br>
- in the DeviceN color space. If there are no spot names<br>
- in the list, it will return false ensuring that the process colors<br>
- will be color managed.<br>
-<br>
-base/gscdevn.c<br>
-base/gscsepr.c<br>
-base/gsicc_cache.c<br>
-base/gsicc_cache.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-29 18:39: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=8026e11e50306a51dc3bb6f2bdc57f34986acd62">8026e11e50306a51dc3bb6f2bdc57f34986acd62</a>
-<blockquote>
-<p>
- Fix undefined behaviour in rops.<br>
-<br>
- We were indexing off the end of a static table. Annyoingly,<br>
- valgrind has failed to pick this up for years.<br>
-<br>
-base/gsroprun.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-29 11:14: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=0bafbd9c1273fab0dc79fd20db0ffc4443683f96">0bafbd9c1273fab0dc79fd20db0ffc4443683f96</a>
-<blockquote>
-<p>
- PDF interpreter - Decode ToUnicode entries of the form /Identity-H/V<br>
-<br>
- Bug #701003 &quot;Text searchability broken due to omission of /ToUnicode /Identity-H&quot;<br>
-<br>
- The PDF references from 1.2 too 2.0 all state that the value associated<br>
- with a ToUnicode key in a FontDescriptor must be a stream object. However<br>
- this file (and one case seen previously, bug 687351) have FontDescriptor<br>
- dictionaries where the value associated with a /ToUnicode key is a<br>
- name object, in both cases /Identity-H.<br>
-<br>
- Although this is clearly not legal, Acrobat not only tolerates it, it<br>
- actually uses it for search/copy/paste (see bug 701003 for details).<br>
- Without the key Acrobat is unable to successfully search the output file.<br>
-<br>
- We can't simply preserve the name object as a ToUnicode value; when<br>
- handling ToUnicode we actually decode the CMap and build a<br>
- GlyphNames2Unicode map (an internal representation of the G2U data<br>
- produced by the Microsoft PostScript printer driver). When writing the<br>
- output file we use that information to get a Unicode value for each<br>
- character we write, and build a new ToUnicode CMap using that.<br>
-<br>
- This commit tackles the problem by pre-scanning for a name object and<br>
- then checking to see if its Identity-H or Identity-V (although we have<br>
- not seen an Identity-V, there seems no reason why it wouldn't be<br>
- equally valid). If we find either of these then we construct a<br>
- GlyphNames2Unicode table for all possible values (0 - 65535) and store<br>
- that with the font as normal. When we write the output file we only<br>
- write the required entries for the subset font, so we write a now<br>
- completely legal ToUnicode CMap, and Acrobat is equally happy with that<br>
- as the original name.<br>
-<br>
- If the ToUnicode value isn't a name object, or isn't one of the<br>
- identities then we proceed as before. This means we will print a<br>
- warning for non conforming ToUnicode entries and ignore them.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-28 19:59:12 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0b9c45fa86f7736e7fec170a135efa83636283ba">0b9c45fa86f7736e7fec170a135efa83636283ba</a>
-<blockquote>
-<p>
- Have CMYK colors in DeviceN color spaces color managed when going to CMYK devices<br>
-<br>
- The current code was only doing color management of DeviceN CMYK when going to<br>
- the separation device (e.g. tiffsep and psdcmyk). It should also be doing this<br>
- for pure CMYK devices like tiff32nc etc. With RGB devices we will be going through<br>
- the alternate tint transform. The would only pertain to DeviceN color spaces composed<br>
- of only process colors (e.g. [Cyan Magenta]). If a spot color was included we would<br>
- be going through the alternate tint transform for a device like tiff32nc.<br>
-<br>
- So with this commit if you have a command line like<br>
-<br>
- -sDEVICE=tiff32nc -sDefaultCMYKProfile=src_cmyk.icc -o output.tif -f input.pdf<br>
-<br>
- it will treat the CMYK values in the DeviceN color space the same as a DeviceCMYK<br>
- source color and make use of the src_cmyk.icc profile to handle those. As mentioned<br>
- this worked with psdcmyk and tiffsep but not standard CMYK devices.<br>
-<br>
-base/gxcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-01 20:30: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=68511243fb4817e8170023d1d6922956325a139d">68511243fb4817e8170023d1d6922956325a139d</a>
-<blockquote>
-<p>
- Move transfer functions to 16 bits.<br>
-<br>
- This means that in 'deep' modes, we sample them in 257 places<br>
- (0000,0100,....ff00,ffff) rather than 256 (00,01,...ff), and<br>
- in 16 bits rather than 8. We also interpolate them on reading.<br>
-<br>
- This in turn increases the size of the data put into the clist.<br>
-<br>
-base/gdevp14.c<br>
-base/gstparam.h<br>
-base/gstrans.c<br>
-base/gstrans.h<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-26 21:24:28 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e2507c443fcd1456ff65695901339fc96f4bbf73">e2507c443fcd1456ff65695901339fc96f4bbf73</a>
-<blockquote>
-<p>
- Fix improper logic in named color support<br>
-<br>
-base/gscdevn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-26 16:47:29 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb9f948ec79d18c2574a9a0bdaf9ab1aeee21e58">fb9f948ec79d18c2574a9a0bdaf9ab1aeee21e58</a>
-<blockquote>
-<p>
- And one more fix to the named color blending.<br>
-<br>
- Fixing issues introduced in previous commit.<br>
-<br>
-base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-26 11:25:19 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e1a534e843743230019de57a36a04129347a505e">e1a534e843743230019de57a36a04129347a505e</a>
-<blockquote>
-<p>
- Fix named color blending<br>
-<br>
- Named color blending was not working the way intended. This was clearly visible<br>
- when pushing a gradient through. This now does a reasonable result blending<br>
- the first colorant with white and then subsequent colorants with the current<br>
- colorant.<br>
-<br>
-base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-26 14:40:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6fcd76043a6fe69ca2b8ecac498f9ca79829931f">6fcd76043a6fe69ca2b8ecac498f9ca79829931f</a>
-<blockquote>
-<p>
- Bug 700973: CIDFont substitution: avoid multiply applying metrics<br>
-<br>
- findCIDFont: we make various efforts to produce a synthetic font style<br>
- (bold, light, italic etc) if the actual type face style is not available.<br>
-<br>
- In these cases, we have to avoid reusing an existing CIDFont substitute because<br>
- the CDevProc will have been 'hooked' to apply the width metrics drawn from the<br>
- PDF file. We want to, if at all possible, use the CIDFont as originally loaded.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-25 17:20: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=cb1414723d95c6813e8e44a8c0529f0063998378">cb1414723d95c6813e8e44a8c0529f0063998378</a>
-<blockquote>
-<p>
- pdfwrite - handle user-defined PCL fonts with character codes &gt; 256<br>
-<br>
- Bug #700996 &quot;PCL Files Processing failure&quot;<br>
-<br>
- The problem is that we cannot handle a character code in excess of 256<br>
- in a PDF Font (we would have to create a CIDFont, which is too much<br>
- work). This was causing us to fail to attach a PDF font to the current<br>
- (user-defined PCL) font. When we later tried to retrieve the font<br>
- that caused a seg fault.<br>
-<br>
- If we simply return an error when there is no attached font then the<br>
- fallback machinery will take us through generating an image instead.<br>
-<br>
- This, however, caused the original file not to work properly, text was<br>
- going missing. Forcing 'early accumulator' to be 0 so that we created a<br>
- new font resolved the problem. Its better, however to remove that entire<br>
- section of code, since it now has no purpose.<br>
-<br>
- This commit results in a PDF file with the correct appearance. A number<br>
- of out test suite files exhibit small differences, particularly at<br>
- low (75 dpi) resolution, but nothing is actually incorrect.<br>
-<br>
-devices/vector/gdevpdti.c<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-24 12:27:16 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b1d3a9fcc40d0dd2dc779830abe21da83183c11">7b1d3a9fcc40d0dd2dc779830abe21da83183c11</a>
-<blockquote>
-<p>
- Fix two issues in replace color management.<br>
-<br>
- Always do replacement for this demo implementation and<br>
- use get_color_mapping_procs_subclass to get the device<br>
- color mapping procs. The old method had an issue with<br>
- overprint compositor and psdcmyk device.<br>
-<br>
-base/gsicc_replacecm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-24 11:20:57 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=29d227c79fa8554e65eb1e081a81cbcb13b76b8a">29d227c79fa8554e65eb1e081a81cbcb13b76b8a</a>
-<blockquote>
-<p>
- Avoid double free in replace color management code<br>
-<br>
-base/gsicc_replacecm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-24 10:27:25 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f947ad5c32968cb113cb3ba4958e239dcf730a5">2f947ad5c32968cb113cb3ba4958e239dcf730a5</a>
-<blockquote>
-<p>
- Use space in calls to gs_strtok<br>
-<br>
-base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-23 21:32:00 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8881a51d55df7df70f4e0083be8569e09213dfba">8881a51d55df7df70f4e0083be8569e09213dfba</a>
-<blockquote>
-<p>
- Fix several warnings and issues from last commit.<br>
-<br>
-base/gscsepr.c<br>
-base/gsicc_cache.c<br>
-base/gxcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-24 10:48: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=7f34ef8c946be47d5a5dcc412b3da608a0066c44">7f34ef8c946be47d5a5dcc412b3da608a0066c44</a>
-<blockquote>
-<p>
- Fix typo in 16bit code in gxblend.c<br>
-<br>
- src_shape needs to be 16bits, not a byte now.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-23 20:11:24 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fea343608ce813156ae8ffc2ea6d42fc5f198e64">fea343608ce813156ae8ffc2ea6d42fc5f198e64</a>
-<blockquote>
-<p>
- Add support for named color when going to separation devicen_icc_cmyk<br>
-<br>
- When going through named color processing with the target device either<br>
- tiffsep or psdcmyk, cmap_devicen_direct and cmap_devicen_halftoned were<br>
- doing an additional cmyk icc mapping. This mapping was needed to ensure<br>
- that CMYK values matched DeviceN mapping values of CMYK+Spot where the Spot<br>
- value was 0 percent. With the use of named color mapping, we want to avoid this<br>
- icc mapping. Fixing this issue involved adding a boolean value to the DeviceN and Separation<br>
- color space params to indicate if the spot colorant(s) are supported by the<br>
- named color profile. This determination is made during the install of the<br>
- device so that it need only be done once. To do that, we needed to add a<br>
- method, gsicc_support_named_color, in gsicc_cache.c, which goes with<br>
- gsicc_transform_named_color, to indicate if the spot colorant is defined in<br>
- the data that we are using. Tested with tiff24, tiff32 and psdcmyk to ensure<br>
- named color mapping is occurring and that no additional mapping occurs after<br>
- that.<br>
-<br>
-base/gscdevn.c<br>
-base/gscsepr.c<br>
-base/gscspace.h<br>
-base/gsicc_cache.c<br>
-base/gsicc_cache.h<br>
-base/gxcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-19 16:38:26 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f0f2fa2a084758bcf99409ce19c2c1f93dc04d32">f0f2fa2a084758bcf99409ce19c2c1f93dc04d32</a>
-<blockquote>
-<p>
- Deep color transparency<br>
-<br>
- Previously, all transparency blending has been done using the<br>
- pdf14 compisitor working in 8 bits. Here, we extend it to be<br>
- capable of working in 16 bits.<br>
-<br>
- When the compositor is created, it looks at the underlying device;<br>
- if that device uses more than 8 bits per component (plus 8 bits<br>
- for tags, if tags are in use), then we use 'deep' (i.e. 16 bit<br>
- per component) pdf14 buffers.<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevmem.c<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gdevprn.c<br>
-base/gsptype1.c<br>
-base/gstrans.h<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-base/gxclrect.c<br>
-base/gxclthrd.c<br>
-base/gxcolor2.h<br>
-base/gxp1fill.c<br>
-base/gxpcolor.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-22 15:33:02 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba8ff34e302ec3e65bd47b14796dcfaef157527f">ba8ff34e302ec3e65bd47b14796dcfaef157527f</a>
-<blockquote>
-<p>
- Hack bmpcmp to accept 16bpc PSD files.<br>
-<br>
- We ignore the bottom bytes of the pixel data.<br>
-<br>
-toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-19 08:16:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d8db95fb00af2fb543439242d3ac122aead88c94">d8db95fb00af2fb543439242d3ac122aead88c94</a>
-<blockquote>
-<p>
- Fix some structure element name confusion in base/sjbig2_luratech.c<br>
-<br>
- A previous commit slightly modified some of memory management for jbig2 global<br>
- data. In mirroring those changes to the Luratech version of the code, a couple<br>
- of places were left with the structure element names from the jbig2dec version.<br>
-<br>
-base/sjbig2_luratech.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-16 19:30:02 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b399f849ce1aa391da1abeb23fd32e376b56e522">b399f849ce1aa391da1abeb23fd32e376b56e522</a>
-<blockquote>
-<p>
- Bug 700624: Fix &quot;full&quot; pattern fills with gaps between cells.<br>
-<br>
- GS has an optimisation in it, whereby if an uncolored pattern fill<br>
- is completely full (the mask is full of 1's), it doesn't bother to<br>
- store the mask. When such a pattern is filled, the code knows just<br>
- to fill the whole thing.<br>
-<br>
- Sadly, this optimisation breaks down when the cells have an X or Y<br>
- step that means there should be gaps between the instances. GS<br>
- currently fills the whole thing, gaps and all.<br>
-<br>
- To fix this, we either need to fix all the different fill routines<br>
- to cope with this case, or (as I have done here), disable the<br>
- optimisation in the case when the X and Y step is larger than the<br>
- 'size' of the pattern cell.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-18 16:58: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=d86210973df93ccca0befd56afba2132da925ebc">d86210973df93ccca0befd56afba2132da925ebc</a>
-<blockquote>
-<p>
- Bug 700986: Remove the crazy md5 file copying nonsense<br>
-<br>
- To preserve building as a standalone test exe, we avoided using Ghostscript<br>
- includes in the md5 source and header files, but dynamically add them to<br>
- copies of the files during the build. Since we no longer need/care for the<br>
- stand alone exe, remove the build complication, and just include the header<br>
- file normally.<br>
-<br>
-base/gsmd5.h<br>
-base/lib.mak<br>
-base/md5main.c<br>
-doc/Develop.htm<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-18 14:24:04 +0100
-</strong>
-<br>Alexander Grahn &lt;a.grahn@fzd.de&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a3be0c9d86981313d8724f6c29f2feaa07152976">a3be0c9d86981313d8724f6c29f2feaa07152976</a>
-<blockquote>
-<p>
- Bug #700984 &quot;BMC pdfmark: BMC keyword missing from content stream (patch included)&quot;<br>
-<br>
- Not sure how this has gone unnoticed for so long. The 'BMC' keyword was<br>
- missing from the emission of the content of the pdfmark. The EMC and<br>
- BDC pdfmarks seem to be OK.<br>
-<br>
- Thanks to Alexander Grahn for identifying the problem and supplying a<br>
- patch to resolve it.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-18 11:18: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=a7cccaac16e6fc252496ab630f7423262e05756d">a7cccaac16e6fc252496ab630f7423262e05756d</a>
-<blockquote>
-<p>
- Fix commit d89bae568d5015144e5d68fea8221543111e119e<br>
-<br>
- Commit d89bae568d5015144e5d68fea8221543111e119e contained an oversight<br>
- which unfortunately was missed due to the testing cluster being in a<br>
- state of flux.<br>
-<br>
- Its possible for fonts to have a Subtype of Type1C as well as the<br>
- noted CIDFontType0C and CIDFontType1C, and we need to cater for that<br>
- as well.<br>
-<br>
- This mostly affected some of the Ghent Working Group test files, and<br>
- not much else, so I've chosen just to push an addditional commit.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-17 15:53:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d89bae568d5015144e5d68fea8221543111e119e">d89bae568d5015144e5d68fea8221543111e119e</a>
-<blockquote>
-<p>
- PDF interpreter - change detection of CFF CIDFont types<br>
-<br>
- Bug #700982 &quot;Error: unrecognized font file starts with &lt;01000D02&gt;&quot;<br>
-<br>
- The code in pdf_font.ps to detect font types, and call an appropriate<br>
- font loader works (in part) by reading the first 4 bytes from the font<br>
- stream, and then using that as the key for a dictionary where the<br>
- values are the font loading procedures.<br>
-<br>
- Most font types have a 'magic number' or similar at the start of the<br>
- font data, but CFF fonts do not. In fact the header of a CFF font is<br>
- highly variable, the only thing we can rely on being the font version<br>
- byte (0x01), the remaining 3 bytes are variable.<br>
-<br>
- We've tackled this previously by simply adding more different varieties<br>
- of string values, but this seems nonsensical. There are too many<br>
- possible values for this to work reliably.<br>
-<br>
- Ideally I'd recode this to use the CIDFont Subtype to select the<br>
- correct font loader, but that would mean recoding all of this, which is<br>
- more work than I want to tackle in this code. Instead I've chosen to<br>
- only have one single 'tag' in the dictionary, and I've extended the code<br>
- handling the case where we don't find a tag in the dictionary.<br>
-<br>
- Previously this checked to see if the first two bytes of the string<br>
- were &lt;8001&gt; and otherwise failed. I've modified this so that if the<br>
- bytes are not &lt;8001&gt; then we check the dictionary /Subtype key. If its<br>
- not present or isn't either CIDFontType0C or 1C then we still throw<br>
- an error. Otherwise we discard the string we read, replace it with the<br>
- one and only string we have stored in the font_tag_dict dictionary and<br>
- proceed.<br>
-<br>
- If there is ever a version 2 of the CFF specification this will fail,<br>
- but we can add a check for the version number if that ever happens<br>
- (seems highly unlikely).<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-16 09:20: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=cf58dd08435d89e5f205127c518595c0d7441535">cf58dd08435d89e5f205127c518595c0d7441535</a>
-<blockquote>
-<p>
- Documentation - describe the ink_cov device<br>
-<br>
- Following up from a question on Stack Overflow, the ink_cov device isn't<br>
- actually described anywhere. Add a description of the device and how its<br>
- output differs from the inkcov device.<br>
-<br>
- At the same time, add the inkcov device(s) to the table of contents in<br>
- devices.htm and also add the bit and bbox devices which were not listed<br>
- in the TOC.<br>
-<br>
-doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-15 08:25: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=5fa1928af0eb110115d34eb4c43bb529dda6f697">5fa1928af0eb110115d34eb4c43bb529dda6f697</a>
-<blockquote>
-<p>
- PDF interpreter - synthesise appearance for text Widget comb fields<br>
-<br>
- Bug #700967 &quot;Warning Combed form fields are not yet implemented&quot;<br>
-<br>
- Comb fields draw a string into a series of 'combs' or boxes, one<br>
- character per box. As usual there are no guidelines in the specification<br>
- as to how to draw the individual characters.<br>
-<br>
- I've chosen to centre each character in the box it is draw in, because<br>
- drawing it from the origin of the box tends to cause collisions with the<br>
- vertical/horizontal lines delineating the box itself (in the one example<br>
- file I have). This may cause slightly odd appearance if a field uses<br>
- mixed upper/lower case, as the text will jump up and down vertically.<br>
-<br>
- The example file supplied has a fault, one of the comb fields has a<br>
- value (/V) string which is longer than the /MaxLen value for the field.<br>
- This indicates to me a fault with the form filling application which<br>
- should not permit this. Acrobat truncates the string, I've chosen to<br>
- not render the string at all, and emit a warning on the back channel.<br>
-<br>
- None of our test suite files show any differences at all; either we<br>
- don't have an examples of this kind of field already, or they all have<br>
- appearance streams.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-12 09:53: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=6d8e1957175ec98443a6bc0d8c3cda6bfdced801">6d8e1957175ec98443a6bc0d8c3cda6bfdced801</a>
-<blockquote>
-<p>
- Bug 700968: Fix TTF Format 4 (segmented) cmap parsing<br>
-<br>
- The format 4 parsing was incorrect, but in a manner only exposed by reading<br>
- an out of spec cmap.<br>
-<br>
- The spec implies that the character codes in the cmap segments should be non-<br>
- overlapping, and the segments should be in order of lowest-to-highest codes.<br>
-<br>
- We were imposing (*not* enforcing) that condition, but forcing the start code<br>
- of the current segment to be greater than size of the range of codes we've<br>
- already read. This, basically, has no effect on fonts that adhere correctly<br>
- to the spec.<br>
-<br>
- The fonts embedded in the files for Bug 700968 do not conform to the spec. For<br>
- example, the 'Z_C00002.tmp' font has the first 92 segments in the cmap with<br>
- start code and end code both set to 33. The above imposing of the no-overlap<br>
- and order of segments meant that when we got past those first 92 segments, we<br>
- were forcibly using character codes 92 and upwards.<br>
-<br>
- Removing the code imposing those conditions causes these files to render<br>
- correctly, and shows no regressions in our existing test suite.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-11 12:16:57 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=adc75668cc254ead4929748fdb5ca988353f91eb">adc75668cc254ead4929748fdb5ca988353f91eb</a>
-<blockquote>
-<p>
- Change s_jbig2decode_release() to free the global context in some cases<br>
-<br>
- Basically, if state-&gt;global_struct is NULL, it means the library should<br>
- free the global_ctx when it's done with it. This is the case when used in<br>
- gpdf (C implementation of PDF).<br>
-<br>
- If the state-&gt;global_struct is non-NULL, then it is a memory-managed<br>
- value that the interpreter will eventually clean up. This is the case<br>
- when used in gs (PS implementation of PDF).<br>
-<br>
-base/sjbig2.c<br>
-base/sjbig2_luratech.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-11 08:49:14 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fd3730fa8429f1ea58b2f5a5bfc1eecd3f835247">fd3730fa8429f1ea58b2f5a5bfc1eecd3f835247</a>
-<blockquote>
-<p>
- Change s_jbig2decode_set_global_data to take a separate pointer for global_ctx<br>
-<br>
- This is so gpdf can pass NULL for the 'gd' pointer, since it doesn't care<br>
- about garbage collection.<br>
-<br>
-base/sjbig2.c<br>
-base/sjbig2.h<br>
-base/sjbig2_luratech.c<br>
-base/sjbig2_luratech.h<br>
-psi/zfjbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-10 14:23: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=06c920713e11bce9bd541bbf9bf294b2ba16aee8">06c920713e11bce9bd541bbf9bf294b2ba16aee8</a>
-<blockquote>
-<p>
- Bug 700952: re-introduce over/underflow workaround<br>
-<br>
- Commit 355434f4b1bbe8c4f98cafad5a6868aa2f0eaae1 reverted a workaround that<br>
- compensated for over/underflow in Freetype's TTF hinting (related to freedom<br>
- and projection vector calculations). That problem no longer exists in recent<br>
- Freetype releases, and the workaround actually caused other issues to occur<br>
- with hinting.<br>
-<br>
- What wasn't obvious was that the workaround also protected over/underflow<br>
- issues relating to the unitsPerEm value.<br>
-<br>
- So this re-instates the workaround, but bases the decision on how the final<br>
- scale is distributing between the Freetype &quot;size&quot; and the Freetype matrix on<br>
- the unitsPerEm value (this is relevant for all font types as, for non-TTF,<br>
- font types, Freetype derives the unitsPerEm from the FontMatrix (for PS type<br>
- fonts).<br>
-<br>
- Also fixes Bug 700875<br>
-<br>
-base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-10 14:51:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=35d9fc4d2a9dd85fc8497cb68389ec6eded73fcb">35d9fc4d2a9dd85fc8497cb68389ec6eded73fcb</a>
-<blockquote>
-<p>
- Update the copyright string.<br>
-<br>
-base/gscdefs.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-10 13:54:57 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=08b91a2141df36d2f733e1822601ad06941674f2">08b91a2141df36d2f733e1822601ad06941674f2</a>
-<blockquote>
-<p>
- Detect system jbig2dec library using pkg-config if available.<br>
-<br>
- Otherwise fall back to traditional presence checking.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-10 20:06:04 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9f111ddc1cdb3cee329fb71e6ce4fd31c150f039">9f111ddc1cdb3cee329fb71e6ce4fd31c150f039</a>
-<blockquote>
-<p>
- jbig2dec: Improve jbig2dec-specific gitignore.<br>
-<br>
-jbig2dec/.gitignore<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-10 13: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=d72c6cdcd686a7dd0836f8a3afc4e23b5bb45144">d72c6cdcd686a7dd0836f8a3afc4e23b5bb45144</a>
-<blockquote>
-<p>
- jbig2dec: Add pkg-config file and allow for it to be installed.<br>
-<br>
-jbig2dec/Makefile.am<br>
-jbig2dec/configure.ac.in<br>
-jbig2dec/jbig2dec.pc.in<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-10 18: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=300dd807b47d48b7b8368ca7b6db3db0312fa19b">300dd807b47d48b7b8368ca7b6db3db0312fa19b</a>
-<blockquote>
-<p>
- jbig2dec: Check that header version matches library version.<br>
-<br>
-jbig2dec/jbig2.c<br>
-jbig2dec/jbig2.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-10 18:00:35 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a2f646ac8a07e7d019ddcb9e0ca2bdff1f5c740f">a2f646ac8a07e7d019ddcb9e0ca2bdff1f5c740f</a>
-<blockquote>
-<p>
- jbig2dec: Expose version number in header.<br>
-<br>
- Since the version number should only be specified in one location,<br>
- the public jbig2dec header, autogen.sh will not regenrate the<br>
- autoconf input file configure.ac.<br>
-<br>
-jbig2dec/autogen.sh<br>
-jbig2dec/config_win32.h<br>
-jbig2dec/configure.ac.in<br>
-jbig2dec/jbig2.h<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-10 13:44:23 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=90e56e3d9195f1aa19977629f2d3d3b4ec4d72cf">90e56e3d9195f1aa19977629f2d3d3b4ec4d72cf</a>
-<blockquote>
-<p>
- jbig2dec: Add empty m4 directory to silence libtool warning.<br>
-<br>
-jbig2dec/Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-10 13:40:08 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cb4d8dee4974e85b8c54f553520bded6fabd7b74">cb4d8dee4974e85b8c54f553520bded6fabd7b74</a>
-<blockquote>
-<p>
- jbig2dec: Silence automake warning about setting CFLAGS directly.<br>
-<br>
- Setting AM_CFLAGS is added to CFLAGS, adding the wanted XCFLAGS.<br>
-<br>
-jbig2dec/Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-10 13:39:05 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f25171c4fc2a5e7cd6bd9ab0b96a5133c038425d">f25171c4fc2a5e7cd6bd9ab0b96a5133c038425d</a>
-<blockquote>
-<p>
- jbig2dec: Silence automake warning about ar use.<br>
-<br>
-jbig2dec/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-05 18:09:20 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9f1959fb44a4da0506c8ef7a8cbb0ccbef4cceea">9f1959fb44a4da0506c8ef7a8cbb0ccbef4cceea</a>
-<blockquote>
-<p>
- jbig2dec: Fix bug where realloc returns NULL.<br>
-<br>
-jbig2dec/jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-10 05:11:16 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=67c9175c4a601a447b22e84251ec8c33ac827277">67c9175c4a601a447b22e84251ec8c33ac827277</a>
-<blockquote>
-<p>
- jbig2: Avoid integer overflow in custom allocator.<br>
-<br>
-base/sjbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-10 05:10:29 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a69dd377c6f07e08ea4f895eabb974c92adccab4">a69dd377c6f07e08ea4f895eabb974c92adccab4</a>
-<blockquote>
-<p>
- jbig2: Print messages from jbig2dec, do not just count them.<br>
-<br>
-base/sjbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-03 11:01:18 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1fb3a69df53754f6a000152606f52b2f4a658b97">1fb3a69df53754f6a000152606f52b2f4a658b97</a>
-<blockquote>
-<p>
- Fix crash reported by customer #531 with multi-threaded rendering.<br>
-<br>
- This was a race condition where threads were continuing to be started<br>
- while we were tearing threads down. This doesn't occur with most usages<br>
- because we render the entire page, but with the customer's device, it<br>
- stops reading before the last line, but the multi-threading rendering<br>
- logic tried to keep starting threads (up to NumRenderingThreads) to<br>
- have later bands available.<br>
-<br>
- The solution is to wait for all threads to be in the &quot;THREAD_DONE&quot;<br>
- state before freeing the threads.<br>
-<br>
- Also, since the color_usage_array of the main thread is shared by the<br>
- rendering threads, wait until the threads are shut down before freeing<br>
- that.<br>
-<br>
-base/gxclist.c<br>
-base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 13:49: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=d9055d0a350ca7681fb8f4854ed4f1c3bf7ed570">d9055d0a350ca7681fb8f4854ed4f1c3bf7ed570</a>
-<blockquote>
-<p>
- Bring master up to date with 9.27 release branch<br>
-<br>
- Product string, dates etc for 9.27 release candidate<br>
-<br>
- News and changelog for 9.27 release candidate<br>
-<br>
- Update product string, dates etc for 9.27 release<br>
-<br>
- News/History9.htm revisions also.<br>
-<br>
-base/version.mak<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/Internal.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>2019-04-04 10:44: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=12e31a72ffe1d2da30bf2c1976795b72ccd320b2">12e31a72ffe1d2da30bf2c1976795b72ccd320b2</a>
-<blockquote>
-<p>
- Update jbig2dec stuff for 0.16 release<br>
-<br>
-jbig2dec/CHANGES<br>
-jbig2dec/config_win32.h<br>
-jbig2dec/configure.ac<br>
-jbig2dec/jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-03 03:28:01 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=76c6de5428936c8fdb7269d7fcc31d4bdc83d745">76c6de5428936c8fdb7269d7fcc31d4bdc83d745</a>
-<blockquote>
-<p>
- Fix problems with &quot;typedef struct foo_s foo;&quot; redefinitions.<br>
-<br>
- In the header revamp, I'd left various places where we<br>
- use the above formulation in more than one location. This<br>
- is fine with all the C compilers I tested it on, but seems<br>
- to update gcc 4.1.2.<br>
-<br>
- This effect can be seen on later gcc's by using<br>
- &quot;-std=gnu89 -pedantic&quot;.<br>
-<br>
- This commit tweaks the code to avoid redefinitions of this<br>
- kind.<br>
-<br>
-base/gsfont.h<br>
-base/gsgdata.h<br>
-base/gspath.h<br>
-base/gspenum.h<br>
-base/gxchar.h<br>
-base/gxdevcli.h<br>
-base/gxfont.h<br>
-base/gxiodev.h<br>
-base/gxpath.h<br>
-base/gxtext.h<br>
-base/lib.mak<br>
-psi/imemory.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-03 08:37: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=7146b7292e27acc54d23b48472f6851ae9b51d8c">7146b7292e27acc54d23b48472f6851ae9b51d8c</a>
-<blockquote>
-<p>
- Fix PDFX_def.ps<br>
-<br>
- Bug #700942<br>
-<br>
- For some reason Git did a merge with this file when I made the change,<br>
- and it messed it up. Since we don't test these files, it didn't get<br>
- noticed.<br>
-<br>
-lib/PDFX_def.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-02 10:55: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=2c97be9f328babb7b544ab3610e6fce05e30cdc8">2c97be9f328babb7b544ab3610e6fce05e30cdc8</a>
-<blockquote>
-<p>
- pdfwrite - change the example PDF/A and PDF/X scripts<br>
-<br>
- From Bug #700930 &quot;Typo in example command for PDF/X-3 in VectorDevices.htm&quot;<br>
-<br>
- The reporter claimed that the (mis-spelled) command didn't work, which<br>
- was not surprising, since it contained a typo. After fixing the<br>
- documentation the reporter claimed that the command didn't work. This<br>
- is true and was missed because of the misleading title.<br>
-<br>
- The PDFX_def.ps file was mistakenly pulling the ProcessColorModel from<br>
- systemdict, which would only be set if this was set on the command line.<br>
- The real problem is the fact that our setpagedevice/currentpagedevice<br>
- code doesn't truly reflect the device setup, so changes to the<br>
- ProcessColorModel caused by setting ColorConversionStrategy are not<br>
- reflected in the values returned by currentpagedevice.<br>
-<br>
- This commit updates PDFX_def.ps to chaeck the ColorConversionStrategy<br>
- instead, which is more reliable, and then use the ProcessColorModel<br>
- from the currentpagedevice as a fallback if ColorConversionStrategy<br>
- is not set. (actually this should not be possible)<br>
-<br>
- Update PDFA_def.ps similarly; although it was using the currentpagedvice<br>
- this is not a reliable method.<br>
-<br>
- Finally; reformat the files, add some extra comments describing what the<br>
- code is doing, make it clearer that these files *should* be customised<br>
- and add additional some basic instruction on customising them.<br>
-<br>
-lib/PDFA_def.ps<br>
-lib/PDFX_def.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-02 08:26: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=978b03b453245c2a48abaee5addea3b7e025a2ed">978b03b453245c2a48abaee5addea3b7e025a2ed</a>
-<blockquote>
-<p>
- Fix another typo.<br>
-<br>
- HTML is annoyingly impossible to spell-check :-(<br>
-<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-01 16:15:21 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2983be3f871e480b6567f5ce5c16206a026851fe">2983be3f871e480b6567f5ce5c16206a026851fe</a>
-<blockquote>
-<p>
- PS interpreter - prevent user code overriding some commad line switches<br>
-<br>
- Bug #700935 &quot;defining BATCH causes typecheck in ifelse&quot;<br>
-<br>
- A (surprisingly large) number of command line switches are checked at<br>
- various points in gs_init.ps, but use the 'current' definition of the<br>
- key, rather than explicitly checking systemdict, which is where the<br>
- command line controls are stored.<br>
-<br>
- This meant that user code could (deliberately or accidentally) override<br>
- the system definition and cause errors or unexpected behaviour.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-01 16:12: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=34a94a5d72f8a339cad4c2e2140519c33b58de79">34a94a5d72f8a339cad4c2e2140519c33b58de79</a>
-<blockquote>
-<p>
- tiffsep devices - add TIFFDateTime to get_params<br>
-<br>
- We need to add this parameter to both put_params and get_params, or it<br>
- will not work properly.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-01 13:30: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=87e4b35c9fc15434d710f86aa265501cad61c34f">87e4b35c9fc15434d710f86aa265501cad61c34f</a>
-<blockquote>
-<p>
- Tiff devices - Honour the TIFFDateTime parameter<br>
-<br>
- The TIFFDateTime switch can be used to disable writing the date and<br>
- time into the tags of TIFF files. However, the tiffg3, tiffg4, tiffsep<br>
- and tiffsep1 devices weren't honouring the parameter.<br>
-<br>
- I believe this also affected the tiff32 and tiff8 devices, all the<br>
- tiffscaled devices and teh tiffcrle device.<br>
-<br>
- Although gdevtfax.c read the parameter, it didn't transfer it to the<br>
- devcie structure. The tiffsep and tiffsep1 devices didn't even read it.<br>
-<br>
- I can't help thinking that having our tiff support spread over 19<br>
- different devices and 3 source files<br>
-<br>
-devices/gdevtfax.c<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-01 10:58: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=b987c511229ba0b70e6a7691366d530fa8db7444">b987c511229ba0b70e6a7691366d530fa8db7444</a>
-<blockquote>
-<p>
- pdfwrite - completely remove the old colour management<br>
-<br>
- Also remove all references (I hope) from the documentation.<br>
-<br>
- While we're changing the docs, remove references to ps2pdf where we are<br>
- really referring to pdfwrite, rewrite the information on LZW Encoding,<br>
- update the 'Opitimize' distiller param note, add some covering words<br>
- about the faxt that pdfwrite doesn't permit the full range of options<br>
- in the LCMS2 implementation that rendering devices do, note that the<br>
- example PDFX_def.ps needs to be modified (cribbed from PDF/A).<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdfp.c<br>
-devices/vector/gdevpsdf.h<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-04-01 08:20: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=f5bd9757cffeb8b173cdde161b39abd381e325c3">f5bd9757cffeb8b173cdde161b39abd381e325c3</a>
-<blockquote>
-<p>
- Documentation changes<br>
-<br>
- Bug #700930 &quot;Ghostscript - Typo in example command for PDF/X-3 in VectorDevices.htm&quot;<br>
-<br>
-doc/VectorDevices.htm<br>
-lib/PDFX_def.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-29 15:43:14 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=086390943b223cd726d7f63ad076b48e57ceae0f">086390943b223cd726d7f63ad076b48e57ceae0f</a>
-<blockquote>
-<p>
- Fix Downscaler ETS brokenness.<br>
-<br>
- We are only supposed to use ETS if requested. We pass in a flag to<br>
- say whether to use it - probably best, on balance, not to ignore it.<br>
-<br>
-base/gxdownscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-28 10:36:53 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3929dbaed570ba58cccbf600ba58158ab4fafd8a">3929dbaed570ba58cccbf600ba58158ab4fafd8a</a>
-<blockquote>
-<p>
- Revise gs.c to use the gsapi API.<br>
-<br>
- It's probably better if our own code reflects the way we recommend others to<br>
- code.<br>
-<br>
-psi/gs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-28 09:21: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=a87c116174ef574465ab12493ef6d0c575bda60d">a87c116174ef574465ab12493ef6d0c575bda60d</a>
-<blockquote>
-<p>
- Fix sefault with 'so' build.<br>
-<br>
- The loaders were passing an unitialise pointer into gsapi_new_instance()<br>
- meaning we might try to dereference the pointer to get to the shared portion<br>
- of the library context.<br>
-<br>
- Initialise the pointer to NULL.<br>
-<br>
- Apply the same fix to everywhere that uses gsapi_new_instance.<br>
-<br>
-pcl/pl/plwmainc.c<br>
-pcl/pl/realmain.c<br>
-psi/apitest.c<br>
-psi/dmmain.c<br>
-psi/dpmain.c<br>
-psi/dwmain.c<br>
-psi/dwmainc.c<br>
-psi/dxmain.c<br>
-psi/dxmainc.c<br>
-toolbin/halftone/gen_stochastic/gen_stochastic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-27 14:41:13 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9723b898561c3cd7b9f207c9976994671940df56">9723b898561c3cd7b9f207c9976994671940df56</a>
-<blockquote>
-<p>
- Update thirdparty.htm: Freetype and jbig2dec versions<br>
-<br>
-doc/thirdparty.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-27 08:08: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=a21912a4c7c2a0cbc79c1a86df77b63bcae850fb">a21912a4c7c2a0cbc79c1a86df77b63bcae850fb</a>
-<blockquote>
-<p>
- Add license file for cups/libcups<br>
-<br>
-cups/LICENSE.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-26 16:26:11 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cdd481e5406b8fd07f0cc9b771adfd6877028d96">cdd481e5406b8fd07f0cc9b771adfd6877028d96</a>
-<blockquote>
-<p>
- Fix valgrind error with PXL patterns and high level devices<br>
-<br>
- Bug #700573 &quot; Uninitialised colors used in path plotting&quot;<br>
-<br>
- When the current colour space is a pattern, and the saved high level<br>
- colour space is also a pattern, we were checking every possible<br>
- component of ccolor.paint.values in both spaces against each other.<br>
-<br>
- The problem is that in gx_hld_save_color we set almost all the values to<br>
- 0, but then copy a single uninitialised value into the 0th index.<br>
-<br>
- This leads to a valgrind error. Henry points out that the PostScript<br>
- interpreter has a hack specifically to work around this in zcolor.c,<br>
- zsetcolor() at around line 313.<br>
-<br>
- This is wasteful, its far better (IMO) to rearrange the logic in<br>
- gx_hld_saved_color_equal(), we already bail out early if the colour<br>
- spaces are not equal. If the spaces are patterns, then there's no point<br>
- in comparing the device components, instead compare the pattern IDs<br>
- *before* we compare the device components, if they are the same then<br>
- return true, if they are different return false.<br>
-<br>
- This avoids us having to check 2 sets of 64 values, and also avoids us<br>
- having to set 64 values every time we create a pattern.<br>
-<br>
-base/gxhldevc.c<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-26 15:14: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=519326a98c1d2172da280305fef0a3a52ddc65bc">519326a98c1d2172da280305fef0a3a52ddc65bc</a>
-<blockquote>
-<p>
- Tweak the pcl/LICENSE to make a little more sense<br>
-<br>
- It hadn't been revised really for the &quot;new&quot; directory structure.<br>
-<br>
- It will probably benefit from a more substantial revisit, but for now, this<br>
- makes it less confusing.<br>
-<br>
-pcl/LICENSE<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-26 09:23:56 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db96dc02a83e45d2997315e52e77cb4c283c09ce">db96dc02a83e45d2997315e52e77cb4c283c09ce</a>
-<blockquote>
-<p>
- Reword the 'greeting' to reflect the open source license.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-26 09:13: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=0371b3cef0e28fa603437faf983c7be8f2160214">0371b3cef0e28fa603437faf983c7be8f2160214</a>
-<blockquote>
-<p>
- Fix 'greeting' and include COPYING in install<br>
-<br>
- The greeting message still referenced the obsolete 'PUBLIC' file. And<br>
- doc/COPYING was missing from the list of files for install.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/unixinst.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-26 10:51:36 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=686204e73479a5fde722ca00a851cfb7f0d4186a">686204e73479a5fde722ca00a851cfb7f0d4186a</a>
-<blockquote>
-<p>
- Bug 700897: fix validation of -M and -N parameters.<br>
-<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-25 19:35:07 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=81d801a07450227eee573aac5fc9259862b4a568">81d801a07450227eee573aac5fc9259862b4a568</a>
-<blockquote>
-<p>
- Fix tiffsep_cmyk_cs_to_cm in tiffsep device<br>
-<br>
- When we were doing just a single or a couple spot colorants using something like<br>
- -c &quot;&lt;&lt; /SeparationColorNames [(Pantone 137 CVU)] /SeparationOrder [(Pantone 137 CVU)]&gt;&gt;<br>
- setpagedevice&quot; the colorants mappings were not getting properly cleared by<br>
- tiffsep_cmyk_cs_to_cm causing fillpage to not clear out the page.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-25 09:01:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c70dc7911aaf559eeec0ced48f8504e24ba39b8a">c70dc7911aaf559eeec0ced48f8504e24ba39b8a</a>
-<blockquote>
-<p>
- Coverity ID 337243 - remove dead code<br>
-<br>
-devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-23 10:29:59 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4dc1cb5197292f3fa7548353c4208f507ca3b310">4dc1cb5197292f3fa7548353c4208f507ca3b310</a>
-<blockquote>
-<p>
- Another trailing white space fix<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-23 10:26:29 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8946e4418257a99ea029283405bc23b75a02e0a5">8946e4418257a99ea029283405bc23b75a02e0a5</a>
-<blockquote>
-<p>
- PDF Interpreter - fix leading and trailing white spaces in pdf_draw.ps<br>
-<br>
- Commit 09c656e066777bd69bbd1902e6163fe3a8a39406 included some<br>
- leading and trailing white spaces.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-20 13:55:54 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f1fccd62b5d1010ecec2817b1b67f3b74b145d02">f1fccd62b5d1010ecec2817b1b67f3b74b145d02</a>
-<blockquote>
-<p>
- tiffscaled: correctly select the downscaler when using ETS<br>
-<br>
- When tiffscaled uses ETS for the halftoning, and it's downscaling, we have to<br>
- select the downscaling &quot;core&quot; based on the factor.<br>
-<br>
-base/gxdownscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 17:49:14 +0100
-</strong>
-<br>Knut Petersen &lt;knut_petersen@t-online.de&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eec855c9baeaa73c0208ed439fbbf1a0d48a447e">eec855c9baeaa73c0208ed439fbbf1a0d48a447e</a>
-<blockquote>
-<p>
- Fix e005c87e09f67f37ce4ae2f80f24cf9182e86d8d<br>
-<br>
- Signed-off-by: Knut Petersen &lt;knut_petersen@t-online.de&gt;<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 10:06:38 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2d67148ab19d5e278ec4dbe9929839a37f9961b7">2d67148ab19d5e278ec4dbe9929839a37f9961b7</a>
-<blockquote>
-<p>
- Bug 700744 Documentation typo.<br>
-<br>
-doc/GS9_Color_Management.pdf<br>
-doc/GS9_Color_Management.tex<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 08:32:46 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=09c656e066777bd69bbd1902e6163fe3a8a39406">09c656e066777bd69bbd1902e6163fe3a8a39406</a>
-<blockquote>
-<p>
- Bug 700686 Matte premultiplied images<br>
-<br>
- The undoing of the matte pre-blend must occur in the image color space. As such<br>
- the group that the interpreter pushes must be that color space and we must make sure<br>
- that we undo the pre-blend before any conversions for the group color space.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-base/gdevp14.c<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 09:25:48 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db24f253409d5d085c2760c814c3e1d3fa2dac59">db24f253409d5d085c2760c814c3e1d3fa2dac59</a>
-<blockquote>
-<p>
- Fix lib/pdf2dsc.ps to use documented Ghostscript pdf procedures.<br>
-<br>
- We eliminated GS_PDF_ProcSet and pdfdict, but runpdfbegin, dopdfpages,<br>
- and runpdfend are still available.<br>
-<br>
-lib/pdf2dsc.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 08:34:05 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=332c74c6ffe84acfc0fa80a99f6590a4be9f561b">332c74c6ffe84acfc0fa80a99f6590a4be9f561b</a>
-<blockquote>
-<p>
- Fix bug 700719: SEGV with very large XStep/YStep and transparent patterns.<br>
-<br>
- At high resolutions, the bonkers XStep/YStep for the pattern could confuse<br>
- the tile_by_steps_trans logic, and could overflow a 32-bit signed int causing<br>
- a sign flip. Protect from this by checking to make sure we only fill within<br>
- the fill_trans_buffer-&gt;rect.<br>
-<br>
-base/gxp1fill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 14:35:43 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c5b92cc2dc9a20c8b6ba204f1e5a5e292bc53846">c5b92cc2dc9a20c8b6ba204f1e5a5e292bc53846</a>
-<blockquote>
-<p>
- Fix FillOrder tag for the TiffG3 and TiffG4 devices<br>
-<br>
- Bug #700255 &quot;Option FillOrder doesn't work anymore&quot;<br>
-<br>
- Commit 0ef309305417776a9f8b8cd143fbf3c5e89456b2 added the FillOrder<br>
- switch to the 'tiff' class of devices, but the fax Tiff devices already<br>
- processed that switch, and the commit did not remove the processing<br>
- from those devices.<br>
-<br>
- This led to us trying to us ending up with the parameter in the params<br>
- list twice when we executed get_params (once from the tiff device<br>
- processing and once from the tiff fax device processing).<br>
-<br>
- When we then next execute a 'put_param', the list has a duplicate<br>
- entry for FillOrder. We stop processing when we find the first entry,<br>
- which means the second entry never gets processed, leading to an<br>
- unused entry in the list, and that throws an error.<br>
-<br>
- The simplest way to fix this is to remove the duplicate 'get_param()'<br>
- processing from the tiff fax devices, leaving it up to the generic<br>
- Tiff device.<br>
-<br>
-devices/gdevtfax.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 13:12:25 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5eebbe1be2b097e541b14fecbd5a154c2cba1519">5eebbe1be2b097e541b14fecbd5a154c2cba1519</a>
-<blockquote>
-<p>
- Bump version number for release<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-<h2><a name="Version9.27"></a>Version 9.27 (2019-04-03)</h2>
-<p><strong>IMPORTANT:</strong> It is our intention, within the next 12 months (ideally sooner,
-in time for the next release) to make SAFER the default mode of operation. For many users
-this will have no effect, since they use SAFER explicitly, but some niche uses which rely
-on SAFER being disabled may need to start explicitly adding the &quot;-dNOSAFER&quot; option.
-<p> Highlights in this release include:
-<ul>
-<li>
-<p>We have extensively cleaned up the Postscript name space: removing access to internal
-and/or undocumented Postscript operators, procedures and data. This has benefits for security
-and maintainability.
-</li>
-<li>
-<p>We have added a new &quot;product&quot;: &quot;gpdl&quot;. This is a rethink/redesign of the old
-&quot;language_switch&quot; product (pspcl6), and includes all the interpreters we
-develop based on the Ghostscript graphics library: Postscript, PDF, PCL6, PXL and XPS.
-This is experimental, and should be considered of beta testing quality, and thus is not
-built by default: it can be built by using the &quot;experimental&quot; target.
-<p><code>gpdl</code> uses a heuristic to judge the file type being passed to it. In general,
-it supports most of the widely used command line options for each interpreter, but
-compatibility is not complete (the practicalities of swapping interpreters means it is
-unlikely that full parity of command line options will be possible).
-</li>
-<li>
-<p>Fontmap can now reference invidual fonts in a TrueType Collection for font subsitution.
-Previously, a Fontmap entry could only reference a TrueType collection and use the default
-(first) font. Now, the Fontmap syntax allows for specifying a specific index in a TTC.
-See the comments at the top of (the default) Fontmap.GS for details.
-</li>
-<li>
-<p>IMPORTANT: We are in the process of forking LittleCMS. LCMS2 is not thread safe, and
-cannot be made thread safe without breaking the ABI. Our fork will be thread safe, and include
-performance enhancements (these changes have all be been offered and rejected upstream). We
-will maintain compatibility between Ghostscript and LCMS2 for a time, but not in perpetuity.
-Our fork will be available as its own package separately from Ghostscript (and MuPDF).
-</li>
-<li>
-<p>The usual round of bug fixes, compatibility changes, and incremental improvements.
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-<h3><a name="9.27_Incompatible_changes"></a>Incompatible changes</h3>
-<ul>
-<li>
-<p>The process of &quot;tidying&quot; the Postscript name space should have removed
-only non-standard and undocumented operators. Nevertheless, it is possible that
-any integrations or utilities that rely on those non-standard and undocumented
-operators may stop working, or may change behaviour.
-<p>If you encounter such a case, please contact us (either the #ghostscript IRC channel,
-or the gs-devel mailing list would be best), and we'll work with you to either find an
-alternative solution.
-<p>One case we know this has occurred is GSView 5 (and earlier). GSView 5 support for PDF
-files relied upon internal use only features which are no longer available. GSView 5 will
-still work as previously for Postscript files. For PDF files, users are encouraged to look
-at <a href="https://www.mupdf.com">MuPDF</a>.
-</li>
-</ul>
-<h3><a name="9.27_changelog"></a>Changelog</h3>
-<p><strong>2019-04-03 09:27:46 +0100
-</strong>
-<p><strong>2019-04-03 09:27:46 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef23f2457ff6c215d99189a0f78bf28f42d5f98c">ef23f2457ff6c215d99189a0f78bf28f42d5f98c</a>
-<blockquote>
-<p>
- Update product string, dates etc for 9.27 release<br>
-<br>
- News/History9.htm revisions also.<br>
-<br>
-base/gscdefs.h<br>
-base/version.mak<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/Internal.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>2019-03-19 14:53:24 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5c3344f40f95c4c8fd806265e4e6191d98e06be5">5c3344f40f95c4c8fd806265e4e6191d98e06be5</a>
-<blockquote>
-<p>
- News and changelog for 9.27 release candidate<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 13:49: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=0e3084881a3f2b40ed17a9f71713304bcbf5c976">0e3084881a3f2b40ed17a9f71713304bcbf5c976</a>
-<blockquote>
-<p>
- Product string, dates etc for 9.27 release candidate<br>
-<br>
-base/gscdefs.h<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/Internal.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>2019-04-03 03:28:01 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d832f46edd65968e795f5f419107eb33a7a3e09f">d832f46edd65968e795f5f419107eb33a7a3e09f</a>
-<blockquote>
-<p>
- Fix problems with &quot;typedef struct foo_s foo;&quot; redefinitions.<br>
-<br>
- In the header revamp, I'd left various places where we<br>
- use the above formulation in more than one location. This<br>
- is fine with all the C compilers I tested it on, but seems<br>
- to update gcc 4.1.2.<br>
-<br>
- This effect can be seen on later gcc's by using<br>
- &quot;-std=gnu89 -pedantic&quot;.<br>
-<br>
- This commit tweaks the code to avoid redefinitions of this<br>
- kind.<br>
-<br>
-base/gsfont.h<br>
-base/gsgdata.h<br>
-base/gspath.h<br>
-base/gspenum.h<br>
-base/gxchar.h<br>
-base/gxdevcli.h<br>
-base/gxfont.h<br>
-base/gxiodev.h<br>
-base/gxpath.h<br>
-base/gxtext.h<br>
-base/lib.mak<br>
-psi/imemory.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-29 15:43:14 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0750e5fa1e3c988f07d3fb5adedfb0896e7b400c">0750e5fa1e3c988f07d3fb5adedfb0896e7b400c</a>
-<blockquote>
-<p>
- Fix Downscaler ETS brokenness.<br>
-<br>
- We are only supposed to use ETS if requested. We pass in a flag to<br>
- say whether to use it - probably best, on balance, not to ignore it.<br>
-<br>
-base/gxdownscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-28 09:21: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=1f602898555e969542760ac86b4e250c411e9f8c">1f602898555e969542760ac86b4e250c411e9f8c</a>
-<blockquote>
-<p>
- Fix sefault with 'so' build.<br>
-<br>
- The loaders were passing an unitialise pointer into gsapi_new_instance()<br>
- meaning we might try to dereference the pointer to get to the shared portion<br>
- of the library context.<br>
-<br>
- Initialise the pointer to NULL.<br>
-<br>
- Apply the same fix to everywhere that uses gsapi_new_instance.<br>
-<br>
-pcl/pl/plwmainc.c<br>
-pcl/pl/realmain.c<br>
-psi/apitest.c<br>
-psi/dmmain.c<br>
-psi/dpmain.c<br>
-psi/dwmain.c<br>
-psi/dwmainc.c<br>
-psi/dxmain.c<br>
-psi/dxmainc.c<br>
-toolbin/halftone/gen_stochastic/gen_stochastic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-27 14:41:13 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4be4e4195c88d195502e3e093f0177534af0439c">4be4e4195c88d195502e3e093f0177534af0439c</a>
-<blockquote>
-<p>
- Update thirdparty.htm: Freetype and jbig2dec versions<br>
-<br>
-doc/thirdparty.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-27 08:08: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=6d6a868110e7b1258f6586593f4e6405a1b0dcc3">6d6a868110e7b1258f6586593f4e6405a1b0dcc3</a>
-<blockquote>
-<p>
- Add license file for cups/libcups<br>
-<br>
-cups/LICENSE.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-26 15:14: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=10eddb8d2b327bfb78c23863577a80b40860f920">10eddb8d2b327bfb78c23863577a80b40860f920</a>
-<blockquote>
-<p>
- Tweak the pcl/LICENSE to make a little more sense<br>
-<br>
- It hadn't been revised really for the &quot;new&quot; directory structure.<br>
-<br>
- It will probably benefit from a more substantial revisit, but for now, this<br>
- makes it less confusing.<br>
-<br>
-pcl/LICENSE<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-26 09:23:56 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb161b7be76b71a99cb1761bcea7b9c13cf987fb">bb161b7be76b71a99cb1761bcea7b9c13cf987fb</a>
-<blockquote>
-<p>
- Reword the 'greeting' to reflect the open source license.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-26 09:13: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=076c127d2a1d697d9d02cf6bce70f5a692e11846">076c127d2a1d697d9d02cf6bce70f5a692e11846</a>
-<blockquote>
-<p>
- Fix 'greeting' and include COPYING in install<br>
-<br>
- The greeting message still referenced the obsolete 'PUBLIC' file. And<br>
- doc/COPYING was missing from the list of files for install.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/unixinst.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-26 10:51:36 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6cc71a794e784887fc7d41ebd87473e7a065e87d">6cc71a794e784887fc7d41ebd87473e7a065e87d</a>
-<blockquote>
-<p>
- Bug 700897: fix validation of -M and -N parameters.<br>
-<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-25 19:35:07 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f53e124de64baf9306ee55e5fda46d77091ad176">f53e124de64baf9306ee55e5fda46d77091ad176</a>
-<blockquote>
-<p>
- Fix tiffsep_cmyk_cs_to_cm in tiffsep device<br>
-<br>
- When we were doing just a single or a couple spot colorants using something like<br>
- -c &quot;&lt;&lt; /SeparationColorNames [(Pantone 137 CVU)] /SeparationOrder [(Pantone 137 CVU)]&gt;&gt;<br>
- setpagedevice&quot; the colorants mappings were not getting properly cleared by<br>
- tiffsep_cmyk_cs_to_cm causing fillpage to not clear out the page.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-25 09:01:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=76ada9e73edaf0cf661f5af85d58580caae9f882">76ada9e73edaf0cf661f5af85d58580caae9f882</a>
-<blockquote>
-<p>
- Coverity ID 337243 - remove dead code<br>
-<br>
-devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-23 10:29:59 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=06ed92ab4efddaea02069b2411aef401f8c7e5ce">06ed92ab4efddaea02069b2411aef401f8c7e5ce</a>
-<blockquote>
-<p>
- Another trailing white space fix<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-23 10:26:29 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c7de4cdfeda7916359303ad0731752918835a876">c7de4cdfeda7916359303ad0731752918835a876</a>
-<blockquote>
-<p>
- PDF Interpreter - fix leading and trailing white spaces in pdf_draw.ps<br>
-<br>
- Commit 09c656e066777bd69bbd1902e6163fe3a8a39406 included some<br>
- leading and trailing white spaces.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-21 16:42:06 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7e0a16411957a2809d61be966af6c08c9a735d84">7e0a16411957a2809d61be966af6c08c9a735d84</a>
-<blockquote>
-<p>
- Revert &quot;Update psd devices to only do one pass while rendering.&quot;<br>
-<br>
- This reverts commit d2d32bcee1cb1b28494ba9b572afa53ef84391af.<br>
-<br>
- Experiment for release testing.<br>
-<br>
-devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-20 13:55:54 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c981b6987fb6a30c1911aaa3aeb6535ce92882c">3c981b6987fb6a30c1911aaa3aeb6535ce92882c</a>
-<blockquote>
-<p>
- tiffscaled: correctly select the downscaler when using ETS<br>
-<br>
- When tiffscaled uses ETS for the halftoning, and it's downscaling, we have to<br>
- select the downscaling &quot;core&quot; based on the factor.<br>
-<br>
-base/gxdownscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 17:49:14 +0100
-</strong>
-<br>Knut Petersen &lt;knut_petersen@t-online.de&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e866aca0186d8847512686b80b2eca12988ba3f">2e866aca0186d8847512686b80b2eca12988ba3f</a>
-<blockquote>
-<p>
- Fix e005c87e09f67f37ce4ae2f80f24cf9182e86d8d<br>
-<br>
- Signed-off-by: Knut Petersen &lt;knut_petersen@t-online.de&gt;<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 10:06:38 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d66449d30e13b4a5d71559d373ab00985b0bd3c1">d66449d30e13b4a5d71559d373ab00985b0bd3c1</a>
-<blockquote>
-<p>
- Bug 700744 Documentation typo.<br>
-<br>
-doc/GS9_Color_Management.pdf<br>
-doc/GS9_Color_Management.tex<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 08:32:46 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20de9c4570bc556505069ff91c121cfb3d2f5984">20de9c4570bc556505069ff91c121cfb3d2f5984</a>
-<blockquote>
-<p>
- Bug 700686 Matte premultiplied images<br>
-<br>
- The undoing of the matte pre-blend must occur in the image color space. As such<br>
- the group that the interpreter pushes must be that color space and we must make sure<br>
- that we undo the pre-blend before any conversions for the group color space.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-base/gdevp14.c<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 09:25:48 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ebbb3ec7d20b5f4c444eb11fc9835e07229ccbd9">ebbb3ec7d20b5f4c444eb11fc9835e07229ccbd9</a>
-<blockquote>
-<p>
- Fix lib/pdf2dsc.ps to use documented Ghostscript pdf procedures.<br>
-<br>
- We eliminated GS_PDF_ProcSet and pdfdict, but runpdfbegin, dopdfpages,<br>
- and runpdfend are still available.<br>
-<br>
-lib/pdf2dsc.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 08:34:05 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=52b4d7918e5792e1fb040f1ba72bd71b9f9ec0a9">52b4d7918e5792e1fb040f1ba72bd71b9f9ec0a9</a>
-<blockquote>
-<p>
- Fix bug 700719: SEGV with very large XStep/YStep and transparent patterns.<br>
-<br>
- At high resolutions, the bonkers XStep/YStep for the pattern could confuse<br>
- the tile_by_steps_trans logic, and could overflow a 32-bit signed int causing<br>
- a sign flip. Protect from this by checking to make sure we only fill within<br>
- the fill_trans_buffer-&gt;rect.<br>
-<br>
-base/gxp1fill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 14:35:43 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e0e9e32357debd5610bca37a804f1bde62f77844">e0e9e32357debd5610bca37a804f1bde62f77844</a>
-<blockquote>
-<p>
- Fix FillOrder tag for the TiffG3 and TiffG4 devices<br>
-<br>
- Bug #700255 &quot;Option FillOrder doesn't work anymore&quot;<br>
-<br>
- Commit 0ef309305417776a9f8b8cd143fbf3c5e89456b2 added the FillOrder<br>
- switch to the 'tiff' class of devices, but the fax Tiff devices already<br>
- processed that switch, and the commit did not remove the processing<br>
- from those devices.<br>
-<br>
- This led to us trying to us ending up with the parameter in the params<br>
- list twice when we executed get_params (once from the tiff device<br>
- processing and once from the tiff fax device processing).<br>
-<br>
- When we then next execute a 'put_param', the list has a duplicate<br>
- entry for FillOrder. We stop processing when we find the first entry,<br>
- which means the second entry never gets processed, leading to an<br>
- unused entry in the list, and that throws an error.<br>
-<br>
- The simplest way to fix this is to remove the duplicate 'get_param()'<br>
- processing from the tiff fax devices, leaving it up to the generic<br>
- Tiff device.<br>
-<br>
-devices/gdevtfax.c<br>
-<p>
-</blockquote>
-<hr>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e843b2dd9a6ae935c9e00ba127302123cb9121e">2e843b2dd9a6ae935c9e00ba127302123cb9121e</a>
-<blockquote>
-<p>
- Bug 700815(2): Fix the end-of-data condition.<br>
-<br>
- The end-of-data condition in the charstring interpreter that checks for SEACs<br>
- was allowing an extra byte to read off the end of the string.<br>
-<br>
- In addition, we also want to handle the out-of-data condition for a (g)subr<br>
- gracefully.<br>
-<br>
-base/gxtype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 08:53:10 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b66ebe07ae5c1fb4ef94f9051e537d69eb789896">b66ebe07ae5c1fb4ef94f9051e537d69eb789896</a>
-<blockquote>
-<p>
- Bug 700815(1): Init gsubrNumberBias in Type 1 fonts and eexec decoder<br>
-<br>
- The gsubrNumberBias is only used for Type 2 fonts, but the structure and<br>
- charstring interpreter are shared between Type 1 and 2 fonts, so we still need<br>
- to set gsubrNumberBias for Type 1 fonts (always 0 for Type 1).<br>
-<br>
- Secondly, full initialise the eexec decoder state, along with some stack<br>
- variables during eexec decode setup.<br>
-<br>
- This fixes most of the valgrind errors in Bug 700815, but not all.<br>
-<br>
-psi/zfont1.c<br>
-psi/zmisc1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-18 10:45:12 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e005c87e09f67f37ce4ae2f80f24cf9182e86d8d">e005c87e09f67f37ce4ae2f80f24cf9182e86d8d</a>
-<blockquote>
-<p>
- Bug 700678: Check for embedded font when substituting<br>
-<br>
- When we apply a font name mapping, make sure that the ultimate font we load<br>
- comes from disk, and is not embedded in the job.<br>
-<br>
- To aid differentiating between a substitute CIDfont (cidfmap), a &quot;real&quot; CIDFont<br>
- resource, and an embedded CIDFont, add a /ResourcePath key to CIDFont resource<br>
- dictionaries (susbsitute CIDFonts contain /Path key).<br>
-<br>
-Resource/Init/gs_cidfn.ps<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-29 08:10:37 -0600
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5edf847476e7a3e342422013283f984e38b52cd9">5edf847476e7a3e342422013283f984e38b52cd9</a>
-<blockquote>
-<p>
- Bug 695903: Augment fontmap syntax to allow TTCs to work 'properly'.<br>
-<br>
- Support dictionary entries in Fontmap, so a fontmap file can contain a map to<br>
- specific fonts in a TTC.<br>
-<br>
- The romfs inlines the fontmap definitions, and ends up parsing them before<br>
- we've bootstrapped the Level 2 world properly so the '&lt;&lt;...&gt;&gt;' dictionary<br>
- syntax not only is not defined but also cannot even be parsed.<br>
-<br>
- So, temporarily enable Level 2 parsing, and include local definitions of the<br>
- names '&lt;&lt;' and '&gt;&gt;' to work as you'd expect.<br>
-<br>
-Resource/Init/Fontmap.GS<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_res.ps<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-19 09:18:09 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a49a201c82106e97148553a8394b74e6c656858">6a49a201c82106e97148553a8394b74e6c656858</a>
-<blockquote>
-<p>
- PDF interpreter - fix commit 33414cb5930ee715a23b75eb37e919b6f15f96c0<br>
-<br>
- There was a logical error in the prior commit which caused all PDF files<br>
- with a /Info dictionary to signal an error.<br>
-<br>
- This rearranges the code to have the correct logic flow, properly<br>
- producing an error only for the broken specimen file.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-18 19:30:43 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=33414cb5930ee715a23b75eb37e919b6f15f96c0">33414cb5930ee715a23b75eb37e919b6f15f96c0</a>
-<blockquote>
-<p>
- PDF interpreter - check the type of the Info dictionary before use<br>
-<br>
-<br>
- Bug #700820 &quot; GPL Ghostscript 9.26: Unrecoverable error, exit code 1&quot;<br>
-<br>
- The problem here is that the trailer dictionary has an entry for the<br>
- /Info dictionary, but the object it poitns to is not a dictionary.<br>
-<br>
- For most purposes this doesn't matter, but when the devce is pdfwrite<br>
- we try to maintain the information in that dictionary.<br>
-<br>
- This commit tests the type of the object referenced by the key in the<br>
- trailer dictionary and if the object isn't a dictionary we don't try to<br>
- use it. We do flag an error though.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-18 11:54:40 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b4e343d201e337478973824995c0bbc25955b36e">b4e343d201e337478973824995c0bbc25955b36e</a>
-<blockquote>
-<p>
- Silence a compiler warning<br>
-<br>
- This is actually a false positive, the code is:<br>
-<br>
- if ((code = glyph_show_setup(i_ctx_p, &amp;glyph)) != 0)<br>
- return code;<br>
- if ((code = gs_glyphshow_begin(igs, glyph, imemory_local, &amp;penum)) &lt; 0)<br>
- return code;<br>
-<br>
- and the warning is against gs_glyphshow_begin. However glyph is actually<br>
- initalised in the line above by glyph_show_setup. There are paths to<br>
- exit that routine without setting glyph, but they all return non-zero<br>
- exit codes.<br>
-<br>
- I suspect the return macros in glyph_show_setup and co are confusing<br>
- the compiler.<br>
-<br>
- To silence the compiler warning, simply initialise the variable.<br>
-<br>
-psi/zcharx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-18 11:13:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b11ad14c36103f3446680efa71d25a216177ccd">9b11ad14c36103f3446680efa71d25a216177ccd</a>
-<blockquote>
-<p>
- Initialise another variabel to silence valgrind<br>
-<br>
- Following on from 086d30c38cb351e95941a950ddadd300e23cd8a4<br>
-<br>
- The last.count member gets tested in pdfmark_adjust_parent_count, even<br>
- when last.id is 0, so we need to initialise that too.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-18 10:14:48 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=086d30c38cb351e95941a950ddadd300e23cd8a4">086d30c38cb351e95941a950ddadd300e23cd8a4</a>
-<blockquote>
-<p>
- pdfwrite - don't write an incomplete Outline entry<br>
-<br>
- Bug #700816 &quot;Valgrind shows problems with pdfmarks&quot;<br>
-<br>
- The file in question has a recursive Outline entry, which eventually<br>
- leads to an execstackoverflow. This causes the pdfwrite device to be<br>
- closed, which leads to it closing and writing the Outkine tree as part<br>
- of the cleanup. Because of the way the /OUT pdfmark works, this means<br>
- there is a dangling reference (because the last /OUT pdfmark had a<br>
- child, but we haven't yet received the child data).<br>
-<br>
-<br>
- There was in fact already code to deal with this, and not write out<br>
- the final outline entry. However it relied upon an uninitialised value<br>
- being 0, which of course it usually isn't.<br>
-<br>
- Fixed by initialising the value to 0, which should avoid the valgrind<br>
- warning, and prevents us writing an invalid Outline tree entry as well.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-18 09:47:35 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1f30baee070ea9da1de1cb479e3a5c49c0514267">1f30baee070ea9da1de1cb479e3a5c49c0514267</a>
-<blockquote>
-<p>
- Check error codes for configuration errors with the pdfwrite family<br>
-<br>
- Bug #800819 &quot;Incorrect parameter value for sColorConversionStrategy is silently ignored.&quot;<br>
-<br>
- The low level parameter checking for the pdfwrite family wasn't<br>
- honouring error returns from certain kinds of parameters, most notably<br>
- those involving lists of permitted values (eg ColorConversionStrategy)<br>
-<br>
- This commit throws an error for those cases.<br>
-<br>
- This causes one file in the regression test suite 'pt.ps' to throw an<br>
- error with the ps2write device. This is because the PostScript program<br>
- contains an invocation of setdistillerparams which sets the<br>
- ColorImageFilter (and GrayImageFilter) to Flate instead of DCT. Level 2<br>
- PostScript doesn't include the Flate filter, that is a level 3 addition<br>
- so we now throw an error on that file.<br>
-<br>
-devices/vector/gdevpdfp.c<br>
-devices/vector/gdevpsdp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-14 15:21:40 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=03019418e745d215beeea1c5b141524eec8346eb">03019418e745d215beeea1c5b141524eec8346eb</a>
-<blockquote>
-<p>
- Alternate way to process that whitelist at end of scanner.<br>
-<br>
- This version doesn't assume there is a --oper-- form on the list, so<br>
- it works with &quot;functions&quot; (procedures) that as well as with operators.<br>
-<br>
-toolbin/scan_ps_dicts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-14 14:17:41 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4163949fa861188f647b7106e181a8121522012f">4163949fa861188f647b7106e181a8121522012f</a>
-<blockquote>
-<p>
- Make sure all references to .sort are executeonly so it can be undef'd<br>
-<br>
- .findfontvalue and .loadttfonttables still had some references<br>
-<br>
- Note: .sort is currently only undef'd in SAFER mode<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-14 14:13:15 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d2f3830b364788a88ea6233f8255cc507f483048">d2f3830b364788a88ea6233f8255cc507f483048</a>
-<blockquote>
-<p>
- Add a bunch of extensions to whitelist<br>
-<br>
- Also, the logic for &quot;functions&quot;, which don't have the --oper-- form<br>
- on the whitelist, is currently broken, so just put everything<br>
- on the operator list until that's sorted (if ever).<br>
-<br>
-toolbin/scan_ps_dicts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-14 09:40:18 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=40c5fae8604fb6f7916beed8b5c5081e29da8cef">40c5fae8604fb6f7916beed8b5c5081e29da8cef</a>
-<blockquote>
-<p>
- Remove some code that was checking for .setglobal to be defined<br>
-<br>
- .setglobal, .currentglobal and .gsheck are all defined in psi/zvmem2.c<br>
- This code seems to be leftover from a time when that might not have been<br>
- the case, but it's unnecessary and confusing now. The comment in the<br>
- C code indicates they are always defined even for language level 1.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-14 08:57:11 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5503e225ade2de26fd9e41e63cd3d26b14c3878b">5503e225ade2de26fd9e41e63cd3d26b14c3878b</a>
-<blockquote>
-<p>
- Whitelist some more operators that are in the PLRM<br>
-<br>
- Not sure why the Ray's automated extraction didn't pick these up?<br>
-<br>
-toolbin/scan_ps_dicts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-13 14:53:41 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fbcda19eb6c8cdba96a6315dfb6f8d241c667259">fbcda19eb6c8cdba96a6315dfb6f8d241c667259</a>
-<blockquote>
-<p>
- Remove UserObjects from whitelist<br>
-<br>
- This is in the PLRM, but it's not an operator and it's not going to<br>
- show up in the scan unless 'defineuserobject' has previously been run.<br>
-<br>
-toolbin/scan_ps_dicts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-13 08:51:06 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad63987d8d4395423513e55008f6ecdcd31f9f26">ad63987d8d4395423513e55008f6ecdcd31f9f26</a>
-<blockquote>
-<p>
- Move .makeoperator docs from Language.htm to Internal.htm.<br>
- It is now an internal operator<br>
-<br>
- Remove it from whitelist in scan_ps_dicts.ps<br>
-<br>
- This has already been undef'd (after initialization), just fixing the<br>
- documentation.<br>
-<br>
- This commit also adds a new &quot;Internal.htm&quot; documentation file, and<br>
- hopefully fixes up the links to it in Readme.htm<br>
-<br>
-doc/Internal.htm<br>
-doc/Language.htm<br>
-doc/Readme.htm<br>
-toolbin/scan_ps_dicts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-13 15:18:57 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c633d492cef7de24dafcecceb6efca982b1ad8be">c633d492cef7de24dafcecceb6efca982b1ad8be</a>
-<blockquote>
-<p>
- Coverity IDs 279970 and 279971<br>
-<br>
- Add some casts to prevent implicit casting promoting unsigned values to<br>
- signed values.<br>
-<br>
- Moost places had already been handled, but three had been missed.<br>
-<br>
-devices/gdevdsp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-13 14:25:47 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=58e490fec4909b18151e25bd55c9e9f91512a007">58e490fec4909b18151e25bd55c9e9f91512a007</a>
-<blockquote>
-<p>
- Fix (non-PostScript) processing of -d switch with radix<br>
-<br>
- The -d switch can take a radix as part of the value assigned to a<br>
- named switch. For example -dDisplayFormat=16#20808 is described in the<br>
- display device documentation as selecting CMYK rendering.<br>
-<br>
- The implementation in plmain.c was completely broken and returned the<br>
- error &quot;Malformed base value for radix&quot; for any switch using '#'.<br>
-<br>
- The first problem is that we increment the pointer 'v' after checking<br>
- 'c' to see if its a number. That means when its not a number (ie #) we<br>
- have moved v on past the # character. So the test for *v being '#'<br>
- fails.<br>
-<br>
- Later we use 'val' which has been initialised to the '#' symbol in the<br>
- string. We check to see its a number or A-&gt;F or a-&gt;f and if its not<br>
- then we throw an error. Of course its initially pointing at '#' so<br>
- it fails immediately.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-08 11:51:31 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9da9391c8f0a1414be45201c79e5cc649a125341">9da9391c8f0a1414be45201c79e5cc649a125341</a>
-<blockquote>
-<p>
- Add &quot;print&quot; operator to whitelist in scan_ps_dicts.ps<br>
-<br>
-toolbin/scan_ps_dicts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-08 11:40:28 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=805ca20a78cd837b5d6a30ad7d0df0828aa5de38">805ca20a78cd837b5d6a30ad7d0df0828aa5de38</a>
-<blockquote>
-<p>
- Add final section that reports any whitelisted operators that are not seen.<br>
-<br>
- By setting the whitelist entry to //false initially, and the //true when<br>
- the operator is encountered in the scan, we can report elements that are in<br>
- the whitelist that probably don't need to be there (they've already been<br>
- undef'ed).<br>
-<br>
- Also for operators, since they may be encountered in a dict in &quot;bare&quot; form,<br>
- or may be seen in packedarray procedures with &quot;--&quot; in front and back, we<br>
- check for either having been encountered by pulling out the &quot;bare&quot; form<br>
- and checking if that whitelist entry has been seen.<br>
-<br>
-toolbin/scan_ps_dicts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-11 08:16:47 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8bc9b0e335b0b69d5b174835a92270903c1dd830">8bc9b0e335b0b69d5b174835a92270903c1dd830</a>
-<blockquote>
-<p>
- Fix Bug #700575 valgrind problem with decode_char.<br>
-<br>
- Previously PCL stored the character code when encoding and returned it<br>
- upon decode. This was only implemented properly for TrueType fonts,<br>
- ie. Intellifont or bitmap fonts did not set the character which<br>
- resulted in an unitialized read. Ostensibly (for PCL/XL) high level<br>
- devices pass the character back upon decode, so it is only necessary<br>
- to return the passed in value and we can dispense with storing the<br>
- last character.<br>
-<br>
-pcl/pl/plchar.c<br>
-pcl/pl/plfont.c<br>
-pcl/pl/plfont.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-11 08:32: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=b881341b3d9993d88a1b395b552f28e62d0abc20">b881341b3d9993d88a1b395b552f28e62d0abc20</a>
-<blockquote>
-<p>
- Fix a typo in an error message<br>
-<br>
- Reported by Michael Witten via email. There was a typo in the error<br>
- message when the number of entries in an xref table didn't match the<br>
- value associated with the /Size key in the trailer dictionary.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-08 11:55:27 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6deec5bffda4b7b3e2f7daa4801150e469b4be95">6deec5bffda4b7b3e2f7daa4801150e469b4be95</a>
-<blockquote>
-<p>
- reformat a conditional to avoid a compiler warning<br>
-<br>
- gcc was giving a false warning on 'glyph' being used uninitialised,<br>
- which is not (I believe) the case. I could fix it by initialising the<br>
- variable, but instead lets remove the annoying multiple calls in an if<br>
- clause.<br>
-<br>
- I'm not certain this will silence the warning.<br>
-<br>
-psi/zcharx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-07 16:51: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=3c8bc1663619afa6dcf74c287801408508c504b1">3c8bc1663619afa6dcf74c287801408508c504b1</a>
-<blockquote>
-<p>
- Bug 700701: stack cleanup for all 'show' operator family.<br>
-<br>
- The exec stack cleanup done in 'show' needs applied to all the other similar<br>
- operators.<br>
-<br>
-psi/zchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-07 13:39:58 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=32258b5f0fe0db14142a6487c46121afa65c2538">32258b5f0fe0db14142a6487c46121afa65c2538</a>
-<blockquote>
-<p>
- Add 'min' and 'max' back in<br>
-<br>
- These are harmless and redundant, but they have been around a long<br>
- time and are documented in Language.htm, so it seems better to keep<br>
- them than to break stuff.<br>
-<br>
- Internal code all uses .min and .max instead, so yes there are two<br>
- versions of the same thing...<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-07 13:28:29 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9f811276ed9eb29a1dc8284159a2995e9be4dabf">9f811276ed9eb29a1dc8284159a2995e9be4dabf</a>
-<blockquote>
-<p>
- Fix the test for which whitelisted operators were found, to check boolean<br>
-<br>
-toolbin/scan_ps_dicts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-07 11:07:30 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3d3e0f2788fd3403bf5ac8d31b732f1404cca4aa">3d3e0f2788fd3403bf5ac8d31b732f1404cca4aa</a>
-<blockquote>
-<p>
- Add a check to scan_ps_dicts.ps to report whitelist entries that aren't found.<br>
-<br>
-toolbin/scan_ps_dicts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-07 12:38:33 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a835217e1f61272f8830eac643f689ba041902e">9a835217e1f61272f8830eac643f689ba041902e</a>
-<blockquote>
-<p>
- Change to use a list of operator/function names and add to dict later<br>
-<br>
- - can break out the lists by category (standard vs extensions)<br>
- - adds the &quot;--&quot; around operators dynamically<br>
- - can put non-operators (functions) in a separate list if desired<br>
- - changed the value in the dict to //false<br>
-<br>
-toolbin/scan_ps_dicts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-07 10:29:17 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9302928bf518f3ce3e739f1ea428e5f82729d7d9">9302928bf518f3ce3e739f1ea428e5f82729d7d9</a>
-<blockquote>
-<p>
- Undef .pdfcharkeys in gs_ttf.ps<br>
-<br>
- Change references to immediate evaluation and undef at end of file<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-07 10:29:01 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36e629576399a596b930878dad0438f9c9a19dd6">36e629576399a596b930878dad0438f9c9a19dd6</a>
-<blockquote>
-<p>
- Add some ghostscript extensions to whitelist<br>
-<br>
-toolbin/scan_ps_dicts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-07 08:30:38 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ccf0be61013372c4c449f0b760fa00ac0b20245f">ccf0be61013372c4c449f0b760fa00ac0b20245f</a>
-<blockquote>
-<p>
- Change shellarguments to .shellarguments and document it.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-doc/Language.htm<br>
-lib/gslp.ps<br>
-lib/pf2afm.ps<br>
-lib/pfbtopfa.ps<br>
-lib/pphs.ps<br>
-lib/printafm.ps<br>
-lib/rollconv.ps<br>
-lib/viewcmyk.ps<br>
-lib/viewpbm.ps<br>
-lib/viewpcx.ps<br>
-lib/viewraw.ps<br>
-lib/viewrgb.ps<br>
-toolbin/pdf_info.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-06 13:57:56 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5a3721b36da0a1a28cb6d132d2c6ae11e1592c0">b5a3721b36da0a1a28cb6d132d2c6ae11e1592c0</a>
-<blockquote>
-<p>
- Undef .confirm, .confirmread<br>
-<br>
- There was a reference in doc/SavedPages.htm to .confirmread which has<br>
- been changed in 314c6b9026efbcada4e48b11c9a173a5e91d779c<br>
- to use standard postscript.<br>
-<br>
- 1) Rearranged code so things are defined before use.<br>
- 2) Change all references to immediate evaluation.<br>
- 3) undef<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-06 16:11:43 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6ddc968966327f3bc24d1edc6a25c0f7ef82cd4">f6ddc968966327f3bc24d1edc6a25c0f7ef82cd4</a>
-<blockquote>
-<p>
- Remove the ownership document.<br>
-<br>
- This hasn't been kept up to date, most of the information can be found<br>
- in Bugzilla by looking at default assignee per component.<br>
-<br>
-doc/who_owns_what.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-06 16:08:56 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b100b794af3da27c127212af96bf4668fbda89b">2b100b794af3da27c127212af96bf4668fbda89b</a>
-<blockquote>
-<p>
- Bug #700671 - error code not propagated back.<br>
-<br>
- In attempt to clean up after an error PCL was stepping on the original<br>
- error code resulting in the interpreter continuing without fonts.<br>
-<br>
-pcl/pcl/pctop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-06 15:30:14 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b731a0d961516bd42b510e1ae036cca109b0ccdb">b731a0d961516bd42b510e1ae036cca109b0ccdb</a>
-<blockquote>
-<p>
- Bug #700671 fix file mode.<br>
-<br>
- The file mode was incorrectly specified to include 'b' with the<br>
- sfopen(), the stream code adds another 'b' because it is always<br>
- binary. This can cause a crash on Windows 10 (see bug #696101).<br>
- Further gp_file_rb should only be used with gp_fopen().<br>
-<br>
-pcl/pl/plfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-06 13:41:07 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=314c6b9026efbcada4e48b11c9a173a5e91d779c">314c6b9026efbcada4e48b11c9a173a5e91d779c</a>
-<blockquote>
-<p>
- Rework a saved-pages example to use standard PostScript (not .confirmread)<br>
-<br>
-doc/SavedPages.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-06 13:38:08 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b9947ecde3bb1cd265ab24e5fd5086ae9f09bdc4">b9947ecde3bb1cd265ab24e5fd5086ae9f09bdc4</a>
-<blockquote>
-<p>
- Tweak whitelist of scan_ps_dicts.ps, add some color ops<br>
-<br>
- - remove statusdict<br>
- - add some standard operators that aren't in the PLRM (related to color)<br>
-<br>
-toolbin/scan_ps_dicts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-06 10:28:52 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=882aec138f3b734182f7494c69cf8c67d72aba77">882aec138f3b734182f7494c69cf8c67d72aba77</a>
-<blockquote>
-<p>
- Undef deprecated min,max,unread and clean up undef of .unread<br>
-<br>
- min, max and unread have been deprecated since like 2001. Deleted<br>
- their definitions. This broke vasaley.ps test file, but I edited it<br>
- to define its own &quot;min&quot;.<br>
-<br>
- Changed existing uses of 'unread' to '.unread', 'min' to '.min', 'max'<br>
- to '.max'.<br>
-<br>
- Made sure all uses of .unread are executeonly.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_img.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_type1.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-06 10:22:25 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ee9e9f283c82eed181d5a11c7bea3735090fd680">ee9e9f283c82eed181d5a11c7bea3735090fd680</a>
-<blockquote>
-<p>
- Add whitelist to scan_ps_dicts.ps<br>
-<br>
- Note that unfortunately, we have to have operators both in the 'bare'<br>
- form and the display form e.g. (exit) (--exit--).<br>
-<br>
-toolbin/scan_ps_dicts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-05 13:18:10 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f5e8f8118bdca7ecae547a1d33d10ae1ec97d646">f5e8f8118bdca7ecae547a1d33d10ae1ec97d646</a>
-<blockquote>
-<p>
- Don't define SAFERUndefinePostScriptOperators unless in SAFER<br>
-<br>
- Previously if SAFER not true, then this would be defined and never undefined.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-05 15:47:16 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=77152d4b71cf542f3c4cb610ad97c3a4d4efa65b">77152d4b71cf542f3c4cb610ad97c3a4d4efa65b</a>
-<blockquote>
-<p>
- Initial version of utility to scan dictionaries for operators<br>
-<br>
-toolbin/scan_ps_dicts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-28 14:57:55 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a45e3a9bf7b878c6f4e4a840ade4e64b5c56cd80">a45e3a9bf7b878c6f4e4a840ade4e64b5c56cd80</a>
-<blockquote>
-<p>
- Cleaned up dead code related to .savelocalstate<br>
-<br>
- .savelocalstate was part of display postscript (gs_dps.ps), so it is<br>
- no longer defined. Cleaned up conditional code that is now dead code.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-28 14:22:32 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=097bb257147f45e5d1c15278cb95b7d19a147ac8">097bb257147f45e5d1c15278cb95b7d19a147ac8</a>
-<blockquote>
-<p>
- Undef .makeinternaldict in gs_init.ps<br>
-<br>
- This used to be used more in gs_dps.ps, when multiple contexts were supported.<br>
- Downgraded it from an operator to a function. It's now only used in one<br>
- place, so undef right after use.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-28 12:50:34 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=def941fa84d55e9ffdd76dec5009440904cf792b">def941fa84d55e9ffdd76dec5009440904cf792b</a>
-<blockquote>
-<p>
- Undef .getpath in gs_init.ps<br>
-<br>
- This was another case where the operator is defined in C and was put<br>
- into the level2dict for no apparent reason. The code that uses it (in<br>
- pdf_ops.ps and pdf_draw.ps) didn't have level2dict available on the<br>
- dictstack when it defined the operators, so it wasn't getting bound.<br>
-<br>
- Solution is to take .getpath out of level2dict. Added zupath_op_defs<br>
- for it and fixed makefile. Then can easily undef it.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-psi/int.mak<br>
-psi/zupath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-28 10:41:44 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f26771b927e154c63101a08c9ca6ecef564e80a3">f26771b927e154c63101a08c9ca6ecef564e80a3</a>
-<blockquote>
-<p>
- Undef .useloresscreen in gs_init.ps<br>
-<br>
- Change to immediate evaluation and undef after use.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-28 09:10:29 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=15e29a6e26dca230b9f35ec9bfa92de37a6f7c8c">15e29a6e26dca230b9f35ec9bfa92de37a6f7c8c</a>
-<blockquote>
-<p>
- Undef .setdefaultbgucr in gs_init.ps<br>
-<br>
- This is just used locally. Change to immediate evaluation and undef after use.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-27 15:21:57 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b8a02cc76747e78e86ad5a127d1aec832b1b7566">b8a02cc76747e78e86ad5a127d1aec832b1b7566</a>
-<blockquote>
-<p>
- Undef .beginpage, .endpage in gs_init.ps<br>
-<br>
- Make sure all uses are executeonly.<br>
- After all the other cleanups, these are now easily undefined.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-27 14:25:08 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c7b85fa9d84d5c9304c783461d5c8b91d580bfbb">c7b85fa9d84d5c9304c783461d5c8b91d580bfbb</a>
-<blockquote>
-<p>
- Undef .mergespecial,.requiredattrs dictionaries in gs_setpd.ps<br>
-<br>
- These are only used locally, but contain some functions (such as<br>
- InputAttributes) which were exposed.<br>
-<br>
- Change to immediate evaluation and undef at end of file.<br>
-<br>
-Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-27 13:58:55 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c2ad80deefb2b5af6b432cf4aa9942303fff17b3">c2ad80deefb2b5af6b432cf4aa9942303fff17b3</a>
-<blockquote>
-<p>
- Undef .clearerror in gs_init.ps<br>
-<br>
- Move definition above use, make all uses immediate evaluation and undef.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-27 13:28:49 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=359306748b1aee2497d650b82a5222df2d99e702">359306748b1aee2497d650b82a5222df2d99e702</a>
-<blockquote>
-<p>
- Undef .type11mapcid, .type9mapcid<br>
-<br>
- Made sure all uses were bind and executeonly, then can undef.<br>
-<br>
- Note that the &quot;CIDWProc&quot; in pdf_font.ps wasn't bound. I didn't see<br>
- any reason for that, so I bound it.<br>
-<br>
-Resource/Init/gs_cidfn.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-27 12:42:11 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af2c7b51e110d831e1c133e2635b2bad8e2e7dc8">af2c7b51e110d831e1c133e2635b2bad8e2e7dc8</a>
-<blockquote>
-<p>
- Undef EPSBoundingBoxInit in gs_init.ps<br>
-<br>
- This is only referenced during initialization. Undef after use.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-27 11:40:03 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34c34b9d9cc51bb90bf1e7c761bb917fcd094734">34c34b9d9cc51bb90bf1e7c761bb917fcd094734</a>
-<blockquote>
-<p>
- Undef .unstoppederrorhandler in gs_init.ps<br>
-<br>
- Change to immediate evaluation and undef right after use.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-04 07:14: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=7cb19e8362925329feed688db308aa3e5b935d0a">7cb19e8362925329feed688db308aa3e5b935d0a</a>
-<blockquote>
-<p>
- Coverity ID 33608<br>
-<br>
- We weren't acting on a return value. If we get an error, which I believe<br>
- should actually be impossible in this case, we might potentially have<br>
- an invalid object being pointed to by an array.<br>
-<br>
- Just in case, if we get an error here, discard the array we just<br>
- allocated and propagate the error.<br>
-<br>
-psi/istack.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-04 07:05:21 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c38992507901fb8a3991ae61f5301f28719230b7">c38992507901fb8a3991ae61f5301f28719230b7</a>
-<blockquote>
-<p>
- Coverity ID 333611<br>
-<br>
- The error handling code in the run length encode filter confuses<br>
- Coverity because it relies on a series of 'got' operations that jump<br>
- into a block of otherwise unreachable code.<br>
-<br>
- The code is (IMO) ugly and confusing, so refactor it to avoid the<br>
- 'if (0)' blocks. This results in many fewer goto labels, and simpler<br>
- code.<br>
-<br>
-base/srle.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-04 07:02: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=ff41c469b656224fb90083e8f622af21952266d9">ff41c469b656224fb90083e8f622af21952266d9</a>
-<blockquote>
-<p>
- Coverity ID 333614 sign extension<br>
-<br>
- An intermediate calculation results in a cast to 'int' which is then<br>
- promoted (on 64-bit systems) to an unsigned long long. If the top bit<br>
- of the intermediate value is set, then all the top bits of the final<br>
- value will be set.<br>
-<br>
- Do an explicit cast to an unsigned to avoid this.<br>
-<br>
-devices/gdevxalt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-04 06:09: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=00909869edf9f38af985086495e310ed2ea6b916">00909869edf9f38af985086495e310ed2ea6b916</a>
-<blockquote>
-<p>
- Coverity IDs 333615, 333613, 333610, 333606<br>
-<br>
- Recent changes ot the code (extra chacking of the return value from<br>
- gs_matrix_invert are causing Coverity to regard unchecked return codes<br>
- from this routine as a problem.<br>
-<br>
- Add return code checks (or cast to void) to pacify.<br>
-<br>
-contrib/eplaser/gdevescv.c<br>
-contrib/lips4/gdevl4v.c<br>
-contrib/opvp/gdevopvp.c<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-04 05:54:56 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a7ab9861741f1aad06f4932c92b1a27fc13e230e">a7ab9861741f1aad06f4932c92b1a27fc13e230e</a>
-<blockquote>
-<p>
- Coverity ID #333616<br>
-<br>
- Add a comment to the default case so that Coverity can tell that we<br>
- fall through to the next case deliberately.<br>
-<br>
-base/srle.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-03-02 15:04:33 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d5bc9bd2a548e6c12dd8224b6d18615d050a5731">d5bc9bd2a548e6c12dd8224b6d18615d050a5731</a>
-<blockquote>
-<p>
- Only use plug-in clone if transform is not identity<br>
-<br>
- lcms will if it finds the table is essentially the identity set<br>
- the transform to a copy operation. If this is the case, then<br>
- just use that operation as it will be as fast as things can get.<br>
-<br>
-lcms2mt/src/cmsxform.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-26 17:22:21 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79ce761f39aac21c270d8fb19142f5f8146440d2">79ce761f39aac21c270d8fb19142f5f8146440d2</a>
-<blockquote>
-<p>
- Bug 700606: Fix problem with interpolated indexed &gt;8bit images.<br>
-<br>
- In the initial decode of the line, all but the first pixel of the<br>
- line is getting a value 0.<br>
-<br>
- We look to be wrongly applying the nth map function to the nth<br>
- pixel, when the nth map function is intended for the nth component<br>
- of the pixel. Given we are only processing indexed images at this<br>
- point, we therefore always want the 0th map function.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-26 19:38:12 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6931f9b2fe9aa8d6ffcdbfece50ffde0ac8d00e8">6931f9b2fe9aa8d6ffcdbfece50ffde0ac8d00e8</a>
-<blockquote>
-<p>
- Undef /.generate_dir_list_templates, /.generate_dir_list_templates_with_length<br>
-<br>
- Made these operators due to length. Made sure all uses are executeonly.<br>
- Undef in gs_init.ps<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-26 15:46:24 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ebea5737da47a55e0838b9472bc05d209717d670">ebea5737da47a55e0838b9472bc05d209717d670</a>
-<blockquote>
-<p>
- Undef .internalstopped in gs_init.ps<br>
-<br>
- This is used all over the place, tons of edits. Making it an operator<br>
- didn't work (something to do with the stack during an error I think --<br>
- fails on tests_private/ps/ps3fts/141-01.ps).<br>
-<br>
- So I made all the references be immediate evaluation, then can undef<br>
- in gs_init.ps.<br>
-<br>
-Resource/Init/gs_btokn.ps<br>
-Resource/Init/gs_cidfm.ps<br>
-Resource/Init/gs_cidfn.ps<br>
-Resource/Init/gs_cidtt.ps<br>
-Resource/Init/gs_cmap.ps<br>
-Resource/Init/gs_diskn.ps<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_frsd.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_res.ps<br>
-Resource/Init/gs_setpd.ps<br>
-Resource/Init/gs_type1.ps<br>
-Resource/Init/pdf_base.ps<br>
-Resource/Init/pdf_main.ps<br>
-Resource/Init/pdf_ops.ps<br>
-Resource/Init/pdf_rbld.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-26 14:34:08 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=239d82b8b382afd435f3b48025954715633da9a9">239d82b8b382afd435f3b48025954715633da9a9</a>
-<blockquote>
-<p>
- Fixed previous undef of .stopped<br>
-<br>
- The .stopped operator had been previously undef'd, but all the usages<br>
- weren't executeonly so it still shows up in the operator scan. Made usages<br>
- executeonly so .stopped is more thoroughly gone.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-26 13:13:21 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a4dbb260b6525e65d9bbe894591a79830afe191e">a4dbb260b6525e65d9bbe894591a79830afe191e</a>
-<blockquote>
-<p>
- Undef .numicc_components and .set_outputintent in gs_init.ps<br>
-<br>
- These are defined as C operators and used in pdf_main.ps. For some<br>
- reason they were defined in ll3dict, and during their use in<br>
- pdf_main.ps, ll3dict wasn't on the dictstack, so they didn't get<br>
- bound, meaning they couldn't easily be undef'd.<br>
-<br>
- The solution I picked was to take them out of ll3dict, as I see no<br>
- reason for them to be there. That's a change to the C code (zicc.c).<br>
- I also renamed the structure to be zicc_op_defs instead of<br>
- zicc_ll3_op_defs, to eliminate any confusion. That required a<br>
- makefile change (int.mak).<br>
-<br>
- After those changes, undef'ing in gs_init.ps is easy.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-psi/int.mak<br>
-psi/zicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-26 09:58:03 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=94a78ca611ccc59383e5c4ea4beba4a13f4d4afd">94a78ca611ccc59383e5c4ea4beba4a13f4d4afd</a>
-<blockquote>
-<p>
- Undef .runresource in gs_init.ps<br>
-<br>
- Change to immediate evaluation (used in gs_res.ps) and undef.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-26 09:53:37 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=81c820ac5154751b248bdc91d0416d1eec354be2">81c820ac5154751b248bdc91d0416d1eec354be2</a>
-<blockquote>
-<p>
- Undef .PurgeDict in gs_init.ps<br>
-<br>
- This was already used with immediate evaluation, so just undef it.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-21 15:13:50 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2aa1452450845649105c752c246a7a9c9b93b479">2aa1452450845649105c752c246a7a9c9b93b479</a>
-<blockquote>
-<p>
- Undef .registererror and .registererror2 in gs_init.ps<br>
-<br>
- .registererror2 is only used locally. Move code so it's defined before use.<br>
- Change to immediate evaluation and undef right afterwards.<br>
-<br>
- .registererror is only used during initialization (not used in any<br>
- procedure definitions), though it's also used in gs_dps2.ps in the same way.<br>
- Undef after the uses.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-21 13:22:20 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23f68c46dd32cc955aec10bfc1c13438bb89a166">23f68c46dd32cc955aec10bfc1c13438bb89a166</a>
-<blockquote>
-<p>
- Undef .execute in gs_init.ps<br>
-<br>
- Used locally, had to rearrange some code.<br>
- Change to immediate evaluation and undef after use.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-21 10:40:58 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d17c277a2e847990fccab18de357afea87024065">d17c277a2e847990fccab18de357afea87024065</a>
-<blockquote>
-<p>
- Undef .printerror_long in gs_init.ps<br>
-<br>
- Some whitespace changes and moved code around.<br>
- This is only used locally.<br>
- Change to immediate evaluation and undef after use.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-21 09:07:51 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be56100b1ecf53092c9d678e4783b5660eb3e47e">be56100b1ecf53092c9d678e4783b5660eb3e47e</a>
-<blockquote>
-<p>
- Clean up and rearrange some code related to SAFER<br>
-<br>
- Add some comments about which ones are extensions and to separate the code.<br>
- Make the temporary stuff not be operators (no need).<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-21 08:53:51 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bdd92585f4a0aaa734053a5755e556ed61c8545d">bdd92585f4a0aaa734053a5755e556ed61c8545d</a>
-<blockquote>
-<p>
- Undef .locksafeglobal, .locksafe_userparams in gs_init.ps<br>
-<br>
- Both of these are only used locally in gs_init.ps. Undef right after use.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-25 14:55: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=a3b526cafb940890aff47dd9933777b88321b3ce">a3b526cafb940890aff47dd9933777b88321b3ce</a>
-<blockquote>
-<p>
- Bug 700678: Check for embedded font when substituting<br>
-<br>
- When we apply a font name mapping, make sure that the ultimate font we load<br>
- comes from disk, and is not embedded in the job.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-25 19:16: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=d2d32bcee1cb1b28494ba9b572afa53ef84391af">d2d32bcee1cb1b28494ba9b572afa53ef84391af</a>
-<blockquote>
-<p>
- Update psd devices to only do one pass while rendering.<br>
-<br>
- Previously, PSD devices would loop over each component in the file<br>
- and then over each line in the file. For non-page mode rendering<br>
- therefore, we would render each page as many times as there were<br>
- components.<br>
-<br>
- Change the logic here to loop over each component, then over each<br>
- line.<br>
-<br>
- This means we seek within the file as we write, but we already<br>
- impose restrictions on the output for this device to ensure that<br>
- we don't write multiple pages to the same file, so this is no<br>
- great loss.<br>
-<br>
-devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-25 19:51:16 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4c741f6ff9b1ab8a0fb433af9db8d7b0db335318">4c741f6ff9b1ab8a0fb433af9db8d7b0db335318</a>
-<blockquote>
-<p>
- Have lcms2mt clone method check for transform plug-ins<br>
-<br>
- When cloning a transform, it is necessary to see if there<br>
- are any plugins that should be used with the new data types.<br>
-<br>
-lcms2mt/src/cmsxform.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-24 22:01: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=d683d1e6450d74619e6277efeebfc222d9a5cb91">d683d1e6450d74619e6277efeebfc222d9a5cb91</a>
-<blockquote>
-<p>
- Bug 700585: Obliterate &quot;superexec&quot;. We don't need it, nor do any known apps.<br>
-<br>
- We were under the impression that the Windows driver 'PScript5.dll' used<br>
- superexec, but after testing with our extensive suite of PostScript file,<br>
- and analysis of the PScript5 &quot;Adobe CoolType ProcSet, it does not appear<br>
- that this operator is needed anymore. Get rid of superexec and all of the<br>
- references to it, since it is a potential security hole.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-psi/icontext.c<br>
-psi/icstate.h<br>
-psi/zcontrol.c<br>
-psi/zdict.c<br>
-psi/zgeneric.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-22 13:43:15 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1bc4205dca71ca075af6ca95aa53a33f5a724586">1bc4205dca71ca075af6ca95aa53a33f5a724586</a>
-<blockquote>
-<p>
- Bug 700584 Cups device<br>
-<br>
- The RGBW color space needs to have the white value mapped properly during the encode process.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-21 13:01:24 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f89824ec77691e80b954fd0e783fc41cf6246599">f89824ec77691e80b954fd0e783fc41cf6246599</a>
-<blockquote>
-<p>
- Bug 692405 X11 device<br>
-<br>
- The X11 device copy_color proc was accessing indices outside its 16 value cache<br>
- causing improper color drawing for the cmyk2 device. For the cmyk4 device, the<br>
- bit manipulations mapping to rgb were incorrect.<br>
-<br>
-devices/gdevxalt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-21 19:12:18 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd60ff8ba5030f078eccabe26a617374c1c2961f">dd60ff8ba5030f078eccabe26a617374c1c2961f</a>
-<blockquote>
-<p>
- Improve bounding box return for clip list accumulator.<br>
-<br>
- This should hopefully reduce the amount of work the scan converter<br>
- has to do every time it writes to the clip list accumulator; in<br>
- particular the clist should set this up so that we don't needlessly<br>
- scan convert lines outside the current band.<br>
-<br>
-base/gxacpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-21 14:20:40 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=02b6572798cfa75f1b77cfa666748add0ae7db31">02b6572798cfa75f1b77cfa666748add0ae7db31</a>
-<blockquote>
-<p>
- Bug 700643: Rejig scan converter - back off in high memory cases.<br>
-<br>
- Group scan converter calling logic together, and call it through<br>
- a single gx_scan_convert_and_fill function.<br>
-<br>
- Have the scan converter bale if the required memory is larger than<br>
- an arbitrary size (currently 1Meg). We subdivide the path into<br>
- bands and retry.<br>
-<br>
-base/gxfill.c<br>
-base/gxscanc.c<br>
-base/gxscanc.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-19 16:37:53 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ed1d07fb8c324dea9988359bbcc400979155ffa8">ed1d07fb8c324dea9988359bbcc400979155ffa8</a>
-<blockquote>
-<p>
- Avoid buffer overflow in transparency buffer dump debug.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-18 17:48:32 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f5a93cd8ca658ce80234319e7355335086c71872">f5a93cd8ca658ce80234319e7355335086c71872</a>
-<blockquote>
-<p>
- Tweak &quot;device_encodes_tags&quot; to avoid const warnings.<br>
-<br>
-base/gxdevcli.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-22 12:28: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=a82601e8f95a2f2147f3b3b9e44ec2b8f3a6be8b">a82601e8f95a2f2147f3b3b9e44ec2b8f3a6be8b</a>
-<blockquote>
-<p>
- Bug 700576(redux): an extra transient proc needs executeonly'ed.<br>
-<br>
-Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-21 07:35:41 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=70e04b6d103193dd1eb1e7748cb6fb231c0482cf">70e04b6d103193dd1eb1e7748cb6fb231c0482cf</a>
-<blockquote>
-<p>
- Undef .setsafeglobal<br>
-<br>
- Only used in gs_init.ps, undef right after use.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-19 15:03:16 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=04e71e429c83dead2c5e69bf126b5c8cf1c18167">04e71e429c83dead2c5e69bf126b5c8cf1c18167</a>
-<blockquote>
-<p>
- Undef .vmreclaim in gs_init.ps<br>
-<br>
- This was tricky because it can be used in showpage, which wasn't bound.<br>
- Previous commit makes it possible to bind showpage.<br>
-<br>
- It's used for debugging in the memento build, but this is useful so I<br>
- needed to maintain that functionality.<br>
-<br>
- Also used in gs_lev2.ps, so make sure that is bound.<br>
-<br>
- Since this operator is defined in C in the level2dict, it needs to<br>
- be undef'd from both systemdict and level2dict.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_lev2.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-19 14:56:31 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a6d754d60409d4ff3832d83801b1d3f96303932">9a6d754d60409d4ff3832d83801b1d3f96303932</a>
-<blockquote>
-<p>
- Make it possible to .bind showpage and copypage<br>
-<br>
- A bunch of operators were being redefined later in other code, so that<br>
- binding showpage and copypage picked up the wrong versions. I think<br>
- historically this was due to the way level2/level3 support was<br>
- implemented. Since we no longer support level1 postscript, we can<br>
- clean some of this up.<br>
-<br>
- The cleanup involves moving some operators from other files into<br>
- gs_init.ps and also removing duplicate (level1) definitions when applicable.<br>
-<br>
- - Move 'initgraphics' operator definition from gs_cspace.ps<br>
- - Move .currentnumcopies, .beginpage, .endpage from gs_setpd.ps<br>
- - Move 'copypage' definition down near showpage, so code is in right places<br>
-<br>
- There are no changes to the code within the moved functions, other than to<br>
- make them .bind executeonly.<br>
-<br>
-Resource/Init/gs_cspace.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-19 08:38:08 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=214fdd5625c81afa4e2c206eb3e54f1f0435580f">214fdd5625c81afa4e2c206eb3e54f1f0435580f</a>
-<blockquote>
-<p>
- Undef .getdefaulthalftone in gs_init.ps<br>
-<br>
- Used in gs_init.ps and gs_ll3.ps. Change to immediate evaluation and undef.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_ll3.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-19 09:29:48 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb5b4c273d42584d560d5d923565fcb4a07ff02d">eb5b4c273d42584d560d5d923565fcb4a07ff02d</a>
-<blockquote>
-<p>
- Undef .bindoperators in gs_init.ps<br>
-<br>
- We undef in different places depending on whether BINDNOW is true or not.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-18 12:11:45 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be86d2ff2f0f0ea0e365707f3be0fa0c9e7315ee">be86d2ff2f0f0ea0e365707f3be0fa0c9e7315ee</a>
-<blockquote>
-<p>
- Bug 700599: Issue an error message if an ExtGstate is not found.<br>
-<br>
- Previously, this was silently ignored. Only issue a single warning,<br>
- and respect PDFSTOPONERROR to prevent continuing with potentially<br>
- incorrect output.<br>
-<br>
- Note that tests_private/pdf/uploads/bug696410.pdf also now gets this<br>
- error message (ExtGState&quot; instead of ExtGState in object 10).<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-20 09:54: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=ed9fcd95bb01f0768bf273b2526732e381202319">ed9fcd95bb01f0768bf273b2526732e381202319</a>
-<blockquote>
-<p>
- Bug 700576: Make a transient proc executeonly (in DefineResource).<br>
-<br>
- This prevents access to .forceput<br>
-<br>
- Solution originally suggested by cbuissar@redhat.com.<br>
-<br>
-Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-20 09:50:13 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=73d1a911f4c8b19c19d37a963c39b01a181b46e1">73d1a911f4c8b19c19d37a963c39b01a181b46e1</a>
-<blockquote>
-<p>
- Update to iclude TOC overflow solution<br>
-<br>
- Also, remove the RS/6000 reference, and just reference IBM AIX<br>
-<br>
-doc/Make.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-19 19:34:59 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e1d09836703104ca5ac8cb94a47f2ce27bee28cd">e1d09836703104ca5ac8cb94a47f2ce27bee28cd</a>
-<blockquote>
-<p>
- Macro removal<br>
-<br>
- Get rid of two macros in the halftone tile creation code.<br>
- One was replaced with an inline function. The other was simple<br>
- enough and used only in two spots to just use directly.<br>
-<br>
-base/gxcht.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-13 12:01:54 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba2043a548559d184cbfe90ca9884734dba6efdc">ba2043a548559d184cbfe90ca9884734dba6efdc</a>
-<blockquote>
-<p>
- Bug 700584: cups device<br>
-<br>
- The cups device has a pile of different color spaces. It is up to the cups device to<br>
- ensure that the color is handled properly for these. RGBA should certainly be treated<br>
- as a 32 3 component color similar to our pngalpha device. RGBW will be treated the same way.<br>
-<br>
- Note that I looked at the output using Mike Sweet's rasterview program. I suspect there<br>
- probably is some work that needs to be done on that viewer to ensure proper viewing of<br>
- this type of data. With this patch gs is doing all it can.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-14 15:14:50 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1521304bd0da395fd11a950ab82a40deebc1f8c4">1521304bd0da395fd11a950ab82a40deebc1f8c4</a>
-<blockquote>
-<p>
- Undef .makepathtemplate in gs_init.ps<br>
-<br>
- Only used locally. Change to immediate evaluation and undef.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-14 15:10:28 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8512e98984c6d1be2bcefd0493fc5c4dd26f118e">8512e98984c6d1be2bcefd0493fc5c4dd26f118e</a>
-<blockquote>
-<p>
- Undef .uservar in gs_init.ps<br>
-<br>
- It was already an operator. Make sure all uses are executeonly and undef.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_statd.ps<br>
-Resource/Init/gs_trap.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-14 14:23:46 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=53a8955c422713ef6794f39de823a03d2f056790">53a8955c422713ef6794f39de823a03d2f056790</a>
-<blockquote>
-<p>
- Undef .userdict in gs_init.ps<br>
-<br>
- It was already an operator. Make sure all uses are executeonly and undef.<br>
-<br>
-Resource/Init/gs_dps2.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_trap.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-14 13:40:08 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7cd5f3cb820f75bc6ad636f09504918d96c9ba63">7cd5f3cb820f75bc6ad636f09504918d96c9ba63</a>
-<blockquote>
-<p>
- Undef .growdict and .growdictlength in gs_init.ps<br>
-<br>
- Changed uses to immediate evaluation, undef with the others.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-14 13:12:17 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ae191913f5c3260d780108217c63d161f49272a">4ae191913f5c3260d780108217c63d161f49272a</a>
-<blockquote>
-<p>
- Undef .putdeviceprops in gs_init.ps<br>
-<br>
- This is only used by /putdeviceprops, but I don't understand what's<br>
- going on with error handling and the comment about backward compatibility.<br>
- Both .putdeviceprops and putdeviceprops were already operators.<br>
-<br>
- Just undef .putdeviceprops with the other operators, after making sure<br>
- everything is executeonly.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-14 11:58:00 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a4acb441374641ba820648e5ae098ce9e5ae9d6">9a4acb441374641ba820648e5ae098ce9e5ae9d6</a>
-<blockquote>
-<p>
- Undef .promptmsg in gs_init.ps<br>
-<br>
- There used to be some code related to readline in lib/gs_rdlin.ps<br>
- that would redfine the .promptmsg, but that code is now gone.<br>
- There doesn't seem to be any reason to keep .promptmsg any more.<br>
- If somebody wants to redefine /prompt, that is still fine and is<br>
- documented in the PLRM.<br>
-<br>
- Change to use immediate evaluation and then undef it.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-14 11:39:08 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e187134ce58a398d46cb0065929ecbe9b40b6d7c">e187134ce58a398d46cb0065929ecbe9b40b6d7c</a>
-<blockquote>
-<p>
- Undef .packtomark in gs_init.ps<br>
-<br>
- This is used in a bunch of other files. Changed all those to<br>
- immediate evaluation.<br>
-<br>
-Resource/Init/gs_btokn.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_res.ps<br>
-Resource/Init/gs_ttf.ps<br>
-Resource/Init/pdf_base.ps<br>
-Resource/Init/pdf_sec.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-16 15:27:43 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3ba38b60a2380a8fbac7d315da5dfeaaf3d4cf21">3ba38b60a2380a8fbac7d315da5dfeaaf3d4cf21</a>
-<blockquote>
-<p>
- Fix some compiler warnings<br>
-<br>
- Noticed in a regression run where warnings were not swallowed. When<br>
- using 'C' Keys we should use the function which searches dictionaries<br>
- using a 'C' string instead of a byte string (which may not be null<br>
- terminated).<br>
-<br>
-devices/vector/gdevpdfj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-16 11:14:57 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c4ef58b66dadf546cbc7370ebbabe5505acc7ed">6c4ef58b66dadf546cbc7370ebbabe5505acc7ed</a>
-<blockquote>
-<p>
- PS interpreter - properly restore exec stack after error in zshow<br>
-<br>
- Bug #700618 &quot;Ghostscript - Invalid read in op_show_finish_setup()&quot;<br>
-<br>
- The problem occurs some time before the actual seg fault. The test file<br>
- is overly complex (not uncommon for fuzzed files), a simpler file would<br>
- be:<br>
-<br>
- /S 80 string def<br>
- 108 480 moveto<br>
- { 1 S show<br>
- } loop<br>
-<br>
- This runs in a loop, showing an empty string. But each iteration of the<br>
- loop leaves an object on the exec stack. Eventually we reach the stack<br>
- limit. The internals of 'show' require us to be able to push an object<br>
- (actually, 2 objects) on to the operand stack, so this results in a<br>
- stack overflow.<br>
-<br>
- Although zshow() checks the return code properly, it does not reset the<br>
- exec stack pointer in the case of an error (it adds up to 11 objects<br>
- to the exec stack itself). For a fatal error this isn't a problem, but<br>
- stack overflow is non-fatal; the interpreter can increase the stack size<br>
- and retry.<br>
-<br>
- This is where the problem exhibits. When we retry zshow() we have left<br>
- entries on the exec stack, in particular a 'mark', because we didn't<br>
- rewind the exec stack on error. We then try to use that to locate an<br>
- enumerator stored on the exec stack, but because we didn't complete the<br>
- setup, what we find is garbage.<br>
-<br>
- The solution is simply to restore the exec stack pointer on error,<br>
- before we return. We should also free the enumerator to prevent a<br>
- (saved by garbage collection) memory leak. So also initialise the<br>
- pointer to NULL, so we can safely free it, even if we didn't get round<br>
- to allocating it.<br>
-<br>
- There are 2 error conditions in this code, we need to update both.<br>
-<br>
-psi/zchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-14 10:20:03 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=205591753126802da850ada6511a0ff8411aa287">205591753126802da850ada6511a0ff8411aa287</a>
-<blockquote>
-<p>
- Fix bug 700585: Restrict superexec and remove it from internals and gs_cet.ps<br>
-<br>
- Also while changing things, restructure the CETMODE so that it will<br>
- work with -dSAFER. The gs_cet.ps is now run when we are still at save<br>
- level 0 with systemdict writeable. Allows us to undefine .makeoperator<br>
- and .setCPSImode internal operators after CETMODE is handled.<br>
-<br>
- Change previous uses of superexec to using .forceput (with the usual<br>
- .bind executeonly to hide it).<br>
-<br>
-Resource/Init/gs_cet.ps<br>
-Resource/Init/gs_dps1.ps<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_ttf.ps<br>
-Resource/Init/gs_type1.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-14 10:16:18 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4250323f0c5e85f43bd82255c846f98869a46354">4250323f0c5e85f43bd82255c846f98869a46354</a>
-<blockquote>
-<p>
- Remove undef of /odef from the SAFER list.<br>
-<br>
- Oops, this change crept in on an earlier commit. No need to include in<br>
- the SAFER list since it's being undef'ed in the main list.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-14 10:09:00 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e8acf6d1aa1fc92f453175509bfdad6f2b12dc73">e8acf6d1aa1fc92f453175509bfdad6f2b12dc73</a>
-<blockquote>
-<p>
- Undef /odef in gs_init.ps<br>
-<br>
- Made a new temporary utility function in gs_cet.ps (.odef) to use instead<br>
- of /odef. This makes it fine to undef odef with all the other operators in<br>
- gs_init.ps<br>
-<br>
- This punts the bigger question of what to do with .makeoperator, but it<br>
- doesn't make the situation any worse than it already was.<br>
-<br>
-Resource/Init/gs_cet.ps<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-13 14:03:29 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3e6e57c0a80948f322b9842add4a7ab86915cdc6">3e6e57c0a80948f322b9842add4a7ab86915cdc6</a>
-<blockquote>
-<p>
- Undef /obind from gs_init.ps<br>
-<br>
- This is only used in gs_typ32.ps, just undef with all the other things in<br>
- gs_init.ps<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-13 13:54:25 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=533f78554f194524abb55183d370e64354caa329">533f78554f194524abb55183d370e64354caa329</a>
-<blockquote>
-<p>
- Deleted definition of /execute, which wasn't used anywhere.<br>
-<br>
- As far as I can tell... It's extremely challenging to try to grep for uses of<br>
- this word.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-13 09:36:29 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c5ed6a1f8583068484b4c138fb1e0e1ef1ad2a3f">c5ed6a1f8583068484b4c138fb1e0e1ef1ad2a3f</a>
-<blockquote>
-<p>
- Undef /runlibfile0 in gs_init.ps<br>
-<br>
- This is just used temporarily.<br>
- Change to immediate evaluation and undef right after use.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-13 08:43:00 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e0b0c12518bc58020efda5ca3d1e4888b33060b2">e0b0c12518bc58020efda5ca3d1e4888b33060b2</a>
-<blockquote>
-<p>
- Delete /ppstack, which is defined in gs_init.ps and not used anywhere<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-13 08:29:39 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b26b5ec2be0a924981a47c8a66b1cfe936170129">b26b5ec2be0a924981a47c8a66b1cfe936170129</a>
-<blockquote>
-<p>
- Remove 'copystring', which was only used in one place<br>
-<br>
- Just put the code in-line.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-12 14:00:29 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=25c744f8a7761676d7790f513ca138eaaed2c366">25c744f8a7761676d7790f513ca138eaaed2c366</a>
-<blockquote>
-<p>
- Undef .set/.currentfilladjust, re-def .set/.currentfilladjust2<br>
-<br>
- The .setfilladjust, .currentfilladjust were just wrappers around the<br>
- '2' versions. They were used in only a couple places, and were just<br>
- dupping/popping the extra args, so I replaced these with equivalent<br>
- uses of the underlying operators.<br>
-<br>
- These were &quot;compatibility&quot; operators for .setfilladjust2 and<br>
- .currentfilladjust2, which do the same basic thing but take two values<br>
- (x,y) instead of 1.<br>
-<br>
- Robin wants these to be official extensions because they are useful<br>
- for testing, so I have taken out the code that undef's .setfilladjust2<br>
- and .currentfilladjust2. We need to add documentation for these.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-12 10:41:34 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=509cb1f2103a2b35efe463271a94b2c33ed6b838">509cb1f2103a2b35efe463271a94b2c33ed6b838</a>
-<blockquote>
-<p>
- Undef /printgreeting in gs_init.ps<br>
-<br>
- Only used locally. Undef right after use.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-13 15:15:33 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e0981f84562bff97f45e401c704289544d4f523">0e0981f84562bff97f45e401c704289544d4f523</a>
-<blockquote>
-<p>
- Avoid buffer overread in pcl ccittfax decompression.<br>
-<br>
- If you:<br>
-<br>
- make gpcl6debugvg<br>
- valgrind --track-origins=yes debugbin/gpcl6 -sOutputFile=test.pdf<br>
- -dMaxBitmap=400000000 -sDEVICE=pdfwrite -r75 -Z: -dNOPAUSE<br>
- -dBATCH -K2000000 -dClusterJob<br>
- tests_private/customer_tests/bug693269.prn<br>
-<br>
- Then we get valgrind errors in cf_decode_eol.<br>
-<br>
- The cause is that process_ccitt_compress is making the read buffer<br>
- 4 bytes too long, due to forgetting to remove the allowance for the<br>
- 4 bytes used for the header word.<br>
-<br>
- The fix is simply to adjust the buffer size.<br>
-<br>
-pcl/pcl/rtraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-09 13:34:17 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=660eaabf87a143b5217dc875550968883d8e4fc0">660eaabf87a143b5217dc875550968883d8e4fc0</a>
-<blockquote>
-<p>
- Bug 700554: jbig2: Use custom allocator for jbig2dec/luratech decoders.<br>
-<br>
-base/sjbig2.c<br>
-base/sjbig2.h<br>
-base/sjbig2_luratech.c<br>
-base/sjbig2_luratech.h<br>
-psi/zfjbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-09 13:34:38 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d942b34ae4a5385f5cd3cfa9b2c708f56c65860">0d942b34ae4a5385f5cd3cfa9b2c708f56c65860</a>
-<blockquote>
-<p>
- jbig2dec: Return allocator once it is retired.<br>
-<br>
-jbig2dec/CHANGES<br>
-jbig2dec/jbig2.c<br>
-jbig2dec/jbig2.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-12 17:27:56 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0fb8c19f9b848fb691dc067a0feebbfee539672b">0fb8c19f9b848fb691dc067a0feebbfee539672b</a>
-<blockquote>
-<p>
- Bug 700564: Tweak to fix shared libjpeg<br>
-<br>
- A custom header include wasn't protected by proprocessor directives.<br>
-<br>
- And remove one not required inclusion.<br>
-<br>
-base/sjpegc.c<br>
-devices/gdevpdfimg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-12 08:04:39 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ecf45905a555386c157967aefc986c94002b3c6d">ecf45905a555386c157967aefc986c94002b3c6d</a>
-<blockquote>
-<p>
- Undef .pdfcharkeys from gs_ttf.ps<br>
-<br>
- Used locally. Change to immediate evaluation and undef.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-07 14:22:14 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=05dddc4d150b372eecd28817b8441694843b64d8">05dddc4d150b372eecd28817b8441694843b64d8</a>
-<blockquote>
-<p>
- Move code around to prepare for more undef'ing<br>
-<br>
- Moved code so things are declared before referenced.<br>
- No changes to the code, just moved it around in the file.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-07 14:02:49 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e7faf522a5f5a770659cf4d1c9cd7f3362eb9b4d">e7faf522a5f5a770659cf4d1c9cd7f3362eb9b4d</a>
-<blockquote>
-<p>
- Undef .findcmap, .pdfmapsymbolic in gs_ttf.ps<br>
-<br>
- Used locally. Change to immediate evaluation and undef.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-07 13:53:00 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a0db357352e338fe8432ec1e18aa901aed61fdd">9a0db357352e338fe8432ec1e18aa901aed61fdd</a>
-<blockquote>
-<p>
- Undef .loadttcidfont, .loadpdfttfont in gs_ttf.ps<br>
-<br>
- These are used in pdf_font.ps. Need to rearrange the order of things<br>
- in the Makefiles so that gs_ttf.ps is included before pdf_font.ps in<br>
- obj/iconfig.h. This also meant moving gs_mgl_e.ps, though I wonder if<br>
- it could be moved up with the other encodings (gs_mex_e.ps,<br>
- gs_mro_e.ps, etc). I didn't look into right now -- it would be a lot<br>
- of Makefile hacking.<br>
-<br>
- After makefile change: change .loadttcidfont and .loadpdfttfont to<br>
- operators, make sure their usage is executeonly, and undef in<br>
- gs_init.ps.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_ttf.ps<br>
-psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-12 09:15:54 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=355434f4b1bbe8c4f98cafad5a6868aa2f0eaae1">355434f4b1bbe8c4f98cafad5a6868aa2f0eaae1</a>
-<blockquote>
-<p>
- Bug 700533: Undo FT over/underflow workaround<br>
-<br>
- Older versions of Freetype had a problem with overflow (and underflow) in the<br>
- Truetype hinting code. That was resolved some time ago with the addition of<br>
- (or handling of) the F_dot_P value.<br>
-<br>
- In the file associaited with this issue, the glyph offset is caused by this<br>
- workaround.<br>
-<br>
- Thus the workaround is no longer required, and as it actually causes a problem,<br>
- it is hereby removed.<br>
-<br>
-base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-11 07:40:02 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fd643f053ea4a311a9e61a10069cfe8747aa950c">fd643f053ea4a311a9e61a10069cfe8747aa950c</a>
-<blockquote>
-<p>
- Bug 700577: Follow on fix.<br>
-<br>
- If the matrix inversion fails, set values for tmat as well as smat.<br>
-<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-11 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=0038d98e024edb55a844f8371e62eacbbeb6f6a6">0038d98e024edb55a844f8371e62eacbbeb6f6a6</a>
-<blockquote>
-<p>
- Bug 700582: Handle disabled streams in s_file_available()<br>
-<br>
- and s_file_read_seek()<br>
-<br>
-base/sfxstdio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-06 17:30:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=52196a78714e632c2c4001edffc65285346ac998">52196a78714e632c2c4001edffc65285346ac998</a>
-<blockquote>
-<p>
- Ensure uses of true/false/null are immiediately evaluated<br>
-<br>
-Resource/Init/gs_cet.ps<br>
-Resource/Init/gs_epsf.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_pdfwr.ps<br>
-Resource/Init/gs_setpd.ps<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>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-10 17:56:23 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=08ffa461bbf0914757c11be28c99829dcdae5a38">08ffa461bbf0914757c11be28c99829dcdae5a38</a>
-<blockquote>
-<p>
- Bug 696318 psdcmykog issues<br>
-<br>
- The psdcmykog device has to ignore certain postscript color settings since<br>
- it does not support any colorants other than the cmykog ones.<br>
- I tested with a file that had Artifex Green and Artifex Orange to<br>
- ensure that rendered properly still after this fix.<br>
-<br>
-devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-10 19:10:26 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aaf522721db34addf48ae1cc64d559bddbcc1c02">aaf522721db34addf48ae1cc64d559bddbcc1c02</a>
-<blockquote>
-<p>
- Improve function naming and simplify initialization and destructor.<br>
-<br>
- No expected differences.<br>
-<br>
-pcl/pxl/pximage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-08 04:08:08 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d9edb5a256b00e787d72462320112ef39bfa27b3">d9edb5a256b00e787d72462320112ef39bfa27b3</a>
-<blockquote>
-<p>
- Without enough prefix codes, a Huffman table cannot be generated.<br>
-<br>
- Previously this was treated as a warning, possibly allowing access<br>
- to uninitialized prefix code entries.<br>
-<br>
-jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-08 04:03:40 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e4a0d6264627ece2a2c09da9d81d21b6b2158481">e4a0d6264627ece2a2c09da9d81d21b6b2158481</a>
-<blockquote>
-<p>
- Make sure to indicate error upon unexpected OOB.<br>
-<br>
-jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-07 18:12:48 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a89d75c1a059093aab4218046a9f258e86a5ab5f">a89d75c1a059093aab4218046a9f258e86a5ab5f</a>
-<blockquote>
-<p>
- Clarify the element size of GR_stats when memsetting.<br>
-<br>
- In case Jbig2ArithCx ever changes, but it is unlikely.<br>
-<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-08 04:15:41 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f2cadf483f44518ddae68c3146ae77f205f7e11b">f2cadf483f44518ddae68c3146ae77f205f7e11b</a>
-<blockquote>
-<p>
- Use common pattern for error detection.<br>
-<br>
- Previously the code used a non-standard variant, but it is better<br>
- to do error detection the same way everywhere.<br>
-<br>
-jbig2dec/jbig2_halftone.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-07 18:12:23 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6238141c4564df091515fac92e3c35275d5ce26f">6238141c4564df091515fac92e3c35275d5ce26f</a>
-<blockquote>
-<p>
- Bug 700384: Indicate error upon error, do not just warn.<br>
-<br>
- Building a Huffman table failed, this was correctly detected,<br>
- but success was indicated to the caller causing a reference<br>
- template to be left uninitialized, which later on caused the<br>
- generic refinement region decoder attempt to use this<br>
- uninitialized data. This was reported by MSAN.<br>
-<br>
- Thanks to oss-fuzz for reporting.<br>
-<br>
-jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-24 03:55:57 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a0421f035fd418d27fd2df80b896d97d3d6e87ea">a0421f035fd418d27fd2df80b896d97d3d6e87ea</a>
-<blockquote>
-<p>
- Bug 694247: Do not confuse openjpeg input buffer usage with size.<br>
-<br>
- Previously s_opjd_accumulate_input() populated the openjpeg input data<br>
- buffer and adjusted the buffer size and usage fields accordingly. The<br>
- openjpeg callbacks for reading, skipping and seeking confused these two<br>
- fields and used the buffer size instead of the buffer usage. This meant<br>
- that there was a risk of reading uninitialized data.<br>
-<br>
-base/sjpx_openjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-25 15:49:56 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a317d2ddfb82ad584a91540fca80db36c6440c7">9a317d2ddfb82ad584a91540fca80db36c6440c7</a>
-<blockquote>
-<p>
- Add sanitize variant of gpdl target.<br>
-<br>
-base/unix-end.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-07 18:18:59 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=38c864f6300ccb2664c3d8707ef41564645742e4">38c864f6300ccb2664c3d8707ef41564645742e4</a>
-<blockquote>
-<p>
- Fix Memento_find when running under valgrind.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-07 20:00:55 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=046cd2e7fc5c6a11a5e59835b06a70f3b65f9eb1">046cd2e7fc5c6a11a5e59835b06a70f3b65f9eb1</a>
-<blockquote>
-<p>
- Ensure that gs_matrix_invert always has its return checked.<br>
-<br>
- If you do:<br>
-<br>
- make gsdebugvg<br>
- valgrind --track-origins=yes debugbin/gs -sOutputFile=test.ps<br>
- -dMaxBitmap=400000000 -sDEVICE=ps2write -r300 -Z: -dNOPAUSE<br>
- -dBATCH -K2000000 -dClusterJob comparefiles/Bug694772.pdf<br>
-<br>
- then you get:<br>
-<br>
- Conditional jump or move depends on uninitialised value(s)<br>
- at 0x945795: gs_matrix_multiply (gsmatrix.c:88)<br>
- by 0x7E568B: pdf_calculate_text_size (gdevpdtt.c:2352)<br>
- by 0x7E58DD: pdf_update_text_state (gdevpdtt.c:2386)<br>
- by 0x7D2E28: pdf_process_string (gdevpdte.c:679)<br>
- by 0x7D079E: pdf_process_string_aux (gdevpdte.c:79)<br>
- by 0x7D68D1: process_plain_text (gdevpdte.c:1582)<br>
- by 0x7E902C: pdf_text_process (gdevpdtt.c:3566)<br>
- by 0x956BEC: gs_text_process (gstext.c:595)<br>
- by 0xB445A0: op_show_continue_pop (zchar.c:583)<br>
- by 0xB42B95: zshow (zchar.c:71)<br>
- by 0xB11AD6: do_call_operator (interp.c:86)<br>
- by 0xB14B0D: interp (interp.c:1300)<br>
- Uninitialised value was created by a stack allocation<br>
- at 0x7E57EA: pdf_update_text_state (gdevpdtt.c:2373)<br>
-<br>
- This is because a matrix inversion fails and is uncaught.<br>
-<br>
-base/gshtscr.c<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdtc.c<br>
-devices/vector/gdevpdtt.c<br>
-devices/vector/gdevpx.c<br>
-devices/vector/gdevtxtw.c<br>
-devices/vector/gdevxps.c<br>
-pcl/pxl/pximage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-07 17:30:48 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c247504269f70d07ce95104440a36f34f1a68a0">1c247504269f70d07ce95104440a36f34f1a68a0</a>
-<blockquote>
-<p>
- Bug 700577: Ensure text enum initialisation sets reqired flags<br>
-<br>
- The default begin_text function initialises various things like<br>
- charpath_flag and is_pure_color. The PCL interpreter then calls<br>
- directly into the graphics lib for string measurement etc, and<br>
- this depends on these flag.<br>
-<br>
- Sadly, not all text enumerator initialisations set these flags;<br>
- in particular if we have the flp device in effect, the subclass<br>
- begin_text function is used and that does not init those values.<br>
-<br>
- The simplest solution appears to be to amend<br>
- gs_text_enum_init_dynamic to always set these flags as required.<br>
-<br>
-base/gstext.c<br>
-base/gxchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-31 16:34:30 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f10f2900633674746f6a8155200f24db51449523">f10f2900633674746f6a8155200f24db51449523</a>
-<blockquote>
-<p>
- Bug 696318: psdrgb device<br>
-<br>
- With certain postscript files, the psdrgb device was getting its process<br>
- color model changed causing significant confusion for the device.<br>
-<br>
-devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-06 21:36:54 +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=5daf81e0edb5dee2911bf419fa2423b2588449ab">5daf81e0edb5dee2911bf419fa2423b2588449ab</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent numerous memory leaks.<br>
-<br>
- Cleanup font for all error returns.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=21465 ./membin/gpcl6 -sDEVICE=pbmraw -dMaxBitmap=2000 -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0282<br>
-<br>
-pcl/pcl/pcsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-06 09:51:49 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8da995af1f586f2f90cac274aa738cd8dad3759f">8da995af1f586f2f90cac274aa738cd8dad3759f</a>
-<blockquote>
-<p>
- Undef check_r6_password and PDFexecform<br>
-<br>
- Immediate binding and undef for check_r6_password.<br>
-<br>
- Move PDFexecform from gs_lev2.ps to pdf_draw.ps (the only place it was<br>
- used), and put it and .PDFexecform in pdfdict. PDFexecform and<br>
- .PDFexecform don't need odef -- just make them executeonly (even though<br>
- they will be hidden in pdfdict).<br>
-<br>
- Also change the initial size of pdfdict to just over the actual size<br>
- (it was growing to &gt; 400 maxlength).<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/pdf_draw.ps<br>
-Resource/Init/pdf_main.ps<br>
-Resource/Init/pdf_ops.ps<br>
-Resource/Init/pdf_sec.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-07 08:48:53 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=060c83126ad016a691f6ef1b43d5232956ddc128">060c83126ad016a691f6ef1b43d5232956ddc128</a>
-<blockquote>
-<p>
- Undef /.loadttfont, /.loadwofffont, /.loadwofftables from gs_ttf.ps<br>
-<br>
- Used locally, so change to immediate evaluation and undef.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-06 15:35:05 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bdc3e6b7201c2a73eeae60cf4cfffb843f5034ea">bdc3e6b7201c2a73eeae60cf4cfffb843f5034ea</a>
-<blockquote>
-<p>
- Reorder code to prep for future cleanup<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-06 14:36:01 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd3b403b72931b9ef52630665fc418ad96075197">dd3b403b72931b9ef52630665fc418ad96075197</a>
-<blockquote>
-<p>
- Undef .readttdata,.nname in gs_ttf.ps<br>
-<br>
- Used locally. Use immediate evaluation and undef.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-06 14:34:01 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=46ec997913d63b6c7d3ac666484c1a04551a082b">46ec997913d63b6c7d3ac666484c1a04551a082b</a>
-<blockquote>
-<p>
- Undef .printtab in gs_ttf.ps<br>
-<br>
- Used locally, so change to immediate evaluation and undef.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-06 14:28:17 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91bf6eef15c30efd90c4e98cc4b95e9e7f85a763">91bf6eef15c30efd90c4e98cc4b95e9e7f85a763</a>
-<blockquote>
-<p>
- Undef .pickcmap, .pickcmap_with_xlatmap, .pickcmap_with_no_xlatmap in gs_ttf.ps<br>
-<br>
- .pickcmap uses immediate evaluation on the other two, so just undef them.<br>
-<br>
- Make .pickcmap an operator because it's a big function. Make sure all uses<br>
- are executeonly. Undef in gs_init.ps.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-06 13:01:26 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=715541a5c7390508d923d48e2eda4417b82a2710">715541a5c7390508d923d48e2eda4417b82a2710</a>
-<blockquote>
-<p>
- Undef .makesfnts in gs_ttf.ps<br>
-<br>
- Large procedure, so made it an operator. Make sure all references are<br>
- executeonly. Undef in gs_init.ps.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-06 11:47:15 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ce52f184357a8043c0b314f2e8319237b75c29ae">ce52f184357a8043c0b314f2e8319237b75c29ae</a>
-<blockquote>
-<p>
- Undef .ttkeys in gs_ttf.ps<br>
-<br>
- Used locally -- change to immediate evaluation and undef at end of file.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-06 10:12:34 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c58684b54be4190a8f1ce3d92200f420aefba9dd">c58684b54be4190a8f1ce3d92200f420aefba9dd</a>
-<blockquote>
-<p>
- Undef .is_ttf_or_otf, .is_woff from gs_ttf.ps<br>
-<br>
- Only used locally, changed to immediate evaluation.<br>
-<br>
- Also moved some of the related things that were already undef'd, to be<br>
- handled together.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-07 07:12:36 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7cc8aeb7bf93deab5d86aeeca6c5b22a3890345d">7cc8aeb7bf93deab5d86aeeca6c5b22a3890345d</a>
-<blockquote>
-<p>
- Bug 700571 SoftMask Matte rendering<br>
-<br>
- Fix for multiple issues with the removal of the preblended transparency<br>
- that can exist with the softmask<br>
-<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-04 11:36:19 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=28f825c642a9af53136a7e661c6026db53604b76">28f825c642a9af53136a7e661c6026db53604b76</a>
-<blockquote>
-<p>
- Workaround Shading/clist valgrind issues with trans_device.<br>
-<br>
- When shading into the clist the code has to cope with 2 devices;<br>
- the target device, and the 'trans_device', which is updated to<br>
- use the source colorspace for the shading.<br>
-<br>
- The number of components can vary between the two, meaning that<br>
- the shading code has to be passing (say) 1 component around,<br>
- but the call into the clist will attempt to write (say) 3 components.<br>
-<br>
- The clist appears to cope with this mismatch on reading (and I<br>
- haven't found a case where we write too few components), so for<br>
- now, just add a hacky PACIFY_VALGRIND section to clear the<br>
- spare color components.<br>
-<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-05 15:22:15 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c8a539b2a2c199bcde37acc652b882239407c47">6c8a539b2a2c199bcde37acc652b882239407c47</a>
-<blockquote>
-<p>
- Undef .is_hex_digit, .pop3ex, .popfex from gs_ttf.ps<br>
-<br>
- These were already used with immediate evaluation, so just need to undef.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-05 14:06:06 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ebfacf80bf673dbaa7e742687f4d319cd1b8dd11">ebfacf80bf673dbaa7e742687f4d319cd1b8dd11</a>
-<blockquote>
-<p>
- Undef .loadttfontdict, which undefs a bunch of internal procedures<br>
-<br>
- Changed to immediate evaluation of the dict. Undef dict at end of file.<br>
- Eliminates a bunch of internal procedures.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-05 12:19:00 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=402c16dec171424700639d8aa41009dbc57b66a7">402c16dec171424700639d8aa41009dbc57b66a7</a>
-<blockquote>
-<p>
- Remove undef of /postalias that was supposed to be removed after v9.09<br>
-<br>
- There are no remaining references to &quot;postalias&quot;, so this appears to be<br>
- dead/unneeded code, as indicated by the comment.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-05 12:12:42 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3575fc86cfcffcec935023238a2d6d0ae62875ca">3575fc86cfcffcec935023238a2d6d0ae62875ca</a>
-<blockquote>
-<p>
- Undef .findttfontname and .findwoffname from gs_ttf.ps<br>
-<br>
- Move code so defined before use. Use immediate evaluation. Undef locally.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-05 12:07:36 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e051acc94b70a952ba2f2baa7209df3a2924bb6">4e051acc94b70a952ba2f2baa7209df3a2924bb6</a>
-<blockquote>
-<p>
- Undef .findseg from gs_ttf.ps<br>
-<br>
- Used locally. Immediate ref and undef in file.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-05 11:54:12 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1bebd7f9f299026de62868e72f70979460080a27">1bebd7f9f299026de62868e72f70979460080a27</a>
-<blockquote>
-<p>
- Undef .fill_identity_cmap, .definettcidfont in gs_ttf.ps<br>
-<br>
- Local definition -- use immediate evaluation and then undef.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-05 09:28:48 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9876fb74118b91ec87a34673735bcd89900ad66a">9876fb74118b91ec87a34673735bcd89900ad66a</a>
-<blockquote>
-<p>
- Undef .charkeys from gs_ttf.ps<br>
-<br>
- - This is a huge procedure, so I made it an operator rather than using<br>
- immediate evaulation<br>
- - Make sure all uses are executeonly<br>
- - Undef in gs_init.ps<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-05 09:25:17 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c12cbfa2585c4af7173e6045c2339f051574b3c">3c12cbfa2585c4af7173e6045c2339f051574b3c</a>
-<blockquote>
-<p>
- Undef .addglyph from gs_ttf.ps<br>
-<br>
- - this already only had immediate references<br>
- - undef at end of gs_ttf.ps<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-06 11:17:27 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1ca42001f0ae456aa3ec080e88719e2d4b4f8131">1ca42001f0ae456aa3ec080e88719e2d4b4f8131</a>
-<blockquote>
-<p>
- Tweak cff_write_Encoding to avoid writing badly formed table.<br>
-<br>
- The following:<br>
-<br>
- make gsdebugvg<br>
- valgrind --track-origins=yes debugbin/gs -sOutputFile=/dev/null<br>
- -dMaxBitmap=400000000 -sDEVICE=pdfwrite -r72 -Z: -dNOPAUSE<br>
- -dBATCH -K2000000 -dClusterJob Bug691693.pdf<br>
-<br>
- results in valgrind warnings:<br>
-<br>
- Use of uninitialised value of size 8<br>
- at 0x53F0B6: deflate_slow (in ghostpdl/bin/gs)<br>
- by 0x53CDA5: deflate (in ghostpdl/bin/gs)<br>
- by 0x6CB1B7: s_zlibE_process (in ghostpdl/bin/gs)<br>
- by 0x6B35F0: swritebuf (in ghostpdl/bin/gs)<br>
- by 0x6B31EB: s_process_write_buf (in ghostpdl/bin/gs)<br>
- by 0x6B28E5: spputc (in ghostpdl/bin/gs)<br>
- by 0x6B2CE1: sputs (in ghostpdl/bin/gs)<br>
- by 0x7E3A43: type2_put_hintmask (in ghostpdl/bin/gs)<br>
- by 0x7E4704: psf_convert_type1_to_type2 (in ghostpdl/bin/gs)<br>
- by 0x7D9770: cff_put_CharString (in ghostpdl/bin/gs)<br>
- by 0x7DAB9B: cff_write_CharStrings (in ghostpdl/bin/gs)<br>
- by 0x7DC58B: psf_write_type2_font (in ghostpdl/bin/gs)<br>
- Uninitialised value was created by a stack allocation<br>
- at 0x7DAF8E: cff_write_Encoding (in ghostpdl/bin/gs)<br>
-<br>
- Investigation shows that cff_write_Encoding is outputting a table<br>
- with uninitialised bytes in that. Not only that, in such cases<br>
- it can clearly omit some valid data.<br>
-<br>
- Conceptually, the routine starts with an empty index table, with<br>
- uninitialised values. For each of the possible 256 entries within<br>
- the font, it attempts to encode the char to get the glyph index.<br>
- If this fails, then the glyph is not encoded, so not mentioned in<br>
- the table.<br>
-<br>
- Assuming it is encoded, it finds the index for that glyph within<br>
- the subset. If there is no index, then it is not in the subset, so<br>
- no entry in the table.<br>
-<br>
- If there is an index, we look up the glyph name. If there is no<br>
- glyph name, we choose not to encode the glyph in the table. This<br>
- is the (first) case which is causing us problems.<br>
-<br>
- Finally, we check to see if the encoded index fits into the simple<br>
- (0..255) table without clashing with a previously encoded glyph;<br>
- if so, we insert it into the index table (incrementing the number<br>
- of entries we have inserted), if not, we have to resort to using a<br>
- supplement entry.<br>
-<br>
- The code then assumes that the first 'actual_enc' bytes of index<br>
- make up the table. This is sadly not the case.<br>
-<br>
- In the test given above, this routine is called several times, one<br>
- of which demonstrates that this assumption is false.<br>
-<br>
- While the entries do yield a set of index values that form a prefix<br>
- within the table (from 0 to 20), number 14 has no glyph name. This<br>
- results in byte 14 of the table having a garbage value in, and<br>
- (more worryingly), because actual_enc is only incremented to 20,<br>
- we don't write the final entry of the table at all, effectively<br>
- dropping a glyph.<br>
-<br>
- It is possible that something has gone wrong earlier in the process<br>
- and that this should be a fatal error, but observation of the code<br>
- shows that if we use a supplement, because a j maps to a previously<br>
- used i, we'll similarly miscount the length of the table.<br>
-<br>
- A better solution, seems to me, to be to keep track of the maximum<br>
- encoded value that has gone into the index table, and to ensure<br>
- that every value within that table has a defined value.<br>
-<br>
- The table is initialised with 0's, as Chris informs me that the CIF<br>
- SID for .notdef is 0.<br>
-<br>
- We make matching changes to cff_Encoding_size.<br>
-<br>
-devices/vector/gdevpsf2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-06 09:54:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0cf2aa5cdb1d7392cd4a6b11a30625be91ef9be0">0cf2aa5cdb1d7392cd4a6b11a30625be91ef9be0</a>
-<blockquote>
-<p>
- PDF interpreter - reset colour space after starting a Group<br>
-<br>
- Bug #700572 &quot;PDF to TIFF - only borders left after conversion - no errors&quot;<br>
-<br>
- The problem is that the PDF file does not set a fill (or indeed stroke)<br>
- colour space or colour before beginning to draw on the canvas. Thus it<br>
- relies upon the default colour values.<br>
-<br>
- Because the page has a transparency Group, and the Group has a Colour<br>
- space, we set the colour space before we begin rendering. The defined<br>
- colour space of the group is an ICCBased space with four components.<br>
- The PDF Reference is clear that the default colour for an ICCBased space<br>
- is that all the components should be 0. This results in us drawing all<br>
- the filled elements in 0 0 0 0, or white.<br>
-<br>
- We need to set the colour space before we define the group for the<br>
- transparency compositor, because the code relies upon the colour space<br>
- of the group being current at the time the group is 'defined'.<br>
-<br>
- Grabbing the current colour space, before setting the group space, and<br>
- then setting it back again afterwards, effectively a gsave/grestore but<br>
- only for the colour space fixes this problem. This causes differences in<br>
- 7 test files, which I believe are progressions.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-05 07:31:05 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8d0253fdeb73bdb021f665e7c5478d6e1f41898e">8d0253fdeb73bdb021f665e7c5478d6e1f41898e</a>
-<blockquote>
-<p>
- Delete .makemodifiedfont<br>
-<br>
- This goes with .definemodifiedfont, which was previously deleted.<br>
- Neither of these functions are referenced anywhere, so removing completely.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-31 15:06:54 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d0883434eb7fd7239048b404dab884803a42f52d">d0883434eb7fd7239048b404dab884803a42f52d</a>
-<blockquote>
-<p>
- Undef .FontDirectory<br>
-<br>
- - It was already an operator. Make it executeonly.<br>
- - Make sure all uses are executeonly.<br>
- - Undef in gs_init.ps<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-31 12:10:48 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cea599bca413609c288a43c7b1d765b53f200083">cea599bca413609c288a43c7b1d765b53f200083</a>
-<blockquote>
-<p>
- Undef .substitutefont and .substitutefontname<br>
-<br>
- Used in gs_fonts.ps and pdf_font.ps<br>
-<br>
- - make it an operator<br>
- - make sure all procedures that use it are executeonly<br>
- - undef in gs_init.ps<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-31 11:58:21 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c52e82d2eeae0eb498eef80c1a86d788fe0b117d">c52e82d2eeae0eb498eef80c1a86d788fe0b117d</a>
-<blockquote>
-<p>
- Undef .loadinitialfonts<br>
-<br>
- Defined in gs_fonts.ps and used in gs_init.ps. Undef right after use in<br>
- gs_init.ps.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-04 16:56:51 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c5fd7dc0f3c706eddd59488a33fc334a2860da49">c5fd7dc0f3c706eddd59488a33fc334a2860da49</a>
-<blockquote>
-<p>
- Ensure return code of gs_bbox_transform_inverse always checked.<br>
-<br>
- Spotted this while debugging something else.<br>
-<br>
-base/gdevbbox.c<br>
-base/gdevbbox.h<br>
-base/gsdevmem.c<br>
-base/gslib.c<br>
-base/gsshade.c<br>
-base/gxp1fill.c<br>
-base/gxshade1.c<br>
-base/gxshade6.c<br>
-xps/xpsopacity.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-01 10:48:31 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2d5b86f0acf37fcb6176817580c2d3bb745e27d2">2d5b86f0acf37fcb6176817580c2d3bb745e27d2</a>
-<blockquote>
-<p>
- Avoid valgrind error in gs_shading_A_fill_rectangle_aux<br>
-<br>
- The following sequence:<br>
-<br>
- make gsdebugvg<br>
- debugbin/gs -sOutputFile=test.pdf -dMaxBitmap=400000000<br>
- -sDEVICE=pdfwrite -r72 -Z: -dNOPAUSE -dBATCH -K2000000 -dClusterJob<br>
- /home/marcos/cluster/tests_private/comparefiles/Bug695746.pdf<br>
- valgrind --track-origins=yes debugbin/gs -sOutputFile=/dev/null<br>
- -dMaxBitmap=400000000 -sDEVICE=ppmraw -r72 -Z: -dNOPAUSE -dBATCH<br>
- -K2000000 -dClusterJob test.pdf<br>
-<br>
- produces valgrind errors:<br>
-<br>
- ==31466== Conditional jump or move depends on uninitialised value(s)<br>
- ==31466== at 0x47873B: gs_shading_A_fill_rectangle_aux (gxshade1.c:256)<br>
- ==31466== by 0x478B6A: gs_shading_A_fill_rectangle (gxshade1.c:301)<br>
- ==31466== by 0x476374: gs_shading_do_fill_rectangle (gsshade.c:477)<br>
- ==31466== by 0x4748DB: gx_dc_pattern2_fill_rectangle (gsptype2.c:243)<br>
- ==31466== by 0xA442ED: gx_default_fill_path (gxfill.c:707)<br>
- ==31466== by 0xA75F9C: gx_fill_path (gxpaint.c:52)<br>
- ==31466== by 0x94D38A: do_fill (gspaint.c:318)<br>
- ==31466== by 0x94D488: fill_with_rule (gspaint.c:352)<br>
- ==31466== by 0x94D4D7: gs_fill (gspaint.c:363)<br>
- ==31466== by 0xB64A36: zfill (zpaint.c:27)<br>
- ==31466== by 0xB10E74: do_call_operator (interp.c:86)<br>
- ==31466== by 0xB143DA: interp (interp.c:1410)<br>
- ==31466== Uninitialised value was created by a stack allocation<br>
- ==31466== at 0x4784DC: gs_shading_A_fill_rectangle_aux (gxshade1.c:216)<br>
-<br>
- These are due to the inversion of a matrix failing, and the error<br>
- being ignored.<br>
-<br>
- Fix the error handling in the function; if the inversion fails, just<br>
- don't render anything and exit. Returning an error causes content to<br>
- be lost from cluster test files.<br>
-<br>
- As a side effect of this, fix gsicc_release_link to follow the<br>
- general rule for destructors that they should accept NULL without<br>
- error.<br>
-<br>
-base/gsicc_cache.c<br>
-base/gsmatrix.c<br>
-base/gxshade1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-03 12:09:52 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=556bb1c7110ee65af5c38a32610c8dfdd9aedc43">556bb1c7110ee65af5c38a32610c8dfdd9aedc43</a>
-<blockquote>
-<p>
- Add non-packed capability to packps<br>
-<br>
- For creating opdfread.h we normally strip comments and whitespace from the<br>
- Postscript, but that makes reading debugging the opdfread Postscript even more<br>
- unpleasant than it has to be.<br>
-<br>
- This adds a &quot;-d&quot; option (&quot;don't pack&quot;) to pack_ps.c.<br>
-<br>
- Also adds a subtarget for opdfread.h that means invoking make thus:<br>
- make DEBUG_OPDFREAD=1<br>
-<br>
- will create opdfread.h without stripping whitespace and comments, so the output<br>
- from ps2write is only baroque and less wilfully horrific.<br>
-<br>
-base/pack_ps.c<br>
-devices/devs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-03 12:09: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=7f86b6a5add79b7a32d216f5095e93112ff58506">7f86b6a5add79b7a32d216f5095e93112ff58506</a>
-<blockquote>
-<p>
- Add copyright notice to source file<br>
-<br>
-devices/gdevpdfimg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-04 17:01:42 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc685b7525c9ccea3ee59bacd6d6f25ab22d174a">dc685b7525c9ccea3ee59bacd6d6f25ab22d174a</a>
-<blockquote>
-<p>
- pdfwrite - use the correct enumerator when handling PCL bitmap fonts<br>
-<br>
- Bug #700562 &quot;Valgrind reveals use of unitialised value in text code&quot;<br>
-<br>
- This is a follow-on from commit c47512e5e638d903d69925f7ebab4de2aa3f481f<br>
- again what we have is confusion over *which* of the two enumerators we<br>
- should be using, when we are converting fonts which we can't preserve<br>
- into type 3 fonts.<br>
-<br>
- For non-PCL cases we don't need the text enumerator for the 'default'<br>
- show functions, so we specifically set pdev-&gt;pte to NULL (at around line<br>
- 3477 in gdevpdtt.c). However for PCL bitmap fonts, or the GL/2 stick<br>
- font, we do need the 'default' enumerator which we create in order to<br>
- process the 'BuildGlyph' for the character.<br>
-<br>
- So we need to make sure we are using the correct enumerator when we try<br>
- to read back the 'returned_glyph'.<br>
-<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-03 14:44:02 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0495abb3605831147f39691701030405b44cd5d0">0495abb3605831147f39691701030405b44cd5d0</a>
-<blockquote>
-<p>
- Fix 700565 - SetHalftoneMethod parsing is wrong.<br>
-<br>
- The parameter numbering was off by one and the check for object type<br>
- should not have exited the command.<br>
-<br>
- Also change the operator to not report missing attributes. This<br>
- results in changes to error test files in the Quality Logic suite,<br>
- however, we did not match the HP error report previously and don't<br>
- plan to do so. Oddly, HP reports a C file and line number in the<br>
- report, we suspect this is a bug.<br>
-<br>
-pcl/pxl/pxink.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-04 10:39:19 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cfc80a96f5ba682d86ce2ee1375cfca5b5941fea">cfc80a96f5ba682d86ce2ee1375cfca5b5941fea</a>
-<blockquote>
-<p>
- type 3 masked image - pacify valgrind with pdfwrite<br>
-<br>
- Bug #693814 &quot;Valgrind reports uninitialised value(s) in pdf written image streams&quot;<br>
-<br>
- The valgrind warnings are real, but essentially benign. If the wisth of<br>
- the mask data for a type 3 masked image is not a multiple of 8, then we<br>
- do not completely write to each bit of the final byte of mask data.<br>
-<br>
- When writing the mask data to a PDF file, we obviously write the entire<br>
- last byte, which causes valgrind to (correctly) complain about using<br>
- uninitialised data. Of course the uninitialised bits are never actually<br>
- used, even by the PDF consumer.<br>
-<br>
- We could put a PACIFY_VALGRIND around this line, but writing<br>
- uninitialised bytes means we could run the same input twice and get two<br>
- slight different PDF files, which would flag as a diff in our testing.<br>
- It would also annoy the 'reproducible builds' people, potentially.<br>
-<br>
- Since its only a single byte, just clear it for reproducibility, even<br>
- when we aren't running valgrind.<br>
-<br>
-base/gximage3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-02 16:21:48 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ca8246f639c73127fd05b674679864a9bf2eb0d2">ca8246f639c73127fd05b674679864a9bf2eb0d2</a>
-<blockquote>
-<p>
- XPS interpreter - address a valgrind problem<br>
-<br>
- Bug #700557 &quot;valgrind error pdfwriting text from an xps file&quot;<br>
-<br>
- The fault is not in pdfwrite, its the XPS interpreter. The pdfwrite<br>
- device copies a font, which involves calling gs_c_name_glyph() to<br>
- retrieve the name of a given glyph. The expectation (because this is<br>
- making a copy of a font) is that the returned string will be persistent<br>
- and not managed by the font or pdfwrite.<br>
-<br>
- In the PostScript interpreter this is managed by adding the glyph name<br>
- to the PostScript name table, which is persistent to the end of job and<br>
- then freed.<br>
-<br>
- Now, the XPS interpreter supplies a routine xps_true_callback_glyph_name<br>
- which is called to retrieve the glyph name. If there is a POST table in<br>
- the font, and it has names, and we can read it, we allocate some memory<br>
- and copy the name there before returning a pointer to that memory.<br>
-<br>
- If there is a POST table, but its a format which has no names, or which<br>
- we cannot deal with, then the code simply made a buffer, printed a<br>
- dummy name into it, and returned that. The problem is that as soon as<br>
- we return, the buffer we created on the stack goes out of scope leading<br>
- to the valgrind error.<br>
-<br>
- It appears that in XPS (and PCL where this code originated) there is no<br>
- mechanism like ht name table, and so even when we can find a name in the<br>
- POST table, we allocate memory for it, and allow it to leak!!<br>
-<br>
- See the comment at around line 263 of xpsttf.c, and note that this is<br>
- the same code as in pl_glyph_name() in plfont.c<br>
-<br>
- Since this memory leak already happens for the case where the POST<br>
- table can be read, I've (reluctantly) chosen to do the same in the case<br>
- where we simply invent a glyph (PCL doesn't do this). I'm not happy<br>
- about it, and the owners of the relevant interpreters really ought to<br>
- fix this properly IMO, or we should rewrite the 'copy_glyph' method<br>
- from the fonts so that it owns the memory for the name, but this would<br>
- be a huge undertaking.<br>
-<br>
-xps/xpsttf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-01 13:07:29 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=11338176d31567a5d63e49d6f91ccac7db706716">11338176d31567a5d63e49d6f91ccac7db706716</a>
-<blockquote>
-<p>
- Rename pdf14 parent_color_info_procs to parent_color_info<br>
-<br>
- As Ray pointed out, this structure has more than just procs in it.<br>
-<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-31 11:31:30 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ec9ca74bed49f2a82acb4bf430eae0d8b3b75c9">4ec9ca74bed49f2a82acb4bf430eae0d8b3b75c9</a>
-<blockquote>
-<p>
- Hide pdfdict and GS_PDF_ProcSet (internal stuff for the PDF interp).<br>
-<br>
- We now keep GS_PDF_ProcSet in pdfdict, and immediately bind pdfdict<br>
- where needed so we can undef it after the last PDF interp file has<br>
- run (pdf_sec.ps).<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_sec.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-02-01 14:45:18 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=78b321cdcbc22df928f3af2772473435e4d0695a">78b321cdcbc22df928f3af2772473435e4d0695a</a>
-<blockquote>
-<p>
- txtwrite - fix use of incorrect index for recording Widths<br>
-<br>
- When scanning multi-byte CIDFont text, we were using the text enumerator<br>
- 'index' to store the widths of glyphs. However this is incorrect when<br>
- the CIDFont uses multiple bytes; the index is the byte count into the<br>
- input string, not the numebr of characters processed.<br>
-<br>
- Use TextBufferIndex instead, which is correctly updated to track the<br>
- character index in the string, not the byte index.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-31 19:14:49 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=52cbdabc0627bbeb918ffeb5f0fe15a6922a8322">52cbdabc0627bbeb918ffeb5f0fe15a6922a8322</a>
-<blockquote>
-<p>
- Bug 700306: Fix values returned by bbox device.<br>
-<br>
- The &quot;any part of a pixel&quot; code in the new scan converter holds a<br>
- &quot;cursor&quot; position that determines where edges intersect with<br>
- the scanlines. The leftmost and rightmost positions of intersection<br>
- are held in this as values of type fixed.<br>
-<br>
- The &quot;null&quot; cursor position is represented by using maximal/minimal<br>
- values. Unfortunately, I used {max,min}_int_in_fixed, rather than<br>
- {max,min}_fixed, which meant they weren't nearly as maximal/minimal<br>
- as they ought to have been.<br>
-<br>
- This meant that the logic for inserting the real left/right hand<br>
- edges went wrong, and we output spurious positions into the<br>
- edgebuffer table. This in turn caused larger spans to be filled<br>
- to the underlying device than expected, hence upsetting the bbox.<br>
-<br>
- For all other devices, there was no problem because overly large<br>
- or small values are clipped away.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-30 15:09:45 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e1f3eb6e848498a085fbec7333cbe2a22d7be318">e1f3eb6e848498a085fbec7333cbe2a22d7be318</a>
-<blockquote>
-<p>
- Undef .growfontdict<br>
-<br>
- - make it an operator<br>
- - make sure all procedures that use it are executeonly<br>
- - undef in gs_init.ps<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_type1.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-30 14:49:10 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=052d8d2afc14b14efa46632f355ee24b273760f1">052d8d2afc14b14efa46632f355ee24b273760f1</a>
-<blockquote>
-<p>
- Undef .fontnameproperties<br>
-<br>
- Used in a gs_fonts.ps and pdf_font.ps. Immediate evaluation and undef in<br>
- gs_init.ps.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-30 13:54:06 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b5031745ae7f00f9d6c653bf647330e1e1f5a9b">7b5031745ae7f00f9d6c653bf647330e1e1f5a9b</a>
-<blockquote>
-<p>
- Undef .findfontname<br>
-<br>
- Only used locally, so use immediate evaluation.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-30 13:40:45 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=64cc22e15f680418c539f0f1d286168bc6d1cf75">64cc22e15f680418c539f0f1d286168bc6d1cf75</a>
-<blockquote>
-<p>
- Undef .definenativefontmap<br>
-<br>
- Only used locally, so use immediate evaluation.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-30 13:38:02 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=829a8c85112193116f39928568e8bf56138b7410">829a8c85112193116f39928568e8bf56138b7410</a>
-<blockquote>
-<p>
- Undef .definemodifiedfont<br>
-<br>
- This was a random procedure not actually used anywhere...<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-30 12:14:52 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=865e68569b194992ab097006f2884c1dc1e83d05">865e68569b194992ab097006f2884c1dc1e83d05</a>
-<blockquote>
-<p>
- Undef .definefakefonts<br>
-<br>
- All the comments seem to say not to bind this one, but immediate evaluation<br>
- should be fine.<br>
-<br>
- Undef in gs_init.ps after all uses.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-30 12:09:43 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=430e219ea17a2650577d70021399c4ead05869e0">430e219ea17a2650577d70021399c4ead05869e0</a>
-<blockquote>
-<p>
- Undef .completefont<br>
-<br>
- - make it an operator<br>
- - make sure all procedures that use it are executeonly<br>
- - undef in gs_init.ps<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-30 09:51:54 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cdcb56ed5af686ab2e368587506f12ba071ff41e">cdcb56ed5af686ab2e368587506f12ba071ff41e</a>
-<blockquote>
-<p>
- Undef .buildnativefontmap<br>
-<br>
- - make it an operator<br>
- - make sure all procedures that use it are executeonly<br>
- - undef in gs_init.ps<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-30 09:40:25 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fe316c21cb1c9a192da58158155a56f46f1f753a">fe316c21cb1c9a192da58158155a56f46f1f753a</a>
-<blockquote>
-<p>
- Undef .origdefinefont, .origundefinefont, .origfindfont<br>
-<br>
- I don't understand why these need to be defined (in gs_res.ps) but things<br>
- break if they are not. So just undef them in gs_init.ps after all the<br>
- initialization is complete.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-30 09:05:55 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d68c6d816d5d584ce340f9d4c827279cc4321125">d68c6d816d5d584ce340f9d4c827279cc4321125</a>
-<blockquote>
-<p>
- Remove .glyphwidth implementation, since it isn't used anywhere<br>
-<br>
- Deleted C implementation.<br>
- Made finish_stringwidth() static since it no longer needs to be exported<br>
- to zglyphwidth().<br>
-<br>
-psi/ichar.h<br>
-psi/zchar.c<br>
-psi/zcharx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-30 08:14:58 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d74962183f1929ebfab7db119d97ca0b82eb3816">d74962183f1929ebfab7db119d97ca0b82eb3816</a>
-<blockquote>
-<p>
- Undef .findfontop<br>
-<br>
- This needs to stay an operator (based on the comments), so have to undef it<br>
- in gs_init.ps.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-29 21:05:41 +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=412a279721c0f17d496147f3b87de873123a530e">412a279721c0f17d496147f3b87de873123a530e</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent numerous memory leaks.<br>
-<br>
- Saving the desired_implmentation ensures that the correct cleanup routines are called.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=1846 ./membin/gpcl6 -sDEVICE=pbmraw -dMaxBitmap=2000 -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0270<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-30 09:30:37 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9bf4dddd99987b45375972ee95d061cc7d3d393f">9bf4dddd99987b45375972ee95d061cc7d3d393f</a>
-<blockquote>
-<p>
- Bug 696600: psdcmykog device_procs<br>
-<br>
- My earlier fix caused massive problems with any transparency files.<br>
- This should fix all the issues.<br>
-<br>
-devices/gdevcmykog.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-29 11:50:21 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f075b380de5c2826055d092f2e4616ed6da89e87">f075b380de5c2826055d092f2e4616ed6da89e87</a>
-<blockquote>
-<p>
- Fix debug message 'v' output num_components_new with spot colors.<br>
-<br>
- The debug message was before the new_num_components was adjusted for<br>
- num_spots.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-28 09:58:51 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0dcbfa4a999fcfe154c313e1a63855b7c0355a8e">0dcbfa4a999fcfe154c313e1a63855b7c0355a8e</a>
-<blockquote>
-<p>
- Bug 700493: Search parent Resources, if not found in Local or Page<br>
-<br>
- The spec mentions that the Page Resources are inherited by a Form<br>
- Xobject (not recommended), but Adobe and mupdf find, and use, the<br>
- Resource definition in a parent (ancestor) Xobject. Recursively<br>
- search the parent Resources ONLY if it isn't found in the Form's<br>
- Resources or the Page Resources (which may include Resources of<br>
- ancestors of the Page).<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-28 10:09:10 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=647992061fc815d29982ecbc1ad76e3e86cc714f">647992061fc815d29982ecbc1ad76e3e86cc714f</a>
-<blockquote>
-<p>
- Fix Bug 694190 for cmykspot and custom put_image functions (fix SEGV)<br>
-<br>
- When we get an error in the PDF interpreter, we can end up in the put_image<br>
- function. This check belongs in the two other pdf14 put_image functions.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-18 09:33:45 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0530328c8d16e69557f8bdeafcd40d8a75f5e994">0530328c8d16e69557f8bdeafcd40d8a75f5e994</a>
-<blockquote>
-<p>
- Fix SEGV found with broken PDF interpreter and Bug690770.pdf<br>
-<br>
- Found accidentally when I was working on a PDF interpreter change, when<br>
- closing the pdf14 device, the smaskcolor-&gt;ref_count was decremented, but<br>
- that object had already been freed (stale pointer). The free was by a<br>
- &quot;restore&quot;, so the smaskcolor needs to be in stable_memory so that it<br>
- will be protected from the restore. Similarly for the &quot;profiles&quot; of that<br>
- structure (and free both with stable_memory).<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-29 08:31:06 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=13faebdf8817a99e1476736687ca2d75c002fb25">13faebdf8817a99e1476736687ca2d75c002fb25</a>
-<blockquote>
-<p>
- Fixed some issues with htmldiff.pl<br>
-<br>
- 1) I am using pngize=0. My version of bmpcmp automatically outputs in<br>
- png format. I think this reveals a bug related to file suffixes?<br>
- Anyway, I added an &quot;outsuffix&quot; variable and at least for my situation,<br>
- it now works. I don't know if this is a general fix or not.<br>
-<br>
- 2) The metafile string was built with $imstr, which isn't a defined<br>
- variable? Changed this to be $imstr1. How did this ever work?<br>
-<br>
-toolbin/htmldiff.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-29 14:31: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=7c8f63f6765254367cb85e3bd0f3b9b1388237c7">7c8f63f6765254367cb85e3bd0f3b9b1388237c7</a>
-<blockquote>
-<p>
- Bug 693814: Fix valgrind error in pdf_image_plane_data_alt.<br>
-<br>
- Valgrind is not smart enough to realise that &lt;undefined_value&gt; * 0 =<br>
- defined 0.<br>
-<br>
- Thus, initialise raster to 0.<br>
-<br>
- This makes the following command run without warnings:<br>
-<br>
- valgrind --track-origins=yes bin/gs -sOutputFile=out.pdf<br>
- -dMaxBitmap=400000000 -sDEVICE=pdfwrite -r300 -Z:<br>
- -dNOPAUSE -dBATCH -K2000000 -dClusterJob<br>
- /home/marcos/cluster/tests_private/comparefiles/Bug692226.ps<br>
-<br>
-base/gximage3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-29 12:51:09 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=14ccdd48a3ba6f546e024a21c3837dc258d1f79d">14ccdd48a3ba6f546e024a21c3837dc258d1f79d</a>
-<blockquote>
-<p>
- Bug 700512: Fix error from image_render_icc16.<br>
-<br>
- If we render a skewed image using image_render_icc16, and the first<br>
- two pixels on the line have identical source values, the current<br>
- code would forget to do the color mapping. This would result in<br>
- a &quot;Fatal&quot; error coming back from the underlying pixel plot routine<br>
- which causes the whole program to exit.<br>
-<br>
- The fix is simply to insist that the first pixel on a row must<br>
- always be mapped.<br>
-<br>
-base/gxi12bit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-28 15:07:07 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7eff21255ed7b053bb78e7654793c63943b10a01">7eff21255ed7b053bb78e7654793c63943b10a01</a>
-<blockquote>
-<p>
- Avoid valgrind problems with copy_landscape.<br>
-<br>
- The copy_landscape routine uses memflip8x8 to transpose 8 lines<br>
- of data to be 8 columns of data.<br>
-<br>
- At the end of the line, unless the width is a multiple of 8, we<br>
- therefore end up accessing uninitialised data. This trips<br>
- valgrind.<br>
-<br>
- We therefore introduce a special case variant for the end of the<br>
- line, where we mask off the undefined bits.<br>
-<br>
- This can be seen by doing:<br>
-<br>
- make vg<br>
- bin/gs -sOutputFile=test.ps -dMaxBitmap=400000000 -sDEVICE=ps2write<br>
- -r300 -Z: -dNOPAUSE -dBATCH -K2000000 -dClusterJob<br>
- /home/marcos/cluster/tests_private/comparefiles/Bug691740.pdf<br>
- valgrind --track-origins=yes bin/gs -sOutputFile=/dev/null<br>
- -dMaxBitmap=400000000 -sDEVICE=pkmraw -r300 -Z: -dNOPAUSE<br>
- -dBATCH -K2000000 -dClusterJob test.ps<br>
-<br>
-base/gsutil.c<br>
-base/gsutil.h<br>
-base/gxifast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-28 09:43:17 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c79f5245d24398b6f024e5e8611882a10b2799b0">c79f5245d24398b6f024e5e8611882a10b2799b0</a>
-<blockquote>
-<p>
- Fix strange valgrind problem; compiler error?<br>
-<br>
- On peeves, the following commands produce valgrind warnings:<br>
-<br>
- make vg<br>
- bin/gs -sOutputFile=out.ps -dMaxBitmap=400000000 -sDEVICE=ps2write<br>
- -r300 -Z: -dNOPAUSE -dBATCH -K2000000 -dClusterJob<br>
- /home/marcos/cluster/tests_private/comparefiles/Bug691112.pdf<br>
- valgrind --track-origins=yes bin/gs -sOutputFile=/dev/null<br>
- -dMaxBitmap=400000000 -sDEVICE=ppmraw -r300 -Z: -dNOPAUSE<br>
- -dBATCH -K2000000 -dClusterJob out.ps<br>
-<br>
- Debugging shows that the &quot;run_len&quot; member of the RLE stream state<br>
- is not being initialised. As far as I can tell, it really out to<br>
- be.<br>
-<br>
- Changing the code to use the (neater, IMHO) mechanism of initing<br>
- the stream state by calling the template init function seems to<br>
- solve this. I cannot for the life of me see why this should make<br>
- a difference, but this is a better way to work in any case.<br>
-<br>
-base/gxclutil.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-28 20:21:24 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=659cb78748c9f4bb4e5f45a1c07872176fba7e57">659cb78748c9f4bb4e5f45a1c07872176fba7e57</a>
-<blockquote>
-<p>
- Bug 696600: psdcmykog device issues<br>
-<br>
- The psdcmykog device is a DeviceN color based device but unlike psdcmyk and<br>
- tiffsep it can't change its color characteristics. It remains as<br>
- a 6 color cmykog device. Postsript files can change the maxseparations<br>
- (example 29-07E.PS) The gdevdevn code will, if it<br>
- detects a change occured, close the device and reopen (see<br>
- devn_printer_put_params) possibly resetting the color info. tiffsep<br>
- and psdcmyk, when reopened, will reset their color characteristics based upon<br>
- the content of the page, avoiding any issues upon the reopen. Here we<br>
- will need to make sure to set the color information to avoid problems.<br>
-<br>
-devices/gdevcmykog.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-27 17:40:25 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7c3c69932c9b12526a54830cca745ceb21aebdec">7c3c69932c9b12526a54830cca745ceb21aebdec</a>
-<blockquote>
-<p>
- Bug 700492 - xl readImage IllegalAttributeValue.<br>
-<br>
- Support switching compression schemes within a single image. We now<br>
- allow switching between lossless modes (uncompressed, rle and<br>
- delta-row) but do not allow changing to jpeg compression.<br>
- Interleaving lossy and lossless compression within a single image is<br>
- not expected in practice.<br>
-<br>
-pcl/pxl/pximage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-28 10:45:58 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6476023744d256b12ea11bff3e121104df99f426">6476023744d256b12ea11bff3e121104df99f426</a>
-<blockquote>
-<p>
- Bug 695046: icc profile not found<br>
-<br>
- When the code is compiled without compile inits the icc profiles<br>
- associated with enumerated color spaces in jpx images could not<br>
- be found.<br>
-<br>
-base/gsicc_manage.c<br>
-base/gsicc_manage.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-28 14:16:35 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c52f058c6d5c912d9d9da609929b4cd306e2760e">c52f058c6d5c912d9d9da609929b4cd306e2760e</a>
-<blockquote>
-<p>
- pdfwrite: Avoid valgrind errors when comparing image lines.<br>
-<br>
- Within pdf_dump_converted_image we compare scanlines of image data<br>
- to the next one. Unfortunately, if scanlines aren't an exact number<br>
- of bytes wide, we have uninitialised bits at the end, which can a)<br>
- cause spurious mismatches, and b) cause valgrind errors, such as<br>
- seen with the following:<br>
-<br>
- make vg<br>
- valgrind --track-origins=yes bin/gs -sOutputFile=out.ps<br>
- -dMaxBitmap=400000000 -sDEVICE=ps2write -r300 -Z: -dNOPAUSE<br>
- -dBATCH -K2000000 -dClusterJob<br>
- /home/marcos/cluster/tests_private/comparefiles/Bug690237.pdf<br>
-<br>
- Here we simply use a modified line comparison routine to test<br>
- the exact set of bits required.<br>
-<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-22 09:37:43 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b092266152f2c43f7f5bb195bf9ef37afa46996b">b092266152f2c43f7f5bb195bf9ef37afa46996b</a>
-<blockquote>
-<p>
- Fix buffer overread in cmd_compress_bitmap.<br>
-<br>
- The following commands:<br>
-<br>
- make debugvg<br>
- debugbin/gs -sOutputFile=/dev/null -dMaxBitmap=400000000 -sDEVICE=ppmraw<br>
- -r300 -Z: -dNOPAUSE -dBATCH -K2000000 -dClusterJob out2.ps<br>
-<br>
- cause a read of uninitialised data in cmd_compress_bitmap.<br>
-<br>
- Painstaking debugging shows that the problem is due to an overread<br>
- at the end of a bitmap line.<br>
-<br>
- cmd_put_bits is called with 408 bits of bitmap data. This passes the<br>
- details into clist_bitmap_bytes, and is told that uncompressed_raster<br>
- should be 448 bits.<br>
-<br>
- It then passes this side into cmd_compress_bitmap, which causes the<br>
- buffer overread.<br>
-<br>
- The interesting point is that this call is:<br>
-<br>
- status = cmd_compress_bitmap((stream_state *) &amp; sstate, data,<br>
- uncompressed_raster &lt;&lt; 3 /*width_bits */ ,<br>
- raster, height, &amp;w);<br>
-<br>
- which suggests that at some point in the past we were passing the<br>
- correct value of width_bits in, and we then changed to passing<br>
- the wrong width in.<br>
-<br>
- Sadly, there is no hint in the commit record as to WHY this changed.<br>
- This line dates back to the earliest commit we have in source control<br>
- in 1998, so it looks like it hasn't changed for a while.<br>
-<br>
- This is only the first part of the problem, though; once in<br>
- cmd_compress_bitmap, the value is fed into bitmap_raster() which again<br>
- rounds it up so it reads off the end of the defined data.<br>
-<br>
- We therefore rework cmd_compress_bitmap. We specifically only compress<br>
- the actual bits of data that we have, and ensure that any padding bits<br>
- (or bytes) are correctly sent as constant zeros.<br>
-<br>
- As well as assugaging valgrind, and preventing potential genuine<br>
- (if unlikely) buffer overreads, this ensures that we should get<br>
- repeatable results on each successive run.<br>
-<br>
-base/gxclbits.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-23 16:13: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=f78601f3d8df7ed16550d834cbf2c440804a6f41">f78601f3d8df7ed16550d834cbf2c440804a6f41</a>
-<blockquote>
-<p>
- Rework RunLengthEncoder.<br>
-<br>
- The existing RunLengthEncoder relies on being able to read ahead<br>
- a few bytes, and then decide that it wants to ask the caller for<br>
- more data.<br>
-<br>
- Unfortunately, this means that the clist cmd_compress_bitmap routine<br>
- can only call it in the &quot;here is all the data in a solid block&quot; case,<br>
- not in the &quot;here is the data a line at a time&quot; case.<br>
-<br>
- This will become even more of a limitation when I rework<br>
- cmd_compress_bitmap to avoid overrun reads in a future commit.<br>
-<br>
- The primary difference here is that we never backtrack on our reads<br>
- within the compression routine. We keep the last 1, 2 or 3 bytes<br>
- read in the state as n0, n1 and n2, and we insert literal bytes into a<br>
- array within the state for copying out later.<br>
-<br>
- Because we now allow cmd_compress_bitmap to run in cases when it<br>
- didn't before, we trip over a bug in there. If height &gt; 0 and<br>
- raster &lt; width_bytes (for instance when raster = 0, so we can repeat<br>
- the same line several times), on 64bit builds the pointer<br>
- arithmetic goes wrong, and we end up accessing illegal memory.<br>
- Fix with a simple cast to int.<br>
-<br>
-base/gxclbits.c<br>
-base/srle.c<br>
-base/srlx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-28 09:37: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=290ad1e4321ee46d34e7f6fdc6936e909092f7d5">290ad1e4321ee46d34e7f6fdc6936e909092f7d5</a>
-<blockquote>
-<p>
- txtwrite - forcibly disable interpolation<br>
-<br>
- Bug #700525 &quot;/unknownerror in --imagemask-- on txtwrite device&quot;<br>
-<br>
- If we have interpolation on, and we get an imagemask, then the rendering<br>
- code tries to use get_bits() to perform the interpolation. This<br>
- obviously doesn't work with a non-rendering device.<br>
-<br>
- The simplest solution is to disable interpolation, which isn't in any<br>
- even useful on a non-rendering device.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-17 15:11:56 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=946025aa4219d2a386ff0ca5b48e7be71d86b81f">946025aa4219d2a386ff0ca5b48e7be71d86b81f</a>
-<blockquote>
-<p>
- Undef/hide internal operators in gs_typ42.ps<br>
-<br>
- Undef internal .type42build, only used locally.<br>
-<br>
- Make %Type42BuildChar and %Type42BuidlGlyph executeonly to properly hide<br>
- .type42execchar.<br>
-<br>
-Resource/Init/gs_typ42.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-17 14:28:28 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9be4230804851ee1cba0aebc97e98f12bc885593">9be4230804851ee1cba0aebc97e98f12bc885593</a>
-<blockquote>
-<p>
- Undef/hide internal operators from gs_type1.ps<br>
-<br>
- /.loadfont1 -- used locally, rearranged code so def is before use<br>
- /.type1build -- end of file has some optional code (it may skip to EOF),<br>
- so I just undef'd it in gs_init.ps<br>
-<br>
- Made %Type1BuildChar, %Type1BuildGlyph, %Type2BuildChar, %Type2BuildGlyph<br>
- executeonly to properly hide .type1execchar and .type2execchar.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_type1.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-17 12:18:26 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e6feb75ec94d7102440a2b86ce16841b3e3023af">e6feb75ec94d7102440a2b86ce16841b3e3023af</a>
-<blockquote>
-<p>
- Undef/hide internal operators in gs_cidfn.ps<br>
-<br>
- /.checkfonttype<br>
- /.loadcidfontresource<br>
- /.readglyphdata<br>
-<br>
- Make %Type9BuildGlyph and %Type11BuildGlyph funcs executeonly to<br>
- properly hide the '.type*execchar' operators that they call.<br>
-<br>
-Resource/Init/gs_cidfn.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-17 09:31:17 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=95ac05d50f5af5f81f0ab2e0e0731a65ad59085e">95ac05d50f5af5f81f0ab2e0e0731a65ad59085e</a>
-<blockquote>
-<p>
- undef .composefontdict from gs_cmap.ps<br>
-<br>
-Resource/Init/gs_cmap.ps<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-16 12:55:22 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2905c901244a3c105560a48ae3047196961920d7">2905c901244a3c105560a48ae3047196961920d7</a>
-<blockquote>
-<p>
- Undef internal operators from gs_cff.ps<br>
-<br>
- - rearranged some code in gs_cff.ps to have things defined before used<br>
- - /.init_wOFF_otto_font_file is only used locally, undef right after use<br>
- - /.init_otto_font_file is used by pdf_fonts.ps, undef in gs_init.ps<br>
-<br>
- /.init_otto_font_file was being defined after it was used, because<br>
- gs_cff.ps was run after pdf_fonts.ps. Need to define before using, in<br>
- order to be able to undef, so had to change psi/int.mak to load<br>
- gs_cff.ps before pdf_fonts.ps. Also moved around the cff.dev dependencies<br>
- accordingly.<br>
-<br>
- NOTE: To see what order the files will be loaded, you can look at<br>
- obj/iconfig.h which is generated by the makefile magic. You can also<br>
- look at the INITFILES array in gs_init.ps, which the stuff in<br>
- iconfig.h eventually generates.<br>
-<br>
-Resource/Init/gs_cff.ps<br>
-Resource/Init/gs_init.ps<br>
-psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-23 12:00:30 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e7ff64cf9b756278f19c87d295ee0fd95c955c05">e7ff64cf9b756278f19c87d295ee0fd95c955c05</a>
-<blockquote>
-<p>
- Fixed bug caused by the way .checksetparams was undef'd<br>
-<br>
- Previously, had undef'd it by making it an operator.<br>
- Now just use an immediate reference and undef it in the gs_lev2.ps file.<br>
-<br>
- This fixes bug introduced in commit fe4c47d8e25d6366ecbb5ff487348148b908a89e.<br>
-<br>
- Undef'ing .checksetparams by making it an operator doesn't work right because<br>
- errors report .checksetparams as the offending function instead of<br>
- the operator that uses it (setsystemparams in this case).<br>
-<br>
- This caused an error in file /tests_private/ps/ps3cet/27-09.PS on page 3,<br>
- where it reports the offending function of some error-handling tests.<br>
- Reporting function should be 'setsystemparams', not '.checksetparams' on<br>
- this page.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_lev2.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-24 15:33:37 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e51c447b690c233b6299e68f9c031a32c61cc263">e51c447b690c233b6299e68f9c031a32c61cc263</a>
-<blockquote>
-<p>
- pdfwrite - detecting duplicate images, check for pending masks<br>
-<br>
- Bug #700495 &quot;gs/gpdl difference with pdfwrite&quot;<br>
-<br>
- This exhibits with gpdl but not gs because, for some unknown reason, the<br>
- MD5 sums from gpdl differ in a few cases from those returned by GS,<br>
- I have no idea why.<br>
-<br>
- But that's not the problem, so I'm ignoring it for now.<br>
-<br>
- The real problem is that when we have an image which has an associated<br>
- Mask or SMask, when checking to see if it is a duplicate of a prior<br>
- image, we were not checking to see if the prior image also had a Mask<br>
- or SMask (as appropriate) which could lead to us emitting an image<br>
- with a missing mask.<br>
-<br>
- We cater for that now in smask_image_check. Also not strictly part of<br>
- this problem, when we did add a Mask or SMask to a stream cos object, we<br>
- didn't invalidate its MD5, which could mean it would match a later image<br>
- when it should not. So set the md5_valid flag to 0 when we add a mask<br>
- entry to the cos object.<br>
-<br>
- On the cluster this show progressions with two files, image-qa.ps and<br>
- 692217.pdf (drop shadows were previously missing)<br>
-<br>
- Note that the previous output for image-qa.ps was incorrect with both<br>
- gs *and* gpdl.<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdfj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-24 08:45: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=3c952a9bde27766af4832435e62fcb659df1ee1f">3c952a9bde27766af4832435e62fcb659df1ee1f</a>
-<blockquote>
-<p>
- Bug 700500: Check Type 3 fonts for transparency<br>
-<br>
- The transparency checking code didn't check Type 3 font resources for<br>
- transparency settings, thus we could miss those, and fail to push the<br>
- compositor device.<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-23 18:59:19 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f5cb0ef75fc11bb65a63a1af35ee2edc94656bb4">f5cb0ef75fc11bb65a63a1af35ee2edc94656bb4</a>
-<blockquote>
-<p>
- Bug 693787 Valgrind issue<br>
-<br>
- An error code was not returned when it was encountered<br>
- leading to the use of uninitialized values.<br>
-<br>
-base/gxshade4.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-23 11:52:19 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aad16609bbc3476c56fa8ab8b52b64c1653594d4">aad16609bbc3476c56fa8ab8b52b64c1653594d4</a>
-<blockquote>
-<p>
- Bug 693816 Valgrind issue<br>
-<br>
- During CMYK color space install unset the device color<br>
- to ensure that any of the overprint checking is not<br>
- invoked with unknown values.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-22 13:34:32 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4cf03307489c9c27da77607821598ded1aa14e73">4cf03307489c9c27da77607821598ded1aa14e73</a>
-<blockquote>
-<p>
- Bug 694243 Valgrind issue<br>
-<br>
- During the creation of the transparency buffer information we were<br>
- exiting if the width or height were zero. We needed to fill in<br>
- a few more items (like the width and the height) before doing so<br>
- as they are tested elsewhere.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-11 13:36:36 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49c8092da88ef6bb0aa281fe294ae0925a44b5b9">49c8092da88ef6bb0aa281fe294ae0925a44b5b9</a>
-<blockquote>
-<p>
- Remove .forcedef, and harden .force* ops more<br>
-<br>
- Remove .forcedef and replace all uses with a direct call to .forceput instead.<br>
-<br>
- Ensure every procedure (named and trasient) that calls .forceput is<br>
- executeonly.<br>
-<br>
-Resource/Init/gs_dps1.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_ll3.ps<br>
-Resource/Init/gs_res.ps<br>
-Resource/Init/gs_statd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-09 14:24:07 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2768d1a6dddb83f5c061207a7ed2813999c1b5c9">2768d1a6dddb83f5c061207a7ed2813999c1b5c9</a>
-<blockquote>
-<p>
- Undefine a bunch of gs_fonts.ps specific procs<br>
-<br>
- Also reorder and add some immediate evaluation, so it still works with the<br>
- undefining.<br>
-<br>
-Resource/Init/gs_dps1.ps<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-18 10:42:10 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59d8f4deef90c1598ff50616519d5576756b4495">59d8f4deef90c1598ff50616519d5576756b4495</a>
-<blockquote>
-<p>
- Harden some uses of .force* operators<br>
-<br>
- by adding a few immediate evalutions<br>
-<br>
-Resource/Init/gs_dps1.ps<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-15 09:08:32 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=99f13091a3f309bdc95d275ea9fec10bb9f42d9a">99f13091a3f309bdc95d275ea9fec10bb9f42d9a</a>
-<blockquote>
-<p>
- Bug700317: Fix logic for an older change<br>
-<br>
- Unlike almost every other function in gs, dict_find_string() returns 1 on<br>
- success 0 or &lt;0 on failure. The logic for this case was wrong.<br>
-<br>
-psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-13 15:28:34 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2db98f9c66135601efb103d8db7d020a672308db">2db98f9c66135601efb103d8db7d020a672308db</a>
-<blockquote>
-<p>
- Any transient procedures that call .force* operators<br>
-<br>
- (i.e. for conditionals or loops) make them executeonly.<br>
-<br>
-Resource/Init/gs_diskn.ps<br>
-Resource/Init/gs_dps1.ps<br>
-Resource/Init/gs_fntem.ps<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_pdfwr.ps<br>
-Resource/Init/gs_res.ps<br>
-Resource/Init/gs_setpd.ps<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>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-05 12:22:13 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=13b0a36f8181db66a91bcc8cea139998b53a8996">13b0a36f8181db66a91bcc8cea139998b53a8996</a>
-<blockquote>
-<p>
- Sanitize op stack for error conditions<br>
-<br>
- We save the stacks to an array and store the array for the error handler to<br>
- access.<br>
-<br>
- For SAFER, we traverse the array, and deep copy any op arrays (procedures). As<br>
- we make these copies, we check for operators that do *not* exist in systemdict,<br>
- when we find one, we replace the operator with a name object (of the form<br>
- &quot;/--opname--&quot;).<br>
-<br>
-psi/int.mak<br>
-psi/interp.c<br>
-psi/istack.c<br>
-psi/istack.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-23 11:45:16 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c47512e5e638d903d69925f7ebab4de2aa3f481f">c47512e5e638d903d69925f7ebab4de2aa3f481f</a>
-<blockquote>
-<p>
- pdfwrite - sort out a type confusion<br>
-<br>
- Bug #700490 &quot;gs_text_enum_t used as pdf_text_enum_t&quot;<br>
-<br>
- There seems to have been 2 sources of confusion here; this falls into<br>
- the 'how did this ever work' category.<br>
-<br>
- The problem only occurs when we are forced to go to a bitmap font, which<br>
- for PostScript and PDF input is very rare, but for PCL there are several<br>
- font types we cannot support and so we must make bitmapped fonts for<br>
- them.<br>
-<br>
- We use a pointer in the pdfwrite device structure to store a pointer to<br>
- the text enumerator, but we store the *wrong* enumerator. We store<br>
- pte_default, which is the enumerator we just created for the standard<br>
- test processing. We don't need to store that one, its available as the<br>
- argument to all the procedures. What we need access to is the original<br>
- text enumerator, the pdfwrite one, and its that one we should be storing<br>
- in the device structure.<br>
-<br>
- There was similar confusion in pdf_text_set_cache, which set penum to<br>
- 'pte' casting it to a pdf_text_enum * in the process. This is clearly<br>
- wrong in the case of making a bitmap font, because we made a standard<br>
- text enumerator and passed that in, so 'pte' won't be a pdf text<br>
- enumerator.<br>
-<br>
- Now it is possible to exercise a different code path and arrive at<br>
- pdf_text_set_cache with a pdf_text_enumerator. There is no other way<br>
- to arrive here.<br>
-<br>
- So we check pdev-&gt;pte (where we would have stored the original pdf<br>
- text enumerator) and if its not NULL we use it as a pdf text enumerator.<br>
- If it is NULL, then we believe the enumerator pte should he a pdf<br>
- text enumerator and cast it as such. Also add a check to ensure that<br>
- the enumerator from the arguments *is* a pdf_text enumerator to avoid<br>
- this confusion in future.<br>
-<br>
- Finally, clean up a couple of minor compiler warnings in passing.<br>
-<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-22 17:31:33 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79589242c72d432f06c7a5f545989362564ab57e">79589242c72d432f06c7a5f545989362564ab57e</a>
-<blockquote>
-<p>
- Add a couple of helpful perl scripts for valgrind testing.<br>
-<br>
- vdb.pl automates the running of valgrind jobs under gdb, and<br>
- multiplexes the output from valgrind and gdb together.<br>
-<br>
- vgbatch.pl automates the running of a list of &quot;cluster like&quot;<br>
- tests under valgrind.<br>
-<br>
-toolbin/vdb.pl<br>
-toolbin/vgbatch.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-21 16:57:10 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=882343089e6c9ec2a4ce574cd7198281706b2f21">882343089e6c9ec2a4ce574cd7198281706b2f21</a>
-<blockquote>
-<p>
- Fix valgrind problem in pdfwrite.<br>
-<br>
- The following command:<br>
-<br>
- gs -sOutputFile=out2.ps -dMaxBitmap=400000000 -sDEVICE=ps2write -r72<br>
- -Z: -dNOPAUSE -dBATCH -K2000000 -dClusterJob<br>
- /home/marcos/cluster/tests_private/comparefiles/Bug690837.pdf<br>
-<br>
- shows problems where we call dash_pattern_eq on uninitialised data.<br>
-<br>
- It looks very much to me like pdf_load_viewer_state fails to copy<br>
- the dash data, despite allocating space for it. We fix that here.<br>
-<br>
- Also, we never check whether the allocation fails or not. Add some<br>
- error checking.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-19 12:45: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=f612df16597bbae73707d0dc9a90235b3de26c6e">f612df16597bbae73707d0dc9a90235b3de26c6e</a>
-<blockquote>
-<p>
- Preemptively fix more potential valgrind problems.<br>
-<br>
- Again, while we know that a+b = a|b when (a&amp;b)==0 (ignoring<br>
- overflow), valgrind is not that smart, and can hence incorrectly<br>
- get undefinedness calculations wrong.<br>
-<br>
- Fix cases in gdevm2 that look wrong, in the same way as the<br>
- previous commit fixed gdevm1.<br>
-<br>
-base/gdevm2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-19 04:32:18 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1a355ecf8adfce6758638aa79bc9f5338fc1e64">d1a355ecf8adfce6758638aa79bc9f5338fc1e64</a>
-<blockquote>
-<p>
- Bug 693784: Tweak copy_mono code for valgrind.<br>
-<br>
- We are smart enough to know that doing a+b is the same as<br>
- doing a|b when (a&amp;b)=0 (ignoring overflow). Valgrind is not.<br>
-<br>
- Accordingly our &quot;bit fetching and skewing&quot; code, when run<br>
- under valgrind can introduce spurious &quot;undefined&quot; status<br>
- to bits when it should not.<br>
-<br>
- The fix is just to use | when we really mean |.<br>
-<br>
- This makes:<br>
-<br>
- debugbin/gs -sOutputFile=out.pkm -dMaxBitmap=400000000<br>
- -sDEVICE=pkmraw -r300 -sDEFAULTPAPERSIZE=letter<br>
- -dNOPAUSE -dBATCH -K1000000 -dClusterJob -dJOBSERVER<br>
- tests/Ghent_V3.0/010_CMYK_OP_x3.pdf<br>
-<br>
- run to completion with no valgrind warnings.<br>
-<br>
-base/gdevm1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-17 14:27:07 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8176af6bdcf8c9d3e80862965d02ed4e71b02236">8176af6bdcf8c9d3e80862965d02ed4e71b02236</a>
-<blockquote>
-<p>
- Bug 693747: Fix valgrind problem.<br>
-<br>
- In the image scaling code, we use interpolate_scaled_expanded_height<br>
- to calculate a value that will only be used if abs_interp_limit &gt; 1.<br>
-<br>
- The setup code only bothers to initialise the values used for this<br>
- calculation if abs_interp_limit &gt; 1, hence valgrind complains that<br>
- this is using undefined values.<br>
-<br>
- The simple fix is to only calculate the values if they might be<br>
- used.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-16 17:56:39 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d0582d65fcb8760628c80a25cd0ff6a0d2db65b">1d0582d65fcb8760628c80a25cd0ff6a0d2db65b</a>
-<blockquote>
-<p>
- GPDL: Tweak PS device init for subclassing.<br>
-<br>
- Subclassing doesn't work with gpdl. For example:<br>
-<br>
- gpdl -sDEVICE=pdfwrite -o out.pdf -dFirstPage=3 lib/image-qa.ps<br>
-<br>
- The device is correctly subclassed on an open, but then we use<br>
- zcurrentoutputdevice to find the device for us to setdevice it.<br>
- This finds the childmost (i.e. pdfwrite) device, rather than<br>
- first_lastpage.<br>
-<br>
- Here, we use zcurrentdevice instead.<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-16 15:34:53 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6cee9657ff63ed555e6092f7eded544189d078d5">6cee9657ff63ed555e6092f7eded544189d078d5</a>
-<blockquote>
-<p>
- Valgrind: tweak sample_unpack functions to avoid false positive UMRs.<br>
-<br>
- The &quot;sample_unpack&quot; template functions rely on unpacking whole<br>
- bytes at a time. Sometimes, the ends of these buffers of bytes<br>
- may have bits that are (intentionally, and permissibly) undefined.<br>
-<br>
- Update the code so that in PACIFY_VALGRIND builds we cope with<br>
- these undefined bits, and carry the undefinedness over into the<br>
- output.<br>
-<br>
-base/gxsamplp.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-16 15:10:56 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4cf2ad7ad15bd52472a342c979bdd48315c43155">4cf2ad7ad15bd52472a342c979bdd48315c43155</a>
-<blockquote>
-<p>
- Update source/header file copyright notice to 2019<br>
-<br>
-Makefile.in<br>
-Resource/CIDFont/ArtifexBullet<br>
-Resource/ColorSpace/DefaultCMYK<br>
-Resource/ColorSpace/DefaultGray<br>
-Resource/ColorSpace/DefaultRGB<br>
-Resource/ColorSpace/TrivialCMYK<br>
-Resource/ColorSpace/sGray<br>
-Resource/ColorSpace/sRGB<br>
-Resource/Decoding/FCO_Dingbats<br>
-Resource/Decoding/FCO_Symbol<br>
-Resource/Decoding/FCO_Unicode<br>
-Resource/Decoding/FCO_Wingdings<br>
-Resource/Decoding/Latin1<br>
-Resource/Decoding/StandardEncoding<br>
-Resource/Decoding/Unicode<br>
-Resource/Encoding/CEEncoding<br>
-Resource/Encoding/ExpertEncoding<br>
-Resource/Encoding/ExpertSubsetEncoding<br>
-Resource/Encoding/NotDefEncoding<br>
-Resource/Encoding/Wingdings<br>
-Resource/Init/FCOfontmap-PCLPS2<br>
-Resource/Init/Fontmap.GS<br>
-Resource/Init/gs_agl.ps<br>
-Resource/Init/gs_btokn.ps<br>
-Resource/Init/gs_cff.ps<br>
-Resource/Init/gs_cidcm.ps<br>
-Resource/Init/gs_ciddc.ps<br>
-Resource/Init/gs_cidfm.ps<br>
-Resource/Init/gs_cidfn.ps<br>
-Resource/Init/gs_cidtt.ps<br>
-Resource/Init/gs_cmap.ps<br>
-Resource/Init/gs_cspace.ps<br>
-Resource/Init/gs_dbt_e.ps<br>
-Resource/Init/gs_diskn.ps<br>
-Resource/Init/gs_dps1.ps<br>
-Resource/Init/gs_dps2.ps<br>
-Resource/Init/gs_dscp.ps<br>
-Resource/Init/gs_epsf.ps<br>
-Resource/Init/gs_fapi.ps<br>
-Resource/Init/gs_fntem.ps<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_frsd.ps<br>
-Resource/Init/gs_icc.ps<br>
-Resource/Init/gs_il1_e.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_ll3.ps<br>
-Resource/Init/gs_mex_e.ps<br>
-Resource/Init/gs_mgl_e.ps<br>
-Resource/Init/gs_mro_e.ps<br>
-Resource/Init/gs_pdf_e.ps<br>
-Resource/Init/gs_pdfwr.ps<br>
-Resource/Init/gs_res.ps<br>
-Resource/Init/gs_resmp.ps<br>
-Resource/Init/gs_setpd.ps<br>
-Resource/Init/gs_statd.ps<br>
-Resource/Init/gs_std_e.ps<br>
-Resource/Init/gs_sym_e.ps<br>
-Resource/Init/gs_trap.ps<br>
-Resource/Init/gs_ttf.ps<br>
-Resource/Init/gs_typ32.ps<br>
-Resource/Init/gs_typ42.ps<br>
-Resource/Init/gs_type1.ps<br>
-Resource/Init/gs_wan_e.ps<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>
-Resource/SubstCID/CNS1-WMode<br>
-Resource/SubstCID/GB1-WMode<br>
-Resource/SubstCID/Japan1-WMode<br>
-Resource/SubstCID/Korea1-WMode<br>
-arch/arch_autoconf.h.in<br>
-arch/windows-arm-msvc.h<br>
-arch/windows-x64-msvc.h<br>
-arch/windows-x86-msvc.h<br>
-base/all-arch.mak<br>
-base/assert_.h<br>
-base/bench.c<br>
-base/claptrap-impl.h<br>
-base/claptrap.h<br>
-base/ctype_.h<br>
-base/dirent_.h<br>
-base/dos_.h<br>
-base/echogs.c<br>
-base/errno_.h<br>
-base/ets.h<br>
-base/ets_tm.h<br>
-base/expat.mak<br>
-base/fapi_bs.mak<br>
-base/fapi_ft.c<br>
-base/fapibstm.c<br>
-base/fapiufst.c<br>
-base/fcntl_.h<br>
-base/freetype.mak<br>
-base/gconf.c<br>
-base/gconf.h<br>
-base/gdbflags.h<br>
-base/gdebug.h<br>
-base/gdevabuf.c<br>
-base/gdevbbox.c<br>
-base/gdevbbox.h<br>
-base/gdevdbit.c<br>
-base/gdevdcrd.c<br>
-base/gdevdcrd.h<br>
-base/gdevddrw.c<br>
-base/gdevddrw.h<br>
-base/gdevdevn.c<br>
-base/gdevdevn.h<br>
-base/gdevdevnprn.h<br>
-base/gdevdflt.c<br>
-base/gdevdgbr.c<br>
-base/gdevdrop.c<br>
-base/gdevdsha.c<br>
-base/gdevemap.c<br>
-base/gdevepo.c<br>
-base/gdevepo.h<br>
-base/gdevflp.c<br>
-base/gdevflp.h<br>
-base/gdevhit.c<br>
-base/gdevkrnlsclass.c<br>
-base/gdevkrnlsclass.h<br>
-base/gdevm1.c<br>
-base/gdevm16.c<br>
-base/gdevm2.c<br>
-base/gdevm24.c<br>
-base/gdevm32.c<br>
-base/gdevm4.c<br>
-base/gdevm40.c<br>
-base/gdevm48.c<br>
-base/gdevm56.c<br>
-base/gdevm64.c<br>
-base/gdevm8.c<br>
-base/gdevmem.c<br>
-base/gdevmem.h<br>
-base/gdevmpla.c<br>
-base/gdevmpla.h<br>
-base/gdevmplt.c<br>
-base/gdevmplt.h<br>
-base/gdevmr1.c<br>
-base/gdevmr2n.c<br>
-base/gdevmr8n.c<br>
-base/gdevmrop.h<br>
-base/gdevmrun.c<br>
-base/gdevmrun.h<br>
-base/gdevmx.c<br>
-base/gdevnfwd.c<br>
-base/gdevoflt.c<br>
-base/gdevoflt.h<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gdevpccm.c<br>
-base/gdevpccm.h<br>
-base/gdevpipe.c<br>
-base/gdevplnx.c<br>
-base/gdevplnx.h<br>
-base/gdevppla.c<br>
-base/gdevppla.h<br>
-base/gdevprn.c<br>
-base/gdevprn.h<br>
-base/gdevpxat.h<br>
-base/gdevpxen.h<br>
-base/gdevpxop.h<br>
-base/gdevrops.c<br>
-base/gdevsclass.c<br>
-base/gdevsclass.h<br>
-base/gdevvec.c<br>
-base/gdevvec.h<br>
-base/gen_ordered.c<br>
-base/gen_ordered.h<br>
-base/genarch.c<br>
-base/genconf.c<br>
-base/gendev.c<br>
-base/genht.c<br>
-base/gp.h<br>
-base/gp_dosfe.c<br>
-base/gp_dosfs.c<br>
-base/gp_dvx.c<br>
-base/gp_getnv.c<br>
-base/gp_mktmp.c<br>
-base/gp_msdll.c<br>
-base/gp_msdos.c<br>
-base/gp_mshdl.c<br>
-base/gp_mslib.c<br>
-base/gp_mspol.c<br>
-base/gp_msprn.c<br>
-base/gp_mswin.c<br>
-base/gp_mswin.h<br>
-base/gp_nsync.c<br>
-base/gp_ntfs.c<br>
-base/gp_nxpsprn.c<br>
-base/gp_os2.c<br>
-base/gp_os2.h<br>
-base/gp_os2fs.c<br>
-base/gp_os2pr.c<br>
-base/gp_os9.c<br>
-base/gp_paper.c<br>
-base/gp_psync.c<br>
-base/gp_stdia.c<br>
-base/gp_stdin.c<br>
-base/gp_strdl.c<br>
-base/gp_unifn.c<br>
-base/gp_unifs.c<br>
-base/gp_unix.c<br>
-base/gp_upapr.c<br>
-base/gp_vms.c<br>
-base/gp_wgetv.c<br>
-base/gp_win32.c<br>
-base/gp_wpapr.c<br>
-base/gp_wsync.c<br>
-base/gp_wutf8.c<br>
-base/gp_wxpsprn.cpp<br>
-base/gpcheck.h<br>
-base/gpgetenv.h<br>
-base/gpmisc.c<br>
-base/gpmisc.h<br>
-base/gpsync.h<br>
-base/gs.mak<br>
-base/gs_dll_call.h<br>
-base/gs_mgl_e.h<br>
-base/gs_mro_e.h<br>
-base/gsalloc.c<br>
-base/gsalloc.h<br>
-base/gsalpha.c<br>
-base/gsalpha.h<br>
-base/gsalphac.c<br>
-base/gsalphac.h<br>
-base/gsargs.c<br>
-base/gsargs.h<br>
-base/gsbitcom.c<br>
-base/gsbitmap.h<br>
-base/gsbitops.c<br>
-base/gsbitops.h<br>
-base/gsbittab.c<br>
-base/gsbittab.h<br>
-base/gsccode.h<br>
-base/gsccolor.h<br>
-base/gscdef.c<br>
-base/gscdefs.h<br>
-base/gscdevn.c<br>
-base/gscdevn.h<br>
-base/gscedata.c<br>
-base/gscedata.h<br>
-base/gscencs.c<br>
-base/gscencs.h<br>
-base/gschar.c<br>
-base/gschar.h<br>
-base/gschar0.c<br>
-base/gscicach.c<br>
-base/gscicach.h<br>
-base/gscie.c<br>
-base/gscie.h<br>
-base/gsciemap.c<br>
-base/gscindex.h<br>
-base/gsclipsr.c<br>
-base/gsclipsr.h<br>
-base/gscms.h<br>
-base/gscolor.c<br>
-base/gscolor.h<br>
-base/gscolor1.c<br>
-base/gscolor1.h<br>
-base/gscolor2.c<br>
-base/gscolor2.h<br>
-base/gscolor3.c<br>
-base/gscolor3.h<br>
-base/gscompt.h<br>
-base/gscoord.c<br>
-base/gscoord.h<br>
-base/gscparam.c<br>
-base/gscpixel.c<br>
-base/gscpixel.h<br>
-base/gscpm.h<br>
-base/gscrd.c<br>
-base/gscrd.h<br>
-base/gscrdp.c<br>
-base/gscrdp.h<br>
-base/gscrypt1.c<br>
-base/gscrypt1.h<br>
-base/gscscie.c<br>
-base/gscsel.h<br>
-base/gscsepr.c<br>
-base/gscsepr.h<br>
-base/gscspace.c<br>
-base/gscspace.h<br>
-base/gscssub.c<br>
-base/gscssub.h<br>
-base/gsdcolor.h<br>
-base/gsdevice.c<br>
-base/gsdevice.h<br>
-base/gsdevmem.c<br>
-base/gsdll.h<br>
-base/gsdllwin.h<br>
-base/gsdparam.c<br>
-base/gsdps1.c<br>
-base/gsdsrc.c<br>
-base/gsdsrc.h<br>
-base/gsequivc.c<br>
-base/gsequivc.h<br>
-base/gserrors.h<br>
-base/gsexit.h<br>
-base/gsfcid.c<br>
-base/gsfcid2.c<br>
-base/gsfcmap.c<br>
-base/gsfcmap.h<br>
-base/gsfcmap1.c<br>
-base/gsflip.c<br>
-base/gsflip.h<br>
-base/gsfname.c<br>
-base/gsfname.h<br>
-base/gsfont.c<br>
-base/gsfont.h<br>
-base/gsfont0.c<br>
-base/gsfont0c.c<br>
-base/gsform1.h<br>
-base/gsfunc.c<br>
-base/gsfunc.h<br>
-base/gsfunc0.c<br>
-base/gsfunc0.h<br>
-base/gsfunc3.c<br>
-base/gsfunc3.h<br>
-base/gsfunc4.c<br>
-base/gsfunc4.h<br>
-base/gsgc.h<br>
-base/gsgcache.c<br>
-base/gsgcache.h<br>
-base/gsgdata.c<br>
-base/gsgdata.h<br>
-base/gsgstate.c<br>
-base/gsgstate.h<br>
-base/gshsb.c<br>
-base/gshsb.h<br>
-base/gsht.c<br>
-base/gsht.h<br>
-base/gsht1.c<br>
-base/gsht1.h<br>
-base/gshtscr.c<br>
-base/gshtx.c<br>
-base/gshtx.h<br>
-base/gsicc.c<br>
-base/gsicc.h<br>
-base/gsicc_cache.c<br>
-base/gsicc_cache.h<br>
-base/gsicc_cms.h<br>
-base/gsicc_create.c<br>
-base/gsicc_create.h<br>
-base/gsicc_lcms2.c<br>
-base/gsicc_lcms2mt.c<br>
-base/gsicc_manage.c<br>
-base/gsicc_manage.h<br>
-base/gsicc_monitorcm.c<br>
-base/gsicc_nocm.c<br>
-base/gsicc_profilecache.c<br>
-base/gsicc_profilecache.h<br>
-base/gsicc_replacecm.c<br>
-base/gsimage.c<br>
-base/gsimage.h<br>
-base/gsimpath.c<br>
-base/gsinit.c<br>
-base/gsio.h<br>
-base/gsiodev.c<br>
-base/gsiodevs.c<br>
-base/gsiodisk.c<br>
-base/gsioram.c<br>
-base/gsiorom.c<br>
-base/gsiorom.h<br>
-base/gsipar3x.h<br>
-base/gsiparam.h<br>
-base/gsiparm3.h<br>
-base/gsiparm4.h<br>
-base/gsjconf.h<br>
-base/gsjmorec.h<br>
-base/gslib.c<br>
-base/gslib.h<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-base/gsline.c<br>
-base/gsline.h<br>
-base/gslparam.h<br>
-base/gsmalloc.c<br>
-base/gsmalloc.h<br>
-base/gsmatrix.c<br>
-base/gsmatrix.h<br>
-base/gsmchunk.c<br>
-base/gsmchunk.h<br>
-base/gsmdebug.h<br>
-base/gsmemory.c<br>
-base/gsmemory.h<br>
-base/gsmemraw.h<br>
-base/gsmemret.c<br>
-base/gsmemret.h<br>
-base/gsmisc.c<br>
-base/gsnamecl.c<br>
-base/gsnamecl.h<br>
-base/gsncdummy.c<br>
-base/gsncdummy.h<br>
-base/gsnogc.c<br>
-base/gsnogc.h<br>
-base/gsnotify.c<br>
-base/gsnotify.h<br>
-base/gsovrc.c<br>
-base/gsovrc.h<br>
-base/gspaint.c<br>
-base/gspaint.h<br>
-base/gsparam.c<br>
-base/gsparam.h<br>
-base/gsparam2.c<br>
-base/gsparams.c<br>
-base/gsparams.h<br>
-base/gsparamx.c<br>
-base/gsparamx.h<br>
-base/gspath.c<br>
-base/gspath.h<br>
-base/gspath1.c<br>
-base/gspath2.h<br>
-base/gspcolor.c<br>
-base/gspcolor.h<br>
-base/gspenum.h<br>
-base/gspmdrv.c<br>
-base/gspmdrv.h<br>
-base/gspmdrv.rc<br>
-base/gsptype1.c<br>
-base/gsptype1.h<br>
-base/gsptype2.c<br>
-base/gsptype2.h<br>
-base/gsrect.h<br>
-base/gsrefct.h<br>
-base/gsromfs0.c<br>
-base/gsrop.c<br>
-base/gsrop.h<br>
-base/gsroprun.c<br>
-base/gsroprun1.h<br>
-base/gsroprun24.h<br>
-base/gsroprun8.h<br>
-base/gsropt.h<br>
-base/gsroptab.c<br>
-base/gsserial.c<br>
-base/gsserial.h<br>
-base/gsshade.c<br>
-base/gsshade.h<br>
-base/gssprintf.h<br>
-base/gsstate.c<br>
-base/gsstate.h<br>
-base/gsstrl.h<br>
-base/gsstrtok.h<br>
-base/gsstruct.h<br>
-base/gsstype.h<br>
-base/gstext.c<br>
-base/gstext.h<br>
-base/gstiffio.c<br>
-base/gstiffio.h<br>
-base/gstparam.h<br>
-base/gstrans.c<br>
-base/gstrans.h<br>
-base/gstrap.c<br>
-base/gstrap.h<br>
-base/gstype1.c<br>
-base/gstype1.h<br>
-base/gstype2.c<br>
-base/gstype42.c<br>
-base/gstypes.h<br>
-base/gsuid.h<br>
-base/gsutil.c<br>
-base/gsutil.h<br>
-base/gswin.rc<br>
-base/gsxfont.h<br>
-base/gx.h<br>
-base/gxacpath.c<br>
-base/gxalloc.h<br>
-base/gxalpha.h<br>
-base/gxarith.h<br>
-base/gxband.h<br>
-base/gxbcache.c<br>
-base/gxbcache.h<br>
-base/gxbitfmt.h<br>
-base/gxbitmap.h<br>
-base/gxbitops.h<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-base/gxccache.c<br>
-base/gxccman.c<br>
-base/gxcdevn.h<br>
-base/gxchar.c<br>
-base/gxchar.h<br>
-base/gxchrout.c<br>
-base/gxchrout.h<br>
-base/gxcht.c<br>
-base/gxcid.h<br>
-base/gxcie.h<br>
-base/gxcindex.h<br>
-base/gxclbits.c<br>
-base/gxcldev.h<br>
-base/gxclfile.c<br>
-base/gxclimag.c<br>
-base/gxclio.h<br>
-base/gxclip.c<br>
-base/gxclip.h<br>
-base/gxclip2.c<br>
-base/gxclip2.h<br>
-base/gxclipm.c<br>
-base/gxclipm.h<br>
-base/gxclipsr.h<br>
-base/gxclist.c<br>
-base/gxclist.h<br>
-base/gxcllzw.c<br>
-base/gxclmem.c<br>
-base/gxclmem.h<br>
-base/gxclpage.c<br>
-base/gxclpage.h<br>
-base/gxclpath.c<br>
-base/gxclpath.h<br>
-base/gxclrast.c<br>
-base/gxclread.c<br>
-base/gxclrect.c<br>
-base/gxclthrd.c<br>
-base/gxclthrd.h<br>
-base/gxclutil.c<br>
-base/gxclzlib.c<br>
-base/gxcmap.c<br>
-base/gxcmap.h<br>
-base/gxcolor2.h<br>
-base/gxcomp.h<br>
-base/gxcoord.h<br>
-base/gxcpath.c<br>
-base/gxcpath.h<br>
-base/gxcspace.h<br>
-base/gxctable.c<br>
-base/gxctable.h<br>
-base/gxcvalue.h<br>
-base/gxdcconv.c<br>
-base/gxdcconv.h<br>
-base/gxdcolor.c<br>
-base/gxdcolor.h<br>
-base/gxdda.h<br>
-base/gxdevbuf.h<br>
-base/gxdevcli.h<br>
-base/gxdevice.h<br>
-base/gxdevmem.h<br>
-base/gxdevndi.c<br>
-base/gxdevrop.h<br>
-base/gxdevsop.h<br>
-base/gxdht.h<br>
-base/gxdhtres.h<br>
-base/gxdhtserial.c<br>
-base/gxdhtserial.h<br>
-base/gxdither.h<br>
-base/gxdownscale.c<br>
-base/gxdownscale.h<br>
-base/gxdtfill.h<br>
-base/gxfapi.c<br>
-base/gxfapi.h<br>
-base/gxfapiu.c<br>
-base/gxfapiu.h<br>
-base/gxfarith.h<br>
-base/gxfcache.h<br>
-base/gxfcid.h<br>
-base/gxfcmap.h<br>
-base/gxfcmap1.h<br>
-base/gxfill.c<br>
-base/gxfill.h<br>
-base/gxfillsl.h<br>
-base/gxfilltr.h<br>
-base/gxfillts.h<br>
-base/gxfixed.h<br>
-base/gxfmap.h<br>
-base/gxfont.h<br>
-base/gxfont0.h<br>
-base/gxfont0c.h<br>
-base/gxfont1.h<br>
-base/gxfont42.h<br>
-base/gxfrac.h<br>
-base/gxftype.h<br>
-base/gxfunc.h<br>
-base/gxgetbit.h<br>
-base/gxgstate.h<br>
-base/gxhintn.c<br>
-base/gxhintn.h<br>
-base/gxhintn1.c<br>
-base/gxhldevc.c<br>
-base/gxhldevc.h<br>
-base/gxht.c<br>
-base/gxht.h<br>
-base/gxht_thresh.c<br>
-base/gxht_thresh.h<br>
-base/gxhtbit.c<br>
-base/gxhttile.h<br>
-base/gxhttype.h<br>
-base/gxi12bit.c<br>
-base/gxi16bit.c<br>
-base/gxiclass.h<br>
-base/gxicolor.c<br>
-base/gxidata.c<br>
-base/gxifast.c<br>
-base/gximag3x.c<br>
-base/gximag3x.h<br>
-base/gximage.c<br>
-base/gximage.h<br>
-base/gximage1.c<br>
-base/gximage3.c<br>
-base/gximage3.h<br>
-base/gximage4.c<br>
-base/gximask.c<br>
-base/gximask.h<br>
-base/gximono.c<br>
-base/gxiodev.h<br>
-base/gxiparam.h<br>
-base/gxipixel.c<br>
-base/gxiscale.c<br>
-base/gxline.h<br>
-base/gxlum.h<br>
-base/gxmatrix.h<br>
-base/gxmclip.c<br>
-base/gxmclip.h<br>
-base/gxobj.h<br>
-base/gxoprect.c<br>
-base/gxoprect.h<br>
-base/gxp1fill.c<br>
-base/gxp1impl.h<br>
-base/gxpaint.c<br>
-base/gxpaint.h<br>
-base/gxpath.c<br>
-base/gxpath.h<br>
-base/gxpath2.c<br>
-base/gxpcache.h<br>
-base/gxpcmap.c<br>
-base/gxpcolor.h<br>
-base/gxpcopy.c<br>
-base/gxpdash.c<br>
-base/gxpflat.c<br>
-base/gxrplane.h<br>
-base/gxsample.c<br>
-base/gxsample.h<br>
-base/gxsamplp.h<br>
-base/gxscanc.c<br>
-base/gxscanc.h<br>
-base/gxshade.c<br>
-base/gxshade.h<br>
-base/gxshade1.c<br>
-base/gxshade4.c<br>
-base/gxshade4.h<br>
-base/gxshade6.c<br>
-base/gxstate.h<br>
-base/gxstdio.h<br>
-base/gxstroke.c<br>
-base/gxsync.c<br>
-base/gxsync.h<br>
-base/gxtext.h<br>
-base/gxtmap.h<br>
-base/gxttf.h<br>
-base/gxttfb.c<br>
-base/gxttfb.h<br>
-base/gxtype1.c<br>
-base/gxtype1.h<br>
-base/gxxfont.h<br>
-base/gzacpath.h<br>
-base/gzcpath.h<br>
-base/gzht.h<br>
-base/gzline.h<br>
-base/gzpath.h<br>
-base/gzspotan.c<br>
-base/gzspotan.h<br>
-base/gzstate.h<br>
-base/ijs.mak<br>
-base/instcopy<br>
-base/jbig2.mak<br>
-base/jerror_.h<br>
-base/jmemcust.c<br>
-base/jmemcust.h<br>
-base/jpeg.mak<br>
-base/jpegxr.mak<br>
-base/lcms2.mak<br>
-base/lcms2mt.mak<br>
-base/lcups.mak<br>
-base/lcupsi.mak<br>
-base/ldf_jb2.mak<br>
-base/lib.mak<br>
-base/locale_.h<br>
-base/lwf_jp2.mak<br>
-base/malloc_.h<br>
-base/math_.h<br>
-base/memory_.h<br>
-base/mkromfs.c<br>
-base/msvccmd.mak<br>
-base/msvclib.mak<br>
-base/msvctail.mak<br>
-base/openjpeg.mak<br>
-base/openvms.mak<br>
-base/openvms.mmk<br>
-base/pack_ps.c<br>
-base/pcwin.mak<br>
-base/pipe_.h<br>
-base/png.mak<br>
-base/png_.h<br>
-base/ramfs.c<br>
-base/ramfs.h<br>
-base/sa85d.c<br>
-base/sa85d.h<br>
-base/sa85x.h<br>
-base/saes.c<br>
-base/saes.h<br>
-base/sarc4.c<br>
-base/sarc4.h<br>
-base/sbcp.c<br>
-base/sbcp.h<br>
-base/sbtx.h<br>
-base/scanchar.h<br>
-base/scantab.c<br>
-base/scf.h<br>
-base/scfd.c<br>
-base/scfdgen.c<br>
-base/scfdtab.c<br>
-base/scfe.c<br>
-base/scfetab.c<br>
-base/scfparam.c<br>
-base/scfx.h<br>
-base/scommon.h<br>
-base/sdcparam.c<br>
-base/sdcparam.h<br>
-base/sdct.h<br>
-base/sdctc.c<br>
-base/sdctd.c<br>
-base/sdcte.c<br>
-base/sddparam.c<br>
-base/sdeparam.c<br>
-base/seexec.c<br>
-base/setjmp_.h<br>
-base/sfilter.h<br>
-base/sfilter1.c<br>
-base/sfilter2.c<br>
-base/sfxboth.c<br>
-base/sfxcommon.c<br>
-base/sfxfd.c<br>
-base/sfxstdio.c<br>
-base/shc.c<br>
-base/shc.h<br>
-base/sidscale.c<br>
-base/sidscale.h<br>
-base/siinterp.c<br>
-base/siinterp.h<br>
-base/simscale.c<br>
-base/simscale.h<br>
-base/siscale.c<br>
-base/siscale.h<br>
-base/sisparam.h<br>
-base/sjbig2.c<br>
-base/sjbig2.h<br>
-base/sjbig2_luratech.c<br>
-base/sjbig2_luratech.h<br>
-base/sjpeg.h<br>
-base/sjpegc.c<br>
-base/sjpegd.c<br>
-base/sjpege.c<br>
-base/sjpx_luratech.c<br>
-base/sjpx_luratech.h<br>
-base/sjpx_none.c<br>
-base/sjpx_openjpeg.c<br>
-base/sjpx_openjpeg.h<br>
-base/slzwc.c<br>
-base/slzwd.c<br>
-base/slzwe.c<br>
-base/slzwx.h<br>
-base/smd5.c<br>
-base/smd5.h<br>
-base/smtf.h<br>
-base/spdiff.c<br>
-base/spdiffx.h<br>
-base/spngp.c<br>
-base/spngpx.h<br>
-base/spprint.c<br>
-base/spprint.h<br>
-base/spsdf.c<br>
-base/spsdf.h<br>
-base/srdline.h<br>
-base/srld.c<br>
-base/srle.c<br>
-base/srlx.h<br>
-base/ssha2.c<br>
-base/ssha2.h<br>
-base/sstring.c<br>
-base/sstring.h<br>
-base/stat_.h<br>
-base/std.h<br>
-base/stdint_.h<br>
-base/stdio_.h<br>
-base/stdpre.h<br>
-base/stream.c<br>
-base/stream.h<br>
-base/strimpl.h<br>
-base/string_.h<br>
-base/strmio.c<br>
-base/strmio.h<br>
-base/stub.mak<br>
-base/szlibc.c<br>
-base/szlibd.c<br>
-base/szlibe.c<br>
-base/szlibx.h<br>
-base/szlibxx.h<br>
-base/tiff.mak<br>
-base/time_.h<br>
-base/ttcalc.c<br>
-base/ttcalc.h<br>
-base/ttcommon.h<br>
-base/ttconf.h<br>
-base/ttconfig.h<br>
-base/ttfinp.c<br>
-base/ttfinp.h<br>
-base/ttfmain.c<br>
-base/ttfmemd.c<br>
-base/ttfmemd.h<br>
-base/ttfoutl.h<br>
-base/ttfsfnt.h<br>
-base/ttinterp.c<br>
-base/ttinterp.h<br>
-base/ttload.c<br>
-base/ttload.h<br>
-base/ttmisc.h<br>
-base/ttobjs.c<br>
-base/ttobjs.h<br>
-base/tttables.h<br>
-base/tttype.h<br>
-base/tttypes.h<br>
-base/ugcclib.mak<br>
-base/unistd_.h<br>
-base/unix-aux.mak<br>
-base/unix-dll.mak<br>
-base/unix-end.mak<br>
-base/unix-gcc.mak<br>
-base/unixansi.mak<br>
-base/unixhead.mak<br>
-base/unixinst.mak<br>
-base/unixlink.mak<br>
-base/valgrind.h<br>
-base/version.mak<br>
-base/vms_x_fix.h<br>
-base/vmsmath.h<br>
-base/windows_.h<br>
-base/winlib.mak<br>
-base/winplat.mak<br>
-base/winrtsup.cpp<br>
-base/winrtsup.h<br>
-base/wrfont.c<br>
-base/wrfont.h<br>
-base/write_t1.c<br>
-base/write_t1.h<br>
-base/write_t2.c<br>
-base/write_t2.h<br>
-base/x_.h<br>
-base/zlib.mak<br>
-configure.ac<br>
-devices/contrib.mak<br>
-devices/devs.mak<br>
-devices/gdev3852.c<br>
-devices/gdev4081.c<br>
-devices/gdev8510.c<br>
-devices/gdev8bcm.c<br>
-devices/gdev8bcm.h<br>
-devices/gdevatx.c<br>
-devices/gdevbit.c<br>
-devices/gdevbj10.c<br>
-devices/gdevbjc.h<br>
-devices/gdevbjcl.c<br>
-devices/gdevbjcl.h<br>
-devices/gdevbmp.c<br>
-devices/gdevbmp.h<br>
-devices/gdevbmpc.c<br>
-devices/gdevccr.c<br>
-devices/gdevcdj.c<br>
-devices/gdevcfax.c<br>
-devices/gdevchameleon.c<br>
-devices/gdevcif.c<br>
-devices/gdevclj.c<br>
-devices/gdevcljc.c<br>
-devices/gdevcmykog.c<br>
-devices/gdevcslw.c<br>
-devices/gdevdfax.c<br>
-devices/gdevdjet.c<br>
-devices/gdevdjtc.c<br>
-devices/gdevdljm.c<br>
-devices/gdevdljm.h<br>
-devices/gdevdm24.c<br>
-devices/gdevdsp.c<br>
-devices/gdevdsp.h<br>
-devices/gdevdsp2.h<br>
-devices/gdevepsc.c<br>
-devices/gdevepsn.c<br>
-devices/gdevescp.c<br>
-devices/gdevfax.c<br>
-devices/gdevfax.h<br>
-devices/gdevfpng.c<br>
-devices/gdevgprf.c<br>
-devices/gdevhl7x.c<br>
-devices/gdevicov.c<br>
-devices/gdevijs.c<br>
-devices/gdevimgn.c<br>
-devices/gdevjbig2.c<br>
-devices/gdevjpeg.c<br>
-devices/gdevjpx.c<br>
-devices/gdevl31s.c<br>
-devices/gdevlbp8.c<br>
-devices/gdevlj56.c<br>
-devices/gdevlp8k.c<br>
-devices/gdevlxm.c<br>
-devices/gdevmeds.c<br>
-devices/gdevmeds.h<br>
-devices/gdevmgr.c<br>
-devices/gdevmgr.h<br>
-devices/gdevmiff.c<br>
-devices/gdevn533.c<br>
-devices/gdevo182.c<br>
-devices/gdevokii.c<br>
-devices/gdevpbm.c<br>
-devices/gdevpcl.c<br>
-devices/gdevpcl.h<br>
-devices/gdevpcx.c<br>
-devices/gdevpe.c<br>
-devices/gdevperm.c<br>
-devices/gdevphex.c<br>
-devices/gdevpjet.c<br>
-devices/gdevplan.c<br>
-devices/gdevplib.c<br>
-devices/gdevplib.h<br>
-devices/gdevpm.h<br>
-devices/gdevpng.c<br>
-devices/gdevpsd.c<br>
-devices/gdevpsd.h<br>
-devices/gdevpsim.c<br>
-devices/gdevpxut.c<br>
-devices/gdevpxut.h<br>
-devices/gdevrinkj.c<br>
-devices/gdevsj48.c<br>
-devices/gdevsnfb.c<br>
-devices/gdevsppr.c<br>
-devices/gdevstc.c<br>
-devices/gdevstc.h<br>
-devices/gdevstc1.c<br>
-devices/gdevstc2.c<br>
-devices/gdevstc3.c<br>
-devices/gdevstc4.c<br>
-devices/gdevtfax.c<br>
-devices/gdevtfax.h<br>
-devices/gdevtfnx.c<br>
-devices/gdevtifs.c<br>
-devices/gdevtifs.h<br>
-devices/gdevtknk.c<br>
-devices/gdevtrac.c<br>
-devices/gdevtsep.c<br>
-devices/gdevupd.c<br>
-devices/gdevwpr2.c<br>
-devices/gdevx.c<br>
-devices/gdevx.h<br>
-devices/gdevxalt.c<br>
-devices/gdevxcf.c<br>
-devices/gdevxcmp.c<br>
-devices/gdevxcmp.h<br>
-devices/gdevxini.c<br>
-devices/gdevxres.c<br>
-devices/gxfcopy.c<br>
-devices/gxfcopy.h<br>
-devices/minftrsz.c<br>
-devices/minftrsz.h<br>
-devices/rinkj/evenbetter-rll.c<br>
-devices/rinkj/evenbetter-rll.h<br>
-devices/rinkj/rinkj-byte-stream.c<br>
-devices/rinkj/rinkj-byte-stream.h<br>
-devices/rinkj/rinkj-config.c<br>
-devices/rinkj/rinkj-config.h<br>
-devices/rinkj/rinkj-device.c<br>
-devices/rinkj/rinkj-device.h<br>
-devices/rinkj/rinkj-dither.c<br>
-devices/rinkj/rinkj-dither.h<br>
-devices/rinkj/rinkj-epson870.c<br>
-devices/rinkj/rinkj-epson870.h<br>
-devices/rinkj/rinkj-screen-eb.c<br>
-devices/rinkj/rinkj-screen-eb.h<br>
-devices/vector/gdevagl.c<br>
-devices/vector/gdevagl.h<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfb.c<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfc.c<br>
-devices/vector/gdevpdfc.h<br>
-devices/vector/gdevpdfd.c<br>
-devices/vector/gdevpdfe.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfg.h<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdfj.c<br>
-devices/vector/gdevpdfk.c<br>
-devices/vector/gdevpdfm.c<br>
-devices/vector/gdevpdfo.c<br>
-devices/vector/gdevpdfo.h<br>
-devices/vector/gdevpdfp.c<br>
-devices/vector/gdevpdfr.c<br>
-devices/vector/gdevpdft.c<br>
-devices/vector/gdevpdfu.c<br>
-devices/vector/gdevpdfv.c<br>
-devices/vector/gdevpdfx.h<br>
-devices/vector/gdevpdt.c<br>
-devices/vector/gdevpdt.h<br>
-devices/vector/gdevpdtb.c<br>
-devices/vector/gdevpdtb.h<br>
-devices/vector/gdevpdtc.c<br>
-devices/vector/gdevpdtd.c<br>
-devices/vector/gdevpdtd.h<br>
-devices/vector/gdevpdte.c<br>
-devices/vector/gdevpdtf.c<br>
-devices/vector/gdevpdtf.h<br>
-devices/vector/gdevpdti.c<br>
-devices/vector/gdevpdti.h<br>
-devices/vector/gdevpdts.c<br>
-devices/vector/gdevpdts.h<br>
-devices/vector/gdevpdtt.c<br>
-devices/vector/gdevpdtt.h<br>
-devices/vector/gdevpdtv.c<br>
-devices/vector/gdevpdtv.h<br>
-devices/vector/gdevpdtw.c<br>
-devices/vector/gdevpdtw.h<br>
-devices/vector/gdevpdtx.h<br>
-devices/vector/gdevpsdf.h<br>
-devices/vector/gdevpsdi.c<br>
-devices/vector/gdevpsdp.c<br>
-devices/vector/gdevpsds.c<br>
-devices/vector/gdevpsds.h<br>
-devices/vector/gdevpsdu.c<br>
-devices/vector/gdevpsf.h<br>
-devices/vector/gdevpsf1.c<br>
-devices/vector/gdevpsf2.c<br>
-devices/vector/gdevpsfm.c<br>
-devices/vector/gdevpsft.c<br>
-devices/vector/gdevpsfu.c<br>
-devices/vector/gdevpsfx.c<br>
-devices/vector/gdevpsu.c<br>
-devices/vector/gdevpsu.h<br>
-devices/vector/gdevpx.c<br>
-devices/vector/gdevtxtw.c<br>
-devices/vector/gdevxps.c<br>
-devices/vector/opdfread.ps<br>
-devices/vector/whitelst.c<br>
-devices/vector/whitelst.h<br>
-gpdl/gpdl.mak<br>
-gpdl/psi/gpdlpsi.mak<br>
-gpdl/psi/psitop.c<br>
-gpdl/pspcl6_gcc.mak<br>
-gpdl/pspcl6_msvc.mak<br>
-ijs/Makefile.am<br>
-ijs/configure.ac<br>
-ijs/ijs.c<br>
-ijs/ijs.h<br>
-ijs/ijs_client.c<br>
-ijs/ijs_client.h<br>
-ijs/ijs_client_example.c<br>
-ijs/ijs_exec_unix.c<br>
-ijs/ijs_exec_win.c<br>
-ijs/ijs_server.c<br>
-ijs/ijs_server_example.c<br>
-ijs/unistd_.h<br>
-ios/ios_arch-arm.h<br>
-ios/ios_arch-x86.h<br>
-jbig2dec/config_win32.h<br>
-jbig2dec/jbig2.c<br>
-jbig2dec/jbig2.h<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_generic.h<br>
-jbig2dec/jbig2_halftone.c<br>
-jbig2dec/jbig2_halftone.h<br>
-jbig2dec/jbig2_huffman.c<br>
-jbig2dec/jbig2_huffman.h<br>
-jbig2dec/jbig2_hufftab.h<br>
-jbig2dec/jbig2_image.c<br>
-jbig2dec/jbig2_image.h<br>
-jbig2dec/jbig2_image_pbm.c<br>
-jbig2dec/jbig2_image_png.c<br>
-jbig2dec/jbig2_image_rw.h<br>
-jbig2dec/jbig2_mmr.c<br>
-jbig2dec/jbig2_mmr.h<br>
-jbig2dec/jbig2_page.c<br>
-jbig2dec/jbig2_page.h<br>
-jbig2dec/jbig2_priv.h<br>
-jbig2dec/jbig2_refinement.c<br>
-jbig2dec/jbig2_refinement.h<br>
-jbig2dec/jbig2_segment.c<br>
-jbig2dec/jbig2_segment.h<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-jbig2dec/jbig2_symbol_dict.h<br>
-jbig2dec/jbig2_text.c<br>
-jbig2dec/jbig2_text.h<br>
-jbig2dec/jbig2dec.c<br>
-jbig2dec/memcmp.c<br>
-jbig2dec/os_types.h<br>
-jbig2dec/pbm2png.c<br>
-lib/FCOfontmap-PCLPS3<br>
-lib/FCOfontmap-PS3<br>
-lib/Fontmap.ATB<br>
-lib/Fontmap.ATM<br>
-lib/Fontmap.OS2<br>
-lib/Fontmap.SGI<br>
-lib/Fontmap.Sol<br>
-lib/Fontmap.URW-136.T1<br>
-lib/Fontmap.URW-136.TT<br>
-lib/Fontmap.Ult<br>
-lib/Fontmap.VMS<br>
-lib/align.ps<br>
-lib/caption.ps<br>
-lib/cat.ps<br>
-lib/cid2code.ps<br>
-lib/docie.ps<br>
-lib/font2pcl.ps<br>
-lib/gs_ce_e.ps<br>
-lib/gs_il2_e.ps<br>
-lib/gs_kanji.ps<br>
-lib/gs_ksb_e.ps<br>
-lib/gs_lgo_e.ps<br>
-lib/gs_lgx_e.ps<br>
-lib/gs_wl1_e.ps<br>
-lib/gs_wl2_e.ps<br>
-lib/gs_wl5_e.ps<br>
-lib/gslp.ps<br>
-lib/gsnup.ps<br>
-lib/image-qa.ps<br>
-lib/jispaper.ps<br>
-lib/lines.ps<br>
-lib/mkcidfm.ps<br>
-lib/pdf2dsc.ps<br>
-lib/pfbtopfa.ps<br>
-lib/ppath.ps<br>
-lib/pphs.ps<br>
-lib/prfont.ps<br>
-lib/ps2ai.ps<br>
-lib/ps2epsi.ps<br>
-lib/rollconv.ps<br>
-lib/stcinfo.ps<br>
-lib/stcolor.ps<br>
-lib/stocht.ps<br>
-lib/traceimg.ps<br>
-lib/traceop.ps<br>
-lib/uninfo.ps<br>
-lib/viewcmyk.ps<br>
-lib/viewgif.ps<br>
-lib/viewmiff.ps<br>
-lib/viewpbm.ps<br>
-lib/viewpcx.ps<br>
-lib/viewps2a.ps<br>
-lib/viewraw.ps<br>
-lib/viewrgb.ps<br>
-lib/winmaps.ps<br>
-lib/zeroline.ps<br>
-pcl/pcl/pcbiptrn.c<br>
-pcl/pcl/pcbiptrn.h<br>
-pcl/pcl/pccid.c<br>
-pcl/pcl/pccid.h<br>
-pcl/pcl/pccolor.c<br>
-pcl/pcl/pccoord.h<br>
-pcl/pcl/pccprint.c<br>
-pcl/pcl/pccsbase.c<br>
-pcl/pcl/pccsbase.h<br>
-pcl/pcl/pcdict.h<br>
-pcl/pcl/pcdither.c<br>
-pcl/pcl/pcdither.h<br>
-pcl/pcl/pcdraw.c<br>
-pcl/pcl/pcdraw.h<br>
-pcl/pcl/pcfont.c<br>
-pcl/pcl/pcfont.h<br>
-pcl/pcl/pcfontpg.c<br>
-pcl/pcl/pcfontst.h<br>
-pcl/pcl/pcfrgrnd.c<br>
-pcl/pcl/pcfrgrnd.h<br>
-pcl/pcl/pcfsel.c<br>
-pcl/pcl/pcfsel.h<br>
-pcl/pcl/pcht.c<br>
-pcl/pcl/pcht.h<br>
-pcl/pcl/pcident.c<br>
-pcl/pcl/pcident.h<br>
-pcl/pcl/pcimpl.c<br>
-pcl/pcl/pcindxed.c<br>
-pcl/pcl/pcindxed.h<br>
-pcl/pcl/pcjob.c<br>
-pcl/pcl/pcl.mak<br>
-pcl/pcl/pcl_top.mak<br>
-pcl/pcl/pclookup.c<br>
-pcl/pcl/pclookup.h<br>
-pcl/pcl/pcmacros.c<br>
-pcl/pcl/pcmisc.c<br>
-pcl/pcl/pcmtx3.c<br>
-pcl/pcl/pcmtx3.h<br>
-pcl/pcl/pcommand.c<br>
-pcl/pcl/pcommand.h<br>
-pcl/pcl/pcpage.c<br>
-pcl/pcl/pcpage.h<br>
-pcl/pcl/pcpalet.c<br>
-pcl/pcl/pcpalet.h<br>
-pcl/pcl/pcparam.h<br>
-pcl/pcl/pcparse.c<br>
-pcl/pcl/pcparse.h<br>
-pcl/pcl/pcpatrn.c<br>
-pcl/pcl/pcpatrn.h<br>
-pcl/pcl/pcpattyp.h<br>
-pcl/pcl/pcpatxfm.c<br>
-pcl/pcl/pcpatxfm.h<br>
-pcl/pcl/pcrect.c<br>
-pcl/pcl/pcsfont.c<br>
-pcl/pcl/pcstate.h<br>
-pcl/pcl/pcstatus.c<br>
-pcl/pcl/pcsymbol.c<br>
-pcl/pcl/pcsymbol.h<br>
-pcl/pcl/pctext.c<br>
-pcl/pcl/pctop.c<br>
-pcl/pcl/pctop.h<br>
-pcl/pcl/pctpm.h<br>
-pcl/pcl/pcuptrn.c<br>
-pcl/pcl/pcuptrn.h<br>
-pcl/pcl/pcursor.c<br>
-pcl/pcl/pcursor.h<br>
-pcl/pcl/pcwhtidx.c<br>
-pcl/pcl/pcwhtidx.h<br>
-pcl/pcl/pcxfmst.h<br>
-pcl/pcl/pgchar.c<br>
-pcl/pcl/pgcolor.c<br>
-pcl/pcl/pgconfig.c<br>
-pcl/pcl/pgdraw.c<br>
-pcl/pcl/pgdraw.h<br>
-pcl/pcl/pgfdata.c<br>
-pcl/pcl/pgfdata.h<br>
-pcl/pcl/pgfont.c<br>
-pcl/pcl/pgfont.h<br>
-pcl/pcl/pgframe.c<br>
-pcl/pcl/pggeom.c<br>
-pcl/pcl/pggeom.h<br>
-pcl/pcl/pginit.c<br>
-pcl/pcl/pginit.h<br>
-pcl/pcl/pglabel.c<br>
-pcl/pcl/pglfill.c<br>
-pcl/pcl/pgmand.h<br>
-pcl/pcl/pgmisc.c<br>
-pcl/pcl/pgmisc.h<br>
-pcl/pcl/pgparse.c<br>
-pcl/pcl/pgpoly.c<br>
-pcl/pcl/pgstate.h<br>
-pcl/pcl/pgvector.c<br>
-pcl/pcl/rtgmode.c<br>
-pcl/pcl/rtgmode.h<br>
-pcl/pcl/rtmisc.c<br>
-pcl/pcl/rtmisc.h<br>
-pcl/pcl/rtraster.c<br>
-pcl/pcl/rtraster.h<br>
-pcl/pcl/rtrstcmp.c<br>
-pcl/pcl/rtrstcmp.h<br>
-pcl/pcl/rtrstst.h<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/pjparse.h<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/pjtop.c<br>
-pcl/pl/pjtop.h<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plalloc.c<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plchar.c<br>
-pcl/pl/plchar.h<br>
-pcl/pl/pldebug.h<br>
-pcl/pl/pldict.c<br>
-pcl/pl/pldict.h<br>
-pcl/pl/pldraw.c<br>
-pcl/pl/pldraw.h<br>
-pcl/pl/plfapi.c<br>
-pcl/pl/plfapi.h<br>
-pcl/pl/plfont.c<br>
-pcl/pl/plfont.h<br>
-pcl/pl/plftable.c<br>
-pcl/pl/plftable.h<br>
-pcl/pl/plht.c<br>
-pcl/pl/plht.h<br>
-pcl/pl/plimpl.c<br>
-pcl/pl/pllfont.c<br>
-pcl/pl/pllfont.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pl/plparams.c<br>
-pcl/pl/plparams.h<br>
-pcl/pl/plparse.h<br>
-pcl/pl/plromfs.mak<br>
-pcl/pl/plsymbol.c<br>
-pcl/pl/plsymbol.h<br>
-pcl/pl/pltop.c<br>
-pcl/pl/pltop.h<br>
-pcl/pl/pluchar.c<br>
-pcl/pl/plufont.c<br>
-pcl/pl/plufstlp.c<br>
-pcl/pl/plufstlp.h<br>
-pcl/pl/plufstlp1.c<br>
-pcl/pl/plulfont.c<br>
-pcl/pl/plvalue.c<br>
-pcl/pl/plvalue.h<br>
-pcl/pl/plvocab.c<br>
-pcl/pl/plvocab.h<br>
-pcl/pl/plwimg.c<br>
-pcl/pl/plwimg.h<br>
-pcl/pl/plwmainc.c<br>
-pcl/pl/plwreg.c<br>
-pcl/pl/plwreg.h<br>
-pcl/pl/plwres.h<br>
-pcl/pl/realmain.c<br>
-pcl/pxl/pxasm.ps<br>
-pcl/pxl/pxattr.h<br>
-pcl/pxl/pxbfont.c<br>
-pcl/pxl/pxbfont.h<br>
-pcl/pxl/pxbfont.ps<br>
-pcl/pxl/pxcet.txt<br>
-pcl/pxl/pxdict.h<br>
-pcl/pxl/pxdiff.txt<br>
-pcl/pxl/pxenum.h<br>
-pcl/pxl/pxerrors.c<br>
-pcl/pxl/pxerrors.h<br>
-pcl/pxl/pxffont.c<br>
-pcl/pxl/pxfont.c<br>
-pcl/pxl/pxfont.h<br>
-pcl/pxl/pxfts.txt<br>
-pcl/pxl/pxgstate.c<br>
-pcl/pxl/pxgstate.h<br>
-pcl/pxl/pximage.c<br>
-pcl/pxl/pximpl.c<br>
-pcl/pxl/pxink.c<br>
-pcl/pxl/pxl.mak<br>
-pcl/pxl/pxlib.txt<br>
-pcl/pxl/pxoper.h<br>
-pcl/pxl/pxpaint.c<br>
-pcl/pxl/pxparse.c<br>
-pcl/pxl/pxparse.h<br>
-pcl/pxl/pxptable.c<br>
-pcl/pxl/pxptable.h<br>
-pcl/pxl/pxpthr.c<br>
-pcl/pxl/pxpthr.h<br>
-pcl/pxl/pxsessio.c<br>
-pcl/pxl/pxspec.txt<br>
-pcl/pxl/pxstate.c<br>
-pcl/pxl/pxstate.h<br>
-pcl/pxl/pxstream.c<br>
-pcl/pxl/pxsymbol.ps<br>
-pcl/pxl/pxsymbol.psc<br>
-pcl/pxl/pxsymbol.psh<br>
-pcl/pxl/pxtag.h<br>
-pcl/pxl/pxtop.c<br>
-pcl/pxl/pxvalue.c<br>
-pcl/pxl/pxvalue.h<br>
-pcl/tools/pxlasm.py<br>
-pcl/tools/pxldis.py<br>
-pcl/tools/suite.tcl<br>
-psi/bfont.h<br>
-psi/btoken.h<br>
-psi/dmmain.c<br>
-psi/dmmain.r<br>
-psi/dpmain.c<br>
-psi/dscparse.c<br>
-psi/dscparse.h<br>
-psi/dstack.h<br>
-psi/dwdll.c<br>
-psi/dwdll.h<br>
-psi/dwimg.c<br>
-psi/dwimg.h<br>
-psi/dwmain.c<br>
-psi/dwmain.rc<br>
-psi/dwmainc.c<br>
-psi/dwnodll.c<br>
-psi/dwreg.c<br>
-psi/dwreg.h<br>
-psi/dwres.h<br>
-psi/dwtext.c<br>
-psi/dwtext.h<br>
-psi/dwtrace.c<br>
-psi/dwtrace.h<br>
-psi/dxmain.c<br>
-psi/dxmainc.c<br>
-psi/estack.h<br>
-psi/files.h<br>
-psi/ghost.h<br>
-psi/gs.c<br>
-psi/gsdll.c<br>
-psi/gsdll2.rc<br>
-psi/gsdll32.rc<br>
-psi/gserver.c<br>
-psi/gsos2.rc<br>
-psi/ialloc.c<br>
-psi/ialloc.h<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-psi/iastate.h<br>
-psi/iastruct.h<br>
-psi/ibnum.c<br>
-psi/ibnum.h<br>
-psi/ichar.h<br>
-psi/ichar1.h<br>
-psi/icharout.h<br>
-psi/icid.h<br>
-psi/icie.h<br>
-psi/icolor.h<br>
-psi/iconf.c<br>
-psi/iconf.h<br>
-psi/icontext.c<br>
-psi/icontext.h<br>
-psi/icremap.h<br>
-psi/icsmap.h<br>
-psi/icstate.h<br>
-psi/iddict.h<br>
-psi/iddstack.h<br>
-psi/idebug.c<br>
-psi/idebug.h<br>
-psi/idict.c<br>
-psi/idict.h<br>
-psi/idictdef.h<br>
-psi/idicttpl.h<br>
-psi/idisp.c<br>
-psi/idisp.h<br>
-psi/idosave.h<br>
-psi/idparam.c<br>
-psi/idparam.h<br>
-psi/idsdata.h<br>
-psi/idstack.c<br>
-psi/idstack.h<br>
-psi/ierrors.h<br>
-psi/iesdata.h<br>
-psi/iestack.h<br>
-psi/ifapi.h<br>
-psi/ifcid.h<br>
-psi/ifilter.h<br>
-psi/ifilter2.h<br>
-psi/ifont.h<br>
-psi/ifont1.h<br>
-psi/ifont2.h<br>
-psi/ifont42.h<br>
-psi/ifrpred.h<br>
-psi/ifunc.h<br>
-psi/ifwpred.h<br>
-psi/igc.c<br>
-psi/igc.h<br>
-psi/igcref.c<br>
-psi/igcstr.c<br>
-psi/igcstr.h<br>
-psi/igstate.h<br>
-psi/iht.h<br>
-psi/iimage.h<br>
-psi/iinit.c<br>
-psi/iinit.h<br>
-psi/ilevel.h<br>
-psi/ilocate.c<br>
-psi/imain.c<br>
-psi/imain.h<br>
-psi/imainarg.c<br>
-psi/imainarg.h<br>
-psi/imemory.h<br>
-psi/iminst.h<br>
-psi/iname.c<br>
-psi/iname.h<br>
-psi/inamedef.h<br>
-psi/inameidx.h<br>
-psi/inames.h<br>
-psi/inamestr.h<br>
-psi/inobtokn.c<br>
-psi/inouparm.c<br>
-psi/int.mak<br>
-psi/interp.c<br>
-psi/interp.h<br>
-psi/iosdata.h<br>
-psi/iostack.h<br>
-psi/ipacked.h<br>
-psi/iparam.c<br>
-psi/iparam.h<br>
-psi/iparray.h<br>
-psi/ipcolor.h<br>
-psi/iplugin.c<br>
-psi/iplugin.h<br>
-psi/ireclaim.c<br>
-psi/iref.h<br>
-psi/isave.c<br>
-psi/isave.h<br>
-psi/iscan.c<br>
-psi/iscan.h<br>
-psi/iscanbin.c<br>
-psi/iscanbin.h<br>
-psi/iscannum.c<br>
-psi/iscannum.h<br>
-psi/isdata.h<br>
-psi/isstate.h<br>
-psi/istack.c<br>
-psi/istack.h<br>
-psi/istkparm.h<br>
-psi/istream.h<br>
-psi/istruct.h<br>
-psi/itoken.h<br>
-psi/iutil.c<br>
-psi/iutil.h<br>
-psi/iutil2.c<br>
-psi/iutil2.h<br>
-psi/ivmem2.h<br>
-psi/ivmspace.h<br>
-psi/main.h<br>
-psi/mkfilelt.cpp<br>
-psi/msvc.mak<br>
-psi/msvc32.mak<br>
-psi/msvc64.mak<br>
-psi/nsisinst.nsi<br>
-psi/oparc.h<br>
-psi/opcheck.h<br>
-psi/opdef.h<br>
-psi/oper.h<br>
-psi/opextern.h<br>
-psi/os2.mak<br>
-psi/ostack.h<br>
-psi/psapi.c<br>
-psi/psapi.h<br>
-psi/psromfs.mak<br>
-psi/store.h<br>
-psi/winint.mak<br>
-psi/zalg.c<br>
-psi/zarith.c<br>
-psi/zarray.c<br>
-psi/zbfont.c<br>
-psi/zbseq.c<br>
-psi/zcfont.c<br>
-psi/zchar.c<br>
-psi/zchar1.c<br>
-psi/zchar2.c<br>
-psi/zchar32.c<br>
-psi/zchar42.c<br>
-psi/zchar42.h<br>
-psi/zcharout.c<br>
-psi/zcharx.c<br>
-psi/zcid.c<br>
-psi/zcie.c<br>
-psi/zcie.h<br>
-psi/zcolor.c<br>
-psi/zcolor.h<br>
-psi/zcolor1.c<br>
-psi/zcolor2.c<br>
-psi/zcolor3.c<br>
-psi/zcontrol.c<br>
-psi/zcrd.c<br>
-psi/zcsindex.c<br>
-psi/zcspixel.c<br>
-psi/zcssepr.c<br>
-psi/zdevcal.c<br>
-psi/zdevice.c<br>
-psi/zdevice2.c<br>
-psi/zdfilter.c<br>
-psi/zdict.c<br>
-psi/zdouble.c<br>
-psi/zdps1.c<br>
-psi/zdscpars.c<br>
-psi/zfaes.c<br>
-psi/zfapi.c<br>
-psi/zfarc4.c<br>
-psi/zfbcp.c<br>
-psi/zfcid.c<br>
-psi/zfcid0.c<br>
-psi/zfcid1.c<br>
-psi/zfcmap.c<br>
-psi/zfdctd.c<br>
-psi/zfdcte.c<br>
-psi/zfdecode.c<br>
-psi/zfile.c<br>
-psi/zfile.h<br>
-psi/zfile1.c<br>
-psi/zfileio.c<br>
-psi/zfilter.c<br>
-psi/zfilter2.c<br>
-psi/zfimscale.c<br>
-psi/zfjbig2.c<br>
-psi/zfjpx.c<br>
-psi/zfmd5.c<br>
-psi/zfont.c<br>
-psi/zfont0.c<br>
-psi/zfont1.c<br>
-psi/zfont2.c<br>
-psi/zfont32.c<br>
-psi/zfont42.c<br>
-psi/zfontenum.c<br>
-psi/zform.c<br>
-psi/zfproc.c<br>
-psi/zfrsd.c<br>
-psi/zfrsd.h<br>
-psi/zfsample.c<br>
-psi/zfsha2.c<br>
-psi/zfunc.c<br>
-psi/zfunc.h<br>
-psi/zfunc0.c<br>
-psi/zfunc3.c<br>
-psi/zfunc4.c<br>
-psi/zfzlib.c<br>
-psi/zgeneric.c<br>
-psi/zgstate.c<br>
-psi/zht.c<br>
-psi/zht1.c<br>
-psi/zht2.c<br>
-psi/zht2.h<br>
-psi/zicc.c<br>
-psi/zicc.h<br>
-psi/zimage.c<br>
-psi/zimage3.c<br>
-psi/ziodev.c<br>
-psi/ziodev2.c<br>
-psi/ziodevsc.c<br>
-psi/zmath.c<br>
-psi/zmatrix.c<br>
-psi/zmedia2.c<br>
-psi/zmisc.c<br>
-psi/zmisc1.c<br>
-psi/zmisc2.c<br>
-psi/zmisc3.c<br>
-psi/zncdummy.c<br>
-psi/zpacked.c<br>
-psi/zpaint.c<br>
-psi/zpath.c<br>
-psi/zpath1.c<br>
-psi/zpcolor.c<br>
-psi/zpdf_r6.c<br>
-psi/zpdfops.c<br>
-psi/zrelbit.c<br>
-psi/zshade.c<br>
-psi/zstack.c<br>
-psi/zstring.c<br>
-psi/zsysvm.c<br>
-psi/ztoken.c<br>
-psi/ztrans.c<br>
-psi/ztrap.c<br>
-psi/ztype.c<br>
-psi/zupath.c<br>
-psi/zusparam.c<br>
-psi/zutf8.c<br>
-psi/zvmem.c<br>
-psi/zvmem2.c<br>
-psi/zwinutf8.c<br>
-toolbin/GenSubstCID.ps<br>
-toolbin/afmutil.py<br>
-toolbin/color/icc_creator/ICC_Creator/CIELAB.h<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_Creator.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_Creator.h<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.h<br>
-toolbin/color/icc_creator/ICC_Creator/icc_create.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/icc_create.h<br>
-toolbin/color/icc_creator/README.txt<br>
-toolbin/encs2c.ps<br>
-toolbin/errlist.tcl<br>
-toolbin/extractFonts.ps<br>
-toolbin/extractICCprofiles.ps<br>
-toolbin/gen_ldf_jb2.py<br>
-toolbin/genfontmap.ps<br>
-toolbin/gitlog2changelog.py<br>
-toolbin/gsmake.tcl<br>
-toolbin/halftone/gen_ordered/gen_ordered_main.c<br>
-toolbin/halftone/gen_stochastic/gen_stochastic.c<br>
-toolbin/headers.tcl<br>
-toolbin/jpxtopdf.c<br>
-toolbin/leaks.tcl<br>
-toolbin/makehist.tcl<br>
-toolbin/memory.py<br>
-toolbin/ocheck.py<br>
-toolbin/pdf_info.ps<br>
-toolbin/pre.tcl<br>
-toolbin/precheck.tcl<br>
-toolbin/split_changelog.py<br>
-toolbin/suite.tcl<br>
-toolbin/tests/build_revision.py<br>
-toolbin/tests/check_all.py<br>
-toolbin/tests/check_comments.py<br>
-toolbin/tests/check_dirs.py<br>
-toolbin/tests/check_docrefs.py<br>
-toolbin/tests/cmpi.py<br>
-toolbin/tests/compare_checksumdb.py<br>
-toolbin/tests/compare_checksums.py<br>
-toolbin/tests/dump_checksum.py<br>
-toolbin/tests/dump_checksum_plus.py<br>
-toolbin/tests/dump_checksum_raw.py<br>
-toolbin/tests/get_baseline_log.py<br>
-toolbin/tests/get_baselines.py<br>
-toolbin/tests/gscheck_all.py<br>
-toolbin/tests/gscheck_fuzzypdf.py<br>
-toolbin/tests/gscheck_pdfwrite.py<br>
-toolbin/tests/gscheck_raster.py<br>
-toolbin/tests/gscheck_testfiles.py<br>
-toolbin/tests/gsconf.py<br>
-toolbin/tests/gsparamsets.py<br>
-toolbin/tests/gssum.py<br>
-toolbin/tests/gstestgs.py<br>
-toolbin/tests/gstestutils.py<br>
-toolbin/tests/gsutil.py<br>
-toolbin/tests/make_baselinedb.py<br>
-toolbin/tests/make_testdb.py<br>
-toolbin/tests/make_two_pdfversions<br>
-toolbin/tests/make_two_versions<br>
-toolbin/tests/myoptparse.py<br>
-toolbin/tests/rasterdb.py<br>
-toolbin/tests/revert_baseline<br>
-toolbin/tests/revert_pdfbaseline<br>
-toolbin/tests/run_nightly.py<br>
-toolbin/tests/run_parallel<br>
-toolbin/tests/run_regression.py<br>
-toolbin/tests/testdiff.py<br>
-toolbin/tests/update_baseline.py<br>
-toolbin/tests/update_specific<br>
-toolbin/tmake.tcl<br>
-xps/ghostxps.h<br>
-xps/xps.mak<br>
-xps/xpsanalyze.c<br>
-xps/xpscff.c<br>
-xps/xpscolor.c<br>
-xps/xpscommon.c<br>
-xps/xpscrc.c<br>
-xps/xpsdoc.c<br>
-xps/xpsfapi.c<br>
-xps/xpsfapi.h<br>
-xps/xpsfont.c<br>
-xps/xpsglyphs.c<br>
-xps/xpsgradient.c<br>
-xps/xpshash.c<br>
-xps/xpsimage.c<br>
-xps/xpsjpeg.c<br>
-xps/xpsjxr.c<br>
-xps/xpsmem.c<br>
-xps/xpsopacity.c<br>
-xps/xpspage.c<br>
-xps/xpspath.c<br>
-xps/xpspng.c<br>
-xps/xpsresource.c<br>
-xps/xpsromfs.mak<br>
-xps/xpstiff.c<br>
-xps/xpstile.c<br>
-xps/xpstop.c<br>
-xps/xpsttf.c<br>
-xps/xpsutf.c<br>
-xps/xpsvisual.c<br>
-xps/xpsxml.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-16 08:08:28 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=373d83836619fe8b675b3db7235e4fee19b699fd">373d83836619fe8b675b3db7235e4fee19b699fd</a>
-<blockquote>
-<p>
- Fixed typo and cleaned up usage of //systemdict vs systemdict<br>
-<br>
- Typo was misspelling of /.PDF_UNDEF_OPLIST<br>
-<br>
- Cleaned this up to just use //systemdict and .forceundef because the<br>
- mix of uses was confusing.<br>
-<br>
- Took out 'executeonly' because it's not needed (though harmless). This<br>
- procedure will have already been undef'd by the time the user gets access<br>
- to the interpreter.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-15 15:30:46 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9cae141e4654124379dc4738bbea4b5b6e13d37b">9cae141e4654124379dc4738bbea4b5b6e13d37b</a>
-<blockquote>
-<p>
- Added array .PDF_UNDEF_OPLIST to pdf_main.ps instead of maintaining twice<br>
-<br>
- Used to maintain two different lists of operators in gs_init.ps and pdf_main.ps<br>
- for undef'ing operators that are used by pdf, in two cases of DELAYBIND or<br>
- not DELAYBIND.<br>
-<br>
- This change defines the array in pdf_main.ps and just references it in<br>
- gs_init.ps.<br>
-<br>
- Also added a couple operators to the pdf_main.ps list that had gotten<br>
- out of sync with the gs_init.ps one (which is why we really need just one<br>
- list...)<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-16 14:10: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=5fac4ab4815b3bd86d471389357cdc7cc184f65c">5fac4ab4815b3bd86d471389357cdc7cc184f65c</a>
-<blockquote>
-<p>
- Update the copyright year (2019) in the documentation<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/gdevds32.c<br>
-doc/sample_downscale_device.htm<br>
-doc/subclass.htm<br>
-doc/thirdparty.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-16 05:12:54 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=03a1e5eaf83896053fa32f68d328ff48f86d906f">03a1e5eaf83896053fa32f68d328ff48f86d906f</a>
-<blockquote>
-<p>
- Valgrind fixes.<br>
-<br>
- Firstly, move entirely to HAVE_VALGRIND rather than ENABLE_VALGRIND.<br>
- My fault for having introduced 2 schemes to do the same thing in<br>
- the past.<br>
-<br>
- Accordingly, move direct inclusions of memcheck/valgrind.h over to<br>
- calling our local valgrind.h header.<br>
-<br>
- And finally, fix the problem that prompted all of this; in<br>
- image_simple_expand, we take 1 bit data in. The last bytes in this<br>
- data can frequently be only semi-filled, resulting in some<br>
- undefined bits. While our code to quickly skip complete bytes is<br>
- safe by construction, valgrind cannot recognise it as such, and so<br>
- signals false positive UMRs.<br>
-<br>
- Work around that here by tweaking valgrinds ideas of what bits<br>
- are defined.<br>
-<br>
-base/gsinit.c<br>
-base/gxclfile.c<br>
-base/gxclist.c<br>
-base/gxclmem.c<br>
-base/gxclutil.c<br>
-base/gxifast.c<br>
-base/valgrind.h<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-14 12:41:25 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5ecd380a5af595f5e843352df88a6957b1accda">b5ecd380a5af595f5e843352df88a6957b1accda</a>
-<blockquote>
-<p>
- New valgrind makefile targets and clist tweak.<br>
-<br>
- We introduce 2 new families of targets to the makefile.<br>
-<br>
- 1) vg, gsvg, gpcl6vg, gxpsvg, gpdlvg<br>
- 2) debugvg, gsdebugvg, gpcl6debugvg, gxpsdebugvg, gpdldebugvg<br>
-<br>
- Those build release and debug versions of the executables, tweaked<br>
- to work better with valgrind. These mirror the existing *mementovg<br>
- targets that were introduced a while ago.<br>
-<br>
- 2 extra tweaks are introduced here too.<br>
-<br>
- Firstly, *for these targets*, we default to using memory for<br>
- bandlist storage. This should cut down on the number of false<br>
- positives we get when using the clist as uninitialised padding<br>
- bytes will not be flagged up as they are written to the clist<br>
- file. (Instead, they will only be flagged up if they are actually<br>
- used during clist playback).<br>
-<br>
- Secondly, whenever we write out a clist block and reset the buffer,<br>
- we reset the buffer to &quot;undefined&quot; state so that valgrind can give<br>
- us useful information again.<br>
-<br>
-base/gxclutil.c<br>
-base/unix-end.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-17 00:22: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=53faf466e769bd380a14370aa38562b942e783c2">53faf466e769bd380a14370aa38562b942e783c2</a>
-<blockquote>
-<p>
- Add clist valgrind helper call.<br>
-<br>
-base/gxcldev.h<br>
-base/gxclimag.c<br>
-base/gxclpath.c<br>
-base/gxclutil.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-14 11:34:09 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1f5d4a1ce74ea841102a7c77e29c68e9b7a032c2">1f5d4a1ce74ea841102a7c77e29c68e9b7a032c2</a>
-<blockquote>
-<p>
- Improve -Z: output messages at startup.<br>
-<br>
- The &quot;Init done&quot; messages given by -Z: were misleading.<br>
-<br>
- Here, we simplify the process a bit. We move the init messages<br>
- (other than the dumping of the args used) out of -Z: and into<br>
- --debug=init-details.<br>
-<br>
- The 3 different init messages are now explicitly done around<br>
- each of the 3 phases, rather than in the code that calls<br>
- those 3 phases. This makes it far clearer, as the phases can<br>
- be called from many different places depending on the exact<br>
- command line in use.<br>
-<br>
- The only downside to this is that only the final phase shows up<br>
- in normal use, as the parsing of --debug=init_details doesn't<br>
- happen until after after the first 2 phases of init have taken<br>
- place. This is no worse than the current code, so we'll take this<br>
- for now, and update it later (maybe by prescanning the arg list)<br>
- if it's ever an issue later on.<br>
-<br>
-base/gdbflags.h<br>
-psi/imain.c<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-11 19:24:47 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=41810035925a2dd419354e8ca918f425603e5cb4">41810035925a2dd419354e8ca918f425603e5cb4</a>
-<blockquote>
-<p>
- Bug 700482: Binary Object scanner could write past allocated ref array<br>
-<br>
- The object length (osize) was used to compute the max_array_index, but<br>
- this exceeded the number of refs allocated based on the overall length<br>
- given in the BOS header. We only allocated overall_length/8 but the bad<br>
- object length value (in this case for a dict, but could be an array)<br>
- was larger so we ended up with a max_array_index that was too large.<br>
-<br>
-psi/iscanbin.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-10 13:48:37 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=deaae0d435112e2fdd9f3f7d1e8eee6e207758f1">deaae0d435112e2fdd9f3f7d1e8eee6e207758f1</a>
-<blockquote>
-<p>
- Squash a warning in XPS interpreter.<br>
-<br>
-xps/ghostxps.h<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-10 13:44:13 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6236f942b0601772221a910e006c9fa865b4568e">6236f942b0601772221a910e006c9fa865b4568e</a>
-<blockquote>
-<p>
- gpdl: Tweak stdin operation to respect gsapi set stdio functions.<br>
-<br>
- Now that gpdl lives entirely under the gsapi API, it should<br>
- respect all that API. That means that as people can define<br>
- callbacks to be used for stdin/stdout/stderr, we should use<br>
- those callbacks if they are set and the program is told to<br>
- read from stdin.<br>
-<br>
- Sadly, the only stdin stream implementation we have that supports<br>
- this mechanism is the one in the postscript interpreter rather<br>
- than the one in the general library, so we can't rely on it being<br>
- there (and even if we could, it assumes the presence of an<br>
- active PS interpreter instance).<br>
-<br>
- We therefore lift this code out and simplify it to give us a<br>
- &quot;callback capable&quot; stdin stream that will be present in all our<br>
- builds. This is NOT available using the standard iodev mechanism<br>
- so no changes in behaviour can happen for existing programs.<br>
-<br>
-base/lib.mak<br>
-base/strmio.c<br>
-base/strmio.h<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-10 21:18:08 +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=4e71598a97bce38f3ba384c055d6ffb852f045fd">4e71598a97bce38f3ba384c055d6ffb852f045fd</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV when no graphic state is saved.<br>
-<br>
- Prevent SEGV if memory allocation fails leading to pgs-&gt;saved being NULL.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=351 ./membin/gpcl6 -sDEVICE=pbmraw -dMaxBitmap=2000 -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0270<br>
-<br>
-base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-10 12:19:10 -0500
-</strong>
-<br>Steve Phillips &lt;steve.phillips@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2ae1181b33be65478db844e3a330cf31f8dee273">2ae1181b33be65478db844e3a330cf31f8dee273</a>
-<blockquote>
-<p>
- Fix for bug 700042 -- Sanitize out-of-bounds read with fuzzed PDF file.<br>
-<br>
- The test file for this bug was fuzzed in such a way as to generate<br>
- Lattice-Form Gouraud shadings with extremely large X coordinates.<br>
- This exposed a bug in the code which performs recursive triangle<br>
- subdivision. A color cache entry is not the same size as a<br>
- patch_color_t so can't be copied directly.<br>
-<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-11 14:25:29 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=24281b198d446da47441b132aba2aa09a5c27ba5">24281b198d446da47441b132aba2aa09a5c27ba5</a>
-<blockquote>
-<p>
- Bug 697630: Check ZIP entry sizes for integer overflow.<br>
-<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-09 17:55: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=1698937968690ca1ff99e50ae8c1c044718505b8">1698937968690ca1ff99e50ae8c1c044718505b8</a>
-<blockquote>
-<p>
- Fix stdin operation for gpdl/gpcl etc.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-09 17:14:13 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5b41d5347c1cde4847d8d631aa20e00a6cdb5728">5b41d5347c1cde4847d8d631aa20e00a6cdb5728</a>
-<blockquote>
-<p>
- Rename xps language implementation points.<br>
-<br>
- use _impl_ instead of _imp_ to be consistent with the others.<br>
-<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-08 18:49:38 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0b89bbaf583441e84804201d2e74169b9c7be5de">0b89bbaf583441e84804201d2e74169b9c7be5de</a>
-<blockquote>
-<p>
- gpdl: Add -c operation to gpdl.<br>
-<br>
- We gather up all the commands specified by -c and pass them into<br>
- the language as a 'prefix' command, to be run just after we have<br>
- inited the job. This means they run inside the encapsulation.<br>
-<br>
- The only language that supports prefix commands is postscript,<br>
- hence only postscript commands can be used. This is what we want.<br>
-<br>
-gpdl/psi/psitop.c<br>
-pcl/pcl/pctop.c<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/pltop.c<br>
-pcl/pl/pltop.h<br>
-pcl/pxl/pxtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-09 17:19:22 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=51196c3b88bf5a865e03907c90ac891ab857f021">51196c3b88bf5a865e03907c90ac891ab857f021</a>
-<blockquote>
-<p>
- Squash a type warning.<br>
-<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-08 16:35: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=cb07f9786acc2faa85b1f3cce89339b65f99c310">cb07f9786acc2faa85b1f3cce89339b65f99c310</a>
-<blockquote>
-<p>
- Bug 700460: Fix Freetype Type1 path segment closepath<br>
-<br>
- * src/psaux/psintrp.c: correctly close a contour<br>
-<br>
- All of the Type 1 path building is done with code common to the revised<br>
- CFF engine, with the exception of closepath, which was still calling<br>
- ps_builder_close_contour(), thus previously cached segments were not<br>
- always written to the path, and glyph corruption, or even invalid outlines<br>
- were possible.<br>
-<br>
- Switch to calling cf2_glyphpath_closeOpenPath()<br>
-<br>
- Committed upstream:<br>
- http://git.savannah.gnu.org/cgit/freetype/freetype2.git/commit/?id=b75abeb5e6561024d182ccdc0eb36a7d2630310e<br>
-<br>
-freetype/src/psaux/psintrp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-08 14:03:28 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fc8c8630f929cbbe1df01fdc3186f25193b31f75">fc8c8630f929cbbe1df01fdc3186f25193b31f75</a>
-<blockquote>
-<p>
- Undefine internal .presentspecial dictionary<br>
-<br>
- This dictionary contains a bunch of procedures that will no longer be exposed.<br>
-<br>
-Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-08 11:53:33 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=71af04a00d1970be001d043480c07bd336453a73">71af04a00d1970be001d043480c07bd336453a73</a>
-<blockquote>
-<p>
- Rearrange code in gs_setpd.ps so things are defined before used.<br>
-<br>
- This is in preparation for undef'ing .presentspecial dictionary.<br>
- I tried to keep the related code together, and I hope I moved the<br>
- right comments with the code...<br>
-<br>
-Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-08 20:05:11 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=06e9bde4dce776a3afa365bc65b1a1278462c865">06e9bde4dce776a3afa365bc65b1a1278462c865</a>
-<blockquote>
-<p>
- Fix Memento squeezing - gs_lib_ctx was using a monitor.<br>
-<br>
- Monitors don't play nice with memento squeezing, so nobble the<br>
- code.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-08 08:37:55 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cae9c43ecc8eb804022d947f65d60358a7e6094a">cae9c43ecc8eb804022d947f65d60358a7e6094a</a>
-<blockquote>
-<p>
- Rewrite some code to be able to undef internal .setpagesize<br>
-<br>
- /.setpagesize is used internally by gs_statd.ps, but it was written<br>
- to pull the current implementation out of statusdict, so it could use<br>
- either a level 2-compatible version that called setpagedevice, or a level 1<br>
- version that didn't call setpagedevice.<br>
-<br>
- Since we don't support level 1 postscript anymore, we should always have<br>
- setpagedevice, so this can be cleaned up.<br>
-<br>
- Now /.setpagesize is just an internal convenience function that we undef<br>
- within gs_statd.ps.<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_statd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-07 20:03:02 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6b9a0722a5e4c8083a59fd3ba22b1b572ec7fcd6">6b9a0722a5e4c8083a59fd3ba22b1b572ec7fcd6</a>
-<blockquote>
-<p>
- Bug 691732 Add support for e-sRGB and ROMMRGB color spaces<br>
-<br>
- JPX images can have an enumerated color space that indicates<br>
- e-sRGB or ROMMRGB.<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_res.ps<br>
-Resource/Init/pdf_draw.ps<br>
-base/gsicc_manage.h<br>
-iccprofiles/esrgb.icc<br>
-iccprofiles/rommrgb.icc<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-19 15:03:27 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c75bd64e30d8ff890cd6495e748b30a4b0dacd32">c75bd64e30d8ff890cd6495e748b30a4b0dacd32</a>
-<blockquote>
-<p>
- Bug 699180: Transparency BBox for stroke needs the expanded path.<br>
-<br>
- The simplified test case has an unusually wide line, but since the path<br>
- is pure horizontal, pathbbox returns the same coordinate for Ymin and Ymax.<br>
- Instead, when painting strokes, use &quot;strokepath pathbbox&quot; to get the actual<br>
- area painted (taking width and miter extensions into account).<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-23 13:02:22 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=10a630656fadb160ec3e01b934adac3e1ca600f9">10a630656fadb160ec3e01b934adac3e1ca600f9</a>
-<blockquote>
-<p>
- Bug 700359: Uniprint device did not set color_info.polarity needed by pdf14<br>
-<br>
- The pdf14 device assumes that if the polarity is ADDITIVE, the colorspace<br>
- must be Gray or RGB. The uniprint device did not set the polarity when the<br>
- colorspace was changed to CMYK, so the number of components set in the pdf14<br>
- compositor was 3, even though the ICC profile for the device expects 4 as<br>
- num_components in. This caused a mismatch when reading the clist because<br>
- it expected 4 components and only 3 were written. Note that the RGBW, RGBOV,<br>
- and RGBNOV modes will probably still fail, but unti we see a case for a device<br>
- needing these unusual modes, just leave it as it has been for many years.<br>
-<br>
- Note that other devices with strange colorspaces, such as RGBA may also<br>
- trip over this.<br>
-<br>
-devices/gdevupd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-26 13:12:39 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=905d1bf02db12aca93a732dbe5956993e19d2443">905d1bf02db12aca93a732dbe5956993e19d2443</a>
-<blockquote>
-<p>
- Bug 699688: Saving pointer into arg_list string invalid (next arg overwrites)<br>
-<br>
- The 'saved_pages_inital_arg' cannot be a pointer into the argument buffer<br>
- (arg_list.cstr) since later long arguments can overwrite past the pointer<br>
- saved (12 characters into the buffer). Instead allocate a buffer for the<br>
- argument and copy the argument into it.<br>
-<br>
- Thanks to Peter Cherepanov for the analysis and part of the fix.<br>
-<br>
-psi/imain.c<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-09 23:04:42 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=02fd67bce5cd981282594b1458c4459613559d1b">02fd67bce5cd981282594b1458c4459613559d1b</a>
-<blockquote>
-<p>
- Remove overprint_mode_alt (overprint mode is the same for stroke and fill)<br>
-<br>
- Also remove effective_overprint_mode_alt.<br>
-<br>
-base/gsstate.c<br>
-base/gxgstate.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-07-09 12:05:56 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0c89f7d14ffdaa3080d996d7502a77f3db949381">0c89f7d14ffdaa3080d996d7502a77f3db949381</a>
-<blockquote>
-<p>
- Fix for bug 692652: Prevent derefence of NULL if parsed.iodev == NULL<br>
-<br>
- Robin's suggestion seems reasonable to me.<br>
-<br>
-base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-17 11:18:07 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e91b67894a28c518b34e0daf75d79715c4aa16e4">e91b67894a28c518b34e0daf75d79715c4aa16e4</a>
-<blockquote>
-<p>
- Remove some blah_DEFINED cruft.<br>
-<br>
- Now we properly &quot;include what we use&quot; let's sanitise the horrid<br>
- blah_DEFINED ifdeffery (i.e. kill it where possible).<br>
-<br>
- Also, we update the .c dependencies in the base/psi makefiles to<br>
- be correct.<br>
-<br>
- Unfortunately, this new correct set of dependencies causes nmake<br>
- to soil itself and die with an out of memory error. After much<br>
- experimentation, I've come to the conclusion that this is because<br>
- it copes poorly with given the same file as a dependency multiple<br>
- times.<br>
-<br>
- Sadly, our style of declaring dependencies in the following style:<br>
-<br>
- foo_h=$(BLAH)/foo.h $(std_h)<br>
- bar_h=$(BLAH)/bar.h $(foo_h) $(std_h)<br>
- baz_h=$(BLAH)/baz.h $(foo_h) $(std_h)<br>
-<br>
- means that a .obj file that depends on $(foo_h) $(bar_h) and $(baz_h)<br>
- ends up depending on foo.h twice, and std.h three times.<br>
-<br>
- I have therefore changed the style of dependencies used to be more<br>
- standard.<br>
-<br>
- We still define:<br>
-<br>
- foo_h=$(BLAH)/foo.h<br>
-<br>
- so each .obj file rule can depend on $(foo_h) etc as required, but the<br>
- dependencies between each .h file are expressed in normal rules at the<br>
- end of the file in a dedicated &quot;# Dependencies&quot; section that we can now<br>
- autogenerate.<br>
-<br>
-base/gdevdevn.c<br>
-base/gdevdevn.h<br>
-base/gdevmrop.h<br>
-base/gdevp14.h<br>
-base/gdevprn.h<br>
-base/gp.h<br>
-base/gsalloc.h<br>
-base/gsccolor.h<br>
-base/gscdevn.h<br>
-base/gschar.h<br>
-base/gscicach.h<br>
-base/gscie.h<br>
-base/gscms.h<br>
-base/gscolor2.h<br>
-base/gscolor3.h<br>
-base/gscrdp.h<br>
-base/gscsepr.h<br>
-base/gscspace.h<br>
-base/gsdcolor.h<br>
-base/gsdevice.h<br>
-base/gsdsrc.h<br>
-base/gsfcmap.h<br>
-base/gsfname.h<br>
-base/gsfont.h<br>
-base/gsfunc.h<br>
-base/gsgc.h<br>
-base/gsgcache.h<br>
-base/gsgdata.h<br>
-base/gsgstate.h<br>
-base/gsht1.h<br>
-base/gsicc_cache.h<br>
-base/gsicc_cms.h<br>
-base/gsimage.h<br>
-base/gsiparam.h<br>
-base/gslibctx.h<br>
-base/gsmatrix.h<br>
-base/gsmemory.h<br>
-base/gsmemraw.h<br>
-base/gsnamecl.h<br>
-base/gsovrc.h<br>
-base/gsparam.h<br>
-base/gspath.h<br>
-base/gspcolor.h<br>
-base/gsptype1.h<br>
-base/gsptype2.h<br>
-base/gsshade.h<br>
-base/gsstate.h<br>
-base/gsstruct.h<br>
-base/gstext.h<br>
-base/gstparam.h<br>
-base/gstrans.h<br>
-base/gstrap.h<br>
-base/gstype1.h<br>
-base/gsuid.h<br>
-base/gxalloc.h<br>
-base/gxblend.h<br>
-base/gxcdevn.h<br>
-base/gxchar.h<br>
-base/gxcid.h<br>
-base/gxclfile.c<br>
-base/gxclipsr.h<br>
-base/gxclist.h<br>
-base/gxclmem.h<br>
-base/gxclthrd.h<br>
-base/gxcmap.h<br>
-base/gxcolor2.h<br>
-base/gxcomp.h<br>
-base/gxcpath.h<br>
-base/gxcspace.h<br>
-base/gxdcolor.h<br>
-base/gxdevbuf.h<br>
-base/gxdevcli.h<br>
-base/gxdevmem.h<br>
-base/gxdht.h<br>
-base/gxdhtres.h<br>
-base/gxdhtserial.h<br>
-base/gxdither.h<br>
-base/gxfapi.h<br>
-base/gxfcache.h<br>
-base/gxfcid.h<br>
-base/gxfcmap.h<br>
-base/gxfill.h<br>
-base/gxfont.h<br>
-base/gxfont0.h<br>
-base/gxfont1.h<br>
-base/gxfont42.h<br>
-base/gxgetbit.h<br>
-base/gxgstate.h<br>
-base/gxhintn.h<br>
-base/gxhldevc.h<br>
-base/gxht.h<br>
-base/gxhttile.h<br>
-base/gxiclass.h<br>
-base/gximage.h<br>
-base/gximask.h<br>
-base/gxiodev.h<br>
-base/gxiparam.h<br>
-base/gxmatrix.h<br>
-base/gxobj.h<br>
-base/gxpaint.h<br>
-base/gxpath.h<br>
-base/gxpcache.h<br>
-base/gxpcolor.h<br>
-base/gxrplane.h<br>
-base/gxsample.h<br>
-base/gxshade.h<br>
-base/gxshade4.h<br>
-base/gxtext.h<br>
-base/gxttfb.h<br>
-base/gxtype1.h<br>
-base/gzpath.h<br>
-base/gzspotan.h<br>
-base/lib.mak<br>
-base/saes.h<br>
-base/sarc4.h<br>
-base/scommon.h<br>
-base/spprint.h<br>
-base/spsdf.h<br>
-base/srdline.h<br>
-base/std.h<br>
-base/strmio.h<br>
-base/tiff.mak<br>
-base/ttfoutl.h<br>
-base/ttobjs.h<br>
-base/unixinst.mak<br>
-devices/contrib.mak<br>
-devices/devs.mak<br>
-devices/gdev8bcm.h<br>
-devices/gdevbmp.h<br>
-devices/gdevdljm.h<br>
-devices/gdevdsp2.h<br>
-devices/gdevfax.h<br>
-devices/gdevmgr.h<br>
-devices/gdevpcl.h<br>
-devices/gdevplib.h<br>
-devices/gdevpsd.c<br>
-devices/gdevpsd.h<br>
-devices/gdevpxut.h<br>
-devices/gdevrinkj.c<br>
-devices/gdevtfax.h<br>
-devices/gdevxcf.c<br>
-devices/gdevxcmp.h<br>
-devices/gxfcopy.h<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfc.h<br>
-devices/vector/gdevpdfg.h<br>
-devices/vector/gdevpdfo.h<br>
-devices/vector/gdevpdfx.h<br>
-devices/vector/gdevpdt.h<br>
-devices/vector/gdevpdtb.h<br>
-devices/vector/gdevpdtf.h<br>
-devices/vector/gdevpdti.h<br>
-devices/vector/gdevpdts.h<br>
-devices/vector/gdevpdtt.h<br>
-devices/vector/gdevpdtw.h<br>
-devices/vector/gdevpdtx.h<br>
-devices/vector/gdevpsds.h<br>
-devices/vector/gdevpsf.h<br>
-devices/vector/gdevpsu.h<br>
-devices/vector/gdevtxtw.c<br>
-gpdl/psi/gpdlpsi.mak<br>
-pcl/pcl/pcfontst.h<br>
-pcl/pcl/pcl.mak<br>
-pcl/pcl/pgstate.h<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plchar.c<br>
-pcl/pl/plfont.h<br>
-pcl/pl/pltop.h<br>
-pcl/pxl/pxfont.h<br>
-pcl/pxl/pxstate.h<br>
-psi/files.h<br>
-psi/ichar1.h<br>
-psi/icid.h<br>
-psi/icremap.h<br>
-psi/icstate.h<br>
-psi/iddstack.h<br>
-psi/idebug.h<br>
-psi/idict.h<br>
-psi/idparam.h<br>
-psi/idsdata.h<br>
-psi/ifont.h<br>
-psi/igc.h<br>
-psi/igstate.h<br>
-psi/imain.h<br>
-psi/imainarg.h<br>
-psi/imemory.h<br>
-psi/iminst.h<br>
-psi/inamedef.h<br>
-psi/inames.h<br>
-psi/int.mak<br>
-psi/interp.h<br>
-psi/iplugin.h<br>
-psi/iref.h<br>
-psi/isave.h<br>
-psi/iscan.h<br>
-psi/isdata.h<br>
-psi/istack.h<br>
-psi/itoken.h<br>
-psi/iutil.h<br>
-toolbin/checkdeps.pl<br>
-toolbin/headercompile.pl<br>
-windows/ghostpcl.vcproj<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-04 17:53:58 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=763a5f4c3bf94cd7cc3d9fcdcde3d7cac4f38796">763a5f4c3bf94cd7cc3d9fcdcde3d7cac4f38796</a>
-<blockquote>
-<p>
- Bug 696368: Avoid a garbage collection crash.<br>
-<br>
- The bulk of this analysis and patch is due to Ken.<br>
-<br>
- We can occasionally hit crashes when dealing with patterns. Ken<br>
- tracked this down to the 'dirty' pointer in the gx_pattern_trans_t<br>
- not being relocated in a garbage collection operation, and hence<br>
- ending up pointing to a random address.<br>
-<br>
- His proposed fix was to change the 'dirty' pointer to be a pointer<br>
- to the actual pdf14_buf that contained the dirty rectangle, and to<br>
- ensure that it was properly enumerated in gc operations. This largely<br>
- solved the issues, but left a crash.<br>
-<br>
- This crash was due to pdf14_get_buffer_information returning<br>
- a pointer to buf, even when it closed the device and hence freed<br>
- buf. This didn't normally affect the caller in as it never accessed<br>
- through the pointer, but *did* trip up any garbage collection that<br>
- happened while the pointer was extant.<br>
-<br>
- The fix is simply to only have pdf14_get_buffer_information return a<br>
- pointer to buf iff buf will actually be around when we return.<br>
-<br>
-base/gdevp14.c<br>
-base/gxp1fill.c<br>
-base/gxpcmap.c<br>
-base/gxpcolor.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-07 09:58:36 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b0bfd775e43232ec488b8131b8dc014eb09d5aa">2b0bfd775e43232ec488b8131b8dc014eb09d5aa</a>
-<blockquote>
-<p>
- Coverity 328396: Correctly handle use cases for register root<br>
-<br>
- There was a logical flaw in the revised iregister_root() implementation that<br>
- meant we only handled 2 of the 3 ways of calling it correctly, the third way<br>
- would result in a segfault.<br>
-<br>
- Also, add a comment noting those three ways of calling the API.<br>
-<br>
-base/gsalloc.c<br>
-base/gsmemory.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-03 09:40:01 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4759b642f0f85f61949df18a43179d9cc5c9a91a">4759b642f0f85f61949df18a43179d9cc5c9a91a</a>
-<blockquote>
-<p>
- Undef internal setpagedevice operators<br>
-<br>
- Had to delay and undef in ps_init.ps:<br>
- /.execinstall<br>
-<br>
- Could undefine locally:<br>
- /.postinstall<br>
- /.copytree<br>
- /.defaultdeviceparams<br>
- /.makecurrentpagedevice<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-01 18:34: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=7fe04b119618b476586e5f5b85c46d72ff05ebfc">7fe04b119618b476586e5f5b85c46d72ff05ebfc</a>
-<blockquote>
-<p>
- Add -I handling to gpdl.<br>
-<br>
- This requires an &quot;add_path&quot; entrypoint be added for each language<br>
- (NULL for everything except PS).<br>
-<br>
- This causes the block of memory used for the -I path to be leaked. I<br>
- suspect this is the same as in gs. A fix for this is a little involved<br>
- so it'll wait for now.<br>
-<br>
-gpdl/psi/psitop.c<br>
-pcl/pcl/pctop.c<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/pltop.c<br>
-pcl/pl/pltop.h<br>
-pcl/pxl/pxtop.c<br>
-psi/psapi.c<br>
-psi/psapi.h<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-03 17:07:25 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2bc43397c39db60b865ca6afd14c048d9e595359">2bc43397c39db60b865ca6afd14c048d9e595359</a>
-<blockquote>
-<p>
- Avoid leak of lib path blocks.<br>
-<br>
- GS keeps a lib_path postscript array with a list of directories<br>
- in. Currently this memory is assumed to be &quot;permanent&quot;, and is<br>
- never freed by the system. This means that whenever we use -I<br>
- we leak a block.<br>
-<br>
- Here, we change the system over so that we copy the different<br>
- path components into memory blocks and free them at the end.<br>
-<br>
- This seemingly simple task is made much harder by the way that<br>
- gs throws out some of the entries in the libpath at random<br>
- points during execution.<br>
-<br>
- Accordingly, I have rejigged the code slightly, and introduced<br>
- comments to explain what is going on, in the hopes that the<br>
- next person through this code (in another 20 years) will have<br>
- an easier time understanding the assumptions baked into it.<br>
-<br>
-psi/imain.c<br>
-psi/imainarg.c<br>
-psi/iminst.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-03 15:14:25 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4aadfa18ccc7fd23e3e4e0a262bcda51ef815b3f">4aadfa18ccc7fd23e3e4e0a262bcda51ef815b3f</a>
-<blockquote>
-<p>
- Bug 700438: Fix SEGV due to overflowing double-&gt;int conversion.<br>
-<br>
- Thanks to Ken for doing most of the investigation on this.<br>
-<br>
- The problem is that we have a double value of 5e9 that won't fit<br>
- into an int (and becomes INT_MIN). This huge negative value is then<br>
- added to a pointer and we access out of range.<br>
-<br>
- The fix is simply to check for our double values being representable<br>
- as ints before we proceed - if not we throw a rangecheck. This is<br>
- reasonable as it corresponds to an image being positioned stupidly<br>
- far off the page.<br>
-<br>
- The complication with this commit comes in that it collides with<br>
- some very suspect old fixes for Bugs 686843 and 687411. The patch<br>
- for 686843 makes the same change in 2 places in the code. It looks<br>
- like 687411 is reported as the same issue, but the fix for it appears<br>
- to be reverting one of the fixes for 686843 - I suspect that the<br>
- patch was reversed.<br>
-<br>
- Given that we can't reproduce the original problems that these bugs<br>
- were trying to solve any more, I am reverting the code to a saner<br>
- form. If the problems recurr, we can reexamine then.<br>
-<br>
-base/gximag3x.c<br>
-base/gximage3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-02 14:43:58 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5a1b7b9e67f5b9827338fe65881608c530a89a35">5a1b7b9e67f5b9827338fe65881608c530a89a35</a>
-<blockquote>
-<p>
- Remove remaining ImageType 2 support, which is now dead code<br>
-<br>
- ImageType 2 was only used for display postscript.<br>
-<br>
- Made make_upath() static, since it is now only used locally by zupath.<br>
-<br>
-base/gsiparm2.h<br>
-base/gximage2.c<br>
-base/gxiparam.h<br>
-base/lib.mak<br>
-devices/gdevx.c<br>
-psi/zupath.c<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-18 14:45:00 +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=486f3b4a677180bbef2553114bf13916c76e1884">486f3b4a677180bbef2553114bf13916c76e1884</a>
-<blockquote>
-<p>
- Bug 697545: Update gx_image_enum_begin to correctly handle error returns.<br>
-<br>
-base/gxi12bit.c<br>
-base/gxiclass.h<br>
-base/gxicolor.c<br>
-base/gxifast.c<br>
-base/gximono.c<br>
-base/gxipixel.c<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-02 11:34:52 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0b3e0befdc87323eb518d6233c5fcdf5e006e6dc">0b3e0befdc87323eb518d6233c5fcdf5e006e6dc</a>
-<blockquote>
-<p>
- Removed has_alpha flag from postscript high-level image functions<br>
-<br>
- The flag was only set to 'true' by the .alphaimage operator, which was<br>
- only used by display postscript and has now been removed.<br>
-<br>
- All other callers passed hard-coded 'false', so the argument is now<br>
- extraneous.<br>
-<br>
-psi/iimage.h<br>
-psi/zimage.c<br>
-psi/zimage3.c<br>
-psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-02 11:54:21 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=42646d6c9e264d8f8c34e5e32cde3e02ff83b87d">42646d6c9e264d8f8c34e5e32cde3e02ff83b87d</a>
-<blockquote>
-<p>
- Pull in fixes from lcms2mt repo.<br>
-<br>
- (This pulls in the latest fixes from mainline lcms2 too).<br>
-<br>
-lcms2mt/README.1ST<br>
-lcms2mt/src/cmsopt.c<br>
-lcms2mt/src/cmsxform.c<br>
-lcms2mt/src/lcms2_internal.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-02 10:02:28 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef075a44f37f89dcbff03bf0bdcc7e7b6fe17c15">ef075a44f37f89dcbff03bf0bdcc7e7b6fe17c15</a>
-<blockquote>
-<p>
- Address compiler warnings<br>
-<br>
- Remove unused variables (x4)<br>
-<br>
- Add include files to fix 'implicit declaration' warnings (x2)<br>
-<br>
- Rewrite a (now) misleading comment.<br>
-<br>
-base/gdevmpla.c<br>
-base/gscspace.c<br>
-devices/gdevpsd.c<br>
-devices/vector/gdevpdft.c<br>
-psi/zfont1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2019-01-01 13:27: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=11fb2c3140b33f88056d5009b62a98f4ad921109">11fb2c3140b33f88056d5009b62a98f4ad921109</a>
-<blockquote>
-<p>
- Fix gpdl --disable-compile-inits build.<br>
-<br>
- Silly typos were preventing chunks 1,2,3 of the romfs being<br>
- built.<br>
-<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-29 09:54:09 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=416a5ebe1f7435f6dc8894576f40a8f247ed386c">416a5ebe1f7435f6dc8894576f40a8f247ed386c</a>
-<blockquote>
-<p>
- Bug 688210: Add psdcmyk16 and psdrgb16 devices<br>
-<br>
- So the patch that was provided was far from sufficient in making this<br>
- work. There was significant work that needed to be done in the<br>
- pdf14 device to ensure that the transparency put_image operation<br>
- worked correctly. Not sure if the author was paid a bounty but I<br>
- question if it was properly tested.<br>
-<br>
- I tested this with some extreme altona files and others and<br>
- everything seems to be working well now. Having the psdcmyk16 device<br>
- is nice as it is our only device to have full spot color support and<br>
- 16 bit output precision.<br>
-<br>
-base/gdevmpla.c<br>
-base/gdevp14.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-base/lib.mak<br>
-base/unix-gcc.mak<br>
-base/unixansi.mak<br>
-configure.ac<br>
-devices/devs.mak<br>
-devices/gdevpsd.c<br>
-devices/gdevpsd.h<br>
-doc/Devices.htm<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-28 14:55:14 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bfecb45e881eee39b2159873b1954f911dcb7fa3">bfecb45e881eee39b2159873b1954f911dcb7fa3</a>
-<blockquote>
-<p>
- Coverity ID 328395 - check return from ref_stack_push<br>
-<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-17 20:16:27 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1a61ba8825e80bbd779192950d61474fb7581a26">1a61ba8825e80bbd779192950d61474fb7581a26</a>
-<blockquote>
-<p>
- Remove &quot;device filter stack&quot; as it is long unused.<br>
-<br>
-base/gdevsclass.c<br>
-base/gsdfilt.c<br>
-base/gsdfilt.h<br>
-base/gxgstate.h<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-19 09:47:55 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=264e3cd12621d8270af08ab645a8aaf2b1b00f7e">264e3cd12621d8270af08ab645a8aaf2b1b00f7e</a>
-<blockquote>
-<p>
- Undefine internal functions in gs_dps2.ps<br>
-<br>
- (Note that despite the name, this isn't really display postscript)<br>
-<br>
- .UserObjects<br>
- .fixcurrenthalftonescreen<br>
- .makehalftoneRGBV<br>
- .fixsethalftonescreen<br>
- .makestackdict<br>
-<br>
-Resource/Init/gs_dps2.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-20 16:09:26 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=48008d0fbcdb26f1deac44f47eb6b0551e4ea17e">48008d0fbcdb26f1deac44f47eb6b0551e4ea17e</a>
-<blockquote>
-<p>
- pdfwrite/PDF interpreter/transparency - identify page level groups<br>
-<br>
- Bug #700376 &quot;Color change after reprocessing PDF with Ghostscript&quot;<br>
-<br>
- The problem here lies in identifying the difference between a /Group<br>
- entry in the Page dictionary, and a Group encountered as part of an<br>
- operation during the course of a Page content stream.<br>
-<br>
- To the rendering code, there is no difference, but pdfwrite needs to<br>
- be able to identify Page level groups so that it can attach them to the<br>
- Page dictionary when it writes them out.<br>
-<br>
- Previously we've been doing this by detecting the fact that we haven't<br>
- started writing anything to the page stream. However, this is simply<br>
- not good enough, in the case of this bug report, the first thing that<br>
- happens is the file runs a form, which has a Group. Because we haven't<br>
- written anything to the page yet, we think its a page level Group and<br>
- emit it as such.<br>
-<br>
- The problem is that in the original, we had set a constant alpha of<br>
- 0.55. When we run the form that is self-contained and uses an alpha of<br>
- 1, but because its in a form, the result of rendering the form is<br>
- composited with the page so far (currently nothing) with teh result that<br>
- the form contents are drawn 50% opaque.<br>
-<br>
- When we come to handle this in pdfwrite, the fact that we think the<br>
- Group for the Form is at the page level causes us to write the Form<br>
- content stream in the page (and the Group for the Form is also put<br>
- in the Page dictionary), and we fail to emit a constant alpha, because<br>
- the form resets it to 1 before executing any marks. That means we<br>
- 'optimise out' the change to 0.55 and the form is drawn 100% opaque.<br>
-<br>
- This commit introduces a new transparency compositor operation<br>
- 'PDF14_BEGIN_TRANS_PAGE_GROUP', the rendering code has been modified<br>
- to treat this as exactly equivalent to a 'PDF14_BEGIN_TRANS_GROUP' so<br>
- that there are no rendering differences.<br>
-<br>
- The pdfwrite device, however, can use it to identify with certainty<br>
- that a given Group is at the Page level and treat it specially.<br>
-<br>
- This results in 5 files in the test suite showing progressions, mostly<br>
- subtle, but one quite marked difference. The files are:<br>
- Altona_Technical_v20_x4.pdf, Bug691783.pdf, Bug691982.pdf, CATX3146.pdf,<br>
- x_-_no_compression_bomb.pdf<br>
- *only* when processed through the pdfwrite device.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-Resource/Init/pdf_main.ps<br>
-base/gdevp14.c<br>
-base/gstrans.c<br>
-base/gstrans.h<br>
-devices/vector/gdevpdft.c<br>
-psi/ztrans.c<br>
-xps/xpsgradient.c<br>
-xps/xpsimage.c<br>
-xps/xpsopacity.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-19 10:09:24 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=16b7aba969bc1d607d80ddab5c8d2430bd36b6a0">16b7aba969bc1d607d80ddab5c8d2430bd36b6a0</a>
-<blockquote>
-<p>
- Remove iimage2.h, zimage2.c (dead code after dps removal)<br>
-<br>
- Remove all the references to these files.<br>
-<br>
-doc/Develop.htm<br>
-psi/iimage2.h<br>
-psi/int.mak<br>
-psi/zimage2.c<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-19 10:32:40 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa1c24756797e43dd63d5318c961baf5f99e2428">fa1c24756797e43dd63d5318c961baf5f99e2428</a>
-<blockquote>
-<p>
- Cleanup from no-longer-existing .alphaimage operator<br>
-<br>
- Remove &lt;has_alpha&gt; parameter and handling from .colorimage<br>
- Remove references to .alphaimage from comments and stuff<br>
-<br>
-Resource/Init/gs_img.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-19 08:53:32 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0466d01e1677c8a4a8e57a191710842c844e5ad4">0466d01e1677c8a4a8e57a191710842c844e5ad4</a>
-<blockquote>
-<p>
- Bug 698828: Change of TRC in default_gray.icc<br>
-<br>
- Reviewing this bug revealed that out default_gray.icc profile had a gamma<br>
- of 1.8. The proper gamma should be the same as that used by default_rgb.icc<br>
- which has the sRGB color space TRC. This commit fixes the issue. Unfortunately<br>
- this is going to cause a huge number of changed files.<br>
-<br>
-iccprofiles/default_gray.icc<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-18 14:24:34 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c58541e2dff52bf9d481f7cd385386716e2bdd5">3c58541e2dff52bf9d481f7cd385386716e2bdd5</a>
-<blockquote>
-<p>
- Remove Display Postscript-related cooperative multitasking code and state<br>
-<br>
- The code this was supporting was in zcontext.c, which has already been<br>
- deleted.<br>
-<br>
-psi/icontext.c<br>
-psi/icstate.h<br>
-psi/interp.c<br>
-psi/oper.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-13 08:57:50 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc156631163eb9c156e0863387def7368abe5a8b">cc156631163eb9c156e0863387def7368abe5a8b</a>
-<blockquote>
-<p>
- Change zmisc.c implementation of usertime to start at 0<br>
-<br>
- The Display Postscript implementation in zcontext.c always returns 0<br>
- the first time 'usertime' is called, and counts time from there.<br>
-<br>
- Since that implementation is going away, change the one in zmisc.c to<br>
- behave the same way. It used to return a value based on the time since the<br>
- process started, which would be variable depending on the implementation.<br>
-<br>
- Both implementations increment based on time spent processing.<br>
-<br>
- This change causes vasarely.ps to run the same with and without dps.<br>
-<br>
-psi/icontext.c<br>
-psi/icstate.h<br>
-psi/zmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-12 07:43:13 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d04beddf3f2b5f5eac46f2ae9d5ab0452e38ada">0d04beddf3f2b5f5eac46f2ae9d5ab0452e38ada</a>
-<blockquote>
-<p>
- Removing display postscript and NeXT dps operators.<br>
-<br>
- This only removes operators that are DPS only. They are marked with<br>
- a &quot;DPS&quot; in the PLRM. Also removes related internal operators.<br>
-<br>
- (gs_img.ps) Remove img_utils_dict<br>
- Dependency on gs_dps.ps is gone. Can just define the utility funcs for use<br>
- and then just undef them at end.<br>
-<br>
- (gs_init.ps)<br>
- Don't need to undef dps operators anymore, because they won't be defined<br>
-<br>
- (pdf_draw.ps)<br>
- Change PDF implementation to call .setscreenphase directly<br>
-<br>
- This used to call it via the dps operator 'sethalftonephase', but that<br>
- is going away, so just make .setscreenphase be part of the pdf<br>
- implementation directly.<br>
-<br>
- Also move implementation of .setscreenphase to zpdfops.c<br>
-<br>
- (gs_cet.ps)<br>
- No longer need to undef 'deviceinfo' for CET because it won't be defined<br>
-<br>
- (gs_btokn.ps)<br>
- Replace the DPS operators in .installsystemnames with placeholders<br>
-<br>
- Keeps the length/values in the array the same, just removing dps operators.<br>
-<br>
- (icontext.c)<br>
- Needed to modify the no_reschedule() proc to return 0 instead<br>
- of an error. I think we can delete a ton of related code, in future commit,<br>
- because the code handling the time_slice_proc and reschedule_proc should<br>
- no longer be needed.<br>
-<br>
- (lots of changes)<br>
- Delete dps-related source files, update makefiles and other files that<br>
- reference the deleted files.<br>
-<br>
-Makefile.in<br>
-Resource/Init/gs_cet.ps<br>
-Resource/Init/gs_dpnxt.ps<br>
-Resource/Init/gs_dps.ps<br>
-Resource/Init/gs_img.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/pdf_draw.ps<br>
-base/gs.mak<br>
-base/gsdpnext.h<br>
-base/gsdps.c<br>
-base/gsdps.h<br>
-base/lib.mak<br>
-base/openvms.mak<br>
-base/openvms.mmk<br>
-base/unix-gcc.mak<br>
-base/unixansi.mak<br>
-gpdl/pspcl6_gcc.mak<br>
-gpdl/pspcl6_msvc.mak<br>
-psi/icontext.c<br>
-psi/int.mak<br>
-psi/msvc.mak<br>
-psi/os2.mak<br>
-psi/psromfs.mak<br>
-psi/zcontext.c<br>
-psi/zdpnext.c<br>
-psi/zdps.c<br>
-psi/zpdfops.c<br>
-toolbin/pre.chk<br>
-toolbin/pre.tcl<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-18 11:41:35 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=164c0da6464b3c9da4923ca4827616a85f0f95a9">164c0da6464b3c9da4923ca4827616a85f0f95a9</a>
-<blockquote>
-<p>
- Bug 699152: gen ordered screen generation<br>
-<br>
- Fix typo in output formatting and clean up a few warnings.<br>
-<br>
-base/gen_ordered.c<br>
-toolbin/halftone/gen_ordered/gen_ordered_main.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-18 09:34:11 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83224c6384cebe4d7463d7b3d7c240c52ca9030b">83224c6384cebe4d7463d7b3d7c240c52ca9030b</a>
-<blockquote>
-<p>
- Bug 700383: Add support for scRGB<br>
-<br>
- XPS files can define RGB colors with things like<br>
-<br>
- Fill=&quot;sc#1, 0.0231533665, 0.08021982, 0.226965874&quot;<br>
-<br>
- This implies that the color space is not sRGB (the standard default in XPS)<br>
- but rather scRGB which shares the primaries of sRGB but has a gamma of 1.0.<br>
-<br>
- Lots of progressions in the XPS files expected with this commit.<br>
-<br>
-base/gscspace.c<br>
-base/gscspace.h<br>
-base/gsicc_manage.c<br>
-base/gsicc_manage.h<br>
-base/lib.mak<br>
-iccprofiles/scrgb.icc<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-18 10:25:59 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0996199c8607807f423ebf67d576482f8f2bbadb">0996199c8607807f423ebf67d576482f8f2bbadb</a>
-<blockquote>
-<p>
- XPS interpreter - remove special case for artificial bold with pdfwrite<br>
-<br>
- Bug #700382 &quot;Synthetic bold generation too heav&quot;<br>
-<br>
- There was special case code for handling artificially emboldended text<br>
- in xps_flush_text_buffer, when the output device could directly handle<br>
- text rendering mode 2 (fill and stroke). This was because the pdfwrite<br>
- device, the only device capable of handling this mode, did some nasty<br>
- trickery with the CTM.<br>
-<br>
- At some point this trickery has been removed, probably as a result of<br>
- the ongoing work to handle stroke+fill as a graphics primitive. The<br>
- result is that the hackery is no longer required, and in fact causes<br>
- the stroke width to be incorrectly calculated, because we are trying to<br>
- reverse a later calculation with the CTM, which is no longer applied.<br>
-<br>
- So simply remove the whole section of code. This shows a very few<br>
- differences in the test suite, all at low resolution (72 dpi) where<br>
- text is slightly bolder, these appear to be (very minor)<br>
- progressions.<br>
-<br>
-xps/xpsglyphs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-15 15:19:14 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2183d4712847901ddf46989e07bdc4dd94a1197f">2183d4712847901ddf46989e07bdc4dd94a1197f</a>
-<blockquote>
-<p>
- pdfwrite - improve h/vmtx table generation for embedded TrueType fonts<br>
-<br>
- Bug 700099 &quot; glyph spacing changed after going through pdfwrite&quot;<br>
-<br>
- This is a difficult one to explain. The primary problem is that the<br>
- original PostScript contains multiple EPS files, which contain multiple<br>
- embedded subsets of the same font, but all with the same name.<br>
-<br>
- Because these subsets are small, they appear to pdfwrite to be the same<br>
- font, the checks we use to check the font do not test every possible<br>
- characteristic, because that would be slow.<br>
-<br>
- Now this is not a problem, except that for bug #697376 we did an ugly<br>
- hack.<br>
-<br>
- The generation of embedded TrueType fonts badly needs rewritten. Currently<br>
- we copy some tables, copy and amend other tables, and generate some tables<br>
- from scratch. This has led to numerous problems, on and off.<br>
-<br>
- In the case of bug 697376, we were only writing the hmtx table with<br>
- exactly as many metrics as the actual glyphs we put in the output file,<br>
- and patched the hhea tale so that it had the correct number of<br>
- hLongMetrics entries. But the spec says that every glyph (even those<br>
- which are empty in the glyf table!) must have a lsb entry. So Acrobat<br>
- Distiller threw an error on encountering our font.<br>
-<br>
- This was solved by copying the hmtx table instead of generating it. Fine<br>
- as far as it goes, but in this case we have hit the problem where we are<br>
- using glyphs from two different fonts. The hmtx table from the first font<br>
- has the wrong metrics for the glyphs in the second font, which leads to<br>
- spacing errors.<br>
-<br>
- The only possible solution, until we can find time to rewrite all of this<br>
- is to 'pad out' the hmtx table with lsb entries for the glyphs which are<br>
- present in the glyf table, but not actually used.<br>
-<br>
- I have a sneaky suspicion that this is still incorrect, we should be<br>
- writing the metrics at the correct place (GID) in the table, instead<br>
- of as a block, but this works well enough for now.<br>
-<br>
-devices/vector/gdevpsft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-14 13:04:04 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6bcf3eb2fd2bca68eef17a8cfcbf272e22d647d1">6bcf3eb2fd2bca68eef17a8cfcbf272e22d647d1</a>
-<blockquote>
-<p>
- Bug 698721 Overprint mode getting used during shading pattern<br>
-<br>
-base/gscspace.c<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-14 09:31:45 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a9359b06801cea8a7a3c4469c1e7f31564a962c">7a9359b06801cea8a7a3c4469c1e7f31564a962c</a>
-<blockquote>
-<p>
- Add missing index update in pdf14 buffer debug<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-12 12:48:39 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=085c795835284d2f0d91ebc87faf5b2da1376bca">085c795835284d2f0d91ebc87faf5b2da1376bca</a>
-<blockquote>
-<p>
- Fix header inclusions.<br>
-<br>
- Run a release build on a linux machine to make arch.h etc. Then<br>
- run toolbin/headercompile.pl to test compiling each headerfile<br>
- by itself.<br>
-<br>
- Resolve all the missing #includes, add missing repeated include<br>
- guards and copyright statements.<br>
-<br>
- Also, update all the header dependencies in the makefiles.<br>
-<br>
- It is possible that the object dependencies in the makefiles can be<br>
- simplified now, but that's a task for another day.<br>
-<br>
-base/ets.h<br>
-base/ets_tm.h<br>
-base/gdbflags.h<br>
-base/gdebug.h<br>
-base/gdevbbox.h<br>
-base/gdevdcrd.h<br>
-base/gdevddrw.h<br>
-base/gdevdevn.h<br>
-base/gdevdevnprn.h<br>
-base/gdevmem.h<br>
-base/gdevmpla.h<br>
-base/gdevmplt.h<br>
-base/gdevmrop.h<br>
-base/gdevp14.h<br>
-base/gdevpccm.h<br>
-base/gdevplnx.h<br>
-base/gdevppla.h<br>
-base/gdevprn.c<br>
-base/gen_ordered.h<br>
-base/gp_mswin.h<br>
-base/gp_os2.h<br>
-base/gpcheck.h<br>
-base/gpmisc.h<br>
-base/gs.mak<br>
-base/gsalloc.h<br>
-base/gsalpha.h<br>
-base/gsalphac.c<br>
-base/gsalphac.h<br>
-base/gsargs.h<br>
-base/gsbitops.h<br>
-base/gsbittab.h<br>
-base/gsccode.h<br>
-base/gscedata.h<br>
-base/gschar.h<br>
-base/gscie.h<br>
-base/gsclipsr.h<br>
-base/gscms.h<br>
-base/gscolor.h<br>
-base/gscolor1.h<br>
-base/gscolor3.h<br>
-base/gscompt.h<br>
-base/gscoord.h<br>
-base/gscpixel.h<br>
-base/gscrypt1.h<br>
-base/gscspace.h<br>
-base/gsdevice.h<br>
-base/gsdfilt.h<br>
-base/gsdll.h<br>
-base/gsdllwin.h<br>
-base/gsdps.h<br>
-base/gsequivc.h<br>
-base/gsexit.h<br>
-base/gsflip.h<br>
-base/gsfname.h<br>
-base/gsfont.h<br>
-base/gsform1.h<br>
-base/gsfunc.h<br>
-base/gsgc.h<br>
-base/gsgcache.h<br>
-base/gsgstate.h<br>
-base/gshsb.h<br>
-base/gsht.h<br>
-base/gshtx.h<br>
-base/gsicc_cache.h<br>
-base/gsicc_profilecache.h<br>
-base/gsimage.h<br>
-base/gsiparm2.h<br>
-base/gslib.h<br>
-base/gsline.h<br>
-base/gsmatrix.h<br>
-base/gsmchunk.h<br>
-base/gsmemory.h<br>
-base/gsnamecl.h<br>
-base/gsovrc.h<br>
-base/gspaint.h<br>
-base/gsparamx.h<br>
-base/gspath.h<br>
-base/gspath2.h<br>
-base/gspcolor.h<br>
-base/gsrect.h<br>
-base/gsrefct.h<br>
-base/gsrop.h<br>
-base/gsroprun1.h<br>
-base/gsroprun24.h<br>
-base/gsroprun8.h<br>
-base/gsropt.h<br>
-base/gsserial.h<br>
-base/gsstate.h<br>
-base/gsstrl.h<br>
-base/gstext.h<br>
-base/gstiffio.h<br>
-base/gstype1.h<br>
-base/gstypes.h<br>
-base/gsuid.h<br>
-base/gsutil.h<br>
-base/gsxfont.h<br>
-base/gx.h<br>
-base/gxband.h<br>
-base/gxbitfmt.h<br>
-base/gxcdevn.h<br>
-base/gxchrout.h<br>
-base/gxcindex.h<br>
-base/gxclip.h<br>
-base/gxclpath.h<br>
-base/gxclthrd.h<br>
-base/gxcmap.h<br>
-base/gxcomp.h<br>
-base/gxcoord.h<br>
-base/gxcpath.h<br>
-base/gxctable.h<br>
-base/gxdcconv.h<br>
-base/gxdcolor.h<br>
-base/gxdda.h<br>
-base/gxdevbuf.h<br>
-base/gxdevcli.h<br>
-base/gxdevmem.h<br>
-base/gxdevndi.h<br>
-base/gxdevrop.h<br>
-base/gxdevsop.h<br>
-base/gxdht.h<br>
-base/gxdhtserial.h<br>
-base/gxdither.h<br>
-base/gxdtfill.h<br>
-base/gxfapi.h<br>
-base/gxfarith.h<br>
-base/gxfcache.h<br>
-base/gxfill.h<br>
-base/gxfillsl.h<br>
-base/gxfilltr.h<br>
-base/gxfillts.h<br>
-base/gxfixed.h<br>
-base/gxfont0.h<br>
-base/gxfont1.h<br>
-base/gxfont42.h<br>
-base/gxgetbit.h<br>
-base/gxgstate.h<br>
-base/gxhintn.h<br>
-base/gxhldevc.h<br>
-base/gxht_thresh.h<br>
-base/gxhttile.h<br>
-base/gxiclass.h<br>
-base/gxiscale.c<br>
-base/gxmatrix.h<br>
-base/gxmclip.h<br>
-base/gxobj.h<br>
-base/gxoprect.h<br>
-base/gxp1impl.h<br>
-base/gxpaint.h<br>
-base/gxpath.h<br>
-base/gxpcache.h<br>
-base/gxsample.h<br>
-base/gxsamplp.h<br>
-base/gxshade4.h<br>
-base/gxstate.h<br>
-base/gxttf.h<br>
-base/gxttfb.h<br>
-base/gxtype1.h<br>
-base/gxxfont.h<br>
-base/gzht.h<br>
-base/gzline.h<br>
-base/jmemcust.c<br>
-base/jmemcust.h<br>
-base/lib.mak<br>
-base/pcwin.mak<br>
-base/sa85d.h<br>
-base/sbcp.h<br>
-base/sbtx.h<br>
-base/scanchar.h<br>
-base/sdcparam.h<br>
-base/sdct.h<br>
-base/sfilter.h<br>
-base/simscale.h<br>
-base/sisparam.h<br>
-base/sjpeg.h<br>
-base/sjpegc.c<br>
-base/slzwx.h<br>
-base/smd5.h<br>
-base/smtf.h<br>
-base/spdiffx.h<br>
-base/spngpx.h<br>
-base/spprint.h<br>
-base/spwgx.h<br>
-base/srdline.h<br>
-base/srlx.h<br>
-base/ssha2.h<br>
-base/sstring.h<br>
-base/strmio.h<br>
-base/szlibx.h<br>
-base/tiff.mak<br>
-base/ttfinp.h<br>
-base/ttfsfnt.h<br>
-base/ttload.h<br>
-base/ttobjs.h<br>
-base/tttype.h<br>
-devices/devs.mak<br>
-devices/gdevxalt.c<br>
-pcl/pcl/pcstate.h<br>
-pcl/pcl/pgstate.h<br>
-pcl/pl/plchar.c<br>
-pcl/pl/pldraw.h<br>
-pcl/pl/plht.c<br>
-pcl/pl/plmain.h<br>
-pcl/pxl/pxgstate.h<br>
-psi/bfont.h<br>
-psi/btoken.h<br>
-psi/dscparse.h<br>
-psi/dwdll.h<br>
-psi/dwimg.h<br>
-psi/files.h<br>
-psi/ibnum.h<br>
-psi/ichar.h<br>
-psi/ichar1.h<br>
-psi/icharout.h<br>
-psi/icid.h<br>
-psi/icie.h<br>
-psi/icolor.h<br>
-psi/iconf.h<br>
-psi/icremap.h<br>
-psi/icsmap.h<br>
-psi/icstate.h<br>
-psi/iddstack.h<br>
-psi/idebug.h<br>
-psi/idicttpl.h<br>
-psi/idisp.h<br>
-psi/idosave.h<br>
-psi/idparam.h<br>
-psi/ifcid.h<br>
-psi/ifilter2.h<br>
-psi/ifont.h<br>
-psi/ifont1.h<br>
-psi/ifont2.h<br>
-psi/ifont42.h<br>
-psi/ifrpred.h<br>
-psi/ifunc.h<br>
-psi/ifwpred.h<br>
-psi/igc.h<br>
-psi/igcstr.h<br>
-psi/iht.h<br>
-psi/iimage.h<br>
-psi/iimage2.h<br>
-psi/iinit.h<br>
-psi/ilevel.h<br>
-psi/imain.h<br>
-psi/imainarg.h<br>
-psi/imemory.h<br>
-psi/iminst.h<br>
-psi/inames.h<br>
-psi/inamestr.h<br>
-psi/int.mak<br>
-psi/interp.h<br>
-psi/iparam.h<br>
-psi/iparray.h<br>
-psi/ipcolor.h<br>
-psi/isave.h<br>
-psi/iscan.h<br>
-psi/iscanbin.h<br>
-psi/iscannum.h<br>
-psi/isdata.h<br>
-psi/isstate.h<br>
-psi/istkparm.h<br>
-psi/istream.h<br>
-psi/istruct.h<br>
-psi/itoken.h<br>
-psi/iutil.h<br>
-psi/iutil2.h<br>
-psi/ivmem2.h<br>
-psi/ivmspace.h<br>
-psi/oparc.h<br>
-psi/opcheck.h<br>
-psi/opdef.h<br>
-psi/opextern.h<br>
-psi/winint.mak<br>
-psi/zchar42.h<br>
-psi/zcie.h<br>
-psi/zcolor.h<br>
-psi/zfile.h<br>
-psi/zfrsd.h<br>
-psi/zfunc.h<br>
-psi/zicc.h<br>
-toolbin/headercompile.pl<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-14 10:38:19 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9d23c4d9a6c02416341992d8b29226273df07af8">9d23c4d9a6c02416341992d8b29226273df07af8</a>
-<blockquote>
-<p>
- PDF interpreter - preserve stroke colour/space round SMask<br>
-<br>
- Bug #699179 &quot; Chart lines rendered as black when converting from pdf to png or jpg&quot;<br>
-<br>
- Michael ran the problem down to the fact that the stroke colour space<br>
- is set before an ExtGState with a Group which has an SMask. The colour<br>
- space before the SMask is an ICCBased space and afterwards it is<br>
- DeviceGray.<br>
-<br>
- The SMask itself has a Group and that group is defined by a Form XObject<br>
- which has (yet another) Group. This Group is defined as having a<br>
- DeviceGray space. The problem is that when we executed a SMask in the<br>
- interpreter, we saved the fill colour space and values and restored<br>
- them at the end (we can't simply use gsave/grestore), but we did not<br>
- preserve the stroke colour space and colourants.<br>
-<br>
- This commit saves that as well. This results in a progression with<br>
- pdfwrite with one file and three other files showing subtle progressions<br>
- with all devices (586_-_missing_images_gs_SMask_not_applied.pdf,<br>
- fireworks_with_radial_shading.pdf, x_-_recursive_xobjects_cause_crash.pdf)<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-14 08:44:36 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c7b69c7799c32ec3e895f2053bb6c4a5e2ceb340">c7b69c7799c32ec3e895f2053bb6c4a5e2ceb340</a>
-<blockquote>
-<p>
- Fix array index typo for resolution (-r) parameter<br>
-<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-13 16:06:46 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0a6cf27a94f14234b4edad6d8af851a6ba7144c0">0a6cf27a94f14234b4edad6d8af851a6ba7144c0</a>
-<blockquote>
-<p>
- Bug 700361: Explicitly setup color fields in txtwrite<br>
-<br>
- Because txtwrite just uses the default implementations for sampled images<br>
- and masks, we want to setup various color related data on initialisation.<br>
-<br>
- This just means setting separable_and_linear appropriately and calling<br>
- set_linear_color_bits_mask_shift().<br>
-<br>
- Prevents a divide by zero when trying to use the values from<br>
- dev-&gt;color_info.comp_bits<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-11 12:26:12 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3e4d8a0ab793ddd889acbcd2a521cfe5a30e5525">3e4d8a0ab793ddd889acbcd2a521cfe5a30e5525</a>
-<blockquote>
-<p>
- Add product, copyright and version info to Windows binaries<br>
-<br>
- This appears in the Windows Explorer: Properties -&gt; Details dialogue.<br>
-<br>
-base/gscdef.c<br>
-base/gscdefs.h<br>
-psi/dwmain.rc<br>
-psi/gsdll32.rc<br>
-psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-03 15:06:12 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=218180b6d38a4641807775c032d8774c165a7657">218180b6d38a4641807775c032d8774c165a7657</a>
-<blockquote>
-<p>
- Add checks for multiple master validity<br>
-<br>
- Validate multiple master fonts at definefont time - this saves checking each<br>
- item multiple as we pass them into Freetype (or other font scaler library).<br>
-<br>
-psi/zfapi.c<br>
-psi/zfont1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-03 14: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=85bb44261edbf10552a09c839decc669f63a8142">85bb44261edbf10552a09c839decc669f63a8142</a>
-<blockquote>
-<p>
- Add an &quot;r_is_number()&quot; macro<br>
-<br>
- By moving the t_integer and t_real enum values to consecutive positions,<br>
- starting on a multiple of 2, we can check for a &quot;number&quot; type in a single step.<br>
-<br>
- Useful for values specced as reals, but which may be integer values, and thus<br>
- parsed into integer objects. This means validation can be a single check,<br>
- rather than checking for real and integer individually.<br>
-<br>
- Also use the macro in various places.<br>
-<br>
-psi/iref.h<br>
-psi/zcolor.c<br>
-psi/zfunc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-29 14:03:46 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e280984683a5ca0f2d496a93d0333b4a89ab7f42">e280984683a5ca0f2d496a93d0333b4a89ab7f42</a>
-<blockquote>
-<p>
- Undef internal funcs in gs_setpd.ps<br>
- Had to rearrange the order of functions, so there are quite a few diffs from that.<br>
-<br>
- /.selectmedia<br>
- /.computemediasize<br>
- /.prepareparams<br>
- /.trysetparams<br>
- /.installpagedevice<br>
-<br>
- (couldn't undef .uninstallpagedevice because it is called from C code)<br>
-<br>
-Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-12 16:01: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=25205fe4aa9d6dc70dd20da8a2ca5e659823bb0c">25205fe4aa9d6dc70dd20da8a2ca5e659823bb0c</a>
-<blockquote>
-<p>
- Update clusterpush.pl<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-02 15:55:55 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a44306a2ed48b3cee8e5246e6db0300eb8113c0d">a44306a2ed48b3cee8e5246e6db0300eb8113c0d</a>
-<blockquote>
-<p>
- Improve Claptrap headers.<br>
-<br>
-base/claptrap-impl.h<br>
-base/claptrap.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-11 09:01:26 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=134b38ac7b8587c9b4bb080b34473ea5e67d48d7">134b38ac7b8587c9b4bb080b34473ea5e67d48d7</a>
-<blockquote>
-<p>
- remove unused variable to silence compiler warning<br>
-<br>
-base/gsicc_lcms2mt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-11 09:00:02 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6451b921ec9f7bab14977552321a12f6f2a87b8">c6451b921ec9f7bab14977552321a12f6f2a87b8</a>
-<blockquote>
-<p>
- Add parentheses to silence a compiler warning<br>
-<br>
-base/gdevsclass.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-08 07:24:43 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3efb86d5d75240b04bed497426cec3dbef36c304">3efb86d5d75240b04bed497426cec3dbef36c304</a>
-<blockquote>
-<p>
- Bug 699305 Softmask with knockout non-isolated group<br>
-<br>
- We were not considering the softmask for the shape when<br>
- doing group composition<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-08 14:51:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=68b052d0d704037369352eb3692eb9792361fc81">68b052d0d704037369352eb3692eb9792361fc81</a>
-<blockquote>
-<p>
- PDF interpreter - Improve T42 CharStrings creation for non-symbolic fonts<br>
-<br>
- Bug #700158 &quot;ghostscript produces incorrect JPG if SubsetFonts=false&quot;<br>
-<br>
- The problem is not in fact a problem with the pdfwrite device, it is<br>
- in fact the poorly documented way that Acrobat deals with TrueType<br>
- fonts, the symbolic/non-symbolic flags and Encodings.<br>
-<br>
- When the font has a 3,1 CMAP subtable we use a number of sources of data<br>
- to try and build a CharStrings dictionary, which we use to map a glyph<br>
- name to a glyph ID:<br>
-<br>
- Encoding CharStrings<br>
- character code --------&gt; glyph name -----------&gt; glyh ID<br>
-<br>
- However when the font has no 3,1 CMAP subtable the specification says<br>
- we should try to use a 1,0 CMAP instead. For 1,0 tables we were not<br>
- using the 'prebuilt_encoding' to generate the CharStrins, which meant<br>
- that we making less use of information than we might, and some glyphs<br>
- were replaced by the /.notdef when rendering.<br>
-<br>
- This commit adds the prebuilt_encoding to the sources of information<br>
- we use to generate Charstrings when using a 1,0 CMAP subtable.<br>
-<br>
- This fixes the problem, and shows a progression with one file in our<br>
- test suite.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-07 11:33:18 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=78af4f91e7a5958acab262f3e90b5ce2a0768562">78af4f91e7a5958acab262f3e90b5ce2a0768562</a>
-<blockquote>
-<p>
- Add a profile for a particular RGB color space<br>
-<br>
-iccprofiles/a98.icc<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-17 15:17: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=abb742af3affbe00da625a1272d682ac5fd4c964">abb742af3affbe00da625a1272d682ac5fd4c964</a>
-<blockquote>
-<p>
- Commit of gpdl-shared-device branch.<br>
-<br>
- This commit is a squashed version of the gpdl-shared-device<br>
- branch. Essentially this is a first version of the new<br>
- language switching mechanism.<br>
-<br>
- This does not build as part as &quot;all&quot;, but rather as &quot;experimental&quot;<br>
- or &quot;gpdl&quot;.<br>
-<br>
-Resource/Init/gs_cet.ps<br>
-Resource/Init/gs_init.ps<br>
-base/gp_mspol.c<br>
-base/gs.mak<br>
-base/gsalloc.c<br>
-base/gsdevice.c<br>
-base/gsiodev.c<br>
-base/gsiodevs.c<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-base/gsmalloc.c<br>
-base/gsmalloc.h<br>
-base/gsmchunk.c<br>
-base/gsmemory.c<br>
-base/gsmemory.h<br>
-base/gsmemret.c<br>
-base/gsstate.c<br>
-base/gsutil.c<br>
-base/gxdownscale.c<br>
-base/gxdownscale.h<br>
-configure.ac<br>
-devices/devs.mak<br>
-devices/gdevchameleon.c<br>
-gpdl/psi/psitop.c<br>
-pcl/pcl/pctop.c<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pl/pltop.c<br>
-pcl/pl/pltop.h<br>
-pcl/pl/plwmainc.c<br>
-pcl/pl/realmain.c<br>
-pcl/pxl/pxtop.c<br>
-psi/dwdll.h<br>
-psi/dwnodll.c<br>
-psi/gsdll2.def<br>
-psi/gsdll32.def<br>
-psi/gsdll32metro.def<br>
-psi/gsdll64.def<br>
-psi/gsdll64metro.def<br>
-psi/gsdllARM32metro.def<br>
-psi/ialloc.c<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-psi/icstate.h<br>
-psi/igc.c<br>
-psi/imain.c<br>
-psi/imain.h<br>
-psi/imainarg.c<br>
-psi/imainarg.h<br>
-psi/imemory.h<br>
-psi/iminst.h<br>
-psi/int.mak<br>
-psi/interp.c<br>
-psi/ireclaim.c<br>
-psi/msvc.mak<br>
-psi/opextern.h<br>
-psi/psapi.c<br>
-psi/psapi.h<br>
-psi/zdevice.c<br>
-psi/zfont.c<br>
-psi/ziodevsc.c<br>
-windows/ghostscript.vcproj<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-07 18:53:59 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eab61428b3fa1e4078e71febefe406dad499814e">eab61428b3fa1e4078e71febefe406dad499814e</a>
-<blockquote>
-<p>
- txtwrite - allow some slop in zero-width detection<br>
-<br>
- Bug #700322 &quot; Endless loop when converting pdf to text &quot;<br>
-<br>
- While trying to fit text (text format 2 or 3) we do some heuristic<br>
- juggling to decide whether or not to use a calculated minimum size.<br>
- During this we check to see whether the width is zero, and if it is<br>
- we don't try to use it because it would result in an infinite loop.<br>
-<br>
- We actually need to allow a little 'slop' around zero, in case floating<br>
- point errors result in a very small, but not quite zero, width.<br>
-<br>
- The loop resuling in the bug isn't endless, but it is very lengthy.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-05 10:40:43 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=74723f099067f6b14f61f0cbf816c0b8536931a2">74723f099067f6b14f61f0cbf816c0b8536931a2</a>
-<blockquote>
-<p>
- Improve gx_get_bits_copy determination of depth.<br>
-<br>
- For devices that are separable, (GX_CINFO_SEP_LIN), it is better to use<br>
- the comp_bits to determine the depth of a plane. Seen with the display<br>
- device in spot color mode where dest_depth calculation from the depth<br>
- divided by num_components is not correct.<br>
-<br>
-base/gdevdgbr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-04 21:31: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=fae21f1668d2b44b18b84cf0923a1d5f3008a696">fae21f1668d2b44b18b84cf0923a1d5f3008a696</a>
-<blockquote>
-<p>
- subclassing devices - fix put_image method<br>
-<br>
- The subclassing devices need to change the 'memory device' parameter to<br>
- be the child device, when its the same as the subclassing device.<br>
-<br>
- Otherwise we end up trying to access the child device's memory pointers<br>
- in the subclassing device, which may not contain valid copies of<br>
- those pointers.<br>
-<br>
-base/gdevsclass.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-03 14:40:37 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e68cc460dbe349f68b81082ff7344db48eb4820">2e68cc460dbe349f68b81082ff7344db48eb4820</a>
-<blockquote>
-<p>
- pdfwrite - don't try and apply transfer functions when converting colours<br>
-<br>
- Bug #700052 &quot;pdfwrite device grayscale conversion looses significant quality on gradients<br>
-<br>
- The problem is that the file contains considerable spurious (ie has no<br>
- effect) transparency operatiosns. in this particular case a number of<br>
- objects are drawn with an SMask and the SMask uses a transfer function<br>
- to invert the single component colour space (The gray objects are in<br>
- fact described in a DeviceN [/Black] colour space, presumabkly to<br>
- still further pointlessly increase teh complexity).<br>
-<br>
- When converting colour space we were altering the transfer function<br>
- from 'Presever' to 'Apply', but we can't actually apply the transfer<br>
- function to the SMask in this case.<br>
-<br>
- So leave this as 'preserve for now', note that transfer functions are<br>
- deprecated, and not permitted in PDF 2.0.<br>
-<br>
-devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-01 10:04:09 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=86ed59a3b47bc4b57fbd9c76681558c300d1471b">86ed59a3b47bc4b57fbd9c76681558c300d1471b</a>
-<blockquote>
-<p>
- pdfwrite - conform to Acrobat limitations for PDF 1.4 to conform to PDF/A-1<br>
-<br>
- Never noticed before, but PDF/A-1 mandates sticking to the architectural<br>
- limits of Acrobat described in the PDF 1.4 specification (Note, these<br>
- are not *PDF* Limitations, they are limitations of the Adobe<br>
- implementation).<br>
-<br>
- It was possible for us to emit co-ordinate movements which are in real<br>
- numbers, but exceed 32767, which is outside the Acrobat limitation.<br>
-<br>
- This commit alters that, and in fact uses the older limitation of<br>
- Acrobat 3 and 4, which limits co-ordinates to +/- 16K.<br>
-<br>
-devices/vector/gdevpdts.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-12-01 10:01:18 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb9d383dd90bb430e18bd9c039300f0cff589323">fb9d383dd90bb430e18bd9c039300f0cff589323</a>
-<blockquote>
-<p>
- pdfwrite - PDF/A-1 must set Compatibility Level of 1.4<br>
-<br>
- Noticed while working on a different bug. Its correct for PDF/A-2 to be<br>
- PDF 1.7, but not for PDF/A-1 we must conform to PDF 1.4.<br>
-<br>
-devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-29 12:30:10 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7eaa19df8086579009552162814b34c651f8d0d4">7eaa19df8086579009552162814b34c651f8d0d4</a>
-<blockquote>
-<p>
- Fix .vmused undef to work properly<br>
-<br>
- Had to both use an immediate reference and make it an operator.<br>
- (commit 2ff600a3c4fc169e7c6c1e83874a6bf63a6fb42b made .vmused an operator)<br>
-<br>
- This test was failing and wasn't detected by cluster test:<br>
- debugbin/gs -DDELAYBIND -IResource/Init -sDEVICE=ppmraw -dSAFER<br>
-<br>
- If I don't make it an operator, then this fails (cluster test detects):<br>
- debugbin/gs -Z: -o out.bin -IResource/Init -sDEVICE=ppmraw -sDEFAULTPAPERSIZE=letter -dNOPAUSE -dBATCH -K2000000 -dClusterJob -dJOBSERVER -dCETMODE %rom%Resource/Init/gs_cet.ps ~/work/samples/tests_private/ps/ps3cet/36-01.PS<br>
-<br>
-Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-28 10:09:01 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=932f4106a00e99e4ee32dcc02e57d3636f383ea1">932f4106a00e99e4ee32dcc02e57d3636f383ea1</a>
-<blockquote>
-<p>
- Undef internal functions from level2dict<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-29 16:07: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=dce2ab5aead0028de39293da8cf835c76b00a7cf">dce2ab5aead0028de39293da8cf835c76b00a7cf</a>
-<blockquote>
-<p>
- Remove nasty type check in gs_fapi_finish_render.<br>
-<br>
- This is a left over from when show and text enumerators were<br>
- significantly different. The only requirement now is that<br>
- text enumerators should set penum-&gt;cc to be NULL. We update<br>
- gs_text_enum_init_dynamic (and hence gs_text_enum_init) to<br>
- do this.<br>
-<br>
-base/gstext.c<br>
-base/gxfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-29 11:48:25 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3bd37e9686f93dabb7121406bf36e59941db8e59">3bd37e9686f93dabb7121406bf36e59941db8e59</a>
-<blockquote>
-<p>
- Remove unnecessary checks on object types from gxfapi.c<br>
-<br>
- These are no longer required as the enumerators are the same.<br>
-<br>
-base/gxfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-29 17:32:30 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=66df699e2d7f19d87542c76e9d96167f2125e654">66df699e2d7f19d87542c76e9d96167f2125e654</a>
-<blockquote>
-<p>
- pdfwrite - add a check to ensure we don't create an invalid PDF file<br>
-<br>
- related to bug #700291 The PDF file in that bug report was created by<br>
- Ghostscript and pdfwrite. The xref table is invalid because it has an<br>
- entry with an offset of 11 digits, which is illegal (the file exceeds<br>
- 10GB in size)<br>
-<br>
- Add a check when writing the xref table to see if any offset is greater<br>
- that 10 digits, and throw an error if it is. We can't check any earlier<br>
- because we don't know the offset of any object in the file until it is<br>
- read from its stored temporary file and written to the main output<br>
- file.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-29 16:22: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=c0682e5dd674ecfedcb92ba114ce5c43306f270a">c0682e5dd674ecfedcb92ba114ce5c43306f270a</a>
-<blockquote>
-<p>
- Only use FT weight vector API if FT is new enough<br>
-<br>
- So strictly later than 2.9.1 or when using our patched sources (SHARE_FT==0)<br>
-<br>
-Makefile.in<br>
-base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-28 17:12:08 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2756f0efae1d3966989b15a6526c5d80848b5015">2756f0efae1d3966989b15a6526c5d80848b5015</a>
-<blockquote>
-<p>
- Bug 700290: Fix problems with DELAYBIND and font substitution<br>
-<br>
- Judicious use of immediate evaluation for .setnativefontmapbuilt and<br>
- .putgstringcopy to avoid problems with DELAYBIND<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-29 11:47:42 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=680b49775bf27fcfe3bcdbe7049abbba544f3329">680b49775bf27fcfe3bcdbe7049abbba544f3329</a>
-<blockquote>
-<p>
- Remove unnecessary checks on type of pgs.<br>
-<br>
- No longer required since pgs and pis were merged.<br>
-<br>
-base/gxchar.c<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-29 11:33:20 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6da179927d5aeaf936ebc81eb9d430f7edc0397a">6da179927d5aeaf936ebc81eb9d430f7edc0397a</a>
-<blockquote>
-<p>
- Remove antiquated check in pdf_shift_text_currentpoint.<br>
-<br>
- pdf_shift_text_currentpoint tests to see that the graphics state<br>
- it is passed is really a graphics state. We believe this is a<br>
- hangover from having graphics states and imager states.<br>
-<br>
- Firstly, the check is wrong, as it uses penum-&gt;dev-&gt;memory when<br>
- it should be using penum-&gt;pgs-&gt;memory. Fixing this is enough to<br>
- solve the problem where this was seen (gpdl pdfwriting files).<br>
-<br>
- Secondly, however the check is no longer needed, so the nicer fix<br>
- is to remove it completely.<br>
-<br>
-devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-29 10:55:32 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cb77559a6825f6fa4b23c1d5efb981eadc7f948f">cb77559a6825f6fa4b23c1d5efb981eadc7f948f</a>
-<blockquote>
-<p>
- Source fixup, remove trailing whitespace<br>
-<br>
-base/strmio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 16:56:43 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f0ca2c929171a025e846a2eddd51f767e04c8e23">f0ca2c929171a025e846a2eddd51f767e04c8e23</a>
-<blockquote>
-<p>
- Bug 695813. Reduce memory usage for ICC profiles. Example AIX361DC_Save.pdf<br>
-<br>
- The same ICC profiles and colorspace were used many times (in the example<br>
- the cited PDF_1.7_ATS file) which could result in memory usage growth and<br>
- performance impact associated with loading the same profile many times.<br>
- There was a icc_profile_cache in the gstate, but it was not being used for<br>
- ICCBased colorspaces, only for CIEBased* spaces.<br>
-<br>
- Adding logic to cache ICCBased colorspaces and change ICCBased space to<br>
- be in stable memory so it can exist in the cache. This results in a<br>
- reduction of the RAM needed for the cited file from 1.0Gb down to 44Mb<br>
- and reduced the parse time from 29.4s down to 24.4s (overall time from<br>
- 94.5s to 91.3s) for ppmraw 600 dpi.<br>
-<br>
- Note that this optimization results in many fewer CS/cs operations being<br>
- emitted by pdfwrite, but this also can result in text being emitted as<br>
- TJ operations (glyphs with positioning) which can result in single pixel<br>
- shifts in glyphs. Sometimes this looks better, sometimes not, but the<br>
- reduction in size/complexity of the resulting PDF is worth it.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-base/gsicc_profilecache.c<br>
-psi/zicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-28 14:04: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=34bb42a7bcd649675d618a62c9f8a3a673598787">34bb42a7bcd649675d618a62c9f8a3a673598787</a>
-<blockquote>
-<p>
- Ensure that gs_cet.ps is not squashed in romfs.<br>
-<br>
- This causes us to misinterpret it as being PCL, and defeats the<br>
- 'skip if read more than once' test.<br>
-<br>
-psi/psromfs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-28 19:13:16 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8d462b070127d3541402b4fda670e0b20c6a61a4">8d462b070127d3541402b4fda670e0b20c6a61a4</a>
-<blockquote>
-<p>
- LCMS2MT: Planar data fix.<br>
-<br>
- The PrecalculatedXFORMIdentity case was failing to allow for planar<br>
- data. Fix that here.<br>
-<br>
- Also, optimise the src = dst case.<br>
-<br>
-lcms2mt/src/cmsxform.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-27 13:11:15 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=87ec442bc2b0bfa6607c5fb7d085dd85f24e1416">87ec442bc2b0bfa6607c5fb7d085dd85f24e1416</a>
-<blockquote>
-<p>
- Undefine internal .findcategory<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_ll3.ps<br>
-Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-27 12:36:14 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2ff600a3c4fc169e7c6c1e83874a6bf63a6fb42b">2ff600a3c4fc169e7c6c1e83874a6bf63a6fb42b</a>
-<blockquote>
-<p>
- Undef a bunch of internal things in gs_res.ps<br>
-<br>
-Resource/Init/gs_res.ps<br>
-Resource/Init/gs_resmp.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 22:30: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=a6da4c97bb99159269468d95daacdf11ab336187">a6da4c97bb99159269468d95daacdf11ab336187</a>
-<blockquote>
-<p>
- Use the new Freetype FT_Set/Get_MM_WightVector API<br>
-<br>
- Being able to set the weight vector in an existing FT font object avoids the<br>
- need to recreate the font every time the weightvector changes in Postscript.<br>
-<br>
- Creating an FT font is a time consuming operation, so this can save considerable<br>
- time in jobs that make heavy use of multiple master fonts<br>
-<br>
-base/fapi_ft.c<br>
-base/gxfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 22:29:24 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bfddf70400bb1fd4b3f7bfd72f333ad09a0b6cba">bfddf70400bb1fd4b3f7bfd72f333ad09a0b6cba</a>
-<blockquote>
-<p>
- Add a setweightvector analogue in Freetype<br>
-<br>
- Avoids the need to recreate the FT font everytime the weightvector changes.<br>
-<br>
- These Freetype changes have been accepted upstream:<br>
- http://git.savannah.gnu.org/cgit/freetype/freetype2.git/commit/?id=78a1e69517ca067224d6e33beffd25e2ec8361d2<br>
-<br>
-freetype/include/freetype/ftmm.h<br>
-freetype/include/freetype/internal/services/svmm.h<br>
-freetype/src/base/ftmm.c<br>
-freetype/src/cff/cffdrivr.c<br>
-freetype/src/truetype/ttdriver.c<br>
-freetype/src/type1/t1driver.c<br>
-freetype/src/type1/t1load.c<br>
-freetype/src/type1/t1load.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-27 19:43: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=3f93e079aa448a202329fd08a350485c3504b9dd">3f93e079aa448a202329fd08a350485c3504b9dd</a>
-<blockquote>
-<p>
- Fix typo in previous commit.<br>
-<br>
- I failed dismally at checking the depth.<br>
-<br>
-base/gdevdflt.c<br>
-devices/gdevbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-27 17:24:38 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c80766f966d2801a8608e72a1dea6dcb4bec4248">c80766f966d2801a8608e72a1dea6dcb4bec4248</a>
-<blockquote>
-<p>
- Bug 700278: Fix inverted colors in jpegcmyk output.<br>
-<br>
- It seems that in the transform pixel region code, I know that<br>
- colours are in the right space, and therefore assume that there<br>
- will be a 1:1 mapping from the raw bytes into the device memory.<br>
-<br>
- Sadly the jpegcmyk device inverts everything, so my assumption<br>
- was wrong.<br>
-<br>
- Accordingly I've added a gxdso to tell me if the encoding is<br>
- direct. I've added this to the obvious devices - more may be<br>
- required in future.<br>
-<br>
- If this is unimplemented, then we'll take the slower route<br>
- and look up colors.<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevp14.c<br>
-base/gxcmap.c<br>
-base/gxdevsop.h<br>
-devices/gdevbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-26 18:01:25 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=779664d79f0dca77dbdd66b753679bfd12dcbbad">779664d79f0dca77dbdd66b753679bfd12dcbbad</a>
-<blockquote>
-<p>
- Have gs_cet.ps run from gs_init.ps<br>
-<br>
- Previously gs_cet.ps was run on the command line, to set up the interpreter<br>
- state so our output more closely matches the example output for the QL CET<br>
- tests.<br>
-<br>
- Allow a -dCETMODE command line switch, which will cause gs_init.ps to run the<br>
- file directly.<br>
-<br>
- This works better for gpdl as it means the changes are made in the intial<br>
- interpreter state, rather than after initialisation is complete.<br>
-<br>
- This also means adding a definition of the default procedure for black<br>
- generation and under color removal (rather it being defined in-line in<br>
- .setdefaultbgucr<br>
-<br>
- Also, add a check so gs_cet.ps only runs once - if we try to run it a second<br>
- time, we'll just skip over the file, flushing through to the end.<br>
-<br>
-Resource/Init/gs_cet.ps<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-21 13:43:50 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5d967e5d2c0b63a3c7d67a08a53ff657d36f0d18">5d967e5d2c0b63a3c7d67a08a53ff657d36f0d18</a>
-<blockquote>
-<p>
- Undef some internal level3 implementation details<br>
-<br>
- Also moved some undef's from gs_init.ps to gs_ll3.ps because they are<br>
- for things defined and used only in this file (or some are defined in<br>
- the C code, but still only used here).<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_ll3.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-20 14:32:20 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f1206fa3834b5a8ff798e08d9cfcbb27bb9bdd41">f1206fa3834b5a8ff798e08d9cfcbb27bb9bdd41</a>
-<blockquote>
-<p>
- Remove dead code from gs_cspace.ps<br>
-<br>
- These are dead code, apparently:<br>
- /..includecolorspace<br>
- /cs_substitute_generic<br>
- /cs_substitute_DeviceRGB_for_PDFX_or_PDFA<br>
-<br>
- This one is called from C code (zcolor.c) and can't be undef'd<br>
- Added comment about how to trigger it.<br>
- /..nosubstdevicetest<br>
-<br>
-Resource/Init/gs_cspace.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-20 12:47:40 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d6630dfe7a2d44aec9193950acc34836a32f97e2">d6630dfe7a2d44aec9193950acc34836a32f97e2</a>
-<blockquote>
-<p>
- Undef'd things used locally in gs_btokn.ps (binary tokens)<br>
-<br>
- /.objectprinttest<br>
- /.bosheader<br>
- /.cntobj<br>
- /.writeobject<br>
- /.writeobjects<br>
-<br>
-Resource/Init/gs_btokn.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-20 12:19:28 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c548ed1dca42cb77572b2a7f8448aad2ce98918c">c548ed1dca42cb77572b2a7f8448aad2ce98918c</a>
-<blockquote>
-<p>
- Fix some previously attempted undef's<br>
-<br>
- /.setdevicecolorrendering1 needs to be undef'd from both systemdict<br>
- and level2dict<br>
-<br>
- /.ProcessICCcomment was misspelled<br>
-<br>
- /.setpagesize is actually in statusdict and haven't successfully undef'd yet<br>
-<br>
-Resource/Init/gs_icc.ps<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-27 14:08: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=de8b6458abaeb9d0b14f02377f3e617f2854e647">de8b6458abaeb9d0b14f02377f3e617f2854e647</a>
-<blockquote>
-<p>
- PS interpreter - fix EPSFitPage (again)<br>
-<br>
- Bug #700279 &quot;On square EPS files -dFitPage incorrectly rotates output&quot;<br>
-<br>
- The commit to fix bug #698555 altered the action of EPSFitPage so that<br>
- it set the media size form the BoundingBox (using EPSCrop) and then<br>
- relied on the usual PostScript page fitting.<br>
-<br>
- However, as noted at the time, this does cause square pages to rotate.<br>
- This isn't actually incorrect, there is no specification for this its a<br>
- Ghostscript feature, and we're free to implement it any way we like.<br>
- However it is a change form the previous behaviour.<br>
-<br>
- This commit reinstates the EPSFitPage code (in EPSBoundingBoxFitPage<br>
- in gs_epsf.ps) and fixes the calculations in that code when the content<br>
- is rotated onto the media (because it fits better that way) so that it<br>
- correctly scales and translates the content onto the new media.<br>
-<br>
- because we are no longer using the PostScript page fitting code, this<br>
- no longer rotates square media.<br>
-<br>
-Resource/Init/gs_epsf.ps<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-26 08:20:19 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=96c381cce28c27eac182549441a6c5025b0dcdd6">96c381cce28c27eac182549441a6c5025b0dcdd6</a>
-<blockquote>
-<p>
- ps2write - move the page level save/restore wrapper<br>
-<br>
- Bug #700232 &quot;A5 duplex to duplex-capable Postscript printer prints single-sided&quot;<br>
-<br>
- Commit 0f6067d2531298060392d0e25fa759d320e03021 for bug #697245<br>
- removed a duplicate definition of pagesave, because it transpires that<br>
- Adobe interpreters don't free save objects when they are no longer<br>
- referenced. Previously we had defined /pagesave in both the page<br>
- content stream, and the code for altering page size.<br>
-<br>
- The problem is that we alter media size as part of processing the<br>
- 'stream' keyword, which is after we have defined /pagesave. Previously<br>
- we would then have redefined it if we needed to alter the media size.<br>
-<br>
- When we got to the end of the page (after the showpage) we would then<br>
- restore the save object. Because we had defined the save object after we<br>
- had altered the media size the media would remain unchanged. With the<br>
- commit above, however, the media size would be restored back to the<br>
- original.<br>
-<br>
- When we process page 2, the media size would then need to he altered<br>
- again, requiring a setpagedevice to be executed. The action of<br>
- setpagedevice, when Duplex is true, is to eject any unpaired pages and<br>
- start again with the first side.<br>
-<br>
- Thus Duplex was working entirely correctly, simply not as desired.<br>
-<br>
- This commit moves the pagesave and restore into the 'stream' and<br>
- 'endstream' processing, so that is taken care of after any media size<br>
- changes.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/opdfread.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-26 15:19:35 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2ceb01328c4270386299ef55dbdc06d1f26d63c8">2ceb01328c4270386299ef55dbdc06d1f26d63c8</a>
-<blockquote>
-<p>
- Remove unneeded check for planar during color conversion<br>
-<br>
-base/gsicc_lcms2mt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-26 12:14:21 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=56b4298a22c3253206615bc6fda34f74aaa72800">56b4298a22c3253206615bc6fda34f74aaa72800</a>
-<blockquote>
-<p>
- Avoid allocations when color transforming planar data<br>
-<br>
-base/gsicc_lcms2mt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 14:27:26 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=461cdaa4287edac9bfd0caebf3e8291e0539a0fd">461cdaa4287edac9bfd0caebf3e8291e0539a0fd</a>
-<blockquote>
-<p>
- Fix some missing type checking and use check_read_type consistently<br>
-<br>
- Some places checked with code, some places used the check__type<br>
- macro (which doesn't check for read access) and some places used<br>
- check_read_type. Also add check for CIEdict1 in hashcieaspace.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 14:19:42 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e45b35ede042259ff9fbf36fa714e874fc5483db">e45b35ede042259ff9fbf36fa714e874fc5483db</a>
-<blockquote>
-<p>
- Change hash key for the icc_profile_cache to uint64_t<br>
-<br>
- This was ulong in some places and int64_t in another, but ulong on a<br>
- Windows build is only 32-bits. Make it consistent (and more bytes on<br>
- Windows).<br>
-<br>
-base/gscms.h<br>
-base/gsicc_profilecache.c<br>
-base/gsicc_profilecache.h<br>
-psi/zcie.c<br>
-psi/zcie.h<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-09 14:26:27 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=410a192c093c22ca1dbfc1764659faa6a48198a8">410a192c093c22ca1dbfc1764659faa6a48198a8</a>
-<blockquote>
-<p>
- Fix infinite loop freeze running all PDF ATS files.<br>
-<br>
- The infinite loop was caused by bumping the ref_count on a cache link<br>
- entry too early so that anytime we reached ICC_CACHE_MAXLINKS links in<br>
- the cache, we would loop forever.<br>
-<br>
- This simplifies the code, removes a function that was only used once,<br>
- and also protects the clist multi-threading from potential lock up due<br>
- to more threads than slots in the icc_link_cache.<br>
-<br>
- Add a semaphore when the link_cache is full (no zero ref_count entries)<br>
- to let other threads run and finish up with the links that are in the<br>
- cache.<br>
-<br>
- No bug opened, but occurred with:<br>
- gs -r600 -sDEVICE=ppmraw -o /dev/null PDF_1.7_ATS/*.pdf<br>
- NB: This requires skipping AC8ZD1CC_Save.pdf since that needs a password.<br>
-<br>
-base/gpsync.h<br>
-base/gscms.h<br>
-base/gsicc_cache.c<br>
-base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-26 16:17:51 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2501816e229ae98e1c0d9a91f8bf00b380301b55">2501816e229ae98e1c0d9a91f8bf00b380301b55</a>
-<blockquote>
-<p>
- Fix comment typo.<br>
-<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-23 16:24:43 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f73fb86fb40d092b4b9a39f43a374bd70eac0d41">f73fb86fb40d092b4b9a39f43a374bd70eac0d41</a>
-<blockquote>
-<p>
- Remove more macros from iscan.c<br>
-<br>
-psi/iscan.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-26 15:14:12 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a364553aa4d0738ec763aa2c262af6fc82b088d">9a364553aa4d0738ec763aa2c262af6fc82b088d</a>
-<blockquote>
-<p>
- Make sfclose accept NULL.<br>
-<br>
- All destructors should accept NULL. Anything else is insanity.<br>
-<br>
-base/strmio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-22 18:47:40 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=40dc5b409c6262b18b4bf5386b5482ead4c511e3">40dc5b409c6262b18b4bf5386b5482ead4c511e3</a>
-<blockquote>
-<p>
- Remove gpdl from the &quot;all&quot; Makefile targets.<br>
-<br>
- Add it to a new &quot;experimental&quot; target that is what &quot;all&quot; used to<br>
- be.<br>
-<br>
-Makefile.in<br>
-base/gs.mak<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-14 14:00:40 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b43a9362c8614182e77b89a3ff8d8c56a6628260">b43a9362c8614182e77b89a3ff8d8c56a6628260</a>
-<blockquote>
-<p>
- iscan.c: Remove some scan macros.<br>
-<br>
-psi/iscan.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-14 13:56: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=9e99c4ab4135f735091d4b3ffe26851604507db5">9e99c4ab4135f735091d4b3ffe26851604507db5</a>
-<blockquote>
-<p>
- iscan.c: Demacro: ssarray<br>
-<br>
-psi/iscan.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-22 19:17:28 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0718e9a4fdc1c107d772d1aff37566c73d5958f8">0718e9a4fdc1c107d772d1aff37566c73d5958f8</a>
-<blockquote>
-<p>
- Remove ziodevs.c from MSVC project.<br>
-<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-19 17:38:11 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=edbad08f9c91c994ac8f8df45e0cbf37ca377104">edbad08f9c91c994ac8f8df45e0cbf37ca377104</a>
-<blockquote>
-<p>
- Remove macro bletcherisms from stream code.<br>
-<br>
-base/gsioram.c<br>
-base/gsiorom.c<br>
-base/sfxfd.c<br>
-base/sfxstdio.c<br>
-base/stream.c<br>
-base/stream.h<br>
-psi/zfilter.c<br>
-psi/zfrsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-22 18:18: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=e1eecc89c943d20145a887c64193fb0bfb44c250">e1eecc89c943d20145a887c64193fb0bfb44c250</a>
-<blockquote>
-<p>
- Squash warnings.<br>
-<br>
-base/gdevdrop.c<br>
-base/gsicc_cache.c<br>
-base/gxclist.c<br>
-devices/gdevxcmp.c<br>
-pcl/pcl/pcfont.c<br>
-psi/ilocate.c<br>
-psi/zvmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-22 16:30:49 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8fe6187ace91d49c3ca07ab850bc1fe50da3409e">8fe6187ace91d49c3ca07ab850bc1fe50da3409e</a>
-<blockquote>
-<p>
- Remove STDIO_IMPLEMENTATION logic from Makefiles.<br>
-<br>
- This has fallen out of usage to the degree where the non-C callbacks<br>
- based version hasn't even built for years (since at least 2006, by<br>
- my git archaeology). Just strip it out completely.<br>
-<br>
-Makefile.in<br>
-base/gs.mak<br>
-base/msvclib.mak<br>
-base/openvms.mak<br>
-base/ugcclib.mak<br>
-base/unix-dll.mak<br>
-base/unix-gcc.mak<br>
-base/unixansi.mak<br>
-psi/int.mak<br>
-psi/msvc.mak<br>
-psi/os2.mak<br>
-psi/ziodevs.c<br>
-psi/ziodevsc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-07 16:03:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=07b4a67404479dfa3ae55835f05b6cc8699c9adc">07b4a67404479dfa3ae55835f05b6cc8699c9adc</a>
-<blockquote>
-<p>
- Bring master up to date with 9.26 release branch<br>
-<br>
- Docs, dates etc<br>
-<br>
- Dates, change log, etc for 9.26 rc1<br>
-<br>
- Dates, changelog, etc for 9.26 release<br>
-<br>
-base/version.mak<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-11-14 21:11:43 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b50d93dfe0b539d2cbbf80b3db8c89362abb265">4b50d93dfe0b539d2cbbf80b3db8c89362abb265</a>
-<blockquote>
-<p>
- Add gpdlmemento target.<br>
-<br>
- Also add &quot;mementovg&quot; targets for building memento with knowledge of<br>
- valgrind. Can't make this the default as then we'd not be able to<br>
- build memento on machines without valgrind installed.<br>
-<br>
-base/unix-end.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-20 18:43:20 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=690bc91e0fff4314128becb98e27b8bdd182c194">690bc91e0fff4314128becb98e27b8bdd182c194</a>
-<blockquote>
-<p>
- Tweak gs_cet.ps papersize handling.<br>
-<br>
- This file has always removed all but the default papersizes from<br>
- InputAttributes. Here, also ensure that we make that the current<br>
- page size to avoid problems with setpagedevice later on.<br>
-<br>
-Resource/Init/gs_cet.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-20 13:44:22 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bca00a68a20b4022ce6138d647daa0b6b7989c9a">bca00a68a20b4022ce6138d647daa0b6b7989c9a</a>
-<blockquote>
-<p>
- Remove pl_top_cursor_t and move to using streams.<br>
-<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plcursor.c<br>
-pcl/pl/plcursor.h<br>
-pcl/pl/plmain.c<br>
-windows/ghostpcl.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-15 15:38:37 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=93e0445e2c9980a3e5eb066d61682e84716972bb">93e0445e2c9980a3e5eb066d61682e84716972bb</a>
-<blockquote>
-<p>
- Delete gs_l2img.ps, and all references in makefiles and docs.<br>
-<br>
- This is dead code that apparently hasn't been used for years. It was<br>
- defining some things in systemdict (.colorspaceimage, .csinextbits)<br>
- that are now also gone.<br>
-<br>
-Resource/Init/gs_l2img.ps<br>
-doc/Develop.htm<br>
-doc/Psfiles.htm<br>
-psi/int.mak<br>
-psi/psromfs.mak<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-15 15:01:48 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a270eea5080ec418202dcb778c1215839123555">9a270eea5080ec418202dcb778c1215839123555</a>
-<blockquote>
-<p>
- Undef a bunch of image-related things<br>
-<br>
- If we get rid of display postscript, this simplifies to just getting rid of<br>
- the img_utils_dict, which contains all the things I have undefined.<br>
-<br>
-Resource/Init/gs_img.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-15 09:23:55 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e06edfb35e09d7e34d4c0c0a31931e28c4cd944d">e06edfb35e09d7e34d4c0c0a31931e28c4cd944d</a>
-<blockquote>
-<p>
- Undefine a bunch of functions<br>
-<br>
- undef .ProcessICCComment from gs_icc.ps<br>
-<br>
- Undef .rewriteTempMapsNotDef in gs_cmap.ps<br>
-<br>
- These are implemented in C code, so not associated with a particular ps file.<br>
-<br>
- /.currentmatrix /.setmatrix /.setdevicecolorrendering1<br>
- /.setlinecap /.setlinejoin /.sizeimagebox /.systemvmcheck<br>
-<br>
-Resource/Init/gs_cmap.ps<br>
-Resource/Init/gs_icc.ps<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-20 12:59:06 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b7ee393b7afb0d584528173d98fe0509d1ea09ff">b7ee393b7afb0d584528173d98fe0509d1ea09ff</a>
-<blockquote>
-<p>
- Remove needless macros in plmain.c<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-19 17:23:02 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c0de6c578f685c03d21c2a5d934734081265d10e">c0de6c578f685c03d21c2a5d934734081265d10e</a>
-<blockquote>
-<p>
- Function cleanup - NULL pointers after free<br>
-<br>
- The PostScript code seems to get away with this, but for the PDF<br>
- interpreter we need the object pointed to by the various 'params'<br>
- structure members to be NULL after they are freed, so that we don't<br>
- try to free memory which has already been freed.<br>
-<br>
-base/gsfunc.c<br>
-base/gsfunc0.c<br>
-base/gsfunc3.c<br>
-base/gsfunc4.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-19 09:28: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=af39fde7b765ea5550a857290d68f58468086a8c">af39fde7b765ea5550a857290d68f58468086a8c</a>
-<blockquote>
-<p>
- Coverity CIDs: 326829, 326828 and 326827<br>
-<br>
- Check return values for gdev_prn_open_printer()<br>
-<br>
-contrib/gdevgdi.c<br>
-contrib/japanese/gdevrpdl.c<br>
-devices/gdevdjet.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-19 09:00:54 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d98293c72cc5b5fe456065a3252d39e9ab28e4d">4d98293c72cc5b5fe456065a3252d39e9ab28e4d</a>
-<blockquote>
-<p>
- Coverity ID 327264 - move pointer NULL check<br>
-<br>
- Due to recent changes in this code, the pointer was being dereferenced<br>
- before we checked it to see if it was NULL. Moe the check so that we<br>
- check for NULL before dereferencing.<br>
-<br>
- The 'pvalue' of the operand can be NULL, even if the object is a t_device<br>
- type, because invalidate_stack_devices traverses the operand stack<br>
- looking for devices, and sets their pvalue member to NULL in order to<br>
- invalidate them so that they cannot be used.<br>
-<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-17 11:20: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=867deb44ce59102b3c817b8228d9cbfd9d9b1fde">867deb44ce59102b3c817b8228d9cbfd9d9b1fde</a>
-<blockquote>
-<p>
- Check structure types when using the r_ptr macro<br>
-<br>
- Two more places where we were using the r_ptr macro to cast a PostScript<br>
- ref object into a structure without thoroughly checking that the object<br>
- was in fact a structure of the correct type.<br>
-<br>
- One case did a partial check, but this is more robust.<br>
-<br>
-base/gsfcid2.c<br>
-base/gsfcmap.c<br>
-psi/zdscpars.c<br>
-psi/zfcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-17 10:00:32 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aba438b1835c4c0f4c2b0aee5b7d8430d7e58251">aba438b1835c4c0f4c2b0aee5b7d8430d7e58251</a>
-<blockquote>
-<p>
- Coverity ID 94865<br>
-<br>
- This had already been tackled, but it turns out there were a couple<br>
- more places where tempnames wasn't freed, but Coverity only seems to<br>
- flag them one at a time.<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-17 09:37:07 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5cfe86c6f37f4838746d7cc7e9e6125538af6e84">5cfe86c6f37f4838746d7cc7e9e6125538af6e84</a>
-<blockquote>
-<p>
- Coverity ID 323322<br>
-<br>
- The new 'transform_pixel_region' method default for forwarding devices<br>
- tests the target device to see if its NULL (some forwarding devices are<br>
- not always forwarding devices, eg bbox), and if it is NULL then instead<br>
- of passing the call to the target device it calls the graphics library<br>
- default.<br>
-<br>
- Unfortunately it was passing the target device as an argument, and this<br>
- is now certain to be NULL. In gx_default_transform_pixel_region_begin()<br>
- we then dereference the pointer which would cause a crash.<br>
-<br>
- So instead, pass the device itself when its not actually a forwarding<br>
- device.<br>
-<br>
- Also, some white space changes.<br>
-<br>
-base/gdevnfwd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-16 17:56:46 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79a6bb7c5e33e0acf281bf7f34e6c6cc20c2549c">79a6bb7c5e33e0acf281bf7f34e6c6cc20c2549c</a>
-<blockquote>
-<p>
- Bug 700205: Bring jbig2dec's copy of memento up to date.<br>
-<br>
-jbig2dec/memento.c<br>
-jbig2dec/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-03 13:07:29 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bd6af85222da668b56a1815fefc374b2096029b5">bd6af85222da668b56a1815fefc374b2096029b5</a>
-<blockquote>
-<p>
- Sync Memento from MuPDF.<br>
-<br>
- * pointer checking functions.<br>
-<br>
- Add some helpful functions for doing quick checks on pointer validity.<br>
- Use these in the reference counting functions.<br>
-<br>
- * make ref counting advance events.<br>
-<br>
- * misc sizeof fixes.<br>
-<br>
-base/memento.c<br>
-base/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-19 17:27:11 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7750a48097a387a006577a02e20e2673a77fc82f">7750a48097a387a006577a02e20e2673a77fc82f</a>
-<blockquote>
-<p>
- Update language recognition mechanism.<br>
-<br>
- Rather than each language implementation offering a single string<br>
- to be matched, they now offer a function to match the given<br>
- string.<br>
-<br>
- This allows us to have the PJL recognising routine accept a<br>
- single &lt;CR&gt;&lt;LF&gt; at the top of a PJL block.<br>
-<br>
- Technically, this is against the spec, which very clearly says<br>
- that any UEL must be followed instantly by &quot;@PJL&quot; rather than<br>
- there being any whitespace there. Sadly, the file from bug 693269<br>
- sends UEL&lt;CR&gt;&lt;LF&gt;@PJL... and so outputs a page of PJL in the<br>
- middle of the job without this fix.<br>
-<br>
- Tests on Henry's HP printer show that his printer at least matches<br>
- this behaviour.<br>
-<br>
- It is hard to see that there can be that many real world files out<br>
- there that will be adversely affected by this fix.<br>
-<br>
- This means we now behave the same on bug 693269 as we did prior to<br>
- making our language switching actually switching languages.<br>
-<br>
-gpdl/psi/psitop.c<br>
-pcl/pcl/pctop.c<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/pltop.c<br>
-pcl/pl/pltop.h<br>
-pcl/pxl/pxtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-15 15:24:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=46d3a9a658f3b92e554cffc3c2ace8c140118155">46d3a9a658f3b92e554cffc3c2ace8c140118155</a>
-<blockquote>
-<p>
- PS interpreter - check infinite result on exp, where possible<br>
-<br>
- Bug #700181 &quot;using exp with 0 as base&quot; (again)<br>
-<br>
- The reporter for the bug failed to mention this condition in the<br>
- original report. Technically we don't always have isinf() available<br>
- (I suspect all real compilers do these days) but where we do we can<br>
- check the result. Where we don't, we're stuck. This mimics the<br>
- behaviour of other math operations in Ghostscript.<br>
-<br>
-psi/zmath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-15 14:18:17 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1218b59561ba950e212ad4e585bd7b0612eb2102">1218b59561ba950e212ad4e585bd7b0612eb2102</a>
-<blockquote>
-<p>
- PDF interpreter - use Appearance streams for highlight annotations<br>
-<br>
- We were previously never using the Appearance stream for a highlight<br>
- annotation, which is documented as incorrect in the PDF 2.0 spec.<br>
-<br>
- The reason we were not using it is because a very few PDF files render<br>
- differently if we do. This is because Acrobat 'sometimes', and I cannot<br>
- figure out the conditions for htis, ignores a perfectly valid Appearance<br>
- and generates a new one.<br>
-<br>
- In this case a customer produced a file where the QuadPoints entry is<br>
- incorrect. If we use the Appearance stream (as Acrobat does) then the<br>
- rendering is correct. If we generate an appearance then, because the<br>
- QuadPoints are incorrect, the rendering is incorrect.<br>
-<br>
- Since the PDF 2.0 specification now makes it clear that we should be<br>
- using a supplied Appearance stream, I've chosen to change the behaviour<br>
- so that we do.<br>
-<br>
- I've also made the text for an appearance stream slightly more robust<br>
- and general.<br>
-<br>
- This does produce a few diffs, because of the afore-mentioned files. In<br>
- my opinion Acrobat is incorrect in how it treats these files. Our new<br>
- rendering is correct.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 21:04:46 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea1b3ef437f39e45874f821c06bd953196625ac5">ea1b3ef437f39e45874f821c06bd953196625ac5</a>
-<blockquote>
-<p>
- Bug 700176: Use the actual output device for both devices in setdevice<br>
-<br>
- Also fixes bug 700189.<br>
-<br>
- The pdf14 compositor device, despite being a forwarding device, does not forward<br>
- all spec_ops to it's target, only a select few are special cased for that.<br>
- gxdso_current_output_device needs to be included in those special cases.<br>
-<br>
- The original commit (661e8d8fb8248) changed the code to use the spec_op to<br>
- retrieve the output device, checking that for LockSafetyParams. If<br>
- LockSafetyParams is set, it returns an invalidaccess error if the new device<br>
- differs from the current device.<br>
-<br>
- When we do the comparison between the two devices, we need to check the<br>
- output device in both cases.<br>
-<br>
- This is complicated by the fact that the new device may not have ever been set<br>
- (and thus fully initialised), and may not have a spec_op method available at<br>
- that point.<br>
-<br>
-base/gdevp14.c<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-13 14:23:41 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fe4c47d8e25d6366ecbb5ff487348148b908a89e">fe4c47d8e25d6366ecbb5ff487348148b908a89e</a>
-<blockquote>
-<p>
- Undefine some level2-related operators<br>
-<br>
- These are only a partial set. Undefine them in both the level2dict and<br>
- systemdict. They are undef'd in gs_init.ps because they are used outside<br>
- the scope of just gs_lev2.ps<br>
-<br>
- /.execform1<br>
- /.getdevparams<br>
- /.setuserparams2<br>
- /.startjob<br>
- /.checkFilePermitparams<br>
- /.checksetparams<br>
- /.copyparam<br>
- /.setpagesize<br>
-<br>
- Rename .dict1 to .pair2dict and use immediate reference.<br>
-<br>
- Undef these at end of gs_lev2.ps (should never make it into systemdict):<br>
- /.pair2dict<br>
- /.checkprocesscomment<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_lev2.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 17:37:02 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=66a273de3ca0560bd41a2448b264d78f9316ba6a">66a273de3ca0560bd41a2448b264d78f9316ba6a</a>
-<blockquote>
-<p>
- Fix PCL handling of slightly malformed PJL.<br>
-<br>
- We parse the PJL lines in, and if we find a terminator character<br>
- other than '\n', we ignore the line. What is worse, we eat the<br>
- character that we trip over, so that if it (say) happened to be<br>
- an ESC, we then don't process the next command correctly.<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 16:01:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=965a557a4cdc8f45ff962616b884c281abd6c72c">965a557a4cdc8f45ff962616b884c281abd6c72c</a>
-<blockquote>
-<p>
- PS interpreter - in seticcspace, ensure the ICC dictionary is a dict<br>
-<br>
- From a review of dict_find_string, that function does not check to see<br>
- if the object it is passed as an argument is a dictionary, so its<br>
- essential to make sure the argument is checked before calling.<br>
-<br>
- This is the only remaining case I could find.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-13 04:18:21 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f1756124f0f3c542bd6c2a9b325dea6bf860fc61">f1756124f0f3c542bd6c2a9b325dea6bf860fc61</a>
-<blockquote>
-<p>
- jbig2dec: Only print repeated error/warning messages once.<br>
-<br>
-base/sjbig2.c<br>
-base/sjbig2.h<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 14:28:48 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bcb605e49dbe306ba881818466f8be591510a9ab">bcb605e49dbe306ba881818466f8be591510a9ab</a>
-<blockquote>
-<p>
- PS interpreter - Throw error from exp when base is 0 and -ve exponent<br>
-<br>
- Bug #700181 &quot;using exp with 0 as base&quot;<br>
-<br>
- If base is 0, and exp is negative, then the result of exp is undefined<br>
- we should throw an error instead of pushing #INF.0 on the stack.<br>
-<br>
-psi/zmath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 13:32:43 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a982079dabc985bbd26d69322f517495158e882">9a982079dabc985bbd26d69322f517495158e882</a>
-<blockquote>
-<p>
- Update .gitattributes file.<br>
-<br>
- Stolen largely from MuPDF's file. This should keep the tabs in<br>
- Makefiles from confusing things.<br>
-<br>
-.gitattributes<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 13:15:11 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa3ac5d4cfea23ddc4eed64fd6f552013019ad1a">fa3ac5d4cfea23ddc4eed64fd6f552013019ad1a</a>
-<blockquote>
-<p>
- MSVC: Remove #define for fstat from unistd.h<br>
-<br>
- We already define it in stat_.h, which seems like a much more sensible<br>
- place.<br>
-<br>
-base/unistd_.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 09:50:08 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=661e8d8fb8248c38d67958beda32f3a5876d0c3f">661e8d8fb8248c38d67958beda32f3a5876d0c3f</a>
-<blockquote>
-<p>
- Bug 700176: check the *output* device for LockSafetyParams<br>
-<br>
- When calling .setdevice we were checking if LockSafetyParams was set, and if so<br>
- throwing an invalidaccess error.<br>
-<br>
- The problem is, if another device, for example the pdf14 compositor is the 'top'<br>
- device, that does not (and cannot) honour LockSafetyParams.<br>
-<br>
- To solve this, we'll now use the (relatively new) gxdso_current_output_device<br>
- spec_op to retrieve the *actual* output device, and check the LockSafetyParams<br>
- flag in that.<br>
-<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 09:31:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a1b3ac61761094713f44dedfce56013308a3b1d">9a1b3ac61761094713f44dedfce56013308a3b1d</a>
-<blockquote>
-<p>
- PS interpreter - add some type checking<br>
-<br>
- These were 'probably' safe anyway, since they mostly treat the objects<br>
- as integers without checking, which at least can't result in a crash.<br>
-<br>
- Nevertheless, we ought to check.<br>
-<br>
- The return from comparedictkeys could be wrong if one of the keys had<br>
- a value which was not an array, it could incorrectly decide the two<br>
- were in fact the same.<br>
-<br>
-psi/zbfont.c<br>
-psi/zcolor.c<br>
-psi/zcrd.c<br>
-psi/zfjpx.c<br>
-psi/zfont.c<br>
-psi/zfont0.c<br>
-psi/zimage3.c<br>
-psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 09:27: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=606a22e77e7f081781e99e44644cd0119f559e03">606a22e77e7f081781e99e44644cd0119f559e03</a>
-<blockquote>
-<p>
- Bug #700168 - add a type check<br>
-<br>
- Bug #700168 &quot;Type confusion in JBIG2Decode&quot;<br>
-<br>
- The code was assuming that .jbig2globalctx was a structure allocated<br>
- by the graphics library, without checking.<br>
-<br>
- Add a check to see that it is a structure and that its the correct<br>
- type of structure.<br>
-<br>
-psi/zfjbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 09:25: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=434753adbe8be5534bfb9b7d91746023e8073d16">434753adbe8be5534bfb9b7d91746023e8073d16</a>
-<blockquote>
-<p>
- Bug #700169 - unchecked type<br>
-<br>
- Bug #700169 &quot;Type confusion in setcolorspace&quot;<br>
-<br>
- In seticc() we extract &quot;Name&quot; from a dictionary, if it succeeds we then<br>
- use it as a string, without checking the type to see if it is in fact<br>
- a string.<br>
-<br>
- Add a check on the type, and add a couple to check that 'N' is an integer<br>
- in a few places too.<br>
-<br>
-psi/zicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-07 15:03:48 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f168df2845e15e5f87232317472d09ad1b2f1a3">4f168df2845e15e5f87232317472d09ad1b2f1a3</a>
-<blockquote>
-<p>
- Move a bunch of existing undef's up to the array with the others.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-08 15:34:38 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b7e7a76098c33e04e22464b6278c68a02b3d39b0">b7e7a76098c33e04e22464b6278c68a02b3d39b0</a>
-<blockquote>
-<p>
- Undefined a bunch of EPS things<br>
-<br>
-Resource/Init/gs_epsf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-07 15:00:27 -0800
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6f8b9869b38909700dcf906332d8825a6c390765">6f8b9869b38909700dcf906332d8825a6c390765</a>
-<blockquote>
-<p>
- Remove .endjob, which is not used anywhere<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-12 17:21: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=aeea342904978c9fe17d85f4906a0f6fcce2d315">aeea342904978c9fe17d85f4906a0f6fcce2d315</a>
-<blockquote>
-<p>
- Bug 700153: restore: always check available stack<br>
-<br>
- Previously, we were checking there was enough stack space available when the<br>
- restore operation required a device change, but since we have to use<br>
- Postscript to reset the userparams (ick!), we need the stack check even when<br>
- not changing the device.<br>
-<br>
-psi/zdevice2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-07 12:22:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2dceb0400c5a571f23070891b8a8028d04926de1">2dceb0400c5a571f23070891b8a8028d04926de1</a>
-<blockquote>
-<p>
- Contrib devices: Check for error return opening output file<br>
-<br>
- 09-59.PS cycles through every available device, attempting to open each one.<br>
-<br>
- For many devices this results in an invalid configuration (mainly a lack of<br>
- output file).<br>
-<br>
- These devices, on being shutdown, ignored the lack of output file, and attempted<br>
- to write their final bytes out anyway (attempting to write data to a null<br>
- FILE * pointer), causing a segfault.<br>
-<br>
- We now check the return value of gdev_prn_open_printer() and only write those<br>
- final bytes if gdev_prn_open_printer() completed successfully.<br>
-<br>
-contrib/japanese/gdevespg.c<br>
-contrib/japanese/gdevnpdl.c<br>
-contrib/lips4/gdevl4r.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-08 14:43:32 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=693baf02152119af6e6afd30bb8ec76d14f84bbf">693baf02152119af6e6afd30bb8ec76d14f84bbf</a>
-<blockquote>
-<p>
- PS interpreter - check the Implementation of a Pattern before use<br>
-<br>
- Bug #700141 &quot;Type confusion in setpattern&quot;<br>
-<br>
- As the bug thread says, we were not checking that the Implementation<br>
- of a pattern dictionary was a structure type, leading to a crash when<br>
- we tried to treat it as one.<br>
-<br>
- Here we make the st_pattern1_instance and st_pattern2_instance<br>
- structures public definitions and in zsetcolor we check the object<br>
- stored under the Implementation key in the supplied dictionary to see if<br>
- its a t_struct or t_astruct type, and if it is that its a<br>
- st_pattern1_instance or st_pattern2_instance structure.<br>
-<br>
- If either check fails we throw a typecheck error.<br>
-<br>
- We need to make the st_pattern1_instance and st_pattern2_instance<br>
- definitions public as they are defined in the graphics library and we<br>
- need to check in the interpreter.<br>
-<br>
-base/gsptype1.c<br>
-base/gsptype2.c<br>
-base/gsptype2.h<br>
-base/gxcolor2.h<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-08 12:58:28 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=81f3d1e7247b9a8e29a388677b01959e612a28c7">81f3d1e7247b9a8e29a388677b01959e612a28c7</a>
-<blockquote>
-<p>
- Fix missing images due to transform_pixel_region and pattern_accumulator.<br>
-<br>
- The pattern_accumulator was defaulting to the forwarding version<br>
- of transform_pixel_region, which was only dealing with the image<br>
- plane, not the mask. Accordingly nothing was being plotted.<br>
-<br>
- Instead, use the default, which devolves to copy_color (for the<br>
- image data) and fill_rectangle (for the mask).<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-07 15:59:32 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5a4fec2a34af925993192e197ab666fe542b79d3">5a4fec2a34af925993192e197ab666fe542b79d3</a>
-<blockquote>
-<p>
- Bump version number for release<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-20 09:51:17 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8efbedbab72687cb51e3c353d5665d00120eed4a">8efbedbab72687cb51e3c353d5665d00120eed4a</a>
-<blockquote>
-<p>
- Dates, changelog, etc for 9.26 release<br>
-<br>
-base/gscdef.c<br>
-base/version.mak<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-11-19 09:28: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=e5978ae6d1e4f3dee0a2838ed580b0373e102613">e5978ae6d1e4f3dee0a2838ed580b0373e102613</a>
-<blockquote>
-<p>
- Coverity CIDs: 326829, 326828 and 326827<br>
-<br>
- Check return values for gdev_prn_open_printer()<br>
-<br>
-contrib/gdevgdi.c<br>
-contrib/japanese/gdevrpdl.c<br>
-devices/gdevdjet.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-19 09:00:54 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a4228a0d8d657fca3bb3becb93a43fae061beae8">a4228a0d8d657fca3bb3becb93a43fae061beae8</a>
-<blockquote>
-<p>
- Coverity ID 327264 - move pointer NULL check<br>
-<br>
- Due to recent changes in this code, the pointer was being dereferenced<br>
- before we checked it to see if it was NULL. Moe the check so that we<br>
- check for NULL before dereferencing.<br>
-<br>
- The 'pvalue' of the operand can be NULL, even if the object is a t_device<br>
- type, because invalidate_stack_devices traverses the operand stack<br>
- looking for devices, and sets their pvalue member to NULL in order to<br>
- invalidate them so that they cannot be used.<br>
-<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-17 11:20: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=c796ccb512ac581f5ac492fda8807d41769c47e8">c796ccb512ac581f5ac492fda8807d41769c47e8</a>
-<blockquote>
-<p>
- Check structure types when using the r_ptr macro<br>
-<br>
- Two more places where we were using the r_ptr macro to cast a PostScript<br>
- ref object into a structure without thoroughly checking that the object<br>
- was in fact a structure of the correct type.<br>
-<br>
- One case did a partial check, but this is more robust.<br>
-<br>
-base/gsfcid2.c<br>
-base/gsfcmap.c<br>
-psi/zdscpars.c<br>
-psi/zfcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-17 10:00:32 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cb9bb72643e95383bcacd88ab718565f3df9a510">cb9bb72643e95383bcacd88ab718565f3df9a510</a>
-<blockquote>
-<p>
- Coverity ID 94865<br>
-<br>
- This had already been tackled, but it turns out there were a couple<br>
- more places where tempnames wasn't freed, but Coverity only seems to<br>
- flag them one at a time.<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-17 09:37:07 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c69827c308b608719d786fc14c8518af4dd6b335">c69827c308b608719d786fc14c8518af4dd6b335</a>
-<blockquote>
-<p>
- Coverity ID 323322<br>
-<br>
- The new 'transform_pixel_region' method default for forwarding devices<br>
- tests the target device to see if its NULL (some forwarding devices are<br>
- not always forwarding devices, eg bbox), and if it is NULL then instead<br>
- of passing the call to the target device it calls the graphics library<br>
- default.<br>
-<br>
- Unfortunately it was passing the target device as an argument, and this<br>
- is now certain to be NULL. In gx_default_transform_pixel_region_begin()<br>
- we then dereference the pointer which would cause a crash.<br>
-<br>
- So instead, pass the device itself when its not actually a forwarding<br>
- device.<br>
-<br>
- Also, some white space changes.<br>
-<br>
-base/gdevnfwd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-15 15:24:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4548ceaf5ada7f7a4c4da5907e27fec62c1ce63d">4548ceaf5ada7f7a4c4da5907e27fec62c1ce63d</a>
-<blockquote>
-<p>
- PS interpreter - check infinite result on exp, where possible<br>
-<br>
- Bug #700181 &quot;using exp with 0 as base&quot; (again)<br>
-<br>
- The reporter for the bug failed to mention this condition in the<br>
- original report. Technically we don't always have isinf() available<br>
- (I suspect all real compilers do these days) but where we do we can<br>
- check the result. Where we don't, we're stuck. This mimics the<br>
- behaviour of other math operations in Ghostscript.<br>
-<br>
-psi/zmath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-15 14:18:17 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a4e3cb230bfdbf9cb5a0d30763889e58f8215ed1">a4e3cb230bfdbf9cb5a0d30763889e58f8215ed1</a>
-<blockquote>
-<p>
- PDF interpreter - use Appearance streams for highlight annotations<br>
-<br>
- We were previously never using the Appearance stream for a highlight<br>
- annotation, which is documented as incorrect in the PDF 2.0 spec.<br>
-<br>
- The reason we were not using it is because a very few PDF files render<br>
- differently if we do. This is because Acrobat 'sometimes', and I cannot<br>
- figure out the conditions for htis, ignores a perfectly valid Appearance<br>
- and generates a new one.<br>
-<br>
- In this case a customer produced a file where the QuadPoints entry is<br>
- incorrect. If we use the Appearance stream (as Acrobat does) then the<br>
- rendering is correct. If we generate an appearance then, because the<br>
- QuadPoints are incorrect, the rendering is incorrect.<br>
-<br>
- Since the PDF 2.0 specification now makes it clear that we should be<br>
- using a supplied Appearance stream, I've chosen to change the behaviour<br>
- so that we do.<br>
-<br>
- I've also made the text for an appearance stream slightly more robust<br>
- and general.<br>
-<br>
- This does produce a few diffs, because of the afore-mentioned files. In<br>
- my opinion Acrobat is incorrect in how it treats these files. Our new<br>
- rendering is correct.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 21:04:46 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e8be28b49c6a43db1861119288933b5a8fdbef73">e8be28b49c6a43db1861119288933b5a8fdbef73</a>
-<blockquote>
-<p>
- Bug 700176: Use the actual output device for both devices in setdevice<br>
-<br>
- Also fixes bug 700189.<br>
-<br>
- The pdf14 compositor device, despite being a forwarding device, does not forward<br>
- all spec_ops to it's target, only a select few are special cased for that.<br>
- gxdso_current_output_device needs to be included in those special cases.<br>
-<br>
- The original commit (661e8d8fb8248) changed the code to use the spec_op to<br>
- retrieve the output device, checking that for LockSafetyParams. If<br>
- LockSafetyParams is set, it returns an invalidaccess error if the new device<br>
- differs from the current device.<br>
-<br>
- When we do the comparison between the two devices, we need to check the<br>
- output device in both cases.<br>
-<br>
- This is complicated by the fact that the new device may not have ever been set<br>
- (and thus fully initialised), and may not have a spec_op method available at<br>
- that point.<br>
-<br>
-base/gdevp14.c<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 16:01:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5db929cf393fa330bf916da37f5d2a5954a3b0c3">5db929cf393fa330bf916da37f5d2a5954a3b0c3</a>
-<blockquote>
-<p>
- PS interpreter - in seticcspace, ensure the ICC dictionary is a dict<br>
-<br>
- From a review of dict_find_string, that function does not check to see<br>
- if the object it is passed as an argument is a dictionary, so its<br>
- essential to make sure the argument is checked before calling.<br>
-<br>
- This is the only remaining case I could find.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-13 04:18:21 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a92e38603902b22c5b20fecefa5da3d2a233516c">a92e38603902b22c5b20fecefa5da3d2a233516c</a>
-<blockquote>
-<p>
- jbig2dec: Only print repeated error/warning messages once.<br>
-<br>
-base/sjbig2.c<br>
-base/sjbig2.h<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 14:28:48 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3bb28e08002ef4a90bddb05aa6cd06a256153663">3bb28e08002ef4a90bddb05aa6cd06a256153663</a>
-<blockquote>
-<p>
- PS interpreter - Throw error from exp when base is 0 and -ve exponent<br>
-<br>
- Bug #700181 &quot;using exp with 0 as base&quot;<br>
-<br>
- If base is 0, and exp is negative, then the result of exp is undefined<br>
- we should throw an error instead of pushing #INF.0 on the stack.<br>
-<br>
-psi/zmath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 09:50:08 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=35766ceb3b28aad95bd63655b1d621a82d3a5b06">35766ceb3b28aad95bd63655b1d621a82d3a5b06</a>
-<blockquote>
-<p>
- Bug 700176: check the *output* device for LockSafetyParams<br>
-<br>
- When calling .setdevice we were checking if LockSafetyParams was set, and if so<br>
- throwing an invalidaccess error.<br>
-<br>
- The problem is, if another device, for example the pdf14 compositor is the 'top'<br>
- device, that does not (and cannot) honour LockSafetyParams.<br>
-<br>
- To solve this, we'll now use the (relatively new) gxdso_current_output_device<br>
- spec_op to retrieve the *actual* output device, and check the LockSafetyParams<br>
- flag in that.<br>
-<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 09:31:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=548bb434e81dadcc9f71adf891a3ef5bea8e2b4e">548bb434e81dadcc9f71adf891a3ef5bea8e2b4e</a>
-<blockquote>
-<p>
- PS interpreter - add some type checking<br>
-<br>
- These were 'probably' safe anyway, since they mostly treat the objects<br>
- as integers without checking, which at least can't result in a crash.<br>
-<br>
- Nevertheless, we ought to check.<br>
-<br>
- The return from comparedictkeys could be wrong if one of the keys had<br>
- a value which was not an array, it could incorrectly decide the two<br>
- were in fact the same.<br>
-<br>
-psi/zbfont.c<br>
-psi/zcolor.c<br>
-psi/zcrd.c<br>
-psi/zfjpx.c<br>
-psi/zfont.c<br>
-psi/zfont0.c<br>
-psi/zimage3.c<br>
-psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 09:27: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=ef252e7dc214bcbd9a2539216aab9202848602bb">ef252e7dc214bcbd9a2539216aab9202848602bb</a>
-<blockquote>
-<p>
- Bug #700168 - add a type check<br>
-<br>
- Bug #700168 &quot;Type confusion in JBIG2Decode&quot;<br>
-<br>
- The code was assuming that .jbig2globalctx was a structure allocated<br>
- by the graphics library, without checking.<br>
-<br>
- Add a check to see that it is a structure and that its the correct<br>
- type of structure.<br>
-<br>
-psi/zfjbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 09:25: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=67d760ab775dae4efe803b5944b0439aa3c0b04a">67d760ab775dae4efe803b5944b0439aa3c0b04a</a>
-<blockquote>
-<p>
- Bug #700169 - unchecked type<br>
-<br>
- Bug #700169 &quot;Type confusion in setcolorspace&quot;<br>
-<br>
- In seticc() we extract &quot;Name&quot; from a dictionary, if it succeeds we then<br>
- use it as a string, without checking the type to see if it is in fact<br>
- a string.<br>
-<br>
- Add a check on the type, and add a couple to check that 'N' is an integer<br>
- in a few places too.<br>
-<br>
-psi/zicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-12 17:21: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=3005fcb9bb160af199e761e03bc70a9f249a987e">3005fcb9bb160af199e761e03bc70a9f249a987e</a>
-<blockquote>
-<p>
- Bug 700153: restore: always check available stack<br>
-<br>
- Previously, we were checking there was enough stack space available when the<br>
- restore operation required a device change, but since we have to use<br>
- Postscript to reset the userparams (ick!), we need the stack check even when<br>
- not changing the device.<br>
-<br>
-psi/zdevice2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-07 12:22:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f99c138cf60d75621eb03ae924453b968274694">2f99c138cf60d75621eb03ae924453b968274694</a>
-<blockquote>
-<p>
- Contrib devices: Check for error return opening output file<br>
-<br>
- 09-59.PS cycles through every available device, attempting to open each one.<br>
-<br>
- For many devices this results in an invalid configuration (mainly a lack of<br>
- output file).<br>
-<br>
- These devices, on being shutdown, ignored the lack of output file, and attempted<br>
- to write their final bytes out anyway (attempting to write data to a null<br>
- FILE * pointer), causing a segfault.<br>
-<br>
- We now check the return value of gdev_prn_open_printer() and only write those<br>
- final bytes if gdev_prn_open_printer() completed successfully.<br>
-<br>
-contrib/japanese/gdevespg.c<br>
-contrib/japanese/gdevnpdl.c<br>
-contrib/lips4/gdevl4r.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-08 14:43:32 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7c8f85a23db24031945af3cacb2c0b4740e67072">7c8f85a23db24031945af3cacb2c0b4740e67072</a>
-<blockquote>
-<p>
- PS interpreter - check the Implementation of a Pattern before use<br>
-<br>
- Bug #700141 &quot;Type confusion in setpattern&quot;<br>
-<br>
- As the bug thread says, we were not checking that the Implementation<br>
- of a pattern dictionary was a structure type, leading to a crash when<br>
- we tried to treat it as one.<br>
-<br>
- Here we make the st_pattern1_instance and st_pattern2_instance<br>
- structures public definitions and in zsetcolor we check the object<br>
- stored under the Implementation key in the supplied dictionary to see if<br>
- its a t_struct or t_astruct type, and if it is that its a<br>
- st_pattern1_instance or st_pattern2_instance structure.<br>
-<br>
- If either check fails we throw a typecheck error.<br>
-<br>
- We need to make the st_pattern1_instance and st_pattern2_instance<br>
- definitions public as they are defined in the graphics library and we<br>
- need to check in the interpreter.<br>
-<br>
-base/gsptype1.c<br>
-base/gsptype2.c<br>
-base/gsptype2.h<br>
-base/gxcolor2.h<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-08 12:58:28 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d6e2125d402033d9073bae3ccde1d95eb3ebc22">4d6e2125d402033d9073bae3ccde1d95eb3ebc22</a>
-<blockquote>
-<p>
- Fix missing images due to transform_pixel_region and pattern_accumulator.<br>
-<br>
- The pattern_accumulator was defaulting to the forwarding version<br>
- of transform_pixel_region, which was only dealing with the image<br>
- plane, not the mask. Accordingly nothing was being plotted.<br>
-<br>
- Instead, use the default, which devolves to copy_color (for the<br>
- image data) and fill_rectangle (for the mask).<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-07 16:03:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e477875e170d738d7ea1497e1489a6d344c3ef29">e477875e170d738d7ea1497e1489a6d344c3ef29</a>
-<blockquote>
-<p>
- Dates, change log, etc for 9.26 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>
-<hr size=20>
-<h2><a name="Version9.26"></a>Version 9.26 (2018-11-20)</h2>
-<p> Highlights in this release include:
-<ul>
-<li>
-<p>Security issues have been the primary focus of this release, including solving
-several (well publicised) real and potential exploits.
-<br>
-<p> <big><u><b>PLEASE NOTE:</b> We <b>strongly</b> urge users to upgrade to this latest
-release to avoid these issues.</u></big>
-</li>
-<li>
-<p>IMPORTANT: We are in the process of forking LittleCMS. LCMS2 is not thread safe, and
-cannot be made thread safe without breaking the ABI. Our fork will be thread safe, and include
-performance enhancements (these changes have all be been offered and rejected upstream). We
-will maintain compatibility between Ghostscript and LCMS2 for a time, but not in perpetuity.
-Our fork will be available as its own package separately from Ghostscript (and MuPDF).
-</li>
-<li>
-<p>Thanks to Man Yue Mo of Semmle Security Research Team, Jens M&uuml;ller of
-Ruhr-Universit&auml;t Bochum and Tavis Ormandy of Google's Project Zero for their help to
-identify specific security issues.
-</li>
-<li>
-<p>The usual round of bug fixes, compatibility changes, and incremental improvements.
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.26_Incompatible_changes"></a>Incompatible changes</h3>
-<ul>
-<li>
-<p>None
-</li>
-</ul>
-<h3><a name="9.26_changelog"></a>Changelog</h3>
-<p><strong>2018-11-20 09:51:17 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d66acfae372e39e8cbc4ce6395b4451cac72516e">d66acfae372e39e8cbc4ce6395b4451cac72516e</a>
-<blockquote>
-<p>
- Dates etc for 9.26 release<br>
-<br>
-base/gscdef.c<br>
-base/version.mak<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-11-19 09:28: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=e5978ae6d1e4f3dee0a2838ed580b0373e102613">e5978ae6d1e4f3dee0a2838ed580b0373e102613</a>
-<blockquote>
-<p>
- Coverity CIDs: 326829, 326828 and 326827<br>
-<br>
- Check return values for gdev_prn_open_printer()<br>
-<br>
-contrib/gdevgdi.c<br>
-contrib/japanese/gdevrpdl.c<br>
-devices/gdevdjet.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-19 09:00:54 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a4228a0d8d657fca3bb3becb93a43fae061beae8">a4228a0d8d657fca3bb3becb93a43fae061beae8</a>
-<blockquote>
-<p>
- Coverity ID 327264 - move pointer NULL check<br>
-<br>
- Due to recent changes in this code, the pointer was being dereferenced<br>
- before we checked it to see if it was NULL. Moe the check so that we<br>
- check for NULL before dereferencing.<br>
-<br>
- The 'pvalue' of the operand can be NULL, even if the object is a t_device<br>
- type, because invalidate_stack_devices traverses the operand stack<br>
- looking for devices, and sets their pvalue member to NULL in order to<br>
- invalidate them so that they cannot be used.<br>
-<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-17 11:20: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=c796ccb512ac581f5ac492fda8807d41769c47e8">c796ccb512ac581f5ac492fda8807d41769c47e8</a>
-<blockquote>
-<p>
- Check structure types when using the r_ptr macro<br>
-<br>
- Two more places where we were using the r_ptr macro to cast a PostScript<br>
- ref object into a structure without thoroughly checking that the object<br>
- was in fact a structure of the correct type.<br>
-<br>
- One case did a partial check, but this is more robust.<br>
-<br>
-base/gsfcid2.c<br>
-base/gsfcmap.c<br>
-psi/zdscpars.c<br>
-psi/zfcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-17 10:00:32 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cb9bb72643e95383bcacd88ab718565f3df9a510">cb9bb72643e95383bcacd88ab718565f3df9a510</a>
-<blockquote>
-<p>
- Coverity ID 94865<br>
-<br>
- This had already been tackled, but it turns out there were a couple<br>
- more places where tempnames wasn't freed, but Coverity only seems to<br>
- flag them one at a time.<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-17 09:37:07 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c69827c308b608719d786fc14c8518af4dd6b335">c69827c308b608719d786fc14c8518af4dd6b335</a>
-<blockquote>
-<p>
- Coverity ID 323322<br>
-<br>
- The new 'transform_pixel_region' method default for forwarding devices<br>
- tests the target device to see if its NULL (some forwarding devices are<br>
- not always forwarding devices, eg bbox), and if it is NULL then instead<br>
- of passing the call to the target device it calls the graphics library<br>
- default.<br>
-<br>
- Unfortunately it was passing the target device as an argument, and this<br>
- is now certain to be NULL. In gx_default_transform_pixel_region_begin()<br>
- we then dereference the pointer which would cause a crash.<br>
-<br>
- So instead, pass the device itself when its not actually a forwarding<br>
- device.<br>
-<br>
- Also, some white space changes.<br>
-<br>
-base/gdevnfwd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-15 15:24:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4548ceaf5ada7f7a4c4da5907e27fec62c1ce63d">4548ceaf5ada7f7a4c4da5907e27fec62c1ce63d</a>
-<blockquote>
-<p>
- PS interpreter - check infinite result on exp, where possible<br>
-<br>
- Bug #700181 &quot;using exp with 0 as base&quot; (again)<br>
-<br>
- The reporter for the bug failed to mention this condition in the<br>
- original report. Technically we don't always have isinf() available<br>
- (I suspect all real compilers do these days) but where we do we can<br>
- check the result. Where we don't, we're stuck. This mimics the<br>
- behaviour of other math operations in Ghostscript.<br>
-<br>
-psi/zmath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-15 14:18:17 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a4e3cb230bfdbf9cb5a0d30763889e58f8215ed1">a4e3cb230bfdbf9cb5a0d30763889e58f8215ed1</a>
-<blockquote>
-<p>
- PDF interpreter - use Appearance streams for highlight annotations<br>
-<br>
- We were previously never using the Appearance stream for a highlight<br>
- annotation, which is documented as incorrect in the PDF 2.0 spec.<br>
-<br>
- The reason we were not using it is because a very few PDF files render<br>
- differently if we do. This is because Acrobat 'sometimes', and I cannot<br>
- figure out the conditions for htis, ignores a perfectly valid Appearance<br>
- and generates a new one.<br>
-<br>
- In this case a customer produced a file where the QuadPoints entry is<br>
- incorrect. If we use the Appearance stream (as Acrobat does) then the<br>
- rendering is correct. If we generate an appearance then, because the<br>
- QuadPoints are incorrect, the rendering is incorrect.<br>
-<br>
- Since the PDF 2.0 specification now makes it clear that we should be<br>
- using a supplied Appearance stream, I've chosen to change the behaviour<br>
- so that we do.<br>
-<br>
- I've also made the text for an appearance stream slightly more robust<br>
- and general.<br>
-<br>
- This does produce a few diffs, because of the afore-mentioned files. In<br>
- my opinion Acrobat is incorrect in how it treats these files. Our new<br>
- rendering is correct.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 21:04:46 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e8be28b49c6a43db1861119288933b5a8fdbef73">e8be28b49c6a43db1861119288933b5a8fdbef73</a>
-<blockquote>
-<p>
- Bug 700176: Use the actual output device for both devices in setdevice<br>
-<br>
- Also fixes bug 700189.<br>
-<br>
- The pdf14 compositor device, despite being a forwarding device, does not forward<br>
- all spec_ops to it's target, only a select few are special cased for that.<br>
- gxdso_current_output_device needs to be included in those special cases.<br>
-<br>
- The original commit (661e8d8fb8248) changed the code to use the spec_op to<br>
- retrieve the output device, checking that for LockSafetyParams. If<br>
- LockSafetyParams is set, it returns an invalidaccess error if the new device<br>
- differs from the current device.<br>
-<br>
- When we do the comparison between the two devices, we need to check the<br>
- output device in both cases.<br>
-<br>
- This is complicated by the fact that the new device may not have ever been set<br>
- (and thus fully initialised), and may not have a spec_op method available at<br>
- that point.<br>
-<br>
-base/gdevp14.c<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 16:01:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5db929cf393fa330bf916da37f5d2a5954a3b0c3">5db929cf393fa330bf916da37f5d2a5954a3b0c3</a>
-<blockquote>
-<p>
- PS interpreter - in seticcspace, ensure the ICC dictionary is a dict<br>
-<br>
- From a review of dict_find_string, that function does not check to see<br>
- if the object it is passed as an argument is a dictionary, so its<br>
- essential to make sure the argument is checked before calling.<br>
-<br>
- This is the only remaining case I could find.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-13 04:18:21 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a92e38603902b22c5b20fecefa5da3d2a233516c">a92e38603902b22c5b20fecefa5da3d2a233516c</a>
-<blockquote>
-<p>
- jbig2dec: Only print repeated error/warning messages once.<br>
-<br>
-base/sjbig2.c<br>
-base/sjbig2.h<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 14:28:48 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3bb28e08002ef4a90bddb05aa6cd06a256153663">3bb28e08002ef4a90bddb05aa6cd06a256153663</a>
-<blockquote>
-<p>
- PS interpreter - Throw error from exp when base is 0 and -ve exponent<br>
-<br>
- Bug #700181 &quot;using exp with 0 as base&quot;<br>
-<br>
- If base is 0, and exp is negative, then the result of exp is undefined<br>
- we should throw an error instead of pushing #INF.0 on the stack.<br>
-<br>
-psi/zmath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 09:50:08 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=35766ceb3b28aad95bd63655b1d621a82d3a5b06">35766ceb3b28aad95bd63655b1d621a82d3a5b06</a>
-<blockquote>
-<p>
- Bug 700176: check the *output* device for LockSafetyParams<br>
-<br>
- When calling .setdevice we were checking if LockSafetyParams was set, and if so<br>
- throwing an invalidaccess error.<br>
-<br>
- The problem is, if another device, for example the pdf14 compositor is the 'top'<br>
- device, that does not (and cannot) honour LockSafetyParams.<br>
-<br>
- To solve this, we'll now use the (relatively new) gxdso_current_output_device<br>
- spec_op to retrieve the *actual* output device, and check the LockSafetyParams<br>
- flag in that.<br>
-<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 09:31:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=548bb434e81dadcc9f71adf891a3ef5bea8e2b4e">548bb434e81dadcc9f71adf891a3ef5bea8e2b4e</a>
-<blockquote>
-<p>
- PS interpreter - add some type checking<br>
-<br>
- These were 'probably' safe anyway, since they mostly treat the objects<br>
- as integers without checking, which at least can't result in a crash.<br>
-<br>
- Nevertheless, we ought to check.<br>
-<br>
- The return from comparedictkeys could be wrong if one of the keys had<br>
- a value which was not an array, it could incorrectly decide the two<br>
- were in fact the same.<br>
-<br>
-psi/zbfont.c<br>
-psi/zcolor.c<br>
-psi/zcrd.c<br>
-psi/zfjpx.c<br>
-psi/zfont.c<br>
-psi/zfont0.c<br>
-psi/zimage3.c<br>
-psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 09:27: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=ef252e7dc214bcbd9a2539216aab9202848602bb">ef252e7dc214bcbd9a2539216aab9202848602bb</a>
-<blockquote>
-<p>
- Bug #700168 - add a type check<br>
-<br>
- Bug #700168 &quot;Type confusion in JBIG2Decode&quot;<br>
-<br>
- The code was assuming that .jbig2globalctx was a structure allocated<br>
- by the graphics library, without checking.<br>
-<br>
- Add a check to see that it is a structure and that its the correct<br>
- type of structure.<br>
-<br>
-psi/zfjbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-14 09:25: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=67d760ab775dae4efe803b5944b0439aa3c0b04a">67d760ab775dae4efe803b5944b0439aa3c0b04a</a>
-<blockquote>
-<p>
- Bug #700169 - unchecked type<br>
-<br>
- Bug #700169 &quot;Type confusion in setcolorspace&quot;<br>
-<br>
- In seticc() we extract &quot;Name&quot; from a dictionary, if it succeeds we then<br>
- use it as a string, without checking the type to see if it is in fact<br>
- a string.<br>
-<br>
- Add a check on the type, and add a couple to check that 'N' is an integer<br>
- in a few places too.<br>
-<br>
-psi/zicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-12 17:21: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=3005fcb9bb160af199e761e03bc70a9f249a987e">3005fcb9bb160af199e761e03bc70a9f249a987e</a>
-<blockquote>
-<p>
- Bug 700153: restore: always check available stack<br>
-<br>
- Previously, we were checking there was enough stack space available when the<br>
- restore operation required a device change, but since we have to use<br>
- Postscript to reset the userparams (ick!), we need the stack check even when<br>
- not changing the device.<br>
-<br>
-psi/zdevice2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-07 12:22:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f99c138cf60d75621eb03ae924453b968274694">2f99c138cf60d75621eb03ae924453b968274694</a>
-<blockquote>
-<p>
- Contrib devices: Check for error return opening output file<br>
-<br>
- 09-59.PS cycles through every available device, attempting to open each one.<br>
-<br>
- For many devices this results in an invalid configuration (mainly a lack of<br>
- output file).<br>
-<br>
- These devices, on being shutdown, ignored the lack of output file, and attempted<br>
- to write their final bytes out anyway (attempting to write data to a null<br>
- FILE * pointer), causing a segfault.<br>
-<br>
- We now check the return value of gdev_prn_open_printer() and only write those<br>
- final bytes if gdev_prn_open_printer() completed successfully.<br>
-<br>
-contrib/japanese/gdevespg.c<br>
-contrib/japanese/gdevnpdl.c<br>
-contrib/lips4/gdevl4r.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-07 16:03:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba84a01d19a60a8a9a3e834331621bb37cb44a6c">ba84a01d19a60a8a9a3e834331621bb37cb44a6c</a>
-<blockquote>
-<p>
- Dates, etc for 9.26 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-11-07 00:32: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=8747f40646ad2da5c405bab5a1e85fba9b71b85b">8747f40646ad2da5c405bab5a1e85fba9b71b85b</a>
-<blockquote>
-<p>
- Add nasty workaround for PXL stroking.<br>
-<br>
- Filter paths to be filled to remove 1 dimensional sections.<br>
-<br>
-base/gxpath.h<br>
-base/gxpcopy.c<br>
-pcl/pxl/pxpaint.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-06 16:46: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=6dd9131bfa9bd2d723e745839e4bc8e5fdc817b7">6dd9131bfa9bd2d723e745839e4bc8e5fdc817b7</a>
-<blockquote>
-<p>
- Ensure stream and string persist as long as required<br>
-<br>
- When we create an ICC based color space from a string source, we create a stream<br>
- object, with the stream data coming from that string.<br>
-<br>
- Because the life of the ICC related objects created by the graphics library<br>
- is not dictated by the save/restore operations in the Postscript world, we<br>
- need to ensure that the stream and the string it references persist as long<br>
- as the graphics library needs.<br>
-<br>
- To do this, we move the string data, and the stream object allocation into<br>
- &quot;system VM&quot;, that is, garbage collected, but *not* save/restore memory.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-06 08:48:58 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=30ef5d0b5b14d3f4eaf7929b81aec2279933e1cc">30ef5d0b5b14d3f4eaf7929b81aec2279933e1cc</a>
-<blockquote>
-<p>
- Fix Bug 699806: Incorrect file size from &quot;status&quot; on Windows.<br>
-<br>
- With commit afe8e546, I missed the use of _wstat and _stat in gp_mswin.c<br>
- for the &quot;status&quot; operator. Change to use _wstat64 and _stat64 and all<br>
- works. Tested with VS 2005 32-bit build and with VS 2015 32 and 64 bit<br>
- builds. Note the file size reported is correct for large files even on<br>
- a 32-bit build.<br>
-<br>
-base/gp_mswin.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-06 12:46:38 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9bb753e22cad9e4a20570267cf8bd54e5910f7f2">9bb753e22cad9e4a20570267cf8bd54e5910f7f2</a>
-<blockquote>
-<p>
- Fix pattern clist data being freed with wrong memory_t.<br>
-<br>
- gx_pattern_accum_alloc was allocating the pattern clist memory<br>
- using storage_memory-&gt;non_gc_memory. It was then being freed in<br>
- clist_close using cdev-&gt;bandlist_memory. The two are not the<br>
- same.<br>
-<br>
- Change the allocation to use target-&gt;memory-&gt;non_gc_memory,<br>
- as cdev-&gt;bandlist_memory is set to that.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-06 09:51:56 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0b0825432e04cbb95731aeb22f3db75886a4e6d8">0b0825432e04cbb95731aeb22f3db75886a4e6d8</a>
-<blockquote>
-<p>
- Bug 700133: handle out of range CIDs in CMap parsing<br>
-<br>
- Implementation Limits sections of both PLRM and PDFRM limit the size of a CID<br>
- value to unsigned two byte values (max 65535). Acrobat and various other<br>
- consumers seem to silently ignore values outside this range in CMaps embedded<br>
- in PDF files.<br>
-<br>
- We now limit the CID value to no more than 65535 when parsing a CMap from a<br>
- PDF file (and emit a warning), and *only* from a PDF file: CMap files read<br>
- from disk, and CMaps embedded in Postscript jobs will still throw an error.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-05 20:07:50 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b42541db28423c49cbf47549551a27e9399fd23">2b42541db28423c49cbf47549551a27e9399fd23</a>
-<blockquote>
-<p>
- Fix dev spec op warning/handling.<br>
-<br>
- My previous fiddling in this area wasn't quite right.<br>
-<br>
- Originally, the code here didn't allow any device to provide<br>
- their own dev spec op (and the warning was hence never hit).<br>
-<br>
- In lifting that restriction, the first commit allowed devices to<br>
- provide their own one. They then ran into the warning message.<br>
-<br>
- The second commit fixed the warning message in this case, but<br>
- sadly left the warning message going off in many 'default' cases<br>
- (and what is more, failed to put the prn one in).<br>
-<br>
- This one hopefully gets everything right. As the comments say<br>
- this does feel like a hack.<br>
-<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-05 15:32:46 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1d59a332b8c560e8949976006424439933c9c64">d1d59a332b8c560e8949976006424439933c9c64</a>
-<blockquote>
-<p>
- Scan converter: Fix pngalpha with zero height rectangles.<br>
-<br>
- Because of the banding hack in pngalpha, zero height rectangles<br>
- aren't always the lowest scanline in the edgebuffer.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-05 14:02:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=85e6fd4df9bb51d5c36e7811a2bac4c52898b08c">85e6fd4df9bb51d5c36e7811a2bac4c52898b08c</a>
-<blockquote>
-<p>
- pdfwrite - add a performance enhancing heuristic for text processing<br>
-<br>
- Bug #700124 &quot;pdfwrite device over 800% performance loss between 9.25 and 9.23&quot;<br>
-<br>
- This is a heuristic attempt to resolve the reduction in performance. The<br>
- code originally used the FontBBox to try and determine if a glven<br>
- glyph was completely clipped out, or was at least partially drawn.<br>
-<br>
- For efficiency reasons we don't include glyphs which are clipper out<br>
- in the pdfwrite output, reducing the PDF size.<br>
-<br>
- However in bug #699454 and bug #699571 we saw EPS files produced from<br>
- OneVision EPSExport which include fonts with a wildly inaccurate<br>
- FontBBox. Two commits; 6a4202691c4317a698fa23c5309ad8974fe2b003 and<br>
- 3bf4f3ea45f0022b6cd36415f095f1bfc119fb73 resolved this.<br>
-<br>
- The initial fix considered the advance width in addition to the glyph<br>
- width, but this proved to be insufficient with the second file which<br>
- drew the same glyph multiple times, with an advance width of 0. The<br>
- commit logs note that the only solution is to determine the glyph width<br>
- accurately, which means processing the glyph program for each glyph,<br>
- which has performance implications (ie its slower).<br>
-<br>
- In order to try and alleviate this where possible, this commit looks at<br>
- the number of integer co-ordinates in font space by scaling the<br>
- FontBBox by the FontMatrix. If the resulting design space is small (an<br>
- arbitrary value of 0.1, 1e 100x100 was chosen as 'small') then we do<br>
- not use the FontBBox, but instead use the slower accurate method.<br>
-<br>
- This may need some adjustment, and its entirely possible that it may,<br>
- in the long term, prove unreliable and have to be removed.<br>
-<br>
-devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-01 12:31:55 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b4f29851a33ff04979bb2eb3a32ab62000c6f19c">b4f29851a33ff04979bb2eb3a32ab62000c6f19c</a>
-<blockquote>
-<p>
- Avoid misleading warning message.<br>
-<br>
- If a printer device provides its own dev_spec_op parameter, the<br>
- system prints a warning. This warning is intended to ensure that<br>
- devices remember to call down to the default printer one, but<br>
- appears irrespective of whether they do or not. This means it will<br>
- confuse most users.<br>
-<br>
- Instead, introduce a debug only dso that we can use to check that<br>
- printer devices do indeed forward properly, and use that to print<br>
- the warning only when required.<br>
-<br>
-base/gdevprn.c<br>
-base/gxdevsop.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-01 08:53: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=897dc2afc509fc331e66be43fbae2b20ded142c6">897dc2afc509fc331e66be43fbae2b20ded142c6</a>
-<blockquote>
-<p>
- Avoid trampling on dev_spec_op when opening printer device.<br>
-<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-01 18:24:58 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1303a9a45124fdea7c4f29858ff900d2d3393c76">1303a9a45124fdea7c4f29858ff900d2d3393c76</a>
-<blockquote>
-<p>
- Scan converter: Zero height rectangles hack.<br>
-<br>
- Spot zero height rectangles, and arrange for them to be rendered.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-03 16:54:27 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=045239d2d00d8febf1804703019c15eb99ac1cfd">045239d2d00d8febf1804703019c15eb99ac1cfd</a>
-<blockquote>
-<p>
- Scan converter: Reduce bbox size.<br>
-<br>
- In some cases (specifically, the &quot;centre of pixel&quot; cases) we could<br>
- have constructed the bbox to be larger than it should have been.<br>
- Fix this here.<br>
-<br>
- This produces diffs (mainly in banded files), because the skipping<br>
- calculations for scanlines below/above the edgebuffer can round<br>
- very slightly differently. These diffs are all 1 pixel things.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-03 14:58:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d03f6e773d0c58c7799ca8f49de6298be59b4e0e">d03f6e773d0c58c7799ca8f49de6298be59b4e0e</a>
-<blockquote>
-<p>
- PDF interpreter - work around type 3 fonts with no FirstChar/LastChar<br>
-<br>
- Bug #700130 &quot;Invalid PDF file renders blank pages&quot;<br>
-<br>
- The file (and the customer original file) has a type 3 font with a<br>
- /Widths array, but neither of the required FirstChar or LastChar<br>
- entries.<br>
-<br>
- With 9.25 and below this was leading to blank pages, where current code<br>
- continued. I think because the previous code left garbage on the stack.<br>
-<br>
- This commit sets FirstChar to 0 and LastChar to the length of the<br>
- /Widths array if either is missing.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-03 10:40: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=d850ebc85cd49dd6445f7fd90f504c28c594aa32">d850ebc85cd49dd6445f7fd90f504c28c594aa32</a>
-<blockquote>
-<p>
- Fix commit 71e99<br>
-<br>
- Change dlmprintf to dmlprintf so it'll work.<br>
-<br>
- I blame the reviewer myself.<br>
-<br>
-base/gdebug.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-03 09:29:24 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=71e99487758e464a077c6781893ce9c6eb4134df">71e99487758e464a077c6781893ce9c6eb4134df</a>
-<blockquote>
-<p>
- Add debug only printing macros<br>
-<br>
- Despite what one might think, dmprintf and co are not exclusing to debug builds<br>
- but are always present, and functional.<br>
-<br>
- Generally, only the print macros for the -Z style debugging output are exluded<br>
- from debug builds.<br>
-<br>
- This adds a dbgprintf and dbgmprintf family of macros which don't rely on a -Z<br>
- option to activate them, but are only present when DEBUG is defined.<br>
-<br>
- Additionally, (in line with convention) the dbgprintf variants (rather than<br>
- dbgmprintf) are exluded when GS_THREADSAFE is defined, since we don't have<br>
- to a context (via a memory pointer) to ensure correct operation of stdout/stderr<br>
- in multithreaded environments.<br>
-<br>
-base/gdebug.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-11-02 13:53: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=5f1c1cbf68fe1f25b2a325b275992338d4d4e449">5f1c1cbf68fe1f25b2a325b275992338d4d4e449</a>
-<blockquote>
-<p>
- Bug 700126: Ensure JPEG passthrough gets shuts down on error<br>
-<br>
- When an ioerror occurs, ensure we wind up the JPEG passthrough state, to<br>
- prevent dangling pointer(s) in pdfwrite.<br>
-<br>
-base/sdct.h<br>
-base/sdctc.c<br>
-base/sdctd.c<br>
-base/sjpegd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-23 17:19: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=d0abc92713b2e84eb32c67839ddec2d160b3af8d">d0abc92713b2e84eb32c67839ddec2d160b3af8d</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV by propagating error code in af_loader_load_glyph.<br>
-<br>
- Propagate error by checking for return code.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=31598 ./membin/gpcl6 -sDEVICE=pbmraw -dMaxBitmap=2000 -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0270<br>
-<br>
-freetype/src/autofit/afloader.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-31 15:30:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ece5cbbd9979cd35737b00e68267762d72feb2ea">ece5cbbd9979cd35737b00e68267762d72feb2ea</a>
-<blockquote>
-<p>
- PDF interpreter - Don't allow page stream fonts to be used for Annotations<br>
-<br>
- Bug #700096 &quot;Poorly constructed PDF file can inappropriately reuse a Font&quot;<br>
-<br>
- The file has a page stream which uses a Helvetica font which is embedded<br>
- and subset, but does not have a subset prefix on the name.<br>
-<br>
- A later annotation uses Helvetica, but does not embed it. So we load<br>
- the Helvetica from the font cache. Unfortunately, this is the subset<br>
- font, and its Encoding is incompatible (as well as missing many glyphs)<br>
- so we get a lot of .notdefs.<br>
-<br>
- Here we put a save and restore pair around the page contents, so that<br>
- when we come to the annotation rendering, we have restored the font<br>
- cache to an 'empty' state, so that we won't try to load any fonts that<br>
- were defined in the page stream to satisfy annotation requests.<br>
-<br>
- For some peculiar reason one broken Sumatra file renders slightly<br>
- differently with this in place, and another was wrong before, differently<br>
- wrong now.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-31 15:38: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=1ef5f08f2c2e27efa978f0010669ff22355c385f">1ef5f08f2c2e27efa978f0010669ff22355c385f</a>
-<blockquote>
-<p>
- Fix display device DisplayFormat=16#a0800 (Separation mode) broken by f2cf6829<br>
-<br>
- The ICC profile checking needs to be told that the device supports_devn, so<br>
- add a spec_op proc to return true when in separation mode, and add a proc for<br>
- fill_rectangle_hl_color so that fillpage will work in Separation mode.<br>
-<br>
- This was fixed for other devices in commit 250b5e83, but the display device<br>
- was not fixed then.<br>
-<br>
-devices/gdevdsp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-31 15:30:05 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ffcfd8d291d0bc4729a4959580befe4faef48b8f">ffcfd8d291d0bc4729a4959580befe4faef48b8f</a>
-<blockquote>
-<p>
- Remove duplicate comment.<br>
-<br>
-base/gxcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-30 17:13:57 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8718be6504d227b925d1015d289f13209152c286">8718be6504d227b925d1015d289f13209152c286</a>
-<blockquote>
-<p>
- Scan converter fix.<br>
-<br>
- Fix 'unevenness' seen in the bottom edge of strokes in:<br>
-<br>
- tests/pdf/Bug6901014_CImg_flyer.pdf.ppmraw.300.1<br>
-<br>
- This is part of the bug tail from the &quot;barcode&quot; fixes where<br>
- cursor positions at (y&amp;255) == 0 are 'special'.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-30 17:13:59 +0100
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=73d4e5d0ac7d697d74bf31ddaed944643f0543a1">73d4e5d0ac7d697d74bf31ddaed944643f0543a1</a>
-<blockquote>
-<p>
- Bug 700056: openjpeg allocator must return NULL if size too large.<br>
-<br>
- Previously if an allocation larger than ARCH_MAX_UINT was requested<br>
- the size value was truncated and supplied to the gs allocator. Depending<br>
- on the values involved an allocation of this truncated value may<br>
- actually succeed. This allocation was then passed back to the openjpeg<br>
- library as claiming that the larger, initial allocation request was<br>
- satisfied, even though the allocation itself was actually smaller.<br>
- This resulted in segmentation faults.<br>
-<br>
-base/sjpx_openjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-20 20:24:47 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=53163da329e2019e27a8876f6b2363628de2ae0f">53163da329e2019e27a8876f6b2363628de2ae0f</a>
-<blockquote>
-<p>
- jbig2dec: Fix signed/unsigned mismatches.<br>
-<br>
-jbig2dec/jbig2_generic.c<br>
-jbig2dec/jbig2_halftone.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-29 11:12:44 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ecb88d9bd6f6cc1ea8b4dee9f2df50da04429135">ecb88d9bd6f6cc1ea8b4dee9f2df50da04429135</a>
-<blockquote>
-<p>
- Fix debug print in clist code -- index value was incorrect.<br>
-<br>
-base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-26 16:47: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=2be9c4dfc343adafa49c3bbce5f205f771280851">2be9c4dfc343adafa49c3bbce5f205f771280851</a>
-<blockquote>
-<p>
- Update mkromfs to allow for splitting data into chunks.<br>
-<br>
- Call this in the pdlromfs builds to keep the chunk size<br>
- small enough to avoid out of memory errors during the<br>
- build (on plancks especially).<br>
-<br>
-base/lib.mak<br>
-base/mkromfs.c<br>
-base/unixlink.mak<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-29 16:17:50 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a359d37fa7c1ba7e3910b83e8672ac9a4b110518">a359d37fa7c1ba7e3910b83e8672ac9a4b110518</a>
-<blockquote>
-<p>
- Add gs_font_dir_free.<br>
-<br>
- This extracts some code from pdfwrite and makes it available to<br>
- other callers.<br>
-<br>
-base/gsfont.c<br>
-base/gsfont.h<br>
-devices/vector/gdevpdf.c<br>
-pcl/pcl/pcfont.c<br>
-pcl/pxl/pxstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-25 19:46: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=17262b11330552fb393bbd2907a9672d0d7eee48">17262b11330552fb393bbd2907a9672d0d7eee48</a>
-<blockquote>
-<p>
- Add a security policy link, and remove gsview.com link<br>
-<br>
- The link for the security policy replaces the original 'team' 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-10-25 14:30: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=04333a6f1344df6b5069880cafe7b190d0984601">04333a6f1344df6b5069880cafe7b190d0984601</a>
-<blockquote>
-<p>
- Fix pngalpha device with device subclassing<br>
-<br>
- Bug #699815 &quot;Segmentation fault for pdf input to pngalpha driver&quot;<br>
-<br>
- The pngalpha device, in pngalpha_create_buf_device() first creates an<br>
- in-memory rendering device (image32) and then overrides two of the<br>
- device methods with its own versions.<br>
-<br>
- This doesn't work at all when we have subclassing devices loaded, because<br>
- the device that gets handed as the 'target' device is the head of the<br>
- chain of devices, and the pngalpha device simply pulls the methods<br>
- directly from that device. Note that this also wouldn't work if a<br>
- forwarding device were present.<br>
-<br>
- We can work around it by descending the chain of devices, and pulling<br>
- the methods from the last device in the chain instead of using the<br>
- 'target' directly. This still feels wrong but it should at least work.<br>
-<br>
-devices/gdevpng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-25 09:22:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ffac21a73b74c8ce01cbae406f7dd3bfd0a7ef65">ffac21a73b74c8ce01cbae406f7dd3bfd0a7ef65</a>
-<blockquote>
-<p>
- Include gsstate.h to avoid a compiler warning<br>
-<br>
- Has the definition of gs_currentcpsimode().<br>
-<br>
-psi/ztype.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-24 13:46:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be2c93dca70926069df25467a724eb787497c6f7">be2c93dca70926069df25467a724eb787497c6f7</a>
-<blockquote>
-<p>
- Allow cvrs to operate on 64-bit integers<br>
-<br>
- Bug #700011 &quot;cvrs may truncate integers&quot;<br>
-<br>
- zcvrs() cast the PostScript intval to an unsigned int internally, which<br>
- truncates 64-bit values to 32-bit values. Other similar operators are<br>
- capable of handling 64-bit values.<br>
-<br>
- This commit casts the result to a ps_uint (PostScript unsigned int)<br>
- which varies in size depending on the platform. If a 64-bit integer<br>
- data type is available it will be 64-bit otherwise it will be 32-bit.<br>
-<br>
- Additionally, check CPSI mode and if it is set, cast the ps_int to an<br>
- unsigned int in order to explicitly truncate to a 32-bit value. We use<br>
- CPSI compatibility mode in our internal testing, and if we don't do this<br>
- then two of the Quality Logic CET files throw errors.<br>
-<br>
- Finally add some words to Use.htm regarding the word size of platforms<br>
- and some of the implications regarding 64-bit values in PostScript.<br>
-<br>
-doc/Use.htm<br>
-psi/ztype.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-23 13:40:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=73f7c6eb92596087a1e30123ba0cdf701f8d6006">73f7c6eb92596087a1e30123ba0cdf701f8d6006</a>
-<blockquote>
-<p>
- Bug 700023: Fix cups get/put_params LeadingEdge logic<br>
-<br>
- Custom device LeadingEdge logic in complicated as it potentially requires<br>
- equivalent changes to changing the page size.<br>
-<br>
- For a device like cups which merely wants the LeadingEdge value stored in its<br>
- own place it makes much more sense to allow the Ghostscript 'core' to handle<br>
- all the logic (which it has to do anyway to ensure the rendering is correct),<br>
- and then just copy the value into the cups specific place.<br>
-<br>
- This saves the problem, as in this case, of unexpectedly ending up with two<br>
- LeadingEdge parameters being included in a call to put_params.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-19 13:14:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e18fcdaa2e2247363c4cc8f851f3096cc5756fa">8e18fcdaa2e2247363c4cc8f851f3096cc5756fa</a>
-<blockquote>
-<p>
- &quot;Hide&quot; a final use of a .force* operator<br>
-<br>
- There was one use of .forceput remaining that was in a regular procedure<br>
- rather than being &quot;hidden&quot; behind an operator.<br>
-<br>
- In this case, it's buried in the resource machinery, and hard to access (I<br>
- would not be confident in claiming it was impossible). This ensures it's<br>
- not accessible.<br>
-<br>
-Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-07 14:23:06 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6b11ea745395193f4f1fc8a7b09dda9913dbe72">f6b11ea745395193f4f1fc8a7b09dda9913dbe72</a>
-<blockquote>
-<p>
- Bug 699740: Better handle failing to set the nulldevice<br>
-<br>
- When pushing the nulldevice, if gs_setdevice_no_erase() failed, that *could*<br>
- mean we end up freeing the device referenced in the graphics state.<br>
-<br>
- If that happens, search back through the saved gstates to find the initial<br>
- graphics state, and pull the initial device from there.<br>
-<br>
- This allows us to return a Fatal error code, and exit cleanly.<br>
-<br>
-base/gsdevice.c<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-18 14:11:45 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=09e6af81cccb5547a18baace0a792f22bc9ea927">09e6af81cccb5547a18baace0a792f22bc9ea927</a>
-<blockquote>
-<p>
- Fix bug# 699969 - inverted colors and misplaced graphics.<br>
-<br>
- Our testing of HP printers indicate that monochrome printers clear the<br>
- seed row for delta row compression for each each block of adaptive<br>
- compression data but color devices leave the row intact.<br>
-<br>
-pcl/pcl/rtraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-18 13:31: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=635dad8721def9da27e13b849ba8e37023703501">635dad8721def9da27e13b849ba8e37023703501</a>
-<blockquote>
-<p>
- Remove unnecessary gs_opendevice() calls<br>
-<br>
- For reasons unknown the target device was being opened prior to the<br>
- languages setting and opening the device with gs_setdevice_no_erase().<br>
- This is unnecessary and apparently wrong, gs_opendevice() does not<br>
- properly fill in the the device procedures (gx_device_fill_in_procs()).<br>
-<br>
-pcl/pl/plmain.c<br>
-pcl/pxl/pxtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-18 17:26:09 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb473839eed3eeaf9acc7db4d88a3a0a8ca5f432">eb473839eed3eeaf9acc7db4d88a3a0a8ca5f432</a>
-<blockquote>
-<p>
- Tweak htmldiff.pl to ignore empty lines without a confusing error.<br>
-<br>
-toolbin/htmldiff.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-05-07 14:51:54 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e29b99f71c5bdb766e7ee57363ce37cfdcab3621">e29b99f71c5bdb766e7ee57363ce37cfdcab3621</a>
-<blockquote>
-<p>
- Update transform_pixel_region with &quot;direct 1:1&quot; methods for memory devs.<br>
-<br>
-base/gdevdrop.c<br>
-base/gxcmap.c<br>
-base/gxcmap.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-05-07 11:32:44 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=852295de5b37409b51970cb9329227f1cf573a7b">852295de5b37409b51970cb9329227f1cf573a7b</a>
-<blockquote>
-<p>
- Attempt transform_pixel_region acceleration for memory devices using templating.<br>
-<br>
-base/gdevdrop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-05-04 19:37:24 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e926e47d349d0c962c6c64c64804d18c20bf9ba">1e926e47d349d0c962c6c64c64804d18c20bf9ba</a>
-<blockquote>
-<p>
- Update clip device to be smarter about transform_pixel_region.<br>
-<br>
- When the clip device is for a single rectangle (a very common case)<br>
- we can avoid resorting to the default transform_pixel_region routine,<br>
- and still use the device's (possibly) optimised one.<br>
-<br>
-base/gxclip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-05-02 17:40: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=eefae1a50eb451584c2e17600933b723dbc68a0e">eefae1a50eb451584c2e17600933b723dbc68a0e</a>
-<blockquote>
-<p>
- Implement transform_pixel_region for memory devices.<br>
-<br>
-base/gdevdrop.c<br>
-base/gdevmem.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-04-19 12:45:14 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3b8f34c00e6ed1f7b4847a55d48b8027c0b0b946">3b8f34c00e6ed1f7b4847a55d48b8027c0b0b946</a>
-<blockquote>
-<p>
- Add &quot;transform_pixel_region&quot; device function.<br>
-<br>
- Use this for handling image type 4 rendering.<br>
-<br>
- The default version of this goes to rectangles. It also knows how to<br>
- send portrait images of 8bps to copy_color.<br>
-<br>
- Next step is to write versions of this for the memory mapped devices<br>
- to know how to go direct.<br>
-<br>
- Essentially we are copying the guts of the<br>
- image_render_color_icc_{portrait,landscape,skew} into a default<br>
- device method, and making the code that called those functions<br>
- call the device method instead.<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevepo.c<br>
-base/gdevflp.c<br>
-base/gdevmplt.c<br>
-base/gdevnfwd.c<br>
-base/gdevoflt.c<br>
-base/gdevsclass.c<br>
-base/gdevsclass.h<br>
-base/gxclip.c<br>
-base/gxclipm.c<br>
-base/gxclist.c<br>
-base/gxcmap.c<br>
-base/gxcmap.h<br>
-base/gxdevcli.h<br>
-base/gxdevice.h<br>
-base/gxi12bit.c<br>
-base/gxicolor.c<br>
-base/gxidata.c<br>
-base/gximage.h<br>
-devices/vector/gdevpdfd.c<br>
-devices/vector/gdevpdfx.h<br>
-doc/Drivers.htm<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-04-23 16:02:10 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=29113956bb0599209ca81698ab36736e373f054a">29113956bb0599209ca81698ab36736e373f054a</a>
-<blockquote>
-<p>
- Use copy_color for some image plotting cases.<br>
-<br>
- Avoid dropping to fill_rectangle where possible. We should be<br>
- careful, because in some cases copy_color ends up doing<br>
- fill_rectangle!<br>
-<br>
-base/gxicolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-04-26 15:18:20 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3d2e9a3b7b633db23b2b0f7bfdff522c48c1d4be">3d2e9a3b7b633db23b2b0f7bfdff522c48c1d4be</a>
-<blockquote>
-<p>
- Add gxdso_copy_color_is_fast.<br>
-<br>
- Default implementation returns 1 if copy_color is not the default<br>
- (as the default drops to copy_rects).<br>
-<br>
- Also the lcvd device (as used by pdfwrite and ps2write) returns 0<br>
- to stop us calling it in this case. The lcvd device lies about<br>
- the width/height, and so clipping goes wrong.<br>
-<br>
-base/gdevdflt.c<br>
-base/gxdevsop.h<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-18 12:50: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=a366c6a1f2dc882e9b3a4baf79bf7ba253bd9165">a366c6a1f2dc882e9b3a4baf79bf7ba253bd9165</a>
-<blockquote>
-<p>
- Update htmldiff.pl<br>
-<br>
- Now properly takes formats from the input test list (though<br>
- this can be overridden).<br>
-<br>
-toolbin/htmldiff.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-17 19:32:08 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23c3e1dd980ec503f5d1f593557d6ebdb5a2173e">23c3e1dd980ec503f5d1f593557d6ebdb5a2173e</a>
-<blockquote>
-<p>
- VS solution for bmpcmp.<br>
-<br>
-toolbin/bmpcmp.sln<br>
-toolbin/bmpcmp.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-16 16:52:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d2a714c9ac3f5cbca0015dbfbfa2fbcb5620fbe">1d2a714c9ac3f5cbca0015dbfbfa2fbcb5620fbe</a>
-<blockquote>
-<p>
- Remove debug code accidentally left in growPDFobjects<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-16 11:32: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=00f48edb588188dc9f10c4a84abdb336725769bd">00f48edb588188dc9f10c4a84abdb336725769bd</a>
-<blockquote>
-<p>
- Don't push the EPO device in front of the nulldevice<br>
-<br>
- There are no bad effects from this, just pointless.<br>
-<br>
-base/gdevepo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-16 15:10: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=0bbf2de242801bdf7001db7f85c5fb3b4016e9e1">0bbf2de242801bdf7001db7f85c5fb3b4016e9e1</a>
-<blockquote>
-<p>
- PDF interpreter - bug in growPDFobjects when repairing PDF file<br>
-<br>
- Bug #699970 &quot;bug in PDF repair&quot;<br>
-<br>
- The function growPDFobjects is used to increase the size of the Objects,<br>
- ObjectStream, Generations and IsGlobal records when the number of<br>
- objects being recorded exceeds the size of the current record.<br>
-<br>
- The problem was that the code assumes Generations is a string, which it<br>
- normally is. However when we are repairing a PDF file, we turn the<br>
- string into an array, and if we need to increase the size of the<br>
- record we need to make a larger array, not a larger string.<br>
-<br>
- This commit checks the current type of the Generations record and either<br>
- creates a large string or larger array, working from the type of the<br>
- existing record.<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-16 11:21:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c218c1463b9c2ff39b1ea514824815fde4853a7">3c218c1463b9c2ff39b1ea514824815fde4853a7</a>
-<blockquote>
-<p>
- Bug 699962: Ensure device survives Postscript &quot;callout&quot;<br>
-<br>
- In shutting down the interpreter, we run Postscript code to remove the 'real'<br>
- device from the graphics state (replacing it with the nulldevice). That means<br>
- we can shutdown and free the device in the C code, without impacting the<br>
- remaining interpreter shutdown.<br>
-<br>
- There is, however, a very small chance that, whilst running the Postcript code,<br>
- the interpreter will trigger a garbage collection - if that happens *after*<br>
- the device reference has been removed from the graphics state, there is no<br>
- 'link' to the device object for the garbager to follow. Thus the device can<br>
- be freed before control returns from executing the Postscript.<br>
-<br>
- Register the device as a garbage collector 'root': thus it is implicitly marked<br>
- and won't be freed before control returns.<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-15 13:35:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=30cd347f37bfb293ffdc407397d1023628400b81">30cd347f37bfb293ffdc407397d1023628400b81</a>
-<blockquote>
-<p>
- font parsing - prevent SEGV in .cffparse<br>
-<br>
- Bug #699961 &quot;currentcolortransfer procs crash .parsecff&quot;<br>
-<br>
- zparsecff checked the operand for being an array (and not a packed<br>
- array) but the returned procedures from the default currentcolortransfer<br>
- are arrays, not packed arrays. This led to the code trying to<br>
- dereference a NULL pointer.<br>
-<br>
- Add a specific check for the 'refs' pointer being NULL before we try<br>
- to use it.<br>
-<br>
- Additionally, make the StartData procedure in the CFF Font Resource<br>
- executeonly to prevent pulling the hidden .parsecff operator out and<br>
- using it. Finally, extend this to other resource types.<br>
-<br>
-Resource/Init/gs_cff.ps<br>
-Resource/Init/gs_cidcm.ps<br>
-Resource/Init/gs_ciddc.ps<br>
-Resource/Init/gs_cmap.ps<br>
-Resource/Init/gs_res.ps<br>
-psi/zfont2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-15 11:28: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=8d19fdf63f91f50466b08f23e2d93d37a4c5ea0b">8d19fdf63f91f50466b08f23e2d93d37a4c5ea0b</a>
-<blockquote>
-<p>
- Make .forceput unavailable from '.policyprocs' helper dictionary<br>
-<br>
- Bug #69963 &quot;1Policy is a dangerous operator, any callers should be odef&quot;<br>
-<br>
- Leaving the .policyprocs dictionary with a procedure which is a simple<br>
- wrapper for .forceput effectively leaves .forceput available.<br>
-<br>
- It seems that the only reason to have .policyprocs is to minimise the<br>
- code in .applypolicies, so we can remove the dictionary and put the<br>
- code straight into .applypolicies, which we can then bind and make<br>
- executeonly, which hides the .forceput. Also, since we don't need<br>
- .applypolicies after startup, we can undefine that from systemdict too.<br>
-<br>
- While we're here, review all the uses of .force* to make certain that<br>
- there are no other similar cases. This showed a few places where we<br>
- hadn't made a function executeonly, so do that too. Its probably not<br>
- required, since I'm reasonably sure its impossible to load those<br>
- functions as packed arrays (they are all defined as operators), but lets<br>
- have a belt and braces approach, the additional time cost is negligible.<br>
-<br>
-Resource/Init/gs_diskn.ps<br>
-Resource/Init/gs_dps.ps<br>
-Resource/Init/gs_epsf.ps<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-14 00:06:46 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=90b8faa80a4746f7f1e0966d6c56a687d2f8d333">90b8faa80a4746f7f1e0966d6c56a687d2f8d333</a>
-<blockquote>
-<p>
- Pull in newly merged and updated LCMS2MT from MuPDF thirdparty repo.<br>
-<br>
- The MuPDF repo should be considered canonical, as that is<br>
- the one that can pull in updates from upstream lcms2 easily.<br>
-<br>
-base/gsicc_lcms2mt.c<br>
-lcms2mt/AUTHORS<br>
-lcms2mt/ChangeLog<br>
-lcms2mt/Projects/VC2010/jpegicc/jpegicc.vcxproj<br>
-lcms2mt/Projects/VC2010/lcms2mt.rc<br>
-lcms2mt/Projects/VC2010/lcms2mt.sln<br>
-lcms2mt/Projects/VC2010/lcms2mt_DLL/lcms2mt_DLL.vcxproj<br>
-lcms2mt/Projects/VC2010/lcms2mt_DLL/lcms2mt_DLL.vcxproj.filters<br>
-lcms2mt/Projects/VC2010/lcms2mt_static/lcms2mt_static.vcxproj<br>
-lcms2mt/Projects/VC2010/lcms2mt_static/lcms2mt_static.vcxproj.filters<br>
-lcms2mt/Projects/VC2010/linkicc/linkicc.vcxproj<br>
-lcms2mt/Projects/VC2010/psicc/psicc.vcxproj<br>
-lcms2mt/Projects/VC2010/testbed/testbed.vcxproj<br>
-lcms2mt/Projects/VC2010/tiffdiff/tiffdiff.vcxproj<br>
-lcms2mt/Projects/VC2010/tifficc/tifficc.vcxproj<br>
-lcms2mt/Projects/VC2010/transicc/transicc.vcxproj<br>
-lcms2mt/Projects/VC2012/jpegicc/jpegicc.vcxproj<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/psicc/psicc.vcxproj<br>
-lcms2mt/Projects/VC2012/testbed/testbed.vcxproj<br>
-lcms2mt/Projects/VC2012/tiffdiff/tiffdiff.vcxproj<br>
-lcms2mt/Projects/VC2012/tifficc/tifficc.vcxproj<br>
-lcms2mt/Projects/VC2012/transicc/transicc.vcxproj<br>
-lcms2mt/Projects/VC2013/jpegicc/jpegicc.vcxproj<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/psicc/psicc.vcxproj<br>
-lcms2mt/Projects/VC2013/testbed/testbed.vcxproj<br>
-lcms2mt/Projects/VC2013/tiffdiff/tiffdiff.vcxproj<br>
-lcms2mt/Projects/VC2013/tifficc/tifficc.vcxproj<br>
-lcms2mt/Projects/VC2013/transicc/transicc.vcxproj<br>
-lcms2mt/Projects/VC2015/jpegicc/jpegicc.vcxproj<br>
-lcms2mt/Projects/VC2015/lcms2mt.sln<br>
-lcms2mt/Projects/VC2015/linkicc/linkicc.vcxproj<br>
-lcms2mt/Projects/VC2015/psicc/psicc.vcxproj<br>
-lcms2mt/Projects/VC2015/testbed/testbed.vcxproj<br>
-lcms2mt/Projects/VC2015/tiffdiff/tiffdiff.vcxproj<br>
-lcms2mt/Projects/VC2015/tifficc/tifficc.vcxproj<br>
-lcms2mt/Projects/VC2015/transicc/transicc.vcxproj<br>
-lcms2mt/Projects/VC2017/jpegicc/jpegicc.vcxproj<br>
-lcms2mt/Projects/VC2017/lcms2mt.sln<br>
-lcms2mt/Projects/VC2017/lcms2mt_DLL/lcms2mt_DLL.vcxproj<br>
-lcms2mt/Projects/VC2017/lcms2mt_static/lcms2mt_static.vcxproj<br>
-lcms2mt/Projects/VC2017/linkicc/linkicc.vcxproj<br>
-lcms2mt/Projects/VC2017/psicc/psicc.vcxproj<br>
-lcms2mt/Projects/VC2017/testbed/testbed.vcxproj<br>
-lcms2mt/Projects/VC2017/tiffdiff/tiffdiff.vcxproj<br>
-lcms2mt/Projects/VC2017/tifficc/tifficc.vcxproj<br>
-lcms2mt/Projects/VC2017/transicc/transicc.vcxproj<br>
-lcms2mt/config.guess<br>
-lcms2mt/doc/WhyThisFork.txt<br>
-lcms2mt/include/lcms2mt.h<br>
-lcms2mt/include/lcms2mt_plugin.h<br>
-lcms2mt/ltmain.sh<br>
-lcms2mt/src/cmsalpha.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/cmsnamed.c<br>
-lcms2mt/src/cmsopt.c<br>
-lcms2mt/src/cmspack.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/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/testcms2.c<br>
-lcms2mt/testbed/testcms2.h<br>
-lcms2mt/testbed/testplugin.c<br>
-lcms2mt/testbed/zoo_icc.c<br>
-lcms2mt/utils/common/utils.h<br>
-lcms2mt/utils/common/vprf.c<br>
-lcms2mt/utils/delphi/lcms2dll.pas<br>
-lcms2mt/utils/jpgicc/jpgicc.c<br>
-lcms2mt/utils/linkicc/linkicc.c<br>
-lcms2mt/utils/psicc/Makefile.am<br>
-lcms2mt/utils/psicc/psicc.c<br>
-lcms2mt/utils/samples/itufax.c<br>
-lcms2mt/utils/samples/roundtrip.c<br>
-lcms2mt/utils/tificc/tifdiff.c<br>
-lcms2mt/utils/tificc/tificc.c<br>
-lcms2mt/utils/transicc/Makefile.am<br>
-lcms2mt/utils/transicc/transicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-14 18:00:24 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fc61ee05129b7cafb22dbce5b93c9a80d30433f7">fc61ee05129b7cafb22dbce5b93c9a80d30433f7</a>
-<blockquote>
-<p>
- Enable Trapping by default.<br>
-<br>
-base/gxdownscale.c<br>
-doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-12 10:54:09 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=45b1d1079b563fc1722ebfb2037b80567b9932ff">45b1d1079b563fc1722ebfb2037b80567b9932ff</a>
-<blockquote>
-<p>
- Bug 699935: Change to allow GSView 5 to work with current Ghostscript.<br>
-<br>
- In 2016, a change was made to consult the ProcessColorModel in order to<br>
- determine if PDF needed special Overprint Transparency handling, but for<br>
- some reason, the GSView display device doesn't have this paramemter in<br>
- the pagedevice dictionary. Change to rely on the /Colors parameter being<br>
- less than 4 for devices that don't need special Overprint trans handling.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-11 15:21:30 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=45450eb49522afc5ed177d93c142d0c049a864e0">45450eb49522afc5ed177d93c142d0c049a864e0</a>
-<blockquote>
-<p>
- Bug 699800: Fix the previous scan converter fix<br>
-<br>
- There were cases where we still weren't handling the cursor<br>
- being on the edge of a pixel correctly, leading to asserts<br>
- and spurious horizontal lines on images.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-08 18:24:23 +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=612d81e94ed0249a8e6fd15e33f409207904ecba">612d81e94ed0249a8e6fd15e33f409207904ecba</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV by propagating error code in tt_find_table.<br>
-<br>
- Propagate error code by checking for return code from access function call.<br>
- Prevent SEGV during pcl_text by checking if a font file is loaded before<br>
- trying to use a font.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=19130 ./membin/gpcl6 -sDEVICE=pbmraw -dMaxBitmap=2000 -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0210<br>
-<br>
-pcl/pcl/pcpage.c<br>
-pcl/pcl/pctext.c<br>
-pcl/pcl/pcursor.c<br>
-pcl/pcl/pcursor.h<br>
-pcl/pl/plchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-10 23:25: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=a5a9bf8c6a63aa4ac6874234fe8cd63e72077291">a5a9bf8c6a63aa4ac6874234fe8cd63e72077291</a>
-<blockquote>
-<p>
- Bug 699938: .loadfontloop must be an operator<br>
-<br>
- In the fix for Bug 699816, I omitted to make .loadfontloop into an operator, to<br>
- better hide .forceundef and .putgstringcopy.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-11 12:22: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=262f94222e6965e639e92b920951ff75c2d8f081">262f94222e6965e639e92b920951ff75c2d8f081</a>
-<blockquote>
-<p>
- Fix mswinpr2 device with subclassing<br>
-<br>
- Bug # 699934 &quot;mswinpr2 creates empty print jobs (with some printer drivers)&quot;<br>
-<br>
- The mswinpr2 device has a bizarre check in it, to see if the device is a<br>
- copy produced by copydevice. Its not clear to me why it does this, and<br>
- the code is very old. It looks to me like this should fail if the device<br>
- *is* a copy produced by copydevice, for the same reason it does with<br>
- subclassing, the Windows-specific parts are set to NULL.<br>
-<br>
- I can't seem to provoke the device to go through this path in normal<br>
- operation, so I'm not going to try and remove it. Instead I've added<br>
- to the test a check to see if the device has been subclassed. If it has<br>
- we no longer reset the Windows-specific parts of the device, but carry<br>
- on using what we have.<br>
-<br>
- While we are here, remove the annoying wdev macro which simply makes<br>
- it hard to debug. Especially when the macro has different definitions<br>
- in different parts of the source file!<br>
-<br>
-devices/gdevwpr2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-10 16:24: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=bf9f3f1536487b4d67643ac3d8bddd149a2b3fa0">bf9f3f1536487b4d67643ac3d8bddd149a2b3fa0</a>
-<blockquote>
-<p>
- Close a device before any other 'finalize' actions<br>
-<br>
- Previously, when a device object was being finalized, we were calling the<br>
- device's own finalize method, and (possibly) freeing the reference counted<br>
- icc data before calling gs_closedevice() to ensure the device is genuinely<br>
- closed.<br>
-<br>
- Reorder the operations so closing the device is the *first* thing we do.<br>
-<br>
-base/gdevsclass.c<br>
-base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-10 15:48: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=b7e8af4ce9f3352631c0e1efaee9b92f9bc43bb3">b7e8af4ce9f3352631c0e1efaee9b92f9bc43bb3</a>
-<blockquote>
-<p>
- Fix a memory leak with subclassed devices (stype)<br>
-<br>
- A dynamic stype in a subclass device wasn't being free with the device - likely<br>
- an oversight from adding the subclass device specific finalize method (rather<br>
- than using the generic device finalize).<br>
-<br>
- If a subclassed device has a 'dynamic' stype,<br>
-<br>
-base/gdevsclass.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-10 15:38: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=34cc326eb2c5695833361887fe0b32e8d987741c">34cc326eb2c5695833361887fe0b32e8d987741c</a>
-<blockquote>
-<p>
- Bug 699927: don't include operator arrays in execstack output<br>
-<br>
- When we transfer the contents of the execution stack into the array, take the<br>
- extra step of replacing any operator arrays on the stack with the operator<br>
- that reference them.<br>
-<br>
- This prevents the contents of Postscript defined, internal only operators (those<br>
- created with .makeoperator) being exposed via execstack (and thus, via error<br>
- handling).<br>
-<br>
- This necessitates a change in the resource remapping 'resource', which contains<br>
- a procedure which relies on the contents of the operators arrays being present.<br>
- As we already had internal-only variants of countexecstack and execstack<br>
- (.countexecstack and .execstack) - using those, and leaving thier operation<br>
- including the operator arrays means the procedure continues to work correctly.<br>
-<br>
- Both .countexecstack and .execstack are undefined after initialization.<br>
-<br>
- Also, when we store the execstack (or part thereof) for an execstackoverflow<br>
- error, make the same oparray/operator substitution as above for execstack.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_resmp.ps<br>
-psi/int.mak<br>
-psi/interp.c<br>
-psi/interp.h<br>
-psi/zcontrol.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-10 17:12: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=04a517f39cc3e25a7aec9766b45aeb2144718ee6">04a517f39cc3e25a7aec9766b45aeb2144718ee6</a>
-<blockquote>
-<p>
- PDF interpreter - don't use CIDFonts from the PDF file for missing ones<br>
-<br>
- Bug #699937 &quot;Poorly constructed PDF file can inappropriately reuse a CIDFont&quot;<br>
-<br>
- If we find a CIDFont is not defined (the FontDescriptor has no FontFile<br>
- entry) then we need to find a substitute. Normally this means going<br>
- to disk and either loading an explicit (user supplied) substitute, or<br>
- using a fallback CIDFont.<br>
-<br>
- However, if the PDF file had defined a CIDFont with the same name<br>
- previously, we could use that instead. If the CIDFont was a complete<br>
- font this should be absolutely fine. However in this the CIDFont is a<br>
- *subset* font, but not identified as such. Using that font leads to<br>
- missing text....<br>
-<br>
- This commit continues to use resourcestatus to locate a substitute<br>
- CIDFont, but it checks the 'status' flag. If its 0 then that means we<br>
- created it via an explicit defineresource, which means (I believe and<br>
- testing seems to confirm) that we created it from the PDF file. If its<br>
- 1 or 2, then it was loaded from disk as a substitute (or is available<br>
- but not in VM, ie its on disk).<br>
-<br>
- So if status is 0, don't use this CIDFont, it might not be reliable,<br>
- instead force an excursion to disk and load a substitute from there.<br>
-<br>
- Tested with an explicit substitution defined in cidfmap to make sure<br>
- that this does not break at the same time. NB! If a PDF file does<br>
- define a CIDFont of the same name, then we won't (I believe) be able<br>
- to load the explicit CIDFont resource, we will always fall back to the<br>
- default.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-09 19:42:34 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7f26bbdc84818f5ecf32c726ff8c15dbb6a94485">7f26bbdc84818f5ecf32c726ff8c15dbb6a94485</a>
-<blockquote>
-<p>
- Add avx2 option to clusterpush.pl<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-09 15:34: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=f1a078763387dde6972b30ee55a4b985d4d130bb">f1a078763387dde6972b30ee55a4b985d4d130bb</a>
-<blockquote>
-<p>
- Explicitly exclude /unknownerror from the SAFERERRORLIST<br>
-<br>
- Since we remove /unknownerror from errordict, we want to exclude it from the<br>
- list we copy to gserrordict for SAFERERRORS<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-08 18:52: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=7df67ad89e59e1c93684eb48cef2b907076e19bc">7df67ad89e59e1c93684eb48cef2b907076e19bc</a>
-<blockquote>
-<p>
- Ensure 'token' errors are reported correctly.<br>
-<br>
- Previously, any error that occurred during the actual token scanning part of<br>
- 'token' would actually report an error against the internal operator:<br>
- '%token_continue'.<br>
-<br>
- This commit ensures that such errors are reported against 'token'.<br>
-<br>
-psi/ztoken.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-02 16:02:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6807394bd94b708be24758287b606154daaaed9">a6807394bd94b708be24758287b606154daaaed9</a>
-<blockquote>
-<p>
- For hidden operators, pass a name object to error handler.<br>
-<br>
- In normal operation, Postscript error handlers are passed the object which<br>
- triggered the error: this is invariably an operator object.<br>
-<br>
- The issue arises when an error is triggered by an operator which is for internal<br>
- use only, and that operator is then passed to the error handler, meaning it<br>
- becomes visible to the error handler code.<br>
-<br>
- By converting to a name object, the error message is still valid, but we no<br>
- longer expose internal use only operators.<br>
-<br>
- The change in gs_dps1.ps is related to the above: previously an error in<br>
- scheck would throw an error against .gcheck, but as .gcheck is now a hidden<br>
- operator, it resulted in a name object being passed to the error handler. As<br>
- scheck is a 'real' operator, it's better to use the real operator, rather than<br>
- the name of an internal, hidden one.<br>
-<br>
-Resource/Init/gs_dps1.ps<br>
-psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-04 10:42: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=1778db6bc10a8d60dfe986b22d2300326733ddd6">1778db6bc10a8d60dfe986b22d2300326733ddd6</a>
-<blockquote>
-<p>
- Bug 699832: add control over hiding error handlers.<br>
-<br>
- With a previous commit changing error handling in SAFER so the handler gets<br>
- passed a name object (rather than executable object), it is less critical to<br>
- hide the error handlers.<br>
-<br>
- This introduces a -dSAFERERRORS option to force only use of the default error<br>
- handlers.<br>
-<br>
- It also adds a .setsafererrors Postscript call, meaning a caller, without<br>
- -dSAFERERRORS, can create their own default error handlers (in errordict, as<br>
- normal), and then call .setsafererrors meaning their own handlers are always<br>
- called.<br>
-<br>
- With -dSAFERERRORS or after a call to .setsafererrors, .setsafererrors is<br>
- removed.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-29 15:34: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=a54c9e61e7d02bbc620bcba9b1c208462a876afb">a54c9e61e7d02bbc620bcba9b1c208462a876afb</a>
-<blockquote>
-<p>
- Bug 699816: Improve hiding of security critical custom operators<br>
-<br>
- Make procedures that use .forceput/.forcedef/.forceundef into operators.<br>
-<br>
- The result of this is that errors get reported against the &quot;top&quot; operator,<br>
- rather than the &quot;called&quot; operator within the procedure.<br>
-<br>
- For example:<br>
- /myproc<br>
- {<br>
- myop<br>
- } bind def<br>
-<br>
- If 'myop' throws an error, the error handler will be passed the 'myop'<br>
- operator. Promoting 'myproc' to a operator means the error handler will be<br>
- passed 'myproc'.<br>
-<br>
-Resource/Init/gs_diskn.ps<br>
-Resource/Init/gs_dps.ps<br>
-Resource/Init/gs_fntem.ps<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_pdfwr.ps<br>
-Resource/Init/gs_setpd.ps<br>
-Resource/Init/gs_typ32.ps<br>
-Resource/Init/gs_type1.ps<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>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-26 20:42:32 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=702f6982b63fca353d9106d2dbb6bb21f826c2e6">702f6982b63fca353d9106d2dbb6bb21f826c2e6</a>
-<blockquote>
-<p>
- Bug 699800: Fix scan converter problem seen with barcodes.<br>
-<br>
- The new scan converter is incorrectly counting a pixel as being<br>
- touched if a line moves horizontally across the bottom edge of<br>
- that pixel.<br>
-<br>
- This means that paths (for example) carefully constructed to cover<br>
- exactly a single pixel, such as:<br>
-<br>
- 0 0 moveto 1 0 lineto 1 1 lineto 0 1 lineto closepath fill<br>
-<br>
- (when rendered at 72dpi) will fill 2 pixels, rather than 1.<br>
-<br>
- The fix is rather more involved that you'd like, as we need to<br>
- treat the cursor being on this vertical edge as a special case.<br>
- We flush and &quot;null&quot; the cursor when we arrive on such an edge,<br>
- and ignore horizontal motion across such edges.<br>
-<br>
- The identical fixes are required both for trap and rect filling.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-08 09:24:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a73071b87a61acf1237da5ad9da59bae9316fb8c">a73071b87a61acf1237da5ad9da59bae9316fb8c</a>
-<blockquote>
-<p>
- Bug 699907: Reinstate GTK+ 2.x.x code.<br>
-<br>
- The fix (from March 2018) for deprecated API calls in the GTK+ 3.x.x API<br>
- didn't account for the new, supported methods not being available in<br>
- GTK+ 2.x.x. Handle both cases, as we do elsewhere.<br>
-<br>
-psi/dxmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-03 17:47:06 +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=0269a72336f210c1736efbf0916a41be4d808d5d">0269a72336f210c1736efbf0916a41be4d808d5d</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV after calling gs_image_class_1_simple.<br>
-<br>
- Prevent SEGV if memory allocation fails leading to penum being freed but then<br>
- used again later.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=20913 ./membin/gpcl6 -sDEVICE=pbmraw -dMaxBitmap=2000 -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0100<br>
-<br>
-base/gxifast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-25 22:25:26 +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=52a37b63bb49e221c3f1b5d1ee11b63ce69da1f0">52a37b63bb49e221c3f1b5d1ee11b63ce69da1f0</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV in gs_setdevice_no_erase.<br>
-<br>
- Prevent SEGV if gsicc_init_iccmanager fails.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=350 ./membin/gpcl6 -sDEVICE=pbmraw -dMaxBitmap=2000 -o /dev/null ./tests_private/pcl/pcl5cfts/fts.0070<br>
-<br>
-base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-03 17:00: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=0a7e5a1c309fa0911b892fa40996a7d55d90bace">0a7e5a1c309fa0911b892fa40996a7d55d90bace</a>
-<blockquote>
-<p>
- PDF interpreter - limit page tree recusrsion checking<br>
-<br>
- Bug #699856 &quot;Attempting to open a carefully crafted PDF file results in long-running computation&quot;<br>
-<br>
- A sufficiently bad page tree can lead to us taking significant amounts<br>
- of time when checking the tree for recursion.<br>
-<br>
- We can limit this by noting the number of pages in the root node<br>
- (given by /Count) and stopping the recursion check when we have<br>
- encountered that many leaf nodes.<br>
-<br>
- Our other recursion checks work by reading the resources from the page<br>
- nodes and so are unaffected by this.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-10-03 14:48: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=d06af15c447f821309cabb0dba5ff97ce1ea4c99">d06af15c447f821309cabb0dba5ff97ce1ea4c99</a>
-<blockquote>
-<p>
- Bug 699857: don't push userdict in preparation for Type 1 fonts<br>
-<br>
- Apparently, Fontographer fonts require a writable dictionary on the<br>
- dict stack. For some reason lost in mists of time, we pushed userdict for that<br>
- purpose - the problem is, that leaves any random redefinition of operators in<br>
- place when we interpret the font file.<br>
-<br>
- Instead, we now push an empty, temporary dictionary for those Fontographer<br>
- fonts. As we already explicitly push systemdict (before the writable dictionary)<br>
- that ensures a consistent environment for the interpretation of Type 1 fonts.<br>
-<br>
-Resource/Init/gs_type1.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-30 22:57: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=cbdc54055b7db024951daf3dcb3cafe0af458e47">cbdc54055b7db024951daf3dcb3cafe0af458e47</a>
-<blockquote>
-<p>
- Change device put_image method to match the other methods in the API<br>
-<br>
- The put_image device method was unique in that the device parameter<br>
- passed to the method was not a pointer to a device structure of the<br>
- device implementing the method, but was a pointer to a device<br>
- structure describing a memory device.<br>
-<br>
- This allowed the memory device to use code from the underlying device,<br>
- which knows how its page buffer is laid out, but data from the memory<br>
- device which rendered the composited transparent operations.<br>
-<br>
- However, this doesn't work at all if we have a chain of devices because<br>
- the device method which we pull from the device at the head of the<br>
- chain, is not the method used to actually rendeer to the page buffer<br>
- of the terminating deevice in the chain.<br>
-<br>
- This commit alters the prorotype to take two device pointers, one for<br>
- the 'terget' device, and one for the memory device which executed the<br>
- put_image. This allows the final device in the chain to use its own<br>
- code to format the buffer pointers from the memory device, while<br>
- allowing intermediate devices to simply pass on the call.<br>
-<br>
- Note that previously a few places checked the put_image method against<br>
- gx_default_put_image (before the device API rationalisation this was a<br>
- check against NULL) and only called put_image if it was not the default.<br>
-<br>
- Now that we have a default implementation (which returns an error), and<br>
- knowing that the existing device methods return an error if they do not<br>
- implment some aspect of the memory layout, we can avoid the test<br>
- altogether; simply call the put_image, the code is already prepared<br>
- to deal with an error return whether that be because the device does not<br>
- implement the method or becuase the device cannot cope with some aspect<br>
- of the layout.<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevepo.c<br>
-base/gdevflp.c<br>
-base/gdevmem.c<br>
-base/gdevmpla.c<br>
-base/gdevnfwd.c<br>
-base/gdevoflt.c<br>
-base/gdevp14.c<br>
-base/gdevsclass.c<br>
-base/gxblend1.c<br>
-base/gxdevcli.h<br>
-base/gxdevice.h<br>
-devices/gdevbit.c<br>
-devices/gdevpng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-27 10:31: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=9565f4ca4aab712f411420fa4c8cae79a2cf88ed">9565f4ca4aab712f411420fa4c8cae79a2cf88ed</a>
-<blockquote>
-<p>
- Bug 699813 &quot;filenameforall calls bad iodev with insufficent scratch&quot;<br>
-<br>
- This was a regression introduced with commit<br>
- 65a9046ded8e9edd5d33bc812a9e94ae29607a1e<br>
-<br>
- I hadn't realised the cleanup procedure was expected to be called in the<br>
- case of both the success *and* error conditions.<br>
-<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-25 15:38:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f8ccc7dfb990336b1ca55f65f2e1a8ecdcb76adf">f8ccc7dfb990336b1ca55f65f2e1a8ecdcb76adf</a>
-<blockquote>
-<p>
- Bug 699793: Hide the .needinput operator<br>
-<br>
- This removes the .needinput operator from systemdict, ensuring it can only<br>
- be used in the initialization code, and not called erroneously from random<br>
- Postscript.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-25 21:50:49 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=043e3d9058f414607ed8454783175db57e7e6524">043e3d9058f414607ed8454783175db57e7e6524</a>
-<blockquote>
-<p>
- Always set the tag, even if the device won't encode it.<br>
-<br>
- Intended to sort an issue encountered while debugging bug 699809,<br>
- namely that tag dependent ICC handling only works for devices that<br>
- actually encode tags.<br>
-<br>
-base/gxgstate.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-25 13:57:54 -0400
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=efe6d83852b131852550de948e7d0869c01c31f8">efe6d83852b131852550de948e7d0869c01c31f8</a>
-<blockquote>
-<p>
- Bug 699809: Fix uninitialised value for render_cond.<br>
-<br>
- gsicc_get_srcprofile doesn't return a render_cond value in<br>
- all cases. This leads to an undefined value being read, and<br>
- this can lead to a SEGV.<br>
-<br>
-base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-25 07:23:07 -0400
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0bfd5394bc1ed6ef9e887071dc14391923e69ebf">0bfd5394bc1ed6ef9e887071dc14391923e69ebf</a>
-<blockquote>
-<p>
- Bug 699809: Avoid overrunning non terminated string buffer.<br>
-<br>
- Don't call strlen on something that doesn't have a terminator.<br>
- Use the stored length instead.<br>
-<br>
-base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-25 11:57:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=677da1c0ac20020760b372a0c8aa5546d0a30429">677da1c0ac20020760b372a0c8aa5546d0a30429</a>
-<blockquote>
-<p>
- Bug 699810: Explicitly set stroke color for PDF Type 3 glyphs<br>
-<br>
- When we render a cache-viable Type 3 glyphs (i.e. one that uses 'd1' rather<br>
- than 'd0'), ensure we set the stroke color to match the fill color.<br>
-<br>
- This is necessary because if we do cache the glyph, we'll render to a mask, and<br>
- fill the mask. On the other hand, if we have to render the glyph uncached,<br>
- we have to ensure that the entire glyph is drawn with the same (fill) color, as<br>
- it would be when drawn cached.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-21 12:03: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=db606d2ffd204e89c812408773a15ef183ebd4b6">db606d2ffd204e89c812408773a15ef183ebd4b6</a>
-<blockquote>
-<p>
- Fix Bug 699794 -- device subclass open_device call must return child code<br>
-<br>
- Even with changes to detect and clean up from errors in setpagedevice (b5)<br>
- and .bigstring, the segfault was still possible because the error return<br>
- code from the child was being ignored, and the device is_open was set true<br>
- when the child device was NOT open. Attempt to 'fillpage' on a clist device<br>
- that is not open is what caused the SEGV.<br>
-<br>
-base/gdevsclass.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-21 12:00:50 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c29ec2fff76e45bbf9cd767ff541556c5d064be4">c29ec2fff76e45bbf9cd767ff541556c5d064be4</a>
-<blockquote>
-<p>
- Add parameter checking in setresolution<br>
-<br>
- Found in sequence for bug 699794<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-21 11:42:19 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=379be67a6a198766e976f1e5daf43e0c0e97522a">379be67a6a198766e976f1e5daf43e0c0e97522a</a>
-<blockquote>
-<p>
- Add parameter type checking on .bigstring<br>
-<br>
- If the parameter is not an integer, this would leave 65400 on the stack.<br>
- Also, if there is no argument, signal stackunderflow.<br>
- Seen with the PS sequence of bug 699794.<br>
-<br>
-Resource/Init/gs_ll3.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-21 11:37: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=9d6ac20d9b2efdabb631a0ff9b0b0fd5c32f5e75">9d6ac20d9b2efdabb631a0ff9b0b0fd5c32f5e75</a>
-<blockquote>
-<p>
- Catch errors and cleanup stack on statusdict page size definitions<br>
-<br>
- This was also found with the sequence from Bug 699794, if .setpagesize<br>
- fails, we need to clean up the two integers (page width, height) then<br>
- signal the error. Since some definitions &quot;load&quot; another (e.g. b5 loads<br>
- isob5) the command name in the error won't be correct for those, but<br>
- it will be close. If anybody cares, we could fix it.<br>
-<br>
-Resource/Init/gs_statd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-21 11:16:18 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=95aa78beae9489d5c9f898fe2032aa23f860867d">95aa78beae9489d5c9f898fe2032aa23f860867d</a>
-<blockquote>
-<p>
- Catch errors in setpagesize, .setpagesize and setpagedevice and cleanup<br>
-<br>
- Bug 699794 showed that attempt to change page size in SAFER mode when the<br>
- nulldevice was the currentdevice would leave 'false' on the stack. Run<br>
- .setdevice in stopped and clean up, and also clean up .setpagesize<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_setpd.ps<br>
-Resource/Init/gs_statd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-23 16:08: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=863b370ba7d791720b97ae10deb211fde8bdbd0a">863b370ba7d791720b97ae10deb211fde8bdbd0a</a>
-<blockquote>
-<p>
- pdfwrite - permit Mod and CreDate pdfmarks in PDF 2.0<br>
-<br>
- Bug 699807 &quot;-dCompatibilityLevel=2.0` prevents all metadata from being set&quot;<br>
-<br>
- PDF 2.0 has deprecated The Document Info dictionary, so we prevented<br>
- pdfmarks from modifying the data in it, as a prelude to removing it<br>
- potentially when later versions of the PDF spec are approved.<br>
-<br>
- However, as the report says, the Creation Date and Modification Date<br>
- are still required for documents with PieceInfo (only), so for now we<br>
- will permit those two values (only) to be set.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-22 14:09: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=0fdbf706be847198be202eefd3e20fc95d60cbcb">0fdbf706be847198be202eefd3e20fc95d60cbcb</a>
-<blockquote>
-<p>
- device subclassing - fix use of put_image in memory devices<br>
-<br>
- Bug 699799 &quot;gswin64c.exe has stopped working&quot;<br>
-<br>
- The cause of this is truly ugly. It seems that the put_image device<br>
- method, uniquely, expects that the device parameter it is passed is not<br>
- the device for which it was intended, but is instead a 'memory'<br>
- device.<br>
-<br>
- All the implementations of put_image start by casting the gx_device *<br>
- to a gx_device_memory *<br>
-<br>
- This is problematic, because it completely disrupts any attempt at a<br>
- device chain. There's no way to have a device's method check to see if<br>
- it has a child device, if its not given its owe device to work with.<br>
-<br>
- This commit hacks around the problem by descending to the terminating<br>
- device, and copying the put_image call from there into the memory device<br>
- which is what the pdf14 compositor will then use.<br>
-<br>
- This needs fixing properly.<br>
-<br>
-base/gdevmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-30 18:39:07 -0500
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=08fb5ddb928cfc7c4cd5f348f28862d97e53d07a">08fb5ddb928cfc7c4cd5f348f28862d97e53d07a</a>
-<blockquote>
-<p>
- Squash warnings in gen_ordered.c<br>
-<br>
- Use ints instead of doubles, because the values only hold ints!<br>
-<br>
-base/gen_ordered.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-21 15:28:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f31702b38fba21153e26c3417c838618e7cfd16f">f31702b38fba21153e26c3417c838618e7cfd16f</a>
-<blockquote>
-<p>
- pdfwrite - fix DSC comment parsing<br>
-<br>
- This may affect other DSC parsing utilities. For some reason double<br>
- comment (%%) marks are being interpreted 'sometimes' in gs_init.ps<br>
- as DSC comments. This only happens when reading the init files from disk<br>
- becuase the ROM file system strips comments.<br>
-<br>
- Passing these to pdfwrite causes it to drop later DSC comments, such<br>
- as %%Title: and %%Creator: which meant the information wasn't being<br>
- embedded in the document information dictionary.<br>
-<br>
- Fix by converting double %% to single % comments, document this in the<br>
- header of gs_init.ps.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-21 13:02:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fac7eb144135f3ed8fbb0028ab1f33ce4dcc1985">fac7eb144135f3ed8fbb0028ab1f33ce4dcc1985</a>
-<blockquote>
-<p>
- Check all uses of dict_find* to ensure 0 return properly handled<br>
-<br>
- dict_find and friends have the surprising quirk of returning &lt; 0 for<br>
- an error and &gt; 0 for no error. But they can also return 0 which means<br>
- 'not found' without it being an error.<br>
-<br>
- From bug 699801, if the code assumes the usual case where 0 is a success<br>
- then an attempt might be made to use the empty dictionary slot returned<br>
- by dict_find*, which can lead to seg faults, and certainly won't have<br>
- the expected result.<br>
-<br>
-psi/icontext.c<br>
-psi/zcid.c<br>
-psi/zfapi.c<br>
-psi/zfcid0.c<br>
-psi/zfcid1.c<br>
-psi/zicc.c<br>
-psi/zpdf_r6.c<br>
-psi/ztoken.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-21 09:49:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ee525fd0010a4f0bb507417860e9faa058c6315">7ee525fd0010a4f0bb507417860e9faa058c6315</a>
-<blockquote>
-<p>
- Bug #699801 &quot;zparse_dsc_comments can crash with invalid dsc_state&quot;<br>
-<br>
- Although zparse_dsc_comments() does check the types of its operands, it<br>
- wasn't checking the return value from dict_find_string properly. It was<br>
- effectively assuming that the dictionary parameter was the *correct*<br>
- dictionary and would contain the key/value pair it needed.<br>
-<br>
- Here we check to see if the key has not been found and throw an error<br>
- if so.<br>
-<br>
-psi/zdscpars.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-21 08:45:35 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2118711d122aeb170031ab7eb80e5a9269055772">2118711d122aeb170031ab7eb80e5a9269055772</a>
-<blockquote>
-<p>
- Bug 699802: add object type check for AES key<br>
-<br>
- Make sure the key string is a string.<br>
-<br>
-psi/zfaes.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-20 17:08: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=8ed08cb9904bc718ad57e0b4884a81a9227ce3ea">8ed08cb9904bc718ad57e0b4884a81a9227ce3ea</a>
-<blockquote>
-<p>
- Bug 699797 &quot;setundercolorremoval memory corruption&quot;<br>
-<br>
- What is happening is that we are not properly reference counting a<br>
- structure.<br>
-<br>
- For setblackgeneration and setundercolorremoval we need to use a<br>
- continuation procedure, which samples the supplied PostScript function<br>
- and then stores the sample map.<br>
-<br>
- As part of this we create an internal structure to hold the map, and we<br>
- make this the current undercolorremoval/blackgeneration entry in the<br>
- graphics state. We *also* push a reference to it onto the exec stack,<br>
- so that the continuation procedure can use it from there. However we<br>
- don't increment the reference count.<br>
-<br>
- When we execute the 'grestore' in the function we reset the values in<br>
- the graphics state, and because the reference count is one we count it<br>
- down and then discard the structure.<br>
-<br>
- When we then throw an error we try to copy data off the exec stack into<br>
- an array, when we hit the reference to the freed strcuture we potentially<br>
- are pointing to invalid memory, leading to a seg fault.<br>
-<br>
- To fix this, increment the reference count of the object when we put<br>
- it on the exec stack, and decrement it when we remove it from the exec<br>
- stack.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-19 18:21:02 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=18e8a06bd34bb51c08760b7ebdbab68ab45712c1">18e8a06bd34bb51c08760b7ebdbab68ab45712c1</a>
-<blockquote>
-<p>
- Bug 699793: Fix handling of .needinput if used from interpreter<br>
-<br>
- .needinput is meant as an internal function, but it is exposed<br>
- to the user. I couldn't see an easy way to undefine it.<br>
-<br>
- But if user calls it, it returns gs_error_Fatal in a place that the<br>
- code wasn't expecting, and basically puts things in an undefined<br>
- state. This change returns a Fatal error at this point, instead.<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-19 09:14:02 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=caa8b4c279a078419ee9c002106a84703c090d5d">caa8b4c279a078419ee9c002106a84703c090d5d</a>
-<blockquote>
-<p>
- Cleanups for FAPI functions<br>
-<br>
- Fix .FAPIAvailable to check for stack underflow<br>
-<br>
- Undefine FAPI functions at end of gs_fapi.ps<br>
- (.FAPIavailable, .FAPIpassfont, .FAPIrebuildfont)<br>
-<br>
- The rendering functions, .FAPIBuildGlyph, .FAPIBuildChar, .FAPIBuildGlyph9,<br>
- are still defined. I noticed similar rendering funcs for other fonts are also<br>
- exposed -- not sure if this is fixable or not.<br>
-<br>
-Resource/Init/gs_fapi.ps<br>
-Resource/Init/gs_init.ps<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-20 16:35: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=b0222e5e39712999f22084996a6b85a120b9389e">b0222e5e39712999f22084996a6b85a120b9389e</a>
-<blockquote>
-<p>
- Bug 699795: add operand checking to .setnativefontmapbuilt<br>
-<br>
- .setnativefontmapbuilt .forceputs a value into systemdict - it is intended<br>
- to be a boolean, but in this case was being called with a compound object<br>
- (a dictionary). Such an object, in local VM, being forced into systemdict<br>
- would then confuse the garbager, since it could be restored away with the<br>
- reference remaining.<br>
-<br>
- This adds operand checking, so .setnativefontmapbuilt will simply ignore<br>
- anything other than a boolean value, and also removes the definition of<br>
- .setnativefontmapbuilt after use, since it is only used in two, closely<br>
- related places.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-20 14:23: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=78ed0a8f0339dba1674285b0aa1f460a59b0c3ee">78ed0a8f0339dba1674285b0aa1f460a59b0c3ee</a>
-<blockquote>
-<p>
- Ensure all errors are included from initialization<br>
-<br>
- Previously only Level 1 errors were added during init.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-20 10:09: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=90e8f8d32b64bae015e19e85e693988daaea54f4">90e8f8d32b64bae015e19e85e693988daaea54f4</a>
-<blockquote>
-<p>
- Bug #699796 &quot;copydevice fails after stack device copies invalidated&quot;<br>
-<br>
- This isn't anything to do with .fill_identity_cmap. A simpler example<br>
- is:<br>
-<br>
- .distillerdevice<br>
- nulldevice<br>
- copydevice<br>
-<br>
- The problem is that when we execute nulldevice we need to invalidate any<br>
- copies, stored on the operand stack, of the device that was current<br>
- before the nulldevice was installed.<br>
-<br>
- We do that by setting the pdevice member of the device structure to NULL.<br>
- However the fact that a device can be invalidated has clearly passed<br>
- by a number of developers in the intervening years, and a number of<br>
- places in the code do check the type of the operand is a device, but<br>
- they don't check to see if the device has been invalidated.<br>
-<br>
- Add validation checks where required.<br>
-<br>
-psi/idisp.c<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-18 14:15:55 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c1657e3b874261e254d4e132499355b22f3dd46a">c1657e3b874261e254d4e132499355b22f3dd46a</a>
-<blockquote>
-<p>
- Change &quot;executeonly&quot; to throw typecheck on gstatetype and devicetype objects<br>
-<br>
- PS doesn't really have a &quot;devicetype&quot;, but it is not listed as an<br>
- acceptable argument type to &quot;executeonly&quot;, so we probably should not<br>
- accept it.<br>
-<br>
- &quot;gstate executeonly&quot; throws typecheck in Acrobat, so we should do the same.<br>
-<br>
- Tested the other &quot;access related&quot; functions (noaccess, readonly,<br>
- rcheck, wcheck, xcheck) and all of these accept &quot;gstate&quot; as an<br>
- argument, even though the PLRM says they should not. Also our initialization<br>
- code does things with wcheck and readonly on devices and gstates.<br>
-<br>
- So, this fix is only for &quot;executeonly&quot;.<br>
-<br>
-psi/ztype.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-19 13:17: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=476f6d039fadc33be09068ec09e55824ce089759">476f6d039fadc33be09068ec09e55824ce089759</a>
-<blockquote>
-<p>
- Fix commit 93d13545f90c37327bf3ca7ac75c9549d7b52f6f<br>
-<br>
- The original fix was passing the px_state_t into px_process_init(), where what<br>
- it takes is actually a px_parser_state_t.<br>
-<br>
- Fixes segfault spotted on the 32bit weekly cluster test.<br>
-<br>
-pcl/pxl/pxsessio.c<br>
-pcl/pxl/pxtop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-18 21:10:33 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=93d13545f90c37327bf3ca7ac75c9549d7b52f6f">93d13545f90c37327bf3ca7ac75c9549d7b52f6f</a>
-<blockquote>
-<p>
- Reset the PXL parser along with state cleanup.<br>
-<br>
-pcl/pxl/pxsessio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-18 11:54:58 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c76bf1cb7cc419534006631ea139ae20801fd824">c76bf1cb7cc419534006631ea139ae20801fd824</a>
-<blockquote>
-<p>
- Undefine some additional internal operators.<br>
-<br>
- .type, .writecvs, .setSMask, .currentSMask<br>
-<br>
- These don't seem to be referenced anywhere outside of the initialization code,<br>
- which binds their usages. Passes cluster if they are removed.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-13 13:06:01 -0700
-</strong>
-<br>Nancy Durgin &lt;nancy.durgin@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=29d8ed33d90bea26b24995c43ad53119a943f2d6">29d8ed33d90bea26b24995c43ad53119a943f2d6</a>
-<blockquote>
-<p>
- Fixed a bunch of incorrect parameter counts<br>
-<br>
- (Note that these were basically harmless, but they make a nice hint to the<br>
- programmers, so it's nice if the hint is correct...)<br>
-<br>
-psi/zcolor.c<br>
-psi/zdevice.c<br>
-psi/zfile1.c<br>
-psi/zform.c<br>
-psi/zmisc.c<br>
-psi/zvmem2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-17 14:06:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7c3e7eee829cc3d2582e4aa7ae1fd495ca72cef1">7c3e7eee829cc3d2582e4aa7ae1fd495ca72cef1</a>
-<blockquote>
-<p>
- Implement .currentoutputdevice operator<br>
-<br>
- The currentdevice operator returns the device currently installed in the<br>
- graphics state. This can be the output/page device, but also could be a<br>
- forwarding device (bbox device), compositor (pdf14) or subclass device<br>
- (erasepage optimisation, First/Last page etc).<br>
-<br>
- In certain circumstances (for example during a setpagedevice) we want to be<br>
- sure we're retrieving the *actual* output/page device.<br>
-<br>
- The new .currentoutputdevice operator uses the spec_op device method to traverse<br>
- any chain of devices and retrieve the final device in the chain, which<br>
- should always be the output/page device.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_setpd.ps<br>
-base/gdevdflt.c<br>
-base/gxdevsop.h<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-17 10:18:16 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8bc783cb586231da2916f423bf5793e194092679">8bc783cb586231da2916f423bf5793e194092679</a>
-<blockquote>
-<p>
- Bug 699778: Fix doc/* file list in base/unixinst.mak<br>
-<br>
-base/unixinst.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-18 08:12: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=442b5608a6384358e26014c8dec81c169145461e">442b5608a6384358e26014c8dec81c169145461e</a>
-<blockquote>
-<p>
- Documentation - fix a couple of typos<br>
-<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-17 12:14:36 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1535333e85a2901cc873c2694c5ee8508cffd992">1535333e85a2901cc873c2694c5ee8508cffd992</a>
-<blockquote>
-<p>
- Bug 699777 &quot; -dFILTERIMAGE often loses text&quot;<br>
-<br>
- The pdfwrite device's implementation of transparency relies upon the<br>
- image for a Softmask being run, and pushing a clip, which increments the<br>
- viewer state. However if we have -dFILTERIMAGE in place, then we won't<br>
- do this (its in the pdfwrite implementation of begin_typed_image).<br>
-<br>
- When we close the transparency mask, this then leads to the viewer state<br>
- stack being out by one.<br>
-<br>
- There's no easy way to address this, so when we go to restore the viewer<br>
- state, if it would fall off the bottom then check to see if FILTERIMAGE<br>
- is true. If it is, then just don't return an error.<br>
-<br>
- This is a rare condition, it relies upon the transparency being nested<br>
- quite deeply in groups (in this case the SoftMask is nested about four<br>
- layers deep in spurious transparency).<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-11 18:47:10 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb887f9e8a318628b2b82120e1e825343264e42c">fb887f9e8a318628b2b82120e1e825343264e42c</a>
-<blockquote>
-<p>
- Remove unnecessary struct entry from pcl_interp_instance_s.<br>
-<br>
- We no longer extend the instance from the implementation.<br>
-<br>
-pcl/pcl/pctop.c<br>
-pcl/pxl/pxtop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-13 15:18: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=da0910fe776cf6f28391558d01bea8953235f1f7">da0910fe776cf6f28391558d01bea8953235f1f7</a>
-<blockquote>
-<p>
- VS Project: Add some missing files.<br>
-<br>
-windows/ghostpcl.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-06 19:33: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=68b679df65f8d9ffbbb4acdc2662105e440778df">68b679df65f8d9ffbbb4acdc2662105e440778df</a>
-<blockquote>
-<p>
- Fix &quot;ambiguous else&quot; warning.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-12 15:34:50 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=96ab2635885c40a81d6146d1f3363a019d8af93a">96ab2635885c40a81d6146d1f3363a019d8af93a</a>
-<blockquote>
-<p>
- Fix bug #699564 - pageside different from HP.<br>
-<br>
- The pageside should be updated only if the page is marked. Also<br>
- refactor and simplify the Page Side Select routine.<br>
-<br>
- Thanks to Norbert Janssen for identifying and analyzing this problem.<br>
-<br>
-pcl/pcl/pcjob.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-13 16:09: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=687e9a482e40d5e2fc6ac7aa66fb4791afccb949">687e9a482e40d5e2fc6ac7aa66fb4791afccb949</a>
-<blockquote>
-<p>
- Tweak examples/transparency_example.ps<br>
-<br>
- So it prints a warning and runs to completion, rather than erroring out<br>
- when -dSAFER is set.<br>
-<br>
-examples/transparency_example.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-10 09:25:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c7b6473b425445c6d6c0637f42fdbf5536244198">c7b6473b425445c6d6c0637f42fdbf5536244198</a>
-<blockquote>
-<p>
- Bring master up to date with 9.25 release branch<br>
-<br>
-base/version.mak<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-09-11 10:59:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba8eda9d8c62e34ce3fed2d22647797e29494eb7">ba8eda9d8c62e34ce3fed2d22647797e29494eb7</a>
-<blockquote>
-<p>
- Bug 699757: disable epo device for x11 devices<br>
-<br>
- The epo device interferes with the operation of the x11 devices when those<br>
- are integrating with an existing X application (i.e. xv, or other application<br>
- that relies on the 'GHOSTVIEW' functionality).<br>
-<br>
- Disable epo by adding an x11 specific fillpage method.<br>
-<br>
-devices/gdevx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-11 11:12:13 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b7c4003f6855b2e11cdda32cdf259c7005dce38b">b7c4003f6855b2e11cdda32cdf259c7005dce38b</a>
-<blockquote>
-<p>
- PDF interpreter - work around GSView 5 and PAGELABEL pdfmarks<br>
-<br>
- We added the ability to process PDF page labels as pdfmarks, instead of<br>
- using the .pagelabels operator (as used by pdfwrite) for the benefit of<br>
- DejaVu.<br>
-<br>
- Unfortunately, GSView 5 redefines the pdfmark operator, and attempts<br>
- to process the information itself. This is a problem when it doesn't<br>
- recognise the pdfmark in question, which it does not with PAGELABEL.<br>
-<br>
- There's no way for us to fix GSView 5, and we don't want to revert the<br>
- enhancement for DejaVu because that is still being actively maintained.<br>
-<br>
- This commit is a rather ugly hack which relies upon the presence of a<br>
- specific named dictionary in userdict when GSView is executing. If that<br>
- dictionary is present then we don't create PAGELABEL pdfmarks, thus<br>
- avoiding confusing GSView 5.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-10 09:21:26 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7fee37d18e9cbcbc99c3e0e5048a7de78f9be58e">7fee37d18e9cbcbc99c3e0e5048a7de78f9be58e</a>
-<blockquote>
-<p>
- Move pre-release version to 9.26<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-10 17:05: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=57c41b4d49ff949503f7d29a0f3dea0504b9e45e">57c41b4d49ff949503f7d29a0f3dea0504b9e45e</a>
-<blockquote>
-<p>
- Bug 699753: Windows uninstall: remove all installed files etc<br>
-<br>
- This was partly caused by a subtlety of the nsis installer syntax which means<br>
- the '/r' option for the 'File' operation will match and install all<br>
- files/directories in the file heirarchy that match the search term, unless they<br>
- are explicitly excluded.<br>
-<br>
- For example:<br>
- File /r doc<br>
-<br>
- will end up matching:<br>
- doc/<br>
- something/doc<br>
- another/thing/doc<br>
-<br>
- So, ensure we exclude subtrees so we no longer accidentally include files we<br>
- don't intend.<br>
-<br>
- Also, add the missing removals, so we do remove eveything we intended to<br>
- install.<br>
-<br>
- Lastly add in (and include removal of!) the Resource/* tree, and the iccprofiles<br>
- directories - both of which users have asked to be included.<br>
-<br>
-psi/nsisinst.nsi<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-10 07:42:13 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb1d28f6937f3692facc2f09ce540f5aa313380b">eb1d28f6937f3692facc2f09ce540f5aa313380b</a>
-<blockquote>
-<p>
- Correct getdeviceprops documentation<br>
-<br>
-doc/Language.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-13 10:54: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=070358777b534c600c522da8541690022102b7a6">070358777b534c600c522da8541690022102b7a6</a>
-<blockquote>
-<p>
- Dates, product string, changelog, etc for 9.25 release<br>
-<br>
-base/gscdef.c<br>
-base/version.mak<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-09-11 10:59:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b3fbf2bca24b2833322985be390fc739d237f7d">4b3fbf2bca24b2833322985be390fc739d237f7d</a>
-<blockquote>
-<p>
- Bug 699757: disable epo device for x11 devices<br>
-<br>
- The epo device interferes with the operation of the x11 devices when those<br>
- are integrating with an existing X application (i.e. xv, or other application<br>
- that relies on the 'GHOSTVIEW' functionality).<br>
-<br>
- Disable epo by adding an x11 specific fillpage method.<br>
-<br>
-devices/gdevx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-11 11:12:13 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ac63e47077e0e7d02e99e247e0c47c4737e0cb8">5ac63e47077e0e7d02e99e247e0c47c4737e0cb8</a>
-<blockquote>
-<p>
- PDF interpreter - work around GSView 5 and PAGELABEL pdfmarks<br>
-<br>
- We added the ability to process PDF page labels as pdfmarks, instead of<br>
- using the .pagelabels operator (as used by pdfwrite) for the benefit of<br>
- DejaVu.<br>
-<br>
- Unfortunately, GSView 5 redefines the pdfmark operator, and attempts<br>
- to process the information itself. This is a problem when it doesn't<br>
- recognise the pdfmark in question, which it does not with PAGELABEL.<br>
-<br>
- There's no way for us to fix GSView 5, and we don't want to revert the<br>
- enhancement for DejaVu because that is still being actively maintained.<br>
-<br>
- This commit is a rather ugly hack which relies upon the presence of a<br>
- specific named dictionary in userdict when GSView is executing. If that<br>
- dictionary is present then we don't create PAGELABEL pdfmarks, thus<br>
- avoiding confusing GSView 5.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-10 17:05: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=b3974730243cb449299524768fc810ad7bac4f73">b3974730243cb449299524768fc810ad7bac4f73</a>
-<blockquote>
-<p>
- Bug 699753: Windows uninstall: remove all installed files etc<br>
-<br>
- This was partly caused by a subtlety of the nsis installer syntax which means<br>
- the '/r' option for the 'File' operation will match and install all<br>
- files/directories in the file heirarchy that match the search term, unless they<br>
- are explicitly excluded.<br>
-<br>
- For example:<br>
- File /r doc<br>
-<br>
- will end up matching:<br>
- doc/<br>
- something/doc<br>
- another/thing/doc<br>
-<br>
- So, ensure we exclude subtrees so we no longer accidentally include files we<br>
- don't intend.<br>
-<br>
- Also, add the missing removals, so we do remove eveything we intended to<br>
- install.<br>
-<br>
- Lastly add in (and include removal of!) the Resource/* tree, and the iccprofiles<br>
- directories - both of which users have asked to be included.<br>
-<br>
-psi/nsisinst.nsi<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-10 07:42:13 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7738ffa5136549dd0cdcdf89974e339187246998">7738ffa5136549dd0cdcdf89974e339187246998</a>
-<blockquote>
-<p>
- Correct getdeviceprops documentation<br>
-<br>
-doc/Language.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-10 09:54:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7146378240f90bf4171ae7a2a00cc9d46eaec86d">7146378240f90bf4171ae7a2a00cc9d46eaec86d</a>
-<blockquote>
-<p>
- Add a note about unSAFERness of ps2epsi<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-10 09:25:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4cfee19351e36543927b78b97dbf2e600daa9bfe">4cfee19351e36543927b78b97dbf2e600daa9bfe</a>
-<blockquote>
-<p>
- Dates/news/history for 9.25 release candidate 1<br>
-<br>
-base/gscdef.c<br>
-base/version.mak<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>
-<hr size=20>
-
-<h2><a name="Version9.25"></a>Version 9.25 (2018-09-13)</h2>
-<p> Highlights in this release include:
-<ul>
-<li>
-<p>This release fixes problems with argument handling, some unintended results of
-the security fixes to the SAFER file access restrictions (specifically accessing
-ICC profile files), and some additional security issues over the recent 9.24 release.
-</li>
-<li>
-<p>Security issues have been the primary focus of this release, including solving
-several (well publicised) real and potential exploits.
-<br>
-<p> <big><u><b>PLEASE NOTE:</b> We <b>strongly</b> urge users to upgrade to this latest
-release to avoid these issues.</u></big>
-</li>
-<li>
-<p>As well as Ghostscript itself, jbig2dec has had a significant amount of work improving
-its robustness in the face of out specification files.
-</li>
-<li>
-<p>IMPORTANT: We are in the process of forking LittleCMS. LCMS2 is not thread safe, and
-cannot be made thread safe without breaking the ABI. Our fork will be thread safe, and include
-performance enhancements (these changes have all be been offered and rejected upstream). We
-will maintain compatibility between Ghostscript and LCMS2 for a time, but not in perpetuity.
-Our fork will be available as its own package separately from Ghostscript (and MuPDF).
-</li>
-<li>
-<p>The usual round of bug fixes, compatibility changes, and incremental improvements.
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.25_Incompatible_changes"></a>Incompatible changes</h3>
-<ul>
-<li>
-<p>None
-</li>
-</ul>
-<h3><a name="9.25_changelog"></a>Changelog</h3>
-<p><strong>2018-09-13 10:54: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=2f00215a28bcc43bb5857081378a6d956ef8b9d5">2f00215a28bcc43bb5857081378a6d956ef8b9d5</a>
-<blockquote>
-<p>
- Dates, product string, etc for 9.25 release<br>
-<br>
-base/gscdef.c<br>
-base/version.mak<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-09-11 10:59:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b3fbf2bca24b2833322985be390fc739d237f7d">4b3fbf2bca24b2833322985be390fc739d237f7d</a>
-<blockquote>
-<p>
- Bug 699757: disable epo device for x11 devices<br>
-<br>
- The epo device interferes with the operation of the x11 devices when those<br>
- are integrating with an existing X application (i.e. xv, or other application<br>
- that relies on the 'GHOSTVIEW' functionality).<br>
-<br>
- Disable epo by adding an x11 specific fillpage method.<br>
-<br>
-devices/gdevx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-11 11:12:13 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ac63e47077e0e7d02e99e247e0c47c4737e0cb8">5ac63e47077e0e7d02e99e247e0c47c4737e0cb8</a>
-<blockquote>
-<p>
- PDF interpreter - work around GSView 5 and PAGELABEL pdfmarks<br>
-<br>
- We added the ability to process PDF page labels as pdfmarks, instead of<br>
- using the .pagelabels operator (as used by pdfwrite) for the benefit of<br>
- DejaVu.<br>
-<br>
- Unfortunately, GSView 5 redefines the pdfmark operator, and attempts<br>
- to process the information itself. This is a problem when it doesn't<br>
- recognise the pdfmark in question, which it does not with PAGELABEL.<br>
-<br>
- There's no way for us to fix GSView 5, and we don't want to revert the<br>
- enhancement for DejaVu because that is still being actively maintained.<br>
-<br>
- This commit is a rather ugly hack which relies upon the presence of a<br>
- specific named dictionary in userdict when GSView is executing. If that<br>
- dictionary is present then we don't create PAGELABEL pdfmarks, thus<br>
- avoiding confusing GSView 5.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-10 17:05: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=b3974730243cb449299524768fc810ad7bac4f73">b3974730243cb449299524768fc810ad7bac4f73</a>
-<blockquote>
-<p>
- Bug 699753: Windows uninstall: remove all installed files etc<br>
-<br>
- This was partly caused by a subtlety of the nsis installer syntax which means<br>
- the '/r' option for the 'File' operation will match and install all<br>
- files/directories in the file heirarchy that match the search term, unless they<br>
- are explicitly excluded.<br>
-<br>
- For example:<br>
- File /r doc<br>
-<br>
- will end up matching:<br>
- doc/<br>
- something/doc<br>
- another/thing/doc<br>
-<br>
- So, ensure we exclude subtrees so we no longer accidentally include files we<br>
- don't intend.<br>
-<br>
- Also, add the missing removals, so we do remove eveything we intended to<br>
- install.<br>
-<br>
- Lastly add in (and include removal of!) the Resource/* tree, and the iccprofiles<br>
- directories - both of which users have asked to be included.<br>
-<br>
-psi/nsisinst.nsi<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-10 07:42:13 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7738ffa5136549dd0cdcdf89974e339187246998">7738ffa5136549dd0cdcdf89974e339187246998</a>
-<blockquote>
-<p>
- Correct getdeviceprops documentation<br>
-<br>
-doc/Language.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-10 09:54:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7146378240f90bf4171ae7a2a00cc9d46eaec86d">7146378240f90bf4171ae7a2a00cc9d46eaec86d</a>
-<blockquote>
-<p>
- Add a note about unSAFERness of ps2epsi<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-10 09:25:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7657f3698ce5a440b069ff953e57841950919132">7657f3698ce5a440b069ff953e57841950919132</a>
-<blockquote>
-<p>
- Dates etc for 9.25 release candidate 1<br>
-<br>
-base/gscdef.c<br>
-base/version.mak<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-09-10 08:41: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=7b0c4cc3e79d1e689b5fc3251a1130f409ed7a82">7b0c4cc3e79d1e689b5fc3251a1130f409ed7a82</a>
-<blockquote>
-<p>
- Bug 699748 &quot;gs9.24/windows can't process environment variable GS_OPTIONS anymore&quot;<br>
-<br>
- This problem only exhibits in a 64-bit build.<br>
-<br>
- The problem is caused by the union of 's' and 'file' in the arg_source<br>
- structure. When in a 32-bit build, this happens to work out to be 0<br>
- when the source is a string and not a file. But in a 64-bit it does not.<br>
-<br>
- Now because we have a 'is_file' member in the structure this isn't a<br>
- problem, except that in get_codepoint() we pass both the u.file and<br>
- u.str members to the decoding function. In get_codepoint_utf8 we then<br>
- check to see if 'file' is 0, and if it is not, we attempt to read from<br>
- it. If 'file' is 0, then we treat this as a string instead.<br>
-<br>
- To avoid altering the decoding function, with potential knock-on effects<br>
- through the code, I've chosen to test the 'is_file' member and pass<br>
- NULL for the file if this is not a file.<br>
-<br>
-base/gsargs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-08 09:47: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=95281026d983bff8f72e431c7f620a0e8d07c2af">95281026d983bff8f72e431c7f620a0e8d07c2af</a>
-<blockquote>
-<p>
- Bug 699744 &quot;ps2epsi fails with Error: /undefined in --setpagedevice--&quot;<br>
-<br>
- Recent changes required to harden SAFER mode mean that it is no longer<br>
- possible to run this script in SAFER mode, because it relies upon<br>
- unsafe Ghostscript non-standard extension operators.<br>
-<br>
- Removing SAFER and DELAYSAFER, and the code to reset SAFER, allow the<br>
- program to run as well as it ever did (ie badly). This program should<br>
- now be considered unsafe, you should not use it on untrusted PostScript<br>
- programs.<br>
-<br>
- I think its likely we will deprecate and remove this program in future.<br>
-<br>
-lib/ps2epsi<br>
-lib/ps2epsi.bat<br>
-lib/ps2epsi.cmd<br>
-lib/ps2epsi.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-07 10:33:41 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=232c2bf9db56ab32fbe5026e1b3eabdbb88380a8">232c2bf9db56ab32fbe5026e1b3eabdbb88380a8</a>
-<blockquote>
-<p>
- gprf device: Memory leak<br>
-<br>
- The deflate_block was not being freed after the writing of the page.<br>
-<br>
-devices/gdevgprf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-07 10:17:44 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d4c2e30bc057bc99e8d0fac04f6ecaae4721f435">d4c2e30bc057bc99e8d0fac04f6ecaae4721f435</a>
-<blockquote>
-<p>
- Get formats set properly in gscms_transform_color<br>
-<br>
- The color space was not getting set in the input<br>
- and output formats when we had a change in the lcms<br>
- formatters.<br>
-<br>
-base/gsicc_lcms2mt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-07 08:54:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa78d81c37afc28950020df4accf58d7bb1d01e7">fa78d81c37afc28950020df4accf58d7bb1d01e7</a>
-<blockquote>
-<p>
- Initialize a variable.<br>
-<br>
- Prevents static analysis tools from complaining about it being used<br>
- uninitialized (it's being to in order to initialize it).<br>
-<br>
-psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-07 08:16:06 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=790f13e61ddbe232327b34665606f52b4d943676">790f13e61ddbe232327b34665606f52b4d943676</a>
-<blockquote>
-<p>
- Tidy up adding the temp dirs to the PermitFile* arrays<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-07 08:07:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=643b24dbd002fb9c131313253c307cf3951b3d47">643b24dbd002fb9c131313253c307cf3951b3d47</a>
-<blockquote>
-<p>
- Bug 699718(2): Improve/augment stack size checking<br>
-<br>
- Improve the rebustness of the previous solution (previously it could trigger an<br>
- error when there *was* stack capacity available).<br>
-<br>
- Remove redundant check: we don't need to check if the *current* stack size is<br>
- sufficient, before checking the maximum permitted stack size.<br>
-<br>
- Also check the exec stack, as execstackoverflow can also cause the<br>
- Postscript call out to fail.<br>
-<br>
- Lastly, in event of failure, put the LockSafetyParams flag back in the existing<br>
- device (this is only necessary because we don't enfore JOBSERVER mode).<br>
-<br>
- Note: the Postscript callout (%grestorepagedevice) never pushes any dictionaries<br>
- on the dict stack - if that changes, we should check that stack, too.<br>
-<br>
-psi/zdevice2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-07 08:05: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=7dd56d01397a40da636ad88a5d19af4e2e404e6a">7dd56d01397a40da636ad88a5d19af4e2e404e6a</a>
-<blockquote>
-<p>
- Put .setdebug back into the proc removal list for SAFER<br>
-<br>
- accidentally removed in a previous commit<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-07 15:22:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=65a9046ded8e9edd5d33bc812a9e94ae29607a1e">65a9046ded8e9edd5d33bc812a9e94ae29607a1e</a>
-<blockquote>
-<p>
- Bug #699707 &quot;Security review bug - continuation procedures&quot;<br>
-<br>
- As a result of the recent security review, this bug was raised to go<br>
- through the PostScript interpreter looking for places where we exit the<br>
- 'C' level and return control to PostScript. This is done when we need<br>
- to evaluate something in the PostScript environment, such as a transfer<br>
- function or a tint transform.<br>
-<br>
- Because these functions are written in PostScript we need to run them<br>
- in the PostScript environment.<br>
-<br>
- To do this we push the procedure (or at least 'a' procedure) onto the<br>
- exec stack and exit with an o_push_estack error. In many cases that's<br>
- all we need to do, but sometimes we want to return control back to the<br>
- 'C' environment and, in some of those cases, we want to store some state<br>
- for the C code. We can't use the operand stack (because the PostScript<br>
- function will alter that) so we store stuff on the exec stack instead.<br>
-<br>
- When we complete the C level, we should restore the exec stack, so if<br>
- we stored any state on it, we should remove it. Sometimes we were not<br>
- doing so if there was an error.<br>
-<br>
- Generally this did not cause a problem, because in general on an error<br>
- we would stop. However if the error handler had been altered it was<br>
- possible we might carry on. 'Sometimes' that would mean we tried to<br>
- execute something which wasn't executable, and sometimes it might mean<br>
- that we tried to return to the C level, but without the expected<br>
- state on the exec stack.<br>
-<br>
- This could lead to memory corruption and crashes.<br>
-<br>
- This commit tries to find everywhere where we might end up leaving<br>
- extra items on the exec stack in the case of an error, and either<br>
- removes the required number of items from the exec stack or uses<br>
- whatever cleanup routine was established for the C code.<br>
-<br>
- Its important to note that, in normal use, none of these could actually<br>
- cause a problem. This makes it hard to test. all the cases here I have<br>
- tested, though in many cases the only way I could produce an error was<br>
- by forcing an error return in the debugger. I suspect some error cases<br>
- simply aren't possible but its good practice to check the return codes<br>
- anyway, even if its only a theoretical problem.<br>
-<br>
-psi/zalg.c<br>
-psi/zcie.c<br>
-psi/zcolor1.c<br>
-psi/zcontrol.c<br>
-psi/zfile.c<br>
-psi/zht1.c<br>
-psi/zht2.c<br>
-psi/zpath1.c<br>
-psi/zpcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-06 14:18: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=0da9680ca0506fd3cdf70840ad5387d85cab4996">0da9680ca0506fd3cdf70840ad5387d85cab4996</a>
-<blockquote>
-<p>
- gscms_transform_color fails in cloning operation<br>
-<br>
- The cloning operation was getting called with a NULL<br>
- pointer for the current ICC link handle.<br>
-<br>
-base/gsicc_lcms2mt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-06 11:39:58 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6ebd382763546e31a024376ff49ff2f074627de">f6ebd382763546e31a024376ff49ff2f074627de</a>
-<blockquote>
-<p>
- Remove obsolete code and comment (from 1999)<br>
-<br>
- After this long, there is no reason to carry this code around that was<br>
- a hack for joins of a flattened curve.<br>
-<br>
-base/gxstroke.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-06 12:07:35 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f509c2c1350fbb3549dcd539448bf02742c1b49e">f509c2c1350fbb3549dcd539448bf02742c1b49e</a>
-<blockquote>
-<p>
- gproof device supports post rendering ICC profile<br>
-<br>
- This issue was introduced during some error clean up<br>
- of the ICC profile code.<br>
-<br>
-devices/gdevgprf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-06 18:40: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=13418541a5ae19b15f51cbb87faf344902f5af98">13418541a5ae19b15f51cbb87faf344902f5af98</a>
-<blockquote>
-<p>
- Bug 699722 (2): add wildcards to the permissions paths.<br>
-<br>
- The temp and ICC profile paths need to finish with wildcards to work correctly.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-05 17:14: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=3e5d316b72e3965b7968bb1d96baa137cd063ac6">3e5d316b72e3965b7968bb1d96baa137cd063ac6</a>
-<blockquote>
-<p>
- Bug 699718: Ensure stack space is available before gsrestore call out<br>
-<br>
- During a grestore, if the device is going to change, we call out to Postscript<br>
- to restore the device configuration, before returning to restore the graphics<br>
- state internally.<br>
-<br>
- We have to ensure sufficient op stack space is available to complete the<br>
- operation, otherwise the device can end up an undefined state.<br>
-<br>
-Resource/Init/gs_setpd.ps<br>
-psi/zdevice2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-06 14:08: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=c8c01f8c4164bc10281d9e8f87cf96314d93104b">c8c01f8c4164bc10281d9e8f87cf96314d93104b</a>
-<blockquote>
-<p>
- Bug 699722: Add the ICCProfilesDir to the PermitReading list<br>
-<br>
- There was also an issue that the string being returned from the graphics<br>
- library was null terminated, and Postscript strings are not (and Ghostscript<br>
- strings are not necessarily). We leave the null termination in place, but<br>
- reduce the length returned by 1.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-06 09:16:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb713b3818b52d8a6cf62c951eba2e1795ff9624">fb713b3818b52d8a6cf62c951eba2e1795ff9624</a>
-<blockquote>
-<p>
- Bug 699708 (part 1): 'Hide' non-replaceable error handlers for SAFER<br>
-<br>
- We already had a 'private' dictionary for non-standard errors: gserrordict.<br>
-<br>
- This now includes all the default error handlers, the dictionary is made<br>
- noaccess and all the prodedures are bound and executeonly.<br>
-<br>
- When running with -dSAFER, in the event of a Postscript error, instead of<br>
- pulling the handler from errordict, we'll pull it from gserrordict - thus<br>
- malicious input cannot trigger problems by the use of custom error handlers.<br>
-<br>
- errordict remains open and writeable, so files such as the Quality Logic tests<br>
- that install their own handlers will still 'work', with the exception that the<br>
- custom error handlers will not be called.<br>
-<br>
- This is a 'first pass', 'sledgehammer' approach: a nice addition would to allow<br>
- an integrator to specify a list of errors that are not to be replaced (for<br>
- example, embedded applications would probably want to ensure that VMerror is<br>
- always handled as they intend).<br>
-<br>
-Resource/Init/gs_init.ps<br>
-psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-05 17:00: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=0d8c7d563745bfd89051a203267fcbf2492ecfcc">0d8c7d563745bfd89051a203267fcbf2492ecfcc</a>
-<blockquote>
-<p>
- Bug 699720: Change available buffer space to int from uint<br>
-<br>
- sbufavailable() returns the number of bytes still available in the stream<br>
- buffer. This can end up as negative at EOF (after we've read the final byte in<br>
- the buffer, we read ptr is moved to the next byte, past the end of the buffer -<br>
- that should never be read, however).<br>
-<br>
- We can safely use a signed integer since this is buffer space, *not* the total<br>
- bytes available from the stream<br>
-<br>
-psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-05 12:54:46 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=37c1547e61e758cdd17c3dcb0504e2f5988004c3">37c1547e61e758cdd17c3dcb0504e2f5988004c3</a>
-<blockquote>
-<p>
- Delete legacy code source file, and references to it<br>
-<br>
-base/gp_sysv.c<br>
-base/unix-aux.mak<br>
-doc/Develop.htm<br>
-doc/Source.htm<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-04 14:35:18 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=164b6cb355900d0faea7468b4eafb3154aa90f6a">164b6cb355900d0faea7468b4eafb3154aa90f6a</a>
-<blockquote>
-<p>
- Fix some comment typos.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-06 07:33:16 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3a5815b014c316e28584f134dc3c06e43c848b38">3a5815b014c316e28584f134dc3c06e43c848b38</a>
-<blockquote>
-<p>
- Add overprint support to knock out rect-fill<br>
-<br>
- When doing the rect fill for transparency knockout groups<br>
- we were not handling overprint properly<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-04 11:18: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=5317e232d5a0309fc367d8bedb89988dd4bc38c9">5317e232d5a0309fc367d8bedb89988dd4bc38c9</a>
-<blockquote>
-<p>
- Fix bit rot in RAW_DUMP and TRACK_COMPOSE_GROUPS<br>
-<br>
- maskbuf is not defined in this particular path (as it is NULL)<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-07-09 16:38: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=1435e31660ba94909688dabf74b411ead3196384">1435e31660ba94909688dabf74b411ead3196384</a>
-<blockquote>
-<p>
- Fix bug in mkromfs binary compaction.<br>
-<br>
- When writing long strings, psc-&gt;inpos changes value between<br>
- writing it's low and high bytes.<br>
-<br>
-base/mkromfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-07-05 17:16:00 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ec955366733d15a4f720271186abcf922ea2535">5ec955366733d15a4f720271186abcf922ea2535</a>
-<blockquote>
-<p>
- Remove GS_NO_UTF8<br>
-<br>
-base/gp_mswin.c<br>
-base/gp_ntfs.c<br>
-base/gp_wgetv.c<br>
-base/gp_wutf8.c<br>
-base/gsargs.c<br>
-base/msvclib.mak<br>
-base/windows_.h<br>
-devices/gdevwpr2.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plwmainc.c<br>
-psi/dwmain.c<br>
-psi/dwmainc.c<br>
-psi/dwtext.c<br>
-psi/dwtext.h<br>
-psi/iapi.c<br>
-psi/imainarg.c<br>
-psi/iminst.h<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-07-09 11:15:00 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bc1d2d9742c960f1d4905f43810be072c5d92390">bc1d2d9742c960f1d4905f43810be072c5d92390</a>
-<blockquote>
-<p>
- Bug 691725: Tweak gssetgs*.bat files.<br>
-<br>
- The existing scripts assume that the gs binaries are on the path.<br>
- The tweaked scripts check to see if there is a binary in the same<br>
- directory as the .bat file, and if there is, use that in preference<br>
- to any version on the path.<br>
-<br>
- Otherwise functionality is identical.<br>
-<br>
-lib/gssetgs.bat<br>
-lib/gssetgs32.bat<br>
-lib/gssetgs64.bat<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-06 12:56:51 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=68eca5e94e6f63f4392b15581ad41af52e0edfd9">68eca5e94e6f63f4392b15581ad41af52e0edfd9</a>
-<blockquote>
-<p>
- Fix SEGV seen in all-devices test with plank examples/ridt91.eps<br>
-<br>
- Silly typo in the contone fill code for the landscape flippedy<br>
- color cache case.<br>
-<br>
-base/gximono.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-05 23:58:39 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6473ad1394900c79a7ca5335accaaad9cd67d42a">6473ad1394900c79a7ca5335accaaad9cd67d42a</a>
-<blockquote>
-<p>
- Add prototype missed from previous commit.<br>
-<br>
-psi/interp.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-05 18:07:40 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b533271d8bd915593a2f8e1a1f446ee940c7d76">2b533271d8bd915593a2f8e1a1f446ee940c7d76</a>
-<blockquote>
-<p>
- Fix arg_copy leaks.<br>
-<br>
- When handling -d or -s args, the code currently arg_copies the string<br>
- it gets back, then uses that copied block to make postscript names<br>
- from.<br>
-<br>
- Here we change the code so that postscript names are made in a<br>
- slightly different way, so they copy the string content. This means<br>
- we can free the arg_copied block afterwards, solving the leaks.<br>
-<br>
- While we are here, remove a layer of nasty variable hiding macros<br>
- that do nothing but confuse things.<br>
-<br>
-psi/iddict.h<br>
-psi/idict.c<br>
-psi/idict.h<br>
-psi/iinit.c<br>
-psi/imain.c<br>
-psi/imainarg.c<br>
-psi/interp.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-05 15:59: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=a8c7899267121cb92503fe0f7e7f6ae433c386b1">a8c7899267121cb92503fe0f7e7f6ae433c386b1</a>
-<blockquote>
-<p>
- Bug 699711: Review arg_next to ensure that NULL arg returns are coped with.<br>
-<br>
- We can only return NULL from arg_next if the return code == 0. We<br>
- therefore have to ensure that all call sites check for either of<br>
- those conditions.<br>
-<br>
-base/gsargs.c<br>
-pcl/pl/plmain.c<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-05 13:46:50 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=df4ec49e0f2237fe5b17d5d620f8c3cad95b3b5e">df4ec49e0f2237fe5b17d5d620f8c3cad95b3b5e</a>
-<blockquote>
-<p>
- Second attempt at fix for bug 699699.<br>
-<br>
- The previous attempt failed because it gave the wrong return value<br>
- when we hit an empty argument.<br>
-<br>
- Now we ignore empty arguments.<br>
-<br>
-base/gsargs.c<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-05 13:19:51 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ecfbc3126834e442edb309112e8995df9f10daa4">ecfbc3126834e442edb309112e8995df9f10daa4</a>
-<blockquote>
-<p>
- Revert previous fix for Bug 699699.<br>
-<br>
- Revert &quot;Bug 699699 &quot;Crash upon bogus input argument.&quot;&quot;<br>
- (commit b509290189f1f37a76339f7b6921d42f126bfd57).<br>
-<br>
- This reopens bug 699699, so we can fix it in a way that doesn't<br>
- return 1 for 'empty' arguments.<br>
- This reopens bug 699699.<br>
-<br>
-base/gsargs.c<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-05 16:42:44 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=01514a0c6add9cbafe3c3ba55f57968154d2b323">01514a0c6add9cbafe3c3ba55f57968154d2b323</a>
-<blockquote>
-<p>
- Bug 699719: Fix @ files in arg handling.<br>
-<br>
- When we met an @file in the arg handling, we were failing to swallow<br>
- it and returning &quot;@file&quot; to the caller.<br>
-<br>
-base/gsargs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-05 16:43:20 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c887103a58563dd4e95acab49f9ee60f2aa13a7">6c887103a58563dd4e95acab49f9ee60f2aa13a7</a>
-<blockquote>
-<p>
- Update signed ghostpdf.cat to new certificate<br>
-<br>
- also add a *.cat rule to .gitattributes to ensure .cat files are always treated<br>
- as binary<br>
-<br>
-.gitattributes<br>
-lib/ghostpdf.cat<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-05 08:44: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=e914f1da46e33decc534486598dc3eadf69e6efb">e914f1da46e33decc534486598dc3eadf69e6efb</a>
-<blockquote>
-<p>
- Fix incomplete comment from previous commit<br>
-<br>
-Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-04 23:18:46 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5812b1b78fc4d36fdc293b7859de69241140d590">5812b1b78fc4d36fdc293b7859de69241140d590</a>
-<blockquote>
-<p>
- Bug 699714: retain .LockSafetyParams through failed .installpagedevice<br>
-<br>
- In the event that the .trysetparams fails during .installpagedevice, catch the<br>
- error, and ensure that at least the .LockSafetyParams is set.<br>
-<br>
-Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-04 17:01:08 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bc3df0773fccf4b4906a3e59652ad646ea0fee91">bc3df0773fccf4b4906a3e59652ad646ea0fee91</a>
-<blockquote>
-<p>
- For ICC profile validation, have cups id iteself as DeviceN<br>
-<br>
- Give the range of color spaces and models that cups supports, we can't<br>
- reasonably provide (or expect others to provide) output ICC profiles for all<br>
- cases.<br>
-<br>
- For the purpose of profile validation, have it claim to be DeviceN and benefit<br>
- from the extra tolerance in profiles allowed for that class of device.<br>
-<br>
-cups/gdevcups.c<br>
-devices/devs.mak<br>
-<p>
-</blockquote>
-<hr>
-<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=90a692cfbfc2d6ec3c227149cd8d52fc22dc9e4e">90a692cfbfc2d6ec3c227149cd8d52fc22dc9e4e</a>
-<blockquote>
-<p>
- Bring master up to date with 9.24 release branch<br>
-<br>
- Doc changes, etc<br>
-<br>
-base/version.mak<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-09-03 16:57: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=cc6fafb69b7957c9a7eac9a0087793d48be0443c">cc6fafb69b7957c9a7eac9a0087793d48be0443c</a>
-<blockquote>
-<p>
- Silence a coverity warning.<br>
-<br>
-base/gdevdflt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-03 15:32: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=29b6890cc618a88e0d9eb8e996d3e0153b5fbda9">29b6890cc618a88e0d9eb8e996d3e0153b5fbda9</a>
-<blockquote>
-<p>
- Update files for jbig2dec release 0.15<br>
-<br>
-jbig2dec/CHANGES<br>
-jbig2dec/config_win32.h<br>
-jbig2dec/configure.ac<br>
-jbig2dec/jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-03 15:34: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=fd6cac72bbc050e1a2832fd59f9fb1792b493750">fd6cac72bbc050e1a2832fd59f9fb1792b493750</a>
-<blockquote>
-<p>
- PostScript interpreter - More places where exec stack is not restored<br>
-<br>
- For the setcolorspace continuation procedure, and the related procs<br>
- for specific colour spaces, we need to remove the extra operands we<br>
- placed on the exec stack, so that there's no possibility of returning<br>
- and executing them.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-03 14:17: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=b509290189f1f37a76339f7b6921d42f126bfd57">b509290189f1f37a76339f7b6921d42f126bfd57</a>
-<blockquote>
-<p>
- Bug 699699 &quot;Crash upon bogus input argument.&quot;<br>
-<br>
- The code in arg_next starts by setting *argstr to NULL, the following<br>
- do..while loop assumes that *argstr will be filled in, and checks its<br>
- first byte. However, if we run out of characters in the argument string<br>
- then *argstr remains NULL, and causes a crash.<br>
-<br>
- This can happen if we pass an empty quoted argument &quot;&quot;<br>
-<br>
- In addition, the processing of -o and possibly other switches assumes<br>
- that arg_next will return an error if it doesn't find an argument<br>
- whereas now it can return a NULL. I believe its possible that it always<br>
- could do so.<br>
-<br>
- So check the 'arg' returned from arg_next to make sure its not NULL<br>
- before we try to use it.<br>
-<br>
- We should check other places where arg_next is called as well.<br>
-<br>
-base/gsargs.c<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-01 17:50: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=0704d18b10314d701a522ad6c16718e0b8e199b7">0704d18b10314d701a522ad6c16718e0b8e199b7</a>
-<blockquote>
-<p>
- Bug 699658(related): Move recording of temp file names into C<br>
-<br>
- When we successfully create a temporary file from Postscript, either doing so<br>
- when SAFER is not in force, or when SAFER is in force, and creating it in<br>
- a write permitted directory, we record the file name so we can later delete<br>
- the file, even is SAFER has been engaged, or if the PermitWriting list has<br>
- changed to no longer the directory in question.<br>
-<br>
- Previously the recording of the name was done in Postscript, even though the<br>
- checking was done in C.<br>
-<br>
- This moves the recording of the names to C, meaning we can remove the Postscript<br>
- redefinitions of .tempfile and deletfile, and make the dictionary in question<br>
- noaccess.<br>
-<br>
- Also, tidy up the adding of the temporary file directory to the list of<br>
- permitted directories, and include the list in all of the categories<br>
- (PermitFileWriting, PermitFileReading and PermitFileControl) - it was only<br>
- previously adding to writing.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-psi/int.mak<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-31 15:57: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=29f4603fc0c6de7d5df1f293f0a7efbffe8112bd">29f4603fc0c6de7d5df1f293f0a7efbffe8112bd</a>
-<blockquote>
-<p>
- Bug 699693: Fix FAPI handling of multibyte Unicode code point<br>
-<br>
- The original code worked for one byte code points, and for the case there the<br>
- original character code and Unicode value both had the same number of bytes,<br>
- but was totally wrong if the the two were different.<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-01 11:28: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=7ba6d80c69f0c74601ffc1077d27e0d1a299e57f">7ba6d80c69f0c74601ffc1077d27e0d1a299e57f</a>
-<blockquote>
-<p>
- Bug #699687 &quot;grestore can bypass SAFER&quot;<br>
-<br>
- The code in z2grestore (part of the level 2 restore machinery) in<br>
- ghostpdl/psi/zdevice2.c sets the device's LockSafetyParams to false, and<br>
- according to the comments there relies on putdeviceparams setting<br>
- the flag back when the old device is re-instated.<br>
-<br>
- However, if we have corrupted any part of the device's content, then<br>
- its possible to exit putdeviceparams, in one place only, without<br>
- setting LockSafetyParams. Here we simply add an explicit reset of the<br>
- value even in the case of an error setting the new device.<br>
-<br>
-base/gsdparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-01 09:28: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=61ad589fb861d28e2d2c9d0b609ec4da4d7dd247">61ad589fb861d28e2d2c9d0b609ec4da4d7dd247</a>
-<blockquote>
-<p>
- Bug 699677 &quot;.bindnow still causing side effects&quot;<br>
-<br>
- In fact, its nothing to do with .bindnow. That simply modifies the exec<br>
- stack in a way which makes the problem exhibit.<br>
-<br>
- setcustomcolor should really check its operands. because it doens't, it<br>
- creates a tint transform function which tries to mulitply a number by<br>
- (in this case) a name. This throws an error of course.<br>
-<br>
- The problem is that the code to sample the tint transform function<br>
- didn't deal properly with the case where the PostScript function throws<br>
- an error. In that case it properly exits the code which executes the<br>
- function, but it fails to unwind the exec stack.<br>
-<br>
- This leads to use trying to complete the function, using the enumerator,<br>
- which has been stored on the exec stack. Because we didn't clean up the<br>
- exec stack, what we retrieve isn't an enumerator. This causes us to try<br>
- to access invalid memory and can result in a crash.<br>
-<br>
- So, several steps. Firstly have the sampling code properly handle the<br>
- error and restore the exec stack. Secondly, have the setcolorspace code<br>
- be prepared to accept a NULL returned from the sampling code and treat<br>
- that as an error (and also fix a similar exec stack problem in the<br>
- setcolorspace code). Finally; have setcustomcolor validate its operands.<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-psi/zcolor.c<br>
-psi/zfsample.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-29 09:30:19 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c98cb5237c983e363fe05757b2639eab550499e8">c98cb5237c983e363fe05757b2639eab550499e8</a>
-<blockquote>
-<p>
- Fix for security issues found during internal security audit<br>
-<br>
- While most of the invocations of .forceput and related operators were<br>
- &quot;protected&quot; by being within &quot;executeonly&quot; procedures, several had crept<br>
- in that did not make sure that the operator was hidden in a procedure<br>
- that could not be read.<br>
-<br>
-Resource/Init/gs_dps.ps<br>
-Resource/Init/gs_fntem.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_pdfwr.ps<br>
-Resource/Init/gs_setpd.ps<br>
-Resource/Init/gs_typ32.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-31 08:12: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=d60214879cd71cf9f995c7d8862394293ffa9014">d60214879cd71cf9f995c7d8862394293ffa9014</a>
-<blockquote>
-<p>
- Remove embedded, copyrighted ICC profile from PNG images<br>
-<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>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-31 09:58: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=478b73874179262d880c1417b5a11fb534a18651">478b73874179262d880c1417b5a11fb534a18651</a>
-<blockquote>
-<p>
- PDF interpreter - remove a warning message<br>
-<br>
- Commit f6bcc0dfc173b80fddab4fbf10afb34332ff1112 added extra checking<br>
- and processing to deal with the (illegal) case of a Text block which<br>
- includes a 'q' operator.<br>
-<br>
- As part of that commit, we added a warning message so that users would<br>
- be able to tell there was a problem. Unfortunately, there are cases<br>
- which are perfectly legal (eg running a Pattern PaintProc to fill the<br>
- text) where a q can apparently occur inside a text object.<br>
-<br>
- We can't differentiate between executing a 'q' in such cases, so the<br>
- only option is to remove the warning. This does not affect the actual<br>
- operation of the code, it still copes with a 'q' inside text objects,<br>
- whether legally or not.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-30 13:33:36 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f8834d04215857e6150876bf189b682dbf254f8a">f8834d04215857e6150876bf189b682dbf254f8a</a>
-<blockquote>
-<p>
- ps2write - modify Lab space handling<br>
-<br>
- Commit 9e58cc8dd7e9b98620c798c901f800aff2e381ce improved the handling of<br>
- /Separation spaces with an Lab alternate space.<br>
-<br>
- However, it also altered the handling of Lab spaces as the base space<br>
- for patterns, or the initial space. This caused a small difference in<br>
- release testing.<br>
-<br>
- The result was incorrect previously, and after the above commit, but the<br>
- commit made it appear worse from a user's perspective. Until we can<br>
- get time to properly convert Lab base spaces into a device space, return<br>
- the code to its prior state. This does not affect the improvement to<br>
- Separation spaces.<br>
-<br>
-devices/vector/gdevpdfc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-30 09:34: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=6dfd431fb4a97665044dcea7a061e8fa6ec36098">6dfd431fb4a97665044dcea7a061e8fa6ec36098</a>
-<blockquote>
-<p>
- Bug #699684 &quot;gs segfaults in refset_null_new when processing malformed file&quot;<br>
-<br>
- It is possible for a specifically malformed Binary Object Sequence to<br>
- run out of data to process (and return to refill the buffer) when it<br>
- had read *exactly* the maximum number of objects declared in the top<br>
- array.<br>
-<br>
- This meant that the 'index' pointing to the next expected array entry<br>
- to be filled in actually pointed past the end of the array.<br>
-<br>
- We then called a routine to set the unused entries in the array to null<br>
- objects (for GC purposes), using the index. Because it pointed past the<br>
- end of the array this led to the count of objects being -1. The code<br>
- then counted down the count, until it reached 0, while at the same time<br>
- writing null objects past the end of the array.<br>
-<br>
- This commit simply checks the index against the array size and doesn't<br>
- attempt to fill it in if its less than that value. Note that the array<br>
- index is 0-based, hence &lt; not &lt;=.<br>
-<br>
-psi/iscanbin.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-29 07:59: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=d469deaf34e25f701a531ffd36cfc7f738efc4a2">d469deaf34e25f701a531ffd36cfc7f738efc4a2</a>
-<blockquote>
-<p>
- Fix a typo in commit 21ae2f8d9953<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-28 16:39: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=a25e6980ca87eaf0ef3d7e71acbed1ff2db7ab28">a25e6980ca87eaf0ef3d7e71acbed1ff2db7ab28</a>
-<blockquote>
-<p>
- Bump version on master to 9.25<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-26 15:16:46 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=032603f3c5448fc32609c51c932d11529eb6b581">032603f3c5448fc32609c51c932d11529eb6b581</a>
-<blockquote>
-<p>
- Bug 699673: jbig2dec: Initialize return code for all cases.<br>
-<br>
- Thanks to oss-fuzz for reporting.<br>
-<br>
-jbig2dec/jbig2_arith.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-26 15:16:02 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=343366cf2d6c3170d8b582d5df076f803c699262">343366cf2d6c3170d8b582d5df076f803c699262</a>
-<blockquote>
-<p>
- jbig2dec: Avoid dereferencing pointer before it is tested.<br>
-<br>
- Thanks to coverity.<br>
-<br>
-jbig2dec/jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-03 09:44: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=32f1afe5c1e0b862e3bde05dc7b860a5f65cfbea">32f1afe5c1e0b862e3bde05dc7b860a5f65cfbea</a>
-<blockquote>
-<p>
- Update dates, product string etc for release<br>
-<br>
- Fix release date<br>
-<br>
-base/gscdef.c<br>
-base/version.mak<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-09-03 08:34: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=ae222d8aa93783ba542b8ba91d62a1e107650563">ae222d8aa93783ba542b8ba91d62a1e107650563</a>
-<blockquote>
-<p>
- Update changelog... again<br>
-<br>
-doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-01 17:50: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=07da47959687c1e6a112ad746929ef66e82b5aa9">07da47959687c1e6a112ad746929ef66e82b5aa9</a>
-<blockquote>
-<p>
- Bug 699658(related): Move recording of temp file names into C<br>
-<br>
- When we successfully create a temporary file from Postscript, either doing so<br>
- when SAFER is not in force, or when SAFER is in force, and creating it in<br>
- a write permitted directory, we record the file name so we can later delete<br>
- the file, even is SAFER has been engaged, or if the PermitWriting list has<br>
- changed to no longer the directory in question.<br>
-<br>
- Previously the recording of the name was done in Postscript, even though the<br>
- checking was done in C.<br>
-<br>
- This moves the recording of the names to C, meaning we can remove the Postscript<br>
- redefinitions of .tempfile and deletfile, and make the dictionary in question<br>
- noaccess.<br>
-<br>
- Also, tidy up the adding of the temporary file directory to the list of<br>
- permitted directories, and include the list in all of the categories<br>
- (PermitFileWriting, PermitFileReading and PermitFileControl) - it was only<br>
- previously adding to writing.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-psi/int.mak<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-31 15:57: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=d8cfd2e7e1000f644afcaca2f196cb6d494049b8">d8cfd2e7e1000f644afcaca2f196cb6d494049b8</a>
-<blockquote>
-<p>
- Bug 699693: Fix FAPI handling of multibyte Unicode code point<br>
-<br>
- The original code worked for one byte code points, and for the case there the<br>
- original character code and Unicode value both had the same number of bytes,<br>
- but was totally wrong if the the two were different.<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-01 11:28: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=a5993c537ae035b2396da5189fd985006627a478">a5993c537ae035b2396da5189fd985006627a478</a>
-<blockquote>
-<p>
- Bug #699687 &quot;grestore can bypass SAFER&quot;<br>
-<br>
- The code in z2grestore (part of the level 2 restore machinery) in<br>
- ghostpdl/psi/zdevice2.c sets the device's LockSafetyParams to false, and<br>
- according to the comments there relies on putdeviceparams setting<br>
- the flag back when the old device is re-instated.<br>
-<br>
- However, if we have corrupted any part of the device's content, then<br>
- its possible to exit putdeviceparams, in one place only, without<br>
- setting LockSafetyParams. Here we simply add an explicit reset of the<br>
- value even in the case of an error setting the new device.<br>
-<br>
-base/gsdparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-01 09:28: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=21b27dc55b493564006c91326a5ddc636cf88563">21b27dc55b493564006c91326a5ddc636cf88563</a>
-<blockquote>
-<p>
- Bug 699677 &quot;.bindnow still causing side effects&quot;<br>
-<br>
- In fact, its nothing to do with .bindnow. That simply modifies the exec<br>
- stack in a way which makes the problem exhibit.<br>
-<br>
- setcustomcolor should really check its operands. because it doens't, it<br>
- creates a tint transform function which tries to mulitply a number by<br>
- (in this case) a name. This throws an error of course.<br>
-<br>
- The problem is that the code to sample the tint transform function<br>
- didn't deal properly with the case where the PostScript function throws<br>
- an error. In that case it properly exits the code which executes the<br>
- function, but it fails to unwind the exec stack.<br>
-<br>
- This leads to use trying to complete the function, using the enumerator,<br>
- which has been stored on the exec stack. Because we didn't clean up the<br>
- exec stack, what we retrieve isn't an enumerator. This causes us to try<br>
- to access invalid memory and can result in a crash.<br>
-<br>
- So, several steps. Firstly have the sampling code properly handle the<br>
- error and restore the exec stack. Secondly, have the setcolorspace code<br>
- be prepared to accept a NULL returned from the sampling code and treat<br>
- that as an error (and also fix a similar exec stack problem in the<br>
- setcolorspace code). Finally; have setcustomcolor validate its operands.<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-psi/zcolor.c<br>
-psi/zfsample.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-29 09:30:19 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91d6bc4d3e3865388ede3bcd4e84bbb8787b78e4">91d6bc4d3e3865388ede3bcd4e84bbb8787b78e4</a>
-<blockquote>
-<p>
- Fix for security issues found during internal security audit<br>
-<br>
- While most of the invocations of .forceput and related operators were<br>
- &quot;protected&quot; by being within &quot;executeonly&quot; procedures, several had crept<br>
- in that did not make sure that the operator was hidden in a procedure<br>
- that could not be read.<br>
-<br>
-Resource/Init/gs_dps.ps<br>
-Resource/Init/gs_fntem.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_pdfwr.ps<br>
-Resource/Init/gs_setpd.ps<br>
-Resource/Init/gs_typ32.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-31 08:12: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=cd83407209c3901ddfabd09e144c90ea105005d7">cd83407209c3901ddfabd09e144c90ea105005d7</a>
-<blockquote>
-<p>
- Remove embedded, copyrighted ICC profile from PNG images<br>
-<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>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-30 15:07: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=f667df996290e64fc091d81b7513abdac488e156">f667df996290e64fc091d81b7513abdac488e156</a>
-<blockquote>
-<p>
- Update dates etc for release candidate 2<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-30 13:33:36 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=214d6725e4a2b539294ebfba528a8d0961379fd0">214d6725e4a2b539294ebfba528a8d0961379fd0</a>
-<blockquote>
-<p>
- ps2write - modify Lab space handling<br>
-<br>
- Commit 9e58cc8dd7e9b98620c798c901f800aff2e381ce improved the handling of<br>
- /Separation spaces with an Lab alternate space.<br>
-<br>
- However, it also altered the handling of Lab spaces as the base space<br>
- for patterns, or the initial space. This caused a small difference in<br>
- release testing.<br>
-<br>
- The result was incorrect previously, and after the above commit, but the<br>
- commit made it appear worse from a user's perspective. Until we can<br>
- get time to properly convert Lab base spaces into a device space, return<br>
- the code to its prior state. This does not affect the improvement to<br>
- Separation spaces.<br>
-<br>
-devices/vector/gdevpdfc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-30 09:34: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=e40f79df969e4168daf65b3b3af3ea73b6a71fc4">e40f79df969e4168daf65b3b3af3ea73b6a71fc4</a>
-<blockquote>
-<p>
- Bug #699684 &quot;gs segfaults in refset_null_new when processing malformed file&quot;<br>
-<br>
- It is possible for a specifically malformed Binary Object Sequence to<br>
- run out of data to process (and return to refill the buffer) when it<br>
- had read *exactly* the maximum number of objects declared in the top<br>
- array.<br>
-<br>
- This meant that the 'index' pointing to the next expected array entry<br>
- to be filled in actually pointed past the end of the array.<br>
-<br>
- We then called a routine to set the unused entries in the array to null<br>
- objects (for GC purposes), using the index. Because it pointed past the<br>
- end of the array this led to the count of objects being -1. The code<br>
- then counted down the count, until it reached 0, while at the same time<br>
- writing null objects past the end of the array.<br>
-<br>
- This commit simply checks the index against the array size and doesn't<br>
- attempt to fill it in if its less than that value. Note that the array<br>
- index is 0-based, hence &lt; not &lt;=.<br>
-<br>
-psi/iscanbin.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-29 11:43: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=06e4829c6756f0aa6918ba19710050295bd29bfe">06e4829c6756f0aa6918ba19710050295bd29bfe</a>
-<blockquote>
-<p>
- Update changelog post 9.24rc1<br>
-<br>
-doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-29 07:59: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=110b1843b16d92878fd56d874b95bac5e130c720">110b1843b16d92878fd56d874b95bac5e130c720</a>
-<blockquote>
-<p>
- Fix a typo in commit 21ae2f8d9953<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-26 15:16:46 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=74cc0437c7d4aa8bef051300b0ba3b510b9922c4">74cc0437c7d4aa8bef051300b0ba3b510b9922c4</a>
-<blockquote>
-<p>
- Bug 699673: jbig2dec: Initialize return code for all cases.<br>
-<br>
- Thanks to oss-fuzz for reporting.<br>
-<br>
-jbig2dec/jbig2_arith.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-26 15:16:02 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=46c4a646d5c7954f076478aa8e85a4fc3b2b1f66">46c4a646d5c7954f076478aa8e85a4fc3b2b1f66</a>
-<blockquote>
-<p>
- jbig2dec: Avoid dereferencing pointer before it is tested.<br>
-<br>
- Thanks to coverity.<br>
-<br>
-jbig2dec/jbig2.c<br>
-<p>
-</blockquote>
-<hr size=20>
-<h2><a name="Version9.24"></a>Version 9.24 (2018-09-03)</h2>
-
-<p> Highlights in this release include:
-<ul>
-<li>
-<p>Security issues have been the primary focus of this release, including solving
-several (well publicised) real and potential exploits.
-<br>
-<p> <big><u><b>PLEASE NOTE:</b> We <b>strongly</b> urge users to upgrade to this latest
-release to avoid these issues.</u></big>
-</li>
-<li>
-<p>As well as Ghostscript itself, jbig2dec has had a significant amount of work improving
-its robustness in the face of out specification files.
-</li>
-<li>
-<p>IMPORTANT: We are in the process of forking LittleCMS. LCMS2 is not thread safe, and
-cannot be made thread safe without breaking the ABI. Our fork will be thread safe, and include
-performance enhancements (these changes have all be been offered and rejected upstream). We
-will maintain compatibility between Ghostscript and LCMS2 for a time, but not in perpetuity.
-Our fork will be available as its own package separately from Ghostscript (and MuPDF).
-</li>
-<li>
-<p>The usual round of bug fixes, compatibility changes, and incremental improvements.
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.24_Incompatible_changes"></a>Incompatible changes</h3>
-<ul>
-<li>
-<p>None
-</li>
-</ul>
-<h3><a name="9.24_changelog"></a>Changelog</h3>
-<p><strong>2018-09-01 17:50: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=07da47959687c1e6a112ad746929ef66e82b5aa9">07da47959687c1e6a112ad746929ef66e82b5aa9</a>
-<blockquote>
-<p>
- Bug 699658(related): Move recording of temp file names into C<br>
-<br>
- When we successfully create a temporary file from Postscript, either doing so<br>
- when SAFER is not in force, or when SAFER is in force, and creating it in<br>
- a write permitted directory, we record the file name so we can later delete<br>
- the file, even is SAFER has been engaged, or if the PermitWriting list has<br>
- changed to no longer the directory in question.<br>
-<br>
- Previously the recording of the name was done in Postscript, even though the<br>
- checking was done in C.<br>
-<br>
- This moves the recording of the names to C, meaning we can remove the Postscript<br>
- redefinitions of .tempfile and deletfile, and make the dictionary in question<br>
- noaccess.<br>
-<br>
- Also, tidy up the adding of the temporary file directory to the list of<br>
- permitted directories, and include the list in all of the categories<br>
- (PermitFileWriting, PermitFileReading and PermitFileControl) - it was only<br>
- previously adding to writing.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-psi/int.mak<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-31 15:57: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=d8cfd2e7e1000f644afcaca2f196cb6d494049b8">d8cfd2e7e1000f644afcaca2f196cb6d494049b8</a>
-<blockquote>
-<p>
- Bug 699693: Fix FAPI handling of multibyte Unicode code point<br>
-<br>
- The original code worked for one byte code points, and for the case there the<br>
- original character code and Unicode value both had the same number of bytes,<br>
- but was totally wrong if the the two were different.<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-01 11:28: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=a5993c537ae035b2396da5189fd985006627a478">a5993c537ae035b2396da5189fd985006627a478</a>
-<blockquote>
-<p>
- Bug #699687 &quot;grestore can bypass SAFER&quot;<br>
-<br>
- The code in z2grestore (part of the level 2 restore machinery) in<br>
- ghostpdl/psi/zdevice2.c sets the device's LockSafetyParams to false, and<br>
- according to the comments there relies on putdeviceparams setting<br>
- the flag back when the old device is re-instated.<br>
-<br>
- However, if we have corrupted any part of the device's content, then<br>
- its possible to exit putdeviceparams, in one place only, without<br>
- setting LockSafetyParams. Here we simply add an explicit reset of the<br>
- value even in the case of an error setting the new device.<br>
-<br>
-base/gsdparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-09-01 09:28: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=21b27dc55b493564006c91326a5ddc636cf88563">21b27dc55b493564006c91326a5ddc636cf88563</a>
-<blockquote>
-<p>
- Bug 699677 &quot;.bindnow still causing side effects&quot;<br>
-<br>
- In fact, its nothing to do with .bindnow. That simply modifies the exec<br>
- stack in a way which makes the problem exhibit.<br>
-<br>
- setcustomcolor should really check its operands. because it doens't, it<br>
- creates a tint transform function which tries to mulitply a number by<br>
- (in this case) a name. This throws an error of course.<br>
-<br>
- The problem is that the code to sample the tint transform function<br>
- didn't deal properly with the case where the PostScript function throws<br>
- an error. In that case it properly exits the code which executes the<br>
- function, but it fails to unwind the exec stack.<br>
-<br>
- This leads to use trying to complete the function, using the enumerator,<br>
- which has been stored on the exec stack. Because we didn't clean up the<br>
- exec stack, what we retrieve isn't an enumerator. This causes us to try<br>
- to access invalid memory and can result in a crash.<br>
-<br>
- So, several steps. Firstly have the sampling code properly handle the<br>
- error and restore the exec stack. Secondly, have the setcolorspace code<br>
- be prepared to accept a NULL returned from the sampling code and treat<br>
- that as an error (and also fix a similar exec stack problem in the<br>
- setcolorspace code). Finally; have setcustomcolor validate its operands.<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-psi/zcolor.c<br>
-psi/zfsample.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-29 09:30:19 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91d6bc4d3e3865388ede3bcd4e84bbb8787b78e4">91d6bc4d3e3865388ede3bcd4e84bbb8787b78e4</a>
-<blockquote>
-<p>
- Fix for security issues found during internal security audit<br>
-<br>
- While most of the invocations of .forceput and related operators were<br>
- &quot;protected&quot; by being within &quot;executeonly&quot; procedures, several had crept<br>
- in that did not make sure that the operator was hidden in a procedure<br>
- that could not be read.<br>
-<br>
-Resource/Init/gs_dps.ps<br>
-Resource/Init/gs_fntem.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_pdfwr.ps<br>
-Resource/Init/gs_setpd.ps<br>
-Resource/Init/gs_typ32.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-30 15:07: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=00dd8bc74c2abb38195b9f88f7de36f169296a97">00dd8bc74c2abb38195b9f88f7de36f169296a97</a>
-<blockquote>
-<p>
- Update dates etc for release candidate 2<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-30 13:33:36 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=214d6725e4a2b539294ebfba528a8d0961379fd0">214d6725e4a2b539294ebfba528a8d0961379fd0</a>
-<blockquote>
-<p>
- ps2write - modify Lab space handling<br>
-<br>
- Commit 9e58cc8dd7e9b98620c798c901f800aff2e381ce improved the handling of<br>
- /Separation spaces with an Lab alternate space.<br>
-<br>
- However, it also altered the handling of Lab spaces as the base space<br>
- for patterns, or the initial space. This caused a small difference in<br>
- release testing.<br>
-<br>
- The result was incorrect previously, and after the above commit, but the<br>
- commit made it appear worse from a user's perspective. Until we can<br>
- get time to properly convert Lab base spaces into a device space, return<br>
- the code to its prior state. This does not affect the improvement to<br>
- Separation spaces.<br>
-<br>
-devices/vector/gdevpdfc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-30 09:34: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=e40f79df969e4168daf65b3b3af3ea73b6a71fc4">e40f79df969e4168daf65b3b3af3ea73b6a71fc4</a>
-<blockquote>
-<p>
- Bug #699684 &quot;gs segfaults in refset_null_new when processing malformed file&quot;<br>
-<br>
- It is possible for a specifically malformed Binary Object Sequence to<br>
- run out of data to process (and return to refill the buffer) when it<br>
- had read *exactly* the maximum number of objects declared in the top<br>
- array.<br>
-<br>
- This meant that the 'index' pointing to the next expected array entry<br>
- to be filled in actually pointed past the end of the array.<br>
-<br>
- We then called a routine to set the unused entries in the array to null<br>
- objects (for GC purposes), using the index. Because it pointed past the<br>
- end of the array this led to the count of objects being -1. The code<br>
- then counted down the count, until it reached 0, while at the same time<br>
- writing null objects past the end of the array.<br>
-<br>
- This commit simply checks the index against the array size and doesn't<br>
- attempt to fill it in if its less than that value. Note that the array<br>
- index is 0-based, hence &lt; not &lt;=.<br>
-<br>
-psi/iscanbin.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-29 11:43: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=7874cfe914edc8a244976d914fc5a150c263651e">7874cfe914edc8a244976d914fc5a150c263651e</a>
-<blockquote>
-<p>
- Update changelog post 9.24rc1<br>
-<br>
-doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-29 07:59: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=110b1843b16d92878fd56d874b95bac5e130c720">110b1843b16d92878fd56d874b95bac5e130c720</a>
-<blockquote>
-<p>
- Fix a typo in commit 21ae2f8d9953<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-26 15:16:46 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=74cc0437c7d4aa8bef051300b0ba3b510b9922c4">74cc0437c7d4aa8bef051300b0ba3b510b9922c4</a>
-<blockquote>
-<p>
- Bug 699673: jbig2dec: Initialize return code for all cases.<br>
-<br>
- Thanks to oss-fuzz for reporting.<br>
-<br>
-jbig2dec/jbig2_arith.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-08-26 15:16:02 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=46c4a646d5c7954f076478aa8e85a4fc3b2b1f66">46c4a646d5c7954f076478aa8e85a4fc3b2b1f66</a>
-<blockquote>
-<p>
- jbig2dec: Avoid dereferencing pointer before it is tested.<br>
-<br>
- Thanks to coverity.<br>
-<br>
-jbig2dec/jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<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>
-<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: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 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>
-<p><strong>2018-02-26 15:48:45 +0100
-</strong>
-<br>David Kaspar [Dee'Kej] &lt;dkaspar@redhat.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8c206ceeeac12b048aeafc9ea51080b624750ff4">8c206ceeeac12b048aeafc9ea51080b624750ff4</a>
-<blockquote>
-<p>
- Bug 699068: configure.ac: forcibly disable strict aliasing via CFLAGS<br>
-<br>
- In case user specifies their own CFLAGS that contains -O2, -O3, -Os or<br>
- -fstrict-aliasing, the default behaviour to disable the strict<br>
- aliasing will be overriden and enabled, which is not correct...<br>
-<br>
- This commit will append the -fno-strict-aliasing option to CFLAGS set<br>
- by user, which will effectively force the disabling of strict aliasing.<br>
-<br>
- NOTE: originally the patch issued a warning when appending -fno-strict-aliasing<br>
- and I've changed it to a normal checking/result message pattern - it seems less<br>
- likely to cause end user confusion/panic<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-03-05 21:48: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=39686173fd26eb6e5eee91202433f5e5f307f61c">39686173fd26eb6e5eee91202433f5e5f307f61c</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/gscolor.c<br>
-base/gsdparam.c<br>
-base/gsptype1.c<br>
-pcl/pcl/pcbiptrn.c<br>
-pcl/pcl/pcpatrn.c<br>
-pcl/pcl/pginit.c<br>
-pcl/pcl/pglabel.c<br>
-pcl/pcl/rtraster.c<br>
-pcl/pl/plparams.c<br>
-pcl/pxl/pxgstate.c<br>
-pcl/pxl/pxink.c<br>
-pcl/pxl/pxpthr.c<br>
-psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-21 19:59:25 +0100
-</strong>
-<br>David Kaspar [Dee'Kej] &lt;dkaspar@redhat.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=469bd6ecf5b223b3e6e3f32ec5a4900866c35e57">469bd6ecf5b223b3e6e3f32ec5a4900866c35e57</a>
-<blockquote>
-<p>
- Bug 699057: Makefile.in: @LDFLAGS@ added into GCFLAGS<br>
-<br>
- Previously, the 'gsc' and 'gsx' binaries were not using LDFLAGS when<br>
- they were built with shared library. Adding LDFLAGS into GCFLAGS fixes<br>
- this issue, and specifying LDFLAGS now works for these binaries as well.<br>
-<br>
-Makefile.in<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-03-06 10:16: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=71e152462e2b47e8e31aec7cf1238934640aa480">71e152462e2b47e8e31aec7cf1238934640aa480</a>
-<blockquote>
-<p>
- Update zlib to 1.2.11<br>
-<br>
-zlib/CMakeLists.txt<br>
-zlib/ChangeLog<br>
-zlib/Makefile.in<br>
-zlib/README<br>
-zlib/adler32.c<br>
-zlib/as400/bndsrc<br>
-zlib/as400/compile.clp<br>
-zlib/as400/readme.txt<br>
-zlib/compress.c<br>
-zlib/configure<br>
-zlib/contrib/README.contrib<br>
-zlib/contrib/ada/zlib-streams.ads<br>
-zlib/contrib/ada/zlib-thin.ads<br>
-zlib/contrib/blast/blast.c<br>
-zlib/contrib/blast/blast.h<br>
-zlib/contrib/delphi/ZLib.pas<br>
-zlib/contrib/dotzlib/DotZLib/UnitTests.cs<br>
-zlib/contrib/infback9/inftree9.c<br>
-zlib/contrib/minizip/configure.ac<br>
-zlib/contrib/minizip/iowin32.c<br>
-zlib/contrib/minizip/unzip.c<br>
-zlib/contrib/minizip/zip.c<br>
-zlib/contrib/pascal/zlibpas.pas<br>
-zlib/contrib/puff/puff.c<br>
-zlib/contrib/vstudio/readme.txt<br>
-zlib/contrib/vstudio/vc10/zlib.rc<br>
-zlib/contrib/vstudio/vc10/zlibvc.def<br>
-zlib/contrib/vstudio/vc11/zlib.rc<br>
-zlib/contrib/vstudio/vc11/zlibvc.def<br>
-zlib/contrib/vstudio/vc12/miniunz.vcxproj<br>
-zlib/contrib/vstudio/vc12/minizip.vcxproj<br>
-zlib/contrib/vstudio/vc12/testzlib.vcxproj<br>
-zlib/contrib/vstudio/vc12/testzlibdll.vcxproj<br>
-zlib/contrib/vstudio/vc12/zlib.rc<br>
-zlib/contrib/vstudio/vc12/zlibstat.vcxproj<br>
-zlib/contrib/vstudio/vc12/zlibvc.def<br>
-zlib/contrib/vstudio/vc12/zlibvc.sln<br>
-zlib/contrib/vstudio/vc12/zlibvc.vcxproj<br>
-zlib/contrib/vstudio/vc14/miniunz.vcxproj<br>
-zlib/contrib/vstudio/vc14/minizip.vcxproj<br>
-zlib/contrib/vstudio/vc14/testzlib.vcxproj<br>
-zlib/contrib/vstudio/vc14/testzlibdll.vcxproj<br>
-zlib/contrib/vstudio/vc14/zlib.rc<br>
-zlib/contrib/vstudio/vc14/zlibstat.vcxproj<br>
-zlib/contrib/vstudio/vc14/zlibvc.def<br>
-zlib/contrib/vstudio/vc14/zlibvc.sln<br>
-zlib/contrib/vstudio/vc14/zlibvc.vcxproj<br>
-zlib/contrib/vstudio/vc9/zlib.rc<br>
-zlib/contrib/vstudio/vc9/zlibvc.def<br>
-zlib/crc32.c<br>
-zlib/deflate.c<br>
-zlib/deflate.h<br>
-zlib/examples/gun.c<br>
-zlib/examples/gzlog.c<br>
-zlib/examples/zran.c<br>
-zlib/gzguts.h<br>
-zlib/gzlib.c<br>
-zlib/gzread.c<br>
-zlib/gzwrite.c<br>
-zlib/infback.c<br>
-zlib/inffast.c<br>
-zlib/inflate.c<br>
-zlib/inflate.h<br>
-zlib/inftrees.c<br>
-zlib/msdos/Makefile.dj2<br>
-zlib/msdos/Makefile.emx<br>
-zlib/old/Makefile.emx<br>
-zlib/old/os2/Makefile.os2<br>
-zlib/os400/README400<br>
-zlib/os400/bndsrc<br>
-zlib/os400/make.sh<br>
-zlib/os400/zlib.inc<br>
-zlib/qnx/package.qpg<br>
-zlib/test/example.c<br>
-zlib/test/infcover.c<br>
-zlib/test/minigzip.c<br>
-zlib/treebuild.xml<br>
-zlib/trees.c<br>
-zlib/uncompr.c<br>
-zlib/win32/Makefile.gcc<br>
-zlib/win32/Makefile.msc<br>
-zlib/win32/README-WIN32.txt<br>
-zlib/win32/VisualC.txt<br>
-zlib/win32/zlib.def<br>
-zlib/win32/zlib1.rc<br>
-zlib/zconf.h<br>
-zlib/zconf.h.cmakein<br>
-zlib/zconf.h.in<br>
-zlib/zlib.3<br>
-zlib/zlib.3.pdf<br>
-zlib/zlib.h<br>
-zlib/zlib.map<br>
-zlib/zutil.c<br>
-zlib/zutil.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-03-06 12:36:11 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=08482c582115a1396d0fd9186011008f889a61c5">08482c582115a1396d0fd9186011008f889a61c5</a>
-<blockquote>
-<p>
- Work around a change in the zlib API for 1.2.11<br>
-<br>
- where it's used in the Freetype/zlib interface debugging code.<br>
-<br>
-freetype/src/gzip/zutil.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-03-02 10:54:06 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3da667d889e54fb1a323769fbb4f93b971d0fff4">3da667d889e54fb1a323769fbb4f93b971d0fff4</a>
-<blockquote>
-<p>
- CCITT Fax - ensure calculation rounds up<br>
-<br>
- Still Bug #696413, follows on from commit 0221c9<br>
-<br>
- When calculating the number of bytes required to store the encoded lines<br>
- we multiply the number of columns byt the number of bits required<br>
- for 2 pixels, then divide by 16 to get the required number of bytes.<br>
-<br>
- This commit simply ensures that the division by 16 is rounded *up* and<br>
- not down. Previously we could end up dropping up to 7 bits of required<br>
- space. Generally this is not likely to be a problem but it is technically<br>
- a problem, and can be demonstrated on pathological cases.<br>
-<br>
-base/scfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-03-01 18: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=0221c9e4c43b25375dab6c9d15a777eecf20d261">0221c9e4c43b25375dab6c9d15a777eecf20d261</a>
-<blockquote>
-<p>
- Fix CCITT Fax Encoder<br>
-<br>
- Bug #696413 &quot;Seg faults found by fuzzing in pdf_store_page_resources (gdevpdfu.c:1663)&quot;<br>
-<br>
- As noted it eh bug report, the problem is that the encoding buffer is<br>
- allocated with a size based on the maximum number of bits for horizontal<br>
- encoding (6 bits per pixel), but for 2D encoding some of the bits might<br>
- use vertical encoding. Vertically encoded bits with an offset of 3 use<br>
- 7 bits per pixel, not 6.<br>
-<br>
- If we get a line with sufficient 7-bit encodings, where the horizontal<br>
- bits are encoded with 6 bits (eg runs of 1 pixel), then we can end up<br>
- running off the end of the buffer. Make the allocation assume a maximum<br>
- of 7 encoded bits per pixel instead.<br>
-<br>
-base/scfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-27 20:56:07 +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=e27f0530e3410547563daf757dc5c121c21d2f1c">e27f0530e3410547563daf757dc5c121c21d2f1c</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in show_proceed.<br>
-<br>
- Fix memory leak and SEGV when gs_newpath returns an error code.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=9017 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-base/gxchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-27 21:12:12 +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=49974a63cad8c792067fbf63905a271022b0e806">49974a63cad8c792067fbf63905a271022b0e806</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leaks in hpgl_print_char.<br>
-<br>
- Fix memory leak when pcl_mark_page_for_current_pos returns an error code.<br>
- Also prevent path becoming orphaned in cpath_set_rectangle.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=9010 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-base/gxcpath.c<br>
-pcl/pcl/pglabel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-28 17:17:23 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=03194b72312b6777021f0554bdd30fecc89db486">03194b72312b6777021f0554bdd30fecc89db486</a>
-<blockquote>
-<p>
- txtwrite - guard against infinite loop<br>
-<br>
- vertical text could result in an advance width of 0, which would cause<br>
- us to try and write an infinite number of spaces.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-28 14:04:32 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d57bd7ce641d8134d559f5e8190e2578137e1d39">d57bd7ce641d8134d559f5e8190e2578137e1d39</a>
-<blockquote>
-<p>
- txtwrite - better dynamic resizing<br>
-<br>
- A better fix for bug #699078, this implemnets the thought I had while<br>
- writing up the description of the problem. In this case we check whether<br>
- the current 'effective size' of the monospaced font would lead to<br>
- the end of the current run of text lying to the right of the 'next' run<br>
- of text on this line. If it would, then use the newly calculated<br>
- effective size, no matter how small it is, to avoid collisions.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-28 09:34:06 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d0d4e282f98487ca2979edbaf6834d9341bcee53">d0d4e282f98487ca2979edbaf6834d9341bcee53</a>
-<blockquote>
-<p>
- txtwrite - slacken a restriction on minimum width selection<br>
-<br>
- Bug #699078 &quot; Extracted text is not properly seperated&quot;<br>
-<br>
- Allow the minimum size assigned to the monospaced output to be smaller<br>
- than previously (previously we limited it to .75 of the smallest point<br>
- size of any used font).<br>
-<br>
- This will reduce the number of horizontal text collisions at the cost<br>
- of potentially making the text output wider.<br>
-<br>
- Essentially this is caused by using a monospaced font to represent the<br>
- original proportionally spaced input. A sufficiently long run of<br>
- characters which are significantly less than the M width could result in<br>
- the position being further to the right (when converted to monspaced<br>
- text) than the neext horizontal fragment. So we wouldn't try to<br>
- space it any further.<br>
-<br>
- Previously we limited the calculation of the minimum character size in<br>
- a run to 3/4 of the M space. Here we reduce that to 1/2 which will<br>
- permit more flexibility, but as stated, at the potential cost of the<br>
- output text being 'wider' (containing more spaces).<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-26 21:25:19 +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=a16736bc4ea251c46f1aa1d3b6176aadf5f0b914">a16736bc4ea251c46f1aa1d3b6176aadf5f0b914</a>
-<blockquote>
-<p>
- Bug 697545 : Update PCL to return error codes (Patch VI).<br>
-<br>
- Prevent numerous SEGV points by ensuring error codes are returned and<br>
- handled appropriately.<br>
-<br>
-pcl/pl/plparams.c<br>
-pcl/pl/pluchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-25 20:36:29 +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=50f7fc4f7a99d874af86e4a874067ba3a7760c42">50f7fc4f7a99d874af86e4a874067ba3a7760c42</a>
-<blockquote>
-<p>
- Bug 697545 : Update PCL to return error codes (Patch V).<br>
-<br>
- Prevent numerous SEGV points by ensuring error codes are returned and<br>
- handled appropriately.<br>
-<br>
-pcl/pcl/rtraster.c<br>
-pcl/pl/plchar.c<br>
-pcl/pl/plht.c<br>
-pcl/pl/pllfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-23 18:02:47 +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=0edcf910b80a1656c9441f32bd1770d2600ab915">0edcf910b80a1656c9441f32bd1770d2600ab915</a>
-<blockquote>
-<p>
- Bug 697545 : Update PCL to return error codes (Patch IV).<br>
-<br>
- Prevent numerous SEGV points by ensuring error codes are returned and<br>
- handled appropriately.<br>
-<br>
-pcl/pcl/pginit.c<br>
-pcl/pcl/pginit.h<br>
-pcl/pcl/pglabel.c<br>
-pcl/pcl/pglfill.c<br>
-pcl/pcl/pgmand.h<br>
-pcl/pcl/pgmisc.c<br>
-pcl/pcl/pgpoly.c<br>
-pcl/pcl/pgvector.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-22 20:34:53 +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=9f90d1361564289e6dbe56863a5fe1be1ca28f83">9f90d1361564289e6dbe56863a5fe1be1ca28f83</a>
-<blockquote>
-<p>
- Bug 697545 : Update PCL to return error codes (Patch III).<br>
-<br>
- Prevent numerous SEGV points by ensuring error codes are returned and<br>
- handled appropriately.<br>
-<br>
-pcl/pcl/pgchar.c<br>
-pcl/pcl/pgconfig.c<br>
-pcl/pcl/pgdraw.c<br>
-pcl/pcl/pgfdata.c<br>
-pcl/pcl/pgfont.c<br>
-pcl/pcl/pgframe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-23 14:35:57 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6375e295893a71b5695fba2ca117747e326c8ec2">6375e295893a71b5695fba2ca117747e326c8ec2</a>
-<blockquote>
-<p>
- pdfwrite - gracefully handle inappropriate PDFA command line<br>
-<br>
- If a user sets -dPDFA, but does not set ColorConversionStrategy, and<br>
- then processes an input file which has a DeviceN space with an alternate<br>
- space which does not match the ProcessColorModel, then we would write<br>
- an invalid PDF file (invalid function for the colour space).<br>
-<br>
- Now technically this shouldn't happen, but we can guard against this<br>
- specific user error by spotting the problem and returning a rangecheck<br>
- error instead, which will cause the earlier code to fall back to<br>
- writing a device colour instead.<br>
-<br>
- No diffrences expected.<br>
-<br>
-devices/vector/gdevpdfc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-20 22:13:51 +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=03607549d598b14ebbb6d4aea9591e10fc35c6cc">03607549d598b14ebbb6d4aea9591e10fc35c6cc</a>
-<blockquote>
-<p>
- Bug 697545 : Update PCL to return error codes (Patch II).<br>
-<br>
- Prevent numerous SEGV points by ensuring error codes are returned and<br>
- handled appropriately.<br>
-<br>
-pcl/pcl/pcsfont.c<br>
-pcl/pcl/pcsymbol.c<br>
-pcl/pcl/pctext.c<br>
-pcl/pcl/pctop.c<br>
-pcl/pcl/pcuptrn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-20 18:40:37 +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=de2c3c2c536d5aff97091b146ed259270228dcb9">de2c3c2c536d5aff97091b146ed259270228dcb9</a>
-<blockquote>
-<p>
- Bug 697545 : Update PCL to return error codes (Patch I).<br>
-<br>
- Prevent numerous SEGV points by ensuring error codes are returned and<br>
- handled appropriately.<br>
-<br>
-pcl/pcl/pccolor.c<br>
-pcl/pcl/pcdraw.c<br>
-pcl/pcl/pcfontpg.c<br>
-pcl/pcl/pcindxed.c<br>
-pcl/pcl/pcjob.c<br>
-pcl/pcl/pcmacros.c<br>
-pcl/pcl/pcpalet.c<br>
-pcl/pcl/pcparse.c<br>
-pcl/pcl/pcpatrn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-14 17:26: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=8f2f27a730fc7ba76847d39fc46d6d7183cd27a3">8f2f27a730fc7ba76847d39fc46d6d7183cd27a3</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leaks during font loading.<br>
-<br>
- Fix memory leaks for numerous allocation events.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=1564 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-base/gstype42.c<br>
-base/gxfapi.c<br>
-pcl/pl/plfapi.c<br>
-pcl/pl/plfont.c<br>
-pcl/pl/pllfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-18 16:05:18 +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=cceb3db394d9547d309f596001b02c63dec4d7f5">cceb3db394d9547d309f596001b02c63dec4d7f5</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in gx_path_new.<br>
-<br>
- During a memory allocation event failure the orginal path would not be<br>
- decremented and hence become orphaned.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=8959 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-base/gxpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-19 15:43:20 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3f5736cb8a255cdfe00d59896dc39d050d1db00e">3f5736cb8a255cdfe00d59896dc39d050d1db00e</a>
-<blockquote>
-<p>
- Add more bounds checking to type 2 font interpreter<br>
-<br>
- Bug #699042 &quot;stack out of bounds read in gs_type2_interpret, gstype2.c line 701&quot;<br>
-<br>
- The warning is caused by 'csp' being below the cstack bottom bound.<br>
- Adding a check for that prevents this warning. While we're here, add<br>
- checks to the bounds of 'transient_array' which wasn't being checked<br>
- previously.<br>
-<br>
-base/gstype2.c<br>
-base/gxtype1.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-19 14:26:29 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc2bfef83b1dca09e016e43238f71ca6c7a622b3">cc2bfef83b1dca09e016e43238f71ca6c7a622b3</a>
-<blockquote>
-<p>
- PDF interpreter - fix ToUnicode processing of bfrange with high byte set<br>
-<br>
- Bug #699041 &quot;Cyrilic text not respected&quot;<br>
-<br>
- The title is a misnomer, the problem is not Cyrillic fonts as such.<br>
-<br>
- The example file has an unusually complex ToUnicode CMap, which includes<br>
- bfrange entries where the CID has a value &gt; 0xFF. The code in pdf_font.ps<br>
- to create our internal GlyphNames2Unicode table was adding the 'offset'<br>
- (The high byte of the index) to the CID, which basically means we were<br>
- adding the high byte twice (the key already included the high byte).<br>
-<br>
- Fix this by simply not adding the offset to the keys.<br>
-<br>
- Its surprisingly hard to find examples of this, I can't immediately see<br>
- any in our test suite. I have gone through some of the files which<br>
- have been reported as problems with ToUnicode processing in the past<br>
- but none of them fall into this condition.<br>
-<br>
- A couple of files show difference, but these are irrelevant, they are of<br>
- the 'wrong before, differently wrong now' category.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-18 14:18:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb2aa457387429b84c043430354b8476ac918961">eb2aa457387429b84c043430354b8476ac918961</a>
-<blockquote>
-<p>
- Squash a couple of build warnings<br>
-<br>
- Sort out negation of the PDFA flag<br>
-<br>
- Ensure a variable is initialised under all conceivable circumstances<br>
-<br>
-devices/vector/gdevpdtd.c<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-16 19:32:11 +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=f006720c87026a67cdcaeab983fe888d4401cb0e">f006720c87026a67cdcaeab983fe888d4401cb0e</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV by returning error codes.<br>
-<br>
- Prevent numerous SEGV points by ensuring error codes are returned and<br>
- handled appropriately.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=8961 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pcl/pgconfig.c<br>
-pcl/pcl/pgframe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-16 18:56: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=833333a6df506ad9525bb797245042442a0f31cb">833333a6df506ad9525bb797245042442a0f31cb</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV in palette_do_reset.<br>
-<br>
- Prevent SEGV when trying to access contents of empty palette.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=8956 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pcl/pcpalet.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-16 18:39:30 +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=0ebfdae6fceedbbe7036c487916193b4349d4dd3">0ebfdae6fceedbbe7036c487916193b4349d4dd3</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in alloc_indexed_cspace.<br>
-<br>
- Fix memory leak for allocation event 8953.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=8954 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pcl/pcindxed.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-13 15:53:09 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9f9daedfdf98bab590eba53e34fba76b96307ec0">9f9daedfdf98bab590eba53e34fba76b96307ec0</a>
-<blockquote>
-<p>
- Fix Bug 698969 SEGV caused by overflow in mark_line_*** functions<br>
-<br>
- Clipping needs to be performed in 64-bit to allow for the original<br>
- line segment being larger than can fit in signed 32-bit.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-16 10:29: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=ad07c06b7f898eeb663ee7eed336c2c602a91551">ad07c06b7f898eeb663ee7eed336c2c602a91551</a>
-<blockquote>
-<p>
- pdf_info.ps - check for null DescendantFonts after oforce<br>
-<br>
- pdf_info.ps was modified to check for circular references when resolving<br>
- indirect objects. Now if we find recursion we return a null.<br>
-<br>
- However, we weren't checking that when resolving DescendantFonts which<br>
- could lead to a typecheck error if we had two different CIDFonts on<br>
- the same page, and the CIDFonts used the same DescendantFonts array<br>
- (which is silly, of course).<br>
-<br>
-toolbin/pdf_info.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-15 10:15:28 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a8c1d6be02fc7020ab4cf5cfbecf91790f7dc10">6a8c1d6be02fc7020ab4cf5cfbecf91790f7dc10</a>
-<blockquote>
-<p>
- Bug 696654 - PCL/PXL fails to build with system-shared libjpeg.<br>
-<br>
- Remove the HP CLJ 3500/3500/3600 emulation until it can be properly<br>
- integrated with libjpeg.<br>
-<br>
-base/gdevpxat.h<br>
-base/gdevpxen.h<br>
-pcl/pxl/pxl.mak<br>
-pcl/pxl/pxptable.c<br>
-pcl/pxl/pxsessio.c<br>
-pcl/pxl/pxstate.h<br>
-pcl/pxl/pxvendor.c<br>
-pcl/pxl/pxvendor.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-15 14:36:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=094aebef5c058ad312e5d2bfd46d897c21fac398">094aebef5c058ad312e5d2bfd46d897c21fac398</a>
-<blockquote>
-<p>
- pdfwrite - remove dead code<br>
-<br>
- Commit efb9bf3949617b4c733a6dcce04acd142c50115d changed the flow of<br>
- control to avoid going through code which could not work, since it left<br>
- a variable unassigned (and didn't do any part of the work that would<br>
- be required to give the variable a sensible value).<br>
-<br>
- That left some code unreachable leading to a coverity warning (Coverity<br>
- ID 262411). I was unable to find any way to trigger the original<br>
- condition, and the code as it stands should at least work, even if it<br>
- might be sub-optimal in some cases. So remove the dead code to prevent<br>
- the warning, if this needs fixing in future there will need to be more<br>
- code written anyway.<br>
-<br>
-devices/vector/gdevpdfb.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-15 09:02:01 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4384f85cbb9383cbeefea80e45e8893a5d64c7af">4384f85cbb9383cbeefea80e45e8893a5d64c7af</a>
-<blockquote>
-<p>
- PDF interpreter - remove a debug pstack<br>
-<br>
- accidentally left some debugging code in place, remove it now.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-14 17:01:21 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d1b64fe9474d4c1e6d5f4185c77cb42a8ac5bc0">7d1b64fe9474d4c1e6d5f4185c77cb42a8ac5bc0</a>
-<blockquote>
-<p>
- Remove a long obselete C source file<br>
-<br>
- Also remove a documentation reference and Windows project references<br>
-<br>
-doc/Develop.htm<br>
-psi/zhsb.c<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-14 17:26: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=ecf45b80c55bc79c17bed5143426cd9f8060ec2f">ecf45b80c55bc79c17bed5143426cd9f8060ec2f</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leaks during tt font loading.<br>
-<br>
- Fix memory leak for allocation event numbers 1551, 1552 and 1553.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=1554 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pl/plfont.c<br>
-pcl/pl/pllfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-14 15:38:42 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb8f0822a31e0e976cb659000532fde2fdbccd8c">bb8f0822a31e0e976cb659000532fde2fdbccd8c</a>
-<blockquote>
-<p>
- PDF interpreter - detect and ignore circular references in Outlines<br>
-<br>
- Bug #699029 &quot;infinite loop on pdfium test file&quot;<br>
-<br>
- If the /Next in an Outline points to any previously encountered<br>
- Outline entry, terminate processing of Outlines and warn the user.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-14 10:28:37 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=06ceaa2715fcbe2056214b0f958edc7deb4fa085">06ceaa2715fcbe2056214b0f958edc7deb4fa085</a>
-<blockquote>
-<p>
- pdfwrite - improve stack bounds checking on font interpreters<br>
-<br>
- Bug #699020 &quot;stack buffer underflow (read) in gs_type2_interpret / gstype2.c line 567&quot;<br>
-<br>
- The internal type 1 and type 2 font interpreters are only used by<br>
- the vector devices (in particular pdfwrite), for rendering we use<br>
- FreeType.<br>
-<br>
- This commit improves the bounds checking of the operand stacks used<br>
- by these interpreters, to catch more cases of badly formed or<br>
- corrupted fonts and throw an error in these cases.<br>
-<br>
- This addresses the stated bug, but should actually prevent a lot<br>
- more problems which we haven't yet seen test cases for.<br>
-<br>
-base/gstype1.c<br>
-base/gstype2.c<br>
-base/gxtype1.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-13 12:00:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c1a8dc52c0e320c41d04b6f32086622150962d61">c1a8dc52c0e320c41d04b6f32086622150962d61</a>
-<blockquote>
-<p>
- fix commit bcef41ad72a16472a3003d357bf8d8680174ab85<br>
-<br>
- Accidentally left currentdict on the operand stack afetr startup.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-13 10:48: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=16586a6a0d8fac17d5201f102e0775e527d3a529">16586a6a0d8fac17d5201f102e0775e527d3a529</a>
-<blockquote>
-<p>
- Bug 699019: bounds check stack access in Type 2 vmoveto<br>
-<br>
-base/gstype2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-13 10:22:56 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bcef41ad72a16472a3003d357bf8d8680174ab85">bcef41ad72a16472a3003d357bf8d8680174ab85</a>
-<blockquote>
-<p>
- PS interpreter - fix setpagedevice with -dDELAYBIND<br>
-<br>
- When a user sets a fixed resolution using -r, then the setpagedevice<br>
- code looks for the existence of a /HWResolution key in the page device<br>
- dictionary and attempts to remove it using .undef to prevent the<br>
- resolution being altered.<br>
-<br>
- However, if DELAYBIND is set, then the .undef operator is removed<br>
- before .bindnow is run, which means that, when setpagedevice executes,<br>
- the .undef operator is not defined.<br>
-<br>
- So add the same code for .undef as we use for other similar operators<br>
- (eg .forceundef), don't remove the definition if DELAYBIND is set, but<br>
- do remove it when .bindnow executes.<br>
-<br>
- This is, of course, a security hole, but then the whole DELAYBIND<br>
- situation is.<br>
-<br>
- While we are here, add a key /NOBIND with the value false to systemdict.<br>
- This is because some ancient, badly-behaved and no longer maintained<br>
- software checks this key unconditionally, if its not present it fails<br>
- with an undefined error. Setting it to false pacifies that software.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-13 08:52:32 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=310a0bcaba3527903fc66fed2984f30d0bd4e4ab">310a0bcaba3527903fc66fed2984f30d0bd4e4ab</a>
-<blockquote>
-<p>
- Bug 699016: add stack bounds check for Type 1 seac<br>
-<br>
- The macro for checking the stack bounds is now called from both the Type 1 and<br>
- Type 2 charstring code, so move it to a common header, and tweak the name to<br>
- fit.<br>
-<br>
-base/gstype2.c<br>
-base/gxtype1.c<br>
-base/gxtype1.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-13 08:35: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=9bbf14bc7210bc54613b0f64a5ad95368891982a">9bbf14bc7210bc54613b0f64a5ad95368891982a</a>
-<blockquote>
-<p>
- Bug 699015: bounds check stack for Type 2 callsubr<br>
-<br>
-base/gstype2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-12 21:47:29 +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=0e9ba7084176c7834db00927a8326310c6b83a67">0e9ba7084176c7834db00927a8326310c6b83a67</a>
-<blockquote>
-<p>
- Fix memory leak in xps_imp_set_device.<br>
-<br>
- The param list can become orphaned if an error occurs early on in the code.<br>
-<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-11 20:44:04 +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=5e9639e974afaa89027a5ccd573e50ff98e3ca3f">5e9639e974afaa89027a5ccd573e50ff98e3ca3f</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in pcl_load_built_in_symbol_sets.<br>
-<br>
- Fix memory leak for allocation event number 1266.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=1267 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pcl/pcsymbol.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-11 20:20:36 +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=3e4c6beff724a4e0078a48e6f5200c23ae73f52b">3e4c6beff724a4e0078a48e6f5200c23ae73f52b</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in pl_top_create_device.<br>
-<br>
- The param list can become orphaned if an error occurs early on in the code.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=676 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-12 15:23:19 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a4445fe0a312af901a79d6f41ace975a50d88a31">a4445fe0a312af901a79d6f41ace975a50d88a31</a>
-<blockquote>
-<p>
- Bug 699012: bounds check point index in Move_Zp2_Point()<br>
-<br>
-base/ttinterp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-12 12:05:44 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e7abbb92e92ba326b4fc06491bd3c3cde61932b3">e7abbb92e92ba326b4fc06491bd3c3cde61932b3</a>
-<blockquote>
-<p>
- Bug 699013: Check glyph has a contour before accessing it.<br>
-<br>
- in Ins_IUP()<br>
-<br>
-base/ttinterp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-12 15:20:23 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=edf3684305414731fbdb9b90de7dbcbab0dace5f">edf3684305414731fbdb9b90de7dbcbab0dace5f</a>
-<blockquote>
-<p>
- Fix comments<br>
-<br>
- The comments in zinitgrpahics and the PostScript definition of<br>
- initgraphics in gs_cspace.ps were incorrect, now that gs_initgraphics<br>
- does reset the colour space properly.<br>
-<br>
- However, we do still need the /initgraphics override in gs_cspace.ps<br>
- in order to correctly set the colour space which we store in the<br>
- 'interpreter' graphics state. We only use that to hand back in response<br>
- to a currentcolorspace, but we do need it.<br>
-<br>
-Resource/Init/gs_cspace.ps<br>
-psi/zgstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-12 13:47:18 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b7a0556297296d8355748b9b130de02923a1c4cd">b7a0556297296d8355748b9b130de02923a1c4cd</a>
-<blockquote>
-<p>
- Check for error case in gs_cspace_new_ICC()<br>
-<br>
- If we fail to allocate memory for a new colour space, simply return<br>
- NULL, don't try to use the failed allocation!<br>
-<br>
-base/gscspace.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-12 12:21:50 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a708d9fdcba9efbe21f236830e47eb4f4085672">7a708d9fdcba9efbe21f236830e47eb4f4085672</a>
-<blockquote>
-<p>
- More work with initgraphics<br>
-<br>
- Firstly, remove the kludgy gs_initgraphics_no_cspace() and have the<br>
- PostScript operator zinitgraphics() call gs_initgraphics().<br>
-<br>
- This meant fixing the gs_initgraphics routine; the previous commit<br>
- d527031607a881237819835c2b1045c81e24c387 simply overwrote the existing<br>
- colour spaces in the graphics state with the new DeviceGray space. This<br>
- could lead to memory leaks if the previous colour space had been<br>
- reference counted up. So now we call gs_setcolorspace instead, which also<br>
- correctly sets the current colour.<br>
-<br>
- This led to the interesting discovery that the null brush in PXL has<br>
- never been handled properly by the high level devices. This is<br>
- handled by the PXL interpreter setting a DeviceGray colour space, and<br>
- then directly editing the device colour 'type' field and setting it to<br>
- 'typ_null'. This doesn't seem like the best way to proceed to me, I<br>
- would have expected us to push the nulldevice, but its what is done.<br>
-<br>
- No in gx_hld_is_hl_color_available() the code simply tested whether<br>
- the device color 'ccolor_valid' flag was set. Since the PXL interpreter<br>
- simply stomped on the type field, and did not update any of the other<br>
- fields, the result of this was unknown. Sometimes we would decide it<br>
- was valid, and sometimes not. If we did decide it was valid then we<br>
- used the DeviceGray space and colour (0, black) which was also set up<br>
- by the null brush code to draw the object, which means that we could<br>
- end up drawing objects which should not be drawn.<br>
-<br>
- 'Fixed' this by having the code explicitly test for the device color<br>
- type being 'null' as well as being valid. In passing, it did appear<br>
- to me that we do not always update the ccolor_valid flag in the device<br>
- color structure, which may well lead to more problems of this kind.<br>
-<br>
- This does result in a number of differences in the output. Mostly<br>
- these are due to the error page now always being rendered in DeviceGray<br>
- which results in a slightly (invisible) difference in printed gray text.<br>
- A very large number of the Quality Logic files exhibit progressions<br>
- due to the fact that we are now correctly processing the null brush.<br>
-<br>
-base/gsstate.c<br>
-base/gxhldevc.c<br>
-psi/zgstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-04 18:45:26 +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=1af4fced38d9d842195e5635c9e0aa4b5e13f21b">1af4fced38d9d842195e5635c9e0aa4b5e13f21b</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in pcl interpreter.<br>
-<br>
- If an error occurs during pl_set_device then the new interpreter is partially<br>
- set up but the old interpreter is still listed as current so the cleanup<br>
- code does not reclaim the partially set up memory. The patch ensures the<br>
- correct interpreter is cleaned up and also zeros out unset fields to prevent<br>
- a SEGV during memory freeing.<br>
-<br>
- Fix memory leak for allocation event number 1265.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=1266 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pcl/pctop.c<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-10 22:28: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=98d8f8d12a40bf36f0acdaefc0c63a7562326cab">98d8f8d12a40bf36f0acdaefc0c63a7562326cab</a>
-<blockquote>
-<p>
- Fix compile warning about possible uninitialized procedure pointers<br>
-<br>
- Setting to NULL is OK since it will trigger a SEGV, but it looks<br>
- like the code will always set the procedures if it needs the source<br>
- colors.<br>
-<br>
-base/gdevmpla.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-10 11:43:15 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2fe4c53757ef143071517216cacdbb228dfc4243">2fe4c53757ef143071517216cacdbb228dfc4243</a>
-<blockquote>
-<p>
- Fix compiler warning: mlut_size<br>
-<br>
- This is OK because mlut_size is only used when 'clut' is non-NULL<br>
- but if so, it is initialized in line 1179.<br>
-<br>
-base/gsicc_create.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-10 11:28:48 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d3fb0f876971f604597c10519259520a8035cb58">d3fb0f876971f604597c10519259520a8035cb58</a>
-<blockquote>
-<p>
- Fix gcc warning: gscms_is_threadsafe prototype<br>
-<br>
-base/gsicc_cms.h<br>
-base/gsicc_lcms2.c<br>
-base/gsicc_lcms2art.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-06 11:53:24 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=01a71ecbfe576d0a840946a0089f23ce131e995d">01a71ecbfe576d0a840946a0089f23ce131e995d</a>
-<blockquote>
-<p>
- Change from CMM_THREAD_SAFE #define to a gscms_is_threadsafe function<br>
-<br>
- In preparation for enabling sharing the profiles and link cache among<br>
- rendering threads, switch from a compile time flag to a function that<br>
- is returned by the CMS interface module linked in (e.g gsicc_lcms2.c)<br>
-<br>
- This avoids more build machinery to propagate the flag, and ensures<br>
- that the flag won't be mis-matched to the CMS in use.<br>
-<br>
- Also flag a few FIXME places identified that relate to multi-threaded<br>
- sharing of profiles and the profile link cache. Initially, even though<br>
- lcms2art is thread safe, return &quot;false&quot; until the multi-threaded<br>
- rendering works.<br>
-<br>
-base/gdevp14.c<br>
-base/gsicc_cms.h<br>
-base/gsicc_lcms2.c<br>
-base/gsicc_lcms2art.c<br>
-base/gxcldev.h<br>
-base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-10 10:59:29 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da66356a665432f998642b2e9c45756f876f0996">da66356a665432f998642b2e9c45756f876f0996</a>
-<blockquote>
-<p>
- PCL interpreter - correctly identify high level devices<br>
-<br>
- Pointed out by Chris, the code in here explicitly tested the name of the<br>
- device to decide if it was a high level device. We deprecated that<br>
- approach some time ago, replacing it with a spec_op call instead.<br>
-<br>
- The comment said 'this needs a better solution' and this is it.<br>
-<br>
- Should work correctly now with any device which identifies itself as a<br>
- high level device.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-08 13:57:54 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b4a301c90a8905d6b7ba703342ddc9cb1c8ff69">4b4a301c90a8905d6b7ba703342ddc9cb1c8ff69</a>
-<blockquote>
-<p>
- Fix 694689 - Seg faults found by fuzzing.<br>
-<br>
- Allow clients of the decompression routines to pass in a parameter to<br>
- indicate no further input or output is expected. The decompression<br>
- routines should produce an error if the parameter is set and more<br>
- processing is needed. The pattern code uses this to indicate indicate<br>
- the final scanline has been processed, it is not needed by the image<br>
- code.<br>
-<br>
-pcl/pxl/pximage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-07 17:03:04 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e4764d61562a44c77920ee67884ca846184b25c">8e4764d61562a44c77920ee67884ca846184b25c</a>
-<blockquote>
-<p>
- Add line pointer to the pattern enumerator.<br>
-<br>
- This tracks the scan line position within the pattern while reading,<br>
- simplifying bounds checking.<br>
-<br>
-pcl/pxl/pximage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-05 13:28:52 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=faef871274167e12e93fc24026096474d00b794d">faef871274167e12e93fc24026096474d00b794d</a>
-<blockquote>
-<p>
- Remove pushed argument.<br>
-<br>
- No need to push the filename simply run the file and use a do while<br>
- loop.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-02 10:35:28 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f29e2296e81378ed42b93215137361ab586b2393">f29e2296e81378ed42b93215137361ab586b2393</a>
-<blockquote>
-<p>
- Warning cleanup.<br>
-<br>
-pcl/pcl/pcpalet.c<br>
-pcl/pcl/pcparse.c<br>
-pcl/pcl/pglabel.c<br>
-pcl/pl/pllfont.c<br>
-pcl/pxl/pxtop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-07 21:08:46 +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=b808ea741efe357cf71254d9064e782dfd753584">b808ea741efe357cf71254d9064e782dfd753584</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in gs_state_alloc.<br>
-<br>
- The colour allocation code in gs_gstate_alloc was being repeated in the call<br>
- to gs_initgraphics leading to the first set of allocated colours becoming<br>
- orphaned. Given that gs_initigraphics is always called from gs_gstate_alloc<br>
- the duplicate code can be safely removed.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=419 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-06 18:04:07 +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=98e5b234b27d82e52d660a9e0bfc6c14e3d7a5cd">98e5b234b27d82e52d660a9e0bfc6c14e3d7a5cd</a>
-<blockquote>
-<p>
- Bug 697545 : Prevent SEGV in pcpage_do_reset.<br>
-<br>
- Prevent SEGV if memory allocation fails and returns a NULL paper size.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=1215 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pcl/pcpage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-07 15:46:28 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=10dcb4943e552a3d53fbaf0b4e8741258238f7a7">10dcb4943e552a3d53fbaf0b4e8741258238f7a7</a>
-<blockquote>
-<p>
- Handle a potential error condition in PXL<br>
-<br>
- Bug #698995 &quot;Fixing error returns in gxicolor.c can cause PXL to enter an infinite loop or seg fault&quot;<br>
-<br>
- This started off as a fix to a scanbuild warning and spiralled somewhat.<br>
-<br>
- Fixing gs_image_class_4_color() so that it didn't ignore an error return<br>
- led to the possibility of the PXL interpreter seg faulting or ending up<br>
- in an infinte loop.<br>
-<br>
- Initially this turned out to be because gs_initgraphics() was no longer<br>
- setting the colour space to the proper default, leading to us trying<br>
- to use the very pattern space which failed. That was fixed in the<br>
- previous commit.<br>
-<br>
- After that it turned out that in an error condition we were freeing<br>
- an image enumerator twice. This didn't seem to cause the PostScript<br>
- interpreter a problem, though it seems likely it did really, it simply<br>
- didn't exhibit before the interpreter exited. The PXL interpreter<br>
- however threw an error in the memory manager rather rapidly.<br>
-<br>
- Fixed that by not calling gx_default_end_image in gx_enum_begin()<br>
- when we hit this particular error condition (no handler for an image).<br>
-<br>
- This removes one of the free instances, and seems more reasonable anyway<br>
- it seems wrong to end an image we haven't yet begun.<br>
-<br>
- This allows us to now propagate the error up from px_remap_pattern<br>
- without causing a seg fault or infinite loop. (finally)<br>
-<br>
-base/gxipixel.c<br>
-pcl/pxl/pxink.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-07 09:55:41 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d527031607a881237819835c2b1045c81e24c387">d527031607a881237819835c2b1045c81e24c387</a>
-<blockquote>
-<p>
- Alter gs_initgraphcis to once again set the colour space and colour<br>
-<br>
- At some time in the past gs_initgraphics was altered for 'colour substitution'<br>
- so that it did not reset the colour space and current colour. This is<br>
- surprising because the PostScript initgraphics operator is supposed to<br>
- do exactly that.<br>
-<br>
- Restoring the code resulted in many seg faults with the PDF interpreter<br>
- so this is obviously a requirement, even though I can't see why.<br>
-<br>
- However, leaving gs_initgraphics as it is would mean that (as per the<br>
- comment above the procedure) that all the interpreters (clients) would<br>
- have to reset the colour space and colour after calling it, which is<br>
- entirely unreasonable. Not only that, it hasn't been done leading to<br>
- the PXL interpreter printing error pages in the wrong colour.<br>
-<br>
- This commit restores the setting of the colour space and colour to<br>
- gs_initgraphics, but introduces a new gs_initgraphics_no_cpsace()<br>
- procedure to be called from zinitgraphics, which behaves exactly as<br>
- the modified gs_initgraphics did, and does not set the colour space<br>
- or colour values.<br>
-<br>
- The PDF interpreter now continues to work and the PXL interpreter now<br>
- prints a number of error pages in black where it previously was using a<br>
- pattern, grey or in one case green colour.<br>
-<br>
-base/gsstate.c<br>
-base/gsstate.h<br>
-psi/zgstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-07 09:49:34 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=28c58b4114ec145b8597372b6e29cec9e1f5df15">28c58b4114ec145b8597372b6e29cec9e1f5df15</a>
-<blockquote>
-<p>
- Yet more scanbuild warnings<br>
-<br>
- gxhintn.c remove some unnecessary assignemnts<br>
-<br>
- gxicolor.c remove an assignement, add an error check<br>
-<br>
- gximono.c add an error check<br>
-<br>
- gxiscale.c refactor code to remove some unnecessary assignments<br>
-<br>
- gdevpsft.c remove unnecessary assignment<br>
-<br>
-base/gxhintn.c<br>
-base/gxicolor.c<br>
-base/gximono.c<br>
-base/gxiscale.c<br>
-devices/vector/gdevpsft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-29 15:32:34 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1b1015dc0e07b5269c4ee2009d5b896702550a3a">1b1015dc0e07b5269c4ee2009d5b896702550a3a</a>
-<blockquote>
-<p>
- Tweak scale parameters in structure.<br>
-<br>
- Be consistent with naming. Add PatchHeightOut and TopMarginOut so<br>
- we have the complete set. These are required for forthcoming work.<br>
-<br>
-base/gxiscale.c<br>
-base/sidscale.c<br>
-base/siscale.c<br>
-base/sisparam.h<br>
-devices/vector/gdevpsdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-02 12:48:07 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=38e0c643e62087c089c59c9ad44fc468dd09cd37">38e0c643e62087c089c59c9ad44fc468dd09cd37</a>
-<blockquote>
-<p>
- Tweak bitmap interpolater patch size.<br>
-<br>
- When we interpolate an image, we restrict the interpolation to<br>
- the &quot;patch&quot; of the destination image that is actually visible.<br>
- Previously, the calculation of this patch has been inaccurate,<br>
- resulting in a larger area being decoded than was actually<br>
- needed.<br>
-<br>
- While this extra work was largely mitigated by the &quot;Active&quot; area<br>
- detection code, it has meant that the contribution calculations<br>
- within the scaler were 'wrapping' the outside pixels in the<br>
- region to avoid accessing out of bounds.<br>
-<br>
- This upsets the new library we are working on to do the scaling,<br>
- and it's basically inelegant. Instead we fix the destination<br>
- patch calculations so that the patch is correctly sized based<br>
- upon the available source data. This is safe to do because we<br>
- know the source data was already expanded.<br>
-<br>
-base/gxiscale.c<br>
-base/sisparam.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-06 11:46:56 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6005484617ada241d2f5f4deee4808616474831">f6005484617ada241d2f5f4deee4808616474831</a>
-<blockquote>
-<p>
- Address more scanbuild/gcc/clang warnings<br>
-<br>
- gdevkrnlsclass.c Change a while...do into a do...while to see if it<br>
- pacifies a 'dereference of NULL pointer' in scanbuild<br>
-<br>
- gsparamx.c Incorrect return code could lead to an earlier error not<br>
- being preserved. Fortunately this is currently only called by claptrap.<br>
-<br>
- gsptype1.c remove unnecessary assignments<br>
- gssprintf.c &quot; &quot; &quot;<br>
- gstype2.c &quot; &quot; &quot;<br>
- gstype42.c &quot; &quot; &quot;<br>
- gxfill.c &quot; &quot; &quot;<br>
-<br>
- gsptype2.c rejig the code to avoid setting a return code that isn't used.<br>
- Add a check on a return code that was missing.<br>
-<br>
- gxchar.c add return code checking<br>
- gxcmap.c &quot; &quot; &quot; &quot;<br>
-<br>
-base/gdevkrnlsclass.c<br>
-base/gsparamx.c<br>
-base/gsptype1.c<br>
-base/gsptype2.c<br>
-base/gssprintf.c<br>
-base/gstype2.c<br>
-base/gstype42.c<br>
-base/gxchar.c<br>
-base/gxcmap.c<br>
-base/gxfill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-06 10:30:32 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=16688a8b833cf4e8950265e933604c32b1f2392e">16688a8b833cf4e8950265e933604c32b1f2392e</a>
-<blockquote>
-<p>
- Address more scanbuild/gcc/clang warnings<br>
-<br>
- gp_os2.c free buffer and close file on memory full (as per other<br>
- error conditions).<br>
-<br>
- gscicach.c remove unnecessary assignment<br>
- gsdparam.c &quot; &quot; &quot; &quot;<br>
- gxfapi.c &quot; &quot; &quot; &quot;<br>
-<br>
- gscscie.c check a return code<br>
- zicc.c &quot; &quot; &quot; &quot;<br>
- zpcolor.c &quot; &quot; &quot; &quot;<br>
-<br>
- mkromfs.c If realloc should fail in process_path, free working memory<br>
- print an error and exit as per other error conditions.<br>
-<br>
- zcolor.c ensure depth cannot be 0. This should not be possible, no<br>
- existing code causes this, but its best to be safe and it prevents a<br>
- possible unassigned pointer dereference (possibly NULL) which is what<br>
- scanbuild complains of. Best to catch this in the interpreter.<br>
-<br>
-base/gp_os2.c<br>
-base/gscicach.c<br>
-base/gscscie.c<br>
-base/gsdparam.c<br>
-base/gxfapi.c<br>
-base/mkromfs.c<br>
-psi/zcolor.c<br>
-psi/zicc.c<br>
-psi/zpcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-05 16:09:28 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=650aae633131396b802b2cae6e09afbd5aae6ad6">650aae633131396b802b2cae6e09afbd5aae6ad6</a>
-<blockquote>
-<p>
- Coverity ID #261212<br>
-<br>
- This probably showed up because of Ray's work adding return value<br>
- checking. Previously there were probably enough places not checking<br>
- the return code for Coverity to decide it was deliberate, now it is<br>
- raising a warning.<br>
-<br>
- Add a check and take action on an error return.<br>
-<br>
-psi/zcrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-05 16:08:25 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d7a5f0a14e873c7f5f557c4b635f4b4f166b41d2">d7a5f0a14e873c7f5f557c4b635f4b4f166b41d2</a>
-<blockquote>
-<p>
- Coverity ID #261211 - unchecked return value<br>
-<br>
- This probably showed up because of Ray's work adding return value<br>
- checking. Previously there were probably enough places not checking<br>
- the return code for Coverity to decide t was deliberate, now it is<br>
- raising a warning.<br>
-<br>
- Add a check of the return code.<br>
-<br>
-devices/vector/gdevpsdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-05 15:34:58 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b8e36896913713f46a43dbbc0c0ed83f34ab4f10">b8e36896913713f46a43dbbc0c0ed83f34ab4f10</a>
-<blockquote>
-<p>
- Try to squash 3 identical scanbuild warnings<br>
-<br>
- I think scanbuild is deciding that 'depth' could be less than 0, leading<br>
- us to not enter the loop which assigns 'obj'. This is not true, the<br>
- depth cannot be less than 0.<br>
-<br>
- Try making 'depth' an unsigned int as a hint to scanbuild, and see if<br>
- the warning goes away.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-05 15:32: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=88e7812d362483d07ce63b47ae75c4852fe01a8f">88e7812d362483d07ce63b47ae75c4852fe01a8f</a>
-<blockquote>
-<p>
- txtwrite - honour error conditions<br>
-<br>
- 2 warnings from scanbuild, we were ignoring a potential error return in<br>
- two places.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-05 11:55:11 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9c38c79741193010b23dabceb76996488415bd09">9c38c79741193010b23dabceb76996488415bd09</a>
-<blockquote>
-<p>
- Clean up another scanbuild warning<br>
-<br>
- We increment a local variable just before it goes out of scope, which is<br>
- clearly pointless.<br>
-<br>
-devices/vector/gdevpsft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-05 11:54:14 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0b4c59be1793c81e9d8cfeba04e74b6020571f5d">0b4c59be1793c81e9d8cfeba04e74b6020571f5d</a>
-<blockquote>
-<p>
- Fix another scanbuild warning<br>
-<br>
- We don't seem to have any test cases which hit this, but it does look<br>
- possible from the code that we can end up trying to dereference<br>
- p_tile, and we don't check to see if its not NULL, which we do in a<br>
- lot of other places in this fucntion.<br>
-<br>
- To be safe, test it first and return an error if its NULL.<br>
-<br>
-devices/vector/gdevpdfv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-05 10:39:21 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5d9d4bc1bbd272478bb9fd24fc1c0e44b0edc22a">5d9d4bc1bbd272478bb9fd24fc1c0e44b0edc22a</a>
-<blockquote>
-<p>
- Remove an unused function, clear a scanbuild warning<br>
-<br>
- The function cos_write_stream_from_pipeline was never used, so remove<br>
- its definition.<br>
-<br>
- At the same time try to squash a harmless scanbuild warning. We us a<br>
- 'while(s....' loop to try and find a stream, scanbuild regards this as<br>
- implying that 's' might be NULL *initially*, which is not true. This<br>
- leads to a 'NULL pointer dereference' warning in the line after the<br>
- loop, because scanbuild thinks we can get to s-&gt;state with s being an<br>
- inital NULL.<br>
-<br>
- Since we already check for s becoming NULL inside the loop, we don't<br>
- need to check it in while condition.<br>
-<br>
-devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-05 10:35:16 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=43b2b593743433f45590b02b788c54d6bcf563a7">43b2b593743433f45590b02b788c54d6bcf563a7</a>
-<blockquote>
-<p>
- Prevent potential garbage pointer dereference<br>
-<br>
- Picked up by scanbuild, if pdf_enter_substream failed then pres would be<br>
- left uninitialised, but we would then try to dereference it and assign a<br>
- value to a member before acting on the error return code.<br>
-<br>
- Change the order of execution to test the return code first.<br>
-<br>
-devices/vector/gdevpdti.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-05 09:43:01 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=efb9bf3949617b4c733a6dcce04acd142c50115d">efb9bf3949617b4c733a6dcce04acd142c50115d</a>
-<blockquote>
-<p>
- Remove faulty code picked up by scanbuild<br>
-<br>
- scanbuild correctly warned that a variable was uninitialised. In fact<br>
- it looks to me like the code that was flagged simply can't work.<br>
-<br>
- Fortunately it isn't exercised by any files in our test suite, and has<br>
- never been reported as a bug, so its clearly an uncommon (perhaps even<br>
- impossible) case.<br>
-<br>
- All the same, lets fall back to the default handling if we hit it,<br>
- because at least that works, which the old code definitely didn't.<br>
-<br>
-devices/vector/gdevpdfb.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-05 09:40:50 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba6d8c5ec0fa27822041cb3bbc620e531fabcf0a">ba6d8c5ec0fa27822041cb3bbc620e531fabcf0a</a>
-<blockquote>
-<p>
- remove a scanbuild warning<br>
-<br>
- We don't care about errors in this case, we are already aborting due<br>
- to an error. So just discard the status return.<br>
-<br>
-devices/vector/gdevpdfj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-03 10:46:23 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b119c51e5ce8d671bc33e38b7ebf7a5bdf5f9af5">b119c51e5ce8d671bc33e38b7ebf7a5bdf5f9af5</a>
-<blockquote>
-<p>
- Remove unused variable<br>
-<br>
- another scanbuild warning<br>
-<br>
-base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-03 10:26:18 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dde422bb086ce0b2f56609fa3fc9af87867fc757">dde422bb086ce0b2f56609fa3fc9af87867fc757</a>
-<blockquote>
-<p>
- partially revert 07f9da3cb5647b18458cd52d1be35ab5365790eb<br>
-<br>
- This was a scanbuild false positive, the original code was in fact<br>
- correct.<br>
-<br>
-base/gdevkrnlsclass.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-02 15:29:09 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa4941c607680159ed62bfe79b754a099adf5a4e">fa4941c607680159ed62bfe79b754a099adf5a4e</a>
-<blockquote>
-<p>
- squash more scanbuild warnings<br>
-<br>
- check some return values.<br>
-<br>
- Remove some initialisations that aren't required.<br>
-<br>
- Remove soem unused variables.<br>
-<br>
-base/gsdparam.c<br>
-base/gsfunc0.c<br>
-base/gsht.c<br>
-base/gsht1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-02 14:43: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=3f38e3eeb6e6e7d88abbe1dca7675e237d5274e7">3f38e3eeb6e6e7d88abbe1dca7675e237d5274e7</a>
-<blockquote>
-<p>
- Remove spurious semi-colons introduced in 63f0fcc87e7c<br>
-<br>
- I mistakenly left the trailing semi-colon in the macros defining the contents<br>
- of two pairs of structures.<br>
-<br>
- Oddly, this caused a warning on VS2017, but not gcc/clang.<br>
-<br>
- Thanks to Shailesh Mistry for pointing it out.<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-02 13:11:05 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=452efeca35ee7e3fe381cae9a71d6efbcce68cd0">452efeca35ee7e3fe381cae9a71d6efbcce68cd0</a>
-<blockquote>
-<p>
- Address warning in gdevbit.c<br>
-<br>
- Fix the &quot;missing braces in initializer&quot; warning - the explicit declaration of<br>
- the gs_bitrgbtags_device initializer had gotten out of step with the<br>
- gx_device_printer_s definition.<br>
-<br>
-devices/gdevbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-02 14:10: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=9036e05dfbcfa7968e00a53ef7ae9f6146740e94">9036e05dfbcfa7968e00a53ef7ae9f6146740e94</a>
-<blockquote>
-<p>
- Remove the 'device filter chain'<br>
-<br>
- This was an early attempt to allow the possibility of 'chaining'<br>
- devices together. I believe it was never actually completed, although<br>
- the stack existed and was carefully preserved in the graphcis state,<br>
- the only code which accessed it was '.popdevicefilter'.<br>
-<br>
- No C code or PostScript code ever actually pushed a device onto the<br>
- device filter stack, and nothing ever examined the stack to pass<br>
- operations through the 'chain'.<br>
-<br>
- Since its been superseded by device subclassing, and didn't actually<br>
- seem to do anything anyway, remove it altogether. In addition to<br>
- removing clutter this also reduces the amount of 'magic' surrounding<br>
- reference counted objects in gstates.<br>
-<br>
-base/gdevp14.c<br>
-base/gsgstate.c<br>
-base/gsstate.c<br>
-base/gxgstate.h<br>
-base/lib.mak<br>
-doc/Develop.htm<br>
-doc/who_owns_what.txt<br>
-psi/int.mak<br>
-psi/zdfilter.c<br>
-psi/ztrans.c<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-02 11:55:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=154f27478bdf5b27858a9f446433d5b62febb89d">154f27478bdf5b27858a9f446433d5b62febb89d</a>
-<blockquote>
-<p>
- remove some unused code - scanbuild warnings....<br>
-<br>
-base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-02 11:17:19 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=84370aa9d391c37eccd467760c471e99e355a8ec">84370aa9d391c37eccd467760c471e99e355a8ec</a>
-<blockquote>
-<p>
- Fix some debug prints - scanbuild warning fix<br>
-<br>
- The number of parameters and number of format specifiers didn't match,<br>
- this would only be apparent when built with DISPLAY_DEBUG defined.<br>
-<br>
-psi/dpmain.c<br>
-psi/dwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-02 11:16:11 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1552615d4ae39a50a5f7bb40e5f481919ef0cb58">1552615d4ae39a50a5f7bb40e5f481919ef0cb58</a>
-<blockquote>
-<p>
- Fix memory leak - scanbuild warning<br>
-<br>
- Not really a leak as such, but it prevents the warning.<br>
-<br>
-psi/apitest.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-02 11:15: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=ab8d4f968c01900e94438575ce33ae7a4fd63167">ab8d4f968c01900e94438575ce33ae7a4fd63167</a>
-<blockquote>
-<p>
- LCMS2art - fix some warnings from scanbuild<br>
-<br>
- Make three functions static, to avoid 'no prototype' warnings.<br>
-<br>
-lcms2art/src/cmsalpha.c<br>
-lcms2art/src/cmssamp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-02 09:45:39 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0c9d19b947f9ca5bfe6ed1ba221e303d60bfc0cb">0c9d19b947f9ca5bfe6ed1ba221e303d60bfc0cb</a>
-<blockquote>
-<p>
- Remove the Mitsubishi CP50 colour dot matrix printer device<br>
-<br>
- Recent changes caused this device to enter clist mode more frequently<br>
- and our automated testing revealed that in clist mode this device<br>
- does not work. It calls a device method which should never be called.<br>
-<br>
- Its possible to remove the call, but we have no way to determine whether<br>
- the resulting output actually works.<br>
-<br>
- Given the age of this device (and Mitsubishi have reused the model<br>
- number for a different device, so it must be old) we are removing<br>
- support for this device and deleting it fro the build.<br>
-<br>
- If someone is still using this device, we'll reinstate support if they<br>
- are prepared to test the outptu for us.<br>
-<br>
-base/unix-gcc.mak<br>
-configure.ac<br>
-devices/contrib.mak<br>
-devices/gdevcp50.c<br>
-doc/Develop.htm<br>
-psi/msvc.mak<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-02 08:54: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=252527b4257133a722f4f03dce1e8abcbcc3f3c8">252527b4257133a722f4f03dce1e8abcbcc3f3c8</a>
-<blockquote>
-<p>
- Fix jmp_buf related compiler warning (setjmp_.h)<br>
-<br>
- The compiler (gcc/clang) considers the alignment of entries in a structure to<br>
- be a run-time &quot;variable&quot;, thus gives a warning when that value is used to<br>
- size an array used in a globally available data type.<br>
-<br>
- The solution (suggested by Robin) is to use a buffer twice the size of a jmpbuf,<br>
- thus guaranteeing we have enough space to offset into the buffer, and get the<br>
- required alignment.<br>
-<br>
-base/setjmp_.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-01 14:56:31 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f52a7ccf96f1b9bb90194ba1dd6a50040dd63896">f52a7ccf96f1b9bb90194ba1dd6a50040dd63896</a>
-<blockquote>
-<p>
- Fix debug flag for TTF loading<br>
-<br>
- Two places were erroneously using PDFDEBUG instead of TTFDEBUG<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-01 09:46: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=5b546c80e79e6d1f1c6c3a9a71bfb58ee23a328c">5b546c80e79e6d1f1c6c3a9a71bfb58ee23a328c</a>
-<blockquote>
-<p>
- Address the popen prototype warning<br>
-<br>
- Only include the hacky popen() prototype if it doesn't already exist in the<br>
- standard header files.<br>
-<br>
-Makefile.in<br>
-base/pipe_.h<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-02-01 11:40:20 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=88aea05567f36d4d37c00a51b818c80f88291f6b">88aea05567f36d4d37c00a51b818c80f88291f6b</a>
-<blockquote>
-<p>
- Remove another unused procedure from the OpenJPEG interface<br>
-<br>
-base/sjpx_openjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-31 09:56:46 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=63f0fcc87e7c6a0ca38e92b7b3d72f1e936f2d0e">63f0fcc87e7c6a0ca38e92b7b3d72f1e936f2d0e</a>
-<blockquote>
-<p>
- Fix discarded qualifier warnings in pcl/pl/pjparse.c<br>
-<br>
- Create separate structure definitions for the normal and default PJL<br>
- environment and PJL font sources data.<br>
-<br>
- The only difference between the two is the default one qualifies string<br>
- values as const.<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-31 11:59: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=4d2f9f48fc272b7bb396f36704de03a7c15d2b3f">4d2f9f48fc272b7bb396f36704de03a7c15d2b3f</a>
-<blockquote>
-<p>
- Fix _MSC_VER undefined warnings on non-MSC compilers<br>
-<br>
-lcms2art/src/lcms2_internal.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-31 10:22:34 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b272292d9294e88e32d177d8b5e916f8bfaeb78b">b272292d9294e88e32d177d8b5e916f8bfaeb78b</a>
-<blockquote>
-<p>
- Add a zlib specific CFLAGS and avoid discarded const warning<br>
-<br>
- zlib has a table initialization with string literals that gcc<br>
- automatically makes const, but the structure definition for the table does not<br>
- qualify those entries as const. Hence we get warnings.<br>
-<br>
- This adds ZLIB_CFLAGS and, with a gcc compatible compiler, sets it to:<br>
- -Wno-write-strings<br>
-<br>
- which kills that warning.<br>
-<br>
- Done this way because we want to retain that warning in the Ghostscript code.<br>
-<br>
-Makefile.in<br>
-base/zlib.mak<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-31 09:34: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=aea7d587749819b7e59d24720efe86b1f8555186">aea7d587749819b7e59d24720efe86b1f8555186</a>
-<blockquote>
-<p>
- Add a TIFF specific CFLAGS and avoid discarded const warning<br>
-<br>
- libtiff has a large table initialization with string literals that gcc<br>
- automatically makes const, but the structure definition for the table does not<br>
- qualify those entries as const. Hence we get warnings.<br>
-<br>
- This adds TIFF_CFLAGS and, with a gcc compatible compiler, sets it to:<br>
- -Wno-write-strings<br>
-<br>
- which kills that warning.<br>
-<br>
- Done this way because we want to retain that warning in the Ghostscript code.<br>
-<br>
-Makefile.in<br>
-base/tiff.mak<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-27 23:11:13 +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=865c3a83a449dc2c28f58095183b7493ccd970c4">865c3a83a449dc2c28f58095183b7493ccd970c4</a>
-<blockquote>
-<p>
- Update error code checking to use hpgl_call within pgdraw.c file. Also<br>
- revert error code check in hpgl_draw_current_path to prevent failures<br>
- during cluster run.<br>
-<br>
-pcl/pcl/pgdraw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-27 17:50:41 +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=4ae64a398e6d5693c1dd4dd9348054cd21ef2443">4ae64a398e6d5693c1dd4dd9348054cd21ef2443</a>
-<blockquote>
-<p>
- Check all return code from param_write_float_array.<br>
-<br>
-pcl/pcl/pcommand.c<br>
-pcl/pxl/pxsessio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-27 16:50: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=d372efa33d9e2550b887154e2d6a3b9d03bc6438">d372efa33d9e2550b887154e2d6a3b9d03bc6438</a>
-<blockquote>
-<p>
- Check all return codes from pxPassthrough_init.<br>
-<br>
-pcl/pxl/pxpthr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-27 16:27:08 +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=cc620400517cd76a5276602aea59f1231f934c46">cc620400517cd76a5276602aea59f1231f934c46</a>
-<blockquote>
-<p>
- Check all return codes from pcl_enter_graphics_mode.<br>
-<br>
-pcl/pcl/rtgmode.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-27 15:18: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=db10b7b56e5de12f92c1df83237ec4ff4b0dcf2a">db10b7b56e5de12f92c1df83237ec4ff4b0dcf2a</a>
-<blockquote>
-<p>
- Check all return codes from pcl_end_graphics_mode.<br>
-<br>
-pcl/pcl/pctop.c<br>
-pcl/pcl/rtgmode.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-26 22:45:54 +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=1df8810b79c5ef5979b1cad5ffe22a1fed824871">1df8810b79c5ef5979b1cad5ffe22a1fed824871</a>
-<blockquote>
-<p>
- Update propagation of error codes from pcl_end_page.<br>
-<br>
-pcl/pcl/pcjob.c<br>
-pcl/pcl/pcpage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-26 22:17:36 +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=e63064cfa3142e7a893a1666570f390d83662360">e63064cfa3142e7a893a1666570f390d83662360</a>
-<blockquote>
-<p>
- Update pcl_mark_page_for_character to propagate error codes.<br>
-<br>
-pcl/pcl/pcpage.c<br>
-pcl/pcl/pcpage.h<br>
-pcl/pcl/pctext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-26 21:57:56 +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=6f514a99fdb079d76df981a39dcb45f090766849">6f514a99fdb079d76df981a39dcb45f090766849</a>
-<blockquote>
-<p>
- Update functionality to propagate error codes.<br>
-<br>
-pcl/pcl/pcpage.c<br>
-pcl/pcl/pcpage.h<br>
-pcl/pcl/pgdraw.c<br>
-pcl/pcl/pglabel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-26 21:20: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=193d143d1843edb2515138e6b4b9e7c4f5c06aa5">193d143d1843edb2515138e6b4b9e7c4f5c06aa5</a>
-<blockquote>
-<p>
- Update functionality to propagate error codes returned from new_page_size.<br>
-<br>
-pcl/pcl/pcpage.c<br>
-pcl/pcl/pcpage.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-26 17:59:15 +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=0d3c2753172bb9e22aa879d7503ec44f4b33e8f4">0d3c2753172bb9e22aa879d7503ec44f4b33e8f4</a>
-<blockquote>
-<p>
- Update pcl_transform_rect to remove unused memory variable.<br>
-<br>
-pcl/pcl/pcpage.c<br>
-pcl/pcl/pcpatxfm.c<br>
-pcl/pcl/pcpatxfm.h<br>
-pcl/pcl/rtgmode.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-31 15:37:17 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=961b01a6e50e640afac0e696f9ce74a677e648ec">961b01a6e50e640afac0e696f9ce74a677e648ec</a>
-<blockquote>
-<p>
- Squash more scan build warnings<br>
-<br>
- Remove initialisations which aren't required (sometimes due to multiple<br>
- initialisations.<br>
-<br>
- In interp.c, store the error value in the actual return code.<br>
-<br>
- Action error return codes.<br>
-<br>
- Fix a few white space oddities.<br>
-<br>
-psi/dscparse.c<br>
-psi/gs.c<br>
-psi/imain.c<br>
-psi/interp.c<br>
-psi/zcie.c<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-31 14:47:41 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7220e8e037ccee1c234872d143ec0ca14682604b">7220e8e037ccee1c234872d143ec0ca14682604b</a>
-<blockquote>
-<p>
- Squash some more warnings<br>
-<br>
- scan build this time, none of them serious.<br>
-<br>
- Check some return codes and remove some unused variables.<br>
-<br>
-devices/gdevpdfimg.c<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfc.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdft.c<br>
-devices/vector/gdevpdfu.c<br>
-devices/vector/gdevpsdp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-31 09:59:01 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=68fcaea85611267eec9f4bac3443977fe15627dc">68fcaea85611267eec9f4bac3443977fe15627dc</a>
-<blockquote>
-<p>
- squash GCC warnings<br>
-<br>
- remove an unused variable from a (large) macro in gxfilltr.h<br>
-<br>
- remove some unused variables, and an entire unused function in<br>
- sjpx_openjpeg.c<br>
-<br>
- remove an unused variable in gdevbit.c<br>
-<br>
- remove an unused variable in gdevjpeg.c<br>
-<br>
- bracket a variable declaration and usage with #ifdef DEBUG to prevent<br>
- the compiler warning that the variable is set but not read on non-debug<br>
- builds. gdevxps.c<br>
-<br>
- preserve 'const' when passing a memory pointer to a procedure to<br>
- avoid a warning about discarding const. zcie.c<br>
-<br>
-base/gxfilltr.h<br>
-base/sjpx_openjpeg.c<br>
-devices/gdevbit.c<br>
-devices/gdevjpeg.c<br>
-devices/vector/gdevxps.c<br>
-psi/zcie.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-31 09:55:34 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=07f9da3cb5647b18458cd52d1be35ab5365790eb">07f9da3cb5647b18458cd52d1be35ab5365790eb</a>
-<blockquote>
-<p>
- Device subclassing - fix potential problems<br>
-<br>
- Flagged by scan build, the code to work a chain of devices had a<br>
- potential problem in walking up and down the chain.<br>
-<br>
- Also flagged by scan build, the create_compositor method checked the<br>
- target child device before trying to use it to set the saved target<br>
- color info, but didn't check it before trying to set the procs.<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevkrnlsclass.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-30 11:49:19 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=67daf3d995d83da98988085e68548a4920fe1747">67daf3d995d83da98988085e68548a4920fe1747</a>
-<blockquote>
-<p>
- Get rid of some gcc warnings.<br>
-<br>
- Add initializers for variables that confuse gcc. Also get rid of the<br>
- clist_reinit_output_file which was only needed for the RETRYING code<br>
- and the partial page rendering (this function had unused variable<br>
- warnings). THis should have been part of commit 7eda41b.<br>
-<br>
-base/gxclist.c<br>
-base/gxclpath.c<br>
-base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-30 16:37:58 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22cf826fe4d0c0206be582d35c99954199dee999">22cf826fe4d0c0206be582d35c99954199dee999</a>
-<blockquote>
-<p>
- Update copyright notice with new head office address.<br>
-<br>
- Also update copyright dates.<br>
-<br>
- Remove gs_cmdl.ps as we no longer use it, and remove its entry from<br>
- psfiles.htm.<br>
-<br>
- Remove xfonts.htm as this feature (xfont support) is long, long gone.<br>
-<br>
-Makefile.in<br>
-Resource/CIDFont/ArtifexBullet<br>
-Resource/CMap/Identity-UTF16-H<br>
-Resource/ColorSpace/DefaultCMYK<br>
-Resource/ColorSpace/DefaultGray<br>
-Resource/ColorSpace/DefaultRGB<br>
-Resource/ColorSpace/TrivialCMYK<br>
-Resource/ColorSpace/sGray<br>
-Resource/ColorSpace/sRGB<br>
-Resource/Decoding/FCO_Dingbats<br>
-Resource/Decoding/FCO_Symbol<br>
-Resource/Decoding/FCO_Unicode<br>
-Resource/Decoding/FCO_Wingdings<br>
-Resource/Decoding/Latin1<br>
-Resource/Decoding/StandardEncoding<br>
-Resource/Decoding/Unicode<br>
-Resource/Encoding/CEEncoding<br>
-Resource/Encoding/ExpertEncoding<br>
-Resource/Encoding/ExpertSubsetEncoding<br>
-Resource/Encoding/NotDefEncoding<br>
-Resource/Encoding/Wingdings<br>
-Resource/Init/FCOfontmap-PCLPS2<br>
-Resource/Init/Fontmap.GS<br>
-Resource/Init/gs_agl.ps<br>
-Resource/Init/gs_btokn.ps<br>
-Resource/Init/gs_cff.ps<br>
-Resource/Init/gs_cidcm.ps<br>
-Resource/Init/gs_ciddc.ps<br>
-Resource/Init/gs_cidfm.ps<br>
-Resource/Init/gs_cidfn.ps<br>
-Resource/Init/gs_cidtt.ps<br>
-Resource/Init/gs_cmap.ps<br>
-Resource/Init/gs_cspace.ps<br>
-Resource/Init/gs_dbt_e.ps<br>
-Resource/Init/gs_diskn.ps<br>
-Resource/Init/gs_dpnxt.ps<br>
-Resource/Init/gs_dps.ps<br>
-Resource/Init/gs_dps1.ps<br>
-Resource/Init/gs_dps2.ps<br>
-Resource/Init/gs_dscp.ps<br>
-Resource/Init/gs_epsf.ps<br>
-Resource/Init/gs_fapi.ps<br>
-Resource/Init/gs_fntem.ps<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_frsd.ps<br>
-Resource/Init/gs_icc.ps<br>
-Resource/Init/gs_il1_e.ps<br>
-Resource/Init/gs_img.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_l2img.ps<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_ll3.ps<br>
-Resource/Init/gs_mex_e.ps<br>
-Resource/Init/gs_mgl_e.ps<br>
-Resource/Init/gs_mro_e.ps<br>
-Resource/Init/gs_pdf_e.ps<br>
-Resource/Init/gs_pdfwr.ps<br>
-Resource/Init/gs_res.ps<br>
-Resource/Init/gs_resmp.ps<br>
-Resource/Init/gs_setpd.ps<br>
-Resource/Init/gs_statd.ps<br>
-Resource/Init/gs_std_e.ps<br>
-Resource/Init/gs_sym_e.ps<br>
-Resource/Init/gs_trap.ps<br>
-Resource/Init/gs_ttf.ps<br>
-Resource/Init/gs_typ32.ps<br>
-Resource/Init/gs_typ42.ps<br>
-Resource/Init/gs_type1.ps<br>
-Resource/Init/gs_wan_e.ps<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>
-Resource/SubstCID/CNS1-WMode<br>
-Resource/SubstCID/GB1-WMode<br>
-Resource/SubstCID/Japan1-WMode<br>
-Resource/SubstCID/Korea1-WMode<br>
-arch/arch_autoconf.h.in<br>
-arch/windows-arm-msvc.h<br>
-arch/windows-x64-msvc.h<br>
-arch/windows-x86-msvc.h<br>
-base/all-arch.mak<br>
-base/assert_.h<br>
-base/bench.c<br>
-base/bobbin.c<br>
-base/bobbin.h<br>
-base/claptrap-init.c<br>
-base/claptrap-planar.c<br>
-base/claptrap.c<br>
-base/claptrap.h<br>
-base/ctype_.h<br>
-base/dirent_.h<br>
-base/dos_.h<br>
-base/echogs.c<br>
-base/errno_.h<br>
-base/expat.mak<br>
-base/fapi_bs.mak<br>
-base/fapi_ft.c<br>
-base/fapibstm.c<br>
-base/fapiufst.c<br>
-base/fcntl_.h<br>
-base/freetype.mak<br>
-base/gconf.c<br>
-base/gconf.h<br>
-base/gdbflags.h<br>
-base/gdebug.h<br>
-base/gdevabuf.c<br>
-base/gdevbbox.c<br>
-base/gdevbbox.h<br>
-base/gdevdbit.c<br>
-base/gdevdcrd.c<br>
-base/gdevdcrd.h<br>
-base/gdevddrw.c<br>
-base/gdevddrw.h<br>
-base/gdevdevn.c<br>
-base/gdevdevn.h<br>
-base/gdevdevnprn.h<br>
-base/gdevdflt.c<br>
-base/gdevdgbr.c<br>
-base/gdevdrop.c<br>
-base/gdevdsha.c<br>
-base/gdevemap.c<br>
-base/gdevflp.c<br>
-base/gdevflp.h<br>
-base/gdevhit.c<br>
-base/gdevkrnlsclass.c<br>
-base/gdevkrnlsclass.h<br>
-base/gdevm1.c<br>
-base/gdevm16.c<br>
-base/gdevm2.c<br>
-base/gdevm24.c<br>
-base/gdevm32.c<br>
-base/gdevm4.c<br>
-base/gdevm40.c<br>
-base/gdevm48.c<br>
-base/gdevm56.c<br>
-base/gdevm64.c<br>
-base/gdevm8.c<br>
-base/gdevmem.c<br>
-base/gdevmem.h<br>
-base/gdevmpla.c<br>
-base/gdevmpla.h<br>
-base/gdevmplt.c<br>
-base/gdevmplt.h<br>
-base/gdevmr1.c<br>
-base/gdevmr2n.c<br>
-base/gdevmr8n.c<br>
-base/gdevmrop.h<br>
-base/gdevmrun.c<br>
-base/gdevmrun.h<br>
-base/gdevmx.c<br>
-base/gdevnfwd.c<br>
-base/gdevoflt.c<br>
-base/gdevoflt.h<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gdevpccm.c<br>
-base/gdevpccm.h<br>
-base/gdevpipe.c<br>
-base/gdevplnx.c<br>
-base/gdevplnx.h<br>
-base/gdevppla.c<br>
-base/gdevppla.h<br>
-base/gdevprn.c<br>
-base/gdevprn.h<br>
-base/gdevpxat.h<br>
-base/gdevpxen.h<br>
-base/gdevpxop.h<br>
-base/gdevrops.c<br>
-base/gdevsclass.c<br>
-base/gdevsclass.h<br>
-base/gdevvec.c<br>
-base/gdevvec.h<br>
-base/gen_ordered.c<br>
-base/gen_ordered.h<br>
-base/genarch.c<br>
-base/genconf.c<br>
-base/gendev.c<br>
-base/genht.c<br>
-base/gp.h<br>
-base/gp_dosfe.c<br>
-base/gp_dosfs.c<br>
-base/gp_dvx.c<br>
-base/gp_getnv.c<br>
-base/gp_mktmp.c<br>
-base/gp_msdll.c<br>
-base/gp_msdos.c<br>
-base/gp_mshdl.c<br>
-base/gp_mslib.c<br>
-base/gp_mspol.c<br>
-base/gp_msprn.c<br>
-base/gp_mswin.c<br>
-base/gp_mswin.h<br>
-base/gp_nsync.c<br>
-base/gp_ntfs.c<br>
-base/gp_nxpsprn.c<br>
-base/gp_os2.c<br>
-base/gp_os2.h<br>
-base/gp_os2fs.c<br>
-base/gp_os2pr.c<br>
-base/gp_os9.c<br>
-base/gp_paper.c<br>
-base/gp_psync.c<br>
-base/gp_stdia.c<br>
-base/gp_stdin.c<br>
-base/gp_strdl.c<br>
-base/gp_sysv.c<br>
-base/gp_unifn.c<br>
-base/gp_unifs.c<br>
-base/gp_unix.c<br>
-base/gp_upapr.c<br>
-base/gp_vms.c<br>
-base/gp_wgetv.c<br>
-base/gp_win32.c<br>
-base/gp_wpapr.c<br>
-base/gp_wsync.c<br>
-base/gp_wutf8.c<br>
-base/gp_wxpsprn.cpp<br>
-base/gpcheck.h<br>
-base/gpgetenv.h<br>
-base/gpmisc.c<br>
-base/gpmisc.h<br>
-base/gpsync.h<br>
-base/gs.mak<br>
-base/gs_dll_call.h<br>
-base/gs_mgl_e.h<br>
-base/gs_mro_e.h<br>
-base/gsalloc.c<br>
-base/gsalloc.h<br>
-base/gsalpha.c<br>
-base/gsalpha.h<br>
-base/gsalphac.c<br>
-base/gsalphac.h<br>
-base/gsargs.c<br>
-base/gsargs.h<br>
-base/gsbitcom.c<br>
-base/gsbitmap.h<br>
-base/gsbitops.c<br>
-base/gsbitops.h<br>
-base/gsbittab.c<br>
-base/gsbittab.h<br>
-base/gsccode.h<br>
-base/gsccolor.h<br>
-base/gscdef.c<br>
-base/gscdefs.h<br>
-base/gscdevn.c<br>
-base/gscdevn.h<br>
-base/gscedata.c<br>
-base/gscedata.h<br>
-base/gscencs.c<br>
-base/gscencs.h<br>
-base/gschar.c<br>
-base/gschar.h<br>
-base/gschar0.c<br>
-base/gscicach.c<br>
-base/gscicach.h<br>
-base/gscie.c<br>
-base/gscie.h<br>
-base/gsciemap.c<br>
-base/gscindex.h<br>
-base/gsclipsr.c<br>
-base/gsclipsr.h<br>
-base/gscms.h<br>
-base/gscolor.c<br>
-base/gscolor.h<br>
-base/gscolor1.c<br>
-base/gscolor1.h<br>
-base/gscolor2.c<br>
-base/gscolor2.h<br>
-base/gscolor3.c<br>
-base/gscolor3.h<br>
-base/gscompt.h<br>
-base/gscoord.c<br>
-base/gscoord.h<br>
-base/gscparam.c<br>
-base/gscpixel.c<br>
-base/gscpixel.h<br>
-base/gscpm.h<br>
-base/gscrd.c<br>
-base/gscrd.h<br>
-base/gscrdp.c<br>
-base/gscrdp.h<br>
-base/gscrypt1.c<br>
-base/gscrypt1.h<br>
-base/gscscie.c<br>
-base/gscsel.h<br>
-base/gscsepr.c<br>
-base/gscsepr.h<br>
-base/gscspace.c<br>
-base/gscspace.h<br>
-base/gscssub.c<br>
-base/gscssub.h<br>
-base/gsdcolor.h<br>
-base/gsdevice.c<br>
-base/gsdevice.h<br>
-base/gsdevmem.c<br>
-base/gsdfilt.c<br>
-base/gsdfilt.h<br>
-base/gsdll.h<br>
-base/gsdllwin.h<br>
-base/gsdparam.c<br>
-base/gsdpnext.h<br>
-base/gsdps.c<br>
-base/gsdps.h<br>
-base/gsdps1.c<br>
-base/gsdsrc.c<br>
-base/gsdsrc.h<br>
-base/gsequivc.c<br>
-base/gsequivc.h<br>
-base/gserrors.h<br>
-base/gsexit.h<br>
-base/gsfcid.c<br>
-base/gsfcid2.c<br>
-base/gsfcmap.c<br>
-base/gsfcmap.h<br>
-base/gsfcmap1.c<br>
-base/gsflip.c<br>
-base/gsflip.h<br>
-base/gsfname.c<br>
-base/gsfname.h<br>
-base/gsfont.c<br>
-base/gsfont.h<br>
-base/gsfont0.c<br>
-base/gsfont0c.c<br>
-base/gsform1.h<br>
-base/gsfunc.c<br>
-base/gsfunc.h<br>
-base/gsfunc0.c<br>
-base/gsfunc0.h<br>
-base/gsfunc3.c<br>
-base/gsfunc3.h<br>
-base/gsfunc4.c<br>
-base/gsfunc4.h<br>
-base/gsgc.h<br>
-base/gsgcache.c<br>
-base/gsgcache.h<br>
-base/gsgdata.c<br>
-base/gsgdata.h<br>
-base/gsgstate.c<br>
-base/gshsb.c<br>
-base/gshsb.h<br>
-base/gsht.c<br>
-base/gsht.h<br>
-base/gsht1.c<br>
-base/gsht1.h<br>
-base/gshtscr.c<br>
-base/gshtx.c<br>
-base/gshtx.h<br>
-base/gsicc.c<br>
-base/gsicc.h<br>
-base/gsicc_cache.c<br>
-base/gsicc_cache.h<br>
-base/gsicc_cms.h<br>
-base/gsicc_create.c<br>
-base/gsicc_create.h<br>
-base/gsicc_lcms2.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_profilecache.c<br>
-base/gsicc_profilecache.h<br>
-base/gsicc_replacecm.c<br>
-base/gsimage.c<br>
-base/gsimage.h<br>
-base/gsimpath.c<br>
-base/gsinit.c<br>
-base/gsio.h<br>
-base/gsiodev.c<br>
-base/gsiodevs.c<br>
-base/gsiodisk.c<br>
-base/gsioram.c<br>
-base/gsiorom.c<br>
-base/gsiorom.h<br>
-base/gsipar3x.h<br>
-base/gsiparam.h<br>
-base/gsiparm2.h<br>
-base/gsiparm3.h<br>
-base/gsiparm4.h<br>
-base/gsjconf.h<br>
-base/gsjmorec.h<br>
-base/gslib.c<br>
-base/gslib.h<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-base/gsline.c<br>
-base/gsline.h<br>
-base/gslparam.h<br>
-base/gsmalloc.c<br>
-base/gsmalloc.h<br>
-base/gsmatrix.c<br>
-base/gsmatrix.h<br>
-base/gsmchunk.c<br>
-base/gsmchunk.h<br>
-base/gsmd5.c<br>
-base/gsmd5.h<br>
-base/gsmdebug.h<br>
-base/gsmemory.c<br>
-base/gsmemory.h<br>
-base/gsmemraw.h<br>
-base/gsmemret.c<br>
-base/gsmemret.h<br>
-base/gsmisc.c<br>
-base/gsnamecl.c<br>
-base/gsnamecl.h<br>
-base/gsncdummy.c<br>
-base/gsncdummy.h<br>
-base/gsnogc.c<br>
-base/gsnogc.h<br>
-base/gsnotify.c<br>
-base/gsnotify.h<br>
-base/gsovrc.c<br>
-base/gsovrc.h<br>
-base/gspaint.c<br>
-base/gspaint.h<br>
-base/gsparam.c<br>
-base/gsparam.h<br>
-base/gsparam2.c<br>
-base/gsparams.c<br>
-base/gsparams.h<br>
-base/gsparamx.c<br>
-base/gsparamx.h<br>
-base/gspath.c<br>
-base/gspath.h<br>
-base/gspath1.c<br>
-base/gspath2.h<br>
-base/gspcolor.c<br>
-base/gspcolor.h<br>
-base/gspenum.h<br>
-base/gspmdrv.c<br>
-base/gspmdrv.h<br>
-base/gspmdrv.rc<br>
-base/gsptype1.c<br>
-base/gsptype1.h<br>
-base/gsptype2.c<br>
-base/gsptype2.h<br>
-base/gsrect.h<br>
-base/gsrefct.h<br>
-base/gsromfs0.c<br>
-base/gsrop.c<br>
-base/gsrop.h<br>
-base/gsroprun.c<br>
-base/gsroprun1.h<br>
-base/gsroprun24.h<br>
-base/gsroprun8.h<br>
-base/gsropt.h<br>
-base/gsroptab.c<br>
-base/gsserial.c<br>
-base/gsserial.h<br>
-base/gsshade.c<br>
-base/gsshade.h<br>
-base/gssprintf.h<br>
-base/gsstate.c<br>
-base/gsstate.h<br>
-base/gsstrl.h<br>
-base/gsstrtok.h<br>
-base/gsstruct.h<br>
-base/gsstype.h<br>
-base/gstext.c<br>
-base/gstext.h<br>
-base/gstiffio.c<br>
-base/gstiffio.h<br>
-base/gstparam.h<br>
-base/gstrans.c<br>
-base/gstrans.h<br>
-base/gstrap.c<br>
-base/gstrap.h<br>
-base/gstype1.c<br>
-base/gstype1.h<br>
-base/gstype2.c<br>
-base/gstype42.c<br>
-base/gstypes.h<br>
-base/gsuid.h<br>
-base/gsutil.c<br>
-base/gsutil.h<br>
-base/gswin.rc<br>
-base/gsxfont.h<br>
-base/gx.h<br>
-base/gxacpath.c<br>
-base/gxalloc.h<br>
-base/gxalpha.h<br>
-base/gxarith.h<br>
-base/gxband.h<br>
-base/gxbcache.c<br>
-base/gxbcache.h<br>
-base/gxbitfmt.h<br>
-base/gxbitmap.h<br>
-base/gxbitops.h<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-base/gxccache.c<br>
-base/gxccman.c<br>
-base/gxcdevn.h<br>
-base/gxchar.c<br>
-base/gxchar.h<br>
-base/gxchrout.c<br>
-base/gxchrout.h<br>
-base/gxcht.c<br>
-base/gxcid.h<br>
-base/gxcie.h<br>
-base/gxcindex.h<br>
-base/gxclbits.c<br>
-base/gxcldev.h<br>
-base/gxclfile.c<br>
-base/gxclimag.c<br>
-base/gxclio.h<br>
-base/gxclip.c<br>
-base/gxclip.h<br>
-base/gxclip2.c<br>
-base/gxclip2.h<br>
-base/gxclipm.c<br>
-base/gxclipm.h<br>
-base/gxclipsr.h<br>
-base/gxclist.c<br>
-base/gxclist.h<br>
-base/gxcllzw.c<br>
-base/gxclmem.c<br>
-base/gxclmem.h<br>
-base/gxclpage.c<br>
-base/gxclpage.h<br>
-base/gxclpath.c<br>
-base/gxclpath.h<br>
-base/gxclrast.c<br>
-base/gxclread.c<br>
-base/gxclrect.c<br>
-base/gxclthrd.c<br>
-base/gxclthrd.h<br>
-base/gxclutil.c<br>
-base/gxclzlib.c<br>
-base/gxcmap.c<br>
-base/gxcmap.h<br>
-base/gxcolor2.h<br>
-base/gxcomp.h<br>
-base/gxcoord.h<br>
-base/gxcpath.c<br>
-base/gxcpath.h<br>
-base/gxcspace.h<br>
-base/gxctable.c<br>
-base/gxctable.h<br>
-base/gxcvalue.h<br>
-base/gxdcconv.c<br>
-base/gxdcconv.h<br>
-base/gxdcolor.c<br>
-base/gxdcolor.h<br>
-base/gxdda.h<br>
-base/gxdevbuf.h<br>
-base/gxdevcli.h<br>
-base/gxdevice.h<br>
-base/gxdevmem.h<br>
-base/gxdevndi.c<br>
-base/gxdevndi.h<br>
-base/gxdevrop.h<br>
-base/gxdevsop.h<br>
-base/gxdht.h<br>
-base/gxdhtres.h<br>
-base/gxdhtserial.c<br>
-base/gxdhtserial.h<br>
-base/gxdither.h<br>
-base/gxdownscale.c<br>
-base/gxdownscale.h<br>
-base/gxdtfill.h<br>
-base/gxfapi.c<br>
-base/gxfapi.h<br>
-base/gxfapiu.c<br>
-base/gxfapiu.h<br>
-base/gxfarith.h<br>
-base/gxfcache.h<br>
-base/gxfcid.h<br>
-base/gxfcmap.h<br>
-base/gxfcmap1.h<br>
-base/gxfill.c<br>
-base/gxfill.h<br>
-base/gxfillsl.h<br>
-base/gxfilltr.h<br>
-base/gxfillts.h<br>
-base/gxfixed.h<br>
-base/gxfmap.h<br>
-base/gxfont.h<br>
-base/gxfont0.h<br>
-base/gxfont0c.h<br>
-base/gxfont1.h<br>
-base/gxfont42.h<br>
-base/gxfrac.h<br>
-base/gxftype.h<br>
-base/gxfunc.h<br>
-base/gxgetbit.h<br>
-base/gxgstate.h<br>
-base/gxhintn.c<br>
-base/gxhintn.h<br>
-base/gxhintn1.c<br>
-base/gxhldevc.c<br>
-base/gxhldevc.h<br>
-base/gxht.c<br>
-base/gxht.h<br>
-base/gxht_thresh.c<br>
-base/gxht_thresh.h<br>
-base/gxhtbit.c<br>
-base/gxhttile.h<br>
-base/gxhttype.h<br>
-base/gxi12bit.c<br>
-base/gxi16bit.c<br>
-base/gxiclass.h<br>
-base/gxicolor.c<br>
-base/gxidata.c<br>
-base/gxifast.c<br>
-base/gximag3x.c<br>
-base/gximag3x.h<br>
-base/gximage.c<br>
-base/gximage.h<br>
-base/gximage1.c<br>
-base/gximage2.c<br>
-base/gximage3.c<br>
-base/gximage3.h<br>
-base/gximage4.c<br>
-base/gximask.c<br>
-base/gximask.h<br>
-base/gximdecode.c<br>
-base/gximdecode.h<br>
-base/gximono.c<br>
-base/gxiodev.h<br>
-base/gxiparam.h<br>
-base/gxipixel.c<br>
-base/gxiscale.c<br>
-base/gxline.h<br>
-base/gxlum.h<br>
-base/gxmatrix.h<br>
-base/gxmclip.c<br>
-base/gxmclip.h<br>
-base/gxobj.h<br>
-base/gxoprect.c<br>
-base/gxoprect.h<br>
-base/gxp1fill.c<br>
-base/gxp1impl.h<br>
-base/gxpaint.c<br>
-base/gxpaint.h<br>
-base/gxpath.c<br>
-base/gxpath.h<br>
-base/gxpath2.c<br>
-base/gxpcache.h<br>
-base/gxpcmap.c<br>
-base/gxpcolor.h<br>
-base/gxpcopy.c<br>
-base/gxpdash.c<br>
-base/gxpflat.c<br>
-base/gxrplane.h<br>
-base/gxsample.c<br>
-base/gxsample.h<br>
-base/gxsamplp.h<br>
-base/gxscanc.c<br>
-base/gxscanc.h<br>
-base/gxshade.c<br>
-base/gxshade.h<br>
-base/gxshade1.c<br>
-base/gxshade4.c<br>
-base/gxshade4.h<br>
-base/gxshade6.c<br>
-base/gxstate.h<br>
-base/gxstdio.h<br>
-base/gxstroke.c<br>
-base/gxsync.c<br>
-base/gxsync.h<br>
-base/gxtext.h<br>
-base/gxtmap.h<br>
-base/gxttf.h<br>
-base/gxttfb.c<br>
-base/gxttfb.h<br>
-base/gxtype1.c<br>
-base/gxtype1.h<br>
-base/gxxfont.h<br>
-base/gzacpath.h<br>
-base/gzcpath.h<br>
-base/gzht.h<br>
-base/gzline.h<br>
-base/gzpath.h<br>
-base/gzspotan.c<br>
-base/gzspotan.h<br>
-base/gzstate.h<br>
-base/ijs.mak<br>
-base/instcopy<br>
-base/jbig2.mak<br>
-base/jerror_.h<br>
-base/jmemcust.c<br>
-base/jmemcust.h<br>
-base/jpeg.mak<br>
-base/jpegxr.mak<br>
-base/lcms2.mak<br>
-base/lcms2art.mak<br>
-base/lcups.mak<br>
-base/lcupsi.mak<br>
-base/ldf_jb2.mak<br>
-base/lib.mak<br>
-base/locale_.h<br>
-base/lwf_jp2.mak<br>
-base/malloc_.h<br>
-base/math_.h<br>
-base/md5main.c<br>
-base/memento.c<br>
-base/memento.h<br>
-base/memory_.h<br>
-base/mkromfs.c<br>
-base/msvccmd.mak<br>
-base/msvclib.mak<br>
-base/msvctail.mak<br>
-base/openjpeg.mak<br>
-base/openvms.mak<br>
-base/openvms.mmk<br>
-base/pack_ps.c<br>
-base/pcwin.mak<br>
-base/pipe_.h<br>
-base/png.mak<br>
-base/png_.h<br>
-base/ramfs.c<br>
-base/ramfs.h<br>
-base/sa85d.c<br>
-base/sa85d.h<br>
-base/sa85x.h<br>
-base/saes.c<br>
-base/saes.h<br>
-base/sarc4.c<br>
-base/sarc4.h<br>
-base/sbcp.c<br>
-base/sbcp.h<br>
-base/sbtx.h<br>
-base/scanchar.h<br>
-base/scantab.c<br>
-base/scf.h<br>
-base/scfd.c<br>
-base/scfdgen.c<br>
-base/scfdtab.c<br>
-base/scfe.c<br>
-base/scfetab.c<br>
-base/scfparam.c<br>
-base/scfx.h<br>
-base/scommon.h<br>
-base/sdcparam.c<br>
-base/sdcparam.h<br>
-base/sdct.h<br>
-base/sdctc.c<br>
-base/sdctd.c<br>
-base/sdcte.c<br>
-base/sddparam.c<br>
-base/sdeparam.c<br>
-base/seexec.c<br>
-base/setjmp_.h<br>
-base/sfilter.h<br>
-base/sfilter2.c<br>
-base/sfxboth.c<br>
-base/sfxcommon.c<br>
-base/sfxfd.c<br>
-base/sfxstdio.c<br>
-base/shc.c<br>
-base/shc.h<br>
-base/sidscale.c<br>
-base/sidscale.h<br>
-base/siinterp.c<br>
-base/siinterp.h<br>
-base/simscale.c<br>
-base/simscale.h<br>
-base/siscale.c<br>
-base/siscale.h<br>
-base/sisparam.h<br>
-base/sjbig2.c<br>
-base/sjbig2.h<br>
-base/sjbig2_luratech.c<br>
-base/sjbig2_luratech.h<br>
-base/sjpeg.h<br>
-base/sjpegc.c<br>
-base/sjpegd.c<br>
-base/sjpege.c<br>
-base/sjpx_luratech.c<br>
-base/sjpx_luratech.h<br>
-base/sjpx_none.c<br>
-base/sjpx_openjpeg.c<br>
-base/sjpx_openjpeg.h<br>
-base/slzwc.c<br>
-base/slzwd.c<br>
-base/slzwe.c<br>
-base/slzwx.h<br>
-base/smd5.c<br>
-base/smd5.h<br>
-base/smtf.h<br>
-base/spdiff.c<br>
-base/spdiffx.h<br>
-base/spngp.c<br>
-base/spngpx.h<br>
-base/spprint.c<br>
-base/spprint.h<br>
-base/spsdf.c<br>
-base/spsdf.h<br>
-base/spwgd.c<br>
-base/spwgx.h<br>
-base/srdline.h<br>
-base/srld.c<br>
-base/srle.c<br>
-base/srlx.h<br>
-base/ssha2.c<br>
-base/ssha2.h<br>
-base/sstring.c<br>
-base/sstring.h<br>
-base/stat_.h<br>
-base/std.h<br>
-base/stdint_.h<br>
-base/stdio_.h<br>
-base/stdpre.h<br>
-base/stream.c<br>
-base/stream.h<br>
-base/strimpl.h<br>
-base/string_.h<br>
-base/strmio.c<br>
-base/strmio.h<br>
-base/stub.mak<br>
-base/szlibc.c<br>
-base/szlibd.c<br>
-base/szlibe.c<br>
-base/szlibx.h<br>
-base/szlibxx.h<br>
-base/tiff.mak<br>
-base/time_.h<br>
-base/ttcalc.c<br>
-base/ttcalc.h<br>
-base/ttcommon.h<br>
-base/ttconf.h<br>
-base/ttconfig.h<br>
-base/ttfinp.c<br>
-base/ttfinp.h<br>
-base/ttfmain.c<br>
-base/ttfmemd.c<br>
-base/ttfmemd.h<br>
-base/ttfoutl.h<br>
-base/ttfsfnt.h<br>
-base/ttinterp.c<br>
-base/ttinterp.h<br>
-base/ttload.c<br>
-base/ttload.h<br>
-base/ttmisc.h<br>
-base/ttobjs.c<br>
-base/ttobjs.h<br>
-base/tttables.h<br>
-base/tttype.h<br>
-base/tttypes.h<br>
-base/ugcclib.mak<br>
-base/unistd_.h<br>
-base/unix-aux.mak<br>
-base/unix-dll.mak<br>
-base/unix-end.mak<br>
-base/unix-gcc.mak<br>
-base/unixansi.mak<br>
-base/unixhead.mak<br>
-base/unixinst.mak<br>
-base/unixlink.mak<br>
-base/valgrind.h<br>
-base/version.mak<br>
-base/vms_x_fix.h<br>
-base/vmsmath.h<br>
-base/windows_.h<br>
-base/winlib.mak<br>
-base/winplat.mak<br>
-base/winrtsup.cpp<br>
-base/winrtsup.h<br>
-base/wrfont.c<br>
-base/wrfont.h<br>
-base/write_t1.c<br>
-base/write_t1.h<br>
-base/write_t2.c<br>
-base/write_t2.h<br>
-base/x_.h<br>
-base/zlib.mak<br>
-configure.ac<br>
-devices/contrib.mak<br>
-devices/devs.mak<br>
-devices/gdev3852.c<br>
-devices/gdev4081.c<br>
-devices/gdev8510.c<br>
-devices/gdev8bcm.c<br>
-devices/gdev8bcm.h<br>
-devices/gdevatx.c<br>
-devices/gdevbit.c<br>
-devices/gdevbj10.c<br>
-devices/gdevbjc.h<br>
-devices/gdevbjcl.c<br>
-devices/gdevbjcl.h<br>
-devices/gdevbmp.c<br>
-devices/gdevbmp.h<br>
-devices/gdevbmpc.c<br>
-devices/gdevccr.c<br>
-devices/gdevcdj.c<br>
-devices/gdevcfax.c<br>
-devices/gdevcif.c<br>
-devices/gdevclj.c<br>
-devices/gdevcljc.c<br>
-devices/gdevcmykog.c<br>
-devices/gdevcp50.c<br>
-devices/gdevcslw.c<br>
-devices/gdevdfax.c<br>
-devices/gdevdjet.c<br>
-devices/gdevdjtc.c<br>
-devices/gdevdljm.c<br>
-devices/gdevdljm.h<br>
-devices/gdevdm24.c<br>
-devices/gdevdsp.c<br>
-devices/gdevdsp.h<br>
-devices/gdevdsp2.h<br>
-devices/gdevepsc.c<br>
-devices/gdevepsn.c<br>
-devices/gdevescp.c<br>
-devices/gdevfax.c<br>
-devices/gdevfax.h<br>
-devices/gdevfpng.c<br>
-devices/gdevgprf.c<br>
-devices/gdevhl7x.c<br>
-devices/gdevicov.c<br>
-devices/gdevijs.c<br>
-devices/gdevimgn.c<br>
-devices/gdevjbig2.c<br>
-devices/gdevjpeg.c<br>
-devices/gdevjpx.c<br>
-devices/gdevl31s.c<br>
-devices/gdevlbp8.c<br>
-devices/gdevlj56.c<br>
-devices/gdevlp8k.c<br>
-devices/gdevlxm.c<br>
-devices/gdevmeds.c<br>
-devices/gdevmeds.h<br>
-devices/gdevmgr.c<br>
-devices/gdevmgr.h<br>
-devices/gdevmiff.c<br>
-devices/gdevn533.c<br>
-devices/gdevo182.c<br>
-devices/gdevokii.c<br>
-devices/gdevpbm.c<br>
-devices/gdevpcl.c<br>
-devices/gdevpcl.h<br>
-devices/gdevpcx.c<br>
-devices/gdevpe.c<br>
-devices/gdevperm.c<br>
-devices/gdevphex.c<br>
-devices/gdevpjet.c<br>
-devices/gdevplan.c<br>
-devices/gdevplib.c<br>
-devices/gdevplib.h<br>
-devices/gdevpm.h<br>
-devices/gdevpng.c<br>
-devices/gdevpsd.c<br>
-devices/gdevpsd.h<br>
-devices/gdevpsim.c<br>
-devices/gdevpxut.c<br>
-devices/gdevpxut.h<br>
-devices/gdevrinkj.c<br>
-devices/gdevsj48.c<br>
-devices/gdevsnfb.c<br>
-devices/gdevsppr.c<br>
-devices/gdevstc.c<br>
-devices/gdevstc.h<br>
-devices/gdevstc1.c<br>
-devices/gdevstc2.c<br>
-devices/gdevstc3.c<br>
-devices/gdevstc4.c<br>
-devices/gdevtfax.c<br>
-devices/gdevtfax.h<br>
-devices/gdevtfnx.c<br>
-devices/gdevtifs.c<br>
-devices/gdevtifs.h<br>
-devices/gdevtknk.c<br>
-devices/gdevtrac.c<br>
-devices/gdevtsep.c<br>
-devices/gdevupd.c<br>
-devices/gdevwpr2.c<br>
-devices/gdevx.c<br>
-devices/gdevx.h<br>
-devices/gdevxalt.c<br>
-devices/gdevxcf.c<br>
-devices/gdevxcmp.c<br>
-devices/gdevxcmp.h<br>
-devices/gdevxini.c<br>
-devices/gdevxres.c<br>
-devices/gxfcopy.c<br>
-devices/gxfcopy.h<br>
-devices/minftrsz.c<br>
-devices/minftrsz.h<br>
-devices/rinkj/evenbetter-rll.c<br>
-devices/rinkj/evenbetter-rll.h<br>
-devices/rinkj/rinkj-byte-stream.c<br>
-devices/rinkj/rinkj-byte-stream.h<br>
-devices/rinkj/rinkj-config.c<br>
-devices/rinkj/rinkj-config.h<br>
-devices/rinkj/rinkj-device.c<br>
-devices/rinkj/rinkj-device.h<br>
-devices/rinkj/rinkj-dither.c<br>
-devices/rinkj/rinkj-dither.h<br>
-devices/rinkj/rinkj-epson870.c<br>
-devices/rinkj/rinkj-epson870.h<br>
-devices/rinkj/rinkj-screen-eb.c<br>
-devices/rinkj/rinkj-screen-eb.h<br>
-devices/vector/gdevagl.c<br>
-devices/vector/gdevagl.h<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfb.c<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfc.c<br>
-devices/vector/gdevpdfc.h<br>
-devices/vector/gdevpdfd.c<br>
-devices/vector/gdevpdfe.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfg.h<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdfj.c<br>
-devices/vector/gdevpdfk.c<br>
-devices/vector/gdevpdfm.c<br>
-devices/vector/gdevpdfo.c<br>
-devices/vector/gdevpdfo.h<br>
-devices/vector/gdevpdfp.c<br>
-devices/vector/gdevpdfr.c<br>
-devices/vector/gdevpdft.c<br>
-devices/vector/gdevpdfu.c<br>
-devices/vector/gdevpdfv.c<br>
-devices/vector/gdevpdfx.h<br>
-devices/vector/gdevpdt.c<br>
-devices/vector/gdevpdt.h<br>
-devices/vector/gdevpdtb.c<br>
-devices/vector/gdevpdtb.h<br>
-devices/vector/gdevpdtc.c<br>
-devices/vector/gdevpdtd.c<br>
-devices/vector/gdevpdtd.h<br>
-devices/vector/gdevpdte.c<br>
-devices/vector/gdevpdtf.c<br>
-devices/vector/gdevpdtf.h<br>
-devices/vector/gdevpdti.c<br>
-devices/vector/gdevpdti.h<br>
-devices/vector/gdevpdts.c<br>
-devices/vector/gdevpdts.h<br>
-devices/vector/gdevpdtt.c<br>
-devices/vector/gdevpdtt.h<br>
-devices/vector/gdevpdtv.c<br>
-devices/vector/gdevpdtv.h<br>
-devices/vector/gdevpdtw.c<br>
-devices/vector/gdevpdtw.h<br>
-devices/vector/gdevpdtx.h<br>
-devices/vector/gdevpsdf.h<br>
-devices/vector/gdevpsdi.c<br>
-devices/vector/gdevpsdp.c<br>
-devices/vector/gdevpsds.c<br>
-devices/vector/gdevpsds.h<br>
-devices/vector/gdevpsdu.c<br>
-devices/vector/gdevpsf.h<br>
-devices/vector/gdevpsf1.c<br>
-devices/vector/gdevpsf2.c<br>
-devices/vector/gdevpsfm.c<br>
-devices/vector/gdevpsft.c<br>
-devices/vector/gdevpsfu.c<br>
-devices/vector/gdevpsfx.c<br>
-devices/vector/gdevpsu.c<br>
-devices/vector/gdevpsu.h<br>
-devices/vector/gdevpx.c<br>
-devices/vector/gdevtxtw.c<br>
-devices/vector/gdevxps.c<br>
-devices/vector/opdfread.ps<br>
-devices/vector/whitelst.c<br>
-devices/vector/whitelst.h<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/GS9_Color_Management.tex<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/Xfonts.htm<br>
-doc/gdevds32.c<br>
-doc/sample_downscale_device.htm<br>
-doc/thirdparty.htm<br>
-examples/waterfal.ps<br>
-gpdl/gpdl.mak<br>
-gpdl/psi/gpdlpsi.mak<br>
-gpdl/psi/psitop.c<br>
-gpdl/pspcl6_gcc.mak<br>
-gpdl/pspcl6_msvc.mak<br>
-ijs/Makefile.am<br>
-ijs/configure.ac<br>
-ijs/ijs.c<br>
-ijs/ijs.h<br>
-ijs/ijs_client.c<br>
-ijs/ijs_client.h<br>
-ijs/ijs_client_example.c<br>
-ijs/ijs_exec_unix.c<br>
-ijs/ijs_exec_win.c<br>
-ijs/ijs_server.c<br>
-ijs/ijs_server_example.c<br>
-ijs/unistd_.h<br>
-ios/ios_arch-arm.h<br>
-ios/ios_arch-x86.h<br>
-jbig2dec/config_win32.h<br>
-jbig2dec/jbig2.c<br>
-jbig2dec/jbig2.h<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_generic.h<br>
-jbig2dec/jbig2_halftone.c<br>
-jbig2dec/jbig2_halftone.h<br>
-jbig2dec/jbig2_huffman.c<br>
-jbig2dec/jbig2_huffman.h<br>
-jbig2dec/jbig2_hufftab.h<br>
-jbig2dec/jbig2_image.c<br>
-jbig2dec/jbig2_image.h<br>
-jbig2dec/jbig2_image_pbm.c<br>
-jbig2dec/jbig2_image_png.c<br>
-jbig2dec/jbig2_metadata.c<br>
-jbig2dec/jbig2_metadata.h<br>
-jbig2dec/jbig2_mmr.c<br>
-jbig2dec/jbig2_mmr.h<br>
-jbig2dec/jbig2_page.c<br>
-jbig2dec/jbig2_priv.h<br>
-jbig2dec/jbig2_refinement.c<br>
-jbig2dec/jbig2_segment.c<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-jbig2dec/jbig2_symbol_dict.h<br>
-jbig2dec/jbig2_text.c<br>
-jbig2dec/jbig2_text.h<br>
-jbig2dec/jbig2dec.c<br>
-jbig2dec/memcmp.c<br>
-jbig2dec/memento.c<br>
-jbig2dec/memento.h<br>
-jbig2dec/os_types.h<br>
-jbig2dec/pbm2png.c<br>
-lib/FCOfontmap-PCLPS3<br>
-lib/FCOfontmap-PS3<br>
-lib/Fontmap.ATB<br>
-lib/Fontmap.ATM<br>
-lib/Fontmap.OS2<br>
-lib/Fontmap.SGI<br>
-lib/Fontmap.Sol<br>
-lib/Fontmap.URW-136.T1<br>
-lib/Fontmap.URW-136.TT<br>
-lib/Fontmap.Ult<br>
-lib/Fontmap.VMS<br>
-lib/align.ps<br>
-lib/caption.ps<br>
-lib/cat.ps<br>
-lib/cid2code.ps<br>
-lib/docie.ps<br>
-lib/font2pcl.ps<br>
-lib/gs_ce_e.ps<br>
-lib/gs_cmdl.ps<br>
-lib/gs_il2_e.ps<br>
-lib/gs_kanji.ps<br>
-lib/gs_ksb_e.ps<br>
-lib/gs_lgo_e.ps<br>
-lib/gs_lgx_e.ps<br>
-lib/gs_wl1_e.ps<br>
-lib/gs_wl2_e.ps<br>
-lib/gs_wl5_e.ps<br>
-lib/gslp.ps<br>
-lib/gsnup.ps<br>
-lib/image-qa.ps<br>
-lib/jispaper.ps<br>
-lib/lines.ps<br>
-lib/mkcidfm.ps<br>
-lib/pdf2dsc.ps<br>
-lib/pfbtopfa.ps<br>
-lib/ppath.ps<br>
-lib/pphs.ps<br>
-lib/prfont.ps<br>
-lib/ps2ai.ps<br>
-lib/ps2epsi.ps<br>
-lib/rollconv.ps<br>
-lib/stcinfo.ps<br>
-lib/stcolor.ps<br>
-lib/stocht.ps<br>
-lib/traceimg.ps<br>
-lib/traceop.ps<br>
-lib/uninfo.ps<br>
-lib/viewcmyk.ps<br>
-lib/viewgif.ps<br>
-lib/viewjpeg.ps<br>
-lib/viewmiff.ps<br>
-lib/viewpbm.ps<br>
-lib/viewpcx.ps<br>
-lib/viewps2a.ps<br>
-lib/viewpwg.ps<br>
-lib/viewraw.ps<br>
-lib/viewrgb.ps<br>
-lib/winmaps.ps<br>
-lib/zeroline.ps<br>
-pcl/LICENSE<br>
-pcl/pcl/pcbiptrn.c<br>
-pcl/pcl/pcbiptrn.h<br>
-pcl/pcl/pccid.c<br>
-pcl/pcl/pccid.h<br>
-pcl/pcl/pccolor.c<br>
-pcl/pcl/pccoord.h<br>
-pcl/pcl/pccprint.c<br>
-pcl/pcl/pccsbase.c<br>
-pcl/pcl/pccsbase.h<br>
-pcl/pcl/pcdict.h<br>
-pcl/pcl/pcdither.c<br>
-pcl/pcl/pcdither.h<br>
-pcl/pcl/pcdraw.c<br>
-pcl/pcl/pcdraw.h<br>
-pcl/pcl/pcfont.c<br>
-pcl/pcl/pcfont.h<br>
-pcl/pcl/pcfontpg.c<br>
-pcl/pcl/pcfontst.h<br>
-pcl/pcl/pcfrgrnd.c<br>
-pcl/pcl/pcfrgrnd.h<br>
-pcl/pcl/pcfsel.c<br>
-pcl/pcl/pcfsel.h<br>
-pcl/pcl/pcht.c<br>
-pcl/pcl/pcht.h<br>
-pcl/pcl/pcident.c<br>
-pcl/pcl/pcident.h<br>
-pcl/pcl/pcimpl.c<br>
-pcl/pcl/pcindxed.c<br>
-pcl/pcl/pcindxed.h<br>
-pcl/pcl/pcjob.c<br>
-pcl/pcl/pcl.mak<br>
-pcl/pcl/pcl_top.mak<br>
-pcl/pcl/pclookup.c<br>
-pcl/pcl/pclookup.h<br>
-pcl/pcl/pcmacros.c<br>
-pcl/pcl/pcmisc.c<br>
-pcl/pcl/pcmtx3.c<br>
-pcl/pcl/pcmtx3.h<br>
-pcl/pcl/pcommand.c<br>
-pcl/pcl/pcommand.h<br>
-pcl/pcl/pcpage.c<br>
-pcl/pcl/pcpage.h<br>
-pcl/pcl/pcpalet.c<br>
-pcl/pcl/pcpalet.h<br>
-pcl/pcl/pcparam.h<br>
-pcl/pcl/pcparse.c<br>
-pcl/pcl/pcparse.h<br>
-pcl/pcl/pcpatrn.c<br>
-pcl/pcl/pcpatrn.h<br>
-pcl/pcl/pcpattyp.h<br>
-pcl/pcl/pcpatxfm.c<br>
-pcl/pcl/pcpatxfm.h<br>
-pcl/pcl/pcrect.c<br>
-pcl/pcl/pcsfont.c<br>
-pcl/pcl/pcstate.h<br>
-pcl/pcl/pcstatus.c<br>
-pcl/pcl/pcsymbol.c<br>
-pcl/pcl/pcsymbol.h<br>
-pcl/pcl/pctext.c<br>
-pcl/pcl/pctop.c<br>
-pcl/pcl/pctop.h<br>
-pcl/pcl/pctpm.h<br>
-pcl/pcl/pcuptrn.c<br>
-pcl/pcl/pcuptrn.h<br>
-pcl/pcl/pcursor.c<br>
-pcl/pcl/pcursor.h<br>
-pcl/pcl/pcwhtidx.c<br>
-pcl/pcl/pcwhtidx.h<br>
-pcl/pcl/pcxfmst.h<br>
-pcl/pcl/pgchar.c<br>
-pcl/pcl/pgcolor.c<br>
-pcl/pcl/pgconfig.c<br>
-pcl/pcl/pgdraw.c<br>
-pcl/pcl/pgdraw.h<br>
-pcl/pcl/pgfdata.c<br>
-pcl/pcl/pgfdata.h<br>
-pcl/pcl/pgfont.c<br>
-pcl/pcl/pgfont.h<br>
-pcl/pcl/pgframe.c<br>
-pcl/pcl/pggeom.c<br>
-pcl/pcl/pggeom.h<br>
-pcl/pcl/pginit.c<br>
-pcl/pcl/pginit.h<br>
-pcl/pcl/pglabel.c<br>
-pcl/pcl/pglfill.c<br>
-pcl/pcl/pgmand.h<br>
-pcl/pcl/pgmisc.c<br>
-pcl/pcl/pgmisc.h<br>
-pcl/pcl/pgparse.c<br>
-pcl/pcl/pgpoly.c<br>
-pcl/pcl/pgstate.h<br>
-pcl/pcl/pgvector.c<br>
-pcl/pcl/rtgmode.c<br>
-pcl/pcl/rtgmode.h<br>
-pcl/pcl/rtmisc.c<br>
-pcl/pcl/rtmisc.h<br>
-pcl/pcl/rtraster.c<br>
-pcl/pcl/rtraster.h<br>
-pcl/pcl/rtrstcmp.c<br>
-pcl/pcl/rtrstcmp.h<br>
-pcl/pcl/rtrstst.h<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/pjparse.h<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/pjtop.c<br>
-pcl/pl/pjtop.h<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plalloc.c<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plchar.c<br>
-pcl/pl/plchar.h<br>
-pcl/pl/plcursor.c<br>
-pcl/pl/plcursor.h<br>
-pcl/pl/pldebug.h<br>
-pcl/pl/pldict.c<br>
-pcl/pl/pldict.h<br>
-pcl/pl/pldraw.c<br>
-pcl/pl/pldraw.h<br>
-pcl/pl/plfapi.c<br>
-pcl/pl/plfapi.h<br>
-pcl/pl/plfont.c<br>
-pcl/pl/plfont.h<br>
-pcl/pl/plftable.c<br>
-pcl/pl/plftable.h<br>
-pcl/pl/plht.c<br>
-pcl/pl/plht.h<br>
-pcl/pl/plimpl.c<br>
-pcl/pl/pllfont.c<br>
-pcl/pl/pllfont.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pl/plparams.c<br>
-pcl/pl/plparams.h<br>
-pcl/pl/plparse.h<br>
-pcl/pl/plromfs.mak<br>
-pcl/pl/plsymbol.c<br>
-pcl/pl/plsymbol.h<br>
-pcl/pl/pltop.c<br>
-pcl/pl/pltop.h<br>
-pcl/pl/pluchar.c<br>
-pcl/pl/plufont.c<br>
-pcl/pl/plufstlp.c<br>
-pcl/pl/plufstlp.h<br>
-pcl/pl/plufstlp1.c<br>
-pcl/pl/plulfont.c<br>
-pcl/pl/plvalue.c<br>
-pcl/pl/plvalue.h<br>
-pcl/pl/plvocab.c<br>
-pcl/pl/plvocab.h<br>
-pcl/pl/plwimg.c<br>
-pcl/pl/plwimg.h<br>
-pcl/pl/plwmainc.c<br>
-pcl/pl/plwreg.c<br>
-pcl/pl/plwreg.h<br>
-pcl/pl/plwres.h<br>
-pcl/pl/realmain.c<br>
-pcl/pxl/pxasm.ps<br>
-pcl/pxl/pxattr.h<br>
-pcl/pxl/pxbfont.c<br>
-pcl/pxl/pxbfont.h<br>
-pcl/pxl/pxbfont.ps<br>
-pcl/pxl/pxcet.txt<br>
-pcl/pxl/pxdict.h<br>
-pcl/pxl/pxdiff.txt<br>
-pcl/pxl/pxenum.h<br>
-pcl/pxl/pxerrors.c<br>
-pcl/pxl/pxerrors.h<br>
-pcl/pxl/pxffont.c<br>
-pcl/pxl/pxfont.c<br>
-pcl/pxl/pxfont.h<br>
-pcl/pxl/pxfts.txt<br>
-pcl/pxl/pxgstate.c<br>
-pcl/pxl/pxgstate.h<br>
-pcl/pxl/pximage.c<br>
-pcl/pxl/pximpl.c<br>
-pcl/pxl/pxink.c<br>
-pcl/pxl/pxl.mak<br>
-pcl/pxl/pxlib.txt<br>
-pcl/pxl/pxoper.h<br>
-pcl/pxl/pxpaint.c<br>
-pcl/pxl/pxparse.c<br>
-pcl/pxl/pxparse.h<br>
-pcl/pxl/pxptable.c<br>
-pcl/pxl/pxptable.h<br>
-pcl/pxl/pxpthr.c<br>
-pcl/pxl/pxpthr.h<br>
-pcl/pxl/pxsessio.c<br>
-pcl/pxl/pxspec.txt<br>
-pcl/pxl/pxstate.c<br>
-pcl/pxl/pxstate.h<br>
-pcl/pxl/pxstream.c<br>
-pcl/pxl/pxsymbol.ps<br>
-pcl/pxl/pxsymbol.psc<br>
-pcl/pxl/pxsymbol.psh<br>
-pcl/pxl/pxtag.h<br>
-pcl/pxl/pxtop.c<br>
-pcl/pxl/pxvalue.c<br>
-pcl/pxl/pxvalue.h<br>
-pcl/pxl/pxvendor.c<br>
-pcl/pxl/pxvendor.h<br>
-pcl/tools/cmpi/cmpi.cpp<br>
-pcl/tools/pxlasm.py<br>
-pcl/tools/pxldis.py<br>
-pcl/tools/suite.tcl<br>
-psi/bfont.h<br>
-psi/btoken.h<br>
-psi/dmmain.c<br>
-psi/dmmain.r<br>
-psi/dpmain.c<br>
-psi/dscparse.c<br>
-psi/dscparse.h<br>
-psi/dstack.h<br>
-psi/dwdll.c<br>
-psi/dwdll.h<br>
-psi/dwimg.c<br>
-psi/dwimg.h<br>
-psi/dwmain.c<br>
-psi/dwmain.rc<br>
-psi/dwmainc.c<br>
-psi/dwnodll.c<br>
-psi/dwreg.c<br>
-psi/dwreg.h<br>
-psi/dwres.h<br>
-psi/dwtext.c<br>
-psi/dwtext.h<br>
-psi/dwtrace.c<br>
-psi/dwtrace.h<br>
-psi/dxmain.c<br>
-psi/dxmainc.c<br>
-psi/estack.h<br>
-psi/files.h<br>
-psi/ghost.h<br>
-psi/gs.c<br>
-psi/gsdll.c<br>
-psi/gsdll2.rc<br>
-psi/gsdll32.rc<br>
-psi/gserver.c<br>
-psi/gsos2.rc<br>
-psi/ialloc.c<br>
-psi/ialloc.h<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-psi/iastate.h<br>
-psi/iastruct.h<br>
-psi/ibnum.c<br>
-psi/ibnum.h<br>
-psi/ichar.h<br>
-psi/ichar1.h<br>
-psi/icharout.h<br>
-psi/icid.h<br>
-psi/icie.h<br>
-psi/icolor.h<br>
-psi/iconf.c<br>
-psi/iconf.h<br>
-psi/icontext.c<br>
-psi/icontext.h<br>
-psi/icremap.h<br>
-psi/icsmap.h<br>
-psi/icstate.h<br>
-psi/iddict.h<br>
-psi/iddstack.h<br>
-psi/idebug.c<br>
-psi/idebug.h<br>
-psi/idict.c<br>
-psi/idict.h<br>
-psi/idictdef.h<br>
-psi/idicttpl.h<br>
-psi/idisp.c<br>
-psi/idisp.h<br>
-psi/idosave.h<br>
-psi/idparam.c<br>
-psi/idparam.h<br>
-psi/idsdata.h<br>
-psi/idstack.c<br>
-psi/idstack.h<br>
-psi/ierrors.h<br>
-psi/iesdata.h<br>
-psi/iestack.h<br>
-psi/ifapi.h<br>
-psi/ifcid.h<br>
-psi/ifilter.h<br>
-psi/ifilter2.h<br>
-psi/ifont.h<br>
-psi/ifont1.h<br>
-psi/ifont2.h<br>
-psi/ifont42.h<br>
-psi/ifrpred.h<br>
-psi/ifunc.h<br>
-psi/ifwpred.h<br>
-psi/igc.c<br>
-psi/igc.h<br>
-psi/igcref.c<br>
-psi/igcstr.c<br>
-psi/igcstr.h<br>
-psi/igstate.h<br>
-psi/iht.h<br>
-psi/iimage.h<br>
-psi/iimage2.h<br>
-psi/iinit.c<br>
-psi/iinit.h<br>
-psi/ilevel.h<br>
-psi/ilocate.c<br>
-psi/imain.c<br>
-psi/imain.h<br>
-psi/imainarg.c<br>
-psi/imainarg.h<br>
-psi/imemory.h<br>
-psi/iminst.h<br>
-psi/iname.c<br>
-psi/iname.h<br>
-psi/inamedef.h<br>
-psi/inameidx.h<br>
-psi/inames.h<br>
-psi/inamestr.h<br>
-psi/inobtokn.c<br>
-psi/inouparm.c<br>
-psi/int.mak<br>
-psi/interp.c<br>
-psi/interp.h<br>
-psi/iosdata.h<br>
-psi/iostack.h<br>
-psi/ipacked.h<br>
-psi/iparam.c<br>
-psi/iparam.h<br>
-psi/iparray.h<br>
-psi/ipcolor.h<br>
-psi/iplugin.c<br>
-psi/iplugin.h<br>
-psi/ireclaim.c<br>
-psi/iref.h<br>
-psi/isave.c<br>
-psi/isave.h<br>
-psi/iscan.c<br>
-psi/iscan.h<br>
-psi/iscanbin.c<br>
-psi/iscanbin.h<br>
-psi/iscannum.c<br>
-psi/iscannum.h<br>
-psi/isdata.h<br>
-psi/isstate.h<br>
-psi/istack.c<br>
-psi/istack.h<br>
-psi/istkparm.h<br>
-psi/istream.h<br>
-psi/istruct.h<br>
-psi/itoken.h<br>
-psi/iutil.c<br>
-psi/iutil.h<br>
-psi/iutil2.c<br>
-psi/iutil2.h<br>
-psi/ivmem2.h<br>
-psi/ivmspace.h<br>
-psi/main.h<br>
-psi/mkfilelt.cpp<br>
-psi/msvc.mak<br>
-psi/msvc32.mak<br>
-psi/msvc64.mak<br>
-psi/nsisinst.nsi<br>
-psi/oparc.h<br>
-psi/opcheck.h<br>
-psi/opdef.h<br>
-psi/oper.h<br>
-psi/opextern.h<br>
-psi/os2.mak<br>
-psi/ostack.h<br>
-psi/psromfs.mak<br>
-psi/sfilter1.c<br>
-psi/store.h<br>
-psi/winint.mak<br>
-psi/zalg.c<br>
-psi/zarith.c<br>
-psi/zarray.c<br>
-psi/zbfont.c<br>
-psi/zbseq.c<br>
-psi/zcfont.c<br>
-psi/zchar.c<br>
-psi/zchar1.c<br>
-psi/zchar2.c<br>
-psi/zchar32.c<br>
-psi/zchar42.c<br>
-psi/zchar42.h<br>
-psi/zcharout.c<br>
-psi/zcharx.c<br>
-psi/zcid.c<br>
-psi/zcie.c<br>
-psi/zcie.h<br>
-psi/zcolor.c<br>
-psi/zcolor.h<br>
-psi/zcolor1.c<br>
-psi/zcolor2.c<br>
-psi/zcolor3.c<br>
-psi/zcontext.c<br>
-psi/zcontrol.c<br>
-psi/zcrd.c<br>
-psi/zcsindex.c<br>
-psi/zcspixel.c<br>
-psi/zcssepr.c<br>
-psi/zdevcal.c<br>
-psi/zdevice.c<br>
-psi/zdevice2.c<br>
-psi/zdfilter.c<br>
-psi/zdict.c<br>
-psi/zdouble.c<br>
-psi/zdpnext.c<br>
-psi/zdps.c<br>
-psi/zdps1.c<br>
-psi/zdscpars.c<br>
-psi/zfaes.c<br>
-psi/zfapi.c<br>
-psi/zfarc4.c<br>
-psi/zfbcp.c<br>
-psi/zfcid.c<br>
-psi/zfcid0.c<br>
-psi/zfcid1.c<br>
-psi/zfcmap.c<br>
-psi/zfdctd.c<br>
-psi/zfdcte.c<br>
-psi/zfdecode.c<br>
-psi/zfile.c<br>
-psi/zfile.h<br>
-psi/zfile1.c<br>
-psi/zfileio.c<br>
-psi/zfilter.c<br>
-psi/zfilter2.c<br>
-psi/zfimscale.c<br>
-psi/zfjbig2.c<br>
-psi/zfjpx.c<br>
-psi/zfmd5.c<br>
-psi/zfont.c<br>
-psi/zfont0.c<br>
-psi/zfont1.c<br>
-psi/zfont2.c<br>
-psi/zfont32.c<br>
-psi/zfont42.c<br>
-psi/zfontenum.c<br>
-psi/zform.c<br>
-psi/zfproc.c<br>
-psi/zfrsd.c<br>
-psi/zfrsd.h<br>
-psi/zfsample.c<br>
-psi/zfsha2.c<br>
-psi/zfunc.c<br>
-psi/zfunc.h<br>
-psi/zfunc0.c<br>
-psi/zfunc3.c<br>
-psi/zfunc4.c<br>
-psi/zfzlib.c<br>
-psi/zgeneric.c<br>
-psi/zgstate.c<br>
-psi/zhsb.c<br>
-psi/zht.c<br>
-psi/zht1.c<br>
-psi/zht2.c<br>
-psi/zht2.h<br>
-psi/zicc.c<br>
-psi/zicc.h<br>
-psi/zimage.c<br>
-psi/zimage2.c<br>
-psi/zimage3.c<br>
-psi/ziodev.c<br>
-psi/ziodev2.c<br>
-psi/ziodevs.c<br>
-psi/ziodevsc.c<br>
-psi/zmath.c<br>
-psi/zmatrix.c<br>
-psi/zmedia2.c<br>
-psi/zmisc.c<br>
-psi/zmisc1.c<br>
-psi/zmisc2.c<br>
-psi/zmisc3.c<br>
-psi/zncdummy.c<br>
-psi/zpacked.c<br>
-psi/zpaint.c<br>
-psi/zpath.c<br>
-psi/zpath1.c<br>
-psi/zpcolor.c<br>
-psi/zpdf_r6.c<br>
-psi/zpdfops.c<br>
-psi/zrelbit.c<br>
-psi/zshade.c<br>
-psi/zstack.c<br>
-psi/zstring.c<br>
-psi/zsysvm.c<br>
-psi/ztoken.c<br>
-psi/ztrans.c<br>
-psi/ztrap.c<br>
-psi/ztype.c<br>
-psi/zupath.c<br>
-psi/zusparam.c<br>
-psi/zutf8.c<br>
-psi/zvmem.c<br>
-psi/zvmem2.c<br>
-psi/zwinutf8.c<br>
-toolbin/GenSubstCID.ps<br>
-toolbin/afmutil.py<br>
-toolbin/color/icc_creator/ICC_Creator/CIELAB.h<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_Creator.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_Creator.h<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.h<br>
-toolbin/color/icc_creator/ICC_Creator/icc_create.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/icc_create.h<br>
-toolbin/color/icc_creator/README.txt<br>
-toolbin/encs2c.ps<br>
-toolbin/errlist.tcl<br>
-toolbin/extractFonts.ps<br>
-toolbin/extractICCprofiles.ps<br>
-toolbin/gen_ldf_jb2.py<br>
-toolbin/genfontmap.ps<br>
-toolbin/gitlog2changelog.py<br>
-toolbin/gsmake.tcl<br>
-toolbin/halftone/gen_ordered/README<br>
-toolbin/halftone/gen_ordered/gen_ordered_main.c<br>
-toolbin/halftone/gen_stochastic/gen_stochastic.c<br>
-toolbin/halftone/thresh_remap/thresh_remap.c<br>
-toolbin/headers.tcl<br>
-toolbin/jpxtopdf.c<br>
-toolbin/leaks.tcl<br>
-toolbin/makehist.tcl<br>
-toolbin/memory.py<br>
-toolbin/ocheck.py<br>
-toolbin/pdf_info.ps<br>
-toolbin/pre.tcl<br>
-toolbin/precheck.tcl<br>
-toolbin/split_changelog.py<br>
-toolbin/suite.tcl<br>
-toolbin/tests/build_revision.py<br>
-toolbin/tests/check_all.py<br>
-toolbin/tests/check_comments.py<br>
-toolbin/tests/check_dirs.py<br>
-toolbin/tests/check_docrefs.py<br>
-toolbin/tests/cmpi.py<br>
-toolbin/tests/compare_checksumdb.py<br>
-toolbin/tests/compare_checksums.py<br>
-toolbin/tests/dump_checksum.py<br>
-toolbin/tests/dump_checksum_plus.py<br>
-toolbin/tests/dump_checksum_raw.py<br>
-toolbin/tests/fuzzy.c<br>
-toolbin/tests/get_baseline_log.py<br>
-toolbin/tests/get_baselines.py<br>
-toolbin/tests/gscheck_all.py<br>
-toolbin/tests/gscheck_fuzzypdf.py<br>
-toolbin/tests/gscheck_pdfwrite.py<br>
-toolbin/tests/gscheck_raster.py<br>
-toolbin/tests/gscheck_testfiles.py<br>
-toolbin/tests/gsconf.py<br>
-toolbin/tests/gsparamsets.py<br>
-toolbin/tests/gssum.py<br>
-toolbin/tests/gstestgs.py<br>
-toolbin/tests/gstestutils.py<br>
-toolbin/tests/gsutil.py<br>
-toolbin/tests/make_baselinedb.py<br>
-toolbin/tests/make_testdb.py<br>
-toolbin/tests/make_two_pdfversions<br>
-toolbin/tests/make_two_versions<br>
-toolbin/tests/myoptparse.py<br>
-toolbin/tests/rasterdb.py<br>
-toolbin/tests/revert_baseline<br>
-toolbin/tests/revert_pdfbaseline<br>
-toolbin/tests/run_nightly.py<br>
-toolbin/tests/run_parallel<br>
-toolbin/tests/run_regression.py<br>
-toolbin/tests/testdiff.py<br>
-toolbin/tests/update_baseline.py<br>
-toolbin/tests/update_specific<br>
-toolbin/tmake.tcl<br>
-xps/ghostxps.h<br>
-xps/xps.mak<br>
-xps/xpsanalyze.c<br>
-xps/xpscff.c<br>
-xps/xpscolor.c<br>
-xps/xpscommon.c<br>
-xps/xpscrc.c<br>
-xps/xpsdoc.c<br>
-xps/xpsfapi.c<br>
-xps/xpsfapi.h<br>
-xps/xpsfont.c<br>
-xps/xpsglyphs.c<br>
-xps/xpsgradient.c<br>
-xps/xpshash.c<br>
-xps/xpsimage.c<br>
-xps/xpsjpeg.c<br>
-xps/xpsjxr.c<br>
-xps/xpsmem.c<br>
-xps/xpsopacity.c<br>
-xps/xpspage.c<br>
-xps/xpspath.c<br>
-xps/xpspng.c<br>
-xps/xpsresource.c<br>
-xps/xpsromfs.mak<br>
-xps/xpstiff.c<br>
-xps/xpstile.c<br>
-xps/xpstop.c<br>
-xps/xpsttf.c<br>
-xps/xpsutf.c<br>
-xps/xpsvisual.c<br>
-xps/xpsxml.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-30 08:35:40 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=013b8208180cccf65d3c5ee374b678ceffe39cf7">013b8208180cccf65d3c5ee374b678ceffe39cf7</a>
-<blockquote>
-<p>
- Documentation - restore docs on image-qa.ps<br>
-<br>
- Commit b223c93caa34ad34dfd33d534529b3f11d067aab was slightly over<br>
- enthusiastic and accidentally removed the documentation for the file<br>
- image-qa.ps.<br>
-<br>
- Restore it here.<br>
-<br>
-doc/Psfiles.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-29 12:27: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=ad8f4138ad44647125424aa4b635aade1a2557ad">ad8f4138ad44647125424aa4b635aade1a2557ad</a>
-<blockquote>
-<p>
- Compiler warning in base/gsicc_manage.c<br>
-<br>
- Comparing a pointer to '\0' should be comparing to NULL to check for a valid<br>
- string argument,<br>
-<br>
-base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-29 16:12: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=b223c93caa34ad34dfd33d534529b3f11d067aab">b223c93caa34ad34dfd33d534529b3f11d067aab</a>
-<blockquote>
-<p>
- Documentation - correct erroneous information in psfiles.htm<br>
-<br>
- Psfiles.htm incorrectly listed a number of files as being in 'lib'<br>
- when in fact they have been moved to 'Resource/Init. In addition<br>
- Several files were listed which no longer exist, and some files in<br>
- 'examples' were not listed or described.<br>
-<br>
- I suspect this listing is still not comprehensive, but at I believe<br>
- the information that is there is now at least correct.<br>
-<br>
-doc/Psfiles.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-29 14:05:50 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d8ec036836a0abcfe3cc677bb88a61bdfd1a65bb">d8ec036836a0abcfe3cc677bb88a61bdfd1a65bb</a>
-<blockquote>
-<p>
- pdfwrite - remove a global from gdevpdtt.c<br>
-<br>
-<br>
- See bug #693376<br>
-<br>
- In gdevpdtt.c we hold a static gs_glyph standard_glyph_code_for_notdef<br>
- which is initially assinged to GS_NO_GLYPH, and is later assigned a<br>
- value from the encoding table:<br>
-<br>
- standard_glyph_code_for_notdef =<br>
- gs_c_name_glyph((const byte *)&quot;.notdef&quot;, 7) - gs_c_min_std_encoding_glyph;<br>
-<br>
- However, this is only done if the current value is GS_NO_GLYPH. In effect<br>
- standard_glyph_code_for_notdef is a constant. But we can't define it as<br>
- a constant because the actual value depends on the contents of a table<br>
- which is built at compile time.<br>
-<br>
- This appears to be an attempt to limit the number of times we call<br>
- gs_c_name_glyph because that is a relatively expensive operation, and<br>
- the actual value returned never changes between builds.<br>
-<br>
- But we don't want to have globals, really, so this commit simply gets<br>
- and stores the value when the PDF font resource is created in<br>
- font_resource_alloc(). We then can look up the value when we need it.<br>
-<br>
- This is, obviously, slightly slower than a one-time lookup, because<br>
- we execute it once for every font. It also uses up a fraction more<br>
- memory. However, compared to the performance and memory usage of pdfrwite<br>
- the differences are miniscule.<br>
-<br>
-devices/vector/gdevpdtf.c<br>
-devices/vector/gdevpdtf.h<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-28 10:31:26 +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=e29a7e00401549ebb7c03c8324209489b7c87681">e29a7e00401549ebb7c03c8324209489b7c87681</a>
-<blockquote>
-<p>
- Coverity ID: 259882 Fix typo in pcl_impl_allocate_interp_instance.<br>
-<br>
- Fix typo to allow conditional freeing of pcli-&gt;pcs.pids.<br>
-<br>
-pcl/pcl/pctop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-19 14:28:46 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b155ebd780b5737aac4e8096c8fbaa5cb78212c">2b155ebd780b5737aac4e8096c8fbaa5cb78212c</a>
-<blockquote>
-<p>
- Bug 694260: FAPI: tidy up error return for broken TT glyph<br>
-<br>
- In the event of an error retrieving a TTF glyph, we were storing the negative<br>
- error code in the same variable we use to store the glyph length for a valid<br>
- glyph, which is an unsigned variable, causing a valgrind error, and potential<br>
- security issue reading uninitialized memory.<br>
-<br>
- In fact, other consumers silently cope with this type of problem and<br>
- (presumably) use a notdef glyph instead. So this tweaks the error codes to<br>
- do the same.<br>
-<br>
- Because we now have to differentiate between different types of error, we<br>
- can no longer just use a negative value, so there is an enumerated type for<br>
- the error values.<br>
-<br>
-base/fapi_ft.c<br>
-base/gxfapi.h<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-25 09:28: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=b82848bc26f47b5b5727d24f03d08eb3679c7243">b82848bc26f47b5b5727d24f03d08eb3679c7243</a>
-<blockquote>
-<p>
- Add script and arch*.h headers for ios build<br>
-<br>
- This results in a &quot;fat&quot; libgs.a library which can be linked used either for the<br>
- simulator or a &quot;real&quot; ios build.<br>
-<br>
- Really, this script just automates/simplifies the process of using our existing<br>
- cross-compile support.<br>
-<br>
- The only slightly out of the ordinary part is combining the Intel and arm<br>
- libraries into the single fat library.<br>
-<br>
-configure.ac<br>
-ios/build_ios_gslib.sh<br>
-ios/ios-README.txt<br>
-ios/ios_arch-arm.h<br>
-ios/ios_arch-x86.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-24 19:23:42 +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=83f78ff2c85413866f0d4e549fc6a39aa72417e6">83f78ff2c85413866f0d4e549fc6a39aa72417e6</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in cmsCreateLab2ProfileTHR.<br>
-<br>
- Fix memory leak for allocation event numbers 821 - 854.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=860 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-lcms2art/src/cmsvirt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-24 18:42:46 +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=e8501487c929db1bc1a624bf101a3464b447db07">e8501487c929db1bc1a624bf101a3464b447db07</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in BuildRGBOutputMatrixShaper.<br>
-<br>
- Fix memory leak for allocation event numbers 787 - 792.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=795 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-lcms2art/src/cmsio1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-23 18:10:04 +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=571200a055310b157f3640742f32564fc2de5697">571200a055310b157f3640742f32564fc2de5697</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak c_param_write.<br>
-<br>
- Fix memory leak for allocation event number 676.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=677 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-base/gscparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-23 18:18:49 +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=92ccfa3dcb2ca9fd2273611f7ed2111d3ae319a8">92ccfa3dcb2ca9fd2273611f7ed2111d3ae319a8</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in cmsStageAllocMatrix.<br>
-<br>
- Fix memory leak for allocation event numbers 753 - 754.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=755 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-lcms2art/src/cmslut.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-20 12:30:50 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0c498888ca6c0bdf4b90d1b3a79a4a185d810a22">0c498888ca6c0bdf4b90d1b3a79a4a185d810a22</a>
-<blockquote>
-<p>
- Fix clusterpush detection for mupdf repositories.<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-24 17:02:26 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb6abd533cdfed34d076c3320c931d778189c202">bb6abd533cdfed34d076c3320c931d778189c202</a>
-<blockquote>
-<p>
- Make gitpush.sh script executable.<br>
-<br>
-toolbin/localcluster/gitpush.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-24 15:18:07 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9010c622cd4d17053ee405bb378ed08bcaa16251">9010c622cd4d17053ee405bb378ed08bcaa16251</a>
-<blockquote>
-<p>
- pdfwrite - ensure we have a substream Resource dictionary before using it<br>
-<br>
- Bug #692182 &quot;xps -&gt; pdfwrite SEGVs with softmasked pattern&quot;<br>
-<br>
- After much messing about with this bug over the years, it appears<br>
- that most of the bugs have been fixed. However one still remained;<br>
- we could attempt to add a ProcSet Resource to a substream, even<br>
- though we had not yet allocated a Resource for that substream.<br>
-<br>
- Although it shows up with this file, technically it could<br>
- probably happen with any kind of input.<br>
-<br>
- Fixed here by allocating a substream Resource dictionary if we<br>
- don't already have one when we want to add the Procsets to it.<br>
-<br>
- No differences expected<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-24 09:33:20 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb5f2a85c5c3f6436df6158d7fba1977be68116f">eb5f2a85c5c3f6436df6158d7fba1977be68116f</a>
-<blockquote>
-<p>
- Bug 698903: bounds check t2 charstring stack in op<br>
-<br>
- Add a stack bounds checking macro for the Type 2 charstring stack, and use it<br>
- for the rmoveto op.<br>
-<br>
-base/gstype2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-23 18:15:18 +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=f5e42eb1dc1cc96bab67990e886756a089a3fa5a">f5e42eb1dc1cc96bab67990e886756a089a3fa5a</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in AllocateToneCurveStruct.<br>
-<br>
- Fix memory leak for allocation event number 741.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=742 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-lcms2art/src/cmsgamma.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-23 18:05:54 +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=ebae375c979146fd8c2457e217dcb4e67618a718">ebae375c979146fd8c2457e217dcb4e67618a718</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in gs_copydevice2.<br>
-<br>
- Fix memory leak for allocation event number 673.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=674 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-23 08:49:04 +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=34f29fe8f77a626ef71c1f04fd781dd8b8bacd85">34f29fe8f77a626ef71c1f04fd781dd8b8bacd85</a>
-<blockquote>
-<p>
- Bug 697545 : Fix pxstate memory leak.<br>
-<br>
- Fix memory leak for allocation event numbers 517 - 520.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=578 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-base/gsfont.c<br>
-pcl/pxl/pxstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-23 16:42:34 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2ce962cfc20267b3e678d8d1357dfc2643b7a477">2ce962cfc20267b3e678d8d1357dfc2643b7a477</a>
-<blockquote>
-<p>
- pdfwrite - take advantage of GSUB table glyph substitution enhancement<br>
-<br>
- Bug #691574 &quot;vert punctuation is rotated when convert ps to 1.3 pdf&quot;<br>
-<br>
- Commit 7dd033589ce40649ab602fba4c0473aa40c48439 was an enhancement to<br>
- apply vertical glyph substitution from a TrueType GSUB table. This is<br>
- primarily used when a user specifies a TrueType font to be used as a<br>
- replacement for a missing CIDFont (especially in PDF files). Using a<br>
- horizontal font as a replacement for a vertical font can result in<br>
- punctuation marks at the wrong orientation.<br>
-<br>
- This commit uses the machinery added in that previous commit to apply<br>
- the same fix for pdfwrite. Note that this still does not produce<br>
- 'correct' output, because its still a substitute font being used. It<br>
- does produce punctuation marks at the correct orientation now though,<br>
- for the limited selection of test files we have. The other relevant<br>
- report is 698471, though that was reported against rendering, the same<br>
- effect occurs with pdfwrite.<br>
-<br>
- The cluster shows one diff, a progression, which surprises me since I<br>
- cannot duplicate the reference output, but I'm not going to complain<br>
- since its a progression.<br>
-<br>
-devices/gxfcopy.c<br>
-devices/gxfcopy.h<br>
-devices/vector/gdevpdtb.c<br>
-devices/vector/gdevpdtc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-22 17:14:31 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=de0bad3a42012d57fea6c2d55325c033db7a3ded">de0bad3a42012d57fea6c2d55325c033db7a3ded</a>
-<blockquote>
-<p>
- Fix Bug 698874 - incorrect text positioning.<br>
-<br>
- The bug title is misleading, this a font selection problem where 1 of<br>
- 2 fonts with the same attributes must be selected. Experiments<br>
- suggest the HP chooses the font which was defined earliest. We<br>
- emulate the same effect in our interpreter by creating sequential PJL<br>
- font numbers for downloaded fonts and the selection algorithm<br>
- prefering lower numbers.<br>
-<br>
- Progression with the test file bug690520.pcl.<br>
-<br>
-pcl/pcl/pcfont.c<br>
-pcl/pcl/pcfsel.c<br>
-pcl/pcl/pcsfont.c<br>
-pcl/pcl/pcstate.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-22 11:32:20 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5b6ffad4c3e6d12fbb1caf9d0f17d7de77ca3c3">b5b6ffad4c3e6d12fbb1caf9d0f17d7de77ca3c3</a>
-<blockquote>
-<p>
- Fix rc_increment for CMM_THREAD_SAFE case (only 1 param, not 2)<br>
-<br>
- Thanks to Michael Vrhel for tripping over this first.<br>
-<br>
-base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-20 18:12:08 +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=8089072692df101c5464e67b3c3a2cebf9b6682d">8089072692df101c5464e67b3c3a2cebf9b6682d</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in gstate_free_contents.<br>
-<br>
- Fix memory leak for allocation event numbers 346 - 348.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=349 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-20 13:01:22 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6adaf9b4d691bfec64d6d6888bb4fed776a2da12">6adaf9b4d691bfec64d6d6888bb4fed776a2da12</a>
-<blockquote>
-<p>
- Bug 698867: Don't push texttransparency knockout group for invisible text<br>
-<br>
- The customer's example file had text that was not opaque, but was being<br>
- rendered in TextRenderingMode 3 (invisible). Don't push the extra<br>
- transparency group for this. Reduces time from 483 seconds to 44 seconds<br>
- with default clist params, and with BufferSpace of &gt; 32m down to 14 seconds.<br>
- Also reduces page mode (-dBufferSpace=2000m) from 40 minutes to 9 seconds.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-20 10:55:29 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1bc1bfaf123e866695813895d02da0956f79cb31">1bc1bfaf123e866695813895d02da0956f79cb31</a>
-<blockquote>
-<p>
- Minor fix and addition of debugging info for clist cropping.<br>
-<br>
-base/gxclimag.c<br>
-base/gxclist.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-22 15:20:29 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb5d417375e1c7052aeb9f2532d34573bfd07f53">eb5d417375e1c7052aeb9f2532d34573bfd07f53</a>
-<blockquote>
-<p>
- Feature - JPEG Pass through<br>
-<br>
- This commit adds the capability for the PostScript and PDF interpreters<br>
- to pass JPEG compressed image data directly to a device (currently the<br>
- pdfwrite family of devices) as the original JPEG data.<br>
-<br>
- This allows us to avoid the compression artefacts caused by decompressing<br>
- JPEG image data, and then applying JPEG compression again.<br>
-<br>
- This works by having the JPEG decoder inquire (via spec_op) if the<br>
- current device would like the original uncompressed data. If so then it<br>
- instructs the JPEG stream decoder to call a routine which will use<br>
- more spec_ops to pass the uncompressed data to the device.<br>
-<br>
- The interpreter still calls the image methods with the decompressed<br>
- data, its up to the device to ignore these calls while handling JPEG<br>
- pass-through.<br>
-<br>
- We have to work this way in PostScript, as we must decompress the data<br>
- as it arrives in order to find the end of the DCT compressed data. In<br>
- addition, this allows the device to change its mind about accepting<br>
- compressed data directly if it discovers from the image data that it<br>
- is not suitable for preserving unchanged.<br>
-<br>
- This approach does not work with the PXL and XPS interpreters. These<br>
- interpreters appear to completely decompress the JPEG data before<br>
- starting an image, unlike the PostScript and PDF interpreters where the<br>
- image methods are called as the stream is decopressed.<br>
-<br>
- As a result this feature is disabled for these interpreters.<br>
-<br>
-Resource/Init/gs_pdfwr.ps<br>
-base/gxdevsop.h<br>
-base/sdct.h<br>
-base/sdctd.c<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdfj.c<br>
-devices/vector/gdevpdfx.h<br>
-devices/vector/gdevpsdf.h<br>
-devices/vector/gdevpsdi.c<br>
-devices/vector/gdevpsdp.c<br>
-doc/VectorDevices.htm<br>
-pcl/pxl/pximage.c<br>
-pcl/pxl/pxvendor.c<br>
-psi/int.mak<br>
-psi/zfdctd.c<br>
-xps/xpsjpeg.c<br>
-xps/xpstiff.c<br>
-xps/xpstile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-21 14:53:08 +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=f858f560061560cbd3670509206dfdd98fea4d07">f858f560061560cbd3670509206dfdd98fea4d07</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in px_state_alloc.<br>
-<br>
- Fix memory leak for allocation event numbers 515 and 516.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=517 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pxl/pxstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-20 22:17:57 +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=9e0509877950e3ffef5c576472ff12a3e3fb37b3">9e0509877950e3ffef5c576472ff12a3e3fb37b3</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak of hpgl_parser_state.<br>
-<br>
- Fix memory leak for allocation event number 420.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=421 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pcl/pcommand.c<br>
-pcl/pcl/pgparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-20 21:29:08 +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=0177158989db4de55199e1b482cbffb033c4a213">0177158989db4de55199e1b482cbffb033c4a213</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in pcl_impl_allocate_interp_instance.<br>
-<br>
- Fix memory leak for allocation event numbers 328 - 417.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=419 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pcl/pctop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-20 20:02:53 +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=3278973da5d771e3fc56d1a4295c3bdb3a1a51b5">3278973da5d771e3fc56d1a4295c3bdb3a1a51b5</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in file_prepare_stream.<br>
-<br>
- Fix memory leak for allocation event number 357.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=358 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-base/sfxcommon.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-20 19:07:34 +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=43711760b611b1a8e17f3490e3b58914508098f9">43711760b611b1a8e17f3490e3b58914508098f9</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in gs_nulldevice.<br>
-<br>
- Fix memory leak for allocation event number 355.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=356 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-19 10:01:22 +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=76aea30116ea14ebb2238d34251e44a7e547ebf0">76aea30116ea14ebb2238d34251e44a7e547ebf0</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in gs_gstate_alloc.<br>
-<br>
- Fix memory leak for allocation event numbers 330 - 334. The path, clip_path and<br>
- effective_clip_path are initialised at the start of gs_gstate_alloc during the<br>
- call to gstate_alloc so this redundant code can be removed.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=348 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-20 14:34:13 +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=b09da43f803fda306d3eb8eca99d825f70156db7">b09da43f803fda306d3eb8eca99d825f70156db7</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in gp_enumerate_files_init.<br>
-<br>
- Fix memory leak for allocation event numbers 199 and 200.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=201 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-base/gp_unifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-17 20:02:32 +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=76c335c7672e3841055d6c6effc2ae61715c8b6a">76c335c7672e3841055d6c6effc2ae61715c8b6a</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in gs_enumerate_files_init.<br>
-<br>
- Fix memory leak for allocation event numbers 183 and 184.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=185 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-base/gsiodev.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-18 12:06:11 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b8eb0c07b84667b0e3f5ab47f328767012781bf">4b8eb0c07b84667b0e3f5ab47f328767012781bf</a>
-<blockquote>
-<p>
- Bug 691224 : Remove the long non-functional DISKFONTS feature.<br>
-<br>
- This feature (allowing Type 1 fonts to be loaded into VM without CharStrings<br>
- and individual CharStrings read from the font file on demand) only ever worked<br>
- with very specifically formatted Type 1 fonts (those coming from the also long<br>
- dead and gone bdftops.ps tool). Any significant variation from that format<br>
- would not work.<br>
-<br>
- As we no longer use fonts derived from BDF (and BDF are very much a thing of the<br>
- past!), DISKFONTS has not worked for a *long* time, hence removing it.<br>
-<br>
- In addition, even on printers, memory is no longer quite the issue it was, nor<br>
- are the core Postscript fonts as widely used or relied upon as they were.<br>
-<br>
-Resource/Init/gs_diskf.ps<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_type1.ps<br>
-doc/Psfiles.htm<br>
-doc/Use.htm<br>
-doc/gs-vms.hlp<br>
-man/gs.1<br>
-psi/int.mak<br>
-psi/psromfs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-18 12:39:00 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f3e26b054b866678512cd6c0c2e2daba9f4c17db">f3e26b054b866678512cd6c0c2e2daba9f4c17db</a>
-<blockquote>
-<p>
- Bug 697856: Reduce clist buffer memory usage for worst case files.<br>
-<br>
- The band_height is chosen based on number of bytes per scan line, and<br>
- a fudge factor if the page uses transparency. For pages with a large<br>
- number of raster lines, the number of bands could cause the space<br>
- needed for the band &quot;states&quot; to exceed the space remaining in the<br>
- buffer. This was handled by doubling the BufferSpace until there<br>
- was enough space for the band states. Improve by increasing the space<br>
- available more gradually. For one of the worst case files, Bug689581.pdf,<br>
- this reduces the memory needed from 40Mb to 24Mb.<br>
-<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-17 17:33:48 +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=c470009cbf8be2aaed7b4b438307479959949625">c470009cbf8be2aaed7b4b438307479959949625</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leak in pl_main_delete_instance.<br>
-<br>
- Fix memory leak for allocation event number 28.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=183 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-17 12:54:59 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c90c6e03844713000f0e300e371487fa49980f5">3c90c6e03844713000f0e300e371487fa49980f5</a>
-<blockquote>
-<p>
- Fix bug 697843: Use after free in pdf14_device_finalize<br>
-<br>
- The trans_group_parent_cmap_procs (misnamed because it has a LOT of<br>
- parent color info along with the cmap procs) needs to be allocated<br>
- in stable_memory to prevent a dangling pointer being seen during the<br>
- pdf14_device_finalize during alloc_restore_all because the parent<br>
- color info may be freed before the pdf14 device itself.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-17 11:43:55 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bfda8d1f442e3c8e81018833c3698ffcb63535fb">bfda8d1f442e3c8e81018833c3698ffcb63535fb</a>
-<blockquote>
-<p>
- Fix (some) missing dependencies<br>
-<br>
- Noticed during other work, but not committed as part of those fixes<br>
- since this is unrelatd.<br>
-<br>
-devices/devs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-17 11:18:42 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c998242a1168320aba8efb909189654f153b8dd3">c998242a1168320aba8efb909189654f153b8dd3</a>
-<blockquote>
-<p>
- Fix bug 698306: consecutive pushpdf14devicefilter leads to SEGV<br>
-<br>
- If we get to pushpdf14devicefilter with the pdf14 device, the closedevice<br>
- will forward the close to the target, but if the pdf14 device hasn't<br>
- been disabled, the opendevice won't forward to the target. Call the<br>
- pdf14_disable_device to make sure the pdf14_open_device will forward.<br>
-<br>
-base/gdevp14.c<br>
-psi/int.mak<br>
-psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-17 12:29:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f0fe2481a2e9b0b632a1d4e804a5a1d27fe9c017">f0fe2481a2e9b0b632a1d4e804a5a1d27fe9c017</a>
-<blockquote>
-<p>
- Prevent undefined error with -DDEBUG<br>
-<br>
- The procedure for dumping VM stats with -DDEBUG and -DINITDEBUG was not being<br>
- bound, so the .&lt;operator&gt; internal operators we now undefine after<br>
- initialization were missing by the time the procedure was called.<br>
-<br>
- Now, simply bind the procedure<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-16 20:04:30 +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=6e7149bae6bd5c2a7b5acff50ba6600b3beb3818">6e7149bae6bd5c2a7b5acff50ba6600b3beb3818</a>
-<blockquote>
-<p>
- Bug 697545 : Memory squeezing fix for double freeing of ToneCurve.<br>
-<br>
- Avoid SEGV by removing unnecessary freeing of ToneCurve.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=751 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-lcms2art/src/cmsio1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-16 19:41:55 +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=1bbf91df4b8df650f3efe0effd37cf1cf91c9657">1bbf91df4b8df650f3efe0effd37cf1cf91c9657</a>
-<blockquote>
-<p>
- Bug 697545 : Memory squeezing fix for mutex in lcms2art code<br>
-<br>
- Prevent SEGV by checking for NULL mutex pointer before attempting<br>
- to use or destroy it.<br>
-<br>
-lcms2art/src/cmserr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-15 17:26:37 +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=3aeff79d28e832aefcd005c99ae67304c927b3d3">3aeff79d28e832aefcd005c99ae67304c927b3d3</a>
-<blockquote>
-<p>
- Bug 697545 : Fix memory leaks and SEGVs.<br>
-<br>
- Prevent table being orphaned due to early memory allocation failures. Remove<br>
- cleanup code to prevent double freeing iodev entries. Prevent SEGV when ramfs<br>
- state fails to allocate.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=25 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-base/gsiodev.c<br>
-base/gsioram.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-16 11:18:27 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d250ce572e7f2e067693a19de8d38b6612b73501">d250ce572e7f2e067693a19de8d38b6612b73501</a>
-<blockquote>
-<p>
- Fix segfault with &quot;all devices&quot; test.<br>
-<br>
- Turns out there's a group of devices that actually open a file as they are being<br>
- closed, which causes problems if we've already freed up the I/O device table,<br>
- which commit 2e86e7f64e added.<br>
-<br>
- So, rejig the Postscript interpreter's I/O device table init/finit functions to<br>
- allow later freeing of the table (whilst keeping the two consistent in their<br>
- parameters).<br>
-<br>
-psi/iinit.c<br>
-psi/iinit.h<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-16 10:47:14 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e62df8bbd78e8db1cb254a6ab4c2ebf1232c6c7e">e62df8bbd78e8db1cb254a6ab4c2ebf1232c6c7e</a>
-<blockquote>
-<p>
- Reduce severity of memory debug problem detection<br>
-<br>
- Bug #698849 &quot;gs_abort with Bad object&quot;<br>
-<br>
- The error occurs because of the combination of -Z? and -dLastPage. In<br>
- order to do First/Last Page processing, we insert a subclassing device<br>
- ahead of the regular device (ppmraw in this case).<br>
-<br>
- The subclassing works by making a new device structure, copying the<br>
- existing device to it, and replacing the content of the existing<br>
- device structure. This is done to maintain coherency of gsave/grestore<br>
- and save/restore; the structures maintain pointers to the device in<br>
- the graphics state structure, so we can't simply move it.<br>
-<br>
- When subclassing, we change the declared size of the structure (ssize)<br>
- but we don't (can't!) change the size that the memory manager allocated<br>
- in the first place. This leads to a mismatch between the declared size<br>
- of the structure and the allocated size. I mentioned this in the<br>
- original commit for subclassing, but noted that in normal use there is<br>
- nowhere that actually checks.<br>
-<br>
- However, if you set -Z? then additional checks are done on memory<br>
- validity, and this discrepancy is flagged. It also raises an abort,<br>
- presumably because this is seen as serious enough to stop and<br>
- investigate.<br>
-<br>
- I don't want to remove this check altogether, as it may still be useful,<br>
- but we don't want to abort now because this might be a benign change<br>
- caused by subclassing.<br>
-<br>
- So here, pull the size != ssize check out separately from the other<br>
- consistency checks, and if it is not true raise a warning, but do<br>
- *not* abort the process.<br>
-<br>
-psi/ilocate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-15 11:41:01 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d730d2087680cff4e3b153536922406bfcf4493">4d730d2087680cff4e3b153536922406bfcf4493</a>
-<blockquote>
-<p>
- Fix bug 698823. Segfault with psdrgb and transparency_example.ps<br>
-<br>
- The psdrgb device has max_components == 3, but the pdf14 device was<br>
- using spot_colors to set it more than that (transparency_example.ps<br>
- doed not set PageSpotColors so it was -1, leading to underflow).<br>
- If page_spot_colors is the default -1, then don't use it, and also<br>
- limit the num_components to max_components for the device.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-15 08:14:02 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=afe8e5468db1f875432aa711676eaf4007d13daa">afe8e5468db1f875432aa711676eaf4007d13daa</a>
-<blockquote>
-<p>
- Fix opening of files &gt; 2GB on Windows built with VS after VS2013<br>
-<br>
- For whatever reason, even on 64 bit builds, Visual Studio changed<br>
- behaviour and the compiler/run-time now invoke __fstat64i32 for<br>
- fstat. This returns an error if the file size can't fit in int32<br>
- (the older fstat just returned a negative number, ignoring overflow)<br>
- Change to use __fstat64 which works on VS 2005 so it should be<br>
- fine. I also tested this build on an ancient Dell with 760Mb RAM<br>
- running Windows XP SP3 and it runs fine, so __fstat64 is not a<br>
- problem going back that far.<br>
-<br>
-base/stat_.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-15 17:22: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=b199f558834d0fbd365cccc426eed0fdc3e035c7">b199f558834d0fbd365cccc426eed0fdc3e035c7</a>
-<blockquote>
-<p>
- pdfwrite - Fix the detection of type 3 descendants in composite fonts<br>
-<br>
- Bug #698844 &quot;ps2pdf creates unusually large PDF files starting with version 9.21&quot;<br>
- Bug #698647 &quot;PCL5 - Downloadfont not as T3 Font interpreted&quot;<br>
- Bug #607462 &quot;Ghostscript falls into infinite loop with pdfwrite&quot;<br>
-<br>
- The actual problem was that a Type 0 composite font with a single<br>
- descendant was used with stringwidth and the space glyph. This was not<br>
- detected by pdf_text_begin() and so the glyph was cached, but it was not<br>
- added to any type 3 font, it was simply processed as a stringwidth.<br>
-<br>
- Later the same glyph from the same font was used in earnest, pdfwrite<br>
- noticed it didn't have a copy of the glyph and set up to capture the<br>
- CharProc. But the glyph was present in the glyph cache which meant the<br>
- CharProc wasn't executed, leading to an infinite loop.<br>
-<br>
- The fix applied prevented caching type 3 fonts, but that caused problems<br>
- with cases where we wanted to convert a font to type 3, so the fix<br>
- was extended to only prevent caching of input type 3 fonts, not<br>
- synthesised ones.<br>
-<br>
- However, this still caused problems with programs which used type 3 fonts<br>
- with glyphshow. Because we did not cache the glyphs we would detect each<br>
- glyph use through glyphshow as a new glyph, and so there would be no<br>
- glyph reuse, leading to large slow PDF files.<br>
-<br>
- Here we extend the check on descendants of type 3 fonts so that if no<br>
- font change takes place, we still check the 'current' descendant to<br>
- see if its type 3. If a type 3 descendant is detected then we skip<br>
- caching the glyph which prevents the whole problem.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-15 14:06:34 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=99a839311c7d7e1dab919bd88f7632c5e230708f">99a839311c7d7e1dab919bd88f7632c5e230708f</a>
-<blockquote>
-<p>
- Remove hamrless/pointless no-op assignment from previous commit<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-15 13:48:27 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ead0b5bee31a6e2756749a5c8fb6508e49b64703">ead0b5bee31a6e2756749a5c8fb6508e49b64703</a>
-<blockquote>
-<p>
- Bug 698856: Ensure is_glyph_index flag is consistently set<br>
-<br>
- The is_glyph_index is (now) set as a local variable, then copied to<br>
- the structure before the ps_get_glyphname_or_cid() function returns.<br>
-<br>
- A couple of branches in the code were still setting the structure value directly<br>
- meaning the local variable was wrong.<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-15 08:17:46 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e86e7f64ed169345c9fb49b9c9eaf0a1bf78720">2e86e7f64ed169345c9fb49b9c9eaf0a1bf78720</a>
-<blockquote>
-<p>
- Bug 698842: cleanup the io_dev table and contents<br>
-<br>
- This is slightly complicated as (in the Ghostscript case) the table can be<br>
- freed explicitly, or by the garbager.<br>
-<br>
-base/gdevpipe.c<br>
-base/gp_mshdl.c<br>
-base/gp_msprn.c<br>
-base/gp_os2pr.c<br>
-base/gsiodev.c<br>
-base/gsiodevs.c<br>
-base/gsiodisk.c<br>
-base/gsioram.c<br>
-base/gsiorom.c<br>
-base/gslib.c<br>
-base/gxiodev.h<br>
-base/lib.mak<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plmain.c<br>
-psi/iinit.c<br>
-psi/iinit.h<br>
-psi/imain.c<br>
-psi/int.mak<br>
-psi/zdevcal.c<br>
-psi/ziodev.c<br>
-psi/ziodev2.c<br>
-psi/ziodevs.c<br>
-psi/ziodevsc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-12 08:48: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=d0829c3cc4d64594499035d664c918acc9047d70">d0829c3cc4d64594499035d664c918acc9047d70</a>
-<blockquote>
-<p>
- Update to latest CMap release from Adobe<br>
-<br>
- From:<br>
- https://github.com/adobe-type-tools/cmap-resources<br>
-<br>
-Resource/CMap/78-EUC-H<br>
-Resource/CMap/78-EUC-V<br>
-Resource/CMap/78-H<br>
-Resource/CMap/78-RKSJ-H<br>
-Resource/CMap/78-RKSJ-V<br>
-Resource/CMap/78-V<br>
-Resource/CMap/78ms-RKSJ-H<br>
-Resource/CMap/78ms-RKSJ-V<br>
-Resource/CMap/83pv-RKSJ-H<br>
-Resource/CMap/90ms-RKSJ-H<br>
-Resource/CMap/90ms-RKSJ-V<br>
-Resource/CMap/90msp-RKSJ-H<br>
-Resource/CMap/90msp-RKSJ-V<br>
-Resource/CMap/90pv-RKSJ-H<br>
-Resource/CMap/90pv-RKSJ-V<br>
-Resource/CMap/Add-H<br>
-Resource/CMap/Add-RKSJ-H<br>
-Resource/CMap/Add-RKSJ-V<br>
-Resource/CMap/Add-V<br>
-Resource/CMap/Adobe-CNS1-0<br>
-Resource/CMap/Adobe-CNS1-1<br>
-Resource/CMap/Adobe-CNS1-2<br>
-Resource/CMap/Adobe-CNS1-3<br>
-Resource/CMap/Adobe-CNS1-4<br>
-Resource/CMap/Adobe-CNS1-5<br>
-Resource/CMap/Adobe-CNS1-6<br>
-Resource/CMap/Adobe-CNS1-7<br>
-Resource/CMap/Adobe-GB1-0<br>
-Resource/CMap/Adobe-GB1-1<br>
-Resource/CMap/Adobe-GB1-2<br>
-Resource/CMap/Adobe-GB1-3<br>
-Resource/CMap/Adobe-GB1-4<br>
-Resource/CMap/Adobe-GB1-5<br>
-Resource/CMap/Adobe-Japan1-0<br>
-Resource/CMap/Adobe-Japan1-1<br>
-Resource/CMap/Adobe-Japan1-2<br>
-Resource/CMap/Adobe-Japan1-3<br>
-Resource/CMap/Adobe-Japan1-4<br>
-Resource/CMap/Adobe-Japan1-5<br>
-Resource/CMap/Adobe-Japan1-6<br>
-Resource/CMap/Adobe-Japan2-0<br>
-Resource/CMap/Adobe-Korea1-0<br>
-Resource/CMap/Adobe-Korea1-1<br>
-Resource/CMap/Adobe-Korea1-2<br>
-Resource/CMap/B5-H<br>
-Resource/CMap/B5-V<br>
-Resource/CMap/B5pc-H<br>
-Resource/CMap/B5pc-V<br>
-Resource/CMap/CNS-EUC-H<br>
-Resource/CMap/CNS-EUC-V<br>
-Resource/CMap/CNS1-H<br>
-Resource/CMap/CNS1-V<br>
-Resource/CMap/CNS2-H<br>
-Resource/CMap/CNS2-V<br>
-Resource/CMap/ETHK-B5-H<br>
-Resource/CMap/ETHK-B5-V<br>
-Resource/CMap/ETen-B5-H<br>
-Resource/CMap/ETen-B5-V<br>
-Resource/CMap/ETenms-B5-H<br>
-Resource/CMap/ETenms-B5-V<br>
-Resource/CMap/EUC-H<br>
-Resource/CMap/EUC-V<br>
-Resource/CMap/Ext-H<br>
-Resource/CMap/Ext-RKSJ-H<br>
-Resource/CMap/Ext-RKSJ-V<br>
-Resource/CMap/Ext-V<br>
-Resource/CMap/GB-EUC-H<br>
-Resource/CMap/GB-EUC-V<br>
-Resource/CMap/GB-H<br>
-Resource/CMap/GB-V<br>
-Resource/CMap/GBK-EUC-H<br>
-Resource/CMap/GBK-EUC-V<br>
-Resource/CMap/GBK2K-H<br>
-Resource/CMap/GBK2K-V<br>
-Resource/CMap/GBKp-EUC-H<br>
-Resource/CMap/GBKp-EUC-V<br>
-Resource/CMap/GBT-EUC-H<br>
-Resource/CMap/GBT-EUC-V<br>
-Resource/CMap/GBT-H<br>
-Resource/CMap/GBT-V<br>
-Resource/CMap/GBTpc-EUC-H<br>
-Resource/CMap/GBTpc-EUC-V<br>
-Resource/CMap/GBpc-EUC-H<br>
-Resource/CMap/GBpc-EUC-V<br>
-Resource/CMap/H<br>
-Resource/CMap/HKdla-B5-H<br>
-Resource/CMap/HKdla-B5-V<br>
-Resource/CMap/HKdlb-B5-H<br>
-Resource/CMap/HKdlb-B5-V<br>
-Resource/CMap/HKgccs-B5-H<br>
-Resource/CMap/HKgccs-B5-V<br>
-Resource/CMap/HKm314-B5-H<br>
-Resource/CMap/HKm314-B5-V<br>
-Resource/CMap/HKm471-B5-H<br>
-Resource/CMap/HKm471-B5-V<br>
-Resource/CMap/HKscs-B5-H<br>
-Resource/CMap/HKscs-B5-V<br>
-Resource/CMap/Hankaku<br>
-Resource/CMap/Hiragana<br>
-Resource/CMap/Hojo-EUC-H<br>
-Resource/CMap/Hojo-EUC-V<br>
-Resource/CMap/Hojo-H<br>
-Resource/CMap/Hojo-V<br>
-Resource/CMap/Identity-H<br>
-Resource/CMap/Identity-V<br>
-Resource/CMap/KSC-EUC-H<br>
-Resource/CMap/KSC-EUC-V<br>
-Resource/CMap/KSC-H<br>
-Resource/CMap/KSC-Johab-H<br>
-Resource/CMap/KSC-Johab-V<br>
-Resource/CMap/KSC-V<br>
-Resource/CMap/KSCms-UHC-H<br>
-Resource/CMap/KSCms-UHC-HW-H<br>
-Resource/CMap/KSCms-UHC-HW-V<br>
-Resource/CMap/KSCms-UHC-V<br>
-Resource/CMap/KSCpc-EUC-H<br>
-Resource/CMap/KSCpc-EUC-V<br>
-Resource/CMap/Katakana<br>
-Resource/CMap/NWP-H<br>
-Resource/CMap/NWP-V<br>
-Resource/CMap/RKSJ-H<br>
-Resource/CMap/RKSJ-V<br>
-Resource/CMap/Roman<br>
-Resource/CMap/UniCNS-UCS2-H<br>
-Resource/CMap/UniCNS-UCS2-V<br>
-Resource/CMap/UniCNS-UTF16-H<br>
-Resource/CMap/UniCNS-UTF16-V<br>
-Resource/CMap/UniCNS-UTF32-H<br>
-Resource/CMap/UniCNS-UTF32-V<br>
-Resource/CMap/UniCNS-UTF8-H<br>
-Resource/CMap/UniCNS-UTF8-V<br>
-Resource/CMap/UniGB-UCS2-H<br>
-Resource/CMap/UniGB-UCS2-V<br>
-Resource/CMap/UniGB-UTF16-H<br>
-Resource/CMap/UniGB-UTF16-V<br>
-Resource/CMap/UniGB-UTF32-H<br>
-Resource/CMap/UniGB-UTF32-V<br>
-Resource/CMap/UniGB-UTF8-H<br>
-Resource/CMap/UniGB-UTF8-V<br>
-Resource/CMap/UniHojo-UCS2-H<br>
-Resource/CMap/UniHojo-UCS2-V<br>
-Resource/CMap/UniHojo-UTF16-H<br>
-Resource/CMap/UniHojo-UTF16-V<br>
-Resource/CMap/UniHojo-UTF32-H<br>
-Resource/CMap/UniHojo-UTF32-V<br>
-Resource/CMap/UniHojo-UTF8-H<br>
-Resource/CMap/UniHojo-UTF8-V<br>
-Resource/CMap/UniJIS-UCS2-H<br>
-Resource/CMap/UniJIS-UCS2-HW-H<br>
-Resource/CMap/UniJIS-UCS2-HW-V<br>
-Resource/CMap/UniJIS-UCS2-V<br>
-Resource/CMap/UniJIS-UTF16-H<br>
-Resource/CMap/UniJIS-UTF16-V<br>
-Resource/CMap/UniJIS-UTF32-H<br>
-Resource/CMap/UniJIS-UTF32-V<br>
-Resource/CMap/UniJIS-UTF8-H<br>
-Resource/CMap/UniJIS-UTF8-V<br>
-Resource/CMap/UniJIS2004-UTF16-H<br>
-Resource/CMap/UniJIS2004-UTF16-V<br>
-Resource/CMap/UniJIS2004-UTF32-H<br>
-Resource/CMap/UniJIS2004-UTF32-V<br>
-Resource/CMap/UniJIS2004-UTF8-H<br>
-Resource/CMap/UniJIS2004-UTF8-V<br>
-Resource/CMap/UniJISPro-UCS2-HW-V<br>
-Resource/CMap/UniJISPro-UCS2-V<br>
-Resource/CMap/UniJISPro-UTF8-V<br>
-Resource/CMap/UniJISX0213-UTF32-H<br>
-Resource/CMap/UniJISX0213-UTF32-V<br>
-Resource/CMap/UniJISX02132004-UTF32-H<br>
-Resource/CMap/UniJISX02132004-UTF32-V<br>
-Resource/CMap/UniKS-UCS2-H<br>
-Resource/CMap/UniKS-UCS2-V<br>
-Resource/CMap/UniKS-UTF16-H<br>
-Resource/CMap/UniKS-UTF16-V<br>
-Resource/CMap/UniKS-UTF32-H<br>
-Resource/CMap/UniKS-UTF32-V<br>
-Resource/CMap/UniKS-UTF8-H<br>
-Resource/CMap/UniKS-UTF8-V<br>
-Resource/CMap/V<br>
-Resource/CMap/WP-Symbol<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-13 13:10:08 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3b0c7a01433c16f007dd3d92c04edc19bfb79970">3b0c7a01433c16f007dd3d92c04edc19bfb79970</a>
-<blockquote>
-<p>
- Revert GhostPDL.sln due to stray commit<br>
-<br>
- I use VS2017 for profiling, so had converted the solution file.<br>
- It should not have been committed, but slipped through. Reverting<br>
- it here.<br>
-<br>
-windows/GhostPDL.sln<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-13 10:45:32 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=112021a361e9300d9cd0cde0bfc9e691a6e5d0d7">112021a361e9300d9cd0cde0bfc9e691a6e5d0d7</a>
-<blockquote>
-<p>
- pdf_info.ps - gracefully handle circular Resource references<br>
-<br>
- Although not strictly part of Ghostscript, pdf_info.ps is used by<br>
- customers and this is reasonably easy to improve.<br>
-<br>
- When checking for transparency, pdf_info.ps uses the Ghostscript<br>
- PDF interpreter to do the work. However, other aspects of its operation<br>
- (Media Sizes, Font use) aren't available from the PDF interpreter.<br>
-<br>
- When detecting Font usage, pdf_info.ps walks the Page Resource chain,<br>
- and any the Resource chains of any Pattern or XObject Resources used<br>
- on that page, as well as the Resources for any Annots (and also any<br>
- XObject or Pattern Resources used by the Annots). If any of these<br>
- Resource chains contains a circular reference (which they absolutely<br>
- should not) then pdf_info will enter a loop and process unwil it<br>
- exceeds the execution stack limit, throwing an error.<br>
-<br>
- In this commit we borrow the technique used by the PDF interpreter, we<br>
- create a dictionary and every object which we inspect has its object<br>
- number stored in that dictionary. Whenever we encounter a new object<br>
- we first check to see if its number is in that dictionary. If it is, we<br>
- know we've seen it before and this is (possibly) a circular reference.<br>
-<br>
- Even if it is not a circular reference, we've already checked that chain<br>
- so we don't need to check it again.<br>
-<br>
- This isn't cluster checked.<br>
-<br>
-toolbin/pdf_info.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-23 21:19:22 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3012651caace0d2d4dd26631e0e10d81fdeab181">3012651caace0d2d4dd26631e0e10d81fdeab181</a>
-<blockquote>
-<p>
- Fix Bug 698729: White lines with LeadingEdge=3 and InterpolateControl&gt;1<br>
-<br>
- Images are always painted in X from left to right, but for landscape the<br>
- lines come in the original order, so if dy is negative we need to back up<br>
- the starting Y coordinate (scaled_y) by the (scaled_h - 1).<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-12 09:52:20 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3110ffa4ee4de170248317813e2e5e5f2d84e75c">3110ffa4ee4de170248317813e2e5e5f2d84e75c</a>
-<blockquote>
-<p>
- Fix errors: Interpolated images + overprint + devn device<br>
-<br>
- When using the overprint compositor, the underlying device may be able<br>
- to handle copy_alpha_hl_color (planar devices) so forward to it even<br>
- when the overprint compositor isn't active and use the correct<br>
- overprint_copy_alpha_hl_color for the generic_procs.<br>
-<br>
- Fix regression errors with psdcmyk device from files in<br>
- tests_private/comparefiles: Bug688308.ps T2CharString.eps and<br>
- from tests_private/ps/ps3cet: 09-47N.PS 10-08.PS 10-14.PS 10-16.PS<br>
- 11-01.PS 11-02.PS 11-03.PS 11-04.PS 11-05.PS 11-06.PS 11-07.PS<br>
- 11-09.PS 11-10.PS 11-11.PS 11-12.PS 11-14.PS 11-15.PS 11-16.PS<br>
- 11-17.PS 11-18.PS 11-19.PS 11-21.PS 11-22.PS 11-26D.PS 11-28.PS<br>
- 12-02.PS 12-04.PS 12-06.PS 12-07D.PS 12-08D.PS 12-11.PS 12-12.PS<br>
- 12-13.PS 13-01.PS 13-02.PS 13-05.PS 13-16.PS 13-17.PS 13-19.PS<br>
- 13-20.PS 13-22.PS 13-26.PS 13-27.PS 13-28.PS 13-29.PS 21-11.PS<br>
-<br>
-base/gsovrc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-12 08:23:09 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1508f69d9ed68baac7e659e6089edbf12c9717a9">1508f69d9ed68baac7e659e6089edbf12c9717a9</a>
-<blockquote>
-<p>
- Fix devn color affecting psdcmyk tests/pdf/Bug6901014_launch_leaflet.pdf p2<br>
-<br>
- The image interpolation uses copy_alpha_hl_color so when InterpolateControl=-1<br>
- is used with this file in clist mode, playback ends up calling the<br>
- default_no_copy_alpha_hl_color function which throws an &quot;undefined&quot; error. If<br>
- this proc is seen, instead pass to copy_alpha which can work as long as the<br>
- devn color can be packed into a chunky color which is the case as long as the<br>
- num_components is &lt;= 8, which is useful enough to make it worth trying. If<br>
- the num_components is too large, the copy_alpha will throw a &quot;rangecheck&quot;.<br>
-<br>
-base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-02 11:32:10 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d6a0412e281b786847ec96acc0ba85ffa22bf04d">d6a0412e281b786847ec96acc0ba85ffa22bf04d</a>
-<blockquote>
-<p>
- Switch to lcms2 Artifex version for CMM<br>
-<br>
- MuPDF is using Artifex's thread-safe version of lcms2. This commit switches gs to using that<br>
- same version. Having gs take advantage of the thread-safe capabilities will be in a different<br>
- commit.<br>
-<br>
-Makefile.in<br>
-base/gscms.h<br>
-base/gsicc_cache.c<br>
-base/gsicc_cms.h<br>
-base/gsicc_lcms.c<br>
-base/gsicc_lcms2.c<br>
-base/gsicc_lcms2art.c<br>
-base/gsicc_manage.c<br>
-base/lcms2art.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>
-devices/gdevpsd.c<br>
-devices/gdevrinkj.c<br>
-devices/vector/gdevpx.c<br>
-lcms2/README.1ST<br>
-lcms2/doc/LittleCMS2.8 API.pdf<br>
-lcms2/doc/LittleCMS2.8 Plugin API.pdf<br>
-lcms2/doc/LittleCMS2.8 tutorial.pdf<br>
-lcms2/include/Makefile.am<br>
-lcms2art/.travis.yml<br>
-lcms2art/AUTHORS<br>
-lcms2art/COPYING<br>
-lcms2art/ChangeLog<br>
-lcms2art/INSTALL<br>
-lcms2art/Lib/BC/BC.txt<br>
-lcms2art/Lib/MS/MS.TXT<br>
-lcms2art/Makefile.am<br>
-lcms2art/Makefile.in<br>
-lcms2art/Projects/.gitignore<br>
-lcms2art/Projects/BorlandC_5.5/lcms2.rc<br>
-lcms2art/Projects/BorlandC_5.5/lcmsdll.lk<br>
-lcms2art/Projects/BorlandC_5.5/lcmsdll.lst<br>
-lcms2art/Projects/BorlandC_5.5/mklcmsdll.bat<br>
-lcms2art/Projects/VC2010/jpegicc/jpegicc.vcxproj<br>
-lcms2art/Projects/VC2010/jpegicc/jpegicc.vcxproj.filters<br>
-lcms2art/Projects/VC2010/linkicc/linkicc.vcxproj<br>
-lcms2art/Projects/VC2010/linkicc/linkicc.vcxproj.filters<br>
-lcms2art/Projects/VC2010/psicc/psicc.vcxproj<br>
-lcms2art/Projects/VC2010/psicc/psicc.vcxproj.filters<br>
-lcms2art/Projects/VC2010/resource.h<br>
-lcms2art/Projects/VC2010/testbed/testbed.vcxproj<br>
-lcms2art/Projects/VC2010/testbed/testbed.vcxproj.filters<br>
-lcms2art/Projects/VC2010/tiffdiff/tiffdiff.vcxproj<br>
-lcms2art/Projects/VC2010/tiffdiff/tiffdiff.vcxproj.filters<br>
-lcms2art/Projects/VC2010/tifficc/tifficc.vcxproj<br>
-lcms2art/Projects/VC2010/tifficc/tifficc.vcxproj.filters<br>
-lcms2art/Projects/VC2010/transicc/transicc.vcxproj<br>
-lcms2art/Projects/VC2010/transicc/transicc.vcxproj.filters<br>
-lcms2art/Projects/VC2012/jpegicc/jpegicc.vcxproj<br>
-lcms2art/Projects/VC2012/jpegicc/jpegicc.vcxproj.filters<br>
-lcms2art/Projects/VC2012/lcms2art.rc<br>
-lcms2art/Projects/VC2012/lcms2art.sln<br>
-lcms2art/Projects/VC2012/lcms2art_DLL/lcms2art_DLL.vcxproj<br>
-lcms2art/Projects/VC2012/lcms2art_DLL/lcms2art_DLL.vcxproj.filters<br>
-lcms2art/Projects/VC2012/lcms2art_static/lcms2art_static.vcxproj<br>
-lcms2art/Projects/VC2012/lcms2art_static/lcms2art_static.vcxproj.filters<br>
-lcms2art/Projects/VC2012/linkicc/linkicc.vcxproj<br>
-lcms2art/Projects/VC2012/linkicc/linkicc.vcxproj.filters<br>
-lcms2art/Projects/VC2012/psicc/psicc.vcxproj<br>
-lcms2art/Projects/VC2012/psicc/psicc.vcxproj.filters<br>
-lcms2art/Projects/VC2012/resource.h<br>
-lcms2art/Projects/VC2012/testbed/testbed.vcxproj<br>
-lcms2art/Projects/VC2012/testbed/testbed.vcxproj.filters<br>
-lcms2art/Projects/VC2012/tiffdiff/tiffdiff.vcxproj<br>
-lcms2art/Projects/VC2012/tiffdiff/tiffdiff.vcxproj.filters<br>
-lcms2art/Projects/VC2012/tifficc/tifficc.vcxproj<br>
-lcms2art/Projects/VC2012/tifficc/tifficc.vcxproj.filters<br>
-lcms2art/Projects/VC2012/transicc/transicc.vcxproj<br>
-lcms2art/Projects/VC2012/transicc/transicc.vcxproj.filters<br>
-lcms2art/Projects/VC2013/jpegicc/jpegicc.vcxproj<br>
-lcms2art/Projects/VC2013/jpegicc/jpegicc.vcxproj.filters<br>
-lcms2art/Projects/VC2013/lcms2art.rc<br>
-lcms2art/Projects/VC2013/lcms2art.sln<br>
-lcms2art/Projects/VC2013/lcms2art_DLL/lcms2art_DLL.vcxproj<br>
-lcms2art/Projects/VC2013/lcms2art_DLL/lcms2art_DLL.vcxproj.filters<br>
-lcms2art/Projects/VC2013/lcms2art_static/lcms2art_static.vcxproj<br>
-lcms2art/Projects/VC2013/lcms2art_static/lcms2art_static.vcxproj.filters<br>
-lcms2art/Projects/VC2013/linkicc/linkicc.vcxproj<br>
-lcms2art/Projects/VC2013/linkicc/linkicc.vcxproj.filters<br>
-lcms2art/Projects/VC2013/psicc/psicc.vcxproj<br>
-lcms2art/Projects/VC2013/psicc/psicc.vcxproj.filters<br>
-lcms2art/Projects/VC2013/resource.h<br>
-lcms2art/Projects/VC2013/testbed/testbed.vcxproj<br>
-lcms2art/Projects/VC2013/testbed/testbed.vcxproj.filters<br>
-lcms2art/Projects/VC2013/tiffdiff/tiffdiff.vcxproj<br>
-lcms2art/Projects/VC2013/tiffdiff/tiffdiff.vcxproj.filters<br>
-lcms2art/Projects/VC2013/tifficc/tifficc.vcxproj<br>
-lcms2art/Projects/VC2013/tifficc/tifficc.vcxproj.filters<br>
-lcms2art/Projects/VC2013/transicc/transicc.vcxproj<br>
-lcms2art/Projects/VC2013/transicc/transicc.vcxproj.filters<br>
-lcms2art/Projects/VC2015/jpegicc/jpegicc.vcxproj<br>
-lcms2art/Projects/VC2015/jpegicc/jpegicc.vcxproj.filters<br>
-lcms2art/Projects/VC2015/lcms2art.rc<br>
-lcms2art/Projects/VC2015/lcms2art.sln<br>
-lcms2art/Projects/VC2015/lcms2art_DLL/lcms2art_DLL.vcxproj<br>
-lcms2art/Projects/VC2015/lcms2art_DLL/lcms2art_DLL.vcxproj.filters<br>
-lcms2art/Projects/VC2015/lcms2art_static/lcms2art_static.vcxproj<br>
-lcms2art/Projects/VC2015/lcms2art_static/lcms2art_static.vcxproj.filters<br>
-lcms2art/Projects/VC2015/linkicc/linkicc.vcxproj<br>
-lcms2art/Projects/VC2015/linkicc/linkicc.vcxproj.filters<br>
-lcms2art/Projects/VC2015/psicc/psicc.vcxproj<br>
-lcms2art/Projects/VC2015/psicc/psicc.vcxproj.filters<br>
-lcms2art/Projects/VC2015/resource.h<br>
-lcms2art/Projects/VC2015/testbed/testbed.vcxproj<br>
-lcms2art/Projects/VC2015/testbed/testbed.vcxproj.filters<br>
-lcms2art/Projects/VC2015/tiffdiff/tiffdiff.vcxproj<br>
-lcms2art/Projects/VC2015/tiffdiff/tiffdiff.vcxproj.filters<br>
-lcms2art/Projects/VC2015/tifficc/tifficc.vcxproj<br>
-lcms2art/Projects/VC2015/tifficc/tifficc.vcxproj.filters<br>
-lcms2art/Projects/VC2015/transicc/transicc.vcxproj<br>
-lcms2art/Projects/VC2015/transicc/transicc.vcxproj.filters<br>
-lcms2art/Projects/VC2017/jpegicc/jpegicc.vcxproj<br>
-lcms2art/Projects/VC2017/jpegicc/jpegicc.vcxproj.filters<br>
-lcms2art/Projects/VC2017/lcms2art.rc<br>
-lcms2art/Projects/VC2017/lcms2art.sln<br>
-lcms2art/Projects/VC2017/lcms2art_DLL/lcms2art_DLL.vcxproj<br>
-lcms2art/Projects/VC2017/lcms2art_DLL/lcms2art_DLL.vcxproj.filters<br>
-lcms2art/Projects/VC2017/lcms2art_static/lcms2art_static.vcxproj<br>
-lcms2art/Projects/VC2017/lcms2art_static/lcms2art_static.vcxproj.filters<br>
-lcms2art/Projects/VC2017/linkicc/linkicc.vcxproj<br>
-lcms2art/Projects/VC2017/linkicc/linkicc.vcxproj.filters<br>
-lcms2art/Projects/VC2017/psicc/psicc.vcxproj<br>
-lcms2art/Projects/VC2017/psicc/psicc.vcxproj.filters<br>
-lcms2art/Projects/VC2017/resource.h<br>
-lcms2art/Projects/VC2017/testbed/testbed.vcxproj<br>
-lcms2art/Projects/VC2017/testbed/testbed.vcxproj.filters<br>
-lcms2art/Projects/VC2017/tiffdiff/tiffdiff.vcxproj<br>
-lcms2art/Projects/VC2017/tiffdiff/tiffdiff.vcxproj.filters<br>
-lcms2art/Projects/VC2017/tifficc/tifficc.vcxproj<br>
-lcms2art/Projects/VC2017/tifficc/tifficc.vcxproj.filters<br>
-lcms2art/Projects/VC2017/transicc/transicc.vcxproj<br>
-lcms2art/Projects/VC2017/transicc/transicc.vcxproj.filters<br>
-lcms2art/Projects/cppcheck/lcms2.cppcheck<br>
-lcms2art/Projects/mac/LittleCMS/._Info.plist<br>
-lcms2art/Projects/mac/LittleCMS/._LittleCMS.xcodeproj<br>
-lcms2art/Projects/mac/LittleCMS/English.lproj/InfoPlist.strings<br>
-lcms2art/Projects/mac/LittleCMS/Info.plist<br>
-lcms2art/Projects/mac/LittleCMS/LittleCMS.xcodeproj/mariama.mode1v3<br>
-lcms2art/Projects/mac/LittleCMS/LittleCMS.xcodeproj/mariama.pbxuser<br>
-lcms2art/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.pbxproj<br>
-lcms2art/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.xcworkspace/contents.xcworkspacedata<br>
-lcms2art/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.xcworkspace/xcuserdata/User.xcuserdatad/UserInterfaceState.xcuserstate<br>
-lcms2art/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.xcworkspace/xcuserdata/User.xcuserdatad/WorkspaceSettings.xcsettings<br>
-lcms2art/Projects/mac/LittleCMS/LittleCMS.xcodeproj/xcuserdata/User.xcuserdatad/xcdebugger/Breakpoints.xcbkptlist<br>
-lcms2art/Projects/mac/LittleCMS/LittleCMS.xcodeproj/xcuserdata/User.xcuserdatad/xcschemes/LittleCMS.xcscheme<br>
-lcms2art/Projects/mac/LittleCMS/LittleCMS.xcodeproj/xcuserdata/User.xcuserdatad/xcschemes/testbed.xcscheme<br>
-lcms2art/Projects/mac/LittleCMS/LittleCMS.xcodeproj/xcuserdata/User.xcuserdatad/xcschemes/xcschememanagement.plist<br>
-lcms2art/Projects/mac/LittleCMS/LittleCMS_Prefix.pch<br>
-lcms2art/Projects/mac/LittleCMS/TestBed-Info.plist<br>
-lcms2art/README.1ST<br>
-lcms2art/aclocal.m4<br>
-lcms2art/autogen.sh<br>
-lcms2art/compile<br>
-lcms2art/config.guess<br>
-lcms2art/config.sub<br>
-lcms2art/configure<br>
-lcms2art/configure.ac<br>
-lcms2art/depcomp<br>
-lcms2art/doc/LittleCMS2.9 API.pdf<br>
-lcms2art/doc/LittleCMS2.9 Plugin API.pdf<br>
-lcms2art/doc/LittleCMS2.9 tutorial.pdf<br>
-lcms2art/doc/WhyThisFork.txt<br>
-lcms2art/doc/src.zip<br>
-lcms2art/include/Makefile.am<br>
-lcms2art/include/Makefile.in<br>
-lcms2art/include/lcms2art.h<br>
-lcms2art/include/lcms2art_plugin.h<br>
-lcms2art/install-sh<br>
-lcms2art/lcms2art.pc.in<br>
-lcms2art/ltmain.sh<br>
-lcms2art/m4/acx_pthread.m4<br>
-lcms2art/m4/ax_append_compile_flags.m4<br>
-lcms2art/m4/ax_append_flag.m4<br>
-lcms2art/m4/ax_check_compile_flag.m4<br>
-lcms2art/m4/ax_gcc_func_attribute.m4<br>
-lcms2art/m4/ax_require_defined.m4<br>
-lcms2art/m4/libtool.m4<br>
-lcms2art/m4/ltoptions.m4<br>
-lcms2art/m4/ltsugar.m4<br>
-lcms2art/m4/ltversion.m4<br>
-lcms2art/m4/lt~obsolete.m4<br>
-lcms2art/missing<br>
-lcms2art/src/Makefile.am<br>
-lcms2art/src/Makefile.in<br>
-lcms2art/src/cmsalpha.c<br>
-lcms2art/src/cmscam02.c<br>
-lcms2art/src/cmscgats.c<br>
-lcms2art/src/cmscnvrt.c<br>
-lcms2art/src/cmserr.c<br>
-lcms2art/src/cmsgamma.c<br>
-lcms2art/src/cmsgmt.c<br>
-lcms2art/src/cmshalf.c<br>
-lcms2art/src/cmsintrp.c<br>
-lcms2art/src/cmsio0.c<br>
-lcms2art/src/cmsio1.c<br>
-lcms2art/src/cmslut.c<br>
-lcms2art/src/cmsmd5.c<br>
-lcms2art/src/cmsmtrx.c<br>
-lcms2art/src/cmsnamed.c<br>
-lcms2art/src/cmsopt.c<br>
-lcms2art/src/cmspack.c<br>
-lcms2art/src/cmspcs.c<br>
-lcms2art/src/cmsplugin.c<br>
-lcms2art/src/cmsps2.c<br>
-lcms2art/src/cmssamp.c<br>
-lcms2art/src/cmssm.c<br>
-lcms2art/src/cmstypes.c<br>
-lcms2art/src/cmsvirt.c<br>
-lcms2art/src/cmswtpnt.c<br>
-lcms2art/src/cmsxform.c<br>
-lcms2art/src/extra_xform.h<br>
-lcms2art/src/lcms2_internal.h<br>
-lcms2art/src/lcms2art.def<br>
-lcms2art/testbed/Makefile.am<br>
-lcms2art/testbed/Makefile.in<br>
-lcms2art/testbed/bad.icc<br>
-lcms2art/testbed/bad_mpe.icc<br>
-lcms2art/testbed/crayons.icc<br>
-lcms2art/testbed/ibm-t61.icc<br>
-lcms2art/testbed/new.icc<br>
-lcms2art/testbed/test1.icc<br>
-lcms2art/testbed/test2.icc<br>
-lcms2art/testbed/test3.icc<br>
-lcms2art/testbed/test4.icc<br>
-lcms2art/testbed/test5.icc<br>
-lcms2art/testbed/testcms2.c<br>
-lcms2art/testbed/testcms2.h<br>
-lcms2art/testbed/testplugin.c<br>
-lcms2art/testbed/testthread.cpp<br>
-lcms2art/testbed/toosmall.icc<br>
-lcms2art/testbed/zoo_icc.c<br>
-lcms2art/utils/common/utils.h<br>
-lcms2art/utils/common/vprf.c<br>
-lcms2art/utils/common/xgetopt.c<br>
-lcms2art/utils/delphi/delphidemo.dpr<br>
-lcms2art/utils/delphi/delphidemo.dproj<br>
-lcms2art/utils/delphi/delphidemo.res<br>
-lcms2art/utils/delphi/demo1.dfm<br>
-lcms2art/utils/delphi/demo1.pas<br>
-lcms2art/utils/delphi/lcms2dll.pas<br>
-lcms2art/utils/jpgicc/LICENSE_iccjpeg<br>
-lcms2art/utils/jpgicc/Makefile.am<br>
-lcms2art/utils/jpgicc/Makefile.in<br>
-lcms2art/utils/jpgicc/iccjpeg.c<br>
-lcms2art/utils/jpgicc/iccjpeg.h<br>
-lcms2art/utils/jpgicc/jpgicc.1<br>
-lcms2art/utils/jpgicc/jpgicc.c<br>
-lcms2art/utils/linkicc/Makefile.am<br>
-lcms2art/utils/linkicc/Makefile.in<br>
-lcms2art/utils/linkicc/linkicc.1<br>
-lcms2art/utils/linkicc/linkicc.c<br>
-lcms2art/utils/matlab/icctrans.c<br>
-lcms2art/utils/matlab/lcms_rsp<br>
-lcms2art/utils/psicc/Makefile.am<br>
-lcms2art/utils/psicc/Makefile.in<br>
-lcms2art/utils/psicc/psicc.1<br>
-lcms2art/utils/psicc/psicc.c<br>
-lcms2art/utils/samples/Makefile.am<br>
-lcms2art/utils/samples/Makefile.in<br>
-lcms2art/utils/samples/itufax.c<br>
-lcms2art/utils/samples/mkcmy.c<br>
-lcms2art/utils/samples/mkgrayer.c<br>
-lcms2art/utils/samples/mktiff8.c<br>
-lcms2art/utils/samples/roundtrip.c<br>
-lcms2art/utils/samples/vericc.c<br>
-lcms2art/utils/samples/wtpt.1<br>
-lcms2art/utils/samples/wtpt.c<br>
-lcms2art/utils/tificc/Makefile.am<br>
-lcms2art/utils/tificc/Makefile.in<br>
-lcms2art/utils/tificc/tifdiff.c<br>
-lcms2art/utils/tificc/tificc.1<br>
-lcms2art/utils/tificc/tificc.c<br>
-lcms2art/utils/transicc/Makefile.am<br>
-lcms2art/utils/transicc/Makefile.in<br>
-lcms2art/utils/transicc/transicc.1<br>
-lcms2art/utils/transicc/transicc.c<br>
-psi/msvc.mak<br>
-psi/os2.mak<br>
-psi/zicc.c<br>
-psi/ztrans.c<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-12 10:56:29 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5ac1a6e73af59d5106bf68ed3ab1a456a1c26dc">b5ac1a6e73af59d5106bf68ed3ab1a456a1c26dc</a>
-<blockquote>
-<p>
- PS interpreter - don't use findresource for Idiom Recognition in bind<br>
-<br>
- The current implementation of idiom recognition uses findresource in<br>
- the definition of the bind operator to check all existing IdiomSets<br>
- for a candidate to substitute.<br>
-<br>
- This is, in fact, wrong. The PLRM (p135 3rd Edition) states that :<br>
-<br>
- &quot;This matching by value occurs only for IdiomSet instances that are<br>
- defined in VM; bind does not consider instances that are in not in VM<br>
- but only in external storage.&quot;<br>
-<br>
- and:<br>
-<br>
- To ensure that the instances in VM are consistent with the external<br>
- ones, the interpreter automatically invokes findresource to load<br>
- external IdiomSet instances into VM at the beginning of each job and at<br>
- certain other times.&quot;<br>
-<br>
- We were not loading the IdiomSet resources into VM, and we were searching<br>
- external resources during bind.<br>
-<br>
- Not only is this incorrect, but because findresource ends up calling<br>
- filenameforall on every directory in the search path, its also very<br>
- slow.<br>
-<br>
- While normally we don't expect to see many occurences of bind during the<br>
- course of a job, the customer supplied file did multiple binds on every<br>
- page, and had &gt; 50,000 pages. This led to a fourfold decrease in<br>
- performance compared to Acrobat Distiller.<br>
-<br>
- Here we load the external resources into gobal VM at startup, and we<br>
- now *only* search instances in VM. This is more correct going by the<br>
- spec, and improves the performance by the desired factor of 4 for the<br>
- customer. It provides a small benefit on cluster testing, which is<br>
- expected as this only affects PostScript input.<br>
-<br>
- No differences expected.<br>
-<br>
-Resource/Init/gs_ll3.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-11 19:58:11 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=338c13198e658b084bbe45930e4837c31102b61f">338c13198e658b084bbe45930e4837c31102b61f</a>
-<blockquote>
-<p>
- ROP Fix: Fix misindexing of scolors/tcolors.<br>
-<br>
- More evidence that this isn't used much.<br>
-<br>
-base/gsroprun8.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-11 18:34:51 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6fda7403e881ec53f2da6bb6f97f2e647ef523c">c6fda7403e881ec53f2da6bb6f97f2e647ef523c</a>
-<blockquote>
-<p>
- ROPs: Squash scan build warnings.<br>
-<br>
-base/gsroprun24.h<br>
-base/gsroprun8.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-10 21:27:32 +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=fc5f089b580040fb70a662e44721fe2fb457ecfa">fc5f089b580040fb70a662e44721fe2fb457ecfa</a>
-<blockquote>
-<p>
- Bug 697545 : Fix new_font_defaults memory leak.<br>
-<br>
- Fix memory leak for allocation event numbers 165 - 180.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=181 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-10 21:10:43 +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=30ca563d890a503fe4411a404d09c36839120114">30ca563d890a503fe4411a404d09c36839120114</a>
-<blockquote>
-<p>
- Bug 697545 : Fix new_font_envir memory leak.<br>
-<br>
- Fix memory leak for allocation event numbers 146 - 161.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=162 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-11 17:43:44 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a706f687ae99626ef5b16b71e5df6a05c202e33">6a706f687ae99626ef5b16b71e5df6a05c202e33</a>
-<blockquote>
-<p>
- ROP fix: Correctly set scolors/tcolors S and T data case.<br>
-<br>
- We weren't setting S and T colors in this particular case of<br>
- the code, which would have shown errors if we'd ever called<br>
- it with S and T being 1 bit data arrays to choose between<br>
- scolors[0] and [1] etc.<br>
-<br>
- It appears that no code in our entire regression suite actually<br>
- calls the S and D both being data case anyway, as proved by<br>
- cluster testing this code with an &quot;abort();&quot; line inserted!<br>
-<br>
-base/gdevmr8n.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-11 17:40:41 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aa8accce0a3f3d323dc45f6bf510a3ddfa76d10d">aa8accce0a3f3d323dc45f6bf510a3ddfa76d10d</a>
-<blockquote>
-<p>
- ROP code: Correction<br>
-<br>
- Don't look for transparency when depth is 1 (it shouldn't be<br>
- used anyway).<br>
-<br>
- Correct transparency handling in 8 bit (it was using 0xffffff<br>
- as the color to check for in this mode). Oddly this wasn't<br>
- producing diffs, which suggests that nothing is exercising<br>
- this code in 8 bit.<br>
-<br>
-base/gsroprun.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-10 20:52:35 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb59c64085552ef0f98c1afdaae3c39ad4e5d421">eb59c64085552ef0f98c1afdaae3c39ad4e5d421</a>
-<blockquote>
-<p>
- Fix stale pointer de-reference during GC due to restore.<br>
-<br>
- If a CIEBasedDEF or DEFG colorspace was set in a save level, a restore<br>
- would free the Table memory, but the pgs-&gt;icc_profile_cache still had<br>
- a (stale) pointer to that area. Fix by copying the Table to memory that<br>
- is not subject to save/restore (stable_memory). Rely on the GC to free<br>
- up the previous table data since we have no idea what allocator was<br>
- used for it (from PostScript it would be local or global VM). Seen with:<br>
- -Z:?@$ -r300 -sDEVICE=psdcmyk -o x.psd tests_private/comparefiles/Bug688308.ps<br>
-<br>
-psi/zcie.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-11 12:03:30 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b3b93ca92f8b9370d4cb5a4e6176df1a06afeda">9b3b93ca92f8b9370d4cb5a4e6176df1a06afeda</a>
-<blockquote>
-<p>
- ROP optimisation: Map more rops onto one another.<br>
-<br>
- Establish an ordering on rops (&quot;unused&quot; &lt; &quot;constant&quot; &lt;<br>
- &quot;bitmap&quot; &lt; &quot;1 bit bitmap&quot;) and swap orders such that S<br>
- is always &gt;= T.<br>
-<br>
- This cuts the number of cases down a bit more.<br>
-<br>
-base/gsroprun.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-02 08:48:33 +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=c56dff6dea636c89b7c24bbec7b28f15171d7810">c56dff6dea636c89b7c24bbec7b28f15171d7810</a>
-<blockquote>
-<p>
- Bug 697545 : Fix pjl_envir memory leak.<br>
-<br>
- Fix memory leak for allocation event numbers 89 - 143.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=144 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-31 14:57:30 +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=411530608129ad6dd2078557a7f3d0a3425a9db8">411530608129ad6dd2078557a7f3d0a3425a9db8</a>
-<blockquote>
-<p>
- Bug 697545 : Fix new_pjl_defaults memory leak.<br>
-<br>
- Fix memory leak for allocation event numbers 32 - 89.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=90 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-10 17:15:38 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=623d2ceee814622b5a75e13120165d8a2f4a2d35">623d2ceee814622b5a75e13120165d8a2f4a2d35</a>
-<blockquote>
-<p>
- ROP transparency optimisation.<br>
-<br>
- If a transparent ROP uses a constant input that is<br>
- transparent, then it's a NOP.<br>
-<br>
-base/gsroprun.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-08 19:10: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=151cb32d94b5790fae44f48763e19c519ac742cb">151cb32d94b5790fae44f48763e19c519ac742cb</a>
-<blockquote>
-<p>
- Miscellaneous fixes to roprun code.<br>
-<br>
- Fold some more rops down to simpler ones.<br>
-<br>
- Remove some functions that are no longer required. Allow<br>
- for NOP ROPs to short circuit all the work.<br>
-<br>
- Also, fix what looks like a problem in the setup for 1bit ROPs.<br>
- (Doesn't actually seem to have caused a problem but the new<br>
- code is more readable).<br>
-<br>
- Avoid intermixing rop_operand * and gx_color_index *'s.<br>
-<br>
-base/gdevm1.c<br>
-base/gdevmr8n.c<br>
-base/gsroprun.c<br>
-base/gsroprun24.h<br>
-base/gsroprun8.h<br>
-base/gsropt.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-09 16:38:04 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3927036c14c12857be7dbf98dc777631a365977e">3927036c14c12857be7dbf98dc777631a365977e</a>
-<blockquote>
-<p>
- Fix problem with bitrgbtags and ROPs.<br>
-<br>
- With bitrgbtags, we can get called to do 24 bit rop operations<br>
- with transparency, with colors like 0x01ffffff.<br>
-<br>
- The transparency rop code is supposed to spot 0xffffff as meaning<br>
- &quot;be transparent&quot;, but the tag in the top byte confuses it.<br>
-<br>
- Accordingly, mask off stray bits in the colors before using them.<br>
-<br>
- The same potentially happens for an 8 bit + tags device so we cope<br>
- with that too.<br>
-<br>
-base/gdevmr8n.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-09 07:19:35 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a8612bfd86f7753fceb738364b2808a4ad9d3bdf">a8612bfd86f7753fceb738364b2808a4ad9d3bdf</a>
-<blockquote>
-<p>
- Fix SEGV DEBUG build with -ZA (tests_private/comparefiles/Bug688308.ps)<br>
-<br>
-base/gsalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-08 12:04:57 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b38e9780bf5cbb9dbf41131efa80887826c59b4">9b38e9780bf5cbb9dbf41131efa80887826c59b4</a>
-<blockquote>
-<p>
- Enable the use of the RUN_ROP code.<br>
-<br>
- I thought this had been done years ago :(<br>
-<br>
- Fix a typo that was causing cluster differences, squash some<br>
- warnings, and fix the scolors/tcolors cases to index as<br>
- gx_color_index *'s rather than byte *'s.<br>
-<br>
- Presumably these are the reasons this didn't get enabled before.<br>
- Cluster shows no differences now.<br>
-<br>
- Tests with running 600dpi grashopp.pcl to ppm show this saves<br>
- ~5.5%.<br>
-<br>
-base/gdevmr8n.c<br>
-base/gsroprun.c<br>
-base/gsroprun24.h<br>
-base/gsropt.h<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-11 19:11:04 +0100
-</strong>
-<br>David Kaspar [Dee'Kej] &lt;dkaspar@redhat.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=731559c56907f223c9f0763d512fae7e4d13e1a0">731559c56907f223c9f0763d512fae7e4d13e1a0</a>
-<blockquote>
-<p>
- Bug 698814: use --docdir= configure parameter<br>
-<br>
- Previously, the Ghostscript was using custom path to the documentation<br>
- (as docdir=$(gsdatadir)/doc). This was causing that value of --docdir=<br>
- parameter of ./configure was accepted, but not used at all.<br>
-<br>
- This commit fixes this issue, by using docdir=@docdir@@VERSIONED_PATH@<br>
- instead. However, as a side effect this results in default path for<br>
- documentation to changed to this (with --prefix=/usr):<br>
-<br>
- /usr/share/doc/ghostscript/&lt;version&gt;/<br>
-<br>
- To stay backward compatible, a symlink is automatically created to<br>
- point from the old location (/usr/share/ghostscript/&lt;version&gt;/doc) to<br>
- the new location.<br>
-<br>
- NOTE: Trying to fix this issue with the location of documentation<br>
- staying as it was would require some hacking inside the Autoconf<br>
- itself, which is not desirable.<br>
-<br>
-Makefile.in<br>
-base/unixinst.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-11 17:27:39 +0100
-</strong>
-<br>David Kaspar [Dee'Kej] &lt;dkaspar@redhat.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0da8eed54f24cf3dcb5f950c742a8072b7c7e01a">0da8eed54f24cf3dcb5f950c742a8072b7c7e01a</a>
-<blockquote>
-<p>
- Bug 698813: do not install examples/ by default anymore<br>
-<br>
- Those files in the examples/ folder are for testing purposes,<br>
- and not really good examples for people trying to learn PostScript.<br>
-<br>
- However, we are keeping the 'make install-examples' target for people<br>
- who still wishes to use those files for some reason.<br>
-<br>
-base/unixinst.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-29 16:42:45 +0100
-</strong>
-<br>David Kaspar [Dee'Kej] &lt;dkaspar@redhat.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb3f2ab6f3c5c1d113a8314c0251ca1e50b1196b">eb3f2ab6f3c5c1d113a8314c0251ca1e50b1196b</a>
-<blockquote>
-<p>
- Bug 698795: --without-versioned-path option introduced<br>
-<br>
- Using this option will result in Ghostscript being installed into a<br>
- paths which do not contain its version in them, which can be useful<br>
- on some distributions.<br>
-<br>
- As a result of using this option, the Ghostscript's search path will<br>
- be updated as well, to include correct files locations.<br>
-<br>
- This option is disabled by default, and configure's help page states<br>
- that using this option is dangerous, risky and unsupported.<br>
-<br>
-Makefile.in<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-06 18:27:24 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c120a33a91c9251c9a9e409680e92d9625a92da">3c120a33a91c9251c9a9e409680e92d9625a92da</a>
-<blockquote>
-<p>
- Back out stray change in last commit.<br>
-<br>
-windows/GhostPDL.sln<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-05 17:04:59 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=47d4d0779563983ab79362acbf3522758ce7a09c">47d4d0779563983ab79362acbf3522758ce7a09c</a>
-<blockquote>
-<p>
- Optimise some image_render_mono cases.<br>
-<br>
- Split a case within image_render_mono into separate portrait<br>
- and landscape cases. Use fill rectangle rather than fill_trap<br>
- to save time, and avoid halftoning where possible.<br>
-<br>
- This saves us about 15% runtime in 1000pages.pcl.<br>
-<br>
-base/gximono.c<br>
-windows/GhostPDL.sln<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-04 17:53:56 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d356025602f3f9f9a1e656bd14430cd95c059548">d356025602f3f9f9a1e656bd14430cd95c059548</a>
-<blockquote>
-<p>
- Tiny additional tweaks to compose groups.<br>
-<br>
- Measurable differences, but only just.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2018-01-04 15:56:55 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=75f389e6b8a2f2bf15ab3044ae4e1ef185061e8d">75f389e6b8a2f2bf15ab3044ae4e1ef185061e8d</a>
-<blockquote>
-<p>
- pdf14 compose group (masked group) optimisation.<br>
-<br>
- The common case is for the mask (if there is one) to entirely<br>
- cover the group we are masking. We can avoid needless<br>
- checking in this case.<br>
-<br>
- This is the case the apple airprint performance test file<br>
- hits and saves &gt; 4% pam, 5% ppm, and 9% pgm.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-29 17:43: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=193e3b87bc711d30be0c2c41f6b3e61f49c92b22">193e3b87bc711d30be0c2c41f6b3e61f49c92b22</a>
-<blockquote>
-<p>
- Fix problem with parsing non 8 bit arguments.<br>
-<br>
- A problem was reported on IRC, pointing out that we fail to<br>
- correctly parse single char switches when we are using<br>
- GS_ARG_ENCODING_UTF16LE.<br>
-<br>
- This is because arg_next was failing to convert non-indirected<br>
- arguments correctly.<br>
-<br>
- Fixed here.<br>
-<br>
-base/gsargs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-29 13:17:49 +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=5907bf4f455cca68cbb405116e3c98d14a5a59d6">5907bf4f455cca68cbb405116e3c98d14a5a59d6</a>
-<blockquote>
-<p>
- Bug 697545 : Fix pjl_state line buffer memory leak.<br>
-<br>
- Fix memory leak for allocation event number 30.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=31 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-29 14:37:20 +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=9ba8351735da67a3064710136499340810c120c1">9ba8351735da67a3064710136499340810c120c1</a>
-<blockquote>
-<p>
- Bug 697545 : Fix pl_main_languages_init interp memory leak.<br>
-<br>
- Fix memory leak for allocation event number 28, the interp_client_data is<br>
- not set so this memory will not be recovered via the normal route of<br>
- pl_deallocate_interp_instance.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=29 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-29 15:34:32 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b940da204752545813c475488a0a7afd7b55fc7">2b940da204752545813c475488a0a7afd7b55fc7</a>
-<blockquote>
-<p>
- Fix LCMS2 optimisation bug<br>
-<br>
- Found this while importing the optimisations here into the MuPDF<br>
- version of LCMS. When copying for identity transformations,<br>
- allow for extra bytes too.<br>
-<br>
- GS clearly doesn't exercise this routine in this way.<br>
-<br>
-lcms2/src/cmsxform.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-23 10:50:11 +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=906314509273578d4fb5382a8d922ccb2b7adb10">906314509273578d4fb5382a8d922ccb2b7adb10</a>
-<blockquote>
-<p>
- Bug 697545 : Fix gs_fapi_init memory leak.<br>
-<br>
- Fix memory leak for allocation event number 13.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=14 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-13 17:28:11 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a089895193d71ad6ad70a91cbf9fe02a121261c">9a089895193d71ad6ad70a91cbf9fe02a121261c</a>
-<blockquote>
-<p>
- Introduce ColorAccuracy setting<br>
-<br>
- Set the level of accuracy that should be used. A setting of 0 will result in less accurate<br>
- color rendering compared to a setting of 2. However, the creation of a transformation<br>
- will be faster at a setting of 0 compared to a setting of 2. Default setting is 2.<br>
-<br>
-base/gsdparam.c<br>
-base/gsicc_cms.h<br>
-base/gsicc_lcms2.c<br>
-base/gsicc_manage.c<br>
-base/gsicc_manage.h<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-28 13:56:37 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4fb32aef42d267948d97243e7f5512a2b37431b0">4fb32aef42d267948d97243e7f5512a2b37431b0</a>
-<blockquote>
-<p>
- XPS interpreter - when discarding an ICC profile for an image, NULL hte pointer<br>
-<br>
- Possibly Bug #698834 &quot; xps dump&quot;<br>
-<br>
- Its not at all clear what the bug reporter sees as a problem, but when<br>
- I run the file to the display the XPS interpreter warns that it is<br>
- discarding an ICC profile because it has the wrong number of<br>
- components (profile has 4 in, 3 out components, image claims to be<br>
- RGB).<br>
-<br>
- This counts the profile reference down by 1 but doesn't set the pointer<br>
- to the profile, saved in the image structure, to NULL leading to us<br>
- trying to free a garbage pointer later.<br>
-<br>
- Setting the pointer to NULL solves the problem, and may fix the bug<br>
- report, if that's what the reporter is complaining about.<br>
-<br>
-xps/xpsimage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-21 19:41:20 +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=32cc4f267175dcc7a0dac0219e8e042ec9918cd9">32cc4f267175dcc7a0dac0219e8e042ec9918cd9</a>
-<blockquote>
-<p>
- Bug 697545 : Fix main instance memory leak.<br>
-<br>
- Fix memory leak for allocation event number 12.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=13 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-20 14:20: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=3b24fd02b2bbeaef3d2e0374023fa330a9cddeac">3b24fd02b2bbeaef3d2e0374023fa330a9cddeac</a>
-<blockquote>
-<p>
- Add 'gs_restrict' to function prototypes to match functions<br>
-<br>
- Also add gs_restrict to some functions, because they are assigned to<br>
- function pointers that expect gs_restrict pointers.<br>
-<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-19 16:15: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=ac7e8dfb78a2b3ae2875f64e6feb6f4dce5300b4">ac7e8dfb78a2b3ae2875f64e6feb6f4dce5300b4</a>
-<blockquote>
-<p>
- More tweaking to pdf14_fill_rect cases.<br>
-<br>
- Ensure that the gray/rgb/cmyk cases for AirPrint all go through<br>
- routines that have been hand tweaked.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-19 18:22:28 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f00a08ec0a7f2fedbc2a7d14c603ec22758ed81c">f00a08ec0a7f2fedbc2a7d14c603ec22758ed81c</a>
-<blockquote>
-<p>
- Avoid shadowing a variable in mark_fill_rect_add3_common.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-19 15:21: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=28c4beb74e779da37c4e7aa7f149750a98c09a73">28c4beb74e779da37c4e7aa7f149750a98c09a73</a>
-<blockquote>
-<p>
- Remove obsolete font files:<br>
-<br>
- NimbusSans-BoldOblique (replaced with NimbusSans-BoldItalic)<br>
- NimbusSans-Oblique (replaced with NimbusSans-Italic)<br>
-<br>
-Resource/Font/NimbusSans-BoldOblique<br>
-Resource/Font/NimbusSans-Oblique<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-19 13:23:42 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9d1e45d36064249220ca2f51280770aaaab3a971">9d1e45d36064249220ca2f51280770aaaab3a971</a>
-<blockquote>
-<p>
- Common up optimised cases of group blending.<br>
-<br>
- Additive and Subtractive make no difference (modulo rounding) when<br>
- dealing with normal mode blends. As such we can halve the number<br>
- of optimised routines required.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-19 10:16:16 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1143a7aba79e6316ccfb5fc2b0943dcd7a64a48f">1143a7aba79e6316ccfb5fc2b0943dcd7a64a48f</a>
-<blockquote>
-<p>
- pdfwrite - drop unusable Matte from SMask when doing colour conversion<br>
-<br>
- Bug #698817 &quot;ColorConversionStrategy=Gray breaks image with smask&quot;<br>
-<br>
- SMask images can have a Matte entry which is a preblended colour. It<br>
- must have the same number of components as the parent image. If we are<br>
- doing colour conversion then we can't unconditionally use the existing<br>
- Matte value, as it may have the wrong number of components for the<br>
- converted image.<br>
-<br>
- In fact Matte values are optional and rare. Even rarer are Matte entires<br>
- which have any actual effect. We can't use the value (unless the parent<br>
- image was already in the target colour space, and we can't realistically<br>
- convert the Matte to another space.<br>
-<br>
- So here we test the color conversion strategy, if the image colour space<br>
- is not the same as the target, then we simply discard the Matte entry.<br>
- This isn't 'correct', but then nothing will be, and this stops Acrobat<br>
- from whinging and refusing to render the image at all.<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-19 09:05:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6e77c8f647fecaa1a31116fbcd59ad26fb650905">6e77c8f647fecaa1a31116fbcd59ad26fb650905</a>
-<blockquote>
-<p>
- pdfimage - eliminate a compiler warning<br>
-<br>
- Check a return code to eliminate a compiler warning.<br>
-<br>
-devices/gdevpdfimg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-18 20:59:39 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fbf0e1c9f7014b602f9dd94e8fac37b21dffc798">fbf0e1c9f7014b602f9dd94e8fac37b21dffc798</a>
-<blockquote>
-<p>
- Add CMYK optimised core to image rendering.<br>
-<br>
- Add irii_inner_32bpp_4spp_1abs to go along with others. This one<br>
- is hit in the AirPrint test file when going to CMYK.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-13 15:37:53 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f34cae2ebb2c85c13787fd828eb6194e32cb19d2">f34cae2ebb2c85c13787fd828eb6194e32cb19d2</a>
-<blockquote>
-<p>
- Optimise image_render_interpolate_icc.<br>
-<br>
- Split out the core of the routine into a function call. The<br>
- guts of the original routine go into irii_inner_template,<br>
- which can be static instantiated as required.<br>
-<br>
- I had hoped that merely instantiating this 3 times would be<br>
- enough to optimise the routines, but in the end I had to<br>
- manually cut the core down for the 2 cases that the AirPrint<br>
- test file hits.<br>
-<br>
-base/gxiscale.c<br>
-windows/GhostPDL.sln<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-18 16:38: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=9fb23615725e8a2d6a722814a348094a48a41c36">9fb23615725e8a2d6a722814a348094a48a41c36</a>
-<blockquote>
-<p>
- pdfimage - support the '%d' output format specifier<br>
-<br>
- It hadn't occurred to me that anyone would want to do this, so I hadn't<br>
- implemented it. On reflection its probably useful, and it should<br>
- (finally) solve the all devices regression report problem.<br>
-<br>
- At the same time, add the file to the Windows solution so that we get<br>
- debug information in it.<br>
-<br>
-devices/gdevpdfimg.c<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-18 15:09:02 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=561327c559cd8fa6cb5840a80806cff38ef9aa0b">561327c559cd8fa6cb5840a80806cff38ef9aa0b</a>
-<blockquote>
-<p>
- Manual optimisation of AirPrint hotspot.<br>
-<br>
- compose_group_nonknockout_nonblend_add_isolated_mask_common_solid<br>
- takes a significant amount of time in the AirPrint test file.<br>
- Unroll it manually and optimise to avoid needless planar -&gt; chunky<br>
- -&gt; planar copying.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-18 11:27:32 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=51f279ece4f34c17119a543725c5aee3ca4f8d1d">51f279ece4f34c17119a543725c5aee3ca4f8d1d</a>
-<blockquote>
-<p>
- Fix pattern code for devices handling patterns by subclassing new device<br>
-<br>
- The pattern code permits for us to use an 'internal' accumulator or for<br>
- a device to declare it can handle patterns itself. When a device handles<br>
- patterns we pass spec_ops to the device to delineate the pattern<br>
- operations.<br>
-<br>
- It can happen that when the pattern terminates we (g)restore back to a<br>
- point before the internal pattern accumulator device was pushed into<br>
- the graphics state. To handle that possibility we push a pointer to the<br>
- device onto the exec stack and use that stored pointer to tell the<br>
- pattern accumulator device when the pattern terminates, even if it is<br>
- no longer the current device at that time.<br>
-<br>
- Unfortunately this conflicts with the ability for other devices to<br>
- handle patterns. The code uses that same stored device pointer to<br>
- indicate whether we are using the internal accumulator or not. If the<br>
- stored pointer is NULL then we are not using the internal accumulator.<br>
-<br>
- But this assumed that, if we aren't using the internal accumulator, that<br>
- the current device is the one which declared it could handle the pattern.<br>
- This is dangerous anyway, because there's not restriction on how fat<br>
- back we might have restored, and its possible (if unlikely) that the<br>
- device now in the graphics state isn't the one that can handle<br>
- patterns. In addition, if the underlying device handles patterns by<br>
- subclassing itself with a new pattern handling device, then when we<br>
- restore back, even though the device is the one which stated it could<br>
- handle patterns, its not the one we want to inform of the pattern<br>
- termination.<br>
-<br>
- We handle this simply by getting the current device after the 'start'<br>
- notification. I think its reasonable to assume that the device now in<br>
- place is the one which expects to receive the 'close' message. We<br>
- then store that device on the exec stack. When we get to the cleanup<br>
- routine, if we decide we are not using the internal accumulator, then<br>
- we call the new stored device to handle it.<br>
-<br>
- I think ideally we should store a flag for whether we are using the<br>
- internal accumulator, but it wouldn't be any more efficient.<br>
-<br>
-psi/zpcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-18 09:11:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=15d80a143b71b9b61d007e2abb67a74a5f753cea">15d80a143b71b9b61d007e2abb67a74a5f753cea</a>
-<blockquote>
-<p>
- pdfimage - change the way files are closed<br>
-<br>
- The 'all devices' regression test persists in throwing errors and<br>
- seg faulting with these devices when closing. I can't reproduce the<br>
- problem on Linux.<br>
-<br>
- So instead of preventing the gdevprn code from closing the file, prevent<br>
- the stream code from closing the file instead, and allow the gdevprn<br>
- code to perform normally.<br>
-<br>
- Hopefully this will solve the problem.....<br>
-<br>
-devices/gdevpdfimg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-18 09:08:58 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9de2f57c80bc9e6a25e3fd570a5c1df3321404eb">9de2f57c80bc9e6a25e3fd570a5c1df3321404eb</a>
-<blockquote>
-<p>
- Check for the existence of _MSV_VER before testing its value<br>
-<br>
- On Linux _MSC_VER is not defined, and so leads to a warning everywhere<br>
- that stdpre.h is included.<br>
-<br>
- This just eliminates the warning.<br>
-<br>
-base/stdpre.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-16 11:01:40 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8af42f2da3425a634ec78d8a0add1658778e2226">8af42f2da3425a634ec78d8a0add1658778e2226</a>
-<blockquote>
-<p>
- Define gs_restrict as a synonym for the compiler 'restrict' definition<br>
-<br>
- Using the 'restrict' tag tells the compiler that it can safely assume<br>
- no aliasing of pointers is involved, allowing for even higher levels<br>
- of optimisation. However since this is a non-standard extension<br>
- (though widely supported) the exact definition varies.<br>
-<br>
- We know of 'restrict', '__restrict', '__restrict__' and 'cdecl(restrict)'<br>
-<br>
- The Visual Studio cdecl causes problems with us simply using 'restrict'<br>
- and #defining it in stdpre.h because stdlib.h includes the cdecl. If<br>
- we include stdpre.h before stdlib.h then the compiler tries to expand<br>
- 'cdecl(resgister)' to 'cdecl(__register)' and that fails.<br>
-<br>
- The only way to accommodate all the various options is to use something<br>
- other than the 'restrict' keyword, and to #define that as required for<br>
- the different compilers.<br>
-<br>
- This commit introduces the 'gs_restrict' keyword and that is #defined<br>
- in stdpre.h to be appropriate for whatever compiler is in use (the<br>
- default is to define it to nothing). This means that wherever we want<br>
- to use the restrict capability, we must include stdpre.h.<br>
-<br>
-base/claptrap-planar.c<br>
-base/claptrap.c<br>
-base/claptrap.h<br>
-base/ets.c<br>
-base/ets.h<br>
-base/gxblend.c<br>
-base/gxblend1.c<br>
-base/gxscanc.c<br>
-base/gxscanc.h<br>
-base/siscale.c<br>
-base/stdpre.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-15 21:01:31 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b35aa4c4e4a8e77395b45051ca2621e6823c5623">b35aa4c4e4a8e77395b45051ca2621e6823c5623</a>
-<blockquote>
-<p>
- Add optimised LCMS transform operations.<br>
-<br>
- Add a full set of optimised functions for {1,3,4} -&gt; {1,3,4}<br>
- channels in either 1 or 2 byte form. This should cover all<br>
- the cases we'll hit in gs until we start using spots.<br>
-<br>
-lcms2/src/cmsxform.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-16 16:10:48 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e8e7034a9714191315313daa4a45ce626a9f6cf7">e8e7034a9714191315313daa4a45ce626a9f6cf7</a>
-<blockquote>
-<p>
- Fix bug 698816: Performance with transparency due to commit 3a9d6eb<br>
-<br>
- Tracked this down to the push_transparency_group logic not skipping the<br>
- allocation of the buffer when &quot;idle&quot; was set. This reduced 32-bit Windows<br>
- 9.22 from 45.9 seconds to 19.9 seconds.<br>
-<br>
- Even more good news, HEAD (SHA 3f9c130f 32-bit Windows) from 37.5 seconds to<br>
- 11.9 seconds.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-15 19:07:07 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3f9c130f778167b2f0486bef1c3a2d027433ec57">3f9c130f778167b2f0486bef1c3a2d027433ec57</a>
-<blockquote>
-<p>
- Optimise pdf14_fill_rectangle for CMYK<br>
-<br>
- Add optimised CMYK case.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-15 11:50:32 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0333c58af9a48a14a0e9323732332104e577dc85">0333c58af9a48a14a0e9323732332104e577dc85</a>
-<blockquote>
-<p>
- Optimise pdf14_fill_rectangle.<br>
-<br>
- Optimisations for the common case as seen in Airprint<br>
- test file.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-15 09:54:15 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b35281f914bb77f5e68070fb6ce4e32e955dcc8">9b35281f914bb77f5e68070fb6ce4e32e955dcc8</a>
-<blockquote>
-<p>
- Add new optimised case for pdf14_fill_rect<br>
-<br>
- mark_fill_rect_additive_nospots_common_no_alpha_g.<br>
-<br>
- For the Airprint test case.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-14 20:06:37 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3dfca86e11ea2143525758325ea0feff06e42a52">3dfca86e11ea2143525758325ea0feff06e42a52</a>
-<blockquote>
-<p>
- Further optimisations to image_render_color_icc.<br>
-<br>
- Split it into 3 routines; portrait, landscape and skew.<br>
-<br>
-base/gxicolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-14 18:42:14 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e0ebcde1ce879cf74fb9d8b53670478d5d03717b">e0ebcde1ce879cf74fb9d8b53670478d5d03717b</a>
-<blockquote>
-<p>
- Optimise image_render_color_icc.<br>
-<br>
- Avoid using the color_samples hack, as this merely results in us<br>
- first copying bytes into a new buffer, only to effectively<br>
- memcmp it. Just use the bytes directly.<br>
-<br>
- We lose potential problems with strict aliasing here, and gain<br>
- the benefit of only having to check n bytes rather than<br>
- GS_IMAGE_MAX_COLOR_COMPONENTS bytes each time.<br>
-<br>
- This gives us a noticable speedup on the Airprint test file.<br>
-<br>
-base/gxicolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-15 15:08:40 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2655f09c04ee2678df98c58764390e9e79bfc254">2655f09c04ee2678df98c58764390e9e79bfc254</a>
-<blockquote>
-<p>
- PCLm fixes<br>
-<br>
- rename the device to 'pclm' because none of our devices use capital<br>
- letters.<br>
-<br>
- Mirror the fix for sclose in the PCLm device (didn't realise this was<br>
- a separate function to the pdfimage devices)<br>
-<br>
- remove the unused writehex function<br>
-<br>
-devices/gdevpdfimg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-15 13:06:47 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3cdca3a2c6cfe74a62797d486ce6c69afd9eacd0">3cdca3a2c6cfe74a62797d486ce6c69afd9eacd0</a>
-<blockquote>
-<p>
- pdfimage devices - remove UUID code<br>
-<br>
- The uuid was a holdover from an early incarnation of the code, it<br>
- was dropped later but the code lingered....<br>
-<br>
-devices/gdevpdfimg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-15 11:21:49 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=44d4d979c25eaea76c2d08aceec058f92ee3ed83">44d4d979c25eaea76c2d08aceec058f92ee3ed83</a>
-<blockquote>
-<p>
- Make pdfimage devices work on Linux<br>
-<br>
- Because the devices usurp the FILE * created by the gdevprn code and<br>
- turn it into a stream, we must set the stored pointer to NULL after<br>
- closing or freeing the stream in order to avoid gdev_prn_close()<br>
- attempting to close the underlying file again, which causes an error<br>
- on Linux.<br>
-<br>
- Also remove some routines we no longer use.<br>
-<br>
-devices/gdevpdfimg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-13 14:19:43 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=86322b1ccb1e67cf99672945f1d77925b2902872">86322b1ccb1e67cf99672945f1d77925b2902872</a>
-<blockquote>
-<p>
- Tweak gx_build_blended_image_row.<br>
-<br>
- Move from an array index based scheme to a pointer arithmetic<br>
- based scheme. Saves us lots of multiplications per pixel.<br>
-<br>
- This may not make much difference on x86, but on ARM, where<br>
- pointer arithmetic is largely free, this should help more.<br>
-<br>
-base/gdevp14.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-14 15:27:11 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=899255deef5a92bf36269d0ef3fa355401fe170f">899255deef5a92bf36269d0ef3fa355401fe170f</a>
-<blockquote>
-<p>
- Further optimisations to bitmap scaler.<br>
-<br>
- Use hand unrolled loops rather than static inline optimised ones.<br>
- Fix some debugging. Add CMYK case. Add some restricts. Make the<br>
- zoom_y case explicit in it's reuse of values.<br>
-<br>
-base/siscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-14 12:45:08 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=16eb526bc113a9c783f824ea6940857e302acc3d">16eb526bc113a9c783f824ea6940857e302acc3d</a>
-<blockquote>
-<p>
- Add restrict qualifier to stdpre.h header.<br>
-<br>
- Sprinkle it through the blending code. This should never hurt<br>
- and may well help. We should be using it as a matter of course,<br>
- especially in performance critical routines.<br>
-<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/stdpre.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-14 12:00:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34286be72308b7cba275bbf423e589997e9e683e">34286be72308b7cba275bbf423e589997e9e683e</a>
-<blockquote>
-<p>
- Fix compiler warnings after pdfimage device commit<br>
-<br>
-devices/devs.mak<br>
-devices/gdevpdfimg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-02 08:24:59 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a13371ec8dc077c4a3b28f6935206fe06fc534e">7a13371ec8dc077c4a3b28f6935206fe06fc534e</a>
-<blockquote>
-<p>
- New devices - pdfimage and PCLm<br>
-<br>
- These devices render input to a bitmap (or in the case of PCLm<br>
- multiple bitmaps) then wraps the bitmap(s) up as the content of<br>
- a PDF file. For PCLm there are some additional rules regarding<br>
- headers, extra content and the order in which the content is<br>
- written in the PDF file.<br>
-<br>
- The aim is to support the PCLm mobile printing standard, and<br>
- to permit production of PDF files from input where the graphics<br>
- model differs significantly from PDF (eg PCL and RasterOPs).<br>
-<br>
- Devices are named pdfimage8, pdfimage24, pdfimage32 and PCLm.<br>
-<br>
- Currently produce valid PDF files with a colour depth of 8 (Gray),<br>
- 24 (RGB) or 32 (CMYK), the PCLm device only supports 24-bit RGB.<br>
-<br>
- Devices supports the DownScaleFactor switch to implement<br>
- page level anti-aliasing<br>
-<br>
- -sCompression can be set to None, LZW, Flate, JPEG or RLE (LZW<br>
- is not supported on PCLm, None is only available on PCLm for<br>
- debugging purposes).<br>
-<br>
- The PCLm device supports -dStripHeight to set the vertical height<br>
- of the strips of image content, as required by the specification.<br>
-<br>
- For JPEG compression the devices support both the JPEGQ and<br>
- QFactor controls, exactly as per the jpeg and jpeggray devices.<br>
-<br>
-base/unixansi.mak<br>
-configure.ac<br>
-devices/devs.mak<br>
-devices/gdevpdfimg.c<br>
-devices/vector/gdevpdfe.c<br>
-doc/Devices.htm<br>
-psi/msvc.mak<br>
-psi/os2.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-13 17:55:16 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=099ba1f50e2af5d43a9f007575e78e3605d008be">099ba1f50e2af5d43a9f007575e78e3605d008be</a>
-<blockquote>
-<p>
- LCMS2 tweak: Spot identity transformations<br>
-<br>
- Spot identity transformations and handle them as efficiently as<br>
- possible. (i.e. avoid unpack/null transform/repack).<br>
-<br>
-lcms2/src/cmsopt.c<br>
-lcms2/src/cmsxform.c<br>
-lcms2/src/lcms2_internal.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-13 09:25:09 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=92f0c389ebddf4125dc770f71f4d74187275fd7f">92f0c389ebddf4125dc770f71f4d74187275fd7f</a>
-<blockquote>
-<p>
- Add 2 more optimised blend cases for Airprint test case.<br>
-<br>
- The Airprint Presentation test file hits the<br>
- compose_group_nonknockout_nonblend_add_isolated_mask_common case<br>
- hardest. Add 2 more specialisations of this that cope with<br>
- shape = 255 and alpha == shape == 255.<br>
-<br>
- This saves us just over half a second (of 13.2) on my desktop PC.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-11 19:52:43 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5189a84ddf0ca1454b10bb4a9926cd4f8c4f0eb">b5189a84ddf0ca1454b10bb4a9926cd4f8c4f0eb</a>
-<blockquote>
-<p>
- Add PWGDecode filter.<br>
-<br>
- And lib/viewpwg.ps to use it.<br>
-<br>
-Makefile.in<br>
-base/lib.mak<br>
-base/spwgd.c<br>
-base/spwgx.h<br>
-base/unix-gcc.mak<br>
-lib/viewpwg.ps<br>
-psi/int.mak<br>
-psi/msvc.mak<br>
-psi/zfilter.c<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-12 17:57:05 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0bdb35346b5a9636bc6c1ca629401ba21232d9bb">0bdb35346b5a9636bc6c1ca629401ba21232d9bb</a>
-<blockquote>
-<p>
- Bug 698808: Fix stack overflow in new scan converter.<br>
-<br>
- Remove some code to split lines. This is no longer needed<br>
- due to the fix for bug 698805, and avoids us getting into the<br>
- stack overflow situation.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-12 01:37:14 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2eb66278cb71b4f97b09300d7c405b8228ebeaf6">2eb66278cb71b4f97b09300d7c405b8228ebeaf6</a>
-<blockquote>
-<p>
- Segv fix for XPS files with trans out to sep device<br>
-<br>
- When going out to a separation device, PCL and XPS should set<br>
- PageSpotColors to 0. For PCL this lets the sep device know<br>
- that there are not any spot colors on the page.<br>
-<br>
- For XPS the situation is a bit more complex. XPS files with named colors<br>
- are very rare. I have never seen one in the wild. Supporting<br>
- the separation of them will require work in the XPS interpreter<br>
- to keep track of the colorants (the names of which are in the colorant<br>
- tags of the ICC profile) and make sure that the values are properly<br>
- mapped to the colorant positions on the output device. We will also<br>
- want to do a pre-parser to count the number of independent colorants<br>
- on the page to ensure proper set up of the device. This is needed<br>
- especially if the page has transparency as the pdf14 device expects to<br>
- have this information. Again running into them in the wild is not going to<br>
- occur. If for some reason it does become an issue in the future,<br>
- we can invest the time in doing the above. In the meantime if they<br>
- are encountered they will be remapped to equivalent CMYK colors instead<br>
- of causing a segv.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-12 18:31:00 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ac1fb2a0580fac884cbf8e07aba4834498a5927a">ac1fb2a0580fac884cbf8e07aba4834498a5927a</a>
-<blockquote>
-<p>
- Fix typo in bug fix for 698805.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-12 09:19: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=0aa901ed39ae5c2a8fbf1107dbbd7d3813cab2ee">0aa901ed39ae5c2a8fbf1107dbbd7d3813cab2ee</a>
-<blockquote>
-<p>
- Check for gdevcups.c before including the cups device<br>
-<br>
- Previously, we were checking for the cups directory, which won't work reliably<br>
- if the build machine also has the cups libraries installed.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-12 16:58:00 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ed2c6957a2ed53aac51e0b7d4209e62f096b8d73">ed2c6957a2ed53aac51e0b7d4209e62f096b8d73</a>
-<blockquote>
-<p>
- Bug 698805: Fix NULL pointer dereference in new scan converter.<br>
-<br>
- Again caused by an integer overflow.<br>
-<br>
- signed sy, ey can differ by more than 0x80000000, which means<br>
- when we subtract them, we can end up with a result with a different<br>
- sign.<br>
-<br>
- Fix by using a safer test.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-01 14:43:43 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ac241e31c931858e562dc0a4cd88db31e012c2cf">ac241e31c931858e562dc0a4cd88db31e012c2cf</a>
-<blockquote>
-<p>
- Fix bug 698662. Elements shifted horizontally when clist is used.<br>
-<br>
- The scurveto clist path reading logic assumed that if the first value<br>
- A, was 0, the previous curve entry was vertical, but the writing logic<br>
- checked for B == 0 and decided to use h*curveto, so if A was also 0,<br>
- the reading logic would assume vertical.<br>
-<br>
-base/gxclpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-08 13:43:36 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=43a84c5d99d14881773b78b58892e9b049b938d9">43a84c5d99d14881773b78b58892e9b049b938d9</a>
-<blockquote>
-<p>
- Bug 698794 detect alpha data in PNG image<br>
-<br>
- We were making the decision as to the presence/absence of<br>
- the alpha data in the PNG image a little early. There<br>
- was one more step related to png_set_tRNS_to_alpha<br>
-<br>
-xps/xpspng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-30 18:41:42 -0500
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ee9656472805dc39a6ed3a8bd097dd04e497c19">4ee9656472805dc39a6ed3a8bd097dd04e497c19</a>
-<blockquote>
-<p>
- Fix PCL init routines to return error code.<br>
-<br>
- And fix calling loop to honour error code. Interestingly<br>
- this calling routine was already set up to do most of the<br>
- hard work here. I wonder if this was once done already?<br>
-<br>
-pcl/pcl/pccolor.c<br>
-pcl/pcl/pccprint.c<br>
-pcl/pcl/pcfont.c<br>
-pcl/pcl/pcfrgrnd.c<br>
-pcl/pcl/pcjob.c<br>
-pcl/pcl/pcmacros.c<br>
-pcl/pcl/pcmisc.c<br>
-pcl/pcl/pcommand.c<br>
-pcl/pcl/pcommand.h<br>
-pcl/pcl/pcpage.c<br>
-pcl/pcl/pcpalet.c<br>
-pcl/pcl/pcparse.c<br>
-pcl/pcl/pcparse.h<br>
-pcl/pcl/pcpatrn.c<br>
-pcl/pcl/pcrect.c<br>
-pcl/pcl/pcsfont.c<br>
-pcl/pcl/pcstatus.c<br>
-pcl/pcl/pcsymbol.c<br>
-pcl/pcl/pctext.c<br>
-pcl/pcl/pcuptrn.c<br>
-pcl/pcl/pcursor.c<br>
-pcl/pcl/pgchar.c<br>
-pcl/pcl/pginit.c<br>
-pcl/pcl/pginit.h<br>
-pcl/pcl/rtgmode.c<br>
-pcl/pcl/rtmisc.c<br>
-pcl/pcl/rtraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-05 13:31:25 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5c851a410c3469860a171420240eb92331dcda9e">5c851a410c3469860a171420240eb92331dcda9e</a>
-<blockquote>
-<p>
- pdfwrite - colour conversion changes<br>
-<br>
- Bug #698723 &quot;convert rgb pdf to cmyk with icc profile yields wrong black&quot;<br>
-<br>
- When converting to a base space colour, and applying the transfer<br>
- function, don't use the old-fashioned colour conversion routines but<br>
- instead use the ICC profile colour management.<br>
-<br>
- With this change in place, the CMYK components in the output file are<br>
- the same as those when rendering to TIFF CMYK output.<br>
-<br>
- I am convinced there is more work to do in this area.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-05 13:27:27 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=775e9d28f78b4b0b5b41a24f4c9fc7f19a9326e3">775e9d28f78b4b0b5b41a24f4c9fc7f19a9326e3</a>
-<blockquote>
-<p>
- pdfwrite - correct a device method<br>
-<br>
- Correct the CMYK colour mapping method to use CMYK and not RGB....<br>
-<br>
-devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-01 17:05:07 -0500
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6edda68e00965c0794fdd408cbc02c1729c374ff">6edda68e00965c0794fdd408cbc02c1729c374ff</a>
-<blockquote>
-<p>
- Rejig gs_fapi_ft_ensure_open to avoid error cleanup SEGV.<br>
-<br>
- Also, aesthetics.<br>
-<br>
-base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-01 14:06:12 -0500
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3d6009573b3562d97f03c0fb6b1463ed0e4d133f">3d6009573b3562d97f03c0fb6b1463ed0e4d133f</a>
-<blockquote>
-<p>
- Memory squeezing fix in pl_load_tt_font.<br>
-<br>
- Fix SEGVs due to memory failures while loading a tt font.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=1402 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null<br>
- ./pcl/examples/owl.pcl<br>
-<br>
- Tweaked version of a commit from Shelley.<br>
-<br>
-pcl/pl/plfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-30 18:40:42 -0500
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc5b750951ee94b2d7e0615dde0122af973f49bb">cc5b750951ee94b2d7e0615dde0122af973f49bb</a>
-<blockquote>
-<p>
- Memento: Fix type of signal handler function.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-02 13:11:42 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d9b9cc6ff0fafed282257fd1bf1ba815726a50e">7d9b9cc6ff0fafed282257fd1bf1ba815726a50e</a>
-<blockquote>
-<p>
- PDF interpreter - another case of incorrect ICCBased profiles<br>
-<br>
- More cases like those tackled in commit<br>
- df5b3426d31f79c13a735dff9118e9798ce97af9 for bugs #696690 and 696120<br>
-<br>
- Again we have an ICCBased colour space where the /N alue does not match<br>
- the actual number of components in the ICC profile. Previously we had<br>
- only seen this with images, the customer file uses a 'cs' operator<br>
- which we weren't catching.<br>
-<br>
- No differences expected.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-16 16:41:22 +0100
-</strong>
-<br>David Kaspar [Dee'Kej] &lt;dkaspar@redhat.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=615b31526d06fcdac7abb9e37deac3ce5fb214b6">615b31526d06fcdac7abb9e37deac3ce5fb214b6</a>
-<blockquote>
-<p>
- man/de - all man pages converted to UTF-8 (from ISO-8859-1)<br>
-<br>
-man/de/dvipdf.1<br>
-man/de/gsnd.1<br>
-man/de/pdf2ps.1<br>
-man/de/printafm.1<br>
-man/de/ps2ascii.1<br>
-man/de/ps2ps.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-01 15:16:19 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=69f4ea2d9d86b9eccf5e3477e4dc9d7d51e1d2d8">69f4ea2d9d86b9eccf5e3477e4dc9d7d51e1d2d8</a>
-<blockquote>
-<p>
- Remove obsolete check_source.py tool....<br>
-<br>
- and its configuration file (testing.cfg.example).<br>
-<br>
- Bug 698780 (related)<br>
-<br>
-toolbin/tests/check_source.py<br>
-toolbin/tests/testing.cfg.example<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-27 10:30:52 +0100
-</strong>
-<br>David Kaspar [Dee'Kej] &lt;dkaspar@redhat.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=efc24229b0ba4b2f6a39fe89a4c9c576dbe7e124">efc24229b0ba4b2f6a39fe89a4c9c576dbe7e124</a>
-<blockquote>
-<p>
- Bug 698784: Fix the alias for Helvetica-Narrow-Bold-Oblique<br>
-<br>
- Init/Fontmap.GS:<br>
-<br>
- There was a misalignment between the filename of the<br>
- NimbusSansNarrow-BdOblique and its /Fontname in the T1 font itself.<br>
-<br>
- Filename: NimbusSansNarrow-BdOblique<br>
- /Fontname: /NimbusSansNarrow-BoldOblique<br>
-<br>
- This worked correctly if the fonts were located directly in<br>
- /usr/share/ghostcript/Resources/Font folder on the filesystem.<br>
-<br>
- However, on Fedora we are using /usr/share/fonts/urw-base35/ folder,<br>
- which is part of Ghostscript's Search Path. In this case it was<br>
- causing the Ghostscript being unable to locate the correct font, thus<br>
- crashing while opening any document containing Helvetica Narrow Bold<br>
- Oblique font...<br>
-<br>
- *In addition*, rename the font file so it matches.<br>
-<br>
-Resource/Font/NimbusSansNarrow-BoldOblique<br>
-Resource/Init/Fontmap.GS<br>
-psi/psromfs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-12-01 13:54: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=8d0ca41749ec3070c6a5c660ab0225b42bcb9eb3">8d0ca41749ec3070c6a5c660ab0225b42bcb9eb3</a>
-<blockquote>
-<p>
- Bug 698741: where the comment says &quot;decrement&quot;, actually decrement<br>
-<br>
- The comment stated we'd move to the end of the row, and work backwards, but<br>
- the code was still working forwards, leading to a buffer overrun.<br>
-<br>
-base/gxicolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-24 22:26:59 +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=caa10a82fcf313dab7426250f59517936fa34964">caa10a82fcf313dab7426250f59517936fa34964</a>
-<blockquote>
-<p>
- Bug 697545 : Memory squeezing fix for double freeing of ToneCurve.<br>
-<br>
- Avoid SEGV by removing unnecessary freeing of ToneCurve.<br>
-<br>
- Error created using :-<br>
- MEMENTO_FAILAT=751 ./membin/gpcl6 -sDEVICE=ppmraw -o /dev/null ./pcl/examples/owl.pcl<br>
-<br>
-lcms2/src/cmsio1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-25 19:08:28 +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=346f1d67dc363195885dd041ede2abb0422c4455">346f1d67dc363195885dd041ede2abb0422c4455</a>
-<blockquote>
-<p>
- Bug 697545 : Memory squeezing fix for gs_enumerate_files_next.<br>
-<br>
- Prevent SEGV by checking for NULL pointer before attempting to<br>
- use it.<br>
-<br>
-base/gsiodev.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-24 19:27:50 +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=d2977a7891f5c84526eefdd25b2167e052fa9c90">d2977a7891f5c84526eefdd25b2167e052fa9c90</a>
-<blockquote>
-<p>
- Bug 697545 : Memory squeezing fix for pjl resources.<br>
-<br>
- Prevent SEGV by checking for NULL pointer before attempting to<br>
- free it.<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-24 15:45:16 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=96030033df28fb89732f58ae4df463f7fc06be5b">96030033df28fb89732f58ae4df463f7fc06be5b</a>
-<blockquote>
-<p>
- Add '-DCLUSTER' mechanism to builds.<br>
-<br>
- For autobuild use --enable-cluster option to configure/autogen.sh.<br>
-<br>
- For windows builds, use CLUSTER=1.<br>
-<br>
- This nobbles pdfwrite to use a '0' time in the produced files.<br>
- This enables us to md5sum intermediate files.<br>
-<br>
- Thanks to Chris for his help with the configure minefield.<br>
-<br>
-Makefile.in<br>
-configure.ac<br>
-devices/vector/gdevpdf.c<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-24 19:06:41 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=949ce4cf61f2ccf1ff39dd2c854aec9f9dad5068">949ce4cf61f2ccf1ff39dd2c854aec9f9dad5068</a>
-<blockquote>
-<p>
- Tiny stylistic tweak.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-24 19:06:26 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=33babeb40a9e73e0cfb1d3b30574e305fa6ee7c7">33babeb40a9e73e0cfb1d3b30574e305fa6ee7c7</a>
-<blockquote>
-<p>
- Squash warning.<br>
-<br>
-pcl/pl/plmain.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-23 22:21:15 +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=8b82d6f99ffda116b328e3ae65c58ee5e056e490">8b82d6f99ffda116b328e3ae65c58ee5e056e490</a>
-<blockquote>
-<p>
- Bug 697545 : Memory squeezing fix for mutex in cms code<br>
-<br>
- Prevent SEGV by checking for NULL mutex pointer before attempting<br>
- to use or destroy it.<br>
-<br>
-lcms2/src/cmserr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-23 22:17:55 +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=a46d319b6edc2bc07b14fbf155b5101bf884fe27">a46d319b6edc2bc07b14fbf155b5101bf884fe27</a>
-<blockquote>
-<p>
- Bug 697545 : Memory squeezing fix in pl_main_delete_instance<br>
-<br>
- Prevent SEGV by checking for NULL value before dereferencing.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-23 17:00:06 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=adfedfa4de0457ecacf5814d4a315fcaee00561d">adfedfa4de0457ecacf5814d4a315fcaee00561d</a>
-<blockquote>
-<p>
- OpenType fonts - regard fonts with multiple GSUB tables as invalid<br>
-<br>
- Bug #697627 &quot;IO in gs_notify_all function&quot;<br>
-<br>
- The bug title is a misnomer; the actual problem is that we have a badly<br>
- corrupted font which appears to have 2 GSUB tables. This causes us to<br>
- allocate two chunks of memory to hold the tables, losing the original<br>
- reference when we allocate the second, and also to register the font<br>
- to have the GSUB table released twice.<br>
-<br>
- Trying to release the same memory twice leads to us trying to access<br>
- invalid memory, and therefore to a seg fault.<br>
-<br>
- So if we find we have a GSUB, and we've already allocated memory for a<br>
- GSUB table, just throw an error.<br>
-<br>
- Chris thinks it may be possible to legally have multiple GSUB tables, if<br>
- we ever find such a thing we'll have to rethink this.<br>
-<br>
-base/gstype42.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-23 09:40:36 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3ad236df1e509d0326a1fa31c98e068b5712fd75">3ad236df1e509d0326a1fa31c98e068b5712fd75</a>
-<blockquote>
-<p>
- Bug 698773: Cope with &quot;charstring&quot; of invalid type<br>
-<br>
- This file has a font whose CharStrings dictionary contains:<br>
- /space 3 def<br>
-<br>
- Ideally, when we hit such a case, we should fallback to the .notdef glyph,<br>
- unfortunately, it also has:<br>
- /.notdef 0 def<br>
-<br>
- We *should* throw an error since this is clearly totally invalid, but other<br>
- interpreters *appear* to simply ignore the problem. So, we opt to return an<br>
- empty charstring.<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-23 13:32:26 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f32c03a2daad2d2e0e859bd6fc7547b68bd8bed9">f32c03a2daad2d2e0e859bd6fc7547b68bd8bed9</a>
-<blockquote>
-<p>
- Do not ignore errors from the device's fill_rectangle_hl_color method<br>
-<br>
- Spotted by Robin while fixing indeterminisms, we currently ignore any<br>
- error return from this method in pattern_accum_fill_rectangle_hl_color()<br>
- when it calls its target device. Adding a check and error propagation is<br>
- simple enough, but that then reveals problems with the high level<br>
- devices.<br>
-<br>
- There are, in fact, several problems here. Firstly, the mem* devices<br>
- which are used to render pattern tiles (amongst other things) are<br>
- based on forwarding devices. When we send a spec_op we forward this to<br>
- the 'underlying' device. This is a problem if the spec_op is querying<br>
- whether the device can handle hl_color, because if it can then the<br>
- caller may proceed to use hl_color methods. But the mem* devices cannot<br>
- handle these methods and obviously can't forward them to the underlying<br>
- device, resulting in an error. Fixed this one by using the default<br>
- spec_op method instead of the forwarding one. In future this may require<br>
- further attention.<br>
-<br>
- The NULL device doesn't implement fill_rectangle_hl_color. In fact, with<br>
- the changes elsewhere it doesn't need to, but really we should simply<br>
- handle this in the same way as fill_rectangle and return, all the null<br>
- device does is bit bucket all operations. For completeness, implement<br>
- such a method.<br>
-<br>
- gx_erase_colored_pattern() didn't do a restore (to match its save) if<br>
- an error occurred. Again, with the other changes this is no longer<br>
- triggered, but it does seem wrong so lets fix it.<br>
-<br>
- In gx_pattern_load() and pattern_paint_prepare(), avoid erasing the<br>
- background of the tile if the pattern instance is for a device which<br>
- handles patterns itself (eg pdfwrite). Once again, not really required<br>
- now that the mem* devices don't pass on the spec_op to the underlying<br>
- device, but it saves us bothering with erasing a rectangle which we are<br>
- going to throw away anyway.<br>
-<br>
- Finally, the point of the whole exercise, in<br>
- pattern_accum_fill_rectangle_hl_color(), check the return code from the<br>
- target device's fill_rectangle_hl_color and if its an error, return it.<br>
-<br>
-base/gdevmem.c<br>
-base/gdevnfwd.c<br>
-base/gxpcmap.c<br>
-psi/zpcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-22 21:29:04 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1cfc56251773304fb102237ff8a63c5576f08fe7">1cfc56251773304fb102237ff8a63c5576f08fe7</a>
-<blockquote>
-<p>
- Rewritten version of squeeze2html.pl<br>
-<br>
- This works with the latest memento, and gives nicer results in<br>
- the browser.<br>
-<br>
- Invoke using something like:<br>
-<br>
- MEMENTO_SQUEEZEAT=1 membin/gs -sDEVICE=ppmraw -o /dev/null<br>
- in.pdf |&amp; perl toolbin/squeeze2html.pl -q | gzip -9c &gt; out.html.gz<br>
-<br>
-toolbin/squeeze2html.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-22 17:57: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=276a386da36926cf36942528146b4294a5ff9d6d">276a386da36926cf36942528146b4294a5ff9d6d</a>
-<blockquote>
-<p>
- Coverity IDs 127198, 127199<br>
-<br>
- Check return values and handle errors accordingly.<br>
-<br>
-pcl/pcl/pctext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-22 18:02:26 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd35e58feccf543129bc108857b16fd43d627d02">dd35e58feccf543129bc108857b16fd43d627d02</a>
-<blockquote>
-<p>
- Fix indeterminism caused by buffer overrun in thresholding.<br>
-<br>
- Running:<br>
-<br>
- gs -sOutputFile=out%d.pbm -dMaxBitmap=400000000 -sDEVICE=pbmraw -r300<br>
- -sDEFAULTPAPERSIZE=letter -dNOPAUSE -dBATCH -K2000000 -dClusterJob<br>
- -dJOBSERVER /home/marcos/cluster/tests_private/pdf/uploads/Bug698519.pdf<br>
-<br>
- then catting out{1,2,3,4,5}.pbm together and md5summing it gives a<br>
- different result to running the above job direct to out.pbm.<br>
-<br>
- After much nightmarish debugging, it transpires that this is because<br>
- the special case in the SSE thresholding code that spots the 200%<br>
- scale case is being triggered incorrectly.<br>
-<br>
- The image is 1753 pixels wide, which would be 3506 pixels at 200%.<br>
- We actually display it at 3507 pixels. The code was triggering the<br>
- 200% case by calculating a scale_factor value of fixed_half (128).<br>
-<br>
- The rounding here was causing a false positive.<br>
-<br>
- Instead, we skip the calculation and check by directly comparing<br>
- source and dest sizes.<br>
-<br>
-base/gxicolor.c<br>
-base/gximono.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-21 12:48:54 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=362ec9daadb9992b0def3520cd1dc6fa52edd1c4">362ec9daadb9992b0def3520cd1dc6fa52edd1c4</a>
-<blockquote>
-<p>
- Fix bug 697459 Buffer overflow in fill_threshold_buffer<br>
-<br>
- There was an overflow check for ht_buffer size, but none for the larger<br>
- threshold_buffer. Note that this file didn't fail on Windows because the<br>
- combination of the ht_buffer and the size of the (miscalculated due to<br>
- overflow) threshold_buffer would have exceeded the 2Gb limit.<br>
-<br>
-base/gxht_thresh.c<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-21 19:27:19 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=68fa913b5bc06a4250115f52835cadc5493aab12">68fa913b5bc06a4250115f52835cadc5493aab12</a>
-<blockquote>
-<p>
- Avoid warning.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-21 19:24:04 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=853737363b7b7cd1eab4da68ba8f83b7dfb5f453">853737363b7b7cd1eab4da68ba8f83b7dfb5f453</a>
-<blockquote>
-<p>
- clist tweak: Pass &amp;var to macros if the value of var is updated.<br>
-<br>
- Otherwise it's hard for someone unfamiliar with the macros to see<br>
- what is going on.<br>
-<br>
-base/gxclbits.c<br>
-base/gxcldev.h<br>
-base/gxclimag.c<br>
-base/gxclpath.c<br>
-base/gxclrect.c<br>
-base/gxclutil.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-21 17:40:53 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ce5c3f42d8bd062da65d592abdaaeea90b901970">ce5c3f42d8bd062da65d592abdaaeea90b901970</a>
-<blockquote>
-<p>
- Ensure that single component planar devices can cope with hl_color.<br>
-<br>
- As part of tracking down indeterminisms in the cluster, I found that:<br>
-<br>
- gs -sBandListStorage=file -sOutputFile=out%d.psd -dMaxBitmap=10000<br>
- -sDEVICE=psdcmyk -r300 -Z: -sDEFAULTPAPERSIZE=letter -dNOPAUSE<br>
- -dBATCH -K2000000 -dClusterJob -dJOBSERVER -ZL<br>
- tests_private/pdf/sumatra/586_-_missing_images_gs_SMask_not_applied.pdf<br>
-<br>
- was hitting a case where we were writing a pattern tile into the<br>
- clist that hadn't been initialised at all. This was because all<br>
- the writes to the pattern accumulator went through<br>
- pattern_accum_fill_rectangle_hl_color. This passes the hl_color<br>
- data to the memory devices fill_rectangle_hl_color function, and<br>
- fills the mask with 1s.<br>
-<br>
- The mask was being entirely filled with 1s and so was being discarded<br>
- as unnecessary. Unfortunately the devices fill_rectangle_hl_color<br>
- entrypoint was left as the default which does nothing by raise an<br>
- error.<br>
-<br>
- The fix here is to ensure that when we open a planar device, we<br>
- always add in a suitable fill_rectangle_hl_color function, even<br>
- when the device is superficially the same as a chunky one.<br>
-<br>
- Thanks are due to Michael and Ray for their help with tracking this<br>
- down.<br>
-<br>
-base/gdevmpla.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-21 16:46:18 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=19ebb5f1f497b6f2d50fe13d17d3e627dfb6c868">19ebb5f1f497b6f2d50fe13d17d3e627dfb6c868</a>
-<blockquote>
-<p>
- PS interpreter - restore the flushpage operator<br>
-<br>
- Michael Katzmann, working at the Library of Congress, is using<br>
- Ghostscript in a custom application, which also involves a barcode<br>
- reader and an SQL database.<br>
-<br>
- Currently this resides in an RPM at:<br>
-<br>
- http://engineering.nlsbph.org/repo/fedora/fedora/updates/27/SRPMS/AddressCard-3.17-LoC.fc27.src.rpm<br>
-<br>
- but its not usable without the barcode reader and SQL database....<br>
- For reasons which are not completely clear to me, he wants to use<br>
- flushpage to update the display part way through the operation.<br>
-<br>
- We suspect that it would be possible to avoid this, but it would<br>
- probably require some programming effort on the users part, and since<br>
- flushpage doesn't look like a likely candidate for abuse, we've decided<br>
- just to restore it.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-21 14:13:21 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=37a9d25214efcabe0f36ed4cf6e91c58fcdbfa2d">37a9d25214efcabe0f36ed4cf6e91c58fcdbfa2d</a>
-<blockquote>
-<p>
- PDF interpreter - move a default value to be compatible with all xref types<br>
-<br>
- The commit df5b3426d31f79c13a735dff9118e9798ce97af9 which works around<br>
- PDF files where the /N value and the actual ICC profile colour space<br>
- number of components do not match.<br>
-<br>
- Unfortunately, I made a minor error when creating this, which wasn't<br>
- exposed by the test files on hand at the time. I set the default value<br>
- of ICCProfileNError to false when processing an xref of type 'orig'<br>
- (ie not an xref stream) which means that for PDF files which use xref<br>
- streams the value was not defined, leading to an error.<br>
-<br>
- Move the initial declaration to pdfopenfile instead so that it works<br>
- no matter what type of xref we have,.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-05 16:16:46 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d7893955cf4231c092045affc32e26ad2b6de32">1d7893955cf4231c092045affc32e26ad2b6de32</a>
-<blockquote>
-<p>
- Fix bug 696845 SEGV with --saved-pages-test and transparency<br>
-<br>
- When a file pushes a pdf14devicefilter (or other compositor) it will<br>
- still be the currentdevice after the filter is popped when the saved<br>
- pages printing occurs. We need to check if the device is a forwarding<br>
- device (as compositors will be when deactivated) and use the target<br>
- device to print the saved pages.<br>
-<br>
- Also, if a device uses the gx_default_dev_spec_op, it will return 0<br>
- from the supports_saved_pages call even when it is a printer device.<br>
- In gdev_prn_forwarding_dev_spec_op, check for a zero return and return<br>
- true (1). A device that is a printer device that doesn't support saved<br>
- page printing needs to return &lt; 0 to prevent this.<br>
-<br>
- Add a finalize method for gx_device_printer so we can free up the saved-<br>
- pages-list when the device is freed, but not when the device is closed<br>
- which can happen if it needs to close due to put_params. Also the<br>
- return code from the output_page in gx_saved_page_params_process was<br>
- ignored. Both seen with the file Bug687111.ps and the psdcmyk device.<br>
-<br>
- Also for devn devices, such as psdcmyk, we need to save the separation<br>
- (spot color) names collected during the execution of setcolorspace in<br>
- the gx_saved_page and set them in the devn_params when rendering. These<br>
- are not handled by the paramlist.<br>
-<br>
- Disable --saved-pages= and --saved-pages-test with PCL and XPS since it<br>
- was never completely implemented and the partial implementation causes<br>
- many errors when tested with --saved-pages-test. Note that while the<br>
- --saved-pages-test option is still accepted as a parameter, it is ignored<br>
- so that regression testing with --saved-pages-test can run.<br>
-<br>
- Regression shows 3343 &quot;diffs&quot;, but bmpcmp doesn't show any diffs.<br>
-<br>
-base/gdevp14.c<br>
-base/gdevprn.c<br>
-base/gdevprn.h<br>
-base/gxclist.h<br>
-base/gxclpage.c<br>
-base/lib.mak<br>
-examples/transparency_example.ps<br>
-pcl/pl/plmain.c<br>
-psi/imain.c<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-20 14:33: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=1b64014143a8a571e5dbff3346c6ad902603dda1">1b64014143a8a571e5dbff3346c6ad902603dda1</a>
-<blockquote>
-<p>
- Fix release/debug difference.<br>
-<br>
- In searching for the indeterminism in 11-14.PS, I found that I could<br>
- run the same command line in release and debug builds on peeved, and<br>
- get different results:<br>
-<br>
- touch out1.pgm ref1.pgm &amp;&amp; rm out*.pgm ref*.pgm &amp;&amp;<br>
- bin/gs -sOutputFile=ref%d.pgm -dMaxBitmap=10000 -sDEVICE=pgmraw -r300<br>
- -Z: -sDEFAULTPAPERSIZE=letter -dNOPAUSE -dBATCH -K2000000 -dClusterJob<br>
- -dJOBSERVER %rom%Resource/Init/gs_cet.ps cutdown &gt;&amp; ~/log &amp;&amp;<br>
- debugbin/gs -sOutputFile=out%d.pgm -dMaxBitmap=10000 -sDEVICE=pgmraw<br>
- -r300 -Z: -sDEFAULTPAPERSIZE=letter -dNOPAUSE -dBATCH -K2000000<br>
- -dClusterJob -dJOBSERVER %rom%Resource/Init/gs_cet.ps cutdown<br>
- &gt;&amp; ~/log2 &amp;&amp; md5sum ref*.pgm out*.pgm &amp;&amp; less ~/log ~/log2<br>
-<br>
- After cutting down the file as much as I could, Chris reduced it<br>
- simply to:<br>
-<br>
- 3E9 3E9 moveto 1 1 lineto stroke showpage<br>
-<br>
- Thanks for this!<br>
-<br>
- Tracing through the code, I discovered that the difference came down<br>
- to check_diff_overflow, where the release build was assuming that if<br>
- v1 &gt; v0, v0 - v1 &lt; 0, which is acceptable because v0 - v1 has<br>
- overflown, at which point C says the value is unpredictable.<br>
-<br>
- The fix is to detect the overflow before it happens.<br>
-<br>
-base/gxpflat.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-20 13:51:16 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cea5d8a72dab953fe84ab8f7280003d377559fff">cea5d8a72dab953fe84ab8f7280003d377559fff</a>
-<blockquote>
-<p>
- pdfwrite - Fix typo in on=-page checks for annotations with PDF/X<br>
-<br>
- Bug #698765 &quot;PDF/X Compliance Check Fails with Ghostscript generated PDF&quot;<br>
-<br>
- The upper-right y bound check was incorrect, leading to an incorrect<br>
- decision that an annotation was off the page.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-20 09:51:27 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f9d41654ff0f52b6f42e5eff3215cf183261cffa">f9d41654ff0f52b6f42e5eff3215cf183261cffa</a>
-<blockquote>
-<p>
- Coverity ID 203245 - remove redundant NULL check<br>
-<br>
- The changes which fixed the device method API mean that its no longer<br>
- required to check that dev is not NULL in this routine.<br>
-<br>
-base/gdevsclass.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-17 15:42: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=7b04e4d7b85769169db94f1b0ed72474211ba27a">7b04e4d7b85769169db94f1b0ed72474211ba27a</a>
-<blockquote>
-<p>
- Add another PACIFY_VALGRIND section<br>
-<br>
- Avoid warnings in 586_-_missing_images_gs_SMask_not_applied.pdf<br>
-<br>
-base/gxclist.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-17 15:26:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c5f770b5c64cf7a2f3a0f3c447c089a089a695d1">c5f770b5c64cf7a2f3a0f3c447c089a089a695d1</a>
-<blockquote>
-<p>
- Documentation - Restore the documentation on DELAYBIND and friends<br>
-<br>
- Since we've reinstated DELAYBIND, reinstate the documentation to go<br>
- with it. Also include the helpers .bind and .bindnow.<br>
-<br>
-doc/Language.htm<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-16 20:37:41 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d9c9bea4ecf31e06bcf52d433b632ce0b6b1b239">d9c9bea4ecf31e06bcf52d433b632ce0b6b1b239</a>
-<blockquote>
-<p>
- Fix buffer overrun in gp_enumerate_files_next.<br>
-<br>
- If pattern=&quot;*&quot; and patlength = 1, then pathead = 1.<br>
-<br>
- When we look for any following subdirectory, the code attempts<br>
- to look for the next subdirectory name. To do this it starts<br>
- searching from the byte after the position of the current '/'.<br>
- Unfortunately, if the string ends at the current wildcard, we<br>
- don't have a '/', we have a NUL terminator. This means the<br>
- current code starts looking just after that.<br>
-<br>
- In code terms this means the current code accesses at<br>
- pattern + pathead + 1, without checking pattern[patthead] first.<br>
- This is a simple fix.<br>
-<br>
- We also take this opportunity to simplify a couple of while loop<br>
- conditions. The extra negation is too much for my tiny brain to<br>
- cope with.<br>
-<br>
-base/gp_unifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-16 20:01:57 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f27b751a1662c3ca8ef64c164cf3f9a400dd416b">f27b751a1662c3ca8ef64c164cf3f9a400dd416b</a>
-<blockquote>
-<p>
- Add SINGLE_OBJECT_MEMORY_BLOCKS_ONLY logic.<br>
-<br>
- If SINGLE_OBJECT_MEMORY_BLOCKS_ONLY is defined at<br>
- build time, then we restrict every clump/chunk to<br>
- have just a single object in it. This makes<br>
- valgrind debugging easier as the allocation given<br>
- for when 'undefined' values were created is far<br>
- more likely to be correct.<br>
-<br>
-base/gsalloc.c<br>
-base/gsmchunk.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-16 20:00: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=1e1b4dc73087212abd1c6c9bee3192a1fc6bf630">1e1b4dc73087212abd1c6c9bee3192a1fc6bf630</a>
-<blockquote>
-<p>
- Add some PACIFY_VALGRIND to quash some warnings.<br>
-<br>
- 11-14.PS trips some valgrind warnings where we<br>
- write structures into the clist without having<br>
- cleared the padding in the structures.<br>
-<br>
-base/gsptype1.c<br>
-base/gxclimag.c<br>
-base/gxclist.c<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-16 21:51: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=e93a58466a78aab89e065bdae2d6b77db5620692">e93a58466a78aab89e065bdae2d6b77db5620692</a>
-<blockquote>
-<p>
- pdfwrite - fix instance UUID<br>
-<br>
- Bug #698757 &quot;Instance UUID truncated&quot;<br>
-<br>
- Should have spotted and fixed this at the same time as Bug #697977<br>
- but missed it. As noted in the bug report its practically the same code<br>
- and had the exact same problem.<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-16 13:38:59 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b76dc2d704fcc00edc8c1fd8ae19d01a36e22c49">b76dc2d704fcc00edc8c1fd8ae19d01a36e22c49</a>
-<blockquote>
-<p>
- ps2write - fix string splitting for output formatting<br>
-<br>
- Bug #698708 &quot;Ghostscript loops&quot;<br>
-<br>
- When writing output for ps2write, we limit the output width to 255<br>
- characters. If a string is longer than that we try to split it on<br>
- PostScript tokens. If we can't do that then we just break at 255<br>
- characters and stick in a newline.<br>
-<br>
- The logic in here however was flawed however, it failed to update the<br>
- pointer 'p' which points to the character currently being processed<br>
- and did not reset the width count to 0 when the string was output.<br>
-<br>
- This could lead to us in an infinite loop.<br>
-<br>
-devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-16 11:29:47 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=01ce294445f7988f51f63108d53a89df003f2b1e">01ce294445f7988f51f63108d53a89df003f2b1e</a>
-<blockquote>
-<p>
- Fix tiffsep1 device after device API repair<br>
-<br>
- commit dd820be was over-enthusiastic with the tiffsep1 device, and tried<br>
- to use the device procs accessor on a device struct member other than<br>
- 'procs' with predictably unfortunate effects.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-16 10:28:28 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa499a5809aab45b2891b5c8b2363d1bca890757">fa499a5809aab45b2891b5c8b2363d1bca890757</a>
-<blockquote>
-<p>
- PS interpreter - add warnings for DELAYBIND and WRITESYSTEMDICT<br>
-<br>
- We've seen people using these options in an inappropriate fashion<br>
- and with SAFER set as well. Clearly there is confusion about how to use<br>
- these.<br>
-<br>
- If the user selects SAFER, and selects an option which is liable to<br>
- make it possible for PostScript to evade the SAFER file system access<br>
- restrictions, then emit a warning reminding the user to 'lock' the<br>
- unsafe option down.<br>
-<br>
- Also restore the old behaviour of DELAYBIND and remove the<br>
- REALLYDELAYBIND switch. We have heard from the 'pstoedit' maintainer<br>
- and that tool requires the use of both DELAYBIND and WRIESYSTEMDICT.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-15 16:49:41 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd820bbe7f53e051add94dbcdc779dae1820e0d6">dd820bbe7f53e051add94dbcdc779dae1820e0d6</a>
-<blockquote>
-<p>
- Device method repair - use accessors throughout<br>
-<br>
- A lot of places accessed device methods directly, instead of using the<br>
- accessor macros. Update all the code to use the accessors.<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevmpla.c<br>
-base/gdevnfwd.c<br>
-base/gdevp14.c<br>
-base/gdevprn.c<br>
-base/gdevsclass.c<br>
-base/gdevvec.c<br>
-base/gsdevice.c<br>
-base/gsdparam.c<br>
-base/gsicc_manage.c<br>
-base/gxclist.c<br>
-base/gxclrect.c<br>
-base/gxcmap.c<br>
-base/gxdevice.h<br>
-base/gxfapi.c<br>
-base/gxfill.c<br>
-base/gxp1fill.c<br>
-base/gxpcmap.c<br>
-devices/gdevdsp.c<br>
-devices/gdevplib.c<br>
-devices/gdevtifs.c<br>
-devices/gdevtsep.c<br>
-devices/gdevwpr2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-12 11:10:49 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c9951359bde5c4e72a20624788a47a97872db090">c9951359bde5c4e72a20624788a47a97872db090</a>
-<blockquote>
-<p>
- Repair the device API - device methods should never be NULL<br>
-<br>
- The original intention of the device API was that device methods (with<br>
- the odd exception of fill_rectangle) must not be NULL. That appears<br>
- to have been broken with the introduction of the transparency<br>
- compositor, with the result that the code now:<br>
-<br>
- 1) has to check for methods being NULL sometimes, because that causes<br>
- crashes.<br>
-<br>
- 2) Uses a device method being NULL to determine code paths.<br>
-<br>
- We want to return the device method design, because having to check for<br>
- NULL methods before calling is wasteful.<br>
-<br>
- In this commit:<br>
-<br>
- define default methods for all the methods that previously did not have<br>
- one.<br>
-<br>
- Modify gx_device_fill_in_procs to include those defaults in the device<br>
- methods which it checks for NULL and replaces.<br>
-<br>
- Finding all the places where the code path differs if a device method<br>
- is NULL, alter to check against the default method instead.<br>
-<br>
- Remove NULL checks where they are no longer required. Device whose<br>
- 'procs' get copied directly (clist) must have defaults for all methods.<br>
-<br>
- Fix gx_copy_device_procs so that we only special case (don't replace<br>
- the method) for those few methods where it matters that the subclassing<br>
- device must have the default method if the subclassed device does. Long<br>
- term we should change the code not to rely on this!<br>
-<br>
- Remove a couple of macros that were not required or plain dumb.<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevmem.c<br>
-base/gdevnfwd.c<br>
-base/gdevp14.c<br>
-base/gdevprn.c<br>
-base/gdevsclass.c<br>
-base/gdevvec.c<br>
-base/gscspace.c<br>
-base/gsdevice.c<br>
-base/gsdparam.c<br>
-base/gsicc_manage.c<br>
-base/gsovrc.c<br>
-base/gspaint.c<br>
-base/gstrans.c<br>
-base/gxblend1.c<br>
-base/gxclist.c<br>
-base/gxclrect.c<br>
-base/gxdevice.h<br>
-base/gxfapi.c<br>
-base/gxiscale.c<br>
-base/gxp1fill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-14 20:27:07 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e2565e030eb37a25459671cfa9119715f3a0aae4">e2565e030eb37a25459671cfa9119715f3a0aae4</a>
-<blockquote>
-<p>
- New &quot;planr&quot; device. 1 bit per component, RGB, planar device.<br>
-<br>
-base/gdevmem.c<br>
-base/unix-gcc.mak<br>
-devices/devs.mak<br>
-devices/gdevplan.c<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-15 19:17:05 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a8b1611e7613781cd5c2c7defa2c5315254d9d1d">a8b1611e7613781cd5c2c7defa2c5315254d9d1d</a>
-<blockquote>
-<p>
- Fix operation of 1bpc, 3 component halftones.<br>
-<br>
- In the chunky world, it makes no sense to deal with 3 bit rgb as<br>
- this doesn't pack neatly into a byte. You'd do it by handling<br>
- 4 bit chunks.<br>
-<br>
- Accordingly, parts of Ghostscript are written to assume that you'd<br>
- not do anything this crazy.<br>
-<br>
- Unfortunately, in the planar world, a 1 bpc, 3 component device<br>
- does make (some) sense. Sadly, stuff like the halftone generation<br>
- gets deeply confused by this.<br>
-<br>
- Here we fix 2 specific instances of this problem. In the halftone<br>
- generation, we generate 3bit chunky halftones as 4 bit ones, and in<br>
- the planar_copy_color routines, we assume that 3 bit data is<br>
- actually 4 bit (as a) it probably comes from these routines, and<br>
- b) if it doesn't it'd be packed as 4 bit in any sane world).<br>
-<br>
-base/gdevmpla.c<br>
-base/gxcht.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-15 17:08:58 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fac14b8c25422529acded1e9e920eb20190db340">fac14b8c25422529acded1e9e920eb20190db340</a>
-<blockquote>
-<p>
- clusterpush.pl: Add smoke option<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-15 17:26:35 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ae6f20152ab1e0860952dbeee979ef2c0f195269">ae6f20152ab1e0860952dbeee979ef2c0f195269</a>
-<blockquote>
-<p>
- Fix st_device_vector_max_ptrs.<br>
-<br>
- This should be +4, not +3, but this value appears to be pretty<br>
- much unused, so nothing matters at the moment. It is used by<br>
- st_device_psdf_max_ptrs, but nothing uses that either.<br>
-<br>
- We may remove both of these definitions in future.<br>
-<br>
-base/gdevvec.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-15 17:12:09 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb5726a74bbfbbd2e17b344eb4bc0385d514d4c1">bb5726a74bbfbbd2e17b344eb4bc0385d514d4c1</a>
-<blockquote>
-<p>
- Memento: Add Memento_sequence<br>
-<br>
-base/memento.c<br>
-base/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-15 09:03:27 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d046e24bd2894cf80785bede733006dd53746a07">d046e24bd2894cf80785bede733006dd53746a07</a>
-<blockquote>
-<p>
- PostScript interpreter - silence compiler warning<br>
-<br>
- Prototype a function to silence a compiler warning. Also, make the<br>
- function static since it isn't used elsewhere.<br>
-<br>
-psi/zarith.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-13 11:05:04 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=143a892226b79676f5f8853f63532f9e6f4e8f5e">143a892226b79676f5f8853f63532f9e6f4e8f5e</a>
-<blockquote>
-<p>
- Avoid buffer overflow in GraphicsAlphaBits cdoe with planar device.<br>
-<br>
- In GraphicsAlphaBits, we get the pixels from the underlying device<br>
- (in chunky format). The buffer we get that data into was sized<br>
- according to get_device_raster(dev, false), which (for a planar<br>
- device) returns the size for line of planar data. We want the<br>
- size for one line of chunky data, so use get_device_raster_chunky<br>
- instead.<br>
-<br>
-base/gdevdbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-13 09:07:03 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5fe97ce30de048027da19a85bc574a8adfcf2116">5fe97ce30de048027da19a85bc574a8adfcf2116</a>
-<blockquote>
-<p>
- pdfwrite - fix an error handling problem<br>
-<br>
- Bug 698735 &quot;Ghostscript: SEGV in pdfwrite with -Z@&quot;<br>
-<br>
- This was, unfortunately, caused by the shift to cleaning up memory<br>
- instead of relying on the garbage collector.<br>
-<br>
- When an error occurred writing the metadata, the code simply exited<br>
- back to the caller, it did not close the temporary stream it was<br>
- writing the metadata to.<br>
-<br>
- Due to the way that 'asides' are handled this led to the wrong stream<br>
- being closed, and a pointer retained to a closed stream. The result<br>
- was the seg fault.<br>
-<br>
- There may well be other conditions like this still present.<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-11 19:28:10 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db2415d2b117946e5ec1d46936a134940f99c21d">db2415d2b117946e5ec1d46936a134940f99c21d</a>
-<blockquote>
-<p>
- Bug 698733: make vector device memory stable<br>
-<br>
- The pcl/xl device (gdevpx.c) was using &quot;normal&quot; Postscript global memory for<br>
- its own use, and the vector base device on which it is based. That means the<br>
- memory it allocated could disappear with the end-of-job restore in the<br>
- Postscript interpreter.<br>
-<br>
- Change it so it uses stable memory which is still garbage collected, and still<br>
- subject to relocation, but is *not* subject to Postscript save/restore<br>
- operation.<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-03 08:52:50 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c535ebb24602ff14a375a1590a9df6bd8bb7e9c4">c535ebb24602ff14a375a1590a9df6bd8bb7e9c4</a>
-<blockquote>
-<p>
- Fix bug 695877: SEGV when display callback not set.<br>
-<br>
- Change most of the device procs to return gs_error_Fatal when the callback<br>
- hasn't been set. The open is allowed to be called before it is set, but any<br>
- operations other than fill_rect (allowed for due to fillpage) and close will<br>
- now return Fatal errors. This allows the device to be &quot;fake opened&quot; by gs_init<br>
- before the parameters are processed and the display callback is set and the<br>
- device is opened for actual use.<br>
-<br>
-devices/gdevdsp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-08 14:04:42 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea81364fdda57ce2c82007a150add5949a1c5788">ea81364fdda57ce2c82007a150add5949a1c5788</a>
-<blockquote>
-<p>
- PS interpreter - fix detection of overflow on 64-bit integer multiply<br>
-<br>
- Bug 698722 &quot;Erroneous Range-Check causes wrong arithmetic results&quot;<br>
-<br>
- The work here was actually done by Robin Watts, ably assisted by<br>
- Paul Gardiner.<br>
-<br>
- The previous code failed to properly detect an overflow condition,<br>
- because the cast of MAX_PS_INT to a double reduces the precision to<br>
- only 52 bits for the integer portion, meaning it was possible for<br>
- very large numbers not to be detected as &gt; MAX_PS_INT.<br>
-<br>
-psi/zarith.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-08 10:04:03 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e1aead165e05e98ae765d6569f39ced839d4298e">e1aead165e05e98ae765d6569f39ced839d4298e</a>
-<blockquote>
-<p>
- Guard against divide-by-zero exceptions in the halftone code<br>
-<br>
- Bug #697663 &quot;FPE in gx_compute_cell_values()&quot;<br>
- Bug #698332 &quot;FPE (Division by zero) in pick_cell_size()&quot;<br>
-<br>
- These have the same root cause, in pick_cell_size() we can end up with<br>
- halftone cell parameters which are (I think) improperly initialised.<br>
-<br>
- Certainly its possible to get to the point where we divide using one<br>
- of the parameters, and if its 0 we get an error. I suspect that the<br>
- halftone may be badly broken even when its not 0, but both these files<br>
- are the result of fuzzing, so I doubt its possible to have a real<br>
- working file get to this point.<br>
-<br>
- Guard against the divide-by-zero errors by checking that both the<br>
- parameters are non-zero (its permissible for one to be 0 I believe)<br>
-<br>
-base/gshtscr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-06 13:27:19 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1fb022758a35502b8e299248dd37207c1abc3ffe">1fb022758a35502b8e299248dd37207c1abc3ffe</a>
-<blockquote>
-<p>
- Optimise pdf14_copy_planes<br>
-<br>
- Call code derived from pdf14_compose_group rather than<br>
- breaking everything down to rectangles.<br>
-<br>
-base/gdevp14.c<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-06 18:37:39 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=25d1c5f42b748af8d4d331a7b40ce9863e302332">25d1c5f42b748af8d4d331a7b40ce9863e302332</a>
-<blockquote>
-<p>
- Fix misalignment in pdf14_copy_planes.<br>
-<br>
- In the case where x/y get clipped, we can fail to account for<br>
- this.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-03 18:53:27 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f36ee7a64c9ec95eb6657d06c602d0e4bb6f232">8f36ee7a64c9ec95eb6657d06c602d0e4bb6f232</a>
-<blockquote>
-<p>
- Fix -Z? vs. -Zv output for pattern transparency debug.<br>
-<br>
-base/gdevp14.c<br>
-base/gsptype1.c<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-03 17:42: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=ee863835be136e21d3a4c4bcbe28e6e050e1bc1a">ee863835be136e21d3a4c4bcbe28e6e050e1bc1a</a>
-<blockquote>
-<p>
- Check for a failed allocation before using the buffer.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-03 17:42:21 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc95eea7e6e5b5efb53446c8bcb482b748e9072e">cc95eea7e6e5b5efb53446c8bcb482b748e9072e</a>
-<blockquote>
-<p>
- Squash a warning in pdf14.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-03 17:41:33 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a953768a82d685e575c17feeebf3ea4468a319f3">a953768a82d685e575c17feeebf3ea4468a319f3</a>
-<blockquote>
-<p>
- Fix bad free pdf14 (wrong gs_memory_t)<br>
-<br>
- Michael spotted that:<br>
-<br>
- gs -sDEVICE=tiff24nc -Z$?@ -r300 -o out%d.tif -f .<br>
- ./MyTests/Advertising-PowerPoint-A4.pdf<br>
-<br>
- gave a warning saying that a trans pattern being freed from<br>
- the cache wasn't owned by the supplied memory pointer.<br>
-<br>
- Indeed the free should have been using memory-&gt;stable_memory.<br>
- Here we commit the nice fix whereby the buffer keeps a pointer<br>
- to the memory with which it was allocated.<br>
-<br>
- This simplifies the pdf14_buf_free calls too.<br>
-<br>
- Credit to Ray for finding the cause/identifying the fix.<br>
-<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-03 15:27:50 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c9f8491ecb5cfa382608c47f5a35ad2bce00edc">3c9f8491ecb5cfa382608c47f5a35ad2bce00edc</a>
-<blockquote>
-<p>
- Bug 694918: Fix buffer overrun in image_simple_expand.<br>
-<br>
- If truly crazy values of x_extent are used, the fixed point<br>
- representation can wrap around and we can start accessing out<br>
- of the buffer.<br>
-<br>
- Check for such stupid values and nobble us to do no harm.<br>
-<br>
-base/gxifast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-02 12:07:16 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1ea664170c68539a035279425447f7ce10e130ff">1ea664170c68539a035279425447f7ce10e130ff</a>
-<blockquote>
-<p>
- Add support to viewpbm.ps for GRAYSCALE and RGB_ALPHA and fix logic for FITPAGE<br>
-<br>
- The RAW_DUMP with RAW_DUMP_AS_PAM emits RGB_ALPHA and GRAYSCALE but these<br>
- were not supported. Display RGB_ALPHA as CMYK for now.<br>
-<br>
- Also if SCALE was specified, the ifelse for FITPAGE was inverted.<br>
-<br>
-lib/viewpbm.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-02 11:51:48 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4c1f9b28eab25b519d0a14401ec6bbcf01813e12">4c1f9b28eab25b519d0a14401ec6bbcf01813e12</a>
-<blockquote>
-<p>
- Fix RAW_DUMP (minor omissions/typos when blending was refactored.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-27 08:03:36 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8200f59f1b5aab852e23322587dda7c182fc195b">8200f59f1b5aab852e23322587dda7c182fc195b</a>
-<blockquote>
-<p>
- Fix Bug696372: Transparency with DeviceN not coping with bad PDF's<br>
-<br>
- When a PDF with transparency stops interpretation due to an error, the<br>
- grestore may have popped the pgs so that the pdf14 compositor is no<br>
- longer the currentdevice. The logic in pad14_spot_get_color_comp_index<br>
- assumed that the device was a pdf14_device and got a bogus pointer to<br>
- devn_params. Instead, use the device's ret_devn_params function to get<br>
- the actual pointer.<br>
-<br>
- Also, the poppdf14devicefilter would execute without the pdf14 device<br>
- as the currentdevice. Save the annots_gstate explicitly in pdf_main<br>
- showpagecontents so it can be set back before doing annots and the<br>
- poppdf14devicefilter.<br>
-<br>
- This also required gs_setgstate to always do gs_do_set_overprint since<br>
- the setgstate may have skipped over states with the overprint compositor.<br>
- This caused &quot;drawn_comps&quot; to not be set correctly for the pdf14<br>
- compose_group.<br>
-<br>
- Fixups for 696372 fix commit (also ne-&gt;be last line of commit msg)<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-base/gdevp14.c<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-02 17:54:57 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1626f36c9b6ae68abad7818be7cfb2a95f4ecffe">1626f36c9b6ae68abad7818be7cfb2a95f4ecffe</a>
-<blockquote>
-<p>
- Bug 698713: Further graphicsAlphaBits + new scan converter fix.<br>
-<br>
- Previous I ensured that when using graphicsAlphaBits, the new scan<br>
- converter would restrict its output rectangles/traps to fit<br>
- within y % max_fill_band pixels at a time as required.<br>
-<br>
- I forgot that the base 'y' value taken for this was not necessarily<br>
- aligned to a max_fill_band multiple. Fixed here.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-01 20:08:13 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=30ba3e3a163f729f2d05561e688dc54df6afa2e1">30ba3e3a163f729f2d05561e688dc54df6afa2e1</a>
-<blockquote>
-<p>
- LCMS2: Add optimised 3x16bit -&gt; 1x16bit cached transform.<br>
-<br>
-lcms2/src/cmsxform.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-01 21:15:42 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d68b31cc315e7e687d0b55a5068b7514d7f73f5f">d68b31cc315e7e687d0b55a5068b7514d7f73f5f</a>
-<blockquote>
-<p>
- LCMS2: Refind transform routine on buffer change.<br>
-<br>
-lcms2/src/cmsxform.c<br>
-lcms2/src/lcms2_internal.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-01 17:23: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=4ef5c30e68bbb33b952db1b70508e7412bf79f0f">4ef5c30e68bbb33b952db1b70508e7412bf79f0f</a>
-<blockquote>
-<p>
- Reintroduce and update LCMS optimisations.<br>
-<br>
-lcms2/src/cmsxform.c<br>
-lcms2/src/extra_xform.h<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-31 19:37:10 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1ab17bc53362ea34b61050429c51c575539bf2b9">1ab17bc53362ea34b61050429c51c575539bf2b9</a>
-<blockquote>
-<p>
- Avoid clearing cm_comps arrays in cmap functions.<br>
-<br>
- This goes against commit 99c48263b9 by Ray (dating from Nov 1 2009)<br>
- to fix Bug 690713 and solve some indeterminisms.<br>
-<br>
- My belief is that this SHOULD be fixed in the devices, not in the<br>
- callers. Accordingly I have backed that out, and changed the<br>
- cmyk_cs_to_psdcmyk_cm function (the only one I can find that does<br>
- not set everything to be 0).<br>
-<br>
- The cluster now shows this running with no diffs.<br>
-<br>
-base/gxcmap.c<br>
-devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-11-01 12:07:53 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b3c0fafa490932cc43009c53c7f8a17598fe78d7">b3c0fafa490932cc43009c53c7f8a17598fe78d7</a>
-<blockquote>
-<p>
- Tweak map_XXXX_subclass functions.<br>
-<br>
- To cope with subclassed devices, we no longer simply call:<br>
-<br>
- pprocs = dev_proc(dev, get_color_mapping_procs);<br>
- pprocs-&gt;map_cmyk(dev, ...)<br>
-<br>
- etc. The 'done thing' is to run up the the dev-&gt;parent pointers<br>
- as far as we can, and to get the color mapping procedures from<br>
- that. These color mapping procedures then need to be called<br>
- using the dev pointer from which they were fetched.<br>
-<br>
- To do this, we provide get_color_mapping_procs_subclass<br>
- and map_XXX_subclass functions that pickle the dev search.<br>
-<br>
- The only downside to this is that we end up doing the search<br>
- up the tree twice (or more than twice in the case where we<br>
- make several mapping calls).<br>
-<br>
- Here we therefore tweak these functions so that<br>
- get_color_mapping_procs_subclass returns both the procs AND<br>
- the dev to use when calling them in a structure, and the<br>
- map_XXX_subclass functions now take that structure.<br>
-<br>
- Broadly, this change shouldn't actually alter any operation,<br>
- other than being slightly more efficient.<br>
-<br>
- There are a few wrinkles:<br>
-<br>
- 1) in gsicc_replacecm.c, we were fetching the procs using the<br>
- dev chasing function, but calling them using the unchased dev<br>
- value. Fixed here to use the matching dev value in both cases.<br>
-<br>
- 2) In a couple of places, we have special handling for forwarding<br>
- devices. I am not convinced that we handle subclassed forwarding<br>
- devices correctly (or devices that forward to subclassed devices).<br>
- I have marked these areas with FIXMEs, but they are no worse<br>
- now than they were before.<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevdgbr.c<br>
-base/gdevnfwd.c<br>
-base/gscspace.c<br>
-base/gsicc_replacecm.c<br>
-base/gsovrc.c<br>
-base/gspaint.c<br>
-base/gxcmap.c<br>
-base/gxdcolor.c<br>
-base/gxdevcli.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-31 17:52:12 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=961b14dd7e686a1543541070a1ba943590ef2bf9">961b14dd7e686a1543541070a1ba943590ef2bf9</a>
-<blockquote>
-<p>
- Optimise handle_colors in gxiscale.c<br>
-<br>
- Avoid per-pixel work by doing as much as possible up front.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-31 15:52:49 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=de645ba2116ecfc71d0fdcea84944735736d0278">de645ba2116ecfc71d0fdcea84944735736d0278</a>
-<blockquote>
-<p>
- Avoid looking up the profile for every pixel of an image.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-31 13:07: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=f7b61e0cc56206b6811eee85c4cfd6a0963194e0">f7b61e0cc56206b6811eee85c4cfd6a0963194e0</a>
-<blockquote>
-<p>
- Pass device_profile into color concretizing functions.<br>
-<br>
-base/gdevp14.c<br>
-base/gscdevn.c<br>
-base/gscms.h<br>
-base/gscolor2.c<br>
-base/gscpixel.c<br>
-base/gscsepr.c<br>
-base/gscspace.h<br>
-base/gsicc.c<br>
-base/gsicc_cache.c<br>
-base/gsicc_cache.h<br>
-base/gxcmap.c<br>
-base/gxcspace.h<br>
-base/gxiscale.c<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-27 20:24:32 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=31cb4cf7aa88784219f6fc2be362a66df2f67289">31cb4cf7aa88784219f6fc2be362a66df2f67289</a>
-<blockquote>
-<p>
- Tweak cmap functions for speed.<br>
-<br>
- In looking at the Advertising-PowerPoint-A4.pdf file, I noted that<br>
- cmap_gray_direct and cmap_gray_halftoned were taking a noticable<br>
- amount of time. This commit attempts to alleviate that.<br>
-<br>
- Various observations:<br>
-<br>
- 1) Avoid unnecessary loop in cmap_gray_halftoned (and similar functions).<br>
-<br>
- In some of the code, we do:<br>
-<br>
- for (i = 0; i &lt; n; i++)<br>
- if (i == k)<br>
- do_something_with(i)<br>
-<br>
- why not just use:<br>
-<br>
- if (k &lt; n)<br>
- do_something_with(k)<br>
-<br>
- 2) Typically functions like cmap_gray_direct do a load of work,<br>
- culminating in trying to encode a color value. If that encoding fails,<br>
- it would fallback to trying to use a cmap_gray_halftoned, which would<br>
- do all the work a second time.<br>
-<br>
- Tweak the code to avoid the call, and hence the repetition.<br>
-<br>
- The downside to this is that the work is typically of the form:<br>
-<br>
- for (i = 0; i &lt; n; i++)<br>
- cv[i] = frac2cv(some_calculation_involving(cm_comps[i]));<br>
-<br>
- and in order to be able to avoid the call to cmap_gray_halftoned, we<br>
- need to make it:<br>
-<br>
- for (i = 0; i &lt; n; i++) {<br>
- cm_comps[i] = some_calculation_involving(cm_comps[i]);<br>
- cv[i] = frac2cv(cm_comps[i]);<br>
- }<br>
-<br>
- i.e. we have to do more stores than before. This can hurt us in some<br>
- cases, but it seems like a worthwhile win, especially in light of 3).<br>
-<br>
- 3) A lot of the work in these functions involves mapping colors through<br>
- the effective_transfer functions. This happens in code of the form:<br>
-<br>
- for (i = 0; i &lt; n; i++) {<br>
- cm_comps[i] = gx_map_color_frac(pgs, cm_comps[i], effective_transfer[i]);<br>
- }<br>
-<br>
- If effective_transfer[i] is identity (as it almost always is), then<br>
- this whole loop is a nop.<br>
-<br>
- We make some steps to optimise for this case by having the<br>
- gx_map_color_frac macro check for effective_transfer[i] being<br>
- gs_identity_transfer before calling it, but this doesn't help us<br>
- avoid the loop/load/store.<br>
-<br>
- We therefore extend pgs with a count of the number of<br>
- 'effective_transfer's that are non identity (essentially a flag<br>
- that enables us to know if we can skip this loop or not),<br>
- and use that to optimise our work.<br>
-<br>
-base/gsht.c<br>
-base/gxcmap.c<br>
-base/gxgstate.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-30 19:31:47 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=de651aaa531a7eb6fa99c1ef97682ebe22a3cda7">de651aaa531a7eb6fa99c1ef97682ebe22a3cda7</a>
-<blockquote>
-<p>
- Further optimisations in pdf14_mark_fill_rectangle.<br>
-<br>
- Normal blend mode case is always worth optimising.<br>
-<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-31 14:11:24 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fda23c007c3acb96198648c3f4a65438ce449b63">fda23c007c3acb96198648c3f4a65438ce449b63</a>
-<blockquote>
-<p>
- Squash warnings.<br>
-<br>
-psi/zcolor.c<br>
-psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-30 11:08:09 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=76b922b5d3071288edbf8f0cccdbbd2b0ae34742">76b922b5d3071288edbf8f0cccdbbd2b0ae34742</a>
-<blockquote>
-<p>
- PDF interpreter - try and catch yet more cases of circular references<br>
-<br>
- No bug report for this one, the customer requested destruction of the<br>
- PDF file after analysis, and there was no way to reduce the file to the<br>
- point where nothing sensitive remained.<br>
-<br>
- The problem is that a Form XObject referenced a number of Image XObjects<br>
- one of which contained a DecodeParms array, where the second element<br>
- referenced the original Form XObject. This circular reference leads to<br>
- an error.<br>
-<br>
- Here we maintain a dictionary (initially empty) on the stack which we<br>
- populate with object numbers as we recursively dereference objects.<br>
- When we start a new composite object we copy the array into a new array<br>
- which we discard on completion. This is to prevent false detection of<br>
- circular references if we dereference multiple composite objects at the<br>
- same level (eg if we deal with multiple images, each of which perhaps<br>
- contained a reference to the same colour space).<br>
-<br>
- We now issue an error quoting the object number being circularly<br>
- referenced, replace the object with a null object and continue.<br>
-<br>
- No differences expected.<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-27 18:08:34 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ecb0181ae2c6c64f876f741ef1da2980324442ca">ecb0181ae2c6c64f876f741ef1da2980324442ca</a>
-<blockquote>
-<p>
- Use integer maths for bitmap interpolation internals.<br>
-<br>
- We calculate the weights using doubles still, but store them as<br>
- integers. This means all the inner loops avoid FP.<br>
-<br>
-base/siscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-27 16:53:51 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b62bfe2c7d166bfe8f3743e122abc755d96bec9c">b62bfe2c7d166bfe8f3743e122abc755d96bec9c</a>
-<blockquote>
-<p>
- Unpack/Unroll the inner loops of Mitchell scaler.<br>
-<br>
-base/lib.mak<br>
-base/siscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-26 12:53:29 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=81561e6e04f49a4b3b9599cc09ba2cde4407e936">81561e6e04f49a4b3b9599cc09ba2cde4407e936</a>
-<blockquote>
-<p>
- Optimise clip_fill_rectangle and family.<br>
-<br>
- Avoid testing for transpose each time, and cope with the common<br>
- single rectangle case more efficiently.<br>
-<br>
- This gives a 20% speedup in testing with my cutdown<br>
- Advertising-Powerpoint-A4.pdf file going to 1200dpi, 1bpc cmyk.<br>
-<br>
- The only one called here is clip_fill_rectangle, but push the<br>
- same optimisations through clip_fill_rectangle_hl_color,<br>
- clip_copy_mono, clip_copy_planes etc to help other devices.<br>
-<br>
-base/gxclip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-26 16:00:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d2177ac781235aa67cde3b6fc9d85030c50a8a9">0d2177ac781235aa67cde3b6fc9d85030c50a8a9</a>
-<blockquote>
-<p>
- pdfwrite - take action on an error.<br>
-<br>
- Don't ignore the potential error return from gx_path_current_point()<br>
-<br>
-devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-25 15:04: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=f13a659f9700fac0a0f47007c1eaacddd5c7f208">f13a659f9700fac0a0f47007c1eaacddd5c7f208</a>
-<blockquote>
-<p>
- improve commit d9d74def0095641f20b46716c929bc6f88154490<br>
-<br>
- There were a couple of places that returned 0 which, after the goto<br>
- change, return code. Its just barely possible that code might not be<br>
- 0, so set it to 0 first.<br>
-<br>
-devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-25 14:57: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=d9d74def0095641f20b46716c929bc6f88154490">d9d74def0095641f20b46716c929bc6f88154490</a>
-<blockquote>
-<p>
- pdfwrite - revisit clipped text and commit 46ef6bc80bd7388883a00aa866af38fe8f05d45b<br>
-<br>
- Bug #698693 &quot;clipped text is selectable in pdf&quot;<br>
-<br>
- Commit 46ef6bc80bd7388883a00aa866af38fe8f05d45b fixed bug 697442, in<br>
- that case we needed to completely process text which had been<br>
- deliberately placed off the page (and tehrefore outside the clip).<br>
-<br>
- In that bug the text used glyphshow, which meant that it could not use<br>
- stringwidth to measure the width of the string, and perform accurate<br>
- positioning. So instead it placed the current point off the page,<br>
- used glyphshow to draw the text, and then currentpoint to find the<br>
- displacement.<br>
-<br>
- By not fully processing the text we did not correctly update currentpoint<br>
- and so the text was misplaced. This was fixed by fully processing<br>
- the text, but altering a copy of the text enumerator's 'operation'<br>
- field so that the text was not added to the page (clearing TEXT_DO_DRAW)<br>
-<br>
- However, there are still places (process_text_modify_width) which can<br>
- add the text in, and those look directly at the text enumerator<br>
- operation flags.<br>
-<br>
- So here we still copy the operation flags, but we then modify the copy<br>
- held in the text enumerator, so that any subsequent processor will<br>
- be able to see that the text should not be drawn. At the end of the<br>
- function we restore the flags in the enumerator. This has meant a few<br>
- places executing a 'goto' in order to reset the flags, instead of simply<br>
- returning as previously.<br>
-<br>
- A few test files show extremely minor (1 pixel) positioning differences.<br>
-<br>
-devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-24 07:19:39 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=140e1cb28a6ad42e2ded8381af8b53421923e0e1">140e1cb28a6ad42e2ded8381af8b53421923e0e1</a>
-<blockquote>
-<p>
- Fix bug #694630 - Fuzzing Segmentation Fault.<br>
-<br>
- Along with soft fonts, the built in fonts should not be restored when<br>
- a macro call completes. The segmentation fault in the report was<br>
- caused by a dangling reference to a deleted font after restoring the<br>
- built in font dictionary. Also, removes a stale comment.<br>
-<br>
-pcl/pcl/pcsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-24 12:13:23 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=434234ef22fd28217045c6485672c93a9685a607">434234ef22fd28217045c6485672c93a9685a607</a>
-<blockquote>
-<p>
- Have configure set memory manager alignment.<br>
-<br>
- For certain Unix derivatives (HP-UX, Solaris, and AIX) we have to use 64 bit<br>
- memory alignment - configure will now spot if we are building on and for those<br>
- platforms, and set the alignment appropriately.<br>
-<br>
- Cross compiling still defaults to 32 bit, and if 64 bit alignment is required,<br>
- it must set explicitly.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-21 11:01: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=5889736af797dcba1d46af11a84b765340f6c3c4">5889736af797dcba1d46af11a84b765340f6c3c4</a>
-<blockquote>
-<p>
- PDF interpreter - improve commit 9e8d2e<br>
-<br>
- We should use .endtransparencytextgroup to close the group started by<br>
- .begintransparencytextgroup, not .endtransparencygroup<br>
-<br>
- Oddly this doesn't actually seem to cause any problems, but its not<br>
- right.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-20 14:40: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=6495e38f2dbaeedcaedf84f15c96e78aab6773c4">6495e38f2dbaeedcaedf84f15c96e78aab6773c4</a>
-<blockquote>
-<p>
- Remove useless test in PDF interpreter transparency code<br>
-<br>
- This test was always true since we always have .begintransparencygroup<br>
- It was changed in 2008 from a check for .inittransparencymask which was<br>
- created back in 2006. It was probably a test in case the PDF interpreter<br>
- was running on a system that may not include the pdf14 compositor, but<br>
- that is only a guess.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-20 16:14: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=9e8d2e156aa3ea039f531e6ea378add4ea6e268c">9e8d2e156aa3ea039f531e6ea378add4ea6e268c</a>
-<blockquote>
-<p>
- PDF interpreter - fix annotations with transparency and text<br>
-<br>
- Since the introduction of '.begintransparencytextgroup' the synthesis<br>
- of missing Appearances for annotations involving text has been broken.<br>
-<br>
- Approximately since January 2017.<br>
-<br>
- Introducing '.begintransparencytextgroup' fixes the problem.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-20 14:16: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=2fc463d0efbd044a8232611f0898eeb12b72a970">2fc463d0efbd044a8232611f0898eeb12b72a970</a>
-<blockquote>
-<p>
- Bug 698676: have filenameforall permission check use &quot;reduced&quot; path<br>
-<br>
- Prevents working around SAFER file access permissions.<br>
-<br>
- CVE-2017-15652<br>
-<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-19 13:01:46 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=684f73e8deefacb2aa5d2277f3154b68809b2ab7">684f73e8deefacb2aa5d2277f3154b68809b2ab7</a>
-<blockquote>
-<p>
- Bug 698672: Fix new scanconverter/alphabits interaction.<br>
-<br>
- The alphabits mechanism relies on the scan converter not<br>
- writing trapezoids so tall as to cause its line buffers<br>
- to flush too early.<br>
-<br>
- This is achieved by honoring the max_band_height field in<br>
- the device header. Previously the new scan converter was<br>
- ignoring this. Here we alter the code to pay attention to<br>
- it.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-17 12:19:19 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc9a66978c56fdfff61bc3b1166955e5506470a9">cc9a66978c56fdfff61bc3b1166955e5506470a9</a>
-<blockquote>
-<p>
- Fix bug 693304. Restore with pdf14 can cause SEGV<br>
-<br>
- The pdf14 compositor device is retained but the mask_stack (and other<br>
- elements of the pdf14_ctx need to be in stable memory to prevent<br>
- dangling references after a restore.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-18 17:01:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6d048c85f5c75e7539e8b5fc42f5fd856986cc6e">6d048c85f5c75e7539e8b5fc42f5fd856986cc6e</a>
-<blockquote>
-<p>
- Bug 698669: remove reference to removed example file<br>
-<br>
- Some time ago, we removed the example file chess.ps due to questions over the<br>
- license for the font it used.<br>
-<br>
- But the makefile gubbins to &quot;install&quot; the example files wasn't changed to suit,<br>
- and on HP-UX (but so far, nothing else!) caused &quot;make install&quot; to error out.<br>
-<br>
-base/unixinst.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-18 14:14: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=7da09aaf701bd4ff2acea55aacce84a22455aead">7da09aaf701bd4ff2acea55aacce84a22455aead</a>
-<blockquote>
-<p>
- Bug 698647: pdfwrite: avoid cached glyphs for Type 3 font input only<br>
-<br>
- The original fix in 8360852efab5643d93cc3b040832075e199cd205 wrongly assumed<br>
- that the changed code only came into effect for Type 3 font *input* where,<br>
- in reality, it's for any font for which we have to create a Type 3 in the<br>
- output.<br>
-<br>
- The change to disable the use of the cache should only apply to Type 3 input<br>
- where we want to force the execution of the BuildGlyph/BuildChar proc so<br>
- pdfwrite can capture it.<br>
-<br>
- In all other cases, we need to leave the cache in play.<br>
-<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-17 10:16:51 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9219b1e5febd646f6d87bc424b41237a50529d0d">9219b1e5febd646f6d87bc424b41237a50529d0d</a>
-<blockquote>
-<p>
- Page selection device - fix overprint compositor usage<br>
-<br>
- Bug #698568 &quot;Ghostscript segmentation fault when doing page selection&quot;<br>
-<br>
- The PostScript interpreter uses the current device in the graphics<br>
- state, and calls the create_compositor() method when overprint is<br>
- set to true.<br>
-<br>
- This may or may not insert a new compositor device into the graphics<br>
- state, and whether it does or not is controlled by the return from<br>
- the method. If the device is the same as the one in the graphics state<br>
- then we don't set a new device, if its different then we set the<br>
- returned device.<br>
-<br>
- The page selection device wasn't initialising this parameter, and if<br>
- we were skipping the page we didn't call the child device method,<br>
- which meant we returned an uninitialised pointer to the caller. Since<br>
- this was unlikely to be the same as the current device, we ended up<br>
- trying to set the device in the graphics state to an uninitialised<br>
- pointer, with predictably disastrous results.<br>
-<br>
- The simple fix is to initialise the pointer to the current device in<br>
- the graphics state. If we call the child method, and it wants a new<br>
- compositor then it will overwrite it, if it doesn't, or we are skipping<br>
- the page, then we return the current device and nothing changes.<br>
-<br>
- No differences expected.<br>
-<br>
-base/gdevflp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-13 11:16: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=05432a551f887d7526b2bf3c65f3f1740cb3cc48">05432a551f887d7526b2bf3c65f3f1740cb3cc48</a>
-<blockquote>
-<p>
- PDF interpreter - Improve annotation appearance generation<br>
-<br>
- Bug #698627 &quot;PDF 2.0 tests Polygon annotation&quot;<br>
- Bug #698629 &quot;PDF 2.0 tests Polyline annotation&quot;<br>
- Bug #698630 &quot;PDF 2.0 tests Ink annotation&quot;<br>
-<br>
- This commit refactors the code previously committed for Circle and<br>
- Square annotations to make it more general. Adds support for the Polygon,<br>
- PolyLine and Ink with /Path array (new to PDF 2.0). Adds support for<br>
- transparency in Annotations (some limited support was available before).<br>
- Adds the /Line annotation type and implements the Line Ending (/LE)<br>
- array, but not other aspects of the Line annotation (these may be added<br>
- at a later date).<br>
-<br>
- Bug #698628 &quot;PDF 2.0 tests Redact annotation&quot;<br>
-<br>
- We specifically don't generate an Appearance for Redact annotations, but<br>
- will render one if supplied. This annotation is really an interactive<br>
- feature, not relevant to print.<br>
-<br>
- Predictably this commit causes differences as we now generate substitute<br>
- appearances for more annotation types when the appearance is missing.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-12 14: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=9196c7ff8c41f1b256d58696158cd6b99e238459">9196c7ff8c41f1b256d58696158cd6b99e238459</a>
-<blockquote>
-<p>
- Always force unsigned chars for Luratech<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-09 13:14: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=6b076c380d4479aa64375baaad59dba6729e2c8f">6b076c380d4479aa64375baaad59dba6729e2c8f</a>
-<blockquote>
-<p>
- Fix problems caused by pdf14_compose_group tuning.<br>
-<br>
- It seems that has_mask == 0 does not equate to maskbuf != NULL.<br>
-<br>
- Assuming that mask_mask == 0 =&gt; maskbuf == NULL causes problems in<br>
- tests_private/pdf/sumatra/fireworks_with_radial_shading.pdf (300dpi<br>
- clist renderings in particular) and in<br>
- tests_private/pdf/uploads/Bug697212.pdf (all renderings).<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-10 10:14:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f64fa48dc792230244f20f115b8dbe3545f484da">f64fa48dc792230244f20f115b8dbe3545f484da</a>
-<blockquote>
-<p>
- Documentation - remove references to .runandhide<br>
-<br>
- We removed a number of PostScript operators from accessibility after<br>
- the interpreter is running as part of the security overhaul. One of<br>
- these was .runandhide but we accidentally left a couple of references<br>
- in the documentation (the main part of the documentation was correctly<br>
- updated).<br>
-<br>
- So remove the references here, and update the documentation to note the<br>
- potential risks in using -dNOSAFER with a save object on the exec<br>
- stack.<br>
-<br>
-doc/Language.htm<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-12 10:32: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=dab8018a344409710b989c31575e6e0e4eb243ce">dab8018a344409710b989c31575e6e0e4eb243ce</a>
-<blockquote>
-<p>
- Bring master up to date with gs922 branch<br>
-<br>
- Update docs dates etc for release<br>
-<br>
- Changelog and news<br>
-<br>
- Update dates/product for 9.22rc2<br>
-<br>
- Changelog for 9.22rc2<br>
-<br>
- Dates, product, changelog for 9.22 release<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/Xfonts.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>
-psi/int.mak<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-09 11:08: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=11f058b7fea07b2a5d2677be3f057cc5ee3e9023">11f058b7fea07b2a5d2677be3f057cc5ee3e9023</a>
-<blockquote>
-<p>
- PDF Interpreter - support the /Circle annotation type without an appearance<br>
-<br>
- Bug #698626 &quot;PDF 2.0 tests Circle annotation&quot;<br>
-<br>
- We didn't synthesise an appearance for annotations of type /Circle<br>
- when they had no appearance stream. This commit adds that support.<br>
-<br>
- Rather surprisingly, there do not appear to be any files in our test<br>
- suite which exercise this. Doubly surprising since I thought all the<br>
- release 2 PDF 2.0 FTS files were included and its one of these that<br>
- is quoted in the bug report.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-07 13:33: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=6db482c183959dbccdc865d8a27cb53b054d3dc1">6db482c183959dbccdc865d8a27cb53b054d3dc1</a>
-<blockquote>
-<p>
- PDF Interpreter - support the /Square annotation type with no /Appearance<br>
-<br>
- Bug #698625 &quot;PDF 2.0 tests Square annotation type&quot;<br>
-<br>
- We didn't synthesise an appearance for annotations of type /Square<br>
- when they had no appearance stream. This commit adds that support.<br>
-<br>
- Rather surprisingly, there do not appear to be any files in our test<br>
- suite which exercise this. Doubly surprising since I thought all the<br>
- release 2 PDF 2.0 FTS files were included and its one of these that<br>
- is quoted in the bug report.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-06 17:23: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=83ef35dce760f68019afd1b07bac8118cd9837a2">83ef35dce760f68019afd1b07bac8118cd9837a2</a>
-<blockquote>
-<p>
- PDF and PS Interprters and ps2write - fix type 6 halftones &amp; transfers<br>
-<br>
- Bug698621 &quot;PDF 2.0 tests not applying transfer function from halftone&quot;<br>
-<br>
- The halftones in question are defined (by the PDF interpreter) as type<br>
- 6 halftones, ie file-based threshold arrays.<br>
-<br>
- Rather to my surprise, the reason this didn't work turns out to be<br>
- because the PostScript interpreter has never supported transfer functions<br>
- with type 6 halftones.<br>
-<br>
- So; add support for transfer functions in type 6 halftones. This exposed<br>
- a problem with ps2write (and potentially pdfwrite) when emitting these<br>
- transfer functions, instead of simply specifying the object number of<br>
- the function, we were writing it out decorated with &quot;/TransferFunction&quot;<br>
- which caused ps2write output to fail. So fix that here too.<br>
-<br>
- Remove the 'OBSELETE' comment from the halftone structure, I don't know<br>
- who thought this was obselete, but it really does not seem to be.<br>
-<br>
-base/gsht1.c<br>
-base/gxht.h<br>
-devices/vector/gdevpdfg.c<br>
-psi/zht2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-06 14:52: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=45a826638bfc6309a829b38ecf14ff9c21f438ca">45a826638bfc6309a829b38ecf14ff9c21f438ca</a>
-<blockquote>
-<p>
- Tune pdf14_compose_group inlining.<br>
-<br>
- Pick specific inlinings based upon examination of the data<br>
- from the TRACK_COMPOSE_GROUPS defines.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-05 19:25: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=7b6bce45b1a85266a40844436ea386c4129515f4">7b6bce45b1a85266a40844436ea386c4129515f4</a>
-<blockquote>
-<p>
- Add TRACK_COMPOSE_GROUPS development code.<br>
-<br>
- This enables us to track which combinations of options<br>
- are used, and how frequently.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-05 19: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=5e1675e95b0574f9a5f469458e849e1837c33983">5e1675e95b0574f9a5f469458e849e1837c33983</a>
-<blockquote>
-<p>
- Further tweaks to pdf14_mark_fill_rectangle<br>
-<br>
- Avoid having to check for src_alpha == 0 every time around<br>
- the loop.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-05 19:29: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=8c72c12c30553b76b4e2b23261529ec4c6d49b43">8c72c12c30553b76b4e2b23261529ec4c6d49b43</a>
-<blockquote>
-<p>
- Further tweaks to pdf14_preserve_backdrop<br>
-<br>
- Attempt to avoid blanking tag plane when we're about to copy<br>
- into it.<br>
-<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-05 19:26: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=affab3b5889ce7b8bcb38d0c7c938b907d1e8253">affab3b5889ce7b8bcb38d0c7c938b907d1e8253</a>
-<blockquote>
-<p>
- Fix typo.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-05 14:37:37 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=882e0bfed09e839d53287164ebf4aa99ca5f116a">882e0bfed09e839d53287164ebf4aa99ca5f116a</a>
-<blockquote>
-<p>
- Optimise pdf14_mark_fill_rectangle using inlining.<br>
-<br>
- Same tricks as used for pdf14_compose_group.<br>
-<br>
-base/gdevp14.c<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-04 17:01:24 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=77cdf72595643da5d17e84fb72d8f58ccfe3d038">77cdf72595643da5d17e84fb72d8f58ccfe3d038</a>
-<blockquote>
-<p>
- Avoid duplicating code in art_pdf_composite_pixel_alpha8_inline.<br>
-<br>
- We can spot that blend_mode == BLEND_MODE_Normal in the caller,<br>
- and set first_spot to 0 in that case. Then we always drop<br>
- straight through to the code at the end, and omit the complex<br>
- blend call. Reduces code, doesn't change the speed.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-04 16:54: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=aaccd9b5942aae6738ac02874e627b9e8677f965">aaccd9b5942aae6738ac02874e627b9e8677f965</a>
-<blockquote>
-<p>
- Instantiate some more 'optimised' routines for pdf14_group_compose.<br>
-<br>
- The last one of these is the one that gets hammered in the<br>
- normal_blend_test.pdf file.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-04 16:54: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=3dba9682de0b69a8822507a1c11d9f782c33b4c9">3dba9682de0b69a8822507a1c11d9f782c33b4c9</a>
-<blockquote>
-<p>
- Tweak art_pdf_composite_pixel_alpha_8_inline.<br>
-<br>
- Normal blending allows us to not only skip the art_blend_pixel_8_inline<br>
- call, but also to simplify the calculations.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-04 16:52: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=67bae85a6f46190262cf8a6ad6c37c7aff2e6cc5">67bae85a6f46190262cf8a6ad6c37c7aff2e6cc5</a>
-<blockquote>
-<p>
- Introduce forceinline define.<br>
-<br>
- It seems MSVC thinks it knows best about what to inline and what not to.<br>
-<br>
- Use new 'forceinline' define to persuade it to actually do what it is<br>
- told. On all non-MSVC compilers this just maps to inline.<br>
-<br>
-base/gxblend.c<br>
-base/stdpre.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-04 00:39:53 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a9f06af39ced9a69f5841ceef3f5e921c34ea5a7">a9f06af39ced9a69f5841ceef3f5e921c34ea5a7</a>
-<blockquote>
-<p>
- Further optimisation in pdf14_compose_group.<br>
-<br>
- Avoid memcpy's when unnecessary in some of the subfunctions,<br>
- by having a 'dst' pointer that points to the results. If<br>
- the results are supposed to be the same as the src, don't<br>
- copy the source, just reset the dst pointer.<br>
-<br>
- If the dst pointer is set to NULL, then don't copy the results<br>
- at all, as it'll be the current values unchanged.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-03 19:50:33 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=29e07d407e997a596f682cffa2069e5cea9e3fb4">29e07d407e997a596f682cffa2069e5cea9e3fb4</a>
-<blockquote>
-<p>
- Use inlining on pdf14_compose_group functions.<br>
-<br>
- We move pdf14_compose_group into gxblend.c to enable us to<br>
- make the constituent functions static inlines.<br>
-<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-03 19:09:00 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=65c442f7b2c1a91816f9026553004d66dde147ec">65c442f7b2c1a91816f9026553004d66dde147ec</a>
-<blockquote>
-<p>
- Tweak art_pdf_composite_knockout_group_8.<br>
-<br>
- Another case where we can avoid a memcpy by corrupting the source<br>
- data we are passed.<br>
-<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-03 18:45:30 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ef1126569bbdd405f7ef38eb5cd7e4928321f4f">7ef1126569bbdd405f7ef38eb5cd7e4928321f4f</a>
-<blockquote>
-<p>
- Further optimisations to compose_group.<br>
-<br>
- compose_group calls both art_pdf_recomposite_group_8 and<br>
- art_pdf_composite_group_8 next to one another. Both end<br>
- (in most cases) by doing an identical call to<br>
- art_pdf_composite_pixel_alpha_8.<br>
-<br>
- Tweak the code so that this call happens from the calling<br>
- routine (and thus we only have a single call to the routine).<br>
- This makes no difference now, but potentially saves when<br>
- we start inlining.<br>
-<br>
- The tweaks here to art_pdf_recomposite_group_8 to avoid<br>
- using a temporary array, *do* avoid a copy in the common case.<br>
-<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-03 18:09:05 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8d2a3a5b0f8280449d75ea99ddcadb69259370b6">8d2a3a5b0f8280449d75ea99ddcadb69259370b6</a>
-<blockquote>
-<p>
- Tweak art_pdf_recomposite_group_8.<br>
-<br>
- Avoid having to memcpy the input components in the common case,<br>
- at the expense of corrupting src[n_chan] in the difficult<br>
- case. This is fine, because our only caller never accesses<br>
- src[n_chan] again.<br>
-<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-03 15:05: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=ab6acb21bfc42194650ff90243e0737b43d81919">ab6acb21bfc42194650ff90243e0737b43d81919</a>
-<blockquote>
-<p>
- Start inlining optimisation of compose_group.<br>
-<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-03 13:41:20 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f2d625c260f174d2daa54508f0ff0147c4ad334">8f2d625c260f174d2daa54508f0ff0147c4ad334</a>
-<blockquote>
-<p>
- Tweak art_pdf_composite_knockout_group_8.<br>
-<br>
- This function has 2 branches, both of which end up with the same<br>
- call to art_pdf_knockout_composite_pixel_alpha_8. Tweak the<br>
- code so that we only need do one.<br>
-<br>
- No speedup expected, but this paces the way for inlining later.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-02 20:32:46 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83cd299b98510dc87cd3aa27f57a060b268e05ee">83cd299b98510dc87cd3aa27f57a060b268e05ee</a>
-<blockquote>
-<p>
- Do not overcopy bytes for pdf14 blending.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-03 16:56: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=88152e5c620bda7d25cd351c765751c619019a58">88152e5c620bda7d25cd351c765751c619019a58</a>
-<blockquote>
-<p>
- Tweak art_pdf_composite_pixel_alpha_8.<br>
-<br>
- art_pdf_composite_pixel_alpha_8 is used to blend src and<br>
- destination pixels together with a given blend mode.<br>
-<br>
- In the general case, we have n colour compoents, of which the<br>
- first n-s are process ones, and the next s are spots (followed<br>
- by alpha).<br>
-<br>
- In some cases, we need to blend the first n-s with the given blend<br>
- mode, and the remaining s in Normal mode.<br>
-<br>
- This is currently achieved in the code by making 2 different calls<br>
- down to art_pdf_composite_pixel_8 for each section of the pixel<br>
- (with different 'n' values).<br>
-<br>
- Unfortunately, due to alpha being assumed to be held as the nth<br>
- component, this means we need to do a dance where we stash away<br>
- a components value, copy the alpha in, call the routine, then<br>
- restore the alpha afterwards.<br>
-<br>
- To avoid this, we modify art_pdf_composite_pixel_alpha_8 to take<br>
- another int parameter, specifying the position of the first<br>
- component that needs to be blended with the Normal mode.<br>
-<br>
- This enables us to simplify the outer routines that call this so<br>
- that we have a single call, rather than 3. It also means we don't<br>
- recaulate 'scale' etc twice.<br>
-<br>
- I am not expecting any significant speedups from this alone, but<br>
- it simplifies the code so that hopefully we might get some in<br>
- later commits.<br>
-<br>
-base/gdevp14.c<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-base/gxp1fill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-03 16:55: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=5cc958e9c318ffd51223d6794df389b3c19d1aa1">5cc958e9c318ffd51223d6794df389b3c19d1aa1</a>
-<blockquote>
-<p>
- Tweak pdf14 compose group function towards optimisation.<br>
-<br>
- The plan here is to move towards optimised inner loops. The<br>
- initial version of these inner loops will be done using<br>
- static inline templating. This initial commit won't give<br>
- much (if any) improvement, but starts us on the road.<br>
-<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-02 17:42:34 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b26279df55a77fe2252de803a0e23ff4f703d609">b26279df55a77fe2252de803a0e23ff4f703d609</a>
-<blockquote>
-<p>
- Tweak art_pdf_composite_group_8.<br>
-<br>
- Avoid 2 different calls down to art_pdf_composite_pixel_alpha_8<br>
- when 1 will suffice. No expected speed benefit yet.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-02 14:48:54 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=463928c19de23164ec61e0fdea119195fa1450f4">463928c19de23164ec61e0fdea119195fa1450f4</a>
-<blockquote>
-<p>
- Inline versions of art_pdf_union_mul_8 and art_blend_pixel_8.<br>
-<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-01 12:40:53 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4505a7fa04bc89a3f9463b0bcf069210771a8a42">4505a7fa04bc89a3f9463b0bcf069210771a8a42</a>
-<blockquote>
-<p>
- Fix psd spot color handling in bmpcmp.<br>
-<br>
-toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-05 11:21: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=4f830ad24611ea8c88f78e77dd3b250ee3c55251">4f830ad24611ea8c88f78e77dd3b250ee3c55251</a>
-<blockquote>
-<p>
- PDF interpreter - remove accidental debugging<br>
-<br>
- Left some debugging in the SpotFunction array commit, remove it.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-05 11:11: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=75463b045f4ea314f1d22b1b63be5e3709ec59aa">75463b045f4ea314f1d22b1b63be5e3709ec59aa</a>
-<blockquote>
-<p>
- PDF Interpreter - support PDF 2.0 SpotFunction arrays<br>
-<br>
- Bug #698620 &quot;PDF 2.0 tests invalid halftones&quot;<br>
-<br>
- This was an oversight on my part, I missed new functionality when<br>
- reading the PDF 2.0 specification.<br>
-<br>
- The SpotFunction in a type 1 Halftone can now be a name, function or (new)<br>
- an array of names. If its an array we are supposed to check the entries<br>
- in turn selecting the first one we recognise. If we don't recognise any<br>
- then we should use the default.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-04 15:48: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=3d6168d9bdfe60f77bc60a270945c67e36ac02a3">3d6168d9bdfe60f77bc60a270945c67e36ac02a3</a>
-<blockquote>
-<p>
- Tweak pdf14_preserve_backdrop (for speed).<br>
-<br>
- First the current code clears the backdrop, then we copy into it.<br>
-<br>
- In many cases we overwrite exactly the area we just cleared. Spot<br>
- this, and avoid it.<br>
-<br>
- We *could* optimise this further in cases where we aren't overwriting<br>
- exactly the same region. Wait to see if this is justified.<br>
-<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-04 20:07: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=a2532236a8f85101c3d0377dde163071745c53bf">a2532236a8f85101c3d0377dde163071745c53bf</a>
-<blockquote>
-<p>
- Tweak pdf14_preserve_backdrop (for clarity).<br>
-<br>
- Reduce duplicated code.<br>
-<br>
- Also, ensure that the debugging code that dumps planes actually<br>
- dumps the plane that the file modifies.<br>
-<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-04 17:15:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=df32585f91bb6b1023fef42545cae2419b0e10db">df32585f91bb6b1023fef42545cae2419b0e10db</a>
-<blockquote>
-<p>
- PDF interpreter - permit 0 size font scaling, render nothing<br>
-<br>
- Bug #698619 &quot;PDF 2.0 tests 'zero sized text'&quot;<br>
-<br>
- The PDF 2.0 specification permits font scale of 0 (!), but nothing<br>
- should be rendered....<br>
-<br>
- We can't have a font scale of 0, because it breaks our arithmetic, so<br>
- we set it to a tiny value, unfortunately this still means that stroking<br>
- text rendering modes printed some small garbage.<br>
-<br>
- After a lot of effort with the PDF interpreter, I concluded that there<br>
- was no reasonable way to address this in PostScript, as we didn't<br>
- retain the font size anywhere and had no reasonable, non-volatile,<br>
- place to store it (it needs to respect gsave and grestore).<br>
-<br>
- So in the end I added it to the graphics state and created two new<br>
- operators to read and write it (and undefined them after startup).<br>
- Its an unfortunately brute-force approach, but it has the benefit of<br>
- actually working.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/pdf_ops.ps<br>
-base/gsstate.c<br>
-base/gsstate.h<br>
-base/gxgstate.h<br>
-psi/int.mak<br>
-psi/zgstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-04 14:07: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=3ea417610c5f0526251ed391bfd117a81c9801e1">3ea417610c5f0526251ed391bfd117a81c9801e1</a>
-<blockquote>
-<p>
- Version and dates for jbig2dec release<br>
-<br>
-jbig2dec/CHANGES<br>
-jbig2dec/config_win32.h<br>
-jbig2dec/configure.ac<br>
-jbig2dec/jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-03 16:50:56 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a7815f3b929a05ec8b5aaac965d62d5d370dcbe">4a7815f3b929a05ec8b5aaac965d62d5d370dcbe</a>
-<blockquote>
-<p>
- Fix incorrect group alpha calculation.<br>
-<br>
- In pdf14_compose_group, in the tos_isolated case, for simple<br>
- blends, we call art_pdf_composite_group_8 to apply blend_mode<br>
- to both process and spots. A side effect of this call is to<br>
- update the contents of nos_alpha_g_ptr.<br>
-<br>
- In more complex blends, we split the process and spots into<br>
- 2 different calls to the same function. The current code<br>
- however passes nos_alpha_g_ptr to both however, resulting in<br>
- it being updated twice.<br>
-<br>
- Fixed here by making one of them take NULL.<br>
-<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-03 10:01:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=71e8599455a7befc7a14f6cd1353c9231fb93d48">71e8599455a7befc7a14f6cd1353c9231fb93d48</a>
-<blockquote>
-<p>
- Bug 698615: pdf_add_ToUnicode() correct size of buffer<br>
-<br>
- We allocate a buffer to store the Unicode value, but failing to account for<br>
- the fact that the Unicode value is two bytes, rather than a byte<br>
-<br>
-devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-02 16:32:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a015666f7b532c1d9266c4cdef3427e0b50fea90">a015666f7b532c1d9266c4cdef3427e0b50fea90</a>
-<blockquote>
-<p>
- PDF interpreter - fix default /Decode for Lab images<br>
-<br>
- When we get an image with no /Decode array we create a default one for<br>
- it by looking at the image colour space.<br>
-<br>
- For Lab we use the /Range array, but unfortunately this only covers the<br>
- a and b channels, not the L. However, L always ranges from 0 - 100 so<br>
- here we just pull the Range array apart, add in that range, and create<br>
- a new array for the /Decode.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-28 18:04:20 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9e01cbd5e2d5ce41ae98ea20722ec9a7d452b9e9">9e01cbd5e2d5ce41ae98ea20722ec9a7d452b9e9</a>
-<blockquote>
-<p>
- Fix buffer overflow regression.<br>
-<br>
- The commit to address 694653 (3749bc274) was incorrect, the<br>
- font_data_size variable is not necessarily the size of the buffer.<br>
-<br>
-pcl/pcl/pcsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-28 10:08: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=eb24ad936776bf69f987e90aad8c7fca78fc2b14">eb24ad936776bf69f987e90aad8c7fca78fc2b14</a>
-<blockquote>
-<p>
- Documentation - spruce up WhatIsGS.htm<br>
-<br>
- Remove references to the obselete GhostSVG<br>
-<br>
- Remove references to MuPDF and MuXPS, MuPDF can easily stand alone now<br>
- and its not really part of the Ghostscript family.<br>
-<br>
-doc/WhatIsGS.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-27 08:34:10 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7e342b5978eb9df875a91980554835362412200d">7e342b5978eb9df875a91980554835362412200d</a>
-<blockquote>
-<p>
- Revert commit a5a2862d<br>
-<br>
- Even though the commit fixed bug 695280, we noticed that it caused PS<br>
- and PDF clist image logic to sometimes take the slow &quot;default&quot; handling<br>
- instead of the high-level image path.<br>
-<br>
- To restore the fix for PCL, we could remove the rop3_uses_T altogether,<br>
- but we don't know if this will impact PCL performance.<br>
-<br>
- Re-opening bug 695280.<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-27 16:35:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=40deeb89508e1072a4e93441ea58d6332d10fe4c">40deeb89508e1072a4e93441ea58d6332d10fe4c</a>
-<blockquote>
-<p>
- Documentation - remove reference to obselete switch<br>
-<br>
- Missed this when removing the implementation, PDFDontUseObjectNum is no<br>
- longer supported, so remove it from the documentation.<br>
-<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-26 13:30:16 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9bc74fe17f4699ae160564ba3fb281344d53dba6">9bc74fe17f4699ae160564ba3fb281344d53dba6</a>
-<blockquote>
-<p>
- Fix bug 698560. Transparent pattern-clist playback affected target device<br>
-<br>
- If a transparent pattern was stored as a pattern-clist, changes to the<br>
- pdf14_device during playback were applied to the upper level device, but<br>
- not restored after the playback. This fixes a long standing problem with<br>
- Bug692217.pdf (ELEMENTARY card was to light gray).<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-22 16:06:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8dd5ae8b9ea8dcae7775edb879f2949e2ee55be5">8dd5ae8b9ea8dcae7775edb879f2949e2ee55be5</a>
-<blockquote>
-<p>
- PDF interpreter - clamp Box to MediaBox, even when MediaBox is negative<br>
-<br>
- When applying the various 'Box' values from a PDF file, we need to clamp<br>
- them to the MediaBox values, so that we don't try and extend the final<br>
- output to be larger than the Media (this appears to be Acotbat's<br>
- behaviour).<br>
-<br>
- But we also need to account for the fact that the media (and therefore<br>
- the content) may not lie up and right. Its possible for the media to<br>
- be defined with negative height or width.<br>
-<br>
- We deal with that by scaling/translating the CTM, but we weren't<br>
- taking it into account when calculating the actual media size, which led<br>
- to us calculating the wrong size.<br>
-<br>
- This is more complicated, but we only do it once per page, so the<br>
- performance penalty is insignificant.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-22 12:36:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=819b79e75d8198d16b13c631d6842953f2c6ab81">819b79e75d8198d16b13c631d6842953f2c6ab81</a>
-<blockquote>
-<p>
- Bug 698581: Pscript5Idiom: add missing conditional (and bind)<br>
-<br>
- One of the procedures which Pscript5Idiom &quot;patches&quot; was missing an ifelse<br>
- meaning, when that idiom was hit, an unexecuted procedure was left on<br>
- the stack.<br>
-<br>
- For efficiency and consistency, also bind the entire procedure.<br>
-<br>
-Resource/IdiomSet/Pscript5Idiom<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-22 10:55: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=4a0b2e60e3ed23ec1f7f7e0390ce449bef03b8e4">4a0b2e60e3ed23ec1f7f7e0390ce449bef03b8e4</a>
-<blockquote>
-<p>
- Simpify confusing stack manipulations<br>
-<br>
- The existing code was not wrong, but did several unnecessary stack manipulations<br>
- that made it less efficient but, more importantly, confusing.<br>
-<br>
- Also, remove trailing whitespace.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-21 11:27: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=000915310197a25ff4acc97f0fa476085698d8fd">000915310197a25ff4acc97f0fa476085698d8fd</a>
-<blockquote>
-<p>
- Remove pointless free<br>
-<br>
- In an error condition, we were freeing the object that had failed to allocate.<br>
-<br>
- Not a problem with our memory manager, but might cause confusion reading the<br>
- code (it did for me!).<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-21 18:34: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=6f9ba1282eeb2537248fea11b686eefffc5b86fc">6f9ba1282eeb2537248fea11b686eefffc5b86fc</a>
-<blockquote>
-<p>
- Fix errors with 6b06b8c854<br>
-<br>
- The stack manipulations with the previous commit were not quite right.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-19 10:41:21 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6b06b8c85451bdf022f1684f633a85980e7c62ee">6b06b8c85451bdf022f1684f633a85980e7c62ee</a>
-<blockquote>
-<p>
- Bug 698559 avoid double alpha application<br>
-<br>
- When we have a softmask present in the graphic state, we<br>
- wrap up the fill or stroke with an isolated transparency<br>
- group in the interpreter. After the group is pushed we<br>
- should set the opacityalpha and the shapealpha to 1 to<br>
- avoid a double application of alpha at the rect-fill level and<br>
- the group composition level.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-21 10:13: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=8d57c8c54bd4fe8b5582a31dca69d034743eeacb">8d57c8c54bd4fe8b5582a31dca69d034743eeacb</a>
-<blockquote>
-<p>
- pdfwrite - fix compiler warnign<br>
-<br>
- Cast a pointer correctly to avoid a compiler warning.<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-20 16:48:27 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c1ba880345f3c17f828e28d4c42f38798eab73c2">c1ba880345f3c17f828e28d4c42f38798eab73c2</a>
-<blockquote>
-<p>
- Fix stroke/fill mismatches in 09-37.PS<br>
-<br>
- When 'accurate curves' are requested, ensure we use the same<br>
- curve -&gt; line decomposition for both strokes and fills.<br>
-<br>
-base/gxfill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-20 18:33: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=d9f068ae6d612f09dd37915edd56381c6a9167b7">d9f068ae6d612f09dd37915edd56381c6a9167b7</a>
-<blockquote>
-<p>
- Fix new scan converter glitch with CATX4547.pdf<br>
-<br>
- Page 11 of this file contains details on the revolvers cylinder<br>
- rendered by filling zero width vertical lines. For example:<br>
-<br>
- 0.165 0.068 0 0.187 scn<br>
- 506.47 162.99 m<br>
- 506.47 167.99 l<br>
- 506.47 162.99 l<br>
- f<br>
-<br>
- The new scan converter was incorrectly eliding this. Fixed by<br>
- tweaking the edgebuffer filtering logic for any-part-of-a-pixel<br>
- mode.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-19 18:01:27 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb95f670d3e54befca541dd35c2d7c2fe690ffbd">fb95f670d3e54befca541dd35c2d7c2fe690ffbd</a>
-<blockquote>
-<p>
- Fix in*fill etc test files.<br>
-<br>
- The new scan converter has been assuming that anything with an<br>
- x coord &lt; 0 is off screen. While this is true for almost every<br>
- device I can think of, it need not be true for the hit detection<br>
- device used for infill/instroke operations.<br>
-<br>
- Fixed to use INT_MIN here.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-20 15:37: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=29d1b0b1152324699f63ecf411bf7d590085c403">29d1b0b1152324699f63ecf411bf7d590085c403</a>
-<blockquote>
-<p>
- pdfwrite - fix UTF16 to UTF8 conversion<br>
-<br>
- There was a signed/unsigned error in the arguments to this routine,<br>
- which meant that bytes with the top bit set caused the whole UTF16<br>
- short to become negative as well.<br>
-<br>
- Fixed here.<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-19 17:43: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=c49536553df8eef02c6b0fbf1a46eeb2d086859d">c49536553df8eef02c6b0fbf1a46eeb2d086859d</a>
-<blockquote>
-<p>
- Write initial device error to stderr<br>
-<br>
- As the &quot;Unable to open the initial device, quitting.&quot; occurs outside the<br>
- Postscript error handling auspices, and causes Ghostscript to quit in a<br>
- possibly unexpected way, write it to stderr rather than stdout.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-19 13:59:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=085fc4933e5169176124922925f6cc6b454ac03e">085fc4933e5169176124922925f6cc6b454ac03e</a>
-<blockquote>
-<p>
- PS interpreter - set EPSCrop when EPSFitPage is set<br>
-<br>
- Bug #698555 &quot;using DEVICE[WIDTH|HEIGHT]POINTS results in blank image&quot;<br>
-<br>
- The reporter had not set -dEPSCrop which resulted in no PageSize<br>
- request being sent to the interpreter (because EPS files are note<br>
- permitted to set PageSize). Which defeats the use of PageSize Policy<br>
- 13 to scale the page.<br>
-<br>
- Since anyone using EPSFitPage clearly wants to scale the page to the EPS<br>
- BoundingBox, we may as well set EPSCrop in case they don't.<br>
-<br>
- NB the original reporter had not set -dFIXEDMEDIA either...<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-17 18:34: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=fc08a2810b1594ce865190763a7831704c00846d">fc08a2810b1594ce865190763a7831704c00846d</a>
-<blockquote>
-<p>
- pdfwrite - properly process Octal 134 '\' in pdfmark UTF16 string<br>
-<br>
- Bug #698552 &quot;Some PDF outline UTF-16 text is broken&quot;<br>
-<br>
- The escape processing wasn't catering for an escaped escape '\\' which<br>
- led to us writing the escaped escape direclty and corrupted the remainder<br>
- of the string. We normaly don't use short escapes but write ocral,<br>
- because some versions of Acrobat can't handle the short escapes.<br>
-<br>
- This commit just processes the '\\' properly, as per the other<br>
- escapes.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-17 11:46: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=275d9547b89aa17dc3a3d9441f712dfdfd344201">275d9547b89aa17dc3a3d9441f712dfdfd344201</a>
-<blockquote>
-<p>
- Coverity ID 172798<br>
-<br>
- We hadn't assigned the return value to the variable 'code' but were<br>
- using it (asigned earlier in the code) to action a return.<br>
-<br>
- Fixed by actually assigning the value to the variable.<br>
-<br>
-base/gxshade1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-16 23:34:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ce4bbbde09d087fe3af7036c1fc3f0a38f30c19e">ce4bbbde09d087fe3af7036c1fc3f0a38f30c19e</a>
-<blockquote>
-<p>
- PDF interpreter - more work on images with invalid /Mask<br>
-<br>
- Commit 119ec77d4e44e3861a376323ed14466b28b2f4bf fixed one case of a<br>
- /Mask array with invalid values by treating DeviceGray the same as<br>
- /Indexed. However, while that worked for the particular file in question<br>
- (Bug #697919) it caused a regression with Bug689717 which I somehow<br>
- missed at the time.<br>
-<br>
- This commit treats DeviceGray differently to Indexed spaces and<br>
- clamps the value to either 0 or 1 for 1 BPC images. This seems to work<br>
- as per Acrobat for both files.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 18:24:44 -0500
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7914df697a40314e35847f4e1faca5c964c19e84">7914df697a40314e35847f4e1faca5c964c19e84</a>
-<blockquote>
-<p>
- Bug 696399: Fix buffer overflow in image scaling.<br>
-<br>
- Patch calculation that overflows when x_extent is very<br>
- negative.<br>
-<br>
-base/gxifast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 14:28:28 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=176f0c2f9632b2167cbdd3a3ab44435af3b0bb64">176f0c2f9632b2167cbdd3a3ab44435af3b0bb64</a>
-<blockquote>
-<p>
- Remove stray memsets left in from previous commit.<br>
-<br>
- The &quot;Bug 698427: Fix ignoring errors that lead to division by<br>
- zero.&quot; commit contained stray memsets.<br>
-<br>
-base/gxshade1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 13:04:06 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=11a0bc253157ff84be1ef8d065d3ccbf8d377280">11a0bc253157ff84be1ef8d065d3ccbf8d377280</a>
-<blockquote>
-<p>
- Bug 698427: Fix ignoring errors that lead to division by zero.<br>
-<br>
- By ignoring error return values, we continue running with<br>
- uninitialised data, leading to division by zero.<br>
-<br>
-base/gxshade1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 10:58:11 -0500
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=887026173a2200dba9cb5eed39200f8f1e44cc7a">887026173a2200dba9cb5eed39200f8f1e44cc7a</a>
-<blockquote>
-<p>
- Coverity #135034: Simplify code.<br>
-<br>
- The while loop is not strictly required (but it does match<br>
- the other cases). Simplified here.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 10:47:54 -0500
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d7804bfc4d6bdd863137073bdc4f935c960a8f1d">d7804bfc4d6bdd863137073bdc4f935c960a8f1d</a>
-<blockquote>
-<p>
- Coverity #135037: Fix unused variable.<br>
-<br>
- Don't read a value we don't use.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-05 14:52: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=e289916162ce817275e05c536525954028e7d2bc">e289916162ce817275e05c536525954028e7d2bc</a>
-<blockquote>
-<p>
- Coverity ID# 135035<br>
-<br>
- Remove pointless &quot;upgraded_copypage&quot; code properly.<br>
-<br>
- The previous commit for this removed code that it should not have done<br>
-<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 13:42:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b3de06e71037a6abcf4546fa7d53a00a3ce47cc3">b3de06e71037a6abcf4546fa7d53a00a3ce47cc3</a>
-<blockquote>
-<p>
- Revert &quot;Coverity ID# 135035&quot;<br>
-<br>
- This reverts commit 05c3de8915fafb65b96ba0860523a7a79e2577e2.<br>
-<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-14 22:40: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=b76a38bc57de9085474474fc3de5ec295c9aec21">b76a38bc57de9085474474fc3de5ec295c9aec21</a>
-<blockquote>
-<p>
- Remove man pages for removed (obsolete) tools<br>
-<br>
- (Reported against 9.22 rc1)<br>
-<br>
-doc/gs-vms.hlp<br>
-man/de/font2c.1<br>
-man/de/wftopfa.1<br>
-man/font2c.1<br>
-man/gs.1<br>
-man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-14 07:01: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=6bf33a5d01518dcba8e957299a91a68d871f2b0b">6bf33a5d01518dcba8e957299a91a68d871f2b0b</a>
-<blockquote>
-<p>
- White space issues reported against 9.22 rc1<br>
-<br>
- It seems newer gcc versions (6.4.x and later) report indentation &quot;problems&quot;.<br>
-<br>
- Also, add a cast to ensure bitshift op is done on an unsigned value.<br>
-<br>
-base/gsbitops.c<br>
-base/gsicc_create.c<br>
-base/gxclread.c<br>
-contrib/gdevbjca.c<br>
-contrib/gdevdj9.c<br>
-devices/gdevepsc.c<br>
-pcl/pxl/pxpaint.c<br>
-psi/dscparse.c<br>
-psi/zcrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-14 06: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=d26d2bb23f2d8867d99d5f1fa08a37d3f131e1ad">d26d2bb23f2d8867d99d5f1fa08a37d3f131e1ad</a>
-<blockquote>
-<p>
- Bug 698532: replace ijs/ltmain.sh symlink with file<br>
-<br>
-ijs/ltmain.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-13 08:43: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=cadd9e5faede555fade5e7e8f447de8f40e5c5e9">cadd9e5faede555fade5e7e8f447de8f40e5c5e9</a>
-<blockquote>
-<p>
- Remove reference to old wisc site in Readme.htm<br>
- S<br>
-<br>
-doc/Readme.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-12 10:27:23 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=67b24cbd748db9d96061f476f42c87bd452a496e">67b24cbd748db9d96061f476f42c87bd452a496e</a>
-<blockquote>
-<p>
- Bump version number for release<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-12 11:17:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=95cb9ab7b4ef15bf60bd074220906f9eda145916">95cb9ab7b4ef15bf60bd074220906f9eda145916</a>
-<blockquote>
-<p>
- Remove unused variable 'pdev' to silence compiler warning<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-04 09:50: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=ba50b3c6061d35275b7067204da6f032fb46cf62">ba50b3c6061d35275b7067204da6f032fb46cf62</a>
-<blockquote>
-<p>
- Dates, product, changelog for 9.22 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/Xfonts.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>2017-10-03 10:01:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dcba89978e3cd6e8e55b44e0830594a385a8e07e">dcba89978e3cd6e8e55b44e0830594a385a8e07e</a>
-<blockquote>
-<p>
- Bug 698615: pdf_add_ToUnicode() correct size of buffer<br>
-<br>
- We allocate a buffer to store the Unicode value, but failing to account for<br>
- the fact that the Unicode value is two bytes, rather than a byte<br>
-<br>
-devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-02 16:32:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5751e508f72238c1fcaad1a4c284aa875542dd70">5751e508f72238c1fcaad1a4c284aa875542dd70</a>
-<blockquote>
-<p>
- PDF interpreter - fix default /Decode for Lab images<br>
-<br>
- When we get an image with no /Decode array we create a default one for<br>
- it by looking at the image colour space.<br>
-<br>
- For Lab we use the /Range array, but unfortunately this only covers the<br>
- a and b channels, not the L. However, L always ranges from 0 - 100 so<br>
- here we just pull the Range array apart, add in that range, and create<br>
- a new array for the /Decode.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-28 18:04:20 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c2974bcd2e638be13c0ec814342a1a35ca0872b">3c2974bcd2e638be13c0ec814342a1a35ca0872b</a>
-<blockquote>
-<p>
- Fix buffer overflow regression.<br>
-<br>
- The commit to address 694653 (3749bc274) was incorrect, the<br>
- font_data_size variable is not necessarily the size of the buffer.<br>
-<br>
-pcl/pcl/pcsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-28 11:37:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f1d39c92bff2de2d7b270a419a907c935ea626a6">f1d39c92bff2de2d7b270a419a907c935ea626a6</a>
-<blockquote>
-<p>
- Changelog for 9.22rc2<br>
-<br>
-doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-28 11:35:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1eda05a9fa7327e76b9a4af980d05da9e926e7f">b1eda05a9fa7327e76b9a4af980d05da9e926e7f</a>
-<blockquote>
-<p>
- Update dates/product for 9.22rc2<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/Xfonts.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>2017-09-28 10:08: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=d59e4b57e1807e934ed1dde51e628f84dfb8caa7">d59e4b57e1807e934ed1dde51e628f84dfb8caa7</a>
-<blockquote>
-<p>
- Documentation - spruce up WhatIsGS.htm<br>
-<br>
- Remove references to the obselete GhostSVG<br>
-<br>
- Remove references to MuPDF and MuXPS, MuPDF can easily stand alone now<br>
- and its not really part of the Ghostscript family.<br>
-<br>
-doc/WhatIsGS.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-27 08:34:10 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6830a293f9a69caf50777bb6ee7b553589c0a08">a6830a293f9a69caf50777bb6ee7b553589c0a08</a>
-<blockquote>
-<p>
- Revert commit a5a2862d<br>
-<br>
- Even though the commit fixed bug 695280, we noticed that it caused PS<br>
- and PDF clist image logic to sometimes take the slow &quot;default&quot; handling<br>
- instead of the high-level image path.<br>
-<br>
- To restore the fix for PCL, we could remove the rop3_uses_T altogether,<br>
- but we don't know if this will impact PCL performance.<br>
-<br>
- Re-opening bug 695280.<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-27 16:35:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c10d5ada53245dac13436d663d3dbe265bc9e11a">c10d5ada53245dac13436d663d3dbe265bc9e11a</a>
-<blockquote>
-<p>
- Documentation - remove reference to obselete switch<br>
-<br>
- Missed this when removing the implementation, PDFDontUseObjectNum is no<br>
- longer supported, so remove it from the documentation.<br>
-<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-26 13:30:16 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ccaaa1fd02f1cedf221bd6a34e5eb0ef64ef8f3f">ccaaa1fd02f1cedf221bd6a34e5eb0ef64ef8f3f</a>
-<blockquote>
-<p>
- Fix bug 698560. Transparent pattern-clist playback affected target device<br>
-<br>
- If a transparent pattern was stored as a pattern-clist, changes to the<br>
- pdf14_device during playback were applied to the upper level device, but<br>
- not restored after the playback. This fixes a long standing problem with<br>
- Bug692217.pdf (ELEMENTARY card was to light gray).<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-22 16:06:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c470609a95c3ba5d531da463df7a98da01998452">c470609a95c3ba5d531da463df7a98da01998452</a>
-<blockquote>
-<p>
- PDF interpreter - clamp Box to MediaBox, even when MediaBox is negative<br>
-<br>
- When applying the various 'Box' values from a PDF file, we need to clamp<br>
- them to the MediaBox values, so that we don't try and extend the final<br>
- output to be larger than the Media (this appears to be Acotbat's<br>
- behaviour).<br>
-<br>
- But we also need to account for the fact that the media (and therefore<br>
- the content) may not lie up and right. Its possible for the media to<br>
- be defined with negative height or width.<br>
-<br>
- We deal with that by scaling/translating the CTM, but we weren't<br>
- taking it into account when calculating the actual media size, which led<br>
- to us calculating the wrong size.<br>
-<br>
- This is more complicated, but we only do it once per page, so the<br>
- performance penalty is insignificant.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-22 12:36:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad87c56e9e88907854d4c37f1a80d8f5d06fb8a7">ad87c56e9e88907854d4c37f1a80d8f5d06fb8a7</a>
-<blockquote>
-<p>
- Bug 698581: Pscript5Idiom: add missing conditional (and bind)<br>
-<br>
- One of the procedures which Pscript5Idiom &quot;patches&quot; was missing an ifelse<br>
- meaning, when that idiom was hit, an unexecuted procedure was left on<br>
- the stack.<br>
-<br>
- For efficiency and consistency, also bind the entire procedure.<br>
-<br>
-Resource/IdiomSet/Pscript5Idiom<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-22 10:55: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=9ae11d7a06c216eae554bcc7696028e69c4bc7ee">9ae11d7a06c216eae554bcc7696028e69c4bc7ee</a>
-<blockquote>
-<p>
- Simpify confusing stack manipulations<br>
-<br>
- The existing code was not wrong, but did several unnecessary stack manipulations<br>
- that made it less efficient but, more importantly, confusing.<br>
-<br>
- Also, remove trailing whitespace.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-21 11:27: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=d644437adb7833a2c511d143c13e757383106378">d644437adb7833a2c511d143c13e757383106378</a>
-<blockquote>
-<p>
- Remove pointless free<br>
-<br>
- In an error condition, we were freeing the object that had failed to allocate.<br>
-<br>
- Not a problem with our memory manager, but might cause confusion reading the<br>
- code (it did for me!).<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-21 18:34: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=8760a38e4ca49ce403cb362ecb4d6b4d247587f1">8760a38e4ca49ce403cb362ecb4d6b4d247587f1</a>
-<blockquote>
-<p>
- Fix errors with 6b06b8c854<br>
-<br>
- The stack manipulations with the previous commit were not quite right.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-19 10:41:21 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc966e7f9029c27abc896431a3c4910b40d915ef">cc966e7f9029c27abc896431a3c4910b40d915ef</a>
-<blockquote>
-<p>
- Bug 698559 avoid double alpha application<br>
-<br>
- When we have a softmask present in the graphic state, we<br>
- wrap up the fill or stroke with an isolated transparency<br>
- group in the interpreter. After the group is pushed we<br>
- should set the opacityalpha and the shapealpha to 1 to<br>
- avoid a double application of alpha at the rect-fill level and<br>
- the group composition level.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-21 10:13: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=c03add9e9caaa4958928f74a6ca4f2b71915063c">c03add9e9caaa4958928f74a6ca4f2b71915063c</a>
-<blockquote>
-<p>
- pdfwrite - fix compiler warnign<br>
-<br>
- Cast a pointer correctly to avoid a compiler warning.<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-20 16:48:27 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2285580852e74940a4596b754739ba45a03b40d0">2285580852e74940a4596b754739ba45a03b40d0</a>
-<blockquote>
-<p>
- Fix stroke/fill mismatches in 09-37.PS<br>
-<br>
- When 'accurate curves' are requested, ensure we use the same<br>
- curve -&gt; line decomposition for both strokes and fills.<br>
-<br>
-base/gxfill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-20 18:33: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=0803369908a0b4b24b215881e4c4a4ecc5de61c2">0803369908a0b4b24b215881e4c4a4ecc5de61c2</a>
-<blockquote>
-<p>
- Fix new scan converter glitch with CATX4547.pdf<br>
-<br>
- Page 11 of this file contains details on the revolvers cylinder<br>
- rendered by filling zero width vertical lines. For example:<br>
-<br>
- 0.165 0.068 0 0.187 scn<br>
- 506.47 162.99 m<br>
- 506.47 167.99 l<br>
- 506.47 162.99 l<br>
- f<br>
-<br>
- The new scan converter was incorrectly eliding this. Fixed by<br>
- tweaking the edgebuffer filtering logic for any-part-of-a-pixel<br>
- mode.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-19 18:01:27 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=03ac50df18eb12d40de1615d18730fdd077f605b">03ac50df18eb12d40de1615d18730fdd077f605b</a>
-<blockquote>
-<p>
- Fix in*fill etc test files.<br>
-<br>
- The new scan converter has been assuming that anything with an<br>
- x coord &lt; 0 is off screen. While this is true for almost every<br>
- device I can think of, it need not be true for the hit detection<br>
- device used for infill/instroke operations.<br>
-<br>
- Fixed to use INT_MIN here.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-20 15:37: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=4bb7249ce9320c566da5dac3901c41c7965d37d8">4bb7249ce9320c566da5dac3901c41c7965d37d8</a>
-<blockquote>
-<p>
- pdfwrite - fix UTF16 to UTF8 conversion<br>
-<br>
- There was a signed/unsigned error in the arguments to this routine,<br>
- which meant that bytes with the top bit set caused the whole UTF16<br>
- short to become negative as well.<br>
-<br>
- Fixed here.<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-19 17:43: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=f2f9ed2897a4cf166c1df50422b2e82ad2422947">f2f9ed2897a4cf166c1df50422b2e82ad2422947</a>
-<blockquote>
-<p>
- Write initial device error to stderr<br>
-<br>
- As the &quot;Unable to open the initial device, quitting.&quot; occurs outside the<br>
- Postscript error handling auspices, and causes Ghostscript to quit in a<br>
- possibly unexpected way, write it to stderr rather than stdout.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-19 13:59:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5fc5b64a6cd3917326479d3d3a0546dca0feef3c">5fc5b64a6cd3917326479d3d3a0546dca0feef3c</a>
-<blockquote>
-<p>
- PS interpreter - set EPSCrop when EPSFitPage is set<br>
-<br>
- Bug #698555 &quot;using DEVICE[WIDTH|HEIGHT]POINTS results in blank image&quot;<br>
-<br>
- The reporter had not set -dEPSCrop which resulted in no PageSize<br>
- request being sent to the interpreter (because EPS files are note<br>
- permitted to set PageSize). Which defeats the use of PageSize Policy<br>
- 13 to scale the page.<br>
-<br>
- Since anyone using EPSFitPage clearly wants to scale the page to the EPS<br>
- BoundingBox, we may as well set EPSCrop in case they don't.<br>
-<br>
- NB the original reporter had not set -dFIXEDMEDIA either...<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-17 18:34: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=6e317f178c7fe7c81b573598f848acf8487e4e45">6e317f178c7fe7c81b573598f848acf8487e4e45</a>
-<blockquote>
-<p>
- pdfwrite - properly process Octal 134 '\' in pdfmark UTF16 string<br>
-<br>
- Bug #698552 &quot;Some PDF outline UTF-16 text is broken&quot;<br>
-<br>
- The escape processing wasn't catering for an escaped escape '\\' which<br>
- led to us writing the escaped escape direclty and corrupted the remainder<br>
- of the string. We normaly don't use short escapes but write ocral,<br>
- because some versions of Acrobat can't handle the short escapes.<br>
-<br>
- This commit just processes the '\\' properly, as per the other<br>
- escapes.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-17 11:46: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=122808aa46118d483c2fe431d5382c88cdd6e735">122808aa46118d483c2fe431d5382c88cdd6e735</a>
-<blockquote>
-<p>
- Coverity ID 172798<br>
-<br>
- We hadn't assigned the return value to the variable 'code' but were<br>
- using it (asigned earlier in the code) to action a return.<br>
-<br>
- Fixed by actually assigning the value to the variable.<br>
-<br>
-base/gxshade1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-16 23:34:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=087abbc55390499ca27823afbe7d1b62b4ff4f8e">087abbc55390499ca27823afbe7d1b62b4ff4f8e</a>
-<blockquote>
-<p>
- PDF interpreter - more work on images with invalid /Mask<br>
-<br>
- Commit 119ec77d4e44e3861a376323ed14466b28b2f4bf fixed one case of a<br>
- /Mask array with invalid values by treating DeviceGray the same as<br>
- /Indexed. However, while that worked for the particular file in question<br>
- (Bug #697919) it caused a regression with Bug689717 which I somehow<br>
- missed at the time.<br>
-<br>
- This commit treats DeviceGray differently to Indexed spaces and<br>
- clamps the value to either 0 or 1 for 1 BPC images. This seems to work<br>
- as per Acrobat for both files.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 18:24:44 -0500
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f1ccd5e2c82eb137abb7af000e93447653093a4d">f1ccd5e2c82eb137abb7af000e93447653093a4d</a>
-<blockquote>
-<p>
- Bug 696399: Fix buffer overflow in image scaling.<br>
-<br>
- Patch calculation that overflows when x_extent is very<br>
- negative.<br>
-<br>
-base/gxifast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 14:28:28 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a768ec17b12e44b20d555f3c2fc2c5dcde3d9f0b">a768ec17b12e44b20d555f3c2fc2c5dcde3d9f0b</a>
-<blockquote>
-<p>
- Remove stray memsets left in from previous commit.<br>
-<br>
- The &quot;Bug 698427: Fix ignoring errors that lead to division by<br>
- zero.&quot; commit contained stray memsets.<br>
-<br>
-base/gxshade1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 13:04:06 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=45e4bcf4992c6c22e942730f5df393fc6b4cab63">45e4bcf4992c6c22e942730f5df393fc6b4cab63</a>
-<blockquote>
-<p>
- Bug 698427: Fix ignoring errors that lead to division by zero.<br>
-<br>
- By ignoring error return values, we continue running with<br>
- uninitialised data, leading to division by zero.<br>
-<br>
-base/gxshade1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 10:58:11 -0500
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1b18e15f10532d584c6fc2191e1b2a3f8e5ba7e5">1b18e15f10532d584c6fc2191e1b2a3f8e5ba7e5</a>
-<blockquote>
-<p>
- Coverity #135034: Simplify code.<br>
-<br>
- The while loop is not strictly required (but it does match<br>
- the other cases). Simplified here.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 10:47:54 -0500
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6fb9174c1517143158781ed37e0c6d6eb9321808">6fb9174c1517143158781ed37e0c6d6eb9321808</a>
-<blockquote>
-<p>
- Coverity #135037: Fix unused variable.<br>
-<br>
- Don't read a value we don't use.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-05 14:52: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=228ac64b768ac3df1bcd5f63e3f353f8fd01e372">228ac64b768ac3df1bcd5f63e3f353f8fd01e372</a>
-<blockquote>
-<p>
- Coverity ID# 135035<br>
-<br>
- Remove pointless &quot;upgraded_copypage&quot; code properly.<br>
-<br>
- The previous commit for this removed code that it should not have done<br>
-<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 13:42:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3f9d3e1392236fef4658c8dcad15385670d6831e">3f9d3e1392236fef4658c8dcad15385670d6831e</a>
-<blockquote>
-<p>
- Revert &quot;Coverity ID# 135035&quot;<br>
-<br>
- This reverts commit 05c3de8915fafb65b96ba0860523a7a79e2577e2.<br>
-<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-14 22:40: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=12ff84c1ff077c737b0a194761a370de079943fd">12ff84c1ff077c737b0a194761a370de079943fd</a>
-<blockquote>
-<p>
- Remove man pages for removed (obsolete) tools<br>
-<br>
- (Reported against 9.22 rc1)<br>
-<br>
-doc/gs-vms.hlp<br>
-man/de/font2c.1<br>
-man/de/wftopfa.1<br>
-man/font2c.1<br>
-man/gs.1<br>
-man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-14 07:01: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=7df9b3d9b0dabd9854731fab796d5d458cf743f7">7df9b3d9b0dabd9854731fab796d5d458cf743f7</a>
-<blockquote>
-<p>
- White space issues reported against 9.22 rc1<br>
-<br>
- It seems newer gcc versions (6.4.x and later) report indentation &quot;problems&quot;.<br>
-<br>
- Also, add a cast to ensure bitshift op is done on an unsigned value.<br>
-<br>
-base/gsbitops.c<br>
-base/gsicc_create.c<br>
-base/gxclread.c<br>
-contrib/gdevbjca.c<br>
-contrib/gdevdj9.c<br>
-devices/gdevepsc.c<br>
-pcl/pxl/pxpaint.c<br>
-psi/dscparse.c<br>
-psi/zcrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-14 06: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=9e56aafaf2fc8fe3ffeefc0d13fa8c1b033ddec8">9e56aafaf2fc8fe3ffeefc0d13fa8c1b033ddec8</a>
-<blockquote>
-<p>
- Bug 698532: replace ijs/ltmain.sh symlink with file<br>
-<br>
-ijs/ltmain.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-13 08:43: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=98e115748ec4b16c610396b9444c1d82d263a30c">98e115748ec4b16c610396b9444c1d82d263a30c</a>
-<blockquote>
-<p>
- Remove reference to old wisc site in Readme.htm<br>
- S<br>
-<br>
-doc/Readme.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-12 11:17:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4241a4b3a7099cddac36d13f6c67054483eb7511">4241a4b3a7099cddac36d13f6c67054483eb7511</a>
-<blockquote>
-<p>
- Remove unused variable 'pdev' to silence compiler warning<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-12 11:16: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=29be703c9762714a47f67947d6dfb9efd6c6bc29">29be703c9762714a47f67947d6dfb9efd6c6bc29</a>
-<blockquote>
-<p>
- Changelog and news<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-12 10:32: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=85e04afbc2c80c8c6b129aff2741cbdf4d41ff67">85e04afbc2c80c8c6b129aff2741cbdf4d41ff67</a>
-<blockquote>
-<p>
- Update docs dates etc for release<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/Xfonts.htm<br>
-doc/gs-vms.hlp<br>
-doc/sample_downscale_device.htm<br>
-doc/thirdparty.htm<br>
-man/dvipdf.1<br>
-man/font2c.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>
-man/wftopfa.1<br>
-psi/int.mak<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-12 10:30:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=43561187cdb501ac1c6184082065647253d9336c">43561187cdb501ac1c6184082065647253d9336c</a>
-<blockquote>
-<p>
- Product string and date for release<br>
-<br>
-base/gscdef.c<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-
-<h2><a name="Version9.22"></a>Version 9.22 (2017-10-04)</h2>
-
-<p>This is the sixteeth full release in the stable 9.x series.
-
-<p> Highlights in this release include:
-<ul>
-<li>
-<p>Ghostscript can now consume and produce (via the pdfwrite device) PDF 2.0
-compliant files.
-</li>
-<li>
-<p>The main focus of this release has been security and code cleanliness. Hence
-many AddressSanitizer, Valgrind and Coverity issues have been addressed.
-</li>
-<li>
-<p>The usual round of bug fixes, compatibility changes, and incremental improvements.
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.22_Incompatible_changes"></a>Incompatible changes</h3>
-<ul>
-<li>
-<p>
-The planned device API tidy (still!) did not happen for this release, due to time pressures,
-but we still intend to undertake the following:
-We plan to somewhat tidy up the device API. We intend to remove deprecated device
-procs (methods/function pointers) and change the device API so every device proc
-takes a graphics state parameter (rather than the current scheme where only a
-very few procs take an imager state parameter). This should serve as notice to
-anyone maintaining a Ghostscript device outside the canonical source tree that
-you may (probably will) need to update your device(s) when these changes happen.
-Devices using only the non-deprecated procs should be trivial to update.
-</li>
-</ul>
-<h3><a name="9.22_changelog"></a>Changelog</h3>
-
-<p><strong>2017-10-03 10:01:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dcba89978e3cd6e8e55b44e0830594a385a8e07e">dcba89978e3cd6e8e55b44e0830594a385a8e07e</a>
-<blockquote>
-<p>
- Bug 698615: pdf_add_ToUnicode() correct size of buffer<br>
-<br>
- We allocate a buffer to store the Unicode value, but failing to account for<br>
- the fact that the Unicode value is two bytes, rather than a byte<br>
-<br>
-devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-10-02 16:32:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5751e508f72238c1fcaad1a4c284aa875542dd70">5751e508f72238c1fcaad1a4c284aa875542dd70</a>
-<blockquote>
-<p>
- PDF interpreter - fix default /Decode for Lab images<br>
-<br>
- When we get an image with no /Decode array we create a default one for<br>
- it by looking at the image colour space.<br>
-<br>
- For Lab we use the /Range array, but unfortunately this only covers the<br>
- a and b channels, not the L. However, L always ranges from 0 - 100 so<br>
- here we just pull the Range array apart, add in that range, and create<br>
- a new array for the /Decode.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-28 18:04:20 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c2974bcd2e638be13c0ec814342a1a35ca0872b">3c2974bcd2e638be13c0ec814342a1a35ca0872b</a>
-<blockquote>
-<p>
- Fix buffer overflow regression.<br>
-<br>
- The commit to address 694653 (3749bc274) was incorrect, the<br>
- font_data_size variable is not necessarily the size of the buffer.<br>
-<br>
-pcl/pcl/pcsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-28 11:35:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1eda05a9fa7327e76b9a4af980d05da9e926e7f">b1eda05a9fa7327e76b9a4af980d05da9e926e7f</a>
-<blockquote>
-<p>
- Update dates/product for 9.22rc2<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/Xfonts.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>2017-09-28 10:08: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=d59e4b57e1807e934ed1dde51e628f84dfb8caa7">d59e4b57e1807e934ed1dde51e628f84dfb8caa7</a>
-<blockquote>
-<p>
- Documentation - spruce up WhatIsGS.htm<br>
-<br>
- Remove references to the obselete GhostSVG<br>
-<br>
- Remove references to MuPDF and MuXPS, MuPDF can easily stand alone now<br>
- and its not really part of the Ghostscript family.<br>
-<br>
-doc/WhatIsGS.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-27 08:34:10 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6830a293f9a69caf50777bb6ee7b553589c0a08">a6830a293f9a69caf50777bb6ee7b553589c0a08</a>
-<blockquote>
-<p>
- Revert commit a5a2862d<br>
-<br>
- Even though the commit fixed bug 695280, we noticed that it caused PS<br>
- and PDF clist image logic to sometimes take the slow &quot;default&quot; handling<br>
- instead of the high-level image path.<br>
-<br>
- To restore the fix for PCL, we could remove the rop3_uses_T altogether,<br>
- but we don't know if this will impact PCL performance.<br>
-<br>
- Re-opening bug 695280.<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-27 16:35:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c10d5ada53245dac13436d663d3dbe265bc9e11a">c10d5ada53245dac13436d663d3dbe265bc9e11a</a>
-<blockquote>
-<p>
- Documentation - remove reference to obselete switch<br>
-<br>
- Missed this when removing the implementation, PDFDontUseObjectNum is no<br>
- longer supported, so remove it from the documentation.<br>
-<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-26 13:30:16 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ccaaa1fd02f1cedf221bd6a34e5eb0ef64ef8f3f">ccaaa1fd02f1cedf221bd6a34e5eb0ef64ef8f3f</a>
-<blockquote>
-<p>
- Fix bug 698560. Transparent pattern-clist playback affected target device<br>
-<br>
- If a transparent pattern was stored as a pattern-clist, changes to the<br>
- pdf14_device during playback were applied to the upper level device, but<br>
- not restored after the playback. This fixes a long standing problem with<br>
- Bug692217.pdf (ELEMENTARY card was to light gray).<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-22 16:06:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c470609a95c3ba5d531da463df7a98da01998452">c470609a95c3ba5d531da463df7a98da01998452</a>
-<blockquote>
-<p>
- PDF interpreter - clamp Box to MediaBox, even when MediaBox is negative<br>
-<br>
- When applying the various 'Box' values from a PDF file, we need to clamp<br>
- them to the MediaBox values, so that we don't try and extend the final<br>
- output to be larger than the Media (this appears to be Acotbat's<br>
- behaviour).<br>
-<br>
- But we also need to account for the fact that the media (and therefore<br>
- the content) may not lie up and right. Its possible for the media to<br>
- be defined with negative height or width.<br>
-<br>
- We deal with that by scaling/translating the CTM, but we weren't<br>
- taking it into account when calculating the actual media size, which led<br>
- to us calculating the wrong size.<br>
-<br>
- This is more complicated, but we only do it once per page, so the<br>
- performance penalty is insignificant.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-22 12:36:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad87c56e9e88907854d4c37f1a80d8f5d06fb8a7">ad87c56e9e88907854d4c37f1a80d8f5d06fb8a7</a>
-<blockquote>
-<p>
- Bug 698581: Pscript5Idiom: add missing conditional (and bind)<br>
-<br>
- One of the procedures which Pscript5Idiom &quot;patches&quot; was missing an ifelse<br>
- meaning, when that idiom was hit, an unexecuted procedure was left on<br>
- the stack.<br>
-<br>
- For efficiency and consistency, also bind the entire procedure.<br>
-<br>
-Resource/IdiomSet/Pscript5Idiom<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-22 10:55: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=9ae11d7a06c216eae554bcc7696028e69c4bc7ee">9ae11d7a06c216eae554bcc7696028e69c4bc7ee</a>
-<blockquote>
-<p>
- Simpify confusing stack manipulations<br>
-<br>
- The existing code was not wrong, but did several unnecessary stack manipulations<br>
- that made it less efficient but, more importantly, confusing.<br>
-<br>
- Also, remove trailing whitespace.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-21 11:27: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=d644437adb7833a2c511d143c13e757383106378">d644437adb7833a2c511d143c13e757383106378</a>
-<blockquote>
-<p>
- Remove pointless free<br>
-<br>
- In an error condition, we were freeing the object that had failed to allocate.<br>
-<br>
- Not a problem with our memory manager, but might cause confusion reading the<br>
- code (it did for me!).<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-21 18:34: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=8760a38e4ca49ce403cb362ecb4d6b4d247587f1">8760a38e4ca49ce403cb362ecb4d6b4d247587f1</a>
-<blockquote>
-<p>
- Fix errors with 6b06b8c854<br>
-<br>
- The stack manipulations with the previous commit were not quite right.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-19 10:41:21 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc966e7f9029c27abc896431a3c4910b40d915ef">cc966e7f9029c27abc896431a3c4910b40d915ef</a>
-<blockquote>
-<p>
- Bug 698559 avoid double alpha application<br>
-<br>
- When we have a softmask present in the graphic state, we<br>
- wrap up the fill or stroke with an isolated transparency<br>
- group in the interpreter. After the group is pushed we<br>
- should set the opacityalpha and the shapealpha to 1 to<br>
- avoid a double application of alpha at the rect-fill level and<br>
- the group composition level.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-21 10:13: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=c03add9e9caaa4958928f74a6ca4f2b71915063c">c03add9e9caaa4958928f74a6ca4f2b71915063c</a>
-<blockquote>
-<p>
- pdfwrite - fix compiler warnign<br>
-<br>
- Cast a pointer correctly to avoid a compiler warning.<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-20 16:48:27 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2285580852e74940a4596b754739ba45a03b40d0">2285580852e74940a4596b754739ba45a03b40d0</a>
-<blockquote>
-<p>
- Fix stroke/fill mismatches in 09-37.PS<br>
-<br>
- When 'accurate curves' are requested, ensure we use the same<br>
- curve -&gt; line decomposition for both strokes and fills.<br>
-<br>
-base/gxfill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-20 18:33: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=0803369908a0b4b24b215881e4c4a4ecc5de61c2">0803369908a0b4b24b215881e4c4a4ecc5de61c2</a>
-<blockquote>
-<p>
- Fix new scan converter glitch with CATX4547.pdf<br>
-<br>
- Page 11 of this file contains details on the revolvers cylinder<br>
- rendered by filling zero width vertical lines. For example:<br>
-<br>
- 0.165 0.068 0 0.187 scn<br>
- 506.47 162.99 m<br>
- 506.47 167.99 l<br>
- 506.47 162.99 l<br>
- f<br>
-<br>
- The new scan converter was incorrectly eliding this. Fixed by<br>
- tweaking the edgebuffer filtering logic for any-part-of-a-pixel<br>
- mode.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-19 18:01:27 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=03ac50df18eb12d40de1615d18730fdd077f605b">03ac50df18eb12d40de1615d18730fdd077f605b</a>
-<blockquote>
-<p>
- Fix in*fill etc test files.<br>
-<br>
- The new scan converter has been assuming that anything with an<br>
- x coord &lt; 0 is off screen. While this is true for almost every<br>
- device I can think of, it need not be true for the hit detection<br>
- device used for infill/instroke operations.<br>
-<br>
- Fixed to use INT_MIN here.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-20 15:37: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=4bb7249ce9320c566da5dac3901c41c7965d37d8">4bb7249ce9320c566da5dac3901c41c7965d37d8</a>
-<blockquote>
-<p>
- pdfwrite - fix UTF16 to UTF8 conversion<br>
-<br>
- There was a signed/unsigned error in the arguments to this routine,<br>
- which meant that bytes with the top bit set caused the whole UTF16<br>
- short to become negative as well.<br>
-<br>
- Fixed here.<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-19 17:43: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=f2f9ed2897a4cf166c1df50422b2e82ad2422947">f2f9ed2897a4cf166c1df50422b2e82ad2422947</a>
-<blockquote>
-<p>
- Write initial device error to stderr<br>
-<br>
- As the &quot;Unable to open the initial device, quitting.&quot; occurs outside the<br>
- Postscript error handling auspices, and causes Ghostscript to quit in a<br>
- possibly unexpected way, write it to stderr rather than stdout.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-19 13:59:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5fc5b64a6cd3917326479d3d3a0546dca0feef3c">5fc5b64a6cd3917326479d3d3a0546dca0feef3c</a>
-<blockquote>
-<p>
- PS interpreter - set EPSCrop when EPSFitPage is set<br>
-<br>
- Bug #698555 &quot;using DEVICE[WIDTH|HEIGHT]POINTS results in blank image&quot;<br>
-<br>
- The reporter had not set -dEPSCrop which resulted in no PageSize<br>
- request being sent to the interpreter (because EPS files are note<br>
- permitted to set PageSize). Which defeats the use of PageSize Policy<br>
- 13 to scale the page.<br>
-<br>
- Since anyone using EPSFitPage clearly wants to scale the page to the EPS<br>
- BoundingBox, we may as well set EPSCrop in case they don't.<br>
-<br>
- NB the original reporter had not set -dFIXEDMEDIA either...<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-17 18:34: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=6e317f178c7fe7c81b573598f848acf8487e4e45">6e317f178c7fe7c81b573598f848acf8487e4e45</a>
-<blockquote>
-<p>
- pdfwrite - properly process Octal 134 '\' in pdfmark UTF16 string<br>
-<br>
- Bug #698552 &quot;Some PDF outline UTF-16 text is broken&quot;<br>
-<br>
- The escape processing wasn't catering for an escaped escape '\\' which<br>
- led to us writing the escaped escape direclty and corrupted the remainder<br>
- of the string. We normaly don't use short escapes but write ocral,<br>
- because some versions of Acrobat can't handle the short escapes.<br>
-<br>
- This commit just processes the '\\' properly, as per the other<br>
- escapes.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-17 11:46: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=122808aa46118d483c2fe431d5382c88cdd6e735">122808aa46118d483c2fe431d5382c88cdd6e735</a>
-<blockquote>
-<p>
- Coverity ID 172798<br>
-<br>
- We hadn't assigned the return value to the variable 'code' but were<br>
- using it (asigned earlier in the code) to action a return.<br>
-<br>
- Fixed by actually assigning the value to the variable.<br>
-<br>
-base/gxshade1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-16 23:34:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=087abbc55390499ca27823afbe7d1b62b4ff4f8e">087abbc55390499ca27823afbe7d1b62b4ff4f8e</a>
-<blockquote>
-<p>
- PDF interpreter - more work on images with invalid /Mask<br>
-<br>
- Commit 119ec77d4e44e3861a376323ed14466b28b2f4bf fixed one case of a<br>
- /Mask array with invalid values by treating DeviceGray the same as<br>
- /Indexed. However, while that worked for the particular file in question<br>
- (Bug #697919) it caused a regression with Bug689717 which I somehow<br>
- missed at the time.<br>
-<br>
- This commit treats DeviceGray differently to Indexed spaces and<br>
- clamps the value to either 0 or 1 for 1 BPC images. This seems to work<br>
- as per Acrobat for both files.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 18:24:44 -0500
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f1ccd5e2c82eb137abb7af000e93447653093a4d">f1ccd5e2c82eb137abb7af000e93447653093a4d</a>
-<blockquote>
-<p>
- Bug 696399: Fix buffer overflow in image scaling.<br>
-<br>
- Patch calculation that overflows when x_extent is very<br>
- negative.<br>
-<br>
-base/gxifast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 14:28:28 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a768ec17b12e44b20d555f3c2fc2c5dcde3d9f0b">a768ec17b12e44b20d555f3c2fc2c5dcde3d9f0b</a>
-<blockquote>
-<p>
- Remove stray memsets left in from previous commit.<br>
-<br>
- The &quot;Bug 698427: Fix ignoring errors that lead to division by<br>
- zero.&quot; commit contained stray memsets.<br>
-<br>
-base/gxshade1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 13:04:06 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=45e4bcf4992c6c22e942730f5df393fc6b4cab63">45e4bcf4992c6c22e942730f5df393fc6b4cab63</a>
-<blockquote>
-<p>
- Bug 698427: Fix ignoring errors that lead to division by zero.<br>
-<br>
- By ignoring error return values, we continue running with<br>
- uninitialised data, leading to division by zero.<br>
-<br>
-base/gxshade1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 10:58:11 -0500
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1b18e15f10532d584c6fc2191e1b2a3f8e5ba7e5">1b18e15f10532d584c6fc2191e1b2a3f8e5ba7e5</a>
-<blockquote>
-<p>
- Coverity #135034: Simplify code.<br>
-<br>
- The while loop is not strictly required (but it does match<br>
- the other cases). Simplified here.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 10:47:54 -0500
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6fb9174c1517143158781ed37e0c6d6eb9321808">6fb9174c1517143158781ed37e0c6d6eb9321808</a>
-<blockquote>
-<p>
- Coverity #135037: Fix unused variable.<br>
-<br>
- Don't read a value we don't use.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-05 14:52: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=228ac64b768ac3df1bcd5f63e3f353f8fd01e372">228ac64b768ac3df1bcd5f63e3f353f8fd01e372</a>
-<blockquote>
-<p>
- Coverity ID# 135035<br>
-<br>
- Remove pointless &quot;upgraded_copypage&quot; code properly.<br>
-<br>
- The previous commit for this removed code that it should not have done<br>
-<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-15 13:42:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3f9d3e1392236fef4658c8dcad15385670d6831e">3f9d3e1392236fef4658c8dcad15385670d6831e</a>
-<blockquote>
-<p>
- Revert &quot;Coverity ID# 135035&quot;<br>
-<br>
- This reverts commit 05c3de8915fafb65b96ba0860523a7a79e2577e2.<br>
-<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-14 22:40: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=12ff84c1ff077c737b0a194761a370de079943fd">12ff84c1ff077c737b0a194761a370de079943fd</a>
-<blockquote>
-<p>
- Remove man pages for removed (obsolete) tools<br>
-<br>
- (Reported against 9.22 rc1)<br>
-<br>
-doc/gs-vms.hlp<br>
-man/de/font2c.1<br>
-man/de/wftopfa.1<br>
-man/font2c.1<br>
-man/gs.1<br>
-man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-14 07:01: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=7df9b3d9b0dabd9854731fab796d5d458cf743f7">7df9b3d9b0dabd9854731fab796d5d458cf743f7</a>
-<blockquote>
-<p>
- White space issues reported against 9.22 rc1<br>
-<br>
- It seems newer gcc versions (6.4.x and later) report indentation &quot;problems&quot;.<br>
-<br>
- Also, add a cast to ensure bitshift op is done on an unsigned value.<br>
-<br>
-base/gsbitops.c<br>
-base/gsicc_create.c<br>
-base/gxclread.c<br>
-contrib/gdevbjca.c<br>
-contrib/gdevdj9.c<br>
-devices/gdevepsc.c<br>
-pcl/pxl/pxpaint.c<br>
-psi/dscparse.c<br>
-psi/zcrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-14 06: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=9e56aafaf2fc8fe3ffeefc0d13fa8c1b033ddec8">9e56aafaf2fc8fe3ffeefc0d13fa8c1b033ddec8</a>
-<blockquote>
-<p>
- Bug 698532: replace ijs/ltmain.sh symlink with file<br>
-<br>
-ijs/ltmain.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-13 08:43: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=98e115748ec4b16c610396b9444c1d82d263a30c">98e115748ec4b16c610396b9444c1d82d263a30c</a>
-<blockquote>
-<p>
- Remove reference to old wisc site in Readme.htm<br>
- S<br>
-<br>
-doc/Readme.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-12 11:17:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4241a4b3a7099cddac36d13f6c67054483eb7511">4241a4b3a7099cddac36d13f6c67054483eb7511</a>
-<blockquote>
-<p>
- Remove unused variable 'pdev' to silence compiler warning<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-12 10:32: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=85e04afbc2c80c8c6b129aff2741cbdf4d41ff67">85e04afbc2c80c8c6b129aff2741cbdf4d41ff67</a>
-<blockquote>
-<p>
- Update docs dates etc for release<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/Xfonts.htm<br>
-doc/gs-vms.hlp<br>
-doc/sample_downscale_device.htm<br>
-doc/thirdparty.htm<br>
-man/dvipdf.1<br>
-man/font2c.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>
-man/wftopfa.1<br>
-psi/int.mak<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-12 10:30:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=43561187cdb501ac1c6184082065647253d9336c">43561187cdb501ac1c6184082065647253d9336c</a>
-<blockquote>
-<p>
- Product string and date for release<br>
-<br>
-base/gscdef.c<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-12 10:14: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=56ca27c9a95d7917baebd42b04cb08be872d1e39">56ca27c9a95d7917baebd42b04cb08be872d1e39</a>
-<blockquote>
-<p>
- PDF interpreter - handle invalid XRefStm in hybrid PDF file<br>
-<br>
- Bug #698519 &quot;Invalid XRefStm exits with error&quot;<br>
-<br>
- Just wrap the 'readpdf15xref pop' in a stopped if the user has not set<br>
- PDFSTOPONERROR, also add mark/cleartomark to clean up the stack.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-11 09:30:59 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a1cd439519aa07b5f70b1b044342d90377c1188e">a1cd439519aa07b5f70b1b044342d90377c1188e</a>
-<blockquote>
-<p>
- Coverity ID 94477 and 158386<br>
-<br>
- 94477 suggests a potential access (as an array pcc[i]) past the singelton<br>
- address which could occur if pgs-&gt;color_component_map.num_components &gt; 1<br>
- Copy the &quot;all&quot; value to an array to prevent the issue.<br>
-<br>
- 158386 was a mistake, fixed. Two differences show up with bitrgbtags, but<br>
- they look the same to me.<br>
- tests_private/comparefiles/Altona_Technical_v20_x4.pdf<br>
- tests_private/comparefiles/eci_altona-test-suite-v2_technical2_x4.pdf<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-11 16:22:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9e92e379d04979de614bbdb89a0af5f4aff187cb">9e92e379d04979de614bbdb89a0af5f4aff187cb</a>
-<blockquote>
-<p>
- Coverity ID 107344 and 107345, again....<br>
-<br>
- When testing the return value from ftell() don't assign it to an<br>
- unsigned int....<br>
-<br>
- Warning from clang this time<br>
-<br>
-devices/gdevgprf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-11 09:31: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=49d8d66c80d04bd7bfcae0c50e31b18355408e71">49d8d66c80d04bd7bfcae0c50e31b18355408e71</a>
-<blockquote>
-<p>
- Coverity ID 94485 revisited<br>
-<br>
- another place to check that fw is not negative. Missed the fact there<br>
- were two instances with the first commit.<br>
-<br>
-devices/minftrsz.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-11 09:31: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=954ed1df4b60bd9b3fc57b56cb7503cb950e05b9">954ed1df4b60bd9b3fc57b56cb7503cb950e05b9</a>
-<blockquote>
-<p>
- Coverity IDs 107344, 107345 revisited<br>
-<br>
- Check return values from ftell() as well as fseek()<br>
-<br>
-devices/gdevgprf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-11 08:22: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=988e56308515118b723d868e50e8b5836d43f803">988e56308515118b723d868e50e8b5836d43f803</a>
-<blockquote>
-<p>
- Coverity ID 171512<br>
-<br>
- Check return values from seek and propagate errors if encountered.<br>
-<br>
-pcl/pl/plparams.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-11 08:20: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=c35b385f02e007fe1edf086d8b5175af4a9836f9">c35b385f02e007fe1edf086d8b5175af4a9836f9</a>
-<blockquote>
-<p>
- Coverity IDs 171513 and 171514<br>
-<br>
- prevent potential divide by zero errors. Instead, propagate error<br>
- return codes.<br>
-<br>
-base/gen_ordered.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-10 12:40:14 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d94fd9bd9cb69a998c812eb2f04fdc0083895ae5">d94fd9bd9cb69a998c812eb2f04fdc0083895ae5</a>
-<blockquote>
-<p>
- Adjust .genordered 50% gray level to be on an desirable boundary<br>
-<br>
- Customer needs 50% gray level with 45 degree Angle and DotShape 8<br>
- to be a checkerboard pattern with no stray dots. Add a check to force<br>
- the step at 50% to be an even number of dots. Tested for Frequency<br>
- from 30 to 150 (at 600 dpi).<br>
-<br>
-psi/zht2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-07 15:38: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=dc8eb2a822bda44aab546e0bf7a0e35e3115696b">dc8eb2a822bda44aab546e0bf7a0e35e3115696b</a>
-<blockquote>
-<p>
- Coverity ID 94999<br>
-<br>
- I don't believe its actually possible to end up at the if (swap)<br>
- without setting run, because the few cases in the switch where we<br>
- don't set run, we go back to the top, swap the source and texture,<br>
- and then do the switch again, so somehow we will end up setting run<br>
-<br>
- But its cheap to initialise it, and it will silence Coverity, and it<br>
- guards against any possible future problem.<br>
-<br>
-base/gsroprun.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-05 16:53: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=ff5828a537fbf8b58095f5147b2acd59a6330941">ff5828a537fbf8b58095f5147b2acd59a6330941</a>
-<blockquote>
-<p>
- Compiler warning: discaring const<br>
-<br>
- The fix for coverity ID# 127201 introduced a compiler warning due to an<br>
- accessor macro (ctm_only) implicitly adding const. Make the local variable<br>
- const, too.<br>
-<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-05 15:46:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6846f1d5d8c7f5512fc385b3b9e2fa95cc720c53">6846f1d5d8c7f5512fc385b3b9e2fa95cc720c53</a>
-<blockquote>
-<p>
- Coverity ID# 94891<br>
-<br>
- Add a cast to make integer division explicit.<br>
-<br>
-base/gsdparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-07 13:35: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=534257c41de66f040fa548b47f2bf5950cb5a3cb">534257c41de66f040fa548b47f2bf5950cb5a3cb</a>
-<blockquote>
-<p>
- Coverity ID 94819<br>
-<br>
- No structural changes, just change a couple of pointer type declarations<br>
- I think this should satisfy Coverity and there doesn't seem to be any<br>
- actual problem here.<br>
-<br>
-base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-07 12:11:47 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f12500705c692b0ad51156081901fcd3457a5601">f12500705c692b0ad51156081901fcd3457a5601</a>
-<blockquote>
-<p>
- Coverity ID 158370<br>
-<br>
- Again we shouldn't be able to get to the flagged code with 'raster'<br>
- being uninitialised, because 'data', which is initialised to 0 would<br>
- have to be updated, and that would mean raster was updated as well.<br>
-<br>
- But since we already initialise data its cheap to initialise raster too.<br>
-<br>
-base/gximag3x.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-07 11:36: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=627b0c8a1228830917bb2420edb4613550dd4ef1">627b0c8a1228830917bb2420edb4613550dd4ef1</a>
-<blockquote>
-<p>
- Coverity ID 94819<br>
-<br>
- The comments on clist_end_page() state that it returns negative for an<br>
- error, 0 for success and positive for success with a low memory warning.<br>
-<br>
- In fact it always returns 0.<br>
-<br>
- This means we don't conform to the comments, and discard any errors that<br>
- occur.<br>
-<br>
- This commit reformats the code to reduce the number of tests and to<br>
- store the error codes, as well as adding the potential to return<br>
- something other than 0.<br>
-<br>
-base/gxclist.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-07 10:09:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be04e2ac2389e6fcc2ccf7b50434678c7aefa19d">be04e2ac2389e6fcc2ccf7b50434678c7aefa19d</a>
-<blockquote>
-<p>
- Coverity ID 94571<br>
-<br>
- Its not obvious whether raster can ever be 0 here, it clearly never is<br>
- during our tests, and I think it should not be possible, but just in<br>
- case we'll guard the division with a check.<br>
-<br>
-base/gsimage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-07 08:51: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=24bbc1ed3d0553964dd5086b08062442071e4ef5">24bbc1ed3d0553964dd5086b08062442071e4ef5</a>
-<blockquote>
-<p>
- Fix memory leak<br>
-<br>
- An error exit would leave 'filter' and 'screen_blur' allocated, and<br>
- therefore a memory leak.<br>
-<br>
-base/gen_ordered.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-06 15:51:33 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=30e336aee9812ca3610931f86ea641d82022c8ca">30e336aee9812ca3610931f86ea641d82022c8ca</a>
-<blockquote>
-<p>
- Second fix for missing FULL_FILE_NAME_LENGTH<br>
-<br>
- Previous commit fixed the RAW_SCREEN_DUMP=1 case, but broke the normal<br>
- case. Also added #ifndef RAW_SCREEN_DUMP around the setting in gen_odrered.h<br>
- so that the preprocesor flag could be set via the command line.<br>
-<br>
- Lastly, add base/gen_ordered.h to the Headers section of the .vcproj<br>
-<br>
-base/gen_ordered.h<br>
-toolbin/halftone/gen_ordered/gen_ordered.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-06 14:23:05 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a92188b76f30c5840ce8b0716e5c70e9791fb6eb">a92188b76f30c5840ce8b0716e5c70e9791fb6eb</a>
-<blockquote>
-<p>
- Fix RAW_SCREEN_DUMP for gen_ordered standalone<br>
-<br>
- In refactoring, I missed that FUL_FILE_NAME_LENGTH was needed if<br>
- RAW_SCREEN_DUMP was &gt; 0 (RAW_SCREEN_DUMP is #define'd in genordered.h,<br>
- so put the definition there.).<br>
-<br>
-base/gen_ordered.h<br>
-toolbin/halftone/gen_ordered/gen_ordered_main.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-06 19:08: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=6b085aa479bcf0c8cb426c0b51fe7f98faba72ff">6b085aa479bcf0c8cb426c0b51fe7f98faba72ff</a>
-<blockquote>
-<p>
- Coverity ID 94886<br>
-<br>
- Remove a NULL pointer check, there's no possible way the pointer<br>
- can be NULL at this point. Or if there is, its because a NULL<br>
- pointer was passed in as an argument, and we will seg fault earlier<br>
- in this function anyway, so no point in checking it here.<br>
-<br>
-base/gxfill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-06 19:06:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=754e99239371ec4aa06a9728ae65028ac22c440c">754e99239371ec4aa06a9728ae65028ac22c440c</a>
-<blockquote>
-<p>
- Coverity ID 94627<br>
-<br>
- Guard the dereference of pdht with a NULL pointer test, to avoid a<br>
- potential seg fault.<br>
-<br>
-base/gxdevndi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-06 16:31: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=6857ef647312daa24eb47417b09d823e8b59831d">6857ef647312daa24eb47417b09d823e8b59831d</a>
-<blockquote>
-<p>
- Coverity ID 141334<br>
-<br>
- Add some error checking<br>
-<br>
-base/gxclip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-06 15:58: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=198924f4c94c561543f5838900e21ed761a886a5">198924f4c94c561543f5838900e21ed761a886a5</a>
-<blockquote>
-<p>
- Coverity ID 95001<br>
-<br>
- We can only get back here by jumping to the label 'top'. ymax is not<br>
- used between this point and the last 'goto top', and it is then<br>
- recalculated before being used.<br>
-<br>
- So the assignment is indeed pointless.<br>
-<br>
-base/gxacpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-06 15:11:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0808c9eec2a92db3176b3eac0520f48a2119ddf9">0808c9eec2a92db3176b3eac0520f48a2119ddf9</a>
-<blockquote>
-<p>
- Coverity IDs 164020, 164022, 164025<br>
-<br>
- We don't need to check if dot_grid.data is NULL.<br>
-<br>
- Testing a == 0 &amp;&amp; b == 0 after testing a nd b individually can't be<br>
- correct. Test for both being zero first.<br>
-<br>
- In the case of an error, we could attempt to free memory that had not<br>
- been allocated. Prevent this by checking dot_level_pos is non-NULL.<br>
-<br>
-base/gen_ordered.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-06 14:37:21 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=05768db75e90f56c6fda33c9c14515a3e0b6aeaa">05768db75e90f56c6fda33c9c14515a3e0b6aeaa</a>
-<blockquote>
-<p>
- Addition to commit 18f009a08f1eac4708188b516d375356a502a3b1<br>
-<br>
- Forgot to initialise the pointer to NULL before starting.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-06 10:03: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=18f009a08f1eac4708188b516d375356a502a3b1">18f009a08f1eac4708188b516d375356a502a3b1</a>
-<blockquote>
-<p>
- Coverity IDs 138751, 141130, 141131, 158373<br>
-<br>
- 138751 - The code assumes that a separating device has an ICC profile<br>
- but doesn't check. Add a check and return an error if it doesn't.<br>
-<br>
- 141130 - initialise a structure member<br>
-<br>
- 141131 - check and action return codes<br>
-<br>
- 158373 put #if DEBUG round some code that's only present to provide a<br>
- breakpoint location in debuggers. (and told Coverity to ignore this)<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-05 15:28:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=61856e04852124491a47fa6379f1c3ad296f3366">61856e04852124491a47fa6379f1c3ad296f3366</a>
-<blockquote>
-<p>
- Coverity ID# 122660<br>
-<br>
- NULL pointer check - the code branch above already does so, looks like a simple<br>
- ommission<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-05 15:21:23 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1b9ea22b3456a24e356d3f5a68036cecbb28af56">1b9ea22b3456a24e356d3f5a68036cecbb28af56</a>
-<blockquote>
-<p>
- Coverity ID# 126580<br>
-<br>
- Explicitly promote an unsigned char value to a long.<br>
-<br>
-base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-05 15:12: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=28e95004b508a3f4cd73552d92f7f4cd699c645b">28e95004b508a3f4cd73552d92f7f4cd699c645b</a>
-<blockquote>
-<p>
- Coverity ID# 127201<br>
-<br>
- Fix potential NULL pgs (graphics state) pointer dereference. I suspect this can<br>
- never occur, but it's cheap and should silence coverity<br>
-<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-05 14:52: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=05c3de8915fafb65b96ba0860523a7a79e2577e2">05c3de8915fafb65b96ba0860523a7a79e2577e2</a>
-<blockquote>
-<p>
- Coverity ID# 135035<br>
-<br>
- Remove pointless &quot;upgraded_copypage&quot; code.<br>
-<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-05 14:18:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a6045cc4c7843ee8608c1d4a2fb76e8a10a6581">9a6045cc4c7843ee8608c1d4a2fb76e8a10a6581</a>
-<blockquote>
-<p>
- Coverity ID 95054<br>
-<br>
- Explicitly initialise a member of the new 'order' structure.<br>
-<br>
-base/gxdhtserial.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-05 13:36: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=7dd033589ce40649ab602fba4c0473aa40c48439">7dd033589ce40649ab602fba4c0473aa40c48439</a>
-<blockquote>
-<p>
- Bug 698471: apply vertical substitute glyphs in TTF fonts<br>
-<br>
- We weren't applying vertical glyph substition (from the gsub table).<br>
-<br>
-base/gstype42.c<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-05 13:23:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f753769041467a1c88084d6d26c2755d7174691d">f753769041467a1c88084d6d26c2755d7174691d</a>
-<blockquote>
-<p>
- Bug 698486: memory leaks from fontconfig calls<br>
-<br>
- Address most of the memory leaks stemming from the use of fontconfig.<br>
-<br>
- In this case, just destroying the fontconfig context.<br>
-<br>
-base/gp_unix.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-04 09:39: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=8b249d3ebd8058f2961770e21c72e1ac703cc12f">8b249d3ebd8058f2961770e21c72e1ac703cc12f</a>
-<blockquote>
-<p>
- Coverity ID 139142: etc.c modulo by zero<br>
-<br>
- Only calculate tmline when it will actually be used. The calculation uses<br>
- y % tmheight, but only the ETS_RSTYLE_THRESHOLD case is called with<br>
- tmheight != 0<br>
-<br>
-base/ets.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-05 12:16: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=463854833474dc3ae642e17707e50c451ada1fec">463854833474dc3ae642e17707e50c451ada1fec</a>
-<blockquote>
-<p>
- Coverity ID 94994<br>
-<br>
- Check a return value and action it.<br>
-<br>
-base/gxp1fill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-05 11:41: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=aa75f905024bdf13882c30e543d64e285e22aad1">aa75f905024bdf13882c30e543d64e285e22aad1</a>
-<blockquote>
-<p>
- Coverity ID 158395<br>
-<br>
- I think its not currently possible to trigger this, as it would require<br>
- setting up the device pointer incorrectly before entering this routine.<br>
- However Coverity is correct that it appears possible to end up doing<br>
- a NULL pointer dereference, so add a guard to maek sure that can't<br>
- happen.<br>
-<br>
-base/gzspotan.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-05 10:45:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=06b5a54361525363bdc163b88f965f0d1a295087">06b5a54361525363bdc163b88f965f0d1a295087</a>
-<blockquote>
-<p>
- Coverity ID 94914<br>
-<br>
- Remove an unnecessary copy of a variable, its unconditionally<br>
- overwritten immediately after. Comment that.<br>
-<br>
-base/sfilter2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-05 09:58: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=3f40707f85296c0abf798c9c32c79db33affbddc">3f40707f85296c0abf798c9c32c79db33affbddc</a>
-<blockquote>
-<p>
- Coverity IDs 94554 and 94551<br>
-<br>
- We weren't checking the return values from gp_fseek_64 or fstat() and<br>
- in a couple of places weren't even able to return an error anyway<br>
- (void function).<br>
-<br>
- So check the error returns from the C run-time and add error handling<br>
- as required in order too report these.<br>
-<br>
-base/sfxcommon.c<br>
-base/sfxstdio.c<br>
-base/stream.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-04 19:02: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=ac6c349f54b09df7b2f8cf606b8fe7e62291c2e0">ac6c349f54b09df7b2f8cf606b8fe7e62291c2e0</a>
-<blockquote>
-<p>
- Coverity ID 94959<br>
-<br>
- We were failing to free a couple of allocated buffers in the event of an<br>
- error. The other error test all free both buffers properly.<br>
-<br>
-devices/rinkj/rinkj-epson870.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-04 17:26: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=a11bd1f982f8a8491a4c1ab45aa5535426d01dca">a11bd1f982f8a8491a4c1ab45aa5535426d01dca</a>
-<blockquote>
-<p>
- Coverity IDs 94868, 94936, 158371<br>
-<br>
- Initialise some arrays, these are sparsely populated by the code and<br>
- potentially possible to access uninitialised data.<br>
-<br>
-devices/rinkj/evenbetter-rll.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-04 17:01:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=538f12d7bdd292c4798161a5d49ba2f3bcfebbe3">538f12d7bdd292c4798161a5d49ba2f3bcfebbe3</a>
-<blockquote>
-<p>
- Alter the fix for Coverity ID 94726<br>
-<br>
- Ray objected to my original change, because the debug output would not<br>
- be a valid file. So instead we choose to lose the information that<br>
- logbits2 is non-zero and drop the if clause.<br>
-<br>
-devices/gdevplib.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-04 16:57: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=e0d49f799157f2d0ba1ea4969cc225a15d108cf7">e0d49f799157f2d0ba1ea4969cc225a15d108cf7</a>
-<blockquote>
-<p>
- Coverity IDs 94478 and 94485<br>
-<br>
- The first is a clear typo, the code below this point is the same as the<br>
- code modified in this commit.<br>
-<br>
- The second one is less clear, but I think its reasonable, if there is<br>
- no '0' (-1 return from next_zero()) then we can't make the feature<br>
- larger by darkening to the right, so darken to the left.<br>
-<br>
-devices/minftrsz.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-04 16:27: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=f7d9662c5737d42942dbe1f5d4e74a9d00838b56">f7d9662c5737d42942dbe1f5d4e74a9d00838b56</a>
-<blockquote>
-<p>
- Coverity ID 94479<br>
-<br>
- The macro used here says it shouldn't be used for run-time calculations.<br>
- However this code does use it, I'm not certain for what purpose. Since<br>
- it clearly is possible to get a negative shift, add a guard to the<br>
- values to make sure that can't happen.<br>
-<br>
- Since this code is conditionally compiled out, anyone who compiled it<br>
- in and finds a problem can easily fix it.<br>
-<br>
-devices/gdevxcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-04 15:56:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0462b654d8a57688c1b811a4e04ad8a7aaf0dab9">0462b654d8a57688c1b811a4e04ad8a7aaf0dab9</a>
-<blockquote>
-<p>
- Coverity ID 127202<br>
-<br>
- Check the stored graphics state and if its 0, use the default method.<br>
-<br>
- Remove the now redundant later check on pgs being 0 before use.<br>
-<br>
-devices/gdevx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-04 15:16:42 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c5d0e0970e60d9d4c61865d61fb39629dfd6623">2c5d0e0970e60d9d4c61865d61fb39629dfd6623</a>
-<blockquote>
-<p>
- Coverity IDs 94503, 94506, 94523, 94536<br>
-<br>
- A number of pointless comparisons, checking that a signed 32-bit variable<br>
- had a value less than the maximum for a signed 32-bit integer.<br>
-<br>
- Remove them all.<br>
-<br>
-devices/gdevupd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-04 14:32:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ae7f71a161803d10f263585e8b2e5087835f51b8">ae7f71a161803d10f263585e8b2e5087835f51b8</a>
-<blockquote>
-<p>
- Coverity IDs 94719, 94889, 94912, 94967, 95088, 101187<br>
-<br>
- Return an error instead of storing it (where it gets lost)<br>
-<br>
- As per gdevpsd.c and gdevprf.c refactor the #if conditional compiled<br>
- code to remove a variable and get rid of Coverity warning.<br>
-<br>
- In the 'build_cmyk_raster_line_fromplanar* routines, pass the params as<br>
- a pointer instead of copying the whole 500+ byte structure around.<br>
-<br>
- Finally, not a Coverity warning but a compiler warning; remove an unused<br>
- variable.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-04 13:47: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=413cefabb9888c0810e1c4c23e603fa4e69c7c1d">413cefabb9888c0810e1c4c23e603fa4e69c7c1d</a>
-<blockquote>
-<p>
- Coverity IDs 94856 and 94719<br>
-<br>
- If we get an error from param_read_name, then just return it.<br>
-<br>
- The AddLut lookup is less obvious. Clearly the size of the LUT read from<br>
- the config file should not be less than 0, but there's no clear upper<br>
- limit (other than an unsigned integer). However a 4Gb config file seems<br>
- unlikely. The only example we have has ~23 values for each plane, so a<br>
- limit of 256 entries seems reasonable. If anyone complains its easy to<br>
- increase and we can ask the user what a reasonable limit should be.<br>
-<br>
-devices/gdevrinkj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-04 13:12: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=1cf6a2a71851e507716bd5c82c8c991239ac04e0">1cf6a2a71851e507716bd5c82c8c991239ac04e0</a>
-<blockquote>
-<p>
- Coverity ID 94728<br>
-<br>
- As with gdevgprf.c, refactor the #if conditional compilation so that we<br>
- don't need a variable, and remove the Coverity warning.<br>
-<br>
-devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-04 12:12: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=cdceb9e93516264fcdae965e5eeb0e733bad76ee">cdceb9e93516264fcdae965e5eeb0e733bad76ee</a>
-<blockquote>
-<p>
- Coverity IDs 94596, 94726<br>
-<br>
- A debug print was identical in both the if and else clauses. Not really<br>
- important since its debug, but change the else to match others of the<br>
- same type.<br>
-<br>
- line_ptrs was calculated and altered in the loop invocation, but its<br>
- then immediately overwritten in the loop body, making it pointless.<br>
-<br>
-devices/gdevplib.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-04 11:29:50 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=11e90b8945a54e4e16c702a4ba4ed19cef47f4a2">11e90b8945a54e4e16c702a4ba4ed19cef47f4a2</a>
-<blockquote>
-<p>
- Coverity ID 158390<br>
-<br>
- Since line is recalculated inside the loop on every iteration, there's<br>
- no point in calculating it in the loop definition.<br>
-<br>
-devices/gdevphex.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-04 10:47:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=615d7caf21e957fe3716ef9264def280df20beb7">615d7caf21e957fe3716ef9264def280df20beb7</a>
-<blockquote>
-<p>
- Coverity IDs 121444, 121445, 121449<br>
-<br>
- More problems with intermediate promotion to int, probably caused when<br>
- gx_color_index went from 32 to 64 bits.<br>
-<br>
-devices/gdevpbm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-04 10:29: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=65ef52484c9a973f5fcb72b258cf1bf5a4653a75">65ef52484c9a973f5fcb72b258cf1bf5a4653a75</a>
-<blockquote>
-<p>
- Coverity ID 158391<br>
-<br>
- Initialise 'backtable'. The code does later fill in some entries in<br>
- backtable, but it doesn't fill all of them and I can see no coherence<br>
- between the filling in code and the code that reads data from it. It<br>
- really does look like its possible to read uninitialised data here.<br>
-<br>
-devices/gdevmgr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-03 17:14: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=5f73a2c82f0cbd0d0965709066ebdf13cc0b9c9d">5f73a2c82f0cbd0d0965709066ebdf13cc0b9c9d</a>
-<blockquote>
-<p>
- Coverity ID 94489<br>
-<br>
- The spec says that it must be 3 bytes, and uses a 16 bit shift example<br>
- (suggesting it is stored in the Brother driver as 24 bits).<br>
-<br>
- For us its a short, so rather than copy the brother code, set it to 0 to<br>
- avoid any confusion over whether shifting a short right by 16 results in<br>
- all 0 or all 1.<br>
-<br>
-devices/gdevhl7x.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-03 11:48: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=4e122728ecf07941e15f75fc7feaec57eeb54e90">4e122728ecf07941e15f75fc7feaec57eeb54e90</a>
-<blockquote>
-<p>
- Coverity IDs 107340, 107341, 107343, 107344, 107345, 121455<br>
-<br>
- Considerable rework of error checking in this device.<br>
-<br>
- Firstly add error return checks on fseek and fwrite. Alter functions to<br>
- return those errors. Alter the parent functions to check the errors,<br>
- repeat until we bubble up to the top level.<br>
-<br>
- Coverity claims that ftell() can return a negative value, which as far<br>
- as I can see is not true. However, by casting the return value to an<br>
- unsigned type, and altering the variable types appropriately, I think<br>
- we should eliminate this warning.<br>
-<br>
- Refactor conditionally compiled code to eliminate a variable and get<br>
- rid of a dead code warning.<br>
-<br>
-devices/gdevgprf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-02 18: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=18d430f97d95d5919fb9ea06b63423c8367548b9">18d430f97d95d5919fb9ea06b63423c8367548b9</a>
-<blockquote>
-<p>
- Coverity ID 94722<br>
-<br>
- Change the way memory allocation and free'ing is done so that we no<br>
- longer check row_first, which is always 0. THis should mean that we<br>
- don't need to check min_feature_data before passing it to<br>
- min_feature_size_process(), it is allocated in min_feature_size_init()<br>
- and we do actually now check the return value from there to ensure<br>
- there are no errors which could leave min_feature_data uninitialised.<br>
-<br>
-devices/gdevfax.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-02 17:19: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=4b07f41941f75fc54cd6937ff18426402ab9af36">4b07f41941f75fc54cd6937ff18426402ab9af36</a>
-<blockquote>
-<p>
- Coverity IDs 94575 and 94722<br>
-<br>
- Remove some dead code, refactor and add error checking to avoid a NULL<br>
- pointer dereference<br>
-<br>
-devices/gdevdjtc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-02 16:33: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=6a4506040593416d23930049e41e806336335e67">6a4506040593416d23930049e41e806336335e67</a>
-<blockquote>
-<p>
- Coverity ID 94526<br>
-<br>
- Add some error checking on file handling, and report ioerrors if they<br>
- fail.<br>
-<br>
-devices/gdevdfax.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-02 15:09:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=998dd6a53f17104decc8533d5978023fdd008c21">998dd6a53f17104decc8533d5978023fdd008c21</a>
-<blockquote>
-<p>
- Coverity ID 94814 and 94980<br>
-<br>
- I wasn't able to find a way to reproduce this, because it relies on<br>
- a particular sequence of lines/points. We must fill the data buffer to<br>
- the point where another line or curve will not fit, and then the next<br>
- curve or line must be a 'POINTS_NONE'.<br>
-<br>
- In this case we will not flush the accumulated points, which means we<br>
- will not reset the counter, but we will then still go on to save the<br>
- current co-ordinates in the data buffer, which will cause an overflow.<br>
-<br>
- Fixed by reducing the 'full' check slightly, so that we still have one<br>
- line/curve slot open in the data buffer. If we get a POINTS_NONE then<br>
- we check to see if we have already gone past the slop. If we have, simply<br>
- reduce the counter by one which will cause us to overwrite the previous<br>
- points. Since this must have also been a POINTS_NONE, this just means<br>
- in effect that we have combined consecutive ones.<br>
-<br>
- I'm not certain its even possible to get consecutive POINTS_NONE, but<br>
- its best to be safe.<br>
-<br>
- This should silence Coverity, and fixes the genuine (if hard to<br>
- reproduce) potential problem.<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-02 11:02: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=3a98b6855660c84b2fa5529cc25bdbdc4b2b9d7a">3a98b6855660c84b2fa5529cc25bdbdc4b2b9d7a</a>
-<blockquote>
-<p>
- Coverity ID 94943<br>
-<br>
- I think this code is incorrect, because this routine *always* maps<br>
- CMYK to CMYK, so there's no need to test the colour depth.<br>
-<br>
- Also, it always gets provided with a CMYK buffer, not an RGB one so it<br>
- actually can't write off the end of the buffer. But the declaration<br>
- was wrong, so fix that here to avoid the warning.<br>
-<br>
-devices/gdevcdj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-02 10:55:51 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=065b5cc15cea365c3fa5a1f3133416a0db228082">065b5cc15cea365c3fa5a1f3133416a0db228082</a>
-<blockquote>
-<p>
- Coverity ID 95019<br>
-<br>
- This code was unreachable, its even commented as such. So lets just<br>
- remove it.<br>
-<br>
-devices/gdevcdj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-02 10:54: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=a48211dc97ef345261e7e9a08818dd274b07040e">a48211dc97ef345261e7e9a08818dd274b07040e</a>
-<blockquote>
-<p>
- Coverity ID 94736<br>
-<br>
- Guard against a NULL pointer dereference. If we didn't recognise the<br>
- pritner type, then it was possible to attempt to use a NULL pointer.<br>
-<br>
-devices/gdevcdj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-02 10:50: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=77fae933e126cb3b3aad9faa30a659294ed8a44a">77fae933e126cb3b3aad9faa30a659294ed8a44a</a>
-<blockquote>
-<p>
- Coverity ID 94708<br>
-<br>
- The original code in here was correctly noted by Coverity as being<br>
- dead, because the division by BJC_RESOLUTION_BASE meant that we were<br>
- always comparing 0 with 0.<br>
-<br>
- In addition, the use of bit shifting meant that the resolution wasn't<br>
- tested against a simple multiple of 90 dpi, but against powers of 2<br>
- times 90 dpi, which rapidly led to ridiculous values.<br>
-<br>
- I'm not certain what the original limits should have been here, and<br>
- I don't have a bjc device to test against, but the code as it stood was<br>
- clearly incorrect, and this at least stands some chance or working.<br>
-<br>
-devices/gdevcdj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-02 10:28: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=1e6e40715f9038b177cf4649945af38b4b21e83c">1e6e40715f9038b177cf4649945af38b4b21e83c</a>
-<blockquote>
-<p>
- Coverity ID 121443<br>
-<br>
- This was supposed to be in the earlier commit but somehow fell off...<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-02 09:59: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=f2a4735118b9558a76adf46e7bb6f814a74ffb38">f2a4735118b9558a76adf46e7bb6f814a74ffb38</a>
-<blockquote>
-<p>
- Coverity ID 94703<br>
-<br>
- param_string_from_string cannot return an error so don't try to<br>
- check it.<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-02 09:51: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=ca09b00d27d7a855c0e7cbf55c26b5e287262cca">ca09b00d27d7a855c0e7cbf55c26b5e287262cca</a>
-<blockquote>
-<p>
- Coverity IDs 121437, 121438 and 121443<br>
-<br>
- Not certain if these are really a potential problem, but a type cast<br>
- safely resolves any potential for error.<br>
-<br>
- I suspect this is a hang over from when gs_color_index was a 32-bit<br>
- value instead of 64.<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-09-02 09:40:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34ac92ae1741e4d8573162efbd25520bc8796424">34ac92ae1741e4d8573162efbd25520bc8796424</a>
-<blockquote>
-<p>
- pdfwrite - remove unused code<br>
-<br>
- This code was left over from transfer function the /Apply work, but is<br>
- no longer used. It was also raising warnings with scan-build and<br>
- didn't work properly anyway (which is why its unused).<br>
-<br>
- So remove it.<br>
-<br>
-devices/vector/gdevpsdf.h<br>
-devices/vector/gdevpsdi.c<br>
-devices/vector/gdevpsds.c<br>
-devices/vector/gdevpsds.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-31 16:11:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4129543f9f51ccaf97d8429a9e66e348394e95b0">4129543f9f51ccaf97d8429a9e66e348394e95b0</a>
-<blockquote>
-<p>
- PDF interpreter - add support for Choice fields in Widget annotations<br>
-<br>
- Bug 698461 &quot;PDF files with filled forms are not rendered correctly if they have drop-down lists&quot;<br>
-<br>
- We didn't support Choice fields in either AcroForms or Widget annotations<br>
- which leads to these not being rendered if they have no Appearance (in<br>
- the case of widget annotations) or not rendered at all in the case of<br>
- AcroForms.<br>
-<br>
- This commit adds simple support for single selection Choice fields, we<br>
- may want to improve this later.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-devices/vector/gdevpsds.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-30 16:36:20 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e547f2490aa40a4f8e35bb15e6815e7d6f1be22a">e547f2490aa40a4f8e35bb15e6815e7d6f1be22a</a>
-<blockquote>
-<p>
- clang warning in color mapping code<br>
-<br>
- We were bit shifting -1 (i.e. -1 &lt;&lt; x) which is, strictly speaking undefined.<br>
-<br>
- Where what was meant was meant was -(1 &lt;&lt; x).<br>
-<br>
-base/gxcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-30 16:28:08 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dafd08a54332f66760b8d667a4b59f42bd4edf1f">dafd08a54332f66760b8d667a4b59f42bd4edf1f</a>
-<blockquote>
-<p>
- clang warnings in the TTF code.<br>
-<br>
- There was a type mismatch: we were using a boolean to track if an error had<br>
- occurred, but in most places we were treating it as a gs error code (int type).<br>
-<br>
- Change the type to int, and tweak the couple of places where it was treated as<br>
- a bool.<br>
-<br>
-base/gxttfb.c<br>
-base/gxttfb.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-25 10:54:42 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ff70cedd80fd037414abb8a17cd1988d92da2ad6">ff70cedd80fd037414abb8a17cd1988d92da2ad6</a>
-<blockquote>
-<p>
- This is a combination of 7 commits.<br>
-<br>
- from the openjpeg-2.2.0-update branch<br>
-<br>
- 1) OpenJPEG 2.2.0 initial commit<br>
- 0b5fc7368721af148d85ef8dac2e018de10cfe91<br>
-<br>
- 2) Zap the openjpeg stuff we don't need<br>
- e90bbccd19cb266b55de28ebfd16d024b6e67373<br>
-<br>
- 3) Add predefined openjpeg headers.<br>
- 71242c9a04bb76b8b17fc489d62a91d04c1ad60c<br>
-<br>
- 4) Import patches from Sumatra's tree.<br>
- 8b89e4b5750069172522ecf85e69d094b5e567e7<br>
-<br>
- 5) update makefiles, interface and vcproj files for new openjpeg version<br>
- 456cbe1c76659b0ab022f6ca3f67cc63b253b05f<br>
-<br>
- 6) Avoid getenv call in openjpeg<br>
- 202a0318a7b3a397fcd5d015dcad4293474f464c<br>
-<br>
- 7) Bug 698135: Import security fix for OpenJPEG<br>
- 8057698a5f7833499fdf8d2529162841920e354a<br>
-<br>
-base/openjpeg.mak<br>
-base/sjpx_openjpeg.c<br>
-openjpeg/.gitignore<br>
-openjpeg/.travis.yml<br>
-openjpeg/CHANGELOG.md<br>
-openjpeg/NEWS.md<br>
-openjpeg/THANKS.md<br>
-openjpeg/src/CMakeLists.txt<br>
-openjpeg/src/lib/openjp2/CMakeLists.txt<br>
-openjpeg/src/lib/openjp2/bench_dwt.c<br>
-openjpeg/src/lib/openjp2/bio.c<br>
-openjpeg/src/lib/openjp2/bio.h<br>
-openjpeg/src/lib/openjp2/cidx_manager.c<br>
-openjpeg/src/lib/openjp2/cidx_manager.h<br>
-openjpeg/src/lib/openjp2/cio.c<br>
-openjpeg/src/lib/openjp2/cio.h<br>
-openjpeg/src/lib/openjp2/dwt.c<br>
-openjpeg/src/lib/openjp2/dwt.h<br>
-openjpeg/src/lib/openjp2/event.c<br>
-openjpeg/src/lib/openjp2/event.h<br>
-openjpeg/src/lib/openjp2/function_list.c<br>
-openjpeg/src/lib/openjp2/function_list.h<br>
-openjpeg/src/lib/openjp2/image.c<br>
-openjpeg/src/lib/openjp2/image.h<br>
-openjpeg/src/lib/openjp2/indexbox_manager.h<br>
-openjpeg/src/lib/openjp2/invert.c<br>
-openjpeg/src/lib/openjp2/invert.h<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/libopenjp2.pc.cmake.in<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_clock.c<br>
-openjpeg/src/lib/openjp2/opj_clock.h<br>
-openjpeg/src/lib/openjp2/opj_codec.h<br>
-openjpeg/src/lib/openjp2/opj_common.h<br>
-openjpeg/src/lib/openjp2/opj_config.h<br>
-openjpeg/src/lib/openjp2/opj_config.h.cmake.in<br>
-openjpeg/src/lib/openjp2/opj_config_private.h<br>
-openjpeg/src/lib/openjp2/opj_config_private.h.cmake.in<br>
-openjpeg/src/lib/openjp2/opj_includes.h<br>
-openjpeg/src/lib/openjp2/opj_intmath.h<br>
-openjpeg/src/lib/openjp2/opj_inttypes.h<br>
-openjpeg/src/lib/openjp2/opj_malloc.c<br>
-openjpeg/src/lib/openjp2/opj_malloc.h<br>
-openjpeg/src/lib/openjp2/opj_stdint.h<br>
-openjpeg/src/lib/openjp2/phix_manager.c<br>
-openjpeg/src/lib/openjp2/pi.c<br>
-openjpeg/src/lib/openjp2/pi.h<br>
-openjpeg/src/lib/openjp2/ppix_manager.c<br>
-openjpeg/src/lib/openjp2/raw.h<br>
-openjpeg/src/lib/openjp2/t1.c<br>
-openjpeg/src/lib/openjp2/t1.h<br>
-openjpeg/src/lib/openjp2/t1_generate_luts.c<br>
-openjpeg/src/lib/openjp2/t1_luts.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/tgt.c<br>
-openjpeg/src/lib/openjp2/tgt.h<br>
-openjpeg/src/lib/openjp2/thix_manager.c<br>
-openjpeg/src/lib/openjp2/thread.c<br>
-openjpeg/src/lib/openjp2/thread.h<br>
-openjpeg/src/lib/openjp2/tls_keys.h<br>
-openjpeg/src/lib/openjp2/tpix_manager.c<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-31 09:40:51 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1dbe825e2fefed1156d0f5e02e6b4d5f20a7781">d1dbe825e2fefed1156d0f5e02e6b4d5f20a7781</a>
-<blockquote>
-<p>
- pdfwrite - address compiler warnings<br>
-<br>
- A couple of benign compiler warnings, assigning to an unused variable<br>
-<br>
- Also add some white space because the construction seems to confuse<br>
- scan-build.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpsds.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-30 15:36:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=794c559e34192d96b772950f854600add9c86651">794c559e34192d96b772950f854600add9c86651</a>
-<blockquote>
-<p>
- PDF interpreter - make sure Stamp appearance synthesis cannot have 0 scale<br>
-<br>
- One of the new PDF 2.0 Quality Logic files exhibited a problem with<br>
- synthesising a missing Appearance for some Stamp annotations; the<br>
- scale factor could be calculated as 0.<br>
-<br>
- This commit makes the minimum scale value 1<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-30 10:18: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=782ca576c8582457b063481a4315f7b767ec4546">782ca576c8582457b063481a4315f7b767ec4546</a>
-<blockquote>
-<p>
- PDF interpreter - fix implementation of HTO<br>
-<br>
- I implemented HTO by using the existing sethalftonephase without an<br>
- example to look at. It turns out that sethalftonephase uses<br>
- .setscreenphase which expects three integers while HTO consists of<br>
- an array of 2 reals.<br>
-<br>
- We already manufacture the third integer (the texture) and use aload to<br>
- extract the two reals. This commit uses transform to apply the CTM and<br>
- then cvi to convert the HTO numbers to something that makes a difference<br>
- and is legal.<br>
-<br>
- Fixes the error and the resulting file (rendered at 1bpp) does show a<br>
- difference in the halftone at 300 dpi or better.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-29 14:04: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=050f12a7c1c9b6e17fd6253924ce5929861cd99f">050f12a7c1c9b6e17fd6253924ce5929861cd99f</a>
-<blockquote>
-<p>
- PDF interpreter - Properly clamp real arguments for /Indexed spaces<br>
-<br>
- Bug #698434 &quot;real operands to /Indexed spaces not properly limited (PDF 2.0)&quot;<br>
-<br>
- The quality Logic PDF 2.0 test file fts_14_1422.pdf tests /Indexed<br>
- colour spaces with real value to see if the notes in Section 8.6.6.3<br>
- regarding real values are adhered to. Previously we simply set such<br>
- values to the lowest integer (truncated the fractional part) which is<br>
- wrong according to both the PDF and PostScript specifications.<br>
-<br>
- The PDF specification specifically states that 0.5 rounds *up* while<br>
- the PostScript Language Reference Manual (unusually) doesn't state<br>
- exactly what 'nearest' means.<br>
-<br>
- Since it was wrong for both before I've chosen to apply the same rules<br>
- for both PDF and PostScript, 0.5 and above rounds up, other reals round<br>
- down. Values outside the range 0-&gt;hival are clamped to either 0 or<br>
- hival whichever is nearer (this was already done in fact).<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-29 10:37: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=ed962af64e86887b0c2ca614c877bb743315d414">ed962af64e86887b0c2ca614c877bb743315d414</a>
-<blockquote>
-<p>
- PDF Interpreter - Paint one pixel for Patterns with BBox width/height of 0<br>
-<br>
- Bug #698431 &quot;PDF 2.0 - Patterns with BBox where width or height = 0 should paint 1 pixel&quot;<br>
-<br>
- The ISO32000-2:2017 specification explicitly states (See section 8.7.3.1<br>
- Table 74 and section 8.7.4.3 Table 77) that a Pattern with a BBox where<br>
- the width or height is 0 should still paint one pixel.<br>
-<br>
- We achieve this here by detecting the condition where width or height in<br>
- a Pattern BBox is exactly 0, and add a tiny amount to the urx or ury<br>
- to ensure that one pixels is touched, and therefore painted.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-28 15:28: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=93b7c164f969787767da98ea3cb4b3efdb6ffc32">93b7c164f969787767da98ea3cb4b3efdb6ffc32</a>
-<blockquote>
-<p>
- fix previous commit<br>
-<br>
- Commit e239afa0924503e131b0445bf2624da90f7c93d1 accidentally broke<br>
- ps2write for files with a halftone, but no transfer function. We do need<br>
- to check to see if the transfer function is present before trying to<br>
- emit it!<br>
-<br>
- For safety, set the character array to NULLs before we start.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-28 14:38: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=e239afa0924503e131b0445bf2624da90f7c93d1">e239afa0924503e131b0445bf2624da90f7c93d1</a>
-<blockquote>
-<p>
- pdfwrite - fix 2 scan-build warnings<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-28 14:31: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=f06cb1ba2d51c44cd27cbf12e2011d15e49cd3ad">f06cb1ba2d51c44cd27cbf12e2011d15e49cd3ad</a>
-<blockquote>
-<p>
- PDF Interpreter - Handle recursive /Prev entries in trailer dictionaries<br>
-<br>
- Bug #698409 &quot;PDF xref loop causes denial of service&quot;<br>
-<br>
- This commit creates an array and stores the offset of each /Prev as it<br>
- is encountered while processing xrefs. Each Prev is also compared<br>
- against every preceding offset already stored in the array. If we get<br>
- a match then we have recursion and we break out. The file may not render<br>
- correctly, and we issue the usual warning.<br>
-<br>
- For complex reasons it was necessary to create the array and store it in<br>
- the current dictionary rather than simply leave it on the stack, so we<br>
- undef it again after use.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-26 10:39:51 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=347f334e934356746f7cc63e478fee41a2c4a8dd">347f334e934356746f7cc63e478fee41a2c4a8dd</a>
-<blockquote>
-<p>
- pdfwrite - fix a couple of compiler warnings<br>
-<br>
- Nothing serious, but the code wasn't checking some error returns. We<br>
- should do that so fixed here.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-26 10:03: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=56aa7b23cbb3cea465ba962ce57157e3a6101e3a">56aa7b23cbb3cea465ba962ce57157e3a6101e3a</a>
-<blockquote>
-<p>
- pdfwrite - add code to apply transfer functions instead of preserving<br>
-<br>
- With the release of the PDF 2.0 specification transfer functions have<br>
- been deprecated in graphics states. This means we can no longer simply<br>
- preserve transfer functions as we have done in the past, and removing<br>
- them can lead to unexpected results (Quark XPress is notorious for<br>
- using transfer functions inadvisably). So this commit alters the colour<br>
- handling code fairly extensively in order to allow transfer functions<br>
- to be applied.<br>
-<br>
- In order to achieve this there are conditions under which we are forced<br>
- to convert colour spaces, as its not possible to apply the transfer<br>
- function reasonably to the base space (CIEBased colour spaces are an<br>
- example of this). In this case we will use the ProcessColorModel in<br>
- effect at the time as the space to convert to.<br>
-<br>
- Its also (unfortunately) the case that when the input is a PDF file,<br>
- the PDF file uses transparency and the PDF file has transfer functions<br>
- set in the graphics state, that some kinds of operation (soft mask<br>
- groups for example) cannot have the transfer function simply applied.<br>
- This can result in surprising output. In these (admittedly rare) cases<br>
- removing the transfer function causes differently incorrect output.<br>
- There is no realistic way for us to take a PDF file like this and<br>
- produce an equivalent PDF file which does not contain transfer function.<br>
- Worse, we can't even detect this condition in advance.<br>
-<br>
- This concludes the work required to support PDF 2.0 creation, and<br>
- Ghostscript should now be able to create and consume PDF 2.0 files<br>
- though additional work may be required, and we may choose to add<br>
- more functionality (eg Document Parts processing) in the future.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdfp.c<br>
-devices/vector/gdevpdft.c<br>
-devices/vector/gdevpsdf.h<br>
-devices/vector/gdevpsdi.c<br>
-devices/vector/gdevpsds.c<br>
-devices/vector/gdevpsds.h<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-23 16:41:14 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bd8b456c088516e622659fb58c1079ef0d4aa21f">bd8b456c088516e622659fb58c1079ef0d4aa21f</a>
-<blockquote>
-<p>
- Fixes for .genordered<br>
-<br>
- The zgenordered function created the &quot;THRESH_STRING&quot; length string<br>
- which would be rejected by sethalftone since the Width * Height was<br>
- not equal to the length of the Thresholds string.<br>
-<br>
- Rather than a compile time switch, the .genordered param dict now<br>
- has /OutputType, one of /Type3, /ThreshString, or /TOSArray.<br>
-<br>
- The supercell code still had a &quot;realloc&quot;. This was replaced by the<br>
- simple ALLOC, memcpy, FREE equivalent.<br>
-<br>
- There were still several places that used naked printf. Changed to<br>
- respect the &quot;verbose&quot; value or to use EPRINTF* macros. This required<br>
- a couple of new macros.<br>
-<br>
- Lastly, add DITHERSC (SuperCellSize) and DITHERLEVELS (Levels) as<br>
- options in the gen_ordered_example.ps<br>
-<br>
-base/gen_ordered.c<br>
-doc/Language.htm<br>
-psi/int.mak<br>
-psi/zht2.c<br>
-toolbin/halftone/gen_ordered/gen_ordered_example.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-22 11:27: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=1a9c68e70e338c31a1fbfce6c3750123c6dda319">1a9c68e70e338c31a1fbfce6c3750123c6dda319</a>
-<blockquote>
-<p>
- Move gen_ordered.c from toolbin to base.<br>
-<br>
- Modify to strip non LIB_BUILD functions from gen_ordered.c and<br>
- move gen_ordered.[ch] to base. Main now in gen_ordered_main.c with<br>
- project file referencing ../../../base/ for gen_ordered.[ch].<br>
- Modify the project file appropriately and add a simple Makefile for<br>
- unix.<br>
-<br>
-base/gen_ordered.c<br>
-base/gen_ordered.h<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>
-psi/int.mak<br>
-psi/msvc.mak<br>
-psi/os2.mak<br>
-toolbin/halftone/gen_ordered/Makefile<br>
-toolbin/halftone/gen_ordered/README<br>
-toolbin/halftone/gen_ordered/gen_ordered.vcproj<br>
-toolbin/halftone/gen_ordered/gen_ordered_main.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-19 14:36: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=37c454cb7f70fd27f14dd2c1b9c63528b3a237ab">37c454cb7f70fd27f14dd2c1b9c63528b3a237ab</a>
-<blockquote>
-<p>
- Fix debug -dNOCACHE command line option.<br>
-<br>
- In the last PL API change the code to disbable the cache was<br>
- accidentally removed.<br>
-<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-22 13:43:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3d3fbafe4a8d1a74a3edb3acbe844da66e1176a2">3d3fbafe4a8d1a74a3edb3acbe844da66e1176a2</a>
-<blockquote>
-<p>
- Bug 698392: add a type check to transparency enum_param()<br>
-<br>
- We were using a ref parameter as a name object without checking its type first<br>
-<br>
-psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-22 13:32: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=e61805f2b5559647c0a9122cde508e278f331071">e61805f2b5559647c0a9122cde508e278f331071</a>
-<blockquote>
-<p>
- Bug 698391: check base_space pointer before de-referencing<br>
-<br>
- in gs_pattern1_remap_color()<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-22 13:38: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=a8621022595d5af20f14e87f6ced620dbca43bad">a8621022595d5af20f14e87f6ced620dbca43bad</a>
-<blockquote>
-<p>
- pdfwrite - don't attempt to use the image-to-mask device unless its present<br>
-<br>
- Bug #698390 &quot;gswin32/64 crashes during PDF conversion&quot;<br>
-<br>
- This looks like a simple oversight, other places where we attempt to<br>
- use methods from the mask device we first check to see if we have a<br>
- mask device present, which we do not in this case. This commit simply<br>
- checks the presence of the mask device and doesn't attempt to use it<br>
- if we have not installed one.<br>
-<br>
- No differences expected<br>
-<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-18 16:10: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=e0a921ea3457ae4fea740c4af532e9c103ee9366">e0a921ea3457ae4fea740c4af532e9c103ee9366</a>
-<blockquote>
-<p>
- Fix FAPI memory leaks.<br>
-<br>
- Noticed while chasing down other memory issues.<br>
-<br>
- Two issues, as it turns out:<br>
-<br>
- Firstly, descendants of a composite font were not having the notify method set, so<br>
- we can free the FAPI related memory for the font.<br>
-<br>
- Secondly, the Freetype incremental interface object created for each font was not<br>
- freed along with the font object.<br>
-<br>
-base/fapi_ft.c<br>
-base/gxfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-21 17:05: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=7a9d86b5ed28862b671bfb65d3a4d0622ec745c1">7a9d86b5ed28862b671bfb65d3a4d0622ec745c1</a>
-<blockquote>
-<p>
- XPS Interpreter - fix a formatting mistake<br>
-<br>
- No impact, but it silences a compiler warning. Accidentally introduced<br>
- in commit 6162bbb7b804a0c70a35f218e59fa6c3118cd6a2<br>
-<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-21 09:46:42 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6162bbb7b804a0c70a35f218e59fa6c3118cd6a2">6162bbb7b804a0c70a35f218e59fa6c3118cd6a2</a>
-<blockquote>
-<p>
- Coverity IDs 158378, 158393<br>
-<br>
- Add some limit checks to see if they silence Coverity. Also revisit the<br>
- check added in commit c5bf24912f589c881be44408e110ebdbb2fcd5b9 to<br>
- correct the limit check.<br>
-<br>
- Coverity complains about reading values from a file format and then<br>
- using them without validating them. Its hard to see how to validate<br>
- values which can legitimately range over the whole space available. If<br>
- we add checks for that, then Coverity complains that the checks are<br>
- pointless (which is true of course).<br>
-<br>
- In these cases, however, we are reading unsigned shorts into signed<br>
- integers, so we can add a (pointless, really) test to ensure that the<br>
- integer value lies in the range of a short. This should satisfy the<br>
- 'tainted scalar' complaints and also should silence the overflow<br>
- warnings when using the values to allocate memory.<br>
-<br>
- Normally I wouldn't do this as is costs performance, but we only execute<br>
- this code once when we open the file, so its negligible.<br>
-<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-19 14:53: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=c5bf24912f589c881be44408e110ebdbb2fcd5b9">c5bf24912f589c881be44408e110ebdbb2fcd5b9</a>
-<blockquote>
-<p>
- Coverity IDs 158372 - 4, 158384<br>
-<br>
- This is an attempt to work-around Coverity complaining about a 'tainted<br>
- scalar' or 'tainted argument'. This is caused by reading a 16-bit value<br>
- from the Zip central directory and then using it without checking the<br>
- bounds. Since the legal bounds are 0 - 2^16 its rather hard to see how<br>
- we can bounds check this....<br>
-<br>
- If this doesn't silence the warnings tomorrow, or creates new ones<br>
- complaining that the bounds check is pointless (this has happened with<br>
- Coverity before) then I'll undo this commit and just tell Coverity<br>
- to ignore the warning.<br>
-<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-19 10:54: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=c57ea7b20d39f0e56432c9cc7bbb7f59fcc544e9">c57ea7b20d39f0e56432c9cc7bbb7f59fcc544e9</a>
-<blockquote>
-<p>
- Coverity ID 158375<br>
-<br>
- The function xps_set_nocache() is pointless, it doesn't do anything at<br>
- all, it merely retrieves a value from the PCL state stored in the<br>
- current instance. I suspect the value retrieved is garbage, since this<br>
- is XPS, not PCL, but since we never even use it, its irrelevant.<br>
-<br>
- Whatever the original thinking behind this function was, its not doing<br>
- anything useful, so simply remove it.<br>
-<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-19 10:28:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c552209d54f69152332795bd833fb3d655e79c48">c552209d54f69152332795bd833fb3d655e79c48</a>
-<blockquote>
-<p>
- Coverity ID 158394<br>
-<br>
- I don't actually think the Coverity warning is possible, but I cannot be<br>
- absolutely certain, so its simpler just to explicitly set the contents<br>
- of these two arrays to a fixed 0 before we start. Its a low overhead if<br>
- we do it at the start of the routine.<br>
-<br>
-devices/vector/gdevpsf2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-18 16:08: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=57bb7d00e180439440ab1be775fad94e13d340ff">57bb7d00e180439440ab1be775fad94e13d340ff</a>
-<blockquote>
-<p>
- PDF interpreter - Cover some cases of illegal /Parent entries<br>
-<br>
- Bug #698372<br>
-<br>
- The PDF file has a Page with an invlalid /Parent (it references the Page<br>
- object). Attempting to use that Page object fails when tracking Resources.<br>
-<br>
- This commit alters the object storage introduced with the PDF unique<br>
- font identification so that *any* dictionary with a /Type gets its<br>
- object number stored inside it. We can then compare the object and the<br>
- Parent when tracking resources and refuse to follow a self-referencing<br>
- object.<br>
-<br>
- No differences expected<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-17 15:46: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=39648c6aafbe7ff790dd4dddf577def1fa7b1f07">39648c6aafbe7ff790dd4dddf577def1fa7b1f07</a>
-<blockquote>
-<p>
- Bug 698363: bounds check against length of loca table<br>
-<br>
- In the FAPI code retrieving the glyph data, we weren't checking that the glyph<br>
- index was inside the loca table (i.e. that it was less than or equal to the<br>
- number of glyphs available in the font).<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-16 15:12:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b138093cf78d9f72596a764d4225b5022ed9d9c">2b138093cf78d9f72596a764d4225b5022ed9d9c</a>
-<blockquote>
-<p>
- Bug 698356: Add reference counting for SMask ICC profiles<br>
-<br>
- Previously, we didn't properly reference count the ICC profiles for<br>
- soft masks because we simply swapped in the ones for the mask, and swapped out<br>
- the ones &quot;in force&quot; at the time into temporary storage, then swapped them back<br>
- when the SMask was complete.<br>
-<br>
- That works fine *if* the PDF is well formed, and thus the SMask completes. But<br>
- it causes havoc if the PDF is invalid and causes an error during the processing<br>
- of the SMask.<br>
-<br>
- We'll now properly reference count the profiles.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-12 16:24:54 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6cabb1a7264e81a4b80a515717f7cc8938f1145">f6cabb1a7264e81a4b80a515717f7cc8938f1145</a>
-<blockquote>
-<p>
- Add .gen_ordered operator to PS and htsc_gen_ordered to gs lib<br>
-<br>
- If GS_LIB_BUILD is #defined, gen_ordered.c API can be called from GS to<br>
- allow for addittion of a PS operator to make a HalftoneType 3 (threshold<br>
- array based halftone) controlled by parameters from a dictionary.<br>
-<br>
- The result is can be used by sethalftone or as a HalftoneType 5 halftone.<br>
-<br>
- Also some warnings cleaned up and add checks for ALLOC fail.<br>
-<br>
- Add a gen_ordered parameter to control verbosity of printing The default<br>
- is 0, which is error messages only. Error messages are generated to<br>
- stderr (using the EPRINTF* macro).<br>
-<br>
- Add documentation of these two new operators in doc/Lagnuage.htm<br>
-<br>
- Add an example toolbin/halftone/gen_ordered/gen_ordered_example.ps<br>
- of usage of ,genordered and some related rendering options.<br>
-<br>
- Other parsers (PCL or XPS) may call htsc_set_default_params and<br>
- htsc_gen_ordered as well to make ordered dither halftone generation<br>
- more flexible, but the integration into non-PS parsers is left for<br>
- later.<br>
-<br>
-Makefile.in<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>
-doc/Language.htm<br>
-psi/int.mak<br>
-psi/msvc.mak<br>
-psi/os2.mak<br>
-psi/zht2.c<br>
-toolbin/halftone/gen_ordered/gen_ordered.c<br>
-toolbin/halftone/gen_ordered/gen_ordered.h<br>
-toolbin/halftone/gen_ordered/gen_ordered_example.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-11 10:43: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=e64f5a2eaeb5c667bfc6bf584f4d7655c8b6b959">e64f5a2eaeb5c667bfc6bf584f4d7655c8b6b959</a>
-<blockquote>
-<p>
- Refactor gen_ordered to allow for use by an application (ghostscript).<br>
-<br>
- Also Refactor htsc_save_tos to extract htsc_mask_to_tos to convert<br>
- final_mask.data to turn_on_sequence.<br>
-<br>
- If GS_LIB_BUILD is #defined, the &quot;main&quot; and functions that write files<br>
- will not be included, and all but a few of the functions will be made<br>
- static. Exported functions are:<br>
- htsc_set_default_params<br>
- htsc_gen_ordered<br>
-<br>
- Also ALLOC and FREE are used to allow the use of a memory allocator<br>
- (such as ghostscript's) and PRINTF and EPRINTF macros are used to<br>
- allow for redirection of messages.<br>
-<br>
-toolbin/halftone/gen_ordered/gen_ordered.c<br>
-toolbin/halftone/gen_ordered/gen_ordered.h<br>
-toolbin/halftone/gen_ordered/gen_ordered.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-15 16:56:58 +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=376e4a546024d9d5f22d1f0a76294d5605ad82be">376e4a546024d9d5f22d1f0a76294d5605ad82be</a>
-<blockquote>
-<p>
- Bug 694680: Prevent SEGV due to uninitialised structure.<br>
-<br>
- Changing compression within an image is unimplemented but for<br>
- now we return an error.<br>
-<br>
- However, changing to eNoCompression is allowed since no<br>
- uninitialised structures are encountered.<br>
-<br>
-pcl/pxl/pximage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-15 09:20: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=5628bd182819bafe965cbf86649e678a6701f818">5628bd182819bafe965cbf86649e678a6701f818</a>
-<blockquote>
-<p>
- pdfwrite - remove obselete code<br>
-<br>
- Originally included as part of the colour management rework, this was<br>
- never actually needed, so remove it.<br>
-<br>
-devices/vector/gdevpsds.c<br>
-devices/vector/gdevpsds.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-15 09:19: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=55e3ee85c171a0d7e563535c77d69a8773f17265">55e3ee85c171a0d7e563535c77d69a8773f17265</a>
-<blockquote>
-<p>
- Fix some spurious code in the CUPS device, flagged by the compiler<br>
-<br>
- Somehow a few lines of code were duplicated, fortunately this was<br>
- benign, but lets remove the nonsense lines anwyay.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-11 08:30:24 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ffa47bc975171d8839af1cf8fb9677c173cff0e6">ffa47bc975171d8839af1cf8fb9677c173cff0e6</a>
-<blockquote>
-<p>
- Bug 696386 Fuzzing<br>
-<br>
- Take slow path if we have a 16bit indexed image<br>
-<br>
-base/gxi12bit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-10 17:39:05 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb37a099ccc86c2af63794167ccc1799c6fc06a0">fb37a099ccc86c2af63794167ccc1799c6fc06a0</a>
-<blockquote>
-<p>
- Clean up warning in gen_ordered.c<br>
-<br>
- The comment about what the levels of quantization<br>
- were when no size was given for the macro cell was<br>
- not correct<br>
-<br>
-toolbin/halftone/gen_ordered/gen_ordered.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-10 17:17: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=723d2a565e726cc6f29f4d32f202c29a995b4e37">723d2a565e726cc6f29f4d32f202c29a995b4e37</a>
-<blockquote>
-<p>
- Bug 698344 gen_ordered.c<br>
-<br>
- Fix case for -r600 -l144 -a45 -q64 -s8<br>
- A problem where we only need to take<br>
- one dot location for our first quantization level (there were<br>
- not multiple dots set to get that level)<br>
-<br>
-toolbin/halftone/gen_ordered/gen_ordered.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-10 13:15:15 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f08687ffb24f641f7ed788ccf152752cd502df88">f08687ffb24f641f7ed788ccf152752cd502df88</a>
-<blockquote>
-<p>
- Fix ambiguity in creation of turn on sequence<br>
-<br>
- When dot profile values are the same due to tiling,<br>
- force decision as to which one to turn on next based<br>
- upon distance to center of dot mask.<br>
-<br>
-toolbin/halftone/gen_ordered/gen_ordered.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-09 14:58:02 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a664e0d6601c80388cd8af765400ce071ee8f967">a664e0d6601c80388cd8af765400ce071ee8f967</a>
-<blockquote>
-<p>
- Fix minor offset issue in gen_ordered.c<br>
-<br>
-toolbin/halftone/gen_ordered/gen_ordered.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-07 17:12: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=913acc7c63921770e755a39fca3f768dda49be5d">913acc7c63921770e755a39fca3f768dda49be5d</a>
-<blockquote>
-<p>
- PDF interpreter - PDF 2.0 - basic support for UTF-8 strings<br>
-<br>
- I'm sure this will require more work in future, but for now this is at<br>
- least as good as our support for UTF-16 strings.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-07 13:44: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=2efe17a30ff9a72f0698add0bd8708f3ef1d3b99">2efe17a30ff9a72f0698add0bd8708f3ef1d3b99</a>
-<blockquote>
-<p>
- PDF interpreter - fix typos<br>
-<br>
- two typos in error messages, 'endjobj' should be 'endobj'<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-07 13:37: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=9a5e5e3c396fb18bcd21158c4f44596eed69e5d0">9a5e5e3c396fb18bcd21158c4f44596eed69e5d0</a>
-<blockquote>
-<p>
- PDF interpreter - PDF 2.0 support - per page OutputIntents<br>
-<br>
- The only way previously to handle *any* OutputIntents array was to<br>
- specify UsePDFX3Profile and give the array index of the required<br>
- profile.<br>
-<br>
- This is too inflexible as each page can have a different array, so the<br>
- indices may be different on each page. Add a new switch -dUseOutputIntent<br>
- which takes a string argument.<br>
-<br>
- If we have set -dUseOutputIntent, then check teh document level and each<br>
- page for an array of OutputIntents. If found, check each OutputIntent<br>
- dictionary for a OutputConditionIdentifier and compare it with the<br>
- specified string. If the OutputConditionidentifier is 'Custom' then use<br>
- the value of the Info key instead.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-07 10:07: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=04fd73cadbf91e7a9cf0dee0129384ce23aa3000">04fd73cadbf91e7a9cf0dee0129384ce23aa3000</a>
-<blockquote>
-<p>
- PDF interpreter - PDF 2.0 support add UseBlackPtComp<br>
-<br>
- Michael already implemented the use of black point compensation, and<br>
- we have a PostScript operator to turn it on and off already (GS<br>
- defaults to on).<br>
-<br>
- This just hooks up the PDF 2.0 graphics state entry to the existing<br>
- framework. Note that the PDF entry is a boolean whereas our existing<br>
- PostScript operator takes 0 or 1, so there's a little fiddling to get<br>
- that right.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/pdf_draw.ps<br>
-Resource/Init/pdf_ops.ps<br>
-psi/zcolor3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-07 10:04: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=dcc9ea12638e99917b28b49c120a52c8e309d9fa">dcc9ea12638e99917b28b49c120a52c8e309d9fa</a>
-<blockquote>
-<p>
- PDF interpreter - support for PDF 2.0 add HTO<br>
-<br>
- I doubt we will ever see a Halftone Origin for real. According to the<br>
- specification its like a halftone phase but with a different co-ordinate<br>
- system.<br>
-<br>
- For now simply treat its as a halftone phase, if anyone ever complains<br>
- we can address it, because they will be able to supply an example to<br>
- work from.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-06 12:24: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=478a0a862d2593199bcae599e46bdc97b525bb12">478a0a862d2593199bcae599e46bdc97b525bb12</a>
-<blockquote>
-<p>
- Bug 698334: LeadingEdge parameter problems.<br>
-<br>
- Because -dLeadingEdge=# sets the value in systemdict, we need to return<br>
- this parameter from gx_default_get_param and gx_default_get_params so that<br>
- the systemdict value will get sent to the device (putdeviceprops).<br>
-<br>
- Also found that the JPEG device was using LeadingEdge, but not stripping<br>
- off the &quot;LEADINGEDGE_SET&quot; bit. Fix by anding with LEADINGEDGE_MASK.<br>
-<br>
- Lastly, the cups device put_params needs to be able to accept a null<br>
- parameter type as the default put_params can.<br>
-<br>
-base/gsdparam.c<br>
-cups/gdevcups.c<br>
-devices/gdevjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-06 02:23:55 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d91d4273f38fb8a527ff342d360cee8aaf468896">d91d4273f38fb8a527ff342d360cee8aaf468896</a>
-<blockquote>
-<p>
- Allow for symbol dictionary with 0 symbols.<br>
-<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-14 17: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=b5a27404ff64c427d8bcdbd16742ab15a4f6cda5">b5a27404ff64c427d8bcdbd16742ab15a4f6cda5</a>
-<blockquote>
-<p>
- Plug leak of parameter info in command-line tool.<br>
-<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-14 17:44:45 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d939952cc3262c8e7b31247046f4e7d9c2d7394">1d939952cc3262c8e7b31247046f4e7d9c2d7394</a>
-<blockquote>
-<p>
- Do not grow page if page height is known.<br>
-<br>
- Previously an encountered region segment could cause the page<br>
- height to be increased if the segment height/position occurred<br>
- outside of the page boundaries. This happened regardless of<br>
- whether the page height was previously known or unknown.<br>
-<br>
-jbig2dec/jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-05 11:23:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22dca483140d23a73ab7db835e7d923a91745b6f">22dca483140d23a73ab7db835e7d923a91745b6f</a>
-<blockquote>
-<p>
- pdfwrite - begin support for PDF 2.0<br>
-<br>
- Permit CompatibilityLevel to be 2.0 for production of PDF 2.0. We may<br>
- eventually make this the default.<br>
-<br>
- Don't write ProcSet resources when creating PDF 2.0<br>
- Don't write a Producer etc in the Info dict when creating PDF 2.0<br>
- Don't write DOCINFO pdfmarks in the Info dict when creating PDF 2.0<br>
- Don't write CharSet key in font dictionaries when creating PDF 2.0<br>
- Write FontDescriptor, Widths, FirstChar and LastChar for base 14 fonts<br>
- when creating PDF 2.0<br>
-<br>
- Don't write Transfer functions in graphics states when creating PDF 2.0.<br>
- We need to add the ability to 'apply' transfer functions for proper<br>
- support here.<br>
-<br>
- Need to add support for BlackPointCompensation and (possibly) per-page<br>
- OutputIntents when the PDF itnerpreter has been upgraded to support<br>
- these.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfb.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdfm.c<br>
-devices/vector/gdevpdfp.c<br>
-devices/vector/gdevpdft.c<br>
-devices/vector/gdevpdfv.c<br>
-devices/vector/gdevpdtd.c<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-01 15:57: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=dcda07a31c90ff1ece5a92961eb83b58ffc44be4">dcda07a31c90ff1ece5a92961eb83b58ffc44be4</a>
-<blockquote>
-<p>
- Bug 697232: URW++ font update from 2017/07/27<br>
-<br>
- Adds blue zones for the top features of numbers in:<br>
- NimbusSans-Italic<br>
- NimbusSans-Regular<br>
-<br>
-Resource/Font/NimbusSans-Italic<br>
-Resource/Font/NimbusSans-Regular<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-04 09:22:36 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd1c10382c868b8bd8dba9b52ea7fca970f95eaa">cd1c10382c868b8bd8dba9b52ea7fca970f95eaa</a>
-<blockquote>
-<p>
- pdfwrite - initialise some new downscale parameters<br>
-<br>
- Bug #698329 &quot;Floating point exception in s_IScale_init()&quot;<br>
-<br>
- Commit a936cf76a33389610b558ffaf5de7389265fd657 to fix Bug #693684<br>
- &quot;Add InterpolateControl parameter to limit image interpolation.&quot; added<br>
- a new parameter 'abs_interp_limit' but omittted to initialise the<br>
- variable in pdfwrite's use of the filter.<br>
-<br>
- This led to an unuinitialised variable, which could eventually cause a<br>
- divide by zero fault.<br>
-<br>
- It seems this parameter is only used when scaling up, so this commit<br>
- simply sets it to the minimum value of 1. At the same time initialise<br>
- a couple of other parameters too, these are probably unused and in any<br>
- event should be initialised by the filter code, but its best to be safe.<br>
-<br>
-devices/vector/gdevpsdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-08-02 13:41: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=ca1ec9b486ddba3f921355fd1d775f27f4871356">ca1ec9b486ddba3f921355fd1d775f27f4871356</a>
-<blockquote>
-<p>
- PDF interpreter - remove the PDFDontUseObjectNum switch<br>
-<br>
- This was implemented to allow us to restore the default behaviour if<br>
- it caused problems. No real problems reported, so lets get rid of<br>
- (yet another) of our many, many command line switches.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-29 18:18:58 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cdd2b1bcafdc9108f843183a22360ffbc65525a1">cdd2b1bcafdc9108f843183a22360ffbc65525a1</a>
-<blockquote>
-<p>
- Bug 698034: Fix various problems with MFS downscaling to cmyk.<br>
-<br>
- Firstly, the mfs buffer was not large enough.<br>
-<br>
- Secondly, the downscaling logic in down_core4_mfs was broken - fixed<br>
- by copying it from down_core4.<br>
-<br>
- Thirdly, the sense of the mfs was inverted (we had forced the white<br>
- spots to be zero).<br>
-<br>
- All in all, my finest work. :(<br>
-<br>
- Fixed here.<br>
-<br>
-base/gxdownscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-27 13:22:50 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8321323b7c31828d79c0aa1b5c0312f156a53192">8321323b7c31828d79c0aa1b5c0312f156a53192</a>
-<blockquote>
-<p>
- Fix Bug 695333: PDF 1.4 transparency did not support Spot Color clist devices<br>
-<br>
- Not just the tiffsep device named in the bug, but the psdcmyk device would<br>
- also fail if the clist was used. This file needs to be in the regression suite.<br>
-<br>
- Fix by adding a pdf14_clist_copy_planes proc that forwards to the underlying<br>
- clist device. NB: The pdf14 rendering device already had a copy_planes device<br>
- which is used in page mode or during clist playback.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-28 15:58: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=8b721623f5fee0150822f7ead66ca5820d74e568">8b721623f5fee0150822f7ead66ca5820d74e568</a>
-<blockquote>
-<p>
- Fix a couple of documentation typos<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-28 13:37: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=7454690eb64cb71c13e957fc47e9881463d01ba4">7454690eb64cb71c13e957fc47e9881463d01ba4</a>
-<blockquote>
-<p>
- Coverity ID 158374 - cater for anerror return<br>
-<br>
- This probably isn't possible, we're getting a repeat form so the original<br>
- form must be already stored, but its worth the error check.<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-28 12:06: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=afa8fb82aea663e3da2d7e0e297ca9bc401a1912">afa8fb82aea663e3da2d7e0e297ca9bc401a1912</a>
-<blockquote>
-<p>
- Coverity ID 158379 identical branches<br>
-<br>
- Coverity is obviously correct that the two branches are identical. I'm<br>
- no longer certain of how this works, but I did test it quite extensively<br>
- at the time so I'm going to assume that the code is correct and simply<br>
- remove the branch logic which seems to be pointless.<br>
-<br>
-base/gxshade1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-28 11:37:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f26ebc119717475bef5b6fd6068af5f0ab779dc9">f26ebc119717475bef5b6fd6068af5f0ab779dc9</a>
-<blockquote>
-<p>
- Coverity ID 158388 - don't dereference a pointer before checking it is non-NULL<br>
-<br>
-base/gdevdflt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-28 11:08:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0947a042bab551b60f9004366bc06b098b8bdbf3">0947a042bab551b60f9004366bc06b098b8bdbf3</a>
-<blockquote>
-<p>
- Coverity ID 158394 - uninitial;ised scalar variable subrs_count[j]<br>
-<br>
- Unlike other instances of this, I can't be certain that its impossible<br>
- to read the data when its not been initialised, and in other places<br>
- we zero the memory when we change the current hint size, which suggets<br>
- that its at least potentially possible, so here we zero the array of<br>
- bits (flags).<br>
-<br>
- No differences expected<br>
-<br>
-devices/vector/gdevpsfx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-27 16:33: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=e5d24b703e5413732f2ef58d8fcd5b4803865d7c">e5d24b703e5413732f2ef58d8fcd5b4803865d7c</a>
-<blockquote>
-<p>
- pdfwrite - don't handle some kinds of x/yshow with TJ<br>
-<br>
- Bug 698218 &quot;Font matrix woes, also with PDF Reader/Writer&quot;<br>
-<br>
- In fact this is not a problem with the FontMatrix. The problem is<br>
- actually to do with the way the PDF interpreter executes certain kinds<br>
- of operation, basically Fonts where the /Widths array entries don't<br>
- match the actual glyph widths.<br>
-<br>
- In this case we use an x/yshow operation with the modified width, and<br>
- this works perfectly well for rendering. However, for pdfwrite, we can<br>
- try to use the TJ operator, which works in a slightly different way...<br>
-<br>
- xshow takes a displacement which is measured from the origin of the first<br>
- glyph to the origin of the following glyph, TJ by contrast adds a<br>
- displacement after the first glyph is rendered. Normally we essentially<br>
- subtract the width from the displacement to find the TJ value. However,<br>
- if the Widths array overrides the glyph width, and the actual glyph<br>
- width is significantly different (eg 0), then what happens is that<br>
- we apply the modified width after rendering the first glyph, and then<br>
- apply the TJ displacement. In effect applying it twice.<br>
-<br>
- Detecting this condition turned out to be essentially impossible, there<br>
- are too many cases in PostScript files where similar trickery is pulled<br>
- to reliably determine that this occurs. It is, however, rare, especially<br>
- in PDF files, because very few fonts are neither horizontal nor vertical<br>
- in their FontMatrix (shearing is not uncommon but that's different)<br>
-<br>
- So this commit adds a new boolean which we set false only when we have<br>
- a x/yshow operation, and the width and real width do not match (which<br>
- happens when we have a /Widths mismatch). This prevents the TJ being<br>
- applied and uses direct text positioning commands instead, which works.<br>
-<br>
-devices/vector/gdevpdte.c<br>
-devices/vector/gdevpdts.c<br>
-devices/vector/gdevpdts.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-25 13:55:19 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=44ccac6fb19ec0e3f42b2b51ec4b2b6a4438af71">44ccac6fb19ec0e3f42b2b51ec4b2b6a4438af71</a>
-<blockquote>
-<p>
- Add an upper bound for pattern and bitmap source heights.<br>
-<br>
-pcl/pxl/pxptable.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-21 13:03:54 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=92e2f00d88d664e5249792458c276b6be89b37fa">92e2f00d88d664e5249792458c276b6be89b37fa</a>
-<blockquote>
-<p>
- Remove unnecessary padding.<br>
-<br>
-pcl/pxl/pximage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-21 10:59:35 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bcae781b1f4ef69a67c287f187cf871cd5db60f0">bcae781b1f4ef69a67c287f187cf871cd5db60f0</a>
-<blockquote>
-<p>
- Fix 694654 - fuzzing seg fault.<br>
-<br>
- The clip path accumulator device (gxacpath.c) does not support raster<br>
- operations so don't install the device if the raster operation is not<br>
- default.<br>
-<br>
- To support raster ops the device would need to add procs for get_bits,<br>
- get_bits_rectangle, strip_copy_rop, and copy_color (used by get_bits<br>
- potentially), then it would need to render the accumulated path using<br>
- the current raster operation (it uses &quot;lop_default&quot; now). The<br>
- optimization is not useful in real world PCL files so we choose to<br>
- bypass it.<br>
-<br>
-base/gsimage.c<br>
-base/gximask.c<br>
-base/gximask.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-18 13:50:33 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dbb4ea0147655b70ee51c18f9963566057b05dc6">dbb4ea0147655b70ee51c18f9963566057b05dc6</a>
-<blockquote>
-<p>
- Fix 694643 fuzzing segfault.<br>
-<br>
- It was possible to write past the end of the gs_debug array.<br>
-<br>
-pcl/pcl/pgconfig.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-21 09:38:13 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be281458bc48aa20acd7d276fb1e1713f1966750">be281458bc48aa20acd7d276fb1e1713f1966750</a>
-<blockquote>
-<p>
- Fix bug 694654: Stale cdev-&gt;clip_path with image<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-20 13:23:14 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d751be73cfa40e45bee50560873bf01884b9d92">0d751be73cfa40e45bee50560873bf01884b9d92</a>
-<blockquote>
-<p>
- Add ROUNDSPOT function and fix limit on lpi search.<br>
-<br>
- ROUNDSPOT added as growing white circle transitioning to shrinking black<br>
- circle.<br>
-<br>
- Also there was an arbitrary limit of lpi &lt;= res/10.0 (y&lt;11) that I changed<br>
- to allow things like -l30 -r600 to give more than 100 levels.<br>
-<br>
-toolbin/halftone/gen_ordered/gen_ordered.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-25 12:58: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=f816b092c1f69c0fed977aa8804dadd04f0296a5">f816b092c1f69c0fed977aa8804dadd04f0296a5</a>
-<blockquote>
-<p>
- PDF interpreter - cope with corrupted Pattern<br>
-<br>
- Bug #696410 &quot;Seg faults found by fuzzing in pattern_paint_finish (zpcolor.c:321)&quot;<br>
-<br>
- The file no longer seg faults, but it did enter an endless loop, caused<br>
- by the pattern code consuming the saved dictionary for the 'q' (gsave)<br>
- operation, but leaving another different dictionary on the dictionary<br>
- stack.<br>
-<br>
- The code here 'ends' teh current dictionary if it has neither a /n or<br>
- /self key, otherwise it calls 'Q' which will end it anyway. This<br>
- prevents the loop being endless because countdictstack is greater<br>
- than the saved dict count, but the current dictionary isn't the<br>
- result of a gsave.<br>
-<br>
- No differences expected<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-25 11:30:20 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f0b4fc4f870ada5264c74c17094c982a66bcb42c">f0b4fc4f870ada5264c74c17094c982a66bcb42c</a>
-<blockquote>
-<p>
- Bug 698287: fix out of bounds access in c_pdf14trans_write<br>
-<br>
- In pdf14_clist_create_compositor() we create a temporary compositor command to<br>
- change the compositor procs and avoid creating subsequent compositors (rather<br>
- than enable/disable/reconfigure the already existing compositor).<br>
-<br>
- The problem arises because we create and only copy the data defined by<br>
- the generic gs_composite_t type, rather than the pdf14 compositor specific<br>
- type (gs_pdf14trans_t).<br>
-<br>
- Change so we use, and copy, the full pdf14 compositor command type.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-25 11:02: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=f98e88cabfa7161ec098e0aaf9d94df52923a212">f98e88cabfa7161ec098e0aaf9d94df52923a212</a>
-<blockquote>
-<p>
- Move the PCL/PXL/XPS example files into pcl/examples<br>
-<br>
- instead of pcl/tools<br>
-<br>
-pcl/examples/bitfont.pcl<br>
-pcl/examples/bitfonts.pxl<br>
-pcl/examples/fills.pcl<br>
-pcl/examples/fontpage.pcl<br>
-pcl/examples/fonts.pcl<br>
-pcl/examples/fonts.pxl<br>
-pcl/examples/frs96.pxl<br>
-pcl/examples/gl-chars.pcl<br>
-pcl/examples/grashopp.pcl<br>
-pcl/examples/grid.pcl<br>
-pcl/examples/label.tst<br>
-pcl/examples/lineprinter.pcl<br>
-pcl/examples/null.pxl<br>
-pcl/examples/opaque.pcl<br>
-pcl/examples/origins.pcl<br>
-pcl/examples/owl.pcl<br>
-pcl/examples/owl2.pcl<br>
-pcl/examples/pattern.pcl<br>
-pcl/examples/pattern.pxl<br>
-pcl/examples/tiger.px3<br>
-pcl/examples/tiger.xps<br>
-pcl/examples/vasarely.px3<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-21 15:03:16 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=910927d86239c80cc5bc365445c1df7a6e5fa8da">910927d86239c80cc5bc365445c1df7a6e5fa8da</a>
-<blockquote>
-<p>
- Bug 696387: iccprofile ref counting in gdevp14 compositor<br>
-<br>
- The transparency compositor does extensive swapping and creating of ICC<br>
- profiles but was less than well disciplined with the reference counting. This<br>
- moves *most* of the profile swapping to a consistent use of the reference<br>
- counting.<br>
-<br>
- The one remaining exception is the handling of colors for soft masks, which are<br>
- still handled &quot;specially&quot;.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-13 13:57: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=f060b1bffacca60b45b9be1b94a8944ca2608930">f060b1bffacca60b45b9be1b94a8944ca2608930</a>
-<blockquote>
-<p>
- Bug 698188: (clist) prevent reading off the end of a bitmap buffer<br>
-<br>
- In clist_copy_mono, when the bitmap is clipped (in the x-direction) we apply<br>
- gross clipping to the bitmap data - the &quot;clip&quot; the left edge of the bitmap<br>
- to the nearest byte.<br>
-<br>
- The problem is that we then calculate the aligned bitmap raster from that<br>
- byte offset. Thus, in the uncompressed case, if we copy the aligned raster<br>
- bytes for each scanline, we *can* end up reading off the end of the buffer.<br>
-<br>
- Instead, use width/8 bytes as the amount to copy for each scanline. Then, if<br>
- necessary, zero the padding bytes.<br>
-<br>
-base/gxclbits.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-06 14:54: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=671fd59eb657743aa86fbc1895cb15872a317caa">671fd59eb657743aa86fbc1895cb15872a317caa</a>
-<blockquote>
-<p>
- Bug 698158: prevent trying to reloc a freed object<br>
-<br>
- In the token reader, we pass the scanner state structure around as a<br>
- t_struct ref on the Postscript operand stack.<br>
-<br>
- But we explicitly free the scanner state when we're done, which leaves a<br>
- dangling reference on the operand stack and, unless that reference gets<br>
- overwritten before the next garbager run, we can end up with the garbager<br>
- trying to deal with an already freed object - that can cause a crash, or<br>
- memory corruption.<br>
-<br>
-psi/ztoken.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-13 13:36:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=18a2365b69cc43ed4dbe2bfd44f739622623821c">18a2365b69cc43ed4dbe2bfd44f739622623821c</a>
-<blockquote>
-<p>
- Update fonts to latest URW++ release (2017/05/01)<br>
-<br>
- Plus 2017/07/20 update<br>
-<br>
- Fixes bugs 696582, 697232 and 697058<br>
-<br>
-Resource/Font/C059-BdIta<br>
-Resource/Font/C059-Bold<br>
-Resource/Font/C059-Italic<br>
-Resource/Font/C059-Roman<br>
-Resource/Font/NimbusMonoPS-Bold<br>
-Resource/Font/NimbusMonoPS-BoldItalic<br>
-Resource/Font/NimbusMonoPS-Italic<br>
-Resource/Font/NimbusMonoPS-Regular<br>
-Resource/Font/NimbusRoman-Bold<br>
-Resource/Font/NimbusRoman-BoldItalic<br>
-Resource/Font/NimbusRoman-Italic<br>
-Resource/Font/NimbusRoman-Regular<br>
-Resource/Font/NimbusSans-Bold<br>
-Resource/Font/NimbusSans-BoldItalic<br>
-Resource/Font/NimbusSans-BoldOblique<br>
-Resource/Font/NimbusSans-Italic<br>
-Resource/Font/NimbusSans-Oblique<br>
-Resource/Font/NimbusSans-Regular<br>
-Resource/Font/NimbusSansNarrow-BdOblique<br>
-Resource/Font/NimbusSansNarrow-Bold<br>
-Resource/Font/NimbusSansNarrow-Oblique<br>
-Resource/Font/NimbusSansNarrow-Regular<br>
-Resource/Font/P052-Bold<br>
-Resource/Font/P052-BoldItalic<br>
-Resource/Font/P052-Italic<br>
-Resource/Font/P052-Roman<br>
-Resource/Font/URWBookman-Demi<br>
-Resource/Font/URWBookman-DemiItalic<br>
-Resource/Font/URWBookman-Light<br>
-Resource/Font/URWBookman-LightItalic<br>
-Resource/Font/URWGothic-Book<br>
-Resource/Font/URWGothic-BookOblique<br>
-Resource/Font/URWGothic-Demi<br>
-Resource/Font/URWGothic-DemiOblique<br>
-Resource/Font/Z003-MediumItalic<br>
-Resource/Init/Fontmap.GS<br>
-psi/psromfs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-24 15:54: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=bfed2aa2b1d854d4b63bc75957438e38fca361fc">bfed2aa2b1d854d4b63bc75957438e38fca361fc</a>
-<blockquote>
-<p>
- PDF interpreter - permit Widths arrays to contain indirect objects (!)<br>
-<br>
- Bug 698275 &quot;GPL Ghostscript 9.21: Failed to interpret TT Instructions&quot;<br>
-<br>
- The actual problem is that the PDF file contains a Widths array where<br>
- one or more of the entries is an indirect object. Since this has no<br>
- useful purpose beyond making the PDF file larger I can't think why this<br>
- has been done.<br>
-<br>
- Nevertheless, as usual 'Acrobat accepts it' so now we do too.<br>
-<br>
- The complain about the TT instructions is because in addition the file<br>
- contains two TrueType fonts which are broken.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-19 22:05:33 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=983e56cb679768fe5a048fbb33a43259efb9afbf">983e56cb679768fe5a048fbb33a43259efb9afbf</a>
-<blockquote>
-<p>
- Fix Bug 696398: Segfault with fuzzing file.<br>
-<br>
- Oveflow of integer caused later failure even if allocation of the<br>
- ht_buffer succeeded. Detect overflow, return error.<br>
-<br>
-base/gxht_thresh.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-19 12:13:30 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=877cbdf0b279bb4bf5f3b74182ab6d0101095f99">877cbdf0b279bb4bf5f3b74182ab6d0101095f99</a>
-<blockquote>
-<p>
- Fix bug 696402: Segfault with fuzzed data caused by dda overflow.<br>
-<br>
- The ty of the matrix in the fuzzed data was a very large value that<br>
- resulted in the Y for an image being near the limit for the dda,<br>
- so the first step (dda_next) overflowed from positive to negative<br>
- resulting is a large destination height calculation (vdi). Prevent<br>
- this by not stepping if it would cause an overflow. This will be<br>
- outside the clip limits, so will not affect the output.<br>
-<br>
-base/gxidata.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-20 13:36: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=91fd78617440c18288b6d4cd226fa3f77db91705">91fd78617440c18288b6d4cd226fa3f77db91705</a>
-<blockquote>
-<p>
- Update the nulldevice for DeviceN<br>
-<br>
- Bug #696383 &quot;Seg faults found by fuzzing in get_num_pdf14_spot_colors (gstrans.c:720)&quot;<br>
-<br>
- The problem here is really an example of our poorly maintained device<br>
- API. As stated previously the comments in the code seem to indicate<br>
- that all devices should either implement their own versions of all<br>
- the device methods, or use the graphics library default method. No<br>
- device method should be NULL, so it should never be necessary to check<br>
- this.<br>
-<br>
- Sadly, many of our devices have NULL entries for some methods, and in<br>
- this case the nulldevice did not implement a method for<br>
- 'ret_devn_params'. Presumably this was missed when the mthod was added.<br>
-<br>
- In this commit, just up date the device to use the default method.<br>
-<br>
-base/gdevnfwd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-18 16:36:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=64cb7a492292eb40a01de760be832b7d5425d8e9">64cb7a492292eb40a01de760be832b7d5425d8e9</a>
-<blockquote>
-<p>
- PDF interpreter - detect and ignore recursive Form XObjects<br>
-<br>
- Bug #698226 &quot;Error: /rangecheck in --run--&quot;<br>
-<br>
- The PDF file supplied in the bug is broken, it has a Form XObject:<br>
-<br>
- 285 0 obj<br>
- &lt;&lt;<br>
- /BBox [ 294.572 797.586 306.188 793.466 ]<br>
- /Group 287 0 R<br>
- /Matrix [ 1 0 0 1 0 0 ]<br>
- /Resources &lt;&lt;<br>
- /ExtGState &lt;&lt;<br>
- /GS0 32 0 R<br>
- &gt;&gt;<br>
- /XObject &lt;&lt;<br>
- /Fm0 285 0 R<br>
- &gt;&gt;<br>
- &gt;&gt;<br>
- /Subtype /Form<br>
- /Length 58<br>
- &gt;&gt;<br>
- stream<br>
- q<br>
- 0 Tc 0 Tw 0 Ts 100 Tz 0 Tr []0 d<br>
- /GS0 gs<br>
- 0 TL/Fm0 Do<br>
- Q<br>
- endstream<br>
- endobj<br>
-<br>
- The file throws an error in Acrobat, Ghostscript recurses the Form until<br>
- it hits an execstackoverflow, and is then unable to proceed. Testing<br>
- Acrobat we see that it can detect recursion even when its not a simple<br>
- self-reference, a child referencing a parent is also detected and<br>
- ignored.<br>
-<br>
- In the PDF interpreter we normally push a dictionary on the operand<br>
- stack and record objects as we encounter them, checking each new one<br>
- against all the ones executed so far, and exit if we find reuse. This<br>
- approach doesn't quite work for Form XObjects, because we cannot be<br>
- certain of the operand stack shape when a Form is executed, and so we<br>
- cannot locate our dictionary.<br>
-<br>
- Instead we now store the dictionary in the top level 'pdfdict' which is<br>
- always available. The technique is otherwise the same.<br>
-<br>
- I'm not totally happy with this, but its the best compromise between<br>
- performance hit, memory use and code frailty I could come up with.<br>
-<br>
- No differences expected.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-13 16:02:16 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cea2da4aae1edbf6aef128f44962cfe8baa5c728">cea2da4aae1edbf6aef128f44962cfe8baa5c728</a>
-<blockquote>
-<p>
- Fixes Bug 697900 - No support for disk resident fonts.<br>
-<br>
- Support added for using PCL font resources from the PJL file system.<br>
- Macros have always been supported and using a font wrapped in a macro<br>
- as a workaround works, but this isn't quite correct or convenient.<br>
- Also refactoring and better error handling for alphanumeric key support.<br>
-<br>
-pcl/pcl/pcsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-12 08:53:21 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8d195215c057f4df0c609828b5da65c7f3462588">8d195215c057f4df0c609828b5da65c7f3462588</a>
-<blockquote>
-<p>
- Fix bug #697650 - RemoveFont opearator error handling.<br>
-<br>
- The RemoveFont operator produced an error and stopped processing when<br>
- the font was not found, now we produce a warning and continue like HP.<br>
- Other areas of the code needed tidying up as well. The<br>
- px_widen_font() function did not NULL the font output parameter<br>
- according to its spec and RemoveFont did not check there wasn't an<br>
- error before attempting to remove the font from the font dictionary<br>
-<br>
-pcl/pxl/pxffont.c<br>
-pcl/pxl/pxfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-17 09:19:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=798bc40317ba4b552560f4ceede1607c561ef54c">798bc40317ba4b552560f4ceede1607c561ef54c</a>
-<blockquote>
-<p>
- pdfwrite - remove the 'deferred free' code<br>
-<br>
- Now that the memory cleanup is completed, we can remove the 'hack'<br>
- that defers really freeing freed memory in the memory manager.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-13 13:43: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=091b860bcde7fc610cff89b7711c59597dc06674">091b860bcde7fc610cff89b7711c59597dc06674</a>
-<blockquote>
-<p>
- pdfwrite - memory management cleanup<br>
-<br>
- Bug #696608 &quot;Use after free error in PDF write&quot;<br>
-<br>
- As per the instructions in the original bug report, filling free memory<br>
- with 0x00 causes seg faults because of 'use after free' conditions in<br>
- the pdfwrite resource management.<br>
-<br>
- There were a number of problems solved in order:<br>
-<br>
- 1) Move freeing of colour spaces until after shadings are freed, because<br>
- shadings can refer to colour spaces.<br>
-<br>
- 2) Colour space and function resources can reference other resources of<br>
- the same type. clear such references before freeing the resources.<br>
-<br>
- 3) 'Other' resources can potentially reference other resource types<br>
- (seen with Colorant dictionaries referencing colour spaces). We need to<br>
- clear these references before freeing the resource types. Also, move the<br>
- freeing of 'other' resources until nearer the end.<br>
-<br>
- 4) The 'Metadata' resource was previously added to the Catalog<br>
- dictionary after the 'Other' resources were freed, so the fact that it<br>
- was double referenced (once from resourceOther, once from 'global named<br>
- object' wasn't a problem. Now that we free 'other' resources later,<br>
- this could lead to double freeing. Explicitly remove the Metadata<br>
- reference from the 'other' resource chains to prevent this.<br>
-<br>
- Running this on the cluster fixes all the pdfwrite problems, it does<br>
- however leave one file which still causes problems, just not with pdfwrite.<br>
-<br>
- Bug688308.ps seg faults on the cluster with differing configurations,<br>
- it isn't stable, so I suspect garbage collection may be involved. Its a<br>
- rather complicated page from a yellow pages directory, and involves<br>
- numerous EPS files from varied sources. Unfortunately I can't reproduce<br>
- a problem locally.<br>
-<br>
- However, its not a pdfwrite problem.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfe.c<br>
-devices/vector/gdevpdfo.h<br>
-devices/vector/gdevpdfu.c<br>
-devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-10 15:06:36 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7276327a2f78290a7d526df493d92325947a834d">7276327a2f78290a7d526df493d92325947a834d</a>
-<blockquote>
-<p>
- Bug 698147 - PXL &quot;passthrough&quot; initialization problem.<br>
-<br>
- Don't let PCL clear the current page if XL has marked the page.<br>
- Thanks to Norbert Janssen for the patch.<br>
-<br>
-pcl/pxl/pxpthr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-10 11:09:57 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ec906d206f6ed044b6b7e1b1cc7551150b8db6d4">ec906d206f6ed044b6b7e1b1cc7551150b8db6d4</a>
-<blockquote>
-<p>
- Bug 698125 - JPEG RGB not grayscaled.<br>
-<br>
- Using the XL JPEG compression scheme it is possible to have a mismatch<br>
- between color space in the graphics state and image. This cannot<br>
- happen in any other PXL raster format except JPEG and we expect it<br>
- will rarely happen in the normal workflows. We detect the the<br>
- mismatch and convert the rgb triples to gray triples in advance of<br>
- rendering the scanline.<br>
-<br>
-pcl/pxl/pximage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-28 17:14:14 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=df8ac78c06cc6093409142aaee839cd4bf953588">df8ac78c06cc6093409142aaee839cd4bf953588</a>
-<blockquote>
-<p>
- Renaming and refactoring, no functional differences.<br>
-<br>
- In particular, we get rid of the &quot;universe&quot; structure and move its<br>
- members into the main instance.<br>
-<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-06 13:57:41 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=21e28148792158aba5cf2b93fad755455d0cc8ba">21e28148792158aba5cf2b93fad755455d0cc8ba</a>
-<blockquote>
-<p>
- Fix viewpbm.ps FITPAGE SCALE option<br>
-<br>
-lib/viewpbm.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-05 08:45:10 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=12cb9d16d69cd3430b86d0bdfea7f73fcbeeceb3">12cb9d16d69cd3430b86d0bdfea7f73fcbeeceb3</a>
-<blockquote>
-<p>
- Fix regression from InterpolateControl change that affects pattern-clist<br>
-<br>
- Seen with comparefiles/Bug689851.pdf as missing interpolation.<br>
-<br>
- The clist_make_accum_device did not copy the interpolate_control value<br>
- from the target. Also copy the params for non-clist pattern accum<br>
- devices and forwarding devices along with graphics_type_tag.<br>
-<br>
-base/gdevnfwd.c<br>
-base/gxclist.c<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-05 10:59:18 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6b24e08b26bbd99082e36785fe742108ab705c23">6b24e08b26bbd99082e36785fe742108ab705c23</a>
-<blockquote>
-<p>
- Bug 698135: Import security fix for OpenJPEG<br>
-<br>
- https://pdfium.googlesource.com/pdfium/+/463b77b4f1e4257cd89f3460b5a6fdb102f44265%5E%21/#F0<br>
-<br>
- Patch doesn't apply cleanly, but requires some manual conflict<br>
- resolution.<br>
-<br>
-openjpeg/src/lib/openjp2/dwt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-05 14:31: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=095a0c9e9c16b5c131709d2d831f97a77084f1bd">095a0c9e9c16b5c131709d2d831f97a77084f1bd</a>
-<blockquote>
-<p>
- pdfwrite - prevent substitution of an SMask for an identical parent image<br>
-<br>
- Bug #698128 &quot;PDF created by gs generates &quot;recursive /SMask&quot; messages when run with gs&quot;<br>
-<br>
- When we have the (highly unusual) case where an image dictionary has an<br>
- SMask entry, and the SMask is an image which is identical to the parent<br>
- in every respect (dictionary contents, stream data) except for the<br>
- SMask key, it was possible for pdfwrite to decide to use the SMask<br>
- instead of the image.<br>
-<br>
- This leads to a PDF which has an image which references an SMask in the<br>
- image dictionary, and the SMask is the same image XObject.<br>
-<br>
- In this commit, when checking for an identical image, if the image we<br>
- find is the same as the 'current' softmask image, then do not treat it<br>
- as identical. This prevents us inadvertently detecting an image and its<br>
- SMask as being the same image.<br>
-<br>
-devices/vector/gdevpdfj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-05 10:07:47 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a936cf76a33389610b558ffaf5de7389265fd657">a936cf76a33389610b558ffaf5de7389265fd657</a>
-<blockquote>
-<p>
- Bug 693684: Add InterpolateControl parameter to limit image interpolation.<br>
-<br>
- Previously, we always interpolated to the full device resolution. This<br>
- parameter allows control of the resolution of the interploated image<br>
- which makes sense for devices that cannot render continuous tone at<br>
- the device resolution due to halftone cell size. This avoids the<br>
- overhead of interpolation beyond what the device can reproduce and<br>
- allows the user a quality/performance tradeoff.<br>
-<br>
- The -dDOINTERPOLATE is equivalent to -dInterpolateControl=-1 and the<br>
- -dNOINTERPOLATE is equivalent to -dInterpolateControl=0. These options<br>
- still work for PS/PDF files, but are deprecated and may be removed in<br>
- the future.<br>
-<br>
- Performance results vary, but using the -dInterpolateControl=4 is<br>
- 4.5 times faster with files that have images that are scaled up and cover<br>
- a large portion of the page such as comparefiles/Bug695221.ps at 600dpi.<br>
-<br>
-Resource/Init/gs_img.ps<br>
-Resource/Init/gs_init.ps<br>
-base/gsdparam.c<br>
-base/gxdevcli.h<br>
-base/gxdevice.h<br>
-base/gxht.c<br>
-base/gxiscale.c<br>
-base/lib.mak<br>
-base/siscale.c<br>
-base/sisparam.h<br>
-devices/devs.mak<br>
-devices/gdevbit.c<br>
-devices/vector/gdevpsdi.c<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-27 15:56:01 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e56286167cad5a5fba3e0b8911d9a54b6a5a5400">e56286167cad5a5fba3e0b8911d9a54b6a5a5400</a>
-<blockquote>
-<p>
- Speed up image interpolation with UseFastColor<br>
-<br>
- The check for dev_profile-&gt;usefastcolor was buried way down in the ICC<br>
- remap logic after getting a link, etc. then eventually returning the<br>
- is_identity that would skip transforming the color. Also check in the<br>
- image_class0_interpolate function to disable use_icc so that it uses<br>
- the faster image_render_interpolate rather than the interpolate_icc<br>
- versions.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-29 15:13: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=9ed740e848891de10af6f85bd234298ac2bbab7b">9ed740e848891de10af6f85bd234298ac2bbab7b</a>
-<blockquote>
-<p>
- Fix fuzzing Bug 694668 - CCITT fuzzing.<br>
-<br>
- Bounds check CCITT Columns.<br>
-<br>
-pcl/pcl/pcl.mak<br>
-pcl/pcl/rtraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-04 12:11: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=676ad40aed33815aea7bf65cb9f374b79b1d8518">676ad40aed33815aea7bf65cb9f374b79b1d8518</a>
-<blockquote>
-<p>
- pdfwrite - fix /Colorants when converting DeviceN colour spaces<br>
-<br>
- Bug 698129 &quot;Produced PDF that gives &quot;Wrong operand type&quot; in Acrobat for some pages&quot;<br>
-<br>
- The supplied example uses a Duotone witha CMYK alternate and a Colorants<br>
- array (for the Pantone colour only). When converting to a different<br>
- space we preserve the Spot colours (and therefore DeviceN) but we<br>
- convert the alternate space to the specified base space by sampling the<br>
- original space.<br>
-<br>
- However, if the DeviceN space contained a Colorants array we were writing<br>
- the new colour space array with the Colorants inserted in the wrong<br>
- position, immediately after the ink array instead of at the end.<br>
-<br>
- This commit moves the Colorants entry to the correct place, and also<br>
- adds the (previously missing) Subtype key to the Colorants dictionary.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-07-01 16:36: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=f1cfdcd88da67bcab1efbed26191d27a0ce00a53">f1cfdcd88da67bcab1efbed26191d27a0ce00a53</a>
-<blockquote>
-<p>
- Bug 694626: Prevent SEGV due to division by zero.<br>
-<br>
- Add bounds checking in ttfFont__Open to default nUnitsPerEm to 1024 as<br>
- precedented in ttfOutliner__Outline.<br>
-<br>
-base/ttfmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-29 11:20: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=0b7fa9293f43dce8aea028e4d2b32da1d8fc18c8">0b7fa9293f43dce8aea028e4d2b32da1d8fc18c8</a>
-<blockquote>
-<p>
- Add error checking for gs_colorspace_set_icc_equivalent()<br>
-<br>
-base/gscdevn.c<br>
-base/gsciemap.c<br>
-base/gscolor2.c<br>
-base/gscsepr.c<br>
-base/gstrans.c<br>
-base/gxcmap.c<br>
-base/gxipixel.c<br>
-base/gxiscale.c<br>
-base/gxshade.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-29 11:00: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=d592ee18a9168b1190bc7f7a1426b41fa6d508af">d592ee18a9168b1190bc7f7a1426b41fa6d508af</a>
-<blockquote>
-<p>
- Bug 698151: XPS: bounds check selecting cmap table.<br>
-<br>
-xps/xpsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-29 10:54: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=0c39ac5a0b8ca650101ac6322be34bd7504e7f63">0c39ac5a0b8ca650101ac6322be34bd7504e7f63</a>
-<blockquote>
-<p>
- Bug 698150: XPS: bounds check in format 6 and 10 cmap tables<br>
-<br>
-xps/xpsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-29 12:07:29 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad0ac7883807331c1c9afb0b87585838bd3e63be">ad0ac7883807331c1c9afb0b87585838bd3e63be</a>
-<blockquote>
-<p>
- Bug 697981: Avoid integer overflow problems in scan converter.<br>
-<br>
- Positions can be anywhere in the signed range 0x80000000..0x7fffffff,<br>
- therefore the difference between those positions can overflow a<br>
- signed 32bit representation.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-28 17:03:24 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d4681a07410f96ee68479e0c39f1ca6f27168b8f">d4681a07410f96ee68479e0c39f1ca6f27168b8f</a>
-<blockquote>
-<p>
- Fix Bug 694656, Seg faults found by fuzzing in hpgl_get_char_width<br>
-<br>
- Along with checking that there is a valid font make sure there is a<br>
- current font selection, if not recompute the current font.<br>
-<br>
-pcl/pcl/pglabel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-28 20:29:47 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d9dc902167802515d8ee86bf4e2205461486b50">1d9dc902167802515d8ee86bf4e2205461486b50</a>
-<blockquote>
-<p>
- Squash some warnings in gsmchunk.c<br>
-<br>
-base/gsmchunk.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-07 19:16:46 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af4317bc527142dd0b8a6032799c4accf40bf835">af4317bc527142dd0b8a6032799c4accf40bf835</a>
-<blockquote>
-<p>
- MSVC: Squash double-&gt;float implicit cast warning.<br>
-<br>
-devices/vector/gdevpdfv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-07 19:14:16 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f204ddc13530f1bdb180eb38ebcf5a96caab8b74">f204ddc13530f1bdb180eb38ebcf5a96caab8b74</a>
-<blockquote>
-<p>
- MSVC: Fix some implicit casting warnings in ft_api.c<br>
-<br>
- Simply make the castings explicit.<br>
-<br>
-base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-27 19:18:32 +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=3a684e3dcc55c27506dc179723e8bcd85d121aa7">3a684e3dcc55c27506dc179723e8bcd85d121aa7</a>
-<blockquote>
-<p>
- Bug 694670: Prevent buffer overrun.<br>
-<br>
- Add bounds checking in pxSetHalftoneMethod to prevent a buffer<br>
- overrun.<br>
-<br>
-pcl/pxl/pxink.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-22 22:14:59 +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=25d4e951e5290a34354f633f46d57cb6870fbd5d">25d4e951e5290a34354f633f46d57cb6870fbd5d</a>
-<blockquote>
-<p>
- Bug 694681: Prevent buffer overrun.<br>
-<br>
- Move bounds checking earlier in pxReadRastPattern to prevent a buffer<br>
- overrun when StartLine attribute is set to non-zero.<br>
-<br>
-pcl/pxl/pximage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-27 09:58:44 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc09d291658c1758fe2a0a02776e66355f56b09a">dc09d291658c1758fe2a0a02776e66355f56b09a</a>
-<blockquote>
-<p>
- Bug 698134 Text knock with alphabits<br>
-<br>
- The pdf14_copy_alpha operation was not updated<br>
- when fixes were made to properly handle non-isolated<br>
- knockout groups.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-27 15:33:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6ce668c11ccbadde6d76430ba00205eca853879e">6ce668c11ccbadde6d76430ba00205eca853879e</a>
-<blockquote>
-<p>
- Bug 698130: check the icc profile data exists before accessing it<br>
-<br>
-base/gscsepr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-26 10:04: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=74ce33d1fdb26af4e15a58e5df91dbb1403f66f9">74ce33d1fdb26af4e15a58e5df91dbb1403f66f9</a>
-<blockquote>
-<p>
- Drop the now redundant check for zero length, staight contours<br>
-<br>
- when degenerating the outline into moveto/lineto/curveto operations.<br>
-<br>
-base/gxfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-26 09:58: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=6d17251a6c22673854bcd288d8562650361847e5">6d17251a6c22673854bcd288d8562650361847e5</a>
-<blockquote>
-<p>
- Bug 697983: (re-redux) Drop zero length contours from glyph outlines<br>
-<br>
- Zero length contours cause issues (line-caps) when the outline is stroked.<br>
-<br>
- Turns out the same problem can arise with arcs as with straight lines.<br>
-<br>
- That complicates things where TTFs are concerned since we have to convert cubic<br>
- to conic splines, and the floating point errors make it dubious checking for<br>
- point equality after the conversion. As a result, the checking has to be done<br>
- in the scaler specific interface code, rather than in the scaler independant<br>
- FAPI code.<br>
-<br>
- That just means if we ever integrate another scaler that can handle<br>
- downloadable fonts, we need to take care to include the same checks as are<br>
- now in the Freetype interface code.<br>
-<br>
-base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-20 06:50:49 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=793f93b08813e898aa0f1b316619e33568275fb0">793f93b08813e898aa0f1b316619e33568275fb0</a>
-<blockquote>
-<p>
- Fix Bug 697926, processing jpeg embedded color parameters.<br>
-<br>
- HP ignores the height, width and color components provided with the<br>
- raster commands and uses the values in the embedded JPEG.<br>
- Consequently, we have to defer beginning the image until the image<br>
- data arrives.<br>
-<br>
-pcl/pxl/pximage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-21 01:07:17 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4942c650d9ab84671724e1f98541829ba8b6ff80">4942c650d9ab84671724e1f98541829ba8b6ff80</a>
-<blockquote>
-<p>
- Adapt tools to use renamed gpcl6 binary.<br>
-<br>
-pcl/tools/docov.pl<br>
-pcl/tools/pcl2pdfwr<br>
-pcl/tools/pcl2pdfwr.bat<br>
-pcl/tools/plot2pdf.sh<br>
-pcl/tools/smoke_check.sh<br>
-pcl/tools/smoke_update.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-21 16:01: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=3b6625b9f04daedf678a137475858ad35b991052">3b6625b9f04daedf678a137475858ad35b991052</a>
-<blockquote>
-<p>
- pdfwrite - don't arbitrarily alter the 'current' shape alpha<br>
-<br>
- Bug 697472 &quot;Transparent box appears lighter&quot;<br>
-<br>
- Whenever we opened a substream, if it was an XObject resource we would<br>
- set the blend mode and shape alpha to the default values.<br>
-<br>
- This looks wrong to me, and it means that when using a complex ExtGState<br>
- which includes a SMask, if there was an alpha other than 1 in the<br>
- ExtGState then we would write the constant alpha out twice, once<br>
- in the page content, and once again in the resulting Group Form<br>
- XObject which we create. If the alpha was not 1, then this causes it<br>
- to be applied twice, resulting in rendered content which is too pale.<br>
-<br>
- Both of these look incorrect, but removing the blend mode causes other<br>
- files to fail. Removing the shape alpha causes progressions in a number<br>
- of test suite files.<br>
-<br>
-devices/vector/gdevpdti.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-21 07:38:01 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e178c1c3a45076fcffbe703c722b4f9bca0ac532">e178c1c3a45076fcffbe703c722b4f9bca0ac532</a>
-<blockquote>
-<p>
- Fix typo in previous commit s/b PageUsesTransparency<br>
-<br>
-examples/transparency_example.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-20 17:57: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=670840afcd100f4751b911cf4ac3bf0415ba55c2">670840afcd100f4751b911cf4ac3bf0415ba55c2</a>
-<blockquote>
-<p>
- Bug 698087: Heap buffer overflow with confused clist colorspace<br>
-<br>
- The PDF14 transparency compositor changes the colorspace to Gray<br>
- (8-bit), but if a 1-bit deep device is the target device, and the<br>
- normal startup for transparent pages doesn't happen, the playback<br>
- would write 8-bit data to a 1-bit deep buffer<br>
-<br>
- Also fix the transparency_example.ps so that it sets the device param<br>
- PageUsesTransparency which is expected.<br>
-<br>
-examples/transparency_example.ps<br>
-psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-20 15:39:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7258589eb5005d05c1499e717da8de804e1c35e1">7258589eb5005d05c1499e717da8de804e1c35e1</a>
-<blockquote>
-<p>
- Bug 698069: tighten up the out-of-data condition in spgetcc<br>
-<br>
-base/stream.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-20 10:06: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=8aaacf3f8d3837b471fc302de0a84c85ecb24307">8aaacf3f8d3837b471fc302de0a84c85ecb24307</a>
-<blockquote>
-<p>
- Bug 698081: more bounds checking in xps_load_sfnt_name<br>
-<br>
-xps/xpsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-19 13:26: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=605af24e8adcbc71bec1c5e1283dc20eabfbc515">605af24e8adcbc71bec1c5e1283dc20eabfbc515</a>
-<blockquote>
-<p>
- Yet another check on raster memory for get_bits_rectangle<br>
-<br>
- Bug #698073 &quot;Potential null pointer dereference in mem_word_get_bits_rectangle&quot;<br>
-<br>
- Not the same reason, but still a potential use of dev-&gt;line_ptrs, which<br>
- can be NULL If you mangle makeimagedevice and copyscanlines.<br>
-<br>
-base/gdevmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-19 10:02: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=a5c6f7da872845b1d9bf2025c0cd5fc98b937d90">a5c6f7da872845b1d9bf2025c0cd5fc98b937d90</a>
-<blockquote>
-<p>
- PS interpreter - remove 'STRICT' and remove from documentation<br>
-<br>
- The 'STRICT' switch is documented as removing as many Ghostsctipt<br>
- extensions as possible. In reality it only removes some media size<br>
- definitions from statusdict.<br>
-<br>
- This seems less than useful, so remove it to reduce clutter.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_statd.ps<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-19 09:46:21 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2fa6beaa40144c592661a611bf35ff6f06d3354f">2fa6beaa40144c592661a611bf35ff6f06d3354f</a>
-<blockquote>
-<p>
- Tools - remove ps2ascii.ps, recode scripts to use txtwrite<br>
-<br>
- ps2ascii.ps uses DELAYBIND, which we would like to get rid of, in<br>
- addition it doesn't do a terribly good job of actually extracting text.<br>
- The txtwrite device is more sophisticated, although it does not have the<br>
- added 'COMPLEX' feature of ps2ascii.ps which emits strokes and fills<br>
- as rectangles.<br>
-<br>
- If the COMPLEX feature set should prove useful enough it would be easy<br>
- to add this functionality to a new device, but in reality I doubt<br>
- anyone is using this. The scripts specifically set -dSIMPLE.<br>
-<br>
- This allows us to deprecate DELAYBIND and in future remove it.<br>
-<br>
-lib/ps2ascii<br>
-lib/ps2ascii.bat<br>
-lib/ps2ascii.cmd<br>
-lib/ps2ascii.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-17 17:06: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=8f796773b5aae90362ec500d942dc38e6a1f0f6b">8f796773b5aae90362ec500d942dc38e6a1f0f6b</a>
-<blockquote>
-<p>
- PS interpreter - deprecate DELAYBIND, remove from documentation<br>
-<br>
- DELAYBIND seems like a bad idea, we suspect there is nothing it does<br>
- which cannot be achieved another way.<br>
-<br>
- For now we will continue to allow it, but user will have to set<br>
- -dREALLYDELAYBIND instead, setting -dDELAYBIND will trigger a warning<br>
- message and an error.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-doc/Language.htm<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-17 16:13: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=0a41e707c2ca9a9243df640b32c5abe372be1f53">0a41e707c2ca9a9243df640b32c5abe372be1f53</a>
-<blockquote>
-<p>
- PS interpreter - remove NOBIND option and all references<br>
-<br>
- This was only ever supposed to be a 'debugging aid' and its something<br>
- of a struggle to see why it would be useful.<br>
-<br>
-Resource/Init/gs_dps1.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_ll3.ps<br>
-doc/Language.htm<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-17 14:27: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=c294b131ea270cea5d66c9b0a6ea61d3a69a20a0">c294b131ea270cea5d66c9b0a6ea61d3a69a20a0</a>
-<blockquote>
-<p>
- PS interpreter - fix use of superexec with DELAYBIND<br>
-<br>
- Commit 8556b698892e4706aa0b9d996bec82fed645eaa5 removed superexec from<br>
- systemdict, leaving it in internaldict, where it should be. However,<br>
- if we run with DELAYBIND then by the time we come to bind the procedures<br>
- which use superexec the definition in systemdict is gone.<br>
-<br>
- Technically this shouldn't be a problem, as we should be using the version<br>
- in internaldict. But if we do that, without DELAYBIND the internaldict<br>
- definition isn't present, because we haven't copied it yet....<br>
-<br>
- So now we look for the presence of superexec in systemdict and use that<br>
- one if its present, otherwise we assume its in internaldict and use<br>
- that instead.<br>
-<br>
- Unfortunately the use of DELAYBIND interferes with the cluster testing<br>
- causing thousands of files to fail. I've run a random selection of them<br>
- locally in a normal setup and they work, I guess we'll just have to<br>
- hope for the best and fix any problems as they are reported.<br>
-<br>
-Resource/Init/gs_dps1.ps<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_ttf.ps<br>
-Resource/Init/gs_type1.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-17 11:17: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=971472c83a345a16dac9f90f91258bb22dd77f22">971472c83a345a16dac9f90f91258bb22dd77f22</a>
-<blockquote>
-<p>
- Make operator hiding work with DELAYBIND<br>
-<br>
- Commit 1497d65039885a52b598b137dd8622bd4672f9be undefines as many operators<br>
- as possible once startup is completed, in order to prevent potantially<br>
- malicious PostScript or PDF files using them.<br>
-<br>
- However, if DELAYBIND (itself a gaping security hole if used) is<br>
- specified, this leads to an endless loop. Instead we must undefine the<br>
- operators during .bindnow (after the deferred binding has occured).<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-13 00:45:54 +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=4bf1f491517c4d1f30f594a77ea4adbef263bfc9">4bf1f491517c4d1f30f594a77ea4adbef263bfc9</a>
-<blockquote>
-<p>
- Bug 694639: Prevent buffer overrun.<br>
-<br>
- Add bounds checking in pxReadRastPattern to prevent a buffer overrun when<br>
- StartLine attribute is set to non-zero.<br>
-<br>
-pcl/pxl/pximage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-16 15:40: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=824aa630e2d4ce5b53e78cf8b2686ee6acb7a5fe">824aa630e2d4ce5b53e78cf8b2686ee6acb7a5fe</a>
-<blockquote>
-<p>
- Bug 698066: Ensure device has raster memory before using it<br>
-<br>
- Same solution as Bug #697676<br>
-<br>
- This is only possible by abusing/mis-using Ghostscript-specific<br>
- language extensions, so cannot happen in a general PostScript program.<br>
-<br>
- Nevertheless, Ghostscript should not crash. So this commit checks the<br>
- memory device to see if raster memory has been allocated, before trying<br>
- to read from it.<br>
-<br>
-base/gdevmpla.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-16 09:03:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=260fefe6504653742a623d416fcf73f6b2559579">260fefe6504653742a623d416fcf73f6b2559579</a>
-<blockquote>
-<p>
- Bug 698065: xps: fix reading of idRangeOffset in cmap table<br>
-<br>
- In format 4 cmap tables the idRangeOffset was being read as a signed value,<br>
- but it is unsigned.<br>
-<br>
-xps/xpsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-16 08:50: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=961b10cdd71403072fb99401a45f3bef6ce53626">961b10cdd71403072fb99401a45f3bef6ce53626</a>
-<blockquote>
-<p>
- Bug 698064: bounds check xps_encode/decode_font_char_imp<br>
-<br>
-xps/xpsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-16 08:29: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=c501a58f8d5650c8ba21d447c0d6f07eafcb0f15">c501a58f8d5650c8ba21d447c0d6f07eafcb0f15</a>
-<blockquote>
-<p>
- Bug 698063: Bounds check Ins_JMPR<br>
-<br>
-base/ttinterp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-15 09:05:20 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=937ccd17ac65935633b2ebc06cb7089b91e17e6b">937ccd17ac65935633b2ebc06cb7089b91e17e6b</a>
-<blockquote>
-<p>
- Bug 698056: make bounds check in gx_ttfReader__Read more robust<br>
-<br>
-base/gxttfb.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-15 08:58: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=7755e67116e8973ee0e3b22d653df026a84fa01b">7755e67116e8973ee0e3b22d653df026a84fa01b</a>
-<blockquote>
-<p>
- Bug 698055: bounds check zone pointer in Ins_MDRP<br>
-<br>
-base/ttinterp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-14 22:00:52 +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=f887813ad00d680e2ea5d81606fd21d1b68067af">f887813ad00d680e2ea5d81606fd21d1b68067af</a>
-<blockquote>
-<p>
- Bug 694662: Bounds check formlines in pcl_vmi_default()<br>
-<br>
- Added bounds checking to clamp value between a minimum of 5 and a<br>
- maximum of 128.<br>
-<br>
-pcl/pcl/pcursor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-13 22:35:37 +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=3749bc274be1ae5a2f9897447708e84418ccf7a4">3749bc274be1ae5a2f9897447708e84418ccf7a4</a>
-<blockquote>
-<p>
- Bug 694653: Prevent buffer overrun.<br>
-<br>
- Add bounds checking to pcl_character_data to prevent a buffer overrun if<br>
- the continuation data total is greater than font_data_size.<br>
-<br>
-pcl/pcl/pcsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-14 16:07: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=db85b2782543f6dc6397a2e87c6beefc00b25b54">db85b2782543f6dc6397a2e87c6beefc00b25b54</a>
-<blockquote>
-<p>
- Fix mistake introduced with the pcl glyph data bounds checking code<br>
-<br>
- When I added the bounds checking for PCL glyph data, I changed slightly the<br>
- way offsets were calculated for the PXL 'error handler' bitmap font so<br>
- we could know the data length.<br>
-<br>
- I messed up, and forgot to fully take account of the first byte being the<br>
- char code, and not part of the bitmap data.<br>
-<br>
-pcl/pxl/pxerrors.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-14 15:14: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=4992ef5bc283a6347737f1369ef3d7bd4efbdce1">4992ef5bc283a6347737f1369ef3d7bd4efbdce1</a>
-<blockquote>
-<p>
- Bug 697983: (redux) Drop zero length contours from glyph outlines<br>
-<br>
- When a outline glyph has contours with only one point in it, we end up with<br>
- a moveto and a lineto the same point, thus resulting in a zero length line<br>
- segment. This causes problems when the outline is stroked (line caps).<br>
-<br>
- We'll now drop these pointless lineto operations.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-base/gxfapi.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-14 10:46: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=80f4cc558efdd73be26ede4057ac1750b0b34210">80f4cc558efdd73be26ede4057ac1750b0b34210</a>
-<blockquote>
-<p>
- chunk allocator: on free, use original size for single object chunk<br>
-<br>
- On allocation, we decide, based on the requested size (+ house keeping data)<br>
- if an object should be in a chunk on its own. But the size recorded can be<br>
- larger than that if the chunk was recovered from the free list (because the<br>
- free list can contain merged free chunks). In such a case, we also record the<br>
- padding bytes.<br>
-<br>
- On freeing, we have to use the object size minus the object padding to<br>
- identify single object chunks - to mirror the decision making in the allocation<br>
- code.<br>
-<br>
- Fixes the cluster segfault with C410.bin and bitrgbtags<br>
-<br>
-base/gsmchunk.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-14 10:14: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=3ee55637480d5e319a5de0481b01c3346855cbc9">3ee55637480d5e319a5de0481b01c3346855cbc9</a>
-<blockquote>
-<p>
- Bug 698050: xps: bounds check offset for requested cmap table<br>
-<br>
-xps/ghostxps.h<br>
-xps/xpsfont.c<br>
-xps/xpsglyphs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-14 09:30: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=3c2aebbedd37fab054e80f2e315de07d7e9b5bdb">3c2aebbedd37fab054e80f2e315de07d7e9b5bdb</a>
-<blockquote>
-<p>
- Bug 698044: restrict font name length to the buffer size.<br>
-<br>
-xps/ghostxps.h<br>
-xps/xpsfont.c<br>
-xps/xpsttf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-14 09:16: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=c53183d4e7103e87368b7cfa15367a47d559e323">c53183d4e7103e87368b7cfa15367a47d559e323</a>
-<blockquote>
-<p>
- Bug 698042: xps: fix glyph index and index bounds check.<br>
-<br>
- If a gs_glyph has the GS_MIN_GLYPH_INDEX offset, we need to remove the offset<br>
- before we try to use it.<br>
-<br>
- Secondly, using a unsigned variable for a value from which we subtract 1, and<br>
- which can be zero doesn't work well. Switch to a signed value.<br>
-<br>
-xps/xpsttf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-14 09:28: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=6cf7a8c45517d5857aa81cf59a82a2cc5c7d021c">6cf7a8c45517d5857aa81cf59a82a2cc5c7d021c</a>
-<blockquote>
-<p>
- PDF interpreter - fix a problem with AcroForm interpretation<br>
-<br>
- No bug for this, noticed in passing while working on a customer bug.<br>
-<br>
- If we turn on AcroForm processing, and we have an AcroFOrm where a /Tx<br>
- field has a /V entry, then we would not write the value to the string we<br>
- are accumulating. We would only write the value if we had no /V but a<br>
- /DV.<br>
-<br>
- Instead the string was left on the stack, leading to an error. This<br>
- appears to be due to a logical error when writing the V/DV handling<br>
- where the write== was placed inside the if clause, when it should be<br>
- outside the clause.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-13 06:58:32 +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=fe61712d5157066212d0fcee79b129d6ddcbd251">fe61712d5157066212d0fcee79b129d6ddcbd251</a>
-<blockquote>
-<p>
- Bug 694657: Prevent SEGV due to missing font.<br>
-<br>
- Updated pcl_reselect_font to check for missing font.<br>
-<br>
- Updated hpgl_select_stick_font to initialise font-&gt;storage before it is<br>
- used in pcl_downloaded_and_bound.<br>
-<br>
-pcl/pcl/pcfsel.c<br>
-pcl/pcl/pglabel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-12 18:05:14 +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=8e1acddeb57e9cbb105ec9ff9e65d35005cac44f">8e1acddeb57e9cbb105ec9ff9e65d35005cac44f</a>
-<blockquote>
-<p>
- Bug 694648: Prevent buffer overrun.<br>
-<br>
- Add bounds checking to pl_tt_string_proc to prevent a buffer overrun if<br>
- the incoming offset value is greater than the header size.<br>
-<br>
-pcl/pl/plchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-12 17:50:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=284f5fe121d8eb0a0f50a6f2465ee2f99a061018">284f5fe121d8eb0a0f50a6f2465ee2f99a061018</a>
-<blockquote>
-<p>
- mkromfs needs linked to zlib when using shared zlib<br>
-<br>
- Ensure the compiler/linker command line parameter gets propagated from configure<br>
- to the mkromfs build.<br>
-<br>
-Makefile.in<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-12 13:15: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=98f6da60b9d463c617e631fc254cf6d66f2e8e3c">98f6da60b9d463c617e631fc254cf6d66f2e8e3c</a>
-<blockquote>
-<p>
- Bug 698026: bounds check zone pointers in Ins_IP()<br>
-<br>
-base/ttinterp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-12 13:08: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=c7c55972758a93350882c32147801a3485b010fe">c7c55972758a93350882c32147801a3485b010fe</a>
-<blockquote>
-<p>
- Bug 698024: bounds check zone pointer in Ins_MIRP()<br>
-<br>
-base/ttinterp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-12 12:59: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=d2ab84732936b6e7e5a461dc94344902965e9a06">d2ab84732936b6e7e5a461dc94344902965e9a06</a>
-<blockquote>
-<p>
- Bug 698025: validate offsets reading TTF name table in xps<br>
-<br>
-xps/xpsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-10 14:06:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6507e828ddfe1f60645bc925bff9bedfdb306ce">f6507e828ddfe1f60645bc925bff9bedfdb306ce</a>
-<blockquote>
-<p>
- graphics library - fix memory leak regression<br>
-<br>
- Bug # 698005 &quot;regression: commit 70cfc6afc42b9c299e9c05359f12455055105fac with Bug692720.pdf&quot;<br>
-<br>
- Commit 70cfc6 created a path from a list of rectangles early in a clip,<br>
- in order to minimise the number of times the path was created (creating<br>
- it later caused it to be discarded and re-created multiple times)<br>
-<br>
- Unfortunately, as I feared at the time, this introduced a memory leak<br>
- under certain conditions. When the clip_path is discarded we weren't<br>
- counting down the reference to the path_list.<br>
-<br>
- With this commit Bug697270.pdf uses approximately the same amount of<br>
- memory as it did before commit 70cfc6, but runs approximately 20%<br>
- faster.<br>
-<br>
- The regular cluster run also seems to exhibit a further ~20% improvement<br>
- in performance, presumably in addition to the existing 10% from the initial<br>
- commit. Note, this *only* affects configurations where the clist is<br>
- used.<br>
-<br>
-base/gxcpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-08 16:57:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a4f2cd23893cabe466d977668975987f925278d2">a4f2cd23893cabe466d977668975987f925278d2</a>
-<blockquote>
-<p>
- pdfwrite - keep using /Subsample for /Indexed images when downsampling<br>
-<br>
- Bug #698000 &quot;Inappropriate choice of downsampling filter for Indexed images&quot;<br>
-<br>
- For Bug #693917 we checked the downsampling factor for the Subsample and<br>
- Average downsampling filters and, if it was not an integer or nearly so,<br>
- we forced the Bicubic filter instead.<br>
-<br>
- Unfortunately, this doesn't work well for image data in a /Indexed colour<br>
- space.<br>
-<br>
- Instead this commit checks the colour space and, if its a /Indexed space,<br>
- forces the downsampling factor to the nearest integer, and preserves the<br>
- Subsample or Average filter.<br>
-<br>
-devices/vector/gdevpsdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-08 15:43:42 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2a9d6adb5239e797eec3358518950e49565730b0">2a9d6adb5239e797eec3358518950e49565730b0</a>
-<blockquote>
-<p>
- Bug 697983: avoid marking zero length glyph contours<br>
-<br>
- The file contains many glyphs with stray zero length contours dotted around the<br>
- 'main body' of the glyph outline. When a text rendering mode involving stroke<br>
- was used, these were resulting in the linecaps being drawn, and showing as<br>
- extra dots around the gylphs.<br>
-<br>
- Force linecap to 'butt' when using a stroking text rendering mode to avoid this.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-07 14:55:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cfde94be1d4286bc47633c6e6eaf4e659bd78066">cfde94be1d4286bc47633c6e6eaf4e659bd78066</a>
-<blockquote>
-<p>
- Bug 697985: bounds check the array allocations methods<br>
-<br>
- The clump allocator has four allocation functions that use 'number of elements'<br>
- and 'size of elements' parameters (rather than a simple 'number of bytes').<br>
-<br>
- Those need specific bounds checking.<br>
-<br>
-base/gsalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-07 14:27:51 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=70cfc6afc42b9c299e9c05359f12455055105fac">70cfc6afc42b9c299e9c05359f12455055105fac</a>
-<blockquote>
-<p>
- Bug 697679: Ensure clist playback correctly creates clip paths.<br>
-<br>
- Ghostscript clip paths consist of 3 parts:<br>
-<br>
- 1) A list of scan converted rectangles that union together to give<br>
- the clipping region.<br>
- 2) (Optionally) a path that represents the clipping region.<br>
- 3) A path_list structure (a list of paths that when intersected<br>
- together give the required clipping region).<br>
-<br>
- 3 is required for high level devices like pdfwrite (and the opvp<br>
- device).<br>
-<br>
- Most of the code is at pains to preserve path_list as gx_cpaths are<br>
- manipulated. The exception to this appears to be the clist code.<br>
- The rectangle list is sent through the clist, but the path is not.<br>
-<br>
- Accordingly, the code to intersect a gx_cpath with another path<br>
- checks to see if the path_list is valid on entry. If not, it<br>
- synthesizes one from the rectangle list.<br>
-<br>
- This bug is caused by the fact that we end up intersecting a<br>
- clip path 120000 times in a pattern clist playback. Each of those<br>
- synthesizes a path from the rectangle list.<br>
-<br>
- The fix here is to make the pattern clist playback create the<br>
- path_list each time it is replayed, meaning we have &lt; 100 such<br>
- operations.<br>
-<br>
- Thanks to Ken for his work on this, and for coming up with the<br>
- initial version of this patch.<br>
-<br>
-base/gxclrast.c<br>
-base/gxcpath.c<br>
-base/gxpath.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-06-03 18:50: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=0af88bdacdd8962244ac0a538c78b56bd5cc9376">0af88bdacdd8962244ac0a538c78b56bd5cc9376</a>
-<blockquote>
-<p>
- pdfwrite - fix customised doumentUUID<br>
-<br>
- Bug #697977 &quot;document UUID gets truncated&quot;<br>
-<br>
- The code writing out a user-specified documentUUID had an error, failing<br>
- to account for the 'uuid:' prefix.<br>
-<br>
- Credit to Axel Holewa for finding the preoblem and suggesting the fix.<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-19 18:12:00 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9c94340cd251ead99b4ae9121d1138c83be9a5df">9c94340cd251ead99b4ae9121d1138c83be9a5df</a>
-<blockquote>
-<p>
- PXL: Optimise 1 pixel wide image handling.<br>
-<br>
- If we are given a 1xH image, we'd rather reflect it to be<br>
- an Hx1 image so that it gets passed through the image code<br>
- as a single scanline. This allows things like collation of<br>
- runs of matching pixels to work far better.<br>
-<br>
- In particular this improves page mode performance for j11.prn.<br>
-<br>
-pcl/pxl/pximage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-29 16:19: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=5f53dbc3e917d44e92619f831ba06be7944b5471">5f53dbc3e917d44e92619f831ba06be7944b5471</a>
-<blockquote>
-<p>
- Bounds check buffers for downloaded glyphs in PCL.<br>
-<br>
- For downloaded fonts, there were several buffer overreads reported by valgrind<br>
- when interpreting Intellifont glyph descriptions.<br>
-<br>
- This adds using the (already existing) length field to bounds check when we<br>
- interpret the glyph.<br>
-<br>
-pcl/pcl/pcsfont.c<br>
-pcl/pl/plchar.c<br>
-pcl/pl/plfont.c<br>
-pcl/pl/plfont.h<br>
-pcl/pl/pllfont.c<br>
-pcl/pl/plulfont.c<br>
-pcl/pxl/pxerrors.c<br>
-pcl/pxl/pxfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-29 16:22:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fe6ed9f54a02357e01c1f8c517b6af831e5f59ae">fe6ed9f54a02357e01c1f8c517b6af831e5f59ae</a>
-<blockquote>
-<p>
- Ensure a FAPI instance is attached to a cloned font<br>
-<br>
- It was possible for a cloned font to be missing the FAPI server attached to the<br>
- 'parent' font. Add in a pl_fapi_passfont() call so it's guaranteed to be<br>
- available.<br>
-<br>
-pcl/pcl/pcsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-31 20:51:00 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bc12dc36623f3eb3c553ea1455cf1fd84d10b114">bc12dc36623f3eb3c553ea1455cf1fd84d10b114</a>
-<blockquote>
-<p>
- Avoid needless clip path recalculations.<br>
-<br>
- While investigating Bug 697679, I spotted that clip_call_fill_path<br>
- was being called with a non NULL pcpath, thus triggering a 'slow'<br>
- rebuild of the clipping path.<br>
-<br>
- In at least some of these cases, pcpath pointed to an invalid<br>
- clipping path. I believe this means we might as well have used<br>
- the fast route!<br>
-<br>
-base/gxclip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-31 20:14: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=9ee2adefdfc9a12bf71acd1e08e88b8cc8af0502">9ee2adefdfc9a12bf71acd1e08e88b8cc8af0502</a>
-<blockquote>
-<p>
- Avoid calling the same function twice.<br>
-<br>
- Not really expecting any huge speed benefit from this, but<br>
- it's silly to call it twice with the same args.<br>
-<br>
-base/gxcpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-31 21:44: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=2cebfeb7c91d5bcf916bc2c51d32a213f0ca776d">2cebfeb7c91d5bcf916bc2c51d32a213f0ca776d</a>
-<blockquote>
-<p>
- Bug 694646: Fix SEGV due to missing FontName attribute.<br>
-<br>
- pxSetFont allowed for an optional FontName attribute which meant it tried<br>
- to set a font using NULL. This function has been updated to check that<br>
- FontName, CharSize and SymbolSet are not NULL before trying to use them.<br>
-<br>
-pcl/pxl/pxfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-31 12:28: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=e57b2aafe5bf09bb7e7df5f4608a4910145553b2">e57b2aafe5bf09bb7e7df5f4608a4910145553b2</a>
-<blockquote>
-<p>
- Bug 697970: Solve underflow/overflow problems in new scan converter.<br>
-<br>
- The test file asks us to fill a line with one end at 0x7fffffff,<br>
- using 'any part of a pixel'. In order to calculate the index table<br>
- the existing code 'expands' this vertical area by 0x7f to allow<br>
- for rounding within a pixel. This leads to 0x8000007e, which<br>
- is of a different sign.<br>
-<br>
- Correspondingly the vertical ranges touched by the lines appear<br>
- different in the indexing and marking phases.<br>
-<br>
- To fix this we rejig the line calculations to avoid this<br>
- difference by more carefully doing the expansion.<br>
-<br>
- Thanks to Kamil Frankowicz for doing the fuzz testing that lead<br>
- to this bug/fix.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-31 13:50: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=9e621d6ffb0e29c5de8331bf2c95003c8cf85941">9e621d6ffb0e29c5de8331bf2c95003c8cf85941</a>
-<blockquote>
-<p>
- PDF interpreter - apply Optional Content /Usage dictionaries<br>
-<br>
- Bug #696076 &quot;Ghost script 9.16/9.15 print PDF layer even if print state is &quot;Never Print&quot;&quot;<br>
-<br>
- We currently only apply the /OFF (or /ON) entries from the Optional<br>
- Content Properties (/OCProperties) which is quite a high level and hence<br>
- low granularity control.<br>
-<br>
- This commit adds processing of the /Usage dictionary; any ordinary<br>
- Optional Content (not OCMD) which is not set to /OFF in the OCProperties<br>
- is checked for the existence of a /Usage dictionary. We then check for<br>
- either a /Print or /View key in the dictionary depending on the setting<br>
- of the -dPrinted command line switch. If the relevant key is present<br>
- then we check for a ViewState key and use that to determine whether the<br>
- Optional Content should be rendered or not.<br>
-<br>
- Note that if -dPrinted is not set on the command line then the interpreter<br>
- will attempt to guess. If the current device has OutputFile set then<br>
- the interpreter will assume that it should consider 'Print' keys. If it<br>
- is not present in the device, then the interpreter will assume that it<br>
- should consider 'View' keys.<br>
-<br>
- This causes the PDF file Bug690364.pdf to render radically differently.<br>
- This is because much of the content is set to not print, and a small<br>
- amount of extra data is set to render only when printed. Because the<br>
- cluster uses an OutputFile, we assume that we should behave as if<br>
- printing.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-31 11:24:40 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=33cf871a82e0fd9a0ebfed14317a2fa0f40e1e9d">33cf871a82e0fd9a0ebfed14317a2fa0f40e1e9d</a>
-<blockquote>
-<p>
- Bug 697748: Fix misspelled alignment attribute in SSE code.<br>
-<br>
- The SSE thresholding code relies on a buffer being 16 byte aligned.<br>
- To achieve this we use a compiler attribute to force alignment<br>
- to 16 bytes.<br>
-<br>
- MSVC uses &quot;align(16)&quot;, but gcc etc uses &quot;aligned(16)&quot;.<br>
-<br>
- We were using &quot;align(16)&quot; for both. Fix this in the macro here.<br>
-<br>
- Thanks to Timo Teras for spotting the problem and suggesting the<br>
- fix.<br>
-<br>
-base/gxht_thresh.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-30 10:30: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=b883b8fc62ec6bc630d5f88abef0d7799efa6687">b883b8fc62ec6bc630d5f88abef0d7799efa6687</a>
-<blockquote>
-<p>
- pdfwrite - Don't assume param list strings are NULL-terminated<br>
-<br>
- Bug #697948 &quot;(Add an ID to memory allocations.) breaks PDF/A output&quot;<br>
-<br>
- The bug description is misleading; in fact the problem is that the code<br>
- for reading a flag numeric value from a string parameter was assuming<br>
- the parameter was NULL_terminated, when in fact it is not.<br>
-<br>
- Depending on exactly how the memory layout happened to be, the bytes<br>
- following the parameter may or may not be NULLs, or ASCII digits. If it<br>
- so happened that the trailing bytes were ASCII digits, it was possible<br>
- for an incorrect Flag value to be parsed, which could lead to an error<br>
- being flagged.<br>
-<br>
- This commit just copies the actual number of bytes in the parameter<br>
- string to a temporary stack-based character buffer, NULL terminates the<br>
- buffer and reads the Flag value from there.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-28 21:46: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=4226202adec2a3f3a416e1986e8630bf7ca3bdc7">4226202adec2a3f3a416e1986e8630bf7ca3bdc7</a>
-<blockquote>
-<p>
- Fix Bug 694633 fuzzing segmentation fault.<br>
-<br>
- Return an error if the GL/2 parser runs out of data while processing<br>
- a macro. If within a macro, unlike the normal data stream, the GL/2<br>
- commands already have access to all of the data.<br>
-<br>
-pcl/pcl/pgparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-04 09:28: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=7918a01dd37bc383e61ae0b237341e69286dc83c">7918a01dd37bc383e61ae0b237341e69286dc83c</a>
-<blockquote>
-<p>
- PDF interpreter - Move ExtGState parameters into the regular graphics state<br>
-<br>
- Bug #696511 - &quot;Move ExtGState parameters into the regular graphics state&quot;<br>
-<br>
- A long time ago a decision was made not to replicate the PDF ExtGstate<br>
- parameters in the graphics state. This has had long term painful consequences<br>
- because we were unable to do a gsave/grestore to simply preserve<br>
- parameters but had to jump throuhg a lot of hoops. Amongst other problems<br>
- has been confusion over when exactly a change in colour has taken place.<br>
- With this commit the ExtGState parameters are moved into the graphics state<br>
- and obey gsave and grestore.<br>
-<br>
- This extensive commit was worked on in the PDF_gstate branch and the history<br>
- is preserved in that branch.<br>
-<br>
- This does introduce a few differences in the test suite;<br>
-<br>
- There are a few cases where broken files (recursive SMasks) now render<br>
- slightly differently.<br>
-<br>
- Some files now exhibit progressions, especially with CMYK or DeviceN output<br>
- devices, this is because the 'default' colour space was incorrect, the code<br>
- was using DeviceGray instead of the device's colour space, and this makes<br>
- a difference for some types of transparency blending when the Group does<br>
- not specify a Blending space.<br>
-<br>
- A few other files demonstrate progressions because a change in colour now<br>
- takes place before an error occurs.<br>
-<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>
-base/gsstate.c<br>
-base/gsstate.h<br>
-base/gstrans.c<br>
-base/gstrans.h<br>
-base/gxgstate.h<br>
-psi/igstate.h<br>
-psi/int.mak<br>
-psi/zcolor.c<br>
-psi/zcssepr.c<br>
-psi/zgstate.c<br>
-psi/zmatrix.c<br>
-psi/ztrans.c<br>
-psi/ztype.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-29 11:22: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=2e2a9d851c73192739c9227ef0030f3ba3e7b6fd">2e2a9d851c73192739c9227ef0030f3ba3e7b6fd</a>
-<blockquote>
-<p>
- PDF interpreter - Don't render closed Popup annotations, synthesise missing Popup Appearances<br>
-<br>
- Bug #697951 &quot;MuPDF - Arguably incorrect annotation&quot;<br>
-<br>
- Although this is a MuPDF bug, it showed a couple of problems in Ghostscript<br>
-<br>
- Firstly; Popup annotations which have /Open false should not be rendered<br>
-<br>
- Secondly; Popup annotations with no /Open should be treated as ?open False<br>
-<br>
- Finally, Popup annotations with no /Appearance were not rendered, unlike<br>
- other annotation types we were not synthesising an Appearance.<br>
-<br>
- This commit addresses all 3 of these, and shows progressions with:<br>
-<br>
- tests_private/pdf/PDF_1.7_FTS/fts_32_3232.pdf<br>
- tests_private/pdf/sumatra/1312_-_comments_not_displayed.pdf<br>
- tests_private/pdf/sumatra/1571_-_popup_annotations.pdf<br>
- tests_private/pdf/sumatra/embedded_go-to_actions.pdf<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-28 21:27:41 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3ded6c3b28a1b183a492ada2f2a3970953f3d060">3ded6c3b28a1b183a492ada2f2a3970953f3d060</a>
-<blockquote>
-<p>
- Increment the PJL stream pointer for illegal characters.<br>
-<br>
- When an illegal character is encountered within a PJL command we exit<br>
- with end of job. With recent changes it is necessary to increment the<br>
- stream pointer as well because the PJL interpreter is reinvoked upon<br>
- UEL resulting in an infinite loop.<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-24 19:29:57 +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=3ebffb1d96ba0cacec23016eccb4047dab365853">3ebffb1d96ba0cacec23016eccb4047dab365853</a>
-<blockquote>
-<p>
- Bug 697934: Fix SEGV due to error code being ignored.<br>
-<br>
- The return code from jbig2_decode_text_region was being ignored so the<br>
- code continued to try and parse the invalid file using incomplete/empty<br>
- structures.<br>
-<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-26 17:05:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5cf06167c248f345a1042c421cc2f5f741bf281d">5cf06167c248f345a1042c421cc2f5f741bf281d</a>
-<blockquote>
-<p>
- pdfwrite - correctly set the BPC for the image downsampling filter<br>
-<br>
- Bug #697944 &quot;Segmentation fault with -sDEVICE=pdfwrite&quot;<br>
-<br>
- The code to call the downsampling filter resizes the input to the filter<br>
- to 8BPC, and then resizes the output from the filter back to whatever<br>
- the required depth was.<br>
-<br>
- But the stream state for the downsampling filter was left with the<br>
- original BPC. This led to the Mitchell filter calculating two parameters<br>
- sizeofPixelIn and sizeofPixelOut incorrectly as 0 (4/8 is 0 in integer<br>
- arithmetic). Later the code used sizeofPixelOut being 1 to write 1 byte<br>
- output data, but if the value was not 1 it wrote 2 bytes of output.<br>
-<br>
- This causes a buffer overflow in the callers buffer, leading to memory<br>
- corruption and an eventual seg fault.<br>
-<br>
- This commit simply sets the BPC in the stream state correctly to reflect<br>
- the fact that the intermediate data is always 8 bits.<br>
-<br>
-devices/vector/gdevpsdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-26 13:13: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=6cae884b66944318c34e17992c628a246dda18aa">6cae884b66944318c34e17992c628a246dda18aa</a>
-<blockquote>
-<p>
- Vector devices - work around TrueType subsetting bug corrupting metrics tables<br>
-<br>
- Bug #697376 &quot;Adobe Distiller can't handle EPS files created with eps2write - limitcheck error&quot;<br>
-<br>
- The TrueType writing code for the vector devices continues to produce<br>
- problems. We should rewrite this code but realistically that is still<br>
- some way off.<br>
-<br>
- In this case the code was attempting to minimise the size of the VMTX<br>
- and HMTX tables by only writing out the metrics for the glyphs we were<br>
- actually including in the font (unused glyphs remain as references in the<br>
- font, but have no outlines).<br>
-<br>
- This is not valid in TrueType, the metrics tables must contain an entry<br>
- for each glyph. Looking at the code it should have been clear that this<br>
- was nonsense, but apparently it was missed.<br>
-<br>
- We can save a minimal amount of space by writing out the metrics for all<br>
- the glyphs up to the last used one, and then writing just a 0 side<br>
- bearing for each remaining glyph, but the space saving is small. So I've<br>
- chosen simply to disable the subsetting of metrics and copy the entire<br>
- table.<br>
-<br>
-devices/vector/gdevpsft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-26 11:27: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=bf949eaff89ac71b30d4a93638716e2c63090b0a">bf949eaff89ac71b30d4a93638716e2c63090b0a</a>
-<blockquote>
-<p>
- Bug 697949: check parameters for .setuseciecolor<br>
-<br>
-psi/zcolor3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-24 08:54:25 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d57e9332127baa82fa8083c0927498f412aa48d8">d57e9332127baa82fa8083c0927498f412aa48d8</a>
-<blockquote>
-<p>
- Fix tags with transparency.<br>
-<br>
- Only change the tag if the alpha_s (source alpha) is &gt; 0. If it is 100%<br>
- and the BlendMode is Normal, then we use the object's tag, if not, we<br>
- combine with the existing tag (in the backdrop/destination) by OR'ing<br>
- the bits together. Note that for some Blend modes, the pixel may only<br>
- have contributions from the source or from the destination, but we don't<br>
- use that because it could change the tag within an object (e.g, gradient<br>
- or image) depending on the color value causing unexpected shifts in the<br>
- tag value.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-24 16:26: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=2e3ca2386ae8045a084dc862e7e22f3df1341d0e">2e3ca2386ae8045a084dc862e7e22f3df1341d0e</a>
-<blockquote>
-<p>
- device subclassing fix reference counting and stype patching<br>
-<br>
- We patch the memory manager's 'stype' on the original device's memory<br>
- when we subclass the device, but had missed resetting that when we<br>
- unsubclass the device, restoring the child device. This left the memory<br>
- manager stype set incorrectly.<br>
-<br>
- Secondly it transpires that we can alter the reference count of the<br>
- parent, so that it differs from the child, and we hadn't accounted for<br>
- that. If the reference count of the child (subclassed) device differs<br>
- from the parent (subclassing) device at the point where we unsubclass<br>
- the device, we need to make sure we retain the correct reference<br>
- count. Otherwise we can end up with saved gstates pointing to a device<br>
- which has been freed.<br>
-<br>
-base/gdevdflt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-23 13:05:42 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b13ef3074dd164d2317cd5d03331b8de96ea98d0">b13ef3074dd164d2317cd5d03331b8de96ea98d0</a>
-<blockquote>
-<p>
- pdfwrite - unescape specially escaped names in pdfmark operations<br>
-<br>
- Bug #697885 &quot;Commented pdf-file converting with 9.21 comments are omitted but not with &lt;= 9.20 versions&quot;<br>
-<br>
- We now preserve (where possible) annotations from input PDF files<br>
- into the output file, where previously these were effectively 'folded into'<br>
- the page content stream.<br>
-<br>
- In order to do this for Appearances, we need to create a separate Form<br>
- XObjet which we reference from the annotation. Doing this requires<br>
- some underhandedness in the PDF interpreter, where me make use of<br>
- a non-standard 'escape' consisting of tow NULL (0x00) bytes before the<br>
- name of the Form XObject, and one NULL after.<br>
-<br>
- This works well, but ended up copying the NULL bytes into the output<br>
- PDF file. This is actually legal, but it seriously confused the<br>
- Linearisation code when it tried to alter the object numbers in order<br>
- to write them in the correct xref table.<br>
-<br>
- Since these NULLs are not required and confuse the code, we now take<br>
- extra action to remove them from the string we create working from the<br>
- pdfmark data.<br>
-<br>
-devices/vector/gdevpdfr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-22 10:18: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=b914c5de71fcc7675f40d8557975ec87cd46fced">b914c5de71fcc7675f40d8557975ec87cd46fced</a>
-<blockquote>
-<p>
- Bug 697910: handle Type 1 fonts with 'embedded' Type 1 fonts<br>
-<br>
- The test file for this bug has a Type 1 font stream (for an oblique version of<br>
- a font) which 'contains' a second (non-oblique) Type 1 font, from which the<br>
- 'outer' font pulls the CharStrings (the oblique version contains its own<br>
- subrs to make the regular font into the oblique font).<br>
-<br>
- A previous fix for a broken Type 1 font broke support for the above (valid)<br>
- form of Type 1 font. The broken Type 1 ends up putting various required keys<br>
- in the current dictionary, rather than in the font dictionary.<br>
-<br>
- The previous fix pushes a sacrificial &quot;top dictionary&quot; before executing the font<br>
- stream. It identifies the broken font by spotting that required keys exist in<br>
- a dictionary on the dictionary stack (rather than in the font dictionary on the<br>
- operand stack on the call to definefont). When it encounters the broken font<br>
- layout, it copies the required keys into that sacrificial top dictionary, and<br>
- uses that as the font dictionary.<br>
-<br>
- The Type 1 inside another Type confuses that code, and ends up creating one font<br>
- from the &quot;inner&quot; Type 1.<br>
-<br>
- This commit reverses the logic: it checks for required keys missing from the<br>
- font dictionary, and if any are missing, it tries to find them on the<br>
- dictionary stack.<br>
-<br>
- This is slightly less robust than the original solution, since it assumes that<br>
- the font has created a font dictionary, but has defined required keys before<br>
- pushing it onto the dictionary stack. A font that fails entirely to create<br>
- a font dictionary will fail.<br>
-<br>
- Obviously, a solution for broken fonts that causes (admittedly strange) but<br>
- valid fonts to fail is unacceptable. If we find a case of a font that is broken<br>
- as described above, we can revisit this fix.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-17 15:27:23 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d7cade08ad36382a0ed5dfa72fcb9a0e9a822417">d7cade08ad36382a0ed5dfa72fcb9a0e9a822417</a>
-<blockquote>
-<p>
- Remove shared device psi implementation and improve documentation.<br>
-<br>
- The experimental gpdl build now only supports running PostScript and<br>
- PDF in a seperate context with it's own device using the normal API.<br>
- At this time it only runs files detected as PostScript or PDF in the<br>
- default device with no arguments. The previous setup did not work<br>
- properly and if we are to have a shared device it should be<br>
- implemented anew anyway.<br>
-<br>
- Also improve the documentation for how languages plug into the<br>
- language switching system.<br>
-<br>
-gpdl/psi/psitop.c<br>
-pcl/pcl/pctop.c<br>
-pcl/pl/plimpl.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/pltop.h<br>
-psi/imain.c<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-11 13:56:04 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=00d5670774e9c56cb8bf6e9f877756c82d10536e">00d5670774e9c56cb8bf6e9f877756c82d10536e</a>
-<blockquote>
-<p>
- Clean up documentation and simplify language implementation procs.<br>
-<br>
-pcl/pcl/pctop.c<br>
-pcl/pl/pltop.h<br>
-pcl/pxl/pxtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-08 17:16:56 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d585f6b8b2150c70a4fdc8d2b4d582012411f586">d585f6b8b2150c70a4fdc8d2b4d582012411f586</a>
-<blockquote>
-<p>
- PL API: Remove separate interpreter instances.<br>
-<br>
- The previous design was complicated by supporting multiple instances<br>
- of each language which will never be used, so we can remove the<br>
- interpreter instance type and access each language through the<br>
- implementation pointer.<br>
-<br>
-gpdl/psi/psitop.c<br>
-pcl/pcl/pcimpl.c<br>
-pcl/pcl/pcstate.h<br>
-pcl/pcl/pctop.c<br>
-pcl/pcl/pctop.h<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/pjparse.h<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/pjtop.c<br>
-pcl/pl/pjtop.h<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plimpl.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pl/pltop.c<br>
-pcl/pl/pltop.h<br>
-pcl/pl/realmain.c<br>
-pcl/pxl/pxstate.h<br>
-pcl/pxl/pxtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-21 20:42:15 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b6689161cc0dcbbb0f029a91708ac2724570a63d">b6689161cc0dcbbb0f029a91708ac2724570a63d</a>
-<blockquote>
-<p>
- PL API: make PJL an implementation and several miscellaneous improvements.<br>
-<br>
- It is simpler to have PJL selected as an implementation upon seeing<br>
- the @PJL identifier or detecting a UEL in the input stream.<br>
- Previously we always entered the PJL interpreter after exiting another<br>
- language. Also, added stubs for the &quot;run_string&quot; api.<br>
-<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plcursor.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pl/realmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-03 13:04:53 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=611289048a343ec07eb3ec1dd19aa922211f200d">611289048a343ec07eb3ec1dd19aa922211f200d</a>
-<blockquote>
-<p>
- Remove cursor renewal.<br>
-<br>
- This hack was used so the languages could return without consuming<br>
- data which is wrong. The underlying problem was the XL interpreter<br>
- returning 0 when it should have been returning an exit code.<br>
-<br>
-pcl/pl/plcursor.c<br>
-pcl/pl/plcursor.h<br>
-pcl/pl/plmain.c<br>
-pcl/pxl/pxtop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-30 17:10:50 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3eb111d09610e72106af19b28a90982b14dc55dc">3eb111d09610e72106af19b28a90982b14dc55dc</a>
-<blockquote>
-<p>
- PL API: cleanup unused functions replace by API calls.<br>
-<br>
-pcl/pl/gpcl6dll32.def<br>
-pcl/pl/gpcl6dll64.def<br>
-pcl/pl/gpdldll32.def<br>
-pcl/pl/gpdldll64.def<br>
-pcl/pl/gxpsdll32.def<br>
-pcl/pl/gxpsdll64.def<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-29 08:08:56 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=87af13a97cc6868dd31379e446f089b1dd9e101a">87af13a97cc6868dd31379e446f089b1dd9e101a</a>
-<blockquote>
-<p>
- PLAPI: Use api for windows display program.<br>
-<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-02 10:20:58 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=761bf52f3591219b8262549d9a337d0a3d71fd61">761bf52f3591219b8262549d9a337d0a3d71fd61</a>
-<blockquote>
-<p>
- PL API: add plapi implementation.<br>
-<br>
- Fills out the plapi implementation and changes the default command line<br>
- program to use the new api.<br>
-<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plapi.c<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pl/realmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-29 08:55:44 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=47d3e1e7ec973fcead1f88cf24e4bdc430123592">47d3e1e7ec973fcead1f88cf24e4bdc430123592</a>
-<blockquote>
-<p>
- Memory leak check.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-29 08:38:42 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0877d850a63fe57ad60fac065ae7675817ba7a4f">0877d850a63fe57ad60fac065ae7675817ba7a4f</a>
-<blockquote>
-<p>
- Rename pltoputl to plcursor.<br>
-<br>
- Only the cursor code remained in pltoputl.<br>
-<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plcursor.c<br>
-pcl/pl/plcursor.h<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-23 11:10:31 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ebd2e51a648e0657eb9bd2464be01ad09f9b01e0">ebd2e51a648e0657eb9bd2464be01ad09f9b01e0</a>
-<blockquote>
-<p>
- Move all cursor code to single module.<br>
-<br>
- Not sure why this was spread out in plmain.c and pltoputl.c.<br>
-<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plmain.c<br>
-pcl/pl/pltoputl.c<br>
-pcl/pl/pltoputl.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-22 15:09:31 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2ec6f74df2fa14776182a75d306f3028170f5715">2ec6f74df2fa14776182a75d306f3028170f5715</a>
-<blockquote>
-<p>
- Make the main instance opaque.<br>
-<br>
- Needed to reduce spreading dependencies resulting from including<br>
- plmain.h.<br>
-<br>
-pcl/pcl/pctop.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pxl/pxtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-21 12:03:57 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6850869002f40634a2af0e6a1c939d3ed385f217">6850869002f40634a2af0e6a1c939d3ed385f217</a>
-<blockquote>
-<p>
- Factor out common icc code into 1 pl procedure.<br>
-<br>
-pcl/pcl/pctop.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pxl/pxtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-21 10:17:40 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5c663ee7cf06f0887404709aae45141fb3049817">5c663ee7cf06f0887404709aae45141fb3049817</a>
-<blockquote>
-<p>
- Remove unused vmspaces and nogc references.<br>
-<br>
-pcl/pcl/pcl.mak<br>
-pcl/pcl/pcpage.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pl/pltop.c<br>
-pcl/pxl/pxl.mak<br>
-pcl/pxl/pxtop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-19 21:43:08 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a20606c8f5ce3f8c0ce80c84a831ed4a98f2156">6a20606c8f5ce3f8c0ce80c84a831ed4a98f2156</a>
-<blockquote>
-<p>
- PL API: functions to exit and delete the main instance, like gs.<br>
-<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-18 14:50:20 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2a3bc2153fd93542914b83df5d94dbafdbe257ec">2a3bc2153fd93542914b83df5d94dbafdbe257ec</a>
-<blockquote>
-<p>
- Fix the gpdl build, PCL and XPS language switching for testing.<br>
-<br>
- This uncovered a problem with the PJL state and the command line. PJL<br>
- should not be initialized for each file (pl_main_run_file()) if PJL<br>
- was issued on the command line (-J switch) otherwise it should be<br>
- initialized.<br>
-<br>
-pcl/pl/plimpl.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-17 20:47:14 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=37d1286a66bd80a471aa9ac0a166bc291a8318db">37d1286a66bd80a471aa9ac0a166bc291a8318db</a>
-<blockquote>
-<p>
- PL API - Reorganizing main procedure.<br>
-<br>
- Splits out routines for running a file and inializing with arguments,<br>
- consistent with gs API. The allocator module was removed, the<br>
- procedures were to simple to be separated out. Lots of trivial clean<br>
- up as well.<br>
-<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plalloc.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-15 11:11:13 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f1dd6db9f969d0a6d23baeb781f5082f8d0f78e4">f1dd6db9f969d0a6d23baeb781f5082f8d0f78e4</a>
-<blockquote>
-<p>
- PL API: deprecate error string buffers which were never used.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-15 10:32:49 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bd95aa0cf7a5eef3e37c4bfa29ec32debd6b954d">bd95aa0cf7a5eef3e37c4bfa29ec32debd6b954d</a>
-<blockquote>
-<p>
- PL API: continues previous commit removing pre and post page operations.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-14 13:01:07 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e9ff0dcf1892086276872e868a254d012ab48702">e9ff0dcf1892086276872e868a254d012ab48702</a>
-<blockquote>
-<p>
- PL API: continue previous commit, purge pre and post page closures.<br>
-<br>
-pcl/pcl/pctop.c<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/pltop.c<br>
-pcl/pl/pltop.h<br>
-pcl/pxl/pxtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-14 12:34:40 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=97f9904dc5d8f45cbca93b02098eac077bca7f5c">97f9904dc5d8f45cbca93b02098eac077bca7f5c</a>
-<blockquote>
-<p>
- PL API: remove instance page count and refactor output page.<br>
-<br>
- The page count is no longer needed in the main instance, it is now<br>
- available in the device. The output page closures were convoluted and<br>
- never used, factor out a common procedure to output the page,<br>
- pl_finish_page(), to be used by PCL, PXL and XPS.<br>
-<br>
-pcl/pcl/pctop.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pxl/pxtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-13 16:38:10 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23d85c19be2700d098d133f87a40e24031a9c64e">23d85c19be2700d098d133f87a40e24031a9c64e</a>
-<blockquote>
-<p>
- Remove set client instance procedure.<br>
-<br>
- Unnecessary complexity between the main program and the individual languages.<br>
-<br>
-pcl/pcl/pctop.c<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pl/pltop.c<br>
-pcl/pl/pltop.h<br>
-pcl/pxl/pxtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-09 10:34:42 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e14474ba4eff1cf7c42ff8888a3daa6dc6c83aaa">e14474ba4eff1cf7c42ff8888a3daa6dc6c83aaa</a>
-<blockquote>
-<p>
- PL API Remove device_memory main instance member.<br>
-<br>
- This was only needed for the language switch build with PS and PDF<br>
- which is no longer supported.<br>
-<br>
-gpdl/psi/psitop.c<br>
-pcl/pcl/pctop.c<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pl/pltop.c<br>
-pcl/pl/pltop.h<br>
-pcl/pxl/pxtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-08 17:33:41 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3e026d15093a2a7279c3c4e46b3e24cb5ee11370">3e026d15093a2a7279c3c4e46b3e24cb5ee11370</a>
-<blockquote>
-<p>
- PL API: Add PJL instance to PDL array.<br>
-<br>
- Previously the PJL interpreter was separated out from the other<br>
- interpreters now it is simply known to be the 0'th entry in the array<br>
- of languages. Having it separate would yet another member in the main<br>
- instance with the new API.<br>
-<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/plimpl.c<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-08 08:40:56 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ce20a5af6c0d72ae1d0198f3c44e2b0a0d0a09d6">ce20a5af6c0d72ae1d0198f3c44e2b0a0d0a09d6</a>
-<blockquote>
-<p>
- PL API: remove pdl implementation array references.<br>
-<br>
- A copy of a reference to the array was used in varous places, yet it<br>
- is a global constant, so reference the global directly.<br>
-<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-08 07:34:26 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a3ad76f1872b46390328c31102c9b6e6bf25d776">a3ad76f1872b46390328c31102c9b6e6bf25d776</a>
-<blockquote>
-<p>
- PL API: remove plplatf module.<br>
-<br>
- This makes the startup more consistent with gs.<br>
-<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plplatf.c<br>
-pcl/pl/plplatf.h<br>
-pcl/pl/plplatfps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-07 18:30:04 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=587bfc08b8e833c2aa45284fe558a8d9b7116f4e">587bfc08b8e833c2aa45284fe558a8d9b7116f4e</a>
-<blockquote>
-<p>
- PL API: move argument state to the main instance.<br>
-<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-07 16:53:00 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7f856d0f9de2145e7533ad239de618506ae145e6">7f856d0f9de2145e7533ad239de618506ae145e6</a>
-<blockquote>
-<p>
- PL API: move device parameter list to the main instance.<br>
-<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-07 13:40:09 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ce6334ed0996ccd2d52ac81d273a78293487bfd">5ce6334ed0996ccd2d52ac81d273a78293487bfd</a>
-<blockquote>
-<p>
- PL API: access main instance parameters directly.<br>
-<br>
-pcl/pcl/pctop.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pl/pltop.h<br>
-pcl/pxl/pxtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-07 09:38:45 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6ab1d85eef2b821dcb08f8b82622fa92be1be1af">6ab1d85eef2b821dcb08f8b82622fa92be1be1af</a>
-<blockquote>
-<p>
- PL API: make main instance the &quot;top of the system&quot;<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-30 19:52:57 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a7d93d3f71ec4a92a726998f1acac85489c277e">9a7d93d3f71ec4a92a726998f1acac85489c277e</a>
-<blockquote>
-<p>
- PL API Make language read buffer a member of the language instance.<br>
-<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-29 17:26:55 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1130f6ac765de4c6d202281496e1ad62b8370460">1130f6ac765de4c6d202281496e1ad62b8370460</a>
-<blockquote>
-<p>
- PL API: refactor initialization to be more like gs.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-28 11:56:01 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6cf194e23355ed75ddd248bde3e4849c8ad1bfcf">6cf194e23355ed75ddd248bde3e4849c8ad1bfcf</a>
-<blockquote>
-<p>
- SVG is no longer supported, remove test file.<br>
-<br>
- Also adds an xps tiger created by xpswrite.<br>
-<br>
-pcl/tools/tiger.svg<br>
-pcl/tools/tiger.xps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-27 15:35:38 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=46a472c247dd33d53124b79204594c707c99e134">46a472c247dd33d53124b79204594c707c99e134</a>
-<blockquote>
-<p>
- PL API - remove PJL memory allocator.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-18 13:47:46 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c672305a6e45a39c446918b5c4899c9763fc8f5b">c672305a6e45a39c446918b5c4899c9763fc8f5b</a>
-<blockquote>
-<p>
- PL API - make &quot;universe&quot; part of instance.<br>
-<br>
- The &quot;universe&quot; is soon to be deprecated but for now include it in the<br>
- instance so it is available to all api functions.<br>
-<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-17 16:43:19 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c5b13ee9953a4d482ab3bce112c61f19cf758a62">c5b13ee9953a4d482ab3bce112c61f19cf758a62</a>
-<blockquote>
-<p>
- PL API - Dynamically allocate main instance.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-19 11:08: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=119ec77d4e44e3861a376323ed14466b28b2f4bf">119ec77d4e44e3861a376323ed14466b28b2f4bf</a>
-<blockquote>
-<p>
- PDF interpreter - better match the behaviour of Acrobat with invalid /Mask<br>
-<br>
- Bug #697919 &quot;Invalid Mask values cause content to not render&quot;<br>
-<br>
- The sample file has a 1 bit per component image with a Mask, the values<br>
- in the mask array are [204 255]. Since this is a 1 bit image, clearly the<br>
- only valid values are 0 or 1.<br>
-<br>
- Previously (bug #692852) we have specifically treated /Indexed spaces<br>
- with an invalid Mask specially, so that if the initial value is out<br>
- of range we ignore the Mask array, otherwise we use the initial value<br>
- and set the second to 1.<br>
-<br>
- Also previously we have bug #689717 which is, in fact, an identical<br>
- case to this one. In that case we have code which clamps the two values<br>
- to 'max - 1' which works for that case. In fact, it works too well for<br>
- that case, and produces content which is almost certainly desired by<br>
- the author, but which Acrobat does not render.<br>
-<br>
- In this commit we make the DeviceGray case match the /Indexed case, I<br>
- rather suspect that for 1 bit images Acrobat *never* uses the /Mask<br>
- array values, but I don't have an example in any other colour space. So<br>
- for now we'll leave them alone.<br>
-<br>
- This causes the file for Bug 689717 to render with content 'missing',<br>
- however it does now match Acrobat. I do not think we can reasonably match<br>
- Acrobat's result for this bug without also matching it for the prior bug.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-15 14:34: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=5501c28dbb1814aa869cb5132e52d5bcf090ec6e">5501c28dbb1814aa869cb5132e52d5bcf090ec6e</a>
-<blockquote>
-<p>
- New chunk memory manager.<br>
-<br>
- Based off the original chunk heap managers code, this uses splay<br>
- trees for free blocks to speed searching. (Dual, top-down,<br>
- semi-splaying trees, one ordered on size, and another on location).<br>
-<br>
- Adding this memory manager runs into a problem with pdfwrite.<br>
- Because pdfwrite is not entirely behaved with memory freeing, it<br>
- can free the same blocks more than once. This primarily happens<br>
- in pdf_close.<br>
-<br>
- The existing chunk memory manager seems to get away with this by<br>
- luck, whereas this revised version sees SEGVs in some {pcl,xps} -&gt;<br>
- pdfwrite tests.<br>
-<br>
- Accordingly, we add a special fudge; if we call gs_defer_frees(1)<br>
- then the memory manager defers freeing blocks by putting them<br>
- onto a linked list (but only once). When we then call<br>
- gs_defer_frees(0), the manager finalizes all the blocks on the<br>
- list (which may in turn add new blocks to the list!). Once<br>
- all the blocks have been finalized, they are then freed.<br>
-<br>
- &quot;All&quot; the pdfwrite double frees come from inside pdf_close (or<br>
- all the ones I have seen at least). Accordingly we bracket<br>
- pdf_close with gs_defer_frees(1) and gs_defer_frees(0).<br>
-<br>
-base/gsalloc.c<br>
-base/gsmalloc.c<br>
-base/gsmchunk.c<br>
-base/gsmchunk.h<br>
-base/gsmemory.h<br>
-base/gsmemret.c<br>
-devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-18 16:18:25 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b69d68995d065d61b2defe919c038cf9cf60b598">b69d68995d065d61b2defe919c038cf9cf60b598</a>
-<blockquote>
-<p>
- Fix buffer overrun in xpspath.c<br>
-<br>
- Seen with tests_private/xps/sumatra/buffer_overflow_in_path_handling.xps<br>
-<br>
- Specifically:<br>
-<br>
- bin/gxps -sOutputFile=out.pdf -sDEVICE=pdfwrite -r72 -Z: -dNOPAUSE<br>
- -dBATCH -dClusterJob<br>
- tests_private/xps/sumatra/buffer_overflow_in_path_handling.xps<br>
-<br>
-xps/xpspath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-18 15:59:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e0088aa8d8e65ad7455d35e9280fe978163534b">1e0088aa8d8e65ad7455d35e9280fe978163534b</a>
-<blockquote>
-<p>
- Bug 696412 - Fix seg fault in pdf_end_transparency_mask<br>
-<br>
- Bug #696412 &quot;Seg faults found by fuzzing in pdf_end_transparency_mask&quot;<br>
-<br>
- The file is (of course) badly corrupted, leading to us receiving a<br>
- 'end' for a transparency mask when we did not previously receive a<br>
- 'begin'.<br>
-<br>
- The code in pdf_end_transparency_mask assumed that the prior begin would<br>
- have created a soft mask dictionary, but of course if we didn't see the<br>
- begin then we don't have one.<br>
-<br>
- Check for this and simply return an error instead of trying to<br>
- dereference the NULL pointer.<br>
-<br>
-devices/vector/gdevpdft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-18 14:10:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=58aeac2fbd1489c797351a9b53134e40729b661c">58aeac2fbd1489c797351a9b53134e40729b661c</a>
-<blockquote>
-<p>
- Bug 696377 - Fix a seg fault in subclassing<br>
-<br>
- Bug #696377 &quot;Seg faults found by fuzzing in default_subclass_create_compositor&quot;<br>
-<br>
- With a sufficiently corrupted file it was possible to reach this point<br>
- with a mismatch of transparency group begin/end. This could lead to<br>
- us having the compositor device being NULL which we would then try to<br>
- dereference.<br>
-<br>
- Simply check the compositor device and don't try to dereference it if<br>
- its NULL.<br>
-<br>
- This was only reproducible on the commit mentioned in the bug report,<br>
- after fixing it the file continued on to seg fault in a completely<br>
- different place. However I believe this is due to the fact that the<br>
- corrupted file leads to a mismatch of push/pop groups for transparency<br>
- and Michael has addressed that with later commits. The file runs to<br>
- completion (with *many* errors) on current code.<br>
-<br>
-base/gdevsclass.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-14 03:34:57 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=56c26790af78f94c08a595e0c9da527418c47614">56c26790af78f94c08a595e0c9da527418c47614</a>
-<blockquote>
-<p>
- Bug 697866: Do bounds checking of read data.<br>
-<br>
- Credit to Ken for suggesting what bounds to check.<br>
-<br>
-jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-14 03:37:11 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d39d31168cec8a08ac1e5c44c95925fecb087173">d39d31168cec8a08ac1e5c44c95925fecb087173</a>
-<blockquote>
-<p>
- Make clipping in image compositing handle underflow.<br>
-<br>
-jbig2dec/jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-14 12: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=a328d6377bac5268d3a8c071fbbf54c66e07de3a">a328d6377bac5268d3a8c071fbbf54c66e07de3a</a>
-<blockquote>
-<p>
- Fix memory leak in case of error.<br>
-<br>
-jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-14 03:31:50 +0800
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dbdcc8158d59960abfa5241b55ed76cbd40e12f3">dbdcc8158d59960abfa5241b55ed76cbd40e12f3</a>
-<blockquote>
-<p>
- Fix double free in error case.<br>
-<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-16 20:53:27 +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=8e466b1468df6afd91eac6266a417160540d8789">8e466b1468df6afd91eac6266a417160540d8789</a>
-<blockquote>
-<p>
- Bug 694632: Fix SEGV due to invalid proportional_spacing value.<br>
-<br>
- Updated pcl_font_header to correctly handle fonts where the<br>
- proportional_spacing is greater than 1.<br>
-<br>
-pcl/pcl/pcsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-17 14:38:45 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bc8190c4e8050364c10bb3545ca6c705bfb3d38c">bc8190c4e8050364c10bb3545ca6c705bfb3d38c</a>
-<blockquote>
-<p>
- Squash warning.<br>
-<br>
- Don't implicitly lose 'const'.<br>
-<br>
-pcl/pcl/pcstate.h<br>
-pcl/pcl/pctext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-17 13:03: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=24781094295489cafe562239a251300c6cfbd6ca">24781094295489cafe562239a251300c6cfbd6ca</a>
-<blockquote>
-<p>
- Remove superfluous gsmemlok files.<br>
-<br>
- Use it or lose it.<br>
-<br>
-base/gsmalloc.c<br>
-base/gsmemlok.c<br>
-base/gsmemlok.h<br>
-base/gxclread.c<br>
-base/gxclthrd.c<br>
-base/lib.mak<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-17 09:58: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=79fd8d7466f51c74bd0c14dc1fd33cfaba0e7b83">79fd8d7466f51c74bd0c14dc1fd33cfaba0e7b83</a>
-<blockquote>
-<p>
- Bug 697909: Handle PDF T3 glyph streams with unmatched 'q'<br>
-<br>
- We have to handle the case where a glyph description stream from a PDF Type 3<br>
- font has an unmatched 'q'. We can track this in the PDF interpreter by checking<br>
- the depth of the dictionary stack, and unwinding with 'Q' operations until the<br>
- dictionary stack is back to where we started.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-17 12:45:20 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b38ed8a40e013ea79c89c6561eedf1841caa9801">b38ed8a40e013ea79c89c6561eedf1841caa9801</a>
-<blockquote>
-<p>
- Add gs_set_object_type function to gs_memory_t interface.<br>
-<br>
- The subclassing code uses a horribly unsafe hack to reset<br>
- the type of a device object. This fails when the device<br>
- object is not of the expected type (in this case, when it's<br>
- not from the i_alloc manager).<br>
-<br>
- Add a new access function to the API to allow this to happen<br>
- safely regardless of manager type.<br>
-<br>
-base/gdevdflt.c<br>
-base/gsalloc.c<br>
-base/gsmalloc.c<br>
-base/gsmchunk.c<br>
-base/gsmemlok.c<br>
-base/gsmemory.h<br>
-base/gsmemret.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-15 14:32:47 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5fd7b3473fc7cd02a2575f47b38d07f0e1e4222">b5fd7b3473fc7cd02a2575f47b38d07f0e1e4222</a>
-<blockquote>
-<p>
- Squash warning in ETS code<br>
-<br>
- Missing 'restrict' in a prototype.<br>
-<br>
-base/ets.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-14 11:53:42 +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=b9c9f25d2cf43835d3d563e6012968b253e7faf1">b9c9f25d2cf43835d3d563e6012968b253e7faf1</a>
-<blockquote>
-<p>
- Bug 694628: Fix SEGV due to invalid bits_per_index value.<br>
-<br>
- Updated check_cid_hdr to correctly handle indexed colour<br>
- spaces where the bits_per_index is greater than 8.<br>
-<br>
-pcl/pcl/pccid.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-15 13:42:23 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9468f852a09232d1f4200d252ffb665bc4d86f51">9468f852a09232d1f4200d252ffb665bc4d86f51</a>
-<blockquote>
-<p>
- Bug 696416: clean up pdfwrite form stack after error.<br>
-<br>
- In pdfwrite, when we start accumulating a form (whether a 'real' form, or a<br>
- transparency group), we save a load of 'state' in stack form, so we can then<br>
- unroll it when the form execution completes.<br>
-<br>
- If we begin a form, and the form content throws an error, we can reach the end<br>
- of the page whilst still having not unrolled the state from the form level back<br>
- to the page level, leaving the form stream object as the 'current' stream<br>
- rather than the page stream.<br>
-<br>
- This results in the form not being marked as used, and potentially freed,<br>
- resulting in a seg fault when we try to flush the current stream (expecting it<br>
- to be the page stream, not the form stream).<br>
-<br>
- Before we proceed to complete the page, ensure that we've unrolled any errant<br>
- form states.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-15 13:26:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=050d101bda8a73a6da44c379b20156f1ce49c948">050d101bda8a73a6da44c379b20156f1ce49c948</a>
-<blockquote>
-<p>
- Remove spurious extra definition of RAMFS_APPEND<br>
-<br>
- Spotted by Robin<br>
-<br>
-base/ramfs.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-12 11:21: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=969bef004730b3feb8cc01cf99d12f152807b24e">969bef004730b3feb8cc01cf99d12f152807b24e</a>
-<blockquote>
-<p>
- Bug 696397: further validate TTF glyph &quot;end point&quot; values<br>
-<br>
- In a TTF glyph, we have to read the index of last point for each contour. We<br>
- already validated the value to ensure that the value for index &quot;i + 1&quot; was<br>
- always larger than that for &quot;i&quot;. But we didn't check the values are positive.<br>
-<br>
-base/ttfmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-12 11:19:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7de3003abd8a66ec312ebed4146bd56ec4649d8f">7de3003abd8a66ec312ebed4146bd56ec4649d8f</a>
-<blockquote>
-<p>
- Bug 696390: bounds check Type 2 charstring &quot;registry&quot;<br>
-<br>
- We emulate a &quot;Registry&quot; construct for Type 2 charstrings, but only with a single<br>
- entry. Bounds check accesses to it to avoid overrun.<br>
-<br>
-base/gstype2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-13 10:48:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=98fca6146085dc2cf60effb0596e79fe12b3e69f">98fca6146085dc2cf60effb0596e79fe12b3e69f</a>
-<blockquote>
-<p>
- pdfwrite - make sure an EP pdfmark is not an orphan<br>
-<br>
- Bug #696375 &quot;Seg faults found by fuzzing in cos_object_memory (gdevpdfo.c:189)&quot;<br>
-<br>
- The fault is caused because the initial /BP pdfmark is corrupted. This<br>
- means that a substream and resource for the 'Picture' has not been<br>
- created, leading to us trying to dereference a NULL pointer.<br>
-<br>
- If the resource is NULL&lt; throw an 'undefined' error instead.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-12 13:15: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=7df7d8b6c37ca2d42ffcf1eb5bc795e741241259">7df7d8b6c37ca2d42ffcf1eb5bc795e741241259</a>
-<blockquote>
-<p>
- Remove descriptions of operators which have been hidden<br>
-<br>
-doc/Language.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-12 11:54: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=35a0ead22c8f1f459a4466b435b2486d53e75836">35a0ead22c8f1f459a4466b435b2486d53e75836</a>
-<blockquote>
-<p>
- Update documentation to reflect recent utility file removal<br>
-<br>
-doc/Psfiles.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-12 11:20:13 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a0753746c3b6dd0ee01f37ebf9f3903450e9e832">a0753746c3b6dd0ee01f37ebf9f3903450e9e832</a>
-<blockquote>
-<p>
- remove deleted file references from unixinst.mak<br>
-<br>
-base/unixinst.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-12 08:42: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=e8750a73313d6083aa949bc5223a26ae55ef02dd">e8750a73313d6083aa949bc5223a26ae55ef02dd</a>
-<blockquote>
-<p>
- Renove or modify many files from lib and toolbin that are no longer useful<br>
-<br>
- Remove unused packfile.ps and gs_pfile.ps file from lib<br>
- --------------------------------------------------------<br>
- The PostScript claims to 'Pack groups of files together, with<br>
- compression, for use in storage-scarce environments.'<br>
-<br>
- It also states that it 'must be kept consistent with gs_pfile.ps' which<br>
- says it is 'Runtime support for minimum-space fonts and packed files'<br>
-<br>
- I've never heard of either of these being used, they aren't used in the<br>
- ROM file system and it seems unlikely these days that there is a great<br>
- deal of call for minimising file sizes.<br>
-<br>
- If these should need to be reinstated, note that they use .setglobal<br>
- .currentglobal and .computecodes. At the time of this commit these<br>
- operators were being deprecated and hidden though the C support is<br>
- retained. If the C code is later removed then these library files<br>
- will not work.<br>
-<br>
- Remove font2c.ps<br>
- -----------------<br>
- If we want to build a font into C and link it, we have the ROM file<br>
- system in place to do so. This no longer seems useful.<br>
-<br>
- remove font2c<br>
-<br>
- Remove impath.ps<br>
- -----------------<br>
- The apparent purpose of this code is to take a bitmap (scan ?) of a<br>
- glyph and turn it into a PostScript type 1 font form, presumably in<br>
- order to make a font.<br>
-<br>
- This doesn't seem hugely useful, and seems to me at least borderline<br>
- illegal depending on jurisdiction.<br>
-<br>
- We also want to remove, or at least disable, the .imagepath operator<br>
- which this program (and only this program) relies upon. If we ever<br>
- need to re-instate this program, we will also need to reinstate<br>
- .imagepath<br>
-<br>
- Remove pdfinflt.ps and pdfwrite.ps<br>
- -----------------------------------<br>
- pdfwrite is only (as far as I can see) used by pdfinflt.ps which says:<br>
-<br>
- % It is not yet ready for prime time, but it is available for anyone wants<br>
- % to fix it.<br>
- %<br>
- % The main problem is:<br>
- %<br>
- % 1. Sometimes the PDF files that are written are broken. When they are<br>
- % broken, GS gets an xref problem.<br>
- %<br>
- % This problem is actually due to lib/pdfwrite.ps since even<br>
- % when no conversion is done, the file is may be bad.<br>
-<br>
- Since it doesn't work, and we can use MuPDF (which does work) for the<br>
- same task, I've chosen to delete both these files.<br>
-<br>
- Remove unprot.ps wrfont.ps<br>
- ---------------------------<br>
- unprot.ps 'disables access checks' according to the comments in order<br>
- to print out eexec-encrypted type 1 fonts. Since this could, presumably<br>
- be used to read a noaccess dictionary and dump type 1 font outlines it<br>
- is of dubious legality. (see the comments in wrfont.ps)<br>
-<br>
- wrfont.ps is used to decode a type 1 font, we have better tools for<br>
- decoding fonts so this file seems mostly useless.<br>
-<br>
- By the same reasoning we don't need type1ops.ps or type1enc.ps<br>
-<br>
- Remove addxchar.ps<br>
- -------------------<br>
- This was used to add extended Latin characters to a font. Our fonts<br>
- now contain all the standard glyphs that Adobe fonts do, we don't want<br>
- to go back down the route of adding (and maintaining) poor quality<br>
- additional glyphs to the fonts.<br>
-<br>
- Remove decrypt.ps<br>
- ------------------<br>
- Yet another way to decrypt a type 1 font. In addition to dubious<br>
- legality we have better ways to do this.<br>
-<br>
- Remove pcharstr.ps<br>
- -------------------<br>
- Again, we have better tools for doing this job and the legality of<br>
- this tool is debatable.<br>
-<br>
- Remove markhint.ps<br>
- -------------------<br>
- We believe we now have better tools for dealing with fonts than this.<br>
-<br>
- Delete level1.ps<br>
- -----------------<br>
- A fairly pointless file.<br>
-<br>
- Remove smoke.ps from toolbin<br>
- -----------------------------<br>
- Our current testing method is much more thorough.<br>
-<br>
- Remove bughunt.sh<br>
- ------------------<br>
- A 'user contributed file that has not been kept current', since 1995<br>
- apparently. I can't believe this is still useful.<br>
-<br>
- Remove pstogsf.bat<br>
- -------------------<br>
- I'm fairly certain this is long defunct.<br>
-<br>
- Remove showchar.ps<br>
- -------------------<br>
- another font-related utility, we've deleted the programs it reliee on,<br>
- so....<br>
-<br>
- Remove wftopfa<br>
- ---------------<br>
- Wadalab fonts, given these were uploaded by Werner Lemberg I'm as sure<br>
- as possible that we don't need these utilities to work with these<br>
- fonts.<br>
-<br>
- Remove markpath.sh<br>
- -------------------<br>
- seems like a moderately pointless file; since it uses flushpage,<br>
- which I want to hide, remove it.<br>
-<br>
- Remove quit.ps<br>
- ---------------<br>
- Seriously ? A file which just contains 'quit' ?<br>
-<br>
- Modify various of our utilities to not use Ghostscript extension ops<br>
- ---------------------------------------------------------------------<br>
- We want to hide various of our extension operators, these files used<br>
- .devicename, .rectappend, .currentglobal, .setglobal and .namestring<br>
-<br>
- Replaced .currentglobal/.setglobal with currenglobal/setglobal<br>
-<br>
- Replaced .rectappend with a simple PostScript path<br>
-<br>
- Replaced .devicename with currentdevice /Name get<br>
-<br>
- Replaced .namestring with 1024 string cvs<br>
-<br>
- Remove EndOfTask.ps<br>
- --------------------<br>
- Just a Ctrl-D<br>
-<br>
- Remove gs_rdlin.ps<br>
- -------------------<br>
- Linux 'readline' support, just sets prompt to nothing<br>
-<br>
- Remove showpage.ps<br>
- -------------------<br>
- just contains 'showpage'!<br>
-<br>
-lib/EndOfTask.ps<br>
-lib/addxchar.ps<br>
-lib/decrypt.ps<br>
-lib/font2c<br>
-lib/font2c.bat<br>
-lib/font2c.cmd<br>
-lib/font2c.ps<br>
-lib/font2pcl.ps<br>
-lib/gs_pfile.ps<br>
-lib/gs_rdlin.ps<br>
-lib/impath.ps<br>
-lib/level1.ps<br>
-lib/markhint.ps<br>
-lib/markpath.ps<br>
-lib/packfile.ps<br>
-lib/pcharstr.ps<br>
-lib/pdfwrite.ps<br>
-lib/pftogsf.bat<br>
-lib/ps2ascii.ps<br>
-lib/quit.ps<br>
-lib/showchar.ps<br>
-lib/showpage.ps<br>
-lib/traceop.ps<br>
-lib/type1enc.ps<br>
-lib/type1ops.ps<br>
-lib/unprot.ps<br>
-lib/viewmiff.ps<br>
-lib/wftopfa<br>
-lib/wftopfa.ps<br>
-lib/wrfont.ps<br>
-toolbin/bughunt.sh<br>
-toolbin/pdf_info.ps<br>
-toolbin/pdfinflt.ps<br>
-toolbin/smoke.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-11 13:09:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1497d65039885a52b598b137dd8622bd4672f9be">1497d65039885a52b598b137dd8622bd4672f9be</a>
-<blockquote>
-<p>
- Remove as many non-standard operators as possible<br>
-<br>
- Remove all the Display PostScript operators and all the NeXT extensions<br>
-<br>
- Remove all the operators which do not appear to be used in our code<br>
-<br>
- Remove all the operators which are only used in bound procedures defined<br>
- at startup and which can therefore subsequently be removed.<br>
-<br>
- The operators to be undefined are stored in arrays in PostScript and<br>
- the C support code is untouched. This means that it is relatively<br>
- simple for an end user to restore an operator if required.<br>
-<br>
- Operators which are used in our test suite files are listed in the<br>
- arrays but commented out.<br>
-<br>
- Operators which are used (by our own code) in a way which requires them<br>
- to be present are also listed in the arrays, but commented out.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-12 13:47: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=0072619f46f89e0c7406160d4829bccda314b37d">0072619f46f89e0c7406160d4829bccda314b37d</a>
-<blockquote>
-<p>
- ps2epsi - reapply fix<br>
-<br>
- Bug #697890 &quot;Bug 689832 still unresolved in master&quot;<br>
-<br>
- The fix for this was applied (contrary to the report in 697890) but it<br>
- was later removed as part of the fix for bug #688500.<br>
-<br>
- I presume this was accidental, since 688500 predates 689832, but the<br>
- fix was applied later. I don' know how this happened and after 8 years<br>
- I don't propose to worry about it.<br>
-<br>
- Just reapply the fix for 689832<br>
-<br>
-lib/ps2epsi.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-12 11:22:55 +0100
-</strong>
-<br>Joseph Heenan &lt;joseph@emobix.co.uk&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0feca09fccfa3b45b095f85a9627a89954b03d58">0feca09fccfa3b45b095f85a9627a89954b03d58</a>
-<blockquote>
-<p>
- Update URLs in jbig2dec README<br>
-<br>
-jbig2dec/README<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-11 18:23: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=fdd5bef4c19dcc653b07c5cfd3cea4de13aab0f7">fdd5bef4c19dcc653b07c5cfd3cea4de13aab0f7</a>
-<blockquote>
-<p>
- Tweak MSVC build flags for profile builds.<br>
-<br>
- Always build with frame pointers enabled, otherwise we get no<br>
- stacktraces, which makes the profiles much less useful.<br>
-<br>
-base/msvccmd.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-11 13:30:45 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ce0dd3907f01e93cc42c1b5e5d18c996cf7822e9">ce0dd3907f01e93cc42c1b5e5d18c996cf7822e9</a>
-<blockquote>
-<p>
- XPS and PXL did not set the scan converter option.<br>
-<br>
-pcl/pxl/pxtop.c<br>
-xps/xps.mak<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-17 16:23:41 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9cbd475a13e5b0992bb7f8e33d75eb246c1a622d">9cbd475a13e5b0992bb7f8e33d75eb246c1a622d</a>
-<blockquote>
-<p>
- There is no reason to flush the cache when writing mode changes.<br>
-<br>
-pcl/pxl/pxgstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-11 16:42: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=181ebf1c8c07c5411e98d50cbac86511e0098e4d">181ebf1c8c07c5411e98d50cbac86511e0098e4d</a>
-<blockquote>
-<p>
- PDF interpreter don't warn about Decode for ImaegMasks<br>
-<br>
- An imagemask could result in a warning about Decode arrays being the<br>
- wrong length if the current colour space was not DeviceGray.<br>
-<br>
- This commit properly checks to see if the image is an ImageMask and<br>
- checks the Decode length is 2.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-11 14:07: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=ccfd2c75ac9be4cbd369e4cbdd40ba11a0c7bdad">ccfd2c75ac9be4cbd369e4cbdd40ba11a0c7bdad</a>
-<blockquote>
-<p>
- Bug 697892: fix check for op stack underflow.<br>
-<br>
- In the original fix, I used the wrong method to check for stack underflow, this<br>
- is using the correct method.<br>
-<br>
-psi/zfrsd.c<br>
-psi/zmisc3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-11 09:57: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=31f9fddb4a330c21ea8268fc9e8ae0ead23296bf">31f9fddb4a330c21ea8268fc9e8ae0ead23296bf</a>
-<blockquote>
-<p>
- Bug 696417: fully initialise TTF bytecode context.<br>
-<br>
- Although the font and CVT programs aren't supposed to use certain opcodes,<br>
- specifically, in this case, the opcodes that reference the contents of the<br>
- zone pointers. But this font contains programs that do. Since other interpreters<br>
- handle this, just ensure we initialize the context fully (so the zone pointers<br>
- are valid) before executing the context.<br>
-<br>
-base/ttobjs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-10 18:43: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=6839638079bab4dc6f1e9e87e340e98b2e39ba7c">6839638079bab4dc6f1e9e87e340e98b2e39ba7c</a>
-<blockquote>
-<p>
- Bug 696421: check for infinite recursion in TTF composite glyph<br>
-<br>
- This font contains a composite glyph that references itself, resulting in<br>
- infinite recursion when we try to retrieve the metrics for the glyph.<br>
-<br>
- Add a check for this (trivial) case.<br>
-<br>
-base/gstype42.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-10 18:20: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=496ebe4757eb630d09589a577738891c1e803707">496ebe4757eb630d09589a577738891c1e803707</a>
-<blockquote>
-<p>
- Bug 696422: bounds check number of points in TTF glyph<br>
-<br>
- There was already a bounds check for the number of points in a TTF glyph<br>
- outline contour, to avoid buffer overflow, but it failed to check that the value<br>
- was positive. In this case, the value is negative, which caused loops to fail<br>
- to exit. This is sufficiently broken, we can only give up and return an error<br>
-<br>
-base/ttfmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-10 16:33: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=85cd173e3ceeb638a2b035e057a0497f10547978">85cd173e3ceeb638a2b035e057a0497f10547978</a>
-<blockquote>
-<p>
- Bug 694150(2): Ensure lzw state is fully intialized.<br>
-<br>
- valgrind identified an issue where the OldTiff flag in the lzw state wasn't<br>
- initialized. Although not evident in this case, it was possible for other fields<br>
- to also not be set. So, initialize the state fully before using it.<br>
-<br>
-psi/zfdecode.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-10 17:50:39 +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=ed6c5133a1004ce8d38f1b44de85a7186feda95e">ed6c5133a1004ce8d38f1b44de85a7186feda95e</a>
-<blockquote>
-<p>
- Bug 697683: Bounds check before reading from image source data.<br>
-<br>
- Add extra check to prevent reading off the end of the image source<br>
- data buffer.<br>
-<br>
- Thank you to Dai Ge for finding this issue and suggesting a patch.<br>
-<br>
-jbig2dec/jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-10 15:34:35 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1a624d1bfa1e63ceab87f5e4e22c3daffa2d0f01">1a624d1bfa1e63ceab87f5e4e22c3daffa2d0f01</a>
-<blockquote>
-<p>
- Bug 697811 (continued): Fix the other 3 equivalent cases.<br>
-<br>
- Followup from the previous commit, applying the same fix to the<br>
- other 3 cases.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-10 15:18:34 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=210893fb2b271717957fcca4e6c049494024cc9d">210893fb2b271717957fcca4e6c049494024cc9d</a>
-<blockquote>
-<p>
- Bug 697847: Fix SEGV seen in scan converter.<br>
-<br>
- Previously the scan converter had had problems with extremely<br>
- large/small values over/underflowing during bezier subdivision.<br>
-<br>
- We'd fixed this by calling into a &quot;_big&quot; variant of the<br>
- subdivision routine that sacrificed accuracy in the bottom bit.<br>
-<br>
- Unfortunately, this can cause 'jitter' in the low bits of the<br>
- subdivided curves, which can cause scanlines to be crossed<br>
- repeatedly. Once a single curve can cross a given scanline<br>
- more times than expected, our buffer allocation is too small<br>
- and we get crashes such as the one seen here.<br>
-<br>
- The fix is to move to using 64bit accuracy in the _big variant<br>
- and thus not introduce the jitter.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-10 11:13:04 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b38f2cb37b7bf469b36ac52b62c4aab6ccf55b6b">b38f2cb37b7bf469b36ac52b62c4aab6ccf55b6b</a>
-<blockquote>
-<p>
- Bug 697813: Fix integer overflow leading to buffer overflow.<br>
-<br>
- When calculating the amount of space required for a buffer, we<br>
- were using an int. This would overflow, meaning we'd allocate<br>
- less than we needed, and then segmentation fault when we overran<br>
- the end.<br>
-<br>
- Fix is to count the space required in an int64_t, and check that<br>
- that actually fits into a uint (the type passed to the allocation<br>
- function) before allocating.<br>
-<br>
- Side note: Surely gs should be using size_t's rather than uints<br>
- for its allocation calls?<br>
-<br>
- Also, our error cleanup was freeing the wrong thing. Fix that too.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-05 13:25:08 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0bccbb7bc00ffaeee7785544aa796c315f4b579f">0bccbb7bc00ffaeee7785544aa796c315f4b579f</a>
-<blockquote>
-<p>
- Bug 697861 Avoid push of text transparency group when no text is drawn<br>
-<br>
- The text can be handed to the pdf14 device text_begin operation with a graphic<br>
- state that has a null device. This occurs when the text state was<br>
- set to do no stroke or fill, only movements. In such a case we<br>
- don't want to do the text group push until we actually have some<br>
- text to draw.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-08 16:08: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=ab78fab575a8d699aeec7ca37fecff66413cb93b">ab78fab575a8d699aeec7ca37fecff66413cb93b</a>
-<blockquote>
-<p>
- Ensure FAPI server is present in base font in .FAPIBuildChar<br>
-<br>
- The code used 'I', the FAPI server retrieved from the font dictionary,<br>
- without checking to see if it was NULL.<br>
-<br>
- Prevents a seg fault<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-08 12:16: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=24133e312b7824ad1b5bc7701039b34b800b7062">24133e312b7824ad1b5bc7701039b34b800b7062</a>
-<blockquote>
-<p>
- remove #if TEST sections<br>
-<br>
- This code seems to be no longer used, it wasn't compiled and<br>
- I can't see a justification to retain it.<br>
-<br>
-base/gscencs.c<br>
-psi/zfdcte.c<br>
-psi/zfunc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-08 11:48:42 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2ef1ae95e0b0c7f24a246868dd26339bb5db7160">2ef1ae95e0b0c7f24a246868dd26339bb5db7160</a>
-<blockquote>
-<p>
- remove smtf.c, zrop.c, zdosio.c and zfilterx.c from all builds<br>
-<br>
- Some of these were included in some builds, none of the content is<br>
- believed to be still useful.<br>
-<br>
- Update the Windows projects to reflect the file deletions<br>
-<br>
- Update develop.htm to also reflect the file removal<br>
-<br>
-Makefile.in<br>
-base/smtf.c<br>
-base/unix-gcc.mak<br>
-doc/Develop.htm<br>
-psi/int.mak<br>
-psi/os2.mak<br>
-psi/zcidtest.c<br>
-psi/zdosio.c<br>
-psi/zfilterx.c<br>
-psi/zrop.c<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-06 09:26: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=f11cb093563ace8c4b831bcb97caff951474e380">f11cb093563ace8c4b831bcb97caff951474e380</a>
-<blockquote>
-<p>
- Remove some old colour test code and associated operators<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-06 09:09: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=4ee490955006dda75797468ba1a69a71867c8cdb">4ee490955006dda75797468ba1a69a71867c8cdb</a>
-<blockquote>
-<p>
- Delete the unused source file zcsdevn.c from the PostScript interpreter<br>
-<br>
- Remove the reference from the Windows VS projects<br>
-<br>
- Remove the reference in develop.htm<br>
-<br>
-doc/Develop.htm<br>
-psi/zcsdevn.c<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-05 15:38: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=ff2243aae6d34e395f0d5cbac93689df7069c09c">ff2243aae6d34e395f0d5cbac93689df7069c09c</a>
-<blockquote>
-<p>
- Bug 697859 - unchecked operand in .repeatform can cause seg fault<br>
-<br>
- Check that the second operand is a dictionary before we try to use it.<br>
-<br>
-psi/zform.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-03 22:06: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=b184e783702246e154294326d03d9abda669fcfa">b184e783702246e154294326d03d9abda669fcfa</a>
-<blockquote>
-<p>
- Bug 697703: Prevent integer overflow vulnerability.<br>
-<br>
- Add extra check for the offset being greater than the size<br>
- of the image and hence reading off the end of the buffer.<br>
-<br>
- Thank you to Dai Ge for finding this issue and suggesting a patch.<br>
-<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-04 15:50: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=e24e6194ca59d7b556116451490f71d2d85f4642">e24e6194ca59d7b556116451490f71d2d85f4642</a>
-<blockquote>
-<p>
- Bug 697854 - unchecked operand in .seticcspace can cause seg fault<br>
-<br>
- This operator hasn't been used since (I think) the release of 9.0. To<br>
- prevent this problem, remove it totally.<br>
-<br>
-psi/zicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-04 15:13:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=956becf97c69ccb2542a37c9a6421159dfe58e4e">956becf97c69ccb2542a37c9a6421159dfe58e4e</a>
-<blockquote>
-<p>
- Bug 697853 - unchecked operands in .begintransparencymaskgroup<br>
-<br>
- The operator .begintransparencymaskgroup didn't check the type (or<br>
- indeed existence) of its 5th parameter. Because this a boolean it<br>
- wouldn't have caused an actual problem, but nor would it have correctly<br>
- signalled a stackunderflow or typecheck error. Also, we should always<br>
- validate the operands.<br>
-<br>
-psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-04 14:16: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=59ef159e4c42c84c72130c14825f9517ef53cc16">59ef159e4c42c84c72130c14825f9517ef53cc16</a>
-<blockquote>
-<p>
- Extend annotation type control for pdfwrite<br>
-<br>
- The original solution to control the drawing of annotations based on the<br>
- annotation type only worked for output devices that do not preserve things<br>
- like annotations (i.e. only non-pdfwrite devices).<br>
-<br>
- This applies the filtering to also work with pdfwrite.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-04 14:26:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=88667cf67d3a435bc3ba727ab173c77666c8a1bb">88667cf67d3a435bc3ba727ab173c77666c8a1bb</a>
-<blockquote>
-<p>
- Bug 697850 - .getdeviceparms doesn't check operands<br>
-<br>
- This is actually benign because the unchecked parameter is used as an<br>
- argument to stack_param_list_write() which simply ignores it if the<br>
- type is incorrect. However, its possible we might change this at some<br>
- point, I think its best to check the type.<br>
-<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-04 13:42: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=37f9ba12dad303edca41ef166dd5b8815fb31763">37f9ba12dad303edca41ef166dd5b8815fb31763</a>
-<blockquote>
-<p>
- Bug 697848 - .type42execchar doesn't validate parameters<br>
-<br>
- The code made quite a has of parameter validation, it did validate some<br>
- parameters, but not very coherently.<br>
-<br>
-psi/zchar42.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-04 12:08: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=478800857dfc06b0d2d363dd1ef916dbdda061ed">478800857dfc06b0d2d363dd1ef916dbdda061ed</a>
-<blockquote>
-<p>
- Correct function /Domain array checks<br>
-<br>
- Bug #697858 &quot;Function Domain validation incorrect&quot;<br>
-<br>
- The PDF and PostScript specifications state that the entries in a Domain<br>
- array for a function must be such that Domain2i &lt;= Domain2i+1<br>
-<br>
- However the code in fn_build_sub_function() inverted the sense by<br>
- checking if Domain2i &gt;= Domain2i+1 and throwing an error if so. This is<br>
- of course incorrect for the case where Domain2i == Domain2i+1, this<br>
- should not be an error, but the code treated it as an error.<br>
-<br>
-psi/zfunc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-03 12:05: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=57f20719e1cfaea77b67cb26e26de7fe4d7f9b2e">57f20719e1cfaea77b67cb26e26de7fe4d7f9b2e</a>
-<blockquote>
-<p>
- Bug 697846: revision to commit 4f83478c88 (.eqproc)<br>
-<br>
- When using the &quot;DELAYBIND&quot; feature, it turns out that .eqproc can be called with<br>
- parameters that are not both procedures. In this case, it turns out, the<br>
- expectation is for the operator to return 'false', rather than throw an error.<br>
-<br>
-psi/zmisc3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-05-03 11:47:35 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2a619d16d86348805b1732fb1e21c88dd00374fd">2a619d16d86348805b1732fb1e21c88dd00374fd</a>
-<blockquote>
-<p>
- Add finer control of PDF annotation drawing.<br>
-<br>
- Add the ability to define an array of annotation types that gs should draw,<br>
- and ignore the others. On the command line, you'd add:<br>
- -c &quot;/ShowAnnotTypes [.....]&quot; -f &lt;input file&gt;<br>
-<br>
- Where the array can contain one or more of:<br>
- /Stamp<br>
- /Squiggly<br>
- /Underline<br>
- /Link<br>
- /Text<br>
- /Highlight<br>
- /Ink<br>
- /FreeText<br>
- /StrikeOut<br>
- /stamp_dict<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-26 22:12:14 +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=5e57e483298dae8b8d4ec9aab37a526736ac2e97">5e57e483298dae8b8d4ec9aab37a526736ac2e97</a>
-<blockquote>
-<p>
- Bug 697693: Prevent SEGV due to integer overflow.<br>
-<br>
- While building a Huffman table, the start and end points were susceptible<br>
- to integer overflow.<br>
-<br>
- Thank you to Jiaqi for finding this issue and suggesting a patch.<br>
-<br>
-jbig2dec/jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-27 13:21: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=04b37bbce174eed24edec7ad5b920eb93db4d47d">04b37bbce174eed24edec7ad5b920eb93db4d47d</a>
-<blockquote>
-<p>
- Bug 697799: have .rsdparams check its parameters<br>
-<br>
- The Ghostscript internal operator .rsdparams wasn't checking the number or<br>
- type of the operands it was being passed. Do so.<br>
-<br>
-psi/zfrsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-27 13:03: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=4f83478c88c2e05d6e8d79ca4557eb039354d2f3">4f83478c88c2e05d6e8d79ca4557eb039354d2f3</a>
-<blockquote>
-<p>
- Bug 697799: have .eqproc check its parameters<br>
-<br>
- The Ghostscript custom operator .eqproc was not check the number or type of<br>
- the parameters it was given.<br>
-<br>
-psi/zmisc3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-27 12:34:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5603e8fc3e59c435318877efe627967ee6baebb8">5603e8fc3e59c435318877efe627967ee6baebb8</a>
-<blockquote>
-<p>
- Bug 697769: cmap tab for symbolic fonts, and format 4 cmap parsing<br>
-<br>
- This involved two problems:<br>
- Firstly, the logic of whether to treat a font flagged as symbolic *really*<br>
- as symbolic was missing a condition. It appears that as well as checking for<br>
- a symbolic (3.0) cmap table, we also need to check for a UCS-2 (3.1) cmap<br>
- table.<br>
-<br>
- As noted before, this area is poorly documented in the spec, so it is possible<br>
- further issues may arise.<br>
-<br>
- Secondly, the fonts in the test file are, in fact, invalid. Each using a format<br>
- 4 segmented cmap table with only one, non-terminal, segment. According to the<br>
- TTF spec, a format 4 table should have a terminating segment whose start and<br>
- end codes are 0xffff. These fonts do not have such a segment. As it happens,<br>
- we ignore the terminal segment anyway, so by simply tweaking the loop<br>
- condition, we can parse the one segment, and retrieve a usable cmap.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-27 12:28:42 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=05d0bbc50ad453990520ed2d2ded3ace538bcb1d">05d0bbc50ad453990520ed2d2ded3ace538bcb1d</a>
-<blockquote>
-<p>
- Change TTF cmap procedure name and tidy up<br>
-<br>
- The procedure for parsing the TTF cmap table was called &quot;cmaparray&quot;, but it<br>
- has returned a dictionary rather than an array for a *long* time. So change<br>
- the procedure name to &quot;cmapdict&quot;.<br>
-<br>
- In the format 4 cmap parsing, left over from when we did return an array, we<br>
- looped over the codes, counting as we go, so we could allocate an array large<br>
- enough to hold all the mappings, then looped over them again to fill in the<br>
- array.<br>
-<br>
- As we now use a dictionary, there is no need to pre-count, so the first<br>
- loop was redundant - remove it.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-20 09:54: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=e589d67461e7e522c8af6cb9cc61064018b6a4fc">e589d67461e7e522c8af6cb9cc61064018b6a4fc</a>
-<blockquote>
-<p>
- Bug 696379: Handle error correctly in font with CDevProc<br>
-<br>
- In event of a Type 1 charstring font throwing an error setting up for a<br>
- CDevProc, ensure we use the correct path to exit the function, doing the<br>
- required cleanup along the way.<br>
-<br>
-psi/zchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-19 16:20: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=7e78f3a285bb41a6d3a33d608c6ba9d00b9cd107">7e78f3a285bb41a6d3a33d608c6ba9d00b9cd107</a>
-<blockquote>
-<p>
- Ensure gs is sufficiently inited before using PS memory<br>
-<br>
- Spotted by accident: having &quot;-o&quot; first in the command line can cause a<br>
- segfault<br>
-<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-06 22:10: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=88fc69e9bf5bfc73ce906c038b09bc8055dabe96">88fc69e9bf5bfc73ce906c038b09bc8055dabe96</a>
-<blockquote>
-<p>
- Bug 697722: Skip glyph cache with vertical substitution<br>
-<br>
- The way PXL implements vertical glyph substitution means it defeats our glyph<br>
- cache logic - the cache doesn't have the information to differentiate between<br>
- a vertical substitute and a regular glyph.<br>
-<br>
- As this is a very rarely used feature, the simplest solution is to disable use<br>
- of the cache when vertical substitutes are in force - it will neither lookup<br>
- existing, nor add new glyph instances to the cache.<br>
-<br>
- If we start seeing more jobs using vertical glyph substitution, and this proves<br>
- to be a performance bottleneck, we can revisit this and add the required data<br>
- for the cache to handle these (and possibly other) cases.<br>
-<br>
-pcl/pxl/pxfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-25 21:05:27 +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=7f5fb63f7f2ef5ff3f234e0653412d8f4a439c0d">7f5fb63f7f2ef5ff3f234e0653412d8f4a439c0d</a>
-<blockquote>
-<p>
- Bug 694150 : Fix SEGV in s_LZWD_process.<br>
-<br>
- Prevent using prev_code &lt; 0 which would make an entry before the table.<br>
- This in turn means that when a length of 4 is decoded, the decoder fails<br>
- to find the eod and continues to write off the end of the memory segment.<br>
-<br>
-base/slzwd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-26 16:12:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d2ba380aaa4df253bb6a1237f136ab4984657bd">1d2ba380aaa4df253bb6a1237f136ab4984657bd</a>
-<blockquote>
-<p>
- PDF interpreter - Apply /Widths to illegal (empty) type 3 CharProcs<br>
-<br>
- Bug #697805 &quot;Incorrect spacing between text&quot;<br>
-<br>
- The file (created by the Skia graphics library) embeds all the fonts as<br>
- type 3, the CharProc for the space glyph is embedded as an empty stream:<br>
-<br>
- 17 0 obj<br>
- &lt;&lt;<br>
- /Length 0<br>
- &gt;&gt;<br>
- stream<br>
- endstream<br>
- endobj<br>
-<br>
- The specification does not say what should happen if the /Width entry<br>
- is not the same as the actual width in the glyph description, but we<br>
- choose to use the /Width, because from prior experience we know that's<br>
- what Acrobat does.<br>
-<br>
- However, this glyph is illegal, because it contains neither a d0 nor a d1<br>
- operator. We apply the Widths override when executing d0 or d1, so if<br>
- the (required) operator is not present in the glyph description we<br>
- cannot override it.<br>
-<br>
- In this commit we detect a 0 length stream and treat it the same as a<br>
- missing stream; we execute a dummy d1 which enables us to do the<br>
- Widths override.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-26 10:20: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=d648ec8c6935387d485b1d9be56e2d147109616f">d648ec8c6935387d485b1d9be56e2d147109616f</a>
-<blockquote>
-<p>
- (e)ps2write - add definition of MacRoman Encoding<br>
-<br>
- Bug #697733, follow on from commit c90836f3782ce8e8f3076cb8b50503cfe91dabcf<br>
-<br>
- The previous commit altered to using MacRoman Encoding for embedded,<br>
- subset TrueType fonts, because we prefer the 1,0 CMAP subtable from<br>
- such fonts. However, MacRoman is not a standard Encoding for PostScript<br>
- interpreters. Add it here.<br>
-<br>
-devices/vector/opdfread.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-25 17:08: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=8556b698892e4706aa0b9d996bec82fed645eaa5">8556b698892e4706aa0b9d996bec82fed645eaa5</a>
-<blockquote>
-<p>
- PS interpreter - remove superexec from systemdict<br>
-<br>
- This looks like bit rot, superexec was meant to have been undefined from<br>
- systemdict, and moved to internaldict, but the code only executed if<br>
- superexec was defined in the current dictionary. It seems that at some<br>
- time in the past the order of execution was changed in such a way that<br>
- the current dictionary at that point was no longer systemdict.<br>
-<br>
- So instead of checking currentdict, explicitly check systemdict.<br>
-<br>
- This means changing our gs_cet.ps file which we use for the Quality<br>
- Logic CET (Command Emulation Test) suite so that it can find superexec<br>
- and use it to set up our environment in a specific fashion, to prevent<br>
- spurious differences when running the tests.<br>
-<br>
- If sueperexec isn't available when we run the CET tests we'll get an<br>
- error, which sounds like a good idea, hopefully we'll notice that.<br>
-<br>
-Resource/Init/gs_cet.ps<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-25 13:38: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=31cb597dbbff0a6aebe48469568837e2844cdfdc">31cb597dbbff0a6aebe48469568837e2844cdfdc</a>
-<blockquote>
-<p>
- A better DSC Parser fix for bug #697800<br>
-<br>
- Commit 06d283c4a20fe7ec727bebb56404242734ea2d70 checked the number of<br>
- operands, but this is a better fix, since it also correctly checks the<br>
- type of the dictionary operand, which the previous fix didn't do.<br>
-<br>
-psi/zdscpars.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-25 13:03:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=06d283c4a20fe7ec727bebb56404242734ea2d70">06d283c4a20fe7ec727bebb56404242734ea2d70</a>
-<blockquote>
-<p>
- DSC parser - check number of operands supplied<br>
-<br>
- Bug 697800 &quot;Null pointer dereference in zparse_dsc_comments()&quot;<br>
-<br>
- The custom operator .parse_dsc_comments wasn't checking the number of<br>
- operands supplied, before attempting to validate them. If not enough<br>
- were supplied it ended up falling off the bottom of the operand stack.<br>
-<br>
- Generate a stackunderflow error when this happens.<br>
-<br>
-psi/zdscpars.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-24 12:01: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=db4cb499fbc3c87b2b0182e550c82eb3c93fc1b4">db4cb499fbc3c87b2b0182e550c82eb3c93fc1b4</a>
-<blockquote>
-<p>
- PS interpreter - restore correct error behaviour for invalid /Decode arrays<br>
-<br>
- PDF interpreter - trim excessively long Decode arrays to the correct length<br>
-<br>
- Bug #697787 &quot; regression, several EPS figures which work fine with gs &lt;= 9.07 throw Error with gs &gt; 9.08&quot;<br>
-<br>
- commit 89c224b029357002c48660dae98de2d1e560d4e0 was applied to fix<br>
- bug #694276, and the fix was, I'm afraid, incorrect.<br>
-<br>
- The bug in question was a PDF file where the /Decode array was too long<br>
- (by 1 entry) for the actual colour space. This caused the PostScript<br>
- interpreter to (correctly) throw an error. Ray fixed this by altering<br>
- the PostScript interpreter so that it did not throw an error when the<br>
- Decode array was too long, but instead used the requisite number of<br>
- elements.<br>
-<br>
- This is not correct, the PostScirpt interpreter should throw an error.<br>
-<br>
- The file attached to this report is an EPS file which relies (horribly)<br>
- on getting an error when the Deocde array is too long for an image, and<br>
- uses that to call colorimage instead.<br>
-<br>
- By not throwing an error we treat the image as being in DeviceGray and,<br>
- since the data is actually RGB, only read 1/3 of the image data. We then<br>
- attempt to carry on from that point and throw real errors due to reading<br>
- from the middle of a data string.<br>
-<br>
- This commit reverts (significant) the changes in commit<br>
- 89c224b029357002c48660dae98de2d1e560d4e0. It also addresses the 'bug'<br>
- in report #694726 by shifting the checking to the PDF interpreter and<br>
- having that correctly set the decode array.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-psi/idparam.c<br>
-psi/zimage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-28 09:22:23 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5fa7596d8d467e98fbc069d11b7a3769f7d024f0">5fa7596d8d467e98fbc069d11b7a3769f7d024f0</a>
-<blockquote>
-<p>
- More fixes for tag plane problems.<br>
-<br>
- tests_private/comparefiles/Altona_Technical_v20_x4.pdf Page 7 had a<br>
- problem in blending when nos_knockout was true that ignored the tag.<br>
-<br>
- This also showed up cases where the alt_dev_color was not updated with<br>
- the tag (e.g. tests_private/comparefiles/0000728-simpleNG.pdf).<br>
-<br>
- Another difference that tests_private/comparefiles/Bug689761.pdf shows<br>
- is that &quot;gsave fill grestore stroke&quot; reverts the dev_color with grestore,<br>
- but doesn't change the dev-&gt;graphics_type_tag. Keep the tag in the<br>
- dev_color structure so that we know if the dev_color needs unset.<br>
-<br>
- Fix the ensure_tag_is_set inline function to make sure BOTH the device's<br>
- graphics_type_tag AND the dev_color.tag are set correctly.<br>
-<br>
- We need to write and read the pattern tag plane for raster patterns with<br>
- transparency. Seen with tests_private/comparefiles/Bug689422.pdf<br>
-<br>
- Lastly, the ensure_tag_is_set in gs_shfill needs to happen before the<br>
- remap_color (since it may unset the dev_color if the tag was different).<br>
-<br>
-base/gdevdsha.c<br>
-base/gdevp14.c<br>
-base/gscolor3.c<br>
-base/gsdcolor.h<br>
-base/gsdevice.c<br>
-base/gsht.c<br>
-base/gsptype1.c<br>
-base/gxblend1.c<br>
-base/gxdcolor.h<br>
-base/gxgstate.h<br>
-base/gxp1fill.c<br>
-base/gxpcmap.c<br>
-base/gxpcolor.h<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-18 09:38:17 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=35a5977484afecae01afc92f5018709feba6bc91">35a5977484afecae01afc92f5018709feba6bc91</a>
-<blockquote>
-<p>
- gs_fillpage should set the tag to UNTOUCHED, not PATH.<br>
-<br>
- This produces tag plane differences in areas that have transparency<br>
- that are painted (touched) in a transparency group since the page level<br>
- buffer will now have tag UNTOUCHED == 0 instead of PATH, so areas that<br>
- were PATH+TEXT or PATH+IMAGE can become just TEXT or IMAGE (which is<br>
- correct).<br>
-<br>
-base/gspaint.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-10 12:23:00 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=82ec3b5eef0a530666044dc94b6ba94ed9aa15b6">82ec3b5eef0a530666044dc94b6ba94ed9aa15b6</a>
-<blockquote>
-<p>
- Set color_info separable_and_linear for bitrgbtags device.<br>
-<br>
- Since this device is separable and linear, we can skip the testing in<br>
- check_device_separable and check_device_compatible_encoding. We can<br>
- safely set GX_CINFO_SEP_LIN_STANDARD since the low (color) bits are<br>
- compatible with the pdf14_encode_color_tag.<br>
-<br>
- This shows up many shading differences since the device was being<br>
- (incorrectly) classified as SEP_LIN_UNKNOWN which would then flatten<br>
- color patches and use fill_trapezoid rather than the preferred<br>
- fill_linear_color_trapezoid (the latter writes less data to the<br>
- clist).<br>
-<br>
-devices/gdevbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-20 14:34:43 -0400
-</strong>
-<br>Steve Phillips &lt;steve.phillips@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59c7840aea41253d274d9037b637e60c38359f9f">59c7840aea41253d274d9037b637e60c38359f9f</a>
-<blockquote>
-<p>
- Auto-generate opdfread.h from opdfread.ps during the build using packps tool<br>
-<br>
- This commit implements a new packps tool which converts PostScript files<br>
- to packed arrays of C strings, providing a method to compile PostScript<br>
- code directly into the executable. Using this tool, the opdfread.h<br>
- file is now derived from devices/vector/opdfread.ps.<br>
-<br>
- - The packps utility is built from the new file base/pack_ps.c.<br>
- - opdfread.ps has been moved from lib to /devices/vector. This is<br>
- now the reference file for the opdfread header procset code.<br>
- - opdfread.h has been removed from /devices/vector and is now built<br>
- within the DEVGEN directory as part of the make process.<br>
- - For Windows builds, a stale file reference to Resource\Init\opdfread.ps<br>
- has been removed from the project file. Additionally, a file reference<br>
- to opdfread.ps has been added to the /devices/vector source list, and<br>
- the reference to opdfread.h has been removed from the header file list.<br>
-<br>
-base/gs.mak<br>
-base/msvctail.mak<br>
-base/pack_ps.c<br>
-base/unix-aux.mak<br>
-base/unix-end.mak<br>
-devices/devs.mak<br>
-devices/vector/opdfread.h<br>
-devices/vector/opdfread.ps<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-20 13:42:31 -0400
-</strong>
-<br>Steve Phillips &lt;steve.phillips@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7daa44b70e213e704e0da53032a89bf56ff07e0a">7daa44b70e213e704e0da53032a89bf56ff07e0a</a>
-<blockquote>
-<p>
- Reconcile differences between opdfread.h and opdfread.ps<br>
-<br>
- This change reconciles all differences between devices/vector/opdfread.h<br>
- and lib/opdfread.ps so that they contain exactly the same PostScript code,<br>
- other than whitespace differences and comments. The opdfread.h file was<br>
- originally created through a one-time conversion of opdfread.ps to an array<br>
- of C strings, and opdfread.h is currently used as the reference code for<br>
- source builds. These two files have diverged slightly over time, so the<br>
- unused code in opdfread.ps was no longer up-to-date.<br>
-<br>
- In this commit, all differences between these two files have been reconciled<br>
- so that either the header file or the PostScript version can be used as the<br>
- reference copy. A subsequent commit will add a tool to derive opdfread.h<br>
- from opdfread.ps during the build process, which will use opdfread.ps as<br>
- the master copy instead. This commit ensures that this tool change will<br>
- not introduce any functional differences in the generated header file.<br>
-<br>
- For ease of comparison, all whitespace-only changes (removing spaces and<br>
- moving code to different lines) have been made in opdfread.h, so there are<br>
- no functional changes to this module.<br>
-<br>
- The changes to opdfread.ps resolve all remaining functional differences,<br>
- with opdfread.h used as the reference source for any changes.<br>
-<br>
- With these changes, the new packps tool converts opdfread.ps to a C<br>
- file which matches opdfread.h exactly, other than the header comments<br>
- at the top of the file.<br>
-<br>
-devices/vector/opdfread.h<br>
-lib/opdfread.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-20 13:57: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=18174668ea815c7830841a511f1dc850557772a9">18174668ea815c7830841a511f1dc850557772a9</a>
-<blockquote>
-<p>
- Scan converter: Remove 2 outdated asserts.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-20 12:31: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=53c1849dabf14941bc191506b6feaf2d6f7817cb">53c1849dabf14941bc191506b6feaf2d6f7817cb</a>
-<blockquote>
-<p>
- Add missing braces in scan converter code.<br>
-<br>
- The lack of these could cause memory overwrites when<br>
- DEBUG_SCAN_CONVERTER was enabled.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-20 11:57:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=13b97d2c1b4c8a819e0682047d044f9308a56174">13b97d2c1b4c8a819e0682047d044f9308a56174</a>
-<blockquote>
-<p>
- Initialise path bounding boxes.<br>
-<br>
- Bug #697770 &quot;Inconsistent behaviour&quot;<br>
-<br>
- The problem is that gx_path_init_bbox_accumulator() sets bbox_accurate<br>
- which is later used to signal that the attached bbox is valid and<br>
- accurate.<br>
-<br>
- But we don't actually initialise the bbox member at all, in the bug in<br>
- question the glyph has no contours, so creates no path, leaving the<br>
- bbox uninitialised. But because we have set bbox_accurate we just<br>
- copy the values when determining the font bounding box, leading to<br>
- insane values.<br>
-<br>
- Initialising the bbox gives more reasonable results.<br>
-<br>
-base/gxpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-19 12:06:39 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8210a2864372723b49c526e2b102fdc00c9c4699">8210a2864372723b49c526e2b102fdc00c9c4699</a>
-<blockquote>
-<p>
- Bug 697762: Fix scan converter SEGVs.<br>
-<br>
- The SEGVs are caused by the scan converter allowing less room<br>
- in the table than is actually required. This happens due to<br>
- the mark_curve subdivision overflowing.<br>
-<br>
- For example, if we have a curve such as:<br>
-<br>
- 0 0x80000000 moveto<br>
- 0 0x80000000 0 0x80000000 0 0x80000000 curveto<br>
-<br>
- Then the current subdivision logic does:<br>
-<br>
- fixed ay = (sy + c1y)&gt;&gt;1<br>
-<br>
- For sy = c1y = 0x80000000 this gives ay = 0, when clearly<br>
- the average should be 0x80000000.<br>
-<br>
- An alternative formulation of the splitting code:<br>
-<br>
- fixed ay = (sy&gt;&gt;1) + (c1y&gt;&gt;1)<br>
-<br>
- gives the required result, at the expense of dropping accuracy at<br>
- the low end.<br>
-<br>
- This commit therefore has 2 formulations of the splitting code, one<br>
- for 'big' values (values that might overflow), and ones for normal<br>
- values (values that won't).<br>
-<br>
- We select between the two pieces of code by comparing the top 2<br>
- bits of each value; if they differ, then we use the big variant.<br>
-<br>
- Also, when calculating the size of the table required, we were<br>
- incorrectly closing the curve more often than we needed to. This<br>
- had no ill effect other than inflating the amount of memory we<br>
- needed.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-18 12:37:21 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0f598a2c56f2ccec4ecf67f8f585a340b04057ef">0f598a2c56f2ccec4ecf67f8f585a340b04057ef</a>
-<blockquote>
-<p>
- PDF interpreter - detect missing 'endobj' on final object in file<br>
-<br>
- Bug #697761 &quot; Broken PDF (missing endobj on final object) causes error&quot;<br>
-<br>
- The sample file has the final two objects (Info and Catalog dictionaries)<br>
- written with missing 'endobj' Our normal processing catches that in the<br>
- body of the file, but if its the final object, then we carried on and<br>
- tried to process the entire trailer and xref.<br>
-<br>
- Add 'xref' to the entries in resolveopdict and treat it as a missing<br>
- endobj. While we're here, add an error message for the case of detecting<br>
- an 'obj' when resolving an object. We already handle that, but we<br>
- weren't producing an error for it.<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-17 15:41:11 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3e7e5272faf866419473a7c8e0149028bdfb4add">3e7e5272faf866419473a7c8e0149028bdfb4add</a>
-<blockquote>
-<p>
- MSVC: Fix x64 'All' configuration.<br>
-<br>
-windows/GhostPDL.sln<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-15 14:33: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=43ed8ae1ce7e254866d443176e48c9ca6787db35">43ed8ae1ce7e254866d443176e48c9ca6787db35</a>
-<blockquote>
-<p>
- subclassing devices - process the graphics_type_tag into all chained devices<br>
-<br>
- The tag devices encode the type of operation into the device color, if<br>
- the devices graphics_type_tag has the GS_DEVICE_ENCODES_TAGS bit set.<br>
-<br>
- The specific tag is maintained by altering the graphics_type_tag in the<br>
- device structure using a device method (set_graphics_type_tag). However,<br>
- when checking to see if the tag needs to change (for a different marking<br>
- operation type), the code does not, as might be expected, use a<br>
- symmetric device method such as get_graphics_type_tag. It was felt that<br>
- the performance impact would be unacceptable. Instead the<br>
- graphics_type_tag of the *current* device in the graphics state is<br>
- inspected directly from the structure.<br>
-<br>
- This means that every device chaining method (and there are several,<br>
- see ghostpdl/doc/subclass.htm) needs to ensure that every device in<br>
- the chain sets its graphics_type_tag in the device structure, *and*<br>
- passes that on to any underlying devices.<br>
-<br>
- Apparently the 'forwarding' devices already do this, I presume the clist<br>
- and transparency compositors do as well, I haven't checked. The obselete<br>
- 'device filter chain' does not, the subclassing devices did not either.<br>
-<br>
- Its also important (for pattern colour spaces) that we track the tag<br>
- even when we are not actually rendering.<br>
-<br>
- So here we remove the code from the First/Last page device which skipped<br>
- tags on elided pages. This means the device can instead use the standard<br>
- subclassing default method.<br>
-<br>
- In the standard subclassing default method we now update the tag on the<br>
- current device in the chain before passing it on to the next device.<br>
- This means that all devices in the chain now track the tag. An important<br>
- note for any subclassing devices which implement a set_graphics_type_tag<br>
- method is that it must set the tag in its device structure. So we document<br>
- that as well.<br>
-<br>
-base/gdevflp.c<br>
-base/gdevsclass.c<br>
-doc/subclass.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-14 14:19:53 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22d8a2653ae532c7c23aa9a441e6c120edd9bdef">22d8a2653ae532c7c23aa9a441e6c120edd9bdef</a>
-<blockquote>
-<p>
- Add back icc support for PNG output<br>
-<br>
- When the png library was updated, the embedded ICC profile<br>
- was no longer getting written. This fixes the issue as<br>
- well as fixes a minor issue in our setting of D50 in the<br>
- resource ICC profiles which prompted a warning from the<br>
- PNG library.<br>
-<br>
-devices/gdevpng.c<br>
-iccprofiles/default_cmyk.icc<br>
-iccprofiles/default_rgb.icc<br>
-iccprofiles/gray_to_k.icc<br>
-iccprofiles/lab.icc<br>
-iccprofiles/ps_cmyk.icc<br>
-iccprofiles/ps_gray.icc<br>
-iccprofiles/ps_rgb.icc<br>
-iccprofiles/srgb.icc<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-13 16:01: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=6d65aaa8af3a9f56c1828e7943c6e1c8b93cf614">6d65aaa8af3a9f56c1828e7943c6e1c8b93cf614</a>
-<blockquote>
-<p>
- PCL - remove the 'bias' from glyph indices before use, if present<br>
-<br>
- Bug #697744 &quot;Accents not handled correctly&quot;<br>
-<br>
- In plfont.c, pl_glyph_name, we use the 'glyph' (which is of type<br>
- gs_glyph) as an index to retrieve a glyph name from a TrueType font.<br>
-<br>
- However, as per the documentation in gsccode.h, if the glyph is truly<br>
- an index (as opposed to a name) then it is biased by GS_MIN_GLYPH_INDEX<br>
- which means that attempting to use it directly as an index into the font<br>
- fails, and returns no name.<br>
-<br>
- This causes pdfwrite multiple problems; firstly it causes the original<br>
- glyph to be rendered as a bitmap. Then, because the glyph is a composite<br>
- glyph (its made up of two or more other glyphs) subsequent uses of the<br>
- same glyph cause it to become confused, and use the initail component<br>
- glyph.<br>
-<br>
- This can be easily resolved simply by testing to see if the glyph is<br>
- biased by GS_MIN_GLYPH_INDEX and, if it is, removing the bias.<br>
-<br>
- In addition to fixing the reported problem a number of test suite files<br>
- show progressions (accents now present) and small but useful quality<br>
- improvements (glyphs no longer rendered as bitmaps) as well as being<br>
- able to properly extract text from either the PCL or the output PDF file.<br>
-<br>
-pcl/pl/plfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-12 16:02: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=c90836f3782ce8e8f3076cb8b50503cfe91dabcf">c90836f3782ce8e8f3076cb8b50503cfe91dabcf</a>
-<blockquote>
-<p>
- (e)ps2write - use correct encoding for subset TrueType fonts<br>
-<br>
- Bug #697733 &quot;Character section is not handled with eps2write&quot;<br>
-<br>
- We carry around a 'base encoding' with fonts, which is generally the<br>
- encoding of the original font, potentially 'refined' to a more useful<br>
- encoding if its originally one we can't use.<br>
-<br>
- For TrueType fonts, we would either Standard or ISOLatin1, and in fact<br>
- almost always StandardEncoding.<br>
-<br>
- The problem is that if we are subsetting the font, then we *don't* embed<br>
- the original font's CMAP subtable, we generate a new pair, one of Windows<br>
- Unicode (3,1) and one of Mac Roman (1,0). Neither is suitable for use<br>
- with StandrdEncoding and in fact the opdfread code will always use the<br>
- MacRoman Encoding.<br>
-<br>
- This can lead to a problem if the same glyph name is encoded in one or<br>
- other Encodings, and is either missing or in a in a different position<br>
- in the other.<br>
-<br>
- When we encode the string we will use StandardEncoding, and the opdfread<br>
- code will read the character codes using MacRoman Encoding, so the<br>
- Charstrings dictionary will be incorrectly constructed and glyphs will<br>
- either become notdef or potentially use the wrong glyph.<br>
-<br>
- To fix it; if we have a TrueType font, and are subsetting it, select<br>
- a Base Encoding of MacRoman. Update the refine_encoding procedure to<br>
- permit a TrueType fotn to have MacRoman encoding.<br>
-<br>
- This shows a minor progression in one file in the test suite;<br>
- Bug691848.ps, surprisingly with Kanji text.....<br>
-<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-11 14:55: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=e90c8f5a93e274b02b7e25762ef83995455f8464">e90c8f5a93e274b02b7e25762ef83995455f8464</a>
-<blockquote>
-<p>
- Yet another fix for tag handling that affects shading fills and pdf14<br>
-<br>
- The comp_shift that is relied upon for color generation in fill_linear<br>
- color_scanline did not work because the comp_shift[num_components] was<br>
- not set for the pdf14 device when the device &quot;has_tags&quot;.<br>
-<br>
- Also fix a bunch of whitespace variances.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-07 18:39:58 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba92812e5a25c3c1f8d13c79e584398d2250b72a">ba92812e5a25c3c1f8d13c79e584398d2250b72a</a>
-<blockquote>
-<p>
- Scan Converter: Speed tweak to sorting.<br>
-<br>
- When sorting the intersects on a scanline, if the list is short<br>
- use inline sort code, rather than calling qsort. This is a big<br>
- saving in runtime, presumably due to function call overhead.<br>
-<br>
- This reduces the bug 697678 time from 40 seconds to 35.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-10 18:10:32 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=31aefb5777a72c54363685498c07f2cd00867525">31aefb5777a72c54363685498c07f2cd00867525</a>
-<blockquote>
-<p>
- Scan converter: Simplify edgecmp comparison.<br>
-<br>
- It *shouldn't* matter the order we treat up/down edges in,<br>
- therefore, it shouldn't matter if we alter our sort routine<br>
- to actually care about the bottom bits. This results in<br>
- simpler (and hence, hopefully, faster) code.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-07 18:15: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=9eb97696875fb97b08321aba009c14419a4feeba">9eb97696875fb97b08321aba009c14419a4feeba</a>
-<blockquote>
-<p>
- Tweak make_table for speed.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-10 18:47: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=81385210e0d484050ee6ed7898b03ebcc5105ba1">81385210e0d484050ee6ed7898b03ebcc5105ba1</a>
-<blockquote>
-<p>
- Scan converter: Fix double written pixels<br>
-<br>
- The any part of a pixel (non trap) code could occasionally double<br>
- write some pixels. Fixed here.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-10 18:09: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=bc739b046c0490e5ab941ef2942eadac37a2ce13">bc739b046c0490e5ab941ef2942eadac37a2ce13</a>
-<blockquote>
-<p>
- Squash a float &lt;-&gt; double warning.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-10 18:05:44 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e16d0c760651b973d5a750524cf9e69df8601256">e16d0c760651b973d5a750524cf9e69df8601256</a>
-<blockquote>
-<p>
- MSVC: Profile builds. Ensure linker optimisations are enabled<br>
-<br>
- /DEBUG disables optimisations, so add /OPT:REF and /OPT:ICF to<br>
- reenable them.<br>
-<br>
-base/msvccmd.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-07 18:06: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=74f9d86d60c8ded49d0df2c23bec2d68fea1f6b5">74f9d86d60c8ded49d0df2c23bec2d68fea1f6b5</a>
-<blockquote>
-<p>
- Revert &quot;gs_malloc_memory_t: change type of limit/used/max_used&quot;<br>
-<br>
- This reverts commit 47417a5cbfbfa3d7bb9ee387909246cdd265d4ff.<br>
-<br>
- Until I can debug the errors is causes on Windows.<br>
-<br>
-base/gsalloc.c<br>
-base/gsmalloc.c<br>
-base/gsmalloc.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-07 15:09:29 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1cd00def041e82e66e2ea12a153801552b64246e">1cd00def041e82e66e2ea12a153801552b64246e</a>
-<blockquote>
-<p>
- Squash warning.<br>
-<br>
- ./base/gsfont.c:1006:12: warning: overflow in implicit constant conversion [-Woverflow]<br>
-<br>
-base/gsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-07 13:15:46 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9eae07a45a76f8944d7fbfe1fb4546f473fcf400">9eae07a45a76f8944d7fbfe1fb4546f473fcf400</a>
-<blockquote>
-<p>
- Further scan converter work inspired by Bug 697678<br>
-<br>
- This applies the same changes done for the any-part-of-a-pixel,<br>
- trapezoid case to the any-part-of-a-pixel non-trapezoid case.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-05 17:56:14 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f158bfa0346833ac2181bc66709cfabff1a12afc">f158bfa0346833ac2181bc66709cfabff1a12afc</a>
-<blockquote>
-<p>
- Further work inspired by Bug 697678<br>
-<br>
- Apply the same speedups for vertically clipped paths as have already<br>
- been done for the any-part-of-a-pixel, trapezoid case to the<br>
- centre-of-a-pixel cases.<br>
-<br>
- The any-part-of-a-pixel, non-trapezoid case remains to be done.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-06 08:46:20 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ee57023920599a2209e5e0b7eded2ae9c2002e19">ee57023920599a2209e5e0b7eded2ae9c2002e19</a>
-<blockquote>
-<p>
- Fix error in color updating<br>
-<br>
- Ray found an issue that would appear to cause problems when we have<br>
- transparency and spot colors for the separations devices.<br>
- The mask and shift values in color info were not getting set properly<br>
- for the spot colors in this case. It is not a real issue<br>
- due to the way that the separation device colors are<br>
- stored in the devn hl color (planar) but is good to fix<br>
- to avoid confusion.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-04 14:43: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=47417a5cbfbfa3d7bb9ee387909246cdd265d4ff">47417a5cbfbfa3d7bb9ee387909246cdd265d4ff</a>
-<blockquote>
-<p>
- gs_malloc_memory_t: change type of limit/used/max_used<br>
-<br>
- The limit, used and max_used values in gs_malloc_memory_t were type ulong,<br>
- giving rise to differences between LP64 systems (Unix-like) and LLP64 systems<br>
- (MS Windows).<br>
-<br>
- So, make them uint64_t for consistency across platforms.<br>
-<br>
-base/gsalloc.c<br>
-base/gsmalloc.c<br>
-base/gsmalloc.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-06 16:44: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=bfa6b2ecbe48edc69a7d9d22a12419aed25960b8">bfa6b2ecbe48edc69a7d9d22a12419aed25960b8</a>
-<blockquote>
-<p>
- Bug 697548: use the correct param list enumerator<br>
-<br>
- When we encountered dictionary in a ref_param_list, we were using the enumerator<br>
- for the &quot;parent&quot; param_list, rather than the enumerator for the param_list<br>
- we just created for the dictionary. That parent was usually the stack<br>
- list enumerator, and caused a segfault.<br>
-<br>
- Using the correct enumerator works better.<br>
-<br>
-psi/iparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-31 13:36:03 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=063416192c169889ef0b227aab5d912f71640590">063416192c169889ef0b227aab5d912f71640590</a>
-<blockquote>
-<p>
- Fix gx_default_fill_linear_color_scanline to handle tags.<br>
-<br>
- The fill_linear_color_scanline would calculate linear and separable colors<br>
- based on the num_components, which does not include the tags, leaving the<br>
- tag value set to 0 (GS_UNTOUCHED_TAG). If the device does need tags<br>
- (GS_DEVICE_ENCODES_TAGS set) then set the tag value using the last comp_shift<br>
- to GS_PATH_TAG. Seen with Ghent_V5.0/GWG010_CMYK_OP_x3.pdf and the<br>
- bitrgbtags device in clist mode.<br>
-<br>
-base/gdevdsha.c<br>
-base/gxdevcli.h<br>
-devices/gdevbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-05 11:42:30 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9c711b79f1230cbbd346d1cbf7e9bcaa701d2e4c">9c711b79f1230cbbd346d1cbf7e9bcaa701d2e4c</a>
-<blockquote>
-<p>
- Scan converter optimisations<br>
-<br>
- Optimise unneeded writes when updating the cursor.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-05 12:28:20 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d90f7b0782b74201cbca8e40e02800453a48a873">d90f7b0782b74201cbca8e40e02800453a48a873</a>
-<blockquote>
-<p>
- Attempt to fix warning.<br>
-<br>
- ./base/gsccode.h:29:20: warning: overflow in implicit constant conversion<br>
-<br>
-base/gsccode.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-05 10:38:16 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=25c8f788cf15829adb5f1e3292f46f9ca9a1c329">25c8f788cf15829adb5f1e3292f46f9ca9a1c329</a>
-<blockquote>
-<p>
- Fix scan converter issues.<br>
-<br>
- Commit edba51f (&quot;Bug 697678: Scan converter performance (out of<br>
- range lines).&quot; caused 3 SEGVs in the normal tests, but caused<br>
- many many more in the overnights.<br>
-<br>
- This commit fixes those. The problems were due to edge effects<br>
- on the top/bottom of the edgebuffers, due to differences in<br>
- the logic for rising/falling lines.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-29 11:08:03 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ac125ce3320aeb3888c18805cd12136d3e1ebfc7">ac125ce3320aeb3888c18805cd12136d3e1ebfc7</a>
-<blockquote>
-<p>
- Fix a problem with tags not being set in dev_color<br>
-<br>
- When the tag is changed, we need to unset the dev_color so that the<br>
- device's encode_color gets called to apply the correct tag. Seen with<br>
- the bitrgbtags device and the file: tests/pdf/Bug691997.pdf<br>
-<br>
- Also, fix a problem with the hit_detect device (infill PS operator).<br>
- If the dev_color is unset in the fill or stroke operation, it would<br>
- attempt to remap the dev_color which would fail because the hit detect<br>
- device doesn't have a device profile. This sets the grapchis_type_tag<br>
- to GS_PATH_TAG so that fill and stroke don't unset (and subsequently<br>
- remap in gx_set_dev_color) the dev_color.<br>
-<br>
-base/gdevddrw.c<br>
-base/gdevnfwd.c<br>
-base/gdevp14.c<br>
-base/gscolor3.c<br>
-base/gsdps1.c<br>
-base/gsimage.c<br>
-base/gspaint.c<br>
-base/gstext.c<br>
-base/gxclrast.c<br>
-base/gxdevcli.h<br>
-base/gxgstate.h<br>
-base/gxpcmap.c<br>
-psi/zupath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-04-04 11:37: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=ddb63fcf10ce51416f0921dbb0f7b0dee3cf3849">ddb63fcf10ce51416f0921dbb0f7b0dee3cf3849</a>
-<blockquote>
-<p>
- PDF interpreter - don't remove Filters from streams declared as 0 Length<br>
-<br>
- No bug number for this, the problem arose from a Stack Overflow<br>
- question here http://stackoverflow.com/questions/43149372/repairing-pdfs-with-damaged-xref-table/43154410?noredirect=1#comment73447166_43154410<br>
-<br>
- The PDF file is multiply broken, it has invalid xref entries and each<br>
- page is an image XObject whose dictionary has an indirect object for<br>
- the /Length entry. In every case the Length is defined as 0.<br>
-<br>
- For some obscure reason, sometime in the past someone added code to<br>
- remove the /Filter entry from the dictionary when a stream has a<br>
- declared Length of 0. I have no idea why, if the stream is compressed<br>
- or encoded then removing the Filter can have no useful effect. But<br>
- if the Filter is left in place we can still recover from an invalid<br>
- Length declaration, provided we properly decode the stream, which<br>
- obviously requires us to install the correct Filter(s).<br>
-<br>
- So here we simply remove the code which undefines the Filter in the<br>
- stream dictionary.<br>
-<br>
- cluster runs show no differences.<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-30 14:18:11 +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=ea5389d2ff12797df9a1fd932f499223460a3808">ea5389d2ff12797df9a1fd932f499223460a3808</a>
-<blockquote>
-<p>
- Bug 697545: Memory Squeezing fix font cache leak.<br>
-<br>
- Fix font cache leak when memory squeezing:<br>
-<br>
- gs -sDEVICE=bit -o /dev/null: examples/tiger.eps<br>
-<br>
-base/gsfont.c<br>
-devices/vector/gdevpdf.c<br>
-pcl/pcl/pcfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-28 22:56: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=9fbb9d8695deecfe937ffdd91b9bd69613c1c8df">9fbb9d8695deecfe937ffdd91b9bd69613c1c8df</a>
-<blockquote>
-<p>
- Bug 697545: Memory Squeezing fix leaks in swproc.<br>
-<br>
- Fix memory leaks in swproc when memory squeezing:<br>
-<br>
- gs -sDEVICE=bit -o /dev/null: examples/tiger.eps<br>
-<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-29 20:31: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=5499169177746ec62d8440f193be418999f156d4">5499169177746ec62d8440f193be418999f156d4</a>
-<blockquote>
-<p>
- Change GS_UNTOUCHED_TAG to 0 and GS_UNKNOWN_TAG to 0x40<br>
-<br>
- This is mostly arbitrary, but it sort of makes more sense that UNTOUCHED<br>
- be 0 so any marking operation can just OR tag bits into the tag plane or<br>
- color (e.g. gdevp14.c).<br>
-<br>
- This will change ALL bitrgbtags regression results.<br>
-<br>
-base/gdevp14.c<br>
-base/gscms.h<br>
-base/gxblend1.c<br>
-base/gxdevice.h<br>
-devices/gdevbit.c<br>
-lib/viewpbm.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-29 19:26:50 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=edba51f4647f56b3559451f5fdbfbde04bc87828">edba51f4647f56b3559451f5fdbfbde04bc87828</a>
-<blockquote>
-<p>
- Bug 697678: Scan converter performance (out of range lines).<br>
-<br>
- This significantly improves the timings.<br>
-<br>
- Essentially, if we were rendering just a band of a page (say from<br>
- Y1 to Y2) and the line extended beyond that (say from Y0 to Y3,<br>
- where Y0 &lt; Y1 or Y2 &lt; Y3), we'd have run the bresenham for the<br>
- entire range rather than for just the section we needed to.<br>
-<br>
- This was particularly problematic in the example file due to the<br>
- use of a clipping device, meaning that we were repeatedly<br>
- scan converting lines in 1 pixel high regions.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-29 20:36:04 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0fe78bcd5eb6cc919e6b0a97aadb6f9259176bc8">0fe78bcd5eb6cc919e6b0a97aadb6f9259176bc8</a>
-<blockquote>
-<p>
- Tweak bmpcmp to better handle tags.<br>
-<br>
-toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-29 21:04: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=7dbcd5da85934c9e437c557c359556f3c67b48d5">7dbcd5da85934c9e437c557c359556f3c67b48d5</a>
-<blockquote>
-<p>
- Scan converter: Fix restrict in prototypes.<br>
-<br>
- Forgot to change the prototypes while adding restrict.<br>
-<br>
-base/gxscanc.c<br>
-base/gxscanc.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-29 11:55:40 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d6903654402789d60bff227fd916a368991ef3eb">d6903654402789d60bff227fd916a368991ef3eb</a>
-<blockquote>
-<p>
- Scan converter: Special case vertical lines.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-29 11:55: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=df5be672c357ffc884d0b2f0b7a890e1783ed402">df5be672c357ffc884d0b2f0b7a890e1783ed402</a>
-<blockquote>
-<p>
- Remove unnecessary assignments from scan converter<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-28 19:32:26 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2342e8533bf55a39226e0c99e75c9d2aae3b3d6b">2342e8533bf55a39226e0c99e75c9d2aae3b3d6b</a>
-<blockquote>
-<p>
- Tweak Scan Converter.<br>
-<br>
- Mark pointers as restricted to try to alleviate aliasing.<br>
-<br>
- Use static inlines for speed.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-28 09:12:05 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=93e2557fb36f69310b7f325c70203ae063ef1fae">93e2557fb36f69310b7f325c70203ae063ef1fae</a>
-<blockquote>
-<p>
- Fix clist file to invalidate the read cache upon writing (see bug 697689).<br>
-<br>
- This fixes the unknownerror reported by the bug, but does not totally fix<br>
- the use of # false .outputpage with the clist since the data after the<br>
- first cmd_opv_end_page is not rendered to the page (stops the clist reader).<br>
- The bug is left open for that reason and has been marked bountiable.<br>
-<br>
-base/gxclfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-24 17:32:14 +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=fa6f17de62fd27cef4005f336afcd1ac656dc9af">fa6f17de62fd27cef4005f336afcd1ac656dc9af</a>
-<blockquote>
-<p>
- Bug 697545: Memory Squeezing fix i_register_root leaks.<br>
-<br>
- Fix memory leak for i_register_root allocation when memory squeezing:<br>
-<br>
- gs -sDEVICE=bit -o /dev/null: examples/tiger.eps<br>
-<br>
-base/gsiodev.c<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-psi/imain.c<br>
-psi/zfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-23 09:20: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=2eab4ad4d3e861e8e39a10ba58cfdb217b32db78">2eab4ad4d3e861e8e39a10ba58cfdb217b32db78</a>
-<blockquote>
-<p>
- Remove a pointless typedef<br>
-<br>
-base/gsmemory.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-27 09:38: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=c06135acc959dbc0458352579bafe238794f2733">c06135acc959dbc0458352579bafe238794f2733</a>
-<blockquote>
-<p>
- pdfwrite - don't try to allocate a 0 length buffer for metadata<br>
-<br>
- Bug #697684 &quot;Regression - Ghostscript 9.21 fails when pdfmark contains certain Unicode characters&quot;<br>
-<br>
- Under some conditions, specifying a 0 length buffer size when calling<br>
- gs_alloc_bytes() can return a NULL pointer. Since we use a NULL return<br>
- to indicate a failure to allocate a buffer, this results in a VM error.<br>
-<br>
- In this commit we check the data length and don't try to allocate or<br>
- use a 0 length buffer.<br>
-<br>
- We'll tackle the allocation problem separately, it would be better if<br>
- gs_alloc_bytes didn't return a NULL pointer.<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-24 11:47: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=0d21a58ab12b9584faa54baa48ce0dab350af53e">0d21a58ab12b9584faa54baa48ce0dab350af53e</a>
-<blockquote>
-<p>
- jbig2dec - refine test for &quot;Denial of Service&quot; images<br>
-<br>
- Bug 697682 &quot;Incorrectly displayed a PDF file on GSView, MuPDF and GhostScript&quot;<br>
-<br>
- In commit 7366747076f3b75def52079bd4d5021539a16394 Simon introduced a<br>
- test to try and detect a JBIG2 compressed image which would take an<br>
- unreasonable amount of time to process. Unfortunately, the test also trips<br>
- up this real world (if rather extreme) example.<br>
-<br>
- The test looks for an image to be &gt; 16MB and for the segment being<br>
- processed to contain less than 1/256 of the image data. However, since<br>
- we use this same section for symbol decoding, the segment size can be<br>
- considerably smaller than that, and still be legal.<br>
-<br>
- This commit alters the image size to 64MB (as this is, frankly, ridiculously<br>
- large for a JBIG2 image) and for the segment size to be less than<br>
- 1/65536 of the total image data. This means that images less than 64MB,<br>
- with segments larger than ~1KB might still cause a DOS, but this seems<br>
- to be simply a problem we have to accept.<br>
-<br>
- Since the DOS time is dependent on the size of the data, and the size<br>
- of the segment, this is a compromise.<br>
-<br>
-jbig2dec/jbig2_generic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-23 19:36:43 +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=eb6ebd779b24cf36ac8dd13e3553c9b262235b37">eb6ebd779b24cf36ac8dd13e3553c9b262235b37</a>
-<blockquote>
-<p>
- Bug 697545: Memory Squeezing fix events 244 to 267<br>
-<br>
- Fix memory leaks for allocation event number 244 to 267<br>
- when memory squeezing:<br>
-<br>
- gs -sDEVICE=bit -o /dev/null: examples/tiger.eps<br>
-<br>
- Setting the init_done level earlier in gs_main_init1 means that the<br>
- existing code in gs_main_finit will clean up after any failures in<br>
- i_plugin_init and i_iodev_init.<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-21 22:38:44 +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=6dd92923afc2779975c0c7a128bb12ed92c263ba">6dd92923afc2779975c0c7a128bb12ed92c263ba</a>
-<blockquote>
-<p>
- Bug 697545: Memory Squeezing updated fix for events 10 to 33<br>
-<br>
- Fix memory leaks for allocation event number 10 to 33<br>
- when memory squeezing:<br>
-<br>
- gs -sDEVICE=bit -o /dev/null: examples/tiger.eps<br>
-<br>
-psi/ialloc.c<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-21 17:50:14 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa182eb185494fae17731f426fb3307d7feda4f0">fa182eb185494fae17731f426fb3307d7feda4f0</a>
-<blockquote>
-<p>
- Bug 697681: fix shared lib build with openjpeg &gt;= 2.1.1<br>
-<br>
- In 2.1.1 openjpeg extended the use of the OPJ_STATIC to use gcc attributes to<br>
- hide certain functions, as well as the previous use of preventing the<br>
- inclusion of the Windows DllMain function.<br>
-<br>
- As we (in Ghostscript) need the functions the OPJ_STATIC on Linux/Unix hides,<br>
- only set the flag for Windows builds.<br>
-<br>
-base/lib.mak<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-21 17:59:12 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c17c7bbaad9002b38f4881497fc3ce3cc4eb64e6">c17c7bbaad9002b38f4881497fc3ce3cc4eb64e6</a>
-<blockquote>
-<p>
- Add capability to sign the nsis installer exe<br>
-<br>
- On the nmake command line or in the evironment, it requires the following<br>
- variables to be set:<br>
- KEYFILE - pfx file containing the key<br>
- KEYPWORD - password for using the above key file<br>
- TIMESTAMP - URL for the timestamp server<br>
-<br>
-psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-21 15:45:34 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a0e27403bbb991f5a541d39122a92505afb0d1dc">a0e27403bbb991f5a541d39122a92505afb0d1dc</a>
-<blockquote>
-<p>
- Fix the shared openjpeg build<br>
-<br>
-base/sjpx_openjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-21 12:01: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=b8b1d543fe833478c167940110e04ddc353d0f3b">b8b1d543fe833478c167940110e04ddc353d0f3b</a>
-<blockquote>
-<p>
- Bug 697677: fix support for --disable-openjpeg<br>
-<br>
-base/lib.mak<br>
-base/sjpx_none.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-20 09:04:31 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59d8b2e95d2acd2b7e3f86809fa9ebe8ea7eeb8d">59d8b2e95d2acd2b7e3f86809fa9ebe8ea7eeb8d</a>
-<blockquote>
-<p>
- Move invalid_file_stream into gc memory.<br>
-<br>
- At initialisation we create an special stream (in the gs context) to use as an<br>
- invalid stream whenever we need one.<br>
-<br>
- It was originally being allocated in non-gc memory. Since the context is in<br>
- gc memory, the invalid_file_stream can leak. Rather than add explicit freeing<br>
- of the invalid_file_stream, and risk a life span conflict between a gc object<br>
- and a non-gc object, it makes it neater, and more sense, to keep the<br>
- invalid_file_stream in gc memory. It *is* stable memory (not subject to<br>
- save/restore) and allocated as an immovable object (not subject to relocating<br>
- by the garbager).<br>
-<br>
- Fixes a problem spotted by Shailesh Mistry while working on memory squeezing<br>
- event 170.<br>
-<br>
-psi/icontext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-20 09:34:11 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=309eca4e0a31ea70dcc844812691439312dad091">309eca4e0a31ea70dcc844812691439312dad091</a>
-<blockquote>
-<p>
- Ensure a device has raster memory, before trying to read it.<br>
-<br>
- Bug #697676 &quot;Null pointer dereference in mem_get_bits_rectangle()&quot;<br>
-<br>
- This is only possible by abusing/mis-using Ghostscript-specific<br>
- language extensions, so cannot happen in a general PostScript program.<br>
-<br>
- Nevertheless, Ghostscript should not crash. So this commit checks the<br>
- memory device to see if raster memory has been allocated, before trying<br>
- to read from it.<br>
-<br>
-base/gdevmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-29 17:08:58 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd5da2cb3e08398ac6d86598b36b00994d058308">dd5da2cb3e08398ac6d86598b36b00994d058308</a>
-<blockquote>
-<p>
- Make the edgebuffer scan converter the default.<br>
-<br>
- Selecting the new (edgebuffer) scan converter (as is now the<br>
- default) has the effect of forcing the fill adjust values to<br>
- be 0 or 0.5.<br>
-<br>
-base/gslibctx.h<br>
-base/gsstate.c<br>
-base/gsstate.h<br>
-base/gxfill.c<br>
-pcl/pcl/pctop.c<br>
-psi/zmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-16 18:27: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=c4bff06c6c527af4cdddc2bd4cbd6fef8ffa4e22">c4bff06c6c527af4cdddc2bd4cbd6fef8ffa4e22</a>
-<blockquote>
-<p>
- Set tags correctly for glyphs when sent as masked images.<br>
-<br>
- In gx_image_cached_char we can end up sending the glyph as<br>
- an imagemask. When we do so, the tag is incorrectly reset<br>
- to image, rather than text.<br>
-<br>
- Here we correct that by adding an 'image_is_text' flag to<br>
- gs_image_init and gs_image_begin_typed.<br>
-<br>
- This can be seen by the fact that:<br>
-<br>
- gs -sDEVICE=bitrgbtags -o out.bit -r600 -dMaxBitmap=1000<br>
- tests_private/customer_tests/jw202dwo.pcl<br>
-<br>
- and<br>
-<br>
- gs -sDEVICE=bitrgbtags -o out.bit -r600 -dMaxBitmap=400000000<br>
- tests_private/customer_tests/jw202dwo.pcl<br>
-<br>
- give different tag values for the text.<br>
-<br>
-base/gsimage.c<br>
-base/gsimage.h<br>
-base/gsptype1.c<br>
-base/gxccache.c<br>
-base/gxfapi.c<br>
-pcl/pcl/pctext.c<br>
-pcl/pcl/rtraster.c<br>
-pcl/pl/pldraw.c<br>
-psi/zimage.c<br>
-psi/zimage2.c<br>
-xps/xpsimage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-06 10:31:53 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=66361d261c6cdcf4d01463ac9d1d769951a32bed">66361d261c6cdcf4d01463ac9d1d769951a32bed</a>
-<blockquote>
-<p>
- Bring master up to date with 9.21 release branch<br>
-<br>
- Update copyrights in &quot;top&quot; makefiles<br>
-<br>
- Update dates and versions<br>
-<br>
- Update News.html and History9.htm<br>
-<br>
- with highlights and changelogs<br>
-<br>
- Date and product string for 9.21 release<br>
-<br>
- Changelog and News + date for 9.21 release<br>
-<br>
- Dates for 9.21 release<br>
-<br>
-Makefile.in<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/Xfonts.htm<br>
-doc/gs-vms.hlp<br>
-doc/sample_downscale_device.htm<br>
-doc/thirdparty.htm<br>
-man/dvipdf.1<br>
-man/font2c.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>
-man/wftopfa.1<br>
-psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-16 15:57:47 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4237b0bc1155a781de80c0079d72c0bcdacbb95e">4237b0bc1155a781de80c0079d72c0bcdacbb95e</a>
-<blockquote>
-<p>
- Remove two erroneous uses of return_error<br>
-<br>
-psi/idisp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-16 07:54: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=ec32c674469fab173c6df5e97bc3f3aff37e6c92">ec32c674469fab173c6df5e97bc3f3aff37e6c92</a>
-<blockquote>
-<p>
- Fix SEGV with tiffsep1 device found by customer 531.<br>
-<br>
- When &quot;warning_given&quot; was set, the device was cast to tiffsep_device,<br>
- but the parameter was in a different offset with the tiffsep1_device.<br>
- Move the warning_given to the tiffsep_devices_common part of the structure<br>
- so the casting works properly.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-15 14:15:00 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6cd467ecdb2678847670fd22a0d5dd39b89e8ca3">6cd467ecdb2678847670fd22a0d5dd39b89e8ca3</a>
-<blockquote>
-<p>
- Tweak code in gxfapi.c to avoid repetition.<br>
-<br>
-base/gxfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-15 19:04:13 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8ad42f17df0c9e7afe25f95ecfae8fd005ac589c">8ad42f17df0c9e7afe25f95ecfae8fd005ac589c</a>
-<blockquote>
-<p>
- Fix typo.<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-15 19:38:32 +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=e146bb38c20e5b967d89e16db244b2beb74ba345">e146bb38c20e5b967d89e16db244b2beb74ba345</a>
-<blockquote>
-<p>
- Bug 697545: Memory squeezing SEGV event in gstate_clone<br>
-<br>
- An allocation failure in gstate_clone caused pgs-&gt;color to be<br>
- freed too early when memory squeezing:<br>
-<br>
- gs -sDEVICE=bit -o /dev/null: examples/tiger.eps<br>
-<br>
-base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-15 15:32:03 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=917b4e28c37d5e9ac3a605658f51b29a2357ab28">917b4e28c37d5e9ac3a605658f51b29a2357ab28</a>
-<blockquote>
-<p>
- PDF interpreter - add B operators to spcial 'W' handling<br>
-<br>
- Previously we had altered the handling of stroke, fill and eofill when<br>
- in a 'W' context, to detect changes in the graphics state between the<br>
- 'W' or 'W*' operation and the terminating path operator.<br>
-<br>
- Unfortunately when this was done the B, b, B* and b* operators were<br>
- missed, which meant these always behaved as if an invalid graphics<br>
- state change was executed, ignored the graphics state change, and<br>
- ended up rednering incorrectly.<br>
-<br>
- This commit adds those operators to the special handling of the W and<br>
- W* operators.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-15 14:46: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=46ef6bc80bd7388883a00aa866af38fe8f05d45b">46ef6bc80bd7388883a00aa866af38fe8f05d45b</a>
-<blockquote>
-<p>
- pdfwrite: properly handle text outside the clip<br>
-<br>
- Bug 697442:<br>
-<br>
- To work around an Acrobat limitation (related to glyphs with very large<br>
- coordinates), we don't emit glyph whose bounding box is outside the current<br>
- clipping region.<br>
-<br>
- However, the file in question here uses a combination of show and glyphshow to<br>
- display text, and it also measures (in the manner of stringwidth) to position<br>
- the text. *But* because it relies on glyphshow, it cannot use stringwidth. It<br>
- moves the current point outside the page, draws the text (strings and glyph<br>
- names), and records how far the current point has moved.<br>
-<br>
- The previous code would skip out early to avoid emitting the clipped out glyphs,<br>
- whilst still apparently updating the current point. *But* the values from which<br>
- the current point were updated were not correctly set due to skipping out<br>
- early.<br>
-<br>
- We now do everything *except* emit the glyphs, thus the various values are<br>
- correct, and the currentpoint is updated properly.<br>
-<br>
-devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-12 17:07:18 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=16b7f46fa03a82445784608b8db21f11cd76c884">16b7f46fa03a82445784608b8db21f11cd76c884</a>
-<blockquote>
-<p>
- Fix Bug 697661 -- SEGV with tiffsep1 device and threshold array halftones<br>
-<br>
- Threshold arrays create a different type of gx_ht_order than screen type<br>
- halftones so the bit_data is short X,Y coordinates instead of offset,mask<br>
- (gx_ht_bit) elements that the tiffsep1 &quot;threshold_from_order&quot; code was<br>
- expecting. Using the bit_index proc of the order works for all gx_ht_order<br>
- types.<br>
-<br>
- TODO: determine if it is possible to use the gx_ht_construct_threshold<br>
- function. This function is used in the FAST_HT_CODE used for some<br>
- images to halftone devices that need halftoning.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-11 15:10:00 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a5a2862d9503fedfb32f46f1cbc669c40497474f">a5a2862d9503fedfb32f46f1cbc669c40497474f</a>
-<blockquote>
-<p>
- Fix bug 695280 page mode and clist mode differ<br>
-<br>
- The clist mode &quot;uses_color&quot; was ignoring CombineWithColor if the rop<br>
- did not use the texture (rop3_uses_T false). This affects the ps3cet<br>
- 09-40.PS and pcl5ccet/23-11.BIN files.<br>
-<br>
- Note that this reults in these cases not using high-level images<br>
- in the clist since currently the clist cannot accomodate the two<br>
- different colorspaces (painting an Indexed colorspace image through<br>
- a pattern). Since the number of changed file is minimal, I assume<br>
- that the performance impact does not affect many files.<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-10 19:44:43 +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=cc35e521d8fb162f97252a3509b9041f4253b818">cc35e521d8fb162f97252a3509b9041f4253b818</a>
-<blockquote>
-<p>
- Bug 697545: Memory Squeezing updated fix for events 10 to 33<br>
-<br>
- Fix memory leaks for allocation event number 10 to 33<br>
- when memory squeezing:<br>
-<br>
- gs -sDEVICE=bit -o /dev/null: examples/tiger.eps<br>
-<br>
-psi/ialloc.c<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-10 13:14:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=acf5451a357a8595e692fe86e0be722a69e036dc">acf5451a357a8595e692fe86e0be722a69e036dc</a>
-<blockquote>
-<p>
- PDF interpreter - avoid looping/recursion searching for Default* spaces<br>
-<br>
- Bug #697655 &quot; gswin32c.exe hangs while interpreting some pdf files&quot;<br>
-<br>
- The (insane) PDF file ended up looping through Resources and XObjects<br>
- looking for any instances of the Default* colour spaces. We need the<br>
- information to set UseCIEColor to true if any are present, in order<br>
- to do proper colour management on the input colours.<br>
-<br>
- Follows the same technique we already use for transparency and cpot<br>
- colour searches.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-23 18:06:53 +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=62a865bbdf2abafabe5971d42c71be2bd1233e5c">62a865bbdf2abafabe5971d42c71be2bd1233e5c</a>
-<blockquote>
-<p>
- Bug 697545: Memory Squeezing fix events 10 to 33<br>
-<br>
- Fix memory leaks for allocation event number 10 to 33<br>
- when memory squeezing:<br>
-<br>
- gs -sDEVICE=bit -o /dev/null: examples/tiger.eps<br>
-<br>
-psi/ialloc.c<br>
-psi/ialloc.h<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-05 20:16: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=1df92f6952038fa70aa9cad8c398f360b0323539">1df92f6952038fa70aa9cad8c398f360b0323539</a>
-<blockquote>
-<p>
- Bug 697545: Memory Squeezing fix.<br>
-<br>
- Fix memory leak for allocation event number 170<br>
- when memory squeezing:<br>
-<br>
- gs -sDEVICE=bit -o /dev/null: examples/tiger.eps<br>
-<br>
-psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-07 14:20: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=67dba2b7fdb5adf4b3f8cdf112c7ac67a89a9ea8">67dba2b7fdb5adf4b3f8cdf112c7ac67a89a9ea8</a>
-<blockquote>
-<p>
- MSVC: Add 2 missing files to solution.<br>
-<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-08 10:15:25 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f37a69d40a6222d903b48b97b58a26151ea2e493">f37a69d40a6222d903b48b97b58a26151ea2e493</a>
-<blockquote>
-<p>
- txtwrite - fix Unicode conversion of glyph names 'unixxxx'<br>
-<br>
- More fallout from the ToUnicode revamp required for pdfwrite, commit<br>
- 9dba57f0f9a53c130ec2771c0ed1d7bd6bbef6ab<br>
-<br>
- The code to handle converting glyphs whose name conforms to the<br>
- uniXXXX form, when there is no better ToUnicode information, was still<br>
- returning the number of bytes, not shorts. In addition, the original<br>
- change was packing the 2 bytes as two shorts instead of a singe short.<br>
-<br>
- This resulted in incorrect output. Fixed here by packing the 4 nibbles<br>
- into a single short and returning a count of 1 short.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-03 19:42: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=64f5d62c80176085335d84c24e02cd49d9e032b9">64f5d62c80176085335d84c24e02cd49d9e032b9</a>
-<blockquote>
-<p>
- Bug 697545: Extend &quot;separable_and_linear&quot; processing.<br>
-<br>
- First, avoid needless check_separable_and_linear tests.<br>
-<br>
- When we make a memory store for a target device, we use<br>
- the encoding/decoding color functions from that target<br>
- device. It seems reasonable to copy the &quot;separable_and_linear&quot;<br>
- information from that device too, to avoid having to needlessly<br>
- retest using the same encoding/decoding functions to get<br>
- the same answer.<br>
-<br>
- Next, extend gx_color_enc_sep_lin_t to represent not just<br>
- whether we know details about the device colors separability<br>
- and linearity (and what those details are if known), but also<br>
- to encode whether those are standard encodings or not. The<br>
- standard encoding is defined to be &quot;that which is compatible<br>
- with the pdf14 compositor&quot;.<br>
-<br>
- Finally, we add a function, check_device_separable_encoding,<br>
- that 'promotes' the record for a given space from being a<br>
- known separable_and_linear one, to one that knows it's<br>
- separable_and_linear, but also knows whether it uses the<br>
- standard encoding.<br>
-<br>
- Call this in clist_close_writer_and_init_reader to ensure that<br>
- the buffer device is created knowing whether it's a standard<br>
- encoding or not. If called here, it only ever needs to run once.<br>
-<br>
- Call it again in pdf14_ok_to_optimize (just in case we ever slip<br>
- through - this takes no time if it has been run already). This<br>
- enables us to make a correct choice, and to avoid skipping<br>
- transparency bands if we are not using the standard (pdf14<br>
- compositor compatible) encoding.<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevmem.c<br>
-base/gdevp14.c<br>
-base/gscspace.c<br>
-base/gsicc.c<br>
-base/gsovrc.c<br>
-base/gxclread.c<br>
-base/gxcmap.c<br>
-base/gxdevcli.h<br>
-base/gxdevice.h<br>
-base/gxshade6.c<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-07 10:24:37 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ddd39cb2ea1773bf001cd4f975856446c2bd7f43">ddd39cb2ea1773bf001cd4f975856446c2bd7f43</a>
-<blockquote>
-<p>
- Bug 696915: Second attempt at fix.<br>
-<br>
- In attempting to fix a buffer overrun in mapped8_copy01, I broke it.<br>
- This is a proper fix. Previously I'd missed the increment of count<br>
- after the loop.<br>
-<br>
-base/gdevm8.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-07 10:08:11 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1a7bfc5dd6d84a15bba163c0f7328fb766d8be20">1a7bfc5dd6d84a15bba163c0f7328fb766d8be20</a>
-<blockquote>
-<p>
- Revert &quot;Bug 696915: Fix buffer overread in mapped8_copy01.&quot;<br>
-<br>
- This reverts commit 4e646ef8103f3ab2ab9d7de64bd30cc2156f0441.<br>
-<br>
- Cluster testing shows problems with this.<br>
-<br>
-base/gdevm8.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-06 10:00:11 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b46bb757037a18bfcc95e61fbe751df5e4cfdd58">b46bb757037a18bfcc95e61fbe751df5e4cfdd58</a>
-<blockquote>
-<p>
- Bump version number.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-16 09:20:11 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f80288c8a4b9c9abfc0fa3ccce3b6d169baa59ff">f80288c8a4b9c9abfc0fa3ccce3b6d169baa59ff</a>
-<blockquote>
-<p>
- Dates for 9.21 release<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/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/Xfonts.htm<br>
-doc/gs-vms.hlp<br>
-doc/sample_downscale_device.htm<br>
-doc/thirdparty.htm<br>
-man/dvipdf.1<br>
-man/font2c.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>
-man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-16 09:19: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=a96ade6b7238764b1a940dafbe2b7d52932f66ec">a96ade6b7238764b1a940dafbe2b7d52932f66ec</a>
-<blockquote>
-<p>
- Changelog and News + date for 9.21 release<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-16 09:13:57 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db6fa66eba7427854f491738500ecf9f179446fc">db6fa66eba7427854f491738500ecf9f179446fc</a>
-<blockquote>
-<p>
- Date and product string for 9.21 release<br>
-<br>
-base/gscdef.c<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-12 17:07:18 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6ffbbb5a389df10d7b7a0a630a910363f75b73d6">6ffbbb5a389df10d7b7a0a630a910363f75b73d6</a>
-<blockquote>
-<p>
- Fix Bug 697661 -- SEGV with tiffsep1 device and threshold array halftones<br>
-<br>
- Threshold arrays create a different type of gx_ht_order than screen type<br>
- halftones so the bit_data is short X,Y coordinates instead of offset,mask<br>
- (gx_ht_bit) elements that the tiffsep1 &quot;threshold_from_order&quot; code was<br>
- expecting. Using the bit_index proc of the order works for all gx_ht_order<br>
- types.<br>
-<br>
- TODO: determine if it is possible to use the gx_ht_construct_threshold<br>
- function. This function is used in the FAST_HT_CODE used for some<br>
- images to halftone devices that need halftoning.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-08 10:15:25 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a629fb9e9f03d8d5aefd32d3c46f6045dba41ccb">a629fb9e9f03d8d5aefd32d3c46f6045dba41ccb</a>
-<blockquote>
-<p>
- txtwrite - fix Unicode conversion of glyph names 'unixxxx'<br>
-<br>
- More fallout from the ToUnicode revamp required for pdfwrite, commit<br>
- 9dba57f0f9a53c130ec2771c0ed1d7bd6bbef6ab<br>
-<br>
- The code to handle converting glyphs whose name conforms to the<br>
- uniXXXX form, when there is no better ToUnicode information, was still<br>
- returning the number of bytes, not shorts. In addition, the original<br>
- change was packing the 2 bytes as two shorts instead of a singe short.<br>
-<br>
- This resulted in incorrect output. Fixed here by packing the 4 nibbles<br>
- into a single short and returning a count of 1 short.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-07 10:24:37 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bea6c3e636b0fcf49ab5042fb0506fdb1f5fe4b8">bea6c3e636b0fcf49ab5042fb0506fdb1f5fe4b8</a>
-<blockquote>
-<p>
- Bug 696915: Second attempt at fix.<br>
-<br>
- In attempting to fix a buffer overrun in mapped8_copy01, I broke it.<br>
- This is a proper fix. Previously I'd missed the increment of count<br>
- after the loop.<br>
-<br>
-base/gdevm8.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-07 10:08:11 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1d0bf5f9776bf2ad26e223bf3d36e85176e7c78">d1d0bf5f9776bf2ad26e223bf3d36e85176e7c78</a>
-<blockquote>
-<p>
- Revert &quot;Bug 696915: Fix buffer overread in mapped8_copy01.&quot;<br>
-<br>
- This reverts commit 4e646ef8103f3ab2ab9d7de64bd30cc2156f0441.<br>
-<br>
- Cluster testing shows problems with this.<br>
-<br>
-base/gdevm8.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-07 10:42:00 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8115fa337c70e08516a9fad6da68edf5b461cb2d">8115fa337c70e08516a9fad6da68edf5b461cb2d</a>
-<blockquote>
-<p>
- Product string for 9.20RC2<br>
-<br>
-base/gscdef.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-06 10:57: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=53dc6a1e4bb61ce1aaf689550d42ec6cf706d889">53dc6a1e4bb61ce1aaf689550d42ec6cf706d889</a>
-<blockquote>
-<p>
- Update News.html and History9.htm<br>
-<br>
- with highlights and changelogs<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-06 10:32:53 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f4b5eb2cf7d173d69c7a6bdb8008447f8e1b174">2f4b5eb2cf7d173d69c7a6bdb8008447f8e1b174</a>
-<blockquote>
-<p>
- Update dates and versions<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/Xfonts.htm<br>
-doc/gs-vms.hlp<br>
-doc/sample_downscale_device.htm<br>
-doc/thirdparty.htm<br>
-man/dvipdf.1<br>
-man/font2c.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>
-man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-06 10:31:53 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d3e8640525cab77feabf33db732e5d1bb4eb652">7d3e8640525cab77feabf33db732e5d1bb4eb652</a>
-<blockquote>
-<p>
- Update copyrights in &quot;top&quot; makefiles<br>
-<br>
-Makefile.in<br>
-psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-06 10:28:47 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f917db5eb0b94c864cef770022d86b22e45df98">8f917db5eb0b94c864cef770022d86b22e45df98</a>
-<blockquote>
-<p>
- Product string for 9.20RC1<br>
-<br>
-base/gscdef.c<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-
-<h2><a name="Version9.21"></a>Version 9.21 (2017-03-16)</h2>
-
-<p>This is the fifteenth full release in the stable 9.x series.
-
-<p> Highlights in this release include:
-<ul>
-<li>
-<p>pdfwrite now preserves annotations from input PDFs (where possible).
-</li>
-<li>
-<p>The GhostXPS interpreter now provides the pdfwrite device with the data
-it requires to emit a ToUnicode CMap: thus allowing fully searchable PDFs to
-be created from XPS input (in the vast majority of cases).
-</li>
-<li>
-<p>Ghostscript now allows the default color space for PDF transparency blends.
-</li>
-<li>
-<p>The Ghostscript/GhostPDL configure script now has much better/fuller support
-for cross compiling.
-</li>
-<li>
-<p>The tiffscaled and tiffscaled4 devices can now use ETS (Even Tone Screening)
-</li>
-<li>
-<p>The toolbin/pdf_info.ps utility can now emit the PDF XML metadata.
-</li>
-<li>
-<p>Ghostscript has a new scan converter available (currently optional, but will
-become the default in a near future release). It can be enabled by using the command
-line option: '-dSCANCONVERTERTYPE=2'. This new implementation provides vastly improved
-performance with large and complex paths.
-</li>
-<li>
-<p>The usual round of bug fixes, compatibility changes, and incremental improvements.
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.20_Incompatible_changes"></a>Incompatible changes</h3>
-<ul>
-<li>
-<p>
-The planned device API tidy (still!) did not happen for this release, due to time pressures,
-but we still intend to undertake the following:
-We plan to somewhat tidy up the device API. We intend to remove deprecated device
-procs (methods/function pointers) and change the device API so every device proc
-takes a graphics state parameter (rather than the current scheme where only a
-very few procs take an imager state parameter). This should serve as notice to
-anyone maintaining a Ghostscript device outside the canonical source tree that
-you may (probably will) need to update your device(s) when these changes happen.
-Devices using only the non-deprecated procs should be trivial to update.
-</li>
-</ul>
-
-<h3><a name="9.21_changelog"></a>Changelog</h3>
-<p><strong>2017-03-16 09:13:57 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db6fa66eba7427854f491738500ecf9f179446fc">db6fa66eba7427854f491738500ecf9f179446fc</a>
-<blockquote>
-<p>
- Date and product string for 9.21 release<br>
-<br>
-base/gscdef.c<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-12 17:07:18 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6ffbbb5a389df10d7b7a0a630a910363f75b73d6">6ffbbb5a389df10d7b7a0a630a910363f75b73d6</a>
-<blockquote>
-<p>
- Fix Bug 697661 -- SEGV with tiffsep1 device and threshold array halftones<br>
-<br>
- Threshold arrays create a different type of gx_ht_order than screen type<br>
- halftones so the bit_data is short X,Y coordinates instead of offset,mask<br>
- (gx_ht_bit) elements that the tiffsep1 &quot;threshold_from_order&quot; code was<br>
- expecting. Using the bit_index proc of the order works for all gx_ht_order<br>
- types.<br>
-<br>
- TODO: determine if it is possible to use the gx_ht_construct_threshold<br>
- function. This function is used in the FAST_HT_CODE used for some<br>
- images to halftone devices that need halftoning.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-08 10:15:25 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a629fb9e9f03d8d5aefd32d3c46f6045dba41ccb">a629fb9e9f03d8d5aefd32d3c46f6045dba41ccb</a>
-<blockquote>
-<p>
- txtwrite - fix Unicode conversion of glyph names 'unixxxx'<br>
-<br>
- More fallout from the ToUnicode revamp required for pdfwrite, commit<br>
- 9dba57f0f9a53c130ec2771c0ed1d7bd6bbef6ab<br>
-<br>
- The code to handle converting glyphs whose name conforms to the<br>
- uniXXXX form, when there is no better ToUnicode information, was still<br>
- returning the number of bytes, not shorts. In addition, the original<br>
- change was packing the 2 bytes as two shorts instead of a singe short.<br>
-<br>
- This resulted in incorrect output. Fixed here by packing the 4 nibbles<br>
- into a single short and returning a count of 1 short.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-07 10:24:37 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bea6c3e636b0fcf49ab5042fb0506fdb1f5fe4b8">bea6c3e636b0fcf49ab5042fb0506fdb1f5fe4b8</a>
-<blockquote>
-<p>
- Bug 696915: Second attempt at fix.<br>
-<br>
- In attempting to fix a buffer overrun in mapped8_copy01, I broke it.<br>
- This is a proper fix. Previously I'd missed the increment of count<br>
- after the loop.<br>
-<br>
-base/gdevm8.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-07 10:08:11 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1d0bf5f9776bf2ad26e223bf3d36e85176e7c78">d1d0bf5f9776bf2ad26e223bf3d36e85176e7c78</a>
-<blockquote>
-<p>
- Revert &quot;Bug 696915: Fix buffer overread in mapped8_copy01.&quot;<br>
-<br>
- This reverts commit 4e646ef8103f3ab2ab9d7de64bd30cc2156f0441.<br>
-<br>
- Cluster testing shows problems with this.<br>
-<br>
-base/gdevm8.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-07 10:42:00 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8115fa337c70e08516a9fad6da68edf5b461cb2d">8115fa337c70e08516a9fad6da68edf5b461cb2d</a>
-<blockquote>
-<p>
- Product string for 9.20RC2<br>
-<br>
-base/gscdef.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-06 10:32:53 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f4b5eb2cf7d173d69c7a6bdb8008447f8e1b174">2f4b5eb2cf7d173d69c7a6bdb8008447f8e1b174</a>
-<blockquote>
-<p>
- Update dates and versions<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/Xfonts.htm<br>
-doc/gs-vms.hlp<br>
-doc/sample_downscale_device.htm<br>
-doc/thirdparty.htm<br>
-man/dvipdf.1<br>
-man/font2c.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>
-man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-06 10:31:53 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d3e8640525cab77feabf33db732e5d1bb4eb652">7d3e8640525cab77feabf33db732e5d1bb4eb652</a>
-<blockquote>
-<p>
- Update copyrights in &quot;top&quot; makefiles<br>
-<br>
-Makefile.in<br>
-psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-06 10:28:47 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f917db5eb0b94c864cef770022d86b22e45df98">8f917db5eb0b94c864cef770022d86b22e45df98</a>
-<blockquote>
-<p>
- Product string for 9.20RC1<br>
-<br>
-base/gscdef.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-03 10:20:14 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=278c66866eb41c0d8220d31bd7f12887706eb51c">278c66866eb41c0d8220d31bd7f12887706eb51c</a>
-<blockquote>
-<p>
- Change git behaviour broke gitlog2changelog.py<br>
-<br>
- remove the --cc options<br>
-<br>
-toolbin/gitlog2changelog.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-03 10:00:05 -0700
-</strong>
-<br>Henry &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d2da0ae232605c4f62a97f8cf1cedce15c4ba9f">1d2da0ae232605c4f62a97f8cf1cedce15c4ba9f</a>
-<blockquote>
-<p>
- Add error message when resident fonts are not found.<br>
-<br>
- The fix also uncovered a regression. The XL interpreter was checking<br>
- if the function to load built in fonts returned a code less than 0<br>
- which does not happen anymore. Upon error the function returns 0 (false),<br>
- indicating no fonts found.<br>
-<br>
-pcl/pcl/pcfont.c<br>
-pcl/pxl/pxsessio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-03 06:58:19 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c9cb91b2fb59481247aaee88779577ef6c103327">c9cb91b2fb59481247aaee88779577ef6c103327</a>
-<blockquote>
-<p>
- Update the default PCL font search path.<br>
-<br>
- The font search path was never updated when the directory structure<br>
- changed, also add a directory entry to allow PCL to find fonts while<br>
- cluster testing without an environment variable or command line<br>
- setting.<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-03 09:30:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=62354d822b29006d7e431a2b07c70106647b62c8">62354d822b29006d7e431a2b07c70106647b62c8</a>
-<blockquote>
-<p>
- Remove the left over Mac specific files.<br>
-<br>
- OS X is basically just a Unix-like system, so building gs for it is now just<br>
- like for any other Unix-like system. We haven't supported Mac Classic for some<br>
- time.<br>
-<br>
- Several Mac related files were left over, atrophied and no longer any value.<br>
-<br>
- This removes them.<br>
-<br>
-base/gsiomacres.c<br>
-base/lib.mak<br>
-base/macgenmcpxml.sh<br>
-base/macos_carbon_d_pre.h<br>
-base/macos_carbon_pre.h<br>
-base/macos_classic_d_pre.h<br>
-base/macosx.mak<br>
-base/macsystypes.h<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-02 16:35:51 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba8d4abaa9c33edd8c79da7022f231e4b21f22e9">ba8d4abaa9c33edd8c79da7022f231e4b21f22e9</a>
-<blockquote>
-<p>
- fix bug 697621: color_usage.or bits were wrong with transparency<br>
-<br>
- The psdcmykog uses the color_usage.or bits to decide which components need to<br>
- be processed, skipping those that are not needed. When the pdf14 device changes<br>
- the color_info the color that will actually go on the page cannot be known<br>
- without transforming the color to the device color which is too expensive.<br>
-<br>
- Also fix the polarity tests in gx_color_index2usage (it was being ignored)<br>
-<br>
-base/gxclist.c<br>
-base/gxclpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-02 12:26: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=ea14e8c7c8f8ece7a7ea2a324bca2c115c61b1a3">ea14e8c7c8f8ece7a7ea2a324bca2c115c61b1a3</a>
-<blockquote>
-<p>
- Bug 697626: bounds check allocations in the chunk allocator<br>
-<br>
- Ensure the requested memory allocation doesn't overflow the 32 bit variables<br>
- in the chunk allocator.<br>
-<br>
-base/gsmchunk.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-01 10:26:17 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=670e5d250c6049694f0f1f1c3d15270d6dc2246a">670e5d250c6049694f0f1f1c3d15270d6dc2246a</a>
-<blockquote>
-<p>
- Bug 697615: Only apply CompatibleOverprint handling to some colorspaces<br>
-<br>
- Testing with Adobe shows that only Gray, CMYK, DeviceN and Sep color<br>
- spaces should use the special CompatibleOverprint handling specified<br>
- in the section &quot;Compatibility with Opaque Overprinting&quot;.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-01 12:59:12 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0a8f8a53a968a638e828086f0725780aa64793c0">0a8f8a53a968a638e828086f0725780aa64793c0</a>
-<blockquote>
-<p>
- Fix clump handling.<br>
-<br>
- Ray spotted that running:<br>
-<br>
- debugbin/gs -r300 -Z@\$\?: -dJOBSERVER<br>
-<br>
- is enough to send us into an infinite loop.<br>
-<br>
- Tracking this down, it appears that the reason is to do with<br>
- the gs_ref_memory_t's use of 'pcc' and 'cc'.<br>
-<br>
- It copies the 'current' chunk out of the splay tree, and then<br>
- puts it back later, without realising that the splay tree<br>
- may have been altered.<br>
-<br>
- The simplest fix appears to be just to not do this copying.<br>
-<br>
-base/gsalloc.c<br>
-base/gxalloc.h<br>
-psi/ialloc.c<br>
-psi/igc.c<br>
-psi/ilocate.c<br>
-psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-28 17:36:00 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f8c0d4e78f75de95b0d74210b3e929abef6f3a60">f8c0d4e78f75de95b0d74210b3e929abef6f3a60</a>
-<blockquote>
-<p>
- Add sanity check on image sizes.<br>
-<br>
- Inspired by bug 697395, but doesn't actually solve any problem<br>
- seen in that bug (or at least, not that I can see, as I can't<br>
- reproduce the problem with file2).<br>
-<br>
-jbig2dec/jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-03-01 09:47:58 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bbb2b961388b028d7d9d8f6454ced8192ad513c1">bbb2b961388b028d7d9d8f6454ced8192ad513c1</a>
-<blockquote>
-<p>
- Fix Bug 697624 - PCL segfaults with --disable-compile inits.<br>
-<br>
- Instead of trying to continue we exit upon initialization if no fonts<br>
- are found and the current emulation is PCL.<br>
-<br>
-pcl/pcl/pcfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-28 18:43:04 +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=ce437b88df500a184ae2ca15d67a019f57a11d20">ce437b88df500a184ae2ca15d67a019f57a11d20</a>
-<blockquote>
-<p>
- Bug 697545: Memory Squeezing fix.<br>
-<br>
- Fix memory leaks for allocation event numbers 25 to 32<br>
- when memory squeezing:<br>
-<br>
- gs -sDEVICE=bit -o /dev/null: examples/tiger.eps<br>
-<br>
-psi/imain.c<br>
-psi/iname.c<br>
-psi/inames.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-28 19:54: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=0ebb37a19ece80fa03af8de5047705722625870b">0ebb37a19ece80fa03af8de5047705722625870b</a>
-<blockquote>
-<p>
- Bug 697372: Fix crash due to pattern clist being freed<br>
-<br>
- When rendering a pattern from a clist into the pdf14 compositor, the compositor<br>
- takes a reference to the pattern clist device. This is fine pre-page-clist, or<br>
- with no page clist involved (when the memory is managed by the garbage<br>
- collector), but post-page-clist the life span of the pattern clist device is<br>
- dicated by the clist replay, *not* by references to it (as in the gc'ed case).<br>
- This can result in a dangling pointer, which later causes a crash in the<br>
- garbage collector when it cleans up after the page-clist has completed.<br>
-<br>
- So, when pattern fill has been completed, remove the reference to the pattern<br>
- clist device.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-28 15:36:34 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=459a0e650ffab1069a6f59c17775f5fd462c45d2">459a0e650ffab1069a6f59c17775f5fd462c45d2</a>
-<blockquote>
-<p>
- Bug 696364: Restrict size of alphabits buffer<br>
-<br>
- Thanks to Michael for doing the investigation, and leaving a<br>
- really good write up of the problem on the bug.<br>
-<br>
- The basic problem is that we have a transparency group that<br>
- contains a softmask. The softmask is larger than the transparency<br>
- group, so it is restricted to the size of the group and written<br>
- into the clist as occupying just a small set of bands.<br>
-<br>
- The content for the softmask is larger, however, so when used with<br>
- GraphicsAlphaBits, we create various alphabits devices, draw<br>
- the contents, and then send the results with copy_alpha.<br>
-<br>
- These copy_alpha calls are NOT restricted to being within the<br>
- reduced region for the softmask. This therefore upsets the clist<br>
- reading.<br>
-<br>
- The fix, as suggested by Michael in his bug report is to limit<br>
- the size of the softmask contents (by limiting the size of the<br>
- alphabits buffers).<br>
-<br>
- Ideally the alphabits device would know what region to limit<br>
- itself to just by looking at the graphics state it's passed in.<br>
- Unfortunately, that doesn't work as the current softmask/groups<br>
- aren't reflected in the graphic state. This feels wrong to me,<br>
- but that's the way it is.<br>
-<br>
- Instead, we have to resort to asking the device to limit our<br>
- bbox according to the current state. We achieve this by adding<br>
- a new dev_spec_op, and adding the required plumbing to the pdf14<br>
- device (to pass it on to the target) and the clist device (to<br>
- actually do the restriction).<br>
-<br>
-base/gdevp14.c<br>
-base/gspaint.c<br>
-base/gxclrect.c<br>
-base/gxdevsop.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-28 07:05:58 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a9394e6abc6b0107da4f42675bf35eb031fe068">4a9394e6abc6b0107da4f42675bf35eb031fe068</a>
-<blockquote>
-<p>
- Fix DEPTH is RAW_DUMP_AS_PAM GRAYSCALE_ALPHA header<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-27 13:37:41 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ff07b67892c201a0a16d983b05d121ac409b78a0">ff07b67892c201a0a16d983b05d121ac409b78a0</a>
-<blockquote>
-<p>
- Bug 697615: color_usage was incorrectly updated for devn with pdf14<br>
-<br>
- When the pdf14 compositor messes with the color space and color_info,<br>
- it doesn't change the target (clist) color_info, but sets the new<br>
- information in cldev-&gt;clist_color_info. In order to properly update the<br>
- color_usage cmd_drawing_color_usage needs to set the bits according to the<br>
- clist_color_info num_components and polarity in gx_dc_devn_get_nonzero_comps,<br>
- so save the cldev-&gt;color_info values, set them to the cldev-&gt;clist_color_info<br>
- values for the calculation and restore them afterwards<br>
-<br>
-base/gxclpath.c<br>
-base/gxdcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-27 14:15:30 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=97ddb45834c73f697e53839c6b433f65248d9c2a">97ddb45834c73f697e53839c6b433f65248d9c2a</a>
-<blockquote>
-<p>
- Improve pcl page marking detection.<br>
-<br>
- Instead of looking at only the character's position to determine if a<br>
- character marks the page we now look at the extant of the character's<br>
- width. Thanks to Norbert Janssen for the fix.<br>
-<br>
-pcl/pcl/pcpage.c<br>
-pcl/pcl/pcpage.h<br>
-pcl/pcl/pctext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-27 18:20: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=8bb1aab8a60810aefb67a6d2764a54abc547878b">8bb1aab8a60810aefb67a6d2764a54abc547878b</a>
-<blockquote>
-<p>
- Bug 697545: Memory Squeezing fix.<br>
-<br>
- Fix memory leak for allocation event number 22<br>
- when memory squeezing:<br>
-<br>
- gs -sDEVICE=bit -o /dev/null: examples/tiger.eps<br>
-<br>
-base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-26 05:23: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=a76a82abca879fcf351fce5aba50a48e7de41963">a76a82abca879fcf351fce5aba50a48e7de41963</a>
-<blockquote>
-<p>
- Bug 697545: Memory Squeezing fix.<br>
-<br>
- Fix memory leak for allocation event number 10<br>
- when memory squeezing:<br>
-<br>
- gs -sDEVICE=bit -o /dev/null: examples/tiger.eps<br>
-<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-24 18:21:12 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=009e40a0534e1d11ed5ee353477859b5cdd4faed">009e40a0534e1d11ed5ee353477859b5cdd4faed</a>
-<blockquote>
-<p>
- Bug 696921: Don't &quot;early decode&quot; when interpolating Lab images<br>
-<br>
- Applying the decode array to Lab source values during the<br>
- conversion to fracs that takes place before non-icc based<br>
- interpolation causes an overflow.<br>
-<br>
- We therefore leave the application of the decode array until<br>
- after the interpolation.<br>
-<br>
- After the interpolation, we don't actually want to apply the<br>
- decode array though - in that we want the result in the usual<br>
- 0...1 float form rather than the 0..100/-128..127/-128...127<br>
- ranges that the color would seem to require.<br>
-<br>
- One option would be simply to not apply the decode array. This<br>
- will however go wrong when we meet an Lab file with a<br>
- non-standard Decode array. We therefore apply the given decode<br>
- array (which may well be the default), and 'undo' the default<br>
- one to get the values we actually want.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-24 19:05: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=af3c1d10726b2d932d951bf021193cbd5bcc734d">af3c1d10726b2d932d951bf021193cbd5bcc734d</a>
-<blockquote>
-<p>
- Bug 697048: Fix compatible overprint blend mode.<br>
-<br>
- Fix from Michael Vrhel.<br>
-<br>
- Compatible overprint is operating in subtractive color spaces, so<br>
- a 'zero' component actually means 0xFF.<br>
-<br>
-base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-24 18:40: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=9e38426abd977fbc67c0d91103eb7bd3573409bb">9e38426abd977fbc67c0d91103eb7bd3573409bb</a>
-<blockquote>
-<p>
- Update clusterpush.pl<br>
-<br>
- Allow &quot;extended&quot;, &quot;cull&quot; and &quot;win32&quot;.<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-23 15:20:35 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1aebfe56c80bb46bba74c23654d9febcf5f761b5">1aebfe56c80bb46bba74c23654d9febcf5f761b5</a>
-<blockquote>
-<p>
- Correct assert in new scan converter<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-24 09:33:05 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=13686f5374600d41105587c20a15f3c1e55f3534">13686f5374600d41105587c20a15f3c1e55f3534</a>
-<blockquote>
-<p>
- Return Fatal errors from PS putdeviceparams to avoid potential SEGV<br>
-<br>
- The change to return Fatal from the display device (commit 269354e)<br>
- would segfault with the PS interpreter because zputdeviceparams never<br>
- returned an error code, assuming that the interpreter could handle it,<br>
- but this resulted in a segfault when setpagedevice tried to erase the<br>
- page and the display device did not have a valid bitmap. Return the<br>
- Fatal error so the interpreter can exit cleanly.without performing<br>
- the usual setpagedevice &quot;configurationerror&quot; recovery.<br>
-<br>
-psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-24 16:10:11 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dabad3f6e9c2bdbd152f67a66b698262f94b816d">dabad3f6e9c2bdbd152f67a66b698262f94b816d</a>
-<blockquote>
-<p>
- PDF interpreter - remove some (ancient) debug code<br>
-<br>
- This line seems to have been left in accidentally a long, long, time<br>
- ago. Surprisingly its never been noticed before....<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-24 15:50:21 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=269354ea918e4498df67e52a1efd16295e031421">269354ea918e4498df67e52a1efd16295e031421</a>
-<blockquote>
-<p>
- Fix display device for non-PostScript interpreters<br>
-<br>
- commit cf279b8c4773e14045dd6b411c3a524c6ac39124 fixed a potential<br>
- crash when memory was exhausted, but used the gs_abort() routine to<br>
- tell the interpreter to abort immediately and not carry on.<br>
-<br>
- Unfortunately, and despite the comment in gsexit.h, gs_abort() is only<br>
- available in the PostScript interpreter.<br>
-<br>
- So here we opt to return a fatal error, which *should* cause the<br>
- interpreter to give up (it does on PCL and PostScript) and will allow<br>
- us to build GhostPCL on Windows.<br>
-<br>
-devices/gdevdsp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-24 10:12: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=0e9a345e7badf0d53ab19761a938665079883612">0e9a345e7badf0d53ab19761a938665079883612</a>
-<blockquote>
-<p>
- Bug 694995: Fix 'wrapped' x11 devices' buffered 'mode'<br>
-<br>
- The x11 devices can either unbuffered (where rendered objects go straight to the<br>
- screen) or buffered (where objects are rendered to a memory buffer device, and<br>
- then blitted to the screen).<br>
-<br>
- Additionally, the 'real' x11 device always uses the resolution and color specs<br>
- of the X11 server on which it is running. Then devices such as x11mono and<br>
- x11cmyk using a &quot;wrapper&quot; device in order to keep the x11 device using the<br>
- specs of the X11 server, whilst presenting an appropriate character to the rest<br>
- of Ghostscript (so, even though x11 is *probably* running 24bit RBG, x11mono<br>
- needs to look like a pure monochrome device).<br>
-<br>
- Because we need the 'real' x11 device to handle get_params/put_params, and we<br>
- need to temporarily 'patch' the color info of the 'real' x11 device so it<br>
- retrieves/applies the params correctly.<br>
-<br>
- The problem arises when we run one of these 'wrapper' devices in buffered mode.<br>
- The memory buffer device (particularly after a resizing of the page buffer),<br>
- would end up being configured based on the color settings of the 'wrapper'<br>
- device, rather than the 'wrapped' device. So we could end up treating a 1bpp<br>
- mono bitmap (from the memory buffer device) as a 24bpp RGB pixmap and blitting<br>
- to the screen. Causing a buffer overflow, and segfault.<br>
-<br>
- To solve that, store the color info we need away from its place in a<br>
- standard device, and use the x11 device's own dedicated copy for setting up<br>
- the memory buffer device.<br>
-<br>
-devices/gdevx.c<br>
-devices/gdevx.h<br>
-devices/gdevxalt.c<br>
-devices/gdevxini.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-22 07:17:54 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=670c6b29ebbd29fb3238575cb08a6c2c9586ace7">670c6b29ebbd29fb3238575cb08a6c2c9586ace7</a>
-<blockquote>
-<p>
- Add support for RGB_TAG PAM files to lib/viewpbm.ps (type from bitrgbtags)<br>
-<br>
- The bitrgbtags device was changed recently to create a PAM (P7) file rather<br>
- than a bogus P6 file with 4 components. This means that the pcl/tools/GOT<br>
- detag.c and tagimage.c no longer worked. Instead of changing these the<br>
- lib/viewpbm.ps was enhanced to process the RGB_TAG P7 files.<br>
-<br>
- By default, it shows the image, and with -dTAG it shows pseudo-color for<br>
- the tag values, UNKNOWN/UNMARKED is white, TEXT is black, PATH is yellow<br>
- and IMAGE is red.<br>
-<br>
- example usage:<br>
- gs -dSCALE=1 -- lib/viewpbm.ps bitrgbags.pam<br>
- or<br>
- gs -dSCALE=1 -dTAG -- lib/viewpbm.ps bitrgbags.pam<br>
-<br>
- This can also be used to convert the P7 image to another format using<br>
- -sDEVICE=___ -o ___ arguments prior to the -- option.<br>
-<br>
- Also, fix numerous problems with FITPAGE and SCALE options. They were<br>
- just WRONG!<br>
-<br>
-lib/viewpbm.ps<br>
-pcl/tools/GOT/README<br>
-pcl/tools/GOT/detag.c<br>
-pcl/tools/GOT/dotags.sh<br>
-pcl/tools/GOT/tagimage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-22 17:51:17 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=862b31689c3f1c6425f5522adc820b73e352e012">862b31689c3f1c6425f5522adc820b73e352e012</a>
-<blockquote>
-<p>
- Improve bitrgbtags device so that unmarked areas are preserved.<br>
-<br>
- Similar to pngalpha, the bitrgbtags device needs to have a fillpage<br>
- procedure to fill the page to &quot;GS_UNTOUCHED_TAG&quot; | white (0xffffff)<br>
- Without this, the page was entirely set to &quot;PATH&quot; by the default<br>
- fillpage.<br>
-<br>
- Note this will change EVERY bitrgbtags output in the regression results.<br>
-<br>
-devices/gdevbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-23 13:04:11 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b0d12644776ab1517e549903ba3262c082759680">b0d12644776ab1517e549903ba3262c082759680</a>
-<blockquote>
-<p>
- Bug 697607: correctly bounds check glyph index in TTFs<br>
-<br>
- The update to Freetype removed a bounds check in the Freetype code when the<br>
- incremental API is in use (leaving it up to the caller to validate the glyph<br>
- index). This adds that bounds check to our glyph data callback.<br>
-<br>
- As part of that, return the trueNumGlyphs and numGlyphs varaibles in the<br>
- Ghostscript type 42 font structure to their (apparent) original intent:<br>
- trueNumGlyphs is the value read from the maxp table, whilst numGlyphs is a value<br>
- derived from the size of the loca table (see the bug for a fuller explanation).<br>
-<br>
-base/gstype42.c<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-23 11:30:22 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e646ef8103f3ab2ab9d7de64bd30cc2156f0441">4e646ef8103f3ab2ab9d7de64bd30cc2156f0441</a>
-<blockquote>
-<p>
- Bug 696915: Fix buffer overread in mapped8_copy01.<br>
-<br>
- If the stars align, we can overread by 1 source byte<br>
- in mapped8_copy01. Simple fix.<br>
-<br>
-base/gdevm8.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-22 17:24:24 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cf279b8c4773e14045dd6b411c3a524c6ac39124">cf279b8c4773e14045dd6b411c3a524c6ac39124</a>
-<blockquote>
-<p>
- Fix SEGV is display device when PageSize needs bitmap &gt; 2Gb<br>
-<br>
- The display_put_params is supposed to revert to the original settings<br>
- if an error is encountered, but since it frees the display bitmap before<br>
- attempting to allocate the new one, if that allocation fails, the device<br>
- is left with a memory device that has an invald bitmap pointer.<br>
-<br>
- Instead revert the settings and attempt to allocate a bitmap with those<br>
- settings. If that fails (unlikely) then gs_abort with an error message.<br>
-<br>
- NB: It is preferable to free one bitmap before allocating the new one<br>
- in case we are near a system memory constraint.<br>
-<br>
-devices/gdevdsp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-22 23:54:38 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=340b7c7f79d45ed36cd247ff0c13586e6b6a4763">340b7c7f79d45ed36cd247ff0c13586e6b6a4763</a>
-<blockquote>
-<p>
- Bug 696520: Avoid dereferencing NULL in epson devices.<br>
-<br>
- Adopt Peter Cherepanov's patch to avoid dereferencing NULL.<br>
-<br>
- Only calculate the pure color if we know we're going to need<br>
- it - by which time we know it's safe to deference.<br>
-<br>
-contrib/eplaser/gdevescv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-20 16:32:51 +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=4c99ddc1dbd610d9d677750d6b1dabcb1cda8fb0">4c99ddc1dbd610d9d677750d6b1dabcb1cda8fb0</a>
-<blockquote>
-<p>
- Bug 697545: Memory Squeezing fix.<br>
-<br>
- Fix memory leaks for allocation event number 8 and 9<br>
- when memory squeezing:<br>
-<br>
- gs -sDEVICE=bit -o /dev/null: examples/tiger.eps<br>
-<br>
-psi/gs.c<br>
-psi/iapi.c<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-22 16:41:33 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=21901b860ca033ed14168d3c191b39ff714946b5">21901b860ca033ed14168d3c191b39ff714946b5</a>
-<blockquote>
-<p>
- Bug 697602: Remove 2 instances of variable shadowing.<br>
-<br>
- Hard to believe these are right because setting code<br>
- and then falling out of scope doesn't achieve much.<br>
-<br>
-base/gp_wxpsprn.cpp<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-22 08:11:48 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f8d299c399312fdd41958843a101db36353ad8e2">f8d299c399312fdd41958843a101db36353ad8e2</a>
-<blockquote>
-<p>
- Avoid getenv call in openjpeg<br>
-<br>
- getenv is not allowed in certain cases causing linking<br>
- issues. This fix should be pushed to the openjpeg<br>
- group. Thanks to Chris for the fix.<br>
-<br>
-openjpeg/src/lib/openjp2/j2k.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-21 16:46:07 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e8831a02f172490d7b175e54c7d15814acacea4">8e8831a02f172490d7b175e54c7d15814acacea4</a>
-<blockquote>
-<p>
- Update bytes_decoded for the non-cache code path.<br>
-<br>
- If a glyph is being rendered without going through the glyph cache, we still<br>
- must update the 'bytes_decoded' entry in the text enumerator.<br>
-<br>
-base/gxchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-20 10:16:32 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=948d880467b2436813f7ffe5d1bd694c9475093c">948d880467b2436813f7ffe5d1bd694c9475093c</a>
-<blockquote>
-<p>
- Bug 694269: valgrind issues in Type 1 charstring interpreter<br>
-<br>
- 1) Bounds check the charstring data so we don't run off the end of the buffer<br>
-<br>
- 2) Initialise various entries in the Type 1 hinter state: in a well formed<br>
- font these will never be used without being set from the charstring, but in<br>
- a broken font, they can be used without being set.<br>
-<br>
- 3) Initialise the (sacrificial) path we use when retrieving glyph metrics etc.<br>
-<br>
- 4) Initialise the contents of the stack<br>
-<br>
-base/gstype1.c<br>
-base/gxhintn.c<br>
-base/gxpath.c<br>
-base/gxtype1.c<br>
-base/gxtype1.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-17 11:07: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=64c433d69b7732ae919a029dbf4b635133c97f03">64c433d69b7732ae919a029dbf4b635133c97f03</a>
-<blockquote>
-<p>
- Bug 694250: bounds check in TTF hinting code<br>
-<br>
- Broken font tries to access *way* off the end of the opcode buffer. Check the<br>
- index before using it<br>
-<br>
-base/ttinterp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-17 11:33:36 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83b54c55a485a17124321d437e8207515396024a">83b54c55a485a17124321d437e8207515396024a</a>
-<blockquote>
-<p>
- Bug 694268: init stack based data.<br>
-<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-16 10:27: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=cf60a549d2413ae96b17010f0a69f82b797d33e3">cf60a549d2413ae96b17010f0a69f82b797d33e3</a>
-<blockquote>
-<p>
- Fix low memory crash in native font enumeration.<br>
-<br>
-psi/zfontenum.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-20 10:24:14 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=12091a85336f5c422545f03b4afcd1ea7362a10e">12091a85336f5c422545f03b4afcd1ea7362a10e</a>
-<blockquote>
-<p>
- Fix misspelled TUPLTYPE in PAM header for bitrgbtags output.<br>
-<br>
- Also add in DEPTH 4<br>
-<br>
-devices/gdevbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-20 15:58: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=8e918ac9ca06971534c7e39087ecca05c3809ce7">8e918ac9ca06971534c7e39087ecca05c3809ce7</a>
-<blockquote>
-<p>
- Update bmpcmp to cope with PAMs with RGB_TAG input.<br>
-<br>
- We treat these as CMYK PAMs for now. This should be enough for<br>
- us to spot differences in the false color images produced.<br>
-<br>
-toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-20 15:48:47 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f21824bbf5bd1c0ba8cb19855a8fbc5e0681ff74">f21824bbf5bd1c0ba8cb19855a8fbc5e0681ff74</a>
-<blockquote>
-<p>
- Update bitrgbtags device to use better header.<br>
-<br>
- The bit devices output raw data.<br>
-<br>
- The bittagsrgb device outputs rgb + a tag plane, with a PPM header.<br>
- The PPM header tells code to expect 3 bytes of image data, not 4,<br>
- so is wrong. Here we change it over to use a PAM header (of type<br>
- RGB_TAG).<br>
-<br>
- This allows bmpcmp to be amended to cope better.<br>
-<br>
-devices/gdevbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-20 09:45:18 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ecceafe3abba2714ef9b432035fe0739d9b1a283">ecceafe3abba2714ef9b432035fe0739d9b1a283</a>
-<blockquote>
-<p>
- Resolve image enumerator ownership on error<br>
-<br>
- Bug #697596 &quot;Use-After-Free in i_free_object()&quot;<br>
-<br>
- There is confusion over ownership of 'penum' between gx_begin_image1(),<br>
- gx_begin_image4() and gx_image_enum_begin() which is called from these<br>
- two functions (and only from these two functions).<br>
-<br>
- The enumerator is allocated in gx_begin_image?() and freed there if<br>
- gx_image_enum_begin() returns an error. However, gx_image_enum_begin()<br>
- also frees the enumerator on an error; except that it doesn't always do<br>
- so. Its a large function and there are at least 9 ways to exit it, only<br>
- 4 of which free the enumerator.<br>
-<br>
- This commit removes the 'free' instances from gx_image_enum_begin()<br>
- leaving the cleanup as the responsibility of the calling code, which<br>
- performed the allocation.<br>
-<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-19 10:13:53 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8452f9238959a4d518af365812bf031fe4d8d4b7">8452f9238959a4d518af365812bf031fe4d8d4b7</a>
-<blockquote>
-<p>
- Fix Coverity CID 141336 -- Indentation gripe.<br>
-<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-06 19:21:43 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eccf38345588ced6595d3414fca10098e9855da3">eccf38345588ced6595d3414fca10098e9855da3</a>
-<blockquote>
-<p>
- Add -dDumpXML to toolbin/pdf_info.ps options and fix -dDumpFontsNeeded<br>
-<br>
- As an example of getting even more info from the PDF, add -dDumpXML to<br>
- dump the PDF Metadata (if any).<br>
-<br>
- Also a problem found with -dDumpFontsNeeded=false was fixed.<br>
-<br>
- usage to dump the basic info and Metadata:<br>
- gs -q -dDumpXML -dDumpMediaSizes=false -dDumpFontsNeeded=false -- \<br>
- toolbin/pdf_info.ps examples/annots.pdf<br>
-<br>
-toolbin/pdf_info.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-18 17:57:18 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e548d290d7d052a32e65493a703e1276230554c3">e548d290d7d052a32e65493a703e1276230554c3</a>
-<blockquote>
-<p>
- Fix 697576: false colors with pxlcolor.<br>
-<br>
- PXL high level image processing does not support DeviceN, fall back to<br>
- rendering rectangles.<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-18 08:50:48 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cb5ec3dc7d0214ca3a784f9630b0775142c2ec08">cb5ec3dc7d0214ca3a784f9630b0775142c2ec08</a>
-<blockquote>
-<p>
- Fix bug #687561, bad parsing of intellifont data.<br>
-<br>
- The previous code read the metric offset field at the wrong positon (8<br>
- vs. 6) resulting in a value that caused a range check error. Further,<br>
- the range checking which checked the offsets were ordered is not<br>
- useful or correct, and has been removed. There is nothing in the<br>
- documentation to indicate the offsets must be ordered and showing<br>
- order does not help in preventing out of bounds access.<br>
-<br>
-pcl/pcl/pcsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-16 21:47:47 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c139c069968a59bc53e45d8373dd70d30278d152">c139c069968a59bc53e45d8373dd70d30278d152</a>
-<blockquote>
-<p>
- Change -Za output to omit the (mostly useless) opening/closing clump messages<br>
-<br>
- The -ZA is noisier so, keep these messages for that debug level (for now).<br>
- I've worked with Ghostscript allocators for MANY years and have yet to<br>
- find these messages useful. This is a precursor to totally deleting these<br>
- messages.<br>
-<br>
-base/gsalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-16 16:37:28 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=88201849f123642dac3920a0bad5e68290280798">88201849f123642dac3920a0bad5e68290280798</a>
-<blockquote>
-<p>
- Fix incorrect calculation of pdf14 number of components.<br>
-<br>
- This was seen with DeviceN devices (psdcmyk, tiffsep, ...) with the file:<br>
- tests_private/comparefiles/Altona_Technical_v20_x4.pdf resulting in<br>
- Error messages and warnings that &quot;Output may be incorrect&quot;. With the<br>
- -dPDFSTOPONERROR option, an reangecheck error is reported.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-16 07:56:26 +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=7bb2ad6cce75aae3ebedaa5883e1ecd6ba19b52d">7bb2ad6cce75aae3ebedaa5883e1ecd6ba19b52d</a>
-<blockquote>
-<p>
- Bug 697545: Memory Squeezing fix.<br>
-<br>
- Fix for 'red 85546'. This is a SEGV seen at allocation event<br>
- 85546 when memory squeezing:<br>
-<br>
- gs -sDEVICE=bit -o /dev/null: examples/tiger.eps<br>
-<br>
- Also account for all the other places that allocate a new<br>
- colorspace without checking the returned value.<br>
-<br>
-base/gsgstate.c<br>
-base/gsicc_manage.c<br>
-base/gsimage.c<br>
-base/gsptype1.c<br>
-base/gstrans.c<br>
-base/gxclrast.c<br>
-devices/vector/gdevpdfb.c<br>
-devices/vector/gdevpdfc.c<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpsdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-29 11:14:39 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=40a82d9e72340b8547f0d45709693e456465ccfd">40a82d9e72340b8547f0d45709693e456465ccfd</a>
-<blockquote>
-<p>
- Fix Bug 697502, problems with NumRenderingThreads exceeding available RAM<br>
-<br>
- The logic that determined the amount of printer buffer space, and allocated it<br>
- was including the ESTIMATED pdf14 transparency buffer space, but we only need<br>
- to make sure that amount of space is available, not actually allocate it (since<br>
- then it wouldn't be availble when needed).<br>
-<br>
- if there wasn't enough memory for the band buffer when a thread's clist reader<br>
- was opened, gdev_prn_setup_as_command_list would try reducing the BufferSpace<br>
- (by successive dividing by 2) until it could fit. This would result in a<br>
- reader band size that did not match what was used to write the clist. This<br>
- so we force the BandBufferSpace to be exactly the same as was used in the writer<br>
- using the cdev page_info.band_params. The tile_cache_size was added to the<br>
- space_params used to set up the thread clist device to make it match that used<br>
- by the writer.<br>
-<br>
- In order to make sure we don't &quot;over commit&quot; in creating threads we reserve<br>
- an extra amount per thread, currently 2 Mb plus the ht_cache size times the<br>
- number of components, plus when the page uses transparency, we increase it by<br>
- the ESTIMATED_PDF14_ROW_SPACE times the band_height. We further increase it by<br>
- the size of the link profiles and the size of the icclink profiles (CURRENTLY<br>
- ESTIMATED). We free the reserve area as we start threads.<br>
-<br>
- Also when an allocation for a thread failed, the 'band' used for next_band was<br>
- being decremented but it did not need to be since it was already the correct value.<br>
- This had caused a problem with threads getting started for the wrong band.<br>
-<br>
- Fix gx_ht_read_and_install to prevent double free if gx_gstate_dev_ht_install<br>
- gets an error (VMerror).<br>
-<br>
- Fix gdevbit so that we don't keep going after get_bits returns an error.<br>
-<br>
- TODO: collect the size of the icclinks rather than a rather worst case value<br>
- currently estimated.<br>
-<br>
-base/gdevprn.c<br>
-base/gsht.c<br>
-base/gsicc_manage.c<br>
-base/gxclist.c<br>
-base/gxclthrd.c<br>
-base/gxdevcli.h<br>
-base/gxdhtserial.c<br>
-devices/gdevbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-16 08:52:48 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=89371a73c6d97606ca61884b555b7c13ec1534ac">89371a73c6d97606ca61884b555b7c13ec1534ac</a>
-<blockquote>
-<p>
- Fix segfaults in low memory conditions<br>
-<br>
- Bug 697572 &quot;Segfaults when ps2write runs out of memory&quot;<br>
-<br>
- Add some return code checks in pdfwrite/ps2write, check a stream when<br>
- trying to close an 'aside', add a check for error return codes when<br>
- rendering a cached glyph bitmap.<br>
-<br>
-base/gxccache.c<br>
-devices/vector/gdevpdfb.c<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdfj.c<br>
-devices/vector/gdevpdfo.c<br>
-devices/vector/gdevpdti.c<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-11 04:30:56 +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=4d2b25f06c25e6e3e2b1bf319481a7442d42af8a">4d2b25f06c25e6e3e2b1bf319481a7442d42af8a</a>
-<blockquote>
-<p>
- Bug 697531 : Tidy up unused code.<br>
-<br>
- The first patch for this bug made the error return from<br>
- jbig2_word_stream_buf_get_next_word pointless so this<br>
- patch removes all the remaining redundant code.<br>
-<br>
- jbig2_word_stream_buf_get_next_word does not need to return<br>
- any value so this is now defined as a void type and the rest<br>
- of the code has been updated accordingly.<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_huffman.c<br>
-jbig2dec/jbig2_priv.h<br>
-jbig2dec/jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-15 06:13:55 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1f8ada0d7e2c19138038bccd585e412b1f7a0267">1f8ada0d7e2c19138038bccd585e412b1f7a0267</a>
-<blockquote>
-<p>
- Fix ignored return code in pdf14 transparency.<br>
-<br>
- This fixes segfaults that pop up later. Found when testing multi-threaded<br>
- rendering with (somewhat) constrained memory (-K256000) on the file:<br>
- tests_private/pdf/sumatra/x_-_renders_slowly.pdf.ppmraw.300.0<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-15 14:59:27 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=460ef0691145c8c81e238f61baa5009c29838304">460ef0691145c8c81e238f61baa5009c29838304</a>
-<blockquote>
-<p>
- pdfwrite - improve commit ad3e0de3e3ca33f00c81c071560bf6c9f4d5a0f0<br>
-<br>
- Use gs_note_error instead of simply returning an error, and don't<br>
- bother checking pdfont, since we check for NULL immediately above.<br>
-<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-14 16:47:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=120f8533b705142ef83b899736e41e5739df5fc2">120f8533b705142ef83b899736e41e5739df5fc2</a>
-<blockquote>
-<p>
- Tweak the string that controls the greeting message<br>
-<br>
- For GPL releases we print a greeting message on execution that states the<br>
- software is supplied without warranty.<br>
-<br>
- So, we should check for it being the GPL release before printing it.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-15 10:01:39 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad3e0de3e3ca33f00c81c071560bf6c9f4d5a0f0">ad3e0de3e3ca33f00c81c071560bf6c9f4d5a0f0</a>
-<blockquote>
-<p>
- pdfwrite - don't seg fault for Line Printer font and UFST<br>
-<br>
- Using the PCL Line Printer Font, when built to use UFST, can't be<br>
- handled with pdfwrite currently. In fact, using UFST with pdfwrite<br>
- results in garbage output anyway.<br>
-<br>
- However, we should not seg fault. So here we check to see if we have a<br>
- PDF Font resource associated with a native font, and if we don't have<br>
- one when we need it, we give up and signal an invalidfont error.<br>
-<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-14 11:50:34 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=836e9a34c17b8bc2fdb4376f572982dfe1412ae0">836e9a34c17b8bc2fdb4376f572982dfe1412ae0</a>
-<blockquote>
-<p>
- Make frac31s hold values in the defined range in all cases.<br>
-<br>
- frac31s are supposed to hold values where 0x7ff..... represents 1.<br>
-<br>
- The code, however, currently converts to and from devn values using<br>
- 0x00007ff8 as 1.<br>
-<br>
- Either we need to update the docs, or we need to fix the code to be<br>
- consistent. This is an attempt at the latter.<br>
-<br>
-base/gdevdsha.c<br>
-base/gscicach.c<br>
-base/gxcvalue.h<br>
-base/gxfrac.h<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-14 15:37:43 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b969fb501f59d807d54fcfc186b7b97b55cebe0f">b969fb501f59d807d54fcfc186b7b97b55cebe0f</a>
-<blockquote>
-<p>
- XPS interpreter - fix some Coverity warnings<br>
-<br>
- Check a few values read from TT tables to satisfy Coverity 'tainted<br>
- scalar' errors.<br>
-<br>
- May need some additional changes, but I can't see any way to validate<br>
- the unsigned 32 bit values.<br>
-<br>
-xps/xpsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-14 12:48:10 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7273aa3cd04e0acb212e335ab6b3f360cbd727c9">7273aa3cd04e0acb212e335ab6b3f360cbd727c9</a>
-<blockquote>
-<p>
- Fix SAFER issue with filenameforall<br>
-<br>
- With the change to ensure we only apply SAFER permissions to real file system<br>
- operations (so only on '%os%' and not on other PS '%&lt;device&gt;%' devices), the<br>
- way filenameforall called the permission checking function meant it did not<br>
- work correctly.<br>
-<br>
- Basically, check_file_permissions() and co must have a valid iodev parameter<br>
- passed to them to function correctly.<br>
-<br>
- So, fix that call.<br>
-<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-14 10:22:46 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b3acfdeaf1eb63a07e8169ea4c30ace7522054bc">b3acfdeaf1eb63a07e8169ea4c30ace7522054bc</a>
-<blockquote>
-<p>
- Yet more SAFER problems with .libfile<br>
-<br>
- With the change to ensure we only apply SAFER permissions to real file system<br>
- operations (so only on '%os%' and not on other PS '%&lt;device&gt;%' devices), the<br>
- .libfile call was dropping through without being restricted.<br>
-<br>
- This changes the .libfile code to call the permissions checking function<br>
- properly.<br>
-<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-14 09:37: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=3d14e0b20dfdc05cda60f7a9a4c78e9d3ee206e2">3d14e0b20dfdc05cda60f7a9a4c78e9d3ee206e2</a>
-<blockquote>
-<p>
- Split out $(MAKE) from recursive make calls<br>
-<br>
- Commit 8acec58309 consolidate the common parts of the various recursive make<br>
- calls. Turns out, this breaks parallel make, as it defeats the make<br>
- algorithm which spots a make command line. As a result, none of those recursive<br>
- make calls would do parallel builds.<br>
-<br>
- So, this time, we keep the options consolidated into a make variable, but put<br>
- back the $(MAKE) call explicitly for each recursive call<br>
-<br>
-base/unix-end.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-13 16:02:54 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e36d3979ebcaa1ce28f7c58e7e1c7a5959816eb8">e36d3979ebcaa1ce28f7c58e7e1c7a5959816eb8</a>
-<blockquote>
-<p>
- Fix Windows UFST build.<br>
-<br>
-psi/msvc.mak<br>
-windows/ghostscript-ufst.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-09 20:32:56 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c7d5567fbc5f98488761ab93eaed60f1ac26023e">c7d5567fbc5f98488761ab93eaed60f1ac26023e</a>
-<blockquote>
-<p>
- Bug 697484: fix mkromfs memory leak<br>
-<br>
- In commit aa28186288 we missed the need to free some of the memory used during<br>
- the file name sorting phase.<br>
-<br>
-base/mkromfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-09 15:54: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=e476d710841d8be4d4e56c2b9e468e914f977161">e476d710841d8be4d4e56c2b9e468e914f977161</a>
-<blockquote>
-<p>
- ramfs: fix modes other than (r) and (w)<br>
-<br>
- The (a), (r+) and (w+) modes were not working correctly. The &quot;core&quot; code of the<br>
- ramfs was correct, but the &quot;glue&quot; code between the Ghostscript stream API<br>
- and the ramfs core was not setting flags to support those.<br>
-<br>
- Conversely, the ramfs &quot;glue&quot; code was not setting the permissions flags<br>
- correctly in the stream objects it created, when using the &quot;+&quot; modes.<br>
-<br>
- Also, (w) and (w+) were not truncating the file on opening.<br>
-<br>
- Finally, tweak the definition of the various read/write/etc flags for the<br>
- ramfs code so the values match those used in the stream API (this makes fixing<br>
- the flags in the stream objects much simpler).<br>
-<br>
-base/gsioram.c<br>
-base/lib.mak<br>
-base/ramfs.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-07 15:44:52 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=42fd2f459098bfda17ca8d29195ada57154cfe06">42fd2f459098bfda17ca8d29195ada57154cfe06</a>
-<blockquote>
-<p>
- Change how we check for artibrary file accesses<br>
-<br>
- When we apply the SAFER restrictions, we have to *not* apply the rules<br>
- for Postscript devices (such as %rom%, %calendar% etc), we only want to apply<br>
- the restrictions to the &quot;real&quot; file system (%os%).<br>
-<br>
- Previously the code was checking if the iodev's &quot;open_file&quot; method was set to<br>
- the one for the %os% device, but that is actually not set (it is intentionally<br>
- NULL), so here we check the i/o device instance to ensure it is not the<br>
- i/o device instance for %os%<br>
-<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-01 12:46:57 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd3c9ba2839ada5162aaccfeb442a958bfea637c">dd3c9ba2839ada5162aaccfeb442a958bfea637c</a>
-<blockquote>
-<p>
- Build exes from static lib builds.<br>
-<br>
- Add targets to build executables linked to the static library builds, meaning we<br>
- can actually test the static libs we create.<br>
-<br>
-base/unix-end.mak<br>
-base/unixlink.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-12 20:55:11 +0100
-</strong>
-<br>Stefan Brüns &lt;stefan.bruens@rwth-aachen.de&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aa2818628843205283c563865cd56b4091f2e37f">aa2818628843205283c563865cd56b4091f2e37f</a>
-<blockquote>
-<p>
- Bug 697484: mkromfs: sort gp_enumerate_files output....<br>
-<br>
- for deterministic ROM contents<br>
-<br>
- gp_enumerate_files_next returns dir entries in the same order as returned<br>
- by readdir. Sort by name to generate deterministic output.<br>
-<br>
-base/mkromfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-12 18:04:57 +0100
-</strong>
-<br>Stefan Brüns &lt;stefan.bruens@rwth-aachen.de&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=98696f718b5c0f9a5fd9c33d61f81da469b9a4e1">98696f718b5c0f9a5fd9c33d61f81da469b9a4e1</a>
-<blockquote>
-<p>
- Bug 697484: mkromfs: make build reproducible.....<br>
-<br>
- use buildtime from SOURCE_DATE_EPOCH<br>
-<br>
- The environment variable SOURCE_DATE_EPOCH is the common approach for<br>
- getting reproducible timestamps and thus builds. In case the variable<br>
- is not set, keep using the current time of the mkromfs run.<br>
-<br>
- Signed-off-by: Stefan Brüns &lt;stefan.bruens@rwth-aachen.de&gt;<br>
-<br>
-base/mkromfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-07 22:15:58 +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=4c7b41dff7d57be0e13de15c45b0296602e63472">4c7b41dff7d57be0e13de15c45b0296602e63472</a>
-<blockquote>
-<p>
- Bug 697531 : Fix decoder error on JBIG2 compressed image.<br>
-<br>
- The problem is in jbig2_word_stream_buf_get_next_word<br>
- returning -1 and sending a fail error causing the whole<br>
- file to fail.<br>
-<br>
- Now when the buffer is exhausted, the returned value is set<br>
- to zero so that the decoder does not try to use an<br>
- unintialised value.<br>
-<br>
- This now means the error return is pointless and another<br>
- commit will follow this one to tidy up the unused code.<br>
-<br>
-jbig2dec/jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-08 10:46:58 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ca4d2cc269effd69273112ec7ad9d40076abbc1">7ca4d2cc269effd69273112ec7ad9d40076abbc1</a>
-<blockquote>
-<p>
- Increase PDF 1.4 transparency ESTIMATED_ROW_SPACE<br>
-<br>
- Testing showed that the ESTIMATED_PDF14_ROW_SPACE was too optimistic, so<br>
- increase NUM_PDF14_BUFFERS to 4 and use the target num_components (primarily<br>
- for spot color devices such as tiffsep) to try and make this more robust.<br>
- Still a guess, but works better as tested with multi-threaded rendering.<br>
-<br>
- Note, the band height chosen based on the BufferSpace will be different<br>
- when the page has transparency, so there are differences. I have reviewed<br>
- them and they are all 1 pixel differences or invisible color differences.<br>
-<br>
-base/gstrans.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-08 14:49:35 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9284128b1a16c21a95570f4c79258590839a10c7">9284128b1a16c21a95570f4c79258590839a10c7</a>
-<blockquote>
-<p>
- Further fixes to ramfs.<br>
-<br>
- All allocations are made using fs-&gt;memory, so all frees should be<br>
- done with it too. This wasn't caught by memory squeezing (or other<br>
- tests), because we don't actually use the ramdisc.<br>
-<br>
-base/ramfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-07 20:28:28 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cffb5712bc10c2c2f46adf311fc74aaae74cb784">cffb5712bc10c2c2f46adf311fc74aaae74cb784</a>
-<blockquote>
-<p>
- Commit a9a58bb95 was incorrect, clearing some values that it shouldn't<br>
-<br>
- The penum-&gt;rect values were cleared, and this didn't cover all uses of<br>
- gx_image_enum_alloc. Also, return *ppenum NULL if alloc fails in case the<br>
- caller doesn't check the return code. Also, if we fail the enum_begin,<br>
- free the enum and set *pinfo to NULL.<br>
-<br>
-base/gximage1.c<br>
-base/gximage4.c<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-07 19:32:08 +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=a1b951c274a1d48340cfbaddb1308c92836dbc61">a1b951c274a1d48340cfbaddb1308c92836dbc61</a>
-<blockquote>
-<p>
- Bug 697545: Memory Squeezing fix.<br>
-<br>
- Fix for 'red 242'. This is a SEGV seen at allocation event<br>
- 242 when memory squeezing:<br>
-<br>
- gs -sDEVICE=bit -o /dev/null: examples/tiger.eps<br>
-<br>
-base/ramfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-07 19:52:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6084cc0a0cb1cd6e0d5b9be044622c74a16a0573">6084cc0a0cb1cd6e0d5b9be044622c74a16a0573</a>
-<blockquote>
-<p>
- XPS interpreter - add a reverse GID lookup for the benefit of pdfwrite<br>
-<br>
- Bug #697304 &quot;Encoding gets lost when generating PDF&quot;<br>
-<br>
- Prior to this commit the XPS interpreter, like the PCL interpreter, did<br>
- not really return a character code when asked for an equivalent for a<br>
- GID. Instead it returned the 'last' character code.<br>
-<br>
- For strings with multiple characters processed at once, this meant that<br>
- all the characters in the string were assigned the same 'code' as the<br>
- last character in the string. Also there was no reason to assume that<br>
- code was even a Unicode value.<br>
-<br>
- This commit adds code to reverse the TrueType CMAP subtable lookup;<br>
- given a GID it will return a character code. We then use the resulting<br>
- character code in pdfwrite (which is the only device to use this method)<br>
- to build a ToUnicode CMap in the output PDF file.<br>
-<br>
- There are a number of caveats with this commit;<br>
-<br>
- I've only been able to create XPS files with fonts containing format 4<br>
- CMAP subtables. While I've coded the others (but not 2 or 8 because the<br>
- normal character code -&gt; GID mapping doesn't support them either) I<br>
- have no way to actually test whether they work<br>
-<br>
- I'm not certain whether its possible to get an XPS file containing a<br>
- font which does not have a 3,1 CMAP. Again I've not been able to create<br>
- such a file, if we ever encounter one this code will likely not work<br>
- properly.<br>
-<br>
-<br>
- I have tested Latin and Far Eastern scripts, and files which use more<br>
- than 256 glyphs from a single font. All of these appear to work as<br>
- expected. When more than 256 glyphs are used from the same font, we<br>
- create a PDF file with multiple simple subsets of the font, each with<br>
- less than 256 glyphs. Each subset has its own ToUnicode CMap and so<br>
- cut&amp;paste works as expected.<br>
-<br>
- No differences expected, we cannot cluster test this code.<br>
-<br>
-xps/ghostxps.h<br>
-xps/xpsfont.c<br>
-xps/xpsttf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-07 09:42:43 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a9a58bb95e4a41014f42cae9393767b26da3aa80">a9a58bb95e4a41014f42cae9393767b26da3aa80</a>
-<blockquote>
-<p>
- Fix dangling pointer in gx_image_enum after malloc fail.<br>
-<br>
- Yet another, probably a squeezing failure since it failed with:<br>
- -K30000 -dMaxBitmap=0 -r300 -sDEVICE=pkmraw -o nul: tests/pdf/cmyk_blend.pdf<br>
-<br>
-base/gximage1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-06 19:20:40 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a65893f973c65d2ba22f8b2a2c6cf0822fc8c1da">a65893f973c65d2ba22f8b2a2c6cf0822fc8c1da</a>
-<blockquote>
-<p>
- Bug 697555: Fix UTF-8 handling of args.<br>
-<br>
- The logic for checking for continuation bytes in UTF-8 was<br>
- broken. Continuation bytes have the top bit set, but not the top 2<br>
- bits set.<br>
-<br>
- This leaves the issue of @files on windows always being taken<br>
- as UTF-8.<br>
-<br>
-base/gsargs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-01 16:31: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=c1834eb0cf024cf51231a19b975d97f33c559e0c">c1834eb0cf024cf51231a19b975d97f33c559e0c</a>
-<blockquote>
-<p>
- Fix Luratech Linux build use if &quot;inline&quot;<br>
-<br>
- Compilers don't seem to like &quot;inline&quot; being used without &quot;static&quot;, so tweak the<br>
- build flags for Luratech so that doesn't happen.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-06 12:31:12 +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=aaf0b87aa5e0c41a32a290c836a5b3811433c561">aaf0b87aa5e0c41a32a290c836a5b3811433c561</a>
-<blockquote>
-<p>
- Fix memory leak in psi/imain.c<br>
-<br>
- Remove unused &quot;paths&quot; allocation.<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-06 09:49:45 +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=e4439a505ed3ac582d7f65260678bc9dca03ce54">e4439a505ed3ac582d7f65260678bc9dca03ce54</a>
-<blockquote>
-<p>
- Bug 697545: Memory Squeezing fix.<br>
-<br>
- Fix for 'red 62'. This is a SEGV seen at allocation event<br>
- 62 when memory squeezing:<br>
-<br>
- gs -sDEVICE=bit -o /dev/null: examples/tiger.eps<br>
-<br>
- Also, improve the macro for FREE in base/gxclmem.c<br>
-<br>
-base/gsmemory.h<br>
-base/gxclmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-27 16:38:26 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2bf2b4cebe44b74229e086380c3c25110f37aed0">2bf2b4cebe44b74229e086380c3c25110f37aed0</a>
-<blockquote>
-<p>
- pdfwrite - where possible, preserve annotations<br>
-<br>
- This allows us to preserve many (but not all) annotation from an<br>
- input PDF file as annotations in the output PDF file. This only<br>
- works with the pdfwrite device, the ps2write device does not<br>
- write pdfmarks to the output.<br>
-<br>
- Certain kinds of annotations (eg Link annotations) cannot be<br>
- preserved, because they require a page (or other object) destination<br>
- which we can't easily know at the time we create the pdfmark.<br>
-<br>
- Widget annotations are not preserved as these only have relvance<br>
- in AcroForms, and since we don't preserve AcroForms, its much<br>
- better to render the Widgets, otherwise their appearance will<br>
- be lost along with the AcroForm data.<br>
-<br>
- It is possible that this behaviour may not be desirable, and<br>
- that there could be bugs in this code, so a new switch<br>
- '-dPreserveAnnots' is defined for use with the pdfwrite device<br>
- only. If set to false the old behaviour returns, and annotations<br>
- will be rendered instead of preserved.<br>
-<br>
- There are a few differences with this code; a few progressions,<br>
- a few 'differences' and one file where the Stamp annotation no<br>
- longer renders. THis is because the Form for the Apperance is<br>
- invliad (leaves junk on the stack) and attempts to work around<br>
- this ran into al kinds of trouble. In the end I ran out of time<br>
- and chose to accept the error, the form is incorrect after all.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-Resource/Init/pdf_main.ps<br>
-base/gdevp14.c<br>
-base/gsform1.h<br>
-base/gxdevsop.h<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdfu.c<br>
-devices/vector/gdevpdfx.h<br>
-doc/VectorDevices.htm<br>
-psi/zform.c<br>
-psi/zpdfops.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-04 08:36:05 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=678e660cd4efcbf155675539c13a584cdffb5258">678e660cd4efcbf155675539c13a584cdffb5258</a>
-<blockquote>
-<p>
- Fix memento builds.<br>
-<br>
-base/gsrefct.h<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-03 12:29:20 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59d509244ddb6fe9719a6205bf5657268efcb6d6">59d509244ddb6fe9719a6205bf5657268efcb6d6</a>
-<blockquote>
-<p>
- Add missing \n to error message.<br>
-<br>
-psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-03 02:53:02 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1392f5d2e7fe73bce8ff56cef62e4205f8a53bfd">1392f5d2e7fe73bce8ff56cef62e4205f8a53bfd</a>
-<blockquote>
-<p>
- Memory squeezing fixes (PCL)<br>
-<br>
- Harden PCL (and gslibctx etc) against memory failures<br>
- during initialisation.<br>
-<br>
-base/gsicc_manage.c<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-base/gsmalloc.c<br>
-pcl/pl/plalloc.c<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-03 02:48:52 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=92ecd60a5218eb5bd1ba5e497e5fd2550112b5ed">92ecd60a5218eb5bd1ba5e497e5fd2550112b5ed</a>
-<blockquote>
-<p>
- Destructors should cope with being called with NULL.<br>
-<br>
- Tweak pl level so that neat error closedown is easier.<br>
-<br>
-pcl/pl/pltop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-02 20:12:33 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd6fdc6dd668776d7b9570dd07e1e1790fcba8fb">dd6fdc6dd668776d7b9570dd07e1e1790fcba8fb</a>
-<blockquote>
-<p>
- Fix Memento builds.<br>
-<br>
- Some headers were sometimes being used with memento.h having<br>
- been included, and sometimes not. This lead to differing<br>
- redefinitions of 'free'.<br>
-<br>
-base/gsfunc.h<br>
-base/lib.mak<br>
-base/ttfoutl.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-27 16:32:07 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9060c91ef75d7d36cfc1fd975e3368415df69b3a">9060c91ef75d7d36cfc1fd975e3368415df69b3a</a>
-<blockquote>
-<p>
- New scan converter fix.<br>
-<br>
- Don't convert ex and ey from endpoints to distance until *after*<br>
- we have finished using it as an endpoint.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-02 04:07:47 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d8af3708a4907e98b5db54860d379702355dc077">d8af3708a4907e98b5db54860d379702355dc077</a>
-<blockquote>
-<p>
- Tweak gs to enable fast Memento memory squeezing.<br>
-<br>
- Memento can memory squeeze in 2 modes; firstly it can repeatedly<br>
- run the same job again and again failing at subsequent points.<br>
-<br>
- This has the advantage of being simple, but it has the problem<br>
- of being slow, in that processing is repeated again and again.<br>
-<br>
- A faster mode is available where we run to the point of failure,<br>
- then fork. The child proceeds to fail, and once failed, the<br>
- parent then continues for 1 more allocation then repeats the<br>
- process. Thus the only repeated work is in the failure cases.<br>
-<br>
- The downside to this is that fork copes very badly with<br>
- multi-threaded programs. Firstly, it only duplicates the current<br>
- thread - this means that we can only use it with single<br>
- threaded programs. Secondly, even with single threaded programs<br>
- the forked child goes wrong if you try to use mutexes etc.<br>
-<br>
- This means that in order to use GS with the fast memento memory<br>
- squeezer, we need to ensure we don't create mutexes etc. We<br>
- do this by adding a MEMENTO_SQUEEZE_BUILD define to gs.<br>
-<br>
-base/gp_psync.c<br>
-base/gsicc_cache.c<br>
-base/gsicc_lcms2.c<br>
-base/gsicc_manage.c<br>
-base/gsmalloc.c<br>
-base/sjpx_openjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-02 03:34:22 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8cca94c736bb4babc676bd2ce49176d93058b8b3">8cca94c736bb4babc676bd2ce49176d93058b8b3</a>
-<blockquote>
-<p>
- Memento memory squeezing tweaks.<br>
-<br>
- Add Memento_bt() - a function to output the backtrace<br>
- to stderr.<br>
-<br>
- Call this when we fork for a memory squeeze.<br>
-<br>
- Forking only clones the active thread, so we can only use<br>
- the forking memory squeezer on single threaded tasks. Even<br>
- with single threaded tasks, you can't unlock mutexes in<br>
- the child that were taken in the parent. This means that<br>
- we need to disable mutexes in the main application if we<br>
- want to memory squeeze safely.<br>
-<br>
- Also tweak the time we spend sleeping while waiting for a child<br>
- to die. This makes a huge difference to the runtime.<br>
-<br>
- If we die during squeezing due to a SEGV, then don't bother<br>
- listing the blocks that we leaked.<br>
-<br>
-base/memento.c<br>
-base/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-01 19:46:29 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=de2314431f400a439cb2bcebb1152fc206b8804d">de2314431f400a439cb2bcebb1152fc206b8804d</a>
-<blockquote>
-<p>
- Fix ignored return code for ICC profile device parameters.<br>
-<br>
- All of the uses of gx_default_put_icc_colorants and gx_default_put_icc<br>
- ignored the return code which might be VMerror. Found when testing with<br>
- multi-threaded rendering and low memory conditions.<br>
-<br>
-base/gsdparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-02-01 08:40:01 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cead170cb9e8dc25e59e3c8d7d8616d8b2f7119a">cead170cb9e8dc25e59e3c8d7d8616d8b2f7119a</a>
-<blockquote>
-<p>
- Memento: Improve memory squeezing.<br>
-<br>
- It seems that Memory squeezing can sometimes run into<br>
- problems with the child hanging after a fork. This seems<br>
- to be related to the child process SEGVing and the<br>
- signal handler not picking it up.<br>
-<br>
- I've introduced a workaround so that the parent now only<br>
- waits a maximum of 30 seconds before killing the child and<br>
- continuing.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-25 21:42:53 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3a9d6ebe560689930eaf3aca00652b22cef26423">3a9d6ebe560689930eaf3aca00652b22cef26423</a>
-<blockquote>
-<p>
- Bug 626295 Text Knockout Transparency<br>
-<br>
- When we have transparency, text knockout set,<br>
- with either a non-normal blend mode or an<br>
- opacity less than 1.0, we need to push a<br>
- non-isolated knockout group. Graphic state<br>
- changes can occur between the BT and ET commands.<br>
- As such, we will need to handling the push<br>
- operation in pdf14_text_begin (and the clist version)<br>
- when the conditions are right. This is a special<br>
- group that indicates its uniqueness with a text_group<br>
- flag. This flag is included through the clist, the<br>
- group as well as the device. Once set, subsequent<br>
- calls to pdf14_text_begin will not push another group.<br>
- The group is popped with ET is encountered through the<br>
- zendtransparencytextgroup command from the interpreter.<br>
- If the pdf14 device is not currently in a text group,<br>
- this group pop is ignored (and not even placed in<br>
- the clist). The pdfwrite compositor logic, ignores<br>
- and group pushes that occur with the text_group set<br>
- as well as all PDF14_END_TRANS_TEXT_GROUP types.<br>
- Due to confusion of with the annotation text writing<br>
- methods, I had to add a PDF14_BEGIN_TRANS_TEXT_GROUP<br>
- to denote when we encounter a BT in the source file<br>
- to ensure that we are only going to push groups if<br>
- our conditions are right and we are in a BT/ET pair and<br>
- not drawing a text annotation.<br>
-<br>
- One optimization we may want to look at doing later, is<br>
- determining the bbox for the area between BT and ET.<br>
- Currently the group push is the same size as the parent<br>
- group which is likely much to large.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gstparam.h<br>
-base/gstrans.c<br>
-base/gstrans.h<br>
-devices/vector/gdevpdft.c<br>
-psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-31 19:05:05 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=04c75cebae5912610526c997604f8d15fb933682">04c75cebae5912610526c997604f8d15fb933682</a>
-<blockquote>
-<p>
- Fix a typo/thinko in the static lib build changes.<br>
-<br>
- I'd mistakenly used $(TOP_OBJ) instead of $(XPS_TOP_OBJS) for the XPS<br>
- static library.<br>
-<br>
-base/unixlink.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-31 15:04: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=ba07b2df0ea519b1a6e9fcdfe6f7a25be92264fa">ba07b2df0ea519b1a6e9fcdfe6f7a25be92264fa</a>
-<blockquote>
-<p>
- Fix Windows build<br>
-<br>
- In adding/tidying the Unix-like static library targets, I forgot to tweak the<br>
- VS nmake Makefiles to cope with the revisions. Done here.<br>
-<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-31 10:05:11 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8acec5830978b1199b3cda4eae3064deb4d91818">8acec5830978b1199b3cda4eae3064deb4d91818</a>
-<blockquote>
-<p>
- Consolidate recurive make calls<br>
-<br>
- We have various classes of target (e.g. debug, profile etc) that rely on<br>
- recursively calling make with specific sets of options per class.<br>
-<br>
- Put the make call and the options into a macro for each class<br>
-<br>
-base/unix-end.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-31 09:12:34 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d9e40fcbf0a213e6717e1ab3bd234f5b20ca1270">d9e40fcbf0a213e6717e1ab3bd234f5b20ca1270</a>
-<blockquote>
-<p>
- Add debug static lib targets.<br>
-<br>
- For neatness, I've moved the &quot;visible&quot; targets to unix-end.mak with the other<br>
- Unix-like targets.<br>
-<br>
- And then added the recursive make calls to build debug versions.<br>
-<br>
-base/unix-end.mak<br>
-base/unixlink.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-31 08:57:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7718fe48373ff62f140d33080af9f49fc21b9f39">7718fe48373ff62f140d33080af9f49fc21b9f39</a>
-<blockquote>
-<p>
- Tidy/Add static lib target(s).<br>
-<br>
- Tidy up the libgs target for the gs static library on Unix-like systems (since<br>
- we're now using it).<br>
-<br>
- Rejig the PCL, XPS and PDL executable builds to a) more closely match the gs<br>
- one, and b) facilitate static library targets for those, too.<br>
-<br>
- Add the static library targets for the PCL/XPS/PDL builds (libgpcl6, libgxps<br>
- and libgpdl respectively).<br>
-<br>
-base/gs.mak<br>
-base/unixlink.mak<br>
-gpdl/gpdl.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-30 15:05:36 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=94278ad478278567dbdfcb87137676ff73e86c22">94278ad478278567dbdfcb87137676ff73e86c22</a>
-<blockquote>
-<p>
- XPS Transparency check remote resource dictionary<br>
-<br>
- The XPS interpreter checks for the presence of transparency<br>
- on the page. It was not checking remote resource dictionaries<br>
- but rather was assuming that they always had transparency<br>
- which resulted in an unneeded push of the pdf14 device when<br>
- going to a raster output device.<br>
-<br>
-xps/xpsanalyze.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-30 14:08:52 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=587d0a7edfd3519bd28981eb2703cfaaf11c747c">587d0a7edfd3519bd28981eb2703cfaaf11c747c</a>
-<blockquote>
-<p>
- Fix coverity issues 140991 and 140990<br>
-<br>
- Introduced from http://git.ghostscript.com/?p=ghostpdl.git;a=commit;h=91741e126688807cd086dad55158cd0cad63725a<br>
-<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-27 12:17:00 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8cde4bc582904132bd8bb78e6c5da5ab2ebdb6ce">8cde4bc582904132bd8bb78e6c5da5ab2ebdb6ce</a>
-<blockquote>
-<p>
- XPS Transparency check<br>
-<br>
- The XPS interpreter code was not setting the device param to<br>
- indicate if a page had transparency. As such, the fact that<br>
- a page had transparency was not getting used in the decision<br>
- to invoke or not invoke the command list.<br>
-<br>
-xps/ghostxps.h<br>
-xps/xpspage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-30 07:25:59 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=827ab0227853b9ee5491ceb76b178757aa2ab733">827ab0227853b9ee5491ceb76b178757aa2ab733</a>
-<blockquote>
-<p>
- Fix a potential de-reference of a NULL pointer with -Zv<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-27 13:24:32 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91741e126688807cd086dad55158cd0cad63725a">91741e126688807cd086dad55158cd0cad63725a</a>
-<blockquote>
-<p>
- xps: low memory null dereference<br>
-<br>
- If the allocation in xps_new_part fails, it returns<br>
- a null object which is then getting dereferenced.<br>
-<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-26 11:35:38 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c27947491f9b4bc87b09bff0648e1816ebd2af19">c27947491f9b4bc87b09bff0648e1816ebd2af19</a>
-<blockquote>
-<p>
- Segfault in low memory configurations<br>
-<br>
- Testing with -K values for bug 697504, I was able to reproduce some<br>
- segfaults, but don't know if they relate to the one mentioned here and<br>
- on bug 691170 (which was closed as fixed), but these need to get fixed<br>
- in any case.<br>
-<br>
- These occured because the init2 had not completed, but the interp was<br>
- being called to do more stuff than it could reasonably hope to do in<br>
- this case. Testing with -K values from 15000 down to 100 by 100 now<br>
- no longer segfaults.<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-26 18:09:06 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0734126eafa7c9212341886626d15d90ccce400f">0734126eafa7c9212341886626d15d90ccce400f</a>
-<blockquote>
-<p>
- Add XPS_INDIRECTED_FILE_ACCESS define<br>
-<br>
- If defined, then the xps interpreter looks to use user<br>
- supplied xps_{fopen,ftell,fseek,getc,fread,fclose} functions<br>
- rather than gp_fopen,ftell,fseek,getc,fread,fclose.<br>
-<br>
-xps/ghostxps.h<br>
-xps/xpsjxr.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-25 14:41:17 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=68af8c3b1584d0b001c7bd96456caf7547a0229e">68af8c3b1584d0b001c7bd96456caf7547a0229e</a>
-<blockquote>
-<p>
- Bug 697503: Check resource path, and GenericResourceDir...<br>
-<br>
- ...paths when searching for resources.<br>
-<br>
- This relates back to bug 694509.<br>
-<br>
- If GenericResourceDir is set as a relative path, relative to a non-standard<br>
- GS_LIB search path, we have to prefix the resource path (Category/Key) with<br>
- the GenericResourceDir for the search path machinery to find the resource<br>
- file.<br>
-<br>
- *However*, if the GenericResourceDir is set in the normal way (automagically<br>
- by the initialization), then just using the plan resource path is required.<br>
-<br>
- So, try both the plain 'Category/Key' path, and the<br>
- 'GenericResourceDir/Category/Key' path.<br>
-<br>
-Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-25 16:00:40 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d07b45685976bd38e5cec8062b3a61d2ada5575">4d07b45685976bd38e5cec8062b3a61d2ada5575</a>
-<blockquote>
-<p>
- Hide more JPEG entries.<br>
-<br>
-base/gsjconf.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-24 18:07:11 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aeb0bfb6c99e1e1683a21f684c18c1363ccc16cb">aeb0bfb6c99e1e1683a21f684c18c1363ccc16cb</a>
-<blockquote>
-<p>
- Add more jpeg symbols to be hidden.<br>
-<br>
- It seems these clash with the devboards software too.<br>
-<br>
-base/gsjconf.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-20 17:02:39 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c7d005ac1c92a6fee43554fffd9a6f38c0a6b962">c7d005ac1c92a6fee43554fffd9a6f38c0a6b962</a>
-<blockquote>
-<p>
- Add GS_NO_FILESYSTEM define for systems with no FS.<br>
-<br>
- Some systems (such as ThreadX), have std headers that<br>
- define FILE, but do not actually have a real filing<br>
- system implementation. As such, they don't support<br>
- filing system enumeration.<br>
-<br>
- We therefore introduce a GS_NO_FILESYSTEM define that<br>
- stubs out the code in these entrypoints.<br>
-<br>
- At some point we may split the contents out to a different<br>
- platform, but this will probably require some careful<br>
- thinking about other functions in these files to avoid<br>
- duplication of code.<br>
-<br>
-base/gdevpipe.c<br>
-base/gp_unifs.c<br>
-base/gp_unix.c<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-19 18:49: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=9568153b12b80d477f3031b88631910082a55bc8">9568153b12b80d477f3031b88631910082a55bc8</a>
-<blockquote>
-<p>
- Add option to hide jpeg entrypoints.<br>
-<br>
- If we define GS_HIDE_INTERNAL_JPEG on build, then a series of macros<br>
- is used to rename internal JPEG entrypoints. This can prevent<br>
- symbol clashes when linking with other libraries.<br>
-<br>
- There may well be more symbols to add here in future, but this<br>
- seems to be enough to solve it for me now.<br>
-<br>
-base/gsjconf.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-24 12:41:12 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aafd60bddbb3d5cfc0d9fb726d0cf81c51805c4c">aafd60bddbb3d5cfc0d9fb726d0cf81c51805c4c</a>
-<blockquote>
-<p>
- Remove opj_clock.c from build.<br>
-<br>
- Only defines one function, that isn't used, and doesn't compile<br>
- on all platforms.<br>
-<br>
-base/openjpeg.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-24 12:41:05 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea534adfd0a3deed4f2a70d47fc9d78c1911d928">ea534adfd0a3deed4f2a70d47fc9d78c1911d928</a>
-<blockquote>
-<p>
- Fix icc34.h header to compile on ThreadX.<br>
-<br>
- Honour HAVE_STDINT_H predefine.<br>
-<br>
- Also, tweak the #ifdeffery to be more readable (IMHO).<br>
- Less nesting and rightward creep, and a more straightforward<br>
-<br>
-base/icc34.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-21 15:01:14 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eead75f44a03517ad50702f3c65d8c5784b4bfbb">eead75f44a03517ad50702f3c65d8c5784b4bfbb</a>
-<blockquote>
-<p>
- Fizes for the ramfs (%ram% device) (Bug 226943)<br>
-<br>
- There were problems with the GC not tracing the s-&gt;file pointer from the<br>
- stream (assumed to be an OS item) so change to using non_gc_memory. Also<br>
- problems with writing buffers more that a single block (not advancing<br>
- in the source buffer).<br>
-<br>
- The bytesavailable operator didn't work because there was a bogus file_limit<br>
- in the stream, and s_ram_available was wrong.<br>
-<br>
- Change the &quot;this&quot; to &quot;thisdirent&quot; so that C++ debuggers (like VS) can<br>
- show the structure contents correctly.<br>
-<br>
- The bug shows an example that can be used to run a PDF file from stdin<br>
- without needing to write a file to disk.<br>
-<br>
-base/gsioram.c<br>
-base/ramfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-23 12:33:22 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=024e9bd9a07ff906e91f78594c9d547f5228b3c6">024e9bd9a07ff906e91f78594c9d547f5228b3c6</a>
-<blockquote>
-<p>
- Force some typedef enums to be 32 bits.<br>
-<br>
- Modern C's are allowed to shrink typedef enums so that they are<br>
- only as large as required to cover all the values in the<br>
- enumeration. This can mean that typedef enums can now be byte<br>
- sized.<br>
-<br>
- This works very badly when we have an array of them, take the<br>
- address and cast it to an int *. That int * is no longer<br>
- appropriately aligned for some compilers. This happens in the<br>
- get_param code.<br>
-<br>
- We therefore add a trailing 'large' enum value to force the<br>
- enums to be large. This will break down if we ever have a platform<br>
- where ints are larger than 32bits.<br>
-<br>
-base/gscms.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-23 11:48:11 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=24cb576dd60e903466b2d78cc718b3dd4da19529">24cb576dd60e903466b2d78cc718b3dd4da19529</a>
-<blockquote>
-<p>
- MSVC: Add %ram% FS to VS project.<br>
-<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-16 18:33:25 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e6753115b8a4c72c5e526f2a0a3849391a255962">e6753115b8a4c72c5e526f2a0a3849391a255962</a>
-<blockquote>
-<p>
- Use consistent types in API and C implementation.<br>
-<br>
-base/gssprintf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-19 11:44:18 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79d6e96a8db2956c8317fd8bdeb8d8db5fd0e212">79d6e96a8db2956c8317fd8bdeb8d8db5fd0e212</a>
-<blockquote>
-<p>
- Bug 697489 xps transparency issue<br>
-<br>
- The xps interpreter was pushing transparency groups without<br>
- pushing the pdf14 device. The problem was that the interpreter<br>
- was not checking the glyphs in the resource dictionaries.<br>
-<br>
- I also optimized the code to stop checking for transparency<br>
- once it finds transparency.<br>
-<br>
-xps/xpsanalyze.c<br>
-xps/xpspage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-18 14:49:40 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a9bd0b6d95b16d594983682ae387922507e70b98">a9bd0b6d95b16d594983682ae387922507e70b98</a>
-<blockquote>
-<p>
- Bug 697489 bitrgbtags segv<br>
-<br>
- The clist compositor call was not returning the existing<br>
- compositing device in certain cases causing an issue<br>
- later in the code.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-18 13:24:20 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=56879003723e608173cdc063a8f2da4172f29a95">56879003723e608173cdc063a8f2da4172f29a95</a>
-<blockquote>
-<p>
- Bug 697488 segv in pattern code<br>
-<br>
- The transparency code was not updating the bit depth<br>
- properly when we had a color space change in the presence<br>
- of spot colors<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-18 09:43:24 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b12adcc4c201e94e1f726c8fa6ad7eea8a5f4ca7">b12adcc4c201e94e1f726c8fa6ad7eea8a5f4ca7</a>
-<blockquote>
-<p>
- Bug 697435 bitrgbtags device<br>
-<br>
- The bit depth in the device was not getting set correctly<br>
- during a color space change in the transparency code when<br>
- the target device includes tags.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-18 14:18: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=b5abd7391d4d065e6b4d05c119d2dd243bda2f4d">b5abd7391d4d065e6b4d05c119d2dd243bda2f4d</a>
-<blockquote>
-<p>
- Bug 697482: handle cff with broken /Private data<br>
-<br>
- The problem in this case is that the offset into the cff data for the /Private<br>
- dictionary definition is well beyond the end of the cff stream.<br>
-<br>
- Bounds check the offset, and if it's nonsense, treat it as a zero length<br>
- /Private dictionary (in the hope that the font doesn't actually need it.<br>
-<br>
- NOTE: /Private *is* a required entry, so *using* the font may throw an error.<br>
-<br>
-psi/zfont2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-18 14:29:18 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=90d3fb2e75aea47501dceb298ccd4f4229d4a6f3">90d3fb2e75aea47501dceb298ccd4f4229d4a6f3</a>
-<blockquote>
-<p>
- Fix error check/return logic in the CFF parser<br>
-<br>
-psi/zfont2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-17 10:48:07 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=51c5aa09762602b5dd3982ff3b92e182f1637dd4">51c5aa09762602b5dd3982ff3b92e182f1637dd4</a>
-<blockquote>
-<p>
- Bug 697435 bittags device blending color space<br>
-<br>
- In the clist case, there was a mixup with the ICC profile<br>
- during playback. This fixes that issue. While the small<br>
- file in Bug 697433 works with this fix, the large file<br>
- (regression3.pdf) still shows 2 issues. When the blending<br>
- color space is -sBlendColorProfile=default_cmyk.icc at 300dpi<br>
- we see a dropped band (likely some confusion about the<br>
- pdf14/clist optimization). When we use no blending color<br>
- space we end up with a segv in clist_playback_band<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-13 19:16:56 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0dbfbb773e40d23de5052fc5641387dad5d79bae">0dbfbb773e40d23de5052fc5641387dad5d79bae</a>
-<blockquote>
-<p>
- Code cleanup. Remove unused code in transparency code.<br>
-<br>
-base/gdevp14.c<br>
-base/gscolorbuffer.c<br>
-base/gscolorbuffer.h<br>
-base/lib.mak<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-13 12:33:05 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8aa6b2ae6b27912339548380b602b8e3e6d17db3">8aa6b2ae6b27912339548380b602b8e3e6d17db3</a>
-<blockquote>
-<p>
- Bug 697435 Tags device with Blending color space<br>
-<br>
- Allow the use of put_image when we specified a blending color space.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-12 13:25: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=7d97633daa0679a688a85a8a8805c261bd828a7e">7d97633daa0679a688a85a8a8805c261bd828a7e</a>
-<blockquote>
-<p>
- Add bitrgbtags device to Windows default build.<br>
-<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-12 13:16:58 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3434578b240b1e4bc34a0ce108595653e0994a11">3434578b240b1e4bc34a0ce108595653e0994a11</a>
-<blockquote>
-<p>
- Add basic support for CMYK PAM (P7) format files.<br>
-<br>
- This works for the files generated by Ghostscript and mupdf, so it<br>
- is useful enough to add.<br>
-<br>
-lib/viewpbm.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-11 09:58:34 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0130e9cc9f196b4bd2e107cd71826210a8274c9d">0130e9cc9f196b4bd2e107cd71826210a8274c9d</a>
-<blockquote>
-<p>
- Fix SEGV bug 697473 bitrgbtags device with transparency<br>
-<br>
- The SEGV was caused by setting tos-&gt;n_planes to the wrong value if we<br>
- converted colors to a different number of color components. Also fix<br>
- clearing of the tags if the backdrop was NULL (leave it set as it was<br>
- by pdf14_buf_new to GS_UNKNOWN_TAG).<br>
-<br>
- Lastly, the pdf14_put_image wasn't setting up the buffer pointers for<br>
- all of the planes (alpha and tag), so bit_put_image choked. This<br>
- probably would have caused a problem with pngalpha.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-11 10:08: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=e424a42d269a626db054fb76e481df011ec6f1d6">e424a42d269a626db054fb76e481df011ec6f1d6</a>
-<blockquote>
-<p>
- pdfwrite: set the 'bytes_decoded' value in the text enum<br>
-<br>
- For CIDFont subsitutions (and spotting single byte space characters), we need<br>
- to know how many bytes were read from the input string for the current glyph,<br>
- hence we have the 'bytes_decoded' value. For one code path, pdfwrite was<br>
- failing to set the value.<br>
-<br>
-devices/vector/gdevpdtc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-11 09:16:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aedc5a96d855086711b8accd48bd014dd57b18fa">aedc5a96d855086711b8accd48bd014dd57b18fa</a>
-<blockquote>
-<p>
- Fix the profile (pg) build.<br>
-<br>
-base/unix-end.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-11 09:19:07 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=40869fa69cdb74126977e35c2028d4176d350cdb">40869fa69cdb74126977e35c2028d4176d350cdb</a>
-<blockquote>
-<p>
- Improve CIDFont rearranged font handling slightly<br>
-<br>
- Noticed while investigating a customer problem. We do not handle<br>
- rearranged fonts (because they are a hideous hack) but we do have code<br>
- to at least process them. Unfortunately there's a typo in the code which<br>
- causes it to throw an error if its ever executed.<br>
-<br>
- Fix the typo here.<br>
-<br>
- The fact that this has never come up indicates how often this mess is<br>
- used; ie never.<br>
-<br>
-Resource/Init/gs_cmap.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-04 13:13:14 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8360852efab5643d93cc3b040832075e199cd205">8360852efab5643d93cc3b040832075e199cd205</a>
-<blockquote>
-<p>
- Bug 697462: pdfwrite: avoid cached glyph use<br>
-<br>
- When pdfwrite is accumulating a Type 3 font, and we want to try to capture the<br>
- CharProc (rather than falling back to a bitmap), we need to stop the core<br>
- font code from using a previously cached glyph bitmap (for example, from an<br>
- earlier stringwidth operation), so we're sure the CharProc gets executed.<br>
-<br>
- If we don't ensure the cache doesn't get used, we end up in an infinite loop,<br>
- where pdfwrite repeatedly returns to the core to run the CharProc.<br>
-<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-06 15:37:08 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3f4e699c31368a08b0146ef62f5b196315bd700d">3f4e699c31368a08b0146ef62f5b196315bd700d</a>
-<blockquote>
-<p>
- Update color document with new GS logo<br>
-<br>
-doc/GS9_Color_Management.pdf<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-06 09:59:29 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=434ae2a49e9b6026a3ae1eeceb0f32b78a894ee1">434ae2a49e9b6026a3ae1eeceb0f32b78a894ee1</a>
-<blockquote>
-<p>
- Color code clean up.<br>
-<br>
-base/gdevp14.c<br>
-base/gsicc_cache.c<br>
-base/gsicc_manage.c<br>
-base/gsicc_manage.h<br>
-psi/zicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-06 09:56:15 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=32765969861bee5773b5f1207dae2500fa1fd506">32765969861bee5773b5f1207dae2500fa1fd506</a>
-<blockquote>
-<p>
- Update color management documentation<br>
-<br>
-doc/GS9_Color_Management.pdf<br>
-doc/GS9_Color_Management.tex<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-05 15:21:22 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2259f4c693d02a43c007cab6cb268fa4e6d6c542">2259f4c693d02a43c007cab6cb268fa4e6d6c542</a>
-<blockquote>
-<p>
- Tidy variable naming in iapi.{c,h}<br>
-<br>
- Use 'instance' consistently.<br>
-<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-03 14:37:26 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f45ea017e9691c2b817884746306d27e06e0199">2f45ea017e9691c2b817884746306d27e06e0199</a>
-<blockquote>
-<p>
- Windows gs: Avoid unininitialised read.<br>
-<br>
-pcl/pl/plwmainc.c<br>
-psi/dpmain.c<br>
-psi/dwmain.c<br>
-psi/dwmainc.c<br>
-psi/dxmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-03 10:17:13 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8071bb2950068a3c6a1b5a405d16548177503a14">8071bb2950068a3c6a1b5a405d16548177503a14</a>
-<blockquote>
-<p>
- New scan converter: Fix some warnings.<br>
-<br>
- &quot;ey is set and then never used&quot; in some release builds.<br>
-<br>
- Rejig the code to avoid this.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-02 18:27:50 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=06e756898579cd21dbff40ad30efff9571a549fe">06e756898579cd21dbff40ad30efff9571a549fe</a>
-<blockquote>
-<p>
- New scan converter: Fix problems in trap fills.<br>
-<br>
- I was calculating trapezium fills slightly wrong.<br>
-<br>
- Also, I was filling the 'centre of a pixel' cases edgebuffers<br>
- with slightly incorrect values. Now the debugging shows that<br>
- we are getting exactly what we want in the example files I<br>
- have tried.<br>
-<br>
- This results in much smoother edges on some shapes.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2017-01-02 18:25:08 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb1f10f6eaed79016dd924b2e5730160e9267fd3">fb1f10f6eaed79016dd924b2e5730160e9267fd3</a>
-<blockquote>
-<p>
- New scan converter: Improved debugging.<br>
-<br>
- Update the debugging output from the new scan converter to be<br>
- more useful.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-29 14:00:21 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=90fd0c7ca3efc1ddff64a86f4104b13b3ac969eb">90fd0c7ca3efc1ddff64a86f4104b13b3ac969eb</a>
-<blockquote>
-<p>
- Bug 697456. Dont create new ctx when pdf14 device reenabled<br>
-<br>
- This bug had yet another weird case where the user created a<br>
- file that pushed the pdf14 device twice. We were in that case,<br>
- creating a new ctx and blowing away the original one with out<br>
- proper clean up. To avoid, only create a new one when we need it.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-29 12:00:40 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d621292fb2c8157d9899dcd83fd04dd250e30fe4">d621292fb2c8157d9899dcd83fd04dd250e30fe4</a>
-<blockquote>
-<p>
- Bug 697444 Unmatched transparency group pop<br>
-<br>
- This issue can only occur if there is an unmatched group pop.<br>
- If the interpreter is doing that, then the interpreter is<br>
- broken. With this bug the user is intentionally doing it.<br>
- We now throw and error when it occurs.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-29 15:57:43 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4bef1a1d32e29b68855616020dbff574b9cda08f">4bef1a1d32e29b68855616020dbff574b9cda08f</a>
-<blockquote>
-<p>
- Bug 697453: Avoid divide by 0 in scan conversion code.<br>
-<br>
- Arithmetic overflow due to extreme values in the scan conversion<br>
- code can cause a division by 0.<br>
-<br>
- Avoid this with a simple extra check.<br>
-<br>
- dx_old=cf814d81<br>
- endp-&gt;x_next=b0e859b9<br>
- alp-&gt;x_next=8069a73a<br>
-<br>
- leads to dx_den = 0<br>
-<br>
-base/gxfill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-29 13:39:50 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0aeb0bbd41cc16e70ab6e4b1d56e0c510bf2a758">0aeb0bbd41cc16e70ab6e4b1d56e0c510bf2a758</a>
-<blockquote>
-<p>
- Bug 697423: Fix overflow in pngalpha.<br>
-<br>
- The composite creation maths in the copy_alpha method overflowed<br>
- due to the alpha range being changed from 0..15 to 0..255 in<br>
- commit d9f041d6fe7eda89364df1424f85ace974ed0fec. Changing to<br>
- unsigned solves this.<br>
-<br>
-devices/gdevpng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-28 18:34: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=a7f3177cb0ae8f56cfec52ea38a4f6f613c91055">a7f3177cb0ae8f56cfec52ea38a4f6f613c91055</a>
-<blockquote>
-<p>
- New scan converter: Fix problems seen at local minima/maxima.<br>
-<br>
- Sometimes the fill isn't quite right at the extremes of shapes.<br>
-<br>
- This is due to a problem when we exactly align with scanlines.<br>
-<br>
- See the output of tests_private/comparefiles/Bug696174.ps at 300dpi<br>
- for some examples. Look at the tie lines for the first notes in the<br>
- last line of page 2 - a scanlines worth of pixels are missing from<br>
- the top.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-28 14:16:00 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79572779090e4f777bfd21996f04ff9bddcd3cbc">79572779090e4f777bfd21996f04ff9bddcd3cbc</a>
-<blockquote>
-<p>
- New scan converter: Fix zero height rectangle behaviour.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-27 16:18:40 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=290c044b5156b8111326da25738cbc3c1ad2b182">290c044b5156b8111326da25738cbc3c1ad2b182</a>
-<blockquote>
-<p>
- Add some debug code to new scan converter.<br>
-<br>
- Output the rectangles/traps filled by the scan converter as<br>
- postscript.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-23 19:39: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=deb69ac011df1cc58a0da4c08123e2aebf819c7e">deb69ac011df1cc58a0da4c08123e2aebf819c7e</a>
-<blockquote>
-<p>
- New scanconverter; fix various problems<br>
-<br>
- 1) Fix problems seen when stroke and fills don't line up.<br>
-<br>
- This turns out to be because fills done with traps and &quot;any<br>
- part of a pixel&quot; (APP) were being rounded wrongly. Fixed here.<br>
-<br>
- 2) Fix some debug statements.<br>
-<br>
- 3) Fix some centre of pixel trap filling code - the code to<br>
- look for the 'end' of traps was failing due to only comparing<br>
- the first half of the intercepts on a given line.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-22 17:27:11 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8d722263343e7c17769cc4026a76cc28046a8e1a">8d722263343e7c17769cc4026a76cc28046a8e1a</a>
-<blockquote>
-<p>
- Fix new scan converter.<br>
-<br>
- When filling by traps with any part of a pixel in the new scan<br>
- converter, we were hitting cases where we we missing parts<br>
- of lines.<br>
-<br>
- As seen in the borders of the &quot;CPU&quot; and &quot;CACHE&quot; boxes on:<br>
-<br>
- gs -dSCANCONVERTERTYPE=2 -o out.png -sDEVICE=png16m -r72<br>
- -dFirstPage3 -dLastPage3 tests/pdf/Bug6901014_SMP_Warwick_14.pdf<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-22 17:26:24 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0c625d998fb85d87b6184bd52bfeee954746a2cd">0c625d998fb85d87b6184bd52bfeee954746a2cd</a>
-<blockquote>
-<p>
- Improve debugging in new scan converter.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-22 10:34: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=64fcc1460ef1af131c17d3ced0f01ec755243986">64fcc1460ef1af131c17d3ced0f01ec755243986</a>
-<blockquote>
-<p>
- Fix a scan-build warning<br>
-<br>
- The return value stored in code wasn't being actioned, move it to<br>
- code1 instead.<br>
-<br>
-devices/vector/gdevpdfv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-21 18:16:28 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5924a809c21ce8564c72b9917e4a5fbd278049ad">5924a809c21ce8564c72b9917e4a5fbd278049ad</a>
-<blockquote>
-<p>
- Fix double pixels writes in new scanconverter.<br>
-<br>
- When scan converting to scanlines with any part of a pixel<br>
- we have to be careful not to double write pixels. The logic<br>
- for this was broken. Fix it here.<br>
-<br>
- Seen with:<br>
-<br>
- gs -dSCANCONVERTERTYPE=2 -o out.png -sDEVICE=png16m -r72<br>
- tests_private/comparefiles/Bug687295c.pdf<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-21 16:54:14 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=daf85701dab05f17e924a48a81edc9195b4a04e8">daf85701dab05f17e924a48a81edc9195b4a04e8</a>
-<blockquote>
-<p>
- fix crash with bad data supplied to makeimagedevice<br>
-<br>
- Bug #697450 &quot;Null pointer dereference in gx_device_finalize()&quot;<br>
-<br>
- The problem here is that the code to finalise a device unconditionally<br>
- frees the icc_struct member of the device structure. However this<br>
- particular (weird) device is not setup as a normal device, probably<br>
- because its very, very ancient. Its possible for the initialisation<br>
- of the device to abort with an error before calling gs_make_mem_device()<br>
- which is where the icc_struct member gets allocated (or set to NULL).<br>
-<br>
- If that happens, then the cleanup code tries to free the device, which<br>
- calls finalize() which tries to free a garbage pointer.<br>
-<br>
- Setting the device memory to 0x00 after we allocate it means that the<br>
- icc_struct member will be NULL&lt; and our memory manager allows for that<br>
- happily enough, which avoids the problem.<br>
-<br>
-base/gsdevmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-21 15:42: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=2299c9a25fc9ae7b59752f1795f8b53920901c80">2299c9a25fc9ae7b59752f1795f8b53920901c80</a>
-<blockquote>
-<p>
- pdfwrite - don't emit degenerate Matrix for type 2 Patterns<br>
-<br>
- Bug 697451 &quot;shfill with degenerate matrix leads to PDF unreadable with Acrobat&quot;<br>
-<br>
- The original file deliberately makes the CTM degenerate before drawing<br>
- a shfill. Although all PostScript consumers handle this without complaint.<br>
- When converted to PDF most PDF consumers also are happy with the<br>
- situation, however Adobe Acrobat recoils in horror and aborts the<br>
- processing of the page stream with an error.<br>
-<br>
- Adobe Acrobat Distiller simply refuses (silently!) to embed the shfill<br>
- in the PDF file.<br>
-<br>
- We don't have a way to drop the fill, so instead, if the Matrix is<br>
- degenerate, replace it with the smallest scale matrix we can. Acrobat<br>
- is happy with this.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/vector/gdevpdfv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-20 10:40:56 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d820556974dbafaed04cfe5356fc66556907128">7d820556974dbafaed04cfe5356fc66556907128</a>
-<blockquote>
-<p>
- Fix accuracy of bbox device with curves in filled paths<br>
-<br>
- Bug #697446 &quot;bbox device is inaccurate with certain curves, when filled&quot;<br>
-<br>
- The problem here is that, when a path is not clipped, is composed of<br>
- certain types of flattish curves at the boundary, we used an inaccurate<br>
- method to determine the bounds of the path.<br>
-<br>
- The old code used gx_path_bbox, which only considers the points in a path<br>
- which is a problem for curves, because it considers the control points<br>
- to be part of the curve, which they are not, and with some curves<br>
- they can lie a long way from the actual path, as in this case.<br>
-<br>
- This commit simply forces the code through the scan-converter in order<br>
- to get an accurate result, the same as the stroked code.<br>
-<br>
- No differences expected.<br>
-<br>
-base/gdevbbox.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-19 16:24:37 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79a594c9bd95239ee975e930563e7fb567018372">79a594c9bd95239ee975e930563e7fb567018372</a>
-<blockquote>
-<p>
- Fix SEGV seen with new scan converter.<br>
-<br>
- The following command:<br>
-<br>
- gs -sOutputFile=out.ppm -dMaxBitmap=400000000 -sDEVICE=ppmraw -r300<br>
- -Z: -sDEFAULTPAPERSIZE=letter -dNOPAUSE -dBATCH -K2000000 -dClusterJob<br>
- -dJOBSERVER -dSCANCONVERTERTYPE=2 %rom%Resource/Init/gs_cet.ps ~/11-11.PS<br>
-<br>
- was failing, due to a problem in the scan conversion code with<br>
- extreme paths.<br>
-<br>
-base/gxscanc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-17 10:33:18 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2d46dd9e83edc813f2047a89cd260ab4de48fdf4">2d46dd9e83edc813f2047a89cd260ab4de48fdf4</a>
-<blockquote>
-<p>
- More heuristic fixes from ToUnicode CMap changes<br>
-<br>
- Bug #697436 &quot;Chinese character can not be copied out correctly&quot;<br>
-<br>
- The changes in commit 9dba57f0f9a53c130ec2771c0ed1d7bd6bbef6ab to<br>
- properly handle ToUnicde CMaps had rippling effects throughout the<br>
- code wherever ToUnicode CMaps are read or generated. In this case the<br>
- code which turned glyph names of the form uniXXXX into Unicode code<br>
- point XXXX (in the absence of a GlyphNames2Unicode table) was not<br>
- updated correctly.<br>
-<br>
- This commit changes the allocation from two shorts to a single unsigned<br>
- short, and fill sin the data from the glyph name in big-endian format<br>
- (as required throughout the ToUnicode code now), which results in<br>
- the correct ToUnicode CMap being generated.<br>
-<br>
-devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-13 09:20:45 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=00dfdefe5d38871c0c67b08ede10a208b6897d10">00dfdefe5d38871c0c67b08ede10a208b6897d10</a>
-<blockquote>
-<p>
- Bug 693307 Overprint issues<br>
-<br>
- Remove the portions of code used to simulate<br>
- the overprinting of CMYK and spot colorants while<br>
- in an RGB device. This really can't work and<br>
- we are doing a real separation compositor device for<br>
- this process. The code parts removed only confuse<br>
- understanding of the overprint compositor. Also fix<br>
- problems related to Bug 693307 which were caused by<br>
- some confusion in the code with regard to the overprint<br>
- mode. Fix other issues related to the Ghent overprint<br>
- tests where we were not handling properly the case<br>
- of overprinting with a gray color when the output<br>
- device was CMYK based. Finally there were multiple<br>
- issues with the testing and setting of the overprint<br>
- settings and the use of the effective overprint mode<br>
-<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gscdevn.c<br>
-base/gscolor.c<br>
-base/gscsepr.c<br>
-base/gscspace.c<br>
-base/gsicc.c<br>
-base/gsovrc.c<br>
-base/gsovrc.h<br>
-base/gstrans.h<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-base/gxcmap.c<br>
-base/gxcspace.h<br>
-base/gxdevcli.h<br>
-base/gxoprect.c<br>
-base/gxoprect.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-15 13:56:43 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=46de0c56a0132356084b320a9f7e4d2ac1396c1c">46de0c56a0132356084b320a9f7e4d2ac1396c1c</a>
-<blockquote>
-<p>
- Bug 697435 add blending color space<br>
-<br>
- This adds the ability to specify the default (based) blending<br>
- color space for a target device when we have transparency blending.<br>
- -sBlendColorProfile=&quot;my_profile.icc&quot; is used for the specification.<br>
- Only Gray, RGB, or CMYK ICC profiles are allowed. Also, separation<br>
- devices (e.g. tiffsep and psdcmyk) will not support the use of this<br>
- at this time. Note also that if a target device has a put_image<br>
- procedure where it did its own blending or tag processing, this command<br>
- proc is not called if the blending color space is specified as the final color<br>
- conversion is applied through begin_typed_image.<br>
-<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gscms.h<br>
-base/gsdparam.c<br>
-base/gsequivc.c<br>
-base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-14 15:56:31 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=73060a27e554f8e64ae2aba4a1b03822207346c7">73060a27e554f8e64ae2aba4a1b03822207346c7</a>
-<blockquote>
-<p>
- Fix warnings: remove unsigned &lt; 0 tests that are always false.<br>
-<br>
-jbig2dec/jbig2_image.c<br>
-jbig2dec/jbig2_mmr.c<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-12 17:47: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=cecf6b592945d247bf932f6a4f50065db4acfba8">cecf6b592945d247bf932f6a4f50065db4acfba8</a>
-<blockquote>
-<p>
- Squash signed/unsigned warnings in MSVC jbig2 build.<br>
-<br>
- Also rename &quot;new&quot; to &quot;new_dict&quot;, because &quot;new&quot; is a bad<br>
- variable name.<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_huffman.h<br>
-jbig2dec/jbig2_image.c<br>
-jbig2dec/jbig2_mmr.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_symbol_dict.h<br>
-jbig2dec/jbig2_text.c<br>
-jbig2dec/jbig2_text.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-12 08:31:34 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0efaa8dff5b82169313a086861597e0f455892d3">0efaa8dff5b82169313a086861597e0f455892d3</a>
-<blockquote>
-<p>
- Bug 697350. Fix isolated knockout group rendering<br>
-<br>
- The blending code in the knockout isolate case had issues<br>
- and the only difference compared to the non-isolated case<br>
- is that we don't need to do the blend with the backdrop.<br>
-<br>
-base/gdevp14.c<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-12 17:53: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=15d9aaac64334776284310f5cbfe8ae79edae540">15d9aaac64334776284310f5cbfe8ae79edae540</a>
-<blockquote>
-<p>
- Squash annoying MSVC warning.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-09 19:29:37 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f5ac81f27674c54540c6313ed31b027f1385ceb5">f5ac81f27674c54540c6313ed31b027f1385ceb5</a>
-<blockquote>
-<p>
- Add ETS to Downscaler.<br>
-<br>
- Currently only hooked up for tiffscaled and tiffscaled4.<br>
-<br>
- Enable using -dDownScaleETS=1 along with the usual other downscaler<br>
- hooks.<br>
-<br>
- No control over all the myriad ETS flags as yet.<br>
-<br>
-base/ets.c<br>
-base/ets.h<br>
-base/ets_tm.h<br>
-base/gxdownscale.c<br>
-base/gxdownscale.h<br>
-base/lib.mak<br>
-devices/gdevtifs.c<br>
-devices/gdevtifs.h<br>
-devices/gdevtsep.c<br>
-doc/Devices.htm<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-09 12:33:41 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd50b33582901eda25fce78a40552de91db3c8e5">dd50b33582901eda25fce78a40552de91db3c8e5</a>
-<blockquote>
-<p>
- Use normal blend mode for spots when mode is non-white preserving<br>
-<br>
- When we are doing the group compositing, make sure to catch the<br>
- cases where we have spot colorants and the blend modes is either<br>
- non-separable or non-white preserving. In those cases, the spot<br>
- colorants have to use the normal blend mode.<br>
-<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-09 10:43:57 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8894abf2985a58900e778957f93151b6cec1c17a">8894abf2985a58900e778957f93151b6cec1c17a</a>
-<blockquote>
-<p>
- Address a segfault and error introduced in 4b3be09<br>
-<br>
- In the zbegintransparencymaskgroup with a '/None' SMask parameter with the clist<br>
- in use, we get to clist_create_compositor().<br>
-<br>
- In there, the return value of the get_cropping method can be either an error<br>
- (negative) or a specific cropping operation (positive). We assign it to 'code',<br>
- and if it's an error, return it, if not, assign it to another variable. But<br>
- don't set 'code' to anything else. It is then possible to get to the end of the<br>
- function without going through the path where 'code' is used again.<br>
-<br>
- Setting 'code' to 0 after storing the cropping op solves the problem.<br>
-<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-08 18:09:58 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b3be091fa0384e679baaf04b14ea195da5adf21">4b3be091fa0384e679baaf04b14ea195da5adf21</a>
-<blockquote>
-<p>
- Bug 697415: 'clean up' after images with SMask entries<br>
-<br>
- Our handling of images with SMasks depends on telling the transparency<br>
- compositor to expect an SMask image, draw the SMask as a regular image,<br>
- tell the compositor the SMask is done, and then draw the 'main' image (to<br>
- which the compositor will apply the SMask).<br>
-<br>
- The problem was that the compositor treats SMasks from images and SMasks from<br>
- ExtGState as the same (which they really are), but the image drawing code<br>
- took no action to inform the compositor we were done with the SMask, thus<br>
- leaving it place.<br>
-<br>
- By adding a call to &quot;unset&quot; the SMask from the current graphics state (in this<br>
- case, it's really the current group in the compositor), we ensure the SMask<br>
- is only applied to the current image).<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-05 18:30:06 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c875bf7490447579e850fa4722874848c3be4657">c875bf7490447579e850fa4722874848c3be4657</a>
-<blockquote>
-<p>
- PDF Interpreter - more indirect object foolishness<br>
-<br>
- Bug #697402 &quot;PDF rendered as blank in PDF with unusual font width array&quot;<br>
-<br>
- Not ony the /Widths array of one of the fonts, but also an entry in a<br>
- /W array for a CIDFont specify a value using an indirect object<br>
- reference.<br>
-<br>
- While this is silly (it makes the PDF file larger and slower) it is legal<br>
- so this commit copes with it by dereferencing any indirect references.<br>
-<br>
- We alos now handle W2 arrays with references, even though this file<br>
- doesn't use one.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-03 06:40:17 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e16bd592aaccde9b384415a87d8a9bef9c57f83">0e16bd592aaccde9b384415a87d8a9bef9c57f83</a>
-<blockquote>
-<p>
- Fix debug output for pattern bitmaps<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-03 12:25:58 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc746214644deacd5233a1453ce660573af09443">cc746214644deacd5233a1453ce660573af09443</a>
-<blockquote>
-<p>
- txtwrite - sort out endian-ness of Unicode based on architecture<br>
-<br>
- Bug #697339 &quot;Device txtwrite seems to be broken&quot;<br>
-<br>
- decode_glyph sppears always to return big-endian shorts for Unicode<br>
- code points. On litlee-endian platforms, reverse the byte order so<br>
- that we can treat the data as shorts instead of bytes.<br>
-<br>
- As I don't have a big endian device to test this on, further work may<br>
- be required.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-02 09:00:20 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d05c99ba9f3c1539a5b02a96ed050422677d9704">d05c99ba9f3c1539a5b02a96ed050422677d9704</a>
-<blockquote>
-<p>
- Remove MarginsHWResolution non-standard device parameter<br>
-<br>
-base/gdevp14.c<br>
-base/gscoord.c<br>
-base/gsdevice.c<br>
-base/gsdevmem.c<br>
-base/gsdparam.c<br>
-base/gspath.c<br>
-base/gxclist.c<br>
-base/gxdevcli.h<br>
-base/gxdevice.h<br>
-devices/gdevbit.c<br>
-devices/gdevupd.c<br>
-devices/gdevxalt.c<br>
-devices/gdevxini.c<br>
-lib/align.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-02 19:03:42 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b880332b899e0e59d17c7e48033e5cc816e5a831">b880332b899e0e59d17c7e48033e5cc816e5a831</a>
-<blockquote>
-<p>
- pdfwrite - adjust Mono Subsample resolution to integer<br>
-<br>
- Bug #697351 &quot;/Subsample filter needs to make non-integer scales integer for monochrome images&quot;<br>
-<br>
- The only downsampling filter available for monochrome images and<br>
- imagemasks (1 bpp images and masks) is the /Subsample filter. However<br>
- the Subsample filter only works when the downsampling factor is an<br>
- exact integer.<br>
-<br>
- Its unreasonable to insist that all the monochrome images in a given<br>
- document can be downsampled to a specific resolution and that the downsample<br>
- factor for all those images will be an integer.<br>
-<br>
- So here, if the image is monochrome (so we canot switch to the Bicubic<br>
- filter) and the factor is not an integer, we force the factor to the<br>
- nearest integer.<br>
-<br>
- Also, update the documentation which incorrectly stated that when<br>
- /PDFSETTINGS was set to 'prepress', monochrome images used the Bicubic<br>
- filter, it actually uses the Subsample filter.<br>
-<br>
-devices/vector/gdevpsdi.c<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-02 17:13:35 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=26acbbb980a44d9610080876afeef5bb834d21e3">26acbbb980a44d9610080876afeef5bb834d21e3</a>
-<blockquote>
-<p>
- Documentation - Document the fact that setpagedevice resets distiller params<br>
-<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-12-02 16:33:25 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=336c69b8be32c7193909a7f25b1a073b0ac2d92f">336c69b8be32c7193909a7f25b1a073b0ac2d92f</a>
-<blockquote>
-<p>
- PDF Interpreter - have warning messages respect QUIET<br>
-<br>
- Bug #697394 &quot;stderr is included with stdout when result is set to stdout&quot;<br>
-<br>
- We do want the warnings to go to stdout, for debugging purposes,<br>
- because it is easier to use -dPDFDEBUG if the warnings are interleaved.<br>
-<br>
- For the benefit of user piping the output to stdout, have the warning<br>
- messages respect -dQUIET so they don't end up in the output file.<br>
-<br>
- Error messages (which are directed to stderr anyway) are not suppressed<br>
- as these are important.<br>
-<br>
- No differences expected<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-24 12:26:17 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a8d6c4074ee8cfc251ebdd44ce4d2f97cdf20517">a8d6c4074ee8cfc251ebdd44ce4d2f97cdf20517</a>
-<blockquote>
-<p>
- Revert commit 3cde6d6d, require %d OutputFile spec for multi-page tiffsep<br>
-<br>
- The previous commit allowed multi-page separation files, but this would only<br>
- work if all pages had the same spot colors. If a later page added a spot color<br>
- it would be appended to the set of spot colors, but then the separation layer<br>
- would be emitted with the previous spot color name (according to the order)<br>
- and the CMYK equivalent for that previous spot color would be used to make the<br>
- CMYK composite.<br>
-<br>
- Now multi-page tiffsep requires the use of %d (or some other format that uses<br>
- the page number in the filename). The first page can be output without %d, and<br>
- the second page will issue an error message and quit with ioerror.<br>
-<br>
- In theory we could wait to issue the error until we encounter a spot color order<br>
- that was not the same as the first page, but this is of little utility, and<br>
- this change makes tiffsep operate similarly to the psdcmyk device.<br>
-<br>
-devices/gdevtsep.c<br>
-doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-24 09:56:12 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f42898997f249062f5da8fcf9c3a46cd6443fb39">f42898997f249062f5da8fcf9c3a46cd6443fb39</a>
-<blockquote>
-<p>
- PDF interpreter - skip 'R' operator in invalid context<br>
-<br>
- Bug #697365 &quot;corrupted content stream causes error&quot;<br>
-<br>
- The file has 2 Form XObject whose content streams have a single garbage<br>
- byte at the end of the stream, and which forms part of the 'endstream'.<br>
-<br>
- In one case this simply leads to garbage on the stack, which we deal with<br>
- already, but in the other case the garbage happens to be a 'R character<br>
- which we attempt to process as a token.<br>
-<br>
- Now attempting to process an R operator fails in this case, because the<br>
- stack contents are not a pair of integers. However, in the process, it<br>
- removes two stack objects which we require for further processing.<br>
-<br>
- There's no way to restore those to the operand stack, and there is no<br>
- way to not process the 'R' as a token. We also cannot temporarily<br>
- define 'R' as a no-op for the course of a stream, because if the<br>
- stream uses named objects which have not already been dereferenced<br>
- we need to execute the R operator to resolve them.<br>
-<br>
- This commit modifies the definition of R so that it checks the type<br>
- of the expected operands before consuming them. If they are not both<br>
- integers then it flags an error, leaves the stack alone and exits.<br>
-<br>
- THis will, of course, be slightly slower than the current approach<br>
- which doesn't check types, but it should only be executed once<br>
- for each object in the file. Even for a large file that should only<br>
- be a few tens of thousands, and this is likely to be lost among<br>
- the processing time for real operations. However, shuold this<br>
- causew significant performance problems we may remove this in the<br>
- future.<br>
-<br>
- No differences expected.<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-23 09:26:16 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b7ea690782c306241ed94fa3bdaf296f6bcc455f">b7ea690782c306241ed94fa3bdaf296f6bcc455f</a>
-<blockquote>
-<p>
- Bug 697366<br>
-<br>
- Partial fix. Pattern now renders correctly. Issues<br>
- with a few other spots though.<br>
-<br>
-base/gdevdsha.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-23 06:58:19 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2237813596c8703de6008dd6c05460f9dac3ed75">2237813596c8703de6008dd6c05460f9dac3ed75</a>
-<blockquote>
-<p>
- Fix segv due to improper depth computation<br>
-<br>
- Commit<br>
- 47294ff5b168d25bfc7db64f51572d64b8ebde91<br>
- had an issue that was found when running<br>
- eci_altona-test-suite-v2_technical2_x4.pdf<br>
- (the Altona file with ALL the pages on one page)<br>
- with tiffsep and psdcmyk. This fixes the segv.<br>
- A rending issue remains on this issue.<br>
- Bug http://bugs.ghostscript.com/show_bug.cgi?id=697366<br>
- was opened to address.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-21 10:03:24 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5b87f18df814aaa9f0036c843a4b24b1638aa4cf">5b87f18df814aaa9f0036c843a4b24b1638aa4cf</a>
-<blockquote>
-<p>
- libtiff: update to 4.0.7<br>
-<br>
- Add in portability changes to tiffiop.h<br>
-<br>
- Portability tiffiop.h<br>
-<br>
- Remove globals from tif_pixarlog.c<br>
-<br>
-tiff/CMakeLists.txt<br>
-tiff/ChangeLog<br>
-tiff/HOWTO-RELEASE<br>
-tiff/Makefile.am<br>
-tiff/Makefile.in<br>
-tiff/RELEASE-DATE<br>
-tiff/VERSION<br>
-tiff/aclocal.m4<br>
-tiff/build/CMakeLists.txt<br>
-tiff/build/Makefile.am<br>
-tiff/build/Makefile.in<br>
-tiff/config/compile<br>
-tiff/config/depcomp<br>
-tiff/config/ltmain.sh<br>
-tiff/config/missing<br>
-tiff/config/test-driver<br>
-tiff/configure<br>
-tiff/configure.ac<br>
-tiff/configure.com<br>
-tiff/contrib/CMakeLists.txt<br>
-tiff/contrib/Makefile.am<br>
-tiff/contrib/Makefile.in<br>
-tiff/contrib/addtiffo/CMakeLists.txt<br>
-tiff/contrib/addtiffo/Makefile.am<br>
-tiff/contrib/addtiffo/Makefile.in<br>
-tiff/contrib/addtiffo/addtiffo.c<br>
-tiff/contrib/addtiffo/tif_overview.c<br>
-tiff/contrib/addtiffo/tif_ovrcache.c<br>
-tiff/contrib/dbs/CMakeLists.txt<br>
-tiff/contrib/dbs/Makefile.am<br>
-tiff/contrib/dbs/Makefile.in<br>
-tiff/contrib/dbs/xtiff/CMakeLists.txt<br>
-tiff/contrib/dbs/xtiff/Makefile.am<br>
-tiff/contrib/dbs/xtiff/Makefile.in<br>
-tiff/contrib/dbs/xtiff/xtiff.c<br>
-tiff/contrib/iptcutil/CMakeLists.txt<br>
-tiff/contrib/iptcutil/Makefile.am<br>
-tiff/contrib/iptcutil/Makefile.in<br>
-tiff/contrib/iptcutil/iptcutil.c<br>
-tiff/contrib/mfs/CMakeLists.txt<br>
-tiff/contrib/mfs/Makefile.am<br>
-tiff/contrib/mfs/Makefile.in<br>
-tiff/contrib/pds/CMakeLists.txt<br>
-tiff/contrib/pds/Makefile.am<br>
-tiff/contrib/pds/Makefile.in<br>
-tiff/contrib/ras/CMakeLists.txt<br>
-tiff/contrib/ras/Makefile.am<br>
-tiff/contrib/ras/Makefile.in<br>
-tiff/contrib/stream/CMakeLists.txt<br>
-tiff/contrib/stream/Makefile.am<br>
-tiff/contrib/stream/Makefile.in<br>
-tiff/contrib/tags/CMakeLists.txt<br>
-tiff/contrib/tags/Makefile.am<br>
-tiff/contrib/tags/Makefile.in<br>
-tiff/contrib/win_dib/CMakeLists.txt<br>
-tiff/contrib/win_dib/Makefile.am<br>
-tiff/contrib/win_dib/Makefile.in<br>
-tiff/html/CMakeLists.txt<br>
-tiff/html/Makefile.am<br>
-tiff/html/Makefile.in<br>
-tiff/html/addingtags.html<br>
-tiff/html/bugs.html<br>
-tiff/html/build.html<br>
-tiff/html/contrib.html<br>
-tiff/html/document.html<br>
-tiff/html/images.html<br>
-tiff/html/images/CMakeLists.txt<br>
-tiff/html/images/Makefile.am<br>
-tiff/html/images/Makefile.in<br>
-tiff/html/index.html<br>
-tiff/html/internals.html<br>
-tiff/html/intro.html<br>
-tiff/html/libtiff.html<br>
-tiff/html/man/CMakeLists.txt<br>
-tiff/html/man/HtmlDoc.cmake<br>
-tiff/html/man/Makefile.am<br>
-tiff/html/man/Makefile.in<br>
-tiff/html/man/TIFFClose.3tiff.html<br>
-tiff/html/man/TIFFDataWidth.3tiff.html<br>
-tiff/html/man/TIFFError.3tiff.html<br>
-tiff/html/man/TIFFFieldDataType.3tiff.html<br>
-tiff/html/man/TIFFFieldName.3tiff.html<br>
-tiff/html/man/TIFFFieldPassCount.3tiff.html<br>
-tiff/html/man/TIFFFieldReadCount.3tiff.html<br>
-tiff/html/man/TIFFFieldTag.3tiff.html<br>
-tiff/html/man/TIFFFieldWriteCount.3tiff.html<br>
-tiff/html/man/TIFFFlush.3tiff.html<br>
-tiff/html/man/TIFFGetField.3tiff.html<br>
-tiff/html/man/TIFFRGBAImage.3tiff.html<br>
-tiff/html/man/TIFFReadDirectory.3tiff.html<br>
-tiff/html/man/TIFFReadEncodedStrip.3tiff.html<br>
-tiff/html/man/TIFFReadEncodedTile.3tiff.html<br>
-tiff/html/man/TIFFReadRGBAImage.3tiff.html<br>
-tiff/html/man/TIFFReadRGBAStrip.3tiff.html<br>
-tiff/html/man/TIFFReadRGBATile.3tiff.html<br>
-tiff/html/man/TIFFReadRawStrip.3tiff.html<br>
-tiff/html/man/TIFFReadRawTile.3tiff.html<br>
-tiff/html/man/TIFFReadScanline.3tiff.html<br>
-tiff/html/man/TIFFReadTile.3tiff.html<br>
-tiff/html/man/TIFFSetDirectory.3tiff.html<br>
-tiff/html/man/TIFFSetField.3tiff.html<br>
-tiff/html/man/TIFFWarning.3tiff.html<br>
-tiff/html/man/TIFFWriteDirectory.3tiff.html<br>
-tiff/html/man/TIFFWriteEncodedStrip.3tiff.html<br>
-tiff/html/man/TIFFWriteEncodedTile.3tiff.html<br>
-tiff/html/man/TIFFWriteRawStrip.3tiff.html<br>
-tiff/html/man/TIFFWriteRawTile.3tiff.html<br>
-tiff/html/man/TIFFWriteScanline.3tiff.html<br>
-tiff/html/man/TIFFWriteTile.3tiff.html<br>
-tiff/html/man/TIFFbuffer.3tiff.html<br>
-tiff/html/man/TIFFcodec.3tiff.html<br>
-tiff/html/man/TIFFcolor.3tiff.html<br>
-tiff/html/man/TIFFmemory.3tiff.html<br>
-tiff/html/man/TIFFsize.3tiff.html<br>
-tiff/html/man/TIFFstrip.3tiff.html<br>
-tiff/html/man/TIFFswab.3tiff.html<br>
-tiff/html/man/TIFFtile.3tiff.html<br>
-tiff/html/man/fax2ps.1.html<br>
-tiff/html/man/fax2tiff.1.html<br>
-tiff/html/man/gif2tiff.1.html<br>
-tiff/html/man/index.html<br>
-tiff/html/man/pal2rgb.1.html<br>
-tiff/html/man/ppm2tiff.1.html<br>
-tiff/html/man/ras2tiff.1.html<br>
-tiff/html/man/raw2tiff.1.html<br>
-tiff/html/man/rgb2ycbcr.1.html<br>
-tiff/html/man/sgi2tiff.1.html<br>
-tiff/html/man/thumbnail.1.html<br>
-tiff/html/man/tiff2bw.1.html<br>
-tiff/html/man/tiff2pdf.1.html<br>
-tiff/html/man/tiff2ps.1.html<br>
-tiff/html/man/tiff2rgba.1.html<br>
-tiff/html/man/tiffcmp.1.html<br>
-tiff/html/man/tiffcp.1.html<br>
-tiff/html/man/tiffcrop.1.html<br>
-tiff/html/man/tiffdither.1.html<br>
-tiff/html/man/tiffdump.1.html<br>
-tiff/html/man/tiffgt.1.html<br>
-tiff/html/man/tiffinfo.1.html<br>
-tiff/html/man/tiffmedian.1.html<br>
-tiff/html/man/tiffset.1.html<br>
-tiff/html/man/tiffsplit.1.html<br>
-tiff/html/man/tiffsv.1.html<br>
-tiff/html/misc.html<br>
-tiff/html/support.html<br>
-tiff/html/tools.html<br>
-tiff/html/v3.4beta007.html<br>
-tiff/html/v3.4beta016.html<br>
-tiff/html/v3.4beta018.html<br>
-tiff/html/v3.4beta024.html<br>
-tiff/html/v3.4beta028.html<br>
-tiff/html/v3.4beta029.html<br>
-tiff/html/v3.4beta031.html<br>
-tiff/html/v3.4beta032.html<br>
-tiff/html/v3.4beta033.html<br>
-tiff/html/v3.4beta034.html<br>
-tiff/html/v3.4beta035.html<br>
-tiff/html/v3.4beta036.html<br>
-tiff/html/v3.5.1.html<br>
-tiff/html/v3.5.2.html<br>
-tiff/html/v3.5.3.html<br>
-tiff/html/v3.5.4.html<br>
-tiff/html/v3.5.5.html<br>
-tiff/html/v3.5.6-beta.html<br>
-tiff/html/v3.5.7.html<br>
-tiff/html/v3.6.0.html<br>
-tiff/html/v3.6.1.html<br>
-tiff/html/v3.7.0.html<br>
-tiff/html/v3.7.0alpha.html<br>
-tiff/html/v3.7.0beta.html<br>
-tiff/html/v3.7.0beta2.html<br>
-tiff/html/v3.7.1.html<br>
-tiff/html/v3.7.2.html<br>
-tiff/html/v3.7.3.html<br>
-tiff/html/v3.7.4.html<br>
-tiff/html/v3.8.0.html<br>
-tiff/html/v3.8.1.html<br>
-tiff/html/v3.8.2.html<br>
-tiff/html/v3.9.0beta.html<br>
-tiff/html/v3.9.1.html<br>
-tiff/html/v3.9.2.html<br>
-tiff/html/v4.0.0.html<br>
-tiff/html/v4.0.1.html<br>
-tiff/html/v4.0.2.html<br>
-tiff/html/v4.0.3.html<br>
-tiff/html/v4.0.4.html<br>
-tiff/html/v4.0.4beta.html<br>
-tiff/html/v4.0.5.html<br>
-tiff/html/v4.0.6.html<br>
-tiff/html/v4.0.7.html<br>
-tiff/libtiff/CMakeLists.txt<br>
-tiff/libtiff/Makefile.am<br>
-tiff/libtiff/Makefile.in<br>
-tiff/libtiff/Makefile.vc<br>
-tiff/libtiff/libtiff.def<br>
-tiff/libtiff/mkg3states.c<br>
-tiff/libtiff/tif_aux.c<br>
-tiff/libtiff/tif_close.c<br>
-tiff/libtiff/tif_codec.c<br>
-tiff/libtiff/tif_color.c<br>
-tiff/libtiff/tif_compress.c<br>
-tiff/libtiff/tif_config.h.cmake.in<br>
-tiff/libtiff/tif_config.h.in<br>
-tiff/libtiff/tif_config.vc.h<br>
-tiff/libtiff/tif_dir.c<br>
-tiff/libtiff/tif_dirinfo.c<br>
-tiff/libtiff/tif_dirread.c<br>
-tiff/libtiff/tif_dirwrite.c<br>
-tiff/libtiff/tif_dumpmode.c<br>
-tiff/libtiff/tif_extension.c<br>
-tiff/libtiff/tif_fax3.c<br>
-tiff/libtiff/tif_fax3.h<br>
-tiff/libtiff/tif_getimage.c<br>
-tiff/libtiff/tif_jpeg.c<br>
-tiff/libtiff/tif_jpeg_12.c<br>
-tiff/libtiff/tif_luv.c<br>
-tiff/libtiff/tif_lzma.c<br>
-tiff/libtiff/tif_lzw.c<br>
-tiff/libtiff/tif_next.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_predict.h<br>
-tiff/libtiff/tif_print.c<br>
-tiff/libtiff/tif_read.c<br>
-tiff/libtiff/tif_stream.cxx<br>
-tiff/libtiff/tif_strip.c<br>
-tiff/libtiff/tif_swab.c<br>
-tiff/libtiff/tif_thunder.c<br>
-tiff/libtiff/tif_tile.c<br>
-tiff/libtiff/tif_unix.c<br>
-tiff/libtiff/tif_win32.c<br>
-tiff/libtiff/tif_write.c<br>
-tiff/libtiff/tif_zip.c<br>
-tiff/libtiff/tiff.h<br>
-tiff/libtiff/tiffconf.h.cmake.in<br>
-tiff/libtiff/tiffconf.vc.h<br>
-tiff/libtiff/tiffio.h<br>
-tiff/libtiff/tiffiop.h<br>
-tiff/libtiff/tiffvers.h<br>
-tiff/libtiff/uvcode.h<br>
-tiff/man/CMakeLists.txt<br>
-tiff/man/Makefile.am<br>
-tiff/man/Makefile.in<br>
-tiff/man/TIFFClose.3tiff<br>
-tiff/man/TIFFDataWidth.3tiff<br>
-tiff/man/TIFFError.3tiff<br>
-tiff/man/TIFFFieldDataType.3tiff<br>
-tiff/man/TIFFFieldName.3tiff<br>
-tiff/man/TIFFFieldPassCount.3tiff<br>
-tiff/man/TIFFFieldReadCount.3tiff<br>
-tiff/man/TIFFFieldTag.3tiff<br>
-tiff/man/TIFFFieldWriteCount.3tiff<br>
-tiff/man/TIFFFlush.3tiff<br>
-tiff/man/TIFFGetField.3tiff<br>
-tiff/man/TIFFRGBAImage.3tiff<br>
-tiff/man/TIFFReadDirectory.3tiff<br>
-tiff/man/TIFFReadEncodedStrip.3tiff<br>
-tiff/man/TIFFReadEncodedTile.3tiff<br>
-tiff/man/TIFFReadRGBAImage.3tiff<br>
-tiff/man/TIFFReadRGBAStrip.3tiff<br>
-tiff/man/TIFFReadRGBATile.3tiff<br>
-tiff/man/TIFFReadRawStrip.3tiff<br>
-tiff/man/TIFFReadRawTile.3tiff<br>
-tiff/man/TIFFReadScanline.3tiff<br>
-tiff/man/TIFFReadTile.3tiff<br>
-tiff/man/TIFFSetDirectory.3tiff<br>
-tiff/man/TIFFSetField.3tiff<br>
-tiff/man/TIFFWarning.3tiff<br>
-tiff/man/TIFFWriteDirectory.3tiff<br>
-tiff/man/TIFFWriteEncodedStrip.3tiff<br>
-tiff/man/TIFFWriteEncodedTile.3tiff<br>
-tiff/man/TIFFWriteRawStrip.3tiff<br>
-tiff/man/TIFFWriteRawTile.3tiff<br>
-tiff/man/TIFFWriteScanline.3tiff<br>
-tiff/man/TIFFWriteTile.3tiff<br>
-tiff/man/TIFFbuffer.3tiff<br>
-tiff/man/TIFFcodec.3tiff<br>
-tiff/man/TIFFcolor.3tiff<br>
-tiff/man/TIFFmemory.3tiff<br>
-tiff/man/TIFFsize.3tiff<br>
-tiff/man/TIFFstrip.3tiff<br>
-tiff/man/TIFFswab.3tiff<br>
-tiff/man/TIFFtile.3tiff<br>
-tiff/man/bmp2tiff.1<br>
-tiff/man/fax2ps.1<br>
-tiff/man/fax2tiff.1<br>
-tiff/man/gif2tiff.1<br>
-tiff/man/libtiff.3tiff<br>
-tiff/man/pal2rgb.1<br>
-tiff/man/ppm2tiff.1<br>
-tiff/man/ras2tiff.1<br>
-tiff/man/raw2tiff.1<br>
-tiff/man/rgb2ycbcr.1<br>
-tiff/man/sgi2tiff.1<br>
-tiff/man/thumbnail.1<br>
-tiff/man/tiff2bw.1<br>
-tiff/man/tiff2pdf.1<br>
-tiff/man/tiff2ps.1<br>
-tiff/man/tiff2rgba.1<br>
-tiff/man/tiffcmp.1<br>
-tiff/man/tiffcp.1<br>
-tiff/man/tiffcrop.1<br>
-tiff/man/tiffdither.1<br>
-tiff/man/tiffdump.1<br>
-tiff/man/tiffgt.1<br>
-tiff/man/tiffinfo.1<br>
-tiff/man/tiffmedian.1<br>
-tiff/man/tiffset.1<br>
-tiff/man/tiffsplit.1<br>
-tiff/man/tiffsv.1<br>
-tiff/nmake.opt<br>
-tiff/port/CMakeLists.txt<br>
-tiff/port/Makefile.am<br>
-tiff/port/Makefile.in<br>
-tiff/port/Makefile.vc<br>
-tiff/port/libport.h<br>
-tiff/port/snprintf.c<br>
-tiff/port/strcasecmp.c<br>
-tiff/test/CMakeLists.txt<br>
-tiff/test/Makefile.am<br>
-tiff/test/Makefile.in<br>
-tiff/test/TiffSplitTest.cmake<br>
-tiff/test/TiffTest.cmake<br>
-tiff/test/TiffTestCommon.cmake<br>
-tiff/test/ascii_tag.c<br>
-tiff/test/bmp2tiff_palette.sh<br>
-tiff/test/bmp2tiff_rgb.sh<br>
-tiff/test/common.sh<br>
-tiff/test/custom_dir.c<br>
-tiff/test/gif2tiff.sh<br>
-tiff/test/images/palette-1c-8b.bmp<br>
-tiff/test/images/palette-1c-8b.gif<br>
-tiff/test/images/quad-tile.jpg.tiff<br>
-tiff/test/images/rgb-3c-8b.bmp<br>
-tiff/test/long_tag.c<br>
-tiff/test/raw_decode.c<br>
-tiff/test/rewrite_tag.c<br>
-tiff/test/short_tag.c<br>
-tiff/test/strip.c<br>
-tiff/test/tiff2rgba-quad-tile.jpg.sh<br>
-tiff/tools/CMakeLists.txt<br>
-tiff/tools/Makefile.am<br>
-tiff/tools/Makefile.in<br>
-tiff/tools/Makefile.vc<br>
-tiff/tools/bmp2tiff.c<br>
-tiff/tools/fax2ps.c<br>
-tiff/tools/fax2tiff.c<br>
-tiff/tools/gif2tiff.c<br>
-tiff/tools/pal2rgb.c<br>
-tiff/tools/ppm2tiff.c<br>
-tiff/tools/ras2tiff.c<br>
-tiff/tools/rasterfile.h<br>
-tiff/tools/raw2tiff.c<br>
-tiff/tools/rgb2ycbcr.c<br>
-tiff/tools/sgi2tiff.c<br>
-tiff/tools/sgisv.c<br>
-tiff/tools/thumbnail.c<br>
-tiff/tools/tiff2bw.c<br>
-tiff/tools/tiff2pdf.c<br>
-tiff/tools/tiff2ps.c<br>
-tiff/tools/tiff2rgba.c<br>
-tiff/tools/tiffcmp.c<br>
-tiff/tools/tiffcp.c<br>
-tiff/tools/tiffcrop.c<br>
-tiff/tools/tiffdither.c<br>
-tiff/tools/tiffdump.c<br>
-tiff/tools/tiffgt.c<br>
-tiff/tools/tiffinfo.c<br>
-tiff/tools/tiffmedian.c<br>
-tiff/tools/tiffset.c<br>
-tiff/tools/tiffsplit.c<br>
-tiff/tools/ycbcr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-08 09:50:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6655712ee1d0bf2a7818044613bbed226b7abddd">6655712ee1d0bf2a7818044613bbed226b7abddd</a>
-<blockquote>
-<p>
- Update freetype to 2.7.0<br>
-<br>
- Tweak makefile for new freetype version<br>
-<br>
- Force use of the v35 Freetype bytecode interpreter<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/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/atari/ATARI.H<br>
-freetype/builds/atari/README.TXT<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/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.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-sh<br>
-freetype/builds/unix/install.mk<br>
-freetype/builds/unix/ltmain.sh<br>
-freetype/builds/unix/mkinstalldirs<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.sln<br>
-freetype/builds/wince/vc2005-ce/freetype.vcproj<br>
-freetype/builds/wince/vc2005-ce/index.html<br>
-freetype/builds/wince/vc2008-ce/freetype.sln<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.UNIX<br>
-freetype/docs/INSTALL.VMS<br>
-freetype/docs/LICENSE.TXT<br>
-freetype/docs/TODO<br>
-freetype/docs/VERSION.DLL<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-pfr_fonts.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-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/config/ftconfig.h<br>
-freetype/include/config/ftheader.h<br>
-freetype/include/config/ftmodule.h<br>
-freetype/include/config/ftoption.h<br>
-freetype/include/config/ftstdlib.h<br>
-freetype/include/freetype.h<br>
-freetype/include/freetype/config/ftconfig.h<br>
-freetype/include/freetype/config/ftheader.h<br>
-freetype/include/freetype/config/ftmodule.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/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/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/ftcalc.h<br>
-freetype/include/freetype/internal/ftdebug.h<br>
-freetype/include/freetype/internal/ftdriver.h<br>
-freetype/include/freetype/internal/ftgloadr.h<br>
-freetype/include/freetype/internal/fthash.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/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/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/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/include/ftadvanc.h<br>
-freetype/include/ftautoh.h<br>
-freetype/include/ftbbox.h<br>
-freetype/include/ftbdf.h<br>
-freetype/include/ftbitmap.h<br>
-freetype/include/ftbzip2.h<br>
-freetype/include/ftcache.h<br>
-freetype/include/ftcffdrv.h<br>
-freetype/include/ftchapters.h<br>
-freetype/include/ftcid.h<br>
-freetype/include/fterrdef.h<br>
-freetype/include/fterrors.h<br>
-freetype/include/ftgasp.h<br>
-freetype/include/ftglyph.h<br>
-freetype/include/ftgxval.h<br>
-freetype/include/ftgzip.h<br>
-freetype/include/ftimage.h<br>
-freetype/include/ftincrem.h<br>
-freetype/include/ftlcdfil.h<br>
-freetype/include/ftlist.h<br>
-freetype/include/ftlzw.h<br>
-freetype/include/ftmac.h<br>
-freetype/include/ftmm.h<br>
-freetype/include/ftmodapi.h<br>
-freetype/include/ftmoderr.h<br>
-freetype/include/ftotval.h<br>
-freetype/include/ftoutln.h<br>
-freetype/include/ftpfr.h<br>
-freetype/include/ftrender.h<br>
-freetype/include/ftsizes.h<br>
-freetype/include/ftsnames.h<br>
-freetype/include/ftstroke.h<br>
-freetype/include/ftsynth.h<br>
-freetype/include/ftsystem.h<br>
-freetype/include/fttrigon.h<br>
-freetype/include/ftttdrv.h<br>
-freetype/include/fttypes.h<br>
-freetype/include/ftwinfnt.h<br>
-freetype/include/ftxf86.h<br>
-freetype/include/internal/autohint.h<br>
-freetype/include/internal/ftcalc.h<br>
-freetype/include/internal/ftdebug.h<br>
-freetype/include/internal/ftdriver.h<br>
-freetype/include/internal/ftgloadr.h<br>
-freetype/include/internal/ftmemory.h<br>
-freetype/include/internal/ftobjs.h<br>
-freetype/include/internal/ftpic.h<br>
-freetype/include/internal/ftrfork.h<br>
-freetype/include/internal/ftserv.h<br>
-freetype/include/internal/ftstream.h<br>
-freetype/include/internal/fttrace.h<br>
-freetype/include/internal/ftvalid.h<br>
-freetype/include/internal/internal.h<br>
-freetype/include/internal/psaux.h<br>
-freetype/include/internal/pshints.h<br>
-freetype/include/internal/services/svbdf.h<br>
-freetype/include/internal/services/svcid.h<br>
-freetype/include/internal/services/svgldict.h<br>
-freetype/include/internal/services/svgxval.h<br>
-freetype/include/internal/services/svkern.h<br>
-freetype/include/internal/services/svmm.h<br>
-freetype/include/internal/services/svotval.h<br>
-freetype/include/internal/services/svpfr.h<br>
-freetype/include/internal/services/svpostnm.h<br>
-freetype/include/internal/services/svprop.h<br>
-freetype/include/internal/services/svpscmap.h<br>
-freetype/include/internal/services/svpsinfo.h<br>
-freetype/include/internal/services/svsfnt.h<br>
-freetype/include/internal/services/svttcmap.h<br>
-freetype/include/internal/services/svtteng.h<br>
-freetype/include/internal/services/svttglyf.h<br>
-freetype/include/internal/services/svwinfnt.h<br>
-freetype/include/internal/services/svxf86nm.h<br>
-freetype/include/internal/sfnt.h<br>
-freetype/include/internal/t1types.h<br>
-freetype/include/internal/tttypes.h<br>
-freetype/include/t1tables.h<br>
-freetype/include/ttnameid.h<br>
-freetype/include/tttables.h<br>
-freetype/include/tttags.h<br>
-freetype/include/ttunpat.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/hbshim.c<br>
-freetype/src/autofit/hbshim.h<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/fthash.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/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/ftwinfnt.c<br>
-freetype/src/base/ftxf86.c<br>
-freetype/src/base/md5.c<br>
-freetype/src/base/rules.mk<br>
-freetype/src/bdf/Jamfile<br>
-freetype/src/bdf/bdf.h<br>
-freetype/src/bdf/bdfdrivr.c<br>
-freetype/src/bdf/bdfdrivr.h<br>
-freetype/src/bdf/bdferror.h<br>
-freetype/src/bdf/bdflib.c<br>
-freetype/src/bdf/rules.mk<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/cf2arrst.c<br>
-freetype/src/cff/cf2arrst.h<br>
-freetype/src/cff/cf2blues.h<br>
-freetype/src/cff/cf2error.h<br>
-freetype/src/cff/cf2fixed.h<br>
-freetype/src/cff/cf2font.h<br>
-freetype/src/cff/cf2ft.c<br>
-freetype/src/cff/cf2ft.h<br>
-freetype/src/cff/cf2glue.h<br>
-freetype/src/cff/cf2hints.c<br>
-freetype/src/cff/cf2hints.h<br>
-freetype/src/cff/cf2intrp.c<br>
-freetype/src/cff/cf2intrp.h<br>
-freetype/src/cff/cf2read.h<br>
-freetype/src/cff/cf2stack.c<br>
-freetype/src/cff/cf2stack.h<br>
-freetype/src/cff/cf2types.h<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/cfftypes.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/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/pcf.h<br>
-freetype/src/pcf/pcfdrivr.c<br>
-freetype/src/pcf/pcfdrivr.h<br>
-freetype/src/pcf/pcferror.h<br>
-freetype/src/pcf/pcfread.c<br>
-freetype/src/pcf/pcfread.h<br>
-freetype/src/pcf/pcfutil.h<br>
-freetype/src/pcf/rules.mk<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/module.mk<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/psconv.c<br>
-freetype/src/psaux/psconv.h<br>
-freetype/src/psaux/psobjs.c<br>
-freetype/src/psaux/psobjs.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/chktrcmp.py<br>
-freetype/src/tools/docmaker/content.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/Makefile<br>
-freetype/src/tools/ftrandom/README<br>
-freetype/src/tools/ftrandom/ftrandom.c<br>
-freetype/src/tools/glnames.py<br>
-freetype/src/tools/no-copyright<br>
-freetype/src/tools/test_afm.c<br>
-freetype/src/tools/update-copyright<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>2016-11-15 09:58:58 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=99c6a18eb430a9091c79369b2bdd2952d481c7d5">99c6a18eb430a9091c79369b2bdd2952d481c7d5</a>
-<blockquote>
-<p>
- Document use of string for subsituted CIDFont name<br>
-<br>
- Add a comment and example at the top of cidfmap with details of dealing with<br>
- CIDFont names with spaces in them.<br>
-<br>
-Resource/Init/cidfmap<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-07 14:52: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=23dc144b3c3d3dbafd83dca7b9c09e6977b774d6">23dc144b3c3d3dbafd83dca7b9c09e6977b774d6</a>
-<blockquote>
-<p>
- Update lcms2 to 2.8<br>
-<br>
- Tweak makefile for lcms2 2.8<br>
-<br>
- Delete mac file system specific files from lcms2 tree<br>
-<br>
- Bug 697056: Fix LCMS static init of critical section.<br>
-<br>
- LCMS2 relies on being able to statically init a mutex<br>
- (actually a Critical Section on windows). Windows has<br>
- no official API for statically initing a critical<br>
- section, so lcms2 uses a hack (albeit it a safe one)<br>
- to do this.<br>
-<br>
- Unfortunately ApplicationVerifier (and presumably other<br>
- similar tools) don't understand this idiom, and get<br>
- confused by not seeing an explicit initialisation call.<br>
- This is causing problems for a customer.<br>
-<br>
- This commit therefore introduces code to properly<br>
- initialise it on Windows. In order to avoid any possible<br>
- multithreaded startup issues, we use the Windows<br>
- InterlockedCompareExchangePointer API (introduced in<br>
- Windows XP).<br>
-<br>
- If anyone wants to avoid this code (so they can work<br>
- on pre-Windows XP), they can build with:<br>
-<br>
- CMS_RELY_ON_WINDOWS_STATIC_MUTEX_INIT<br>
-<br>
- defined, and get the old behaviour. We automatically<br>
- set this when building with any version of MSVC older<br>
- than VS2005 (i.e. those that don't have that API<br>
- available).<br>
-<br>
-base/lcms2.mak<br>
-lcms2/AUTHORS<br>
-lcms2/ChangeLog<br>
-lcms2/Makefile.am<br>
-lcms2/Makefile.in<br>
-lcms2/Projects/BorlandC_5.5/lcms2.rc<br>
-lcms2/Projects/BorlandC_5.5/lcmsdll.lst<br>
-lcms2/Projects/VC2008/jpegicc/jpegicc.vcproj<br>
-lcms2/Projects/VC2008/lcms2.rc<br>
-lcms2/Projects/VC2008/lcms2.sln<br>
-lcms2/Projects/VC2008/lcms2_DLL/lcms2_DLL.vcproj<br>
-lcms2/Projects/VC2008/lcms2_static/lcms2_static.vcproj<br>
-lcms2/Projects/VC2008/linkicc/linkicc.vcproj<br>
-lcms2/Projects/VC2008/psicc/psicc.vcproj<br>
-lcms2/Projects/VC2008/resource.h<br>
-lcms2/Projects/VC2008/testbed/testbed.vcproj<br>
-lcms2/Projects/VC2008/tiffdiff/tiffdiff.vcproj<br>
-lcms2/Projects/VC2008/tifficc/tifficc.vcproj<br>
-lcms2/Projects/VC2008/transicc/transicc.vcproj<br>
-lcms2/Projects/VC2010/jpegicc/jpegicc.vcproj<br>
-lcms2/Projects/VC2010/jpegicc/jpegicc.vcxproj<br>
-lcms2/Projects/VC2010/lcms2.rc<br>
-lcms2/Projects/VC2010/lcms2.sln<br>
-lcms2/Projects/VC2010/lcms2_DLL/lcms2_DLL.vcproj<br>
-lcms2/Projects/VC2010/lcms2_static/lcms2_static.vcproj<br>
-lcms2/Projects/VC2010/linkicc/linkicc.vcproj<br>
-lcms2/Projects/VC2010/psicc/psicc.vcproj<br>
-lcms2/Projects/VC2010/testbed/testbed.vcproj<br>
-lcms2/Projects/VC2010/tiffdiff/tiffdiff.vcproj<br>
-lcms2/Projects/VC2010/tifficc/tifficc.vcproj<br>
-lcms2/Projects/VC2010/transicc/transicc.vcproj<br>
-lcms2/Projects/VC2012/jpegicc/jpegicc.vcproj<br>
-lcms2/Projects/VC2012/jpegicc/jpegicc.vcxproj<br>
-lcms2/Projects/VC2012/jpegicc/jpegicc.vcxproj.filters<br>
-lcms2/Projects/VC2012/lcms2.rc<br>
-lcms2/Projects/VC2012/lcms2.sln<br>
-lcms2/Projects/VC2012/lcms2_DLL/lcms2_DLL.vcproj<br>
-lcms2/Projects/VC2012/lcms2_DLL/lcms2_DLL.vcxproj<br>
-lcms2/Projects/VC2012/lcms2_DLL/lcms2_DLL.vcxproj.filters<br>
-lcms2/Projects/VC2012/lcms2_static/lcms2_static.vcproj<br>
-lcms2/Projects/VC2012/lcms2_static/lcms2_static.vcxproj<br>
-lcms2/Projects/VC2012/lcms2_static/lcms2_static.vcxproj.filters<br>
-lcms2/Projects/VC2012/linkicc/linkicc.vcproj<br>
-lcms2/Projects/VC2012/linkicc/linkicc.vcxproj<br>
-lcms2/Projects/VC2012/linkicc/linkicc.vcxproj.filters<br>
-lcms2/Projects/VC2012/psicc/psicc.vcproj<br>
-lcms2/Projects/VC2012/psicc/psicc.vcxproj<br>
-lcms2/Projects/VC2012/psicc/psicc.vcxproj.filters<br>
-lcms2/Projects/VC2012/resource.h<br>
-lcms2/Projects/VC2012/testbed/testbed.vcproj<br>
-lcms2/Projects/VC2012/testbed/testbed.vcxproj<br>
-lcms2/Projects/VC2012/testbed/testbed.vcxproj.filters<br>
-lcms2/Projects/VC2012/tiffdiff/tiffdiff.vcproj<br>
-lcms2/Projects/VC2012/tiffdiff/tiffdiff.vcxproj<br>
-lcms2/Projects/VC2012/tiffdiff/tiffdiff.vcxproj.filters<br>
-lcms2/Projects/VC2012/tifficc/tifficc.vcproj<br>
-lcms2/Projects/VC2012/tifficc/tifficc.vcxproj<br>
-lcms2/Projects/VC2012/tifficc/tifficc.vcxproj.filters<br>
-lcms2/Projects/VC2012/transicc/transicc.vcproj<br>
-lcms2/Projects/VC2012/transicc/transicc.vcxproj<br>
-lcms2/Projects/VC2012/transicc/transicc.vcxproj.filters<br>
-lcms2/Projects/VC2013/jpegicc/jpegicc.vcxproj<br>
-lcms2/Projects/VC2013/jpegicc/jpegicc.vcxproj.filters<br>
-lcms2/Projects/VC2013/lcms2.rc<br>
-lcms2/Projects/VC2013/lcms2.sln<br>
-lcms2/Projects/VC2013/lcms2_DLL/lcms2_DLL.vcxproj<br>
-lcms2/Projects/VC2013/lcms2_DLL/lcms2_DLL.vcxproj.filters<br>
-lcms2/Projects/VC2013/lcms2_static/lcms2_static.vcxproj<br>
-lcms2/Projects/VC2013/lcms2_static/lcms2_static.vcxproj.filters<br>
-lcms2/Projects/VC2013/linkicc/linkicc.vcxproj<br>
-lcms2/Projects/VC2013/linkicc/linkicc.vcxproj.filters<br>
-lcms2/Projects/VC2013/psicc/psicc.vcxproj<br>
-lcms2/Projects/VC2013/psicc/psicc.vcxproj.filters<br>
-lcms2/Projects/VC2013/resource.h<br>
-lcms2/Projects/VC2013/testbed/testbed.vcxproj<br>
-lcms2/Projects/VC2013/testbed/testbed.vcxproj.filters<br>
-lcms2/Projects/VC2013/tiffdiff/tiffdiff.vcxproj<br>
-lcms2/Projects/VC2013/tiffdiff/tiffdiff.vcxproj.filters<br>
-lcms2/Projects/VC2013/tifficc/tifficc.vcxproj<br>
-lcms2/Projects/VC2013/tifficc/tifficc.vcxproj.filters<br>
-lcms2/Projects/VC2013/transicc/transicc.vcxproj<br>
-lcms2/Projects/VC2013/transicc/transicc.vcxproj.filters<br>
-lcms2/Projects/VC2015/jpegicc/jpegicc.vcxproj<br>
-lcms2/Projects/VC2015/jpegicc/jpegicc.vcxproj.filters<br>
-lcms2/Projects/VC2015/lcms2.rc<br>
-lcms2/Projects/VC2015/lcms2.sln<br>
-lcms2/Projects/VC2015/lcms2_DLL/lcms2_DLL.vcxproj<br>
-lcms2/Projects/VC2015/lcms2_DLL/lcms2_DLL.vcxproj.filters<br>
-lcms2/Projects/VC2015/lcms2_static/lcms2_static.vcxproj<br>
-lcms2/Projects/VC2015/lcms2_static/lcms2_static.vcxproj.filters<br>
-lcms2/Projects/VC2015/linkicc/linkicc.vcxproj<br>
-lcms2/Projects/VC2015/linkicc/linkicc.vcxproj.filters<br>
-lcms2/Projects/VC2015/psicc/psicc.vcxproj<br>
-lcms2/Projects/VC2015/psicc/psicc.vcxproj.filters<br>
-lcms2/Projects/VC2015/resource.h<br>
-lcms2/Projects/VC2015/testbed/testbed.vcxproj<br>
-lcms2/Projects/VC2015/testbed/testbed.vcxproj.filters<br>
-lcms2/Projects/VC2015/tiffdiff/tiffdiff.vcxproj<br>
-lcms2/Projects/VC2015/tiffdiff/tiffdiff.vcxproj.filters<br>
-lcms2/Projects/VC2015/tifficc/tifficc.vcxproj<br>
-lcms2/Projects/VC2015/tifficc/tifficc.vcxproj.filters<br>
-lcms2/Projects/VC2015/transicc/transicc.vcxproj<br>
-lcms2/Projects/VC2015/transicc/transicc.vcxproj.filters<br>
-lcms2/Projects/cppcheck/lcms2.cppcheck<br>
-lcms2/Projects/mac/LittleCMS/._Info.plist<br>
-lcms2/Projects/mac/LittleCMS/._LittleCMS.xcodeproj<br>
-lcms2/Projects/mac/LittleCMS/English.lproj/InfoPlist.strings<br>
-lcms2/Projects/mac/LittleCMS/Info.plist<br>
-lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/mariama.mode1v3<br>
-lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/mariama.pbxuser<br>
-lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.pbxproj<br>
-lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.xcworkspace/contents.xcworkspacedata<br>
-lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.xcworkspace/xcuserdata/User.xcuserdatad/UserInterfaceState.xcuserstate<br>
-lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.xcworkspace/xcuserdata/User.xcuserdatad/WorkspaceSettings.xcsettings<br>
-lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/xcuserdata/User.xcuserdatad/xcdebugger/Breakpoints.xcbkptlist<br>
-lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/xcuserdata/User.xcuserdatad/xcschemes/LittleCMS.xcscheme<br>
-lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/xcuserdata/User.xcuserdatad/xcschemes/testbed.xcscheme<br>
-lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/xcuserdata/User.xcuserdatad/xcschemes/xcschememanagement.plist<br>
-lcms2/Projects/mac/LittleCMS/LittleCMS_Prefix.pch<br>
-lcms2/Projects/mac/LittleCMS/TestBed-Info.plist<br>
-lcms2/aclocal.m4<br>
-lcms2/autogen.sh<br>
-lcms2/compile<br>
-lcms2/config.guess<br>
-lcms2/config.sub<br>
-lcms2/configure<br>
-lcms2/configure.ac<br>
-lcms2/depcomp<br>
-lcms2/doc/LittleCMS2.6 API.pdf<br>
-lcms2/doc/LittleCMS2.6 Plugin API.pdf<br>
-lcms2/doc/LittleCMS2.6 tutorial.pdf<br>
-lcms2/doc/LittleCMS2.8 API.pdf<br>
-lcms2/doc/LittleCMS2.8 Plugin API.pdf<br>
-lcms2/doc/LittleCMS2.8 tutorial.pdf<br>
-lcms2/doc/src.zip<br>
-lcms2/include/Makefile.in<br>
-lcms2/include/lcms2.h<br>
-lcms2/include/lcms2_plugin.h<br>
-lcms2/install-sh<br>
-lcms2/ltmain.sh<br>
-lcms2/m4/acx_pthread.m4<br>
-lcms2/m4/libtool.m4<br>
-lcms2/m4/ltoptions.m4<br>
-lcms2/m4/ltsugar.m4<br>
-lcms2/m4/ltversion.m4<br>
-lcms2/m4/lt~obsolete.m4<br>
-lcms2/missing<br>
-lcms2/src/Makefile.am<br>
-lcms2/src/Makefile.in<br>
-lcms2/src/cmsalpha.c<br>
-lcms2/src/cmscam02.c<br>
-lcms2/src/cmscgats.c<br>
-lcms2/src/cmscnvrt.c<br>
-lcms2/src/cmserr.c<br>
-lcms2/src/cmsgamma.c<br>
-lcms2/src/cmsgmt.c<br>
-lcms2/src/cmshalf.c<br>
-lcms2/src/cmsintrp.c<br>
-lcms2/src/cmsio0.c<br>
-lcms2/src/cmsio1.c<br>
-lcms2/src/cmslut.c<br>
-lcms2/src/cmsmd5.c<br>
-lcms2/src/cmsmtrx.c<br>
-lcms2/src/cmsnamed.c<br>
-lcms2/src/cmsopt.c<br>
-lcms2/src/cmspack.c<br>
-lcms2/src/cmspcs.c<br>
-lcms2/src/cmsplugin.c<br>
-lcms2/src/cmsps2.c<br>
-lcms2/src/cmssamp.c<br>
-lcms2/src/cmssm.c<br>
-lcms2/src/cmstypes.c<br>
-lcms2/src/cmsvirt.c<br>
-lcms2/src/cmswtpnt.c<br>
-lcms2/src/cmsxform.c<br>
-lcms2/src/extra_xform.h<br>
-lcms2/src/lcms2.def<br>
-lcms2/src/lcms2_internal.h<br>
-lcms2/testbed/Makefile.am<br>
-lcms2/testbed/Makefile.in<br>
-lcms2/testbed/crayons.icc<br>
-lcms2/testbed/ibm-t61.icc<br>
-lcms2/testbed/new.icc<br>
-lcms2/testbed/test1.icc<br>
-lcms2/testbed/test2.icc<br>
-lcms2/testbed/test3.icc<br>
-lcms2/testbed/test4.icc<br>
-lcms2/testbed/test5.icc<br>
-lcms2/testbed/testcms2.c<br>
-lcms2/testbed/testcms2.h<br>
-lcms2/testbed/testplugin.c<br>
-lcms2/testbed/toosmall.icc<br>
-lcms2/testbed/zoo_icc.c<br>
-lcms2/utils/common/utils.h<br>
-lcms2/utils/common/vprf.c<br>
-lcms2/utils/delphi/delphidemo.res<br>
-lcms2/utils/delphi/demo1.dfm<br>
-lcms2/utils/delphi/lcms2.dll<br>
-lcms2/utils/delphi/lcms2dll.pas<br>
-lcms2/utils/jpgicc/LICENSE_iccjpeg<br>
-lcms2/utils/jpgicc/Makefile.am<br>
-lcms2/utils/jpgicc/Makefile.in<br>
-lcms2/utils/jpgicc/iccjpeg.c<br>
-lcms2/utils/jpgicc/jpgicc.1<br>
-lcms2/utils/jpgicc/jpgicc.c<br>
-lcms2/utils/linkicc/Makefile.am<br>
-lcms2/utils/linkicc/Makefile.in<br>
-lcms2/utils/linkicc/linkicc.1<br>
-lcms2/utils/linkicc/linkicc.c<br>
-lcms2/utils/psicc/Makefile.am<br>
-lcms2/utils/psicc/Makefile.in<br>
-lcms2/utils/psicc/psicc.1<br>
-lcms2/utils/psicc/psicc.c<br>
-lcms2/utils/samples/Makefile.am<br>
-lcms2/utils/samples/roundtrip.c<br>
-lcms2/utils/samples/wtpt.c<br>
-lcms2/utils/tificc/Makefile.am<br>
-lcms2/utils/tificc/Makefile.in<br>
-lcms2/utils/tificc/tifdiff.c<br>
-lcms2/utils/tificc/tificc.1<br>
-lcms2/utils/tificc/tificc.c<br>
-lcms2/utils/transicc/Makefile.am<br>
-lcms2/utils/transicc/Makefile.in<br>
-lcms2/utils/transicc/transicc.1<br>
-lcms2/utils/transicc/transicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-07 10:42:05 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=64ad2a92195fd05e9ba34995ae994eb250fc9c7c">64ad2a92195fd05e9ba34995ae994eb250fc9c7c</a>
-<blockquote>
-<p>
- Update libpng to 1.6.26<br>
-<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/arm_init.c<br>
-libpng/arm/filter_neon_intrinsics.c<br>
-libpng/autogen.sh<br>
-libpng/config.h.in<br>
-libpng/configure<br>
-libpng/configure.ac<br>
-libpng/contrib/README.txt<br>
-libpng/contrib/arm-neon/README<br>
-libpng/contrib/arm-neon/linux-auxv.c<br>
-libpng/contrib/arm-neon/linux.c<br>
-libpng/contrib/conftest/pngcp.dfa<br>
-libpng/contrib/examples/README.txt<br>
-libpng/contrib/examples/iccfrompng.c<br>
-libpng/contrib/examples/pngpixel.c<br>
-libpng/contrib/examples/pngtopng.c<br>
-libpng/contrib/examples/simpleover.c<br>
-libpng/contrib/gregbook/README<br>
-libpng/contrib/gregbook/readpng2.c<br>
-libpng/contrib/gregbook/rpng-win.c<br>
-libpng/contrib/gregbook/rpng2-win.c<br>
-libpng/contrib/gregbook/rpng2-x.c<br>
-libpng/contrib/intel/INSTALL<br>
-libpng/contrib/intel/filter_sse2_intrinsics.c<br>
-libpng/contrib/intel/intel_init.c<br>
-libpng/contrib/intel/intel_sse.patch<br>
-libpng/contrib/libtests/fakepng.c<br>
-libpng/contrib/libtests/makepng.c<br>
-libpng/contrib/libtests/pngimage.c<br>
-libpng/contrib/libtests/pngstest-errors.h<br>
-libpng/contrib/libtests/pngstest.c<br>
-libpng/contrib/libtests/pngunknown.c<br>
-libpng/contrib/libtests/pngvalid.c<br>
-libpng/contrib/libtests/readpng.c<br>
-libpng/contrib/libtests/tarith.c<br>
-libpng/contrib/libtests/timepng.c<br>
-libpng/contrib/mips-msa/README<br>
-libpng/contrib/mips-msa/linux.c<br>
-libpng/contrib/pngminus/README<br>
-libpng/contrib/pngminus/png2pnm.c<br>
-libpng/contrib/pngminus/pnm2png.c<br>
-libpng/contrib/pngsuite/README<br>
-libpng/contrib/tools/README.txt<br>
-libpng/contrib/tools/chkfmt<br>
-libpng/contrib/tools/genpng.c<br>
-libpng/contrib/tools/png-fix-itxt.c<br>
-libpng/contrib/tools/pngcp.c<br>
-libpng/contrib/tools/pngfix.c<br>
-libpng/contrib/tools/reindent<br>
-libpng/contrib/visupng/PngFile.c<br>
-libpng/example.c<br>
-libpng/libpng-manual.txt<br>
-libpng/libpng.3<br>
-libpng/libpngpf.3<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/pngdebug.h<br>
-libpng/pngerror.c<br>
-libpng/pngget.c<br>
-libpng/pnginfo.h<br>
-libpng/pngmem.c<br>
-libpng/pngpread.c<br>
-libpng/pngpriv.h<br>
-libpng/pngread.c<br>
-libpng/pngrio.c<br>
-libpng/pngrtran.c<br>
-libpng/pngrutil.c<br>
-libpng/pngset.c<br>
-libpng/pngstruct.h<br>
-libpng/pngtest.c<br>
-libpng/pngtrans.c<br>
-libpng/pngwio.c<br>
-libpng/pngwrite.c<br>
-libpng/pngwtran.c<br>
-libpng/pngwutil.c<br>
-libpng/projects/vstudio/README.txt<br>
-libpng/projects/vstudio/WARNING<br>
-libpng/projects/vstudio/libpng/libpng.vcxproj<br>
-libpng/projects/vstudio/pnglibconf/pnglibconf.vcxproj<br>
-libpng/projects/vstudio/pngstest/pngstest.vcxproj<br>
-libpng/projects/vstudio/pngtest/pngtest.vcxproj<br>
-libpng/projects/vstudio/pngunknown/pngunknown.vcxproj<br>
-libpng/projects/vstudio/pngvalid/pngvalid.vcxproj<br>
-libpng/projects/vstudio/readme.txt<br>
-libpng/projects/vstudio/zlib.props<br>
-libpng/projects/vstudio/zlib/zlib.vcxproj<br>
-libpng/scripts/README.txt<br>
-libpng/scripts/def.c<br>
-libpng/scripts/genchk.cmake.in<br>
-libpng/scripts/genout.cmake.in<br>
-libpng/scripts/gensrc.cmake.in<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.msys<br>
-libpng/scripts/makefile.ne12bsd<br>
-libpng/scripts/makefile.netbsd<br>
-libpng/scripts/makefile.openbsd<br>
-libpng/scripts/makefile.sco<br>
-libpng/scripts/pnglibconf.dfa<br>
-libpng/scripts/pnglibconf.h.prebuilt<br>
-libpng/scripts/symbols.def<br>
-libpng/scripts/test.cmake.in<br>
-libpng/tests/pngimage-full<br>
-libpng/tests/pngimage-quick<br>
-libpng/tests/pngstest<br>
-libpng/tests/pngstest-0g01<br>
-libpng/tests/pngstest-0g02<br>
-libpng/tests/pngstest-0g04<br>
-libpng/tests/pngstest-0g08<br>
-libpng/tests/pngstest-0g16<br>
-libpng/tests/pngstest-2c08<br>
-libpng/tests/pngstest-2c16<br>
-libpng/tests/pngstest-3p01<br>
-libpng/tests/pngstest-3p02<br>
-libpng/tests/pngstest-3p04<br>
-libpng/tests/pngstest-3p08<br>
-libpng/tests/pngstest-4a08<br>
-libpng/tests/pngstest-4a16<br>
-libpng/tests/pngstest-6a08<br>
-libpng/tests/pngstest-6a16<br>
-libpng/tests/pngstest-error<br>
-libpng/tests/pngtest<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-size<br>
-libpng/tests/pngvalid-progressive-interlace-standard<br>
-libpng/tests/pngvalid-progressive-interlace-transform<br>
-libpng/tests/pngvalid-progressive-standard<br>
-libpng/tests/pngvalid-standard<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-22 09:14:28 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1b1e7f3f4abf7a97101ff7f4e2389ca2edd9af0a">1b1e7f3f4abf7a97101ff7f4e2389ca2edd9af0a</a>
-<blockquote>
-<p>
- PDF Interpreter - ensure /Separation ink names are not indirect objects<br>
-<br>
- Bug #697358 &quot;PDF interpreter throws an error on a colour space&quot;<br>
-<br>
- Another bizarre file that thinks its a good idea to reference items<br>
- as indirect objects instead of a simple inclusion. This time its the<br>
- ink name in a /Separation space.<br>
-<br>
- Simply make sure it is not an indirect object.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-20 13:53:06 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=47294ff5b168d25bfc7db64f51572d64b8ebde91">47294ff5b168d25bfc7db64f51572d64b8ebde91</a>
-<blockquote>
-<p>
- Bug 697345 Blend Color Space Support for Separation devices<br>
-<br>
- This is a rather large commit that brings support for transparency<br>
- blend color spaces to the separation devices. Previously the<br>
- transparency compositor always used CMYK for the blend color space<br>
- if the output device was a separation device.<br>
-<br>
- With this commit:<br>
-<br>
- If the blend space is RGB or Gray based, then we now ensure that the<br>
- alternate tint transform is not used when we encounter a separation or DeviceN color space.<br>
- (assuming we have not run out of spot color space at the target device). Note that<br>
- if the any of the spot colors in a DeviceN color space are CMYK process colorants and the<br>
- blend space is Gray or RGB, the alternate tint transform IS used.<br>
-<br>
- 2) The pdf14 compositor now handles a mixture of additive and subtractive components.<br>
- I.e. RGB + spots or Gray + spots.<br>
-<br>
- 3) If the blend mode is non white preserving or not separable, then the spot colors<br>
- use the normal blend mode while the process colorants use the specified blend mode.<br>
-<br>
- 4) In the process there was a bit of code clean up. But much remains to be cleaned.<br>
-<br>
-base/gdevdevn.c<br>
-base/gdevdevn.h<br>
-base/gdevdsha.c<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gscdevn.c<br>
-base/gscsepr.c<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-base/gxclrast.c<br>
-base/gxcmap.h<br>
-base/gxdcolor.c<br>
-base/gxdevsop.h<br>
-base/gxshade6.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-17 16:45:04 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c9d8618934ebf682f72dd9b3ebef48b2be535a8d">c9d8618934ebf682f72dd9b3ebef48b2be535a8d</a>
-<blockquote>
-<p>
- Change API for put_image<br>
-<br>
-base/gdevflp.c<br>
-base/gdevmpla.c<br>
-base/gdevoflt.c<br>
-base/gdevp14.c<br>
-base/gdevsclass.c<br>
-base/gxblend1.c<br>
-base/gxdevcli.h<br>
-devices/gdevbit.c<br>
-devices/gdevpng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-21 15:43:14 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b33ffc0e958b613cd6ba114d42720694b11219ff">b33ffc0e958b613cd6ba114d42720694b11219ff</a>
-<blockquote>
-<p>
- PDF interpreter - ensure Rect array entries are not indirect objects<br>
-<br>
- Bug #697357 &quot;Can't handle annots where /Rect entries are indirect&quot;<br>
-<br>
- The example file has an insanely constructed Rect entry, where not only<br>
- is the /Rect value itself an indirect object, but each of the entries<br>
- in the array is also an indirect object.<br>
-<br>
- Here we ensure that the entries in a /Rect for an annotation are<br>
- fully resolved.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-21 11:30:50 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=737da8a64a873ea128c5830519d3327baecc6444">737da8a64a873ea128c5830519d3327baecc6444</a>
-<blockquote>
-<p>
- PDF interpreter - when detecting transparent pages, include Form 'Groups'<br>
-<br>
- Bug #697354 &quot;PDF Interpreter fails to push pdf14 compositor&quot;<br>
-<br>
- We have an optimisation in the PDF interpreter which ignores page<br>
- level Group definitions, as these have no effect on the output.<br>
-<br>
- However, the way this is performed meant that we also did not detect<br>
- Group entries in Form XObjects. So if the only transparency on a page<br>
- was a Form XObject with a Group entry, then we would incorrectly<br>
- decide that the page had no transparency.<br>
-<br>
- We do still want to do the performance check at the page level, but its<br>
- important that we include Form XObject Groups in the resources check. So<br>
- here we specifically check Form XObjects to see if they have a Group.<br>
-<br>
- This produces differences in a few files, surprisingly miniscule<br>
- differences. It appears that we have a number of files which include<br>
- Forms with Group entries which, as is so often the case with PDF<br>
- files produced by naive graphics libraries, don't actually *do* any<br>
- real transparency.<br>
-<br>
- Unfortunately this does mean we now process those files slower than<br>
- we did before (and ps2write now produces images for them), but I don't<br>
- see any real prospect of detecting pointless transparency at this depth<br>
- in a PDF file.<br>
-<br>
- So the only differences are small colour changes depending on the<br>
- ProcessColorModel of the destination device. None of these appear to<br>
- be significant to me.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-16 14:13:18 -0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36269a8e76b7b495eba9cc061ebf52163188876a">36269a8e76b7b495eba9cc061ebf52163188876a</a>
-<blockquote>
-<p>
- &quot;rpdl&quot; output device: Allow 5pt tolerance for page size selection<br>
-<br>
- The &quot;rpdl&quot; printer driver required an exact match of the page size in<br>
- points so that the correct command for selecting the page size was<br>
- sent to the printer. Otherwise the printer received the command for a<br>
- custom size. Tis is fixed now, allowing a 5-point tolerance (Bug<br>
- 697348).<br>
-<br>
-contrib/japanese/gdevrpdl.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-15 15:06:58 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=99e9ca317adbd28b5faf3e9eda4c63d636478f43">99e9ca317adbd28b5faf3e9eda4c63d636478f43</a>
-<blockquote>
-<p>
- Bug 697045: Skip over broken tile data rather than aborting.<br>
-<br>
-openjpeg/src/lib/openjp2/j2k.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-01 18:50:30 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f6ddae95676585717159445001fda2ebb00db8d">2f6ddae95676585717159445001fda2ebb00db8d</a>
-<blockquote>
-<p>
- Squash compiler warning.<br>
-<br>
-base/gxccman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-14 16:59: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=90b7603c1afb3ad79a6a0dfee97560b1c3565379">90b7603c1afb3ad79a6a0dfee97560b1c3565379</a>
-<blockquote>
-<p>
- PCL - fix pdfmark parsing for PUTFILE<br>
-<br>
- Bug #697285 &quot;Not able to produce a valid PDF/A - Invalid ColorSpace error opening a PDF&quot;<br>
-<br>
- We have a special pdfmark type '/PUTFILE' for dealing with files,<br>
- because unlike PostScript we can't deal with these as file objects in<br>
- PJL. The code reading the file had a bug, I think caused by altering<br>
- for error detection.<br>
-<br>
- Fixed here, and returned the error back up the tree. However, note that<br>
- the PCL interpreter still ignores error returns from PJL parsing.<br>
-<br>
- No differences expected.<br>
-<br>
-pcl/pl/plparams.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-14 15:06:49 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0f6067d2531298060392d0e25fa759d320e03021">0f6067d2531298060392d0e25fa759d320e03021</a>
-<blockquote>
-<p>
- ps2write - don't try to alter /pagesave when modifying media size<br>
-<br>
- Bug #697245 &quot; Generated postscript by ps2write causes limitcheck for save error&quot;<br>
-<br>
- When altering the media size for a page the code defined the save object<br>
- 'pagesave' with the new media size. I believe the intention was probably<br>
- to have the new media size persist, in order to avoid calling setpagdevice<br>
- for every subsequent page with the modified media.<br>
-<br>
- Unfortunately, this does not remove the prior 'save' object attached to<br>
- /pagesave. The only way to get rid of that is to actually 'restore' it.<br>
-<br>
- So, fundamentally, we need to remove the definition of pagesave from<br>
- the code which sets the media size. We can achieve the same effect in a<br>
- rather more roundabout fashion by also moving the definition of pagesave<br>
- within the page stream to a point after the definition of the page<br>
- dictionary.<br>
-<br>
- Less neat, but it works.<br>
-<br>
- For some obscure reason this results in some pages being rendered<br>
- very slightly different sizes on the cluster. I've checked and the<br>
- current sizes are correct. I have no idea why this was wrong before<br>
- and I'm not interested enough to go looking, since they are now<br>
- correct.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/opdfread.h<br>
-lib/opdfread.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-14 10:14:01 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8cefc79359e14fdb8b967697bba33b754e83bcad">8cefc79359e14fdb8b967697bba33b754e83bcad</a>
-<blockquote>
-<p>
- pdfwrite - fix calculation of a bounding box<br>
-<br>
- Bug #697237 &quot;ps2pdf not producing correct PDF with a rotated character in the PS&quot;<br>
-<br>
- The code for detecting a glyph which is completely clipped out of the<br>
- output had a fault; after calculating the Font BoundingBox in current<br>
- user space, it only considered three of the points of the resulting<br>
- rectangle to calculate the largest rectangle.<br>
-<br>
- This erroneous rectangle was then used to decide if a glyph was entirely<br>
- outside the clipping area. Since the top left corner was not considered<br>
- a sufficiently large glyph rotated to an acute enough anti-clockwise<br>
- angle could appear to be totally clipped when in fact it is only<br>
- partially clipped.<br>
-<br>
- Fix this here by considering all four points.<br>
-<br>
- This show two very minor progressions in Quality Logic tests and some<br>
- PXL-&gt;PDF conversions are now larger. The reason is that we use the<br>
- font bounding box and a couple of glyphs are now considered to be<br>
- unclipped when in fact they are totally clipped out, but we can't tell.<br>
- This results in not only the glyphs but also a font being embedded<br>
- in the output and increasing the size slightly.<br>
-<br>
-devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-12 11:24:18 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a46245139253b2ec607fcd06c549a6293d05a3a8">a46245139253b2ec607fcd06c549a6293d05a3a8</a>
-<blockquote>
-<p>
- Fix a bug in device subclassing<br>
-<br>
- If we free the memory used by a child device, we must not then try<br>
- to write to that memory.<br>
-<br>
- Chanced upon while working on bug #697279<br>
-<br>
-base/gdevdflt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-10 17:45: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=513d6fd7ddfc5a59fbf8bf6ce72eda6c97fea9f8">513d6fd7ddfc5a59fbf8bf6ce72eda6c97fea9f8</a>
-<blockquote>
-<p>
- remove a bunch of now unused variables from the earlier shading code<br>
- commit.<br>
-<br>
-base/gxshade1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-10 14:42:49 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8a26fa67398970f357e1292310ef20556a8e5d96">8a26fa67398970f357e1292310ef20556a8e5d96</a>
-<blockquote>
-<p>
- Fix 'corner' radial gradient case.<br>
-<br>
- Bug #697144 &quot; Some incorrectly rendered radial shadings&quot;<br>
-<br>
- This is to address 'radialshade4.ps, but fixed (the customer had managed<br>
- to create incorrect PostScript for this specific test, see radialshade4b.ps).<br>
-<br>
- In the case where the two circles defining a radial gradient are<br>
- tangential, and the larger circle has 'extend' set to true, the extended<br>
- area should be limited to the tangent which touches the two circles, and<br>
- the smaller circle should not be filled.<br>
-<br>
- Getting this corre4ct with our existing method for drawing gradients<br>
- has been difficult. It 'looks like' all gradients are defined in terms<br>
- of tensor patches, rather than having a dedicated plotter for each<br>
- gradient type.<br>
-<br>
- In order to generate a proper 'truncated' annulus for this case, it is<br>
- necessary to construct a number of different 'quadrilaterals' and fit<br>
- them carefully around the larger circle. To ensure no 'cracks' appear<br>
- between the quads, we must also take care to ensure that they join at<br>
- horizontal or vertical boundaries (in user space).<br>
-<br>
- There's some trigonometry involved to get this correct, and to avoid<br>
- having to check for infinity returns from tan(alpha), and generally<br>
- avoid the complex work required in the general case, we handle the<br>
- cases where the tangent point of the circles is on a horizontal or<br>
- vertical axis.<br>
-<br>
- This passes cluster tests, the customer test suite, and my own hand<br>
- created PostScript files which exercise the code rather more thoroughly<br>
-<br>
- No differences expected.<br>
-<br>
-base/gxshade1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-09 22:02:47 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d4d8b7d51f79b47d21d3c82fe652a79e1f890df5">d4d8b7d51f79b47d21d3c82fe652a79e1f890df5</a>
-<blockquote>
-<p>
- Fix bug 697323, Segfault after pattern with transparency.<br>
-<br>
- While the pdfwrite device usage may have contributed to the path being<br>
- taken, the segfault was in the GC and was due to a pattern-clist device<br>
- still existing in the allocator, but no longer referenced (at least as<br>
- seen with a debug build. The fix was to set gx_device_retain false for<br>
- the adev (pattern accum device, which may be a pattern-clist device) for<br>
- the case where the pattern uses transparency so the freeing the saved<br>
- gstate would free the pdf14 device and it would rc_decrement its target,<br>
- thus freeing the accumulator device.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-07 14:03:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e2523b9dae517f91bd7da78323e5207d099a10e">0e2523b9dae517f91bd7da78323e5207d099a10e</a>
-<blockquote>
-<p>
- Fix expat build on Windows<br>
-<br>
- The new version of expat uses time/date API calls to seed a hash function. That<br>
- means we need a extra CFLAG (/DWIN32) and to drop the /Za CFLAG as we do for<br>
- LCMS2.<br>
-<br>
-base/expat.mak<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-14 10:40:36 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c9f7be4f4de8e98df9d34ff8e4a7f781c0a33899">c9f7be4f4de8e98df9d34ff8e4a7f781c0a33899</a>
-<blockquote>
-<p>
- Bring master up to date with 9.20 release branch<br>
-<br>
- Docs, dates, copyrights etc.<br>
-<br>
- Copyrights, dates etc<br>
-<br>
- Update News and changelog<br>
-<br>
- Fix a type in the release comments<br>
-<br>
- Changelog update for 9.20 RC2<br>
-<br>
- Update date and product string for 9.20 release<br>
-<br>
- Copyrights, dates etc<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/Xfonts.htm<br>
-doc/gs-vms.hlp<br>
-doc/sample_downscale_device.htm<br>
-doc/thirdparty.htm<br>
-man/dvipdf.1<br>
-man/font2c.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>
-man/wftopfa.1<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-04 13:18: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=21b582ca561214aa9c5b9c8987a1c0cdce43ace6">21b582ca561214aa9c5b9c8987a1c0cdce43ace6</a>
-<blockquote>
-<p>
- Add expat endian settings.<br>
-<br>
- And fix the logic for the LCMS2 endian setting (noticed in passing).<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-04 12:41: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=c99d0ad7d5f5187e5e0279b6f9c8092798badc2f">c99d0ad7d5f5187e5e0279b6f9c8092798badc2f</a>
-<blockquote>
-<p>
- Bug 697181: allow xps build with shared expat.<br>
-<br>
-Makefile.in<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-04 12:13:08 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=00b5d81646bb936577cbea2476e13f0a5dd4b9f1">00b5d81646bb936577cbea2476e13f0a5dd4b9f1</a>
-<blockquote>
-<p>
- Update to expat 2.2.0<br>
-<br>
-expat/CMake.README<br>
-expat/CMakeLists.txt<br>
-expat/COPYING<br>
-expat/Changes<br>
-expat/ConfigureChecks.cmake<br>
-expat/MANIFEST<br>
-expat/Makefile.in<br>
-expat/README<br>
-expat/aclocal.m4<br>
-expat/amiga/Makefile<br>
-expat/amiga/README.txt<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/launch.c<br>
-expat/amiga/stdlib.c<br>
-expat/bcb5/elements.bpr<br>
-expat/bcb5/expat.bpr<br>
-expat/bcb5/expat.mak<br>
-expat/bcb5/expat_static.bpr<br>
-expat/bcb5/expat_static.mak<br>
-expat/bcb5/expatw.bpr<br>
-expat/bcb5/expatw.mak<br>
-expat/bcb5/expatw_static.bpr<br>
-expat/bcb5/expatw_static.mak<br>
-expat/bcb5/outline.bpr<br>
-expat/bcb5/xmlwf.bpr<br>
-expat/bcb5/xmlwf.mak<br>
-expat/configure<br>
-expat/configure.ac<br>
-expat/configure.in<br>
-expat/conftools/PrintPath<br>
-expat/conftools/ac_c_bigendian_cross.m4<br>
-expat/conftools/config.guess<br>
-expat/conftools/config.sub<br>
-expat/conftools/expat.m4<br>
-expat/conftools/get-version.sh<br>
-expat/conftools/install-sh<br>
-expat/conftools/libtool.m4<br>
-expat/conftools/ltmain.sh<br>
-expat/conftools/mkinstalldirs<br>
-expat/doc/expat.png<br>
-expat/doc/reference.html<br>
-expat/doc/valid-xhtml10.png<br>
-expat/doc/xmlwf.1<br>
-expat/doc/xmlwf.sgml<br>
-expat/doc/xmlwf.xml<br>
-expat/examples/elements.c<br>
-expat/examples/elements.dsp<br>
-expat/examples/outline.c<br>
-expat/examples/outline.dsp<br>
-expat/expat.dsw<br>
-expat/expat.pc.in<br>
-expat/expat_config.h.cmake<br>
-expat/expat_config.h.in<br>
-expat/lib/amigaconfig.h<br>
-expat/lib/expat.dsp<br>
-expat/lib/expat.h<br>
-expat/lib/expat_external.h<br>
-expat/lib/expat_static.dsp<br>
-expat/lib/expatw.dsp<br>
-expat/lib/expatw_static.dsp<br>
-expat/lib/internal.h<br>
-expat/lib/libexpat.def<br>
-expat/lib/libexpatw.def<br>
-expat/lib/xmlparse.c<br>
-expat/lib/xmlrole.c<br>
-expat/lib/xmltok.c<br>
-expat/lib/xmltok.h<br>
-expat/lib/xmltok_impl.c<br>
-expat/m4/libtool.m4<br>
-expat/m4/ltoptions.m4<br>
-expat/m4/ltsugar.m4<br>
-expat/m4/ltversion.m4<br>
-expat/m4/lt~obsolete.m4<br>
-expat/tests/README.txt<br>
-expat/tests/benchmark/README.txt<br>
-expat/tests/benchmark/benchmark.dsp<br>
-expat/tests/chardata.c<br>
-expat/tests/minicheck.c<br>
-expat/tests/minicheck.h<br>
-expat/tests/runtests.c<br>
-expat/tests/xmltest.sh<br>
-expat/win32/README.txt<br>
-expat/win32/expat.iss<br>
-expat/xmlwf/codepage.c<br>
-expat/xmlwf/readfilemap.c<br>
-expat/xmlwf/unixfilemap.c<br>
-expat/xmlwf/xmlfile.c<br>
-expat/xmlwf/xmlwf.c<br>
-expat/xmlwf/xmlwf.dsp<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-03 13:09:27 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a73e3cf1ca91bbdb51d5a999a491e58fb9a7ce35">a73e3cf1ca91bbdb51d5a999a491e58fb9a7ce35</a>
-<blockquote>
-<p>
- Bug 697286: handle GlyphDirectory as an array<br>
-<br>
- For high level devices that need to copy CIDFonts, we need to establish the<br>
- highest CID in a given CIDFont. If the font has a GlyphDirectory dictionary<br>
- the only way to do so is to iterate through the keys to find the highest.<br>
-<br>
- The code handling this ignored that the GlyphDirectory could be an array,<br>
- which confused the dictionary content iterator, and caused a segfault.<br>
-<br>
- In the case of an array, set the high CID to the highest index available in the<br>
- array.<br>
-<br>
-psi/zfcid.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-02 16:19:02 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc62c90930512f4b571f68c9110022b234cbd411">dc62c90930512f4b571f68c9110022b234cbd411</a>
-<blockquote>
-<p>
- Bug 697186: Tweak to previous JPEG fix.<br>
-<br>
- Only clamp the DC coefficient. This shouldn't make a difference<br>
- in any real world cases, but is more correct.<br>
-<br>
-jpeg/jidctint.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-11-01 18:40:04 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8dcec8cc076a0cf8350ca7a6ec1d3136812e2a24">8dcec8cc076a0cf8350ca7a6ec1d3136812e2a24</a>
-<blockquote>
-<p>
- Bug 697186: Workaround JPEG lib bug.<br>
-<br>
- Commit fix for overflow. Awaiting response from IJG.<br>
-<br>
-jpeg/jidctint.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-26 16:35: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=1eebbfa373d295bdd2bad88aaef1edc368450568">1eebbfa373d295bdd2bad88aaef1edc368450568</a>
-<blockquote>
-<p>
- Bug 697231: Introduce caching to use of clipping paths.<br>
-<br>
- When we create a clipping device from a path, we copy over the<br>
- pointers to the rectangle list, and start searching them from<br>
- the start.<br>
-<br>
- This means that if we perform an operation that causes lots of<br>
- calls to something with the same clipping path (like for instance<br>
- a stroke operation with a clipping path that calls down to a fill<br>
- path with a clipping path), then we will repeatedly search from<br>
- the top of the rectangle list.<br>
-<br>
- This massively slows stuff down.<br>
-<br>
- This commit introduces a 'cached' entry in the clipping path<br>
- that can be updated after a clipping device has been used to show<br>
- the last place in the list that was found. Subsequent creations<br>
- start searching from this point.<br>
-<br>
- This gives us the desired locality of reference, and massively<br>
- speeds up the test file.<br>
-<br>
-base/gxacpath.c<br>
-base/gxclip.c<br>
-base/gxcpath.c<br>
-base/gxcpath.h<br>
-base/gxfill.c<br>
-base/gzcpath.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-26 12:14:48 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=71629c04758788b238d6ff3537d9708f430a4db7">71629c04758788b238d6ff3537d9708f430a4db7</a>
-<blockquote>
-<p>
- Tweak to clip device nesting.<br>
-<br>
- Any call through clip_call_fill_path will be safely nested<br>
- in terms of the clippers used. Reflect this in the<br>
- initialisation of the local device. This avoids an error given<br>
- with the next commit.<br>
-<br>
-base/gxclip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-26 17:39:29 -0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0726780b28920045ee6f344a34bc5e8565bc4ed5">0726780b28920045ee6f344a34bc5e8565bc4ed5</a>
-<blockquote>
-<p>
- &quot;cups&quot; output device: When creating PWG Raster output, always output the bitmap of the full page, ignoring any unprintable margins suggested by the PPD file.<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-26 08:37: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=f0b49c3cf4e0602627c4dc5b6ff910074d298398">f0b49c3cf4e0602627c4dc5b6ff910074d298398</a>
-<blockquote>
-<p>
- set GX_DOWNSCALER_PARAMS_DEFAULTS to remaining JPEG devices<br>
-<br>
- Michael's fix in commit 45268652fcddf2031f5edb592bc61e53d9ac4f5b<br>
- resolves the problem for jpeg, but didn't fix the jpeggray or jpegcmyk<br>
- devices, as shown by the all devices test.<br>
-<br>
- I believe copying the same fix to the other devices should resolve those<br>
- too.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/gdevjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-25 15:34: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=45268652fcddf2031f5edb592bc61e53d9ac4f5b">45268652fcddf2031f5edb592bc61e53d9ac4f5b</a>
-<blockquote>
-<p>
- Set GX_DOWNSCALER_PARAMS_DEFAULTS in jpeg<br>
-<br>
- Fix for crash caused by division by zero<br>
-<br>
-devices/gdevjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-25 18:25: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=cb8022f3e15b761adf4bbc78621cf0699f69e21c">cb8022f3e15b761adf4bbc78621cf0699f69e21c</a>
-<blockquote>
-<p>
- Fix SEGV caused by previous commit.<br>
-<br>
- Running:<br>
-<br>
- gs --debug<br>
-<br>
- would cause a SEGV in gs_finit_push_systemdict due to<br>
- i_ctx_p being NULL.<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-25 11:16: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=2f3679b53632c5b7b9e9a416311ae82f36645fc9">2f3679b53632c5b7b9e9a416311ae82f36645fc9</a>
-<blockquote>
-<p>
- Bug 697220(2): Fix returning execstackoverflow<br>
-<br>
- In one case of returning execstackoverflow from the main interpreter loop,<br>
- we'd set the interpreter's private count value of objects to execute, *before*<br>
- we try to push the ref array onto the stack. As a consequence the object<br>
- count was for the new array, but the top of the exec stack was still the<br>
- previous array. This meant when we sync'ed the interpreter loop's internal<br>
- state with the state in the interpreter context, the size of the top object<br>
- on the exec stack could be wrong, causing problems in the garbager - especially<br>
- if the length was too long.<br>
-<br>
- To resolve, move the exec stack bounds check before the count gets set.<br>
-<br>
-psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-25 11: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=3f09e7022e39412af98602cdfe22adfb34a7fa63">3f09e7022e39412af98602cdfe22adfb34a7fa63</a>
-<blockquote>
-<p>
- Bug 697220(1): Push systemdict onto dict stack before we cleanup.<br>
-<br>
- As part of shutting down the Postscript interpreter, we run some Postscript<br>
- from the C code. We really don't want to stumble across random redefinitions<br>
- of operators (especially if the definitions trigger errors) at this point.<br>
-<br>
- So, push systemdict onto the top of the dict stack before we start our cleanup.<br>
-<br>
- Do it in C, to further ensure we don't trip over redefinitions in the Postscipt<br>
- world.<br>
-<br>
- This *should* resolve the segfaults, but leaves a garbage collector error<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-25 11:10: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=5d1ae930711d492d01110ef054c0add3c7615910">5d1ae930711d492d01110ef054c0add3c7615910</a>
-<blockquote>
-<p>
- Fix BOBBIN undefined warnings.<br>
-<br>
-base/bobbin.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-23 00:58: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=3216c2b692fe5a4c87936819b2fe14d0963a347a">3216c2b692fe5a4c87936819b2fe14d0963a347a</a>
-<blockquote>
-<p>
- Bug 697144: Fix fix for previous radial shading fix.<br>
-<br>
- This fixes the final case in page_create_color.ps<br>
-<br>
- In some cases R_tensor_annulus can be called twice; avoid<br>
- flipping function_arg_shift back and forth.<br>
-<br>
-base/gxshade1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-22 15:47:35 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5915f971fa47c8ad1561e403bc7aacd86325c428">5915f971fa47c8ad1561e403bc7aacd86325c428</a>
-<blockquote>
-<p>
- Bug 697144: Fix radial shadings broken by previous fix.<br>
-<br>
- The previous fix addressed the fact that monotonicity of a<br>
- filled quad was being tested based on splitting on u rather<br>
- than v (or vice versa). It turns out that in some<br>
- circumstances (when circles are entirely nested), we reverse<br>
- u and v, and hence need to reverse the test.<br>
-<br>
- The previous fix did not allow for this.<br>
-<br>
-base/gxshade1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-21 17:00: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=898cdaedf52a37c84923d75aa2942e48b0fec91c">898cdaedf52a37c84923d75aa2942e48b0fec91c</a>
-<blockquote>
-<p>
- Bug 697144: Fix radialshade2.ps<br>
-<br>
- Many many moons ago, a fix was committed for bug 690831. The<br>
- commit message for that was lost in the great svn -&gt; git<br>
- migration, but the bug itself makes the history clear.<br>
-<br>
- Looking back at this again now, it appears that the fix was<br>
- incorrect. Ghostscript was in fact doing the right thing by<br>
- the letter of the standard, but Acrobat was applying a fudge<br>
- factor.<br>
-<br>
- When filling a radial shade, the code tests to see if the<br>
- two circles are nested. If so, then when the shade is 'extended',<br>
- the entire area outside the final circle is filled. If not,<br>
- a different fill operation has to happen.<br>
-<br>
- The file given in the bug has a shade where the two circles are<br>
- very close to being nested, but are not strictly so. Acrobat is<br>
- choosing to treat them as if they were.<br>
-<br>
- We therefore revert the code to 'unbreak' it, and adjust the<br>
- fudge factor in our code to give the same results as Acrobat does.<br>
-<br>
- This causes no changes in the cluster tests.<br>
-<br>
-base/gxshade1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-25 10:59: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=c3c4bf022a631be939ebb4bf6f59e41514cb1e48">c3c4bf022a631be939ebb4bf6f59e41514cb1e48</a>
-<blockquote>
-<p>
- Bug 696508: improve configure cross compile support<br>
-<br>
- This is a squashing of the commits on the branch:<br>
-<br>
- CCAUX-configure<br>
-<br>
- This allows CCAUX and related settings to be set on the configure command<br>
- line, or in the environment.<br>
-<br>
- Also, using configure to guess at creating an arch.h file which gets used<br>
- rather than genarch generating one. A couple of things in that file will<br>
- not be as accurate as using genarch, but those are rare, and almost<br>
- certainly for outdated systems (such as whether floats use IEEE<br>
- representation).<br>
-<br>
- Better documentation to follow, but as an example, building for Android would<br>
- work with:<br>
-<br>
- ./configure --host=arm-linux-gnu --build=x86_64-linux-gnu \<br>
- CC=/opt/android-ndk-r10e/toolchains/arm-linux-androideabi-4.9/prebuilt/linux-x86_64/bin/arm-linux-androideabi-gcc \<br>
- CFLAGS=&quot;--sysroot=/home/cliddell/bin/android-ndk-r10e/platforms/android-18/arch-arm -MMD -MP -MF -fpic \<br>
- -ffunction-sections -funwind-tables -fstack-protector -no-canonical-prefixes -march=armv7-a -mfloat-abi=softfp \<br>
- -mfpu=vfpv3-d16 -mthumb -fomit-frame-pointer -fno-strict-aliasing -finline-limit=64 -Wa,--noexecstack&quot; LDFLAGS=&quot; \<br>
- --sysroot=/home/cliddell/bin/android-ndk-r10e/platforms/android-18/arch-arm -MMD -MP -MF -fpic -ffunction-sections \<br>
- -funwind-tables -fstack-protector -no-canonical-prefixes -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -mthumb \<br>
- -fomit-frame-pointer -fno-strict-aliasing -finline-limit=64 -Wa,--noexecstack&quot; CCAUX=gcc CFLAGSAUX=&quot; &quot;<br>
-<br>
-.gitignore<br>
-Makefile.in<br>
-arch/arch_autoconf.h.in<br>
-base/gsroprun.c<br>
-base/unix-aux.mak<br>
-base/unix-end.mak<br>
-configure.ac<br>
-xps/xps.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-20 16:45:09 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0845a1c90f7a22a5b50fddbf7809d985b98290cd">0845a1c90f7a22a5b50fddbf7809d985b98290cd</a>
-<blockquote>
-<p>
- Bug 697144: Fix radialshade1.ps<br>
-<br>
- When filling a radial shading, we form 4 tensor patches, one for<br>
- each quadrant. The points for these are represented as poles of<br>
- the tensor patches as p-&gt;poles[v][u].<br>
-<br>
- One quadrant might look like (excuse the ascii art)<br>
-<br>
- J I H G p-&gt;poles[0][0] = A p-&gt;poles[3][0] = J<br>
- F p-&gt;poles[0][1] = B p-&gt;poles[2][0] = K<br>
- K ED p-&gt;poles[0][2] = C p-&gt;poles[1][0] = L<br>
- p-&gt;poles[0][3] = D<br>
- C p-&gt;poles[1][3] = E (plus 4 more points<br>
- p-&gt;poles[2][3] = F internal to the<br>
- B p-&gt;poles[3][3] = G patch, not shown<br>
- p-&gt;poles[3][2] = H here)<br>
- L A p-&gt;poles[3][1] = I<br>
-<br>
- Thus 'u' controls how far along the radius of the radial shading<br>
- we are, and 'v' controls how far 'around' the shading we are.<br>
-<br>
- The shading code first subdivides the patch on v (using the<br>
- split_patch routine). This gives us a succession of slices running<br>
- from the centre of the radial fill to the outside (like slices of<br>
- pizza).<br>
-<br>
- It then subdivides these slices (using split_slice) to give small<br>
- quadrangles to fill.<br>
-<br>
- The code then checks to see whether these quadrangles need to be<br>
- further divided by checking to see whether the color change across<br>
- such quadrangles is monotonic or not. If it is, and the quadrangles<br>
- are 'not big' (for some definition of big) then it is considered<br>
- reasonable to fill them using a linear fill.<br>
-<br>
- For simple radial fills, the color changes across 'u' not 'v'.<br>
- We thefore check for the color change in the given range to see<br>
- if it is monotonic, and if it not, we divide the patch.<br>
-<br>
- As part of the work for bug 689189 (see commit 36375961a02091)<br>
- Igor had identified some uses of the radial fill code where the<br>
- tensor patches are constructed such that the color varies across<br>
- 'v' rather than 'u', and had therefore amended the code so allow<br>
- for this.<br>
-<br>
- Unfortunately the setup for this appears to have got it wrong<br>
- for the normal radial case. Fixing that here solves the problem.<br>
-<br>
-base/gxshade1.c<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-20 11:45:54 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cca05810721874cabcc377615cac050bd775ed37">cca05810721874cabcc377615cac050bd775ed37</a>
-<blockquote>
-<p>
- Add -dNoSeparationFiles to tiffsep device<br>
-<br>
- If -dNoSeparationFiles is specified when using the tiffsep<br>
- device, only the composite file will be created, no<br>
- separations are created in this case.<br>
-<br>
-devices/gdevtsep.c<br>
-doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-17 16:34:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6d1822faa68c17b945aea2713985b7095ca424aa">6d1822faa68c17b945aea2713985b7095ca424aa</a>
-<blockquote>
-<p>
- ASAN segfault: add missing pointer to pclxl_image_enum_t gc info<br>
-<br>
- The pclxl_image_enum_t stores a pointer to an icclink which is allocated in gc<br>
- memory, so the garbager needs to know about that.<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-17 15:14: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=e6460567fcec3b4c96dd4912e556e3b846adaef2">e6460567fcec3b4c96dd4912e556e3b846adaef2</a>
-<blockquote>
-<p>
- Refine SAFER file access permissions<br>
-<br>
- SAFER (amongst other things) is to stop arbitrary file accesses on the host<br>
- system (in Postscript terms '%os%....') but it should not limit access to<br>
- other Postscript devices (most importantly '%rom%').<br>
-<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-17 16:21:30 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ed425fcd620837bf63a18a3ee2a2202fa91b1207">ed425fcd620837bf63a18a3ee2a2202fa91b1207</a>
-<blockquote>
-<p>
- Add -sPostRenderICCProfile support to tiffsep<br>
-<br>
- Customer would like to have this capability.<br>
-<br>
-devices/devs.mak<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-17 20:10:46 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=937efa62c23c2c79c7487895421041896e8c14b7">937efa62c23c2c79c7487895421041896e8c14b7</a>
-<blockquote>
-<p>
- Fix previous JPEG commit.<br>
-<br>
- The previous commit did not even compile. I have no idea how<br>
- I managed to get that to pass the tests I ran!<br>
-<br>
- Apologies.<br>
-<br>
-devices/gdevjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-17 18:11:08 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6f14fb471faedbe9657d32743dba609ddd3a0465">6f14fb471faedbe9657d32743dba609ddd3a0465</a>
-<blockquote>
-<p>
- Add Downscaler functionality to jpeg devices.<br>
-<br>
-devices/gdevjpeg.c<br>
-doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-12 14:15:50 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=910f459d535cec757b8e5f541dd39be6fa2fb0c9">910f459d535cec757b8e5f541dd39be6fa2fb0c9</a>
-<blockquote>
-<p>
- Bug 697012: Fix buffer overflow in gxps.<br>
-<br>
- Port back same fix already applied to muxps.<br>
-<br>
-xps/xpsglyphs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-17 10:03:53 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9388ecefe9d8659d8434aa78d07a1fa247c8ea4e">9388ecefe9d8659d8434aa78d07a1fa247c8ea4e</a>
-<blockquote>
-<p>
- Rework openjpeg subsampled decode.<br>
-<br>
- The current code performs the yuv -&gt; rgb step on the data<br>
- within openjpegs buffers. Unfortunately, this means that<br>
- subsampled data is &quot;expanded&quot; into rgb, converted, and then<br>
- redecimated. The R plane stays intact, and the G and the B<br>
- are degraded. The code is then desubsampled again when copying<br>
- out into the stream, but the damage has been done.<br>
-<br>
- This gives awful results.<br>
-<br>
- Instead here, we simplify the code to decode a row at a time<br>
- into a row buffer. We then convert that row buffer to rgb, and<br>
- copy that out. We never redecimate the output.<br>
-<br>
- This looks much better.<br>
-<br>
-base/sjpx_openjpeg.c<br>
-base/sjpx_openjpeg.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-16 11:36: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=08b3f4a91fc65f36da13dfb02a1273c70638c6af">08b3f4a91fc65f36da13dfb02a1273c70638c6af</a>
-<blockquote>
-<p>
- Bug 697217(4): deal with negative index in context ops<br>
-<br>
- In this case the join operator was being passed a negative index.<br>
-<br>
-psi/zcontext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-16 11:30:36 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a7a8b148c368d313f913c23a754e14394d6fb5a1">a7a8b148c368d313f913c23a754e14394d6fb5a1</a>
-<blockquote>
-<p>
- Bug 697217(3): guard against stack underflow in debug info dump<br>
-<br>
- In the event of an error exit, we dump out the contents of the stacks.<br>
-<br>
- *But* in the event of an error, we can already be into the &quot;guard&quot; entries<br>
- below the bottom of the normal operand stack - so protect against that<br>
- when dumping out the stack.<br>
-<br>
-psi/idebug.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-16 13:11:46 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=86ea41068f8ee8930aa169ad3a106db4f7d6c7db">86ea41068f8ee8930aa169ad3a106db4f7d6c7db</a>
-<blockquote>
-<p>
- Bug 697217(2): cleanup exec stack on currentcolor* error<br>
-<br>
- If an error occurs when retrieving currentcolor values, we have to clean up<br>
- the exec stack before returning the error.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-16 11:18: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=060cfdc002d29158d9d7f6c5fb15f187c165d408">060cfdc002d29158d9d7f6c5fb15f187c165d408</a>
-<blockquote>
-<p>
- Bug 697217(1): Match signs when checking lengths in binary sequences<br>
-<br>
-psi/iscanbin.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-14 15:50: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=1f6581f9b77868b56a2f6269f3d1440c9eaad8b0">1f6581f9b77868b56a2f6269f3d1440c9eaad8b0</a>
-<blockquote>
-<p>
- Bug 692721: remove SMask specific stuff from form dict<br>
-<br>
- When we get an SMask group, we have to store the graphics state and the contents<br>
- of the ExtGState, and reset all that before we execute the content stream<br>
- for the group XObject. So it all gets setup in the correct place, that<br>
- information needs to be added to the group's form dictionary.<br>
-<br>
- It turns out we also need to *remove* these entries from the group's form<br>
- dictionary, in case it gets reused as a normal for XObject.<br>
-<br>
- The gstate and extended gstate values remain in the SMask parameter dictionary,<br>
- so any reuse of the SMask will still work correctly.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-14 08:38:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3bf51ac09d8759761057bbf1817434415616258e">3bf51ac09d8759761057bbf1817434415616258e</a>
-<blockquote>
-<p>
- pdfwrite - fix SMask handling, when painting with a Pattern<br>
-<br>
- Bug #697212 &quot;Error in SMask during ExtGState&quot;<br>
-<br>
- The title is misleading, the error occurs with a Pattern, but there must<br>
- be an SMask preceding it. This appears to have been a very long-standing<br>
- problem in the code, but it was hidden by ignoring an error return code.<br>
- Fixing Coverity reports meant that the return code was actioned, and that<br>
- is what revealed the problem.<br>
-<br>
- When we start a new substream to capture a Pattern PaintProc we need to<br>
- reset the 'soft_mask_id' (the ID assigned to the SMask pdfwrite has<br>
- created) in the graphics state. If we don't do that then the code (in<br>
- effect) tries to handle the SMask twice, once for the correct stream<br>
- and once for the pattern PaintProc stream, and this results in the<br>
- stack of pdfwrite internal gstate copies becoming unsynchronised, as well<br>
- as creating a PDF file with unbalanced q/Q operators.<br>
-<br>
- Ignoring the return code had masked this problem.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-13 16:47:47 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=84fec37351ebd502c70ac16347fae4b1b5f5cbe6">84fec37351ebd502c70ac16347fae4b1b5f5cbe6</a>
-<blockquote>
-<p>
- Fix for Bug 695154<br>
-<br>
- The pngalpha device should really have its separable_and_linear setting<br>
- set to GX_CINFO_UNKNOWN_SEP_LIN. In this case, the device will get its shifting<br>
- and mask color info settings set up and in this case the gradient<br>
- code will actually work in the manner to which it is designed.<br>
-<br>
-devices/gdevpng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-12 11:02:09 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=06add83a38437ccd2e7f0f1deb5e2d7bc7a8546d">06add83a38437ccd2e7f0f1deb5e2d7bc7a8546d</a>
-<blockquote>
-<p>
- Bug 695340. Avoid NULL dereferences<br>
-<br>
-base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-09 08:22:03 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6d5b4ffeb00f50faf45b72191d38dea422f28405">6d5b4ffeb00f50faf45b72191d38dea422f28405</a>
-<blockquote>
-<p>
- Bug 694189 catch NULL of pinst<br>
-<br>
- If an error occurs and we dig through the saved<br>
- gstates to find the pattern but come up empty<br>
- then return an error<br>
-<br>
-psi/zpcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-11 11:16:59 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=62e787ce74c5c22aaba9377a709bc06217bd46f8">62e787ce74c5c22aaba9377a709bc06217bd46f8</a>
-<blockquote>
-<p>
- Fix Bug 696866: patterns need to set color_usage.or over the entire area<br>
-<br>
- Thanks to Michael Vrhel for the simplified file and suggesting the cause of<br>
- the problem.<br>
-<br>
-base/gxclpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-11 16:07: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=a48d5240229d2a5cf9413ff2a425c40e2db03b8e">a48d5240229d2a5cf9413ff2a425c40e2db03b8e</a>
-<blockquote>
-<p>
- xpswrite: Add color space to enumerated pointers<br>
-<br>
- In the xps_image_enum_s the pointer to the color space (pcs) was not<br>
- declared to the garbage collector, so could end up moving with the<br>
- object being updated.<br>
-<br>
- Caused a segfault spotted in the weekly regression test (for EPSCrop, but<br>
- that's not relevant)<br>
-<br>
-devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-10 14:03: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=a34f71c530409a559c4cb35cb1a23296541d53c3">a34f71c530409a559c4cb35cb1a23296541d53c3</a>
-<blockquote>
-<p>
- Fix Bug 696864: Use Default colorspaces when processing SMask<br>
-<br>
- This is done by saving the OverrideICC user parameter before setting the<br>
- colorspace, etc. so as to ignore the ICC profile, which may have a gamma<br>
- that we don't expect, and restore it after the SMask has been rendered.<br>
- Note this file rendered correctly with -dOverrideICC on the command line,<br>
- but this patch automatically applies that during execmaskgroup.<br>
-<br>
- Thanks to Michael Vrhel for identifying the problem and coming up with a<br>
- simplified test case.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-08 17:27: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=a87e380acd5e326f7d4e4380348bac393fac3058">a87e380acd5e326f7d4e4380348bac393fac3058</a>
-<blockquote>
-<p>
- Remove the appledmp, iwlo, iwhi, iwlq devices<br>
-<br>
-base/unix-gcc.mak<br>
-configure.ac<br>
-devices/contrib.mak<br>
-devices/gdevadmp.c<br>
-doc/Develop.htm<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-07 15:52:42 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad13de0b7a11675f34a29a03d1597a780da54851">ad13de0b7a11675f34a29a03d1597a780da54851</a>
-<blockquote>
-<p>
- Update docs to reflect removal mswindll device<br>
-<br>
-doc/DLL.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-07 15:38:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e0f5118c432d4f17d8038871691517d84ce01918">e0f5118c432d4f17d8038871691517d84ce01918</a>
-<blockquote>
-<p>
- Remove the os2prn device<br>
-<br>
-base/pcwin.mak<br>
-devices/devs.mak<br>
-devices/gdevos2p.c<br>
-doc/Develop.htm<br>
-psi/os2.mak<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-07 15:31:06 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5be37082980552a9d8a21b70a7ee93fbf4320e8f">5be37082980552a9d8a21b70a7ee93fbf4320e8f</a>
-<blockquote>
-<p>
- Remove the mswindll and mswin devices<br>
-<br>
- As well as the (long non-functional/non-useful) Windows &quot;xfont&quot; code.<br>
-<br>
-base/pcwin.mak<br>
-devices/devs.mak<br>
-devices/gdevmswn.c<br>
-devices/gdevmswn.h<br>
-devices/gdevmsxf.c<br>
-devices/gdevwddb.c<br>
-devices/gdevwdib.c<br>
-devices/gdevwprn.c<br>
-doc/DLL.htm<br>
-doc/Develop.htm<br>
-psi/gsdll32.def<br>
-psi/gsdll32metro.def<br>
-psi/gsdll32w.lnk<br>
-psi/gsdll64.def<br>
-psi/gsdll64metro.def<br>
-psi/gsdllARM32metro.def<br>
-psi/msvc.mak<br>
-toolbin/pre.chk<br>
-toolbin/tests/check_comments.py<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-07 15:07: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=ff59e2a9f86a4476aa67b5e768811fe43b0b4f0c">ff59e2a9f86a4476aa67b5e768811fe43b0b4f0c</a>
-<blockquote>
-<p>
- Remove the macos device<br>
-<br>
-devices/gdevmac.c<br>
-devices/gdevmac.h<br>
-devices/gdevmacpictop.h<br>
-devices/gdevmacttf.h<br>
-doc/Develop.htm<br>
-toolbin/tests/check_comments.py<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-07 15:01:26 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c0d6e66d219006acfa3201963a0a7123dce3cc9">6c0d6e66d219006acfa3201963a0a7123dce3cc9</a>
-<blockquote>
-<p>
- Remove sgirgb device<br>
-<br>
-base/unix-gcc.mak<br>
-configure.ac<br>
-devices/contrib.mak<br>
-devices/gdevsgi.c<br>
-devices/gdevsgi.h<br>
-doc/Develop.htm<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-06 15:05:23 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa981020ef9f96cb2d4d92bd48da81b025bc267a">fa981020ef9f96cb2d4d92bd48da81b025bc267a</a>
-<blockquote>
-<p>
- Remove the various &quot;vga&quot; devices<br>
-<br>
-devices/devs.mak<br>
-devices/gdevevga.c<br>
-devices/gdevpcfb.c<br>
-devices/gdevpcfb.h<br>
-devices/gdevs3ga.c<br>
-devices/gdevsco.c<br>
-devices/gdevsvga.h<br>
-doc/Develop.htm<br>
-toolbin/pre.chk<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-06 14:52: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=3488db574bf6d7291f51180395da9aa7fd6816cc">3488db574bf6d7291f51180395da9aa7fd6816cc</a>
-<blockquote>
-<p>
- Remove svga device(s)<br>
-<br>
-devices/devs.mak<br>
-devices/gdevsvga.c<br>
-doc/Develop.htm<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-06 14:40:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=323a1cb0e1fbd96bed87f818874f51543b286949">323a1cb0e1fbd96bed87f818874f51543b286949</a>
-<blockquote>
-<p>
- Remove the sunview device<br>
-<br>
-devices/contrib.mak<br>
-devices/gdevsun.c<br>
-doc/Develop.htm<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-06 14:37: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=74aa1c0b1f71f59f866c800bd698712cdb5c9405">74aa1c0b1f71f59f866c800bd698712cdb5c9405</a>
-<blockquote>
-<p>
- Remove the sunhmono device<br>
-<br>
-base/unix-gcc.mak<br>
-configure.ac<br>
-devices/contrib.mak<br>
-devices/gdevsunr.c<br>
-doc/Develop.htm<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-06 14:32: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=4010f1e52592197537e1af639fe3228b8b5fc727">4010f1e52592197537e1af639fe3228b8b5fc727</a>
-<blockquote>
-<p>
- Remove sparc (printer) device<br>
-<br>
-devices/contrib.mak<br>
-doc/Develop.htm<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-06 14:28: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=5c6b4d035b6c8c3466e77bc4a581732659d3687e">5c6b4d035b6c8c3466e77bc4a581732659d3687e</a>
-<blockquote>
-<p>
- Remove the att3b1 device<br>
-<br>
-configure.ac<br>
-devices/contrib.mak<br>
-devices/gdev3b1.c<br>
-doc/Develop.htm<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-06 14:25: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=6e98f2159d615b4bedd6e5d83c95a511d4f9ea6f">6e98f2159d615b4bedd6e5d83c95a511d4f9ea6f</a>
-<blockquote>
-<p>
- Remove the herc device<br>
-<br>
-devices/contrib.mak<br>
-devices/gdevherc.c<br>
-doc/Develop.htm<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-06 14:16: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=8901d9044df836f9ee8988f1ce9f6bbebbc6c314">8901d9044df836f9ee8988f1ce9f6bbebbc6c314</a>
-<blockquote>
-<p>
- Remove lvga256 device<br>
-<br>
-devices/devs.mak<br>
-devices/gdevl256.c<br>
-doc/Develop.htm<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-06 14:09: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=a6b63be35e0278b4018863cf9b197e90686cc374">a6b63be35e0278b4018863cf9b197e90686cc374</a>
-<blockquote>
-<p>
- Remove the s3ga device<br>
-<br>
-devices/devs.mak<br>
-doc/Develop.htm<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-06 14:04:23 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=461b6c19ab09b19ac436b6ccba234f36ad70c197">461b6c19ab09b19ac436b6ccba234f36ad70c197</a>
-<blockquote>
-<p>
- Remove vgalib device<br>
-<br>
-devices/devs.mak<br>
-devices/gdevvglb.c<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-06 13:47:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f659ff57a2e3fa011255569dcdf54cc825aaa9af">f659ff57a2e3fa011255569dcdf54cc825aaa9af</a>
-<blockquote>
-<p>
- Remove omni device<br>
-<br>
-Makefile.in<br>
-configure.ac<br>
-contrib/contrib.mak<br>
-contrib/defs.h<br>
-contrib/gomni.c<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-06 13:43: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=ec346cc09daada7c16e7213be154e86f644c6d04">ec346cc09daada7c16e7213be154e86f644c6d04</a>
-<blockquote>
-<p>
- Remove mag16 and mag256 devices<br>
-<br>
-configure.ac<br>
-contrib/contrib.mak<br>
-contrib/japanese/gdevmag.c<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-06 13:05: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=c0448269dd1928b2aff0307ed1206118f329af14">c0448269dd1928b2aff0307ed1206118f329af14</a>
-<blockquote>
-<p>
- Remove the moribund Mac Classic specific files.<br>
-<br>
-base/gp_mac.c<br>
-base/gp_mac.h<br>
-base/gp_macio.c<br>
-base/gp_macpoll.c<br>
-base/macos-mcp.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-10 09:45: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=ed539f1b8d29b2f03cd22ac2d54ee9036000d565">ed539f1b8d29b2f03cd22ac2d54ee9036000d565</a>
-<blockquote>
-<p>
- Remove doc sections about making SAFER the default<br>
-<br>
-man/gs.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-10 09:40: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=7119a01ae110a4c81b002f86464e684259626b30">7119a01ae110a4c81b002f86464e684259626b30</a>
-<blockquote>
-<p>
- Remove from the documentation the stated intention to make -dSAFER the<br>
- default.<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-10 08:45: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=9572484beac8fda920cbca3f6c6d09a5dc424825">9572484beac8fda920cbca3f6c6d09a5dc424825</a>
-<blockquote>
-<p>
- Fix pdfmark argument validation<br>
-<br>
- This doesn't fit neatly into any category, its a PostScript 'operator'<br>
- but it is only implemented for the pdfwrite device...<br>
-<br>
- The pdfmark operator takes a mark, a series of arguments and a name<br>
- object. Zero argument sis valid, but the absence of a name object is<br>
- not. We weren't checking for the absence of a name object, or<br>
- validating its type.<br>
-<br>
- No differences expected.<br>
-<br>
-Resource/Init/gs_pdfwr.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-10 08:09:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ec6ba697311d2424189583f8fc26d373a584a4ce">ec6ba697311d2424189583f8fc26d373a584a4ce</a>
-<blockquote>
-<p>
- Coverity ID 137703 - remove some dead code<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-08 16:35: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=b60d50b7567369ad856cebe1efb6cd7dd2284219">b60d50b7567369ad856cebe1efb6cd7dd2284219</a>
-<blockquote>
-<p>
- Bug 697193: status operator honour SAFER option<br>
-<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-08 16:18: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=4ea759bbd40746410fb2beb82e3ba9ebb6788107">4ea759bbd40746410fb2beb82e3ba9ebb6788107</a>
-<blockquote>
-<p>
- Bug 697204: fully init lock object<br>
-<br>
- The scheduler field (which is relocatable) was not being initialisedm causing a<br>
- segfault in teh garbage collector<br>
-<br>
-psi/zcontext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-08 16:10: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=f5c7555c30393e64ec1f5ab0dfae5b55b3b3fc78">f5c7555c30393e64ec1f5ab0dfae5b55b3b3fc78</a>
-<blockquote>
-<p>
- Bug 697203: check for sufficient params in .sethalftone5<br>
-<br>
- and param types<br>
-<br>
-psi/zht2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-08 16:01:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a5360401495654e89301b2516703c1d2877fc5ba">a5360401495654e89301b2516703c1d2877fc5ba</a>
-<blockquote>
-<p>
- Check for NULL return from memory allocation<br>
-<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-05 09:36:33 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f3de2191afc0d8fcf0285736d2d25fa6071a7981">f3de2191afc0d8fcf0285736d2d25fa6071a7981</a>
-<blockquote>
-<p>
- Bug 696860 remove memcmp of structs in gscrdp.c<br>
-<br>
-base/gscie.c<br>
-base/gscie.h<br>
-base/gscrdp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-05 09:59: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=6f749c0c44e7b9e09737b9f29edf29925a34f0cf">6f749c0c44e7b9e09737b9f29edf29925a34f0cf</a>
-<blockquote>
-<p>
- Bug 697179: Reference count device icc profile<br>
-<br>
- when copying a device<br>
-<br>
-base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-05 09:55: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=6d444c273da5499a4cd72f21cb6d4c9a5256807d">6d444c273da5499a4cd72f21cb6d4c9a5256807d</a>
-<blockquote>
-<p>
- Bug 697178: Add a file permissions callback<br>
-<br>
- For the rare occasions when the graphics library directly opens a file<br>
- (currently for reading), this allows us to apply any restrictions on<br>
- file access normally applied in the interpteter.<br>
-<br>
-base/gsicc_manage.c<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-psi/imain.c<br>
-psi/int.mak<br>
-psi/zfile.c<br>
-psi/zfile.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-03 01:46: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=8abd22010eb4db0fb1b10e430d5f5d83e015ef70">8abd22010eb4db0fb1b10e430d5f5d83e015ef70</a>
-<blockquote>
-<p>
- Bug 697169: Be rigorous with SAFER permissions<br>
-<br>
- Once we've opened our input file from the command line, enforce the SAFER<br>
- rules.<br>
-<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-19 08:43:35 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d609a3d4c1b8583d1c22db6b4d3bce4b239cf88c">d609a3d4c1b8583d1c22db6b4d3bce4b239cf88c</a>
-<blockquote>
-<p>
- Use ToUnicode for substituted CIDFonts<br>
-<br>
- When we substitute a CIDFont in a PDF file with a TTF from disk, use the<br>
- ToUnicode CMap (if available) to extract Unicode values. In a lot of case, this<br>
- gets a more accurate character code to glyph mapping than the previous reliance<br>
- on the low level glyph ordering from the TTF.<br>
-<br>
- This also meant being more robust for broken ToUnicode CMap. Also, an additional<br>
- option (-dIgnoreToUnicode) to skip parsing of the ToUnicode CMap - for cases<br>
- where a correctly formed ToUnicode is semantically wrong.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-base/gstext.c<br>
-base/gxfapi.c<br>
-base/gxfapi.h<br>
-pcl/pl/plfapi.c<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-05 08:32: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=3089131dc90ec008ff540d41df0f1a9fbc2dd47b">3089131dc90ec008ff540d41df0f1a9fbc2dd47b</a>
-<blockquote>
-<p>
- Bug 696859 memcmp of struct removal in gscrd.c<br>
-<br>
-base/gscrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-05 13:15: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=799531ffc1240933786cd2121add9d7e3cba778e">799531ffc1240933786cd2121add9d7e3cba778e</a>
-<blockquote>
-<p>
- Coverity ID 137283 - pdfwrite - remove some redundant code<br>
-<br>
- I had left some code that catered for a UTF16 surrogate pair promoted to<br>
- UTF32, converting the result to UTF8. But I didn't implement the UTF32<br>
- promotion, leaving it as a potential future enhancement.<br>
-<br>
- However, Coverity whinges about the test always being true, so here<br>
- just remove the code. Its trivial enough to add in if we ever need it.<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-05 10:10:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=875a0095f37626a721c7ff57d606a0f95af03913">875a0095f37626a721c7ff57d606a0f95af03913</a>
-<blockquote>
-<p>
- DSC parser - validate parameters<br>
-<br>
- Bug #697190 &quot;.initialize_dsc_parser doesn't validate the parameter is a dict type before using it.&quot;<br>
-<br>
- Regardless of any security implications, its simply wrong for a PostScript<br>
- operator not to validate its parameter(s).<br>
-<br>
- No differences expected.<br>
-<br>
-psi/zdscpars.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-05 09:41:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aef8f6cfbff9080e4b9c54053bc909875c09a2be">aef8f6cfbff9080e4b9c54053bc909875c09a2be</a>
-<blockquote>
-<p>
- Prevent dereference of NULL device method<br>
-<br>
- Bug #697189 &quot;.gethardwareparams crashes with any special device&quot;<br>
-<br>
- Another NULL device method problem. As noted previously, the original<br>
- design intended that device methods should never be NULL, but this<br>
- has been ignored over the years leading to the current mess of some<br>
- methods being NULL accidentally, some being NULL deliberately and<br>
- having different effects when NULL, and some methods never being NULL.<br>
-<br>
- While I do still intend to try and rectify this one day, in the meantime<br>
- add a check to make sure the method is not NULL before trying to<br>
- execute it in this case.<br>
-<br>
- No differences expected<br>
-<br>
-base/gsdparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-04 16:24:13 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36a2c94c4ebea8aa1c9cb2ca98e124a5b363000e">36a2c94c4ebea8aa1c9cb2ca98e124a5b363000e</a>
-<blockquote>
-<p>
- Fix misplace parenthesis and missing const<br>
-<br>
-base/gdevdevn.c<br>
-base/gscie.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-04 15:54:56 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e4ab4499f9f33c51cdb95020c99cf0f4f1e6ee77">e4ab4499f9f33c51cdb95020c99cf0f4f1e6ee77</a>
-<blockquote>
-<p>
- Bug 696858 remove memcmp struct in gscie.c<br>
-<br>
-base/gscie.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-04 14:39:54 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e9a339b766fb7a4d791c5ba1d85bdd24e6dbbaa">2e9a339b766fb7a4d791c5ba1d85bdd24e6dbbaa</a>
-<blockquote>
-<p>
- Bug 696854 remove memcmp of structs in gdevdevn.c<br>
-<br>
-base/gdevdevn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-04 12:04:03 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4fd414107c5b36419896a9c46956cb254adf201f">4fd414107c5b36419896a9c46956cb254adf201f</a>
-<blockquote>
-<p>
- Bug 696862 remove memcmp() color info structure<br>
-<br>
-base/gsdevice.c<br>
-base/gxclpage.c<br>
-base/gxdevcli.h<br>
-base/gximage2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-10-03 16:21:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a8642064fe21752b00e28d05483baca029fe0891">a8642064fe21752b00e28d05483baca029fe0891</a>
-<blockquote>
-<p>
- pdfwrite - fix ToUnicode CMap sequence consolidation<br>
-<br>
- Bug #697176 &quot;ToUnicode CMap generation broken in 9.20&quot;<br>
-<br>
- The reworking to handle the current version of ToUnicode CMap missed<br>
- a case where the size of a code pair had changed. This led to a loop<br>
- comparing incorrect values, instead of comparing two consecutive<br>
- values, it compared a value with one much earlier.<br>
-<br>
- In general this led to a loss of efficient, causing us to emit two or<br>
- more entries when it was possible to emit a single range. However in the<br>
- rare case when the comparison happened to compare two values that were<br>
- consecutive, but shouldn't have been, this led to us writing an incorrect<br>
- ToUnicode CMap.<br>
-<br>
- No differences expected.<br>
-<br>
-base/gsfcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-29 21:57: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=309edf631cf1160087ede69384f502aa1d64006c">309edf631cf1160087ede69384f502aa1d64006c</a>
-<blockquote>
-<p>
- pdfwrite - Fix handling of Separation /All alternate space conversion<br>
-<br>
- Bug #697118 &quot;Separation colorspace is not converted correctly by pdfwrite&quot;<br>
-<br>
- The /All Separation space wasn't getting the components of the tint<br>
- transform colour space correctly set. For rendering we never need to<br>
- do that, and simply set the relevant component of the Separation<br>
- (or DeviceN) space to be the tint value.<br>
-<br>
- This commit forces the CMS to run the tint transform when we need to<br>
- create a new, different, alternate for the Separation space.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-29 19:22:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=727aeab76c39026722e3e492a30ae2f7c218c1ec">727aeab76c39026722e3e492a30ae2f7c218c1ec</a>
-<blockquote>
-<p>
- Fix UTF16 surrogate pair detection<br>
-<br>
- Flagged by clang, the use of a short would fail to detect surrogate<br>
- pairs, this shuold be an unsigned short.<br>
-<br>
- Bizarrely this worked as expected on Windows, I have no idea how.<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-29 17:35: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=273a133110838ee5702e7eb6409a853c598211b2">273a133110838ee5702e7eb6409a853c598211b2</a>
-<blockquote>
-<p>
- Remove (and re-implement) ConvertUTF.c<br>
-<br>
- Bug #697122 &quot; embedded ConvertUTF.c is buggy and licensed incompatibly with GPL/APGL&quot;<br>
-<br>
- Its not clear that this code is incompatible with GPL, nor do we think<br>
- any 'bugginess' in the code affects us, since we are using a comparatively<br>
- small part of the included code.<br>
-<br>
- Nevertheless its possible to remove the code, and re-implement the small<br>
- part we actually need, and that is done here.<br>
-<br>
- Also removed the DSCEncodingToUnicode option which was insanely difficult<br>
- to use, and incorrectly documented.<br>
-<br>
- Yhis shows one difference, 692486_-_heap_overflow_in_pdf_to_ucs2.pdf<br>
- now correctly throws an error, because the PDF file contains document<br>
- information (Application) which has an invalid UTF16-BE sequence.<br>
-<br>
-base/ConvertUTF.c<br>
-base/ConvertUTF.h<br>
-base/lib.mak<br>
-devices/devs.mak<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfe.c<br>
-devices/vector/gdevpdfp.c<br>
-devices/vector/gdevpdfx.h<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-27 17:07:02 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=27e01aa77d0cf1668f60d87cf7417c90bf309d1b">27e01aa77d0cf1668f60d87cf7417c90bf309d1b</a>
-<blockquote>
-<p>
- Squash 2 warnings in the openjpeg code.<br>
-<br>
-openjpeg/src/lib/openjp2/j2k.c<br>
-openjpeg/src/lib/openjp2/thread.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-27 16:08:57 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a78bfb8698061e22e3d460b8c15825992e44def">9a78bfb8698061e22e3d460b8c15825992e44def</a>
-<blockquote>
-<p>
- Import new OpenJPEG version.<br>
-<br>
- Squashed version of openjpeg-update-20160927<br>
-<br>
- This squashes the following commits:<br>
-<br>
- * Import new OpenJPEG version.<br>
-<br>
- From https://github.com/uclouvain/openjpeg<br>
-<br>
- Final commit is:<br>
-<br>
- commit 34dae137a9a8c04feaa9763ae7e09a86ecb10400<br>
- Author: Mathieu Malaterre &lt;mathieu.malaterre@gmail.com&gt;<br>
- Date: Mon Sep 26 12:01:31 2016 +0200<br>
-<br>
- OPENJPEG_NAMESPACE is configurable by user<br>
-<br>
- * Zap the OpenJPEG stuff we don't need<br>
-<br>
- * Add predefined openjpeg headers.<br>
-<br>
- * Import patches from Sumatra's tree.<br>
-<br>
- * Update Makefiles for new openjpeg<br>
-<br>
- * Update MSVC for new files<br>
-<br>
- * OpenJPEG allocation fixes.<br>
-<br>
- The old version of openjpeg allocates using malloc/free.<br>
-<br>
- The new version of openjpeg allocates via opj_malloc (and co).<br>
-<br>
- We can capture these and pass them down to our own allocators,<br>
- but we cannot get openjpeg to pass us a gs_memory_t * to use.<br>
-<br>
- We therefore resort to using a static to hold 'the current<br>
- gs_memory_t *' before we call openjpeg. To keep this threadsafe<br>
- we add some private data to the gslibctx, which the openjpeg<br>
- implementation can use to hold a lock.<br>
-<br>
- We add calls to both jpx decode implementations to init this<br>
- private data (where the luratech implementation is null).<br>
-<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-base/openjpeg.mak<br>
-base/sjpx_luratech.c<br>
-base/sjpx_openjpeg.c<br>
-openjpeg/AUTHORS<br>
-openjpeg/AUTHORS.md<br>
-openjpeg/CHANGELOG.md<br>
-openjpeg/CHANGES<br>
-openjpeg/NEWS<br>
-openjpeg/NEWS.md<br>
-openjpeg/THANKS<br>
-openjpeg/THANKS.md<br>
-openjpeg/src/lib/openjp2/CMakeLists.txt<br>
-openjpeg/src/lib/openjp2/bio.c<br>
-openjpeg/src/lib/openjp2/cidx_manager.c<br>
-openjpeg/src/lib/openjp2/cio.c<br>
-openjpeg/src/lib/openjp2/cio.h<br>
-openjpeg/src/lib/openjp2/dwt.c<br>
-openjpeg/src/lib/openjp2/dwt.h<br>
-openjpeg/src/lib/openjp2/event.h<br>
-openjpeg/src/lib/openjp2/function_list.c<br>
-openjpeg/src/lib/openjp2/function_list.h<br>
-openjpeg/src/lib/openjp2/image.c<br>
-openjpeg/src/lib/openjp2/indexbox_manager.h<br>
-openjpeg/src/lib/openjp2/invert.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/libopenjp2.pc.cmake.in<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_clock.c<br>
-openjpeg/src/lib/openjp2/opj_codec.h<br>
-openjpeg/src/lib/openjp2/opj_config.h.cmake.in<br>
-openjpeg/src/lib/openjp2/opj_config_private.h.cmake.in<br>
-openjpeg/src/lib/openjp2/opj_includes.h<br>
-openjpeg/src/lib/openjp2/opj_intmath.h<br>
-openjpeg/src/lib/openjp2/opj_malloc.c<br>
-openjpeg/src/lib/openjp2/opj_malloc.h<br>
-openjpeg/src/lib/openjp2/phix_manager.c<br>
-openjpeg/src/lib/openjp2/pi.c<br>
-openjpeg/src/lib/openjp2/pi.h<br>
-openjpeg/src/lib/openjp2/ppix_manager.c<br>
-openjpeg/src/lib/openjp2/raw.c<br>
-openjpeg/src/lib/openjp2/t1.c<br>
-openjpeg/src/lib/openjp2/t1.h<br>
-openjpeg/src/lib/openjp2/t1_generate_luts.c<br>
-openjpeg/src/lib/openjp2/t1_luts.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/tgt.c<br>
-openjpeg/src/lib/openjp2/tgt.h<br>
-openjpeg/src/lib/openjp2/thix_manager.c<br>
-openjpeg/src/lib/openjp2/thread.c<br>
-openjpeg/src/lib/openjp2/thread.h<br>
-openjpeg/src/lib/openjp2/tls_keys.h<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-27 11:22: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=b4cc6d28e9a456a34a7348d98ff78ada9da727bb">b4cc6d28e9a456a34a7348d98ff78ada9da727bb</a>
-<blockquote>
-<p>
- Add pre-processor define for shared OpenJPEG<br>
-<br>
-Makefile.in<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-23 17:17:19 -0300
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9e00367c3f598dc5e7b80d492e2b2d7321015fb3">9e00367c3f598dc5e7b80d492e2b2d7321015fb3</a>
-<blockquote>
-<p>
- pxlcolor/pxlmono output devices: Make MediaPosition, ManualFeed, and MediaType work<br>
-<br>
- In the pxlcolor and pxlmono output devices (for PCL-XL printers) the<br>
- support for the attributes MediaPosition, ManualFeed, and MediaType<br>
- got broken when ESP Ghostscript got merged into GPL Ghostscript (Bug<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-22 09:21: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=c1a79c6ab5ffadde8e296cd3e0b9e52a87c4ef66">c1a79c6ab5ffadde8e296cd3e0b9e52a87c4ef66</a>
-<blockquote>
-<p>
- Bug 697087: Apply PDF TTF rules when loading from disk<br>
-<br>
- When we substitute a TTF from disk for a (non-embedded) TTF in a PDF, apply the<br>
- same rules (if possible) as when reading a TTF embedded in a PDF. So, selection<br>
- of cmap table, font encoding, whether or not to draw the notdef etc.<br>
-<br>
- This applies *only* to fonts, *not* to CIDFonts.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-22 15:24:45 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=abffa3e76c3e33b683333be329b39efaf762eca7">abffa3e76c3e33b683333be329b39efaf762eca7</a>
-<blockquote>
-<p>
- Remove Android logging code.<br>
-<br>
- Bow to protestations from my colleagues and move code into<br>
- the caller. Probably nicer. If anyone ever needs the code they<br>
- can grab it from git.<br>
-<br>
- Revert &quot;Tweak android logging code logic.&quot;<br>
- This reverts commit 4d08bfd98b5fcd7cd4c2bd5faf72ac9615354ee3.<br>
-<br>
- Revert &quot;Add android logging code.&quot;<br>
- This reverts commit 2c52876b77d348866941fb85f6d0349a51df0455.<br>
-<br>
-psi/iapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-21 16:22:48 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d08bfd98b5fcd7cd4c2bd5faf72ac9615354ee3">4d08bfd98b5fcd7cd4c2bd5faf72ac9615354ee3</a>
-<blockquote>
-<p>
- Tweak android logging code logic.<br>
-<br>
- It seems we don't set NDEBUG in release builds for android.<br>
- Revert to #ifdef DEBUG rather than #ifndef NDEBUG as a guard.<br>
-<br>
-psi/iapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-21 12:01:47 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c52876b77d348866941fb85f6d0349a51df0455">2c52876b77d348866941fb85f6d0349a51df0455</a>
-<blockquote>
-<p>
- Add android logging code.<br>
-<br>
- Update stdio redirection so that stdout and stderr go to<br>
- Android.log in DEBUG builds.<br>
-<br>
-psi/iapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 18:07: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=1bd7f32d70549971b4a384c5865e1fd030f49f20">1bd7f32d70549971b4a384c5865e1fd030f49f20</a>
-<blockquote>
-<p>
- Bug 697138: Fix --disable-sse2 to work with openjpeg<br>
-<br>
- OpenJPEG enables it's SSE code based on the compiler defining __SSE__ so we<br>
- want to undefine that if we're not using SSE operations.<br>
-<br>
-Makefile.in<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 19:57:14 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20b0255206254ebcce1cde0a4a63d74b0aedcecf">20b0255206254ebcce1cde0a4a63d74b0aedcecf</a>
-<blockquote>
-<p>
- Fix splay tree traversal (again)<br>
-<br>
- When setting up a traversal from a midpoint of the tree, we'd<br>
- immediately trip into the &quot;has hit the endpoint&quot; code.<br>
-<br>
- Fix that.<br>
-<br>
-base/gsalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 09:03:31 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e1153bf2d344044cd9fdfb7706f829b63348118">0e1153bf2d344044cd9fdfb7706f829b63348118</a>
-<blockquote>
-<p>
- FitPage should not add in rotation if destination page is square.<br>
-<br>
- If the PageSize was square, it would be treated as &quot;not landscape&quot;,<br>
- but landscape pages in would be arbitrarily rotated.<br>
-<br>
- Note this does not change the bahavior of PS or EPS page fitting.<br>
- TBD: Add an option to fit to a page and never rotate (FitPageNR)<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 16:48:45 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=570041cc341557da8521fdace380f837cc572a69">570041cc341557da8521fdace380f837cc572a69</a>
-<blockquote>
-<p>
- Fix Memento crash<br>
-<br>
- When reallocing set the rawsize before attempting to write<br>
- the post guard block.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 13:41: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=3dd5f4c6b02179422bd8686fceed1f4955221d90">3dd5f4c6b02179422bd8686fceed1f4955221d90</a>
-<blockquote>
-<p>
- Sync Memento with MuPDF.<br>
-<br>
-base/memento.c<br>
-base/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 13:04:51 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e01c57e0f0773e29bc6f921cfc677576e72739d">4e01c57e0f0773e29bc6f921cfc677576e72739d</a>
-<blockquote>
-<p>
- Bug 697134: Tweak MEMENTO_GS_HACKS inclusion.<br>
-<br>
- Rather than rolling our own memset prototype in this case, use<br>
- the one that gs provides.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-16 15:23: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=1a0104084a4dfdff77165d931bdc87849c8ad824">1a0104084a4dfdff77165d931bdc87849c8ad824</a>
-<blockquote>
-<p>
- Clump has_refs - follow up to commit 63f74ce6<br>
-<br>
- The function save_set_new() (where the original fix for 'has_refs' is located)<br>
- is called in two circumstances: when creating a save level, and when destroying<br>
- a save level.<br>
-<br>
- We have to retain the 'has_refs' value for the latter case for the garbager to<br>
- function correctly, but doing so in the former results in the garbager<br>
- sometimes scanning more memory than is really necessary (it can end up scanning<br>
- ref memory from the previous save state, which is pointless since that cannot<br>
- change).<br>
-<br>
- This change means that 'has_refs == true' will only be retained in the<br>
- 'destroying a save level' case (which works correctly because, by the time the<br>
- function is called, we've already returned the relevant allocated to its<br>
- previous state).<br>
-<br>
-psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-15 14:14:35 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bfffe2011e1c8ffe53a432424b049f3989d6174a">bfffe2011e1c8ffe53a432424b049f3989d6174a</a>
-<blockquote>
-<p>
- Fix bug 697097. SMask subpixel offset must match image offset.<br>
-<br>
- The dda used to select the source pixel for mapping into the image<br>
- must use the same stepping for gray (monochrome) and color images<br>
- since an SMask is monochrome and the image may be in color. This is<br>
- primarily evident with the bug file since Matte is used to indicate<br>
- that the source data is premuliplied. Colors can shift a LOT since<br>
- the removal of the premultiplication can expand mistaked.<br>
-<br>
-base/gxicolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-14 16:31:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5521e702af192e06f186d0d741f24097eb5b8e26">5521e702af192e06f186d0d741f24097eb5b8e26</a>
-<blockquote>
-<p>
- PDF interpreter - fix for GSView 5<br>
-<br>
- Commit 093bd18bd923644fcd25c507088c0ebc63b4c320 included an<br>
- 'optimisation' to prevent rescanning for transparency if we had already<br>
- scanned. However, this assumed that the function pdfshowpage_setup<br>
- had already been executed in order to set a variable.<br>
-<br>
- This is always true when running files via Ghostscript, but any<br>
- application (such as GSView 5) which executes the PDF operations<br>
- individually need not execute this function. If the function was not<br>
- executed then an error occurred. From other comments in pdf_main.ps<br>
- its possible that customers may be using these functions as well (see<br>
- the comments above the definition of /pdfshowpage)<br>
-<br>
- This commit checks to see if the variable has been set, if it has then<br>
- it is used, otherwise we rescan for transparency. This prevents the<br>
- error, but uses the optimisation if its possible to do so.<br>
-<br>
- No differences expected<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-14 10:28: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=04117ec705cfc89ce4bb4b451ba95af61b937fe0">04117ec705cfc89ce4bb4b451ba95af61b937fe0</a>
-<blockquote>
-<p>
- Bump version number to 9.21<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-26 11:36: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=5deee306126e09f95e40e69fe04a7d26c842fb56">5deee306126e09f95e40e69fe04a7d26c842fb56</a>
-<blockquote>
-<p>
- Update date and product string for 9.20 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/Xfonts.htm<br>
-doc/gs-vms.hlp<br>
-doc/sample_downscale_device.htm<br>
-doc/thirdparty.htm<br>
-man/dvipdf.1<br>
-man/font2c.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>
-man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 20:33:21 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3263f33ba60aafe7b671d2c9b7a3b25fb39a7bee">3263f33ba60aafe7b671d2c9b7a3b25fb39a7bee</a>
-<blockquote>
-<p>
- Changelog update for 9.20 RC2<br>
-<br>
-doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-14 17:35: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=457cc95668fbf26cf9cf5e4ee10709ad8c8e2c58">457cc95668fbf26cf9cf5e4ee10709ad8c8e2c58</a>
-<blockquote>
-<p>
- Fix a type in the release comments<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-14 12:14: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=eedf4c16032d2a8ec356705f28cee3fdbec248d2">eedf4c16032d2a8ec356705f28cee3fdbec248d2</a>
-<blockquote>
-<p>
- Update News and changelog<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-14 10:40:36 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7658715de338f9cd3a62d44f7c503f81d03a3fae">7658715de338f9cd3a62d44f7c503f81d03a3fae</a>
-<blockquote>
-<p>
- Copyrights, dates etc<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/Xfonts.htm<br>
-doc/gs-vms.hlp<br>
-doc/sample_downscale_device.htm<br>
-doc/thirdparty.htm<br>
-man/dvipdf.1<br>
-man/font2c.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>
-man/wftopfa.1<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-14 10:34: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=8749511b204f255740a1555520a9b1d7adcceacf">8749511b204f255740a1555520a9b1d7adcceacf</a>
-<blockquote>
-<p>
- Change product family for RC<br>
-<br>
- Plus dates<br>
-<br>
-base/gscdef.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 18:07: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=65898de27797a835d2029676d4380b3c7806dc9e">65898de27797a835d2029676d4380b3c7806dc9e</a>
-<blockquote>
-<p>
- Bug 697138: Fix --disable-sse2 to work with openjpeg<br>
-<br>
- OpenJPEG enables it's SSE code based on the compiler defining __SSE__ so we<br>
- want to undefine that if we're not using SSE operations.<br>
-<br>
-Makefile.in<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 19:57:14 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ed866d7ab135edebd9c53f52026426d403f53a49">ed866d7ab135edebd9c53f52026426d403f53a49</a>
-<blockquote>
-<p>
- Fix splay tree traversal (again)<br>
-<br>
- When setting up a traversal from a midpoint of the tree, we'd<br>
- immediately trip into the &quot;has hit the endpoint&quot; code.<br>
-<br>
- Fix that.<br>
-<br>
-base/gsalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 09:03:31 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba8a97dc6f67e044d567e38c68cfd5b785835615">ba8a97dc6f67e044d567e38c68cfd5b785835615</a>
-<blockquote>
-<p>
- FitPage should not add in rotation if destination page is square.<br>
-<br>
- If the PageSize was square, it would be treated as &quot;not landscape&quot;,<br>
- but landscape pages in would be arbitrarily rotated.<br>
-<br>
- Note this does not change the bahavior of PS or EPS page fitting.<br>
- TBD: Add an option to fit to a page and never rotate (FitPageNR)<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 16:48:45 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=029f4ec2d6b8165b0cfff02173cde68edaebc108">029f4ec2d6b8165b0cfff02173cde68edaebc108</a>
-<blockquote>
-<p>
- Fix Memento crash<br>
-<br>
- When reallocing set the rawsize before attempting to write<br>
- the post guard block.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 13:41: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=5547040a0de52d588401ea9f1dfd20bc8168f455">5547040a0de52d588401ea9f1dfd20bc8168f455</a>
-<blockquote>
-<p>
- Sync Memento with MuPDF.<br>
-<br>
-base/memento.c<br>
-base/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 13:04:51 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f763382b616c35e9a021bde4e5347c1d67df5a0a">f763382b616c35e9a021bde4e5347c1d67df5a0a</a>
-<blockquote>
-<p>
- Bug 697134: Tweak MEMENTO_GS_HACKS inclusion.<br>
-<br>
- Rather than rolling our own memset prototype in this case, use<br>
- the one that gs provides.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-16 15:23: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=c3c48bbdda6915abfe39b4a0de9978555fc071ba">c3c48bbdda6915abfe39b4a0de9978555fc071ba</a>
-<blockquote>
-<p>
- Clump has_refs - follow up to commit 63f74ce6<br>
-<br>
- The function save_set_new() (where the original fix for 'has_refs' is located)<br>
- is called in two circumstances: when creating a save level, and when destroying<br>
- a save level.<br>
-<br>
- We have to retain the 'has_refs' value for the latter case for the garbager to<br>
- function correctly, but doing so in the former results in the garbager<br>
- sometimes scanning more memory than is really necessary (it can end up scanning<br>
- ref memory from the previous save state, which is pointless since that cannot<br>
- change).<br>
-<br>
- This change means that 'has_refs == true' will only be retained in the<br>
- 'destroying a save level' case (which works correctly because, by the time the<br>
- function is called, we've already returned the relevant allocated to its<br>
- previous state).<br>
-<br>
-psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-15 14:14:35 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=974843fc7c06bc7354bd5f74f87a22014b0a1e16">974843fc7c06bc7354bd5f74f87a22014b0a1e16</a>
-<blockquote>
-<p>
- Fix bug 697097. SMask subpixel offset must match image offset.<br>
-<br>
- The dda used to select the source pixel for mapping into the image<br>
- must use the same stepping for gray (monochrome) and color images<br>
- since an SMask is monochrome and the image may be in color. This is<br>
- primarily evident with the bug file since Matte is used to indicate<br>
- that the source data is premuliplied. Colors can shift a LOT since<br>
- the removal of the premultiplication can expand mistaked.<br>
-<br>
-base/gxicolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-14 16:31:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8079f5a688d54ba7ab5358d59a7773caa2176d23">8079f5a688d54ba7ab5358d59a7773caa2176d23</a>
-<blockquote>
-<p>
- PDF interpreter - fix for GSView 5<br>
-<br>
- Commit 093bd18bd923644fcd25c507088c0ebc63b4c320 included an<br>
- 'optimisation' to prevent rescanning for transparency if we had already<br>
- scanned. However, this assumed that the function pdfshowpage_setup<br>
- had already been executed in order to set a variable.<br>
-<br>
- This is always true when running files via Ghostscript, but any<br>
- application (such as GSView 5) which executes the PDF operations<br>
- individually need not execute this function. If the function was not<br>
- executed then an error occurred. From other comments in pdf_main.ps<br>
- its possible that customers may be using these functions as well (see<br>
- the comments above the definition of /pdfshowpage)<br>
-<br>
- This commit checks to see if the variable has been set, if it has then<br>
- it is used, otherwise we rescan for transparency. This prevents the<br>
- error, but uses the optimisation if its possible to do so.<br>
-<br>
- No differences expected<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-
-<h2><a name="Version9.20"></a>Version 9.20 (2016-09-26)</h2>
-
-<p>This is the fourteenth full release in the stable 9.x series, and is purely
-a maintenance release.
-
-<p> Highlights in this release include:
-<ul>
-<li>
-<p>The usual round of bug fixes, compatibility changes, and incremental improvements.
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.20_Incompatible_changes"></a>Incompatible changes</h3>
-<ul>
-<li>
-<p>
-The planned device API tidy did not happen for this release, due to time pressures,
-but we still intend to undertake the following:
-We plan to somewhat tidy up the device API. We intend to remove deprecated device
-procs (methods/function pointers) and change the device API so every device proc
-takes a graphics state parameter (rather than the current scheme where only a
-very few procs take an imager state parameter). This should serve as notice to
-anyone maintaining a Ghostscript device outside the canonical source tree that
-you may (probably will) need to update your device(s) when these changes happen.
-Devices using only the non-deprecated procs should be trivial to update.
-</li>
-</ul>
-
-<h3><a name="9.20_changelog"></a>Changelog</h3>
-<p><strong>2016-09-20 18:07: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=1bd7f32d70549971b4a384c5865e1fd030f49f20">1bd7f32d70549971b4a384c5865e1fd030f49f20</a>
-<blockquote>
-<p>
- Bug 697138: Fix --disable-sse2 to work with openjpeg<br>
-<br>
- OpenJPEG enables it's SSE code based on the compiler defining __SSE__ so we<br>
- want to undefine that if we're not using SSE operations.<br>
-<br>
-Makefile.in<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 19:57:14 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20b0255206254ebcce1cde0a4a63d74b0aedcecf">20b0255206254ebcce1cde0a4a63d74b0aedcecf</a>
-<blockquote>
-<p>
- Fix splay tree traversal (again)<br>
-<br>
- When setting up a traversal from a midpoint of the tree, we'd<br>
- immediately trip into the &quot;has hit the endpoint&quot; code.<br>
-<br>
- Fix that.<br>
-<br>
-base/gsalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 09:03:31 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e1153bf2d344044cd9fdfb7706f829b63348118">0e1153bf2d344044cd9fdfb7706f829b63348118</a>
-<blockquote>
-<p>
- FitPage should not add in rotation if destination page is square.<br>
-<br>
- If the PageSize was square, it would be treated as &quot;not landscape&quot;,<br>
- but landscape pages in would be arbitrarily rotated.<br>
-<br>
- Note this does not change the bahavior of PS or EPS page fitting.<br>
- TBD: Add an option to fit to a page and never rotate (FitPageNR)<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 16:48:45 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=570041cc341557da8521fdace380f837cc572a69">570041cc341557da8521fdace380f837cc572a69</a>
-<blockquote>
-<p>
- Fix Memento crash<br>
-<br>
- When reallocing set the rawsize before attempting to write<br>
- the post guard block.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 13:41: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=3dd5f4c6b02179422bd8686fceed1f4955221d90">3dd5f4c6b02179422bd8686fceed1f4955221d90</a>
-<blockquote>
-<p>
- Sync Memento with MuPDF.<br>
-<br>
-base/memento.c<br>
-base/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-20 13:04:51 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e01c57e0f0773e29bc6f921cfc677576e72739d">4e01c57e0f0773e29bc6f921cfc677576e72739d</a>
-<blockquote>
-<p>
- Bug 697134: Tweak MEMENTO_GS_HACKS inclusion.<br>
-<br>
- Rather than rolling our own memset prototype in this case, use<br>
- the one that gs provides.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-16 15:23: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=1a0104084a4dfdff77165d931bdc87849c8ad824">1a0104084a4dfdff77165d931bdc87849c8ad824</a>
-<blockquote>
-<p>
- Clump has_refs - follow up to commit 63f74ce6<br>
-<br>
- The function save_set_new() (where the original fix for 'has_refs' is located)<br>
- is called in two circumstances: when creating a save level, and when destroying<br>
- a save level.<br>
-<br>
- We have to retain the 'has_refs' value for the latter case for the garbager to<br>
- function correctly, but doing so in the former results in the garbager<br>
- sometimes scanning more memory than is really necessary (it can end up scanning<br>
- ref memory from the previous save state, which is pointless since that cannot<br>
- change).<br>
-<br>
- This change means that 'has_refs == true' will only be retained in the<br>
- 'destroying a save level' case (which works correctly because, by the time the<br>
- function is called, we've already returned the relevant allocated to its<br>
- previous state).<br>
-<br>
-psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-15 14:14:35 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bfffe2011e1c8ffe53a432424b049f3989d6174a">bfffe2011e1c8ffe53a432424b049f3989d6174a</a>
-<blockquote>
-<p>
- Fix bug 697097. SMask subpixel offset must match image offset.<br>
-<br>
- The dda used to select the source pixel for mapping into the image<br>
- must use the same stepping for gray (monochrome) and color images<br>
- since an SMask is monochrome and the image may be in color. This is<br>
- primarily evident with the bug file since Matte is used to indicate<br>
- that the source data is premuliplied. Colors can shift a LOT since<br>
- the removal of the premultiplication can expand mistaked.<br>
-<br>
-base/gxicolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-14 16:31:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5521e702af192e06f186d0d741f24097eb5b8e26">5521e702af192e06f186d0d741f24097eb5b8e26</a>
-<blockquote>
-<p>
- PDF interpreter - fix for GSView 5<br>
-<br>
- Commit 093bd18bd923644fcd25c507088c0ebc63b4c320 included an<br>
- 'optimisation' to prevent rescanning for transparency if we had already<br>
- scanned. However, this assumed that the function pdfshowpage_setup<br>
- had already been executed in order to set a variable.<br>
-<br>
- This is always true when running files via Ghostscript, but any<br>
- application (such as GSView 5) which executes the PDF operations<br>
- individually need not execute this function. If the function was not<br>
- executed then an error occurred. From other comments in pdf_main.ps<br>
- its possible that customers may be using these functions as well (see<br>
- the comments above the definition of /pdfshowpage)<br>
-<br>
- This commit checks to see if the variable has been set, if it has then<br>
- it is used, otherwise we rescan for transparency. This prevents the<br>
- error, but uses the optimisation if its possible to do so.<br>
-<br>
- No differences expected<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-14 10:40:36 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79c79254908fe69462407c60966dd10521b4a9ac">79c79254908fe69462407c60966dd10521b4a9ac</a>
-<blockquote>
-<p>
- Copyrights, dates etc<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/Xfonts.htm<br>
-doc/gs-vms.hlp<br>
-doc/sample_downscale_device.htm<br>
-doc/thirdparty.htm<br>
-man/dvipdf.1<br>
-man/font2c.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>
-man/wftopfa.1<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-14 10:34: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=703223237fe84cff31628e78a511cf60ef632969">703223237fe84cff31628e78a511cf60ef632969</a>
-<blockquote>
-<p>
- Change product family for RC<br>
-<br>
- Plus dates<br>
-<br>
-base/gscdef.c<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-07 11:05:08 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd181f9d5cb9b2cd589cb43b0d06b1e6ebc579b4">cd181f9d5cb9b2cd589cb43b0d06b1e6ebc579b4</a>
-<blockquote>
-<p>
- Bug 697102 - AddressSanitizer: buffer overflow solid_pattern_data<br>
-<br>
- Although (likely) benign, solving this is trivial: give the rendering code<br>
- a ushort rather than a single byte.<br>
-<br>
-pcl/pcl/pcbiptrn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-07 11:33: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=cd95789bc8eaf0e86f902c8ba3f796340ffdad25">cd95789bc8eaf0e86f902c8ba3f796340ffdad25</a>
-<blockquote>
-<p>
- Ensure PCL/XPS free all their memory.<br>
-<br>
- Noticed in passing (thrown up by ASAN): the plmain code was not fully shutting<br>
- down the memory manager when using the chunk allocator.<br>
-<br>
- This commit adds a convenient function (gs_memory_chunk_wrap) and a<br>
- pl_alloc_finit() function to ensure that all happens.<br>
-<br>
-base/gsmalloc.c<br>
-base/gsmchunk.c<br>
-base/gsmchunk.h<br>
-pcl/pl/plalloc.c<br>
-pcl/pl/plalloc.h<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-07 09:58: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=dbfde5f3400e97b6d9b71a6549ff419dcefc9a95">dbfde5f3400e97b6d9b71a6549ff419dcefc9a95</a>
-<blockquote>
-<p>
- Bug 696599: cast disguised wrong type dereference.<br>
-<br>
- The code was casting to a gx_device_printer to get to the BLS_force_memory<br>
- value, but since the target device for a clist device is no longer<br>
- necessarily a printer device, it wasn't guaranteed that the struct contained<br>
- that entry.<br>
-<br>
- So move BLS_force_memory to the base device type (gx_device), so it's always<br>
- available.<br>
-<br>
-base/gdevprn.h<br>
-base/gxclbits.c<br>
-base/gxdevcli.h<br>
-base/gxdevice.h<br>
-devices/gdevbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-12 19:31:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e541e3e356624506720fddd26441a2c43d82024">8e541e3e356624506720fddd26441a2c43d82024</a>
-<blockquote>
-<p>
- pdfwrite - don't reset the graphics state object for new XObject streams<br>
-<br>
- Bug #697109 &quot;Inkscape graphics in Latex PDF distorted on compression&quot;<br>
-<br>
- When starting a new substream the pdfwrite code always resets the current<br>
- graphics state to the 'initial' state. This seem, to me, utterly wrong,<br>
- if we have changed the graphics state, then it persists into any<br>
- 'substreams'.<br>
-<br>
- Indeed, in this case we set the dash array, then the fact that we have<br>
- transparency causes us to push a new group, this starts a new substream,<br>
- we reset the graphics parameters (including the dash). Then we set the<br>
- dash pattern to the default and stroke a path. If we didn't start a<br>
- group we would notice the dash had changed and emit the change. However<br>
- because the group causes a reset, we see the dash change to the same as<br>
- it currently is, so we don't emit it.<br>
-<br>
- I'm not totally happy with this change, there are a *lot* of subtleties<br>
- in the code, not least the (bonkers) fact that starting a group *does*<br>
- reset 3 extended graphics state parameters (SMask and constant alpha).<br>
- It looks like we have some assumptions built in elsewhere as well. If<br>
- I don't reset all the parameters then some other files start to fail.<br>
-<br>
- This fix doesn't reset the graphics state for XObjects, but does for<br>
- everything else. For XObjects it only resets the 3 group parameters.<br>
-<br>
- I'd spend more time on this but I want to get some sort of fix into the<br>
- 9.20 release. This definitely needs more investigation.<br>
-<br>
- There are a number of diffs, most are definite progressions, a few that<br>
- I can't be sure of but they don't seem any worse (and in some cases the<br>
- original file is technically broken anyway). Oddly there are more<br>
- progressions when rendering to halftoned devices, I can only assume<br>
- that we were previously emitting a broken halftone.<br>
-<br>
-devices/vector/gdevpdti.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-12 17:50: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=d1ef839f4c41645cdba9524d0062c5aa2c533818">d1ef839f4c41645cdba9524d0062c5aa2c533818</a>
-<blockquote>
-<p>
- Bug 697110: Ensure stream 'file_limit' is correct<br>
-<br>
- Follow-on from commit 4b101952d81a5899972f81f7b18ef3becd5bd45e<br>
-<br>
- There are several places that set, and check the value of file_limit for<br>
- streams. Ensure they all use the requisite value whether the gs_offset_t is<br>
- 64 bit (normal) or 32 bit (abnormal).<br>
-<br>
- To make it easier, and more consistent, pull the logic out into a macro.<br>
-<br>
-base/gsioram.c<br>
-base/gsiorom.c<br>
-base/sfxfd.c<br>
-base/sfxstdio.c<br>
-base/stream.h<br>
-psi/zfrsd.c<br>
-psi/ziodevsc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-09 07:54:26 +0200
-</strong>
-<br>Janssen &lt;njj@ocevenlo.oce.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=efdd255f800b4f1bc22e81d686691aa1b48f785f">efdd255f800b4f1bc22e81d686691aa1b48f785f</a>
-<blockquote>
-<p>
- Bug 697088, HPGL not printing PCL downloaded font.<br>
-<br>
- The hpgl_map_symbol() function is modified to handle downloaded<br>
- (bound) pcl fonts correctly. HPGL and PCL now use the same<br>
- char_is_printable() function to detect printable characters.<br>
-<br>
- modified: pcl/pcl/pcstate.h<br>
- modified: pcl/pcl/pctext.c<br>
- modified: pcl/pcl/pglabel.c<br>
-<br>
-pcl/pcl/pcstate.h<br>
-pcl/pcl/pctext.c<br>
-pcl/pcl/pglabel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-11 10:52:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e25d823decd905a4917d26fe3d08a15af12eb1a6">e25d823decd905a4917d26fe3d08a15af12eb1a6</a>
-<blockquote>
-<p>
- pdfwrite - another guard against a NULL clip path<br>
-<br>
- commit ab3a1249ce28e3cac629ce1466d17e635ff50fab introduced a check<br>
- to ensure a clip path wasn't null before using it. This caused Coverity<br>
- to then check the use of that clip path throughout the function, and<br>
- identify another area needing a check.<br>
-<br>
-devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-10 11:52: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=aa23930545649007079b17057083c1725427c558">aa23930545649007079b17057083c1725427c558</a>
-<blockquote>
-<p>
- Apply fix suggested in Bug 697108 to prevent infinite loop<br>
-<br>
- Hopefully the last missed increment of a loop variable in the image<br>
- interpolation code.<br>
-<br>
- Thanks to Jonathan Dagresta for the patch.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-09 12:15: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=cca3ba8087dbec47a6e7a8e5368da9e28fb81663">cca3ba8087dbec47a6e7a8e5368da9e28fb81663</a>
-<blockquote>
-<p>
- Add building a 'stripped' shared lib.<br>
-<br>
- configure.ac now finds the 'strip' exe.<br>
-<br>
- There's a new target 'so-only-stripped' which builds the .so libs and then<br>
- strips them using the supplied strip exe<br>
-<br>
-Makefile.in<br>
-base/unix-dll.mak<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-09 09:05: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=0783d723673f60099d6cdaa47431d6fd2bfad68b">0783d723673f60099d6cdaa47431d6fd2bfad68b</a>
-<blockquote>
-<p>
- Tweak .so target to not have a &quot;main&quot; function.<br>
-<br>
-base/unix-dll.mak<br>
-base/unixlink.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-08 15:10:47 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e088b1dfdaab9dc66b96b2f2d022384f6258a822">e088b1dfdaab9dc66b96b2f2d022384f6258a822</a>
-<blockquote>
-<p>
- Bug #696658 - 2 ligatures had incorrect mappings.<br>
-<br>
- The unicode values were wrong for ff and fi. With this fix and the<br>
- new URW fonts the problem reported is fixed.<br>
-<br>
-pcl/pl/plsymbol.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-08 09:12: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=e221dcd1b756f2a6e04531876e43b587fa8577b1">e221dcd1b756f2a6e04531876e43b587fa8577b1</a>
-<blockquote>
-<p>
- pdfwrite - don't attempt to keep co-ordinates &lt;32K when creating PDF 1.5+<br>
-<br>
- Bug #697098 &quot;pdfwrite charpath conversion problem&quot;<br>
-<br>
- When the PDFCompatibilityLevel is 1.5 or above we can use reals with<br>
- sensible ranges, instead of the +/- 32767 that old versions of the<br>
- specification limited us to.<br>
-<br>
- This results in a large number of small differences, some minor progressions<br>
-<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-07 16:11:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e644fc3454bf84555b2d8369138d2f25bfbf6133">e644fc3454bf84555b2d8369138d2f25bfbf6133</a>
-<blockquote>
-<p>
- pdfwrite - Don't limit the resolution when Compatibility &gt; 1.4<br>
-<br>
- Bug #697098 &quot;pdfwrite charpath conversion problem&quot;<br>
-<br>
- This is not a fix, but a work-around, especially for future files.<br>
-<br>
- We currently limit the resolution by checking the media size to see if<br>
- it lies in the range +/- 16,000. This is because The PDF Reference states<br>
- that co-ordinates are real numbers, and versions of the spec prior to<br>
- 1.5 have a limit of +/- 32,767 for real numbers. In practice it was<br>
- noted that Acrobat Reader couldn't even cope with numbers that large so<br>
- we arbitrarily settled on 16,384 and then allowed a bit of slop.<br>
-<br>
- With the PDF 1.5 specification (now 13 years old) this limit was raised<br>
- to +/- 3.403x10^38<br>
-<br>
- In the interim we have also raised our default PDF creation to 1.5 and<br>
- we have adopted other means (altering the CTM) to keep co-ordinates<br>
- in the 32,767 range. So there is really no reason to maintain this old<br>
- hack.<br>
-<br>
-devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-07 16:03: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=ab3a1249ce28e3cac629ce1466d17e635ff50fab">ab3a1249ce28e3cac629ce1466d17e635ff50fab</a>
-<blockquote>
-<p>
- pdfwrite - guard against an empty clip path<br>
-<br>
- Noticed while doing other work, if we don't have a clip path, we must<br>
- not attempt to use it to clip text.....<br>
-<br>
- No differences expected<br>
-<br>
-devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-07 10:37:27 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c835d00d51a70d410e0092f9442d30bcf38e95f1">c835d00d51a70d410e0092f9442d30bcf38e95f1</a>
-<blockquote>
-<p>
- Soft Mask Matte Entry Bug 697097<br>
-<br>
- Included getting the Matte color entries to the<br>
- transparency compositor action (Thanks to Ray)<br>
- and undoing the preblend with the Matte bias.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gstparam.h<br>
-base/gstrans.c<br>
-base/gstrans.h<br>
-base/gxblend1.c<br>
-psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-07 07:17: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=4b101952d81a5899972f81f7b18ef3becd5bd45e">4b101952d81a5899972f81f7b18ef3becd5bd45e</a>
-<blockquote>
-<p>
- Fix sread_subfile check for file_limit when gs_offset_t is bigger than long.<br>
-<br>
- The file_limit was initialized in sread_file and swrite_file to the largest<br>
- gs_offset_t value, but the check only compared to max_long.<br>
-<br>
-base/sfxstdio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-04 10:51: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=527450e2ef1eca2ad26cdfba3a4f667e90bfd992">527450e2ef1eca2ad26cdfba3a4f667e90bfd992</a>
-<blockquote>
-<p>
- Fix typo introduced in commit c9f24068<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-02 10:37:59 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=57387434f2bfefea94445b095465dfb621855ba1">57387434f2bfefea94445b095465dfb621855ba1</a>
-<blockquote>
-<p>
- Fix is_big_mask calculation to be sqrt(a*a + b*b)<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-09-01 07:44:23 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a127d73fc54024ad7aa6a73703c642527137d4ac">a127d73fc54024ad7aa6a73703c642527137d4ac</a>
-<blockquote>
-<p>
- Add findrgbcustomcolor as requested by customer 400.<br>
-<br>
- This appears to be used in the AI5 ProcSet of Adobe Illustrator (R)<br>
- Version 7.0 Full Prolog and allows us to construct a Separation<br>
- space that has a DeviceRGB alternate colorspace and tint transform.<br>
- There is no Adobe documentation that mentions this, but I found one<br>
- other implementation that had this procedure defined.<br>
-<br>
- Also fix missing pop when setcustomcolor is invoked with tint == null<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-30 12:59:37 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=776b12c8b6051cad5c6e1839a00f20221b33731d">776b12c8b6051cad5c6e1839a00f20221b33731d</a>
-<blockquote>
-<p>
- Bug 697032 - remove files with unsuitable licenses<br>
-<br>
-contrib/japanese/doc/djgpp.txt<br>
-contrib/japanese/doc/gdevmag.txt<br>
-contrib/japanese/doc/gs261j.euc<br>
-contrib/japanese/doc/gs261j.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-30 12:43:58 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=605f61b950d79204762198e67c9700b9410b465e">605f61b950d79204762198e67c9700b9410b465e</a>
-<blockquote>
-<p>
- Bug 697032, remove chess.ps<br>
-<br>
-examples/chess.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-30 08:33:32 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd8d83665f5e32ce7057e3ca2e8662eabb195c2a">dd8d83665f5e32ce7057e3ca2e8662eabb195c2a</a>
-<blockquote>
-<p>
- Add mention of PostRenderProfile option in documentation.<br>
-<br>
-doc/Devices.htm<br>
-doc/sample_downscale_device.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-30 16:03:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d26a2bb28aeeb5e94c501ff085bb52f72151f65b">d26a2bb28aeeb5e94c501ff085bb52f72151f65b</a>
-<blockquote>
-<p>
- Bug 696867: strip trailing whitespace from configure.ac<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-26 15:44:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=66d905ba077ec5025299a7cd2074e66fac2e09d2">66d905ba077ec5025299a7cd2074e66fac2e09d2</a>
-<blockquote>
-<p>
- Reinstate pointer alignment special case for sparc and hpux<br>
-<br>
- The configure check for required pointer alignment works on Linux/SPARC, but<br>
- not on Solaris/SPARC - so reinstate the special case code in genarch.c<br>
-<br>
- I'm including the HP/UX case as well since it's safer, and does not add<br>
- to the complexity of code.<br>
-<br>
-base/genarch.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-26 15:12:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6290b83763b6a7022112886517d23ce3d2140ca">c6290b83763b6a7022112886517d23ce3d2140ca</a>
-<blockquote>
-<p>
- Bug 697064: FAPI: work around compiler bug<br>
-<br>
- The Sun cc compiler optimizer has bug that *seems* to result in the order<br>
- addition operations being changed (which isn't legal). In this case, we're<br>
- unpacking bytes from a stream, and reordering the operations means the<br>
- bytes come out of the stream in the wrong order.<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-26 13:44: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=b830052545cbcd5f31fc90edc8ddedf54eb9eded">b830052545cbcd5f31fc90edc8ddedf54eb9eded</a>
-<blockquote>
-<p>
- Fix a couple of minor typos in the Trap param section.<br>
-<br>
-doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-26 13:37:47 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7bb57f5d37e246ceb551ed5821873239ab26034e">7bb57f5d37e246ceb551ed5821873239ab26034e</a>
-<blockquote>
-<p>
- Add documentaion and sample code for a CMYK 32-bit downscaling device<br>
-<br>
-doc/gdevds32.c<br>
-doc/sample_downscale_device.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-29 13:46:13 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a76c1e1c6bce85d01682e8e595b50ddabed5be3d">a76c1e1c6bce85d01682e8e595b50ddabed5be3d</a>
-<blockquote>
-<p>
- Bug #696856 - fix memcmp being used on a structure.<br>
-<br>
- The bad memcmp was part of an obsolete implementation to include icc<br>
- profiles in the photoshop device which is removed with this change.<br>
-<br>
-devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-29 12:46:47 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6892b89fab66086346d754714806ce0870407970">6892b89fab66086346d754714806ce0870407970</a>
-<blockquote>
-<p>
- Fix 696929 - SetLineDash error.<br>
-<br>
- Many HP printer and our PXL interpreter limit the dash element array<br>
- size to 20 so we shouldn't produce PCLXL that exceeds that limit.<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-26 12:12:37 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f18c60fd2aa43f59fbf197463aca30ea3a0bc2d">2f18c60fd2aa43f59fbf197463aca30ea3a0bc2d</a>
-<blockquote>
-<p>
- Fix 697030 - Interpreter exit.<br>
-<br>
- If the vector device's begin image procedure fails fallback to using<br>
- the default image code instead of producing an error.<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-25 13:26:13 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=124e9f44c03cc0d3773d18708ee285b75cb12c04">124e9f44c03cc0d3773d18708ee285b75cb12c04</a>
-<blockquote>
-<p>
- Fix minor typo in devs.mak for the tiffscaled8 devcice<br>
-<br>
-devices/devs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-25 08:56:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af8dfa700dca2671ea9d81e01adb2db219c0bb2f">af8dfa700dca2671ea9d81e01adb2db219c0bb2f</a>
-<blockquote>
-<p>
- Tweak the .a target<br>
-<br>
- Add an explicit &quot;gslib&quot; target, and have the .a end up in the &quot;bin&quot; direstory<br>
- rather than the root of the tree.<br>
-<br>
- So, to build the .a now, you'd do &quot;make gslib&quot;<br>
-<br>
-base/unixlink.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-25 08:55: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=94913c07fe8c4863d925cf117664a07262c6fc9d">94913c07fe8c4863d925cf117664a07262c6fc9d</a>
-<blockquote>
-<p>
- Add a couple of headers for function prototypes<br>
-<br>
- abs() and memset() prototypes.<br>
-<br>
- Also, dependencies as required<br>
-<br>
-base/gp_psync.c<br>
-base/gxht_thresh.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-24 10:12:59 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7f08915e1b84fc15759ab8a3aacab47196bbaf32">7f08915e1b84fc15759ab8a3aacab47196bbaf32</a>
-<blockquote>
-<p>
- Bug 697060. -dUsePDFX3Profile and -dNumRenderingThreads<br>
-<br>
- When the output intent profile is used it was cloned from<br>
- the target device, but it was not getting its initial settings<br>
- in place. The threads do not need the post render profile nor<br>
- the output intent profile (it is the device profile in this case)<br>
-<br>
- This was tested on -dUsePDFX3Profile, -dNumRenderingThreads=4<br>
- -sPostRenderProfile=&quot;myprinter.icc&quot; with the file Altona_Technical_v20_x4.pdf<br>
-<br>
-base/gsicc_manage.c<br>
-base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-24 07:49:53 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8a8eefe5dcb1509aa5ebd7517438c755045bb139">8a8eefe5dcb1509aa5ebd7517438c755045bb139</a>
-<blockquote>
-<p>
- Bug 697059 Pattern and Spot Color<br>
-<br>
- If the only occurrence of a spot color was in a pattern,<br>
- the equivalent CMYK values were not getting set for use<br>
- by a separation device during the installation of the<br>
- separation color space. This was due to the fact that<br>
- the pattern accumulator bits device (whose target is the<br>
- real device) has its update_spot_equivalent_color proc set<br>
- to default which ends up doing nothing. Instead we now<br>
- set the bits device proc to forward to the real target<br>
- device.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-23 08:09:09 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc3192c4fddaccfe4d3199e944ae9a7b8edb5682">cc3192c4fddaccfe4d3199e944ae9a7b8edb5682</a>
-<blockquote>
-<p>
- Improve bug 696985. Performance issue (and large memory usage).<br>
-<br>
- The GC would run due to the 'system' VM which never had it's limit set (default<br>
- 600,000), but after the GC ran the limits for all of the VM's were reset to<br>
- the current allocated plus the limit, so the local VM and global VM were not<br>
- in a state to be collected (pages ran in a save ... restore).<br>
-<br>
- Setting the system VM limit to the same value allows the file to complete<br>
- in 84 seconds and only uses 74Mb (a cut down file that was 5k pages took 170<br>
- seconds and used 634Mb before the change). The entire large file only needed<br>
- 725 GC's to complete and most were for the local VM (space==12), rather than<br>
- for the system VM (space==4).<br>
-<br>
- Also change the formatting of one of the gs_debug['0'] messages to keep all<br>
- the relevant values on one line which makes searching/grepping easier.<br>
-<br>
-base/gsalloc.c<br>
-psi/zvmem2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-22 15:10: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=e20ae050feea47ded0d96c49627ed5c7b3502db6">e20ae050feea47ded0d96c49627ed5c7b3502db6</a>
-<blockquote>
-<p>
- Set default rendering condition to unspecified<br>
-<br>
- Also fix up a few memory issues with respect to the post render<br>
- ICC profile.<br>
-<br>
-base/gsdevice.c<br>
-base/gsicc_manage.c<br>
-base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-23 16:41:16 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=755eddab9cb238324dc84ac1fd5c9736314d8a48">755eddab9cb238324dc84ac1fd5c9736314d8a48</a>
-<blockquote>
-<p>
- Partially revert &quot;Change &quot;GPL Ghostscript&quot; to &quot;Ghostscript&quot;&quot;<br>
-<br>
- Change references from GPL to AGPL, but leave the product/project name<br>
- as &quot;GPL Ghostscript&quot;.<br>
-<br>
-base/gp_wgetv.c<br>
-base/gscdef.c<br>
-doc/Commprod.htm<br>
-doc/Install.htm<br>
-doc/Language.htm<br>
-doc/Readme.htm<br>
-doc/Release.htm<br>
-psi/dwreg.c<br>
-psi/mkfilelt.cpp<br>
-psi/nsisinst.nsi<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-22 08:52: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=5cbf2d0185ce6b268abffc275d72ffd1a6b5b18b">5cbf2d0185ce6b268abffc275d72ffd1a6b5b18b</a>
-<blockquote>
-<p>
- PDF interpreter - honour /Intent for images<br>
-<br>
- Bug #697055 &quot; Intent entry in Image Dictionary not honored&quot;<br>
-<br>
- This causes a number of differences, most are not discernible, (careful<br>
- scrutiny shows slightly brighter colour in a few of these) however<br>
- icc_v4_profile.pdf shows a marked progression in one image<br>
- (V4 CMYK profile).<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-21 16:58:29 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=923d7bd2715f24a41a79894086b8106885a71ccd">923d7bd2715f24a41a79894086b8106885a71ccd</a>
-<blockquote>
-<p>
- Dependency fix for gxscanc.c.<br>
-<br>
- The dependency gx.h was missing from the dependency list; this caused<br>
- parallel builds to fail.<br>
-<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-21 22:44:34 +0000
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c9af5e8a5578b01714ddca0afa13b5707e3a14a9">c9af5e8a5578b01714ddca0afa13b5707e3a14a9</a>
-<blockquote>
-<p>
- Revert a few line-breaks from the recent auto-indentation<br>
-<br>
- This is a cosmetic change - no modification to code logic.<br>
-<br>
- No cluster differences<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-20 20:38:16 +0000
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1142ba29b19a819aba4cb89f029a6d15330ea11a">1142ba29b19a819aba4cb89f029a6d15330ea11a</a>
-<blockquote>
-<p>
- Factoring out a long common expression, for readability.<br>
-<br>
- This is a cosmetic change, and does not affect the code logic.<br>
- This part of the code had grown steadily in the past from<br>
- stuff_1<br>
- to<br>
- (flipped ? stuff_2 : stuff_1)<br>
- to<br>
- if (!icc)<br>
- (flipped ? stuff_2 : stuff_1)<br>
- else<br>
- (flipped ? stuff_2a : stuff_1a)<br>
-<br>
- No cluster differences<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-19 00:40:16 +0100
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ada0c784640fcd355a0d6a1b2132dafad14f21bc">ada0c784640fcd355a0d6a1b2132dafad14f21bc</a>
-<blockquote>
-<p>
- Auto-indent according to doc/C-style.htm<br>
-<br>
- Running<br>
- indent -bad -nbap -nsob -br -ce -cli4 -npcs -ncs -i4 -di0 -psl -lp -lps -nut<br>
- , according to doc/C-style.htm<br>
-<br>
- This fixes some inconsistent tabs and indentations accumulated over the years.<br>
-<br>
- No cluster differences<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-19 00:56:29 +0000
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=764812e438e1a94afa09a8b46fa017d8cb287fac">764812e438e1a94afa09a8b46fa017d8cb287fac</a>
-<blockquote>
-<p>
- Add a few semi-colons and manually breaking a few lines<br>
-<br>
- This is a non-code-logic change to assist the next step, auto-indentation.<br>
-<br>
- No cluster differences<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-19 00:00:13 +0100
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=62898632f38230fc778f929ab4ea4469b36ac3b4">62898632f38230fc778f929ab4ea4469b36ac3b4</a>
-<blockquote>
-<p>
- Use default unoptimized code path for non-CMYK and inverted images.<br>
-<br>
- 5 of the test files have 32-bit images which the new CMYK code does<br>
- not process correctly. So we revert back to the unoptimized code<br>
- path for them.<br>
-<br>
- 1 with 32-bit DeviceN:<br>
-<br>
- tests_private/comparefiles/Bug692494.pdf<br>
-<br>
- 4 have inverted Decode arrays ([1 0 1 0 1 0 1 0]) - i.e. they<br>
- are RGBW rather than CMYK. It is probably not hard to cope with them<br>
- also, but push them back onto the unoptimized code path for now:<br>
-<br>
- tests_private/comparefiles/Bug696487.pdf<br>
- tests_private/comparefiles/z400454b01d4-1.pdf<br>
- tests_private/pdf/PDFIA1.7_SUBSET/CATX6554.pdf<br>
- tests_private/pdf/sumatra/1610_-_Decode_ignored_for_JPX_images_regression_from_r2055_.pdf<br>
-<br>
- No cluster differences<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-18 23:16:16 +0100
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cf72ede2c68e1f76530b1da86dfda70e8ee5295c">cf72ede2c68e1f76530b1da86dfda70e8ee5295c</a>
-<blockquote>
-<p>
- Calculate correctly the offset for the last (incomplete) strip of a flipped image for icc<br>
-<br>
- The ICC-transform code path was never thoroughly tested. PXL can do rotated<br>
- but not reflected images; we worked around this limitation by processing the<br>
- scanlines from the end of the buffer backward. For an incomplete strip, we<br>
- therefore need to offset into the final buffer. The offset is different for<br>
- pre-icc code path vs icc-transformed code path.<br>
-<br>
- Affected files:<br>
- tests_private/comparefiles/besttest.pdf<br>
- tests_private/pdf/PDFIA1.7_SUBSET/CATX4547.pdf<br>
- tests_private/pdf/sumatra/x_-_text_clipped_away_above_141_pc.pdf<br>
-<br>
- No cluster differences<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-17 03:17:41 +0000
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=50aa6f1bcb7035c3eb7f6e0d3e502ae021ba681e">50aa6f1bcb7035c3eb7f6e0d3e502ae021ba681e</a>
-<blockquote>
-<p>
- Allow 32-bit CMYK image (converted to 24-bit RGB) to be jpeg compressed.<br>
-<br>
- Previously, anything except 24-bit RGB is forbidden from going through<br>
- jpeg compression, because anything other than image does not make sense.<br>
- RLE and DeltaRow can apply to general byte-stream data, not jpeg.<br>
-<br>
- This is another part of the enhancement for bug 696905, and depends<br>
- on the previous two of this group. The previous two changes convert<br>
- 32-bit CMYK data to 24-bit RGB internally, either through<br>
- DeviceCMYK-&gt;RGB or icc. So this change is just a one-liner.<br>
-<br>
- No cluster differences<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-13 21:36:54 +0000
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cea5c6072c1e224fea7c0a7334d943cc1250ad5b">cea5c6072c1e224fea7c0a7334d943cc1250ad5b</a>
-<blockquote>
-<p>
- Make 32-bit CMYK image icc-proccessed, unless UseFastColor is specified.<br>
-<br>
- This is a further part of the enhancement for bug 696905.<br>
-<br>
- There is a big block of comments about a previous change of<br>
- pclxl_can_handle_color_space() (introduced in bug 692329)<br>
- being wrong and causes slightly wrong colors. That needs to be<br>
- looked at eventually, and this change updated.<br>
-<br>
- No cluster differences<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-10 14:31:47 +0000
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=967460041394c2ece02aedf9dba59ef4a3137f28">967460041394c2ece02aedf9dba59ef4a3137f28</a>
-<blockquote>
-<p>
- Optimize for CMYK image inputs in pxlcolor/pxlmono<br>
-<br>
- This is part of the enhancement for bug 696905.<br>
-<br>
- pxlcolor/pxlmono is not supposed to be colour-accurate. This change must be<br>
- used together with -dUseFastColor=true, or there will be unsighty colour<br>
- tiling between image portions under different colour management, or lack of.<br>
-<br>
- No cluster differences<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-16 16:24: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=0a5e560e38f47b19257debff272adbe3acacbfab">0a5e560e38f47b19257debff272adbe3acacbfab</a>
-<blockquote>
-<p>
- Fix -dDisplayFormat=16#20808 that caused 50% Cyan background with transparency.<br>
-<br>
- This was broken in commit 4e44c99 that added a clist device when transparency<br>
- caused MaxBitmap to be exceeded. The values for max_gray and dither_grays in<br>
- the color_info for the pdf14_accum_CMYK were incorrectly initialized confusing<br>
- the gx_default_encode_color and COLROUND macros.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-23 18:14:29 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=18ef67078eb63103ed5e0de627296cb86f493d42">18ef67078eb63103ed5e0de627296cb86f493d42</a>
-<blockquote>
-<p>
- Bug 696636: New scan converter.<br>
-<br>
- This commit adds a new scan converter implementation designed<br>
- to address some of the problems seen with 'busy' paths in the<br>
- current implementation.<br>
-<br>
- No 'active line list' is kept, instead we run through the path<br>
- generating a buffer of scanline edge intersections. This trades<br>
- repeated sorting of the active list against potentially higher<br>
- memory usage.<br>
-<br>
- This code has 2 pairs of different variants. Each pair copes<br>
- with 'centre of pixel' and 'any part of a pixel' rendering<br>
- modes. One pair scan converts to rectangles, another pair to<br>
- trapezoids.<br>
-<br>
- These routine does not give identical results to the old code,<br>
- partly due to (minimal) rounding issues, but more due to the<br>
- fact that the new code is only equivalent to adjust values of<br>
- 0 or 0.5.<br>
-<br>
- GS uses intermediate adjust values by default (such as 0.3)<br>
- when rasterising at low resolution (&lt; 150dpi). In such cases<br>
- this new code will cover more than the old code did. It is<br>
- hoped that the impact of this is reduced due to the fact we<br>
- use freetype for character rendering now.<br>
-<br>
- This new scan converter is disabled by default. To enable it,<br>
- set the scanconverter value to be non-zero. This is most easily<br>
- achieved by using -dSCANCONVERTERTYPE=1 on the command line.<br>
-<br>
- Runs vastly faster on the cases highlighted in bugs 692351<br>
- and 691984.<br>
-<br>
-base/gslibctx.h<br>
-base/gspaint.c<br>
-base/gxfill.c<br>
-base/gxscanc.c<br>
-base/gxscanc.h<br>
-base/lib.mak<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-11 14:12: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=bb689d1d01b339088d89b98b5eabef0c195cfdc4">bb689d1d01b339088d89b98b5eabef0c195cfdc4</a>
-<blockquote>
-<p>
- Scan converter configuration code.<br>
-<br>
- Here, we introduce the notion of &quot;which scan converter are<br>
- we using&quot; to the core library. This is an integer value<br>
- in gs_lib_ctx_t which (currently) defaults to 1.<br>
-<br>
- We add graphics library calls to get/set this value, and<br>
- new operators reflecting these into postscript.<br>
-<br>
- In addition, we update both the PCL frontend and the PS init<br>
- code so that -dSCANCONVERTERTYPE can be used on the command<br>
- line to set the desired scan converter value.<br>
-<br>
- -dSCANCONVERTERTYPE or -dSCANCONVERTERTYPE=1 will set it to<br>
- 1. -dSCANCONVERTERTYPE=false or -dSCANCONVERTERTYPE=0 will<br>
- set it to 0. Otherwise -dSCANCONVERTERTYPE=&lt;int&gt; will set<br>
- it to the required value.<br>
-<br>
- Currently we only have the one scan converter in gs, hence<br>
- setting this value makes no difference. A subsequent commit<br>
- (probably the very next one) will introduce an alternative<br>
- scan converter that will be disabled by default, but can be<br>
- enabled by setting this value. This commit merely prepares<br>
- the framework for that to fit into.<br>
-<br>
- The intent is that:<br>
-<br>
- 0 (or lower) will mean &quot;The old scan converter&quot;<br>
- 1 will mean &quot;The default scan converter&quot;<br>
- 2 (or higher) will mean new scan converters yet to be defined.<br>
-<br>
- Thanks to Ken for the postscript code.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-base/gsstate.c<br>
-base/gsstate.h<br>
-pcl/pcl/pcstate.h<br>
-pcl/pcl/pctop.c<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pl/pltop.h<br>
-pcl/pxl/pxpthr.c<br>
-psi/int.mak<br>
-psi/zmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-19 16:17:39 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1fbbfeb5dc9d1a12c8ed2e4640e59c416450e478">1fbbfeb5dc9d1a12c8ed2e4640e59c416450e478</a>
-<blockquote>
-<p>
- Bug 697056: Fix LCMS static init of critical section.<br>
-<br>
- LCMS2 relies on being able to statically init a mutex<br>
- (actually a Critical Section on windows). Windows has<br>
- no official API for statically initing a critical<br>
- section, so lcms2 uses a hack (albeit it a safe one)<br>
- to do this.<br>
-<br>
- Unfortunately ApplicationVerifier (and presumably other<br>
- similar tools) don't understand this idiom, and get<br>
- confused by not seeing an explicit initialisation call.<br>
- This is causing problems for a customer.<br>
-<br>
- This commit therefore introduces code to properly<br>
- initialise it on Windows. In order to avoid any possible<br>
- multithreaded startup issues, we use the Windows<br>
- InterlockedCompareExchangePointer API (introduced in<br>
- Windows XP).<br>
-<br>
- If anyone wants to avoid this code (so they can work<br>
- on pre-Windows XP), they can build with:<br>
-<br>
- CMS_RELY_ON_WINDOWS_STATIC_MUTEX_INIT<br>
-<br>
- defined, and get the old behaviour. We automatically<br>
- set this when building with any version of MSVC older<br>
- than VS2005 (i.e. those that don't have that API<br>
- available).<br>
-<br>
-lcms2/src/cmsplugin.c<br>
-lcms2/src/lcms2_internal.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-17 18:40: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=31bdc6bb9587da08d0aecddfee2533e8368706d4">31bdc6bb9587da08d0aecddfee2533e8368706d4</a>
-<blockquote>
-<p>
- MSVC solution: Reorder files in XML.<br>
-<br>
- MSVC has sorted the list of files alphabetically, and this moved<br>
- one. This should be an invisible change.<br>
-<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-17 15:05:02 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=16fa0fbe02250839ff9c953245b5962a65c816cb">16fa0fbe02250839ff9c953245b5962a65c816cb</a>
-<blockquote>
-<p>
- Bug 697044: Fix indeterminism in tiffscaled<br>
-<br>
- When downscaling by a factor of 3, we render at the usual device<br>
- width, then take groups of 9 (3*3) pixels to combine them<br>
- together.<br>
-<br>
- Externally from the downscaler we were rounding the scaled size<br>
- down, whereas internally we were rounding it up.<br>
-<br>
- This means we'd potentially be calculating 1 more pixel than we<br>
- actually needed, using some uninitialised data.<br>
-<br>
- Now we round down both internally and externally.<br>
-<br>
-base/gxdownscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-17 07:46: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=7dee0903b551b43e40bfa12aabce1061c0dae171">7dee0903b551b43e40bfa12aabce1061c0dae171</a>
-<blockquote>
-<p>
- Change &quot;GPL Ghostscript&quot; to &quot;Ghostscript&quot;<br>
-<br>
- and various other instances of GPL to APGL.<br>
-<br>
- Note that this means changing the product string (Postscript visible),<br>
- and all the Windows registry keys we use.<br>
-<br>
-base/gp_wgetv.c<br>
-base/gscdef.c<br>
-doc/Commprod.htm<br>
-doc/Install.htm<br>
-doc/Language.htm<br>
-doc/Make.htm<br>
-doc/Readme.htm<br>
-doc/Release.htm<br>
-doc/thirdparty.htm<br>
-psi/dwreg.c<br>
-psi/mkfilelt.cpp<br>
-psi/nsisinst.nsi<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-10 11:27:57 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7eda41b6392a09256447cccbe8b770717f5122f2">7eda41b6392a09256447cccbe8b770717f5122f2</a>
-<blockquote>
-<p>
- Remove the RECT_RECOVER and VMerror retrying logic from the clist<br>
-<br>
- The entire concept relies on recovery by being able to store an entire<br>
- page raster image somewhere when the clist writing gets a VMerror, but<br>
- if we have room for a page, we could have used page mode in the first<br>
- place and totally avoid clist complexity VMerrors. Rip this code out<br>
- to make the clist more readable and maintainable.<br>
-<br>
-base/gdevprn.c<br>
-base/gdevprn.h<br>
-base/gxcldev.h<br>
-base/gxclimag.c<br>
-base/gxclist.c<br>
-base/gxclist.h<br>
-base/gxclpath.c<br>
-base/gxclrect.c<br>
-base/gxclutil.c<br>
-devices/gdevbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-10 07:32:29 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a1c3ce81d35c869a2385c3f3e08250c484cfb2ab">a1c3ce81d35c869a2385c3f3e08250c484cfb2ab</a>
-<blockquote>
-<p>
- Remove all traces of the (probably bit-rotted) async renderer<br>
-<br>
- This has mostly been replaced by BGPrint and saved-pages (except for<br>
- a queue), but that will be added differently in the future.<br>
-<br>
-base/gdevprn.c<br>
-base/gdevprn.h<br>
-base/gdevprna.c<br>
-base/gdevprna.h<br>
-base/gxpageq.c<br>
-base/gxpageq.h<br>
-base/lib.mak<br>
-devices/devs.mak<br>
-devices/gdevbit.c<br>
-devices/gdevbmpa.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-11 14:56:47 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ce7245f9b4eb21af76310790ac0f1ec92e237e90">ce7245f9b4eb21af76310790ac0f1ec92e237e90</a>
-<blockquote>
-<p>
- Update PCL command line parser arg handling.<br>
-<br>
- Certain &quot;special&quot; params are interpreted directly by the pcl<br>
- build, and handled directly. (Namely, BATCH, NOPAUSE,<br>
- NOINTERPOLATE and NOCACHE).<br>
-<br>
- The current code can only cope with these being being used<br>
- with no argument. i.e. -dNOINTERPOLATE will be accepted, but<br>
- -dNOINTERPOLATE=1 will not trigger the no interpolation code.<br>
-<br>
- Here we change the code so that we now decide whether the arg is<br>
- a 'special' one or a normal param at the last moment, and<br>
- correctly raise errors if the values are set out of line.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-11 14:55:48 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f3703d439ebea68be96654e1f74f7e77c62eb823">f3703d439ebea68be96654e1f74f7e77c62eb823</a>
-<blockquote>
-<p>
- Fix error/warning in PCL build.<br>
-<br>
- return of a function returning void is not allowed in C,<br>
- even though it semantically makes sense.<br>
-<br>
-pcl/pcl/pcwhtidx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-11 17:50:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=df3d872f9e561a119eb29e7dcc25d0a466ea4a00">df3d872f9e561a119eb29e7dcc25d0a466ea4a00</a>
-<blockquote>
-<p>
- Decrement rather than free reference counted object<br>
-<br>
- Commit b9a265a02b7d1 fixed the unintialised reference count data for the<br>
- cie_joint_caches in a temporary gstate created during CIE to ICC conversion.<br>
-<br>
- I hadn't realised it was explicitly freed later on, rather than either<br>
- had the ref count decremented, or left to the default gstate freeing to deal<br>
- with. This was causing a C lib error on Windows, and a valgrind error on<br>
- Linux.<br>
-<br>
- Switching to using the reference counting machinery resolves the problem.<br>
-<br>
-base/gscie.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-10 15:55:50 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=684457fff0bb980c719cd40de63b6f322068d9ce">684457fff0bb980c719cd40de63b6f322068d9ce</a>
-<blockquote>
-<p>
- Add a specific licence comment to ramfs.h<br>
-<br>
-base/ramfs.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-09 17:12: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=7c247cba2ee612b61cad624cb4915d4dbfbb6ce0">7c247cba2ee612b61cad624cb4915d4dbfbb6ce0</a>
-<blockquote>
-<p>
- Further compensation for Freetype number representation<br>
-<br>
-base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-08 15:34: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=b259a1f93ad59636b9c95a57d86484e53aff47a6">b259a1f93ad59636b9c95a57d86484e53aff47a6</a>
-<blockquote>
-<p>
- Have configure add flag for AIX large file support<br>
-<br>
- AIX uses a different pre-preprocessor directive to enable access to the &gt;2Gb<br>
- file operations (fopen64 etc). Further, adding the AIX one in the same place<br>
- as the existing one (base/stdpre.h) does not work.<br>
-<br>
- So, have configure add -D_LARGE_FILES to the CFLAGS on AIX.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-04 19:12:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=63f74ce638cce033f724f42ec9393056c880e37f">63f74ce638cce033f724f42ec9393056c880e37f</a>
-<blockquote>
-<p>
- Preserve the clump has_refs flag.<br>
-<br>
- refs are handled specially by the garbager and during a restore operation, so<br>
- it's worth, during a save, restting the flag if no refs are left in a clump.<br>
-<br>
- *But*, for the garbager to work correctly, we *must* ensure the flag is set<br>
- when refs are still in a given clump.<br>
-<br>
-psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-08 12:34:28 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=12d4dd43bab634a24a4b602e799ea1e550ab769f">12d4dd43bab634a24a4b602e799ea1e550ab769f</a>
-<blockquote>
-<p>
- Fix global/local VM issue with gstate that b9a265a trips over.<br>
-<br>
- The commit to perform finalization cleanup of gstates had problems at<br>
- the alloc_restore_all when global memory was finalized because local<br>
- memory was already freed, but there was still &quot;savedinitalgstate&quot; in<br>
- systemdict that was in global VM but that had elements that were in<br>
- local VM.<br>
-<br>
- Also .forceundef savedinitialgstate in systemdict to avoid leaving<br>
- a pointer to localVM from systemdict. This isn't strictly needed<br>
- since systemdict isn't ever traced by restore_finalize.<br>
-<br>
-Resource/Init/gs_dps.ps<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-08 17:00: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=90c660a5e1d45bee0e15ee46bf9c54d19f3f635f">90c660a5e1d45bee0e15ee46bf9c54d19f3f635f</a>
-<blockquote>
-<p>
- pdfwrite - check return values<br>
-<br>
- picked up by scan-build, I carelessly forgot to check the return value<br>
- from pdf_add_resource.<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-08 13:19:50 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f7ffeb0319e112a1657987a9e5bad5b0f834a074">f7ffeb0319e112a1657987a9e5bad5b0f834a074</a>
-<blockquote>
-<p>
- pdfwrite - permit nested Forms in PDF output<br>
-<br>
- Bug #696986 &quot;Add support for nested PostScript forms as nested Form XObjects in pdfwrite&quot;<br>
-<br>
- Previously we checked for nested forms and 'unrolled' the child form(s)<br>
- into the parent PaintProc. However a simple extension (declaring the<br>
- child Form XObject(s) as Resources for the parent) permits us to have<br>
- nested forms.<br>
-<br>
- Note that the way our PostScript output (from ps2write) works, it is<br>
- not possible to support nested forms, so in this case we continue to<br>
- unroll the child PaintProc into the parent. The code works, despite<br>
- the inefficiency.<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-08 13:16: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=5f4319612f1837f89b9586a5695018d3554325d8">5f4319612f1837f89b9586a5695018d3554325d8</a>
-<blockquote>
-<p>
- PosScript interpreter - don't error on nested forms<br>
-<br>
- In commit fa20f5915978823a8c72a80e49fa90ce9c5c5879 I added code to check<br>
- if a Form PaintProc illegally left junk on the stack after execution<br>
- and cleaned it up if it did (issuing a warning).<br>
-<br>
- However, the code didn't cease checking when it found the first Form<br>
- dictionary, which meant that if there were two Form dictionaries on the<br>
- stack (nested forms) then we would throw an error.<br>
-<br>
- This commit simply terminates the loop when we find and check a Form<br>
- dictionary. If forms are nested then terminating the enclosing form will<br>
- lead it to check its own dictionary on the stack and so on.<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-27 19:48:39 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b9a265a02b7d1522fa56a353eb2bd0074ef3c715">b9a265a02b7d1522fa56a353eb2bd0074ef3c715</a>
-<blockquote>
-<p>
- Fix memory leak due to PDF interpreter DefaultQstate losing scope<br>
-<br>
- The graphics state is mostly tracked during gsave/grestore operations,<br>
- but the 'gstate' operator can result in a graphics state not being<br>
- freed until a garbage collection. Add a 'finalization' function for<br>
- gstates to deal with this.<br>
-<br>
- The alloc_restore_all function needs to do gs_grestoreall_for_restore<br>
- so that the gstates don't end up with dangling pointers, so pass the<br>
- interpreter context instead of the dual memory pointer so it can call<br>
- that function.<br>
-<br>
- Thanks to Chris for coming up with this approach to the 'finit' freeing,<br>
- and finding the fix for a SEGV due missing rc_init in gx_cie_to_xyz_alloc<br>
- that affected a couple of PS FTS files.<br>
-<br>
-base/gscie.c<br>
-base/gsicc_cache.c<br>
-base/gsstate.c<br>
-base/gxgstate.h<br>
-psi/imain.c<br>
-psi/int.mak<br>
-psi/isave.c<br>
-psi/isave.h<br>
-psi/zvmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-03 11:52:43 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=feaaad91269f7515692f911f29c93b3c4b6d0477">feaaad91269f7515692f911f29c93b3c4b6d0477</a>
-<blockquote>
-<p>
- Bug 696983 - Fix bidirectional XPS spacing.<br>
-<br>
- Bidirectional setting was not accounted for when advance width was set<br>
- in the XPS Indices Attribute.<br>
-<br>
-xps/xpsglyphs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-15 08:04:41 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af706ab3fafd2671d30fe82e4ebd431610c15d6c">af706ab3fafd2671d30fe82e4ebd431610c15d6c</a>
-<blockquote>
-<p>
- Fix Coverity ID 102148, buffer not terminated.<br>
-<br>
- Also, require the client to pass in a file name without spaces as a<br>
- routine precondition instead of trying to replace spaces with<br>
- underscores each time a font is built.<br>
-<br>
- Note gs_font_name is a ghostscript string with a size but also requires<br>
- null termination, see the typedef's header file.<br>
-<br>
-pcl/pcl/pglabel.c<br>
-pcl/pl/plfont.c<br>
-pcl/pl/pllfont.c<br>
-pcl/pl/plufont.c<br>
-pcl/pl/plulfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-03 16:33:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=deac5c942561bc044499987e86aa46eaa7abd495">deac5c942561bc044499987e86aa46eaa7abd495</a>
-<blockquote>
-<p>
- pdfwrite - don't complain about linearising encrypted files, when not linearinsing<br>
-<br>
-devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-11 10:36:27 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=093bd18bd923644fcd25c507088c0ebc63b4c320">093bd18bd923644fcd25c507088c0ebc63b4c320</a>
-<blockquote>
-<p>
- Support CompatibleOverprint in the interpreter (bug 696876)<br>
-<br>
- If the device is not a HighLevelDevice and the device supports<br>
- overprint (ProcessColorModel == /DeviceCMYK) then transparency needs<br>
- to treat painting operations differently by pushing a non-isolated,<br>
- non-knockout group and set the BlendMode to CompatibleOverprint.<br>
- Also the opacityalpha needs to be 1 during painting in this group.<br>
-<br>
- Note that although the interpreter now has code for fill, stroke,<br>
- 'sh' (shaded fills), text and images, our regression suite does<br>
- not seem to have OP with transparency for the 'sh' op (yet).<br>
- Out of all of our PDF test files, only 21 trigger this code<br>
- (including all of the PDF ATS files that are not run as part of<br>
- the commit regression tests.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-Resource/Init/pdf_main.ps<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-25 11:29:17 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=82e37a2d3309381ca55cde3a5515ab8aa61e3ebe">82e37a2d3309381ca55cde3a5515ab8aa61e3ebe</a>
-<blockquote>
-<p>
- Bug696876: Fix overprint blending when CompatibleOverprint mode not used.<br>
-<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-29 18:19:33 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc393ffc7b748c8f053eaf4028e8cf130fabbbf7">cc393ffc7b748c8f053eaf4028e8cf130fabbbf7</a>
-<blockquote>
-<p>
- Revised gx_subpath_is_rectangular.<br>
-<br>
- This copes with more cases. For a given rectangle A, B, C, D, the<br>
- original code coped with:<br>
-<br>
- Move A, Line B, Line C, Line D, close<br>
- Move A, Line B, Line C, Line D, Move E, ...<br>
- Move A, Line B, Line C, Line D, Line A<br>
- Move A, Line B, Line C, Line D, Line A, Close<br>
- Move A, Line B, Line C, Line D, Line A, Move E<br>
-<br>
- (and the flipped variants)<br>
-<br>
- We now cope with other cases including repeated corners:<br>
-<br>
- Move A, Line B, Line B, Line C, Line D, close<br>
-<br>
- etc<br>
-<br>
- and the case where the lines are curves that are really lines.<br>
-<br>
-base/gxpath.h<br>
-base/gxpath2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-08-01 10:34: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=1e214a7382f35f52ae1efe2b53169704913e4df5">1e214a7382f35f52ae1efe2b53169704913e4df5</a>
-<blockquote>
-<p>
- pdfwrite - don't coerce Dests from strings to names unless required<br>
-<br>
- Bug #696974 &quot;GS pdfwrite seems to break /GoToR's destination names /D&quot;<br>
-<br>
- We were always altering GoTo and GoToR Destinations from strings into<br>
- names, because string Dests are a PDF 1.2 feature. However its not<br>
- always possible to represent a string (eg Unicode) as a name.<br>
-<br>
- In this commit we don't try to force the Dest into a name unless the<br>
- PDF level is &lt; 1.2 and if we do try to coerce it, we check to see if it<br>
- can be represented. If not we throw an error and drop the Dest.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-29 17:06:47 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f885f6395594fc52c81075ebf7698ecd5bd09e6c">f885f6395594fc52c81075ebf7698ecd5bd09e6c</a>
-<blockquote>
-<p>
- Add some parentheses to clarify interpolation condition.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-29 17:06: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=ca7d98064b32f4ad216732dc1523016a67878b26">ca7d98064b32f4ad216732dc1523016a67878b26</a>
-<blockquote>
-<p>
- Include gximage.h for prototype of gx_image_compute_mat<br>
-<br>
-base/gsimage.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-29 15:48: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=7f8c86ebfc9efbb63df4898f15f93a705ff3ceaf">7f8c86ebfc9efbb63df4898f15f93a705ff3ceaf</a>
-<blockquote>
-<p>
- Remove Visual Debugger<br>
-<br>
-base/gdevddrw.c<br>
-base/gdevdsha.c<br>
-base/gdevm24.c<br>
-base/gdevmr8n.c<br>
-base/gdevp14.c<br>
-base/gsimage.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-base/gxclread.c<br>
-base/gxdtfill.h<br>
-base/gxfill.c<br>
-base/gxfillsl.h<br>
-base/gxfilltr.h<br>
-base/gxfillts.h<br>
-base/gxhintn.c<br>
-base/gxhintn1.c<br>
-base/gxi12bit.c<br>
-base/gximono.c<br>
-base/gxiscale.c<br>
-base/gxpath.c<br>
-base/gxpcopy.c<br>
-base/gxpflat.c<br>
-base/gxshade1.c<br>
-base/gxshade4.c<br>
-base/gxshade6.c<br>
-base/gxstroke.c<br>
-base/gzspotan.c<br>
-base/lib.mak<br>
-base/vdtrace.c<br>
-base/vdtrace.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plwmainc.c<br>
-psi/dmmain.c<br>
-psi/dwdll.c<br>
-psi/dwdll.h<br>
-psi/dwmain.c<br>
-psi/dwmainc.c<br>
-psi/dwnodll.c<br>
-psi/dwtrace.c<br>
-psi/dwtrace.h<br>
-psi/gsdll32.def<br>
-psi/gsdll32metro.def<br>
-psi/gsdll64.def<br>
-psi/gsdll64metro.def<br>
-psi/gsdllARM32metro.def<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-29 14:52:46 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d98f2adc027cd995b3c66e9dddd1d2fdad18e946">d98f2adc027cd995b3c66e9dddd1d2fdad18e946</a>
-<blockquote>
-<p>
- Remove pseudo_rasterization.<br>
-<br>
- I'ts not used any more, and is just extra complexity that we don't<br>
- need.<br>
-<br>
-base/gdevddrw.h<br>
-base/gxfdrop.c<br>
-base/gxfdrop.h<br>
-base/gxfill.c<br>
-base/gxfill.h<br>
-base/gxfilltr.h<br>
-base/gzspotan.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-29 13:26:39 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4639fe50f8037a35b981ed239aa5cdf1a30a19ed">4639fe50f8037a35b981ed239aa5cdf1a30a19ed</a>
-<blockquote>
-<p>
- Skip 0 length edges when filling.<br>
-<br>
- In theory, a zero length edge shouldn't make any difference<br>
- to the appearance of a path. In practice, they appear as<br>
- horizontal edges, and so can trip the code in gxfilltr.h that's<br>
- labelled as:<br>
-<br>
- /*<br>
- * This is a hack to make sure that isolated horizontal<br>
- * lines get stroked.<br>
- */<br>
-<br>
- That code is only called for !PSEUDO_RASTERIZATION.<br>
-<br>
- There is code in gxfill.c that ignores zero length edges, but<br>
- this is currently conditional on pseudo_rasterization being<br>
- turned on.<br>
-<br>
- As I understand it, PSEUDO_RASTERISATION is 1 when we are<br>
- plotting chars, and should never be so anymore. The idea is that<br>
- PSEUDO_RASTERISATION prevents dropouts in characters, hence it<br>
- feels wrong that any code that has this on should plot LESS than<br>
- code with it off.<br>
-<br>
- I suspect that Igor got the test the wrong way around here.<br>
-<br>
- I am just removing the test, and always ignoring 0 length edges.<br>
-<br>
-base/gxfill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-29 13:40: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=bd0df3ce9e72315f54d857f4de028da79412802f">bd0df3ce9e72315f54d857f4de028da79412802f</a>
-<blockquote>
-<p>
- Fix FirstPage/LastPage for non-PDF input<br>
-<br>
- Robin spotted this one. When I added the page ranges code to augment<br>
- the existing First/Last page functionality I moved the code which<br>
- decided whether an operation was destined for a page which was being<br>
- output into a single routine. Previously this was simple code which<br>
- was replicated in each method, but the added complexity meant it was<br>
- better handled centrally.<br>
-<br>
- However, when doing so I accidentally dropped the '-1' from the First<br>
- and Last Page tests (PageCount starts from 0) which meant these were<br>
- off by one throughout.<br>
-<br>
- Added these back in here.<br>
-<br>
-base/gdevflp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-26 20:31:06 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e901f44bdfcee1855378bdd6e26989fa294c8d5">8e901f44bdfcee1855378bdd6e26989fa294c8d5</a>
-<blockquote>
-<p>
- Fix DeviceGrayToK. Bug 696875<br>
-<br>
- By default we have -dDeviceGrayToK=true map all gray source<br>
- colors directly to the K channel when the Device is CMYK based.<br>
- This fix changes it so that Ghostscript matches Acrobat and<br>
- Distiller and does this mapping only if the source color<br>
- was truly defined as DeviceGray.<br>
-<br>
- The file in Bug 696875 has the property that it has a gray image<br>
- whose color space is DefaultGray, which references an ICC color<br>
- space. This color space was being treated as DeviceGray by<br>
- Ghostscript but it really should be color managed and not<br>
- treated as DeviceGray since it is ICC based.<br>
-<br>
- There are several progressions in the test suite assuming the<br>
- reference is Acrobat. The differences are caused by the fact<br>
- that gray sources that are not DeviceGray are now color<br>
- managed.<br>
-<br>
-base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-27 12:11: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=200b1450b99ec4f1d3b7356b8497ff57da5460f3">200b1450b99ec4f1d3b7356b8497ff57da5460f3</a>
-<blockquote>
-<p>
- Remove leftover debugging code (pstack)<br>
-<br>
-Resource/Init/pdf_rbld.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-27 08:54: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=a2e50179a29ffa30f332bd19ab7b0ca50e4bc933">a2e50179a29ffa30f332bd19ab7b0ca50e4bc933</a>
-<blockquote>
-<p>
- PDF interpreter - fix some typos<br>
-<br>
- Ray noticed that the (future proofing) code to handle a 're' inside<br>
- a text block had a typo. We haven't ever encountered such a thing, the<br>
- code is there so that when we do encoutner one it will just work.<br>
-<br>
- No differences expected.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-26 18:28: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=337167e66a8edf08fc65826afdcf62cede445dc1">337167e66a8edf08fc65826afdcf62cede445dc1</a>
-<blockquote>
-<p>
- Fix windows_debug_out.<br>
-<br>
- Simplified code that properly copes with strings longer than<br>
- 4096.<br>
-<br>
- Thanks to Ray for spotting the problem(s) with the last one.<br>
-<br>
-psi/dwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-25 17:57:56 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=016eeca9b2136d322d15f8add7bb207e61bfdb8c">016eeca9b2136d322d15f8add7bb207e61bfdb8c</a>
-<blockquote>
-<p>
- Fix Memento bug.<br>
-<br>
- When hunting for the block that contains a pointer, if we can't find<br>
- one, return NULL, not the unchanged pointer!<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-25 16:51: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=eb30a6927cf172c45bda4717a8bb8e21e7a5fe95">eb30a6927cf172c45bda4717a8bb8e21e7a5fe95</a>
-<blockquote>
-<p>
- Import latest Memento from MuPDF.<br>
-<br>
- Reintroduce the Memento_tick, and Mememto_event changes which haven't<br>
- made it to MuPDF yet.<br>
-<br>
-base/memento.c<br>
-base/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-25 17:57: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=2858aea017d933b2187d6eb5ac5718f0a45f3ca1">2858aea017d933b2187d6eb5ac5718f0a45f3ca1</a>
-<blockquote>
-<p>
- Fix silly mistake in Windows OutputDebugString code.<br>
-<br>
-psi/dwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-26 11:18: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=05bdaafd166a22797dc7f58e74d415081e00d469">05bdaafd166a22797dc7f58e74d415081e00d469</a>
-<blockquote>
-<p>
- PDF interpreter - handle PageLabels where the number tree starts with Kids<br>
-<br>
- Bug #696947 &quot;Regression: Error: /undefined in --run-- writing pdf file starting with 5784bfbfba7191cacce5309e88afac0851287460&quot;<br>
-<br>
- This is not really a regression, exactly. Prior to the commit noted<br>
- above we discarded PageLabels, the commit added the ability to preserve<br>
- these.<br>
-<br>
- However, we had a limited number of available files to test from, and<br>
- this particular file is the first one I have encountered where the<br>
- number tree defining the page ranges begins with a number tree node<br>
- which has /Kids but no /Nums (Table 3.34, p166 of the 1.7 specification<br>
- says that the Root node may have /Kids only if there are no /Nums)<br>
-<br>
- I did code to cope with this but there was a minor flaw in the code,<br>
- fixed here, which we lacked a test case for.<br>
-<br>
- Note that, although the specification says on p595 that the value of<br>
- the PageLabels entry in the Catalog is a number tree, this file neatly<br>
- exposes a probable bug in Acrobat. If the root of the number tree has<br>
- no /Nums, but does have /Kids (which is valid for a number tree, see<br>
- above) then Acrobat X does not display the PageLabels.<br>
-<br>
- This probably explains why we have never seen such a file before.<br>
-<br>
- For now I have chosen to permit the number tree to have /Kids, if in<br>
- the future we need to revise this to behave like Acrobat we can do so.<br>
-<br>
- This does have the interesting side effect that if the file is sent to<br>
- the pdfwrite device (and there is no other device which can use<br>
- PageLabels) the resulting PDF file will have working labels, where the<br>
- original does not.<br>
-<br>
- No differences expected<br>
-<br>
-Resource/Init/gs_pdfwr.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-22 15:44:43 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6f1da3c990ab7de4c3218bf8beff21f19449b284">6f1da3c990ab7de4c3218bf8beff21f19449b284</a>
-<blockquote>
-<p>
- Update PCL fonts and font table.<br>
-<br>
- Replace old URW fonts and update the font table with the new font<br>
- names.<br>
-<br>
-pcl/pl/plftable.h<br>
-pcl/urwfonts/A028-Ext.ttf<br>
-pcl/urwfonts/A028-Med.ttf<br>
-pcl/urwfonts/A030-Bol.ttf<br>
-pcl/urwfonts/A030-BolIta.ttf<br>
-pcl/urwfonts/A030-Ita.ttf<br>
-pcl/urwfonts/A030-Reg.ttf<br>
-pcl/urwfonts/Algiers-ExtraBold.ttf<br>
-pcl/urwfonts/Algiers-Medium.ttf<br>
-pcl/urwfonts/AntiqueOlive-Bol.ttf<br>
-pcl/urwfonts/AntiqueOlive-Bold.ttf<br>
-pcl/urwfonts/AntiqueOlive-Ita.ttf<br>
-pcl/urwfonts/AntiqueOlive-Italic.ttf<br>
-pcl/urwfonts/AntiqueOlive-Reg.ttf<br>
-pcl/urwfonts/AntiqueOlive-Regular.ttf<br>
-pcl/urwfonts/C011Condensed-Bold.ttf<br>
-pcl/urwfonts/C059-BdIta.ttf<br>
-pcl/urwfonts/C059-Bold.ttf<br>
-pcl/urwfonts/C059-Italic.ttf<br>
-pcl/urwfonts/C059-Roman.ttf<br>
-pcl/urwfonts/C093-Regular.ttf<br>
-pcl/urwfonts/CenturySchL-Bold.ttf<br>
-pcl/urwfonts/CenturySchL-BoldItal.ttf<br>
-pcl/urwfonts/CenturySchL-Ital.ttf<br>
-pcl/urwfonts/CenturySchL-Roma.ttf<br>
-pcl/urwfonts/ClarendonURW-BolCon.ttf<br>
-pcl/urwfonts/Coronet.ttf<br>
-pcl/urwfonts/D050000L.ttf<br>
-pcl/urwfonts/Dingbats.ttf<br>
-pcl/urwfonts/Garamond-Antiqua.ttf<br>
-pcl/urwfonts/Garamond-Halbfett.ttf<br>
-pcl/urwfonts/Garamond-Kursiv.ttf<br>
-pcl/urwfonts/Garamond-KursivHalbfett.ttf<br>
-pcl/urwfonts/GaramondNo8-Ita.ttf<br>
-pcl/urwfonts/GaramondNo8-Med.ttf<br>
-pcl/urwfonts/GaramondNo8-MedIta.ttf<br>
-pcl/urwfonts/GaramondNo8-Reg.ttf<br>
-pcl/urwfonts/LetterGothic-Bol.ttf<br>
-pcl/urwfonts/LetterGothic-Bold.ttf<br>
-pcl/urwfonts/LetterGothic-Ita.ttf<br>
-pcl/urwfonts/LetterGothic-Italic.ttf<br>
-pcl/urwfonts/LetterGothic-Reg.ttf<br>
-pcl/urwfonts/LetterGothic-Regular.ttf<br>
-pcl/urwfonts/Mauritius-Reg.ttf<br>
-pcl/urwfonts/Mauritius-Regular.ttf<br>
-pcl/urwfonts/NewDingbats.ttf<br>
-pcl/urwfonts/NimbusMonL-Bold.ttf<br>
-pcl/urwfonts/NimbusMonL-BoldObli.ttf<br>
-pcl/urwfonts/NimbusMonL-Regu.ttf<br>
-pcl/urwfonts/NimbusMonL-ReguObli.ttf<br>
-pcl/urwfonts/NimbusMono-Bol.ttf<br>
-pcl/urwfonts/NimbusMono-BolIta.ttf<br>
-pcl/urwfonts/NimbusMono-Bold.ttf<br>
-pcl/urwfonts/NimbusMono-BoldItalic.ttf<br>
-pcl/urwfonts/NimbusMono-Ita.ttf<br>
-pcl/urwfonts/NimbusMono-Italic.ttf<br>
-pcl/urwfonts/NimbusMono-Reg.ttf<br>
-pcl/urwfonts/NimbusMono-Regular.ttf<br>
-pcl/urwfonts/NimbusMonoPS-Bold.ttf<br>
-pcl/urwfonts/NimbusMonoPS-BoldItalic.ttf<br>
-pcl/urwfonts/NimbusMonoPS-Italic.ttf<br>
-pcl/urwfonts/NimbusMonoPS-Regular.ttf<br>
-pcl/urwfonts/NimbusRomNo9L-Medi.ttf<br>
-pcl/urwfonts/NimbusRomNo9L-MediItal.ttf<br>
-pcl/urwfonts/NimbusRomNo9L-Regu.ttf<br>
-pcl/urwfonts/NimbusRomNo9L-ReguItal.ttf<br>
-pcl/urwfonts/NimbusRoman-Bold.ttf<br>
-pcl/urwfonts/NimbusRoman-BoldItalic.ttf<br>
-pcl/urwfonts/NimbusRoman-Italic.ttf<br>
-pcl/urwfonts/NimbusRoman-Regular.ttf<br>
-pcl/urwfonts/NimbusRomanNo4-Bol.ttf<br>
-pcl/urwfonts/NimbusRomanNo4-BolIta.ttf<br>
-pcl/urwfonts/NimbusRomanNo4-Bold.ttf<br>
-pcl/urwfonts/NimbusRomanNo4-BoldItalic.ttf<br>
-pcl/urwfonts/NimbusRomanNo4-Italic.ttf<br>
-pcl/urwfonts/NimbusRomanNo4-Lig.ttf<br>
-pcl/urwfonts/NimbusRomanNo4-LigIta.ttf<br>
-pcl/urwfonts/NimbusRomanNo4-Regular.ttf<br>
-pcl/urwfonts/NimbusRomanNo9-Bold.ttf<br>
-pcl/urwfonts/NimbusRomanNo9-BoldItalic.ttf<br>
-pcl/urwfonts/NimbusRomanNo9-Ita.ttf<br>
-pcl/urwfonts/NimbusRomanNo9-Italic.ttf<br>
-pcl/urwfonts/NimbusRomanNo9-Med.ttf<br>
-pcl/urwfonts/NimbusRomanNo9-MedIta.ttf<br>
-pcl/urwfonts/NimbusRomanNo9-Reg.ttf<br>
-pcl/urwfonts/NimbusRomanNo9-Regular.ttf<br>
-pcl/urwfonts/NimbusSanL-Bold.ttf<br>
-pcl/urwfonts/NimbusSanL-BoldCond.ttf<br>
-pcl/urwfonts/NimbusSanL-BoldCondItal.ttf<br>
-pcl/urwfonts/NimbusSanL-BoldItal.ttf<br>
-pcl/urwfonts/NimbusSanL-Regu.ttf<br>
-pcl/urwfonts/NimbusSanL-ReguCond.ttf<br>
-pcl/urwfonts/NimbusSanL-ReguCondItal.ttf<br>
-pcl/urwfonts/NimbusSanL-ReguItal.ttf<br>
-pcl/urwfonts/NimbusSans-Bold.ttf<br>
-pcl/urwfonts/NimbusSans-BoldOblique.ttf<br>
-pcl/urwfonts/NimbusSans-Oblique.ttf<br>
-pcl/urwfonts/NimbusSans-Regular.ttf<br>
-pcl/urwfonts/NimbusSansNarrow-BdOblique.ttf<br>
-pcl/urwfonts/NimbusSansNarrow-Bold.ttf<br>
-pcl/urwfonts/NimbusSansNarrow-Oblique.ttf<br>
-pcl/urwfonts/NimbusSansNarrow-Regular.ttf<br>
-pcl/urwfonts/NimbusSansNo2-Bold.ttf<br>
-pcl/urwfonts/NimbusSansNo2-BoldItalic.ttf<br>
-pcl/urwfonts/NimbusSansNo2-Italic.ttf<br>
-pcl/urwfonts/NimbusSansNo2-Regular.ttf<br>
-pcl/urwfonts/P052-Bold.ttf<br>
-pcl/urwfonts/P052-BoldItalic.ttf<br>
-pcl/urwfonts/P052-Italic.ttf<br>
-pcl/urwfonts/P052-Roman.ttf<br>
-pcl/urwfonts/StandardSymL.ttf<br>
-pcl/urwfonts/StandardSymbolsPS.ttf<br>
-pcl/urwfonts/Symbols.ttf<br>
-pcl/urwfonts/U001-Bol.ttf<br>
-pcl/urwfonts/U001-BolIta.ttf<br>
-pcl/urwfonts/U001-Ita.ttf<br>
-pcl/urwfonts/U001-Reg.ttf<br>
-pcl/urwfonts/U001Con-Bol.ttf<br>
-pcl/urwfonts/U001Con-BolIta.ttf<br>
-pcl/urwfonts/U001Con-Ita.ttf<br>
-pcl/urwfonts/U001Con-Reg.ttf<br>
-pcl/urwfonts/URWBookman-Demi.ttf<br>
-pcl/urwfonts/URWBookman-DemiItalic.ttf<br>
-pcl/urwfonts/URWBookman-Light.ttf<br>
-pcl/urwfonts/URWBookman-LightItalic.ttf<br>
-pcl/urwfonts/URWBookmanL-DemiBold.ttf<br>
-pcl/urwfonts/URWBookmanL-DemiBoldItal.ttf<br>
-pcl/urwfonts/URWBookmanL-Ligh.ttf<br>
-pcl/urwfonts/URWBookmanL-LighItal.ttf<br>
-pcl/urwfonts/URWChanceryL-MediItal.ttf<br>
-pcl/urwfonts/URWClassicSans-Bold.ttf<br>
-pcl/urwfonts/URWClassicSans-BoldItalic.ttf<br>
-pcl/urwfonts/URWClassicSans-Regular.ttf<br>
-pcl/urwfonts/URWClassicSans-RegularIt.ttf<br>
-pcl/urwfonts/URWClassicSansCond-BdItalic.ttf<br>
-pcl/urwfonts/URWClassicSansCond-Bold.ttf<br>
-pcl/urwfonts/URWClassicSansCond-Italic.ttf<br>
-pcl/urwfonts/URWClassicSansCond-Regular.ttf<br>
-pcl/urwfonts/URWClassico-Bol.ttf<br>
-pcl/urwfonts/URWClassico-BolIta.ttf<br>
-pcl/urwfonts/URWClassico-Bold.ttf<br>
-pcl/urwfonts/URWClassico-BoldItalic.ttf<br>
-pcl/urwfonts/URWClassico-Ita.ttf<br>
-pcl/urwfonts/URWClassico-Italic.ttf<br>
-pcl/urwfonts/URWClassico-Reg.ttf<br>
-pcl/urwfonts/URWClassico-Regular.ttf<br>
-pcl/urwfonts/URWDings.ttf<br>
-pcl/urwfonts/URWGothic-Book.ttf<br>
-pcl/urwfonts/URWGothic-BookOblique.ttf<br>
-pcl/urwfonts/URWGothic-Demi.ttf<br>
-pcl/urwfonts/URWGothic-DemiOblique.ttf<br>
-pcl/urwfonts/URWGothicL-Book.ttf<br>
-pcl/urwfonts/URWGothicL-BookObli.ttf<br>
-pcl/urwfonts/URWGothicL-Demi.ttf<br>
-pcl/urwfonts/URWGothicL-DemiObli.ttf<br>
-pcl/urwfonts/URWPalladioL-Bold.ttf<br>
-pcl/urwfonts/URWPalladioL-BoldItal.ttf<br>
-pcl/urwfonts/URWPalladioL-Ital.ttf<br>
-pcl/urwfonts/URWPalladioL-Roma.ttf<br>
-pcl/urwfonts/Z003-MediumItalic.ttf<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-25 11:16: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=8fedc1d7a098481e6607ffb6ef4612f18b68ed95">8fedc1d7a098481e6607ffb6ef4612f18b68ed95</a>
-<blockquote>
-<p>
- High level devices - handle 12 BPC image data<br>
-<br>
- Bug #696944 &quot;Lockup with pdfwrite device&quot;<br>
-<br>
- This appears to be a bug of very long standing and points up our previous<br>
- lack of image test files in the cluster runs, since it hasn't emerged<br>
- before.<br>
-<br>
- The high level image stream code did not properly handle 12 bit data,<br>
- In s_compr_chooser__unpack_and_recognize() we ended up with 8 bits of<br>
- data remaining, which is not less than 8, but because the input size is<br>
- 12 bits it is also not &gt; the bits per sample. This led to an infinite<br>
- loop trying to read data at the end of a line.<br>
-<br>
- Here we change the '&lt;' to '&lt;=' to properly detect the end of input, so<br>
- we don't fall into this trap of assuming samples are 8 BPC.<br>
-<br>
-devices/vector/gdevpsds.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-14 15:29:23 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49ba79c5c27129cc0f47b150c49363b3ab3b1b63">49ba79c5c27129cc0f47b150c49363b3ab3b1b63</a>
-<blockquote>
-<p>
- Add support for -sPostRenderProfile=&quot;icc profile&quot; to tiffscaled devices<br>
-<br>
- With this commit, it is possible to have the tiffscaled32, tiffscaled24<br>
- and tiffscaled8 devices apply an ICC profile after rendering, which<br>
- will transform the rendered page to the color space defined by<br>
- PostRenderProfile. When used in conjunction with -dUsePDFX3Profile,<br>
- if the source file contains an Output Intent profile, the page will<br>
- be rendered first to the color space defined by the output intent profile and then<br>
- transformed to the color space defined by the PostRenderProfile setting. In this<br>
- way, we can avoid issues caused by mismatching ICC profiles in overprint<br>
- situations. This along with the commit http://git.ghostscript.com/?p=ghostpdl.git;a=commit;h=0df325b4bdbd037c92e2528fc16900de84f8d9c1<br>
- are needed to create a patch.<br>
-<br>
-base/gxdownscale.c<br>
-base/gxdownscale.h<br>
-devices/devs.mak<br>
-devices/gdevpng.c<br>
-devices/gdevtfnx.c<br>
-devices/gdevtifs.c<br>
-devices/gdevtifs.h<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-22 12:01:29 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d89f998d1008d693592f4c69ccf92085aa277060">d89f998d1008d693592f4c69ccf92085aa277060</a>
-<blockquote>
-<p>
- Send stdout/stderr to windows debug console too.<br>
-<br>
- When debugging in MSVC it's much easier to watch the output pane<br>
- rather than the terminal window.<br>
-<br>
-psi/dwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-21 16:26:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a3790308268f70e1be29eb8cca0c0e55711ef67">6a3790308268f70e1be29eb8cca0c0e55711ef67</a>
-<blockquote>
-<p>
- PDF interpreter - treat invalid BaseEncoding as a missing BaseEncoding<br>
-<br>
- Bug #696942 &quot;Missing content reading PDF file&quot;<br>
-<br>
- The file contains Encoding dictionaries which contain BaseEncoding<br>
- entries which are invalid, one is '/utf-8' the other is '/'. We already<br>
- checked for '/' and ignored it, and we already checked named Encodings<br>
- against the permissible list of Encodings, so here we just extend the<br>
- checks for BaseEncoding to see if a named BaseEncoding is in the list<br>
- pf permitted names.<br>
-<br>
- No differences expected.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-21 13:01: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=e5326d42115f162d906415bdf3b5cbcba1cb477d">e5326d42115f162d906415bdf3b5cbcba1cb477d</a>
-<blockquote>
-<p>
- Fix an inline function for storing 12-bit image data<br>
-<br>
- Bug #696940 &quot; crash with 12-bit type 3 images&quot;<br>
-<br>
- When I removed the 'load' and 'store' macros from the graphics library<br>
- code, replacing with static inline functions commit<br>
- d5008bf9092e99b5eb7f295c9d684850bf2aa66f I made an error. There was<br>
- a 'break' missed in the 12 bit store function.<br>
-<br>
- We should probably add image-qa.ps to our test files for the cluster.<br>
-<br>
-base/gsbitops.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-20 17:16:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=19931aea2fb8e6e72f58806836f0e769cd3139dd">19931aea2fb8e6e72f58806836f0e769cd3139dd</a>
-<blockquote>
-<p>
- Fix position of 'const' modifier<br>
-<br>
-base/genconf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-19 23:58:16 +0300
-</strong>
-<br>Boris Nagaev &lt;bnagaev@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3e5f8d3267e8abf3330da15fa6c159dd067bedc3">3e5f8d3267e8abf3330da15fa6c159dd067bedc3</a>
-<blockquote>
-<p>
- Fix the --disable-contrib option for out-of-tree builds<br>
-<br>
- The grep to exclude contrib/contrib.mak was not lenient enough to handle<br>
- srcdir!=dstdir.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-20 12:50: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=7795d6d4a30d923bd3c11f4dd27b86617c15f1bd">7795d6d4a30d923bd3c11f4dd27b86617c15f1bd</a>
-<blockquote>
-<p>
- Bug 696937: readhexstring handle signed/unsigned char<br>
-<br>
- When readhexstring runs out of data, we overload an integer ref with the<br>
- number of bytes from the input buffer used, and the value of a trailing<br>
- odd numbered byte shifted to the top 8 bits of the integer value. If no<br>
- trailing byte was read, the value is set to -1.<br>
-<br>
- When restarting readhexstring with a full buffer, we relied on casting to<br>
- char to retrieve the signed value from the top 8 bits on the integer ref.<br>
-<br>
- Unfortunately, unqualified chars are not signed on all platforms, and on<br>
- platforms where chars are unsigned, we ended up with an invalid value.<br>
-<br>
- So, have the casting use qualified (signed/unsigned) chars for writing and<br>
- reading back the value.<br>
-<br>
- To make this neater, and consistent, add an &quot;schar&quot; type to match the existing<br>
- &quot;uchar&quot; type.<br>
-<br>
-base/stdpre.h<br>
-psi/zfileio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-20 12:50:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49c7c0ec017baa0fe1708e185586859d9188dd2a">49c7c0ec017baa0fe1708e185586859d9188dd2a</a>
-<blockquote>
-<p>
- Remove some debugging code.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-20 11:38:09 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=97a2fc7002bbaecdaa9673fc59e0929d8f61e36b">97a2fc7002bbaecdaa9673fc59e0929d8f61e36b</a>
-<blockquote>
-<p>
- Silence warning.<br>
-<br>
-base/gsfunc0.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-19 15:20:53 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d512fd15d80625557c5a3c494d7a86b89ffa5bd3">d512fd15d80625557c5a3c494d7a86b89ffa5bd3</a>
-<blockquote>
-<p>
- Fix debug builds.<br>
-<br>
- Code I modified yesterday broke the debug printfs.<br>
-<br>
-psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-18 18:56:50 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e21bbf5f9ca6d0a75a18342cb951608ad072cddf">e21bbf5f9ca6d0a75a18342cb951608ad072cddf</a>
-<blockquote>
-<p>
- Bug 696837: Improve performance of memory searches.<br>
-<br>
- The swap to use splay trees reduces the performance of this<br>
- file from 11 seconds to 25 seconds for me.<br>
-<br>
- This is due to the additional complexity of traversing a<br>
- more complex memory structure. The hope is that in the average<br>
- case we'll do better (or at least no worse), and that we'll<br>
- make gains in more pathological cases.<br>
-<br>
- It turns out that in alloc_is_since_save I was failing to<br>
- actually make use of the fact that the new structure is<br>
- sorted and can hence be searched much more efficiently.<br>
-<br>
- Do that here. This gets performance back to 17 seconds - so<br>
- still a net loss, but less so.<br>
-<br>
-base/gsalloc.c<br>
-base/gxalloc.h<br>
-psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-18 18:53: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=702bc7f6b3f0634daae556a4a2c27fae44d80300">702bc7f6b3f0634daae556a4a2c27fae44d80300</a>
-<blockquote>
-<p>
- Fix stray result of global replace.<br>
-<br>
-base/gsalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-15 18:39:56 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0df325b4bdbd037c92e2528fc16900de84f8d9c1">0df325b4bdbd037c92e2528fc16900de84f8d9c1</a>
-<blockquote>
-<p>
- Add color management hooks for downscaler.<br>
-<br>
-base/gxdownscale.c<br>
-base/gxdownscale.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-18 10:03:24 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e7642ca7abdddc7fba5ab2a6450f1fc7dad62eb">2e7642ca7abdddc7fba5ab2a6450f1fc7dad62eb</a>
-<blockquote>
-<p>
- Fix 696933 interpreter exit.<br>
-<br>
- The PXL output device did not take into account transparency when<br>
- checking if the destination was needed.<br>
-<br>
-devices/devs.mak<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-18 13:03: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=00c81b3dd0dfd918168a56741c56920331890319">00c81b3dd0dfd918168a56741c56920331890319</a>
-<blockquote>
-<p>
- txtwrite - fix a conversion from bytes to shorts<br>
-<br>
- Bug 696935 &quot;SEGV in txtwrite&quot;<br>
-<br>
- When I modified the ToUnicode processing to return more than a single<br>
- code point for a given glyph, I altered the code to return a required<br>
- buffer size (or count of bytes copied). Txtwrite wanted a count of code<br>
- pints (always 2 bytes for ToUnicode) and so I should have divided the<br>
- return value by the size of a short. For some reason I multiplied it<br>
- instead, I have no idea what I was thinking of.....<br>
-<br>
- I couldn't reproduce a SEGV but since this was a buffer overrun problem<br>
- it would depend on the memory layout. With this fix the text is once<br>
- again sensible, and Robin reports the SEGV has gone away.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-15 09:00:05 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=03ef4a5345cf996270679bc3c3e9103991bd8d24">03ef4a5345cf996270679bc3c3e9103991bd8d24</a>
-<blockquote>
-<p>
- Fix previous commit that was missing most of the changes.<br>
-<br>
-base/gxacpath.c<br>
-base/gxclip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-12 14:55:28 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9c2d7369994b7b3c4b7204c7e6fe11b34e243037">9c2d7369994b7b3c4b7204c7e6fe11b34e243037</a>
-<blockquote>
-<p>
- Fix problems with commit fd34a32 (bug 696841) which transposed clip<br>
-<br>
- Even though the transposition of clip paths commit fd34a32 didn't<br>
- turn up any differences, it had problems, some spotted by desk check<br>
- and some as a result of testing the customer file and debug.<br>
-<br>
- First, the accum_fill_rectangle needs to transpose coordinates. Then<br>
- the clip device must transpose coordinates when comparing to rectangles<br>
- in the list. The clip_enumerate function and the procedures that open<br>
- code checks against rdev-&gt;current transpose the coordinates. If they<br>
- need to call clip_enumerate_rest it is with transposed values. The<br>
- coordinates in the ccdata structure are non-transposed.<br>
-<br>
- It was surprising when the previous commit didn't show any problems<br>
- (my trust in the regression test took a hit).<br>
-<br>
-base/gxclip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-14 18:54: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=762afc5e23d658345ac0484e9eeb0186d340803c">762afc5e23d658345ac0484e9eeb0186d340803c</a>
-<blockquote>
-<p>
- MSVC: Tweak makefile so .pdb files go in the obj directory<br>
-<br>
- This avoids them going at the top, and hence makes cleaning etc<br>
- easier.<br>
-<br>
-base/msvccmd.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-14 11:31: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=fd1b84560536076f655421e98a27e58d2881ca70">fd1b84560536076f655421e98a27e58d2881ca70</a>
-<blockquote>
-<p>
- XPS interpreter - fix 'synthetic bold' text style<br>
-<br>
- Bug 696914 &quot;Large black objects in output with pdfwrite device&quot;<br>
-<br>
- The problem here is that the XPS interpreter, when creating a synthetic<br>
- bold font, merely set the text rendering mode to 2 (fill and stroke),<br>
- assuming that the graphics library would deal with this.<br>
-<br>
- However, the graphics library does not care about text rendering modes<br>
- at all. The graphics state parameter is used only by the high level<br>
- devices and (apart from this instance) only be the PDF interpreter. When<br>
- the PDF interpreter encounters a text rendering mode other than 0 it<br>
- checks the device to see whether it wants text rendering modes preserved.<br>
- If it does, then the interpreter simply sets the mode and does nothing<br>
- else. If, however, the device does not want the mode preserved, then the<br>
- PDF interpreter breaks the text rendering mode into its component<br>
- operations.<br>
-<br>
- This commit adds the same functionality to the XPS interpreter. It seems<br>
- that the XPS interpreter only uses this for synthetic bold, and so only<br>
- uses Tr 2. So the code now checks with the device to see if it wants<br>
- the mode preserved, if it does, we simply leave it (but see below).<br>
- Otherwise, we stroke the text, and then draw it normally (fill). This<br>
- means that the artificial bold text is now actually drawn bold.<br>
-<br>
- There is one slight complication. When stroking a path the pdfwrite device<br>
- takes care to undo the scaling done by the CTM from the stroke width.<br>
- But when using a text render mode, it does not do so, it uses the<br>
- line width 'as is'. The XPS interpreter sets the line width including<br>
- the CTM (which is correct for stroking), so we need to 'undo' the CTM<br>
- applied to the line width before we draw the text, when we are preserving<br>
- the text rendering mode.<br>
-<br>
-xps/ghostxps.h<br>
-xps/xpsglyphs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-13 08:13:09 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d3ee57f5a57bb68d0693ca11fafdedd1f2249f5">1d3ee57f5a57bb68d0693ca11fafdedd1f2249f5</a>
-<blockquote>
-<p>
- Images of 0 area caused division by 0.<br>
-<br>
- We now let the default begin image procedure handle this case.<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-08 14:46:06 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c8342b4a7b6cdcc4cb1261bf2b008f6df257b5c6">c8342b4a7b6cdcc4cb1261bf2b008f6df257b5c6</a>
-<blockquote>
-<p>
- URW++ update to base 35 from June 2016.<br>
-<br>
- This extends the Greek and Cyrillic glyphs originally supplied in only three<br>
- font families to cover all the relevant fonts in the base 35.<br>
-<br>
- These remain covered by the GPL with the embedding exemption.<br>
-<br>
-Resource/Font/C059-BdIta<br>
-Resource/Font/C059-Bold<br>
-Resource/Font/C059-Italic<br>
-Resource/Font/C059-Roman<br>
-Resource/Font/CenturySchL-Bold<br>
-Resource/Font/CenturySchL-BoldItal<br>
-Resource/Font/CenturySchL-Ital<br>
-Resource/Font/CenturySchL-Roma<br>
-Resource/Font/D050000L<br>
-Resource/Font/Dingbats<br>
-Resource/Font/NimbusMono-Bold<br>
-Resource/Font/NimbusMono-BoldOblique<br>
-Resource/Font/NimbusMono-Oblique<br>
-Resource/Font/NimbusMono-Regular<br>
-Resource/Font/NimbusMonoPS-Bold<br>
-Resource/Font/NimbusMonoPS-BoldItalic<br>
-Resource/Font/NimbusMonoPS-Italic<br>
-Resource/Font/NimbusMonoPS-Regular<br>
-Resource/Font/NimbusRomNo9L-Med<br>
-Resource/Font/NimbusRomNo9L-MedIta<br>
-Resource/Font/NimbusRomNo9L-Reg<br>
-Resource/Font/NimbusRomNo9L-RegIta<br>
-Resource/Font/NimbusRoman-Bold<br>
-Resource/Font/NimbusRoman-BoldItalic<br>
-Resource/Font/NimbusRoman-Italic<br>
-Resource/Font/NimbusRoman-Regular<br>
-Resource/Font/NimbusSanL-Bol<br>
-Resource/Font/NimbusSanL-BolIta<br>
-Resource/Font/NimbusSanL-BoldCond<br>
-Resource/Font/NimbusSanL-BoldCondItal<br>
-Resource/Font/NimbusSanL-Reg<br>
-Resource/Font/NimbusSanL-RegIta<br>
-Resource/Font/NimbusSanL-ReguCond<br>
-Resource/Font/NimbusSanL-ReguCondItal<br>
-Resource/Font/NimbusSans-Bold<br>
-Resource/Font/NimbusSans-BoldOblique<br>
-Resource/Font/NimbusSans-Oblique<br>
-Resource/Font/NimbusSans-Regular<br>
-Resource/Font/NimbusSansNarrow-BdOblique<br>
-Resource/Font/NimbusSansNarrow-Bold<br>
-Resource/Font/NimbusSansNarrow-Oblique<br>
-Resource/Font/NimbusSansNarrow-Regular<br>
-Resource/Font/P052-Bold<br>
-Resource/Font/P052-BoldItalic<br>
-Resource/Font/P052-Italic<br>
-Resource/Font/P052-Roman<br>
-Resource/Font/StandardSymL<br>
-Resource/Font/StandardSymbolsPS<br>
-Resource/Font/URWBookman-Demi<br>
-Resource/Font/URWBookman-DemiItalic<br>
-Resource/Font/URWBookman-Light<br>
-Resource/Font/URWBookman-LightItalic<br>
-Resource/Font/URWBookmanL-DemiBold<br>
-Resource/Font/URWBookmanL-DemiBoldItal<br>
-Resource/Font/URWBookmanL-Ligh<br>
-Resource/Font/URWBookmanL-LighItal<br>
-Resource/Font/URWChanceryL-MediItal<br>
-Resource/Font/URWGothic-Book<br>
-Resource/Font/URWGothic-BookOblique<br>
-Resource/Font/URWGothic-Demi<br>
-Resource/Font/URWGothic-DemiOblique<br>
-Resource/Font/URWGothicL-Book<br>
-Resource/Font/URWGothicL-BookObli<br>
-Resource/Font/URWGothicL-Demi<br>
-Resource/Font/URWGothicL-DemiObli<br>
-Resource/Font/URWPalladioL-Bold<br>
-Resource/Font/URWPalladioL-BoldItal<br>
-Resource/Font/URWPalladioL-Ital<br>
-Resource/Font/URWPalladioL-Roma<br>
-Resource/Font/Z003-MediumItalic<br>
-Resource/Init/Fontmap.GS<br>
-psi/psromfs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-12 10:30:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a086f21714dbcb710d698bb2b47ac7a9e3ce89db">a086f21714dbcb710d698bb2b47ac7a9e3ce89db</a>
-<blockquote>
-<p>
- pdfwrite - fix PDF/X-3 Box emission when boes supplied via pdfmark<br>
-<br>
- Bug #696919 &quot; Wrong TrimBox and Metadata not allowed in PDF/X-3 conversion&quot;<br>
-<br>
- The code to calculate, check and emit the various Boxes when creating<br>
- PDF/X output relied upon the mediabox array contents being set. However<br>
- this array was initialised to 0, and not set correctly. I suspect this<br>
- has been altered at some time in the past, since we now use a temporary<br>
- array of floats (instead of doubles) to store and emit the MediaBox.<br>
-<br>
- The upshot of this is that we were writing just the differences from<br>
- the MediaBox instead of the full Box values.<br>
-<br>
- No differences expected, the cluster doesn't test PDF/X-3 creation<br>
-<br>
-devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-12 10:25: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=9f2e9ea89e35b4857ca06056ef978005bfae48bc">9f2e9ea89e35b4857ca06056ef978005bfae48bc</a>
-<blockquote>
-<p>
- Allow SubFileDecode filter to exceed 2GB<br>
-<br>
- Bug #696916 &quot;32-bit byte counter in /SubFileDecode&quot;<br>
-<br>
- Adopt the patch supplied by Alex Cherepanov, this allows a SubFileDeocde<br>
- filter to skip more than 2GB of data. I haven't tested Alex's file,<br>
- I'll assume it works for him.<br>
-<br>
- No differences in cluster testing.<br>
-<br>
-base/sfilter.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-12 00:25: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=08fb4a4997cf85a0f903f55f099e266d9ab70290">08fb4a4997cf85a0f903f55f099e266d9ab70290</a>
-<blockquote>
-<p>
- Fix landscape imagemask plotting.<br>
-<br>
- In commit 0fb16eb7 I implemented interpolation of imagemasks<br>
- for the non hl-color case. Unfortunately it appears I implemented<br>
- it badly.<br>
-<br>
- Thanks to Ray for spotting this and supplying the fix.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-11 16:54: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=344a80aab2e4ca48f4332c49f74560d56e739ad8">344a80aab2e4ca48f4332c49f74560d56e739ad8</a>
-<blockquote>
-<p>
- PDF interpreter - cope with Default* ColorSpace definitions in Forms<br>
-<br>
- Bug #696875 &quot; Differences in output - altona swatch p&quot;<br>
-<br>
- Our existing code for dealing with DefaultGray, DefaultRGB and DefaultCMYK<br>
- ColorSpace definitions is not great. It relies upon defining these as<br>
- ColorSpace resources, and setting UseCIEColor to true. When we then<br>
- set DevicGray, DeviceRGB or DeviceCMYK the PostScript code detects the<br>
- use of CIEColor and loads the corresponding 'Default' colour space<br>
- instead of loading the device space (NB the initial definitions are<br>
- identity, ie initally DefaultGray = DeviceGray)<br>
-<br>
- This was only done for Pages, not for Forms, and we now have examples<br>
- (test suite files) which use different Default* spaces in Forms.<br>
-<br>
- This code extends the detection of Default* spaces to Form XObjects<br>
- and turns on UseCIEColor if it finds any. DoForm now detects any such<br>
- spaces and defines appropriate ColorSpace resources. I would like to<br>
- put save/restore around the form to preserve any existing definitions,<br>
- but that causes the transparency code to seg fault. Instead we carefully<br>
- copy any existing definitions, and replace them after running the form.<br>
-<br>
- This show progressions in 2 files:<br>
- Altona_Technical_v20_x4.pdf<br>
- CATX9509.pdf<br>
-<br>
- The file Bug695948.pdf now times out. This is because of the crazy way<br>
- the file is constructed, it has forms nested 50 levels deep, only the<br>
- last one making any actual marks. Each form declares every preceding<br>
- form as a resource (which it need not do, only the form it actually<br>
- uses need be declared). This causes the code attempting to detect the<br>
- use of Default* colour spaces to take an extraordinarily long time. I've<br>
- decided to accept this as the price for getting the Altona file to work.<br>
-<br>
- In the long term we should rework the use of Default* colour spaces so<br>
- that the ICC manager is involved. This should ideally mean storing the<br>
- Default* spaces in the graphics state I think.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-08 10:23:11 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d619ee9816662b4264f6d9ca3be0045a42a7d61">0d619ee9816662b4264f6d9ca3be0045a42a7d61</a>
-<blockquote>
-<p>
- CompatibleOverprint blend mode addition (c-code)<br>
-<br>
- This adds support in the transparency code for providing proper<br>
- application of blending when we have overprint and transparency.<br>
- The description is in Section 7.6.3 of the spec. This is for<br>
- fixing Bug 696876. This does not complete the problem yet. We<br>
- have to add code in the interpreter side to invoke this blending mode<br>
- when overprint is enabled and we are painting elementary graphics objects<br>
- (fills, strokes, text, images, and shadings) (That is from the spec).<br>
-<br>
- If the blend mode is anything BUT Normal, the interpreter should<br>
- push a non-isolated non-knockout group prior to painting the object. The<br>
- blend mode should be set to BLEND_MODE_CompatibleOverprint. When<br>
- we pop the group, the blend mode should be restored to the non-Normal<br>
- blend mode for the group composition.<br>
-<br>
-base/gdevp14.c<br>
-base/gstparam.h<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-base/gxp1fill.c<br>
-base/gxpcolor.h<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-07 11:07:45 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=60195a79aff2a53662a471a59c2900c8435730f6">60195a79aff2a53662a471a59c2900c8435730f6</a>
-<blockquote>
-<p>
- Improve performance for interpolated landscape images (bug 696841)<br>
-<br>
- There was a comment that indicated that doing landscape runs was not<br>
- worthwhile, but on the customer's test file it improved peformance by<br>
- 40%.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-05 08:57:24 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fd34a32b0fd8f6d38f26c464b3a4efa6fdc37a56">fd34a32b0fd8f6d38f26c464b3a4efa6fdc37a56</a>
-<blockquote>
-<p>
- Improve performance of landscape masks for bug 696841.<br>
-<br>
- Since the clip list accumulator is optimized for x-major entry of rects,<br>
- if we know the information is y-major, as for landscape imagemasks, then<br>
- transpose X and Y in the list, and similarly transpose back when doing<br>
- the clip_enumeration bounds checking and calling the target operation<br>
- (process function).<br>
-<br>
- This improves the processing of the customer's file from 1900 seconds to<br>
- 96 seconds!<br>
-<br>
- So far only landscape imagemask clip path accumulation uses this. TBD<br>
- is to evaluate if any other uses of the clip path accum device can take<br>
- advantage of this transposition.<br>
-<br>
-base/gsimage.c<br>
-base/gxacpath.c<br>
-base/gxclip.c<br>
-base/gxclrast.c<br>
-base/gxcpath.c<br>
-base/gxcpath.h<br>
-base/gximage.h<br>
-base/gximask.c<br>
-base/gximask.h<br>
-base/gxipixel.c<br>
-base/gzacpath.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-06 13:59: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=ab8f19f34d7c2b1ea7d1a853bc9fa74f58bf49e2">ab8f19f34d7c2b1ea7d1a853bc9fa74f58bf49e2</a>
-<blockquote>
-<p>
- Extend the -sSourceObjectICC to include gray ICC profiles<br>
-<br>
- This makes it possible to specify overriding gray ICC profiles<br>
- for gray color spaces as specified in the file referenced by<br>
- -sSourceObjectICC. The notation is similar to that described<br>
- for the RGB and CMYK color spaces in the color document.<br>
- Fixes Bug 696834.<br>
-<br>
-base/gscms.h<br>
-base/gsicc_cache.c<br>
-base/gsicc_manage.c<br>
-base/gsicc_manage.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-06 10:52:49 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8387d9f2cb6f77dca2b12d87f865a28dd52a9840">8387d9f2cb6f77dca2b12d87f865a28dd52a9840</a>
-<blockquote>
-<p>
- Add support to create threshold profiles for input color spaces<br>
-<br>
- This adds the ability to the ICC Creator tool in toolbin/color<br>
- to create ICC profiles that will threshold to neutral CIELAB<br>
- values of black or white. You can specify the L* point at<br>
- which to apply the transition. The input curve treats the device values as<br>
- having the traditional sRGB like gamma. This is work toward dealing<br>
- with the enhancement in Bug 696834<br>
-<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_Creator.rc<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.h<br>
-toolbin/color/icc_creator/ICC_Creator/icc_create.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/icc_create.h<br>
-toolbin/color/icc_creator/ICC_Creator/resource.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-05 10:17:48 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e9b54d14d939bd038bfddc745ea765cb970c9edb">e9b54d14d939bd038bfddc745ea765cb970c9edb</a>
-<blockquote>
-<p>
- Fix force_interpolation to work properly with interpolation threshold<br>
-<br>
- If the scaling was less than the threshold, interpolation would be skipped<br>
- even if it had been forced by logic in gxipixel.c. Also skip interpolation<br>
- if it doesn't do anything (Width and Height In == Out).<br>
-<br>
-base/gxidata.c<br>
-base/gximage.h<br>
-base/gxipixel.c<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-05 09:31:00 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cdbf67714cddad97b2cad46adc56c648764be733">cdbf67714cddad97b2cad46adc56c648764be733</a>
-<blockquote>
-<p>
- Use fixed_epsilon to detect downscale for force_interpolation of patterns<br>
-<br>
- PCL uses patterns (a lot) but due to rounding patterns intended to be 1:1<br>
- scale end up as slightly less (grasshop.pcl) so interpolation would be<br>
- forced.<br>
-<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-04 14:25:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f342b3bdf81308ff3ce90381ec741a1b0f25ed0c">f342b3bdf81308ff3ce90381ec741a1b0f25ed0c</a>
-<blockquote>
-<p>
- pdfwrite - fix an off-by-1 error copying extension metadata<br>
-<br>
- We were copying one byte too few from the supplied string. Take the<br>
- opportunity to optimise the size of the allocated data at the same<br>
- time. Its only 1 byte, but still.....<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-04 10:26: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=810ce1e302af7d12e08650ccf0d88407b04a0d46">810ce1e302af7d12e08650ccf0d88407b04a0d46</a>
-<blockquote>
-<p>
- PDF interpreter - cope with missing parameters in Destinations<br>
-<br>
- The PDF specification says that certain elements in Destinations can<br>
- be 'null' but doesn't say that this actually means 'missing'.<br>
-<br>
- Commit b4fc7327fa0c792a7b218610b86d9fa4533d3e0b added support for this<br>
- in XYZ Dests, this commit adds support for FitH, FitV, FitBH and FitBV<br>
- Dests completing the variations. Note that the spec says that 'null'<br>
- values for FitR have 'undefined results' so we just throw those away<br>
- still.<br>
-<br>
- No differences expected.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-07-04 08:13: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=389657cf69b2a9c612442c8222236e3ce6f869ca">389657cf69b2a9c612442c8222236e3ce6f869ca</a>
-<blockquote>
-<p>
- PDF interpreter - handle ToUnicode CMaps with large ranges<br>
-<br>
- The CMap reading code did not cope with range entries which spanned<br>
- more than 255 indices in a single range, it assumed there would never<br>
- be more than this and only used a single byte for the key values.<br>
-<br>
- Fixing that revealed that the ToUnicode generation (from the decoded<br>
- CMap) also assumed that a range would never span more than 255 indices.<br>
- This was a little more complex to fix.<br>
-<br>
- This commit should allow arbitrary length ranges, even though the<br>
- ToUnicode specification currently limits the keys to 0-65536. This is<br>
- not tested by cluster runs, but appears to work with all the problematic<br>
- ToUnicode files I can find on a quick sweep through Git.<br>
-<br>
-Resource/Init/gs_cmap.ps<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-30 16:31: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=bbb684bc346851cb08d615048c9f50c106ec1fe4">bbb684bc346851cb08d615048c9f50c106ec1fe4</a>
-<blockquote>
-<p>
- add per-page annotation detection to pdf_info.ps<br>
-<br>
-toolbin/pdf_info.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-24 09:14:43 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7dca388d4b952357c931f52b4bb16dee76cea01e">7dca388d4b952357c931f52b4bb16dee76cea01e</a>
-<blockquote>
-<p>
- Minor changes to clusterpush.pl and improvements in its documentation.<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-toolbin/localcluster/clusterpush.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-24 10:28: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=fd75e1678500f1ba60296ddf8fbb17e60aedcd6d">fd75e1678500f1ba60296ddf8fbb17e60aedcd6d</a>
-<blockquote>
-<p>
- Match Acrobat's use of AutoRotatePages and DSC<br>
-<br>
- When AutoRotatePages is set to anything except /None Acrobat will<br>
- honour DSC Orientation comments and use them in preference to the<br>
- heuristically determined value, which we weren't doing.<br>
-<br>
- This commit matches Acrobat, including the ability to have the heuristic<br>
- override the DSC comments by setting -dParseDSCComments=false.<br>
-<br>
- The documentation is updated and now correct, including mentioning that<br>
- the heuristic can be preferred by turning off DSC parsing.<br>
-<br>
- A few files (7) show a difference because of different orientation<br>
- with the pdfwrite device.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-23 09:09: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=75e76c19392457f442d10770f6096a558fe6befc">75e76c19392457f442d10770f6096a558fe6befc</a>
-<blockquote>
-<p>
- remove memcmp() of structures from zfont1.c<br>
-<br>
- Bug 696863 &quot;memcmp() in zfont1.c&quot;<br>
-<br>
-psi/zfont1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-22 16:36:20 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ce6369cb89453e75f1915e6f520a19c49a4096b">5ce6369cb89453e75f1915e6f520a19c49a4096b</a>
-<blockquote>
-<p>
- Flip cups files right side up in bmpcmp.c.<br>
-<br>
-toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-22 18:15:55 +0100
-</strong>
-<br>Brian Norris &lt;computersforpeace@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d54d8d529fdc9515068384c6262f321bec06bf5f">d54d8d529fdc9515068384c6262f321bec06bf5f</a>
-<blockquote>
-<p>
- Bug 696843: poor dependencies for install target<br>
-<br>
- The dependencies for the install target were poorly specified causing them<br>
- to sometimes fail when called in a parallel make.<br>
-<br>
-contrib/contrib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-22 18:12:34 +0100
-</strong>
-<br>Brian Norris &lt;computersforpeace@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=832c32645075dcd93e8e448ec012241f79edac17">832c32645075dcd93e8e448ec012241f79edac17</a>
-<blockquote>
-<p>
- Fix use of shell built-in 'trap'<br>
-<br>
- In instcopy we use the shell built-in 'trap' so that if anything goes wrong<br>
- in the copying process, we ensure cleanup afterwards. But we only setup the<br>
- trap *after* we'd started copying stuff.<br>
-<br>
- It was *probably* okay, but is safer and cleaner this way.<br>
-<br>
- Noticed in passing looking at Bug 696843.<br>
-<br>
-base/instcopy<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-22 10:00:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d278f6a3b8b7baecbe23d7fa40de1164fd67e63e">d278f6a3b8b7baecbe23d7fa40de1164fd67e63e</a>
-<blockquote>
-<p>
- More TTF post table wranglings<br>
-<br>
- The original TTF spec listed name table indices between 32768 and 65536 as<br>
- &quot;reserved for future use&quot;. The latest OTF spec (1.60) has indices up to and<br>
- including 63335 as valid.<br>
-<br>
- So, tweak our post table handling to cope.<br>
-<br>
- Since numGlyphs is a unsigned short (16 bit) number, there is no point checking<br>
- for the upper limit of value, now, so that check is dropped.<br>
-<br>
- Also, since we pre-process the requested indices to ascertain the largest index<br>
- we have to deal with, and if the number of names is less than that, fill the<br>
- remainder of the array with /.notdef names, we can also drop the explicit check<br>
- for indices beyond the available names.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-21 14:39: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=b4fc7327fa0c792a7b218610b86d9fa4533d3e0b">b4fc7327fa0c792a7b218610b86d9fa4533d3e0b</a>
-<blockquote>
-<p>
- pdfwrite - cope with missing optional arguments in /XYZ Dests<br>
-<br>
- Bug 696838 &quot;Preserve /Dests when not named&quot;<br>
-<br>
- Well it seems that 3 of the arguments for an XYZ Destination are<br>
- optional and may be omitted, using the current setting instead. The<br>
- link destination code wasn't catering for that.<br>
-<br>
- This commit checks the number of arguments in the array, throws errors<br>
- when there are too many or not enough, and replaces missing optional<br>
- values with 'null' which is equivalent and doesn't break the code.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-20 16:29:21 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f3ed5db0fff13a4f2262e1d203ac6444df196c5d">f3ed5db0fff13a4f2262e1d203ac6444df196c5d</a>
-<blockquote>
-<p>
- Bug 696824 (redux): post table handling<br>
-<br>
- It turns out that it is valid for the number of entries in the post table's name<br>
- list to be larger than the number of glyph indices used in the font (for what<br>
- purpose, I cannot fathom).<br>
-<br>
- Worse, the number of entries in the name list is not declared anywhere, so the<br>
- only option is to pre-process to recover it. In fact, we pro-process the list<br>
- of indices (rather than the list of names) and note the highest reference -<br>
- this is more efficient as the indices are short, and fixed length values, where<br>
- names tend to longer, and of variable length.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-19 10:59:25 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6aff224d35988db9a388eee4ddd849eee18bd9d6">6aff224d35988db9a388eee4ddd849eee18bd9d6</a>
-<blockquote>
-<p>
- Fix clist_dev_spec_op forwarding when the device is pattern-clist<br>
-<br>
- Detected while investigating bug 696841, but it doesn't help with the<br>
- performance issue. It would cause gridfitting and forced interpolation<br>
- to be different for patterns accumulated to a bitmap compared to those<br>
- that used the pattern-clist.<br>
-<br>
-base/gxclrect.c<br>
-base/gxpcmap.c<br>
-base/gxpcolor.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-18 10:21: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=9744319ca8e8f55fa2b8e146557e2b146deb6f1b">9744319ca8e8f55fa2b8e146557e2b146deb6f1b</a>
-<blockquote>
-<p>
- Coverity ID 94756 - add a 'fall through' comment<br>
-<br>
-base/gxshade4.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-18 09:30:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9484cc1d16b50f506bcea80030cffc442e46d717">9484cc1d16b50f506bcea80030cffc442e46d717</a>
-<blockquote>
-<p>
- pdfwrite - test a return code to silence a scan-build warning.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-17 18:12: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=e64d0620193b05d57f37d2deceac965ec5114e67">e64d0620193b05d57f37d2deceac965ec5114e67</a>
-<blockquote>
-<p>
- pdfwrite - don't compress data from Metadata pdfmark when output is PDF/A<br>
-<br>
- Bug 696864 &quot;Metadata stream should not be compressed, when using a pdfmark&quot;<br>
-<br>
- This turned out to be rather more complex than expected. The stream is<br>
- constructed via a pdfmark before we add the 'Metadata' key to its<br>
- dictionary. This means that at the time we create the stream, we don't<br>
- know that it should not be compressed, so we open it with compression<br>
- filters added.<br>
-<br>
- We can't throw away the stream we have at the time data is written to<br>
- it, because we've written keys to its associated dictionary. Also that<br>
- would generate a new object number leaving an unused object in the xref<br>
- which is legal but undesirable.<br>
-<br>
- This means that we either have to defer the compression filters<br>
- until we write to the file, or close the compression filters when we see<br>
- the Metadata. Ideally I'd like to do the former, but I wasn't able to<br>
- prove categorically that there was no other code path leading to a<br>
- pdfmark-created stream which would evade the checks.<br>
-<br>
- So I've chosen to discard the existing compressed stream when we find<br>
- a /Metadata pdfmark, and create a new uncompressed stream for the<br>
- stream object. This means also deleting the Filter and DecodeParams<br>
- entries from the dictionary, if present.<br>
-<br>
- Finally, there has for some time been an icky hack in the code where we<br>
- overload the meaning of 'CompressFonts' to determine whether to compress<br>
- all streams outside of page streams (which are controlled with<br>
- CompressPages). This commit also adds the new debugging switch<br>
- CompressStreams which, if set to false (default is true) will not<br>
- compress streams other than Fonts or Pages, which still retain their<br>
- existing controls.<br>
-<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdfm.c<br>
-devices/vector/gdevpdfp.c<br>
-devices/vector/gdevpdfx.h<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-14 18:26:18 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c889ceed3b9a78da16ea2387f3b8029e25aa15b">3c889ceed3b9a78da16ea2387f3b8029e25aa15b</a>
-<blockquote>
-<p>
- Memento: Add Memento_tick()<br>
-<br>
- Sometimes it can be useful to be able to run a program<br>
- repeatedly and stop it at a given place, just before a<br>
- problem occurs.<br>
-<br>
- Suppose you know that the problem occurs in the 'foo'<br>
- function, but only after a number of runs.<br>
-<br>
- Insert a call to Memento_tick() at the top of foo, rebuild<br>
- and run in the debugger. When the problem occurs, consult<br>
- memento.sequence to see what event number we are on;<br>
- suppose it's 1000.<br>
-<br>
- Then you can rerun the debugger with breakpoints on Memento_inited<br>
- and Memento_breakpoint. When the program stops at Memento_inited,<br>
- call Memento_breakAt(1000) and continue execution. The program<br>
- will then stop in Memento_breakpoint within the Memento_tick<br>
- call just before the problem occurs, enabling you to step forward<br>
- and see what goes wrong.<br>
-<br>
-base/memento.c<br>
-base/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-02 19:31:27 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3bc51652cc962f0256acdf37f52d0a7d98b20ed1">3bc51652cc962f0256acdf37f52d0a7d98b20ed1</a>
-<blockquote>
-<p>
- Bobbin: Add first version of Bobbin.<br>
-<br>
- A simple tool to help debug performance problems with<br>
- threads.<br>
-<br>
- Build with BOBBIN defined, and all pthreads calls (or at<br>
- least all the ones gs uses) go through Bobbin. This keeps<br>
- track of the time each threads spends waiting on mutexes<br>
- or condition variables.<br>
-<br>
- Hopefully this allows contention to be spotted.<br>
-<br>
- A report is printed at the end.<br>
-<br>
-base/bobbin.c<br>
-base/bobbin.h<br>
-base/gdevprn.c<br>
-base/gp_psync.c<br>
-base/gpsync.h<br>
-base/gsicc_cache.c<br>
-base/gsicc_lcms2.c<br>
-base/gsicc_manage.c<br>
-base/gsmalloc.c<br>
-base/gxclthrd.c<br>
-base/gxsync.c<br>
-base/gxsync.h<br>
-base/lib.mak<br>
-base/malloc_.h<br>
-base/memento.h<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-14 15:33:46 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b3cea386ef8ebc24198963a26c90ad33dc1f8f07">b3cea386ef8ebc24198963a26c90ad33dc1f8f07</a>
-<blockquote>
-<p>
- Bug 696833: Use sane way to identify fill/stroke in a glyph<br>
-<br>
- There was a highly unreliable hack used in the do_fill() and do_stroke()<br>
- functions in order to the set the object type tag between line art and<br>
- text.<br>
-<br>
- This uses a more robust solution<br>
-<br>
-base/gspaint.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-14 08:33:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f3b34d04f6c7b58375582a6b46abb024a0bb0ab0">f3b34d04f6c7b58375582a6b46abb024a0bb0ab0</a>
-<blockquote>
-<p>
- Clarify description comment in gdevmiff.c<br>
-<br>
-devices/gdevmiff.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-14 16:29: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=53d35a364f99dc2353104cfec0c684a062034456">53d35a364f99dc2353104cfec0c684a062034456</a>
-<blockquote>
-<p>
- pdfwrite - move linearisation records to non-GC memory<br>
-<br>
- Bug 696832 &quot;crashes on Windows server 2012 R2&quot;<br>
-<br>
- This seems to be because the pointer enumeration was messed up and<br>
- we didn't enumerate the 'PageList' at all, causing some spectacular<br>
- faults in Garbage collection, because linearization only occurs when<br>
- closing the device, which means we always do GC beforehand and move<br>
- all the pointers.<br>
-<br>
- The simples solution is just to move the records to non-GC memory, there<br>
- is no reason for these to be tracked by the garbage collector.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-14 10:01: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=d6c70b021c6dd2ee20dfdbd82b4bbfc213b1c64a">d6c70b021c6dd2ee20dfdbd82b4bbfc213b1c64a</a>
-<blockquote>
-<p>
- pdfwrite - fix octal escapes in Ext_Matadata pdfmark processing<br>
-<br>
- Bug #696830 &quot;Ext_Metadata pdfmark — does it work with general UTF-8 text string?&quot;<br>
-<br>
- The code for undoing octal escapes in the Ext_Metadata pdfmark<br>
- processing code did not subtract 0x30 (ASCII '0') from bytes before<br>
- converting them to binary, resulting in incorrect data.<br>
-<br>
- Thanks to Ross Moore for finding the problem and tracking down the fix.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-13 12:38: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=aeabbe1b9bfbcc3a2214c030aa5c77910112e021">aeabbe1b9bfbcc3a2214c030aa5c77910112e021</a>
-<blockquote>
-<p>
- ps2write - permit image downsampling<br>
-<br>
- For inline images we set up 'lossless' filters, which use lossless<br>
- compression, but also disable downsampling.<br>
-<br>
- This seems wrong for pdfwrite, and because ps2write always uses inline<br>
- images, means that downsampling wasn't working at all for ps2write.<br>
-<br>
- This commit alters the lossless filters to allow for image downsampling<br>
- even when inline. At the same time we change the ps2write defaults to<br>
- not downsample color images, so that we don't see a change in behaviour.<br>
-<br>
-Resource/Init/gs_pdfwr.ps<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpsdf.h<br>
-devices/vector/gdevpsdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-11 16:47: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=2fc20e2ff73b0d015f7aab9f5bc2df0e11361536">2fc20e2ff73b0d015f7aab9f5bc2df0e11361536</a>
-<blockquote>
-<p>
- Update LZW decode to cope with TIFF 5.0 streams.<br>
-<br>
- The LZW decoder used in TIFF 5.0 streams is not as strict as<br>
- normal LZW. When we hit the maximum number of codes we do not<br>
- expect a CLEAR code immediately.<br>
-<br>
-base/slzwd.c<br>
-base/slzwx.h<br>
-xps/xpstiff.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-13 08:46: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=aa55104b991e14e142267f85bb2695a59481cff0">aa55104b991e14e142267f85bb2695a59481cff0</a>
-<blockquote>
-<p>
- Coverity ID 127203 don't test variable<br>
-<br>
- The variable pgs must be valid, if it isn't we would already have<br>
- seg faulted, so there's no point testing it.<br>
-<br>
- Not sure why coverity suddenly started detecting this, I don't<br>
- believe the code has changed.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-13 08:45:21 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5eaeba97a259aca8057c48e0dc130ae7182a6bcf">5eaeba97a259aca8057c48e0dc130ae7182a6bcf</a>
-<blockquote>
-<p>
- Coverity ID 94741 add a 'fall through' comment to a switch<br>
-<br>
-devices/gdevupd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-09 19:11:40 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c1ea03762b602589acc27b8cea330ae99596edc4">c1ea03762b602589acc27b8cea330ae99596edc4</a>
-<blockquote>
-<p>
- Improve splay tree handling in clumps.<br>
-<br>
- The code walks the splay tree of clumps in 3 main ways.<br>
-<br>
- Firstly it can do an inorder traversal of the tree, from<br>
- min to max. We call this a &quot;forward&quot; traversal.<br>
-<br>
- Secondly it can do a reverse-inorder traversal of the tree,<br>
- from max to min. We call this a &quot;backward&quot; traversal.<br>
-<br>
- Finally, and most commonly, it can do an inorder traversal<br>
- of the tree, from an arbitrary starting position, so that when<br>
- it hits the max, the calling code can restart it from the min.<br>
-<br>
- This latter behaviour was nastily implemented, requiring the<br>
- callers to jump through hoops. I think that some of the callers<br>
- had been getting it wrong, resulting in incomplete traversals<br>
- of the tree.<br>
-<br>
- We implement a nicer version here, where the logic for looping<br>
- from max to min, and stopping when we reach the start position<br>
- is neatly encapsulated in the tree handling.<br>
-<br>
- We also update the clump sanity checking and call it in more<br>
- places.<br>
-<br>
- This seems to fix the stale pointer problem that Ray has<br>
- encountered, presumably because clumps are correctly freed<br>
- now.<br>
-<br>
-base/gsalloc.c<br>
-base/gxalloc.h<br>
-psi/igc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-10 09:49: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=99e331527d541a8f01ad5455c4eb2aabd67281a6">99e331527d541a8f01ad5455c4eb2aabd67281a6</a>
-<blockquote>
-<p>
- Fix .locksafe<br>
-<br>
- Apparently we need to .forceput the definition of getenve into<br>
- systemdict, at least when running GSView 5.0.<br>
-<br>
- Discovered when trying to investigate a customer bug report using<br>
- GSView 5.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-09 08:50: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=0d4644c003067fc14ca1db9c600dce420c06e6b1">0d4644c003067fc14ca1db9c600dce420c06e6b1</a>
-<blockquote>
-<p>
- Add strlcpy and strlcat to ghostscript.<br>
-<br>
- Adds the FreeBsd implementation of the safer string functions. These<br>
- replace the xps implementations which did not have proper source<br>
- acknowledgment.<br>
-<br>
-base/gsstrl.c<br>
-base/gsstrl.h<br>
-base/lib.mak<br>
-base/string_.h<br>
-xps/ghostxps.h<br>
-xps/xpscolor.c<br>
-xps/xpsdoc.c<br>
-xps/xpsimage.c<br>
-xps/xpsmem.c<br>
-xps/xpspage.c<br>
-xps/xpsresource.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-07 16:16:40 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f0cca98368f5dd21dcbc79cae3247b57a88236c">8f0cca98368f5dd21dcbc79cae3247b57a88236c</a>
-<blockquote>
-<p>
- Remove unused remap code.<br>
-<br>
- Remove code to remap raster with bits per component that don't divide 8.<br>
- 3,5,6 and 7 bit per pixel pcl raster is always consolidated to 8 bits<br>
- per pixel before remapping.<br>
-<br>
-pcl/pcl/pcwhtidx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-07 07:49:46 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d3d41654f43ff7a027cb9ffb271c90020a6c2de7">d3d41654f43ff7a027cb9ffb271c90020a6c2de7</a>
-<blockquote>
-<p>
- Remove unnecessary remap macros.<br>
-<br>
- The free macro was never used the array has always been freed directly.<br>
-<br>
-pcl/pcl/pcwhtidx.c<br>
-pcl/pcl/pcwhtidx.h<br>
-pcl/pcl/rtraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-08 18:02: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=9d7c50bce20bd870305c3206c731498bc5ef6bbd">9d7c50bce20bd870305c3206c731498bc5ef6bbd</a>
-<blockquote>
-<p>
- Bug 696824: 'post' table with out of range indices<br>
-<br>
- Loading a Truetype font with a 'post' table which has glyph indices outside<br>
- the range of glyph names available, we'd previously exit the loop filling in<br>
- the array of names early - leaving subsequent entries in the array unset.<br>
- Which would, later, cause a typecheck error.<br>
-<br>
- To be more tolerant, when we encounter an index outside the available range,<br>
- just use notdef for that position in the name array.<br>
-<br>
-Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-07 10:28: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=054861374d6822738865892d5a0c2bb78cd58a9d">054861374d6822738865892d5a0c2bb78cd58a9d</a>
-<blockquote>
-<p>
- PDF interpreter - refuse to set degenerate text matrix<br>
-<br>
- Bug 696817 &quot;Regression: text missing starting with 83e211723f975beff6ce488a2a6ee5105c089121&quot;<br>
-<br>
- The file sets a font size of 0 and then a ridiculous text matrix:<br>
-<br>
- -2147483648 -2147483648 -2147483648 -2147483648 197 380 Tm<br>
-<br>
- Combined with the CTM this leads to a degenerate CTM (the 2-dimensional<br>
- co-ordinates all map to a one dimensional line). This is clearly silly.<br>
-<br>
- This is not in fact a regression, I modified the code so that it would<br>
- behave the same when TextAlphaBits is set as when it is not. Although<br>
- this file did 'work' previously, when TextAlphaBiots is not set, it<br>
- did not work if TextAlphaBits was set, so the code works as expected.<br>
-<br>
- This commit adds a test for a degenerate matrix resulting from Tm and<br>
- ignores it if it would. We already 'fix' a font size of 0.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-06 17:39: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=3cdf4f936d07333e78f545d67ce14ccbe4290b4c">3cdf4f936d07333e78f545d67ce14ccbe4290b4c</a>
-<blockquote>
-<p>
- Add 'fall through' comments to many switch cases to satisfy Coverity<br>
-<br>
-base/gdevdrop.c<br>
-base/gdevprn.c<br>
-base/gdevvec.c<br>
-base/gsbitops.h<br>
-base/gsdevmem.c<br>
-base/gsdparam.c<br>
-base/gsfunc4.c<br>
-base/gsht.c<br>
-base/gsparamx.c<br>
-base/gxclimag.c<br>
-base/gxclrast.c<br>
-base/gxpath2.c<br>
-base/sstring.c<br>
-cups/gdevcups.c<br>
-devices/gdevupd.c<br>
-devices/gdevxalt.c<br>
-devices/vector/gdevpdfd.c<br>
-devices/vector/gdevpdtd.c<br>
-devices/vector/gdevtxtw.c<br>
-psi/imainarg.c<br>
-psi/interp.c<br>
-psi/iscan.c<br>
-psi/iscannum.c<br>
-psi/zcolor.c<br>
-psi/zmedia2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-06 16:45: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=c4dd42e0bcfd9e5bdd42a248111b5786ad7096cb">c4dd42e0bcfd9e5bdd42a248111b5786ad7096cb</a>
-<blockquote>
-<p>
- Fix two makefile typos from the imager_state-&gt;gs_gsgstate commit<br>
-<br>
- First was a missing closing parenthasis in a macro reference in psi/int.mak<br>
-<br>
- Second was using a period ('.') in a macro name in base/lib.mak<br>
-<br>
- Oddly, neither of these manifested with GNU make, only with nmake on Windows.<br>
-<br>
-base/lib.mak<br>
-psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-24 12:50:47 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=45dcf097558e880a76f569dd8d6c678f6ed186ce">45dcf097558e880a76f569dd8d6c678f6ed186ce</a>
-<blockquote>
-<p>
- Make gs_imager_state == gs_state.<br>
-<br>
- Change how gstate initialisation is done:<br>
-<br>
- Previously we relied on the imager state being a subset of the gstate (thus<br>
- assigning an imager state to a graphics state over wrote to the entries<br>
- common to both, and didn't overwrite any already set graphics state specific<br>
- entries).<br>
-<br>
- Making the imager and graphics states the same means that approach doesn't work,<br>
- so this changes it to initialise the entries individually.<br>
-<br>
- Renames gsistate.c-&gt;gsgstate.c and gxistate.h-&gt;gxgstate.h<br>
-<br>
- Cleanup and fix the gs_state gc stuff.<br>
-<br>
- Uses different check for pre/post clist pdf14 device<br>
-<br>
- Previously, the code used &quot;is_gstate&quot; in the imager/graphics state object<br>
- to determine if the code was being called pre or post clist (post clist would<br>
- only ever have had an imager_state so is_gstate = false).<br>
-<br>
- With no imager state any more, that test would no longer work (and I am dubious<br>
- about whether it was really safe, anyway). Other places check for the presence<br>
- of a clist reader device in the pdf14 device structure - so use that here<br>
- too.<br>
-<br>
- Adds initial (NULL) value for show_gstate pointer in gs_state.<br>
-<br>
- Removes the now pointless macro for the contents of the graphics state<br>
-<br>
- Changes function names that had &quot;imager&quot; to use &quot;gstate&quot;<br>
-<br>
- Removes the redundant 'is_state' flag<br>
-<br>
- Cleans up gs_(g)state_putdeviceparams():<br>
-<br>
- Previously we had to similar routines: one took a graphics state, and used the<br>
- device from the graphics state, the other took an imager state and the device<br>
- as an explicit parameter.<br>
-<br>
- With the removal of the imager state, &quot;merge&quot; those two functions<br>
-<br>
- Replaces gs_state with gs_gstate<br>
-<br>
- It makes for less confusion as it really is a g(raphics)state<br>
-<br>
-base/gdevabuf.c<br>
-base/gdevbbox.c<br>
-base/gdevddrw.c<br>
-base/gdevdevn.c<br>
-base/gdevdevn.h<br>
-base/gdevdflt.c<br>
-base/gdevflp.c<br>
-base/gdevmpla.c<br>
-base/gdevmplt.c<br>
-base/gdevnfwd.c<br>
-base/gdevoflt.c<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gdevplnx.c<br>
-base/gdevsclass.c<br>
-base/gdevvec.c<br>
-base/gdevvec.h<br>
-base/gsalpha.c<br>
-base/gsalpha.h<br>
-base/gsalphac.c<br>
-base/gscdevn.c<br>
-base/gscdevn.h<br>
-base/gschar.c<br>
-base/gschar.h<br>
-base/gscicach.c<br>
-base/gscicach.h<br>
-base/gscie.c<br>
-base/gscie.h<br>
-base/gsciemap.c<br>
-base/gsclipsr.c<br>
-base/gsclipsr.h<br>
-base/gscolor.c<br>
-base/gscolor.h<br>
-base/gscolor1.c<br>
-base/gscolor1.h<br>
-base/gscolor2.c<br>
-base/gscolor2.h<br>
-base/gscolor3.c<br>
-base/gscolor3.h<br>
-base/gscoord.c<br>
-base/gscoord.h<br>
-base/gscpixel.c<br>
-base/gscscie.c<br>
-base/gscsepr.c<br>
-base/gscsepr.h<br>
-base/gscspace.c<br>
-base/gscspace.h<br>
-base/gscssub.c<br>
-base/gscssub.h<br>
-base/gsdevice.c<br>
-base/gsdevice.h<br>
-base/gsdfilt.c<br>
-base/gsdfilt.h<br>
-base/gsdps.c<br>
-base/gsdps.h<br>
-base/gsdps1.c<br>
-base/gsequivc.c<br>
-base/gsequivc.h<br>
-base/gsfont.c<br>
-base/gsfont.h<br>
-base/gsgstate.c<br>
-base/gshsb.c<br>
-base/gshsb.h<br>
-base/gsht.c<br>
-base/gsht.h<br>
-base/gsht1.c<br>
-base/gsht1.h<br>
-base/gshtscr.c<br>
-base/gshtx.c<br>
-base/gshtx.h<br>
-base/gsicc.c<br>
-base/gsicc_cache.c<br>
-base/gsicc_cache.h<br>
-base/gsicc_cms.h<br>
-base/gsicc_create.c<br>
-base/gsicc_create.h<br>
-base/gsicc_manage.c<br>
-base/gsicc_manage.h<br>
-base/gsicc_nocm.c<br>
-base/gsicc_profilecache.c<br>
-base/gsicc_profilecache.h<br>
-base/gsicc_replacecm.c<br>
-base/gsimage.c<br>
-base/gsimage.h<br>
-base/gsimpath.c<br>
-base/gsiparm2.h<br>
-base/gsistate.c<br>
-base/gslib.c<br>
-base/gsline.c<br>
-base/gsline.h<br>
-base/gsnamecl.c<br>
-base/gsnamecl.h<br>
-base/gsncdummy.c<br>
-base/gsovrc.c<br>
-base/gspaint.c<br>
-base/gspaint.h<br>
-base/gspath.c<br>
-base/gspath.h<br>
-base/gspath1.c<br>
-base/gspath2.h<br>
-base/gspcolor.c<br>
-base/gspcolor.h<br>
-base/gsptype1.c<br>
-base/gsptype1.h<br>
-base/gsptype2.c<br>
-base/gsptype2.h<br>
-base/gsrefct.h<br>
-base/gsrop.c<br>
-base/gsrop.h<br>
-base/gsshade.c<br>
-base/gsshade.h<br>
-base/gsstate.c<br>
-base/gsstate.h<br>
-base/gsstype.h<br>
-base/gstext.c<br>
-base/gstext.h<br>
-base/gstrans.c<br>
-base/gstrans.h<br>
-base/gstype1.c<br>
-base/gstype1.h<br>
-base/gstype2.c<br>
-base/gstype42.c<br>
-base/gx.h<br>
-base/gxacpath.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-base/gxccache.c<br>
-base/gxcdevn.h<br>
-base/gxchar.c<br>
-base/gxchar.h<br>
-base/gxchrout.c<br>
-base/gxchrout.h<br>
-base/gxcht.c<br>
-base/gxcie.h<br>
-base/gxcldev.h<br>
-base/gxclimag.c<br>
-base/gxclip.c<br>
-base/gxclip.h<br>
-base/gxclip2.c<br>
-base/gxclipm.c<br>
-base/gxclist.c<br>
-base/gxclist.h<br>
-base/gxclpath.c<br>
-base/gxclpath.h<br>
-base/gxclrast.c<br>
-base/gxclrect.c<br>
-base/gxcmap.c<br>
-base/gxcmap.h<br>
-base/gxcomp.h<br>
-base/gxcoord.h<br>
-base/gxcpath.c<br>
-base/gxcspace.h<br>
-base/gxdcconv.c<br>
-base/gxdcconv.h<br>
-base/gxdcolor.c<br>
-base/gxdcolor.h<br>
-base/gxdevcli.h<br>
-base/gxdevice.h<br>
-base/gxdevmem.h<br>
-base/gxdht.h<br>
-base/gxdhtserial.c<br>
-base/gxdhtserial.h<br>
-base/gxfapi.c<br>
-base/gxfapi.h<br>
-base/gxfcache.h<br>
-base/gxfill.c<br>
-base/gxfont.h<br>
-base/gxfont42.h<br>
-base/gxgstate.h<br>
-base/gxhintn.c<br>
-base/gxhldevc.c<br>
-base/gxhldevc.h<br>
-base/gxht.c<br>
-base/gxht.h<br>
-base/gxht_thresh.c<br>
-base/gxi12bit.c<br>
-base/gxi16bit.c<br>
-base/gxicolor.c<br>
-base/gxifast.c<br>
-base/gximag3x.c<br>
-base/gximag3x.h<br>
-base/gximage.c<br>
-base/gximage.h<br>
-base/gximage1.c<br>
-base/gximage2.c<br>
-base/gximage3.c<br>
-base/gximage3.h<br>
-base/gximage4.c<br>
-base/gximono.c<br>
-base/gxiparam.h<br>
-base/gxipixel.c<br>
-base/gxiscale.c<br>
-base/gxistate.h<br>
-base/gxp1impl.h<br>
-base/gxpaint.c<br>
-base/gxpaint.h<br>
-base/gxpath.h<br>
-base/gxpcmap.c<br>
-base/gxpcolor.h<br>
-base/gxpcopy.c<br>
-base/gxpdash.c<br>
-base/gxshade.c<br>
-base/gxshade.h<br>
-base/gxshade1.c<br>
-base/gxshade4.c<br>
-base/gxshade4.h<br>
-base/gxshade6.c<br>
-base/gxstate.h<br>
-base/gxstroke.c<br>
-base/gxtext.h<br>
-base/gxttfb.c<br>
-base/gxtype1.c<br>
-base/gxtype1.h<br>
-base/gzacpath.h<br>
-base/gzht.h<br>
-base/gzline.h<br>
-base/gzstate.h<br>
-base/lib.mak<br>
-contrib/eplaser/gdevescv.c<br>
-contrib/japanese/gdevlbp3.c<br>
-contrib/japanese/gdevp201.c<br>
-contrib/lips4/gdevl4v.c<br>
-contrib/opvp/gdevopvp.c<br>
-contrib/pcl3/eprn/eprnparm.c<br>
-contrib/pcl3/eprn/gdeveprn.c<br>
-contrib/pcl3/eprn/gdeveprn.h<br>
-cups/gdevcups.c<br>
-devices/devs.mak<br>
-devices/gdevbit.c<br>
-devices/gdevdsp.c<br>
-devices/gdevepsn.c<br>
-devices/gdevgprf.c<br>
-devices/gdevijs.c<br>
-devices/gdevo182.c<br>
-devices/gdevokii.c<br>
-devices/gdevpbm.c<br>
-devices/gdevperm.c<br>
-devices/gdevpng.c<br>
-devices/gdevpsd.c<br>
-devices/gdevrinkj.c<br>
-devices/gdevsgi.c<br>
-devices/gdevsj48.c<br>
-devices/gdevtrac.c<br>
-devices/gdevtsep.c<br>
-devices/gdevx.c<br>
-devices/gdevxcf.c<br>
-devices/gdevxini.c<br>
-devices/gxfcopy.c<br>
-devices/vector/gdevpdfb.c<br>
-devices/vector/gdevpdfc.c<br>
-devices/vector/gdevpdfc.h<br>
-devices/vector/gdevpdfd.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfg.h<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdfk.c<br>
-devices/vector/gdevpdft.c<br>
-devices/vector/gdevpdfv.c<br>
-devices/vector/gdevpdfx.h<br>
-devices/vector/gdevpdtc.c<br>
-devices/vector/gdevpdte.c<br>
-devices/vector/gdevpdti.c<br>
-devices/vector/gdevpdts.c<br>
-devices/vector/gdevpdts.h<br>
-devices/vector/gdevpdtt.c<br>
-devices/vector/gdevpdtt.h<br>
-devices/vector/gdevpsdf.h<br>
-devices/vector/gdevpsdi.c<br>
-devices/vector/gdevpsds.c<br>
-devices/vector/gdevpsds.h<br>
-devices/vector/gdevpsdu.c<br>
-devices/vector/gdevpsfx.c<br>
-devices/vector/gdevpx.c<br>
-devices/vector/gdevtxtw.c<br>
-devices/vector/gdevxps.c<br>
-doc/Drivers.htm<br>
-gpdl/psi/psitop.c<br>
-pcl/pcl/pcommand.c<br>
-pcl/pcl/pcpage.c<br>
-pcl/pcl/pcpatrn.c<br>
-pcl/pcl/pcrect.c<br>
-pcl/pcl/pcstate.h<br>
-pcl/pcl/pctext.c<br>
-pcl/pcl/pctop.c<br>
-pcl/pcl/pgdraw.c<br>
-pcl/pcl/pgfont.c<br>
-pcl/pcl/pglabel.c<br>
-pcl/pcl/pgstate.h<br>
-pcl/pcl/rtraster.c<br>
-pcl/pl/plchar.c<br>
-pcl/pl/plchar.h<br>
-pcl/pl/pldraw.c<br>
-pcl/pl/pldraw.h<br>
-pcl/pl/plfapi.c<br>
-pcl/pl/plht.c<br>
-pcl/pl/plht.h<br>
-pcl/pl/plmain.h<br>
-pcl/pl/pluchar.c<br>
-pcl/pxl/pxerrors.c<br>
-pcl/pxl/pxfont.c<br>
-pcl/pxl/pxgstate.c<br>
-pcl/pxl/pxgstate.h<br>
-pcl/pxl/pximage.c<br>
-pcl/pxl/pxink.c<br>
-pcl/pxl/pxl.mak<br>
-pcl/pxl/pxpaint.c<br>
-pcl/pxl/pxsessio.c<br>
-pcl/pxl/pxstate.c<br>
-pcl/pxl/pxstate.h<br>
-pcl/pxl/pxtop.c<br>
-psi/gserver.c<br>
-psi/icie.h<br>
-psi/icolor.h<br>
-psi/icontext.c<br>
-psi/icstate.h<br>
-psi/igstate.h<br>
-psi/int.mak<br>
-psi/zchar.c<br>
-psi/zchar1.c<br>
-psi/zchar42.c<br>
-psi/zcie.c<br>
-psi/zcolor.c<br>
-psi/zcontext.c<br>
-psi/zcrd.c<br>
-psi/zcsindex.c<br>
-psi/zdevice2.c<br>
-psi/zdpnext.c<br>
-psi/zdps.c<br>
-psi/zdps1.c<br>
-psi/zgstate.c<br>
-psi/zht2.c<br>
-psi/zicc.c<br>
-psi/zmatrix.c<br>
-psi/zpath.c<br>
-psi/zpath1.c<br>
-psi/zpcolor.c<br>
-psi/ztrans.c<br>
-psi/zupath.c<br>
-psi/zusparam.c<br>
-psi/zvmem.c<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-xps/ghostxps.h<br>
-xps/xpscff.c<br>
-xps/xpsfapi.c<br>
-xps/xpsgradient.c<br>
-xps/xpspage.c<br>
-xps/xpstile.c<br>
-xps/xpstop.c<br>
-xps/xpsttf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-06 10:49: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=41d8d83a77ee6ea12109dde7b72dedc61cca01a3">41d8d83a77ee6ea12109dde7b72dedc61cca01a3</a>
-<blockquote>
-<p>
- Coverity ID: 94795 handle stack based T1 hinter state<br>
-<br>
- If the Type 1 hinter state is a stack allocation, then the 'memory' pointer<br>
- will be NULL, so pass a suitable allocator into the functions that need them,<br>
- rather than assuming the hinter state one will be valid.<br>
-<br>
-base/gstype1.c<br>
-base/gstype2.c<br>
-base/gxhintn.c<br>
-base/gxhintn.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-06 13:19: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=8f644a331f5d5c79a523c35495b0751d8ba44916">8f644a331f5d5c79a523c35495b0751d8ba44916</a>
-<blockquote>
-<p>
- Coverity ID 94995 - take 2....<br>
-<br>
- Turns out there are two chunks of code that need to be removed. The code<br>
- is currently dead, but we might want it someday so #if 0 it out rather<br>
- than simply deleting it.<br>
-<br>
-devices/vector/gdevpsfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-06 13:12: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=1d1bcc3997e44f36b5559163cca738091c035813">1d1bcc3997e44f36b5559163cca738091c035813</a>
-<blockquote>
-<p>
- Coverity ID 95084<br>
-<br>
- Turns out there were two places where we needed a NULL dererference<br>
- check<br>
-<br>
-devices/gdevxcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-06 12:32:50 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d020de175b5c26f9fb06d28fa3e2010ba4dbfcb9">d020de175b5c26f9fb06d28fa3e2010ba4dbfcb9</a>
-<blockquote>
-<p>
- Coverity ID 126581 - cast to avoid implicit sign extension<br>
-<br>
-devices/gdevtifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-06 11:57: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=154c010b817eb171e10e91d5ff5aaa946127f8ad">154c010b817eb171e10e91d5ff5aaa946127f8ad</a>
-<blockquote>
-<p>
- Coverity ID 94540<br>
-<br>
- missed a check on fseek return code<br>
-<br>
-devices/gdevsgi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-06 11:30: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=dd0c18056a5f28ad43f23860a5e54b990d9d64a2">dd0c18056a5f28ad43f23860a5e54b990d9d64a2</a>
-<blockquote>
-<p>
- Coverity ID 127115<br>
-<br>
- check pis before dereferencing pointer, return error if NULL<br>
-<br>
-devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-06 10:31:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=716a2e45caac97bb1e91484b0f706e47801d71d5">716a2e45caac97bb1e91484b0f706e47801d71d5</a>
-<blockquote>
-<p>
- Coverity IDs 94897, 127116<br>
-<br>
- Missed a chack against a buffer size in earlier commit<br>
- the file descriptor 'fd' is initially set negative, need to check<br>
- the value before trying to close it.<br>
-<br>
-devices/gdevijs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-06 10:21: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=25936513d5dfc0270f23be57d8c79de32a0e45eb">25936513d5dfc0270f23be57d8c79de32a0e45eb</a>
-<blockquote>
-<p>
- Coverity ID 127117<br>
-<br>
- us is an unsigned short, so remove the pointless test 'us &lt; 0'<br>
-<br>
-devices/gdevifno.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-03 16:32: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=bc06a8ac477bd5b08e34c5e74d70bc6107255da0">bc06a8ac477bd5b08e34c5e74d70bc6107255da0</a>
-<blockquote>
-<p>
- Coverity ID: 94951 limit the size of strings.....<br>
-<br>
- .... read from the command line<br>
-<br>
-base/mkromfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-03 16:11: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=e48b8ea64488d065d647212eb205ae2041f6fe30">e48b8ea64488d065d647212eb205ae2041f6fe30</a>
-<blockquote>
-<p>
- Coverity 94527: check a return code.<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-03 15:26: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=3cbaf3dc7d1e8790bd9b6cb748a6ea88052522c7">3cbaf3dc7d1e8790bd9b6cb748a6ea88052522c7</a>
-<blockquote>
-<p>
- Coverity ID: 94590 Initialise ref to null object.<br>
-<br>
- Previously we initialised a ref pointer to NULL, which coverity reckoned could<br>
- result in a null pointer dereference.<br>
-<br>
- Instead, initialise it to a reference to a null object.<br>
-<br>
-psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-03 16:10: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=bc90e4de0e59a1c8ccefc4b367220d36f9213beb">bc90e4de0e59a1c8ccefc4b367220d36f9213beb</a>
-<blockquote>
-<p>
- Test use of 'fall through' comment to silence Coverity<br>
-<br>
- When encountering switch cases where we deliberately don't have a<br>
- break.<br>
-<br>
-base/gdevbbox.c<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-03 10:43: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=cff9c80230086676a22c1c9f81457855bd8c69c5">cff9c80230086676a22c1c9f81457855bd8c69c5</a>
-<blockquote>
-<p>
- Coverity ID - 95084ce inside<br>
-<br>
- Move a pointer derefeferene into a if clause checking for NULL<br>
-<br>
-devices/gdevxcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-01 16:01: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=ba73a9d5cf2dcdd84d74046288c9e056ce39f5df">ba73a9d5cf2dcdd84d74046288c9e056ce39f5df</a>
-<blockquote>
-<p>
- Coverity ID 94895<br>
-<br>
- Don't ignore a return code<br>
-<br>
-devices/gdevxcf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-01 15:58: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=e63a4886b3b345db5b9656c7b82d3fcf91436d85">e63a4886b3b345db5b9656c7b82d3fcf91436d85</a>
-<blockquote>
-<p>
- Coverity IDs 94767, 126581<br>
-<br>
- Avoid a potential (probably impossible) divide-by-zero<br>
- Remove pointless test of unsigned variable &lt; 0<br>
-<br>
-devices/gdevstc2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-01 15:45: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=f8d1ca815990feca25a1ef5dad70aa177d9c4670">f8d1ca815990feca25a1ef5dad70aa177d9c4670</a>
-<blockquote>
-<p>
- initialise some variables to silence a CPP warning<br>
-<br>
-devices/gdevijs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-01 15:41: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=afbab2f5452541d45ca4186a743f95fe4c28370a">afbab2f5452541d45ca4186a743f95fe4c28370a</a>
-<blockquote>
-<p>
- Check return code - compiler warning<br>
-<br>
- The code was not checking the return value of sgi_begin_page() which<br>
- could fail. If we then continued, various members of 'cur' could<br>
- be used uninitialised and in any event the device could not possibly<br>
- continue safely.<br>
-<br>
- NB this could happen if we wrote multiple pages and did not specify<br>
- '%d' in the OutputFile or if we exhausted memory.<br>
-<br>
-devices/gdevsgi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-01 15:25: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=b5e474eca6e8b83f5b4a5bce2b2736c70ca3e3d6">b5e474eca6e8b83f5b4a5bce2b2736c70ca3e3d6</a>
-<blockquote>
-<p>
- Various Coverity IDs<br>
-<br>
- 94605 - logically dead code, remove the dead code<br>
- 94779 - dereference NULL - test pointer before use<br>
- 94940 - cast to avoid sign extension<br>
- 121446 - cast to avoid overflow<br>
- 126582 - cast to avoid sign extension<br>
-<br>
-devices/gdevstc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-01 14:49: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=aa8ac2b01659b998f5561bbabb3b0f863d88fd3e">aa8ac2b01659b998f5561bbabb3b0f863d88fd3e</a>
-<blockquote>
-<p>
- Coverity ID 94540 check and action a return code<br>
-<br>
-devices/gdevsgi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-01 14:38: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=1ef49f0612b367bfca7ebec1642b5a20fc440852">1ef49f0612b367bfca7ebec1642b5a20fc440852</a>
-<blockquote>
-<p>
- Coverity IDs 94791, 95082<br>
-<br>
- I *think* this will solve the Coverity complaint about the sprintf<br>
- mismatch. Only way to find out is to try it.<br>
-<br>
-devices/gdevlp8k.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-01 10:13: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=a42440365ee0fa333d28005a511090e9f7530ed1">a42440365ee0fa333d28005a511090e9f7530ed1</a>
-<blockquote>
-<p>
- IJS device - Coverity IDs 94848, 94897, 94970, 94997<br>
-<br>
- Close an fd (result of 'dup') on error<br>
-<br>
- Check the return value from a routine against array bounds before using<br>
- it as an array index.<br>
-<br>
-devices/gdevijs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-01 09:37: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=3cb304a014ca7bfdfe7196bb10ca0fd6498de13a">3cb304a014ca7bfdfe7196bb10ca0fd6498de13a</a>
-<blockquote>
-<p>
- inferno device - Coverity ID 94985 - prevent overrun<br>
-<br>
- Explicitly check a calculated buffer index to ensure it is not past the<br>
- end of the buffer.<br>
-<br>
-devices/gdevifno.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-06-01 09:30:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=97c955fc3a92f8286382f5242a82f8aec45416ae">97c955fc3a92f8286382f5242a82f8aec45416ae</a>
-<blockquote>
-<p>
- inkcov - Coverity IDs 94600, 94671, 94820, 95003<br>
-<br>
- Explicit check of total_pix to guarantee no divide-by-zero error. This<br>
- could only occur if page width or height was 0, which *should* be<br>
- impossible anyway.<br>
-<br>
- Promote a 32-bit signed int to a 64-bit unsigned to prevent potential<br>
- signed overflow (2 times).<br>
-<br>
-devices/gdevicov.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-31 15:28: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=04b455ea5a59866f4955f07c295c6fd955ea9a7f">04b455ea5a59866f4955f07c295c6fd955ea9a7f</a>
-<blockquote>
-<p>
- Coverity ID 94636 Remove dead code, pointless test and now unused variable<br>
-<br>
-devices/gdevescp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-31 14:42: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=5a7a7f4ed4effb576368c7b923c4aa95aef0f5b4">5a7a7f4ed4effb576368c7b923c4aa95aef0f5b4</a>
-<blockquote>
-<p>
- ToUnicode CMaps - avoid buffer overrun<br>
-<br>
- Bug 696811 &quot;Regression: address sanitizer error starting with 9dba57f0f9a53c130ec2771c0ed1d7bd6bbef6ab&quot;<br>
-<br>
- An oversight when I rewrote the ToUnicode CMap processing recently.<br>
- Originally the ToUnicode CMap array always carried 2 bytes; now it can<br>
- hold an arbitrary length of data.<br>
-<br>
- However, I'd missed the fact that there is one location which expects<br>
- to read 2 bytes, if we are only storing 1, and we reach the end of the<br>
- array (maximum character code) then we would read one byte past the end<br>
- of the array.<br>
-<br>
- Fixed here by checking the size of the value and only reading the second<br>
- byte if there are at least 2 (set the second byte value to 0 if not).<br>
-<br>
-base/gsfcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-31 10:16: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=85cec887fbd31099b2c6977f4427b20d25f98714">85cec887fbd31099b2c6977f4427b20d25f98714</a>
-<blockquote>
-<p>
- pdfwrite - prevent invalid combination of encryption and linearisation<br>
-<br>
- The pdfwrite device does linearization as a post-creation process,<br>
- this makes it difficult to deal with encryption as we alter the object<br>
- numbers, and the object number is used as part of the encryption.<br>
-<br>
- In order to support this we would have to decrypt each string or stream<br>
- and then re-encrypt with a different encryption key using the new<br>
- object number.<br>
-<br>
- This is way too much effort for a feature of such marginal utility.<br>
-<br>
- Instead, prevent the combination taking place, and document this as a<br>
- limitation.<br>
-<br>
-devices/vector/gdevpdfp.c<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-30 09:47: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=bce0e0b651b2ec2c14b6d28b3da290f48b2b49dd">bce0e0b651b2ec2c14b6d28b3da290f48b2b49dd</a>
-<blockquote>
-<p>
- Coverity IDs 94672, 94998 dead code, unused value<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-29 11:40: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=a99ac607787704b0171db55846976aa8438b85e7">a99ac607787704b0171db55846976aa8438b85e7</a>
-<blockquote>
-<p>
- pdfwrite - #if out some unused code<br>
-<br>
- This code causes Coverity to complain about 'countof', quite rightly.<br>
- However the code cannot currently be executed as subset_glyphs is<br>
- always NULL. The code looks like it might (if fixed) possibly be<br>
- useful so for now I've used #if 0 to remove it.<br>
-<br>
-devices/vector/gdevpsfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-29 11:09: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=6d772c95b87f9d5e81b49f15badb1d58d1448fee">6d772c95b87f9d5e81b49f15badb1d58d1448fee</a>
-<blockquote>
-<p>
- xpswrite - various Coverity IDs<br>
-<br>
- IDs:<br>
- 94615 - remove dead code (can only get to this point with pie == NULL)<br>
- 94646 - check pointer non-NULL before dereference<br>
- 94666 - return error if allocation fails<br>
- 94878 - Move assignment after NULL pointer check<br>
- 94894 - check and action a return value<br>
-<br>
-devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-28 10:13: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=b4e0f2080b25fc3518d9e4fb68f4d7d478bac8eb">b4e0f2080b25fc3518d9e4fb68f4d7d478bac8eb</a>
-<blockquote>
-<p>
- Coverity ID 94614 - remove dead code<br>
-<br>
- lnum can only be 0 on the first time round the loop, initially<br>
- num_blank_lines is 0, and is only modified in the 'if' clause, whereas<br>
- the test against lnum is in the else clause. So num_blank_lines<br>
- cannot be non-zero on the first pass, and lnum cannot be zero on<br>
- subsequent passes. Therefore the code is dead.<br>
-<br>
-devices/gdev3852.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-26 14:34:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1f8219335025566277364bde52315aa339d6fda4">1f8219335025566277364bde52315aa339d6fda4</a>
-<blockquote>
-<p>
- pdfwrite - remove an unused (and rather pointless) function<br>
-<br>
-devices/vector/gdevpdfx.h<br>
-devices/vector/gdevpdts.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-26 14:02:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d5f17bbf37e4090952080423e3aa35c29c2751f5">d5f17bbf37e4090952080423e3aa35c29c2751f5</a>
-<blockquote>
-<p>
- txtwrite - fix the ToUnicode processing<br>
-<br>
- commit 9dba57f0f9a53c130ec2771c0ed1d7bd6bbef6ab inadvertently broke<br>
- txtweite, I changed the meaning of the return value from the font<br>
- decode_glyph method. Initially I had intended it to be a count of<br>
- unsigned shorts, but altered it to bytes. Unfortunately I had<br>
- changed txtwrite for shorts, but forgot to change it for bytes.<br>
-<br>
- This led to a buffer overrun and heap corruption.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-26 13:00: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=094d5a1880f1cb9ed320ca9353eb69436e09b594">094d5a1880f1cb9ed320ca9353eb69436e09b594</a>
-<blockquote>
-<p>
- pdfwrite - honour PDFA-2 restriction on OPM<br>
-<br>
- Bug 696799 &quot; Conformation to PDF/A fails specification ISO 19005-2:2011, clause: 6.2.4.2, test number 2 in veraPDF&quot;<br>
-<br>
- It seems the standards committee decided to disallow OPM 1, essentially.<br>
- The spec does say that its only disallowed when a CMYK space is used<br>
- and overprinting is true for either stroke or fill, but since that's<br>
- the only time its ever used that essentially means it can't be set.<br>
-<br>
- This seems like a bad idea, because PDF/A-1 did *not* enforce this,<br>
- which means that the same file cna make a valid PDF/A-1 but not a valid<br>
- PDF/A-2.<br>
-<br>
- Still nobody asked my opinion, and its in the spec, so this commit<br>
- enforces it. We can't wait until its actually *used*, we have to<br>
- prevent it being set in the first place.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-25 16:56: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=f25436308ce95a714319c572b7fa2f571ef5e84b">f25436308ce95a714319c572b7fa2f571ef5e84b</a>
-<blockquote>
-<p>
- PDF interpreter - fix GlyphNames2Unicode with 2 byte keys<br>
-<br>
- Bug 695834 &quot;After processing a pdf file with PDF writer copy &amp; paste doesn't work anymore&quot;<br>
-<br>
- The .convert_ToUnicode-into-g2u function translates .CodeMapData<br>
- (which is generated from a CMap) into a GlyphNames2Unicode dictionary,<br>
- but due to an oversight, when the high byte of an integer key was set<br>
- (via the 'offset' stored in .CodeMapData) it was not being added to the<br>
- key when generating ranges, with the result that the keys were incorrect<br>
- and could overwrite earlier values.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-25 16:53: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=0124e1a5e635abc4cb65e53ca13930e3b95499fe">0124e1a5e635abc4cb65e53ca13930e3b95499fe</a>
-<blockquote>
-<p>
- Fonts - add some new glyph names to the Unicode Decoding resource<br>
-<br>
- Bug 695806 &quot;Words with ligatures cannot be searched for in PDF created with ps2pdf&quot;<br>
-<br>
- TeX seems to use some non-standard glyph names for ligatures, just<br>
- add those names to the existing ones for the benefit of ToUnicode<br>
- CMap generation<br>
-<br>
-Resource/Decoding/Unicode<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-25 16:51: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=9dba57f0f9a53c130ec2771c0ed1d7bd6bbef6ab">9dba57f0f9a53c130ec2771c0ed1d7bd6bbef6ab</a>
-<blockquote>
-<p>
- pdfwrite - ToUnicode revamp<br>
-<br>
- Bug 695461 &quot; Why does the search results changes after pdf optimzation in ghostscript?&quot;<br>
-<br>
- The existing ToUnicode functions were written against the original<br>
- ToUnicode specification, and assume that there will be no more than<br>
- 2 unsigned shorts returned as the Unicode code point for any given<br>
- glyph. Sadly Adobe have revised the ToUnicode CMap making it the same<br>
- as a regular CMap, and then extending it still further.<br>
-<br>
- It is now possible for a single glyph to map to a string of up to<br>
- 512 bytes.<br>
-<br>
- This commit revises the existing C 'decode_glyph's so that instead of<br>
- returning a gs_char for the Unicode code point, we return a string of<br>
- bytes. If the caller initially says that the string it is passing is<br>
- zero bytes, then we do not copy the bytes, we just return the required<br>
- size of the string (in bytes).<br>
-<br>
- A return value of 0 from a decode_glyph function means that the glyph<br>
- was not in the map and so could not be 'decoded'.<br>
-<br>
- As a consequence of this change, and to further permit more than<br>
- 2 unsigned shorts for ToUnicode CMaps, the CMap lookup enumerator<br>
- now needs to be able to allocate memory, so the 'next_lookup'<br>
- methods all now take a gs_memory_t pointer to make ths possible.<br>
-<br>
- The ToUnicode cmap table also has to change. Formerly it was a simple<br>
- 4 bytes per code, either 255 or 65535 codes array. For simplicity<br>
- I've chosen to keep it as a large continuous array, but each entry<br>
- is now the number of bytes required to store the longest defined<br>
- Unicode value for that font, plus 2 bytes. The 2 bytes give the length<br>
- of the reserved space actually used by each Unicode code point. The<br>
- bytes are stored immediately following the length (so a 2 byte length<br>
- Pascal string if you like). This may possibly cause ToUnicode maps<br>
- to use a lot of memory, in the short term we'll live with it because<br>
- these only exist with pdfwrite, and that only really is expected<br>
- to run on decent sized platforms. May need to do something better in<br>
- future.<br>
-<br>
-base/gsfcid2.c<br>
-base/gsfcmap.c<br>
-base/gsfcmap.h<br>
-base/gsfcmap1.c<br>
-base/gsfont.c<br>
-base/gxfcmap.h<br>
-base/gxfont.h<br>
-devices/vector/gdevpdtc.c<br>
-devices/vector/gdevpdte.c<br>
-devices/vector/gdevpsf.h<br>
-devices/vector/gdevpsfm.c<br>
-devices/vector/gdevtxtw.c<br>
-pcl/pl/plfont.c<br>
-psi/bfont.h<br>
-psi/zbfont.c<br>
-xps/xpscff.c<br>
-xps/xpsttf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-25 13:44:28 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a60087bafbaabf7052e65eb7f08548ae596d91d4">a60087bafbaabf7052e65eb7f08548ae596d91d4</a>
-<blockquote>
-<p>
- Change PCL/XPS -Z: to use wall clock time on unix rather than cpu time.<br>
-<br>
- See 4a2a3c755dc51722483e3dda5eab821a9b7035d4 that does the same thing<br>
- for PS interpreter.<br>
-<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-25 12:49:04 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a2a3c755dc51722483e3dda5eab821a9b7035d4">4a2a3c755dc51722483e3dda5eab821a9b7035d4</a>
-<blockquote>
-<p>
- Change -Z: timing output to use wall clock time rather than CPU time.<br>
-<br>
- On Windows, the gp_get_usertime would give elapsed time (wall clock),<br>
- but on linux (depending on &quot;use_times_for_usertime&quot;, which was defined<br>
- on most unix systems), the result was CPU time for the process. This<br>
- caused multi-threaded runs to show no improvement (CPU time would only<br>
- increase a bit, but elapsed time could be much better).<br>
-<br>
- By using &quot;realtime&quot; for the minst-&gt;base_time and in print_resource_usage,<br>
- all platforms work consistently.<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-25 12:33:45 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=15d4d4b5ccac7d54362d9ae2f6f400f7e26a7627">15d4d4b5ccac7d54362d9ae2f6f400f7e26a7627</a>
-<blockquote>
-<p>
- Bug 696800 - subpolygon mode flag not reset.<br>
-<br>
- A flag is used in polygon mode when a subpolygon is created which is<br>
- used later when building subpolygon paths (they're special). The code<br>
- that builds the path always resets the flag so the special handling is<br>
- not applied to regular paths. The degenerate case of creating an<br>
- empty subpolygon resulted in the flag being left set. Now we reset<br>
- the flag when we exit subpolygon mode.<br>
-<br>
-pcl/pcl/pgpoly.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-25 14:12: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=e450c0fa22a073f468d214e763c542f7ca3a473b">e450c0fa22a073f468d214e763c542f7ca3a473b</a>
-<blockquote>
-<p>
- pdfwrite - fix AutoFilterStrategy for Luratech<br>
-<br>
- Commit 74d5e9fb7d70d3d3d9cf964c76c550134c822020 used an enum for the<br>
- autofilter strategy (as well as fixing numerous other problems in the<br>
- code) instead of a string. But this part of the Luratech code didn't<br>
- get altered, which would have led to it not working properly<br>
-<br>
-devices/vector/gdevpsdp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-25 10:41: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=9308777ef5ce79552041ca138083a7f001799019">9308777ef5ce79552041ca138083a7f001799019</a>
-<blockquote>
-<p>
- Add some directories to the list in LICENSE<br>
-<br>
- Add explicit mention of iccprofiles, pcl, xps and gpdl directories to the<br>
- list in the LICENSE file.<br>
-<br>
-LICENSE<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-23 09:34: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=b62625272225b3d7beb2a7f4310089efebfc1903">b62625272225b3d7beb2a7f4310089efebfc1903</a>
-<blockquote>
-<p>
- Bug 696602: Buffer overflow<br>
-<br>
- Turned out the offending code was actually unused.<br>
-<br>
-base/gsicc_manage.c<br>
-base/gsicc_manage.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-20 10:54: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=b2c68b707812f6a258c991241b4dde4fd4a8cc1d">b2c68b707812f6a258c991241b4dde4fd4a8cc1d</a>
-<blockquote>
-<p>
- Coverity ID: 122659 further impossible alpha code tweak<br>
-<br>
- A while back, we identified code in gx_alloc_char_bits() that, due to long<br>
- standing changes in the setup code, simply cannot be used. We opted to<br>
- conditionally compile out that code, just in case.<br>
-<br>
- Coverity spotted that some later code was dependant on that now redundant code.<br>
-<br>
- So, add the later code to the conditionally compiled out code.<br>
-<br>
-base/gxccman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-20 10:47: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=29b831273bf8c7ed17835ab5ece59ea7e87ff07e">29b831273bf8c7ed17835ab5ece59ea7e87ff07e</a>
-<blockquote>
-<p>
- Coverity ID: 94750 change where we get the memory pointer.<br>
-<br>
- Use a guaranteed non-NULL pointer from which to get the memory pointer for<br>
- a fatal error message print out.<br>
-<br>
-base/gxccman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-19 14:46: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=bb5ed57c5c00d139285f16f6d69505e6d0d95f9e">bb5ed57c5c00d139285f16f6d69505e6d0d95f9e</a>
-<blockquote>
-<p>
- Coverity ID: 125640: check return from clump_locate_ptr()<br>
-<br>
- In this, clump_locate_ptr() should never fail in this location, if it does, it<br>
- it is a catastrophic failure, and we should just abort.<br>
-<br>
-psi/ialloc.c<br>
-psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-19 16:31:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb4a2e734e71c86261d386ce53ab92605dff503a">fb4a2e734e71c86261d386ce53ab92605dff503a</a>
-<blockquote>
-<p>
- Coverity ID: 94516 remove spurious range check code.<br>
-<br>
- The code alleged to be checking a length value was valid, but in fact could not<br>
- fail, and thus had no effect.<br>
-<br>
-psi/iscanbin.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-19 15:52:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f196b120c236993ae5f01ccd5415be5da7c751c3">f196b120c236993ae5f01ccd5415be5da7c751c3</a>
-<blockquote>
-<p>
- Coverity ID 94563: move the fallback assignment.<br>
-<br>
- When a gc run is triggered, if a specific space (local, global etc) isn't<br>
- specified, we try to find the space which caused it. In case it wasn't found,<br>
- we were setting the pointer to the allocator, but doing so in the wrong place.<br>
-<br>
- Move it to a more suitable place.<br>
-<br>
-psi/ireclaim.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-19 15:13: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=cb988d950c8f154e62f28b2755f2205af9b98060">cb988d950c8f154e62f28b2755f2205af9b98060</a>
-<blockquote>
-<p>
- Coverity ID: 94590 initialize ierror ref contents.<br>
-<br>
-psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-19 15:02: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=7b0be9cc0ea4f8e2fc764b57d5c70a35d4f7b0ce">7b0be9cc0ea4f8e2fc764b57d5c70a35d4f7b0ce</a>
-<blockquote>
-<p>
- Coverity ID: 94749 check a pointer != NULL<br>
-<br>
- When we search for the ID of a save level, it should never be possible to reach<br>
- the point where save == NULL when we exit the loop - if it does, it implies<br>
- a serious failure (most likely memory corruption), so return a totally<br>
- impossible value.<br>
-<br>
-psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-19 14:55: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=114451da4f27bbfda36bdde201ba7bdc960a3760">114451da4f27bbfda36bdde201ba7bdc960a3760</a>
-<blockquote>
-<p>
- Coverity ID: 95036: ignore return from interp_reclaim<br>
-<br>
- In this case, we can safely ignore it, as it will be be triggered and handled<br>
- at the top, next time through the loop.<br>
-<br>
-psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-19 09:23:08 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d807b791559f64276d6fb1676fbab2cb66140bd0">d807b791559f64276d6fb1676fbab2cb66140bd0</a>
-<blockquote>
-<p>
- Remove deprecated Pn macros for pre-ANSI compilers<br>
-<br>
- These were, apparently, left in place for the benefit of libjpeg, but that has<br>
- long since ceased to be necessary, so they were just clutter.<br>
-<br>
-base/jpeg.mak<br>
-base/lib.mak<br>
-base/stdpn.h<br>
-base/stdpre.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-19 09:25:36 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d2772b4017397ebd3ad69022ed440b084812096a">d2772b4017397ebd3ad69022ed440b084812096a</a>
-<blockquote>
-<p>
- Add to a comment about a deprecated function<br>
-<br>
-base/gsdevice.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-18 18:35: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=7d3dc0cccbf7b1a1d0a273eb78287bf8bb659fb8">7d3dc0cccbf7b1a1d0a273eb78287bf8bb659fb8</a>
-<blockquote>
-<p>
- Remove gs_no_glyph, gs_min_cid_glyph and gs_max_glyph<br>
-<br>
- These were legacy remnants. Replace their remaining uses with the upper case,<br>
- non-deprecated equivalents.<br>
-<br>
-base/gsccode.h<br>
-base/gscencs.c<br>
-base/gscencs.h<br>
-base/gschar0.c<br>
-base/gsfcid.c<br>
-base/gsfcid2.c<br>
-base/gsfcmap.c<br>
-base/gsfcmap.h<br>
-base/gsfcmap1.c<br>
-base/gsfont.c<br>
-base/gstext.c<br>
-base/gxchar.c<br>
-base/gxfapi.c<br>
-base/gxfont.h<br>
-devices/gdevtrac.c<br>
-devices/vector/gdevpdtd.c<br>
-devices/vector/gdevpdte.c<br>
-devices/vector/gdevpdtf.c<br>
-devices/vector/gdevpsf.h<br>
-devices/vector/gdevpsf1.c<br>
-devices/vector/gdevpsf2.c<br>
-devices/vector/gdevpsft.c<br>
-devices/vector/gdevpsfu.c<br>
-pcl/pcl/pctext.c<br>
-pcl/pl/plchar.c<br>
-pcl/pl/plfapi.c<br>
-psi/zbfont.c<br>
-psi/zchar.c<br>
-psi/zchar32.c<br>
-psi/zcharout.c<br>
-psi/zcharx.c<br>
-psi/zfcid0.c<br>
-psi/zfcid1.c<br>
-psi/zfont.c<br>
-psi/zfont32.c<br>
-psi/zfont42.c<br>
-xps/xpscff.c<br>
-xps/xpsttf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-18 18:40: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=b1b8ec293a199d58742c3ed45c47f249359e3392">b1b8ec293a199d58742c3ed45c47f249359e3392</a>
-<blockquote>
-<p>
- Coverity ID: 94531<br>
-<br>
- Remove the check against GS_MAX_GLYPH since that is the maximum value of<br>
- the gs_glyph data type, anyway.<br>
-<br>
-psi/zfont42.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-18 18:32: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=3e210f8e786464ec1f4ec8524abdf8f6a9a6f39b">3e210f8e786464ec1f4ec8524abdf8f6a9a6f39b</a>
-<blockquote>
-<p>
- Fix the PCL and XPS .so builds.<br>
-<br>
- The soname value wasn't being set correctly, so they both ended up being called<br>
- libgs.so... internally.<br>
-<br>
-Makefile.in<br>
-base/macosx.mak<br>
-base/unix-dll.mak<br>
-base/unix-gcc.mak<br>
-base/unixansi.mak<br>
-base/unixlink.mak<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-17 20:03: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=b43055a17fe8369daa100ce5b522c86f215567fd">b43055a17fe8369daa100ce5b522c86f215567fd</a>
-<blockquote>
-<p>
- PCL/XPS so targets typo<br>
-<br>
- Remove the autotools markers (&quot;@&quot;) and replace with make variable markers<br>
- (&quot;$()&quot;).<br>
-<br>
-base/unix-dll.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-19 17:48:14 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=07b3d1c457b146d7fc6b2e63a680366cd3002e52">07b3d1c457b146d7fc6b2e63a680366cd3002e52</a>
-<blockquote>
-<p>
- Update of ICC creator code<br>
-<br>
- The code had suffered some bit rot due to the movement of MS to<br>
- unicode with the newer versions of Visual studio. I updated the<br>
- project to VS 2013, fixed several bugs dealing with unicode, cleaned<br>
- the code, and fixed issues in the creation of PS-like CMYK ICC profiles<br>
- when using the UCR/BG data. Updated the UCR/BG data and included an<br>
- example with Max K. Included ICC profiles for Max K and No K. The<br>
- Max K profile would be useful in for text output with -sTextICCProfile=max_k.icc<br>
-<br>
-toolbin/color/icc_creator/ICC_Creator.sln<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_Creator.rc<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_Creator.vcproj<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_Creator.vcxproj<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_Creator.vcxproj.filters<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.h<br>
-toolbin/color/icc_creator/ICC_Creator/icc_create.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/icc_create.h<br>
-toolbin/color/icc_creator/README.txt<br>
-toolbin/color/icc_creator/max_k.icc<br>
-toolbin/color/icc_creator/no_k.icc<br>
-toolbin/color/icc_creator/ucr_bg.txt<br>
-toolbin/color/icc_creator/ucr_bg_max_k.txt<br>
-toolbin/color/icc_creator/ucr_bg_no_k.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-16 10:53:53 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1e5eef9a6e62424a07194a5e04300d84a749491">d1e5eef9a6e62424a07194a5e04300d84a749491</a>
-<blockquote>
-<p>
- Fix Coverity 94799 Explicit null dereference<br>
-<br>
- Make sure we do not deference the backdrop if it is NULL when we are doing<br>
- are group composing.<br>
-<br>
-base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-18 21:36:43 +0100
-</strong>
-<br>Mistry &lt;smistry@trl.co.uk&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e426b1593a4b682f3cc83fc9559e4acc16ea1744">e426b1593a4b682f3cc83fc9559e4acc16ea1744</a>
-<blockquote>
-<p>
- Bug 696786 : Prevent checking too early for buffer overrun<br>
-<br>
- The code has reached near the end of the buffer so you can not just take the<br>
- last 4 bytes, in this case you have to read any remaining bytes and make a<br>
- return value based on that, in this edge case you have no bytes to read so the<br>
- return value is zero.<br>
-<br>
-jbig2dec/jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-18 18:54: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=1cfc3d978813a6ce0564a50718bb742024e62cdd">1cfc3d978813a6ce0564a50718bb742024e62cdd</a>
-<blockquote>
-<p>
- Coverity IDs 94953, 94964<br>
-<br>
- Move a pointer dereference into the block that conditionally executes<br>
- when the pointer is non-NULL. I think the pointer can never be NULL<br>
- but we were doing the test anyway.<br>
-<br>
- Alter the declaration of a function, it was incorrect before.<br>
-<br>
-devices/gxfcopy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-09 12:55:56 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=33a1bb7fc1cc618e7f562a6231fc48755f4dad74">33a1bb7fc1cc618e7f562a6231fc48755f4dad74</a>
-<blockquote>
-<p>
- Fix Coverity ID's: 94500, 94697, 94819, 94829, 94996, 126373.<br>
-<br>
-base/gxclimag.c<br>
-base/gxclpath.c<br>
-base/gxclrast.c<br>
-base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-18 14:44: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=49f43fb5c95e0bf3f3f44a9cb33393470d2388b6">49f43fb5c95e0bf3f3f44a9cb33393470d2388b6</a>
-<blockquote>
-<p>
- Coverity IDs 126566, 126567, 126568<br>
-<br>
- More dead code exposed by the macro removal in gsbitops.h.<br>
-<br>
-base/gximage3.c<br>
-devices/gdevxalt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-18 14:10: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=13b3c67366aef69beed5f9c7e058c59a03714997">13b3c67366aef69beed5f9c7e058c59a03714997</a>
-<blockquote>
-<p>
- Coverity ID 126579<br>
-<br>
- Explicit cast to avoid implicit cast and potential sign extension.<br>
- Can't actually happen, but the explicit cast costs no more than the<br>
- implicit, and avoids the warning.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-18 13:51: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=991a906e492b23dc1199dc47cb6d48f25d2b9fc9">991a906e492b23dc1199dc47cb6d48f25d2b9fc9</a>
-<blockquote>
-<p>
- Coverity IDs 126564, 126565<br>
-<br>
- Remove some dead code. This was also present in the macro version of<br>
- this code, revealed by move to inline functions.<br>
-<br>
-base/gsflip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-18 13:28:13 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=93f26fbb884a6a26016c86e25c64f2bcd061949f">93f26fbb884a6a26016c86e25c64f2bcd061949f</a>
-<blockquote>
-<p>
- Coverity IDs 126571, 126572, 126577<br>
-<br>
- Fallout from the change from macros to inline functions, change a function<br>
- parameter from uint32 * to ushort * and remove the redundant type casts<br>
-<br>
- Change a variable from unint32 to ushort<br>
-<br>
- Finally, remove a redundant check for &lt; 0 on an unsigned variable.<br>
-<br>
-base/gdevdgbr.c<br>
-base/gdevmpla.c<br>
-base/gsbitops.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-18 08:49: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=a045d4290e2b371ed4ed8de210f8a9efa4989d01">a045d4290e2b371ed4ed8de210f8a9efa4989d01</a>
-<blockquote>
-<p>
- Various Coverity issues - 126569 126583<br>
-<br>
- While moving from macros to inline functions:<br>
- Missed a pointer dereference, fixed.<br>
- Missed an 'inline' declaration, fixed.<br>
-<br>
- Fixed some casts of shifts which were implicitly promoted resulting in<br>
- potential sign problems. These were also present with the former<br>
- macros, but are fixed now.<br>
-<br>
-base/gsbitops.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-13 15:11: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=26aa9f163805f69ec54d05a1237aebbda719706a">26aa9f163805f69ec54d05a1237aebbda719706a</a>
-<blockquote>
-<p>
- Font copying - fix the dropping of 'extension' (duplicate) glyphs<br>
-<br>
- Bug #696777 &quot;AddressSanitizer heap-buffer-overflow in copied_drop_extension_glyphs&quot;<br>
-<br>
- When we find that we have a glyph which is processed with different<br>
- /Widths, we need to encode it specially in the font. We do this by<br>
- extending the glyph name with a ~GS~x where x is an integer.<br>
-<br>
- For output though (pdfwrite and friends) we really don't want to emit<br>
- these non-standard glyphs which are duplicates of existing glyphs, the<br>
- Widths emission should take care of the metrics problem for us. (in<br>
- fact we deal with it by leaving ghe Widths alone and alter the<br>
- spacing with a TJ operator).<br>
-<br>
- This is supposed to be performed by 'copied_drop_extension_glyphs()'<br>
- but the code for detecting additional duplicates was incorrect and<br>
- caused us to read off a block of memory. Fixing that revealed another<br>
- problem, the code which was supposed to truncate the 'extended' name<br>
- to the normal name was using the wrong loop index and was updating<br>
- the 'non-extended' rather than 'extended' glyph name, which of course<br>
- had no effect.<br>
-<br>
- I've fixed both cases, and altered the names of the loop counters to<br>
- be a little more descriptive in the hope of avoiding future such<br>
- problems.<br>
-<br>
- This then exposed faults in the type 1 to Type 2 (CFF) conversion<br>
- code which simply wasn't expecting slots to be unused (and as Chris<br>
- points out rather begs the question of what this is for). Fixing this<br>
- required ratehr more extensive changes to the converter, but it seems<br>
- to work correctly now.<br>
-<br>
- No differences expected<br>
-<br>
-devices/gxfcopy.c<br>
-devices/vector/gdevpsf2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-17 12:05: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=fd35140f473cd64f7c27daae268858e2277127a9">fd35140f473cd64f7c27daae268858e2277127a9</a>
-<blockquote>
-<p>
- Bug 696782: Fix the asciitilde glyph.<br>
-<br>
- The asciitilde glyph was at the wrong y offset, meaning it appeared at the top<br>
- of the font bounding box, rather than near the middle of it.<br>
-<br>
-Resource/Font/NimbusSanL-ReguCond<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-17 08:06:57 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0b2375b2e94e08a13bf972c22eafc9c9917421da">0b2375b2e94e08a13bf972c22eafc9c9917421da</a>
-<blockquote>
-<p>
- Missing va_end.<br>
-<br>
-pcl/pcl/pcstatus.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-17 07:58:27 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b0a19d008448ca5952506f6bfc67f5982de78a07">b0a19d008448ca5952506f6bfc67f5982de78a07</a>
-<blockquote>
-<p>
- Faulty parser control flow fixed.<br>
-<br>
- The PCL parser did not properly transition from scanning data to<br>
- scanning parameters in short hand mode. Coverity uncovered the<br>
- problem (102252).<br>
-<br>
-pcl/pcl/pcparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-13 11:40:36 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39b2eb4200b81e081fb97be0df4575c5ceb3afd3">39b2eb4200b81e081fb97be0df4575c5ceb3afd3</a>
-<blockquote>
-<p>
- Coverity fixes.<br>
-<br>
- pcht.c 102234: parameter list released twice.<br>
- pcsymbol.c 102225: insecure data handling.<br>
-<br>
- The latter is not a bug as far as we can tell but the readability of the<br>
- code and directness of the checks have been improved anyway.<br>
-<br>
-pcl/pcl/pcht.c<br>
-pcl/pcl/pcsymbol.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-13 11:31:30 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c9e348bde9a8f007352c88477fb3655291b12f8">6c9e348bde9a8f007352c88477fb3655291b12f8</a>
-<blockquote>
-<p>
- Fix symbol set lookup.<br>
-<br>
- The PJL symbol set lookup could potentially dereference NULL for a<br>
- couple of the sets, also we rebuild the table to simply return the<br>
- associated symbol set number, there is no need to calculate the number<br>
- at runtime.<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-13 10:01: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=fcedd5c71e5edac73f4240c635c6280dce918152">fcedd5c71e5edac73f4240c635c6280dce918152</a>
-<blockquote>
-<p>
- pdfwrite - prevent buffer overrun<br>
-<br>
- While investigating Bug #696777, the new rectangular subpath code threw<br>
- errors with address sanitizer. This was due to trying to pick up the<br>
- last segment co-ordinate using the loop counter, when it should have<br>
- been using the segment index.<br>
-<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-12 17:38: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=6bba1f6fa4d48e9651873d34815ede36bca73a74">6bba1f6fa4d48e9651873d34815ede36bca73a74</a>
-<blockquote>
-<p>
- Bug 696776: Allow gs run without pdfwrite installed.<br>
-<br>
- With the build consolidation change, one of the requirements was that there<br>
- should be no dependencies in the graphics library build objects on any of<br>
- the interpreter objects.<br>
-<br>
- That meant that gs_pdfwr.ps always gets built in, and then run by the<br>
- initialization code, which then throws an error when pdfwrite is not<br>
- present.<br>
-<br>
- To handle this, check if pdfwrite is available, and if not, skip executing<br>
- the contents of gs_pdfwr.ps.<br>
-<br>
-Resource/Init/gs_pdfwr.ps<br>
-devices/devs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-13 08:29:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f7b9321be1a0d029e1465af699dff52319b1c906">f7b9321be1a0d029e1465af699dff52319b1c906</a>
-<blockquote>
-<p>
- Revert the use of gp_get_realtime in pdfwrite<br>
-<br>
-base/gp_win32.c<br>
-base/time_.h<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-09 11:40: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=14e151e48e07af8eee5efbbc336e1a1b59eb93a2">14e151e48e07af8eee5efbbc336e1a1b59eb93a2</a>
-<blockquote>
-<p>
- Build PCL and XPS as shared library and DLL<br>
-<br>
- Also, most of building gpdl as a shared lib and DLL is here, too.<br>
-<br>
- There isn't really an &quot;API&quot; here: the library has one entry point:<br>
- &quot;pl_main_aux()&quot;, this is really just the build skeleton on which we can<br>
- assemble a real API.<br>
-<br>
- On Windows, PCL, XPS and (if forced to build) GPDL will all default to building<br>
- a DLL and a &quot;loader&quot; executable (rather than the monolithic exe it build<br>
- previously). The monolithic builds can still be done by passing nmake the<br>
- MAKEDLL=0 option.<br>
-<br>
- On other (Unix-like) systems, they will default to the monolithic builds.<br>
-<br>
- This all mirrors the gs builds.<br>
-<br>
-Makefile.in<br>
-base/gscdef.c<br>
-base/std.h<br>
-base/unix-dll.mak<br>
-pcl/pl/gpcl6dll32.def<br>
-pcl/pl/gpcl6dll64.def<br>
-pcl/pl/gpdldll32.def<br>
-pcl/pl/gpdldll64.def<br>
-pcl/pl/gxpsdll32.def<br>
-pcl/pl/gxpsdll64.def<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plwimg.c<br>
-pcl/pl/plwmainc.c<br>
-pcl/pl/plwreg.c<br>
-psi/msvc.mak<br>
-xps/xps.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-12 12:20: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=a39fa755db3f83a1d1fd8611d66dde487ed95f9d">a39fa755db3f83a1d1fd8611d66dde487ed95f9d</a>
-<blockquote>
-<p>
- Typo in language.htm<br>
-<br>
- Bug #696775 &quot;Typo in documentation&quot;<br>
-<br>
- Noticed and reported by &quot;rrt@sc3d.org&quot;, fixed ehre.<br>
-<br>
-doc/Language.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-12 11:27:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3e825c0ee714a26633395e95bdf143d30b14fc28">3e825c0ee714a26633395e95bdf143d30b14fc28</a>
-<blockquote>
-<p>
- Fix gp_get_realtime commit<br>
-<br>
- The gp_get_realtime commit attempted top use both the upper and lower<br>
- values in the long[2] array, this turns out to be a bad idea on Unix<br>
- systems, because that uses timeofday() instead of time(), and results<br>
- in a time_t which causes a GPF in gmtimte() (NB I think its pretty poor that a<br>
- function which takes a 64-bit value can cause a GPF if the value is<br>
- sufficiently large!)<br>
-<br>
- Instead use only the bottom long. This will, eventually, cause us to<br>
- write incorrect time stamps (when we overflow a long), we will have<br>
- to look into that when the time comes.<br>
-<br>
- At the same time fix the definitions of gp_get_realtime() and<br>
- gp_get_usertime() in gp.h as these were incorrect.<br>
-<br>
-base/gp.h<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-11 16:15: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=646248bf7730c8d2ecf4ff2d06c494a5c280d211">646248bf7730c8d2ecf4ff2d06c494a5c280d211</a>
-<blockquote>
-<p>
- Make pdfwrite use the OS-agnostic gp_get_realtime () function<br>
-<br>
- Also fix the Windows go_get_realtime() function so that it returns<br>
- the same values as the other OS's<br>
-<br>
- The change in time_.h is to prevent the definition of timeval if we<br>
- have already included windows.h (_WINDOWS_ is defined) as this also<br>
- defines timeval (actually in winsock.h, claims to be copied from a BSD<br>
- header).<br>
-<br>
-base/gp_win32.c<br>
-base/time_.h<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-11 09:59:09 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=545defc11cdb1b7a1009ccf8103417273fb3d7ee">545defc11cdb1b7a1009ccf8103417273fb3d7ee</a>
-<blockquote>
-<p>
- Coverity fixes.<br>
-<br>
- 122662 plparams.c: resource leak.<br>
- 122664 plparams.c, 122663 pjparse.c: unnecessary null check.<br>
- 122661 plparams.c: negative returns.<br>
- 102248 pcpage.c: uninitialized pointer write.<br>
- 102237 pjparse.c: uninitialized variable.<br>
-<br>
-pcl/pcl/pcpage.c<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/plparams.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-11 14:34: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=4e9c4db88f1aff478230b7cb0c32eb60846231a3">4e9c4db88f1aff478230b7cb0c32eb60846231a3</a>
-<blockquote>
-<p>
- remove an unused variable<br>
-<br>
- commit c4a33f573adbf8627f08407e4357475285b46cf0 replaced the variable<br>
- 'int i' with 'unsigned int j', but left the definition of i, which<br>
- meant it was then unused leading to a cppcheck warning.<br>
-<br>
- Simply remove the now unused variable.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-11 14:01:47 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d5008bf9092e99b5eb7f295c9d684850bf2aa66f">d5008bf9092e99b5eb7f295c9d684850bf2aa66f</a>
-<blockquote>
-<p>
- Remove a load of macros in the graphics library<br>
-<br>
- The 'load' and 'store' macros were deemed offensive for a number of<br>
- reasons; they declared variables, hiding them from casual view, they<br>
- hid flow control (switch statements started in one macro, ended in<br>
- another), returns from inside macros, some macros were not (and could<br>
- not be) bounded by &quot;do{...} while&quot; which means care needed to be taken<br>
- with ';' and were very deeply nested, the names chose for the macros<br>
- made them look like functions, finally macros are hard to debug, even<br>
- with a macro-expanding debugger.<br>
-<br>
- Additionally there were the 'LINE_ACCUM' macros, some of which simply<br>
- called the 'load/store' macros directly, which just added another<br>
- layer of obfuscation, particularly since these macros were defined in<br>
- a different header file. Macros could be nested 4 or 5 levels deep.<br>
-<br>
- This commit finishes removing all but one of the macros, the last<br>
- remaining macro has been renamed to upper case to make it clearer that<br>
- it is a macro. It can't easily be removed since it depends on the size<br>
- of gx_color_index, which is a compile time #define.<br>
-<br>
- The functionality of the macros has either been expanded in line or<br>
- replaced with inline functions declared in gsbitops.h. The majority<br>
- of the macros have been replaced with functions, even for small functions<br>
- where it seemed useful to keep the name as a description of the actual<br>
- functionality.<br>
-<br>
- I don't anticipate any differences, but I think this makes the code<br>
- easier to understand, easier to debug, and therefore easier to maintain.<br>
-<br>
-base/gdevdbit.c<br>
-base/gdevdgbr.c<br>
-base/gdevmpla.c<br>
-base/gsalphac.c<br>
-base/gsbitops.c<br>
-base/gsbitops.h<br>
-base/gsflip.c<br>
-base/gxcindex.h<br>
-base/gximag3x.c<br>
-base/gximage3.c<br>
-base/gxiscale.c<br>
-devices/gdevpng.c<br>
-devices/gdevxalt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-10 07:21:45 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=473afa3fbc71bd8cd1814f5e9d7f551ebbda436d">473afa3fbc71bd8cd1814f5e9d7f551ebbda436d</a>
-<blockquote>
-<p>
- Fix Coverity identified dereferences before null check.<br>
-<br>
- Coverity id's: 102199, 10220[012]<br>
-<br>
-pcl/pcl/pcdraw.c<br>
-pcl/pcl/pcfrgrnd.c<br>
-pcl/pxl/pxgstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-09 10:42:50 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a09336ddb6257103ea9d020ed8ace474e1e12df6">a09336ddb6257103ea9d020ed8ace474e1e12df6</a>
-<blockquote>
-<p>
- Fix Coverity identified potential buffer overflows.<br>
-<br>
- Coverity numbers: 122665 (#1 - #8). Also fixes a reversed argument<br>
- problem with an unimplemented function (100212) and a typo with a<br>
- previous coverity problem was fixed.<br>
-<br>
-pcl/pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-10 10:15:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2bf16c4c6942ffe38ded65df1d17e485843de4f0">2bf16c4c6942ffe38ded65df1d17e485843de4f0</a>
-<blockquote>
-<p>
- Remove remaining persistent cache code.<br>
-<br>
-base/gp.h<br>
-base/gp_dvx.c<br>
-base/gp_mac.c<br>
-base/gp_mswin.c<br>
-base/gp_os2.c<br>
-base/gp_os9.c<br>
-base/gp_vms.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-06 15:54: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=db1ecd47087fa139e310d42772cb912184f5bc6a">db1ecd47087fa139e310d42772cb912184f5bc6a</a>
-<blockquote>
-<p>
- Remove the (unused) &quot;persistent cache&quot; code<br>
-<br>
-base/gp_unix_cache.c<br>
-base/unix-aux.mak<br>
-psi/zmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-09 09:28:00 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c4a33f573adbf8627f08407e4357475285b46cf0">c4a33f573adbf8627f08407e4357475285b46cf0</a>
-<blockquote>
-<p>
- Change max_components and num_components in dev.color_info to uchar<br>
-<br>
- There are locations in the code where Coverity has complained about<br>
- code logic that resulted in passing of unintialized values that<br>
- could only occur if num_components &lt; 0 . Since this should never<br>
- be the case, we will make it clear by setting num_components and<br>
- max_components to uchar. This will limit our support to 256 colors<br>
- by a device.<br>
-<br>
-base/gdevdbit.c<br>
-base/gdevddrw.c<br>
-base/gdevdevn.c<br>
-base/gdevdevn.h<br>
-base/gdevdgbr.c<br>
-base/gdevdrop.c<br>
-base/gdevmem.c<br>
-base/gdevmpla.c<br>
-base/gdevp14.c<br>
-base/gdevplnx.c<br>
-base/gscspace.c<br>
-base/gsdparam.c<br>
-base/gsicc_cache.c<br>
-base/gsovrc.c<br>
-base/gsptype2.c<br>
-base/gxblend1.c<br>
-base/gxclist.c<br>
-base/gxclrast.c<br>
-base/gxclread.c<br>
-base/gxclrect.c<br>
-base/gxcmap.c<br>
-base/gxdcolor.c<br>
-base/gxdevcli.h<br>
-base/gxdtfill.h<br>
-base/gxpcmap.c<br>
-base/gxshade6.c<br>
-cups/gdevcups.c<br>
-devices/gdevcmykog.c<br>
-devices/gdevpbm.c<br>
-devices/gdevrinkj.c<br>
-devices/gdevxcf.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpsdi.c<br>
-psi/zcolor.c<br>
-psi/zdpnext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-09 11:04:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ccd831b1b17b7e5f62e43583da51505d202b4de7">ccd831b1b17b7e5f62e43583da51505d202b4de7</a>
-<blockquote>
-<p>
- Coverity ID 126372 - incorrect test '||' instead of '&amp;&amp;'<br>
-<br>
-base/ttfmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-09 08:38: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=16328264c44400e242fd2a7c0a2b38ef16abfe3c">16328264c44400e242fd2a7c0a2b38ef16abfe3c</a>
-<blockquote>
-<p>
- Coverity IDs 102152, 126374 - 1x check return value and 3x cleanup<br>
-<br>
- Missed a check of the return value from fseek in a prior commit and<br>
- 3 cases where I added a check of a file operation, exited the function<br>
- on error, but did not close the locally opened file.<br>
-<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-09 08:30: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=ef840222e42df8d69d3e3f8a0f153c8cbe0b96db">ef840222e42df8d69d3e3f8a0f153c8cbe0b96db</a>
-<blockquote>
-<p>
- Coverity ID 102187 (again) - remove 2 more tests of unsigned variables &gt; 0<br>
-<br>
- Missed the fact there were multiple occurrences in the first commit<br>
-<br>
-xps/xpsttf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-07 09:41: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=5aef585cd506caad237972953fe62f013f0fd4e2">5aef585cd506caad237972953fe62f013f0fd4e2</a>
-<blockquote>
-<p>
- Replace the 'sample_load*' macros with inline functions<br>
-<br>
-base/gdevdgbr.c<br>
-base/gdevmpla.c<br>
-base/gsalphac.c<br>
-base/gsbitops.c<br>
-base/gsbitops.h<br>
-base/gximag3x.c<br>
-base/gximage3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-08 10:15:11 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49a22e649644cc71e42e8f87954a01322133e96e">49a22e649644cc71e42e8f87954a01322133e96e</a>
-<blockquote>
-<p>
- Fix memset of incorrect size.<br>
-<br>
-base/gp_psync.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-07 12:28:18 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6329a63a5b358ff2522c9a2fee04afc7dea6e125">6329a63a5b358ff2522c9a2fee04afc7dea6e125</a>
-<blockquote>
-<p>
- Fix Coverity ID's in gdevp14.c (too many for one line)<br>
-<br>
- ID list: 95577, 94594. 94612. 94628, 94637, 94689, 94958, 94978, 95032<br>
- 95033, 96060<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-06 17:09:04 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=43d009b93762d1c69d6f7d08b2fb7962e1ccba78">43d009b93762d1c69d6f7d08b2fb7962e1ccba78</a>
-<blockquote>
-<p>
- Coverity 95029: Out of bounds write in gdevijs.c<br>
-<br>
- While parsing params, if we hit the end of the buffer, stop<br>
- rather than trying to write into it.<br>
-<br>
-devices/gdevijs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-06 16:16: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=429bddce6bb0089d247e7bd6c32dbb6b7d7efdeb">429bddce6bb0089d247e7bd6c32dbb6b7d7efdeb</a>
-<blockquote>
-<p>
- Coverity 95056: Uninitalised variable use.<br>
-<br>
- The analysis of this case going wrong relies on the variable being<br>
- negative. Change it to be unsigned to avoid this.<br>
-<br>
-base/sfilter2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-06 16:07:51 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20b13a63253d1271ee1b3eeaea090e269a0f27fb">20b13a63253d1271ee1b3eeaea090e269a0f27fb</a>
-<blockquote>
-<p>
- MSVC: Add missing jpegxr directory to solution<br>
-<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-06 16:05:18 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5e075d70152429f2216ba5d002bdc9e5dadfc14">b5e075d70152429f2216ba5d002bdc9e5dadfc14</a>
-<blockquote>
-<p>
- Coverity 102233: Uninitialised variable use.<br>
-<br>
- Looks like an initialisation was dropped. Copying from similar<br>
- functions as inspection suggets this is correct.<br>
-<br>
-jpegxr/r_strip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-06 08:47:41 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=224a4a9a3315873c59e6d688635615ed1a5be3d5">224a4a9a3315873c59e6d688635615ed1a5be3d5</a>
-<blockquote>
-<p>
- Various Coverity fixes<br>
-<br>
- pjparse.c: 102194 Resource leak and 102181 argument can't be negative,<br>
- and 102171 logically dead code.<br>
- pjparsei.c: 102174 Dereference after null.<br>
- plfont.c: 102189 unsigned compare against 0.<br>
- pxfont.c: 102176 Deref after null check.<br>
-<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/plfont.c<br>
-pcl/pxl/pxfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 15:44:56 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5f12ea458d83bf9f301fae6066526c4f890bae06">5f12ea458d83bf9f301fae6066526c4f890bae06</a>
-<blockquote>
-<p>
- Fix many unchecked returns in PCL.<br>
-<br>
- Coverity ids: 10215[013568], 10216[0579].<br>
-<br>
-pcl/pcl/pcsfont.c<br>
-pcl/pcl/pgchar.c<br>
-pcl/pcl/pginit.c<br>
-pcl/pcl/pglfill.c<br>
-pcl/pcl/rtmisc.c<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/plmain.c<br>
-pcl/pxl/pxgstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-05 10:22:51 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e1d95eea940bca0892f016cd79d6ee72a2219ba">8e1d95eea940bca0892f016cd79d6ee72a2219ba</a>
-<blockquote>
-<p>
- Bug 696703: Shading disappears at high dpi.<br>
-<br>
- The Shading doesn't disappear, it simply plots solid white.<br>
-<br>
- This is due to an overflow in the tensor patch calculations.<br>
-<br>
- (fixed + fixed + fixed)/3 can overflow.<br>
-<br>
- Change this to be (int64_t + int64_t + int64_t)/3.<br>
-<br>
- For efficiency (and improved accuracy) we postpone the /3 until<br>
- the end of the series of operations that use it (where it becomes<br>
- a /9).<br>
-<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-05 13:15:25 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7032b71519c04432f2c56748103bd9dfe32ac6ff">7032b71519c04432f2c56748103bd9dfe32ac6ff</a>
-<blockquote>
-<p>
- Revert &quot;Makefile for Android MuPDF libgs.so&quot;<br>
-<br>
- This reverts commit e350758ceb8d9f7ec6bb209908a6ce1fe35e2397.<br>
-<br>
- Committed in error.<br>
-<br>
-Makefile.android<br>
-arch/android.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-05 10:19: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=219ac028f804f8470faf502830c545b7858845b4">219ac028f804f8470faf502830c545b7858845b4</a>
-<blockquote>
-<p>
- Remove free variables from macros.<br>
-<br>
- In macro-hell, the lowest level is reserved for macros that<br>
- rely on free variables. While removing the macros would be<br>
- nicer, this at least moves it up a level.<br>
-<br>
-base/gsshade.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-05 09:14:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7cef5b5e9746ade53779ae13989e3d070337ac68">7cef5b5e9746ade53779ae13989e3d070337ac68</a>
-<blockquote>
-<p>
- Coverity IDs 94574, 94743, 94524, 94691<br>
-<br>
-<br>
- ttfmain.c:<br>
- Use 'code' instead of 'error', error is the wrong variable to test<br>
- Remove pointless code with no effect<br>
-<br>
- ttinterp.c:<br>
- Correct a copy/paste error (cur_x should be cur_y)<br>
- remove pointless self-assignment<br>
-<br>
-base/ttfmain.c<br>
-base/ttinterp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-05 06:59: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=e03821104b5752c7b343f7b839ec9a9c01c5f4b1">e03821104b5752c7b343f7b839ec9a9c01c5f4b1</a>
-<blockquote>
-<p>
- Fix to commit 5b173d99c6ed3ebbd84eff6e63e987441a5da10d<br>
-<br>
- Slightly over-enthusiastic commit, potentially tried to free an object<br>
- 'part' before it had been created. Three occurrences in three different<br>
- error conditions.<br>
-<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 18:55:36 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b916edd3554e42a4cd3de4c9bd17450e9cbb202">7b916edd3554e42a4cd3de4c9bd17450e9cbb202</a>
-<blockquote>
-<p>
- Fix Coverity ID 95026: Code not reachable -- seems to be editing error.<br>
-<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 13:19:59 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c2ba126a3ca1b740526b998e5e49a1c6c6f98ce8">c2ba126a3ca1b740526b998e5e49a1c6c6f98ce8</a>
-<blockquote>
-<p>
- Fix Coverity ID: 94491 Buffer not nul terminated.<br>
-<br>
- Leave room for the 'nul' in the count for strncpy.<br>
-<br>
-base/gxclread.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 13:24:45 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=88f49c9ae729336e8b1e68e2e8b231eac56b6d96">88f49c9ae729336e8b1e68e2e8b231eac56b6d96</a>
-<blockquote>
-<p>
- Coverity ID 119184<br>
-<br>
- Use floating point math for scaling the colors when doing the smoothness test.<br>
-<br>
-base/gscspace.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 13:14:02 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cbe50881d78c9c9bb13745569f806cb92bc14dd9">cbe50881d78c9c9bb13745569f806cb92bc14dd9</a>
-<blockquote>
-<p>
- Fix Coverity ID's: 94501, 94697 and 94712 (only last was non-trivial)<br>
-<br>
- The change to gximask.c checks to make sure that pcpath == NULL is never<br>
- dereferenced. Others were minor/trivial and easily fixed).<br>
-<br>
-base/gxclrast.c<br>
-base/gximask.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 11:02:10 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91158cabe4fd1d4faef98408ed3a36c3cbcc3ec7">91158cabe4fd1d4faef98408ed3a36c3cbcc3ec7</a>
-<blockquote>
-<p>
- Fix Coverity issue 94826, Buffer overrun, 94595 De-ref after NULL check<br>
-<br>
- The 'buf' declaration had 1 instead of 2 for the cap_join case.<br>
-<br>
- The dereference after NULL check is a warning, and two case call the<br>
- gx_default_fill_path (for shading fill) where ppath==NULL is OK, but<br>
- we add a check before emitting the ppath via cmd_put_path since that<br>
- _would_ dereference ppath elements. The first two are &quot;Ignore&quot;.<br>
-<br>
-base/gxclpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 08:51:41 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c98fd2a26df5498593e562b2551b637acebb2896">c98fd2a26df5498593e562b2551b637acebb2896</a>
-<blockquote>
-<p>
- Fix Coverity issues 94873, 121257, 121258 and 121859.<br>
-<br>
- in gxclpage, strncpy should have the copy length 1 less than buffer size<br>
- so that there will be room for the terminating nul. Also check return<br>
- from clist_close_writer_and_init_reader.<br>
-<br>
- The scan of saved_pages_keys needed the countof, not sizeof the array<br>
- of pointers (sizeof(a)/sizeof(a[0]))<br>
-<br>
-base/gxclpage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-03 18:00:39 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6a7e077b4936f82a32b5de1c944ae14c1881950">a6a7e077b4936f82a32b5de1c944ae14c1881950</a>
-<blockquote>
-<p>
- Fix potential cleanup error in pthreads handling.<br>
-<br>
- When creating a semaphore, if the mutex inits, but the condition<br>
- variable doesn't, we'd fail to destroy the mutex.<br>
-<br>
-base/gp_psync.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 09:52: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=5b173d99c6ed3ebbd84eff6e63e987441a5da10d">5b173d99c6ed3ebbd84eff6e63e987441a5da10d</a>
-<blockquote>
-<p>
- Coverity IDs 102152, 102157, 102159, 102161, 102162, 102164, 102182, 102183<br>
-<br>
- A load of unchecked return values from fseek/fread<br>
-<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 09:31:21 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab551afbaa92aacf0a451364e1273ff6e138fab5">ab551afbaa92aacf0a451364e1273ff6e138fab5</a>
-<blockquote>
-<p>
- Coverity ID 102152 - check if fseek failed and throw error if so<br>
-<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 09:25: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=4327987dc81df5f9e48af83de340af8973c529cb">4327987dc81df5f9e48af83de340af8973c529cb</a>
-<blockquote>
-<p>
- Coverity ID 102188 - remove redundant check if unsigned variable &lt; 0<br>
-<br>
-xps/xpsttf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 09:24: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=eeeeacfb3c62ec7954b3982edab3d39c4a4faccc">eeeeacfb3c62ec7954b3982edab3d39c4a4faccc</a>
-<blockquote>
-<p>
- Coverity ID 102187 - remove a redundant check of unsigned variable &lt; 0<br>
-<br>
-xps/xpsttf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 09:23: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=4b252650fa3d07348b680b3b19e3d3b8672eafc2">4b252650fa3d07348b680b3b19e3d3b8672eafc2</a>
-<blockquote>
-<p>
- Coverity ID 102187 - check and action a return code<br>
-<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 09:19: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=e99becee24fd1608084c734e34be5297ec3b4141">e99becee24fd1608084c734e34be5297ec3b4141</a>
-<blockquote>
-<p>
- Coverity ID 102257 - check and action a return value<br>
-<br>
- At the same time, cleaned up a whole load of potential memory leaks<br>
- on error conditions.<br>
-<br>
-xps/xpspage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 09:13: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=fca4b8dab7f588c9e7439ce7c06d347b6eeabf59">fca4b8dab7f588c9e7439ce7c06d347b6eeabf59</a>
-<blockquote>
-<p>
- Coverity ID 102184 - fix white space indenting<br>
-<br>
-xps/xpsmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 09:11:51 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=358c42de2691b9b0adb020244d6c70a20d94257c">358c42de2691b9b0adb020244d6c70a20d94257c</a>
-<blockquote>
-<p>
- Coverity ID 102195 - clean up memory on error exit.<br>
-<br>
-xps/xpsjxr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 09:08:36 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7c95a58878fd3fca7b964eb6e067cac55587286e">7c95a58878fd3fca7b964eb6e067cac55587286e</a>
-<blockquote>
-<p>
- Coverity ID 102246 - initialise a pointer variable<br>
-<br>
-xps/xpsgradient.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 09:04: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=b933637c55943ce50eefdd665666ec7fc90fa25b">b933637c55943ce50eefdd665666ec7fc90fa25b</a>
-<blockquote>
-<p>
- Coverity ID 102235 - initialise a memory array to 0<br>
-<br>
-xps/xpscff.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 08:43: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=e1ac3e1ce877bbbc89edbd719fab6ee304e0da38">e1ac3e1ce877bbbc89edbd719fab6ee304e0da38</a>
-<blockquote>
-<p>
- Luratech decoder - set the initial colour space to 'unset'<br>
-<br>
- If the image dictionary has a ColorSpace we set the colorspace member,<br>
- and if we get to disconvering the 'N' value, and its still unset then<br>
- we set it from the N value. But the Luratech decoder 'set_defaults'<br>
- method didn't initially set the colorspace member to 'gs_jpx_cs_unset'<br>
- so we might never set it from the /N value.<br>
-<br>
-base/sjpx_luratech.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-04 08:34:51 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b8678aa57feaf7fa60273f7c0e4fe28e44fa78c3">b8678aa57feaf7fa60273f7c0e4fe28e44fa78c3</a>
-<blockquote>
-<p>
- Coverity ID 94683 - check pointer is not NULL before dereference<br>
-<br>
- I'm pretty sure this can't happen, but this makes certain.<br>
-<br>
-psi/zcontext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-02 07:55:50 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d56fc8010e3c8456e565bab38eb54d7f218bed27">d56fc8010e3c8456e565bab38eb54d7f218bed27</a>
-<blockquote>
-<p>
- Prevent buffer overrun during image interpolation (NOCIE, UseFastColor)<br>
-<br>
- When using NOCIE and UseFastColor to revert to non-ICC color conversion,<br>
- we encounter a few instances where we decode samples, but the buffer was<br>
- not being allocated for it. Bug691466.pdf and fts_17_1700.pdf through 1707<br>
- and fts_31_3116.pdf were examples going to ppmraw.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-03 09:03: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=e4c06b9c1cd3130cbbd4fc5599e55056f2136cf1">e4c06b9c1cd3130cbbd4fc5599e55056f2136cf1</a>
-<blockquote>
-<p>
- Bug #692945 &quot; Need warn equivalent of -dPDFSTOPONERROR, like -dPDFSTOPONWARN&quot;<br>
-<br>
- This commit adds (and documents the new command line switch<br>
- PDFSTOPONWARNING. When set this will cause the PDF interpreter to raise<br>
- an 'undefined' error if a warning is encountered, and stop processing<br>
- the input.<br>
-<br>
- Note that PDFSTOPONWARNING implies that PDFSTOPONERROR is true, and sets<br>
- it if it is not.<br>
-<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/pdf_main.ps<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-02 15:24: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=e8fe0ee8255c0ee8a71e811ddeeb49a211dd6586">e8fe0ee8255c0ee8a71e811ddeeb49a211dd6586</a>
-<blockquote>
-<p>
- Bug #696687 - cannot open encrypt pdf file<br>
-<br>
- We need to treat a /StmF value of /Identity the same as we would if the<br>
- key was missing....<br>
-<br>
- No differences expected<br>
-<br>
-Resource/Init/pdf_sec.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-02 13:31: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=6b7d44b001788183e1222856ad84737612c84466">6b7d44b001788183e1222856ad84737612c84466</a>
-<blockquote>
-<p>
- Coverity ID 94530 (again) - Check and action a return code<br>
-<br>
- Missed a second occurence of the same thing.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-02 12:28: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=3c99fe662db97d01a76e59a9548dd49ce6b65256">3c99fe662db97d01a76e59a9548dd49ce6b65256</a>
-<blockquote>
-<p>
- Coverity ID 94730 - fix an incorrect index<br>
-<br>
- This one's a puzzle. Coverity is absolutely correct that the '-1'<br>
- is invalid, as we use it later as an array index, in fact we possibly<br>
- use it in several different sub-functions, as an array index, and its<br>
- not valid for it to be negative in any of them. There are no tests<br>
- on the value to take special action.<br>
-<br>
- I'm forced to conclude that it should simply be a positive '1' not a<br>
- negative '1'.<br>
-<br>
- I am also unable to get the code to take this path, so I can't test the<br>
- change, but the -1 was definitely wrong, and a step of 1 looks correct.<br>
-<br>
-base/gsfunc0.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-02 11:57:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=08d98e00bc18b47bdf357f2c3f3ba5f47995ce68">08d98e00bc18b47bdf357f2c3f3ba5f47995ce68</a>
-<blockquote>
-<p>
- Coverity ID 94487 - use pre-calculated value to avoid shift<br>
-<br>
-base/gsfunc0.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-02 09:43: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=7253f0cfd8f67ffab1683fb1ad9c54b4250a930f">7253f0cfd8f67ffab1683fb1ad9c54b4250a930f</a>
-<blockquote>
-<p>
- Coverity ID: 125783<br>
-<br>
- Move memory freeing into the common cleanup code before function returns:<br>
- fixes leak in event of an error.<br>
-<br>
- Also, add some pointer initialisation for safety.<br>
-<br>
-base/mkromfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-02 09:41: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=a8f8634c36cdfcf516cd0576127a84f1b09921c2">a8f8634c36cdfcf516cd0576127a84f1b09921c2</a>
-<blockquote>
-<p>
- Coverity ID: 125785<br>
-<br>
- Move string buffer freeing *after* the error message that uses the buffer<br>
-<br>
-base/genconf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-02 09:35: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=417aacf016f3e4298e9c825aa9b4586434b36a76">417aacf016f3e4298e9c825aa9b4586434b36a76</a>
-<blockquote>
-<p>
- scan-build warnings in zfapi.c and gxfapi.c<br>
-<br>
- zfapi.c: initialize pointer and check it's valid before using it<br>
-<br>
- gxfapi.c: remove unnecessary assignment.<br>
-<br>
-base/gxfapi.c<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-02 09:44:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ebdb8acb36a8084089fa7093882a40a4484640fb">ebdb8acb36a8084089fa7093882a40a4484640fb</a>
-<blockquote>
-<p>
- Coverity ID 94546 - correct impossible condition<br>
-<br>
- the a_all bit mask does not include the 'a_executable' bit, making the<br>
- r_has_masked_attrs() test always return false. We do not have a test<br>
- case for this invalid parameter, but I think this is at least an<br>
- improvement.<br>
-<br>
-psi/zshade.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-30 11:18:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c8827f917d2ff40ffeda384fa8df0ceaed2670de">c8827f917d2ff40ffeda384fa8df0ceaed2670de</a>
-<blockquote>
-<p>
- Coverity IDs: 94798, 94930, 94932, 94951, 95022<br>
-<br>
- 94798: check for null before using pointer<br>
-<br>
- 94930: Initialize structure before using<br>
-<br>
- 94932: use %d for &quot;int&quot; in printf (rather than %ld)<br>
-<br>
- 94951: Use an intermediate string buffer (limiting string size) to protect from<br>
- buffer overflow.<br>
-<br>
- 95022: use %d for &quot;int&quot; in printf (rather than %ld)<br>
-<br>
-base/mkromfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-30 11:07:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad59c4428676c61ce2c44b21d76b84154bbec26d">ad59c4428676c61ce2c44b21d76b84154bbec26d</a>
-<blockquote>
-<p>
- Coverity IDs: 94527, 94804, 94888<br>
-<br>
- 94527: fix ignored return value<br>
-<br>
- 94804: the code could not fall into the condition Coverity warned about (the<br>
- condition is checked by the calling code. But adding a &quot;default&quot; to the innner<br>
- switch should clear the warning, make the code clearer, and not cost us<br>
- anything.<br>
-<br>
- 94888: explicit cast to avoid unintended sign confusion.<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-02 08:26:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ba62042a98039203b45b019ffc523778de38513">7ba62042a98039203b45b019ffc523778de38513</a>
-<blockquote>
-<p>
- Coverity ID 94706 - fix a copy/paste error<br>
-<br>
- Commit 1ba0d89544ba6d057867648027c5a6919888c619 was meant to test for<br>
- 'pgd' being non-NULL but a silly copy/paste error tested 'pgd-&gt;bits.data'<br>
- by mistake.<br>
-<br>
-base/gstype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-02 08:19: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=94c7469f9d4dff9c32314b95b89f00e584ec1ed4">94c7469f9d4dff9c32314b95b89f00e584ec1ed4</a>
-<blockquote>
-<p>
- Coverity ID 125639 (again) - clamp page number to 0<br>
-<br>
- Commit 83353631064ac5307a9b62877d5a0664e7ac800e fixed 2 occurrences<br>
- but missed a 3rd one.<br>
-<br>
-base/gdevflp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-02 08:16:21 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8b8725f7fbf9bd51a20459caeeda487bee019cf4">8b8725f7fbf9bd51a20459caeeda487bee019cf4</a>
-<blockquote>
-<p>
- Coverity ID 121436 (again) - guard a 2nd place where a pointer is dereferenced<br>
-<br>
- Commit 5655e62da7ad0a4c6368994a11cdb9954d1fa296 missed a second place<br>
- where 'textures' is dereferenced.<br>
-<br>
-base/gdevdrop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-02 08:11: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=38de4f3a79583a2b7147a369a86cb1e599331300">38de4f3a79583a2b7147a369a86cb1e599331300</a>
-<blockquote>
-<p>
- Coverity ID 94765 (again) - really make sure array index is not negative<br>
-<br>
- commit fa1757fe4317171cd45755d0b66111ebf12be920 only fixed half the<br>
- problem (possibility of num_planes being 0 or less), technically we can<br>
- still go round the loop and have no planes requested (params-data[]<br>
- all being 0). This should never happen of course, but this ensures that<br>
- if it does we throw an error, instead of crashing.<br>
-<br>
-base/gdevdgbr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-02 08:05: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=ee023598f2f16ab07cd4dced768729a39c2a9369">ee023598f2f16ab07cd4dced768729a39c2a9369</a>
-<blockquote>
-<p>
- Coverity ID 94880 (again) - explicit cast to avoid signed implicit cast<br>
-<br>
- Missed a couple of cases the first time....<br>
-<br>
-base/aes.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-05-02 08:00:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2d8ddfb13033f53795120eb700e9618e0b15f486">2d8ddfb13033f53795120eb700e9618e0b15f486</a>
-<blockquote>
-<p>
- Coverity ID 125784 - initialise a variable<br>
-<br>
-base/gdevdbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-30 10:14: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=957f6cdd4376a12e7b037808f8c9326887d32ef3">957f6cdd4376a12e7b037808f8c9326887d32ef3</a>
-<blockquote>
-<p>
- Bug #696334 - Don't clean up exec stack after a stackoverflow error<br>
-<br>
- The problem is that the CET file leaves junk on the operand stack after<br>
- running the colour transform, it also runs three nested loops, 10 steps<br>
- in each loop, for each of the of R, G and B components. This (eventually)<br>
- leads to a stack overflow error.<br>
-<br>
- This wouldn't normally be a problem, but we then go round and increase<br>
- the stack size, and retry the operation. But, because we had removed the<br>
- execution stack operands, the operator failed, leading to a typecheck<br>
- error.<br>
-<br>
- We can (and I have) fix this by not popping the elements off the exec<br>
- stack when the error is a stackoverflow. This permits us to properly<br>
- clean up the exec stack for other types of error, and we can hope that<br>
- the stackoverflow is self-correcting. Its not ideal but its the best I<br>
- can think of.<br>
-<br>
- No differences expected<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-29 10:07: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=b24e0938edf4477a8d318e79a60497fd39e25a57">b24e0938edf4477a8d318e79a60497fd39e25a57</a>
-<blockquote>
-<p>
- Bug 696700: Reduce error messages in release<br>
-<br>
-base/gsicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-29 15:49: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=71fdcc8a7e15271928587637def7187c1e2ac807">71fdcc8a7e15271928587637def7187c1e2ac807</a>
-<blockquote>
-<p>
- Coverity ID 94498 - Make size clearer<br>
-<br>
- There was nothing actually wrong with the previous code, but it took<br>
- the sizeof() a value rather than using the #define for the actual<br>
- number of bits in a color_value, using the #define is clearer<br>
-<br>
-psi/zdpnext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-29 15:23: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=9980daa62eb9909ef5a33935886df24008180c4b">9980daa62eb9909ef5a33935886df24008180c4b</a>
-<blockquote>
-<p>
- Coverity ID 94732 - prevent a NULL dereference<br>
-<br>
-psi/zcontext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-29 14:42: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=7b96281dec9a53a56a444ef18f00a8c6611a4395">7b96281dec9a53a56a444ef18f00a8c6611a4395</a>
-<blockquote>
-<p>
- Fix bug in Commit 117eac07f12948d4c581335a5587c22815ad18dd<br>
-<br>
- As was more or less inevitable, I made a mistake in one of these<br>
- Coverity fixes. I believe this resolves the problem<br>
-<br>
-psi/iutil.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-29 11:57: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=85ebe6e6ec96e0f24ca057fe6b628bf9d33e61e6">85ebe6e6ec96e0f24ca057fe6b628bf9d33e61e6</a>
-<blockquote>
-<p>
- Coverity ID 94603 - guard against a NULL pointer dereference<br>
-<br>
- Other cases return error, but ths is a void function....<br>
-<br>
-psi/zcontext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-29 11: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=117eac07f12948d4c581335a5587c22815ad18dd">117eac07f12948d4c581335a5587c22815ad18dd</a>
-<blockquote>
-<p>
- Coverity ID 95013 - prevent a potential 1 byte buffer overrun<br>
-<br>
-psi/iutil.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-29 11:25: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=ab82e27e0941582a879f01e53a6fd7e41dcf8bb2">ab82e27e0941582a879f01e53a6fd7e41dcf8bb2</a>
-<blockquote>
-<p>
- Coverity ID 94852 - explicit cast to prevent 32-bit overflow<br>
-<br>
-base/siscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-29 11:20: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=8ccd0c1a010e78de76e7f84c5659964444de53fe">8ccd0c1a010e78de76e7f84c5659964444de53fe</a>
-<blockquote>
-<p>
- Coverity ID 94564 - remove dead code<br>
-<br>
- I'm practically certain we don't use this code anyway since the adoption<br>
- of FreeType.<br>
-<br>
-base/gzspotan.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-29 11:15: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=e2d61987cc597e121ff68b9cdf3a80f82fce03e2">e2d61987cc597e121ff68b9cdf3a80f82fce03e2</a>
-<blockquote>
-<p>
- Coverity ID 95044 - remove dead code<br>
-<br>
- A 'goto' was unreachable, being preceded by a goto (after macro expansion)<br>
- Replaced with a break just to match the other cases.<br>
-<br>
-base/gxtype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-29 11:10: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=6df3e33a8445ef53ab5cb5debdf28b2384001284">6df3e33a8445ef53ab5cb5debdf28b2384001284</a>
-<blockquote>
-<p>
- Coverity ID 94883 - array overrun<br>
-<br>
- This appears to be genuinely a potential problem. A triangular line cap<br>
- requires 3 points which, together with the start and end points<br>
- results in a total of 5 points, the array is only 4.<br>
-<br>
- Extend the array to 5 to ensure that we cannot run off the end.<br>
-<br>
-base/gxstroke.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-29 10:46: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=2eeb1cf7951dc0184082adbaf30167eac4dffcf9">2eeb1cf7951dc0184082adbaf30167eac4dffcf9</a>
-<blockquote>
-<p>
- Coverity ID 94664 - make an else clause clearer<br>
-<br>
- The &gt;0 (actually == 1), &lt; 0 cases were already covered, and terminated<br>
- with a goto, so the only way to get here was if code == 0, so it<br>
- doesn't actually matter if we enclose the 'else' clause in<br>
- parentheses or not, in any event we will execute the 'goto out'.<br>
-<br>
- But this is clearer.<br>
-<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-29 10:25: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=f083229e242b8a0ce4f55935a17ad006502bc5bb">f083229e242b8a0ce4f55935a17ad006502bc5bb</a>
-<blockquote>
-<p>
- Coverity ID 94537 - inconsistent use of a variable<br>
-<br>
- It doesn't actually seem to matter whether we use 'big' or 'big1' here<br>
- but we should be consistent throughout, since they need not be the<br>
- same. Three places use big1 (which is variable, big remains unchanged)<br>
- and one uses big, so I believe that is the incorrect case and have<br>
- changed it accordingly,<br>
-<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-29 09:12:42 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=55bb1e8f7c3ff1bfcf6bea0149f7ce05c2323401">55bb1e8f7c3ff1bfcf6bea0149f7ce05c2323401</a>
-<blockquote>
-<p>
- Coverity IDs 94982, 95068 - extend 2 arrays by 1 to prevent overrun<br>
-<br>
- I can't quite convince myself that its impossible to overrun these arrays<br>
- and it only costs 8 bytes of heap storage, so lets just extend them.<br>
-<br>
-base/gxpcopy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-29 09:11: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=9bb3550bb02656203e29e6984160cc097757bcb6">9bb3550bb02656203e29e6984160cc097757bcb6</a>
-<blockquote>
-<p>
- Coverity ID 94547 - don't ignore a return value<br>
-<br>
- I think its very unlikely this could ever cause a problem, but it is<br>
- theoretically possible.<br>
-<br>
-base/gxpcopy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-29 08:47: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=4b87ec33e0bd4b0383e186e9b4d5d21fe20fa98f">4b87ec33e0bd4b0383e186e9b4d5d21fe20fa98f</a>
-<blockquote>
-<p>
- Coverity IDs 94875, 95076 - explicit cast to avoid integer overflow<br>
-<br>
- I don't believe this is a real problem.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-29 08:28: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=4080ef1c210020e6c3ba22f5b21b5eb6181cc28e">4080ef1c210020e6c3ba22f5b21b5eb6181cc28e</a>
-<blockquote>
-<p>
- Coverity ID 94693 - Fix a return check<br>
-<br>
- The code looks like it was originally of the form:<br>
- if ((code = .....) &lt; 0)<br>
- and has been changed to return the error code instead, but the<br>
- '&lt; 0' was accidentally left behind.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 17:04:36 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=07c424bda4443ab51442d18fe8502a9610efd070">07c424bda4443ab51442d18fe8502a9610efd070</a>
-<blockquote>
-<p>
- Coverity ID 121447 - explicit cast to avoid potential overflow<br>
-<br>
-base/gxcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 16:55: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=22d1de0456139c2e93e67372f574536794800268">22d1de0456139c2e93e67372f574536794800268</a>
-<blockquote>
-<p>
- Coverity ID 94874 - remove pointless code<br>
-<br>
- There was no point in checking for penum being NULL as we had already<br>
- dereferenced it. I'm certain we should not get here with penum NULL.<br>
-<br>
-base/gxccache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 16:35: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=1f324ef9520f49ee03136c8c8a438662d3d1fba0">1f324ef9520f49ee03136c8c8a438662d3d1fba0</a>
-<blockquote>
-<p>
- Coverity ID 94584 - prevent a potential divide by zero<br>
-<br>
- This would only be possible with an invalid font, but we've seen plenty<br>
- of those over the years!<br>
-<br>
-base/gstype2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 16:08: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=1ba0d89544ba6d057867648027c5a6919888c619">1ba0d89544ba6d057867648027c5a6919888c619</a>
-<blockquote>
-<p>
- Coverity ID 94873 - prevent a potential NULL dereference<br>
-<br>
- I'm almost certain this condition cannot arise, but lets be safe.<br>
-<br>
-base/gstype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 15:36: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=8b5def7074f49c4a231b5b49046af2a510c0fa37">8b5def7074f49c4a231b5b49046af2a510c0fa37</a>
-<blockquote>
-<p>
- Coverity ID 121453 - reorder code to check pointer before dereferencing<br>
-<br>
-base/gsshade.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 14:33: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=60455507951739cc7826c9e0429d1273adf6b87c">60455507951739cc7826c9e0429d1273adf6b87c</a>
-<blockquote>
-<p>
- Coverity ID 94900 check and action a return code<br>
-<br>
-base/gspaint.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 14:31: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=4722eeefcd1f084e335422b53d6b87b5e73efa18">4722eeefcd1f084e335422b53d6b87b5e73efa18</a>
-<blockquote>
-<p>
- Coverity ID 94849 - initialise a member of a structure<br>
-<br>
- I'm certain this doesn't matter, but this should get rid of the warning.<br>
-<br>
-base/gsovrc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 14:26: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=4a550a4bdca8dec8cd7907bfc11d9ce454f85dbf">4a550a4bdca8dec8cd7907bfc11d9ce454f85dbf</a>
-<blockquote>
-<p>
- Coverity ID 94555 - check a return code<br>
-<br>
- And if we overflowed the buffer, emit the customary 'truncated'<br>
- warning after writing the output.<br>
-<br>
-base/gsmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 13:57: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=6ab7be0da61c115d95ecead8ba5be99dfb82e777">6ab7be0da61c115d95ecead8ba5be99dfb82e777</a>
-<blockquote>
-<p>
- Coverity ID 94583 - guarantee prevention of NULL dereference<br>
-<br>
- I don't think this was actually possible to generate, as p_ctx-&gt;profiledir_len<br>
- ought to be 0 if p_ctx-&gt;profiledir is NULL.<br>
-<br>
- But this is safer.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 13:47: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=6957a9b2daad5256ae91f7416cc62368e0817847">6957a9b2daad5256ae91f7416cc62368e0817847</a>
-<blockquote>
-<p>
- Coverity ID 94864 - don't dereference a pointer until after NULL check<br>
-<br>
-base/gsioram.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 13:43: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=e92d375e70f9db4f332135a8dba1d4b5ef5379a0">e92d375e70f9db4f332135a8dba1d4b5ef5379a0</a>
-<blockquote>
-<p>
- Coverity ID 95053 - ensure we do not dereference a potential NULL pointer<br>
-<br>
-base/gsht.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 13:23: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=29570038d7a5ef3e0e606a8e92680a7a2a159a8d">29570038d7a5ef3e0e606a8e92680a7a2a159a8d</a>
-<blockquote>
-<p>
- Coverity ID 94649 - prevent potential NULL dereference<br>
-<br>
-base/gsht.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 12:15:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6911125a371ba43f2014e43d4a3a12516aeebad9">6911125a371ba43f2014e43d4a3a12516aeebad9</a>
-<blockquote>
-<p>
- Coverity IDs 94657, 94867, 94995<br>
-<br>
- Set some array contents to NULL to ensure we cannot access uninitialised<br>
- data. Ensure an array index cannot be negative (return error if it<br>
- ever is).<br>
-<br>
-base/gsfunc4.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 11:53:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2bf6fe4fe5b0e32cc8961843e7f4752f13536208">2bf6fe4fe5b0e32cc8961843e7f4752f13536208</a>
-<blockquote>
-<p>
- Coverity ID 94844 - pay attention to parameter checking<br>
-<br>
- We checked the parameters for validity, but ignored the result !<br>
-<br>
-base/gsfunc3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 11:42: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=a51b3d81caf2936ad017236b6099bc97acf5584a">a51b3d81caf2936ad017236b6099bc97acf5584a</a>
-<blockquote>
-<p>
- Coverity ID 121451 - explicit cast to avoid potential overflow<br>
-<br>
-base/gdevmr2n.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 11:33:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba0d94c3f1628f1f36358e7ff513d699bf5aa87c">ba0d94c3f1628f1f36358e7ff513d699bf5aa87c</a>
-<blockquote>
-<p>
- Coverity ID 94662 - ensure argument is not NULL<br>
-<br>
- gx_make_rop_texture_device checked 'target' to see if it is NULL, but<br>
- then later dereferenced target without checking. It 'looks like' this<br>
- is a condition which can't happen, because we would get a seg fault.<br>
-<br>
- In fact it is only called from one place, and that location<br>
- (gx_image_enum_begin) can return an error, so I've chosen to ensure<br>
- that the argument cannot be NULL before calling gx_make_rop_texture_device<br>
-<br>
-base/gdevrops.c<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-28 10:23: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=a1625fe7efe8da391f77932f866504ee75b936ac">a1625fe7efe8da391f77932f866504ee75b936ac</a>
-<blockquote>
-<p>
- Coverity ID 94796 - guard against (throw an error) possible NULL dereference<br>
-<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-27 16:42:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d9cc10861f21fe7c5dde8836a09028d9ad8b8d97">d9cc10861f21fe7c5dde8836a09028d9ad8b8d97</a>
-<blockquote>
-<p>
- Coverity ID 94705 - prevent a NULL pointer dereference<br>
-<br>
- gs_cie_jc_complete dereferences pis-&gt;cie_render.<br>
-<br>
-base/gsciemap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-27 15:27: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=405236003e7a0cc472f46fda556f011d58cc2ca9">405236003e7a0cc472f46fda556f011d58cc2ca9</a>
-<blockquote>
-<p>
- Coverity ID 121450 - explicit cast to 64-bit type, avoids faulty implicit 32-bit cast<br>
-<br>
-base/gsbitops.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-27 15:04: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=1446fbba1351efc867f9dedcc96c27e8be0c4f06">1446fbba1351efc867f9dedcc96c27e8be0c4f06</a>
-<blockquote>
-<p>
- Coverity ID 94825 - initialise struct members so copying doesn't give a warning<br>
-<br>
-base/gsalphac.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-27 14:35:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b04a8f07705611a731629ca328f117b12e617776">b04a8f07705611a731629ca328f117b12e617776</a>
-<blockquote>
-<p>
- Coverity ID 125641 - remove a harmless line of dead code<br>
-<br>
-base/gsalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-27 14:26: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=dab434b2058d77088c6f495904602b30539effd1">dab434b2058d77088c6f495904602b30539effd1</a>
-<blockquote>
-<p>
- Coverity ID 121452 - resource leak<br>
-<br>
- free 'filekey' if we successfully allocated it, and then later aborted.<br>
-<br>
-base/gp_unix_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-27 10:09:20 +0100
-</strong>
-<br>Caolán McNamara &lt;caolanm@redhat.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=abeee8de532a512aeb5e4b0c3f7b11abcea30b72">abeee8de532a512aeb5e4b0c3f7b11abcea30b72</a>
-<blockquote>
-<p>
- Resolves: gs#696735 valgrind bits_bounding_box uninitialized values<br>
-<br>
-base/gxfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-26 11:07:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=934af9c2ac583542d7a167cda75b83e79adc6c7e">934af9c2ac583542d7a167cda75b83e79adc6c7e</a>
-<blockquote>
-<p>
- Coverity IDs: 36550, 94906, 94907, 95028, 95064<br>
-<br>
- 36550: handle errors from file operations.<br>
-<br>
- 94906, 94907, 95028, 95064: ensure we don't overflow string buffers.<br>
-<br>
-base/genconf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-26 11:05: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=0efb1a2a5b49dab22afb2cb9985f6fb155f1db29">0efb1a2a5b49dab22afb2cb9985f6fb155f1db29</a>
-<blockquote>
-<p>
- cppcheck: uninitialized variable in gsmd5.c<br>
-<br>
- In practice, porbably can't happen - simple initialization should resolve the<br>
- warning<br>
-<br>
-base/gsmd5.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-26 11:04: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=1de3af7338592b108fa01dfed496df3092ed1fa9">1de3af7338592b108fa01dfed496df3092ed1fa9</a>
-<blockquote>
-<p>
- Address some error handling issues in mkromfs.c<br>
-<br>
- cppcheck reported some potential resource leaks in error conditions.<br>
-<br>
-base/mkromfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-26 09:05: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=94c93f7841ad4b90522756acc7ed0083475cd74a">94c93f7841ad4b90522756acc7ed0083475cd74a</a>
-<blockquote>
-<p>
- Change allocator initialization.<br>
-<br>
- cppcheck reckoned the pointer to the memory allocator (cmem) could possibly be<br>
- a NULL pointer dereference (in fact, that's not true).<br>
-<br>
- But a simple tweak to how cmem is initialized can prevent the error arising.<br>
-<br>
-base/fapi_ft.c<br>
-base/fapiufst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-27 10:23:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=33b190011e6aa70b7ab2049842a10b090544c2d1">33b190011e6aa70b7ab2049842a10b090544c2d1</a>
-<blockquote>
-<p>
- Coverity ID 94842 - initialise some variables<br>
-<br>
- Worst case (I think) would have resulted in indeterminate, incorrect,<br>
- rendering, so not a huge issue but fixed just in case.<br>
-<br>
-base/gdevmpla.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-27 10:02:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1497b768ef1463a952f981a97b66900138268005">1497b768ef1463a952f981a97b66900138268005</a>
-<blockquote>
-<p>
- Coverity ID 94578 - avoid dereferencing a pointer if its NULL<br>
-<br>
- The variable 'textures' was checked for being NULL before assigning<br>
- traster from it, but we then later used textures without checking it.<br>
-<br>
- I did consider adding a similar check to the original one here, at the<br>
- point flagged by Coverity, but the loop would then have proceeded to<br>
- use a NULL pointer as an array, leading to further problems.<br>
-<br>
- I suspect that textures cannot (or at least should not) be NULL, and<br>
- none of our test files exercise ths case. So I've chosen to simply<br>
- return if it ever is.<br>
-<br>
-base/gdevmpla.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-27 09:36: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=fbeade5f65fe17607df5da0b20ab562c2e68dc01">fbeade5f65fe17607df5da0b20ab562c2e68dc01</a>
-<blockquote>
-<p>
- Coverity ID 94508 - check and action a return code<br>
-<br>
-base/gdevmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-27 09:10: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=5655e62da7ad0a4c6368994a11cdb9954d1fa296">5655e62da7ad0a4c6368994a11cdb9954d1fa296</a>
-<blockquote>
-<p>
- Coverity ID 121436 - guard against a NULL dereference<br>
-<br>
- textures is checked for NULL in the procedure initialisation, so it<br>
- seems it may be possible for it to be NULL. Make sure we don't try to<br>
- dereference it if so.<br>
-<br>
-base/gdevdrop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-27 08:34:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa1757fe4317171cd45755d0b66111ebf12be920">fa1757fe4317171cd45755d0b66111ebf12be920</a>
-<blockquote>
-<p>
- Coverity ID 94765 guard against invalid array index<br>
-<br>
- We checked to ensure that no more than 1 plane was requested, but we<br>
- didn't check to ensure that at least 1 plane *was* selected.<br>
-<br>
-base/gdevdgbr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-26 10:22:56 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da2d4893743831b9739eaa3f7f4373e011a39e36">da2d4893743831b9739eaa3f7f4373e011a39e36</a>
-<blockquote>
-<p>
- Coverity ID 94879 and 94963 Performance inefficiency<br>
-<br>
- Pass pointer to landscape information instead of structure when<br>
- applying threshold.<br>
-<br>
-base/gxht_thresh.c<br>
-base/gxht_thresh.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-25 15:45:41 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=341a0b9a1268cb246c1e0cc12d684a59b39cf876">341a0b9a1268cb246c1e0cc12d684a59b39cf876</a>
-<blockquote>
-<p>
- Fix nocm (-dUseFastColor) allocation when using NumRenderingThreads&gt;0<br>
-<br>
- Rendering threads use a chunk_memory allocator that is, by nature, not<br>
- GC'ed so its non_gc_memory points to itself, but the icc_cache_cl of the<br>
- (and the icc_cache_list[]) link caches use thread_safe_memory (the heap<br>
- allocator) so when the thread exits, we have &quot;leaked&quot; nocm elements from<br>
- the chunk allocator (seen with a DEBUG build) and end up with stale pointers<br>
- in the link_cache that cause SEGV when the link cache's contents are removed.<br>
-<br>
- Problem seen with:<br>
- -dNOCIE -dUseFastColor -dNumRenderingThreads=1 -dMaxBitmap=0 j9_acrobat.pdf<br>
-<br>
-base/gsicc_cache.c<br>
-base/gsicc_nocm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-26 15:39: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=979d208cb52fb7fda65d742aa09311067c60aba6">979d208cb52fb7fda65d742aa09311067c60aba6</a>
-<blockquote>
-<p>
- Bug 696733: Make sure we have an open file before writing to it<br>
-<br>
- The lj3100sw writes the last data to the output file on closing, but if there<br>
- have been no pages written, there is no open output file.<br>
-<br>
- On close, check we have an open (non-NULL) output file before attempting to<br>
- write the final data.<br>
-<br>
-devices/gdevl31s.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-26 15:40: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=10da8a2209c066b9060e2de0c2641a977266d115">10da8a2209c066b9060e2de0c2641a977266d115</a>
-<blockquote>
-<p>
- Typo in commit 7f42fb28229370fa9829c56c42e203ba3da5c1d2<br>
-<br>
- I put the parenthesis in the wrong place and missed the failure to<br>
- compile due to the cluster being very busy<br>
-<br>
-base/gdevdbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-26 15:15:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e1c3a86d9d9845c717bd09b65b219b2add238ac8">e1c3a86d9d9845c717bd09b65b219b2add238ac8</a>
-<blockquote>
-<p>
- coverity ID 104077 - pass a large data structure as a pointer<br>
-<br>
-base/gdevdevn.c<br>
-base/gdevdevn.h<br>
-devices/gdevgprf.c<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-26 15:14: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=7f42fb28229370fa9829c56c42e203ba3da5c1d2">7f42fb28229370fa9829c56c42e203ba3da5c1d2</a>
-<blockquote>
-<p>
- silence compiler warning, make sure variable is initialised<br>
-<br>
-base/gdevdbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-26 14:38: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=24065aee02fd942cd81ff373514489e9e6177491">24065aee02fd942cd81ff373514489e9e6177491</a>
-<blockquote>
-<p>
- Coverity IDs 94687 &amp; 94762 - prevent NULL dereference<br>
-<br>
- Don't attempt to set pequiv_colors data, if the pointer is NULL<br>
-<br>
-base/gdevdevn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-26 14:15: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=5649f1d05a3dbdd7dfc969b0b7b05328bde07629">5649f1d05a3dbdd7dfc969b0b7b05328bde07629</a>
-<blockquote>
-<p>
- Coverity ID 94589 and 94687 - prevent a NULL dereference<br>
-<br>
- The code contained a poorly named macro (copy_tile) which executed<br>
- a device method without testing to see if it was NULL. We know from<br>
- prior work that the original intention was that device methods should<br>
- *never* be NULL, but we also know that some devices do have NULL methods<br>
- and indeed this very routine sets some NULL methods.<br>
-<br>
- So to be safe we now check the method before executing it. At the same<br>
- time I've renamed the macro, using upper case so we have some chance of<br>
- seeing its a macro, and prevents the macro name collisions with the<br>
- code in gdevwddb.c and gdevwprn.c.<br>
-<br>
- I also rewrote it to use if....else instead of ? : because it was<br>
- practically unreadable before.<br>
-<br>
- Removed the (pointless) 'return_if_interrupt' macro.<br>
-<br>
- Finally, added the do..while(0) construction around the macro body.<br>
-<br>
-base/gdevdbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-26 13:15: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=fc2e6a0517d4ecc7a486647da8bfaa9e1ab9e03e">fc2e6a0517d4ecc7a486647da8bfaa9e1ab9e03e</a>
-<blockquote>
-<p>
- Coverity ID 121448 - change the order of casting<br>
-<br>
- Change the cast position to avoid implicit type promotion, and consequent<br>
- potential integer overflow.<br>
-<br>
- I don't believe this is really a problem, but the explicit early casting<br>
- prevents any problems and makes no differences otherwise.<br>
-<br>
-base/gdevabuf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-26 11:56:42 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e79881cba48fcbfa84d09a4c0f78cfaaf53347d9">e79881cba48fcbfa84d09a4c0f78cfaaf53347d9</a>
-<blockquote>
-<p>
- Coverity IDs 94851, 94872, 94880, 94884, 94885, 94918, 94939, 95050, 95061<br>
-<br>
- I *think* that casting the intermediate result to an unsigned int should<br>
- prevent the implicit cast to a signed int, which will prevent the<br>
- sign extension which Coverity is warning about.<br>
-<br>
- I'll check after the next Coverity submission and rework this if it<br>
- should turn out to be insufficient.<br>
-<br>
-base/aes.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-25 16:32:00 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bc5657a8613d078d5774a5453d47fa9c5f410f54">bc5657a8613d078d5774a5453d47fa9c5f410f54</a>
-<blockquote>
-<p>
- Bug 696675 - UI message in output file.<br>
-<br>
- Update this file to be a bit more in sync with its analog in gs<br>
- dwmain.c. Hopefully by redirecting output to stderr we will avoid the<br>
- issue reported in the bug where error messages were being directed to<br>
- output files. I was unable to reproduce it locally with Windows 10 once<br>
- the changes were applied.<br>
-<br>
-pcl/pl/plwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-24 15:01:32 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=86f15f469c2015a6f2c85593eab08c3625a24df2">86f15f469c2015a6f2c85593eab08c3625a24df2</a>
-<blockquote>
-<p>
- Coverity ID 95017 Null dereference possible<br>
-<br>
- Check for device NULL and if it is return NULL for link<br>
- in the replacement color code.<br>
-<br>
-base/gsicc_replacecm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-24 14:58:27 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2761b30ed29f3e6b87ebe739fbb289d5c345db44">2761b30ed29f3e6b87ebe739fbb289d5c345db44</a>
-<blockquote>
-<p>
- Coverity ID 94960: Dereference before NULL check.<br>
-<br>
- It has already been checked if pis was NULL on<br>
- all the paths leading to this, so remove the check here.<br>
-<br>
-base/gsicc_nocm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-24 14:55:06 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c09d5f52594f04966d93c7001fec49707970e6bf">c09d5f52594f04966d93c7001fec49707970e6bf</a>
-<blockquote>
-<p>
- Coverity ID 94714: Possible Null Dereference<br>
-<br>
- If device is NULL in the no_cm color management return NULL for the link.<br>
- The device is required for this transform.<br>
-<br>
-base/gsicc_nocm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-24 14:49:09 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=142ebba4e98047b0ebd1acce28911b042c19f899">142ebba4e98047b0ebd1acce28911b042c19f899</a>
-<blockquote>
-<p>
- Coverity ID 125642 Possible dereference NULL issue<br>
-<br>
- Make sure we do the testing correct to avoid any<br>
- possible dereference of NULL.<br>
-<br>
-base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-24 14:36: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=d683717565b3e09ff6bcacbc1fec50352cd08507">d683717565b3e09ff6bcacbc1fec50352cd08507</a>
-<blockquote>
-<p>
- Coverity ID 94673 Dead code removal<br>
-<br>
-base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-23 12:37:23 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d417ff8cbfe7b6a04a15bc9f898e77ab2ffd737">4d417ff8cbfe7b6a04a15bc9f898e77ab2ffd737</a>
-<blockquote>
-<p>
- Change PS interpreter allocator chunks to clumps.<br>
-<br>
- We are in the confusing position of having the PS interpreter<br>
- allocator that allocates in chunks, along with a chunked allocator.<br>
-<br>
- To avoid this confusing clash of terminology, we do some<br>
- global renames to change the standard allocator to allocate<br>
- in 'clumps' instead.<br>
-<br>
-base/gdbflags.h<br>
-base/gdevprna.c<br>
-base/gxobj.h<br>
-psi/ialloc.c<br>
-psi/igcref.c<br>
-psi/imain.c<br>
-psi/imainarg.c<br>
-psi/iminst.h<br>
-psi/inameidx.h<br>
-psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-25 17:09:50 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1cc9c37f2b437244235222832989b4f0fb42ae4">d1cc9c37f2b437244235222832989b4f0fb42ae4</a>
-<blockquote>
-<p>
- pdfwrite - continue writing fonts even after one fails<br>
-<br>
- File Bug693711.pdf has a number of broken fonts which we cannot write<br>
- out (Acrobat throws an error on these pages in the original PDF file).<br>
- Previously when we encountered an error writing a font we would stop<br>
- writing fonts, even the ones which were valid.<br>
-<br>
- Here we store the error (we don't want to forget there was one, so we<br>
- can report it at the end) but carry on emitting the PDF file. This<br>
- does a better job of emitting a file from broken input.<br>
-<br>
-devices/vector/gdevpdtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-25 09:21:24 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dca281c3d8011a2afe3caadc23009fe38d8df839">dca281c3d8011a2afe3caadc23009fe38d8df839</a>
-<blockquote>
-<p>
- Bug 696314, Add PJL to staple documents.<br>
-<br>
- Staple setting for the PXL devices courtesy of Hin-Tak Leung.<br>
-<br>
-devices/gdevlj56.c<br>
-devices/gdevpxut.c<br>
-devices/gdevpxut.h<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-25 15:12: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=22e08ac60e5363282631b596e996c0d0ad806484">22e08ac60e5363282631b596e996c0d0ad806484</a>
-<blockquote>
-<p>
- pdfwrite - clear/delete extra temp files when run with %d in OutputFile<br>
-<br>
- Bug #696727 &quot;Regression: pdfwrite leaves temp files&quot;<br>
-<br>
- For some reason this does not exhibit on Windows, I have no idea why.<br>
- This commit adds a call to the function that closes and removes<br>
- pdfwrite's temporary files if we exit due to a '%d' in OutputFile in<br>
- order to prevent a spurious extra file being output.<br>
-<br>
- For me this fixes the problem on Linux.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-25 13:20:35 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=efe7fd03e0ca45aac5ee4610ed9a23b7ea712e0d">efe7fd03e0ca45aac5ee4610ed9a23b7ea712e0d</a>
-<blockquote>
-<p>
- Bug 696730: print meaningful error when device shutdown fails<br>
-<br>
- When we explicitly close the default device, previously we just printed the<br>
- error code, and a reference to gserrors.h - this finds the error code in the<br>
- Postscript world, and prints the Postcript error string instead.<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-25 10:17: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=17b6456984a0676a8cf271ff7abc29fdd5ff10a5">17b6456984a0676a8cf271ff7abc29fdd5ff10a5</a>
-<blockquote>
-<p>
- Coverity IDs 95065, 121457: tidy up error conditions<br>
-<br>
-base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-25 09:54:26 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=43e5273d8ce5e8c7ec02da874129fd2bea26301e">43e5273d8ce5e8c7ec02da874129fd2bea26301e</a>
-<blockquote>
-<p>
- Coverity IDs 94494, 94617, 94818, 95043<br>
-<br>
- 94494: increase size of string buffer to allow for NULL termination.<br>
-<br>
- 94617: Initialize string pointer to avoid NULL dereference.<br>
-<br>
- 94818: Initialize string variable (fmode).<br>
-<br>
- 95043: Swtich to strncpy() to ensure we don't overflow string buffer<br>
-<br>
-base/echogs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-25 10:34: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=3787c3f9753c542a5bd3f040b2aaa73db2f2f527">3787c3f9753c542a5bd3f040b2aaa73db2f2f527</a>
-<blockquote>
-<p>
- Fix clump splay tree backward in-order traversal.<br>
-<br>
- When walking backwards, we stop for 'in-order' operation when<br>
- stepping from the right, not the left.<br>
-<br>
- Also, backward walking requires different initialisation from<br>
- forward walking.<br>
-<br>
- Add some debug code to dump a clump tree, and fix a prototype.<br>
-<br>
-base/gsalloc.c<br>
-base/gsalloc.h<br>
-base/gxalloc.h<br>
-psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-25 09:22: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=99c712e4b10b459d2eab687d0f4db481999aad96">99c712e4b10b459d2eab687d0f4db481999aad96</a>
-<blockquote>
-<p>
- Coverity ID 101841, change order of code so that NULL check comes before dereference<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-25 09:17:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3cd70f69f9054fdb9da2c18d4d1bdbbd5cd752ad">3cd70f69f9054fdb9da2c18d4d1bdbbd5cd752ad</a>
-<blockquote>
-<p>
- add parentheses to make the control flow obvious, as requested by owner.<br>
-<br>
-psi/ialloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-25 09:01:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=74fd7f6bbe5e2aa493ef9bd087ab64adbabe71bc">74fd7f6bbe5e2aa493ef9bd087ab64adbabe71bc</a>
-<blockquote>
-<p>
- Coverity ID 94725 - correct misleading indenting<br>
-<br>
-psi/ialloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-25 08:45:13 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a3d988b75d952367ed898d0e1ac2af79add49296">a3d988b75d952367ed898d0e1ac2af79add49296</a>
-<blockquote>
-<p>
- Coverity ID 94530 check and action a return code<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-25 08:25: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=83353631064ac5307a9b62877d5a0664e7ac800e">83353631064ac5307a9b62877d5a0664e7ac800e</a>
-<blockquote>
-<p>
- Coverity ID 125639 - clamp page numbers to 0<br>
-<br>
- The PageList is supposed to be page numbers 1 onwards. Putting a zero<br>
- in the list would potentially have caused the numbers to 'wrap' resulting<br>
- in no output.<br>
-<br>
-base/gdevflp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-23 10:59: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=88a145bebee34481862ea79d09098eb71dd15e38">88a145bebee34481862ea79d09098eb71dd15e38</a>
-<blockquote>
-<p>
- Coverity ID 94810 - properly bracket macro<br>
-<br>
- gx_setcurrentpoint is a macro, with 2 lines of code. This meant the else<br>
- clause was only applied to the first line, and the second was always<br>
- processed.<br>
-<br>
- Fortuitously the if clause would have invalidated the current point so<br>
- I believe this is always safe, but its best to be certain and not<br>
- corrupt the current point.<br>
-<br>
-base/gspaint.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 14:51:02 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f622fe34c6290e737216dbc85d93efcdd3895fd">2f622fe34c6290e737216dbc85d93efcdd3895fd</a>
-<blockquote>
-<p>
- Coverity ID 94776 Dereference after null check<br>
-<br>
- This should not have been an issue since the only<br>
- case where we called with a NULL device we have a profile,<br>
- but we will add the check for safety.<br>
-<br>
-base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 11:55:57 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=644914cb5cef5b6138cb5f2a2ac541ea2333edc1">644914cb5cef5b6138cb5f2a2ac541ea2333edc1</a>
-<blockquote>
-<p>
- Bug 696726: gdevcmykog.c - insure that temp files are deleted<br>
-<br>
- Call gp_open_scratch_file_rm() instead of gp_open_scratch_file() to insure<br>
- that no temp files are left around if Ghostscript is killed or crashes.<br>
-<br>
-devices/gdevcmykog.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 11:36:24 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=263b9e169ec5cf09c4b671ef9ea58f3e0edbe994">263b9e169ec5cf09c4b671ef9ea58f3e0edbe994</a>
-<blockquote>
-<p>
- Coverity ID 94766: Self assignment (no effect)<br>
-<br>
- Remove spurious code.<br>
-<br>
-base/gxcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 11:25:56 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ae840462e761fbb798e0a3f9ca822a69b252220d">ae840462e761fbb798e0a3f9ca822a69b252220d</a>
-<blockquote>
-<p>
- Coverity ID 94882 and 95018: Uninitialized variables<br>
-<br>
- If someone sets the number of inputs to an out of range<br>
- value in the transform, we will return 0 for our output<br>
- in the no_cm and replace_cm color management work flow.<br>
-<br>
-base/gsicc_nocm.c<br>
-base/gsicc_replacecm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 10:55:18 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6026f85a1a30738a8f453d9d3bbd8a785aff1d1b">6026f85a1a30738a8f453d9d3bbd8a785aff1d1b</a>
-<blockquote>
-<p>
- Coverity ID: 94515, 94513, 94528 copy-paste errors<br>
-<br>
- Output buffer was using input plane stride.<br>
-<br>
-base/gsicc_monitorcm.c<br>
-base/gsicc_nocm.c<br>
-base/gsicc_replacecm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 10:44:59 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=199d49a64706673643671bbb74c19a91809f7e38">199d49a64706673643671bbb74c19a91809f7e38</a>
-<blockquote>
-<p>
- Coverity ID 94935 Out-of-bounds read<br>
-<br>
- Mistake when we are resetting the proof or the device link<br>
- profile. We would have ended up overrunning the profile<br>
- array that is used for the default/text/graphic/image array.<br>
-<br>
-base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 10:30:18 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=55d58a84767b82fe9f81b7b2357e1feafa06f017">55d58a84767b82fe9f81b7b2357e1feafa06f017</a>
-<blockquote>
-<p>
- Coverity ID 94570, 94785, 94915 Missing break in switch<br>
-<br>
- The CIEXYZ case can't occur so it has been removed. It<br>
- was a vestige from the early days of the ICC development.<br>
- The CIEXYZ case was missing a break statement, which led to three<br>
- coverity complaints.<br>
-<br>
-base/gscms.h<br>
-base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 18:22:30 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=15ee3fb57b660a796f8ac40c8784cfb165405336">15ee3fb57b660a796f8ac40c8784cfb165405336</a>
-<blockquote>
-<p>
- Change standard allocator chunks to clumps.<br>
-<br>
- We are in the confusing position of having a standard<br>
- allocator that allocates in chunks, along with a chunked<br>
- allocator.<br>
-<br>
- To avoid this confusing clash of terminology, we do some<br>
- global renames to change the standard allocator to allocate<br>
- in 'clumps' instead.<br>
-<br>
-base/gdbflags.h<br>
-base/gsalloc.c<br>
-base/gxalloc.h<br>
-base/gxobj.h<br>
-doc/Develop.htm<br>
-doc/Use.htm<br>
-psi/ialloc.c<br>
-psi/igc.c<br>
-psi/igc.h<br>
-psi/igcstr.c<br>
-psi/igcstr.h<br>
-psi/ilocate.c<br>
-psi/ireclaim.c<br>
-psi/isave.c<br>
-psi/zcontext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 09:56:04 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e749f3d65d203edbc7c140ec8fd76b66805d27ff">e749f3d65d203edbc7c140ec8fd76b66805d27ff</a>
-<blockquote>
-<p>
- Coverity ID 94910 Uninitialized pointer read<br>
-<br>
- Set indices to avoid use of uninitialized index. It is actually not<br>
- possible to access them using real data but someone could perhaps<br>
- be malicious and cause a problem<br>
-<br>
-base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 13: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=7b0baf9dc683b3ed6ac27b7a8f89718220589f7c">7b0baf9dc683b3ed6ac27b7a8f89718220589f7c</a>
-<blockquote>
-<p>
- Rework gsalloc chunk list to use splay trees.<br>
-<br>
- Instead of using a simple linked list (that can result in<br>
- slow searching in pathological cases), change to a splay tree<br>
- structure.<br>
-<br>
-base/gsalloc.c<br>
-base/gxalloc.h<br>
-psi/ialloc.c<br>
-psi/igc.c<br>
-psi/ilocate.c<br>
-psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 09:24:52 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd683d444dba28a6bb4701be065353e4f5344de0">dd683d444dba28a6bb4701be065353e4f5344de0</a>
-<blockquote>
-<p>
- Coverity ID 94568 Dereference after null check<br>
-<br>
- The device profile is not even used in this function.<br>
- Likely left over by mistake. Dereference of NULL no<br>
- longer possible here.<br>
-<br>
-base/gsicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 09:07:12 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd34f9f634b2d179bb898138255bb20c3de8c76f">dd34f9f634b2d179bb898138255bb20c3de8c76f</a>
-<blockquote>
-<p>
- Coverity ID 95055 Uninitialized scalar variable<br>
-<br>
- If we have an invalid color space (non-CIE) we should<br>
- not be in this part of the code. Throw an error in<br>
- this case (the default in the switch) which will make<br>
- us avoid the uninitialized access.<br>
-<br>
-base/gsicc_create.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 13:59: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=e821df35998b594b844edf3e554d5a8002a6311d">e821df35998b594b844edf3e554d5a8002a6311d</a>
-<blockquote>
-<p>
- Coverity ID 94783 - prevent a NULL dereference<br>
-<br>
- If the device doesn't have a 'color_usage_array' then trying to use it<br>
- will be fatal. There is a check for the array being NULL, but it was<br>
- empty!<br>
-<br>
- As a work-around, if it is NULL then return -1 which looks like its a<br>
- 'do nothing' value.<br>
-<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 13:28:42 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b49a4b5142dba407e63e2b8907efce3d38202ac4">b49a4b5142dba407e63e2b8907efce3d38202ac4</a>
-<blockquote>
-<p>
- Coverity ID 94751 - error in return check<br>
-<br>
- Looks like this was a &quot;if ((code= ...) &lt; 0)&quot; converted into &quot;code=.. if<br>
- (code &lt; 0)&quot; but mistakenly.<br>
-<br>
-psi/zpcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 13:17: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=3204fa03a809db3d8ff26d629012096ff1aecef6">3204fa03a809db3d8ff26d629012096ff1aecef6</a>
-<blockquote>
-<p>
- Coverity ID 94977 - check and action 2 return codes<br>
-<br>
-psi/zicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 12:59:42 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bffaddf2c2c1d3f0a52e205cf33c9023a779ace7">bffaddf2c2c1d3f0a52e205cf33c9023a779ace7</a>
-<blockquote>
-<p>
- Coverity ID 94543 check a return code<br>
-<br>
- This does actually lead to a memory leak, but there is equivalent code<br>
- below (allocating prci) which potentially leaks in exactly the same<br>
- way, so I'm going to ignore the leak. A real VM error will quickly<br>
- cause the interpreter to exit anyway.<br>
-<br>
-psi/zgstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 11:54: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=caf54da6fe8635a17f069e947ff87d0b6c37a592">caf54da6fe8635a17f069e947ff87d0b6c37a592</a>
-<blockquote>
-<p>
- Coverity ID 94789 - missing parentheses could cause error<br>
-<br>
- This appears to be a genuine bug, even if the parameters were valid<br>
- we would jump to the failure condition. Seems we do not have a test<br>
- case for this code path.<br>
-<br>
-psi/zfsample.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 11:36:13 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=58db0de140dc12170d4fb4b33d32a90f5d57f0e2">58db0de140dc12170d4fb4b33d32a90f5d57f0e2</a>
-<blockquote>
-<p>
- Coverity ID 94947 - initialise an unused paramter<br>
-<br>
- delta is only used for Dissolve blend modes, so I'm pretty certain this<br>
- is really a false positive, but it does no harm to initialise it to 0.<br>
-<br>
-psi/zdpnext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 11:27: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=56315a80d2bd49d3d9baa71ea3be8b1dba64adcd">56315a80d2bd49d3d9baa71ea3be8b1dba64adcd</a>
-<blockquote>
-<p>
- Coverity ID 95062 - check and action a return code<br>
-<br>
- Almost certainly impossible to trigger, the only way to get an error<br>
- here would be for the ref pointed to by arr to not be an array, which<br>
- should have been checked earlier, All the same, lets check the return<br>
- code.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 10:57:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5bfdb858ea41d0018acc3c022e885fc6b4a1ccfc">5bfdb858ea41d0018acc3c022e885fc6b4a1ccfc</a>
-<blockquote>
-<p>
- fix Coverity ID 94865 - free some memory on exit<br>
-<br>
- This is minor, as the memory leak only occurs on a fatal error and<br>
- application exit.<br>
-<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 10:23: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=5ee4779b097da19ef0b50cd4c04d0f7f6da46da4">5ee4779b097da19ef0b50cd4c04d0f7f6da46da4</a>
-<blockquote>
-<p>
- Coverity ID 94725 - purely cosmetic indenting<br>
-<br>
-psi/ialloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 10:16: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=8d6c1c1396d3678afd37f8492be7e31aed405c59">8d6c1c1396d3678afd37f8492be7e31aed405c59</a>
-<blockquote>
-<p>
- Coverity ID 94927 - initialise a string buffer<br>
-<br>
- Set the buffer contents to all 0, prevents possibility of using<br>
- uninitialised data and makes a 'buf[] = 0' redundant.<br>
-<br>
-psi/dscparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-22 09:48: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=2a5d6cd40a49c89efdb83c6f4399ec7ad8692218">2a5d6cd40a49c89efdb83c6f4399ec7ad8692218</a>
-<blockquote>
-<p>
- txtwrite - Coverity fix, Adobe glyph list lookup not working<br>
-<br>
- Coverity ID 94593<br>
-<br>
- The code to search the Adobe Glyph List in an attempt to find a Unicode<br>
- value for a named glyph was incorrect, and simply didn't work. Because<br>
- 'index' started at -1, and all the searches started by testing if<br>
- 'index &gt;= 0', all the table searches were skipped.<br>
-<br>
- This should actually run the searches and may improve the text extraction<br>
- a little.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-21 18:04:55 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=42bca0e60954adc27d78998905e0daab97136be2">42bca0e60954adc27d78998905e0daab97136be2</a>
-<blockquote>
-<p>
- Fix for Bug 696724<br>
-<br>
- This issue was caused by the interaction of the AA alpha and the fact<br>
- that we have a knock out group. In such a case, we don't want the<br>
- AA alpha to be knocking out what was already drawn. Instead we want<br>
- to do a blend with the AA alpha and then force the alpha to what ever<br>
- the alpha is in the graphic state. This is achieved by looking at<br>
- what is already drawn in our destination and if there is nothing there,<br>
- then we just copy. If there is something there, then we blend and<br>
- then set the alpha value appropriately.<br>
-<br>
-base/gdevp14.c<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-21 16:26: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=fa3dbd3a9fa9ddb2894ef80738d95c3c1b6a92a6">fa3dbd3a9fa9ddb2894ef80738d95c3c1b6a92a6</a>
-<blockquote>
-<p>
- Coverity fix - CID 94748 and 94805 potentail NULL dereference<br>
-<br>
- In both these cases we check dev for NULL and then either dereference dev<br>
- or dereference a pointer set to NULL if dev is NULL.<br>
-<br>
- Simply guard against that. I don't believe this should be possible<br>
- in any event, I don't think the graphics state should *ever* have no<br>
- device.<br>
-<br>
-base/gscspace.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-21 15:43: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=e9d0f658f01ca857f18c9e038adbdad899979f25">e9d0f658f01ca857f18c9e038adbdad899979f25</a>
-<blockquote>
-<p>
- Coverity fix - CID 95051, initialise a variable<br>
-<br>
-base/gdevvec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-20 09:22:16 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3f8b170b6a7ab90cb64814502c0cde317f9fd4ae">3f8b170b6a7ab90cb64814502c0cde317f9fd4ae</a>
-<blockquote>
-<p>
- Remove some defunct references to old wisc site.<br>
-<br>
-doc/API.htm<br>
-doc/Release.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-19 12:05:58 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=43a88f4e6377fa6d4ea0a609450ddb19ee0474cb">43a88f4e6377fa6d4ea0a609450ddb19ee0474cb</a>
-<blockquote>
-<p>
- Add max_used to gs_memory_status and use it for -Z: resource usage<br>
-<br>
- By adding this to the gs_memory_status_t and returning it (if available)<br>
- from the gs_memory_status function of allocators, we can print the max<br>
- used even when it is not a DEBUG build and avoid the ugly gs_debug<br>
- hack previously used to print the max_used for a DEBUG build. The<br>
- time for tracking this is microscopic. Also the chunk_mem allocator<br>
- now tracks this always, not just for DEBUG builds.<br>
-<br>
-base/gsalloc.c<br>
-base/gsmalloc.c<br>
-base/gsmalloc.h<br>
-base/gsmchunk.c<br>
-base/gsmemory.h<br>
-base/gsmemraw.h<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-19 15:56: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=4976a1a4a0b44cd44467e6fe2ba5d453e7573434">4976a1a4a0b44cd44467e6fe2ba5d453e7573434</a>
-<blockquote>
-<p>
- Bug 696716: cff parser: cope with incomplete encoded numbers<br>
-<br>
- The fonts in the test case had an incomplete 32 bit number at the end of the<br>
- stream - meaning it threw an error trying to read 4 bytes when only 1 byte<br>
- was available.<br>
-<br>
- Update the code to read *up to* 4 bytes in these cases.<br>
-<br>
- The fonts are still invalid because they leave a dirty operand stack, but the<br>
- cff parser ignores such problems.<br>
-<br>
- Also quieten an uninitialised variable warning.<br>
-<br>
-psi/zfont2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-19 16:02:36 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a1e2d8b247955e65a7e1ed26e3b8163a58fa6ca7">a1e2d8b247955e65a7e1ed26e3b8163a58fa6ca7</a>
-<blockquote>
-<p>
- page processing - remove a spurious line of code<br>
-<br>
- Spotted by scan-build, this line of code did no harm, but served no<br>
- useful purpose either, since its return value wasn't tested.<br>
-<br>
-base/gdevflp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-19 15: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=3376c638a5d5cad500c48862ace55b8e1eafc458">3376c638a5d5cad500c48862ace55b8e1eafc458</a>
-<blockquote>
-<p>
- txtwrite action a return code<br>
-<br>
- From Coverity ID 94593<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-19 14:27: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=e9e077eff06e8fb4141885d9225f212920af431c">e9e077eff06e8fb4141885d9225f212920af431c</a>
-<blockquote>
-<p>
- pdfwrite - remove some dead code in the ICC handling: Coverity analysis<br>
-<br>
-devices/vector/gdevpdfk.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-19 11:18: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=69c20a21a5bd53284437029b5b9d316a408a7392">69c20a21a5bd53284437029b5b9d316a408a7392</a>
-<blockquote>
-<p>
- Add a system to allow processing of individual pages and ranges of pages<br>
-<br>
- Bug #692752 &quot;Implement mechanism to specify a range (or ranges) of pages for txtwrite&quot;<br>
-<br>
- Documented in Use.htm, this introduces a new command line parameter<br>
- 'PageList' which allows for ranges and individual pages to be specified<br>
- for processing.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-base/gdevdflt.c<br>
-base/gdevflp.c<br>
-base/gdevflp.h<br>
-base/gdevkrnlsclass.c<br>
-base/gsdevice.c<br>
-base/gsdparam.c<br>
-base/gxdevcli.h<br>
-base/gxdevice.h<br>
-devices/gdevbit.c<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-18 17:06:58 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e6ecf9ccab71740fddc70f2e6cb30bef3b831d61">e6ecf9ccab71740fddc70f2e6cb30bef3b831d61</a>
-<blockquote>
-<p>
- On windows, in profile builds, disable DLL build.<br>
-<br>
- This enables Very Sleepy to reliably find symbols for me.<br>
-<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-18 15:31:53 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7c0e498f47b97a3086fdb4297de600b0ef66d584">7c0e498f47b97a3086fdb4297de600b0ef66d584</a>
-<blockquote>
-<p>
- BBox device: speed up.<br>
-<br>
- When taking the bbox of a stroked path, don't stroke the entire<br>
- path to a new path, and then take the bbox of that. Instead<br>
- allow the stroke code to call the underlying bbox code for each<br>
- path segment directly.<br>
-<br>
- On files with HUGE paths this can save a lot of mallocs/frees.<br>
-<br>
-base/gdevbbox.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-18 15:17: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=952ac2015ef8e1e1d3fe84224e99e6b98bc84f05">952ac2015ef8e1e1d3fe84224e99e6b98bc84f05</a>
-<blockquote>
-<p>
- Remove unneeded padding byte.<br>
-<br>
- This made sense until 2002 when another byte was added. Since then<br>
- it's been bloat.<br>
-<br>
-base/gzpath.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-18 09:35:37 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e350758ceb8d9f7ec6bb209908a6ce1fe35e2397">e350758ceb8d9f7ec6bb209908a6ce1fe35e2397</a>
-<blockquote>
-<p>
- Makefile for Android MuPDF libgs.so<br>
-<br>
- make -f Makefile.android so<br>
-<br>
-Makefile.android<br>
-arch/android.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-16 10:34:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e1e13aa4492918ff0dec6062faab351ba9ae6ac0">e1e13aa4492918ff0dec6062faab351ba9ae6ac0</a>
-<blockquote>
-<p>
- pdfwrite - when fill-&gt;bitmap conversion degenerates to empty, just drop it<br>
-<br>
- Bug #696705 &quot;crash in pdfwrite&quot;<br>
-<br>
- This is caused by a combination of a low resolution and converting<br>
- colours into RGB, when a shading uses Separation colour spaces.<br>
-<br>
- The code renders the shading as a bitmap, but the path to fill is empty<br>
- triggering the use of the mask instead of the path. However, because<br>
- we are a shading not a masked image, there is no mask.<br>
-<br>
- Instead we now simply drop the shading.<br>
-<br>
- No differences expected<br>
-<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-14 10:00: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=df5b3426d31f79c13a735dff9118e9798ce97af9">df5b3426d31f79c13a735dff9118e9798ce97af9</a>
-<blockquote>
-<p>
- PDF Interpreter - try to work around invalid ICCBased spaces<br>
-<br>
- Bug #696690 and Bug #696120<br>
-<br>
- These files have ICCBased spaces where the value of /N and the number of<br>
- components in the profile differ. In addition the profile in Bug #696690<br>
- is invalid. In the case of Bug #696690 the /N value is correct, and the<br>
- profile is wrong, in the case of Bug #696120 the /N value is incorrect<br>
- and the profile is correct.<br>
-<br>
- We 'suspect' that Acrobat uses the fact that Bug #696120 is a pure image<br>
- to detect that the /N is incorrect, we can't be sure whether it uses the<br>
- profile or just uses the /N to decide on a device space.<br>
-<br>
- What we now do is; If the /N and device profile number of components<br>
- don't match, we assume the device profile is correct and patch /N to be<br>
- the same as the profile (see /ICCBased-resolve), but we save the<br>
- original value of /N in /OrigN. In the PostScript setcolor operator, if<br>
- the space is a genuine ICCBased space (not a replacement for a device<br>
- space) we call set_dev_color which will actually exercise the profile.<br>
- If that fails we return an error. For ICCbased spaces we run setcolor in<br>
- a stopped context, and if it fails we check to see if there is a /OrigN<br>
- (this occurs only if the /N was different to the number of components in<br>
- the profile). If there is a /OrigN then prefer that to the profile,<br>
- otherwise they agreed, so just use /N and select a device space. If we<br>
- can't select a device space with the correct number of components, give<br>
- up and throw an error.<br>
-<br>
- This produces some differences in a small number of files, mostly the<br>
- PAM device at 72 dpi. These are not visually perceptible, and since they<br>
- only occur on one device at low resolution I think they are spurious.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-Resource/Init/pdf_main.ps<br>
-Resource/Init/pdf_ops.ps<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-11 14:28:47 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=87665c0a73e3d53f791017813424d6f3ba5f85c7">87665c0a73e3d53f791017813424d6f3ba5f85c7</a>
-<blockquote>
-<p>
- txtwrite - reinstate an earlier commit by Robin Watts<br>
-<br>
- This was removed as I couldn't, at the time, be certain that it was not<br>
- required. Having spent some time working through the various macros, and<br>
- the code, I'm now convinced that this is not required, and is probably<br>
- a remnant of an early attempt at this device, which used garbage collected<br>
- objects.<br>
-<br>
- This was originally added by Robin as a small part of commit<br>
- fd9a66f997bb57e9628a703774eddcf933475a34 and removed by me in commit<br>
- 15b3f5cbf12461e2ed318e793669b7c34e32089b<br>
-<br>
-<br>
- No differences expected<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-11 13:32: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=faa3f93a3f7f2da9c53501fc5780999ba14cb1e3">faa3f93a3f7f2da9c53501fc5780999ba14cb1e3</a>
-<blockquote>
-<p>
- pdfwrite - remove some deleted code accidentally left with #if<br>
-<br>
-devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-11 10:06:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=416aa779312c296dfbecd87e6ba88ea57284a337">416aa779312c296dfbecd87e6ba88ea57284a337</a>
-<blockquote>
-<p>
- pdfwrite - Remove the 'old' (non-ICC) colour management code<br>
-<br>
- Removal of this code has been warned for some time, since there have<br>
- been practically no reports of problems, and those few have been<br>
- fixed, I'm now removing the old and deprecated colour conversion<br>
- code.<br>
-<br>
- We also now process, but ignore, changes to ProcessColorModel. If you<br>
- want output in a specific colour space, then use ColorConversionStrategy<br>
- to select the output colour space. Note that although we ignore the<br>
- value, we do change it, so that code which attempts to set the<br>
- ProcessColorModel won't produce an error (ie some of the Quality Logic<br>
- test files).<br>
-<br>
- This does produce one small difference; Bug692106.ps run through<br>
- ps2write, the result is somewhat improved when rendered to RGB.<br>
-<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfc.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdfk.c<br>
-devices/vector/gdevpdfp.c<br>
-devices/vector/gdevpdfv.c<br>
-devices/vector/gdevpdfx.h<br>
-devices/vector/gdevpsdf.h<br>
-devices/vector/gdevpsdu.c<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-09 14:38: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=6cab1a4b2a08a7d0bcb4772d28a22c72eff62052">6cab1a4b2a08a7d0bcb4772d28a22c72eff62052</a>
-<blockquote>
-<p>
- pdfwrite - write fonts as ProcSet resources instead of fonts<br>
-<br>
- Seems that font names aren't allowed to have spaces and aren't supposed<br>
- to use string syntax (bloody stupid idea). So just write a DSC comment<br>
- that its a ProcSet instead of a Font, problem solved.<br>
-<br>
-devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-09 09:18:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b28091a97d3c153feeecf47dc8fefa90ab5984a2">b28091a97d3c153feeecf47dc8fefa90ab5984a2</a>
-<blockquote>
-<p>
- PDF interpreter - fix a typo in an error message<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-05 10:51: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=0ec0f1627b7f7f5ffa1347123a926cd1e32c9f19">0ec0f1627b7f7f5ffa1347123a926cd1e32c9f19</a>
-<blockquote>
-<p>
- PDF interpreter + pdfwrite - use font object numbers to detect identical fonts<br>
-<br>
- Previously we have had problems when dealing with multiple input PDF files<br>
- where the files contain subset fonts with poorly chosen subset prefixes.<br>
- Because we only have the font name to work with it was difficult to<br>
- determine whether two fonts with the same name were, in fact, the same font.<br>
- Incorrectly deciding that fonts were the same led to glyphs being wrong<br>
- in the pdfwrite output, whereas treating all fonts as unique resulted in<br>
- outputting far, far too many font instances.<br>
-<br>
- In ths commit we add a means to determine from PostScript the filename<br>
- associated with a PostScript file object and we use that to get the<br>
- filename of the current PDF file being processed in the PDF interpreter.<br>
-<br>
- When we encounter a font in a PDF file, we check to see whether it has<br>
- an object number and a FontDescriptor, if the FontDescriptor is present<br>
- we get its object number. We then check to see if the FontDescriptor<br>
- has a FontFile, if it does not then the font is not embedded.<br>
-<br>
- If the font is embedded then we use the object number of the FontDescriptor<br>
- (two fonts can have the same FOntDescriptor, and we can treat these as<br>
- being the same font) and combine it with the PDF filename using a<br>
- CRC to produce a hash which we store in the font as an XUID.<br>
-<br>
- pdfwrite then uses the XUID (if present) to determine if two fonts<br>
- are in fact the same font.<br>
-<br>
- Adding the XUID causes a very small number of pixel differences in<br>
- the text of some PDF files (especially, for some reason, with the<br>
- psdcmy device). Also, a few PDF files have multiple copies of the<br>
- same font, with different FontDescriptors, which were previously merged<br>
- but now are not, whch leads to a small increase in file size.<br>
-<br>
- This new behaviour can be disabled by adding the -dPDFDontUseFontObjectNum<br>
- switch on the command line.<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-Resource/Init/pdf_font.ps<br>
-Resource/Init/pdf_main.ps<br>
-Resource/Init/pdf_ops.ps<br>
-devices/vector/gdevpdtf.h<br>
-devices/vector/gdevpdtt.c<br>
-doc/VectorDevices.htm<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-08 11:59:16 +0200
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d3d767d9b91ae7d82c261fbdfd735f3042161032">d3d767d9b91ae7d82c261fbdfd735f3042161032</a>
-<blockquote>
-<p>
- Reindent jbig2dec source to follow gs coding style.<br>
-<br>
- First a pass through gnu indent:<br>
- indent \<br>
- -bad -nbap -nsob -br -ce -cli0 \<br>
- -npcs -ncs -i4 -di0 -psl -lp -lps -nut -l160 \<br>
- *.c *.h<br>
-<br>
- Followed by astyle to patch over some of the indentation bugs in gnu indent:<br>
-<br>
- astyle --style=kr -H -U -k3 *.c *.h<br>
-<br>
-jbig2dec/config_win32.h<br>
-jbig2dec/getopt.c<br>
-jbig2dec/getopt.h<br>
-jbig2dec/getopt1.c<br>
-jbig2dec/jbig2.c<br>
-jbig2dec/jbig2.h<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_generic.h<br>
-jbig2dec/jbig2_halftone.c<br>
-jbig2dec/jbig2_halftone.h<br>
-jbig2dec/jbig2_huffman.c<br>
-jbig2dec/jbig2_huffman.h<br>
-jbig2dec/jbig2_hufftab.h<br>
-jbig2dec/jbig2_image.c<br>
-jbig2dec/jbig2_image.h<br>
-jbig2dec/jbig2_image_pbm.c<br>
-jbig2dec/jbig2_image_png.c<br>
-jbig2dec/jbig2_metadata.c<br>
-jbig2dec/jbig2_metadata.h<br>
-jbig2dec/jbig2_mmr.c<br>
-jbig2dec/jbig2_mmr.h<br>
-jbig2dec/jbig2_page.c<br>
-jbig2dec/jbig2_priv.h<br>
-jbig2dec/jbig2_refinement.c<br>
-jbig2dec/jbig2_segment.c<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-jbig2dec/jbig2_symbol_dict.h<br>
-jbig2dec/jbig2_text.c<br>
-jbig2dec/jbig2_text.h<br>
-jbig2dec/jbig2dec.c<br>
-jbig2dec/memcmp.c<br>
-jbig2dec/memento.c<br>
-jbig2dec/memento.h<br>
-jbig2dec/os_types.h<br>
-jbig2dec/pbm2png.c<br>
-jbig2dec/sha1.c<br>
-jbig2dec/sha1.h<br>
-jbig2dec/snprintf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-05 15:21:43 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22506f32c40851e9ec6d0321f7ef82f1c9e12605">22506f32c40851e9ec6d0321f7ef82f1c9e12605</a>
-<blockquote>
-<p>
- Update C-style to mention that we don't mix tabs and spaces.<br>
-<br>
-doc/C-style.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-05 14:53:03 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=08b7f1ef45a844138df28e678c062400036a7b8b">08b7f1ef45a844138df28e678c062400036a7b8b</a>
-<blockquote>
-<p>
- Fix warning: for loop has empty body (semicolon at end of line).<br>
-<br>
-jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-08 09:42: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=9c29e53a5955c3c12ed1b1dff66a564cbec8d24d">9c29e53a5955c3c12ed1b1dff66a564cbec8d24d</a>
-<blockquote>
-<p>
- Close file on error before exit<br>
-<br>
-jbig2dec/jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-08 09:37: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=d65f57bc4dc4732dc828a342498c34308101e507">d65f57bc4dc4732dc828a342498c34308101e507</a>
-<blockquote>
-<p>
- Fix jbig2dec libpng API versions support<br>
-<br>
-jbig2dec/jbig2_image_png.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-07 15:33: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=b0878d062cf7acefbc2b47e038af4e3392132981">b0878d062cf7acefbc2b47e038af4e3392132981</a>
-<blockquote>
-<p>
- Update version number and dates for jbig2dec release<br>
-<br>
- will be v0.13<br>
-<br>
-jbig2dec/CHANGES<br>
-jbig2dec/config_win32.h<br>
-jbig2dec/configure.ac<br>
-jbig2dec/jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-31 08:00: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=1e6f5f00082ee7aa8dbcf65bfcc3ba85acd89443">1e6f5f00082ee7aa8dbcf65bfcc3ba85acd89443</a>
-<blockquote>
-<p>
- Correct a couple of typos<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-05 12:28: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=f29334eac74485b8274d13b56915b5e28290e6c7">f29334eac74485b8274d13b56915b5e28290e6c7</a>
-<blockquote>
-<p>
- txtwrite - remove some commented out code<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-04-05 12: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=734ebbf2ca118da7fbc56ae53e7c08db477ce96d">734ebbf2ca118da7fbc56ae53e7c08db477ce96d</a>
-<blockquote>
-<p>
- pdfwrite - remove various chunks of dead/deprecated code<br>
-<br>
-devices/vector/gdevpdfc.c<br>
-devices/vector/gdevpdfd.c<br>
-devices/vector/gdevpdte.c<br>
-devices/vector/gdevpdtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-05 14:56:03 -0800
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab109aaeb3ddba59518b036fb288402a65cf7ce8">ab109aaeb3ddba59518b036fb288402a65cf7ce8</a>
-<blockquote>
-<p>
- Bug 694724: Have filenameforall and getenv honor SAFER<br>
-<br>
-Resource/Init/gs_init.ps<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-29 15:25: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=bcdbe51791cf38240c73862af9ca1cacb8f3e177">bcdbe51791cf38240c73862af9ca1cacb8f3e177</a>
-<blockquote>
-<p>
- Tidy up the 'sanitize' target<br>
-<br>
- Have configure check that the compiler and linker can handle the address<br>
- sanitizer options, and if not, put something dummy in so the 'sanitize'<br>
- will fail pretty much immediately.<br>
-<br>
- Remove the '-i' option from the recursive make call since we no longer need<br>
- that.<br>
-<br>
-Makefile.in<br>
-base/unix-end.mak<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-03 11:38:44 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8b1d6f2f8d9e9f1706e2893042872a723a6d3ce3">8b1d6f2f8d9e9f1706e2893042872a723a6d3ce3</a>
-<blockquote>
-<p>
- Bug 696563: tidy memory use in genconf and mkromfs<br>
-<br>
- Both tools failed to free all their working memory before exit.<br>
-<br>
- genconf was especially bad.<br>
-<br>
-base/genconf.c<br>
-base/mkromfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-05 15:52: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=fc1d455fe97e3c306a04c5f3674bb61969d9302d">fc1d455fe97e3c306a04c5f3674bb61969d9302d</a>
-<blockquote>
-<p>
- Bug 693179: move gc related variables off C stack<br>
-<br>
- The variables ticks_left and gc_signal were local stack variables in interp()<br>
- and gs_call_inter() respectively, a pointer to which was set in the<br>
- gs_memory_gc_status_t of each memory &quot;space&quot;.<br>
-<br>
- This moves and &quot;merges&quot; the variables into a single entry in gs_lib_ctx, and<br>
- has the memory spaces access that variable directly in gs_lib_ctx, rather than<br>
- through a pointer belonging to each space.<br>
-<br>
-base/gsalloc.c<br>
-base/gsalloc.h<br>
-base/gslibctx.h<br>
-psi/interp.c<br>
-psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-29 08:42:50 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=96a779957d6d0dc83e0f97e302b1e5ecdc924f61">96a779957d6d0dc83e0f97e302b1e5ecdc924f61</a>
-<blockquote>
-<p>
- pdfwrite - silence some compiler warnings<br>
-<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-28 17:41:16 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22dac7b2fa8f5015687396433ceb6c5038002ec9">22dac7b2fa8f5015687396433ceb6c5038002ec9</a>
-<blockquote>
-<p>
- Remove a couple of mac specific hidden files<br>
-<br>
- These shouldn't be in the repo<br>
-<br>
-lcms2/Projects/mac/._.DS_Store<br>
-lcms2/Projects/mac/LittleCMS/._.DS_Store<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-28 17: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=fa20f5915978823a8c72a80e49fa90ce9c5c5879">fa20f5915978823a8c72a80e49fa90ce9c5c5879</a>
-<blockquote>
-<p>
- High level forms - cope with junk on stack after PaintProc<br>
-<br>
- Bug #696678 &quot; &quot;Error: /typecheck in --.execform1--&quot; writing pdf file&quot;<br>
-<br>
- Form PaintProc procedures are supposed to have no side effects, in<br>
- particular they should not disturb the stacks. There are some<br>
- PostScript programs which (usually by negligence) don't obey this<br>
- restriction.<br>
-<br>
- If the PaintProc deliberately disturbs the stacks, or has other side-<br>
- effects, then there is nothing we can do about it, but if its just an<br>
- oversight we can 'fix' the problem by removing extraneous objects from<br>
- the operand stack after we execute the PaintProc and before we call<br>
- .endform.<br>
-<br>
- This allows some badly behaved PostScript programs to work.<br>
-<br>
- No differences expected.<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-22 15:12:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f124ca485a4a0648cc502f5e5adb3e2b8b9de955">f124ca485a4a0648cc502f5e5adb3e2b8b9de955</a>
-<blockquote>
-<p>
- pdfwrite - optimise rectangular subpaths as 're' where possible<br>
-<br>
- The current 'vector device' path code doesn't work properly with clips and<br>
- doesn't optimise rectangular subpaths as rectangles. (For the purposes<br>
- of 're' optimisation a rectangular subpath is a moveto, followed by 4<br>
- lineto's at right angles, followed by a closepath).<br>
-<br>
- This commit creates new code to handle pahts in pdfwrite, if the enumerator<br>
- is a clip enumerator it correctly enumerates the subpaths from the clip<br>
- instead of enumerating the path.<br>
-<br>
- We buffer up operations looking for rectangles; when we find one, if the<br>
- current matrix is not sheared or skewed, then we check to see if the<br>
- rectangle is 'x first'. If it isn't we move the starting point round by one<br>
- as 're' always emits width first. We also check to see if we are doing<br>
- a dashed stroke, as if we are we cannot move the initial vertex as this<br>
- will cause the dash to be incorrect (abort the optimisation).<br>
-<br>
- We copy the code from gdevvec whcih checks to see if the whole path is<br>
- a rectangle, and also the 'optimise' code whch will concatenate colinear<br>
- moveto and lineto operations into a single operation.<br>
-<br>
- Finally we also preserve the heuristic that prevents a fill with a trailing<br>
- moveto as ths apparently exposed a bug in old versions of Acrobat.<br>
-<br>
- Ths does result in a number of single pixel or single pixel wide<br>
- differences in the test suite, but they all look like simple differences<br>
- to me, not regressions. The new code doesn not appear to be<br>
- singificantly slower and ths does produce a useful reduction in file<br>
- size for some files.<br>
-<br>
-base/gdevvec.h<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-23 17:28:08 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=efc6c6f3587b0c08522f3d9f45e611dc1dceba23">efc6c6f3587b0c08522f3d9f45e611dc1dceba23</a>
-<blockquote>
-<p>
- Bring Memento up to date with MuPDF version.<br>
-<br>
-base/memento.c<br>
-base/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-23 17:24:04 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7152391110d4b58287740e4de90912024169ac9d">7152391110d4b58287740e4de90912024169ac9d</a>
-<blockquote>
-<p>
- Add comment to misleading device code.<br>
-<br>
-devices/gdevdjtc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-24 11:04:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5a7b20755617cde8c915ab24725f94fd74be3aee">5a7b20755617cde8c915ab24725f94fd74be3aee</a>
-<blockquote>
-<p>
- Bring master up to date with gs919 branch<br>
-<br>
- Add words to 9.18 release notes<br>
-<br>
- about the revised directory structure, build and executable names<br>
-<br>
- Tweak changelog for 9.18 release<br>
-<br>
- Update dates versions in docs etc<br>
-<br>
- Changelog + release &quot;highlights&quot;.<br>
-<br>
- Dates, strings and changelog for release.<br>
-<br>
-Makefile.in<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/Xfonts.htm<br>
-doc/gs-vms.hlp<br>
-doc/thirdparty.htm<br>
-man/dvipdf.1<br>
-man/font2c.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>
-man/wftopfa.1<br>
-psi/int.mak<br>
-psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-21 10:38:58 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ee0a82260050b2b7391b4968cd02682557e2cbc">7ee0a82260050b2b7391b4968cd02682557e2cbc</a>
-<blockquote>
-<p>
- PDF interpreter - cope with Indexed space with 'hival' being indirect<br>
-<br>
- The code to handle an Indexed colour space expected that the 'hival',<br>
- that is the highest index, would be an integer. It can legally be an<br>
- indirect reference. Dumb, but legal.<br>
-<br>
- Here we 'resolve' the hival in case it is an indirect reference.<br>
-<br>
- No differences expected<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-17 17:12: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=2dda1c123c76a126059808c04df63805f1694686">2dda1c123c76a126059808c04df63805f1694686</a>
-<blockquote>
-<p>
- Bug 696665: add extra brackets for better compatibility<br>
-<br>
- Some versions of autoconf enforce macro arguments to macros being bounded by<br>
- &quot;[&quot; and &quot;[&quot;, others do not (the version I have does not), but we should use<br>
- them for best compatibility.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-17 10:21: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=2e262fac0f15b51dd3588e3e92157b5fd2a90bb2">2e262fac0f15b51dd3588e3e92157b5fd2a90bb2</a>
-<blockquote>
-<p>
- Remove some left debug code.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-17 10:06:14 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c281807816be4dcc10c3fc66b32651098f321600">c281807816be4dcc10c3fc66b32651098f321600</a>
-<blockquote>
-<p>
- Bug 696665: fix gs only install<br>
-<br>
- I added dummy gpcl6 and gxps exe names to avoid a warning when building from a<br>
- gs only release archive. I neglected to add appropriate dummy install targets<br>
- for those, and that caused an error with &quot;make install&quot;.<br>
-<br>
-base/unixinst.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-15 08:29:03 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aeb5c1e3d2b47ffb9f4ccd01d32429ebd2c5effc">aeb5c1e3d2b47ffb9f4ccd01d32429ebd2c5effc</a>
-<blockquote>
-<p>
- Increase limits for tile_clip_buffer and Max VM on 64-bit machines<br>
-<br>
- These changes allow the file from bug 696257 to complete on 64-bit gcc<br>
- builds where a &quot;long&quot; is 64 bits. Also the MaxLocalVM and MaxGlobalVM<br>
- values returned in CPSI mode are truncated to return only the low 32<br>
- bits (CET 99-01.ps)<br>
-<br>
-base/gsalloc.c<br>
-base/gxmclip.h<br>
-psi/zusparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-15 08:17:34 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=28049debc650116b9762d7b0ec82f52d45039927">28049debc650116b9762d7b0ec82f52d45039927</a>
-<blockquote>
-<p>
- Revert change to mswinpr2 device from commit 5cf300b<br>
-<br>
- This caused us to ignore the printer specified by -s%printer%___<br>
- and always use the default printer if QueryUser was not specified<br>
-<br>
-devices/gdevwpr2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-15 10:38: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=38990b3619ed74308454d0d3910bd394a982e7cd">38990b3619ed74308454d0d3910bd394a982e7cd</a>
-<blockquote>
-<p>
- pdfwrite - more changes for composite object emission<br>
-<br>
- This 'fixes' Bug 696657, but it is not correct in general.<br>
-<br>
- We break the emission of composite objects up into blocks of less than<br>
- 255 characters for compliance with DSC output, but if any one of the<br>
- objects contains certain characters ('/' '[' '{' '(' or ' ') then we<br>
- might break the object inappropriately (this is likely for strings and<br>
- is the case for ths file).<br>
-<br>
- There is no way to address this 'properly' in general, its perfectly<br>
- possible to create a PostScript object more than 255 bytes which<br>
- cannot be broken up, so I'm going to ignore the problem for now, since<br>
- it only occurs when writing pdfmarks to the ps2write device and having<br>
- DSC turned on (which is the default).<br>
-<br>
- If anyone really needs to do this, they should set ProduceDSC to false.<br>
-<br>
-devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-15 09:37:53 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=15240a6631e2c721402dcbaf58d9b784707bde42">15240a6631e2c721402dcbaf58d9b784707bde42</a>
-<blockquote>
-<p>
- Bug 696655: have configure support --without-pcl<br>
-<br>
- and --without-xps.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-15 09:19: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=5d1ffe2669e7523e579a4cc47bb6debe805c0a2c">5d1ffe2669e7523e579a4cc47bb6debe805c0a2c</a>
-<blockquote>
-<p>
- pdfwrite - fix writing of composite objects<br>
-<br>
- When emitting composite objects we attempt (for reasons which are<br>
- unclear) to do so in chunks of 256 bytes or less. The code to split a<br>
- large buffer into smaller buffers was simply broken, did not work<br>
- properly at all.<br>
-<br>
- This commit fixes the logical flaw, allowing us to write composite<br>
- objects larger then 254 bytes without error.<br>
-<br>
- NB this is a rare condition, such objects are usually only created<br>
- from input such as pdfmarks, normal composite objects are created and<br>
- emitted by pdfwrite itself and do not go through this code.<br>
-<br>
-devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-14 10:09: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=ebd8585aabd050b64e33221478d0bcb6b7f41abf">ebd8585aabd050b64e33221478d0bcb6b7f41abf</a>
-<blockquote>
-<p>
- Always have configure set gpcl6 and gxps exe names<br>
-<br>
- But still skip adding them to the targets list if the source is not available.<br>
-<br>
- This avoids a warning when building a Ghostscript only release archive.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-11 10:13: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=36ea2f21ee862f6e3d3276389cf71a8d0008865b">36ea2f21ee862f6e3d3276389cf71a8d0008865b</a>
-<blockquote>
-<p>
- Bump version number/date<br>
-<br>
-Resource/Init/gs_init.ps<br>
-base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-23 08:19:58 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=50a8b6fcd897e71344965d6bc300f0d01b850fad">50a8b6fcd897e71344965d6bc300f0d01b850fad</a>
-<blockquote>
-<p>
- Dates, strings and changelog 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/Xfonts.htm<br>
-doc/gs-vms.hlp<br>
-doc/thirdparty.htm<br>
-man/dvipdf.1<br>
-man/font2c.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>
-man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-17 17:12: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=9cf6bfee8d3c285e84d28437bff0747f601a7827">9cf6bfee8d3c285e84d28437bff0747f601a7827</a>
-<blockquote>
-<p>
- Bug 696665: add extra brackets for better compatibility<br>
-<br>
- Some versions of autoconf enforce macro arguments to macros being bounded by<br>
- &quot;[&quot; and &quot;[&quot;, others do not (the version I have does not), but we should use<br>
- them for best compatibility.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-17 10:21: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=d7e175bc49d8dcdc38af093cd744c62cb6451686">d7e175bc49d8dcdc38af093cd744c62cb6451686</a>
-<blockquote>
-<p>
- Remove some left debug code.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-17 10:06:14 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a529498d1a52bbb91cca5e32512d6c49e665a004">a529498d1a52bbb91cca5e32512d6c49e665a004</a>
-<blockquote>
-<p>
- Bug 696665: fix gs only install<br>
-<br>
- I added dummy gpcl6 and gxps exe names to avoid a warning when building from a<br>
- gs only release archive. I neglected to add appropriate dummy install targets<br>
- for those, and that caused an error with &quot;make install&quot;.<br>
-<br>
-base/unixinst.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-15 08:17:34 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3a089782b11699fe83c22a92544623a9c21e0c4a">3a089782b11699fe83c22a92544623a9c21e0c4a</a>
-<blockquote>
-<p>
- Revert change to mswinpr2 device from commit 5cf300b<br>
-<br>
- This caused us to ignore the printer specified by -s%printer%___<br>
- and always use the default printer if QueryUser was not specified<br>
-<br>
-devices/gdevwpr2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-11 12:17:57 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1a8b008b6d34efcc00b8c10507a28b517ab5b7db">1a8b008b6d34efcc00b8c10507a28b517ab5b7db</a>
-<blockquote>
-<p>
- Changelog + release &quot;highlights&quot;.<br>
-<br>
-doc/Devices.htm<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-14 10:09: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=2e7c06dc36d9fe255a6171a28967eb53395abe4f">2e7c06dc36d9fe255a6171a28967eb53395abe4f</a>
-<blockquote>
-<p>
- Always have configure set gpcl6 and gxps exe names<br>
-<br>
- But still skip adding them to the targets list if the source is not available.<br>
-<br>
- This avoids a warning when building a Ghostscript only release archive.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-11 10:34:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7f9c8fbce554eebdbda21f25d208c541355e177d">7f9c8fbce554eebdbda21f25d208c541355e177d</a>
-<blockquote>
-<p>
- Update dates versions in docs etc<br>
-<br>
-Makefile.in<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/Xfonts.htm<br>
-doc/gs-vms.hlp<br>
-doc/thirdparty.htm<br>
-man/dvipdf.1<br>
-man/font2c.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>
-man/wftopfa.1<br>
-psi/int.mak<br>
-psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-11 10:30:26 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=837d4dcaff85a7c96726caaeeb10b690aa6e18f1">837d4dcaff85a7c96726caaeeb10b690aa6e18f1</a>
-<blockquote>
-<p>
- Change product string for 9.19 RC1<br>
-<br>
-base/gscdef.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-30 14:57: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=50efb7307dab9df334ad45acdfbe83bf2f3ffba3">50efb7307dab9df334ad45acdfbe83bf2f3ffba3</a>
-<blockquote>
-<p>
- Tweak changelog for 9.18 release<br>
-<br>
-doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-24 11:04:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=32e59ede8dddc2838478dfaeac2a238318c22835">32e59ede8dddc2838478dfaeac2a238318c22835</a>
-<blockquote>
-<p>
- Add words to 9.18 release notes<br>
-<br>
- about the revised directory structure, build and executable names<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-
-<h2><a name="Version9.19"></a>Version 9.19 (2016-03-23)</h2>
-
-<p>This is the thirteenth full release in the stable 9.x series, and is mainly
-a maintenance release.
-
-<p> Highlights in this release include:
-<ul>
-<li>
-<p>
-New custom PJL (near) equivalents for pdfmark and setdistillerparams. These were
-primarily added to allow pdfwrite to be configured correctly for PDF/A output from
-GhostPCL.
-See: <a href="VectorDevices.htm#PXL_IN">pdfwrite with PCL input</a> for
-more details.
-<p>
-Ghostscript users should continue to use the existing pdfmark and setdistillerparams
-capabilities.
-</li>
-<li>
-<p>
-Metadata pdfmark is now implemented. This allows the user to
-specify an XMP stream which will be written to the Catalog of the PDF
-file. A new pdfmark 'Ext_Metadata' has been defined. This takes a string
-parameter which contains XML to be added to the XMP normally created by
-pdfwrite.
-<p>
-See <a href="VectorDevices.htm#Extensions">pdfwrite pdfmark extensions</a> for more
-information.
-</li>
-<li>
-<p>
-An experimental, rudimentary raster trapping implementation has been added to the Ghostscript
-graphics library. See <a href="Devices.htm#TIFF_trapping">Trapping</a> for details.
-</li>
-<li>
-<p>
-The halftone threshold array generation tools (part of <code>toolbin/halftone</code>) have been
-improved with <code>thresh_remap</code> which allows folding the transfer function (AKA toner
-response curve (TRC)) into the threshold array so that highlights are improved. Further,
-<code>gen_stochastic</code> has improved support for minimum dot size and shape.
-</li>
-<li>
-<p>Plus the usual round of bug fixes, compatibility changes, and incremental improvements.
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.19_Incompatible_changes"></a>Incompatible changes</h3>
-<ul>
-<li>
-<p>
-(Minor) API change: copy_alpha now supports 8 bit depth (as well as the previous 2 and 4).
-</li>
-<li>
-<p>
-The gs man pages are woefully out of date and basically unmaintained. With the release
-following 9.19, we intend to replace their contents with a very limited summary of (unlikely
-to ever change aspects of) calling Ghostscript, and a pointer to the (maintained) HTML
-documentation. That is, unless a volunteer is willing to update, and commit to
-maintaining the man pages.
-</li>
-<li>
-We plan (ideally for the release following 9.19) to somewhat tidy up the device API.
-We plan to remove deprecated device procs (methods/function pointers). We also
-intend to merge the imager state and graphics state (thus eliminating the
-imager state), and change the device API so every device proc takes a graphics
-state parameter (rather than the current scheme where only a very few procs
-take an imager state parameter). This should serve as notice to anyone
-maintaining a Ghostscript device outside the canonical source tree that you
-may (probably will) need to update your device(s) when these changes happen.
-Devices using only the non-deprecated procs should be trivial to update.
-</li>
-</ul>
-
-<h3><a name="9.19_changelog"></a>Changelog</h3>
-<p><strong>2016-03-17 17:12: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=9cf6bfee8d3c285e84d28437bff0747f601a7827">9cf6bfee8d3c285e84d28437bff0747f601a7827</a>
-<blockquote>
-<p>
- Bug 696665: add extra brackets for better compatibility<br>
-<br>
- Some versions of autoconf enforce macro arguments to macros being bounded by<br>
- &quot;[&quot; and &quot;[&quot;, others do not (the version I have does not), but we should use<br>
- them for best compatibility.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-17 10:21: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=d7e175bc49d8dcdc38af093cd744c62cb6451686">d7e175bc49d8dcdc38af093cd744c62cb6451686</a>
-<blockquote>
-<p>
- Remove some left debug code.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-17 10:06:14 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a529498d1a52bbb91cca5e32512d6c49e665a004">a529498d1a52bbb91cca5e32512d6c49e665a004</a>
-<blockquote>
-<p>
- Bug 696665: fix gs only install<br>
-<br>
- I added dummy gpcl6 and gxps exe names to avoid a warning when building from a<br>
- gs only release archive. I neglected to add appropriate dummy install targets<br>
- for those, and that caused an error with &quot;make install&quot;.<br>
-<br>
-base/unixinst.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-15 08:17:34 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3a089782b11699fe83c22a92544623a9c21e0c4a">3a089782b11699fe83c22a92544623a9c21e0c4a</a>
-<blockquote>
-<p>
- Revert change to mswinpr2 device from commit 5cf300b<br>
-<br>
- This caused us to ignore the printer specified by -s%printer%___<br>
- and always use the default printer if QueryUser was not specified<br>
-<br>
-devices/gdevwpr2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-14 10:09: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=f75b4a8160d60039d850c581c7fbe18f1574bc39">f75b4a8160d60039d850c581c7fbe18f1574bc39</a>
-<blockquote>
-<p>
- Always have configure set gpcl6 and gxps exe names<br>
-<br>
- But still skip adding them to the targets list if the source is not available.<br>
-<br>
- This avoids a warning when building a Ghostscript only release archive.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-11 10:34:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7f9c8fbce554eebdbda21f25d208c541355e177d">7f9c8fbce554eebdbda21f25d208c541355e177d</a>
-<blockquote>
-<p>
- Update dates versions in docs etc<br>
-<br>
-Makefile.in<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/Xfonts.htm<br>
-doc/gs-vms.hlp<br>
-doc/thirdparty.htm<br>
-man/dvipdf.1<br>
-man/font2c.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>
-man/wftopfa.1<br>
-psi/int.mak<br>
-psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-11 10:30:26 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=837d4dcaff85a7c96726caaeeb10b690aa6e18f1">837d4dcaff85a7c96726caaeeb10b690aa6e18f1</a>
-<blockquote>
-<p>
- Change product string for 9.19 RC1<br>
-<br>
-base/gscdef.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-30 14:57: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=50efb7307dab9df334ad45acdfbe83bf2f3ffba3">50efb7307dab9df334ad45acdfbe83bf2f3ffba3</a>
-<blockquote>
-<p>
- Tweak changelog for 9.18 release<br>
-<br>
-doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-24 11:04:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=32e59ede8dddc2838478dfaeac2a238318c22835">32e59ede8dddc2838478dfaeac2a238318c22835</a>
-<blockquote>
-<p>
- Add words to 9.18 release notes<br>
-<br>
- about the revised directory structure, build and executable names<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-10 11:16:51 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e980dc6f1356e659254974838a94e16d6506af44">e980dc6f1356e659254974838a94e16d6506af44</a>
-<blockquote>
-<p>
- Bug 696640: Fix stack overflow in memento.<br>
-<br>
- Windows backtraces are limited to 63 levels. Linux ones can be<br>
- any size. I'd mistakenly overflown the buffers in the linux<br>
- case.<br>
-<br>
- While we're fixing that, improve the code to require less copying.<br>
-<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-10 04:32:36 -0800
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=596e5b0bb0bc470cc177e5dca35bc69de7c664d1">596e5b0bb0bc470cc177e5dca35bc69de7c664d1</a>
-<blockquote>
-<p>
- Memento: Fix linux memento builds.<br>
-<br>
- The fix for windows builds broke linux due to -DMEMENTO<br>
- being in CFLAGS on windows, and GENOPT on configured builds.<br>
-<br>
- Also tidy the code to avoid things detected by the more picky<br>
- compiler on Linux.<br>
-<br>
-base/lib.mak<br>
-base/memento.c<br>
-base/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-09 23:44:10 +0100
-</strong>
-<br>Vincent Torri &lt;vincent dot torri at gmail dot com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=80c9d7671534c51e7239e0f7c5ca8a67a43c842d">80c9d7671534c51e7239e0f7c5ca8a67a43c842d</a>
-<blockquote>
-<p>
- Bug 696641 - support build with MSYS2<br>
-<br>
- uname in MSYS2 terminal reports MSYS_NT-6.1, so add MSYS* to all the &quot;case&quot;<br>
- in configure.ac.<br>
-<br>
- Note: cygwin terminal's uname reports CYGWIN_NT-6.1<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-10 11:11:35 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f79377b1a156c40ff304a3d161b54865e35f23a3">f79377b1a156c40ff304a3d161b54865e35f23a3</a>
-<blockquote>
-<p>
- Fix windows memento builds.<br>
-<br>
- So, windows.h cannot be used unless Microsoft extensions are enabled.<br>
- How dumb is that?<br>
-<br>
-base/lib.mak<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-09 10:49:26 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e787367c085457a106890ce4c2068dccee86933">0e787367c085457a106890ce4c2068dccee86933</a>
-<blockquote>
-<p>
- Removing hacky HAVE_LIBDL stuff for memento....<br>
-<br>
- Replace with proper configure setting.<br>
-<br>
-base/lib.mak<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-09 15:36:50 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f0dd9dd527451c1a2b625c667c4bf0a131e9ce3">4f0dd9dd527451c1a2b625c667c4bf0a131e9ce3</a>
-<blockquote>
-<p>
- Properly fix building with shared OpenJPEG.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-07 06:26:25 -0800
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d4339898f181acb77bc4cc2a419f38cf4727b4e">0d4339898f181acb77bc4cc2a419f38cf4727b4e</a>
-<blockquote>
-<p>
- Memento: Store/display backtraces with blocks.<br>
-<br>
- If built with MEMENTO_DETAILS (on by default), we store the<br>
- backtrace on every event that affects a block.<br>
-<br>
- Memento_details(address) will display the events that affected<br>
- a block (typically malloc, {realloc}*, free), including the<br>
- backtrace at each point.<br>
-<br>
- Windows and linux use different mechanisms for this. Windows<br>
- loads a DLL and calls windows specific functions - no extra<br>
- libraries are required.<br>
-<br>
- Linux also loads a shared object (libbacktrace.so). This is not<br>
- present on all platforms, so on platforms where it is not available<br>
- we just get addresses. These can be converted using addr2line<br>
- (unless ASLR is enabled).<br>
-<br>
-base/lib.mak<br>
-base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-05 15:25:01 -0800
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8692d5e0996ab3995e1d02efc3d0ca145ccced71">8692d5e0996ab3995e1d02efc3d0ca145ccced71</a>
-<blockquote>
-<p>
- Fix psdcmyk handling of output to /dev/null or equivalent.<br>
-<br>
- The PSD file format does not support multiple images (pages) in a single file,<br>
- so we spot such an attempt (by checking whether or not the output file string<br>
- has a &quot;%d&quot; in it) and throw an error.<br>
-<br>
- This also throws an error if an attempt is made to write multiple pages to<br>
- /dev/null (as is done for performance testing).<br>
-<br>
- Since it really doesn't matter if the output &quot;file&quot; is invalid when we're just<br>
- discarding the data, spot this case, and allow multi-page files to run<br>
- without error.<br>
-<br>
-devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-05 14:34:20 -0800
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49852e6060f63b3feaa15157ee27644eb1d1b8c9">49852e6060f63b3feaa15157ee27644eb1d1b8c9</a>
-<blockquote>
-<p>
- Remove pointless (Mac classic only) setenv()<br>
-<br>
-base/gp_macio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-05 13:12:46 -0800
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=381bc0729b96f47ebe1ee5d49cb603d688361291">381bc0729b96f47ebe1ee5d49cb603d688361291</a>
-<blockquote>
-<p>
- Bug 696610: add pngmonod into the configure build<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-05 20:01:04 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd3c6a408bd64e515a46cfb4bdbbb7e42d0b943e">cd3c6a408bd64e515a46cfb4bdbbb7e42d0b943e</a>
-<blockquote>
-<p>
- Now that we have contatced the original author and received written<br>
- copyright assignment, update the copyright headers for the RAM file<br>
- system code.<br>
-<br>
-base/gsioram.c<br>
-base/ramfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-04 16:18:23 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=284cd94895a68c0d558c2b9d5325b77cce90f807">284cd94895a68c0d558c2b9d5325b77cce90f807</a>
-<blockquote>
-<p>
- Document psdcmykog device.<br>
-<br>
-doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-04 15:15:07 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5cf300b7347c509f7530f5f9e7d6b0b997581f33">5cf300b7347c509f7530f5f9e7d6b0b997581f33</a>
-<blockquote>
-<p>
- Fix bug 696559, default to QueryUser=3 so that printer properties are correct.<br>
-<br>
- Thanks to Nikolaus Kreuzer for suggesting this method. It now seems to work<br>
- as requested and as I would expect.<br>
-<br>
-devices/gdevwpr2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-04 13:56:09 -0800
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=53ee0f551785f8ae3689f8cef77b48d76ba6340f">53ee0f551785f8ae3689f8cef77b48d76ba6340f</a>
-<blockquote>
-<p>
- Bug 696518: remove long deceased pcx2up device.<br>
-<br>
-base/unix-gcc.mak<br>
-configure.ac<br>
-devices/devs.mak<br>
-devices/gdevp2up.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-04 14:04:19 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab70c0f9de22ff012d5d73f9b2aab9ae724a743b">ab70c0f9de22ff012d5d73f9b2aab9ae724a743b</a>
-<blockquote>
-<p>
- Fix bug 696515 -- the snowflak.ps did not handle page size &lt; 250 points.<br>
-<br>
-examples/snowflak.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-14 10:26:16 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=449604f1a31067fa8e32227c3ce234b55b8cf143">449604f1a31067fa8e32227c3ce234b55b8cf143</a>
-<blockquote>
-<p>
- Get rid of code allowing for no 12 bit or 16 bit image support.<br>
-<br>
- The gxino12b.c and gxino16b.c modules were no longer used and the<br>
- graphics library always supported 12 and 16 bit images, so remove<br>
- the leftover code allowing for these to be build time options.<br>
-<br>
- This was causing false positives with helgrind since the procs<br>
- were being set into the two-dimensional array at run time. The<br>
- unpackicc_16 had this same code even though there was no method<br>
- or check for non-support.<br>
-<br>
-base/gxi12bit.c<br>
-base/gxi16bit.c<br>
-base/gximage.h<br>
-base/gximdecode.c<br>
-base/gxino12b.c<br>
-base/gxino16b.c<br>
-base/gxipixel.c<br>
-base/gxiscale.c<br>
-base/gxsample.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-04 19:17:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f71dca797cbcdf0430fd8009c6c517baed62b4cb">f71dca797cbcdf0430fd8009c6c517baed62b4cb</a>
-<blockquote>
-<p>
- pdfwrite - FunctionType 2 C0 and C1 are optional<br>
-<br>
- Bug #696626 &quot; A PDF file causes ps2pdf crash&quot;<br>
-<br>
- The code fro serialising a Type 2 function was assuming that C0 and C1<br>
- were valid (validated by the interpreter) and always present. In fact<br>
- both of these are optional. We were attempting to dereference a NULL<br>
- pointer.<br>
-<br>
- Altered the type 2 serialise code to write the default values if either<br>
- or both of C0 and C1 are not present.<br>
-<br>
- No differences expected.<br>
-<br>
-base/gsfunc3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-04 18:50:01 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a90ca3d4c30339f93b1e595ee81d08f1ca7174e4">a90ca3d4c30339f93b1e595ee81d08f1ca7174e4</a>
-<blockquote>
-<p>
- ps2write - suppress an address sanitizer warning for MM fonts<br>
-<br>
- ps2write does not currently handle Multiple Master fonts well, we know<br>
- this there is an open enhancement for it. We do have a hacky work-around<br>
- which turns the MM OtherSubrs into regular OtherSubrs using the blended<br>
- values.<br>
-<br>
- This doesn't work when the font program uses constrcuts such as ' x y div'<br>
- in order to create floating point values. This could mean that we did<br>
- not have as many paramters as expected on the stack as are required for<br>
- a given MM OtherSubr, leading to us indexing off the bottom of the<br>
- stack.<br>
-<br>
- This meant we were using random values, but this didn't really matter<br>
- as the data is always going to be wrong. However the address sanitizer<br>
- complains about this.....<br>
-<br>
- In this commit if we would underrun the stack we just write a 0 instead<br>
-<br>
-devices/vector/gdevpsf1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-04 15:40:30 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8175c6993efa8637ac39a050cc0696a19214abe1">8175c6993efa8637ac39a050cc0696a19214abe1</a>
-<blockquote>
-<p>
- pdfwrite fix address sanitizer complaint.<br>
-<br>
- When checking a font name to see if its a URW replacement for a base 14<br>
- font we were doing a memcmp with the length of the candidate name.<br>
-<br>
- If that length exceeded the length of the URW name then we were in<br>
- effect comparng against part of the next name (or random bytes off the<br>
- end of the table.<br>
-<br>
- Of course this is harmless except in the highly unlikely case of the end<br>
- of the table not being followed by more data bytes. But the address<br>
- sanitizer complains. So we now compare the length of the two strings<br>
- first.<br>
-<br>
-devices/vector/gdevpdtb.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-03 15:50:48 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b40526038481dd3158331df6c42c47654e02c3ab">b40526038481dd3158331df6c42c47654e02c3ab</a>
-<blockquote>
-<p>
- Memento: Speed improvements.<br>
-<br>
- Avoid searching the linked list of blocks in order to remove a<br>
- block by moving to a doubly linked list. This can be done<br>
- without increasing the amount of memory in use by making better<br>
- use of the 'parent' pointer that is only used when displaying<br>
- nested blocks.<br>
-<br>
- Also store magic values in the 'child' and 'sibling' pointers<br>
- (again only used when displaying nested blocks) so that we<br>
- can quickly verify that a block is real before doing too much<br>
- with it.<br>
-<br>
- Those changes drastically reduce the time required for<br>
- MEMENTO_LEAKONLY runs (now the same order of magnitude as non<br>
- memento runs).<br>
-<br>
- Normal memento runs are still very slow when the numbers of<br>
- blocks increase due to the paranoid checking taking time.<br>
-<br>
- To ameliorate this a bit, we try 2 other things.<br>
-<br>
- Firstly, we optimise the searching of blocks by making use of<br>
- int aligned tests. This still doesn't make much difference.<br>
-<br>
- Secondly, we introduce a new mechanism for the 'paranoia'<br>
- levels. If a negative number is given for the paranoia level<br>
- (say -n) then we first perform our overwrite checks after n events.<br>
- We next test after 2n events, then 4n, then 8n etc.<br>
-<br>
- The new default paranoia level is set to be -1024.<br>
-<br>
- This makes a huge difference, and brings normal memento runs<br>
- down to be comparable with debug runs.<br>
-<br>
-base/memento.c<br>
-base/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-01 16:58:43 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83055a87a2ce1910ede8cdfe722766a8a4c13d55">83055a87a2ce1910ede8cdfe722766a8a4c13d55</a>
-<blockquote>
-<p>
- Bug 696616: Move antidropout downscaler functionality.<br>
-<br>
- The current code globally enables use of the antidropout<br>
- downscaler on all halftoned devices (unless they override<br>
- the gxdso call), when interpolation is enabled.<br>
-<br>
- We now introduce a -dAntidropoutDownscaler option that<br>
- defaults off. That sets a bit in dev.color_info that is<br>
- used to control the option. This decouples it from<br>
- interpolation.<br>
-<br>
-base/gdevdflt.c<br>
-base/gsdparam.c<br>
-base/gxdevcli.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-01 17:20: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=7a3d6527825a79471e93b723bbd2e6dad0c61b64">7a3d6527825a79471e93b723bbd2e6dad0c61b64</a>
-<blockquote>
-<p>
- Fix up some broken/out of date links<br>
-<br>
- Marcos did some cleanup identifying broken links, based on his work, I've fixed<br>
- the broken links, and removed those to files that no longer exist.<br>
-<br>
-doc/Develop.htm<br>
-doc/Drivers.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-03-01 15:04:38 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=579f5891d69bcb057f27e44d49bf686d64a9f2ee">579f5891d69bcb057f27e44d49bf686d64a9f2ee</a>
-<blockquote>
-<p>
- Bug 696620: Avoid rangecheck errors in tiff devices.<br>
-<br>
- Only write downscaler options if we will read them.<br>
-<br>
-devices/gdevtifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-29 15:33:23 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c4c85ae660c22d8442c3a9ea17bbc295f2a2fac">3c4c85ae660c22d8442c3a9ea17bbc295f2a2fac</a>
-<blockquote>
-<p>
- high level forms - account for flipped/mirrored CTM<br>
-<br>
- For high level forms support, if the device requests a specific CTM be<br>
- applied we calculate a clip path which includes negative co-ordinates<br>
- to ensure that a translated form won't be erroneously clipped to the<br>
- page.<br>
-<br>
- When doing this, we need to account for the CTM when the form is executed<br>
- potentially being flipped or mirrored (or both!)<br>
-<br>
- No differences expected.<br>
-<br>
-psi/zform.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-28 09:02:43 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5d15322e32f85f9b4d9fbebd19148d7a95428adf">5d15322e32f85f9b4d9fbebd19148d7a95428adf</a>
-<blockquote>
-<p>
- pdfwrite - silence Coverity warning<br>
-<br>
- Change an indent to silence Coverity.....<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-26 09:38:46 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f682ba02caa1cb974e475cc387efce1e04d901f5">f682ba02caa1cb974e475cc387efce1e04d901f5</a>
-<blockquote>
-<p>
- Fixed links in Develop.htm and Drivers.html.<br>
-<br>
- Some referenced files appear to no longer exist, I've left those in<br>
- the documentation but commented out with a 'missing' notation.<br>
-<br>
-doc/Develop.htm<br>
-doc/Drivers.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-25 14:23:02 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b94ac333a172558441726e47f257cb26a3b6f924">b94ac333a172558441726e47f257cb26a3b6f924</a>
-<blockquote>
-<p>
- Bug 696615: Solve incorrect copy_alpha of hl_color<br>
-<br>
- The code that expanded alphas to 8 bits was incorrect for the<br>
- 4 bit case.<br>
-<br>
-base/gdevdbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-25 10:56:35 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=65b72cece8e2462fd787e8d54d9f990327a061ac">65b72cece8e2462fd787e8d54d9f990327a061ac</a>
-<blockquote>
-<p>
- Fix dropped error code in clist code.<br>
-<br>
-base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-25 11:47:27 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f69cda3004976da8da5c23ca86fdb62086ec508">8f69cda3004976da8da5c23ca86fdb62086ec508</a>
-<blockquote>
-<p>
- Another set of broken doc links.<br>
-<br>
-doc/WhatIsGS.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-25 11:30:19 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=09ca513fbcd7e3a843cc2690dd9dadecfd50bad9">09ca513fbcd7e3a843cc2690dd9dadecfd50bad9</a>
-<blockquote>
-<p>
- Fixed another broken link in doc.<br>
-<br>
-doc/WhatIsGS.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-25 11:18:26 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d954bfd6b0bb8e3d7400ca1f5e4b6494ec91384">4d954bfd6b0bb8e3d7400ca1f5e4b6494ec91384</a>
-<blockquote>
-<p>
- Fixed broken links in doc/*.htm.<br>
-<br>
- There are still broken links in doc/Psfiles.htm, doc/Develop.htm, and<br>
- doc/Drivers.htm caused by the files they refer to having been moved to<br>
- a different directory. Those will be fixed in a separate commit.<br>
-<br>
-doc/Devices.htm<br>
-doc/Language.htm<br>
-doc/Readme.htm<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-24 20:09:58 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bcf738d762ef65e16f060d57ea15824f1f6bd57c">bcf738d762ef65e16f060d57ea15824f1f6bd57c</a>
-<blockquote>
-<p>
- Bug 696611: Avoid imagemask interpolation errors with pbmraw.<br>
-<br>
- pbmraw (deliberately) doesn't know how to copy_alpha. We never<br>
- call copy_alpha when going to pbmraw direct because of this, but<br>
- the clist wrapping defeats our detection. This results in an<br>
- error.<br>
-<br>
- Tests enabling copy_alpha for pbmraw show a degredation in render<br>
- quality, so instead, we just disable all imagemask interpolation<br>
- when going to halftone devices.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-24 15:56: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=036710b85c9e1b08ea0c0c7d5e2ad0734a1460eb">036710b85c9e1b08ea0c0c7d5e2ad0734a1460eb</a>
-<blockquote>
-<p>
- Add some 'sanitize' targets to the Makefile<br>
-<br>
- These build with address sanitizer enabled.<br>
-<br>
- These hackily set the '-i' flag in the recursive calls to make<br>
- to sidestep the problems with genconf/mkromfs leaking at the<br>
- moment. These issues will be fixed and the -i removed.<br>
-<br>
-Makefile.in<br>
-base/unix-end.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-24 17:51: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=dd65a40fa66835646972b665f352498c696557a1">dd65a40fa66835646972b665f352498c696557a1</a>
-<blockquote>
-<p>
- Bug 696609: Fix operation in non 24bpp modes.<br>
-<br>
- I had the depth checks in blank_unmasked_pixels wrong.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-24 16:34:35 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1386dbd1ad0bef6b6264e198162d0b7c9abfce54">1386dbd1ad0bef6b6264e198162d0b7c9abfce54</a>
-<blockquote>
-<p>
- Bug 696603: Quieten address sanitiser.<br>
-<br>
- mem_mono_copy_mono includes some clever code that reads<br>
- 16 bits at a time and shifts to do fast mono copies of<br>
- unaligned data. This can result in overreading the end<br>
- of data by a byte, but never so far as to cause address<br>
- overflows due to the granularity at which data can be<br>
- allocated.<br>
-<br>
- The 'overread' data is never actually used.<br>
-<br>
- The simple fix here just extends the source block by<br>
- a byte to avoid error sanitizer complaining. Valgrind<br>
- correctly does not flag this.<br>
-<br>
-pcl/pcl/pcbiptrn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-24 13:45:20 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=628f3de2f47e46d2b56fa9f6bfd7b7a479d8b10e">628f3de2f47e46d2b56fa9f6bfd7b7a479d8b10e</a>
-<blockquote>
-<p>
- Bug 699613: gs leaves temp files in GS_NO_UTF8 windows builds.<br>
-<br>
- Adopt Cecil Hornbakers patch to solve this. Many thanks!<br>
-<br>
-base/gp_mswin.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-24 12:30:28 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8fa7be62354e783551661cbda24b56deb3e67f1f">8fa7be62354e783551661cbda24b56deb3e67f1f</a>
-<blockquote>
-<p>
- Remove unused variables/conditions from gdevpdf.c<br>
-<br>
- Spotted while debugging bug 696612.<br>
-<br>
- Various places in the code do:<br>
-<br>
- { int j, code = 0;<br>
- for (j = 0; j &lt; n &amp;&amp; code &gt;= 0; j++)<br>
- {<br>
- STUFF<br>
- }<br>
- }<br>
-<br>
- which is a perfectly reasonable thing to do - except for the<br>
- facts that: 1) STUFF never alters the value of code, and 2) even<br>
- if STUFF did alter the value of code, we never check the value<br>
- and return it.<br>
-<br>
- Accordingly, I've just removed the references to code.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-24 12:31: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=e2a848f1157fdecab41165ac790394202e13d9d0">e2a848f1157fdecab41165ac790394202e13d9d0</a>
-<blockquote>
-<p>
- Bug 696612: Swallow rangecheck errors in psf_check_outline_glyphs<br>
-<br>
- At the closedown of the file, we run through and write out fonts.<br>
- As part of this process, we check the glyphs in the font. If any<br>
- of the glyphs come back as bad, we abort the whole process.<br>
-<br>
- Previously we ignored any errors here, and my change to make us<br>
- not ignore errors in the pdf_close routine caused this regression.<br>
-<br>
- After discussion with Ken and Chris, the correct fix, I believe,<br>
- is to continue to catch and honour all errors in pdf_close, but<br>
- to explicitly swallow certain errors lower down.<br>
-<br>
- Chris suggested, and I agree with him, that simply swallowing<br>
- the rangecheck error in psf_check_outline_glyphs would be an<br>
- acceptable fix (for now at least).<br>
-<br>
- I am leaving the bug open and passing it to Ken so that he can<br>
- double check this area in more detail at his convenience.<br>
-<br>
-devices/vector/gdevpsfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-23 19:53:31 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=636bb0bce0ece581f3004915e2c10c79c00439eb">636bb0bce0ece581f3004915e2c10c79c00439eb</a>
-<blockquote>
-<p>
- Bug 695180: Maintain antialias levels into pdf14 devices.<br>
-<br>
- When creating a pdf14 device, ensure that the antialias level<br>
- of the pdf14 device matches that of the underlying device.<br>
-<br>
- This prevents antialiasing getting lost when the clist kicks<br>
- in for transparency.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-23 18:57:28 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b85daf6bdb43c09fe92ac9c319c9fea5b012989a">b85daf6bdb43c09fe92ac9c319c9fea5b012989a</a>
-<blockquote>
-<p>
- Bug696540: Fix pattern accumulator initialisation<br>
-<br>
- When we create a pattern accumulator the bitmap contents are<br>
- initially undefined. We then draw a rectangle over them to set<br>
- them to known values.<br>
-<br>
- Unfortunately the code that writes this bitmap does not check<br>
- for the ctm being sane, so in some cases the initialisation<br>
- can fail.<br>
-<br>
- This shows up as indeterminisms in the alpha blending.<br>
-<br>
- The simple fix is to set the ctm to the identity matrix before<br>
- rendering.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-28 17:35:10 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7aed42f6e9f1f0bf09dde46d7004d517faed0d2e">7aed42f6e9f1f0bf09dde46d7004d517faed0d2e</a>
-<blockquote>
-<p>
- Fix potential valgrind warning.<br>
-<br>
- We don't have an example file for this, but this was spotted<br>
- during investigations into Bug 693784.<br>
-<br>
- We can overrun by 1 pixel for odd length rows. When we overrun<br>
- we read the lower 4 bits of a byte, and those may be undefined.<br>
-<br>
- Simply make PACIFY_VALGRIND blank these bits before we start.<br>
-<br>
-devices/gdevpbm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-23 14:59:25 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=89f02bdede0a2a46ee8937e6138b0f8905b524f5">89f02bdede0a2a46ee8937e6138b0f8905b524f5</a>
-<blockquote>
-<p>
- Bug 696609: Fix x11alpha regressions.<br>
-<br>
- The changes to pattern_accum_get_bits_rectangle were causing<br>
- a lack of output.<br>
-<br>
- This was due to the call to the underlying get_bits_rectangle<br>
- returning with a pointer to the data (rather than supplying<br>
- a copy of it). The blank_unmasked_bits call would then fail<br>
- as it could not alter the underlying data safely.<br>
-<br>
- The fix is simply to remove the bit that allows a copy of the<br>
- data to be submitted from the options before calling, thus<br>
- ensuring that we can operate on a copy.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-22 09:09:50 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ece091d02c69174fb96dc6b02df9e30f9c964461">ece091d02c69174fb96dc6b02df9e30f9c964461</a>
-<blockquote>
-<p>
- pdfwrite - fix a colour conversion crash<br>
-<br>
- Discovered while working on an unrelated problem. If we had set the<br>
- CompatibilityLevel to &lt; 1.3 and encountered a CIEBased colour space in<br>
- the input file, then we unconditionally return a 'convert' result<br>
- because we cannot embed an ICC profile in such an old PDF version.<br>
-<br>
- However we did not update the 'pcs_orig' argument, and later tried to<br>
- use it, resulting in a NULL dereference.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-19 09:29:58 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e636c3958126201c858d394d05c135bcd90cf3df">e636c3958126201c858d394d05c135bcd90cf3df</a>
-<blockquote>
-<p>
- Avoid another undefined data return case.<br>
-<br>
- Attempting to getbits from any pattern accumulator without a<br>
- color plane cannot work. Give an error.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-19 09:29:51 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c480ef1b2d0a9ede3df1d6fc64e6f305e378d3d7">c480ef1b2d0a9ede3df1d6fc64e6f305e378d3d7</a>
-<blockquote>
-<p>
- Fix possible undefined variable access.<br>
-<br>
- I messed this up while refactoring.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-18 19:37:05 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc6adc3f223ac00778e6236b687ab624cadb4445">cc6adc3f223ac00778e6236b687ab624cadb4445</a>
-<blockquote>
-<p>
- Ensure pattern_accumulator_get_bits returns defined values.<br>
-<br>
- When reading bits from the pattern_accumulator, if it has a mask<br>
- then blank the masked bits as otherwise the values are undefined.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-18 17:33:18 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f63ceefb7fc70cc7ccce9e4ae4221c5b5ca00100">f63ceefb7fc70cc7ccce9e4ae4221c5b5ca00100</a>
-<blockquote>
-<p>
- Update Acrobat2Tiff to hopefully work with 10/11/DC too.<br>
-<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff.vb<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-18 16:31:31 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9bb42182c7637e11bc2939fb359ab79365594202">9bb42182c7637e11bc2939fb359ab79365594202</a>
-<blockquote>
-<p>
- Update devices to return errors using return_error.<br>
-<br>
-contrib/gdevcd8.c<br>
-contrib/gdevdj9.c<br>
-contrib/gomni.c<br>
-contrib/japanese/gdevdmpr.c<br>
-devices/gdevcdj.c<br>
-devices/gdevcmykog.c<br>
-devices/gdevfpng.c<br>
-devices/gdevmac.c<br>
-devices/gdevmac.h<br>
-devices/gdevmswn.c<br>
-devices/gdevmsxf.c<br>
-devices/gdevos2p.c<br>
-devices/gdevpng.c<br>
-devices/gdevsvga.c<br>
-devices/gdevtifs.c<br>
-devices/gdevtsep.c<br>
-devices/gdevupd.c<br>
-devices/gdevwddb.c<br>
-devices/gdevwdib.c<br>
-devices/gdevwpr2.c<br>
-devices/gdevwprn.c<br>
-devices/gxfcopy.c<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdfm.c<br>
-devices/vector/gdevpdfo.c<br>
-devices/vector/gdevpdfr.c<br>
-devices/vector/gdevpdfu.c<br>
-devices/vector/gdevpdfx.h<br>
-devices/vector/gdevpdtc.c<br>
-devices/vector/gdevpdte.c<br>
-devices/vector/gdevpdtt.c<br>
-devices/vector/gdevpsdi.c<br>
-devices/vector/gdevpsdp.c<br>
-devices/vector/gdevpsf1.c<br>
-devices/vector/gdevpsf2.c<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-17 17:50:19 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c00965e4c05f08ec000303d53942e846187eed1a">c00965e4c05f08ec000303d53942e846187eed1a</a>
-<blockquote>
-<p>
- Improve logability of errors.<br>
-<br>
- Ensure that we always return_error(gs_error_blah) rather than just<br>
- return gs_error_blah.<br>
-<br>
-base/fapi_ft.c<br>
-base/fapibstm.c<br>
-base/fapiufst.c<br>
-base/gdevabuf.c<br>
-base/gdevdbit.c<br>
-base/gdevdflt.c<br>
-base/gdevdrop.c<br>
-base/gdevm24.c<br>
-base/gdevnfwd.c<br>
-base/gdevp14.c<br>
-base/gdevprn.c<br>
-base/gdevsclass.c<br>
-base/gdevvec.c<br>
-base/gp_mswin.c<br>
-base/gp_wsync.c<br>
-base/gsargs.c<br>
-base/gsdparam.c<br>
-base/gsfunc0.c<br>
-base/gsicc_cache.c<br>
-base/gsicc_lcms2.c<br>
-base/gsicc_manage.c<br>
-base/gsiodisk.c<br>
-base/gsioram.c<br>
-base/gsiorom.c<br>
-base/gslibctx.c<br>
-base/gsovrc.c<br>
-base/gxccman.c<br>
-base/gxcht.c<br>
-base/gxclthrd.c<br>
-base/gxcmap.c<br>
-base/gxdhtserial.c<br>
-base/gxdownscale.c<br>
-base/gxht.c<br>
-base/gxpageq.c<br>
-base/gxshade.c<br>
-base/sjbig2_luratech.c<br>
-base/sjpegc.c<br>
-base/sjpx_luratech.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-18 16:15:33 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=18af3c05dc3774512529436fd41d953fa24b34f8">18af3c05dc3774512529436fd41d953fa24b34f8</a>
-<blockquote>
-<p>
- Avoid interpolating imagemasks in pattern accumulators.<br>
-<br>
- To interpolate imagemasks, we need to do a copy_alpha operation.<br>
- These are impossible to do well on a pattern accumulator due to<br>
- the 1bpp alpha plane.<br>
-<br>
- As such the best thing we can do is to sidestep the problem.<br>
-<br>
-base/gxipixel.c<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-17 16:23:40 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a08a24751a672a21972d3888d651dacae054888e">a08a24751a672a21972d3888d651dacae054888e</a>
-<blockquote>
-<p>
- MSVC Solution: Add gdevsclass.{c,h} to the solution.<br>
-<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-18 10:49:11 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ccca669b1a1bf97fc1b778dd6f768b3a71d9dfbc">ccca669b1a1bf97fc1b778dd6f768b3a71d9dfbc</a>
-<blockquote>
-<p>
- Silence a compiler warning<br>
-<br>
- accidentally left a debugging variable in place<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-18 10:29:58 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=32e721e9e4c21f0a843ada824d17ac465f21ac4b">32e721e9e4c21f0a843ada824d17ac465f21ac4b</a>
-<blockquote>
-<p>
- pdfwrite - don't render shadings if we don't need to convert base space<br>
-<br>
- Bug #690125 &quot;Gradient / Fill Pattern Conversion Issues&quot;<br>
-<br>
- Since the change to ICC colour management, the check to see whether we<br>
- could support the base space of a shading was incorrect, it checked the<br>
- strategy against 'ICC' instead of the real base space of the pattern.<br>
-<br>
- This change checks the actual base space of the pattern before deciding<br>
- whether we can handle it.<br>
-<br>
- Although this 'fixes' this bug its not the whole story, I want to alter<br>
- the functions so that they can be sampled and generate a different colour<br>
- space if we are doing colour conversion, rather than rendering the<br>
- shading.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-17 11:30:34 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=19755c9a944bc257c936345742e3dc18703ca17f">19755c9a944bc257c936345742e3dc18703ca17f</a>
-<blockquote>
-<p>
- Bug #696592 Macro and duplex state interaction.<br>
-<br>
- The duplex page state was not being properly maintained during overlay<br>
- macro execution. Thanks to Norbert Janssen for discovering and<br>
- analyzing this problem.<br>
-<br>
-pcl/pcl/pcjob.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-16 18:03:30 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=80f7b13626dbf60275a8ea2d4ae16336832cfec5">80f7b13626dbf60275a8ea2d4ae16336832cfec5</a>
-<blockquote>
-<p>
- Further indeterminism fixes for halftoning.<br>
-<br>
- Yesterday I changed the halftone code to calculate the dest_width<br>
- etc from the bresenham. Now it turns out that the bresenham is<br>
- tweaked slightly in some cases, so that the 2 places where it<br>
- was being used to calculate dest_width were still getting<br>
- different results.<br>
-<br>
- This commit rearranges the code so that the same bresenham values<br>
- are used consistently, and so should give us proper matches.<br>
-<br>
-base/gxht_thresh.c<br>
-base/gxicolor.c<br>
-base/gximono.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-16 17:09:14 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d282b4d03e8dacfea9efb2867cc8cedb2f154a0f">d282b4d03e8dacfea9efb2867cc8cedb2f154a0f</a>
-<blockquote>
-<p>
- Bug 696594: Fix timeouts in cluster.<br>
-<br>
- Thanks to Ken for spotting this one.<br>
-<br>
- I'd neglected to update x in the landscape code, resulting in<br>
- infinite loops.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-16 12:07:03 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1a7c20c004643d38b3eb8fb9898927c351a7a63d">1a7c20c004643d38b3eb8fb9898927c351a7a63d</a>
-<blockquote>
-<p>
- pdfwrite - force non-Identity CMap emission when creating PDF/A<br>
-<br>
- Bug #696547 &quot;Converting to PDF/A using -dPDFACompatibilityPolicy=2 returns without error but produces invalid PDF/A files&quot;<br>
-<br>
- The third and (so far) final bug in this collection.<br>
-<br>
- PDF/A mandates that all CMaps except Identity-H and Identity-V must be<br>
- embedded in the PDF file. Previously we were not doing that for the<br>
- 'standard' CMaps.<br>
-<br>
- This commit forces the emission of all CMaps except Identity ones when<br>
- producing PDF/A output.<br>
-<br>
- No differences expected<br>
-<br>
-devices/vector/gdevpdtc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-15 19:31:33 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=656b19ddd19772c5c3fd40817d6532c853494d68">656b19ddd19772c5c3fd40817d6532c853494d68</a>
-<blockquote>
-<p>
- Fix unused variable.<br>
-<br>
- Leftover from previous code rework.<br>
-<br>
-base/gxht_thresh.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-15 18:15:12 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=92b88a1aefcd3410d8378bac8e92122622b7c80a">92b88a1aefcd3410d8378bac8e92122622b7c80a</a>
-<blockquote>
-<p>
- MSVC: Add targets for debugging.<br>
-<br>
- Add output paths to the projects so that the debugger knows where<br>
- to find the executable for each different build configuration.<br>
-<br>
-windows/ghostpcl.vcproj<br>
-windows/ghostpdl.vcproj<br>
-windows/ghostxps.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-15 16:57:46 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a8525ca93d7be6091f38ee68f4dbefa540158fa">4a8525ca93d7be6091f38ee68f4dbefa540158fa</a>
-<blockquote>
-<p>
- Bug 696323: Fix indeterminism in thresholding code.<br>
-<br>
- The thresholding code calculates the destination width of the<br>
- image lines in one way, then fills the data based on the<br>
- bresenham. It is possible for the destination width calculated<br>
- to not match that given by the bresenham, in which case<br>
- undefined data can be plotted.<br>
-<br>
- The fix here is simply to calculate the destination width from<br>
- the bresenham, so it will exactly match the actual data we get.<br>
-<br>
-base/gxht_thresh.c<br>
-base/gxht_thresh.h<br>
-base/gxicolor.c<br>
-base/gximono.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-15 15:08:38 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d66d291c29a7c34a4ba32060af7e9f4f1870a6c">0d66d291c29a7c34a4ba32060af7e9f4f1870a6c</a>
-<blockquote>
-<p>
- Add &quot;NoInterpolateImagemasks&quot; device param.<br>
-<br>
- Rather than relying on the 'HighLevelDevice' device param, instead<br>
- look at a new 'NoInterpolateImagemasks' param.<br>
-<br>
-base/gdevvec.c<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-12 14:12:41 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5a9269c17c036606f13f257f7ee5580a3a191530">5a9269c17c036606f13f257f7ee5580a3a191530</a>
-<blockquote>
-<p>
- Bug 696132: Reapply previous work.<br>
-<br>
- Previous commits in this area went in piecemeal and caused lots of<br>
- diffs which were then fixed etc. By committing here in one go, we<br>
- hope to get saner results from the tests which we can have more<br>
- confidence in.<br>
-<br>
- A summary of the changes:<br>
-<br>
- 1) Introduce a mechanism so that we can know whether we are in<br>
- a pattern accumulator or not.<br>
-<br>
- 2) When plotting an othogonal image use that mechanism to detect<br>
- whether we are in a pattern accumulator. If we are, then grid<br>
- fit the image.<br>
-<br>
- 3) If we are in a pattern accumulator and we are downscaling an<br>
- image, then interpolate it. This avoids nasty dropouts with<br>
- halftoned images that can (due to nearest neighbour plotting)<br>
- suddenly change massively in appearance.<br>
-<br>
-base/gxdevsop.h<br>
-base/gxipixel.c<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-15 15:22:46 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2959218b70dcb95765e458073195b4a9baa65be9">2959218b70dcb95765e458073195b4a9baa65be9</a>
-<blockquote>
-<p>
- graphics library - make vector devices implement the correct spec_op handler<br>
-<br>
- Devices based on gdevvec were not properly having the spec_op method<br>
- assigned to the gdevvec spec_op handler if the device didn't handle<br>
- spec_op itself.<br>
-<br>
- Ideally this would be done by having the device prototype being fully<br>
- populated, but the number of device methods makes that impractical.<br>
- Instead, if the method is NULL or the gx_default method, replace it<br>
- with the gdevvec one.<br>
-<br>
- This already works for devices based on gdevprn as a simlar hack is<br>
- performed in gx_default_create_buf_device<br>
-<br>
- No differences expected<br>
-<br>
-base/gdevvec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-15 10:21:57 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=343e3ed65423135a1f25ba1b5d52f45707c17c70">343e3ed65423135a1f25ba1b5d52f45707c17c70</a>
-<blockquote>
-<p>
- documentation - make it clearer the NumRenderingThreads has no effect on pdfwrite<br>
-<br>
- Unfortunately nothing can be done about the 'cargo cult' approach to<br>
- command line parameters which most people seem to use, but we should try<br>
- and make it clear in the documentation, on the off-chance that someone<br>
- actually reads it.<br>
-<br>
-doc/Language.htm<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-12 10:14:50 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=38e501dcddb6a15e9d2e41ae534d398942f9e839">38e501dcddb6a15e9d2e41ae534d398942f9e839</a>
-<blockquote>
-<p>
- Move Acrobat2TIFF from pcl/tools to toolbin (it is not PCL related)<br>
-<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff.sln<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff.vb<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff.vbproj<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Application.Designer.vb<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Application.myapp<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/AssemblyInfo.vb<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Resources.Designer.vb<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Resources.resx<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Settings.Designer.vb<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Settings.settings<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Acrobat2Tiff.exe<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Acrobat2Tiff.vshost.exe<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Acrobat2Tiff.xml<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Interop.Acrobat.dll<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff.sln<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff.vb<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff.vbproj<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Application.Designer.vb<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Application.myapp<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/AssemblyInfo.vb<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Resources.Designer.vb<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Resources.resx<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Settings.Designer.vb<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Settings.settings<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Acrobat2Tiff.exe<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Acrobat2Tiff.vshost.exe<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Acrobat2Tiff.xml<br>
-toolbin/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Interop.Acrobat.dll<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-07 09:07:53 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5c83e97e4c1216d7e3f67c7001a2513b0c1b9b45">5c83e97e4c1216d7e3f67c7001a2513b0c1b9b45</a>
-<blockquote>
-<p>
- Remove OMIT_SAVED_PAGES_TEST that was left in plmain when removed from gs<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-12 14:04:11 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c080667d88ba604a7033da1e507e2c39fa0fca2">6c080667d88ba604a7033da1e507e2c39fa0fca2</a>
-<blockquote>
-<p>
- Revert Bug 696132 work, in order to start from scratch.<br>
-<br>
- Revert:<br>
-<br>
- 1) &quot;Bug 696132/696572: Continued &quot;pattern gap&quot; work - interpolate&quot;<br>
- commit 80693d83612e03b26a5006b74296c6e9f11779da.<br>
-<br>
- 2) &quot;Bug 696132/696572: Continued &quot;pattern gap&quot; work - tidying.&quot;<br>
- commit 1b843b1a6adca2f0245af8049b7c5d6d8f00ae5d.<br>
-<br>
- 3) &quot;Fix gridfitting images being too greedy.&quot;<br>
- commit c902d4d4ba62306aa59cd30c3f450af5ad7bf797.<br>
-<br>
- 4) &quot;Bug 696132: Grid fit images within pattern fills.&quot;<br>
- commit 6b04051b251d7dbde9a2e6f170cac9dc7950e20e.<br>
-<br>
- After this I can reintroduce the commits and get (hopefully)<br>
- cleaner testing data.<br>
-<br>
-base/gxdevsop.h<br>
-base/gxipixel.c<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-12 13:49:17 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a44fff01232a1ae6c7200a403a132d860c2de718">a44fff01232a1ae6c7200a403a132d860c2de718</a>
-<blockquote>
-<p>
- pdfwrite - disallow Launch Actions in annotations when creating PDF/A<br>
-<br>
- Bug #696547 &quot;Converting to PDF/A using -dPDFACompatibilityPolicy=2 returns without error but produces invalid PDF/A files&quot;<br>
-<br>
- Another part of this bug. PDF/A does not permit Launch actions for<br>
- annotations, if we get one, and we are emitting PDF/A, consult the<br>
- CompatibilityPolicy and take appropriate action.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-12 13:48:06 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d83aa202383cfccdcf83a80f728106bf19267dd">1d83aa202383cfccdcf83a80f728106bf19267dd</a>
-<blockquote>
-<p>
- pdfwrite - disallow missing glyphs in CIDFonts when creating PDF/A<br>
-<br>
- Bug #696547 &quot;Converting to PDF/A using -dPDFACompatibilityPolicy=2 returns without error but produces invalid PDF/A files&quot;<br>
-<br>
- One part of this bug. PDF/A insists that all fonts be embedded, and<br>
- all glyphs used from that font are present. If we detect a condition<br>
- where that is not the case, and we are emitting PDF/A consult the<br>
- CompatibilityPolicy and take appropriate action.<br>
-<br>
-devices/vector/gdevpdtc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-12 13:45:43 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9df72d93fbe869b44a566911bdf81d2aefc3ac79">9df72d93fbe869b44a566911bdf81d2aefc3ac79</a>
-<blockquote>
-<p>
- Documentation - fix an incorrect example and make usage a little clearer<br>
-<br>
-doc/VectorDevices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-12 11:44: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=b7d67a3b885f86c23d731f2bff77e16d73e1dc39">b7d67a3b885f86c23d731f2bff77e16d73e1dc39</a>
-<blockquote>
-<p>
- Fix CompatibilityLevel typo in man pages<br>
-<br>
- The man pages listed -dCompatibility instead of -dCompatibilityLevel<br>
-<br>
-man/de/ps2pdf.1<br>
-man/ps2pdf.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-12 11:41:10 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7f32dc0df826defdd20f8cd493ce795e0c73b83a">7f32dc0df826defdd20f8cd493ce795e0c73b83a</a>
-<blockquote>
-<p>
- Add documentation for the inkcov device.<br>
-<br>
- Credit to Jonas Smedegaard &lt;dr@jones.dk&gt;<br>
-<br>
-doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-12 10:57: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=3340d723e22500fd10c05ac113d7f5532a1ea762">3340d723e22500fd10c05ac113d7f5532a1ea762</a>
-<blockquote>
-<p>
- Bug 696586 (2): Clean up some leftovers in my previous commit<br>
-<br>
-base/openjpeg.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-12 09:01:20 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ca1d9d7a6a5cea50e1bb3a562b2b5c79d640c0c">4ca1d9d7a6a5cea50e1bb3a562b2b5c79d640c0c</a>
-<blockquote>
-<p>
- Bug 696585: Fix jpeg, tiff and cups shared lib builds<br>
-<br>
- Some more overzealous dependencies removed.<br>
-<br>
- Mostly, credit to Jonas Smedegaard &lt;dr@jones.dk&gt;, plus some tweaks of my own<br>
-<br>
-base/jpegxr.mak<br>
-base/lcups.mak<br>
-base/lcupsi.mak<br>
-base/tiff.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-12 08:51: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=cf6f31c177fb36b3a706c80da4c003d009fbe2af">cf6f31c177fb36b3a706c80da4c003d009fbe2af</a>
-<blockquote>
-<p>
- Bug 696586: support shared OpenJPEG lib<br>
-<br>
- There was a halfhearted attempt there already, do it properly.<br>
-<br>
-Makefile.in<br>
-base/openjpeg.mak<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-11 12:08:13 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=80693d83612e03b26a5006b74296c6e9f11779da">80693d83612e03b26a5006b74296c6e9f11779da</a>
-<blockquote>
-<p>
- Bug 696132/696572: Continued &quot;pattern gap&quot; work - interpolate<br>
-<br>
- Marcos reports (in bug 696572) that many files have problems<br>
- after the commit done for bug 696132. That commit was intended to<br>
- cause all orthogonal images within a pattern to be gridfitted.<br>
- Due to a mistake, this actually caused all orthogonal images<br>
- ANYWHERE to be gridfitted. That bug was fixed a few commits<br>
- ago (c902d4d).<br>
-<br>
- Having fixed that, so we now operate as originally intended<br>
- we still have some problems showing. These (in the cases tested<br>
- at least) appear to be due to the radically different renderings<br>
- given of images when they are very slightly permuted. This is<br>
- because when images are being rendered at a smaller size<br>
- than their source, dropouts occur.<br>
-<br>
- A classic example of this might be an image of the form:<br>
-<br>
- * * * * * *<br>
- * * * * *<br>
- * * * * * *<br>
- * * * * *<br>
-<br>
- which is used as a pattern to give a halftone efferct.<br>
-<br>
- When downscaled, this is very sensitive to dropouts; we can easily<br>
- get solid black or white out of such images. Using interpolation<br>
- gives a truer rendition of the intended output.<br>
-<br>
- This commit spots such downscales of gridfitted images within<br>
- pattern accumulators and forces interpolation on for them.<br>
-<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-11 12:08: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=1b843b1a6adca2f0245af8049b7c5d6d8f00ae5d">1b843b1a6adca2f0245af8049b7c5d6d8f00ae5d</a>
-<blockquote>
-<p>
- Bug 696132/696572: Continued &quot;pattern gap&quot; work - tidying.<br>
-<br>
- Rejig the existing code slightly to make it more readable.<br>
-<br>
- No functional changes, just clearer code.<br>
-<br>
-base/gxdevsop.h<br>
-base/gxipixel.c<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-11 16:56:23 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=710d030617a586c5b9bbc105dd3054e467112f47">710d030617a586c5b9bbc105dd3054e467112f47</a>
-<blockquote>
-<p>
- PDF interpreter - allow the operand stack to gro without limit<br>
-<br>
- Bug #696567 &quot;Error reading PDF file: /stackunderflow in --run--&quot;<br>
-<br>
- The file has a page with an outrageous number of ExtGStates on it,<br>
- 447000, many (possibly all) of which do not contain any actual gstate.<br>
-<br>
- This was causing a stackoverflow because the maximummoperand stack<br>
- size was set at 300,000. This commit builds on the code for<br>
- Bug #696487 (from the same customer) and enables the operand stack to<br>
- grow without limit when interpreting PDF files.<br>
-<br>
- Of course, the page is still stupidly slow.<br>
-<br>
- No differences expected.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-11 12:06:28 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d781291c9acb4eb30bf4920882c23b03fa445a2b">d781291c9acb4eb30bf4920882c23b03fa445a2b</a>
-<blockquote>
-<p>
- pdfwrite - don't emit an empty clip<br>
-<br>
- Bug #696566 &quot;Regression: acrobat cannot open ghostscript generated pdf file starting with b56ff42047f6df6e7c74a79b91cd7d193bfa7357&quot;<br>
-<br>
- This appears to be a weird bug in Acrobat. If we had a PostScript file<br>
- which did the equivalent of 'clip newpath clip' then we could end up<br>
- writing the same equivalent to the PDF file as 'W n W n'. Under some<br>
- (and only some) conditions, depending apparently on what operation<br>
- followed the clip, Acrobat would throw a fit on this and stop.<br>
-<br>
- No other PDF consumer seems to be bothered by this, and indeed if we<br>
- alter the PDF contents slightly Acrobat isn't bothered either.<br>
-<br>
- Since I cannot determine exactly what Acrobat is complaining about, and<br>
- since the empty clip makes no real sense anyway, I've added code which<br>
- detects an empty path and doesn't bother to write the clip (W) operator.<br>
-<br>
- This seems to pacify Acrobat, but I can't guarantee that other degenerate<br>
- paths won't cause similar problems.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-10 21:07:57 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c902d4d4ba62306aa59cd30c3f450af5ad7bf797">c902d4d4ba62306aa59cd30c3f450af5ad7bf797</a>
-<blockquote>
-<p>
- Fix gridfitting images being too greedy.<br>
-<br>
- Devices that don't understand a gxdso will return -1, which we<br>
- were incorrectly reading as meaning &quot;gridfit this image&quot;.<br>
-<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-10 15:57:02 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=393e7a835a375b32bf06e8eec4ef89cd2c333d99">393e7a835a375b32bf06e8eec4ef89cd2c333d99</a>
-<blockquote>
-<p>
- PDF interpreter - handle Xref stream with incorrect length<br>
-<br>
- Bug 696560 &quot;Error reading PDF file&quot;<br>
-<br>
- The file uses compressed Xref streams (several of them in fact) and one<br>
- of them has an incorrect length (36 instead of 34). This leads to the<br>
- interpreter reading past the end of the stream and consuming the first<br>
- two bytes of the following token, so instead of seeing 'endstream' as<br>
- we should, we encounter 'dstream'.<br>
-<br>
- We already have code which attempts to detect and handle this condition<br>
- but it assumes that the stream is being executed as an object, not as<br>
- an xref, and expects the object number and generation to be on the<br>
- stack, which they are not when we are dealing with an Xref stream.<br>
-<br>
- In this commit, when we detect such a problem we attempt to verify if<br>
- we are dealing with an object by checking to see if the stack contains<br>
- at least 3 objects (the stream dict, the object and generation) and that<br>
- the second and third objects down are integers. If these conditions are<br>
- met we end the object and execute the 'exit' operator to terminate<br>
- the calling .pdfrun function. Otherwise we simply return with the<br>
- dictionary on the stack, as this is what the xref code expects.<br>
-<br>
- The regression file Bug696240.pdf should now render correctly.<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-10 12:50: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=7f5ed0cde537a43fdc8bae669ffc413f39d69df8">7f5ed0cde537a43fdc8bae669ffc413f39d69df8</a>
-<blockquote>
-<p>
- Detect 'impossible' code path being called.<br>
-<br>
- As part of the work towards bug 696562, we spotted a code path<br>
- that can never be run.<br>
-<br>
- gx_alloc_char_bits is only called from one place (base/gxchar.c<br>
- line 607). dev2 can only be non-NULL if:<br>
-<br>
- iwidth &gt; MAX_CCACHE_TEMP_BITMAP_BITS / iheight &amp;&amp;<br>
- log2_scale.x + log2_scale.y &gt; alpha_bits<br>
-<br>
- The second half of that condition can never be true due to the<br>
- construction of the log2_scale.{x,y} values in<br>
- gx_compute_text_oversampling().<br>
-<br>
- Rather than rip this code out just before a release (and inevitably<br>
- be proved wrong), we add an error in this code path. If no one<br>
- reports it to us, we'll rip the code out later.<br>
-<br>
-base/gxccman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-08 17:13:35 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0fb16eb72ee9136856e0a52dcb194993fced16c9">0fb16eb72ee9136856e0a52dcb194993fced16c9</a>
-<blockquote>
-<p>
- Bug 696562: Interpolate imagemasks.<br>
-<br>
- When rendering imagemasks, we can get nasty dropout effects if we<br>
- should be using interpolation. To fix this, we implement<br>
- interpolation for the non-high level device case.<br>
-<br>
- We use copy_alpha (and copy_alpha_hl_color) to write the data. We<br>
- only do this in the case of devices that don't declare themselves<br>
- to be high-level.<br>
-<br>
-base/gxiscale.c<br>
-devices/gdevpng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-09 17:12: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=71f32f8bbc9e905732293ef2c2bd0821744c1a86">71f32f8bbc9e905732293ef2c2bd0821744c1a86</a>
-<blockquote>
-<p>
- Only insert default_copy_alpha_hl_color if it can work.<br>
-<br>
- default_copy_alpha_hl_color requires underlying copy_planes and<br>
- get_bits_rectangle methods. If the device does not provide them<br>
- then do not add default_copy_alpha_hl_color.<br>
-<br>
-base/gdevdflt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-08 12:23: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=d9f041d6fe7eda89364df1424f85ace974ed0fec">d9f041d6fe7eda89364df1424f85ace974ed0fec</a>
-<blockquote>
-<p>
- Extend copy_alpha to support 8 bit depth.<br>
-<br>
- Currently copy_alpha (and copy_alpha_hl_color) can only accept<br>
- 2 or 4 bits of alpha data. In order for the work on bug 696562<br>
- to proceed we need it to support 8 bits of alpha data. Extend<br>
- the 2 default implementations here.<br>
-<br>
- Also update the docs to mention the new bit depths, and to mention<br>
- the existence of copy_alpha_hl_color at all.<br>
-<br>
- Remove the line in the docs that claims copy_alpha will not be<br>
- called unless get_alpha_bits returns non-1, as this will shortly<br>
- not be true.<br>
-<br>
-base/gdevabuf.c<br>
-base/gdevdbit.c<br>
-base/gdevm24.c<br>
-base/gdevp14.c<br>
-devices/gdevpng.c<br>
-devices/gdevsvga.c<br>
-doc/Drivers.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-08 18:51:14 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c75e35b6bbadd553a074509c3d80046457dda98">3c75e35b6bbadd553a074509c3d80046457dda98</a>
-<blockquote>
-<p>
- Bug 696571: Fix rangecheck in tiffscaled.<br>
-<br>
- I was putting some params that I wasn't getting (or vice versa).<br>
-<br>
-devices/gdevtifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-08 17:10:42 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=453e8fca47db33555f86774b99cde0b429223c92">453e8fca47db33555f86774b99cde0b429223c92</a>
-<blockquote>
-<p>
- Tidy downscaler params.<br>
-<br>
- Use ints rather than longs consistently. This should shut<br>
- coverity up.<br>
-<br>
-base/gxdownscale.c<br>
-base/gxdownscale.h<br>
-devices/gdevfpng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-09 13:45:19 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=75a299ff71ef01d645acc744fb2248f99830e84a">75a299ff71ef01d645acc744fb2248f99830e84a</a>
-<blockquote>
-<p>
- silence a couple of compiler warnings<br>
-<br>
- Check and action the return value from fread throw an ioerror if it<br>
- failed.<br>
-<br>
- Prototype a couple of functions (this is an old warning)<br>
-<br>
- I did not remove two functions 'pjl_impl_set_envvar' and<br>
- 'pjl_impl_set_defvar'. Although these are not used at present they<br>
- match 'pjl_impl_get_envvar', which *is* used. It would be surprising<br>
- to a programmer if only one accessor was defiend.<br>
-<br>
-pcl/pl/pjparse.h<br>
-pcl/pl/plparams.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-08 16:55:47 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b65f6276c674a9947f3c65f7d08b46c02ba0ff3">4b65f6276c674a9947f3c65f7d08b46c02ba0ff3</a>
-<blockquote>
-<p>
- Silence warning about unchecked return code.<br>
-<br>
- Check the return code.<br>
-<br>
-devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-10 10:04: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=d097c4624a7c23610b007aab98860d175535cb48">d097c4624a7c23610b007aab98860d175535cb48</a>
-<blockquote>
-<p>
- PJL interpreter - add new methods to configure pdfwrite<br>
-<br>
- Bug #693117 &quot;PCL -&gt; PDF/A&quot;<br>
- Bug #693058 &quot;There is no way to control many pdfwrite features in GhostPCL (eg AutoRotatePages)&quot;<br>
-<br>
- Originally developed on the branch PJL_pdfwrite_config, full history<br>
- is available on that branch.<br>
-<br>
- Added new PDFMARK and SETDISTILLERPARAMS PJL tokens which will allow<br>
- for 'PostScript like' syntax whch can be used to configure the<br>
- pdfwrite family of devices.<br>
-<br>
- This will allow for the production of PDF/A-1b files and also the<br>
- control of some features which cannot be set from the command line.<br>
-<br>
- Updated the documentation, gathering all the high level devices in<br>
- one place, split the documentation into controls based on the<br>
- input language and the output format.<br>
-<br>
- No differences expected.<br>
-<br>
-doc/Devices.htm<br>
-doc/Drivers.htm<br>
-doc/Ps2pdf.htm<br>
-doc/Ps2ps2.htm<br>
-doc/Readme.htm<br>
-doc/Use.htm<br>
-doc/VectorDevices.htm<br>
-pcl/pcl/pcjob.c<br>
-pcl/pcl/pcl.mak<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plparams.c<br>
-pcl/pl/plparams.h<br>
-pcl/pxl/pxsessio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-08 13:55:40 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=119e73617fb0f1b20e6d3257d26df0159c4ca81a">119e73617fb0f1b20e6d3257d26df0159c4ca81a</a>
-<blockquote>
-<p>
- PDF interpreter - yet more robust error handlign with broken files<br>
-<br>
- Bug #696540 &quot;ps2pdf fails on a file that can be opened by some other viewers&quot;<br>
-<br>
- Two problems here.<br>
-<br>
- First, the file has been truncated and garbage written, after the startxref<br>
- token. Previously we used the 'token' operator to try and read both the<br>
- 'startxref' and the actual offset value. However, while executing the<br>
- token operator we reached EOF, and this *closes* the underlying file.<br>
- Unsurprisingly this then caused ioerrors on every subsequent operation.<br>
-<br>
- So, define a new routine 'token_no_close' which installs a SubFileDecode<br>
- filter on top of the existing file/filter chain and reads from that. We<br>
- explicitly set CloseSource to false so that even if we encounter EOF<br>
- while executing the file we will only close the filter and not the<br>
- underlying file/filter chain.<br>
-<br>
- However this then exposed a different problem when rebuilding the xref;<br>
- we scan backwards looking for a trailer with a /Root key. But if the<br>
- trailer was early in the file (&lt; 64Kb), and the block reading worked<br>
- out so that the initial block was less than 64Kb then we would calculate<br>
- The offset to the trailer incorrectly because we assumed the block size<br>
- was always 64Kb, which it isn't if we don't have 64Kb to read.<br>
-<br>
- No differences expected<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-Resource/Init/pdf_rbld.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-03 12:48:07 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=15f8b6ce6d7ae574d7803bb19d2f5cec474f087b">15f8b6ce6d7ae574d7803bb19d2f5cec474f087b</a>
-<blockquote>
-<p>
- Disable trapping by default.<br>
-<br>
- Build with ENABLE_TRAPPING to reenable it. Add explanation and<br>
- warnings to doc/Devices.htm.<br>
-<br>
-base/gxdownscale.c<br>
-doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-01 17:22:53 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=afc7e2cfb9544a8cebd8abb0d89e02429ad98f7d">afc7e2cfb9544a8cebd8abb0d89e02429ad98f7d</a>
-<blockquote>
-<p>
- Reduce boilerplate downscaler params handling.<br>
-<br>
- The same sets of parameters (or subsets thereof) are read/<br>
- written in many devices get/put_params routines to control<br>
- the downscaler.<br>
-<br>
- Arrange to read/write these all in one place to keep the<br>
- code simpler.<br>
-<br>
-base/gxdownscale.c<br>
-base/gxdownscale.h<br>
-devices/gdevfpng.c<br>
-devices/gdevgprf.c<br>
-devices/gdevpng.c<br>
-devices/gdevpsd.c<br>
-devices/gdevtfnx.c<br>
-devices/gdevtifs.c<br>
-devices/gdevtifs.h<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-29 19:06:22 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=afbffabc7bf3593d3de5a210899e364371807c66">afbffabc7bf3593d3de5a210899e364371807c66</a>
-<blockquote>
-<p>
- Simple optimisations to ClapTrap.<br>
-<br>
-base/claptrap-init.c<br>
-base/claptrap-planar.c<br>
-base/claptrap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-28 11:33: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=049ba9c4de3514452e4bd3b6601c20e1d22188fd">049ba9c4de3514452e4bd3b6601c20e1d22188fd</a>
-<blockquote>
-<p>
- Initial import of ClapTrap.<br>
-<br>
- Hooked in under the downscaler, so accessible to any device that<br>
- calls the downscaler without too many changes.<br>
-<br>
- Only enabled for CMYK devices, so tiffscaled32, tiffsep and<br>
- psdcmyk.<br>
-<br>
- -dTrapX and -dTrapY set the horizontal and vertical search areas.<br>
- Use 0 for off, otherwise n searches +/- n either side.<br>
-<br>
- TrapOrder sets the cmyk spot ordering from darkest to lightest.<br>
- For CMYK, default is [ 3 1 0 2 ] (K, M, C, Y).<br>
-<br>
- For CMYK and spots, default is [ 3 1 0 2 4 5 6 7 ... ]. This<br>
- will be wrong if spots aren't arranged in darkest to lightest order.<br>
-<br>
- A typical command line might look like:<br>
-<br>
- gs -sDEVICE=tiffsep -dTrapX=2 -dTrapY=2 -o out.tif<br>
- -c &quot;&lt;&lt; /TrapOrder [ 3 1 0 2 ] setpagedevice &gt;&gt;&quot;<br>
- -f examples/tiger.eps<br>
-<br>
-base/claptrap-impl.h<br>
-base/claptrap-init.c<br>
-base/claptrap-planar.c<br>
-base/claptrap.c<br>
-base/claptrap.h<br>
-base/gxdownscale.c<br>
-base/gxdownscale.h<br>
-base/lib.mak<br>
-devices/gdevpsd.c<br>
-devices/gdevtifs.c<br>
-devices/gdevtifs.h<br>
-devices/gdevtsep.c<br>
-doc/Devices.htm<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-03 19:08:46 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6b04051b251d7dbde9a2e6f170cac9dc7950e20e">6b04051b251d7dbde9a2e6f170cac9dc7950e20e</a>
-<blockquote>
-<p>
- Bug 696132: Grid fit images within pattern fills.<br>
-<br>
- To avoid white lines appearing between pattern fills, grid fit<br>
- images whenever they appear within such fills.<br>
-<br>
- Gridfitting involves stretching any axis aligned image to<br>
- completely cover the pixels it touches.<br>
-<br>
- The vast majority of this patch is to do with detecting that<br>
- we are in a pattern accumulation device in a nice way (allowing<br>
- for the possibilities of pdf14 accumulators etc).<br>
-<br>
-base/gxdevsop.h<br>
-base/gxipixel.c<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-05 10:31:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=de6cead970c7aebdca0c49d841bb94897f02102d">de6cead970c7aebdca0c49d841bb94897f02102d</a>
-<blockquote>
-<p>
- PDF interpreter - move a device name check into a parameter check<br>
-<br>
- Bug #696568 &quot;Treatment of page labels&quot;<br>
-<br>
- Previously we were checking against the device being pdfwrite before<br>
- processing page labels, because these require special handling. This<br>
- stops it working with the DejaVu device (which I wasn't previously<br>
- aware of) so instead we use the current method of checking a device<br>
- parameter to see if the device wants to be given the Page Labels.<br>
-<br>
- Because the pdfmark syntax apparently cannot handle the range of<br>
- possible schemes for PageLabels (see bug #692901) we don't handle<br>
- PageLabels as pdfmarks, but instead as a specific device parameter.<br>
-<br>
- We won't change this unless someone can show conclusively that the<br>
- pdfmark syntax can handle all possible formats for PageLabels.<br>
-<br>
- No differences expected<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfp.c<br>
-devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-04 08:02: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=25717bc03607476d3fa3a4f26a852c8064fe31c4">25717bc03607476d3fa3a4f26a852c8064fe31c4</a>
-<blockquote>
-<p>
- Bug 696565: remove spurious deps for shared lcms, cups and jpeg<br>
-<br>
- When I added a load of missing dependencies, I was over zealous and added some<br>
- depedencies to some of the shared library builds that are only relevant to the<br>
- non-shared library cases.<br>
-<br>
-base/jpegxr.mak<br>
-base/lcms2.mak<br>
-base/lcups.mak<br>
-base/lcupsi.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-03 09:07:57 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8a3b3487d4946e0b66388c2602d70a5ed45193ff">8a3b3487d4946e0b66388c2602d70a5ed45193ff</a>
-<blockquote>
-<p>
- Don't use stack allocation for text enum<br>
-<br>
- Text (and show) enumeators can no longer be safely allocated on the stack since<br>
- we need the memory manager's metadata to check the type (show or text) we're<br>
- dealing with (to correctly handle an error condition without crashing).<br>
-<br>
-base/gstext.c<br>
-base/gxtext.h<br>
-pcl/pl/plfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-01 11:57: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=f8e77523b98f0e95e0d93fa282d6955f8f537eea">f8e77523b98f0e95e0d93fa282d6955f8f537eea</a>
-<blockquote>
-<p>
- Bug 696516: tiffsep(1) validation of compression method<br>
-<br>
- Use a meaningful value of bits-per-component to validate the compression setting<br>
- for tiffsep and tiffsep1.<br>
-<br>
- Since both those devices ignore the device BitsPerComponent setting, we cannot<br>
- rely on that, so check explicitly for tiffsep or tiffsep1 and use an<br>
- appropriate bpc value depending which is in force.<br>
-<br>
- Also, change the comment on the default tiffsep(1) device(s) BitsPerComponent<br>
- value from &quot;Not used&quot; to &quot;Ignored&quot; which is more accurate, since bpc can and<br>
- does change, but has no effect on those two devices.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-03 11:56:00 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5c1ae7a77f19ff3e7521a80c276335e473ba2b60">5c1ae7a77f19ff3e7521a80c276335e473ba2b60</a>
-<blockquote>
-<p>
- VS2015: Workaround apparent C runtime bug.<br>
-<br>
- The behaviour of _read appears to have changed in VS2015 in<br>
- a way that is contrary to the documentation. If a _read call<br>
- is given a single &quot;return&quot; keypress, it puts \n in the buffer<br>
- but returns 0 as the number of things read.<br>
-<br>
- This, according to the documentation means 'EOF'. We therefore<br>
- have some sneaky code to guess when it's lying to us.<br>
-<br>
-psi/dwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-02 15:10:21 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=57df4f3b0234e4231f024b53e0428ead17e95c3c">57df4f3b0234e4231f024b53e0428ead17e95c3c</a>
-<blockquote>
-<p>
- VS2015 builds: Tweak to fix bool problems.<br>
-<br>
- Always include windows_.h first, wherever we include it.<br>
- This gets the windows definition of 'bool' in, and we can then<br>
- override it with our own.<br>
-<br>
-base/gp_mswin.c<br>
-base/gp_ntfs.c<br>
-base/gp_win32.c<br>
-base/gp_wsync.c<br>
-base/gsicc_monitorcm.c<br>
-base/gstype42.c<br>
-base/stdpre.h<br>
-devices/gdevmswn.h<br>
-devices/gdevmsxf.c<br>
-devices/gdevwpr2.c<br>
-psi/msvc.mak<br>
-psi/zwinutf8.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-02 10:27:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb799fa99685fc9cd0177242a5f923180eda135c">bb799fa99685fc9cd0177242a5f923180eda135c</a>
-<blockquote>
-<p>
- Revert and fix commit a7655b5d2fc42217eac71efd01f22fe3cca33d4a<br>
-<br>
- In the previous commit I misunderstood the return value meanings from<br>
- s_DCT_byte_params leading to an incorrect default (and causing many<br>
- diffs)<br>
-<br>
- This commit properly sets the return value so that, if the key is not<br>
- found we use the correct default.<br>
-<br>
- Again, lots of diffs expected here.<br>
-<br>
-base/sdcparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-01 15:51:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a7655b5d2fc42217eac71efd01f22fe3cca33d4a">a7655b5d2fc42217eac71efd01f22fe3cca33d4a</a>
-<blockquote>
-<p>
- PS interpreter - further fix for DCTEncode params arrays<br>
-<br>
- commit 96f79a46a559af75995bf021cc85438c99509bbb missed the fact that,<br>
- when a parameter is returned from parameter processing we need to<br>
- return a positive code &gt; 0, otherwise the caller assumes that there was<br>
- no error, but no key found either.<br>
-<br>
- This actually makes the HSamples, VSamples and QuantTables work for<br>
- the DCTEncode filter.<br>
-<br>
- This causes a *very* large number of diffs, because the pdfwrite (and<br>
- ps2write) devices now actually use the parameters defined for these values<br>
- resulting in small differences in DCT (JPEG) output.<br>
-<br>
- Also the Quality Logic test 23-12E.ps tests this feature and now shows<br>
- a difference.<br>
-<br>
-base/sdcparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-29 13:51: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=b826c1774a0b89e237590232be227642734c3a5e">b826c1774a0b89e237590232be227642734c3a5e</a>
-<blockquote>
-<p>
- Bug 696553: reduce redundant loading of (some) substitute fonts<br>
-<br>
- Loading fonts from a Fontmap mapping, the actual font name from the font<br>
- file usually does not match the Postscript font name.<br>
-<br>
- When that happens, a subsequent attempt to load the same font name will not<br>
- find the font in the font directory, and this triggers the whole font file<br>
- loading process via Fontmap.<br>
-<br>
- Add code to create a new font with the original Postscript font name.<br>
-<br>
- Also, undefine the orginal font from the font file, to avoid cluttering up<br>
- the FontDirectory with pointless entries.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-02-01 10:32: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=96f79a46a559af75995bf021cc85438c99509bbb">96f79a46a559af75995bf021cc85438c99509bbb</a>
-<blockquote>
-<p>
- PS interpreter - fix array processing for the DCTEncode params dict<br>
-<br>
- The PLRM says that HSamples, VSamples can be strings, arrays or packed<br>
- arrays and QuantTables can be an array or a packed array (of strings,<br>
- arrays or packed arrays). If they are array types, then the values must<br>
- be integers.<br>
-<br>
- In sdcparam.c where we process the paramters we were checking and<br>
- processing strings, and if the data was not a string we tried to handle<br>
- it as an array of floats (which is technically incorrect), but we never<br>
- tried to process the data as an int array.<br>
-<br>
- This led to the routine throwing a typecheck error, so the values were<br>
- never used.<br>
-<br>
- This commit adds processing for int arrays (I've left the float array<br>
- processing intact, even though its wrong).<br>
-<br>
- No differences expected, this is really only used by pdfwrite.<br>
-<br>
-base/sdcparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-30 10:45:29 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9399eefc54d7c14b9ebf56ca585f4946abaf555e">9399eefc54d7c14b9ebf56ca585f4946abaf555e</a>
-<blockquote>
-<p>
- pdfwrite - fix alpha duplication<br>
-<br>
- Bug #696524 &quot;gs: Some elements discarded in PDF with 3d transform&quot;<br>
-<br>
- The bug title is incorrect. In fact the problem is complex; we have two<br>
- forms, each of which is preceded by a graphics state, each graphics state<br>
- modifies the constant alpha, but one has alpha is shape false, while the<br>
- other has it as true.<br>
-<br>
- This causes confusion when updating the alpha as we cannot have AIS<br>
- both true and false at the same time, so we don't know which alpha to<br>
- use.<br>
-<br>
- This commit checks the graphics state to see which alpha usage is the<br>
- default state and sets AIS from that, as appropriate for whether the<br>
- opacity or shape is set.<br>
-<br>
- This is a little hacky but I think its safe enough and fixes what is a<br>
- rather rare problem.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-29 10:30:13 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=471af1e1961054327484bf86a474669f37634c7f">471af1e1961054327484bf86a474669f37634c7f</a>
-<blockquote>
-<p>
- Bug 696554: cleanup after failing to read font value<br>
-<br>
- In /.findfontvalue, if we hit an error tokenizing the contents of the font file<br>
- the stack cleanup was incorrect.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-28 15:37:14 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=29757551f9935292418df94d588693e13e3afeec">29757551f9935292418df94d588693e13e3afeec</a>
-<blockquote>
-<p>
- PDF interpreter - repair xref processing with PDFSTOPONERROR<br>
-<br>
- commit c9f24068810f762f2a54d33d7cb8040eff080368 accidentally broke the<br>
- processing of xref tables with -dPDFSTOPONERROR, any xref would lead to<br>
- an error and premature exit.<br>
-<br>
- This commit repairs the processing as intended, so that *valid* xref<br>
- tables won't cause us to stop with an error.<br>
-<br>
- No differences expected<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-28 12:24:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1204680ae25d0cfa1ab815952b3009a024c6b9ec">1204680ae25d0cfa1ab815952b3009a024c6b9ec</a>
-<blockquote>
-<p>
- pdfwrite - prevent emitting a negative value for linewidth<br>
-<br>
- Bug #696548 &quot;Regression: acrobat cannot open ghostscript generated pdf file starting with d43d5653c0e052c172ce1db9d9b04d4ba7360de3&quot;<br>
-<br>
- The PDF reference states that linewidth is a non-negative number, and<br>
- we were emitting a negative value in some conditions.<br>
-<br>
- Bizarrely (given the horrendously broken PDF files Acrobat *will* read)<br>
- this causes an error in Acrobat, though not in practically every other<br>
- PDF consumer.<br>
-<br>
- This commit simply forces the value to be positive.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-28 11:38:53 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d6d499ba4bb4fa27d0f6970a5e98b3372f52d05c">d6d499ba4bb4fa27d0f6970a5e98b3372f52d05c</a>
-<blockquote>
-<p>
- PDF interpreter - Handle inline images in a text block<br>
-<br>
- Bug #696545 &quot;Missing inline images&quot;<br>
-<br>
- Similar to bug #695897, where image XObjects were being drawn inside<br>
- a text block (between BT and ET), in this case we have inline images<br>
- (ID) inside a text block.<br>
-<br>
- This is, according to the specification, illegal but Acrobat simply<br>
- ignores that and draws the image using the CTM in force when the BT<br>
- operator is encountered.<br>
-<br>
- This commit just reuses the code for Bug 695897 and applies it to the<br>
- ID operator as well.<br>
-<br>
- No differences expected<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-27 18:42:06 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a8b8922b4608d6bf021714100dcd3b85ac1a8c86">a8b8922b4608d6bf021714100dcd3b85ac1a8c86</a>
-<blockquote>
-<p>
- Make waterfal.ps standalone<br>
-<br>
- Originally waterfal.ps called .runlibfile to run landscap.ps (in the lib<br>
- directory) to draw the page landscape.<br>
-<br>
- Since .runlibfile is non-standard Postscript, and lib is no longer in our<br>
- default search path, *and* it is only five lines of Postscript, it's a<br>
- needless complication - better for the file to be self contained.<br>
-<br>
-examples/waterfal.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-26 08:47:30 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3bbced3ab549bef42f47fb28c10287b32826d1b4">3bbced3ab549bef42f47fb28c10287b32826d1b4</a>
-<blockquote>
-<p>
- Fix for Bug 696514. rinkj device<br>
-<br>
- The rinkj device was dereferencing a NULL pointer related<br>
- to the ICC device link profile that it can be set up to use.<br>
- Fixing this issued and playing around with a various command<br>
- line options revealed a problem in error trapping in the<br>
- icc code where you could cause a crash by having a bogus<br>
- device link profile specified on the command line. This<br>
- fixes that crash also.<br>
-<br>
-base/gsciemap.c<br>
-base/gsicc_create.c<br>
-base/gsicc_manage.c<br>
-base/gsicc_manage.h<br>
-devices/gdevrinkj.c<br>
-xps/xpscolor.c<br>
-xps/xpsimage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-26 16:48:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5e270fffe76164b07b29dec2358ef01003866674">5e270fffe76164b07b29dec2358ef01003866674</a>
-<blockquote>
-<p>
- PS Interpeter - correct the error from setfileposition on invalid file<br>
-<br>
- Noticed while working on a different problem, the check_file macro in<br>
- stream.h returns invalidaccess if a file is invalid, the PLRM (see<br>
- setfileposition operator on p669 of the 3rd edition) says that the<br>
- error return should be ioerror.<br>
-<br>
-base/stream.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-26 15:45:55 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=704617563f8640f6b229ffd65185f79efb0ae195">704617563f8640f6b229ffd65185f79efb0ae195</a>
-<blockquote>
-<p>
- PDF interpreter - more robustness in the face of broken Info dicts<br>
-<br>
- Bug #696541 &quot;ps2pdf fails (typecheck) on a file that can be opened by some other viewers&quot;<br>
-<br>
- This only fails if the device states it can accept document info,<br>
- currently that's limited to pdfwrite and friends.<br>
-<br>
- The problem is that the Info dictionary contains invalid strings, and<br>
- those cause the parsing to break with an error.<br>
-<br>
- This commit simply ignores the error (thereby bit-bucketing the Info)<br>
- just like other devices.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-25 15:50:14 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d9dbc622e4828089e4f2ad63203eb2a32b0e1737">d9dbc622e4828089e4f2ad63203eb2a32b0e1737</a>
-<blockquote>
-<p>
- Fix for bug 696517<br>
-<br>
- bitrgbtags device needed to have its get_color_comp_index<br>
- set to the gx_default_DevRGB_get_color_comp_index.<br>
-<br>
-devices/gdevbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-25 12:27:58 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a5c3505255381bcfd4ec3b5265142927d56e264">9a5c3505255381bcfd4ec3b5265142927d56e264</a>
-<blockquote>
-<p>
- Bug 696521. Fix for bit rotted contributed devices.<br>
-<br>
- These devices now run to completion. I can't verify if the output<br>
- is correct however.<br>
-<br>
-contrib/japanese/gdevmjc.c<br>
-devices/gdevphex.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-25 09:59:23 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6e07b8891aa1bebf258f3936fd537e169aa45c05">6e07b8891aa1bebf258f3936fd537e169aa45c05</a>
-<blockquote>
-<p>
- Fix #69643 Margins don't work in XL.<br>
-<br>
- The PXL interpreter was setting the hardware margins to 0 overriding<br>
- the setting from the command line. We simply remove the setting and<br>
- let the device set to the default parameters if it isn't set on the<br>
- command line or explicitly elsewhere.<br>
-<br>
-pcl/pxl/pxsessio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-23 08:13:45 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ccb0968c696ab80eb19071e0f3b93c850759856a">ccb0968c696ab80eb19071e0f3b93c850759856a</a>
-<blockquote>
-<p>
- Fix typo in last commit.<br>
-<br>
-pcl/pcl/rtgmode.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-22 12:17:29 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f56510cefb91ee24becd43e5f0d9baa7be53367d">f56510cefb91ee24becd43e5f0d9baa7be53367d</a>
-<blockquote>
-<p>
- Fix badly scaled image (696530) and refactor.<br>
-<br>
- Many RTL plotters do not restrict resolutions so we allow any resolution<br>
- in RTL mode. Further the the function which sets the resolution was<br>
- awkward: wrongly commented with a complex nested ternary operator. We<br>
- now use a simpler lookup table and hopefully have a better explanation<br>
- of what we are doing in the comments.<br>
-<br>
-pcl/pcl/rtgmode.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-22 14:30:39 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c30df20c44d608b9c0832e5ef117f08cd358895b">c30df20c44d608b9c0832e5ef117f08cd358895b</a>
-<blockquote>
-<p>
- pdfwrite - correct a buffer size when converting colours<br>
-<br>
- Bug #696531 &quot;Ghostscript segfaults on some PDF files&quot;<br>
-<br>
- When converting DeviceN (and some other) spaces to a different colour<br>
- space we do not convert the actual space, we convert the *base* space<br>
- in order to better preserve the original colour intent.<br>
-<br>
- For example a Separation ink of 'PANTONE 4' might have a base space (to<br>
- which the PANTONE colour will be converted if that ink is not available)<br>
- of DeviceCMYK. If we set the ColourConversionStrategy to RGB then we can<br>
- either convert every pantone colour to CMYK then convert the CMYK to RGB<br>
- or we can alter the base space from CMYK to RGB, we choose to alter the<br>
- base space.<br>
-<br>
- To do this we need to create a function which maps the input colours to<br>
- the base space. This function needs a data source, and the buffer being<br>
- allocated to hold the data had its size incorrectly calculated.<br>
-<br>
- This led to running off the end of the buffer and corrupting memory.<br>
- This commit corrects the buffer size calculation.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/vector/gdevpdfc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-22 13:55:24 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=19abd5d192aeab76f521791148f8b586414504a1">19abd5d192aeab76f521791148f8b586414504a1</a>
-<blockquote>
-<p>
- Bug 696522: Set up copy_planes for all planar devices.<br>
-<br>
- Previously we never set up the copy_planes dev proc for planar<br>
- devices that had a single plane, but it seems we need to.<br>
-<br>
-base/gdevmpla.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-21 09:51:43 -0800
-</strong>
-<br>Brian Norris &lt;computersforpeace@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0c176a91d53c85cdacd7917c76d6f659125ac3f6">0c176a91d53c85cdacd7917c76d6f659125ac3f6</a>
-<blockquote>
-<p>
- Bug 696528: kill off ijs-config<br>
-<br>
- The custom ijs-config tool gives different include paths than pkg-config<br>
- (-I${INCLUDE_PATH}/ijs vs. -I${INCLUDE_PATH}/), which can be confusing<br>
- for developers using this library. pkg-config is more standard anyway,<br>
- so just kill the custom tool.<br>
-<br>
-ijs/Makefile.am<br>
-ijs/Makefile.in<br>
-ijs/configure<br>
-ijs/configure.ac<br>
-ijs/ijs-config.1<br>
-ijs/ijs-config.in<br>
-ijs/libtool<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-21 10:48: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=fd63655e199fbfcda8e52c873b3a28bf27914c93">fd63655e199fbfcda8e52c873b3a28bf27914c93</a>
-<blockquote>
-<p>
- Enable &quot;accurate curves&quot; by default.<br>
-<br>
- This helps to address bug 696466 (and it's earlier related<br>
- bug 688434).<br>
-<br>
-base/gxistate.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-21 18:09:09 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e25594f98886a164f4465505595691aca8136deb">e25594f98886a164f4465505595691aca8136deb</a>
-<blockquote>
-<p>
- Bug 696466: Preliminary work on setaccuratecurves.<br>
-<br>
- If accurate curves are enabled, and the same path is filled<br>
- and then stroked, we can get very different results when the<br>
- flatness is high.<br>
-<br>
- This can look very odd. Ensure that we flatten paths in the<br>
- same way for both fills and strokes when accurate curves is<br>
- enabled.<br>
-<br>
-base/gxfill.c<br>
-base/gxpath.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-20 20:15:42 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=064559beaa05329b1d9e6283e6d17a8c87765e7f">064559beaa05329b1d9e6283e6d17a8c87765e7f</a>
-<blockquote>
-<p>
- Bug 696466: Fix incorrect line joins in strokes.<br>
-<br>
- When we flatten a path for stroking, we keep 'notes' on each<br>
- line to tell us whether each line was present in the original<br>
- path, or whether it was generated by the flattening process.<br>
-<br>
- We further note which lines were generated by the flattening<br>
- process, and are NOT the first one in a given curve. We do this<br>
- so that we can apply the 'curve join' to the start of such line<br>
- segments.<br>
-<br>
- The &quot;curve_join&quot; is an optimisation to speed path drawing. When<br>
- we've flattened a curve, it makes no sense to draw (say) a round<br>
- join between each flattened line, because they will be almost<br>
- parallel, and the join will be visually indistinguishable from<br>
- a simple bevel (in most cases).<br>
-<br>
- It's still important that we draw the correct curve between any<br>
- preceeding line and the first line in the curve though.<br>
-<br>
- Sometimes, (especially when setaccuratecurves is turned on), the<br>
- first line in a flattened curve may be degenerate (i.e. 0 length).<br>
- The stroker spots degenerate sections and skips them. Unfortunately<br>
- that means it also skips the note about it being the first line<br>
- from a curve, and the wrong join is used.<br>
-<br>
- The fix implemented here is to alter the stroker so that when<br>
- it skips a degenerate section, it checks for the 'first line<br>
- from an arc' flag and carries it forwards.<br>
-<br>
-base/gxstroke.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-18 10:16:09 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=68dc00f46d402685f2060ce7ae1b64056996556f">68dc00f46d402685f2060ce7ae1b64056996556f</a>
-<blockquote>
-<p>
- Improve interpolated image processing collecting runs of non-pure colors.<br>
-<br>
- It the colorspace output is not &quot;pure&quot;, runs were not being detected.<br>
- Use code similar to the pure color case detecting runs when the interpolated<br>
- color (psrc) is the same.<br>
-<br>
- This allows the file on Bug 696140 to complete (eventually).<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-19 12:32:37 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e153e19cfd9660ea81c738ea8be3dd9183b3bbc">1e153e19cfd9660ea81c738ea8be3dd9183b3bbc</a>
-<blockquote>
-<p>
- Fix dereference of NULL pointer<br>
-<br>
- When gscms_get_link is called with a device link profile as the source<br>
- and no destination profile, we had a dereferencing issue. Thanks<br>
- to Henry for seeing this.<br>
-<br>
-base/gsicc_lcms2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-18 16:50:46 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=10916df6310cb94c4074302cf485f535d76b4533">10916df6310cb94c4074302cf485f535d76b4533</a>
-<blockquote>
-<p>
- PS/PDF interpreters - fix Text rendering mode 3 with large glyphs<br>
-<br>
- Bug #696513 &quot;Regression: Ghostscript renders unexpected boxes starting with bb246f03fab855325a73fdc982ed9802c1f16772&quot;<br>
-<br>
- The commit noted as causing the regression is, frankly, incorrect.<br>
-<br>
- When handling text we have two possible paths; one with caching and,<br>
- for large glyphs at high resolution, one without caching.<br>
-<br>
- When doing a stringwidth or Tr3 with a cached glyph, we simply avoid<br>
- rendering the cached bitmap. However with non-cached glyphs its not so<br>
- simple. We run the CharProc/BuildGlyph procedure as PostScript, which<br>
- means all the operations are indistinguishable from regular PostScript.<br>
-<br>
- So, when performing a stringwidth using a non-cached glyph, and prior to<br>
- the noted commit, when using Tr 3, we push the null device in order to<br>
- prevent the glyphs actually marking the page, and then grestore back to<br>
- original device when we finish.<br>
-<br>
- The commit noted broke that by failing to push the null device, meaning<br>
- that uncached glyph in rendering mode 3 did actually mark the raster.<br>
-<br>
- The first part of the commit reverses the earlier commit, and implements<br>
- skipping the currentpoint by explicitly checking the 'operation' before<br>
- performing it. In fact this is no longer necessary as the PDF interpreter<br>
- now checks this at an earlier stage and the original bug can no longer<br>
- be reproduced this way anyway.<br>
-<br>
- However, this exposed two new problems which had previously been masked,<br>
- but were nevertheless potential bugs:<br>
-<br>
- The 'procs' structure in a device was originally intended to be fully<br>
- populated, each proc should either have a device-specific method or a<br>
- graphics library default. This means there is no need to check the value<br>
- of a device proc, we can always execute it.<br>
-<br>
- Unfortunately, as noted before, this has been broken for some time in<br>
- the code base. There are several methods which do not have graphics<br>
- library defaults, and are not set up by the default device macros. This<br>
- can lead to the 'procs' members being NULL.<br>
-<br>
- There are several places in the code where we explicitly check for a<br>
- device method being NULL before execution in order to catch this<br>
- condition. Ideally we should go back and fix these properly so that we<br>
- can go back to simply executing the device method without checking. But<br>
- this is a big job.....<br>
-<br>
- So here we add two more cases where we check a device method<br>
- 'update_spot_equivalent_colors' to be sure its not NULL before we<br>
- execute it.<br>
-<br>
- No differences expected.<br>
-<br>
-base/gscdevn.c<br>
-base/gscsepr.c<br>
-base/gxchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-18 08:57:10 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da79b51a8bc3aeb4c4e55ae4ce6ebe07b34b93cf">da79b51a8bc3aeb4c4e55ae4ce6ebe07b34b93cf</a>
-<blockquote>
-<p>
- Fix xpswrite/gprf builds with shared zlib.<br>
-<br>
- Both those devices depend on zlib, but lacked the Makefile magic to cope with<br>
- both &quot;local&quot; and shared zlib libraries.<br>
-<br>
-devices/devs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-15 15:46:07 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e6b986c30ca319ad87d5e1fea9a327d74f3de83">1e6b986c30ca319ad87d5e1fea9a327d74f3de83</a>
-<blockquote>
-<p>
- PDF interpreter - improved Acrobat matching with illegal '--x' numbers<br>
-<br>
- It seems that Acrobat handles malformed numbers of the form '--&lt;number&gt;'<br>
- by ignoring the duplicated negations. GS was treating these as 0.<br>
-<br>
- This commit adds to the special 'invalid number' scanning by treating<br>
- numbers with any number of negative signs as a single negative.<br>
-<br>
- Progressions in sumatra/2238_-_text_wrongly_aligned.pdf and<br>
- sumatra/2238_-_doubly_negated_numbers.pdf<br>
-<br>
-psi/iscan.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-14 14:21:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=193ecef5be3f755e8285a55776e0aacdbaf249c1">193ecef5be3f755e8285a55776e0aacdbaf249c1</a>
-<blockquote>
-<p>
- PDF interpreter - allow unlimited growth of stacks<br>
-<br>
- Bug #696487 &quot;Error: /undefined in --run-- reading PDF file&quot;<br>
-<br>
- The problem is caused by the fact that we use a dictionary to store<br>
- ExtGstate changes, so every time we do a gsave we need a new dictionary<br>
- to hold those changes. The file is sub-optimal and contains thousands<br>
- of nested gsaves, which means we need thousands of dictionaries, and<br>
- quickly fill up the dictionary stack.<br>
-<br>
- We could specify a larger maximum dictionary stack, but there is no<br>
- obvious limit to files of this type, one page was seen to have in excess<br>
- of 6,000 nested gsaves. Instead we permit unchecked stack growth by<br>
- setting MaxDictStack (or MaxOpStack / MaxExecStack) to -1 so that the<br>
- stack will grow as required until we run out of memory.<br>
-<br>
- Bug #696511 has been opened as an enhancement to move the ExtGstate<br>
- parameters into the regular graphics state which has to be better than<br>
- the current kludge.<br>
-<br>
- No differences expected.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-psi/istack.c<br>
-psi/zusparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-13 11:27:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=665d68106d0a0853273d0d0d4a555f22cd984c0b">665d68106d0a0853273d0d0d4a555f22cd984c0b</a>
-<blockquote>
-<p>
- Fix libjpeg jconfig.h dependency<br>
-<br>
- Our customised jconfig.h depends on our own arch.h header - add that to<br>
- jpeg.mak<br>
-<br>
-base/jpeg.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-12 15:59: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=bb6963e41cedb4ff68db0e0ff61d4de2668fdc5e">bb6963e41cedb4ff68db0e0ff61d4de2668fdc5e</a>
-<blockquote>
-<p>
- Tidy up the error code and string return in arg_next()<br>
-<br>
- Previously the arg_next() return value was the string containing the argument<br>
- and the error code (if any) was returned via a pointer parameter to an int<br>
- variable.<br>
-<br>
- Change it so the return value is the error code, and the argument string is<br>
- returned via a parameter.<br>
-<br>
-base/gsargs.c<br>
-base/gsargs.h<br>
-pcl/pl/plmain.c<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-12 10:22:59 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=05aa8a4d63935183a0902d33892041ea3f7769da">05aa8a4d63935183a0902d33892041ea3f7769da</a>
-<blockquote>
-<p>
- Fix crash in x64 Windows display device<br>
-<br>
- The code used for the 64 bit display device was broken due<br>
- to an improper initialization of the pointer size during<br>
- the class registration as well as the use of the wrong<br>
- API where we were using SetWindowLong/GetWindowLong instead of<br>
- SetWindowLongPtr/GetWindowLongPtr. Thanks to Robin for<br>
- helping with this.<br>
-<br>
-pcl/pl/plwimg.c<br>
-psi/dwimg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-12 14:43:17 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fde64dbcf02a2548145d662196e83cd0319cece5">fde64dbcf02a2548145d662196e83cd0319cece5</a>
-<blockquote>
-<p>
- PS interpreter - properly handle errors when preparing to run CDevProc<br>
-<br>
- Bug #696503 &quot; Regression: segfault with pdfwrite starting with 2deb460ef02e2802546e09979243764ede2d4173&quot;<br>
-<br>
- The bug title is something of a misnomer, the stated commit does not<br>
- cause the problem, it simply shifts memory around and exposes the<br>
- already existing bug.<br>
-<br>
- The problem is caused by a faulty CIDFont, and the default behaviour of<br>
- the PDF interpreter, which does not halt when an error is encountered.<br>
-<br>
- When running CIDFonts we need to execute a CDevProc in order to add the<br>
- PDF /W or /W2 values to the width of the glyph. However, the font we use<br>
- when setting up to run the CDevProc is broken so badly that we throw an<br>
- error from z1_set_cache. We return the error, but we don't terminate<br>
- the text enumerator, which leads to us continuing with the text. Not<br>
- surprisingly this eventually crashes.<br>
-<br>
- This commit terminates the 'show' operation if it detects an error when<br>
- setting up to run the CDevProc.<br>
-<br>
- No differences expected<br>
-<br>
-psi/zchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-11 16:10: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=15b3f5cbf12461e2ed318e793669b7c34e32089b">15b3f5cbf12461e2ed318e793669b7c34e32089b</a>
-<blockquote>
-<p>
- text extraction - restore the GC macro<br>
-<br>
- Robin asserts that this macro can have no effect and removed it as it<br>
- causes a compiler warning.<br>
-<br>
- Checking this properly will require more time than I have conveniently<br>
- at the moment, and I seem to recall that this was required, in the past<br>
- at least.<br>
-<br>
- Because this might result in a difficult to track down GC problem, and<br>
- was only removed to prevent a compiler warning, I'm restoring the old<br>
- code until I can get the time to walk through it properly and determine<br>
- if it is genuinely unused, and if it is, whether it should be.....<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-11 14:13: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=d43e2ebb241d5a6ed63a2d0cc2c7ff0909498510">d43e2ebb241d5a6ed63a2d0cc2c7ff0909498510</a>
-<blockquote>
-<p>
- Remove legacy lower case arch_* macros<br>
-<br>
- Most of the ARCH_* macros had lower case equivalents for &quot;backwards<br>
- compatibility&quot; - it's been long enough.....<br>
-<br>
-base/gdevdevn.c<br>
-base/gdevm1.c<br>
-base/gdevm16.c<br>
-base/gdevm2.c<br>
-base/gdevm24.c<br>
-base/gdevm32.c<br>
-base/gdevm4.c<br>
-base/gdevm40.c<br>
-base/gdevm48.c<br>
-base/gdevm56.c<br>
-base/gdevm64.c<br>
-base/gdevm8.c<br>
-base/gdevmem.c<br>
-base/gdevmem.h<br>
-base/gsalloc.c<br>
-base/gsbitops.c<br>
-base/gsbitops.h<br>
-base/gsccode.h<br>
-base/gscie.h<br>
-base/gsfont.c<br>
-base/gsovrc.c<br>
-base/gspaint.c<br>
-base/gsparam.c<br>
-base/gxalloc.h<br>
-base/gxbitops.h<br>
-base/gxchar.c<br>
-base/gxcht.c<br>
-base/gxcindex.h<br>
-base/gxcvalue.h<br>
-base/gxdcolor.c<br>
-base/gxdevcli.h<br>
-base/gxdevice.h<br>
-base/gxfapi.c<br>
-base/gxfill.c<br>
-base/gxfill.h<br>
-base/gxfrac.h<br>
-base/gxi12bit.c<br>
-base/gxidata.c<br>
-base/gxiscale.c<br>
-base/gxmclip.h<br>
-base/gxobj.h<br>
-base/gxoprect.c<br>
-base/gxpcmap.c<br>
-base/gxsample.c<br>
-base/gxtype1.h<br>
-base/gzht.h<br>
-base/scf.h<br>
-base/shc.h<br>
-base/smtf.c<br>
-base/spngp.c<br>
-base/std.h<br>
-contrib/gdevhl12.c<br>
-devices/gdev4693.c<br>
-devices/gdevbmpc.c<br>
-devices/gdevdsp.c<br>
-devices/gdevgprf.c<br>
-devices/gdevimgn.c<br>
-devices/gdevmgr.c<br>
-devices/gdevmswn.c<br>
-devices/gdevpcx.c<br>
-devices/gdevpsd.c<br>
-devices/gdevstc.c<br>
-devices/gdevstc.h<br>
-devices/gdevsun.c<br>
-devices/gdevtfax.c<br>
-devices/gdevtfnx.c<br>
-devices/gdevtsep.c<br>
-devices/gdevupd.c<br>
-devices/gdevxcf.c<br>
-devices/vector/gdevpdfb.c<br>
-devices/vector/gdevpdfv.c<br>
-pcl/pcl/pccoord.h<br>
-pcl/pcl/pcommand.h<br>
-pcl/pl/plchar.c<br>
-psi/ialloc.c<br>
-psi/idict.c<br>
-psi/idict.h<br>
-psi/igcref.c<br>
-psi/igcstr.c<br>
-psi/iref.h<br>
-psi/zdouble.c<br>
-psi/zusparam.c<br>
-toolbin/color/icc_creator/ICC_Creator/icc_create.cpp<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-09 08:09:06 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9bf5ab79cf5a0e9d6eee490fe1859c6d6aa28ca5">9bf5ab79cf5a0e9d6eee490fe1859c6d6aa28ca5</a>
-<blockquote>
-<p>
- Fix typo in Make.htm.<br>
-<br>
- Spotted by Brian Norris.<br>
-<br>
-doc/Make.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-08 15:42:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b7b278daa5a8290681de6ad157060fb2e9068ea">4b7b278daa5a8290681de6ad157060fb2e9068ea</a>
-<blockquote>
-<p>
- Bug 696497 (part 2): fix support for building with a JPX decoder<br>
-<br>
-base/lib.mak<br>
-psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-08 13:54: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=57fbbff9f296ddf75d3deafb0094543a04c5450b">57fbbff9f296ddf75d3deafb0094543a04c5450b</a>
-<blockquote>
-<p>
- Tweak LCMS2 endian setting in configure<br>
-<br>
- The previous configure setting did not work with the latest endian stuff in<br>
- lcms2.h when building a universal binary on Mac. This change resolves that.<br>
-<br>
- Also change the order of the types we check when looking for a 64 bit data<br>
- type for color indices - put the more commonly successful one first. Again,<br>
- this is in support of universal binaries on Mac.<br>
-<br>
- Noticed in passing.....<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-08 11:00:08 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e8632ae0ac799d4ad7cf253530576c53369baa7">2e8632ae0ac799d4ad7cf253530576c53369baa7</a>
-<blockquote>
-<p>
- Bug 696498: clean up endian configure checks<br>
-<br>
- The custom endian checks in the configure scripts were implemented because the<br>
- built-in test in the most common autoconf version at the time was buggy on<br>
- several platforms.<br>
-<br>
- Those autoconf problems were addressed some time and several versions ago, and<br>
- the newer versions are widely adopted, so we can safely use the built-in<br>
- AC_C_BIGENDIAN() test.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-07 20:32:19 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=08eaf8b0f70c5ad000001e01d767e4093ba38eff">08eaf8b0f70c5ad000001e01d767e4093ba38eff</a>
-<blockquote>
-<p>
- Tidy up cmap table selection in fapi_ft.c<br>
-<br>
- Rearrange so we don't try to select the cmap table for non-TT fonts, and only<br>
- once.<br>
-<br>
- Also, make it explicit and comment the fact we ignore the return value from<br>
- the Freetype call.<br>
-<br>
-base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-07 17:44:56 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d5fe73441042077ee8e76494a94b9fef5102c3d0">d5fe73441042077ee8e76494a94b9fef5102c3d0</a>
-<blockquote>
-<p>
- Bug 696502: cope with PaintProc with more gsaves than grestores<br>
-<br>
- If a pattern PaintProc executes one or more gsave operations, and fails to<br>
- execute a matching number of grestore operations, we can end up trying to<br>
- complete any transparency operations and cache the pattern tile with the<br>
- wrong gstate in force.<br>
-<br>
- pattern_paint_cleanup() already dealt with that, so add similar code to<br>
- pattern_paint_finish() - as the information is already available on the<br>
- stack.<br>
-<br>
-psi/zpcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-07 17:09:34 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=03456d0a01bfb2823261d200d40bf2975c947eb8">03456d0a01bfb2823261d200d40bf2975c947eb8</a>
-<blockquote>
-<p>
- Bug 696499: avoid infinite recursion of Show calls<br>
-<br>
- In the PDF interpreter we keep a procedure called &quot;/Show&quot; in the PDF<br>
- graphics state dictionary, which gets changed to suit the current text<br>
- rendering settings when we enter a text context.<br>
-<br>
- To cope with a previous broken PDF we prevent changes to the graphics state<br>
- under certain circumstances (specifically, after a 'W' operator).<br>
-<br>
- In this case, we have a *very* broken PDF that attempts to draw some text<br>
- in these circumstances - as the graphics state is is now &quot;locked&quot;, we<br>
- cannot update /Show and we end up infinitely recursing.<br>
-<br>
- We now special case /Show to prevent this.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-07 12:33: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=b0f5a97512332ecf2ec7cf1cc413fe7305a4060e">b0f5a97512332ecf2ec7cf1cc413fe7305a4060e</a>
-<blockquote>
-<p>
- Bug 696497: Fix support for building with no jbig2 decoder<br>
-<br>
-base/lib.mak<br>
-psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-07 09:03:10 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f5d28536e4518716fdfe974e580194c8f57871d">8f5d28536e4518716fdfe974e580194c8f57871d</a>
-<blockquote>
-<p>
- Bug 696281: fix check for using shared freetype lib<br>
-<br>
- When I changed the initial value of the Freetype source path variable (to reduce<br>
- the risk of header search path problems), I neglected to fix the logic for<br>
- falling back to the system's libfreetype2.<br>
-<br>
- Credit to Rodrigo Rivas Costa for spotting the problem.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-07 09:15:54 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e29faf57ebe822b6f4c526b87a21c7cfeea768b">2e29faf57ebe822b6f4c526b87a21c7cfeea768b</a>
-<blockquote>
-<p>
- Remove unused code from last commit<br>
-<br>
- Last commit had a static function that I was thinking of using. I decided not to<br>
- use it and forgot to remove it with the commit.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-05 10:41:58 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1e15776353f8128dfec34a50a14feea12b2a072">b1e15776353f8128dfec34a50a14feea12b2a072</a>
-<blockquote>
-<p>
- Refactor code in gxiscale.c<br>
-<br>
- Quite a bit of code duplication present in gxiscale.c. This gets many of the color<br>
- tests/initializations into common static functions and simplifies some of the tests.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-06 20:08:20 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e9a94db35178e398c759fdf31fa586e2913aab55">e9a94db35178e398c759fdf31fa586e2913aab55</a>
-<blockquote>
-<p>
- VS builds: Ensure /FC is added to CFLAGS<br>
-<br>
- /FC forces the compiler to report full paths in warnings and<br>
- error messages. This enables throwback to work correctly in the<br>
- IDE. This only affects builds with the DEVSTUDIO variable<br>
- defined (i.e. those done from the VS solution).<br>
-<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-06 19:16:58 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bd067d202a7944554dafb82ee71e5ce4ab0adf90">bd067d202a7944554dafb82ee71e5ce4ab0adf90</a>
-<blockquote>
-<p>
- Remove some wacky code from gxttfb<br>
-<br>
- Originally by Igor, neither Chris nor I can understand the<br>
- purpose of this purposeless code.<br>
-<br>
- Chris has run against the test files and can't find any that trigger<br>
- the case, so removing it seems harmless.<br>
-<br>
-base/gxttfb.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-31 13:55: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=645e21d1faa7024c6d6f4c690125453344f56c2d">645e21d1faa7024c6d6f4c690125453344f56c2d</a>
-<blockquote>
-<p>
- Bug 649971: GS Stroking fix<br>
-<br>
- 'Fat' strokes for curves of high curvature can go wrong due to the<br>
- winding for the 'underjoin' below curves being in the wrong sense.<br>
-<br>
- This commit introduces a tweaked version of the code that solves this<br>
- at the cost of more complex paths. Sadly the cost for this seems to<br>
- be a huge slowdown, so the new code is disabled for now unless we<br>
- build with SLOWER_BUT_MORE_ACCURATE_STROKING defined.<br>
-<br>
-base/gxstroke.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-06 16:54:22 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab929e3d6568334e336a952794918fb92123e869">ab929e3d6568334e336a952794918fb92123e869</a>
-<blockquote>
-<p>
- VS Solution: Add some missing files<br>
-<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-06 17:01:28 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c2ec1e45216df7311cf14dd0b1d261a0173d70c">6c2ec1e45216df7311cf14dd0b1d261a0173d70c</a>
-<blockquote>
-<p>
- Silence some more warnings.<br>
-<br>
-base/gdevdbit.c<br>
-base/gdevflp.c<br>
-base/gdevoflt.c<br>
-base/genht.c<br>
-base/gp_unix_cache.c<br>
-base/gshtscr.c<br>
-base/gsicc_manage.c<br>
-base/gxclrast.c<br>
-base/gxclread.c<br>
-base/gxclthrd.c<br>
-base/gxcpath.c<br>
-base/gzcpath.h<br>
-base/ttinterp.c<br>
-contrib/pcl3/eprn/eprnrend.c<br>
-contrib/pcl3/eprn/gdeveprn.c<br>
-psi/iscan.c<br>
-psi/iscanbin.c<br>
-psi/zimage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-06 16:57:16 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=433d47aa3efdcf5cb26026dae27793ab901f12db">433d47aa3efdcf5cb26026dae27793ab901f12db</a>
-<blockquote>
-<p>
- Fix some dropped errors in pdfwrite.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfo.c<br>
-devices/vector/gdevpdfu.c<br>
-devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-05 17:05:19 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b30e140190d1b18eaf769a29855f5cfe20e4922e">b30e140190d1b18eaf769a29855f5cfe20e4922e</a>
-<blockquote>
-<p>
- Squash warnings: postscript interpreter<br>
-<br>
- Avoid some 'defined but not used' warnings in release builds.<br>
-<br>
- Avoid a particularly bonkers warning about &quot;string&quot; + int not doing<br>
- concatenation (and simplify the code a bit).<br>
-<br>
- Remove some unused code.<br>
-<br>
-psi/ilocate.c<br>
-psi/iutil.c<br>
-psi/zcontext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-05 16:26:12 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e0bcc257b1d94b8d5b1e800c25a1dd7149aa773c">e0bcc257b1d94b8d5b1e800c25a1dd7149aa773c</a>
-<blockquote>
-<p>
- Fix macro error in gxfapi.h<br>
-<br>
- We have a macro that defines an expression. Add params to ensure<br>
- that if MACRO = A || B || C that !MACRO = !(A || B || C) not<br>
- !A || B || C.<br>
-<br>
-base/gxfapi.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-05 17:00:38 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5f7bc19bbbc551142dd94733a94657ef571ea4f8">5f7bc19bbbc551142dd94733a94657ef571ea4f8</a>
-<blockquote>
-<p>
- Fix some error returns in pdfwrite.<br>
-<br>
- Various places in the pdfwrite device we call:<br>
-<br>
- gs_note_error(x)<br>
-<br>
- and then carry on. The compiler warnings report whinges about<br>
- this.<br>
-<br>
- We could fix it by doing:<br>
-<br>
- (void)gs_note_error(x);<br>
-<br>
- to simply shut the compiler warnings up, but it might be nicer to<br>
- do it properly by changing the functions to correctly return<br>
- errors.<br>
-<br>
- I'm going to try the latter. Ken can kick me later.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfo.c<br>
-devices/vector/gdevpdfu.c<br>
-devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-05 17:07:02 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9c8d7abbff0cb9f8856e18934528f7b81702627d">9c8d7abbff0cb9f8856e18934528f7b81702627d</a>
-<blockquote>
-<p>
- VS solution: gdevpxut.c was in the wrong place.<br>
-<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-05 17:04: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=fd9a66f997bb57e9628a703774eddcf933475a34">fd9a66f997bb57e9628a703774eddcf933475a34</a>
-<blockquote>
-<p>
- Squash warnings: various warnings in devices.<br>
-<br>
- Nothing contentious here.<br>
-<br>
-devices/devs.mak<br>
-devices/gdevlp8k.c<br>
-devices/gdevpxut.c<br>
-devices/gdevupd.c<br>
-devices/rinkj/rinkj-screen-eb.c<br>
-devices/vector/gdevpdti.c<br>
-devices/vector/gdevpsds.c<br>
-devices/vector/gdevpx.c<br>
-devices/vector/gdevtxtw.c<br>
-devices/vector/gdevxps.c<br>
-devices/vector/whitelst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-05 12:43: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=e7e548af55b7034409e96483fee1d92313573973">e7e548af55b7034409e96483fee1d92313573973</a>
-<blockquote>
-<p>
- Squash miscellaneous warnings.<br>
-<br>
- Remove some redundant variables, and tweak code to avoid compiler<br>
- warnings.<br>
-<br>
-contrib/gdevmd2k.c<br>
-contrib/pcl3/eprn/eprnfs.c<br>
-contrib/pcl3/eprn/eprnparm.c<br>
-contrib/pcl3/eprn/eprnrend.c<br>
-contrib/pcl3/eprn/gdeveprn.c<br>
-contrib/pcl3/eprn/gdeveprn.h<br>
-contrib/pcl3/eprn/mediasize.c<br>
-contrib/pcl3/eprn/mediasize.h<br>
-contrib/pcl3/eprn/pagecount.c<br>
-contrib/pcl3/eprn/pagecount.h<br>
-contrib/pcl3/src/gdevpcl3.c<br>
-contrib/pcl3/src/pcl3opts.c<br>
-contrib/pcl3/src/pclcap.c<br>
-contrib/pcl3/src/pclcap.h<br>
-contrib/pcl3/src/pclcomp.c<br>
-contrib/pcl3/src/pclgen.c<br>
-contrib/pcl3/src/pclgen.h<br>
-contrib/pcl3/src/pclscan.c<br>
-contrib/pcl3/src/pclscan.h<br>
-contrib/pcl3/src/pclsize.c<br>
-contrib/pcl3/src/pclsize.h<br>
-devices/gdevhl7x.c<br>
-devices/gdevifno.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-05 07:39:18 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8fa72d8d85859cc4e8e52bd72231f1af8f7862a2">8fa72d8d85859cc4e8e52bd72231f1af8f7862a2</a>
-<blockquote>
-<p>
- Fix minor typo in &quot;unbalanced q/Q&quot; message for &quot;too many q's&quot; case.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-05 09:49:24 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=53975ad9284df0a3aaaaca1f9bf7843620741086">53975ad9284df0a3aaaaca1f9bf7843620741086</a>
-<blockquote>
-<p>
- Type 1 glyph name synthesis minor efficiency improvement<br>
-<br>
- Some very small efficiency improvements - mainly, avoiding the need to<br>
- re-init a scratch string with a loop.<br>
-<br>
-Resource/Init/gs_type1.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 19:50:53 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7c2b9d06f582996ed6c230aacfbf9a0dc88c1349">7c2b9d06f582996ed6c230aacfbf9a0dc88c1349</a>
-<blockquote>
-<p>
- Clean up logic statements in gxiscale.c<br>
-<br>
- The test to determine if we need to do an upfront decode during the color<br>
- management of colors in the image scaling routine were confusing to<br>
- say the least. This should clarify everything.<br>
-<br>
-base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 19:44:35 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=92e3e79af6a068f99a723aba56df6b2cd17bbb39">92e3e79af6a068f99a723aba56df6b2cd17bbb39</a>
-<blockquote>
-<p>
- Squash clang warnings: Miscellaneous more warnings<br>
-<br>
- All fairly self explainatory.<br>
-<br>
-base/gxfdrop.c<br>
-base/gxfill.c<br>
-base/gxhintn.c<br>
-base/gximono.c<br>
-base/gxshade6.c<br>
-base/gxstroke.c<br>
-base/gxttfb.c<br>
-base/sjpx_openjpeg.c<br>
-base/ttfmain.c<br>
-base/vdtrace.c<br>
-contrib/gdevgdi.c<br>
-contrib/gdevlx7.c<br>
-contrib/opvp/gdevopvp.c<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 18:56:28 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e3bc0494fc7084bd729a393e7bd6aebeeba6b6a9">e3bc0494fc7084bd729a393e7bd6aebeeba6b6a9</a>
-<blockquote>
-<p>
- Squash clang warning: Avoid testing enums out of range.<br>
-<br>
- clang complains that the code we use to test whether an enum value<br>
- we get it out of range is testing for values outside the enum range.<br>
- Fix it with an explicit cast.<br>
-<br>
-base/gstrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 18:54: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=d957420f8b2949fb7cd7563ee52af2807eb9aa7a">d957420f8b2949fb7cd7563ee52af2807eb9aa7a</a>
-<blockquote>
-<p>
- Squash warning: clist code<br>
-<br>
- clang complains that the clist code is checking an enum return against<br>
- out of range values. Rejig the code to use a switch rather than the<br>
- chain of ifs (clearer IMAO), and handle the out of range values in the<br>
- default case.<br>
-<br>
-base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 18:44:36 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=06f4897ea836544c48f15b7b3ffb7c4d1dc3a7d1">06f4897ea836544c48f15b7b3ffb7c4d1dc3a7d1</a>
-<blockquote>
-<p>
- Remove unused structure definition from gsshade.c<br>
-<br>
- Meshes are a superclass - never instantiated on their own.<br>
-<br>
-base/gsshade.c<br>
-base/gsshade.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 18:44: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=94ce8c79aca2a839f369a3d61347facb1b5bef7e">94ce8c79aca2a839f369a3d61347facb1b5bef7e</a>
-<blockquote>
-<p>
- Fix harmless tiny type typo in icc stuff.<br>
-<br>
- This shuts clang up.<br>
-<br>
-base/gsicc_create.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 18:42:49 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=438f429625773d675a0649fb189e1378be2c6b29">438f429625773d675a0649fb189e1378be2c6b29</a>
-<blockquote>
-<p>
- Squash warnings: gsht.c<br>
-<br>
- Remove unused table, and pacify clang by casting an enum type to<br>
- int before comparing it to out of range enum values.<br>
-<br>
-base/gsht.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 18:28:21 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9aec49be8f43a1a3a4bdad7a552ef9fcf039b2e7">9aec49be8f43a1a3a4bdad7a552ef9fcf039b2e7</a>
-<blockquote>
-<p>
- Avoid unused function warning in release builds.<br>
-<br>
-base/gsfcmap1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 18:27:12 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3d07583e43d472979250f57b80a50028226c667b">3d07583e43d472979250f57b80a50028226c667b</a>
-<blockquote>
-<p>
- Fix use of uninitialised var.<br>
-<br>
-base/gscspace.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 18:24:31 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3a563b047e686038283474b9cef942ffa889f7a3">3a563b047e686038283474b9cef942ffa889f7a3</a>
-<blockquote>
-<p>
- Fix typo: == should be =<br>
-<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 18:22:43 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34857cb1514033237cf658f33157a991606cfe7d">34857cb1514033237cf658f33157a991606cfe7d</a>
-<blockquote>
-<p>
- Remove unused definition.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 18:11: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=3343e6fe21259e548cb93748f70e81c7255d7ec7">3343e6fe21259e548cb93748f70e81c7255d7ec7</a>
-<blockquote>
-<p>
- Squash warnings: Use better unused var paradigm.<br>
-<br>
- Using &quot;n = n;&quot; causes some versions of gcc to whinge. Trying<br>
- (void)n; instead.<br>
-<br>
-base/gspmdrv.c<br>
-base/gsptype1.c<br>
-contrib/japanese/gdevmjc.c<br>
-devices/gdevcmykog.c<br>
-devices/gdevgprf.c<br>
-devices/gdevpsd.c<br>
-jpeg/jcsample.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 18:11:18 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=80ceaaec2fe06505cb0a5059ad5f95ea28004f9f">80ceaaec2fe06505cb0a5059ad5f95ea28004f9f</a>
-<blockquote>
-<p>
- Remove unused function from gdevddrw.c<br>
-<br>
-base/gdevddrw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 17:34:53 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=24c51631502da158557e0f35368756dd95cdfb38">24c51631502da158557e0f35368756dd95cdfb38</a>
-<blockquote>
-<p>
- Fix potential problem in transparency code<br>
-<br>
- If we ever use more the 8 bits for color values, we'd try to<br>
- pack numbers &gt; 255 into a byte in pdf14_cmykspot_put_image and<br>
- pdf14_custom_put_image. Simple fix is to use 0xff rather than<br>
- gx_max_color_value.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 17:33:25 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=46b2671d6526cb6aee37f786bb616c1513248a02">46b2671d6526cb6aee37f786bb616c1513248a02</a>
-<blockquote>
-<p>
- Fix typo in gdevdbgr.c<br>
-<br>
- Should be | not || as a &amp; (constant || constant) doesn't really<br>
- make sense.<br>
-<br>
-base/gdevdgbr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 17:18:19 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7069210f88b764929a32713ab5032f02097b62b5">7069210f88b764929a32713ab5032f02097b62b5</a>
-<blockquote>
-<p>
- Squash warnings: XPS MSVC<br>
-<br>
- Add some casts etc to squash (most of) the warnings seen in<br>
- an MSVC debug build of ghostxps.<br>
-<br>
- We have an unavoidable &quot;cast away of const&quot; in a devspecop call,<br>
- and various stupidities in the jpegxr lib left over.<br>
-<br>
-xps/ghostxps.h<br>
-xps/xpscff.c<br>
-xps/xpscolor.c<br>
-xps/xpsglyphs.c<br>
-xps/xpsgradient.c<br>
-xps/xpsjpeg.c<br>
-xps/xpsjxr.c<br>
-xps/xpspath.c<br>
-xps/xpspng.c<br>
-xps/xpstiff.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 16:39:31 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d697081ba9f0943977ed5ae8a62c7389046a5776">d697081ba9f0943977ed5ae8a62c7389046a5776</a>
-<blockquote>
-<p>
- Squash warnings: MSVC PCL<br>
-<br>
- Squash the warnings seen when building a debug PCL build on MSVC 2005.<br>
-<br>
- Mostly addition of simple casts.<br>
-<br>
-pcl/pcl/pcjob.c<br>
-pcl/pcl/pcpage.c<br>
-pcl/pcl/pglabel.c<br>
-pcl/pcl/pglfill.c<br>
-pcl/pcl/rtgmode.c<br>
-pcl/pl/plchar.c<br>
-pcl/pl/pllfont.c<br>
-pcl/pxl/pximage.c<br>
-pcl/pxl/pxink.c<br>
-pcl/pxl/pxvendor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 16:16:18 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=15d2abc903ed91f5f319687c2bc6959a38d36069">15d2abc903ed91f5f319687c2bc6959a38d36069</a>
-<blockquote>
-<p>
- Windows PCL: Correct return type from int to void.<br>
-<br>
- Nothing was ever returned.<br>
-<br>
-pcl/pl/plwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 16:11:06 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5fe48dd2498953fc3df7f8f22655e91c77f97076">5fe48dd2498953fc3df7f8f22655e91c77f97076</a>
-<blockquote>
-<p>
- Squash warnings: MSVC ones.<br>
-<br>
- Tweak the code to avoid the warnings seen in the MSVC debug build of<br>
- gs.<br>
-<br>
- Mostly adding a few casts to make type changes explicit (and hence<br>
- avoid the &quot;casting from int to double might lose data&quot; etc warnings).<br>
-<br>
- Reorder the headers in a couple of places to avoid offsetof being<br>
- redefined in a system header warnings.<br>
-<br>
-base/gpmisc.c<br>
-base/gsicc_create.c<br>
-base/gxclimag.c<br>
-base/gxfapi.c<br>
-devices/gdevdsp.c<br>
-devices/gdevfpng.c<br>
-devices/gdevgprf.c<br>
-devices/gdevpng.c<br>
-devices/gdevtifs.c<br>
-devices/vector/gdevpdfu.c<br>
-devices/vector/gdevpsds.c<br>
-devices/vector/gdevxps.c<br>
-psi/gsdll.c<br>
-psi/iscannum.c<br>
-psi/iutil.c<br>
-psi/zdpnext.c<br>
-psi/zdps1.c<br>
-psi/zmatrix.c<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 17:07: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=063c0a1eface77cdc2c4e657599521c7146ec8ca">063c0a1eface77cdc2c4e657599521c7146ec8ca</a>
-<blockquote>
-<p>
- Bug 696480: add a missing 'pop' for stack cleanup.<br>
-<br>
- When attempting to create all viable glyph name mappings in a Type 1 font,<br>
- as a last ditch, we try to parse a unicode code point out of a string containing<br>
- a'uniXXXX' type glyph name (where 'XXXX' is the code point). If that parsing<br>
- fails, we were leaving the string on the stack, causing an error.<br>
-<br>
-Resource/Init/gs_type1.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 14:14:35 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7795f0f1f8700651d2a79f979a5d40885569dd11">7795f0f1f8700651d2a79f979a5d40885569dd11</a>
-<blockquote>
-<p>
- Squash warnings: ICC code.<br>
-<br>
- Various bits of the ICC code collects return values only to not<br>
- check them. Fix that here.<br>
-<br>
- In some cases this is because functions have a 'void' return type<br>
- so there isn't a way to return an error. Change those return types<br>
- and ensure that all callers check and propogate the errors.<br>
-<br>
-base/gdevdevn.c<br>
-base/gscms.h<br>
-base/gsdevice.c<br>
-base/gsequivc.c<br>
-base/gsequivc.h<br>
-base/gsicc_cache.c<br>
-base/gsicc_cache.h<br>
-base/gsicc_cms.h<br>
-base/gsicc_lcms.c<br>
-base/gsicc_lcms2.c<br>
-base/gsicc_manage.c<br>
-base/gsicc_monitorcm.c<br>
-base/gsicc_nocm.c<br>
-base/gsicc_replacecm.c<br>
-base/gspaint.c<br>
-base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 14:10:04 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=998c8bf7a2e409b6c4c29b8e535028a24404e7c5">998c8bf7a2e409b6c4c29b8e535028a24404e7c5</a>
-<blockquote>
-<p>
- Squash warnings: Contrib devices<br>
-<br>
- Workaround as many warnings as possible in the contrib devices.<br>
-<br>
- Removing dead code, checking return values etc, fixing type casts<br>
- (char to unsigned char etc).<br>
-<br>
-contrib/eplaser/gdevescv.c<br>
-contrib/gdevmd2k.c<br>
-contrib/japanese/gdev10v.c<br>
-contrib/japanese/gdevalps.c<br>
-contrib/japanese/gdevespg.c<br>
-contrib/japanese/gdevfmpr.c<br>
-contrib/japanese/gdevlbp3.c<br>
-contrib/japanese/gdevmag.c<br>
-contrib/japanese/gdevml6.c<br>
-contrib/lips4/gdevl4r.c<br>
-contrib/lips4/gdevl4v.c<br>
-contrib/opvp/gdevopvp.c<br>
-contrib/pcl3/eprn/eprnparm.c<br>
-contrib/pcl3/src/gdevpcl3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 14:07:31 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39cdb5df0e2f8e3e4410e008b2a7fb72dcdff805">39cdb5df0e2f8e3e4410e008b2a7fb72dcdff805</a>
-<blockquote>
-<p>
- Avoid ignoring a return code during garbage collection.<br>
-<br>
-psi/ireclaim.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 14:05:59 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3388e52d3ea54fa2d46e857d3004a229d143ad40">3388e52d3ea54fa2d46e857d3004a229d143ad40</a>
-<blockquote>
-<p>
- gdevxcf: don't confuse rgb and cmyk profile functions.<br>
-<br>
- We are writing prgbs to both ProfileRGB and ProfileCMYK.<br>
- That seems wrong.<br>
-<br>
-devices/gdevxcf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 14:04:00 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd32af452b8bd08e7eb5daf3344d2caae8a13dc7">dd32af452b8bd08e7eb5daf3344d2caae8a13dc7</a>
-<blockquote>
-<p>
- Squash Warnings: JBig2<br>
-<br>
- ifdef out some used code.<br>
-<br>
- Make some functions static that should be.<br>
-<br>
-jbig2dec/jbig2_generic.c<br>
-jbig2dec/jbig2_image.c<br>
-jbig2dec/jbig2_refinement.c<br>
-jbig2dec/jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 13:59:43 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=046f22db259214cb77b95e631d65ebdacec79a87">046f22db259214cb77b95e631d65ebdacec79a87</a>
-<blockquote>
-<p>
- Squash warnings: XPS.<br>
-<br>
- Avoid some warnings in the XPS code.<br>
-<br>
- Mostly 'set but unused' variables. Either remove these or<br>
- (in cases where they may be required later) comment them out.<br>
-<br>
- Ensure that all return codes are checked once read. This has<br>
- meant making a few functions return error codes that didn't before.<br>
-<br>
- Include an extra gs header in ghostxps.h. This trips the code into<br>
- objecting to using printf etc. Change the calls to printf to use<br>
- dlprintf instead (as they should do).<br>
-<br>
- Change the prototypes for some functions to pass const params<br>
- in some cases, and make a few return error codes rather than ignoring<br>
- them.<br>
-<br>
- Add a couple of missing prototypes.<br>
-<br>
-xps/ghostxps.h<br>
-xps/xpsdoc.c<br>
-xps/xpshash.c<br>
-xps/xpsmem.c<br>
-xps/xpsopacity.c<br>
-xps/xpsxml.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 13:52:43 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a7588ce7c7cd1b0a8d55818af5d2f34dd17d3ff">7a7588ce7c7cd1b0a8d55818af5d2f34dd17d3ff</a>
-<blockquote>
-<p>
- Minimise warnings in unix ijs code calling execvp.<br>
-<br>
- execvp should really take const char *args, but linux is 'inconsistent'<br>
- about this. We assume that the args are of this form in our code,<br>
- so we'd rather have 1 warning on the call on such systems, rather than<br>
- n about the setup on all systems.<br>
-<br>
-ijs/ijs_exec_unix.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 13:51: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=882ce8be8592ed51243c9a7190c89fb1d2d61fd8">882ce8be8592ed51243c9a7190c89fb1d2d61fd8</a>
-<blockquote>
-<p>
- ijs_server: Don't ignore the 'sign' var when parsing ints.<br>
-<br>
-ijs/ijs_server.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 13:16: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=91470dae4954f9c9e36c019616c3ff7bcdd173de">91470dae4954f9c9e36c019616c3ff7bcdd173de</a>
-<blockquote>
-<p>
- Squash warnings: Cull unused or dead code.<br>
-<br>
- In cases where the code is there for potential future use,<br>
- comment small sections out or use #ifdef UNUSED.<br>
-<br>
-base/mkromfs.c<br>
-contrib/gdevcd8.c<br>
-contrib/gdevdj9.c<br>
-contrib/gdevgdi.c<br>
-contrib/gdevlx32.c<br>
-contrib/gdevop4w.c<br>
-contrib/japanese/gdevmjc.c<br>
-contrib/japanese/gdevrpdl.c<br>
-devices/gdevhl7x.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 13:10:15 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2d914c99900578d76753a134ea6d7bf35eb932f3">2d914c99900578d76753a134ea6d7bf35eb932f3</a>
-<blockquote>
-<p>
- Squash warnings: Add explicit bracketing.<br>
-<br>
- &amp;&amp; binds more tightly than || in C (similarly &amp; and |).<br>
-<br>
- Expressions such as &quot;A &amp;&amp; B || C&quot; are therefore well defined, but<br>
- often error prone and confusing to read, so the compiler warns about<br>
- them. We add explicit parentheses to shut this up (and to clarify<br>
- the code).<br>
-<br>
-base/gxiscale.c<br>
-contrib/pcl3/eprn/eprnfs.c<br>
-contrib/pcl3/eprn/eprnparm.c<br>
-contrib/pcl3/eprn/eprnrend.c<br>
-contrib/pcl3/eprn/gdeveprn.c<br>
-contrib/pcl3/eprn/mediasize.c<br>
-contrib/pcl3/src/gdevpcl3.c<br>
-contrib/pcl3/src/pclcomp.c<br>
-contrib/pcl3/src/pclgen.c<br>
-contrib/pcl3/src/pclsize.c<br>
-devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 13:03:13 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c8e1e6dff1d48adf79659455e7082735909558a1">c8e1e6dff1d48adf79659455e7082735909558a1</a>
-<blockquote>
-<p>
- Squash warning: switch(rop)<br>
-<br>
- Ensure that rop3_T and rop3_S are defined as enum values as well<br>
- as preprocessor definitions.<br>
-<br>
- They must be preprocessor definitions as otherwise the rop templating<br>
- code does not work. If they are not enum values, we get warned about<br>
- switch(rop) testing for values not defined in the enums.<br>
-<br>
-base/gsropt.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 12:57:15 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ff1c44b4dbe241df64dd3d9892df56a421921c2b">ff1c44b4dbe241df64dd3d9892df56a421921c2b</a>
-<blockquote>
-<p>
- Squash warning: Improve static init<br>
-<br>
-base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 12:54:18 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc15153ffe7fe8ca9fa38091bfb50a67897b768b">cc15153ffe7fe8ca9fa38091bfb50a67897b768b</a>
-<blockquote>
-<p>
- Squash Warnings: Add casts to avoid warnings.<br>
-<br>
-base/gdevmem.c<br>
-base/gsht.c<br>
-base/gsicc_manage.c<br>
-base/gzht.h<br>
-base/sdctd.c<br>
-contrib/gdevbjc_.c<br>
-contrib/gdevbjc_.h<br>
-contrib/gdevbjca.c<br>
-devices/rinkj/rinkj-device.h<br>
-devices/rinkj/rinkj-screen-eb.c<br>
-psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 12:44:43 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=240b8f048945a129aacb1e84c7e7b66cf0d5bff1">240b8f048945a129aacb1e84c7e7b66cf0d5bff1</a>
-<blockquote>
-<p>
- Squash Warnings: Unused Var/Var set but not used.<br>
-<br>
-base/gscrdp.c<br>
-base/gsfcmap1.c<br>
-base/gsicc.c<br>
-base/gsiorom.c<br>
-base/gstype1.c<br>
-base/gstype42.c<br>
-base/gxclimag.c<br>
-base/gxdtfill.h<br>
-base/gxhintn.c<br>
-base/gxi12bit.c<br>
-base/sdcparam.c<br>
-base/strmio.c<br>
-devices/gdevcdj.c<br>
-devices/gdevlp8k.c<br>
-devices/gdevphex.c<br>
-devices/gdevxalt.c<br>
-devices/gdevxcf.c<br>
-devices/rinkj/evenbetter-rll.c<br>
-devices/rinkj/rinkj-epson870.c<br>
-devices/vector/gdevpdfk.c<br>
-devices/vector/gdevpsds.c<br>
-psi/imain.c<br>
-psi/zfont.c<br>
-xps/xpscff.c<br>
-xps/xpsfont.c<br>
-xps/xpsglyphs.c<br>
-xps/xpsgradient.c<br>
-xps/xpstile.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 11:53:44 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8db551f3a3e949035889fcb63188764ca61ab8c1">8db551f3a3e949035889fcb63188764ca61ab8c1</a>
-<blockquote>
-<p>
- Squash warnings: Warnings caused by printf specifiers.<br>
-<br>
-base/gdevnfwd.c<br>
-base/gscspace.c<br>
-base/gsicc_cache.c<br>
-base/gsicc_manage.c<br>
-base/gsmchunk.c<br>
-base/gstrans.c<br>
-base/gxclrect.c<br>
-base/gxpflat.c<br>
-base/scfd.c<br>
-devices/vector/gdevpsft.c<br>
-psi/igc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2016-01-04 11:43:51 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6e628ac44909dd2a0fc738eaa491d92a6e4c1db0">6e628ac44909dd2a0fc738eaa491d92a6e4c1db0</a>
-<blockquote>
-<p>
- Squash Warnings: Simple unused variable warnings.<br>
-<br>
-base/gdevflp.c<br>
-base/gdevoflt.c<br>
-base/gscoord.c<br>
-base/gsptype1.c<br>
-base/gxclist.c<br>
-contrib/japanese/gdev10v.c<br>
-devices/gdevcmykog.c<br>
-devices/gdevgprf.c<br>
-devices/gdevijs.c<br>
-devices/gdevplan.c<br>
-devices/gdevpsd.c<br>
-jpeg/jcsample.c<br>
-psi/zicc.c<br>
-xps/xpsjxr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-31 08:34:09 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=95a16466806c9f8c4f783fd6ebfb0095b9227f56">95a16466806c9f8c4f783fd6ebfb0095b9227f56</a>
-<blockquote>
-<p>
- Squash warning: remove unused variable.<br>
-<br>
-base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-31 16:13:19 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=df47d1bfc3f5d3bf5c58660b98840f3c9a6b6018">df47d1bfc3f5d3bf5c58660b98840f3c9a6b6018</a>
-<blockquote>
-<p>
- Avoid some warnings in the stroking code.<br>
-<br>
-base/gxstroke.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-31 02:40:39 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=27ab71451562b815d04e71903c1feb223069c0a2">27ab71451562b815d04e71903c1feb223069c0a2</a>
-<blockquote>
-<p>
- Bug 697822: clist fix<br>
-<br>
- When saving/restoring the clist state around the saved pages<br>
- processing, ensure that the file handling is correct. Leaving<br>
- the old filenames in play in particular is a bad thing, as the<br>
- shared fdesc stuff gets confused by this.<br>
-<br>
- This commit reworks that so that clist files aren't closed/reopened<br>
- as much.<br>
-<br>
-base/gxclpage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-31 02:39:10 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f920cb3d90603df9c5f48df007ef10750f2427ff">f920cb3d90603df9c5f48df007ef10750f2427ff</a>
-<blockquote>
-<p>
- Bug 695822: clist fix<br>
-<br>
- When reading from the cfile, if we fail to read a cmd_block,<br>
- give up as nothing else will make sense.<br>
-<br>
-base/gxclread.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-31 02:37:31 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=87d413205bd948d302345004092ed43f9b6bc213">87d413205bd948d302345004092ed43f9b6bc213</a>
-<blockquote>
-<p>
- Bug 695822: clist fix<br>
-<br>
- If we rewind a page, ensure that the 'end_pos' for the bfile is<br>
- reset to 0.<br>
-<br>
-base/gxclist.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-31 02:36:52 -0800
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7c67185c0f428f2cec5a8bb339e8917ee3f6584e">7c67185c0f428f2cec5a8bb339e8917ee3f6584e</a>
-<blockquote>
-<p>
- Trivial whitespace fix in clist comment.<br>
-<br>
-base/gxclfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-28 13:22:35 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=834afc272d0df4dc09b1f24ac4366afa26de48b2">834afc272d0df4dc09b1f24ac4366afa26de48b2</a>
-<blockquote>
-<p>
- Bug 693777: Valgrind indeterminism.<br>
-<br>
- Valgrind reports an indeterminism in gs_image_class_1_simple,<br>
- caused by penum-&gt;map[0].inverted not being set.<br>
-<br>
- Analysis reveals that image_init_colors is not setting .inverted<br>
- in some cases. The fix is simply to ensure that it's always set.<br>
-<br>
-base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-27 09:51:24 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34ccb87a69ed6e632468e495a54ecb69bf9f5719">34ccb87a69ed6e632468e495a54ecb69bf9f5719</a>
-<blockquote>
-<p>
- pdfwrite - remove some debugging code causing a compiler warning<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-24 17:18:09 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d4056b5dab63199d86c8fb140807b9b307a427c0">d4056b5dab63199d86c8fb140807b9b307a427c0</a>
-<blockquote>
-<p>
- pdfwrite - implement Metadata pdfmark and a non-standard extension metadata pdfmark<br>
-<br>
- Bug #696472 &quot;pdfwrite lacks support for /Metadata pdfmark&quot;<br>
-<br>
- There are several issues tackled in this single commit:<br>
-<br>
- 1) A previous commit left it impossible to use the EMBED pdfmark unless<br>
- producing PDF/A, fixed.<br>
-<br>
- 2) The Metadata pdfmark is now implemented. This allows the user to<br>
- specify an XMP stream which will be written to the Catalog of the PDF<br>
- file. The pdfwrite device will not overwrite this, or add any further<br>
- Metadata, it is the user's responsibility to get the XMP data correct.<br>
-<br>
- 3) A new pdfmark 'Ext_Metadata' has bee defined. This takes a string<br>
- parameter which contains XML to be add to the XMP normally created by<br>
- pdfwrite. Again ths is up to the user to specify correctly.<br>
-<br>
- In no case does pdfwrite attempt to validate the data, though it will<br>
- issue warnings that PDF/A and PDF/X files may not be valid.<br>
-<br>
- The additional pdfmark is to support creation of the ZugFERD electronic<br>
- invoice (http://www.ferd-net.de/front_content.php?idcat=231&amp;changelang=4)<br>
- and potentially other similar formats in the future.<br>
-<br>
- These new features are essentially untested.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfe.c<br>
-devices/vector/gdevpdfm.c<br>
-devices/vector/gdevpdfx.h<br>
-doc/Ps2pdf.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-23 14:11:47 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=21bd4941bafcd55064ba70acf1af66117e1267bd">21bd4941bafcd55064ba70acf1af66117e1267bd</a>
-<blockquote>
-<p>
- Documentation - sterner words on use of PDFSETTINGS<br>
-<br>
- Many people use the 'PDFSETTINGS' switch without, aopparently, comprehending<br>
- that this will involve some alteration to the input. In addition there<br>
- seems to be a belief that '/prepress' will produce the best (ie closest<br>
- to the original) output, which is absolutely not the case. The best<br>
- quality is obtained by leaving pdfwrite alone.<br>
-<br>
- I doubt it will make any difference, since so many people use a cargo cult<br>
- approach to Ghostscript command line parameters, but at least it is now<br>
- in the documentation.<br>
-<br>
-doc/Ps2pdf.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-23 12:30:12 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e55a2b097f17846a23d0454302f7950d83baca9c">e55a2b097f17846a23d0454302f7950d83baca9c</a>
-<blockquote>
-<p>
- pdfwrite - If downsampling filter initialisation fails, don't downsample<br>
-<br>
- If the image downsampling filter failed during initialisation we still<br>
- carried on and set up to downsample (we ignored the error return). This<br>
- would later result in a further error, and we would try to fall back<br>
- using the default image code. However, that would again try to set up<br>
- the downsampling filter, and would again fail, resulting in the image<br>
- being dropped from the output.<br>
-<br>
- Here we check the return code from image initialisation, and if it fails<br>
- we emit a warnign and stop trying to do downsampling.<br>
-<br>
-devices/vector/gdevpsdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-23 12:27: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=8f7f0dc6616762ee14437265ec8f10bef4094a95">8f7f0dc6616762ee14437265ec8f10bef4094a95</a>
-<blockquote>
-<p>
- pdfwrite - fix mono image downsampling for /prepress setup<br>
-<br>
- The /prepress PDFSETTING had the monochrome image downsampling set to<br>
- /Bicubic. This is not appropriate for monochrome images, as it would<br>
- require converting the image to to grayscale.<br>
-<br>
- The same is true for all downsampling methods except /Subsample, so<br>
- here we alter the setting to /Subsample, which matches the other settings.<br>
-<br>
-Resource/Init/gs_pdfwr.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-22 17:21:37 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd43cb649f5772096b71c23f1bf36982531b74fa">dd43cb649f5772096b71c23f1bf36982531b74fa</a>
-<blockquote>
-<p>
- Bug 694970: Improve downscaler docs.<br>
-<br>
- Mention the explicit limit for DownScaleFactor.<br>
-<br>
- There is no point in downscaling by more than 8, as any given<br>
- pixel ceases to contribute enough to make a difference.<br>
-<br>
- At any rate, any downscale scale &gt;= 12 runs the risk of overflowing<br>
- the 32bit integers used to do the sum.<br>
-<br>
-doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-22 13:42:04 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0fd77514b93367aafaddfa3138f2b8424c7f7085">0fd77514b93367aafaddfa3138f2b8424c7f7085</a>
-<blockquote>
-<p>
- Documentation - Note that the pdfwrite option PDFA now allows values up to 3<br>
-<br>
-doc/Ps2pdf.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-22 13:35:48 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8555f7fd1500322ab6e5b2ab979eb233623c232d">8555f7fd1500322ab6e5b2ab979eb233623c232d</a>
-<blockquote>
-<p>
- pdfwrite - permit creation of PDF/A-3 files, disable file embedding if PDFA &lt; 2<br>
-<br>
- Bug #696473 &quot;feature request: PDF/A-3 support&quot;<br>
-<br>
- There is actually very little practical difference between a PDF/A-2<br>
- and a PDF/A-3 file, PDF/A-3 permits embedding of arbitrary files<br>
- while PDF/A-2 does not.<br>
-<br>
- Prior to commit a91d2576df0e60f6e691a3bd967b51109ae41f22 which<br>
- added support for the EMBED pdfmark there was therefore no point in<br>
- PDF/A-3 output.<br>
-<br>
- This commit allows the -dPDFA switch to be turned up to 3 and creates<br>
- appropriate metadata. It also disables the EMBED pdfmark when creating<br>
- PDF/A-1 and emits a warning for PDF/A-2 that we don't validate the<br>
- content (PDF/A-2 only permits inclusion of PDF/A-1 and PDF/A-2). The<br>
- precise behaviour depends on the setting of PDFACompatibilityPolicy.<br>
-<br>
- I can't claim this is well tested.<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-devices/vector/gdevpdfm.c<br>
-devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-18 16:14:31 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=50cb214c0223d12c891cbab8e5d337975b6f3cba">50cb214c0223d12c891cbab8e5d337975b6f3cba</a>
-<blockquote>
-<p>
- Move Memento include back into jbig2_priv.h<br>
-<br>
- It's clearly nicer not to have Memento as part of the external<br>
- interface of jbig2, and this solves bug 696183.<br>
-<br>
- The include has ping ponged back and forth from jbig2.h in the<br>
- past due to problems with the jbig2 allocator field naming.<br>
- We fix that here with a spot of #ifdef/#undef-ery.<br>
-<br>
- We also simplify some of the hackery here. Rather than having<br>
- specific defines such as GSBUILD (meaning 'get memento.h from<br>
- some place that you magically know about') and JBIG_NO_MEMENTO<br>
- (meaning 'just ignore memento.h at all'), we now just have<br>
- JBIG_EXTERNAL_MEMENTO_H.<br>
-<br>
- Projects which have their own version of Memento in, and use<br>
- jbig2dec should define JBIG_EXTERNAL_MEMENTO_H to the location<br>
- of the memento.h file at build time.<br>
-<br>
-base/jbig2.mak<br>
-jbig2dec/jbig2.c<br>
-jbig2dec/jbig2.h<br>
-jbig2dec/jbig2_priv.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-18 14:03:06 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6f57908e88674a1582e87043f79dc8a1c04ce55f">6f57908e88674a1582e87043f79dc8a1c04ce55f</a>
-<blockquote>
-<p>
- PDF interpreter - reword warnings<br>
-<br>
- Marcos has complained on customer's behalf on a number of occasions<br>
- that we don't use the word 'error' very much when fixing broken PDF<br>
- files leading to unrealistic expectations from the customer.<br>
-<br>
- This commit breaks the errors and warnings up into two distinct groups;<br>
-<br>
- Warnings are now uncommon and are reserved for situations where it seems<br>
- unlikely to me that the problem will result in a rendering error. For<br>
- example, any problems processing ToUnicode CMaps are now treated as<br>
- warnings since these are not used in rendering.<br>
-<br>
- Anything which I feel has a reasonable chance of indicating a problem<br>
- with the PDF file sufficiently serious to result in a difference between<br>
- our output and Acrobat is now flagged as an error.<br>
-<br>
- Each message should explicitly use the word error or warning as<br>
- appropriate, to avoid any confusion.<br>
-<br>
- The end of job notifications differ slightly between errors and<br>
- warnings (errors state again that the output may be incorrect). This<br>
- potentially allows us to take additional different action in the future<br>
- as errors and warnings are tracked separately (NB errors trump<br>
- warnings, if you get an error, you get he error EOJ message)<br>
-<br>
- These notifications now also obey QUIET, so they won't be show if this is<br>
- set.<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>2015-12-17 14:33:22 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f8803ba7066e3be8a627e62eb1406c21c604c639">f8803ba7066e3be8a627e62eb1406c21c604c639</a>
-<blockquote>
-<p>
- Bug 696142: Sanitise tiffsep separation names.<br>
-<br>
- The existing code 'copies' separation names for printing/using in<br>
- filenames in a very naive way. It essentially blanks out any<br>
- characters unsupported in the filesystem with (or '%') with '_'.<br>
- Top bit set chars are let through unchanged, which causes<br>
- confusion as we now assume that filenames are held internally<br>
- in utf-8 format.<br>
-<br>
- The code is updated here to output such filenames with simple<br>
- %02x style escaping. All characters unsupported in the filesystem<br>
- (or '%', or backspace, or top bit set chars) are escaped.<br>
-<br>
- This leaves us utf-8 safe strings.<br>
-<br>
- The only 'interesting' aspect here is that we have to check for<br>
- whether we need to put '%%' instead of '%' because we might be<br>
- printf-style processing the string later on.<br>
-<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-16 12:24:12 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=47d23e2dfbae8db3b142b70aaef086c1bd6e097d">47d23e2dfbae8db3b142b70aaef086c1bd6e097d</a>
-<blockquote>
-<p>
- Fix for Bug 695074 x11 device encode color<br>
-<br>
- The X11 device can be set up for different bit depths including<br>
- indexed like colors. It could fill its palette when we have<br>
- a small number of possible colors and fail to encode. Really the<br>
- device should not fail the encoding but always return the best<br>
- color that it can. It should not rely upon gs to do any halftoning<br>
- to provide possibly see if another color could be encoded.<br>
-<br>
- With this fix, we try to use a color that is in the existing palette,<br>
- adding a color if it is not available and we have space. If we<br>
- no longer have space we now force the use of the closest color in<br>
- the table.<br>
-<br>
-devices/gdevxcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-16 14:55:01 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c9f24068810f762f2a54d33d7cb8040eff080368">c9f24068810f762f2a54d33d7cb8040eff080368</a>
-<blockquote>
-<p>
- PDF Interpreter - improve performance on files with many xref sections<br>
-<br>
- Bug #696454 &quot;Regression: Performance decrease starting with 002cd5262ccb71010473abfb9069e1fb39f36f12&quot;<br>
-<br>
- The file is very large, and has an extremely large (~700,000 entries)<br>
- xref table with a very large number of sections in it. Normally we<br>
- allocate our internal xref storage as we parse the xref table, each time<br>
- we find a new section we increase the size of an array by the number<br>
- of entries in the section.<br>
-<br>
- If we have a lot of sections, we end up spending a lot of time in the<br>
- memory management, allocating, copying and freeing arrays. This was less<br>
- of a problem when we used a 2D array because each array had a maximum of<br>
- 65535 entries. However now that we use a single array this can be time<br>
- consuming.<br>
-<br>
- The first part of this commit searches the trailer dictionaries (stored<br>
- after the xref) looking for the /Size entry. If we find one we use that<br>
- to set the initial size of the xref array. This saves us having to resize<br>
- the array as the Size is large enough to contain all entries.<br>
-<br>
- However, this file *also* has an error in its /Size entry. It declares<br>
- the /Size as 88693, whereas in fact the xref contains nearly 700,000<br>
- entries. Our code still worked, but it was again spending a great deal<br>
- of time in memory management.<br>
-<br>
- So the second part of this commit detects the fact that the declared<br>
- /Size is incorrect. When this happens, instead of allocating just<br>
- enough new entries in the array for the section we have discovered we<br>
- allocate 65534 entries, which makes it more likely that subsequent<br>
- sections will not need to increase the size again.<br>
-<br>
- This is slightly wasteful of memory as we allocate storage we will never<br>
- use, but since the file is invalid it seems better to do this than<br>
- spend a lot of time minimising memory usage.<br>
-<br>
- In my cluster tests this seems to give a small performance improvement<br>
-<br>
- No other differences expected.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-15 11:34:12 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8a5802e5c99959032ccd1763861effbd30dad440">8a5802e5c99959032ccd1763861effbd30dad440</a>
-<blockquote>
-<p>
- PDF interpreter - improved recovery encountering broken fonts<br>
-<br>
- Bug #696306 &quot;Incomplete rendering of PDF file&quot;<br>
-<br>
- The original commit to fix this 487ed6d3b5fabbe21c23da288fbf020f49a28fae<br>
- did resolve the problem, however it was replaced with a better (better<br>
- in terms of correct PostScript error handling)<br>
- 243614398b7bf3e8c4d080de7f8bbcb7436472cf<br>
-<br>
- Unfortunately I only tested that with a decompressed file from MuPDF,<br>
- rather than the original file, and this failed with an additional<br>
- problem in the original file.<br>
-<br>
- The file has a font stream which is ASCIIHex encoded, but contains,<br>
- at the end, some non-ASCIIHex characters (specifically a Q) which<br>
- causes an error in the ASCIIHexDecode before we even try to execute<br>
- the font (which is also damaged).<br>
-<br>
- The commit to fix this fixed the handling of the broken font, but did<br>
- not work correctly with the invalid ASCIIHex stream. The problem was<br>
- that the font code returns a null object (instead of a font dictionary)<br>
- but does not signal an error. This means that the code for recovering<br>
- the operand and dictionary stacks did not execute, leaving the dict<br>
- stack in an incorrect state.<br>
-<br>
- This code copies and executes the recovery code so that, even if there<br>
- is no error, we still clean up.<br>
-<br>
- In addition, PDFSTOPONERROR is now honoured in a couple more places when<br>
- we encounter font problems.<br>
-<br>
- Finally I haver altered pdfformaterror to put its output on stdout<br>
- instead of stderr, because this makes debugging much easier (the<br>
- warnings are now interleaved into the PDFDEBUG output for instance).<br>
-<br>
- No differences expected<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-14 13:05:14 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=877655e3ec275accf5cba7cd724ec845fb4cb396">877655e3ec275accf5cba7cd724ec845fb4cb396</a>
-<blockquote>
-<p>
- Coverity 120747: correct a typo in the WOFF C code<br>
-<br>
-base/gstype42.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-14 12:43:05 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a7addfad24879fadb2d44fba25be70ed43ccb163">a7addfad24879fadb2d44fba25be70ed43ccb163</a>
-<blockquote>
-<p>
- Bug 692427: include the ICC code in the Level 2 features<br>
-<br>
- The ICC handling code was pulled in by the PDF interpreter feature, but since<br>
- 9.00 we *always* have an ICC color workflow (even for Postscript). So make<br>
- the Postscript Level 2 core depend on the ICC feature (this should be sufficient<br>
- because we no longer support a pure Level 1 interpreter, and it saves rewriting<br>
- the ICC Postscript code to use only Level 1 + Ghostscript extensions code).<br>
-<br>
-Resource/Init/gs_icc.ps<br>
-psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-14 11:46:15 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=760fcc4243072daa545419f57c0513b3d24a23de">760fcc4243072daa545419f57c0513b3d24a23de</a>
-<blockquote>
-<p>
- Use sdct.dev in non-autotools builds, too.<br>
-<br>
- And fix a typo from previous commit<br>
-<br>
-base/lib.mak<br>
-base/unix-gcc.mak<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-14 14:26:55 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a3cc9ea512025960b68deca87170053e43393dbc">a3cc9ea512025960b68deca87170053e43393dbc</a>
-<blockquote>
-<p>
- PDF interpreter - handle (invalid) PS CMap streams<br>
-<br>
- Bug #696449 &quot;Incomplete rendering of PDF file&quot;<br>
-<br>
- The file includes a CIDFont which uses a custom CMap, which is incorrectly<br>
- defined. CMaps in PDF files are specified to be a CMap stream, that is a<br>
- dictionary declaration followed by a stream of data. The dictionary<br>
- should contain the CMApName, the CIDSystemInfo and WMode.<br>
-<br>
- The supplied file has a stream which is simply a PostScript CMap, it<br>
- does not include any of the required definitions, and is, as far as I can<br>
- see, therefore invalid.<br>
-<br>
- Nevertheless 'Acrobat can open it', so I've modified the type 0 font<br>
- and more specifically the CMap interpretation, to read a PostScript<br>
- CMap. This is not as easy as it may seem, and there may still be<br>
- problems with this code, because PostScript CMap files are normally<br>
- (unsurprisingly) run in a PostScript interpreter. Trying to handle them<br>
- without executing them in a PostScript interpreter is tricky. We can't<br>
- simply execute the PostScript (which would be ideal) because we need to<br>
- alter the CMAP Type.<br>
-<br>
- This commit also contains a minor change to make Annotation processing<br>
- check the PDFSTOPONERROR flag when running annotations, and if it is set<br>
- cease processing, instead of ignoring the error.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-14 10:31:56 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=18e58518812980b09215ae17b8c385cdb46fda19">18e58518812980b09215ae17b8c385cdb46fda19</a>
-<blockquote>
-<p>
- JPEG/DCT dependency fix<br>
-<br>
- Because we have common code to handle certain aspects of JPEG/DCT encoding and<br>
- decoding, we cannot include one without the other.<br>
-<br>
- Add a &quot;top level&quot; sdct.dev which includes both sdcte.dev and sdctd.dev and make<br>
- that part of the core graphics lib features.<br>
-<br>
- As our code and the libjpeg code both have considerable common code between<br>
- encoding and decoding, the inpact on the executable size is negligible.<br>
-<br>
-Makefile.in<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-11 14:02:24 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1dccf1916e1227e66ffdfbbd0d99c385268f60db">1dccf1916e1227e66ffdfbbd0d99c385268f60db</a>
-<blockquote>
-<p>
- Bug 695576: tidy up xpsprint dependency confusion<br>
-<br>
- Promote the pushing of jobs into the XPS print queue to be a &quot;platform&quot;<br>
- feature - i.e. make it a required &quot;gp_&quot; call, with a real one for Windows<br>
- (when supporting libs are available) and a dummy for when an XPS print queue<br>
- is not available.<br>
-<br>
- This eases the confusion of dependencies and removes the need for platform<br>
- specific conditionally compiled code in the xpswrite device code.<br>
-<br>
-base/gp.h<br>
-base/gp_nxpsprn.c<br>
-base/gp_wxpsprn.cpp<br>
-base/lib.mak<br>
-base/macos-mcp.mak<br>
-base/openvms.mak<br>
-base/unix-aux.mak<br>
-base/winlib.mak<br>
-base/winplat.mak<br>
-base/xpsprint.cpp<br>
-devices/vector/gdevxps.c<br>
-psi/os2.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-11 12:02:41 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fabc4fb245306177204bf9439424cca33132b6fa">fabc4fb245306177204bf9439424cca33132b6fa</a>
-<blockquote>
-<p>
- PDF interpreter - fix OutputIntent for device when no Trailer located in PDF (broken)<br>
-<br>
- Bug #696447 &quot;Error message lost with x11 device&quot;<br>
-<br>
- Despite the comment, I believe the X11 device behaviour is correct. We<br>
- generally try not to throw PostScript errors when dealing with PDF files,<br>
- even badly broken PDF files.<br>
-<br>
- In this case the PDF is so broken we are unable to repair it (Acrobat<br>
- can't either), which means we have no Trailer either found or created.<br>
- However, we must continue with our processing loop and that includes<br>
- processing OutputIntents, if the device supports them.<br>
-<br>
- The X11 device (and the Windows display device amongst others) do *NOT*<br>
- support an OutputIntent (its not file based so there's nowhere to put it)<br>
- but the ppmraw device, erroneously I believe, does claim to be able to<br>
- write an OutputIntent.<br>
-<br>
- This led us into code in writeoutputintents whcih attempted to use the<br>
- Trailer without checking if it was present, and so throwing an error.<br>
-<br>
- This commit simply checks if we have a Trailer, and doesn't attempt to<br>
- write the OutputIntent if we don't (because the PDF is unusable anyway)<br>
-<br>
-<br>
- This makes the devices behave the same, even though its not exactly<br>
- the fix Marcos wanted.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-11 11:02:14 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e8a5151dcc3a3451a42a294ed7bddbf137ddf518">e8a5151dcc3a3451a42a294ed7bddbf137ddf518</a>
-<blockquote>
-<p>
- Bug 696446: only use const strings for param list keys<br>
-<br>
- The original fix replaced uses of strdup() (which caused a memory leak) with<br>
- a dynamically allocated temporary string which was freed at the end of<br>
- cups_get/put_params().<br>
-<br>
- Unfortunately, as param lists simply take a reference to the key string, this<br>
- meant that the contents of the string were overwritten, and indeterminate<br>
- after being freed.<br>
-<br>
- Switch to using lists of static const strings.<br>
-<br>
- And add a stern warning to gsparams.h on the subject.<br>
-<br>
- And squash a couple of compiler warnings in the cups code.<br>
-<br>
-base/gsparam.h<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-10 16:11:30 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=546d49f920ed3b1d7f8eec26ae1c8d94b7d6fd32">546d49f920ed3b1d7f8eec26ae1c8d94b7d6fd32</a>
-<blockquote>
-<p>
- PDF interpreter - don't store ICCBased colour spaces in resolved dicts<br>
-<br>
- Bug #696439 &quot;unable to extract page one special page&quot;<br>
-<br>
- The page in question has nearly 2000 images, most in ICCbased colour<br>
- spaces, and large profiles (around 2MB or more). Because of the way we<br>
- dereference objects, this led to the ICCbased DataSource (the 2MB+)<br>
- being stored in the colour space, which was stored in the image<br>
- dictionaries, which were stored in the Page's Resources dicttionary.<br>
-<br>
- The Page's Resources dictionary is not freed until the page is complete<br>
- which meant we were storing an awful lot of data. When we exceeded 2GB<br>
- (on the 32 bit build) we ran out of memory and mostly stopped rendering<br>
- anything further.<br>
-<br>
- This commit alters the image (and shading, which has the same problem)<br>
- handling so that if the colour space is an array object, we make a copy<br>
- of the dictionary and use that. This leaves the original definition<br>
- unresolved in the Page's Resources dictionary, if we should need to use<br>
- the object again then we will have the (slight) overhead of needing to<br>
- rerun it, but at least we won't be storing gobs of mostly useless data<br>
- in the general case.<br>
-<br>
- No differences expected.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-12 18:37: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=bcf0e5887c74e3337fcac62addf0de70be9a2cb8">bcf0e5887c74e3337fcac62addf0de70be9a2cb8</a>
-<blockquote>
-<p>
- Commit of WOFF font support for GS<br>
-<br>
- Support in Ghostscript is implemented by augmenting the TrueType handling in<br>
- the Postscript world. Loading WOFF fonts &quot;stripped&quot; is not supported, except<br>
- for the purpose of finding the font name from the name table.<br>
-<br>
- There is also a C implementation in the graphics library which takes a memory<br>
- buffer or a stream, and unpacks the WOFF into a TTF in a memory buffer. It<br>
- is currently not called.<br>
-<br>
-Resource/Init/gs_cff.ps<br>
-Resource/Init/gs_cidtt.ps<br>
-Resource/Init/gs_ttf.ps<br>
-base/gstype42.c<br>
-base/gsutil.c<br>
-base/gsutil.h<br>
-base/gxfont42.h<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-09 18:09:12 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=618d0c07922e47b869cdec48235ff003c791d2e3">618d0c07922e47b869cdec48235ff003c791d2e3</a>
-<blockquote>
-<p>
- Bug 696441: handle numcopies &gt; 1 in bgprint mode.<br>
-<br>
- When numcopies is greater than 1, the device closes and closes and opens<br>
- the output file(s) for each copy. In the case of background printing, the<br>
- main device opens the output file, and generally expects to close the same<br>
- file, but with num_copies &gt; 1 that is not the case.<br>
-<br>
- When shutting down a bgprint &quot;worker&quot; device, copy the file pointer from<br>
- the worker device to the main device, so the main device retains a valid<br>
- output file pointer.<br>
-<br>
-base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-04 15:47: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=47dd8a92aeb7b574748871127a6621ce9f7abbb9">47dd8a92aeb7b574748871127a6621ce9f7abbb9</a>
-<blockquote>
-<p>
- Fix memory leaks in cups device<br>
-<br>
- Noticed while debugging Bug 694179.<br>
-<br>
- The main leak here is due to the strdup in cups_get_params and cups_put_params.<br>
- The code was then refactored to have one exit point to catch the remaining<br>
- 6K leak.<br>
-<br>
- However, the final 6k is due to the global structure created in<br>
- cups_globals_alloc and later freed in cups_globals_free. The free function<br>
- call is only done on windows due to a #define WIN32 and not called on a<br>
- Linux machine where the server continues to run.<br>
-<br>
- No cluster differences<br>
-<br>
-cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-04 15:42:53 +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=160665445b3b10da794959e508b5dd800b0592e5">160665445b3b10da794959e508b5dd800b0592e5</a>
-<blockquote>
-<p>
- Bug 694179: Fix memory leak in jbig2dec<br>
-<br>
- Ensure the image contents are initialised, so that, if an error occurs, the<br>
- image can be safely cleaned up.<br>
-<br>
- No cluster differences.<br>
-<br>
-jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-23 20:35:09 +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=24c38f914a24391f880e2fd73423dff9cc9a678f">24c38f914a24391f880e2fd73423dff9cc9a678f</a>
-<blockquote>
-<p>
- Bug 694180: Fix memory leak if there is an error while parsing jbig2 global stream.<br>
-<br>
-base/sjbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-04 17:46:33 -0500
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb89b8a3a9f58898402750dbcef43156e54d0118">fb89b8a3a9f58898402750dbcef43156e54d0118</a>
-<blockquote>
-<p>
- Bug 695771: multithread/bgprint render may not be complete device shutdown<br>
-<br>
- In some cleanup code, I assumed that by the time that code was called, rendering<br>
- would be complete - specifcally, background rendering would be complete.<br>
-<br>
- This may be true when background rendering is one thread, but is definitely not<br>
- guaranteed when we have bgprint *and* multithreaded rendering.<br>
-<br>
- Rather nicely, accounting for this actually makes the code tidier.<br>
-<br>
- Also, add a check that we successfully created a clist IFILE object before<br>
- storing a value in it.<br>
-<br>
-base/gdevprn.c<br>
-base/gxclfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-04 21:29:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=80539e002a8a2feed7a1d34608980c3a0d13dbbc">80539e002a8a2feed7a1d34608980c3a0d13dbbc</a>
-<blockquote>
-<p>
- pdfwrite - fix array dta source mesh shadings<br>
-<br>
- Bug #696433 &quot;Indeterminism with Bug695847b.ps and the pdfwrite device&quot;<br>
-<br>
- The code for emitting a mesh shading in a PDF given floating point<br>
- input (array based vertex data, at least) calcul;ates the number of<br>
- colour samples by multiplying the number of componentsd in the colour<br>
- space by the number of vertices.<br>
-<br>
- However, when applying the max/min clamping from the ranges array in the<br>
- colour space, it used the current colour sample index, which obviously<br>
- could be much larger than the number of components in the colour space.<br>
-<br>
- This caused us to run off the end of the pranges array and use<br>
- uninitialised data to set the colour sample, leading to non-deterministic<br>
- (and indeed incorrect) output.<br>
-<br>
- We now pass in the number of components in the colour space and use the<br>
- modulus of that with the colour value index to index the pranges array.<br>
-<br>
-devices/vector/gdevpdfv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-01 16:47:47 -0500
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=17e2a278e9a4adfd534941813075e428f3ea7966">17e2a278e9a4adfd534941813075e428f3ea7966</a>
-<blockquote>
-<p>
- Make writing TIFF DateTime tag optional.<br>
-<br>
- Add a -dTIFFDateTime option, defaults to &quot;true&quot; (existing behaviour) and<br>
- -dTIFFDateTime=false prevents the tag being written to the output file.<br>
-<br>
- Also, document this and the UseBigTIFF option.<br>
-<br>
-devices/gdevtfax.c<br>
-devices/gdevtfnx.c<br>
-devices/gdevtifs.c<br>
-devices/gdevtifs.h<br>
-devices/gdevtsep.c<br>
-doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-04 17:04:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=44c63aecd4d13f47e0f75e74f63f38715ab7ab73">44c63aecd4d13f47e0f75e74f63f38715ab7ab73</a>
-<blockquote>
-<p>
- EPSFitPage - fix some kinds of rotation<br>
-<br>
- Bug #696128 &quot;Rendering an EPS to a PNG with -dEPSFitPage and -gWxH sometimes results in blank render&quot;<br>
-<br>
- There was a typo in commit d59e1feb9545b399027907cb2d1a6855c524e0b4 which<br>
- prevented proper rotation in some cases. Note that in this particular<br>
- case we do *NOT* want to rotate.<br>
-<br>
-Resource/Init/gs_epsf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-12-04 07:01:38 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4703d04a6146904cab9b1b04aee1478e31df52da">4703d04a6146904cab9b1b04aee1478e31df52da</a>
-<blockquote>
-<p>
- Fix bug 696258: Crash with mswinpr2 device due to typo.<br>
-<br>
- There was a typo in win_pr2_getdc was calling gs_strtok with the &quot;last&quot;<br>
- parameter being a value instead of a pointer to the buffer.<br>
-<br>
-devices/gdevwpr2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-29 18:12:02 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=237f98e6abb42407466240585b897b5190b68053">237f98e6abb42407466240585b897b5190b68053</a>
-<blockquote>
-<p>
- Document that the -c option should be specified after other otions (Bug 695293).<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-27 10:08: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=e1af9ed039398be924e31179e6b742682f49e772">e1af9ed039398be924e31179e6b742682f49e772</a>
-<blockquote>
-<p>
- Bug 689856: CIE cache: account for different sizes of ulong<br>
-<br>
- Handle both 32 bit and 64 bit ulong sizes.<br>
-<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-24 11:52: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=96d5dc98103b6adab46efa4baeb19535675929b8">96d5dc98103b6adab46efa4baeb19535675929b8</a>
-<blockquote>
-<p>
- Docs: Add words about soon removing DisableFAPI<br>
-<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-26 20:03:23 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5596cc435aec8387ddd2e64437f1f9486f3ee5c6">5596cc435aec8387ddd2e64437f1f9486f3ee5c6</a>
-<blockquote>
-<p>
- Fixed call to Luratech JP2_Compress_SetLicense() (Bug 695768).<br>
-<br>
- The Luratech JP2_Decompress_SetLicense() routine was being called instead<br>
- of JP2_Compress_SetLicense() in the compression section. Thanks for<br>
- Rodrigo Terra for the finding this.<br>
-<br>
- Untested since Ghostscript doesn't use this code.<br>
-<br>
-base/sjpx_luratech.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-24 16:54:55 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d8ee66a742b9dbc006dd69e6049d9acfef4ad89f">d8ee66a742b9dbc006dd69e6049d9acfef4ad89f</a>
-<blockquote>
-<p>
- xps: Fix warnings.<br>
-<br>
-xps/xpspath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-24 13:10:48 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=86a2f29eddb0addaa1c72bd7967748083fb6be3c">86a2f29eddb0addaa1c72bd7967748083fb6be3c</a>
-<blockquote>
-<p>
- xps: Multiply alpha from opacity attribute with alpha from color attribute.<br>
-<br>
-xps/xpsglyphs.c<br>
-xps/xpspath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-24 13:02:09 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b4393aa83107a484cafc59241eac964fc5a6e560">b4393aa83107a484cafc59241eac964fc5a6e560</a>
-<blockquote>
-<p>
- xps: Support AlternateContent compatibility markup.<br>
-<br>
-xps/ghostxps.h<br>
-xps/xpscommon.c<br>
-xps/xpspage.c<br>
-xps/xpsxml.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-20 12:51:09 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=286433913eeaa01d53e5225b524afb56039cdde8">286433913eeaa01d53e5225b524afb56039cdde8</a>
-<blockquote>
-<p>
- xps: Fix potential memory leak.<br>
-<br>
-xps/xpspage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-20 12:50:52 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ab039de8626a3052483aeb806186aaa4079e925">7ab039de8626a3052483aeb806186aaa4079e925</a>
-<blockquote>
-<p>
- xps: Add more warning messages.<br>
-<br>
-xps/xpsdoc.c<br>
-xps/xpstile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-19 15:10:36 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ea84e45f743381e2b47d94a3718a400904ba45f">7ea84e45f743381e2b47d94a3718a400904ba45f</a>
-<blockquote>
-<p>
- xps: Avoid generating unnecessary linetos for arcs.<br>
-<br>
-xps/xpspath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-19 11:38:55 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cba41adae8a388156f8e4eae29cbf1cd5a61cd1e">cba41adae8a388156f8e4eae29cbf1cd5a61cd1e</a>
-<blockquote>
-<p>
- xps: Avoid ctype.h<br>
-<br>
-xps/xpsglyphs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-19 11:34:14 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=40e2a79e7e4c223c4219b12020fde906df5fd91e">40e2a79e7e4c223c4219b12020fde906df5fd91e</a>
-<blockquote>
-<p>
- xps: Use xps_strlcpy instead of strcpy when parsing colors.<br>
-<br>
-xps/xpscolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-17 16:54:23 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=100dff645dbb231de77e7b2f347a459490213bef">100dff645dbb231de77e7b2f347a459490213bef</a>
-<blockquote>
-<p>
- xps: Check that we have the last piece of multi-part zip entries.<br>
-<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-12 16:57:45 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef0b983d909787c0a2ace46f61993af84ec32f66">ef0b983d909787c0a2ace46f61993af84ec32f66</a>
-<blockquote>
-<p>
- xps: Add special case handling of zero-length dash patterns.<br>
-<br>
-xps/TODO<br>
-xps/xpspath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-18 15:43:40 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0833727c2a2e23daefd2721f64d7fb9e02ee3049">0833727c2a2e23daefd2721f64d7fb9e02ee3049</a>
-<blockquote>
-<p>
- xps: Bail on zip errors instead of returning a part full of garbage.<br>
-<br>
-xps/xpsimage.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-18 15:36:57 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=15a26a58d1cedf0ab2ad7a968ea2ac5a58e48842">15a26a58d1cedf0ab2ad7a968ea2ac5a58e48842</a>
-<blockquote>
-<p>
- xps: Fix uninitialized value.<br>
-<br>
-xps/xpspath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-13 16:33:42 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b91a3627f29ab0c831a56bc5585a5895398279e">7b91a3627f29ab0c831a56bc5585a5895398279e</a>
-<blockquote>
-<p>
- xps: Various arithmetic and uninitialized value fixes.<br>
-<br>
-xps/xpsgradient.c<br>
-xps/xpsimage.c<br>
-xps/xpspath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-23 08:05:58 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ac252acf1dec30c24bbba9adfc3140fb23a41d7b">ac252acf1dec30c24bbba9adfc3140fb23a41d7b</a>
-<blockquote>
-<p>
- Tidy up a few comments.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-23 07:24:49 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=65ad11d96a83783a71e9e0a2ff8534bf0cdd9864">65ad11d96a83783a71e9e0a2ff8534bf0cdd9864</a>
-<blockquote>
-<p>
- Fix the gs library context's allocator use.<br>
-<br>
- The gs library context now uses the allocator with which it was<br>
- initialized for all memory operations. Previously it used different<br>
- allocators, resulting in mismatched alloc/free pairs. For example, the<br>
- languages passed in a memory pointer to the heap allocator upon<br>
- initialization of the context and then passed in a memory pointer to chunk<br>
- allocator when the library context is shut down.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-20 13:56:33 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c8bc794d9e9fe9c03d1519cf2a70f70a2d0784d8">c8bc794d9e9fe9c03d1519cf2a70f70a2d0784d8</a>
-<blockquote>
-<p>
- Improve documentation and fixup toolbin/halftone tools<br>
-<br>
- The thresh_remap (previously referred to as linearize_threshold) was<br>
- never in the package, so add it in a separate directory, and fix the<br>
- reference to it in gen_ordered.c<br>
-<br>
- Add README files for the upper level, for thresh_remap and for the<br>
- gen_stochastic directories, so people don't have to read the code to<br>
- find the parameters.<br>
-<br>
- Fix gen_stochastic minimum dot logic to actually work, although only<br>
- the 2x2 (-m5) parameter was tested. Also change the defaults for the<br>
- tolerance, -t, to 10 (1%) and exponential factor affecting choice, -p,<br>
- to 2.5 both of which tighten the selection to improve the quality (at<br>
- least in my opinion).<br>
-<br>
-toolbin/halftone/README<br>
-toolbin/halftone/gen_ordered/gen_ordered.c<br>
-toolbin/halftone/gen_stochastic/README<br>
-toolbin/halftone/gen_stochastic/gen_stochastic.c<br>
-toolbin/halftone/gen_stochastic/gen_stochastic.sln<br>
-toolbin/halftone/gen_stochastic/gen_stochastic.vcproj<br>
-toolbin/halftone/thresh_remap/README<br>
-toolbin/halftone/thresh_remap/thresh_remap.c<br>
-toolbin/halftone/thresh_remap/thresh_remap.sln<br>
-toolbin/halftone/thresh_remap/thresh_remap.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-19 14:16:46 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ecd8816ca46c15da304d6bc93f79f39d47c51952">ecd8816ca46c15da304d6bc93f79f39d47c51952</a>
-<blockquote>
-<p>
- Bug 696363 &amp; 696362: wrong error code return.<br>
-<br>
- The FAPI/UFST code was returning a &quot;limitcheck&quot; error when no glyph raster was<br>
- available, when it should have been &quot;unregistered&quot;.<br>
-<br>
- This caused problems when I added the return code checks to address some<br>
- Coverity warnings.<br>
-<br>
-base/fapiufst.c<br>
-base/gxfapi.c<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-19 14:14:27 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=92f236c7f2293db8aeae437ac0800617552d6e63">92f236c7f2293db8aeae437ac0800617552d6e63</a>
-<blockquote>
-<p>
- Bug 696357: correctly check the length of a string<br>
-<br>
- Indeterminism in 34_all.PS: the check on the size of the string containing the<br>
- font's CIDMap was incorrect leading to reading off the end.<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-16 17:26:56 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0ec425689333b77b9badd8585989e15655d740c1">0ec425689333b77b9badd8585989e15655d740c1</a>
-<blockquote>
-<p>
- Bug 696316: Enforce memory alignment for libpng<br>
-<br>
- libpng's inclusion of it's jmp buffer at the beginning of it's private context<br>
- requires the allocation to be 16 byte aligned on Win64 (because the jmp<br>
- buffer must be 16 byte aligned).<br>
-<br>
- In the libpng callback functions for memory allocationg and freeing enforce<br>
- that alignment.<br>
-<br>
- Also, add those callbacks (including the alignment enforcement) to the gdevpng.c<br>
- output device.<br>
-<br>
- (Code mostly supplied by Robin!).<br>
-<br>
- No cluster differences.<br>
-<br>
-devices/gdevpng.c<br>
-xps/xpspng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-18 10:59: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=d368650e9f3e7e6e4af2d840ffa0dd1e161a9694">d368650e9f3e7e6e4af2d840ffa0dd1e161a9694</a>
-<blockquote>
-<p>
- PDF Interpreter - Handle incorrect /Size in Xref streams<br>
-<br>
- Bug #696365 &quot;Error reading PDF file&quot;<br>
-<br>
- The PDF file is, as usual, invalid. It uses Xref streams and is a<br>
- Linearized file, meaning that there are two Xrefs, the first one being<br>
- for page 1 (caused by Linearization).<br>
-<br>
- This xref looks like ths:<br>
-<br>
- &lt;&lt;<br>
- /Size 12<br>
- /Root 30 0 R<br>
- /Prev 15073<br>
- /Info 28 0 R<br>
- /ID[&lt;B6AEC95A19F1E4391AFF6AF538489730&gt;&lt;B6AEC95A19F1E4391AFF6AF538489730&gt;]<br>
- /Type/XRef/Index[29 39]/W[1 4 1]/Filter /FlateDecode /Length 112<br>
- &gt;&gt;<br>
-<br>
- Notice that the Size (the number of entries in the xref) is given as 12<br>
- but the Index (starting index + number of entries) gives the size of the<br>
- table as 39, starting at index 29.<br>
-<br>
- We were believing the Size, which meant that we created a Xref table<br>
- which was too small to hold the actual number of entries.<br>
-<br>
- This commit checks both 'starting index + number of entries in the Index'<br>
- and 'starting index + Size' and uses the larger.<br>
-<br>
- NB the xref also contains an entry with an invalid offset, but this does<br>
- not seem to cause a problem, presumably the entry is never actually used<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-17 13:34: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=5e8eae05c4629217f87eaab7302ac7b880dd9c7c">5e8eae05c4629217f87eaab7302ac7b880dd9c7c</a>
-<blockquote>
-<p>
- Hash CIE spaces to detect matching, cached, ICC profiles<br>
-<br>
- Bug #696355 &quot;Create unique ID for CIE color spaces&quot;<br>
-<br>
- Creating an ICC profile for a PostScript colour space is a performance<br>
- hit. Especially (I believe) for CIE spaces. We maintain a cache of ICC<br>
- profiles that have been created, but we need a way to identify if a<br>
- given, cached, profile matches a newly selected colour space.<br>
-<br>
- There is code already in place for this, but missing the generation of<br>
- a unique ID for a space, so that we can find a matching profile, if we<br>
- have one cached.<br>
-<br>
- This commit uses the existing MD5 machinery to create a hash from the<br>
- PostScript array defining a CIEBased colour space. We then use that hash<br>
- as the ID for the space, and check to see if we already have a cached<br>
- ICC profile with a matching ID.<br>
-<br>
- This should improve performance on files using CIEBased colour spaces,<br>
- especially if they do 'gsave [/CIEBased &lt;&lt;...&gt;&gt;] setcolorspace grestore'<br>
- operations, as we will only need to create the ICC profile once.<br>
-<br>
- I've created and manually checked example CIEBasedA, CIEBasedABC,<br>
- CIEBasedDEF and CIEBasedDEFG files to see that two identical spaces are<br>
- correctly identified as the same and that spaces with even very tiny<br>
- differences are correctly identified as different.<br>
-<br>
- No differences expected in cluster test.<br>
-<br>
-psi/zcie.c<br>
-psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-16 12:46:18 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=70880b866b06e34e4c078e115001371ae8e9c454">70880b866b06e34e4c078e115001371ae8e9c454</a>
-<blockquote>
-<p>
- Docs: Remove references to OS X framework<br>
-<br>
- No cluster differences<br>
-<br>
-doc/API.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-16 12:30:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ff6175631e7b8c79849d6de637aaaf5338476d62">ff6175631e7b8c79849d6de637aaaf5338476d62</a>
-<blockquote>
-<p>
- Bug 696352: initalise io dev table count variable.<br>
-<br>
- Previously the io device count was only initalised when the library context<br>
- was created, but it seems the library context can survive multiple<br>
- instances of the interpreter.<br>
-<br>
- Initialise the count variable every time a new io device table is created.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/gsiodev.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-16 09:17:19 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5757d87431c31cf99ea294697382239ab74d424e">5757d87431c31cf99ea294697382239ab74d424e</a>
-<blockquote>
-<p>
- graphics library - if pattern x or y size is 0, don't estimate tile size<br>
-<br>
- Inspired by Bug #696351<br>
-<br>
- The bug report in Bug #696351 is ridiculously incomplete and the reporter<br>
- seems determined not to provide any real assistance.<br>
-<br>
- However, by some logic and experimentation it did prove possible to<br>
- (eventually) reproduce the problem and trace through the code from<br>
- pattern creation. (run with a very low resolution, -r10 did it for me)<br>
-<br>
- The crash is caused by attempting to estimate the size of a pattern<br>
- bitmap tile, when the pattern has a size of 0 in the y direction. This<br>
- is a legitimate value, we simply drop the pattern in this case. Since<br>
- we aren't going to render anything, the tile will have a size of 0 so<br>
- we can easily short-circuit all this calculation by testing for the tile<br>
- being 0 in either the x or y direction and simply returning 0.<br>
-<br>
- No differences expected.<br>
-<br>
-base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-13 11:55:20 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e21aae2ee801a6468e44697970d11d4d56d0c6ab">e21aae2ee801a6468e44697970d11d4d56d0c6ab</a>
-<blockquote>
-<p>
- Bug 694237: Handle missing/incomplete TTF glyph lengths<br>
-<br>
- In the case of a broken TTF based CIDFont passing through ps2write (or one of<br>
- the pdfwrite paths that requires glyphs to be rendered), we can end up with<br>
- a partially complete font structure - in particular, the glyph lengths table<br>
- may be incomplete or missing.<br>
-<br>
- We have a couple of fallback options available to get the length of a glyph:<br>
- the first is to retrieve the offset of the data for *next* glyph index and<br>
- the difference between the two offsets is the length of the glyph of interest.<br>
- If that fails (particularly if we are already processing the last available<br>
- glyph), we can use the offset to the end of the sfnt data - since the glyph<br>
- table is invariably the last table in the sfnt stream.<br>
-<br>
- No cluster differences.<br>
-<br>
-psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-13 08:48: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=5aa97eed0f8b17ea0f7138d36d64af505420caa1">5aa97eed0f8b17ea0f7138d36d64af505420caa1</a>
-<blockquote>
-<p>
- Bug 696345: .nativeFontmap when TTF name table is invalid<br>
-<br>
- When building the .nativeFontmap (using fonts retrieved from a platform<br>
- specific API - i.e. fontconfig), if we can't read the font name from the<br>
- font file, we fall back to using the font name as reported by the API.<br>
-<br>
- But, the code failed to take into account that the operand stack has different<br>
- depth depending on whether we were able to read the name from the file or not.<br>
-<br>
- This commit handles that by using a counttomark rather than hard coded stack<br>
- depth.<br>
-<br>
- No cluster differences.<br>
-<br>
-Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-12 17:22: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=dfe06d0d8b3f296b908709c22157f7135ed660c7">dfe06d0d8b3f296b908709c22157f7135ed660c7</a>
-<blockquote>
-<p>
- Bug 694238: init several gs_glyph_info_t structs<br>
-<br>
- In various places we were calling a font's glyph_info which may, or may not<br>
- fully fill in the gs_glyph_info_t passed to it, then using the results,<br>
- regardless of whether the specific value had been set. Initialize to zeros<br>
- for at least consistent results.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/gsfont.c<br>
-devices/gxfcopy.c<br>
-devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-12 17:17: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=01cb2de3fbbcfa7c7f809176bb72249831d93b98">01cb2de3fbbcfa7c7f809176bb72249831d93b98</a>
-<blockquote>
-<p>
- Bug 694238: Fix segfault in error during PatternType 1<br>
-<br>
- If the PaintProc of a Type 1 pattern triggers an error after having done one<br>
- or more gsaves, we'll try to retrieve the pattern instance from the wrong<br>
- graphics state when we attempt the final cleanup.<br>
-<br>
- To address this, store a reference to the pattern instance on the exec stack<br>
- which a) guarantees we get the correct pattern instance during cleanup,<br>
- and b) allows us to roll back the graphics state stack to the correct point.<br>
-<br>
- No cluster differences.<br>
-<br>
-psi/zpcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-13 08:20: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=daf28428a76f3a89a9cff9285cb7b0a663a86b63">daf28428a76f3a89a9cff9285cb7b0a663a86b63</a>
-<blockquote>
-<p>
- Coverity: fix some ignored return codes in FAPI<br>
-<br>
- No cluster differences.<br>
-<br>
-base/gxfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-12 16:25:54 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e85900d1814a65918b9c7e90504e25155ae0b9c1">e85900d1814a65918b9c7e90504e25155ae0b9c1</a>
-<blockquote>
-<p>
- xps: Return with error on encrypted zip files.<br>
-<br>
-xps/ghostxps.h<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-12 16:27:06 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9d1c199af467cd1138bf07c6f66a276e26875c99">9d1c199af467cd1138bf07c6f66a276e26875c99</a>
-<blockquote>
-<p>
- xps: Fix buffer overflow in xps_parse_color.<br>
-<br>
-xps/ghostxps.h<br>
-xps/xpsanalyze.c<br>
-xps/xpscolor.c<br>
-xps/xpsglyphs.c<br>
-xps/xpspath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-12 16:24:30 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0fa7177163f46c77f7928c520ddc3f90de4c59dc">0fa7177163f46c77f7928c520ddc3f90de4c59dc</a>
-<blockquote>
-<p>
- xps: Fix indeterminism with broken zip files.<br>
-<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-12 16:13:05 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b4be4d130b37578be55eb6aae4feb8a57c0636d">9b4be4d130b37578be55eb6aae4feb8a57c0636d</a>
-<blockquote>
-<p>
- xps: Fix gradient ordering edge case.<br>
-<br>
- Gradients in XPS code are ordered by offset. If however two offsets are<br>
- equal, the order of the colors depends on the sort algorithm instead of<br>
- the original order in the document. This is shown e.g. in 2245*.xps:<br>
-<br>
- &lt;GradientStop Offset=&quot;0&quot; Color=&quot;#ff00ff00&quot; /&gt;<br>
- &lt;GradientStop Offset=&quot;0.5&quot; Color=&quot;#ff0000ff&quot; /&gt;<br>
- &lt;GradientStop Offset=&quot;0.5&quot; Color=&quot;#ff00ff00&quot; /&gt;<br>
- &lt;GradientStop Offset=&quot;1&quot; Color=&quot;#ff00ffff&quot; /&gt;<br>
-<br>
- Tracking the original order of gradient stops and always sorting earlier<br>
- stops first makes gradient ordering consistent.<br>
-<br>
-xps/xpsgradient.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-11 16:59:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb56dc645039d5a2f376920af1023b7ece801c88">bb56dc645039d5a2f376920af1023b7ece801c88</a>
-<blockquote>
-<p>
- PDF Interpreter - Ignore empty /Kids arrays in AcroForm fields<br>
-<br>
- Bug #696342 &quot;PDF Annotation Error: /rangecheck in --run--&quot;<br>
-<br>
- The PDF file has an AcroForm with a field where the /Kids array is [ ]<br>
- This previously caused an error.<br>
-<br>
- Adopting the patch from Martin McNabb with a very slight tweak to issue<br>
- a warning if -dQUIET isn't set.<br>
-<br>
- Bizarrely this does exhibit a progression with Bug694429.pdf on the<br>
- cluster, even though this code isn't executed......<br>
-<br>
- Its a progression so I'm not going to complain.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-09 10:33:16 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e174b0553e6e2d3bb641cbede1187dfe7979ae86">e174b0553e6e2d3bb641cbede1187dfe7979ae86</a>
-<blockquote>
-<p>
- PDF interpreter - Allow Shading whose Extend array contains indirect refs<br>
-<br>
- Bug #696338 &quot;Garbled output - File has unbalanced q/Q operators (too many Q's)&quot;<br>
-<br>
- A Shading dictionary contains (bizarrely) an Extend array which has<br>
- members which are indirect references instead of simple booleans.<br>
-<br>
- Mad, but legal.....<br>
-<br>
- This commit adds the Extend array to shrdict, which does additional<br>
- processing of the Shading dictionary before passing to the graphics<br>
- library. In this case we simply dereference the objects.<br>
-<br>
- No differences expected.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-04 16:08:13 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f330b5d4bdae73f9ca88c04e2a1391800c5da758">f330b5d4bdae73f9ca88c04e2a1391800c5da758</a>
-<blockquote>
-<p>
- Fix Bug 696324 SMask None handled incorrectly by clist writing.<br>
-<br>
- The SMask None special case that is sent using gssmask in the PDF<br>
- interpreter when it needs to make sure there is no SMask in place<br>
- needs special handling w.r.t. the clist cropping logic since we do<br>
- want to write it, but there won't be a endtransparencymask to<br>
- perform the pop of the cropping stack.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-02 15:17: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=142820542bb883e304788bd4dcc2833b6486cf6d">142820542bb883e304788bd4dcc2833b6486cf6d</a>
-<blockquote>
-<p>
- Bug 693011: stop PSD devs writing multiple images to one file<br>
-<br>
- PSD does not support multiple pages/images per file. Previously the PSD devices<br>
- would allow writing multiple image to the PSD output file, and end up with an<br>
- invalid PSD file.<br>
-<br>
- The devices will now check what the output name file has the &quot;%d&quot; formatter to<br>
- so each page written to a separate file, and if it isn't there, they will<br>
- generate an error message and error code if an attempt is made to produce<br>
- more than one page.<br>
-<br>
- To be clear: and single page input file will complete without error without the<br>
- &quot;%d&quot; formatter.<br>
-<br>
- No cluster differences<br>
-<br>
-base/gdevdevnprn.h<br>
-devices/devs.mak<br>
-devices/gdevcmykog.c<br>
-devices/gdevpsd.c<br>
-devices/gdevpsd.h<br>
-doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-02 15:16:26 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4c6f80586f047561c5ed4e2f9d3a307c2ca6099f">4c6f80586f047561c5ed4e2f9d3a307c2ca6099f</a>
-<blockquote>
-<p>
- Add Art/Bleed/Trim boxes to pdf_info.ps<br>
-<br>
- No cluster diffs.<br>
-<br>
-toolbin/pdf_info.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-03 19:25:38 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3d2d28598857d94b4c4683fe3ae5a0a71fdfe17d">3d2d28598857d94b4c4683fe3ae5a0a71fdfe17d</a>
-<blockquote>
-<p>
- Bug 696305: Ensure subdivided lines are not dropped<br>
-<br>
- While walking the contour in scan_contour, we use<br>
- gx_flattened_iterator to cope with flattening curves.<br>
- Each time we call gx_flattened_iterator__next we get the<br>
- next section of the line out.<br>
-<br>
- To avoid overflows in huge lines/curves the iterator splits<br>
- segments into 4. This was showing up a problem in this code<br>
- whereby a vertical line from 0x80xxxxxx to 0x7fxxxxxx was<br>
- being split into 4. 2 of these sub-divided lines crossed the<br>
- region of interest, but only the first of them was being<br>
- considered for addition into the active line list.<br>
-<br>
- The fix here is simply to ensure that we continue to loop<br>
- through the iterator for the curve if we fail to add anything<br>
- from it.<br>
-<br>
- It is possible that there are further optimisations possible<br>
- here (see the FIXMEs in the code), but the changes I've made<br>
- should be safe and minimally invasive.<br>
-<br>
- Many thanks to Chris for doing the legwork in tracking the<br>
- cause down!<br>
-<br>
-base/gxfill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-03 13:41:20 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=35148ae2ffd20e949e01da427a82a6eee20b7127">35148ae2ffd20e949e01da427a82a6eee20b7127</a>
-<blockquote>
-<p>
- Bug 696305: Revamp scan_contour<br>
-<br>
- As part of the investigation into bug 696305, rejig the functions<br>
- around 'scan_contour' for clarity.<br>
-<br>
- Firstly, we pull the usage of contour_cursor into scan_contour.<br>
- Rather than having the caller set part of the structure up, and<br>
- then pass it in, have the caller pass in the required parts and<br>
- let all of the structure handling be done within scan_contour.<br>
- This improves the modularity of this code at least.<br>
-<br>
- Secondly, rather than having the contour_cursor structure contain<br>
- a pointer to a gx_flattened_iterator allocated separately on the<br>
- stack, have it be part of the structure. This saves lots of<br>
- dereferencing (which might help with repeated reads due to C's<br>
- pointer aliasing) and is clearer to read.<br>
-<br>
- Thirdly, we break the if's into more deeply nested things. This<br>
- results in more indented code, but it avoids us having to retest<br>
- the same variables several times, and may give us some improvement<br>
- in runtimes.<br>
-<br>
- Firstly, add some comments. This is a break with tradition in<br>
- this code. These comments describe my understanding (however<br>
- limited) it may be of what the code is doing.<br>
-<br>
-base/gxfill.c<br>
-base/gxfill.h<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-03 09:07:27 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7fbc6ddf76a5590252dc25642ae13da15f2a92db">7fbc6ddf76a5590252dc25642ae13da15f2a92db</a>
-<blockquote>
-<p>
- pdfwrite - prevent selection of inappropriate Downsample filter<br>
-<br>
- Bug #696322 &quot; GS produces empty PDF with /MonoImageDownsampleType /Bicubic&quot;<br>
-<br>
- We can't use anything except Subsample for Monochrome images, because<br>
- anything else will turn them into grayscale images.<br>
-<br>
- This commit prevents the selection of any downsampling filter if the<br>
- image is monochrome, using the default Subsample.<br>
-<br>
- No differences expected<br>
-<br>
-devices/vector/gdevpsdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-03 08:21: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=de66bba6a320e7b263260205637976c734805909">de66bba6a320e7b263260205637976c734805909</a>
-<blockquote>
-<p>
- Fix PCL/XPS Windows builds from previous commit<br>
-<br>
- A typo and a missing header caused the Windows PCL/XPS builds to fail.<br>
-<br>
- No cluster differences.<br>
-<br>
-pcl/pl/plwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-02 12:37: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=6b1b1d72ed6432bc29b719e186ea8ebd0b26de8a">6b1b1d72ed6432bc29b719e186ea8ebd0b26de8a</a>
-<blockquote>
-<p>
- Expunge references to e_* style errors<br>
-<br>
- No cluster differences<br>
-<br>
-base/fapibstm.c<br>
-base/gp_unifs.c<br>
-base/gpcheck.h<br>
-base/gsiomacres.c<br>
-base/sjpeg.h<br>
-base/strmio.c<br>
-contrib/japanese/gdevdmpr.c<br>
-contrib/pscolor/test.c<br>
-devices/vector/gdevpdfr.c<br>
-devices/vector/gdevpdfx.h<br>
-devices/vector/gdevpdtt.c<br>
-doc/API.htm<br>
-doc/C-style.htm<br>
-doc/Develop.htm<br>
-pcl/pcl/pcommand.h<br>
-pcl/pl/plparse.h<br>
-pcl/pl/plwmainc.c<br>
-toolbin/halftone/gen_stochastic/gen_stochastic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-28 10:33: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=ac5d49f03f44aa45ba9a0788bbe351b0510a5bcc">ac5d49f03f44aa45ba9a0788bbe351b0510a5bcc</a>
-<blockquote>
-<p>
- Coverity #94560: Protect from possible null ptr deref..<br>
-<br>
- Also ensure we always write a character to the character set.<br>
-<br>
- No cluster differences<br>
-<br>
-base/wrfont.c<br>
-base/write_t2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-11-01 09:43:04 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c28ba38b907ec1c6a5755669ea0ecb55b95f8cc">6c28ba38b907ec1c6a5755669ea0ecb55b95f8cc</a>
-<blockquote>
-<p>
- Bug 694982: DeviceN ICC Source Profiles<br>
-<br>
- The use of -sDeviceNProfile was broken when we introduced<br>
- delayed initialization of the ICC profiles. This fixes<br>
- the issue and adds a ReadMe to the example to explain why<br>
- the orange and green colorants will be swapped from what<br>
- happens when -sDeviceNProfile is not used.<br>
-<br>
-base/gsicc_manage.c<br>
-toolbin/color/icc_creator/example/README.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-31 12:24:01 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=243614398b7bf3e8c4d080de7f8bbcb7436472cf">243614398b7bf3e8c4d080de7f8bbcb7436472cf</a>
-<blockquote>
-<p>
- Replacement fix for commit 487ed6<br>
-<br>
- Bug #696306 was originally fixed in commit 487ed6. After talking about<br>
- it with Chris, it became clearer why I was unable to intercept the<br>
- broken font where I wanted. gs_type1.ps contains a redefinition of<br>
- .buildfont1, and this redefinition does not properly preserve the<br>
- stack in the event of an error.<br>
-<br>
- If this was a simple procedure that would be understandable, but the<br>
- redefinition is of a C operator, so not preserving the stack is actually<br>
- wrong.<br>
-<br>
- The commit here corrects that problem, which enables me to intercept the<br>
- error much later in the page rendering and do a considerably better job<br>
- of correcting the problem. This now renders as per Marcos' Acrobat<br>
- screenshot (but unlike mine).<br>
-<br>
- This fix should be used in preference.<br>
-<br>
-Resource/Init/gs_type1.ps<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-29 14:29: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=c938315af2a0d4d90a03a762d19d31bf35b47b07">c938315af2a0d4d90a03a762d19d31bf35b47b07</a>
-<blockquote>
-<p>
- Bug 695042; -dUsePDFX3Profile with -dNumRenderingThreads issues<br>
-<br>
- When a PDF file has on Output Intent (OI) profile and we want<br>
- to use it as the device profile or the proof profile, it is<br>
- set for the device through a call from the interpreter in<br>
- zset_outputintent. Unlike other profiles for the device,<br>
- this profile is not a device param that is set with get/put<br>
- params of a file name. Instead the profile is inside the source<br>
- file that is being rendered.<br>
-<br>
- When the threads are set up in setup_device_and_mem_for_thread<br>
- the icc profiles are set through put and get param calls. Since<br>
- the OI profile is not available in this manner, this fails.<br>
-<br>
- This fix detects the presence of the OI profile during<br>
- setup_device_and_mem_for_thread and clones the profiles.<br>
- Doing a straight reference to the profile instead of cloning<br>
- is problematic if the CMM is not thread safe in its use<br>
- of the profile handles (which is true for LCMS), hence the<br>
- cloning process.<br>
-<br>
- In addition, in this commit a non-ascii character was added to<br>
- the special name for the OI profile to help avoid issues with<br>
- an actual profile being named with our special key word.<br>
-<br>
-base/gsicc_manage.c<br>
-base/gsicc_manage.h<br>
-base/gxclthrd.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-30 11:58:21 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=487ed6d3b5fabbe21c23da288fbf020f49a28fae">487ed6d3b5fabbe21c23da288fbf020f49a28fae</a>
-<blockquote>
-<p>
- PDF interpreter - handle broken type 1 fonts with no Private dict earlier<br>
-<br>
- Bug #696306 &quot;Incomplete rendering of PDF file&quot;<br>
-<br>
- The embedded type 1 font 'Consolas' is broken. The eexec encrypted<br>
- portion of the font suddenly ends during a glyph description. This means<br>
- that the Private dictionary is never added to the font dictionary but is<br>
- instead left on the operand stack. Where the PDF interpreter removes it<br>
- in order to avoid other errors.<br>
-<br>
- The error actually occurs inside .buildfont1, but despite efforts it<br>
- proved impossible to deal with the error at that point. This was due to<br>
- all the code already in place to deal with other errors while handling<br>
- broken PDF files. It wasn't possible to address this particular problem<br>
- without breaking other (admittedly invalid) PDF files.<br>
-<br>
- This commit checks the font dictionary for the presence of a Private<br>
- dictionary before returning from readtype1 and if the Private dict is<br>
- not present it instead returns a null object, which signals the calling<br>
- code to attempt to load the font from another source.<br>
-<br>
- No differences expected<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-29 09:59:13 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e0498dcff844d119ee51873394aef93be5bfffc6">e0498dcff844d119ee51873394aef93be5bfffc6</a>
-<blockquote>
-<p>
- Fix for transparency_example.ps to set the number of spot colors, Bug 695277.<br>
-<br>
- From Michael Vrhel:<br>
-<br>
- The ps file transparency_example.ps failed to set the number of spot<br>
- colors on the page. This information is expected to be provided<br>
- for the pdf14 device by the PDF interpreter when we are dealing with the<br>
- separable devices (e.g. psdcmyk, tiffsep)<br>
-<br>
-examples/transparency_example.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-24 17:12: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=65b10e0fc85dc791848dbd43dbcf673669c1fc4c">65b10e0fc85dc791848dbd43dbcf673669c1fc4c</a>
-<blockquote>
-<p>
- Bug 696222: Fix segfault due to image buffer being allocated too small leading to a memory over run.<br>
-<br>
- Also updated pclr functionality to detect BitsPerComponent early and so<br>
- allowing the signature image to be decoded correctly.<br>
-<br>
- Signed-off-by: Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-base/sjpx_luratech.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-23 10:11:14 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d2c0a7d63b5a2b9b5e99883b89fc03b12f60b77d">d2c0a7d63b5a2b9b5e99883b89fc03b12f60b77d</a>
-<blockquote>
-<p>
- Handle NULL returns from gsicc_profile_new.<br>
-<br>
- Fix for bug 696268. Also clean up some of the other error handling<br>
- in gsicc_create.c, gsicc_manage.c and gsciemap.c<br>
-<br>
-base/gsciemap.c<br>
-base/gsicc_create.c<br>
-base/gsicc_manage.c<br>
-psi/zicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-28 11:08:20 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1a7740b8a021e2962964fcaf69dd0d95e1af5888">1a7740b8a021e2962964fcaf69dd0d95e1af5888</a>
-<blockquote>
-<p>
- Fix for crash in Bug 696290<br>
-<br>
- The planar devices were not getting the bit depth arrays set up.<br>
- This was causing an issue during the gradient fill for high level<br>
- colors where we were trying to make a smoothness decision during<br>
- the line fills. Problem occurred for all the existing planar devices.<br>
-<br>
-devices/gdevcmykog.c<br>
-devices/gdevpsd.c<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-27 10:08:57 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e95a71f661323214a4206f534068301b441dbe3">0e95a71f661323214a4206f534068301b441dbe3</a>
-<blockquote>
-<p>
- Fix for bug 696227.<br>
-<br>
- The color usage information for the clist bands was not getting<br>
- updated for certain cases where we are doing trapezoid fills.<br>
-<br>
-base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-26 11:01:16 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aaefd493e35b75e761e542713d18cecabfe96593">aaefd493e35b75e761e542713d18cecabfe96593</a>
-<blockquote>
-<p>
- Add proper check for gx_dc_type_data_devn color type in shading color linearity<br>
-<br>
- When we added the gx_dc_type_data_devn to support the Device N planar devices,<br>
- we failed to update the linearity check for shadings when we draw to these<br>
- devices. This resulted in the linearity check always failing which resulted<br>
- in extreme decomposition of the shading beyond what was needed.<br>
-<br>
- Fixes bug 696290. Note that a couple files like 442-01.ps will have some minor<br>
- shading artifacts visible that were not there before for the psdcmyk device.<br>
- I checked, and these same artifacts are visible in other CMYK devices (e.g. tiff32nc)<br>
- for this file.<br>
-<br>
- These issues are different than what was addressed by this fix and should not<br>
- be considered a regression by this commit. That said, we may want to open a bug<br>
- related to those issues.<br>
-<br>
-base/gscspace.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-26 08:32:32 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc5cae259b8f5b7dc4b6105f60b56af72fed235a">dc5cae259b8f5b7dc4b6105f60b56af72fed235a</a>
-<blockquote>
-<p>
- check gp_fseek_64 return value and action it, silences Coverity CID 118348<br>
-<br>
-devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-22 12:27:50 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59c818b145474f6e8a8dc315adaaa308f8e53aac">59c818b145474f6e8a8dc315adaaa308f8e53aac</a>
-<blockquote>
-<p>
- Fix multi-threaded rendering crash on Windows. Bug 696254.<br>
-<br>
- The use of fseek(...SEEK_END)...ftell to determine the file size is not<br>
- thread safe because reading changes the current position. On Windows, the<br>
- ReadFile changes the position of the 'fd' attached to the stream and handle,<br>
- and the ftell uses 'lseek(fd, 0, SEEK_CUR)' to get the current position<br>
- which may have moved due to reads on other threads.<br>
-<br>
- On unix, similar conditions can occur sharing the FILE * stream. Also on<br>
- unix, we must assume that without PREAD support, we cannot share the file<br>
- descriptor since reading requires &quot;ftell..seek..read..seek&quot; sequences that<br>
- are not thread safe without locking (that is not yet implemented, and may<br>
- impact performance).<br>
-<br>
- Maintain the filesize while writing the file in the IFILE wrapper stucture<br>
- and use that for the file size instead of fseek..ftell to avoid the position<br>
- change that could happen on the clist file due to a read by a different<br>
- thread on that same file fd.<br>
-<br>
- This was a rare problem because only cl_cache_read_init used the seek..tell<br>
- mechanism to get the filesize, and this only happens in a thread on the<br>
- first read (to either the bfile or the cfile) which is a narrow window.<br>
-<br>
-base/gp_unifs.c<br>
-base/gxclfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-23 11:16:20 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb1154ad98a2826679be009bf92576aaec99a4dd">fb1154ad98a2826679be009bf92576aaec99a4dd</a>
-<blockquote>
-<p>
- Bug 694149: Move copied font init earlier.<br>
-<br>
- When copying a font (for high level device use) we have to initialize at least<br>
- some of the gs_font structure contents so that, in the event of a later fail,<br>
- the font can be cleaned up, finalized and freed correctly.<br>
-<br>
- No cluster differences.<br>
-<br>
-devices/gxfcopy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-23 10:16: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=feafe5e540a0545ec5d28f3f66bb542056bba495">feafe5e540a0545ec5d28f3f66bb542056bba495</a>
-<blockquote>
-<p>
- Bug 696301: add gserrors.h to the installed files<br>
-<br>
- for the so-install target.<br>
-<br>
- Also remove a spurious (copy'n'paste error) comment.<br>
-<br>
- No cluster differences<br>
-<br>
-base/gserrors.h<br>
-base/unix-dll.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-22 18:03: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=3ff82bf9367e36cf582811634cc37831907c439c">3ff82bf9367e36cf582811634cc37831907c439c</a>
-<blockquote>
-<p>
- Bug 694147: add stack checks in Type 1 charstrings<br>
-<br>
- Add checks for the both the operand stack and the 'control' stack during<br>
- interpreting of Type 1 charstrings.<br>
-<br>
- No cluster differences<br>
-<br>
-base/gstype1.c<br>
-base/gxtype1.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-22 16:13:20 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3be1a95a2b6e5a8a9c7472d077cdd454315a40fd">3be1a95a2b6e5a8a9c7472d077cdd454315a40fd</a>
-<blockquote>
-<p>
- Bug 696102: use gs_abort() instead of forced segfault<br>
-<br>
- In the garbage collector, in a condition that should not occur, gs_abort()<br>
- is the correct way to bail out.<br>
-<br>
- No cluster differences.<br>
-<br>
-psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-22 16:11:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c92c06899aab159ad2f60f69d3ce76ecdb03caff">c92c06899aab159ad2f60f69d3ce76ecdb03caff</a>
-<blockquote>
-<p>
- Add more details about COMPILE_INITS trade-offs<br>
-<br>
- No cluster differences<br>
-<br>
-doc/Make.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-22 15:35:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f435300f1647be90380554b23099ae6dd047c6c0">f435300f1647be90380554b23099ae6dd047c6c0</a>
-<blockquote>
-<p>
- Tweak for CIDSystemInfo indirect object fix<br>
-<br>
- So these will be handled for all CIDFont types, and not just those with TTF<br>
- outlines.<br>
-<br>
- No cluster differences.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-22 10:35:50 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34dba299b2f76c6ee6254950b5d32fd4026bd030">34dba299b2f76c6ee6254950b5d32fd4026bd030</a>
-<blockquote>
-<p>
- Typo in .gitattributes, corrected eof to eol. Try and get line endings<br>
- consistent in ghostpdf.inf<br>
-<br>
-.gitattributes<br>
-lib/ghostpdf.inf<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-22 10:33:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0dd90a3cef222b7195459ee16dfcba0093c24b55">0dd90a3cef222b7195459ee16dfcba0093c24b55</a>
-<blockquote>
-<p>
- remove the accidentally added ghostpdl.inf<br>
-<br>
-lib/ghostpdl.inf<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-22 10:13: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=3e1089d53b8b44b9c0c0dcdcc493b7290f11773e">3e1089d53b8b44b9c0c0dcdcc493b7290f11773e</a>
-<blockquote>
-<p>
- Try again to get Git to change the ghostpdf.inf file<br>
-<br>
-lib/ghostpdf.inf<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-22 10:02:36 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0baeb24527e4d700cd2e0b0de30cfb58a9b3ba9c">0baeb24527e4d700cd2e0b0de30cfb58a9b3ba9c</a>
-<blockquote>
-<p>
- Touch the ghostpdf.inf file simply in order to get it to be updated in Git<br>
-<br>
- We need the ghostpdf.inf file to have consistent line endings across<br>
- platforms (see commit c46f8651e6bea69b76f84dd58568c18fc73ade7d) simply<br>
- updating the .gitattributes file doesn't seem to actually alter the file.<br>
-<br>
-lib/ghostpdl.inf<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-22 09:48: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=c46f8651e6bea69b76f84dd58568c18fc73ade7d">c46f8651e6bea69b76f84dd58568c18fc73ade7d</a>
-<blockquote>
-<p>
- Make all '.inf' files have DOS/Windows line terminators<br>
-<br>
- This means that when checked out onto a Linux platform for building releases<br>
- the line endings will still be 'correct' for DOS/Windows platforms and,<br>
- more importantly, will be the same as was used when creating any '.cat'<br>
- files which are used for digital signing.<br>
-<br>
-.gitattributes<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-21 11:11:43 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=268bc03cbf664cad907f7a1f8ee9be7db93f9405">268bc03cbf664cad907f7a1f8ee9be7db93f9405</a>
-<blockquote>
-<p>
- Fix some of the paths in the visual studio project<br>
-<br>
- This fixes the paths for the openjpeg files. I don't see the jpegxr content in the project.<br>
- Also the jpeg files need to be cleaned up. Some of the refs in the project are not really<br>
- there.<br>
-<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-21 10:55:12 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3d4ade241415faeed82e8cc355f58c58d6b0b886">3d4ade241415faeed82e8cc355f58c58d6b0b886</a>
-<blockquote>
-<p>
- Add name space definitions for Open XPS<br>
-<br>
- With this commit we should be rendering Open XPS content. Fix for bug 696272<br>
-<br>
-xps/ghostxps.h<br>
-xps/xpsdoc.c<br>
-xps/xpsxml.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-21 10:19: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=1f0ad334a81e871dbbbc9929928ec025c616926a">1f0ad334a81e871dbbbc9929928ec025c616926a</a>
-<blockquote>
-<p>
- PDF interpreter - check for (illegal) non-dict XObjects when scanning spot colours<br>
-<br>
- Bug #696288 &quot;Error: /typecheck in --run-- writing psdcmyk file&quot;<br>
-<br>
- The PDF file contains a /Pages dictionary which includes a /Resources<br>
- dictionary, this is consulted if a page calls for a resource which isn't<br>
- defined in the page's own Resources dictionary.<br>
-<br>
- Unfortunately the XObject dictionary defined in this resource contains a<br>
- reference to an object which is not an XObject.<br>
-<br>
- When scanning for transparency we deal with this (and ignore it) but when<br>
- scanning for page spot colours, we do not, resulting in a typecheck error.<br>
-<br>
- This commit adds checking the XObject type when scanning for page spot<br>
- colours, and ignores anything which isn't a dictionary.<br>
-<br>
- No differences expected.<br>
-<br>
-Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-21 09:20:42 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=56aa405c6d7913701091ce58370679b571690d82">56aa405c6d7913701091ce58370679b571690d82</a>
-<blockquote>
-<p>
- PDF interpreter - ignore indirect references to invalid object number 0<br>
-<br>
- Bug #696289 &quot;**** Unrecoverable error in ref! writing PDF file&quot;<br>
-<br>
- The Outlines tree is referenced indirectly as &quot;0 0 R&quot; which is invalid<br>
- (object number 0 is reserved). The resolveR routine which resolves indirect<br>
- references checks the validity of the object number but was checking for a<br>
- value *less* than 0, when it should have been less than or equal.<br>
-<br>
- This commit alters the lt to le, which allows the file to be processed, of<br>
- course there are no Outlines present since those were originally broken.<br>
-<br>
- Note this only exhibits with high level devices because rendering devices<br>
- cannot usefully use the Outlines tree, and ignore it.<br>
-<br>
-<br>
- No differences expected.<br>
-<br>
-Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-19 16:35:51 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3777fa7d9a00158ed2b84de1b547b5fe4a8241dd">3777fa7d9a00158ed2b84de1b547b5fe4a8241dd</a>
-<blockquote>
-<p>
- Undo mistakenly added debug code from the last commit.<br>
-<br>
-base/gsalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-19 15:59:57 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e0ce584138cbc37c91e757a18d9946b02d3abd03">e0ce584138cbc37c91e757a18d9946b02d3abd03</a>
-<blockquote>
-<p>
- Fix crash in language switch build introduced by an API change in<br>
- ghostscript argument processing.<br>
-<br>
- The language switch system is being reworked but it is nonetheless<br>
- useful to have the old design working at least for the time being. It<br>
- looks as though earlier revisions of arg_init() supported a null<br>
- terminated list, now the function reads all the arguments specified by<br>
- &quot;argc&quot;. The language switch build used a null terminated list smaller<br>
- than argc resulting in dereferencing null in arg_init().<br>
-<br>
- Also remove the business about reading options from a file, certainly<br>
- not worth the distraction of reading it.<br>
-<br>
-base/gsalloc.c<br>
-gpdl/psi/psitop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-16 14:34: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=fe1c025dcbaef436b4a45e0a0bcb4af4d98eefde">fe1c025dcbaef436b4a45e0a0bcb4af4d98eefde</a>
-<blockquote>
-<p>
- Correct some out of date information regarding ColorConversionStrategy<br>
-<br>
- The PDF/A and PDF/X sections of the documentation contained some out of<br>
- date settings. The main body of the text remained correct.<br>
-<br>
-doc/Ps2pdf.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-14 13:54:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e126995d6327788ddac7fd99f55db3c1603beea7">e126995d6327788ddac7fd99f55db3c1603beea7</a>
-<blockquote>
-<p>
- Bug 696271: Fix a load of makefile dependencies.<br>
-<br>
- A large number of targets weren't depending on the makefile in which they were<br>
- defined.<br>
-<br>
- Almost no targets were dependent on the top level makefile.<br>
-<br>
- A significant number of targets were missing the &quot;MAKEDIRS&quot; dependency (which<br>
- is specific to GNU make as an order-only prerequisite).<br>
-<br>
- No cluster differences<br>
-<br>
-base/expat.mak<br>
-base/fapi_bs.mak<br>
-base/freetype.mak<br>
-base/gs.mak<br>
-base/ijs.mak<br>
-base/jbig2.mak<br>
-base/jpeg.mak<br>
-base/jpegxr.mak<br>
-base/lcms2.mak<br>
-base/lcups.mak<br>
-base/lcupsi.mak<br>
-base/ldf_jb2.mak<br>
-base/lib.mak<br>
-base/lwf_jp2.mak<br>
-base/msvclib.mak<br>
-base/msvctail.mak<br>
-base/openjpeg.mak<br>
-base/pcwin.mak<br>
-base/png.mak<br>
-base/tiff.mak<br>
-base/unix-aux.mak<br>
-base/unix-dll.mak<br>
-base/unix-end.mak<br>
-base/unixinst.mak<br>
-base/unixlink.mak<br>
-base/winlib.mak<br>
-base/winplat.mak<br>
-base/zlib.mak<br>
-contrib/contrib.mak<br>
-cups/cups.mak<br>
-devices/contrib.mak<br>
-devices/devs.mak<br>
-pcl/pcl/pcl.mak<br>
-pcl/pcl/pcl_top.mak<br>
-pcl/pl/pl.mak<br>
-pcl/pxl/pxl.mak<br>
-psi/int.mak<br>
-psi/msvc.mak<br>
-psi/os2.mak<br>
-psi/winint.mak<br>
-xps/xps.mak<br>
-xps/xps_gcc.mak<br>
-xps/xps_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-14 15:23: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=74ba28a80804f82aaa68682733c7d7a3cd5f9cbd">74ba28a80804f82aaa68682733c7d7a3cd5f9cbd</a>
-<blockquote>
-<p>
- pdfwrite - guard against NULL pointer dereference and correct a loop<br>
-<br>
- Bug #696275 &quot;-dFastWebView parameter crashes Ghostscript&quot;<br>
-<br>
- This is a twofold fix. A Coverity static analysis fix added some return<br>
- checking, but this happened inside a faulty loop, the code should not have<br>
- been executed. Because the return value wasn't checked, this didn't cause a<br>
- problem......<br>
-<br>
- Checking the return value meant that we returned an error to the caller, and<br>
- an oversight there could lead to us dereferencing a pointer which had not<br>
- been allocated.<br>
-<br>
- This commit fixes both of these problems.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-14 09:50: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=c6fa28f20c464c4badb2579b6bf8dfd0c7cc0230">c6fa28f20c464c4badb2579b6bf8dfd0c7cc0230</a>
-<blockquote>
-<p>
- Bug 696267: augment DroidSansFallback.ttf<br>
-<br>
- Specifcally to add the Yen symbol, but adds any glyphs in DroidSans.ttf not<br>
- present in DroidSansFallback.ttf<br>
-<br>
- One minor cluster change - 959_-_cannot_search_for_japanese.pdf<br>
-<br>
-Resource/CIDFSubst/DroidSansFallback.ttf<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-13 08:32: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=1ebc998c9e6e18468a64210ed5da091e765cef1c">1ebc998c9e6e18468a64210ed5da091e765cef1c</a>
-<blockquote>
-<p>
- Squash a compiler warning<br>
-<br>
- I hadn't realised but the 'setup_fn' is a fixed 256 byte character array<br>
- rather than a char pointer, so there's no point for testing it being<br>
- non-NULL.<br>
-<br>
- Of course, having the filename be a fixed length array has other implications<br>
- for buffer overruns.....<br>
-<br>
-devices/gdevrinkj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-12 16:40:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5571ddfa377c5d7d98f55af40e693814ac287ae4">5571ddfa377c5d7d98f55af40e693814ac287ae4</a>
-<blockquote>
-<p>
- prevent rinkj device crash when misconfigured (no SetupFile)<br>
-<br>
- Bug #696246 &quot;Ghostscript 9.18 with -dFirstPage/-dLastPage fails for ijs and some x11 devices&quot;<br>
-<br>
- The rinkj device requires a SetupFile to be given as a device parameter,<br>
- however it doesn't actually check to see if one is given, and just tries<br>
- to open the filename, with a predictable crash when none is given.<br>
-<br>
- Here we check the filename and attempt to ensure it is both present and<br>
- minimally valid.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/gdevrinkj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-12 16:38: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=1bdbe4f87dc57648821e613ebcc591b84e8b35b3">1bdbe4f87dc57648821e613ebcc591b84e8b35b3</a>
-<blockquote>
-<p>
- Ensure plib devices always use the clist<br>
-<br>
- Bug #696246 &quot;Ghostscript 9.18 with -dFirstPage/-dLastPage fails for ijs and some x11 devices&quot;<br>
-<br>
- the plib* class of devices only work if clist is present, but previously<br>
- they left the banding_type set to 'auto', which meant that under some<br>
- conditions we did not use the clist, leading to a seg fault.<br>
-<br>
- This commit simply forces banding_type to be 'BandingAlways'.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/gdevplib.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-12 16:36: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=007bd77d08d800e6b07274d62e3c91be7c4a3f47">007bd77d08d800e6b07274d62e3c91be7c4a3f47</a>
-<blockquote>
-<p>
- Guard against NULL 'base' for non-clist devices<br>
-<br>
- Bug #696246 &quot;Ghostscript 9.18 with -dFirstPage/-dLastPage fails for ijs and some x11 devices&quot;<br>
-<br>
- This is actually for the plib device. This device is currently (this will<br>
- change in the next commit) set to BandingAuto, despite the fact that the<br>
- device only works in banding mode.<br>
-<br>
- This can lead to use arriving in gdev_mem_open_scan_lines with all of<br>
- mdev-&gt;bitmap_memory, mdev-&gt;line_pointers_memory and mdev-&gt;base being set to<br>
- NULL. The code didn't check and assumed that mdev-&gt;base was valid, which<br>
- led to a later seg fault.<br>
-<br>
- Here we just check to make sure it isn't NULL and return an error if it is.<br>
- This doesn't prevent the possibility of garbage uninitialised values, but<br>
- there's not much we can do to check that at this stage, devices are supposed<br>
- to be initialised to 0 so this 'shouldn't' happen.<br>
-<br>
- No differences expected.<br>
-<br>
-base/gdevmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-09 10:04: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=92f91de4a43e164602f2c219f895006347db958c">92f91de4a43e164602f2c219f895006347db958c</a>
-<blockquote>
-<p>
- Bug 696232: apply metrics for PCL TTF fonts.<br>
-<br>
- Specifically, metrics for Format 1 Class 2 glyph data.<br>
-<br>
- Several PCL/PXL files show differences, most are not really visible without<br>
- pixel level comparisons, a very few are (mostly subtle) progressions.<br>
-<br>
-base/fapi_ft.c<br>
-base/gxfapi.c<br>
-pcl/pl/plchar.c<br>
-pcl/pl/plchar.h<br>
-pcl/pl/plfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-09 12:54: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=95553954b8d150e847090ec03db3b10a998e82be">95553954b8d150e847090ec03db3b10a998e82be</a>
-<blockquote>
-<p>
- Bug 696246: patch the memory manager fields for sublassed devices.<br>
-<br>
- When we subclass a device, we were patching the &quot;visible&quot; type field - that is,<br>
- the one referenced directly in the device structure. We were not patching<br>
- the type information in the memory object header so, in particular, the<br>
- garbage collector could end up calling the wrong methods for the subclassed<br>
- device.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/gdevdflt.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-09 10:54: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=b68e05c3b78c19ae06003281adaa2736cb53e605">b68e05c3b78c19ae06003281adaa2736cb53e605</a>
-<blockquote>
-<p>
- Bug 696246: devijs account for device sublassing.<br>
-<br>
- The IJS device wasn't coping with the possibility it had been subclassed.<br>
-<br>
- No cluster differences<br>
-<br>
-devices/gdevijs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-08 15:02: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=d39382efae340a29cd5a502b52d135f63f9202ce">d39382efae340a29cd5a502b52d135f63f9202ce</a>
-<blockquote>
-<p>
- Add configure and makefile stuff for isinf() and isnan()<br>
-<br>
- Bug #696248 related.<br>
-<br>
-Makefile.in<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-08 13:54:50 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5411d274b19067bec99189dd0a956432d619c80e">5411d274b19067bec99189dd0a956432d619c80e</a>
-<blockquote>
-<p>
- PS interpreter - check for floating point exceptions in mul, div and add<br>
-<br>
- Bug #696248 &quot;gs9.18 crash on display of nan; also poor handling of inf&quot;<br>
-<br>
- The mul, div and add operators did not detect invalid results (infinity or<br>
- non-a-number). This is likely because there is no guaranteed portable<br>
- method for detection of these prior to C99.<br>
-<br>
- Here we add checks for this results using the C99 extensions isnan() and<br>
- isinf(). These are guarded by #ifdef so that they do not cause compilation<br>
- problems on compilers that don't support them. Additionally add support for<br>
- early versions of Microsoft Visual Studio which used somewhat different<br>
- names for these functions.<br>
-<br>
- This code requires some changes to the configure scripts on Linus in<br>
- order to enable it.<br>
-<br>
- On systems which do not support isnan() and isinf() there will be no change,<br>
- we will continue to not report errors in ths case.<br>
-<br>
- No differences expected.<br>
-<br>
-base/gssprintf.c<br>
-base/math_.h<br>
-psi/zarith.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-07 09:26:05 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=33f782ee9e09fd840d0d50598db491e5b8a951f5">33f782ee9e09fd840d0d50598db491e5b8a951f5</a>
-<blockquote>
-<p>
- Fix Bug #696242: PCL should be the default implementation when<br>
- building with XPS.<br>
-<br>
-pcl/pl/plimpl.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-07 09:33: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=ddda7e89bb0bf35cec575c54b19fa8ba3608d8f7">ddda7e89bb0bf35cec575c54b19fa8ba3608d8f7</a>
-<blockquote>
-<p>
- PS interpreter - fix a buffer overrun in '=='<br>
-<br>
- Since changing the implementation of sprintf we now have a situation<br>
- where %g can return &gt; 50 bytes of data for a INF. In obj_cvp we define a<br>
- fixed size buffer on the heap to receive this, but only 50 bytes wide, so<br>
- the buffer overflows and we get a crash.<br>
-<br>
- Increased the size of the buffer well past the maximum possible return<br>
- size from sprintf.<br>
-<br>
- No differences expected.<br>
-<br>
-psi/iutil.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-06 17:36: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=b3c0f7279a34836276df5126a0d4a7a1abd00977">b3c0f7279a34836276df5126a0d4a7a1abd00977</a>
-<blockquote>
-<p>
- Add a missing dependency for the gs romfs file<br>
-<br>
-psi/psromfs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-05 13:15: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=0db2e3063957b94ee331da09369a9e4116c3d9c1">0db2e3063957b94ee331da09369a9e4116c3d9c1</a>
-<blockquote>
-<p>
- pdfwrite - cater for forms with negative bounding boxes<br>
-<br>
- When setting a clip for forms, we were not accounting for the possibility<br>
- of a form which was wholly negative in either or both dimensions.<br>
-<br>
- Here we permit that and create a better clip.<br>
-<br>
- No differences expected.<br>
-<br>
-psi/zform.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-10-01 13:37: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=a7a09c72cd84b539914d97ceafd02673f0dd32f9">a7a09c72cd84b539914d97ceafd02673f0dd32f9</a>
-<blockquote>
-<p>
- pdfwrite - prevent NULL pointer dereference<br>
-<br>
- Bug #696234 &quot; Regression: segfault with pdfwrite starting with 17131c7a7fdf9d8537c4715e538c49b29c8945a8&quot;<br>
-<br>
- When trying to find an object in the resource chains using an ID, we can<br>
- encounter resources which have been cancelled. These have no object (it has<br>
- been freed) so trying to dereference the object can cause a SEG fault.<br>
-<br>
- I did try to free the resource as well, when cancelling it but that spun<br>
- off into a maze of complications involving the garbage collector. It seems<br>
- that 'something' was maintaining a pointer to those structures, so freeing<br>
- them caused all kinds of relocation/free problems.<br>
-<br>
- Its a lot easier just to prevent dereferencing the pointer.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-30 09:43: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=38dd52355037ce88c21bad94bff0df04d71ffc8b">38dd52355037ce88c21bad94bff0df04d71ffc8b</a>
-<blockquote>
-<p>
- pdfwrite - improve tiny text matrix clamping in 53ac1eca93ac13fead4c4ab8ced0faeee1ee517c<br>
-<br>
- Use fabs instead of abs on the matrix elements, and allow individual<br>
- scaling for each element so that clamping to a minimum value can vary for<br>
- each element.<br>
-<br>
- No diffrences expected.<br>
-<br>
-devices/vector/gdevpdts.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-29 15:32: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=e88f94fed2a339288b3ee65cf3dce348c0b3419d">e88f94fed2a339288b3ee65cf3dce348c0b3419d</a>
-<blockquote>
-<p>
- Contents of CIDSystemInfo can be indirect references<br>
-<br>
- Cope with that....<br>
-<br>
- No cluster differences.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-28 22:44: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=c874900bf0c184bd61586acfb6f4ebb5a007f730">c874900bf0c184bd61586acfb6f4ebb5a007f730</a>
-<blockquote>
-<p>
- Improve initalization of the gdevplib device.<br>
-<br>
- Tweak so it uses appropriate macro, eliminating warnings, and hopefully making<br>
- long term maintenance easier.<br>
-<br>
- No cluster differences.<br>
-<br>
-devices/gdevplib.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-28 09:53: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=da2038b2040827f9f29faa43266477f73d83c043">da2038b2040827f9f29faa43266477f73d83c043</a>
-<blockquote>
-<p>
- Bug 696229: initialize clist color space validity.<br>
-<br>
- The clist uses a stack variable to hold the device color. Valgrind reports<br>
- that the ccolor_valid entry in the device color can remain unset, so set<br>
- it to invalid when the initialize the device color to &quot;unset&quot;.<br>
-<br>
- Also, add a PACIFY_VALGRIND memset so pattern bitmap buffers are fully zeroed<br>
- on allocation - stops valgrind getting upset about writing and reading back<br>
- uninitialised (padding) bytes to/from the clist.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/gdevmem.c<br>
-base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-29 14:25: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=53ac1eca93ac13fead4c4ab8ced0faeee1ee517c">53ac1eca93ac13fead4c4ab8ced0faeee1ee517c</a>
-<blockquote>
-<p>
- pdfwrite - ensure we don't write non-zero matrix elements with too tiny a value<br>
-<br>
- Bug #696228 &quot;Regression: error starting with 70b442162ff8f3d40595d0eb9fb365d341139ee2&quot;<br>
-<br>
- The change noted causes the PDF interpreter to replace degenerate text matrices<br>
- with a very tiny scaling matrix. However, when writing this back through<br>
- ps2write, we also take the size of the font into account, and bake this<br>
- into the matrix.<br>
-<br>
- If the font size was less than 1 this could lead to us writing a value too<br>
- small for printf's '%g' format, and it ended up being written as zero, which<br>
- caused the error with the ps2write output.<br>
-<br>
- This commit checks each of the array elements to see if they are non-zero, but<br>
- have a value so small that they will *become* zero when written out. If this<br>
- happens we recalculate the scale so that the minimum value is emitted. The<br>
- value is so small anyway that this should not cause a perceptible difference.<br>
- We *don't* do this for the Tx and Ty values as we want these to be correct<br>
- and it doesn't cause a problem if these are 0.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/vector/gdevpdts.c<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-
-<h2><a name="Version9.18"></a>Version 9.18 (2015-09-23)</h2>
-
-<p>This is the thirteenth full release in the stable 9.x series, and is
-a maintenance release.
-
-<p> Highlights in this release include:
-<ul>
-<li>
-<p>
-A substantial revision of the build system and GhostPDL directory structure,
-meaning the GhostPCL and GhostXPS &quotproducts&quot are now built by the
-Ghostscript build system &quotproper&quot rather than having their own builds
-which called the Ghostscript build system for certain parts of the builds.
-<p>
-Ghostscript-only users should not be affected by this change.
-<p>
-For users of the PCL and XPS interpreters (collectively downloaded as &quotGhostPDL&quot) there
-is a new, &quotflatter&quot directory structure and only one <code>configure</code> and one
-<code>make</code> invocation to build all the products. There are also some executable default name changes
-to bring the PCL and XPS binaries in line with the Ghostscript ones. All executables now end up in
-the &quotbin&quot directory (or build specific variant thereof, e.g. &quotdebugbin&quot). The PCL
-executable, by default, is now &quotgpcl6&quot on Unix like systems and &quotgpcl6win??.exe&quot (where
-&quot??&quot is either &quot32&quot or &quot64&quot). The XPS executable remains &quotgxps&quot on Unix-like
-systems, but similarly becomes &quotgxpswin??.exe&quot on Windows.
-<p>
-Those using scripts or other automated processes will need to take steps to cope with these changes.
-</li>
-<li>
-<p>
-A new method of internally inserting devices into the device chain has been
-developed, named "device subclassing". This allows suitably written devices to
-be more easily and consistently as &quotfilter&quot devices.
-<p>
-The first fruit of this is a new implementation of the &quot-dFirstPage&quot/&quot-dLastPage&quot
-feature which functions a device filter in the Ghostscript graphics library,
-meaning it works consistently with all input languages.
-</li>
-<li>
-The &quotghostpdl.inf&quot file, provided to simplify installing a Postscript
-printer configure to produce output to suit Ghostscript's &quotpdfwrite&quot device
-is now available as a digitally signed version: &quotghostpdl.cat&quot.
-</li>
-<li>
-<p>Plus the usual round of bug fixes, compatibility changes, and incremental improvements.
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.18_Incompatible_changes"></a>Incompatible changes</h3>
-<p>
-No recorded incompatible changes.
-
-<h3><a name="9.18_changelog"></a>Changelog</h3>
-
-<p><strong>2015-09-29 15:32: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=60ecc24519fa3c5be80617bd88fd0489344fd617">60ecc24519fa3c5be80617bd88fd0489344fd617</a>
-<blockquote>
-<p>
- Contents of CIDSystemInfo can be indirect references<br>
-<br>
- Cope with that....<br>
-<br>
- No cluster differences.<br>
-<br>
-Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-25 14:36: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=6c1b1ccce595e6477c972c9bf927462986b343a2">6c1b1ccce595e6477c972c9bf927462986b343a2</a>
-<blockquote>
-<p>
- More ICC reference counting problems<br>
-<br>
- Fix a few ICC profile reference counting issues with LAB and Calibrated color<br>
- spaces.<br>
-<br>
- No cluster differences.<br>
-<br>
-psi/zicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-24 21:09:53 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f616e3be41a6c3a13ddda3dddf9d57d73edc32be">f616e3be41a6c3a13ddda3dddf9d57d73edc32be</a>
-<blockquote>
-<p>
- Avoid doing color linearity tests when they are not needed.<br>
-<br>
- In the shading code there are several tests to determine if we<br>
- are sufficiently linear in our fill region. If not, it is further<br>
- divided. For certain color mappings we are always going to be linear<br>
- and do not need to check. We test for these now and avoid the check.<br>
- Cluster push reported 119 diffs. Checked them and they looked<br>
- reasonable. Differences in various gradient fills. The run time<br>
- numbers from the regression test improved significantly.<br>
- Going from a cpu time of 37:29:22 to 29:28:04 with gs going from<br>
- 19:42:34 to 15:25:29<br>
-<br>
-base/gxshade.c<br>
-base/gxshade.h<br>
-base/gxshade6.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-24 11:44:23 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b675dca5482eadece52ba917e1e492d9f30df618">b675dca5482eadece52ba917e1e492d9f30df618</a>
-<blockquote>
-<p>
- gximono.c: fix use of color sample cache<br>
-<br>
- When pulling multiple samples from the color cache (for example, for RGB and<br>
- CMYK) we should get the pointer to the first sample (from which we can work<br>
- through the samples) rather than the sample value itself.<br>
-<br>
- Identified by Johannes Meixner.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/gximono.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-24 14:30:20 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3a5faa7c23b323b7cdac8377a666c2fc64dc1990">3a5faa7c23b323b7cdac8377a666c2fc64dc1990</a>
-<blockquote>
-<p>
- Bug 696223: cope with empty %rom% returning an error<br>
-<br>
- The romfs is always included now, but if there are no files (i.e. if we're using<br>
- the &quot;dummy&quot; romfs for COMPILE_INITS=0) it returns an &quot;unregistered&quot; error from<br>
- the &quot;status&quot; method.<br>
-<br>
- This trips up the code for identifying the ICC profiles path, which stats the<br>
- default ICC profile path, which happens to be %rom%iccprofiles.<br>
-<br>
- So, put the status call in a stopped context, and act accordingly.<br>
-<br>
- No cluster differences.<br>
-<br>
-Resource/Init/gs_lev2.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-24 09:32:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=67d03961a838a391f79fcb0fbbded02ca53ad2e9">67d03961a838a391f79fcb0fbbded02ca53ad2e9</a>
-<blockquote>
-<p>
- Bug 696151: fix logic in gx_downscaler_get_bits_rectangle()<br>
-<br>
- The logic about whether to use an interim buffer or not did not match between<br>
- gx_downscaler_init_planar() and gx_downscaler_get_bits_rectangle() causing the<br>
- latter to attempt to write into a buffer that had not been allocated, thus<br>
- crashing.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/gxdownscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-24 11:04:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e35c4ca446faf442b558aa3dd2d2957e18d45ea4">e35c4ca446faf442b558aa3dd2d2957e18d45ea4</a>
-<blockquote>
-<p>
- Add words to release notes<br>
-<br>
- about the revised directory structure, build and executable names<br>
-<br>
-doc/History9.htm<br>
-doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-24 08:26: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=30021e7ba7cac7310cf0018746aad0ea1f2ee772">30021e7ba7cac7310cf0018746aad0ea1f2ee772</a>
-<blockquote>
-<p>
- Add missing dependencies....<br>
-<br>
- gsromfs0.c -&gt; time_.h<br>
- iconfig.c -&gt; gs.tr<br>
-<br>
- No cluster differences.<br>
-<br>
-base/lib.mak<br>
-psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-23 12:04: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=474e96f093527b1714df2f06dc66502a6d83db32">474e96f093527b1714df2f06dc66502a6d83db32</a>
-<blockquote>
-<p>
- Remove gpdl from the default target list<br>
-<br>
- No cluster differences<br>
-<br>
-configure.ac<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-22 09:12: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=dafc7774e523411a228d236612df03cab1b11c17">dafc7774e523411a228d236612df03cab1b11c17</a>
-<blockquote>
-<p>
- Delete the left-overs from the build reorg.<br>
-<br>
- No cluster differences.<br>
-<br>
-old-stuff/COPYING<br>
-old-stuff/Makefile<br>
-old-stuff/autogen.sh<br>
-old-stuff/common/cp.bat<br>
-old-stuff/common/gccdefs.mak<br>
-old-stuff/common/generic.mak<br>
-old-stuff/common/msvc_top.mak<br>
-old-stuff/common/msvcdefs.mak<br>
-old-stuff/common/mv.bat<br>
-old-stuff/common/pcdefs.mak<br>
-old-stuff/common/rm.bat<br>
-old-stuff/common/sgidefs.mak<br>
-old-stuff/common/ugcc_top.mak<br>
-old-stuff/common/unixdefs.mak<br>
-old-stuff/config.mak.in<br>
-old-stuff/configure.ac<br>
-old-stuff/main/pcl6_gcc.mak<br>
-old-stuff/main/pcl6_msvc.mak<br>
-old-stuff/win32/GhostPDL.sln<br>
-old-stuff/win32/ReadMe.txt<br>
-old-stuff/win32/language_switch.vcproj<br>
-old-stuff/win32/pcl.vcproj<br>
-old-stuff/win32/xps.vcproj<br>
-old-stuff/xcode/GhostPDL/GhostPDL.xcodeproj/project.pbxproj<br>
-old-stuff/xcode/GhostPDL/GhostPDL.xcodeproj/project.xcworkspace/contents.xcworkspacedata<br>
-old-stuff/xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/GhostPDL.xcscheme<br>
-old-stuff/xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/ghostscript.xcscheme<br>
-old-stuff/xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/language_switch.xcscheme<br>
-old-stuff/xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/pcl.xcscheme<br>
-old-stuff/xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/svg.xcscheme<br>
-old-stuff/xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/xps.xcscheme<br>
-old-stuff/xcode/Makefile<br>
-old-stuff/xcode/clang_wrapper.c<br>
-old-stuff/xcode/clang_wrapper.sh<br>
-old-stuff/xcode/resolve.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-22 09:10: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=0b78c7a692745084e7b9f328f4165af84eca57fe">0b78c7a692745084e7b9f328f4165af84eca57fe</a>
-<blockquote>
-<p>
- Revise Make.htm.<br>
-<br>
- Fix out of date links, remove long untested systems, and general cleanup.<br>
-<br>
- No cluster differences.<br>
-<br>
-doc/Make.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-22 08:20: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=e9e62834caf6b75248ea6e9ba558821834339075">e9e62834caf6b75248ea6e9ba558821834339075</a>
-<blockquote>
-<p>
- Tweak the WinRT build for new build scheme.<br>
-<br>
- No cluster differences.<br>
-<br>
-old-stuff/winrt/GhostPDL.sln<br>
-windows/Ghostscript-winrt.sln<br>
-windows/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-17 21:21:46 -0500
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=01639146163f7e196658ba7feb98d5c1a2cb8c34">01639146163f7e196658ba7feb98d5c1a2cb8c34</a>
-<blockquote>
-<p>
- Bug 694180 (related): jbig2dec base streams error handling<br>
-<br>
- Two problems:<br>
-<br>
- First: when creating the jbig2dec context, you optionally pass it a function<br>
- pointer and data pointer to use to record error conditions. The data pointer<br>
- being used was the pointer to the Ghostscript stream state - which was allocated<br>
- in normal Postscript memory - i.e. subject to relocation by the garbage<br>
- collector. As this was stored as part of jbig2dec's internals, there was no<br>
- way for the garbage collector to move the pointer, and thus the location<br>
- was potentially nonsense.<br>
-<br>
- Secondly, in testing the fix for above, it turns out that, in the event of an<br>
- error during JBIG2 decoding, there was no cleanup done - only the memory for<br>
- the stream state would be discarded (by the garbage collector), the jbig2dec<br>
- context was left to leak.<br>
-<br>
- To fix the first problem, add a non-gc memory structure with the pointers<br>
- required for the jbig2dec error callback.<br>
-<br>
- For the second problem, add a finalize method to the jbig2dec stream state<br>
- so the non-gc stuff can be cleaned up in the event of an error.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/sjbig2.c<br>
-base/sjbig2.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-18 09:49:55 -0500
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=94c98185fdc65a9e048303b3bbc40949f61b0fc3">94c98185fdc65a9e048303b3bbc40949f61b0fc3</a>
-<blockquote>
-<p>
- jbig2dec: release huffman table memory properly<br>
-<br>
- Freeing huffman table memory didn't use the jbig2dec allocator call, just called<br>
- &quot;free&quot; directly. Caused a crash if the caller uses a custom allocator.<br>
-<br>
- No cluster differences.<br>
-<br>
-jbig2dec/jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-23 08:14:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=375fc31051400eda284cd450ea108317489ea8a0">375fc31051400eda284cd450ea108317489ea8a0</a>
-<blockquote>
-<p>
- remove an unused variable to silence a compiler warning<br>
-<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-22 14:15: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=adcbb5795f02903c71504faa9dd26fdfee69c9f3">adcbb5795f02903c71504faa9dd26fdfee69c9f3</a>
-<blockquote>
-<p>
- Fix bug 696201. Regression caused by fast HT fixes commit 695065f2<br>
-<br>
- The entire threshold array was not being initialized to the max value<br>
- when num_repeats &gt; 1. Apparently this is rare.<br>
-<br>
-base/gsht.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-22 14:05: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=a711e36640bde6b4d76e51de5e2d57124bb49ff7">a711e36640bde6b4d76e51de5e2d57124bb49ff7</a>
-<blockquote>
-<p>
- Get rid of &quot;magic number&quot; returns from compositor is_closing proc<br>
-<br>
- Instead use enums that are somewhat mnemonic. We hate magic numbers.<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevp14.c<br>
-base/gscompt.h<br>
-base/gsovrc.c<br>
-base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-18 13:39:58 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d04e52b3b4bb2a0dd03d70d31630b3e79c0fb31">0d04e52b3b4bb2a0dd03d70d31630b3e79c0fb31</a>
-<blockquote>
-<p>
- Convert constants used by 'is_closing' compositor proc to menmonic enums<br>
-<br>
- These had used constants that were a source of wasted time when working on<br>
- compositors since one had to hunt around for the 'meaning' of constant<br>
- numeric values. Change to using a gs_compositor_closing_state enum with<br>
- somewhat meaningful names.<br>
-<br>
-base/gdevdflt.c<br>
-base/gdevp14.c<br>
-base/gscompt.h<br>
-base/gsovrc.c<br>
-base/gxclrast.c<br>
-base/gxcomp.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-22 20:36: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=c48fb6fb210b852d4156ea303c3ba0e9060c7a75">c48fb6fb210b852d4156ea303c3ba0e9060c7a75</a>
-<blockquote>
-<p>
- Bug 696052: Check that cloned image exists before proceeding further.<br>
-<br>
-jbig2dec/jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-18 23:15: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=54510dd67d4f1344fda4e913be9c70341e453fe8">54510dd67d4f1344fda4e913be9c70341e453fe8</a>
-<blockquote>
-<p>
- pdfwrite - yet more symbolic font meddling<br>
-<br>
- Bug #696207 &quot;Creation of PDF/A-1b from PDF results in missing characters&quot;<br>
-<br>
- The previous fix for symbolic fonts could lead to a situation where we emitted<br>
- an embedded, subset, symbolic TrueType font, bu put a /Encoding in the font.<br>
-<br>
- This is invalid for PDF/A-1 and also causes Acrobat to do strange things with<br>
- the CMAP subtable(s) in the font. This commit should ensure (by synchronising<br>
- the tests) that we don't emit symbolic TT fonts with an Encoding.<br>
-<br>
- Checking with the test file for bug 695969 indicates that the code still<br>
- works for that case too.<br>
-<br>
- This has unfortunatley required some re-organisation of data structure<br>
- declarations.<br>
-<br>
- I think we won't be able to reliably have this work until the TrueType font<br>
- embedding code is rewritten.<br>
-<br>
- In any event the heuristics seem improved again.<br>
-<br>
-devices/vector/gdevpdtd.c<br>
-devices/vector/gdevpdtd.h<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-18 20:22:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=128b24a5c42f0cb73f4b3c39fabb2fb46707af8a">128b24a5c42f0cb73f4b3c39fabb2fb46707af8a</a>
-<blockquote>
-<p>
- txtwrite - cater for empty strings<br>
-<br>
- Bug #696212 &quot;txtwrite: pdfs generated by JasperReports cause segfault in gs&quot;<br>
-<br>
- The PDF file contains an operation of the form () Tj The empty string<br>
- means that we don't process the text (because there is none) resulting in<br>
- uninitialised data later.<br>
-<br>
- Fixed by ignoring emtpy strings.<br>
-<br>
-devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-15 10:24: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=478dda05a6a4b3b1f8ce2a934fb0f60870d2fc98">478dda05a6a4b3b1f8ce2a934fb0f60870d2fc98</a>
-<blockquote>
-<p>
- Fix pdf14 compositor/ICC reference counting problems.<br>
-<br>
- One reference counting issue whereby the code originally assumed it would be<br>
- moving an existing ICC profile reference, rather than creating a new reference<br>
- (thus no reference counting was done) and it transpired that in certain cases<br>
- a new profile could end up being created - thus reference counting was required<br>
- to ensure that, in the case where a newly created profile was used, it would<br>
- also be freed as required. In this case, one of the places where the reference<br>
- was removed did not decrement the reference count.<br>
-<br>
- Secondly, in the event of the compositor being interrupted (by an error or user<br>
- intervention) between push group and pop group operations, when we come to<br>
- finalize the compositor device, we have to emulate the ICC profile restorations<br>
- that happen during a pop group, so all the references and reference counts end<br>
- up back where they were when the push group happened.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-15 10:15: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=f894956b58e3e5c9a2238c0cd66a98d803c7c117">f894956b58e3e5c9a2238c0cd66a98d803c7c117</a>
-<blockquote>
-<p>
- Fix memory leak with pattern clists.<br>
-<br>
- The clist reader's ICC cache gets recreated every time we execute a clist,<br>
- but previously the code did not take action to clean it up, this the<br>
- reference count was wrong, and we leaked memory.<br>
-<br>
- Whilst it may be preferable to have it persist, in the short term, it seems<br>
- safer to cleanup after clist playback, as that is functionally the same as the<br>
- existing behaviour.<br>
-<br>
- No cluster differences<br>
-<br>
-base/gxp1fill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-15 10:11:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2432584e6bb6a257c47261430d1cd8ef3e71c9c4">2432584e6bb6a257c47261430d1cd8ef3e71c9c4</a>
-<blockquote>
-<p>
- Cleanup after error in clist<br>
-<br>
- If an error (or interrupt) occurs during clist replay, ensure we tidy up<br>
- the memory buffer device that the clist renders into before propagating<br>
- the error.<br>
-<br>
- No cluster differences<br>
-<br>
-base/gxclread.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-15 10:07: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=b7fffb5a7429cfd1f0716c98f1b71f57eda653dc">b7fffb5a7429cfd1f0716c98f1b71f57eda653dc</a>
-<blockquote>
-<p>
- Change memcpy to memmove<br>
-<br>
- valgrind reported overlapping memory regions in a memcpy, so change it to<br>
- memmove which copes with such cases.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/gxclfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-15 11:02:46 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=989f7afffdbf49d6b385f3e817a0dc7a736f13bc">989f7afffdbf49d6b385f3e817a0dc7a736f13bc</a>
-<blockquote>
-<p>
- Prevent crash with reference count debugging (-Z^)<br>
-<br>
- The garbage collector makes no promises about the order in which objects are<br>
- swept. As a result, it is possible for a forwarding device to remain unswept<br>
- after its target has already.<br>
-<br>
- To handle such relationships, the garbage collector leaves memory contents alone<br>
- until the entire sweep is complete, so the forwarding device's decrement of the<br>
- target reference count is safe. However, with rc debugging active, the debugging<br>
- code attempts to ascertain the object type by interrogating the memory header,<br>
- which the garbage has, by now, userped for it's own uses - causing a crash.<br>
-<br>
- By setting the rc.memory pointer to NULL when the target device is finalized,<br>
- the rc debugging code is kept happy.<br>
-<br>
- In the non-gc case, the finalize is the very last thing to happen before the<br>
- memory is actually freed, thus the memory pointer is moot by that stage.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-16 20:30: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=717a3d6e5e139d6cbb2474dbb44bf0ca2069d5b4">717a3d6e5e139d6cbb2474dbb44bf0ca2069d5b4</a>
-<blockquote>
-<p>
- eps2write - convert path bounding box to user space from device space<br>
-<br>
- Bug #696181 &quot;BoundingBox wrong when using eps2write in AIX environment&quot;<br>
-<br>
- I can't test this on an AIX setup, but for me the test file was incorrect<br>
- on Windows anyway.<br>
-<br>
- In order to find the marking extent of a (filled) path we intersect the<br>
- path with the current clipping path and check the extents of the resulting<br>
- rectangle against the extents of the current BBox.<br>
-<br>
- However, the result of the intersection is in device space, and we did not<br>
- 'undo' the resolution. Other places in the code *do* remove the scaling<br>
- due to resolution, so we simply adopt that here.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-15 12:55:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22dcf8215791732199f6b76a7d7e330b0b792931">22dcf8215791732199f6b76a7d7e330b0b792931</a>
-<blockquote>
-<p>
- Coverity ID #95039 - initialise a stack<br>
-<br>
- I don't think its possible for this to be a problem, but its pretty cheap to<br>
- do.<br>
-<br>
-devices/vector/gdevpsf1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-15 09:43: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=5772922322e908279196a77bddc6bd1d973f5f82">5772922322e908279196a77bddc6bd1d973f5f82</a>
-<blockquote>
-<p>
- Coverity ID #94682 check and action a return value.<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-14 13:38: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=c4d4f68db961ea0bebde67764fa3c7383277b6c2">c4d4f68db961ea0bebde67764fa3c7383277b6c2</a>
-<blockquote>
-<p>
- pdfwrite force XMP metadata emission when creating PDF/A<br>
-<br>
- Discovered while working on PCL -&gt; PDF/A, we need to have XMP metadata<br>
- emitted for PDF/A compatibility.<br>
-<br>
-devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-10 13:56: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=f077c60d6441d5dae58bcaeeab2977491f5dff66">f077c60d6441d5dae58bcaeeab2977491f5dff66</a>
-<blockquote>
-<p>
- Coverity ID #107437 check and action a return value<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-09 14:35: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=0dd8e231284a6c898cd21bb9d6f3e096282b3907">0dd8e231284a6c898cd21bb9d6f3e096282b3907</a>
-<blockquote>
-<p>
- Add a special finalize method for the pdf14 compositor<br>
-<br>
- In the event of an error, the pdf14 compositor device can be part way through<br>
- accumulating its data. Add a finalize method to discard stuff that might remain<br>
- before the device itself is freed.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-08 09:30:16 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=28989d155efe5db7f2ea5f4477a7e654f5402470">28989d155efe5db7f2ea5f4477a7e654f5402470</a>
-<blockquote>
-<p>
- Bug 696178: avoid var overflow with large CFF font<br>
-<br>
- If a CFF/Type 2 font has a large number of (g)subrs, the remaining buffer size<br>
- when we come to recreate the font for Freetype could be larger than 64435<br>
- bytes, and this could overflow the usigned short parameter we pass to the<br>
- helper function which extracts and stores each (g)subr.<br>
-<br>
- As I doubt we'll see a font with a single (g)subr of more than 65535 bytes, I'm<br>
- just clamping the value to the usigned short range.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/write_t2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-07 20:32:35 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=08c278231e4fa357cb4a8b001b751b132819c739">08c278231e4fa357cb4a8b001b751b132819c739</a>
-<blockquote>
-<p>
- Change cluster host from casper.ghostscript.com to cluster.ghostscript.com.<br>
-<br>
-toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-04 10:28:54 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bd02324382fc0f97674ad29235600e498566fb16">bd02324382fc0f97674ad29235600e498566fb16</a>
-<blockquote>
-<p>
- Prevent leak if device subclassing fails.<br>
-<br>
- Move a check earlier, before any allocations.<br>
- Also fix a divide by zero problem seen while testing with the spotcmyk<br>
- device and -dFirstPage=2 on tests_private/comparefiles/86554321.pdf<br>
-<br>
-base/gdevdflt.c<br>
-base/gxdevndi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-03 08:53: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=0ed9597158122a9200b6e973fbb0810bbf97e1eb">0ed9597158122a9200b6e973fbb0810bbf97e1eb</a>
-<blockquote>
-<p>
- Remove the moribund pdf_cslayer.ps etc.<br>
-<br>
- THe BMC/BDC/EMC marked content operators are now handled fully in the PDF<br>
- interpreter &quot;proper&quot; and this original handling has not been touched or used<br>
- (or even built-in) since it's original authoring 7 years ago.<br>
-<br>
- No cluster differences.<br>
-<br>
-Resource/Init/pdf_cslayer.ps<br>
-psi/int.mak<br>
-psi/psromfs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-09-01 09:54: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=66fc00c563bfbbb3736159f646b58666fe444c55">66fc00c563bfbbb3736159f646b58666fe444c55</a>
-<blockquote>
-<p>
- Don't require Type 42 fonts to have copyrigth information<br>
-<br>
- Bug #696174 &quot;Error: /invalidfont in --show--&quot;<br>
-<br>
- The problem occurs because the embedded type 42 fonts don't include a<br>
- Copyright entry in the names table. When copying fonts, we try to copy the<br>
- copyright information, and it fails which results in an invalid font error.<br>
-<br>
- Clearly we want to copy the information if its present, but its absence<br>
- shouldn't be regarded as an error, so this commit simply ignores the return<br>
- value when we try to copy the copyright information.<br>
-<br>
-base/gstype42.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-31 22:24:25 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=57ed8b1f0accfa6364bf0fc0699d0bab22b79ac2">57ed8b1f0accfa6364bf0fc0699d0bab22b79ac2</a>
-<blockquote>
-<p>
- Fix mistake in spot color value collection in gprf device<br>
-<br>
-devices/gdevgprf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-31 12: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=3bd0059f57389a935c8ec35a92fdb8d5263d4e1c">3bd0059f57389a935c8ec35a92fdb8d5263d4e1c</a>
-<blockquote>
-<p>
- pdfwrite - a missed SMask case<br>
-<br>
- Commit 937bfdbc0c6204ae0be40b1ed1c4bb880568d6be which was to fix a Coverity<br>
- detected problem uncovered a missing case in the new SMask handling. We need<br>
- to check for the soft mask ID having changed when we start accumulating a<br>
- pattern.<br>
-<br>
- Good catch there from Coverity.<br>
-<br>
-devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-31 08:39: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=1ca58566f41417aac93a5cba0b757ddfdb8bd2a7">1ca58566f41417aac93a5cba0b757ddfdb8bd2a7</a>
-<blockquote>
-<p>
- Coverity ID #107342 another return value check<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-31 08:36: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=937bfdbc0c6204ae0be40b1ed1c4bb880568d6be">937bfdbc0c6204ae0be40b1ed1c4bb880568d6be</a>
-<blockquote>
-<p>
- Coverity ID #107346 check and action a return value<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-27 11:10:31 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=55203d93e86974ee974c441d567c27b06507e98e">55203d93e86974ee974c441d567c27b06507e98e</a>
-<blockquote>
-<p>
- Remove the compressed_color_encoding that has not been used for a while.<br>
-<br>
-base/gdevdbit.c<br>
-base/gdevdevn.c<br>
-base/gdevdevn.h<br>
-base/gdevp14.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-28 12:22: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=0877e6183221beb559e02e8aed87efa9cb65064a">0877e6183221beb559e02e8aed87efa9cb65064a</a>
-<blockquote>
-<p>
- Rename gproof device to gprf.<br>
-<br>
- The device produces .gprf files, not .gproof ones, and gs<br>
- never actually touches a .gproof file, so the name is<br>
- definitely wrong as is.<br>
-<br>
-devices/gdevgprf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-28 12:00:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3d3982f844fed6d6cb092055980900289fb6a402">3d3982f844fed6d6cb092055980900289fb6a402</a>
-<blockquote>
-<p>
- Add &quot;safe&quot; defaults for the FT and LCMS2 source dirs<br>
-<br>
- So we don't risk (too much) finding spurious headers for wrong versions<br>
- when linking to shared libraries for Freetype and LittleCMS2, use the same<br>
- safe default (&quot;src&quot;) as the other shared libs.<br>
-<br>
- No cluster differences<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-28 11:13:36 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cdc41ce6ddbb7b0233645c750ccfbf6eb927a5c6">cdc41ce6ddbb7b0233645c750ccfbf6eb927a5c6</a>
-<blockquote>
-<p>
- Add gprf device to Unix builds.<br>
-<br>
- No cluster diffs.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-28 11:06: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=5ba6e5c4488b6dca2530e772086dd7d45d99709d">5ba6e5c4488b6dca2530e772086dd7d45d99709d</a>
-<blockquote>
-<p>
- Check for _cmsCreateMutex in lcms2<br>
-<br>
- When checking for a usable system lcms2 library, check that it contains the<br>
- _cmsCreateMutex() - that ensures we get a sufficiently up to date version<br>
-<br>
- No cluster diffs<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-26 12:11: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=c6c744cf1634bf7e8a90f4a404ee019ba73451d1">c6c744cf1634bf7e8a90f4a404ee019ba73451d1</a>
-<blockquote>
-<p>
- Update the example &quot;fixed&quot; makefiles<br>
-<br>
- This provides an example/start point for unix-like systems that don't,<br>
- for whatever reason, want to use the autoconf build.<br>
-<br>
- No cluster differences<br>
-<br>
-base/unix-gcc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-26 12:07:36 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=95acc209c0522c16c985b5916c1043471635e8e3">95acc209c0522c16c985b5916c1043471635e8e3</a>
-<blockquote>
-<p>
- If no libtiff, leave out xpswrite<br>
-<br>
- xpswrite depends on libtiff, so it libtiff isn't available we need to leave out<br>
- the xpswrite devices<br>
-<br>
- No cluster differences<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-27 09:45:49 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3b20ec9955f6b7e48c90d9a021d1511e03b67977">3b20ec9955f6b7e48c90d9a021d1511e03b67977</a>
-<blockquote>
-<p>
- Fixes PCL crash when a new ICC directory is specified on the command<br>
- line.<br>
-<br>
- The library context must use the same allocator to create and free the<br>
- icc directory string. The memory parameter passed in is not necessarily<br>
- the same as the original. For example the PCL client wraps the<br>
- allocator to use the chunk allocator after the icc directory string is<br>
- created (part of gs_malloc_init). This can result in memory being<br>
- managed by 2 different memory handlers. Fortunately the original memory<br>
- pointer was tucked in the library context structure and that can be used<br>
- instead of the parameter passed in.<br>
-<br>
- There are other areas in the library context code that need to be<br>
- checked for this same problem, and a discussion about how this might be<br>
- handled better is in the works.<br>
-<br>
-base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-27 08:18:06 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=57b90f1c71fc4ae03051917fe912c3917702ba91">57b90f1c71fc4ae03051917fe912c3917702ba91</a>
-<blockquote>
-<p>
- Fix PCL crash if no device argument is specified.<br>
-<br>
- The previous change (0eac574ee24) to have PCL use the graphics library<br>
- default device list did not account for a missing device on the command<br>
- line. The change intended to remove the check for an index &lt; 0 at the<br>
- beginning of the pl_top_create_device() procedure.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-27 13:28: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=7f17c1ddae39841ef1b2bbef84cc3c95cf2e1685">7f17c1ddae39841ef1b2bbef84cc3c95cf2e1685</a>
-<blockquote>
-<p>
- pdfwrite - improved SMask handling<br>
-<br>
- This follows on from commit 1a319a9, in that commit we included the soft mask<br>
- ID in the graphics state we were tracking (in fact it was present in the<br>
- structure, but untracked). This did resolve the problem adequately, but left<br>
- us emitting graphics states with /SMask /None entries in order to remove<br>
- some kinds of SMask.<br>
-<br>
- A neater solution, implemented here, is to use gsave and grestore instead.<br>
-<br>
- Thia is committed separately as it marks a significant change in the way<br>
- pdfwrite works. Previously only clips were handled by using gsave and grestore<br>
- and I'm slightly concerned that this may not work completely seamlessly<br>
- with this change.<br>
-<br>
- This exhibits some slight halftoning differences with Altona_Technical_v20_x4.pdf<br>
- and Bug692368.pdf, and some invisible to the naked eye differences in<br>
- Bug690534.pdf, Bug694290.pdf 1439_color_softmask_filas_to_draw_jpx_image.pdf<br>
-<br>
- Progressions are seen in 586_-_missing_images_gs_SMask_not_applied.pdf<br>
- multiply_luminosity_masks_ignored.pdf and x_-_renders_slowly.pdf<br>
-<br>
-devices/vector/gdevpdfd.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdft.c<br>
-devices/vector/gdevpdfx.h<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-27 11:44: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=1a319a93c147eb14a0791d837bb7f1c5dfd81a3c">1a319a93c147eb14a0791d837bb7f1c5dfd81a3c</a>
-<blockquote>
-<p>
- pdfwrite - track soft mask IDs in our saved graphcs states<br>
-<br>
- Bug #695250 &quot;Missing text from pdfwrite&quot;<br>
-<br>
- The problem was that we were not tracking soft mask IDs in our saved copies<br>
- of the graphics state, which meant that we were not properly adding (or<br>
- removing) when creating ExtGStates in pdf_update_alpha().<br>
-<br>
- This addresses the specific issue in the bug, as well as showing progressions<br>
- in the test file x_-_renders_slowly.pdf (missing Qt logo now appears)<br>
-<br>
- However, a more ambitious treatment, which better tracks gsave/grestore by<br>
- actually emitting q/Q operations seems to show still further improvement.<br>
- I'm going to add this as a separate commit as, despite the progressions,<br>
- I'm a little unsure about it.<br>
-<br>
-devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-25 22:45:23 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=11c1290bab401e84785c731bd8a931bb3bc66c44">11c1290bab401e84785c731bd8a931bb3bc66c44</a>
-<blockquote>
-<p>
- Fix mixup in what is the plane raster vs the row raster in gproof device_procs<br>
-<br>
- The icc code had several issues as we converted the chunks of 256 planer lines<br>
- of data. The various paths tested out correctly with gsview on windows after<br>
- these fixes.<br>
-<br>
-devices/gdevgprf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-26 07:54: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=69b0e7d39eae1b2a20738258dec0efcd1b38a271">69b0e7d39eae1b2a20738258dec0efcd1b38a271</a>
-<blockquote>
-<p>
- Include romfs in the static lib build<br>
-<br>
- No cluster differences.<br>
-<br>
-base/unixlink.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-25 09:28: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=7459309630cf63fd791bfd1a79e2f3ac47d92b70">7459309630cf63fd791bfd1a79e2f3ac47d92b70</a>
-<blockquote>
-<p>
- Fix the gs static library target<br>
-<br>
- The recent build reorganisation broke the gs.a target, meaning an incomplete<br>
- set of object files were included in the library file.<br>
-<br>
- No cluster differences<br>
-<br>
-base/gs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-24 17:38: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=8fcea1fef23c45a81ad5d13a5e3afd5662e0efef">8fcea1fef23c45a81ad5d13a5e3afd5662e0efef</a>
-<blockquote>
-<p>
- Bug 696126 (2): PCL/XPS should (sort of) ignore COMPILE_INITS (for now)<br>
-<br>
- As the PCL and XPS exes *must* have the icc profiles available in a romfs, they<br>
- will paretially ignore the COMPILE_INITS setting, and always use a rom file<br>
- system for the ICC profiles. COMPILE_INITS=0 will cause PCL to not include<br>
- it's fonts in the romfs.<br>
-<br>
- This means always including the romfs I/O code in the graphics library, then<br>
- building an empty romfs into Ghostscript for COMPILE_INITS=0, and the romfs i/o<br>
- will now return gs_error_unregistered from its file_status method if<br>
- the empty romfs is found (identified by gs_romfs_buildtime being zero).<br>
-<br>
- No cluster differences.<br>
-<br>
-base/gs.mak<br>
-base/gsiorom.c<br>
-base/gsromfs0.c<br>
-base/lib.mak<br>
-psi/imain.c<br>
-psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-24 15:33: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=a32ece5ee924a6a4a581f7e6dd298f9d9af6d475">a32ece5ee924a6a4a581f7e6dd298f9d9af6d475</a>
-<blockquote>
-<p>
- Bug 696126: tweak error checking for graphics state creation<br>
-<br>
- We need to check and handle a failure to create a graphics state before trying<br>
- to initialise the ICC profile handling to prevent a crash<br>
-<br>
- No cluster differences<br>
-<br>
-pcl/pcl/pctop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-05 09:19: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=67aad48044024b9c198c72304971055a288322d9">67aad48044024b9c198c72304971055a288322d9</a>
-<blockquote>
-<p>
- Latest fonts with updated cyrillic and greek glyphs<br>
-<br>
-Resource/Font/BookmanURW-DemBol<br>
-Resource/Font/BookmanURW-DemBolIta<br>
-Resource/Font/BookmanURW-Lig<br>
-Resource/Font/BookmanURW-LigIta<br>
-Resource/Font/CenturySchL-Bold<br>
-Resource/Font/CenturySchL-BoldItal<br>
-Resource/Font/CenturySchL-Ital<br>
-Resource/Font/CenturySchL-Roma<br>
-Resource/Font/CenturySchURW-Bol<br>
-Resource/Font/CenturySchURW-BolIta<br>
-Resource/Font/CenturySchURW-Ita<br>
-Resource/Font/CenturySchURW-Rom<br>
-Resource/Font/ChanceryURW-MedIta<br>
-Resource/Font/NimbusMono-Bold<br>
-Resource/Font/NimbusMono-BoldOblique<br>
-Resource/Font/NimbusMono-Oblique<br>
-Resource/Font/NimbusMono-Regular<br>
-Resource/Font/NimbusRomNo9L-Med<br>
-Resource/Font/NimbusRomNo9L-MedIta<br>
-Resource/Font/NimbusRomNo9L-Reg<br>
-Resource/Font/NimbusRomNo9L-RegIta<br>
-Resource/Font/NimbusSanL-Bol<br>
-Resource/Font/NimbusSanL-BolIta<br>
-Resource/Font/NimbusSanL-BoldCond<br>
-Resource/Font/NimbusSanL-BoldCondItal<br>
-Resource/Font/NimbusSanL-Reg<br>
-Resource/Font/NimbusSanL-RegIta<br>
-Resource/Font/NimbusSanL-ReguCond<br>
-Resource/Font/NimbusSanL-ReguCondItal<br>
-Resource/Font/NimbusSanNar-Bol<br>
-Resource/Font/NimbusSanNar-BolIta<br>
-Resource/Font/NimbusSanNar-Ita<br>
-Resource/Font/NimbusSanNar-Reg<br>
-Resource/Font/PalladioURW-Bol<br>
-Resource/Font/PalladioURW-BolIta<br>
-Resource/Font/PalladioURW-Ita<br>
-Resource/Font/PalladioURW-Rom<br>
-Resource/Font/URWBookmanL-DemiBold<br>
-Resource/Font/URWBookmanL-DemiBoldItal<br>
-Resource/Font/URWBookmanL-Ligh<br>
-Resource/Font/URWBookmanL-LighItal<br>
-Resource/Font/URWChanceryL-MediItal<br>
-Resource/Font/URWGothic-Boo<br>
-Resource/Font/URWGothic-BooObl<br>
-Resource/Font/URWGothic-Dem<br>
-Resource/Font/URWGothic-DemObl<br>
-Resource/Font/URWGothicL-Book<br>
-Resource/Font/URWGothicL-BookObli<br>
-Resource/Font/URWGothicL-Demi<br>
-Resource/Font/URWGothicL-DemiObli<br>
-Resource/Font/URWPalladioL-Bold<br>
-Resource/Font/URWPalladioL-BoldItal<br>
-Resource/Font/URWPalladioL-Ital<br>
-Resource/Font/URWPalladioL-Roma<br>
-Resource/Init/Fontmap.GS<br>
-psi/psromfs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-21 09:12:16 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4084d87a0ff7c66ecf0b9ece65f9cd9da496c15b">4084d87a0ff7c66ecf0b9ece65f9cd9da496c15b</a>
-<blockquote>
-<p>
- Bug 696161: ensure we have a show enumerator object<br>
-<br>
- before using it as such - it is possible (via an invalid configuration) to get<br>
- a text enumerator, and treating that as a show enumerator can cause a crash.<br>
-<br>
- Similarly, ensure we have a graphics state (and not just an imager state).<br>
-<br>
- Found and fix suggested by Ken.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/gxchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-21 18:01:46 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=849891b1577e3caab4c73f0bfa5c27a7308e1ffc">849891b1577e3caab4c73f0bfa5c27a7308e1ffc</a>
-<blockquote>
-<p>
- GProof: Component names from devn_params are not null terminated.<br>
-<br>
- Use the given length, not strlen.<br>
-<br>
-devices/gdevgprf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-20 11:00: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=a45d3714ad03c67cee37d6ec29a8eda0fc2e937f">a45d3714ad03c67cee37d6ec29a8eda0fc2e937f</a>
-<blockquote>
-<p>
- vector devices - prevent the use of Graphics and TextAlphaBits<br>
-<br>
- The GraphicsAlphaBits and TextAlphaBits parameters don't make sense and don't<br>
- work with the vector devices, with the exception of rendering transparency.<br>
- In addition they can potentially cause seg faults and other errors.<br>
-<br>
- Although we've always had code to detect the use of this at rendering<br>
- time, this hasn't stopped people from pointlessly using them.<br>
-<br>
- To prevent such foolishness (at the expense of transparency flattening, which<br>
- is a very minor usage) this commit prints a warning and throws an error on<br>
- attempts to use these switches with vector devices.<br>
-<br>
- Additionally update the documentation to make it clear that this is not<br>
- permitted.<br>
-<br>
-base/gdevvec.c<br>
-devices/vector/gdevpsdu.c<br>
-doc/Devices.htm<br>
-doc/Language.htm<br>
-doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-21 18:12:46 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=55af534b9d621d7ae8a2d6818369dc468514841b">55af534b9d621d7ae8a2d6818369dc468514841b</a>
-<blockquote>
-<p>
- Add gprf device to Windows builds.<br>
-<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-19 15:34: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=af72527ff3b08ff91230a0884ce601b949735cf6">af72527ff3b08ff91230a0884ce601b949735cf6</a>
-<blockquote>
-<p>
- pdfwrite - consider both X and Y axes when deciding on downsampling<br>
-<br>
- Bug #696152 &quot;gs no more rendering figure inside the frame&quot;<br>
-<br>
- The decision on downsampling is taken by comparing the image resolution<br>
- against the downsampling threshold. Previously we only considered the<br>
- resolution in the X direction, assuming (not entirely unreasonably) that<br>
- the image would be of similar resolution in each direction.<br>
-<br>
- However in this case the image is massively scaled (and therefore has a<br>
- practical very high resolution) in the X direction, but is barely scaled<br>
- at all in the Y direction.<br>
-<br>
- Downsampling this image caused the height of the image to be reduced to 1<br>
- whcih effectively caused it to disappear.<br>
-<br>
- No differences expected.<br>
-<br>
-devices/vector/gdevpsdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-19 14:20: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=ac4b3ca63dbb4f51aaae6d6e927672ebde207326">ac4b3ca63dbb4f51aaae6d6e927672ebde207326</a>
-<blockquote>
-<p>
- pdfwrite - fix an 'unescape' for \b<br>
-<br>
- Bug #696147 &quot;\b is converted into 007 in devices/vector/gdevpdfm.c&quot;<br>
-<br>
- Picked up, and fix provided, by popjussi (at gmail.com)<br>
-<br>
- The code is pretty clearly an 'off by 1' error when converting the<br>
- escaped character code into an octal number.<br>
-<br>
- No differences expected<br>
-<br>
-devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-18 14:27: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=0eac574ee24b9567743906721039fa0279ab3175">0eac574ee24b9567743906721039fa0279ab3175</a>
-<blockquote>
-<p>
- Use default device list for PCL/XPS<br>
-<br>
- Previously, the PCL and XPS executables would simply default to the first<br>
- device in the graphics library's device list, and ignore the actual compile<br>
- time set default device list.<br>
-<br>
- It now uses the graphics library's default device list, bringing it inline<br>
- with Ghostscript.<br>
-<br>
- No cluster differences.<br>
-<br>
-pcl/pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-18 16:07: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=021277d531aa5ba13cfcbfde5bc1a6012db54fd7">021277d531aa5ba13cfcbfde5bc1a6012db54fd7</a>
-<blockquote>
-<p>
- Bug 696150: make allocator available to init jpeg state in gdevpx.c<br>
-<br>
- When I changed the JPEG state API, it seems I missed one of the instances<br>
- of its use - now fixed.<br>
-<br>
- Identified by Dmitry Pankratov.<br>
-<br>
- No cluster differences.<br>
-<br>
-devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-18 15:44:16 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d552e3ba3ed5a3e43062ee5bb1778787bff829ff">d552e3ba3ed5a3e43062ee5bb1778787bff829ff</a>
-<blockquote>
-<p>
- Add a target to build only the unix shared lib<br>
-<br>
- The &quot;so-only&quot; target will build the .so shared library, and the associated<br>
- sym links, but not the &quot;loader&quot; executables.<br>
-<br>
- This is useful for building/cross compiling the .so when you haven't got<br>
- the dependencies available for the executables (x11, gtk etc).<br>
-<br>
- No cluster differences<br>
-<br>
-base/unix-dll.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-18 13:47: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=9238bb855cae9ac53b6cf2b95e3b070f3de69a38">9238bb855cae9ac53b6cf2b95e3b070f3de69a38</a>
-<blockquote>
-<p>
- Recursive make calls use -f &quot;makefile name&quot; option<br>
-<br>
- The recursive make calls previously relied<br>
- on the makefile being the default name &quot;Makefile&quot; - by passing the name of<br>
- the makefile to the sub-call, we can use custom makefile names.<br>
-<br>
- Currently only works for GNU make (detected in configure).<br>
-<br>
- For this to work, if you rename the makefile, you must also edit the name in<br>
- the &quot;MAKEFILE&quot; variable to match your custom makefile name.<br>
-<br>
- No cluster differences.<br>
-<br>
-Makefile.in<br>
-base/unix-dll.mak<br>
-base/unix-end.mak<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-18 14:33: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=0e30e7c64f4001adfa5fe376e4cd9ab184903b55">0e30e7c64f4001adfa5fe376e4cd9ab184903b55</a>
-<blockquote>
-<p>
- Bug 696149: tweak under/overflow prevention in FAPI/UFST<br>
-<br>
- Due to limits of the fixed point arithmetic in the UFST, we have to balance<br>
- various scale factors at extreme scales (scale matrix, font size, &quot;resolution&quot;)<br>
- to ensure varaibles don't over/under flow.<br>
-<br>
- It looks like there was a typo, or just a mistake in how two of the factors<br>
- were being scaled relative each other which could cause *extremely* small<br>
- scale factors to end up as *extremely* large scale factors.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/fapiufst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-17 11:38:42 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e607d6afe7afde57f5f2218f5a7ec267a95a45e4">e607d6afe7afde57f5f2218f5a7ec267a95a45e4</a>
-<blockquote>
-<p>
- Split fonts files out from romfs args<br>
-<br>
- Have each interpreter specify it's font files separately from any other<br>
- resources for inclusion in the romfs. That means when integrating the UFST<br>
- into the build, we can automatically leave out the font files, whilst including<br>
- the FCO files.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/lib.mak<br>
-pcl/pl/plromfs.mak<br>
-psi/psromfs.mak<br>
-xps/xpsromfs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-18 19:51:16 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fc9afb317f3f3e1af5c74fcf381af50a28328acd">fc9afb317f3f3e1af5c74fcf381af50a28328acd</a>
-<blockquote>
-<p>
- GProof: Trade performance for compression.<br>
-<br>
- Use Z_BEST_SPEED rather than Z_BEST_COMPRESSION when saving the<br>
- raster data.<br>
-<br>
-devices/gdevgprf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-18 12:42: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=98b136b5343998849d983e9c508e6f6047cdec64">98b136b5343998849d983e9c508e6f6047cdec64</a>
-<blockquote>
-<p>
- GProof device: Fix no-icc rgb generation.<br>
-<br>
- Derefence pointers to get colour values, rather than using the<br>
- pointers themselves as colour values.<br>
-<br>
-devices/gdevgprf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-17 08:20: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=828b99f459b17f8537eae96694d745409a577469">828b99f459b17f8537eae96694d745409a577469</a>
-<blockquote>
-<p>
- PDF interpreter - Attempt to validate the ICCBased /N value for color spaces<br>
-<br>
- Bug #696120 &quot;Invalid PDF to TIFF conversion&quot;<br>
-<br>
- The supplied specimen file is incorrect, it has an ICCBased colour space<br>
- which contains the /N key (number of channels) set to a value of 3, but<br>
- the actual profile is a gray profile, and therefore /N should be 1.<br>
-<br>
- Here we add a new function .numicc_components which attempts to find the<br>
- number of components from an ICC profile (returns 0 if it can't determine<br>
- the value). We then use that returned value to compare to the actual<br>
- /N value given. If the two don't match, and the calculated value is non-zero<br>
- then we use the calculated value instead, and alter the value of /N.<br>
-<br>
- One file in the cluster test suite is shown as different, but it is visually<br>
- the same.<br>
-<br>
- In passing, remove some unused variables and commented out code from zicc.c<br>
- to silence some compiler warnings.<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-psi/zicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-14 12:18:14 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6ebd1b211bda59c5d2a70c423f3539a8e11d1bce">6ebd1b211bda59c5d2a70c423f3539a8e11d1bce</a>
-<blockquote>
-<p>
- Bug 696092 - fix memory leak in the X driver.<br>
-<br>
- Thanks to Hin-Tak Leung for providing a patch to cleanup when the X<br>
- device closes.<br>
-<br>
-devices/gdevxini.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-14 17:48:11 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c50adbe72f3e8a07c96127a4df9d78b422acf22a">c50adbe72f3e8a07c96127a4df9d78b422acf22a</a>
-<blockquote>
-<p>
- MSVC Solution: Adjust output location.<br>
-<br>
- Output location had not been adjusted to allow for the projects<br>
- being moved to a subdirectory.<br>
-<br>
-windows/All.vcproj<br>
-windows/ghostscript-ufst.vcproj<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-25 12:35:14 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=695065f2183049bafb8c468f1bc54996da7698dd">695065f2183049bafb8c468f1bc54996da7698dd</a>
-<blockquote>
-<p>
- Fix bug 695929. gx_ht_construct_threshold t_level calculation was wrong.<br>
-<br>
- Rewrite the threshold construction method. For num_levels &lt; 256 the<br>
- previous &quot;t_level_adjust&quot;, etc. were never invoked, but the logic for<br>
- the adjustment was incorrect (only worked for num_levels == 256).<br>
- This algorithm uses the same method for determining 'shade' as the<br>
- logic in gx_render_device_DeviceN which is used prior to setting up<br>
- the HT tile in the non-fast threshold code.<br>
-<br>
- The 'off' is eliminated since that caused threshold values that do not<br>
- match the HT tiling code, and the init_value and threshold values now<br>
- match those generated by the HT tiling code for num_levels &lt; 256.<br>
- Tested with 300 dpi and DITHERPPI values of 18, 24, 30, 33, 39, 52,<br>
- and 60 (the default).<br>
-<br>
- Also the size of images with the fast code was wrong (dest_width)<br>
- and the phase of the pixels did not match the image code (dda_init).<br>
- This also re-enables the fast code disabled with an earlier commit.<br>
- This was tested with tests/pdf/GridDownscaleTest0.pdf, modified to<br>
- test all rotations, and at 72, 300 and 1200 dpi.<br>
-<br>
- The transfer function is now pickled into the threshold array levels.<br>
- Although this causes some minor shade differences since the normal<br>
- cmap function calculates the shade from a frac (0-32760) and the<br>
- threshold has to select the shade from a byte value (0-255). The<br>
- 09-47N.PS test shows this.<br>
-<br>
- Also the texture screen_phase is used to adjust the thresholds when<br>
- filling the threshold buffer.<br>
-<br>
- This collection of changes fixes the customer bug, also seen with<br>
- 12-07B.PS and reduces the number of differences to the non-fast HT<br>
- code from 3931 to 1026. The 12-07B.PS still shows a screen angle<br>
- issue (page 3) that occurs when num_repeat &gt; 0, but changing the logic<br>
- results in a marked increase in the number of differences. Also, xl<br>
- tests show some phase shift in Y that remains unexplained.<br>
-<br>
- All other diffs appear to be transfer function related<br>
-<br>
- fixup<br>
-<br>
-base/gsht.c<br>
-base/gxdht.h<br>
-base/gxht_thresh.c<br>
-base/gxht_thresh.h<br>
-base/gxicolor.c<br>
-base/gximono.c<br>
-base/gzht.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-14 15:13: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=6a90174e403131c372acf19e1d63e5d202333503">6a90174e403131c372acf19e1d63e5d202333503</a>
-<blockquote>
-<p>
- Validate SMask object before evaluating it.<br>
-<br>
- and if it's not valid, replace the object with /None<br>
-<br>
- Relates to test file:<br>
- tests_private/pdf/sumatra/broken_xobject_messing_up_clip_stack.pdf<br>
-<br>
- No cluster differences<br>
-<br>
-Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-10 12:57:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=819e651a61d16c636821b3281a3cc70ec434dbb7">819e651a61d16c636821b3281a3cc70ec434dbb7</a>
-<blockquote>
-<p>
- Ensure imager state is not marked as graphics state<br>
-<br>
- In various places in the pdf14 compositor device, we use local copies of the<br>
- imager state (so stuff specific to the pdf14 compositor functions doesn't<br>
- accidentally affect the &quot;upstream&quot; state).<br>
-<br>
- This ensures that those copies are not marked as being a graphics state, in case<br>
- the imager state started life as a full graphics state.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-10 09:34: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=91e952779b18b3db612c96d898cd3c6f6c433ca7">91e952779b18b3db612c96d898cd3c6f6c433ca7</a>
-<blockquote>
-<p>
- Bug 696127: add missing tiffscaled* devs to configure build<br>
-<br>
- The tiffscaled4, tiffscaled8, tiffscaled24 and tiffscaled32 were missed from<br>
- the default list of TIFF devices in the configure based builds.<br>
-<br>
- No cluster differences.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-14 07:24:48 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b6538e2fac9dd4e7e423c4f974fcdd235626484">7b6538e2fac9dd4e7e423c4f974fcdd235626484</a>
-<blockquote>
-<p>
- Fix bug #694673, segmentation fault caused by &quot;fuzzing&quot; test.<br>
-<br>
- Deleting the current font resulted in later dereferencing an invalid<br>
- pointer to the font. We now set the current font to &quot;NULL&quot;. This<br>
- problem should not have required a fuzzing test to find it should have<br>
- been realized by the original CET 3.0 test.<br>
-<br>
-pcl/pxl/pxfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-11 14:57:06 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20d5f3dcf93022f843a8bba1e17594b768c85306">20d5f3dcf93022f843a8bba1e17594b768c85306</a>
-<blockquote>
-<p>
- Fix for bug 696124, character scaling with a singular matrix.<br>
-<br>
- By experiment HP does not ignore requests for font height which are out<br>
- of range, instead it clamps the values to the limits of the range. The<br>
- minimum is .25 points. The cet files in these bugs are requesting a<br>
- font size of 0 and the HP laserjet does render a very small character<br>
- which is visible but only readable with magnification assuming normal<br>
- vision.<br>
-<br>
- This change just allows the matrix to be scaled to the minimum value<br>
- allowing the test files in the bug to continue processing, these tiny<br>
- characters do not render properly even with this change. The rounding of<br>
- escapement would have to be worked in PCL and likely the font rasterizer<br>
- would need to be looked at, the characters do not appear correct even<br>
- with proper spacing.<br>
-<br>
- There is no practical demand to do this correctly, so we don't plan to<br>
- work on it anytime soon.<br>
-<br>
-pcl/pcl/pcfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-07 14:58: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=6ebbe34a5a5ae65a513f50970854032625d5a8db">6ebbe34a5a5ae65a513f50970854032625d5a8db</a>
-<blockquote>
-<p>
- Coverity ID #102065 prevent a potential NULL pointer derefernce<br>
-<br>
-base/gdevsclass.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-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=b22c02829e476a07a8c7fb93f919b2ea797a8791">b22c02829e476a07a8c7fb93f919b2ea797a8791</a>
-<blockquote>
-<p>
- Commit 6fb23cff7abcef91d03b43454d2d40d79c5e83da was actually incorrect.<br>
-<br>
- The Coverity report is a false positive, and the change causes a seg fault, fixed here.<br>
-<br>
- At the same time fix another fualt that prevented the cluster building<br>
- Ghostscript.<br>
-<br>
-devices/vector/gdevpdti.c<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-06 10:42: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=108ed487b6c24554b00e36f3b716fd37e427bd09">108ed487b6c24554b00e36f3b716fd37e427bd09</a>
-<blockquote>
-<p>
- Coverity ID #94769 restore saved FontMatrix on error<br>
-<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-06 10:39: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=ae73639179ec10c29d902f7e802e769bca70fd06">ae73639179ec10c29d902f7e802e769bca70fd06</a>
-<blockquote>
-<p>
- Coverity ID #94641 remove dead code<br>
-<br>
-devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-30 17:27:23 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1fae53a708fca6c2ac0417bc23f5d095cc379250">1fae53a708fca6c2ac0417bc23f5d095cc379250</a>
-<blockquote>
-<p>
- Bug 696101: fix uses of the sfopen API.<br>
-<br>
- The stream API in GS is defined as *always* opening files in binary mode,<br>
- where applicable, so there is no need for the API clients to specify binary<br>
- mode.<br>
-<br>
- This is previously been benign, and thus ignored, but reportedly ending up with<br>
- a duplicate 'b' character in the mode causes a crash on Windows 10.<br>
-<br>
- No cluster differences.<br>
-<br>
-base/fapiufst.c<br>
-base/gsicc_manage.c<br>
-base/lib.mak<br>
-base/sfxcommon.c<br>
-base/strmio.h<br>
-devices/vector/gdevpdfu.c<br>
-pcl/pl/pllfont.c<br>
-psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-06 09:20: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=6fb23cff7abcef91d03b43454d2d40d79c5e83da">6fb23cff7abcef91d03b43454d2d40d79c5e83da</a>
-<blockquote>
-<p>
- Coverity ID #95037. Fix what looks like a simple oversight<br>
-<br>
-devices/vector/gdevpdti.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-06 09:16:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c2adcc65d5e56e008b082675bc3883edb92f57a4">c2adcc65d5e56e008b082675bc3883edb92f57a4</a>
-<blockquote>
-<p>
- Coverity ID #94925 alter '&gt;' to '&gt;=' to avoid potential overrun<br>
-<br>
-devices/vector/gdevpdti.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-06 09:05: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=eb2204d269bb5577170ad28fc837704c8f865dba">eb2204d269bb5577170ad28fc837704c8f865dba</a>
-<blockquote>
-<p>
- Coverity ID #94859 avoid potential NULL pointer dereference<br>
-<br>
-devices/vector/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-06 08:51:21 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=56d3dfcbb53294e980e3a0169c2e676143eb66e7">56d3dfcbb53294e980e3a0169c2e676143eb66e7</a>
-<blockquote>
-<p>
- Coverity ID #101184 prevent a potential NULL pointer dereference<br>
-<br>
-devices/vector/gdevpdfv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-06 08:25: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=38635d15c08f5359632bf3ed6162ed125ce204c0">38635d15c08f5359632bf3ed6162ed125ce204c0</a>
-<blockquote>
-<p>
- Coverity ID #94860 remove dead code<br>
-<br>
-devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-05 15:15: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=b71c1d775b1ca343a7cd80fc842f6681d2fd4037">b71c1d775b1ca343a7cd80fc842f6681d2fd4037</a>
-<blockquote>
-<p>
- Coverity ID #101186 Remove some unused code to silence warnigns<br>
-<br>
-devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-05 14:50:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2964fc6908aa86a9a7b2964b6c1e8d70459641b0">2964fc6908aa86a9a7b2964b6c1e8d70459641b0</a>
-<blockquote>
-<p>
- Coverity ID #95040 check a return code<br>
-<br>
-devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-04 16:02: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=6fc5e5a406e6dae25233719a8c6cc1442c774695">6fc5e5a406e6dae25233719a8c6cc1442c774695</a>
-<blockquote>
-<p>
- pdfwrite - fix some sorting problems in Names trees<br>
-<br>
- Bug #696030 &quot;main level of bookmarks not being set as destination&quot;<br>
-<br>
- The new code to write the Names tree as a tree had some logical flaws when<br>
- ordering the keys which led to some entries not being written.<br>
-<br>
-devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-08-04 08:55: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=b56ff42047f6df6e7c74a79b91cd7d193bfa7357">b56ff42047f6df6e7c74a79b91cd7d193bfa7357</a>
-<blockquote>
-<p>
- pdfwrite - improved clips under rare conditions<br>
-<br>
- Bug #696093 &quot;Distortion converting PS to PDF&quot;<br>
-<br>
- The test file exposes a rare condition in the graphics library and the<br>
- pdfwrite device.<br>
-<br>
- The example is carelessly constructed by the designer; a blue rectangle<br>
- has an image laid over the top of it, the image is required to be at a<br>
- particular position in order to align the text in the image with other<br>
- parts of the text, in other images. This causes part of the image to<br>
- obscure the underlying blue rectangle.<br>
-<br>
- A simple way to resolve this would be to change the z-order so that the<br>
- rectangle lies on top of the image, or to apply a clip to the image to<br>
- stop it overlapping. Instead the designer has created a new image, the<br>
- same colour as the blue rectangle, and placed that on top of the image<br>
- containing the text. This image has been clipped to a very small area. In<br>
- addition the applied clip is not quite rectangular.<br>
-<br>
- The effect of this is that two clipping paths intersect, when this happens<br>
- the graphics library calculates the intersection as a series of rectangles.<br>
- Because the final clip is very small and very nearly rectangular, at the<br>
- resolution used by pdfwrite the intersection (at pixel level) *is* a<br>
- rectangle.<br>
-<br>
- So the code wrote the final clip as a rectangle. This works fine at specific<br>
- resolutions, but at other resolutions (ie other zoom levels in Acrobat)<br>
- the lack of precision caused the clip to go slightly awry, allowing the<br>
- clipped image to get bigger and overlap portions of the image containing the<br>
- text.<br>
-<br>
- The first part of the fix is in pdfwrite. We check the 'path_valid' member<br>
- of the clip path structure. This is set if the clip is set due to a single<br>
- path, if its the intersection of two paths, then path_valid is reset.<br>
-<br>
- We only write a simple rectangle if the clip path is a rectangle *and* the<br>
- rectangle is the result of a single path.<br>
-<br>
- Otherwise, we use the path_list. This is a list of all the paths that were<br>
- used to create this clip. By writing the paths out we recover the accuracy.<br>
-<br>
- There is, however, a second part to this. Initclip, and a few other operations<br>
- can set the clip to a rectangular area, *without* setting a path. This<br>
- results in path_valid being false *and* not having a path_list. In this case<br>
- the pdfwrite code just writes the rectangle.<br>
-<br>
- There is one further wrinkle; If we had an existing clip which was overridden<br>
- with a rectangle by one of these operators, the graphics library did not<br>
- clear the path_list member of the clip path. This meant that the path_list<br>
- referred to the paths which created a totally different clip to the one<br>
- actually being applied. For rendering this isn't a problem, but for the<br>
- pdfwrite device it caused us to write a completely incorrect set of paths.<br>
-<br>
- There are a number of cluster differences, mostly at low resolution<br>
- (because the resolution matters):<br>
-<br>
- minor (single pixel changes)<br>
- -----------------------------<br>
- Bug689189.pdf<br>
- Bug689748.pdf<br>
- Bug690395.pdf<br>
- Bug691115.pdf<br>
- Bug694871.eps<br>
- Bug695863.pdf<br>
- pcl5ccet/32_02.bin<br>
- catx4547.pdf<br>
- catx6508.pdf<br>
- x_-_text_clipped_away_above_141_pc.pdf<br>
- 09-34.ps<br>
- 10-01.ps<br>
-<br>
- minor changes<br>
- --------------------<br>
- pcl6cet3.0/c303.bin<br>
- pcl6cet3.0/c304.bin<br>
- pcl6cet3.0/c308.bin<br>
- pcl6cet3.0/c309.bin<br>
- pcl6cet3.0/c310.bin<br>
- pcl6cet3.0/c311.bin<br>
- pcl6cet3.0/c312.bin<br>
- pcl6cet3.0/c314.bin<br>
- pcl6cet3.0/c315.bin<br>
- pcl6cet3.0/c316.bin<br>
- pcl6cet3.0/c317.bin<br>
- pcl6cet3.0/c318.bin<br>
- pcl6cet3.0/c319.bin<br>
- pcl6cet3.0/c321.bin<br>
- pcl6cet3.0/c331.bin<br>
- pcl6cet3.0/c332.bin<br>
- pcl6cet3.0/c333.bin<br>
- pcl6cet3.0/c335.bin<br>
- pcl6cet3.0/c401.bin<br>
- pcl6cet3.0/c403.bin<br>
- pcl6cet3.0/c404.bin<br>
- pcl6cet3.0/c405.bin<br>
- pcl6cet3.0/c406.bin<br>
- pcl6cet3.0/c407.bin<br>
- pcl6cet3.0/c408.bin<br>
- pcl6cet3.0/c409.bin<br>
- pcl6cet3.0/c410.bin<br>
- pcl6cet3.0/c411.bin<br>
- pcl6cet3.0/c412.bin<br>
- pcl6cet3.0/c413.bin<br>
- pcl6cet3.0/c414.bin<br>
- pcl6cet3.0/c415.bin<br>
- pcl6cet3.0/c416.bin<br>
- pcl6cet3.0/c417.bin<br>
- pcl6cet3.0/c418.bin<br>
- pcl6cet3.0/c420.bin<br>
- pcl6cet3.0/c422.bin<br>
- pcl6cet3.0/c424.bin<br>
- pcl6cet3.0/c425.bin<br>
- pcl6cet3.0/c426.bin<br>
-<br>
- minor (single pixel changes), probably progressions<br>
- ----------------------------------------------------<br>
- 09_47N.pdf<br>
- 26_09.pdf<br>
- 09-34.ps<br>
- 10-01.ps<br>
- 10-08.ps<br>
- 10-13.ps<br>
- 10-14.ps<br>
- 10-16.ps<br>
- 13-16.ps<br>
- 13-17.ps<br>
- 13-19.ps<br>
-<br>
- small but useful progressions<br>
- Bug692720.pdf<br>
- Bug694909.pdf<br>
- x_-_text_clipped_away_above_141_pc.pdf<br>
-<br>
- significant progressions<br>
- -------------------------<br>
- pcl6cet3.0/c325.bin<br>
- xpsfts-a4/fts_34xx.xps<br>
- xpsfts-a4/fts_42xx.xps<br>
- xpsfts-a4/fts_45xx.xps<br>
-<br>
- just different (wrong both ways)<br>
- --------------------------------<br>
- pcl6cet3.0/c421.bin<br>
- pcl6cet3.0/c422.bin<br>
-<br>
-base/gspath.c<br>
-devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-31 14: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=83e211723f975beff6ce488a2a6ee5105c089121">83e211723f975beff6ce488a2a6ee5105c089121</a>
-<blockquote>
-<p>
- Force the normal text handling to throw errors under the same (degenerate<br>
- CTM) conditions as when -dTextAlphaBits is set.<br>
-<br>
- Currently if the CTM is something like [0 0 0 0 Tx Ty] then Ghostscript<br>
- throws an error if -dTextAlphaBits is set, but not if it isn't. This leads<br>
- to a number of bug reports citing problems with TextAlphaBits which really<br>
- isn't the case.<br>
-<br>
- Testing Adobe seems to indicate that, for PostScript, and error is the<br>
- expected behaviour.<br>
-<br>
- This commit adds a 'currentpoint' call in two places so that we get the same<br>
- error no matter which code path we follow.<br>
-<br>
- The PDF interpreter has already been fixed so that all known cases will not<br>
- throw errors with this commit, but two PCL files from Quality Logic do now<br>
- throw an error, 18-08.bin and 18-09.bin. A bug report will be raised for<br>
- these.<br>
-<br>
-base/gxfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-31 11:05: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=70b442162ff8f3d40595d0eb9fb365d341139ee2">70b442162ff8f3d40595d0eb9fb365d341139ee2</a>
-<blockquote>
-<p>
- PDF interpreter - detect and 'fix' degenerate text matrices<br>
-<br>
- Cluster test files Bug689006.pdf, Bug690179.pdf and Bug694981.pdf all end<br>
- up setting a degenerate text matrix (horizontal or vertical scale of 0)<br>
- albeit in different ways.<br>
-<br>
- This commit detects these cases, and fixes the matrix by changing to a<br>
- tiny scale factor, instead of 0.<br>
-<br>
- These files now work with -dTextAlphaBits=4, which they did not before. In<br>
- addition there are several progressions exhibited.<br>
-<br>
- Bug694981.pdf now works with the psdcmyk device.<br>
- singular_ctm_3_tr_mode.pdf and Bug689614.pdf with the ps2write device no<br>
- longer produce PostScript files which error out on execution.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-29 08:57: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=b2f3441d5481e9629130b989d5ad14841f22ce98">b2f3441d5481e9629130b989d5ad14841f22ce98</a>
-<blockquote>
-<p>
- PDF interpreter - clamp horizontal text spacing to prevent degenerate CTM<br>
-<br>
- Bug #696107 &quot;Text missing with -dTextAlphaBits=4&quot;<br>
-<br>
- The file contains three occurrences of &quot;0 Tz&quot; which sets the horizontal<br>
- scale factor to 0. This causes the CTM to have a zero horizontal scale<br>
- which (correctly) throws an error when TextAlphaBits is set.<br>
-<br>
- This commit detects setting Tz to 0 and replaces it with a miniscule, but<br>
- non-zero, value thus preventing the degenerate matrix and the error.<br>
-<br>
- A later commit will change the behaviour of the graphics library so that it<br>
- is at least consistent with differing values for TextAlphaBits.<br>
-<br>
-Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-30 12:09:53 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=47622dec684584b38571516b844e007cda7853c8">47622dec684584b38571516b844e007cda7853c8</a>
-<blockquote>
-<p>
- Initial commit for color management in gproof device.<br>
-<br>
- There are four possible cases that had to be handled.<br>
- They depend upon if we have or do not have non standard colorants<br>
- and if we have or do not have the proper ICC profiles<br>
-<br>
- Essentially we may have to compute the equivalent CMYK colors<br>
- for the image that includes spot colors and we may have to do<br>
- a very slow conversion to RGB when we don't have the proper<br>
- ICC profiles. The fastest case, occurs when we have an ICC<br>
- for all our source colorants (including any spots).<br>
-<br>
-devices/gdevgprf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-29 07:17:58 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab674af32798e8b7ce46bb093acfe756d226cdf6">ab674af32798e8b7ce46bb093acfe756d226cdf6</a>
-<blockquote>
-<p>
- Fixes for Windows build with VS 2015.<br>
-<br>
- Apparently snprintf is now available (since VS2014), and we need to<br>
- make sure and undef bool to avoid conflicts.<br>
-<br>
-base/gp_mswin.c<br>
-base/stdio_.h<br>
-base/windows_.h<br>
-jbig2dec/config_win32.h<br>
-tiff/libtiff/tif_config.vc.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-30 07:22:34 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=56045937000ea510c40347bc921a287624ea502d">56045937000ea510c40347bc921a287624ea502d</a>
-<blockquote>
-<p>
- Add /PROFILE linker switch for gpcl, gxps profile builds on Windows<br>
-<br>
-base/msvccmd.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-29 11:51:56 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be5f5ebf5c30219671d762c0423f83c86de93e62">be5f5ebf5c30219671d762c0423f83c86de93e62</a>
-<blockquote>
-<p>
- Make the lcms temp memory allocations use memory from the device<br>
-<br>
- With recent changes a link may not have a valid link cache entry and<br>
- previously were using memory from the link cache entry for temporary<br>
- memory allocations.<br>
-<br>
-base/gsicc_lcms2.c<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-27 12:17:13 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a6eafb5cbe23d7618bec87b3a904c9bb116150a">7a6eafb5cbe23d7618bec87b3a904c9bb116150a</a>
-<blockquote>
-<p>
- Move a tiffsep method and struct to the common devn device so it can be used by others<br>
-<br>
- The gproof device needs to do some of the same things as the tiffsep device when<br>
- the ICC profile is not sufficient to map the colorants.<br>
-<br>
-base/gdevdevn.c<br>
-base/gdevdevn.h<br>
-devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-25 17:53: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=e32fe0b1e0cebc58fa9d413d2c6541d26a238d04">e32fe0b1e0cebc58fa9d413d2c6541d26a238d04</a>
-<blockquote>
-<p>
- Bug 696114: fix disable compile inits build<br>
-<br>
- Fix mistakes for the non-compile inits build.<br>
-<br>
- For that case, we make a single empty romfs source file, which then gets built<br>
- into different object files, one for each product. When I made those changes<br>
- I got the source and object file names the wrong way round.<br>
-<br>
-base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-24 11:43:27 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0eee21b097b505e24915b9c535ce166f92a397b6">0eee21b097b505e24915b9c535ce166f92a397b6</a>
-<blockquote>
-<p>
- Create equivalent RGB colors from CMYK equivalent colors<br>
-<br>
- The ICC profiles are used if they are valid. If not, the old<br>
- canned routines for doing the conversions are used. Note that<br>
- the icc link was added to the context.<br>
-<br>
-devices/gdevgprf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-23 13:23:38 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6e470ae65e274d9671df1bfc72007203c3158855">6e470ae65e274d9671df1bfc72007203c3158855</a>
-<blockquote>
-<p>
- Set up for color management in gproof device<br>
-<br>
- Here we remove code that is not needed as well as create the<br>
- link between the source and the destination profiles and<br>
- release it when the device is closed. Next step will be to apply<br>
- the profile to the data.<br>
-<br>
-devices/gdevgprf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-23 12:59: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=547f44324971c716ae3ee4d7a2cb0b48e011f0b4">547f44324971c716ae3ee4d7a2cb0b48e011f0b4</a>
-<blockquote>
-<p>
- Clean up a few items in the device based link allocation.<br>
-<br>
- Had to add a way to free the link, make sure the allocation is done in non-gc memory<br>
- and initialize a few more items.<br>
-<br>
-base/gsicc_cache.c<br>
-base/gsicc_cache.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-23 11:19:46 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6ee000ceb76fe7da46aaa89ff5c5f7c304775a3">a6ee000ceb76fe7da46aaa89ff5c5f7c304775a3</a>
-<blockquote>
-<p>
- Add support in ICC code for the creation of links that are not in the cache<br>
-<br>
- This is needed for use by device that are doing post rendering color management.<br>
- In this case, they do not have access to the imager state and the icc cache. They<br>
- typically only need one link which will be applied to the rendered data.<br>
-<br>
-base/gsicc_cache.c<br>
-base/gsicc_cache.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-22 15:28: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=3f492a9920f9d4cd30e6229c5b0b56bf1b7ade28">3f492a9920f9d4cd30e6229c5b0b56bf1b7ade28</a>
-<blockquote>
-<p>
- Remove jasper and lcms (vers 1) references from ghostscript.vcproj<br>
-<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-22 12:18:00 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=317b83e6f31f91a2a8c957df46f7d9b922290110">317b83e6f31f91a2a8c957df46f7d9b922290110</a>
-<blockquote>
-<p>
- Fix paths for files in visual studio project.<br>
-<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-22 14:49:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c02e58e490f3488e506873018ad04f2565a82c9">2c02e58e490f3488e506873018ad04f2565a82c9</a>
-<blockquote>
-<p>
- Remove the Postscript based CFF interpreter.<br>
-<br>
- The C CFF implementation has been the default for quite some time, and it is<br>
- several years since we had the one problem reported on it, so it seems fitting<br>
- to remove it as redundant, and it's supporting data.<br>
-<br>
- No cluster differences.<br>
-<br>
-Resource/Init/gs_cff.ps<br>
-Resource/Init/gs_css_e.ps<br>
-psi/int.mak<br>
-psi/psromfs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-22 18:05: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=b0fd01a31fc4f74a1afab5f915bfccc6864d0235">b0fd01a31fc4f74a1afab5f915bfccc6864d0235</a>
-<blockquote>
-<p>
- Remove a FIXME comment.....<br>
-<br>
-Makefile.in<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-21 08:30: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=f9c3dbc6ed02b9bba2f1d54dea10acce5145da24">f9c3dbc6ed02b9bba2f1d54dea10acce5145da24</a>
-<blockquote>
-<p>
- Add post rendering ICC profile to device params and Device ICC structure<br>
-<br>
- We will initially use this for the gsproof device but it would be accessible<br>
- for any of the devices if they wish to do additional color managed processing<br>
- for the creation of some special proofing output for example<br>
-<br>
-base/gscms.h<br>
-base/gsdparam.c<br>
-base/gsequivc.c<br>
-base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-20 21: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=ba2eea6610e997ecd3735ee95d0325e59ae45006">ba2eea6610e997ecd3735ee95d0325e59ae45006</a>
-<blockquote>
-<p>
- Fix typo in gx_default_get_param for TextICCProfile.<br>
-<br>
-base/gsdparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-10 17:26:45 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d94669ba0009288630bcec80a3dd725cfa7ba002">d94669ba0009288630bcec80a3dd725cfa7ba002</a>
-<blockquote>
-<p>
- First cut at gproof device.<br>
-<br>
-devices/devs.mak<br>
-devices/gdevgprf.c<br>
-windows/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-21 10:42:10 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=578025a9cc9cd682f8570004f6d873e76f1af3ef">578025a9cc9cd682f8570004f6d873e76f1af3ef</a>
-<blockquote>
-<p>
- MS solution; move to windows directory<br>
-<br>
- Remove repeated files from within ghostpdl.<br>
-<br>
-All.vcproj<br>
-GhostPDL.sln<br>
-ghostall.vcproj<br>
-ghostpcl.vcproj<br>
-ghostpdl.vcproj<br>
-ghostscript-ufst.vcproj<br>
-ghostscript.vcproj<br>
-ghostscript_rt.vcxproj<br>
-ghostxps.vcproj<br>
-windows/All.vcproj<br>
-windows/GhostPDL.sln<br>
-windows/ghostpcl.vcproj<br>
-windows/ghostpdl.vcproj<br>
-windows/ghostscript-ufst.vcproj<br>
-windows/ghostscript.vcproj<br>
-windows/ghostscript_rt.vcxproj<br>
-windows/ghostxps.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-21 14:12: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=d9eff8f0120d772189bf54fb5de6f7d0b061e7b3">d9eff8f0120d772189bf54fb5de6f7d0b061e7b3</a>
-<blockquote>
-<p>
- Fix a few mistakes in the Windows makefiles<br>
-<br>
-base/lcupsi.mak<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-21 11:45: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=15436d6ad86d5f394b5699474be82f624a289685">15436d6ad86d5f394b5699474be82f624a289685</a>
-<blockquote>
-<p>
- Add targets for memento and profile builds<br>
-<br>
- for each individual executable. And update the VS projects to use them<br>
-<br>
-base/unix-end.mak<br>
-ghostpcl.vcproj<br>
-ghostpdl.vcproj<br>
-ghostscript.vcproj<br>
-ghostxps.vcproj<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-21 00:08:24 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2aa05a2667836e9bb9f46a4d64ceb68f14556214">2aa05a2667836e9bb9f46a4d64ceb68f14556214</a>
-<blockquote>
-<p>
- MS solution; add 'All' project.<br>
-<br>
- The All project invokes some new makefile targets. These makefile<br>
- targets just depend on all the appropriate existing makefile targets.<br>
- Thus we get a sequential build of the different projects.<br>
-<br>
- Nmake does not (yet) support parallelism, so we don't have the problem<br>
- of building multiple projects in parallel as we get when we build<br>
- multiple projects in the solution.<br>
-<br>
- We use the configuration manager in the solution to ensure that when<br>
- we build the entire solution, only 'All' is built.<br>
-<br>
-All.vcproj<br>
-GhostPDL.sln<br>
-ghostall.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-20 20:29:26 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=428c32050b287e90db4d77ff920dd37162d43c94">428c32050b287e90db4d77ff920dd37162d43c94</a>
-<blockquote>
-<p>
- Tweak VS solution a bit more; avoid repeating files.<br>
-<br>
- To avoid files showing up more than once when we search for them,<br>
- ensure that each file is only included once. This means that common<br>
- files are listed only under ghostscript.<br>
-<br>
- This makes no difference to builds etc, as that's all handled by the<br>
- Makefiles.<br>
-<br>
-ghostpcl.vcproj<br>
-ghostscript.vcproj<br>
-ghostxps.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-20 20:06: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=c676ef3689f80f9103727a40e91fcbcf52882f3f">c676ef3689f80f9103727a40e91fcbcf52882f3f</a>
-<blockquote>
-<p>
- Fix VS solution configuration issues.<br>
-<br>
- It seems the solution has gotten confused, and wants to build<br>
- Release-contrib for all exes in all cases.<br>
-<br>
-GhostPDL.sln<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-20 21:25: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=4a545c49f3a22a891c60cbd0f228b1c08fe11ec4">4a545c49f3a22a891c60cbd0f228b1c08fe11ec4</a>
-<blockquote>
-<p>
- Fix the gpcl6 and gxps targets for Windows.<br>
-<br>
-psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-23 16:24:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6948650efd3fb9e2a70b8cf16aca57e9d0b7eb0a">6948650efd3fb9e2a70b8cf16aca57e9d0b7eb0a</a>
-<blockquote>
-<p>
- Commit of build_consolidation branch<br>
-<br>
- Squashed into one commit (see branch for details of the evolution of the<br>
- branch).<br>
-<br>
- This brings gpcl6 and gxps into the Ghostscript build system, and a shared<br>
- set of graphics library object files for all the interpreters.<br>
-<br>
- Also, brings the same configuration options to the pcl and xps products as we<br>
- have for Ghostscript.<br>
-<br>
-COPYING<br>
-COPYING.AFPL<br>
-DroidSansFallback.NOTICE<br>
-GhostPDL.sln<br>
-LICENSE<br>
-Makefile<br>
-Makefile.in<br>
-NEWS<br>
-README.txt<br>
-Resource/CIDFSubst/DroidSansFallback.ttf<br>
-Resource/CIDFont/ArtifexBullet<br>
-Resource/CMap/78-EUC-H<br>
-Resource/CMap/78-EUC-V<br>
-Resource/CMap/78-H<br>
-Resource/CMap/78-RKSJ-H<br>
-Resource/CMap/78-RKSJ-V<br>
-Resource/CMap/78-V<br>
-Resource/CMap/78ms-RKSJ-H<br>
-Resource/CMap/78ms-RKSJ-V<br>
-Resource/CMap/83pv-RKSJ-H<br>
-Resource/CMap/90ms-RKSJ-H<br>
-Resource/CMap/90ms-RKSJ-V<br>
-Resource/CMap/90msp-RKSJ-H<br>
-Resource/CMap/90msp-RKSJ-V<br>
-Resource/CMap/90pv-RKSJ-H<br>
-Resource/CMap/90pv-RKSJ-V<br>
-Resource/CMap/Add-H<br>
-Resource/CMap/Add-RKSJ-H<br>
-Resource/CMap/Add-RKSJ-V<br>
-Resource/CMap/Add-V<br>
-Resource/CMap/Adobe-CNS1-0<br>
-Resource/CMap/Adobe-CNS1-1<br>
-Resource/CMap/Adobe-CNS1-2<br>
-Resource/CMap/Adobe-CNS1-3<br>
-Resource/CMap/Adobe-CNS1-4<br>
-Resource/CMap/Adobe-CNS1-5<br>
-Resource/CMap/Adobe-CNS1-6<br>
-Resource/CMap/Adobe-GB1-0<br>
-Resource/CMap/Adobe-GB1-1<br>
-Resource/CMap/Adobe-GB1-2<br>
-Resource/CMap/Adobe-GB1-3<br>
-Resource/CMap/Adobe-GB1-4<br>
-Resource/CMap/Adobe-GB1-5<br>
-Resource/CMap/Adobe-Japan1-0<br>
-Resource/CMap/Adobe-Japan1-1<br>
-Resource/CMap/Adobe-Japan1-2<br>
-Resource/CMap/Adobe-Japan1-3<br>
-Resource/CMap/Adobe-Japan1-4<br>
-Resource/CMap/Adobe-Japan1-5<br>
-Resource/CMap/Adobe-Japan1-6<br>
-Resource/CMap/Adobe-Korea1-0<br>
-Resource/CMap/Adobe-Korea1-1<br>
-Resource/CMap/Adobe-Korea1-2<br>
-Resource/CMap/B5-H<br>
-Resource/CMap/B5-V<br>
-Resource/CMap/B5pc-H<br>
-Resource/CMap/B5pc-V<br>
-Resource/CMap/CNS-EUC-H<br>
-Resource/CMap/CNS-EUC-V<br>
-Resource/CMap/CNS1-H<br>
-Resource/CMap/CNS1-V<br>
-Resource/CMap/CNS2-H<br>
-Resource/CMap/CNS2-V<br>
-Resource/CMap/ETHK-B5-H<br>
-Resource/CMap/ETHK-B5-V<br>
-Resource/CMap/ETen-B5-H<br>
-Resource/CMap/ETen-B5-V<br>
-Resource/CMap/ETenms-B5-H<br>
-Resource/CMap/ETenms-B5-V<br>
-Resource/CMap/EUC-H<br>
-Resource/CMap/EUC-V<br>
-Resource/CMap/Ext-H<br>
-Resource/CMap/Ext-RKSJ-H<br>
-Resource/CMap/Ext-RKSJ-V<br>
-Resource/CMap/Ext-V<br>
-Resource/CMap/GB-EUC-H<br>
-Resource/CMap/GB-EUC-V<br>
-Resource/CMap/GB-H<br>
-Resource/CMap/GB-V<br>
-Resource/CMap/GBK-EUC-H<br>
-Resource/CMap/GBK-EUC-V<br>
-Resource/CMap/GBK2K-H<br>
-Resource/CMap/GBK2K-V<br>
-Resource/CMap/GBKp-EUC-H<br>
-Resource/CMap/GBKp-EUC-V<br>
-Resource/CMap/GBT-EUC-H<br>
-Resource/CMap/GBT-EUC-V<br>
-Resource/CMap/GBT-H<br>
-Resource/CMap/GBT-V<br>
-Resource/CMap/GBTpc-EUC-H<br>
-Resource/CMap/GBTpc-EUC-V<br>
-Resource/CMap/GBpc-EUC-H<br>
-Resource/CMap/GBpc-EUC-V<br>
-Resource/CMap/H<br>
-Resource/CMap/HKdla-B5-H<br>
-Resource/CMap/HKdla-B5-V<br>
-Resource/CMap/HKdlb-B5-H<br>
-Resource/CMap/HKdlb-B5-V<br>
-Resource/CMap/HKgccs-B5-H<br>
-Resource/CMap/HKgccs-B5-V<br>
-Resource/CMap/HKm314-B5-H<br>
-Resource/CMap/HKm314-B5-V<br>
-Resource/CMap/HKm471-B5-H<br>
-Resource/CMap/HKm471-B5-V<br>
-Resource/CMap/HKscs-B5-H<br>
-Resource/CMap/HKscs-B5-V<br>
-Resource/CMap/Hankaku<br>
-Resource/CMap/Hiragana<br>
-Resource/CMap/Identity-H<br>
-Resource/CMap/Identity-UTF16-H<br>
-Resource/CMap/Identity-V<br>
-Resource/CMap/KSC-EUC-H<br>
-Resource/CMap/KSC-EUC-V<br>
-Resource/CMap/KSC-H<br>
-Resource/CMap/KSC-Johab-H<br>
-Resource/CMap/KSC-Johab-V<br>
-Resource/CMap/KSC-V<br>
-Resource/CMap/KSCms-UHC-H<br>
-Resource/CMap/KSCms-UHC-HW-H<br>
-Resource/CMap/KSCms-UHC-HW-V<br>
-Resource/CMap/KSCms-UHC-V<br>
-Resource/CMap/KSCpc-EUC-H<br>
-Resource/CMap/KSCpc-EUC-V<br>
-Resource/CMap/Katakana<br>
-Resource/CMap/NWP-H<br>
-Resource/CMap/NWP-V<br>
-Resource/CMap/RKSJ-H<br>
-Resource/CMap/RKSJ-V<br>
-Resource/CMap/Roman<br>
-Resource/CMap/UniCNS-UCS2-H<br>
-Resource/CMap/UniCNS-UCS2-V<br>
-Resource/CMap/UniCNS-UTF16-H<br>
-Resource/CMap/UniCNS-UTF16-V<br>
-Resource/CMap/UniCNS-UTF32-H<br>
-Resource/CMap/UniCNS-UTF32-V<br>
-Resource/CMap/UniCNS-UTF8-H<br>
-Resource/CMap/UniCNS-UTF8-V<br>
-Resource/CMap/UniGB-UCS2-H<br>
-Resource/CMap/UniGB-UCS2-V<br>
-Resource/CMap/UniGB-UTF16-H<br>
-Resource/CMap/UniGB-UTF16-V<br>
-Resource/CMap/UniGB-UTF32-H<br>
-Resource/CMap/UniGB-UTF32-V<br>
-Resource/CMap/UniGB-UTF8-H<br>
-Resource/CMap/UniGB-UTF8-V<br>
-Resource/CMap/UniHojo-UCS2-H<br>
-Resource/CMap/UniJIS-UCS2-H<br>
-Resource/CMap/UniJIS-UCS2-HW-H<br>
-Resource/CMap/UniJIS-UCS2-HW-V<br>
-Resource/CMap/UniJIS-UCS2-V<br>
-Resource/CMap/UniJIS-UTF16-H<br>
-Resource/CMap/UniJIS-UTF16-V<br>
-Resource/CMap/UniJIS-UTF32-H<br>
-Resource/CMap/UniJIS-UTF32-V<br>
-Resource/CMap/UniJIS-UTF8-H<br>
-Resource/CMap/UniJIS-UTF8-V<br>
-Resource/CMap/UniJIS2004-UTF16-H<br>
-Resource/CMap/UniJIS2004-UTF16-V<br>
-Resource/CMap/UniJIS2004-UTF32-H<br>
-Resource/CMap/UniJIS2004-UTF32-V<br>
-Resource/CMap/UniJIS2004-UTF8-H<br>
-Resource/CMap/UniJIS2004-UTF8-V<br>
-Resource/CMap/UniJISPro-UCS2-HW-V<br>
-Resource/CMap/UniJISPro-UCS2-V<br>
-Resource/CMap/UniJISPro-UTF8-V<br>
-Resource/CMap/UniJISX0213-UTF32-H<br>
-Resource/CMap/UniJISX0213-UTF32-V<br>
-Resource/CMap/UniJISX02132004-UTF32-H<br>
-Resource/CMap/UniJISX02132004-UTF32-V<br>
-Resource/CMap/UniKS-UCS2-H<br>
-Resource/CMap/UniKS-UCS2-V<br>
-Resource/CMap/UniKS-UTF16-H<br>
-Resource/CMap/UniKS-UTF16-V<br>
-Resource/CMap/UniKS-UTF32-H<br>
-Resource/CMap/UniKS-UTF32-V<br>
-Resource/CMap/UniKS-UTF8-H<br>
-Resource/CMap/UniKS-UTF8-V<br>
-Resource/CMap/V<br>
-Resource/CMap/WP-Symbol<br>
-Resource/ColorSpace/DefaultCMYK<br>
-Resource/ColorSpace/DefaultGray<br>
-Resource/ColorSpace/DefaultRGB<br>
-Resource/ColorSpace/TrivialCMYK<br>
-Resource/ColorSpace/sGray<br>
-Resource/ColorSpace/sRGB<br>
-Resource/Decoding/FCO_Dingbats<br>
-Resource/Decoding/FCO_Symbol<br>
-Resource/Decoding/FCO_Unicode<br>
-Resource/Decoding/FCO_Wingdings<br>
-Resource/Decoding/Latin1<br>
-Resource/Decoding/StandardEncoding<br>
-Resource/Decoding/Unicode<br>
-Resource/Encoding/CEEncoding<br>
-Resource/Encoding/ExpertEncoding<br>
-Resource/Encoding/ExpertSubsetEncoding<br>
-Resource/Encoding/NotDefEncoding<br>
-Resource/Encoding/Wingdings<br>
-Resource/Font/BookmanURW-DemBol<br>
-Resource/Font/BookmanURW-DemBolIta<br>
-Resource/Font/BookmanURW-Lig<br>
-Resource/Font/BookmanURW-LigIta<br>
-Resource/Font/CenturySchURW-Bol<br>
-Resource/Font/CenturySchURW-BolIta<br>
-Resource/Font/CenturySchURW-Ita<br>
-Resource/Font/CenturySchURW-Rom<br>
-Resource/Font/ChanceryURW-MedIta<br>
-Resource/Font/Dingbats<br>
-Resource/Font/NimbusMono-Bold<br>
-Resource/Font/NimbusMono-BoldOblique<br>
-Resource/Font/NimbusMono-Oblique<br>
-Resource/Font/NimbusMono-Regular<br>
-Resource/Font/NimbusRomNo9L-Med<br>
-Resource/Font/NimbusRomNo9L-MedIta<br>
-Resource/Font/NimbusRomNo9L-Reg<br>
-Resource/Font/NimbusRomNo9L-RegIta<br>
-Resource/Font/NimbusSanL-Bol<br>
-Resource/Font/NimbusSanL-BolIta<br>
-Resource/Font/NimbusSanL-Reg<br>
-Resource/Font/NimbusSanL-RegIta<br>
-Resource/Font/NimbusSanNar-Bol<br>
-Resource/Font/NimbusSanNar-BolIta<br>
-Resource/Font/NimbusSanNar-Ita<br>
-Resource/Font/NimbusSanNar-Reg<br>
-Resource/Font/PalladioURW-Bol<br>
-Resource/Font/PalladioURW-BolIta<br>
-Resource/Font/PalladioURW-Ita<br>
-Resource/Font/PalladioURW-Rom<br>
-Resource/Font/StandardSymL<br>
-Resource/Font/URWGothic-Boo<br>
-Resource/Font/URWGothic-BooObl<br>
-Resource/Font/URWGothic-Dem<br>
-Resource/Font/URWGothic-DemObl<br>
-Resource/IdiomSet/Pscript5Idiom<br>
-Resource/Init/FAPIcidfmap<br>
-Resource/Init/FAPIconfig<br>
-Resource/Init/FAPIfontmap<br>
-Resource/Init/FCOfontmap-PCLPS2<br>
-Resource/Init/Fontmap<br>
-Resource/Init/Fontmap.GS<br>
-Resource/Init/cidfmap<br>
-Resource/Init/gs_agl.ps<br>
-Resource/Init/gs_btokn.ps<br>
-Resource/Init/gs_cet.ps<br>
-Resource/Init/gs_cff.ps<br>
-Resource/Init/gs_cidcm.ps<br>
-Resource/Init/gs_ciddc.ps<br>
-Resource/Init/gs_cidfm.ps<br>
-Resource/Init/gs_cidfn.ps<br>
-Resource/Init/gs_cidtt.ps<br>
-Resource/Init/gs_cmap.ps<br>
-Resource/Init/gs_cspace.ps<br>
-Resource/Init/gs_css_e.ps<br>
-Resource/Init/gs_dbt_e.ps<br>
-Resource/Init/gs_diskf.ps<br>
-Resource/Init/gs_diskn.ps<br>
-Resource/Init/gs_dpnxt.ps<br>
-Resource/Init/gs_dps.ps<br>
-Resource/Init/gs_dps1.ps<br>
-Resource/Init/gs_dps2.ps<br>
-Resource/Init/gs_dscp.ps<br>
-Resource/Init/gs_epsf.ps<br>
-Resource/Init/gs_fapi.ps<br>
-Resource/Init/gs_fntem.ps<br>
-Resource/Init/gs_fonts.ps<br>
-Resource/Init/gs_frsd.ps<br>
-Resource/Init/gs_icc.ps<br>
-Resource/Init/gs_il1_e.ps<br>
-Resource/Init/gs_img.ps<br>
-Resource/Init/gs_init.ps<br>
-Resource/Init/gs_l2img.ps<br>
-Resource/Init/gs_lev2.ps<br>
-Resource/Init/gs_ll3.ps<br>
-Resource/Init/gs_mex_e.ps<br>
-Resource/Init/gs_mgl_e.ps<br>
-Resource/Init/gs_mro_e.ps<br>
-Resource/Init/gs_pdf_e.ps<br>
-Resource/Init/gs_pdfwr.ps<br>
-Resource/Init/gs_res.ps<br>
-Resource/Init/gs_resmp.ps<br>
-Resource/Init/gs_setpd.ps<br>
-Resource/Init/gs_statd.ps<br>
-Resource/Init/gs_std_e.ps<br>
-Resource/Init/gs_sym_e.ps<br>
-Resource/Init/gs_trap.ps<br>
-Resource/Init/gs_ttf.ps<br>
-Resource/Init/gs_typ32.ps<br>
-Resource/Init/gs_typ42.ps<br>
-Resource/Init/gs_type1.ps<br>
-Resource/Init/gs_wan_e.ps<br>
-Resource/Init/pdf_base.ps<br>
-Resource/Init/pdf_cslayer.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>
-Resource/Init/xlatmap<br>
-Resource/SubstCID/CNS1-WMode<br>
-Resource/SubstCID/GB1-WMode<br>
-Resource/SubstCID/Japan1-WMode<br>
-Resource/SubstCID/Korea1-WMode<br>
-arch/osx-x86-x86_64-ppc-gcc.h<br>
-arch/windows-arm-msvc.h<br>
-arch/windows-x64-msvc.h<br>
-arch/windows-x86-msvc.h<br>
-autogen.sh<br>
-base/ConvertUTF.c<br>
-base/ConvertUTF.h<br>
-base/aes.c<br>
-base/aes.h<br>
-base/all-arch.mak<br>
-base/append_l.com<br>
-base/assert_.h<br>
-base/bcc32.cfg<br>
-base/bench.c<br>
-base/catmake<br>
-base/copy_one.com<br>
-base/cp.bat<br>
-base/cp.cmd<br>
-base/ctype_.h<br>
-base/dirent_.h<br>
-base/dos_.h<br>
-base/echogs.c<br>
-base/errno_.h<br>
-base/expat.mak<br>
-base/fapi_bs.mak<br>
-base/fapi_ft.c<br>
-base/fapibstm.c<br>
-base/fapiufst.c<br>
-base/fcntl_.h<br>
-base/freetype.mak<br>
-base/gconf.c<br>
-base/gconf.h<br>
-base/gdbflags.h<br>
-base/gdebug.h<br>
-base/gdevabuf.c<br>
-base/gdevbbox.c<br>
-base/gdevbbox.h<br>
-base/gdevdbit.c<br>
-base/gdevdcrd.c<br>
-base/gdevdcrd.h<br>
-base/gdevddrw.c<br>
-base/gdevddrw.h<br>
-base/gdevdevn.c<br>
-base/gdevdevn.h<br>
-base/gdevdevnprn.h<br>
-base/gdevdflt.c<br>
-base/gdevdgbr.c<br>
-base/gdevdrop.c<br>
-base/gdevdsha.c<br>
-base/gdevemap.c<br>
-base/gdevflp.c<br>
-base/gdevflp.h<br>
-base/gdevhit.c<br>
-base/gdevkrnlsclass.c<br>
-base/gdevkrnlsclass.h<br>
-base/gdevm1.c<br>
-base/gdevm16.c<br>
-base/gdevm2.c<br>
-base/gdevm24.c<br>
-base/gdevm32.c<br>
-base/gdevm4.c<br>
-base/gdevm40.c<br>
-base/gdevm48.c<br>
-base/gdevm56.c<br>
-base/gdevm64.c<br>
-base/gdevm8.c<br>
-base/gdevmem.c<br>
-base/gdevmem.h<br>
-base/gdevmpla.c<br>
-base/gdevmpla.h<br>
-base/gdevmplt.c<br>
-base/gdevmplt.h<br>
-base/gdevmr1.c<br>
-base/gdevmr2n.c<br>
-base/gdevmr8n.c<br>
-base/gdevmrop.h<br>
-base/gdevmrun.c<br>
-base/gdevmrun.h<br>
-base/gdevmx.c<br>
-base/gdevnfwd.c<br>
-base/gdevoflt.c<br>
-base/gdevoflt.h<br>
-base/gdevp14.c<br>
-base/gdevp14.h<br>
-base/gdevpccm.c<br>
-base/gdevpccm.h<br>
-base/gdevpipe.c<br>
-base/gdevplnx.c<br>
-base/gdevplnx.h<br>
-base/gdevppla.c<br>
-base/gdevppla.h<br>
-base/gdevprn.c<br>
-base/gdevprn.h<br>
-base/gdevprna.c<br>
-base/gdevprna.h<br>
-base/gdevpxat.h<br>
-base/gdevpxen.h<br>
-base/gdevpxop.h<br>
-base/gdevrops.c<br>
-base/gdevsclass.c<br>
-base/gdevsclass.h<br>
-base/gdevvec.c<br>
-base/gdevvec.h<br>
-base/genarch.c<br>
-base/genconf.c<br>
-base/gendev.c<br>
-base/genht.c<br>
-base/gp.h<br>
-base/gp_dosfe.c<br>
-base/gp_dosfs.c<br>
-base/gp_dvx.c<br>
-base/gp_getnv.c<br>
-base/gp_mac.c<br>
-base/gp_mac.h<br>
-base/gp_macio.c<br>
-base/gp_macpoll.c<br>
-base/gp_mktmp.c<br>
-base/gp_msdll.c<br>
-base/gp_msdos.c<br>
-base/gp_mshdl.c<br>
-base/gp_mslib.c<br>
-base/gp_mspol.c<br>
-base/gp_msprn.c<br>
-base/gp_mswin.c<br>
-base/gp_mswin.h<br>
-base/gp_nsync.c<br>
-base/gp_ntfs.c<br>
-base/gp_os2.c<br>
-base/gp_os2.h<br>
-base/gp_os2fs.c<br>
-base/gp_os2pr.c<br>
-base/gp_os9.c<br>
-base/gp_paper.c<br>
-base/gp_psync.c<br>
-base/gp_stdia.c<br>
-base/gp_stdin.c<br>
-base/gp_strdl.c<br>
-base/gp_sysv.c<br>
-base/gp_unifn.c<br>
-base/gp_unifs.c<br>
-base/gp_unix.c<br>
-base/gp_unix_cache.c<br>
-base/gp_upapr.c<br>
-base/gp_vms.c<br>
-base/gp_wgetv.c<br>
-base/gp_win32.c<br>
-base/gp_wpapr.c<br>
-base/gp_wsync.c<br>
-base/gp_wutf8.c<br>
-base/gpcheck.h<br>
-base/gpgetenv.h<br>
-base/gpmisc.c<br>
-base/gpmisc.h<br>
-base/gpsync.h<br>
-base/gs.mak<br>
-base/gs_dll_call.h<br>
-base/gs_mgl_e.h<br>
-base/gs_mro_e.h<br>
-base/gsalloc.c<br>
-base/gsalloc.h<br>
-base/gsalpha.c<br>
-base/gsalpha.h<br>
-base/gsalphac.c<br>
-base/gsalphac.h<br>
-base/gsargs.c<br>
-base/gsargs.h<br>
-base/gsbitcom.c<br>
-base/gsbitmap.h<br>
-base/gsbitops.c<br>
-base/gsbitops.h<br>
-base/gsbittab.c<br>
-base/gsbittab.h<br>
-base/gsccode.h<br>
-base/gsccolor.h<br>
-base/gscdef.c<br>
-base/gscdefs.h<br>
-base/gscdevn.c<br>
-base/gscdevn.h<br>
-base/gscedata.c<br>
-base/gscedata.h<br>
-base/gscencs.c<br>
-base/gscencs.h<br>
-base/gschar.c<br>
-base/gschar.h<br>
-base/gschar0.c<br>
-base/gscicach.c<br>
-base/gscicach.h<br>
-base/gscie.c<br>
-base/gscie.h<br>
-base/gsciemap.c<br>
-base/gscindex.h<br>
-base/gsclipsr.c<br>
-base/gsclipsr.h<br>
-base/gscms.h<br>
-base/gscolor.c<br>
-base/gscolor.h<br>
-base/gscolor1.c<br>
-base/gscolor1.h<br>
-base/gscolor2.c<br>
-base/gscolor2.h<br>
-base/gscolor3.c<br>
-base/gscolor3.h<br>
-base/gscolorbuffer.c<br>
-base/gscolorbuffer.h<br>
-base/gscompt.h<br>
-base/gscoord.c<br>
-base/gscoord.h<br>
-base/gscparam.c<br>
-base/gscpixel.c<br>
-base/gscpixel.h<br>
-base/gscpm.h<br>
-base/gscrd.c<br>
-base/gscrd.h<br>
-base/gscrdp.c<br>
-base/gscrdp.h<br>
-base/gscrypt1.c<br>
-base/gscrypt1.h<br>
-base/gscscie.c<br>
-base/gscsel.h<br>
-base/gscsepr.c<br>
-base/gscsepr.h<br>
-base/gscspace.c<br>
-base/gscspace.h<br>
-base/gscssub.c<br>
-base/gscssub.h<br>
-base/gsdcolor.h<br>
-base/gsdevice.c<br>
-base/gsdevice.h<br>
-base/gsdevmem.c<br>
-base/gsdfilt.c<br>
-base/gsdfilt.h<br>
-base/gsdll.h<br>
-base/gsdllwin.h<br>
-base/gsdparam.c<br>
-base/gsdpnext.h<br>
-base/gsdps.c<br>
-base/gsdps.h<br>
-base/gsdps1.c<br>
-base/gsdsrc.c<br>
-base/gsdsrc.h<br>
-base/gsequivc.c<br>
-base/gsequivc.h<br>
-base/gserrors.h<br>
-base/gsexit.h<br>
-base/gsfcid.c<br>
-base/gsfcid2.c<br>
-base/gsfcmap.c<br>
-base/gsfcmap.h<br>
-base/gsfcmap1.c<br>
-base/gsflip.c<br>
-base/gsflip.h<br>
-base/gsfname.c<br>
-base/gsfname.h<br>
-base/gsfont.c<br>
-base/gsfont.h<br>
-base/gsfont0.c<br>
-base/gsfont0c.c<br>
-base/gsform1.h<br>
-base/gsfunc.c<br>
-base/gsfunc.h<br>
-base/gsfunc0.c<br>
-base/gsfunc0.h<br>
-base/gsfunc3.c<br>
-base/gsfunc3.h<br>
-base/gsfunc4.c<br>
-base/gsfunc4.h<br>
-base/gsgc.h<br>
-base/gsgcache.c<br>
-base/gsgcache.h<br>
-base/gsgdata.c<br>
-base/gsgdata.h<br>
-base/gshsb.c<br>
-base/gshsb.h<br>
-base/gsht.c<br>
-base/gsht.h<br>
-base/gsht1.c<br>
-base/gsht1.h<br>
-base/gshtscr.c<br>
-base/gshtx.c<br>
-base/gshtx.h<br>
-base/gsicc.c<br>
-base/gsicc.h<br>
-base/gsicc_cache.c<br>
-base/gsicc_cache.h<br>
-base/gsicc_cms.h<br>
-base/gsicc_create.c<br>
-base/gsicc_create.h<br>
-base/gsicc_lcms.c<br>
-base/gsicc_lcms2.c<br>
-base/gsicc_manage.c<br>
-base/gsicc_manage.h<br>
-base/gsicc_monitorcm.c<br>
-base/gsicc_nocm.c<br>
-base/gsicc_profilecache.c<br>
-base/gsicc_profilecache.h<br>
-base/gsicc_replacecm.c<br>
-base/gsimage.c<br>
-base/gsimage.h<br>
-base/gsimpath.c<br>
-base/gsinit.c<br>
-base/gsio.h<br>
-base/gsiodev.c<br>
-base/gsiodevs.c<br>
-base/gsiodisk.c<br>
-base/gsiomacres.c<br>
-base/gsioram.c<br>
-base/gsiorom.c<br>
-base/gsiorom.h<br>
-base/gsipar3x.h<br>
-base/gsiparam.h<br>
-base/gsiparm2.h<br>
-base/gsiparm3.h<br>
-base/gsiparm4.h<br>
-base/gsistate.c<br>
-base/gsjconf.h<br>
-base/gsjmorec.h<br>
-base/gslib.c<br>
-base/gslib.h<br>
-base/gslibctx.c<br>
-base/gslibctx.h<br>
-base/gsline.c<br>
-base/gsline.h<br>
-base/gslparam.h<br>
-base/gsmalloc.c<br>
-base/gsmalloc.h<br>
-base/gsmatrix.c<br>
-base/gsmatrix.h<br>
-base/gsmchunk.c<br>
-base/gsmchunk.h<br>
-base/gsmd5.c<br>
-base/gsmd5.h<br>
-base/gsmdebug.h<br>
-base/gsmemlok.c<br>
-base/gsmemlok.h<br>
-base/gsmemory.c<br>
-base/gsmemory.h<br>
-base/gsmemraw.h<br>
-base/gsmemret.c<br>
-base/gsmemret.h<br>
-base/gsmisc.c<br>
-base/gsnamecl.c<br>
-base/gsnamecl.h<br>
-base/gsncdummy.c<br>
-base/gsncdummy.h<br>
-base/gsnogc.c<br>
-base/gsnogc.h<br>
-base/gsnotify.c<br>
-base/gsnotify.h<br>
-base/gsovrc.c<br>
-base/gsovrc.h<br>
-base/gspaint.c<br>
-base/gspaint.h<br>
-base/gsparam.c<br>
-base/gsparam.h<br>
-base/gsparam2.c<br>
-base/gsparams.c<br>
-base/gsparams.h<br>
-base/gsparamx.c<br>
-base/gsparamx.h<br>
-base/gspath.c<br>
-base/gspath.h<br>
-base/gspath1.c<br>
-base/gspath2.h<br>
-base/gspcolor.c<br>
-base/gspcolor.h<br>
-base/gspenum.h<br>
-base/gspmdrv.c<br>
-base/gspmdrv.def<br>
-base/gspmdrv.h<br>
-base/gspmdrv.icx<br>
-base/gspmdrv.rc<br>
-base/gsptype1.c<br>
-base/gsptype1.h<br>
-base/gsptype2.c<br>
-base/gsptype2.h<br>
-base/gsrect.h<br>
-base/gsrefct.h<br>
-base/gsromfs0.c<br>
-base/gsrop.c<br>
-base/gsrop.h<br>
-base/gsroprun.c<br>
-base/gsroprun1.h<br>
-base/gsroprun24.h<br>
-base/gsroprun8.h<br>
-base/gsropt.h<br>
-base/gsroptab.c<br>
-base/gsserial.c<br>
-base/gsserial.h<br>
-base/gsshade.c<br>
-base/gsshade.h<br>
-base/gssprintf.c<br>
-base/gssprintf.h<br>
-base/gsstate.c<br>
-base/gsstate.h<br>
-base/gsstrtok.c<br>
-base/gsstrtok.h<br>
-base/gsstruct.h<br>
-base/gsstype.h<br>
-base/gstext.c<br>
-base/gstext.h<br>
-base/gstiffio.c<br>
-base/gstiffio.h<br>
-base/gstparam.h<br>
-base/gstrans.c<br>
-base/gstrans.h<br>
-base/gstrap.c<br>
-base/gstrap.h<br>
-base/gstype1.c<br>
-base/gstype1.h<br>
-base/gstype2.c<br>
-base/gstype42.c<br>
-base/gstypes.h<br>
-base/gsuid.h<br>
-base/gsutil.c<br>
-base/gsutil.h<br>
-base/gswin.icx<br>
-base/gswin.rc<br>
-base/gswin16.icx<br>
-base/gswin32.rc<br>
-base/gsxfont.h<br>
-base/gx.h<br>
-base/gxacpath.c<br>
-base/gxalloc.h<br>
-base/gxalpha.h<br>
-base/gxarith.h<br>
-base/gxband.h<br>
-base/gxbcache.c<br>
-base/gxbcache.h<br>
-base/gxbitfmt.h<br>
-base/gxbitmap.h<br>
-base/gxbitops.h<br>
-base/gxblend.c<br>
-base/gxblend.h<br>
-base/gxblend1.c<br>
-base/gxccache.c<br>
-base/gxccman.c<br>
-base/gxcdevn.h<br>
-base/gxchar.c<br>
-base/gxchar.h<br>
-base/gxchrout.c<br>
-base/gxchrout.h<br>
-base/gxcht.c<br>
-base/gxcid.h<br>
-base/gxcie.h<br>
-base/gxcindex.h<br>
-base/gxclbits.c<br>
-base/gxcldev.h<br>
-base/gxclfile.c<br>
-base/gxclimag.c<br>
-base/gxclio.h<br>
-base/gxclip.c<br>
-base/gxclip.h<br>
-base/gxclip2.c<br>
-base/gxclip2.h<br>
-base/gxclipm.c<br>
-base/gxclipm.h<br>
-base/gxclipsr.h<br>
-base/gxclist.c<br>
-base/gxclist.h<br>
-base/gxcllzw.c<br>
-base/gxclmem.c<br>
-base/gxclmem.h<br>
-base/gxclpage.c<br>
-base/gxclpage.h<br>
-base/gxclpath.c<br>
-base/gxclpath.h<br>
-base/gxclrast.c<br>
-base/gxclread.c<br>
-base/gxclrect.c<br>
-base/gxclthrd.c<br>
-base/gxclthrd.h<br>
-base/gxclutil.c<br>
-base/gxclzlib.c<br>
-base/gxcmap.c<br>
-base/gxcmap.h<br>
-base/gxcolor2.h<br>
-base/gxcomp.h<br>
-base/gxcoord.h<br>
-base/gxcpath.c<br>
-base/gxcpath.h<br>
-base/gxcspace.h<br>
-base/gxctable.c<br>
-base/gxctable.h<br>
-base/gxcvalue.h<br>
-base/gxdcconv.c<br>
-base/gxdcconv.h<br>
-base/gxdcolor.c<br>
-base/gxdcolor.h<br>
-base/gxdda.h<br>
-base/gxdevbuf.h<br>
-base/gxdevcli.h<br>
-base/gxdevice.h<br>
-base/gxdevmem.h<br>
-base/gxdevndi.c<br>
-base/gxdevndi.h<br>
-base/gxdevrop.h<br>
-base/gxdevsop.h<br>
-base/gxdht.h<br>
-base/gxdhtres.h<br>
-base/gxdhtserial.c<br>
-base/gxdhtserial.h<br>
-base/gxdither.h<br>
-base/gxdownscale.c<br>
-base/gxdownscale.h<br>
-base/gxdtfill.h<br>
-base/gxfapi.c<br>
-base/gxfapi.h<br>
-base/gxfapiu.c<br>
-base/gxfapiu.h<br>
-base/gxfarith.h<br>
-base/gxfcache.h<br>
-base/gxfcid.h<br>
-base/gxfcmap.h<br>
-base/gxfcmap1.h<br>
-base/gxfdrop.c<br>
-base/gxfdrop.h<br>
-base/gxfill.c<br>
-base/gxfill.h<br>
-base/gxfillsl.h<br>
-base/gxfilltr.h<br>
-base/gxfillts.h<br>
-base/gxfixed.h<br>
-base/gxfmap.h<br>
-base/gxfont.h<br>
-base/gxfont0.h<br>
-base/gxfont0c.h<br>
-base/gxfont1.h<br>
-base/gxfont42.h<br>
-base/gxfrac.h<br>
-base/gxftype.h<br>
-base/gxfunc.h<br>
-base/gxgetbit.h<br>
-base/gxhintn.c<br>
-base/gxhintn.h<br>
-base/gxhintn1.c<br>
-base/gxhldevc.c<br>
-base/gxhldevc.h<br>
-base/gxht.c<br>
-base/gxht.h<br>
-base/gxht_thresh.c<br>
-base/gxht_thresh.h<br>
-base/gxhtbit.c<br>
-base/gxhttile.h<br>
-base/gxhttype.h<br>
-base/gxi12bit.c<br>
-base/gxi16bit.c<br>
-base/gxiclass.h<br>
-base/gxicolor.c<br>
-base/gxidata.c<br>
-base/gxifast.c<br>
-base/gximag3x.c<br>
-base/gximag3x.h<br>
-base/gximage.c<br>
-base/gximage.h<br>
-base/gximage1.c<br>
-base/gximage2.c<br>
-base/gximage3.c<br>
-base/gximage3.h<br>
-base/gximage4.c<br>
-base/gximask.c<br>
-base/gximask.h<br>
-base/gximdecode.c<br>
-base/gximdecode.h<br>
-base/gximono.c<br>
-base/gxino12b.c<br>
-base/gxino16b.c<br>
-base/gxiodev.h<br>
-base/gxiparam.h<br>
-base/gxipixel.c<br>
-base/gxiscale.c<br>
-base/gxistate.h<br>
-base/gxline.h<br>
-base/gxlum.h<br>
-base/gxmatrix.h<br>
-base/gxmclip.c<br>
-base/gxmclip.h<br>
-base/gxobj.h<br>
-base/gxoprect.c<br>
-base/gxoprect.h<br>
-base/gxp1fill.c<br>
-base/gxp1impl.h<br>
-base/gxpageq.c<br>
-base/gxpageq.h<br>
-base/gxpaint.c<br>
-base/gxpaint.h<br>
-base/gxpath.c<br>
-base/gxpath.h<br>
-base/gxpath2.c<br>
-base/gxpcache.h<br>
-base/gxpcmap.c<br>
-base/gxpcolor.h<br>
-base/gxpcopy.c<br>
-base/gxpdash.c<br>
-base/gxpflat.c<br>
-base/gxrplane.h<br>
-base/gxsample.c<br>
-base/gxsample.h<br>
-base/gxsamplp.h<br>
-base/gxshade.c<br>
-base/gxshade.h<br>
-base/gxshade1.c<br>
-base/gxshade4.c<br>
-base/gxshade4.h<br>
-base/gxshade6.c<br>
-base/gxstate.h<br>
-base/gxstdio.h<br>
-base/gxstroke.c<br>
-base/gxsync.c<br>
-base/gxsync.h<br>
-base/gxtext.h<br>
-base/gxtmap.h<br>
-base/gxttf.h<br>
-base/gxttfb.c<br>
-base/gxttfb.h<br>
-base/gxtype1.c<br>
-base/gxtype1.h<br>
-base/gxxfont.h<br>
-base/gzacpath.h<br>
-base/gzcpath.h<br>
-base/gzht.h<br>
-base/gzline.h<br>
-base/gzpath.h<br>
-base/gzspotan.c<br>
-base/gzspotan.h<br>
-base/gzstate.h<br>
-base/icc34.h<br>
-base/ijs.mak<br>
-base/instcopy<br>
-base/jbig2.mak<br>
-base/jerror_.h<br>
-base/jmemcust.c<br>
-base/jmemcust.h<br>
-base/jpeg.mak<br>
-base/jpegxr.mak<br>
-base/lcms2.mak<br>
-base/lcups.mak<br>
-base/lcupsi.mak<br>
-base/ldf_jb2.mak<br>
-base/lib.mak<br>
-base/locale_.h<br>
-base/lwf_jp2.mak<br>
-base/macgenmcpxml.sh<br>
-base/macos-mcp.mak<br>
-base/macos_carbon_d_pre.h<br>
-base/macos_carbon_pre.h<br>
-base/macos_classic_d_pre.h<br>
-base/macosx.mak<br>
-base/macsystypes.h<br>
-base/malloc_.h<br>
-base/math_.h<br>
-base/md5main.c<br>
-base/memento.c<br>
-base/memento.h<br>
-base/memory_.h<br>
-base/mkromfs.c<br>
-base/msvccmd.mak<br>
-base/msvclib.mak<br>
-base/msvctail.mak<br>
-base/mv.bat<br>
-base/mv.cmd<br>
-base/openjpeg.mak<br>
-base/openvms.mak<br>
-base/openvms.mmk<br>
-base/pcwin.mak<br>
-base/pipe_.h<br>
-base/png.mak<br>
-base/png_.h<br>
-base/ramfs.c<br>
-base/ramfs.h<br>
-base/rm.bat<br>
-base/rm.cmd<br>
-base/rm_all.com<br>
-base/rm_one.com<br>
-base/sa85d.c<br>
-base/sa85d.h<br>
-base/sa85x.h<br>
-base/saes.c<br>
-base/saes.h<br>
-base/sarc4.c<br>
-base/sarc4.h<br>
-base/sbcp.c<br>
-base/sbcp.h<br>
-base/sbtx.h<br>
-base/scanchar.h<br>
-base/scantab.c<br>
-base/scf.h<br>
-base/scfd.c<br>
-base/scfdgen.c<br>
-base/scfdtab.c<br>
-base/scfe.c<br>
-base/scfetab.c<br>
-base/scfparam.c<br>
-base/scfx.h<br>
-base/scommon.h<br>
-base/sdcparam.c<br>
-base/sdcparam.h<br>
-base/sdct.h<br>
-base/sdctc.c<br>
-base/sdctd.c<br>
-base/sdcte.c<br>
-base/sddparam.c<br>
-base/sdeparam.c<br>
-base/seexec.c<br>
-base/setjmp_.h<br>
-base/sfilter.h<br>
-base/sfilter2.c<br>
-base/sfxboth.c<br>
-base/sfxcommon.c<br>
-base/sfxfd.c<br>
-base/sfxstdio.c<br>
-base/sha2.c<br>
-base/sha2.h<br>
-base/shc.c<br>
-base/shc.h<br>
-base/sidscale.c<br>
-base/sidscale.h<br>
-base/siinterp.c<br>
-base/siinterp.h<br>
-base/simscale.c<br>
-base/simscale.h<br>
-base/siscale.c<br>
-base/siscale.h<br>
-base/sisparam.h<br>
-base/sjbig2.c<br>
-base/sjbig2.h<br>
-base/sjbig2_luratech.c<br>
-base/sjbig2_luratech.h<br>
-base/sjpeg.h<br>
-base/sjpegc.c<br>
-base/sjpegd.c<br>
-base/sjpege.c<br>
-base/sjpx_luratech.c<br>
-base/sjpx_luratech.h<br>
-base/sjpx_openjpeg.c<br>
-base/sjpx_openjpeg.h<br>
-base/slzwc.c<br>
-base/slzwd.c<br>
-base/slzwe.c<br>
-base/slzwx.h<br>
-base/smd5.c<br>
-base/smd5.h<br>
-base/smtf.c<br>
-base/smtf.h<br>
-base/spdiff.c<br>
-base/spdiffx.h<br>
-base/spngp.c<br>
-base/spngpx.h<br>
-base/spprint.c<br>
-base/spprint.h<br>
-base/spsdf.c<br>
-base/spsdf.h<br>
-base/srdline.h<br>
-base/srld.c<br>
-base/srle.c<br>
-base/srlx.h<br>
-base/ssha2.c<br>
-base/ssha2.h<br>
-base/sstring.c<br>
-base/sstring.h<br>
-base/stat_.h<br>
-base/std.h<br>
-base/stdint_.h<br>
-base/stdio_.h<br>
-base/stdpn.h<br>
-base/stdpre.h<br>
-base/stream.c<br>
-base/stream.h<br>
-base/strimpl.h<br>
-base/string_.h<br>
-base/strmio.c<br>
-base/strmio.h<br>
-base/stub.mak<br>
-base/szlibc.c<br>
-base/szlibd.c<br>
-base/szlibe.c<br>
-base/szlibx.h<br>
-base/szlibxx.h<br>
-base/tiff.mak<br>
-base/time_.h<br>
-base/ttcalc.c<br>
-base/ttcalc.h<br>
-base/ttcommon.h<br>
-base/ttconf.h<br>
-base/ttconfig.h<br>
-base/ttfinp.c<br>
-base/ttfinp.h<br>
-base/ttfmain.c<br>
-base/ttfmemd.c<br>
-base/ttfmemd.h<br>
-base/ttfoutl.h<br>
-base/ttfsfnt.h<br>
-base/ttinterp.c<br>
-base/ttinterp.h<br>
-base/ttload.c<br>
-base/ttload.h<br>
-base/ttmisc.h<br>
-base/ttobjs.c<br>
-base/ttobjs.h<br>
-base/tttables.h<br>
-base/tttype.h<br>
-base/tttypes.h<br>
-base/ugcclib.mak<br>
-base/unistd_.h<br>
-base/unix-aux.mak<br>
-base/unix-dll.mak<br>
-base/unix-end.mak<br>
-base/unix-gcc.mak<br>
-base/unixansi.mak<br>
-base/unixhead.mak<br>
-base/unixinst.mak<br>
-base/unixlink.mak<br>
-base/valgrind.h<br>
-base/vdtrace.c<br>
-base/vdtrace.h<br>
-base/version.mak<br>
-base/vms_x_fix.h<br>
-base/vmsmath.h<br>
-base/windows_.h<br>
-base/winlib.mak<br>
-base/winplat.mak<br>
-base/winrtsup.cpp<br>
-base/winrtsup.h<br>
-base/wrfont.c<br>
-base/wrfont.h<br>
-base/write_t1.c<br>
-base/write_t1.h<br>
-base/write_t2.c<br>
-base/write_t2.h<br>
-base/x_.h<br>
-base/xpsprint.cpp<br>
-base/zlib.mak<br>
-common/cp.bat<br>
-common/gccdefs.mak<br>
-common/generic.mak<br>
-common/msvc_top.mak<br>
-common/msvcdefs.mak<br>
-common/mv.bat<br>
-common/pcdefs.mak<br>
-common/rm.bat<br>
-common/sgidefs.mak<br>
-common/ugcc_top.mak<br>
-common/unixdefs.mak<br>
-config.mak.in<br>
-configure.ac<br>
-contrib/chp2200/AUTHORS<br>
-contrib/chp2200/COPYING<br>
-contrib/chp2200/INSTALL<br>
-contrib/contrib.mak<br>
-contrib/defs.h<br>
-contrib/eplaser/gdevescv.c<br>
-contrib/eplaser/gdevescv.h<br>
-contrib/epson740/README<br>
-contrib/epson740/printerdb_rh5.2<br>
-contrib/epson740/printerdb_rh6.0<br>
-contrib/epson740/ps-to-printer.fpi_rh5.2<br>
-contrib/epson740/upp-HowTo-to-be<br>
-contrib/gdevbjc_.c<br>
-contrib/gdevbjc_.h<br>
-contrib/gdevbjca.c<br>
-contrib/gdevcd8.c<br>
-contrib/gdevcd8.h<br>
-contrib/gdevdj9.c<br>
-contrib/gdevgdi.c<br>
-contrib/gdevhl12.c<br>
-contrib/gdevln03.c<br>
-contrib/gdevlx32.c<br>
-contrib/gdevlx7.c<br>
-contrib/gdevmd2k.c<br>
-contrib/gdevop4w.c<br>
-contrib/gdevxes.c<br>
-contrib/gomni.c<br>
-contrib/japanese/dmp_init.ps<br>
-contrib/japanese/dmp_site.ps<br>
-contrib/japanese/doc/Gdevlips.htm<br>
-contrib/japanese/doc/README.gs550j<br>
-contrib/japanese/doc/cdj880.txt<br>
-contrib/japanese/doc/dj505j.txt<br>
-contrib/japanese/doc/djgpp.txt<br>
-contrib/japanese/doc/gdev10v.txt<br>
-contrib/japanese/doc/gdevalps.txt<br>
-contrib/japanese/doc/gdevcd8.txt<br>
-contrib/japanese/doc/gdevdmpr.txt<br>
-contrib/japanese/doc/gdevfmlbp.txt<br>
-contrib/japanese/doc/gdevj100.txt<br>
-contrib/japanese/doc/gdevlbp3.txt<br>
-contrib/japanese/doc/gdevmag.txt<br>
-contrib/japanese/doc/gdevmd2k.txt<br>
-contrib/japanese/doc/gdevmjc.txt<br>
-contrib/japanese/doc/gdevml6.txt<br>
-contrib/japanese/doc/gdevp201.txt<br>
-contrib/japanese/doc/gs261j.euc<br>
-contrib/japanese/doc/gs261j.txt<br>
-contrib/japanese/dviprlib.c<br>
-contrib/japanese/dviprlib.h<br>
-contrib/japanese/escp_24.src<br>
-contrib/japanese/gdev10v.c<br>
-contrib/japanese/gdevalps.c<br>
-contrib/japanese/gdevdmpr.c<br>
-contrib/japanese/gdevespg.c<br>
-contrib/japanese/gdevfmlbp.c<br>
-contrib/japanese/gdevfmpr.c<br>
-contrib/japanese/gdevj100.c<br>
-contrib/japanese/gdevlbp3.c<br>
-contrib/japanese/gdevmag.c<br>
-contrib/japanese/gdevmjc.c<br>
-contrib/japanese/gdevmjc.h<br>
-contrib/japanese/gdevml6.c<br>
-contrib/japanese/gdevnpdl.c<br>
-contrib/japanese/gdevp201.c<br>
-contrib/japanese/gdevrpdl.c<br>
-contrib/lips4/gdevl4r.c<br>
-contrib/lips4/gdevl4v.c<br>
-contrib/lips4/gdevlips.c<br>
-contrib/lips4/gdevlips.h<br>
-contrib/lips4/gdevlprn.c<br>
-contrib/lips4/gdevlprn.h<br>
-contrib/lxm3200-tweaked/LICENSE<br>
-contrib/lxm3200-tweaked/README<br>
-contrib/lxm3200-tweaked/RELEASE_NOTES<br>
-contrib/lxm3200-tweaked/Z12-Z31-QuickSetup<br>
-contrib/md2k_md5k/README.jis<br>
-contrib/opvp/gdevopvp.c<br>
-contrib/opvp/opvp.h<br>
-contrib/opvp/opvp_0_2_0.h<br>
-contrib/opvp/opvp_common.h<br>
-contrib/opvp/opvp_media.def<br>
-contrib/pcl3/BUGS<br>
-contrib/pcl3/LGPL<br>
-contrib/pcl3/NEWS<br>
-contrib/pcl3/README<br>
-contrib/pcl3/doc/gs-mods.txt<br>
-contrib/pcl3/doc/gs-pcl3.1<br>
-contrib/pcl3/doc/gs-pcl3.html<br>
-contrib/pcl3/doc/gs-pcl3.ref<br>
-contrib/pcl3/doc/how-to-report.txt<br>
-contrib/pcl3/doc/notes.bbl<br>
-contrib/pcl3/doc/notes.tex<br>
-contrib/pcl3/doc/pcl3opts.1<br>
-contrib/pcl3/doc/pcl3opts.html<br>
-contrib/pcl3/doc/pcl3opts.ref<br>
-contrib/pcl3/doc/reports.txt<br>
-contrib/pcl3/eprn/eprnfs.c<br>
-contrib/pcl3/eprn/eprnparm.c<br>
-contrib/pcl3/eprn/eprnrend.c<br>
-contrib/pcl3/eprn/gdeveprn.c<br>
-contrib/pcl3/eprn/gdeveprn.h<br>
-contrib/pcl3/eprn/mediasize.c<br>
-contrib/pcl3/eprn/mediasize.h<br>
-contrib/pcl3/eprn/pagecount.c<br>
-contrib/pcl3/eprn/pagecount.h<br>
-contrib/pcl3/lib/cups-pcl3<br>
-contrib/pcl3/lib/example.mcf<br>
-contrib/pcl3/lib/if-pcl3<br>
-contrib/pcl3/pcl3.tar.sig<br>
-contrib/pcl3/ppd/README<br>
-contrib/pcl3/ppd/catppd<br>
-contrib/pcl3/ppd/fonts.ppd<br>
-contrib/pcl3/ppd/gs-5.50.ppd<br>
-contrib/pcl3/ppd/gs-6.01.ppd<br>
-contrib/pcl3/ppd/gs-6.50.ppd<br>
-contrib/pcl3/ppd/gs-6.51.ppd<br>
-contrib/pcl3/ppd/gs-7.00.ppd<br>
-contrib/pcl3/ppd/gs-common.ppd<br>
-contrib/pcl3/ppd/gs-pcl3-common.ppd<br>
-contrib/pcl3/ppd/gs-pcl3-hpdj1120c.ppd<br>
-contrib/pcl3/ppd/gs-pcl3-hpdj3xx.ppd<br>
-contrib/pcl3/ppd/gs-pcl3-hpdj400.ppd<br>
-contrib/pcl3/ppd/gs-pcl3-hpdj500.ppd<br>
-contrib/pcl3/ppd/gs-pcl3-hpdj500c.ppd<br>
-contrib/pcl3/ppd/gs-pcl3-hpdj510.ppd<br>
-contrib/pcl3/ppd/gs-pcl3-hpdj540.ppd<br>
-contrib/pcl3/ppd/gs-pcl3-hpdj550c.ppd<br>
-contrib/pcl3/ppd/gs-pcl3-hpdj600.ppd<br>
-contrib/pcl3/ppd/gs-pcl3-hpdj660c.ppd<br>
-contrib/pcl3/ppd/gs-pcl3-hpdj680c.ppd<br>
-contrib/pcl3/ppd/gs-pcl3-hpdj8xxc.ppd<br>
-contrib/pcl3/ppd/gs-pcl3-hpdjportable.ppd<br>
-contrib/pcl3/ppd/gs-pcl3-unspec.ppd<br>
-contrib/pcl3/ppd/gs-pcl3-unspecold.ppd<br>
-contrib/pcl3/ps/calign.ps<br>
-contrib/pcl3/ps/dumppdd.ps<br>
-contrib/pcl3/ps/levels-test.ps<br>
-contrib/pcl3/ps/margins-A4.ps<br>
-contrib/pcl3/ps/margins-A4Rotated.ps<br>
-contrib/pcl3/ps/margins-Env10Rotated.ps<br>
-contrib/pcl3/ps/margins-EnvDLRotated.ps<br>
-contrib/pcl3/ps/margins-Letter.ps<br>
-contrib/pcl3/ps/margins-LetterRotated.ps<br>
-contrib/pcl3/src/contrib.mak-5.50.add<br>
-contrib/pcl3/src/contrib.mak-6.01.add<br>
-contrib/pcl3/src/contrib.mak-6.50.add<br>
-contrib/pcl3/src/contrib.mak-6.51.add<br>
-contrib/pcl3/src/contrib.mak-7.00.add<br>
-contrib/pcl3/src/gdevpcl3.c<br>
-contrib/pcl3/src/pcl3opts-de.msg<br>
-contrib/pcl3/src/pcl3opts-en.msg<br>
-contrib/pcl3/src/pcl3opts.c<br>
-contrib/pcl3/src/pclcap.c<br>
-contrib/pcl3/src/pclcap.h<br>
-contrib/pcl3/src/pclcomp.c<br>
-contrib/pcl3/src/pclgen.c<br>
-contrib/pcl3/src/pclgen.h<br>
-contrib/pcl3/src/pclscan.c<br>
-contrib/pcl3/src/pclscan.h<br>
-contrib/pcl3/src/pclsize.c<br>
-contrib/pcl3/src/pclsize.h<br>
-contrib/pcl3/src/zmedia2.c-5.50.diff<br>
-contrib/pcl3/src/zmedia2.c-6.01.diff<br>
-contrib/pcl3/src/zmedia2.c-6.50.diff<br>
-contrib/pcl3/src/zmedia2.c-6.51.diff<br>
-contrib/pcl3/src/zmedia2.c-7.00.diff<br>
-contrib/pscolor/Makefile<br>
-contrib/pscolor/black.pdf<br>
-contrib/pscolor/black.ps<br>
-contrib/pscolor/color.pdf<br>
-contrib/pscolor/color.ps<br>
-contrib/pscolor/colorsplit.vcproj<br>
-contrib/pscolor/common.mak<br>
-contrib/pscolor/input.ps<br>
-contrib/pscolor/instream.yy<br>
-contrib/pscolor/test.c<br>
-contrib/pscolor/windows.mak<br>
-contrib/uniprint/PM760p.upp<br>
-contrib/uniprint/PM760pl.upp<br>
-contrib/uniprint/PM820p.upp<br>
-contrib/uniprint/PM820pl.upp<br>
-contrib/uniprint/Stc670p.upp<br>
-contrib/uniprint/Stc670pl.upp<br>
-contrib/uniprint/Stc680p.upp<br>
-contrib/uniprint/Stc680pl.upp<br>
-contrib/uniprint/Stc740p.upp<br>
-contrib/uniprint/Stc740pl.upp<br>
-contrib/uniprint/Stc760p.upp<br>
-contrib/uniprint/Stc760pl.upp<br>
-contrib/uniprint/Stc777p.upp<br>
-contrib/uniprint/Stc777pl.upp<br>
-contrib/uniprint/Stp720p.upp<br>
-contrib/uniprint/Stp720pl.upp<br>
-contrib/uniprint/Stp870p.upp<br>
-contrib/uniprint/Stp870pl.upp<br>
-contrib/uniprint/bjc6000a1.upp<br>
-contrib/uniprint/bjc6000b1.upp<br>
-contrib/uniprint/s400a1.upp<br>
-contrib/uniprint/s400b1.upp<br>
-contrib/uniprint/sharp.upp<br>
-contrib/uniprint/sipixa6.upp<br>
-contrib/uniprint/stc740ih.upp<br>
-cups/cups.mak<br>
-cups/gdevcups.c<br>
-cups/libs/Makedefs<br>
-cups/libs/configlinux.h<br>
-cups/libs/configwin.h<br>
-cups/libs/cups/Dependencies<br>
-cups/libs/cups/Makefile<br>
-cups/libs/cups/adminutil.c<br>
-cups/libs/cups/adminutil.h<br>
-cups/libs/cups/api-array.header<br>
-cups/libs/cups/api-array.shtml<br>
-cups/libs/cups/api-cups.header<br>
-cups/libs/cups/api-cups.shtml<br>
-cups/libs/cups/api-filedir.header<br>
-cups/libs/cups/api-filedir.shtml<br>
-cups/libs/cups/api-filter.header<br>
-cups/libs/cups/api-filter.shtml<br>
-cups/libs/cups/api-httpipp.header<br>
-cups/libs/cups/api-httpipp.shtml<br>
-cups/libs/cups/api-overview.header<br>
-cups/libs/cups/api-overview.shtml<br>
-cups/libs/cups/api-ppd.header<br>
-cups/libs/cups/api-ppd.shtml<br>
-cups/libs/cups/array-private.h<br>
-cups/libs/cups/array.c<br>
-cups/libs/cups/array.h<br>
-cups/libs/cups/attr.c<br>
-cups/libs/cups/auth.c<br>
-cups/libs/cups/backchannel.c<br>
-cups/libs/cups/backend.c<br>
-cups/libs/cups/backend.h<br>
-cups/libs/cups/conflicts.c<br>
-cups/libs/cups/cups-private.h<br>
-cups/libs/cups/cups.h<br>
-cups/libs/cups/custom.c<br>
-cups/libs/cups/debug-private.h<br>
-cups/libs/cups/debug.c<br>
-cups/libs/cups/dest-job.c<br>
-cups/libs/cups/dest-localization.c<br>
-cups/libs/cups/dest-options.c<br>
-cups/libs/cups/dest.c<br>
-cups/libs/cups/dir.c<br>
-cups/libs/cups/dir.h<br>
-cups/libs/cups/emit.c<br>
-cups/libs/cups/encode.c<br>
-cups/libs/cups/file-private.h<br>
-cups/libs/cups/file.c<br>
-cups/libs/cups/file.h<br>
-cups/libs/cups/getdevices.c<br>
-cups/libs/cups/getifaddrs.c<br>
-cups/libs/cups/getputfile.c<br>
-cups/libs/cups/globals.c<br>
-cups/libs/cups/http-addr.c<br>
-cups/libs/cups/http-addrlist.c<br>
-cups/libs/cups/http-private.h<br>
-cups/libs/cups/http-support.c<br>
-cups/libs/cups/http.c<br>
-cups/libs/cups/http.h<br>
-cups/libs/cups/ipp-private.h<br>
-cups/libs/cups/ipp-support.c<br>
-cups/libs/cups/ipp.c<br>
-cups/libs/cups/ipp.h<br>
-cups/libs/cups/langprintf.c<br>
-cups/libs/cups/language-private.h<br>
-cups/libs/cups/language.c<br>
-cups/libs/cups/language.h<br>
-cups/libs/cups/libcups2.def<br>
-cups/libs/cups/libcups2.rc<br>
-cups/libs/cups/libcups_s.exp<br>
-cups/libs/cups/localize.c<br>
-cups/libs/cups/mark.c<br>
-cups/libs/cups/md5-private.h<br>
-cups/libs/cups/md5.c<br>
-cups/libs/cups/md5passwd.c<br>
-cups/libs/cups/notify.c<br>
-cups/libs/cups/options.c<br>
-cups/libs/cups/page.c<br>
-cups/libs/cups/ppd-cache.c<br>
-cups/libs/cups/ppd-private.h<br>
-cups/libs/cups/ppd.c<br>
-cups/libs/cups/ppd.h<br>
-cups/libs/cups/pwg-media.c<br>
-cups/libs/cups/pwg-private.h<br>
-cups/libs/cups/pwg.h<br>
-cups/libs/cups/raster-private.h<br>
-cups/libs/cups/raster.h<br>
-cups/libs/cups/request.c<br>
-cups/libs/cups/sidechannel.c<br>
-cups/libs/cups/sidechannel.h<br>
-cups/libs/cups/snmp-private.h<br>
-cups/libs/cups/snmp.c<br>
-cups/libs/cups/snprintf.c<br>
-cups/libs/cups/sspi-private.h<br>
-cups/libs/cups/sspi.c<br>
-cups/libs/cups/string-private.h<br>
-cups/libs/cups/string.c<br>
-cups/libs/cups/tempfile.c<br>
-cups/libs/cups/test.ppd<br>
-cups/libs/cups/test2.ppd<br>
-cups/libs/cups/testadmin.c<br>
-cups/libs/cups/testarray.c<br>
-cups/libs/cups/testconflicts.c<br>
-cups/libs/cups/testcups.c<br>
-cups/libs/cups/testfile.c<br>
-cups/libs/cups/testhttp.c<br>
-cups/libs/cups/testi18n.c<br>
-cups/libs/cups/testipp.c<br>
-cups/libs/cups/testlang.c<br>
-cups/libs/cups/testoptions.c<br>
-cups/libs/cups/testppd.c<br>
-cups/libs/cups/testpwg.c<br>
-cups/libs/cups/testsnmp.c<br>
-cups/libs/cups/thread-private.h<br>
-cups/libs/cups/thread.c<br>
-cups/libs/cups/transcode.c<br>
-cups/libs/cups/transcode.h<br>
-cups/libs/cups/usersys.c<br>
-cups/libs/cups/utf8demo.txt<br>
-cups/libs/cups/util.c<br>
-cups/libs/cups/versioning.h<br>
-cups/libs/filter/Dependencies<br>
-cups/libs/filter/Makefile<br>
-cups/libs/filter/api-raster.header<br>
-cups/libs/filter/api-raster.shtml<br>
-cups/libs/filter/commandtops.c<br>
-cups/libs/filter/common.c<br>
-cups/libs/filter/common.h<br>
-cups/libs/filter/error.c<br>
-cups/libs/filter/gziptoany.c<br>
-cups/libs/filter/interpret.c<br>
-cups/libs/filter/libcupsimage2.def<br>
-cups/libs/filter/libcupsimage_s.exp<br>
-cups/libs/filter/postscript-driver.header<br>
-cups/libs/filter/postscript-driver.shtml<br>
-cups/libs/filter/ppd-compiler.header<br>
-cups/libs/filter/ppd-compiler.shtml<br>
-cups/libs/filter/pstops.c<br>
-cups/libs/filter/raster-driver.header<br>
-cups/libs/filter/raster-driver.shtml<br>
-cups/libs/filter/raster.c<br>
-cups/libs/filter/rasterbench.c<br>
-cups/libs/filter/rastertoepson.c<br>
-cups/libs/filter/rastertohp.c<br>
-cups/libs/filter/rastertolabel.c<br>
-cups/libs/filter/rastertopwg.c<br>
-cups/libs/filter/spec-ppd.header<br>
-cups/libs/filter/spec-ppd.shtml<br>
-cups/libs/filter/testraster.c<br>
-devices/contrib.mak<br>
-devices/devs.mak<br>
-devices/gdev3852.c<br>
-devices/gdev3b1.c<br>
-devices/gdev4081.c<br>
-devices/gdev4693.c<br>
-devices/gdev8510.c<br>
-devices/gdev8bcm.c<br>
-devices/gdev8bcm.h<br>
-devices/gdevadmp.c<br>
-devices/gdevatx.c<br>
-devices/gdevbit.c<br>
-devices/gdevbj10.c<br>
-devices/gdevbjc.h<br>
-devices/gdevbjcl.c<br>
-devices/gdevbjcl.h<br>
-devices/gdevbmp.c<br>
-devices/gdevbmp.h<br>
-devices/gdevbmpa.c<br>
-devices/gdevbmpc.c<br>
-devices/gdevccr.c<br>
-devices/gdevcdj.c<br>
-devices/gdevcfax.c<br>
-devices/gdevcif.c<br>
-devices/gdevclj.c<br>
-devices/gdevcljc.c<br>
-devices/gdevcmykog.c<br>
-devices/gdevcp50.c<br>
-devices/gdevcslw.c<br>
-devices/gdevdfax.c<br>
-devices/gdevdjet.c<br>
-devices/gdevdjtc.c<br>
-devices/gdevdljm.c<br>
-devices/gdevdljm.h<br>
-devices/gdevdm24.c<br>
-devices/gdevdsp.c<br>
-devices/gdevdsp.h<br>
-devices/gdevdsp2.h<br>
-devices/gdevepsc.c<br>
-devices/gdevepsn.c<br>
-devices/gdevescp.c<br>
-devices/gdevevga.c<br>
-devices/gdevfax.c<br>
-devices/gdevfax.h<br>
-devices/gdevfpng.c<br>
-devices/gdevherc.c<br>
-devices/gdevhl7x.c<br>
-devices/gdevicov.c<br>
-devices/gdevifno.c<br>
-devices/gdevijs.c<br>
-devices/gdevimgn.c<br>
-devices/gdevjbig2.c<br>
-devices/gdevjpeg.c<br>
-devices/gdevjpx.c<br>
-devices/gdevl256.c<br>
-devices/gdevl31s.c<br>
-devices/gdevlbp8.c<br>
-devices/gdevlj56.c<br>
-devices/gdevlp8k.c<br>
-devices/gdevlxm.c<br>
-devices/gdevmac.c<br>
-devices/gdevmac.h<br>
-devices/gdevmacpictop.h<br>
-devices/gdevmacttf.h<br>
-devices/gdevmeds.c<br>
-devices/gdevmeds.h<br>
-devices/gdevmgr.c<br>
-devices/gdevmgr.h<br>
-devices/gdevmiff.c<br>
-devices/gdevmswn.c<br>
-devices/gdevmswn.h<br>
-devices/gdevmsxf.c<br>
-devices/gdevn533.c<br>
-devices/gdevo182.c<br>
-devices/gdevokii.c<br>
-devices/gdevos2p.c<br>
-devices/gdevp2up.c<br>
-devices/gdevpbm.c<br>
-devices/gdevpcfb.c<br>
-devices/gdevpcfb.h<br>
-devices/gdevpcl.c<br>
-devices/gdevpcl.h<br>
-devices/gdevpcx.c<br>
-devices/gdevpe.c<br>
-devices/gdevperm.c<br>
-devices/gdevphex.c<br>
-devices/gdevpjet.c<br>
-devices/gdevplan.c<br>
-devices/gdevplib.c<br>
-devices/gdevplib.h<br>
-devices/gdevpm.h<br>
-devices/gdevpng.c<br>
-devices/gdevpsd.c<br>
-devices/gdevpsim.c<br>
-devices/gdevpxut.c<br>
-devices/gdevpxut.h<br>
-devices/gdevrinkj.c<br>
-devices/gdevs3ga.c<br>
-devices/gdevsco.c<br>
-devices/gdevsgi.c<br>
-devices/gdevsgi.h<br>
-devices/gdevsj48.c<br>
-devices/gdevsnfb.c<br>
-devices/gdevsppr.c<br>
-devices/gdevstc.c<br>
-devices/gdevstc.h<br>
-devices/gdevstc1.c<br>
-devices/gdevstc2.c<br>
-devices/gdevstc3.c<br>
-devices/gdevstc4.c<br>
-devices/gdevsun.c<br>
-devices/gdevsunr.c<br>
-devices/gdevsvga.c<br>
-devices/gdevsvga.h<br>
-devices/gdevtfax.c<br>
-devices/gdevtfax.h<br>
-devices/gdevtfnx.c<br>
-devices/gdevtifs.c<br>
-devices/gdevtifs.h<br>
-devices/gdevtknk.c<br>
-devices/gdevtrac.c<br>
-devices/gdevtsep.c<br>
-devices/gdevupd.c<br>
-devices/gdevvglb.c<br>
-devices/gdevwddb.c<br>
-devices/gdevwdib.c<br>
-devices/gdevwpr2.c<br>
-devices/gdevwprn.c<br>
-devices/gdevx.c<br>
-devices/gdevx.h<br>
-devices/gdevxalt.c<br>
-devices/gdevxcf.c<br>
-devices/gdevxcmp.c<br>
-devices/gdevxcmp.h<br>
-devices/gdevxini.c<br>
-devices/gdevxres.c<br>
-devices/gxfcopy.c<br>
-devices/gxfcopy.h<br>
-devices/minftrsz.c<br>
-devices/minftrsz.h<br>
-devices/rinkj/evenbetter-rll.c<br>
-devices/rinkj/evenbetter-rll.h<br>
-devices/rinkj/rinkj-byte-stream.c<br>
-devices/rinkj/rinkj-byte-stream.h<br>
-devices/rinkj/rinkj-config.c<br>
-devices/rinkj/rinkj-config.h<br>
-devices/rinkj/rinkj-device.c<br>
-devices/rinkj/rinkj-device.h<br>
-devices/rinkj/rinkj-dither.c<br>
-devices/rinkj/rinkj-dither.h<br>
-devices/rinkj/rinkj-epson870.c<br>
-devices/rinkj/rinkj-epson870.h<br>
-devices/rinkj/rinkj-screen-eb.c<br>
-devices/rinkj/rinkj-screen-eb.h<br>
-devices/vector/gdevagl.c<br>
-devices/vector/gdevagl.h<br>
-devices/vector/gdevpdf.c<br>
-devices/vector/gdevpdfb.c<br>
-devices/vector/gdevpdfb.h<br>
-devices/vector/gdevpdfc.c<br>
-devices/vector/gdevpdfc.h<br>
-devices/vector/gdevpdfd.c<br>
-devices/vector/gdevpdfe.c<br>
-devices/vector/gdevpdfg.c<br>
-devices/vector/gdevpdfg.h<br>
-devices/vector/gdevpdfi.c<br>
-devices/vector/gdevpdfj.c<br>
-devices/vector/gdevpdfk.c<br>
-devices/vector/gdevpdfm.c<br>
-devices/vector/gdevpdfo.c<br>
-devices/vector/gdevpdfo.h<br>
-devices/vector/gdevpdfp.c<br>
-devices/vector/gdevpdfr.c<br>
-devices/vector/gdevpdft.c<br>
-devices/vector/gdevpdfu.c<br>
-devices/vector/gdevpdfv.c<br>
-devices/vector/gdevpdfx.h<br>
-devices/vector/gdevpdt.c<br>
-devices/vector/gdevpdt.h<br>
-devices/vector/gdevpdtb.c<br>
-devices/vector/gdevpdtb.h<br>
-devices/vector/gdevpdtc.c<br>
-devices/vector/gdevpdtd.c<br>
-devices/vector/gdevpdtd.h<br>
-devices/vector/gdevpdte.c<br>
-devices/vector/gdevpdtf.c<br>
-devices/vector/gdevpdtf.h<br>
-devices/vector/gdevpdti.c<br>
-devices/vector/gdevpdti.h<br>
-devices/vector/gdevpdts.c<br>
-devices/vector/gdevpdts.h<br>
-devices/vector/gdevpdtt.c<br>
-devices/vector/gdevpdtt.h<br>
-devices/vector/gdevpdtv.c<br>
-devices/vector/gdevpdtv.h<br>
-devices/vector/gdevpdtw.c<br>
-devices/vector/gdevpdtw.h<br>
-devices/vector/gdevpdtx.h<br>
-devices/vector/gdevpsdf.h<br>
-devices/vector/gdevpsdi.c<br>
-devices/vector/gdevpsdp.c<br>
-devices/vector/gdevpsds.c<br>
-devices/vector/gdevpsds.h<br>
-devices/vector/gdevpsdu.c<br>
-devices/vector/gdevpsf.h<br>
-devices/vector/gdevpsf1.c<br>
-devices/vector/gdevpsf2.c<br>
-devices/vector/gdevpsfm.c<br>
-devices/vector/gdevpsft.c<br>
-devices/vector/gdevpsfu.c<br>
-devices/vector/gdevpsfx.c<br>
-devices/vector/gdevpsu.c<br>
-devices/vector/gdevpsu.h<br>
-devices/vector/gdevpx.c<br>
-devices/vector/gdevtxtw.c<br>
-devices/vector/gdevxps.c<br>
-devices/vector/opdfread.h<br>
-devices/vector/whitelst.c<br>
-devices/vector/whitelst.h<br>
-doc/API.htm<br>
-doc/AUTHORS<br>
-doc/C-style.htm<br>
-doc/COPYING<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/GS9_Color_Management.pdf<br>
-doc/GS9_Color_Management.tex<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/Makefile<br>
-doc/News.htm<br>
-doc/Projects.htm<br>
-doc/Ps-style.htm<br>
-doc/Ps2epsi.htm<br>
-doc/Ps2pdf.htm<br>
-doc/Ps2ps2.htm<br>
-doc/Psfiles.htm<br>
-doc/README<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/WhatIsGS.htm<br>
-doc/Xfonts.htm<br>
-doc/ghostpdl.pdf<br>
-doc/ghostpdl.tex<br>
-doc/ghostpdl.txt<br>
-doc/gs-vms.hlp<br>
-doc/gs.css<br>
-doc/gsdoc.el<br>
-doc/index.html<br>
-doc/pclxps/Makefile<br>
-doc/pclxps/README<br>
-doc/pclxps/ghostpdl.pdf<br>
-doc/pclxps/ghostpdl.tex<br>
-doc/pclxps/ghostpdl.txt<br>
-doc/pscet_status.txt<br>
-doc/subclass.htm<br>
-doc/thirdparty.htm<br>
-examples/alphabet.ps<br>
-examples/annots.pdf<br>
-examples/chess.ps<br>
-examples/cjk/all_ac1.ps<br>
-examples/cjk/all_ag1.ps<br>
-examples/cjk/all_aj1.ps<br>
-examples/cjk/all_aj2.ps<br>
-examples/cjk/all_ak1.ps<br>
-examples/cjk/article9.ps<br>
-examples/cjk/gscjk_ac.ps<br>
-examples/cjk/gscjk_ag.ps<br>
-examples/cjk/gscjk_aj.ps<br>
-examples/cjk/gscjk_ak.ps<br>
-examples/cjk/iso2022.ps<br>
-examples/cjk/iso2022v.ps<br>
-examples/colorcir.ps<br>
-examples/doretree.ps<br>
-examples/escher.ps<br>
-examples/golfer.eps<br>
-examples/grayalph.ps<br>
-examples/ridt91.eps<br>
-examples/snowflak.ps<br>
-examples/text_graph_image_cmyk_rgb.pdf<br>
-examples/text_graphic_image.pdf<br>
-examples/tiger.eps<br>
-examples/transparency_example.ps<br>
-examples/vasarely.ps<br>
-examples/waterfal.ps<br>
-expat/COPYING<br>
-expat/Changes<br>
-expat/MANIFEST<br>
-expat/Makefile.in<br>
-expat/README<br>
-expat/amiga/Makefile<br>
-expat/amiga/README.txt<br>
-expat/amiga/expat.xml<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/amiga/stdlib.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.in<br>
-expat/conftools/PrintPath<br>
-expat/conftools/ac_c_bigendian_cross.m4<br>
-expat/conftools/config.guess<br>
-expat/conftools/config.sub<br>
-expat/conftools/expat.m4<br>
-expat/conftools/get-version.sh<br>
-expat/conftools/install-sh<br>
-expat/conftools/libtool.m4<br>
-expat/conftools/ltmain.sh<br>
-expat/conftools/mkinstalldirs<br>
-expat/doc/expat.png<br>
-expat/doc/reference.html<br>
-expat/doc/style.css<br>
-expat/doc/valid-xhtml10.png<br>
-expat/doc/xmlwf.1<br>
-expat/doc/xmlwf.sgml<br>
-expat/examples/elements.c<br>
-expat/examples/elements.dsp<br>
-expat/examples/outline.c<br>
-expat/examples/outline.dsp<br>
-expat/expat.dsw<br>
-expat/expat_config.h.in<br>
-expat/lib/Makefile.MPW<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_external.h<br>
-expat/lib/expat_static.dsp<br>
-expat/lib/expatw.dsp<br>
-expat/lib/expatw_static.dsp<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/macconfig.h<br>
-expat/lib/nametab.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/tests/README.txt<br>
-expat/tests/benchmark/README.txt<br>
-expat/tests/benchmark/benchmark.c<br>
-expat/tests/benchmark/benchmark.dsp<br>
-expat/tests/benchmark/benchmark.dsw<br>
-expat/tests/chardata.c<br>
-expat/tests/chardata.h<br>
-expat/tests/minicheck.c<br>
-expat/tests/minicheck.h<br>
-expat/tests/runtests.c<br>
-expat/tests/runtestspp.cpp<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/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/xmlwin32url.cxx<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/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/atari/ATARI.H<br>
-freetype/builds/atari/FNames.SIC<br>
-freetype/builds/atari/FREETYPE.PRJ<br>
-freetype/builds/atari/README.TXT<br>
-freetype/builds/atari/deflinejoiner.awk<br>
-freetype/builds/atari/gen-purec-patch.sh<br>
-freetype/builds/beos/beos-def.mk<br>
-freetype/builds/beos/beos.mk<br>
-freetype/builds/beos/detect.mk<br>
-freetype/builds/cmake/iOS.cmake<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/README<br>
-freetype/builds/mac/ascii2mpw.py<br>
-freetype/builds/mac/freetype-Info.plist<br>
-freetype/builds/mac/ftlib.prj.xml<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.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-sh<br>
-freetype/builds/unix/install.mk<br>
-freetype/builds/unix/ltmain.sh<br>
-freetype/builds/unix/mkinstalldirs<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.sln<br>
-freetype/builds/wince/vc2005-ce/freetype.vcproj<br>
-freetype/builds/wince/vc2005-ce/index.html<br>
-freetype/builds/wince/vc2008-ce/freetype.sln<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.sln<br>
-freetype/builds/windows/vc2005/freetype.vcproj<br>
-freetype/builds/windows/vc2005/index.html<br>
-freetype/builds/windows/vc2008/freetype.sln<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.user.props<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.dsw<br>
-freetype/builds/windows/visualc/freetype.sln<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.dsw<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/CMAKE<br>
-freetype/docs/CUSTOMIZE<br>
-freetype/docs/DEBUG<br>
-freetype/docs/FTL.TXT<br>
-freetype/docs/GPLv2.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/LICENSE.TXT<br>
-freetype/docs/MAKEPP<br>
-freetype/docs/PROBLEMS<br>
-freetype/docs/TODO<br>
-freetype/docs/VERSION.DLL<br>
-freetype/docs/formats.txt<br>
-freetype/docs/freetype-config.1<br>
-freetype/docs/raster.txt<br>
-freetype/docs/reference/README<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-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-pfr_fonts.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-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/config/ftconfig.h<br>
-freetype/include/config/ftheader.h<br>
-freetype/include/config/ftmodule.h<br>
-freetype/include/config/ftoption.h<br>
-freetype/include/config/ftstdlib.h<br>
-freetype/include/freetype.h<br>
-freetype/include/ft2build.h<br>
-freetype/include/ftadvanc.h<br>
-freetype/include/ftautoh.h<br>
-freetype/include/ftbbox.h<br>
-freetype/include/ftbdf.h<br>
-freetype/include/ftbitmap.h<br>
-freetype/include/ftbzip2.h<br>
-freetype/include/ftcache.h<br>
-freetype/include/ftcffdrv.h<br>
-freetype/include/ftchapters.h<br>
-freetype/include/ftcid.h<br>
-freetype/include/fterrdef.h<br>
-freetype/include/fterrors.h<br>
-freetype/include/ftgasp.h<br>
-freetype/include/ftglyph.h<br>
-freetype/include/ftgxval.h<br>
-freetype/include/ftgzip.h<br>
-freetype/include/ftimage.h<br>
-freetype/include/ftincrem.h<br>
-freetype/include/ftlcdfil.h<br>
-freetype/include/ftlist.h<br>
-freetype/include/ftlzw.h<br>
-freetype/include/ftmac.h<br>
-freetype/include/ftmm.h<br>
-freetype/include/ftmodapi.h<br>
-freetype/include/ftmoderr.h<br>
-freetype/include/ftotval.h<br>
-freetype/include/ftoutln.h<br>
-freetype/include/ftpfr.h<br>
-freetype/include/ftrender.h<br>
-freetype/include/ftsizes.h<br>
-freetype/include/ftsnames.h<br>
-freetype/include/ftstroke.h<br>
-freetype/include/ftsynth.h<br>
-freetype/include/ftsystem.h<br>
-freetype/include/fttrigon.h<br>
-freetype/include/ftttdrv.h<br>
-freetype/include/fttypes.h<br>
-freetype/include/ftwinfnt.h<br>
-freetype/include/ftxf86.h<br>
-freetype/include/internal/autohint.h<br>
-freetype/include/internal/ftcalc.h<br>
-freetype/include/internal/ftdebug.h<br>
-freetype/include/internal/ftdriver.h<br>
-freetype/include/internal/ftgloadr.h<br>
-freetype/include/internal/ftmemory.h<br>
-freetype/include/internal/ftobjs.h<br>
-freetype/include/internal/ftpic.h<br>
-freetype/include/internal/ftrfork.h<br>
-freetype/include/internal/ftserv.h<br>
-freetype/include/internal/ftstream.h<br>
-freetype/include/internal/fttrace.h<br>
-freetype/include/internal/ftvalid.h<br>
-freetype/include/internal/internal.h<br>
-freetype/include/internal/psaux.h<br>
-freetype/include/internal/pshints.h<br>
-freetype/include/internal/services/svbdf.h<br>
-freetype/include/internal/services/svcid.h<br>
-freetype/include/internal/services/svgldict.h<br>
-freetype/include/internal/services/svgxval.h<br>
-freetype/include/internal/services/svkern.h<br>
-freetype/include/internal/services/svmm.h<br>
-freetype/include/internal/services/svotval.h<br>
-freetype/include/internal/services/svpfr.h<br>
-freetype/include/internal/services/svpostnm.h<br>
-freetype/include/internal/services/svprop.h<br>
-freetype/include/internal/services/svpscmap.h<br>
-freetype/include/internal/services/svpsinfo.h<br>
-freetype/include/internal/services/svsfnt.h<br>
-freetype/include/internal/services/svttcmap.h<br>
-freetype/include/internal/services/svtteng.h<br>
-freetype/include/internal/services/svttglyf.h<br>
-freetype/include/internal/services/svwinfnt.h<br>
-freetype/include/internal/services/svxf86nm.h<br>
-freetype/include/internal/sfnt.h<br>
-freetype/include/internal/t1types.h<br>
-freetype/include/internal/tttypes.h<br>
-freetype/include/t1tables.h<br>
-freetype/include/ttnameid.h<br>
-freetype/include/tttables.h<br>
-freetype/include/tttags.h<br>
-freetype/include/ttunpat.h<br>
-freetype/modules.cfg<br>
-freetype/objs/README<br>
-freetype/src/Jamfile<br>
-freetype/src/autofit/Jamfile<br>
-freetype/src/autofit/afangles.c<br>
-freetype/src/autofit/afangles.h<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/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/hbshim.c<br>
-freetype/src/autofit/hbshim.h<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/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/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/ftwinfnt.c<br>
-freetype/src/base/ftxf86.c<br>
-freetype/src/base/md5.c<br>
-freetype/src/base/md5.h<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/bdf.h<br>
-freetype/src/bdf/bdfdrivr.c<br>
-freetype/src/bdf/bdfdrivr.h<br>
-freetype/src/bdf/bdferror.h<br>
-freetype/src/bdf/bdflib.c<br>
-freetype/src/bdf/module.mk<br>
-freetype/src/bdf/rules.mk<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/cf2arrst.c<br>
-freetype/src/cff/cf2arrst.h<br>
-freetype/src/cff/cf2blues.c<br>
-freetype/src/cff/cf2blues.h<br>
-freetype/src/cff/cf2error.c<br>
-freetype/src/cff/cf2error.h<br>
-freetype/src/cff/cf2fixed.h<br>
-freetype/src/cff/cf2font.c<br>
-freetype/src/cff/cf2font.h<br>
-freetype/src/cff/cf2ft.c<br>
-freetype/src/cff/cf2ft.h<br>
-freetype/src/cff/cf2glue.h<br>
-freetype/src/cff/cf2hints.c<br>
-freetype/src/cff/cf2hints.h<br>
-freetype/src/cff/cf2intrp.c<br>
-freetype/src/cff/cf2intrp.h<br>
-freetype/src/cff/cf2read.c<br>
-freetype/src/cff/cf2read.h<br>
-freetype/src/cff/cf2stack.c<br>
-freetype/src/cff/cf2stack.h<br>
-freetype/src/cff/cf2types.h<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/cfftypes.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/adler32.c<br>
-freetype/src/gzip/ftgzip.c<br>
-freetype/src/gzip/infblock.c<br>
-freetype/src/gzip/infblock.h<br>
-freetype/src/gzip/infcodes.c<br>
-freetype/src/gzip/infcodes.h<br>
-freetype/src/gzip/inffixed.h<br>
-freetype/src/gzip/inflate.c<br>
-freetype/src/gzip/inftrees.c<br>
-freetype/src/gzip/inftrees.h<br>
-freetype/src/gzip/infutil.c<br>
-freetype/src/gzip/infutil.h<br>
-freetype/src/gzip/rules.mk<br>
-freetype/src/gzip/zconf.h<br>
-freetype/src/gzip/zlib.h<br>
-freetype/src/gzip/zutil.c<br>
-freetype/src/gzip/zutil.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/module.mk<br>
-freetype/src/pcf/pcf.c<br>
-freetype/src/pcf/pcf.h<br>
-freetype/src/pcf/pcfdrivr.c<br>
-freetype/src/pcf/pcfdrivr.h<br>
-freetype/src/pcf/pcferror.h<br>
-freetype/src/pcf/pcfread.c<br>
-freetype/src/pcf/pcfread.h<br>
-freetype/src/pcf/pcfutil.c<br>
-freetype/src/pcf/pcfutil.h<br>
-freetype/src/pcf/rules.mk<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/module.mk<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/psconv.c<br>
-freetype/src/psaux/psconv.h<br>
-freetype/src/psaux/psobjs.c<br>
-freetype/src/psaux/psobjs.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/Jamfile<br>
-freetype/src/tools/afblue.pl<br>
-freetype/src/tools/apinames.c<br>
-freetype/src/tools/chktrcmp.py<br>
-freetype/src/tools/cordic.py<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/ftrandom/Makefile<br>
-freetype/src/tools/ftrandom/README<br>
-freetype/src/tools/ftrandom/ftrandom.c<br>
-freetype/src/tools/glnames.py<br>
-freetype/src/tools/test_afm.c<br>
-freetype/src/tools/test_bbox.c<br>
-freetype/src/tools/test_trig.c<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/version.sed<br>
-freetype/vms_make.com<br>
-ghostall.vcproj<br>
-ghostpcl.vcproj<br>
-ghostpdl.vcproj<br>
-ghostscript-ufst.vcproj<br>
-ghostscript.vcproj<br>
-ghostscript_rt.vcxproj<br>
-ghostxps.vcproj<br>
-gpdl/gpdl.mak<br>
-gpdl/psi/gpdlpsi.mak<br>
-gpdl/psi/psitop.c<br>
-gpdl/pspcl6_gcc.mak<br>
-gpdl/pspcl6_msvc.mak<br>
-gs/DroidSansFallback.NOTICE<br>
-gs/LICENSE<br>
-gs/Makefile.in<br>
-gs/Resource/CIDFSubst/DroidSansFallback.ttf<br>
-gs/Resource/CIDFont/ArtifexBullet<br>
-gs/Resource/CMap/78-EUC-H<br>
-gs/Resource/CMap/78-EUC-V<br>
-gs/Resource/CMap/78-H<br>
-gs/Resource/CMap/78-RKSJ-H<br>
-gs/Resource/CMap/78-RKSJ-V<br>
-gs/Resource/CMap/78-V<br>
-gs/Resource/CMap/78ms-RKSJ-H<br>
-gs/Resource/CMap/78ms-RKSJ-V<br>
-gs/Resource/CMap/83pv-RKSJ-H<br>
-gs/Resource/CMap/90ms-RKSJ-H<br>
-gs/Resource/CMap/90ms-RKSJ-V<br>
-gs/Resource/CMap/90msp-RKSJ-H<br>
-gs/Resource/CMap/90msp-RKSJ-V<br>
-gs/Resource/CMap/90pv-RKSJ-H<br>
-gs/Resource/CMap/90pv-RKSJ-V<br>
-gs/Resource/CMap/Add-H<br>
-gs/Resource/CMap/Add-RKSJ-H<br>
-gs/Resource/CMap/Add-RKSJ-V<br>
-gs/Resource/CMap/Add-V<br>
-gs/Resource/CMap/Adobe-CNS1-0<br>
-gs/Resource/CMap/Adobe-CNS1-1<br>
-gs/Resource/CMap/Adobe-CNS1-2<br>
-gs/Resource/CMap/Adobe-CNS1-3<br>
-gs/Resource/CMap/Adobe-CNS1-4<br>
-gs/Resource/CMap/Adobe-CNS1-5<br>
-gs/Resource/CMap/Adobe-CNS1-6<br>
-gs/Resource/CMap/Adobe-GB1-0<br>
-gs/Resource/CMap/Adobe-GB1-1<br>
-gs/Resource/CMap/Adobe-GB1-2<br>
-gs/Resource/CMap/Adobe-GB1-3<br>
-gs/Resource/CMap/Adobe-GB1-4<br>
-gs/Resource/CMap/Adobe-GB1-5<br>
-gs/Resource/CMap/Adobe-Japan1-0<br>
-gs/Resource/CMap/Adobe-Japan1-1<br>
-gs/Resource/CMap/Adobe-Japan1-2<br>
-gs/Resource/CMap/Adobe-Japan1-3<br>
-gs/Resource/CMap/Adobe-Japan1-4<br>
-gs/Resource/CMap/Adobe-Japan1-5<br>
-gs/Resource/CMap/Adobe-Japan1-6<br>
-gs/Resource/CMap/Adobe-Korea1-0<br>
-gs/Resource/CMap/Adobe-Korea1-1<br>
-gs/Resource/CMap/Adobe-Korea1-2<br>
-gs/Resource/CMap/B5-H<br>
-gs/Resource/CMap/B5-V<br>
-gs/Resource/CMap/B5pc-H<br>
-gs/Resource/CMap/B5pc-V<br>
-gs/Resource/CMap/CNS-EUC-H<br>
-gs/Resource/CMap/CNS-EUC-V<br>
-gs/Resource/CMap/CNS1-H<br>
-gs/Resource/CMap/CNS1-V<br>
-gs/Resource/CMap/CNS2-H<br>
-gs/Resource/CMap/CNS2-V<br>
-gs/Resource/CMap/ETHK-B5-H<br>
-gs/Resource/CMap/ETHK-B5-V<br>
-gs/Resource/CMap/ETen-B5-H<br>
-gs/Resource/CMap/ETen-B5-V<br>
-gs/Resource/CMap/ETenms-B5-H<br>
-gs/Resource/CMap/ETenms-B5-V<br>
-gs/Resource/CMap/EUC-H<br>
-gs/Resource/CMap/EUC-V<br>
-gs/Resource/CMap/Ext-H<br>
-gs/Resource/CMap/Ext-RKSJ-H<br>
-gs/Resource/CMap/Ext-RKSJ-V<br>
-gs/Resource/CMap/Ext-V<br>
-gs/Resource/CMap/GB-EUC-H<br>
-gs/Resource/CMap/GB-EUC-V<br>
-gs/Resource/CMap/GB-H<br>
-gs/Resource/CMap/GB-V<br>
-gs/Resource/CMap/GBK-EUC-H<br>
-gs/Resource/CMap/GBK-EUC-V<br>
-gs/Resource/CMap/GBK2K-H<br>
-gs/Resource/CMap/GBK2K-V<br>
-gs/Resource/CMap/GBKp-EUC-H<br>
-gs/Resource/CMap/GBKp-EUC-V<br>
-gs/Resource/CMap/GBT-EUC-H<br>
-gs/Resource/CMap/GBT-EUC-V<br>
-gs/Resource/CMap/GBT-H<br>
-gs/Resource/CMap/GBT-V<br>
-gs/Resource/CMap/GBTpc-EUC-H<br>
-gs/Resource/CMap/GBTpc-EUC-V<br>
-gs/Resource/CMap/GBpc-EUC-H<br>
-gs/Resource/CMap/GBpc-EUC-V<br>
-gs/Resource/CMap/H<br>
-gs/Resource/CMap/HKdla-B5-H<br>
-gs/Resource/CMap/HKdla-B5-V<br>
-gs/Resource/CMap/HKdlb-B5-H<br>
-gs/Resource/CMap/HKdlb-B5-V<br>
-gs/Resource/CMap/HKgccs-B5-H<br>
-gs/Resource/CMap/HKgccs-B5-V<br>
-gs/Resource/CMap/HKm314-B5-H<br>
-gs/Resource/CMap/HKm314-B5-V<br>
-gs/Resource/CMap/HKm471-B5-H<br>
-gs/Resource/CMap/HKm471-B5-V<br>
-gs/Resource/CMap/HKscs-B5-H<br>
-gs/Resource/CMap/HKscs-B5-V<br>
-gs/Resource/CMap/Hankaku<br>
-gs/Resource/CMap/Hiragana<br>
-gs/Resource/CMap/Identity-H<br>
-gs/Resource/CMap/Identity-UTF16-H<br>
-gs/Resource/CMap/Identity-V<br>
-gs/Resource/CMap/KSC-EUC-H<br>
-gs/Resource/CMap/KSC-EUC-V<br>
-gs/Resource/CMap/KSC-H<br>
-gs/Resource/CMap/KSC-Johab-H<br>
-gs/Resource/CMap/KSC-Johab-V<br>
-gs/Resource/CMap/KSC-V<br>
-gs/Resource/CMap/KSCms-UHC-H<br>
-gs/Resource/CMap/KSCms-UHC-HW-H<br>
-gs/Resource/CMap/KSCms-UHC-HW-V<br>
-gs/Resource/CMap/KSCms-UHC-V<br>
-gs/Resource/CMap/KSCpc-EUC-H<br>
-gs/Resource/CMap/KSCpc-EUC-V<br>
-gs/Resource/CMap/Katakana<br>
-gs/Resource/CMap/NWP-H<br>
-gs/Resource/CMap/NWP-V<br>
-gs/Resource/CMap/RKSJ-H<br>
-gs/Resource/CMap/RKSJ-V<br>
-gs/Resource/CMap/Roman<br>
-gs/Resource/CMap/UniCNS-UCS2-H<br>
-gs/Resource/CMap/UniCNS-UCS2-V<br>
-gs/Resource/CMap/UniCNS-UTF16-H<br>
-gs/Resource/CMap/UniCNS-UTF16-V<br>
-gs/Resource/CMap/UniCNS-UTF32-H<br>
-gs/Resource/CMap/UniCNS-UTF32-V<br>
-gs/Resource/CMap/UniCNS-UTF8-H<br>
-gs/Resource/CMap/UniCNS-UTF8-V<br>
-gs/Resource/CMap/UniGB-UCS2-H<br>
-gs/Resource/CMap/UniGB-UCS2-V<br>
-gs/Resource/CMap/UniGB-UTF16-H<br>
-gs/Resource/CMap/UniGB-UTF16-V<br>
-gs/Resource/CMap/UniGB-UTF32-H<br>
-gs/Resource/CMap/UniGB-UTF32-V<br>
-gs/Resource/CMap/UniGB-UTF8-H<br>
-gs/Resource/CMap/UniGB-UTF8-V<br>
-gs/Resource/CMap/UniHojo-UCS2-H<br>
-gs/Resource/CMap/UniJIS-UCS2-H<br>
-gs/Resource/CMap/UniJIS-UCS2-HW-H<br>
-gs/Resource/CMap/UniJIS-UCS2-HW-V<br>
-gs/Resource/CMap/UniJIS-UCS2-V<br>
-gs/Resource/CMap/UniJIS-UTF16-H<br>
-gs/Resource/CMap/UniJIS-UTF16-V<br>
-gs/Resource/CMap/UniJIS-UTF32-H<br>
-gs/Resource/CMap/UniJIS-UTF32-V<br>
-gs/Resource/CMap/UniJIS-UTF8-H<br>
-gs/Resource/CMap/UniJIS-UTF8-V<br>
-gs/Resource/CMap/UniJIS2004-UTF16-H<br>
-gs/Resource/CMap/UniJIS2004-UTF16-V<br>
-gs/Resource/CMap/UniJIS2004-UTF32-H<br>
-gs/Resource/CMap/UniJIS2004-UTF32-V<br>
-gs/Resource/CMap/UniJIS2004-UTF8-H<br>
-gs/Resource/CMap/UniJIS2004-UTF8-V<br>
-gs/Resource/CMap/UniJISPro-UCS2-HW-V<br>
-gs/Resource/CMap/UniJISPro-UCS2-V<br>
-gs/Resource/CMap/UniJISPro-UTF8-V<br>
-gs/Resource/CMap/UniJISX0213-UTF32-H<br>
-gs/Resource/CMap/UniJISX0213-UTF32-V<br>
-gs/Resource/CMap/UniJISX02132004-UTF32-H<br>
-gs/Resource/CMap/UniJISX02132004-UTF32-V<br>
-gs/Resource/CMap/UniKS-UCS2-H<br>
-gs/Resource/CMap/UniKS-UCS2-V<br>
-gs/Resource/CMap/UniKS-UTF16-H<br>
-gs/Resource/CMap/UniKS-UTF16-V<br>
-gs/Resource/CMap/UniKS-UTF32-H<br>
-gs/Resource/CMap/UniKS-UTF32-V<br>
-gs/Resource/CMap/UniKS-UTF8-H<br>
-gs/Resource/CMap/UniKS-UTF8-V<br>
-gs/Resource/CMap/V<br>
-gs/Resource/CMap/WP-Symbol<br>
-gs/Resource/ColorSpace/DefaultCMYK<br>
-gs/Resource/ColorSpace/DefaultGray<br>
-gs/Resource/ColorSpace/DefaultRGB<br>
-gs/Resource/ColorSpace/TrivialCMYK<br>
-gs/Resource/ColorSpace/sGray<br>
-gs/Resource/ColorSpace/sRGB<br>
-gs/Resource/Decoding/FCO_Dingbats<br>
-gs/Resource/Decoding/FCO_Symbol<br>
-gs/Resource/Decoding/FCO_Unicode<br>
-gs/Resource/Decoding/FCO_Wingdings<br>
-gs/Resource/Decoding/Latin1<br>
-gs/Resource/Decoding/StandardEncoding<br>
-gs/Resource/Decoding/Unicode<br>
-gs/Resource/Encoding/CEEncoding<br>
-gs/Resource/Encoding/ExpertEncoding<br>
-gs/Resource/Encoding/ExpertSubsetEncoding<br>
-gs/Resource/Encoding/NotDefEncoding<br>
-gs/Resource/Encoding/Wingdings<br>
-gs/Resource/Font/BookmanURW-DemBol<br>
-gs/Resource/Font/BookmanURW-DemBolIta<br>
-gs/Resource/Font/BookmanURW-Lig<br>
-gs/Resource/Font/BookmanURW-LigIta<br>
-gs/Resource/Font/CenturySchURW-Bol<br>
-gs/Resource/Font/CenturySchURW-BolIta<br>
-gs/Resource/Font/CenturySchURW-Ita<br>
-gs/Resource/Font/CenturySchURW-Rom<br>
-gs/Resource/Font/ChanceryURW-MedIta<br>
-gs/Resource/Font/Dingbats<br>
-gs/Resource/Font/NimbusMono-Bold<br>
-gs/Resource/Font/NimbusMono-BoldOblique<br>
-gs/Resource/Font/NimbusMono-Oblique<br>
-gs/Resource/Font/NimbusMono-Regular<br>
-gs/Resource/Font/NimbusRomNo9L-Med<br>
-gs/Resource/Font/NimbusRomNo9L-MedIta<br>
-gs/Resource/Font/NimbusRomNo9L-Reg<br>
-gs/Resource/Font/NimbusRomNo9L-RegIta<br>
-gs/Resource/Font/NimbusSanL-Bol<br>
-gs/Resource/Font/NimbusSanL-BolIta<br>
-gs/Resource/Font/NimbusSanL-Reg<br>
-gs/Resource/Font/NimbusSanL-RegIta<br>
-gs/Resource/Font/NimbusSanNar-Bol<br>
-gs/Resource/Font/NimbusSanNar-BolIta<br>
-gs/Resource/Font/NimbusSanNar-Ita<br>
-gs/Resource/Font/NimbusSanNar-Reg<br>
-gs/Resource/Font/PalladioURW-Bol<br>
-gs/Resource/Font/PalladioURW-BolIta<br>
-gs/Resource/Font/PalladioURW-Ita<br>
-gs/Resource/Font/PalladioURW-Rom<br>
-gs/Resource/Font/StandardSymL<br>
-gs/Resource/Font/URWGothic-Boo<br>
-gs/Resource/Font/URWGothic-BooObl<br>
-gs/Resource/Font/URWGothic-Dem<br>
-gs/Resource/Font/URWGothic-DemObl<br>
-gs/Resource/IdiomSet/Pscript5Idiom<br>
-gs/Resource/Init/FAPIcidfmap<br>
-gs/Resource/Init/FAPIconfig<br>
-gs/Resource/Init/FAPIfontmap<br>
-gs/Resource/Init/FCOfontmap-PCLPS2<br>
-gs/Resource/Init/Fontmap<br>
-gs/Resource/Init/Fontmap.GS<br>
-gs/Resource/Init/cidfmap<br>
-gs/Resource/Init/gs_agl.ps<br>
-gs/Resource/Init/gs_btokn.ps<br>
-gs/Resource/Init/gs_cet.ps<br>
-gs/Resource/Init/gs_cff.ps<br>
-gs/Resource/Init/gs_cidcm.ps<br>
-gs/Resource/Init/gs_ciddc.ps<br>
-gs/Resource/Init/gs_cidfm.ps<br>
-gs/Resource/Init/gs_cidfn.ps<br>
-gs/Resource/Init/gs_cidtt.ps<br>
-gs/Resource/Init/gs_cmap.ps<br>
-gs/Resource/Init/gs_cspace.ps<br>
-gs/Resource/Init/gs_css_e.ps<br>
-gs/Resource/Init/gs_dbt_e.ps<br>
-gs/Resource/Init/gs_diskf.ps<br>
-gs/Resource/Init/gs_diskn.ps<br>
-gs/Resource/Init/gs_dpnxt.ps<br>
-gs/Resource/Init/gs_dps.ps<br>
-gs/Resource/Init/gs_dps1.ps<br>
-gs/Resource/Init/gs_dps2.ps<br>
-gs/Resource/Init/gs_dscp.ps<br>
-gs/Resource/Init/gs_epsf.ps<br>
-gs/Resource/Init/gs_fapi.ps<br>
-gs/Resource/Init/gs_fntem.ps<br>
-gs/Resource/Init/gs_fonts.ps<br>
-gs/Resource/Init/gs_frsd.ps<br>
-gs/Resource/Init/gs_icc.ps<br>
-gs/Resource/Init/gs_il1_e.ps<br>
-gs/Resource/Init/gs_img.ps<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/Resource/Init/gs_l2img.ps<br>
-gs/Resource/Init/gs_lev2.ps<br>
-gs/Resource/Init/gs_ll3.ps<br>
-gs/Resource/Init/gs_mex_e.ps<br>
-gs/Resource/Init/gs_mgl_e.ps<br>
-gs/Resource/Init/gs_mro_e.ps<br>
-gs/Resource/Init/gs_pdf_e.ps<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-gs/Resource/Init/gs_res.ps<br>
-gs/Resource/Init/gs_resmp.ps<br>
-gs/Resource/Init/gs_setpd.ps<br>
-gs/Resource/Init/gs_statd.ps<br>
-gs/Resource/Init/gs_std_e.ps<br>
-gs/Resource/Init/gs_sym_e.ps<br>
-gs/Resource/Init/gs_trap.ps<br>
-gs/Resource/Init/gs_ttf.ps<br>
-gs/Resource/Init/gs_typ32.ps<br>
-gs/Resource/Init/gs_typ42.ps<br>
-gs/Resource/Init/gs_type1.ps<br>
-gs/Resource/Init/gs_wan_e.ps<br>
-gs/Resource/Init/pdf_base.ps<br>
-gs/Resource/Init/pdf_cslayer.ps<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/Resource/Init/pdf_font.ps<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/Resource/Init/pdf_ops.ps<br>
-gs/Resource/Init/pdf_rbld.ps<br>
-gs/Resource/Init/pdf_sec.ps<br>
-gs/Resource/Init/xlatmap<br>
-gs/Resource/SubstCID/CNS1-WMode<br>
-gs/Resource/SubstCID/GB1-WMode<br>
-gs/Resource/SubstCID/Japan1-WMode<br>
-gs/Resource/SubstCID/Korea1-WMode<br>
-gs/arch/osx-x86-x86_64-ppc-gcc.h<br>
-gs/arch/windows-arm-msvc.h<br>
-gs/arch/windows-x64-msvc.h<br>
-gs/arch/windows-x86-msvc.h<br>
-gs/autogen.sh<br>
-gs/base/ConvertUTF.c<br>
-gs/base/ConvertUTF.h<br>
-gs/base/aes.c<br>
-gs/base/aes.h<br>
-gs/base/all-arch.mak<br>
-gs/base/append_l.com<br>
-gs/base/assert_.h<br>
-gs/base/bcc32.cfg<br>
-gs/base/bench.c<br>
-gs/base/catmake<br>
-gs/base/copy_one.com<br>
-gs/base/cp.bat<br>
-gs/base/cp.cmd<br>
-gs/base/ctype_.h<br>
-gs/base/dirent_.h<br>
-gs/base/dos_.h<br>
-gs/base/echogs.c<br>
-gs/base/errno_.h<br>
-gs/base/expat.mak<br>
-gs/base/fapi_bs.mak<br>
-gs/base/fapi_ft.c<br>
-gs/base/fapibstm.c<br>
-gs/base/fapiufst.c<br>
-gs/base/fcntl_.h<br>
-gs/base/freetype.mak<br>
-gs/base/gconf.c<br>
-gs/base/gconf.h<br>
-gs/base/gdbflags.h<br>
-gs/base/gdebug.h<br>
-gs/base/gdevabuf.c<br>
-gs/base/gdevbbox.c<br>
-gs/base/gdevbbox.h<br>
-gs/base/gdevdbit.c<br>
-gs/base/gdevdcrd.c<br>
-gs/base/gdevdcrd.h<br>
-gs/base/gdevddrw.c<br>
-gs/base/gdevddrw.h<br>
-gs/base/gdevdevn.c<br>
-gs/base/gdevdevn.h<br>
-gs/base/gdevdevnprn.h<br>
-gs/base/gdevdflt.c<br>
-gs/base/gdevdgbr.c<br>
-gs/base/gdevdrop.c<br>
-gs/base/gdevdsha.c<br>
-gs/base/gdevemap.c<br>
-gs/base/gdevflp.c<br>
-gs/base/gdevflp.h<br>
-gs/base/gdevhit.c<br>
-gs/base/gdevkrnlsclass.c<br>
-gs/base/gdevkrnlsclass.h<br>
-gs/base/gdevm1.c<br>
-gs/base/gdevm16.c<br>
-gs/base/gdevm2.c<br>
-gs/base/gdevm24.c<br>
-gs/base/gdevm32.c<br>
-gs/base/gdevm4.c<br>
-gs/base/gdevm40.c<br>
-gs/base/gdevm48.c<br>
-gs/base/gdevm56.c<br>
-gs/base/gdevm64.c<br>
-gs/base/gdevm8.c<br>
-gs/base/gdevmem.c<br>
-gs/base/gdevmem.h<br>
-gs/base/gdevmpla.c<br>
-gs/base/gdevmpla.h<br>
-gs/base/gdevmplt.c<br>
-gs/base/gdevmplt.h<br>
-gs/base/gdevmr1.c<br>
-gs/base/gdevmr2n.c<br>
-gs/base/gdevmr8n.c<br>
-gs/base/gdevmrop.h<br>
-gs/base/gdevmrun.c<br>
-gs/base/gdevmrun.h<br>
-gs/base/gdevmx.c<br>
-gs/base/gdevnfwd.c<br>
-gs/base/gdevoflt.c<br>
-gs/base/gdevoflt.h<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevp14.h<br>
-gs/base/gdevpccm.c<br>
-gs/base/gdevpccm.h<br>
-gs/base/gdevpipe.c<br>
-gs/base/gdevplnx.c<br>
-gs/base/gdevplnx.h<br>
-gs/base/gdevppla.c<br>
-gs/base/gdevppla.h<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevprn.h<br>
-gs/base/gdevprna.c<br>
-gs/base/gdevprna.h<br>
-gs/base/gdevpxat.h<br>
-gs/base/gdevpxen.h<br>
-gs/base/gdevpxop.h<br>
-gs/base/gdevrops.c<br>
-gs/base/gdevsclass.c<br>
-gs/base/gdevsclass.h<br>
-gs/base/gdevvec.c<br>
-gs/base/gdevvec.h<br>
-gs/base/genarch.c<br>
-gs/base/genconf.c<br>
-gs/base/gendev.c<br>
-gs/base/genht.c<br>
-gs/base/gp.h<br>
-gs/base/gp_dosfe.c<br>
-gs/base/gp_dosfs.c<br>
-gs/base/gp_dvx.c<br>
-gs/base/gp_getnv.c<br>
-gs/base/gp_mac.c<br>
-gs/base/gp_mac.h<br>
-gs/base/gp_macio.c<br>
-gs/base/gp_macpoll.c<br>
-gs/base/gp_mktmp.c<br>
-gs/base/gp_msdll.c<br>
-gs/base/gp_msdos.c<br>
-gs/base/gp_mshdl.c<br>
-gs/base/gp_mslib.c<br>
-gs/base/gp_mspol.c<br>
-gs/base/gp_msprn.c<br>
-gs/base/gp_mswin.c<br>
-gs/base/gp_mswin.h<br>
-gs/base/gp_nsync.c<br>
-gs/base/gp_ntfs.c<br>
-gs/base/gp_os2.c<br>
-gs/base/gp_os2.h<br>
-gs/base/gp_os2fs.c<br>
-gs/base/gp_os2pr.c<br>
-gs/base/gp_os9.c<br>
-gs/base/gp_paper.c<br>
-gs/base/gp_psync.c<br>
-gs/base/gp_stdia.c<br>
-gs/base/gp_stdin.c<br>
-gs/base/gp_strdl.c<br>
-gs/base/gp_sysv.c<br>
-gs/base/gp_unifn.c<br>
-gs/base/gp_unifs.c<br>
-gs/base/gp_unix.c<br>
-gs/base/gp_unix_cache.c<br>
-gs/base/gp_upapr.c<br>
-gs/base/gp_vms.c<br>
-gs/base/gp_wgetv.c<br>
-gs/base/gp_win32.c<br>
-gs/base/gp_wpapr.c<br>
-gs/base/gp_wsync.c<br>
-gs/base/gp_wutf8.c<br>
-gs/base/gpcheck.h<br>
-gs/base/gpgetenv.h<br>
-gs/base/gpmisc.c<br>
-gs/base/gpmisc.h<br>
-gs/base/gpsync.h<br>
-gs/base/gs.mak<br>
-gs/base/gs_dll_call.h<br>
-gs/base/gs_mgl_e.h<br>
-gs/base/gs_mro_e.h<br>
-gs/base/gsalloc.c<br>
-gs/base/gsalloc.h<br>
-gs/base/gsalpha.c<br>
-gs/base/gsalpha.h<br>
-gs/base/gsalphac.c<br>
-gs/base/gsalphac.h<br>
-gs/base/gsargs.c<br>
-gs/base/gsargs.h<br>
-gs/base/gsbitcom.c<br>
-gs/base/gsbitmap.h<br>
-gs/base/gsbitops.c<br>
-gs/base/gsbitops.h<br>
-gs/base/gsbittab.c<br>
-gs/base/gsbittab.h<br>
-gs/base/gsccode.h<br>
-gs/base/gsccolor.h<br>
-gs/base/gscdef.c<br>
-gs/base/gscdefs.h<br>
-gs/base/gscdevn.c<br>
-gs/base/gscdevn.h<br>
-gs/base/gscedata.c<br>
-gs/base/gscedata.h<br>
-gs/base/gscencs.c<br>
-gs/base/gscencs.h<br>
-gs/base/gschar.c<br>
-gs/base/gschar.h<br>
-gs/base/gschar0.c<br>
-gs/base/gscicach.c<br>
-gs/base/gscicach.h<br>
-gs/base/gscie.c<br>
-gs/base/gscie.h<br>
-gs/base/gsciemap.c<br>
-gs/base/gscindex.h<br>
-gs/base/gsclipsr.c<br>
-gs/base/gsclipsr.h<br>
-gs/base/gscms.h<br>
-gs/base/gscolor.c<br>
-gs/base/gscolor.h<br>
-gs/base/gscolor1.c<br>
-gs/base/gscolor1.h<br>
-gs/base/gscolor2.c<br>
-gs/base/gscolor2.h<br>
-gs/base/gscolor3.c<br>
-gs/base/gscolor3.h<br>
-gs/base/gscolorbuffer.c<br>
-gs/base/gscolorbuffer.h<br>
-gs/base/gscompt.h<br>
-gs/base/gscoord.c<br>
-gs/base/gscoord.h<br>
-gs/base/gscparam.c<br>
-gs/base/gscpixel.c<br>
-gs/base/gscpixel.h<br>
-gs/base/gscpm.h<br>
-gs/base/gscrd.c<br>
-gs/base/gscrd.h<br>
-gs/base/gscrdp.c<br>
-gs/base/gscrdp.h<br>
-gs/base/gscrypt1.c<br>
-gs/base/gscrypt1.h<br>
-gs/base/gscscie.c<br>
-gs/base/gscsel.h<br>
-gs/base/gscsepr.c<br>
-gs/base/gscsepr.h<br>
-gs/base/gscspace.c<br>
-gs/base/gscspace.h<br>
-gs/base/gscssub.c<br>
-gs/base/gscssub.h<br>
-gs/base/gsdcolor.h<br>
-gs/base/gsdevice.c<br>
-gs/base/gsdevice.h<br>
-gs/base/gsdevmem.c<br>
-gs/base/gsdfilt.c<br>
-gs/base/gsdfilt.h<br>
-gs/base/gsdll.h<br>
-gs/base/gsdllwin.h<br>
-gs/base/gsdparam.c<br>
-gs/base/gsdpnext.h<br>
-gs/base/gsdps.c<br>
-gs/base/gsdps.h<br>
-gs/base/gsdps1.c<br>
-gs/base/gsdsrc.c<br>
-gs/base/gsdsrc.h<br>
-gs/base/gsequivc.c<br>
-gs/base/gsequivc.h<br>
-gs/base/gserrors.h<br>
-gs/base/gsexit.h<br>
-gs/base/gsfcid.c<br>
-gs/base/gsfcid2.c<br>
-gs/base/gsfcmap.c<br>
-gs/base/gsfcmap.h<br>
-gs/base/gsfcmap1.c<br>
-gs/base/gsflip.c<br>
-gs/base/gsflip.h<br>
-gs/base/gsfname.c<br>
-gs/base/gsfname.h<br>
-gs/base/gsfont.c<br>
-gs/base/gsfont.h<br>
-gs/base/gsfont0.c<br>
-gs/base/gsfont0c.c<br>
-gs/base/gsform1.h<br>
-gs/base/gsfunc.c<br>
-gs/base/gsfunc.h<br>
-gs/base/gsfunc0.c<br>
-gs/base/gsfunc0.h<br>
-gs/base/gsfunc3.c<br>
-gs/base/gsfunc3.h<br>
-gs/base/gsfunc4.c<br>
-gs/base/gsfunc4.h<br>
-gs/base/gsgc.h<br>
-gs/base/gsgcache.c<br>
-gs/base/gsgcache.h<br>
-gs/base/gsgdata.c<br>
-gs/base/gsgdata.h<br>
-gs/base/gshsb.c<br>
-gs/base/gshsb.h<br>
-gs/base/gsht.c<br>
-gs/base/gsht.h<br>
-gs/base/gsht1.c<br>
-gs/base/gsht1.h<br>
-gs/base/gshtscr.c<br>
-gs/base/gshtx.c<br>
-gs/base/gshtx.h<br>
-gs/base/gsicc.c<br>
-gs/base/gsicc.h<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_cache.h<br>
-gs/base/gsicc_cms.h<br>
-gs/base/gsicc_create.c<br>
-gs/base/gsicc_create.h<br>
-gs/base/gsicc_lcms.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_manage.h<br>
-gs/base/gsicc_monitorcm.c<br>
-gs/base/gsicc_nocm.c<br>
-gs/base/gsicc_profilecache.c<br>
-gs/base/gsicc_profilecache.h<br>
-gs/base/gsicc_replacecm.c<br>
-gs/base/gsimage.c<br>
-gs/base/gsimage.h<br>
-gs/base/gsimpath.c<br>
-gs/base/gsinit.c<br>
-gs/base/gsio.h<br>
-gs/base/gsiodev.c<br>
-gs/base/gsiodevs.c<br>
-gs/base/gsiodisk.c<br>
-gs/base/gsiomacres.c<br>
-gs/base/gsioram.c<br>
-gs/base/gsiorom.c<br>
-gs/base/gsiorom.h<br>
-gs/base/gsipar3x.h<br>
-gs/base/gsiparam.h<br>
-gs/base/gsiparm2.h<br>
-gs/base/gsiparm3.h<br>
-gs/base/gsiparm4.h<br>
-gs/base/gsistate.c<br>
-gs/base/gsjconf.h<br>
-gs/base/gsjmorec.h<br>
-gs/base/gslib.c<br>
-gs/base/gslib.h<br>
-gs/base/gslibctx.c<br>
-gs/base/gslibctx.h<br>
-gs/base/gsline.c<br>
-gs/base/gsline.h<br>
-gs/base/gslparam.h<br>
-gs/base/gsmalloc.c<br>
-gs/base/gsmalloc.h<br>
-gs/base/gsmatrix.c<br>
-gs/base/gsmatrix.h<br>
-gs/base/gsmchunk.c<br>
-gs/base/gsmchunk.h<br>
-gs/base/gsmd5.c<br>
-gs/base/gsmd5.h<br>
-gs/base/gsmdebug.h<br>
-gs/base/gsmemlok.c<br>
-gs/base/gsmemlok.h<br>
-gs/base/gsmemory.c<br>
-gs/base/gsmemory.h<br>
-gs/base/gsmemraw.h<br>
-gs/base/gsmemret.c<br>
-gs/base/gsmemret.h<br>
-gs/base/gsmisc.c<br>
-gs/base/gsnamecl.c<br>
-gs/base/gsnamecl.h<br>
-gs/base/gsncdummy.c<br>
-gs/base/gsncdummy.h<br>
-gs/base/gsnogc.c<br>
-gs/base/gsnogc.h<br>
-gs/base/gsnotify.c<br>
-gs/base/gsnotify.h<br>
-gs/base/gsovrc.c<br>
-gs/base/gsovrc.h<br>
-gs/base/gspaint.c<br>
-gs/base/gspaint.h<br>
-gs/base/gsparam.c<br>
-gs/base/gsparam.h<br>
-gs/base/gsparam2.c<br>
-gs/base/gsparams.c<br>
-gs/base/gsparams.h<br>
-gs/base/gsparamx.c<br>
-gs/base/gsparamx.h<br>
-gs/base/gspath.c<br>
-gs/base/gspath.h<br>
-gs/base/gspath1.c<br>
-gs/base/gspath2.h<br>
-gs/base/gspcolor.c<br>
-gs/base/gspcolor.h<br>
-gs/base/gspenum.h<br>
-gs/base/gspmdrv.c<br>
-gs/base/gspmdrv.def<br>
-gs/base/gspmdrv.h<br>
-gs/base/gspmdrv.icx<br>
-gs/base/gspmdrv.rc<br>
-gs/base/gsptype1.c<br>
-gs/base/gsptype1.h<br>
-gs/base/gsptype2.c<br>
-gs/base/gsptype2.h<br>
-gs/base/gsrect.h<br>
-gs/base/gsrefct.h<br>
-gs/base/gsromfs0.c<br>
-gs/base/gsrop.c<br>
-gs/base/gsrop.h<br>
-gs/base/gsroprun.c<br>
-gs/base/gsroprun1.h<br>
-gs/base/gsroprun24.h<br>
-gs/base/gsroprun8.h<br>
-gs/base/gsropt.h<br>
-gs/base/gsroptab.c<br>
-gs/base/gsserial.c<br>
-gs/base/gsserial.h<br>
-gs/base/gsshade.c<br>
-gs/base/gsshade.h<br>
-gs/base/gssprintf.c<br>
-gs/base/gssprintf.h<br>
-gs/base/gsstate.c<br>
-gs/base/gsstate.h<br>
-gs/base/gsstrtok.c<br>
-gs/base/gsstrtok.h<br>
-gs/base/gsstruct.h<br>
-gs/base/gsstype.h<br>
-gs/base/gstext.c<br>
-gs/base/gstext.h<br>
-gs/base/gstiffio.c<br>
-gs/base/gstiffio.h<br>
-gs/base/gstparam.h<br>
-gs/base/gstrans.c<br>
-gs/base/gstrans.h<br>
-gs/base/gstrap.c<br>
-gs/base/gstrap.h<br>
-gs/base/gstype1.c<br>
-gs/base/gstype1.h<br>
-gs/base/gstype2.c<br>
-gs/base/gstype42.c<br>
-gs/base/gstypes.h<br>
-gs/base/gsuid.h<br>
-gs/base/gsutil.c<br>
-gs/base/gsutil.h<br>
-gs/base/gswin.icx<br>
-gs/base/gswin.rc<br>
-gs/base/gswin16.icx<br>
-gs/base/gswin32.rc<br>
-gs/base/gsxfont.h<br>
-gs/base/gx.h<br>
-gs/base/gxacpath.c<br>
-gs/base/gxalloc.h<br>
-gs/base/gxalpha.h<br>
-gs/base/gxarith.h<br>
-gs/base/gxband.h<br>
-gs/base/gxbcache.c<br>
-gs/base/gxbcache.h<br>
-gs/base/gxbitfmt.h<br>
-gs/base/gxbitmap.h<br>
-gs/base/gxbitops.h<br>
-gs/base/gxblend.c<br>
-gs/base/gxblend.h<br>
-gs/base/gxblend1.c<br>
-gs/base/gxccache.c<br>
-gs/base/gxccman.c<br>
-gs/base/gxcdevn.h<br>
-gs/base/gxchar.c<br>
-gs/base/gxchar.h<br>
-gs/base/gxchrout.c<br>
-gs/base/gxchrout.h<br>
-gs/base/gxcht.c<br>
-gs/base/gxcid.h<br>
-gs/base/gxcie.h<br>
-gs/base/gxcindex.h<br>
-gs/base/gxclbits.c<br>
-gs/base/gxcldev.h<br>
-gs/base/gxclfile.c<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclio.h<br>
-gs/base/gxclip.c<br>
-gs/base/gxclip.h<br>
-gs/base/gxclip2.c<br>
-gs/base/gxclip2.h<br>
-gs/base/gxclipm.c<br>
-gs/base/gxclipm.h<br>
-gs/base/gxclipsr.h<br>
-gs/base/gxclist.c<br>
-gs/base/gxclist.h<br>
-gs/base/gxcllzw.c<br>
-gs/base/gxclmem.c<br>
-gs/base/gxclmem.h<br>
-gs/base/gxclpage.c<br>
-gs/base/gxclpage.h<br>
-gs/base/gxclpath.c<br>
-gs/base/gxclpath.h<br>
-gs/base/gxclrast.c<br>
-gs/base/gxclread.c<br>
-gs/base/gxclrect.c<br>
-gs/base/gxclthrd.c<br>
-gs/base/gxclthrd.h<br>
-gs/base/gxclutil.c<br>
-gs/base/gxclzlib.c<br>
-gs/base/gxcmap.c<br>
-gs/base/gxcmap.h<br>
-gs/base/gxcolor2.h<br>
-gs/base/gxcomp.h<br>
-gs/base/gxcoord.h<br>
-gs/base/gxcpath.c<br>
-gs/base/gxcpath.h<br>
-gs/base/gxcspace.h<br>
-gs/base/gxctable.c<br>
-gs/base/gxctable.h<br>
-gs/base/gxcvalue.h<br>
-gs/base/gxdcconv.c<br>
-gs/base/gxdcconv.h<br>
-gs/base/gxdcolor.c<br>
-gs/base/gxdcolor.h<br>
-gs/base/gxdda.h<br>
-gs/base/gxdevbuf.h<br>
-gs/base/gxdevcli.h<br>
-gs/base/gxdevice.h<br>
-gs/base/gxdevmem.h<br>
-gs/base/gxdevndi.c<br>
-gs/base/gxdevndi.h<br>
-gs/base/gxdevrop.h<br>
-gs/base/gxdevsop.h<br>
-gs/base/gxdht.h<br>
-gs/base/gxdhtres.h<br>
-gs/base/gxdhtserial.c<br>
-gs/base/gxdhtserial.h<br>
-gs/base/gxdither.h<br>
-gs/base/gxdownscale.c<br>
-gs/base/gxdownscale.h<br>
-gs/base/gxdtfill.h<br>
-gs/base/gxfapi.c<br>
-gs/base/gxfapi.h<br>
-gs/base/gxfapiu.c<br>
-gs/base/gxfapiu.h<br>
-gs/base/gxfarith.h<br>
-gs/base/gxfcache.h<br>
-gs/base/gxfcid.h<br>
-gs/base/gxfcmap.h<br>
-gs/base/gxfcmap1.h<br>
-gs/base/gxfdrop.c<br>
-gs/base/gxfdrop.h<br>
-gs/base/gxfill.c<br>
-gs/base/gxfill.h<br>
-gs/base/gxfillsl.h<br>
-gs/base/gxfilltr.h<br>
-gs/base/gxfillts.h<br>
-gs/base/gxfixed.h<br>
-gs/base/gxfmap.h<br>
-gs/base/gxfont.h<br>
-gs/base/gxfont0.h<br>
-gs/base/gxfont0c.h<br>
-gs/base/gxfont1.h<br>
-gs/base/gxfont42.h<br>
-gs/base/gxfrac.h<br>
-gs/base/gxftype.h<br>
-gs/base/gxfunc.h<br>
-gs/base/gxgetbit.h<br>
-gs/base/gxhintn.c<br>
-gs/base/gxhintn.h<br>
-gs/base/gxhintn1.c<br>
-gs/base/gxhldevc.c<br>
-gs/base/gxhldevc.h<br>
-gs/base/gxht.c<br>
-gs/base/gxht.h<br>
-gs/base/gxht_thresh.c<br>
-gs/base/gxht_thresh.h<br>
-gs/base/gxhtbit.c<br>
-gs/base/gxhttile.h<br>
-gs/base/gxhttype.h<br>
-gs/base/gxi12bit.c<br>
-gs/base/gxi16bit.c<br>
-gs/base/gxiclass.h<br>
-gs/base/gxicolor.c<br>
-gs/base/gxidata.c<br>
-gs/base/gxifast.c<br>
-gs/base/gximag3x.c<br>
-gs/base/gximag3x.h<br>
-gs/base/gximage.c<br>
-gs/base/gximage.h<br>
-gs/base/gximage1.c<br>
-gs/base/gximage2.c<br>
-gs/base/gximage3.c<br>
-gs/base/gximage3.h<br>
-gs/base/gximage4.c<br>
-gs/base/gximask.c<br>
-gs/base/gximask.h<br>
-gs/base/gximdecode.c<br>
-gs/base/gximdecode.h<br>
-gs/base/gximono.c<br>
-gs/base/gxino12b.c<br>
-gs/base/gxino16b.c<br>
-gs/base/gxiodev.h<br>
-gs/base/gxiparam.h<br>
-gs/base/gxipixel.c<br>
-gs/base/gxiscale.c<br>
-gs/base/gxistate.h<br>
-gs/base/gxline.h<br>
-gs/base/gxlum.h<br>
-gs/base/gxmatrix.h<br>
-gs/base/gxmclip.c<br>
-gs/base/gxmclip.h<br>
-gs/base/gxobj.h<br>
-gs/base/gxoprect.c<br>
-gs/base/gxoprect.h<br>
-gs/base/gxp1fill.c<br>
-gs/base/gxp1impl.h<br>
-gs/base/gxpageq.c<br>
-gs/base/gxpageq.h<br>
-gs/base/gxpaint.c<br>
-gs/base/gxpaint.h<br>
-gs/base/gxpath.c<br>
-gs/base/gxpath.h<br>
-gs/base/gxpath2.c<br>
-gs/base/gxpcache.h<br>
-gs/base/gxpcmap.c<br>
-gs/base/gxpcolor.h<br>
-gs/base/gxpcopy.c<br>
-gs/base/gxpdash.c<br>
-gs/base/gxpflat.c<br>
-gs/base/gxrplane.h<br>
-gs/base/gxsample.c<br>
-gs/base/gxsample.h<br>
-gs/base/gxsamplp.h<br>
-gs/base/gxshade.c<br>
-gs/base/gxshade.h<br>
-gs/base/gxshade1.c<br>
-gs/base/gxshade4.c<br>
-gs/base/gxshade4.h<br>
-gs/base/gxshade6.c<br>
-gs/base/gxstate.h<br>
-gs/base/gxstdio.h<br>
-gs/base/gxstroke.c<br>
-gs/base/gxsync.c<br>
-gs/base/gxsync.h<br>
-gs/base/gxtext.h<br>
-gs/base/gxtmap.h<br>
-gs/base/gxttf.h<br>
-gs/base/gxttfb.c<br>
-gs/base/gxttfb.h<br>
-gs/base/gxtype1.c<br>
-gs/base/gxtype1.h<br>
-gs/base/gxxfont.h<br>
-gs/base/gzacpath.h<br>
-gs/base/gzcpath.h<br>
-gs/base/gzht.h<br>
-gs/base/gzline.h<br>
-gs/base/gzpath.h<br>
-gs/base/gzspotan.c<br>
-gs/base/gzspotan.h<br>
-gs/base/gzstate.h<br>
-gs/base/icc34.h<br>
-gs/base/ijs.mak<br>
-gs/base/instcopy<br>
-gs/base/jbig2.mak<br>
-gs/base/jerror_.h<br>
-gs/base/jmemcust.c<br>
-gs/base/jmemcust.h<br>
-gs/base/jpeg.mak<br>
-gs/base/jpegxr.mak<br>
-gs/base/lcms2.mak<br>
-gs/base/lcups.mak<br>
-gs/base/lcupsi.mak<br>
-gs/base/ldf_jb2.mak<br>
-gs/base/lib.mak<br>
-gs/base/locale_.h<br>
-gs/base/lwf_jp2.mak<br>
-gs/base/macgenmcpxml.sh<br>
-gs/base/macos-mcp.mak<br>
-gs/base/macos_carbon_d_pre.h<br>
-gs/base/macos_carbon_pre.h<br>
-gs/base/macos_classic_d_pre.h<br>
-gs/base/macosx.mak<br>
-gs/base/macsystypes.h<br>
-gs/base/malloc_.h<br>
-gs/base/math_.h<br>
-gs/base/md5main.c<br>
-gs/base/memento.c<br>
-gs/base/memento.h<br>
-gs/base/memory_.h<br>
-gs/base/mkromfs.c<br>
-gs/base/msvccmd.mak<br>
-gs/base/msvclib.mak<br>
-gs/base/msvctail.mak<br>
-gs/base/mv.bat<br>
-gs/base/mv.cmd<br>
-gs/base/openjpeg.mak<br>
-gs/base/openvms.mak<br>
-gs/base/openvms.mmk<br>
-gs/base/pcwin.mak<br>
-gs/base/pipe_.h<br>
-gs/base/png.mak<br>
-gs/base/png_.h<br>
-gs/base/ramfs.c<br>
-gs/base/ramfs.h<br>
-gs/base/rm.bat<br>
-gs/base/rm.cmd<br>
-gs/base/rm_all.com<br>
-gs/base/rm_one.com<br>
-gs/base/sa85d.c<br>
-gs/base/sa85d.h<br>
-gs/base/sa85x.h<br>
-gs/base/saes.c<br>
-gs/base/saes.h<br>
-gs/base/sarc4.c<br>
-gs/base/sarc4.h<br>
-gs/base/sbcp.c<br>
-gs/base/sbcp.h<br>
-gs/base/sbtx.h<br>
-gs/base/scanchar.h<br>
-gs/base/scantab.c<br>
-gs/base/scf.h<br>
-gs/base/scfd.c<br>
-gs/base/scfdgen.c<br>
-gs/base/scfdtab.c<br>
-gs/base/scfe.c<br>
-gs/base/scfetab.c<br>
-gs/base/scfparam.c<br>
-gs/base/scfx.h<br>
-gs/base/scommon.h<br>
-gs/base/sdcparam.c<br>
-gs/base/sdcparam.h<br>
-gs/base/sdct.h<br>
-gs/base/sdctc.c<br>
-gs/base/sdctd.c<br>
-gs/base/sdcte.c<br>
-gs/base/sddparam.c<br>
-gs/base/sdeparam.c<br>
-gs/base/seexec.c<br>
-gs/base/setjmp_.h<br>
-gs/base/sfilter.h<br>
-gs/base/sfilter2.c<br>
-gs/base/sfxboth.c<br>
-gs/base/sfxcommon.c<br>
-gs/base/sfxfd.c<br>
-gs/base/sfxstdio.c<br>
-gs/base/sha2.c<br>
-gs/base/sha2.h<br>
-gs/base/shc.c<br>
-gs/base/shc.h<br>
-gs/base/sidscale.c<br>
-gs/base/sidscale.h<br>
-gs/base/siinterp.c<br>
-gs/base/siinterp.h<br>
-gs/base/simscale.c<br>
-gs/base/simscale.h<br>
-gs/base/siscale.c<br>
-gs/base/siscale.h<br>
-gs/base/sisparam.h<br>
-gs/base/sjbig2.c<br>
-gs/base/sjbig2.h<br>
-gs/base/sjbig2_luratech.c<br>
-gs/base/sjbig2_luratech.h<br>
-gs/base/sjpeg.h<br>
-gs/base/sjpegc.c<br>
-gs/base/sjpegd.c<br>
-gs/base/sjpege.c<br>
-gs/base/sjpx_luratech.c<br>
-gs/base/sjpx_luratech.h<br>
-gs/base/sjpx_openjpeg.c<br>
-gs/base/sjpx_openjpeg.h<br>
-gs/base/slzwc.c<br>
-gs/base/slzwd.c<br>
-gs/base/slzwe.c<br>
-gs/base/slzwx.h<br>
-gs/base/smd5.c<br>
-gs/base/smd5.h<br>
-gs/base/smtf.c<br>
-gs/base/smtf.h<br>
-gs/base/spdiff.c<br>
-gs/base/spdiffx.h<br>
-gs/base/spngp.c<br>
-gs/base/spngpx.h<br>
-gs/base/spprint.c<br>
-gs/base/spprint.h<br>
-gs/base/spsdf.c<br>
-gs/base/spsdf.h<br>
-gs/base/srdline.h<br>
-gs/base/srld.c<br>
-gs/base/srle.c<br>
-gs/base/srlx.h<br>
-gs/base/ssha2.c<br>
-gs/base/ssha2.h<br>
-gs/base/sstring.c<br>
-gs/base/sstring.h<br>
-gs/base/stat_.h<br>
-gs/base/std.h<br>
-gs/base/stdint_.h<br>
-gs/base/stdio_.h<br>
-gs/base/stdpn.h<br>
-gs/base/stdpre.h<br>
-gs/base/stream.c<br>
-gs/base/stream.h<br>
-gs/base/strimpl.h<br>
-gs/base/string_.h<br>
-gs/base/strmio.c<br>
-gs/base/strmio.h<br>
-gs/base/stub.mak<br>
-gs/base/szlibc.c<br>
-gs/base/szlibd.c<br>
-gs/base/szlibe.c<br>
-gs/base/szlibx.h<br>
-gs/base/szlibxx.h<br>
-gs/base/tiff.mak<br>
-gs/base/time_.h<br>
-gs/base/ttcalc.c<br>
-gs/base/ttcalc.h<br>
-gs/base/ttcommon.h<br>
-gs/base/ttconf.h<br>
-gs/base/ttconfig.h<br>
-gs/base/ttfinp.c<br>
-gs/base/ttfinp.h<br>
-gs/base/ttfmain.c<br>
-gs/base/ttfmemd.c<br>
-gs/base/ttfmemd.h<br>
-gs/base/ttfoutl.h<br>
-gs/base/ttfsfnt.h<br>
-gs/base/ttinterp.c<br>
-gs/base/ttinterp.h<br>
-gs/base/ttload.c<br>
-gs/base/ttload.h<br>
-gs/base/ttmisc.h<br>
-gs/base/ttobjs.c<br>
-gs/base/ttobjs.h<br>
-gs/base/tttables.h<br>
-gs/base/tttype.h<br>
-gs/base/tttypes.h<br>
-gs/base/ugcclib.mak<br>
-gs/base/unistd_.h<br>
-gs/base/unix-aux.mak<br>
-gs/base/unix-dll.mak<br>
-gs/base/unix-end.mak<br>
-gs/base/unix-gcc.mak<br>
-gs/base/unixansi.mak<br>
-gs/base/unixhead.mak<br>
-gs/base/unixinst.mak<br>
-gs/base/unixlink.mak<br>
-gs/base/valgrind.h<br>
-gs/base/vdtrace.c<br>
-gs/base/vdtrace.h<br>
-gs/base/version.mak<br>
-gs/base/vms_x_fix.h<br>
-gs/base/vmsmath.h<br>
-gs/base/windows_.h<br>
-gs/base/winlib.mak<br>
-gs/base/winplat.mak<br>
-gs/base/winrtsup.cpp<br>
-gs/base/winrtsup.h<br>
-gs/base/wrfont.c<br>
-gs/base/wrfont.h<br>
-gs/base/write_t1.c<br>
-gs/base/write_t1.h<br>
-gs/base/write_t2.c<br>
-gs/base/write_t2.h<br>
-gs/base/x_.h<br>
-gs/base/xpsprint.cpp<br>
-gs/base/zlib.mak<br>
-gs/configure.ac<br>
-gs/contrib/chp2200/AUTHORS<br>
-gs/contrib/chp2200/COPYING<br>
-gs/contrib/chp2200/INSTALL<br>
-gs/contrib/contrib.mak<br>
-gs/contrib/defs.h<br>
-gs/contrib/eplaser/gdevescv.c<br>
-gs/contrib/eplaser/gdevescv.h<br>
-gs/contrib/epson740/README<br>
-gs/contrib/epson740/printerdb_rh5.2<br>
-gs/contrib/epson740/printerdb_rh6.0<br>
-gs/contrib/epson740/ps-to-printer.fpi_rh5.2<br>
-gs/contrib/epson740/upp-HowTo-to-be<br>
-gs/contrib/gdevbjc_.c<br>
-gs/contrib/gdevbjc_.h<br>
-gs/contrib/gdevbjca.c<br>
-gs/contrib/gdevcd8.c<br>
-gs/contrib/gdevcd8.h<br>
-gs/contrib/gdevdj9.c<br>
-gs/contrib/gdevgdi.c<br>
-gs/contrib/gdevhl12.c<br>
-gs/contrib/gdevln03.c<br>
-gs/contrib/gdevlx32.c<br>
-gs/contrib/gdevlx7.c<br>
-gs/contrib/gdevmd2k.c<br>
-gs/contrib/gdevop4w.c<br>
-gs/contrib/gdevxes.c<br>
-gs/contrib/gomni.c<br>
-gs/contrib/japanese/dmp_init.ps<br>
-gs/contrib/japanese/dmp_site.ps<br>
-gs/contrib/japanese/doc/Gdevlips.htm<br>
-gs/contrib/japanese/doc/README.gs550j<br>
-gs/contrib/japanese/doc/cdj880.txt<br>
-gs/contrib/japanese/doc/dj505j.txt<br>
-gs/contrib/japanese/doc/djgpp.txt<br>
-gs/contrib/japanese/doc/gdev10v.txt<br>
-gs/contrib/japanese/doc/gdevalps.txt<br>
-gs/contrib/japanese/doc/gdevcd8.txt<br>
-gs/contrib/japanese/doc/gdevdmpr.txt<br>
-gs/contrib/japanese/doc/gdevfmlbp.txt<br>
-gs/contrib/japanese/doc/gdevj100.txt<br>
-gs/contrib/japanese/doc/gdevlbp3.txt<br>
-gs/contrib/japanese/doc/gdevmag.txt<br>
-gs/contrib/japanese/doc/gdevmd2k.txt<br>
-gs/contrib/japanese/doc/gdevmjc.txt<br>
-gs/contrib/japanese/doc/gdevml6.txt<br>
-gs/contrib/japanese/doc/gdevp201.txt<br>
-gs/contrib/japanese/doc/gs261j.euc<br>
-gs/contrib/japanese/doc/gs261j.txt<br>
-gs/contrib/japanese/dviprlib.c<br>
-gs/contrib/japanese/dviprlib.h<br>
-gs/contrib/japanese/escp_24.src<br>
-gs/contrib/japanese/gdev10v.c<br>
-gs/contrib/japanese/gdevalps.c<br>
-gs/contrib/japanese/gdevdmpr.c<br>
-gs/contrib/japanese/gdevespg.c<br>
-gs/contrib/japanese/gdevfmlbp.c<br>
-gs/contrib/japanese/gdevfmpr.c<br>
-gs/contrib/japanese/gdevj100.c<br>
-gs/contrib/japanese/gdevlbp3.c<br>
-gs/contrib/japanese/gdevmag.c<br>
-gs/contrib/japanese/gdevmjc.c<br>
-gs/contrib/japanese/gdevmjc.h<br>
-gs/contrib/japanese/gdevml6.c<br>
-gs/contrib/japanese/gdevnpdl.c<br>
-gs/contrib/japanese/gdevp201.c<br>
-gs/contrib/japanese/gdevrpdl.c<br>
-gs/contrib/lips4/gdevl4r.c<br>
-gs/contrib/lips4/gdevl4v.c<br>
-gs/contrib/lips4/gdevlips.c<br>
-gs/contrib/lips4/gdevlips.h<br>
-gs/contrib/lips4/gdevlprn.c<br>
-gs/contrib/lips4/gdevlprn.h<br>
-gs/contrib/lxm3200-tweaked/LICENSE<br>
-gs/contrib/lxm3200-tweaked/README<br>
-gs/contrib/lxm3200-tweaked/RELEASE_NOTES<br>
-gs/contrib/lxm3200-tweaked/Z12-Z31-QuickSetup<br>
-gs/contrib/md2k_md5k/README.jis<br>
-gs/contrib/opvp/gdevopvp.c<br>
-gs/contrib/opvp/opvp.h<br>
-gs/contrib/opvp/opvp_0_2_0.h<br>
-gs/contrib/opvp/opvp_common.h<br>
-gs/contrib/opvp/opvp_media.def<br>
-gs/contrib/pcl3/BUGS<br>
-gs/contrib/pcl3/LGPL<br>
-gs/contrib/pcl3/NEWS<br>
-gs/contrib/pcl3/README<br>
-gs/contrib/pcl3/doc/gs-mods.txt<br>
-gs/contrib/pcl3/doc/gs-pcl3.1<br>
-gs/contrib/pcl3/doc/gs-pcl3.html<br>
-gs/contrib/pcl3/doc/gs-pcl3.ref<br>
-gs/contrib/pcl3/doc/how-to-report.txt<br>
-gs/contrib/pcl3/doc/notes.bbl<br>
-gs/contrib/pcl3/doc/notes.tex<br>
-gs/contrib/pcl3/doc/pcl3opts.1<br>
-gs/contrib/pcl3/doc/pcl3opts.html<br>
-gs/contrib/pcl3/doc/pcl3opts.ref<br>
-gs/contrib/pcl3/doc/reports.txt<br>
-gs/contrib/pcl3/eprn/eprnfs.c<br>
-gs/contrib/pcl3/eprn/eprnparm.c<br>
-gs/contrib/pcl3/eprn/eprnrend.c<br>
-gs/contrib/pcl3/eprn/gdeveprn.c<br>
-gs/contrib/pcl3/eprn/gdeveprn.h<br>
-gs/contrib/pcl3/eprn/mediasize.c<br>
-gs/contrib/pcl3/eprn/mediasize.h<br>
-gs/contrib/pcl3/eprn/pagecount.c<br>
-gs/contrib/pcl3/eprn/pagecount.h<br>
-gs/contrib/pcl3/lib/cups-pcl3<br>
-gs/contrib/pcl3/lib/example.mcf<br>
-gs/contrib/pcl3/lib/if-pcl3<br>
-gs/contrib/pcl3/pcl3.tar.sig<br>
-gs/contrib/pcl3/ppd/README<br>
-gs/contrib/pcl3/ppd/catppd<br>
-gs/contrib/pcl3/ppd/fonts.ppd<br>
-gs/contrib/pcl3/ppd/gs-5.50.ppd<br>
-gs/contrib/pcl3/ppd/gs-6.01.ppd<br>
-gs/contrib/pcl3/ppd/gs-6.50.ppd<br>
-gs/contrib/pcl3/ppd/gs-6.51.ppd<br>
-gs/contrib/pcl3/ppd/gs-7.00.ppd<br>
-gs/contrib/pcl3/ppd/gs-common.ppd<br>
-gs/contrib/pcl3/ppd/gs-pcl3-common.ppd<br>
-gs/contrib/pcl3/ppd/gs-pcl3-hpdj1120c.ppd<br>
-gs/contrib/pcl3/ppd/gs-pcl3-hpdj3xx.ppd<br>
-gs/contrib/pcl3/ppd/gs-pcl3-hpdj400.ppd<br>
-gs/contrib/pcl3/ppd/gs-pcl3-hpdj500.ppd<br>
-gs/contrib/pcl3/ppd/gs-pcl3-hpdj500c.ppd<br>
-gs/contrib/pcl3/ppd/gs-pcl3-hpdj510.ppd<br>
-gs/contrib/pcl3/ppd/gs-pcl3-hpdj540.ppd<br>
-gs/contrib/pcl3/ppd/gs-pcl3-hpdj550c.ppd<br>
-gs/contrib/pcl3/ppd/gs-pcl3-hpdj600.ppd<br>
-gs/contrib/pcl3/ppd/gs-pcl3-hpdj660c.ppd<br>
-gs/contrib/pcl3/ppd/gs-pcl3-hpdj680c.ppd<br>
-gs/contrib/pcl3/ppd/gs-pcl3-hpdj8xxc.ppd<br>
-gs/contrib/pcl3/ppd/gs-pcl3-hpdjportable.ppd<br>
-gs/contrib/pcl3/ppd/gs-pcl3-unspec.ppd<br>
-gs/contrib/pcl3/ppd/gs-pcl3-unspecold.ppd<br>
-gs/contrib/pcl3/ps/calign.ps<br>
-gs/contrib/pcl3/ps/dumppdd.ps<br>
-gs/contrib/pcl3/ps/levels-test.ps<br>
-gs/contrib/pcl3/ps/margins-A4.ps<br>
-gs/contrib/pcl3/ps/margins-A4Rotated.ps<br>
-gs/contrib/pcl3/ps/margins-Env10Rotated.ps<br>
-gs/contrib/pcl3/ps/margins-EnvDLRotated.ps<br>
-gs/contrib/pcl3/ps/margins-Letter.ps<br>
-gs/contrib/pcl3/ps/margins-LetterRotated.ps<br>
-gs/contrib/pcl3/src/contrib.mak-5.50.add<br>
-gs/contrib/pcl3/src/contrib.mak-6.01.add<br>
-gs/contrib/pcl3/src/contrib.mak-6.50.add<br>
-gs/contrib/pcl3/src/contrib.mak-6.51.add<br>
-gs/contrib/pcl3/src/contrib.mak-7.00.add<br>
-gs/contrib/pcl3/src/gdevpcl3.c<br>
-gs/contrib/pcl3/src/pcl3opts-de.msg<br>
-gs/contrib/pcl3/src/pcl3opts-en.msg<br>
-gs/contrib/pcl3/src/pcl3opts.c<br>
-gs/contrib/pcl3/src/pclcap.c<br>
-gs/contrib/pcl3/src/pclcap.h<br>
-gs/contrib/pcl3/src/pclcomp.c<br>
-gs/contrib/pcl3/src/pclgen.c<br>
-gs/contrib/pcl3/src/pclgen.h<br>
-gs/contrib/pcl3/src/pclscan.c<br>
-gs/contrib/pcl3/src/pclscan.h<br>
-gs/contrib/pcl3/src/pclsize.c<br>
-gs/contrib/pcl3/src/pclsize.h<br>
-gs/contrib/pcl3/src/zmedia2.c-5.50.diff<br>
-gs/contrib/pcl3/src/zmedia2.c-6.01.diff<br>
-gs/contrib/pcl3/src/zmedia2.c-6.50.diff<br>
-gs/contrib/pcl3/src/zmedia2.c-6.51.diff<br>
-gs/contrib/pcl3/src/zmedia2.c-7.00.diff<br>
-gs/contrib/pscolor/Makefile<br>
-gs/contrib/pscolor/black.pdf<br>
-gs/contrib/pscolor/black.ps<br>
-gs/contrib/pscolor/color.pdf<br>
-gs/contrib/pscolor/color.ps<br>
-gs/contrib/pscolor/colorsplit.vcproj<br>
-gs/contrib/pscolor/common.mak<br>
-gs/contrib/pscolor/input.ps<br>
-gs/contrib/pscolor/instream.yy<br>
-gs/contrib/pscolor/test.c<br>
-gs/contrib/pscolor/windows.mak<br>
-gs/contrib/uniprint/PM760p.upp<br>
-gs/contrib/uniprint/PM760pl.upp<br>
-gs/contrib/uniprint/PM820p.upp<br>
-gs/contrib/uniprint/PM820pl.upp<br>
-gs/contrib/uniprint/Stc670p.upp<br>
-gs/contrib/uniprint/Stc670pl.upp<br>
-gs/contrib/uniprint/Stc680p.upp<br>
-gs/contrib/uniprint/Stc680pl.upp<br>
-gs/contrib/uniprint/Stc740p.upp<br>
-gs/contrib/uniprint/Stc740pl.upp<br>
-gs/contrib/uniprint/Stc760p.upp<br>
-gs/contrib/uniprint/Stc760pl.upp<br>
-gs/contrib/uniprint/Stc777p.upp<br>
-gs/contrib/uniprint/Stc777pl.upp<br>
-gs/contrib/uniprint/Stp720p.upp<br>
-gs/contrib/uniprint/Stp720pl.upp<br>
-gs/contrib/uniprint/Stp870p.upp<br>
-gs/contrib/uniprint/Stp870pl.upp<br>
-gs/contrib/uniprint/bjc6000a1.upp<br>
-gs/contrib/uniprint/bjc6000b1.upp<br>
-gs/contrib/uniprint/s400a1.upp<br>
-gs/contrib/uniprint/s400b1.upp<br>
-gs/contrib/uniprint/sharp.upp<br>
-gs/contrib/uniprint/sipixa6.upp<br>
-gs/contrib/uniprint/stc740ih.upp<br>
-gs/cups/cups.mak<br>
-gs/cups/gdevcups.c<br>
-gs/cups/libs/Makedefs<br>
-gs/cups/libs/configlinux.h<br>
-gs/cups/libs/configwin.h<br>
-gs/cups/libs/cups/Dependencies<br>
-gs/cups/libs/cups/Makefile<br>
-gs/cups/libs/cups/adminutil.c<br>
-gs/cups/libs/cups/adminutil.h<br>
-gs/cups/libs/cups/api-array.header<br>
-gs/cups/libs/cups/api-array.shtml<br>
-gs/cups/libs/cups/api-cups.header<br>
-gs/cups/libs/cups/api-cups.shtml<br>
-gs/cups/libs/cups/api-filedir.header<br>
-gs/cups/libs/cups/api-filedir.shtml<br>
-gs/cups/libs/cups/api-filter.header<br>
-gs/cups/libs/cups/api-filter.shtml<br>
-gs/cups/libs/cups/api-httpipp.header<br>
-gs/cups/libs/cups/api-httpipp.shtml<br>
-gs/cups/libs/cups/api-overview.header<br>
-gs/cups/libs/cups/api-overview.shtml<br>
-gs/cups/libs/cups/api-ppd.header<br>
-gs/cups/libs/cups/api-ppd.shtml<br>
-gs/cups/libs/cups/array-private.h<br>
-gs/cups/libs/cups/array.c<br>
-gs/cups/libs/cups/array.h<br>
-gs/cups/libs/cups/attr.c<br>
-gs/cups/libs/cups/auth.c<br>
-gs/cups/libs/cups/backchannel.c<br>
-gs/cups/libs/cups/backend.c<br>
-gs/cups/libs/cups/backend.h<br>
-gs/cups/libs/cups/conflicts.c<br>
-gs/cups/libs/cups/cups-private.h<br>
-gs/cups/libs/cups/cups.h<br>
-gs/cups/libs/cups/custom.c<br>
-gs/cups/libs/cups/debug-private.h<br>
-gs/cups/libs/cups/debug.c<br>
-gs/cups/libs/cups/dest-job.c<br>
-gs/cups/libs/cups/dest-localization.c<br>
-gs/cups/libs/cups/dest-options.c<br>
-gs/cups/libs/cups/dest.c<br>
-gs/cups/libs/cups/dir.c<br>
-gs/cups/libs/cups/dir.h<br>
-gs/cups/libs/cups/emit.c<br>
-gs/cups/libs/cups/encode.c<br>
-gs/cups/libs/cups/file-private.h<br>
-gs/cups/libs/cups/file.c<br>
-gs/cups/libs/cups/file.h<br>
-gs/cups/libs/cups/getdevices.c<br>
-gs/cups/libs/cups/getifaddrs.c<br>
-gs/cups/libs/cups/getputfile.c<br>
-gs/cups/libs/cups/globals.c<br>
-gs/cups/libs/cups/http-addr.c<br>
-gs/cups/libs/cups/http-addrlist.c<br>
-gs/cups/libs/cups/http-private.h<br>
-gs/cups/libs/cups/http-support.c<br>
-gs/cups/libs/cups/http.c<br>
-gs/cups/libs/cups/http.h<br>
-gs/cups/libs/cups/ipp-private.h<br>
-gs/cups/libs/cups/ipp-support.c<br>
-gs/cups/libs/cups/ipp.c<br>
-gs/cups/libs/cups/ipp.h<br>
-gs/cups/libs/cups/langprintf.c<br>
-gs/cups/libs/cups/language-private.h<br>
-gs/cups/libs/cups/language.c<br>
-gs/cups/libs/cups/language.h<br>
-gs/cups/libs/cups/libcups2.def<br>
-gs/cups/libs/cups/libcups2.rc<br>
-gs/cups/libs/cups/libcups_s.exp<br>
-gs/cups/libs/cups/localize.c<br>
-gs/cups/libs/cups/mark.c<br>
-gs/cups/libs/cups/md5-private.h<br>
-gs/cups/libs/cups/md5.c<br>
-gs/cups/libs/cups/md5passwd.c<br>
-gs/cups/libs/cups/notify.c<br>
-gs/cups/libs/cups/options.c<br>
-gs/cups/libs/cups/page.c<br>
-gs/cups/libs/cups/ppd-cache.c<br>
-gs/cups/libs/cups/ppd-private.h<br>
-gs/cups/libs/cups/ppd.c<br>
-gs/cups/libs/cups/ppd.h<br>
-gs/cups/libs/cups/pwg-media.c<br>
-gs/cups/libs/cups/pwg-private.h<br>
-gs/cups/libs/cups/pwg.h<br>
-gs/cups/libs/cups/raster-private.h<br>
-gs/cups/libs/cups/raster.h<br>
-gs/cups/libs/cups/request.c<br>
-gs/cups/libs/cups/sidechannel.c<br>
-gs/cups/libs/cups/sidechannel.h<br>
-gs/cups/libs/cups/snmp-private.h<br>
-gs/cups/libs/cups/snmp.c<br>
-gs/cups/libs/cups/snprintf.c<br>
-gs/cups/libs/cups/sspi-private.h<br>
-gs/cups/libs/cups/sspi.c<br>
-gs/cups/libs/cups/string-private.h<br>
-gs/cups/libs/cups/string.c<br>
-gs/cups/libs/cups/tempfile.c<br>
-gs/cups/libs/cups/test.ppd<br>
-gs/cups/libs/cups/test2.ppd<br>
-gs/cups/libs/cups/testadmin.c<br>
-gs/cups/libs/cups/testarray.c<br>
-gs/cups/libs/cups/testconflicts.c<br>
-gs/cups/libs/cups/testcups.c<br>
-gs/cups/libs/cups/testfile.c<br>
-gs/cups/libs/cups/testhttp.c<br>
-gs/cups/libs/cups/testi18n.c<br>
-gs/cups/libs/cups/testipp.c<br>
-gs/cups/libs/cups/testlang.c<br>
-gs/cups/libs/cups/testoptions.c<br>
-gs/cups/libs/cups/testppd.c<br>
-gs/cups/libs/cups/testpwg.c<br>
-gs/cups/libs/cups/testsnmp.c<br>
-gs/cups/libs/cups/thread-private.h<br>
-gs/cups/libs/cups/thread.c<br>
-gs/cups/libs/cups/transcode.c<br>
-gs/cups/libs/cups/transcode.h<br>
-gs/cups/libs/cups/usersys.c<br>
-gs/cups/libs/cups/utf8demo.txt<br>
-gs/cups/libs/cups/util.c<br>
-gs/cups/libs/cups/versioning.h<br>
-gs/cups/libs/filter/Dependencies<br>
-gs/cups/libs/filter/Makefile<br>
-gs/cups/libs/filter/api-raster.header<br>
-gs/cups/libs/filter/api-raster.shtml<br>
-gs/cups/libs/filter/commandtops.c<br>
-gs/cups/libs/filter/common.c<br>
-gs/cups/libs/filter/common.h<br>
-gs/cups/libs/filter/error.c<br>
-gs/cups/libs/filter/gziptoany.c<br>
-gs/cups/libs/filter/interpret.c<br>
-gs/cups/libs/filter/libcupsimage2.def<br>
-gs/cups/libs/filter/libcupsimage_s.exp<br>
-gs/cups/libs/filter/postscript-driver.header<br>
-gs/cups/libs/filter/postscript-driver.shtml<br>
-gs/cups/libs/filter/ppd-compiler.header<br>
-gs/cups/libs/filter/ppd-compiler.shtml<br>
-gs/cups/libs/filter/pstops.c<br>
-gs/cups/libs/filter/raster-driver.header<br>
-gs/cups/libs/filter/raster-driver.shtml<br>
-gs/cups/libs/filter/raster.c<br>
-gs/cups/libs/filter/rasterbench.c<br>
-gs/cups/libs/filter/rastertoepson.c<br>
-gs/cups/libs/filter/rastertohp.c<br>
-gs/cups/libs/filter/rastertolabel.c<br>
-gs/cups/libs/filter/rastertopwg.c<br>
-gs/cups/libs/filter/spec-ppd.header<br>
-gs/cups/libs/filter/spec-ppd.shtml<br>
-gs/cups/libs/filter/testraster.c<br>
-gs/devices/contrib.mak<br>
-gs/devices/devs.mak<br>
-gs/devices/gdev3852.c<br>
-gs/devices/gdev3b1.c<br>
-gs/devices/gdev4081.c<br>
-gs/devices/gdev4693.c<br>
-gs/devices/gdev8510.c<br>
-gs/devices/gdev8bcm.c<br>
-gs/devices/gdev8bcm.h<br>
-gs/devices/gdevadmp.c<br>
-gs/devices/gdevatx.c<br>
-gs/devices/gdevbit.c<br>
-gs/devices/gdevbj10.c<br>
-gs/devices/gdevbjc.h<br>
-gs/devices/gdevbjcl.c<br>
-gs/devices/gdevbjcl.h<br>
-gs/devices/gdevbmp.c<br>
-gs/devices/gdevbmp.h<br>
-gs/devices/gdevbmpa.c<br>
-gs/devices/gdevbmpc.c<br>
-gs/devices/gdevccr.c<br>
-gs/devices/gdevcdj.c<br>
-gs/devices/gdevcfax.c<br>
-gs/devices/gdevcif.c<br>
-gs/devices/gdevclj.c<br>
-gs/devices/gdevcljc.c<br>
-gs/devices/gdevcmykog.c<br>
-gs/devices/gdevcp50.c<br>
-gs/devices/gdevcslw.c<br>
-gs/devices/gdevdfax.c<br>
-gs/devices/gdevdjet.c<br>
-gs/devices/gdevdjtc.c<br>
-gs/devices/gdevdljm.c<br>
-gs/devices/gdevdljm.h<br>
-gs/devices/gdevdm24.c<br>
-gs/devices/gdevdsp.c<br>
-gs/devices/gdevdsp.h<br>
-gs/devices/gdevdsp2.h<br>
-gs/devices/gdevepsc.c<br>
-gs/devices/gdevepsn.c<br>
-gs/devices/gdevescp.c<br>
-gs/devices/gdevevga.c<br>
-gs/devices/gdevfax.c<br>
-gs/devices/gdevfax.h<br>
-gs/devices/gdevfpng.c<br>
-gs/devices/gdevherc.c<br>
-gs/devices/gdevhl7x.c<br>
-gs/devices/gdevicov.c<br>
-gs/devices/gdevifno.c<br>
-gs/devices/gdevijs.c<br>
-gs/devices/gdevimgn.c<br>
-gs/devices/gdevjbig2.c<br>
-gs/devices/gdevjpeg.c<br>
-gs/devices/gdevjpx.c<br>
-gs/devices/gdevl256.c<br>
-gs/devices/gdevl31s.c<br>
-gs/devices/gdevlbp8.c<br>
-gs/devices/gdevlj56.c<br>
-gs/devices/gdevlp8k.c<br>
-gs/devices/gdevlxm.c<br>
-gs/devices/gdevmac.c<br>
-gs/devices/gdevmac.h<br>
-gs/devices/gdevmacpictop.h<br>
-gs/devices/gdevmacttf.h<br>
-gs/devices/gdevmeds.c<br>
-gs/devices/gdevmeds.h<br>
-gs/devices/gdevmgr.c<br>
-gs/devices/gdevmgr.h<br>
-gs/devices/gdevmiff.c<br>
-gs/devices/gdevmswn.c<br>
-gs/devices/gdevmswn.h<br>
-gs/devices/gdevmsxf.c<br>
-gs/devices/gdevn533.c<br>
-gs/devices/gdevo182.c<br>
-gs/devices/gdevokii.c<br>
-gs/devices/gdevos2p.c<br>
-gs/devices/gdevp2up.c<br>
-gs/devices/gdevpbm.c<br>
-gs/devices/gdevpcfb.c<br>
-gs/devices/gdevpcfb.h<br>
-gs/devices/gdevpcl.c<br>
-gs/devices/gdevpcl.h<br>
-gs/devices/gdevpcx.c<br>
-gs/devices/gdevpe.c<br>
-gs/devices/gdevperm.c<br>
-gs/devices/gdevphex.c<br>
-gs/devices/gdevpjet.c<br>
-gs/devices/gdevplan.c<br>
-gs/devices/gdevplib.c<br>
-gs/devices/gdevplib.h<br>
-gs/devices/gdevpm.h<br>
-gs/devices/gdevpng.c<br>
-gs/devices/gdevpsd.c<br>
-gs/devices/gdevpsim.c<br>
-gs/devices/gdevpxut.c<br>
-gs/devices/gdevpxut.h<br>
-gs/devices/gdevrinkj.c<br>
-gs/devices/gdevs3ga.c<br>
-gs/devices/gdevsco.c<br>
-gs/devices/gdevsgi.c<br>
-gs/devices/gdevsgi.h<br>
-gs/devices/gdevsj48.c<br>
-gs/devices/gdevsnfb.c<br>
-gs/devices/gdevsppr.c<br>
-gs/devices/gdevstc.c<br>
-gs/devices/gdevstc.h<br>
-gs/devices/gdevstc1.c<br>
-gs/devices/gdevstc2.c<br>
-gs/devices/gdevstc3.c<br>
-gs/devices/gdevstc4.c<br>
-gs/devices/gdevsun.c<br>
-gs/devices/gdevsunr.c<br>
-gs/devices/gdevsvga.c<br>
-gs/devices/gdevsvga.h<br>
-gs/devices/gdevtfax.c<br>
-gs/devices/gdevtfax.h<br>
-gs/devices/gdevtfnx.c<br>
-gs/devices/gdevtifs.c<br>
-gs/devices/gdevtifs.h<br>
-gs/devices/gdevtknk.c<br>
-gs/devices/gdevtrac.c<br>
-gs/devices/gdevtsep.c<br>
-gs/devices/gdevupd.c<br>
-gs/devices/gdevvglb.c<br>
-gs/devices/gdevwddb.c<br>
-gs/devices/gdevwdib.c<br>
-gs/devices/gdevwpr2.c<br>
-gs/devices/gdevwprn.c<br>
-gs/devices/gdevx.c<br>
-gs/devices/gdevx.h<br>
-gs/devices/gdevxalt.c<br>
-gs/devices/gdevxcf.c<br>
-gs/devices/gdevxcmp.c<br>
-gs/devices/gdevxcmp.h<br>
-gs/devices/gdevxini.c<br>
-gs/devices/gdevxres.c<br>
-gs/devices/gxfcopy.c<br>
-gs/devices/gxfcopy.h<br>
-gs/devices/minftrsz.c<br>
-gs/devices/minftrsz.h<br>
-gs/devices/rinkj/evenbetter-rll.c<br>
-gs/devices/rinkj/evenbetter-rll.h<br>
-gs/devices/rinkj/rinkj-byte-stream.c<br>
-gs/devices/rinkj/rinkj-byte-stream.h<br>
-gs/devices/rinkj/rinkj-config.c<br>
-gs/devices/rinkj/rinkj-config.h<br>
-gs/devices/rinkj/rinkj-device.c<br>
-gs/devices/rinkj/rinkj-device.h<br>
-gs/devices/rinkj/rinkj-dither.c<br>
-gs/devices/rinkj/rinkj-dither.h<br>
-gs/devices/rinkj/rinkj-epson870.c<br>
-gs/devices/rinkj/rinkj-epson870.h<br>
-gs/devices/rinkj/rinkj-screen-eb.c<br>
-gs/devices/rinkj/rinkj-screen-eb.h<br>
-gs/devices/vector/gdevagl.c<br>
-gs/devices/vector/gdevagl.h<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfb.c<br>
-gs/devices/vector/gdevpdfb.h<br>
-gs/devices/vector/gdevpdfc.c<br>
-gs/devices/vector/gdevpdfc.h<br>
-gs/devices/vector/gdevpdfd.c<br>
-gs/devices/vector/gdevpdfe.c<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpdfg.h<br>
-gs/devices/vector/gdevpdfi.c<br>
-gs/devices/vector/gdevpdfj.c<br>
-gs/devices/vector/gdevpdfk.c<br>
-gs/devices/vector/gdevpdfm.c<br>
-gs/devices/vector/gdevpdfo.c<br>
-gs/devices/vector/gdevpdfo.h<br>
-gs/devices/vector/gdevpdfp.c<br>
-gs/devices/vector/gdevpdfr.c<br>
-gs/devices/vector/gdevpdft.c<br>
-gs/devices/vector/gdevpdfu.c<br>
-gs/devices/vector/gdevpdfv.c<br>
-gs/devices/vector/gdevpdfx.h<br>
-gs/devices/vector/gdevpdt.c<br>
-gs/devices/vector/gdevpdt.h<br>
-gs/devices/vector/gdevpdtb.c<br>
-gs/devices/vector/gdevpdtb.h<br>
-gs/devices/vector/gdevpdtc.c<br>
-gs/devices/vector/gdevpdtd.c<br>
-gs/devices/vector/gdevpdtd.h<br>
-gs/devices/vector/gdevpdte.c<br>
-gs/devices/vector/gdevpdtf.c<br>
-gs/devices/vector/gdevpdtf.h<br>
-gs/devices/vector/gdevpdti.c<br>
-gs/devices/vector/gdevpdti.h<br>
-gs/devices/vector/gdevpdts.c<br>
-gs/devices/vector/gdevpdts.h<br>
-gs/devices/vector/gdevpdtt.c<br>
-gs/devices/vector/gdevpdtt.h<br>
-gs/devices/vector/gdevpdtv.c<br>
-gs/devices/vector/gdevpdtv.h<br>
-gs/devices/vector/gdevpdtw.c<br>
-gs/devices/vector/gdevpdtw.h<br>
-gs/devices/vector/gdevpdtx.h<br>
-gs/devices/vector/gdevpsdf.h<br>
-gs/devices/vector/gdevpsdi.c<br>
-gs/devices/vector/gdevpsdp.c<br>
-gs/devices/vector/gdevpsds.c<br>
-gs/devices/vector/gdevpsds.h<br>
-gs/devices/vector/gdevpsdu.c<br>
-gs/devices/vector/gdevpsf.h<br>
-gs/devices/vector/gdevpsf1.c<br>
-gs/devices/vector/gdevpsf2.c<br>
-gs/devices/vector/gdevpsfm.c<br>
-gs/devices/vector/gdevpsft.c<br>
-gs/devices/vector/gdevpsfu.c<br>
-gs/devices/vector/gdevpsfx.c<br>
-gs/devices/vector/gdevpsu.c<br>
-gs/devices/vector/gdevpsu.h<br>
-gs/devices/vector/gdevpx.c<br>
-gs/devices/vector/gdevtxtw.c<br>
-gs/devices/vector/gdevxps.c<br>
-gs/devices/vector/opdfread.h<br>
-gs/devices/vector/whitelst.c<br>
-gs/devices/vector/whitelst.h<br>
-gs/doc/API.htm<br>
-gs/doc/AUTHORS<br>
-gs/doc/C-style.htm<br>
-gs/doc/COPYING<br>
-gs/doc/Changes.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/GS9_Color_Management.pdf<br>
-gs/doc/GS9_Color_Management.tex<br>
-gs/doc/Helpers.htm<br>
-gs/doc/Hershey.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/gs.css<br>
-gs/doc/gsdoc.el<br>
-gs/doc/index.html<br>
-gs/doc/pscet_status.txt<br>
-gs/doc/subclass.htm<br>
-gs/doc/thirdparty.htm<br>
-gs/examples/alphabet.ps<br>
-gs/examples/annots.pdf<br>
-gs/examples/chess.ps<br>
-gs/examples/cjk/all_ac1.ps<br>
-gs/examples/cjk/all_ag1.ps<br>
-gs/examples/cjk/all_aj1.ps<br>
-gs/examples/cjk/all_aj2.ps<br>
-gs/examples/cjk/all_ak1.ps<br>
-gs/examples/cjk/article9.ps<br>
-gs/examples/cjk/gscjk_ac.ps<br>
-gs/examples/cjk/gscjk_ag.ps<br>
-gs/examples/cjk/gscjk_aj.ps<br>
-gs/examples/cjk/gscjk_ak.ps<br>
-gs/examples/cjk/iso2022.ps<br>
-gs/examples/cjk/iso2022v.ps<br>
-gs/examples/colorcir.ps<br>
-gs/examples/doretree.ps<br>
-gs/examples/escher.ps<br>
-gs/examples/golfer.eps<br>
-gs/examples/grayalph.ps<br>
-gs/examples/ridt91.eps<br>
-gs/examples/snowflak.ps<br>
-gs/examples/text_graph_image_cmyk_rgb.pdf<br>
-gs/examples/text_graphic_image.pdf<br>
-gs/examples/tiger.eps<br>
-gs/examples/transparency_example.ps<br>
-gs/examples/vasarely.ps<br>
-gs/examples/waterfal.ps<br>
-gs/expat/COPYING<br>
-gs/expat/Changes<br>
-gs/expat/MANIFEST<br>
-gs/expat/Makefile.in<br>
-gs/expat/README<br>
-gs/expat/amiga/Makefile<br>
-gs/expat/amiga/README.txt<br>
-gs/expat/amiga/expat.xml<br>
-gs/expat/amiga/expat_lib.c<br>
-gs/expat/amiga/expat_vectors.c<br>
-gs/expat/amiga/include/inline4/expat.h<br>
-gs/expat/amiga/include/interfaces/expat.h<br>
-gs/expat/amiga/include/libraries/expat.h<br>
-gs/expat/amiga/include/proto/expat.h<br>
-gs/expat/amiga/launch.c<br>
-gs/expat/amiga/stdlib.c<br>
-gs/expat/bcb5/README.txt<br>
-gs/expat/bcb5/all_projects.bpg<br>
-gs/expat/bcb5/elements.bpf<br>
-gs/expat/bcb5/elements.bpr<br>
-gs/expat/bcb5/elements.mak<br>
-gs/expat/bcb5/expat.bpf<br>
-gs/expat/bcb5/expat.bpr<br>
-gs/expat/bcb5/expat.mak<br>
-gs/expat/bcb5/expat_static.bpf<br>
-gs/expat/bcb5/expat_static.bpr<br>
-gs/expat/bcb5/expat_static.mak<br>
-gs/expat/bcb5/expatw.bpf<br>
-gs/expat/bcb5/expatw.bpr<br>
-gs/expat/bcb5/expatw.mak<br>
-gs/expat/bcb5/expatw_static.bpf<br>
-gs/expat/bcb5/expatw_static.bpr<br>
-gs/expat/bcb5/expatw_static.mak<br>
-gs/expat/bcb5/libexpat_mtd.def<br>
-gs/expat/bcb5/libexpatw_mtd.def<br>
-gs/expat/bcb5/makefile.mak<br>
-gs/expat/bcb5/outline.bpf<br>
-gs/expat/bcb5/outline.bpr<br>
-gs/expat/bcb5/outline.mak<br>
-gs/expat/bcb5/setup.bat<br>
-gs/expat/bcb5/xmlwf.bpf<br>
-gs/expat/bcb5/xmlwf.bpr<br>
-gs/expat/bcb5/xmlwf.mak<br>
-gs/expat/configure<br>
-gs/expat/configure.in<br>
-gs/expat/conftools/PrintPath<br>
-gs/expat/conftools/ac_c_bigendian_cross.m4<br>
-gs/expat/conftools/config.guess<br>
-gs/expat/conftools/config.sub<br>
-gs/expat/conftools/expat.m4<br>
-gs/expat/conftools/get-version.sh<br>
-gs/expat/conftools/install-sh<br>
-gs/expat/conftools/libtool.m4<br>
-gs/expat/conftools/ltmain.sh<br>
-gs/expat/conftools/mkinstalldirs<br>
-gs/expat/doc/expat.png<br>
-gs/expat/doc/reference.html<br>
-gs/expat/doc/style.css<br>
-gs/expat/doc/valid-xhtml10.png<br>
-gs/expat/doc/xmlwf.1<br>
-gs/expat/doc/xmlwf.sgml<br>
-gs/expat/examples/elements.c<br>
-gs/expat/examples/elements.dsp<br>
-gs/expat/examples/outline.c<br>
-gs/expat/examples/outline.dsp<br>
-gs/expat/expat.dsw<br>
-gs/expat/expat_config.h.in<br>
-gs/expat/lib/Makefile.MPW<br>
-gs/expat/lib/amigaconfig.h<br>
-gs/expat/lib/ascii.h<br>
-gs/expat/lib/asciitab.h<br>
-gs/expat/lib/expat.dsp<br>
-gs/expat/lib/expat.h<br>
-gs/expat/lib/expat_external.h<br>
-gs/expat/lib/expat_static.dsp<br>
-gs/expat/lib/expatw.dsp<br>
-gs/expat/lib/expatw_static.dsp<br>
-gs/expat/lib/iasciitab.h<br>
-gs/expat/lib/internal.h<br>
-gs/expat/lib/latin1tab.h<br>
-gs/expat/lib/libexpat.def<br>
-gs/expat/lib/libexpatw.def<br>
-gs/expat/lib/macconfig.h<br>
-gs/expat/lib/nametab.h<br>
-gs/expat/lib/utf8tab.h<br>
-gs/expat/lib/winconfig.h<br>
-gs/expat/lib/xmlparse.c<br>
-gs/expat/lib/xmlrole.c<br>
-gs/expat/lib/xmlrole.h<br>
-gs/expat/lib/xmltok.c<br>
-gs/expat/lib/xmltok.h<br>
-gs/expat/lib/xmltok_impl.c<br>
-gs/expat/lib/xmltok_impl.h<br>
-gs/expat/lib/xmltok_ns.c<br>
-gs/expat/tests/README.txt<br>
-gs/expat/tests/benchmark/README.txt<br>
-gs/expat/tests/benchmark/benchmark.c<br>
-gs/expat/tests/benchmark/benchmark.dsp<br>
-gs/expat/tests/benchmark/benchmark.dsw<br>
-gs/expat/tests/chardata.c<br>
-gs/expat/tests/chardata.h<br>
-gs/expat/tests/minicheck.c<br>
-gs/expat/tests/minicheck.h<br>
-gs/expat/tests/runtests.c<br>
-gs/expat/tests/runtestspp.cpp<br>
-gs/expat/tests/xmltest.sh<br>
-gs/expat/vms/README.vms<br>
-gs/expat/vms/descrip.mms<br>
-gs/expat/vms/expat_config.h<br>
-gs/expat/win32/MANIFEST.txt<br>
-gs/expat/win32/README.txt<br>
-gs/expat/win32/expat.iss<br>
-gs/expat/xmlwf/codepage.c<br>
-gs/expat/xmlwf/codepage.h<br>
-gs/expat/xmlwf/ct.c<br>
-gs/expat/xmlwf/filemap.h<br>
-gs/expat/xmlwf/readfilemap.c<br>
-gs/expat/xmlwf/unixfilemap.c<br>
-gs/expat/xmlwf/win32filemap.c<br>
-gs/expat/xmlwf/xmlfile.c<br>
-gs/expat/xmlwf/xmlfile.h<br>
-gs/expat/xmlwf/xmlmime.c<br>
-gs/expat/xmlwf/xmlmime.h<br>
-gs/expat/xmlwf/xmltchar.h<br>
-gs/expat/xmlwf/xmlurl.h<br>
-gs/expat/xmlwf/xmlwf.c<br>
-gs/expat/xmlwf/xmlwf.dsp<br>
-gs/expat/xmlwf/xmlwin32url.cxx<br>
-gs/freetype/CMakeLists.txt<br>
-gs/freetype/ChangeLog<br>
-gs/freetype/ChangeLog.20<br>
-gs/freetype/ChangeLog.21<br>
-gs/freetype/ChangeLog.22<br>
-gs/freetype/ChangeLog.23<br>
-gs/freetype/ChangeLog.24<br>
-gs/freetype/Jamfile<br>
-gs/freetype/Jamrules<br>
-gs/freetype/Makefile<br>
-gs/freetype/README<br>
-gs/freetype/README.git<br>
-gs/freetype/autogen.sh<br>
-gs/freetype/builds/amiga/README<br>
-gs/freetype/builds/amiga/include/config/ftconfig.h<br>
-gs/freetype/builds/amiga/include/config/ftmodule.h<br>
-gs/freetype/builds/amiga/makefile<br>
-gs/freetype/builds/amiga/makefile.os4<br>
-gs/freetype/builds/amiga/smakefile<br>
-gs/freetype/builds/amiga/src/base/ftdebug.c<br>
-gs/freetype/builds/amiga/src/base/ftsystem.c<br>
-gs/freetype/builds/ansi/ansi-def.mk<br>
-gs/freetype/builds/ansi/ansi.mk<br>
-gs/freetype/builds/atari/ATARI.H<br>
-gs/freetype/builds/atari/FNames.SIC<br>
-gs/freetype/builds/atari/FREETYPE.PRJ<br>
-gs/freetype/builds/atari/README.TXT<br>
-gs/freetype/builds/atari/deflinejoiner.awk<br>
-gs/freetype/builds/atari/gen-purec-patch.sh<br>
-gs/freetype/builds/beos/beos-def.mk<br>
-gs/freetype/builds/beos/beos.mk<br>
-gs/freetype/builds/beos/detect.mk<br>
-gs/freetype/builds/cmake/iOS.cmake<br>
-gs/freetype/builds/compiler/ansi-cc.mk<br>
-gs/freetype/builds/compiler/bcc-dev.mk<br>
-gs/freetype/builds/compiler/bcc.mk<br>
-gs/freetype/builds/compiler/emx.mk<br>
-gs/freetype/builds/compiler/gcc-dev.mk<br>
-gs/freetype/builds/compiler/gcc.mk<br>
-gs/freetype/builds/compiler/intelc.mk<br>
-gs/freetype/builds/compiler/unix-lcc.mk<br>
-gs/freetype/builds/compiler/visualage.mk<br>
-gs/freetype/builds/compiler/visualc.mk<br>
-gs/freetype/builds/compiler/watcom.mk<br>
-gs/freetype/builds/compiler/win-lcc.mk<br>
-gs/freetype/builds/detect.mk<br>
-gs/freetype/builds/dos/detect.mk<br>
-gs/freetype/builds/dos/dos-def.mk<br>
-gs/freetype/builds/dos/dos-emx.mk<br>
-gs/freetype/builds/dos/dos-gcc.mk<br>
-gs/freetype/builds/dos/dos-wat.mk<br>
-gs/freetype/builds/exports.mk<br>
-gs/freetype/builds/freetype.mk<br>
-gs/freetype/builds/link_dos.mk<br>
-gs/freetype/builds/link_std.mk<br>
-gs/freetype/builds/mac/FreeType.m68k_cfm.make.txt<br>
-gs/freetype/builds/mac/FreeType.m68k_far.make.txt<br>
-gs/freetype/builds/mac/FreeType.ppc_carbon.make.txt<br>
-gs/freetype/builds/mac/FreeType.ppc_classic.make.txt<br>
-gs/freetype/builds/mac/README<br>
-gs/freetype/builds/mac/ascii2mpw.py<br>
-gs/freetype/builds/mac/freetype-Info.plist<br>
-gs/freetype/builds/mac/ftlib.prj.xml<br>
-gs/freetype/builds/mac/ftmac.c<br>
-gs/freetype/builds/modules.mk<br>
-gs/freetype/builds/newline<br>
-gs/freetype/builds/os2/detect.mk<br>
-gs/freetype/builds/os2/os2-def.mk<br>
-gs/freetype/builds/os2/os2-dev.mk<br>
-gs/freetype/builds/os2/os2-gcc.mk<br>
-gs/freetype/builds/symbian/bld.inf<br>
-gs/freetype/builds/symbian/freetype.mmp<br>
-gs/freetype/builds/toplevel.mk<br>
-gs/freetype/builds/unix/aclocal.m4<br>
-gs/freetype/builds/unix/config.guess<br>
-gs/freetype/builds/unix/config.sub<br>
-gs/freetype/builds/unix/configure.ac<br>
-gs/freetype/builds/unix/configure.raw<br>
-gs/freetype/builds/unix/detect.mk<br>
-gs/freetype/builds/unix/freetype-config.in<br>
-gs/freetype/builds/unix/freetype2.in<br>
-gs/freetype/builds/unix/freetype2.m4<br>
-gs/freetype/builds/unix/ft-munmap.m4<br>
-gs/freetype/builds/unix/ftconfig.in<br>
-gs/freetype/builds/unix/ftsystem.c<br>
-gs/freetype/builds/unix/install-sh<br>
-gs/freetype/builds/unix/install.mk<br>
-gs/freetype/builds/unix/ltmain.sh<br>
-gs/freetype/builds/unix/mkinstalldirs<br>
-gs/freetype/builds/unix/pkg.m4<br>
-gs/freetype/builds/unix/unix-cc.in<br>
-gs/freetype/builds/unix/unix-def.in<br>
-gs/freetype/builds/unix/unix-dev.mk<br>
-gs/freetype/builds/unix/unix-lcc.mk<br>
-gs/freetype/builds/unix/unix.mk<br>
-gs/freetype/builds/unix/unixddef.mk<br>
-gs/freetype/builds/vms/ftconfig.h<br>
-gs/freetype/builds/vms/ftsystem.c<br>
-gs/freetype/builds/wince/ftdebug.c<br>
-gs/freetype/builds/wince/vc2005-ce/freetype.sln<br>
-gs/freetype/builds/wince/vc2005-ce/freetype.vcproj<br>
-gs/freetype/builds/wince/vc2005-ce/index.html<br>
-gs/freetype/builds/wince/vc2008-ce/freetype.sln<br>
-gs/freetype/builds/wince/vc2008-ce/freetype.vcproj<br>
-gs/freetype/builds/wince/vc2008-ce/index.html<br>
-gs/freetype/builds/windows/detect.mk<br>
-gs/freetype/builds/windows/ftdebug.c<br>
-gs/freetype/builds/windows/vc2005/freetype.sln<br>
-gs/freetype/builds/windows/vc2005/freetype.vcproj<br>
-gs/freetype/builds/windows/vc2005/index.html<br>
-gs/freetype/builds/windows/vc2008/freetype.sln<br>
-gs/freetype/builds/windows/vc2008/freetype.vcproj<br>
-gs/freetype/builds/windows/vc2008/index.html<br>
-gs/freetype/builds/windows/vc2010/freetype.sln<br>
-gs/freetype/builds/windows/vc2010/freetype.user.props<br>
-gs/freetype/builds/windows/vc2010/freetype.vcxproj<br>
-gs/freetype/builds/windows/vc2010/freetype.vcxproj.filters<br>
-gs/freetype/builds/windows/vc2010/index.html<br>
-gs/freetype/builds/windows/visualc/freetype.dsp<br>
-gs/freetype/builds/windows/visualc/freetype.dsw<br>
-gs/freetype/builds/windows/visualc/freetype.sln<br>
-gs/freetype/builds/windows/visualc/freetype.vcproj<br>
-gs/freetype/builds/windows/visualc/index.html<br>
-gs/freetype/builds/windows/visualce/freetype.dsp<br>
-gs/freetype/builds/windows/visualce/freetype.dsw<br>
-gs/freetype/builds/windows/visualce/freetype.vcproj<br>
-gs/freetype/builds/windows/visualce/index.html<br>
-gs/freetype/builds/windows/w32-bcc.mk<br>
-gs/freetype/builds/windows/w32-bccd.mk<br>
-gs/freetype/builds/windows/w32-dev.mk<br>
-gs/freetype/builds/windows/w32-gcc.mk<br>
-gs/freetype/builds/windows/w32-icc.mk<br>
-gs/freetype/builds/windows/w32-intl.mk<br>
-gs/freetype/builds/windows/w32-lcc.mk<br>
-gs/freetype/builds/windows/w32-mingw32.mk<br>
-gs/freetype/builds/windows/w32-vcc.mk<br>
-gs/freetype/builds/windows/w32-wat.mk<br>
-gs/freetype/builds/windows/win32-def.mk<br>
-gs/freetype/configure<br>
-gs/freetype/devel/ft2build.h<br>
-gs/freetype/devel/ftoption.h<br>
-gs/freetype/docs/CHANGES<br>
-gs/freetype/docs/CMAKE<br>
-gs/freetype/docs/CUSTOMIZE<br>
-gs/freetype/docs/DEBUG<br>
-gs/freetype/docs/FTL.TXT<br>
-gs/freetype/docs/GPLv2.TXT<br>
-gs/freetype/docs/INSTALL<br>
-gs/freetype/docs/INSTALL.ANY<br>
-gs/freetype/docs/INSTALL.CROSS<br>
-gs/freetype/docs/INSTALL.GNU<br>
-gs/freetype/docs/INSTALL.MAC<br>
-gs/freetype/docs/INSTALL.UNIX<br>
-gs/freetype/docs/INSTALL.VMS<br>
-gs/freetype/docs/LICENSE.TXT<br>
-gs/freetype/docs/MAKEPP<br>
-gs/freetype/docs/PROBLEMS<br>
-gs/freetype/docs/TODO<br>
-gs/freetype/docs/VERSION.DLL<br>
-gs/freetype/docs/formats.txt<br>
-gs/freetype/docs/freetype-config.1<br>
-gs/freetype/docs/raster.txt<br>
-gs/freetype/docs/reference/README<br>
-gs/freetype/docs/reference/ft2-auto_hinter.html<br>
-gs/freetype/docs/reference/ft2-base_interface.html<br>
-gs/freetype/docs/reference/ft2-basic_types.html<br>
-gs/freetype/docs/reference/ft2-bdf_fonts.html<br>
-gs/freetype/docs/reference/ft2-bitmap_handling.html<br>
-gs/freetype/docs/reference/ft2-bzip2.html<br>
-gs/freetype/docs/reference/ft2-cache_subsystem.html<br>
-gs/freetype/docs/reference/ft2-cff_driver.html<br>
-gs/freetype/docs/reference/ft2-cid_fonts.html<br>
-gs/freetype/docs/reference/ft2-computations.html<br>
-gs/freetype/docs/reference/ft2-font_formats.html<br>
-gs/freetype/docs/reference/ft2-gasp_table.html<br>
-gs/freetype/docs/reference/ft2-glyph_management.html<br>
-gs/freetype/docs/reference/ft2-glyph_stroker.html<br>
-gs/freetype/docs/reference/ft2-glyph_variants.html<br>
-gs/freetype/docs/reference/ft2-gx_validation.html<br>
-gs/freetype/docs/reference/ft2-gzip.html<br>
-gs/freetype/docs/reference/ft2-header_file_macros.html<br>
-gs/freetype/docs/reference/ft2-header_inclusion.html<br>
-gs/freetype/docs/reference/ft2-incremental.html<br>
-gs/freetype/docs/reference/ft2-index.html<br>
-gs/freetype/docs/reference/ft2-lcd_filtering.html<br>
-gs/freetype/docs/reference/ft2-list_processing.html<br>
-gs/freetype/docs/reference/ft2-lzw.html<br>
-gs/freetype/docs/reference/ft2-mac_specific.html<br>
-gs/freetype/docs/reference/ft2-module_management.html<br>
-gs/freetype/docs/reference/ft2-multiple_masters.html<br>
-gs/freetype/docs/reference/ft2-ot_validation.html<br>
-gs/freetype/docs/reference/ft2-outline_processing.html<br>
-gs/freetype/docs/reference/ft2-pfr_fonts.html<br>
-gs/freetype/docs/reference/ft2-quick_advance.html<br>
-gs/freetype/docs/reference/ft2-raster.html<br>
-gs/freetype/docs/reference/ft2-sfnt_names.html<br>
-gs/freetype/docs/reference/ft2-sizes_management.html<br>
-gs/freetype/docs/reference/ft2-system_interface.html<br>
-gs/freetype/docs/reference/ft2-toc.html<br>
-gs/freetype/docs/reference/ft2-truetype_engine.html<br>
-gs/freetype/docs/reference/ft2-truetype_tables.html<br>
-gs/freetype/docs/reference/ft2-tt_driver.html<br>
-gs/freetype/docs/reference/ft2-type1_tables.html<br>
-gs/freetype/docs/reference/ft2-user_allocation.html<br>
-gs/freetype/docs/reference/ft2-version.html<br>
-gs/freetype/docs/reference/ft2-winfnt_fonts.html<br>
-gs/freetype/docs/release<br>
-gs/freetype/include/config/ftconfig.h<br>
-gs/freetype/include/config/ftheader.h<br>
-gs/freetype/include/config/ftmodule.h<br>
-gs/freetype/include/config/ftoption.h<br>
-gs/freetype/include/config/ftstdlib.h<br>
-gs/freetype/include/freetype.h<br>
-gs/freetype/include/ft2build.h<br>
-gs/freetype/include/ftadvanc.h<br>
-gs/freetype/include/ftautoh.h<br>
-gs/freetype/include/ftbbox.h<br>
-gs/freetype/include/ftbdf.h<br>
-gs/freetype/include/ftbitmap.h<br>
-gs/freetype/include/ftbzip2.h<br>
-gs/freetype/include/ftcache.h<br>
-gs/freetype/include/ftcffdrv.h<br>
-gs/freetype/include/ftchapters.h<br>
-gs/freetype/include/ftcid.h<br>
-gs/freetype/include/fterrdef.h<br>
-gs/freetype/include/fterrors.h<br>
-gs/freetype/include/ftgasp.h<br>
-gs/freetype/include/ftglyph.h<br>
-gs/freetype/include/ftgxval.h<br>
-gs/freetype/include/ftgzip.h<br>
-gs/freetype/include/ftimage.h<br>
-gs/freetype/include/ftincrem.h<br>
-gs/freetype/include/ftlcdfil.h<br>
-gs/freetype/include/ftlist.h<br>
-gs/freetype/include/ftlzw.h<br>
-gs/freetype/include/ftmac.h<br>
-gs/freetype/include/ftmm.h<br>
-gs/freetype/include/ftmodapi.h<br>
-gs/freetype/include/ftmoderr.h<br>
-gs/freetype/include/ftotval.h<br>
-gs/freetype/include/ftoutln.h<br>
-gs/freetype/include/ftpfr.h<br>
-gs/freetype/include/ftrender.h<br>
-gs/freetype/include/ftsizes.h<br>
-gs/freetype/include/ftsnames.h<br>
-gs/freetype/include/ftstroke.h<br>
-gs/freetype/include/ftsynth.h<br>
-gs/freetype/include/ftsystem.h<br>
-gs/freetype/include/fttrigon.h<br>
-gs/freetype/include/ftttdrv.h<br>
-gs/freetype/include/fttypes.h<br>
-gs/freetype/include/ftwinfnt.h<br>
-gs/freetype/include/ftxf86.h<br>
-gs/freetype/include/internal/autohint.h<br>
-gs/freetype/include/internal/ftcalc.h<br>
-gs/freetype/include/internal/ftdebug.h<br>
-gs/freetype/include/internal/ftdriver.h<br>
-gs/freetype/include/internal/ftgloadr.h<br>
-gs/freetype/include/internal/ftmemory.h<br>
-gs/freetype/include/internal/ftobjs.h<br>
-gs/freetype/include/internal/ftpic.h<br>
-gs/freetype/include/internal/ftrfork.h<br>
-gs/freetype/include/internal/ftserv.h<br>
-gs/freetype/include/internal/ftstream.h<br>
-gs/freetype/include/internal/fttrace.h<br>
-gs/freetype/include/internal/ftvalid.h<br>
-gs/freetype/include/internal/internal.h<br>
-gs/freetype/include/internal/psaux.h<br>
-gs/freetype/include/internal/pshints.h<br>
-gs/freetype/include/internal/services/svbdf.h<br>
-gs/freetype/include/internal/services/svcid.h<br>
-gs/freetype/include/internal/services/svgldict.h<br>
-gs/freetype/include/internal/services/svgxval.h<br>
-gs/freetype/include/internal/services/svkern.h<br>
-gs/freetype/include/internal/services/svmm.h<br>
-gs/freetype/include/internal/services/svotval.h<br>
-gs/freetype/include/internal/services/svpfr.h<br>
-gs/freetype/include/internal/services/svpostnm.h<br>
-gs/freetype/include/internal/services/svprop.h<br>
-gs/freetype/include/internal/services/svpscmap.h<br>
-gs/freetype/include/internal/services/svpsinfo.h<br>
-gs/freetype/include/internal/services/svsfnt.h<br>
-gs/freetype/include/internal/services/svttcmap.h<br>
-gs/freetype/include/internal/services/svtteng.h<br>
-gs/freetype/include/internal/services/svttglyf.h<br>
-gs/freetype/include/internal/services/svwinfnt.h<br>
-gs/freetype/include/internal/services/svxf86nm.h<br>
-gs/freetype/include/internal/sfnt.h<br>
-gs/freetype/include/internal/t1types.h<br>
-gs/freetype/include/internal/tttypes.h<br>
-gs/freetype/include/t1tables.h<br>
-gs/freetype/include/ttnameid.h<br>
-gs/freetype/include/tttables.h<br>
-gs/freetype/include/tttags.h<br>
-gs/freetype/include/ttunpat.h<br>
-gs/freetype/modules.cfg<br>
-gs/freetype/objs/README<br>
-gs/freetype/src/Jamfile<br>
-gs/freetype/src/autofit/Jamfile<br>
-gs/freetype/src/autofit/afangles.c<br>
-gs/freetype/src/autofit/afangles.h<br>
-gs/freetype/src/autofit/afblue.c<br>
-gs/freetype/src/autofit/afblue.cin<br>
-gs/freetype/src/autofit/afblue.dat<br>
-gs/freetype/src/autofit/afblue.h<br>
-gs/freetype/src/autofit/afblue.hin<br>
-gs/freetype/src/autofit/afcjk.c<br>
-gs/freetype/src/autofit/afcjk.h<br>
-gs/freetype/src/autofit/afcover.h<br>
-gs/freetype/src/autofit/afdummy.c<br>
-gs/freetype/src/autofit/afdummy.h<br>
-gs/freetype/src/autofit/aferrors.h<br>
-gs/freetype/src/autofit/afglobal.c<br>
-gs/freetype/src/autofit/afglobal.h<br>
-gs/freetype/src/autofit/afhints.c<br>
-gs/freetype/src/autofit/afhints.h<br>
-gs/freetype/src/autofit/afindic.c<br>
-gs/freetype/src/autofit/afindic.h<br>
-gs/freetype/src/autofit/aflatin.c<br>
-gs/freetype/src/autofit/aflatin.h<br>
-gs/freetype/src/autofit/aflatin2.c<br>
-gs/freetype/src/autofit/aflatin2.h<br>
-gs/freetype/src/autofit/afloader.c<br>
-gs/freetype/src/autofit/afloader.h<br>
-gs/freetype/src/autofit/afmodule.c<br>
-gs/freetype/src/autofit/afmodule.h<br>
-gs/freetype/src/autofit/afpic.c<br>
-gs/freetype/src/autofit/afpic.h<br>
-gs/freetype/src/autofit/afranges.c<br>
-gs/freetype/src/autofit/afranges.h<br>
-gs/freetype/src/autofit/afscript.h<br>
-gs/freetype/src/autofit/afstyles.h<br>
-gs/freetype/src/autofit/aftypes.h<br>
-gs/freetype/src/autofit/afwarp.c<br>
-gs/freetype/src/autofit/afwarp.h<br>
-gs/freetype/src/autofit/afwrtsys.h<br>
-gs/freetype/src/autofit/autofit.c<br>
-gs/freetype/src/autofit/hbshim.c<br>
-gs/freetype/src/autofit/hbshim.h<br>
-gs/freetype/src/autofit/module.mk<br>
-gs/freetype/src/autofit/rules.mk<br>
-gs/freetype/src/base/Jamfile<br>
-gs/freetype/src/base/basepic.c<br>
-gs/freetype/src/base/basepic.h<br>
-gs/freetype/src/base/ftadvanc.c<br>
-gs/freetype/src/base/ftapi.c<br>
-gs/freetype/src/base/ftbase.c<br>
-gs/freetype/src/base/ftbase.h<br>
-gs/freetype/src/base/ftbbox.c<br>
-gs/freetype/src/base/ftbdf.c<br>
-gs/freetype/src/base/ftbitmap.c<br>
-gs/freetype/src/base/ftcalc.c<br>
-gs/freetype/src/base/ftcid.c<br>
-gs/freetype/src/base/ftdbgmem.c<br>
-gs/freetype/src/base/ftdebug.c<br>
-gs/freetype/src/base/ftfstype.c<br>
-gs/freetype/src/base/ftgasp.c<br>
-gs/freetype/src/base/ftgloadr.c<br>
-gs/freetype/src/base/ftglyph.c<br>
-gs/freetype/src/base/ftgxval.c<br>
-gs/freetype/src/base/ftinit.c<br>
-gs/freetype/src/base/ftlcdfil.c<br>
-gs/freetype/src/base/ftmac.c<br>
-gs/freetype/src/base/ftmm.c<br>
-gs/freetype/src/base/ftobjs.c<br>
-gs/freetype/src/base/ftotval.c<br>
-gs/freetype/src/base/ftoutln.c<br>
-gs/freetype/src/base/ftpatent.c<br>
-gs/freetype/src/base/ftpfr.c<br>
-gs/freetype/src/base/ftpic.c<br>
-gs/freetype/src/base/ftrfork.c<br>
-gs/freetype/src/base/ftsnames.c<br>
-gs/freetype/src/base/ftstream.c<br>
-gs/freetype/src/base/ftstroke.c<br>
-gs/freetype/src/base/ftsynth.c<br>
-gs/freetype/src/base/ftsystem.c<br>
-gs/freetype/src/base/fttrigon.c<br>
-gs/freetype/src/base/fttype1.c<br>
-gs/freetype/src/base/ftutil.c<br>
-gs/freetype/src/base/ftwinfnt.c<br>
-gs/freetype/src/base/ftxf86.c<br>
-gs/freetype/src/base/md5.c<br>
-gs/freetype/src/base/md5.h<br>
-gs/freetype/src/base/rules.mk<br>
-gs/freetype/src/bdf/Jamfile<br>
-gs/freetype/src/bdf/README<br>
-gs/freetype/src/bdf/bdf.c<br>
-gs/freetype/src/bdf/bdf.h<br>
-gs/freetype/src/bdf/bdfdrivr.c<br>
-gs/freetype/src/bdf/bdfdrivr.h<br>
-gs/freetype/src/bdf/bdferror.h<br>
-gs/freetype/src/bdf/bdflib.c<br>
-gs/freetype/src/bdf/module.mk<br>
-gs/freetype/src/bdf/rules.mk<br>
-gs/freetype/src/bzip2/Jamfile<br>
-gs/freetype/src/bzip2/ftbzip2.c<br>
-gs/freetype/src/bzip2/rules.mk<br>
-gs/freetype/src/cache/Jamfile<br>
-gs/freetype/src/cache/ftcache.c<br>
-gs/freetype/src/cache/ftcbasic.c<br>
-gs/freetype/src/cache/ftccache.c<br>
-gs/freetype/src/cache/ftccache.h<br>
-gs/freetype/src/cache/ftccback.h<br>
-gs/freetype/src/cache/ftccmap.c<br>
-gs/freetype/src/cache/ftcerror.h<br>
-gs/freetype/src/cache/ftcglyph.c<br>
-gs/freetype/src/cache/ftcglyph.h<br>
-gs/freetype/src/cache/ftcimage.c<br>
-gs/freetype/src/cache/ftcimage.h<br>
-gs/freetype/src/cache/ftcmanag.c<br>
-gs/freetype/src/cache/ftcmanag.h<br>
-gs/freetype/src/cache/ftcmru.c<br>
-gs/freetype/src/cache/ftcmru.h<br>
-gs/freetype/src/cache/ftcsbits.c<br>
-gs/freetype/src/cache/ftcsbits.h<br>
-gs/freetype/src/cache/rules.mk<br>
-gs/freetype/src/cff/Jamfile<br>
-gs/freetype/src/cff/cf2arrst.c<br>
-gs/freetype/src/cff/cf2arrst.h<br>
-gs/freetype/src/cff/cf2blues.c<br>
-gs/freetype/src/cff/cf2blues.h<br>
-gs/freetype/src/cff/cf2error.c<br>
-gs/freetype/src/cff/cf2error.h<br>
-gs/freetype/src/cff/cf2fixed.h<br>
-gs/freetype/src/cff/cf2font.c<br>
-gs/freetype/src/cff/cf2font.h<br>
-gs/freetype/src/cff/cf2ft.c<br>
-gs/freetype/src/cff/cf2ft.h<br>
-gs/freetype/src/cff/cf2glue.h<br>
-gs/freetype/src/cff/cf2hints.c<br>
-gs/freetype/src/cff/cf2hints.h<br>
-gs/freetype/src/cff/cf2intrp.c<br>
-gs/freetype/src/cff/cf2intrp.h<br>
-gs/freetype/src/cff/cf2read.c<br>
-gs/freetype/src/cff/cf2read.h<br>
-gs/freetype/src/cff/cf2stack.c<br>
-gs/freetype/src/cff/cf2stack.h<br>
-gs/freetype/src/cff/cf2types.h<br>
-gs/freetype/src/cff/cff.c<br>
-gs/freetype/src/cff/cffcmap.c<br>
-gs/freetype/src/cff/cffcmap.h<br>
-gs/freetype/src/cff/cffdrivr.c<br>
-gs/freetype/src/cff/cffdrivr.h<br>
-gs/freetype/src/cff/cfferrs.h<br>
-gs/freetype/src/cff/cffgload.c<br>
-gs/freetype/src/cff/cffgload.h<br>
-gs/freetype/src/cff/cffload.c<br>
-gs/freetype/src/cff/cffload.h<br>
-gs/freetype/src/cff/cffobjs.c<br>
-gs/freetype/src/cff/cffobjs.h<br>
-gs/freetype/src/cff/cffparse.c<br>
-gs/freetype/src/cff/cffparse.h<br>
-gs/freetype/src/cff/cffpic.c<br>
-gs/freetype/src/cff/cffpic.h<br>
-gs/freetype/src/cff/cfftoken.h<br>
-gs/freetype/src/cff/cfftypes.h<br>
-gs/freetype/src/cff/module.mk<br>
-gs/freetype/src/cff/rules.mk<br>
-gs/freetype/src/cid/Jamfile<br>
-gs/freetype/src/cid/ciderrs.h<br>
-gs/freetype/src/cid/cidgload.c<br>
-gs/freetype/src/cid/cidgload.h<br>
-gs/freetype/src/cid/cidload.c<br>
-gs/freetype/src/cid/cidload.h<br>
-gs/freetype/src/cid/cidobjs.c<br>
-gs/freetype/src/cid/cidobjs.h<br>
-gs/freetype/src/cid/cidparse.c<br>
-gs/freetype/src/cid/cidparse.h<br>
-gs/freetype/src/cid/cidriver.c<br>
-gs/freetype/src/cid/cidriver.h<br>
-gs/freetype/src/cid/cidtoken.h<br>
-gs/freetype/src/cid/module.mk<br>
-gs/freetype/src/cid/rules.mk<br>
-gs/freetype/src/cid/type1cid.c<br>
-gs/freetype/src/gxvalid/Jamfile<br>
-gs/freetype/src/gxvalid/README<br>
-gs/freetype/src/gxvalid/gxvalid.c<br>
-gs/freetype/src/gxvalid/gxvalid.h<br>
-gs/freetype/src/gxvalid/gxvbsln.c<br>
-gs/freetype/src/gxvalid/gxvcommn.c<br>
-gs/freetype/src/gxvalid/gxvcommn.h<br>
-gs/freetype/src/gxvalid/gxverror.h<br>
-gs/freetype/src/gxvalid/gxvfeat.c<br>
-gs/freetype/src/gxvalid/gxvfeat.h<br>
-gs/freetype/src/gxvalid/gxvfgen.c<br>
-gs/freetype/src/gxvalid/gxvjust.c<br>
-gs/freetype/src/gxvalid/gxvkern.c<br>
-gs/freetype/src/gxvalid/gxvlcar.c<br>
-gs/freetype/src/gxvalid/gxvmod.c<br>
-gs/freetype/src/gxvalid/gxvmod.h<br>
-gs/freetype/src/gxvalid/gxvmort.c<br>
-gs/freetype/src/gxvalid/gxvmort.h<br>
-gs/freetype/src/gxvalid/gxvmort0.c<br>
-gs/freetype/src/gxvalid/gxvmort1.c<br>
-gs/freetype/src/gxvalid/gxvmort2.c<br>
-gs/freetype/src/gxvalid/gxvmort4.c<br>
-gs/freetype/src/gxvalid/gxvmort5.c<br>
-gs/freetype/src/gxvalid/gxvmorx.c<br>
-gs/freetype/src/gxvalid/gxvmorx.h<br>
-gs/freetype/src/gxvalid/gxvmorx0.c<br>
-gs/freetype/src/gxvalid/gxvmorx1.c<br>
-gs/freetype/src/gxvalid/gxvmorx2.c<br>
-gs/freetype/src/gxvalid/gxvmorx4.c<br>
-gs/freetype/src/gxvalid/gxvmorx5.c<br>
-gs/freetype/src/gxvalid/gxvopbd.c<br>
-gs/freetype/src/gxvalid/gxvprop.c<br>
-gs/freetype/src/gxvalid/gxvtrak.c<br>
-gs/freetype/src/gxvalid/module.mk<br>
-gs/freetype/src/gxvalid/rules.mk<br>
-gs/freetype/src/gzip/Jamfile<br>
-gs/freetype/src/gzip/adler32.c<br>
-gs/freetype/src/gzip/ftgzip.c<br>
-gs/freetype/src/gzip/infblock.c<br>
-gs/freetype/src/gzip/infblock.h<br>
-gs/freetype/src/gzip/infcodes.c<br>
-gs/freetype/src/gzip/infcodes.h<br>
-gs/freetype/src/gzip/inffixed.h<br>
-gs/freetype/src/gzip/inflate.c<br>
-gs/freetype/src/gzip/inftrees.c<br>
-gs/freetype/src/gzip/inftrees.h<br>
-gs/freetype/src/gzip/infutil.c<br>
-gs/freetype/src/gzip/infutil.h<br>
-gs/freetype/src/gzip/rules.mk<br>
-gs/freetype/src/gzip/zconf.h<br>
-gs/freetype/src/gzip/zlib.h<br>
-gs/freetype/src/gzip/zutil.c<br>
-gs/freetype/src/gzip/zutil.h<br>
-gs/freetype/src/lzw/Jamfile<br>
-gs/freetype/src/lzw/ftlzw.c<br>
-gs/freetype/src/lzw/ftzopen.c<br>
-gs/freetype/src/lzw/ftzopen.h<br>
-gs/freetype/src/lzw/rules.mk<br>
-gs/freetype/src/otvalid/Jamfile<br>
-gs/freetype/src/otvalid/module.mk<br>
-gs/freetype/src/otvalid/otvalid.c<br>
-gs/freetype/src/otvalid/otvalid.h<br>
-gs/freetype/src/otvalid/otvbase.c<br>
-gs/freetype/src/otvalid/otvcommn.c<br>
-gs/freetype/src/otvalid/otvcommn.h<br>
-gs/freetype/src/otvalid/otverror.h<br>
-gs/freetype/src/otvalid/otvgdef.c<br>
-gs/freetype/src/otvalid/otvgpos.c<br>
-gs/freetype/src/otvalid/otvgpos.h<br>
-gs/freetype/src/otvalid/otvgsub.c<br>
-gs/freetype/src/otvalid/otvjstf.c<br>
-gs/freetype/src/otvalid/otvmath.c<br>
-gs/freetype/src/otvalid/otvmod.c<br>
-gs/freetype/src/otvalid/otvmod.h<br>
-gs/freetype/src/otvalid/rules.mk<br>
-gs/freetype/src/pcf/Jamfile<br>
-gs/freetype/src/pcf/README<br>
-gs/freetype/src/pcf/module.mk<br>
-gs/freetype/src/pcf/pcf.c<br>
-gs/freetype/src/pcf/pcf.h<br>
-gs/freetype/src/pcf/pcfdrivr.c<br>
-gs/freetype/src/pcf/pcfdrivr.h<br>
-gs/freetype/src/pcf/pcferror.h<br>
-gs/freetype/src/pcf/pcfread.c<br>
-gs/freetype/src/pcf/pcfread.h<br>
-gs/freetype/src/pcf/pcfutil.c<br>
-gs/freetype/src/pcf/pcfutil.h<br>
-gs/freetype/src/pcf/rules.mk<br>
-gs/freetype/src/pfr/Jamfile<br>
-gs/freetype/src/pfr/module.mk<br>
-gs/freetype/src/pfr/pfr.c<br>
-gs/freetype/src/pfr/pfrcmap.c<br>
-gs/freetype/src/pfr/pfrcmap.h<br>
-gs/freetype/src/pfr/pfrdrivr.c<br>
-gs/freetype/src/pfr/pfrdrivr.h<br>
-gs/freetype/src/pfr/pfrerror.h<br>
-gs/freetype/src/pfr/pfrgload.c<br>
-gs/freetype/src/pfr/pfrgload.h<br>
-gs/freetype/src/pfr/pfrload.c<br>
-gs/freetype/src/pfr/pfrload.h<br>
-gs/freetype/src/pfr/pfrobjs.c<br>
-gs/freetype/src/pfr/pfrobjs.h<br>
-gs/freetype/src/pfr/pfrsbit.c<br>
-gs/freetype/src/pfr/pfrsbit.h<br>
-gs/freetype/src/pfr/pfrtypes.h<br>
-gs/freetype/src/pfr/rules.mk<br>
-gs/freetype/src/psaux/Jamfile<br>
-gs/freetype/src/psaux/afmparse.c<br>
-gs/freetype/src/psaux/afmparse.h<br>
-gs/freetype/src/psaux/module.mk<br>
-gs/freetype/src/psaux/psaux.c<br>
-gs/freetype/src/psaux/psauxerr.h<br>
-gs/freetype/src/psaux/psauxmod.c<br>
-gs/freetype/src/psaux/psauxmod.h<br>
-gs/freetype/src/psaux/psconv.c<br>
-gs/freetype/src/psaux/psconv.h<br>
-gs/freetype/src/psaux/psobjs.c<br>
-gs/freetype/src/psaux/psobjs.h<br>
-gs/freetype/src/psaux/rules.mk<br>
-gs/freetype/src/psaux/t1cmap.c<br>
-gs/freetype/src/psaux/t1cmap.h<br>
-gs/freetype/src/psaux/t1decode.c<br>
-gs/freetype/src/psaux/t1decode.h<br>
-gs/freetype/src/pshinter/Jamfile<br>
-gs/freetype/src/pshinter/module.mk<br>
-gs/freetype/src/pshinter/pshalgo.c<br>
-gs/freetype/src/pshinter/pshalgo.h<br>
-gs/freetype/src/pshinter/pshglob.c<br>
-gs/freetype/src/pshinter/pshglob.h<br>
-gs/freetype/src/pshinter/pshinter.c<br>
-gs/freetype/src/pshinter/pshmod.c<br>
-gs/freetype/src/pshinter/pshmod.h<br>
-gs/freetype/src/pshinter/pshnterr.h<br>
-gs/freetype/src/pshinter/pshpic.c<br>
-gs/freetype/src/pshinter/pshpic.h<br>
-gs/freetype/src/pshinter/pshrec.c<br>
-gs/freetype/src/pshinter/pshrec.h<br>
-gs/freetype/src/pshinter/rules.mk<br>
-gs/freetype/src/psnames/Jamfile<br>
-gs/freetype/src/psnames/module.mk<br>
-gs/freetype/src/psnames/psmodule.c<br>
-gs/freetype/src/psnames/psmodule.h<br>
-gs/freetype/src/psnames/psnamerr.h<br>
-gs/freetype/src/psnames/psnames.c<br>
-gs/freetype/src/psnames/pspic.c<br>
-gs/freetype/src/psnames/pspic.h<br>
-gs/freetype/src/psnames/pstables.h<br>
-gs/freetype/src/psnames/rules.mk<br>
-gs/freetype/src/raster/Jamfile<br>
-gs/freetype/src/raster/ftmisc.h<br>
-gs/freetype/src/raster/ftraster.c<br>
-gs/freetype/src/raster/ftraster.h<br>
-gs/freetype/src/raster/ftrend1.c<br>
-gs/freetype/src/raster/ftrend1.h<br>
-gs/freetype/src/raster/module.mk<br>
-gs/freetype/src/raster/raster.c<br>
-gs/freetype/src/raster/rasterrs.h<br>
-gs/freetype/src/raster/rastpic.c<br>
-gs/freetype/src/raster/rastpic.h<br>
-gs/freetype/src/raster/rules.mk<br>
-gs/freetype/src/sfnt/Jamfile<br>
-gs/freetype/src/sfnt/module.mk<br>
-gs/freetype/src/sfnt/pngshim.c<br>
-gs/freetype/src/sfnt/pngshim.h<br>
-gs/freetype/src/sfnt/rules.mk<br>
-gs/freetype/src/sfnt/sfdriver.c<br>
-gs/freetype/src/sfnt/sfdriver.h<br>
-gs/freetype/src/sfnt/sferrors.h<br>
-gs/freetype/src/sfnt/sfnt.c<br>
-gs/freetype/src/sfnt/sfntpic.c<br>
-gs/freetype/src/sfnt/sfntpic.h<br>
-gs/freetype/src/sfnt/sfobjs.c<br>
-gs/freetype/src/sfnt/sfobjs.h<br>
-gs/freetype/src/sfnt/ttbdf.c<br>
-gs/freetype/src/sfnt/ttbdf.h<br>
-gs/freetype/src/sfnt/ttcmap.c<br>
-gs/freetype/src/sfnt/ttcmap.h<br>
-gs/freetype/src/sfnt/ttcmapc.h<br>
-gs/freetype/src/sfnt/ttkern.c<br>
-gs/freetype/src/sfnt/ttkern.h<br>
-gs/freetype/src/sfnt/ttload.c<br>
-gs/freetype/src/sfnt/ttload.h<br>
-gs/freetype/src/sfnt/ttmtx.c<br>
-gs/freetype/src/sfnt/ttmtx.h<br>
-gs/freetype/src/sfnt/ttpost.c<br>
-gs/freetype/src/sfnt/ttpost.h<br>
-gs/freetype/src/sfnt/ttsbit.c<br>
-gs/freetype/src/sfnt/ttsbit.h<br>
-gs/freetype/src/smooth/Jamfile<br>
-gs/freetype/src/smooth/ftgrays.c<br>
-gs/freetype/src/smooth/ftgrays.h<br>
-gs/freetype/src/smooth/ftsmerrs.h<br>
-gs/freetype/src/smooth/ftsmooth.c<br>
-gs/freetype/src/smooth/ftsmooth.h<br>
-gs/freetype/src/smooth/ftspic.c<br>
-gs/freetype/src/smooth/ftspic.h<br>
-gs/freetype/src/smooth/module.mk<br>
-gs/freetype/src/smooth/rules.mk<br>
-gs/freetype/src/smooth/smooth.c<br>
-gs/freetype/src/tools/Jamfile<br>
-gs/freetype/src/tools/afblue.pl<br>
-gs/freetype/src/tools/apinames.c<br>
-gs/freetype/src/tools/chktrcmp.py<br>
-gs/freetype/src/tools/cordic.py<br>
-gs/freetype/src/tools/docmaker/content.py<br>
-gs/freetype/src/tools/docmaker/docbeauty.py<br>
-gs/freetype/src/tools/docmaker/docmaker.py<br>
-gs/freetype/src/tools/docmaker/formatter.py<br>
-gs/freetype/src/tools/docmaker/sources.py<br>
-gs/freetype/src/tools/docmaker/tohtml.py<br>
-gs/freetype/src/tools/docmaker/utils.py<br>
-gs/freetype/src/tools/ftrandom/Makefile<br>
-gs/freetype/src/tools/ftrandom/README<br>
-gs/freetype/src/tools/ftrandom/ftrandom.c<br>
-gs/freetype/src/tools/glnames.py<br>
-gs/freetype/src/tools/test_afm.c<br>
-gs/freetype/src/tools/test_bbox.c<br>
-gs/freetype/src/tools/test_trig.c<br>
-gs/freetype/src/truetype/Jamfile<br>
-gs/freetype/src/truetype/module.mk<br>
-gs/freetype/src/truetype/rules.mk<br>
-gs/freetype/src/truetype/truetype.c<br>
-gs/freetype/src/truetype/ttdriver.c<br>
-gs/freetype/src/truetype/ttdriver.h<br>
-gs/freetype/src/truetype/tterrors.h<br>
-gs/freetype/src/truetype/ttgload.c<br>
-gs/freetype/src/truetype/ttgload.h<br>
-gs/freetype/src/truetype/ttgxvar.c<br>
-gs/freetype/src/truetype/ttgxvar.h<br>
-gs/freetype/src/truetype/ttinterp.c<br>
-gs/freetype/src/truetype/ttinterp.h<br>
-gs/freetype/src/truetype/ttobjs.c<br>
-gs/freetype/src/truetype/ttobjs.h<br>
-gs/freetype/src/truetype/ttpic.c<br>
-gs/freetype/src/truetype/ttpic.h<br>
-gs/freetype/src/truetype/ttpload.c<br>
-gs/freetype/src/truetype/ttpload.h<br>
-gs/freetype/src/truetype/ttsubpix.c<br>
-gs/freetype/src/truetype/ttsubpix.h<br>
-gs/freetype/src/type1/Jamfile<br>
-gs/freetype/src/type1/module.mk<br>
-gs/freetype/src/type1/rules.mk<br>
-gs/freetype/src/type1/t1afm.c<br>
-gs/freetype/src/type1/t1afm.h<br>
-gs/freetype/src/type1/t1driver.c<br>
-gs/freetype/src/type1/t1driver.h<br>
-gs/freetype/src/type1/t1errors.h<br>
-gs/freetype/src/type1/t1gload.c<br>
-gs/freetype/src/type1/t1gload.h<br>
-gs/freetype/src/type1/t1load.c<br>
-gs/freetype/src/type1/t1load.h<br>
-gs/freetype/src/type1/t1objs.c<br>
-gs/freetype/src/type1/t1objs.h<br>
-gs/freetype/src/type1/t1parse.c<br>
-gs/freetype/src/type1/t1parse.h<br>
-gs/freetype/src/type1/t1tokens.h<br>
-gs/freetype/src/type1/type1.c<br>
-gs/freetype/src/type42/Jamfile<br>
-gs/freetype/src/type42/module.mk<br>
-gs/freetype/src/type42/rules.mk<br>
-gs/freetype/src/type42/t42drivr.c<br>
-gs/freetype/src/type42/t42drivr.h<br>
-gs/freetype/src/type42/t42error.h<br>
-gs/freetype/src/type42/t42objs.c<br>
-gs/freetype/src/type42/t42objs.h<br>
-gs/freetype/src/type42/t42parse.c<br>
-gs/freetype/src/type42/t42parse.h<br>
-gs/freetype/src/type42/t42types.h<br>
-gs/freetype/src/type42/type42.c<br>
-gs/freetype/src/winfonts/Jamfile<br>
-gs/freetype/src/winfonts/fnterrs.h<br>
-gs/freetype/src/winfonts/module.mk<br>
-gs/freetype/src/winfonts/rules.mk<br>
-gs/freetype/src/winfonts/winfnt.c<br>
-gs/freetype/src/winfonts/winfnt.h<br>
-gs/freetype/version.sed<br>
-gs/freetype/vms_make.com<br>
-gs/ghostscript-ufst.vcproj<br>
-gs/ghostscript.vcproj<br>
-gs/ghostscript_rt.vcxproj<br>
-gs/iccprofiles/default_cmyk.icc<br>
-gs/iccprofiles/default_gray.icc<br>
-gs/iccprofiles/default_rgb.icc<br>
-gs/iccprofiles/gray_to_k.icc<br>
-gs/iccprofiles/lab.icc<br>
-gs/iccprofiles/ps_cmyk.icc<br>
-gs/iccprofiles/ps_gray.icc<br>
-gs/iccprofiles/ps_rgb.icc<br>
-gs/iccprofiles/sgray.icc<br>
-gs/iccprofiles/srgb.icc<br>
-gs/ijs/Makefile.am<br>
-gs/ijs/Makefile.in<br>
-gs/ijs/README<br>
-gs/ijs/autogen.sh<br>
-gs/ijs/common.mak<br>
-gs/ijs/compile<br>
-gs/ijs/config.guess<br>
-gs/ijs/config.sub<br>
-gs/ijs/configure<br>
-gs/ijs/configure.ac<br>
-gs/ijs/ijs-config.1<br>
-gs/ijs/ijs-config.in<br>
-gs/ijs/ijs.c<br>
-gs/ijs/ijs.h<br>
-gs/ijs/ijs.pc.in<br>
-gs/ijs/ijs_client.c<br>
-gs/ijs/ijs_client.h<br>
-gs/ijs/ijs_client_example.c<br>
-gs/ijs/ijs_exec_unix.c<br>
-gs/ijs/ijs_exec_win.c<br>
-gs/ijs/ijs_server.c<br>
-gs/ijs/ijs_server.h<br>
-gs/ijs/ijs_server_example.c<br>
-gs/ijs/ijs_spec.pdf<br>
-gs/ijs/ijs_spec.ps<br>
-gs/ijs/ijs_spec.sgml<br>
-gs/ijs/install-sh<br>
-gs/ijs/libtool<br>
-gs/ijs/ltmain.sh<br>
-gs/ijs/missing<br>
-gs/ijs/state.eps<br>
-gs/ijs/state.fig<br>
-gs/ijs/unistd_.h<br>
-gs/ijs/unix.mak<br>
-gs/ijs/windows.mak<br>
-gs/jbig2dec/.gitignore<br>
-gs/jbig2dec/CHANGES<br>
-gs/jbig2dec/COPYING<br>
-gs/jbig2dec/LICENSE<br>
-gs/jbig2dec/Makefile.am<br>
-gs/jbig2dec/Makefile.unix<br>
-gs/jbig2dec/README<br>
-gs/jbig2dec/annex-h.jbig2<br>
-gs/jbig2dec/autogen.sh<br>
-gs/jbig2dec/config_win32.h<br>
-gs/jbig2dec/configure.ac<br>
-gs/jbig2dec/getopt.c<br>
-gs/jbig2dec/getopt.h<br>
-gs/jbig2dec/getopt1.c<br>
-gs/jbig2dec/jbig2.c<br>
-gs/jbig2dec/jbig2.h<br>
-gs/jbig2dec/jbig2_arith.c<br>
-gs/jbig2dec/jbig2_arith.h<br>
-gs/jbig2dec/jbig2_arith_iaid.c<br>
-gs/jbig2dec/jbig2_arith_iaid.h<br>
-gs/jbig2dec/jbig2_arith_int.c<br>
-gs/jbig2dec/jbig2_arith_int.h<br>
-gs/jbig2dec/jbig2_generic.c<br>
-gs/jbig2dec/jbig2_generic.h<br>
-gs/jbig2dec/jbig2_halftone.c<br>
-gs/jbig2dec/jbig2_halftone.h<br>
-gs/jbig2dec/jbig2_huffman.c<br>
-gs/jbig2dec/jbig2_huffman.h<br>
-gs/jbig2dec/jbig2_hufftab.h<br>
-gs/jbig2dec/jbig2_image.c<br>
-gs/jbig2dec/jbig2_image.h<br>
-gs/jbig2dec/jbig2_image_pbm.c<br>
-gs/jbig2dec/jbig2_image_png.c<br>
-gs/jbig2dec/jbig2_metadata.c<br>
-gs/jbig2dec/jbig2_metadata.h<br>
-gs/jbig2dec/jbig2_mmr.c<br>
-gs/jbig2dec/jbig2_mmr.h<br>
-gs/jbig2dec/jbig2_page.c<br>
-gs/jbig2dec/jbig2_priv.h<br>
-gs/jbig2dec/jbig2_refinement.c<br>
-gs/jbig2dec/jbig2_segment.c<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-gs/jbig2dec/jbig2_symbol_dict.h<br>
-gs/jbig2dec/jbig2_text.c<br>
-gs/jbig2dec/jbig2_text.h<br>
-gs/jbig2dec/jbig2dec.1<br>
-gs/jbig2dec/jbig2dec.c<br>
-gs/jbig2dec/memcmp.c<br>
-gs/jbig2dec/memento.c<br>
-gs/jbig2dec/memento.h<br>
-gs/jbig2dec/msvc.mak<br>
-gs/jbig2dec/os_types.h<br>
-gs/jbig2dec/pbm2png.c<br>
-gs/jbig2dec/sha1.c<br>
-gs/jbig2dec/sha1.h<br>
-gs/jbig2dec/snprintf.c<br>
-gs/jbig2dec/test_jbig2dec.py<br>
-gs/jpeg/Makefile.am<br>
-gs/jpeg/Makefile.in<br>
-gs/jpeg/README<br>
-gs/jpeg/aclocal.m4<br>
-gs/jpeg/ar-lib<br>
-gs/jpeg/cderror.h<br>
-gs/jpeg/cdjpeg.c<br>
-gs/jpeg/cdjpeg.h<br>
-gs/jpeg/change.log<br>
-gs/jpeg/cjpeg.1<br>
-gs/jpeg/cjpeg.c<br>
-gs/jpeg/ckconfig.c<br>
-gs/jpeg/coderules.txt<br>
-gs/jpeg/compile<br>
-gs/jpeg/config.guess<br>
-gs/jpeg/config.sub<br>
-gs/jpeg/configure<br>
-gs/jpeg/configure.ac<br>
-gs/jpeg/depcomp<br>
-gs/jpeg/djpeg.1<br>
-gs/jpeg/djpeg.c<br>
-gs/jpeg/example.c<br>
-gs/jpeg/filelist.txt<br>
-gs/jpeg/install-sh<br>
-gs/jpeg/install.txt<br>
-gs/jpeg/jaricom.c<br>
-gs/jpeg/jcapimin.c<br>
-gs/jpeg/jcapistd.c<br>
-gs/jpeg/jcarith.c<br>
-gs/jpeg/jccoefct.c<br>
-gs/jpeg/jccolor.c<br>
-gs/jpeg/jcdctmgr.c<br>
-gs/jpeg/jchuff.c<br>
-gs/jpeg/jcinit.c<br>
-gs/jpeg/jcmainct.c<br>
-gs/jpeg/jcmarker.c<br>
-gs/jpeg/jcmaster.c<br>
-gs/jpeg/jcomapi.c<br>
-gs/jpeg/jconfig.bcc<br>
-gs/jpeg/jconfig.cfg<br>
-gs/jpeg/jconfig.dj<br>
-gs/jpeg/jconfig.mac<br>
-gs/jpeg/jconfig.manx<br>
-gs/jpeg/jconfig.mc6<br>
-gs/jpeg/jconfig.sas<br>
-gs/jpeg/jconfig.st<br>
-gs/jpeg/jconfig.txt<br>
-gs/jpeg/jconfig.vc<br>
-gs/jpeg/jconfig.vms<br>
-gs/jpeg/jconfig.wat<br>
-gs/jpeg/jcparam.c<br>
-gs/jpeg/jcprepct.c<br>
-gs/jpeg/jcsample.c<br>
-gs/jpeg/jctrans.c<br>
-gs/jpeg/jdapimin.c<br>
-gs/jpeg/jdapistd.c<br>
-gs/jpeg/jdarith.c<br>
-gs/jpeg/jdatadst.c<br>
-gs/jpeg/jdatasrc.c<br>
-gs/jpeg/jdcoefct.c<br>
-gs/jpeg/jdcolor.c<br>
-gs/jpeg/jdct.h<br>
-gs/jpeg/jddctmgr.c<br>
-gs/jpeg/jdhuff.c<br>
-gs/jpeg/jdinput.c<br>
-gs/jpeg/jdmainct.c<br>
-gs/jpeg/jdmarker.c<br>
-gs/jpeg/jdmaster.c<br>
-gs/jpeg/jdmerge.c<br>
-gs/jpeg/jdpostct.c<br>
-gs/jpeg/jdsample.c<br>
-gs/jpeg/jdtrans.c<br>
-gs/jpeg/jerror.c<br>
-gs/jpeg/jerror.h<br>
-gs/jpeg/jfdctflt.c<br>
-gs/jpeg/jfdctfst.c<br>
-gs/jpeg/jfdctint.c<br>
-gs/jpeg/jidctflt.c<br>
-gs/jpeg/jidctfst.c<br>
-gs/jpeg/jidctint.c<br>
-gs/jpeg/jinclude.h<br>
-gs/jpeg/jmemansi.c<br>
-gs/jpeg/jmemdos.c<br>
-gs/jpeg/jmemdosa.asm<br>
-gs/jpeg/jmemmac.c<br>
-gs/jpeg/jmemmgr.c<br>
-gs/jpeg/jmemname.c<br>
-gs/jpeg/jmemnobs.c<br>
-gs/jpeg/jmemsys.h<br>
-gs/jpeg/jmorecfg.h<br>
-gs/jpeg/jpegint.h<br>
-gs/jpeg/jpeglib.h<br>
-gs/jpeg/jpegtran.1<br>
-gs/jpeg/jpegtran.c<br>
-gs/jpeg/jquant1.c<br>
-gs/jpeg/jquant2.c<br>
-gs/jpeg/jutils.c<br>
-gs/jpeg/jversion.h<br>
-gs/jpeg/libjpeg.map<br>
-gs/jpeg/libjpeg.txt<br>
-gs/jpeg/ltmain.sh<br>
-gs/jpeg/makcjpeg.st<br>
-gs/jpeg/makdjpeg.st<br>
-gs/jpeg/makeadsw.vc6<br>
-gs/jpeg/makeasln.v10<br>
-gs/jpeg/makecdep.vc6<br>
-gs/jpeg/makecdsp.vc6<br>
-gs/jpeg/makecfil.v10<br>
-gs/jpeg/makecmak.vc6<br>
-gs/jpeg/makecvcx.v10<br>
-gs/jpeg/makeddep.vc6<br>
-gs/jpeg/makeddsp.vc6<br>
-gs/jpeg/makedfil.v10<br>
-gs/jpeg/makedmak.vc6<br>
-gs/jpeg/makedvcx.v10<br>
-gs/jpeg/makefile.ansi<br>
-gs/jpeg/makefile.bcc<br>
-gs/jpeg/makefile.dj<br>
-gs/jpeg/makefile.manx<br>
-gs/jpeg/makefile.mc6<br>
-gs/jpeg/makefile.mms<br>
-gs/jpeg/makefile.sas<br>
-gs/jpeg/makefile.unix<br>
-gs/jpeg/makefile.vc<br>
-gs/jpeg/makefile.vms<br>
-gs/jpeg/makefile.wat<br>
-gs/jpeg/makejdep.vc6<br>
-gs/jpeg/makejdsp.vc6<br>
-gs/jpeg/makejdsw.vc6<br>
-gs/jpeg/makejfil.v10<br>
-gs/jpeg/makejmak.vc6<br>
-gs/jpeg/makejsln.v10<br>
-gs/jpeg/makejvcx.v10<br>
-gs/jpeg/makeproj.mac<br>
-gs/jpeg/makerdep.vc6<br>
-gs/jpeg/makerdsp.vc6<br>
-gs/jpeg/makerfil.v10<br>
-gs/jpeg/makermak.vc6<br>
-gs/jpeg/makervcx.v10<br>
-gs/jpeg/maketdep.vc6<br>
-gs/jpeg/maketdsp.vc6<br>
-gs/jpeg/maketfil.v10<br>
-gs/jpeg/maketmak.vc6<br>
-gs/jpeg/maketvcx.v10<br>
-gs/jpeg/makewdep.vc6<br>
-gs/jpeg/makewdsp.vc6<br>
-gs/jpeg/makewfil.v10<br>
-gs/jpeg/makewmak.vc6<br>
-gs/jpeg/makewvcx.v10<br>
-gs/jpeg/makljpeg.st<br>
-gs/jpeg/maktjpeg.st<br>
-gs/jpeg/makvms.opt<br>
-gs/jpeg/missing<br>
-gs/jpeg/rdbmp.c<br>
-gs/jpeg/rdcolmap.c<br>
-gs/jpeg/rdgif.c<br>
-gs/jpeg/rdjpgcom.1<br>
-gs/jpeg/rdjpgcom.c<br>
-gs/jpeg/rdppm.c<br>
-gs/jpeg/rdrle.c<br>
-gs/jpeg/rdswitch.c<br>
-gs/jpeg/rdtarga.c<br>
-gs/jpeg/structure.txt<br>
-gs/jpeg/testimg.bmp<br>
-gs/jpeg/testimg.jpg<br>
-gs/jpeg/testimg.ppm<br>
-gs/jpeg/testimgp.jpg<br>
-gs/jpeg/testorig.jpg<br>
-gs/jpeg/testprog.jpg<br>
-gs/jpeg/transupp.c<br>
-gs/jpeg/transupp.h<br>
-gs/jpeg/usage.txt<br>
-gs/jpeg/wizard.txt<br>
-gs/jpeg/wrbmp.c<br>
-gs/jpeg/wrgif.c<br>
-gs/jpeg/wrjpgcom.1<br>
-gs/jpeg/wrjpgcom.c<br>
-gs/jpeg/wrppm.c<br>
-gs/jpeg/wrrle.c<br>
-gs/jpeg/wrtarga.c<br>
-gs/jpegxr/APP.rc<br>
-gs/jpegxr/APP.vcproj<br>
-gs/jpegxr/COPYRIGHT.txt<br>
-gs/jpegxr/DLL.rc<br>
-gs/jpegxr/DLL.vcproj<br>
-gs/jpegxr/JPEG-XR.sln<br>
-gs/jpegxr/Makefile<br>
-gs/jpegxr/README.txt<br>
-gs/jpegxr/algo.c<br>
-gs/jpegxr/api.c<br>
-gs/jpegxr/app_resource.h<br>
-gs/jpegxr/cr_parse.c<br>
-gs/jpegxr/cw_emit.c<br>
-gs/jpegxr/dll_resource.h<br>
-gs/jpegxr/dllmain.c<br>
-gs/jpegxr/file.c<br>
-gs/jpegxr/file.h<br>
-gs/jpegxr/flags.c<br>
-gs/jpegxr/init.c<br>
-gs/jpegxr/io.c<br>
-gs/jpegxr/jpegxr.c<br>
-gs/jpegxr/jpegxr.h<br>
-gs/jpegxr/jpegxr_pixelformat.c<br>
-gs/jpegxr/jxr_priv.h<br>
-gs/jpegxr/my_getopt-1.5/LICENSE<br>
-gs/jpegxr/my_getopt-1.5/getopt.h<br>
-gs/jpegxr/my_getopt-1.5/my_getopt.c<br>
-gs/jpegxr/my_getopt-1.5/my_getopt.h<br>
-gs/jpegxr/qp.tab.c<br>
-gs/jpegxr/qp.tab.h<br>
-gs/jpegxr/qp_lexor.c<br>
-gs/jpegxr/qp_lexor.lex<br>
-gs/jpegxr/qp_parse.y<br>
-gs/jpegxr/r_parse.c<br>
-gs/jpegxr/r_strip.c<br>
-gs/jpegxr/r_tile_frequency.c<br>
-gs/jpegxr/r_tile_spatial.c<br>
-gs/jpegxr/sample.qp<br>
-gs/jpegxr/stdint_minimal.h<br>
-gs/jpegxr/versions-windows.txt<br>
-gs/jpegxr/w_emit.c<br>
-gs/jpegxr/w_strip.c<br>
-gs/jpegxr/w_tile_frequency.c<br>
-gs/jpegxr/w_tile_spatial.c<br>
-gs/jpegxr/x_strip.c<br>
-gs/lcms2/AUTHORS<br>
-gs/lcms2/COPYING<br>
-gs/lcms2/ChangeLog<br>
-gs/lcms2/INSTALL<br>
-gs/lcms2/Lib/BC/BC.txt<br>
-gs/lcms2/Lib/MS/MS.TXT<br>
-gs/lcms2/Makefile.am<br>
-gs/lcms2/Makefile.in<br>
-gs/lcms2/Projects/.gitignore<br>
-gs/lcms2/Projects/BorlandC_5.5/lcms2.rc<br>
-gs/lcms2/Projects/BorlandC_5.5/lcmsdll.lk<br>
-gs/lcms2/Projects/BorlandC_5.5/lcmsdll.lst<br>
-gs/lcms2/Projects/BorlandC_5.5/mklcmsdll.bat<br>
-gs/lcms2/Projects/VC2008/jpegicc/jpegicc.vcproj<br>
-gs/lcms2/Projects/VC2008/lcms2.rc<br>
-gs/lcms2/Projects/VC2008/lcms2.sln<br>
-gs/lcms2/Projects/VC2008/lcms2_DLL/lcms2_DLL.vcproj<br>
-gs/lcms2/Projects/VC2008/lcms2_static/lcms2_static.vcproj<br>
-gs/lcms2/Projects/VC2008/linkicc/linkicc.vcproj<br>
-gs/lcms2/Projects/VC2008/psicc/psicc.vcproj<br>
-gs/lcms2/Projects/VC2008/resource.h<br>
-gs/lcms2/Projects/VC2008/testbed/testbed.vcproj<br>
-gs/lcms2/Projects/VC2008/tiffdiff/tiffdiff.vcproj<br>
-gs/lcms2/Projects/VC2008/tifficc/tifficc.vcproj<br>
-gs/lcms2/Projects/VC2008/transicc/transicc.vcproj<br>
-gs/lcms2/Projects/VC2010/jpegicc/jpegicc.vcproj<br>
-gs/lcms2/Projects/VC2010/jpegicc/jpegicc.vcxproj<br>
-gs/lcms2/Projects/VC2010/jpegicc/jpegicc.vcxproj.filters<br>
-gs/lcms2/Projects/VC2010/lcms2.rc<br>
-gs/lcms2/Projects/VC2010/lcms2.sln<br>
-gs/lcms2/Projects/VC2010/lcms2_DLL/lcms2_DLL.vcproj<br>
-gs/lcms2/Projects/VC2010/lcms2_DLL/lcms2_DLL.vcxproj<br>
-gs/lcms2/Projects/VC2010/lcms2_DLL/lcms2_DLL.vcxproj.filters<br>
-gs/lcms2/Projects/VC2010/lcms2_static/lcms2_static.vcproj<br>
-gs/lcms2/Projects/VC2010/lcms2_static/lcms2_static.vcxproj<br>
-gs/lcms2/Projects/VC2010/lcms2_static/lcms2_static.vcxproj.filters<br>
-gs/lcms2/Projects/VC2010/linkicc/linkicc.vcproj<br>
-gs/lcms2/Projects/VC2010/linkicc/linkicc.vcxproj<br>
-gs/lcms2/Projects/VC2010/linkicc/linkicc.vcxproj.filters<br>
-gs/lcms2/Projects/VC2010/psicc/psicc.vcproj<br>
-gs/lcms2/Projects/VC2010/psicc/psicc.vcxproj<br>
-gs/lcms2/Projects/VC2010/psicc/psicc.vcxproj.filters<br>
-gs/lcms2/Projects/VC2010/resource.h<br>
-gs/lcms2/Projects/VC2010/testbed/testbed.vcproj<br>
-gs/lcms2/Projects/VC2010/testbed/testbed.vcxproj<br>
-gs/lcms2/Projects/VC2010/testbed/testbed.vcxproj.filters<br>
-gs/lcms2/Projects/VC2010/tiffdiff/tiffdiff.vcproj<br>
-gs/lcms2/Projects/VC2010/tiffdiff/tiffdiff.vcxproj<br>
-gs/lcms2/Projects/VC2010/tiffdiff/tiffdiff.vcxproj.filters<br>
-gs/lcms2/Projects/VC2010/tifficc/tifficc.vcproj<br>
-gs/lcms2/Projects/VC2010/tifficc/tifficc.vcxproj<br>
-gs/lcms2/Projects/VC2010/tifficc/tifficc.vcxproj.filters<br>
-gs/lcms2/Projects/VC2010/transicc/transicc.vcproj<br>
-gs/lcms2/Projects/VC2010/transicc/transicc.vcxproj<br>
-gs/lcms2/Projects/VC2010/transicc/transicc.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/jpegicc/jpegicc.vcproj<br>
-gs/lcms2/Projects/VC2012/jpegicc/jpegicc.vcxproj<br>
-gs/lcms2/Projects/VC2012/jpegicc/jpegicc.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/lcms2.rc<br>
-gs/lcms2/Projects/VC2012/lcms2.sln<br>
-gs/lcms2/Projects/VC2012/lcms2_DLL/lcms2_DLL.vcproj<br>
-gs/lcms2/Projects/VC2012/lcms2_DLL/lcms2_DLL.vcxproj<br>
-gs/lcms2/Projects/VC2012/lcms2_DLL/lcms2_DLL.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/lcms2_static/lcms2_static.vcproj<br>
-gs/lcms2/Projects/VC2012/lcms2_static/lcms2_static.vcxproj<br>
-gs/lcms2/Projects/VC2012/lcms2_static/lcms2_static.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/linkicc/linkicc.vcproj<br>
-gs/lcms2/Projects/VC2012/linkicc/linkicc.vcxproj<br>
-gs/lcms2/Projects/VC2012/linkicc/linkicc.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/psicc/psicc.vcproj<br>
-gs/lcms2/Projects/VC2012/psicc/psicc.vcxproj<br>
-gs/lcms2/Projects/VC2012/psicc/psicc.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/resource.h<br>
-gs/lcms2/Projects/VC2012/testbed/testbed.vcproj<br>
-gs/lcms2/Projects/VC2012/testbed/testbed.vcxproj<br>
-gs/lcms2/Projects/VC2012/testbed/testbed.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/tiffdiff/tiffdiff.vcproj<br>
-gs/lcms2/Projects/VC2012/tiffdiff/tiffdiff.vcxproj<br>
-gs/lcms2/Projects/VC2012/tiffdiff/tiffdiff.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/tifficc/tifficc.vcproj<br>
-gs/lcms2/Projects/VC2012/tifficc/tifficc.vcxproj<br>
-gs/lcms2/Projects/VC2012/tifficc/tifficc.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/transicc/transicc.vcproj<br>
-gs/lcms2/Projects/VC2012/transicc/transicc.vcxproj<br>
-gs/lcms2/Projects/VC2012/transicc/transicc.vcxproj.filters<br>
-gs/lcms2/Projects/cppcheck/lcms2.cppcheck<br>
-gs/lcms2/Projects/mac/._.DS_Store<br>
-gs/lcms2/Projects/mac/LittleCMS/._.DS_Store<br>
-gs/lcms2/Projects/mac/LittleCMS/English.lproj/InfoPlist.strings<br>
-gs/lcms2/Projects/mac/LittleCMS/Info.plist<br>
-gs/lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/mariama.mode1v3<br>
-gs/lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/mariama.pbxuser<br>
-gs/lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.pbxproj<br>
-gs/lcms2/Projects/mac/LittleCMS/LittleCMS_Prefix.pch<br>
-gs/lcms2/Projects/mac/LittleCMS/TestBed-Info.plist<br>
-gs/lcms2/README.1ST<br>
-gs/lcms2/aclocal.m4<br>
-gs/lcms2/autogen.sh<br>
-gs/lcms2/config.guess<br>
-gs/lcms2/config.sub<br>
-gs/lcms2/configure<br>
-gs/lcms2/configure.ac<br>
-gs/lcms2/depcomp<br>
-gs/lcms2/doc/LittleCMS2.6 API.pdf<br>
-gs/lcms2/doc/LittleCMS2.6 Plugin API.pdf<br>
-gs/lcms2/doc/LittleCMS2.6 tutorial.pdf<br>
-gs/lcms2/doc/src.zip<br>
-gs/lcms2/include/Makefile.am<br>
-gs/lcms2/include/Makefile.in<br>
-gs/lcms2/include/lcms2.h<br>
-gs/lcms2/include/lcms2_plugin.h<br>
-gs/lcms2/install-sh<br>
-gs/lcms2/lcms2.pc.in<br>
-gs/lcms2/ltmain.sh<br>
-gs/lcms2/m4/acx_pthread.m4<br>
-gs/lcms2/missing<br>
-gs/lcms2/src/Makefile.am<br>
-gs/lcms2/src/Makefile.in<br>
-gs/lcms2/src/cmscam02.c<br>
-gs/lcms2/src/cmscgats.c<br>
-gs/lcms2/src/cmscnvrt.c<br>
-gs/lcms2/src/cmserr.c<br>
-gs/lcms2/src/cmsgamma.c<br>
-gs/lcms2/src/cmsgmt.c<br>
-gs/lcms2/src/cmshalf.c<br>
-gs/lcms2/src/cmsintrp.c<br>
-gs/lcms2/src/cmsio0.c<br>
-gs/lcms2/src/cmsio1.c<br>
-gs/lcms2/src/cmslut.c<br>
-gs/lcms2/src/cmsmd5.c<br>
-gs/lcms2/src/cmsmtrx.c<br>
-gs/lcms2/src/cmsnamed.c<br>
-gs/lcms2/src/cmsopt.c<br>
-gs/lcms2/src/cmspack.c<br>
-gs/lcms2/src/cmspcs.c<br>
-gs/lcms2/src/cmsplugin.c<br>
-gs/lcms2/src/cmsps2.c<br>
-gs/lcms2/src/cmssamp.c<br>
-gs/lcms2/src/cmssm.c<br>
-gs/lcms2/src/cmstypes.c<br>
-gs/lcms2/src/cmsvirt.c<br>
-gs/lcms2/src/cmswtpnt.c<br>
-gs/lcms2/src/cmsxform.c<br>
-gs/lcms2/src/extra_xform.h<br>
-gs/lcms2/src/lcms2.def<br>
-gs/lcms2/src/lcms2_internal.h<br>
-gs/lcms2/testbed/Makefile.am<br>
-gs/lcms2/testbed/Makefile.in<br>
-gs/lcms2/testbed/bad.icc<br>
-gs/lcms2/testbed/ibm-t61.icc<br>
-gs/lcms2/testbed/new.icc<br>
-gs/lcms2/testbed/test1.icc<br>
-gs/lcms2/testbed/test2.icc<br>
-gs/lcms2/testbed/test3.icc<br>
-gs/lcms2/testbed/test4.icc<br>
-gs/lcms2/testbed/test5.icc<br>
-gs/lcms2/testbed/testcms2.c<br>
-gs/lcms2/testbed/testcms2.h<br>
-gs/lcms2/testbed/testplugin.c<br>
-gs/lcms2/testbed/testthread.cpp<br>
-gs/lcms2/testbed/toosmall.icc<br>
-gs/lcms2/testbed/zoo_icc.c<br>
-gs/lcms2/utils/common/utils.h<br>
-gs/lcms2/utils/common/vprf.c<br>
-gs/lcms2/utils/common/xgetopt.c<br>
-gs/lcms2/utils/delphi/delphidemo.dpr<br>
-gs/lcms2/utils/delphi/delphidemo.dproj<br>
-gs/lcms2/utils/delphi/delphidemo.res<br>
-gs/lcms2/utils/delphi/demo1.dfm<br>
-gs/lcms2/utils/delphi/demo1.pas<br>
-gs/lcms2/utils/delphi/lcms2.dll<br>
-gs/lcms2/utils/delphi/lcms2dll.pas<br>
-gs/lcms2/utils/jpgicc/Makefile.am<br>
-gs/lcms2/utils/jpgicc/Makefile.in<br>
-gs/lcms2/utils/jpgicc/iccjpeg.c<br>
-gs/lcms2/utils/jpgicc/iccjpeg.h<br>
-gs/lcms2/utils/jpgicc/jpgicc.1<br>
-gs/lcms2/utils/jpgicc/jpgicc.c<br>
-gs/lcms2/utils/linkicc/Makefile.am<br>
-gs/lcms2/utils/linkicc/Makefile.in<br>
-gs/lcms2/utils/linkicc/linkicc.1<br>
-gs/lcms2/utils/linkicc/linkicc.c<br>
-gs/lcms2/utils/matlab/icctrans.c<br>
-gs/lcms2/utils/matlab/lcms_rsp<br>
-gs/lcms2/utils/psicc/Makefile.am<br>
-gs/lcms2/utils/psicc/Makefile.in<br>
-gs/lcms2/utils/psicc/psicc.1<br>
-gs/lcms2/utils/psicc/psicc.c<br>
-gs/lcms2/utils/samples/Makefile.am<br>
-gs/lcms2/utils/samples/Makefile.in<br>
-gs/lcms2/utils/samples/itufax.c<br>
-gs/lcms2/utils/samples/mkcmy.c<br>
-gs/lcms2/utils/samples/mkgrayer.c<br>
-gs/lcms2/utils/samples/mktiff8.c<br>
-gs/lcms2/utils/samples/roundtrip.c<br>
-gs/lcms2/utils/samples/vericc.c<br>
-gs/lcms2/utils/samples/wtpt.1<br>
-gs/lcms2/utils/samples/wtpt.c<br>
-gs/lcms2/utils/tificc/Makefile.am<br>
-gs/lcms2/utils/tificc/Makefile.in<br>
-gs/lcms2/utils/tificc/tifdiff.c<br>
-gs/lcms2/utils/tificc/tificc.1<br>
-gs/lcms2/utils/tificc/tificc.c<br>
-gs/lcms2/utils/transicc/Makefile.am<br>
-gs/lcms2/utils/transicc/Makefile.in<br>
-gs/lcms2/utils/transicc/transicc.1<br>
-gs/lcms2/utils/transicc/transicc.c<br>
-gs/lib/EndOfTask.ps<br>
-gs/lib/FAPIconfig-FCO<br>
-gs/lib/FCOfontmap-PCLPS3<br>
-gs/lib/FCOfontmap-PS3<br>
-gs/lib/Fontmap.ATB<br>
-gs/lib/Fontmap.ATM<br>
-gs/lib/Fontmap.OS2<br>
-gs/lib/Fontmap.OSF<br>
-gs/lib/Fontmap.SGI<br>
-gs/lib/Fontmap.Sol<br>
-gs/lib/Fontmap.URW-136.T1<br>
-gs/lib/Fontmap.URW-136.TT<br>
-gs/lib/Fontmap.Ult<br>
-gs/lib/Fontmap.VMS<br>
-gs/lib/Info-macos.plist<br>
-gs/lib/PDFA_def.ps<br>
-gs/lib/PDFX_def.ps<br>
-gs/lib/acctest.ps<br>
-gs/lib/addxchar.ps<br>
-gs/lib/afmdiff.awk<br>
-gs/lib/align.ps<br>
-gs/lib/bj8.rpd<br>
-gs/lib/bj8gc12f.upp<br>
-gs/lib/bj8hg12f.upp<br>
-gs/lib/bj8oh06n.upp<br>
-gs/lib/bj8pa06n.upp<br>
-gs/lib/bj8pp12f.upp<br>
-gs/lib/bj8ts06n.upp<br>
-gs/lib/bjc610a0.upp<br>
-gs/lib/bjc610a1.upp<br>
-gs/lib/bjc610a2.upp<br>
-gs/lib/bjc610a3.upp<br>
-gs/lib/bjc610a4.upp<br>
-gs/lib/bjc610a5.upp<br>
-gs/lib/bjc610a6.upp<br>
-gs/lib/bjc610a7.upp<br>
-gs/lib/bjc610a8.upp<br>
-gs/lib/bjc610b1.upp<br>
-gs/lib/bjc610b2.upp<br>
-gs/lib/bjc610b3.upp<br>
-gs/lib/bjc610b4.upp<br>
-gs/lib/bjc610b6.upp<br>
-gs/lib/bjc610b7.upp<br>
-gs/lib/bjc610b8.upp<br>
-gs/lib/caption.ps<br>
-gs/lib/cat.ps<br>
-gs/lib/cbjc600.ppd<br>
-gs/lib/cbjc800.ppd<br>
-gs/lib/cdj550.upp<br>
-gs/lib/cdj690.upp<br>
-gs/lib/cdj690ec.upp<br>
-gs/lib/cid2code.ps<br>
-gs/lib/decrypt.ps<br>
-gs/lib/dnj750c.upp<br>
-gs/lib/dnj750m.upp<br>
-gs/lib/docie.ps<br>
-gs/lib/dvipdf<br>
-gs/lib/eps2eps<br>
-gs/lib/eps2eps.bat<br>
-gs/lib/eps2eps.cmd<br>
-gs/lib/font2c<br>
-gs/lib/font2c.bat<br>
-gs/lib/font2c.cmd<br>
-gs/lib/font2c.ps<br>
-gs/lib/font2pcl.ps<br>
-gs/lib/ghostpdf.README<br>
-gs/lib/ghostpdf.cat<br>
-gs/lib/ghostpdf.inf<br>
-gs/lib/ghostpdf.ppd<br>
-gs/lib/gs_ce_e.ps<br>
-gs/lib/gs_cmdl.ps<br>
-gs/lib/gs_il2_e.ps<br>
-gs/lib/gs_kanji.ps<br>
-gs/lib/gs_ksb_e.ps<br>
-gs/lib/gs_l.xbm<br>
-gs/lib/gs_l.xpm<br>
-gs/lib/gs_l_m.xbm<br>
-gs/lib/gs_lgo_e.ps<br>
-gs/lib/gs_lgx_e.ps<br>
-gs/lib/gs_m.xbm<br>
-gs/lib/gs_m.xpm<br>
-gs/lib/gs_m_m.xbm<br>
-gs/lib/gs_pfile.ps<br>
-gs/lib/gs_rdlin.ps<br>
-gs/lib/gs_s.xbm<br>
-gs/lib/gs_s.xpm<br>
-gs/lib/gs_s_m.xbm<br>
-gs/lib/gs_t.xbm<br>
-gs/lib/gs_t.xpm<br>
-gs/lib/gs_t_m.xbm<br>
-gs/lib/gs_wl1_e.ps<br>
-gs/lib/gs_wl2_e.ps<br>
-gs/lib/gs_wl5_e.ps<br>
-gs/lib/gsbj<br>
-gs/lib/gsbj.bat<br>
-gs/lib/gsdj<br>
-gs/lib/gsdj.bat<br>
-gs/lib/gsdj500<br>
-gs/lib/gsdj500.bat<br>
-gs/lib/gslj<br>
-gs/lib/gslj.bat<br>
-gs/lib/gslp<br>
-gs/lib/gslp.bat<br>
-gs/lib/gslp.ps<br>
-gs/lib/gsnd<br>
-gs/lib/gsnd.bat<br>
-gs/lib/gsndt.bat<br>
-gs/lib/gsnup.ps<br>
-gs/lib/gssetgs.bat<br>
-gs/lib/gssetgs32.bat<br>
-gs/lib/gssetgs64.bat<br>
-gs/lib/gst.bat<br>
-gs/lib/gstt.bat<br>
-gs/lib/ht_ccsto.ps<br>
-gs/lib/image-qa.ps<br>
-gs/lib/impath.ps<br>
-gs/lib/jispaper.ps<br>
-gs/lib/jobseparator.ps<br>
-gs/lib/landscap.ps<br>
-gs/lib/level1.ps<br>
-gs/lib/lines.ps<br>
-gs/lib/lp386.bat<br>
-gs/lib/lp386r2.bat<br>
-gs/lib/lpgs.bat<br>
-gs/lib/lpr2.bat<br>
-gs/lib/lprsetup.sh<br>
-gs/lib/markhint.ps<br>
-gs/lib/markpath.ps<br>
-gs/lib/mkcidfm.ps<br>
-gs/lib/necp2x.upp<br>
-gs/lib/necp2x6.upp<br>
-gs/lib/opdfread.ps<br>
-gs/lib/packfile.ps<br>
-gs/lib/pcharstr.ps<br>
-gs/lib/pdf2dsc<br>
-gs/lib/pdf2dsc.bat<br>
-gs/lib/pdf2dsc.ps<br>
-gs/lib/pdf2ps<br>
-gs/lib/pdf2ps.bat<br>
-gs/lib/pdf2ps.cmd<br>
-gs/lib/pdfwrite.ps<br>
-gs/lib/pf2afm<br>
-gs/lib/pf2afm.bat<br>
-gs/lib/pf2afm.cmd<br>
-gs/lib/pf2afm.ps<br>
-gs/lib/pfbtopfa<br>
-gs/lib/pfbtopfa.bat<br>
-gs/lib/pfbtopfa.ps<br>
-gs/lib/pftogsf.bat<br>
-gs/lib/ppath.ps<br>
-gs/lib/pphs<br>
-gs/lib/pphs.ps<br>
-gs/lib/prfont.ps<br>
-gs/lib/printafm<br>
-gs/lib/printafm.ps<br>
-gs/lib/ps2ai.ps<br>
-gs/lib/ps2ascii<br>
-gs/lib/ps2ascii.bat<br>
-gs/lib/ps2ascii.cmd<br>
-gs/lib/ps2ascii.ps<br>
-gs/lib/ps2epsi<br>
-gs/lib/ps2epsi.bat<br>
-gs/lib/ps2epsi.cmd<br>
-gs/lib/ps2epsi.ps<br>
-gs/lib/ps2pdf<br>
-gs/lib/ps2pdf.bat<br>
-gs/lib/ps2pdf.cmd<br>
-gs/lib/ps2pdf12<br>
-gs/lib/ps2pdf12.bat<br>
-gs/lib/ps2pdf12.cmd<br>
-gs/lib/ps2pdf13<br>
-gs/lib/ps2pdf13.bat<br>
-gs/lib/ps2pdf13.cmd<br>
-gs/lib/ps2pdf14<br>
-gs/lib/ps2pdf14.bat<br>
-gs/lib/ps2pdf14.cmd<br>
-gs/lib/ps2pdfwr<br>
-gs/lib/ps2pdfxx.bat<br>
-gs/lib/ps2ps<br>
-gs/lib/ps2ps.bat<br>
-gs/lib/ps2ps.cmd<br>
-gs/lib/ps2ps2<br>
-gs/lib/ps2ps2.bat<br>
-gs/lib/ps2ps2.cmd<br>
-gs/lib/quit.ps<br>
-gs/lib/ras1.upp<br>
-gs/lib/ras24.upp<br>
-gs/lib/ras3.upp<br>
-gs/lib/ras32.upp<br>
-gs/lib/ras4.upp<br>
-gs/lib/ras8m.upp<br>
-gs/lib/rinkj-2200-setup<br>
-gs/lib/rollconv.ps<br>
-gs/lib/showchar.ps<br>
-gs/lib/showpage.ps<br>
-gs/lib/st640ih.upp<br>
-gs/lib/st640ihg.upp<br>
-gs/lib/st640p.upp<br>
-gs/lib/st640pg.upp<br>
-gs/lib/st640pl.upp<br>
-gs/lib/st640plg.upp<br>
-gs/lib/stc.upp<br>
-gs/lib/stc1520h.upp<br>
-gs/lib/stc2.upp<br>
-gs/lib/stc200_h.upp<br>
-gs/lib/stc2_h.upp<br>
-gs/lib/stc2s_h.upp<br>
-gs/lib/stc300.upp<br>
-gs/lib/stc300bl.upp<br>
-gs/lib/stc300bm.upp<br>
-gs/lib/stc500p.upp<br>
-gs/lib/stc500ph.upp<br>
-gs/lib/stc600ih.upp<br>
-gs/lib/stc600p.upp<br>
-gs/lib/stc600pl.upp<br>
-gs/lib/stc640p.upp<br>
-gs/lib/stc800ih.upp<br>
-gs/lib/stc800p.upp<br>
-gs/lib/stc800pl.upp<br>
-gs/lib/stc_h.upp<br>
-gs/lib/stc_l.upp<br>
-gs/lib/stcany.upp<br>
-gs/lib/stcany_h.upp<br>
-gs/lib/stcinfo.ps<br>
-gs/lib/stcolor.ps<br>
-gs/lib/stocht.ps<br>
-gs/lib/traceimg.ps<br>
-gs/lib/traceop.ps<br>
-gs/lib/type1enc.ps<br>
-gs/lib/type1ops.ps<br>
-gs/lib/uninfo.ps<br>
-gs/lib/unix-lpr.sh<br>
-gs/lib/unprot.ps<br>
-gs/lib/viewcmyk.ps<br>
-gs/lib/viewgif.ps<br>
-gs/lib/viewjpeg.ps<br>
-gs/lib/viewmiff.ps<br>
-gs/lib/viewpbm.ps<br>
-gs/lib/viewpcx.ps<br>
-gs/lib/viewps2a.ps<br>
-gs/lib/viewraw.ps<br>
-gs/lib/viewrgb.ps<br>
-gs/lib/wftopfa<br>
-gs/lib/wftopfa.ps<br>
-gs/lib/winmaps.ps<br>
-gs/lib/wmakebat.bat<br>
-gs/lib/wrfont.ps<br>
-gs/lib/zeroline.ps<br>
-gs/libpng/ANNOUNCE<br>
-gs/libpng/CHANGES<br>
-gs/libpng/CMakeLists.txt<br>
-gs/libpng/INSTALL<br>
-gs/libpng/LICENSE<br>
-gs/libpng/Makefile.am<br>
-gs/libpng/Makefile.in<br>
-gs/libpng/README<br>
-gs/libpng/TODO<br>
-gs/libpng/aclocal.m4<br>
-gs/libpng/arm/arm_init.c<br>
-gs/libpng/arm/filter_neon.S<br>
-gs/libpng/arm/filter_neon_intrinsics.c<br>
-gs/libpng/autogen.sh<br>
-gs/libpng/compile<br>
-gs/libpng/config.guess<br>
-gs/libpng/config.h.in<br>
-gs/libpng/config.sub<br>
-gs/libpng/configure<br>
-gs/libpng/configure.ac<br>
-gs/libpng/contrib/README.txt<br>
-gs/libpng/contrib/arm-neon/README<br>
-gs/libpng/contrib/arm-neon/android-ndk.c<br>
-gs/libpng/contrib/arm-neon/linux-auxv.c<br>
-gs/libpng/contrib/arm-neon/linux.c<br>
-gs/libpng/contrib/conftest/README<br>
-gs/libpng/contrib/conftest/read.dfa<br>
-gs/libpng/contrib/conftest/s_read.dfa<br>
-gs/libpng/contrib/conftest/s_write.dfa<br>
-gs/libpng/contrib/conftest/simple.dfa<br>
-gs/libpng/contrib/conftest/write.dfa<br>
-gs/libpng/contrib/examples/README.txt<br>
-gs/libpng/contrib/examples/iccfrompng.c<br>
-gs/libpng/contrib/examples/pngpixel.c<br>
-gs/libpng/contrib/examples/pngtopng.c<br>
-gs/libpng/contrib/gregbook/COPYING<br>
-gs/libpng/contrib/gregbook/LICENSE<br>
-gs/libpng/contrib/gregbook/Makefile.mingw32<br>
-gs/libpng/contrib/gregbook/Makefile.sgi<br>
-gs/libpng/contrib/gregbook/Makefile.unx<br>
-gs/libpng/contrib/gregbook/Makefile.w32<br>
-gs/libpng/contrib/gregbook/README<br>
-gs/libpng/contrib/gregbook/makevms.com<br>
-gs/libpng/contrib/gregbook/readpng.c<br>
-gs/libpng/contrib/gregbook/readpng.h<br>
-gs/libpng/contrib/gregbook/readpng2.c<br>
-gs/libpng/contrib/gregbook/readpng2.h<br>
-gs/libpng/contrib/gregbook/readppm.c<br>
-gs/libpng/contrib/gregbook/rpng-win.c<br>
-gs/libpng/contrib/gregbook/rpng-x.c<br>
-gs/libpng/contrib/gregbook/rpng2-win.c<br>
-gs/libpng/contrib/gregbook/rpng2-x.c<br>
-gs/libpng/contrib/gregbook/toucan.png<br>
-gs/libpng/contrib/gregbook/wpng.c<br>
-gs/libpng/contrib/gregbook/writepng.c<br>
-gs/libpng/contrib/gregbook/writepng.h<br>
-gs/libpng/contrib/libtests/fakepng.c<br>
-gs/libpng/contrib/libtests/gentests.sh<br>
-gs/libpng/contrib/libtests/makepng.c<br>
-gs/libpng/contrib/libtests/pngimage.c<br>
-gs/libpng/contrib/libtests/pngstest.c<br>
-gs/libpng/contrib/libtests/pngunknown.c<br>
-gs/libpng/contrib/libtests/pngvalid.c<br>
-gs/libpng/contrib/libtests/readpng.c<br>
-gs/libpng/contrib/libtests/tarith.c<br>
-gs/libpng/contrib/libtests/timepng.c<br>
-gs/libpng/contrib/pngminim/README<br>
-gs/libpng/contrib/pngminim/decoder/README<br>
-gs/libpng/contrib/pngminim/decoder/makefile<br>
-gs/libpng/contrib/pngminim/decoder/pngusr.dfa<br>
-gs/libpng/contrib/pngminim/decoder/pngusr.h<br>
-gs/libpng/contrib/pngminim/encoder/README<br>
-gs/libpng/contrib/pngminim/encoder/makefile<br>
-gs/libpng/contrib/pngminim/encoder/pngusr.dfa<br>
-gs/libpng/contrib/pngminim/encoder/pngusr.h<br>
-gs/libpng/contrib/pngminim/preader/README<br>
-gs/libpng/contrib/pngminim/preader/makefile<br>
-gs/libpng/contrib/pngminim/preader/pngusr.dfa<br>
-gs/libpng/contrib/pngminim/preader/pngusr.h<br>
-gs/libpng/contrib/pngminus/README<br>
-gs/libpng/contrib/pngminus/makefile.std<br>
-gs/libpng/contrib/pngminus/makefile.tc3<br>
-gs/libpng/contrib/pngminus/makevms.com<br>
-gs/libpng/contrib/pngminus/png2pnm.bat<br>
-gs/libpng/contrib/pngminus/png2pnm.c<br>
-gs/libpng/contrib/pngminus/png2pnm.sh<br>
-gs/libpng/contrib/pngminus/pngminus.bat<br>
-gs/libpng/contrib/pngminus/pngminus.sh<br>
-gs/libpng/contrib/pngminus/pnm2png.bat<br>
-gs/libpng/contrib/pngminus/pnm2png.c<br>
-gs/libpng/contrib/pngminus/pnm2png.sh<br>
-gs/libpng/contrib/pngsuite/README<br>
-gs/libpng/contrib/pngsuite/basn0g01.png<br>
-gs/libpng/contrib/pngsuite/basn0g02.png<br>
-gs/libpng/contrib/pngsuite/basn0g04.png<br>
-gs/libpng/contrib/pngsuite/basn0g08.png<br>
-gs/libpng/contrib/pngsuite/basn0g16.png<br>
-gs/libpng/contrib/pngsuite/basn2c08.png<br>
-gs/libpng/contrib/pngsuite/basn2c16.png<br>
-gs/libpng/contrib/pngsuite/basn3p01.png<br>
-gs/libpng/contrib/pngsuite/basn3p02.png<br>
-gs/libpng/contrib/pngsuite/basn3p04.png<br>
-gs/libpng/contrib/pngsuite/basn3p08.png<br>
-gs/libpng/contrib/pngsuite/basn4a08.png<br>
-gs/libpng/contrib/pngsuite/basn4a16.png<br>
-gs/libpng/contrib/pngsuite/basn6a08.png<br>
-gs/libpng/contrib/pngsuite/basn6a16.png<br>
-gs/libpng/contrib/pngsuite/ftbbn0g01.png<br>
-gs/libpng/contrib/pngsuite/ftbbn0g02.png<br>
-gs/libpng/contrib/pngsuite/ftbbn0g04.png<br>
-gs/libpng/contrib/pngsuite/ftbbn2c16.png<br>
-gs/libpng/contrib/pngsuite/ftbbn3p08.png<br>
-gs/libpng/contrib/pngsuite/ftbgn2c16.png<br>
-gs/libpng/contrib/pngsuite/ftbgn3p08.png<br>
-gs/libpng/contrib/pngsuite/ftbrn2c08.png<br>
-gs/libpng/contrib/pngsuite/ftbwn0g16.png<br>
-gs/libpng/contrib/pngsuite/ftbwn3p08.png<br>
-gs/libpng/contrib/pngsuite/ftbyn3p08.png<br>
-gs/libpng/contrib/pngsuite/ftp0n0g08.png<br>
-gs/libpng/contrib/pngsuite/ftp0n2c08.png<br>
-gs/libpng/contrib/pngsuite/ftp0n3p08.png<br>
-gs/libpng/contrib/pngsuite/ftp1n3p08.png<br>
-gs/libpng/contrib/tools/README.txt<br>
-gs/libpng/contrib/tools/checksum-icc.c<br>
-gs/libpng/contrib/tools/chkfmt<br>
-gs/libpng/contrib/tools/cvtcolor.c<br>
-gs/libpng/contrib/tools/intgamma.sh<br>
-gs/libpng/contrib/tools/makesRGB.c<br>
-gs/libpng/contrib/tools/png-fix-itxt.c<br>
-gs/libpng/contrib/tools/pngfix.c<br>
-gs/libpng/contrib/tools/sRGB.h<br>
-gs/libpng/contrib/visupng/PngFile.c<br>
-gs/libpng/contrib/visupng/PngFile.h<br>
-gs/libpng/contrib/visupng/README.txt<br>
-gs/libpng/contrib/visupng/VisualPng.c<br>
-gs/libpng/contrib/visupng/VisualPng.dsp<br>
-gs/libpng/contrib/visupng/VisualPng.dsw<br>
-gs/libpng/contrib/visupng/VisualPng.ico<br>
-gs/libpng/contrib/visupng/VisualPng.png<br>
-gs/libpng/contrib/visupng/VisualPng.rc<br>
-gs/libpng/contrib/visupng/cexcept.h<br>
-gs/libpng/contrib/visupng/resource.h<br>
-gs/libpng/depcomp<br>
-gs/libpng/example.c<br>
-gs/libpng/install-sh<br>
-gs/libpng/libpng-config.in<br>
-gs/libpng/libpng-manual.txt<br>
-gs/libpng/libpng.3<br>
-gs/libpng/libpng.pc.in<br>
-gs/libpng/libpngpf.3<br>
-gs/libpng/ltmain.sh<br>
-gs/libpng/missing<br>
-gs/libpng/png.5<br>
-gs/libpng/png.c<br>
-gs/libpng/png.h<br>
-gs/libpng/pngbar.jpg<br>
-gs/libpng/pngbar.png<br>
-gs/libpng/pngconf.h<br>
-gs/libpng/pngdebug.h<br>
-gs/libpng/pngerror.c<br>
-gs/libpng/pngget.c<br>
-gs/libpng/pnginfo.h<br>
-gs/libpng/pngmem.c<br>
-gs/libpng/pngnow.png<br>
-gs/libpng/pngpread.c<br>
-gs/libpng/pngpriv.h<br>
-gs/libpng/pngread.c<br>
-gs/libpng/pngrio.c<br>
-gs/libpng/pngrtran.c<br>
-gs/libpng/pngrutil.c<br>
-gs/libpng/pngset.c<br>
-gs/libpng/pngstruct.h<br>
-gs/libpng/pngtest.c<br>
-gs/libpng/pngtest.png<br>
-gs/libpng/pngtrans.c<br>
-gs/libpng/pngusr.dfa<br>
-gs/libpng/pngwio.c<br>
-gs/libpng/pngwrite.c<br>
-gs/libpng/pngwtran.c<br>
-gs/libpng/pngwutil.c<br>
-gs/libpng/projects/owatcom/libpng.tgt<br>
-gs/libpng/projects/owatcom/libpng.wpj<br>
-gs/libpng/projects/owatcom/pngconfig.mak<br>
-gs/libpng/projects/owatcom/pngstest.tgt<br>
-gs/libpng/projects/owatcom/pngtest.tgt<br>
-gs/libpng/projects/owatcom/pngvalid.tgt<br>
-gs/libpng/projects/visualc71/PRJ0041.mak<br>
-gs/libpng/projects/visualc71/README.txt<br>
-gs/libpng/projects/visualc71/README_zlib.txt<br>
-gs/libpng/projects/visualc71/libpng.sln<br>
-gs/libpng/projects/visualc71/libpng.vcproj<br>
-gs/libpng/projects/visualc71/pngtest.vcproj<br>
-gs/libpng/projects/visualc71/zlib.vcproj<br>
-gs/libpng/projects/vstudio/WARNING<br>
-gs/libpng/projects/vstudio/libpng/libpng.vcxproj<br>
-gs/libpng/projects/vstudio/pnglibconf/pnglibconf.vcxproj<br>
-gs/libpng/projects/vstudio/pngstest/pngstest.vcxproj<br>
-gs/libpng/projects/vstudio/pngtest/pngtest.vcxproj<br>
-gs/libpng/projects/vstudio/pngunknown/pngunknown.vcxproj<br>
-gs/libpng/projects/vstudio/pngvalid/pngvalid.vcxproj<br>
-gs/libpng/projects/vstudio/readme.txt<br>
-gs/libpng/projects/vstudio/vstudio.sln<br>
-gs/libpng/projects/vstudio/zlib.props<br>
-gs/libpng/projects/vstudio/zlib/zlib.vcxproj<br>
-gs/libpng/scripts/README.txt<br>
-gs/libpng/scripts/SCOPTIONS.ppc<br>
-gs/libpng/scripts/checksym.awk<br>
-gs/libpng/scripts/def.c<br>
-gs/libpng/scripts/descrip.mms<br>
-gs/libpng/scripts/dfn.awk<br>
-gs/libpng/scripts/intprefix.c<br>
-gs/libpng/scripts/libpng-config-body.in<br>
-gs/libpng/scripts/libpng-config-head.in<br>
-gs/libpng/scripts/libpng.pc.in<br>
-gs/libpng/scripts/libtool.m4<br>
-gs/libpng/scripts/ltoptions.m4<br>
-gs/libpng/scripts/ltsugar.m4<br>
-gs/libpng/scripts/ltversion.m4<br>
-gs/libpng/scripts/lt~obsolete.m4<br>
-gs/libpng/scripts/macro.lst<br>
-gs/libpng/scripts/makefile.32sunu<br>
-gs/libpng/scripts/makefile.64sunu<br>
-gs/libpng/scripts/makefile.acorn<br>
-gs/libpng/scripts/makefile.aix<br>
-gs/libpng/scripts/makefile.amiga<br>
-gs/libpng/scripts/makefile.atari<br>
-gs/libpng/scripts/makefile.bc32<br>
-gs/libpng/scripts/makefile.beos<br>
-gs/libpng/scripts/makefile.bor<br>
-gs/libpng/scripts/makefile.cegcc<br>
-gs/libpng/scripts/makefile.darwin<br>
-gs/libpng/scripts/makefile.dec<br>
-gs/libpng/scripts/makefile.dj2<br>
-gs/libpng/scripts/makefile.freebsd<br>
-gs/libpng/scripts/makefile.gcc<br>
-gs/libpng/scripts/makefile.hp64<br>
-gs/libpng/scripts/makefile.hpgcc<br>
-gs/libpng/scripts/makefile.hpux<br>
-gs/libpng/scripts/makefile.ibmc<br>
-gs/libpng/scripts/makefile.intel<br>
-gs/libpng/scripts/makefile.knr<br>
-gs/libpng/scripts/makefile.linux<br>
-gs/libpng/scripts/makefile.mips<br>
-gs/libpng/scripts/makefile.msc<br>
-gs/libpng/scripts/makefile.msys<br>
-gs/libpng/scripts/makefile.ne12bsd<br>
-gs/libpng/scripts/makefile.netbsd<br>
-gs/libpng/scripts/makefile.openbsd<br>
-gs/libpng/scripts/makefile.sco<br>
-gs/libpng/scripts/makefile.sggcc<br>
-gs/libpng/scripts/makefile.sgi<br>
-gs/libpng/scripts/makefile.so9<br>
-gs/libpng/scripts/makefile.solaris<br>
-gs/libpng/scripts/makefile.solaris-x86<br>
-gs/libpng/scripts/makefile.std<br>
-gs/libpng/scripts/makefile.sunos<br>
-gs/libpng/scripts/makefile.tc3<br>
-gs/libpng/scripts/makefile.vcwin32<br>
-gs/libpng/scripts/makevms.com<br>
-gs/libpng/scripts/options.awk<br>
-gs/libpng/scripts/pnglibconf.dfa<br>
-gs/libpng/scripts/pnglibconf.h.prebuilt<br>
-gs/libpng/scripts/pnglibconf.mak<br>
-gs/libpng/scripts/pngwin.rc<br>
-gs/libpng/scripts/prefix.c<br>
-gs/libpng/scripts/smakefile.ppc<br>
-gs/libpng/scripts/sym.c<br>
-gs/libpng/scripts/symbols.c<br>
-gs/libpng/scripts/symbols.def<br>
-gs/libpng/scripts/vers.c<br>
-gs/libpng/test-driver<br>
-gs/libpng/tests/pngimage-full<br>
-gs/libpng/tests/pngimage-quick<br>
-gs/libpng/tests/pngstest<br>
-gs/libpng/tests/pngstest-0g01<br>
-gs/libpng/tests/pngstest-0g02<br>
-gs/libpng/tests/pngstest-0g04<br>
-gs/libpng/tests/pngstest-0g08<br>
-gs/libpng/tests/pngstest-0g16<br>
-gs/libpng/tests/pngstest-2c08<br>
-gs/libpng/tests/pngstest-2c16<br>
-gs/libpng/tests/pngstest-3p01<br>
-gs/libpng/tests/pngstest-3p02<br>
-gs/libpng/tests/pngstest-3p04<br>
-gs/libpng/tests/pngstest-3p08<br>
-gs/libpng/tests/pngstest-4a08<br>
-gs/libpng/tests/pngstest-4a16<br>
-gs/libpng/tests/pngstest-6a08<br>
-gs/libpng/tests/pngstest-6a16<br>
-gs/libpng/tests/pngstest-error<br>
-gs/libpng/tests/pngtest<br>
-gs/libpng/tests/pngunknown-IDAT<br>
-gs/libpng/tests/pngunknown-discard<br>
-gs/libpng/tests/pngunknown-if-safe<br>
-gs/libpng/tests/pngunknown-sAPI<br>
-gs/libpng/tests/pngunknown-sTER<br>
-gs/libpng/tests/pngunknown-save<br>
-gs/libpng/tests/pngunknown-vpAg<br>
-gs/libpng/tests/pngvalid-gamma-16-to-8<br>
-gs/libpng/tests/pngvalid-gamma-alpha-mode<br>
-gs/libpng/tests/pngvalid-gamma-background<br>
-gs/libpng/tests/pngvalid-gamma-expand16-alpha-mode<br>
-gs/libpng/tests/pngvalid-gamma-expand16-background<br>
-gs/libpng/tests/pngvalid-gamma-expand16-transform<br>
-gs/libpng/tests/pngvalid-gamma-sbit<br>
-gs/libpng/tests/pngvalid-gamma-threshold<br>
-gs/libpng/tests/pngvalid-gamma-transform<br>
-gs/libpng/tests/pngvalid-progressive-interlace-size<br>
-gs/libpng/tests/pngvalid-progressive-interlace-standard<br>
-gs/libpng/tests/pngvalid-progressive-interlace-transform<br>
-gs/libpng/tests/pngvalid-progressive-standard<br>
-gs/libpng/tests/pngvalid-standard<br>
-gs/man/de/dvipdf.1<br>
-gs/man/de/font2c.1<br>
-gs/man/de/gsnd.1<br>
-gs/man/de/pdf2dsc.1<br>
-gs/man/de/pdf2ps.1<br>
-gs/man/de/printafm.1<br>
-gs/man/de/ps2ascii.1<br>
-gs/man/de/ps2pdf.1<br>
-gs/man/de/ps2ps.1<br>
-gs/man/de/wftopfa.1<br>
-gs/man/dvipdf.1<br>
-gs/man/eps2eps.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-gs/openjpeg/AUTHORS<br>
-gs/openjpeg/CHANGES<br>
-gs/openjpeg/LICENSE<br>
-gs/openjpeg/NEWS<br>
-gs/openjpeg/THANKS<br>
-gs/openjpeg/src/lib/openjp2/CMakeLists.txt<br>
-gs/openjpeg/src/lib/openjp2/bio.c<br>
-gs/openjpeg/src/lib/openjp2/bio.h<br>
-gs/openjpeg/src/lib/openjp2/cidx_manager.c<br>
-gs/openjpeg/src/lib/openjp2/cidx_manager.h<br>
-gs/openjpeg/src/lib/openjp2/cio.c<br>
-gs/openjpeg/src/lib/openjp2/cio.h<br>
-gs/openjpeg/src/lib/openjp2/dwt.c<br>
-gs/openjpeg/src/lib/openjp2/dwt.h<br>
-gs/openjpeg/src/lib/openjp2/event.c<br>
-gs/openjpeg/src/lib/openjp2/event.h<br>
-gs/openjpeg/src/lib/openjp2/function_list.c<br>
-gs/openjpeg/src/lib/openjp2/function_list.h<br>
-gs/openjpeg/src/lib/openjp2/image.c<br>
-gs/openjpeg/src/lib/openjp2/image.h<br>
-gs/openjpeg/src/lib/openjp2/indexbox_manager.h<br>
-gs/openjpeg/src/lib/openjp2/invert.c<br>
-gs/openjpeg/src/lib/openjp2/invert.h<br>
-gs/openjpeg/src/lib/openjp2/j2k.c<br>
-gs/openjpeg/src/lib/openjp2/j2k.h<br>
-gs/openjpeg/src/lib/openjp2/jp2.c<br>
-gs/openjpeg/src/lib/openjp2/jp2.h<br>
-gs/openjpeg/src/lib/openjp2/libopenjp2.pc.cmake.in<br>
-gs/openjpeg/src/lib/openjp2/mct.c<br>
-gs/openjpeg/src/lib/openjp2/mct.h<br>
-gs/openjpeg/src/lib/openjp2/mqc.c<br>
-gs/openjpeg/src/lib/openjp2/mqc.h<br>
-gs/openjpeg/src/lib/openjp2/openjpeg.c<br>
-gs/openjpeg/src/lib/openjp2/openjpeg.h<br>
-gs/openjpeg/src/lib/openjp2/opj_clock.c<br>
-gs/openjpeg/src/lib/openjp2/opj_clock.h<br>
-gs/openjpeg/src/lib/openjp2/opj_codec.h<br>
-gs/openjpeg/src/lib/openjp2/opj_config.h<br>
-gs/openjpeg/src/lib/openjp2/opj_config.h.cmake.in<br>
-gs/openjpeg/src/lib/openjp2/opj_config_private.h<br>
-gs/openjpeg/src/lib/openjp2/opj_config_private.h.cmake.in<br>
-gs/openjpeg/src/lib/openjp2/opj_includes.h<br>
-gs/openjpeg/src/lib/openjp2/opj_intmath.h<br>
-gs/openjpeg/src/lib/openjp2/opj_inttypes.h<br>
-gs/openjpeg/src/lib/openjp2/opj_malloc.h<br>
-gs/openjpeg/src/lib/openjp2/opj_stdint.h<br>
-gs/openjpeg/src/lib/openjp2/phix_manager.c<br>
-gs/openjpeg/src/lib/openjp2/pi.c<br>
-gs/openjpeg/src/lib/openjp2/pi.h<br>
-gs/openjpeg/src/lib/openjp2/ppix_manager.c<br>
-gs/openjpeg/src/lib/openjp2/raw.c<br>
-gs/openjpeg/src/lib/openjp2/raw.h<br>
-gs/openjpeg/src/lib/openjp2/t1.c<br>
-gs/openjpeg/src/lib/openjp2/t1.h<br>
-gs/openjpeg/src/lib/openjp2/t1_generate_luts.c<br>
-gs/openjpeg/src/lib/openjp2/t1_luts.h<br>
-gs/openjpeg/src/lib/openjp2/t2.c<br>
-gs/openjpeg/src/lib/openjp2/t2.h<br>
-gs/openjpeg/src/lib/openjp2/tcd.c<br>
-gs/openjpeg/src/lib/openjp2/tcd.h<br>
-gs/openjpeg/src/lib/openjp2/tgt.c<br>
-gs/openjpeg/src/lib/openjp2/tgt.h<br>
-gs/openjpeg/src/lib/openjp2/thix_manager.c<br>
-gs/openjpeg/src/lib/openjp2/tpix_manager.c<br>
-gs/psi/apitest.c<br>
-gs/psi/bfont.h<br>
-gs/psi/btoken.h<br>
-gs/psi/dmmain.c<br>
-gs/psi/dmmain.r<br>
-gs/psi/dpmain.c<br>
-gs/psi/dscparse.c<br>
-gs/psi/dscparse.h<br>
-gs/psi/dstack.h<br>
-gs/psi/dw32c.def<br>
-gs/psi/dw64c.def<br>
-gs/psi/dwdll.c<br>
-gs/psi/dwdll.h<br>
-gs/psi/dwimg.c<br>
-gs/psi/dwimg.h<br>
-gs/psi/dwmain.c<br>
-gs/psi/dwmain.rc<br>
-gs/psi/dwmain32.def<br>
-gs/psi/dwmain64.def<br>
-gs/psi/dwmainc.c<br>
-gs/psi/dwnodll.c<br>
-gs/psi/dwreg.c<br>
-gs/psi/dwreg.h<br>
-gs/psi/dwres.h<br>
-gs/psi/dwsetup.def<br>
-gs/psi/dwsetup_x64.manifest<br>
-gs/psi/dwsetup_x86.manifest<br>
-gs/psi/dwtext.c<br>
-gs/psi/dwtext.h<br>
-gs/psi/dwtrace.c<br>
-gs/psi/dwtrace.h<br>
-gs/psi/dwuninst.def<br>
-gs/psi/dwuninst_x64.manifest<br>
-gs/psi/dwuninst_x86.manifest<br>
-gs/psi/dxmain.c<br>
-gs/psi/dxmainc.c<br>
-gs/psi/estack.h<br>
-gs/psi/files.h<br>
-gs/psi/ghost.h<br>
-gs/psi/gs.c<br>
-gs/psi/gsdll.c<br>
-gs/psi/gsdll2.def<br>
-gs/psi/gsdll2.rc<br>
-gs/psi/gsdll32.def<br>
-gs/psi/gsdll32.rc<br>
-gs/psi/gsdll32metro.def<br>
-gs/psi/gsdll32w.lnk<br>
-gs/psi/gsdll64.def<br>
-gs/psi/gsdll64metro.def<br>
-gs/psi/gsdllARM32metro.def<br>
-gs/psi/gserver.c<br>
-gs/psi/gsos2.def<br>
-gs/psi/gsos2.icx<br>
-gs/psi/gsos2.rc<br>
-gs/psi/ialloc.c<br>
-gs/psi/ialloc.h<br>
-gs/psi/iapi.c<br>
-gs/psi/iapi.h<br>
-gs/psi/iastate.h<br>
-gs/psi/iastruct.h<br>
-gs/psi/ibnum.c<br>
-gs/psi/ibnum.h<br>
-gs/psi/ichar.h<br>
-gs/psi/ichar1.h<br>
-gs/psi/icharout.h<br>
-gs/psi/icid.h<br>
-gs/psi/icie.h<br>
-gs/psi/icolor.h<br>
-gs/psi/iconf.c<br>
-gs/psi/iconf.h<br>
-gs/psi/icontext.c<br>
-gs/psi/icontext.h<br>
-gs/psi/icremap.h<br>
-gs/psi/icsmap.h<br>
-gs/psi/icstate.h<br>
-gs/psi/iddict.h<br>
-gs/psi/iddstack.h<br>
-gs/psi/idebug.c<br>
-gs/psi/idebug.h<br>
-gs/psi/idict.c<br>
-gs/psi/idict.h<br>
-gs/psi/idictdef.h<br>
-gs/psi/idicttpl.h<br>
-gs/psi/idisp.c<br>
-gs/psi/idisp.h<br>
-gs/psi/idosave.h<br>
-gs/psi/idparam.c<br>
-gs/psi/idparam.h<br>
-gs/psi/idsdata.h<br>
-gs/psi/idstack.c<br>
-gs/psi/idstack.h<br>
-gs/psi/ierrors.h<br>
-gs/psi/iesdata.h<br>
-gs/psi/iestack.h<br>
-gs/psi/ifapi.h<br>
-gs/psi/ifcid.h<br>
-gs/psi/ifilter.h<br>
-gs/psi/ifilter2.h<br>
-gs/psi/ifont.h<br>
-gs/psi/ifont1.h<br>
-gs/psi/ifont2.h<br>
-gs/psi/ifont42.h<br>
-gs/psi/ifrpred.h<br>
-gs/psi/ifunc.h<br>
-gs/psi/ifwpred.h<br>
-gs/psi/igc.c<br>
-gs/psi/igc.h<br>
-gs/psi/igcref.c<br>
-gs/psi/igcstr.c<br>
-gs/psi/igcstr.h<br>
-gs/psi/igstate.h<br>
-gs/psi/iht.h<br>
-gs/psi/iimage.h<br>
-gs/psi/iimage2.h<br>
-gs/psi/iinit.c<br>
-gs/psi/iinit.h<br>
-gs/psi/ilevel.h<br>
-gs/psi/ilocate.c<br>
-gs/psi/imain.c<br>
-gs/psi/imain.h<br>
-gs/psi/imainarg.c<br>
-gs/psi/imainarg.h<br>
-gs/psi/imemory.h<br>
-gs/psi/iminst.h<br>
-gs/psi/iname.c<br>
-gs/psi/iname.h<br>
-gs/psi/inamedef.h<br>
-gs/psi/inameidx.h<br>
-gs/psi/inames.h<br>
-gs/psi/inamestr.h<br>
-gs/psi/inobtokn.c<br>
-gs/psi/inouparm.c<br>
-gs/psi/int.mak<br>
-gs/psi/interp.c<br>
-gs/psi/interp.h<br>
-gs/psi/iosdata.h<br>
-gs/psi/iostack.h<br>
-gs/psi/ipacked.h<br>
-gs/psi/iparam.c<br>
-gs/psi/iparam.h<br>
-gs/psi/iparray.h<br>
-gs/psi/ipcolor.h<br>
-gs/psi/iplugin.c<br>
-gs/psi/iplugin.h<br>
-gs/psi/ireclaim.c<br>
-gs/psi/iref.h<br>
-gs/psi/isave.c<br>
-gs/psi/isave.h<br>
-gs/psi/iscan.c<br>
-gs/psi/iscan.h<br>
-gs/psi/iscanbin.c<br>
-gs/psi/iscanbin.h<br>
-gs/psi/iscannum.c<br>
-gs/psi/iscannum.h<br>
-gs/psi/isdata.h<br>
-gs/psi/isstate.h<br>
-gs/psi/istack.c<br>
-gs/psi/istack.h<br>
-gs/psi/istkparm.h<br>
-gs/psi/istream.h<br>
-gs/psi/istruct.h<br>
-gs/psi/itoken.h<br>
-gs/psi/iutil.c<br>
-gs/psi/iutil.h<br>
-gs/psi/iutil2.c<br>
-gs/psi/iutil2.h<br>
-gs/psi/ivmem2.h<br>
-gs/psi/ivmspace.h<br>
-gs/psi/main.h<br>
-gs/psi/mkfilelt.cpp<br>
-gs/psi/msvc.mak<br>
-gs/psi/msvc32.mak<br>
-gs/psi/msvc64.mak<br>
-gs/psi/nsisinst.nsi<br>
-gs/psi/oparc.h<br>
-gs/psi/opcheck.h<br>
-gs/psi/opdef.h<br>
-gs/psi/oper.h<br>
-gs/psi/opextern.h<br>
-gs/psi/os2.mak<br>
-gs/psi/ostack.h<br>
-gs/psi/psromfs.mak<br>
-gs/psi/sfilter1.c<br>
-gs/psi/store.h<br>
-gs/psi/winint.mak<br>
-gs/psi/zalg.c<br>
-gs/psi/zarith.c<br>
-gs/psi/zarray.c<br>
-gs/psi/zbfont.c<br>
-gs/psi/zbseq.c<br>
-gs/psi/zcfont.c<br>
-gs/psi/zchar.c<br>
-gs/psi/zchar1.c<br>
-gs/psi/zchar2.c<br>
-gs/psi/zchar32.c<br>
-gs/psi/zchar42.c<br>
-gs/psi/zchar42.h<br>
-gs/psi/zcharout.c<br>
-gs/psi/zcharx.c<br>
-gs/psi/zcid.c<br>
-gs/psi/zcidtest.c<br>
-gs/psi/zcie.c<br>
-gs/psi/zcie.h<br>
-gs/psi/zcolor.c<br>
-gs/psi/zcolor.h<br>
-gs/psi/zcolor1.c<br>
-gs/psi/zcolor2.c<br>
-gs/psi/zcolor3.c<br>
-gs/psi/zcontext.c<br>
-gs/psi/zcontrol.c<br>
-gs/psi/zcrd.c<br>
-gs/psi/zcsdevn.c<br>
-gs/psi/zcsindex.c<br>
-gs/psi/zcspixel.c<br>
-gs/psi/zcssepr.c<br>
-gs/psi/zdevcal.c<br>
-gs/psi/zdevice.c<br>
-gs/psi/zdevice2.c<br>
-gs/psi/zdfilter.c<br>
-gs/psi/zdict.c<br>
-gs/psi/zdosio.c<br>
-gs/psi/zdouble.c<br>
-gs/psi/zdpnext.c<br>
-gs/psi/zdps.c<br>
-gs/psi/zdps1.c<br>
-gs/psi/zdscpars.c<br>
-gs/psi/zfaes.c<br>
-gs/psi/zfapi.c<br>
-gs/psi/zfarc4.c<br>
-gs/psi/zfbcp.c<br>
-gs/psi/zfcid.c<br>
-gs/psi/zfcid0.c<br>
-gs/psi/zfcid1.c<br>
-gs/psi/zfcmap.c<br>
-gs/psi/zfdctd.c<br>
-gs/psi/zfdcte.c<br>
-gs/psi/zfdecode.c<br>
-gs/psi/zfile.c<br>
-gs/psi/zfile.h<br>
-gs/psi/zfile1.c<br>
-gs/psi/zfileio.c<br>
-gs/psi/zfilter.c<br>
-gs/psi/zfilter2.c<br>
-gs/psi/zfilterx.c<br>
-gs/psi/zfimscale.c<br>
-gs/psi/zfjbig2.c<br>
-gs/psi/zfjpx.c<br>
-gs/psi/zfmd5.c<br>
-gs/psi/zfont.c<br>
-gs/psi/zfont0.c<br>
-gs/psi/zfont1.c<br>
-gs/psi/zfont2.c<br>
-gs/psi/zfont32.c<br>
-gs/psi/zfont42.c<br>
-gs/psi/zfontenum.c<br>
-gs/psi/zform.c<br>
-gs/psi/zfproc.c<br>
-gs/psi/zfrsd.c<br>
-gs/psi/zfrsd.h<br>
-gs/psi/zfsample.c<br>
-gs/psi/zfsha2.c<br>
-gs/psi/zfunc.c<br>
-gs/psi/zfunc.h<br>
-gs/psi/zfunc0.c<br>
-gs/psi/zfunc3.c<br>
-gs/psi/zfunc4.c<br>
-gs/psi/zfzlib.c<br>
-gs/psi/zgeneric.c<br>
-gs/psi/zgstate.c<br>
-gs/psi/zhsb.c<br>
-gs/psi/zht.c<br>
-gs/psi/zht1.c<br>
-gs/psi/zht2.c<br>
-gs/psi/zht2.h<br>
-gs/psi/zicc.c<br>
-gs/psi/zicc.h<br>
-gs/psi/zimage.c<br>
-gs/psi/zimage2.c<br>
-gs/psi/zimage3.c<br>
-gs/psi/ziodev.c<br>
-gs/psi/ziodev2.c<br>
-gs/psi/ziodevs.c<br>
-gs/psi/ziodevsc.c<br>
-gs/psi/zmath.c<br>
-gs/psi/zmatrix.c<br>
-gs/psi/zmedia2.c<br>
-gs/psi/zmisc.c<br>
-gs/psi/zmisc1.c<br>
-gs/psi/zmisc2.c<br>
-gs/psi/zmisc3.c<br>
-gs/psi/zncdummy.c<br>
-gs/psi/zpacked.c<br>
-gs/psi/zpaint.c<br>
-gs/psi/zpath.c<br>
-gs/psi/zpath1.c<br>
-gs/psi/zpcolor.c<br>
-gs/psi/zpdf_r6.c<br>
-gs/psi/zpdfops.c<br>
-gs/psi/zrelbit.c<br>
-gs/psi/zrop.c<br>
-gs/psi/zshade.c<br>
-gs/psi/zstack.c<br>
-gs/psi/zstring.c<br>
-gs/psi/zsysvm.c<br>
-gs/psi/ztoken.c<br>
-gs/psi/ztrans.c<br>
-gs/psi/ztrap.c<br>
-gs/psi/ztype.c<br>
-gs/psi/zupath.c<br>
-gs/psi/zusparam.c<br>
-gs/psi/zutf8.c<br>
-gs/psi/zvmem.c<br>
-gs/psi/zvmem2.c<br>
-gs/psi/zwinutf8.c<br>
-gs/tiff/COPYRIGHT<br>
-gs/tiff/ChangeLog<br>
-gs/tiff/HOWTO-RELEASE<br>
-gs/tiff/Makefile.am<br>
-gs/tiff/Makefile.in<br>
-gs/tiff/Makefile.vc<br>
-gs/tiff/README<br>
-gs/tiff/README.vms<br>
-gs/tiff/RELEASE-DATE<br>
-gs/tiff/SConstruct<br>
-gs/tiff/TODO<br>
-gs/tiff/VERSION<br>
-gs/tiff/aclocal.m4<br>
-gs/tiff/autogen.sh<br>
-gs/tiff/build/Makefile.am<br>
-gs/tiff/build/Makefile.in<br>
-gs/tiff/build/README<br>
-gs/tiff/config/compile<br>
-gs/tiff/config/config.guess<br>
-gs/tiff/config/config.sub<br>
-gs/tiff/config/depcomp<br>
-gs/tiff/config/install-sh<br>
-gs/tiff/config/ltmain.sh<br>
-gs/tiff/config/missing<br>
-gs/tiff/config/mkinstalldirs<br>
-gs/tiff/configure<br>
-gs/tiff/configure.ac<br>
-gs/tiff/configure.com<br>
-gs/tiff/contrib/Makefile.am<br>
-gs/tiff/contrib/Makefile.in<br>
-gs/tiff/contrib/README<br>
-gs/tiff/contrib/addtiffo/Makefile.am<br>
-gs/tiff/contrib/addtiffo/Makefile.in<br>
-gs/tiff/contrib/addtiffo/Makefile.vc<br>
-gs/tiff/contrib/addtiffo/README<br>
-gs/tiff/contrib/addtiffo/addtiffo.c<br>
-gs/tiff/contrib/addtiffo/tif_overview.c<br>
-gs/tiff/contrib/addtiffo/tif_ovrcache.c<br>
-gs/tiff/contrib/addtiffo/tif_ovrcache.h<br>
-gs/tiff/contrib/dbs/Makefile.am<br>
-gs/tiff/contrib/dbs/Makefile.in<br>
-gs/tiff/contrib/dbs/README<br>
-gs/tiff/contrib/dbs/tiff-bi.c<br>
-gs/tiff/contrib/dbs/tiff-grayscale.c<br>
-gs/tiff/contrib/dbs/tiff-palette.c<br>
-gs/tiff/contrib/dbs/tiff-rgb.c<br>
-gs/tiff/contrib/dbs/xtiff/Makefile.am<br>
-gs/tiff/contrib/dbs/xtiff/Makefile.in<br>
-gs/tiff/contrib/dbs/xtiff/README<br>
-gs/tiff/contrib/dbs/xtiff/patchlevel.h<br>
-gs/tiff/contrib/dbs/xtiff/xtiff.c<br>
-gs/tiff/contrib/dbs/xtiff/xtifficon.h<br>
-gs/tiff/contrib/iptcutil/Makefile.am<br>
-gs/tiff/contrib/iptcutil/Makefile.in<br>
-gs/tiff/contrib/iptcutil/README<br>
-gs/tiff/contrib/iptcutil/iptcutil.c<br>
-gs/tiff/contrib/iptcutil/test.iptc<br>
-gs/tiff/contrib/iptcutil/test.txt<br>
-gs/tiff/contrib/mfs/Makefile.am<br>
-gs/tiff/contrib/mfs/Makefile.in<br>
-gs/tiff/contrib/mfs/README<br>
-gs/tiff/contrib/mfs/mfs_file.c<br>
-gs/tiff/contrib/pds/Makefile.am<br>
-gs/tiff/contrib/pds/Makefile.in<br>
-gs/tiff/contrib/pds/README<br>
-gs/tiff/contrib/pds/tif_imageiter.c<br>
-gs/tiff/contrib/pds/tif_imageiter.h<br>
-gs/tiff/contrib/pds/tif_pdsdirread.c<br>
-gs/tiff/contrib/pds/tif_pdsdirwrite.c<br>
-gs/tiff/contrib/ras/Makefile.am<br>
-gs/tiff/contrib/ras/Makefile.in<br>
-gs/tiff/contrib/ras/README<br>
-gs/tiff/contrib/ras/ras2tif.c<br>
-gs/tiff/contrib/ras/tif2ras.c<br>
-gs/tiff/contrib/stream/Makefile.am<br>
-gs/tiff/contrib/stream/Makefile.in<br>
-gs/tiff/contrib/stream/README<br>
-gs/tiff/contrib/stream/tiffstream.cpp<br>
-gs/tiff/contrib/stream/tiffstream.h<br>
-gs/tiff/contrib/tags/Makefile.am<br>
-gs/tiff/contrib/tags/Makefile.in<br>
-gs/tiff/contrib/tags/README<br>
-gs/tiff/contrib/tags/listtif.c<br>
-gs/tiff/contrib/tags/maketif.c<br>
-gs/tiff/contrib/tags/xtif_dir.c<br>
-gs/tiff/contrib/tags/xtiffio.h<br>
-gs/tiff/contrib/tags/xtiffiop.h<br>
-gs/tiff/contrib/win_dib/Makefile.am<br>
-gs/tiff/contrib/win_dib/Makefile.in<br>
-gs/tiff/contrib/win_dib/Makefile.w95<br>
-gs/tiff/contrib/win_dib/README.Tiffile<br>
-gs/tiff/contrib/win_dib/README.tiff2dib<br>
-gs/tiff/contrib/win_dib/Tiffile.cpp<br>
-gs/tiff/contrib/win_dib/tiff2dib.c<br>
-gs/tiff/html/Makefile.am<br>
-gs/tiff/html/Makefile.in<br>
-gs/tiff/html/TIFFTechNote2.html<br>
-gs/tiff/html/addingtags.html<br>
-gs/tiff/html/bugs.html<br>
-gs/tiff/html/build.html<br>
-gs/tiff/html/contrib.html<br>
-gs/tiff/html/document.html<br>
-gs/tiff/html/images.html<br>
-gs/tiff/html/images/Makefile.am<br>
-gs/tiff/html/images/Makefile.in<br>
-gs/tiff/html/images/back.gif<br>
-gs/tiff/html/images/bali.jpg<br>
-gs/tiff/html/images/cat.gif<br>
-gs/tiff/html/images/cover.jpg<br>
-gs/tiff/html/images/cramps.gif<br>
-gs/tiff/html/images/dave.gif<br>
-gs/tiff/html/images/info.gif<br>
-gs/tiff/html/images/jello.jpg<br>
-gs/tiff/html/images/jim.gif<br>
-gs/tiff/html/images/note.gif<br>
-gs/tiff/html/images/oxford.gif<br>
-gs/tiff/html/images/quad.jpg<br>
-gs/tiff/html/images/ring.gif<br>
-gs/tiff/html/images/smallliz.jpg<br>
-gs/tiff/html/images/strike.gif<br>
-gs/tiff/html/images/warning.gif<br>
-gs/tiff/html/index.html<br>
-gs/tiff/html/internals.html<br>
-gs/tiff/html/intro.html<br>
-gs/tiff/html/libtiff.html<br>
-gs/tiff/html/man/Makefile.am<br>
-gs/tiff/html/man/Makefile.in<br>
-gs/tiff/html/man/TIFFClose.3tiff.html<br>
-gs/tiff/html/man/TIFFDataWidth.3tiff.html<br>
-gs/tiff/html/man/TIFFError.3tiff.html<br>
-gs/tiff/html/man/TIFFFlush.3tiff.html<br>
-gs/tiff/html/man/TIFFGetField.3tiff.html<br>
-gs/tiff/html/man/TIFFOpen.3tiff.html<br>
-gs/tiff/html/man/TIFFPrintDirectory.3tiff.html<br>
-gs/tiff/html/man/TIFFRGBAImage.3tiff.html<br>
-gs/tiff/html/man/TIFFReadDirectory.3tiff.html<br>
-gs/tiff/html/man/TIFFReadEncodedStrip.3tiff.html<br>
-gs/tiff/html/man/TIFFReadEncodedTile.3tiff.html<br>
-gs/tiff/html/man/TIFFReadRGBAImage.3tiff.html<br>
-gs/tiff/html/man/TIFFReadRGBAStrip.3tiff.html<br>
-gs/tiff/html/man/TIFFReadRGBATile.3tiff.html<br>
-gs/tiff/html/man/TIFFReadRawStrip.3tiff.html<br>
-gs/tiff/html/man/TIFFReadRawTile.3tiff.html<br>
-gs/tiff/html/man/TIFFReadScanline.3tiff.html<br>
-gs/tiff/html/man/TIFFReadTile.3tiff.html<br>
-gs/tiff/html/man/TIFFSetDirectory.3tiff.html<br>
-gs/tiff/html/man/TIFFSetField.3tiff.html<br>
-gs/tiff/html/man/TIFFWarning.3tiff.html<br>
-gs/tiff/html/man/TIFFWriteDirectory.3tiff.html<br>
-gs/tiff/html/man/TIFFWriteEncodedStrip.3tiff.html<br>
-gs/tiff/html/man/TIFFWriteEncodedTile.3tiff.html<br>
-gs/tiff/html/man/TIFFWriteRawStrip.3tiff.html<br>
-gs/tiff/html/man/TIFFWriteRawTile.3tiff.html<br>
-gs/tiff/html/man/TIFFWriteScanline.3tiff.html<br>
-gs/tiff/html/man/TIFFWriteTile.3tiff.html<br>
-gs/tiff/html/man/TIFFbuffer.3tiff.html<br>
-gs/tiff/html/man/TIFFcodec.3tiff.html<br>
-gs/tiff/html/man/TIFFcolor.3tiff.html<br>
-gs/tiff/html/man/TIFFmemory.3tiff.html<br>
-gs/tiff/html/man/TIFFquery.3tiff.html<br>
-gs/tiff/html/man/TIFFsize.3tiff.html<br>
-gs/tiff/html/man/TIFFstrip.3tiff.html<br>
-gs/tiff/html/man/TIFFswab.3tiff.html<br>
-gs/tiff/html/man/TIFFtile.3tiff.html<br>
-gs/tiff/html/man/fax2ps.1.html<br>
-gs/tiff/html/man/fax2tiff.1.html<br>
-gs/tiff/html/man/gif2tiff.1.html<br>
-gs/tiff/html/man/index.html<br>
-gs/tiff/html/man/libtiff.3tiff.html<br>
-gs/tiff/html/man/pal2rgb.1.html<br>
-gs/tiff/html/man/ppm2tiff.1.html<br>
-gs/tiff/html/man/ras2tiff.1.html<br>
-gs/tiff/html/man/raw2tiff.1.html<br>
-gs/tiff/html/man/rgb2ycbcr.1.html<br>
-gs/tiff/html/man/sgi2tiff.1.html<br>
-gs/tiff/html/man/thumbnail.1.html<br>
-gs/tiff/html/man/tiff2bw.1.html<br>
-gs/tiff/html/man/tiff2pdf.1.html<br>
-gs/tiff/html/man/tiff2ps.1.html<br>
-gs/tiff/html/man/tiff2rgba.1.html<br>
-gs/tiff/html/man/tiffcmp.1.html<br>
-gs/tiff/html/man/tiffcp.1.html<br>
-gs/tiff/html/man/tiffcrop.1.html<br>
-gs/tiff/html/man/tiffdither.1.html<br>
-gs/tiff/html/man/tiffdump.1.html<br>
-gs/tiff/html/man/tiffgt.1.html<br>
-gs/tiff/html/man/tiffinfo.1.html<br>
-gs/tiff/html/man/tiffmedian.1.html<br>
-gs/tiff/html/man/tiffset.1.html<br>
-gs/tiff/html/man/tiffsplit.1.html<br>
-gs/tiff/html/man/tiffsv.1.html<br>
-gs/tiff/html/misc.html<br>
-gs/tiff/html/support.html<br>
-gs/tiff/html/tools.html<br>
-gs/tiff/html/v3.4beta007.html<br>
-gs/tiff/html/v3.4beta016.html<br>
-gs/tiff/html/v3.4beta018.html<br>
-gs/tiff/html/v3.4beta024.html<br>
-gs/tiff/html/v3.4beta028.html<br>
-gs/tiff/html/v3.4beta029.html<br>
-gs/tiff/html/v3.4beta031.html<br>
-gs/tiff/html/v3.4beta032.html<br>
-gs/tiff/html/v3.4beta033.html<br>
-gs/tiff/html/v3.4beta034.html<br>
-gs/tiff/html/v3.4beta035.html<br>
-gs/tiff/html/v3.4beta036.html<br>
-gs/tiff/html/v3.5.1.html<br>
-gs/tiff/html/v3.5.2.html<br>
-gs/tiff/html/v3.5.3.html<br>
-gs/tiff/html/v3.5.4.html<br>
-gs/tiff/html/v3.5.5.html<br>
-gs/tiff/html/v3.5.6-beta.html<br>
-gs/tiff/html/v3.5.7.html<br>
-gs/tiff/html/v3.6.0.html<br>
-gs/tiff/html/v3.6.1.html<br>
-gs/tiff/html/v3.7.0.html<br>
-gs/tiff/html/v3.7.0alpha.html<br>
-gs/tiff/html/v3.7.0beta.html<br>
-gs/tiff/html/v3.7.0beta2.html<br>
-gs/tiff/html/v3.7.1.html<br>
-gs/tiff/html/v3.7.2.html<br>
-gs/tiff/html/v3.7.3.html<br>
-gs/tiff/html/v3.7.4.html<br>
-gs/tiff/html/v3.8.0.html<br>
-gs/tiff/html/v3.8.1.html<br>
-gs/tiff/html/v3.8.2.html<br>
-gs/tiff/html/v3.9.0beta.html<br>
-gs/tiff/html/v3.9.1.html<br>
-gs/tiff/html/v3.9.2.html<br>
-gs/tiff/html/v4.0.0.html<br>
-gs/tiff/libtiff-4.pc.in<br>
-gs/tiff/libtiff/Makefile.am<br>
-gs/tiff/libtiff/Makefile.in<br>
-gs/tiff/libtiff/Makefile.vc<br>
-gs/tiff/libtiff/SConstruct<br>
-gs/tiff/libtiff/libtiff.def<br>
-gs/tiff/libtiff/libtiff.map<br>
-gs/tiff/libtiff/libtiffxx.map<br>
-gs/tiff/libtiff/mkg3states.c<br>
-gs/tiff/libtiff/t4.h<br>
-gs/tiff/libtiff/tif_aux.c<br>
-gs/tiff/libtiff/tif_close.c<br>
-gs/tiff/libtiff/tif_codec.c<br>
-gs/tiff/libtiff/tif_color.c<br>
-gs/tiff/libtiff/tif_compress.c<br>
-gs/tiff/libtiff/tif_config.h-vms<br>
-gs/tiff/libtiff/tif_config.h.in<br>
-gs/tiff/libtiff/tif_config.vc.h<br>
-gs/tiff/libtiff/tif_config.wince.h<br>
-gs/tiff/libtiff/tif_dir.c<br>
-gs/tiff/libtiff/tif_dir.h<br>
-gs/tiff/libtiff/tif_dirinfo.c<br>
-gs/tiff/libtiff/tif_dirread.c<br>
-gs/tiff/libtiff/tif_dirwrite.c<br>
-gs/tiff/libtiff/tif_dumpmode.c<br>
-gs/tiff/libtiff/tif_error.c<br>
-gs/tiff/libtiff/tif_extension.c<br>
-gs/tiff/libtiff/tif_fax3.c<br>
-gs/tiff/libtiff/tif_fax3.h<br>
-gs/tiff/libtiff/tif_fax3sm.c<br>
-gs/tiff/libtiff/tif_flush.c<br>
-gs/tiff/libtiff/tif_getimage.c<br>
-gs/tiff/libtiff/tif_jbig.c<br>
-gs/tiff/libtiff/tif_jpeg.c<br>
-gs/tiff/libtiff/tif_jpeg_12.c<br>
-gs/tiff/libtiff/tif_luv.c<br>
-gs/tiff/libtiff/tif_lzma.c<br>
-gs/tiff/libtiff/tif_lzw.c<br>
-gs/tiff/libtiff/tif_next.c<br>
-gs/tiff/libtiff/tif_ojpeg.c<br>
-gs/tiff/libtiff/tif_open.c<br>
-gs/tiff/libtiff/tif_packbits.c<br>
-gs/tiff/libtiff/tif_pixarlog.c<br>
-gs/tiff/libtiff/tif_predict.c<br>
-gs/tiff/libtiff/tif_predict.h<br>
-gs/tiff/libtiff/tif_print.c<br>
-gs/tiff/libtiff/tif_read.c<br>
-gs/tiff/libtiff/tif_stream.cxx<br>
-gs/tiff/libtiff/tif_strip.c<br>
-gs/tiff/libtiff/tif_swab.c<br>
-gs/tiff/libtiff/tif_thunder.c<br>
-gs/tiff/libtiff/tif_tile.c<br>
-gs/tiff/libtiff/tif_unix.c<br>
-gs/tiff/libtiff/tif_version.c<br>
-gs/tiff/libtiff/tif_warning.c<br>
-gs/tiff/libtiff/tif_win32.c<br>
-gs/tiff/libtiff/tif_write.c<br>
-gs/tiff/libtiff/tif_zip.c<br>
-gs/tiff/libtiff/tiff.h<br>
-gs/tiff/libtiff/tiffconf.h.in<br>
-gs/tiff/libtiff/tiffconf.vc.h<br>
-gs/tiff/libtiff/tiffconf.wince.h<br>
-gs/tiff/libtiff/tiffio.h<br>
-gs/tiff/libtiff/tiffio.hxx<br>
-gs/tiff/libtiff/tiffiop.h<br>
-gs/tiff/libtiff/tiffvers.h<br>
-gs/tiff/libtiff/uvcode.h<br>
-gs/tiff/m4/acinclude.m4<br>
-gs/tiff/m4/libtool.m4<br>
-gs/tiff/m4/ltoptions.m4<br>
-gs/tiff/m4/ltsugar.m4<br>
-gs/tiff/m4/ltversion.m4<br>
-gs/tiff/m4/lt~obsolete.m4<br>
-gs/tiff/man/Makefile.am<br>
-gs/tiff/man/Makefile.in<br>
-gs/tiff/man/TIFFClose.3tiff<br>
-gs/tiff/man/TIFFDataWidth.3tiff<br>
-gs/tiff/man/TIFFError.3tiff<br>
-gs/tiff/man/TIFFFlush.3tiff<br>
-gs/tiff/man/TIFFGetField.3tiff<br>
-gs/tiff/man/TIFFOpen.3tiff<br>
-gs/tiff/man/TIFFPrintDirectory.3tiff<br>
-gs/tiff/man/TIFFRGBAImage.3tiff<br>
-gs/tiff/man/TIFFReadDirectory.3tiff<br>
-gs/tiff/man/TIFFReadEncodedStrip.3tiff<br>
-gs/tiff/man/TIFFReadEncodedTile.3tiff<br>
-gs/tiff/man/TIFFReadRGBAImage.3tiff<br>
-gs/tiff/man/TIFFReadRGBAStrip.3tiff<br>
-gs/tiff/man/TIFFReadRGBATile.3tiff<br>
-gs/tiff/man/TIFFReadRawStrip.3tiff<br>
-gs/tiff/man/TIFFReadRawTile.3tiff<br>
-gs/tiff/man/TIFFReadScanline.3tiff<br>
-gs/tiff/man/TIFFReadTile.3tiff<br>
-gs/tiff/man/TIFFSetDirectory.3tiff<br>
-gs/tiff/man/TIFFSetField.3tiff<br>
-gs/tiff/man/TIFFWarning.3tiff<br>
-gs/tiff/man/TIFFWriteDirectory.3tiff<br>
-gs/tiff/man/TIFFWriteEncodedStrip.3tiff<br>
-gs/tiff/man/TIFFWriteEncodedTile.3tiff<br>
-gs/tiff/man/TIFFWriteRawStrip.3tiff<br>
-gs/tiff/man/TIFFWriteRawTile.3tiff<br>
-gs/tiff/man/TIFFWriteScanline.3tiff<br>
-gs/tiff/man/TIFFWriteTile.3tiff<br>
-gs/tiff/man/TIFFbuffer.3tiff<br>
-gs/tiff/man/TIFFcodec.3tiff<br>
-gs/tiff/man/TIFFcolor.3tiff<br>
-gs/tiff/man/TIFFmemory.3tiff<br>
-gs/tiff/man/TIFFquery.3tiff<br>
-gs/tiff/man/TIFFsize.3tiff<br>
-gs/tiff/man/TIFFstrip.3tiff<br>
-gs/tiff/man/TIFFswab.3tiff<br>
-gs/tiff/man/TIFFtile.3tiff<br>
-gs/tiff/man/bmp2tiff.1<br>
-gs/tiff/man/fax2ps.1<br>
-gs/tiff/man/fax2tiff.1<br>
-gs/tiff/man/gif2tiff.1<br>
-gs/tiff/man/libtiff.3tiff<br>
-gs/tiff/man/pal2rgb.1<br>
-gs/tiff/man/ppm2tiff.1<br>
-gs/tiff/man/ras2tiff.1<br>
-gs/tiff/man/raw2tiff.1<br>
-gs/tiff/man/rgb2ycbcr.1<br>
-gs/tiff/man/sgi2tiff.1<br>
-gs/tiff/man/thumbnail.1<br>
-gs/tiff/man/tiff2bw.1<br>
-gs/tiff/man/tiff2pdf.1<br>
-gs/tiff/man/tiff2ps.1<br>
-gs/tiff/man/tiff2rgba.1<br>
-gs/tiff/man/tiffcmp.1<br>
-gs/tiff/man/tiffcp.1<br>
-gs/tiff/man/tiffcrop.1<br>
-gs/tiff/man/tiffdither.1<br>
-gs/tiff/man/tiffdump.1<br>
-gs/tiff/man/tiffgt.1<br>
-gs/tiff/man/tiffinfo.1<br>
-gs/tiff/man/tiffmedian.1<br>
-gs/tiff/man/tiffset.1<br>
-gs/tiff/man/tiffsplit.1<br>
-gs/tiff/man/tiffsv.1<br>
-gs/tiff/nmake.opt<br>
-gs/tiff/port/Makefile.am<br>
-gs/tiff/port/Makefile.in<br>
-gs/tiff/port/Makefile.vc<br>
-gs/tiff/port/dummy.c<br>
-gs/tiff/port/getopt.c<br>
-gs/tiff/port/lfind.c<br>
-gs/tiff/port/libport.h<br>
-gs/tiff/port/strcasecmp.c<br>
-gs/tiff/port/strtoul.c<br>
-gs/tiff/port/strtoull.c<br>
-gs/tiff/test/Makefile.am<br>
-gs/tiff/test/Makefile.in<br>
-gs/tiff/test/ascii_tag.c<br>
-gs/tiff/test/bmp2tiff_palette.sh<br>
-gs/tiff/test/bmp2tiff_rgb.sh<br>
-gs/tiff/test/check_tag.c<br>
-gs/tiff/test/common.sh<br>
-gs/tiff/test/gif2tiff.sh<br>
-gs/tiff/test/images/README.txt<br>
-gs/tiff/test/images/logluv-3c-16b.tiff<br>
-gs/tiff/test/images/minisblack-1c-16b.tiff<br>
-gs/tiff/test/images/minisblack-1c-8b.pgm<br>
-gs/tiff/test/images/minisblack-1c-8b.tiff<br>
-gs/tiff/test/images/minisblack-2c-8b-alpha.tiff<br>
-gs/tiff/test/images/miniswhite-1c-1b.pbm<br>
-gs/tiff/test/images/miniswhite-1c-1b.tiff<br>
-gs/tiff/test/images/palette-1c-1b.tiff<br>
-gs/tiff/test/images/palette-1c-4b.tiff<br>
-gs/tiff/test/images/palette-1c-8b.bmp<br>
-gs/tiff/test/images/palette-1c-8b.gif<br>
-gs/tiff/test/images/palette-1c-8b.tiff<br>
-gs/tiff/test/images/rgb-3c-16b.tiff<br>
-gs/tiff/test/images/rgb-3c-8b.bmp<br>
-gs/tiff/test/images/rgb-3c-8b.ppm<br>
-gs/tiff/test/images/rgb-3c-8b.tiff<br>
-gs/tiff/test/long_tag.c<br>
-gs/tiff/test/ppm2tiff_pbm.sh<br>
-gs/tiff/test/ppm2tiff_pgm.sh<br>
-gs/tiff/test/ppm2tiff_ppm.sh<br>
-gs/tiff/test/rewrite_tag.c<br>
-gs/tiff/test/short_tag.c<br>
-gs/tiff/test/strip.c<br>
-gs/tiff/test/strip_rw.c<br>
-gs/tiff/test/test_arrays.c<br>
-gs/tiff/test/test_arrays.h<br>
-gs/tiff/test/tiff2pdf.sh<br>
-gs/tiff/test/tiff2ps-EPS1.sh<br>
-gs/tiff/test/tiff2ps-PS1.sh<br>
-gs/tiff/test/tiff2ps-PS2.sh<br>
-gs/tiff/test/tiff2ps-PS3.sh<br>
-gs/tiff/test/tiff2rgba-logluv-3c-16b.sh<br>
-gs/tiff/test/tiff2rgba-minisblack-1c-16b.sh<br>
-gs/tiff/test/tiff2rgba-minisblack-1c-8b.sh<br>
-gs/tiff/test/tiff2rgba-minisblack-2c-8b-alpha.sh<br>
-gs/tiff/test/tiff2rgba-miniswhite-1c-1b.sh<br>
-gs/tiff/test/tiff2rgba-palette-1c-1b.sh<br>
-gs/tiff/test/tiff2rgba-palette-1c-4b.sh<br>
-gs/tiff/test/tiff2rgba-palette-1c-8b.sh<br>
-gs/tiff/test/tiff2rgba-rgb-3c-16b.sh<br>
-gs/tiff/test/tiff2rgba-rgb-3c-8b.sh<br>
-gs/tiff/test/tiffcp-g3-1d-fill.sh<br>
-gs/tiff/test/tiffcp-g3-1d.sh<br>
-gs/tiff/test/tiffcp-g3-2d-fill.sh<br>
-gs/tiff/test/tiffcp-g3-2d.sh<br>
-gs/tiff/test/tiffcp-g3.sh<br>
-gs/tiff/test/tiffcp-g4.sh<br>
-gs/tiff/test/tiffcp-logluv.sh<br>
-gs/tiff/test/tiffcp-split-join.sh<br>
-gs/tiff/test/tiffcp-split.sh<br>
-gs/tiff/test/tiffcp-thumbnail.sh<br>
-gs/tiff/test/tiffcrop-R90-logluv-3c-16b.sh<br>
-gs/tiff/test/tiffcrop-R90-minisblack-1c-16b.sh<br>
-gs/tiff/test/tiffcrop-R90-minisblack-1c-8b.sh<br>
-gs/tiff/test/tiffcrop-R90-minisblack-2c-8b-alpha.sh<br>
-gs/tiff/test/tiffcrop-R90-miniswhite-1c-1b.sh<br>
-gs/tiff/test/tiffcrop-R90-palette-1c-1b.sh<br>
-gs/tiff/test/tiffcrop-R90-palette-1c-4b.sh<br>
-gs/tiff/test/tiffcrop-R90-palette-1c-8b.sh<br>
-gs/tiff/test/tiffcrop-R90-rgb-3c-16b.sh<br>
-gs/tiff/test/tiffcrop-R90-rgb-3c-8b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-logluv-3c-16b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-minisblack-1c-16b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-minisblack-1c-8b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-minisblack-2c-8b-alpha.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-miniswhite-1c-1b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-palette-1c-1b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-palette-1c-4b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-palette-1c-8b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-rgb-3c-16b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-rgb-3c-8b.sh<br>
-gs/tiff/test/tiffcrop-extract-logluv-3c-16b.sh<br>
-gs/tiff/test/tiffcrop-extract-minisblack-1c-16b.sh<br>
-gs/tiff/test/tiffcrop-extract-minisblack-1c-8b.sh<br>
-gs/tiff/test/tiffcrop-extract-minisblack-2c-8b-alpha.sh<br>
-gs/tiff/test/tiffcrop-extract-miniswhite-1c-1b.sh<br>
-gs/tiff/test/tiffcrop-extract-palette-1c-1b.sh<br>
-gs/tiff/test/tiffcrop-extract-palette-1c-4b.sh<br>
-gs/tiff/test/tiffcrop-extract-palette-1c-8b.sh<br>
-gs/tiff/test/tiffcrop-extract-rgb-3c-16b.sh<br>
-gs/tiff/test/tiffcrop-extract-rgb-3c-8b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-logluv-3c-16b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-minisblack-1c-16b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-minisblack-1c-8b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-minisblack-2c-8b-alpha.sh<br>
-gs/tiff/test/tiffcrop-extractz14-miniswhite-1c-1b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-palette-1c-1b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-palette-1c-4b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-palette-1c-8b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-rgb-3c-16b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-rgb-3c-8b.sh<br>
-gs/tiff/test/tiffdump.sh<br>
-gs/tiff/test/tiffinfo.sh<br>
-gs/tiff/test/tifftest.h<br>
-gs/tiff/tools/Makefile.am<br>
-gs/tiff/tools/Makefile.in<br>
-gs/tiff/tools/Makefile.vc<br>
-gs/tiff/tools/bmp2tiff.c<br>
-gs/tiff/tools/fax2ps.c<br>
-gs/tiff/tools/fax2tiff.c<br>
-gs/tiff/tools/gif2tiff.c<br>
-gs/tiff/tools/pal2rgb.c<br>
-gs/tiff/tools/ppm2tiff.c<br>
-gs/tiff/tools/ras2tiff.c<br>
-gs/tiff/tools/rasterfile.h<br>
-gs/tiff/tools/raw2tiff.c<br>
-gs/tiff/tools/rgb2ycbcr.c<br>
-gs/tiff/tools/sgi2tiff.c<br>
-gs/tiff/tools/sgisv.c<br>
-gs/tiff/tools/thumbnail.c<br>
-gs/tiff/tools/tiff2bw.c<br>
-gs/tiff/tools/tiff2pdf.c<br>
-gs/tiff/tools/tiff2ps.c<br>
-gs/tiff/tools/tiff2rgba.c<br>
-gs/tiff/tools/tiffcmp.c<br>
-gs/tiff/tools/tiffcp.c<br>
-gs/tiff/tools/tiffcrop.c<br>
-gs/tiff/tools/tiffdither.c<br>
-gs/tiff/tools/tiffdump.c<br>
-gs/tiff/tools/tiffgt.c<br>
-gs/tiff/tools/tiffinfo.c<br>
-gs/tiff/tools/tiffmedian.c<br>
-gs/tiff/tools/tiffset.c<br>
-gs/tiff/tools/tiffsplit.c<br>
-gs/tiff/tools/ycbcr.c<br>
-gs/toolbin/GenSubstCID.ps<br>
-gs/toolbin/afmutil.py<br>
-gs/toolbin/apitest.pl<br>
-gs/toolbin/bmpcmp.c<br>
-gs/toolbin/bughunt.sh<br>
-gs/toolbin/bugsByEngineer.pl<br>
-gs/toolbin/checkdeps.pl<br>
-gs/toolbin/color/icc_creator/ICC Profiles/cmyk_k_ouput_only.icc<br>
-gs/toolbin/color/icc_creator/ICC Profiles/ps_emulate_cmyk.icc<br>
-gs/toolbin/color/icc_creator/ICC Profiles/ps_emulate_gray.icc<br>
-gs/toolbin/color/icc_creator/ICC Profiles/ps_emulate_rgb.icc<br>
-gs/toolbin/color/icc_creator/ICC_Creator.sln<br>
-gs/toolbin/color/icc_creator/ICC_Creator/CIELAB.h<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_Creator.cpp<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_Creator.h<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_Creator.rc<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_Creator.vcproj<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.cpp<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.h<br>
-gs/toolbin/color/icc_creator/ICC_Creator/icc34.h<br>
-gs/toolbin/color/icc_creator/ICC_Creator/icc_create.cpp<br>
-gs/toolbin/color/icc_creator/ICC_Creator/icc_create.h<br>
-gs/toolbin/color/icc_creator/ICC_Creator/res/ICC_Creator.rc2<br>
-gs/toolbin/color/icc_creator/ICC_Creator/res/gsimage_.ico<br>
-gs/toolbin/color/icc_creator/ICC_Creator/res/gswin.ico<br>
-gs/toolbin/color/icc_creator/ICC_Creator/resource.h<br>
-gs/toolbin/color/icc_creator/ICC_Creator/stdafx.cpp<br>
-gs/toolbin/color/icc_creator/ICC_Creator/stdafx.h<br>
-gs/toolbin/color/icc_creator/ICC_Creator/targetver.h<br>
-gs/toolbin/color/icc_creator/README.txt<br>
-gs/toolbin/color/icc_creator/effects/black_output.icc<br>
-gs/toolbin/color/icc_creator/effects/c_only.txt<br>
-gs/toolbin/color/icc_creator/effects/cyan_output.icc<br>
-gs/toolbin/color/icc_creator/effects/k_only.txt<br>
-gs/toolbin/color/icc_creator/effects/m_only.txt<br>
-gs/toolbin/color/icc_creator/effects/magenta_output.icc<br>
-gs/toolbin/color/icc_creator/effects/y_only.txt<br>
-gs/toolbin/color/icc_creator/effects/yellow_output.icc<br>
-gs/toolbin/color/icc_creator/example/artifex_blue_purple.icc<br>
-gs/toolbin/color/icc_creator/example/artifex_tritone.icc<br>
-gs/toolbin/color/icc_creator/example/cielab_values.txt<br>
-gs/toolbin/color/icc_creator/example/color_names.txt<br>
-gs/toolbin/color/icc_creator/example/duotone.pdf<br>
-gs/toolbin/color/icc_creator/example/tritone.pdf<br>
-gs/toolbin/color/icc_creator/example/tritone_cielab.txt<br>
-gs/toolbin/color/icc_creator/example/tritone_names.txt<br>
-gs/toolbin/color/icc_creator/ucr_bg.txt<br>
-gs/toolbin/color/named_color/named_color_table.txt<br>
-gs/toolbin/color/named_color/named_colors.pdf<br>
-gs/toolbin/color/src_color/cmyk_des_renderintent.icc<br>
-gs/toolbin/color/src_color/cmyk_src_cyan.icc<br>
-gs/toolbin/color/src_color/cmyk_src_magenta.icc<br>
-gs/toolbin/color/src_color/cmyk_src_renderintent.icc<br>
-gs/toolbin/color/src_color/cmyk_src_yellow.icc<br>
-gs/toolbin/color/src_color/objsrc_profiles_example.txt<br>
-gs/toolbin/color/src_color/rgb_source_blue.icc<br>
-gs/toolbin/color/src_color/rgb_source_green.icc<br>
-gs/toolbin/color/src_color/rgb_source_red.icc<br>
-gs/toolbin/drawafm.ps<br>
-gs/toolbin/encs2c.ps<br>
-gs/toolbin/errlist.tcl<br>
-gs/toolbin/extractFonts.ps<br>
-gs/toolbin/extractICCprofiles.ps<br>
-gs/toolbin/gen_ldf_jb2.py<br>
-gs/toolbin/genfontmap.ps<br>
-gs/toolbin/gitlog2changelog.py<br>
-gs/toolbin/gitsetup.sh<br>
-gs/toolbin/gsmake<br>
-gs/toolbin/gsmake.tcl<br>
-gs/toolbin/halftone/ETS/README.txt<br>
-gs/toolbin/halftone/ETS/ei03.pdf<br>
-gs/toolbin/halftone/ETS/ets.c<br>
-gs/toolbin/halftone/ETS/ets.h<br>
-gs/toolbin/halftone/ETS/ipview.html<br>
-gs/toolbin/halftone/ETS/test_ets.c<br>
-gs/toolbin/halftone/ETS/tm.h<br>
-gs/toolbin/halftone/ETS/win32/ETS.sln<br>
-gs/toolbin/halftone/ETS/win32/ETS.vcproj<br>
-gs/toolbin/halftone/gen_ordered/README<br>
-gs/toolbin/halftone/gen_ordered/gen_ordered.c<br>
-gs/toolbin/halftone/gen_ordered/gen_ordered.sln<br>
-gs/toolbin/halftone/gen_ordered/gen_ordered.vcproj<br>
-gs/toolbin/halftone/gen_stochastic/gen_stochastic.c<br>
-gs/toolbin/halftone/gen_stochastic/gen_stochastic.sln<br>
-gs/toolbin/halftone/gen_stochastic/gen_stochastic.vcproj<br>
-gs/toolbin/headers.tcl<br>
-gs/toolbin/htmldiff.pl<br>
-gs/toolbin/jpxtopdf.c<br>
-gs/toolbin/leaks.tcl<br>
-gs/toolbin/localcluster/clusterpush.pl<br>
-gs/toolbin/localcluster/clusterpush.txt<br>
-gs/toolbin/localcluster/gitpush.sh<br>
-gs/toolbin/localcluster/readme<br>
-gs/toolbin/makehist.tcl<br>
-gs/toolbin/memory.py<br>
-gs/toolbin/ocheck.py<br>
-gs/toolbin/pdf_info.ps<br>
-gs/toolbin/pdfinflt.ps<br>
-gs/toolbin/performance.pl<br>
-gs/toolbin/pre.chk<br>
-gs/toolbin/pre.tcl<br>
-gs/toolbin/precheck.tcl<br>
-gs/toolbin/pscet_status.pl<br>
-gs/toolbin/search-svn-revs<br>
-gs/toolbin/search/README<br>
-gs/toolbin/smoke.ps<br>
-gs/toolbin/split_changelog.py<br>
-gs/toolbin/squeeze2html.pl<br>
-gs/toolbin/suite.tcl<br>
-gs/toolbin/tests/README<br>
-gs/toolbin/tests/build_revision.py<br>
-gs/toolbin/tests/check_all.py<br>
-gs/toolbin/tests/check_comments.py<br>
-gs/toolbin/tests/check_dirs.py<br>
-gs/toolbin/tests/check_docrefs.py<br>
-gs/toolbin/tests/check_source.py<br>
-gs/toolbin/tests/cmpi.py<br>
-gs/toolbin/tests/collate.py<br>
-gs/toolbin/tests/compare_checksumdb.py<br>
-gs/toolbin/tests/compare_checksums.py<br>
-gs/toolbin/tests/dump_checksum.py<br>
-gs/toolbin/tests/dump_checksum_plus.py<br>
-gs/toolbin/tests/dump_checksum_raw.py<br>
-gs/toolbin/tests/find_unique_file.py<br>
-gs/toolbin/tests/fuzzy.c<br>
-gs/toolbin/tests/get_baseline_log.py<br>
-gs/toolbin/tests/get_baselines.py<br>
-gs/toolbin/tests/gscheck_all.py<br>
-gs/toolbin/tests/gscheck_fuzzypdf.py<br>
-gs/toolbin/tests/gscheck_pdfwrite.py<br>
-gs/toolbin/tests/gscheck_raster.py<br>
-gs/toolbin/tests/gscheck_testfiles.py<br>
-gs/toolbin/tests/gsconf.py<br>
-gs/toolbin/tests/gsparamsets.py<br>
-gs/toolbin/tests/gssum.py<br>
-gs/toolbin/tests/gstestgs.py<br>
-gs/toolbin/tests/gstestutils.py<br>
-gs/toolbin/tests/gsutil.py<br>
-gs/toolbin/tests/gsvalidate.py<br>
-gs/toolbin/tests/main.py<br>
-gs/toolbin/tests/make_baselinedb.py<br>
-gs/toolbin/tests/make_testdb.py<br>
-gs/toolbin/tests/make_two_pdfversions<br>
-gs/toolbin/tests/make_two_versions<br>
-gs/toolbin/tests/myoptparse.py<br>
-gs/toolbin/tests/rasterdb.py<br>
-gs/toolbin/tests/regen_baseline.py<br>
-gs/toolbin/tests/regen_filelist.py<br>
-gs/toolbin/tests/revert_baseline<br>
-gs/toolbin/tests/revert_pdfbaseline<br>
-gs/toolbin/tests/run_nightly<br>
-gs/toolbin/tests/run_nightly.py<br>
-gs/toolbin/tests/run_parallel<br>
-gs/toolbin/tests/run_regression.py<br>
-gs/toolbin/tests/run_series.py<br>
-gs/toolbin/tests/testdiff.py<br>
-gs/toolbin/tests/testing.cfg.example<br>
-gs/toolbin/tests/update_baseline.py<br>
-gs/toolbin/tests/update_specific<br>
-gs/toolbin/tests/updatelist.py<br>
-gs/toolbin/tests/updatelistpdf.py<br>
-gs/toolbin/tests/validate.py<br>
-gs/toolbin/tmake.tcl<br>
-gs/toolbin/vg_bugs.supp<br>
-gs/toolbin/vg_okay.supp<br>
-gs/zlib/CMakeLists.txt<br>
-gs/zlib/ChangeLog<br>
-gs/zlib/FAQ<br>
-gs/zlib/INDEX<br>
-gs/zlib/Makefile<br>
-gs/zlib/Makefile.in<br>
-gs/zlib/README<br>
-gs/zlib/adler32.c<br>
-gs/zlib/amiga/Makefile.pup<br>
-gs/zlib/amiga/Makefile.sas<br>
-gs/zlib/as400/bndsrc<br>
-gs/zlib/as400/compile.clp<br>
-gs/zlib/as400/readme.txt<br>
-gs/zlib/as400/zlib.inc<br>
-gs/zlib/compress.c<br>
-gs/zlib/configure<br>
-gs/zlib/contrib/README.contrib<br>
-gs/zlib/contrib/ada/buffer_demo.adb<br>
-gs/zlib/contrib/ada/mtest.adb<br>
-gs/zlib/contrib/ada/read.adb<br>
-gs/zlib/contrib/ada/readme.txt<br>
-gs/zlib/contrib/ada/test.adb<br>
-gs/zlib/contrib/ada/zlib-streams.adb<br>
-gs/zlib/contrib/ada/zlib-streams.ads<br>
-gs/zlib/contrib/ada/zlib-thin.adb<br>
-gs/zlib/contrib/ada/zlib-thin.ads<br>
-gs/zlib/contrib/ada/zlib.adb<br>
-gs/zlib/contrib/ada/zlib.ads<br>
-gs/zlib/contrib/ada/zlib.gpr<br>
-gs/zlib/contrib/amd64/amd64-match.S<br>
-gs/zlib/contrib/asm686/README.686<br>
-gs/zlib/contrib/asm686/match.S<br>
-gs/zlib/contrib/blast/Makefile<br>
-gs/zlib/contrib/blast/README<br>
-gs/zlib/contrib/blast/blast.c<br>
-gs/zlib/contrib/blast/blast.h<br>
-gs/zlib/contrib/blast/test.pk<br>
-gs/zlib/contrib/blast/test.txt<br>
-gs/zlib/contrib/delphi/ZLib.pas<br>
-gs/zlib/contrib/delphi/ZLibConst.pas<br>
-gs/zlib/contrib/delphi/readme.txt<br>
-gs/zlib/contrib/delphi/zlibd32.mak<br>
-gs/zlib/contrib/dotzlib/DotZLib.build<br>
-gs/zlib/contrib/dotzlib/DotZLib.chm<br>
-gs/zlib/contrib/dotzlib/DotZLib.sln<br>
-gs/zlib/contrib/dotzlib/DotZLib/AssemblyInfo.cs<br>
-gs/zlib/contrib/dotzlib/DotZLib/ChecksumImpl.cs<br>
-gs/zlib/contrib/dotzlib/DotZLib/CircularBuffer.cs<br>
-gs/zlib/contrib/dotzlib/DotZLib/CodecBase.cs<br>
-gs/zlib/contrib/dotzlib/DotZLib/Deflater.cs<br>
-gs/zlib/contrib/dotzlib/DotZLib/DotZLib.cs<br>
-gs/zlib/contrib/dotzlib/DotZLib/DotZLib.csproj<br>
-gs/zlib/contrib/dotzlib/DotZLib/GZipStream.cs<br>
-gs/zlib/contrib/dotzlib/DotZLib/Inflater.cs<br>
-gs/zlib/contrib/dotzlib/DotZLib/UnitTests.cs<br>
-gs/zlib/contrib/dotzlib/LICENSE_1_0.txt<br>
-gs/zlib/contrib/dotzlib/readme.txt<br>
-gs/zlib/contrib/gcc_gvmat64/gvmat64.S<br>
-gs/zlib/contrib/infback9/README<br>
-gs/zlib/contrib/infback9/infback9.c<br>
-gs/zlib/contrib/infback9/infback9.h<br>
-gs/zlib/contrib/infback9/inffix9.h<br>
-gs/zlib/contrib/infback9/inflate9.h<br>
-gs/zlib/contrib/infback9/inftree9.c<br>
-gs/zlib/contrib/infback9/inftree9.h<br>
-gs/zlib/contrib/inflate86/inffas86.c<br>
-gs/zlib/contrib/inflate86/inffast.S<br>
-gs/zlib/contrib/iostream/test.cpp<br>
-gs/zlib/contrib/iostream/zfstream.cpp<br>
-gs/zlib/contrib/iostream/zfstream.h<br>
-gs/zlib/contrib/iostream2/zstream.h<br>
-gs/zlib/contrib/iostream2/zstream_test.cpp<br>
-gs/zlib/contrib/iostream3/README<br>
-gs/zlib/contrib/iostream3/TODO<br>
-gs/zlib/contrib/iostream3/test.cc<br>
-gs/zlib/contrib/iostream3/zfstream.cc<br>
-gs/zlib/contrib/iostream3/zfstream.h<br>
-gs/zlib/contrib/masmx64/bld_ml64.bat<br>
-gs/zlib/contrib/masmx64/gvmat64.asm<br>
-gs/zlib/contrib/masmx64/inffas8664.c<br>
-gs/zlib/contrib/masmx64/inffasx64.asm<br>
-gs/zlib/contrib/masmx64/readme.txt<br>
-gs/zlib/contrib/masmx86/bld_ml32.bat<br>
-gs/zlib/contrib/masmx86/inffas32.asm<br>
-gs/zlib/contrib/masmx86/match686.asm<br>
-gs/zlib/contrib/masmx86/readme.txt<br>
-gs/zlib/contrib/minizip/Makefile<br>
-gs/zlib/contrib/minizip/Makefile.am<br>
-gs/zlib/contrib/minizip/MiniZip64_Changes.txt<br>
-gs/zlib/contrib/minizip/MiniZip64_info.txt<br>
-gs/zlib/contrib/minizip/configure.ac<br>
-gs/zlib/contrib/minizip/crypt.h<br>
-gs/zlib/contrib/minizip/ioapi.c<br>
-gs/zlib/contrib/minizip/ioapi.h<br>
-gs/zlib/contrib/minizip/iowin32.c<br>
-gs/zlib/contrib/minizip/iowin32.h<br>
-gs/zlib/contrib/minizip/make_vms.com<br>
-gs/zlib/contrib/minizip/miniunz.c<br>
-gs/zlib/contrib/minizip/miniunzip.1<br>
-gs/zlib/contrib/minizip/minizip.1<br>
-gs/zlib/contrib/minizip/minizip.c<br>
-gs/zlib/contrib/minizip/minizip.pc.in<br>
-gs/zlib/contrib/minizip/mztools.c<br>
-gs/zlib/contrib/minizip/mztools.h<br>
-gs/zlib/contrib/minizip/unzip.c<br>
-gs/zlib/contrib/minizip/unzip.h<br>
-gs/zlib/contrib/minizip/zip.c<br>
-gs/zlib/contrib/minizip/zip.h<br>
-gs/zlib/contrib/pascal/example.pas<br>
-gs/zlib/contrib/pascal/readme.txt<br>
-gs/zlib/contrib/pascal/zlibd32.mak<br>
-gs/zlib/contrib/pascal/zlibpas.pas<br>
-gs/zlib/contrib/puff/Makefile<br>
-gs/zlib/contrib/puff/README<br>
-gs/zlib/contrib/puff/puff.c<br>
-gs/zlib/contrib/puff/puff.h<br>
-gs/zlib/contrib/puff/pufftest.c<br>
-gs/zlib/contrib/puff/zeros.raw<br>
-gs/zlib/contrib/testzlib/testzlib.c<br>
-gs/zlib/contrib/testzlib/testzlib.txt<br>
-gs/zlib/contrib/untgz/Makefile<br>
-gs/zlib/contrib/untgz/Makefile.msc<br>
-gs/zlib/contrib/untgz/untgz.c<br>
-gs/zlib/contrib/vstudio/readme.txt<br>
-gs/zlib/contrib/vstudio/vc10/miniunz.vcxproj<br>
-gs/zlib/contrib/vstudio/vc10/miniunz.vcxproj.filters<br>
-gs/zlib/contrib/vstudio/vc10/minizip.vcxproj<br>
-gs/zlib/contrib/vstudio/vc10/minizip.vcxproj.filters<br>
-gs/zlib/contrib/vstudio/vc10/testzlib.vcxproj<br>
-gs/zlib/contrib/vstudio/vc10/testzlib.vcxproj.filters<br>
-gs/zlib/contrib/vstudio/vc10/testzlibdll.vcxproj<br>
-gs/zlib/contrib/vstudio/vc10/testzlibdll.vcxproj.filters<br>
-gs/zlib/contrib/vstudio/vc10/zlib.rc<br>
-gs/zlib/contrib/vstudio/vc10/zlibstat.vcxproj<br>
-gs/zlib/contrib/vstudio/vc10/zlibstat.vcxproj.filters<br>
-gs/zlib/contrib/vstudio/vc10/zlibvc.def<br>
-gs/zlib/contrib/vstudio/vc10/zlibvc.sln<br>
-gs/zlib/contrib/vstudio/vc10/zlibvc.vcxproj<br>
-gs/zlib/contrib/vstudio/vc10/zlibvc.vcxproj.filters<br>
-gs/zlib/contrib/vstudio/vc11/miniunz.vcxproj<br>
-gs/zlib/contrib/vstudio/vc11/minizip.vcxproj<br>
-gs/zlib/contrib/vstudio/vc11/testzlib.vcxproj<br>
-gs/zlib/contrib/vstudio/vc11/testzlibdll.vcxproj<br>
-gs/zlib/contrib/vstudio/vc11/zlib.rc<br>
-gs/zlib/contrib/vstudio/vc11/zlibstat.vcxproj<br>
-gs/zlib/contrib/vstudio/vc11/zlibvc.def<br>
-gs/zlib/contrib/vstudio/vc11/zlibvc.sln<br>
-gs/zlib/contrib/vstudio/vc11/zlibvc.vcxproj<br>
-gs/zlib/contrib/vstudio/vc9/miniunz.vcproj<br>
-gs/zlib/contrib/vstudio/vc9/minizip.vcproj<br>
-gs/zlib/contrib/vstudio/vc9/testzlib.vcproj<br>
-gs/zlib/contrib/vstudio/vc9/testzlibdll.vcproj<br>
-gs/zlib/contrib/vstudio/vc9/zlib.rc<br>
-gs/zlib/contrib/vstudio/vc9/zlibstat.vcproj<br>
-gs/zlib/contrib/vstudio/vc9/zlibvc.def<br>
-gs/zlib/contrib/vstudio/vc9/zlibvc.sln<br>
-gs/zlib/contrib/vstudio/vc9/zlibvc.vcproj<br>
-gs/zlib/crc32.c<br>
-gs/zlib/crc32.h<br>
-gs/zlib/deflate.c<br>
-gs/zlib/deflate.h<br>
-gs/zlib/doc/algorithm.txt<br>
-gs/zlib/doc/rfc1950.txt<br>
-gs/zlib/doc/rfc1951.txt<br>
-gs/zlib/doc/rfc1952.txt<br>
-gs/zlib/doc/txtvsbin.txt<br>
-gs/zlib/examples/README.examples<br>
-gs/zlib/examples/enough.c<br>
-gs/zlib/examples/fitblk.c<br>
-gs/zlib/examples/gun.c<br>
-gs/zlib/examples/gzappend.c<br>
-gs/zlib/examples/gzjoin.c<br>
-gs/zlib/examples/gzlog.c<br>
-gs/zlib/examples/gzlog.h<br>
-gs/zlib/examples/zlib_how.html<br>
-gs/zlib/examples/zpipe.c<br>
-gs/zlib/examples/zran.c<br>
-gs/zlib/gzclose.c<br>
-gs/zlib/gzguts.h<br>
-gs/zlib/gzlib.c<br>
-gs/zlib/gzread.c<br>
-gs/zlib/gzwrite.c<br>
-gs/zlib/infback.c<br>
-gs/zlib/inffast.c<br>
-gs/zlib/inffast.h<br>
-gs/zlib/inffixed.h<br>
-gs/zlib/inflate.c<br>
-gs/zlib/inflate.h<br>
-gs/zlib/inftrees.c<br>
-gs/zlib/inftrees.h<br>
-gs/zlib/make_vms.com<br>
-gs/zlib/msdos/Makefile.bor<br>
-gs/zlib/msdos/Makefile.dj2<br>
-gs/zlib/msdos/Makefile.emx<br>
-gs/zlib/msdos/Makefile.msc<br>
-gs/zlib/msdos/Makefile.tc<br>
-gs/zlib/nintendods/Makefile<br>
-gs/zlib/nintendods/README<br>
-gs/zlib/old/Makefile.emx<br>
-gs/zlib/old/Makefile.riscos<br>
-gs/zlib/old/README<br>
-gs/zlib/old/descrip.mms<br>
-gs/zlib/old/os2/Makefile.os2<br>
-gs/zlib/old/os2/zlib.def<br>
-gs/zlib/old/visual-basic.txt<br>
-gs/zlib/qnx/package.qpg<br>
-gs/zlib/test/example.c<br>
-gs/zlib/test/infcover.c<br>
-gs/zlib/test/minigzip.c<br>
-gs/zlib/treebuild.xml<br>
-gs/zlib/trees.c<br>
-gs/zlib/trees.h<br>
-gs/zlib/uncompr.c<br>
-gs/zlib/watcom/watcom_f.mak<br>
-gs/zlib/watcom/watcom_l.mak<br>
-gs/zlib/win32/DLL_FAQ.txt<br>
-gs/zlib/win32/Makefile.bor<br>
-gs/zlib/win32/Makefile.gcc<br>
-gs/zlib/win32/Makefile.msc<br>
-gs/zlib/win32/README-WIN32.txt<br>
-gs/zlib/win32/VisualC.txt<br>
-gs/zlib/win32/zlib.def<br>
-gs/zlib/win32/zlib1.rc<br>
-gs/zlib/zconf.h<br>
-gs/zlib/zconf.h.cmakein<br>
-gs/zlib/zconf.h.in<br>
-gs/zlib/zlib.3<br>
-gs/zlib/zlib.3.pdf<br>
-gs/zlib/zlib.h<br>
-gs/zlib/zlib.map<br>
-gs/zlib/zlib.pc.cmakein<br>
-gs/zlib/zlib.pc.in<br>
-gs/zlib/zlib2ansi<br>
-gs/zlib/zutil.c<br>
-gs/zlib/zutil.h<br>
-iccprofiles/default_cmyk.icc<br>
-iccprofiles/default_gray.icc<br>
-iccprofiles/default_rgb.icc<br>
-iccprofiles/gray_to_k.icc<br>
-iccprofiles/lab.icc<br>
-iccprofiles/ps_cmyk.icc<br>
-iccprofiles/ps_gray.icc<br>
-iccprofiles/ps_rgb.icc<br>
-iccprofiles/sgray.icc<br>
-iccprofiles/srgb.icc<br>
-ijs/Makefile.am<br>
-ijs/Makefile.in<br>
-ijs/README<br>
-ijs/autogen.sh<br>
-ijs/common.mak<br>
-ijs/compile<br>
-ijs/config.guess<br>
-ijs/config.sub<br>
-ijs/configure<br>
-ijs/configure.ac<br>
-ijs/ijs-config.1<br>
-ijs/ijs-config.in<br>
-ijs/ijs.c<br>
-ijs/ijs.h<br>
-ijs/ijs.pc.in<br>
-ijs/ijs_client.c<br>
-ijs/ijs_client.h<br>
-ijs/ijs_client_example.c<br>
-ijs/ijs_exec_unix.c<br>
-ijs/ijs_exec_win.c<br>
-ijs/ijs_server.c<br>
-ijs/ijs_server.h<br>
-ijs/ijs_server_example.c<br>
-ijs/ijs_spec.pdf<br>
-ijs/ijs_spec.ps<br>
-ijs/ijs_spec.sgml<br>
-ijs/install-sh<br>
-ijs/libtool<br>
-ijs/ltmain.sh<br>
-ijs/missing<br>
-ijs/state.eps<br>
-ijs/state.fig<br>
-ijs/unistd_.h<br>
-ijs/unix.mak<br>
-ijs/windows.mak<br>
-jbig2dec/.gitignore<br>
-jbig2dec/CHANGES<br>
-jbig2dec/COPYING<br>
-jbig2dec/LICENSE<br>
-jbig2dec/Makefile.am<br>
-jbig2dec/Makefile.unix<br>
-jbig2dec/README<br>
-jbig2dec/annex-h.jbig2<br>
-jbig2dec/autogen.sh<br>
-jbig2dec/config_win32.h<br>
-jbig2dec/configure.ac<br>
-jbig2dec/getopt.c<br>
-jbig2dec/getopt.h<br>
-jbig2dec/getopt1.c<br>
-jbig2dec/jbig2.c<br>
-jbig2dec/jbig2.h<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_generic.h<br>
-jbig2dec/jbig2_halftone.c<br>
-jbig2dec/jbig2_halftone.h<br>
-jbig2dec/jbig2_huffman.c<br>
-jbig2dec/jbig2_huffman.h<br>
-jbig2dec/jbig2_hufftab.h<br>
-jbig2dec/jbig2_image.c<br>
-jbig2dec/jbig2_image.h<br>
-jbig2dec/jbig2_image_pbm.c<br>
-jbig2dec/jbig2_image_png.c<br>
-jbig2dec/jbig2_metadata.c<br>
-jbig2dec/jbig2_metadata.h<br>
-jbig2dec/jbig2_mmr.c<br>
-jbig2dec/jbig2_mmr.h<br>
-jbig2dec/jbig2_page.c<br>
-jbig2dec/jbig2_priv.h<br>
-jbig2dec/jbig2_refinement.c<br>
-jbig2dec/jbig2_segment.c<br>
-jbig2dec/jbig2_symbol_dict.c<br>
-jbig2dec/jbig2_symbol_dict.h<br>
-jbig2dec/jbig2_text.c<br>
-jbig2dec/jbig2_text.h<br>
-jbig2dec/jbig2dec.1<br>
-jbig2dec/jbig2dec.c<br>
-jbig2dec/memcmp.c<br>
-jbig2dec/memento.c<br>
-jbig2dec/memento.h<br>
-jbig2dec/msvc.mak<br>
-jbig2dec/os_types.h<br>
-jbig2dec/pbm2png.c<br>
-jbig2dec/sha1.c<br>
-jbig2dec/sha1.h<br>
-jbig2dec/snprintf.c<br>
-jbig2dec/test_jbig2dec.py<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/cdjpeg.c<br>
-jpeg/cdjpeg.h<br>
-jpeg/change.log<br>
-jpeg/cjpeg.1<br>
-jpeg/cjpeg.c<br>
-jpeg/ckconfig.c<br>
-jpeg/coderules.txt<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/example.c<br>
-jpeg/filelist.txt<br>
-jpeg/install-sh<br>
-jpeg/install.txt<br>
-jpeg/jaricom.c<br>
-jpeg/jcapimin.c<br>
-jpeg/jcapistd.c<br>
-jpeg/jcarith.c<br>
-jpeg/jccoefct.c<br>
-jpeg/jccolor.c<br>
-jpeg/jcdctmgr.c<br>
-jpeg/jchuff.c<br>
-jpeg/jcinit.c<br>
-jpeg/jcmainct.c<br>
-jpeg/jcmarker.c<br>
-jpeg/jcmaster.c<br>
-jpeg/jcomapi.c<br>
-jpeg/jconfig.bcc<br>
-jpeg/jconfig.cfg<br>
-jpeg/jconfig.dj<br>
-jpeg/jconfig.mac<br>
-jpeg/jconfig.manx<br>
-jpeg/jconfig.mc6<br>
-jpeg/jconfig.sas<br>
-jpeg/jconfig.st<br>
-jpeg/jconfig.txt<br>
-jpeg/jconfig.vc<br>
-jpeg/jconfig.vms<br>
-jpeg/jconfig.wat<br>
-jpeg/jcparam.c<br>
-jpeg/jcprepct.c<br>
-jpeg/jcsample.c<br>
-jpeg/jctrans.c<br>
-jpeg/jdapimin.c<br>
-jpeg/jdapistd.c<br>
-jpeg/jdarith.c<br>
-jpeg/jdatadst.c<br>
-jpeg/jdatasrc.c<br>
-jpeg/jdcoefct.c<br>
-jpeg/jdcolor.c<br>
-jpeg/jdct.h<br>
-jpeg/jddctmgr.c<br>
-jpeg/jdhuff.c<br>
-jpeg/jdinput.c<br>
-jpeg/jdmainct.c<br>
-jpeg/jdmarker.c<br>
-jpeg/jdmaster.c<br>
-jpeg/jdmerge.c<br>
-jpeg/jdpostct.c<br>
-jpeg/jdsample.c<br>
-jpeg/jdtrans.c<br>
-jpeg/jerror.c<br>
-jpeg/jerror.h<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/jmemansi.c<br>
-jpeg/jmemdos.c<br>
-jpeg/jmemdosa.asm<br>
-jpeg/jmemmac.c<br>
-jpeg/jmemmgr.c<br>
-jpeg/jmemname.c<br>
-jpeg/jmemnobs.c<br>
-jpeg/jmemsys.h<br>
-jpeg/jmorecfg.h<br>
-jpeg/jpegint.h<br>
-jpeg/jpeglib.h<br>
-jpeg/jpegtran.1<br>
-jpeg/jpegtran.c<br>
-jpeg/jquant1.c<br>
-jpeg/jquant2.c<br>
-jpeg/jutils.c<br>
-jpeg/jversion.h<br>
-jpeg/libjpeg.map<br>
-jpeg/libjpeg.txt<br>
-jpeg/ltmain.sh<br>
-jpeg/makcjpeg.st<br>
-jpeg/makdjpeg.st<br>
-jpeg/makeadsw.vc6<br>
-jpeg/makeasln.v10<br>
-jpeg/makecdep.vc6<br>
-jpeg/makecdsp.vc6<br>
-jpeg/makecfil.v10<br>
-jpeg/makecmak.vc6<br>
-jpeg/makecvcx.v10<br>
-jpeg/makeddep.vc6<br>
-jpeg/makeddsp.vc6<br>
-jpeg/makedfil.v10<br>
-jpeg/makedmak.vc6<br>
-jpeg/makedvcx.v10<br>
-jpeg/makefile.ansi<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.vms<br>
-jpeg/makefile.wat<br>
-jpeg/makejdep.vc6<br>
-jpeg/makejdsp.vc6<br>
-jpeg/makejdsw.vc6<br>
-jpeg/makejfil.v10<br>
-jpeg/makejmak.vc6<br>
-jpeg/makejsln.v10<br>
-jpeg/makejvcx.v10<br>
-jpeg/makeproj.mac<br>
-jpeg/makerdep.vc6<br>
-jpeg/makerdsp.vc6<br>
-jpeg/makerfil.v10<br>
-jpeg/makermak.vc6<br>
-jpeg/makervcx.v10<br>
-jpeg/maketdep.vc6<br>
-jpeg/maketdsp.vc6<br>
-jpeg/maketfil.v10<br>
-jpeg/maketmak.vc6<br>
-jpeg/maketvcx.v10<br>
-jpeg/makewdep.vc6<br>
-jpeg/makewdsp.vc6<br>
-jpeg/makewfil.v10<br>
-jpeg/makewmak.vc6<br>
-jpeg/makewvcx.v10<br>
-jpeg/makljpeg.st<br>
-jpeg/maktjpeg.st<br>
-jpeg/makvms.opt<br>
-jpeg/missing<br>
-jpeg/rdbmp.c<br>
-jpeg/rdcolmap.c<br>
-jpeg/rdgif.c<br>
-jpeg/rdjpgcom.1<br>
-jpeg/rdjpgcom.c<br>
-jpeg/rdppm.c<br>
-jpeg/rdrle.c<br>
-jpeg/rdswitch.c<br>
-jpeg/rdtarga.c<br>
-jpeg/structure.txt<br>
-jpeg/testimg.bmp<br>
-jpeg/testimg.jpg<br>
-jpeg/testimg.ppm<br>
-jpeg/testimgp.jpg<br>
-jpeg/testorig.jpg<br>
-jpeg/testprog.jpg<br>
-jpeg/transupp.c<br>
-jpeg/transupp.h<br>
-jpeg/usage.txt<br>
-jpeg/wizard.txt<br>
-jpeg/wrbmp.c<br>
-jpeg/wrgif.c<br>
-jpeg/wrjpgcom.1<br>
-jpeg/wrjpgcom.c<br>
-jpeg/wrppm.c<br>
-jpeg/wrrle.c<br>
-jpeg/wrtarga.c<br>
-jpegxr/APP.rc<br>
-jpegxr/APP.vcproj<br>
-jpegxr/COPYRIGHT.txt<br>
-jpegxr/DLL.rc<br>
-jpegxr/DLL.vcproj<br>
-jpegxr/JPEG-XR.sln<br>
-jpegxr/Makefile<br>
-jpegxr/README.txt<br>
-jpegxr/algo.c<br>
-jpegxr/api.c<br>
-jpegxr/app_resource.h<br>
-jpegxr/cr_parse.c<br>
-jpegxr/cw_emit.c<br>
-jpegxr/dll_resource.h<br>
-jpegxr/dllmain.c<br>
-jpegxr/file.c<br>
-jpegxr/file.h<br>
-jpegxr/flags.c<br>
-jpegxr/init.c<br>
-jpegxr/io.c<br>
-jpegxr/jpegxr.c<br>
-jpegxr/jpegxr.h<br>
-jpegxr/jpegxr_pixelformat.c<br>
-jpegxr/jxr_priv.h<br>
-jpegxr/my_getopt-1.5/LICENSE<br>
-jpegxr/my_getopt-1.5/getopt.h<br>
-jpegxr/my_getopt-1.5/my_getopt.c<br>
-jpegxr/my_getopt-1.5/my_getopt.h<br>
-jpegxr/qp.tab.c<br>
-jpegxr/qp.tab.h<br>
-jpegxr/qp_lexor.c<br>
-jpegxr/qp_lexor.lex<br>
-jpegxr/qp_parse.y<br>
-jpegxr/r_parse.c<br>
-jpegxr/r_strip.c<br>
-jpegxr/r_tile_frequency.c<br>
-jpegxr/r_tile_spatial.c<br>
-jpegxr/sample.qp<br>
-jpegxr/stdint_minimal.h<br>
-jpegxr/versions-windows.txt<br>
-jpegxr/w_emit.c<br>
-jpegxr/w_strip.c<br>
-jpegxr/w_tile_frequency.c<br>
-jpegxr/w_tile_spatial.c<br>
-jpegxr/x_strip.c<br>
-language_switch/pspcl6_gcc.mak<br>
-language_switch/pspcl6_msvc.mak<br>
-lcms2/AUTHORS<br>
-lcms2/COPYING<br>
-lcms2/ChangeLog<br>
-lcms2/INSTALL<br>
-lcms2/Lib/BC/BC.txt<br>
-lcms2/Lib/MS/MS.TXT<br>
-lcms2/Makefile.am<br>
-lcms2/Makefile.in<br>
-lcms2/Projects/.gitignore<br>
-lcms2/Projects/BorlandC_5.5/lcms2.rc<br>
-lcms2/Projects/BorlandC_5.5/lcmsdll.lk<br>
-lcms2/Projects/BorlandC_5.5/lcmsdll.lst<br>
-lcms2/Projects/BorlandC_5.5/mklcmsdll.bat<br>
-lcms2/Projects/VC2008/jpegicc/jpegicc.vcproj<br>
-lcms2/Projects/VC2008/lcms2.rc<br>
-lcms2/Projects/VC2008/lcms2.sln<br>
-lcms2/Projects/VC2008/lcms2_DLL/lcms2_DLL.vcproj<br>
-lcms2/Projects/VC2008/lcms2_static/lcms2_static.vcproj<br>
-lcms2/Projects/VC2008/linkicc/linkicc.vcproj<br>
-lcms2/Projects/VC2008/psicc/psicc.vcproj<br>
-lcms2/Projects/VC2008/resource.h<br>
-lcms2/Projects/VC2008/testbed/testbed.vcproj<br>
-lcms2/Projects/VC2008/tiffdiff/tiffdiff.vcproj<br>
-lcms2/Projects/VC2008/tifficc/tifficc.vcproj<br>
-lcms2/Projects/VC2008/transicc/transicc.vcproj<br>
-lcms2/Projects/VC2010/jpegicc/jpegicc.vcproj<br>
-lcms2/Projects/VC2010/jpegicc/jpegicc.vcxproj<br>
-lcms2/Projects/VC2010/jpegicc/jpegicc.vcxproj.filters<br>
-lcms2/Projects/VC2010/lcms2.rc<br>
-lcms2/Projects/VC2010/lcms2.sln<br>
-lcms2/Projects/VC2010/lcms2_DLL/lcms2_DLL.vcproj<br>
-lcms2/Projects/VC2010/lcms2_DLL/lcms2_DLL.vcxproj<br>
-lcms2/Projects/VC2010/lcms2_DLL/lcms2_DLL.vcxproj.filters<br>
-lcms2/Projects/VC2010/lcms2_static/lcms2_static.vcproj<br>
-lcms2/Projects/VC2010/lcms2_static/lcms2_static.vcxproj<br>
-lcms2/Projects/VC2010/lcms2_static/lcms2_static.vcxproj.filters<br>
-lcms2/Projects/VC2010/linkicc/linkicc.vcproj<br>
-lcms2/Projects/VC2010/linkicc/linkicc.vcxproj<br>
-lcms2/Projects/VC2010/linkicc/linkicc.vcxproj.filters<br>
-lcms2/Projects/VC2010/psicc/psicc.vcproj<br>
-lcms2/Projects/VC2010/psicc/psicc.vcxproj<br>
-lcms2/Projects/VC2010/psicc/psicc.vcxproj.filters<br>
-lcms2/Projects/VC2010/resource.h<br>
-lcms2/Projects/VC2010/testbed/testbed.vcproj<br>
-lcms2/Projects/VC2010/testbed/testbed.vcxproj<br>
-lcms2/Projects/VC2010/testbed/testbed.vcxproj.filters<br>
-lcms2/Projects/VC2010/tiffdiff/tiffdiff.vcproj<br>
-lcms2/Projects/VC2010/tiffdiff/tiffdiff.vcxproj<br>
-lcms2/Projects/VC2010/tiffdiff/tiffdiff.vcxproj.filters<br>
-lcms2/Projects/VC2010/tifficc/tifficc.vcproj<br>
-lcms2/Projects/VC2010/tifficc/tifficc.vcxproj<br>
-lcms2/Projects/VC2010/tifficc/tifficc.vcxproj.filters<br>
-lcms2/Projects/VC2010/transicc/transicc.vcproj<br>
-lcms2/Projects/VC2010/transicc/transicc.vcxproj<br>
-lcms2/Projects/VC2010/transicc/transicc.vcxproj.filters<br>
-lcms2/Projects/VC2012/jpegicc/jpegicc.vcproj<br>
-lcms2/Projects/VC2012/jpegicc/jpegicc.vcxproj<br>
-lcms2/Projects/VC2012/jpegicc/jpegicc.vcxproj.filters<br>
-lcms2/Projects/VC2012/lcms2.rc<br>
-lcms2/Projects/VC2012/lcms2.sln<br>
-lcms2/Projects/VC2012/lcms2_DLL/lcms2_DLL.vcproj<br>
-lcms2/Projects/VC2012/lcms2_DLL/lcms2_DLL.vcxproj<br>
-lcms2/Projects/VC2012/lcms2_DLL/lcms2_DLL.vcxproj.filters<br>
-lcms2/Projects/VC2012/lcms2_static/lcms2_static.vcproj<br>
-lcms2/Projects/VC2012/lcms2_static/lcms2_static.vcxproj<br>
-lcms2/Projects/VC2012/lcms2_static/lcms2_static.vcxproj.filters<br>
-lcms2/Projects/VC2012/linkicc/linkicc.vcproj<br>
-lcms2/Projects/VC2012/linkicc/linkicc.vcxproj<br>
-lcms2/Projects/VC2012/linkicc/linkicc.vcxproj.filters<br>
-lcms2/Projects/VC2012/psicc/psicc.vcproj<br>
-lcms2/Projects/VC2012/psicc/psicc.vcxproj<br>
-lcms2/Projects/VC2012/psicc/psicc.vcxproj.filters<br>
-lcms2/Projects/VC2012/resource.h<br>
-lcms2/Projects/VC2012/testbed/testbed.vcproj<br>
-lcms2/Projects/VC2012/testbed/testbed.vcxproj<br>
-lcms2/Projects/VC2012/testbed/testbed.vcxproj.filters<br>
-lcms2/Projects/VC2012/tiffdiff/tiffdiff.vcproj<br>
-lcms2/Projects/VC2012/tiffdiff/tiffdiff.vcxproj<br>
-lcms2/Projects/VC2012/tiffdiff/tiffdiff.vcxproj.filters<br>
-lcms2/Projects/VC2012/tifficc/tifficc.vcproj<br>
-lcms2/Projects/VC2012/tifficc/tifficc.vcxproj<br>
-lcms2/Projects/VC2012/tifficc/tifficc.vcxproj.filters<br>
-lcms2/Projects/VC2012/transicc/transicc.vcproj<br>
-lcms2/Projects/VC2012/transicc/transicc.vcxproj<br>
-lcms2/Projects/VC2012/transicc/transicc.vcxproj.filters<br>
-lcms2/Projects/cppcheck/lcms2.cppcheck<br>
-lcms2/Projects/mac/._.DS_Store<br>
-lcms2/Projects/mac/LittleCMS/._.DS_Store<br>
-lcms2/Projects/mac/LittleCMS/English.lproj/InfoPlist.strings<br>
-lcms2/Projects/mac/LittleCMS/Info.plist<br>
-lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/mariama.mode1v3<br>
-lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/mariama.pbxuser<br>
-lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.pbxproj<br>
-lcms2/Projects/mac/LittleCMS/LittleCMS_Prefix.pch<br>
-lcms2/Projects/mac/LittleCMS/TestBed-Info.plist<br>
-lcms2/README.1ST<br>
-lcms2/aclocal.m4<br>
-lcms2/autogen.sh<br>
-lcms2/config.guess<br>
-lcms2/config.sub<br>
-lcms2/configure<br>
-lcms2/configure.ac<br>
-lcms2/depcomp<br>
-lcms2/doc/LittleCMS2.6 API.pdf<br>
-lcms2/doc/LittleCMS2.6 Plugin API.pdf<br>
-lcms2/doc/LittleCMS2.6 tutorial.pdf<br>
-lcms2/doc/src.zip<br>
-lcms2/include/Makefile.am<br>
-lcms2/include/Makefile.in<br>
-lcms2/include/lcms2.h<br>
-lcms2/include/lcms2_plugin.h<br>
-lcms2/install-sh<br>
-lcms2/lcms2.pc.in<br>
-lcms2/ltmain.sh<br>
-lcms2/m4/acx_pthread.m4<br>
-lcms2/missing<br>
-lcms2/src/Makefile.am<br>
-lcms2/src/Makefile.in<br>
-lcms2/src/cmscam02.c<br>
-lcms2/src/cmscgats.c<br>
-lcms2/src/cmscnvrt.c<br>
-lcms2/src/cmserr.c<br>
-lcms2/src/cmsgamma.c<br>
-lcms2/src/cmsgmt.c<br>
-lcms2/src/cmshalf.c<br>
-lcms2/src/cmsintrp.c<br>
-lcms2/src/cmsio0.c<br>
-lcms2/src/cmsio1.c<br>
-lcms2/src/cmslut.c<br>
-lcms2/src/cmsmd5.c<br>
-lcms2/src/cmsmtrx.c<br>
-lcms2/src/cmsnamed.c<br>
-lcms2/src/cmsopt.c<br>
-lcms2/src/cmspack.c<br>
-lcms2/src/cmspcs.c<br>
-lcms2/src/cmsplugin.c<br>
-lcms2/src/cmsps2.c<br>
-lcms2/src/cmssamp.c<br>
-lcms2/src/cmssm.c<br>
-lcms2/src/cmstypes.c<br>
-lcms2/src/cmsvirt.c<br>
-lcms2/src/cmswtpnt.c<br>
-lcms2/src/cmsxform.c<br>
-lcms2/src/extra_xform.h<br>
-lcms2/src/lcms2.def<br>
-lcms2/src/lcms2_internal.h<br>
-lcms2/testbed/Makefile.am<br>
-lcms2/testbed/Makefile.in<br>
-lcms2/testbed/bad.icc<br>
-lcms2/testbed/ibm-t61.icc<br>
-lcms2/testbed/new.icc<br>
-lcms2/testbed/test1.icc<br>
-lcms2/testbed/test2.icc<br>
-lcms2/testbed/test3.icc<br>
-lcms2/testbed/test4.icc<br>
-lcms2/testbed/test5.icc<br>
-lcms2/testbed/testcms2.c<br>
-lcms2/testbed/testcms2.h<br>
-lcms2/testbed/testplugin.c<br>
-lcms2/testbed/testthread.cpp<br>
-lcms2/testbed/toosmall.icc<br>
-lcms2/testbed/zoo_icc.c<br>
-lcms2/utils/common/utils.h<br>
-lcms2/utils/common/vprf.c<br>
-lcms2/utils/common/xgetopt.c<br>
-lcms2/utils/delphi/delphidemo.dpr<br>
-lcms2/utils/delphi/delphidemo.dproj<br>
-lcms2/utils/delphi/delphidemo.res<br>
-lcms2/utils/delphi/demo1.dfm<br>
-lcms2/utils/delphi/demo1.pas<br>
-lcms2/utils/delphi/lcms2.dll<br>
-lcms2/utils/delphi/lcms2dll.pas<br>
-lcms2/utils/jpgicc/Makefile.am<br>
-lcms2/utils/jpgicc/Makefile.in<br>
-lcms2/utils/jpgicc/iccjpeg.c<br>
-lcms2/utils/jpgicc/iccjpeg.h<br>
-lcms2/utils/jpgicc/jpgicc.1<br>
-lcms2/utils/jpgicc/jpgicc.c<br>
-lcms2/utils/linkicc/Makefile.am<br>
-lcms2/utils/linkicc/Makefile.in<br>
-lcms2/utils/linkicc/linkicc.1<br>
-lcms2/utils/linkicc/linkicc.c<br>
-lcms2/utils/matlab/icctrans.c<br>
-lcms2/utils/matlab/lcms_rsp<br>
-lcms2/utils/psicc/Makefile.am<br>
-lcms2/utils/psicc/Makefile.in<br>
-lcms2/utils/psicc/psicc.1<br>
-lcms2/utils/psicc/psicc.c<br>
-lcms2/utils/samples/Makefile.am<br>
-lcms2/utils/samples/Makefile.in<br>
-lcms2/utils/samples/itufax.c<br>
-lcms2/utils/samples/mkcmy.c<br>
-lcms2/utils/samples/mkgrayer.c<br>
-lcms2/utils/samples/mktiff8.c<br>
-lcms2/utils/samples/roundtrip.c<br>
-lcms2/utils/samples/vericc.c<br>
-lcms2/utils/samples/wtpt.1<br>
-lcms2/utils/samples/wtpt.c<br>
-lcms2/utils/tificc/Makefile.am<br>
-lcms2/utils/tificc/Makefile.in<br>
-lcms2/utils/tificc/tifdiff.c<br>
-lcms2/utils/tificc/tificc.1<br>
-lcms2/utils/tificc/tificc.c<br>
-lcms2/utils/transicc/Makefile.am<br>
-lcms2/utils/transicc/Makefile.in<br>
-lcms2/utils/transicc/transicc.1<br>
-lcms2/utils/transicc/transicc.c<br>
-lib/EndOfTask.ps<br>
-lib/FAPIconfig-FCO<br>
-lib/FCOfontmap-PCLPS3<br>
-lib/FCOfontmap-PS3<br>
-lib/Fontmap.ATB<br>
-lib/Fontmap.ATM<br>
-lib/Fontmap.OS2<br>
-lib/Fontmap.OSF<br>
-lib/Fontmap.SGI<br>
-lib/Fontmap.Sol<br>
-lib/Fontmap.URW-136.T1<br>
-lib/Fontmap.URW-136.TT<br>
-lib/Fontmap.Ult<br>
-lib/Fontmap.VMS<br>
-lib/Info-macos.plist<br>
-lib/PDFA_def.ps<br>
-lib/PDFX_def.ps<br>
-lib/acctest.ps<br>
-lib/addxchar.ps<br>
-lib/afmdiff.awk<br>
-lib/align.ps<br>
-lib/bj8.rpd<br>
-lib/bj8gc12f.upp<br>
-lib/bj8hg12f.upp<br>
-lib/bj8oh06n.upp<br>
-lib/bj8pa06n.upp<br>
-lib/bj8pp12f.upp<br>
-lib/bj8ts06n.upp<br>
-lib/bjc610a0.upp<br>
-lib/bjc610a1.upp<br>
-lib/bjc610a2.upp<br>
-lib/bjc610a3.upp<br>
-lib/bjc610a4.upp<br>
-lib/bjc610a5.upp<br>
-lib/bjc610a6.upp<br>
-lib/bjc610a7.upp<br>
-lib/bjc610a8.upp<br>
-lib/bjc610b1.upp<br>
-lib/bjc610b2.upp<br>
-lib/bjc610b3.upp<br>
-lib/bjc610b4.upp<br>
-lib/bjc610b6.upp<br>
-lib/bjc610b7.upp<br>
-lib/bjc610b8.upp<br>
-lib/caption.ps<br>
-lib/cat.ps<br>
-lib/cbjc600.ppd<br>
-lib/cbjc800.ppd<br>
-lib/cdj550.upp<br>
-lib/cdj690.upp<br>
-lib/cdj690ec.upp<br>
-lib/cid2code.ps<br>
-lib/decrypt.ps<br>
-lib/dnj750c.upp<br>
-lib/dnj750m.upp<br>
-lib/docie.ps<br>
-lib/dvipdf<br>
-lib/eps2eps<br>
-lib/eps2eps.bat<br>
-lib/eps2eps.cmd<br>
-lib/font2c<br>
-lib/font2c.bat<br>
-lib/font2c.cmd<br>
-lib/font2c.ps<br>
-lib/font2pcl.ps<br>
-lib/ghostpdf.README<br>
-lib/ghostpdf.cat<br>
-lib/ghostpdf.inf<br>
-lib/ghostpdf.ppd<br>
-lib/gs_ce_e.ps<br>
-lib/gs_cmdl.ps<br>
-lib/gs_il2_e.ps<br>
-lib/gs_kanji.ps<br>
-lib/gs_ksb_e.ps<br>
-lib/gs_l.xbm<br>
-lib/gs_l.xpm<br>
-lib/gs_l_m.xbm<br>
-lib/gs_lgo_e.ps<br>
-lib/gs_lgx_e.ps<br>
-lib/gs_m.xbm<br>
-lib/gs_m.xpm<br>
-lib/gs_m_m.xbm<br>
-lib/gs_pfile.ps<br>
-lib/gs_rdlin.ps<br>
-lib/gs_s.xbm<br>
-lib/gs_s.xpm<br>
-lib/gs_s_m.xbm<br>
-lib/gs_t.xbm<br>
-lib/gs_t.xpm<br>
-lib/gs_t_m.xbm<br>
-lib/gs_wl1_e.ps<br>
-lib/gs_wl2_e.ps<br>
-lib/gs_wl5_e.ps<br>
-lib/gsbj<br>
-lib/gsbj.bat<br>
-lib/gsdj<br>
-lib/gsdj.bat<br>
-lib/gsdj500<br>
-lib/gsdj500.bat<br>
-lib/gslj<br>
-lib/gslj.bat<br>
-lib/gslp<br>
-lib/gslp.bat<br>
-lib/gslp.ps<br>
-lib/gsnd<br>
-lib/gsnd.bat<br>
-lib/gsndt.bat<br>
-lib/gsnup.ps<br>
-lib/gssetgs.bat<br>
-lib/gssetgs32.bat<br>
-lib/gssetgs64.bat<br>
-lib/gst.bat<br>
-lib/gstt.bat<br>
-lib/ht_ccsto.ps<br>
-lib/image-qa.ps<br>
-lib/impath.ps<br>
-lib/jispaper.ps<br>
-lib/jobseparator.ps<br>
-lib/landscap.ps<br>
-lib/level1.ps<br>
-lib/lines.ps<br>
-lib/lp386.bat<br>
-lib/lp386r2.bat<br>
-lib/lpgs.bat<br>
-lib/lpr2.bat<br>
-lib/lprsetup.sh<br>
-lib/markhint.ps<br>
-lib/markpath.ps<br>
-lib/mkcidfm.ps<br>
-lib/necp2x.upp<br>
-lib/necp2x6.upp<br>
-lib/opdfread.ps<br>
-lib/packfile.ps<br>
-lib/pcharstr.ps<br>
-lib/pdf2dsc<br>
-lib/pdf2dsc.bat<br>
-lib/pdf2dsc.ps<br>
-lib/pdf2ps<br>
-lib/pdf2ps.bat<br>
-lib/pdf2ps.cmd<br>
-lib/pdfwrite.ps<br>
-lib/pf2afm<br>
-lib/pf2afm.bat<br>
-lib/pf2afm.cmd<br>
-lib/pf2afm.ps<br>
-lib/pfbtopfa<br>
-lib/pfbtopfa.bat<br>
-lib/pfbtopfa.ps<br>
-lib/pftogsf.bat<br>
-lib/ppath.ps<br>
-lib/pphs<br>
-lib/pphs.ps<br>
-lib/prfont.ps<br>
-lib/printafm<br>
-lib/printafm.ps<br>
-lib/ps2ai.ps<br>
-lib/ps2ascii<br>
-lib/ps2ascii.bat<br>
-lib/ps2ascii.cmd<br>
-lib/ps2ascii.ps<br>
-lib/ps2epsi<br>
-lib/ps2epsi.bat<br>
-lib/ps2epsi.cmd<br>
-lib/ps2epsi.ps<br>
-lib/ps2pdf<br>
-lib/ps2pdf.bat<br>
-lib/ps2pdf.cmd<br>
-lib/ps2pdf12<br>
-lib/ps2pdf12.bat<br>
-lib/ps2pdf12.cmd<br>
-lib/ps2pdf13<br>
-lib/ps2pdf13.bat<br>
-lib/ps2pdf13.cmd<br>
-lib/ps2pdf14<br>
-lib/ps2pdf14.bat<br>
-lib/ps2pdf14.cmd<br>
-lib/ps2pdfwr<br>
-lib/ps2pdfxx.bat<br>
-lib/ps2ps<br>
-lib/ps2ps.bat<br>
-lib/ps2ps.cmd<br>
-lib/ps2ps2<br>
-lib/ps2ps2.bat<br>
-lib/ps2ps2.cmd<br>
-lib/quit.ps<br>
-lib/ras1.upp<br>
-lib/ras24.upp<br>
-lib/ras3.upp<br>
-lib/ras32.upp<br>
-lib/ras4.upp<br>
-lib/ras8m.upp<br>
-lib/rinkj-2200-setup<br>
-lib/rollconv.ps<br>
-lib/showchar.ps<br>
-lib/showpage.ps<br>
-lib/st640ih.upp<br>
-lib/st640ihg.upp<br>
-lib/st640p.upp<br>
-lib/st640pg.upp<br>
-lib/st640pl.upp<br>
-lib/st640plg.upp<br>
-lib/stc.upp<br>
-lib/stc1520h.upp<br>
-lib/stc2.upp<br>
-lib/stc200_h.upp<br>
-lib/stc2_h.upp<br>
-lib/stc2s_h.upp<br>
-lib/stc300.upp<br>
-lib/stc300bl.upp<br>
-lib/stc300bm.upp<br>
-lib/stc500p.upp<br>
-lib/stc500ph.upp<br>
-lib/stc600ih.upp<br>
-lib/stc600p.upp<br>
-lib/stc600pl.upp<br>
-lib/stc640p.upp<br>
-lib/stc800ih.upp<br>
-lib/stc800p.upp<br>
-lib/stc800pl.upp<br>
-lib/stc_h.upp<br>
-lib/stc_l.upp<br>
-lib/stcany.upp<br>
-lib/stcany_h.upp<br>
-lib/stcinfo.ps<br>
-lib/stcolor.ps<br>
-lib/stocht.ps<br>
-lib/traceimg.ps<br>
-lib/traceop.ps<br>
-lib/type1enc.ps<br>
-lib/type1ops.ps<br>
-lib/uninfo.ps<br>
-lib/unix-lpr.sh<br>
-lib/unprot.ps<br>
-lib/viewcmyk.ps<br>
-lib/viewgif.ps<br>
-lib/viewjpeg.ps<br>
-lib/viewmiff.ps<br>
-lib/viewpbm.ps<br>
-lib/viewpcx.ps<br>
-lib/viewps2a.ps<br>
-lib/viewraw.ps<br>
-lib/viewrgb.ps<br>
-lib/wftopfa<br>
-lib/wftopfa.ps<br>
-lib/winmaps.ps<br>
-lib/wmakebat.bat<br>
-lib/wrfont.ps<br>
-lib/zeroline.ps<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/aclocal.m4<br>
-libpng/arm/arm_init.c<br>
-libpng/arm/filter_neon.S<br>
-libpng/arm/filter_neon_intrinsics.c<br>
-libpng/autogen.sh<br>
-libpng/compile<br>
-libpng/config.guess<br>
-libpng/config.h.in<br>
-libpng/config.sub<br>
-libpng/configure<br>
-libpng/configure.ac<br>
-libpng/contrib/README.txt<br>
-libpng/contrib/arm-neon/README<br>
-libpng/contrib/arm-neon/android-ndk.c<br>
-libpng/contrib/arm-neon/linux-auxv.c<br>
-libpng/contrib/arm-neon/linux.c<br>
-libpng/contrib/conftest/README<br>
-libpng/contrib/conftest/read.dfa<br>
-libpng/contrib/conftest/s_read.dfa<br>
-libpng/contrib/conftest/s_write.dfa<br>
-libpng/contrib/conftest/simple.dfa<br>
-libpng/contrib/conftest/write.dfa<br>
-libpng/contrib/examples/README.txt<br>
-libpng/contrib/examples/iccfrompng.c<br>
-libpng/contrib/examples/pngpixel.c<br>
-libpng/contrib/examples/pngtopng.c<br>
-libpng/contrib/gregbook/COPYING<br>
-libpng/contrib/gregbook/LICENSE<br>
-libpng/contrib/gregbook/Makefile.mingw32<br>
-libpng/contrib/gregbook/Makefile.sgi<br>
-libpng/contrib/gregbook/Makefile.unx<br>
-libpng/contrib/gregbook/Makefile.w32<br>
-libpng/contrib/gregbook/README<br>
-libpng/contrib/gregbook/makevms.com<br>
-libpng/contrib/gregbook/readpng.c<br>
-libpng/contrib/gregbook/readpng.h<br>
-libpng/contrib/gregbook/readpng2.c<br>
-libpng/contrib/gregbook/readpng2.h<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/toucan.png<br>
-libpng/contrib/gregbook/wpng.c<br>
-libpng/contrib/gregbook/writepng.c<br>
-libpng/contrib/gregbook/writepng.h<br>
-libpng/contrib/libtests/fakepng.c<br>
-libpng/contrib/libtests/gentests.sh<br>
-libpng/contrib/libtests/makepng.c<br>
-libpng/contrib/libtests/pngimage.c<br>
-libpng/contrib/libtests/pngstest.c<br>
-libpng/contrib/libtests/pngunknown.c<br>
-libpng/contrib/libtests/pngvalid.c<br>
-libpng/contrib/libtests/readpng.c<br>
-libpng/contrib/libtests/tarith.c<br>
-libpng/contrib/libtests/timepng.c<br>
-libpng/contrib/pngminim/README<br>
-libpng/contrib/pngminim/decoder/README<br>
-libpng/contrib/pngminim/decoder/makefile<br>
-libpng/contrib/pngminim/decoder/pngusr.dfa<br>
-libpng/contrib/pngminim/decoder/pngusr.h<br>
-libpng/contrib/pngminim/encoder/README<br>
-libpng/contrib/pngminim/encoder/makefile<br>
-libpng/contrib/pngminim/encoder/pngusr.dfa<br>
-libpng/contrib/pngminim/encoder/pngusr.h<br>
-libpng/contrib/pngminim/preader/README<br>
-libpng/contrib/pngminim/preader/makefile<br>
-libpng/contrib/pngminim/preader/pngusr.dfa<br>
-libpng/contrib/pngminim/preader/pngusr.h<br>
-libpng/contrib/pngminus/README<br>
-libpng/contrib/pngminus/makefile.std<br>
-libpng/contrib/pngminus/makefile.tc3<br>
-libpng/contrib/pngminus/makevms.com<br>
-libpng/contrib/pngminus/png2pnm.bat<br>
-libpng/contrib/pngminus/png2pnm.c<br>
-libpng/contrib/pngminus/png2pnm.sh<br>
-libpng/contrib/pngminus/pngminus.bat<br>
-libpng/contrib/pngminus/pngminus.sh<br>
-libpng/contrib/pngminus/pnm2png.bat<br>
-libpng/contrib/pngminus/pnm2png.c<br>
-libpng/contrib/pngminus/pnm2png.sh<br>
-libpng/contrib/pngsuite/README<br>
-libpng/contrib/pngsuite/basn0g01.png<br>
-libpng/contrib/pngsuite/basn0g02.png<br>
-libpng/contrib/pngsuite/basn0g04.png<br>
-libpng/contrib/pngsuite/basn0g08.png<br>
-libpng/contrib/pngsuite/basn0g16.png<br>
-libpng/contrib/pngsuite/basn2c08.png<br>
-libpng/contrib/pngsuite/basn2c16.png<br>
-libpng/contrib/pngsuite/basn3p01.png<br>
-libpng/contrib/pngsuite/basn3p02.png<br>
-libpng/contrib/pngsuite/basn3p04.png<br>
-libpng/contrib/pngsuite/basn3p08.png<br>
-libpng/contrib/pngsuite/basn4a08.png<br>
-libpng/contrib/pngsuite/basn4a16.png<br>
-libpng/contrib/pngsuite/basn6a08.png<br>
-libpng/contrib/pngsuite/basn6a16.png<br>
-libpng/contrib/pngsuite/ftbbn0g01.png<br>
-libpng/contrib/pngsuite/ftbbn0g02.png<br>
-libpng/contrib/pngsuite/ftbbn0g04.png<br>
-libpng/contrib/pngsuite/ftbbn2c16.png<br>
-libpng/contrib/pngsuite/ftbbn3p08.png<br>
-libpng/contrib/pngsuite/ftbgn2c16.png<br>
-libpng/contrib/pngsuite/ftbgn3p08.png<br>
-libpng/contrib/pngsuite/ftbrn2c08.png<br>
-libpng/contrib/pngsuite/ftbwn0g16.png<br>
-libpng/contrib/pngsuite/ftbwn3p08.png<br>
-libpng/contrib/pngsuite/ftbyn3p08.png<br>
-libpng/contrib/pngsuite/ftp0n0g08.png<br>
-libpng/contrib/pngsuite/ftp0n2c08.png<br>
-libpng/contrib/pngsuite/ftp0n3p08.png<br>
-libpng/contrib/pngsuite/ftp1n3p08.png<br>
-libpng/contrib/tools/README.txt<br>
-libpng/contrib/tools/checksum-icc.c<br>
-libpng/contrib/tools/chkfmt<br>
-libpng/contrib/tools/cvtcolor.c<br>
-libpng/contrib/tools/intgamma.sh<br>
-libpng/contrib/tools/makesRGB.c<br>
-libpng/contrib/tools/png-fix-itxt.c<br>
-libpng/contrib/tools/pngfix.c<br>
-libpng/contrib/tools/sRGB.h<br>
-libpng/contrib/visupng/PngFile.c<br>
-libpng/contrib/visupng/PngFile.h<br>
-libpng/contrib/visupng/README.txt<br>
-libpng/contrib/visupng/VisualPng.c<br>
-libpng/contrib/visupng/VisualPng.dsp<br>
-libpng/contrib/visupng/VisualPng.dsw<br>
-libpng/contrib/visupng/VisualPng.ico<br>
-libpng/contrib/visupng/VisualPng.png<br>
-libpng/contrib/visupng/VisualPng.rc<br>
-libpng/contrib/visupng/cexcept.h<br>
-libpng/contrib/visupng/resource.h<br>
-libpng/depcomp<br>
-libpng/example.c<br>
-libpng/install-sh<br>
-libpng/libpng-config.in<br>
-libpng/libpng-manual.txt<br>
-libpng/libpng.3<br>
-libpng/libpng.pc.in<br>
-libpng/libpngpf.3<br>
-libpng/ltmain.sh<br>
-libpng/missing<br>
-libpng/png.5<br>
-libpng/png.c<br>
-libpng/png.h<br>
-libpng/pngbar.jpg<br>
-libpng/pngbar.png<br>
-libpng/pngconf.h<br>
-libpng/pngdebug.h<br>
-libpng/pngerror.c<br>
-libpng/pngget.c<br>
-libpng/pnginfo.h<br>
-libpng/pngmem.c<br>
-libpng/pngnow.png<br>
-libpng/pngpread.c<br>
-libpng/pngpriv.h<br>
-libpng/pngread.c<br>
-libpng/pngrio.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/pngusr.dfa<br>
-libpng/pngwio.c<br>
-libpng/pngwrite.c<br>
-libpng/pngwtran.c<br>
-libpng/pngwutil.c<br>
-libpng/projects/owatcom/libpng.tgt<br>
-libpng/projects/owatcom/libpng.wpj<br>
-libpng/projects/owatcom/pngconfig.mak<br>
-libpng/projects/owatcom/pngstest.tgt<br>
-libpng/projects/owatcom/pngtest.tgt<br>
-libpng/projects/owatcom/pngvalid.tgt<br>
-libpng/projects/visualc71/PRJ0041.mak<br>
-libpng/projects/visualc71/README.txt<br>
-libpng/projects/visualc71/README_zlib.txt<br>
-libpng/projects/visualc71/libpng.sln<br>
-libpng/projects/visualc71/libpng.vcproj<br>
-libpng/projects/visualc71/pngtest.vcproj<br>
-libpng/projects/visualc71/zlib.vcproj<br>
-libpng/projects/vstudio/WARNING<br>
-libpng/projects/vstudio/libpng/libpng.vcxproj<br>
-libpng/projects/vstudio/pnglibconf/pnglibconf.vcxproj<br>
-libpng/projects/vstudio/pngstest/pngstest.vcxproj<br>
-libpng/projects/vstudio/pngtest/pngtest.vcxproj<br>
-libpng/projects/vstudio/pngunknown/pngunknown.vcxproj<br>
-libpng/projects/vstudio/pngvalid/pngvalid.vcxproj<br>
-libpng/projects/vstudio/readme.txt<br>
-libpng/projects/vstudio/vstudio.sln<br>
-libpng/projects/vstudio/zlib.props<br>
-libpng/projects/vstudio/zlib/zlib.vcxproj<br>
-libpng/scripts/README.txt<br>
-libpng/scripts/SCOPTIONS.ppc<br>
-libpng/scripts/checksym.awk<br>
-libpng/scripts/def.c<br>
-libpng/scripts/descrip.mms<br>
-libpng/scripts/dfn.awk<br>
-libpng/scripts/intprefix.c<br>
-libpng/scripts/libpng-config-body.in<br>
-libpng/scripts/libpng-config-head.in<br>
-libpng/scripts/libpng.pc.in<br>
-libpng/scripts/libtool.m4<br>
-libpng/scripts/ltoptions.m4<br>
-libpng/scripts/ltsugar.m4<br>
-libpng/scripts/ltversion.m4<br>
-libpng/scripts/lt~obsolete.m4<br>
-libpng/scripts/macro.lst<br>
-libpng/scripts/makefile.32sunu<br>
-libpng/scripts/makefile.64sunu<br>
-libpng/scripts/makefile.acorn<br>
-libpng/scripts/makefile.aix<br>
-libpng/scripts/makefile.amiga<br>
-libpng/scripts/makefile.atari<br>
-libpng/scripts/makefile.bc32<br>
-libpng/scripts/makefile.beos<br>
-libpng/scripts/makefile.bor<br>
-libpng/scripts/makefile.cegcc<br>
-libpng/scripts/makefile.darwin<br>
-libpng/scripts/makefile.dec<br>
-libpng/scripts/makefile.dj2<br>
-libpng/scripts/makefile.freebsd<br>
-libpng/scripts/makefile.gcc<br>
-libpng/scripts/makefile.hp64<br>
-libpng/scripts/makefile.hpgcc<br>
-libpng/scripts/makefile.hpux<br>
-libpng/scripts/makefile.ibmc<br>
-libpng/scripts/makefile.intel<br>
-libpng/scripts/makefile.knr<br>
-libpng/scripts/makefile.linux<br>
-libpng/scripts/makefile.mips<br>
-libpng/scripts/makefile.msc<br>
-libpng/scripts/makefile.msys<br>
-libpng/scripts/makefile.ne12bsd<br>
-libpng/scripts/makefile.netbsd<br>
-libpng/scripts/makefile.openbsd<br>
-libpng/scripts/makefile.sco<br>
-libpng/scripts/makefile.sggcc<br>
-libpng/scripts/makefile.sgi<br>
-libpng/scripts/makefile.so9<br>
-libpng/scripts/makefile.solaris<br>
-libpng/scripts/makefile.solaris-x86<br>
-libpng/scripts/makefile.std<br>
-libpng/scripts/makefile.sunos<br>
-libpng/scripts/makefile.tc3<br>
-libpng/scripts/makefile.vcwin32<br>
-libpng/scripts/makevms.com<br>
-libpng/scripts/options.awk<br>
-libpng/scripts/pnglibconf.dfa<br>
-libpng/scripts/pnglibconf.h.prebuilt<br>
-libpng/scripts/pnglibconf.mak<br>
-libpng/scripts/pngwin.rc<br>
-libpng/scripts/prefix.c<br>
-libpng/scripts/smakefile.ppc<br>
-libpng/scripts/sym.c<br>
-libpng/scripts/symbols.c<br>
-libpng/scripts/symbols.def<br>
-libpng/scripts/vers.c<br>
-libpng/test-driver<br>
-libpng/tests/pngimage-full<br>
-libpng/tests/pngimage-quick<br>
-libpng/tests/pngstest<br>
-libpng/tests/pngstest-0g01<br>
-libpng/tests/pngstest-0g02<br>
-libpng/tests/pngstest-0g04<br>
-libpng/tests/pngstest-0g08<br>
-libpng/tests/pngstest-0g16<br>
-libpng/tests/pngstest-2c08<br>
-libpng/tests/pngstest-2c16<br>
-libpng/tests/pngstest-3p01<br>
-libpng/tests/pngstest-3p02<br>
-libpng/tests/pngstest-3p04<br>
-libpng/tests/pngstest-3p08<br>
-libpng/tests/pngstest-4a08<br>
-libpng/tests/pngstest-4a16<br>
-libpng/tests/pngstest-6a08<br>
-libpng/tests/pngstest-6a16<br>
-libpng/tests/pngstest-error<br>
-libpng/tests/pngtest<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-size<br>
-libpng/tests/pngvalid-progressive-interlace-standard<br>
-libpng/tests/pngvalid-progressive-interlace-transform<br>
-libpng/tests/pngvalid-progressive-standard<br>
-libpng/tests/pngvalid-standard<br>
-main/pcl6_gcc.mak<br>
-main/pcl6_msvc.mak<br>
-man/de/dvipdf.1<br>
-man/de/font2c.1<br>
-man/de/gsnd.1<br>
-man/de/pdf2dsc.1<br>
-man/de/pdf2ps.1<br>
-man/de/printafm.1<br>
-man/de/ps2ascii.1<br>
-man/de/ps2pdf.1<br>
-man/de/ps2ps.1<br>
-man/de/wftopfa.1<br>
-man/dvipdf.1<br>
-man/eps2eps.1<br>
-man/font2c.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>
-man/wftopfa.1<br>
-old-stuff/COPYING<br>
-old-stuff/Makefile<br>
-old-stuff/autogen.sh<br>
-old-stuff/common/cp.bat<br>
-old-stuff/common/gccdefs.mak<br>
-old-stuff/common/generic.mak<br>
-old-stuff/common/msvc_top.mak<br>
-old-stuff/common/msvcdefs.mak<br>
-old-stuff/common/mv.bat<br>
-old-stuff/common/pcdefs.mak<br>
-old-stuff/common/rm.bat<br>
-old-stuff/common/sgidefs.mak<br>
-old-stuff/common/ugcc_top.mak<br>
-old-stuff/common/unixdefs.mak<br>
-old-stuff/config.mak.in<br>
-old-stuff/configure.ac<br>
-old-stuff/main/pcl6_gcc.mak<br>
-old-stuff/main/pcl6_msvc.mak<br>
-old-stuff/win32/GhostPDL.sln<br>
-old-stuff/win32/ReadMe.txt<br>
-old-stuff/win32/language_switch.vcproj<br>
-old-stuff/win32/pcl.vcproj<br>
-old-stuff/win32/xps.vcproj<br>
-old-stuff/winrt/GhostPDL.sln<br>
-old-stuff/xcode/GhostPDL/GhostPDL.xcodeproj/project.pbxproj<br>
-old-stuff/xcode/GhostPDL/GhostPDL.xcodeproj/project.xcworkspace/contents.xcworkspacedata<br>
-old-stuff/xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/GhostPDL.xcscheme<br>
-old-stuff/xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/ghostscript.xcscheme<br>
-old-stuff/xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/language_switch.xcscheme<br>
-old-stuff/xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/pcl.xcscheme<br>
-old-stuff/xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/svg.xcscheme<br>
-old-stuff/xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/xps.xcscheme<br>
-old-stuff/xcode/Makefile<br>
-old-stuff/xcode/clang_wrapper.c<br>
-old-stuff/xcode/clang_wrapper.sh<br>
-old-stuff/xcode/resolve.sh<br>
-openjpeg/AUTHORS<br>
-openjpeg/CHANGES<br>
-openjpeg/LICENSE<br>
-openjpeg/NEWS<br>
-openjpeg/THANKS<br>
-openjpeg/src/lib/openjp2/CMakeLists.txt<br>
-openjpeg/src/lib/openjp2/bio.c<br>
-openjpeg/src/lib/openjp2/bio.h<br>
-openjpeg/src/lib/openjp2/cidx_manager.c<br>
-openjpeg/src/lib/openjp2/cidx_manager.h<br>
-openjpeg/src/lib/openjp2/cio.c<br>
-openjpeg/src/lib/openjp2/cio.h<br>
-openjpeg/src/lib/openjp2/dwt.c<br>
-openjpeg/src/lib/openjp2/dwt.h<br>
-openjpeg/src/lib/openjp2/event.c<br>
-openjpeg/src/lib/openjp2/event.h<br>
-openjpeg/src/lib/openjp2/function_list.c<br>
-openjpeg/src/lib/openjp2/function_list.h<br>
-openjpeg/src/lib/openjp2/image.c<br>
-openjpeg/src/lib/openjp2/image.h<br>
-openjpeg/src/lib/openjp2/indexbox_manager.h<br>
-openjpeg/src/lib/openjp2/invert.c<br>
-openjpeg/src/lib/openjp2/invert.h<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/libopenjp2.pc.cmake.in<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/openjpeg.c<br>
-openjpeg/src/lib/openjp2/openjpeg.h<br>
-openjpeg/src/lib/openjp2/opj_clock.c<br>
-openjpeg/src/lib/openjp2/opj_clock.h<br>
-openjpeg/src/lib/openjp2/opj_codec.h<br>
-openjpeg/src/lib/openjp2/opj_config.h<br>
-openjpeg/src/lib/openjp2/opj_config.h.cmake.in<br>
-openjpeg/src/lib/openjp2/opj_config_private.h<br>
-openjpeg/src/lib/openjp2/opj_config_private.h.cmake.in<br>
-openjpeg/src/lib/openjp2/opj_includes.h<br>
-openjpeg/src/lib/openjp2/opj_intmath.h<br>
-openjpeg/src/lib/openjp2/opj_inttypes.h<br>
-openjpeg/src/lib/openjp2/opj_malloc.h<br>
-openjpeg/src/lib/openjp2/opj_stdint.h<br>
-openjpeg/src/lib/openjp2/phix_manager.c<br>
-openjpeg/src/lib/openjp2/pi.c<br>
-openjpeg/src/lib/openjp2/pi.h<br>
-openjpeg/src/lib/openjp2/ppix_manager.c<br>
-openjpeg/src/lib/openjp2/raw.c<br>
-openjpeg/src/lib/openjp2/raw.h<br>
-openjpeg/src/lib/openjp2/t1.c<br>
-openjpeg/src/lib/openjp2/t1.h<br>
-openjpeg/src/lib/openjp2/t1_generate_luts.c<br>
-openjpeg/src/lib/openjp2/t1_luts.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/tgt.c<br>
-openjpeg/src/lib/openjp2/tgt.h<br>
-openjpeg/src/lib/openjp2/thix_manager.c<br>
-openjpeg/src/lib/openjp2/tpix_manager.c<br>
-pcl/Anomalies.txt<br>
-pcl/COPYING.AFPL<br>
-pcl/LICENSE<br>
-pcl/NEWS<br>
-pcl/PCL5C_Color_Laserjet_4700_Differences.xls<br>
-pcl/README.txt<br>
-pcl/pcbiptrn.c<br>
-pcl/pcbiptrn.h<br>
-pcl/pccid.c<br>
-pcl/pccid.h<br>
-pcl/pccolor.c<br>
-pcl/pccoord.h<br>
-pcl/pccprint.c<br>
-pcl/pccsbase.c<br>
-pcl/pccsbase.h<br>
-pcl/pcdict.h<br>
-pcl/pcdither.c<br>
-pcl/pcdither.h<br>
-pcl/pcdraw.c<br>
-pcl/pcdraw.h<br>
-pcl/pcfont.c<br>
-pcl/pcfont.h<br>
-pcl/pcfontpg.c<br>
-pcl/pcfontst.h<br>
-pcl/pcfrgrnd.c<br>
-pcl/pcfrgrnd.h<br>
-pcl/pcfsel.c<br>
-pcl/pcfsel.h<br>
-pcl/pcht.c<br>
-pcl/pcht.h<br>
-pcl/pcident.c<br>
-pcl/pcident.h<br>
-pcl/pcimpl.c<br>
-pcl/pcindxed.c<br>
-pcl/pcindxed.h<br>
-pcl/pcjob.c<br>
-pcl/pcl.mak<br>
-pcl/pcl/Anomalies.txt<br>
-pcl/pcl/PCL5C_Color_Laserjet_4700_Differences.xls<br>
-pcl/pcl/pcbiptrn.c<br>
-pcl/pcl/pcbiptrn.h<br>
-pcl/pcl/pccid.c<br>
-pcl/pcl/pccid.h<br>
-pcl/pcl/pccolor.c<br>
-pcl/pcl/pccoord.h<br>
-pcl/pcl/pccprint.c<br>
-pcl/pcl/pccsbase.c<br>
-pcl/pcl/pccsbase.h<br>
-pcl/pcl/pcdict.h<br>
-pcl/pcl/pcdither.c<br>
-pcl/pcl/pcdither.h<br>
-pcl/pcl/pcdraw.c<br>
-pcl/pcl/pcdraw.h<br>
-pcl/pcl/pcfont.c<br>
-pcl/pcl/pcfont.h<br>
-pcl/pcl/pcfontpg.c<br>
-pcl/pcl/pcfontst.h<br>
-pcl/pcl/pcfrgrnd.c<br>
-pcl/pcl/pcfrgrnd.h<br>
-pcl/pcl/pcfsel.c<br>
-pcl/pcl/pcfsel.h<br>
-pcl/pcl/pcht.c<br>
-pcl/pcl/pcht.h<br>
-pcl/pcl/pcident.c<br>
-pcl/pcl/pcident.h<br>
-pcl/pcl/pcimpl.c<br>
-pcl/pcl/pcindxed.c<br>
-pcl/pcl/pcindxed.h<br>
-pcl/pcl/pcjob.c<br>
-pcl/pcl/pcl.mak<br>
-pcl/pcl/pcl_top.mak<br>
-pcl/pcl/pclookup.c<br>
-pcl/pcl/pclookup.h<br>
-pcl/pcl/pcmacros.c<br>
-pcl/pcl/pcmisc.c<br>
-pcl/pcl/pcmtx3.c<br>
-pcl/pcl/pcmtx3.h<br>
-pcl/pcl/pcommand.c<br>
-pcl/pcl/pcommand.h<br>
-pcl/pcl/pcpage.c<br>
-pcl/pcl/pcpage.h<br>
-pcl/pcl/pcpalet.c<br>
-pcl/pcl/pcpalet.h<br>
-pcl/pcl/pcparam.h<br>
-pcl/pcl/pcparse.c<br>
-pcl/pcl/pcparse.h<br>
-pcl/pcl/pcpatrn.c<br>
-pcl/pcl/pcpatrn.h<br>
-pcl/pcl/pcpattyp.h<br>
-pcl/pcl/pcpatxfm.c<br>
-pcl/pcl/pcpatxfm.h<br>
-pcl/pcl/pcrect.c<br>
-pcl/pcl/pcsfont.c<br>
-pcl/pcl/pcstate.h<br>
-pcl/pcl/pcstatus.c<br>
-pcl/pcl/pcsymbol.c<br>
-pcl/pcl/pcsymbol.h<br>
-pcl/pcl/pctext.c<br>
-pcl/pcl/pctop.c<br>
-pcl/pcl/pctop.h<br>
-pcl/pcl/pctpm.h<br>
-pcl/pcl/pcuptrn.c<br>
-pcl/pcl/pcuptrn.h<br>
-pcl/pcl/pcursor.c<br>
-pcl/pcl/pcursor.h<br>
-pcl/pcl/pcwhtidx.c<br>
-pcl/pcl/pcwhtidx.h<br>
-pcl/pcl/pcxfmst.h<br>
-pcl/pcl/pgchar.c<br>
-pcl/pcl/pgcolor.c<br>
-pcl/pcl/pgconfig.c<br>
-pcl/pcl/pgdraw.c<br>
-pcl/pcl/pgdraw.h<br>
-pcl/pcl/pgfdata.c<br>
-pcl/pcl/pgfdata.h<br>
-pcl/pcl/pgfont.c<br>
-pcl/pcl/pgfont.h<br>
-pcl/pcl/pgframe.c<br>
-pcl/pcl/pggeom.c<br>
-pcl/pcl/pggeom.h<br>
-pcl/pcl/pginit.c<br>
-pcl/pcl/pginit.h<br>
-pcl/pcl/pglabel.c<br>
-pcl/pcl/pglfill.c<br>
-pcl/pcl/pgmand.h<br>
-pcl/pcl/pgmisc.c<br>
-pcl/pcl/pgmisc.h<br>
-pcl/pcl/pgparse.c<br>
-pcl/pcl/pgpoly.c<br>
-pcl/pcl/pgstate.h<br>
-pcl/pcl/pgvector.c<br>
-pcl/pcl/rtgmode.c<br>
-pcl/pcl/rtgmode.h<br>
-pcl/pcl/rtmisc.c<br>
-pcl/pcl/rtmisc.h<br>
-pcl/pcl/rtraster.c<br>
-pcl/pcl/rtraster.h<br>
-pcl/pcl/rtrstcmp.c<br>
-pcl/pcl/rtrstcmp.h<br>
-pcl/pcl/rtrstst.h<br>
-pcl/pcl_top.mak<br>
-pcl/pclookup.c<br>
-pcl/pclookup.h<br>
-pcl/pcmacros.c<br>
-pcl/pcmisc.c<br>
-pcl/pcmtx3.c<br>
-pcl/pcmtx3.h<br>
-pcl/pcommand.c<br>
-pcl/pcommand.h<br>
-pcl/pcpage.c<br>
-pcl/pcpage.h<br>
-pcl/pcpalet.c<br>
-pcl/pcpalet.h<br>
-pcl/pcparam.h<br>
-pcl/pcparse.c<br>
-pcl/pcparse.h<br>
-pcl/pcpatrn.c<br>
-pcl/pcpatrn.h<br>
-pcl/pcpattyp.h<br>
-pcl/pcpatxfm.c<br>
-pcl/pcpatxfm.h<br>
-pcl/pcrect.c<br>
-pcl/pcsfont.c<br>
-pcl/pcstate.h<br>
-pcl/pcstatus.c<br>
-pcl/pcsymbol.c<br>
-pcl/pcsymbol.h<br>
-pcl/pctext.c<br>
-pcl/pctop.c<br>
-pcl/pctop.h<br>
-pcl/pctpm.h<br>
-pcl/pcuptrn.c<br>
-pcl/pcuptrn.h<br>
-pcl/pcursor.c<br>
-pcl/pcursor.h<br>
-pcl/pcwhtidx.c<br>
-pcl/pcwhtidx.h<br>
-pcl/pcxfmst.h<br>
-pcl/pgchar.c<br>
-pcl/pgcolor.c<br>
-pcl/pgconfig.c<br>
-pcl/pgdraw.c<br>
-pcl/pgdraw.h<br>
-pcl/pgfdata.c<br>
-pcl/pgfdata.h<br>
-pcl/pgfont.c<br>
-pcl/pgfont.h<br>
-pcl/pgframe.c<br>
-pcl/pggeom.c<br>
-pcl/pggeom.h<br>
-pcl/pginit.c<br>
-pcl/pginit.h<br>
-pcl/pglabel.c<br>
-pcl/pglfill.c<br>
-pcl/pgmand.h<br>
-pcl/pgmisc.c<br>
-pcl/pgmisc.h<br>
-pcl/pgparse.c<br>
-pcl/pgpoly.c<br>
-pcl/pgstate.h<br>
-pcl/pgvector.c<br>
-pcl/pl/pjparse.c<br>
-pcl/pl/pjparse.h<br>
-pcl/pl/pjparsei.c<br>
-pcl/pl/pjtop.c<br>
-pcl/pl/pjtop.h<br>
-pcl/pl/pl.mak<br>
-pcl/pl/plalloc.c<br>
-pcl/pl/plalloc.h<br>
-pcl/pl/plapi.h<br>
-pcl/pl/plchar.c<br>
-pcl/pl/plchar.h<br>
-pcl/pl/pldebug.h<br>
-pcl/pl/pldict.c<br>
-pcl/pl/pldict.h<br>
-pcl/pl/pldraw.c<br>
-pcl/pl/pldraw.h<br>
-pcl/pl/plfapi.c<br>
-pcl/pl/plfapi.h<br>
-pcl/pl/plfont.c<br>
-pcl/pl/plfont.h<br>
-pcl/pl/plftable.c<br>
-pcl/pl/plftable.h<br>
-pcl/pl/plht.c<br>
-pcl/pl/plht.h<br>
-pcl/pl/plimpl.c<br>
-pcl/pl/pllfont.c<br>
-pcl/pl/pllfont.h<br>
-pcl/pl/plmain.c<br>
-pcl/pl/plmain.h<br>
-pcl/pl/plparse.h<br>
-pcl/pl/plplatf.c<br>
-pcl/pl/plplatf.h<br>
-pcl/pl/plplatfps.c<br>
-pcl/pl/plromfs.mak<br>
-pcl/pl/plsymbol.c<br>
-pcl/pl/plsymbol.h<br>
-pcl/pl/pltop.c<br>
-pcl/pl/pltop.h<br>
-pcl/pl/pltoputl.c<br>
-pcl/pl/pltoputl.h<br>
-pcl/pl/pluchar.c<br>
-pcl/pl/plufont.c<br>
-pcl/pl/plufstlp.c<br>
-pcl/pl/plufstlp.h<br>
-pcl/pl/plufstlp1.c<br>
-pcl/pl/plulfont.c<br>
-pcl/pl/plvalue.c<br>
-pcl/pl/plvalue.h<br>
-pcl/pl/plvocab.c<br>
-pcl/pl/plvocab.h<br>
-pcl/pl/plwimg.c<br>
-pcl/pl/plwimg.h<br>
-pcl/pl/plwmainc.c<br>
-pcl/pl/plwreg.c<br>
-pcl/pl/plwreg.h<br>
-pcl/pl/plwres.h<br>
-pcl/pl/realmain.c<br>
-pcl/pxl/PXL_Color_Laserjet_4700_Differences.xls<br>
-pcl/pxl/pxasm.bat<br>
-pcl/pxl/pxasm.ps<br>
-pcl/pxl/pxattr.h<br>
-pcl/pxl/pxbfont.c<br>
-pcl/pxl/pxbfont.h<br>
-pcl/pxl/pxbfont.ps<br>
-pcl/pxl/pxcet.txt<br>
-pcl/pxl/pxdict.h<br>
-pcl/pxl/pxdiff.txt<br>
-pcl/pxl/pxenum.h<br>
-pcl/pxl/pxerrors.c<br>
-pcl/pxl/pxerrors.h<br>
-pcl/pxl/pxffont.c<br>
-pcl/pxl/pxfont.c<br>
-pcl/pxl/pxfont.h<br>
-pcl/pxl/pxfts.txt<br>
-pcl/pxl/pxgstate.c<br>
-pcl/pxl/pxgstate.h<br>
-pcl/pxl/pximage.c<br>
-pcl/pxl/pximpl.c<br>
-pcl/pxl/pxink.c<br>
-pcl/pxl/pxl.mak<br>
-pcl/pxl/pxlib.txt<br>
-pcl/pxl/pxoper.h<br>
-pcl/pxl/pxpaint.c<br>
-pcl/pxl/pxparse.c<br>
-pcl/pxl/pxparse.h<br>
-pcl/pxl/pxptable.c<br>
-pcl/pxl/pxptable.h<br>
-pcl/pxl/pxpthr.c<br>
-pcl/pxl/pxpthr.h<br>
-pcl/pxl/pxsessio.c<br>
-pcl/pxl/pxspec.txt<br>
-pcl/pxl/pxstate.c<br>
-pcl/pxl/pxstate.h<br>
-pcl/pxl/pxstream.c<br>
-pcl/pxl/pxsymbol.ps<br>
-pcl/pxl/pxsymbol.psc<br>
-pcl/pxl/pxsymbol.psh<br>
-pcl/pxl/pxtag.h<br>
-pcl/pxl/pxtop.c<br>
-pcl/pxl/pxvalue.c<br>
-pcl/pxl/pxvalue.h<br>
-pcl/pxl/pxvendor.c<br>
-pcl/pxl/pxvendor.h<br>
-pcl/rtgmode.c<br>
-pcl/rtgmode.h<br>
-pcl/rtmisc.c<br>
-pcl/rtmisc.h<br>
-pcl/rtraster.c<br>
-pcl/rtraster.h<br>
-pcl/rtrstcmp.c<br>
-pcl/rtrstcmp.h<br>
-pcl/rtrstst.h<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff.sln<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff.vb<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff.vbproj<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Application.Designer.vb<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Application.myapp<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/AssemblyInfo.vb<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Resources.Designer.vb<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Resources.resx<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Settings.Designer.vb<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Settings.settings<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Acrobat2Tiff.exe<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Acrobat2Tiff.vshost.exe<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Acrobat2Tiff.xml<br>
-pcl/tools/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Interop.Acrobat.dll<br>
-pcl/tools/GOT/README<br>
-pcl/tools/GOT/detag.c<br>
-pcl/tools/GOT/dotags.sh<br>
-pcl/tools/GOT/tagimage.c<br>
-pcl/tools/bitfont.pcl<br>
-pcl/tools/bitfonts.pxl<br>
-pcl/tools/cat_url.py<br>
-pcl/tools/check_deps.py<br>
-pcl/tools/cmpi/Makefile<br>
-pcl/tools/cmpi/Makefile.in<br>
-pcl/tools/cmpi/README<br>
-pcl/tools/cmpi/cmpi.bkl<br>
-pcl/tools/cmpi/cmpi.cpp<br>
-pcl/tools/cmpi/cmpi.dsp<br>
-pcl/tools/cmpi/cmpi.dsw<br>
-pcl/tools/cmpi/cmpi.pro<br>
-pcl/tools/cmpi/cmpi.rc<br>
-pcl/tools/cmpi/cmpi.sln<br>
-pcl/tools/cmpi/cmpi.suo<br>
-pcl/tools/cmpi/cmpi.vcp<br>
-pcl/tools/cmpi/cmpi.vcproj<br>
-pcl/tools/cmpi/cmpi.vcw<br>
-pcl/tools/cmpi/descrip.mms<br>
-pcl/tools/cmpi/makefile.bcc<br>
-pcl/tools/cmpi/makefile.dmc<br>
-pcl/tools/cmpi/makefile.dms<br>
-pcl/tools/cmpi/makefile.dos<br>
-pcl/tools/cmpi/makefile.gcc<br>
-pcl/tools/cmpi/makefile.sc<br>
-pcl/tools/cmpi/makefile.unx<br>
-pcl/tools/cmpi/makefile.va<br>
-pcl/tools/cmpi/makefile.vc<br>
-pcl/tools/cmpi/makefile.wat<br>
-pcl/tools/docov.pl<br>
-pcl/tools/fills.pcl<br>
-pcl/tools/fontpage.pcl<br>
-pcl/tools/fonts.pcl<br>
-pcl/tools/fonts.pxl<br>
-pcl/tools/frs96.pxl<br>
-pcl/tools/gl-chars.pcl<br>
-pcl/tools/gl2_chars.pl<br>
-pcl/tools/grashopp.pcl<br>
-pcl/tools/grid.pcl<br>
-pcl/tools/label.tst<br>
-pcl/tools/lineprinter.pcl<br>
-pcl/tools/make_snapshot.sh<br>
-pcl/tools/makeromttf.py<br>
-pcl/tools/null.pxl<br>
-pcl/tools/opaque.pcl<br>
-pcl/tools/origins.pcl<br>
-pcl/tools/owl.pcl<br>
-pcl/tools/owl2.pcl<br>
-pcl/tools/pattern.pcl<br>
-pcl/tools/pattern.pxl<br>
-pcl/tools/pcl2pdf<br>
-pcl/tools/pcl2pdf.bat<br>
-pcl/tools/pcl2pdfwr<br>
-pcl/tools/pcl2pdfwr.bat<br>
-pcl/tools/plot2pdf.sh<br>
-pcl/tools/pxlasm.py<br>
-pcl/tools/pxldis.py<br>
-pcl/tools/regress.sh<br>
-pcl/tools/revlist.py<br>
-pcl/tools/smoke_baseline.txt<br>
-pcl/tools/smoke_check.sh<br>
-pcl/tools/smoke_update.sh<br>
-pcl/tools/suite.tcl<br>
-pcl/tools/tiger.px3<br>
-pcl/tools/tiger.svg<br>
-pcl/tools/tt2pcl.c<br>
-pcl/tools/vasarely.px3<br>
-pcl/urwfonts/A028-Ext.ttf<br>
-pcl/urwfonts/A028-Med.ttf<br>
-pcl/urwfonts/A030-Bol.ttf<br>
-pcl/urwfonts/A030-BolIta.ttf<br>
-pcl/urwfonts/A030-Ita.ttf<br>
-pcl/urwfonts/A030-Reg.ttf<br>
-pcl/urwfonts/AntiqueOlive-Bol.ttf<br>
-pcl/urwfonts/AntiqueOlive-Ita.ttf<br>
-pcl/urwfonts/AntiqueOlive-Reg.ttf<br>
-pcl/urwfonts/ArtLinePrinter.ttf<br>
-pcl/urwfonts/CenturySchL-Bold.ttf<br>
-pcl/urwfonts/CenturySchL-BoldItal.ttf<br>
-pcl/urwfonts/CenturySchL-Ital.ttf<br>
-pcl/urwfonts/CenturySchL-Roma.ttf<br>
-pcl/urwfonts/ClarendonURW-BolCon.ttf<br>
-pcl/urwfonts/Coronet.ttf<br>
-pcl/urwfonts/Dingbats.ttf<br>
-pcl/urwfonts/GaramondNo8-Ita.ttf<br>
-pcl/urwfonts/GaramondNo8-Med.ttf<br>
-pcl/urwfonts/GaramondNo8-MedIta.ttf<br>
-pcl/urwfonts/GaramondNo8-Reg.ttf<br>
-pcl/urwfonts/LetterGothic-Bol.ttf<br>
-pcl/urwfonts/LetterGothic-Ita.ttf<br>
-pcl/urwfonts/LetterGothic-Reg.ttf<br>
-pcl/urwfonts/Mauritius-Reg.ttf<br>
-pcl/urwfonts/NewDingbats.ttf<br>
-pcl/urwfonts/NimbusMonL-Bold.ttf<br>
-pcl/urwfonts/NimbusMonL-BoldObli.ttf<br>
-pcl/urwfonts/NimbusMonL-Regu.ttf<br>
-pcl/urwfonts/NimbusMonL-ReguObli.ttf<br>
-pcl/urwfonts/NimbusMono-Bol.ttf<br>
-pcl/urwfonts/NimbusMono-BolIta.ttf<br>
-pcl/urwfonts/NimbusMono-Ita.ttf<br>
-pcl/urwfonts/NimbusMono-Reg.ttf<br>
-pcl/urwfonts/NimbusRomNo9L-Medi.ttf<br>
-pcl/urwfonts/NimbusRomNo9L-MediItal.ttf<br>
-pcl/urwfonts/NimbusRomNo9L-Regu.ttf<br>
-pcl/urwfonts/NimbusRomNo9L-ReguItal.ttf<br>
-pcl/urwfonts/NimbusRomanNo4-Bol.ttf<br>
-pcl/urwfonts/NimbusRomanNo4-BolIta.ttf<br>
-pcl/urwfonts/NimbusRomanNo4-Lig.ttf<br>
-pcl/urwfonts/NimbusRomanNo4-LigIta.ttf<br>
-pcl/urwfonts/NimbusRomanNo9-Ita.ttf<br>
-pcl/urwfonts/NimbusRomanNo9-Med.ttf<br>
-pcl/urwfonts/NimbusRomanNo9-MedIta.ttf<br>
-pcl/urwfonts/NimbusRomanNo9-Reg.ttf<br>
-pcl/urwfonts/NimbusSanL-Bold.ttf<br>
-pcl/urwfonts/NimbusSanL-BoldCond.ttf<br>
-pcl/urwfonts/NimbusSanL-BoldCondItal.ttf<br>
-pcl/urwfonts/NimbusSanL-BoldItal.ttf<br>
-pcl/urwfonts/NimbusSanL-Regu.ttf<br>
-pcl/urwfonts/NimbusSanL-ReguCond.ttf<br>
-pcl/urwfonts/NimbusSanL-ReguCondItal.ttf<br>
-pcl/urwfonts/NimbusSanL-ReguItal.ttf<br>
-pcl/urwfonts/StandardSymL.ttf<br>
-pcl/urwfonts/U001-Bol.ttf<br>
-pcl/urwfonts/U001-BolIta.ttf<br>
-pcl/urwfonts/U001-Ita.ttf<br>
-pcl/urwfonts/U001-Reg.ttf<br>
-pcl/urwfonts/U001Con-Bol.ttf<br>
-pcl/urwfonts/U001Con-BolIta.ttf<br>
-pcl/urwfonts/U001Con-Ita.ttf<br>
-pcl/urwfonts/U001Con-Reg.ttf<br>
-pcl/urwfonts/URWBookmanL-DemiBold.ttf<br>
-pcl/urwfonts/URWBookmanL-DemiBoldItal.ttf<br>
-pcl/urwfonts/URWBookmanL-Ligh.ttf<br>
-pcl/urwfonts/URWBookmanL-LighItal.ttf<br>
-pcl/urwfonts/URWChanceryL-MediItal.ttf<br>
-pcl/urwfonts/URWClassico-Bol.ttf<br>
-pcl/urwfonts/URWClassico-BolIta.ttf<br>
-pcl/urwfonts/URWClassico-Ita.ttf<br>
-pcl/urwfonts/URWClassico-Reg.ttf<br>
-pcl/urwfonts/URWGothicL-Book.ttf<br>
-pcl/urwfonts/URWGothicL-BookObli.ttf<br>
-pcl/urwfonts/URWGothicL-Demi.ttf<br>
-pcl/urwfonts/URWGothicL-DemiObli.ttf<br>
-pcl/urwfonts/URWPalladioL-Bold.ttf<br>
-pcl/urwfonts/URWPalladioL-BoldItal.ttf<br>
-pcl/urwfonts/URWPalladioL-Ital.ttf<br>
-pcl/urwfonts/URWPalladioL-Roma.ttf<br>
-pcl6/pcl6.xcodeproj/project.pbxproj<br>
-pl/dwimg.c<br>
-pl/dwimg.h<br>
-pl/dwmainc.c<br>
-pl/dwreg.c<br>
-pl/dwreg.h<br>
-pl/dwres.h<br>
-pl/pjparse.c<br>
-pl/pjparse.h<br>
-pl/pjparsei.c<br>
-pl/pjtop.c<br>
-pl/pjtop.h<br>
-pl/pl.mak<br>
-pl/plalloc.c<br>
-pl/plalloc.h<br>
-pl/plapi.h<br>
-pl/plchar.c<br>
-pl/plchar.h<br>
-pl/pldebug.h<br>
-pl/pldict.c<br>
-pl/pldict.h<br>
-pl/pldraw.c<br>
-pl/pldraw.h<br>
-pl/plfapi.c<br>
-pl/plfapi.h<br>
-pl/plfont.c<br>
-pl/plfont.h<br>
-pl/plftable.c<br>
-pl/plftable.h<br>
-pl/plht.c<br>
-pl/plht.h<br>
-pl/plimpl.c<br>
-pl/pllfont.c<br>
-pl/pllfont.h<br>
-pl/plmain.c<br>
-pl/plmain.h<br>
-pl/plparse.h<br>
-pl/plplatf.c<br>
-pl/plplatf.h<br>
-pl/plplatfps.c<br>
-pl/plsymbol.c<br>
-pl/plsymbol.h<br>
-pl/pltop.c<br>
-pl/pltop.h<br>
-pl/pltoputl.c<br>
-pl/pltoputl.h<br>
-pl/pluchar.c<br>
-pl/plufont.c<br>
-pl/plufstlp.c<br>
-pl/plufstlp.h<br>
-pl/plufstlp1.c<br>
-pl/plulfont.c<br>
-pl/plvalue.c<br>
-pl/plvalue.h<br>
-pl/plvocab.c<br>
-pl/plvocab.h<br>
-pl/realmain.c<br>
-psi/apitest.c<br>
-psi/bfont.h<br>
-psi/btoken.h<br>
-psi/dmmain.c<br>
-psi/dmmain.r<br>
-psi/dpmain.c<br>
-psi/dscparse.c<br>
-psi/dscparse.h<br>
-psi/dstack.h<br>
-psi/dw32c.def<br>
-psi/dw64c.def<br>
-psi/dwdll.c<br>
-psi/dwdll.h<br>
-psi/dwimg.c<br>
-psi/dwimg.h<br>
-psi/dwmain.c<br>
-psi/dwmain.rc<br>
-psi/dwmain32.def<br>
-psi/dwmain64.def<br>
-psi/dwmainc.c<br>
-psi/dwnodll.c<br>
-psi/dwreg.c<br>
-psi/dwreg.h<br>
-psi/dwres.h<br>
-psi/dwsetup.def<br>
-psi/dwsetup_x64.manifest<br>
-psi/dwsetup_x86.manifest<br>
-psi/dwtext.c<br>
-psi/dwtext.h<br>
-psi/dwtrace.c<br>
-psi/dwtrace.h<br>
-psi/dwuninst.def<br>
-psi/dwuninst_x64.manifest<br>
-psi/dwuninst_x86.manifest<br>
-psi/dxmain.c<br>
-psi/dxmainc.c<br>
-psi/estack.h<br>
-psi/files.h<br>
-psi/ghost.h<br>
-psi/gs.c<br>
-psi/gsdll.c<br>
-psi/gsdll2.def<br>
-psi/gsdll2.rc<br>
-psi/gsdll32.def<br>
-psi/gsdll32.rc<br>
-psi/gsdll32metro.def<br>
-psi/gsdll32w.lnk<br>
-psi/gsdll64.def<br>
-psi/gsdll64metro.def<br>
-psi/gsdllARM32metro.def<br>
-psi/gserver.c<br>
-psi/gsos2.def<br>
-psi/gsos2.icx<br>
-psi/gsos2.rc<br>
-psi/ialloc.c<br>
-psi/ialloc.h<br>
-psi/iapi.c<br>
-psi/iapi.h<br>
-psi/iastate.h<br>
-psi/iastruct.h<br>
-psi/ibnum.c<br>
-psi/ibnum.h<br>
-psi/ichar.h<br>
-psi/ichar1.h<br>
-psi/icharout.h<br>
-psi/icid.h<br>
-psi/icie.h<br>
-psi/icolor.h<br>
-psi/iconf.c<br>
-psi/iconf.h<br>
-psi/icontext.c<br>
-psi/icontext.h<br>
-psi/icremap.h<br>
-psi/icsmap.h<br>
-psi/icstate.h<br>
-psi/iddict.h<br>
-psi/iddstack.h<br>
-psi/idebug.c<br>
-psi/idebug.h<br>
-psi/idict.c<br>
-psi/idict.h<br>
-psi/idictdef.h<br>
-psi/idicttpl.h<br>
-psi/idisp.c<br>
-psi/idisp.h<br>
-psi/idosave.h<br>
-psi/idparam.c<br>
-psi/idparam.h<br>
-psi/idsdata.h<br>
-psi/idstack.c<br>
-psi/idstack.h<br>
-psi/ierrors.h<br>
-psi/iesdata.h<br>
-psi/iestack.h<br>
-psi/ifapi.h<br>
-psi/ifcid.h<br>
-psi/ifilter.h<br>
-psi/ifilter2.h<br>
-psi/ifont.h<br>
-psi/ifont1.h<br>
-psi/ifont2.h<br>
-psi/ifont42.h<br>
-psi/ifrpred.h<br>
-psi/ifunc.h<br>
-psi/ifwpred.h<br>
-psi/igc.c<br>
-psi/igc.h<br>
-psi/igcref.c<br>
-psi/igcstr.c<br>
-psi/igcstr.h<br>
-psi/igstate.h<br>
-psi/iht.h<br>
-psi/iimage.h<br>
-psi/iimage2.h<br>
-psi/iinit.c<br>
-psi/iinit.h<br>
-psi/ilevel.h<br>
-psi/ilocate.c<br>
-psi/imain.c<br>
-psi/imain.h<br>
-psi/imainarg.c<br>
-psi/imainarg.h<br>
-psi/imemory.h<br>
-psi/iminst.h<br>
-psi/iname.c<br>
-psi/iname.h<br>
-psi/inamedef.h<br>
-psi/inameidx.h<br>
-psi/inames.h<br>
-psi/inamestr.h<br>
-psi/inobtokn.c<br>
-psi/inouparm.c<br>
-psi/int.mak<br>
-psi/interp.c<br>
-psi/interp.h<br>
-psi/iosdata.h<br>
-psi/iostack.h<br>
-psi/ipacked.h<br>
-psi/iparam.c<br>
-psi/iparam.h<br>
-psi/iparray.h<br>
-psi/ipcolor.h<br>
-psi/iplugin.c<br>
-psi/iplugin.h<br>
-psi/ireclaim.c<br>
-psi/iref.h<br>
-psi/isave.c<br>
-psi/isave.h<br>
-psi/iscan.c<br>
-psi/iscan.h<br>
-psi/iscanbin.c<br>
-psi/iscanbin.h<br>
-psi/iscannum.c<br>
-psi/iscannum.h<br>
-psi/isdata.h<br>
-psi/isstate.h<br>
-psi/istack.c<br>
-psi/istack.h<br>
-psi/istkparm.h<br>
-psi/istream.h<br>
-psi/istruct.h<br>
-psi/itoken.h<br>
-psi/iutil.c<br>
-psi/iutil.h<br>
-psi/iutil2.c<br>
-psi/iutil2.h<br>
-psi/ivmem2.h<br>
-psi/ivmspace.h<br>
-psi/main.h<br>
-psi/mkfilelt.cpp<br>
-psi/msvc.mak<br>
-psi/msvc32.mak<br>
-psi/msvc64.mak<br>
-psi/nsisinst.nsi<br>
-psi/oparc.h<br>
-psi/opcheck.h<br>
-psi/opdef.h<br>
-psi/oper.h<br>
-psi/opextern.h<br>
-psi/os2.mak<br>
-psi/ostack.h<br>
-psi/psi.mak<br>
-psi/psitop.c<br>
-psi/psromfs.mak<br>
-psi/sfilter1.c<br>
-psi/store.h<br>
-psi/winint.mak<br>
-psi/zalg.c<br>
-psi/zarith.c<br>
-psi/zarray.c<br>
-psi/zbfont.c<br>
-psi/zbseq.c<br>
-psi/zcfont.c<br>
-psi/zchar.c<br>
-psi/zchar1.c<br>
-psi/zchar2.c<br>
-psi/zchar32.c<br>
-psi/zchar42.c<br>
-psi/zchar42.h<br>
-psi/zcharout.c<br>
-psi/zcharx.c<br>
-psi/zcid.c<br>
-psi/zcidtest.c<br>
-psi/zcie.c<br>
-psi/zcie.h<br>
-psi/zcolor.c<br>
-psi/zcolor.h<br>
-psi/zcolor1.c<br>
-psi/zcolor2.c<br>
-psi/zcolor3.c<br>
-psi/zcontext.c<br>
-psi/zcontrol.c<br>
-psi/zcrd.c<br>
-psi/zcsdevn.c<br>
-psi/zcsindex.c<br>
-psi/zcspixel.c<br>
-psi/zcssepr.c<br>
-psi/zdevcal.c<br>
-psi/zdevice.c<br>
-psi/zdevice2.c<br>
-psi/zdfilter.c<br>
-psi/zdict.c<br>
-psi/zdosio.c<br>
-psi/zdouble.c<br>
-psi/zdpnext.c<br>
-psi/zdps.c<br>
-psi/zdps1.c<br>
-psi/zdscpars.c<br>
-psi/zfaes.c<br>
-psi/zfapi.c<br>
-psi/zfarc4.c<br>
-psi/zfbcp.c<br>
-psi/zfcid.c<br>
-psi/zfcid0.c<br>
-psi/zfcid1.c<br>
-psi/zfcmap.c<br>
-psi/zfdctd.c<br>
-psi/zfdcte.c<br>
-psi/zfdecode.c<br>
-psi/zfile.c<br>
-psi/zfile.h<br>
-psi/zfile1.c<br>
-psi/zfileio.c<br>
-psi/zfilter.c<br>
-psi/zfilter2.c<br>
-psi/zfilterx.c<br>
-psi/zfimscale.c<br>
-psi/zfjbig2.c<br>
-psi/zfjpx.c<br>
-psi/zfmd5.c<br>
-psi/zfont.c<br>
-psi/zfont0.c<br>
-psi/zfont1.c<br>
-psi/zfont2.c<br>
-psi/zfont32.c<br>
-psi/zfont42.c<br>
-psi/zfontenum.c<br>
-psi/zform.c<br>
-psi/zfproc.c<br>
-psi/zfrsd.c<br>
-psi/zfrsd.h<br>
-psi/zfsample.c<br>
-psi/zfsha2.c<br>
-psi/zfunc.c<br>
-psi/zfunc.h<br>
-psi/zfunc0.c<br>
-psi/zfunc3.c<br>
-psi/zfunc4.c<br>
-psi/zfzlib.c<br>
-psi/zgeneric.c<br>
-psi/zgstate.c<br>
-psi/zhsb.c<br>
-psi/zht.c<br>
-psi/zht1.c<br>
-psi/zht2.c<br>
-psi/zht2.h<br>
-psi/zicc.c<br>
-psi/zicc.h<br>
-psi/zimage.c<br>
-psi/zimage2.c<br>
-psi/zimage3.c<br>
-psi/ziodev.c<br>
-psi/ziodev2.c<br>
-psi/ziodevs.c<br>
-psi/ziodevsc.c<br>
-psi/zmath.c<br>
-psi/zmatrix.c<br>
-psi/zmedia2.c<br>
-psi/zmisc.c<br>
-psi/zmisc1.c<br>
-psi/zmisc2.c<br>
-psi/zmisc3.c<br>
-psi/zncdummy.c<br>
-psi/zpacked.c<br>
-psi/zpaint.c<br>
-psi/zpath.c<br>
-psi/zpath1.c<br>
-psi/zpcolor.c<br>
-psi/zpdf_r6.c<br>
-psi/zpdfops.c<br>
-psi/zrelbit.c<br>
-psi/zrop.c<br>
-psi/zshade.c<br>
-psi/zstack.c<br>
-psi/zstring.c<br>
-psi/zsysvm.c<br>
-psi/ztoken.c<br>
-psi/ztrans.c<br>
-psi/ztrap.c<br>
-psi/ztype.c<br>
-psi/zupath.c<br>
-psi/zusparam.c<br>
-psi/zutf8.c<br>
-psi/zvmem.c<br>
-psi/zvmem2.c<br>
-psi/zwinutf8.c<br>
-pxl/PXL_Color_Laserjet_4700_Differences.xls<br>
-pxl/pxasm.bat<br>
-pxl/pxasm.ps<br>
-pxl/pxattr.h<br>
-pxl/pxbfont.c<br>
-pxl/pxbfont.h<br>
-pxl/pxbfont.ps<br>
-pxl/pxcet.txt<br>
-pxl/pxdict.h<br>
-pxl/pxdiff.txt<br>
-pxl/pxenum.h<br>
-pxl/pxerrors.c<br>
-pxl/pxerrors.h<br>
-pxl/pxffont.c<br>
-pxl/pxfont.c<br>
-pxl/pxfont.h<br>
-pxl/pxfts.txt<br>
-pxl/pxgstate.c<br>
-pxl/pxgstate.h<br>
-pxl/pximage.c<br>
-pxl/pximpl.c<br>
-pxl/pxink.c<br>
-pxl/pxl.mak<br>
-pxl/pxlib.txt<br>
-pxl/pxoper.h<br>
-pxl/pxpaint.c<br>
-pxl/pxparse.c<br>
-pxl/pxparse.h<br>
-pxl/pxptable.c<br>
-pxl/pxptable.h<br>
-pxl/pxpthr.c<br>
-pxl/pxpthr.h<br>
-pxl/pxsessio.c<br>
-pxl/pxspec.txt<br>
-pxl/pxstate.c<br>
-pxl/pxstate.h<br>
-pxl/pxstream.c<br>
-pxl/pxsymbol.ps<br>
-pxl/pxsymbol.psc<br>
-pxl/pxsymbol.psh<br>
-pxl/pxtag.h<br>
-pxl/pxtop.c<br>
-pxl/pxvalue.c<br>
-pxl/pxvalue.h<br>
-pxl/pxvendor.c<br>
-pxl/pxvendor.h<br>
-tiff/COPYRIGHT<br>
-tiff/ChangeLog<br>
-tiff/HOWTO-RELEASE<br>
-tiff/Makefile.am<br>
-tiff/Makefile.in<br>
-tiff/Makefile.vc<br>
-tiff/README<br>
-tiff/README.vms<br>
-tiff/RELEASE-DATE<br>
-tiff/SConstruct<br>
-tiff/TODO<br>
-tiff/VERSION<br>
-tiff/aclocal.m4<br>
-tiff/autogen.sh<br>
-tiff/build/Makefile.am<br>
-tiff/build/Makefile.in<br>
-tiff/build/README<br>
-tiff/config/compile<br>
-tiff/config/config.guess<br>
-tiff/config/config.sub<br>
-tiff/config/depcomp<br>
-tiff/config/install-sh<br>
-tiff/config/ltmain.sh<br>
-tiff/config/missing<br>
-tiff/config/mkinstalldirs<br>
-tiff/configure<br>
-tiff/configure.ac<br>
-tiff/configure.com<br>
-tiff/contrib/Makefile.am<br>
-tiff/contrib/Makefile.in<br>
-tiff/contrib/README<br>
-tiff/contrib/addtiffo/Makefile.am<br>
-tiff/contrib/addtiffo/Makefile.in<br>
-tiff/contrib/addtiffo/Makefile.vc<br>
-tiff/contrib/addtiffo/README<br>
-tiff/contrib/addtiffo/addtiffo.c<br>
-tiff/contrib/addtiffo/tif_overview.c<br>
-tiff/contrib/addtiffo/tif_ovrcache.c<br>
-tiff/contrib/addtiffo/tif_ovrcache.h<br>
-tiff/contrib/dbs/Makefile.am<br>
-tiff/contrib/dbs/Makefile.in<br>
-tiff/contrib/dbs/README<br>
-tiff/contrib/dbs/tiff-bi.c<br>
-tiff/contrib/dbs/tiff-grayscale.c<br>
-tiff/contrib/dbs/tiff-palette.c<br>
-tiff/contrib/dbs/tiff-rgb.c<br>
-tiff/contrib/dbs/xtiff/Makefile.am<br>
-tiff/contrib/dbs/xtiff/Makefile.in<br>
-tiff/contrib/dbs/xtiff/README<br>
-tiff/contrib/dbs/xtiff/patchlevel.h<br>
-tiff/contrib/dbs/xtiff/xtiff.c<br>
-tiff/contrib/dbs/xtiff/xtifficon.h<br>
-tiff/contrib/iptcutil/Makefile.am<br>
-tiff/contrib/iptcutil/Makefile.in<br>
-tiff/contrib/iptcutil/README<br>
-tiff/contrib/iptcutil/iptcutil.c<br>
-tiff/contrib/iptcutil/test.iptc<br>
-tiff/contrib/iptcutil/test.txt<br>
-tiff/contrib/mfs/Makefile.am<br>
-tiff/contrib/mfs/Makefile.in<br>
-tiff/contrib/mfs/README<br>
-tiff/contrib/mfs/mfs_file.c<br>
-tiff/contrib/pds/Makefile.am<br>
-tiff/contrib/pds/Makefile.in<br>
-tiff/contrib/pds/README<br>
-tiff/contrib/pds/tif_imageiter.c<br>
-tiff/contrib/pds/tif_imageiter.h<br>
-tiff/contrib/pds/tif_pdsdirread.c<br>
-tiff/contrib/pds/tif_pdsdirwrite.c<br>
-tiff/contrib/ras/Makefile.am<br>
-tiff/contrib/ras/Makefile.in<br>
-tiff/contrib/ras/README<br>
-tiff/contrib/ras/ras2tif.c<br>
-tiff/contrib/ras/tif2ras.c<br>
-tiff/contrib/stream/Makefile.am<br>
-tiff/contrib/stream/Makefile.in<br>
-tiff/contrib/stream/README<br>
-tiff/contrib/stream/tiffstream.cpp<br>
-tiff/contrib/stream/tiffstream.h<br>
-tiff/contrib/tags/Makefile.am<br>
-tiff/contrib/tags/Makefile.in<br>
-tiff/contrib/tags/README<br>
-tiff/contrib/tags/listtif.c<br>
-tiff/contrib/tags/maketif.c<br>
-tiff/contrib/tags/xtif_dir.c<br>
-tiff/contrib/tags/xtiffio.h<br>
-tiff/contrib/tags/xtiffiop.h<br>
-tiff/contrib/win_dib/Makefile.am<br>
-tiff/contrib/win_dib/Makefile.in<br>
-tiff/contrib/win_dib/Makefile.w95<br>
-tiff/contrib/win_dib/README.Tiffile<br>
-tiff/contrib/win_dib/README.tiff2dib<br>
-tiff/contrib/win_dib/Tiffile.cpp<br>
-tiff/contrib/win_dib/tiff2dib.c<br>
-tiff/html/Makefile.am<br>
-tiff/html/Makefile.in<br>
-tiff/html/TIFFTechNote2.html<br>
-tiff/html/addingtags.html<br>
-tiff/html/bugs.html<br>
-tiff/html/build.html<br>
-tiff/html/contrib.html<br>
-tiff/html/document.html<br>
-tiff/html/images.html<br>
-tiff/html/images/Makefile.am<br>
-tiff/html/images/Makefile.in<br>
-tiff/html/images/back.gif<br>
-tiff/html/images/bali.jpg<br>
-tiff/html/images/cat.gif<br>
-tiff/html/images/cover.jpg<br>
-tiff/html/images/cramps.gif<br>
-tiff/html/images/dave.gif<br>
-tiff/html/images/info.gif<br>
-tiff/html/images/jello.jpg<br>
-tiff/html/images/jim.gif<br>
-tiff/html/images/note.gif<br>
-tiff/html/images/oxford.gif<br>
-tiff/html/images/quad.jpg<br>
-tiff/html/images/ring.gif<br>
-tiff/html/images/smallliz.jpg<br>
-tiff/html/images/strike.gif<br>
-tiff/html/images/warning.gif<br>
-tiff/html/index.html<br>
-tiff/html/internals.html<br>
-tiff/html/intro.html<br>
-tiff/html/libtiff.html<br>
-tiff/html/man/Makefile.am<br>
-tiff/html/man/Makefile.in<br>
-tiff/html/man/TIFFClose.3tiff.html<br>
-tiff/html/man/TIFFDataWidth.3tiff.html<br>
-tiff/html/man/TIFFError.3tiff.html<br>
-tiff/html/man/TIFFFlush.3tiff.html<br>
-tiff/html/man/TIFFGetField.3tiff.html<br>
-tiff/html/man/TIFFOpen.3tiff.html<br>
-tiff/html/man/TIFFPrintDirectory.3tiff.html<br>
-tiff/html/man/TIFFRGBAImage.3tiff.html<br>
-tiff/html/man/TIFFReadDirectory.3tiff.html<br>
-tiff/html/man/TIFFReadEncodedStrip.3tiff.html<br>
-tiff/html/man/TIFFReadEncodedTile.3tiff.html<br>
-tiff/html/man/TIFFReadRGBAImage.3tiff.html<br>
-tiff/html/man/TIFFReadRGBAStrip.3tiff.html<br>
-tiff/html/man/TIFFReadRGBATile.3tiff.html<br>
-tiff/html/man/TIFFReadRawStrip.3tiff.html<br>
-tiff/html/man/TIFFReadRawTile.3tiff.html<br>
-tiff/html/man/TIFFReadScanline.3tiff.html<br>
-tiff/html/man/TIFFReadTile.3tiff.html<br>
-tiff/html/man/TIFFSetDirectory.3tiff.html<br>
-tiff/html/man/TIFFSetField.3tiff.html<br>
-tiff/html/man/TIFFWarning.3tiff.html<br>
-tiff/html/man/TIFFWriteDirectory.3tiff.html<br>
-tiff/html/man/TIFFWriteEncodedStrip.3tiff.html<br>
-tiff/html/man/TIFFWriteEncodedTile.3tiff.html<br>
-tiff/html/man/TIFFWriteRawStrip.3tiff.html<br>
-tiff/html/man/TIFFWriteRawTile.3tiff.html<br>
-tiff/html/man/TIFFWriteScanline.3tiff.html<br>
-tiff/html/man/TIFFWriteTile.3tiff.html<br>
-tiff/html/man/TIFFbuffer.3tiff.html<br>
-tiff/html/man/TIFFcodec.3tiff.html<br>
-tiff/html/man/TIFFcolor.3tiff.html<br>
-tiff/html/man/TIFFmemory.3tiff.html<br>
-tiff/html/man/TIFFquery.3tiff.html<br>
-tiff/html/man/TIFFsize.3tiff.html<br>
-tiff/html/man/TIFFstrip.3tiff.html<br>
-tiff/html/man/TIFFswab.3tiff.html<br>
-tiff/html/man/TIFFtile.3tiff.html<br>
-tiff/html/man/fax2ps.1.html<br>
-tiff/html/man/fax2tiff.1.html<br>
-tiff/html/man/gif2tiff.1.html<br>
-tiff/html/man/index.html<br>
-tiff/html/man/libtiff.3tiff.html<br>
-tiff/html/man/pal2rgb.1.html<br>
-tiff/html/man/ppm2tiff.1.html<br>
-tiff/html/man/ras2tiff.1.html<br>
-tiff/html/man/raw2tiff.1.html<br>
-tiff/html/man/rgb2ycbcr.1.html<br>
-tiff/html/man/sgi2tiff.1.html<br>
-tiff/html/man/thumbnail.1.html<br>
-tiff/html/man/tiff2bw.1.html<br>
-tiff/html/man/tiff2pdf.1.html<br>
-tiff/html/man/tiff2ps.1.html<br>
-tiff/html/man/tiff2rgba.1.html<br>
-tiff/html/man/tiffcmp.1.html<br>
-tiff/html/man/tiffcp.1.html<br>
-tiff/html/man/tiffcrop.1.html<br>
-tiff/html/man/tiffdither.1.html<br>
-tiff/html/man/tiffdump.1.html<br>
-tiff/html/man/tiffgt.1.html<br>
-tiff/html/man/tiffinfo.1.html<br>
-tiff/html/man/tiffmedian.1.html<br>
-tiff/html/man/tiffset.1.html<br>
-tiff/html/man/tiffsplit.1.html<br>
-tiff/html/man/tiffsv.1.html<br>
-tiff/html/misc.html<br>
-tiff/html/support.html<br>
-tiff/html/tools.html<br>
-tiff/html/v3.4beta007.html<br>
-tiff/html/v3.4beta016.html<br>
-tiff/html/v3.4beta018.html<br>
-tiff/html/v3.4beta024.html<br>
-tiff/html/v3.4beta028.html<br>
-tiff/html/v3.4beta029.html<br>
-tiff/html/v3.4beta031.html<br>
-tiff/html/v3.4beta032.html<br>
-tiff/html/v3.4beta033.html<br>
-tiff/html/v3.4beta034.html<br>
-tiff/html/v3.4beta035.html<br>
-tiff/html/v3.4beta036.html<br>
-tiff/html/v3.5.1.html<br>
-tiff/html/v3.5.2.html<br>
-tiff/html/v3.5.3.html<br>
-tiff/html/v3.5.4.html<br>
-tiff/html/v3.5.5.html<br>
-tiff/html/v3.5.6-beta.html<br>
-tiff/html/v3.5.7.html<br>
-tiff/html/v3.6.0.html<br>
-tiff/html/v3.6.1.html<br>
-tiff/html/v3.7.0.html<br>
-tiff/html/v3.7.0alpha.html<br>
-tiff/html/v3.7.0beta.html<br>
-tiff/html/v3.7.0beta2.html<br>
-tiff/html/v3.7.1.html<br>
-tiff/html/v3.7.2.html<br>
-tiff/html/v3.7.3.html<br>
-tiff/html/v3.7.4.html<br>
-tiff/html/v3.8.0.html<br>
-tiff/html/v3.8.1.html<br>
-tiff/html/v3.8.2.html<br>
-tiff/html/v3.9.0beta.html<br>
-tiff/html/v3.9.1.html<br>
-tiff/html/v3.9.2.html<br>
-tiff/html/v4.0.0.html<br>
-tiff/libtiff-4.pc.in<br>
-tiff/libtiff/Makefile.am<br>
-tiff/libtiff/Makefile.in<br>
-tiff/libtiff/Makefile.vc<br>
-tiff/libtiff/SConstruct<br>
-tiff/libtiff/libtiff.def<br>
-tiff/libtiff/libtiff.map<br>
-tiff/libtiff/libtiffxx.map<br>
-tiff/libtiff/mkg3states.c<br>
-tiff/libtiff/t4.h<br>
-tiff/libtiff/tif_aux.c<br>
-tiff/libtiff/tif_close.c<br>
-tiff/libtiff/tif_codec.c<br>
-tiff/libtiff/tif_color.c<br>
-tiff/libtiff/tif_compress.c<br>
-tiff/libtiff/tif_config.h-vms<br>
-tiff/libtiff/tif_config.h.in<br>
-tiff/libtiff/tif_config.vc.h<br>
-tiff/libtiff/tif_config.wince.h<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_dumpmode.c<br>
-tiff/libtiff/tif_error.c<br>
-tiff/libtiff/tif_extension.c<br>
-tiff/libtiff/tif_fax3.c<br>
-tiff/libtiff/tif_fax3.h<br>
-tiff/libtiff/tif_fax3sm.c<br>
-tiff/libtiff/tif_flush.c<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_lzma.c<br>
-tiff/libtiff/tif_lzw.c<br>
-tiff/libtiff/tif_next.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_predict.h<br>
-tiff/libtiff/tif_print.c<br>
-tiff/libtiff/tif_read.c<br>
-tiff/libtiff/tif_stream.cxx<br>
-tiff/libtiff/tif_strip.c<br>
-tiff/libtiff/tif_swab.c<br>
-tiff/libtiff/tif_thunder.c<br>
-tiff/libtiff/tif_tile.c<br>
-tiff/libtiff/tif_unix.c<br>
-tiff/libtiff/tif_version.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/tiff.h<br>
-tiff/libtiff/tiffconf.h.in<br>
-tiff/libtiff/tiffconf.vc.h<br>
-tiff/libtiff/tiffconf.wince.h<br>
-tiff/libtiff/tiffio.h<br>
-tiff/libtiff/tiffio.hxx<br>
-tiff/libtiff/tiffiop.h<br>
-tiff/libtiff/tiffvers.h<br>
-tiff/libtiff/uvcode.h<br>
-tiff/m4/acinclude.m4<br>
-tiff/m4/libtool.m4<br>
-tiff/m4/ltoptions.m4<br>
-tiff/m4/ltsugar.m4<br>
-tiff/m4/ltversion.m4<br>
-tiff/m4/lt~obsolete.m4<br>
-tiff/man/Makefile.am<br>
-tiff/man/Makefile.in<br>
-tiff/man/TIFFClose.3tiff<br>
-tiff/man/TIFFDataWidth.3tiff<br>
-tiff/man/TIFFError.3tiff<br>
-tiff/man/TIFFFlush.3tiff<br>
-tiff/man/TIFFGetField.3tiff<br>
-tiff/man/TIFFOpen.3tiff<br>
-tiff/man/TIFFPrintDirectory.3tiff<br>
-tiff/man/TIFFRGBAImage.3tiff<br>
-tiff/man/TIFFReadDirectory.3tiff<br>
-tiff/man/TIFFReadEncodedStrip.3tiff<br>
-tiff/man/TIFFReadEncodedTile.3tiff<br>
-tiff/man/TIFFReadRGBAImage.3tiff<br>
-tiff/man/TIFFReadRGBAStrip.3tiff<br>
-tiff/man/TIFFReadRGBATile.3tiff<br>
-tiff/man/TIFFReadRawStrip.3tiff<br>
-tiff/man/TIFFReadRawTile.3tiff<br>
-tiff/man/TIFFReadScanline.3tiff<br>
-tiff/man/TIFFReadTile.3tiff<br>
-tiff/man/TIFFSetDirectory.3tiff<br>
-tiff/man/TIFFSetField.3tiff<br>
-tiff/man/TIFFWarning.3tiff<br>
-tiff/man/TIFFWriteDirectory.3tiff<br>
-tiff/man/TIFFWriteEncodedStrip.3tiff<br>
-tiff/man/TIFFWriteEncodedTile.3tiff<br>
-tiff/man/TIFFWriteRawStrip.3tiff<br>
-tiff/man/TIFFWriteRawTile.3tiff<br>
-tiff/man/TIFFWriteScanline.3tiff<br>
-tiff/man/TIFFWriteTile.3tiff<br>
-tiff/man/TIFFbuffer.3tiff<br>
-tiff/man/TIFFcodec.3tiff<br>
-tiff/man/TIFFcolor.3tiff<br>
-tiff/man/TIFFmemory.3tiff<br>
-tiff/man/TIFFquery.3tiff<br>
-tiff/man/TIFFsize.3tiff<br>
-tiff/man/TIFFstrip.3tiff<br>
-tiff/man/TIFFswab.3tiff<br>
-tiff/man/TIFFtile.3tiff<br>
-tiff/man/bmp2tiff.1<br>
-tiff/man/fax2ps.1<br>
-tiff/man/fax2tiff.1<br>
-tiff/man/gif2tiff.1<br>
-tiff/man/libtiff.3tiff<br>
-tiff/man/pal2rgb.1<br>
-tiff/man/ppm2tiff.1<br>
-tiff/man/ras2tiff.1<br>
-tiff/man/raw2tiff.1<br>
-tiff/man/rgb2ycbcr.1<br>
-tiff/man/sgi2tiff.1<br>
-tiff/man/thumbnail.1<br>
-tiff/man/tiff2bw.1<br>
-tiff/man/tiff2pdf.1<br>
-tiff/man/tiff2ps.1<br>
-tiff/man/tiff2rgba.1<br>
-tiff/man/tiffcmp.1<br>
-tiff/man/tiffcp.1<br>
-tiff/man/tiffcrop.1<br>
-tiff/man/tiffdither.1<br>
-tiff/man/tiffdump.1<br>
-tiff/man/tiffgt.1<br>
-tiff/man/tiffinfo.1<br>
-tiff/man/tiffmedian.1<br>
-tiff/man/tiffset.1<br>
-tiff/man/tiffsplit.1<br>
-tiff/man/tiffsv.1<br>
-tiff/nmake.opt<br>
-tiff/port/Makefile.am<br>
-tiff/port/Makefile.in<br>
-tiff/port/Makefile.vc<br>
-tiff/port/dummy.c<br>
-tiff/port/getopt.c<br>
-tiff/port/lfind.c<br>
-tiff/port/libport.h<br>
-tiff/port/strcasecmp.c<br>
-tiff/port/strtoul.c<br>
-tiff/port/strtoull.c<br>
-tiff/test/Makefile.am<br>
-tiff/test/Makefile.in<br>
-tiff/test/ascii_tag.c<br>
-tiff/test/bmp2tiff_palette.sh<br>
-tiff/test/bmp2tiff_rgb.sh<br>
-tiff/test/check_tag.c<br>
-tiff/test/common.sh<br>
-tiff/test/gif2tiff.sh<br>
-tiff/test/images/README.txt<br>
-tiff/test/images/logluv-3c-16b.tiff<br>
-tiff/test/images/minisblack-1c-16b.tiff<br>
-tiff/test/images/minisblack-1c-8b.pgm<br>
-tiff/test/images/minisblack-1c-8b.tiff<br>
-tiff/test/images/minisblack-2c-8b-alpha.tiff<br>
-tiff/test/images/miniswhite-1c-1b.pbm<br>
-tiff/test/images/miniswhite-1c-1b.tiff<br>
-tiff/test/images/palette-1c-1b.tiff<br>
-tiff/test/images/palette-1c-4b.tiff<br>
-tiff/test/images/palette-1c-8b.bmp<br>
-tiff/test/images/palette-1c-8b.gif<br>
-tiff/test/images/palette-1c-8b.tiff<br>
-tiff/test/images/rgb-3c-16b.tiff<br>
-tiff/test/images/rgb-3c-8b.bmp<br>
-tiff/test/images/rgb-3c-8b.ppm<br>
-tiff/test/images/rgb-3c-8b.tiff<br>
-tiff/test/long_tag.c<br>
-tiff/test/ppm2tiff_pbm.sh<br>
-tiff/test/ppm2tiff_pgm.sh<br>
-tiff/test/ppm2tiff_ppm.sh<br>
-tiff/test/rewrite_tag.c<br>
-tiff/test/short_tag.c<br>
-tiff/test/strip.c<br>
-tiff/test/strip_rw.c<br>
-tiff/test/test_arrays.c<br>
-tiff/test/test_arrays.h<br>
-tiff/test/tiff2pdf.sh<br>
-tiff/test/tiff2ps-EPS1.sh<br>
-tiff/test/tiff2ps-PS1.sh<br>
-tiff/test/tiff2ps-PS2.sh<br>
-tiff/test/tiff2ps-PS3.sh<br>
-tiff/test/tiff2rgba-logluv-3c-16b.sh<br>
-tiff/test/tiff2rgba-minisblack-1c-16b.sh<br>
-tiff/test/tiff2rgba-minisblack-1c-8b.sh<br>
-tiff/test/tiff2rgba-minisblack-2c-8b-alpha.sh<br>
-tiff/test/tiff2rgba-miniswhite-1c-1b.sh<br>
-tiff/test/tiff2rgba-palette-1c-1b.sh<br>
-tiff/test/tiff2rgba-palette-1c-4b.sh<br>
-tiff/test/tiff2rgba-palette-1c-8b.sh<br>
-tiff/test/tiff2rgba-rgb-3c-16b.sh<br>
-tiff/test/tiff2rgba-rgb-3c-8b.sh<br>
-tiff/test/tiffcp-g3-1d-fill.sh<br>
-tiff/test/tiffcp-g3-1d.sh<br>
-tiff/test/tiffcp-g3-2d-fill.sh<br>
-tiff/test/tiffcp-g3-2d.sh<br>
-tiff/test/tiffcp-g3.sh<br>
-tiff/test/tiffcp-g4.sh<br>
-tiff/test/tiffcp-logluv.sh<br>
-tiff/test/tiffcp-split-join.sh<br>
-tiff/test/tiffcp-split.sh<br>
-tiff/test/tiffcp-thumbnail.sh<br>
-tiff/test/tiffcrop-R90-logluv-3c-16b.sh<br>
-tiff/test/tiffcrop-R90-minisblack-1c-16b.sh<br>
-tiff/test/tiffcrop-R90-minisblack-1c-8b.sh<br>
-tiff/test/tiffcrop-R90-minisblack-2c-8b-alpha.sh<br>
-tiff/test/tiffcrop-R90-miniswhite-1c-1b.sh<br>
-tiff/test/tiffcrop-R90-palette-1c-1b.sh<br>
-tiff/test/tiffcrop-R90-palette-1c-4b.sh<br>
-tiff/test/tiffcrop-R90-palette-1c-8b.sh<br>
-tiff/test/tiffcrop-R90-rgb-3c-16b.sh<br>
-tiff/test/tiffcrop-R90-rgb-3c-8b.sh<br>
-tiff/test/tiffcrop-doubleflip-logluv-3c-16b.sh<br>
-tiff/test/tiffcrop-doubleflip-minisblack-1c-16b.sh<br>
-tiff/test/tiffcrop-doubleflip-minisblack-1c-8b.sh<br>
-tiff/test/tiffcrop-doubleflip-minisblack-2c-8b-alpha.sh<br>
-tiff/test/tiffcrop-doubleflip-miniswhite-1c-1b.sh<br>
-tiff/test/tiffcrop-doubleflip-palette-1c-1b.sh<br>
-tiff/test/tiffcrop-doubleflip-palette-1c-4b.sh<br>
-tiff/test/tiffcrop-doubleflip-palette-1c-8b.sh<br>
-tiff/test/tiffcrop-doubleflip-rgb-3c-16b.sh<br>
-tiff/test/tiffcrop-doubleflip-rgb-3c-8b.sh<br>
-tiff/test/tiffcrop-extract-logluv-3c-16b.sh<br>
-tiff/test/tiffcrop-extract-minisblack-1c-16b.sh<br>
-tiff/test/tiffcrop-extract-minisblack-1c-8b.sh<br>
-tiff/test/tiffcrop-extract-minisblack-2c-8b-alpha.sh<br>
-tiff/test/tiffcrop-extract-miniswhite-1c-1b.sh<br>
-tiff/test/tiffcrop-extract-palette-1c-1b.sh<br>
-tiff/test/tiffcrop-extract-palette-1c-4b.sh<br>
-tiff/test/tiffcrop-extract-palette-1c-8b.sh<br>
-tiff/test/tiffcrop-extract-rgb-3c-16b.sh<br>
-tiff/test/tiffcrop-extract-rgb-3c-8b.sh<br>
-tiff/test/tiffcrop-extractz14-logluv-3c-16b.sh<br>
-tiff/test/tiffcrop-extractz14-minisblack-1c-16b.sh<br>
-tiff/test/tiffcrop-extractz14-minisblack-1c-8b.sh<br>
-tiff/test/tiffcrop-extractz14-minisblack-2c-8b-alpha.sh<br>
-tiff/test/tiffcrop-extractz14-miniswhite-1c-1b.sh<br>
-tiff/test/tiffcrop-extractz14-palette-1c-1b.sh<br>
-tiff/test/tiffcrop-extractz14-palette-1c-4b.sh<br>
-tiff/test/tiffcrop-extractz14-palette-1c-8b.sh<br>
-tiff/test/tiffcrop-extractz14-rgb-3c-16b.sh<br>
-tiff/test/tiffcrop-extractz14-rgb-3c-8b.sh<br>
-tiff/test/tiffdump.sh<br>
-tiff/test/tiffinfo.sh<br>
-tiff/test/tifftest.h<br>
-tiff/tools/Makefile.am<br>
-tiff/tools/Makefile.in<br>
-tiff/tools/Makefile.vc<br>
-tiff/tools/bmp2tiff.c<br>
-tiff/tools/fax2ps.c<br>
-tiff/tools/fax2tiff.c<br>
-tiff/tools/gif2tiff.c<br>
-tiff/tools/pal2rgb.c<br>
-tiff/tools/ppm2tiff.c<br>
-tiff/tools/ras2tiff.c<br>
-tiff/tools/rasterfile.h<br>
-tiff/tools/raw2tiff.c<br>
-tiff/tools/rgb2ycbcr.c<br>
-tiff/tools/sgi2tiff.c<br>
-tiff/tools/sgisv.c<br>
-tiff/tools/thumbnail.c<br>
-tiff/tools/tiff2bw.c<br>
-tiff/tools/tiff2pdf.c<br>
-tiff/tools/tiff2ps.c<br>
-tiff/tools/tiff2rgba.c<br>
-tiff/tools/tiffcmp.c<br>
-tiff/tools/tiffcp.c<br>
-tiff/tools/tiffcrop.c<br>
-tiff/tools/tiffdither.c<br>
-tiff/tools/tiffdump.c<br>
-tiff/tools/tiffgt.c<br>
-tiff/tools/tiffinfo.c<br>
-tiff/tools/tiffmedian.c<br>
-tiff/tools/tiffset.c<br>
-tiff/tools/tiffsplit.c<br>
-tiff/tools/ycbcr.c<br>
-toolbin/GenSubstCID.ps<br>
-toolbin/afmutil.py<br>
-toolbin/apitest.pl<br>
-toolbin/bmpcmp.c<br>
-toolbin/bughunt.sh<br>
-toolbin/bugsByEngineer.pl<br>
-toolbin/checkdeps.pl<br>
-toolbin/color/icc_creator/ICC Profiles/cmyk_k_ouput_only.icc<br>
-toolbin/color/icc_creator/ICC Profiles/ps_emulate_cmyk.icc<br>
-toolbin/color/icc_creator/ICC Profiles/ps_emulate_gray.icc<br>
-toolbin/color/icc_creator/ICC Profiles/ps_emulate_rgb.icc<br>
-toolbin/color/icc_creator/ICC_Creator.sln<br>
-toolbin/color/icc_creator/ICC_Creator/CIELAB.h<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_Creator.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_Creator.h<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_Creator.rc<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_Creator.vcproj<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.h<br>
-toolbin/color/icc_creator/ICC_Creator/icc34.h<br>
-toolbin/color/icc_creator/ICC_Creator/icc_create.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/icc_create.h<br>
-toolbin/color/icc_creator/ICC_Creator/res/ICC_Creator.rc2<br>
-toolbin/color/icc_creator/ICC_Creator/res/gsimage_.ico<br>
-toolbin/color/icc_creator/ICC_Creator/res/gswin.ico<br>
-toolbin/color/icc_creator/ICC_Creator/resource.h<br>
-toolbin/color/icc_creator/ICC_Creator/stdafx.cpp<br>
-toolbin/color/icc_creator/ICC_Creator/stdafx.h<br>
-toolbin/color/icc_creator/ICC_Creator/targetver.h<br>
-toolbin/color/icc_creator/README.txt<br>
-toolbin/color/icc_creator/effects/black_output.icc<br>
-toolbin/color/icc_creator/effects/c_only.txt<br>
-toolbin/color/icc_creator/effects/cyan_output.icc<br>
-toolbin/color/icc_creator/effects/k_only.txt<br>
-toolbin/color/icc_creator/effects/m_only.txt<br>
-toolbin/color/icc_creator/effects/magenta_output.icc<br>
-toolbin/color/icc_creator/effects/y_only.txt<br>
-toolbin/color/icc_creator/effects/yellow_output.icc<br>
-toolbin/color/icc_creator/example/artifex_blue_purple.icc<br>
-toolbin/color/icc_creator/example/artifex_tritone.icc<br>
-toolbin/color/icc_creator/example/cielab_values.txt<br>
-toolbin/color/icc_creator/example/color_names.txt<br>
-toolbin/color/icc_creator/example/duotone.pdf<br>
-toolbin/color/icc_creator/example/tritone.pdf<br>
-toolbin/color/icc_creator/example/tritone_cielab.txt<br>
-toolbin/color/icc_creator/example/tritone_names.txt<br>
-toolbin/color/icc_creator/ucr_bg.txt<br>
-toolbin/color/named_color/named_color_table.txt<br>
-toolbin/color/named_color/named_colors.pdf<br>
-toolbin/color/src_color/cmyk_des_renderintent.icc<br>
-toolbin/color/src_color/cmyk_src_cyan.icc<br>
-toolbin/color/src_color/cmyk_src_magenta.icc<br>
-toolbin/color/src_color/cmyk_src_renderintent.icc<br>
-toolbin/color/src_color/cmyk_src_yellow.icc<br>
-toolbin/color/src_color/objsrc_profiles_example.txt<br>
-toolbin/color/src_color/rgb_source_blue.icc<br>
-toolbin/color/src_color/rgb_source_green.icc<br>
-toolbin/color/src_color/rgb_source_red.icc<br>
-toolbin/drawafm.ps<br>
-toolbin/encs2c.ps<br>
-toolbin/errlist.tcl<br>
-toolbin/extractFonts.ps<br>
-toolbin/extractICCprofiles.ps<br>
-toolbin/gen_ldf_jb2.py<br>
-toolbin/genfontmap.ps<br>
-toolbin/gitlog2changelog.py<br>
-toolbin/gitsetup.sh<br>
-toolbin/gsmake<br>
-toolbin/gsmake.tcl<br>
-toolbin/halftone/ETS/README.txt<br>
-toolbin/halftone/ETS/ei03.pdf<br>
-toolbin/halftone/ETS/ets.c<br>
-toolbin/halftone/ETS/ets.h<br>
-toolbin/halftone/ETS/ipview.html<br>
-toolbin/halftone/ETS/test_ets.c<br>
-toolbin/halftone/ETS/tm.h<br>
-toolbin/halftone/ETS/win32/ETS.sln<br>
-toolbin/halftone/ETS/win32/ETS.vcproj<br>
-toolbin/halftone/gen_ordered/README<br>
-toolbin/halftone/gen_ordered/gen_ordered.c<br>
-toolbin/halftone/gen_ordered/gen_ordered.sln<br>
-toolbin/halftone/gen_ordered/gen_ordered.vcproj<br>
-toolbin/halftone/gen_stochastic/gen_stochastic.c<br>
-toolbin/halftone/gen_stochastic/gen_stochastic.sln<br>
-toolbin/halftone/gen_stochastic/gen_stochastic.vcproj<br>
-toolbin/headers.tcl<br>
-toolbin/htmldiff.pl<br>
-toolbin/jpxtopdf.c<br>
-toolbin/leaks.tcl<br>
-toolbin/localcluster/clusterpush.pl<br>
-toolbin/localcluster/clusterpush.txt<br>
-toolbin/localcluster/gitpush.sh<br>
-toolbin/localcluster/readme<br>
-toolbin/makehist.tcl<br>
-toolbin/memory.py<br>
-toolbin/ocheck.py<br>
-toolbin/pdf_info.ps<br>
-toolbin/pdfinflt.ps<br>
-toolbin/performance.pl<br>
-toolbin/pre.chk<br>
-toolbin/pre.tcl<br>
-toolbin/precheck.tcl<br>
-toolbin/pscet_status.pl<br>
-toolbin/search-svn-revs<br>
-toolbin/search/README<br>
-toolbin/smoke.ps<br>
-toolbin/split_changelog.py<br>
-toolbin/squeeze2html.pl<br>
-toolbin/suite.tcl<br>
-toolbin/tests/README<br>
-toolbin/tests/build_revision.py<br>
-toolbin/tests/check_all.py<br>
-toolbin/tests/check_comments.py<br>
-toolbin/tests/check_dirs.py<br>
-toolbin/tests/check_docrefs.py<br>
-toolbin/tests/check_source.py<br>
-toolbin/tests/cmpi.py<br>
-toolbin/tests/collate.py<br>
-toolbin/tests/compare_checksumdb.py<br>
-toolbin/tests/compare_checksums.py<br>
-toolbin/tests/dump_checksum.py<br>
-toolbin/tests/dump_checksum_plus.py<br>
-toolbin/tests/dump_checksum_raw.py<br>
-toolbin/tests/find_unique_file.py<br>
-toolbin/tests/fuzzy.c<br>
-toolbin/tests/get_baseline_log.py<br>
-toolbin/tests/get_baselines.py<br>
-toolbin/tests/gscheck_all.py<br>
-toolbin/tests/gscheck_fuzzypdf.py<br>
-toolbin/tests/gscheck_pdfwrite.py<br>
-toolbin/tests/gscheck_raster.py<br>
-toolbin/tests/gscheck_testfiles.py<br>
-toolbin/tests/gsconf.py<br>
-toolbin/tests/gsparamsets.py<br>
-toolbin/tests/gssum.py<br>
-toolbin/tests/gstestgs.py<br>
-toolbin/tests/gstestutils.py<br>
-toolbin/tests/gsutil.py<br>
-toolbin/tests/gsvalidate.py<br>
-toolbin/tests/main.py<br>
-toolbin/tests/make_baselinedb.py<br>
-toolbin/tests/make_testdb.py<br>
-toolbin/tests/make_two_pdfversions<br>
-toolbin/tests/make_two_versions<br>
-toolbin/tests/myoptparse.py<br>
-toolbin/tests/rasterdb.py<br>
-toolbin/tests/regen_baseline.py<br>
-toolbin/tests/regen_filelist.py<br>
-toolbin/tests/revert_baseline<br>
-toolbin/tests/revert_pdfbaseline<br>
-toolbin/tests/run_nightly<br>
-toolbin/tests/run_nightly.py<br>
-toolbin/tests/run_parallel<br>
-toolbin/tests/run_regression.py<br>
-toolbin/tests/run_series.py<br>
-toolbin/tests/testdiff.py<br>
-toolbin/tests/testing.cfg.example<br>
-toolbin/tests/update_baseline.py<br>
-toolbin/tests/update_specific<br>
-toolbin/tests/updatelist.py<br>
-toolbin/tests/updatelistpdf.py<br>
-toolbin/tests/validate.py<br>
-toolbin/tmake.tcl<br>
-toolbin/vg_bugs.supp<br>
-toolbin/vg_okay.supp<br>
-tools/Acrobat2Tiff/Acrobat2Tiff.sln<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff.vb<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff.vbproj<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Application.Designer.vb<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Application.myapp<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/AssemblyInfo.vb<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Resources.Designer.vb<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Resources.resx<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Settings.Designer.vb<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Settings.settings<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Acrobat2Tiff.exe<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Acrobat2Tiff.vshost.exe<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Acrobat2Tiff.xml<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Interop.Acrobat.dll<br>
-tools/GOT/README<br>
-tools/GOT/detag.c<br>
-tools/GOT/dotags.sh<br>
-tools/GOT/tagimage.c<br>
-tools/bitfont.pcl<br>
-tools/bitfonts.pxl<br>
-tools/cat_url.py<br>
-tools/check_deps.py<br>
-tools/cmpi/Makefile<br>
-tools/cmpi/Makefile.in<br>
-tools/cmpi/README<br>
-tools/cmpi/cmpi.bkl<br>
-tools/cmpi/cmpi.cpp<br>
-tools/cmpi/cmpi.dsp<br>
-tools/cmpi/cmpi.dsw<br>
-tools/cmpi/cmpi.pro<br>
-tools/cmpi/cmpi.rc<br>
-tools/cmpi/cmpi.sln<br>
-tools/cmpi/cmpi.suo<br>
-tools/cmpi/cmpi.vcp<br>
-tools/cmpi/cmpi.vcproj<br>
-tools/cmpi/cmpi.vcw<br>
-tools/cmpi/descrip.mms<br>
-tools/cmpi/makefile.bcc<br>
-tools/cmpi/makefile.dmc<br>
-tools/cmpi/makefile.dms<br>
-tools/cmpi/makefile.dos<br>
-tools/cmpi/makefile.gcc<br>
-tools/cmpi/makefile.sc<br>
-tools/cmpi/makefile.unx<br>
-tools/cmpi/makefile.va<br>
-tools/cmpi/makefile.vc<br>
-tools/cmpi/makefile.wat<br>
-tools/colorcirc.xps<br>
-tools/docov.pl<br>
-tools/fills.pcl<br>
-tools/fontpage.pcl<br>
-tools/fonts.pcl<br>
-tools/fonts.pxl<br>
-tools/frs96.pxl<br>
-tools/gl-chars.pcl<br>
-tools/gl2_chars.pl<br>
-tools/grashopp.pcl<br>
-tools/grid.pcl<br>
-tools/label.tst<br>
-tools/lineprinter.pcl<br>
-tools/make_snapshot.sh<br>
-tools/makeromttf.py<br>
-tools/null.pxl<br>
-tools/opaque.pcl<br>
-tools/origins.pcl<br>
-tools/owl.pcl<br>
-tools/owl2.pcl<br>
-tools/pattern.pcl<br>
-tools/pattern.pxl<br>
-tools/pcl2pdf<br>
-tools/pcl2pdf.bat<br>
-tools/pcl2pdfwr<br>
-tools/pcl2pdfwr.bat<br>
-tools/plot2pdf.sh<br>
-tools/pxlasm.py<br>
-tools/pxldis.py<br>
-tools/regress.sh<br>
-tools/revlist.py<br>
-tools/smoke_baseline.txt<br>
-tools/smoke_check.sh<br>
-tools/smoke_update.sh<br>
-tools/suite.tcl<br>
-tools/tiger.px3<br>
-tools/tiger.svg<br>
-tools/tiger.xps<br>
-tools/tt2pcl.c<br>
-tools/vasarely.px3<br>
-tools/xps2tiff/README<br>
-tools/xps2tiff/xps2tiff.sln<br>
-tools/xps2tiff/xps2tiff/AssemblyInfo.cpp<br>
-tools/xps2tiff/xps2tiff/stdafx.cpp<br>
-tools/xps2tiff/xps2tiff/stdafx.h<br>
-tools/xps2tiff/xps2tiff/xps2tiff.cpp<br>
-tools/xps2tiff/xps2tiff/xps2tiff.vcproj<br>
-urwfonts/A028-Ext.ttf<br>
-urwfonts/A028-Med.ttf<br>
-urwfonts/A030-Bol.ttf<br>
-urwfonts/A030-BolIta.ttf<br>
-urwfonts/A030-Ita.ttf<br>
-urwfonts/A030-Reg.ttf<br>
-urwfonts/AntiqueOlive-Bol.ttf<br>
-urwfonts/AntiqueOlive-Ita.ttf<br>
-urwfonts/AntiqueOlive-Reg.ttf<br>
-urwfonts/ArtLinePrinter.ttf<br>
-urwfonts/CenturySchL-Bold.ttf<br>
-urwfonts/CenturySchL-BoldItal.ttf<br>
-urwfonts/CenturySchL-Ital.ttf<br>
-urwfonts/CenturySchL-Roma.ttf<br>
-urwfonts/ClarendonURW-BolCon.ttf<br>
-urwfonts/Coronet.ttf<br>
-urwfonts/Dingbats.ttf<br>
-urwfonts/GaramondNo8-Ita.ttf<br>
-urwfonts/GaramondNo8-Med.ttf<br>
-urwfonts/GaramondNo8-MedIta.ttf<br>
-urwfonts/GaramondNo8-Reg.ttf<br>
-urwfonts/LetterGothic-Bol.ttf<br>
-urwfonts/LetterGothic-Ita.ttf<br>
-urwfonts/LetterGothic-Reg.ttf<br>
-urwfonts/Mauritius-Reg.ttf<br>
-urwfonts/NewDingbats.ttf<br>
-urwfonts/NimbusMonL-Bold.ttf<br>
-urwfonts/NimbusMonL-BoldObli.ttf<br>
-urwfonts/NimbusMonL-Regu.ttf<br>
-urwfonts/NimbusMonL-ReguObli.ttf<br>
-urwfonts/NimbusMono-Bol.ttf<br>
-urwfonts/NimbusMono-BolIta.ttf<br>
-urwfonts/NimbusMono-Ita.ttf<br>
-urwfonts/NimbusMono-Reg.ttf<br>
-urwfonts/NimbusRomNo9L-Medi.ttf<br>
-urwfonts/NimbusRomNo9L-MediItal.ttf<br>
-urwfonts/NimbusRomNo9L-Regu.ttf<br>
-urwfonts/NimbusRomNo9L-ReguItal.ttf<br>
-urwfonts/NimbusRomanNo4-Bol.ttf<br>
-urwfonts/NimbusRomanNo4-BolIta.ttf<br>
-urwfonts/NimbusRomanNo4-Lig.ttf<br>
-urwfonts/NimbusRomanNo4-LigIta.ttf<br>
-urwfonts/NimbusRomanNo9-Ita.ttf<br>
-urwfonts/NimbusRomanNo9-Med.ttf<br>
-urwfonts/NimbusRomanNo9-MedIta.ttf<br>
-urwfonts/NimbusRomanNo9-Reg.ttf<br>
-urwfonts/NimbusSanL-Bold.ttf<br>
-urwfonts/NimbusSanL-BoldCond.ttf<br>
-urwfonts/NimbusSanL-BoldCondItal.ttf<br>
-urwfonts/NimbusSanL-BoldItal.ttf<br>
-urwfonts/NimbusSanL-Regu.ttf<br>
-urwfonts/NimbusSanL-ReguCond.ttf<br>
-urwfonts/NimbusSanL-ReguCondItal.ttf<br>
-urwfonts/NimbusSanL-ReguItal.ttf<br>
-urwfonts/StandardSymL.ttf<br>
-urwfonts/U001-Bol.ttf<br>
-urwfonts/U001-BolIta.ttf<br>
-urwfonts/U001-Ita.ttf<br>
-urwfonts/U001-Reg.ttf<br>
-urwfonts/U001Con-Bol.ttf<br>
-urwfonts/U001Con-BolIta.ttf<br>
-urwfonts/U001Con-Ita.ttf<br>
-urwfonts/U001Con-Reg.ttf<br>
-urwfonts/URWBookmanL-DemiBold.ttf<br>
-urwfonts/URWBookmanL-DemiBoldItal.ttf<br>
-urwfonts/URWBookmanL-Ligh.ttf<br>
-urwfonts/URWBookmanL-LighItal.ttf<br>
-urwfonts/URWChanceryL-MediItal.ttf<br>
-urwfonts/URWClassico-Bol.ttf<br>
-urwfonts/URWClassico-BolIta.ttf<br>
-urwfonts/URWClassico-Ita.ttf<br>
-urwfonts/URWClassico-Reg.ttf<br>
-urwfonts/URWGothicL-Book.ttf<br>
-urwfonts/URWGothicL-BookObli.ttf<br>
-urwfonts/URWGothicL-Demi.ttf<br>
-urwfonts/URWGothicL-DemiObli.ttf<br>
-urwfonts/URWPalladioL-Bold.ttf<br>
-urwfonts/URWPalladioL-BoldItal.ttf<br>
-urwfonts/URWPalladioL-Ital.ttf<br>
-urwfonts/URWPalladioL-Roma.ttf<br>
-win32/GhostPDL.sln<br>
-win32/ReadMe.txt<br>
-win32/language_switch.vcproj<br>
-win32/pcl.vcproj<br>
-win32/xps.vcproj<br>
-winrt/GhostPDL.sln<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/project.pbxproj<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/project.xcworkspace/contents.xcworkspacedata<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/GhostPDL.xcscheme<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/ghostscript.xcscheme<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/language_switch.xcscheme<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/pcl.xcscheme<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/svg.xcscheme<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/xps.xcscheme<br>
-xcode/Makefile<br>
-xcode/clang_wrapper.c<br>
-xcode/clang_wrapper.sh<br>
-xcode/resolve.sh<br>
-xps/tools/colorcirc.xps<br>
-xps/tools/tiger.xps<br>
-xps/tools/xps2tiff/README<br>
-xps/tools/xps2tiff/xps2tiff.sln<br>
-xps/tools/xps2tiff/xps2tiff/AssemblyInfo.cpp<br>
-xps/tools/xps2tiff/xps2tiff/stdafx.cpp<br>
-xps/tools/xps2tiff/xps2tiff/stdafx.h<br>
-xps/tools/xps2tiff/xps2tiff/xps2tiff.cpp<br>
-xps/tools/xps2tiff/xps2tiff/xps2tiff.vcproj<br>
-xps/xps.mak<br>
-xps/xpsromfs.mak<br>
-zlib/CMakeLists.txt<br>
-zlib/ChangeLog<br>
-zlib/FAQ<br>
-zlib/INDEX<br>
-zlib/Makefile<br>
-zlib/Makefile.in<br>
-zlib/README<br>
-zlib/adler32.c<br>
-zlib/amiga/Makefile.pup<br>
-zlib/amiga/Makefile.sas<br>
-zlib/as400/bndsrc<br>
-zlib/as400/compile.clp<br>
-zlib/as400/readme.txt<br>
-zlib/as400/zlib.inc<br>
-zlib/compress.c<br>
-zlib/configure<br>
-zlib/contrib/README.contrib<br>
-zlib/contrib/ada/buffer_demo.adb<br>
-zlib/contrib/ada/mtest.adb<br>
-zlib/contrib/ada/read.adb<br>
-zlib/contrib/ada/readme.txt<br>
-zlib/contrib/ada/test.adb<br>
-zlib/contrib/ada/zlib-streams.adb<br>
-zlib/contrib/ada/zlib-streams.ads<br>
-zlib/contrib/ada/zlib-thin.adb<br>
-zlib/contrib/ada/zlib-thin.ads<br>
-zlib/contrib/ada/zlib.adb<br>
-zlib/contrib/ada/zlib.ads<br>
-zlib/contrib/ada/zlib.gpr<br>
-zlib/contrib/amd64/amd64-match.S<br>
-zlib/contrib/asm686/README.686<br>
-zlib/contrib/asm686/match.S<br>
-zlib/contrib/blast/Makefile<br>
-zlib/contrib/blast/README<br>
-zlib/contrib/blast/blast.c<br>
-zlib/contrib/blast/blast.h<br>
-zlib/contrib/blast/test.pk<br>
-zlib/contrib/blast/test.txt<br>
-zlib/contrib/delphi/ZLib.pas<br>
-zlib/contrib/delphi/ZLibConst.pas<br>
-zlib/contrib/delphi/readme.txt<br>
-zlib/contrib/delphi/zlibd32.mak<br>
-zlib/contrib/dotzlib/DotZLib.build<br>
-zlib/contrib/dotzlib/DotZLib.chm<br>
-zlib/contrib/dotzlib/DotZLib.sln<br>
-zlib/contrib/dotzlib/DotZLib/AssemblyInfo.cs<br>
-zlib/contrib/dotzlib/DotZLib/ChecksumImpl.cs<br>
-zlib/contrib/dotzlib/DotZLib/CircularBuffer.cs<br>
-zlib/contrib/dotzlib/DotZLib/CodecBase.cs<br>
-zlib/contrib/dotzlib/DotZLib/Deflater.cs<br>
-zlib/contrib/dotzlib/DotZLib/DotZLib.cs<br>
-zlib/contrib/dotzlib/DotZLib/DotZLib.csproj<br>
-zlib/contrib/dotzlib/DotZLib/GZipStream.cs<br>
-zlib/contrib/dotzlib/DotZLib/Inflater.cs<br>
-zlib/contrib/dotzlib/DotZLib/UnitTests.cs<br>
-zlib/contrib/dotzlib/LICENSE_1_0.txt<br>
-zlib/contrib/dotzlib/readme.txt<br>
-zlib/contrib/gcc_gvmat64/gvmat64.S<br>
-zlib/contrib/infback9/README<br>
-zlib/contrib/infback9/infback9.c<br>
-zlib/contrib/infback9/infback9.h<br>
-zlib/contrib/infback9/inffix9.h<br>
-zlib/contrib/infback9/inflate9.h<br>
-zlib/contrib/infback9/inftree9.c<br>
-zlib/contrib/infback9/inftree9.h<br>
-zlib/contrib/inflate86/inffas86.c<br>
-zlib/contrib/inflate86/inffast.S<br>
-zlib/contrib/iostream/test.cpp<br>
-zlib/contrib/iostream/zfstream.cpp<br>
-zlib/contrib/iostream/zfstream.h<br>
-zlib/contrib/iostream2/zstream.h<br>
-zlib/contrib/iostream2/zstream_test.cpp<br>
-zlib/contrib/iostream3/README<br>
-zlib/contrib/iostream3/TODO<br>
-zlib/contrib/iostream3/test.cc<br>
-zlib/contrib/iostream3/zfstream.cc<br>
-zlib/contrib/iostream3/zfstream.h<br>
-zlib/contrib/masmx64/bld_ml64.bat<br>
-zlib/contrib/masmx64/gvmat64.asm<br>
-zlib/contrib/masmx64/inffas8664.c<br>
-zlib/contrib/masmx64/inffasx64.asm<br>
-zlib/contrib/masmx64/readme.txt<br>
-zlib/contrib/masmx86/bld_ml32.bat<br>
-zlib/contrib/masmx86/inffas32.asm<br>
-zlib/contrib/masmx86/match686.asm<br>
-zlib/contrib/masmx86/readme.txt<br>
-zlib/contrib/minizip/Makefile<br>
-zlib/contrib/minizip/Makefile.am<br>
-zlib/contrib/minizip/MiniZip64_Changes.txt<br>
-zlib/contrib/minizip/MiniZip64_info.txt<br>
-zlib/contrib/minizip/configure.ac<br>
-zlib/contrib/minizip/crypt.h<br>
-zlib/contrib/minizip/ioapi.c<br>
-zlib/contrib/minizip/ioapi.h<br>
-zlib/contrib/minizip/iowin32.c<br>
-zlib/contrib/minizip/iowin32.h<br>
-zlib/contrib/minizip/make_vms.com<br>
-zlib/contrib/minizip/miniunz.c<br>
-zlib/contrib/minizip/miniunzip.1<br>
-zlib/contrib/minizip/minizip.1<br>
-zlib/contrib/minizip/minizip.c<br>
-zlib/contrib/minizip/minizip.pc.in<br>
-zlib/contrib/minizip/mztools.c<br>
-zlib/contrib/minizip/mztools.h<br>
-zlib/contrib/minizip/unzip.c<br>
-zlib/contrib/minizip/unzip.h<br>
-zlib/contrib/minizip/zip.c<br>
-zlib/contrib/minizip/zip.h<br>
-zlib/contrib/pascal/example.pas<br>
-zlib/contrib/pascal/readme.txt<br>
-zlib/contrib/pascal/zlibd32.mak<br>
-zlib/contrib/pascal/zlibpas.pas<br>
-zlib/contrib/puff/Makefile<br>
-zlib/contrib/puff/README<br>
-zlib/contrib/puff/puff.c<br>
-zlib/contrib/puff/puff.h<br>
-zlib/contrib/puff/pufftest.c<br>
-zlib/contrib/puff/zeros.raw<br>
-zlib/contrib/testzlib/testzlib.c<br>
-zlib/contrib/testzlib/testzlib.txt<br>
-zlib/contrib/untgz/Makefile<br>
-zlib/contrib/untgz/Makefile.msc<br>
-zlib/contrib/untgz/untgz.c<br>
-zlib/contrib/vstudio/readme.txt<br>
-zlib/contrib/vstudio/vc10/miniunz.vcxproj<br>
-zlib/contrib/vstudio/vc10/miniunz.vcxproj.filters<br>
-zlib/contrib/vstudio/vc10/minizip.vcxproj<br>
-zlib/contrib/vstudio/vc10/minizip.vcxproj.filters<br>
-zlib/contrib/vstudio/vc10/testzlib.vcxproj<br>
-zlib/contrib/vstudio/vc10/testzlib.vcxproj.filters<br>
-zlib/contrib/vstudio/vc10/testzlibdll.vcxproj<br>
-zlib/contrib/vstudio/vc10/testzlibdll.vcxproj.filters<br>
-zlib/contrib/vstudio/vc10/zlib.rc<br>
-zlib/contrib/vstudio/vc10/zlibstat.vcxproj<br>
-zlib/contrib/vstudio/vc10/zlibstat.vcxproj.filters<br>
-zlib/contrib/vstudio/vc10/zlibvc.def<br>
-zlib/contrib/vstudio/vc10/zlibvc.sln<br>
-zlib/contrib/vstudio/vc10/zlibvc.vcxproj<br>
-zlib/contrib/vstudio/vc10/zlibvc.vcxproj.filters<br>
-zlib/contrib/vstudio/vc11/miniunz.vcxproj<br>
-zlib/contrib/vstudio/vc11/minizip.vcxproj<br>
-zlib/contrib/vstudio/vc11/testzlib.vcxproj<br>
-zlib/contrib/vstudio/vc11/testzlibdll.vcxproj<br>
-zlib/contrib/vstudio/vc11/zlib.rc<br>
-zlib/contrib/vstudio/vc11/zlibstat.vcxproj<br>
-zlib/contrib/vstudio/vc11/zlibvc.def<br>
-zlib/contrib/vstudio/vc11/zlibvc.sln<br>
-zlib/contrib/vstudio/vc11/zlibvc.vcxproj<br>
-zlib/contrib/vstudio/vc9/miniunz.vcproj<br>
-zlib/contrib/vstudio/vc9/minizip.vcproj<br>
-zlib/contrib/vstudio/vc9/testzlib.vcproj<br>
-zlib/contrib/vstudio/vc9/testzlibdll.vcproj<br>
-zlib/contrib/vstudio/vc9/zlib.rc<br>
-zlib/contrib/vstudio/vc9/zlibstat.vcproj<br>
-zlib/contrib/vstudio/vc9/zlibvc.def<br>
-zlib/contrib/vstudio/vc9/zlibvc.sln<br>
-zlib/contrib/vstudio/vc9/zlibvc.vcproj<br>
-zlib/crc32.c<br>
-zlib/crc32.h<br>
-zlib/deflate.c<br>
-zlib/deflate.h<br>
-zlib/doc/algorithm.txt<br>
-zlib/doc/rfc1950.txt<br>
-zlib/doc/rfc1951.txt<br>
-zlib/doc/rfc1952.txt<br>
-zlib/doc/txtvsbin.txt<br>
-zlib/examples/README.examples<br>
-zlib/examples/enough.c<br>
-zlib/examples/fitblk.c<br>
-zlib/examples/gun.c<br>
-zlib/examples/gzappend.c<br>
-zlib/examples/gzjoin.c<br>
-zlib/examples/gzlog.c<br>
-zlib/examples/gzlog.h<br>
-zlib/examples/zlib_how.html<br>
-zlib/examples/zpipe.c<br>
-zlib/examples/zran.c<br>
-zlib/gzclose.c<br>
-zlib/gzguts.h<br>
-zlib/gzlib.c<br>
-zlib/gzread.c<br>
-zlib/gzwrite.c<br>
-zlib/infback.c<br>
-zlib/inffast.c<br>
-zlib/inffast.h<br>
-zlib/inffixed.h<br>
-zlib/inflate.c<br>
-zlib/inflate.h<br>
-zlib/inftrees.c<br>
-zlib/inftrees.h<br>
-zlib/make_vms.com<br>
-zlib/msdos/Makefile.bor<br>
-zlib/msdos/Makefile.dj2<br>
-zlib/msdos/Makefile.emx<br>
-zlib/msdos/Makefile.msc<br>
-zlib/msdos/Makefile.tc<br>
-zlib/nintendods/Makefile<br>
-zlib/nintendods/README<br>
-zlib/old/Makefile.emx<br>
-zlib/old/Makefile.riscos<br>
-zlib/old/README<br>
-zlib/old/descrip.mms<br>
-zlib/old/os2/Makefile.os2<br>
-zlib/old/os2/zlib.def<br>
-zlib/old/visual-basic.txt<br>
-zlib/qnx/package.qpg<br>
-zlib/test/example.c<br>
-zlib/test/infcover.c<br>
-zlib/test/minigzip.c<br>
-zlib/treebuild.xml<br>
-zlib/trees.c<br>
-zlib/trees.h<br>
-zlib/uncompr.c<br>
-zlib/watcom/watcom_f.mak<br>
-zlib/watcom/watcom_l.mak<br>
-zlib/win32/DLL_FAQ.txt<br>
-zlib/win32/Makefile.bor<br>
-zlib/win32/Makefile.gcc<br>
-zlib/win32/Makefile.msc<br>
-zlib/win32/README-WIN32.txt<br>
-zlib/win32/VisualC.txt<br>
-zlib/win32/zlib.def<br>
-zlib/win32/zlib1.rc<br>
-zlib/zconf.h<br>
-zlib/zconf.h.cmakein<br>
-zlib/zconf.h.in<br>
-zlib/zlib.3<br>
-zlib/zlib.3.pdf<br>
-zlib/zlib.h<br>
-zlib/zlib.map<br>
-zlib/zlib.pc.cmakein<br>
-zlib/zlib.pc.in<br>
-zlib/zlib2ansi<br>
-zlib/zutil.c<br>
-zlib/zutil.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-19 22:51:01 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7fd9e0be26e67c36f87733bc89ea07dc26d9f839">7fd9e0be26e67c36f87733bc89ea07dc26d9f839</a>
-<blockquote>
-<p>
- Modify clusterpush.pl to handle build_consolidation directory structure.<br>
-<br>
-gs/toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-15 16:10: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=f374cec0a68ad63707f398967f1a9fb38163fdae">f374cec0a68ad63707f398967f1a9fb38163fdae</a>
-<blockquote>
-<p>
- pdfwrite - More fiddling with symbolic TrueType fonts<br>
-<br>
- Bug #695969 &quot;Regression: Missing umlauts starting with 28b7d3c75adb8e942f2158bdec445a147f945530&quot;<br>
-<br>
- The problem here is the way that Acrobat behaves with symbolic fonts. If we define<br>
- a font as 'symbolic', then we don't write an Encoding (its not permitted<br>
- with PDF/A, and is technically invalid), and Acrobat uses the font's 1,0<br>
- CMAP subtable.<br>
-<br>
- If we do not write the font as symbolic then we need to write an Encoding. In<br>
- this case it seems that Acrobat uses the embedded font's 3,1 CMAP subtable.<br>
-<br>
- The problem is that the two tables need not be consistent, and in the case<br>
- of this file, are not. The character code 77 maps to GID 48 in both cases<br>
- but the character code 252 maps to GID 129 (a composite glyph) with the 3,1<br>
- CMAP and to a /.notdef with the 1,0 CMAP.<br>
-<br>
- This is only a problem if we *don't* subset the font, because if we subset the<br>
- font we *generate* a set of CMAP subtables, and we generate tables which<br>
- are consistent with each other.<br>
-<br>
- I did consider forcing the CMAP tables to be generated, even when not subsetting<br>
- the font, but this font contains more than 255 glyphs, so we can't fit them<br>
- all into a 1,0 CMAP anyway, so which ones should we use ?<br>
-<br>
- So instead, if we have a TrueType font, are embedding it, are *not* subsetting it<br>
- *and* the original font was 'not symbolic', (which we test by looking for the<br>
- presence of a 'nearest_encoding_index' in the original font as this is set<br>
- from the is_symbolic flag in the PDF interpreter, which is set from the<br>
- original font descriptor Flags value), then we do *NOT* mark the font as<br>
- symbolic.<br>
-<br>
- This also means altering the check against creating an Encoding, if we are<br>
- (eventually) going to make the font non-symbolic, then we need to add an<br>
- Encoding to it as well.<br>
-<br>
- This causes a difference in one cluster test, this is due to the fact that<br>
- the font can't be embedded due to licencing restrictions. Because of this<br>
- the output was already incorrect, its now incorrect in a slightly different<br>
- way.<br>
-<br>
-gs/devices/vector/gdevpdtd.c<br>
-gs/devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-13 16:03: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=962c6299e5fe72120eba0f966cbd0430105d8b49">962c6299e5fe72120eba0f966cbd0430105d8b49</a>
-<blockquote>
-<p>
- Update TrueType font copying code to handle OpenType 1.7 OS/2 tables<br>
-<br>
- Bug #696049 &quot;Postscript can not konverted to PDF&quot;<br>
-<br>
- The embedded TrueType font conforms to version 1.7 of the OpenType specifiction<br>
- which introduces 2 new variables to the OS/2 table. This makes the OS/2 table<br>
- length too great for the sanity checks in the code and it abrots with an error.<br>
-<br>
- This commit extends the checking to cater for version 1.7 OpenType OS/2<br>
- tables, and removes an unused variable at the same time.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gxttf.h<br>
-gs/devices/vector/gdevpsft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-13 10:08: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=7a18e49ebfbc225a3f1e8562571a2fc70fb61c48">7a18e49ebfbc225a3f1e8562571a2fc70fb61c48</a>
-<blockquote>
-<p>
- PDF interpreter - check type of XObject resoruces when scanning for transparency<br>
-<br>
- Bug #696083 &quot;Error reading PDF file&quot;<br>
-<br>
- The PDF file has a single page, but the /Pages dictionary has a Resources<br>
- dictionary (which is consulted if any page is missing a resource definition)<br>
-<br>
- The Page is complete, but when scanning for the presence of transparency<br>
- (to improve performance) we test any 'Parent' resources as well, and in this<br>
- case the Pages dictionary contains an XObject resource which is incorrect.<br>
-<br>
- Instead of a dictoinary, its an integer, and since that's the wrong type we<br>
- throw an error.<br>
-<br>
- This commit checks the type of XObject resources during scanning for transparency<br>
- and ignores (with a warning) any which have an incorrect type.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-02 11:07: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=aa48df9c6d4af5e611e8b641d8c544885f59b2ac">aa48df9c6d4af5e611e8b641d8c544885f59b2ac</a>
-<blockquote>
-<p>
- graphics library and interpreter changes to allow us to subclass the<br>
- pattern accumulator device.<br>
-<br>
- The main change is to pass a structure to the<br>
- device_spec_op which handle patterns. This structure carries the graphcs<br>
- state, which we require. This has required altering pdfwrite (the only<br>
- device currently implementing these spec_ops) and all the interpreters in<br>
- order to pass the required information.<br>
-<br>
- An additional change places the GC structure descriptor for the pattern<br>
- accumulator device in the device structure's 'stype' instead of leaving it<br>
- NULL. We can't subclass devices with a NULL stype.<br>
-<br>
-gs/base/gsptype1.c<br>
-gs/base/gxdevsop.h<br>
-gs/base/gxpcmap.c<br>
-gs/devices/vector/gdevpdfd.c<br>
-gs/devices/vector/gdevpdfi.c<br>
-gs/psi/zpcolor.c<br>
-pxl/pxink.c<br>
-xps/xpstile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-10 14:38: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=a3598cd629a959c189a9b2195640c3d5bdf8490d">a3598cd629a959c189a9b2195640c3d5bdf8490d</a>
-<blockquote>
-<p>
- Makefile: Add ZI_ macro for zlib include<br>
-<br>
- For files that only need zlib (and not, for example libpng nor libtiff), add a<br>
- makefile macro just for the zlib include path, and tweak to use it where<br>
- appropriate (gdevfpng.c doesn't use libpng but does use zlib).<br>
-<br>
- No cluster differences<br>
-<br>
-gs/base/gs.mak<br>
-gs/devices/devs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-10 14:48:51 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5a3bcaf5439ce0f911297d8e2a5699cd4cd983f3">5a3bcaf5439ce0f911297d8e2a5699cd4cd983f3</a>
-<blockquote>
-<p>
- Initialise a variable to silence scan-build (it can't actually be used uninitialised)<br>
-<br>
-gs/base/gdevdflt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-10 14:39:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=326a116687ee35db6d1bdcc54f2a8b2fb4458878">326a116687ee35db6d1bdcc54f2a8b2fb4458878</a>
-<blockquote>
-<p>
- PDF interpreter - alter rebuilding of xref when problems are detected<br>
-<br>
- Bug #696084 &quot;Page rendered blank&quot;<br>
-<br>
- The file is pretty classically broken. It starts with an entry in the xref<br>
- for object 290 which is not flagged as 'free'. However, when we check the<br>
- file at the given offset it actually points to object 228.<br>
-<br>
- This triggers us to rescan the file, because the xref is broken. So we sweep<br>
- the file from beginning to end looking for the sequence 'x y obj'. NB we<br>
- don't (can't) do this for object streams, because those are compressed.<br>
-<br>
- When we find an object definition we enter it into the rebuilt xref table.<br>
-<br>
- However, this file contains duplicate definitions for all the page objects<br>
- which leads us to emit a warning that there are multiple definitions and the<br>
- output may be incorrect. The rebuilding code uses the *last* definition of<br>
- a given object and the highest generation number, because in general when<br>
- there are multiple definitions of the same object, the last one is the one<br>
- that's correct (PDF tools usually modify the file by appending rather than<br>
- writing into the middle of the file).<br>
-<br>
- However, in this case, the *first* definition is the correct one. Not only<br>
- that but the second definitions aren't even valid.....<br>
-<br>
- So the problem is caused by; a broken xref table, multiple definitions of<br>
- the same object, and the later definitions being invalid.<br>
-<br>
- I've worked around this by checking the *original* xref table and if one of<br>
- the definitions is at the same offset as defined in the original xref we now<br>
- always prefer that definition, otherwise we prefer the last definition, as<br>
- before.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_rbld.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-10 09:00: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=4dbd8ee3ffa0c0f18fe43acff3e859b61323844b">4dbd8ee3ffa0c0f18fe43acff3e859b61323844b</a>
-<blockquote>
-<p>
- Coverity IDs 101838 and 101840<br>
-<br>
-gs/base/gdevsclass.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-10 08: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=202bd93e65d5f30070de06f4dc449450e316ebad">202bd93e65d5f30070de06f4dc449450e316ebad</a>
-<blockquote>
-<p>
- Coverity ID 101842, checking 'dev' and 'child' before dereferencing<br>
-<br>
-gs/base/gdevdflt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-10 08:30: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=e28d75a2f2b7828d1d6deb7667f545c7c73ace33">e28d75a2f2b7828d1d6deb7667f545c7c73ace33</a>
-<blockquote>
-<p>
- Coverity IDs 101844, 101843, 101839<br>
-<br>
- I don't think that dev can be NULL here, but just for safety.<br>
-<br>
-gs/base/gdevmplt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-09 15:14: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=80653628e28a8520a48b0ca3bb9cd0e1a1874001">80653628e28a8520a48b0ca3bb9cd0e1a1874001</a>
-<blockquote>
-<p>
- Move variable to procedure header, from body<br>
-<br>
- This caused PCL not to build on VS and (at least sometimes) on Linuc but<br>
- oddly was not a problem on the cluster.<br>
-<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-09 15:13:13 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6214c2d6f8ed3aea4f4e7140899489ada5ccc46">f6214c2d6f8ed3aea4f4e7140899489ada5ccc46</a>
-<blockquote>
-<p>
- Fix a potential uninitialised variable spotted by scan-build<br>
-<br>
-pcl/pcpalet.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-17 14:51: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=f98b0b84a7f7c1833550ee3938f60aef356840c3">f98b0b84a7f7c1833550ee3938f60aef356840c3</a>
-<blockquote>
-<p>
- Addition of device 'subclassing'<br>
-<br>
- This is a new feature in the graphcs library which allows for a chain of<br>
- devices to be created and for new devices to be created and added to that<br>
- chain, even if the graphcs state is not available.<br>
-<br>
- The work for ths was originally performed on the 'device_subclassing'<br>
- branch, and all the history is maikntained in that branch. This single<br>
- commit embodies all the work, but none of the history.<br>
-<br>
- The background to the code is documented in ghostpdl/doc/subclass.htm.<br>
-<br>
- In addition to the graphics library support for this feature there are two<br>
- new devices; the First Page/Last Page device and the Object Filtering<br>
- device.<br>
-<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/base/gdevbbox.c<br>
-gs/base/gdevdevn.c<br>
-gs/base/gdevdflt.c<br>
-gs/base/gdevdgbr.c<br>
-gs/base/gdevflp.c<br>
-gs/base/gdevflp.h<br>
-gs/base/gdevkrnlsclass.c<br>
-gs/base/gdevkrnlsclass.h<br>
-gs/base/gdevmplt.c<br>
-gs/base/gdevmplt.h<br>
-gs/base/gdevnfwd.c<br>
-gs/base/gdevoflt.c<br>
-gs/base/gdevoflt.h<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevsclass.c<br>
-gs/base/gdevsclass.h<br>
-gs/base/gdevvec.c<br>
-gs/base/gscspace.c<br>
-gs/base/gsdevice.c<br>
-gs/base/gsdparam.c<br>
-gs/base/gserrors.h<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_replacecm.c<br>
-gs/base/gsovrc.c<br>
-gs/base/gspaint.c<br>
-gs/base/gsstate.c<br>
-gs/base/gxclbits.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclist.h<br>
-gs/base/gxclpage.c<br>
-gs/base/gxclrast.c<br>
-gs/base/gxcmap.c<br>
-gs/base/gxdcolor.c<br>
-gs/base/gxdevcli.h<br>
-gs/base/gxdevice.h<br>
-gs/base/gxpcmap.c<br>
-gs/base/lib.mak<br>
-gs/contrib/opvp/gdevopvp.c<br>
-gs/contrib/pcl3/eprn/gdeveprn.c<br>
-gs/contrib/pcl3/src/gdevpcl3.c<br>
-gs/devices/gdevbit.c<br>
-gs/devices/gdevcdj.c<br>
-gs/devices/gdevdsp.c<br>
-gs/devices/gdevfpng.c<br>
-gs/devices/gdevpbm.c<br>
-gs/devices/gdevtfax.c<br>
-gs/devices/gdevtifs.c<br>
-gs/devices/gdevtsep.c<br>
-gs/devices/gdevupd.c<br>
-gs/devices/gdevwdib.c<br>
-gs/devices/gdevwpr2.c<br>
-gs/devices/gdevx.c<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfb.h<br>
-gs/devices/vector/gdevpdfc.c<br>
-gs/devices/vector/gdevpdfc.h<br>
-gs/devices/vector/gdevpdfi.c<br>
-gs/devices/vector/gdevpdfk.c<br>
-gs/devices/vector/gdevpdfo.c<br>
-gs/devices/vector/gdevpdfo.h<br>
-gs/devices/vector/gdevpdfp.c<br>
-gs/devices/vector/gdevpdfu.c<br>
-gs/devices/vector/gdevpdfv.c<br>
-gs/devices/vector/gdevpdfx.h<br>
-gs/devices/vector/gdevpdtd.c<br>
-gs/devices/vector/gdevpdtt.c<br>
-gs/devices/vector/gdevpsdu.c<br>
-gs/devices/vector/gdevpx.c<br>
-gs/devices/vector/gdevtxtw.c<br>
-gs/devices/vector/gdevxps.c<br>
-gs/doc/Use.htm<br>
-gs/doc/subclass.htm<br>
-gs/psi/zdevice2.c<br>
-pcl/pcl.mak<br>
-pcl/pcpalet.c<br>
-pl/plmain.c<br>
-psi/psitop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-07 16:57: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=0c0b0859ae1aba64861599f0e7f74f143f305932">0c0b0859ae1aba64861599f0e7f74f143f305932</a>
-<blockquote>
-<p>
- Bug 696041: sanity check for memory allocation.<br>
-<br>
- In gs_heap_alloc_bytes(), add a sanity check to ensure we don't overflow the<br>
- variable holding the actual number of bytes we allocate.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/base/gsmalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-05 17:56:30 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9d53a5175c77ca789f099f3d77d4109f6a412cdd">9d53a5175c77ca789f099f3d77d4109f6a412cdd</a>
-<blockquote>
-<p>
- Document added lib and examples file to silence regression warnings.<br>
-<br>
-gs/doc/Develop.htm<br>
-gs/doc/Psfiles.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-03 13:25: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=95c861c397536f4427297caf88935ef474466f8f">95c861c397536f4427297caf88935ef474466f8f</a>
-<blockquote>
-<p>
- Bug 695475: use gs_snprintf in font serializing<br>
-<br>
- Change to using gs_snprintf() (from gs_sprintf) in the Type 1 and 2 font<br>
- serializing code, and if the number is truncated, print a warning (but carry<br>
- on).<br>
-<br>
- No cluster differences<br>
-<br>
-gs/base/lib.mak<br>
-gs/base/wrfont.c<br>
-gs/base/wrfont.h<br>
-gs/base/write_t1.c<br>
-gs/base/write_t2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-02 15:57: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=d8c1bfb119b9a5d44d684227104c01bcdbcea0f5">d8c1bfb119b9a5d44d684227104c01bcdbcea0f5</a>
-<blockquote>
-<p>
- Remove last vestige of TurboC build<br>
-<br>
-gs/base/turboc.cfg<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-30 08:58: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=65a4fa4d6fbd3ab04f565e051d6a7af8f65c0960">65a4fa4d6fbd3ab04f565e051d6a7af8f65c0960</a>
-<blockquote>
-<p>
- Replace strtok()<br>
-<br>
- Add a portable, thread-safe equivalent of strtok() lifted from the Apache<br>
- project a tweaked slightly for use in Ghostcript.<br>
-<br>
- Commit apache strtok source &quot;as is&quot;<br>
-<br>
- Rename apache strtok source file to suit GS<br>
-<br>
- Add header for gs_strtok()<br>
-<br>
- First pass at makefile changes for gs_strtok()<br>
-<br>
- Tweak apache strtok() code to work for Ghostscript<br>
-<br>
- Further makefile tweak for gs_strtok<br>
-<br>
- Missing semicolon<br>
-<br>
- Modify code to use gs_strtok() instead of strtok<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsstrtok.c<br>
-gs/base/gsstrtok.h<br>
-gs/base/lib.mak<br>
-gs/base/string_.h<br>
-gs/devices/gdevwpr2.c<br>
-gs/psi/dscparse.c<br>
-pl/pjparse.c<br>
-pl/pllfont.c<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-29 12:05: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=b04c259dc71b3c7890e0c3771ee1b8f79519be1e">b04c259dc71b3c7890e0c3771ee1b8f79519be1e</a>
-<blockquote>
-<p>
- Replace trio for sprintf<br>
-<br>
- Use code from the Apache project (under Apache License) tweaked to remove<br>
- Apache specific dependencies and to better fit our formatting needs.<br>
-<br>
- Cluster differences only due to slight difference in at what point the exponent<br>
- notation kicks in.<br>
-<br>
- Add Apache's sprintf implementation &quot;as is&quot;<br>
-<br>
- Rename Apache sprintf source.<br>
-<br>
- Tweak to work outside of Apache<br>
-<br>
-common/msvc_top.mak<br>
-common/ugcc_top.mak<br>
-config.mak.in<br>
-configure.ac<br>
-gs/Makefile.in<br>
-gs/base/gs.mak<br>
-gs/base/gssprintf.c<br>
-gs/base/gssprintf.h<br>
-gs/base/gxclmem.c<br>
-gs/base/lib.mak<br>
-gs/base/trio.mak<br>
-gs/base/unix-gcc.mak<br>
-gs/base/unixansi.mak<br>
-gs/base/winlib.mak<br>
-gs/configure.ac<br>
-gs/psi/msvc.mak<br>
-gs/trio/CHANGES<br>
-gs/trio/FILES<br>
-gs/trio/Makefile.in<br>
-gs/trio/README<br>
-gs/trio/autogen.sh<br>
-gs/trio/compare.c<br>
-gs/trio/configure.in<br>
-gs/trio/doc/doc.h<br>
-gs/trio/doc/doc_dynamic.h<br>
-gs/trio/doc/doc_printf.h<br>
-gs/trio/doc/doc_register.h<br>
-gs/trio/doc/doc_scanf.h<br>
-gs/trio/doc/doc_static.h<br>
-gs/trio/doc/footer.html<br>
-gs/trio/doc/header.html<br>
-gs/trio/doc/trio.cfg<br>
-gs/trio/doc/trio.css<br>
-gs/trio/example.c<br>
-gs/trio/html/group___dynamic_strings.html<br>
-gs/trio/html/group___printf.html<br>
-gs/trio/html/group___scanf.html<br>
-gs/trio/html/group___special_quantities.html<br>
-gs/trio/html/group___static_strings.html<br>
-gs/trio/html/group___user_defined.html<br>
-gs/trio/html/index.html<br>
-gs/trio/html/modules.html<br>
-gs/trio/html/trio.css<br>
-gs/trio/install-sh<br>
-gs/trio/maketgz<br>
-gs/trio/regression.c<br>
-gs/trio/strio.h<br>
-gs/trio/trio.c<br>
-gs/trio/trio.h<br>
-gs/trio/triodef.h<br>
-gs/trio/trionan.c<br>
-gs/trio/trionan.h<br>
-gs/trio/triop.h<br>
-gs/trio/triostr.c<br>
-gs/trio/triostr.h<br>
-main/pcl6_gcc.mak<br>
-main/pcl6_msvc.mak<br>
-xps/xps_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-02 09:22: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=86beea017099fa94f210b8eaa028656c197ce676">86beea017099fa94f210b8eaa028656c197ce676</a>
-<blockquote>
-<p>
- Support for Margins on the PCL command line.<br>
-<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-02 07:43:09 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c802d7bca87d26fabbc090518e942b2424e1f269">c802d7bca87d26fabbc090518e942b2424e1f269</a>
-<blockquote>
-<p>
- Margins resolution units were not correct for the X11 device.<br>
-<br>
- X11 initializes resolution and margin's resolution to &quot;FAKE_RES&quot; (1152)<br>
- at compile time. Upon initialization if the resolution is still<br>
- FAKE_RES indicating the resolution wasn't set on the command line or by<br>
- parameter setting the code figures out a good resolution by querying X11<br>
- screen dimensions. It forgot to set the Margin Resolution which<br>
- remained at 1152 dpi.<br>
-<br>
-gs/devices/gdevxini.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-07-02 07:40:11 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=04859e2ea30608d0ae8a4b844dac2f7ea36cbb82">04859e2ea30608d0ae8a4b844dac2f7ea36cbb82</a>
-<blockquote>
-<p>
- A little better documentation for &quot;MarginsHWResolution&quot;.<br>
-<br>
-gs/base/gxdevcli.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-30 07:28:35 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8563e28b346f50cef8ee30dafba8a39b9af55e20">8563e28b346f50cef8ee30dafba8a39b9af55e20</a>
-<blockquote>
-<p>
- Fix 696039 - Command line option doesn't allow &quot;0&quot; margins.<br>
-<br>
- A parsing error in scanf will not allow parsing floats in the format<br>
- %fx%f if the float argument is 0, we now use strtok() to parse the<br>
- floats in the format string.<br>
-<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-29 15:56:39 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3f39e091c56a8abbe61124a728ab9382b246643b">3f39e091c56a8abbe61124a728ab9382b246643b</a>
-<blockquote>
-<p>
- Fix lacking debug output for the label termination command.<br>
-<br>
-pcl/pgchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-29 08:39:20 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=07859ace56b3410ac0af31ce1300505e7582d756">07859ace56b3410ac0af31ce1300505e7582d756</a>
-<blockquote>
-<p>
- Improve the readability of the built-in bitmap patterns. The change has<br>
- no effect on program execution.<br>
-<br>
-pcl/pcbiptrn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-30 08:05:14 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=835ce7c78f3e396554dd2b965e41476e1bd72f8d">835ce7c78f3e396554dd2b965e41476e1bd72f8d</a>
-<blockquote>
-<p>
- Coverity ID #95048: Use of 'f' file pointer after freed by freopen.<br>
-<br>
-gs/base/gxclfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-30 13:53: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=2d54c07d327f8d7b3eabc8a15c80127dc847e949">2d54c07d327f8d7b3eabc8a15c80127dc847e949</a>
-<blockquote>
-<p>
- XPS Interpreter - allow for empty remote resource dictionaries<br>
-<br>
- Bug #696061 &quot;conversion of Test.xps fails with segment violation&quot;<br>
-<br>
- If there was no remote resource dictionary, or it was empty, the code<br>
- assigned XML data to the dictionary, which would cause a seg fault as the<br>
- dictionary pointer was NULL.<br>
-<br>
- Simply check for a NULL dictionary pointer and if found, discard the<br>
- 'xml' data instead of assigning it to the dictionary.<br>
-<br>
- A similar fix is already present in MuPDF.<br>
-<br>
-xps/xpsresource.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-29 18:51:39 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cf5a15bbc7b932ef4525962f770b1d6126383732">cf5a15bbc7b932ef4525962f770b1d6126383732</a>
-<blockquote>
-<p>
- Coverity ID #95083: Uninitialized variable 'code' used if color is not pure<br>
-<br>
-gs/base/gxcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-28 19:27: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=612f284f7cba5f3abf45b7f572af064cac0d005e">612f284f7cba5f3abf45b7f572af064cac0d005e</a>
-<blockquote>
-<p>
- PDF Interpreter - Don't attempt to draw annotations scaled to 0 size<br>
-<br>
- Bug #696051 &quot;Warning only appears with -dTextAlphaBits=4&quot;<br>
-<br>
- This commit does not address the underlying fault. The interpreter/graphics<br>
- library behaves differently with TextAlphaBits set and not. This:<br>
-<br>
- /Helvetica findfont 20 scalefont setfont 10 10 moveto (test) show<br>
-<br>
- gives an error with -dTextAlphaBits set, but not when it isn't. The latter<br>
- appears to be incorrect.<br>
-<br>
- We work around this in the PDF interpreter by checking the scale factor<br>
- (because the actual fault is a /Rect [0 0 0 0]) and if either the x or y<br>
- scale is 0, we simply don't draw the annotation.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-23 15:36:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7e8cd8ff35d36d66a7f5de50c16bcc0a4352777d">7e8cd8ff35d36d66a7f5de50c16bcc0a4352777d</a>
-<blockquote>
-<p>
- Commit f5444527 inadvertently introduced seg faults, fixed here.<br>
-<br>
-gs/devices/vector/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-23 12:37:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d5287fe7585d7a203656244a72a15cb958cd798d">d5287fe7585d7a203656244a72a15cb958cd798d</a>
-<blockquote>
-<p>
- Coverity ID #94512 copy paste error, x should have been y<br>
-<br>
-gs/devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-23 12:14: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=f544452718283d4d7122b3c22c1f3991313099ea">f544452718283d4d7122b3c22c1f3991313099ea</a>
-<blockquote>
-<p>
- Coverity ID #94859 rearrange code to avoid potential NULL pointer dereference<br>
-<br>
-gs/devices/vector/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-23 12:03:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6b7de65620163f1a92ce42ef787a0ae4b07ecdef">6b7de65620163f1a92ce42ef787a0ae4b07ecdef</a>
-<blockquote>
-<p>
- Coverity ID #94702 a missing ',' caused two standard CMap names to be concatenated, which means they were effectively both corrupted.<br>
-<br>
-gs/devices/vector/gdevpdtc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-23 11:44: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=83d2eb9128d94aa18fc4f9cc7d0b79e5d53976e5">83d2eb9128d94aa18fc4f9cc7d0b79e5d53976e5</a>
-<blockquote>
-<p>
- Coverity ID #94692 the variable 'code1' is pointlessly used to save a<br>
- return code. This is no longer needed, so removed.<br>
-<br>
-gs/devices/vector/gdevpdtb.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-23 11:29: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=3fd5c000705d844ae609945ae82260ccdff58896">3fd5c000705d844ae609945ae82260ccdff58896</a>
-<blockquote>
-<p>
- Coverity ID #94854, 94855, 94871, 94928 avoid potential array overrun<br>
- by using '&gt;=' instead of '&gt;'. In practice this can't happen, because the<br>
- enum value 'NUM_RESOURCe_TYPES' isn't used to create or address any actual<br>
- resources.<br>
-<br>
-gs/devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-23 08:55: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=352a75aaba6804eab50b49e6c574365a83e37c47">352a75aaba6804eab50b49e6c574365a83e37c47</a>
-<blockquote>
-<p>
- Coverity ID #94534 another two ignored returns from gp_fseek_64<br>
-<br>
-gs/devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-23 08:53:13 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=47485417cd9a734d5a7c9951eadcd8d5888ac34b">47485417cd9a734d5a7c9951eadcd8d5888ac34b</a>
-<blockquote>
-<p>
- Coverity ID #94521 fix two more cases of ignored return values from gp_fseek_64<br>
-<br>
-gs/devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-23 08:50:50 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ebc78b1157d2393d5996425c1c2bd06b383db478">ebc78b1157d2393d5996425c1c2bd06b383db478</a>
-<blockquote>
-<p>
- Coverity ID #94509 check and action return value from gp_fessk_64<br>
-<br>
-gs/devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-23 08:47: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=867a7589bd1006ba9d1f0866e1ccf2fb87094c49">867a7589bd1006ba9d1f0866e1ccf2fb87094c49</a>
-<blockquote>
-<p>
- Initialise variable to silence compiler warning<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-14 10:22:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d16982fb1078ecfe371f15df86c63f4649d70fdd">d16982fb1078ecfe371f15df86c63f4649d70fdd</a>
-<blockquote>
-<p>
- Bug 696034: Add the correct updated font files<br>
-<br>
- I mistakenly committed the wrong font update (ones without the extra cyrillic<br>
- and greek glyphs), this corrects the mistake.<br>
-<br>
- Cluster differences expected....<br>
-<br>
-gs/Resource/Font/NimbusMon-Bol<br>
-gs/Resource/Font/NimbusMon-BolObl<br>
-gs/Resource/Font/NimbusMon-Obl<br>
-gs/Resource/Font/NimbusMon-Reg<br>
-gs/Resource/Font/NimbusMono-Bold<br>
-gs/Resource/Font/NimbusMono-BoldOblique<br>
-gs/Resource/Font/NimbusMono-Oblique<br>
-gs/Resource/Font/NimbusMono-Regular<br>
-gs/Resource/Font/NimbusRom-Ita<br>
-gs/Resource/Font/NimbusRom-Med<br>
-gs/Resource/Font/NimbusRom-MedIta<br>
-gs/Resource/Font/NimbusRom-Reg<br>
-gs/Resource/Font/NimbusRomNo9L-Med<br>
-gs/Resource/Font/NimbusRomNo9L-MedIta<br>
-gs/Resource/Font/NimbusRomNo9L-Reg<br>
-gs/Resource/Font/NimbusRomNo9L-RegIta<br>
-gs/Resource/Font/NimbusSan-Bol<br>
-gs/Resource/Font/NimbusSan-BolIta<br>
-gs/Resource/Font/NimbusSan-Ita<br>
-gs/Resource/Font/NimbusSan-Reg<br>
-gs/Resource/Font/NimbusSanL-Bol<br>
-gs/Resource/Font/NimbusSanL-BolIta<br>
-gs/Resource/Font/NimbusSanL-Reg<br>
-gs/Resource/Font/NimbusSanL-RegIta<br>
-gs/Resource/Init/Fontmap.GS<br>
-gs/psi/psromfs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-23 08:24: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=663d2c237506045862a4c8d13cbea26c534dc893">663d2c237506045862a4c8d13cbea26c534dc893</a>
-<blockquote>
-<p>
- Quash some compiler warnings.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-22 08:02: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=e30f3e82b017756428974be81c08fb212f28673e">e30f3e82b017756428974be81c08fb212f28673e</a>
-<blockquote>
-<p>
- Coverity #94836: remove dead code.<br>
-<br>
- No cluster diffs<br>
-<br>
-gs/base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 16:00:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=078079b7a857c5d640854fd1a06578675d9adaab">078079b7a857c5d640854fd1a06578675d9adaab</a>
-<blockquote>
-<p>
- Coverity ID #94816: initialise pointer to NULL.<br>
-<br>
- Benign: initialise the ft_stream pointer to NULL when we're not opening a stream<br>
- based font in freetype.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 15:57: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=e0778e3f7815dd4a27b275772560dc450d5e2bc3">e0778e3f7815dd4a27b275772560dc450d5e2bc3</a>
-<blockquote>
-<p>
- Coverity ID# 94753: clean up error handling.<br>
-<br>
- Move handling an out of memory condition to avoid a potential null pointer<br>
- dereference.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 15:55: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=81137c03db99736261862fb2745e8e989983e859">81137c03db99736261862fb2745e8e989983e859</a>
-<blockquote>
-<p>
- Coverity: ID #94572: NULL pointer dereference<br>
-<br>
- In the event we have no i/o device, throw an error. Avoids a possible NULL<br>
- pointer dereference.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 15:45:20 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9e264c139aa99ad827171e65ebd802d55cb92dbe">9e264c139aa99ad827171e65ebd802d55cb92dbe</a>
-<blockquote>
-<p>
- Coverity ID #94675, #94731, #94772, #94800<br>
-<br>
- Tidy up conditionals where one condition cannot occur at that point (mostly<br>
- benign copy and paste mistakes).<br>
-<br>
- Restore a locally changed value in an external object before returning.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gxfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-23 08:21: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=134424c1fe1b163e3bd3e230b6b2acd217843d9c">134424c1fe1b163e3bd3e230b6b2acd217843d9c</a>
-<blockquote>
-<p>
- The default case lacked a break. I suspect this is a hold over from an<br>
- older set of code where it may have made sense, it doesn't now.<br>
-<br>
-gs/devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-23 08:20: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=500f1e8f1436ac82c642c325d0f0e67aabc9cef9">500f1e8f1436ac82c642c325d0f0e67aabc9cef9</a>
-<blockquote>
-<p>
- Coverity ID #94701 two comparisons against ccs_sRGB. We really wanted to<br>
- test for RGB or sRGB here, so one of them should have been ccs_RGB. Fixed<br>
-<br>
-gs/devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-22 14:59: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=05e65d67fcf33e8223bacfe7c060380ba291c07c">05e65d67fcf33e8223bacfe7c060380ba291c07c</a>
-<blockquote>
-<p>
- change missed in previous commit<br>
-<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-22 14:57: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=94105d6b7273c83e24f8561f4c086657fa071219">94105d6b7273c83e24f8561f4c086657fa071219</a>
-<blockquote>
-<p>
- coverity ID #94518 more checks on return code form gp_fseek_64<br>
-<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-22 14:39: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=a89d5988026eeb1477bd9a2ec8b463fc4596fa21">a89d5988026eeb1477bd9a2ec8b463fc4596fa21</a>
-<blockquote>
-<p>
- Coverity ID #94510 add some checks to the return from gp_fseek_64<br>
-<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-22 14:18:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=30f0a322ea0643366a93274e03dc80e226a7b822">30f0a322ea0643366a93274e03dc80e226a7b822</a>
-<blockquote>
-<p>
- Coverity ID #94648, ensure a pointer cannot be dereferenced if NULL. In<br>
- practice it can't happen because we check the size of the data firs, and the<br>
- size is initialised to 0. But it is slightly safer to be certain.<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-22 13:51: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=0f7ab3e067a5e8b8434312ca5ce364869288eeec">0f7ab3e067a5e8b8434312ca5ce364869288eeec</a>
-<blockquote>
-<p>
- Coverity ID #94530 check and action a return code.<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-21 16:28:42 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d4a868350c8ec82b8ce42100cd03aef92e1d40a">4d4a868350c8ec82b8ce42100cd03aef92e1d40a</a>
-<blockquote>
-<p>
- Coverity ID #94974, the variable can never be uninitialised, but that's<br>
- not evident because it depends on the switch statement and there is no<br>
- default case coded because we cater for all possibilities.<br>
-<br>
- Add a memset to the default case just to set the memory to NULL, it will<br>
- never be called.<br>
-<br>
-gs/devices/vector/gdevpdfk.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-21 16:24: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=7427b67964490963ce82076a0cd4ff334d03ad62">7427b67964490963ce82076a0cd4ff334d03ad62</a>
-<blockquote>
-<p>
- Coverity ID #94931 increase buffer to 256 so that array bounds check is correct.<br>
-<br>
-gs/devices/vector/gdevpdfj.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-21 16:16: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=a8eb47a837b31ce723e76c98f122ba834b7380d0">a8eb47a837b31ce723e76c98f122ba834b7380d0</a>
-<blockquote>
-<p>
- Coverity ID #94678 guard a potential null pointer dereference with a check.<br>
-<br>
-gs/devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-21 13:51:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f629df898a59145db4b8b60447ba46671a3bf76e">f629df898a59145db4b8b60447ba46671a3bf76e</a>
-<blockquote>
-<p>
- dummy<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-21 13:36: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=010b0dc68542a17e0309f230ee071ca0a6f2bb84">010b0dc68542a17e0309f230ee071ca0a6f2bb84</a>
-<blockquote>
-<p>
- Coverity ID #95002 another couple of pointless NULL pointer checks<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-21 13:30: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=b0f10e57dcd17c31a8754eaca38ba49a4496f52d">b0f10e57dcd17c31a8754eaca38ba49a4496f52d</a>
-<blockquote>
-<p>
- Coverity ID #94908 pointless check of NULL Pointer, removed.<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-21 13:23: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=6482eded57246b1ddebe590d6874a01220477d16">6482eded57246b1ddebe590d6874a01220477d16</a>
-<blockquote>
-<p>
- Coverity ID #94680, the previous code checked the incorrect returned value,<br>
- leading to dead code.<br>
-<br>
- Coverity ID #94786, this is spurious, we check the colour space is one of<br>
- Gray, RGB or CMYK, then switch on the number of components (1, 3, 4) and set<br>
- a variable. This causes a complaint that the variable 'command' could be<br>
- dereferenced when NULL. In practice this is impossible.<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 15:51:42 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34aa319c5d592ffba5d814aef30e67f3aef55adb">34aa319c5d592ffba5d814aef30e67f3aef55adb</a>
-<blockquote>
-<p>
- Coverity ID #94561 its technically possible to get into new_pdf_reset_color<br>
- with pis being NULL, if we don't have a high level colour imager state for a stroke.<br>
- In practice I don't believe its possible to have a pattern colour space for<br>
- a stroke without an image state for a high level colour, but its wise to<br>
- check before dereferencing.<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 15: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=c82b4be5033763c0a5fb4b46e5f5628b6703e7f3">c82b4be5033763c0a5fb4b46e5f5628b6703e7f3</a>
-<blockquote>
-<p>
- Coverity ID #94544, should have been assigning to y, not x<br>
-<br>
-gs/devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 11:25: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=75c8ee6f7e8e3d87033a5d1055d66237ed28b387">75c8ee6f7e8e3d87033a5d1055d66237ed28b387</a>
-<blockquote>
-<p>
- Coverity: don't ignore error return.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 11:18: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=3adab1a6e20eebc004e032c50f017b176e5b3aeb">3adab1a6e20eebc004e032c50f017b176e5b3aeb</a>
-<blockquote>
-<p>
- Coverity: move assignment to before the return<br>
-<br>
- Resetting a pointer to NULL was after the function returned.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 11:10:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d366dc9568f3bd2da06b57c7b0776b299200861a">d366dc9568f3bd2da06b57c7b0776b299200861a</a>
-<blockquote>
-<p>
- Coverity: add initializer and check some return codes.<br>
-<br>
- In truth, these were benign - we couldn't get to the ps_get_glyphname_or_cid()<br>
- call if the dictionary lookups would fail, and the possibly &quot;uninitialized<br>
- variable&quot; also couldn't happen, as one of the routes through the code that sets<br>
- it would have to be traversed with a valid font, and if the font were not valid<br>
- we'd never get to that function....<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 11:02: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=24f0b7d55b89b30d64623e03269027020628a432">24f0b7d55b89b30d64623e03269027020628a432</a>
-<blockquote>
-<p>
- Coverity: change parameter from explicit array to ptr.<br>
-<br>
- gs_type42_default_get_metrics() takes either a 4 element or 8 element float<br>
- array depending on metrics requested, but the parameter was explicitly declared<br>
- as a four element array.<br>
-<br>
- No cluster diffs.<br>
-<br>
-gs/base/gstype42.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 14:30:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e7db1c8bc26d57740b6ce4e6bcb2a154de2952a">1e7db1c8bc26d57740b6ce4e6bcb2a154de2952a</a>
-<blockquote>
-<p>
- Add a pointer cast to silence a Cppcheck warning (can't be a new warning<br>
- but it just popped up).<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 14:29: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=c458209c7de440ce65b1ae48f982635d2f1cf2ac">c458209c7de440ce65b1ae48f982635d2f1cf2ac</a>
-<blockquote>
-<p>
- Coverity ID #94519, #94538 check the return value from gp_fseek_64.<br>
-<br>
- Coverity ID #94813, check return value from fread and return error if failed.<br>
-<br>
- Coverity ID #95042, add a missing check on return value of rewrite_object<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 10:18: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=d64555d5f1180ee84875c7031d5acc3596397c24">d64555d5f1180ee84875c7031d5acc3596397c24</a>
-<blockquote>
-<p>
- Bug 696037: resolve issue with named pipes on Windows<br>
-<br>
- The stat() call does not work for named pipes on Windows.<br>
-<br>
- Move around the order of tests in lib_file_open_search_with_no_combine() so<br>
- it works with names pipes.<br>
-<br>
- The way lib_file_open_search_with_no_combine() works is that we have a list of<br>
- paths to search, and list of paths from which we are allowed to open files.<br>
-<br>
- If a file does not exist in one path from our search list, we continue<br>
- searching.<br>
-<br>
- If, on the other hand, the file does exist, but is not in a path we are<br>
- permitted to use files from, we have to throw an invalidaccess error.<br>
-<br>
- Previously, we'd stat() the file, then consult our allowed paths, then open the<br>
- file - taking appropriate alternative action if any of those stages failed.<br>
-<br>
- Now, we consult the permitted paths first, and if that fails, only then do we<br>
- call stat() to decide whether to throw an error, or continue searching.<br>
-<br>
- This should work correctly with Windows named pipes, as the names are always of<br>
- the form &quot;\\\\.\\pipe\\...&quot; (local) or &quot;\\ServerName\pipe\...&quot; (remote) so in<br>
- both cases the leading character being &quot;\&quot; will identify it as an absolute path<br>
- and those are always allowed.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 10:36:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=106be79bed699548c6094a0ffa98d73be3e32ce8">106be79bed699548c6094a0ffa98d73be3e32ce8</a>
-<blockquote>
-<p>
- Split previous initialisation so that we don't end up assigning an integer<br>
- to a pointer (causing a new warning...)<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 08:06: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=c46817a77dc2fd72ea2d1c16e140fba607a8787c">c46817a77dc2fd72ea2d1c16e140fba607a8787c</a>
-<blockquote>
-<p>
- Check before dereferencing a pointer, silences Coverity warning.<br>
-<br>
-gs/devices/vector/gdevpdfv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 08:04:50 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=997591ab50521899870075d3f85f1c7aef1ea81b">997591ab50521899870075d3f85f1c7aef1ea81b</a>
-<blockquote>
-<p>
- Initialise 'Stack' memory to silence a Coverity warning. bounds check an<br>
- array access to ensure we don't read off the bottom end.<br>
-<br>
-gs/devices/vector/gdevpsf1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 08:03:47 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e5de820e5fca5cc836c4bf7099f86eb0ab5299ae">e5de820e5fca5cc836c4bf7099f86eb0ab5299ae</a>
-<blockquote>
-<p>
- Silence a Coverity warning by initialising some variables<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 08:03: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=74b3ed15d3c03f9486fa829ba9fd14d26c5eb582">74b3ed15d3c03f9486fa829ba9fd14d26c5eb582</a>
-<blockquote>
-<p>
- Check a return value to silence a Coverity warning<br>
- Should this actually ever fail we'd write an invalid PDF file anyway.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-19 08:02: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=223c7994f8caa0500dc345ff86170d55776fc222">223c7994f8caa0500dc345ff86170d55776fc222</a>
-<blockquote>
-<p>
- Spotted by Coverity, fix parentheses for checking file is writeable<br>
-<br>
-gs/base/ramfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-16 18:32:47 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b4c78e969e75d8a0a9490511af07bb41cc26431">9b4c78e969e75d8a0a9490511af07bb41cc26431</a>
-<blockquote>
-<p>
- Bug 695234: Fix valgrind warnings with fuzzed file.<br>
-<br>
- The file was reported as causing SEGVs, but I cannot reproduce this.<br>
- Possibly the SEGV was fixed by Chris' change for bug 694205.<br>
-<br>
-gs/base/gxfill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-15 17:30:39 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b83b92758672b1ea690d4b979afaf07cf251b11f">b83b92758672b1ea690d4b979afaf07cf251b11f</a>
-<blockquote>
-<p>
- Bug 695348: Proper fix for avoiding SEGV in interpolated scalar.<br>
-<br>
- Avoid using the interpolated scaler for images where the<br>
- calculations have overflowed.<br>
-<br>
-gs/base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-16 10:13:47 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=72ca9b670f70cfaad1a299f891d03a313143cc3c">72ca9b670f70cfaad1a299f891d03a313143cc3c</a>
-<blockquote>
-<p>
- PDF interpreter - further work to handle illegal operations in text blocks<br>
-<br>
- Bug #696017 &quot;Portions of page missing&quot;<br>
-<br>
- The specimen file contains numerous operations illegally inside text blocks,<br>
- previously we fixed this for nested text blocks and more recently for images<br>
- inside text blocks. However this file also has stroke operations inside text<br>
- blocks (also illegal).<br>
-<br>
- Here we handle this by redefining the path construction operators so that<br>
- they check for the existence of a SavedTextMatrix and use that instead of<br>
- the CTM if it is present. This has some consequences; we can't do this for<br>
- pattern PaintProcs or the pattern will be incorrectly defined, and the flag<br>
- we were previously using (presence of TextSavedMatrix in currentdict) can't<br>
- be used as that isn't present during the execution of a PaintProc. So we<br>
- have to look at the current definition of the marking operations (we choose<br>
- to just use /m for brevity) and take action based upon that. We always set<br>
- the 'normal' marking ops for a PaintProc, and if we are in a text block<br>
- we switch the ops back again after running the PaintProc.<br>
-<br>
- No differences (except the obvious expected one in Bug696017.pdf)<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-15 16:49:51 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4191a9eb66adffbf6ae77c4f89f6dbbffc847ed9">4191a9eb66adffbf6ae77c4f89f6dbbffc847ed9</a>
-<blockquote>
-<p>
- Revert &quot;Bug 695348: Avoid SEGV in interpolated scaler.&quot;<br>
-<br>
- This reverts commit 78b27bf3e1a70699296f41442e767b1d04492b1c.<br>
-<br>
- I forgot a ' &lt; 0' in one of the tests. This returns the tests to<br>
- sanity to let me check the impact of the proper fix correctly.<br>
-<br>
-gs/base/gxipixel.c<br>
-gs/base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-15 13:51:14 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=78b27bf3e1a70699296f41442e767b1d04492b1c">78b27bf3e1a70699296f41442e767b1d04492b1c</a>
-<blockquote>
-<p>
- Bug 695348: Avoid SEGV in interpolated scaler.<br>
-<br>
- Don't use interpolated scaler if calculations have overflowed.<br>
-<br>
-gs/base/gxipixel.c<br>
-gs/base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-12 19:54: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=1572afcd641ed003150eec439c7ca16145cd0888">1572afcd641ed003150eec439c7ca16145cd0888</a>
-<blockquote>
-<p>
- Bug 695954: Add gp_stat function.<br>
-<br>
- gp_stat just calls stat, except on windows, where it converts from<br>
- UTF8 to unicode and calls _wstat.<br>
-<br>
-gs/base/gp.h<br>
-gs/base/gp_macio.c<br>
-gs/base/gp_mswin.c<br>
-gs/base/gp_os2fs.c<br>
-gs/base/gp_unifs.c<br>
-gs/base/gp_vms.c<br>
-gs/base/gsiodev.c<br>
-gs/base/stat_.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-11 12:18: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=908a9083697c8d41057110f30adf7a6c6b6eb46b">908a9083697c8d41057110f30adf7a6c6b6eb46b</a>
-<blockquote>
-<p>
- pdfwrite - fix ToUnicode emission<br>
-<br>
- Bug #696021 &quot;commit 24c562(fix for #692119) causes G2U mapping is lost in CIDFont&quot;<br>
-<br>
- Despite the bug title, it was in fact commit<br>
- 1be6f4e4084443772b928510fb7ebce71572ea10 which broke the handling of the<br>
- code created by PSCRIPT5.DLL. The windows printing system emits a<br>
- GlyphNames2Unicode dictionary which you would expect to contain names and<br>
- Unicode values, but in fact contains character codes and Unicode values.<br>
-<br>
- Sometimes we have the Character code to CID mapping being an identity, and<br>
- sometimes we don't. So we need to check both of these, which we can conveniently<br>
- do by lying to the decode_glyph procedure and pretending we are not a CIDFont.<br>
- We don't generally want to do this though, so we only do it if the CID and<br>
- character code differ. I haven't found a case where a PDF input file has a<br>
- differing CID and character code *and* fails decode_glyph with a CID, but<br>
- I suspect this may be possible, in which case we'll get a garbage ToUnicode<br>
- CMap, but it won't be worse than it was before<br>
-<br>
- I think the code originally supplied by the user to fix this bug is dangerous<br>
- (may produce incorrect results with PDF input files) and so have not entirely<br>
- adopted it but created our own resolution.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdtc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-08 03:15:26 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2395efe0bb6ee1e054ace4866a3c8dc4afb56c60">2395efe0bb6ee1e054ace4866a3c8dc4afb56c60</a>
-<blockquote>
-<p>
- Use an enum for error codes common to all modules<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gserrors.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-09 12:36: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=4da046f4dff81fdb6d8b7fdf5d114187d4782617">4da046f4dff81fdb6d8b7fdf5d114187d4782617</a>
-<blockquote>
-<p>
- Bug 695810: improve/expand tests for memory alignment<br>
-<br>
- Add a cross platform test for minimum memory alignment in configure. Make it<br>
- apply for the whole of the build (not just LCMS). And allow it to be<br>
- overridden at the command line.<br>
-<br>
- No cluster diffs<br>
-<br>
-configure.ac<br>
-gs/Makefile.in<br>
-gs/base/genarch.c<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-10 09:29: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=dbfd36b313eb9866300d5f7daef1249831332acf">dbfd36b313eb9866300d5f7daef1249831332acf</a>
-<blockquote>
-<p>
- PDF interpreter - ignore broken SMask in ExtGState<br>
-<br>
- Bug #696027 &quot;Blank page instead of expected output&quot;<br>
-<br>
- The PDF file is invalid, it has an ExtGState with a SMask dictionary, the<br>
- SMask does not contain a /Group, which is required and the dictionary is<br>
- unusable without it.<br>
-<br>
- This commit wraps the execution of SMask in a stopped so that if it fails<br>
- we can raise a warning and continue with the ExtGState, effectively ignoring<br>
- the invalid SMask.<br>
-<br>
- This produces a small progression in tests_private/pdf/sumatra/broken_xobject_messing_up_clip_stack.pdf<br>
- that particular file is so damaged even Acrobat won't open it, but a<br>
- progression is nice anyway.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-09 09:56: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=7e05f9d78f63b2a84339f1f39505a786fed75599">7e05f9d78f63b2a84339f1f39505a786fed75599</a>
-<blockquote>
-<p>
- Remove 2 unused variables to silence compiler warnings.<br>
-<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-09 09:20:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cb48631e7254e0843a08f075777cbecb43947823">cb48631e7254e0843a08f075777cbecb43947823</a>
-<blockquote>
-<p>
- pdfwrite - write encrypted strings in Dests tree if protected PDF output<br>
-<br>
- Bug #695992<br>
-<br>
- We were forced to stop using names when creatng a Dests tree (instead of<br>
- an array), even though it seems legal, because Acrobat didn't like it.<br>
-<br>
- However, I forgot to take account of password protected PDF files, which<br>
- require us to encrypt strings. Encryption is applied in this commit if<br>
- it is required.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-04 16:30:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=640801c0fd5527c7f183549df4fd2da365e427d4">640801c0fd5527c7f183549df4fd2da365e427d4</a>
-<blockquote>
-<p>
- Consolidate almost all error codes into the graphics library<br>
-<br>
- Do away with the separate/duplicate error code definitions in the Postscript<br>
- interpreter and in the graphics library. Also, where possible, do the same<br>
- for PCL.<br>
-<br>
- The exception is the PXL code which has errors codes entirely of its own -<br>
- as unpleasant as that is, it would require rather more invasive changes to<br>
- have PXL use the common error codes. Possibly something to consider for a<br>
- future commit.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gserrors.h<br>
-gs/base/stream.h<br>
-gs/psi/apitest.c<br>
-gs/psi/dmmain.c<br>
-gs/psi/dpmain.c<br>
-gs/psi/dwmain.c<br>
-gs/psi/dwmainc.c<br>
-gs/psi/dxmain.c<br>
-gs/psi/dxmainc.c<br>
-gs/psi/estack.h<br>
-gs/psi/gs.c<br>
-gs/psi/gsdll.c<br>
-gs/psi/gserver.c<br>
-gs/psi/ialloc.c<br>
-gs/psi/iapi.c<br>
-gs/psi/iapi.h<br>
-gs/psi/ibnum.c<br>
-gs/psi/icontext.c<br>
-gs/psi/idict.c<br>
-gs/psi/idict.h<br>
-gs/psi/idparam.c<br>
-gs/psi/ierrors.h<br>
-gs/psi/igstate.h<br>
-gs/psi/iinit.c<br>
-gs/psi/imain.c<br>
-gs/psi/imain.h<br>
-gs/psi/imainarg.c<br>
-gs/psi/iname.c<br>
-gs/psi/inobtokn.c<br>
-gs/psi/int.mak<br>
-gs/psi/interp.c<br>
-gs/psi/iparam.c<br>
-gs/psi/iparam.h<br>
-gs/psi/iplugin.c<br>
-gs/psi/ireclaim.c<br>
-gs/psi/isave.c<br>
-gs/psi/iscan.c<br>
-gs/psi/iscanbin.c<br>
-gs/psi/iscanbin.h<br>
-gs/psi/iscannum.c<br>
-gs/psi/istack.c<br>
-gs/psi/istack.h<br>
-gs/psi/iutil.c<br>
-gs/psi/iutil.h<br>
-gs/psi/iutil2.c<br>
-gs/psi/ivmspace.h<br>
-gs/psi/opcheck.h<br>
-gs/psi/oper.h<br>
-gs/psi/ostack.h<br>
-gs/psi/zalg.c<br>
-gs/psi/zarith.c<br>
-gs/psi/zarray.c<br>
-gs/psi/zbfont.c<br>
-gs/psi/zbseq.c<br>
-gs/psi/zcfont.c<br>
-gs/psi/zchar.c<br>
-gs/psi/zchar1.c<br>
-gs/psi/zchar32.c<br>
-gs/psi/zchar42.c<br>
-gs/psi/zcharout.c<br>
-gs/psi/zcharx.c<br>
-gs/psi/zcid.c<br>
-gs/psi/zcidtest.c<br>
-gs/psi/zcie.c<br>
-gs/psi/zcolor.c<br>
-gs/psi/zcontext.c<br>
-gs/psi/zcontrol.c<br>
-gs/psi/zcrd.c<br>
-gs/psi/zdevice.c<br>
-gs/psi/zdevice2.c<br>
-gs/psi/zdict.c<br>
-gs/psi/zdouble.c<br>
-gs/psi/zdpnext.c<br>
-gs/psi/zdps.c<br>
-gs/psi/zdps1.c<br>
-gs/psi/zdscpars.c<br>
-gs/psi/zfaes.c<br>
-gs/psi/zfapi.c<br>
-gs/psi/zfarc4.c<br>
-gs/psi/zfcid.c<br>
-gs/psi/zfcid0.c<br>
-gs/psi/zfcid1.c<br>
-gs/psi/zfcmap.c<br>
-gs/psi/zfdctd.c<br>
-gs/psi/zfdcte.c<br>
-gs/psi/zfdecode.c<br>
-gs/psi/zfile.c<br>
-gs/psi/zfile1.c<br>
-gs/psi/zfileio.c<br>
-gs/psi/zfilter.c<br>
-gs/psi/zfilter2.c<br>
-gs/psi/zfilterx.c<br>
-gs/psi/zfimscale.c<br>
-gs/psi/zfjbig2.c<br>
-gs/psi/zfont.c<br>
-gs/psi/zfont0.c<br>
-gs/psi/zfont1.c<br>
-gs/psi/zfont2.c<br>
-gs/psi/zfont42.c<br>
-gs/psi/zfontenum.c<br>
-gs/psi/zform.c<br>
-gs/psi/zfproc.c<br>
-gs/psi/zfrsd.c<br>
-gs/psi/zfsample.c<br>
-gs/psi/zfunc.c<br>
-gs/psi/zfunc0.c<br>
-gs/psi/zfunc3.c<br>
-gs/psi/zfunc4.c<br>
-gs/psi/zgeneric.c<br>
-gs/psi/zgstate.c<br>
-gs/psi/zht.c<br>
-gs/psi/zht1.c<br>
-gs/psi/zht2.c<br>
-gs/psi/zicc.c<br>
-gs/psi/zimage.c<br>
-gs/psi/zimage3.c<br>
-gs/psi/ziodev.c<br>
-gs/psi/ziodev2.c<br>
-gs/psi/ziodevs.c<br>
-gs/psi/ziodevsc.c<br>
-gs/psi/zmath.c<br>
-gs/psi/zmatrix.c<br>
-gs/psi/zmedia2.c<br>
-gs/psi/zmisc.c<br>
-gs/psi/zmisc1.c<br>
-gs/psi/zmisc2.c<br>
-gs/psi/zpacked.c<br>
-gs/psi/zpaint.c<br>
-gs/psi/zpath1.c<br>
-gs/psi/zpcolor.c<br>
-gs/psi/zpdf_r6.c<br>
-gs/psi/zpdfops.c<br>
-gs/psi/zshade.c<br>
-gs/psi/zstack.c<br>
-gs/psi/zstring.c<br>
-gs/psi/ztoken.c<br>
-gs/psi/ztrans.c<br>
-gs/psi/ztrap.c<br>
-gs/psi/ztype.c<br>
-gs/psi/zupath.c<br>
-gs/psi/zusparam.c<br>
-gs/psi/zutf8.c<br>
-gs/psi/zvmem.c<br>
-gs/psi/zvmem2.c<br>
-gs/psi/zwinutf8.c<br>
-pcl/pgchar.c<br>
-pcl/pgconfig.c<br>
-pcl/pglabel.c<br>
-pcl/pglfill.c<br>
-pcl/pgmand.h<br>
-pcl/pgparse.c<br>
-pcl/pgvector.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-06 20:07:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6d05fcee5521bc410068b16925c36476f207eab">a6d05fcee5521bc410068b16925c36476f207eab</a>
-<blockquote>
-<p>
- pdfwrite - fix consecutive CIE colour usage<br>
-<br>
- Bug #695847 &quot; colors in CIE color model are not converted correctly to PDF&quot;<br>
-<br>
- CIE colours cannot be represented directly in a PDF file, they *must* be<br>
- converted into an ICCBased colour space. If the colour conversion strategy<br>
- was LeaveColorUnchanged then the first usage of a colour in a CIEBased<br>
- colour space was correctly convrted, and the colour components rescaled,<br>
- but if the job then used another, different, colour in the same colour<br>
- space then the components were written out unscaled.<br>
-<br>
- This commit forces colours in a CIEBased space to always be rescaled.<br>
-<br>
- This gives one small progression in the test suite (09-31.ps) and some<br>
- slight colour differences in a further 7 files.<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-05 23:59: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=3a54125ff9225876f56e812f45bfc38cb2861c4b">3a54125ff9225876f56e812f45bfc38cb2861c4b</a>
-<blockquote>
-<p>
- PDF Interpreter - fix a problem with DecodeParms<br>
-<br>
- Bug #696019 &quot;- Regression: reading PDF file produces error starting with ddaea8157085f4efb227e78326dd739d59493b97&quot;<br>
-<br>
- There was a problem whe we had an image dictionary with a /Filter, which was<br>
- not an array. We consumed the image and stream dictionaries which led to an<br>
- error.<br>
-<br>
- This commit correctly updates and preserves the dictionaries.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-05 12:09:55 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4752fbce72100255089a5251b741711eab038ea0">4752fbce72100255089a5251b741711eab038ea0</a>
-<blockquote>
-<p>
- Clarified comment re. default PCL HW margins in pcl/pcpage.c.<br>
-<br>
-pcl/pcpage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-04 11:17:34 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=70242e40c8b12024f517155176cd81bf62bb932e">70242e40c8b12024f517155176cd81bf62bb932e</a>
-<blockquote>
-<p>
- MSVC: Ensure that language switch still build on windows.<br>
-<br>
- We were a) not linking in the right msprinter device (XPSPrint<br>
- missing), and b) not linking in the lib that XPSPrint needed.<br>
-<br>
-gs/base/msvctail.mak<br>
-language_switch/pspcl6_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-04 11:14:56 -0700
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=07c977b5d7f586758143afa07bde29d9fe9eaede">07c977b5d7f586758143afa07bde29d9fe9eaede</a>
-<blockquote>
-<p>
- MSVC Makefile sanitisation: Pass PGMFILES etc in debug call<br>
-<br>
- In the recursive make call done for debug builds, we pass<br>
- BUILD_SYSTEM. If we're going to pass BUILD_SYSTEM, we must<br>
- pass PGMFILES and PGMFILESx86 too, as these will not get<br>
- set if BUILD_SYSTEM is already set.<br>
-<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-06-04 13:51: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=d3dd0d208955d1368270e1139178bc6776e0574e">d3dd0d208955d1368270e1139178bc6776e0574e</a>
-<blockquote>
-<p>
- Windows display builds: set app as being dpi aware.<br>
-<br>
- This avoids horrible screen scaling.<br>
-<br>
-gs/psi/dwmain.c<br>
-gs/psi/dwmainc.c<br>
-pl/dwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-28 09:40: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=32fc208587c2c8e6d2eca660ed0c84bdc6d799cd">32fc208587c2c8e6d2eca660ed0c84bdc6d799cd</a>
-<blockquote>
-<p>
- Bug #696009 &quot;File doc/current/Install.htm and Windows 95&quot;<br>
-<br>
- The last version of Ghostscript which actually installed (using our installer)<br>
- on Windows 95 was apparently 8.60, the documentation said 8.71.<br>
-<br>
-gs/doc/Install.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-28 09:38: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=be72694a3cac0aa72c0843334e7f1afdabbddc7a">be72694a3cac0aa72c0843334e7f1afdabbddc7a</a>
-<blockquote>
-<p>
- Digitally sign the 'ghostscript printer' file ghostpdf.inf<br>
-<br>
- Recent versions (8+) of Windows make it very difficult to install a device<br>
- whose driver is not signed. While the ghostpdf.inf file isn't really part<br>
- of Ghostscript we have had enquiries about producing s signed version. Now<br>
- that we have our own certificate, this is possible and is done here.<br>
-<br>
- This should now install without problems on WIndows 8 and with fewer warnings<br>
- from UAC on Vista and Windows 7.<br>
-<br>
-gs/lib/ghostpdf.README<br>
-gs/lib/ghostpdf.cat<br>
-gs/lib/ghostpdf.inf<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-26 16:44: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=46cbd27208a84296d7bda96bf24b83ec0c084b57">46cbd27208a84296d7bda96bf24b83ec0c084b57</a>
-<blockquote>
-<p>
- Bug 694549: make optimisation more robust.<br>
-<br>
- And optimisation to reduce load on the memory manager and garbage collector<br>
- could end up dumping PS refs in a chunk not marked as containing refs,<br>
- potentially resulting in refs being mis-handled during save/restore.<br>
-<br>
- No cluster differences, but should stop Bug688845.eps seg faulting/erroring out<br>
-<br>
-gs/psi/ialloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-25 10:45:47 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef0c86cbf991166924c84657eac90ca357457697">ef0c86cbf991166924c84657eac90ca357457697</a>
-<blockquote>
-<p>
- Disable fast threhsold halftoning because it doesn't match HT tiling.<br>
-<br>
- This was discovered while working on fixing a bug in the threshold<br>
- array generation (bug 695929). The 'off' offset causes gray shade<br>
- differences, and the t_level_adjust, delta and delta_sum logic is<br>
- broken for num_levels &gt; 256.<br>
-<br>
-gs/base/gxht_thresh.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-23 18:08:57 -0300
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d73a3420ad559a527fd0ee94ddb3a37620933a16">d73a3420ad559a527fd0ee94ddb3a37620933a16</a>
-<blockquote>
-<p>
- &quot;cups&quot;/&quot;pwgraster&quot; output devices: Added support for the color spaces<br>
- 18 (SGray), 19 (SRGB), and 20 (Adobe RGB).<br>
-<br>
- Note that this is not a full implementation in terms of color<br>
- management. The implementation is done by simply using the most<br>
- similar of the existing color spaces, simple grayscale (0) for SGray<br>
- and RGB (1) for SRGB and Adobe RGB.<br>
-<br>
- This prevents Ghostscript from crashing and produce an output as close<br>
- as possible to the desired when these new color spaces are requested.<br>
-<br>
- TODO: Proper color management for the SGray, SRGB, and Adobe RGB<br>
- output.<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-21 21:53: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=668406a56eb351bf07fe3b5ec1be7bfc89cf4d77">668406a56eb351bf07fe3b5ec1be7bfc89cf4d77</a>
-<blockquote>
-<p>
- Bug 696005: handle indirect objs in image parameters<br>
-<br>
- When we round and convert to integer the height parameter in an image (to handle<br>
- the parameter being a real rather than integer, it needs to account for the<br>
- value being an indirect object.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-21 12:48: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=30d3d658ddc70e070e915995e072eb2315942619">30d3d658ddc70e070e915995e072eb2315942619</a>
-<blockquote>
-<p>
- Make use of revised endian checks in LCMS2.<br>
-<br>
- No cluster differences<br>
-<br>
-configure.ac<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-21 12:40: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=17ee8f214fc2621c594efcdb898756b3b8ff649a">17ee8f214fc2621c594efcdb898756b3b8ff649a</a>
-<blockquote>
-<p>
- Bug 695544: Simplify/Improve endian decisions in lcms2.h<br>
-<br>
- Firstly, protect the endian decisions in lcms2.h so that settings given on the<br>
- compiler command line are not silently overridden. Thus being set explicitly<br>
- gets the highest priority.<br>
-<br>
- Secondly, use the endianness detected by the configure script, and remove the<br>
- complex and error prone stuff for PPC platforms from lcms2.h. Thus the endianess<br>
- from configure gets second highest priority.<br>
-<br>
- Thirdly, if neither of the above are set, fall back to some simple (and long<br>
- standing) platform/compiler specific tests. These should rarely, if ever, come<br>
- into play in a &quot;normal&quot; build for a &quot;normal&quot; Unix-like system.<br>
-<br>
- Submitted and committed upstream:<br>
- https://github.com/mm2/Little-CMS/commit/6e33faab<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/lcms2/include/lcms2.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-20 17:54:21 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e2a659fd03505668929eb0264a97e959fc722eb9">e2a659fd03505668929eb0264a97e959fc722eb9</a>
-<blockquote>
-<p>
- Fix comment regarding FAPI, UFST and Freetype<br>
-<br>
- No cluster differences<br>
-<br>
-gs/Makefile.in<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-19 15:42:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f831cdfd7909bb1bd1feabb12311ffed1afd7c03">f831cdfd7909bb1bd1feabb12311ffed1afd7c03</a>
-<blockquote>
-<p>
- Fix compiler warning unsigned/signed comparison<br>
-<br>
-gs/base/gp_unifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-19 15:38: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=d81f899051cb374faa1da265a41c3eec899a36a6">d81f899051cb374faa1da265a41c3eec899a36a6</a>
-<blockquote>
-<p>
- Update to libjpeg 9a<br>
-<br>
-gs/jpeg/Makefile.am<br>
-gs/jpeg/Makefile.in<br>
-gs/jpeg/README<br>
-gs/jpeg/aclocal.m4<br>
-gs/jpeg/ansi2knr.1<br>
-gs/jpeg/ansi2knr.c<br>
-gs/jpeg/ar-lib<br>
-gs/jpeg/change.log<br>
-gs/jpeg/cjpeg.1<br>
-gs/jpeg/cjpeg.c<br>
-gs/jpeg/compile<br>
-gs/jpeg/config.guess<br>
-gs/jpeg/config.sub<br>
-gs/jpeg/configure<br>
-gs/jpeg/configure.ac<br>
-gs/jpeg/depcomp<br>
-gs/jpeg/djpeg.1<br>
-gs/jpeg/djpeg.c<br>
-gs/jpeg/filelist.txt<br>
-gs/jpeg/install-sh<br>
-gs/jpeg/install.txt<br>
-gs/jpeg/jcapistd.c<br>
-gs/jpeg/jcarith.c<br>
-gs/jpeg/jccolor.c<br>
-gs/jpeg/jcdctmgr.c<br>
-gs/jpeg/jchuff.c<br>
-gs/jpeg/jcinit.c<br>
-gs/jpeg/jcmainct.c<br>
-gs/jpeg/jcmarker.c<br>
-gs/jpeg/jcmaster.c<br>
-gs/jpeg/jconfig.cfg<br>
-gs/jpeg/jconfig.txt<br>
-gs/jpeg/jconfig.vc<br>
-gs/jpeg/jcparam.c<br>
-gs/jpeg/jctrans.c<br>
-gs/jpeg/jdapimin.c<br>
-gs/jpeg/jdapistd.c<br>
-gs/jpeg/jdarith.c<br>
-gs/jpeg/jdatadst.c<br>
-gs/jpeg/jdcolor.c<br>
-gs/jpeg/jddctmgr.c<br>
-gs/jpeg/jdhuff.c<br>
-gs/jpeg/jdinput.c<br>
-gs/jpeg/jdmainct.c<br>
-gs/jpeg/jdmarker.c<br>
-gs/jpeg/jdmaster.c<br>
-gs/jpeg/jdmerge.c<br>
-gs/jpeg/jerror.c<br>
-gs/jpeg/jerror.h<br>
-gs/jpeg/jfdctint.c<br>
-gs/jpeg/jidctint.c<br>
-gs/jpeg/jmemmgr.c<br>
-gs/jpeg/jmorecfg.h<br>
-gs/jpeg/jpegint.h<br>
-gs/jpeg/jpeglib.h<br>
-gs/jpeg/jpegtran.1<br>
-gs/jpeg/jpegtran.c<br>
-gs/jpeg/jversion.h<br>
-gs/jpeg/libjpeg.map<br>
-gs/jpeg/libjpeg.txt<br>
-gs/jpeg/makefile.ansi<br>
-gs/jpeg/makefile.bcc<br>
-gs/jpeg/makefile.dj<br>
-gs/jpeg/makefile.manx<br>
-gs/jpeg/makefile.mc6<br>
-gs/jpeg/makefile.mms<br>
-gs/jpeg/makefile.sas<br>
-gs/jpeg/makefile.unix<br>
-gs/jpeg/makefile.vc<br>
-gs/jpeg/makefile.wat<br>
-gs/jpeg/missing<br>
-gs/jpeg/rdjpgcom.1<br>
-gs/jpeg/structure.txt<br>
-gs/jpeg/testimg.bmp<br>
-gs/jpeg/testimg.ppm<br>
-gs/jpeg/transupp.c<br>
-gs/jpeg/transupp.h<br>
-gs/jpeg/usage.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-19 11:03:04 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22c1f418a37ccbb31aaf2910cf7926ce85bf8df0">22c1f418a37ccbb31aaf2910cf7926ce85bf8df0</a>
-<blockquote>
-<p>
- Fix some compiler warnings. Thanks to Robin for spotting these.<br>
-<br>
- Note change to use _fstat64 to allow for large file sizes and to get<br>
- rid of warnings. Fixed use of QueryPerformance functions (Windows).<br>
- Fix a wrong cast in cmd_drawing_color_usage.<br>
-<br>
-gs/base/gp_mswin.c<br>
-gs/base/gp_win32.c<br>
-gs/base/gxclpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-19 12:27:36 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c10206487eb9aa4623395148fa4b393b95af8ce">2c10206487eb9aa4623395148fa4b393b95af8ce</a>
-<blockquote>
-<p>
- Add in some error checking during ICC profile creation.<br>
-<br>
- Thanks to Tim Waugh for catching one of these (bug 695474)<br>
-<br>
-gs/base/gsciemap.c<br>
-gs/base/gsicc_manage.c<br>
-xps/xpscolor.c<br>
-xps/xpsimage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-19 09:59:31 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0309d66cc63c8ebfed8b8aa301d8c819b469dd63">0309d66cc63c8ebfed8b8aa301d8c819b469dd63</a>
-<blockquote>
-<p>
- Do not embed ICC profiles in JPEG, TIFF or PNG when -dUseFastColor is specified<br>
-<br>
- A reasonable request in bug 695584<br>
-<br>
-gs/devices/gdevjpeg.c<br>
-gs/devices/gdevpng.c<br>
-gs/devices/gdevtifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-14 15:33: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=47b1c5726a717be052957b399ff0e2cd32fd7bca">47b1c5726a717be052957b399ff0e2cd32fd7bca</a>
-<blockquote>
-<p>
- pdfwrite - Fix a conversion of a /Separation bas space<br>
-<br>
- Bug #695953 &quot;bad pdf generation&quot;<br>
-<br>
- When converting a /Separation space's alternate, because the suer has<br>
- specified ColorConversionStrategy, if the conversion was to sRGB we would<br>
- write the incorrect space, as this case was missing from the switch.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-14 12:17:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab45751e7b38c7f9b28b090af52649f19355115d">ab45751e7b38c7f9b28b090af52649f19355115d</a>
-<blockquote>
-<p>
- pdfwrite - Use the Mitchell filter instead of 'bicubic' for better quality<br>
-<br>
- Bug #695597 &quot;Look at the output from the pdfwrite Bicubic image downsampler&quot;<br>
-<br>
- The Mitchell filter output is clearly of superior quality to the existing<br>
- bicubic filter. So use it instead.....<br>
-<br>
- Note; when we switch to bicubic because the downsampling factor is not an<br>
- integer, we still use bicubic.<br>
-<br>
- Update the documentation and change some of the defaults as well.<br>
-<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-gs/devices/vector/gdevpsdi.c<br>
-gs/doc/Ps2pdf.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-13 15:04: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=d9172b7dfeac889e4301cd98216fdc297bf9e7bc">d9172b7dfeac889e4301cd98216fdc297bf9e7bc</a>
-<blockquote>
-<p>
- Don't load the image compression chooser when we are going to force lossless compression<br>
-<br>
- Bug #695978 &quot;Unexpected downsampling&quot;<br>
-<br>
- As noted in the bug thread, this isn't to do with downsampling. However, in<br>
- the original email conversation I did note that there was a confusion in<br>
- two tests in the code which should have been the same.<br>
-<br>
- This commit resolves that confusion, if we are forcing lossless compression<br>
- we set the count of alternate streams to 1 initially. This will prevent us<br>
- from loading the image compression chooser and hence avoid the second test<br>
- which only takes place if we have alternate streams.<br>
-<br>
- Disabling the compression chooser is what gets the performance gain noted<br>
- in the bug thread. It so happens that by specifying the downsampling filter<br>
- the code took a different path, even though no downsampling was taking, and<br>
- this was causing the compression chooser to be dumped.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-12 17:30: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=04de5b2db8ed54f424b6ec9458d7e1b5a15c89b4">04de5b2db8ed54f424b6ec9458d7e1b5a15c89b4</a>
-<blockquote>
-<p>
- Update zlib to 1.2.8.<br>
-<br>
- Don't define _LARGEFILE64_SOURCE on MSVC build<br>
-<br>
- zlib 1.2.8 tries to include unistd.h if _LARGEFILE64_SOURCE is defined,<br>
- causing build failure on Windows.<br>
-<br>
-gs/base/stdpre.h<br>
-gs/zlib/CMakeLists.txt<br>
-gs/zlib/ChangeLog<br>
-gs/zlib/Makefile.in<br>
-gs/zlib/README<br>
-gs/zlib/adler32.c<br>
-gs/zlib/as400/bndsrc<br>
-gs/zlib/as400/compile.clp<br>
-gs/zlib/as400/readme.txt<br>
-gs/zlib/as400/zlib.inc<br>
-gs/zlib/compress.c<br>
-gs/zlib/configure<br>
-gs/zlib/contrib/README.contrib<br>
-gs/zlib/contrib/blast/blast.c<br>
-gs/zlib/contrib/blast/blast.h<br>
-gs/zlib/contrib/delphi/ZLib.pas<br>
-gs/zlib/contrib/dotzlib/DotZLib/UnitTests.cs<br>
-gs/zlib/contrib/infback9/infback9.c<br>
-gs/zlib/contrib/infback9/inftree9.c<br>
-gs/zlib/contrib/minizip/configure.ac<br>
-gs/zlib/contrib/minizip/crypt.h<br>
-gs/zlib/contrib/minizip/iowin32.c<br>
-gs/zlib/contrib/minizip/miniunzip.1<br>
-gs/zlib/contrib/minizip/minizip.1<br>
-gs/zlib/contrib/minizip/unzip.c<br>
-gs/zlib/contrib/minizip/unzip.h<br>
-gs/zlib/contrib/minizip/zip.c<br>
-gs/zlib/contrib/pascal/zlibpas.pas<br>
-gs/zlib/contrib/puff/puff.c<br>
-gs/zlib/contrib/puff/puff.h<br>
-gs/zlib/contrib/puff/pufftest.c<br>
-gs/zlib/contrib/testzlib/testzlib.c<br>
-gs/zlib/contrib/vstudio/readme.txt<br>
-gs/zlib/contrib/vstudio/vc10/miniunz.vcxproj.user<br>
-gs/zlib/contrib/vstudio/vc10/minizip.vcxproj.user<br>
-gs/zlib/contrib/vstudio/vc10/testzlib.vcxproj.user<br>
-gs/zlib/contrib/vstudio/vc10/testzlibdll.vcxproj.user<br>
-gs/zlib/contrib/vstudio/vc10/zlib.rc<br>
-gs/zlib/contrib/vstudio/vc10/zlibstat.vcxproj<br>
-gs/zlib/contrib/vstudio/vc10/zlibstat.vcxproj.user<br>
-gs/zlib/contrib/vstudio/vc10/zlibvc.def<br>
-gs/zlib/contrib/vstudio/vc10/zlibvc.vcxproj<br>
-gs/zlib/contrib/vstudio/vc10/zlibvc.vcxproj.user<br>
-gs/zlib/contrib/vstudio/vc11/miniunz.vcxproj<br>
-gs/zlib/contrib/vstudio/vc11/minizip.vcxproj<br>
-gs/zlib/contrib/vstudio/vc11/testzlib.vcxproj<br>
-gs/zlib/contrib/vstudio/vc11/testzlibdll.vcxproj<br>
-gs/zlib/contrib/vstudio/vc11/zlib.rc<br>
-gs/zlib/contrib/vstudio/vc11/zlibstat.vcxproj<br>
-gs/zlib/contrib/vstudio/vc11/zlibvc.def<br>
-gs/zlib/contrib/vstudio/vc11/zlibvc.sln<br>
-gs/zlib/contrib/vstudio/vc11/zlibvc.vcxproj<br>
-gs/zlib/contrib/vstudio/vc9/zlib.rc<br>
-gs/zlib/contrib/vstudio/vc9/zlibvc.def<br>
-gs/zlib/crc32.c<br>
-gs/zlib/deflate.c<br>
-gs/zlib/deflate.h<br>
-gs/zlib/examples/enough.c<br>
-gs/zlib/examples/gun.c<br>
-gs/zlib/examples/gzappend.c<br>
-gs/zlib/examples/gzjoin.c<br>
-gs/zlib/examples/gzlog.c<br>
-gs/zlib/examples/gzlog.h<br>
-gs/zlib/examples/zran.c<br>
-gs/zlib/gzguts.h<br>
-gs/zlib/gzlib.c<br>
-gs/zlib/gzread.c<br>
-gs/zlib/gzwrite.c<br>
-gs/zlib/infback.c<br>
-gs/zlib/inffast.c<br>
-gs/zlib/inflate.c<br>
-gs/zlib/inftrees.c<br>
-gs/zlib/qnx/package.qpg<br>
-gs/zlib/test/example.c<br>
-gs/zlib/test/minigzip.c<br>
-gs/zlib/treebuild.xml<br>
-gs/zlib/trees.c<br>
-gs/zlib/uncompr.c<br>
-gs/zlib/win32/Makefile.msc<br>
-gs/zlib/win32/README-WIN32.txt<br>
-gs/zlib/win32/zlib.def<br>
-gs/zlib/win32/zlib1.rc<br>
-gs/zlib/zconf.h<br>
-gs/zlib/zconf.h.cmakein<br>
-gs/zlib/zconf.h.in<br>
-gs/zlib/zlib.3<br>
-gs/zlib/zlib.3.pdf<br>
-gs/zlib/zlib.h<br>
-gs/zlib/zlib.map<br>
-gs/zlib/zutil.c<br>
-gs/zlib/zutil.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-12 18:02: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=26657b796bb6756bf5a907f1745efe1d325978e0">26657b796bb6756bf5a907f1745efe1d325978e0</a>
-<blockquote>
-<p>
- Rename md5.c/h to gsmd5.c/h to avoid clashes.<br>
-<br>
-gs/base/gp_unix_cache.c<br>
-gs/base/gsmd5.c<br>
-gs/base/gsmd5.h<br>
-gs/base/lib.mak<br>
-gs/base/md5.c<br>
-gs/base/md5.h<br>
-gs/base/md5main.c<br>
-gs/base/smd5.h<br>
-gs/base/stdpre.h<br>
-gs/base/unix-aux.mak<br>
-gs/doc/Develop.htm<br>
-gs/ghostscript.vcproj<br>
-gs/ghostscript_rt.vcxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-12 16:21: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=66e29868f02aaaed1f4f751d41c3b4c4e2bf4399">66e29868f02aaaed1f4f751d41c3b4c4e2bf4399</a>
-<blockquote>
-<p>
- Update to libpng 1.6.17<br>
-<br>
-gs/libpng/ANNOUNCE<br>
-gs/libpng/CHANGES<br>
-gs/libpng/CMakeLists.txt<br>
-gs/libpng/INSTALL<br>
-gs/libpng/LICENSE<br>
-gs/libpng/Makefile.am<br>
-gs/libpng/Makefile.in<br>
-gs/libpng/README<br>
-gs/libpng/TODO<br>
-gs/libpng/aclocal.m4<br>
-gs/libpng/arm/arm_init.c<br>
-gs/libpng/arm/filter_neon.S<br>
-gs/libpng/arm/filter_neon_intrinsics.c<br>
-gs/libpng/autogen.sh<br>
-gs/libpng/compile<br>
-gs/libpng/config.guess<br>
-gs/libpng/config.h.in<br>
-gs/libpng/config.sub<br>
-gs/libpng/configure<br>
-gs/libpng/configure.ac<br>
-gs/libpng/contrib/arm-neon/README<br>
-gs/libpng/contrib/arm-neon/android-ndk.c<br>
-gs/libpng/contrib/arm-neon/linux-auxv.c<br>
-gs/libpng/contrib/arm-neon/linux.c<br>
-gs/libpng/contrib/conftest/README<br>
-gs/libpng/contrib/conftest/read.dfa<br>
-gs/libpng/contrib/conftest/s_read.dfa<br>
-gs/libpng/contrib/conftest/s_write.dfa<br>
-gs/libpng/contrib/conftest/simple.dfa<br>
-gs/libpng/contrib/conftest/write.dfa<br>
-gs/libpng/contrib/examples/iccfrompng.c<br>
-gs/libpng/contrib/examples/pngpixel.c<br>
-gs/libpng/contrib/gregbook/Makefile.mingw32<br>
-gs/libpng/contrib/gregbook/Makefile.sgi<br>
-gs/libpng/contrib/gregbook/Makefile.unx<br>
-gs/libpng/contrib/gregbook/Makefile.w32<br>
-gs/libpng/contrib/gregbook/readpng.c<br>
-gs/libpng/contrib/gregbook/readpng2.c<br>
-gs/libpng/contrib/gregbook/readppm.c<br>
-gs/libpng/contrib/gregbook/rpng-x.c<br>
-gs/libpng/contrib/gregbook/rpng2-win.c<br>
-gs/libpng/contrib/gregbook/rpng2-x.c<br>
-gs/libpng/contrib/gregbook/writepng.c<br>
-gs/libpng/contrib/libtests/fakepng.c<br>
-gs/libpng/contrib/libtests/pngimage.c<br>
-gs/libpng/contrib/libtests/pngstest.c<br>
-gs/libpng/contrib/libtests/pngunknown.c<br>
-gs/libpng/contrib/libtests/pngvalid.c<br>
-gs/libpng/contrib/libtests/timepng.c<br>
-gs/libpng/contrib/pngminim/decoder/makefile<br>
-gs/libpng/contrib/pngminim/decoder/pngusr.h<br>
-gs/libpng/contrib/pngminim/encoder/makefile<br>
-gs/libpng/contrib/pngminim/encoder/pngusr.dfa<br>
-gs/libpng/contrib/pngminim/encoder/pngusr.h<br>
-gs/libpng/contrib/pngminim/preader/makefile<br>
-gs/libpng/contrib/pngminim/preader/pngusr.h<br>
-gs/libpng/contrib/pngminus/makefile.std<br>
-gs/libpng/contrib/pngminus/makefile.tc3<br>
-gs/libpng/contrib/pngminus/png2pnm.bat<br>
-gs/libpng/contrib/pngminus/png2pnm.c<br>
-gs/libpng/contrib/pngminus/png2pnm.sh<br>
-gs/libpng/contrib/pngminus/pngminus.bat<br>
-gs/libpng/contrib/pngminus/pngminus.sh<br>
-gs/libpng/contrib/pngminus/pnm2png.bat<br>
-gs/libpng/contrib/pngminus/pnm2png.c<br>
-gs/libpng/contrib/pngminus/pnm2png.sh<br>
-gs/libpng/contrib/tools/fixitxt.c<br>
-gs/libpng/contrib/tools/intgamma.sh<br>
-gs/libpng/contrib/tools/png-fix-itxt.c<br>
-gs/libpng/contrib/tools/pngfix.c<br>
-gs/libpng/contrib/visupng/PngFile.c<br>
-gs/libpng/depcomp<br>
-gs/libpng/example.c<br>
-gs/libpng/install-sh<br>
-gs/libpng/libpng-manual.txt<br>
-gs/libpng/libpng.3<br>
-gs/libpng/libpngpf.3<br>
-gs/libpng/ltmain.sh<br>
-gs/libpng/missing<br>
-gs/libpng/png.5<br>
-gs/libpng/png.c<br>
-gs/libpng/png.h<br>
-gs/libpng/pngconf.h<br>
-gs/libpng/pngdebug.h<br>
-gs/libpng/pngerror.c<br>
-gs/libpng/pngget.c<br>
-gs/libpng/pnginfo.h<br>
-gs/libpng/pngmem.c<br>
-gs/libpng/pngpread.c<br>
-gs/libpng/pngpriv.h<br>
-gs/libpng/pngread.c<br>
-gs/libpng/pngrio.c<br>
-gs/libpng/pngrtran.c<br>
-gs/libpng/pngrutil.c<br>
-gs/libpng/pngset.c<br>
-gs/libpng/pngstruct.h<br>
-gs/libpng/pngtest.c<br>
-gs/libpng/pngtrans.c<br>
-gs/libpng/pngusr.dfa<br>
-gs/libpng/pngwio.c<br>
-gs/libpng/pngwrite.c<br>
-gs/libpng/pngwtran.c<br>
-gs/libpng/pngwutil.c<br>
-gs/libpng/projects/vstudio/readme.txt<br>
-gs/libpng/projects/vstudio/zlib.props<br>
-gs/libpng/scripts/README.txt<br>
-gs/libpng/scripts/def.c<br>
-gs/libpng/scripts/def.dfn<br>
-gs/libpng/scripts/descrip.mms<br>
-gs/libpng/scripts/dfn.awk<br>
-gs/libpng/scripts/intprefix.c<br>
-gs/libpng/scripts/intprefix.dfn<br>
-gs/libpng/scripts/libpng-config-body.in<br>
-gs/libpng/scripts/libpng-config-head.in<br>
-gs/libpng/scripts/libpng.pc.in<br>
-gs/libpng/scripts/libtool.m4<br>
-gs/libpng/scripts/ltoptions.m4<br>
-gs/libpng/scripts/ltsugar.m4<br>
-gs/libpng/scripts/ltversion.m4<br>
-gs/libpng/scripts/lt~obsolete.m4<br>
-gs/libpng/scripts/makefile.32sunu<br>
-gs/libpng/scripts/makefile.64sunu<br>
-gs/libpng/scripts/makefile.aix<br>
-gs/libpng/scripts/makefile.amiga<br>
-gs/libpng/scripts/makefile.atari<br>
-gs/libpng/scripts/makefile.bc32<br>
-gs/libpng/scripts/makefile.beos<br>
-gs/libpng/scripts/makefile.bor<br>
-gs/libpng/scripts/makefile.cegcc<br>
-gs/libpng/scripts/makefile.darwin<br>
-gs/libpng/scripts/makefile.dec<br>
-gs/libpng/scripts/makefile.dj2<br>
-gs/libpng/scripts/makefile.elf<br>
-gs/libpng/scripts/makefile.freebsd<br>
-gs/libpng/scripts/makefile.gcc<br>
-gs/libpng/scripts/makefile.hp64<br>
-gs/libpng/scripts/makefile.hpgcc<br>
-gs/libpng/scripts/makefile.hpux<br>
-gs/libpng/scripts/makefile.ibmc<br>
-gs/libpng/scripts/makefile.intel<br>
-gs/libpng/scripts/makefile.knr<br>
-gs/libpng/scripts/makefile.linux<br>
-gs/libpng/scripts/makefile.mips<br>
-gs/libpng/scripts/makefile.msc<br>
-gs/libpng/scripts/makefile.msys<br>
-gs/libpng/scripts/makefile.ne12bsd<br>
-gs/libpng/scripts/makefile.netbsd<br>
-gs/libpng/scripts/makefile.openbsd<br>
-gs/libpng/scripts/makefile.sco<br>
-gs/libpng/scripts/makefile.sggcc<br>
-gs/libpng/scripts/makefile.sgi<br>
-gs/libpng/scripts/makefile.so9<br>
-gs/libpng/scripts/makefile.solaris<br>
-gs/libpng/scripts/makefile.solaris-x86<br>
-gs/libpng/scripts/makefile.std<br>
-gs/libpng/scripts/makefile.sunos<br>
-gs/libpng/scripts/makefile.tc3<br>
-gs/libpng/scripts/makefile.vcwin32<br>
-gs/libpng/scripts/makevms.com<br>
-gs/libpng/scripts/options.awk<br>
-gs/libpng/scripts/pnglibconf.dfa<br>
-gs/libpng/scripts/pnglibconf.h.prebuilt<br>
-gs/libpng/scripts/pnglibconf.mak<br>
-gs/libpng/scripts/prefix.c<br>
-gs/libpng/scripts/prefix.dfn<br>
-gs/libpng/scripts/sym.c<br>
-gs/libpng/scripts/sym.dfn<br>
-gs/libpng/scripts/symbols.c<br>
-gs/libpng/scripts/symbols.def<br>
-gs/libpng/scripts/symbols.dfn<br>
-gs/libpng/scripts/vers.c<br>
-gs/libpng/scripts/vers.dfn<br>
-gs/libpng/test-driver<br>
-gs/libpng/tests/pngimage-full<br>
-gs/libpng/tests/pngimage-quick<br>
-gs/libpng/tests/pngvalid-progressive-standard<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-12 16:26: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=7274a44e2fda741572c815ef17298b7e37c96e7a">7274a44e2fda741572c815ef17298b7e37c96e7a</a>
-<blockquote>
-<p>
- Add freetype's configure script to our repo.<br>
-<br>
- Missed from previous commit.<br>
-<br>
-gs/freetype/configure<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-07 15:48: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=9b6129c546bd924fb588219bc2d352ff44a79dd5">9b6129c546bd924fb588219bc2d352ff44a79dd5</a>
-<blockquote>
-<p>
- Update freetype to 2.5.5 and tweak our makefile for it<br>
-<br>
- Bug 695774: Fallback for glyph with degenerate bbox<br>
-<br>
- (Re-applying after update to Freetype 2.5.5)<br>
-<br>
- If a glyph has only one very narrow feature, the bbox can end up with either<br>
- the width or height of the bbox being 0, in which case no raster memory is<br>
- allocated and no attempt is made to render the glyph. This is less than ideal<br>
- when the drop-out compensation in the rendering code would actually result in<br>
- the glyph being rendered.<br>
-<br>
- Normally the coordinates for the bbox are rounded (which is technically<br>
- correct). Now, if that results in the width or height being 0, we'll<br>
- then try explicitly rounding up/down, providing a sort of naive whole glyph<br>
- drop-out compensation.<br>
-<br>
- The same change has been included upstream and will be in the next scheduled<br>
- Freetype release:<br>
- http://git.savannah.gnu.org/cgit/freetype/freetype2.git/commit/?id=942aa5ff<br>
-<br>
- This causes a large number of low resolution differences on cluster, all<br>
- progressions where glyphs like dash ('-'), underscore ('_') and vertical<br>
- bar ('|') were dropping out entirely, and are now printing.<br>
-<br>
- Revert to old Freetype CFF code<br>
-<br>
- (for now, at least)<br>
-<br>
- The new CFF code causes issues:<br>
-<br>
- Altona_Technical_1v1_x3.pdf - missing u-umlaut<br>
- Bug687311.pdf - missing glyph<br>
- Bug689516.pdf - extra ' glyph<br>
- Bug690559.pdf - missing umlaut glyphs<br>
- Bug691045.pdf- missing accent glyphs<br>
- type2accent.pdf - missing accent glyphs<br>
- z400454b01d4-1.pdf - content missing<br>
-<br>
- Fix and reenable new FT CFF code.<br>
-<br>
- 1) The incremental interface to Freetype requires the callback method to apply<br>
- character code mapping via std encoding, rather it being applied internally<br>
- in Freetype.<br>
- submitted and applied upstream:<br>
- http://git.savannah.gnu.org/cgit/freetype/freetype2.git/commit/?id=d65bf72<br>
-<br>
- 2) The VVCURVETO, HHCURVETO, VHCURVETO and HVCURVETO in the old CFF engine were<br>
- tolerant of extra parameters on the stack, apply a similar thing in the<br>
- new CFF code.<br>
- submitted and applied upstream:<br>
- http://git.savannah.gnu.org/cgit/freetype/freetype2.git/commit/?id=a87fb8cc<br>
-<br>
-gs/base/freetype.mak<br>
-gs/freetype/CMakeLists.txt<br>
-gs/freetype/ChangeLog<br>
-gs/freetype/ChangeLog.21<br>
-gs/freetype/ChangeLog.23<br>
-gs/freetype/ChangeLog.24<br>
-gs/freetype/Jamfile<br>
-gs/freetype/README<br>
-gs/freetype/README.git<br>
-gs/freetype/autogen.sh<br>
-gs/freetype/builds/amiga/README<br>
-gs/freetype/builds/amiga/include/config/ftconfig.h<br>
-gs/freetype/builds/amiga/include/config/ftmodule.h<br>
-gs/freetype/builds/amiga/include/freetype/config/ftconfig.h<br>
-gs/freetype/builds/amiga/include/freetype/config/ftmodule.h<br>
-gs/freetype/builds/amiga/makefile<br>
-gs/freetype/builds/amiga/makefile.os4<br>
-gs/freetype/builds/amiga/smakefile<br>
-gs/freetype/builds/amiga/src/base/ftdebug.c<br>
-gs/freetype/builds/amiga/src/base/ftsystem.c<br>
-gs/freetype/builds/atari/deflinejoiner.awk<br>
-gs/freetype/builds/cmake/iOS.cmake<br>
-gs/freetype/builds/compiler/bcc-dev.mk<br>
-gs/freetype/builds/detect.mk<br>
-gs/freetype/builds/dos/detect.mk<br>
-gs/freetype/builds/exports.mk<br>
-gs/freetype/builds/freetype.mk<br>
-gs/freetype/builds/mac/README<br>
-gs/freetype/builds/mac/freetype-Info.plist<br>
-gs/freetype/builds/mac/ftmac.c<br>
-gs/freetype/builds/modules.mk<br>
-gs/freetype/builds/symbian/bld.inf<br>
-gs/freetype/builds/toplevel.mk<br>
-gs/freetype/builds/unix/aclocal.m4<br>
-gs/freetype/builds/unix/config.guess<br>
-gs/freetype/builds/unix/config.sub<br>
-gs/freetype/builds/unix/configure<br>
-gs/freetype/builds/unix/configure.ac<br>
-gs/freetype/builds/unix/configure.raw<br>
-gs/freetype/builds/unix/detect.mk<br>
-gs/freetype/builds/unix/freetype-config.in<br>
-gs/freetype/builds/unix/freetype2.in<br>
-gs/freetype/builds/unix/freetype2.m4<br>
-gs/freetype/builds/unix/ft2unix.h<br>
-gs/freetype/builds/unix/ftconfig.in<br>
-gs/freetype/builds/unix/ftsystem.c<br>
-gs/freetype/builds/unix/install-sh<br>
-gs/freetype/builds/unix/install.mk<br>
-gs/freetype/builds/unix/ltmain.sh<br>
-gs/freetype/builds/unix/pkg.m4<br>
-gs/freetype/builds/unix/unix-def.in<br>
-gs/freetype/builds/vms/ftconfig.h<br>
-gs/freetype/builds/vms/ftsystem.c<br>
-gs/freetype/builds/win32/detect.mk<br>
-gs/freetype/builds/win32/ftdebug.c<br>
-gs/freetype/builds/win32/vc2005/freetype.sln<br>
-gs/freetype/builds/win32/vc2005/freetype.vcproj<br>
-gs/freetype/builds/win32/vc2005/index.html<br>
-gs/freetype/builds/win32/vc2008/freetype.sln<br>
-gs/freetype/builds/win32/vc2008/freetype.vcproj<br>
-gs/freetype/builds/win32/vc2008/index.html<br>
-gs/freetype/builds/win32/vc2010/freetype.sln<br>
-gs/freetype/builds/win32/vc2010/freetype.vcxproj<br>
-gs/freetype/builds/win32/vc2010/freetype.vcxproj.filters<br>
-gs/freetype/builds/win32/vc2010/index.html<br>
-gs/freetype/builds/win32/visualc/freetype.dsp<br>
-gs/freetype/builds/win32/visualc/freetype.dsw<br>
-gs/freetype/builds/win32/visualc/freetype.sln<br>
-gs/freetype/builds/win32/visualc/freetype.vcproj<br>
-gs/freetype/builds/win32/visualc/index.html<br>
-gs/freetype/builds/win32/visualce/freetype.dsp<br>
-gs/freetype/builds/win32/visualce/freetype.dsw<br>
-gs/freetype/builds/win32/visualce/freetype.vcproj<br>
-gs/freetype/builds/win32/visualce/index.html<br>
-gs/freetype/builds/win32/w32-bcc.mk<br>
-gs/freetype/builds/win32/w32-bccd.mk<br>
-gs/freetype/builds/win32/w32-dev.mk<br>
-gs/freetype/builds/win32/w32-gcc.mk<br>
-gs/freetype/builds/win32/w32-icc.mk<br>
-gs/freetype/builds/win32/w32-intl.mk<br>
-gs/freetype/builds/win32/w32-lcc.mk<br>
-gs/freetype/builds/win32/w32-mingw32.mk<br>
-gs/freetype/builds/win32/w32-vcc.mk<br>
-gs/freetype/builds/win32/w32-wat.mk<br>
-gs/freetype/builds/win32/win32-def.mk<br>
-gs/freetype/builds/wince/ftdebug.c<br>
-gs/freetype/builds/wince/vc2005-ce/freetype.vcproj<br>
-gs/freetype/builds/wince/vc2005-ce/index.html<br>
-gs/freetype/builds/wince/vc2008-ce/freetype.vcproj<br>
-gs/freetype/builds/wince/vc2008-ce/index.html<br>
-gs/freetype/builds/windows/detect.mk<br>
-gs/freetype/builds/windows/ftdebug.c<br>
-gs/freetype/builds/windows/vc2005/freetype.sln<br>
-gs/freetype/builds/windows/vc2005/freetype.vcproj<br>
-gs/freetype/builds/windows/vc2005/index.html<br>
-gs/freetype/builds/windows/vc2008/freetype.sln<br>
-gs/freetype/builds/windows/vc2008/freetype.vcproj<br>
-gs/freetype/builds/windows/vc2008/index.html<br>
-gs/freetype/builds/windows/vc2010/freetype.sln<br>
-gs/freetype/builds/windows/vc2010/freetype.user.props<br>
-gs/freetype/builds/windows/vc2010/freetype.vcxproj<br>
-gs/freetype/builds/windows/vc2010/freetype.vcxproj.filters<br>
-gs/freetype/builds/windows/vc2010/index.html<br>
-gs/freetype/builds/windows/visualc/freetype.dsp<br>
-gs/freetype/builds/windows/visualc/freetype.dsw<br>
-gs/freetype/builds/windows/visualc/freetype.sln<br>
-gs/freetype/builds/windows/visualc/freetype.vcproj<br>
-gs/freetype/builds/windows/visualc/index.html<br>
-gs/freetype/builds/windows/visualce/freetype.dsp<br>
-gs/freetype/builds/windows/visualce/freetype.dsw<br>
-gs/freetype/builds/windows/visualce/freetype.vcproj<br>
-gs/freetype/builds/windows/visualce/index.html<br>
-gs/freetype/builds/windows/w32-bcc.mk<br>
-gs/freetype/builds/windows/w32-bccd.mk<br>
-gs/freetype/builds/windows/w32-dev.mk<br>
-gs/freetype/builds/windows/w32-gcc.mk<br>
-gs/freetype/builds/windows/w32-icc.mk<br>
-gs/freetype/builds/windows/w32-intl.mk<br>
-gs/freetype/builds/windows/w32-lcc.mk<br>
-gs/freetype/builds/windows/w32-mingw32.mk<br>
-gs/freetype/builds/windows/w32-vcc.mk<br>
-gs/freetype/builds/windows/w32-wat.mk<br>
-gs/freetype/builds/windows/win32-def.mk<br>
-gs/freetype/configure<br>
-gs/freetype/devel/ft2build.h<br>
-gs/freetype/devel/ftoption.h<br>
-gs/freetype/docs/CHANGES<br>
-gs/freetype/docs/CMAKE<br>
-gs/freetype/docs/CUSTOMIZE<br>
-gs/freetype/docs/DEBUG<br>
-gs/freetype/docs/INSTALL<br>
-gs/freetype/docs/INSTALL.ANY<br>
-gs/freetype/docs/INSTALL.CROSS<br>
-gs/freetype/docs/INSTALL.GNU<br>
-gs/freetype/docs/INSTALL.UNIX<br>
-gs/freetype/docs/LICENSE.TXT<br>
-gs/freetype/docs/VERSION.DLL<br>
-gs/freetype/docs/formats.txt<br>
-gs/freetype/docs/freetype-config.1<br>
-gs/freetype/docs/reference/ft2-auto_hinter.html<br>
-gs/freetype/docs/reference/ft2-base_interface.html<br>
-gs/freetype/docs/reference/ft2-basic_types.html<br>
-gs/freetype/docs/reference/ft2-bdf_fonts.html<br>
-gs/freetype/docs/reference/ft2-bitmap_handling.html<br>
-gs/freetype/docs/reference/ft2-bzip2.html<br>
-gs/freetype/docs/reference/ft2-cache_subsystem.html<br>
-gs/freetype/docs/reference/ft2-cff_driver.html<br>
-gs/freetype/docs/reference/ft2-cid_fonts.html<br>
-gs/freetype/docs/reference/ft2-computations.html<br>
-gs/freetype/docs/reference/ft2-font_formats.html<br>
-gs/freetype/docs/reference/ft2-gasp_table.html<br>
-gs/freetype/docs/reference/ft2-glyph_management.html<br>
-gs/freetype/docs/reference/ft2-glyph_stroker.html<br>
-gs/freetype/docs/reference/ft2-glyph_variants.html<br>
-gs/freetype/docs/reference/ft2-gx_validation.html<br>
-gs/freetype/docs/reference/ft2-gzip.html<br>
-gs/freetype/docs/reference/ft2-header_file_macros.html<br>
-gs/freetype/docs/reference/ft2-header_inclusion.html<br>
-gs/freetype/docs/reference/ft2-incremental.html<br>
-gs/freetype/docs/reference/ft2-index.html<br>
-gs/freetype/docs/reference/ft2-lcd_filtering.html<br>
-gs/freetype/docs/reference/ft2-list_processing.html<br>
-gs/freetype/docs/reference/ft2-lzw.html<br>
-gs/freetype/docs/reference/ft2-mac_specific.html<br>
-gs/freetype/docs/reference/ft2-module_management.html<br>
-gs/freetype/docs/reference/ft2-multiple_masters.html<br>
-gs/freetype/docs/reference/ft2-ot_validation.html<br>
-gs/freetype/docs/reference/ft2-outline_processing.html<br>
-gs/freetype/docs/reference/ft2-pfr_fonts.html<br>
-gs/freetype/docs/reference/ft2-quick_advance.html<br>
-gs/freetype/docs/reference/ft2-raster.html<br>
-gs/freetype/docs/reference/ft2-sfnt_names.html<br>
-gs/freetype/docs/reference/ft2-sizes_management.html<br>
-gs/freetype/docs/reference/ft2-system_interface.html<br>
-gs/freetype/docs/reference/ft2-toc.html<br>
-gs/freetype/docs/reference/ft2-truetype_engine.html<br>
-gs/freetype/docs/reference/ft2-truetype_tables.html<br>
-gs/freetype/docs/reference/ft2-tt_driver.html<br>
-gs/freetype/docs/reference/ft2-type1_tables.html<br>
-gs/freetype/docs/reference/ft2-user_allocation.html<br>
-gs/freetype/docs/reference/ft2-version.html<br>
-gs/freetype/docs/reference/ft2-winfnt_fonts.html<br>
-gs/freetype/docs/release<br>
-gs/freetype/include/config/ftconfig.h<br>
-gs/freetype/include/config/ftheader.h<br>
-gs/freetype/include/config/ftmodule.h<br>
-gs/freetype/include/config/ftoption.h<br>
-gs/freetype/include/config/ftstdlib.h<br>
-gs/freetype/include/freetype.h<br>
-gs/freetype/include/freetype/config/ftconfig.h<br>
-gs/freetype/include/freetype/config/ftheader.h<br>
-gs/freetype/include/freetype/config/ftmodule.h<br>
-gs/freetype/include/freetype/config/ftoption.h<br>
-gs/freetype/include/freetype/config/ftstdlib.h<br>
-gs/freetype/include/freetype/freetype.h<br>
-gs/freetype/include/freetype/ftadvanc.h<br>
-gs/freetype/include/freetype/ftbbox.h<br>
-gs/freetype/include/freetype/ftbdf.h<br>
-gs/freetype/include/freetype/ftbitmap.h<br>
-gs/freetype/include/freetype/ftbzip2.h<br>
-gs/freetype/include/freetype/ftcache.h<br>
-gs/freetype/include/freetype/ftchapters.h<br>
-gs/freetype/include/freetype/ftcid.h<br>
-gs/freetype/include/freetype/fterrdef.h<br>
-gs/freetype/include/freetype/fterrors.h<br>
-gs/freetype/include/freetype/ftgasp.h<br>
-gs/freetype/include/freetype/ftglyph.h<br>
-gs/freetype/include/freetype/ftgxval.h<br>
-gs/freetype/include/freetype/ftgzip.h<br>
-gs/freetype/include/freetype/ftimage.h<br>
-gs/freetype/include/freetype/ftincrem.h<br>
-gs/freetype/include/freetype/ftlcdfil.h<br>
-gs/freetype/include/freetype/ftlist.h<br>
-gs/freetype/include/freetype/ftlzw.h<br>
-gs/freetype/include/freetype/ftmac.h<br>
-gs/freetype/include/freetype/ftmm.h<br>
-gs/freetype/include/freetype/ftmodapi.h<br>
-gs/freetype/include/freetype/ftmoderr.h<br>
-gs/freetype/include/freetype/ftotval.h<br>
-gs/freetype/include/freetype/ftoutln.h<br>
-gs/freetype/include/freetype/ftpfr.h<br>
-gs/freetype/include/freetype/ftrender.h<br>
-gs/freetype/include/freetype/ftsizes.h<br>
-gs/freetype/include/freetype/ftsnames.h<br>
-gs/freetype/include/freetype/ftstroke.h<br>
-gs/freetype/include/freetype/ftsynth.h<br>
-gs/freetype/include/freetype/ftsystem.h<br>
-gs/freetype/include/freetype/fttrigon.h<br>
-gs/freetype/include/freetype/fttypes.h<br>
-gs/freetype/include/freetype/ftwinfnt.h<br>
-gs/freetype/include/freetype/ftxf86.h<br>
-gs/freetype/include/freetype/internal/autohint.h<br>
-gs/freetype/include/freetype/internal/ftcalc.h<br>
-gs/freetype/include/freetype/internal/ftdebug.h<br>
-gs/freetype/include/freetype/internal/ftdriver.h<br>
-gs/freetype/include/freetype/internal/ftgloadr.h<br>
-gs/freetype/include/freetype/internal/ftmemory.h<br>
-gs/freetype/include/freetype/internal/ftobjs.h<br>
-gs/freetype/include/freetype/internal/ftpic.h<br>
-gs/freetype/include/freetype/internal/ftrfork.h<br>
-gs/freetype/include/freetype/internal/ftserv.h<br>
-gs/freetype/include/freetype/internal/ftstream.h<br>
-gs/freetype/include/freetype/internal/fttrace.h<br>
-gs/freetype/include/freetype/internal/ftvalid.h<br>
-gs/freetype/include/freetype/internal/internal.h<br>
-gs/freetype/include/freetype/internal/psaux.h<br>
-gs/freetype/include/freetype/internal/pshints.h<br>
-gs/freetype/include/freetype/internal/services/svbdf.h<br>
-gs/freetype/include/freetype/internal/services/svcid.h<br>
-gs/freetype/include/freetype/internal/services/svgldict.h<br>
-gs/freetype/include/freetype/internal/services/svgxval.h<br>
-gs/freetype/include/freetype/internal/services/svkern.h<br>
-gs/freetype/include/freetype/internal/services/svmm.h<br>
-gs/freetype/include/freetype/internal/services/svotval.h<br>
-gs/freetype/include/freetype/internal/services/svpfr.h<br>
-gs/freetype/include/freetype/internal/services/svpostnm.h<br>
-gs/freetype/include/freetype/internal/services/svpscmap.h<br>
-gs/freetype/include/freetype/internal/services/svpsinfo.h<br>
-gs/freetype/include/freetype/internal/services/svsfnt.h<br>
-gs/freetype/include/freetype/internal/services/svttcmap.h<br>
-gs/freetype/include/freetype/internal/services/svtteng.h<br>
-gs/freetype/include/freetype/internal/services/svttglyf.h<br>
-gs/freetype/include/freetype/internal/services/svwinfnt.h<br>
-gs/freetype/include/freetype/internal/services/svxf86nm.h<br>
-gs/freetype/include/freetype/internal/sfnt.h<br>
-gs/freetype/include/freetype/internal/t1types.h<br>
-gs/freetype/include/freetype/internal/tttypes.h<br>
-gs/freetype/include/freetype/t1tables.h<br>
-gs/freetype/include/freetype/ttnameid.h<br>
-gs/freetype/include/freetype/tttables.h<br>
-gs/freetype/include/freetype/tttags.h<br>
-gs/freetype/include/freetype/ttunpat.h<br>
-gs/freetype/include/ft2build.h<br>
-gs/freetype/include/ftadvanc.h<br>
-gs/freetype/include/ftautoh.h<br>
-gs/freetype/include/ftbbox.h<br>
-gs/freetype/include/ftbdf.h<br>
-gs/freetype/include/ftbitmap.h<br>
-gs/freetype/include/ftbzip2.h<br>
-gs/freetype/include/ftcache.h<br>
-gs/freetype/include/ftcffdrv.h<br>
-gs/freetype/include/ftchapters.h<br>
-gs/freetype/include/ftcid.h<br>
-gs/freetype/include/fterrdef.h<br>
-gs/freetype/include/fterrors.h<br>
-gs/freetype/include/ftgasp.h<br>
-gs/freetype/include/ftglyph.h<br>
-gs/freetype/include/ftgxval.h<br>
-gs/freetype/include/ftgzip.h<br>
-gs/freetype/include/ftimage.h<br>
-gs/freetype/include/ftincrem.h<br>
-gs/freetype/include/ftlcdfil.h<br>
-gs/freetype/include/ftlist.h<br>
-gs/freetype/include/ftlzw.h<br>
-gs/freetype/include/ftmac.h<br>
-gs/freetype/include/ftmm.h<br>
-gs/freetype/include/ftmodapi.h<br>
-gs/freetype/include/ftmoderr.h<br>
-gs/freetype/include/ftotval.h<br>
-gs/freetype/include/ftoutln.h<br>
-gs/freetype/include/ftpfr.h<br>
-gs/freetype/include/ftrender.h<br>
-gs/freetype/include/ftsizes.h<br>
-gs/freetype/include/ftsnames.h<br>
-gs/freetype/include/ftstroke.h<br>
-gs/freetype/include/ftsynth.h<br>
-gs/freetype/include/ftsystem.h<br>
-gs/freetype/include/fttrigon.h<br>
-gs/freetype/include/ftttdrv.h<br>
-gs/freetype/include/fttypes.h<br>
-gs/freetype/include/ftwinfnt.h<br>
-gs/freetype/include/ftxf86.h<br>
-gs/freetype/include/internal/autohint.h<br>
-gs/freetype/include/internal/ftcalc.h<br>
-gs/freetype/include/internal/ftdebug.h<br>
-gs/freetype/include/internal/ftdriver.h<br>
-gs/freetype/include/internal/ftgloadr.h<br>
-gs/freetype/include/internal/ftmemory.h<br>
-gs/freetype/include/internal/ftobjs.h<br>
-gs/freetype/include/internal/ftpic.h<br>
-gs/freetype/include/internal/ftrfork.h<br>
-gs/freetype/include/internal/ftserv.h<br>
-gs/freetype/include/internal/ftstream.h<br>
-gs/freetype/include/internal/fttrace.h<br>
-gs/freetype/include/internal/ftvalid.h<br>
-gs/freetype/include/internal/internal.h<br>
-gs/freetype/include/internal/psaux.h<br>
-gs/freetype/include/internal/pshints.h<br>
-gs/freetype/include/internal/services/svbdf.h<br>
-gs/freetype/include/internal/services/svcid.h<br>
-gs/freetype/include/internal/services/svgldict.h<br>
-gs/freetype/include/internal/services/svgxval.h<br>
-gs/freetype/include/internal/services/svkern.h<br>
-gs/freetype/include/internal/services/svmm.h<br>
-gs/freetype/include/internal/services/svotval.h<br>
-gs/freetype/include/internal/services/svpfr.h<br>
-gs/freetype/include/internal/services/svpostnm.h<br>
-gs/freetype/include/internal/services/svprop.h<br>
-gs/freetype/include/internal/services/svpscmap.h<br>
-gs/freetype/include/internal/services/svpsinfo.h<br>
-gs/freetype/include/internal/services/svsfnt.h<br>
-gs/freetype/include/internal/services/svttcmap.h<br>
-gs/freetype/include/internal/services/svtteng.h<br>
-gs/freetype/include/internal/services/svttglyf.h<br>
-gs/freetype/include/internal/services/svwinfnt.h<br>
-gs/freetype/include/internal/services/svxf86nm.h<br>
-gs/freetype/include/internal/sfnt.h<br>
-gs/freetype/include/internal/t1types.h<br>
-gs/freetype/include/internal/tttypes.h<br>
-gs/freetype/include/t1tables.h<br>
-gs/freetype/include/ttnameid.h<br>
-gs/freetype/include/tttables.h<br>
-gs/freetype/include/tttags.h<br>
-gs/freetype/include/ttunpat.h<br>
-gs/freetype/modules.cfg<br>
-gs/freetype/src/Jamfile<br>
-gs/freetype/src/autofit/afangles.c<br>
-gs/freetype/src/autofit/afblue.c<br>
-gs/freetype/src/autofit/afblue.cin<br>
-gs/freetype/src/autofit/afblue.dat<br>
-gs/freetype/src/autofit/afblue.h<br>
-gs/freetype/src/autofit/afblue.hin<br>
-gs/freetype/src/autofit/afcjk.c<br>
-gs/freetype/src/autofit/afcjk.h<br>
-gs/freetype/src/autofit/afcover.h<br>
-gs/freetype/src/autofit/afdummy.c<br>
-gs/freetype/src/autofit/afdummy.h<br>
-gs/freetype/src/autofit/afglobal.c<br>
-gs/freetype/src/autofit/afglobal.h<br>
-gs/freetype/src/autofit/afhints.c<br>
-gs/freetype/src/autofit/afhints.h<br>
-gs/freetype/src/autofit/afindic.c<br>
-gs/freetype/src/autofit/afindic.h<br>
-gs/freetype/src/autofit/aflatin.c<br>
-gs/freetype/src/autofit/aflatin.h<br>
-gs/freetype/src/autofit/aflatin2.c<br>
-gs/freetype/src/autofit/aflatin2.h<br>
-gs/freetype/src/autofit/afloader.c<br>
-gs/freetype/src/autofit/afloader.h<br>
-gs/freetype/src/autofit/afmodule.c<br>
-gs/freetype/src/autofit/afmodule.h<br>
-gs/freetype/src/autofit/afpic.c<br>
-gs/freetype/src/autofit/afpic.h<br>
-gs/freetype/src/autofit/afranges.c<br>
-gs/freetype/src/autofit/afranges.h<br>
-gs/freetype/src/autofit/afscript.h<br>
-gs/freetype/src/autofit/afstyles.h<br>
-gs/freetype/src/autofit/aftypes.h<br>
-gs/freetype/src/autofit/afwrtsys.h<br>
-gs/freetype/src/autofit/autofit.c<br>
-gs/freetype/src/autofit/hbshim.c<br>
-gs/freetype/src/autofit/hbshim.h<br>
-gs/freetype/src/autofit/rules.mk<br>
-gs/freetype/src/base/basepic.c<br>
-gs/freetype/src/base/basepic.h<br>
-gs/freetype/src/base/ftadvanc.c<br>
-gs/freetype/src/base/ftbbox.c<br>
-gs/freetype/src/base/ftbdf.c<br>
-gs/freetype/src/base/ftbitmap.c<br>
-gs/freetype/src/base/ftcalc.c<br>
-gs/freetype/src/base/ftcid.c<br>
-gs/freetype/src/base/ftdbgmem.c<br>
-gs/freetype/src/base/ftdebug.c<br>
-gs/freetype/src/base/ftfstype.c<br>
-gs/freetype/src/base/ftgloadr.c<br>
-gs/freetype/src/base/ftglyph.c<br>
-gs/freetype/src/base/ftgxval.c<br>
-gs/freetype/src/base/ftinit.c<br>
-gs/freetype/src/base/ftlcdfil.c<br>
-gs/freetype/src/base/ftmac.c<br>
-gs/freetype/src/base/ftmm.c<br>
-gs/freetype/src/base/ftobjs.c<br>
-gs/freetype/src/base/ftotval.c<br>
-gs/freetype/src/base/ftoutln.c<br>
-gs/freetype/src/base/ftpfr.c<br>
-gs/freetype/src/base/ftpic.c<br>
-gs/freetype/src/base/ftrfork.c<br>
-gs/freetype/src/base/ftsnames.c<br>
-gs/freetype/src/base/ftstream.c<br>
-gs/freetype/src/base/ftstroke.c<br>
-gs/freetype/src/base/ftsynth.c<br>
-gs/freetype/src/base/ftsystem.c<br>
-gs/freetype/src/base/fttrigon.c<br>
-gs/freetype/src/base/fttype1.c<br>
-gs/freetype/src/base/ftutil.c<br>
-gs/freetype/src/base/ftwinfnt.c<br>
-gs/freetype/src/base/md5.c<br>
-gs/freetype/src/base/md5.h<br>
-gs/freetype/src/base/rules.mk<br>
-gs/freetype/src/bdf/bdfdrivr.c<br>
-gs/freetype/src/bdf/bdflib.c<br>
-gs/freetype/src/bzip2/ftbzip2.c<br>
-gs/freetype/src/cache/Jamfile<br>
-gs/freetype/src/cache/ftcbasic.c<br>
-gs/freetype/src/cache/ftccache.c<br>
-gs/freetype/src/cache/ftccache.h<br>
-gs/freetype/src/cache/ftccback.h<br>
-gs/freetype/src/cache/ftccmap.c<br>
-gs/freetype/src/cache/ftcmanag.c<br>
-gs/freetype/src/cache/ftcmanag.h<br>
-gs/freetype/src/cache/ftcmru.h<br>
-gs/freetype/src/cache/ftcsbits.c<br>
-gs/freetype/src/cff/cf2arrst.c<br>
-gs/freetype/src/cff/cf2arrst.h<br>
-gs/freetype/src/cff/cf2blues.c<br>
-gs/freetype/src/cff/cf2blues.h<br>
-gs/freetype/src/cff/cf2error.c<br>
-gs/freetype/src/cff/cf2error.h<br>
-gs/freetype/src/cff/cf2fixed.h<br>
-gs/freetype/src/cff/cf2font.c<br>
-gs/freetype/src/cff/cf2font.h<br>
-gs/freetype/src/cff/cf2ft.c<br>
-gs/freetype/src/cff/cf2ft.h<br>
-gs/freetype/src/cff/cf2glue.h<br>
-gs/freetype/src/cff/cf2hints.c<br>
-gs/freetype/src/cff/cf2hints.h<br>
-gs/freetype/src/cff/cf2intrp.c<br>
-gs/freetype/src/cff/cf2intrp.h<br>
-gs/freetype/src/cff/cf2read.c<br>
-gs/freetype/src/cff/cf2read.h<br>
-gs/freetype/src/cff/cf2stack.c<br>
-gs/freetype/src/cff/cf2stack.h<br>
-gs/freetype/src/cff/cf2types.h<br>
-gs/freetype/src/cff/cff.c<br>
-gs/freetype/src/cff/cffcmap.c<br>
-gs/freetype/src/cff/cffdrivr.c<br>
-gs/freetype/src/cff/cffgload.c<br>
-gs/freetype/src/cff/cffgload.h<br>
-gs/freetype/src/cff/cffload.c<br>
-gs/freetype/src/cff/cffobjs.c<br>
-gs/freetype/src/cff/cffobjs.h<br>
-gs/freetype/src/cff/cffparse.c<br>
-gs/freetype/src/cff/cffpic.c<br>
-gs/freetype/src/cff/cffpic.h<br>
-gs/freetype/src/cff/cfftypes.h<br>
-gs/freetype/src/cff/rules.mk<br>
-gs/freetype/src/cid/cidgload.c<br>
-gs/freetype/src/cid/cidload.c<br>
-gs/freetype/src/cid/cidobjs.c<br>
-gs/freetype/src/cid/cidparse.c<br>
-gs/freetype/src/cid/cidparse.h<br>
-gs/freetype/src/cid/cidriver.c<br>
-gs/freetype/src/gxvalid/gxvbsln.c<br>
-gs/freetype/src/gxvalid/gxvcommn.c<br>
-gs/freetype/src/gxvalid/gxvcommn.h<br>
-gs/freetype/src/gxvalid/gxverror.h<br>
-gs/freetype/src/gxvalid/gxvfeat.c<br>
-gs/freetype/src/gxvalid/gxvjust.c<br>
-gs/freetype/src/gxvalid/gxvkern.c<br>
-gs/freetype/src/gxvalid/gxvlcar.c<br>
-gs/freetype/src/gxvalid/gxvmod.c<br>
-gs/freetype/src/gxvalid/gxvmort.c<br>
-gs/freetype/src/gxvalid/gxvmort.h<br>
-gs/freetype/src/gxvalid/gxvmort0.c<br>
-gs/freetype/src/gxvalid/gxvmort1.c<br>
-gs/freetype/src/gxvalid/gxvmort2.c<br>
-gs/freetype/src/gxvalid/gxvmort4.c<br>
-gs/freetype/src/gxvalid/gxvmort5.c<br>
-gs/freetype/src/gxvalid/gxvmorx.c<br>
-gs/freetype/src/gxvalid/gxvmorx.h<br>
-gs/freetype/src/gxvalid/gxvmorx0.c<br>
-gs/freetype/src/gxvalid/gxvmorx1.c<br>
-gs/freetype/src/gxvalid/gxvmorx2.c<br>
-gs/freetype/src/gxvalid/gxvmorx4.c<br>
-gs/freetype/src/gxvalid/gxvmorx5.c<br>
-gs/freetype/src/gxvalid/gxvopbd.c<br>
-gs/freetype/src/gxvalid/gxvprop.c<br>
-gs/freetype/src/gxvalid/gxvtrak.c<br>
-gs/freetype/src/gzip/adler32.c<br>
-gs/freetype/src/gzip/ftgzip.c<br>
-gs/freetype/src/gzip/inftrees.c<br>
-gs/freetype/src/gzip/rules.mk<br>
-gs/freetype/src/gzip/zconf.h<br>
-gs/freetype/src/gzip/zutil.c<br>
-gs/freetype/src/gzip/zutil.h<br>
-gs/freetype/src/lzw/ftlzw.c<br>
-gs/freetype/src/lzw/ftzopen.h<br>
-gs/freetype/src/otvalid/otvbase.c<br>
-gs/freetype/src/otvalid/otvcommn.c<br>
-gs/freetype/src/otvalid/otvcommn.h<br>
-gs/freetype/src/otvalid/otverror.h<br>
-gs/freetype/src/otvalid/otvgdef.c<br>
-gs/freetype/src/otvalid/otvgpos.c<br>
-gs/freetype/src/otvalid/otvgsub.c<br>
-gs/freetype/src/otvalid/otvjstf.c<br>
-gs/freetype/src/otvalid/otvmath.c<br>
-gs/freetype/src/otvalid/otvmod.c<br>
-gs/freetype/src/pcf/README<br>
-gs/freetype/src/pcf/pcfdrivr.c<br>
-gs/freetype/src/pcf/pcfread.c<br>
-gs/freetype/src/pcf/pcfutil.c<br>
-gs/freetype/src/pfr/pfrcmap.c<br>
-gs/freetype/src/pfr/pfrdrivr.c<br>
-gs/freetype/src/pfr/pfrgload.c<br>
-gs/freetype/src/pfr/pfrload.c<br>
-gs/freetype/src/pfr/pfrobjs.c<br>
-gs/freetype/src/pfr/pfrsbit.c<br>
-gs/freetype/src/psaux/afmparse.c<br>
-gs/freetype/src/psaux/psconv.c<br>
-gs/freetype/src/psaux/psconv.h<br>
-gs/freetype/src/psaux/psobjs.c<br>
-gs/freetype/src/psaux/t1cmap.c<br>
-gs/freetype/src/psaux/t1decode.c<br>
-gs/freetype/src/pshinter/pshalgo.c<br>
-gs/freetype/src/pshinter/pshalgo.h<br>
-gs/freetype/src/pshinter/pshglob.c<br>
-gs/freetype/src/pshinter/pshglob.h<br>
-gs/freetype/src/pshinter/pshmod.c<br>
-gs/freetype/src/pshinter/pshpic.c<br>
-gs/freetype/src/pshinter/pshpic.h<br>
-gs/freetype/src/pshinter/pshrec.c<br>
-gs/freetype/src/pshinter/pshrec.h<br>
-gs/freetype/src/psnames/psmodule.c<br>
-gs/freetype/src/psnames/pspic.c<br>
-gs/freetype/src/psnames/pspic.h<br>
-gs/freetype/src/psnames/rules.mk<br>
-gs/freetype/src/raster/ftmisc.h<br>
-gs/freetype/src/raster/ftraster.c<br>
-gs/freetype/src/raster/ftrend1.c<br>
-gs/freetype/src/raster/rastpic.c<br>
-gs/freetype/src/raster/rastpic.h<br>
-gs/freetype/src/sfnt/pngshim.c<br>
-gs/freetype/src/sfnt/pngshim.h<br>
-gs/freetype/src/sfnt/rules.mk<br>
-gs/freetype/src/sfnt/sfdriver.c<br>
-gs/freetype/src/sfnt/sferrors.h<br>
-gs/freetype/src/sfnt/sfnt.c<br>
-gs/freetype/src/sfnt/sfntpic.c<br>
-gs/freetype/src/sfnt/sfntpic.h<br>
-gs/freetype/src/sfnt/sfobjs.c<br>
-gs/freetype/src/sfnt/ttbdf.c<br>
-gs/freetype/src/sfnt/ttcmap.c<br>
-gs/freetype/src/sfnt/ttcmap.h<br>
-gs/freetype/src/sfnt/ttcmapc.h<br>
-gs/freetype/src/sfnt/ttkern.c<br>
-gs/freetype/src/sfnt/ttload.c<br>
-gs/freetype/src/sfnt/ttmtx.c<br>
-gs/freetype/src/sfnt/ttmtx.h<br>
-gs/freetype/src/sfnt/ttpost.c<br>
-gs/freetype/src/sfnt/ttsbit.c<br>
-gs/freetype/src/sfnt/ttsbit.h<br>
-gs/freetype/src/sfnt/ttsbit0.c<br>
-gs/freetype/src/smooth/ftgrays.c<br>
-gs/freetype/src/smooth/ftsmooth.c<br>
-gs/freetype/src/smooth/ftspic.c<br>
-gs/freetype/src/smooth/ftspic.h<br>
-gs/freetype/src/tools/afblue.pl<br>
-gs/freetype/src/tools/apinames.c<br>
-gs/freetype/src/tools/chktrcmp.py<br>
-gs/freetype/src/tools/cordic.py<br>
-gs/freetype/src/tools/docmaker/content.py<br>
-gs/freetype/src/tools/docmaker/docmaker.py<br>
-gs/freetype/src/tools/docmaker/formatter.py<br>
-gs/freetype/src/tools/docmaker/sources.py<br>
-gs/freetype/src/tools/docmaker/tohtml.py<br>
-gs/freetype/src/tools/docmaker/utils.py<br>
-gs/freetype/src/tools/ftrandom/README<br>
-gs/freetype/src/tools/ftrandom/ftrandom.c<br>
-gs/freetype/src/tools/test_afm.c<br>
-gs/freetype/src/tools/test_bbox.c<br>
-gs/freetype/src/tools/test_trig.c<br>
-gs/freetype/src/truetype/rules.mk<br>
-gs/freetype/src/truetype/truetype.c<br>
-gs/freetype/src/truetype/ttdriver.c<br>
-gs/freetype/src/truetype/ttgload.c<br>
-gs/freetype/src/truetype/ttgload.h<br>
-gs/freetype/src/truetype/ttgxvar.c<br>
-gs/freetype/src/truetype/ttinterp.c<br>
-gs/freetype/src/truetype/ttinterp.h<br>
-gs/freetype/src/truetype/ttobjs.c<br>
-gs/freetype/src/truetype/ttobjs.h<br>
-gs/freetype/src/truetype/ttpic.c<br>
-gs/freetype/src/truetype/ttpic.h<br>
-gs/freetype/src/truetype/ttpload.c<br>
-gs/freetype/src/truetype/ttsubpix.c<br>
-gs/freetype/src/truetype/ttsubpix.h<br>
-gs/freetype/src/type1/t1afm.c<br>
-gs/freetype/src/type1/t1driver.c<br>
-gs/freetype/src/type1/t1gload.c<br>
-gs/freetype/src/type1/t1load.c<br>
-gs/freetype/src/type1/t1objs.c<br>
-gs/freetype/src/type1/t1parse.c<br>
-gs/freetype/src/type42/t42drivr.c<br>
-gs/freetype/src/type42/t42objs.c<br>
-gs/freetype/src/type42/t42parse.c<br>
-gs/freetype/src/winfonts/winfnt.c<br>
-gs/freetype/vms_make.com<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-05 12:33:16 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=28876fa00c5a325a6b3ad2e768375f203d060aaf">28876fa00c5a325a6b3ad2e768375f203d060aaf</a>
-<blockquote>
-<p>
- Improve efficiency of pdf_info.ps<br>
-<br>
- Original, pdf_info.ps would loop to retrieve each page of a PDF, emit its<br>
- media information. Then, in a second loop, it would retrieve each page, and<br>
- emit its font information.<br>
-<br>
- This change means it will loop only once, retrieving each page only once, and<br>
- using the same page dictionary object for both media information and fonts used.<br>
-<br>
- This *should* improve the speed on very large PDF files.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/toolbin/pdf_info.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-11 09:57:01 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8117f3e31575a08451d0e8a1b9c251ffbef047a8">8117f3e31575a08451d0e8a1b9c251ffbef047a8</a>
-<blockquote>
-<p>
- Non-Isolated transparency groups should ignore CS entry<br>
-<br>
- If a transparency group is not isolated the blending color<br>
- space for the group is inherited from the parent group.<br>
-<br>
- This is a partial fix for the issues seen in Bug 695930.<br>
- In particular the issues seen with the letter D.<br>
-<br>
-gs/base/gstrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-30 15:06:06 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0f3691890027236e3c7b34317426b913f62288dc">0f3691890027236e3c7b34317426b913f62288dc</a>
-<blockquote>
-<p>
- Bug 695972: always use a square scaling for glyphs<br>
-<br>
- We're seeing Truetype fonts whose hinting programs do not work correctly with<br>
- certain, non-square scalings. So ensure that the scale we pass to Freetype<br>
- is equal in in width and height, then apply the non-square part in the final,<br>
- output matrix (along with non-square resolution scaling, and shearing etc).<br>
-<br>
- This causes quite a lot of cluster differences, due to rounding changes.<br>
-<br>
-gs/base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-05-02 19:49:34 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b34e6835e6e918dfca8c6558fe00eedcca6660c5">b34e6835e6e918dfca8c6558fe00eedcca6660c5</a>
-<blockquote>
-<p>
- Fix error in gsapi; gsapi_run_string is broken.<br>
-<br>
- gsapi_run_string calls through to gsapi_run_string_with_length<br>
- with the first argument converted from a gs_lib_ctx_t * to a void *.<br>
- gsapi_run_string_with_length then performs this conversion again.<br>
- This will lead to a SEGV.<br>
-<br>
- The fix is not to do this dereference.<br>
-<br>
- Wouldn't it be better if we used types here rather than void *'s?<br>
-<br>
-gs/psi/iapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-27 10:11:22 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=505601bd6ee848be2aff84d264ae9583ae96c64a">505601bd6ee848be2aff84d264ae9583ae96c64a</a>
-<blockquote>
-<p>
- Fix Bug #695951 Portion of page cut off.<br>
-<br>
- Implement the PJL command EDGETOEDGE, not only does this enable full<br>
- bleed but it also shifts the logical page to the left allowing printing<br>
- of graphics that would have been clipped because they extended past the<br>
- physical page edge.<br>
-<br>
-pcl/pcpage.c<br>
-pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-15 14:33:18 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b742626e8ec7d976535395316f7986097982b73b">b742626e8ec7d976535395316f7986097982b73b</a>
-<blockquote>
-<p>
- Use the Windows &quot;QueryPerformanceCounter&quot; high res timer for usertime.<br>
-<br>
- The gp_get_realtime is OK, but for gp_get_usertime from C it is handy<br>
- to have better resolution. Also use this for the -Z: output from the<br>
- print_resource_usage function. NB the functions were always defined<br>
- as returning seconds and nanoseconds.<br>
-<br>
-gs/base/gp_win32.c<br>
-gs/psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-22 16:44:37 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=53cb4209b397c9e8121aeec31607cbfb53622f20">53cb4209b397c9e8121aeec31607cbfb53622f20</a>
-<blockquote>
-<p>
- Fix for file BFAZSLPD.pdf JPX image uses Lab colorspace.<br>
-<br>
- The jp2_csp_dict definitiion for the basic Lab colorspace for a JPX<br>
- encoded image was (1) not an array with a dict as the second element<br>
- as required by the PDF parser, and (2) the dict must have a WhitePoint<br>
- array (required per the PDF spec).<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-17 14:24:35 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d56cdfd63c26a29d118f570d1b37d32214834c78">d56cdfd63c26a29d118f570d1b37d32214834c78</a>
-<blockquote>
-<p>
- Remove -Werror=return-type for builds with UFST<br>
-<br>
- Some UFST versions will fail to build with -Werror=return-type, so when<br>
- building with UFST, strip that option from the compiler flags.<br>
-<br>
- No cluster differences.<br>
-<br>
-configure.ac<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-21 12:18: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=3b174bb21edd57fb53914d3fea3c202f9e41d4a3">3b174bb21edd57fb53914d3fea3c202f9e41d4a3</a>
-<blockquote>
-<p>
- Remove a now superfluous assignment to NULL.<br>
-<br>
- The previous commit changed pdf14_free_mask_stack() so it would set the<br>
- pdf14 context &quot;mask_stack&quot; pointer to NULL after freeing the memory, so<br>
- there's now no requirement for the calling code to do so.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-21 12:00: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=e895599e66cc174b2d7a2740e747f05589836546">e895599e66cc174b2d7a2740e747f05589836546</a>
-<blockquote>
-<p>
- Bug 695952: avoid double free of mask_stack.<br>
-<br>
- The pdf14 context &quot;mask_stack&quot; could end up being freed twice, once by<br>
- pdf14_free_mask_stack() and then again explicitly.<br>
-<br>
- This commit removes the erroneous free, but I also opted to change<br>
- pdf14_free_mask_stack() so it takes the pdf14 context pointer (rather than<br>
- just the &quot;mask_stack&quot; pointer) which means it can set the pointer to NULL as<br>
- well as freeing it, which is safer for the error handling case.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-21 10:33: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=30fde04cca068e34cc64f3656d7eefc50a8316d7">30fde04cca068e34cc64f3656d7eefc50a8316d7</a>
-<blockquote>
-<p>
- PDF Interpreter - validate and clamp arguments to Td<br>
-<br>
- Bug #695950 &quot;Incomplete rendering of PDF file&quot;<br>
-<br>
- As usual an invalid PDF file. In this case the PDF file contains an argument<br>
- to Td which is 1.5090553259294607 x 10^258. Typical implementation limits<br>
- in Appendix C of the PDF Reference limit reals to 3.403x10^38<br>
-<br>
- GS returns the value as -infinity, it appears Acrobat clamps these out of range<br>
- values to 0 (at least for the Td operator)<br>
-<br>
- This commit checks the arguments against 2^32 as checking against the full<br>
- range permitted for reals would be slightly more difficult, and its unlikely<br>
- that a real file would use arguments larger than this anyway. If any argument<br>
- is out of range it gets clamped to 0.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-18 17:52: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=e2f65f3e0087442caf6d657f238e50ce87403988">e2f65f3e0087442caf6d657f238e50ce87403988</a>
-<blockquote>
-<p>
- Bug 695934: Fix a typo in Type 1 font bounds checking.<br>
-<br>
- When I added some stack bounds checking to the Type 1 charstring code, I<br>
- mistakenly used a value for subrs in the gsubrs section, this could lead to<br>
- stack corruption and a subsequent segfault.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gxtype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-17 12:19:26 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b3fc1892747bba78cc2dcc8181803bf5dc4b6a5d">b3fc1892747bba78cc2dcc8181803bf5dc4b6a5d</a>
-<blockquote>
-<p>
- Bug 695890: Update jbig2dec for modern libpng<br>
-<br>
- libpng 1.5.x and newer hide the internals, and only allow values to be set and<br>
- retrieved via define API calls.<br>
-<br>
- Also tidy up a couple of (benign) compiler warnings.<br>
-<br>
- No cluster diffs.<br>
-<br>
-gs/jbig2dec/jbig2_arith.c<br>
-gs/jbig2dec/jbig2_image_pbm.c<br>
-gs/jbig2dec/jbig2_image_png.c<br>
-gs/jbig2dec/jbig2_refinement.c<br>
-gs/jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-16 15:28:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5d87a9ba906ad303abdd487a719cc966e857c198">5d87a9ba906ad303abdd487a719cc966e857c198</a>
-<blockquote>
-<p>
- Tweak FAPI code for server search.<br>
-<br>
- If we have multiple FAPI &quot;servers&quot; (i.e. font renderers) we cycle through them<br>
- testing if they can handle a particular font. To indicate it cannot, a server<br>
- will return an invalidaccess error, which we were erroneously returning to the<br>
- interpreter.<br>
-<br>
- Now keep searching on an invalidaccess.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-16 15:26: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=6d1bde2bad1afeb610735f7ea53cabd7d3120fbe">6d1bde2bad1afeb610735f7ea53cabd7d3120fbe</a>
-<blockquote>
-<p>
- PDF interpreter - additional debugging option<br>
-<br>
- Added a 'stdoutprint' to go along with stderrprint, this allows us to<br>
- have the 'pdfformaterror' and other informative messages sent to stdout<br>
- instead of stderr.<br>
-<br>
- When capturing stdout and stderr for debugging purposes it can be useful to<br>
- have the logging/debug messages go to the same place as the error messages<br>
- in order that they are captured properly 'interleaved'.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-15 17:19: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=4dce3f3cb2ece5795312a85c5ac2693ff8293169">4dce3f3cb2ece5795312a85c5ac2693ff8293169</a>
-<blockquote>
-<p>
- pdfwrite - Pay attention to /MediaBox pdfmarks<br>
-<br>
- Previously we always emitted a /MediaBox for each page based only on the<br>
- PostScript media size, even if we had a /MediaBox /Page pdfmark.<br>
-<br>
- This in itself is incorrect, but worse we would then emit the MediaBox from<br>
- the /Page pdfmark as well, leading to a dictionary with duplicate keys....<br>
-<br>
- This commit will use any /MediaBox /Page pdfmark in preference to any PostScript<br>
- media settings, though it will default to those if no such pdfmark is sent.<br>
-<br>
- This exhibits a difference in Bug692502.eps because this file (uniquely in<br>
- our test suite it seems) does emit a /MediaBox /Page pdfmark, which is<br>
- different to the media we use in PostScript. Previously it was incorrect,<br>
- now it is correct, or at least we honour the pdfmark now.....<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-10 11:47:13 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e8142ce7390e2686456894a602df07d8de16a7c7">e8142ce7390e2686456894a602df07d8de16a7c7</a>
-<blockquote>
-<p>
- Fix for bug 695916. Simulated overprint blending of spots colors issue<br>
-<br>
- For non separation devices, we had attempted to simulate the overprint effect of spot colors<br>
- that are not CMYK values. This was set up by default, and could be turned on/off<br>
- with -dSimulateOverprint = true/false. Looking over the method used to<br>
- simulate the colors, it was clear that there were issues and that a completely<br>
- different approach is needed. To do proper spot color overprinting simulation<br>
- will require buffers for each of the spot colorants. The plan is to<br>
- achieve this through the use of the pdf14 device and setting it up in<br>
- a manner similar to how it is set up when the target device is a separation<br>
- device. The colorants will then be collapsed to the device's real color<br>
- space when the pdf14 put image occurs. For now, this commit disables the<br>
- blending approach, which did not work in every case, fixing the customers issue<br>
- with this file.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gsdparam.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsovrc.c<br>
-gs/base/gsstate.c<br>
-gs/base/gxblend1.c<br>
-gs/base/gxoprect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-09 10:43: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=64188c8e3615de788ad916b7d14e24e98d9c289c">64188c8e3615de788ad916b7d14e24e98d9c289c</a>
-<blockquote>
-<p>
- Fix Bug 695904, Transparency with non-identity transfer functions.<br>
-<br>
- This does _not_ yet implement the arcane transfer function handling of<br>
- section 7.6.4 of the PDF 1.7 Reference Manual, but it fixes a problem<br>
- detected by customer 532 who uses a transfer function set by PS before<br>
- the PDF file runs. This was causing bands in part of the image.<br>
-<br>
- The problem was that the pdf14 compositor was not applying the transfer<br>
- function for monochrome or indexed color images, and did apply it for<br>
- color images or when the halftone thresholding was done during image<br>
- processing. The transfer function was then applied during pdf14_put_image<br>
- only when the default method of passing the image to the device was<br>
- used (not when the device implemented a put_image proc, as the customer's<br>
- code does for efficiency). If color images had the transfer function<br>
- applied, then the put_image would apply it a second time.<br>
-<br>
- For bands that had the pdf14 compositor skipped because transparency<br>
- was not needed, the transfer function was applied correctly, causing<br>
- differences on transitions to bands that used the pdf14 compositor.<br>
-<br>
- The fix applies the transfer function in the pdf14 cmap procs and does<br>
- _not_ apply it during pdf14_put_image, which also makes it consistent<br>
- with devices that implement a put_image proc and do not have the pis<br>
- or any way to get the transfer function.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-09 10:41: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=f143277e868a37d7154c64408c0cc9b30c4fdb9d">f143277e868a37d7154c64408c0cc9b30c4fdb9d</a>
-<blockquote>
-<p>
- txtwrite - Be careful not to handle strinwidth operations as text<br>
-<br>
- Bug #695914 &quot;txtwrite command is different then Adobe save as other tool&quot;<br>
-<br>
- If we have a CIDFont with a descendant, and the descendant is not present,<br>
- and we substitute with a type 1 font, then when we do a stringwidth the<br>
- txtwrite code could throw an error (no current point) if the text was the<br>
- first element on the page.<br>
-<br>
- This would then throw the font handling off, and we would get the text as<br>
- being in a type 1 font, instead of a type 0 font, which meant that the text<br>
- output was incorrect, even when a ToUnicode CMap was present.<br>
-<br>
- We can deal with this easily by copying the approach from pdfwrite, if its<br>
- a stringwidth let the graphics library deal with it.<br>
-<br>
- No differences in cluster, we don't test txtwrite<br>
-<br>
-gs/devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-08 17:04: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=35f03f7dfdbd7aa834e5c283a24cad48184f7a27">35f03f7dfdbd7aa834e5c283a24cad48184f7a27</a>
-<blockquote>
-<p>
- eps2write - Use an improved approach to getting the BBox of filled paths<br>
-<br>
- Bug #695910 &quot;Error reading a content stream&quot; when using device eps2write by GhostScript 9.16 &quot;<br>
-<br>
- The eps2write device, unlike other devices, needs a 'page' bounding box and<br>
- so often 'renders' content where the other high level devices don't. In<br>
- general this works because we degenerate to low level operations, which are<br>
- then filtered by the eps2write device and used to calculate the BBox.<br>
-<br>
- Unfortunately for pattern fills this doesn't work, as we check the pattern<br>
- tile boundaries, and because we aren't really rendering these are 0. This<br>
- causes an 'unregistered' error.<br>
-<br>
- This commit alters the way we calculate filled path BBoxes, instead of<br>
- rendering to low level objects, we take advantage of the code to calculate<br>
- the bounding box of a path, intersect that with the current clip path's<br>
- outer bounding box, and use that as the BBox of the path. Because we only<br>
- case about maxima and minima this is sufficient, we don't have to worry<br>
- about all the nooks and crannies potentially present in the path.<br>
-<br>
- We do have to watch out for a degenerate path or bbox though, and not take<br>
- that into account.<br>
-<br>
- This commit also does a couple of casts, just to eliminate a compiler warning.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-07 13:26: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=f63ac1a69b1bec4c97d032b69c61bcadeb69902f">f63ac1a69b1bec4c97d032b69c61bcadeb69902f</a>
-<blockquote>
-<p>
- Up version number to 9.18<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-07 16:40:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d82053315ada259dfccaabdc41fbbaab50df46a1">d82053315ada259dfccaabdc41fbbaab50df46a1</a>
-<blockquote>
-<p>
- PDF interpreter - attempt to recover from broken, linearised, PDF file<br>
-<br>
- Bug #695619 &quot;mupdf cannot load page with a special PDF file&quot;<br>
-<br>
- The 'special' PDF file is in fact a totally broken PDF file, caused by<br>
- concatenating a regular PDF file with a linearised PDF file. We detect the<br>
- fact that the xref is not where the Linearised file says it is, and attempt<br>
- to recover, but fail because the trailer dictionary we find is for the<br>
- linearised file, and so does not contain a Root object. Without that we<br>
- cannot decipher the file.<br>
-<br>
- We could attempt to find a 'Linearised' key, but instead I've opted to<br>
- search backwards through the file looking for a previous trailer dictionary<br>
- until we find one that has a Root key, or fail altogether to locate one. If<br>
- we find eon we proceed as before, if we fail to find a trailer with a Root<br>
- key we fail altogether, there's not much else we can do.<br>
-<br>
- Note that depending how ones chooses to 'recover' from this broken PDF file<br>
- could potentially determine *which* of the 2 PDF files present actually<br>
- gets interpreted. We match Acrobat in this case, I won't guarantee we will<br>
- do so in every case.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_rbld.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-06 21:43: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=22573c9d775a7a56449d601e0bbc951c2b325f16">22573c9d775a7a56449d601e0bbc951c2b325f16</a>
-<blockquote>
-<p>
- Bug 695905: reoder tests to prevent seg fault.<br>
-<br>
- We should check the pointer is not null *before* trying to strcmp it.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/devices/vector/gdevpsdp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-02 16:18: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=e136d916239917c9224ebba180cb12329271a597">e136d916239917c9224ebba180cb12329271a597</a>
-<blockquote>
-<p>
- Fix a couple of minor typos and out of dates<br>
-<br>
- relating to cidfmap.<br>
-<br>
-gs/Resource/Init/cidfmap<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-02 12:14:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad0c3d1a9f4f209aefa4414b8073e42cd440edd5">ad0c3d1a9f4f209aefa4414b8073e42cd440edd5</a>
-<blockquote>
-<p>
- Tidy jbig2dec build configuration:<br>
-<br>
- 1) Remove automake version specific tests/use<br>
-<br>
- The script does unpleasant things which can cause us to attempt to use a<br>
- specific version of automake, which should not really be needed these days.<br>
-<br>
- So we now just check that the automake version is greater than or equal to the<br>
- version we require.<br>
-<br>
- The old method can still be accessed by invoking autogen.sh thus:<br>
- USE_OLD=yes ./autogen.sh<br>
-<br>
- 2) Add automake option to make dist &quot;self contained&quot;<br>
-<br>
- The automake default is to symlink to a few scripts ('compile', 'missing' etc)<br>
- in the current system's automake install. That results in a configuration<br>
- reliant on automake being installed, and the same version, for a build.<br>
-<br>
- Add the '--copy' automake option so the script files are copied rather than<br>
- linked, so we get a self contained configure/make/install setup.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/ijs/autogen.sh<br>
-gs/jbig2dec/autogen.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-06 11:59:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=54f502f35b12fd889a47e048b15d92bd8ca66d55">54f502f35b12fd889a47e048b15d92bd8ca66d55</a>
-<blockquote>
-<p>
- PDF Interpreter - work around non-text operations inside a text block<br>
-<br>
- Bug #695897 &quot;Text missing reading PDF file&quot;<br>
-<br>
- In addition to nesting text block inside one another, the test file also<br>
- executes a 'Do' (draw image) operator inside a text block. This is also<br>
- illegal, except in the context of type character descriptions, or pattern<br>
- fills of text, or similar.<br>
-<br>
- This commit slightly modifies the previous one (7bc2078) by copying the<br>
- TextSaveMatrix, instead of simply referencing it, when we execute a gsave<br>
- inside a text block. We can then safely modify the copied array whenever<br>
- a 'cm' operation takes place (just as we already did for TextSaveMatrix),<br>
- finally we can check for TextSaveMatrix or qTextSaveMatrix being present<br>
- when we execute a non-text operation. If this occurs (so far only Do tests<br>
- this) then we save the graphics state (so we don't disturb any following text)<br>
- return to the 'TextSaveMatrix', perform the operation and then restore the<br>
- graphics state.<br>
-<br>
- It should be emphasised that this file is badly broken, both nested text blocks<br>
- and non-text operations inside text blocks are specifically forbidden in the<br>
- PDF reference. So the warning messages emitted when this occurs have been<br>
- extended slightly.<br>
-<br>
- No differences expected<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-04 09:35: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=76c20780b2148e56ffcb6944d910d5a04f4f96a9">76c20780b2148e56ffcb6944d910d5a04f4f96a9</a>
-<blockquote>
-<p>
- PDF Inerpreter - work around illegally nested BT blocks<br>
-<br>
- Bug #695897 &quot;Text missing reading PDF file&quot;<br>
-<br>
- There are actually 2 problems with this file, this is the first fix. The<br>
- file contains nested text blocks, quite a few of them, in direct contravention<br>
- of the PDF specification.<br>
-<br>
- We already have code to detect this, but it relies on a specific key being<br>
- present in the current dictionary to detect the condition. Sadly this file<br>
- executes the nested blocks inside a q/Q pair as well, and the way the PDF<br>
- interpreter deals with a q means that we start a new, empty, dictionary<br>
- which neatly prevents us detecting this.<br>
-<br>
- The nasty hack here introduces a new key 'qTextSaveMatrix' in the dictionary<br>
- created by a 'q' operator, *if* the current dictionary has a TextSaveMatrix<br>
- key present. We then add detection of the qTextSaveMatrix key to the BT<br>
- operator in exactly the same way as the existing TextSaveMatrx.<br>
-<br>
- Attempts to have the TextSaveMatrix copied and used, so that the CTM would<br>
- follow the nesting simply didn't work, leading to the key being present<br>
- when it shouldn't be, or not present when it should, or having the wrong<br>
- value. The only 'correct' way to deal with this illegal file is to separate<br>
- the Text Matrix out from the CTM and track changes to it as required. This<br>
- would mean rewriting large parts of the PDF interpreter which I don;t think<br>
- is reasonable to cope with an invalid file.<br>
-<br>
- The second problem will be the subject of another commit.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-01 16:36:18 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=29cc06bfced3b06b55bed829ce314273461b21e5">29cc06bfced3b06b55bed829ce314273461b21e5</a>
-<blockquote>
-<p>
- Clean up assumption that gs_no_id is &quot;false&quot;<br>
-<br>
-gs/base/gxclpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-02 08:42: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=f1d98961fe65d8b0964ab93040d995d5463a43d8">f1d98961fe65d8b0964ab93040d995d5463a43d8</a>
-<blockquote>
-<p>
- Remove spurious debug code.<br>
-<br>
- No cluster diffs<br>
-<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-30 22:31:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=30c7475eee24393f454368b998980afbae89e542">30c7475eee24393f454368b998980afbae89e542</a>
-<blockquote>
-<p>
- Fix a (rather unfortunate) typo in some debug code.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/toolbin/headers.tcl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-04-01 15:50:02 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8dc207fec1341fa844bc7ae578eb37a8d0267087">8dc207fec1341fa844bc7ae578eb37a8d0267087</a>
-<blockquote>
-<p>
- Fix bug 695867, incorrect cursor position.<br>
-<br>
- The current user space position was not being maintained by the HPGL IR<br>
- command. This is fairly rare and we haven't seen it in our tests,<br>
- HPGL's SC (scale), IP (Input P1 and P2) and IR (Input Relative P1 and<br>
- P2) are used to set up scaling for the page and most jobs usually will<br>
- provide an initial user space coordinate after modifying the CTM and not<br>
- depend on the location that was current when the scaling was applied.<br>
-<br>
- There is more work to be done in this area, the IP command needs similar<br>
- updating as provided here for IR, and other attributes like anchor<br>
- corner and carriage return position should be looked at for side effects<br>
- resulting from IP, IR or SC.<br>
-<br>
-pcl/pgconfig.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-28 15:22:22 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=820064dd06bb0bd63c0c89dc5f500fe70c23ac4b">820064dd06bb0bd63c0c89dc5f500fe70c23ac4b</a>
-<blockquote>
-<p>
- Refactor and cleanup hpgl/2 IP and IR commands.<br>
-<br>
-pcl/pgconfig.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-30 22:19: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=f68473b9034c542575ac8f8334e0c7fc546fa422">f68473b9034c542575ac8f8334e0c7fc546fa422</a>
-<blockquote>
-<p>
- Fix date typo in the docs.<br>
-<br>
- No cluster diffs.<br>
-<br>
-gs/doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-30 10:56: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=2a0d0d006ce1066cbe83ebc818025321953a1cd3">2a0d0d006ce1066cbe83ebc818025321953a1cd3</a>
-<blockquote>
-<p>
- Add the MAKEDIRS target onto the pnglibconf.h deps<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/png.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-30 10:19: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=6dd7e751d41639fd303b795d1503173d38d8d82d">6dd7e751d41639fd303b795d1503173d38d8d82d</a>
-<blockquote>
-<p>
- Move the augmenting of CFLAGS for -Werror....<br>
-<br>
- until after we've identified we're building with gcc.<br>
-<br>
- No cluster differences.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-19 11:55:19 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=26e90b59da069a84cc34501f4c8b4dbfc3dacbe0">26e90b59da069a84cc34501f4c8b4dbfc3dacbe0</a>
-<blockquote>
-<p>
- Bring master up to date with release branch<br>
-<br>
- Update versions and dates for release candidate.<br>
-<br>
- Update News.htm and History9.htm for release candidate.<br>
-<br>
- Some doc updates in response to rc1 feedback<br>
-<br>
- Tweak dates and stuff for second release candidate<br>
-<br>
- Update History file.<br>
-<br>
- Update changelog<br>
-<br>
- Update product string and date in the code.<br>
-<br>
- Update release date in the docs.<br>
-<br>
-README.txt<br>
-gs/Makefile.in<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-gs/contrib/opvp/gdevopvp.c<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-gs/psi/int.mak<br>
-gs/psi/msvc.mak<br>
-gs/psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-27 17:30:18 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e8937a52502d0244c6a3bc173dccd4d83cf00f2">1e8937a52502d0244c6a3bc173dccd4d83cf00f2</a>
-<blockquote>
-<p>
- Fix 695888 - GhostPCL locks up.<br>
-<br>
- The flag to indicate a command is not implemented (e_Unimplemented) was<br>
- set to a positive integer which the GL/2 parser uses to tell the pcl<br>
- parser more PCL is expected. This isn't a problem unless the job<br>
- terminates unexpectedly with an unimplemented GL/2 command leaving the<br>
- PCL parser poised to read more data. Without changing the<br>
- parsers we simply change the unimplemented flag to 0 and the command<br>
- will be properly ignored, like range errors (e_Range).<br>
-<br>
- Unfortunately that leaves us with the same code for e_Range and<br>
- e_Unimplemented which may be an inconvenience when debugging, but both<br>
- codes demand the same behavior of the parsers so we prefer this change<br>
- to trying to find all the places in the parser where e_Unimplemented<br>
- should be &quot;plugged in&quot;.<br>
-<br>
-pcl/pcommand.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-27 09:58:06 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5e87a537c30c15e30615eafedb83ff040a33f6ee">5e87a537c30c15e30615eafedb83ff040a33f6ee</a>
-<blockquote>
-<p>
- PDF Interpreter - When resolving type 6 halftones, preserve the underlying PDFfile position<br>
-<br>
- Bug #695886 &quot;Error reading a content stream, missing objects&quot;<br>
-<br>
- Type 6 halftones in PDF are stream based, so when we first use a graphics<br>
- state which includes a type 6 halftone, we use resolvestream to read the<br>
- halftone.<br>
-<br>
- However resolvestream does not preserve the current file position of PDFfile<br>
- and resolveht6 wasn't taking steps to save and restore it. Often this would<br>
- not be harmful but if we are already reading a stream (eg a page content<br>
- stream) and the stream was large enough not to be entirely buffered then when<br>
- we ran out of data we would return to 'PDFfile' to read another buffer from<br>
- the content stream. The fact that PDFfile had been repositioned would cause<br>
- us to read the wrong data (always, in fact, the 'endstream' from the halftone<br>
- stream).<br>
-<br>
- This commit retrieves the current position of PDFfile and restores it after<br>
- resolving the stream.<br>
-<br>
- No differences expected<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-23 15:29: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=f56588ea3cb9337b3c4143a9eb651f085cfe8298">f56588ea3cb9337b3c4143a9eb651f085cfe8298</a>
-<blockquote>
-<p>
- LCMS2 pointer alignment on SPARC/gcc<br>
-<br>
- Building on commit 5a2da7dd71:<br>
-<br>
- With gcc on (Ultra)SPARC hardware, pointers must be 8 byte aligned, even in<br>
- 32 bit userspace (where sizeof(void *) == 4).<br>
-<br>
- So it means taking special action to enforce 8 byte alignment in the LCMS2<br>
- memory management code.<br>
-<br>
- We'll set the alignment for SPARC builds in the configure script.<br>
-<br>
- No cluster differences.<br>
-<br>
-config.mak.in<br>
-configure.ac<br>
-gs/Makefile.in<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-24 13:50:34 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cab2628321d8806747da90c02c3abf4b2c9fe4c3">cab2628321d8806747da90c02c3abf4b2c9fe4c3</a>
-<blockquote>
-<p>
- LCMS2 on SPARC ptr alignment.<br>
-<br>
- Allow the ptr alignment for LCMS2 memory management to set at build time on the<br>
- compiler command line.<br>
-<br>
- Submitted upstream:<br>
- https://github.com/mm2/Little-CMS/commit/dd0074b2<br>
-<br>
- No cluster differences<br>
-<br>
-gs/lcms2/src/lcms2_internal.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-23 17:03: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=8bb53a7f2cb309cc10209f8e7ed31daf6c2f4811">8bb53a7f2cb309cc10209f8e7ed31daf6c2f4811</a>
-<blockquote>
-<p>
- Bug 695882: ensure function protypes are available<br>
-<br>
- There are some special defines on Linux to include prototypes for pread, pwrite<br>
- and pthread_mutexattr_settype: add these to our &quot;unistd_.h&quot; header.<br>
-<br>
- Also, tweak the the configure script to check for prototypes as well as just<br>
- successful linking before including the code that uses those functions<br>
-<br>
- No cluster differences<br>
-<br>
-configure.ac<br>
-gs/base/gp_psync.c<br>
-gs/base/unistd_.h<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-24 11:07:43 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0997387b6b691d7495722d020ee7f6bab4988020">0997387b6b691d7495722d020ee7f6bab4988020</a>
-<blockquote>
-<p>
- PDF Interpreter - ignore XRefStm entries which poitn beyond end of file<br>
-<br>
- Bug #695883 &quot;Error: /invalidaccess in --run--&quot;<br>
-<br>
- The file is pretty well broken, it claims to be a hybrid (PDF 1.5 or better<br>
- readable by PDF 1.4 consumer, it uses xref streams) and as such its trailer<br>
- dictionary contains an XRefStm key whose value is supposed to point to the<br>
- PDF 1.5 xref stream. It doesn't, in fact it points past the end of the file<br>
- and so is clearly bogus.<br>
-<br>
- This commit tests to ensure the XRefStm value is inside the file before<br>
- attempting to read it.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-20 00:11:26 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8a275b2f12c2d22cb40fcf421c309a018dd48b0e">8a275b2f12c2d22cb40fcf421c309a018dd48b0e</a>
-<blockquote>
-<p>
- Tweak builds for SPARC architecture<br>
-<br>
- SPARC's interesting alignment requirements don't work with the memory header<br>
- ID code, so disable it.<br>
-<br>
- No cluster differences.<br>
-<br>
-configure.ac<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-19 11:50: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=e77a35e7ffef84328a7fb26379783455da3f8a58">e77a35e7ffef84328a7fb26379783455da3f8a58</a>
-<blockquote>
-<p>
- Bump version numbers to 9.17<br>
-<br>
- Usual cluster differences.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-30 09:16:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=92d4dd195d0cb9155851411db04e1d2af1f59c03">92d4dd195d0cb9155851411db04e1d2af1f59c03</a>
-<blockquote>
-<p>
- Update release date in the docs.<br>
-<br>
-gs/contrib/opvp/gdevopvp.c<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-30 09:15: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=20c71f82b1116ee95e0ae03121b9f137900fbcd8">20c71f82b1116ee95e0ae03121b9f137900fbcd8</a>
-<blockquote>
-<p>
- Update product string and date in the code.<br>
-<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-24 14:08:57 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2a35f042bfa9fa431794546bff4b2e388036798d">2a35f042bfa9fa431794546bff4b2e388036798d</a>
-<blockquote>
-<p>
- Update changelog<br>
-<br>
-gs/doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-23 15:29: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=49ac7a284e46cf8df8eb553c91ee48a6b004652e">49ac7a284e46cf8df8eb553c91ee48a6b004652e</a>
-<blockquote>
-<p>
- LCMS2 pointer alignment on SPARC/gcc<br>
-<br>
- Building on commit 5a2da7dd71:<br>
-<br>
- With gcc on (Ultra)SPARC hardware, pointers must be 8 byte aligned, even in<br>
- 32 bit userspace (where sizeof(void *) == 4).<br>
-<br>
- So it means taking special action to enforce 8 byte alignment in the LCMS2<br>
- memory management code.<br>
-<br>
- We'll set the alignment for SPARC builds in the configure script.<br>
-<br>
- No cluster differences.<br>
-<br>
-config.mak.in<br>
-configure.ac<br>
-gs/Makefile.in<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-24 13:50:34 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f2f22a246dcbe8468880535ea75f47e0fc4619ce">f2f22a246dcbe8468880535ea75f47e0fc4619ce</a>
-<blockquote>
-<p>
- LCMS2 on SPARC ptr alignment.<br>
-<br>
- Allow the ptr alignment for LCMS2 memory management to set at build time on the<br>
- compiler command line.<br>
-<br>
- Submitted upstream:<br>
- https://github.com/mm2/Little-CMS/commit/dd0074b2<br>
-<br>
- No cluster differences<br>
-<br>
-gs/lcms2/src/lcms2_internal.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-23 17:03: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=b96200d7fc5f3b7464744589f6657e9b4c4cb3ec">b96200d7fc5f3b7464744589f6657e9b4c4cb3ec</a>
-<blockquote>
-<p>
- Bug 695882: ensure function protypes are available<br>
-<br>
- There are some special defines on Linux to include prototypes for pread, pwrite<br>
- and pthread_mutexattr_settype: add these to our &quot;unistd_.h&quot; header.<br>
-<br>
- Also, tweak the the configure script to check for prototypes as well as just<br>
- successful linking before including the code that uses those functions<br>
-<br>
- No cluster differences<br>
-<br>
-configure.ac<br>
-gs/base/gp_psync.c<br>
-gs/base/unistd_.h<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-24 11:07:43 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9358edca362b60f8ace388768548e6e94f5ebec8">9358edca362b60f8ace388768548e6e94f5ebec8</a>
-<blockquote>
-<p>
- PDF Interpreter - ignore XRefStm entries which poitn beyond end of file<br>
-<br>
- Bug #695883 &quot;Error: /invalidaccess in --run--&quot;<br>
-<br>
- The file is pretty well broken, it claims to be a hybrid (PDF 1.5 or better<br>
- readable by PDF 1.4 consumer, it uses xref streams) and as such its trailer<br>
- dictionary contains an XRefStm key whose value is supposed to point to the<br>
- PDF 1.5 xref stream. It doesn't, in fact it points past the end of the file<br>
- and so is clearly bogus.<br>
-<br>
- This commit tests to ensure the XRefStm value is inside the file before<br>
- attempting to read it.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-20 15:45:56 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=866f98d9b88b6b450aa4d112cabc60a1f964bbd6">866f98d9b88b6b450aa4d112cabc60a1f964bbd6</a>
-<blockquote>
-<p>
- Update History file.<br>
-<br>
-gs/doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-20 15:09: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=08c4ed7a418ea4eed1efd12cf8fe81297c00a2f9">08c4ed7a418ea4eed1efd12cf8fe81297c00a2f9</a>
-<blockquote>
-<p>
- Tweak dates and stuff for second release candidate<br>
-<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-20 14:58: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=6aac092d495d1651840074cd2ed9ba64d9d4c0a4">6aac092d495d1651840074cd2ed9ba64d9d4c0a4</a>
-<blockquote>
-<p>
- Some doc updates in response to rc1 feedback<br>
-<br>
-README.txt<br>
-gs/doc/History9.htm<br>
-gs/doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-20 00:11:26 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c56ffb81354dca442b69389b0f7a0b75e4e864e">6c56ffb81354dca442b69389b0f7a0b75e4e864e</a>
-<blockquote>
-<p>
- Tweak builds for SPARC architecture<br>
-<br>
- SPARC's interesting alignment requirements don't work with the memory header<br>
- ID code, so disable it.<br>
-<br>
- No cluster differences.<br>
-<br>
-configure.ac<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-19 11:55:19 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=369bb9d36e4309c93bb60a2eb799ee5ff16e9c7c">369bb9d36e4309c93bb60a2eb799ee5ff16e9c7c</a>
-<blockquote>
-<p>
- Update versions and dates for release candidate.<br>
-<br>
- Update News.htm and History9.htm for release candidate.<br>
-<br>
-gs/Makefile.in<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-gs/psi/int.mak<br>
-gs/psi/msvc.mak<br>
-gs/psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-
-<h2><a name="Version9.16"></a>Version 9.16 (2015-03-30)</h2>
-
-<p>This is the twelfth full release in the stable 9.x series, and is
-primarily a maintenance release.
-
-<p> Highlights in this release include:
-<ul>
-<li>
-<p>"LockColorants" command line option for tiffsep and psdcmyk devices. Specifying
--dLockColorants will restrict those devices to only the colorants list on the command
-line (thus: -c "<< /SeparationColorNames [ /Cyan /Magenta /Yellow /Black /Violet /Orange]
-/SeparationOrder [ /Cyan /Magenta /Yellow /Black /Violet /Orange]>> setpagedevice"), rather
-than allowing the devices to add new colorants as encountered in the input. This is, obviously,
-preferable for real printers, where only a certain of inks will be available.
-</li>
-<li>
-<p>Improved high level devices handling of Forms. Whilst High level devices (eg pdfwrite)
-already checked Forms to see if they are duplicates, and if so use the initial definition.
-However, this does not improve performance, since the Form PaintProc still needs to be executed
-for each instance of the Form, and the matching algorithm could, in very odd circumstances, be
-defeated. The new implementation benefits both causes, meaning the second and subsequent invocation
-of the form need not re-run the PaintProc, and removes the heuristic aspect of the reuse detection.
-</li>
-<li>
-<p>New URW+ fonts in which the families NimbusMono, NimbusRoman and NimbusSans have been
-augmented with production quality Greek and Cyrillic glyphs. These correspond to our
-substitutes for the PDF base 14 fonts.
-</li>
-<li>
-<p>Plus the usual round of bug fixes, compatibility changes, and incremental improvements.
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.16_Incompatible_changes"></a>Incompatible changes</h3>
-<p>
-No recorded incompatible changes.
-
-<h3><a name="9.16_changelog"></a>Changelog</h3>
-<p><strong>2015-03-20 00:11:26 +0000
-</strong>
-<p><strong>2015-03-19 11:55:19 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49ac7a284e46cf8df8eb553c91ee48a6b004652e">49ac7a284e46cf8df8eb553c91ee48a6b004652e</a>
-<blockquote>
-<p>
- LCMS2 pointer alignment on SPARC/gcc<br>
-<br>
- Building on commit 5a2da7dd71:<br>
-<br>
- With gcc on (Ultra)SPARC hardware, pointers must be 8 byte aligned, even in<br>
- 32 bit userspace (where sizeof(void *) == 4).<br>
-<br>
- So it means taking special action to enforce 8 byte alignment in the LCMS2<br>
- memory management code.<br>
-<br>
- We'll set the alignment for SPARC builds in the configure script.<br>
-<br>
- No cluster differences.<br>
-<br>
-config.mak.in<br>
-configure.ac<br>
-gs/Makefile.in<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-24 13:50:34 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f2f22a246dcbe8468880535ea75f47e0fc4619ce">f2f22a246dcbe8468880535ea75f47e0fc4619ce</a>
-<blockquote>
-<p>
- LCMS2 on SPARC ptr alignment.<br>
-<br>
- Allow the ptr alignment for LCMS2 memory management to set at build time on the<br>
- compiler command line.<br>
-<br>
- Submitted upstream:<br>
- https://github.com/mm2/Little-CMS/commit/dd0074b2<br>
-<br>
- No cluster differences<br>
-<br>
-gs/lcms2/src/lcms2_internal.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-23 17:03: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=b96200d7fc5f3b7464744589f6657e9b4c4cb3ec">b96200d7fc5f3b7464744589f6657e9b4c4cb3ec</a>
-<blockquote>
-<p>
- Bug 695882: ensure function protypes are available<br>
-<br>
- There are some special defines on Linux to include prototypes for pread, pwrite<br>
- and pthread_mutexattr_settype: add these to our &quot;unistd_.h&quot; header.<br>
-<br>
- Also, tweak the the configure script to check for prototypes as well as just<br>
- successful linking before including the code that uses those functions<br>
-<br>
- No cluster differences<br>
-<br>
-configure.ac<br>
-gs/base/gp_psync.c<br>
-gs/base/unistd_.h<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-24 11:07:43 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9358edca362b60f8ace388768548e6e94f5ebec8">9358edca362b60f8ace388768548e6e94f5ebec8</a>
-<blockquote>
-<p>
- PDF Interpreter - ignore XRefStm entries which poitn beyond end of file<br>
-<br>
- Bug #695883 &quot;Error: /invalidaccess in --run--&quot;<br>
-<br>
- The file is pretty well broken, it claims to be a hybrid (PDF 1.5 or better<br>
- readable by PDF 1.4 consumer, it uses xref streams) and as such its trailer<br>
- dictionary contains an XRefStm key whose value is supposed to point to the<br>
- PDF 1.5 xref stream. It doesn't, in fact it points past the end of the file<br>
- and so is clearly bogus.<br>
-<br>
- This commit tests to ensure the XRefStm value is inside the file before<br>
- attempting to read it.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c56ffb81354dca442b69389b0f7a0b75e4e864e">6c56ffb81354dca442b69389b0f7a0b75e4e864e</a>
-<blockquote>
-<p>
- Tweak builds for SPARC architecture<br>
-<br>
- SPARC's interesting alignment requirements don't work with the memory header<br>
- ID code, so disable it.<br>
-<br>
- No cluster differences.<br>
-<br>
-configure.ac<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=03d399b295f9a39f743eb194ebce0995d52d0bfb">03d399b295f9a39f743eb194ebce0995d52d0bfb</a>
-<blockquote>
-<p>
- Update versions and dates for release candidate.<br>
-<br>
-gs/Makefile.in<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-gs/psi/int.mak<br>
-gs/psi/msvc.mak<br>
-gs/psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-19 13:50:07 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a463733e35e1070a06029657dedb67148c33c87a">a463733e35e1070a06029657dedb67148c33c87a</a>
-<blockquote>
-<p>
- Handle an invalid cidfmap entry in the CIDFont subst code<br>
-<br>
- Certain types of invalid entry in the cidfmap can mean that resourcestatus<br>
- returns &quot;true&quot; but a subsequent &quot;findresource&quot; will fail. There is already<br>
- validation code to strip out invalid entries, but as an extra safety measure,<br>
- call the findresource in a stopped context, so we can recover, and continue<br>
- with the next substitution fallback stage.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-19 10:51:32 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=68f1390c29df09d2cc7cdb5c815c71aaa77f667c">68f1390c29df09d2cc7cdb5c815c71aaa77f667c</a>
-<blockquote>
-<p>
- Add instructions about using ghostpdf.inf on Windows 8<br>
-<br>
- Add the instructions in the comments in ghostpdf.inf, and in a separate README<br>
- file.<br>
-<br>
- Lots of &quot;AT YOUR OWN RISK!!&quot; comments in both.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/lib/ghostpdf.README<br>
-gs/lib/ghostpdf.inf<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-19 10:49:34 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2487b24d668f86350a1c5bdcf0e7a485470665e9">2487b24d668f86350a1c5bdcf0e7a485470665e9</a>
-<blockquote>
-<p>
- Correct a copy'n'paste mistake in a conditional<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-18 08:37:15 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c4edb1e23eec531b96194f85685b30656149732">3c4edb1e23eec531b96194f85685b30656149732</a>
-<blockquote>
-<p>
- Bug 695860: only shutdown BGPrint if it's active<br>
-<br>
- Always forcing a setpagedevice interacts poorly with pdfwrite/ps2write (which<br>
- rely on the device shutting down to trigger emitting the final output).<br>
-<br>
- Since vector devices cannot benefit from BGPrint, only disable BGPrint (with<br>
- setpagedevice) if BGPrint was active in the first place.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-17 22:42: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=2ceee5a8a0e1a4d65f14de5f6cf53bb939b2f02c">2ceee5a8a0e1a4d65f14de5f6cf53bb939b2f02c</a>
-<blockquote>
-<p>
- Bug 695872: handle real/integer mixup in image Decode dict<br>
-<br>
- In PDF we now pass the Height value from the image dict into the parameters<br>
- for the filter to access (specifically, the DCTDecodeFilter), and this will<br>
- cause an error if the Height value is, erroneously, a real rather than integer<br>
- value (the Postscript image operator appears to already handle that error,<br>
- at least in certain cases, gracefully).<br>
-<br>
- So the filter code does not throw an error, round and convert the value to an<br>
- integer before storing it in the filter parameters dictionary.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-17 21:44:50 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ace1b71cd0097ee830692e3e59738e084f5a4141">ace1b71cd0097ee830692e3e59738e084f5a4141</a>
-<blockquote>
-<p>
- Fix a couple of typos in Install.htm<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/doc/Install.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-17 18:05: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=41ff61ceceb55dd03da6b309c290c880c38fce04">41ff61ceceb55dd03da6b309c290c880c38fce04</a>
-<blockquote>
-<p>
- Bug 692861: update Install.htm for &quot;new&quot; installer.<br>
-<br>
- Bring Install.htm in-line with the nsis based Windows installer.<br>
-<br>
- Also, remove references to Adobe Type Manager, and document that OpenVMS and<br>
- OS/2 are no longer actively supported by us.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/doc/Install.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-17 16:38:50 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b18cefb10c2391188d07ad0ca397e58121434b8b">b18cefb10c2391188d07ad0ca397e58121434b8b</a>
-<blockquote>
-<p>
- Recursive mutex emulation: fix order of operations<br>
-<br>
- We have to invalidate the self_id value *before* we unlock the mutex, as the<br>
- mutex implicitly protects the self_id (and lcount) value.<br>
-<br>
- Also add asserts so we'll abort if the self_id and/or lcount get out of whack.<br>
-<br>
- Finally, add a missing default value for RECURSIVE_MUTEXATTR in the ghostpdl<br>
- configure.<br>
-<br>
- No cluster differences<br>
-<br>
-configure.ac<br>
-gs/base/gp_psync.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-17 14:45: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=3dbcbb2ac75a8565534310cba189544ccdd1c1c4">3dbcbb2ac75a8565534310cba189544ccdd1c1c4</a>
-<blockquote>
-<p>
- Bug 695862: addendum - fix typo<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gp_psync.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-16 22:18: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=edf3461901805376bdb1b9aa995df359531c7539">edf3461901805376bdb1b9aa995df359531c7539</a>
-<blockquote>
-<p>
- Fix a write after free memory issue.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/base/stream.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-16 12:52: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=444e0bf9c43bae0261660e6318ba0e514c18d41e">444e0bf9c43bae0261660e6318ba0e514c18d41e</a>
-<blockquote>
-<p>
- Bug 695862: use PTHREAD_MUTEX_RECURSIVE(_NP) if available<br>
-<br>
- or properly emulate recursive mutexes ourselves.<br>
-<br>
- No cluster differences<br>
-<br>
-config.mak.in<br>
-configure.ac<br>
-gs/Makefile.in<br>
-gs/base/gp_psync.c<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-07 16:25:46 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f1feefae4e6412d37db6abb46b492a74073964c7">f1feefae4e6412d37db6abb46b492a74073964c7</a>
-<blockquote>
-<p>
- Bug 691396: add new lines to FAPIdebug messages.<br>
-<br>
- No cluster differences<br>
-<br>
- tmp commit<br>
-<br>
-gs/Resource/Init/gs_fapi.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-07 17:05:53 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=febe7a1acf152ef7379a126bfa65358604272b5a">febe7a1acf152ef7379a126bfa65358604272b5a</a>
-<blockquote>
-<p>
- Flush around FAPI &quot;internal&quot; debug messages.<br>
-<br>
- Try to avoid the FAPI -Z1 messages stomping on other output messages by flushing<br>
- around the messages.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-gs/base/fapiufst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-07 15:10: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=0f1d26a75ccb1adc806287f7e97af14af85f4fdf">0f1d26a75ccb1adc806287f7e97af14af85f4fdf</a>
-<blockquote>
-<p>
- Bug 692815: Fonts resourcestatus and native fonts<br>
-<br>
- The core of the resourcestatus implementation for the Fonts category would<br>
- check the content of Fontmap, but would not trigger the native font scanning<br>
- to occur. So two invokations of resourcestatus for Font could result in<br>
- different results depending on whether, in the intervening period, another<br>
- operation had triggered the native font scan.<br>
-<br>
- This could result in unexpected behaviour from the PDF interpreter where a<br>
- &quot;synthetic&quot; substitute could be created on the first page, and a native font<br>
- selected on the second page, for the same font name.<br>
-<br>
- We'll now try to &quot;find&quot; the font for resourcestatus, if we fail, we'll try to<br>
- trigger the native font scan, and retry.<br>
-<br>
- Further, I had missed the fact that this code used the Fontmap dictionary in my<br>
- previous commit, so it now accounts for the new NativeFontmap dict.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_fonts.ps<br>
-gs/Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-05 14:56: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=3edd8e8e64c0b35364c2fdf2e13336191c023f4b">3edd8e8e64c0b35364c2fdf2e13336191c023f4b</a>
-<blockquote>
-<p>
- Bug 690653: fix order of font substitution mapping.<br>
-<br>
- Previously, the enumeration of the &quot;native fonts&quot; (i.e. when using<br>
- fontconfig) wrote the mappings into the same Fontmap dictionary that is built<br>
- from the Fontmap file.<br>
-<br>
- This could cause several problems. Firstly, it was possible for fonts found by<br>
- the native font search to effective replace the default font set - which should<br>
- *never* happen. Secondly, and even worse, the font found when trying to load<br>
- one of the default font set could change depending on whether a prior attempt<br>
- was made to load from from outside the default font, because the attempt to load<br>
- a font from outside the default set would trigger the Fontmap to change with the<br>
- native fonts being added.<br>
-<br>
- We'll now keep the Fontmap dict from the Fontmap file separate from a new<br>
- native fontmap dictionary. We'll now check the Fontmap dictionary, then try to<br>
- load directly by name, then check the .nativeFontmap dict.<br>
-<br>
- The .nativeFontmap also gets the results of scanning the directories in the<br>
- FONTDIR paremeter.<br>
-<br>
- No cluster differences.<br>
-<br>
- Bug 690653 (related): update pdf interp to use NativeFontmap<br>
-<br>
- The pdf interpreter accesses Fontmap, so tweak it to also use NativeFontmap.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/Resource/Init/gs_fonts.ps<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-16 18:29:09 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0391d0e73c1892138b11c1416113e32b80d3317f">0391d0e73c1892138b11c1416113e32b80d3317f</a>
-<blockquote>
-<p>
- Update clusterpush.pl to cope with new mupdf source layout.<br>
-<br>
-gs/toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-16 08:39:36 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=949e2de694cb5464a26794b7679d8f74ad2fe02b">949e2de694cb5464a26794b7679d8f74ad2fe02b</a>
-<blockquote>
-<p>
- Temporary fix for bug 695711. Disable BGPrint when NumRenderingThreads &gt; 0.<br>
-<br>
- This will be fixed, but since background printing is an optimization, it is<br>
- better to disable it instead of having a SEGV occur due to a race condition.<br>
-<br>
-gs/base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-16 10:08: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=d4440c2190845bdd165f3d208d508f45e2142bee">d4440c2190845bdd165f3d208d508f45e2142bee</a>
-<blockquote>
-<p>
- pdfwrite - process octal escapes in DSC comments<br>
-<br>
- Bug #695850 - &quot;DSC comments not being read correctly from PDFDocEncoding&quot;<br>
-<br>
- DSC comments are not encoded using PDFDocEncoding, nor are they PostScript<br>
- strings, they are a simple sequence of bytes. So it seems that we should<br>
- simply preserve that sequence in the output PDF file. However Distiller<br>
- behaves 'oddly' with DSC comments containing escape characters:<br>
-<br>
- octal escapes (\ followed by 3 numbers) are converted into apparently a<br>
- PDFDocEncoding byte<br>
-<br>
- non-octal numeric escapes (\ followed by less than 3 numbers or numebrs<br>
- which aren't octal) have the \ changed to a ?<br>
-<br>
- non-octal non-numeric escapes (eg \n) simply get the escape dropped.<br>
-<br>
- IMO this leads to problems, for example bug687660.ps has a %%Title which is<br>
- a DOS filename '%%Title: (C:\PHYSICS\TeX\SPINTRONICS\SPIN_HALL\gh_ef_001.eps)'<br>
- Distiller mangles this by dropping all the '\' characters to become<br>
- (C:PHYSICSTeXSPINTRONICSSPIN_HALLgh_ef_001.eps)<br>
-<br>
- This commit alters the way that pdfwrite handles octal escapes *only*. These<br>
- are converted to binary and will then be encoded as if they were in<br>
- PDFDocEncoding which matches Distiller. We will not attempt to match the<br>
- observed behaviour of Distiller, not least because I think its completely<br>
- the wrong thing to do.<br>
-<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-13 09:20: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=a16e39318467d8a802296bd34bbf0fab7f7809d5">a16e39318467d8a802296bd34bbf0fab7f7809d5</a>
-<blockquote>
-<p>
- Fix for bug 695863 overprint while pattern color is active<br>
-<br>
- If a pattern color space is present when a graphics state swap occurs, and<br>
- the overprint changes from on to off in the graphics state the overprint<br>
- compositor is not disabled. In Bug 695863 a DeviceN image fill follows such<br>
- a case and the fill is improperly performed with overprint enabled. With this<br>
- commit we disable the overprint compositor if overprint is off. If overprint<br>
- is not off, it is not clear how we should proceed, as the color space is<br>
- a factor in that set up and here the color space is a pattern.<br>
-<br>
-gs/base/gspcolor.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-10 22:05:52 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=64e33af885e49b40c0ebc070ede50e86a8ed3bdb">64e33af885e49b40c0ebc070ede50e86a8ed3bdb</a>
-<blockquote>
-<p>
- Change to check for len &gt; 0 on while loop<br>
-<br>
- Requested by a customer and protects against caller passing invalid len<br>
-<br>
-gs/psi/dwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-07 08:38:57 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e8a9c4265c3346055ecfc8025880cab28e268de">8e8a9c4265c3346055ecfc8025880cab28e268de</a>
-<blockquote>
-<p>
- Fix for bug 693070 psdrgb device<br>
-<br>
- The psdrgb device should not alter its number of components but it should stay<br>
- fixed. This commit plus b5b03bde360a7ba625a4c40a936c4e2fd5a32359<br>
- should fix the psdrgb device.<br>
-<br>
-gs/devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-06 13:28:51 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5b03bde360a7ba625a4c40a936c4e2fd5a32359">b5b03bde360a7ba625a4c40a936c4e2fd5a32359</a>
-<blockquote>
-<p>
- PageSpotColors was getting handled by devn_get_params but not devn_put_params<br>
-<br>
- For additive devices devn_put_params was not handling PageSpotColors but<br>
- devn_get_params was. This mismatch would lead to an error for the psdrgb<br>
- device, which is an additive device built upon the DeviceN device. Additive<br>
- devices do not handle apot colors at this time so the fix was to make<br>
- the handling of PageSpotColors in devn_get_params dependent upon the device<br>
- polarity like devn_put_params does.<br>
-<br>
-gs/base/gdevdevn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-06 11:19:07 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c75e5c690c6f9c1da2e9225d4986967d1d391c8b">c75e5c690c6f9c1da2e9225d4986967d1d391c8b</a>
-<blockquote>
-<p>
- Fix for bug 695791. Wrong ICC profile written when source was CIELAB colorspace.<br>
-<br>
-gs/devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-03-03 18:59:17 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=12ddbaa69c38fa0178ff60a012ff358987b6238d">12ddbaa69c38fa0178ff60a012ff358987b6238d</a>
-<blockquote>
-<p>
- Handle non-integer /Rotate values.<br>
-<br>
- Add a convert to integer (cvi) after retrieving the /Rotate entry from a PDF<br>
- /Page object (we already reject values that are not a multiple of 90).<br>
-<br>
- In this case, the value was 90.0.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-27 12:25:15 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=863c929faa7811ce6d78cb8d1b4610ee00a7a572">863c929faa7811ce6d78cb8d1b4610ee00a7a572</a>
-<blockquote>
-<p>
- Fix mistake on temp state setup for named color replacement<br>
-<br>
- I had not properly set up the colorant mapping positions and<br>
- size for the temporary graphic state that is used during the<br>
- storage of the color values that are set by the named color<br>
- replacement code. Thanks to Stefan for finding this.<br>
-<br>
-gs/base/gxcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-26 18:01:04 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7093747c7336656cfba938cff705b36fea6106c2">7093747c7336656cfba938cff705b36fea6106c2</a>
-<blockquote>
-<p>
- More improvement related to bug #695833 properly selecting LinePrinter<br>
- not Courier.<br>
-<br>
-pl/plftable.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-26 17:54:10 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f4f0f0a92a543adef944c09ff065defe1c58fefe">f4f0f0a92a543adef944c09ff065defe1c58fefe</a>
-<blockquote>
-<p>
- Remove the test for a TrueType file type to make way for supporting<br>
- other font file types.<br>
-<br>
-pl/pllfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-25 07:44:51 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=70bd09212747f8b13e94948c04cadf5b0df65899">70bd09212747f8b13e94948c04cadf5b0df65899</a>
-<blockquote>
-<p>
- Silence a compiler warning in fuzzy.c<br>
-<br>
-gs/toolbin/tests/fuzzy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-12 10:13:10 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a2d08f1eb88355c81672668595f0b80f32386e48">a2d08f1eb88355c81672668595f0b80f32386e48</a>
-<blockquote>
-<p>
- Fix pattern-clist with transparency color mismatch with raster patterns<br>
-<br>
- Cust 532 noticed that colors would be (very slightly) different when patterns<br>
- were rendered from raster patterns vs. using the pattern-clist approach. This<br>
- happened when the pattern has transparency such as fts_25_2526.ps.<br>
-<br>
- The file tests_private/comparefiles/Bug692720.pdf is a progression (lower left<br>
- &quot;21h&quot; and &quot;22h&quot; are missing and the bold outline for some of the text on the<br>
- left panel is wrong without this change.<br>
-<br>
- Fix it to make sure and push and pop a transparency group around the pattern<br>
- filling when pattern-clist is used, the same as for raster patterns that have<br>
- transparecncy. The 'blending_mode' was moved to the tile (gx_color_tile_s)<br>
- from the ttrans (gx_pattern_trans_s) struct so that it will be available when<br>
- painting from the pattern-clist.<br>
-<br>
- Also remove some code in gxpcmap.c that was dead (#if 0) since 2007.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gsptype1.c<br>
-gs/base/gxclread.c<br>
-gs/base/gximask.c<br>
-gs/base/gxp1fill.c<br>
-gs/base/gxpcmap.c<br>
-gs/base/gxpcolor.h<br>
-gs/psi/zpcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-23 14:13:53 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb531eecd1942807a792ef66a1aa49ec00792d13">fb531eecd1942807a792ef66a1aa49ec00792d13</a>
-<blockquote>
-<p>
- Fix bugs 695840, 695841. Regression due to pdf14_clist optimization.<br>
-<br>
- If the color characteristics of the device do not match the pdf14<br>
- compositor, rendering the clist bands without the pdf14 compositor<br>
- will fail, either by reading colors with the wrong depth back from<br>
- the clist or colors having been pre-converted using a device ICC<br>
- profile that is different than the colors that are written using<br>
- the pdf14 compositor.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevp14.h<br>
-gs/base/gxclrast.c<br>
-gs/base/gxclread.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-23 12:18:01 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1dca5f29bf59d3071021a3ba4b7378e60d0e7a10">1dca5f29bf59d3071021a3ba4b7378e60d0e7a10</a>
-<blockquote>
-<p>
- Fixes for named color support<br>
-<br>
- A few minor fixes for named color support including the detection of the<br>
- None colorant in the DeviceN list of colorants. Making sure that the<br>
- equivalent CMYK color is correctly computed. Make sure that all the<br>
- colorants in the device are cleared out prior to setting the ones<br>
- associated with the device profile in the example code given in<br>
- gsicc_transform_named_color.<br>
-<br>
-gs/base/gsequivc.c<br>
-gs/base/gsequivc.h<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gxcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-23 10:15:02 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=46b59d18a8f4d204e83327e135c17657caefde3a">46b59d18a8f4d204e83327e135c17657caefde3a</a>
-<blockquote>
-<p>
- Fix issues with sICCOutputColors option<br>
-<br>
- If an NCLR ICC profile is specified for output then it is also<br>
- possible to specify the colorant names associated with the profile.<br>
- This information is described by the sICCOutputColors parameter.<br>
- There was an issue where the default colorant names AND the<br>
- colorant names specified by sICCOutputColors were getting<br>
- added to the device. With this fix only the colorants specified<br>
- by sICCOutputColors are added to the device.<br>
-<br>
-gs/base/gsdparam.c<br>
-gs/base/gsicc_manage.c<br>
-gs/devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-23 12:30:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=375752983d9373b28bf1fada04fc9325673bc51c">375752983d9373b28bf1fada04fc9325673bc51c</a>
-<blockquote>
-<p>
- Bug 695516: fix psl.dev/psbase.dev deps snafu....<br>
-<br>
- And also tidy dependency for PDF interpreter.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-23 11:49: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=1125d53f8db9f7402f37fa8fe7823257e4c6554a">1125d53f8db9f7402f37fa8fe7823257e4c6554a</a>
-<blockquote>
-<p>
- PDF Interpreter - fix some kinds of FreeText processing<br>
-<br>
- Bug 695848 &quot;Ghostscript decode error when opening PDF&quot;<br>
-<br>
- The processing of the Default Appearance was mishandling some colour<br>
- specifications. It was expecting arrays for all operators, when in fact only<br>
- the (undocumented ?) 'r' operator takes an array, all the others simply<br>
- take a sequence of values.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-20 15:05:51 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6ab5713f556bde0be38fa411e2eb1d25eb73e2c5">6ab5713f556bde0be38fa411e2eb1d25eb73e2c5</a>
-<blockquote>
-<p>
- Use different remap proc for indexed color space when dealing with named colors<br>
-<br>
- Currently the Index color space uses gx_default_remap_color for its remap procedure.<br>
- This is a problem for when we are dealing with an index color whose base space<br>
- is DeviceN and we are doing named color replacement in our color management. To<br>
- fix this, we introduce a different version of the Indexed color space that is installed<br>
- with a different remap proc for the case when we have a index color space whose<br>
- base space is DeviceN or Separation AND we have specified a named color ICC profile.<br>
-<br>
-gs/base/gscolor2.c<br>
-gs/base/gscolor2.h<br>
-gs/psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-20 14:23:56 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=033cf566b74c7e12bfb82d9b63a7bc680c51c5f8">033cf566b74c7e12bfb82d9b63a7bc680c51c5f8</a>
-<blockquote>
-<p>
- Add LockColorants option to tiffsep and psdcmyk devices<br>
-<br>
- If someone specifies a list of colorants using something like this<br>
-<br>
- -c &quot;&lt;&lt; /SeparationColorNames [ /Cyan /Magenta /Yellow /Black /Violet /Orange]<br>
- /SeparationOrder [ /Cyan /Magenta /Yellow /Black /Violet /Orange]&gt;&gt; setpagedevice&quot;<br>
-<br>
- on the command line, it would be nice if they also had the option to<br>
- keep the colorants to only this set for the tiffsep and psdcmyk devices.<br>
-<br>
- Currently, the list of colorants above would be included as well as any that<br>
- are encountered in the document (up to a max of 64). In some cases, this<br>
- may be the desired outcome. In other cases, the user may like to keep the colorants<br>
- to only those set by SeparationColorNames. Toward that end, this commits adds<br>
- a -dLockColorants=true/false option for the tiffsep and psdcmyk devices to<br>
- ensure that the devices do not add on additional colorants as they are<br>
- encountered in the document.<br>
-<br>
-gs/devices/gdevpsd.c<br>
-gs/devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-20 09:51:50 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5135b9cd1a26332af64ff3a770103d8d8ad001a0">5135b9cd1a26332af64ff3a770103d8d8ad001a0</a>
-<blockquote>
-<p>
- Bug 695842: cope with no pread/pwrite available<br>
-<br>
- Older Unix and Linux systems for example.<br>
-<br>
- Without pread/pwrite we also disable multithreading support.<br>
-<br>
- No cluster differences<br>
-<br>
-config.mak.in<br>
-configure.ac<br>
-gs/Makefile.in<br>
-gs/base/gp_unifs.c<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-20 11:32:34 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=93ceb24e53ac62b5d6ac338dd8983e2e2a15eaad">93ceb24e53ac62b5d6ac338dd8983e2e2a15eaad</a>
-<blockquote>
-<p>
- Cope with systems with inttypes.h that doesn't define PRI..<br>
-<br>
- The PRI... macros for printf formatting aren't always available, so cope better with that.<br>
-<br>
- Solaris, for example.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/base/stdint_.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-20 11:30:26 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5c7b12b0bfd990329b6ecd009afbfc4f037e8b48">5c7b12b0bfd990329b6ecd009afbfc4f037e8b48</a>
-<blockquote>
-<p>
- Cope with systems without strnlen.<br>
-<br>
- We'll use strnlen in preference, but replace it with strlen if strnlen isn't available.<br>
-<br>
- An example would be Sun cc on Solaris.<br>
-<br>
- No cluster differences<br>
-<br>
-configure.ac<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-18 15:57: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=1e7626e4a9db58f9e5a531c04233bc8b04c52b1f">1e7626e4a9db58f9e5a531c04233bc8b04c52b1f</a>
-<blockquote>
-<p>
- Bug 695836: add flag for MINGW binary file opening<br>
-<br>
- MINGW, being a unix-like API on Windows, using the file handling gp_unifn.c,<br>
- but unlike &quot;real&quot; Unix systems, requires an extra flag for opening binary<br>
- files.<br>
-<br>
- Add that conditional on being built for MINGW<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gp_unifn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-16 10:13:58 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f27d8957a6afde54c0105fe6599b175b7ec46540">f27d8957a6afde54c0105fe6599b175b7ec46540</a>
-<blockquote>
-<p>
- Increase the linewidth used in idiom recognition of artificial bold text<br>
-<br>
- Bug #695835 &quot;Artificially emboldened fonts not showing up as bold in output PDF&quot;<br>
-<br>
- I believe this to be an Acrobat display bug, different versions of Acrobat<br>
- display the result differently, modifying the viewer preferences alters the<br>
- boldness significantly, and opening another file also alters the displayed<br>
- boldness.<br>
-<br>
- However, I've opted to increase the linewidth we are using slightly. This<br>
- results in a few single pixel differences in our output. At 600 dpi the<br>
- test file is slightly bolder, about 1 pixel worth.<br>
-<br>
- Comparison against the PostScript output is slightly complicated, because<br>
- the 'fill and stroke' results in slightly smoother output than the 'draw<br>
- the glyph 4 times' approach. However, there is little significant difference<br>
- as far as I can tell.<br>
-<br>
-gs/Resource/IdiomSet/Pscript5Idiom<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-12 17:09:40 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b3af6d5075a23cd6b5ef199e7680be8ab1045a6">7b3af6d5075a23cd6b5ef199e7680be8ab1045a6</a>
-<blockquote>
-<p>
- Fixes bug #695833 to correctly select the Line Printer font instead of<br>
- Courier.<br>
-<br>
- We need to have a LinePrinter font entry in the font table for each<br>
- symbol set supported by LinePrinter. We were missing an entry for the<br>
- PS text (10J) symbol set.<br>
-<br>
-pl/plftable.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-12 13:24:58 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4264a0716724dbd7fd8e35a53572e262658d5979">4264a0716724dbd7fd8e35a53572e262658d5979</a>
-<blockquote>
-<p>
- Fix error recovery after invalid type 1c (CFF) font<br>
-<br>
- Bug #695819 &quot;Ghostscript cannot process font stream&quot;<br>
-<br>
- The PDF file (which purports to have been produced by an earlier version<br>
- of Ghostscript) contains a CFF font which has en empty names index.<br>
-<br>
- Ghostscript, not unreasonably, treats this as being 'the first byte of the<br>
- name is 0x00' which indicates a font which has been deleted from the<br>
- FontSet. This means that the embedded FontSet contains no fonts.<br>
-<br>
- Since there are on fonts, we obviously can't use the font stream, and so<br>
- we enter an error recovery process. This exposes a problem specific to<br>
- this type of font, failing in this fashion, which left the operand stack<br>
- in a condition where we were unable to recover from the error.<br>
-<br>
- This commit detects the error condition at an earlier stage and prevents<br>
- the change to the operand stack, which allows the missing font to be<br>
- substituted, and the file runs to completion.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-10 10:30:53 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=40e783f0274ede8a5a15caf878bd18cad1bfa690">40e783f0274ede8a5a15caf878bd18cad1bfa690</a>
-<blockquote>
-<p>
- Fix for crash issue in -dUseFastColor<br>
-<br>
- The noncm link was storing the target device color mapping procs<br>
- and using those to map the colors. The problem is that some devices<br>
- (for example tiffsep) rely upon special device structures to<br>
- do the mapping. When we had a forwarding device like the overprint<br>
- device in front of the target, we were calling the target mapping<br>
- procs where we should be calling the overprint device mapping procs.<br>
- This commit fixes the issue.<br>
-<br>
-gs/base/gsicc_nocm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-09 11:04:27 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=14ea68e33fa129addf3860e3bf760060aa100ce3">14ea68e33fa129addf3860e3bf760060aa100ce3</a>
-<blockquote>
-<p>
- Fixes for named color replacement.<br>
-<br>
- The sample code for named color replacement had several issues<br>
- that this commits fixes.<br>
-<br>
- 1) The memory allocations were not being done in non-gc memory.<br>
- 2) There needed to be a release method to free the allocations<br>
- when we are done with the named color profile structure.<br>
- Since this is a &quot;custom&quot; profile, the release procedure for<br>
- a profile was added as a member variable to the profile structure.<br>
- 3) The decision to use the named color profile was moved earlier<br>
- in the ghostscript color remapping logic. The ensures we<br>
- have better control and avoid unwanted multiple remaps.<br>
-<br>
- Once the color is assigned values by the call to<br>
- gsicc_transform_named_color in gx_remap_named_color, note<br>
- that in gx_remap_concrete_devicen the transfer functions are applied.<br>
- Also note that in gx_remap_concrete_devicen we will end up doing<br>
- a possible ICC mapping of just the CMYK values from source CMYK to<br>
- destination CMYK via the call to devicen_icc_cmyk. The reason for<br>
- this is explained by the large comment in that part of the code.<br>
- If this remap is not desired, for example if gx_remap_named_color<br>
- assigned the CMYK values in the destination space already, then<br>
- this mapping should be disabled. The decision to enable or disable<br>
- is a design/customization decision of which the developer should be aware.<br>
-<br>
-gs/base/gscdevn.c<br>
-gs/base/gscms.h<br>
-gs/base/gscsepr.c<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gxcmap.c<br>
-gs/base/gxcspace.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-05 17:21:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=17131c7a7fdf9d8537c4715e538c49b29c8945a8">17131c7a7fdf9d8537c4715e538c49b29c8945a8</a>
-<blockquote>
-<p>
- Improve high level devices handling of Forms<br>
-<br>
- Bug #695805 &quot;PostScript can defeat the code to spot PostScript forms being run multiple times &quot;<br>
-<br>
- High level devices (eg pdfwrite) already check Forms to see if they are<br>
- duplicates, and if so use the initial definition. However, this does not<br>
- improve performance, since the Form PaintProc still needs to be executed<br>
- for each instance of the Form.<br>
-<br>
- This commit adds two new spec_op enums, and uses them to improve performance<br>
- as well, but *only* for high level devices.<br>
-<br>
- After running a PaintProc, the PostScript .execform1 procedure now sends a<br>
- spec_op to the device requesting an integer ID to store in the Form. If the<br>
- device does not do its own form caching it will return -1, in which case<br>
- the PostScript will not store the value.<br>
-<br>
- Each time a Form is executed, the PostScript code will look to see if we<br>
- have a non-null value stored for the Implementation key in the Form dictioanry.<br>
- If so, then we assume its a dictionary (ideally we should check, but this is<br>
- all tightly coupled code), pull the /FormID from it, and then send another<br>
- (different) spec_op to the device. On receipt of this the device simply<br>
- reuses its stored Form.<br>
-<br>
- This absolves us from running the PaintProc again, which on some files can<br>
- have significant performance benefits. It also means that even Forms which<br>
- execute pdfmarks (as the original file does) will be recognised as the same<br>
- form, which the duplicate removal code cannot achieve.<br>
-<br>
- The customer's test file runs in ~16 seconds now,producing a 4.3 Mb output<br>
- file, previously this produced an 81 Mb file and took around 20 minutes.<br>
-<br>
-gs/Resource/Init/gs_lev2.ps<br>
-gs/base/gsform1.h<br>
-gs/base/gxdevsop.h<br>
-gs/devices/vector/gdevpdfb.h<br>
-gs/devices/vector/gdevpdfi.c<br>
-gs/devices/vector/gdevpdfx.h<br>
-gs/psi/zform.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-23 09:48:50 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be26bcf588c1dff9f8a867f764bb46b0d6389081">be26bcf588c1dff9f8a867f764bb46b0d6389081</a>
-<blockquote>
-<p>
- Update URW fonts to Jan 2015 release.<br>
-<br>
- The families NimbusMono, NimbusRoman and NimbusSans have been augmented with<br>
- production quality Greek and Cyrillic glyphs. These correspond to our<br>
- substitutes for the PDF base 14 fonts<br>
-<br>
- Lots of minor pixel level cluster differences, and<br>
- sumatra/664_-_accented_characters_missing.PDF<br>
-<br>
- is progression with previously missing accented glyphs now printing<br>
-<br>
-gs/Resource/Font/BookmanURW-DemBol<br>
-gs/Resource/Font/BookmanURW-DemBolIta<br>
-gs/Resource/Font/BookmanURW-Lig<br>
-gs/Resource/Font/BookmanURW-LigIta<br>
-gs/Resource/Font/CenturySchL-Bold<br>
-gs/Resource/Font/CenturySchL-BoldItal<br>
-gs/Resource/Font/CenturySchL-Ital<br>
-gs/Resource/Font/CenturySchL-Roma<br>
-gs/Resource/Font/CenturySchURW-Bol<br>
-gs/Resource/Font/CenturySchURW-BolIta<br>
-gs/Resource/Font/CenturySchURW-Ita<br>
-gs/Resource/Font/CenturySchURW-Rom<br>
-gs/Resource/Font/ChanceryURW-MedIta<br>
-gs/Resource/Font/NimbusMon-Bol<br>
-gs/Resource/Font/NimbusMon-BolObl<br>
-gs/Resource/Font/NimbusMon-Obl<br>
-gs/Resource/Font/NimbusMon-Reg<br>
-gs/Resource/Font/NimbusMonL-Bold<br>
-gs/Resource/Font/NimbusMonL-BoldObli<br>
-gs/Resource/Font/NimbusMonL-Regu<br>
-gs/Resource/Font/NimbusMonL-ReguObli<br>
-gs/Resource/Font/NimbusRom-Ita<br>
-gs/Resource/Font/NimbusRom-Med<br>
-gs/Resource/Font/NimbusRom-MedIta<br>
-gs/Resource/Font/NimbusRom-Reg<br>
-gs/Resource/Font/NimbusRomNo9L-Medi<br>
-gs/Resource/Font/NimbusRomNo9L-MediItal<br>
-gs/Resource/Font/NimbusRomNo9L-Regu<br>
-gs/Resource/Font/NimbusRomNo9L-ReguItal<br>
-gs/Resource/Font/NimbusSan-Bol<br>
-gs/Resource/Font/NimbusSan-BolIta<br>
-gs/Resource/Font/NimbusSan-Ita<br>
-gs/Resource/Font/NimbusSan-Reg<br>
-gs/Resource/Font/NimbusSanL-Bold<br>
-gs/Resource/Font/NimbusSanL-BoldCond<br>
-gs/Resource/Font/NimbusSanL-BoldCondItal<br>
-gs/Resource/Font/NimbusSanL-BoldItal<br>
-gs/Resource/Font/NimbusSanL-Regu<br>
-gs/Resource/Font/NimbusSanL-ReguCond<br>
-gs/Resource/Font/NimbusSanL-ReguCondItal<br>
-gs/Resource/Font/NimbusSanL-ReguItal<br>
-gs/Resource/Font/NimbusSanNar-Bol<br>
-gs/Resource/Font/NimbusSanNar-BolIta<br>
-gs/Resource/Font/NimbusSanNar-Ita<br>
-gs/Resource/Font/NimbusSanNar-Reg<br>
-gs/Resource/Font/PalladioURW-Bol<br>
-gs/Resource/Font/PalladioURW-BolIta<br>
-gs/Resource/Font/PalladioURW-Ita<br>
-gs/Resource/Font/PalladioURW-Rom<br>
-gs/Resource/Font/URWBookmanL-DemiBold<br>
-gs/Resource/Font/URWBookmanL-DemiBoldItal<br>
-gs/Resource/Font/URWBookmanL-Ligh<br>
-gs/Resource/Font/URWBookmanL-LighItal<br>
-gs/Resource/Font/URWChanceryL-MediItal<br>
-gs/Resource/Font/URWGothic-Boo<br>
-gs/Resource/Font/URWGothic-BooObl<br>
-gs/Resource/Font/URWGothic-Dem<br>
-gs/Resource/Font/URWGothic-DemObl<br>
-gs/Resource/Font/URWGothicL-Book<br>
-gs/Resource/Font/URWGothicL-BookObli<br>
-gs/Resource/Font/URWGothicL-Demi<br>
-gs/Resource/Font/URWGothicL-DemiObli<br>
-gs/Resource/Font/URWPalladioL-Bold<br>
-gs/Resource/Font/URWPalladioL-BoldItal<br>
-gs/Resource/Font/URWPalladioL-Ital<br>
-gs/Resource/Font/URWPalladioL-Roma<br>
-gs/Resource/Init/Fontmap.GS<br>
-gs/psi/psromfs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-03 16:05: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=af9d47bf4ed5ebe42c1b2592a607bd891cd1dd92">af9d47bf4ed5ebe42c1b2592a607bd891cd1dd92</a>
-<blockquote>
-<p>
- Bug 695787: skip WOFF fonts in font scanning<br>
-<br>
- As Ghostscript doesn't support WOFF fonts, skip them during the building of the<br>
- &quot;native&quot; fonts table - this prevents the pseudo-parsing from consuming large<br>
- amounts of memory and processor time pointlessly.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_fonts.ps<br>
-gs/Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-02 13:31:32 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8803294d1768a74a2ca3a1acc97f7def74752791">8803294d1768a74a2ca3a1acc97f7def74752791</a>
-<blockquote>
-<p>
- commit 23aab341f57c20974e4dfcb68abb13ce08c5e5a8 actually committed the wrong<br>
- code by accident, ooops!<br>
-<br>
- This is the corrected test for a type 2 font being used. The comments in<br>
- the previous commit still apply, this isn't a 'fix' just a work-around to<br>
- avoid a crash.<br>
-<br>
-gs/devices/vector/gdevpdtc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-02-02 11:52:49 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23aab341f57c20974e4dfcb68abb13ce08c5e5a8">23aab341f57c20974e4dfcb68abb13ce08c5e5a8</a>
-<blockquote>
-<p>
- Noticed by chrisl while working on moving our installed base fonts to<br>
- CFF, if a type 0 font has an FDepVector which uses both a type 3 font, and<br>
- a base font (which is CFF) then we fail to process the condition where<br>
- we use one glyph from the type 3 and follow it with a glyph from the<br>
- type 2.<br>
-<br>
- The problem seems to be that we get confused, we detect the error with the<br>
- CFF font, but instead of capturing it as a bitmap (fallback case) we end<br>
- up dealing with it as if we had started capturing a type 3 charproc. Of<br>
- course we didn't start capturing it that way, so that causes chaos.<br>
-<br>
- In the long run this will need to be fixed properly (ie figure out why we<br>
- are ending the glyph with the current font being type 3, when it should be<br>
- type 2), but for now this prevents the GPF. When/if we do move to CFF fonts<br>
- for our base fonts, this will need to be revisited.<br>
-<br>
-gs/devices/vector/gdevpdtc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-29 17:33:48 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3af4b00ad39d7c3672f3967512d81b1f8ecf6bac">3af4b00ad39d7c3672f3967512d81b1f8ecf6bac</a>
-<blockquote>
-<p>
- Fix some (probably not all) dependencies when the build has minimal devices.<br>
-<br>
- The lib.mak was missing some dependencies, and pdf_main.ps depended on the<br>
- .pdfputparams which is only defined if the pdfwrite device is built in.<br>
- Tested with a build from: autogen.sh --with-drivers=ppmraw,pgmraw,pbmraw<br>
- which only has bbox and those devices.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-30 10:43: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=47178da0d32b82a40b75f9aa9684210ff4dc1d24">47178da0d32b82a40b75f9aa9684210ff4dc1d24</a>
-<blockquote>
-<p>
- Remove the reference to -dLanguageLevel=1 in the man page.<br>
-<br>
- Also remove the incorrect nonsense about language level 3 and so on, which<br>
- has never been correct, and some general tidying up. Also point out that,<br>
- despite the name of the scripts, PDF is an equally acceptable input.<br>
-<br>
- Update the versions and dates and so on to reflect the edit.<br>
-<br>
-gs/man/ps2ps.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-28 08:34:08 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=704fcded8bb82dcbfad512ee8eec80e1d5655ded">704fcded8bb82dcbfad512ee8eec80e1d5655ded</a>
-<blockquote>
-<p>
- Fix miscalculation of pattern size when 'has_tags' is true.<br>
-<br>
- This fix was developed for customer 532 who uses tags. The 'has_tags'<br>
- passed in to gx_pattern_size_estimate is a boolean, so we should adjust<br>
- size for the extra tag byte, not the value (which doesn't have to be 1).<br>
-<br>
-gs/base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-23 17:32:36 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8c015519af0f14ada59399a96d0f4ffc3c9e5ccd">8c015519af0f14ada59399a96d0f4ffc3c9e5ccd</a>
-<blockquote>
-<p>
- Fix some debug statements that used NULL mem pointers.<br>
-<br>
-gs/base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-22 08:35:39 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c8cf49712712f288d5b956f36ecb285a39a2b134">c8cf49712712f288d5b956f36ecb285a39a2b134</a>
-<blockquote>
-<p>
- Fix emprintf problem with previous commit<br>
-<br>
-gs/devices/gdevplib.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-21 13:41:35 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cad213c2d188e7461322ee6f810684bea5358235">cad213c2d188e7461322ee6f810684bea5358235</a>
-<blockquote>
-<p>
- Fix BandHeight and segfault problems with plib device.<br>
-<br>
- The BandHeight will be 0 initially to convey &quot;set it automatically<br>
- if it isn't set on the command line. Only check once it has been<br>
- set.<br>
-<br>
- Once past this a segfault was occurring because the mdev-&gt;line_ptrs<br>
- never was set. This seems to have been broken by commit c4357bef<br>
- caused by passing &quot;mlines&quot; into the device's setup_buf_device<br>
- rather than NULL in the call from clist_rasterize_lines (which<br>
- did fix another segfault).<br>
-<br>
- Since regression doesn't test this device, I don't expect any<br>
- differences.<br>
-<br>
-gs/devices/gdevplib.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-20 16:01:07 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f38db629f962a599693e13b572eef9ee64412800">f38db629f962a599693e13b572eef9ee64412800</a>
-<blockquote>
-<p>
- Add the plib device family to build on Unix.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/configure.ac<br>
-gs/devices/gdevplib.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-19 11:19:08 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d9083d4f20d53eda3ae129cd35d1947144db743">4d9083d4f20d53eda3ae129cd35d1947144db743</a>
-<blockquote>
-<p>
- Commit the automake/autoconf/libtool derived files<br>
-<br>
- For ijs the build is not expected to change, and if it does, it will be very<br>
- infrequent. So keeping the derived files in source control simplifies things.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/ijs/Makefile.in<br>
-gs/ijs/compile<br>
-gs/ijs/config.guess<br>
-gs/ijs/config.sub<br>
-gs/ijs/configure<br>
-gs/ijs/install-sh<br>
-gs/ijs/libtool<br>
-gs/ijs/ltmain.sh<br>
-gs/ijs/missing<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-19 11:15: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=c09cc83e53c9a1269e0c64fea94d9ceeafa9a494">c09cc83e53c9a1269e0c64fea94d9ceeafa9a494</a>
-<blockquote>
-<p>
- Remove automake version specific tests/use<br>
-<br>
- The script does unpleasant things which can cause us to attempt to use a<br>
- specific version of automake, which should not really be needed these days.<br>
-<br>
- So we now just check that the automake version is greater than or equal to the<br>
- version we require.<br>
-<br>
- The old method can still be accessed by invoking autogen.sh thus:<br>
- USE_OLD=yes ./autogen.sh<br>
-<br>
- Also, reset the the minimum automake version to 1.6.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/ijs/autogen.sh<br>
-gs/ijs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-21 22:34: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=b2d6985a0fdc20c9775e3caa2f90af039cc5e2f5">b2d6985a0fdc20c9775e3caa2f90af039cc5e2f5</a>
-<blockquote>
-<p>
- Remove spurious debug code.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_type1.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-21 22:08: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=da65b995be88cfcbef7c99dbae1d15f5eb14122d">da65b995be88cfcbef7c99dbae1d15f5eb14122d</a>
-<blockquote>
-<p>
- Bug 695794: fix invalidaccess with some Type 1 fonts<br>
-<br>
- Use superexec to execute the .growput to enter the flag into the font dictionary<br>
- that indicates we've already applied the glyph mapping augmentation. Handles<br>
- the case that the font dictionary already readonly.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_type1.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-20 09:22:31 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=38501651d81ae41f6505e7f457f46a975648c63a">38501651d81ae41f6505e7f457f46a975648c63a</a>
-<blockquote>
-<p>
- Fix C stack overflow with psdcmykog.<br>
-<br>
- The commit fe0b8fcf increased the gp_filename_sizeof to 4096, and<br>
- this increased the stack usage for cmykog_process_arg_t by enough<br>
- to cause stack overflow on Windows.<br>
-<br>
-gs/devices/gdevcmykog.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-20 09:00:31 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a8a479e6104a509de49b0d10d8aae6cc4cd4809a">a8a479e6104a509de49b0d10d8aae6cc4cd4809a</a>
-<blockquote>
-<p>
- Clean up gx_pattern_size_estimate to clamp at max_int<br>
-<br>
- When the pattern had transparency, we had conditional assignment to<br>
- limit at (max_int * ~0xFFFF), but not otherwise. No known defect.<br>
-<br>
-gs/base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-19 09:15:47 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2cc3a1779d832fc84b36f0ebb20336bbdad17352">2cc3a1779d832fc84b36f0ebb20336bbdad17352</a>
-<blockquote>
-<p>
- Bug 695774: Fallback for glyph with degenerate bbox<br>
-<br>
- If a glyph has only one very narrow feature, the bbox can end up with either<br>
- the width or height of the bbox being 0, in which case no raster memory is<br>
- allocated and no attempt is made to render the glyph. This is less than ideal<br>
- when the drop-out compensation in the rendering code would actually result in<br>
- the glyph being rendered.<br>
-<br>
- Normally the coordinates for the bbox are rounded (which is technically<br>
- correct). Now, if that results in the width or height being 0, we'll<br>
- then try explicitly rounding up/down, providing a sort of naive whole glyph<br>
- drop-out compensation.<br>
-<br>
- The same change has been included upstream and will be in the next scheduled<br>
- Freetype release:<br>
- http://git.savannah.gnu.org/cgit/freetype/freetype2.git/commit/?id=942aa5ff<br>
-<br>
- This causes a large number of low resolution differences on cluster, all<br>
- progressions where glyphs like dash ('-'), underscore ('_') and vertical<br>
- bar ('|') were dropping out entirely, and are now printing.<br>
-<br>
-gs/freetype/src/raster/ftrend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-17 10:58: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=2c14b47453cc4c4bc6d6a97af073ae0145f107dd">2c14b47453cc4c4bc6d6a97af073ae0145f107dd</a>
-<blockquote>
-<p>
- txtwrite - properly terminate 'char' tags<br>
-<br>
- Bug #695788 &quot;txtwrite textoutput=0 XML file&quot;<br>
-<br>
- The 'char' tag was being terminated with a '&gt;' instead of a '/&gt;'.<br>
-<br>
- Reported, and the offending code isolated, by Petko Lukov, who offered to<br>
- create a patch, but the change is so trivial I simply went ahead with it.<br>
-<br>
- No differences expected, cluster doesn't test txtwrite.<br>
-<br>
-gs/devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-17 09:01:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8a72aff8e6f1009cce8cf0ed535baf3d6c362fb4">8a72aff8e6f1009cce8cf0ed535baf3d6c362fb4</a>
-<blockquote>
-<p>
- Slience a (benign) compiler warning about missing return<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/dxmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-16 10:27:51 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7882030e49b1309c6d8ccc96b799c8eddb0cc10d">7882030e49b1309c6d8ccc96b799c8eddb0cc10d</a>
-<blockquote>
-<p>
- Improve error message when required OutputFile not specified.<br>
-<br>
- Bug 695767. Also improve the formatting when there was a filename<br>
- by adding ' around the filename,<br>
-<br>
-gs/base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-16 15:26:56 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=66eafeeec0288a96dde38ecb406961c869ce06e4">66eafeeec0288a96dde38ecb406961c869ce06e4</a>
-<blockquote>
-<p>
- Move bbox.dev to be immediately after the x11 devs<br>
-<br>
- So that in pcl and xps on Unix, if we aren't including the x11 devices, we'll<br>
- default to bbox.<br>
-<br>
- No cluster differences<br>
-<br>
-main/pcl6_gcc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-16 15:18: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=d1ef180b6cad83dde54843e028accb22222e6f39">d1ef180b6cad83dde54843e028accb22222e6f39</a>
-<blockquote>
-<p>
- Explicitly check for both libcups and libcupsimage<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-16 09:40:27 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6e1e22c7643ee2e0b28a702a3ed9fc5b8f3a96b0">6e1e22c7643ee2e0b28a702a3ed9fc5b8f3a96b0</a>
-<blockquote>
-<p>
- NTFS - fix some memory problems Bug 695752<br>
-<br>
- Bug #695752 &quot;gp_enumerate_files_close leaks some memory&quot;<br>
-<br>
- This appears to be a simple oversight in the original commit, a piece of<br>
- allocated memory was not freed, the 'free' call was commented out.<br>
-<br>
- Noticed in passing; if the allocation of the file pattern fails, we were not<br>
- freeing the file or directory enumerators, leading to a memory leak as<br>
- well.<br>
-<br>
- No differences expected (cluster does not test Windows file system)<br>
-<br>
-gs/base/gp_ntfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-15 16:16:59 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d9168fef51ff878e58834b38d620f4afc9fa66c2">d9168fef51ff878e58834b38d620f4afc9fa66c2</a>
-<blockquote>
-<p>
- pdfwrite - fix compiler warning<br>
-<br>
- The compiler complained that pres could be NULL. In fact it should never be,<br>
- it *should* be the same as pres1, but we ought to be dereferencing pres1 here<br>
- anyway, not pres, so we make that change, just in case.<br>
-<br>
-gs/devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-14 10:51:21 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=65b46878adabda061b67670dfd81899acca2cea1">65b46878adabda061b67670dfd81899acca2cea1</a>
-<blockquote>
-<p>
- Fix warnings from f02d0a5<br>
-<br>
- For some reason no warnings came up during the cluster push. Thanks<br>
- to those who fixed a couple. Hopefully this fixes the rest.<br>
-<br>
-gs/base/gximdecode.c<br>
-gs/devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-13 12:31:40 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=48eb76b5b774772e39b0a163a9a3c1d06eafbdd4">48eb76b5b774772e39b0a163a9a3c1d06eafbdd4</a>
-<blockquote>
-<p>
- Allow Orientation pagedevice parameter to control the FitPage rotation<br>
-<br>
- With this change, Orientation is no longer ignored except for devices<br>
- that support pdfmark where it must be 0 (e.g., pdfwrite). Now with<br>
- -dFitPage, -c &quot;&lt;&lt; /Orientation 0 &gt;&gt; setpagedevice&quot; will use either 0<br>
- or 90 degree rotation, while -c &quot;&lt;&lt; /Orientation 2 &gt;&gt; setpagedevice&quot;<br>
- will rotate either 180 degrees or 270 degrees.<br>
-<br>
- Note that Orientation 2 will invert a page (rotate by 180) if 270<br>
- degree rotation is not needed for the best fit.<br>
-<br>
- Orientation will also control which way is &quot;up&quot; without -dFitPage,<br>
- but may result in clipping.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-14 15:01:24 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6213ab0b0c3229f1744e404e0d673d36f62bd6cd">6213ab0b0c3229f1744e404e0d673d36f62bd6cd</a>
-<blockquote>
-<p>
- Treat a couple of compiler warnings as errors.<br>
-<br>
- Treat declaration-after-statement and return-type warnings as errors when<br>
- building with gcc.<br>
-<br>
- No cluster differences.<br>
-<br>
-configure.ac<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-14 15:01: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=d18f698b8e7176653d096b2e554eeff713be4182">d18f698b8e7176653d096b2e554eeff713be4182</a>
-<blockquote>
-<p>
- Fix a missing return type for a function.<br>
-<br>
-gs/devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-14 13:21:54 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d7bffde12e3b9856e271af3b50254fd93d98b3d3">d7bffde12e3b9856e271af3b50254fd93d98b3d3</a>
-<blockquote>
-<p>
- Fix 'warning: ISO C90 forbids mixed declarations and code'<br>
-<br>
- Commit f02d0a5 added code which declares variables in the body of a<br>
- function. This is not permitted in C90 (or C89), is contrary to the coding<br>
- style for Ghostscript and fails to compile Ghostscript under Visual Studio.<br>
-<br>
- In addition 'zip_close_all_archive_files()' did not have a return value on<br>
- success which led to random return values and a number of regression files<br>
- failing.<br>
-<br>
- Moved the variables to the start of the functions (removing const as required)<br>
- and added a specific return code on success.<br>
-<br>
- Now compiles under Windows, does not throw as many warnings on Linux and<br>
- does not cause spurious regression failures. There are still many warnings<br>
- produced by gcc, EG:<br>
-<br>
- ./devices/vector/gdevxps.c:1771:9: warning: unused variable 'count' [-Wunused-variable]<br>
- ./devices/vector/gdevxps.c:1770:9: warning: unused variable 'code' [-Wunused-variable]<br>
-<br>
- The author of the commit should address those separately.<br>
-<br>
-gs/base/gximdecode.c<br>
-gs/devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-15 12:15:14 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f02d0a5067a0970aa5e9c6b4f9cd08956485447e">f02d0a5067a0970aa5e9c6b4f9cd08956485447e</a>
-<blockquote>
-<p>
- Add support for encoded source images with xpswrite device. Fix for bug 695698<br>
-<br>
- Also fixes 695754 and 695680.<br>
-<br>
- The xps format does not allow for the image data encodings that PDF source files can<br>
- create. Hence we have to decode the data prior to writing out to our TIFF file.<br>
- The clist image code had static methods for doing the decode during color monitoring. These<br>
- methods were re-factored to work on a new structure that are now member variables for<br>
- the xpswrite image enum structure and the clist image enum structure. The methods and<br>
- the structure definition were placed in their own file gximdecode.c/h<br>
-<br>
- Also this adds support for images in indexed, CIELAB, DeviceN and separation color spaces.<br>
-<br>
- Finally, images are stored in a temp file during creation and then copied into the zip<br>
- archived, releasing the image temp file. ICC profiles are written directly from memory<br>
- to the zip file. This avoids having lots of temp files around for each image that is<br>
- created. A similar process needs to be done for other parts of the xps document. With the<br>
- current architecture of having a temp file open for every &quot;file&quot; in the package we would<br>
- not be able to create something larger than 512 pages on windows due to the limit on<br>
- the number of open files.<br>
-<br>
-gs/base/gxclimag.c<br>
-gs/base/gximdecode.c<br>
-gs/base/gximdecode.h<br>
-gs/base/lib.mak<br>
-gs/devices/devs.mak<br>
-gs/devices/vector/gdevxps.c<br>
-gs/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-13 11:19:53 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3e7115492c378ffa324c0a083244a785a6a61f82">3e7115492c378ffa324c0a083244a785a6a61f82</a>
-<blockquote>
-<p>
- pdfwrite - optimise pdf_foget_resource with CharProc resources<br>
-<br>
- Bug #695778 &quot;Long delay converting .ps file to .pdf file&quot;<br>
-<br>
- The specimen file uses glyphshow to draw a huge number of 'characters',<br>
- these turn out to be bitmaps which, taken together create the page. Each<br>
- page defines and at the end specifically undefines a type 3 font and the<br>
- glyphs are stored in this font.<br>
-<br>
- Since PDF has no equivalent to glypshow we store the glyphs in multiple<br>
- type 3 fonts, resulting in around 10 times as many fonts. The creation and<br>
- storage of the fonts and glyphs is quite slow.<br>
-<br>
- However, we start off unaware that this is a glyphshow operation, so we<br>
- start by attempting to capture the type 3 CharProc. Its not until we get<br>
- to the actual capture of the bitmap that we discover we cannot handle the<br>
- glyph like this. That means we have to discard the CharProc we had begun,<br>
- and remove it from the list of stored resources.<br>
-<br>
- Now resources are stored in 'chains' which is a simple way of limiting the<br>
- number of searches. We hash on the resource ID and pick the chain based on<br>
- that.<br>
-<br>
- The first problem was that pdf_forget_resource was not using the hash, it<br>
- was checking every entry in every chain, in effect checking all the entries<br>
- of a given resource type. Even if it found a match, it continued checking<br>
- the remaining chains! As the number of stored CharProcs (we still store<br>
- the glyphs as CharProcs, but in a different font) increases, the time taken<br>
- to exhaustively check all the glyphs increases.<br>
-<br>
- Here we fix that by starting from the correct chain based on the hash of<br>
- the id (if its 0 we start at the first chain, so if we haven't allocated an<br>
- ID we check all the entries). When we find a match we return immediately<br>
- instead of merely exiting the *inner* loop.<br>
-<br>
- The second problem is that we don't allocate an ID for CharProcs initially.<br>
- This is fixed by storing the ID which we used temporarily as an argument<br>
- to pdf_enter_substream.<br>
-<br>
- Taken together these speed up this file by a factor of ~8.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfu.c<br>
-gs/devices/vector/gdevpdti.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-13 09:28: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=7d97b54d767627d1d88ea026c3d3accd11cb670f">7d97b54d767627d1d88ea026c3d3accd11cb670f</a>
-<blockquote>
-<p>
- Bug 695783: correct cups return of string parameters<br>
-<br>
- The cups device was using param_string_from_string() to return string parameters<br>
- allocated in the device structure in its get_params method. Of the many problems<br>
- this could cause, it came to light due to the same parameter being sent through<br>
- put_params thus causing strncpy() to attempt to copy a string to itself, causing<br>
- a segfault.<br>
-<br>
- Changing to the correct param_string_from_transient_string() way to return such<br>
- strings resolves the problem.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-12 11:10: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=f29420b18ba7abedb649d0352fb1b16adae1d4a5">f29420b18ba7abedb649d0352fb1b16adae1d4a5</a>
-<blockquote>
-<p>
- Bug 695743: LCMS: Fix a macro clash on SNONE<br>
-<br>
- Partial patch pulled from Marti's github repo:<br>
- https://github.com/mm2/Little-CMS/commit/5bc4f52f<br>
-<br>
- (only the macro clash fix).<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/lcms2/src/cmscgats.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-12 09:56: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=84d749a65e509c31805a8f99d1aad78c013f13e6">84d749a65e509c31805a8f99d1aad78c013f13e6</a>
-<blockquote>
-<p>
- Bug 695764: allow compiler to be overridden<br>
-<br>
- Allow the C compiler to set by the configure script.<br>
-<br>
- No cluster differences.<br>
-<br>
-common/gccdefs.mak<br>
-config.mak.in<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-12 08:44:46 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e17fcc029c96949982b8f01c6e649b87dceab1be">e17fcc029c96949982b8f01c6e649b87dceab1be</a>
-<blockquote>
-<p>
- Bug 695772: account for clist icc_table being shared<br>
-<br>
- When multi-thread rendering is used (but not background printing), the icc_table<br>
- is shared between all the render thread devices and the 'parent' device in the<br>
- interpreter thread - but it is not reference counted. We rely on the fact that<br>
- the device in the interpreter thread will exist before, and persist past the<br>
- death of the rendering threads.<br>
-<br>
- So, when dismantling a rendering thread device, null the icc_table entry so<br>
- it doesn't get erroneously freed.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-09 11:25: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=30abb3d5d5fbf9cf67d4ff691e898c8b29e39a56">30abb3d5d5fbf9cf67d4ff691e898c8b29e39a56</a>
-<blockquote>
-<p>
- Add automake option to make dist &quot;self contained&quot;<br>
-<br>
- The automake default is to symlink to a few scripts ('compile', 'missing' etc)<br>
- in the current system's automake install. That results in a configuration<br>
- reliant on automake being installed, and the same version, for a build.<br>
-<br>
- Add the '--copy' automake option so the script files are copied rather than<br>
- linked, so we get a self contained configure/make/install setup.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/ijs/autogen.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-09 11:23:34 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9961f351a3c71949da49eb75b65560028fb8272e">9961f351a3c71949da49eb75b65560028fb8272e</a>
-<blockquote>
-<p>
- Bug 695148: remove spec PDF and PS from clean list<br>
-<br>
- As the IJS spec hasn't changed in ages, we'll just keep the PDF and PS files<br>
- of the spec in git, so no need to remove them with a &quot;make clean&quot;.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/ijs/Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-07 07:57:36 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d78594c1982682a06c9fb8fc7f2ea746938a93cc">d78594c1982682a06c9fb8fc7f2ea746938a93cc</a>
-<blockquote>
-<p>
- Fix problem in xps_zip_alloc_items caused by previous commit: 188c7b0<br>
-<br>
- When the allocation succeeded, nothing was returned.<br>
-<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-03 16:00:16 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=188c7b05a5c232ba43e6b3172023498f7aa72c70">188c7b05a5c232ba43e6b3172023498f7aa72c70</a>
-<blockquote>
-<p>
- Fix segfault with ppmraw -r300 from fts_06_0626.pdf.xpse when allocation fails<br>
-<br>
- The gxps had numerous places where allocation failures were ignored,<br>
- writing to RAM at offsets from 0 (NULL). This no longer fails, but the<br>
- fixes are not yet complete. Running a memento build with the parameters:<br>
- MEMENTO_SQUEEZEAT=1 gxps -o /dev/null -sDEVICE=ppmraw in.xps<br>
-<br>
-xps/xpsdoc.c<br>
-xps/xpsfont.c<br>
-xps/xpsgradient.c<br>
-xps/xpshash.c<br>
-xps/xpsimage.c<br>
-xps/xpsjpeg.c<br>
-xps/xpsjxr.c<br>
-xps/xpspath.c<br>
-xps/xpspng.c<br>
-xps/xpsresource.c<br>
-xps/xpstiff.c<br>
-xps/xpsxml.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2015-01-02 22:48:56 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f553eec30efa8cbefdc3c3635e090abb915a1a9d">f553eec30efa8cbefdc3c3635e090abb915a1a9d</a>
-<blockquote>
-<p>
- Fix bug 695373: xpswrite leaves temp files on Windows.<br>
-<br>
- There is a recent addidtion of a gp function to open a temp file that<br>
- will be deleted upon close: 'gp_open_scratch_file_rm'. The method of<br>
- 'unlink' after open does not work on Windows. This function is platform<br>
- specific and works on all supported platforms even if the process crashes.<br>
-<br>
- Also get rid of confusing error messages. PageSpotColors is now only<br>
- given to devices that support it (pdf_main.ps) and NumRenderingThreads<br>
- and BGPrint are ignored for vector devices (gdevvec.c).<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/base/gdevvec.c<br>
-gs/devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-11-24 11:13:33 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=64f9cafcfc594ddaa1d1981a16f45fce25e4fb18">64f9cafcfc594ddaa1d1981a16f45fce25e4fb18</a>
-<blockquote>
-<p>
- Fix BGPrint=true SEGV and slowdown due to commit 9108db2<br>
-<br>
- Bug 695669:<br>
- The BGPrint problem was due to using the fname afer freeing it but the<br>
- 'fake_path_to_file' logic needed the fname in order to find the real<br>
- file to close.<br>
-<br>
- Tail of commit 6ecc8536:<br>
- Also the original cfname and bfname (ocfname and obfname) were copied<br>
- using strnlen so the trailing NULL wasn't copied resulting in UMR being<br>
- used for the close/delete.<br>
-<br>
- Tail of bug 693121:<br>
- The performance of unbuffered I/O is slow, seen on many files, but<br>
- a good example is: tests/df/Bug6901014_Fourth_crash_signature_testcase.pdf<br>
- with params: -sDEVICE=pbmraw -o /dev/null -r300 -dMaxBitmap=0<br>
-<br>
- The fix for this is to add a read cache. This caching method in intended<br>
- to also be used by the memory based clist logic (TBI).<br>
-<br>
- With the cache, the performance on the above goes from 40 seconds down to<br>
- 4.6 seconds, and with -dBGPrint=true reduces to 3.8 seconds (which crashes<br>
- prior to this fix).<br>
-<br>
-gs/base/gdevprn.c<br>
-gs/base/gxclfile.c<br>
-gs/base/gxclist.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-30 09:18:31 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7631204934e5d8b0bcdb13d8691370365eb84b2b">7631204934e5d8b0bcdb13d8691370365eb84b2b</a>
-<blockquote>
-<p>
- Add directory entry configuration support to fix a broken ghostpdl<br>
- build after a Mac upgrade to Yosemite.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-23 16:01:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=35bb14eaf871b6a7e41e17688bcc41a1fb4da595">35bb14eaf871b6a7e41e17688bcc41a1fb4da595</a>
-<blockquote>
-<p>
- pdfwrite - add 'Launch' Actions<br>
-<br>
- Bug #695715 &quot;Launch action link annotations removed after GS processing&quot;<br>
-<br>
- Add Launch actions to the PDF interpreter, for both annotations and<br>
- outlines.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-23 13:53:27 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fde4b9b183a140b8906874d0bf56d258b488d4b9">fde4b9b183a140b8906874d0bf56d258b488d4b9</a>
-<blockquote>
-<p>
- pdfwrite - free copied base fonts on exit<br>
-<br>
- Bug #695753 &quot;Segfault in gs_purge_font_from_char_caches_forced with -Z@&quot;<br>
-<br>
- The problem here is that we free copied fonts when we free the associated<br>
- FontDescriptor (because until then we need the copied font). However, if<br>
- we have a 'base 14' font, or other font which is not embedded, we do not<br>
- create a FontDescriptor, and so never free the font copy we take when the<br>
- font is used.<br>
-<br>
- This later causes a problem because when the garbage collector frees this<br>
- font copy it is still pointing to a font cache which no longer exists.<br>
-<br>
- This commit tests to see if a FontDescriptor is associated with a font when<br>
- we free the (PDF) font. If it is not then we free the copied font there and<br>
- then, as well as the ancillary bytes used for the font name etc.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdtf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-23 13:08: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=bd2e9c2c30b0696ca9f929637193aaef38951e6a">bd2e9c2c30b0696ca9f929637193aaef38951e6a</a>
-<blockquote>
-<p>
- follow up to commit dc2c3634aeae6634b130e124b1f0997f17ee3141<br>
-<br>
- Separate GoTo and GoToR processing for links as well as Outlines<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-22 11:29:49 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=01b9c47eefd7f88195e71f877e5ea44f183a0067">01b9c47eefd7f88195e71f877e5ea44f183a0067</a>
-<blockquote>
-<p>
- pdfwrite - when writing Names array use better method to find /Last<br>
-<br>
- Bug #695704 &quot;GS 9.15 (still) breaks *something* in hyperref-generated pdf BOOKMARKS&quot;<br>
-<br>
- The find_last_dict_entry code should have returned the same results as for<br>
- find_next_dict_entry, but it clearly didn't, resulting in effective<br>
- truncation of the Names array.<br>
-<br>
- Simplified the code here by using find_next_dict_entry in a loop to locate<br>
- the last entry. This should mean we cannot be out of sync, the code is simpler<br>
- and easier to follow.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-22 10:47:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc2c3634aeae6634b130e124b1f0997f17ee3141">dc2c3634aeae6634b130e124b1f0997f17ee3141</a>
-<blockquote>
-<p>
- pdfwrite - separate GoTo and GoToR processing<br>
-<br>
- Because we convert any named destination in a GoTo to a specific internal<br>
- destination, we cannot handle GoTo and GoToR in the same way. Here we<br>
- split the two again, and this time add a comment so we don't end up merging<br>
- them again by mistake.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-20 10:57:39 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c525aa076d7094fa487621602b8e326c58eeabe">2c525aa076d7094fa487621602b8e326c58eeabe</a>
-<blockquote>
-<p>
- pdfwrite - improve Goto and GoToR handling<br>
-<br>
- Bug #695747 &quot;git produces broken pdf from pdfTeX output&quot;<br>
-<br>
- The original code for generating pdfmarks from the equivalent annotations<br>
- in a PDF file did not properly create an Action dictionary, which caused<br>
- /D and /Dest entries to be removed.<br>
-<br>
- Here we handle this more cleanly, and properly create the Action dictionary<br>
-<br>
- NB for ps2write this relies upon commit b5a4f24141ab47b5ba2b7b3dff938ba30a8a908a<br>
- being present, in order to deal with the empty objects produced by ps2write.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-20 10:53:28 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5a4f24141ab47b5ba2b7b3dff938ba30a8a908a">b5a4f24141ab47b5ba2b7b3dff938ba30a8a908a</a>
-<blockquote>
-<p>
- ps2write - handle empty object definitions<br>
-<br>
- object definitions such as:<br>
-<br>
- 5 0 obj<br>
- endobj<br>
-<br>
- cause errors. Handle this by checking in /endobj to see if the stack count<br>
- is 1 (only the object number is present) and if so, do not attempt to<br>
- define the object.<br>
-<br>
-gs/devices/vector/opdfread.h<br>
-gs/lib/opdfread.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-19 13:10:03 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7df6f9570c00c34a3e1d6c74d66186a371208f0e">7df6f9570c00c34a3e1d6c74d66186a371208f0e</a>
-<blockquote>
-<p>
- Integrate Ken Sharp's solution to preserve PCL transparent text in<br>
- pdfwrite to fix bug #695731.<br>
-<br>
- PCL characters are rendered transparently when the current color is<br>
- white and pattern transparency is on. Usually this is done by simply<br>
- not printing or rendering the effected text. For high level devices<br>
- like pdfwrite we try to preserve the original intent of the source<br>
- document and include the text and transparency setting in the output.<br>
-<br>
-pcl/pcl.mak<br>
-pcl/pctext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-19 15:31:24 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b3669dbcd3d29cd212e9961fcfc7b98780aa408">9b3669dbcd3d29cd212e9961fcfc7b98780aa408</a>
-<blockquote>
-<p>
- Add link to description of &quot;Vienna&quot; naming style<br>
-<br>
- After a discussion on IRC: a summary of the &quot;Vienna naming style&quot; is actually<br>
- later in the document, this just adds a link between the early reference and<br>
- the fuller summary.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/doc/Ps-style.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-18 17:12: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=09def28ae012fc0e1b4f65ea55b19639c7737bc9">09def28ae012fc0e1b4f65ea55b19639c7737bc9</a>
-<blockquote>
-<p>
- Bug 695750: fix icc link cache leak when freeing clist devices<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-11-24 22:47:15 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ddbec6f11792e2fa974c95924a984f876a9a705">5ddbec6f11792e2fa974c95924a984f876a9a705</a>
-<blockquote>
-<p>
- Simplify rectangle output to be vertical and horizontal lines instead<br>
- of general lines.<br>
-<br>
- The vertical and horizontal line commands take 1 argument resulting in<br>
- more compact XPS and we'd expect it to be faster when rendered.<br>
-<br>
-gs/devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-18 11:35: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=8e196062593b295421b869db9d5cd9ab22f7205e">8e196062593b295421b869db9d5cd9ab22f7205e</a>
-<blockquote>
-<p>
- pdfwrite - some changes to text handling for Tr 3<br>
-<br>
- Bug #695731 &quot;PCL interpreter doesn't send text to the graphics library if its not visible.&quot;<br>
-<br>
- Altering the PCL interpreter to set the Text rendering mode to 3 for<br>
- 'invisible' text demonstrated a few problems in pdfwrite.<br>
-<br>
- 1) If the last character drawn was in Tr 3, and we buffer some new text in<br>
- Tr mode 0, but we are inside a gsave, and the outer state is Tr 0, then when<br>
- we restore back to the Tr 0 the mode is not emitted for the buffered text. Leaving<br>
- it as Tr mode 3. To fix this (and potentially other similar graphics state<br>
- problems) we now call sync_text_state when we reset text, this will<br>
- potentially flush the text buffer as well.<br>
-<br>
- 2) We were not using the text rendering mode from the graphics state when<br>
- falling back to a type 3 bitmap font, because the character code was out<br>
- of range (falling back for other reasons *did* preserve it).<br>
-<br>
- This commit fixes these two problems.<br>
-<br>
- Because of the change to text flushing some text is being drawn 1 pixel different<br>
- in location, presumably due to rounding differences, I've reviewed these<br>
- and they look fine to me.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdti.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-17 20:48: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=06a462093e4145073a61e6ca62aabbb343e39fa1">06a462093e4145073a61e6ca62aabbb343e39fa1</a>
-<blockquote>
-<p>
- Bug 695745: apply resourcestatus hook only once.<br>
-<br>
- pdfwrite requires that Type 32 fonts be disabled, and it does it by hooking<br>
- the resourcestatus operator. The problem is, because we always append<br>
- to the operator table, if we string a number PS files together from the<br>
- PScript5.dll, we can end up overflowing the operator table by repeatedly<br>
- doing the resourcestatus hook.<br>
-<br>
- This just puts a boolean into systemdict to note that we're already applied<br>
- the hook, and there don't do it again.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-15 08:21:18 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=07150250834717499b74c87d00a8dc52599d33ec">07150250834717499b74c87d00a8dc52599d33ec</a>
-<blockquote>
-<p>
- pdfwrite - pass imager state through coloured patterns as well<br>
-<br>
- commit eef2764 passed the imager state through to the underlying routines<br>
- for uncolored patterns. This commit extends the same change to include<br>
- coloured patterns.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpdfg.h<br>
-gs/devices/vector/gdevpdfv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-13 12:24:11 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3570b4830e7f54f3a057176bc01db04ec311fe23">3570b4830e7f54f3a057176bc01db04ec311fe23</a>
-<blockquote>
-<p>
- pdfwrite - increase predefined minimum CompatiblityLevel<br>
-<br>
- To avoid having to create V2 profiles, increase the minimum value of<br>
- CompatibilityLevel in the predefined PDFSETTINGS to 1.5<br>
-<br>
- No differences expected<br>
-<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-13 11:16: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=eef2764f3f9ab6dac88ea6720a05693c1d19af43">eef2764f3f9ab6dac88ea6720a05693c1d19af43</a>
-<blockquote>
-<p>
- pdfwrite porpagate the imager state through the pdfwrite Pattern code.<br>
-<br>
- Bug #695733 &quot;Error using pattern under odd conditions&quot;<br>
-<br>
- If we set UseCIEColor, so that all colours are converted into CIEBased spaces,<br>
- *and* we set CompatibilityLevel &lt; 1.5 so that we require to convert ICCBased<br>
- profiles to V2, and then use a Pattern colour space, pdfwrite throws an<br>
- error.<br>
-<br>
- This is because we were not propagating the image state through the pattern<br>
- code, and the new colour code requires the imager state in order to generate<br>
- a V2 ICC profile for inclusion in the PDF file.<br>
-<br>
- Here we simply pass the imager state through for use.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdfc.c<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpdfg.h<br>
-gs/devices/vector/gdevpdfv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-12 13:09:43 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e153528e1f5044d2018284fbf2eea45b545232fe">e153528e1f5044d2018284fbf2eea45b545232fe</a>
-<blockquote>
-<p>
- xpswrite device: fix for missing images.<br>
-<br>
- Force vector device to do new path as the clip path is the image path.<br>
- I had a case where the clip path ids were the same but the CTM was changing<br>
- which resulted in subsequent images coming up missing on the page. i.e. only<br>
- the first one was shown.<br>
-<br>
-gs/devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-12 10:20:31 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36c89af1edf269fe68f61c48326ff257862e274d">36c89af1edf269fe68f61c48326ff257862e274d</a>
-<blockquote>
-<p>
- Fix for broken make file introduced in 878ef4d48a0aebc9354ccd09443a1a52ad93c9a0.<br>
-<br>
- When adding the libtiff capability into the xpswrite device, I failed to update the devs.mak<br>
- file. This broke the Windows release 64x build. Not sure why the other platforms were also<br>
- not broken. Likely something is not getting cleaned up during a clean and rebuild.<br>
-<br>
-gs/devices/devs.mak<br>
-gs/devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-11 12:07:15 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=27ce88cce7024691f292071cb602c119afc91f61">27ce88cce7024691f292071cb602c119afc91f61</a>
-<blockquote>
-<p>
- Bug 694509: Fix file name &quot;building&quot; for resources<br>
-<br>
- After we'd created a candidate file name, there was a spurious &quot;exch&quot; in<br>
- place before we actually tried to validate the file name.<br>
-<br>
- So, instead of &quot;&lt;path-to-resources&gt;/&lt;Resource Category&gt;/&lt;Resource Instance&gt;&quot;<br>
- being passed to .libfile, we actually passed the Postscript &quot;path&quot;:<br>
- &quot;&lt;Resource Category&gt;/&lt;Resource Instance&gt;&quot;<br>
-<br>
- Simply removing the exch seems to resolve this bug for me.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-05 13:59:31 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dbcb29d2508de6ea997cf07d0987c107cd754cfb">dbcb29d2508de6ea997cf07d0987c107cd754cfb</a>
-<blockquote>
-<p>
- Bug 695711: Resolve issue with relative paths for FONTPATH<br>
-<br>
- Check whether a &quot;lib&quot; file exists, and whether we are allowed to open it,<br>
- before we try to open it.<br>
-<br>
- This reverts &quot;&quot;starting_arg_file&quot; should only apply once.&quot; (commit<br>
- 407cc61e87b0fd9d44d72ca740af7d3c85dee78d).<br>
-<br>
- Which caused problems with, for example, the &quot;-sFONTPATH=...&quot; option when the<br>
- path is relative rather than absolute.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/imainarg.c<br>
-gs/psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-04 08:24:32 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ac4bfb62efdef25bf6d60c7f6a985dc6344891ca">ac4bfb62efdef25bf6d60c7f6a985dc6344891ca</a>
-<blockquote>
-<p>
- Bug 695712: Revise glyph name map generation for TT fonts<br>
-<br>
- Reinstate the unicode cmap and formatted &quot;uniXXXX&quot; glyph name methods of<br>
- finding glyph name maps, but in a more efficient method than the original<br>
- implementation.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-12-11 14:45: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=2207f06c5647e4308622733df854e49e2d48c97f">2207f06c5647e4308622733df854e49e2d48c97f</a>
-<blockquote>
-<p>
- Handle a 'q' during the course of a 'W.....n' sequence<br>
-<br>
- Bug #695723 &quot;Inverted images when converting PDF to Tiff (B&amp;W)&quot;<br>
-<br>
- The 'W' (and W*) operators are unlike their PostScript equivalents, and all<br>
- other PDF operators, they don't take effect immediately they simply add to<br>
- the clip path and produce a new clip path. Not until the 'n' is executed do<br>
- they actually apply the clip path. The Ghostscript PDF interpreter handles<br>
- this by accumulating the path operations (W/W*) until a 'n' is encountered.<br>
-<br>
- Normally nothing else would need to be done, but because we've seen broken<br>
- PDF files that change the graphics state while accumulating a clip, and we<br>
- know that Acrobat ignores these, we have to track this. We do this by using<br>
- a dictionary.<br>
-<br>
- So each graphics state operator checks the current dictionary to see if we<br>
- are inside a 'W' context and if so emits a warning and drops the change.<br>
- Again, so far so good.<br>
-<br>
- However, the 'q' starts a new dictionary (pushing the existing 'W' one back<br>
- one level), which means that the 'n' operator closes that new dictionary<br>
- instead of the one it should close, and that brings the 'W' dictionary back<br>
- to the front.<br>
-<br>
- Now when we execute the '1 1 1 rg' it looks at the dictionary and says &quot;aha,<br>
- we are in a 'W' state, so ignore this&quot;.<br>
-<br>
- This commit has the 'q' operator check to see if we are in a 'W' context. If<br>
- we are we copy the context dictionary to the stack, and close it. Then we<br>
- start the q 'nodict' dictionary. Finally we reopen the 'W' dictionary from<br>
- the stack. Now the 'n' will correctly close the 'W' dictionary, leaving the<br>
- 'nodict' in its place.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-31 13:30: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=813dc08154a525e5acca20b5da446eb58199680f">813dc08154a525e5acca20b5da446eb58199680f</a>
-<blockquote>
-<p>
- Update jbig2dec version and CHANGES file<br>
-<br>
- No cluster differences<br>
-<br>
-gs/jbig2dec/CHANGES<br>
-gs/jbig2dec/config_win32.h<br>
-gs/jbig2dec/configure.ac<br>
-gs/jbig2dec/jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-11-19 15:02: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=66710da50af90cca72c2c8ea4942f3c4a23c9e5b">66710da50af90cca72c2c8ea4942f3c4a23c9e5b</a>
-<blockquote>
-<p>
- Bug 695688: improve cidfmap record validation.<br>
-<br>
- The previous record validation only checked for valid substitutions when the<br>
- substitution referenced a TTF file (and removed the mapping if the TTF file was<br>
- not available). It ignored name to name mappings.<br>
-<br>
- This revision adds validation to the name to name mappings, again removing<br>
- ones found to be invalid.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_cidfm.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-24 12:30:27 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=878ef4d48a0aebc9354ccd09443a1a52ad93c9a0">878ef4d48a0aebc9354ccd09443a1a52ad93c9a0</a>
-<blockquote>
-<p>
- Add high level image handling to xpswrite device.<br>
-<br>
- This adds the ability to create high level image content with the XPS write device.<br>
- It includes the writing of the ICC profile for the image and will support gray, rgb,<br>
- and cmyk images. Currently it only supports 8 bit per color channel bit depth.<br>
-<br>
- Conflicts:<br>
- gs/devices/vector/gdevxps.c<br>
-<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_cache.h<br>
-gs/base/gsicc_create.c<br>
-gs/devices/vector/gdevxps.c<br>
-gs/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-11-18 09:16:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a476643d942cfbcc6f68e7470e0d8425d31435ce">a476643d942cfbcc6f68e7470e0d8425d31435ce</a>
-<blockquote>
-<p>
- Documentation - remove some odd switches from examples in ps2pdf.htm<br>
-<br>
-gs/doc/Ps2pdf.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-11-17 11:33:42 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d5a454da233c45775f640f251cec5c035e1ee55">7d5a454da233c45775f640f251cec5c035e1ee55</a>
-<blockquote>
-<p>
- Minor fixes to clusterpush documentation (done primarily to force an update of md5sums).<br>
-<br>
-gs/toolbin/localcluster/clusterpush.pl<br>
-gs/toolbin/localcluster/clusterpush.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-11-17 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=abcaeaace08efa5d1596ef6a50f3d809d0b07a4a">abcaeaace08efa5d1596ef6a50f3d809d0b07a4a</a>
-<blockquote>
-<p>
- pdfwrite - remove the force to the old CMS for PDF/A-1<br>
-<br>
- Before we could guarantee a V2 ICC profile we forced the CMS to be the old<br>
- version for PDF/A-1. Now that we can guarantee a V2 profile this is no longer<br>
- required, and is removed here.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-11-14 12:15:45 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a37526a0606a29f0f0a86cd4b815ec7d966a1a0">4a37526a0606a29f0f0a86cd4b815ec7d966a1a0</a>
-<blockquote>
-<p>
- Improve performance of PDF TJ operator to avoid repeated setfillstate<br>
-<br>
- Add TextFillStateNeeded and add settextfillstate that conditionally<br>
- performs setfillstate only once for the operations.<br>
-<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-11-13 14:30:37 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b669cfb4d3805adbcc2d7d7a3fa9fad3e9645aa1">b669cfb4d3805adbcc2d7d7a3fa9fad3e9645aa1</a>
-<blockquote>
-<p>
- Warning cleanup and remove an obsolete PCL XL colorspace type.<br>
-<br>
-gs/base/gdevpxen.h<br>
-pcl/pcfsel.c<br>
-pcl/pglabel.c<br>
-pl/plftable.h<br>
-pxl/pxgstate.c<br>
-pxl/pxink.c<br>
-pxl/pxptable.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-11-12 23:03:50 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a814674105d9b57d5751e21d4a803df9fa4a4856">a814674105d9b57d5751e21d4a803df9fa4a4856</a>
-<blockquote>
-<p>
- Added xpswrite option to clusterpush.pl.<br>
-<br>
-gs/toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-11-12 16:50:50 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=40bc5a9477192f663d66ffcad75cd14d7dac43ab">40bc5a9477192f663d66ffcad75cd14d7dac43ab</a>
-<blockquote>
-<p>
- Fix 695673: symbol set not used correctly.<br>
-<br>
- If we don't support a requested symbol set we map the font directly<br>
- with the character codes, i.e. the symbol mapping is identity. Due to<br>
- an historical artifact we used to map symbol and wingding fonts<br>
- without symbol sets by just adding 0xf000 to the input character code,<br>
- thus evolved the conditional to check if the font is internal and the<br>
- symbol set is 0 just add 0xf000 because it must be a wingdings or<br>
- symbol font. Of course that is wrong even if very rarely encountered,<br>
- and unnecessary because we've added the symbols sets needed to support<br>
- wingdings and symbol.<br>
-<br>
-pcl/pctext.c<br>
-pcl/pglabel.c<br>
-pl/plsymbol.c<br>
-pl/plsymbol.h<br>
-pxl/pxfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-11-10 14:31: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=c98c38c8b9912fc3510ef2e1e53c3ff1837b0519">c98c38c8b9912fc3510ef2e1e53c3ff1837b0519</a>
-<blockquote>
-<p>
- eps2write - don't clamp text BBox to the text enumerator origin<br>
-<br>
- Bug #695671 &quot;eps2write gives incorrect bounding box with rotated text&quot;<br>
-<br>
- The bug here is that, having gone to some effort to retrieve the bounding<br>
- box of the text, the code then clamps the origin of the text box to the<br>
- origin of the text enumerator.<br>
-<br>
- This is clearly incorrect for rotated text, and I'm doubtful it makes sense<br>
- even for upright text. I'm somewhat puzzled because it looks quite deliberate<br>
- but I don't see why, and my testing shows no differences if I don't do this.<br>
-<br>
- So I'm removing this for now, this may need some more attention in the future<br>
- but then that is still generally true of the eps2write device.<br>
-<br>
- No differences expected, the eps2write device is not cluster tested.<br>
-<br>
-gs/devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-11-06 09:53:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b7fa37ecf0f25b125fafeed15873963853148276">b7fa37ecf0f25b125fafeed15873963853148276</a>
-<blockquote>
-<p>
- Documentation change - improve and correct MaxShadinBitmapSize documentation<br>
-<br>
-gs/doc/Ps2pdf.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-11-05 15:57:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7bdf34b3dfd52e3897cef02e7c540270c10e2349">7bdf34b3dfd52e3897cef02e7c540270c10e2349</a>
-<blockquote>
-<p>
- PDF Interpreter - run annotations in a stopped context for error-and-continue<br>
-<br>
- Bug #695453 &quot;Conversion to png fails with undefinedresult in --run--&quot;<br>
-<br>
- The PDF test file was supplied privately, it contains 3 annotations, each of<br>
- which is invalid having /Rect, /QuadPoints or /BBox arrays where each<br>
- element is 0.<br>
-<br>
- Here we simply run the annotation inside a stopped context so that if it<br>
- throws an error we can raise a message and carry on.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-11-05 10:33: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=25b7ec08e8fed8a69c9b3ac75fbf3ccc43693e7c">25b7ec08e8fed8a69c9b3ac75fbf3ccc43693e7c</a>
-<blockquote>
-<p>
- PDF interpreter - attempt to recover from empty stream with broken endstream<br>
-<br>
- Bug #695664 &quot;Problem reading PDF file: stream length incorrect&quot;<br>
-<br>
- The file has an annotation with a broken stream, its empty (Length 0) and<br>
- the endstream keyword is incorrectly written as endsteam.<br>
-<br>
- When we encounter the endobj we attempt to unwind back to the object number<br>
- and generation on the stack, but we don't have those on the stack, so instead<br>
- we consume the error recovery information, which then leads to the stream<br>
- code being unable to recover from the error condition, resulting in an error.<br>
-<br>
- This change to endobj looks to see if either of the 2nd and third entries<br>
- on the operand stack are a 'mark', and if so assumes that this is a broken<br>
- empty stream, pops back to the mark and exits leaving cleanup to the<br>
- stream code.<br>
-<br>
- Clearly this code can be defeated, depending on what garbage is left behind<br>
- by the broken stream, but in general we might reasonably expect to find two<br>
- integers before a mark object. Even if we don't, the result will still be no<br>
- worse than at present.<br>
-<br>
- No differences expected<br>
-<br>
-gs/Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-11-03 15:36:55 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b2a6decb294ca8c48c71da2211f3284b2334d921">b2a6decb294ca8c48c71da2211f3284b2334d921</a>
-<blockquote>
-<p>
- PDF interpreter - make unrecognised operators obey PDFSTOPONERROR<br>
-<br>
- Bug #695661 &quot;Ghostscript command hangs indefinitely&quot;<br>
-<br>
- The PDF file is badly corrupted, Acrobat fails to display most of page 27,<br>
- MuPDF complains of zlib errors.<br>
-<br>
- Ghostscript also emits many warnings and then proceeds to spend an interminably<br>
- long time subdividing a curve. At resolutions up to ~25 dpi its reasonably<br>
- quick, after that its a long time indeed.<br>
-<br>
- We can't simply catch the zlib errors like MuPDF, as bug #688716 indicates<br>
- that, under at least some conditions, Acrobat ignores these errors.<br>
-<br>
- The problem seems to be caused by the fact that the corrupted data includes<br>
- some truly massive co-ordinates, but we can't simply ignore those either<br>
- as a real number can vary up to +/- 3.403 x 10^38. Possibly we could limit<br>
- numbers representing co-ordinates to 14,400, since that's the maximum<br>
- Acrobat can use, but that would mean a *lot* of reworking in the PDF<br>
- interpreter.<br>
-<br>
- The best I can come up with short of that is to make malformed numbers<br>
- throw an error, and honour PDFSTOPONERROR, which to be frank should have<br>
- been the case already.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-16 12:26:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a3bb342587cc7247420a05ff2428c4c94da194c0">a3bb342587cc7247420a05ff2428c4c94da194c0</a>
-<blockquote>
-<p>
- Bug 695593: Add the MAKEDIRS target wherever it was missing.<br>
-<br>
- MAKEDIRS target was missing from a large number of object files and other<br>
- files created during the build process. This could cause problems when<br>
- running parallel make instances.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/expat.mak<br>
-gs/base/fapi_bs.mak<br>
-gs/base/freetype.mak<br>
-gs/base/ijs.mak<br>
-gs/base/jbig2.mak<br>
-gs/base/jpeg.mak<br>
-gs/base/jpegxr.mak<br>
-gs/base/lcms2.mak<br>
-gs/base/lcups.mak<br>
-gs/base/lcupsi.mak<br>
-gs/base/ldf_jb2.mak<br>
-gs/base/lib.mak<br>
-gs/base/lwf_jp2.mak<br>
-gs/base/openjpeg.mak<br>
-gs/base/png.mak<br>
-gs/base/tiff.mak<br>
-gs/base/trio.mak<br>
-gs/base/unix-aux.mak<br>
-gs/base/zlib.mak<br>
-gs/devices/contrib.mak<br>
-gs/devices/devs.mak<br>
-gs/psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-31 12:39: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=0f0b9350206c99e5f4b73fe639ed3e085066fe5e">0f0b9350206c99e5f4b73fe639ed3e085066fe5e</a>
-<blockquote>
-<p>
- Fix and improve bit-rotted jbig2dec/libpng build on Windows<br>
-<br>
- The Windows jbig2dec build incorporating libpng had bit-rotted, credit to<br>
- Ray for identifying the problems there.<br>
-<br>
- In addition, I've added provision for specifying the libpng and zlib source<br>
- paths on the nmake command line, and automatic inclusion of libpng if<br>
- the path appears valid.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/jbig2dec/jbig2_image_png.c<br>
-gs/jbig2dec/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-30 10:59: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=69a6dc944e63a4a037eccc0d0cba5dee6bf9f272">69a6dc944e63a4a037eccc0d0cba5dee6bf9f272</a>
-<blockquote>
-<p>
- Fix annoying, hard to reproduce ICC related warning<br>
-<br>
- Occasionally, and in hard to reproduce circumstances, we could get a warning<br>
- from the ICC code:<br>
- ./base/gsicc_manage.c:1084: gsicc_open_search(): \<br>
- Could not find &lt;garbage string&gt;<br>
-<br>
- This, it turns out, is because the get_params code was returning a pointer to<br>
- a string allocated in non-gc memory, which just isn't compatible with the<br>
- way the Postscript interpreter interacts with the graphics library.<br>
-<br>
- This commit changes the way the parameter is returned so it copies the string<br>
- into gc memory, compatible with use in a Postscript string object. Note that the<br>
- put_params equivalent code was already correct in copying the string from gc<br>
- memory into non-gc memory managed by the device code.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/base/gsdparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-27 21:19:44 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ee0bc20cc98c8e8381003a25dfa0b21e681c6545">ee0bc20cc98c8e8381003a25dfa0b21e681c6545</a>
-<blockquote>
-<p>
- replace jbig2_arith_get_offset with jbig2_arith_has_reached_marker<br>
-<br>
- The DOS check introduced with 6e1f2259115efac14cd6c7ad9d119b43013a32a1<br>
- tries to determine whether arithmetic coding has run out of data and<br>
- has entered an infinite loop. It does so by checking how many bytes<br>
- have been read and compares with the number of bytes available. The fix<br>
- however fails to take into account bytes which have been cached in<br>
- _Jbig2ArithState::next_word which causes valid images to be rejected.<br>
-<br>
- This patch corrects that bug by replacing that check with a generic<br>
- check as to whether the end of the data stream has been reached (which<br>
- is the case if the only two remaining cached bytes are 0xFF and a value<br>
- larger than 0x8F).<br>
-<br>
- Signed-off-by: Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<br>
-gs/jbig2dec/jbig2_arith.c<br>
-gs/jbig2dec/jbig2_arith.h<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-27 13:51:32 +0200
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9157d6a5fccf109eb6554557eb8904b281571d28">9157d6a5fccf109eb6554557eb8904b281571d28</a>
-<blockquote>
-<p>
- Bug 694892: fix typo in 5eaf740b2c02523ae2ae6454e546cb6700d4e3f3<br>
-<br>
- Signed-off-by: Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<br>
-gs/jbig2dec/jbig2_metadata.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-29 09:29: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=f6789d068a5f7af9cfead5120930893955123be1">f6789d068a5f7af9cfead5120930893955123be1</a>
-<blockquote>
-<p>
- Correct a small out-of-dateness related to COMPILE_INITS<br>
-<br>
- No cluster differences<br>
-<br>
-gs/doc/Make.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-28 17:09:17 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd2c4af1dd92bc4cc32170254c84498792913c0e">cd2c4af1dd92bc4cc32170254c84498792913c0e</a>
-<blockquote>
-<p>
- PDF interpreter - ignore /Contents array entries which don't resolve to dicts<br>
-<br>
- Bug #695645 &quot;PDFWrite fails on file with Error: /typecheck in --run--&quot;<br>
-<br>
- The specimen file has a /Contents array where one of the elements is an<br>
- indirect reference to another array. This isn't legal, entries in the<br>
- /Contents array must be references to streams. Acrobat simply ignores the<br>
- error and displays the page blank.<br>
-<br>
- Here we check each entry before we process it, and if its not a dictionary<br>
- we ignore it, exit the loop processing the entries (as Acrobat apparently does)<br>
- and emit a warning.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-28 16:28:30 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e21bb3e597825215da7ad4d757585fa96eb39909">e21bb3e597825215da7ad4d757585fa96eb39909</a>
-<blockquote>
-<p>
- PDF interpreter - provide a default BBox for Forms<br>
-<br>
- Bug #695632 &quot;Error: /undefined in --.PDFexecform--&quot;<br>
-<br>
- Type 1 Form XObjects are required to have a /BBox, but this example file<br>
- incorrectly omits it. Here we add a default (incorrect) BBox just to work<br>
- around the error. We also emit a warning that the file is damaged.<br>
-<br>
- No diffreences expected.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-28 15:55: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=282c8f902d98543aee12931e69087180829bc8d1">282c8f902d98543aee12931e69087180829bc8d1</a>
-<blockquote>
-<p>
- Remove paragraphs relating to GNU readline<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/doc/Make.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-28 10:49: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=05c2e0876019551d65f8f79655f34aa5adb5ca27">05c2e0876019551d65f8f79655f34aa5adb5ca27</a>
-<blockquote>
-<p>
- Update the docs for fonts and COMPILE_INITS<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-27 19:12:15 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d39b321e4927dfafa428af8c25bddb791b14e15b">d39b321e4927dfafa428af8c25bddb791b14e15b</a>
-<blockquote>
-<p>
- Update color management documentation.<br>
-<br>
-gs/doc/GS9_Color_Management.pdf<br>
-gs/doc/GS9_Color_Management.tex<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-23 09:35:26 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db7ac4892625633204fad65ffa0da6dbaf43fc6a">db7ac4892625633204fad65ffa0da6dbaf43fc6a</a>
-<blockquote>
-<p>
- Bug 695598: cidfmap validation problems on Windows<br>
-<br>
- Originally, the cidfmap validation used &quot;stat&quot; to check whether the font file<br>
- was available (and remove the mapping if the font file is missing). But it<br>
- seems, for some (currently unidentified) reason, stat can fail even if the<br>
- font file is actually avaiable.<br>
-<br>
- This changes the validation code to use &quot;.libfile&quot; and &quot;file&quot; operators to<br>
- check whether the font file can be found - this, it seems, works, even in cases<br>
- where &quot;state&quot; fails.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_cidfm.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-22 13:30: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=352645ff149aa690074030995ef33e1c2e4c35a0">352645ff149aa690074030995ef33e1c2e4c35a0</a>
-<blockquote>
-<p>
- Xpswrite - properly initialise PrinterName<br>
-<br>
- Bug #695617 &quot;Error: Printer name too long&quot;<br>
-<br>
- The xpswrite device doesn't include a full definition of its devicestructure<br>
- or initialisers for its variables.<br>
-<br>
- This can lead to problems if any of these variables are exposed via<br>
- put/get params as the initial parameter will be uninitialised (put and get<br>
- params are called before the device open method)<br>
-<br>
- Here we add a 'finish_copydevice' method and initialise the PrinterName<br>
- in it. Devices are created by calling copydevice on the device prototype<br>
- and the finish_copydevice method is called as the last action from there<br>
- so its safe to initialise the variables, and this will be completed before<br>
- put/get params is called.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-22 14:04:14 +0200
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=648aba52e1430277035471709e3d6596c7016a35">648aba52e1430277035471709e3d6596c7016a35</a>
-<blockquote>
-<p>
- Fix 695618: Keep a tail pointer to speed up parsing long XML documents.<br>
-<br>
-xps/xpsxml.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-20 09:55:22 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c477d95f3e6cf50da2dc125c8d8335a440d9970d">c477d95f3e6cf50da2dc125c8d8335a440d9970d</a>
-<blockquote>
-<p>
- Restrict xpswrite PrinterName device paramater to windows platform.<br>
-<br>
-gs/devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-19 17:54:28 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=54f69da6cdeae9dcffcb1d060ccbeef3e0d4f7b0">54f69da6cdeae9dcffcb1d060ccbeef3e0d4f7b0</a>
-<blockquote>
-<p>
- Bug #695578 - Continue parsing a numeric parameter if a bad character<br>
- is found before a legal value.<br>
-<br>
- This refines an earlier fix, bug #694725 which implemented skipping<br>
- the rest of the numerical parameter when a bad character was parsed.<br>
-<br>
- Thanks to Norbert Janssen for finding and fixing this problem.<br>
-<br>
-pcl/pcparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-19 10:31:42 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=75a6c77aaa4278d462834f08b8da23dabc4566d7">75a6c77aaa4278d462834f08b8da23dabc4566d7</a>
-<blockquote>
-<p>
- Change warnings to debug statements.<br>
-<br>
-gs/devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-19 10:07:57 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8eadbf5b901588e86886f7ab42462c2486e9f561">8eadbf5b901588e86886f7ab42462c2486e9f561</a>
-<blockquote>
-<p>
- Fix warnings introduced with &quot;saved page&quot; work.<br>
-<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-19 09:52:33 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d9a5f2f04b57d09f7f8c2082b29edd43fc96dcb0">d9a5f2f04b57d09f7f8c2082b29edd43fc96dcb0</a>
-<blockquote>
-<p>
- Remove repetive accessors for 2 user options (interpolate and nocache)<br>
- and replace with single routine in pl.<br>
-<br>
-pcl/pctop.c<br>
-pl/plmain.c<br>
-pl/plmain.h<br>
-pxl/pxl.mak<br>
-pxl/pxtop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-11 09:46:19 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d93848b56be856aaa41a7e16fa42c141219244f5">d93848b56be856aaa41a7e16fa42c141219244f5</a>
-<blockquote>
-<p>
- Add -dNOCACHE to the usage help statement that runs when the program<br>
- is run incorrectly or incompletely.<br>
-<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-11 09:42: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=88ed32c13b7bca6c259dc29502a40446bf34f75b">88ed32c13b7bca6c259dc29502a40446bf34f75b</a>
-<blockquote>
-<p>
- Implement NOCACHE parameter. We only support the simple case of<br>
- specifying the parameter or not. Right hand side values of /true and<br>
- /false are not supported.<br>
-<br>
-pcl/pcfont.c<br>
-pcl/pcstate.h<br>
-pcl/pctop.c<br>
-pl/plmain.c<br>
-pl/plmain.h<br>
-pl/pltop.h<br>
-pxl/pxstate.c<br>
-pxl/pxstate.h<br>
-pxl/pxtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-10 11:56:28 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f072fac051e5f008488e5eea66cc76876516ec47">f072fac051e5f008488e5eea66cc76876516ec47</a>
-<blockquote>
-<p>
- Error handling was wrong, objects were dereferenced before checking if<br>
- the allocation failed.<br>
-<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-18 07:55:27 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6715211e308d753a79b35663f951a239704b8092">6715211e308d753a79b35663f951a239704b8092</a>
-<blockquote>
-<p>
- Fix compile issue with Luratech introduced in 74d5e9fb7d70d3d3d9cf964c76c550134c822020.<br>
-<br>
- The change from a char * to an enum for psdf_image_params_s-&gt;AutoFilterStrategy<br>
- required a change in gdevpsdi.c.<br>
-<br>
-gs/devices/vector/gdevpsdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-14 12:39: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=5bf2c272781f20dc2ed4ca8a461166543846f422">5bf2c272781f20dc2ed4ca8a461166543846f422</a>
-<blockquote>
-<p>
- ps2write - undo PDF name escaping for Separation colours<br>
-<br>
- Bug #695590 &quot;Spaces in spot colour names are encoded to &quot;#20&quot;&quot;<br>
-<br>
- The opdfread header wasn't applying the conversion from PDF escaped names<br>
- when the name was an entry in a Separation colour space.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/opdfread.h<br>
-gs/lib/opdfread.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-10 11:26:45 +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=63b484c3040aa644fff2ed2a0861ac8cb082aafb">63b484c3040aa644fff2ed2a0861ac8cb082aafb</a>
-<blockquote>
-<p>
- Bug 695146: patch for missing lrintf<br>
-<br>
- OpenJPEG uses lrintf() which can be missing, or in this case, the prototype is<br>
- missing from the math.h header file - causing faulty output.<br>
-<br>
- This patch checks for the function prototype, if it's missing it replaces the<br>
- lrintf() call with a naive round/cast implementation.<br>
-<br>
- Two reasons for choosing this approach: it saves maintaining a patch against<br>
- OpenJPEG, and secondly, this is only relevant to older systems - more up to<br>
- date systems have lrintf() correctly prototyped, and often have implementations<br>
- optimised to the hardware, so we really want to use it if it's available.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-07 14:33: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=8095a1010b799d5e36ac5bf4a5b67356362df607">8095a1010b799d5e36ac5bf4a5b67356362df607</a>
-<blockquote>
-<p>
- Upon macro creation there is no need to search the dictionary for a<br>
- like named macros and delete it, the dictionary entry is recycled later<br>
- when we add the macro.<br>
-<br>
-pcl/pcmacros.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-07 09:28: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=ca7cea181d7905cb460ad6f82f234d3ee8d5efce">ca7cea181d7905cb460ad6f82f234d3ee8d5efce</a>
-<blockquote>
-<p>
- pdfwrite - fix a logical error in the AutoFilterStrategy params<br>
-<br>
- This code was originally present only when using the Luratech decoder<br>
- but would have been incorrect there too.<br>
-<br>
- Spotted while looking at a scan-build warning<br>
-<br>
-gs/devices/vector/gdevpsdp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-05 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=1f3e40cf0fbbbb9a1c8085584f3e411cb112d9b4">1f3e40cf0fbbbb9a1c8085584f3e411cb112d9b4</a>
-<blockquote>
-<p>
- Bug 695555: fix check to simulate overprint.<br>
-<br>
- Mirror condition from pdf14_mark_fill_rectangle() in<br>
- pdf14_copy_alpha_color() to decide whether we should apply overprinting.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-06 18:00: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=4018f1158984093380971ba1f4096b599c2d639e">4018f1158984093380971ba1f4096b599c2d639e</a>
-<blockquote>
-<p>
- PDF interpreter - improve error recovery with PDF form execution<br>
-<br>
- Bug #695537 &quot;Ghostscript locks up reading attached PDF file&quot;<br>
-<br>
- The problem is that, after we execute a form, we attempt to 'grestore' back<br>
- to the gsave depth at the time we executed the form, this is to try and<br>
- cater for broken form streams that have unbalanced Q/q operators.<br>
-<br>
- This is done by counting the dict stack before the form execution, and after<br>
- the form is complete. If the depth is different we execute 'Q' in a loop<br>
- until we get back to the same dict stack depth.<br>
-<br>
- This assumes that the only reason for having more dictionaries on the stack<br>
- is due to them being pushed by our implementation of 'q'. However in this<br>
- case (and more generally, in any event) we have created some dictionaries<br>
- then encountered an error, and returned control back to the form execution<br>
- routine.<br>
-<br>
- As stated this calls 'Q' in a loop expecting that each 'Q' will decrement<br>
- the number of dictionaries by 1 each time. But 'Q' only does that if the<br>
- dictionary is the result of a 'q' if it isn't it leaves it in place.<br>
-<br>
- So the form execution simply carries on round the loop forever.<br>
-<br>
- This commit addresses this by checking the number of items on the dict<br>
- stack before and after executing 'Q' and if they are the same, it executes<br>
- the 'end' operator instead to remove the topmost dictionary from the stack.<br>
-<br>
- This allows us to carry on removing gstate or general dictionaries until<br>
- we get back to the correct depth.<br>
-<br>
- Note that, because there is a genuine error in the file, we do not render<br>
- it 'correctly', but neither does any other PDF consumer. Other consumers<br>
- render more of it than we do, but they all drop the 'Fannie Mae' logo.<br>
-<br>
- No differences expected<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-06 17:06: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=33e70f43badc2581757549bba55747af3f966622">33e70f43badc2581757549bba55747af3f966622</a>
-<blockquote>
-<p>
- colour handling - remove continuations from the exec stack on error<br>
-<br>
- If we get an error (not running another PostScript function), we were not<br>
- removing our continuation procedure and data from the execution stack<br>
- before exiting setcolorspace.<br>
-<br>
- This led to the interpreter exiting instead of simply flagging an error.<br>
-<br>
- No bug report for this, discovered while working on bug #695537<br>
-<br>
-gs/psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-06 16:37: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=74d5e9fb7d70d3d3d9cf964c76c550134c822020">74d5e9fb7d70d3d3d9cf964c76c550134c822020</a>
-<blockquote>
-<p>
- pdfwrite - Correct Gray and ColorImageAutoFilterStrategy<br>
-<br>
- A number of problems here; firstly the commit that added these to the<br>
- distiller params has the correct names in the commit message, but the names<br>
- used in the code were incorrect (eg ColorAutoFilterStrategy).<br>
-<br>
- Secondly the parameter is supposed to be a name, but the data stored<br>
- was a C string, and get_params was returning an integer, so it actually<br>
- contained half the memory pointer value.<br>
-<br>
- The parameters weren't added to .distillerparamkeys so currentdistillerparams<br>
- didn't return the values.<br>
-<br>
- The default value for the non-Luratech case should have been /JPEG but in<br>
- fact /JPEG2000 was used in both cases.<br>
-<br>
- 99-01-fixed.ps should dhow up as a diff this time, and then should cease<br>
- being indeterminate with the pdfwrite device, as we now return the correct<br>
- name rather than half a random memory location.<br>
-<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-gs/devices/vector/gdevpsdf.h<br>
-gs/devices/vector/gdevpsdp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-05 19:37:24 +0100
-</strong>
-<br>Paul Gardiner &lt;paul.gardiner@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e72d03c68bfb6afaa0b90f6b717f91aef67b6c07">e72d03c68bfb6afaa0b90f6b717f91aef67b6c07</a>
-<blockquote>
-<p>
- Fix compiler warnings introduced by temp-file commit<br>
-<br>
-gs/base/gxclfile.c<br>
-gs/base/unistd_.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-05 17:14: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=5d4d9d9772765501cac81b9b181ecc83f900d08a">5d4d9d9772765501cac81b9b181ecc83f900d08a</a>
-<blockquote>
-<p>
- pdfwrite - move outline relocation after the outline action relocation<br>
-<br>
- Bug #695354 &quot;Segmentation fault splitting PDF&quot;<br>
-<br>
- Move the pointer relocation for outline levels so that it takes place after<br>
- we relocate the outline actions, otherwise we can end up corrupting<br>
- memory.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-24 12:50:17 +0100
-</strong>
-<br>Paul Gardiner &lt;paul.gardiner@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9108db24fef88855199038a257bf935a698af2f4">9108db24fef88855199038a257bf935a698af2f4</a>
-<blockquote>
-<p>
- Avoid failure to clean up temp files when the execution is killed<br>
-<br>
- This currently works only for Windows and Linux builds. For Windows, temp<br>
- files are created with the &quot;delete on close&quot; option. For Linux, temp<br>
- files are immediately unlinked on creation. In both cases, the initially<br>
- opened FILE pointer is kept open throughout execution, and reader access<br>
- is provided by duplicating the initial FILE rather than opening a new<br>
- FILE pointer based on the file name.<br>
-<br>
-gs/base/gp.h<br>
-gs/base/gp_macio.c<br>
-gs/base/gp_mswin.c<br>
-gs/base/gp_os2fs.c<br>
-gs/base/gp_unifs.c<br>
-gs/base/gp_vms.c<br>
-gs/base/gxclfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-03 13:40:21 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0a8ac7c25438fbd4c406fc735c9c0fbd9f05c527">0a8ac7c25438fbd4c406fc735c9c0fbd9f05c527</a>
-<blockquote>
-<p>
- Bug 695244: ensure a consistent allocator for DCT streams.<br>
-<br>
- The existing code could result in a mis-match between the memory allocators<br>
- used for the DCT specific parts of the stream and the main body of the stream.<br>
-<br>
- As both are in gc memory, this could result, when the stream goes out of scope,<br>
- in the DCT specific memory being garbage collected before the main stream<br>
- object. As the main stream object contains the &quot;finalize&quot; method, the call to<br>
- finalize would result in accessing already freed memory.<br>
-<br>
- This commit revises the code to use the same method to work out the allocator<br>
- to use for the main stream object as we do for the DCT specific parts.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zfdctd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-10-02 21:54: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=8f16e6dc73550d3e8f339a609e2dc51998616330">8f16e6dc73550d3e8f339a609e2dc51998616330</a>
-<blockquote>
-<p>
- Bug 695561: remove .DS_Store files<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/lcms2/Projects/mac/.DS_Store<br>
-gs/lcms2/Projects/mac/LittleCMS/.DS_Store<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-30 17: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=f85afab4a4584c79f309e8f5691f5955605c67b5">f85afab4a4584c79f309e8f5691f5955605c67b5</a>
-<blockquote>
-<p>
- Address two compiler warnings.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-30 08:58: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=b460743bdc6c8c4de5fca260224673ca839b11e6">b460743bdc6c8c4de5fca260224673ca839b11e6</a>
-<blockquote>
-<p>
- Remove LCMS.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Makefile.in<br>
-gs/base/lcms.mak<br>
-gs/configure.ac<br>
-gs/lcms/AUTHORS<br>
-gs/lcms/COPYING<br>
-gs/lcms/ChangeLog<br>
-gs/lcms/Delphi/Samples/MAKETEST.BAT<br>
-gs/lcms/Delphi/Samples/TEST.PAS<br>
-gs/lcms/Delphi/Samples/create.pas<br>
-gs/lcms/Delphi/Samples/gamutchk.pas<br>
-gs/lcms/Delphi/Samples/getxyz.pas<br>
-gs/lcms/Delphi/Samples/sRGB Color Space Profile.icm<br>
-gs/lcms/Delphi/Samples/testfrm.pas<br>
-gs/lcms/Delphi/Samples/testwp.pas<br>
-gs/lcms/Delphi/delphidemo.cfg<br>
-gs/lcms/Delphi/delphidemo.dof<br>
-gs/lcms/Delphi/delphidemo.dpr<br>
-gs/lcms/Delphi/delphidemo.res<br>
-gs/lcms/Delphi/demo1.dcu<br>
-gs/lcms/Delphi/demo1.ddp<br>
-gs/lcms/Delphi/demo1.dfm<br>
-gs/lcms/Delphi/demo1.pas<br>
-gs/lcms/Delphi/lcmsdll.pas<br>
-gs/lcms/INSTALL<br>
-gs/lcms/Lib/BC/BC.txt<br>
-gs/lcms/Lib/MS/MS.TXT<br>
-gs/lcms/Makefile.am<br>
-gs/lcms/Makefile.in<br>
-gs/lcms/NEWS<br>
-gs/lcms/Projects/BorlandC_5.5/lcms.rc<br>
-gs/lcms/Projects/BorlandC_5.5/lcmsdll.lk<br>
-gs/lcms/Projects/BorlandC_5.5/lcmsdll.lst<br>
-gs/lcms/Projects/BorlandC_5.5/mklcmsdll.bat<br>
-gs/lcms/Projects/VC2005/Python.vcproj<br>
-gs/lcms/Projects/VC2005/Testbed.vcproj<br>
-gs/lcms/Projects/VC2005/icc2ps.vcproj<br>
-gs/lcms/Projects/VC2005/icclink.vcproj<br>
-gs/lcms/Projects/VC2005/icctrans.vcproj<br>
-gs/lcms/Projects/VC2005/jpegicc.vcproj<br>
-gs/lcms/Projects/VC2005/lcms.rc<br>
-gs/lcms/Projects/VC2005/lcms.sln<br>
-gs/lcms/Projects/VC2005/lcms.vcproj<br>
-gs/lcms/Projects/VC2005/lcmsdll.vcproj<br>
-gs/lcms/Projects/VC2005/resource.h<br>
-gs/lcms/Projects/VC2005/tiffdiff.vcproj<br>
-gs/lcms/Projects/VC2005/tifficc.vcproj<br>
-gs/lcms/Projects/VC2008/Python.vcproj<br>
-gs/lcms/Projects/VC2008/Testbed.vcproj<br>
-gs/lcms/Projects/VC2008/icc2ps.vcproj<br>
-gs/lcms/Projects/VC2008/icclink.vcproj<br>
-gs/lcms/Projects/VC2008/icctrans.vcproj<br>
-gs/lcms/Projects/VC2008/jpegicc.vcproj<br>
-gs/lcms/Projects/VC2008/lcms.rc<br>
-gs/lcms/Projects/VC2008/lcms.sln<br>
-gs/lcms/Projects/VC2008/lcms.vcproj<br>
-gs/lcms/Projects/VC2008/lcmsdll.vcproj<br>
-gs/lcms/Projects/VC2008/resource.h<br>
-gs/lcms/Projects/VC2008/tiffdiff.vcproj<br>
-gs/lcms/Projects/VC2008/tifficc.vcproj<br>
-gs/lcms/Projects/VC6/Python.dsp<br>
-gs/lcms/Projects/VC6/Python.plg<br>
-gs/lcms/Projects/VC6/Testbed.dsp<br>
-gs/lcms/Projects/VC6/Testbed.plg<br>
-gs/lcms/Projects/VC6/icc2ps.dsp<br>
-gs/lcms/Projects/VC6/icclink.dsp<br>
-gs/lcms/Projects/VC6/icctrans.dsp<br>
-gs/lcms/Projects/VC6/jpegicc.dsp<br>
-gs/lcms/Projects/VC6/lcms.dsp<br>
-gs/lcms/Projects/VC6/lcms.dsw<br>
-gs/lcms/Projects/VC6/lcms.opt<br>
-gs/lcms/Projects/VC6/lcms.rc<br>
-gs/lcms/Projects/VC6/lcmsdll.dsp<br>
-gs/lcms/Projects/VC6/resource.h<br>
-gs/lcms/Projects/VC6/tifficc.dsp<br>
-gs/lcms/Projects/VC7/Python.vcproj<br>
-gs/lcms/Projects/VC7/Testbed.vcproj<br>
-gs/lcms/Projects/VC7/icc2ps.vcproj<br>
-gs/lcms/Projects/VC7/icclink.vcproj<br>
-gs/lcms/Projects/VC7/icctrans.vcproj<br>
-gs/lcms/Projects/VC7/jpegicc.vcproj<br>
-gs/lcms/Projects/VC7/lcms.rc<br>
-gs/lcms/Projects/VC7/lcms.sln<br>
-gs/lcms/Projects/VC7/lcms.vcproj<br>
-gs/lcms/Projects/VC7/lcmsdll.vcproj<br>
-gs/lcms/Projects/VC7/resource.h<br>
-gs/lcms/Projects/VC7/tiffdiff.vcproj<br>
-gs/lcms/Projects/VC7/tifficc.vcproj<br>
-gs/lcms/README.1ST<br>
-gs/lcms/aclocal.m4<br>
-gs/lcms/bin/Bin.txt<br>
-gs/lcms/compile<br>
-gs/lcms/config.guess<br>
-gs/lcms/config.sub<br>
-gs/lcms/configure<br>
-gs/lcms/configure.ac<br>
-gs/lcms/depcomp<br>
-gs/lcms/doc/LCMSAPI.TXT<br>
-gs/lcms/doc/TUTORIAL.TXT<br>
-gs/lcms/filter.c<br>
-gs/lcms/include/Makefile.am<br>
-gs/lcms/include/Makefile.in<br>
-gs/lcms/include/icc34.h.in<br>
-gs/lcms/include/lcms.h<br>
-gs/lcms/install-sh<br>
-gs/lcms/install.gcc<br>
-gs/lcms/jpegicc/Makefile.am<br>
-gs/lcms/jpegicc/Makefile.in<br>
-gs/lcms/jpegicc/iccjpeg.c<br>
-gs/lcms/jpegicc/iccjpeg.h<br>
-gs/lcms/jpegicc/jpegicc.1<br>
-gs/lcms/jpegicc/jpegicc.c<br>
-gs/lcms/jpegicc/makefile.simple<br>
-gs/lcms/lcms.pc.in<br>
-gs/lcms/ltmain.sh<br>
-gs/lcms/makefile.simple<br>
-gs/lcms/matlab/icctrans.c<br>
-gs/lcms/matlab/icctrans.matlab.pdf<br>
-gs/lcms/missing<br>
-gs/lcms/mkinstalldirs<br>
-gs/lcms/python/Makefile.am<br>
-gs/lcms/python/Makefile.in<br>
-gs/lcms/python/lcms.i<br>
-gs/lcms/python/lcms.py<br>
-gs/lcms/python/lcms_wrap.cxx<br>
-gs/lcms/python/swig_lcms<br>
-gs/lcms/python/testbed/AdobeRGB1998.icc<br>
-gs/lcms/python/testbed/cam02.py<br>
-gs/lcms/python/testbed/cam97.py<br>
-gs/lcms/python/testbed/clamp.py<br>
-gs/lcms/python/testbed/constant.py<br>
-gs/lcms/python/testbed/createmsh.py<br>
-gs/lcms/python/testbed/gamma.py<br>
-gs/lcms/python/testbed/info.py<br>
-gs/lcms/python/testbed/lab2adobe.py<br>
-gs/lcms/python/testbed/sRGB Color Space Profile.icm<br>
-gs/lcms/python/testbed/sRGB2adobe.py<br>
-gs/lcms/python/testbed/srgb2lab.py<br>
-gs/lcms/python/testbed/srgb2xyz.py<br>
-gs/lcms/python/testbed/virtprf.py<br>
-gs/lcms/python/testbed/whtpnt.py<br>
-gs/lcms/samples/Makefile.am<br>
-gs/lcms/samples/Makefile.in<br>
-gs/lcms/samples/icc2ps.1<br>
-gs/lcms/samples/icc2ps.c<br>
-gs/lcms/samples/icclink.1<br>
-gs/lcms/samples/icclink.c<br>
-gs/lcms/samples/icctrans.1<br>
-gs/lcms/samples/icctrans.c<br>
-gs/lcms/samples/itufax.c<br>
-gs/lcms/samples/makefile.simple<br>
-gs/lcms/samples/mkcmy.c<br>
-gs/lcms/samples/mkgrayer.c<br>
-gs/lcms/samples/mktiff8.c<br>
-gs/lcms/samples/vprf.c<br>
-gs/lcms/samples/wtpt.1<br>
-gs/lcms/samples/wtpt.c<br>
-gs/lcms/samples/xgetopt.c<br>
-gs/lcms/src/Makefile.am<br>
-gs/lcms/src/Makefile.in<br>
-gs/lcms/src/cmscam02.c<br>
-gs/lcms/src/cmscam97.c<br>
-gs/lcms/src/cmscgats.c<br>
-gs/lcms/src/cmscnvrt.c<br>
-gs/lcms/src/cmserr.c<br>
-gs/lcms/src/cmsgamma.c<br>
-gs/lcms/src/cmsgmt.c<br>
-gs/lcms/src/cmsintrp.c<br>
-gs/lcms/src/cmsio0.c<br>
-gs/lcms/src/cmsio1.c<br>
-gs/lcms/src/cmslut.c<br>
-gs/lcms/src/cmsmatsh.c<br>
-gs/lcms/src/cmsmtrx.c<br>
-gs/lcms/src/cmsnamed.c<br>
-gs/lcms/src/cmspack.c<br>
-gs/lcms/src/cmspcs.c<br>
-gs/lcms/src/cmsps2.c<br>
-gs/lcms/src/cmssamp.c<br>
-gs/lcms/src/cmsvirt.c<br>
-gs/lcms/src/cmswtpnt.c<br>
-gs/lcms/src/cmsxform.c<br>
-gs/lcms/src/cmsxform.c.orig<br>
-gs/lcms/src/cmsxform.h<br>
-gs/lcms/src/lcms.def<br>
-gs/lcms/src/makefile.simple<br>
-gs/lcms/testbed/Makefile.am<br>
-gs/lcms/testbed/Makefile.in<br>
-gs/lcms/testbed/makefile.simple<br>
-gs/lcms/testbed/sRGB Color Space Profile.icm<br>
-gs/lcms/testbed/sRGBSpac.icm<br>
-gs/lcms/testbed/testcms.c<br>
-gs/lcms/tifficc/Makefile.am<br>
-gs/lcms/tifficc/Makefile.in<br>
-gs/lcms/tifficc/getopt.c<br>
-gs/lcms/tifficc/makefile.simple<br>
-gs/lcms/tifficc/tiffdiff.c<br>
-gs/lcms/tifficc/tifficc.1<br>
-gs/lcms/tifficc/tifficc.c<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-25 11:21:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6ecc8536f5119f21aa38b94eb00e61214d27bd62">6ecc8536f5119f21aa38b94eb00e61214d27bd62</a>
-<blockquote>
-<p>
- Bug 695502: segfault with -dBGPrint=true<br>
-<br>
- When we're doing background printing, and we're using a memory file based<br>
- clist, we create a &quot;clone&quot; of the file object with it's own &quot;context&quot; but<br>
- which shares the underlying &quot;raw&quot; data with the original file. The original<br>
- code tries to free the underlying raw data memory along with the clone<br>
- file object, but as the clone uses the memory allocator created for the<br>
- rendering thread and the raw data memory was allocated in the interpretation<br>
- &quot;thread&quot;, we end up trying to free memory to the wrong allocator.<br>
-<br>
- This commit has the interpreter thread hold a reference to the original clist<br>
- files, so we can free the &quot;clone&quot; files with the thread allocator, and the<br>
- original file with the allocator from the interpreter thread. As both these<br>
- cleanup actions happen in the interpreter thread, we don't have to worry about<br>
- thread clashes.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevprn.h<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-17 21:17:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ac0f1668fca8e1ca343e02f55faa7dd9f23d549">7ac0f1668fca8e1ca343e02f55faa7dd9f23d549</a>
-<blockquote>
-<p>
- Bug 695483: BGPrint seg fault<br>
-<br>
- When reading params for the existing device, to pass to the cloned device,<br>
- use the thread_memory rather than the original device memory.<br>
-<br>
- And move the io_device_table into immovable memory, rather than regular gc<br>
- memory.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsiodev.c<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-29 08:57:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=68aa4cb52359c0c6e25bcf53735bb05030ee4a2b">68aa4cb52359c0c6e25bcf53735bb05030ee4a2b</a>
-<blockquote>
-<p>
- Fix typo in LICENSE file<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/LICENSE<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-27 15:21: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=d5ecb99d3641a95803c88e6df2f734d392a3be63">d5ecb99d3641a95803c88e6df2f734d392a3be63</a>
-<blockquote>
-<p>
- Make DCT filter finalize routine robust against double calling.<br>
-<br>
- Bug #695542 &quot;Crash on EPS on Mac and Linux&quot;<br>
-<br>
- The problem is that we close a DCT filter inside a gsave context, while<br>
- the file ref is still pointing at it.<br>
-<br>
- When the PostScript 'close' operator closes the DCT filter, we free the<br>
- memory associated with the stream state in the finalize routine. But the<br>
- PostScript file ref is still pointing at it, and when we grestore, the<br>
- finalize routine gets called again. Because the routine doesn't check for<br>
- NULL pointers before freeing, and indeed doesn't NULL the pointers after it<br>
- does free them, this leads to us freeing memory which has already been<br>
- freed.<br>
-<br>
- Apparently we've already fixed a number of similar problems in finalize<br>
- routines, probably caused by people not realising a finalize routine could<br>
- (surprisingly) be called more than once.<br>
-<br>
- In this commit we set the pointers to null after feeing the memory, and<br>
- check for null pointers before attempting to free the memory, and before<br>
- attempting to dereference any pointers.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/sdctc.c<br>
-gs/base/stream.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-27 09:05: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=9ef2c8188a86c5e19c93a38bb01b9297200bd896">9ef2c8188a86c5e19c93a38bb01b9297200bd896</a>
-<blockquote>
-<p>
- Bug 695543 - gs %stdin segfaults<br>
-<br>
- In zopen_file() when we're opening a Postscript device, ensure that we set the<br>
- &quot;state&quot; entry in the iodev structure before calling the device specific &quot;open&quot;<br>
- method - as we do elsewhere in the same circumstances. That is required to<br>
- properly access devices like &quot;%stdin&quot; and co.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-26 09:56: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=97ee68c17fd8709b4509b394b721524b7777c3bb">97ee68c17fd8709b4509b394b721524b7777c3bb</a>
-<blockquote>
-<p>
- Bug 695539: glyph mapping - handle &quot;missing&quot; codepoints<br>
-<br>
- When extending the glyph mapping in a font, the original code for adding the<br>
- codepoint to the font could assume the codepoint was valid as it was always<br>
- read from the Adobe Glyph List. But I added code to &quot;parse&quot; a codepoint from<br>
- the special &quot;uniXXXX&quot; type names, and that breaks that assumption.<br>
-<br>
- Handle the case where we reach that point with codepoint that doesn't exist in<br>
- the AGL.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_ttf.ps<br>
-gs/Resource/Init/gs_type1.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-25 23:42:50 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0c677ef110bb53460062da7586e37a37ea6eae52">0c677ef110bb53460062da7586e37a37ea6eae52</a>
-<blockquote>
-<p>
- Fix Bug #695535 Page not cleared upon resolution setting.<br>
-<br>
- Somewhat puzzling this hasn't come up before but PCL was changing the<br>
- resolution of a PCL job upon receiving a PJL command without erasing<br>
- the page. If the resolution is set on the command line or the device<br>
- default is used the normal page erasing happens with the job's<br>
- resolution already set.<br>
-<br>
-pcl/pcjob.c<br>
-pcl/pcl.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-25 09:47:14 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=53d8252202f860398be69a59d6a6da80aca551ce">53d8252202f860398be69a59d6a6da80aca551ce</a>
-<blockquote>
-<p>
- Fix typo when closing bfile and cfile. Thanks to Norbert Janssen.<br>
-<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-23 07:47:00 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=75a183ff51daebf8c3835f3d6e5107d70061a8ce">75a183ff51daebf8c3835f3d6e5107d70061a8ce</a>
-<blockquote>
-<p>
- Change the -Z: output to report parse done as well as page render done.<br>
-<br>
- This corresponds more closely the the information available with -Z: from<br>
- gs which provides Outputpage start and Outputpage end times. This is useful<br>
- for the 'overview' timing analysis, such as with bug 695374.<br>
-<br>
-pcl/pctop.c<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-23 09:18: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=98b066aad13281ce75471163959db727a5a9da58">98b066aad13281ce75471163959db727a5a9da58</a>
-<blockquote>
-<p>
- pdfwrite - fix a warning and an assignment to conditional<br>
-<br>
- Removing the assignment of a return value to code in order to eliminate a<br>
- compiler warning.<br>
-<br>
- The test of code against gs_error_interrupt was accidentally written as an<br>
- assignment, fixing this causes progressions in:<br>
- Bug690534.pdf<br>
- 586_-_missing_images_gs_SMask_not_applied.pdf<br>
- multiply_luminosity_masks_ignored.pdf<br>
-<br>
- These are progressions over 9.15 as well.<br>
-<br>
-gs/devices/vector/gdevpdft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-08 14:47: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=2454c0d599f3abdff7d7b002d54dd58549e948de">2454c0d599f3abdff7d7b002d54dd58549e948de</a>
-<blockquote>
-<p>
- Update docs, versions and dates for release candidate.<br>
-<br>
- Update docs, dates etc for second release candidate.<br>
-<br>
- Update stuff for release<br>
-<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-22 16:08: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=fd5858999c4117ef16f8127497bcc329e4006833">fd5858999c4117ef16f8127497bcc329e4006833</a>
-<blockquote>
-<p>
- accidentally left a line out of ee3d09<br>
-<br>
- Due to finger trouble, missed this line off the last commit<br>
-<br>
-gs/devices/vector/gdevpdft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-22 16:06: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=ee3d09d4efed339d15d6168f3ef72516d3391576">ee3d09d4efed339d15d6168f3ef72516d3391576</a>
-<blockquote>
-<p>
- pdfwrite - handle transparency mask of type TRANSPARENCY_MASK_None<br>
-<br>
- Bug #695482 &quot;Regression: empty PDF files written starting with ea6290b302598f13e7fb4c29aff73657989e693d&quot;<br>
-<br>
- commit ea6290b302598f13e7fb4c29aff73657989e693d introduced this type of<br>
- transparency mask, which is *not* concluded with an end transparency group.<br>
- Because pdfwrite didn't expect this, it led to 0 length output PDF files.<br>
-<br>
- This commit restores the functionality, it does not (apparently) produce<br>
- correct output from the test file using pdfwrite though.<br>
-<br>
- The differences here are all progressions.<br>
-<br>
-gs/devices/vector/gdevpdft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-22 14:34: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=a1a6d76aae77b28bfd805f06df4a1a9537fbc139">a1a6d76aae77b28bfd805f06df4a1a9537fbc139</a>
-<blockquote>
-<p>
- remove some C++ comments (and some other commented code)<br>
-<br>
-gs/devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-22 13:28:50 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=37837c01c7ca8461e9f458c061e27990dd94ad41">37837c01c7ca8461e9f458c061e27990dd94ad41</a>
-<blockquote>
-<p>
- remove an unused variable to silence a compiler warning<br>
-<br>
-gs/devices/gxfcopy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-22 10:42:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=202b0d827c4840410d01a6acb83c56277829f507">202b0d827c4840410d01a6acb83c56277829f507</a>
-<blockquote>
-<p>
- pdfwrite - close dangling substreams at end of page<br>
-<br>
- Inspired by bug #695482 but not intended as a fix, and also by bug #695354<br>
-<br>
- If we fail to close a substream (possibly because the PDF interpreter throws<br>
- an error) then this leaves a text_state associated with the substream<br>
- dangling, and potentially referencing other freed memory which can lead<br>
- to a crash in the garbage collector. In addition we can end up writing an<br>
- empty PDF file.<br>
-<br>
- This commit closes any substreams which are still open when a page is written<br>
- which ensures the memory is cleaned up, and that a valid (if broken) PDF<br>
- file gets written.<br>
-<br>
- Note that ps2write is (of course) different, and *expects* to have a substream<br>
- open at the end of the page, so in this case we have to close the page and then<br>
- clean up any dangling substreams afterwards.<br>
-<br>
- Although this appears to 'fix' bug #695482 its not a proper fix.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-22 08:51: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=9e5c21512649090ae563b584caec32fb6fdc2bb9">9e5c21512649090ae563b584caec32fb6fdc2bb9</a>
-<blockquote>
-<p>
- pdfwrite - free associated text state when closing a substream<br>
-<br>
- When we open a substream, we create a text state, but we did not prevoously<br>
- free the text state when closing the substream, which could lead to memory<br>
- leaks or if using the '%d' syntax for per-page PDF output, could lead to<br>
- crashes in the garbage collector.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdti.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-22 08:49: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=1cd582c342d1d754d85f5d89f39cbe672b9d9c67">1cd582c342d1d754d85f5d89f39cbe672b9d9c67</a>
-<blockquote>
-<p>
- pdfwrite - free FDArray from copied CIDFOnts when copy is freed<br>
-<br>
- further to commit 26a22e which freed copied descendant fonts from a copy of<br>
- a CIDFont when it was freed, here we free the FDArray itself from teh copy.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/gxfcopy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-19 13:38:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=26a22e6fd3dd42fdcaae568276f82b40d746bce9">26a22e6fd3dd42fdcaae568276f82b40d746bce9</a>
-<blockquote>
-<p>
- Free copied descendant font(s) when freeing a copied CIDFont<br>
-<br>
- When we copy a CIDFont (other than a TrueType CIDFont) we also copy the<br>
- descendant fonts. But when we free them (gs_free_copied_font) we only free<br>
- the CIDFont, leaving the descendants dangling. This can cause problems<br>
- (seg fault) when we garbage collect the descendants.<br>
-<br>
- Here we free the descendants as well. This is complicated by the fact that<br>
- the parent CIDFont 'glyphs' space is shared by all the descendants, so<br>
- we *don't* want to free that when we free the descendant.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/gxfcopy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-17 14:02: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=bb35d2d7bc93b1fff5e182be370d64b24129a09e">bb35d2d7bc93b1fff5e182be370d64b24129a09e</a>
-<blockquote>
-<p>
- Bug 695490: GL stick font seg fault<br>
-<br>
- Initialise width cache values for stick font and 531 font.<br>
-<br>
- No cluster differences.<br>
-<br>
-pcl/pglabel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-17 13:46: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=d4c1bd25347e42d0668a73a57bd9aa8ca904be1a">d4c1bd25347e42d0668a73a57bd9aa8ca904be1a</a>
-<blockquote>
-<p>
- Bug 695491: parallel make fail due to pconfig.h<br>
-<br>
- Create a target for pconfig.h and have it as a dependency where required,<br>
- rather than have each individual target that needs it copy pconf.h to<br>
- pconfig.h which could cause a &quot;collision&quot; during a parallel build.<br>
-<br>
- No cluster differences.<br>
-<br>
-pcl/pcl.mak<br>
-pl/pl.mak<br>
-psi/psi.mak<br>
-pxl/pxl.mak<br>
-xps/xps.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-17 12:23: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=ec56638c8cc6176c2ee935a7ba43cd0af2a02fd1">ec56638c8cc6176c2ee935a7ba43cd0af2a02fd1</a>
-<blockquote>
-<p>
- Bug 695492: fix seg fault regression with '-h'<br>
-<br>
- When called with the '-h' parameter, we don't fully initialise the PS<br>
- interpreter. In which case, we shouldn't try to use the PS interpreter<br>
- when we shut down.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-15 19:33:32 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b66f287128616340b68243bf5384acac066db561">b66f287128616340b68243bf5384acac066db561</a>
-<blockquote>
-<p>
- Fix colors for -sDEVICE=bitrgb -dGrayValues=16<br>
-<br>
- This device was using the default, but that code was encoding the<br>
- color as 5x5x5 RGB since the bit device selects a color_info.depth<br>
- of 16. Import the logic and fix it for the 4-bit RGB case (12-bit<br>
- values in 16-bit pixels).<br>
-<br>
-gs/devices/gdevbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-15 17:51:56 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=10d517b4954e5adaaf7cc8d823db68e8e1b157f3">10d517b4954e5adaaf7cc8d823db68e8e1b157f3</a>
-<blockquote>
-<p>
- Fix the -dRGB option to work with BITS = 1, 2, 4 or 8<br>
-<br>
- Note that the -sDEVICE=bitrgb -dGrayValues=16 was broken due to<br>
- improper encoding. This will be fixed in a separate commit.<br>
-<br>
-gs/lib/viewraw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-15 08:59:08 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb486a42382152c5d7448eabfa7e7a40f8226c81">eb486a42382152c5d7448eabfa7e7a40f8226c81</a>
-<blockquote>
-<p>
- Improvements for viewraw.ps with RGB input for 1 and 2 bpc.<br>
-<br>
- Note BITS=4 is still not supported.<br>
-<br>
-gs/lib/viewraw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-16 14:01:36 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e619c7a51e45c05c3d02792c3353b3c731f3884">2e619c7a51e45c05c3d02792c3353b3c731f3884</a>
-<blockquote>
-<p>
- pdfwrite - mark freshly opened device as 'open'<br>
-<br>
- When using the '%d' format for output files, the pdf_output_page() routine<br>
- closes and reopens the pdfwrite device (to flush the device, creating<br>
- a PDF file). However, it doesn't mark the 'is_open' member of the device,<br>
- and pdfwrite doesn't do that itself, relying on the caller (normally<br>
- gs_opendevice()) to set the flag.<br>
-<br>
- Later we get a setpagedevice, this executes .setdevice which calls<br>
- gs_setdevice_no_erase() which checks dev-&gt;is_open and if it is not open<br>
- then it opens it. This causes pdf_open to allocate all kinds of new<br>
- memory areas, without freeing the old ones, as well as temporary files and<br>
- possibly other structures/memory allocations.<br>
-<br>
- Surprisingly this doesn't actually seem to cause a problem, but its not<br>
- right, and surely will cause problems one day, its definitely causing<br>
- memory leaks in non-GC interpreters.<br>
-<br>
- So this tiny commit just sets the flag is_open when we open the device in<br>
- pdf_output_page.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-15 11:02: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=d0816120fdae4e9592269d98e933cbdf99faad5e">d0816120fdae4e9592269d98e933cbdf99faad5e</a>
-<blockquote>
-<p>
- Bug 695483: disable BGPrint before we shutdown interpreter<br>
-<br>
- Before we start the process of shutting down the PS interpreter, disable BGPrint<br>
- (and set NumRenderingThreads to 0, just for safety). If we don't do this, the<br>
- &quot;parent&quot; rendering thread will continue preparations for the next page whilst<br>
- we shutdown the interpreter, and will thus attempt to access some objects<br>
- subject to garbage collection (such as the I/O device table).<br>
-<br>
- Additionally, when a device switches from BGPrint enabled to disabled, make sure<br>
- we tear down the rendering thread(s) and get rid off the BGPrint related data.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevprn.c<br>
-gs/psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-15 10:21: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=0d22694c3798bf13120be35322b7984fd2296e0f">0d22694c3798bf13120be35322b7984fd2296e0f</a>
-<blockquote>
-<p>
- Bug 695486: initialise c_alone in current chunk (cc)<br>
-<br>
- When we (re-)initialise an allocator, we have to initialise the contents of the<br>
- current chunk (cc) entry - initialise to &quot;false&quot; since that's the common case.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-15 15:19: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=a7b8c4f39f0f8f1f0872c2ae8faff1ddd35cbdb2">a7b8c4f39f0f8f1f0872c2ae8faff1ddd35cbdb2</a>
-<blockquote>
-<p>
- pdfwrite - free pdfwrite's 'complete' font copy if required<br>
-<br>
- Bug #695484 &quot;Regression: seg fault with debug build in pdfwrite starting with ceb5e2f006bf554a56701ee2f2c228841b324a4b&quot;<br>
-<br>
- The problem was caused because pdfwrite can maintain two copies of a font,<br>
- a subset and a complete copy, depending on settings. We were properly freeing<br>
- the subset, but not the complete copy.<br>
-<br>
- This has been a long-standing undetected memory leak, but only on systems<br>
- without garbage collection, because the copied font is subject to GC, and<br>
- indeed this was causing the actual fault. When we restored at the end of the<br>
- file, the copied font was garbage collected, which caused it to try nd free<br>
- any glyphs from its font cache. But the font cache is now (since the commit<br>
- in the bug title) pointing at the pdfwrite font cache, and that has already<br>
- been freed before we get to the end of job restore, resutling in a seg fault.<br>
-<br>
- Here we free the complete font copy if one has been allocated.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-14 23:00: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=0614577faa0b89574b0d9c6c9cabe77398183a40">0614577faa0b89574b0d9c6c9cabe77398183a40</a>
-<blockquote>
-<p>
- Fix Bug 695481 - Barcode font scaled incorrectly.<br>
-<br>
- The downloaded font in this file (the barcode) used the typeface<br>
- family designation of 0 which is reserved for the lineprinter font.<br>
- Our interpreter scales lineprinter specially and identifies<br>
- lineprinter with its typeface number (0), thus the barcode font was<br>
- scaled as if it were the lineprinter font. Now we check the typeface<br>
- number is 0 and the font is internal which will uniquely identify the<br>
- lineprinter font and not confuse other fonts with it.<br>
-<br>
- Technically the font is broken and shouldn't be accepted, the typeface<br>
- family numbers documented by HP should not be reused by downloaded<br>
- fonts, but HP printers seem to print the job.<br>
-<br>
-pcl/pctext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-12 14:49:08 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=94786ac00b285be997aaddbc689180478a47e270">94786ac00b285be997aaddbc689180478a47e270</a>
-<blockquote>
-<p>
- Get rid of last vestiges of pswrite....<br>
-<br>
- Remove epswrite (the final &quot;subdevice&quot; of pswrite) and references to it.<br>
-<br>
- Also remove the gdevps.c source file.<br>
-<br>
- Cluster differences only in files that enumerate the devices list, for<br>
- example:<br>
- 430-01.ps<br>
-<br>
-doc/who_owns_what.txt<br>
-gs/Makefile.in<br>
-gs/base/macos-mcp.mak<br>
-gs/base/macosx.mak<br>
-gs/base/openvms.mak<br>
-gs/base/openvms.mmk<br>
-gs/base/unix-gcc.mak<br>
-gs/base/unixansi.mak<br>
-gs/configure.ac<br>
-gs/devices/devs.mak<br>
-gs/devices/vector/gdevps.c<br>
-gs/lib/eps2eps<br>
-gs/lib/eps2eps.bat<br>
-gs/lib/eps2eps.cmd<br>
-gs/man/ps2ps.1<br>
-gs/psi/msvc.mak<br>
-gs/psi/os2.mak<br>
-gs/toolbin/pre.chk<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-10 11:57:10 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea6290b302598f13e7fb4c29aff73657989e693d">ea6290b302598f13e7fb4c29aff73657989e693d</a>
-<blockquote>
-<p>
- Fix Bug 695471, cust 532. /SMask /None did not remove prior SMask<br>
-<br>
- The 'gssmask' proc in pdf_draw.ps doesn't remove a previous SMask<br>
- when the ExtGState is set to /SMask /None. Change the logic to<br>
- issue a &quot;dummy&quot; .begintransparencymaskgroup (that does NOT have a<br>
- corresponding .endtransparencymask) and add handling for this type<br>
- of SMask in the code. This does not result in a colorspace change,<br>
- but only frees the tos maskbuf. Seen with MSN_Chrome.pdf<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/base/gdevp14.c<br>
-gs/base/gstparam.h<br>
-gs/base/gstrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-27 10:08:45 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3b2d19e8a459610ba50560ee004eae8736644dc1">3b2d19e8a459610ba50560ee004eae8736644dc1</a>
-<blockquote>
-<p>
- Add lib/viewraw.ps utility to view &quot;raw&quot; files<br>
-<br>
- An extended version of lib/viewcmyk.ps so that &quot;raw&quot; output from<br>
- bit, bitrgb or bitcmyk can be displayed or converted. For example:<br>
- gswin32c -sDEVICE=bitrgb -dGrayValues=256 -o x.rgb examples/tiger.eps<br>
- can be viewed with:<br>
- gswin32c -dRGB -dBITS=8 -- lib/viewraw.ps x.rgb 612<br>
-<br>
-gs/lib/viewraw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-08 13:52: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=fcb0c5ee27b9d5a769545f547ee7afdcf8e9829f">fcb0c5ee27b9d5a769545f547ee7afdcf8e9829f</a>
-<blockquote>
-<p>
- Bump version.<br>
-<br>
- Usual cluster differences.....<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-22 11:12: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=8b2e4263a230d0e7cb262532e0f347976f4b289a">8b2e4263a230d0e7cb262532e0f347976f4b289a</a>
-<blockquote>
-<p>
- Update stuff for release<br>
-<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-17 12:23: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=404e71e01ad665deb7435fe37aad6034380297e3">404e71e01ad665deb7435fe37aad6034380297e3</a>
-<blockquote>
-<p>
- Bug 695492: fix seg fault regression with '-h'<br>
-<br>
- When called with the '-h' parameter, we don't fully initialise the PS<br>
- interpreter. In which case, we shouldn't try to use the PS interpreter<br>
- when we shut down.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-16 11:48:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=96a55a20f5b0d852d2118a1ac318293c6a0f716e">96a55a20f5b0d852d2118a1ac318293c6a0f716e</a>
-<blockquote>
-<p>
- Update docs, dates etc for second release candidate.<br>
-<br>
-gs/base/gscdef.c<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-15 11:02: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=551d7dd426fe8ab7f2c0c9d90339784e2b643bad">551d7dd426fe8ab7f2c0c9d90339784e2b643bad</a>
-<blockquote>
-<p>
- Bug 695483: disable BGPrint before we shutdown interpreter<br>
-<br>
- Before we start the process of shutting down the PS interpreter, disable BGPrint<br>
- (and set NumRenderingThreads to 0, just for safety). If we don't do this, the<br>
- &quot;parent&quot; rendering thread will continue preparations for the next page whilst<br>
- we shutdown the interpreter, and will thus attempt to access some objects<br>
- subject to garbage collection (such as the I/O device table).<br>
-<br>
- Additionally, when a device switches from BGPrint enabled to disabled, make sure<br>
- we tear down the rendering thread(s) and get rid off the BGPrint related data.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevprn.c<br>
-gs/psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-15 10:21: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=51b9c7dc2a471b9c3dfe6400c0a55d90db4fec16">51b9c7dc2a471b9c3dfe6400c0a55d90db4fec16</a>
-<blockquote>
-<p>
- Bug 695486: initialise c_alone in current chunk (cc)<br>
-<br>
- When we (re-)initialise an allocator, we have to initialise the contents of the<br>
- current chunk (cc) entry - initialise to &quot;false&quot; since that's the common case.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-15 15:19: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=fec643c7e29810c0c5381bd86ba31ff3595bc9ba">fec643c7e29810c0c5381bd86ba31ff3595bc9ba</a>
-<blockquote>
-<p>
- pdfwrite - free pdfwrite's 'complete' font copy if required<br>
-<br>
- Bug #695484 &quot;Regression: seg fault with debug build in pdfwrite starting with ceb5e2f006bf554a56701ee2f2c228841b324a4b&quot;<br>
-<br>
- The problem was caused because pdfwrite can maintain two copies of a font,<br>
- a subset and a complete copy, depending on settings. We were properly freeing<br>
- the subset, but not the complete copy.<br>
-<br>
- This has been a long-standing undetected memory leak, but only on systems<br>
- without garbage collection, because the copied font is subject to GC, and<br>
- indeed this was causing the actual fault. When we restored at the end of the<br>
- file, the copied font was garbage collected, which caused it to try nd free<br>
- any glyphs from its font cache. But the font cache is now (since the commit<br>
- in the bug title) pointing at the pdfwrite font cache, and that has already<br>
- been freed before we get to the end of job restore, resutling in a seg fault.<br>
-<br>
- Here we free the complete font copy if one has been allocated.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-14 23:00: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=d10d0b9f9a4c11ef11f08849cf0f0f0405ada6c6">d10d0b9f9a4c11ef11f08849cf0f0f0405ada6c6</a>
-<blockquote>
-<p>
- Fix Bug 695481 - Barcode font scaled incorrectly.<br>
-<br>
- The downloaded font in this file (the barcode) used the typeface<br>
- family designation of 0 which is reserved for the lineprinter font.<br>
- Our interpreter scales lineprinter specially and identifies<br>
- lineprinter with its typeface number (0), thus the barcode font was<br>
- scaled as if it were the lineprinter font. Now we check the typeface<br>
- number is 0 and the font is internal which will uniquely identify the<br>
- lineprinter font and not confuse other fonts with it.<br>
-<br>
- Technically the font is broken and shouldn't be accepted, the typeface<br>
- family numbers documented by HP should not be reused by downloaded<br>
- fonts, but HP printers seem to print the job.<br>
-<br>
-pcl/pctext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-12 14:49:08 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f4034b2aa85e685c66e98be8c31c511cd9a5169e">f4034b2aa85e685c66e98be8c31c511cd9a5169e</a>
-<blockquote>
-<p>
- Get rid of last vestiges of pswrite....<br>
-<br>
- Remove epswrite (the final &quot;subdevice&quot; of pswrite) and references to it.<br>
-<br>
- Also remove the gdevps.c source file.<br>
-<br>
- Cluster differences only in files that enumerate the devices list, for<br>
- example:<br>
- 430-01.ps<br>
-<br>
-doc/who_owns_what.txt<br>
-gs/Makefile.in<br>
-gs/base/macos-mcp.mak<br>
-gs/base/macosx.mak<br>
-gs/base/openvms.mak<br>
-gs/base/openvms.mmk<br>
-gs/base/unix-gcc.mak<br>
-gs/base/unixansi.mak<br>
-gs/configure.ac<br>
-gs/devices/devs.mak<br>
-gs/devices/vector/gdevps.c<br>
-gs/lib/eps2eps<br>
-gs/lib/eps2eps.bat<br>
-gs/lib/eps2eps.cmd<br>
-gs/man/ps2ps.1<br>
-gs/psi/msvc.mak<br>
-gs/psi/os2.mak<br>
-gs/toolbin/pre.chk<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-27 10:08:45 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bbe97e4cfc3d725f42ae34125c716902faf72977">bbe97e4cfc3d725f42ae34125c716902faf72977</a>
-<blockquote>
-<p>
- Add lib/viewraw.ps utility to view &quot;raw&quot; files<br>
-<br>
- An extended version of lib/viewcmyk.ps so that &quot;raw&quot; output from<br>
- bit, bitrgb or bitcmyk can be displayed or converted. For example:<br>
- gswin32c -sDEVICE=bitrgb -dGrayValues=256 -o x.rgb examples/tiger.eps<br>
- can be viewed with:<br>
- gswin32c -dRGB -dBITS=8 -- lib/viewraw.ps x.rgb 612<br>
-<br>
-gs/lib/viewraw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-08 14:47: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=540a228f026bf3abd288d5e88a7ef74345600380">540a228f026bf3abd288d5e88a7ef74345600380</a>
-<blockquote>
-<p>
- Update docs, versions and dates for release candidate.<br>
-<br>
-gs/base/gscdef.c<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-<h2><a name="Version9.15"></a>Version 9.15 (2014-09-22)</h2>
-
-<p>This is the eleventh full release in the stable 9.x series, and is
-primarily a maintenance release.
-
-<p> Highlights in this release include:
-<ul>
-<li>
-<p>Ghostscript now supports the PDF security handler revision 6.
-</li>
-<li>
-<p>The pdfwrite and ps2write (and related) devices can now be forced to &quot;flatten&quot;
-glyphs into &quot;basic&quot; marking operations (rather than writing fonts to the output),
-by giving the <code>-dNoOutputFonts</code> command line option (defaults to &quot;false&quot;)
-</li>
-<li>
-<p> PostScript programs can now use get_params or get_param to
-determine if a page contains color markings by reading the pageneutralcolor
-state from the device (so whether the page is &quot;color&quot; or &quot;mono&quot;).
-<p> Note that this is only accurate when in clist mode, so <code>-dMaxBitmap=0</code>
-and <code>-dGrayDetection=true</code> should both be used.
-</li>
-<li>
-<p> The pdfwrite device now supports Link annotations with GoTo and GoToR actions
-</li>
-<li>
-<p> The pdfwrite device now supports BMC/BDC/EMC pdfmarks
-</li>
-<li>
-<p> Regarding the new color management for the pdfwrite device introduced in the
-previous release, the proscription on using the new color management when producing
-PDF/A-1 compliant files is now lifted.
-<p> To reiterate, also, with the new color management implementation, using the
-UseCIEColor option is <strong><em>strongly</em></strong> discouraged.
-<p> For further information on the new pdfwrite color management,
-see: <a href="Ps2pdf.htm#Color_Conversion_and_Management">Color Conversion and Management</a>
-</li>
-<li>
-<p>Plus the usual round of bug fixes, compatibility changes, and incremental improvements.
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.15_Incompatible_changes"></a>Incompatible changes</h3>
-<p>
-No recorded incompatible changes.
-
-<h3><a name="9.15_changelog"></a>Changelog</h3>
-<p><strong>2014-09-08 09:36:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=551d7dd426fe8ab7f2c0c9d90339784e2b643bad">551d7dd426fe8ab7f2c0c9d90339784e2b643bad</a>
-<blockquote>
-<p>
- Bug 695483: disable BGPrint before we shutdown interpreter<br>
-<br>
- Before we start the process of shutting down the PS interpreter, disable BGPrint<br>
- (and set NumRenderingThreads to 0, just for safety). If we don't do this, the<br>
- &quot;parent&quot; rendering thread will continue preparations for the next page whilst<br>
- we shutdown the interpreter, and will thus attempt to access some objects<br>
- subject to garbage collection (such as the I/O device table).<br>
-<br>
- Additionally, when a device switches from BGPrint enabled to disabled, make sure<br>
- we tear down the rendering thread(s) and get rid off the BGPrint related data.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevprn.c<br>
-gs/psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-15 10:21: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=51b9c7dc2a471b9c3dfe6400c0a55d90db4fec16">51b9c7dc2a471b9c3dfe6400c0a55d90db4fec16</a>
-<blockquote>
-<p>
- Bug 695486: initialise c_alone in current chunk (cc)<br>
-<br>
- When we (re-)initialise an allocator, we have to initialise the contents of the<br>
- current chunk (cc) entry - initialise to &quot;false&quot; since that's the common case.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-15 15:19: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=fec643c7e29810c0c5381bd86ba31ff3595bc9ba">fec643c7e29810c0c5381bd86ba31ff3595bc9ba</a>
-<blockquote>
-<p>
- pdfwrite - free pdfwrite's 'complete' font copy if required<br>
-<br>
- Bug #695484 &quot;Regression: seg fault with debug build in pdfwrite starting with ceb5e2f006bf554a56701ee2f2c228841b324a4b&quot;<br>
-<br>
- The problem was caused because pdfwrite can maintain two copies of a font,<br>
- a subset and a complete copy, depending on settings. We were properly freeing<br>
- the subset, but not the complete copy.<br>
-<br>
- This has been a long-standing undetected memory leak, but only on systems<br>
- without garbage collection, because the copied font is subject to GC, and<br>
- indeed this was causing the actual fault. When we restored at the end of the<br>
- file, the copied font was garbage collected, which caused it to try nd free<br>
- any glyphs from its font cache. But the font cache is now (since the commit<br>
- in the bug title) pointing at the pdfwrite font cache, and that has already<br>
- been freed before we get to the end of job restore, resutling in a seg fault.<br>
-<br>
- Here we free the complete font copy if one has been allocated.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-14 23:00: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=d10d0b9f9a4c11ef11f08849cf0f0f0405ada6c6">d10d0b9f9a4c11ef11f08849cf0f0f0405ada6c6</a>
-<blockquote>
-<p>
- Fix Bug 695481 - Barcode font scaled incorrectly.<br>
-<br>
- The downloaded font in this file (the barcode) used the typeface<br>
- family designation of 0 which is reserved for the lineprinter font.<br>
- Our interpreter scales lineprinter specially and identifies<br>
- lineprinter with its typeface number (0), thus the barcode font was<br>
- scaled as if it were the lineprinter font. Now we check the typeface<br>
- number is 0 and the font is internal which will uniquely identify the<br>
- lineprinter font and not confuse other fonts with it.<br>
-<br>
- Technically the font is broken and shouldn't be accepted, the typeface<br>
- family numbers documented by HP should not be reused by downloaded<br>
- fonts, but HP printers seem to print the job.<br>
-<br>
-pcl/pctext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-12 14:49:08 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f4034b2aa85e685c66e98be8c31c511cd9a5169e">f4034b2aa85e685c66e98be8c31c511cd9a5169e</a>
-<blockquote>
-<p>
- Get rid of last vestiges of pswrite....<br>
-<br>
- Remove epswrite (the final &quot;subdevice&quot; of pswrite) and references to it.<br>
-<br>
- Also remove the gdevps.c source file.<br>
-<br>
- Cluster differences only in files that enumerate the devices list, for<br>
- example:<br>
- 430-01.ps<br>
-<br>
-doc/who_owns_what.txt<br>
-gs/Makefile.in<br>
-gs/base/macos-mcp.mak<br>
-gs/base/macosx.mak<br>
-gs/base/openvms.mak<br>
-gs/base/openvms.mmk<br>
-gs/base/unix-gcc.mak<br>
-gs/base/unixansi.mak<br>
-gs/configure.ac<br>
-gs/devices/devs.mak<br>
-gs/devices/vector/gdevps.c<br>
-gs/lib/eps2eps<br>
-gs/lib/eps2eps.bat<br>
-gs/lib/eps2eps.cmd<br>
-gs/man/ps2ps.1<br>
-gs/psi/msvc.mak<br>
-gs/psi/os2.mak<br>
-gs/toolbin/pre.chk<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-27 10:08:45 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bbe97e4cfc3d725f42ae34125c716902faf72977">bbe97e4cfc3d725f42ae34125c716902faf72977</a>
-<blockquote>
-<p>
- Add lib/viewraw.ps utility to view &quot;raw&quot; files<br>
-<br>
- An extended version of lib/viewcmyk.ps so that &quot;raw&quot; output from<br>
- bit, bitrgb or bitcmyk can be displayed or converted. For example:<br>
- gswin32c -sDEVICE=bitrgb -dGrayValues=256 -o x.rgb examples/tiger.eps<br>
- can be viewed with:<br>
- gswin32c -dRGB -dBITS=8 -- lib/viewraw.ps x.rgb 612<br>
-<br>
-gs/lib/viewraw.ps<br>
-<p>
-</blockquote>
-<hr>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8605f67582ae2e2e619ab6fbab9888a23f37fdb9">8605f67582ae2e2e619ab6fbab9888a23f37fdb9</a>
-<blockquote>
-<p>
- pdfwrite - tidy up some compiler warnings<br>
-<br>
- No effect, just silences the compiler or scan-build.<br>
-<br>
-gs/devices/vector/gdevpdfp.c<br>
-gs/devices/vector/gdevpsdp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-04 14:49:21 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b4c9acd0ca532d19421fdf83aa9ad71895fad753">b4c9acd0ca532d19421fdf83aa9ad71895fad753</a>
-<blockquote>
-<p>
- Remove the uproduct and co targets.<br>
-<br>
- Replaced (for now) with a brief message about being unsupported, and to use<br>
- configure --with-ufst=&lt;&gt;<br>
-<br>
- No cluster differences.<br>
-<br>
-Makefile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-04 14:34:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91e8954e01996853ce6dc1318465c7b55e9d1f90">91e8954e01996853ce6dc1318465c7b55e9d1f90</a>
-<blockquote>
-<p>
- Better mkromfs support for cross compile<br>
-<br>
- When cross compiling between platforms of differening endianness, mkromfs will<br>
- now create output usable on the target architecture.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/mkromfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-04 14:31: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=bfeeadc3d534cb01fe6dd3bfb21a0af1e55b0a48">bfeeadc3d534cb01fe6dd3bfb21a0af1e55b0a48</a>
-<blockquote>
-<p>
- Tweak &quot;search&quot; for default CID fallback font.<br>
-<br>
- Fix an issue where the default fallback font could not be found if the<br>
- GenericResourceDir was a relative path.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_cidtt.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-05 15:03: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=201ff60b950912c09d22b3b4ed0b57ed75c3587a">201ff60b950912c09d22b3b4ed0b57ed75c3587a</a>
-<blockquote>
-<p>
- pdfwrite - consume Distiller params even when LockDistillerparams is true<br>
-<br>
- Bug #695468 &quot;/rangecheck in .installpagedevice error when combining LockDistillerParams, setpagedevice, and restore&quot;<br>
-<br>
- Previously when LockDistillerParams was true the distiller param parsing<br>
- code did not get called. This left the Distiller parameter key/value<br>
- pairs 'untouched' in the parameter list.<br>
-<br>
- Ordinarily this is not a problem, but .installpagedevice, which is called<br>
- during restore to reset the page device parameters, insists that all keys<br>
- must be consumed and throws an error if they are not.<br>
-<br>
- This patch alters the distiller parameter parsing to read all the parameters<br>
- no matter what the setting of LockDisillerParams. The values are read into<br>
- a dummy parameter structure, when complete they are either copied back to<br>
- the real structure or, if LockDistillerParams is set, discarded. If we<br>
- discard the parameters we clean up the memory rather than relying on garbage<br>
- collection to do it for us.<br>
-<br>
- I don't think the pdfwrite device currently does this when the device is<br>
- closed, which would be a memory leak, if we ever decide we need to address<br>
- this then we can use the code here.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfp.c<br>
-gs/devices/vector/gdevpsdp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-04 13:16: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=ce3445892ca6094a5c681667b1ecc1aa07c87254">ce3445892ca6094a5c681667b1ecc1aa07c87254</a>
-<blockquote>
-<p>
- Improved form handling of clip areas<br>
-<br>
- Bug #695307 &quot;Preservation of PostScript form elides form content&quot;<br>
-<br>
- When a device (such as pdfwrite) hands back a matrix to set as the CTM<br>
- (pdfwrite does this to capture the form unscaled), we need to account for<br>
- that CTM when we reset the clip, otherwise we can end up clipping content.<br>
-<br>
- Also, rather than using +/- page boundaries, we use +/- the form BBox.<br>
-<br>
- This shows 2 minor progressions in the test suite.<br>
-<br>
-gs/psi/zform.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-02 15:27:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ceb5e2f006bf554a56701ee2f2c228841b324a4b">ceb5e2f006bf554a56701ee2f2c228841b324a4b</a>
-<blockquote>
-<p>
- Address leaking font cache in PCL interpreter<br>
-<br>
- Bug #695017 &quot;pcfont_do_reset() leaks memory&quot;<br>
-<br>
- The PCL interpreter should free its font cache on exit, but it does not.<br>
- This is because of the fact that when we copy fonts the font cache of the<br>
- original font is copied to the font cache of the copied font. Later, when<br>
- a high level device wants to retrieve glyph information, the font code<br>
- uses the font cache from the copied font.<br>
-<br>
- This doesn't immediately seem like a problem, it seems like we should be<br>
- able to defer freeing the font cache until after we've closed the device,<br>
- and that would satisfy pdfwrite. However, the way that PCL 'passthrough'<br>
- works, the PCL interpreter can be run 'inside' the PXL interpreter. If we<br>
- free the PCL interpreter font cache when it exits then pdfwrite has font<br>
- copies which are still pointing at the freed font cache.<br>
-<br>
- We did discuss having the PCL/PXL interpreter set the gs_lib_ctx font_dir<br>
- (it currently dos not do so) and having pdfwrite set the font cache of the<br>
- fonts it copies use that, instead of the font cache from the original font.<br>
- But this seemed to me likely to run into the possibility of the same problem<br>
- recurring in future.<br>
-<br>
- Instead, we have pdfwrite create and maintain its own font cache. When pdfwrite<br>
- copies a font it replaces the font cache pointer (which is initially the same<br>
- as the original font) with the new pdfwrite-specific font cache.<br>
-<br>
- This means that any interpreter can free its font cache and pdfwrite will<br>
- still be able to use its own font cache when retrieving glyph information.<br>
-<br>
- This commit includes both the changes to pdfwrite to enable the new font cache<br>
- and the changes to the PCL/PXL interpreter to free the font cache when the<br>
- interpreter is done with it.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfb.h<br>
-gs/devices/vector/gdevpdfx.h<br>
-gs/devices/vector/gdevpdtb.c<br>
-pcl/pcfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-09-02 09:40:20 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=884b9e456336b1fd7ddb3c50726be5469159421a">884b9e456336b1fd7ddb3c50726be5469159421a</a>
-<blockquote>
-<p>
- Bug 695235: off-by-one error in trio<br>
-<br>
- Tweak to deal with off-by-one errors due to casting of doubles in trio.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/trio/trio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-29 17:19:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c670fd6b0852aa057103632630bab81c9317b613">c670fd6b0852aa057103632630bab81c9317b613</a>
-<blockquote>
-<p>
- Tweak the libtiff configure invocation to use relative paths.<br>
-<br>
- No cluster differences.<br>
-<br>
-configure.ac<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-29 16:05: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=d0c3d8e6b0f5ce246ad5e3d08b1628b529f99582">d0c3d8e6b0f5ce246ad5e3d08b1628b529f99582</a>
-<blockquote>
-<p>
- Add quoting around paths for libtiff configure.<br>
-<br>
- No cluster differences.<br>
-<br>
-configure.ac<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-28 10:09: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=3ff453592e3ae6d98a640047765a5baf1e345964">3ff453592e3ae6d98a640047765a5baf1e345964</a>
-<blockquote>
-<p>
- More work with setpagedevice<br>
-<br>
- commit 55bd0a59caf26a59f852e2dec5b76ad399d9408b fixed the problems with<br>
- RedValues and friends, but at the cost of preventing these keys being set<br>
- by setpagedevice.<br>
-<br>
- This commit allows them to be set by creating a 'write only' dictioanry<br>
- whose keys are removed from the initial device dictionary before we make it<br>
- read-only and send it to setpagedevice.<br>
-<br>
- See the comments in the commit for further details.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-27 14: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=55bd0a59caf26a59f852e2dec5b76ad399d9408b">55bd0a59caf26a59f852e2dec5b76ad399d9408b</a>
-<blockquote>
-<p>
- Fix setpagedevice so that changing ProcessColorModel works<br>
-<br>
- Bug #695439 &quot;Reference to free memory, or segfault with release build&quot;<br>
-<br>
- The problem is the horrendous way our implementation of setpagedevice works.<br>
- Where we should query the device for its parameters, our implementation<br>
- maintains a dictionary (initially built by querying the device) which is<br>
- updated by calls to setpagedevice.<br>
-<br>
- Clearly at some time in the past someone has discovered that this breaks<br>
- badly if the device changes a parameter itself, as this won't be reflected<br>
- in the saved dictionary. So the '.dynamicppkeys' dictionary was defined,<br>
- whose sole purpose is to hold a list of keys whose values must be refreshed<br>
- from the device.<br>
-<br>
- However, this dictionary is *also* used to prevent those same keys being<br>
- sent to the device.....<br>
-<br>
- This means that commit 2eda51b48c7e97adf7c46fc3d7eb34fcdf6061e6 prevented<br>
- any changes to OutputICCProfile being sent to the device.<br>
-<br>
- So I've now made 2 dictionaries with separate purposes, one is for 'read only'<br>
- keys which should not be sent to the device, and one which contains the list<br>
- of keys which must be read back from the device to replace the stored values<br>
- in our dictionary. Keys may appear in both, either, or neither.<br>
-<br>
- The problem in this bug is that we create our initial dictionary when the<br>
- device is in DeviceRGB, and we store the RedValues, GreenValues, BlueValues<br>
- and GrayValues from the device in our stored dictionary. Then we execute<br>
- code to change the ProcessColorModel to DeviceGray. This alters the values<br>
- of the RedValues etc in the device. But these are *not* copied into our<br>
- stored dictionary. Later we call .installpagedevice which does not change<br>
- the ProcessColorModel, but does attempt to set the RedValues etc, which are<br>
- invalid for a DeviceGray ProcessCOlorModel, leading to a rangecheck.<br>
-<br>
- I had hoped that adding these keys to the volatile dictionary would be<br>
- sufficient to fix the problem, but it seems that we don't update our stored<br>
- dictionary with these parameters. The only way to fix this turned out to be<br>
- to add the keys to the 'read only keys' dictionary so that we don't try and<br>
- send them to the device.<br>
-<br>
- I'm not completely sure this is sensible, it isn't obvious to me what these<br>
- values are for, so I can't be certain that they should become 'read only'.<br>
- However, its the simplest way to solve this problem.<br>
-<br>
- Of course the right way to fix this is to change our horrible setpagedevice<br>
- code so that it works the way the spec says it should.<br>
-<br>
- The fix described above resolves the memory warning for me as well.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-25 15:16:13 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ce2fca754b4ba5bce4194bae382ef1d46abaf00">5ce2fca754b4ba5bce4194bae382ef1d46abaf00</a>
-<blockquote>
-<p>
- pdfwrite - fix handling of Tx fields in AcroForms<br>
-<br>
- Bug #695438 &quot;AcroForm text fields not being rendered&quot;<br>
-<br>
- There are multiple parts to this fix.<br>
-<br>
- 1) Alter the default of the NeedAppearances key in AcroForms and AcroForm<br>
- field dictionaries to true so that if its not present we will generate<br>
- Appearances for fields which have none. (we still won't generate them if<br>
- the field is present and set to false, though Acrobat does)<br>
-<br>
- 2) Fix the Length key of the Form dictionary we generate for Tx fields,<br>
- previously it was set to 0, so the form wasn't ever executed.<br>
-<br>
- 3) If there is no 'V' key in the Field dictionary for a Tx field, use the<br>
- /DV key instead. If still no key then use an empty string.<br>
-<br>
- These changes uncovered some interesting additional problems.<br>
-<br>
- 1) Bug687498 has an AcroForm with a Tx field, declared as multiline, where<br>
- the actual data is an empty string. Now that we actually execute the Form<br>
- this causes an error. Add a check to treat strings with less than 2 bytes<br>
- as single line, so that splitstring doesn't throw an error.<br>
-<br>
- 2) Bug692477.pdf, now that we default 'NeedAppearances' to true, we discover<br>
- that this file has a Fields array where every element is the null object,<br>
- which causes errors trying to extract dictionary key/value pairs from it.<br>
- Add a check to see that the Field element is a dictionary, and ignore it if<br>
- it isn't.<br>
-<br>
- No differences expected, we don't test with -dShowAcroForm<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-20 08:54:16 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2eda51b48c7e97adf7c46fc3d7eb34fcdf6061e6">2eda51b48c7e97adf7c46fc3d7eb34fcdf6061e6</a>
-<blockquote>
-<p>
- Bug 695420: Bad pointer to OutputICCProfile string.<br>
-<br>
- This was caused by the gs_setpd.ps logic having a dictionary that has the<br>
- OutputICCProfile pointing to dev-&gt;icc_struct-&gt;device_profile[0]-&gt;name, but<br>
- when ColorConversionStrategy distillerparam is set, it does a rc_decrement<br>
- on the pdev-&gt;icc_struct which frees the entire structure, among those the<br>
- 'name' (which was allocated in non_gc_memory).<br>
-<br>
- Add the OutputICCProfile to the list of .dynamicppkeys in gs_setpd.ps so<br>
- that the string will always be updated and the dictionary won't have a<br>
- stale pointer.<br>
-<br>
- Having a dict with a string in non_gc_memory is OK I guess, even though<br>
- we generally &quot;hide&quot; all non_gc_memory elements from the GC.<br>
-<br>
-gs/Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-24 17:41:32 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b181cc746811d2920cfe183d8fd341de944d65b3">b181cc746811d2920cfe183d8fd341de944d65b3</a>
-<blockquote>
-<p>
- Add a missing condition for devices that need tags to pdf14_recreate_device.<br>
-<br>
- Customer 532 has done extensive testing and uses tags. This change<br>
- is in their code.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-18 16:40: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=727340d4bd2a42b2793d00c3b5cd36facdf26e92">727340d4bd2a42b2793d00c3b5cd36facdf26e92</a>
-<blockquote>
-<p>
- pdfwrite - fix a ShadingType 5 with array DataSource and a Function<br>
-<br>
- Bug #695359 &quot;Wrong gradients after conversion to PDF&quot;<br>
-<br>
- The example file is a hand-coded shading of type 5 with the DataSource<br>
- being an array, but using a function to convert the parametric value at<br>
- each vertex into a colour value.<br>
-<br>
- The PDF specification doesn't support this kind of shading, so we need<br>
- to convert it. In doing so we write out a Decode array, which needs to contain<br>
- the minimum and maximum colour values. Ordinarily we get these from the<br>
- shading dictionary, but when using an array for DataSource this is not<br>
- present. In the absence of the Decode array we were defaulting to 0 and 1<br>
- but the function actually has a range from 0 to 10. This meant we were<br>
- truncating the colour space.<br>
-<br>
- This commit examines the Function (if present) and uses the Domain of the<br>
- function as the values instead of 0 and 1.<br>
-<br>
- This may not be sufficient in the absolute general case, but all mesh<br>
- shadings are rare in real world files, and mesh shadings using array<br>
- DataSource are still less common, as are examples with a function which<br>
- does not have a Domain 0-1. So this will suffice until we see more<br>
- problems.<br>
-<br>
- Note that Acorbat Distiller X produces different output if you run the<br>
- two shadings in the example file separately instead of consecutively. Also<br>
- Acrobat X displays the resulting file from both Distiller and Ghostscript<br>
- incorrectly (Acrobat XI displays them correctly)<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-18 09:15: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=db7668753ca114aabc4d34063876732dc043e9b8">db7668753ca114aabc4d34063876732dc043e9b8</a>
-<blockquote>
-<p>
- PDF interpreter - read BPC from the JPX stream instead of the resource dict<br>
-<br>
- Bug #695387 &quot;PDF with jpeg2000 conversion problems&quot;<br>
-<br>
- The PDF spec states (table 4.39, BPX on page 340 of the PDF Rerference)<br>
- that the Bits Per Component value is to be taken from the JPX stream and<br>
- the image dictionary value should be ignored if present. We were only<br>
- reading the BPC if either that to the ColorSpace was missing from the<br>
- image dictionary.<br>
-<br>
- In this commit we *always* pare the data out of the JPX stream (which is<br>
- a small performance penalty). However, this always overwrites the data in<br>
- the resource dictionary, which is fine for BPX&lt; but not acceptable for the<br>
- colour space, because Acrobat favours the ColorSpace in the<br>
- image dictionary over the JPX colour space, and because we set the colour<br>
- space to be DeviceGray for softmasks.<br>
-<br>
- So we save the colour space from the resource dictionary (if present), read<br>
- the BPC and colour space then, if we had a colour space in the resource<br>
- dictionary we restore it back again.<br>
-<br>
- For some reason this causes problems on the cluster with the test file<br>
- Bug688845.eps. Since this change only affects JPX images, and PDF files, I<br>
- can't see any way that the change can be responsible for this. I am unable<br>
- to reproduce the problem on Windows or Linux locally.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-15 11:30:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a7e8f7592a9861f83dbb94b8b545961caca864ce">a7e8f7592a9861f83dbb94b8b545961caca864ce</a>
-<blockquote>
-<p>
- Bug 694160: Prevent malicious code being injected into the system.<br>
-<br>
- This is essentially the same patch as committed in:<br>
- 4fc4b8410d35b193d549558ab212cc727db9460b<br>
-<br>
- but that patch was missing white space at the ends of automatically<br>
- concatenated strings - hence the interpreter saw, for example:<br>
- &quot;.systemexecend&quot; rather than &quot;.systemexec end&quot;.<br>
-<br>
- Additionally, to avoid that confusion in the future, I've removed the reliance<br>
- on the automatic string concatenation.<br>
-<br>
- Also removed a spurious additional call to &quot;.uninstallpagedevice&quot;.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-15 10:14:36 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1db534ed2b1277b265652d4b660b11e957a3e0bf">1db534ed2b1277b265652d4b660b11e957a3e0bf</a>
-<blockquote>
-<p>
- Revert commit 4fc4b8410d35b193d549558ab212cc727db9460b<br>
-<br>
- See bug #694160 and #695420. Somehow this patch ends up leaving 'quit'<br>
- undefined at the end of job, which breaks the '-o' switch. It also somehow<br>
- manages to break at least some pdfwrite incantations, leading to an undefined<br>
- error with a garbage caller. It kind of looks like the name table is<br>
- broken or similar.<br>
-<br>
- Note that the undefined error on quit occurs when running GS interactively<br>
- and even when this happens, &quot;systemdict /quit get exec&quot; works, so its not<br>
- as simple as /quit being undefined.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-13 20:33:36 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=062f4b4536b7b3fa1742e31c05dc57fe241d6690">062f4b4536b7b3fa1742e31c05dc57fe241d6690</a>
-<blockquote>
-<p>
- Bug 695423: follow up.<br>
-<br>
- Fix the description comments.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/devices/devs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-13 19:28:04 +0100
-</strong>
-<br>Gerard Belanger &lt;gbelanger@practicalautomation.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=25a0cd96ac4b44d96e27c435dad5cc2c31788733">25a0cd96ac4b44d96e27c435dad5cc2c31788733</a>
-<blockquote>
-<p>
- Bug 695423: Add current generation printers to gdevatx.c<br>
-<br>
- Practical Automation printers.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/configure.ac<br>
-gs/devices/devs.mak<br>
-gs/devices/gdevatx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-12 10:17: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=9a80562145b25a7166bd7c8e005446bd306be34e">9a80562145b25a7166bd7c8e005446bd306be34e</a>
-<blockquote>
-<p>
- ps2write - fix conversion of TrueType fonts with format 0 LOCA tables<br>
-<br>
- Bug #695417 &quot;gs(ps2write) produce invalid ps from certain LibreOffice print emission&quot;<br>
-<br>
- The code in the opdfread prolog for converting TrueType fonts to type 42<br>
- fonts was completely broken for fonts with a format 0 LOCA table (16 bit<br>
- offsets). The offending routine is StringToLoca.<br>
-<br>
- The code was reading 32 bits instead of 16, which causes it to exhaust<br>
- the string data, leaving array members uninitialised, which is the inital<br>
- cause of the error. However, it also didn't multiply the offsets it did<br>
- read by 2 (format 0 LOCA offsets are multiplied by 2), and had a 'dup'<br>
- which resulted in the stack having the wrong value on top on exit.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/opdfread.h<br>
-gs/lib/opdfread.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-11 21:22: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=4fc4b8410d35b193d549558ab212cc727db9460b">4fc4b8410d35b193d549558ab212cc727db9460b</a>
-<blockquote>
-<p>
- Bug 694160: Prevent malicious code being injected into the system.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-08 11:55: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=5be9d0429b79f53b0e074fb1042cf3e88134ba0d">5be9d0429b79f53b0e074fb1042cf3e88134ba0d</a>
-<blockquote>
-<p>
- remove an unused variable to silence a compiler warning<br>
-<br>
-gs/devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-08 10:07: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=3a035a2a9e94196920f99a18670ee96202f67bb9">3a035a2a9e94196920f99a18670ee96202f67bb9</a>
-<blockquote>
-<p>
- tiffsep - add code to print CMYK equivalents for spot inks<br>
-<br>
- Bug #695407 &quot;tiffsep should print out separation equivalent CMYK&quot;<br>
-<br>
- Patch supplied by Mateusz Lenik to print out the CMYK equivalents for every<br>
- ink in the job.<br>
-<br>
- Controlled by the new PrintSpotCMYK switch, which is only supported on the<br>
- tiffsep device, documented in devices.htm.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/gdevtsep.c<br>
-gs/doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-05 13:25:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5671fc9b4b5fc8abb326e60195dff7ec46d5b389">5671fc9b4b5fc8abb326e60195dff7ec46d5b389</a>
-<blockquote>
-<p>
- Bug 695394: fix TTF glyph encoding generation<br>
-<br>
- There was a logical error in the glyph encoding generation for TT fonts,<br>
- affecting fonts without post tables.<br>
-<br>
- When handling the case where the same glyph name references two different<br>
- glyphs, the index in the glyph encoding we wrote the generated name to was the<br>
- GID (i.e. the index returned from the cmap table) rather the original index<br>
- we were handling from the glyph encoding.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-01 14:50: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=275dc99017b96c1be74a50026479dbdf8d63192f">275dc99017b96c1be74a50026479dbdf8d63192f</a>
-<blockquote>
-<p>
- PDF interpreter - fix Hybrid file parsing<br>
-<br>
- Bug #695403 &quot;Error ocurred while reading XREF table&quot;<br>
-<br>
- The fix for bug #694342 treated an xref section with no entries as an error<br>
- and caused the xref to be rebuilt. However, if a PDF file is converted into<br>
- a hybrid file (one with an xref *and* an XrefStrm) by adobe CS 3, then it<br>
- does this by adding a 'dummy' xref which has a /Prev pointing to the real<br>
- xref, and a /XrefStrm pointing to the stream.<br>
-<br>
- The dummy xref has a section &quot;0 0&quot;, is first object 0, no objects defined<br>
- which falls foul of the test for Bug 694342 and causes the xref to be rebuilt.<br>
-<br>
- This commit adds a boolean which is initially false and is set true in the<br>
- parsing loop for the xref section. When we encounter a /trailer, instead<br>
- of checking if 0 objects are defined, we now look at that boolean. If its<br>
- 'true' then we have seen a section entry, and can treat this as valid, even<br>
- if no objects are yet defined. If we haven't seen a section then we treat<br>
- it as invalid and force an xref rebuild.<br>
-<br>
- This causes sumatra/694313_-_empty_xref.pdf to stop producing errors as<br>
- well.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-08-01 09:52: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=80395ccbe7558e324ff3cb75c3e241ce0ffd735d">80395ccbe7558e324ff3cb75c3e241ce0ffd735d</a>
-<blockquote>
-<p>
- ps2write - fix a bug in the debug code<br>
-<br>
- The PrintHex routine assumes that PostScript integers are 32 bits wide.<br>
- This is no longer guaranteed with GS. This fix ensures that after we do<br>
- the bit shifting to isolate 4 bits for conversion to hex, we don't have<br>
- a number &gt; 15, which could occur if the integer was sufficiently large.<br>
-<br>
- This prevents the code throwing an error when debugging.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/opdfread.h<br>
-gs/lib/opdfread.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-30 15:33:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9fbecef99a40d8a5b372fadf4ed99fe29c6815a9">9fbecef99a40d8a5b372fadf4ed99fe29c6815a9</a>
-<blockquote>
-<p>
- Bug 695397: handle &quot;unknown&quot; glyph names &gt;16 chars long<br>
-<br>
- When creating glyph aliases for a TTF, we check for &quot;formatted&quot; unicode glyph<br>
- names of the form &quot;uniWXYZ&quot; where &quot;WXYZ&quot; is the glyph code point in base 16.<br>
-<br>
- In doing that we use a temporary string which is 16 characters long (since the<br>
- formatted names we're interested won't be longer that 16).<br>
-<br>
- So, check the glyph name is &lt;16 chars long before checking if it's a &quot;uni...&quot;<br>
- style name.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-30 08:34: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=7a2d86136669e79742aacda148e5c70854273ca5">7a2d86136669e79742aacda148e5c70854273ca5</a>
-<blockquote>
-<p>
- Bug 695380: add a simple sanity check in i_alloc_string<br>
-<br>
- Checks for integer overflow.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-29 17:26: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=f25cb59f2ed56df8366d03c5cb7d9b37dec77934">f25cb59f2ed56df8366d03c5cb7d9b37dec77934</a>
-<blockquote>
-<p>
- Bug 695319: Set pdf14 (trans) ctx to NULL on free on error<br>
-<br>
- In the event of an interpreter triggered error during a transparency operation,<br>
- pdf14_discard_trans_layer() is called to clean up. It frees the context, but<br>
- didn't set the ctx pointer to NULL - thus we could try to free the already<br>
- freed context object when the pdf14 compositor device is shut down.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-29 15:37: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=e889a18896e668e5e565e5ec1cada8b8a64c60a2">e889a18896e668e5e565e5ec1cada8b8a64c60a2</a>
-<blockquote>
-<p>
- Bug 695318: mark memory chunks used for single allocations.<br>
-<br>
- Certain chunks in the memory manager are used to contain only one (o_alone)<br>
- allocation: &quot;large&quot; allocations and &quot;immovable&quot; allocations specifically.<br>
-<br>
- We need to be able to identify those chunks so we don't end up trying to use<br>
- any empty space in them for later allocations - these chhunks can end up with<br>
- empty space in them if the original object allocated in them is shrunk.<br>
-<br>
- The problem that occurs is when we free an o_alone object, we immediately free<br>
- the chunk containing it, thus any other allocations in that chunk are also<br>
- freed.<br>
-<br>
- Adding a c_alone flag to the chunk means we can trivially identify and skip<br>
- those chunks when searching for free memory.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsalloc.c<br>
-gs/base/gxalloc.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-25 15:57: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=21d86e8264a6cd11f963b4c36b989ab4c0ed3294">21d86e8264a6cd11f963b4c36b989ab4c0ed3294</a>
-<blockquote>
-<p>
- Bug 695363: handle TTF with no/empty loca table.<br>
-<br>
- A broken TT font could end up with us allocating a zero length array for<br>
- the for the glyph lengths, then later to attempt to access entries in that<br>
- array.<br>
-<br>
- Thus, avoid allocating the zero length array, and treat a NULL glyph_len array<br>
- the same as a glyph_len of 0.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gstype42.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-24 14:26:30 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea4547f4bc24803f167e8a0b1a1384d9dc8af9e8">ea4547f4bc24803f167e8a0b1a1384d9dc8af9e8</a>
-<blockquote>
-<p>
- Add setting buf-&gt;backdrop to NULL when knockout is false.<br>
-<br>
- Minor issue, but I did find a case where the buf-&gt;backdrop was left<br>
- uninitialized when working on customer 532 issue with fts_25_2526.pdf<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-02 21:17:54 +0200
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23f71dd93eeac60f0ff3c58b17bcd8ccd2d971d6">23f71dd93eeac60f0ff3c58b17bcd8ccd2d971d6</a>
-<blockquote>
-<p>
- xps: Remove trailing whitespace.<br>
-<br>
-xps/xpsgradient.c<br>
-xps/xpsimage.c<br>
-xps/xpsjxr.c<br>
-xps/xpsopacity.c<br>
-xps/xpspath.c<br>
-xps/xpspng.c<br>
-xps/xpstiff.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-02 21:06:47 +0200
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eed68003a30b64649157b7dcdcfc1d5162c3bb63">eed68003a30b64649157b7dcdcfc1d5162c3bb63</a>
-<blockquote>
-<p>
- xps: Allow colormapped 1-bit TIFF files.<br>
-<br>
- Thanks to Norbert Janssen.<br>
-<br>
-xps/xpstiff.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-02 21:01:18 +0200
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3b03ee5480ab38f0d7b4e2ad341385d7dffd8343">3b03ee5480ab38f0d7b4e2ad341385d7dffd8343</a>
-<blockquote>
-<p>
- xps: Improve transparency analysis for resource dictionaries.<br>
-<br>
- Thanks to Norbert Janssen.<br>
-<br>
-xps/xpsanalyze.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-22 09:09:47 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8d3081c0403a1d911a79dce57008ede4279d050a">8d3081c0403a1d911a79dce57008ede4279d050a</a>
-<blockquote>
-<p>
- pdfwrite and ps2write - Mimic the -dNOCACHE output of pswrite<br>
-<br>
- This feature is in response to the thread on gs-devel &quot;pswrite and NOPLATFONTS&quot;<br>
-<br>
- Normally pdfwrite and ps2write try very hard to maintain fonts from the input<br>
- as fonts in the output, for reasons of output size, performance and qualiity.<br>
-<br>
- It seems that some people are relying on using pswrite with -dNOCACHE in<br>
- order to produce PostScript output with no fonts at all. (As far as I can<br>
- see this is to address the limitations of other software). This was never<br>
- a goal for pswrite, but it seems that it works 'well enough' to be useful.<br>
-<br>
- Sadly, despite us flagging the fact that pswrite had been deprecated, nobody<br>
- gave us any feedback until after (several releases after, in fact) we had<br>
- removed the device. We are not going to reinstate support for the pswrite<br>
- device, having spent effort to remove it in order to drop support for it,<br>
- so this commit adds a new feature which causes pdfwrite and friends to<br>
- write the glyph description into the content stream as it is used instead<br>
- of constructing fonts.<br>
-<br>
- This is controlled with the new switch NoOutputFonts which defaults to false<br>
-<br>
- There are no cluster differences with this commit. Using the switch causes<br>
- pretty much every test file which contains text to render differently.<br>
-<br>
-gs/devices/vector/gdevpdfb.h<br>
-gs/devices/vector/gdevpdfp.c<br>
-gs/devices/vector/gdevpdfx.h<br>
-gs/devices/vector/gdevpdtt.c<br>
-gs/doc/Ps2pdf.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-21 11:02: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=b6575b8a91e23365b340771fc67b29819ba7937b">b6575b8a91e23365b340771fc67b29819ba7937b</a>
-<blockquote>
-<p>
- Have pdfwrite/ps2write &quot;flatten&quot; glyphs...<br>
-<br>
- ...into &quot;normal&quot; marking ops if the glyph cache is disabled.<br>
-<br>
-gs/devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-11 13:52: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=f35a388327055a3a2635c91f5e1080af6d957d37">f35a388327055a3a2635c91f5e1080af6d957d37</a>
-<blockquote>
-<p>
- Bug 694205: prevent crash rendering unfeasibly large glyph<br>
-<br>
- Initialise the &quot;prev&quot; entry in the top node in the x line list to null and<br>
- check it isn't null before we use it. If we reach that point, it indicates that<br>
- a) the current path reaches (and probably passes) the limits of our coordinate<br>
- space and b) the line list is already in the correct order - as best it can be,<br>
- anyway.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gxfill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-16 13:14:42 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=56162c7c6c55bd2f98e4a25fa399c0a5865f7249">56162c7c6c55bd2f98e4a25fa399c0a5865f7249</a>
-<blockquote>
-<p>
- Bug #695367 - Writing a 64 bit integer into a 32 bit format specifier<br>
- corrupted sprintf's variadic argument list on some (windows)<br>
- platforms.<br>
-<br>
-gs/devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-14 16:05:36 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef4150919c5dc6c0fcf441cc499a3250d8a6529e">ef4150919c5dc6c0fcf441cc499a3250d8a6529e</a>
-<blockquote>
-<p>
- Use a conditional form feed when selecting a page side, #695325.<br>
-<br>
-pcl/pcjob.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-27 06:59:09 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6fc36d436fa166c87d4d75d3f7d037f80cf6ce6">a6fc36d436fa166c87d4d75d3f7d037f80cf6ce6</a>
-<blockquote>
-<p>
- Bring comment in line with recent changes to the printable region.<br>
-<br>
-pcl/pcxfmst.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-07 12:31:13 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4823edf7be9b8dd1e40306e1b5e0f0edbecb84be">4823edf7be9b8dd1e40306e1b5e0f0edbecb84be</a>
-<blockquote>
-<p>
- pdfwrite - prevent closing the device if its not open<br>
-<br>
- Bug #694380 &quot;Seg fault in pdfwrite&quot;<br>
-<br>
- The file in question throws an error in pdfwrite when we try to write a<br>
- FontDescriptor (the font is broken). The PDF interpreter, however,<br>
- often ignores errors and continues trying to process the input file.<br>
-<br>
- When producing one output file this is not a problem, as the error occurs<br>
- in pdf_close() and so it all works. However, when producing one file per<br>
- page this fails, because we close the device, notice the error, and<br>
- do not open it anew. However the PDF interpreter just carries on. When we<br>
- come to the end of the next page we try to close a device which is already<br>
- closed, and this means we try to dereference an invalid pointer.<br>
-<br>
- In this commit we check the 'is_open' flag of the device in pdf_close and<br>
- if the device is not open then we jump straight back out. We also set is_open<br>
- to false in the same routine as it wasn't previously being set (because we<br>
- couldn't previously close and reopen the device).<br>
-<br>
- This fixes the problem with Bug693711.pdf for me.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-07 09:00: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=84bdbfec67808ea22ec152a56bcb33655ef084aa">84bdbfec67808ea22ec152a56bcb33655ef084aa</a>
-<blockquote>
-<p>
- pdfwrite - add an include file for a prototype, silences a compiler warning<br>
-<br>
-gs/devices/vector/gdevpdfk.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-04 12:02: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=ddae2b83fd7e91053d62b2d4533e850fdba341bf">ddae2b83fd7e91053d62b2d4533e850fdba341bf</a>
-<blockquote>
-<p>
- pdfwrite - fix memory corruption caused by type 3 capture of PCL fonts<br>
-<br>
- Bug #695350 &quot;GhostPCL line shifting&quot;<br>
-<br>
- It was impossible to reproduce this bug exactly as the reporter is running<br>
- Ghostscript on an unusual platform. Fortunately what appears to be the same<br>
- problem could be reproduced on a PowerPC Mac running Linux. It is possible<br>
- that this commit doesn't actually fix the bug though.<br>
-<br>
- When capturing glyph descriptions in order to build a type 3 font from a<br>
- PCL font, we were saving the default text procedures from the enumerator<br>
- (which was created by gx_default_text_begin), and then restoring them when<br>
- we had finished processing the glyph. However, by that time we had already<br>
- releases the enumerator, which meant we were corrupting memory.<br>
-<br>
- Desk checking the code, I can't see any reason for saving the procedures<br>
- from the text enumerator, and I conclude this is either a holdover from an<br>
- earlier version of this code, or an oversight when writing the code that<br>
- captured PCL fonts. In any event this commit removes the save/restore<br>
- behaviour, since it is definitely causing memory corruption.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-02 13:42: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=3bfacc81f717f6e658f3cb4575ded0c36919ec4e">3bfacc81f717f6e658f3cb4575ded0c36919ec4e</a>
-<blockquote>
-<p>
- pdfwrite - detect corrupted type 3 fonts and generate an errror<br>
-<br>
- Bug #694186 &quot;Seg faults found by fuzzing in names_index_ref&quot;<br>
-<br>
- The file has a corrupted glyph in a type 3 font, which throws an error.<br>
- However, pdfwrite can't tell that the glyph threw an error rather than<br>
- simply completing successfully, and tries to use the returned glyph ID. The<br>
- glyph ID is GS_NO_GLYPH which fails with a seg fault when looking up the<br>
- name.<br>
-<br>
- In this commit we check the glyph ID to see if its GS_NO_GLYPH and throw an<br>
- error if it is. This prevents us looking up an invalid glyph ID in the<br>
- name table, and the file is demonstrably broken.<br>
-<br>
- This fixes a1c8db... the other file, cc5c... is also fixed, but in newer<br>
- code never even makes it to this point as the current code detects a different<br>
- problem before it reaches this point.<br>
-<br>
-gs/devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-01 17:30: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=4d2e447a5226bf8b1baf6f079f3e767c72928d88">4d2e447a5226bf8b1baf6f079f3e767c72928d88</a>
-<blockquote>
-<p>
- pdfwrite - ensure we have V2 ICC profiles for PDF/A-1 and PDF &lt; 1.5<br>
-<br>
- Bug 695118 &quot;PDF/A-file is generated with ICC version 4.2 profiles&quot;<br>
-<br>
- PDF/A-1 requires us to use ICC v2 profiles due to the level of PDF mandated<br>
- by the spec. In addition, we should not use V4 profiles when producing<br>
- PDF less than 1.5.<br>
-<br>
- Michael added considerable code to allow us to get a V2 profile, given a<br>
- V4 profile, and this commit makes the changes required for pdfwrite. Its more<br>
- extensive than appears necessary because we need access to the current<br>
- imager state in order to generate the V2 profile, so a large number<br>
- of routines have been altered to pass along the imager state (or NULL in<br>
- some cases, where we can only be dealing with device spaces anyway).<br>
-<br>
- We also change the default version of PDF we produce to 1.5 so that we can<br>
- emit V4 profiles and alter the 'prepress' predfined settings similarly.<br>
-<br>
- This causes changes in a Genoa CET file, but its just different, not wrong.<br>
-<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfb.c<br>
-gs/devices/vector/gdevpdfc.c<br>
-gs/devices/vector/gdevpdfc.h<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpdfg.h<br>
-gs/devices/vector/gdevpdfi.c<br>
-gs/devices/vector/gdevpdfk.c<br>
-gs/devices/vector/gdevpdft.c<br>
-gs/devices/vector/gdevpdfv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-07-01 09:41: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=c4dfed923d2513e4b79f8c765b5682e628b2fa60">c4dfed923d2513e4b79f8c765b5682e628b2fa60</a>
-<blockquote>
-<p>
- pdfwrite - colour conversion<br>
-<br>
- When converting a Separation alternate space we create a new space which<br>
- uses the ink name pf the Separation. We were putting the name into the<br>
- space without copying it, which can lead to it being freed while the original<br>
- space is still pointing to it.<br>
-<br>
- Follow on from commit e492e1671b7b1041ba123a22c1df3b920cf753af which<br>
- addressed DeviceN spaces.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-30 10:14: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=c88ded04ea9977d994b243720b8fa32bc7fa56e7">c88ded04ea9977d994b243720b8fa32bc7fa56e7</a>
-<blockquote>
-<p>
- Type 42 font - correctly initialise Max Composite points and Contours<br>
-<br>
- The previous commit which initiaslised these (by me) was incorrect, the<br>
- values are 2 byte shorts, not 4 byte ints.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gstype42.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-30 09:40: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=e492e1671b7b1041ba123a22c1df3b920cf753af">e492e1671b7b1041ba123a22c1df3b920cf753af</a>
-<blockquote>
-<p>
- pdfwrite - colour conversion of DeviceN alternate spaces<br>
-<br>
- Bug #695306 &quot;Converting a PDF to RGB colorspace causes missing drawing parts&quot;<br>
-<br>
- There are two problems addressed in this commit.<br>
-<br>
- Firstly the code wasn't catering properly for the possibility of an /Indexed<br>
- DeviceN space. We did dereference the Indeexed space, but not until after<br>
- we had tried to use the original space as a DeviceN, with unfortunate<br>
- potential results. We move the dereference to the top of the function<br>
- convert_DeviceN_alternate so that we properly use the DeviceN space.<br>
-<br>
- Secondly when creating the new colour space (ie with a different alternate<br>
- space), we add the names of the inks from the original DeviceN space.<br>
- However, we were using add_no_copy which meant when the new array was<br>
- garbage collected we freed the names, but left them being pointed at by<br>
- the original array, leading to pointers to garbage memory.<br>
-<br>
- No differences expected as the colour conversion is not tested by the cluster<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-27 04:58:24 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9f7902c6a9a5a2315901b3d5ef32e98feefe7e86">9f7902c6a9a5a2315901b3d5ef32e98feefe7e86</a>
-<blockquote>
-<p>
- Fix compiler warnings and dependencies.<br>
-<br>
-gs/base/gspaint.c<br>
-gs/base/gxclthrd.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-26 18:12:52 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=abcf61e770b8b4687c571f321c79e6a0bb0a7424">abcf61e770b8b4687c571f321c79e6a0bb0a7424</a>
-<blockquote>
-<p>
- Fix compiler warnings in ICC generation code.<br>
-<br>
-gs/base/gsicc_create.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-26 16:26:44 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=417ffa428a427abd327ab7be48759d536b0689a6">417ffa428a427abd327ab7be48759d536b0689a6</a>
-<blockquote>
-<p>
- PCL no longer needs to maintain the hardware clipping state with the<br>
- change to have the device maintain the printable region (HWMargins).<br>
- See last commit.<br>
-<br>
-pcl/pcpage.c<br>
-pcl/pcxfmst.h<br>
-pcl/pgdraw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-26 18:22:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5470aa39ebcfff65fb00e163f781c5769f4f9c18">5470aa39ebcfff65fb00e163f781c5769f4f9c18</a>
-<blockquote>
-<p>
- Bug 695334: fix seg fault with CIDFont substitution.<br>
-<br>
- When deciding whether to share the subst_CID_on_WMode table between CIDFont<br>
- objects, make sure the two fonts are allocated in the same VM mode. If they<br>
- differ, do not share the table.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zfcid1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-26 18:21: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=c73b4d533dc236427d57b3e8f9725f12d8d0aadd">c73b4d533dc236427d57b3e8f9725f12d8d0aadd</a>
-<blockquote>
-<p>
- Add the SubstCID resources to the romfs.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/psi/psromfs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-24 05:46:32 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=02c486ce654faf99eac1dcd262651af5d32bae05">02c486ce654faf99eac1dcd262651af5d32bae05</a>
-<blockquote>
-<p>
- Add pageneutralcolor as a printer device parameter to allow query.<br>
-<br>
- fillpage (erasepage from PS) will re-enable monitoring so we needn't<br>
- ouptut the page in order to restart monitoring.<br>
-<br>
- This allows PostScript or clients to use get_params or get_param to<br>
- read the pageneutralcolor state. Presumably this would be used prior<br>
- to showpage. Coupled with the EndPage proc, PS can examine this even<br>
- without emitting the pages.<br>
-<br>
- Note that this is only accurate when in clist mode, so -dMaxBitmap=0<br>
- and -dGrayDetection=true should both be used.<br>
-<br>
-gs/base/gdevprn.c<br>
-gs/base/gspaint.c<br>
-gs/doc/Language.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-26 07:59:12 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f3f29cf2f2ad9ab30c0a10f0634ec4d2d06d906c">f3f29cf2f2ad9ab30c0a10f0634ec4d2d06d906c</a>
-<blockquote>
-<p>
- Default PCL to full bleed, setting the printable region margins to 0.<br>
-<br>
- Actually this change was partially implemented previously, but there<br>
- were still lingering parts of the code that used the 1/6&quot; border to<br>
- affect the output. Older HP printers default to a 1/6&quot; inch printable<br>
- region. This can be implemented by changing the default HWMargins in<br>
- the device or by setting them with the command line option -H, see the<br>
- PCL documentation for details.<br>
-<br>
-pcl/pcpage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-25 20:23: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=b13d19749b58b2b0263013ad9a516c36e56cdb1c">b13d19749b58b2b0263013ad9a516c36e56cdb1c</a>
-<blockquote>
-<p>
- Fix wrong pointer type passing to gsicc_create_compute_cam<br>
-<br>
- No differences expected since the pointer type mix up happened to<br>
- be both float types<br>
-<br>
-gs/base/gsicc_create.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-25 14:59:54 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d6be178195f97d7fa1cd2ae010e5d9e89f911e1a">d6be178195f97d7fa1cd2ae010e5d9e89f911e1a</a>
-<blockquote>
-<p>
- Apply cat02 chromatic adaptation to primaries when creating ICC profile from CalRGB<br>
-<br>
- While I had pickled the CAM into the transform created using the lutAtoB type, I<br>
- failed to apply the transform for the matrix based solution that is used for the<br>
- profile when created from CalRGB. I did have a comment in the code that this needed<br>
- to be done.<br>
-<br>
- Several progressions occur.<br>
-<br>
-gs/base/gsicc_create.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-25 08:54:43 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=759230353994354ae7417cdab1bbb09924dea70f">759230353994354ae7417cdab1bbb09924dea70f</a>
-<blockquote>
-<p>
- Add an option to set hardware margins.<br>
-<br>
- There was no way to specify Ghostscript .HWMargins on the command line<br>
- because the PCL option parser cannot parse most composite objects. So<br>
- we add a '-H' option to be followed by 4 numbers: left, bottom, right<br>
- and top margin.<br>
-<br>
-doc/ghostpdl.pdf<br>
-doc/ghostpdl.tex<br>
-doc/ghostpdl.txt<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-24 12:33: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=f293a2fd1bfed25a69d64472967417d7d40d08ff">f293a2fd1bfed25a69d64472967417d7d40d08ff</a>
-<blockquote>
-<p>
- Fix memory leak in libjpeg custom memory management<br>
-<br>
- Noticed working on another issue: the cleanup function was missing for the<br>
- custom libjpeg memory management code.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/sjpeg.h<br>
-gs/base/sjpegc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-19 17:23:26 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0fc3bea788f6b65062432ff4bc6eace3cc713e63">0fc3bea788f6b65062432ff4bc6eace3cc713e63</a>
-<blockquote>
-<p>
- Various ICC profile related memory leak fixes<br>
-<br>
- Raised by cust 532.<br>
-<br>
- Add several &quot;finalize&quot; methods so ICC profiles (not in garbage collected memory)<br>
- get freed or ref count decremented appropriately when the referencing object<br>
- *is* garbage collected.<br>
-<br>
- Also, there were some mismatched ref count increments.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gscms.h<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_lcms.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_nocm.c<br>
-gs/base/gsstate.c<br>
-gs/base/gstrans.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclist.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-24 13:26:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d936f19a3342a8da88b32a1559087b3a38c66832">d936f19a3342a8da88b32a1559087b3a38c66832</a>
-<blockquote>
-<p>
- pdfwrite - more changes to better handle sRGB ColorConversionStrategy<br>
-<br>
- Following on from commit d704ab3d30b6119c8169d8827226f7325e5ee87f an<br>
- additional 3 cases where I believe we need to handle sRGB as per RGB.<br>
-<br>
- These changes are committed separately as they were found by code inspection<br>
- and I don't have a test case for them.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-24 12:51: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=d704ab3d30b6119c8169d8827226f7325e5ee87f">d704ab3d30b6119c8169d8827226f7325e5ee87f</a>
-<blockquote>
-<p>
- pdfwrite colour conversion - handle alternate conversion to sRGB from DeviceN<br>
-<br>
- Bug #695316 &quot;A DeviceN image in pdf can't be converted to RGB image, it is converted to many paths instead&quot;<br>
- Bug #695306 &quot;Converting a PDF to RGB colorspace causes missing drawing parts&quot;<br>
-<br>
- The code for converting a DeviceN alternate space and tint transform wasn't<br>
- catering for a ColorConversionStrategy of /sRGB. This commit ads the<br>
- ccs_sRGB case, and converts it to RGB as per the documentation, using the<br>
- selected RGB profile.<br>
-<br>
- Bug 695316 now converts the image to an image, though it produces an error<br>
- on exit relating to ICC profiles.<br>
-<br>
- Bug 695306, for me, caused a seg fault, which this commit corrects. I do not<br>
- see any missing content with either sRGB or RGB conversion. I do see the<br>
- same error as for Bug #695316 and I'll continue working on that problem<br>
- under that bug number<br>
-<br>
- No differences expected, the c;luster doesn't test colour conversion<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-21 09:22:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=699e5a8478c2acbe34add1a9b2bd809779001e3f">699e5a8478c2acbe34add1a9b2bd809779001e3f</a>
-<blockquote>
-<p>
- pdfwrite - preserve enumerator text for composite data<br>
-<br>
- Bug #695322 &quot;Distilling PS to PDF using GS causes strange characters for spaces when using a particular sequence in the PS&quot;<br>
-<br>
- The problem occurs because when processing text in a composite font pdfwrite<br>
- overwrites the string data while working on it. In general this is not actually<br>
- a problem, as the string data argument to the show family of operators is<br>
- normally not reused.<br>
-<br>
- However, in this case the customer's PostScript inserts space glyphs by calling<br>
- a bound procedure, instead of simply calling show. The first execution works<br>
- properly, but corrupts the string, the second execution uses the corrupted<br>
- string as the data, and is unable to find a glyph in the font to match the<br>
- corrupted data, which results in the /.notdef being used instead.<br>
-<br>
- The particular routine in question (scan_cmap_text) is one of the most<br>
- convoluted and bloated routines in pdfwrite, and after some inspection it<br>
- was obviously going to be very difficult to avoid overwriting the string<br>
- data, it would run considerable risk of breaking the code in subtle ways,<br>
- and would in any event mean copying the string data around, possibly mutliple<br>
- times.<br>
-<br>
- Accordingly I've chose to make a new copy of the string data in<br>
- process_cmap_text, which is the only parent of scan_cmap_text, and save/restore<br>
- the string data round the call. This prevents the bound string being<br>
- corrupted and fixes the problem.<br>
-<br>
- This also exhibits a progression in Bug691680.ps and I've noted in that<br>
- thread that the remaining problem is fixed.<br>
-<br>
-gs/devices/vector/gdevpdtc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-20 17:53:49 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2322d38f28a21cfaad42e66398bcc34077818beb">2322d38f28a21cfaad42e66398bcc34077818beb</a>
-<blockquote>
-<p>
- Addition of code in gsicc_create.c to create V2 ICC profiles from V4 ICC profiles<br>
-<br>
- This is needed to support a version of PDF-X that requires V2 ICC profiles.<br>
-<br>
-gs/base/gscms.h<br>
-gs/base/gsicc_cms.h<br>
-gs/base/gsicc_create.c<br>
-gs/base/gsicc_create.h<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_manage.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-19 13:43: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=d6a29d5618f95cbbd299a5d5d02ec820ae8d7ced">d6a29d5618f95cbbd299a5d5d02ec820ae8d7ced</a>
-<blockquote>
-<p>
- Check for trivially clipped out images before checking trivially non-clipped<br>
-<br>
- Bug #695320 &quot;Difference in bbox result from 9.06 onwards&quot;<br>
-<br>
- commit a13600f1c241c3e36dbe4973e9d78a8934b16004 introduced checks to see<br>
- if we actually needed a clip device before going ahead and installing it.<br>
- However, the order of checks was slightly incorrect. The code clamps the<br>
- rectangle to be tested to the outer box of the clip path, then checked to<br>
- see if the rectangle was completely included in the inner box.<br>
-<br>
- If the object was completely clipped out then the rectangle would be clamped<br>
- to the outer box of the clip. If the outer and inner boxes were the same<br>
- (rectangular clip) then the test could decide that the totally clipped out<br>
- rectangle was in fact completely enclosed in the inner box.<br>
-<br>
- We fix this here by checking to see if the image is clipped out (by testing<br>
- to see if the top/bottom or left/right edges are co-incident) before we<br>
- check for trivial inclusion.<br>
-<br>
- For totally clipped out objects we then abort the object which, like the<br>
- original fix prevents us installing a clip device and also prevents us<br>
- going through the trapezoid degeneration., Potentially a small performance<br>
- win, as well as getting the bbox correct.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gxclip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-16 07:06:09 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8269dd2b5f6d5aea4a5c1a6374dd7f6e6b7202f5">8269dd2b5f6d5aea4a5c1a6374dd7f6e6b7202f5</a>
-<blockquote>
-<p>
- Fix parameters to tile_by_steps that improves performance on J10<br>
-<br>
- Found while investigating performance for cust 532, one of the calls<br>
- to tile_by_steps in gx_trans_pattern_fill_rect passed the rect upper<br>
- right rather than the width and height. This improved the time spent<br>
- in tile_by_steps from 8 sec to 4 sec on the JEITA J10 page.<br>
-<br>
-gs/base/gxp1fill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-30 07:40:56 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b6c504d49663d737dffbd42aace7891c3fb15dd">9b6c504d49663d737dffbd42aace7891c3fb15dd</a>
-<blockquote>
-<p>
- Fix Knockout true, Isolated false blending with pdf transparency. fts_25_2524<br>
-<br>
- This was reported by customer 532. Knockout blending was seriously broken in<br>
- not using the background correctly when not isolated, and knockout blending<br>
- in art_pdf_composite_knockout_simple_8 did not handle blend modes other than<br>
- normal. Also pdf14_compose_group was basing decisions on tos_isolated when<br>
- nos_isolated was needed, and a special check for tos_knockout when the nos<br>
- is the page level was not needed.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gxblend.c<br>
-gs/base/gxblend.h<br>
-gs/base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-12 15:44:47 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=77f9aa46adf05063752c9afdcd6cff92b332cb66">77f9aa46adf05063752c9afdcd6cff92b332cb66</a>
-<blockquote>
-<p>
- txtwrite - fix a couple of compiler warnings<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-27 14:50: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=b8a9352dac5e388de3c596371143040722fa2285">b8a9352dac5e388de3c596371143040722fa2285</a>
-<blockquote>
-<p>
- Bug 695258: optimize AGL name mapping.<br>
-<br>
- Add a &quot;reverse AGL&quot; dictionary which allows us to create the extra name mappings<br>
- with one pass over the CharStrings dictionary, rather than two passes over the<br>
- entire AGL dictionary.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_agl.ps<br>
-gs/Resource/Init/gs_ttf.ps<br>
-gs/Resource/Init/gs_type1.ps<br>
-gs/psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-12 08:46: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=1413e11d39ea015f1568a7ed7f00f99e16534259">1413e11d39ea015f1568a7ed7f00f99e16534259</a>
-<blockquote>
-<p>
- pdfwrite - more improvements on GoToR and link processing<br>
-<br>
- Still Bug #695269<br>
-<br>
- This time we take account of possible FirstPage and LastPage settings and<br>
- *don't* apply them to GoToR actions.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-11 13:38:56 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=759c5f4aca61fe8914eaec8d86e0a64850034430">759c5f4aca61fe8914eaec8d86e0a64850034430</a>
-<blockquote>
-<p>
- Deterministic seeding for random number generator so the file can be<br>
- regression tested.<br>
-<br>
-gs/examples/snowflak.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-10 17:39:23 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e4a278eccdfd1f7b45daee3b77f9776fcd11e686">e4a278eccdfd1f7b45daee3b77f9776fcd11e686</a>
-<blockquote>
-<p>
- Up the required version of autoconf to 2.60<br>
-<br>
- Due to our (long term!) use of the AC_PROG_SED macro, we need autoconf<br>
- 2.60 (the macro was actually added to the 2.59b release, but 2.60 is close<br>
- enough).<br>
-<br>
- No cluster differences<br>
-<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-10 15:28: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=cb32f7a923fbe661d5b959e8c7a24c147de7f782">cb32f7a923fbe661d5b959e8c7a24c147de7f782</a>
-<blockquote>
-<p>
- pdfwrite - don't include 'GoToR' references in check of destinations<br>
-<br>
- Bug #695269 &quot; PDF file containing outline or link annotation with GoToR action processing ended with a message &quot;ERROR: A pdfmark destination page XXX points beyond the last page YYYY.&quot;&quot;<br>
-<br>
- The problem is that the function which gets a numeric page number, either by<br>
- finding the /Next or /Prev keys or by finding an absolute page number, was<br>
- also updating the 'max_referred_page' variable. This is checked when closing<br>
- the PDF file and an error message emitted if it exceeds the number of pages<br>
- in the PDF file.<br>
-<br>
- Of course, for a GoToR action, its valid for the destination (which is in a<br>
- different file after all) to be greater than the number of pages in the current<br>
- file.<br>
-<br>
- This commit removes the update for the max_referred_page variable from<br>
- pdfmark_page_number, and places it in the calling function. This makes more<br>
- sense to me, its not reasonable that s utility function should have an<br>
- unexpected side effect like that, and it makes more sense for the function<br>
- which handles the destination to decide whether it should update this variable.<br>
-<br>
- No differences expected, we don't test this on the cluster.<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-10 13:31: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=baecaed381a6799e71c451933c3a1707f5653782">baecaed381a6799e71c451933c3a1707f5653782</a>
-<blockquote>
-<p>
- pdfwrite - improved handling of images with &gt; 8 BPC<br>
-<br>
- Bug #691713 &quot;/rangecheck in fts_18_1805.pdf on pdfwrite device&quot;<br>
- Bug #694731 &quot;pdfwrite doesn't handle 16 bpc images&quot;<br>
-<br>
- To date images with more than 8 bits per component, using any transparency<br>
- features, resulted in a rangecheck error as the code was incapable of<br>
- handling 12 or 16 bpc.<br>
-<br>
- The new image code (improved for colour management) now allows us to apply<br>
- a simple 16-&gt;8 (discarding the lower 8 bits) subsampler and this results<br>
- in all the files which caused problems working correctly.<br>
-<br>
- In addition, many files which previously 'fell back' to the default implementation<br>
- (where each image sample is transformed into a filled rectangle) now preserve<br>
- the image as an image. This makes the resulting PDF or PostScript file<br>
- considerably smaller and quicker to process.<br>
-<br>
- Note that this *only* works if the ColorConversionStrategy is 'LeaveColorUnchanged'<br>
- This is because the existing image colour space conversion code cannot cope<br>
- with anything other than 8-bit input.<br>
-<br>
- A number of test files show differences.<br>
-<br>
- The majority are PDF files which previously had content missing but now<br>
- render correctly.<br>
-<br>
- A number are due to the fact that the image is no longer degenerated into<br>
- thousands of rectangles which means that it is recompressed, if the input<br>
- was JPEG and the compression is also JPEG this results in visible artefacts.<br>
-<br>
- Some files show differences due to the fact that the naive downsampling<br>
- gives slightly different results from the accurate colour conversion. These<br>
- show slight improvements in about as many cases as they show slight degradation<br>
-<br>
-gs/devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-09 08:23: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=5cc8aa8af871ab95ddebc2fc15baaf261bd8bb89">5cc8aa8af871ab95ddebc2fc15baaf261bd8bb89</a>
-<blockquote>
-<p>
- PDF interpreter - remove some commented out code<br>
-<br>
- Commit 33fb85045c2590ac58a723ea2abcfbde505e53d1 included some code which was<br>
- commented out but should have been removed.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-07 11:46: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=33fb85045c2590ac58a723ea2abcfbde505e53d1">33fb85045c2590ac58a723ea2abcfbde505e53d1</a>
-<blockquote>
-<p>
- PDF interpreter - improve synthesis of text form fields with no /AP<br>
-<br>
- Bug #694738 &quot; Text synthesis of missing appearances in the PDF interpreter does not handle UTF16BE&quot;<br>
-<br>
- Previously we didn't strip the 0xFE 0xFF byte order mark from UTF16-BE strings<br>
- this commit removes them. We also remove the requirement for a /DA (Default<br>
- Appearance) to be present in a Text field before we synthesise a replacement<br>
- for a missing AP, taking int account any UTF16 strings.<br>
-<br>
- This does not 'fix' bug #694738 but this is because the /DA uses a font which<br>
- is not correctly encoded to draw UTF16 text. The font uses an /Identity-H<br>
- CMap which is unlikely to work with UTF16. Replacing it with our own fallback<br>
- CID font and using a /Identity-UTF16-H CMap draws the text correctly, which<br>
- shows that the problem is the font. NB Acrobat (as usual) ignores appearances<br>
- and creates its own representation, so the Acrobat display is not an indication<br>
- of a bug in GS.<br>
-<br>
- A few files in the test suite show differences because we no longer attempt<br>
- to print the BOM.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-06 17:06: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=b5e0be23db6988057a0007cec24b592180ec25ff">b5e0be23db6988057a0007cec24b592180ec25ff</a>
-<blockquote>
-<p>
- Handle the Identity-UTF16-H CMap &quot;properly&quot;<br>
-<br>
- For &quot;normal&quot; identity CMaps we skip a step in decoding the CID to the GID, but<br>
- this should not be done for the Identity-UTF16-H CMap.<br>
-<br>
- Relates to (but does not resolve) Bug 694738.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-05 16:37:36 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=235b2db4ab9cfd5b82bb45fb941bec04d41a00c8">235b2db4ab9cfd5b82bb45fb941bec04d41a00c8</a>
-<blockquote>
-<p>
- Tweaks for cups 1.7.3 to build on Windows and OS X<br>
-<br>
- No cluster differences<br>
-<br>
-gs/cups/libs/cups/cups.h<br>
-gs/cups/libs/cups/debug.c<br>
-gs/cups/libs/cups/globals.c<br>
-gs/cups/libs/cups/ipp.c<br>
-gs/cups/libs/cups/language.c<br>
-gs/cups/libs/cups/usersys.c<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-05 15:36:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e9b8fbfed2c406ef7612f8c7b7e846f71a2d93d1">e9b8fbfed2c406ef7612f8c7b7e846f71a2d93d1</a>
-<blockquote>
-<p>
- Update libcups to 1.7.3<br>
-<br>
-gs/base/lcups.mak<br>
-gs/base/lcupsi.mak<br>
-gs/cups/libs/configlinux.h<br>
-gs/cups/libs/configwin.h<br>
-gs/cups/libs/cups/Dependencies<br>
-gs/cups/libs/cups/Makefile<br>
-gs/cups/libs/cups/adminutil.c<br>
-gs/cups/libs/cups/adminutil.h<br>
-gs/cups/libs/cups/api-array.header<br>
-gs/cups/libs/cups/api-array.shtml<br>
-gs/cups/libs/cups/api-cups.header<br>
-gs/cups/libs/cups/api-cups.shtml<br>
-gs/cups/libs/cups/api-filedir.header<br>
-gs/cups/libs/cups/api-filedir.shtml<br>
-gs/cups/libs/cups/api-filter.header<br>
-gs/cups/libs/cups/api-filter.shtml<br>
-gs/cups/libs/cups/api-httpipp.header<br>
-gs/cups/libs/cups/api-httpipp.shtml<br>
-gs/cups/libs/cups/api-overview.header<br>
-gs/cups/libs/cups/api-overview.shtml<br>
-gs/cups/libs/cups/api-ppd.header<br>
-gs/cups/libs/cups/api-ppd.shtml<br>
-gs/cups/libs/cups/array-private.h<br>
-gs/cups/libs/cups/array.c<br>
-gs/cups/libs/cups/array.h<br>
-gs/cups/libs/cups/attr.c<br>
-gs/cups/libs/cups/auth.c<br>
-gs/cups/libs/cups/backchannel.c<br>
-gs/cups/libs/cups/backend.c<br>
-gs/cups/libs/cups/backend.h<br>
-gs/cups/libs/cups/conflicts.c<br>
-gs/cups/libs/cups/cups-private.h<br>
-gs/cups/libs/cups/cups.h<br>
-gs/cups/libs/cups/custom.c<br>
-gs/cups/libs/cups/debug-private.h<br>
-gs/cups/libs/cups/debug.c<br>
-gs/cups/libs/cups/debug.h<br>
-gs/cups/libs/cups/dest-job.c<br>
-gs/cups/libs/cups/dest-localization.c<br>
-gs/cups/libs/cups/dest-options.c<br>
-gs/cups/libs/cups/dest.c<br>
-gs/cups/libs/cups/dir.c<br>
-gs/cups/libs/cups/dir.h<br>
-gs/cups/libs/cups/emit.c<br>
-gs/cups/libs/cups/encode.c<br>
-gs/cups/libs/cups/file-private.h<br>
-gs/cups/libs/cups/file.c<br>
-gs/cups/libs/cups/file.h<br>
-gs/cups/libs/cups/getdevices.c<br>
-gs/cups/libs/cups/getifaddrs.c<br>
-gs/cups/libs/cups/getputfile.c<br>
-gs/cups/libs/cups/globals.c<br>
-gs/cups/libs/cups/globals.h<br>
-gs/cups/libs/cups/http-addr.c<br>
-gs/cups/libs/cups/http-addrlist.c<br>
-gs/cups/libs/cups/http-private.h<br>
-gs/cups/libs/cups/http-support.c<br>
-gs/cups/libs/cups/http.c<br>
-gs/cups/libs/cups/http.h<br>
-gs/cups/libs/cups/i18n.h<br>
-gs/cups/libs/cups/ipp-private.h<br>
-gs/cups/libs/cups/ipp-support.c<br>
-gs/cups/libs/cups/ipp.c<br>
-gs/cups/libs/cups/ipp.h<br>
-gs/cups/libs/cups/langprintf.c<br>
-gs/cups/libs/cups/language-private.h<br>
-gs/cups/libs/cups/language.c<br>
-gs/cups/libs/cups/language.h<br>
-gs/cups/libs/cups/libcups2.def<br>
-gs/cups/libs/cups/libcups2.rc<br>
-gs/cups/libs/cups/libcups_s.exp<br>
-gs/cups/libs/cups/localize.c<br>
-gs/cups/libs/cups/mark.c<br>
-gs/cups/libs/cups/md5-apple.h<br>
-gs/cups/libs/cups/md5-private.h<br>
-gs/cups/libs/cups/md5.c<br>
-gs/cups/libs/cups/md5.h<br>
-gs/cups/libs/cups/md5passwd.c<br>
-gs/cups/libs/cups/notify.c<br>
-gs/cups/libs/cups/options.c<br>
-gs/cups/libs/cups/page.c<br>
-gs/cups/libs/cups/ppd-cache.c<br>
-gs/cups/libs/cups/ppd-private.h<br>
-gs/cups/libs/cups/ppd.c<br>
-gs/cups/libs/cups/ppd.h<br>
-gs/cups/libs/cups/pwg-file.c<br>
-gs/cups/libs/cups/pwg-media.c<br>
-gs/cups/libs/cups/pwg-ppd.c<br>
-gs/cups/libs/cups/pwg-private.h<br>
-gs/cups/libs/cups/pwg.h<br>
-gs/cups/libs/cups/raster-private.h<br>
-gs/cups/libs/cups/raster.h<br>
-gs/cups/libs/cups/request.c<br>
-gs/cups/libs/cups/sidechannel.c<br>
-gs/cups/libs/cups/sidechannel.h<br>
-gs/cups/libs/cups/snmp-private.h<br>
-gs/cups/libs/cups/snmp.c<br>
-gs/cups/libs/cups/snprintf.c<br>
-gs/cups/libs/cups/sspi-private.h<br>
-gs/cups/libs/cups/sspi.c<br>
-gs/cups/libs/cups/string-private.h<br>
-gs/cups/libs/cups/string.c<br>
-gs/cups/libs/cups/string.h<br>
-gs/cups/libs/cups/tempfile.c<br>
-gs/cups/libs/cups/test.ppd<br>
-gs/cups/libs/cups/test2.ppd<br>
-gs/cups/libs/cups/testadmin.c<br>
-gs/cups/libs/cups/testarray.c<br>
-gs/cups/libs/cups/testconflicts.c<br>
-gs/cups/libs/cups/testcups.c<br>
-gs/cups/libs/cups/testfile.c<br>
-gs/cups/libs/cups/testhttp.c<br>
-gs/cups/libs/cups/testi18n.c<br>
-gs/cups/libs/cups/testipp.c<br>
-gs/cups/libs/cups/testlang.c<br>
-gs/cups/libs/cups/testoptions.c<br>
-gs/cups/libs/cups/testppd.c<br>
-gs/cups/libs/cups/testpwg.c<br>
-gs/cups/libs/cups/testsnmp.c<br>
-gs/cups/libs/cups/thread-private.h<br>
-gs/cups/libs/cups/thread.c<br>
-gs/cups/libs/cups/transcode.c<br>
-gs/cups/libs/cups/transcode.h<br>
-gs/cups/libs/cups/usersys.c<br>
-gs/cups/libs/cups/utf8demo.txt<br>
-gs/cups/libs/cups/util.c<br>
-gs/cups/libs/cups/versioning.h<br>
-gs/cups/libs/filter/Dependencies<br>
-gs/cups/libs/filter/Makefile<br>
-gs/cups/libs/filter/api-raster.header<br>
-gs/cups/libs/filter/api-raster.shtml<br>
-gs/cups/libs/filter/commandtops.c<br>
-gs/cups/libs/filter/common.c<br>
-gs/cups/libs/filter/common.h<br>
-gs/cups/libs/filter/error.c<br>
-gs/cups/libs/filter/gziptoany.c<br>
-gs/cups/libs/filter/image-bmp.c<br>
-gs/cups/libs/filter/image-colorspace.c<br>
-gs/cups/libs/filter/image-gif.c<br>
-gs/cups/libs/filter/image-jpeg.c<br>
-gs/cups/libs/filter/image-photocd.c<br>
-gs/cups/libs/filter/image-pix.c<br>
-gs/cups/libs/filter/image-png.c<br>
-gs/cups/libs/filter/image-pnm.c<br>
-gs/cups/libs/filter/image-private.h<br>
-gs/cups/libs/filter/image-sgi.c<br>
-gs/cups/libs/filter/image-sgi.h<br>
-gs/cups/libs/filter/image-sgilib.c<br>
-gs/cups/libs/filter/image-sun.c<br>
-gs/cups/libs/filter/image-tiff.c<br>
-gs/cups/libs/filter/image-zoom.c<br>
-gs/cups/libs/filter/image.c<br>
-gs/cups/libs/filter/image.h<br>
-gs/cups/libs/filter/interpret.c<br>
-gs/cups/libs/filter/libcupsimage2.def<br>
-gs/cups/libs/filter/libcupsimage_s.exp<br>
-gs/cups/libs/filter/postscript-driver.header<br>
-gs/cups/libs/filter/postscript-driver.shtml<br>
-gs/cups/libs/filter/ppd-compiler.header<br>
-gs/cups/libs/filter/ppd-compiler.shtml<br>
-gs/cups/libs/filter/pstops.c<br>
-gs/cups/libs/filter/raster-driver.header<br>
-gs/cups/libs/filter/raster-driver.shtml<br>
-gs/cups/libs/filter/raster.c<br>
-gs/cups/libs/filter/rasterbench.c<br>
-gs/cups/libs/filter/rastertoepson.c<br>
-gs/cups/libs/filter/rastertohp.c<br>
-gs/cups/libs/filter/rastertolabel.c<br>
-gs/cups/libs/filter/rastertopwg.c<br>
-gs/cups/libs/filter/spec-ppd.header<br>
-gs/cups/libs/filter/spec-ppd.shtml<br>
-gs/cups/libs/filter/testraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-05 17:06: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=e2da8a39efbfbd96cb05964f3d90e33a507256ef">e2da8a39efbfbd96cb05964f3d90e33a507256ef</a>
-<blockquote>
-<p>
- Include pwgraster.dev with suitable cups revisions<br>
-<br>
- The pwgraster support arrived in cups 1.5, so only build in pwgraster device<br>
- when linking with cups 1.5 and later.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-05 13:36:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd1ec1cfbc66568eeb6c2b4413a477568caeadf4">cd1ec1cfbc66568eeb6c2b4413a477568caeadf4</a>
-<blockquote>
-<p>
- PDF interpreter - ignore broken appearance dicts<br>
-<br>
- Bug #692181 &quot; %%EOF marker&quot;<br>
-<br>
- The bug title is very misleading, there were two problems;<br>
- 1) Ghostscript didn't synthesise appearances fro FreeText annotations<br>
- 2) The appearance dictionaries were invalid.<br>
-<br>
- Previous work added support for FreeText annotations, this commit adds some<br>
- slight improvements to that, and in addition it does minimal validation on<br>
- the AP (appearance) dictionary. If its invalid we don't bother to use it<br>
- but synthesise an appearance anyway.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-03 11:27:09 -0700
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2deb460ef02e2802546e09979243764ede2d4173">2deb460ef02e2802546e09979243764ede2d4173</a>
-<blockquote>
-<p>
- Bug 695274: validate CIDFont substitute records.<br>
-<br>
- In cidfmap records which substitute TTF fonts check whether we can access<br>
- the TTF file, if we cannot, remove the record from the map.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_cidfm.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-03 11:18:13 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc5257faa69ed02333ac63bd1f3c5e360931407a">cc5257faa69ed02333ac63bd1f3c5e360931407a</a>
-<blockquote>
-<p>
- Changed copyright date to 2014.<br>
-<br>
-gs/base/gscdef.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-31 14:02: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=4994e176c4b8ff43ccc91dba807879d02d070d88">4994e176c4b8ff43ccc91dba807879d02d070d88</a>
-<blockquote>
-<p>
- Bug 695272: init PS arrays at alloc time<br>
-<br>
- Write null objects to PS arrays when they are allocated - prevents invalid<br>
- reads/writes during garbage collection if we hit an error between allocation<br>
- and the contents being written.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/ialloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-31 13:24: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=053fa67fa93fa7be26885422f3881b72ccc682a0">053fa67fa93fa7be26885422f3881b72ccc682a0</a>
-<blockquote>
-<p>
- Bug 695275: Add bounds check when retrieving TTF name<br>
-<br>
- When deciding whether a TTF font name is multi or single byte string,<br>
- validate the Platform ID before trying to use it. If it is invalid<br>
- attempt to continue as a single byte string.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-03 05:07: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=87b6bca6b9878ea28e460baac62f0abe974c5748">87b6bca6b9878ea28e460baac62f0abe974c5748</a>
-<blockquote>
-<p>
- txtwrite - fix BOM emission<br>
-<br>
- Bug #695292 &quot;txtwrite device extracts unicode text from file like bigendian&quot;<br>
-<br>
- The code was emitting the BOM in a way that meant it was always written as<br>
- a big-endian BOM when in fsct it should have been the native endian-ness.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-02 17:24:16 -0700
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dae5b12f2e9e4716d6d60874efd7bfee410d69c7">dae5b12f2e9e4716d6d60874efd7bfee410d69c7</a>
-<blockquote>
-<p>
- Destroy gslite<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-doc/who_owns_what.txt<br>
-gs/base/gxccman.c<br>
-gs/base/gxfcache.h<br>
-tools/gslite/README<br>
-tools/gslite/gslite-api.rtf<br>
-tools/gslite/gslt.def<br>
-tools/gslite/gslt.h<br>
-tools/gslite/gslt.mak<br>
-tools/gslite/gslt_alloc.c<br>
-tools/gslite/gslt_alloc.h<br>
-tools/gslite/gslt_font.h<br>
-tools/gslite/gslt_font_api.c<br>
-tools/gslite/gslt_font_api.h<br>
-tools/gslite/gslt_font_api_test.c<br>
-tools/gslite/gslt_font_cache.c<br>
-tools/gslite/gslt_font_cff.c<br>
-tools/gslite/gslt_font_encoding.c<br>
-tools/gslite/gslt_font_glyph.c<br>
-tools/gslite/gslt_font_int.h<br>
-tools/gslite/gslt_font_test.c<br>
-tools/gslite/gslt_font_ttf.c<br>
-tools/gslite/gslt_image.c<br>
-tools/gslite/gslt_image.h<br>
-tools/gslite/gslt_image_jpeg.c<br>
-tools/gslite/gslt_image_png.c<br>
-tools/gslite/gslt_image_test.c<br>
-tools/gslite/gslt_image_threads_test.c<br>
-tools/gslite/gslt_image_tiff.c<br>
-tools/gslite/gslt_init.c<br>
-tools/gslite/gslt_lib_gcc.mak<br>
-tools/gslite/gslt_lib_msvc.mak<br>
-tools/gslite/gslt_stubs.c<br>
-tools/gslite/gslt_test.c<br>
-tools/gslite/tiger.jpg<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-02 17:07:28 -0700
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ddcebb6600c102f0d7d8a396f0dafa67845df48b">ddcebb6600c102f0d7d8a396f0dafa67845df48b</a>
-<blockquote>
-<p>
- Remove &quot;commercial only&quot; comment from ETS docs<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/toolbin/halftone/ETS/README.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-06-02 17:32:33 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e054f1e08f8fdaa557f56cee5ff93f354db1f971">e054f1e08f8fdaa557f56cee5ff93f354db1f971</a>
-<blockquote>
-<p>
- &quot;cups&quot; output device: Do byte-swapping for correct Endian not only for EncodeLUT but also for DecodeLUT<br>
-<br>
- Robin Watts on bug bugs.ghostscript.com/show_bug.cgi?id=695264:<br>
-<br>
- ----------<br>
- Generally, I think it's considered good form that encode_color and<br>
- decode_color should be complementary operations :)<br>
-<br>
- devcups uses EncodeLUT to implement encode_color, and DecodeLUT to<br>
- implement decode_color.<br>
-<br>
- In the case of little endian 16bit, it packs a endian reversal into<br>
- EncodeLUT. It leaves DecodeLUT undiddled though.<br>
-<br>
- Diddling DecodeLUT in the equivalent manner seems (superficially at<br>
- least) to solve the problem.<br>
- ----------<br>
-<br>
- This makes all 16-bit color spaces give correct colors on rasterview.<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-29 15:33: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=95eea50e13987bd06d5634ec7f4dc381a76ee629">95eea50e13987bd06d5634ec7f4dc381a76ee629</a>
-<blockquote>
-<p>
- PDF interpreter - add support for GoTo and GoToR in Link annotations of PDF files<br>
-<br>
- Bug #695268 &quot;PDF file containing link annotation with GoToR action<br>
- broken by GS processing, action is not passed&quot;<br>
-<br>
- Patch supplied by Jacek Bator after the code for Outlines with GoTo and<br>
- GoToR annotations.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-29 08:32: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=272d83387ff590244e3fb8719e8eef2e928f514d">272d83387ff590244e3fb8719e8eef2e928f514d</a>
-<blockquote>
-<p>
- pdfwrite - fix GoTo processing for Outlines in PDF input files<br>
-<br>
- Bug #695267 &quot;Incorrect PDF output for outlines and link annotations with GoTo action&quot;<br>
-<br>
- commit 099657a962e716658f20658051c9692b439ecf2d incorrectly modified the<br>
- GoTo action, it turns out that GoTo and GoToR really do have to be handled<br>
- differently.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-28 20:43:35 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=73123c3caa6495e1b30d1ecd35602629d6a8c17e">73123c3caa6495e1b30d1ecd35602629d6a8c17e</a>
-<blockquote>
-<p>
- Bug 695116: Rewrite JPEG header height when required.<br>
-<br>
- This follows on from Kens previous commit and should fix the bug.<br>
-<br>
- When a PDF includes a JPEG it states the height to use for that<br>
- JPEG. We now check the JPEG header to see if the height declared<br>
- there is 0 or is greater than the PDF specified height. If so,<br>
- we rewrite the header to contain the height specified in the PDF.<br>
-<br>
- Short of performing radical surgery on libjpeg to make it honour<br>
- the DNL tag, this is the best we are going to be able to do.<br>
-<br>
-gs/base/sdctd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-28 18:52: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=ddaea8157085f4efb227e78326dd739d59493b97">ddaea8157085f4efb227e78326dd739d59493b97</a>
-<blockquote>
-<p>
- PDF interpreter - pass image height as a /DecodeParm to all filters<br>
-<br>
- Bug #695116 &quot;**** Warning: File has insufficient data for an image&quot;<br>
-<br>
- This is not a solution for this bug, merely framework to allow it to be fixed.<br>
-<br>
- The PDF file contains a DCT encoded stream for an image, where the header<br>
- declares a height of '-1' and then later uses a DNL marker to set the actual<br>
- number of rows of data in the image. This does not work with libjpeg (in<br>
- fact it doesn't work with an number of JPEG consumers).<br>
-<br>
- However, because this is an image in a PDF file, we do have the image dimensiosn<br>
- from the image dictionary, so we can use that instead, if only we had a way<br>
- to pass the information into the stream decode filter.<br>
-<br>
- This commit modifies the dictionary we provide to the stream code in the PDF<br>
- interpreter, we now insist that all the Filters in an image shall have a<br>
- DecodeParms dictionary, if they don;t already have one we create them as<br>
- required. In that dictionary we add a /Height key and put the Height retrieved<br>
- from the image dictionary in it.<br>
-<br>
- All the decode operators handle being passed a dictionary with parameters,<br>
- so all that is then necessary is to have the DCT decode filter check the<br>
- parameter dictionary and store the Height from it in a new entry in the DCT<br>
- stream state.<br>
-<br>
- The parameter is now available for use by the DCT decode filter, and a future<br>
- commit will use it to fix the actual problem.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/base/sdcparam.c<br>
-gs/base/sdct.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-28 14:48:27 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=625b7570141287bf5ca7b61fc733f81b109b45d7">625b7570141287bf5ca7b61fc733f81b109b45d7</a>
-<blockquote>
-<p>
- &quot;cups&quot; output device: Fixed obvious copy-and-paste error in color conversion.<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-28 11:46:07 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d5065760d06ba71646d08240b87a8de08104c4c5">d5065760d06ba71646d08240b87a8de08104c4c5</a>
-<blockquote>
-<p>
- Fixed PWG Raster support in gdevcups.c to build with all CUPS library versions<br>
-<br>
- We determine now whether we have PWG Raster support by the proper<br>
- macro of the CUPS library, not by whether the built-in or an external<br>
- lib is used. So we can also build with older CUPS library versions as<br>
- external library (bug 695243).<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-28 08:33:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=230e512962ab5d05f137fc6b3665f5dcae0aa4e9">230e512962ab5d05f137fc6b3665f5dcae0aa4e9</a>
-<blockquote>
-<p>
- pdfwrite - test a return code to silence a compiler warning<br>
-<br>
-gs/devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-27 14:09:50 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=64dd281abf84ba7383aa85c99599b5aebea3998a">64dd281abf84ba7383aa85c99599b5aebea3998a</a>
-<blockquote>
-<p>
- pdfwrite - improved handling of 'glyphshow' and similar operations<br>
-<br>
- Bug #695168 &quot;Problem converting xps to pdf&quot;<br>
- Bug #695259 &quot;both (incorrect) B/W and (correct) AA rendering of Libertine font in same PDF output&quot;<br>
-<br>
- Although these are different products, one being Ghostscript and the other<br>
- gxps, the underlying problem is similar. The PostScript makes extensive use<br>
- of the glyphshow operator, which ends up as a TEXT_FROM_SINGLE_GLYPH operation<br>
- in the graphics library, and the XPS interpreter always uses TEXT_FROM_GLYPHS.<br>
-<br>
- In both cases the font is effectively unencoded when pdfwrite seee it. Since<br>
- we cannot construct and use an unencoded font in PDF we have no alternative<br>
- but to create an encoding for the font, and write the text using that encoding.<br>
-<br>
- The way this is done we use the name table, which effectively means that the<br>
- character code we use is derived from the first byte of the glyph name. For<br>
- limited usage this works well, but more complex usage can result in problems.<br>
- For example the glyphs /o and /omicron are both encoded at index 103.<br>
-<br>
- Previously this would cause us to fall back to rendering the font and embedding<br>
- as a type 3 font, or in the worst case an inline image. This is because when<br>
- encoding the text we would discover that an the font already had a glyph<br>
- encoded at the correct index, and would simply pass on, not realising it was<br>
- the incorrect glyph. Later we would check the actual glyph index against the glyph index<br>
- of the glyph encoded at that position, realise they were different and throw an error.<br>
-<br>
- In this commit we check the glyph index early, at the point where we encode the text.<br>
- If the font already has a glyph encoded at the given character code, we check<br>
- the glyph index to see if it matches the current glyph. If it does all is well<br>
- but if it doesn't we break out and create a new font instance, with the new<br>
- glyph encoded in it.<br>
-<br>
- Potentially this could result in a *lot* of font subsets being created, which<br>
- would increase the size of the output PDF file, but the quality improvement<br>
- is well worth it.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-26 12:43: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=099657a962e716658f20658051c9692b439ecf2d">099657a962e716658f20658051c9692b439ecf2d</a>
-<blockquote>
-<p>
- pdfwrite - fix GoTo and GoToR actions when passed through from PDF input<br>
-<br>
- Bug #695232 &quot;Broken PDF file when input file containes bookmarks with GoToR action&quot;<br>
-<br>
- When adding the GoToR functionality I copied the code from the GoTo action<br>
- sadly it seems the GoTo was already incorrect.<br>
-<br>
- This commit should fix both, though I don't have a test for the GoTo action.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-24 09:04: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=5e868fffeaa21ebb0f7b30a4a9c29272d850b18a">5e868fffeaa21ebb0f7b30a4a9c29272d850b18a</a>
-<blockquote>
-<p>
- pdfwrite - prototype a function to silence compiler warnings<br>
-<br>
-gs/devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-23 13:59: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=cb5c738d04a028a88633f3f98d955f4218b05654">cb5c738d04a028a88633f3f98d955f4218b05654</a>
-<blockquote>
-<p>
- pdfwrite - better handling of input PDF files with broken fonts<br>
-<br>
- Bug #695216 &quot;Spurious errors and bad PDF written from input file comparefles/Bug693711.pdf&quot;<br>
-<br>
- The errors are not spurious, and are caused by the missing/damaged fonts in<br>
- the input file.<br>
-<br>
- This commit chooses to ignore these errors, but I may rethink that if it causes<br>
- future problems, the fact that there are no errors when rendering does not<br>
- mean that there should be no errors when creating a PDF file.<br>
-<br>
- Because the PDF interpreter ignores errors and continues regardles we were<br>
- then attempting to write an invalid font, which failed, resulting in an<br>
- (unused) entry in the xref with a duplicate offset of an earlier entry. This<br>
- commit further refines the broken font handling by detecting the fact that<br>
- the font was incorrectly written and elides it from the xref table.<br>
-<br>
- This addresses both of the concerns raised in the bug report, though I would<br>
- point out that ignoring errors when the output device is pdfwrite is always<br>
- very likely to produce broken PDF files.<br>
-<br>
- This does alter the font substitution for Bug693711.pdf on Linux.<br>
-<br>
-gs/devices/vector/gdevpdfu.c<br>
-gs/devices/vector/gdevpdtb.c<br>
-gs/devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-22 18:33: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=93a23603b23160943b42c2f1e357fb75cc0a396b">93a23603b23160943b42c2f1e357fb75cc0a396b</a>
-<blockquote>
-<p>
- Add an extra compiler flag for OpenJPEG 2.1.0<br>
-<br>
- 2.1.0 requires an extra compiler flag &quot;USE_JPIP&quot; that I had forgotten to add<br>
- to the Windows build<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-21 15:30:35 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d2bc37f7e4096fe31d6ebc6679d79935f52ba0c">0d2bc37f7e4096fe31d6ebc6679d79935f52ba0c</a>
-<blockquote>
-<p>
- Update OpenJPEG to 2.1.0<br>
-<br>
- No cluster differences.<br>
-<br>
- Revise configure script with extra flags for OPJ<br>
-<br>
- Copy in new openjpeg (2.1.0) complete<br>
-<br>
- Zap the openjpeg stuff we don't need<br>
-<br>
- Add predefined openjpeg headers.<br>
-<br>
- These are *nearly* empty of actual definitions, as we generate the settings<br>
- from the gs configure script.<br>
-<br>
- Revised makefiles and configure script for new openjpeg<br>
-<br>
- Tweak for updated openjpeg API<br>
-<br>
- Import patches OpenJPEG from Sumatra's tree:<br>
-<br>
- Reference:<br>
- https://code.google.com/p/sumatrapdf/source/browse/trunk/ext/_patches/openjpeg.patch?r=8887<br>
-<br>
-gs/base/gs.mak<br>
-gs/base/openjpeg.mak<br>
-gs/base/sjpx_openjpeg.c<br>
-gs/configure.ac<br>
-gs/openjpeg/AUTHORS<br>
-gs/openjpeg/CHANGES<br>
-gs/openjpeg/LICENSE<br>
-gs/openjpeg/NEWS<br>
-gs/openjpeg/THANKS<br>
-gs/openjpeg/libopenjpeg/CMakeLists.txt<br>
-gs/openjpeg/libopenjpeg/Makefile.am<br>
-gs/openjpeg/libopenjpeg/Makefile.in<br>
-gs/openjpeg/libopenjpeg/bio.c<br>
-gs/openjpeg/libopenjpeg/bio.h<br>
-gs/openjpeg/libopenjpeg/cidx_manager.c<br>
-gs/openjpeg/libopenjpeg/cidx_manager.h<br>
-gs/openjpeg/libopenjpeg/cio.c<br>
-gs/openjpeg/libopenjpeg/cio.h<br>
-gs/openjpeg/libopenjpeg/dwt.c<br>
-gs/openjpeg/libopenjpeg/dwt.h<br>
-gs/openjpeg/libopenjpeg/event.c<br>
-gs/openjpeg/libopenjpeg/event.h<br>
-gs/openjpeg/libopenjpeg/fix.h<br>
-gs/openjpeg/libopenjpeg/function_list.c<br>
-gs/openjpeg/libopenjpeg/function_list.h<br>
-gs/openjpeg/libopenjpeg/image.c<br>
-gs/openjpeg/libopenjpeg/image.h<br>
-gs/openjpeg/libopenjpeg/indexbox_manager.h<br>
-gs/openjpeg/libopenjpeg/int.h<br>
-gs/openjpeg/libopenjpeg/invert.c<br>
-gs/openjpeg/libopenjpeg/invert.h<br>
-gs/openjpeg/libopenjpeg/j2k.c<br>
-gs/openjpeg/libopenjpeg/j2k.h<br>
-gs/openjpeg/libopenjpeg/j2k_lib.c<br>
-gs/openjpeg/libopenjpeg/j2k_lib.h<br>
-gs/openjpeg/libopenjpeg/jp2.c<br>
-gs/openjpeg/libopenjpeg/jp2.h<br>
-gs/openjpeg/libopenjpeg/jpt.c<br>
-gs/openjpeg/libopenjpeg/jpt.h<br>
-gs/openjpeg/libopenjpeg/mct.c<br>
-gs/openjpeg/libopenjpeg/mct.h<br>
-gs/openjpeg/libopenjpeg/mqc.c<br>
-gs/openjpeg/libopenjpeg/mqc.h<br>
-gs/openjpeg/libopenjpeg/openjpeg.c<br>
-gs/openjpeg/libopenjpeg/openjpeg.h<br>
-gs/openjpeg/libopenjpeg/opj_clock.c<br>
-gs/openjpeg/libopenjpeg/opj_clock.h<br>
-gs/openjpeg/libopenjpeg/opj_config.h<br>
-gs/openjpeg/libopenjpeg/opj_config_private.h<br>
-gs/openjpeg/libopenjpeg/opj_includes.h<br>
-gs/openjpeg/libopenjpeg/opj_intmath.h<br>
-gs/openjpeg/libopenjpeg/opj_inttypes.h<br>
-gs/openjpeg/libopenjpeg/opj_malloc.h<br>
-gs/openjpeg/libopenjpeg/opj_stdint.h<br>
-gs/openjpeg/libopenjpeg/phix_manager.c<br>
-gs/openjpeg/libopenjpeg/pi.c<br>
-gs/openjpeg/libopenjpeg/pi.h<br>
-gs/openjpeg/libopenjpeg/ppix_manager.c<br>
-gs/openjpeg/libopenjpeg/raw.c<br>
-gs/openjpeg/libopenjpeg/raw.h<br>
-gs/openjpeg/libopenjpeg/t1.c<br>
-gs/openjpeg/libopenjpeg/t1.h<br>
-gs/openjpeg/libopenjpeg/t1_generate_luts.c<br>
-gs/openjpeg/libopenjpeg/t1_luts.h<br>
-gs/openjpeg/libopenjpeg/t2.c<br>
-gs/openjpeg/libopenjpeg/t2.h<br>
-gs/openjpeg/libopenjpeg/tcd.c<br>
-gs/openjpeg/libopenjpeg/tcd.h<br>
-gs/openjpeg/libopenjpeg/tgt.c<br>
-gs/openjpeg/libopenjpeg/tgt.h<br>
-gs/openjpeg/libopenjpeg/thix_manager.c<br>
-gs/openjpeg/libopenjpeg/tpix_manager.c<br>
-gs/openjpeg/opj_config.h.in.user<br>
-gs/openjpeg/src/lib/openjp2/CMakeLists.txt<br>
-gs/openjpeg/src/lib/openjp2/bio.c<br>
-gs/openjpeg/src/lib/openjp2/bio.h<br>
-gs/openjpeg/src/lib/openjp2/cidx_manager.c<br>
-gs/openjpeg/src/lib/openjp2/cidx_manager.h<br>
-gs/openjpeg/src/lib/openjp2/cio.c<br>
-gs/openjpeg/src/lib/openjp2/cio.h<br>
-gs/openjpeg/src/lib/openjp2/dwt.c<br>
-gs/openjpeg/src/lib/openjp2/dwt.h<br>
-gs/openjpeg/src/lib/openjp2/event.c<br>
-gs/openjpeg/src/lib/openjp2/event.h<br>
-gs/openjpeg/src/lib/openjp2/function_list.c<br>
-gs/openjpeg/src/lib/openjp2/function_list.h<br>
-gs/openjpeg/src/lib/openjp2/image.c<br>
-gs/openjpeg/src/lib/openjp2/image.h<br>
-gs/openjpeg/src/lib/openjp2/indexbox_manager.h<br>
-gs/openjpeg/src/lib/openjp2/invert.c<br>
-gs/openjpeg/src/lib/openjp2/invert.h<br>
-gs/openjpeg/src/lib/openjp2/j2k.c<br>
-gs/openjpeg/src/lib/openjp2/j2k.h<br>
-gs/openjpeg/src/lib/openjp2/jp2.c<br>
-gs/openjpeg/src/lib/openjp2/jp2.h<br>
-gs/openjpeg/src/lib/openjp2/libopenjp2.pc.cmake.in<br>
-gs/openjpeg/src/lib/openjp2/mct.c<br>
-gs/openjpeg/src/lib/openjp2/mct.h<br>
-gs/openjpeg/src/lib/openjp2/mqc.c<br>
-gs/openjpeg/src/lib/openjp2/mqc.h<br>
-gs/openjpeg/src/lib/openjp2/openjpeg.c<br>
-gs/openjpeg/src/lib/openjp2/openjpeg.h<br>
-gs/openjpeg/src/lib/openjp2/opj_clock.c<br>
-gs/openjpeg/src/lib/openjp2/opj_clock.h<br>
-gs/openjpeg/src/lib/openjp2/opj_codec.h<br>
-gs/openjpeg/src/lib/openjp2/opj_config.h<br>
-gs/openjpeg/src/lib/openjp2/opj_config.h.cmake.in<br>
-gs/openjpeg/src/lib/openjp2/opj_config_private.h<br>
-gs/openjpeg/src/lib/openjp2/opj_config_private.h.cmake.in<br>
-gs/openjpeg/src/lib/openjp2/opj_includes.h<br>
-gs/openjpeg/src/lib/openjp2/opj_intmath.h<br>
-gs/openjpeg/src/lib/openjp2/opj_inttypes.h<br>
-gs/openjpeg/src/lib/openjp2/opj_malloc.h<br>
-gs/openjpeg/src/lib/openjp2/opj_stdint.h<br>
-gs/openjpeg/src/lib/openjp2/phix_manager.c<br>
-gs/openjpeg/src/lib/openjp2/pi.c<br>
-gs/openjpeg/src/lib/openjp2/pi.h<br>
-gs/openjpeg/src/lib/openjp2/ppix_manager.c<br>
-gs/openjpeg/src/lib/openjp2/raw.c<br>
-gs/openjpeg/src/lib/openjp2/raw.h<br>
-gs/openjpeg/src/lib/openjp2/t1.c<br>
-gs/openjpeg/src/lib/openjp2/t1.h<br>
-gs/openjpeg/src/lib/openjp2/t1_generate_luts.c<br>
-gs/openjpeg/src/lib/openjp2/t1_luts.h<br>
-gs/openjpeg/src/lib/openjp2/t2.c<br>
-gs/openjpeg/src/lib/openjp2/t2.h<br>
-gs/openjpeg/src/lib/openjp2/tcd.c<br>
-gs/openjpeg/src/lib/openjp2/tcd.h<br>
-gs/openjpeg/src/lib/openjp2/tgt.c<br>
-gs/openjpeg/src/lib/openjp2/tgt.h<br>
-gs/openjpeg/src/lib/openjp2/thix_manager.c<br>
-gs/openjpeg/src/lib/openjp2/tpix_manager.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-20 11: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=21565d4ad3c3eed360d3a56c372663d1ba876c0d">21565d4ad3c3eed360d3a56c372663d1ba876c0d</a>
-<blockquote>
-<p>
- Fix for fts_09_0920 SMask in ExGState ignored for text.<br>
-<br>
- When the SMask is set in the ExtGState rather than in a Group Form,<br>
- we need to push a transparency group before painting the text (after<br>
- the setfillstate) and pop it afterwards, similarly to what we do<br>
- for fills and strokes.<br>
-<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-21 15:30:35 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f032367796457690caa484b1a50aa1f97b80322a">f032367796457690caa484b1a50aa1f97b80322a</a>
-<blockquote>
-<p>
- Ensure memory allocator is available for jpeg encoding<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/devices/gdevjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-21 13:15: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=cc26212b8b4a756d6da891c946b53c52641befd3">cc26212b8b4a756d6da891c946b53c52641befd3</a>
-<blockquote>
-<p>
- pdfwrite - add an idiom for certain patterns produced by the MS driver<br>
-<br>
-<br>
- Bug #695230 &quot;Invalid pattern fill rendering&quot;<br>
-<br>
- The Windows PostScript driver produces some patterns (for background fills)<br>
- which vary the size of the pattern cell according to the device resolution.<br>
- This means that as the resolution goes up, more pattern cells are drawn,<br>
- resulting in a finer and finer pattern.<br>
-<br>
- This resolution neatly defeats our high level pattern capture in pdfwrite.<br>
- It only works properly if the device is running at 72 dpi, and the example<br>
- runs at 600.<br>
-<br>
- It seems the easiest way to deal with this is to create an idiom which will<br>
- replace the resolution-varying pattern with a fixed pattern (it isn't possible<br>
- to have a resolution-dependent pattern in PDF anyway) and this commit adds<br>
- such an idiom.<br>
-<br>
- It also updates the idioms to use the new .spec_op operator to interrogate<br>
- device parameters rather than the slow getdeviceparams previously used.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/IdiomSet/Pscript5Idiom<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-19 15:53: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=1b06d7888faf61bef37fc17b10a1745d889f4c75">1b06d7888faf61bef37fc17b10a1745d889f4c75</a>
-<blockquote>
-<p>
- Remove jmorecfg.h from includes....<br>
-<br>
- in jmemcust.c<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/jmemcust.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-09 12:22:08 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cb50ac70a8e8874a265da59baca7e95790e79af1">cb50ac70a8e8874a265da59baca7e95790e79af1</a>
-<blockquote>
-<p>
- Add an app independent custom memory manager for libjpeg<br>
-<br>
-gs/base/jmemcust.c<br>
-gs/base/jmemcust.h<br>
-gs/base/jpeg.mak<br>
-gs/base/sjpeg.h<br>
-gs/base/sjpegc.c<br>
-gs/base/sjpegd.c<br>
-gs/base/sjpege.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-16 21:01:33 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0145175ab9d530a4ed2c79dc6290235b30e980cc">0145175ab9d530a4ed2c79dc6290235b30e980cc</a>
-<blockquote>
-<p>
- Temporarily disable code introduced in 6fefd767005a8e5e8da0cbb954d0d47fc45fc37b.<br>
-<br>
- For more details see Bug 695243.<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-15 19:54:04 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6fefd767005a8e5e8da0cbb954d0d47fc45fc37b">6fefd767005a8e5e8da0cbb954d0d47fc45fc37b</a>
-<blockquote>
-<p>
- CUPS Raster output device: Fix cupsRasterOpen() call to get correct PWG Raster output<br>
-<br>
- The CUPS Raster output device generated incorrect PWG Raster output<br>
- because it called cupsRasterOpen() without the required<br>
- CUPS_RASTER_WRITE_PWG mode setting. Due to the output never being<br>
- tested with an IPP Everywhere printer but only with software which<br>
- also accepts CUPS Raster, the bug did not get discovered until testing<br>
- the output against the mime type recognition of CUPS where it failed.<br>
-<br>
- Note that this patch only fixes the problem if a shared libcupsimage<br>
- library of the system is used, not with the library included with<br>
- Ghostscript. This is because the included library is too old to<br>
- contain PWG Raster output support. If the included CUPS libraries have<br>
- to be used, the CUPS Raster output device is built as before to assure<br>
- that Ghostscript builds and CUPS Raster can still get generated.<br>
-<br>
-gs/Makefile.in<br>
-gs/cups/gdevcups.c<br>
-gs/devices/devs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-15 08:51: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=4836ecb5c5a03eb7217937b8503b20068e9bf846">4836ecb5c5a03eb7217937b8503b20068e9bf846</a>
-<blockquote>
-<p>
- Bug 695227: fix crash in bbox device<br>
-<br>
- Don't try to assign the &quot;imaging_dev&quot; entry in the text enumerator if the<br>
- enumerator initialisation doesn't complete.<br>
-<br>
- Slightly modified version of the patch supplied by<br>
- Antti Husa &lt;a.husa@hushmail.com&gt;<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevbbox.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-12 11:13: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=a7434eca8268e31fdfc4b47740a7e7695b189bc0">a7434eca8268e31fdfc4b47740a7e7695b189bc0</a>
-<blockquote>
-<p>
- Words about static linking the executable.<br>
-<br>
- Mention the need to explicitly link libraries when building a static gs exe.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/doc/Make.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-12 10:53:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c4cfba8a74fd3255231fb381b55998753174849">3c4cfba8a74fd3255231fb381b55998753174849</a>
-<blockquote>
-<p>
- Pass SHARE_LCMS as a compiler flag.<br>
-<br>
- As pointed out by Albert Astals Cid &lt;aacid@kde.org&gt; although the code had been<br>
- changed to use the system malloc/free calls when sharing LCMS2, the flag<br>
- (SHARE_LCMS==1) I had forgotten to add it to the compiler parameters.<br>
-<br>
- I've opted to add SHARE_LCMS to the compiler flags for LCMS, and include them<br>
- when compiler our interface files - this seems less likely to throw up a<br>
- similar oversight in the future.<br>
-<br>
- No regression differences.<br>
-<br>
-gs/Makefile.in<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-09 07:32:54 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7df04bbe3a7126dc702cb09369ba29fd142bfa62">7df04bbe3a7126dc702cb09369ba29fd142bfa62</a>
-<blockquote>
-<p>
- Only include trace devices (tr_mono, tr_rgb, tr_cmyk) in DEBUG builds on MSVC<br>
-<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-09 07:22:08 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db885d6e72fce5140a56abc8d4f49b0a3658aad7">db885d6e72fce5140a56abc8d4f49b0a3658aad7</a>
-<blockquote>
-<p>
- Add tracedev (tr_mono, tr_rgb, tr_cmyk) to default MSVC build.<br>
-<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-09 00:41:44 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc278761f766f7dbbba051af13b1ea0fdc7cdb08">cc278761f766f7dbbba051af13b1ea0fdc7cdb08</a>
-<blockquote>
-<p>
- Further tweak to ETS; mention patents, and add image viewer<br>
-<br>
- Mention the patents in the comments of the code.<br>
-<br>
- Add the image viewer back, as for people without Photoshop it can<br>
- be hard to visualise the output.<br>
-<br>
-gs/toolbin/halftone/ETS/ets.c<br>
-gs/toolbin/halftone/ETS/ipview.html<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-08 13:19:09 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c203e3342db1933e610433de6915fcb66a8e593f">c203e3342db1933e610433de6915fcb66a8e593f</a>
-<blockquote>
-<p>
- Removed files that were no longer used (SSE and VEC files and Build files). Updated README.txt<br>
-<br>
-gs/toolbin/halftone/ETS/COPYING.txt<br>
-gs/toolbin/halftone/ETS/Makefile_avec<br>
-gs/toolbin/halftone/ETS/Makefile_sse2<br>
-gs/toolbin/halftone/ETS/README.txt<br>
-gs/toolbin/halftone/ETS/_eb_sse2.s<br>
-gs/toolbin/halftone/ETS/build.bat<br>
-gs/toolbin/halftone/ETS/eb_avec.c<br>
-gs/toolbin/halftone/ETS/eb_avec.h<br>
-gs/toolbin/halftone/ETS/eb_sse2.s<br>
-gs/toolbin/halftone/ETS/ets.c<br>
-gs/toolbin/halftone/ETS/ipview.html<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-05 11:38:10 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d2111f620ad95a5deb918c8d64be04012025fed1">d2111f620ad95a5deb918c8d64be04012025fed1</a>
-<blockquote>
-<p>
- Fix clist closepath to wrong start point. Bug 695205, cust 870.<br>
-<br>
- When writing paths into the clist, we simplify the path for each band.<br>
- This means that whole line segments that are not present within a band<br>
- can be omitted which speeds up path rendering for bands. This code had<br>
- a bug that could cause the closepath of a subpath to connect to the<br>
- wrong point.<br>
-<br>
- If the last element written for a subpath ends at point X, and the<br>
- start point of the first element of the next subpath is that same<br>
- point X, then the code would forget to emit a &quot;catchup&quot; moveto.<br>
- This would cause a closepath to connect to the initial point of<br>
- the previous subpath.<br>
-<br>
- Amazingly, this bug has been there since rev 3.60 (Nov 1995) although<br>
- a partial fix was added in 3.68 (May 1996).<br>
-<br>
-gs/base/gxclpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-07 17:51:21 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a33588aad3bde9321bd5ea7eaf37b5adba22482c">a33588aad3bde9321bd5ea7eaf37b5adba22482c</a>
-<blockquote>
-<p>
- Bug 695211: (addendum) set SHARE_TRIO for Windows builds<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-common/msvc_top.mak<br>
-gs/psi/msvc.mak<br>
-xps/xps_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-05 11:12: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=fc0420d74524a9988c8cdf465a2fbf234e343a38">fc0420d74524a9988c8cdf465a2fbf234e343a38</a>
-<blockquote>
-<p>
- Bug 695211: Allow trio to be shared.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/Makefile.in<br>
-gs/base/gs.mak<br>
-gs/base/lib.mak<br>
-gs/base/trio.mak<br>
-gs/configure.ac<br>
-main/pcl6_gcc.mak<br>
-main/pcl6_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-06 10:39:42 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a314230d18fd13810774318d985cc46fe9ed0102">a314230d18fd13810774318d985cc46fe9ed0102</a>
-<blockquote>
-<p>
- PDF interpreter - work around GSView usage of the interpreter<br>
-<br>
- Bug #695179 &quot;Inert links in PDF and collapsing PDF when opened in gsview with gs ver. newer that 9.07&quot;<br>
-<br>
- Commit 073f460af5bb37edb1849c5d6235048598100437 introduced a cumulative page<br>
- count, which is added to pdfmarks when encountered in order to cope with<br>
- running multiple input files. The pdfmarks from the second file would<br>
- be incorrect unless the number of pages in the first file were added to the<br>
- destinationpage numbers.<br>
-<br>
- Unfortunately the (undocumented, unsupported) way that GSView works with the<br>
- PDF interpreter to retrieve links failed, because the variable is unavailable<br>
- under the conditions that GSView exercises the interpreter.<br>
-<br>
- In this commit we extend the CumultaivePageCount usage so that we first check<br>
- if the variable is defined, and if its not, we set a default of '0'. This<br>
- should mean that the supported use of the PDF interpreter continues to work<br>
- correctly with multiple input files, and restores the GSView behaviour.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-05 11:39:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=50e62cb7c50393e0cbb34f82981e7d1f6d7a3a6d">50e62cb7c50393e0cbb34f82981e7d1f6d7a3a6d</a>
-<blockquote>
-<p>
- Bug 695206: add directories to deps for zlib/png objs<br>
-<br>
- Ensure that the build directories exist before we try to build any<br>
- object files from zlib or png.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/png.mak<br>
-gs/base/zlib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-29 15:46:44 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2cad20efb9a9a1ec483c58bd6a087a9445ba23dc">2cad20efb9a9a1ec483c58bd6a087a9445ba23dc</a>
-<blockquote>
-<p>
- Fix wrong tag value for customer 532, file &quot;VINEYARD_p1.pdf&quot;<br>
-<br>
- If the SOURCE alpha is 100%, then replace the tag, otherwise, OR.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-02 10:10: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=87218e9f187d2d8c36c3eb6721f2725d9834553a">87218e9f187d2d8c36c3eb6721f2725d9834553a</a>
-<blockquote>
-<p>
- txtwrite - fix a copy/paste error<br>
-<br>
- After allocating memory we checked to see if it was successful but we checked<br>
- the wrong variable. Corrected here.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-02 09:51: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=63a5201a2b5db40e11dd45cf991a7e5a84d7ce80">63a5201a2b5db40e11dd45cf991a7e5a84d7ce80</a>
-<blockquote>
-<p>
- txtwrite - clear file handle when file is closed<br>
-<br>
- When we close the output file, set the handle to 0 so that we don't later<br>
- attempt to close it again. Apparently closing a closed file causes a<br>
- problem on Linux.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-02 09:18: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=c82e83c2c10751f048a3f2260c9adaceaca7880e">c82e83c2c10751f048a3f2260c9adaceaca7880e</a>
-<blockquote>
-<p>
- Fix some scan-build warnings from commit 0476b5036d8175a4817a9385cb6a15b64fab310e<br>
-<br>
- The code dealing with single device parameters was over-aggressive about<br>
- reducing the ICC profile setup. In practice this is unlikely ever to be<br>
- a problem, there is no real chance that the setup won't be performed<br>
- before we reach this point, but its obviously much better to have the code<br>
- correct.<br>
-<br>
- This commit essentially copies verbatim the setup code from the normal<br>
- get_params device method in the default device.<br>
-<br>
-gs/base/gsdparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-30 12:19: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=34a04b46e5ed098251901ce0b51caa2137928922">34a04b46e5ed098251901ce0b51caa2137928922</a>
-<blockquote>
-<p>
- Bug 695194: ignore invalid color space in shading<br>
-<br>
- When checking objects for spot colors, ignore an invalid color space in a<br>
- shading object.<br>
-<br>
- The code during rendering already deals with this problem (by ignoring the<br>
- shading!).<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-30 09:58: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=b02681f8dd6799236f040576e35884634e9c3508">b02681f8dd6799236f040576e35884634e9c3508</a>
-<blockquote>
-<p>
- Bug 695193: USE_LARGE_COLOR_INDEX=0 on Windows<br>
-<br>
- As we use a pregenerated arch.h for Windows (in order to support cross compiling<br>
- 64 bit executables on 32 bit systems), we need to handle this in a combination<br>
- of the makefile and predefined arch.h<br>
-<br>
- This commit includes equivalent changes for the other pre-defined arch.h files<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/arch/osx-x86-x86_64-ppc-gcc.h<br>
-gs/arch/windows-arm-msvc.h<br>
-gs/arch/windows-x64-msvc.h<br>
-gs/arch/windows-x86-msvc.h<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-01 15:14: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=ad27e65ad745e4dd287e0f7a7a0efb2637472bc2">ad27e65ad745e4dd287e0f7a7a0efb2637472bc2</a>
-<blockquote>
-<p>
- Implement use of the new 'device param' spec op<br>
-<br>
- Wherever possible, replace the .getdeviceparams call with a call to the<br>
- PostScript .special_op to retrieve a single parameter.<br>
-<br>
- This cannot be done unless we can guarantee that the devices we are<br>
- interested in will implement the spec_op device method. So some places<br>
- which appear at first sight to be candidates can't be done this way.<br>
-<br>
-gs/Resource/Init/gs_cidfn.ps<br>
-gs/Resource/Init/gs_fapi.ps<br>
-gs/Resource/Init/gs_img.ps<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-gs/Resource/Init/gs_setpd.ps<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/Resource/Init/pdf_font.ps<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/Resource/Init/pdf_ops.ps<br>
-gs/psi/zfunc4.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-01 15:11: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=0476b5036d8175a4817a9385cb6a15b64fab310e">0476b5036d8175a4817a9385cb6a15b64fab310e</a>
-<blockquote>
-<p>
- Add support for the 'device param' spec op to devices<br>
-<br>
- Adds support for the spec_op which retrieves a single device parameter to<br>
- every device I cna find which currently implements spec_ops.<br>
-<br>
- Add spec_op support to the generic vector device, the txtwrite and the psdf<br>
- devices<br>
-<br>
-gs/base/gdevdflt.c<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevprn.h<br>
-gs/base/gdevvec.c<br>
-gs/base/gdevvec.h<br>
-gs/base/gsdparam.c<br>
-gs/base/gxdevice.h<br>
-gs/base/lib.mak<br>
-gs/devices/gdevcmykog.c<br>
-gs/devices/gdevfpng.c<br>
-gs/devices/vector/gdevpdfi.c<br>
-gs/devices/vector/gdevpdfp.c<br>
-gs/devices/vector/gdevpdfx.h<br>
-gs/devices/vector/gdevps.c<br>
-gs/devices/vector/gdevpsdf.h<br>
-gs/devices/vector/gdevpsdp.c<br>
-gs/devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-01 15:07: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=e2d3dca4aff619e0b407a8c04e559f9c509b9787">e2d3dca4aff619e0b407a8c04e559f9c509b9787</a>
-<blockquote>
-<p>
- Add a new PostScript operator to permit device spec_ops to be executed<br>
-<br>
-gs/psi/int.mak<br>
-gs/psi/opextern.h<br>
-gs/psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-05-01 15:05:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3b03988711bc5ab352c61e4937282e61e5e092aa">3b03988711bc5ab352c61e4937282e61e5e092aa</a>
-<blockquote>
-<p>
- Add a new 'spec op' to retrieve a single parameter from a device.<br>
-<br>
- Includes a new structure to be passed as the 'data' parameter to allow us<br>
- to pass multiple parameters.<br>
-<br>
-gs/base/gxdevsop.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-15 14:18:16 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e69c464da00208889ed4c55ef0e869ac9246e750">e69c464da00208889ed4c55ef0e869ac9246e750</a>
-<blockquote>
-<p>
- Avoid remap calls if color already mapped to a pure color.<br>
-<br>
- Device colors that map to a pure color are common. The optimization<br>
- reduced the number of remap_color calls to 1/390 on a QL pdf test<br>
- file (WWTTN1CT). Performance improvement is small if FP is fast.<br>
-<br>
-gs/base/gscolor2.c<br>
-gs/base/gxcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-29 11:48: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=0c5a6d8c142371b84542ab9ea175501f02cfb9bd">0c5a6d8c142371b84542ab9ea175501f02cfb9bd</a>
-<blockquote>
-<p>
- Bug 695190: implement glyph width cache for pcl/pxl<br>
-<br>
- Using the FAPI integration of UFST instead of the original PCL specific<br>
- one lost an optimisation where glyph widths were cached by the interpreter.<br>
-<br>
- Reintroduce this, and attach the widths cache to the plfont object (instead of<br>
- it being global).<br>
-<br>
- No cluster differences.<br>
-<br>
-pl/plchar.c<br>
-pl/plfont.c<br>
-pl/plfont.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-24 16:37: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=7580b5f2b52a51d9da6e8eb2188360f1c894ee1e">7580b5f2b52a51d9da6e8eb2188360f1c894ee1e</a>
-<blockquote>
-<p>
- Bug 695096: make the &quot;display&quot; device the default in gsx<br>
-<br>
- No cluster differences<br>
-<br>
-gs/psi/dxmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-24 16:22: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=496d5b9ee3c8247354152ec8d2b3b8268cdc4430">496d5b9ee3c8247354152ec8d2b3b8268cdc4430</a>
-<blockquote>
-<p>
- Add support for changing the default device list at runtime<br>
-<br>
- (Bug 695096)<br>
-<br>
- The graphics library searches a list of preferred devices to find a suitable<br>
- default device. Previously that list was created at graphics library compile<br>
- time and could not be changed after that.<br>
-<br>
- This change allows the calling application to retrieve the current string that<br>
- represents this list, and set its preferred list and order, if required.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsdevice.c<br>
-gs/base/gsdevice.h<br>
-gs/base/gslibctx.c<br>
-gs/base/gslibctx.h<br>
-gs/base/lib.mak<br>
-gs/psi/dwdll.c<br>
-gs/psi/dwdll.h<br>
-gs/psi/dwnodll.c<br>
-gs/psi/gsdll2.def<br>
-gs/psi/gsdll32.def<br>
-gs/psi/gsdll32metro.def<br>
-gs/psi/gsdll64.def<br>
-gs/psi/gsdll64metro.def<br>
-gs/psi/gsdllARM32metro.def<br>
-gs/psi/iapi.c<br>
-gs/psi/iapi.h<br>
-gs/psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-24 13:20:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5192635686b3a9da14e4531c7ce7ca85cd629a66">5192635686b3a9da14e4531c7ce7ca85cd629a66</a>
-<blockquote>
-<p>
- Don't pass a 32 bit variable 64 is expected.<br>
-<br>
- On 64 bit platforms the &quot;gsize&quot; type is 64 bits long, thus if we pass a 32 bit<br>
- integer into a call expecting to write to a gsize, we get stack corruption.<br>
-<br>
- Use a temporary gsize variable to retrieve the value, and then copy it to the<br>
- 32 bit integer. As this is for stdin buffers, we're not likely to require<br>
- 64 bit values!<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/psi/dxmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-22 23:50:51 -0400
-</strong>
-<br>James Cloos &lt;cloos@jhcloos.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab862a54568407fdaff554c56baed9809e23860b">ab862a54568407fdaff554c56baed9809e23860b</a>
-<blockquote>
-<p>
- Set the WM_CLASS property when using the x11 DEVICEs.<br>
-<br>
- Add an explicit call to XSetClassHint(1) to the x11 devices to ensure<br>
- that the WM_CLASS property is set.<br>
-<br>
- Setting WM_CLASS allows one to configure how gs’s output window behaves.<br>
-<br>
- For comparison, gtk+ sets the display DEVICE’s output window’s<br>
- WM_CLASS based on the executable’s name.<br>
-<br>
- Signed-off-by: James Cloos &lt;cloos@jhcloos.com&gt;<br>
- Signed-off-by: Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<br>
-gs/devices/gdevxini.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-23 09:43:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c79b0ee1dbc1cbbcbe406abd4bc47f617ed5cb2c">c79b0ee1dbc1cbbcbe406abd4bc47f617ed5cb2c</a>
-<blockquote>
-<p>
- pdfwrite - fix Named destinations with Names tree<br>
-<br>
- Bug #695162 &quot;Internal hyperlinks lost when converting to pdf&quot;<br>
- Bug #695175 &quot;can't save PDF file if compiled with hyperref packages&quot;<br>
-<br>
- In order to add support for the EMBED pdfmark we had to move the named destinations<br>
- from the PDF 1.1 /Dests dictionary to the PDF 1.2+ Names tree. The Names<br>
- tree requires that the 'keys' be strings, unlike the old Dests dict where<br>
- the keys are of course name objects.<br>
-<br>
- Now the PDF reference says that,with PDF 1.2 and above, both strings and<br>
- name objects can be used to refer to named destinations. However it appears<br>
- that this is not true for Acrobat, the reference to a named destination must<br>
- be a string object if we are using a Names tree.<br>
-<br>
- This commit alters the creation of the Names tree so that we store the actual<br>
- destinations as individual objects (this probably wasn't required, but it<br>
- mimics Distiller) instead of inline dictionaries, reinstates a missing /D<br>
- key in said dictionary and crucially alters the reference to the named<br>
- destination so that it is a string and not a name.<br>
-<br>
- The commit also caters for 'unusual' names in named destinations. The PDF<br>
- interpreter 'escapes' the name of a name object by adding leading NULLs if<br>
- the name contains certain kinds of characters. We weren't catering for that<br>
- when converting names to strings for inclusion in the Names tree, which was<br>
- leading to an empty object, and caused Acrobat to refuse to save the file.<br>
-<br>
- Finally, while investigating the problems, I noticed a logical error with<br>
- DOCVIEW pdfmarks which could result in Open actions being written incorrectly<br>
- and this is also fixed here.<br>
-<br>
- No differences expected as the cluster doesn't test this kind of metadata.<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-22 19:02: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=963c6827fdcd2e07c2a7bc6848a97eb7ecb3c38d">963c6827fdcd2e07c2a7bc6848a97eb7ecb3c38d</a>
-<blockquote>
-<p>
- Update Ghostscript solution for Windows.<br>
-<br>
- Later versions of VS dislike relative paths for the working directory<br>
- in the debug set up. The solution is to use &quot;$(ProjectDir)\..&quot; as this<br>
- evaluates to the same dir as &quot;..&quot; used to. Update the ReadMe to<br>
- reflect this.<br>
-<br>
- Also update the Solution files so that &quot;Output&quot; points to the built<br>
- executables. This enables the editing required for the debugging<br>
- setup to be simpler.<br>
-<br>
-gs/ghostscript-ufst.vcproj<br>
-gs/ghostscript.vcproj<br>
-win32/GhostPDL.sln<br>
-win32/ReadMe.txt<br>
-win32/language_switch.vcproj<br>
-win32/pcl.vcproj<br>
-win32/svg.vcproj<br>
-win32/xps.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-22 21:13: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=5898732ce7f140bc9bbe9818c8525a02236aa8f0">5898732ce7f140bc9bbe9818c8525a02236aa8f0</a>
-<blockquote>
-<p>
- Add a cast to address compiler warning<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/iapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-22 17:44: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=fb11fa25a622124ab1ceba66b0f6ba165162f056">fb11fa25a622124ab1ceba66b0f6ba165162f056</a>
-<blockquote>
-<p>
- Bug 695173: skip conversion to UTF8 for &quot;local&quot; encoding<br>
-<br>
- If we're using &quot;GS_ARG_ENCODING_LOCAL&quot; that means arguments are already in the<br>
- text encoding we want so no conversion is required (and the get_codepoint()<br>
- method is set to NULL).<br>
-<br>
- When that happens, skip the conversion step, and avoid a seg fault.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/iapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-21 13:42:40 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4c1b9214b3e996778f69f33abbf02e9d4da95332">4c1b9214b3e996778f69f33abbf02e9d4da95332</a>
-<blockquote>
-<p>
- Fix 694958 - raster portions of plot were rotated because the<br>
- coordinate system was not properly oriented.<br>
-<br>
- The HPGL/2-RTL's current coordinate system is different depending on<br>
- relative extant of plot width and length, rotating the system if the<br>
- width is greater than or equal to the height. We did not handle the<br>
- equal case properly, we mistakenly used a strict inequality.<br>
-<br>
-pcl/pgdraw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-18 11:08: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=12e2eafa38a9932bb136879374423de133075a4a">12e2eafa38a9932bb136879374423de133075a4a</a>
-<blockquote>
-<p>
- PDF interpreter - reinstate (and complete) the BMC/BDC/EMC pdfmark support<br>
-<br>
- Bug #695151 &quot;Add BMC/EMC and BDC pdfmark support&quot;<br>
-<br>
- This is the patch supplied by Alexander Grahn with a couple of very minor<br>
- additions. Firstly we clean up the Properties resource in pdf_close in case<br>
- by some chance there are still properties dictionaries lying around. Secondly<br>
- we treat the Properties resource specially (like fonts) in<br>
- pdf_store_page_resources().<br>
-<br>
- Because we write the properties dictionaries in line, we must not emit them<br>
- in pdf_store_page_resources (they no longer exist for one thing) as this<br>
- leads to duplicate objects being created. We may need to revisit this in the<br>
- future as I'm not 100% certain this is the best way to proceed. However it<br>
- works properly for all the (very few) test cases I have, or have been able<br>
- to create.<br>
-<br>
- This patch also 'fixes' the opdfread ps2write header. In the past if a BMC<br>
- EMC or BDC was encountered in the PDF file it would try to handle it, but<br>
- the handler doesn't exist, leading to PostScript errors. Rather than try<br>
- to reconstruct the requisite pdfmarks I've chosen simply to ignore these<br>
- constructs. If anyone objects strenuously we can figure out a handler<br>
- in future.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-gs/devices/vector/gdevpdfu.c<br>
-gs/devices/vector/opdfread.h<br>
-gs/lib/opdfread.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-17 09:45: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=b374d709ac920682b4848ea9070681ceb6b44790">b374d709ac920682b4848ea9070681ceb6b44790</a>
-<blockquote>
-<p>
- PDF interpreter - treat 0 length CIDToGIDMap as if it were not present<br>
-<br>
- Bug #695167 &quot;Output page blank&quot;<br>
-<br>
- The PDF contained a type 11 CIDFont with a CIDToGIDMap whose length was 0,<br>
- this caused the type11buildfont code to fail.<br>
-<br>
- Since the CIDTogidMap is optional, treating a 0 length map as 'not present'<br>
- seems a sensible solution.<br>
-<br>
- No differences expected<br>
-<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-16 09:41: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=d2f4c3e592b0f4063ce92c9245dc903ad75495fc">d2f4c3e592b0f4063ce92c9245dc903ad75495fc</a>
-<blockquote>
-<p>
- PDF interpreter - improve transparency detection and apply it to annotations<br>
-<br>
- The existence of CA and ca in annotations without appearance streams were<br>
- not detected. The FreeText annotation synthesis can apply transparency if<br>
- present, so we need to detect it and push the compositor.<br>
-<br>
- Also, add the code to the FreeText annotation appearance synthesis to apply<br>
- transparency.<br>
-<br>
- A few (3) Sumatra PDF files now render very slightly differently, and the<br>
- same files now produce larger PostScript than they did before (because they<br>
- are rendered to images)<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-15 12:51:51 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0ace93f19464cab701f117ba1e6ee489062748e5">0ace93f19464cab701f117ba1e6ee489062748e5</a>
-<blockquote>
-<p>
- PDF interpreter - sunthesise appearances for FreeText annotations<br>
-<br>
- Bug #693731 &quot;Freetext annotations are not printed&quot;<br>
-<br>
- The FreeText annotation in question has no appearance stream and we did<br>
- no previously synthesise one. This commit adds code to do so, it should<br>
- work with UTF16-BE text but I don't have a test file for this.<br>
-<br>
- The existing code to draw annotation borders was insufficient, it did not<br>
- correctly drop elements drawn with a colour of /C[] and would not handle<br>
- colours (/C) defined in anything except RGB space.<br>
-<br>
- The Sumatra test file annotations_galore_II.pdf exhibits a progression<br>
- with this commit (its the only other example of this I could find)<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-15 10:09: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=b0a655cb457f5d719a647ef0663c4770c764cef7">b0a655cb457f5d719a647ef0663c4770c764cef7</a>
-<blockquote>
-<p>
- pdfwrite - disable the BMC/BDC/EMC pdfamrks again<br>
-<br>
- The previous commit b90e081b8ad9b64ae4b66bd27262a9582c129cfc could create<br>
- PDF files which Acrobat couldn't open.<br>
-<br>
- This disables the pdfmark processing until I find out why.<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-15 09:35: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=b90e081b8ad9b64ae4b66bd27262a9582c129cfc">b90e081b8ad9b64ae4b66bd27262a9582c129cfc</a>
-<blockquote>
-<p>
- pdfwrite - implement the BDC, BMC and BDC pdfmarks<br>
-<br>
- Bug #695151 &quot;Add BMC/EMC and BDC pdfmark support&quot;<br>
-<br>
- Adopt the patch from Alexander Grahn, with the small addition of code to<br>
- free the Properties resource at the end of the job.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfm.c<br>
-gs/devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-14 16:47:35 +0200
-</strong>
-<br>Norbert Janssen &lt;norbert.janssen@oce.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=723ae69281aec8c7e9ad5192fe77761f4e476186">723ae69281aec8c7e9ad5192fe77761f4e476186</a>
-<blockquote>
-<p>
- Bug 695049: plexity handling in pcl<br>
-<br>
- Handle plexity in pcl (and its interactions with left/top offset<br>
- registrations, pageside selections).<br>
-<br>
-pcl/pcjob.c<br>
-pcl/pcpage.c<br>
-pxl/pxsessio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-11 22:33:07 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=44a0504d79c28baa6d7a5eda6d5a697424be1c7b">44a0504d79c28baa6d7a5eda6d5a697424be1c7b</a>
-<blockquote>
-<p>
- Fix 695417 cursor tracking broken.<br>
-<br>
- The bug subject is incorrect, the problem was initially diagnosed as a<br>
- problem with GL/2 and PCL cursor interaction, but in fact it was the<br>
- rounding of the translation components of PCL raster to device space<br>
- matrix produced incorrect results at some resolutions.<br>
-<br>
- This problem needs a bit more investigation but empirically not<br>
- rounding translation components seems to give better results. I don't<br>
- know if this is because it more closely emulates HP's calculations or<br>
- if there is another interaction in the ghostscript graphics library<br>
- which makes the integral translation components inappropriate.<br>
-<br>
- The change results in many single pixel translations in the regression<br>
- tests.<br>
-<br>
-pcl/rtgmode.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-11 10:46:11 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fdffeb917e804522ed7117f19ac230c9d23d158f">fdffeb917e804522ed7117f19ac230c9d23d158f</a>
-<blockquote>
-<p>
- Fix bug #695129 black background painted with the pxlcolor device.<br>
-<br>
- PXL has no high level understanding of PostScript or PDF transfer<br>
- functions so we fall back to having the graphics library handle color<br>
- conversion when a transfer function is set.<br>
-<br>
-gs/devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-09 14:32: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=c8673cb8209a9f294721fae7a1842fcd8940ecab">c8673cb8209a9f294721fae7a1842fcd8940ecab</a>
-<blockquote>
-<p>
- PDF interpreter - implement the (not yet documented) revision 6 security handler<br>
-<br>
- Copied from the MUPDF implementation. This does cause a few differences,<br>
- I'm not really sure why as the code can't possibly be causing them. I assume<br>
- its simply memory differences of some kind.<br>
-<br>
-gs/Resource/Init/pdf_sec.ps<br>
-gs/psi/int.mak<br>
-gs/psi/zpdf_r6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-08 14:10:45 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd8b2819ddd9c9aba33a19c8913861767296d576">cd8b2819ddd9c9aba33a19c8913861767296d576</a>
-<blockquote>
-<p>
- Disable the remaining long form color commands, fixing 695110.<br>
-<br>
- All of the color long form commands appear to be no longer supported<br>
- on modern HP devices and our implementation of them frequently results<br>
- in unexpected output and difficult to find bugs. This change gets rid<br>
- of the remaining commands which affected white and black point<br>
- settings. Aside from fixing the test file in the bug this improves<br>
- several panels in the Quality Logic FTS against the Color Laserjet<br>
- 4700, i.e. panels 810 and 814.<br>
-<br>
- The command is simply truncated so the long form command is<br>
- transformed into a corresponding short form allowing for setting of<br>
- the color space, bits per component, etc. The long form code remains<br>
- for now and is easily brought back if we get user feedback that there<br>
- is an HP device we care to support with these extended color commands.<br>
- If that is the case it will have to be handled with conditional<br>
- compilation or a device emulation mode. We'd like to avoid that if<br>
- possible.<br>
-<br>
-pcl/pccid.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-07 19:32:45 +0200
-</strong>
-<br>Norbert Janssen &lt;janssnjj@xs4all.nl&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2d0a6b70f3578a1e4ba61d05d1682a0e2a8f764b">2d0a6b70f3578a1e4ba61d05d1682a0e2a8f764b</a>
-<blockquote>
-<p>
- Bug 695138: PCL pushcursor in definemacro not stored correctly (combined command)<br>
-<br>
- When a macro is defined with a combined command and de define is not<br>
- the closing command (i.e. 0x) then the continuation as stored in the<br>
- macro_prefix (pcparse.c) is not correct. It contains only the &lt;ESC&gt;&amp;,<br>
- but should have been &lt;ESC&gt;&amp;f).<br>
- Thus a following 0S is stored as &lt;ESC&gt;&amp;0S, i.s.o. &lt;ESC&gt;&amp;f0S, and is not<br>
- recognized as a valid push-cursor command.<br>
-<br>
-pcl/pcparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-07 10:47: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=11bb9975a044bf281a498a8f20d3f2436725ad3d">11bb9975a044bf281a498a8f20d3f2436725ad3d</a>
-<blockquote>
-<p>
- Bug 692577: tweak lprsetup.sh for non-default locations<br>
-<br>
- Provide a command line option to lprsetup.sh to specify where the filter files<br>
- should be written. Also, implement a simple heuristic to attempt to identify<br>
- the correct location for the filter files.<br>
-<br>
- Finally, if we rely on the above heuristic, issue a warning and give the user<br>
- the chance to abort the script.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/lib/lprsetup.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-04 15:19:47 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7e1117aa46696ea3d05f54e4bdd13d6641d53d8a">7e1117aa46696ea3d05f54e4bdd13d6641d53d8a</a>
-<blockquote>
-<p>
- PXL font code - correct the order of a matrix multiplication<br>
-<br>
- Bug #693947 &quot;The Intellifont as type 3 font commit causes a regression.&quot;<br>
-<br>
- Matrix multiplication is not commutative, and the order of operands was<br>
- incorrect in this case. Since it only matters for high level devices it<br>
- naturally only showed up with pdfwrite.<br>
-<br>
- This shows a progression (with pdfwrite) in C207.bin and bug691464b.xl<br>
- which actually appears to be the same file.<br>
-<br>
-pxl/pxfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-04 14:42:20 +0200
-</strong>
-<br>Norbert Janssen &lt;norbert.janssen@oce.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2024f434636139c9da20ab3afe0356d5e29c2c55">2024f434636139c9da20ab3afe0356d5e29c2c55</a>
-<blockquote>
-<p>
- Bug 695100: pxl jpeg decoding sometimes misses scans<br>
-<br>
- jpeg decoding (s_DCTD_process) is used by all pdls (pdf/ps/pcl/pxl/xps)<br>
- but in different ways.<br>
- The PDLs provide an output buffer (pw-&gt;ptr) for the decoded scan(s), and<br>
- an input buffer (pr-&gt;ptr) with inputdata. XPS's outputbuffer can contain<br>
- the complete image, the other pdls provide a buffer for 1 scan.<br>
-<br>
- So XPS calls the jpeg-decoder once for the complete image (including the<br>
- EOI marker), the other pdls call repeatedly for 1 scan, until all scans<br>
- have been retrieved.<br>
-<br>
- The jpeg-decoder (s_DCTD_process) calls gs_jpeg_read_scanlines(inputdata)<br>
- to decode 1 scan (using the inputdata). If inputdata is not enough the pdl<br>
- is asked for more, until (atleast) 1 scan is available. This scan<br>
- (samples) is then copied into the outputbuffer (goto dumpbuffer:).<br>
- If the outputbuffer is not filled completely, the jpeg-decoder is asked<br>
- for another scan (i.e. for XPS) which is then also added to the<br>
- outputbuffer.<br>
- Else (if the outputbuffer cannot contain the next scan) it is passed back<br>
- to the graphics-lib (pl_image_data), the outputbuffer is emptied and the<br>
- jpeg-decoder is called for the next scan.<br>
-<br>
- However, with PXL, provided outputbuffer is exactly the size of a scan.<br>
- This means that it is only transferred, when s_DCTD_process wants to copy<br>
- a next scan (which fails because the outputbuffer is full; the<br>
- transferring is delayed), or end-of-data is reached.<br>
- If however, the gs_jpeg_read_scanlines() needs multiple inputbuffers to<br>
- provide this next scan, then this next scan will be copied over the not<br>
- yet transferred scan, thus causing the previous scan to be missed.<br>
-<br>
- The fix in sdctd.c prevents the delaying and copies immediately.<br>
- The mod in pximage.c ensures that the complete imagedata (incl the<br>
- jpeg-EOI) is consumed (otherwise a bufferoverflow is triggered).<br>
-<br>
- Some (PXL) cluster differences (progressions).<br>
-<br>
-gs/base/sdctd.c<br>
-pxl/pximage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-02 22:57: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=89d0847d1f12a7069ccf2d6eff6328fd1f9aee10">89d0847d1f12a7069ccf2d6eff6328fd1f9aee10</a>
-<blockquote>
-<p>
- Bug 695133: fix invalid types in form xobject matrix<br>
-<br>
- The PDF in question has a name object rather a real or integer object as the<br>
- last entry in the matrix.<br>
-<br>
- Before rendering the form, check the entries in the matrix, and if there is<br>
- an invalid type, replace it with a real value. I've opted to use 0.00 as the<br>
- replacement value, and this *seems* to reflect Acrobat's behavior. Creating<br>
- a test case where one of the scale values in the matrix is an invalid type<br>
- results in Acrobat not displaying the form, which hints at a degenerate matrix.<br>
- We have also previously established that Acrobat substitutes zero in other<br>
- similar cases.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-02 13:15:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f3b31c9544c05f87fc0a58b133c5757311c49bbc">f3b31c9544c05f87fc0a58b133c5757311c49bbc</a>
-<blockquote>
-<p>
- PS interpreter - don't limit sampled tint transforms to 64k data<br>
-<br>
- Bug #693237 &quot;PDF restrictions on PS function&quot;<br>
-<br>
- The bug title is misleading, as is the comment in the report. The problem<br>
- has little to do with PDF restrictions. When we get a tint transform for a<br>
- complex space we convert it into a PostScript function rather than maintaining<br>
- the tint transform as PostScript (we do this for performance reasons).<br>
-<br>
- In general we try to use a type 4 (PostScript calculator) function, as these<br>
- are the most flexible variety, but these are not defined for PostScript, only<br>
- for PDF, and it is not always possible to handle a tint transform as a type<br>
- 4 function. In this case we fall back to using a type 0 (sampled) function.<br>
-<br>
- In order to create a sampled function we must (obviously!) sample the original<br>
- function, and create a lookup table to store the samples. This is an M-in<br>
- N-out table, so as the number of inputs and outputs increases the size of<br>
- the table increases dramatically. Because we store the data in a string<br>
- the code checks the size of the lookup table against 64k and if it is too<br>
- large (as in this case) rejects it and tries again, taking fewer samples.<br>
-<br>
- The minimum number of samples is 2 (we must sample each end of the ramp),<br>
- and if we cannot fit that into a 64k string, then we returned a rangecheck<br>
- error.<br>
-<br>
- However we now permit strings greater than 64k, so while we still want to<br>
- keep the lookup table to a sensible size, we should not abort just because<br>
- the table is &gt; 64k.<br>
-<br>
- This commit alters the logic so that we try to fit into a 64k string, but<br>
- if we've reached the minimum number of samples we don't bother checking any<br>
- more and simply use a string big enough to hold the data.<br>
-<br>
- This seems to work, however the example file is reduced to the point where<br>
- nothing is visible on the output, and although the bug report references<br>
- a customer file its not attached to the report, nor is there any other<br>
- information which would allow me to find the original file. So this isn't<br>
- hugely well tested in this unusual condition.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/psi/zfsample.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-04-01 14:39: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=fb1ac66da597d9d6fe773ddaf3413098028cc6a0">fb1ac66da597d9d6fe773ddaf3413098028cc6a0</a>
-<blockquote>
-<p>
- pdfwrite - while processing pdfmarks, ensure strings are null-terminated before using sscanf<br>
-<br>
- Bug #695119 &quot;Ghostscript inconsistently fails creating links with pdfmark&quot;<br>
-<br>
- The problem turns out to be that while handling SrcPage in a pdfmark the<br>
- code executed sscanf on a string which was not guaranteed to be null-terminated<br>
-<br>
- Here we copy the data and explicitly null terminate the copy before running<br>
- sscanf, so that the returned value is reliable.<br>
-<br>
- Also remove an uninitialised variable that could potentially have caused a problem.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-31 20:25: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=5b5962e8610a279aba3841adb80d8e66bca2caa9">5b5962e8610a279aba3841adb80d8e66bca2caa9</a>
-<blockquote>
-<p>
- Bug 695087: modify jbig2 device to output jb2 files<br>
-<br>
- The jbig2 device originally was written to output &quot;bare&quot; streams, as are written<br>
- to PDF files, but is of very limited use.<br>
-<br>
- This commit changes it so the &quot;bare&quot; stream is written to a jb2 container file,<br>
- which can be easily opened, for example, by the jbig2dec command line tool.<br>
-<br>
- Note that the output seems to be inverted, I haven't &quot;fixed&quot; that as I'm not<br>
- sure whether our jbi2 output is wrong, or the jbig2dec conversion to PNG is<br>
- wrong.<br>
-<br>
- This is primarily to ease regression testing of the Luratech jbig2 encoder<br>
- integration.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/sjbig2_luratech.c<br>
-gs/base/sjbig2_luratech.h<br>
-gs/devices/gdevjbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-31 20:21:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0ccf3294ecd3dbaa654279ca605dadccb8bd122a">0ccf3294ecd3dbaa654279ca605dadccb8bd122a</a>
-<blockquote>
-<p>
- Bug 695113: fix fpng device build handle shared zlib<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/devices/devs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-31 10:58:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6cc95ce9fa08d126fc7c701f6eccc1cf49781e0b">6cc95ce9fa08d126fc7c701f6eccc1cf49781e0b</a>
-<blockquote>
-<p>
- ps2write - fix CompressPages=false and SubFileDecode filter<br>
-<br>
- commit c30fb930e7c38dd7bcf47b0305e77cb6ba003bc3 altered the default of the<br>
- CompressPages switch to false, this uncovered an interesting bug. The code<br>
- previously used the string 'endstream' as the EODString argument for a<br>
- SubFileDecode filter. When the stream contents are compressed this is reliable<br>
- but if the stream contents are not compressed they may contain the string<br>
- 'endstream' (eg a document describing PDF syntax) which would cause premature<br>
- end of data detection.<br>
-<br>
- In this commit we instead set the EODString to the empty string () and set<br>
- the EODCount to the length of the stream. This is more reliable, because we<br>
- trust the stream length we create ourselves, but does mean that the stream<br>
- can no longer be edited simply, the length must now be consistent with the<br>
- actual stream contents.<br>
-<br>
- This fixes a bug introdcued with commit c30fb930e7c38dd7bcf47b0305e77cb6ba003bc3<br>
- involving the test file DML_003-2010-1_8.pdf<br>
-<br>
-gs/devices/vector/opdfread.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-29 10:43:27 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=083fa3f6912ad3f44fc94d5e1a362878576b0024">083fa3f6912ad3f44fc94d5e1a362878576b0024</a>
-<blockquote>
-<p>
- ps2write - document incompatibility of ProduceDSC with the page options<br>
-<br>
-gs/doc/Ps2ps2.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-29 10:42:57 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c30fb930e7c38dd7bcf47b0305e77cb6ba003bc3">c30fb930e7c38dd7bcf47b0305e77cb6ba003bc3</a>
-<blockquote>
-<p>
- ps2write - alter the default of CompressPages to false for ps2write<br>
-<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-29 10:42:29 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c126936d5bd81af58743d8770d9d21ac22e64211">c126936d5bd81af58743d8770d9d21ac22e64211</a>
-<blockquote>
-<p>
- ps2write - set EPS2Write to false when ProduceDSC is false<br>
-<br>
- Due to the way that DSC and non-DSC headers are emitted the variable EPS2Write<br>
- wasn't set, which resulted in a PostScript error.<br>
-<br>
-gs/devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-28 13:18:34 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=27f586bb4a5f5a3ffe6508874527eae684039380">27f586bb4a5f5a3ffe6508874527eae684039380</a>
-<blockquote>
-<p>
- pdfwrite - clamp CropBox to MediaBox for PDF/X output<br>
-<br>
- Bug #695120 &quot;Page boxes not nested properly when creating PDF/X using files with bleed&quot;<br>
-<br>
- The description of the bug is not accurate, the bleed is irrelevant.<br>
-<br>
- The problem is caused because the specimen file has ridiculously accurate<br>
- MediaBox etc, specified to 3 decimal places. Due to rounding differences the<br>
- CropBox can be a tiny amount (thousandths of a millimeter) large than the<br>
- MediaBox.<br>
-<br>
- I cannot find anywhere in the PDF/X-3 spec which says that the CropBox has<br>
- to be smaller than the MediaBox, but the Acrobat pre-flight tool complains<br>
- if it is.<br>
-<br>
- This commit simply clamps the CropBox to the MediaBox that actually gets written<br>
- to the PDF file (for PDF/X only) and prevents the problem.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-27 13:13:53 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4840334cee8f79d3dedb8b95899dc43e7a55779a">4840334cee8f79d3dedb8b95899dc43e7a55779a</a>
-<blockquote>
-<p>
- pdfwrite - don't emit ICC spaces with no Alternate and no potential default alternate<br>
-<br>
- Bug #691500 &quot;Bad pdf file generated with pdfwrite&quot;<br>
-<br>
- The XPS file cotnains a 6 colour ICC profile, the XPS interpreter passes this<br>
- along as an ICCBased space, but does not construct an /Alternate space for<br>
- it. pdfwrite would then emit a PDF file with a 6 colour profile and no<br>
- /Alternate, which is illegal as there is no possible way to convert the<br>
- input into a device space without handling the ICC profile.<br>
-<br>
- If we encounter this (which I think is only possible from XPS), we now give<br>
- up on the ICC profile and instead convert to the ProcessColorModel colour<br>
- space instead.<br>
-<br>
- Ghostscript can read the resulting file without error, Acrobat gives a<br>
- 'drawing error' and evince complains about input profiles, but in general<br>
- I'm going to label this as a fix.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdfk.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-27 08:23:37 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=094451a13d990ba0f64c285ba157b6f45deb09e6">094451a13d990ba0f64c285ba157b6f45deb09e6</a>
-<blockquote>
-<p>
- txtwrite - fix a buffer overrun<br>
-<br>
- Bug #695109 &quot;gswin32c produces an access violation when using txtwrite&quot;<br>
-<br>
- A cut and paste error led to us trying to copy a char string as a sequence<br>
- of shorts, resulting in overrunning the source buffer. Depending on the<br>
- precise memory layout this could cause access to unallocated memory and<br>
- an application crash.<br>
-<br>
- Thanks to José Antonio for persisting with this bug and doing all the<br>
- debugging work.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-26 09:09:12 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0b40e26308b5a728b1b1cbab7104c7da6b57618f">0b40e26308b5a728b1b1cbab7104c7da6b57618f</a>
-<blockquote>
-<p>
- Update docs for release.<br>
-<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-26 12:52:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=221a37e79b9d0e93d73b257bf16fe9c96c7505a0">221a37e79b9d0e93d73b257bf16fe9c96c7505a0</a>
-<blockquote>
-<p>
- Bump version number.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-26 07:34:18 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ee4458671553d95302439bacbbb66333d019b83a">ee4458671553d95302439bacbbb66333d019b83a</a>
-<blockquote>
-<p>
- Add eps2write to Linux gs and all ghostpdl bulids<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Makefile.in<br>
-gs/configure.ac<br>
-main/pcl6_gcc.mak<br>
-main/pcl6_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-26 08:46: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=c481ce6ab184e6cd109b856d6ba6d2bd440be85b">c481ce6ab184e6cd109b856d6ba6d2bd440be85b</a>
-<blockquote>
-<p>
- ps2write - better documentation for HaveTrueTypes<br>
-<br>
- The documentation for HaveTrueTypes stated that TrueType fonts would be<br>
- emitted as bitmap fonts if -dHaveTrueTypes is false. This information was<br>
- only partially correct, if the size of the bitmap (as determined by the<br>
- text size and resolution) exceeds the maximum for the cache then we don't<br>
- put the bitmap in a font at all, we emit it as an inline image.<br>
-<br>
-gs/doc/Ps2pdf.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-14 10:00:05 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=de72ef09fd37d51755faefdb4d719c78ac85d60c">de72ef09fd37d51755faefdb4d719c78ac85d60c</a>
-<blockquote>
-<p>
- doc changes from 9.12 release<br>
-<br>
- Update version number, release and copyright dates.<br>
-<br>
- Update release notes, changelog and couple of tweaks<br>
-<br>
- Update product string and date for release.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/Makefile.in<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-gs/psi/msvc.mak<br>
-gs/psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-31 15:19: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=cdde0e961884a0dbe7e576af5f2f73df9527af6b">cdde0e961884a0dbe7e576af5f2f73df9527af6b</a>
-<blockquote>
-<p>
- Import LCMS 2.6 Release version<br>
-<br>
- Update gs calling code to cope, including simple mutex<br>
- handlers. Also incorporates our optimisations etc.<br>
-<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/lib.mak<br>
-gs/lcms2/AUTHORS<br>
-gs/lcms2/ChangeLog<br>
-gs/lcms2/Makefile.am<br>
-gs/lcms2/Makefile.in<br>
-gs/lcms2/Projects/VC2010/testbed/testbed.vcxproj<br>
-gs/lcms2/Projects/VC2010/testbed/testbed.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/jpegicc/jpegicc.vcproj<br>
-gs/lcms2/Projects/VC2012/jpegicc/jpegicc.vcxproj<br>
-gs/lcms2/Projects/VC2012/jpegicc/jpegicc.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/lcms2.rc<br>
-gs/lcms2/Projects/VC2012/lcms2.sln<br>
-gs/lcms2/Projects/VC2012/lcms2_DLL/lcms2_DLL.vcproj<br>
-gs/lcms2/Projects/VC2012/lcms2_DLL/lcms2_DLL.vcxproj<br>
-gs/lcms2/Projects/VC2012/lcms2_DLL/lcms2_DLL.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/lcms2_static/lcms2_static.vcproj<br>
-gs/lcms2/Projects/VC2012/lcms2_static/lcms2_static.vcxproj<br>
-gs/lcms2/Projects/VC2012/lcms2_static/lcms2_static.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/linkicc/linkicc.vcproj<br>
-gs/lcms2/Projects/VC2012/linkicc/linkicc.vcxproj<br>
-gs/lcms2/Projects/VC2012/linkicc/linkicc.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/psicc/psicc.vcproj<br>
-gs/lcms2/Projects/VC2012/psicc/psicc.vcxproj<br>
-gs/lcms2/Projects/VC2012/psicc/psicc.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/resource.h<br>
-gs/lcms2/Projects/VC2012/testbed/testbed.vcproj<br>
-gs/lcms2/Projects/VC2012/testbed/testbed.vcxproj<br>
-gs/lcms2/Projects/VC2012/testbed/testbed.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/tiffdiff/tiffdiff.vcproj<br>
-gs/lcms2/Projects/VC2012/tiffdiff/tiffdiff.vcxproj<br>
-gs/lcms2/Projects/VC2012/tiffdiff/tiffdiff.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/tifficc/tifficc.vcproj<br>
-gs/lcms2/Projects/VC2012/tifficc/tifficc.vcxproj<br>
-gs/lcms2/Projects/VC2012/tifficc/tifficc.vcxproj.filters<br>
-gs/lcms2/Projects/VC2012/transicc/transicc.vcproj<br>
-gs/lcms2/Projects/VC2012/transicc/transicc.vcxproj<br>
-gs/lcms2/Projects/VC2012/transicc/transicc.vcxproj.filters<br>
-gs/lcms2/Projects/cppcheck/lcms2.cppcheck<br>
-gs/lcms2/Projects/mac/.DS_Store<br>
-gs/lcms2/Projects/mac/._.DS_Store<br>
-gs/lcms2/Projects/mac/LittleCMS/.DS_Store<br>
-gs/lcms2/Projects/mac/LittleCMS/._.DS_Store<br>
-gs/lcms2/Projects/mac/LittleCMS/Info.plist<br>
-gs/lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/mariama.mode1v3<br>
-gs/lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/mariama.pbxuser<br>
-gs/lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.pbxproj<br>
-gs/lcms2/aclocal.m4<br>
-gs/lcms2/autogen.sh<br>
-gs/lcms2/configure<br>
-gs/lcms2/configure.ac<br>
-gs/lcms2/doc/LittleCMS2.5 API.pdf<br>
-gs/lcms2/doc/LittleCMS2.5 Plugin API.pdf<br>
-gs/lcms2/doc/LittleCMS2.5 tutorial.pdf<br>
-gs/lcms2/doc/LittleCMS2.6 API.pdf<br>
-gs/lcms2/doc/LittleCMS2.6 Plugin API.pdf<br>
-gs/lcms2/doc/LittleCMS2.6 tutorial.pdf<br>
-gs/lcms2/include/Makefile.in<br>
-gs/lcms2/include/lcms2.h<br>
-gs/lcms2/include/lcms2_plugin.h<br>
-gs/lcms2/m4/acx_pthread.m4<br>
-gs/lcms2/src/Makefile.in<br>
-gs/lcms2/src/cmscam02.c<br>
-gs/lcms2/src/cmscgats.c<br>
-gs/lcms2/src/cmscnvrt.c<br>
-gs/lcms2/src/cmserr.c<br>
-gs/lcms2/src/cmsgamma.c<br>
-gs/lcms2/src/cmsgmt.c<br>
-gs/lcms2/src/cmsintrp.c<br>
-gs/lcms2/src/cmsio0.c<br>
-gs/lcms2/src/cmsio1.c<br>
-gs/lcms2/src/cmsopt.c<br>
-gs/lcms2/src/cmspack.c<br>
-gs/lcms2/src/cmsplugin.c<br>
-gs/lcms2/src/cmsps2.c<br>
-gs/lcms2/src/cmstypes.c<br>
-gs/lcms2/src/cmsvirt.c<br>
-gs/lcms2/src/cmswtpnt.c<br>
-gs/lcms2/src/cmsxform.c<br>
-gs/lcms2/src/extra_xform.h<br>
-gs/lcms2/src/lcms2.def<br>
-gs/lcms2/src/lcms2_internal.h<br>
-gs/lcms2/testbed/Makefile.am<br>
-gs/lcms2/testbed/Makefile.in<br>
-gs/lcms2/testbed/ibm-t61.icc<br>
-gs/lcms2/testbed/new.icc<br>
-gs/lcms2/testbed/testcms2.c<br>
-gs/lcms2/testbed/testcms2.h<br>
-gs/lcms2/testbed/testplugin.c<br>
-gs/lcms2/testbed/testthread.cpp<br>
-gs/lcms2/testbed/zoo_icc.c<br>
-gs/lcms2/utils/delphi/lcms2dll.pas<br>
-gs/lcms2/utils/jpgicc/Makefile.in<br>
-gs/lcms2/utils/jpgicc/jpgicc.c<br>
-gs/lcms2/utils/linkicc/Makefile.in<br>
-gs/lcms2/utils/psicc/Makefile.in<br>
-gs/lcms2/utils/psicc/psicc.c<br>
-gs/lcms2/utils/tificc/Makefile.in<br>
-gs/lcms2/utils/tificc/tificc.c<br>
-gs/lcms2/utils/transicc/Makefile.in<br>
-gs/lcms2/utils/transicc/transicc.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-24 10:00:23 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c74e146b74fe6db9f3a91ff71b7478dac79b5c1a">c74e146b74fe6db9f3a91ff71b7478dac79b5c1a</a>
-<blockquote>
-<p>
- Repair performance degradation with PostScript functions<br>
-<br>
- Bug #693561 &quot;gs_c_param_list_release() corrupts memory&quot;<br>
-<br>
- The commit 289aa28f46e2be1c87c34d44ee86dec41e87506b removed the explicit<br>
- test of the device name with a test against a specifically named device<br>
- parameter. However, as noted in the bug, this led to a performance penalty<br>
- as the parameter was re-evaluated inside a loop.<br>
-<br>
- This commit moves the parameter evaluation outside check_psc_function()<br>
- altogether as this routine can be called recursively. Instead the parameter<br>
- is retrieved in the calling routines and passed as a new argument.<br>
-<br>
- No differences expected<br>
-<br>
-gs/psi/zfunc4.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-24 09:56:32 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23666d2037f14a1ef880e60bce9008203e502436">23666d2037f14a1ef880e60bce9008203e502436</a>
-<blockquote>
-<p>
- Make C 'param' collections free memory as per 'ref' params<br>
-<br>
- Bug #693561<br>
-<br>
- The 'memory corruption' referred to in the bug report is actually a memory<br>
- leak, and is only exposed by using the -Z? (check pointers) debugging switch.<br>
- As such its not as disastrous as the bug report makes it sound (I'm unable<br>
- to reproduce the SEGV).<br>
-<br>
- Its caused because when we retrieve a parameter list from the device, we do<br>
- so using the 'C' param list structures rather than the PostScript 'ref'<br>
- params. One of the things that pdfwrite returns is image dictionaries, and<br>
- these require us to create a temporary param list. With the 'ref' param<br>
- structures, when we call param_end_write_dict (redirected through a macro<br>
- to param_end_write_collection, further redirected through a macro to<br>
- plist-&gt;procs-&gt;end_xmit_collection) the memory used by the list is explicitly<br>
- freed, when we use the 'C' param, it is *NOT* freed.<br>
-<br>
- All the places in the code that I can find where we call param_end_write_dict<br>
- seem to assume that this will also free the memory. This commit modifies<br>
- the C param list code so that it also frees the memory. At least now the<br>
- two param types behave the same.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gscparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-22 04:07:14 +0000
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8ae4ee220766aa180150eafeffe4f094f1354f92">8ae4ee220766aa180150eafeffe4f094f1354f92</a>
-<blockquote>
-<p>
- Fixes PXL segfault with trying to set up icc transform for bitmasks, Bug 695103<br>
-<br>
- Masks also get treated as images (the conditionals about being masks,<br>
- bit-depths, interpolation, etc is getting really long...), and the<br>
- iccTranform change mistakenly try to set up link transform for such.<br>
- There should be an additional conditional (where this change is) for<br>
- the data not being masks. This is equivalent to not<br>
- setting up icc tranform for missing color space info (Part 1), but clearer.<br>
- The other two check images having valid color space info, and should stay.<br>
-<br>
- Cluster tested. No difference expected.<br>
-<br>
- Signed-off-by: Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<br>
-gs/devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-21 21:44:30 +0000
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=553cea8ecaeba7a48837325da098583eaef5f1ca">553cea8ecaeba7a48837325da098583eaef5f1ca</a>
-<blockquote>
-<p>
- Further protection against PXL segfault with image data without colorspace info, Bug 695103<br>
-<br>
- Someghow since gs 9.10, it becomes possible for image data to arrive<br>
- without colorspace info, and accessing such causes segfault; we should<br>
- protect against it in any case, but further investigation (possibly<br>
- by somebody else) is needed on how that happened. Part 2 of the fix.<br>
-<br>
- Cluster tested. No difference expected.<br>
-<br>
- Signed-off-by: Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<br>
-gs/devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-21 21:42:30 +0000
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b780ff05fd1959202b27f9c0da383968a7e398e9">b780ff05fd1959202b27f9c0da383968a7e398e9</a>
-<blockquote>
-<p>
- Protection against PXL segfault with image data without colorspace info, Bug 695103<br>
-<br>
- Someghow since gs 9.10, it becomes possible for image data to arrive<br>
- without colorspace info, and accessing such causes segfault; we should<br>
- protect against it in any case, but further investigation (possibly<br>
- by somebody else) is needed on how that happened. Part 1 of the fix.<br>
-<br>
- Cluster tested. No difference expected.<br>
-<br>
- Signed-off-by: Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<br>
-gs/devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-20 11:40:18 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b504d2f72c6903a4dbf66176ec3358e4cd5d151d">b504d2f72c6903a4dbf66176ec3358e4cd5d151d</a>
-<blockquote>
-<p>
- pdfwrite - fix multi-plane images with &lt; 8bpc<br>
-<br>
- The code to pack multiple bit planes into bytes didn't properly account<br>
- for the number of bytes to be written to the output. We always wrote a<br>
- full block of bytes as long as the number of bytes remaining was not<br>
- greater than our block size. That is, it did not account for the fact that<br>
- we might not need to write a complete block of bytes, in the case where the<br>
- number of bytes left was exactly equal to the size of our internal block.<br>
-<br>
- Fixed that by changing the '&gt;=' to '&gt;' so that if the size was equal we would<br>
- properly check to see how many bytes we actually need to write. This then<br>
- uncovered another problem, if the width of the image in bits was a multiple<br>
- of the block size, then we wouldn't write any data. Fixed that too.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-14 23:18:53 +0000
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bccf1cdd8d8936a8ff89ea09c1887a4816ca5685">bccf1cdd8d8936a8ff89ea09c1887a4816ca5685</a>
-<blockquote>
-<p>
- Miscellaneous corrections to typos and comments, accumulated over a while.<br>
-<br>
- Not cluster tested.<br>
-<br>
- Signed-off-by: Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<br>
-gs/base/gxblend.h<br>
-pcl/pcindxed.c<br>
-pcl/rtgmode.c<br>
-pcl/rtraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-10 00:37:09 +0000
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1f1b3eccb689bb9c1fa80f20f222c44ed563e99">d1f1b3eccb689bb9c1fa80f20f222c44ed563e99</a>
-<blockquote>
-<p>
- Fixes unicode-processing related slowdown from the python 2 to 3 migration.<br>
-<br>
- Replaces the last &quot;+&quot; usage by join() in the hex dump part.<br>
-<br>
- Concatenation via &quot;+&quot; in python has always known to be slow.<br>
- It becomes of acceptable speed towards the end of the python<br>
- 2 cycle, and becomes very slow again when 3-migration<br>
- compatibility for python 2 is switched on. This is a<br>
- Python string processing idiosyncrasy - the optimal<br>
- ways of concatenating strings in python is via join(), instead<br>
- of the more common &quot;+&quot;.<br>
-<br>
- 3MB test file (attachment 9725 to bug 694086) - any<br>
- non-small PXL file should do. &quot;+&quot; is almost 20x slower<br>
- than join():<br>
-<br>
- $ time python2 before/pxldis.py test.pxl &gt; /dev/null<br>
-<br>
- real 4m39.810s<br>
- user 4m9.798s<br>
- sys 0m2.548s<br>
-<br>
- $ time python3 before/pxldis.py test.pxl &gt; /dev/null<br>
-<br>
- real 0m13.150s<br>
- user 0m12.374s<br>
- sys 0m0.081s<br>
-<br>
- $ time python2 after/pxldis.py test.pxl &gt; /dev/null<br>
-<br>
- real 0m18.653s<br>
- user 0m17.871s<br>
- sys 0m0.129s<br>
-<br>
- $ time python3 after/pxldis.py test.pxl &gt; /dev/null<br>
-<br>
- real 0m13.295s<br>
- user 0m12.969s<br>
- sys 0m0.053s<br>
-<br>
- Not cluster tested. cluster testing is not relevant to this script.<br>
-<br>
- Signed-off-by: Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<br>
-tools/pxldis.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-12 15:16:05 +0000
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=41ab485d48890ecadc3d5f74657b644f9d1a8d7f">41ab485d48890ecadc3d5f74657b644f9d1a8d7f</a>
-<blockquote>
-<p>
- pxlmono/pxlcolor: Transform deep (24-bit) images with an ICC transform to emit high-level images. Bug 690867.<br>
-<br>
- Deep images with an associated rendering intent<br>
- or custom colour spaces, or icc profiles, could be emitted<br>
- more efficiently as high-level PXL images if the individual<br>
- pixels values are transformed through the icclink transform.<br>
-<br>
- The new code path is off by default, and switched on via an option<br>
- (-diccTransform). When the new code is thoroughly tested, this<br>
- option will be removed and the new code path will become the default.<br>
-<br>
- Cluster tesed - new code is optional and off by default,<br>
- no difference is expected.<br>
-<br>
- Signed-off-by: Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<br>
-gs/devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-12 15:03:58 +0000
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b44b41c9b6c4a7e5ebf03b6970f9be39548443b">4b44b41c9b6c4a7e5ebf03b6970f9be39548443b</a>
-<blockquote>
-<p>
- Implements PCL XL Compression Mode 2 (JPEG), and updated documentation and other support files. Bug 694282.<br>
-<br>
- This patch implements PCL XL Compression Mode 2 (JPEG) -<br>
- Bug 694282. Compression Mode 2 would be appropriate when the<br>
- original image data is already lossy (Bug 691880 - JPX,<br>
- Bug 690867 - JPEG).<br>
-<br>
- Unlike compression mode 1 (RLE) and 3 (DeltaRow), JPEG<br>
- is not appropriate for arbitrary indexed-coloured images<br>
- or masks, so this new functionality will silently fall<br>
- back to RLE for masks and other unsuitable data.<br>
- Currently it is limited to apply to only 24-bit input to<br>
- be on the conservative side. Further furture improvement<br>
- may be possible for gray 8-bit images to emit gray jpeg<br>
- if those can be identified accurately.<br>
-<br>
- Cluster tested. The new functionality is optonal and controlled by<br>
- -dCompressMode=2 (default 1) so no difference is expected.<br>
-<br>
- Signed-off-by: Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<br>
-gs/devices/devs.mak<br>
-gs/devices/vector/gdevpx.c<br>
-gs/doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-18 11:41:44 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39da69e074c36e5a56ac52041444e4af1aa9a7c8">39da69e074c36e5a56ac52041444e4af1aa9a7c8</a>
-<blockquote>
-<p>
- Fix Segfaults caused by 'vertical stripe' fix (f18fac0).<br>
-<br>
- The done flag is no longer needed and caused us to exit the while<br>
- loop before processing enough of the data.<br>
-<br>
- Also, move_landscape_buffer could end up with position_curr ==<br>
- position_new so we were moving 'in place' (wasting time). Fix that.<br>
-<br>
-gs/base/gxht_thresh.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-18 11:39:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7c8b652e6e9019c8e9c9731f8e7a59c3505db638">7c8b652e6e9019c8e9c9731f8e7a59c3505db638</a>
-<blockquote>
-<p>
- pdfwrite - null a pointer to avoid an enumeration problem<br>
-<br>
- pdev-&gt;vgstack wasn't being set to NULL when freed, which could lead to<br>
- garbage collection problems.<br>
-<br>
- At the same time, remove two macros which I really don't like (and made this<br>
- problem difficult to locate) and set a couple more pointers to NULL when<br>
- the contents are freed.<br>
-<br>
- Bug #694380, but unfortunately this simply causes a seg fault in a different<br>
- location.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfx.h<br>
-gs/devices/vector/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-18 10:44: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=f20811cce805fcc748e58112ec4fdaa87b934960">f20811cce805fcc748e58112ec4fdaa87b934960</a>
-<blockquote>
-<p>
- Bug 694612: add some bounds checking to fax decode<br>
-<br>
- to prevent writing off the end of the buffer with corrupted data.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/scfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-17 13:07:37 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2ab7e7b2d8a7cf92b3cb5c4e6d4455e4badc98de">2ab7e7b2d8a7cf92b3cb5c4e6d4455e4badc98de</a>
-<blockquote>
-<p>
- Fix to turn of BPC when we are using the Gray_to_K ICC profile.<br>
-<br>
- This appears to be a bug in lcms. Will follow up with Marti. Also fix for tiff64nc. In the test<br>
- tiff_compression_allowed we were missing the test for the 16 bit case. Surprisingly this commit<br>
- results in progressions in the 8 bit device outputs too when we have a gray source and going<br>
- to a CMYK device.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-gs/devices/gdevtifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-17 13:06:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5412d27994c9abec041e798592b2c842d8910a5c">5412d27994c9abec041e798592b2c842d8910a5c</a>
-<blockquote>
-<p>
- pdfwrite - handle CIDFonts with mixed type 3/type 1 descendants<br>
-<br>
- Bug #691096 &quot;the file generated by ps2pdf from this PS file does not display some chars&quot;<br>
-<br>
- The input has a CIDFont declared which uses both a type 1 and a type 3 font<br>
- as descendants. The pdfwrite device family can't handle this, resulting in<br>
- /.notdef glyphs.<br>
-<br>
- In this commit; when we detect a switch to a type 3 descendant, and the previous<br>
- font was not a type 3, we set 'type3charpath' to true. This forces the<br>
- text handling to fall back to a bitmap font mode for this text.<br>
-<br>
- This is less than ideal, but its a very rare occurence and does result in<br>
- all the text being rendered.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdtc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-15 12:47:22 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f18e30f56b7fcc339b617e82e948ed96d561cde">4f18e30f56b7fcc339b617e82e948ed96d561cde</a>
-<blockquote>
-<p>
- Git rid of some simple 'unused' compiler warnings.<br>
-<br>
-gs/base/gsfcmap1.c<br>
-gs/base/gsicc.c<br>
-gs/base/gsicc_create.c<br>
-gs/base/gxdcolor.c<br>
-gs/base/gxht_thresh.c<br>
-gs/base/gxp1fill.c<br>
-gs/base/gxshade.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-14 14:39: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=1e79e7e3f12404a85d52dfa28b254998b39b0782">1e79e7e3f12404a85d52dfa28b254998b39b0782</a>
-<blockquote>
-<p>
- Fix broken detection for fast image threshold, planar and GrayValues &gt; 2.<br>
-<br>
- The detection enabled ALL planar devices, so bits per component 2 and<br>
- above would use the 1 bit methods.<br>
-<br>
-gs/base/gxicolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-14 09:44:08 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb78de3c11b86088126d3f5d2a7a4c817caf4935">bb78de3c11b86088126d3f5d2a7a4c817caf4935</a>
-<blockquote>
-<p>
- Bump version numbers.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-13 20:35:53 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f18fac03991c6164dfad81f03b3e7a8a4eadf243">f18fac03991c6164dfad81f03b3e7a8a4eadf243</a>
-<blockquote>
-<p>
- Fix sporadic vertical stripes with planar fast image thresholding (pkmraw)<br>
-<br>
- In the landscape code, only the data for the last plane was being moved<br>
- to the start of the contone data for the next 32 lines of output. Seen<br>
- with -sDEVICE=pkmraw -dUsePlanarBuffer J8_landscape.ps but any landscape<br>
- image could have the problem. New code moves all planes and only resets<br>
- the ht_landscape parameters after all planes have been processed and<br>
- output (via copy_planes).<br>
-<br>
-gs/base/gxht_thresh.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-26 09:09:12 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a76558de66281375e2a738a2380ca62c0fd223d4">a76558de66281375e2a738a2380ca62c0fd223d4</a>
-<blockquote>
-<p>
- Update docs for release.<br>
-<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-26 09:06:56 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3ab7b7c314bf478ad76dae0f90f2dd6370fa11a6">3ab7b7c314bf478ad76dae0f90f2dd6370fa11a6</a>
-<blockquote>
-<p>
- Up version number<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-26 07:34:18 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e3e14fce68beb871c48e427af6904f7441bf803">0e3e14fce68beb871c48e427af6904f7441bf803</a>
-<blockquote>
-<p>
- Add eps2write to Linux gs and all ghostpdl bulids<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Makefile.in<br>
-gs/configure.ac<br>
-main/pcl6_gcc.mak<br>
-main/pcl6_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-25 08:39:14 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3059462485a66539f8a036b1bc60584f74901ac2">3059462485a66539f8a036b1bc60584f74901ac2</a>
-<blockquote>
-<p>
- Update product string and date for release.<br>
-<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-14 11:56: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=aac778af6233ee10e66c1ca3f902adf8b6566b60">aac778af6233ee10e66c1ca3f902adf8b6566b60</a>
-<blockquote>
-<p>
- Update release notes, changelog and couple of tweaks<br>
-<br>
-gs/doc/History9.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-18 11:41:44 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20f8aebb83a88ca225b67c3bbf5e6dae936349b0">20f8aebb83a88ca225b67c3bbf5e6dae936349b0</a>
-<blockquote>
-<p>
- Fix Segfaults caused by 'vertical stripe' fix (f18fac0).<br>
-<br>
- The done flag is no longer needed and caused us to exit the while<br>
- loop before processing enough of the data.<br>
-<br>
- Also, move_landscape_buffer could end up with position_curr ==<br>
- position_new so we were moving 'in place' (wasting time). Fix that.<br>
-<br>
-gs/base/gxht_thresh.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-17 13:07:37 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7458c4b5eed25b49ba15dcb37b6dd2ec1d6f0089">7458c4b5eed25b49ba15dcb37b6dd2ec1d6f0089</a>
-<blockquote>
-<p>
- Fix to turn of BPC when we are using the Gray_to_K ICC profile.<br>
-<br>
- This appears to be a bug in lcms. Will follow up with Marti. Also fix for tiff64nc. In the test<br>
- tiff_compression_allowed we were missing the test for the 16 bit case. Surprisingly this commit<br>
- results in progressions in the 8 bit device outputs too when we have a gray source and going<br>
- to a CMYK device.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-gs/devices/gdevtifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-13 20:35:53 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c23cde8b44a751a787636a7747b42b2da7911922">c23cde8b44a751a787636a7747b42b2da7911922</a>
-<blockquote>
-<p>
- Fix sporadic vertical stripes with planar fast image thresholding (pkmraw)<br>
-<br>
- In the landscape code, only the data for the last plane was being moved<br>
- to the start of the contone data for the next 32 lines of output. Seen<br>
- with -sDEVICE=pkmraw -dUsePlanarBuffer J8_landscape.ps but any landscape<br>
- image could have the problem. New code moves all planes and only resets<br>
- the ht_landscape parameters after all planes have been processed and<br>
- output (via copy_planes).<br>
-<br>
-gs/base/gxht_thresh.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-14 10:00:05 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b65f4e9d7cdd32981680a5486e1c1c320ac4046e">b65f4e9d7cdd32981680a5486e1c1c320ac4046e</a>
-<blockquote>
-<p>
- Update version number, release and copyright dates.<br>
-<br>
-gs/Makefile.in<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-gs/psi/msvc.mak<br>
-gs/psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-
-<h2><a name="Version9.14"></a>Version 9.14 (2014-03-26)</h2>
-
-<p>This is the tenth full release in the stable 9.x series, and is
-primarily a maintenance release.
-
-<p> Highlights in this release include:
-<ul>
-<li>
-<p>pdfwrite now uses the same color management engine as Ghostscript rendering
-devices (by default LCMS2). This provides much better control over color
-conversion and color management generally, but will result in some small color
-differences when compared to the old system.
-
-<p>It is no longer necessary to specify UseCIEColor (and we very much encourage
-you not to do this) or the ProcessColorModel if you want to convert a PDF file
-to a specific color space, simply set the ColorConversionStrategy appropriately.
-
-<p>We do not expect any major problems to arise with this new code, but for the
-duration of this release a new switch -dPDFUseOldCMS is available which will
-restore the old color management.
-See: <a href="Ps2pdf.htm#Color_Conversion_and_Management">Color Conversion and Management</a>
-
-<p>Please note that due to constraints of the PDF/A-1 specification, the new
-color management does not yet apply when producing PDF/A files.
-</li>
-<li>
-<p> A new device 'eps2write' has been added which allows for the creation of
-EPS files using the ps2write device instead of the old (deprecated and removed)
-pswrite device. This produces considerably better quality EPS files than
-the old epswrite device which is now also deprecated and will be removed in a
-future release.
-</li>
-<li>
-<p> ps2write now has a feature to allow customisation of the output for specific
-devices. Please see PSDocOptions and PSPageOptions described in ps2ps2.htm
-<a href="Ps2ps2.htm#AdditionalDistillerParams">Additional Distiller Params</a>
-</li>
-<li>
-<p> Ghostscript now reduces memory usage when processing PDF files that use
-transparency and output is to display devices such as Windows display or x11
-(i.e. devices that are strictly full framebuffer devices), and to high level
-vector devices that cannot reproduce the PDF transparency model, such as the
-ps2write device or pdfwrite when 'flattening' to PDF 1.3 or earlier
-(-dCompatibilityLevel=1.3). This uses banding (clist) files to render the
-transparent areas in bands to reduce memory use, and unlike the existing
-page level banding, this is hidden from the target device.
-</li>
-<li>
-<p> Ghostscript can now collect information for pages in temp files (in
-Ghostscript's clist format), then render and output pages for the job in arbitrary
-order, including normal, reverse, odd, even, or any order or subset of the pages.
-This is controlled with the --saved-page=___ option. (Note that this only applies
-to rendering devices, and not high level devices such as pdfwrite and ps2write.)
-See: <a href="Use.htm#Deferred_Page_Rendering">Deferred Page Rendering</a>
-</li>
-<li>
-<p> The Ghostscript device architecture has been extended so that, when
-rendering bands into multiple threads, it is now possible to perform
-post-processing in multiple threads, such as downscale, post-render halftoning,
-or compression. Previously, post processing was only possible in the single
-main thread. This can improve performance significantly.
-</li>
-<li>
-<p> Ghostscript has a new "pwgraster" output device for PWG Raster output
-</li>
-<li>
-<p> The CUPS device now has improved support for PPD-less printing
-</li>
-<li>
-<p>Plus the usual round of bug fixes, compatibility changes, and incremental improvements.
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.09_Incompatible_changes"></a>Incompatible changes</h3>
-<p>
-No recorded incompatible changes.
-
-<h3><a name="9.09_changelog"></a>Changelog</h3>
-<p><strong>2014-03-14 10:00:05 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b65f4e9d7cdd32981680a5486e1c1c320ac4046e">b65f4e9d7cdd32981680a5486e1c1c320ac4046e</a>
-<blockquote>
-<p>
- Update version number, release and copyright dates.<br>
-<br>
-gs/Makefile.in<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-gs/psi/msvc.mak<br>
-gs/psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-18 11:41:44 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20f8aebb83a88ca225b67c3bbf5e6dae936349b0">20f8aebb83a88ca225b67c3bbf5e6dae936349b0</a>
-<blockquote>
-<p>
- Fix Segfaults caused by 'vertical stripe' fix (f18fac0).<br>
-<br>
- The done flag is no longer needed and caused us to exit the while<br>
- loop before processing enough of the data.<br>
-<br>
- Also, move_landscape_buffer could end up with position_curr ==<br>
- position_new so we were moving 'in place' (wasting time). Fix that.<br>
-<br>
-gs/base/gxht_thresh.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-17 13:07:37 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7458c4b5eed25b49ba15dcb37b6dd2ec1d6f0089">7458c4b5eed25b49ba15dcb37b6dd2ec1d6f0089</a>
-<blockquote>
-<p>
- Fix to turn of BPC when we are using the Gray_to_K ICC profile.<br>
-<br>
- This appears to be a bug in lcms. Will follow up with Marti. Also fix for tiff64nc. In the test<br>
- tiff_compression_allowed we were missing the test for the 16 bit case. Surprisingly this commit<br>
- results in progressions in the 8 bit device outputs too when we have a gray source and going<br>
- to a CMYK device.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-gs/devices/gdevtifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-13 20:35:53 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c23cde8b44a751a787636a7747b42b2da7911922">c23cde8b44a751a787636a7747b42b2da7911922</a>
-<blockquote>
-<p>
- Fix sporadic vertical stripes with planar fast image thresholding (pkmraw)<br>
-<br>
- In the landscape code, only the data for the last plane was being moved<br>
- to the start of the contone data for the next 32 lines of output. Seen<br>
- with -sDEVICE=pkmraw -dUsePlanarBuffer J8_landscape.ps but any landscape<br>
- image could have the problem. New code moves all planes and only resets<br>
- the ht_landscape parameters after all planes have been processed and<br>
- output (via copy_planes).<br>
-<br>
-gs/base/gxht_thresh.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-14 09:40: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=7784cce96478d8bcec314e2dc8ecb3d3a849c37b">7784cce96478d8bcec314e2dc8ecb3d3a849c37b</a>
-<blockquote>
-<p>
- Add missing newline to memento error logging.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-11 08:31:32 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c34097f6786f809826a30484e69684adf4915e9a">c34097f6786f809826a30484e69684adf4915e9a</a>
-<blockquote>
-<p>
- Fix output color values of pkm and pkmraw for GrayValues &gt; 2.<br>
-<br>
- In the header we indicate the max value is 255, so the output values<br>
- need to be scaled to that, not the color_info.max_color. We stay with<br>
- 255 since many viewers cannot display PPM files with other that 255<br>
- as the max (ignoring the max value in the header).<br>
-<br>
-gs/devices/gdevpbm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-13 11:43:24 +0000
-</strong>
-<br>James Cloos &lt;cloos@jhcloos.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=685e801f7de04d087166e24b3373ab16dcca57bc">685e801f7de04d087166e24b3373ab16dcca57bc</a>
-<blockquote>
-<p>
- Bug 695080: fix typo in the pngmono device declaration<br>
-<br>
- which caused pngmono to threshold rather than halftone at or above 150 dpi.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/devices/gdevpng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-13 13:47:56 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=303b48577602fb78df5fa40eb2de1d8e73245afa">303b48577602fb78df5fa40eb2de1d8e73245afa</a>
-<blockquote>
-<p>
- Bug 695090: Solve memory overwrite with pkmraw in planar mode.<br>
-<br>
- When using -dUsePlanarBuffer with the pnm devices, we run the<br>
- underlying rendering in planar mode, but then expect 'getbits'<br>
- to return chunky pixels. As such, the memory we allocate to<br>
- 'getbits' into should be allocated for chunky mode, not for<br>
- planar mode.<br>
-<br>
-gs/base/gdevprn.h<br>
-gs/base/gsdevice.c<br>
-gs/base/gxdevcli.h<br>
-gs/devices/gdevpbm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-13 11:19:11 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f2fde5b9596318796f4ffd8d356116b1bb203ae3">f2fde5b9596318796f4ffd8d356116b1bb203ae3</a>
-<blockquote>
-<p>
- Delete gs_fform.ps<br>
-<br>
- If we want to cache forms, we should implement it properly.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/lib/gs_fform.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-13 10:53:49 +0000
-</strong>
-<br>Andreas Schwab &lt;schwab@linux-m68k.org&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=becedfbfdbd9dee77825ff245f48c0acc9d03252">becedfbfdbd9dee77825ff245f48c0acc9d03252</a>
-<blockquote>
-<p>
- Bug 695058: force correct struct ref_s size<br>
-<br>
- On compilers that tightly pack structures (i.e. don't pad to alignment<br>
- boundaries), struct ref_s could end up as 14 bytes instead of 16 bytes,<br>
- thus breaking requirement in the garbage collector.<br>
-<br>
- This is less than ideal, and would be better achieved using the same trick<br>
- we use for the alignment of obj_header_s in base/gxobj.h, linking the structure<br>
- size to the obj_align_mod, but as on the majority of systems struct ref_s is<br>
- already 16 bytes, that results in a zero byte array which notable compilers (at<br>
- least MSVC, and probably others) to error.<br>
-<br>
- No cluster differences,<br>
-<br>
-gs/psi/iref.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-13 09:27: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=fdaa74efeebb753db1855eaf6a3a824ecbf1231e">fdaa74efeebb753db1855eaf6a3a824ecbf1231e</a>
-<blockquote>
-<p>
- Remove deprecated glyph mapping code.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_ttf.ps<br>
-gs/Resource/Init/gs_type1.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-12 17:18:25 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fe0b8fcfb69246cbea99b85f453ed6c3c83f4592">fe0b8fcfb69246cbea99b85f453ed6c3c83f4592</a>
-<blockquote>
-<p>
- Bug 693380: raise file path/name size limit to 4k<br>
-<br>
- And move as many cases of paths allocated on the stack to heap memory as is<br>
- reasonable.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevdevn.c<br>
-gs/base/gp.h<br>
-gs/base/gsdevice.c<br>
-gs/base/gsiodisk.c<br>
-gs/base/gsiomacres.c<br>
-gs/base/gsparam2.c<br>
-gs/devices/gdevtsep.c<br>
-gs/devices/vector/gdevxps.c<br>
-gs/psi/zfile.c<br>
-xps/xpsjxr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-13 10:35: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=83b6646951fee8fe153d14d3e2d7da75894b922a">83b6646951fee8fe153d14d3e2d7da75894b922a</a>
-<blockquote>
-<p>
- PDF interpreter - fix multiple xref stream reading<br>
-<br>
- Bug #695086 &quot;**** Error: Trailer is not found.&quot;<br>
-<br>
- When reading Xref streams, the PDF interpreter resizes its internal xref<br>
- tracking objects by looking at the /Size of the stream and making sure<br>
- the objects are at least that big. However it did not account for the fact<br>
- that an Xref stream may not start with object 0.<br>
-<br>
- In this case the first stream encountered had a /Size of 2, and an /Index<br>
- of [6 0]. This meant that we allocated objects of size 2, then tried to store<br>
- into location8, which naturally failed.<br>
-<br>
- This commit adds the /Index (starting object number) to the /Size before<br>
- ensuring the objects are large enough.<br>
-<br>
- No differences expected<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-12 21:25:39 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos@inches.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fadf80da45458db57cffdd90f1ed6c57aa31e51f">fadf80da45458db57cffdd90f1ed6c57aa31e51f</a>
-<blockquote>
-<p>
- Fixed typo in Devices.htm.<br>
-<br>
-gs/doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-12 15:52:34 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=94d070553225e0a8fb38157e081e9496dee8fde5">94d070553225e0a8fb38157e081e9496dee8fde5</a>
-<blockquote>
-<p>
- pdfwrite - remove deprecated code<br>
-<br>
- Before the release of 9.06 I #ifdef'ed a load of code as deprecated. Nobody<br>
- has found any problems, so I'm removing the code.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfb.h<br>
-gs/devices/vector/gdevpdfp.c<br>
-gs/devices/vector/gdevpdfu.c<br>
-gs/devices/vector/gdevpdfx.h<br>
-gs/devices/vector/gdevpdt.h<br>
-gs/devices/vector/gdevpdte.c<br>
-gs/devices/vector/gdevpdtf.h<br>
-gs/devices/vector/gdevpdtt.c<br>
-gs/devices/vector/gdevpdtw.c<br>
-gs/devices/vector/gdevpsds.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-12 13:32:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0598a205e9293fcaf548571624d93f534afa098d">0598a205e9293fcaf548571624d93f534afa098d</a>
-<blockquote>
-<p>
- Documentation - remove %ram% from the projects, as it is completed<br>
-<br>
-gs/doc/Projects.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-12 09:33:24 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8fad68f7c27f16cf78967443322bc4f638649f27">8fad68f7c27f16cf78967443322bc4f638649f27</a>
-<blockquote>
-<p>
- Update documentation for the pdfwrite family<br>
-<br>
- devices.htm - change epswrite references to eps2write, note that support for<br>
- language level 1 output is now removed.<br>
-<br>
- drivers.htm - alter pswrite to ps2write<br>
-<br>
- use.htm - alter epswrite to eps2write<br>
-<br>
- issues.htm - remove a surprisingly large number of documented issues which<br>
- appear to be no longer issues. Note that epswrite is deprecated.<br>
-<br>
- ps2pdf.htm - improve the documentation of PDF/A and PDF/X output and correct<br>
- the places where it was incorrect with the new colour management.<br>
-<br>
- No differences.<br>
-<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-11 09:58:31 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ee30f349671e3a23d666615f1648eab4a5290b4c">ee30f349671e3a23d666615f1648eab4a5290b4c</a>
-<blockquote>
-<p>
- Abbreviated escape sequence improvement.<br>
-<br>
- Abbreviated escape sequences were not handled properly with commands<br>
- that hold arbitrary amounts of data, like raster and font related<br>
- commands. PCL shorthand is rarely used in this circumstance<br>
- but it is legal. Thanks to Hin-Tak for the discovery and analysis of<br>
- this problem.<br>
-<br>
-pcl/pcparse.c<br>
-pcl/pcparse.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-09 16:11:24 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4c2f426905b4bf300f6b412024d71cd2be6276de">4c2f426905b4bf300f6b412024d71cd2be6276de</a>
-<blockquote>
-<p>
- Remove GhostSVG.<br>
-<br>
- No cluster differences.<br>
-<br>
-Makefile<br>
-gs/configure.ac<br>
-svg/ghostsvg.h<br>
-svg/svg.mak<br>
-svg/svg_gcc.mak<br>
-svg/svg_msvc.mak<br>
-svg/svgcolor.c<br>
-svg/svgcolorlist.h<br>
-svg/svgdoc.c<br>
-svg/svgshapes.c<br>
-svg/svgtop.c<br>
-svg/svgtransform.c<br>
-svg/svgtypes.c<br>
-svg/svgxml.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-09 15:54:06 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8dacc34a50174bceac7786ce47466d9a71547955">8dacc34a50174bceac7786ce47466d9a71547955</a>
-<blockquote>
-<p>
- Remove SVG writer from Ghostscript/GhostPDL<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Makefile.in<br>
-gs/configure.ac<br>
-gs/devices/devs.mak<br>
-gs/devices/vector/gdevsvg.c<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-06 11:57:00 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22ebcc33db33aa15399a6836e48953736256eb41">22ebcc33db33aa15399a6836e48953736256eb41</a>
-<blockquote>
-<p>
- Fix UseFastColor during clist playback.<br>
-<br>
- Discovered with customer 532, the default_match was not set early<br>
- enough in gsicc_get_link for the index to be correct, effectively<br>
- disabling usefastcolor mode. As a result images could be rendered<br>
- with ICC based color transform instead of the 'nocm' fastcolor<br>
- methods.<br>
-<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclist.h<br>
-gs/base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-08 20:29:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f5457548e8162438a43b1aeb2040e34c001adaa4">f5457548e8162438a43b1aeb2040e34c001adaa4</a>
-<blockquote>
-<p>
- Use malloc/free for lcms(2) shared lib build.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsicc_lcms.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/lcms.mak<br>
-gs/base/lcms2.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-07 17:00:28 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=58121374ed0d12aa38c872eb4d069b75ed5875d5">58121374ed0d12aa38c872eb4d069b75ed5875d5</a>
-<blockquote>
-<p>
- cast to silence a compiler warning<br>
-<br>
-gs/base/gdevvec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-07 13:41:01 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=94c5ecffe4bf66cc91108d99a802c7c2d3b86e0b">94c5ecffe4bf66cc91108d99a802c7c2d3b86e0b</a>
-<blockquote>
-<p>
- PS interpreter, vector devices and pdfwrite - remove setdash limit of 11<br>
-<br>
- Bug #693916 &quot;setdash does not accept more than 11 elements in the array argument&quot;<br>
-<br>
- The PostScript interpreter was already capable of this, it simply required<br>
- the limit check to be removed. The vector device needed to allocate and<br>
- free an array of floats, rather than maintain a fixed size array.<br>
-<br>
- pdfwrite was teh most complex as it maintains a stack of gstates, and these<br>
- also needed to be modified to allocate and free the dash array. However the<br>
- gstate stack wasn't already a garbage collecting structure. Rather than going<br>
- to the effort of turning it into one I've opted to allocate the dash pattern<br>
- from non-gc memory.<br>
-<br>
- A few PCL files show differences with pdfwrite, because previously pdfwrite<br>
- would throw an error (more than 11 elements in the dash array) and the stroked<br>
- lines would degenerate into filled rectangles, whereas now they are drawn as<br>
- stroked lines with a correct dash pattern. This is much more efficient.<br>
-<br>
- The clist remains unmodified, Ray assures me that it will be handled there<br>
- without problems.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/gdevvec.c<br>
-gs/base/gdevvec.h<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-05 09:47:52 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b16c45c3b834efb9ff9608360d3c053e91b1f23">4b16c45c3b834efb9ff9608360d3c053e91b1f23</a>
-<blockquote>
-<p>
- Fix UseFastColor ignored for pages with transparency.<br>
-<br>
- Found when researching problem from customer 532.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-03 12:21:12 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e63f9d066c001052f5594f09c3a3a59ff80d2d03">e63f9d066c001052f5594f09c3a3a59ff80d2d03</a>
-<blockquote>
-<p>
- Fix problem with -d***Values=16 and bitrgb device.<br>
-<br>
- The max_gray and max_color would confuse the gx_device_must_halftone<br>
- macro because setting -dGrayValues=16 would end up setting the<br>
- max_gray and max_color to 31 (0x1f) which does NOT halftone. with<br>
- the change setting to 16 values doesn't change the bpc if put_params<br>
- is called again. Also remove allowing -dGrayValues=32 from supported<br>
- choices.<br>
-<br>
-gs/devices/gdevbit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-05 08:54:56 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b442d9a0c193d2d0114e72e1312e7bcc6e558aab">b442d9a0c193d2d0114e72e1312e7bcc6e558aab</a>
-<blockquote>
-<p>
- pdfwrite revert 3894e9c8a3ab125c82048da3bf81515500bb2da0<br>
-<br>
-<br>
- Bug #695083 &quot; Regression: pdfwrite DEVICE generates extra page with -dLastPage= option&quot;<br>
- This wasn't a customer bug report, and it doesn't work well with PCL, when<br>
- specifying -dLastPage, so I've decided just to revert it.<br>
-<br>
- A very few PCL files are flagged by the cluster as different, but there are<br>
- no bmpcmp diffs.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-03 17:34:08 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a68412d171e5c998026a13dffcbc90ef9d477b9">9a68412d171e5c998026a13dffcbc90ef9d477b9</a>
-<blockquote>
-<p>
- Bug 695007: Fix problems with unicode chars in TEMP path.<br>
-<br>
- If there are unicode chars in the temporary path (either that<br>
- given by TMPDIR, TEMP or windows own GetTempPath functions)<br>
- when opening a scratch file, we mishandle them.<br>
-<br>
- This commit improves the behaviour to treat paths consistently<br>
- as UTF8.<br>
-<br>
- This incorporates changes from Paul Gardiner to make the winrtsup.cpp<br>
- functions use wide chars. This simplifies the functions and integrates<br>
- better with the calling code. Also fix some uses of sizeof where size<br>
- in chars was required.<br>
-<br>
-gs/base/gp_mswin.c<br>
-gs/base/winrtsup.cpp<br>
-gs/base/winrtsup.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-04 10:24:47 +0000
-</strong>
-<br>Paul Gardiner &lt;paulg-artifex@glidos.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f29e49d4b157a84b4793eda614447811b471c047">f29e49d4b157a84b4793eda614447811b471c047</a>
-<blockquote>
-<p>
- Fix pointer-usage bug in GetTempFileNameWRT<br>
-<br>
-gs/base/winrtsup.cpp<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-04 15:30:02 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5b2adda7468241123d9559a98cd469f527dd7e3c">5b2adda7468241123d9559a98cd469f527dd7e3c</a>
-<blockquote>
-<p>
- pdfwrite - do not apply the 'Default*' colour spaces<br>
-<br>
- Noticed while testing by Chris.<br>
-<br>
- The PDF spec says that if any of DefaultGray, DefaultRGB or DefaultCMYK are<br>
- present in a PDF page, then we should use those to do a conversion to<br>
- device-independent colour space for colours specified in the matching Device*<br>
- space.<br>
-<br>
- This is broadly equivalent to the UseCIEColor PostScript user parameter but<br>
- unlike that parameter the user has no control over it. Previously we applied<br>
- this conversion but it seems unreasonable to do this for pdfwrite as this<br>
- will convert a PDF using device spaces into a PDF using ICCBased spaces.<br>
-<br>
- Accordingly we now test the device properties and for HigLevel devices we<br>
- do *not* perform this conversion.<br>
-<br>
- If the conversion really is desired then setting -dUseCIEColor will perform it.<br>
-<br>
- This results in a very few files showing differences, neither progressions<br>
- nor regressions, merely different. However the pdfwrite warning about use<br>
- of UseCIEColor does go away.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-04 09:25:18 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2621110f37eb0c94a732578acd24634caec1c25b">2621110f37eb0c94a732578acd24634caec1c25b</a>
-<blockquote>
-<p>
- Bug 694832: add an explicit flag for TTF notdef<br>
-<br>
- The previous solution for this issue &quot;overloaded&quot; an existing workaround for<br>
- pdfwrite. Unfortunately, a clash between pdfwrite's needs and FAPI's meant it<br>
- did not work all the time.<br>
-<br>
- So, when loading a TTF for use in a PDF, add a new flag to the font dictionary<br>
- to tell the FAPI code whether to render a Truetype notdef.<br>
-<br>
- Several differences show up on the cluster - the following are progressions<br>
- compared to Acrobat:<br>
- Bug689757.pdf<br>
- Bug691031.pdf<br>
- Bug691221.pdf<br>
- Bug693538.pdf<br>
- Bug693646.ps<br>
- Bug693711.pdf<br>
- keyboard.pdf<br>
- CATX1490.pdf<br>
- IA3Z0815.pdf<br>
-<br>
- These are different from before, but since Acrobat can't even open these,<br>
- I don't much care:<br>
- 207ee6f24411fc4591d2b5a337c46de8-full.pdf<br>
- 2123_-_MacExpertEncoding_badly_handled.pdf<br>
- 764_-_heading_garbage.pdf<br>
-<br>
-gs/Resource/Init/gs_ttf.ps<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-04 09:49: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=0214c1b9c70cd41026e5cda707e582b32489a64c">0214c1b9c70cd41026e5cda707e582b32489a64c</a>
-<blockquote>
-<p>
- remove a misleading comment<br>
-<br>
-gs/devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-04 09:47:50 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=095ae57e266ee5168f042c26dd2e9d12273efb28">095ae57e266ee5168f042c26dd2e9d12273efb28</a>
-<blockquote>
-<p>
- ps2write - fix missing %%BeginResource comment for FontFile objects<br>
-<br>
- Bug #695082 &quot; ps2write: Some &quot;%%BeginResource&quot; DSC comments have only one &quot;%&quot; character&quot;<br>
-<br>
- FontFile streams were being written with a &quot;%%EndResource&quot; comment, but the<br>
- &quot;%%BeginResource&quot; comment was missing.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdfu.c<br>
-gs/devices/vector/gdevpdfx.h<br>
-gs/devices/vector/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-03-03 14:14:19 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=649848310dd4f9400f63c685748e4f76344ba9d7">649848310dd4f9400f63c685748e4f76344ba9d7</a>
-<blockquote>
-<p>
- ps2write - fix a DSC comment<br>
-<br>
- Bug #695082 &quot;ps2write: Some &quot;%%BeginResource&quot; DSC comments have only one &quot;%&quot; character&quot;<br>
-<br>
- A DSC comment was emitted using a printf format string without escaping the<br>
- &quot;%&quot;s<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-27 11:28:57 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6abeac1c7ab3ee82523353b5373230e2607c0b9">f6abeac1c7ab3ee82523353b5373230e2607c0b9</a>
-<blockquote>
-<p>
- pdfwrite - fix commit 1d1d22976ce5b5e96d862c404ca80f189476bfed<br>
-<br>
- Despite not throwing any regressions, there was a bug in this commit.<br>
-<br>
- A couple of places used the pprintld* routines, which *don't* accept the<br>
- %&quot;PRId64&quot; sequence and this led ot us writing an invalid xref.<br>
-<br>
- Fixed here by using gs_sprintf instead.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-27 09:33: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=1d1d22976ce5b5e96d862c404ca80f189476bfed">1d1d22976ce5b5e96d862c404ca80f189476bfed</a>
-<blockquote>
-<p>
- pdfwrite - fix FastWebView for big-endian devices<br>
-<br>
- Bug #695075 &quot; Creating &quot;optimized&quot; PDF on Big-endian OS gives errors when view the PDF indicating PDF is not right&quot;<br>
-<br>
- This commit applies all the changes supplied by Jonathan Dagresta of SDL,<br>
- see the bug report for details.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-26 10:38:02 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=30f2c656469f5930b1adc82454706743df68b0d7">30f2c656469f5930b1adc82454706743df68b0d7</a>
-<blockquote>
-<p>
- Disable threshold array based image optimization for depth &gt; 1.<br>
-<br>
- The monochrome image case in gximono.c already checked for depth == 1<br>
- but the gxicolor.c code was missing this. These can be removed when<br>
- the gxht_thresh.c code is enhanced for greater bit depths.<br>
-<br>
-gs/base/gxicolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-26 09:20:37 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b53c81e38925d05b00ba9068aebc5fcbc519a685">b53c81e38925d05b00ba9068aebc5fcbc519a685</a>
-<blockquote>
-<p>
- ps2write - add a feature to customise the output for specific devices<br>
-<br>
- Bug #695070 &quot;Customer would like a way to specify printer specific features in ps2write device&quot;<br>
-<br>
- This commit adds two new distiller params, specific to ps2write, PSDocOptions<br>
- and PSPageOptions, which are described in detail in the ps2ps2.htm document.<br>
-<br>
- These allow an end user to specify PostScript (normally device-specific<br>
- configuration) which can be injected into a DSC compliant file at the documet<br>
- level and at the individual page level.<br>
-<br>
- No differences expected<br>
-<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfb.h<br>
-gs/devices/vector/gdevpdfu.c<br>
-gs/devices/vector/gdevpsdf.h<br>
-gs/devices/vector/gdevpsdp.c<br>
-gs/doc/Ps2ps2.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-23 09:46:21 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=77fce4a0cfd70b94a90a876cac0310fda1a969ee">77fce4a0cfd70b94a90a876cac0310fda1a969ee</a>
-<blockquote>
-<p>
- Fix bug 695054, segfault caused by stale pointer in pattern-clist device.<br>
-<br>
- The pattern-clist device could be left allocated in stable memory<br>
- after the pattern was removed from the pattern cache. The pattern<br>
- instance could be freed by a subsequent restore since it was not<br>
- in stable memory. GC trace of the chunks would then reference the<br>
- stale pinst pointer. Also, the heap pointer needs to be valid in<br>
- ialloc_validate_spaces 'state' since it can be used for error output<br>
- and this could cause a segfault.<br>
-<br>
-gs/base/gxpcmap.c<br>
-gs/psi/ilocate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-24 10:41:23 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9990bdac31c018de33de2c09053b7e392a26304f">9990bdac31c018de33de2c09053b7e392a26304f</a>
-<blockquote>
-<p>
- Fix Bug 694685 - Seg faults found by fuzzing in sfopen.<br>
-<br>
- PCL would continue processing with a corrupt font. This could lead to<br>
- bad memory accesses as demonstrated by the fuzzing example. For now,<br>
- we return an error when a corrupt font is encountered and end the job.<br>
- Likely, a lighter approach is called for: continue process without<br>
- defining the font. This would be a bit more involved and we'll<br>
- consider it if users report HP precedent for the behavior.<br>
-<br>
-pcl/pcsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-24 15:14: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=b6f8dba649f1be2ba5b9eb1d257f2052f7f2df28">b6f8dba649f1be2ba5b9eb1d257f2052f7f2df28</a>
-<blockquote>
-<p>
- Move ram file system memory to 'stable' memory<br>
-<br>
- The RAM file system was using regular GC'ed memory for its storage, which is<br>
- subject to save and restore. The RAM file system should not, of course, be<br>
- subject to save and restore!<br>
-<br>
- This commit prevents save and restore affecting the memory for the ramfs<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/ramfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-14 18:16:55 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=863a1dfb328298a39871e49d218a16781fd42cba">863a1dfb328298a39871e49d218a16781fd42cba</a>
-<blockquote>
-<p>
- Bug 694880 and bug 694904: prevent heap overflow in opj_j2k_add_tlmarker<br>
-<br>
- Signed-off-by: Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<br>
-gs/openjpeg/libopenjpeg/j2k.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-14 18:20:36 +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=b17894bfedaf7b76edac15f681a4bd08717c65c0">b17894bfedaf7b76edac15f681a4bd08717c65c0</a>
-<blockquote>
-<p>
- Bug 694906: fix potential heap overflow in opj_t2_read_packet_header<br>
-<br>
- Signed-off-by: Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<br>
-gs/openjpeg/libopenjpeg/t2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-18 09:36: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=7bd3739a888f70edf0270891782a88a547f5e829">7bd3739a888f70edf0270891782a88a547f5e829</a>
-<blockquote>
-<p>
- Make the OpenJPEG callbacks static.....<br>
-<br>
- and give them names more likely to be unique (just for debugging convenience).<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/sjpx_openjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-18 11:22:16 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=174cfd14e4d34a37cdcf2e0372bd0b4334310e8b">174cfd14e4d34a37cdcf2e0372bd0b4334310e8b</a>
-<blockquote>
-<p>
- Fix pngalpha when PDF has transparency. Bugs 687630, 693024 and 695042.<br>
-<br>
- We needed a pngalpha_put_image procedure to properly collect the pdf14<br>
- compositor alpha value. Note that this is NOT simple 0 or 1 alpha, but<br>
- the actual effective page level opacity from the PDF. Note that some<br>
- viewers may not correctly display these despite this being part of<br>
- the PNG spec.<br>
-<br>
-gs/devices/gdevpng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-15 13:54:07 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b69da60516576d65ce1e27087dc358fef067ec58">b69da60516576d65ce1e27087dc358fef067ec58</a>
-<blockquote>
-<p>
- Fix bug 695405. The psdcmykog device should not lock num_components.<br>
-<br>
- This regression was introduced with an attempt to fix SeparationOrder<br>
- handling, but is not needed because we throw an error when there is<br>
- an attempt to set the SeparationOrder, and the device is confused<br>
- when the num_components is reset in the open_device procedure.<br>
-<br>
-gs/devices/gdevcmykog.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-11 08:07: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=3ebdb4596c8fa05656dc3987553217efe72b6b8d">3ebdb4596c8fa05656dc3987553217efe72b6b8d</a>
-<blockquote>
-<p>
- Improve chunk allocator performance using a doubly linked list (bug 694985)<br>
-<br>
- Thanks to Norbert Janssen for the linked list logic. Also make a couple<br>
- of other improvements in the free_object logic and use a separate<br>
- structure for the freelist to avoid confusion with object nodes.<br>
-<br>
-gs/base/gsmchunk.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-14 14:07:11 +0100
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c5ad5b7f373313e9bc7b8991cc9e34506e627e0a">c5ad5b7f373313e9bc7b8991cc9e34506e627e0a</a>
-<blockquote>
-<p>
- xps: Fix memory leaks in xpszip.c when handling errors.<br>
-<br>
- Thanks to Norbert Janssen.<br>
-<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-14 10:12:28 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e93c580b175ac086db942c32fab055c6062e8e4">1e93c580b175ac086db942c32fab055c6062e8e4</a>
-<blockquote>
-<p>
- ps2write - more colour conversion work<br>
-<br>
- Bug #694774<br>
-<br>
- When outputting to PostScript we don't preserve certain colour spaces which<br>
- either cannot be represented in PDF (CIEBased) or in level 2 PostScript<br>
- (ICCBased/Lab/DeviceN) are not preserved. These should be written as device<br>
- colours instead, but this wasn't always happening correctly.<br>
-<br>
- This commit should resolve this, and should now make it possible (but still<br>
- inadvisable) to use -dUseCIEColor with both pdfwrite and ps2write.<br>
-<br>
- A small number of files show (frankly imperceptible) colour shifts with<br>
- ps2write with this change.<br>
-<br>
-gs/devices/vector/gdevpdfc.c<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-13 14:49: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=edbed246ed67fcf24f854795f0d703bcb5d902fe">edbed246ed67fcf24f854795f0d703bcb5d902fe</a>
-<blockquote>
-<p>
- Bug 695027: use a consistent allocator in the FT server<br>
-<br>
- There was some mixing of memory allocators in the Freetype integration code,<br>
- most of the code used the chunk allocator instance created during the<br>
- server initialization, but glyph data allocations were using the allocator from<br>
- the font object.<br>
-<br>
- With two different FAPI servers in place, and with the right combination of<br>
- events, that could mean we'd lose the allocator pointer when destroying<br>
- the font object.<br>
-<br>
- We're consistent in that all the memory allocations in the FAPI/Freetype code<br>
- are directed through the chunk allocator created for that purpose.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-13 14:47:18 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=979d824c9da11e9f366b1d90aed06f9449127997">979d824c9da11e9f366b1d90aed06f9449127997</a>
-<blockquote>
-<p>
- Bug 695024: fix a typo<br>
-<br>
- In the UFST integration code, we check if the Freetype server is available<br>
- and if it is, we punt any non-Microtype fonts to that. The typo is that<br>
- the Freetype server is named &quot;FreeType&quot; - the &quot;T&quot; was lower case.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/fapiufst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-13 15:14:49 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d349b1ae5852db20fcaca21b357748eb5360817">4d349b1ae5852db20fcaca21b357748eb5360817</a>
-<blockquote>
-<p>
- Bug #695034 Improve handling of word spacing with CIDFonta<br>
-<br>
- Bug #695034 &quot;Numbers and words are overlapping&quot;<br>
-<br>
- Word spacing does not apply to ti CIDFOnts, *except* for 1-byte mappings<br>
- where the byte 0x20 has word spacing applied to it.<br>
-<br>
- The previous code attempted to check this by using a heuristic to determine<br>
- a single byte mapping in order to avoid adding more entries to the text<br>
- enumerator. unfortunately this file defeats that heuristic which meant<br>
- that it was necessary to calculate the number of bytes decoded when we<br>
- extract one character, and store that information so that the 'move'<br>
- routine can apply word spacing if required.<br>
-<br>
- This shows two differences with a cluster run. Bug694436.pdf is very subtly<br>
- different, I'm assuming this is a progression. The Sumatra file<br>
- 850_-_wrong_default_for_asian_fonts.pdf shows very significant improvements<br>
- with this commit.<br>
-<br>
-gs/base/gxchar.c<br>
-gs/base/gxtext.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-11 15:15:56 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f4584b0e162a96ec143f0057de63c116e649e02b">f4584b0e162a96ec143f0057de63c116e649e02b</a>
-<blockquote>
-<p>
- Bug 695031: don't assume we can read a font file<br>
-<br>
- When we scan system fonts, we were assuming fonts found would be in a format<br>
- Ghostscript understands. This is not necessarily the case.<br>
-<br>
- So put the minimal parsing call to get the font's name in a stopped context,<br>
- so we can skip the file it's not an understandable format. And clean up the<br>
- stack in the event we try such a file.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-11 12:14:33 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=149b4b33c909c2d67c44c7a820f70209294bee76">149b4b33c909c2d67c44c7a820f70209294bee76</a>
-<blockquote>
-<p>
- Don't allow PS CIE color spaces to be used for transparency group color spaces.<br>
-<br>
- The CIE color spaces are 1-way. In that they map from Device to CIE, not from<br>
- CIE to Device. A transparency group color space needs to be able to go both<br>
- directions. This fixes the regression 694774<br>
-<br>
-gs/base/gsicc_cms.h<br>
-gs/base/gsicc_lcms2.c<br>
-gs/psi/int.mak<br>
-gs/psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-11 11:18:39 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c22a604f0dc176fe1ae7545097e8a818e5d38309">c22a604f0dc176fe1ae7545097e8a818e5d38309</a>
-<blockquote>
-<p>
- Remove final remnants of deprecated CRD code.<br>
-<br>
-pcl/pccid.c<br>
-pcl/pcl.mak<br>
-pl/pl.mak<br>
-pl/plsrgb.c<br>
-pl/plsrgb.h<br>
-pxl/pxgstate.c<br>
-pxl/pximage.c<br>
-pxl/pxink.c<br>
-pxl/pxl.mak<br>
-pxl/pxsessio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-11 08:07: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=c240594f3083158ab829cd121159879183bf49c8">c240594f3083158ab829cd121159879183bf49c8</a>
-<blockquote>
-<p>
- Improve the debug 'cname' for chunk_mem_node_add similar to MEMENTO builds.<br>
-<br>
- For normal builds use the caller's cname when allocating the chunk if the<br>
- object is in its own chunk. Previously this only was used for MEMENTO builds.<br>
- NB: MEMENTO builds put every object in a chunk, so the cname will always be<br>
- the caller's, never &quot;chunk_mem_node_add&quot;.<br>
-<br>
-gs/base/gsmchunk.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-09 11:48:35 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0eaf9e76f83eff5d0dd5eb1f8d9a5314b9ca44cd">0eaf9e76f83eff5d0dd5eb1f8d9a5314b9ca44cd</a>
-<blockquote>
-<p>
- Fix bug 694821. Ignore SeparationOrder with the psdcmykog device.<br>
-<br>
- While this is a DeviceN device with some non-standard components<br>
- that can be painted using Separation or DeviceN colorspaces, this<br>
- device always outputs all 6 channels and can't deal with a subset<br>
- of the channels, so return an error (undefined) for SeparationOrder.<br>
- the separation_map remains constant to avoid color distortion if<br>
- SeparationOrder is used.<br>
-<br>
- Also make sure that we never add separations (NO_AUTO_SPOT_COLORS)<br>
- from the get_color_comp_index procedure.<br>
-<br>
-gs/devices/gdevcmykog.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-07 18:13:52 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a11848051b9abdbe2b750976018d4167a96d2fea">a11848051b9abdbe2b750976018d4167a96d2fea</a>
-<blockquote>
-<p>
- Fix some problems with SeparationOrder handling -- 29-07I.PS<br>
-<br>
- Most importantly, when setting SeparationOrder parameters fail, we<br>
- need to use param_signal_error. Otherwise, even though the error code<br>
- is returned, the stack for setpagedevice would be missing the param<br>
- information and code that caused the error.<br>
-<br>
- Also the num_spot and num_spot_changed were improperly updated when<br>
- ENABLE_AUTO_SPOT_COLORS allowed SeparationOrder to add separations.<br>
-<br>
-gs/base/gdevdevn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-11 09:33: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=f176e516add62d3a943a755a9294c510c579655d">f176e516add62d3a943a755a9294c510c579655d</a>
-<blockquote>
-<p>
- pdfwrite - fix a bug in the font embedding white list detection<br>
-<br>
- While working on bug #695030 I ran across a bug in the font embedding<br>
- white list code. If the bisection of the list exactly hits the target string<br>
- exactly then the bisection would fail to find the string.<br>
-<br>
- This commit special cases this and detects the string.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/whitelst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-10 11:17:01 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fac814792b42dfc2baafe84062ff986b7620cfe3">fac814792b42dfc2baafe84062ff986b7620cfe3</a>
-<blockquote>
-<p>
- pdfwrite - alter the example pdfa_def.ps for PDF/A generation<br>
-<br>
- The pdfa_def.ps file is incorrect with the new colour handling, and has long<br>
- had a problem with only handling Gray or CMYK.<br>
-<br>
- Its no longer possible to retrieve the ProcessColorModel from systemdict,<br>
- we must now use the current device dictionary.<br>
-<br>
- pdfa_def.ps now supports DevuiceGray, DeviceRGB and DeviceCMYK models.<br>
-<br>
- No differences expected<br>
-<br>
-gs/lib/PDFA_def.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-10 11:14: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=e17abc0e4574cdefd25032aa1003ff28503b5867">e17abc0e4574cdefd25032aa1003ff28503b5867</a>
-<blockquote>
-<p>
- pdfwrite - new color code. Fix the emission of DeviceIndependent colours<br>
-<br>
- Bug #694806 &quot;chars and colors lost during PDF/A transformation&quot;<br>
-<br>
- If we used the same device independent (ICCBased) colour space, but a<br>
- different colour, we ended up not writing the new colour. This code fixes<br>
- that problem.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-10 08:34:54 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d59e1feb9545b399027907cb2d1a6855c524e0b4">d59e1feb9545b399027907cb2d1a6855c524e0b4</a>
-<blockquote>
-<p>
- PS interpreter - Fix rotation problem with EPSFitPage<br>
-<br>
- Bug #695016 &quot;Gradient eps file to pdf&quot;<br>
-<br>
- When fitting an EPS Bounding Box to a specified page size, the code looks<br>
- at the width and height of both the page and the EPS file, to see if the<br>
- EPS will fit 'better' by rotating it.<br>
-<br>
- In this particular case the page is square, but there was no special case<br>
- for this, which mean that landscape pages wold be rotated twice, causing<br>
- the content to disappear.<br>
-<br>
- This commit special cases square media sizes and does not attempt to rotate<br>
- the EPS, no matter what its orientation, as there is clearly no point in<br>
- doing so. This prevents the double rotation and resolves the problem.<br>
-<br>
- Tested with landscape, portrait and square media and EPS files, in all<br>
- combinations.<br>
-<br>
- No differences expected<br>
-<br>
-gs/Resource/Init/gs_epsf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-06 09:56:43 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc3770910997a17386c65eaa44e73cf7cf5e8339">dc3770910997a17386c65eaa44e73cf7cf5e8339</a>
-<blockquote>
-<p>
- Fix Windows display device -dDisplayFormat=16#a0800 regression.<br>
-<br>
- Commit 82fc3bd change to msvc.mak removed setting the GX_COLOR_INDEX_TYPE,<br>
- and code in base/gxcindex.h set this incorrectly to 'ulong'. Add the code<br>
- that was removed and also add conditional compile to set this from<br>
- ARCH_SIZEOF_GX_COLOR_INDEX if it is not defined.<br>
-<br>
- Also add a 'compile time assert' that causes the build to fail if the<br>
- sizeof(GX_COLOR_INDEX_TYPE) is not equal to ARCH_SIZEOF_GX_COLOR_INDEX.<br>
- Thanks to Robin for finding this trick on the web.<br>
-<br>
-gs/base/gxcindex.h<br>
-gs/base/lib.mak<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-06 09:53:55 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab3faf9dd8b61b7adc83f370e8caf40f09a442bb">ab3faf9dd8b61b7adc83f370e8caf40f09a442bb</a>
-<blockquote>
-<p>
- pdfwrite - improved error handling in pdf_close<br>
-<br>
- Bug #695013 &quot; GS not finishing pdf write, creating huge files, when root / partition is full&quot;<br>
-<br>
- we weren't checking the error return when trying to find the end of an<br>
- xref section while writing the xref. Any ioerror would havce caused this<br>
- problem.<br>
-<br>
- While this fixes the specific instance of the problem, I can't guarantee<br>
- that more subtle problems (eg filling disk while writing the PDF file)<br>
- don't still exist.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-05 14:19:59 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ff033b6ec050f23cb7b1e6ff52bb48fb45afd9e3">ff033b6ec050f23cb7b1e6ff52bb48fb45afd9e3</a>
-<blockquote>
-<p>
- Update jbig2dec standalone build for Windows.<br>
-<br>
- Add the missing jbig2_halftone.c file, and make building without libpng<br>
- the default.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/jbig2dec/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-04 13:35:04 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a75ff89833289614e0dc2476c822462670f822bc">a75ff89833289614e0dc2476c822462670f822bc</a>
-<blockquote>
-<p>
- Remove strdup in gdevxps.c .<br>
-<br>
- In Windows 8 64 bit builds with VS2012/2013 strdup use resulted in a crash. Replaced<br>
- with standard strlen/gs_alloc_bytes/strcpy. Note that we need to free this allocation at some point.<br>
-<br>
-gs/devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-23 09:53: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=8033bcb40edf7520682cb14ee41226eddf9c8e5e">8033bcb40edf7520682cb14ee41226eddf9c8e5e</a>
-<blockquote>
-<p>
- Tweak xpsprint build.<br>
-<br>
- Conflicts:<br>
- gs/base/msvctail.mak<br>
- gs/base/winlib.mak<br>
- gs/devices/vector/gdevxps.c<br>
-<br>
- Tweak the xpsprint code to use runtime DLL loading<br>
-<br>
- Conflicts:<br>
- gs/base/msvctail.mak<br>
-<br>
-gs/base/msvctail.mak<br>
-gs/base/winlib.mak<br>
-gs/base/xpsprint.cpp<br>
-gs/devices/devs.mak<br>
-gs/devices/vector/gdevxps.c<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-21 12:01:41 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d10c375e190876fef3f431e17c47dcacda03d567">d10c375e190876fef3f431e17c47dcacda03d567</a>
-<blockquote>
-<p>
- Add new code for a 'gsprint' alike which uses the XPS print system on<br>
- WIndows<br>
-<br>
- Add new code for a 'gsprint' on new versions of Windows, using XPS<br>
-<br>
-gs/base/xpsprint.cpp<br>
-gs/devices/vector/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-03 07:18:16 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4eb758e74c73c03b113ba2bf73245f21b1c6de14">4eb758e74c73c03b113ba2bf73245f21b1c6de14</a>
-<blockquote>
-<p>
- Fix writes to freed memory caused by commit 429640.<br>
-<br>
- I had moved the clearing of the ctx to before the gs_malloc_release<br>
- call, but this function frees the ctx, so we wrote to freed memory.<br>
- Move it back.<br>
-<br>
-gs/psi/iapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-31 12:24:25 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=363f3bc0d3b6206cc1e0aff0ce2fe954c0295409">363f3bc0d3b6206cc1e0aff0ce2fe954c0295409</a>
-<blockquote>
-<p>
- Fix bug 694994. Gray and CMYK pdf14 clist accumu devices had wrong color_info.<br>
-<br>
- In cut and pasting the device structures, I negleccted to change the color<br>
- info for the macros.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-02-01 12:10:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f2970c2a35a146f21631612adfca48a0b1bb2b3">2f2970c2a35a146f21631612adfca48a0b1bb2b3</a>
-<blockquote>
-<p>
- PDF interpreter - disable Comment parsing for PDF files<br>
-<br>
- Bug #694987 &quot;PDF metadata messed up for PDF-&gt;PDF conversion&quot;<br>
-<br>
- This is caused by parsing DSC comments from an embedded font file. Of course<br>
- the font should not contain DSC comments, but it seems FontForge always<br>
- embeds such.<br>
-<br>
- There is nothing useful to be gained from *PostScript* comments in a PDF<br>
- file, so the simplest solution is to disable comment parsing for the<br>
- duration of the PDF file.<br>
-<br>
- This will also avoid problems with PostScript XObjects.<br>
-<br>
- No differences expected<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-31 15:08:17 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=161559d289a9b4306673c7d7e089182670c5090a">161559d289a9b4306673c7d7e089182670c5090a</a>
-<blockquote>
-<p>
- Slightly rejig i/o in inkcov device.<br>
-<br>
- Tweak so that output directed to stdout or stderr go through the graphics<br>
- library's own stdout and stderr handlers - that way, it can be seen by<br>
- integrators using the Ghostscript API with custom stdio handler methods.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevprn.c<br>
-gs/base/gslibctx.h<br>
-gs/devices/gdevicov.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-31 14:50:55 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ef7b0d503fee02da12430ee19a394b23b1bfa6f">7ef7b0d503fee02da12430ee19a394b23b1bfa6f</a>
-<blockquote>
-<p>
- pdfwrite - colour conversion, consider sRGB to be RGB<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpdfi.c<br>
-gs/devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-31 09:42: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=a2a785d3f6111410198c396fe21813ddd41664be">a2a785d3f6111410198c396fe21813ddd41664be</a>
-<blockquote>
-<p>
- PDF interpreter - add -dUseBleedBox to complete the quartet of Boxes<br>
-<br>
- Bug #694977 &quot;please provide -dUseBleedBox in analogy to crop- and trimbox&quot;<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-31 08:19: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=6c4e66f6a7a1e9fc3ed3beff84549aa3bbbbe795">6c4e66f6a7a1e9fc3ed3beff84549aa3bbbbe795</a>
-<blockquote>
-<p>
- pdfwrite - remove 2 unused variables<br>
-<br>
- silences compiler warnings<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-30 11:08:55 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=429640b32e1ffcd324c2b44daa1fb35ef41c01d4">429640b32e1ffcd324c2b44daa1fb35ef41c01d4</a>
-<blockquote>
-<p>
- Move final memory (max) usage to gs_malloc_release.<br>
-<br>
- Not all systems (e.g. unix) use the gsapi interface, so the debug<br>
- -Z: didn't print the final memory usage as on Windows.<br>
-<br>
-gs/base/gsmalloc.c<br>
-gs/psi/iapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-30 15:32:23 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea83541f7fcc1af40cf62f0e7457df74e8b427c4">ea83541f7fcc1af40cf62f0e7457df74e8b427c4</a>
-<blockquote>
-<p>
- pdfwrite - more EMBED pdfmrk changes<br>
-<br>
- commit 3e5ae4ea39655643ae352cf4723702a164c10417 omitted a crucial change<br>
- which swapped the search order of /FS and /Name. Without that the dict<br>
- entries are not correctly named.<br>
-<br>
- This oversight demonstrated a flaw in the error handling resulting in invalid<br>
- PDF files being written, which we correct here. If we get an error we close<br>
- the 'aside' so that we don't end up writing the PDF trailer to a temporary<br>
- file instead of the real PDF file.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-30 10:00:23 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3e5ae4ea39655643ae352cf4723702a164c10417">3e5ae4ea39655643ae352cf4723702a164c10417</a>
-<blockquote>
-<p>
- pdfwrite - more work on /EMBED pdfmark<br>
-<br>
- As was rather anticipated, commit a91d2576df0e60f6e691a3bd967b51109ae41f22<br>
- wasn't sufficient. We were writing an invalid name tree as we were writing<br>
- /Limits in the root node. For single entries in the Limits array we only<br>
- wrote the single entry, in fact we should write that entry twice (!). The<br>
- value associated with each key in the EmbeddedFiles array had the dictionary<br>
- we needed stored inside another dictionary with a /FS key. EmbeddedFiles<br>
- were introduced in PDF 1.4, not PDF 1.2.<br>
-<br>
- This commit addresses all those problems, Adobe Acrobat Professional can<br>
- display the list of embedded files and (for embedded PDF files at least)<br>
- can open the embedded file.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfm.c<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-26 11:15:17 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e44c995bcc7a2aa6c32e23cb73fd532a93f5b1c">4e44c995bcc7a2aa6c32e23cb73fd532a93f5b1c</a>
-<blockquote>
-<p>
- Fix bug 689805: Use a clist for pages with transparency that need lots of RAM<br>
-<br>
- Devices that are not gx_device_printer class try to allocate full page bitmaps<br>
- for the stack of transparency buffers. This can kill performance or result in<br>
- VMerror during transparency stack pushes. Devices that are gx_device_printer<br>
- class automatically used clist mode, but other devices did not. Devices that<br>
- do not internally support clist mode are recognized by the return from<br>
- gxdso_supports_saved_pages device spec_op.<br>
-<br>
- A gx_device_printer device is used to accumulate the page, then when the<br>
- PDF14_POP_DEVICE is performed, the page is sent to the original device<br>
- as an image.<br>
-<br>
- NB, both the pdf14clist___ device and the pdf14___ device are kept in the<br>
- device chain since we have to be able to accomodate unwinding the gs_state<br>
- structure that may point to either as various &quot;restore&quot; ops occur.<br>
- Unfortunate, but until we come up with a way to fix the chain of compositors,<br>
- this is the best we can do.<br>
-<br>
- Move space_params to gx_device struct in order to allow non-printer devices<br>
- control over MaxBitmap, BufferSpace, BandBufferSpace, and BandHeight. The x11<br>
- device used MaxBitmap somewhat differently, so it now uses the space_params<br>
- value, and sets the default in its 'open' function, rather than the device<br>
- prototype. The duplicate 'page_uses_transparency' in space_params is removed,<br>
- and all devices have this as a parameter.<br>
-<br>
- Also, get rid if the nasty hacks for detecting pattern-clist devices based on<br>
- the device name, and export these for the pdf14 device and other clients.<br>
-<br>
- Finally, (unrelated) remove the #if 0 for testing with small memory on<br>
- large memory machines, and get rid of the the description of the '.' option<br>
- since this hasn't worked for years, and the command line options can readily<br>
- be set anyway.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevprn.h<br>
-gs/base/gsdparam.c<br>
-gs/base/gsptype1.c<br>
-gs/base/gsstate.c<br>
-gs/base/gstrans.c<br>
-gs/base/gxband.h<br>
-gs/base/gxclbits.c<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclist.h<br>
-gs/base/gxclpage.c<br>
-gs/base/gxclrast.c<br>
-gs/base/gxdevcli.h<br>
-gs/base/gxdevice.h<br>
-gs/base/gxpcmap.c<br>
-gs/base/gxpcolor.h<br>
-gs/base/lib.mak<br>
-gs/devices/gdevbit.c<br>
-gs/devices/gdevplib.c<br>
-gs/devices/gdevx.c<br>
-gs/devices/gdevx.h<br>
-gs/devices/gdevxini.c<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-29 17:32:04 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a91d2576df0e60f6e691a3bd967b51109ae41f22">a91d2576df0e60f6e691a3bd967b51109ae41f22</a>
-<blockquote>
-<p>
- pdfwrite - enable the EMBED pdfamrk<br>
-<br>
- Bug #690043 &quot;Can't create a pdf file with attachment&quot;<br>
-<br>
- This turned out to be more complex than I expected. I had planned to lever<br>
- off the /Dests code, but....<br>
-<br>
- It seems that our Named destinations support is only PDF 1.1. The specification<br>
- was changed ion PDF 1.2 to use a name tree instead of a simple dictionary<br>
- and we didn't alter our code. The EmbeddedFiles wasn't supported in PDF 1.1<br>
- so it has always needed a name tree.<br>
-<br>
- So in addition to adding the EMBED pdfmark, we now also will write a name<br>
- tree for Dests if the CompatibilityLevel is &gt; 1.1. Note that the 'tree'<br>
- we write is the simplest possible one and is likely to be sub-optimal, we<br>
- write all the entries in the root of the tree. However its legal and should<br>
- work, we can extend this later if needs be.<br>
-<br>
- I don't have a good way to test this, but the output looks OK by inspection<br>
- and we don't get any regressions.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfb.h<br>
-gs/devices/vector/gdevpdfm.c<br>
-gs/devices/vector/gdevpdfo.c<br>
-gs/devices/vector/gdevpdfo.h<br>
-gs/devices/vector/gdevpdfu.c<br>
-gs/devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-29 13:07:34 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2dae08db5c51c9a255b8d18ef011f75c4ee48e9f">2dae08db5c51c9a255b8d18ef011f75c4ee48e9f</a>
-<blockquote>
-<p>
- Fix non gcc DEBUG builds of pcl.<br>
-<br>
- Simple transposition of lines required.<br>
-<br>
-pcl/pcsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-28 17:21:48 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f471820635cbbaf4f7ed5c9185700ebb51378f0d">f471820635cbbaf4f7ed5c9185700ebb51378f0d</a>
-<blockquote>
-<p>
- PDF interpreter - attempt to recover from degenerate text matrix or CTM<br>
-<br>
- Some PDF files set a degenerate matrix or text matrix, eg<br>
-<br>
- 0 0 0 0 0 0 Tm<br>
-<br>
- This causes us a problem with currentpoint and .getpath, both of which<br>
- need to invert the CTM. If the CTM is all 0 then it (clearly) can't be<br>
- inverted.<br>
-<br>
- The code here emits a warning, in the case of settextposition it simply<br>
- does not advance the current point (which seems correct, since the text<br>
- will make no changes). In the case where we attempt to grestore (Q) but<br>
- preserving the current path, we drop the path and make a new path. This<br>
- may well not be correct, but its hard to see what would be.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-23 09:17: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=e46be795d1a682259ebcca3df2ad581150414adf">e46be795d1a682259ebcca3df2ad581150414adf</a>
-<blockquote>
-<p>
- epsi.ps - change two \r to \n<br>
-<br>
- Apparently gv has a bug and can't handle \r line endings.<br>
-<br>
- Bug #694968<br>
-<br>
- No differences expected.<br>
-<br>
-gs/lib/ps2epsi.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-23 09:09:48 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=03376079a8c05dd2224c057aaa95c508521ce784">03376079a8c05dd2224c057aaa95c508521ce784</a>
-<blockquote>
-<p>
- vector devices - add a warning message when OutputFile exceeds a limit<br>
-<br>
- Bug #694948<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gdevvec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-11 16:53:48 +0000
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49bb8200d6c92ddcd191026c0273f8bc229ad9e0">49bb8200d6c92ddcd191026c0273f8bc229ad9e0</a>
-<blockquote>
-<p>
- Bug 694873: bare JPEG2000 images without JP2 header in pdf.<br>
-<br>
- To cope with JPEG2000 images without JP2 headers.<br>
-<br>
- This change is essentially the corresponding change in mupdf<br>
- (https://code.google.com/p/sumatrapdf/issues/detail?id=937 ,<br>
- http://bugs.ghostscript.com/show_bug.cgi?id=691346 ,<br>
- test file 937_-_openjpeg_cannot_decode_JP2_structure.pdf),<br>
- where one takes a peek at the first few bytes of the stream<br>
- before setting the decoding parameters; with the caveat that<br>
- in ghostcript, we need to delay most of the stream<br>
- initialization - and allocation of resources - until<br>
- after seeing the first few bytes, and therefore also<br>
- not necessarily de-allocate at stream close.<br>
-<br>
- The cluster test file, openjpeg_166_-_buffer_overflow.pdf,<br>
- (https://code.google.com/p/openjpeg/issues/detail?id=166)<br>
- is of the same issue.<br>
-<br>
- EXPECTED DIFFERENCES:<br>
- 937_-_openjpeg_cannot_decode_JP2_structure.pdf<br>
- openjpeg_166_-_buffer_overflow.pdf<br>
- (Both are progressions.)<br>
-<br>
-gs/base/sjpx_openjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-22 22:06:51 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5d6b18aa6a2a4ece4854ed9af074bb65f41af293">5d6b18aa6a2a4ece4854ed9af074bb65f41af293</a>
-<blockquote>
-<p>
- Set correct portrait/landscape orientation on PCL 5c/e output<br>
-<br>
- Fixes bug #693715.<br>
-<br>
-gs/devices/gdevdjet.c<br>
-gs/devices/gdevdljm.c<br>
-gs/devices/gdevpcl.c<br>
-gs/devices/gdevpcl.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-20 13:18:23 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c699e89a897b85d2f1f0a07ecac8d64b53500804">c699e89a897b85d2f1f0a07ecac8d64b53500804</a>
-<blockquote>
-<p>
- pdfwrite - fix xref when eliding duplicate patterns<br>
-<br>
- commit fe99ca5fd2e3b191a76c7f7d791b72f3603e9fea detected duplicate shading<br>
- patterns, and did not emit them into the PDF file, instead using the first<br>
- definition. Unfortunately, due to a mis-understanding of the existing code<br>
- the xref entry remained assigned, which led to invalid xref tables<br>
- being written.<br>
-<br>
- This commit fixes the xref, and adds some (hopefully useful) comments to<br>
- the relevant functions to try and avoid a repetition.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdfu.c<br>
-gs/devices/vector/gdevpdfv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-17 12:37:24 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=54927dd449c476b5a8c125e9beb1fbe06bebc45e">54927dd449c476b5a8c125e9beb1fbe06bebc45e</a>
-<blockquote>
-<p>
- Fix 694951 - No output produced.<br>
-<br>
- Allow the HPGL/2 command &quot;PG&quot; to initialize the GL/2 parser at the<br>
- beginning of a job.<br>
-<br>
-pcl/pcparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-15 02:00:12 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b13ef732907219b48757e2f501486f71b9f21030">b13ef732907219b48757e2f501486f71b9f21030</a>
-<blockquote>
-<p>
- Bug 694893: prevent overflow in opj_int_ceildivpow2<br>
-<br>
- This can be seen e.g. in:<br>
-<br>
- 4241ac039aba57e6a9c948d519d94216_asan_heap-oob_14650f2_7469_602.pdf<br>
-<br>
- Thanks to Mateusz Jurczyk and Gynvael Coldwind of the Google Security<br>
- Team for providing the example files.<br>
-<br>
-gs/openjpeg/libopenjpeg/opj_intmath.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-14 23:11:43 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5b0c9985e3359aca9b3fcfd94424166aa61a141a">5b0c9985e3359aca9b3fcfd94424166aa61a141a</a>
-<blockquote>
-<p>
- Bug 694880: fix write access violation in opj_j2k_add_tlmarker<br>
-<br>
- A tile_index' current_tpsno may be far larger than the number of tile<br>
- parts because opj_j2k_read_sot increases that number just by 10 instead<br>
- of growing it to the actually required size.<br>
-<br>
- This can be seen e.g. in:<br>
-<br>
- 147af3f1083de4393666b7d99b01b58b_signal_sigsegv_130c531_6155_5136.pdf<br>
-<br>
- Thanks to Mateusz Jurczyk and Gynvael Coldwind of the Google Security<br>
- Team for providing the example files.<br>
-<br>
-gs/openjpeg/libopenjpeg/j2k.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-14 22:45:49 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7366747076f3b75def52079bd4d5021539a16394">7366747076f3b75def52079bd4d5021539a16394</a>
-<blockquote>
-<p>
- Bug 694949: prevent denial of service with arithmetic decoding<br>
-<br>
- Badly constructed Jbig2 images using arithmetic decoding may result in<br>
- a denial of service attack by causing huge images to be created and<br>
- initialized from no data at all (at EOS, the arithmetic decoder always<br>
- returns the same values instead of failing).<br>
-<br>
- Two cases are prevented with this patch:<br>
- * huge generic regions with barely any data to decode it from<br>
- * a huge list of height classes with no data at all to decode it from<br>
-<br>
- This can be seen e.g. in:<br>
-<br>
- b534b5caad95dd405735ec9a079fd43b_asan_heap-oob_14bf3ce_6977_5690.pdf<br>
-<br>
- Thanks to Mateusz Jurczyk and Gynvael Coldwind of the Google Security<br>
- Team for providing the example files.<br>
-<br>
-gs/jbig2dec/jbig2_arith.c<br>
-gs/jbig2dec/jbig2_arith.h<br>
-gs/jbig2dec/jbig2_generic.c<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-17 09:35: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=24dce021d5f774dd4264011cbd64bb4afb5aa51c">24dce021d5f774dd4264011cbd64bb4afb5aa51c</a>
-<blockquote>
-<p>
- PDF interpreter - Don't set UseCIEColor unless actually required.<br>
-<br>
- The PDF specification says that if a PDF file contains a page which uses<br>
- a ColorSpace Resource of DefautlGray, DefaultRGB or DefaultCMYK then this<br>
- should be regarded as a &quot;request that such colors be systematically<br>
- transformed (remapped) into device-independent CIE-based color spaces.&quot;.<br>
- Essentially the PDF equivalent of UseCIEColor.<br>
-<br>
- This does rather beg the question of why not specify the colours in a<br>
- device-independent space in the first place.....<br>
-<br>
- In any event, in order to achieve this the PDF interpreter pulls some<br>
- tricks. We start by defining the Default* resources as the equivalent<br>
- Device* spaces and *always* define UseCIEColor to true. Thus whenever<br>
- we set a device color space the colour machinery tries to use instead the<br>
- appropriate Device* space. Because the color space machinery has an<br>
- optimisation to jump straight out when the requested space is the same as<br>
- the current space, this means that the UseCIEColor transformation should<br>
- have no effect.<br>
-<br>
- However, pdfwrite now emits a warning if UseCIEColor is true, so we want<br>
- to avoid unconditionally setting UseCIEColor (I also find it horrifying that<br>
- we do this terrible hackery).<br>
-<br>
- This commit borrows code used to set the Default* spaces if they exist on<br>
- a page, and uses it to detect such spaces before we call setpagedevice<br>
- for each page. We now only set UseCIEColor if the page actually uses one<br>
- of the Default* spaces and therefore requires it.<br>
-<br>
- I did consider trying to substitute the defined colour space with the<br>
- Default* space whenever a colour space definition takes place and a Default*<br>
- space is defined, but gave up as there were simply too many places where<br>
- color spaces could be defined.<br>
-<br>
- This code does (somewhat unexpectedly) produce some differences.<br>
- These are either progressions or very tiny differences, and I feel that<br>
- *not* setting UseCIEColor should be preferable anyway. (The real puzzle<br>
- is why some PostScript files seem to differ, but they only differ when<br>
- sent to pdfwrite and the PDF is then interpreed. Looks like UseCIEColor<br>
- has some strange behaviour with ICCBased spaces).<br>
-<br>
- with pdfwrite:<br>
- altona_technical_1v2_x3.pdf - very minor colour shift<br>
- altona_technical_v20_x4 - progression on page 7<br>
- 09-31.ps - difference in gray ramp in CIE space<br>
- 09-34.ps - indetectable differences in some CIE colours<br>
-<br>
- all devices:<br>
- Bug692783.pdf - indetectable shits in background<br>
- Catx5720.pdf - slight colour shifts in 3 graphics<br>
- 1021_-_transparency-issue.pdf - tiny colour shifts<br>
- 1141_-_background_shading_cropped.pdf - tiny colour shifts<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-14 20:09:53 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ec1c4adcc5fab850e4038c4d5392adddd265c67e">ec1c4adcc5fab850e4038c4d5392adddd265c67e</a>
-<blockquote>
-<p>
- Bug 694871: move libjpeg away from gc memory<br>
-<br>
- Change the libjpeg interface code to use a chunk allocator instead of garbage<br>
- collected, &quot;unstable&quot; memory.<br>
-<br>
- Previously, the libjpeg integration used &quot;Postscript&quot; memory, that is, memory<br>
- that is subject to garbage collection and save/restore operations.<br>
-<br>
- This means that Postscript like:<br>
- /In (file) (r) file /DCTDecode filter def<br>
- save<br>
- &lt;&lt;<br>
- ...<br>
- /ImageSource In<br>
- ...<br>
- &gt;&gt; image<br>
- restore<br>
- In closefile<br>
-<br>
- would almost certainly cause a crash, since the memory allocated by libjpeg<br>
- during the decoding for the &quot;image&quot; operator would be freed by the &quot;restore&quot;<br>
- operator, *before* the &quot;closefile&quot; destroyed the filter stream and the<br>
- libjpeg context.<br>
-<br>
- If we opt to always wrap the &quot;default&quot; heap allocator in a chunk allocator<br>
- then we should probably remove the chunk allocator instances created<br>
- specifically for libjpeg.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsstruct.h<br>
-gs/base/lib.mak<br>
-gs/base/sdct.h<br>
-gs/base/sdctc.c<br>
-gs/base/sdctd.c<br>
-gs/base/sdcte.c<br>
-gs/base/sjpegc.c<br>
-gs/devices/vector/gdevpsdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-15 12:54: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=c95dd5ba2cfd9b36aa3a18e7725089a741b7fa70">c95dd5ba2cfd9b36aa3a18e7725089a741b7fa70</a>
-<blockquote>
-<p>
- Have DSC parser use GS memory handling<br>
-<br>
- The DSC parser was using it's own default memory alloc/free functions which<br>
- just called the libc malloc/free.<br>
-<br>
- This tweaks our integration code so the parser will use the Ghostscript memory<br>
- management functions.<br>
-<br>
- There are no changes to the parser code, the changes are entirely confined to<br>
- integrating the parser with our PS interpreter.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zdscpars.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-09 23:05:43 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8ec8321df613986e8642e2975f7182072eb4be62">8ec8321df613986e8642e2975f7182072eb4be62</a>
-<blockquote>
-<p>
- make opj_stream_set_user_data accept a NULL stream<br>
-<br>
- ... for consistency with opj_stream_set_* which does so.<br>
-<br>
-gs/openjpeg/libopenjpeg/cio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-09 22:56:54 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d6121c78a0fc6c8cd87c6495e11d327068518c35">d6121c78a0fc6c8cd87c6495e11d327068518c35</a>
-<blockquote>
-<p>
- prevent assertion under MSVC on impossibly large allocations<br>
-<br>
- MSVC's debug CRT asserts that arguments to malloc and realloc aren't<br>
- impossibly large (close to (size_t)-1) which makes testing fuzzed files<br>
- impossible with assertions enabled.<br>
-<br>
- Problem found in a test file, 2236.pdf.asan.40.1376 supplied<br>
- by Mateusz &quot;j00ru&quot; Jurczyk and Gynvael Coldwind of the Google<br>
- Security Team using Address Sanitizer. Many thanks!<br>
-<br>
-gs/openjpeg/libopenjpeg/opj_malloc.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-09 22:54:36 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=87b08a096bb8ad61f9dbe4811e208d9c9d7fe63b">87b08a096bb8ad61f9dbe4811e208d9c9d7fe63b</a>
-<blockquote>
-<p>
- don't define lrintf for MSVC 2013 (fix compilation breakage)<br>
-<br>
-gs/openjpeg/libopenjpeg/opj_includes.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-09 23:04:38 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0f07c3247cc9211e57bb5429634f79c8c762fbfa">0f07c3247cc9211e57bb5429634f79c8c762fbfa</a>
-<blockquote>
-<p>
- fix error message in opj_jp2_read_colr<br>
-<br>
-gs/openjpeg/libopenjpeg/jp2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-09 22:46:48 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f4b1565c10fe6faa7ed3854a7fa3cd0a6e18511">2f4b1565c10fe6faa7ed3854a7fa3cd0a6e18511</a>
-<blockquote>
-<p>
- tweak commit 66d9c0aa17a5abcecd6590e63f0620f7aa51634c<br>
-<br>
- The fix for testcase 1336.pdf.asan.47.376 for bug 694311 was slightly<br>
- too strict: The access violation only happens during the MCT decoding<br>
- step which might be skipped for some images. This patch moves the test<br>
- into opj_tcd_mct_decode to only apply when it's actually required<br>
- (which should allow j2kp4-file3-ycc-8bpc.pdf to be read without errors<br>
- inside openjpeg itself and leaves handling of components of different<br>
- sizes to the calling application/library).<br>
-<br>
-gs/openjpeg/libopenjpeg/tcd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-09 22:40:39 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0eedf7c22a76f089bbe13d76496ae56de38dfbef">0eedf7c22a76f089bbe13d76496ae56de38dfbef</a>
-<blockquote>
-<p>
- tweak commit 99a6f1af177c15f4db475186b79d169c993494ef<br>
-<br>
- Error messages should go to stderr instead of stdout so that tools such<br>
- as mudraw -t don't get stdout polluted.<br>
-<br>
-gs/openjpeg/libopenjpeg/t2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-09 22:35:38 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fc884aee2b69c78500e65c3d05bf216791a9ea4a">fc884aee2b69c78500e65c3d05bf216791a9ea4a</a>
-<blockquote>
-<p>
- prevent heap overflow in opj_t2_read_packet_header<br>
-<br>
- Also prevent a double-free of segment data under OOM conditions.<br>
-<br>
- Problem found in a test file, 1802.pdf.SIGSEGV.36e.894 supplied<br>
- by Mateusz &quot;j00ru&quot; Jurczyk and Gynvael Coldwind of the Google<br>
- Security Team using Address Sanitizer. Many thanks!<br>
-<br>
-gs/openjpeg/libopenjpeg/t2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-09 22:32:37 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83dad6a76536222a3a51146f942e733a2e90ec52">83dad6a76536222a3a51146f942e733a2e90ec52</a>
-<blockquote>
-<p>
- fix potential NULL-pointer dereference<br>
-<br>
- ... caused by testing the wrong variable after opj_realloc<br>
- (happens only in OOM situations)<br>
-<br>
-gs/openjpeg/libopenjpeg/jp2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-23 00:00:32 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dafa1945a18e79578335693a4e4c6247e2617ee2">dafa1945a18e79578335693a4e4c6247e2617ee2</a>
-<blockquote>
-<p>
- jbig2dec: tweak overflow check in jbig2_(re)alloc<br>
-<br>
- If num * size overflows under x64, the value may be negative and still<br>
- fit into a 32-bit integer. The proper check unfortunately requires a<br>
- division.<br>
-<br>
- Note: The maximum allowed allocation is (size_t)-0x100 instead of<br>
- SIZE_MAX so that debug CRTs which check for the allocation of e.g.<br>
- (size_t)-1 never assert.<br>
-<br>
-gs/jbig2dec/jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-10 22:56:52 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5eaf740b2c02523ae2ae6454e546cb6700d4e3f3">5eaf740b2c02523ae2ae6454e546cb6700d4e3f3</a>
-<blockquote>
-<p>
- Bug 694892: buffer overrun in jbig2_comment_ascii<br>
-<br>
-gs/jbig2dec/jbig2_metadata.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-10 22:30:16 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8b82970325b2bd9aa993aa16c214a915ec8210e3">8b82970325b2bd9aa993aa16c214a915ec8210e3</a>
-<blockquote>
-<p>
- follow-up to 8e2f00f15c988d75a4182ecdcdc1a82b4686ef92<br>
-<br>
- This might fix bug 694903.<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-12 22:12:35 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cddfd67f2df1863f8b06770e80e7c97bf970ccbb">cddfd67f2df1863f8b06770e80e7c97bf970ccbb</a>
-<blockquote>
-<p>
- Bug 694882: sanitize component mappings<br>
-<br>
- PCLR, CMAP and CDEF data aren't properly sanitized - even after the<br>
- fixes from the last fuzzing round. This patch unifies all the required<br>
- checks in a new function opj_jp2_check_color which is invoked before<br>
- the cdef and cmap values are used.<br>
-<br>
- This can be seen e.g. in:<br>
-<br>
- 66ea31acbb0f23a2bbc91f64d69a03f5_signal_sigsegv_13937c0_7030_5725.pdf<br>
-<br>
- Thanks to Mateusz Jurczyk and Gynvael Coldwind of the Google Security<br>
- Team for providing the example files.<br>
-<br>
-gs/openjpeg/libopenjpeg/jp2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-09 22:20:37 +0100
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f4139d702559649e577a5df9cfd64b0ca6107a7a">f4139d702559649e577a5df9cfd64b0ca6107a7a</a>
-<blockquote>
-<p>
- don't ignore buffer sizes<br>
-<br>
- Several functions accept a buffer size but never actually check whether<br>
- the buffer overflows during reading/writing. This fixes all cases where<br>
- a size variable has explicitly been marked as unused (through a (void)<br>
- cast).<br>
-<br>
- This was discovered while investigating an assertion caused by<br>
- 7cc691f332f26802c64cdc47e17bff8b_signal_sigabrt_7ffff6d59425_2247_2509.pdf<br>
- among others.<br>
-<br>
- Thanks to Mateusz Jurczyk and Gynvael Coldwind of the Google Security<br>
- Team for providing the example files.<br>
-<br>
-gs/openjpeg/libopenjpeg/event.c<br>
-gs/openjpeg/libopenjpeg/jp2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-10 11:45:16 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c5cd8c29271d8735349353538c4a353f3aa563b">2c5cd8c29271d8735349353538c4a353f3aa563b</a>
-<blockquote>
-<p>
- Debug option &quot;-ZI&quot; results improved or corrected with the goal of<br>
- creating output that can be reassembled back into PCL.<br>
-<br>
- We have an assembler and disassembler for PXL: pxlasm.py, pxldis.py,<br>
- but they do not support PCL. For PCL we will use the GhostPCL<br>
- interpreter with -ZI and an upcoming Python program will read that<br>
- output and reassemble back to PCL.<br>
-<br>
-pcl/pccid.c<br>
-pcl/pcdither.c<br>
-pcl/pclookup.c<br>
-pcl/pcommand.c<br>
-pcl/pcommand.h<br>
-pcl/pcpage.c<br>
-pcl/pcparse.c<br>
-pcl/pcpatrn.c<br>
-pcl/pcsfont.c<br>
-pcl/pcsymbol.c<br>
-pcl/pctext.c<br>
-pcl/pcuptrn.c<br>
-pcl/pglabel.c<br>
-pcl/pgparse.c<br>
-pcl/pgvector.c<br>
-pcl/rtmisc.c<br>
-pcl/rtraster.c<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-11 11:44: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=4a267d719148abf961f479ba6c9024bfa2c18bf5">4a267d719148abf961f479ba6c9024bfa2c18bf5</a>
-<blockquote>
-<p>
- pdfwrite - limit scan line comparison to actual width<br>
-<br>
- Bug #694930 &quot;Valgrind issues found by fuzzing in compute_subimage (gdevpdfd.c:707)&quot;<br>
-<br>
- The local image converter, and specifically mask to clip conversion,<br>
- compare consecutive scan lines of an image to see if they are identical.<br>
-<br>
- However, they were using the width of the allocated raster, which can include<br>
- alignment padding, rather then the actual width of the image data. This<br>
- meant we were comparing uninitialised data. In this case its actually safe<br>
- as we would simply create a more complex clip than required, but its<br>
- definitely sub-optimal.<br>
-<br>
- This commit changes the comparison to use the number of bits in the image,<br>
- rounded up to the nearest byte.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-09 16:08: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=20f6eb7d946cda9bd6b141881d1abd13daec911e">20f6eb7d946cda9bd6b141881d1abd13daec911e</a>
-<blockquote>
-<p>
- More error checking when copying fonts<br>
-<br>
- Bug #694263 is again a fuzzing bug declared to demonstrate Valgrind errors<br>
- which for me causes a seg fault.<br>
-<br>
- This again appears to be due to a broken TrueType font. The additional<br>
- checking in this commit resolves the problem for me.<br>
-<br>
-gs/devices/gxfcopy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-09 12:04:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49a05084feee92818347fbf888fc2ab784b82122">49a05084feee92818347fbf888fc2ab784b82122</a>
-<blockquote>
-<p>
- pdfwrite - initialise some variables to pacify valgrind<br>
-<br>
- Bug #694236 does not give the valgrind warnings described in the bug<br>
- report for me, but did complain about the character widths. It seems<br>
- that somehow (broken font ?) the values were uninitialised. Here we just<br>
- set them to 0.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-09 11:13:02 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e9a574ec0e6d13fcf898a7132ce08476af4ea84d">e9a574ec0e6d13fcf898a7132ce08476af4ea84d</a>
-<blockquote>
-<p>
- Don't attempt to copy a missing glyph when copying fonts<br>
-<br>
- Bug #694236 for me does not (initially at least) cause a Valgrind warning,<br>
- but does cause a seg fault.<br>
-<br>
- The problem is that we have a (presumably broken) TrueType font where we<br>
- try to enumerate all the glyphs in the font. The enumeration code returns<br>
- a GS_NO_GLYPH, but the font copying code doesn't catch that, and so tries<br>
- to copy that glyph. This causes a crash in the name lookup.<br>
-<br>
- The commit here simply adds an additional check that the glyph is not<br>
- 'GS_NO_GLYPH', if it is we treat it as an error.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/gxfcopy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-09 08:19:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb42d237028c3fd832664c5e1479483a430f5ed9">eb42d237028c3fd832664c5e1479483a430f5ed9</a>
-<blockquote>
-<p>
- DSC parser - silence a compiler warning with a cast<br>
-<br>
-gs/psi/dscparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-08 10:57:46 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b2ecdbba02eac6fa19866bd18c83ece7cdd4074d">b2ecdbba02eac6fa19866bd18c83ece7cdd4074d</a>
-<blockquote>
-<p>
- Possible fix for 694837.<br>
-<br>
- Allow the luratech jbig2 encoder to process 0 input without error like<br>
- all other streams encoders. Analysis by Ken Sharp.<br>
-<br>
-gs/base/sjbig2_luratech.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-08 16:12:53 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=32df3bf46606f697d7deae86211c897be63a0764">32df3bf46606f697d7deae86211c897be63a0764</a>
-<blockquote>
-<p>
- DSC parser - reset scanning at end of job<br>
-<br>
- Currently the DSC parser never leaves 'scan_trailer', which is fine for<br>
- one-job-at-a-time usage, but not good for job server or multiple inputs.<br>
-<br>
- This commit modifies the scan-trailer condition so that if a new DSC header<br>
- is encountered, *after* we've found a trailer, we reset some aspects of the<br>
- DSC parsing.<br>
-<br>
- Note that this doesn't completely reset the parser as that caused memory<br>
- problems.<br>
-<br>
- Bug #692208<br>
-<br>
- No differences expected<br>
-<br>
-gs/psi/dscparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-08 08:26:14 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cbeeef7f54bd183515f81d42176a049a7f7703a2">cbeeef7f54bd183515f81d42176a049a7f7703a2</a>
-<blockquote>
-<p>
- pdfwrite - add a warning if -dUseCIEColor is set<br>
-<br>
- With the current color management its not really sensible to set UseCIEColor<br>
- (which was always a horrible hack anyway) in order to do color conversion<br>
- or management.<br>
-<br>
- So if we see this being done, show the user a warning. We don't want to<br>
- raise an error as someone will undoubtedly complain that they have a good<br>
- reason for using UseCIEColor with pdfwrite.....<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-01 20:32:49 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=13b8f94c86efc4b98c7d63774b761bad9783f16c">13b8f94c86efc4b98c7d63774b761bad9783f16c</a>
-<blockquote>
-<p>
- Enable the pdf14 optimization. Previous commit only collected data.<br>
-<br>
- Somehow, the previous commit that collected the data didn't actually<br>
- skip pdf14 transparency on any bands. Also testing showed that fiils<br>
- with patterns that needed transparency were not being detected.<br>
-<br>
- We need to save the page mode pdf14_needed state based on the blend_mode<br>
- and opacity to restore to the correct setting after smask or transpacrency<br>
- group pushes.<br>
-<br>
- Lastly, we punt if the device is not contone, since the colors written<br>
- for bands will be contone which are not compatible with the target.<br>
-<br>
- Correct the pdf14_opmode_names to add in the missing PDF14_ABORT_DEVICE.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gstrans.h<br>
-gs/base/gxclist.h<br>
-gs/base/gxclpath.c<br>
-gs/base/gxclrast.c<br>
-gs/base/gxclread.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-06 14:29:14 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b86a214d542a91e526599aaadd2e68d896c1edff">b86a214d542a91e526599aaadd2e68d896c1edff</a>
-<blockquote>
-<p>
- pdfwrite - fix another memory allocator<br>
-<br>
- After the previous problem caused by using the non-stable memory allocator<br>
- I reviewed all use of this allocator and nonticed that in this case we<br>
- allocate using the stable allocator, but were freeing it using the non-stable<br>
- allocator.<br>
-<br>
- This probably only leaks memory but its best to fix it.<br>
-<br>
-gs/devices/vector/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-06 14:27:37 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=465eb2d291a92c8eda46c090c70594b4ef8f0fba">465eb2d291a92c8eda46c090c70594b4ef8f0fba</a>
-<blockquote>
-<p>
- pdfwrite - add a comment explaining about pdev-&gt;pdf_mewmory<br>
-<br>
-gs/devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-06 14:27:01 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=18f35e567b9e6760bf60a1f4c04b725cd343d5a9">18f35e567b9e6760bf60a1f4c04b725cd343d5a9</a>
-<blockquote>
-<p>
- pdfwrite - minor memory issue<br>
-<br>
- Noticed while reviewing other problems, we didn't check to see if a memory<br>
- allocation was successful, and also; if a subsequent fread() failed we would<br>
- not free the allocated memory.<br>
-<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-06 14:25:06 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba099db2df6867215178b7cfc1065eb921105d66">ba099db2df6867215178b7cfc1065eb921105d66</a>
-<blockquote>
-<p>
- pdfwrite - squelch a compiler warning<br>
-<br>
- undefine PDF_FOR_EPS2WRITE to prevent compiler complaning its redefined.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2014-01-06 10:39:41 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ecf24042611a96c9d5560ccec845f3b2e4d70b38">ecf24042611a96c9d5560ccec845f3b2e4d70b38</a>
-<blockquote>
-<p>
- pdfwrite - use stable memory for the outline tree<br>
-<br>
- Bug #694868 &quot;Regression: seg faults starting with 0790b03698b27dcf342e0175d2f833c921b5dab2&quot;<br>
-<br>
- The move of the outline tree to a dynamic allocation instead of static<br>
- accidentally used memory subject to save and restore instead of stable<br>
- memory. Oddly this only caused problems on the Linux debug build.<br>
-<br>
- This commit moves the allocation to stable memory which I *believe* will<br>
- solve the problem. NB Chris is going to alter the allocation code so that<br>
- a debug build will flag this sort of problem up.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-30 12:50:40 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d4e6b106c336b8ae7db87f4bec6e0afb6993b687">d4e6b106c336b8ae7db87f4bec6e0afb6993b687</a>
-<blockquote>
-<p>
- Fixes for issues with the use of DeviceN source profiles<br>
-<br>
- GC definitions were wrong for some of the structures and also name allocation size was wrong.<br>
- Fixes bug 694865<br>
-<br>
-gs/base/gsicc_lcms.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-20 18:19: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=6700dbf0d426ba8d6a707d639159b5b8db00a95c">6700dbf0d426ba8d6a707d639159b5b8db00a95c</a>
-<blockquote>
-<p>
- Pass on an error code rather than ignore it.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-22 23:22:42 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=17f0dfaf200163d7207f27f3cc34e0a1cf843203">17f0dfaf200163d7207f27f3cc34e0a1cf843203</a>
-<blockquote>
-<p>
- Add missing case for UNKNOWN color space in transparency group.<br>
-<br>
- This is used when the the new group did not specify a color space. We<br>
- were incorrectly returning an error. There is no error. The UNKNOWN<br>
- information is stored in the clist and when we later get the UNKNOWN<br>
- information we known to just keep the current color space.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-23 10:30: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=72713e784ddaea275498a67e25ab77aedbc0eb9b">72713e784ddaea275498a67e25ab77aedbc0eb9b</a>
-<blockquote>
-<p>
- Fix bug 69365: Write pattern colors to all bands consistently for images.<br>
-<br>
- Thanks to Michael Vrhel for tracking this down. If a transparent pattern<br>
- color is written to all bands after having been written to a band for<br>
- an image, the transparency fill_trans_buffer will be NULL because the<br>
- group for the image was pushed at 'begin_typed_image' time. We now write<br>
- the color to all_bands based on the image extent, consistently.<br>
-<br>
-gs/base/gxcldev.h<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-23 15:45:23 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0790b03698b27dcf342e0175d2f833c921b5dab2">0790b03698b27dcf342e0175d2f833c921b5dab2</a>
-<blockquote>
-<p>
- pdfwrite - convert outline tree to dynamic storage<br>
-<br>
- Bug #690429 &quot;convert outline tree from static array to dynamic list&quot;<br>
-<br>
- In the past the outline tree in pdfwrite was a hard coded array with a<br>
- maximum depth of 31. This array is now dynamically allocated, so the depth<br>
- is limited only by available memory.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfb.h<br>
-gs/devices/vector/gdevpdfm.c<br>
-gs/devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-20 17:54:42 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3574d5254bd93dc2b002f93de120043990c3fcda">3574d5254bd93dc2b002f93de120043990c3fcda</a>
-<blockquote>
-<p>
- Remove mistakenly added files.<br>
-<br>
-clustercmd<br>
-clusterdatestamp<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-18 07:56:31 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6f8bb99dae2db541b7941d65816581137990be6d">6f8bb99dae2db541b7941d65816581137990be6d</a>
-<blockquote>
-<p>
- Temp debug patch<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gsptype1.c<br>
-gs/base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-20 15:31:10 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dcb60221c23d33e65ed2193f1f0e6355f06c12ab">dcb60221c23d33e65ed2193f1f0e6355f06c12ab</a>
-<blockquote>
-<p>
- Add more error handling missing from pdf14.<br>
-<br>
-gs/base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-20 15:27: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=d355b00b5915697904a2c0f8a2334050d2c1bf32">d355b00b5915697904a2c0f8a2334050d2c1bf32</a>
-<blockquote>
-<p>
- Bug 694858: Add some missing error handling.<br>
-<br>
- This solves at least some of the SEGVs.<br>
-<br>
-clustercmd<br>
-clusterdatestamp<br>
-gs/base/gstrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-20 10:05:58 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba28d0f50d9de48d8961f93044b5dac8139312f2">ba28d0f50d9de48d8961f93044b5dac8139312f2</a>
-<blockquote>
-<p>
- pdfwrite - update element linked list before freeing element in cos dicts<br>
-<br>
- Bug 694854 &quot;Converting pdf to PDFX standard crashes ghostscript right before the end&quot;<br>
-<br>
- When creating a PDF/X file the code deletes any BleedBox, TrimBox, ArtBox<br>
- entries from the page dictionary after writing them (ho idea why...) using<br>
- the cos_dict_delete() function.<br>
-<br>
- The function frees the memory, and then updates the linked list of elements<br>
- in the dictionary, however it updates the list after freeing the memory. If<br>
- the free memory pointed to should alter before the linked list is updated,<br>
- then the list will be updated with garbage.<br>
-<br>
- Updating the linked list *before* freeing the memory is a much better way<br>
- to proceed.<br>
-<br>
- Because this is only called when creating PDF/X files, no differences are<br>
- expected.<br>
-<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-19 22:30:39 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=615059129740d77fac1db1bbec4a79958d88e3bf">615059129740d77fac1db1bbec4a79958d88e3bf</a>
-<blockquote>
-<p>
- Fixed line conibuation typos in previous commit (d997bc4)<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-19 00:41:19 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=77eb4f71f15365c713f1fec698a87203afaaf984">77eb4f71f15365c713f1fec698a87203afaaf984</a>
-<blockquote>
-<p>
- Add some error checking to pdf14.<br>
-<br>
- When we record an error code, ensure we check it.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-19 12:32: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=3c913314883114d671d550e5db9efa2192241040">3c913314883114d671d550e5db9efa2192241040</a>
-<blockquote>
-<p>
- Only issue the &quot;unbalanced q/Q&quot; warning once per page.<br>
-<br>
- Write a flag to the pdfdict to indicate that we've already issued the warning<br>
- and skip it from then on for the current page. Reset flag at the end of the<br>
- page.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-19 17:03:39 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d997bc49531613205e055c8e4e25d93bb4c762e6">d997bc49531613205e055c8e4e25d93bb4c762e6</a>
-<blockquote>
-<p>
- Added &quot;pwgraster&quot; output device<br>
-<br>
- The &quot;pwgraster&quot; output device rasterizes the input into the PWG Raster<br>
- format, an industry-standarized raster format for printers, especially<br>
- the upcoming IPP Everywhere network printers which are supposed to<br>
- work with any hardware-model-specific software (drivers). As PWG<br>
- Raster is derived from CUPS Raster it is generated by the &quot;cups&quot;<br>
- output device, but calling it with the &quot;pwgraster&quot; name makes it<br>
- generating PWG Raster instead of CUPS Raster.<br>
-<br>
-gs/configure.ac<br>
-gs/cups/gdevcups.c<br>
-gs/devices/devs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-19 09:40:01 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=81b246414c4624cf476793c2590201de408ea33a">81b246414c4624cf476793c2590201de408ea33a</a>
-<blockquote>
-<p>
- pdfwrite - don't allocate multiple object IDs for shadings<br>
-<br>
- Bug #694853 &quot;PDF/A generation does not fix all errors&quot;<br>
-<br>
- When the code to detect and elide duplicate shadings was added we used the<br>
- pdf_substitute_resource function to detect duplicates and drop the new one.<br>
-<br>
- However this function *always* assigned a new object ID if it wasn't a<br>
- duplicate, which leaves the original ID dangling (if the object already had<br>
- one). This commit simply avoids creating a new ID if the object is not a<br>
- duplicate, and already has an ID.<br>
-<br>
- I'm a little nervous about this one, but a cluster push seems to be OK. No<br>
- differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-18 18:43:56 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1a25414344c0a2c3b9c8947ad120d34845ecb387">1a25414344c0a2c3b9c8947ad120d34845ecb387</a>
-<blockquote>
-<p>
- Bug 693365: Add find_pdf14_device function, and use it.<br>
-<br>
- This seems to solve the problem with simple6.pdf at least.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gsicc_monitorcm.c<br>
-gs/base/gspaint.c<br>
-gs/base/gxdevsop.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-18 15:26:49 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36f97ff44c7e94d1cf033a6495f2876b1976ca66">36f97ff44c7e94d1cf033a6495f2876b1976ca66</a>
-<blockquote>
-<p>
- Bug 694258: Allow for floating point inaccuracies in pattern code.<br>
-<br>
- When calculating the regions 'touched' by pattern repeats, allow for<br>
- inaccuracies in the floating point calculations.<br>
-<br>
-gs/base/gsptype1.c<br>
-gs/base/math_.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-18 15:06:17 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b0cbadbbb03dffbf5f9ec9e72658f59e0e59238a">b0cbadbbb03dffbf5f9ec9e72658f59e0e59238a</a>
-<blockquote>
-<p>
- Remove floatp references in docs.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/doc/C-style.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-18 14:53: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=cf009c80c4a371ad64cc5c0444d72902657dbfce">cf009c80c4a371ad64cc5c0444d72902657dbfce</a>
-<blockquote>
-<p>
- Replace the &quot;floatp&quot; with &quot;double&quot;<br>
-<br>
- For historic reasons, floating point parameters used the type &quot;floatp&quot; which<br>
- was actually typedef'ed to &quot;double&quot;.<br>
-<br>
- To reduce confusion, we now use &quot;double&quot; directly.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-gs/base/gdevdcrd.c<br>
-gs/base/gdevdflt.c<br>
-gs/base/gdevvec.c<br>
-gs/base/gdevvec.h<br>
-gs/base/gsalpha.c<br>
-gs/base/gsalpha.h<br>
-gs/base/gscdevn.c<br>
-gs/base/gschar.c<br>
-gs/base/gschar.h<br>
-gs/base/gscie.c<br>
-gs/base/gscie.h<br>
-gs/base/gsciemap.c<br>
-gs/base/gscolor.c<br>
-gs/base/gscolor.h<br>
-gs/base/gscolor1.c<br>
-gs/base/gscolor1.h<br>
-gs/base/gscolor3.c<br>
-gs/base/gscolor3.h<br>
-gs/base/gscoord.c<br>
-gs/base/gscoord.h<br>
-gs/base/gscpixel.c<br>
-gs/base/gscrd.c<br>
-gs/base/gscrdp.c<br>
-gs/base/gsdevice.c<br>
-gs/base/gsdparam.c<br>
-gs/base/gsdps1.c<br>
-gs/base/gsfont.c<br>
-gs/base/gsfont.h<br>
-gs/base/gsfunc0.c<br>
-gs/base/gsfunc4.c<br>
-gs/base/gshsb.c<br>
-gs/base/gshsb.h<br>
-gs/base/gsht.h<br>
-gs/base/gsht1.c<br>
-gs/base/gshtscr.c<br>
-gs/base/gshtx.c<br>
-gs/base/gshtx.h<br>
-gs/base/gsicc.c<br>
-gs/base/gsicc_create.c<br>
-gs/base/gslib.c<br>
-gs/base/gsline.c<br>
-gs/base/gsline.h<br>
-gs/base/gsmatrix.c<br>
-gs/base/gsmatrix.h<br>
-gs/base/gspaint.c<br>
-gs/base/gspath.c<br>
-gs/base/gspath.h<br>
-gs/base/gspath1.c<br>
-gs/base/gspath2.h<br>
-gs/base/gsstate.c<br>
-gs/base/gsstate.h<br>
-gs/base/gstext.c<br>
-gs/base/gstext.h<br>
-gs/base/gstparam.h<br>
-gs/base/gstrans.c<br>
-gs/base/gstrans.h<br>
-gs/base/gxccache.c<br>
-gs/base/gxchar.c<br>
-gs/base/gxchar.h<br>
-gs/base/gxchrout.c<br>
-gs/base/gxchrout.h<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclpath.c<br>
-gs/base/gxcmap.c<br>
-gs/base/gxcolor2.h<br>
-gs/base/gxdevcli.h<br>
-gs/base/gxdevice.h<br>
-gs/base/gxfapi.c<br>
-gs/base/gxfmap.h<br>
-gs/base/gximag3x.c<br>
-gs/base/gximage3.c<br>
-gs/base/gxline.h<br>
-gs/base/gxmatrix.h<br>
-gs/base/gxpath.c<br>
-gs/base/gxpath.h<br>
-gs/base/gxshade1.c<br>
-gs/base/gxshade4.h<br>
-gs/base/gxshade6.c<br>
-gs/base/gxtmap.h<br>
-gs/base/sdcparam.c<br>
-gs/base/spprint.c<br>
-gs/base/spprint.h<br>
-gs/base/stdpre.h<br>
-gs/contrib/eplaser/gdevescv.c<br>
-gs/contrib/eplaser/gdevescv.h<br>
-gs/contrib/lips4/gdevl4v.c<br>
-gs/contrib/opvp/gdevopvp.c<br>
-gs/devices/gdevcdj.c<br>
-gs/devices/gdevclj.c<br>
-gs/devices/gdevijs.c<br>
-gs/devices/gdevjpeg.c<br>
-gs/devices/gdevpxut.c<br>
-gs/devices/gdevpxut.h<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfc.c<br>
-gs/devices/vector/gdevpdfd.c<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpdfg.h<br>
-gs/devices/vector/gdevpdfj.c<br>
-gs/devices/vector/gdevpdfk.c<br>
-gs/devices/vector/gdevpdfm.c<br>
-gs/devices/vector/gdevpdfo.c<br>
-gs/devices/vector/gdevpdfo.h<br>
-gs/devices/vector/gdevpdfv.c<br>
-gs/devices/vector/gdevpdts.c<br>
-gs/devices/vector/gdevpdts.h<br>
-gs/devices/vector/gdevps.c<br>
-gs/devices/vector/gdevpsdf.h<br>
-gs/devices/vector/gdevpsdi.c<br>
-gs/devices/vector/gdevpsdu.c<br>
-gs/devices/vector/gdevpsf2.c<br>
-gs/devices/vector/gdevpx.c<br>
-gs/devices/vector/gdevsvg.c<br>
-gs/devices/vector/gdevxps.c<br>
-gs/psi/idparam.c<br>
-gs/psi/idparam.h<br>
-gs/psi/imain.c<br>
-gs/psi/imain.h<br>
-gs/psi/zcolor.c<br>
-gs/psi/zgstate.c<br>
-gs/psi/zht1.c<br>
-gs/psi/zht2.c<br>
-gs/psi/zmatrix.c<br>
-gs/psi/zpath.c<br>
-gs/psi/zpath1.c<br>
-gs/psi/ztrans.c<br>
-pcl/pccsbase.c<br>
-pcl/pcfont.c<br>
-pcl/pcht.c<br>
-pcl/pcindxed.c<br>
-pcl/pcindxed.h<br>
-pcl/pcmtx3.c<br>
-pcl/pcmtx3.h<br>
-pcl/pcommand.c<br>
-pcl/pcpage.c<br>
-pcl/pcpalet.c<br>
-pcl/pcpalet.h<br>
-pcl/pcparam.h<br>
-pcl/pcpatxfm.c<br>
-pcl/pcpatxfm.h<br>
-pcl/pcrect.c<br>
-pcl/pcsfont.c<br>
-pcl/pctext.c<br>
-pcl/pgcolor.c<br>
-pcl/pgdraw.c<br>
-pcl/pgdraw.h<br>
-pcl/pgfdata.c<br>
-pcl/pggeom.c<br>
-pcl/pggeom.h<br>
-pcl/pglabel.c<br>
-pcl/pgpoly.c<br>
-pcl/pgvector.c<br>
-pcl/rtgmode.c<br>
-pcl/rtraster.c<br>
-pl/pjparse.c<br>
-pl/pjparse.h<br>
-pl/pjparsei.c<br>
-pl/pjtop.c<br>
-pl/pjtop.h<br>
-pl/plchar.c<br>
-pl/plfont.h<br>
-pl/plsrgb.c<br>
-pl/pluchar.c<br>
-pxl/pxink.c<br>
-pxl/pxpaint.c<br>
-pxl/pxpthr.c<br>
-svg/svgtop.c<br>
-tools/gslite/gslt_test.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-18 11:37:40 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ddd13eda3853d53315b7ba656ccd32ad9814c34">5ddd13eda3853d53315b7ba656ccd32ad9814c34</a>
-<blockquote>
-<p>
- ps2write - Don't emit a page size change if the last request failed (and was the same size)<br>
-<br>
- Bug #694852 We check the current media size at the start of every page, and<br>
- only emit a new request if the page is a different size to the current size.<br>
-<br>
- However, if the request fails (media not available) we keep on requesting<br>
- the media via setpagedevice. This causes duplexing to be disabled, as each<br>
- setpagedevice resets the device and ejects the previous page.<br>
-<br>
- This commit still checks the current page size, however, if it is not the<br>
- size needed for the page, we then check to see if 'MediaRequested;' is<br>
- known. If it is not we set the media, and set MediaRequested to the new<br>
- media size. If MediaRequested is known, we check to see if the new media<br>
- size is the same as the last one we requested. If it is there's no point<br>
- in doing a new request as it will fail again,so we drop the request.<br>
-<br>
- If the new requested media is not the same as the last requested media,<br>
- then we do emit a new request, which may or may not be satisfied of course.<br>
-<br>
- This should permit duplexing to work and be slightly faster in the case<br>
- where requested media is not available.<br>
-<br>
-gs/devices/vector/opdfread.h<br>
-gs/lib/opdfread.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-14 13:13: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=2f8b73d56d667334e935071f24f1d6b1860a48e2">2f8b73d56d667334e935071f24f1d6b1860a48e2</a>
-<blockquote>
-<p>
- Bug 694832: refine when to elide the TTF notdef glyph<br>
-<br>
- Only force the Truetype notdef glyph to be non-marking when the font in<br>
- question uses a TTF cmap table other than the symbolic (3.0) cmap table.<br>
-<br>
- Several cluster files show differences - all except one are progressions<br>
- with reference to Acrobat, and the exception was &quot;wrong&quot; before and is<br>
- slightly differently wrong now (an entirely different underlying issue).<br>
-<br>
-gs/Resource/Init/gs_ttf.ps<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-17 17:33:05 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=727b6e87edc234670120dcce040547610736fe0d">727b6e87edc234670120dcce040547610736fe0d</a>
-<blockquote>
-<p>
- Bug 694844: Fix thin stroking of paths with non-idempotent colors.<br>
-<br>
- For non-idempotent colors when stroking we have to construct an entire<br>
- path and then fill it, rather than stroking each section as we go.<br>
-<br>
- Unfortunately in the code that implements this, we missed a case - thin<br>
- sections can be stroked section by section even in the non-idempotent<br>
- case.<br>
-<br>
- We fix that here.<br>
-<br>
- This appears to solve Bug 694844, which was hitting this case.<br>
-<br>
-gs/base/gxstroke.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-16 18:13: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=300c3ea8f2c82471c5e57655bd13549f1172c38a">300c3ea8f2c82471c5e57655bd13549f1172c38a</a>
-<blockquote>
-<p>
- Bug 694842: Fix threshold table generation.<br>
-<br>
- When we generate threshold tables for dithering, we should expect them<br>
- to be 'evenly distributed'. This is not the case currently. In the<br>
- example given in this bug, we generate an 8x4 dither table. This<br>
- contains 32 pixels, all of which can be on or off, hence we have 33<br>
- levels, ranging from 0 on to 32 on.<br>
-<br>
- We would further expect our input range to be evenly divided into these<br>
- levels - i.e. roughly 256/33 in each band.<br>
-<br>
- This is not the case. The threshold table generated is:<br>
-<br>
- threshold array row 0= 88 120 152 184 176 144 112 80<br>
- threshold array row 1= 192 224 208 168 72 40 56 96<br>
- threshold array row 2= 232 255 240 136 32 8 24 128<br>
- threshold array row 3= 216 248 200 104 48 16 64 160<br>
-<br>
- The operation of our thresholding code is to set a pixel if<br>
- contone(x,y) &lt; threshold(x,y), hence our inputs divide into:<br>
- 0-7,8-15,...240-254,255<br>
-<br>
- Not only does this not have the required 256/33 per region, the top<br>
- and bottom regions are far from being even (8 vs 1 entries).<br>
-<br>
- Ideally we should fix this code so generate the correct distribution -<br>
- an enhancement bug will be opened for this. For now we will satisfy<br>
- ourselves by offsetting the thresholds slightly so that the top and<br>
- bottom ranges are at least even. The new code gives:<br>
-<br>
- threshold array row 0= 84 116 148 180 172 140 108 76<br>
- threshold array row 1= 188 220 204 164 68 36 52 92<br>
- threshold array row 2= 228 252 236 132 28 4 20 124<br>
- threshold array row 3= 212 244 196 100 44 12 60 156<br>
-<br>
-gs/base/gsht.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-17 10:30:26 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=712d2254dc190baeea795931a470d39f8d43c2bf">712d2254dc190baeea795931a470d39f8d43c2bf</a>
-<blockquote>
-<p>
- Update opdfread.ps with the changes for eps2write. Although we no longer<br>
- actually use opdfread.ps, instead we use opdfread.h, we want to keep the<br>
- two in sync.<br>
-<br>
-gs/lib/opdfread.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-17 10:29: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=730dbe8b0717b2f882067163737eb89708e7e66d">730dbe8b0717b2f882067163737eb89708e7e66d</a>
-<blockquote>
-<p>
- correct a tab in the source, replacing with spaces.<br>
-<br>
-gs/devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-16 17:44:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1f30a9f66b280fad5cb8133e02530c60a038843c">1f30a9f66b280fad5cb8133e02530c60a038843c</a>
-<blockquote>
-<p>
- Add new 'eps2write' device which will eventually replace epswrite<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/devs.mak<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfb.h<br>
-gs/devices/vector/gdevpdfd.c<br>
-gs/devices/vector/gdevpdfi.c<br>
-gs/devices/vector/gdevpdfu.c<br>
-gs/devices/vector/gdevpdfx.h<br>
-gs/devices/vector/gdevpdtc.c<br>
-gs/devices/vector/gdevpdte.c<br>
-gs/devices/vector/gdevpdti.c<br>
-gs/devices/vector/gdevpdts.c<br>
-gs/devices/vector/gdevpdts.h<br>
-gs/devices/vector/gdevpdtt.c<br>
-gs/devices/vector/gdevpdtt.h<br>
-gs/devices/vector/opdfread.h<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-16 08:32:12 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=abd38464f9b058502c9491873ff7f01f00c406d7">abd38464f9b058502c9491873ff7f01f00c406d7</a>
-<blockquote>
-<p>
- Fix for goof up in loop index variable.<br>
-<br>
- Fixes bug 694811 and 694848. Thanks ken for finding this.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-16 12:34:26 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e2f00f15c988d75a4182ecdcdc1a82b4686ef92">8e2f00f15c988d75a4182ecdcdc1a82b4686ef92</a>
-<blockquote>
-<p>
- Bug 694845: Shailesh Mistrys patch for regression in jbig2dec<br>
-<br>
- Having reverted the problematic patch, this is the fixed version.<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-16 11:45:42 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa8b62e45f07564304d671b57cba7fede5d4729d">fa8b62e45f07564304d671b57cba7fede5d4729d</a>
-<blockquote>
-<p>
- Revert &quot;Bug 694124: Shailesh Mistry's patch for valgrind problems.&quot;<br>
-<br>
- This reverts commit d166833eb541466104c582980be1e42e0062c738.<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-16 10:08:20 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bcac8f9cfd8330ec4434b176c150c44af276393e">bcac8f9cfd8330ec4434b176c150c44af276393e</a>
-<blockquote>
-<p>
- Force special action to build language_switch<br>
-<br>
- A &quot;normal&quot; attempt to build language_switch will elicit a warning, to actually<br>
- make it build, adding &quot;UNSUPPORTED=1&quot; to the (n)make command line is required.<br>
-<br>
-language_switch/pspcl6_gcc.mak<br>
-language_switch/pspcl6_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-15 09:51:50 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=88a39ea069424045161ff000af5574ba340bb51d">88a39ea069424045161ff000af5574ba340bb51d</a>
-<blockquote>
-<p>
- Remove the language switch build from the default make targets.<br>
-<br>
-Makefile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-14 13:54:31 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=70c1f72389b31e95e9cffb6578a3a94e3052cb44">70c1f72389b31e95e9cffb6578a3a94e3052cb44</a>
-<blockquote>
-<p>
- Bug 694843: reset FAPI font data on &quot;refine&quot; font<br>
-<br>
- For example, a font dict may be copied, so the &quot;FAPI&quot; entry is copied with<br>
- the dict, but the new internal font object does not have the FAPI server in<br>
- it. We catch that in the &quot;refine font&quot; call - previously here we didn't reset<br>
- the font data, just &quot;re-bound&quot; the FAPI server. It turns out with the<br>
- language switch build, we need to set the FAPI font data, too.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-13 15:15:24 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5b592a88fa8760f5fd4d7a8f082e094bda981a93">5b592a88fa8760f5fd4d7a8f082e094bda981a93</a>
-<blockquote>
-<p>
- pdfwrite - yet more discriminating tests before TrueType font combining<br>
-<br>
- Bug #694833 &quot;german letters adieresis, odieresis and udieresis are missing after conversion to PDF&quot;<br>
-<br>
- This follows on from commit 8b6be8be2cdcefae39339682d45d3c009ab909ac<br>
- Bug #694538.<br>
-<br>
- Again we have a random pair of Type 42 fonts which would be compatible to<br>
- combine, except that they have differing max composite points and contours.<br>
- Mad, but there you go.<br>
-<br>
- No differences expected, we don't see these files from any other source.<br>
-<br>
-gs/base/gstype42.c<br>
-gs/base/gxfont42.h<br>
-gs/devices/gxfcopy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-12 16:20:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3e8a32f8a884039b851c39b5aceabfd8c8e93198">3e8a32f8a884039b851c39b5aceabfd8c8e93198</a>
-<blockquote>
-<p>
- Inherit CFLAGS from environment in (pdl) configure script<br>
-<br>
- No cluster differences.<br>
-<br>
-config.mak.in<br>
-configure.ac<br>
-main/pcl6_gcc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-12 00:58:04 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=99a6f1af177c15f4db475186b79d169c993494ef">99a6f1af177c15f4db475186b79d169c993494ef</a>
-<blockquote>
-<p>
- Bug 694119: Shailesh Mistry's patch for Valgrind problems.<br>
-<br>
- Don't read off the end of an empty (or almost empty) buffer.<br>
-<br>
-gs/openjpeg/libopenjpeg/t2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-11 19:06: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=bb123bf027bf7ea0aa5b82ed2626d21f91c57613">bb123bf027bf7ea0aa5b82ed2626d21f91c57613</a>
-<blockquote>
-<p>
- Bug 694363: Shailesh Mistry's patch for SEGV.<br>
-<br>
- Avoid buffer overflow due to oversized image dimensions causing<br>
- int overflow.<br>
-<br>
-gs/openjpeg/libopenjpeg/j2k.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-11 19:02:39 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d166833eb541466104c582980be1e42e0062c738">d166833eb541466104c582980be1e42e0062c738</a>
-<blockquote>
-<p>
- Bug 694124: Shailesh Mistry's patch for valgrind problems.<br>
-<br>
- Detect zero sized symbol dictionary and exit neatly. Avoids overreads.<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-11 09:47:45 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f42c717329ec13db00f2627bd89ad4c081379fd9">f42c717329ec13db00f2627bd89ad4c081379fd9</a>
-<blockquote>
-<p>
- Remove extraneous %d from a debug message (-ZL).<br>
-<br>
- Thanks to Henry for spotting this.<br>
-<br>
-gs/base/gxclutil.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-11 16:17:31 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=19d709b45b9173e225bd6e62bb20e9eb5f192254">19d709b45b9173e225bd6e62bb20e9eb5f192254</a>
-<blockquote>
-<p>
- Bug 694836: remove erroring CIDFont subsitute record<br>
-<br>
- When subsituting a CIDFont we dynamically update the CIDFont resource's .map<br>
- dictionary (to ensure the substitute CIDFont is loaded with the correct<br>
- &quot;attributes&quot;).<br>
-<br>
- If findresource fails with the updated .map dictionary, remove the entry we<br>
- just added, to avoid subsequent attempted loads of that CIDFont finding the<br>
- erroring .map entry.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_ciddc.ps<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-11 13:03:28 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b3be65914d6dbe6585dec8576e80c7fb52fffbe4">b3be65914d6dbe6585dec8576e80c7fb52fffbe4</a>
-<blockquote>
-<p>
- pdfwrite - fix compiler comparison oddness<br>
-<br>
- Bug #694838 &quot;Artifex Ghostscript 9.10: JBIG2Encode requires CompabilityLevel &gt;= 1.4&quot;<br>
-<br>
- The code compares a float variable with a non-integer constant. Bizzarely<br>
- the comparison fails unless the contant is declared as type float as well<br>
- (using the x.yf syntax), at least on the Microsoft compiler. Presumably<br>
- without this they are evaluated as double.<br>
-<br>
- This commit simply alters the constants to be declared specifically as<br>
- floats.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-07 16:16:22 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2aaae7404988d7443b002907954693749c468347">2aaae7404988d7443b002907954693749c468347</a>
-<blockquote>
-<p>
- A better fix for the previous -dEPSFitPage.<br>
-<br>
- Note that -dEPSCrop with -dEPSFitPage is actually done in the C<br>
- code.<br>
-<br>
-gs/Resource/Init/gs_epsf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-07 14:42:07 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7f4d1c480eb53e2f18bd87a0c3cb0f98faa7281c">7f4d1c480eb53e2f18bd87a0c3cb0f98faa7281c</a>
-<blockquote>
-<p>
- Fix EPSFitPage (related to bug 694829.<br>
-<br>
- The EPSFitPage now rotates as well as translating/scaling.<br>
-<br>
-gs/Resource/Init/gs_epsf.ps<br>
-gs/Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-03 10:09:56 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ca3d544d51c3e1d63a2fd115dac23255c966ba0e">ca3d544d51c3e1d63a2fd115dac23255c966ba0e</a>
-<blockquote>
-<p>
- pdfwrite - add Resources to current substream when starting an SP pdfmark<br>
-<br>
- Bug #689653 &quot;Nested form XObject pdfmarks not working properly&quot;<br>
- Bug #689883 &quot;/SP pdfmark inside /BP-/EP pdfmark pair for XObject re-use&quot;<br>
-<br>
- When we use a 'picture' via the SP pdfmark, add the picture resource to<br>
- the current substream resources, so that if we are accumulating a substream<br>
- (pattern, form, another picture etc) then the Resources for that substream<br>
- will contain an entry for the picture. Previously they did not and relied<br>
- on inheriting from the page dictionary, which is long since deprecated.<br>
-<br>
- Thanks to Alexander Grahn for diagnosing the problem and supplying the<br>
- patch.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-12-02 16:28:46 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da944b290302bf9391116b806c4a368b7d185d94">da944b290302bf9391116b806c4a368b7d185d94</a>
-<blockquote>
-<p>
- Add debugging for max heap memory allocation for -Z:<br>
-<br>
- This is a minor hack for debug builds that prints out the 'max' usage<br>
- which is often of interest. A better method would be to add a memory<br>
- proc to print the stats that would be implemented for all allocators.<br>
-<br>
- If so, a 'verbosity' control might be nice for 'max' (max used) and<br>
- 'leaked' that would print all elements that the allocator knows about<br>
- (for leak detection), or 'current' to print current allocated size.<br>
-<br>
-gs/psi/iapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-30 13:46:49 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=05d2e5cd0b8ce92ddeacca00e8f64d3f7b2e5883">05d2e5cd0b8ce92ddeacca00e8f64d3f7b2e5883</a>
-<blockquote>
-<p>
- pdfwrite - add garbage collection handlers to Bicubic streams<br>
-<br>
- Bug #694826 &quot;Seg fault with pdfwrite device&quot;<br>
-<br>
- There was an oversight when coding the Bicubic stream downsampling and the<br>
- working buffer was not enabled for relocation on garbage collection.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpsds.c<br>
-gs/devices/vector/gdevpsds.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-29 09:31:04 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=33b41157c24f27cd912fa1d517e9246af37bbe2f">33b41157c24f27cd912fa1d517e9246af37bbe2f</a>
-<blockquote>
-<p>
- txtwrite - set the returned glpyh in the text enumerator before executing CDevProc<br>
-<br>
- Bug #698422 &quot;txtwriter driver crashes with this (badly crafted) PDF file&quot;<br>
-<br>
- The txtwrite device was leaving the 'returned' glyph unset when it needed<br>
- to run the CDevProc for a CIDFont. This could later cause a crash because<br>
- other code would attempt to use the uninitialised variable.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-28 18:24: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=748013087dd75882abbcfe4c630eeddb059be773">748013087dd75882abbcfe4c630eeddb059be773</a>
-<blockquote>
-<p>
- Bug 694362: More tweaking in jbig2dec.<br>
-<br>
- Following more discussions with Simon, and testing within MuPDF, it<br>
- appears that the original code was correct. I am therefore restoring<br>
- the original behaviour, except with a direct jump to cleanup rather<br>
- than relying on dropping into the following case.<br>
-<br>
- This will result in just 1 error being given, and is cleaner, to my<br>
- mind.<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-28 17:51:02 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa25793292f8e6799ecad1bcd6565206b7566664">fa25793292f8e6799ecad1bcd6565206b7566664</a>
-<blockquote>
-<p>
- More work on bug 694362<br>
-<br>
- Back out some 'unreachable code' that I had accidently added back in.<br>
-<br>
- Remove a couple of unreachable 'break;' statements too.<br>
-<br>
-gs/jbig2dec/jbig2.c<br>
-gs/jbig2dec/jbig2_segment.c<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-28 16:43:26 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e697fc428f4cca033d0b844cc4bceebffe50e853">e697fc428f4cca033d0b844cc4bceebffe50e853</a>
-<blockquote>
-<p>
- Pull changes back from mupdf's version of jbig2dec to gs's.<br>
-<br>
- MuPDF now tracks the version of jbig2dec extracted from gs.<br>
- Shelly spotted a couple of minor things that had been lost as<br>
- part of his investigation into bug 694362. Pull them back<br>
- across.<br>
-<br>
-gs/jbig2dec/jbig2.c<br>
-gs/jbig2dec/jbig2_segment.c<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-27 09:38:02 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=01cef1fd7dbaf3ef48dcff9e23875980265f2859">01cef1fd7dbaf3ef48dcff9e23875980265f2859</a>
-<blockquote>
-<p>
- pdfwrite - ignore annotation /AP where the appearance is not a stream<br>
-<br>
- Bug #694809 &quot;Conversion of PDF-file fails with typecheck-error&quot;<br>
-<br>
- The speciment PDF file has an invalid appearance for an annotation:<br>
-<br>
- 182 0 obj<br>
- &lt;&lt;<br>
- /AP &lt;&lt; /N &lt;&lt; /Yes /null &gt;&gt; &gt;&gt;<br>
-<br>
- The normal appearance should be a dictionary where each key value pair has<br>
- a value which is a stream. /null is not a stream.<br>
-<br>
- This commit drops annotations with this problem and emits a warning.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-27 10:44:28 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=87a7fd8afe9af506bf91024d8cc60ef0721450d5">87a7fd8afe9af506bf91024d8cc60ef0721450d5</a>
-<blockquote>
-<p>
- &quot;cups&quot; output device: Support for PPD-less printing and PWG Raster output<br>
-<br>
- 1. PWG Raster output: With -sMediaClass=PwgRaster the output is in PWG<br>
- Raster format and not in CUPS Raster format. TODO: Create &quot;pwg&quot; or<br>
- &quot;pwgraster&quot; output device name for that.<br>
-<br>
- 2. Support for PPD-less printing: If the &quot;PPD&quot; environment variable is<br>
- not set to a valid PPD file, allow setting unprintable margins via<br>
- something like:<br>
-<br>
- &quot;-c '&lt;&lt;/.HWMargins[12 12 12 12] /Margins[0 0]&gt;&gt;setpagedevice'&quot;<br>
-<br>
- 3. Correct rounding by adding 0.5 to float numbers before converting<br>
- them to integer.<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-27 08:43:53 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49f620bbdabaa186b56cb783afd30bcfc8ca40ef">49f620bbdabaa186b56cb783afd30bcfc8ca40ef</a>
-<blockquote>
-<p>
- pdfwrite - remove an unused variable to silence a compiler warning<br>
-<br>
-gs/devices/vector/gdevpdfv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-26 16:20:18 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fe99ca5fd2e3b191a76c7f7d791b72f3603e9fea">fe99ca5fd2e3b191a76c7f7d791b72f3603e9fea</a>
-<blockquote>
-<p>
- pdfwrite - spot reuse of shading dictionaries and don't emit multiple times<br>
-<br>
- Bug #689247 &quot;pdfwrite creates redundant shadings&quot;<br>
-<br>
- Previously we always made a new shading and pattern dictionary every time<br>
- we encountered a shading. Taking advantage of the hashing mechanism that<br>
- was written to improve performance, we can now spot reuse of shading<br>
- dictionaries, and emit only a single copy.<br>
-<br>
- The output from the test file now only contains 106 shadings and patterns<br>
- and the compressed file size is reduced by 41% as a result.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-26 09:21:13 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb3e5c6278fc7ea5e1bfdb3a23944cdcce13eb5a">fb3e5c6278fc7ea5e1bfdb3a23944cdcce13eb5a</a>
-<blockquote>
-<p>
- Change the order of checks when enumerating PCL fonts.<br>
-<br>
- We need to check whether the MT fonts have populated the font dictionary<br>
- before we worry about whether there's a path to find the TTF versions of the<br>
- built-in fonts.<br>
-<br>
- No cluster differences.<br>
-<br>
-pl/pllfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-20 14:55:12 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9ecb86e69f473d8c981baeca6885d67b23964440">9ecb86e69f473d8c981baeca6885d67b23964440</a>
-<blockquote>
-<p>
- pcl/FAPI MT font fixes.<br>
-<br>
- Fix a problem with parsing out the FCO paths from the FCO list string (we could<br>
- run off the end of the string).<br>
-<br>
- Make the &quot;header&quot; byte swapping call conditional on being a little-endian<br>
- platform.<br>
-<br>
- Fix a makefile hiccup that resulted in the FCO files being built into the romfs<br>
- twice.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/fapiufst.c<br>
-main/pcl6_gcc.mak<br>
-pl/pllfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-26 12:07: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=90ec17f20be53db00fcbc2ada6931e7cc7b22b9e">90ec17f20be53db00fcbc2ada6931e7cc7b22b9e</a>
-<blockquote>
-<p>
- pdfwrite - fix dictionary stream hashing<br>
-<br>
- The dictionary stream hashing code didn't initialise the MD5 hash before<br>
- using it, which could lead to problems. Also the cos_stream_equal routine<br>
- was passing in an MD5 state which would then be reused inside the hashing<br>
- code. Although this doesn't seem to cause a problem, and we don't actually<br>
- use that state, its safest if we make use a dummy instead.<br>
-<br>
- Problems discovered while working on duplicate shadings.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-25 18:26:20 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83fb95771604bd85b1b3345f67d83cc99c69bfd9">83fb95771604bd85b1b3345f67d83cc99c69bfd9</a>
-<blockquote>
-<p>
- Bug 694245: Fix valgrind problems.<br>
-<br>
- During stroke calculations, ff we have a non-invertible matrix, then<br>
- use 0 as the calculated distance, rather than running with<br>
- undefined values. We were failing to check for an error code.<br>
-<br>
- Returning an error code stops rendering, so swallow the error and<br>
- continue with 0.<br>
-<br>
-gs/base/gxpdash.c<br>
-gs/base/gxstroke.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-25 18:39:05 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7be77f2a74952c2d7f8f3969ae885a014b51513c">7be77f2a74952c2d7f8f3969ae885a014b51513c</a>
-<blockquote>
-<p>
- Add missing Makefile header dependency.<br>
-<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-25 09:58:08 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d8fcaef61f7af1a032f9dff8d38957b335ee8cc">0d8fcaef61f7af1a032f9dff8d38957b335ee8cc</a>
-<blockquote>
-<p>
- Remove #define DEBUG_TRACE_PS_OPERATORS inadvertently left enabled.<br>
-<br>
-gs/psi/iinit.c<br>
-gs/psi/iinit.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-25 14:33:12 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b3a65aab20feac334cac8e5935ba5cbe310ac69">7b3a65aab20feac334cac8e5935ba5cbe310ac69</a>
-<blockquote>
-<p>
- Fix previous commit; align_bitmap_mod is in bytes not bits.<br>
-<br>
- Correct the calculations in the previous commit.<br>
-<br>
-gs/base/gsiparam.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-25 13:24: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=b81962611a292e1b2c5306f3d5cdfea832715169">b81962611a292e1b2c5306f3d5cdfea832715169</a>
-<blockquote>
-<p>
- Bug 694601: Fix big endian crash in mem_mono_copy_mono.<br>
-<br>
- While the crash is reported on a big endian device, the problem actually<br>
- potentially occurs on little endian systems too. As it happens,<br>
- x86, amd64, and many ARM configurations will read happily from unaligned<br>
- addresses. Some ARMs and many other processors will not, however, so we<br>
- apply a fix that will work properly everywhere.<br>
-<br>
- When calling device level functions, we should ensure that the 'raster'<br>
- given is always a multiple of align_bitmap_mod bits.<br>
-<br>
- Thanks to John Wehle for the bug report and suggested fix.<br>
-<br>
-gs/base/gsiparam.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-23 21:37:03 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a72e695c6ad632a38d27eaaa45bdbad8b5a0fa1">4a72e695c6ad632a38d27eaaa45bdbad8b5a0fa1</a>
-<blockquote>
-<p>
- Fix garbage output with --saved-pages due to not doing needed erasepage.<br>
-<br>
- Actions which print, or reallocate to clist mode or page mode, may<br>
- need the page to be erased. This includes the 'print' action. Seen<br>
- with 12-07C.PS when gs_cet.ps is used.<br>
-<br>
- Also, don't allow &quot;copies n&quot; without a prior &quot;begin&quot;.<br>
-<br>
- Silence a few build warnings (missing dependency)<br>
-<br>
-gs/base/gxclpage.c<br>
-gs/base/gxclpage.h<br>
-gs/psi/iinit.h<br>
-gs/psi/imainarg.c<br>
-gs/psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-20 17:03:48 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=006051023733a636fc7e61754489e05fa38acdea">006051023733a636fc7e61754489e05fa38acdea</a>
-<blockquote>
-<p>
- Remove FORCE_SAVED_PAGES_TEST since cluster now supports extras=...<br>
-<br>
- Also clean up some compiler warnings.<br>
-<br>
-gs/psi/imain.c<br>
-gs/psi/imainarg.c<br>
-gs/psi/iminst.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-23 11:36:09 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=54610538e180cb5cb9b80c51f9a8a3d5b9bba5c2">54610538e180cb5cb9b80c51f9a8a3d5b9bba5c2</a>
-<blockquote>
-<p>
- Make order of --saved-pages-test and --saved-pages= options position independent.<br>
-<br>
- The position of these command line options had been required to be the<br>
- last option prior to the first file to run, but this is not how most<br>
- other command line options operate. This allows the --saved-pages-test<br>
- or --saved-pages=begin option to be placed anywhere in the command line.<br>
-<br>
- The debug option to FORCE_SAVED_PAGES_TEST is now in psi/imain.c<br>
- and the OMIT_SAVED_PAGES_TEST is removed.<br>
-<br>
-gs/psi/imain.c<br>
-gs/psi/imainarg.c<br>
-gs/psi/iminst.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-05 12:27:58 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=97535718d671b728c47f7bbc35512449c47d2bc1">97535718d671b728c47f7bbc35512449c47d2bc1</a>
-<blockquote>
-<p>
- Fix more Segfaults with --saved-pages and psdcmyk and many differences.<br>
-<br>
- Devices that have devn paramaters could close the device so make sure<br>
- and open it. Also set banding_type to BandingAlways while in saved-pages<br>
- mode and restore it when we end saved-pages mode.<br>
-<br>
- A few files still segfaulted, and there were many differences because<br>
- the page was not erased after the saved-pages &quot;begin&quot;.<br>
-<br>
- In gx_saved_page_load, for pages that fit in a single band (as with<br>
- large -dMaxBitmap values), reset the ymin and ymax to force rasterizing<br>
- the next page's clist.<br>
-<br>
-gs/base/gxclpage.c<br>
-gs/base/gxclpage.h<br>
-gs/psi/imainarg.c<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-22 17:34:46 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=55d90681fd4eb85fa8d38b965fb31d12cdb133e2">55d90681fd4eb85fa8d38b965fb31d12cdb133e2</a>
-<blockquote>
-<p>
- Enable shared library builds on AIX (gcc only)<br>
-<br>
- Add the code to detect AIX (and gcc), and setup the command like arguments<br>
- so the &quot;make so&quot; targets works.<br>
-<br>
- There is still a &quot;duplicate symbols&quot; warning on &quot;.main&quot; when linking to the<br>
- shared lib - none of the documented options seemed to resolve that.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-22 15:23: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=cdd142387a04a6d7ea519838e15204c4d7c681d8">cdd142387a04a6d7ea519838e15204c4d7c681d8</a>
-<blockquote>
-<p>
- pdfwrite - flush streams before attempting to MD5 hash them<br>
-<br>
- This was discovered in the process of other work. Its possible that when we<br>
- MD5 hash a stream, its still partially or fully buffered, not written to<br>
- the asides file. This commit makes sure that the streams are flushed first.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-22 12:16:40 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=82e02b0dc49b51fbe4851a16a669ef83d35a2fae">82e02b0dc49b51fbe4851a16a669ef83d35a2fae</a>
-<blockquote>
-<p>
- Bug 694803: Fix truncated psd files.<br>
-<br>
- GS can truncate the number of spots used if we are working with PDF<br>
- files, hence not all 6 planes may be written. Fix this here.<br>
-<br>
-gs/devices/gdevcmykog.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-22 14:09:34 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=47584728a68520b754ba97f0bcbf001a19d8271b">47584728a68520b754ba97f0bcbf001a19d8271b</a>
-<blockquote>
-<p>
- Bug 694802: psdcmykog files truncated on MacOS.<br>
-<br>
- It appears that macos will not allow you to read from files opened<br>
- as &quot;wb&quot;, so use &quot;w+b&quot; instead. I probably should have been using this<br>
- anyway.<br>
-<br>
-gs/devices/gdevcmykog.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-21 16:51: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=16c29cb9deb49be55c582213469ff6993d26c731">16c29cb9deb49be55c582213469ff6993d26c731</a>
-<blockquote>
-<p>
- Bug 694798: Fix SEGV with psdcmykog device.<br>
-<br>
- The alignment/padding code was going wrong. In cases where the device<br>
- changes size and reallocates, we were attempting to resize the buffer<br>
- memory using the aligned pointer rather than the unaligned pointer.<br>
-<br>
-gs/base/gdevmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-21 15:01:16 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1829196ecccb692765c27c9b3eac13367cf50204">1829196ecccb692765c27c9b3eac13367cf50204</a>
-<blockquote>
-<p>
- Bug 694797: Remove stray code from psdcmykog device.<br>
-<br>
- Some stray code in the close method was causing the device to clear the<br>
- file on exit. This only seems to happen in some cases though. Just<br>
- removing the code should solve it.<br>
-<br>
-gs/devices/gdevcmykog.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-21 14:32:23 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1eeb45d0537ba8e561f27d6461fc5b62bd042340">1eeb45d0537ba8e561f27d6461fc5b62bd042340</a>
-<blockquote>
-<p>
- pdfwrite - honour device-independent color conversion strategy for images<br>
-<br>
- Bug #694799 &quot;New: incoherent output intent and color space in PDF/A (bis)&quot;<br>
-<br>
- The image colour conversion wasn't writing a device independent colour<br>
- space for UseDeviceIndependentColor or sRGB, but was instead writing<br>
- the original colour space.<br>
-<br>
- No Differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-20 12:46: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=8a94e4ee285f8b7d2f04edf2d8ac35f687355061">8a94e4ee285f8b7d2f04edf2d8ac35f687355061</a>
-<blockquote>
-<p>
- Remove boilerplate from gdevcmykog<br>
-<br>
-gs/devices/gdevcmykog.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-19 19:57:33 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bbaff51c391f0e3e6c0503da9f355c96a739c1b4">bbaff51c391f0e3e6c0503da9f355c96a739c1b4</a>
-<blockquote>
-<p>
- Silence warning.<br>
-<br>
-gs/devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-19 10:14: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=5af6431204f15f89519aac55c8d8ff42c823ced7">5af6431204f15f89519aac55c8d8ff42c823ced7</a>
-<blockquote>
-<p>
- Fix misplelling of 'parent' in the gp files.<br>
-<br>
-gs/base/gp.h<br>
-gs/base/gp_dosfs.c<br>
-gs/base/gp_macio.c<br>
-gs/base/gp_ntfs.c<br>
-gs/base/gp_os2fs.c<br>
-gs/base/gp_unifn.c<br>
-gs/base/gp_vms.c<br>
-gs/base/gpmisc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-19 19:18:50 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab73cd1550f558f5e1a82e60d95339b044713976">ab73cd1550f558f5e1a82e60d95339b044713976</a>
-<blockquote>
-<p>
- Solve psdcmykog hang on MacOSX.<br>
-<br>
- Mac gets hung in the collating phase, presumably due to different<br>
- handling of eof conditions for read/write file handles.<br>
-<br>
- Also, fix a mistake that can cause SEGVs in non debug versions.<br>
-<br>
-gs/devices/gdevcmykog.c<br>
-gs/devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-19 17:03:27 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9f03f419cc8cc598c2a9b4e94e41d6cfdad61c02">9f03f419cc8cc598c2a9b4e94e41d6cfdad61c02</a>
-<blockquote>
-<p>
- Various small fixes for psdcmykog build issues.<br>
-<br>
- Rename the device. Include it in linux builds by default, along with<br>
- fpng.<br>
-<br>
- Fix various warnings.<br>
-<br>
-gs/Makefile.in<br>
-gs/base/gdevdevnprn.h<br>
-gs/base/lib.mak<br>
-gs/base/unix-gcc.mak<br>
-gs/base/unixansi.mak<br>
-gs/configure.ac<br>
-gs/devices/devs.mak<br>
-gs/devices/gdevcmykog.c<br>
-gs/devices/gdevfpng.c<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-15 18:30:21 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3cee4eb9e3c24e0a2e7c48fddc473590c5a820b6">3cee4eb9e3c24e0a2e7c48fddc473590c5a820b6</a>
-<blockquote>
-<p>
- Make garbage collector private.<br>
-<br>
- Private is better than public.<br>
-<br>
-gs/base/gsgcache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-18 16:20:05 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be1e5a0dde242dc41f4e67a629d6bf403ac2938b">be1e5a0dde242dc41f4e67a629d6bf403ac2938b</a>
-<blockquote>
-<p>
- Update psdcmykog to use common psd writing functions.<br>
-<br>
-gs/devices/gdevcmykog.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-15 17:24:04 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bf2404a47b8b2843e37efbb0d242e5b46357b588">bf2404a47b8b2843e37efbb0d242e5b46357b588</a>
-<blockquote>
-<p>
- Tweak psdcmykog.c to use gdevdevnprn.h functions.<br>
-<br>
- This reduces the boilerplate.<br>
-<br>
-gs/devices/gdevcmykog.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-06 17:52:25 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8cb60cfe03ab7f1ada9b26eb57342fa9eca62e48">8cb60cfe03ab7f1ada9b26eb57342fa9eca62e48</a>
-<blockquote>
-<p>
- psdcmykog: simple example process_page device<br>
-<br>
- This device demonstrates a range of facilities newly added to<br>
- the Ghostscript core. This device exists as an exemplar for these<br>
- facilities, and as a mechanism to allow us to cluster test.<br>
-<br>
-gs/devices/devs.mak<br>
-gs/devices/gdevcmykog.c<br>
-gs/ghostscript.vcproj<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-18 16:19:12 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7089d5416766a4a526b382e57e4436633d29bb9e">7089d5416766a4a526b382e57e4436633d29bb9e</a>
-<blockquote>
-<p>
- Externalise psd writing functions.<br>
-<br>
- This will enable psdcmykog to share the psd writing functions.<br>
-<br>
-gs/base/gdevdevnprn.h<br>
-gs/devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-15 17:14:14 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a1bee59ddf2bf82273359564d6cdb8e0549ae14f">a1bee59ddf2bf82273359564d6cdb8e0549ae14f</a>
-<blockquote>
-<p>
- Extract guts of spotcmyk device to be reusable.<br>
-<br>
- Whenever we build a &quot;devicen&quot; based device, there is a lot of repeated<br>
- code. Tweak the spotcmyk functions (one such device) into a form where<br>
- they can be reused more easily.<br>
-<br>
- Also add cmyk_equiv_colors into this extracted structure. This shouldn't<br>
- matter to code that doesn't use the equivalent colors, (i.e. spotcmyk<br>
- and devicen will be unaffected), but should allow us to bring the psd<br>
- devices into the fold.<br>
-<br>
-gs/base/gdevdevn.c<br>
-gs/base/gdevdevnprn.h<br>
-gs/base/lib.mak<br>
-gs/devices/gdevpsd.c<br>
-gs/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-18 15:43:32 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a65b8db506a553334de495a9b27a18811188539a">a65b8db506a553334de495a9b27a18811188539a</a>
-<blockquote>
-<p>
- pdfwrite - new colour code, emit sRGB as ICCBased<br>
-<br>
- Bug #694780 &quot;incoherent output intent and color space in PDF/A&quot;<br>
-<br>
- sRGB was supposed to be written as ICCBased, but the code has a special<br>
- check to see if the ICC profile being used is one of the default ones<br>
- (ie its our ICC equivalent of Gray, RGB or CMYK) and if it is, we write<br>
- the original colour apace out.<br>
-<br>
- Added a boolean to override this behaviour so that when we emit sRGB we do<br>
- in fact write the ICCBased equivalent profile for RGB.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfb.c<br>
-gs/devices/vector/gdevpdfc.c<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpdfg.h<br>
-gs/devices/vector/gdevpdfi.c<br>
-gs/devices/vector/gdevpdfk.c<br>
-gs/devices/vector/gdevpdft.c<br>
-gs/devices/vector/gdevpdfv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-15 13:21:42 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d2804d480928140577560f673eb6a6419afb9abd">d2804d480928140577560f673eb6a6419afb9abd</a>
-<blockquote>
-<p>
- AES decryption - Don't return an error if the input is not a multiple of 16 bytes<br>
-<br>
- Bug #694781 &quot;Regression: error reading PDF files starting with 4885eb2fa363002fdf0980cd189f2a5bb9340f58&quot;<br>
-<br>
- The stream is technically invalid, it should be a multiple of 16 bytes in<br>
- length. Acrobat as usual silently ignores the error.<br>
-<br>
- We now emit a warning but carry on.<br>
-<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/saes.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-07 12:36:18 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b83ce7db814dd026b97bf2e00429459fc9c1f296">b83ce7db814dd026b97bf2e00429459fc9c1f296</a>
-<blockquote>
-<p>
- Improve collection of color_usage.or bits and track devn colors.<br>
-<br>
- Some of this was in place with cmd_drawing_color_usage, but it was<br>
- not used many times, and it just returned 'all'. Also, add the<br>
- check for devn colors that are widely used with planar devices<br>
- such as psdcmyk.<br>
-<br>
- Also handle the color_usage_array in the setup and teardown of the<br>
- BGPrint thread and/or multiple rendering threads.<br>
-<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclpath.c<br>
-gs/base/gxclrect.c<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-14 12:11:02 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db89e2390033fde0c69ffc01aeff346296336907">db89e2390033fde0c69ffc01aeff346296336907</a>
-<blockquote>
-<p>
- Fix SEGV with BGPrint=true -dNumRenderingThreads=2<br>
-<br>
- With BGPrint=true, the icc_cache_list for the rendering threads was<br>
- allocated using 'mem', but was being freed using mem-&gt;thread_safe_memory.<br>
- The BGPrint clist device 'mem' is a chunk allocator but its thread<br>
- safe memory is the heap allocator.<br>
-<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-14 17:02:27 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=026a7ed96060a9f9a11a16857a9549f77ed5042b">026a7ed96060a9f9a11a16857a9549f77ed5042b</a>
-<blockquote>
-<p>
- Fix alignment of memory buffers in page mode.<br>
-<br>
- The setup buffer call was setting the 'base' member to it's aligned<br>
- version, and the caller was then overwriting it with the unaligned<br>
- version. Simply remove the override.<br>
-<br>
-gs/base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-14 14:02:05 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=10b2168ba0a3973ce1e98b8405e01bc7d235464d">10b2168ba0a3973ce1e98b8405e01bc7d235464d</a>
-<blockquote>
-<p>
- Correct raster calculation in get_bits_rectangle for planar case.<br>
-<br>
-gs/base/gdevdgbr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-13 09:29:55 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea5452061ce70ada597888e629e6f6e9ca09ab10">ea5452061ce70ada597888e629e6f6e9ca09ab10</a>
-<blockquote>
-<p>
- Fix building WIN64=1 with Visual Studio 2013 and add pam to default devices.<br>
-<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-13 16:57:46 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=428f750746c09af66e53eed08a9fabf8dba2fef8">428f750746c09af66e53eed08a9fabf8dba2fef8</a>
-<blockquote>
-<p>
- Bug694768: Fix VMerrors during pattern processing.<br>
-<br>
- In a recent commit I moved the line_ptrs into the clist data block.<br>
- Don't do this for pattern accumulator operation, as the logic is<br>
- different.<br>
-<br>
-gs/base/gxclist.c<br>
-gs/base/gxclread.c<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-13 15:38: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=d42c77506452de368bebb64e61fd5f0b7347b343">d42c77506452de368bebb64e61fd5f0b7347b343</a>
-<blockquote>
-<p>
- Fix SEGVs caused by icc_cache_cl memory space change.<br>
-<br>
- A few commits ago, we moved the icc_cache_cl used for NRT &gt; 0 to the<br>
- thread safe memory handler. This meant it was no longer in gc-able<br>
- space, so we therefore removed the enumeration of icc_cache_cl from<br>
- the clist structure definitions.<br>
-<br>
- Unfortunately I forgot to move the non-NPR related allocations of<br>
- icc_cache_cl to the same thread safe handler, meaning that they were<br>
- still being allocated in gc-able memory and causing crashes. For<br>
- example:<br>
-<br>
- gs/debugbin/gswin32c.exe -Z@ -o out.pbm -sDEVICE=ppmraw -r300<br>
- -dMaxBitmap=400000000 ../ghostpcl/tests_private/comparefiles/Bug690189c.pdf<br>
-<br>
-gs/base/gxclist.c<br>
-gs/base/gxclpage.c<br>
-gs/base/gxclthrd.c<br>
-gs/base/gxp1fill.c<br>
-gs/base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-13 14:03:30 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0c50e7ba960e2ed37deb87501d8b966e5d800cd8">0c50e7ba960e2ed37deb87501d8b966e5d800cd8</a>
-<blockquote>
-<p>
- Fix crash with NPR &gt; 0 and planar devices.<br>
-<br>
- A command such as:<br>
-<br>
- gs -sDEVICE=psdcmyk -r300 -dMaxBitmap=10000 -dNumRenderingThreads=3<br>
- gs/examples/tiger.eps<br>
-<br>
- would crash with a SEGV due to an incorrect calculation for raster in<br>
- get_bits_rectangle.<br>
-<br>
-clustercmd<br>
-clusterdatestamp<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-13 13:35:56 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f221142fa36adc5a3d1192e534196dd4a7e953b4">f221142fa36adc5a3d1192e534196dd4a7e953b4</a>
-<blockquote>
-<p>
- PDF interpreter - more heuristics to work around broken PDF files<br>
-<br>
- Bug #594772 &quot; Regression: missing data reading PDF files starting with d5c42d3a14cee808fd889c14805a69adae8eb5b9&quot;<br>
-<br>
- The PDF file is broken, it has a font with a FontMatrix where one of<br>
- the values is 0.-4.<br>
-<br>
- Previously we used .pdftokenerror which would detect<br>
- this and convert the value to 0 (observed Acrobat behaviour). However at<br>
- some point this was modified so that if we are not in a content stream we<br>
- convert into a name object instead.<br>
-<br>
- This doesn't work in the case of a matrix. Unfortunately changing it back<br>
- broke *many* PDF files. Almost all of them from SumatraPDF and they are<br>
- also badly broken but still....<br>
-<br>
- In essence we want to treat broken numbers as '0' and broken anything else<br>
- as a name. So the code now tries to decide if the input looks like a broken<br>
- number (contains 0-9, ',', '.' or '-' and nothing else). If it looks like a<br>
- number we pass it through .pdftokenerror which will convert it to 0. It is<br>
- possible for .pdftokenerror to throw an error, though, so we run it in a<br>
- stopped context and if it does, we convert to a name instead. If it doesn't<br>
- look like a number, we just convert it to a name.<br>
-<br>
- This causes differences in Bug694429.pdf, but the differences are that more<br>
- text is now drawn. The output was wrong before, its wrong now, its merely<br>
- wrong in a different way.<br>
-<br>
-gs/Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-12 16:19:46 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d3dc3a3a6948a49a2e8faed57290da40a774703">4d3dc3a3a6948a49a2e8faed57290da40a774703</a>
-<blockquote>
-<p>
- Fix 694773 - default raster resolution to the PJL setting when in<br>
- HPGL/RTL mode.<br>
-<br>
-pcl/rtgmode.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-11 19:07:09 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a0a9d6746cf2e911c2db54c756e34e9e52c0723a">a0a9d6746cf2e911c2db54c756e34e9e52c0723a</a>
-<blockquote>
-<p>
- Introduce a list of device caches within the clist.<br>
-<br>
- This is only used when NumRenderingThreads &gt; 0, and avoids us recreating<br>
- caches every page.<br>
-<br>
- We allocate the cache list with the thread safe allocator. This has the<br>
- effect of moving the icc_cache_cl entries out of the thread specific<br>
- chunked allocators, and also out of garbage collected memory. We<br>
- therefore remove the code to enumerate icc_cache_cl.<br>
-<br>
- Also, this has the effect of fixing a gc enumeration bug where the first<br>
- element of the imager state wouldn't have been enumerated.<br>
-<br>
-gs/base/gdevprn.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclist.h<br>
-gs/base/gxclthrd.c<br>
-gs/base/gxclthrd.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-12 17:26:13 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=482b8b302399afda3b14242c56209a76694e0062">482b8b302399afda3b14242c56209a76694e0062</a>
-<blockquote>
-<p>
- Fix reference counting for icc_cache_cl in clist.<br>
-<br>
- Currently we only rc_decrement the icc_cache_cl entry in the bg_print<br>
- case. We should really be decrementing in all cases, but we get away<br>
- with this because the icc_cache_cl entries are allocated in the<br>
- rendering threads own chunked allocator which is destroyed after each<br>
- run.<br>
-<br>
- In a soon-to-come commit, icc_cache_cl will be moved out of the<br>
- thread specific chunked allocator, and these will become real leaks.<br>
-<br>
- The simple fix is to rc_decrement in all cases.<br>
-<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-12 18:31:50 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a0386e872771958c67874ab4ef45eb8f43c63f77">a0386e872771958c67874ab4ef45eb8f43c63f77</a>
-<blockquote>
-<p>
- Add 'extras' option to clusterpush.pl<br>
-<br>
- Use:<br>
-<br>
- clusterpush.pl gs lowres extras=-dNumRenderingThreads=3<br>
-<br>
- to specify extra args to supply to all jobs.<br>
-<br>
-clustercmd<br>
-clusterdatestamp<br>
-gs/toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-11 19:06:41 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6d4dc3c736c4cdf9e1728484857c613baf6ba3b4">6d4dc3c736c4cdf9e1728484857c613baf6ba3b4</a>
-<blockquote>
-<p>
- Silence build warning.<br>
-<br>
- Downcast to the basic device.<br>
-<br>
-gs/devices/gdevfpng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-12 10:33: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=f15da3a62aed425e85597b8482daf7ff778beb31">f15da3a62aed425e85597b8482daf7ff778beb31</a>
-<blockquote>
-<p>
- GS_THREADSAFE: don't ignore &quot;basic&quot; fills....<br>
-<br>
- In the default &quot;fill&quot; device method, don't drop the call to<br>
- gx_general_fill_path() for the GS_THREADSAFE build.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gxfill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-11 16:56:11 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bcb467c754a7a292f2ed65e61953782577e0412d">bcb467c754a7a292f2ed65e61953782577e0412d</a>
-<blockquote>
-<p>
- pdfwrite - set CIDToGIDMap correctly for PDF/A-2 output<br>
-<br>
- Bug #694769 &quot;Fonts changed from TrueType to CID TrueType and not displaying correctly in output PDF&quot;<br>
-<br>
- We opted not to emit CIDSet for PDF/A-2 since its now documented as<br>
- optional and I wasn't able to find a CIDSet which would pass Acrobat's<br>
- preflight tool.<br>
-<br>
- However, the code also skipped the correct setup of the CIDToGIDMap and we<br>
- can't do that or the output will be incorrect.<br>
-<br>
- This commit makes PDF/A-1 and PDF/A-2 behave the same with respect to the<br>
- CIDToGIDMap.<br>
-<br>
- No differences expected, we don't test PDF/A production<br>
-<br>
-gs/devices/vector/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-11 10:42:06 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f9774c5ae1b9cb12a811d810787b3e21d001a08f">f9774c5ae1b9cb12a811d810787b3e21d001a08f</a>
-<blockquote>
-<p>
- Bug 694767: have configure set some Trio flags.<br>
-<br>
- For systems that lack some math functions.<br>
-<br>
- No cluster differences.<br>
-<br>
-config.mak.in<br>
-configure.ac<br>
-gs/Makefile.in<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-11 16:14: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=efc0ab29473b65f1f0a119023601d987921373c0">efc0ab29473b65f1f0a119023601d987921373c0</a>
-<blockquote>
-<p>
- Bug 691498: only declare Windows DLL exports once.<br>
-<br>
- Using both the __declspec(dllexport) form *and* the .def file results in export<br>
- symbols being declared twice, and warning from the linker (but only on x86_64<br>
- for unknown reasons!).<br>
-<br>
- See: http://support.microsoft.com/kb/835326<br>
-<br>
- The original uses of __declspec(dllexport) are left in place, but conditionally<br>
- compiled out, just in case.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gs_dll_call.h<br>
-gs/psi/iapi.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-11 12:41:02 +0000
-</strong>
-<br>Alan Hourihane &lt;alanh@fairlite.co.uk&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=48a0dd978939fb6ae7bd445fd7b07bcf3b918948">48a0dd978939fb6ae7bd445fd7b07bcf3b918948</a>
-<blockquote>
-<p>
- Bug 694766: rename &quot;internal&quot; SHA symbols<br>
-<br>
- Prevent linker errors when linking to something else that uses SHA, by<br>
- prepending &quot;p&quot; (for private) to our &quot;internal&quot; SHA symbols.<br>
-<br>
-gs/base/sha2.c<br>
-gs/base/sha2.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-11 09:07:07 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6d592ef12079f3a1ea7b9218620f813769c3654">c6d592ef12079f3a1ea7b9218620f813769c3654</a>
-<blockquote>
-<p>
- pdfwrite - when unable to convert a Shading colour space, fallback to image<br>
-<br>
- Bug #688731 &quot;Huge PDF file with ProcessColorModel=/DeviceCMYK and ColorConversionStrategy=/CMYK&quot;<br>
-<br>
- When we can't convert the colour space of a shading dictioanary to satisfy<br>
- the ColorConversionStrategy we currently fall back to the rendering method<br>
- used by gx_fill_default, which is to degenerate into parallelograms.<br>
-<br>
- This results in hugs and very slow PDF files.<br>
-<br>
- This commit tests the ColorConversionStrategy when we detect an inability<br>
- to include a Shading unchanged, and if the strategy is not 'LeaveCOlorUnchanged'<br>
- then we use the ps2write approach and render the shading to an image instead.<br>
-<br>
- This produces smaller faster output and the quality can be controlled by<br>
- setting resolution with the -r switch allowing a tradeoff between size and<br>
- quality.<br>
-<br>
- If we should be unable to embed a shading for other reasons we will still<br>
- fall back to the parallelograms method. We may want to avoid this in all<br>
- circumstances, but lets wait for an example before we decide.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-08 18:33: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=db8fcdf94105c55a8886203254e401b601f29a69">db8fcdf94105c55a8886203254e401b601f29a69</a>
-<blockquote>
-<p>
- Remove dev-&gt;num_planes in favour of dev-&gt;is_planar.<br>
-<br>
- This removes the need to remember to keep<br>
- dev-&gt;num_planes == dev-&gt;color_info.num_components for all planar<br>
- devices.<br>
-<br>
-gs/base/gdevdevn.c<br>
-gs/base/gdevdrop.c<br>
-gs/base/gdevmem.c<br>
-gs/base/gdevmpla.c<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevppla.c<br>
-gs/base/gdevprn.c<br>
-gs/base/gsdevice.c<br>
-gs/base/gsovrc.c<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclip.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclist.h<br>
-gs/base/gxclthrd.c<br>
-gs/base/gxdevcli.h<br>
-gs/base/gxht_thresh.c<br>
-gs/base/gxicolor.c<br>
-gs/base/gximono.c<br>
-gs/base/gxp1fill.c<br>
-gs/base/gxpcmap.c<br>
-gs/devices/gdevplib.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-08 16:40:10 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c0e10e8636386abf427f922390445b0b6cb2bb59">c0e10e8636386abf427f922390445b0b6cb2bb59</a>
-<blockquote>
-<p>
- Fix SEGV in psdcmyk.<br>
-<br>
- tests_private/pdf/sumatra/586_-_missing_images_gs_SMask_not_applied.pdf.psdcmyk.300.1<br>
-<br>
- It seems num_planes was getting out of sync with color_info.num_components.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-08 17:55:04 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1cb2458772321dc86117cb45b5b28a1423ccf9b7">1cb2458772321dc86117cb45b5b28a1423ccf9b7</a>
-<blockquote>
-<p>
- pdfwrite - free any allocated memory when initialising stream filters<br>
-<br>
- Bug #694758 &quot;Segmentation Fault&quot;<br>
-<br>
- It seems that the arcane image setup sequence used by pdfwrite can result<br>
- in us calling stream 'init' functions more than once for the same stream.<br>
- Some of the stream filters (Average and Bicubic) allocate some working<br>
- memory in the 'init' procedure, but they don't check to see if the<br>
- working memory has already been allocated.<br>
-<br>
- This is primarily a cause of memory leaks, though since the memory is<br>
- garbage collected it won't (probably) actually leak. However it *does*<br>
- seem to confuse the garbage collector when relocating the stream state<br>
- structure. We allocate a buffer 9.9Kb but when we come to use it it has<br>
- shrunk to a little over 1Kb.<br>
-<br>
- This commit checks the working memory and if its not NULL then we free it<br>
- before re-allocating (we might be re-initialising to a different size) which<br>
- resolves the problem for me. However because it changes the memory pattern<br>
- its possible this is simply masking the problem. Note that this change<br>
- assumes that the structure members will be set to NULL when the structure<br>
- is allocated (which it always is at the moment).<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpsds.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-08 16:08: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=656f26c232933c6b3c29d2e6b37574096572f35a">656f26c232933c6b3c29d2e6b37574096572f35a</a>
-<blockquote>
-<p>
- Bug 694622: address a compiler warning.<br>
-<br>
- Use sprintf() instead of gs_sprintf() for &quot;top level&quot; code.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/psi/dxmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-08 09:52:25 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f2a046ddc81258749e73cfc7a6daf0a43488181">8f2a046ddc81258749e73cfc7a6daf0a43488181</a>
-<blockquote>
-<p>
- Bug 694624: remove couple of deprecated filters.<br>
-<br>
- Remove the Bounded Huffman and Burrows-Wheeler filters: not required by any<br>
- of the interpreters, and not used anywhere else.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/sbhc.c<br>
-gs/base/sbhc.h<br>
-gs/base/sbwbs.c<br>
-gs/base/sbwbs.h<br>
-gs/base/shcgen.c<br>
-gs/base/shcgen.h<br>
-gs/doc/Develop.htm<br>
-gs/psi/int.mak<br>
-gs/psi/zfilterx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-08 13:26: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=a9567942aa10ef2321627316d6f647819584179d">a9567942aa10ef2321627316d6f647819584179d</a>
-<blockquote>
-<p>
- Solve SEGV due to recentl planar changes.<br>
-<br>
- tests_private/comparefiles/Bug692217.pdf.psdcmyk.72.0 would SEGV.<br>
-<br>
- This was because num_planes was getting out of sync with num_components.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-07 17:30:06 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f59dba325a55dd25ad6b5af4f9579b21bd562eb2">f59dba325a55dd25ad6b5af4f9579b21bd562eb2</a>
-<blockquote>
-<p>
- Bug 690878: have ghostpdl use HAVE_FILE64 setting<br>
-<br>
- The GhostPDL configure checked for, but the config.mak.in never used the setting<br>
- for HAVE_FILE64.<br>
-<br>
- Add it in.<br>
-<br>
- No cluster differences.<br>
-<br>
-config.mak.in<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-07 17:21:27 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=31120fdcbb3f1ab815ade3763b638b77bd9b3d76">31120fdcbb3f1ab815ade3763b638b77bd9b3d76</a>
-<blockquote>
-<p>
- Bug 690776: missing check for HAVE_MKSTEMP64<br>
-<br>
- Oddly, the ghostpdl configure.ac checked for mkstemp64 but config.mak.in did not<br>
- have the substitution pattern for the -DHAVE_MKSTEMP64.<br>
-<br>
- So add that in.<br>
-<br>
- No cluster differences.<br>
-<br>
-config.mak.in<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-07 15:37:37 +0000
-</strong>
-<br>Dr. Werner Fink &lt;werner@suse.de&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a4a912b43ae85b8c3d07f6d4727ced14b2e102a">4a4a912b43ae85b8c3d07f6d4727ced14b2e102a</a>
-<blockquote>
-<p>
- Bug 690571: deal with memory dev/xdev dimensions being different.<br>
-<br>
- For GV (and ghostview) a memory deivce is used. The problem is now<br>
- that most time the width and height of the memory device is not<br>
- identical with the xdev device its self. Also extrem large bbox<br>
- can lead to problems on systems with less physical memory.<br>
-<br>
- This patch avoids these two problems.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/devices/gdevx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-07 20:12:14 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c4357befbf3d09c50c4208bbb5dd9864269bf9b3">c4357befbf3d09c50c4208bbb5dd9864269bf9b3</a>
-<blockquote>
-<p>
- Fix previous tweak to clist line_ptrs.<br>
-<br>
- The calculation for the clist line_ptrs used before was broken; I guess<br>
- this proves that we weren't relying on it in most cases. This solves<br>
- a few SEGVs.<br>
-<br>
-gs/base/gdevppla.c<br>
-gs/base/gxclread.c<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-07 18:29:46 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=64a57147f683bfbf4c9f2bfcd978e8bcbd87ad97">64a57147f683bfbf4c9f2bfcd978e8bcbd87ad97</a>
-<blockquote>
-<p>
- Fix SEGV in psdcmyk cluster tests.<br>
-<br>
- tests_private/comparefiles/09_47N.PDF.300.1 SEGVs due to typo in<br>
- gx_forward_strip_tile_rect_devn.<br>
-<br>
-gs/base/gdevnfwd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-07 09:49:47 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1805749a2338844f19a3c7d336fd4707d04b13de">1805749a2338844f19a3c7d336fd4707d04b13de</a>
-<blockquote>
-<p>
- Fix fpng crash, file has_transparency<br>
-<br>
- In clist_playback_band, it checks to see if there is a compositor as<br>
- the target, and needs to free it, but it should not close the device<br>
- if its is_open is false, since that would forward the close to the<br>
- orig_target, closing the memory device. The pdf14 pop_device had<br>
- already done the pdf14_close and set the procs to forward.<br>
-<br>
-gs/base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-07 17:23:40 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6efb9ed5890e7b56814699f6e374de97602a0a1b">6efb9ed5890e7b56814699f6e374de97602a0a1b</a>
-<blockquote>
-<p>
- Squash some warnings.<br>
-<br>
-gs/base/gdevmem.c<br>
-gs/base/gdevmpla.c<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevppla.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_nocm.c<br>
-gs/base/gxccman.c<br>
-gs/base/gxclthrd.c<br>
-gs/base/gximage3.c<br>
-gs/base/gxpcmap.c<br>
-gs/devices/gdevpsd.c<br>
-gs/devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-07 15:47:19 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=432f71e687183df4971c0bee1932fb57ef0295a1">432f71e687183df4971c0bee1932fb57ef0295a1</a>
-<blockquote>
-<p>
- Tweak clist line_ptrs data.<br>
-<br>
- The clist has always allocated space for the memory device as if<br>
- the line_ptrs were to be included within the allocated space, but<br>
- has never actually put the line_ptrs into this space.<br>
-<br>
- Consequently the memory device always allocates space for the<br>
- line_ptrs itself. This space is then freed on a close_device call.<br>
-<br>
- This can present problems in NumRenderingThreads mode, when<br>
- process_page is used. With the existing code, within clist_render_thread,<br>
- the buffer device is setup (and the new line_ptrs block is allocated).<br>
- The device is then freed at the end of clist_playback_band<br>
- (called from clust_render_rectangle). This nukes the line_ptrs<br>
- leaving the get_bits_rectangle call from within the process_fn call<br>
- to fail when dereferencing NULL.<br>
-<br>
- The fix here is to amend the clist device structure to include the<br>
- offset within the block that the line_ptrs should be allocated at.<br>
- This offset can then be used to pass in the address of the line_ptrs<br>
- to the setup_buffer_device call. This means the line_ptrs survive<br>
- device closing.<br>
-<br>
- This still leaves questions (in my mind at least) as to whether the<br>
- handling of the device closures within clist_playback_band is correct<br>
- or not.<br>
-<br>
-gs/base/gxband.h<br>
-gs/base/gxclist.c<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-07 10:37:34 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cfeb9f98b896384ac366f4e30f3653a52de7af87">cfeb9f98b896384ac366f4e30f3653a52de7af87</a>
-<blockquote>
-<p>
- pdfwrite - add a Resources dictionary to 'Group' dictionaries<br>
-<br>
- Bug #693322 &quot;Acrobat Preflight tool reports missing XObjects&quot;<br>
-<br>
- Crazy Cairo-constructed files can result in Group dictionaries which use<br>
- other resources (in this case an ExtGState) and this wasn't possible in<br>
- the existing code. This commit adds a Resources dictionary so that it is<br>
- now possible to recreate this.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-07 09:15: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=6c5ecdf1a54e9d5a572c11860492abce06523f24">6c5ecdf1a54e9d5a572c11860492abce06523f24</a>
-<blockquote>
-<p>
- Bug 694718: &quot;reset&quot; MT fonts for each glyph.<br>
-<br>
- Seems some vesions of UFST require the font object to be recreated for each<br>
- glyph to work correctly. So when I fixed the optimisation in gxfapi.c to<br>
- avoid calling &quot;get_scaled_font()&quot; when the font parameters had not changed, it<br>
- exposed the problem with the UFST integration.<br>
-<br>
- To address this, the fapi/ufst code now zeros out the stored scale matrix for<br>
- MT fonts, so the code in gxfapi.c always registers the scaling as having<br>
- changed. Luckily, recreating the MT font object is not a very expensive<br>
- operation.<br>
-<br>
- Also, grab the design units scale from the UFST state structure if the values<br>
- haven't been set in the outline structure.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/fapiufst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-07 08:27:47 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=58cdefdeadbceda4833e489b6d94f5895a2d8ea4">58cdefdeadbceda4833e489b6d94f5895a2d8ea4</a>
-<blockquote>
-<p>
- pdfwrite - check a return code<br>
-<br>
- Silences a compiler warning (and is the right thing to do of course)<br>
-<br>
-gs/devices/vector/gdevpdft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-06 09:18:19 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=616ff4cc44b00bcf7df97b64c8bdaebbe0620713">616ff4cc44b00bcf7df97b64c8bdaebbe0620713</a>
-<blockquote>
-<p>
- pdfwrite - add transparency Group to substream resources<br>
-<br>
- Bug #691352 &quot;cairo pdf mis-distilled.&quot;<br>
-<br>
- This fixes the last remaining problem with this old bug. When we were<br>
- creating Form XObjects (because of transparency groups) we were assuming<br>
- that the from was a child of the page.<br>
-<br>
- However, groups nested within groups (uncommon, except with Cairo's awful<br>
- output) can cause a Form XObject to have children which are also Form<br>
- XObjects. In this case we need to have the Form (or other substream) add<br>
- the child form to its own Resources rather than inheriting them from the<br>
- Page.<br>
-<br>
- This also addresses (most of) Bug #693332 though this still leaves a<br>
- dangling ExtGState which needs separate investigation.<br>
-<br>
- No Differences expected<br>
-<br>
-gs/devices/vector/gdevpdft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-04 18:32:21 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=29a06fed84063976abe9864659384e7e371d799e">29a06fed84063976abe9864659384e7e371d799e</a>
-<blockquote>
-<p>
- Add alignment and padding code.<br>
-<br>
- Every time we create a new device in the code, we need to copy<br>
- the pad and align values from the 'base' device to the new device.<br>
-<br>
- Build with TEST_PAD_AND_ALIGN defined to force on for pxmraw and psdcmyk.<br>
-<br>
-gs/base/gdevdevn.c<br>
-gs/base/gdevmem.c<br>
-gs/base/gdevmpla.c<br>
-gs/base/gdevppla.c<br>
-gs/base/gdevprn.c<br>
-gs/base/gxbitmap.h<br>
-gs/base/gxclthrd.c<br>
-gs/devices/gdevpbm.c<br>
-gs/devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-01 17:30:00 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b3aec5521e0e5d84164285353af20a5163139c3f">b3aec5521e0e5d84164285353af20a5163139c3f</a>
-<blockquote>
-<p>
- Remove is_native_planar.<br>
-<br>
-gs/base/gdevdevn.c<br>
-gs/base/gdevdflt.c<br>
-gs/base/gdevdrop.c<br>
-gs/base/gdevmem.c<br>
-gs/base/gdevmpla.c<br>
-gs/base/gdevnfwd.c<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevppla.c<br>
-gs/base/gsdevice.c<br>
-gs/base/gsovrc.c<br>
-gs/base/gxccman.c<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclip.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclrect.c<br>
-gs/base/gxdevsop.h<br>
-gs/base/gxht_thresh.c<br>
-gs/base/gxicolor.c<br>
-gs/base/gximage3.c<br>
-gs/base/gximono.c<br>
-gs/base/gxp1fill.c<br>
-gs/base/gxpcmap.c<br>
-gs/devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-01 16:47:06 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6946de99dd19c7a883d7edb28b4f52290e3e934">f6946de99dd19c7a883d7edb28b4f52290e3e934</a>
-<blockquote>
-<p>
- Steps towards supporting aligned and padded buffer devices.<br>
-<br>
- Introduce log2_align_mod, pad and num_planes to the gx_device<br>
- structure. Values of 0 will cause no changes to default behaviours.<br>
-<br>
-gs/base/gdevppla.c<br>
-gs/base/gdevprn.c<br>
-gs/base/gsdevice.c<br>
-gs/base/gxclread.c<br>
-gs/base/gxdevcli.h<br>
-gs/base/gxdevice.h<br>
-gs/base/gxdevmem.h<br>
-gs/devices/gdevbit.c<br>
-gs/devices/gdevplib.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-04 17:23:28 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a8f9934aa6c54830230f749280765ea4e65471d2">a8f9934aa6c54830230f749280765ea4e65471d2</a>
-<blockquote>
-<p>
- pdfwrite - fix some XML emission<br>
-<br>
- Bug #694736 &quot;PDF/A XMP dc:description - wrong element structure&quot;<br>
-<br>
- The dc:creator is specified as a text sequence, but we were also emitting<br>
- the dc:description that way, which is clearly wrong.<br>
-<br>
-gs/devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-04 15:09:03 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f09f7f7cd37f3a52f733019e1d383034dd1c01cf">f09f7f7cd37f3a52f733019e1d383034dd1c01cf</a>
-<blockquote>
-<p>
- pdfwrite - revert a4de55 and check for parentheses properly instead<br>
-<br>
- Bug #694735 &quot;PDF/A XMP metadata and DOCINFO synchronization&quot;<br>
-<br>
- The commit a4de55 was incorrect, the PDF/A spec clearly states that the<br>
- XML creator is based on the Author. However, when an empty string is<br>
- present for the Document Info entry, we should not write the string parentheses<br>
- into the XML, this is clearly incorrect.<br>
-<br>
-<br>
- Still no differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-04 13:41: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=a4de55d2fd0fa38e5110e7b5d5cca746528b28f6">a4de55d2fd0fa38e5110e7b5d5cca746528b28f6</a>
-<blockquote>
-<p>
- pdfwrite - use /Creator instead of /Author for the XML creator entry<br>
-<br>
- Bug #694735 &quot;PDF/A XMP metadata and DOCINFO synchronization&quot;<br>
-<br>
- We were using the Document Info /Author field for the XML 'creator' which<br>
- apparently causes at least one PDF/A validator to take offence. Its not<br>
- entirely clear to me from the documentation which one is inteded to be<br>
- here, so we'll just use /Creator instead.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-04 09:26:47 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ee0bf17f4912f131f7ad98aab744e571a18ece39">ee0bf17f4912f131f7ad98aab744e571a18ece39</a>
-<blockquote>
-<p>
- pdfwrite/ps2write colour management, enable the new code<br>
-<br>
- Change the default setting of teh colour management switch so that we<br>
- default to using the new code.<br>
-<br>
- If we are creating PDF/A-1, force the old colour management, we can't yet<br>
- guarantee that we are getting a version 2 profile.<br>
-<br>
- Add some minimal documentation in ps2pdf.htm, hopefully we will do some<br>
- more work in this area before release, and the documentation can be revamped.<br>
-<br>
- This change results in a lot of differences, especially with ps2write. In<br>
- the main these are slight shifts in color values caused by using a different<br>
- (better) conversion system. However, the new code does a much better job<br>
- of handling some kinds of colour spaces, in particular Separation spaces<br>
- with ps2write which are now preserved. This leads to a number of progressions<br>
- in the test suite.<br>
-<br>
- I've looked at all the differences and I believe they are all either very<br>
- minor colour shifts, or progressions.<br>
-<br>
- This is with 'LeaveColorUnchanged', actually converting to different spaces<br>
- does result in differences but this can't be cluster tested. I believe these<br>
- are all progressions however.<br>
-<br>
-gs/devices/vector/gdevpdfb.h<br>
-gs/devices/vector/gdevpdfp.c<br>
-gs/doc/Ps2pdf.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-02 12:21:21 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=41e1bdc7ef06bd00874890b36a53d84166ef30d0">41e1bdc7ef06bd00874890b36a53d84166ef30d0</a>
-<blockquote>
-<p>
- pdfwrite - colour code, do not apply range limiting for images<br>
-<br>
- When handling an image in a Lab space, do not reset the range of the space.<br>
- We don't need to when preserving an image, and if we use the same space<br>
- immediately afterward for linework, the range clamping causes the components<br>
- to come out black.<br>
-<br>
- No differences, code is not used yet.<br>
-<br>
-gs/devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-02 12:19:03 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eada430a0c612f5f50a9fea6416daa048464a5c3">eada430a0c612f5f50a9fea6416daa048464a5c3</a>
-<blockquote>
-<p>
- pdfwrite - coiour code, silence some compiler warnings<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpsdu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-01 11:01:02 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=82bfa31f2f423223b002aab74323927e8ee42ea0">82bfa31f2f423223b002aab74323927e8ee42ea0</a>
-<blockquote>
-<p>
- Add in some missing checks for failed allocations in gsicc code.<br>
-<br>
- There are a couple of functions that are 'void' that just return,<br>
- which seems like should be fixed. Also fix _cmsCalloc in gsicc_lcms.c<br>
- to actually clear the memory.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_lcms.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_nocm.c<br>
-gs/base/gsicc_profilecache.c<br>
-gs/base/gsicc_replacecm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-11-01 08:32: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=b937b04503837d2ac6f3877478b5500f4bc8ea8a">b937b04503837d2ac6f3877478b5500f4bc8ea8a</a>
-<blockquote>
-<p>
- pdfwrite/ps2write - colour code work<br>
-<br>
- 1) Rescale inputs to 0-&gt;1 before concretizing if the space is specifically<br>
- Lab. Required as the inputs to the ICC profile must be 0-&gt;1. gx_remap_color<br>
- and its children do this for us, but gx_concretize_color does not.<br>
-<br>
- 2) Do not corrupt the device color from the interpreter if we are converting<br>
- to a different colour space, use a temporary structure instead.<br>
-<br>
- 3) Make sure to use frac2float after concretizing to convert the values.<br>
-<br>
- 4) Don't forget to update the saved colour (in the device) after we've<br>
- converted colours.<br>
-<br>
- 5) Update pdsdf_set_color so that if we are using the new colour code we<br>
- get the expected number of output components from the ICC profile attached<br>
- to the device, rather than the device 'color_info'. Update all calls to<br>
- psdf_set_color so that they pass in the required boolean.<br>
-<br>
- This code is still switched off by default, so no cluster differences will<br>
- show up.<br>
-<br>
-gs/devices/vector/gdevpdfc.c<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpdfv.c<br>
-gs/devices/vector/gdevpsdf.h<br>
-gs/devices/vector/gdevpsdu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-31 07:11:47 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5929829c83498b2694bd32cf3579e151c1c99f0d">5929829c83498b2694bd32cf3579e151c1c99f0d</a>
-<blockquote>
-<p>
- Added support for VS2013 to msvc.mak.<br>
-<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-30 17:56:00 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b87f410b4084c84242c254c70c379b96c8fca2d7">b87f410b4084c84242c254c70c379b96c8fca2d7</a>
-<blockquote>
-<p>
- Ensure that gdev_prn_dev_spec_op forwards to the real device.<br>
-<br>
- When the clist hijacks all the device entries, it attempts to forward<br>
- the dev_spec_op calls to the generic printer device. This doesn't<br>
- help when we have a device specific one. Only the printer device<br>
- knows what the original procs were, so the best we can do is to have<br>
- gdev_prn_dev_spec_op forwarding.<br>
-<br>
- This was important as the adjust_bandheight gxdso call was not making<br>
- it through to the underlying device.<br>
-<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevprn.h<br>
-gs/base/gxclist.h<br>
-gs/base/gxclrect.c<br>
-gs/base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-24 21:07: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=bdf630af4252ba87bffa6108840bac53f4754cea">bdf630af4252ba87bffa6108840bac53f4754cea</a>
-<blockquote>
-<p>
- Remove unnecessary code.<br>
-<br>
- The test is unneccessary due to us being within a if.<br>
-<br>
-gs/base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-31 10:10: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=9c77012daa9b1903d7be5fc4f239a46df863d0db">9c77012daa9b1903d7be5fc4f239a46df863d0db</a>
-<blockquote>
-<p>
- Add quotes to conditional for safety.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/msvclib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-30 14:19:06 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=75a8be6597d6ce56182c5391d6be02f997a1aa21">75a8be6597d6ce56182c5391d6be02f997a1aa21</a>
-<blockquote>
-<p>
- Addition of code to test if current ICC color space is the same as new ICC color space<br>
-<br>
-gs/psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-30 18:30: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=5c511841cbe373743165e2248adc583382ca3b2a">5c511841cbe373743165e2248adc583382ca3b2a</a>
-<blockquote>
-<p>
- Avoid warning for missing (not required) encoding for PDFs<br>
-<br>
- Check earlier for the existence of an encoding entry in a PDF font object,<br>
- for font types in which encoding is optional. Avoids a benign but annoying<br>
- warning from the PDF interpreter.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-28 18:45:31 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c186880d7e3651c8a76e55bc981fc22e4a57ea94">c186880d7e3651c8a76e55bc981fc22e4a57ea94</a>
-<blockquote>
-<p>
- Bug 694733 (part 2): ensure jmp_buf alignment is correct<br>
-<br>
- Move the jmp_buf used by the HP/GL parser to be a local variable, accessed<br>
- via a pointer in the state (rather than directly allocated within the state).<br>
-<br>
- This ensures that any alignment requirements are met - specifically, 64 bit<br>
- MS Visual Studio 2010 requires that jmp_bufs be aligned to 16 byte boundaries.<br>
-<br>
- No cluster differences.<br>
-<br>
-pcl/pgmand.h<br>
-pcl/pgparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-28 11:08:19 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=16fbdade9a29352ad936455eab65e77a9db6f768">16fbdade9a29352ad936455eab65e77a9db6f768</a>
-<blockquote>
-<p>
- Bug 694733 (part 1): fix incorrect offsets in chunk allocator<br>
-<br>
- When I changed the chunk allocator to honor the alignment value for the<br>
- memory manager, I missed a couple of places where the calculation of the offset<br>
- to get from the allocated memory address to the address of the chunk node.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsmchunk.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-26 13:42: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=8f491ec1493bcb11583d450a264a1b80d5557217">8f491ec1493bcb11583d450a264a1b80d5557217</a>
-<blockquote>
-<p>
- Fix 694737 - Typeface mask incorrect.<br>
-<br>
- The typeface value is in the first 12 bits and the vendor info in the<br>
- next 4 bits of the short value that stores typeface information. We<br>
- were extracting the first 11 bits for the typeface. This problem is<br>
- not associated with a known bug, and in fact, it is quite unlikely to<br>
- result in a problem, but it is incorrect. Thanks to Norbert Janssen<br>
- for pointing out the problem.<br>
-<br>
-pcl/pcfsel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-24 20:22:18 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1b691ea92ead0590c619ec64a00d93f24452bb2c">1b691ea92ead0590c619ec64a00d93f24452bb2c</a>
-<blockquote>
-<p>
- Fix Luratech build (by removing spurious JPX_AUTOCONF_CFLAGS= from configure.ac).<br>
-<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-24 20:03:15 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5c08e60fc75c940ce6c6df1e75802ce2d72fbd2f">5c08e60fc75c940ce6c6df1e75802ce2d72fbd2f</a>
-<blockquote>
-<p>
- Fix bug 694725 - bad characters in numeric input not processed<br>
- correctly.<br>
-<br>
- Thanks to Norbert Janssen for finding and fixing this problem.<br>
-<br>
-pcl/pcparse.c<br>
-pcl/pcparse.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-24 08:59:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=184dcfd570a96328798e36d8e08495eb426d67f9">184dcfd570a96328798e36d8e08495eb426d67f9</a>
-<blockquote>
-<p>
- Allow user to override configure's color index setting<br>
-<br>
- This command line parameter is not listed in the &quot;configure --help&quot; output<br>
- as it is really intended for our use, and not generally by end users.<br>
-<br>
- To build with 32 bit colour indices, issue:<br>
- ./configure --with-large_color_index=0<br>
-<br>
- to build with 64 bit color indices:<br>
- ./configure --with-large_color_index=1<br>
-<br>
- This works for both Ghostscript and GhostPDL builds.<br>
-<br>
- The only &quot;wrinkle&quot; is that Ghostscript default to:<br>
- &quot;--with-large_color_index=1&quot; (so 64 bit indices)<br>
-<br>
- whilst GhostPDL defaults to:<br>
- &quot;--with-large_color_index=0&quot; (so 32 bit indices)<br>
-<br>
- This retains the previous default settings.<br>
-<br>
- No cluster differences.<br>
-<br>
-config.mak.in<br>
-configure.ac<br>
-gs/configure.ac<br>
-main/pcl6_gcc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-22 11:09:23 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=38ed5ffaf81405a3e8ff094afbc2ada05eaf630c">38ed5ffaf81405a3e8ff094afbc2ada05eaf630c</a>
-<blockquote>
-<p>
- Fix for bug in case where alternate color space for DeviceN and separation is CIE<br>
-<br>
- If the CIE color space has a range different than 0 to 1 we need to rescale before using<br>
- the equivalent ICC profile. Fixes bug 694731. Note diffs for 09-34.PS match what is<br>
- created by Distiller and AR vers. X.<br>
-<br>
-gs/base/gscdevn.c<br>
-gs/base/gsciemap.c<br>
-gs/base/gscsepr.c<br>
-gs/base/gsicc.c<br>
-gs/base/gxcie.h<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-23 16:09: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=c7cca8f105194908bb1b28b3e6606be51533b6d9">c7cca8f105194908bb1b28b3e6606be51533b6d9</a>
-<blockquote>
-<p>
- Fix possible (but very unlikely) SEGV and warning.<br>
-<br>
- It is extremely unlikely that options will be NULL, but check to be<br>
- sure.<br>
-<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-23 12:53:49 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d76e3a434e699f8974f50d98c0b7e82042fdc7ec">d76e3a434e699f8974f50d98c0b7e82042fdc7ec</a>
-<blockquote>
-<p>
- Clean a few #defines out of psdcmyk device.<br>
-<br>
- Not needed since the transition away from compressed color encoding<br>
- to planar operation.<br>
-<br>
-gs/devices/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-23 14:34: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=ad3e3ed7913986cec6acbc1afe0eff0c57627ddc">ad3e3ed7913986cec6acbc1afe0eff0c57627ddc</a>
-<blockquote>
-<p>
- Bug 694734: handle Type 0 font in annotation<br>
-<br>
- The code to generate an appearance from an annotation with an AP, the code<br>
- required the FontBBox, but failed to take account that the FontBBox is not<br>
- required in a Type 0 font.<br>
-<br>
- We now handle it by grabbing the FontBBox from the descendant font - for<br>
- which a FontBBox is mandatory.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-22 08:23:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ee941e19870761a752277f08c82282f53f4d4fee">ee941e19870761a752277f08c82282f53f4d4fee</a>
-<blockquote>
-<p>
- Bug 694722: force ptr alignment to 8 bytes for HP-UX<br>
-<br>
- Like Solaris/SPARC, HP-UX appears to require pointer alignment to be 8 bytes<br>
- even when user space pointers are 32 bits.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/genarch.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-21 13:34: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=25db24cbeb52621cd1e2ae3e79d9b06c97143bc3">25db24cbeb52621cd1e2ae3e79d9b06c97143bc3</a>
-<blockquote>
-<p>
- Add documentation for process_page.<br>
-<br>
-gs/doc/Drivers.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-22 13:08:14 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d2612770174079f423d704af4f68f6c85f63905a">d2612770174079f423d704af4f68f6c85f63905a</a>
-<blockquote>
-<p>
- Update fpng device to use downscaler.<br>
-<br>
-gs/devices/gdevfpng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-18 18:36: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=ae8611c998beaad5e6f0cd2b85abb1b1995d94c4">ae8611c998beaad5e6f0cd2b85abb1b1995d94c4</a>
-<blockquote>
-<p>
- Add fpng device.<br>
-<br>
- Example 'fastpng' device for process_page.<br>
-<br>
-gs/devices/devs.mak<br>
-gs/devices/gdevfpng.c<br>
-gs/ghostscript.vcproj<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-18 22:14: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=afe18de12b530d8d95a132755516847e8fc3f88e">afe18de12b530d8d95a132755516847e8fc3f88e</a>
-<blockquote>
-<p>
- Add gxdso_adjust_bandheight<br>
-<br>
- Add mechanism for adjusting the bandheight. Intended to allow devices to<br>
- exert fine control over bandheight while ghostscript still handles the<br>
- gross sizing. An example would be the downscaler ensuring that bands are<br>
- multiples of the given downscale.<br>
-<br>
-gs/base/gxclist.c<br>
-gs/base/gxdevsop.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-22 13:06:40 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=edd06c70150166780f1360a42499569f3a52903e">edd06c70150166780f1360a42499569f3a52903e</a>
-<blockquote>
-<p>
- Update downscaler to allow for process_page operation.<br>
-<br>
- (No error diffusion in this mode, as bands need to be independent).<br>
-<br>
-gs/base/gxdownscale.c<br>
-gs/base/gxdownscale.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-21 12:03:42 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ca5a608fe9062492f53c80eccb8b78dbdb997499">ca5a608fe9062492f53c80eccb8b78dbdb997499</a>
-<blockquote>
-<p>
- Add default process_page implementation.<br>
-<br>
- This serves to handle the page mode case.<br>
-<br>
-gs/base/gdevdflt.c<br>
-gs/base/gxdevice.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-18 18:36:26 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a25313d4518a942d74528ee7b6a52c96aa0128b6">a25313d4518a942d74528ee7b6a52c96aa0128b6</a>
-<blockquote>
-<p>
- Add process_page entry point.<br>
-<br>
- Add clist implementation (both threaded and non-threaded) for process_page.<br>
-<br>
-gs/base/gxcldev.h<br>
-gs/base/gxclist.c<br>
-gs/base/gxclthrd.c<br>
-gs/base/gxclthrd.h<br>
-gs/base/gxdevcli.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-21 11:54: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=d7bff9b2f7230b527765661ea721d4b60e0e4154">d7bff9b2f7230b527765661ea721d4b60e0e4154</a>
-<blockquote>
-<p>
- pdfwrite - free Named Images stack before clearing local/global named objects<br>
-<br>
- Bug #694136 &quot;Seg faults found by fuzzing in cos_value_free&quot;<br>
-<br>
- If we stored named images in the initial name space then when we closed<br>
- the PDF file we would free and delete the local named objects before we<br>
- freed the named images stack. If the named images stack included entries<br>
- stored in the local named objects stack then we would attempt to free an<br>
- object which was already freed.<br>
-<br>
- So we clear the named images stack first, for added safety we ensure we<br>
- clear the NI stack before global named objects are freed too.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-19 10:50: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=8dbe789dec0a8be00942849f768648da60ee3336">8dbe789dec0a8be00942849f768648da60ee3336</a>
-<blockquote>
-<p>
- pdfwrite - do not compose font name with CMAp when creating a CIDFOnt<br>
-<br>
- Bug #694721 &quot;Issued with font names in pdfwrite device&quot;<br>
-<br>
- When creating a CIDFont for output to a PDF file, we created the name by<br>
- composing the CIDFont name with the CMap originally used with the font.<br>
- However, this doesn't make sense, the CIDFont we emit is not composed with<br>
- that CMap, its usually composed with an Identity CMap. The CIDFont is<br>
- still arranged according to the original CMap, but this is the Ordering<br>
- of the font, not the CMap being used with it, and we record that Ordering<br>
- (should it be useful for anything) in the CIDSystemInfo.<br>
-<br>
- We now do not add the CMap name to the CIDfont name, which allows Acrobat<br>
- to do a 'better' job of copy and paste (apparently it passes the font name<br>
- along).<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdtf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-18 18:33: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=7936b2643f2577fb70fdf2b8d9e3af5c8058668d">7936b2643f2577fb70fdf2b8d9e3af5c8058668d</a>
-<blockquote>
-<p>
- Fix memory leak on error in gxclimag.c<br>
-<br>
- If we fail to allocate pie-&gt;buffer, there is no need to free it during<br>
- the clean up. On the other hand, it's probably a good idea to free 'pie'.<br>
-<br>
- Also, for good style, if nothing else, avoid pinfo being returned with<br>
- a dangling pointer.<br>
-<br>
-gs/base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-17 21:06:02 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=357ec4e2553a80c2bb6df29bb33ad095ac343242">357ec4e2553a80c2bb6df29bb33ad095ac343242</a>
-<blockquote>
-<p>
- Fix Bug694714. Clamp the ymin/ymax values to valid device coordinates.<br>
-<br>
- In write_image_end_all, we could advance to a band past the end of the<br>
- page that didn't have a pcls in the states array, causing a segfault<br>
- when garbage values were used.<br>
-<br>
-gs/base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-18 11:35: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=b21c6dd0fc782709712307f58fe0685634c6db30">b21c6dd0fc782709712307f58fe0685634c6db30</a>
-<blockquote>
-<p>
- pdfwrite - Improve robustness of type 1 font interpreter<br>
-<br>
- Bug #694214 &quot;Seg faults found by fuzzing in type1_next&quot;<br>
-<br>
- The font is corrupted and one of the glyph instrctions performs a 'return'<br>
- without previously executing a subroutine. This caused the font interpreter<br>
- to crash.<br>
-<br>
- We now check when executing a return to see if we are not in the main glyph<br>
- program, if we are, we return an invalidfont error.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpsfx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-17 12:56: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=fc7ead6d34638a521a48debeb9437eac4e82ef98">fc7ead6d34638a521a48debeb9437eac4e82ef98</a>
-<blockquote>
-<p>
- pdfwrite - some casts to prevent compiler warnings<br>
-<br>
-gs/devices/vector/gdevpdfc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-17 12:08: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=3cd2f7878bdae2d954ab27906336a9b87a267cd9">3cd2f7878bdae2d954ab27906336a9b87a267cd9</a>
-<blockquote>
-<p>
- pdfwrite colour code - after concretizing a DeviceN space, don't attempt to convert it again<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-17 12:07: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=bbb32ec3f43405bd794f5d60f58f2d1bb7f5546b">bbb32ec3f43405bd794f5d60f58f2d1bb7f5546b</a>
-<blockquote>
-<p>
- pdfwrite colour - ensure icc_equivalent is set before trying to use it.<br>
-<br>
-gs/devices/vector/gdevpdfc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-17 08:19: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=88df0b8fe9cce08b30ae7b12d6a1e8aa104981e2">88df0b8fe9cce08b30ae7b12d6a1e8aa104981e2</a>
-<blockquote>
-<p>
- pdfwrite - check before dereferencing a pointer<br>
-<br>
- Bug #694716 - &quot;seg fault with pdfwrite&quot;<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-16 09:26:35 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=82fc3bd9f058974403d9f9ff9945391a6b8b20f6">82fc3bd9f058974403d9f9ff9945391a6b8b20f6</a>
-<blockquote>
-<p>
- The color index size was not transmitted properly from the MSVC<br>
- PCL/PXL/XPS makefiles to the Ghostscript makefile system.<br>
-<br>
-common/msvc_top.mak<br>
-gs/base/msvclib.mak<br>
-gs/psi/msvc.mak<br>
-main/pcl6_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-16 00:59:19 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e9b3ce974cbd12452ae11ff1ff4cd48e4a261a9">8e9b3ce974cbd12452ae11ff1ff4cd48e4a261a9</a>
-<blockquote>
-<p>
- Add downscaler support to pngalpha.<br>
-<br>
-gs/devices/gdevpng.c<br>
-gs/doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-15 10:31:33 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a438d95a859b430e58ef448a0995aa13cefac172">a438d95a859b430e58ef448a0995aa13cefac172</a>
-<blockquote>
-<p>
- Minor fixes for use of equivalent ICC profiles from PS objects with pdfwrite<br>
-<br>
-gs/base/gsicc_cache.c<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-14 16:56:25 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a441022bfe6f59dacdca40ce60c37ee02adfa07">9a441022bfe6f59dacdca40ce60c37ee02adfa07</a>
-<blockquote>
-<p>
- Fix for error when nos had shape and alpha_g during compositing.<br>
-<br>
-gs/base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-14 10:30:03 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c1f1619da98236ea06c4fdb1ea403d5ab990e08">1c1f1619da98236ea06c4fdb1ea403d5ab990e08</a>
-<blockquote>
-<p>
- Make sure to set the soft mask opacity to one so that we do not apply the<br>
- global path opacity multiple times when we have an opacity and a soft mask<br>
- from an image. Fix for Bug 694705<br>
-<br>
-xps/xpsgradient.c<br>
-xps/xpsimage.c<br>
-xps/xpsopacity.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-14 17:14: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=a0b7b91e2ca181e06fe11a89c5240e78b6e31aaf">a0b7b91e2ca181e06fe11a89c5240e78b6e31aaf</a>
-<blockquote>
-<p>
- pdfwrite - check return values from 'convert color'<br>
-<br>
- Bug #694221 &quot;Valgrind issues found by fuzzing in choose_DCT_params (gdevpsdi.c:156)&quot;<br>
-<br>
- In the past convert_color could not fail, with ICC handling, it can, so<br>
- we need to check the return code and handle errors gracefully.<br>
-<br>
- This would not in fact have caused problems, but we fix it anyway.<br>
-<br>
-gs/devices/vector/gdevpsdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-11 16:18:32 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d28da52a57923eb76503277d8be2eb0c72165599">d28da52a57923eb76503277d8be2eb0c72165599</a>
-<blockquote>
-<p>
- Fix free mistake made in knockout commit http://git.ghostscript.com/?p=ghostpdl.git;a=commit;h=2d2cc321df4223fd7cf64946ac2fa963fa1cea3d<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-11 15:33: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=561b37fb083fa0dc32ea81b4aaea38607db05814">561b37fb083fa0dc32ea81b4aaea38607db05814</a>
-<blockquote>
-<p>
- Remove the -dDisableFAPI hack from the &quot;languages&quot; builds<br>
-<br>
- No cluster differences.<br>
-<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-11 15:24: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=31ca73d856f974c7e1422948b2fb5794af55bf58">31ca73d856f974c7e1422948b2fb5794af55bf58</a>
-<blockquote>
-<p>
- Have FAPI honor GridFitTT parameter.<br>
-<br>
- The FAPI code now passes the GridFitTT parameter onto the scaler/renderer<br>
- interface code.<br>
-<br>
- The default setting is now &quot;1&quot; for using the bytecode hinting. &quot;0&quot; disables<br>
- all TTF hinting, and &quot;2&quot; (with Freetype) enables Freetype's &quot;autohinting&quot;<br>
- algorithm. With other scalers the paramter currently has no effect, and<br>
- the &quot;2&quot; setting will *always* be scaler dependent.<br>
-<br>
- Causes differences in pretty much every cluster PCL file containing TTF<br>
- glyphs as (and I still think this is a bad idea) PCL disables hinting at 300<br>
- dpi and above. No differences in PS/PDF/XPS/PXL jobs.<br>
-<br>
-gs/base/fapi_ft.c<br>
-gs/base/fapibstm.c<br>
-gs/base/fapiufst.c<br>
-gs/base/gsfont.c<br>
-gs/base/gxfapi.c<br>
-gs/base/gxfapi.h<br>
-gs/doc/Language.htm<br>
-pl/plfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-11 09:45:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9c13e3b9e735ba119f58c751a51fc55efef15a0c">9c13e3b9e735ba119f58c751a51fc55efef15a0c</a>
-<blockquote>
-<p>
- xps interpreter - correct high level pattern handling<br>
-<br>
- A silly error was causing fills to be applied twice. For opaque fills this<br>
- is merely a performance penalty but for transparent fills the result is<br>
- incorrect.<br>
-<br>
- Thanks to Phil McSharry for identifying the problem and supplying a solution.<br>
-<br>
- This shows progressions in a number of test files.<br>
-<br>
-xps/xpspath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-11 08:09: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=6e10e787517ae0212ada6b7735542cbb4c41040c">6e10e787517ae0212ada6b7735542cbb4c41040c</a>
-<blockquote>
-<p>
- Squash a scan-build compiler warning.<br>
-<br>
- Prevent any possibility of a null-pointer dereference.<br>
-<br>
-gs/base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-10 13:34: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=72afba4af187b01fded403d6a986d5de0be741d2">72afba4af187b01fded403d6a986d5de0be741d2</a>
-<blockquote>
-<p>
- txtwrite - fix UTF-8 output Bug #694690<br>
-<br>
- Thanks to r_one_guy@yahoo.fr for pointing this out and supplying a fix. The<br>
- UTF-8 output was incorrect for Unicode values between 0x80 and 0x7FF.<br>
-<br>
- Also, we weren't outputting a BOM for Unicode (UCS2) output.<br>
-<br>
- Not cluster tested<br>
-<br>
-gs/devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-10 12:15: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=f924bf4d2bb4243ebe771e7e42bf1df3e41f415a">f924bf4d2bb4243ebe771e7e42bf1df3e41f415a</a>
-<blockquote>
-<p>
- pdfwrite - don't emit extra blank page with '%d' output file spec<br>
-<br>
- Bug #694576 &quot;Using %d with pdfwrite results in extra, blank page&quot;<br>
-<br>
- Added a flag to the PDF device structure so that we can tell if pdf_close<br>
- has been called as the result of outputting a page. If it has not, and<br>
- the page is unmarked, and we are outputting in 'file per page' mode, then<br>
- we don't emit the page.<br>
-<br>
- However, this leads to a 0 byte output file, so we also need to delete the<br>
- current output file. There seemed to be no obvious way to do this, so I<br>
- have added a gx_device_delete_output_file very similar to the existing<br>
- gx_device_open_output_file and gx_device_close_output_file routines.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gsdevice.c<br>
-gs/base/gxdevice.h<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfb.h<br>
-gs/devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-03 15:15: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=68fa228ade5d2f7496b96676aaa1f82be4584362">68fa228ade5d2f7496b96676aaa1f82be4584362</a>
-<blockquote>
-<p>
- Bug 694519: improve PCL performance with FAPI<br>
-<br>
- Correctly maintain &quot;design_grid&quot; parameter in the font/matrix pair<br>
- structure, for FAPI handled TTFs.<br>
-<br>
- Change a &quot;return&quot; to a &quot;return_error&quot;.<br>
-<br>
- Retrieving glyph metrics was sub-optimal as my original implementation used<br>
- a gs_text_process() call, which uses the entire &quot;show machinery&quot;.<br>
-<br>
- This implementation calls gs_fapi_do_char() directly. This has several benefits:<br>
- we only need a &quot;skeleton&quot; text enumerator, and a &quot;skeleton&quot; graphics state,<br>
- cutting down the local overhead setup. We also cutout a whole lot of setup<br>
- done as part of gs_text_begin() and during gs_text_process() itself. Finally,<br>
- we avoid a lot of &quot;stuff&quot; related to showing entire strings, when we're only<br>
- ever handling a single glyph at a time.<br>
-<br>
- A final optimisation is in the FAPI/FT code: if we're just retrieving metrics,<br>
- we no longer take the action of retrieving the glyph from FT - which is not<br>
- a very cheap operation.<br>
-<br>
- This commit causes ~100 cluster tests to have pixel shift differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-gs/base/gxccman.c<br>
-gs/base/gxfapi.c<br>
-gs/base/gxfapi.h<br>
-gs/psi/zfapi.c<br>
-pl/plfapi.c<br>
-xps/xpsfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-09 12:25:56 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83565d8264e96312df8c26055aaa0e23e57c4c8d">83565d8264e96312df8c26055aaa0e23e57c4c8d</a>
-<blockquote>
-<p>
- Add missing reference to $(memory__h) in gsicc_lcms2.c lib.mak<br>
-<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-30 13:14:52 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2d2cc321df4223fd7cf64946ac2fa963fa1cea3d">2d2cc321df4223fd7cf64946ac2fa963fa1cea3d</a>
-<blockquote>
-<p>
- Knockout non-isolated transparency group support.<br>
-<br>
- Fixes bug 692766<br>
-<br>
- Proper non-isolated knockout group support added.<br>
-<br>
- This commit adds non-isolated knockout group support to gs. Also, previously, non-isolated groups that<br>
- had color space mismatches were being forced to be isolated. We now color convert the parent buffer<br>
- to the new groups color space to ensure that the group is handled in the way it should.<br>
-<br>
- This work revealed an issue in the color handling of planar buffers which was also fixed.<br>
-<br>
- Also, an issue with clipping to the soft mask boundary during a transparency group pop was was<br>
- discovered and fixed as well as an overprint simulation issue in transparency.<br>
-<br>
- Several progressions occurred with this fix.<br>
-<br>
- Fixes bug 692766.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevp14.h<br>
-gs/base/gscsepr.c<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/gstrans.c<br>
-gs/base/gxblend.c<br>
-gs/base/gxblend.h<br>
-gs/base/gxblend1.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-08 11:25: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=1969b28c60d666b5eab0050169b5b9aae1a28db5">1969b28c60d666b5eab0050169b5b9aae1a28db5</a>
-<blockquote>
-<p>
- Bug 694699: Scale FAPI's font BBox for units.<br>
-<br>
- When FAPI &quot;refined&quot; the FontBBox from the scaler's data, it failed to correctly<br>
- take account of the units in which the scaler returned the values.<br>
-<br>
- There was some code which *may* have been an attempt to handle it, but was<br>
- wrong in the general case. That's removed in favour of handling it properly.<br>
-<br>
- Several regression files show differences, mainly with pdfwrite/ps2write: many<br>
- are pixel differences due to rounding, some are progressions. One was wrong<br>
- prior to this commit, and is slightly differently wrong with it.<br>
-<br>
-gs/base/fapi_ft.c<br>
-gs/base/fapibstm.c<br>
-gs/base/fapiufst.c<br>
-gs/base/gxfapi.c<br>
-gs/base/gxfapi.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-08 13:08:17 +0200
-</strong>
-<br>Tor Andersson &lt;tor@ccxvii.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8b28b7dfd503146f7e2355a5dad9202b35405256">8b28b7dfd503146f7e2355a5dad9202b35405256</a>
-<blockquote>
-<p>
- xps: Look harder for a font name in the 'name' table.<br>
-<br>
- We used to look only for &quot;Mac Roman, English&quot; strings, now also try<br>
- &quot;MS Unicode, United States&quot; and &quot;MS Unicode UCS-4, United States&quot; if<br>
- the mac roman string can't be found.<br>
-<br>
-xps/xpsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-07 16:05: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=7276c1f94cfa55aed0554d45858652ee1cac2097">7276c1f94cfa55aed0554d45858652ee1cac2097</a>
-<blockquote>
-<p>
- correct a scan-build warning by checking a return value<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-07 15:05:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1bdb7a9e1a3064b5e8abf29dcdfa9d279715ae34">1bdb7a9e1a3064b5e8abf29dcdfa9d279715ae34</a>
-<blockquote>
-<p>
- Have pdfwrite ignore WMode=1 when a font has no Metrics2 entry<br>
-<br>
- This arose while investigating a customer bug. Sadly its not actually<br>
- anything to do with the customer problem, but it was incorrect. The spec<br>
- says that if a font has WMode 1 but has no Metrics2 entry it should be<br>
- treated as horizontal (WMode = 0)<br>
-<br>
- Quality Logic file 16-09.ps shows a progression with this change.<br>
-<br>
-gs/devices/vector/gdevpdte.c<br>
-gs/devices/vector/gdevpdtt.c<br>
-gs/devices/vector/gdevpdtt.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-04 08:17:40 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cdde8014aa4fe051743fad132f132fd608463744">cdde8014aa4fe051743fad132f132fd608463744</a>
-<blockquote>
-<p>
- Bug 694249: Fix JBig2Dec using broken image regions.<br>
-<br>
- When decoding a &quot;generic immediate region&quot; in jbig2dec, if<br>
- we detect an error, we should not use the image as it may not<br>
- have been entirely initialised.<br>
-<br>
-gs/jbig2dec/jbig2_generic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-02 09:51:31 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=41c13b4cc25b456d3862a73235ddbce09a85a104">41c13b4cc25b456d3862a73235ddbce09a85a104</a>
-<blockquote>
-<p>
- Fix Segfaults with --saved-pages.<br>
-<br>
- If the page was not large enough to use Banding mode, the clist_reset<br>
- would crash after the print request finished and the page reloaded.<br>
- The gx_saved_page_load needs to be after the saved_pages_list is put<br>
- back in the device.<br>
-<br>
- Also, the &quot;file_is_new&quot; status was incorrect if pages were saved, but<br>
- no printing was done. This was seen with the TIFF devices and psdcmyk.<br>
-<br>
- The psi/imainarg.c has a #define FORCE_SAVED_PAGES_TEST (disabled by<br>
- default) to simplify testing on the cluster without modifying command<br>
- line parameters.<br>
-<br>
-gs/base/gdevprn.c<br>
-gs/base/gxclpage.c<br>
-gs/psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-01 17:52: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=dcc172feb018bfe0613f90ce76ce25dd1eafe3ce">dcc172feb018bfe0613f90ce76ce25dd1eafe3ce</a>
-<blockquote>
-<p>
- Bug 689098: Only dash paths when the dashing would be visible.<br>
-<br>
- If the ctm doesn't expand the dash lengths to be &gt; 1 pixel, then<br>
- they can't be seen, so don't bother.<br>
-<br>
-gs/base/gsmatrix.c<br>
-gs/base/gxstroke.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-01 13:41: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=607370ce1a661d8657d5255056d810551c04d642">607370ce1a661d8657d5255056d810551c04d642</a>
-<blockquote>
-<p>
- Bug 692650 - remove dead code in gxifast.c<br>
-<br>
- A piece of code that was obviously left in a special case due to<br>
- cut and pasting can be removed. This will probably not actually<br>
- make any difference as a decent compiler (ha!) would optimise<br>
- it out anyway, but it's neater to remove it.<br>
-<br>
-gs/base/gxifast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-10-01 12:44:13 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b43b8b20c6344ccac7fac48151161a51743246b">9b43b8b20c6344ccac7fac48151161a51743246b</a>
-<blockquote>
-<p>
- Add openjpeg files to ghostscript.vcproj<br>
-<br>
-gs/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-28 08:29: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=29ed18f26f78d3e737b5e73452b1aa1a90088144">29ed18f26f78d3e737b5e73452b1aa1a90088144</a>
-<blockquote>
-<p>
- Eliminate some scan-build warnings in the ramfs code<br>
-<br>
- The warning in gsioram.c is bogus, but hopefully this change will eliminate<br>
- it anyway.<br>
-<br>
- 2 lines deleted in ramfs.c were benign but pointless. The final deletion<br>
- could have caused a seg fault when memory was exhausted.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gsioram.c<br>
-gs/base/ramfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-27 16:03:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be574c5550733da6b2ffa43fbc2099ae01608797">be574c5550733da6b2ffa43fbc2099ae01608797</a>
-<blockquote>
-<p>
- PDF interpreter - update to BPC change for JPEG2000<br>
-<br>
- Bug #694621<br>
-<br>
- If we find a box, which we shoudl not as this is only supposed to be used<br>
- when each colour channel has differing depth, we parse teh BPC from that,<br>
- and ignore the BPC in the ihdr box.<br>
-<br>
- If the components are not all equal, we use the first one and raise a<br>
- warning.<br>
-<br>
- No differences expected<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-27 11: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=6fe7ace41f8afaba72f0f1da7747c062382346fc">6fe7ace41f8afaba72f0f1da7747c062382346fc</a>
-<blockquote>
-<p>
- PDF interpreter - treat invalid BPC of 128 in JPEG2000 files as 8<br>
-<br>
- The test file has JPEG2000 images (produced by JasPer) which have a BPC<br>
- of 128. The valid range for JPEG2000 is 1-&gt;38 and for PDF is 1, 2, 4, 8,<br>
- 12 or 16. Acrobat (of course) opens the file without complaint.<br>
-<br>
- It appears that the image actually has 8 BPC so we specifically treat<br>
- this invalid value as 8.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-26 14:07:19 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49c0d08e7e04c8c4e1472142461f3ed369089639">49c0d08e7e04c8c4e1472142461f3ed369089639</a>
-<blockquote>
-<p>
- Fix 694614 - Properly handle a resolution argument of zero.<br>
-<br>
-pcl/rtgmode.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-26 13:55: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=0f815674bfda9f940a20bb703d124f27b92de181">0f815674bfda9f940a20bb703d124f27b92de181</a>
-<blockquote>
-<p>
- Fix 694615 - CCITT filter overflow.<br>
-<br>
- The type of image columns in the graphics library CCITT filter is a<br>
- signed integer and PCL was assuming an unsigned and therefore did not<br>
- check for possible overflow.<br>
-<br>
-pcl/rtraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-26 10:31:51 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3f02bbe5fad16e1f44131cb444e488e96157de5a">3f02bbe5fad16e1f44131cb444e488e96157de5a</a>
-<blockquote>
-<p>
- Fix 694616 - Fuzzing uncovered a modulo divisor of 0<br>
-<br>
-pcl/rtraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-17 16:49:51 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c561232cf26e060b89fc4f3bd4bf5c679731d4db">c561232cf26e060b89fc4f3bd4bf5c679731d4db</a>
-<blockquote>
-<p>
- pdfwrite - add support for form preservation from PostScript<br>
-<br>
- Bug #687561 et al<br>
-<br>
- We add the new operators .beginform and .endform which call device spec_op<br>
- methods in order to allow devices to capture form streams. Devices can<br>
- also return a matrix to replace the CTM for the course of the form.<br>
-<br>
- Modified pdfwrite to capture and store forms, and set the CTM to the<br>
- pdfwrite general matrix (resolution/72).<br>
-<br>
- Added new PDFexecform for use by the PDF interpreter, trying to capture<br>
- forms from PDF files is fraught with difficulty because we already capture<br>
- transparent forms as forms.<br>
-<br>
- Because some kinds of forms cannot be successfully preserved (only happens<br>
- with badly behaved PostScript) we need a way to prevent forms from being<br>
- preserved. This option does that.<br>
-<br>
- Examples of badly behaved PostScript can be found in a few Quality Logic<br>
- CET tests (use of setgstate in a form to set the CTM to a state prior to<br>
- the form execution, and use of setflat with a parameter derived from the<br>
- CTM. So we add UNROLLFORMS to the gs_cet file.<br>
-<br>
-gs/Resource/Init/gs_cet.ps<br>
-gs/Resource/Init/gs_lev2.ps<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/base/gdevdflt.c<br>
-gs/base/gsform1.h<br>
-gs/base/gxdevsop.h<br>
-gs/devices/vector/gdevpdfb.h<br>
-gs/devices/vector/gdevpdfi.c<br>
-gs/devices/vector/gdevpdfx.h<br>
-gs/doc/Ps2pdf.htm<br>
-gs/psi/int.mak<br>
-gs/psi/zform.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-26 10:34: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=a62129ba436ff3a35c92c704a905d21ceae09a88">a62129ba436ff3a35c92c704a905d21ceae09a88</a>
-<blockquote>
-<p>
- Bug 694575: workaround for filenameforall in regression tests<br>
-<br>
- (This is slightly hacky!)<br>
-<br>
- For the regression testing, especially the weekly tests, several of the QL<br>
- CET files give variable results depending on the exact content of the current<br>
- working directory - because they use filenameforall and vary their output based<br>
- whether it returns an error (mainly due to the path ending up too long for the<br>
- scratch string).<br>
-<br>
- This commit &quot;patches&quot; the filenameforall operator to catch those cases, and<br>
- (hopefully) always return with no files, and no errors, thus giving consistent<br>
- results between runs.<br>
-<br>
- Cluster differences in the CET files, as expected.<br>
-<br>
-gs/Resource/Init/gs_cet.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-25 18:12:58 +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=f9d0691129945b6d0657effcec6e6c440f57a364">f9d0691129945b6d0657effcec6e6c440f57a364</a>
-<blockquote>
-<p>
- Bug 694137 : Prevent accessing outside of array.<br>
-<br>
-gs/openjpeg/libopenjpeg/jp2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-23 14:54: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=f945f8b050fb0a64f5de746f253244afa107bff8">f945f8b050fb0a64f5de746f253244afa107bff8</a>
-<blockquote>
-<p>
- Bug 694586: Have chunk allocator honor alignment<br>
-<br>
- Have the chunk memory manager honor the same alignment as the rest<br>
- of the memory manager(s).<br>
-<br>
- Fixes potential bus errors on SPARC.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsmchunk.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-23 10:55:34 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b6d163b01a4ecca30503fbd770770b1bd7de73e2">b6d163b01a4ecca30503fbd770770b1bd7de73e2</a>
-<blockquote>
-<p>
- Fix potential access violation and add error checking in pdf14 put image.<br>
-<br>
- Fixes segv in fuzzing Bug 694190<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-23 09:56:14 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b8bb26de721811ca80712d8540e9279b4dca5bc9">b8bb26de721811ca80712d8540e9279b4dca5bc9</a>
-<blockquote>
-<p>
- Add error code checking in image color initialization<br>
-<br>
- Fix for bug 694175<br>
-<br>
-gs/base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-23 08:08:50 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f39d9824015ff6f909a59f697947f262d2c9c21c">f39d9824015ff6f909a59f697947f262d2c9c21c</a>
-<blockquote>
-<p>
- Bug 694289: Avoid SEGVs sue to Xmprintfs with mem = NULL<br>
-<br>
- If no memory pointer is supplied to a printf, then (in threadsafe<br>
- builds) return doing nothing or (in non-threadsafe builds) use the<br>
- default one.<br>
-<br>
- Also tweak the lib ctx closedown so that we safely closedown<br>
- without trying to print anything via undefined print pointers.<br>
-<br>
-gs/base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-23 15:19:04 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23ef9ea1fd7193c19c37c9cd00c6aad52a992fd1">23ef9ea1fd7193c19c37c9cd00c6aad52a992fd1</a>
-<blockquote>
-<p>
- Bug 694162: Harden gx_forward_dev_spec_op against SEGVs.<br>
-<br>
- If tdev == 0, don't pass on the call. I cannot reproduce the bug,<br>
- but this seems like a sensible precaution.<br>
-<br>
-gs/base/gdevnfwd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-23 14:29:50 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8c5cbff3351774ac55704c9c633112922313c74b">8c5cbff3351774ac55704c9c633112922313c74b</a>
-<blockquote>
-<p>
- Bug 694159: Check return code on color remap.<br>
-<br>
- If return code is ignored, returned device color may be used when<br>
- it is not initialised.<br>
-<br>
-gs/base/gsshade.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-22 20:56:11 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=81b54e2a9237dec0186ad331af845800011ae6d2">81b54e2a9237dec0186ad331af845800011ae6d2</a>
-<blockquote>
-<p>
- Improved error recovery during transparency group popping.<br>
-<br>
- If the creation of the ICC link fails then we attempt a non-ICC mapping. Fix for fuzz segv bug 694191.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-22 19:13:04 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9f29534318f7a70eb42408a2bdca51dad7181c16">9f29534318f7a70eb42408a2bdca51dad7181c16</a>
-<blockquote>
-<p>
- Added ink_cov device (Bug 694501).<br>
-<br>
- Thanks for Billon Marc &lt;billon.m@free.fr&gt; for the patch.<br>
-<br>
-gs/base/macos-mcp.mak<br>
-gs/base/macosx.mak<br>
-gs/base/openvms.mak<br>
-gs/base/unix-gcc.mak<br>
-gs/base/unixansi.mak<br>
-gs/configure.ac<br>
-gs/devices/devs.mak<br>
-gs/devices/gdevicov.c<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-21 22:36:34 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af81a6bf1a5de5d8cc23aaec7ae663c8985767c7">af81a6bf1a5de5d8cc23aaec7ae663c8985767c7</a>
-<blockquote>
-<p>
- Fix improper error checking in icc color space installation<br>
-<br>
- Fixes fuzzing segv Bug 694192<br>
-<br>
-gs/psi/zicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-20 23:08:57 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bbb9f59c59f7e229001e9e8413ff6ebf812910de">bbb9f59c59f7e229001e9e8413ff6ebf812910de</a>
-<blockquote>
-<p>
- Add in pdf14 abort compositor action<br>
-<br>
- The fuzzing files have identified that the interpreter was popping the<br>
- pdf14 device during a stop. This caused the pdf14 device to think it<br>
- was time to do its put_image command since it was done, causing a lot<br>
- of potential segv issues. This commit adds an abort compositor action<br>
- which will clean up the pdf14 device and set it back up as a pass through<br>
- device allowing for a more graceful exit.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/base/gdevp14.c<br>
-gs/base/gstrans.c<br>
-gs/base/gstrans.h<br>
-gs/base/gxdevcli.h<br>
-gs/devices/vector/gdevpdft.c<br>
-gs/psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-20 12:19:36 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=46b8210665fe111b2fa544eed4a661de831d245e">46b8210665fe111b2fa544eed4a661de831d245e</a>
-<blockquote>
-<p>
- Include another GL/2 command (SP) which can be used to initialize the<br>
- GL/2 interpreter, see related fix with bug #694595 for problem<br>
- details.<br>
-<br>
-pcl/pcparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-19 10:04: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=a5fa1ac21714a2dfdbcd3b9d70bc5cd913764ef3">a5fa1ac21714a2dfdbcd3b9d70bc5cd913764ef3</a>
-<blockquote>
-<p>
- pdfwrite - extend TrueType MaxPoint checking to include CID fonts<br>
-<br>
- Further to commit 8b6be8be2cdcefae39339682d45d3c009ab909ac which added<br>
- checks for MaxPoints and NumContours before merging TrueType fonts, this<br>
- commit adds the same checks to CIDFonts with TrueType base fonts.<br>
-<br>
- Also, relax the checks somewhat. As long as the new font doesn't have<br>
- *more* points, or contours, its safe to merge with the existing font.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/gxfcopy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-18 13:56:35 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=142b12b12b56aba0d4ec7372c0260c39d2d58d28">142b12b12b56aba0d4ec7372c0260c39d2d58d28</a>
-<blockquote>
-<p>
- Additional error checking fixes from fuzzing files<br>
-<br>
- Fixes Bug 694154<br>
-<br>
-gs/base/gsicc.c<br>
-gs/base/gsstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-18 12:26:43 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2236e20a9604602a12a9fbefc05e162d12954b03">2236e20a9604602a12a9fbefc05e162d12954b03</a>
-<blockquote>
-<p>
- Fix error checking for fuzzing case where pdf14 pattern accumulator target was closed<br>
-<br>
- Fixes 3842.pdf.SIGSEGV.201.3160<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-18 10:31:50 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6fbf53542a13b9a8582aef2c50bba7a145a8e49">c6fbf53542a13b9a8582aef2c50bba7a145a8e49</a>
-<blockquote>
-<p>
- Error code checking fix.<br>
-<br>
- Fixes Fuzzing Bug http://bugs.ghostscript.com/show_bug.cgi?id=694161<br>
-<br>
-gs/base/gximag3x.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-17 11:37:05 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f4a1368a6585d20a218acd236d97706401a1b8c1">f4a1368a6585d20a218acd236d97706401a1b8c1</a>
-<blockquote>
-<p>
- Fix for pattern, transparency, clipper interaction issues<br>
-<br>
- Three issues this fixes. One is that if a clipper device is installed during the filling<br>
- with a transparency tile, we need to make sure we get the pdf14 device to pop the group<br>
- and not use the clipper device.<br>
-<br>
- The second issue was that fit_fill was not getting used properly in the tile filling code.<br>
-<br>
- The third issue was that the wrong dimensions were supplied to gx_trans_pattern_fill_rect when<br>
- the pattern was clist based.<br>
-<br>
- This should fix Bug 693365.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gxp1fill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-17 20:02:34 +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=3f098349c0ff70a50ebb0341f1e98da2c2330c84">3f098349c0ff70a50ebb0341f1e98da2c2330c84</a>
-<blockquote>
-<p>
- Bug 694132: Resolve uninitialised variable and handle returning error correctly.<br>
-<br>
-gs/base/gdevprn.c<br>
-gs/base/gxicolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-17 08:47:18 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=54ab9a05fbc13ad402aaa63c86d9ec0422bd112a">54ab9a05fbc13ad402aaa63c86d9ec0422bd112a</a>
-<blockquote>
-<p>
- Fix # 694595 - nothing produced reading PCL files.<br>
-<br>
- This change allows the command BP (Begin Plot) to initiate the HPGL/2<br>
- parser for improperly constructed GL/2 files that lack the Enter GL/2<br>
- command (&lt;ESC&gt;%1B).<br>
-<br>
-pcl/pcparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-17 13:50:56 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5347e2c3e43a28f64b0e4775945c6a58ee72debf">5347e2c3e43a28f64b0e4775945c6a58ee72debf</a>
-<blockquote>
-<p>
- Bug 691182: Disable interpolation for Type3 postscript images<br>
-<br>
- If we interpolate an image, but not its mask we get nasty edge<br>
- effects. We therefore choose not to interpolate either.<br>
-<br>
-gs/psi/zimage3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-13 13:28:16 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b7094e220951fc76656056a426ab7fa1363f38b7">b7094e220951fc76656056a426ab7fa1363f38b7</a>
-<blockquote>
-<p>
- Make sure the mono device that is created for non-FAPI bold font caching has icc procs set.<br>
-<br>
- Fixes bug 694551<br>
-<br>
- Note Enhancement Bug 694593 was opened with this commit so that I will remember to review<br>
- the setting of the get_profile procs for these devices.<br>
-<br>
-gs/base/gdevmem.c<br>
-pl/plchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-07 06:05:01 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=752aeb0e47fc11aff22618a00dd07576647c192d">752aeb0e47fc11aff22618a00dd07576647c192d</a>
-<blockquote>
-<p>
- Avoid forced white point mapping in CMM when the source profile is derived from CIE PS type.<br>
-<br>
- LittleCMS and perhaps other CMMs have methods to force the white point in the mashed transform<br>
- between source and destination color space. The methods used can lead to incorrect results<br>
- when the source space is a non-traditional profile like those derived from CIEDEF(G) types.<br>
- This fix gets and sets the appropriate flags for the CMM to avoid the white point alignment<br>
- when the source space is PS based. Fixes bug 693826<br>
-<br>
- Fixing this bug revealed an issue in the CIEA color space conversion.<br>
-<br>
- Also, fixed old bug, mapping cie ps color spaces to ciexyz to allow ciexyz values larger than 1.0.<br>
- Fixes bug 692807.<br>
-<br>
- Started changes to add in V2 profile creation.<br>
-<br>
- Fixed error handling in this part of code also.<br>
-<br>
-gs/base/gscie.h<br>
-gs/base/gsciemap.c<br>
-gs/base/gsicc.c<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_cms.h<br>
-gs/base/gsicc_create.c<br>
-gs/base/gsicc_lcms.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_manage.h<br>
-gs/base/gxcie.h<br>
-gs/devices/gdevrinkj.c<br>
-gs/devices/gdevxcf.c<br>
-gs/devices/vector/gdevpdfk.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-12 18:08:53 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=808e6d525d978b6f083be8eeb2a612b343500693">808e6d525d978b6f083be8eeb2a612b343500693</a>
-<blockquote>
-<p>
- Bug 694590: Tweak scan converters handling of horizontal lines.<br>
-<br>
- The scan converter only puts horizontal edges into the edge list<br>
- if expanding the height of the line by fill adjust causes it to<br>
- cover a pixel centre.<br>
-<br>
- Unfortunately, for the fill_adjust = 0.5 case we actually use<br>
- adjust_above = 128 and adjust_below = 127, so there is one possible<br>
- subpixel offset for which the line will not appear. We therefore<br>
- tweak the logic to accept all horizontal lines through in this case.<br>
-<br>
- This produces many diffs, all benign. Sorry Marcos.<br>
-<br>
-gs/base/gxfill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-12 12:21: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=002cd5262ccb71010473abfb9069e1fb39f36f12">002cd5262ccb71010473abfb9069e1fb39f36f12</a>
-<blockquote>
-<p>
- PDF interpreter - remove the 2D array of objects for large (&gt;64k) objects<br>
-<br>
- Bug #694470<br>
-<br>
- In the past Ghostscript had a limit of 64k entries for arrays and strings<br>
- but this proved a problem for some PDF files, so a set of new objects were<br>
- defined 'larray' and 'lstring', which were defined as an array of arrays<br>
- and an array of strings. New accessor and utility functions were also<br>
- created.<br>
-<br>
- With bug 694470 there is an object with an index of 2^32 - 1, which takes<br>
- a very long time, as the code allocates more and more sub-arrays.<br>
-<br>
- Now that we have a limit of 2^24 on arrays and strings (which can be increased),<br>
- we can remove the 2d array hackery. This causes the bug file to abort almost<br>
- immediately while rebuilding the xref. It *should* also provide a modest<br>
- performance benefit, and makes the code smaller and easier to deal with.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/pdf_base.ps<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/Resource/Init/pdf_rbld.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-11 16:06:38 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d97571b56d7c740e7d6aeee064313b96048a5667">d97571b56d7c740e7d6aeee064313b96048a5667</a>
-<blockquote>
-<p>
- Fixed typo in lib.mak introduced in b5472ea6bf<br>
-<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-11 11:11:35 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6dd5b91bbaf237ca3153722887d5965b0eb3633e">6dd5b91bbaf237ca3153722887d5965b0eb3633e</a>
-<blockquote>
-<p>
- Ensure overprint drawn components are updated with color space changes during transparency.<br>
-<br>
- Fixes bug 694297<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gstrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-11 18:47:45 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=faea7d6e98d6e7ee0b82d891544a13d703a291f5">faea7d6e98d6e7ee0b82d891544a13d703a291f5</a>
-<blockquote>
-<p>
- Bug 690790: Workaround libpng 64bit build bug.<br>
-<br>
- libpng keeps a jmpbuf in it's structure. jmp_bufs have to be 16 byte<br>
- aligned on x64 systems, and the png allocator makes no effort to<br>
- align the buffer.<br>
-<br>
- The workaround here changes the PNG allocator to allocate it's main<br>
- structure in a larger block than it needs, and to actually use a<br>
- block in the middle of this to ensure alignment. A pointer is<br>
- kept to the real address of the block for freeing.<br>
-<br>
-gs/libpng/png.c<br>
-gs/libpng/pngmem.c<br>
-gs/libpng/pngstruct.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-11 10:15: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=b5472ea6bf6925023febdeab12be9dbd83e811f1">b5472ea6bf6925023febdeab12be9dbd83e811f1</a>
-<blockquote>
-<p>
- update ramfs code<br>
-<br>
-gs/base/gsioram.c<br>
-gs/base/lib.mak<br>
-gs/base/ramfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-07 12:01:22 +0100
-</strong>
-<br>unknown &lt;ken@.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db45b95faa06f8204b9a075323125d7f398c5d06">db45b95faa06f8204b9a075323125d7f398c5d06</a>
-<blockquote>
-<p>
- PDF interpreter - process GoToR actions into pdfmarks for pdfwrite<br>
-<br>
- Bug #693427 &quot;GoToR target file information lost after GS processing&quot;<br>
-<br>
- This commit adds GoToR to the Existing GoTo and Named actions which the<br>
- PDF interpreter will convert into pdfmarks. pdfwrite already handles<br>
- the GoToR action so no changes were needed there.<br>
-<br>
- No differences expected<br>
-<br>
- New ram file system code<br>
-<br>
- Updated from the patch submitted by Michael Slade in bug #226943. This code<br>
- removes a single Unix-ism and rewrites the memory allocations to use the<br>
- GS garbage collected memory (as is appropriate for PostScript) instead of<br>
- using the system malloc.<br>
-<br>
- No differences expected since we have no files that use the ramfs.<br>
-<br>
-gs/Makefile.in<br>
-gs/base/gsioram.c<br>
-gs/base/lib.mak<br>
-gs/base/ramfs.c<br>
-gs/base/ramfs.h<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-07 12:01:22 +0100
-</strong>
-<br>unknown &lt;ken@.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8425cde6e55dfaa26e64e81f54e044187fb98384">8425cde6e55dfaa26e64e81f54e044187fb98384</a>
-<blockquote>
-<p>
- PDF interpreter - process GoToR actions into pdfmarks for pdfwrite<br>
-<br>
- Bug #693427 &quot;GoToR target file information lost after GS processing&quot;<br>
-<br>
- This commit adds GoToR to the Existing GoTo and Named actions which the<br>
- PDF interpreter will convert into pdfmarks. pdfwrite already handles<br>
- the GoToR action so no changes were needed there.<br>
-<br>
- No differences expected<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-06 17:58:57 -0500
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e05fe9d24205f50ee12b97c22a5d1b34fa118ed0">e05fe9d24205f50ee12b97c22a5d1b34fa118ed0</a>
-<blockquote>
-<p>
- Bug 619917: Add support for configurable timeslice<br>
-<br>
- Add more of the patch from Herbert Swann. Many thanks again!<br>
-<br>
-gs/psi/zcontext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-06 15:35:50 -0500
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ddc4b6753a40b2cbac503dbef300d339979274c8">ddc4b6753a40b2cbac503dbef300d339979274c8</a>
-<blockquote>
-<p>
- Bug 691917: Fix SEGVs in display postscript.<br>
-<br>
- Cutdown version of Herbert Swanns patch.<br>
-<br>
-gs/psi/zcontext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-06 15:49:10 -0500
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=64de3a6bf2b3a75123ae406076796f23a773aff1">64de3a6bf2b3a75123ae406076796f23a773aff1</a>
-<blockquote>
-<p>
- Bug 693629: fix outdated FSF address information.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/contrib/gdevbjc_.h<br>
-gs/contrib/gdevcd8.c<br>
-gs/contrib/gdevdj9.c<br>
-gs/contrib/gdevlx32.c<br>
-gs/contrib/opvp/gdevopvp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-13 18:07: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=66d9c0aa17a5abcecd6590e63f0620f7aa51634c">66d9c0aa17a5abcecd6590e63f0620f7aa51634c</a>
-<blockquote>
-<p>
- Bug 694311 : GS openjpeg2 integration<br>
-<br>
- WIP : Update with latest OpenJPEG2. Warning - does not compile yet.<br>
-<br>
- WIP : Update code. Warning - does not compile yet.<br>
-<br>
- WIP : Code compiles but is not cluster tested.<br>
-<br>
- Update to build on xeon and macpro<br>
-<br>
- Use default image creation<br>
-<br>
- Add error/info/warning event handlers.<br>
-<br>
- Update fuzzing patch to allow j2kp4-file3-ycc-8bpc.pdf to process correctly.<br>
-<br>
- Update fuzzing patch to allow bug 691816 to process correctly without blurring.<br>
-<br>
- Patch to cater for eYCC colour space.<br>
-<br>
- Patch for indexed colour spaces and cater for bad BPCC header box.<br>
-<br>
- Cater for alpha channel information.<br>
-<br>
-gs/base/openjpeg.mak<br>
-gs/base/sjpx_openjpeg.c<br>
-gs/base/sjpx_openjpeg.h<br>
-gs/configure.ac<br>
-gs/openjpeg/libopenjpeg/CMakeLists.txt<br>
-gs/openjpeg/libopenjpeg/bio.c<br>
-gs/openjpeg/libopenjpeg/bio.h<br>
-gs/openjpeg/libopenjpeg/cidx_manager.c<br>
-gs/openjpeg/libopenjpeg/cidx_manager.h<br>
-gs/openjpeg/libopenjpeg/cio.c<br>
-gs/openjpeg/libopenjpeg/cio.h<br>
-gs/openjpeg/libopenjpeg/dwt.c<br>
-gs/openjpeg/libopenjpeg/dwt.h<br>
-gs/openjpeg/libopenjpeg/event.c<br>
-gs/openjpeg/libopenjpeg/event.h<br>
-gs/openjpeg/libopenjpeg/function_list.c<br>
-gs/openjpeg/libopenjpeg/function_list.h<br>
-gs/openjpeg/libopenjpeg/image.c<br>
-gs/openjpeg/libopenjpeg/image.h<br>
-gs/openjpeg/libopenjpeg/indexbox_manager.h<br>
-gs/openjpeg/libopenjpeg/invert.c<br>
-gs/openjpeg/libopenjpeg/invert.h<br>
-gs/openjpeg/libopenjpeg/j2k.c<br>
-gs/openjpeg/libopenjpeg/j2k.h<br>
-gs/openjpeg/libopenjpeg/jp2.c<br>
-gs/openjpeg/libopenjpeg/jp2.h<br>
-gs/openjpeg/libopenjpeg/mct.c<br>
-gs/openjpeg/libopenjpeg/mct.h<br>
-gs/openjpeg/libopenjpeg/mqc.c<br>
-gs/openjpeg/libopenjpeg/mqc.h<br>
-gs/openjpeg/libopenjpeg/openjpeg.c<br>
-gs/openjpeg/libopenjpeg/openjpeg.h<br>
-gs/openjpeg/libopenjpeg/opj_clock.c<br>
-gs/openjpeg/libopenjpeg/opj_clock.h<br>
-gs/openjpeg/libopenjpeg/opj_config.h<br>
-gs/openjpeg/libopenjpeg/opj_config_private.h<br>
-gs/openjpeg/libopenjpeg/opj_includes.h<br>
-gs/openjpeg/libopenjpeg/opj_intmath.h<br>
-gs/openjpeg/libopenjpeg/opj_inttypes.h<br>
-gs/openjpeg/libopenjpeg/opj_malloc.h<br>
-gs/openjpeg/libopenjpeg/opj_stdint.h<br>
-gs/openjpeg/libopenjpeg/phix_manager.c<br>
-gs/openjpeg/libopenjpeg/pi.c<br>
-gs/openjpeg/libopenjpeg/pi.h<br>
-gs/openjpeg/libopenjpeg/ppix_manager.c<br>
-gs/openjpeg/libopenjpeg/raw.c<br>
-gs/openjpeg/libopenjpeg/raw.h<br>
-gs/openjpeg/libopenjpeg/t1.c<br>
-gs/openjpeg/libopenjpeg/t1.h<br>
-gs/openjpeg/libopenjpeg/t1_generate_luts.c<br>
-gs/openjpeg/libopenjpeg/t1_luts.h<br>
-gs/openjpeg/libopenjpeg/t2.c<br>
-gs/openjpeg/libopenjpeg/t2.h<br>
-gs/openjpeg/libopenjpeg/tcd.c<br>
-gs/openjpeg/libopenjpeg/tcd.h<br>
-gs/openjpeg/libopenjpeg/tgt.c<br>
-gs/openjpeg/libopenjpeg/tgt.h<br>
-gs/openjpeg/libopenjpeg/thix_manager.c<br>
-gs/openjpeg/libopenjpeg/tpix_manager.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-04 11:03:02 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a92c4411e302b1b99fe65b5d89d26b87671feff5">a92c4411e302b1b99fe65b5d89d26b87671feff5</a>
-<blockquote>
-<p>
- Removal of default initialization of ICC profile in languages. The default will be set when the page erase occurs.<br>
-<br>
- Thanks to Henry for catching this.<br>
-<br>
-pcl/pctop.c<br>
-pxl/pxpthr.c<br>
-pxl/pxtop.c<br>
-svg/svgtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-30 10:00: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=45dfe09a18a7c19c626561d506ab44ee68421c41">45dfe09a18a7c19c626561d506ab44ee68421c41</a>
-<blockquote>
-<p>
- Update product string, dates and docs for 9.10 release.<br>
-<br>
- Bring master up to date with gs910 branch<br>
-<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-15 16:53: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=edb56190f321ea9e094cb161f9b94941d49a40ae">edb56190f321ea9e094cb161f9b94941d49a40ae</a>
-<blockquote>
-<p>
- Update antidropout downscaler.<br>
-<br>
- The antidropout downscaler is not consistent in the way it detects<br>
- 'darker' colors; some of the code predicates 'darker' on the color<br>
- polarity, other parts of it do not.<br>
-<br>
- Here we make it consistently follow the color polarity.<br>
-<br>
- Also, we correctly take the color polarity from the color space, rather<br>
- than from the device. Thanks to Michael Vrhel for making the changes<br>
- to make this possible.<br>
-<br>
-gs/base/gxiscale.c<br>
-gs/base/sidscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-03 18:01: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=02ab2adaafb3cc9322e54f0ea4e78952c34818d2">02ab2adaafb3cc9322e54f0ea4e78952c34818d2</a>
-<blockquote>
-<p>
- Bug 694561: Fix interpolated landscape images (again).<br>
-<br>
- Don't try to accumulate runs of identical pixels in landscape images.<br>
- We weren't aligning the transposed data to bitmap_align, and this was<br>
- causing problems. It's unfeasible to do so, and the underlying driver<br>
- almost certainly will break down to 1 call per pixel, so we might as<br>
- well do that immediately and simplify the code massively.<br>
-<br>
- Also fix some warnings/unused variables.<br>
-<br>
-gs/base/gxcindex.h<br>
-gs/base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-24 20:44: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=bdc103f817778f84efe66f10489c88a9263d279f">bdc103f817778f84efe66f10489c88a9263d279f</a>
-<blockquote>
-<p>
- Addition of new procedure to color spaces to return the polarity of the color space.<br>
-<br>
-gs/base/gsccolor.h<br>
-gs/base/gscdevn.c<br>
-gs/base/gscolor2.c<br>
-gs/base/gscpixel.c<br>
-gs/base/gscscie.c<br>
-gs/base/gscsepr.c<br>
-gs/base/gscspace.c<br>
-gs/base/gsicc.c<br>
-gs/base/gspcolor.c<br>
-gs/base/gxcspace.h<br>
-gs/base/gxdevcli.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-03 12:59: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=5ae4180ca9d17f367acd068537f0a67a243656b8">5ae4180ca9d17f367acd068537f0a67a243656b8</a>
-<blockquote>
-<p>
- PS Interpreter - don't interpolate imagemask data for high level devices<br>
-<br>
- Bug #689460 &quot;imagemask interpolation differs from Adobe&quot;<br>
-<br>
- This is rather a long-running bug. The title isn't really very descriptive<br>
- of the problem, as far as I can tell the problem only affects pdfwrite.<br>
-<br>
- In the current implementation, interpolation of imagemasks is handled in<br>
- *PostScript*, by inserting the ImScaleDecode filter in front of the image<br>
- DataSource. This works well for rendering, but for high level devicees<br>
- (particularly pdfwrite) this means that we do not embed the original mask<br>
- data, we embed the interpolated data. This makes the PDF file much larger<br>
- and also means that when opened with Acrobat Reader, the output does not<br>
- match, becuase Acrobat does interpolation by applying what looks like a<br>
- Mitchell filter, and promoting the imagemask to 8 bpc.<br>
-<br>
- I did look into applying our current scheme in C, as suggested in comment #18,<br>
- but that was inordintely difficult. We can't use the existing 1bpp image<br>
- interpolation code, as that promotes to 8bpc and uses a Mitchell filter,<br>
- so we lose the sharp edges, which is important for a mask. It probably would<br>
- be possible to replicate the PostScript code which adds the ImScaleDecode<br>
- filter to the DataSource, but there seems little point in doing this in<br>
- C when it could be done more easily in PostScript.<br>
-<br>
- So instead I've chosen to test if the current device is a 'high level'<br>
- device and, if it is, not to apply the filter.<br>
-<br>
- With pdfwrite this leads to us producing smaller PDF files, as expected,<br>
- and the result in Acrobat matching the one from Distiller.<br>
-<br>
- When testing with the cluster a small number of Genoa test files exhibit<br>
- differences. These all use the well known 'turkey' image at very low resolution,<br>
- with the old code these were interpolated at 720 dpi and that was the image<br>
- data written out. Now we write the original data and interpolate to the<br>
- resolution of the actual device at rendering time. In the case of 300 dpi<br>
- output this results in small but visible differences.<br>
-<br>
-gs/Resource/Init/gs_img.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-01 12:23:04 +0200
-</strong>
-<br>Simon Bünzli &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=42839db66a6cb026691c2e30af3489ff22d96b35">42839db66a6cb026691c2e30af3489ff22d96b35</a>
-<blockquote>
-<p>
- bug 694281: fix memory leaks and compilation warnings<br>
-<br>
- * jbig2_build_huffman_table leaks LENCOUNT and result under OOM conditions<br>
- * jbig2_decode_symbol_dict leaks an image in an error case<br>
- * jbig2_symbol_dictionary skips cleanup in an error case<br>
- * jbig2_text_region leaks GR_stats in various error and non-error cases<br>
- * MSVC reports two &quot;unreachable code&quot; warnings and a &quot;signed/unsigned<br>
- mismatch&quot; one<br>
-<br>
-gs/jbig2dec/jbig2.c<br>
-gs/jbig2dec/jbig2_huffman.c<br>
-gs/jbig2dec/jbig2_segment.c<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-gs/jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-02 12:26: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=1c1395aeeee68d545a3f293d6aa0ec38999879c9">1c1395aeeee68d545a3f293d6aa0ec38999879c9</a>
-<blockquote>
-<p>
- Update font versions in PPD files.<br>
-<br>
- A couple of ppd's contain version numbers for the font files, update them<br>
- from 1.05 to 1.10<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/contrib/pcl3/ppd/fonts.ppd<br>
-gs/lib/ghostpdf.ppd<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-09-01 18:48:32 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f89dd1d4d38db72a9fc7a605072cf2a419e6f190">f89dd1d4d38db72a9fc7a605072cf2a419e6f190</a>
-<blockquote>
-<p>
- Fix compiler warnings.<br>
-<br>
-gs/base/gxclpage.c<br>
-gs/psi/imainarg.c<br>
-gs/psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-11 13:03:17 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9c95a9ae56b5051ba8c7c3b3d161932678d3b01d">9c95a9ae56b5051ba8c7c3b3d161932678d3b01d</a>
-<blockquote>
-<p>
- Enhance gx_saved_page and save_page function to support advanced functions.<br>
-<br>
- By saving the device params in the saved_page struct we can use it more<br>
- generally to print pages out of order. This is still compatible with the<br>
- rendering of multiple saved pages on a 'master' page for imposition, but<br>
- the latter does not use the device params so pages with differing spot colors<br>
- or differing destination ICC profiles may be incorrect. To be fixed later.<br>
-<br>
- Several utility functions support lists of saved pages: gx_saved_pages_list_new<br>
- to allocate and initialize a saved page list; gx_saved_pages_list_add to alloc<br>
- a new saved page object, fill it with the current page and add it to the end of<br>
- the list; gx_saved_pages_list_print to print various pages in various orders<br>
- from the list; gx_saved_pages_list_free to free the clist files for the saved<br>
- pages as well as the saved pages and the saved pages list and to support the<br>
- parameter and command line arg, gx_saved_pages_param_process. This function<br>
- may be useful for applications as well. See psi/imainarg.c for sample usage<br>
- with --saved-pages-test.<br>
-<br>
- Also, the gx_device_printer get and put params have an added saved-pages string<br>
- parameter to allow control of this feature.<br>
-<br>
- A new command line option --saved-pages=&quot;...&quot; is added that will call the<br>
- 'process' function. This is implemented for BOTH gs imainarg and plmain used<br>
- by the other languages. Also, --saved-pages-test is added for weekly testing<br>
- that will collect all pages in a list (--saved-pages=begin) then after the<br>
- file is processed, will print all pages (--saved-pages=&quot;print normal flush&quot;).<br>
-<br>
- The capability is mentioned in doc/Use.htm, and the parameters for the control<br>
- string is documented in doc/SavedPages.htm<br>
-<br>
-gs/base/gdevdflt.c<br>
-gs/base/gdevppla.c<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevprn.h<br>
-gs/base/gsdparam.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclist.h<br>
-gs/base/gxclpage.c<br>
-gs/base/gxclpage.h<br>
-gs/base/gxclread.c<br>
-gs/base/gxclrect.c<br>
-gs/base/gxclthrd.c<br>
-gs/base/gxdevsop.h<br>
-gs/base/gxpcmap.c<br>
-gs/base/lib.mak<br>
-gs/base/string_.h<br>
-gs/devices/gdevijs.c<br>
-gs/devices/gdevp2up.c<br>
-gs/devices/gdevtsep.c<br>
-gs/doc/SavedPages.htm<br>
-gs/doc/Use.htm<br>
-gs/psi/imainarg.c<br>
-gs/psi/iminst.h<br>
-gs/psi/int.mak<br>
-pl/pl.mak<br>
-pl/plmain.c<br>
-pl/plmain.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-11 22:04:00 +0200
-</strong>
-<br>zeniko &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e7b7ecff0277c0aa7e162edd21842dc4409391ff">e7b7ecff0277c0aa7e162edd21842dc4409391ff</a>
-<blockquote>
-<p>
- Bug 694121: prevent heap overflow<br>
-<br>
- jbig2_decode_symbol_dict checks whether more glyphs are requested than<br>
- are available (SDNUMINSYMS + SDNUMNEWSYMS) but has so far failed check<br>
- whether there are more than expected (SDNUMEXSYMS); fixes<br>
- 3324.pdf.asan.3.2585<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-05 13:11:58 +0200
-</strong>
-<br>zeniko &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f7064096ceac3d6c148096a936e1ea10fd8f0c55">f7064096ceac3d6c148096a936e1ea10fd8f0c55</a>
-<blockquote>
-<p>
- Bug 694111: prevent heap overflow<br>
-<br>
- jbig2_image_compose fails to ensure that the destination rectangle lies<br>
- entirely within the destination buffer (in the case of the file<br>
- 3324.pdf.asan.50.2585, this happens due to a huge value for y). Adding a<br>
- new check which makes sure that...<br>
-<br>
- @ y * dst-&gt;stride + leftbyte doesn't overflow<br>
- @ x and leftbyte don't overflow to the next line<br>
- @ h * dst-&gt;stride doesn't overflow<br>
- @ all values read are within the destination buffer<br>
-<br>
- The file 3324.pdf.asan.50.2585 also demonstrates a memory leak where the<br>
- glyph isn't properly released if jbig2_image_compose fails.<br>
-<br>
-gs/jbig2dec/jbig2_image.c<br>
-gs/jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-30 13:05: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=ca5a118174084f53893978d0c6b71d3a58db41bf">ca5a118174084f53893978d0c6b71d3a58db41bf</a>
-<blockquote>
-<p>
- PDF interpreter - synthesize appearance for multiline text widgets<br>
-<br>
- Bug 689761 &quot;Multiline PDF form field does not honor line breaks&quot;<br>
-<br>
- There are several parts to this change. Firstly there was a bug in the code<br>
- to detect multiline text widgets, which meant that they were not detected<br>
- and instead of flagging a warning and ignoring the widget, we handled it<br>
- as if it were a single line. This also meant that we were mishandling combined<br>
- fields as tetx fields.<br>
-<br>
- Secondly there is code in pdf-draw.ps which checks to see if we can synthesise<br>
- an appearance and if we can it ignores the one provided. Testing with Acrobat<br>
- indicates that this is what Acrobat does. However I think this is very wrong<br>
- and in testing our code I see about as many files which are better if we<br>
- use the appearance stream as are better if we manufacture one. So I've<br>
- chosen (for now at least) to use the appearance stream if we're given one.<br>
-<br>
- Finally we now handle multiline text fields. The string is broken up into<br>
- multiple strings at the line breaks. The height of the rectangle is divided<br>
- by the number of strings, which allows us to space the lines evenly. We<br>
- detect and implement the different types of quadding. Note that Acrobat<br>
- does not seem to distribute the text the same way we do, but I don't see<br>
- any reason to try and mimic it.<br>
-<br>
- Expected Differences<br>
- Bug689450.pdf Bug692968.pdf 1503_text_missing .pdf Bug690526.pdf Bug692591.pdf<br>
- these files have appearance streams that do not match up with the field values.<br>
- 1783_CIDToGIDMap...pdf x_-_complex_fomr.pdf using the appearance stream<br>
- improves the output because our synthesis is not that great.<br>
- comb_and_password.pdf uses a combined field which we previously treated as<br>
- text, and which we now ignore.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-29 16:47:29 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=621b010d1a6e12f7754508fee8a860345b4f84df">621b010d1a6e12f7754508fee8a860345b4f84df</a>
-<blockquote>
-<p>
- Bug 694546: Fix undefined behaviour in gdevpbm.<br>
-<br>
- Thanks to jsmeix for reporting this.<br>
-<br>
-gs/devices/gdevpbm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-29 16:23:20 +0200
-</strong>
-<br>Tor Andersson &lt;tor@ccxvii.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3659374423a9f7b0c4b361ce2e207549ae8b4e25">3659374423a9f7b0c4b361ce2e207549ae8b4e25</a>
-<blockquote>
-<p>
- xps: Check sfnt name table length before accessing array.<br>
-<br>
- Thanks to Shailesh Mistry.<br>
-<br>
-xps/xpsfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-27 16:03:41 +0200
-</strong>
-<br>Tor Andersson &lt;tor@ccxvii.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=30355133c04d2ab3f270a6ea6ee28ae8fa91021b">30355133c04d2ab3f270a6ea6ee28ae8fa91021b</a>
-<blockquote>
-<p>
- xps: Fix memory leak (bug 694469).<br>
-<br>
- Thanks to Shailesh Mistry.<br>
-<br>
-gs/base/gslibctx.c<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-27 16:01:33 +0200
-</strong>
-<br>Tor Andersson &lt;tor@ccxvii.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8017a6b547e12bc43d16f1057ac5dbf075a47d1e">8017a6b547e12bc43d16f1057ac5dbf075a47d1e</a>
-<blockquote>
-<p>
- xps: Check for number of arguments when parsing abbreviated paths.<br>
-<br>
- Thanks to Shailesh Mistry.<br>
-<br>
-xps/xpspath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-27 15:45:09 +0200
-</strong>
-<br>Tor Andersson &lt;tor@ccxvii.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a85570458e46327dd8741c16c758669b5918ac4">9a85570458e46327dd8741c16c758669b5918ac4</a>
-<blockquote>
-<p>
- xps: Avoid infinite loop on syntax errors in abbreviated path geometry.<br>
-<br>
- Thanks to Shailesh Mistry.<br>
-<br>
-xps/xpspath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-27 15:43:14 +0200
-</strong>
-<br>Tor Andersson &lt;tor@ccxvii.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=82fd60791f60a00bbd42b042198d0cc2593c0790">82fd60791f60a00bbd42b042198d0cc2593c0790</a>
-<blockquote>
-<p>
- xps: Skip all but the first resource dictionary if there are many.<br>
-<br>
- Thanks to Shailesh Mistry.<br>
-<br>
-xps/xpspage.c<br>
-xps/xpsresource.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-27 15:42:44 +0200
-</strong>
-<br>Tor Andersson &lt;tor@ccxvii.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bac315e9d796bff6707e1b96e75d403edddf7303">bac315e9d796bff6707e1b96e75d403edddf7303</a>
-<blockquote>
-<p>
- xps: Ignore empty resource dictionaries.<br>
-<br>
- Thanks to Shailesh Mistry.<br>
-<br>
-xps/xpspage.c<br>
-xps/xpsresource.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-23 16:17:55 +0200
-</strong>
-<br>Tor Andersson &lt;tor@ccxvii.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d4d0e216d1327dab177820e2f90cbb2dd38843c6">d4d0e216d1327dab177820e2f90cbb2dd38843c6</a>
-<blockquote>
-<p>
- xps: Check for missing pieces before dereferencing.<br>
-<br>
- Should only be able to happen if .last.piece is missing.<br>
-<br>
- Thanks to Shailesh Mistry.<br>
-<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-23 16:11:03 +0200
-</strong>
-<br>Tor Andersson &lt;tor@ccxvii.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=62c8ba4fa3af5fbe395cd4923766ca8a44fc36f1">62c8ba4fa3af5fbe395cd4923766ca8a44fc36f1</a>
-<blockquote>
-<p>
- xps: Check that Canvas.Resources has child node before descending.<br>
-<br>
- Thanks to Shailesh Mistry.<br>
-<br>
-xps/xpsanalyze.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-23 16:08:37 +0200
-</strong>
-<br>Tor Andersson &lt;tor@ccxvii.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8dc38533ab78a63c9c0a5c82ba96c45c0a9edebc">8dc38533ab78a63c9c0a5c82ba96c45c0a9edebc</a>
-<blockquote>
-<p>
- xps: Check the existence of stripbytecounts before using in TIFF decoder.<br>
-<br>
- Thanks to Shailesh Mistry.<br>
-<br>
-xps/xpstiff.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-27 17:34:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=88bce110851c10455d3165ca748a3371d9c917cc">88bce110851c10455d3165ca748a3371d9c917cc</a>
-<blockquote>
-<p>
- PostScript interpreter - make setpagedevice and EndPage work more like Adobe<br>
-<br>
- Bug 690667 &quot;Changing PageSize during n-up processing by BeginPage/EndPage generates wrong output&quot;<br>
-<br>
- The test job changes setpagedevice during the course of the job, and the<br>
- EndPage takes special action depending on the page count. The first problem<br>
- is that we don't reset the count of pages in the device, and Acrobat can<br>
- be shown to do so on *any* call to setpagedevice (even if the dictionary<br>
- is empty). In zsetdevice() we now reset the page count in the current device<br>
- so that he page count is reset, even if the device doesn't change.<br>
-<br>
- Secondly we call .trysetparams before we execute the EndPage routine (if<br>
- present). The problem here is that .trysetparams actually modifies the<br>
- page device dictionary (and hence the device) and so attributes can change<br>
- before the EndPage, in particular the PageSize. The /setpagedevice routine<br>
- has been modified to move the execution of EndPage much earlier in the<br>
- process. Again testing with Adobe Acrobat shows that the EndPage procedure<br>
- is executed if the dictionary argument is empty, and indeed even if the<br>
- execution of setpagedevice causes an error.<br>
-<br>
- No differences expected. Note this is a potentially destabilising change.<br>
-<br>
-gs/Resource/Init/gs_setpd.ps<br>
-gs/psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-27 15:55: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=07ed0d0cb0de6ebc456a08ca0484c0e8a120b472">07ed0d0cb0de6ebc456a08ca0484c0e8a120b472</a>
-<blockquote>
-<p>
- PDF interpreter - clamp invalid numbers to 0 in Shading Coords<br>
-<br>
- Bug 694542 &quot;Ghostscript failed to convert pdf file to images&quot;<br>
-<br>
- The specimen file contains invalid numbers in the Coords array of every<br>
- Shading dictionary. Acrobat (of course) handles this by silently converting<br>
- all such numbers to 0.<br>
-<br>
- This commit checks the Coords of the Shading, and if any entry is not a number<br>
- (our token parser converts invalid numbers to names) it replaces it with a<br>
- xero.<br>
-<br>
- No differences expected<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-27 13:20:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e413f6aa426fb63c2e9709ad8d28ab862bc1d44d">e413f6aa426fb63c2e9709ad8d28ab862bc1d44d</a>
-<blockquote>
-<p>
- Add the font embedding paragraph.<br>
-<br>
- The URW+ fonts are licensed under the GPL, with an additional allowance<br>
- for embedding the fonts, and that embedding not affecting the license of<br>
- the document in which the font is embedded.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/LICENSE<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-27 11:21: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=8b6be8be2cdcefae39339682d45d3c009ab909ac">8b6be8be2cdcefae39339682d45d3c009ab909ac</a>
-<blockquote>
-<p>
- pdfwrite - more discriminating tests before TrueType font combining<br>
-<br>
- Bug 694538 &quot;Incorrect embedding of fonts&quot;<br>
-<br>
- The test file does not appear to be the regular output of the MS Windows<br>
- PostScript driver, it looks like several files have been stripped and then<br>
- added together. A process liable to failure at the best of times.<br>
-<br>
- In this case we end up with a large number of incrementally downloaded,<br>
- subset, TrueType fonts. Despite the fact that these are the same font and<br>
- in many cases contain the same, or compatible, subsets the fonts are<br>
- downloaded several times, which is why I believe this to be a combination<br>
- of separately created files.<br>
-<br>
- pdfwrite tries to combine such fonts, and does so quite succcesfully in<br>
- this case. However, the individual fonts are not all alike. Some information<br>
- in the TrueType table is clearly copied from the original font (eg the<br>
- numGlyphs value of 3147) and some is not. In particular the maxPoints<br>
- value differs between two otherwise compatible subset fonts (one has additional<br>
- glyphs). It seems Acrobat doesn't like this, it sometimes raises an error<br>
- and does not display any glyphs whose point count exceeds the maxPoints<br>
- value.<br>
-<br>
- This commit adds the maxPoints and maxContours values to the gs_type42_data<br>
- structure and tracks them. Fonts are not now considered compatible if<br>
- these values are different between them.<br>
-<br>
- This will lead to less font merging, but for sensibly created programs<br>
- this will not be a problem, as the driver only downloads the font once. For<br>
- programs created by jamming files together it will prevent the situation<br>
- where we create a font which Acrobat cannot read.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gstype42.c<br>
-gs/base/gxfont42.h<br>
-gs/devices/gxfcopy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-26 14:31: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=e9b47527ec10d911f8154c60f746985e139606b8">e9b47527ec10d911f8154c60f746985e139606b8</a>
-<blockquote>
-<p>
- Bump version number<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-30 10:00: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=7fcadf3b8b0ef1662419c15b8d51e36e434804be">7fcadf3b8b0ef1662419c15b8d51e36e434804be</a>
-<blockquote>
-<p>
- Update product string, dates and docs for 9.10 release.<br>
-<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-29 16:47:29 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b8d4701f17205624ebffe3d4630c9df87ac095b0">b8d4701f17205624ebffe3d4630c9df87ac095b0</a>
-<blockquote>
-<p>
- Bug 694546: Fix undefined behaviour in gdevpbm.<br>
-<br>
- Thanks to jsmeix for reporting this.<br>
-<br>
-gs/devices/gdevpbm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-27 13:56:35 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0680e46d927d1cc02a4bad4c3a90cb9adc3d4580">0680e46d927d1cc02a4bad4c3a90cb9adc3d4580</a>
-<blockquote>
-<p>
- Bring docs up to date for RC.<br>
-<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-26 14:29:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=466d8f67a5b1ada99d05777ba33fab48a7d74bc9">466d8f67a5b1ada99d05777ba33fab48a7d74bc9</a>
-<blockquote>
-<p>
- Change product string for release candidate<br>
-<br>
-gs/base/gscdef.c<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-
-
-<h2><a name="Version9.10"></a>Version 9.10 (2013-08-27)</h2>
-
-<p>This is the ninth full release in the stable 9.x series, and is
-primarily a maintenance release.
-
-<p> Highlights in this release include:
-<ul>
-<li>
-<p> Background printing (BGPrint) is a new feature allowing an accumulated page
-clist to be rendered by one or more rendering threads whilst the interpreter
-(in the "main" thread) continues to accumulate the subsequent page's clist.
-For certain classes of file this can result in a useful performance increase.
-See: <a href="Language.htm#Banding_parameters">Banding Parameters</a>
-</li>
-<li>
-<p> GrayDetection allows suitably written devices to detect "color" input
-in near neutral tones (i.e. near monochrome) and to convert "on-the-fly" to
-pure grayscale, whilst retaining the ability to print full color on demand.
-This is primarily aimed at workflows where saving ink (especially color inks)
-is required.
-See: <a href="Language.htm#Device_parameters">Device Parameters</a>
-</li>
-<li>
-<p> LittleCMS2 and libpng have both been updated to the latest versions.
-</li>
-<li>
-<p> Support has been added to build the Ghostscript DLL for WinRT for x86,
-x64 and ARM (Requires MS Visual Studio 2012 Pro).
-</li>
-<li>
-<p> Processing of Windows command line arguments into UTF8 (as presaged a few
-releases ago) has been enhanced and enabled by default.
-</li>
-<li>
-<p> The URW Postscript font set has been updated to the latest version, fixing
-many compatibility problems with the Adobe fonts.
-</li>
-<li>
-<p>Plus the usual round of bug fixes, compatibility changes, and incremental improvements.
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.10_Incompatible_changes"></a>Incompatible changes</h3>
-<p>
-No recorded incompatible changes.
-
-<h3><a name="9.10_changelog"></a>Changelog</h3>
-<p><strong>2013-08-29 16:47:29 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b8d4701f17205624ebffe3d4630c9df87ac095b0">b8d4701f17205624ebffe3d4630c9df87ac095b0</a>
-<blockquote>
-<p>
- Bug 694546: Fix undefined behaviour in gdevpbm.<br>
-<br>
- Thanks to jsmeix for reporting this.<br>
-<br>
-gs/devices/gdevpbm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-26 14:29:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=466d8f67a5b1ada99d05777ba33fab48a7d74bc9">466d8f67a5b1ada99d05777ba33fab48a7d74bc9</a>
-<blockquote>
-<p>
- Change product string for release candidate<br>
-<br>
-gs/base/gscdef.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-25 20:52:36 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a319086dd71dbcc3ec71b70277734595647784d">4a319086dd71dbcc3ec71b70277734595647784d</a>
-<blockquote>
-<p>
- Fix bug 694539. Reading off the end of the cbuf when dash pattern len is max.<br>
-<br>
- The max length dash pattern (currently 11) was used frequently in this file,<br>
- and in at least one case, this tripped over a memmove that is way too large in<br>
- the top_up_cbuf because the pointer was past the end of the buffer, and the<br>
- unsigned int count was 0xffffffff. The root cause was that the cmd_largest_size<br>
- used to set the warn_limit did not account for both the dot_length and the<br>
- offset.<br>
-<br>
- I corrected cmd_largest_size, added some comments, and added an error message<br>
- and ioerror return to top_up_cbuf.<br>
-<br>
-gs/base/gxcldev.h<br>
-gs/base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-24 10:36: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=2001f469b539a5ccce301ace5d6384b6b7e46888">2001f469b539a5ccce301ace5d6384b6b7e46888</a>
-<blockquote>
-<p>
- Fix -dUseCIEColor (part of the whole VM allocation problem)<br>
-<br>
- See commit ae930279498a5961fcf5d70ffe86864883609cbc for a lengthy explanation)<br>
- of the background to this problem.<br>
-<br>
- The fix for the original problem involved always creating the device dictionary<br>
- for setpagdevice in local VM.<br>
-<br>
- Following on from that we discover the following in zdsp1.c<br>
-<br>
- gstate_check_space(i_ctx_t *i_ctx_p, int_gstate *isp, uint space)<br>
- {<br>
- /*<br>
- * ****** WORKAROUND ALERT ******<br>
- * This code doesn't check the space of the non-refs, or copy their<br>
- * contents, so it can create dangling references from global VM to<br>
- * local VM. Because of this, we simply disallow writing into gstates<br>
- * in global VM (including creating them in the first place) if the<br>
- * save level is greater than 0.<br>
- * ****** WORKAROUND ALERT ******<br>
-<br>
- Now, if we execute the Display PostScript .savelocalstate routine, its vital<br>
- that the gstate and all its contents be in global VM in order to satisfy<br>
- the test in zdps1.c.<br>
-<br>
- So, any calls to setpagedevice before the call to .savelocal must allocate<br>
- the page device dictionary in global VM (as a pointer to the device dictionary<br>
- is saved in the gstate)<br>
-<br>
- Thus we need a way to tell setpagedevice to allocate its dictionary in global<br>
- VM, even though we usually want it in local VM.<br>
-<br>
- This commit adds a somewhat hacky method for this, we insert a specific key<br>
- /..StartupGlobal in the page device dictionary. If setpagedevice finds this<br>
- key in the dictionary we allocate the dict in global VM, and remove the key.<br>
-<br>
- We then use this key in a couple of places in gs_init.ps where we execute<br>
- setpagedevice *before* we've reached .savelocalstate.<br>
-<br>
- This fixes all the myriad problems with allocation states and gives us a way<br>
- to add any more that are required.<br>
-<br>
- I've put a comment into gs_init.ps immediately before /.savelocalstate so<br>
- at least in the future it will be easier to figure out where this is required.<br>
-<br>
- I've searched all the initialisation files looking to see if there are any<br>
- other likely places (the INITFILES string is parsed before we get to<br>
- .savelocalstate) and they all look acceptable. None of the routines actually<br>
- execute setpagedevice.<br>
-<br>
- No cluster differences expected as none of this is tested<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-23 09:15: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=c1510d726063080559e9597db7d4a686f2ca4eae">c1510d726063080559e9597db7d4a686f2ca4eae</a>
-<blockquote>
-<p>
- correct some typos in PDFDocEncoding to UTF8 conversion<br>
-<br>
- Bug #694535 &quot;Typo in charset conversion in gdevpdfe.c&quot;<br>
-<br>
- Credit (and thanks) to Tim Waugh at Red Hat for the fix, applied here.<br>
-<br>
- No differences expected, we clearly don't have any examples that exercise<br>
- this particular case in our test suite.<br>
-<br>
-gs/devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-23 08:42: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=ae930279498a5961fcf5d70ffe86864883609cbc">ae930279498a5961fcf5d70ffe86864883609cbc</a>
-<blockquote>
-<p>
- More work related to VM mode, setpagdevice and startup conditions<br>
-<br>
- This has a lengthy bug tail attached to it, the summary follows, prior<br>
- commits of interest are (ordered by date, earliest first):<br>
- 073f7be1671e7fa2dbbc75984e593d2279bb05d7<br>
- 939e32ff3c8841507aed80435269457f3caac6f5<br>
- 774231a7db63439c72313050a750b219491c172f<br>
- 39b494d41a814e6b27a5828030e58e0b239044fb<br>
-<br>
- Initially the bug report was #687702 &quot;gs8.15 setpagedevice /invalidaccess&quot;,<br>
- the problem was caused by a 'fix' for WordPerfect files which assumed a local<br>
- VM writeable dictionary returned by currentpagedevice. The fix was to create<br>
- a local VM copy of the dictioanry, because its acceptable to store global<br>
- objects in local VM, but not vice versa. (073f7be1671e7fa2dbbc75984e593d2279bb05d7)<br>
-<br>
- However, if we start with -dSAFER then, quite early in gs_init.ps, we call<br>
- /.setsafe (which called /.locksafe) which ends up executing setpagdevice<br>
- in order to set /LockSafetyParams. This causes the page device dictionary to<br>
- be allocated in local VM. This should not cause any problems, but.....<br>
- setpagedevice stores a pointer to the returned dictionary in the graphics<br>
- state, the Display PostScript initialisation code insists that all objects<br>
- in the 'savedinitialgstate' be in global VM, and we just allocated the dict<br>
- in local VM, so we get an error.<br>
-<br>
- This was fixed in setpagedevice by checking for a 1 element dictioanry<br>
- with the specific key '/LockSafetyParams', and creating a global VM dict<br>
- instead of a local one. (939e32ff3c8841507aed80435269457f3caac6f5)<br>
-<br>
- We then discovered that GSView sends PostScript containing '.locksafe',<br>
- which triggers the check in sepagedevice and sets the VM allocation mode<br>
- to global, causing an invalidaccess error. GSView should not be using<br>
- undocumented internal routines but it was decided to fix this, even though<br>
- a release had just been completed. This was done by creating a new routine<br>
- '.locksafeglobal' which sets a key called /LockSafetyParamsGlobal and<br>
- having setpagedevice check for that key, if discovered it creates a global<br>
- VM dictionary and replaces the key with /LockSafetyParams. Finally /.locksafety<br>
- was returned to its original state. (774231a7db63439c72313050a750b219491c172f)<br>
-<br>
- A new release was completed, and it then transpired that, despite having<br>
- tested gv briefly, under certain conditions it executes a script (pdf2dsc)<br>
- which uses pdf2dsc.ps, which calls .setsafe. This didn't seem terribly<br>
- important and so the line was removed from the PS file.<br>
-<br>
- Ray pointed out that the .setsafe routine is (minimally) documented in<br>
- use.htm, and it seems is important to the Unix community because of the<br>
- 'SAFER' switch. So this commit restores /.setsafe (and the line in pdf2dsc.ps)<br>
- and creates a new /.setsafeglobal. This is *only* executed in gs_init.ps,<br>
- its presence is solely for the benefit of DPS so that the initial gstate<br>
- is allocated in global VM, and must not be used anywhere else.<br>
-<br>
- Hopefully we can finally say goodbye to all this mess now.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/lib/pdf2dsc.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-22 16:07:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39b494d41a814e6b27a5828030e58e0b239044fb">39b494d41a814e6b27a5828030e58e0b239044fb</a>
-<blockquote>
-<p>
- remove a '.setsafe' from the PS file it doesn't work any more and nobody<br>
- should be using undocumented internal routines anyway.<br>
-<br>
- We should probably remove pdf2dsc altogether, it relies on using parts<br>
- of the PDF interpreter which, as far as I'm concerned, are subject to<br>
- change without notice.<br>
-<br>
-gs/lib/pdf2dsc.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-22 13:33:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dfd7fc9fe152245256e437141dd7780c8313c971">dfd7fc9fe152245256e437141dd7780c8313c971</a>
-<blockquote>
-<p>
- pdfwrite - make the saved gstate stack dynamically allocated instead of static array<br>
-<br>
- Bug #693591 &quot;Infinite loop writing pdf file&quot;<br>
- Bug #694531 &quot; &quot;*** File has unbalanced q/Q&quot; infinite loop on seemingly valid file&quot;<br>
-<br>
- The stack of saved gstates in pdfwrite was a statically allocated array of 11<br>
- elements. Cairo produces PDF files with insane (and pointless) levels of<br>
- Form XObject nesting which can easily break this limit (as well as causing all<br>
- PDF consumers to render the files slowly)<br>
-<br>
- This commit replaces the fixed size array with a dynamically allocated array.<br>
- For performance reasons we still allocate 11 elements initially, and if we<br>
- exhaust the storage, we reallocate 5 elements larger.<br>
-<br>
- This also shows a progression in the test file 'inefficient_tiling.pdf' this<br>
- file is produced by LaTeX but I guess it may be using Cairo behind the<br>
- scenes.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfb.h<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-16 10:35:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=868bcc0c697619a276e725fd851b5f52079e64a5">868bcc0c697619a276e725fd851b5f52079e64a5</a>
-<blockquote>
-<p>
- Bring master up to date with 9.09 release branch<br>
-<br>
- update docs, version numbers, dates and product string<br>
-<br>
- Update product string, dates and changelog for 9.09 release.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-21 14:26: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=243c299262d0e5ebac46f517e749a3d45cbe9c46">243c299262d0e5ebac46f517e749a3d45cbe9c46</a>
-<blockquote>
-<p>
- Fix a compiler warning which exhibited a real problem<br>
-<br>
- In gdevpdfp.c remove a redefinition of 'code'. The 'for' loop uses the<br>
- outer definition of 'code', but the inner definition is set by<br>
- cos_dict_put_c_key_string() This means that the inner definition is never<br>
- used, and the outer one used to control the loop is never changed, defeatimg<br>
- the purpose.<br>
-<br>
- The other new compiler warnings in pdfwrite are either not valid (some warnings<br>
- are incorrect) or benign and fixing them introduces other warnings.<br>
-<br>
-gs/devices/vector/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-21 13:23: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=077435083eb0d8acb91686ba8b745ec8371e16fd">077435083eb0d8acb91686ba8b745ec8371e16fd</a>
-<blockquote>
-<p>
- Correct the evaluation order in filenameforall processing<br>
-<br>
-gs/base/gp_ntfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-21 10:13: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=735589e5b16cf3d31c6bf73ebd75259db9d18f3c">735589e5b16cf3d31c6bf73ebd75259db9d18f3c</a>
-<blockquote>
-<p>
- Yet more work on NTFS file enumeration<br>
-<br>
- Bug #686853, SaGS comment #9<br>
-<br>
- We now match the pattern template only at the top level of the recursion,<br>
- any directories which match the pattern are enumerated, but their entire<br>
- contents are listed.<br>
-<br>
- Multiple path separators are now removed at each level. It should now be<br>
- impossible to reach a situation where a returned file has '\/' or similar<br>
- contained within it.<br>
-<br>
- Illegal characters ('*' and '?') in the path will now cause no matches to<br>
- be returned. These are of course valid after the final separator of the<br>
- path and will match filename patterns at that level.<br>
-<br>
- I've checked this with various paths utilising multiple path separators,<br>
- mixed use of separators, illegal escaped characters in the path and a modest<br>
- variety of patterns. All this with COMPILE_INITS=0 and COMPILE_INITS=1 and<br>
- in both cases with GS_NO_UTF8=1 and without specifying GS_NO_UTF8. All seems<br>
- to be OK in all cases. None of this is tested by the cluster of course.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gp_ntfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-20 10:21: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=b0c3a494395db460cbb8e28a6896eebccc6b797a">b0c3a494395db460cbb8e28a6896eebccc6b797a</a>
-<blockquote>
-<p>
- Ensure we don't overflow the filename buffer.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gp_unifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-20 10:23: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=c1544d825be1f87ed0821ef0163d08595b5fc0e6">c1544d825be1f87ed0821ef0163d08595b5fc0e6</a>
-<blockquote>
-<p>
- Make the Windows implementation of filenameforall match the Unix version<br>
-<br>
- The Unix version of filenameforall starts in the current working directory<br>
- when no directory is specified.<br>
-<br>
- When the pattern length exceeds the available string we should return a<br>
- rangecheck error, not an empty string.<br>
-<br>
- When the filename exceeds the available string we should return a<br>
- rangecheck error, not a truncated string.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gp_ntfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-19 15:06: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=d6921b5c5ab2af44c48e0084e4a31bcd7512f183">d6921b5c5ab2af44c48e0084e4a31bcd7512f183</a>
-<blockquote>
-<p>
- Allow use of '\\' for filenameforall and friends on Windows<br>
-<br>
- The commit to allow recursive directory enumeration f13bfba removed the<br>
- code which translated '\\' into '\', which could lead to incorrect filenames<br>
- being returned.<br>
-<br>
- This fix restores that functionality, but we still think everyone would be<br>
- better advised to use the PostScript '/' separator instead, which works as<br>
- well as '\' does.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gp_ntfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-18 21:05:00 +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=613554e16d315c8db89653775c1fdcf682f238fe">613554e16d315c8db89653775c1fdcf682f238fe</a>
-<blockquote>
-<p>
- Add quotes around values for a conditional for VS build.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-main/pcl6_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-16 14:00: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=7d93cf893d1d2fac826e3c5f81ea92123425216e">7d93cf893d1d2fac826e3c5f81ea92123425216e</a>
-<blockquote>
-<p>
- Address gp_wgetv not finding *any* environment variables unless compiled with GS_NO_UTF8<br>
-<br>
- The string being passed in as the 'name' was a regular 1 byte C char array.<br>
- But _wgetenv expects to be given a wide character string to find and<br>
- treats the argument as such. This mean environment variables never matched.<br>
-<br>
- This commit mimics the code for the registry variables, and converts the<br>
- name to a wchar before passing to _wgetenv.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gp_wgetv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-02 09:32:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ae09189f11f59c2d350cca820c880cd48a0657d0">ae09189f11f59c2d350cca820c880cd48a0657d0</a>
-<blockquote>
-<p>
- Fix a couple of very minor UFST build issues.<br>
-<br>
- Automatically drop the default Truetype fonts if we're integrating the UFST<br>
- (with it's attendant MT fonts).<br>
-<br>
- No cluster differences.<br>
-<br>
-main/pcl6_gcc.mak<br>
-main/pcl6_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-16 12:47:36 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e67e098fa0b5bf7570453c15ccc98fabf1e561dc">e67e098fa0b5bf7570453c15ccc98fabf1e561dc</a>
-<blockquote>
-<p>
- Fix GS_NO_UTF8 build problem with gs_sprintf.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gp_wgetv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-16 07:58: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=774231a7db63439c72313050a750b219491c172f">774231a7db63439c72313050a750b219491c172f</a>
-<blockquote>
-<p>
- PS Interpreter - yet more meddling with VM allocation and setpagedevice<br>
-<br>
- Bug #694525 &quot;GSView 5.0 does not work with GPL Ghostscript 9.08&quot;<br>
-<br>
- Rather horrifyingly GSView uses undocumented internal operations of<br>
- Ghostscript. In this case the changes to VM allocation mode during setpagedevice<br>
- were being circumvented.<br>
-<br>
- This commit changes the way we detect a setpagedevice during startup, previously<br>
- we check that the dictionary contained one key called /.LockSafetyParams<br>
- and if so assumed that this meant we were in startup, so we set the VM<br>
- allocation mode to global for the benefit of Display PostScxript.<br>
-<br>
- GSView ended up triggering that test, which caused a VM allocation error.<br>
-<br>
- We now look for the key /.LockSafetyParamsGlobal instead. If this is present<br>
- we set the VM allocation mode to global and *replace* the key with<br>
- /.LockSafetyParams instead. This allows accurate detection of the startup<br>
- condition.<br>
-<br>
- No differences expected, GSView 5 seems to work and the original bug still<br>
- is fixed.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-15 19:56: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=4be79a96fe22c988cc4d9edfedac75e6f46e15fa">4be79a96fe22c988cc4d9edfedac75e6f46e15fa</a>
-<blockquote>
-<p>
- Bump version number.<br>
-<br>
- The usual cluster differences.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-15 16:53: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=43e4db79a40b2ac73eac2bf3732f2e2dcc122d12">43e4db79a40b2ac73eac2bf3732f2e2dcc122d12</a>
-<blockquote>
-<p>
- Update special antidropout downscaler code.<br>
-<br>
- In hunting for bug 694451, it looked like the problem was in the<br>
- special antidropout downscaler for a while, but this turned out<br>
- not to be the culprit.<br>
-<br>
- Nonetheless, the code had not been updated to take advantage of the<br>
- 'Active' region optimisations, so we do that here.<br>
-<br>
-gs/base/sidscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-15 16:09:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f86ac4209753ea0e9e06a9f4c22a19a8447b5fb5">f86ac4209753ea0e9e06a9f4c22a19a8447b5fb5</a>
-<blockquote>
-<p>
- Some chenges fed back from customer #661 and.....<br>
-<br>
- some function naming tidy ups I've been meaning to do for some time.<br>
-<br>
- The changes from #661 make the code a bit more flexible for different<br>
- configurations of the font rendering library.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-gs/base/fapiufst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-15 09:06: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=6ba5abfa7325ae980bba37fdc71582eeca152a87">6ba5abfa7325ae980bba37fdc71582eeca152a87</a>
-<blockquote>
-<p>
- update caption.ps so that it does not mark the page on device deactivation<br>
-<br>
- Bug #694517 &quot;additional page with caption.ps&quot;<br>
-<br>
- The EndPage procedure in caption.ps marks the page in the file with the<br>
- defined caption regadless of the reason code for the EndPage. This means<br>
- that it marks the page even on device deactivation.<br>
-<br>
- Since commit 3894e9c8a3ab125c82048da3bf81515500bb2da0 pdfwrite will emit<br>
- pages that are marked, even if no showpage is executed (this is to match<br>
- observed Acrobat Distiller behaviour) and this means that an extra 'blank'<br>
- page is emitted on device deactivation.<br>
-<br>
- This commit simply modifies caption.ps so that it only writes the caption<br>
- if the reason for calling EndPage is *not* device deactivatyion.<br>
-<br>
-gs/lib/caption.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-31 07:45: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=a65df0454d1a8de06d2d342100408482c9ec101b">a65df0454d1a8de06d2d342100408482c9ec101b</a>
-<blockquote>
-<p>
- Bring master up to date with 9.08 release branch.<br>
-<br>
- Change product string for release candidate.<br>
-<br>
- No unexpected cluster differences.<br>
-<br>
- Update version and product strings for release candidate.<br>
-<br>
- Update news and history for 9.08 release.<br>
-<br>
- Update release date for 9.08 release.<br>
-<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-gs/psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-14 16:42:49 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c07d6c816052686d29efdee5e94567066baaf75a">c07d6c816052686d29efdee5e94567066baaf75a</a>
-<blockquote>
-<p>
- Remove stray cluster products.<br>
-<br>
- These should never have been committed.<br>
-<br>
-clustercmd<br>
-clusterdatestamp<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-14 08:59: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=2c369110313fda917820faf3657dee55158b538b">2c369110313fda917820faf3657dee55158b538b</a>
-<blockquote>
-<p>
- PS Interpreter - populate the /OutputDevice resource<br>
-<br>
- Bug #689500 &quot;/OutputDevice category is empty&quot;<br>
-<br>
- This commit uses the devices built into the executable to populate the<br>
- /OutputDevice resource. The bug thread suggests using devicedict but we<br>
- can't do that in gs_res.ps because it isn't set up until later. So we<br>
- duplicate the code used to populate devicedict.<br>
-<br>
- According to the PLRM the only required member of the OutputDevice resource<br>
- instance is the PageSize, I've chosen to copy the same values as Adobe Acrobat<br>
- Distiller, but these can be changed if this proves to be a limitation.<br>
-<br>
- Two additional changes were required, exposed by the Quality Logic test file<br>
- 09-59.ps<br>
-<br>
- In gdevdevn.c devn_get_params() it is possible for the function to be called<br>
- with pequiv_colors set to NULL, this caused a seg fault. Modified the code<br>
- so that it doesn't attempt to dereference a NULL pointer.<br>
-<br>
- The file 09-59.ps uses setpagedevice to set each possible instance of the<br>
- OutputDevice resources, this can cause problems with some devices as it<br>
- doesn't actually send a file. In particular with the mswinpr2 device on<br>
- Windows, but it also caused errors on Linux. Since this is a CET file,<br>
- gs_cet.ps was modified to delete the OutputDevice resource category and<br>
- create a new empty one.<br>
-<br>
- Expected Differences<br>
- 430-01.ps enumerates all the entries in /OutputDevice and so has a *lot*<br>
- more data to print.<br>
-<br>
-gs/Resource/Init/gs_cet.ps<br>
-gs/Resource/Init/gs_res.ps<br>
-gs/base/gdevdevn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-13 00:04:57 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b89761f06d297f8555f346e9c0a7850fc549c668">b89761f06d297f8555f346e9c0a7850fc549c668</a>
-<blockquote>
-<p>
- Fix for problem with double application of alpha when composing isolated groups.<br>
-<br>
-gs/base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-13 13:48: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=6c7d9d1191ed4afad16f7bc4089a43bb18190a96">6c7d9d1191ed4afad16f7bc4089a43bb18190a96</a>
-<blockquote>
-<p>
- Fix bug 694514. Don't use clist HL images in pattern-clist when interpolated.<br>
-<br>
- Since patterns that are put in the clist are large, interpolating multiple<br>
- times for every band intersected by the pattern can kill performance.<br>
-<br>
-clustercmd<br>
-clusterdatestamp<br>
-gs/base/gxclimag.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-13 15:30: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=d7c310e59953aacdeb642ce202c0911071a80d31">d7c310e59953aacdeb642ce202c0911071a80d31</a>
-<blockquote>
-<p>
- Bug 694513: force chars to signed on AIX with Luratech<br>
-<br>
- The Lutatech JBIG2 decoder requires signed chars, so add the requisit flags for<br>
- for the Luratech build to ensure that happens.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-09 17:02: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=e9f0f0eb05ee0abea13deabab6617d20e1913e83">e9f0f0eb05ee0abea13deabab6617d20e1913e83</a>
-<blockquote>
-<p>
- Fix bug 694455. Incorrect CTM when rendering SMasks.<br>
-<br>
- The clippath was incorrect due to the CTM. As specified in 7.5.4 of the PDF spec:<br>
-<br>
- The mask's coordinate system is defined by concatenating the transformation<br>
- matrix specified by the Matrix entry in the transparency group's form dictionary<br>
- (see Section 4.9.1, &quot;Form Dictionaries&quot;) with the current transformation matrix<br>
- at the moment the soft mask is established in the graphics state with the gs<br>
- operator.<br>
-<br>
- This fixes the customer's file and also results in a progression on<br>
- comparefiles/Bug693681.pdf where extra data was previously showing.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-09 16:00: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=e72c03d49e6c0e107afa32b5b2b8a6cf9d43b663">e72c03d49e6c0e107afa32b5b2b8a6cf9d43b663</a>
-<blockquote>
-<p>
- PDF Interpreter - undo commit 946f63b5748a5a19c369a1d42e653c69cd57075e<br>
-<br>
- Marcos wants to have files produce an error, so we don't run them in a<br>
- stopped context any more.<br>
-<br>
- In fact it appears that later work means none of these files exit the<br>
- interpreter on error any more, they do produce PostScript error messages<br>
- though.<br>
-<br>
- 1305_-_crypt_filter_length_ignored.pdf.pdf<br>
- 1479_-_does_not_render.pdf<br>
- 1931_-_crypt_version_5_revision_6.pdf<br>
- 692248_-_recursive_ObjStm_ref.pdf<br>
- 692248_-_wrong_ObjStm_ref.pdf.pdf<br>
- 694313_-_double-free_during_reparation_fails_.pdf<br>
- 694313_-_empty_xref.pdf<br>
- Adobe_LiveCycle_DRM_protection_sample_Adobe.APS_-_adbe.pdrl.v0_fails_.pdf<br>
- MSVR_176_-_missing_range_check_in_pdf_repair_fails_.pdf<br>
- MSVR_201_-_missing_CIDSystemInfo.pdf<br>
- annotations_without_font.pdf<br>
- double_indirect_reference.pdf<br>
- huge_cmap_values.pdf<br>
- recursive_indirect_reference.pdf<br>
- recursive_outline.pdf<br>
- repairing_leaks_object.pdf<br>
- x_-_SumatraPDF1.1DOS.pdf<br>
-<br>
-<br>
- all now produce errors again<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-09 15:15: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=44800428c346804af98b1d9b2e86b6d8e61b858b">44800428c346804af98b1d9b2e86b6d8e61b858b</a>
-<blockquote>
-<p>
- Delete the ._.DS_Store .DS_Store files.....<br>
-<br>
- which cause problems decompressing release archives on OS X.<br>
-<br>
-gs/lcms2/Projects/mac/.DS_Store<br>
-gs/lcms2/Projects/mac/._.DS_Store<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-09 13:50: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=010e9990d734a8a2361663338b1fbd605d0ca052">010e9990d734a8a2361663338b1fbd605d0ca052</a>
-<blockquote>
-<p>
- PDF interpreter and pdfwrite - better handling of Outlines and Dests<br>
-<br>
- Bug #690253 &quot;'pdfmark destination page' error while splitting a PDF: confusing output and invalid links.&quot;<br>
-<br>
- Several parts to this, we had already removed the 'ERROR' from the message<br>
- emitted when a DEST or OUT pdfmark pointed to a page outside the valid range.<br>
-<br>
- This commit makes pdfmark produce an error when an Outline has an invalid<br>
- range (DEST laready did). We also wrap pdfmark invocations in 'stopped' so<br>
- that we can trap the error. This allows us to elide Links and Outlines to<br>
- invalid pages (previously the links remained, but did nothing useful).<br>
-<br>
- Since the bug was raised, we now also use the '%d' syntax to split PDF<br>
- files. This would still produce invalid links, because the page number<br>
- would not be invalid.<br>
-<br>
- We now check the OutputFile when opening a PDF file, and if it contains<br>
- '%d' we set a couple of flags which will skip Outline and Dest link creation<br>
- as these would never be correct.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-08 08:50: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=a850d6c6d14f3a40bb8d40e471bf4822ead8580d">a850d6c6d14f3a40bb8d40e471bf4822ead8580d</a>
-<blockquote>
-<p>
- PDF Interpreter - update to 073f460af5bb37edb1849c5d6235048598100437<br>
-<br>
- Bug #694508 &quot;Regression: error writing PDF file starting with<br>
- 72b397ecb4f5be3fdbf6da4a90a306d259ec3e93&quot;<br>
-<br>
- The commit 073f460af5bb37edb1849c5d6235048598100437 had an error in the<br>
- handling of named actions, which I didn't previously have a test case for.<br>
- NB the commit in the bug title is incorrect, I'm not clear on why Marcos<br>
- thought this was the commit which introduced the error.<br>
-<br>
- This commit fixes that and allows me to test the named actions, which now<br>
- work correctly.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-07 13:18: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=073f460af5bb37edb1849c5d6235048598100437">073f460af5bb37edb1849c5d6235048598100437</a>
-<blockquote>
-<p>
- PDF interpreter - improve handling of pdfmarks when we have multiple input files<br>
-<br>
- Bug #688542 &quot;Bookmarks Get Lost In PDF&quot;<br>
- Bug #688829 &quot;Merging PDF files using gs: outlines and links not updated&quot;<br>
-<br>
- The pdfmarks generated by the PDF interpreter for Outlines and Links use the<br>
- page number relative to the start of the current input file. For single<br>
- input files this works fine, but when we have multiple input files, we end<br>
- up with outlines and links pointing to the wrong place.<br>
-<br>
- To resolve this we need to know, at the start of any PDF file, how many pages<br>
- have already been processed, and then we will add this value to the nominal<br>
- page number when creating the pdfmarks.<br>
-<br>
- Hin-Tak provided a solution (#688829) that used globaldict, which Alex rejected<br>
- for that reason. This commit executes currentpagedevice at the start of every<br>
- PDF input file, and stores in in /CumulativePageCount. We can then use this<br>
- to generate pdfmarks which are correct.<br>
-<br>
- Even if PDF and PostScript input files are mingled, the PDF-generated pdfmarks<br>
- will still be correct.<br>
-<br>
- We won't make any attempt to correct PostScript input, if you are creating a<br>
- PostScript program, you should get it right. If you really must merge, then<br>
- use pdfwrite to create the individual PDF files, and then merge those.<br>
-<br>
- It is possible that other types of generated pdfmark will need similar<br>
- alteration, we'll tackle those as they turn up.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-05 17:42: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=22e66c90bf173e4787717137a25833b4aa823993">22e66c90bf173e4787717137a25833b4aa823993</a>
-<blockquote>
-<p>
- PDF interpreter - increased checking of Outlines, to avoid errors<br>
-<br>
- Bug #694503 &quot;Regression: output pdf file blank starting with 0c8150ab6b2b8ceaa17cc1b1933d523764ffe114&quot;<br>
-<br>
- After attempting to recover from broken objects, it was possible to<br>
- throw an error when processing Outlines, because the recovered object<br>
- was of the wrong type. This could cause PDF files with broken /Outlines to<br>
- fail with pdfwrite, where previously they would write a file, but drop the<br>
- /Outlines. (this only occurs wiht pdfwrite, because we ignore Outlines<br>
- when rendering)<br>
-<br>
- This commit restores the previous behaviour by checking the type of the returned<br>
- object.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-05 13:46: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=72b397ecb4f5be3fdbf6da4a90a306d259ec3e93">72b397ecb4f5be3fdbf6da4a90a306d259ec3e93</a>
-<blockquote>
-<p>
- PDF interpreter run .reusablestreamdecode in 'stopped' to handle errors<br>
-<br>
- Bug #694437 &quot; Infinitely many warnings: **** File has unbalanced q/Q operators (too many Q's) ****&quot;<br>
-<br>
- The infinite recursion is due to not updating the current file position, and<br>
- rerunning the same code, which results in the same error.<br>
-<br>
- To handle this we wrap the exeuction of reusablestreamdecode in a 'stopped'<br>
- context, so that we cna capture the error, and move the file pointer as<br>
- required. The job still throws warnings, but the resulting PDF is the same<br>
- as displayed by Acrobat with the original file.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-02 22:26: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=dc77b50bdb6abe88446dc7cdb9d7bd77a90dbfea">dc77b50bdb6abe88446dc7cdb9d7bd77a90dbfea</a>
-<blockquote>
-<p>
- Bug 694502: reverse of dictomark for PDFs<br>
-<br>
- The order with which the key/value pairs in a &lt;&lt;&gt;&gt; (apparently) differs between<br>
- Postscript and PDF. Postscript pushes the objects onto the stack, then pops<br>
- them in pairs, so the order is reversed compared to the order they were<br>
- encountered. PDF handles them in the order they were encountered.<br>
-<br>
- This is, of course, only a problem when there are duplicate keys.<br>
-<br>
- Thus in PS &quot;&lt;&lt; /a 1 /a 2&gt;&gt;&quot; the key &quot;/a&quot; ends up with the value &quot;1&quot;. In PDF, &quot;/a&quot; gets<br>
- the value &quot;2&quot;.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/int.mak<br>
-gs/psi/zdict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-02 16:51: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=d22c7a5b454ca8e021eb6b71c87627bfb8546edb">d22c7a5b454ca8e021eb6b71c87627bfb8546edb</a>
-<blockquote>
-<p>
- Improve use of stopped to guard against PDF interpreter exit<br>
-<br>
- Improvements to commit 946f63b5748a5a19c369a1d42e653c69cd57075e:<br>
-<br>
- 1) Add an error message so that the file does not silently fail to process.<br>
-<br>
- 2) Check PDFSTOPONERROR and do not run in a stopped context if this is set.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-02 15:13:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=946f63b5748a5a19c369a1d42e653c69cd57075e">946f63b5748a5a19c369a1d42e653c69cd57075e</a>
-<blockquote>
-<p>
- run PDF files totally in a stopped context to prevent interpreter exit on error<br>
-<br>
- What it sys on the tin..... Several recent bug reports cause the interpreter<br>
- to exit if it provokes a PostScript error. Running the PDF file in a stopped<br>
- context prevents that from happening.<br>
-<br>
- Bug #694472, but many others up to #694449 are affected similarly.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-02 11:15: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=709c87fb7837993cb96eaa508c66381c1696ebdf">709c87fb7837993cb96eaa508c66381c1696ebdf</a>
-<blockquote>
-<p>
- add extra error checking of the Trailer dictionary<br>
-<br>
- Bug #694474 the file is badly damaged, and Acrobat won't open it. The only<br>
- problem from our perspective is that the error generated causes the<br>
- interpreter to exit (because there is no Trailer dict). Added more checks<br>
- before use to ensure we don't generate errors with missing (empty) trailer<br>
- dictionaries.<br>
-<br>
- A number of other files no longer cause errors when run with the cluster.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/Resource/Init/pdf_rbld.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-02 09:39: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=0c8150ab6b2b8ceaa17cc1b1933d523764ffe114">0c8150ab6b2b8ceaa17cc1b1933d523764ffe114</a>
-<blockquote>
-<p>
- Attempt to handle broken object definitions (garbage on stack)<br>
-<br>
- If we have certain kinds of broken object definitions we can end up with<br>
- more than one object on the stack when we encounter an endobj (or a new<br>
- object definition before encountering an endobj for the previous object).<br>
- Previously we would throw an error and ignore the object (define it as null)<br>
- now we attempt to recover by removing objects from the stack until we have<br>
- a stack of the form 'n n object' where the 'n' represents an integer.<br>
-<br>
- The bug #694443 now runs to completion although the output is empty. Given<br>
- how badly broken this file is I don't propose to do any more with it.<br>
-<br>
-gs/Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-31 15:09:47 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2667fbaa1c6c5ba84acc04ccc5b7b97723c09ad1">2667fbaa1c6c5ba84acc04ccc5b7b97723c09ad1</a>
-<blockquote>
-<p>
- PDF interpreter - remove lower limit on PDF files, improve broken file handling<br>
-<br>
- At some time in the past we set a lower limit of 400 bytes for PDF files,<br>
- regarding anything less as invalid. While this may or may not be true, it<br>
- prevents us repairing broken files that small. Removed the limit.<br>
-<br>
- When repairing a broken xref, we attempt to use the last startxref to find<br>
- the tgrailer dictionary. If the startxref is followed by anything other than<br>
- an integer we should ignore it.<br>
-<br>
- These both arise from Bug #694443 &quot;/undefined in xref&quot;. The bug is not fixed<br>
- because the file exhibits still more faults.<br>
-<br>
- Expected differences:<br>
- The files 694317_-_minimal.pdf, broken_EOF_object_overwrites_good_object,<br>
- missing_endobj_swallows_following_obj and missing_page_tree.pdf no longer<br>
- produce errors.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/Resource/Init/pdf_rbld.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-31 07:41:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91a5d41eb1fea65adb1110ffa2a3b769263b7635">91a5d41eb1fea65adb1110ffa2a3b769263b7635</a>
-<blockquote>
-<p>
- Bump version for pending release.<br>
-<br>
- No unexpected cluster differences<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-21 14:15: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=952b06580b96045a6b052af9a1842d9f770ccd1b">952b06580b96045a6b052af9a1842d9f770ccd1b</a>
-<blockquote>
-<p>
- Update product string, dates and changelog for 9.09 release.<br>
-<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-20 10:21: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=ba1dedf24849295e107df180a291eba99bb33531">ba1dedf24849295e107df180a291eba99bb33531</a>
-<blockquote>
-<p>
- Ensure we don't overflow the filename buffer.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gp_unifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-20 10:23: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=36088d57f45958b3647b21f5ee3908377f113682">36088d57f45958b3647b21f5ee3908377f113682</a>
-<blockquote>
-<p>
- Make the Windows implementation of filenameforall match the Unix version<br>
-<br>
- The Unix version of filenameforall starts in the current working directory<br>
- when no directory is specified.<br>
-<br>
- When the pattern length exceeds the available string we should return a<br>
- rangecheck error, not an empty string.<br>
-<br>
- When the filename exceeds the available string we should return a<br>
- rangecheck error, not a truncated string.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gp_ntfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-19 15:06: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=167ca10abb0a90c4a28a381223afd6fb80347282">167ca10abb0a90c4a28a381223afd6fb80347282</a>
-<blockquote>
-<p>
- Allow use of '\\' for filenameforall and friends on Windows<br>
-<br>
- The commit to allow recursive directory enumeration f13bfba removed the<br>
- code which translated '\\' into '\', which could lead to incorrect filenames<br>
- being returned.<br>
-<br>
- This fix restores that functionality, but we still think everyone would be<br>
- better advised to use the PostScript '/' separator instead, which works as<br>
- well as '\' does.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gp_ntfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-16 10:35:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36c5b40dd44d7ef8de4aeba40c5d6c817882b594">36c5b40dd44d7ef8de4aeba40c5d6c817882b594</a>
-<blockquote>
-<p>
- update docs, version numbers, dates and product string<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-16 10:26: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=e1c028424f6900412241c076f11f4d9f2409cdb0">e1c028424f6900412241c076f11f4d9f2409cdb0</a>
-<blockquote>
-<p>
- Set product string for release candidate 1<br>
-<br>
-gs/base/gscdef.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-16 14:00: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=397abe5622f0a1a9963617fbf1509015563be6fc">397abe5622f0a1a9963617fbf1509015563be6fc</a>
-<blockquote>
-<p>
- Address gp_wgetv not finding *any* environment variables unless compiled with GS_NO_UTF8<br>
-<br>
- The string being passed in as the 'name' was a regular 1 byte C char array.<br>
- But _wgetenv expects to be given a wide character string to find and<br>
- treats the argument as such. This mean environment variables never matched.<br>
-<br>
- This commit mimics the code for the registry variables, and converts the<br>
- name to a wchar before passing to _wgetenv.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gp_wgetv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-16 12:47:36 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8b5a86bad386569f921d0322bf113fa82b3d4529">8b5a86bad386569f921d0322bf113fa82b3d4529</a>
-<blockquote>
-<p>
- Fix GS_NO_UTF8 build problem with gs_sprintf.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gp_wgetv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-16 07:58: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=182beda4d5199210c4c796c8c501e6e4bb5aa2de">182beda4d5199210c4c796c8c501e6e4bb5aa2de</a>
-<blockquote>
-<p>
- PS Interpreter - yet more meddling with VM allocation and setpagedevice<br>
-<br>
- Bug #694525 &quot;GSView 5.0 does not work with GPL Ghostscript 9.08&quot;<br>
-<br>
- Rather horrifyingly GSView uses undocumented internal operations of<br>
- Ghostscript. In this case the changes to VM allocation mode during setpagedevice<br>
- were being circumvented.<br>
-<br>
- This commit changes the way we detect a setpagedevice during startup, previously<br>
- we check that the dictionary contained one key called /.LockSafetyParams<br>
- and if so assumed that this meant we were in startup, so we set the VM<br>
- allocation mode to global for the benefit of Display PostScxript.<br>
-<br>
- GSView ended up triggering that test, which caused a VM allocation error.<br>
-<br>
- We now look for the key /.LockSafetyParamsGlobal instead. If this is present<br>
- we set the VM allocation mode to global and *replace* the key with<br>
- /.LockSafetyParams instead. This allows accurate detection of the startup<br>
- condition.<br>
-<br>
- No differences expected, GSView 5 seems to work and the original bug still<br>
- is fixed.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-15 12:23: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=dde6d480e632eefbe5ccd42bc52b456582514a2a">dde6d480e632eefbe5ccd42bc52b456582514a2a</a>
-<blockquote>
-<p>
- Bug 694451: Solve problems with interpolated landscape images.<br>
-<br>
- The portrait image code accumulates pixels into scanlines, and then<br>
- plots the whole scanline at once. The landscape image code follows<br>
- this lead by accumulating pixels into 'scancolumns' and then plots<br>
- the whole column at once.<br>
-<br>
- Unfortunately this accumulation for columns goes wrong in the case<br>
- where we are working at &lt; 8 bpp (as the transposition of rows to<br>
- columns fails). This causes images with runs of identical pixels in<br>
- to be 'squished' vertically.<br>
-<br>
- We work around this here in the &lt; 8 bpp case by repeating the writes<br>
- of each pixel so whole bytes are filled. This is suboptimal, but<br>
- doing anything else is tricky with the macros the way they are.<br>
-<br>
-gs/base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-14 14:43:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=951be31dd84da8f355bfada103ce7e62d5e8c3b2">951be31dd84da8f355bfada103ce7e62d5e8c3b2</a>
-<blockquote>
-<p>
- Update release date for 9.08 release.<br>
-<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-09 15:15: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=d3d413364f81c379754b7738c58bb7b74b7ed3c4">d3d413364f81c379754b7738c58bb7b74b7ed3c4</a>
-<blockquote>
-<p>
- Delete the ._.DS_Store .DS_Store files.....<br>
-<br>
- which cause problems decompressing release archives on OS X.<br>
-<br>
-gs/lcms2/Projects/mac/.DS_Store<br>
-gs/lcms2/Projects/mac/._.DS_Store<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-09 09:10: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=e656ce0949b0e8cb8bebc22c820b279b9c2eefa0">e656ce0949b0e8cb8bebc22c820b279b9c2eefa0</a>
-<blockquote>
-<p>
- Update news and history for 9.08 release.<br>
-<br>
-gs/doc/History9.htm<br>
-gs/doc/News.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-08 14:53: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=80d7e88123fe9df85cdaeb345c133e3043ddda15">80d7e88123fe9df85cdaeb345c133e3043ddda15</a>
-<blockquote>
-<p>
- Update version and product strings for release candidate.<br>
-<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-gs/psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-31 07:45: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=b836761d02ca5829e9ff3f5a64437c3bf29b10db">b836761d02ca5829e9ff3f5a64437c3bf29b10db</a>
-<blockquote>
-<p>
- Change product string for release candidate.<br>
-<br>
- No unexpected cluster differences.<br>
-<br>
-gs/base/gscdef.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-20 10:21: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=ba1dedf24849295e107df180a291eba99bb33531">ba1dedf24849295e107df180a291eba99bb33531</a>
-<blockquote>
-<p>
- Ensure we don't overflow the filename buffer.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gp_unifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-20 10:23: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=36088d57f45958b3647b21f5ee3908377f113682">36088d57f45958b3647b21f5ee3908377f113682</a>
-<blockquote>
-<p>
- Make the Windows implementation of filenameforall match the Unix version<br>
-<br>
- The Unix version of filenameforall starts in the current working directory<br>
- when no directory is specified.<br>
-<br>
- When the pattern length exceeds the available string we should return a<br>
- rangecheck error, not an empty string.<br>
-<br>
- When the filename exceeds the available string we should return a<br>
- rangecheck error, not a truncated string.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gp_ntfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-19 15:06: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=167ca10abb0a90c4a28a381223afd6fb80347282">167ca10abb0a90c4a28a381223afd6fb80347282</a>
-<blockquote>
-<p>
- Allow use of '\\' for filenameforall and friends on Windows<br>
-<br>
- The commit to allow recursive directory enumeration f13bfba removed the<br>
- code which translated '\\' into '\', which could lead to incorrect filenames<br>
- being returned.<br>
-<br>
- This fix restores that functionality, but we still think everyone would be<br>
- better advised to use the PostScript '/' separator instead, which works as<br>
- well as '\' does.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gp_ntfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-08-08 14:53: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=80d7e88123fe9df85cdaeb345c133e3043ddda15">80d7e88123fe9df85cdaeb345c133e3043ddda15</a>
-<blockquote>
-<p>
- Update version and product strings for release candidate.<br>
-<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-gs/psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-31 07:45: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=b836761d02ca5829e9ff3f5a64437c3bf29b10db">b836761d02ca5829e9ff3f5a64437c3bf29b10db</a>
-<blockquote>
-<p>
- Change product string for release candidate.<br>
-<br>
- No unexpected cluster differences.<br>
-<br>
-gs/base/gscdef.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-31 07:38: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=5f71fefc4425c86e682a58c6f692f99978fafdb8">5f71fefc4425c86e682a58c6f692f99978fafdb8</a>
-<blockquote>
-<p>
- Remove reference to cups/gstopxl from configure.ac<br>
-<br>
- No cluster differences<br>
-<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-30 17:53:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2db3d0bc1d7bc9e223ac0bcf79c28c234eb906cd">2db3d0bc1d7bc9e223ac0bcf79c28c234eb906cd</a>
-<blockquote>
-<p>
- Tidy some MSVC build issues:<br>
-<br>
- Remove spurious explicit &quot;/DDEBUG&quot; directive when linking genarch.exe.<br>
-<br>
- Set debug options for &quot;aux tools&quot; when doing a debug build.<br>
-<br>
- Fix MSVC &quot;clean&quot; target to handle &quot;aux&quot; directory. We weren't deleting all<br>
- the files.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/msvccmd.mak<br>
-gs/base/msvclib.mak<br>
-gs/base/msvctail.mak<br>
-gs/base/winlib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-30 20:40:22 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c22d3214dff6fedd7b8aaba092dd52eb3b415fd">1c22d3214dff6fedd7b8aaba092dd52eb3b415fd</a>
-<blockquote>
-<p>
- Merge branch 'master' of ghostscript.com:/home/git/ghostpdl<br>
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-30 11:48:07 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=216b2692178e1113ab7252bf700cd980f5939a89">216b2692178e1113ab7252bf700cd980f5939a89</a>
-<blockquote>
-<p>
- Fix 694434, fix incorrect parsing of corrupt file.<br>
-<br>
- Invalid PJL was not properly ignored upon parsing.<br>
-<br>
-pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-30 20:29:01 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9304a21699a6c17579fae32f44f5c92a37c13e2d">9304a21699a6c17579fae32f44f5c92a37c13e2d</a>
-<blockquote>
-<p>
- Moved CUPS filters gstoraster and gstopxl to cups-filters<br>
-<br>
- As Ghostscript's CUPS filters gstoraster and gstopxl need changes to<br>
- allow PPD-less printing on IPP printers and these changes introduce<br>
- a new dependency on the libcupsfilters library of the cups-filters<br>
- project, we have moved these filters to cups-filters now.<br>
-<br>
- In addition, the pdftoraster filter for Poppler-based conversion<br>
- of PDF input to CUPS Raster is also not part of Poppler but part<br>
- of cups-filters. So we get a more symmetric distribution.<br>
-<br>
- Also maintenance of the filters will get easier this way, especially<br>
- duplicate code can move into libcupsfilters.<br>
-<br>
- cups-filters is a free software package hosted by OpenPrinting and it<br>
- contains all CUPS filters needed by CUPS under Linux and additional<br>
- utilities for CUPS. The filters are not part of the CUPS project at<br>
- Apple any more since CUPS 1.6.x.<br>
-<br>
- See<br>
- http://www.linuxfoundation.org/collaborate/workgroups/openprinting/cups-filters<br>
-<br>
-gs/Makefile.in<br>
-gs/configure.ac<br>
-gs/cups/colord.c<br>
-gs/cups/colord.h<br>
-gs/cups/cups.mak<br>
-gs/cups/gstopxl.in<br>
-gs/cups/gstoraster.c<br>
-gs/cups/gstoraster.convs<br>
-gs/cups/pxlcolor.ppd<br>
-gs/cups/pxlmono.ppd<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-30 10:05: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=91d104f9800b8e8e655a5cc1895b626ad57e40e5">91d104f9800b8e8e655a5cc1895b626ad57e40e5</a>
-<blockquote>
-<p>
- Remove debug statement.....<br>
-<br>
- .....left in by mistake.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-29 23:56:56 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e736e0a6730ee7e047bfd1ad701055eec6dffe85">e736e0a6730ee7e047bfd1ad701055eec6dffe85</a>
-<blockquote>
-<p>
- Fix for Bug 694439. We were not checking the code when we had invalid proc<br>
-<br>
- During the creation of a DeviceN colorspace we were not following up with<br>
- an error condition.<br>
-<br>
-gs/psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-29 13:34:17 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5e303dc64dbe55a5ce42e766e5d6a9753a9d387d">5e303dc64dbe55a5ce42e766e5d6a9753a9d387d</a>
-<blockquote>
-<p>
- Fix Windows sscanf %p incompatibility with Trio sprintf.<br>
-<br>
- Windows is internally consistent, but writes %p as 8 or 16 hex chars<br>
- and it's sscanf expects that format. Trio follows the linux style of<br>
- %p which has a leading &quot;0x&quot; followed by the characters. Reading an<br>
- address from a string is required for memfile_fopen and memfile_unlink<br>
- which are changed to use gs_sscanf which is added to gssprintf.*<br>
-<br>
-gs/base/gssprintf.c<br>
-gs/base/gssprintf.h<br>
-gs/base/gxclmem.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-29 13:28:09 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=51309bce92631066e36f117a2e012e05877d6b76">51309bce92631066e36f117a2e012e05877d6b76</a>
-<blockquote>
-<p>
- Remove unused local declaration of a dev_spec_op.<br>
-<br>
-gs/devices/gdevplib.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-17 14:29: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=ebc7505be6340baa73b9c281ef6c593305be3aac">ebc7505be6340baa73b9c281ef6c593305be3aac</a>
-<blockquote>
-<p>
- Changes to allow building gs for WinRT/ARM<br>
-<br>
- The contents of the windows-arm-msvc.h file may need modified.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/arch/windows-arm-msvc.h<br>
-gs/base/lib.mak<br>
-gs/base/msvccmd.mak<br>
-gs/base/msvctail.mak<br>
-gs/base/winlib.mak<br>
-gs/base/winplat.mak<br>
-gs/base/winrtsup.cpp<br>
-gs/ghostscript_rt.vcxproj<br>
-gs/openjpeg/libopenjpeg/opj_includes.h<br>
-gs/psi/gsdllARM32metro.def<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-25 18:44:48 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eddf4893e0e31b1801298eca37d68cd308408283">eddf4893e0e31b1801298eca37d68cd308408283</a>
-<blockquote>
-<p>
- Push optimisations back into lcms2.<br>
-<br>
- They don't work as well as a plugin factory. I am discussing why this<br>
- is the case with Marti.<br>
-<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/lcms2.mak<br>
-gs/base/lib.mak<br>
-gs/ghostscript.vcproj<br>
-gs/lcms2/include/lcms2_extras.h<br>
-gs/lcms2/src/cmsxform.c<br>
-gs/lcms2/src/extra_xforms.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-25 18:30: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=2c2bae08a0a4ec697e95f1732db1246a9fd3401a">2c2bae08a0a4ec697e95f1732db1246a9fd3401a</a>
-<blockquote>
-<p>
- Enable our optimisations for lcms2 as a transform factory.<br>
-<br>
- Not all enabled as there seem to be some problems. Talking to<br>
- Marti about this now.<br>
-<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/lib.mak<br>
-gs/lcms2/src/extra_xform.h<br>
-gs/lcms2/src/extra_xforms.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-25 11:27: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=6ddaa1b971f4d6f96bd57d82484399df82035d9a">6ddaa1b971f4d6f96bd57d82484399df82035d9a</a>
-<blockquote>
-<p>
- pdfwrite - new colour code<br>
-<br>
- We were not using the converted colours for certain spaces, because we were<br>
- modifying the 'paint' values, instead of the drawing colour values.<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-18 15:03:56 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1e63d6e5776c700bf01cb5c1038e8f0b57d29ca">b1e63d6e5776c700bf01cb5c1038e8f0b57d29ca</a>
-<blockquote>
-<p>
- Import LCMS 2.5<br>
-<br>
- Move our optimisations out into an 'extras' plugin, disabled for now.<br>
-<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/lcms2.mak<br>
-gs/ghostscript.vcproj<br>
-gs/lcms2/AUTHORS<br>
-gs/lcms2/ChangeLog<br>
-gs/lcms2/Makefile.am<br>
-gs/lcms2/Makefile.in<br>
-gs/lcms2/NEWS<br>
-gs/lcms2/Projects/.gitignore<br>
-gs/lcms2/Projects/VC2010/jpegicc/jpegicc.vcxproj<br>
-gs/lcms2/Projects/VC2010/lcms2.rc<br>
-gs/lcms2/Projects/VC2010/lcms2.sln<br>
-gs/lcms2/Projects/VC2010/lcms2_DLL/lcms2_DLL.vcxproj<br>
-gs/lcms2/Projects/VC2010/lcms2_static/lcms2_static.vcxproj<br>
-gs/lcms2/Projects/VC2010/linkicc/linkicc.vcxproj<br>
-gs/lcms2/Projects/VC2010/psicc/psicc.vcxproj<br>
-gs/lcms2/Projects/VC2010/testbed/testbed.vcxproj<br>
-gs/lcms2/Projects/VC2010/tiffdiff/tiffdiff.vcxproj<br>
-gs/lcms2/Projects/VC2010/tifficc/tifficc.vcxproj<br>
-gs/lcms2/Projects/VC2010/transicc/transicc.vcxproj<br>
-gs/lcms2/aclocal.m4<br>
-gs/lcms2/configure<br>
-gs/lcms2/configure.ac<br>
-gs/lcms2/doc/LittleCMS2.4 API.pdf<br>
-gs/lcms2/doc/LittleCMS2.4 Plugin API.pdf<br>
-gs/lcms2/doc/LittleCMS2.4 tutorial.pdf<br>
-gs/lcms2/doc/LittleCMS2.5 API.pdf<br>
-gs/lcms2/doc/LittleCMS2.5 Plugin API.pdf<br>
-gs/lcms2/doc/LittleCMS2.5 tutorial.pdf<br>
-gs/lcms2/include/Makefile.in<br>
-gs/lcms2/include/lcms2.h<br>
-gs/lcms2/include/lcms2_extras.h<br>
-gs/lcms2/src/Makefile.in<br>
-gs/lcms2/src/cmscam02.c<br>
-gs/lcms2/src/cmscgats.c<br>
-gs/lcms2/src/cmscnvrt.c<br>
-gs/lcms2/src/cmserr.c<br>
-gs/lcms2/src/cmsgamma.c<br>
-gs/lcms2/src/cmsgmt.c<br>
-gs/lcms2/src/cmsintrp.c<br>
-gs/lcms2/src/cmsio0.c<br>
-gs/lcms2/src/cmsio1.c<br>
-gs/lcms2/src/cmslut.c<br>
-gs/lcms2/src/cmsmd5.c<br>
-gs/lcms2/src/cmsmtrx.c<br>
-gs/lcms2/src/cmsnamed.c<br>
-gs/lcms2/src/cmsopt.c<br>
-gs/lcms2/src/cmspack.c<br>
-gs/lcms2/src/cmspcs.c<br>
-gs/lcms2/src/cmsplugin.c<br>
-gs/lcms2/src/cmsps2.c<br>
-gs/lcms2/src/cmssamp.c<br>
-gs/lcms2/src/cmssm.c<br>
-gs/lcms2/src/cmstypes.c<br>
-gs/lcms2/src/cmsvirt.c<br>
-gs/lcms2/src/cmswtpnt.c<br>
-gs/lcms2/src/cmsxform.c<br>
-gs/lcms2/src/cmsxform.h<br>
-gs/lcms2/src/cmsxform_extras.c<br>
-gs/lcms2/src/extra_xform.h<br>
-gs/lcms2/src/extra_xforms.c<br>
-gs/lcms2/src/lcms2.def<br>
-gs/lcms2/src/lcms2_internal.h<br>
-gs/lcms2/testbed/Makefile.in<br>
-gs/lcms2/testbed/testcms2.c<br>
-gs/lcms2/utils/common/vprf.c<br>
-gs/lcms2/utils/jpgicc/Makefile.in<br>
-gs/lcms2/utils/jpgicc/jpgicc.c<br>
-gs/lcms2/utils/linkicc/Makefile.in<br>
-gs/lcms2/utils/linkicc/linkicc.c<br>
-gs/lcms2/utils/psicc/Makefile.in<br>
-gs/lcms2/utils/psicc/psicc.c<br>
-gs/lcms2/utils/tificc/Makefile.in<br>
-gs/lcms2/utils/tificc/tificc.c<br>
-gs/lcms2/utils/transicc/Makefile.in<br>
-gs/lcms2/utils/transicc/transicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-24 13:35: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=25a2563e775d849c17885305a4e459a328c2761b">25a2563e775d849c17885305a4e459a328c2761b</a>
-<blockquote>
-<p>
- pdfwrite - new colour code, handle 'RGB' same as sRGB for allowed spaces<br>
-<br>
- We were trying to write Shading dictionaries with invalid colour spaces,<br>
- this way we degenerate to rectangles which is ugly but works.<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-23 09:45:02 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a8384d57fad56058d494616ba196401542a540bc">a8384d57fad56058d494616ba196401542a540bc</a>
-<blockquote>
-<p>
- Fix bug 694423. Segfault in clist image writing at some resolutions.<br>
-<br>
- There was an incorrect check for past the end of the page (obo).<br>
-<br>
-gs/base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-23 14:02: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=af38eee8f23f51f74e67cc52d2b72e2dd365bace">af38eee8f23f51f74e67cc52d2b72e2dd365bace</a>
-<blockquote>
-<p>
- pdfwrite - new colour code<br>
-<br>
- Concretize_color doesn't work the way I thought it did. Instead of returning<br>
- components in the original base space, it returns components for the current<br>
- ProcessColorModel, this has resulted in the removal of several steps.<br>
-<br>
- Modified the code which writes converted base spaces for Separation and<br>
- DeviceN spaces, so that the space can be used for images, as well as for<br>
- linework.<br>
-<br>
- The code is now no longer crashes when the ColorConversionStrategy is<br>
- CMYK.<br>
-<br>
- There are still some oddities with CIE/RGB to CMYK conversion, there are<br>
- some problems with CMYK output with type 4 images. Still need to test<br>
- Gray and RGB strategies, and redo LeaveColorUnchanged and UseDeviceIndependentCOlor<br>
- with the latest changes.<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpdfg.h<br>
-gs/devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-22 16:38:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c0d9447b67dcef12d9d321a128985ee77e46fabd">c0d9447b67dcef12d9d321a128985ee77e46fabd</a>
-<blockquote>
-<p>
- pdfwrite - new colour conversion code, fix Indexed Separation/DeviceN<br>
-<br>
- The previous code for converting the base space of a Separation or DeviceN<br>
- space didn't cater for the possibility of a /Indexed space. This code now<br>
- does.<br>
-<br>
- In addition we do a better job of identifying when a base space needs<br>
- converted, there was similar problem here leading to us converting (eg)<br>
- CMYK to CMYK.<br>
-<br>
- There are some oddities with RGB-&gt;CMYK conversion that I need to discuss<br>
- with Michael.<br>
-<br>
-gs/devices/vector/gdevpdfc.c<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpdfg.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-19 13:22:55 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b1a5d0dce3a375ccd4be010d50b3d91929bb982">9b1a5d0dce3a375ccd4be010d50b3d91929bb982</a>
-<blockquote>
-<p>
- Fixed a couple of errors in previous commit.<br>
-<br>
-gs/base/gscie.c<br>
-gs/base/gxhintn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-19 13:10:48 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=37aca23d758c3b5cb53da10aaeccd623f625e01a">37aca23d758c3b5cb53da10aaeccd623f625e01a</a>
-<blockquote>
-<p>
- Remove C++ style comments.<br>
-<br>
- These cause issues with some versions of the AIX C compiler.<br>
-<br>
-gs/base/gscdevn.c<br>
-gs/base/gscie.c<br>
-gs/base/gxhintn.c<br>
-gs/base/sjbig2.c<br>
-gs/base/sjpx_openjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-18 09:10:54 -0400
-</strong>
-<br>James Cloos &lt;cloos@jhcloos.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7f764e594f2f23bac77748693d1c8e886af5b103">7f764e594f2f23bac77748693d1c8e886af5b103</a>
-<blockquote>
-<p>
- Remove MaxBufferedTotal, MaxBufferedArea and MaxBufferedCount<br>
-<br>
- If MaxBitmap is set but MaxBufferedTotal and/or MaxBufferedArea are too small<br>
- some documents will fail to display.<br>
-<br>
- X servers and client boxen have much more ram than they did 10–20 years ago;<br>
- limiting the size of client-side caches beyond what MaxBitmap supports has<br>
- little remaining value.<br>
-<br>
- So deprecate and remove those limits.<br>
-<br>
- Signed-off-by: Henry Stiles henry.stiles@artifex.com<br>
-<br>
-gs/devices/gdevx.c<br>
-gs/devices/gdevx.h<br>
-gs/devices/gdevxini.c<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-17 21:43:23 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=11dca09b381cac3a85625d7a408ccdf7458b1f9e">11dca09b381cac3a85625d7a408ccdf7458b1f9e</a>
-<blockquote>
-<p>
- Bug 694421: use correct .notdef in CIDType 2 fonts<br>
-<br>
- When cmap table is too short for the CID we're looking for, use the CharStrings<br>
- dictionary to get the GID of the .notdef glyph instead of throwing an error.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-15 23:17:44 +0000
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=94196ed84e5b8d264522b378972472ad4b54ed90">94196ed84e5b8d264522b378972472ad4b54ed90</a>
-<blockquote>
-<p>
- Silent a &quot;Value not read&quot; compiler warning.<br>
-<br>
- It is true that the value is no longer used after this point,<br>
- therefore no need to update further. Though it might be<br>
- confusing if its value for its intended meaning is used<br>
- again in the future, say, to detect broken input files.<br>
- Comment it out for now.<br>
-<br>
-pxl/pxvendor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-15 14:37:10 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=777307f9e2aa4c2d74e96dd9c3f1630677c680a6">777307f9e2aa4c2d74e96dd9c3f1630677c680a6</a>
-<blockquote>
-<p>
- Fix 694416, the default DCT color transform was not set up correctly.<br>
-<br>
- The fix was derived directly from MuPDF and is consistent with the<br>
- documentation.<br>
-<br>
-gs/base/sdctd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-13 12:27: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=9834a3b011070a5565b5dcc536f6c2eace10569c">9834a3b011070a5565b5dcc536f6c2eace10569c</a>
-<blockquote>
-<p>
- Changes to allow mingw DLL build<br>
-<br>
- Building the mingw DLL still uses the &quot;so&quot; target.<br>
-<br>
- Also, tidy up and rationalise the way the &quot;so&quot; target works on OS X. It no<br>
- longer relies on a special subtarget.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Makefile.in<br>
-gs/base/unix-dll.mak<br>
-gs/base/unixhead.mak<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-14 23:30:50 +0000
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=37b9962406c99564f6ac16e37540a45cfae5d557">37b9962406c99564f6ac16e37540a45cfae5d557</a>
-<blockquote>
-<p>
- Bug 693661 - implement HP CLJ 3500/3550/3600 emulation<br>
-<br>
- The actual subject of the bug report is<br>
- &quot;pcl6 interpreter exited with error code -995&quot;.<br>
-<br>
- This patch adds two new files, pxl/pxvendor.{c,h} which implement<br>
- HP CLJ 3500/3550/3600 emulation, plus small associated changes<br>
- in existing files.<br>
-<br>
- Included and somewhat less related are:<br>
-<br>
- - a small change of pl/plmain.c to not repeat repeated error messages,<br>
- - switching some 12-year-old debug code from '|' (experimental)<br>
- to '|' (interpreter), to make genuine exp code devel easier.<br>
- - a minor bug fix to px_attribute_names in<br>
- pxl/pxptable.c reported elsewhere which affects debug messages,<br>
- - some stubs in pxl/pxsessio.c and tools/pxldis.py<br>
- for HP 1011/1012/1015 emulation.<br>
-<br>
- Where/what those are should be fairly obvious.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevpxat.h<br>
-gs/base/gdevpxen.h<br>
-pl/plmain.c<br>
-pxl/pxl.mak<br>
-pxl/pxptable.c<br>
-pxl/pxsessio.c<br>
-pxl/pxstate.h<br>
-pxl/pxvendor.c<br>
-pxl/pxvendor.h<br>
-tools/pxldis.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-12 12:56:50 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f3fdc7a37f529f0562a4290d3fce4cced2cd4820">f3fdc7a37f529f0562a4290d3fce4cced2cd4820</a>
-<blockquote>
-<p>
- PDF interpreter - set colour nad space at the time the relevant operators execute<br>
-<br>
- In the past we have only set the colour space and colour values for stroke<br>
- and fill when we actually perform a stroke or fill operation. At the time<br>
- the space and colour was set we would simply store the data.<br>
-<br>
- This can cause problems with a sequence like this:<br>
-<br>
- /CS0 cs 0.2 0.1 0 0 scn<br>
- q<br>
- ....<br>
- f<br>
- Q<br>
-<br>
- q<br>
- ....<br>
- f<br>
- Q<br>
-<br>
- Each time we set the colour and space we then restore back to a point<br>
- before that space was set. On the next fill we need to set the space again.<br>
- If the colour space is an expensive one to set (eg ICCBased) then we waste<br>
- a lot of time.<br>
-<br>
- The 'simple' solution is to set the colour space at the time it is set in<br>
- the PDF file. However, this also meant setting the colour values at the<br>
- time they are set (or we could get space and colour unsynchronised). This<br>
- further led to the discovery that the transparency code can set colours in<br>
- a different space to the saved space (eg for an SMask). So it was necessary<br>
- to have an additional set of routines, one which simply stores the state<br>
- and one which stores and sets it to be the current space/colour.<br>
-<br>
- The time taken for the specimen file is reduced from approximately 4.5<br>
- minutes to around 3.5 seconds. In addition the file CATX1101.pdf shows a<br>
- progression with pdfwrite (gray drop shadow was missing). Because pdfwrite<br>
- no longer swaps colour spaces so frequently with text, text is more often<br>
- emitted as a single operation, which leads to smaller files (15% smaller<br>
- in one case) but does show some very minor (1 pixel) positioning changes<br>
- in text.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-11 22:49:05 +0200
-</strong>
-<br>zeniko &lt;zeniko@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c15166f8be1e1081e5b2beecf46b25f1cbd14d5f">c15166f8be1e1081e5b2beecf46b25f1cbd14d5f</a>
-<blockquote>
-<p>
- Bug 694125: prevent heap underflow<br>
-<br>
- jbig2_decode_mmr_line checks the arguments to jbig2_set_bits since the<br>
- fixes to issue 693050, however these checks still allow for the starting<br>
- index to be negative which results in a write underflow; fixes<br>
- 2860.pdf.asan.9.2069<br>
-<br>
-gs/jbig2dec/jbig2_mmr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-11 08:39: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=076ffc56da93051fb14930394b2026e1821f3cb7">076ffc56da93051fb14930394b2026e1821f3cb7</a>
-<blockquote>
-<p>
- Bugs 693828: pull in new URW+ GPL fonts.<br>
-<br>
- Also 693827, 688557, 691909, 690896 and 687297.<br>
-<br>
- Many differences: most files that use the standard font set change. Changes of<br>
- note are that in Nimbus L Sans Italic several of the &quot;symbol&quot; glyphs (like<br>
- /plus, /plusminus etc) used to be italicised and are now not. This actually<br>
- matches the Adobe equivalent font.<br>
-<br>
- Also there are some cases of the /M glyph being narrower than previously, again<br>
- this is correct wrt to the Adobe equivalent.<br>
-<br>
-gs/Resource/Font/CenturySchL-Bold<br>
-gs/Resource/Font/CenturySchL-BoldItal<br>
-gs/Resource/Font/CenturySchL-Ital<br>
-gs/Resource/Font/CenturySchL-Roma<br>
-gs/Resource/Font/Dingbats<br>
-gs/Resource/Font/NimbusMonL-Bold<br>
-gs/Resource/Font/NimbusMonL-BoldObli<br>
-gs/Resource/Font/NimbusMonL-Regu<br>
-gs/Resource/Font/NimbusMonL-ReguObli<br>
-gs/Resource/Font/NimbusRomNo9L-Medi<br>
-gs/Resource/Font/NimbusRomNo9L-MediItal<br>
-gs/Resource/Font/NimbusRomNo9L-Regu<br>
-gs/Resource/Font/NimbusRomNo9L-ReguItal<br>
-gs/Resource/Font/NimbusSanL-Bold<br>
-gs/Resource/Font/NimbusSanL-BoldCond<br>
-gs/Resource/Font/NimbusSanL-BoldCondItal<br>
-gs/Resource/Font/NimbusSanL-BoldItal<br>
-gs/Resource/Font/NimbusSanL-Regu<br>
-gs/Resource/Font/NimbusSanL-ReguCond<br>
-gs/Resource/Font/NimbusSanL-ReguCondItal<br>
-gs/Resource/Font/NimbusSanL-ReguItal<br>
-gs/Resource/Font/StandardSymL<br>
-gs/Resource/Font/URWBookmanL-DemiBold<br>
-gs/Resource/Font/URWBookmanL-DemiBoldItal<br>
-gs/Resource/Font/URWBookmanL-Ligh<br>
-gs/Resource/Font/URWBookmanL-LighItal<br>
-gs/Resource/Font/URWChanceryL-MediItal<br>
-gs/Resource/Font/URWGothicL-Book<br>
-gs/Resource/Font/URWGothicL-BookObli<br>
-gs/Resource/Font/URWGothicL-Demi<br>
-gs/Resource/Font/URWGothicL-DemiObli<br>
-gs/Resource/Font/URWPalladioL-Bold<br>
-gs/Resource/Font/URWPalladioL-BoldItal<br>
-gs/Resource/Font/URWPalladioL-Ital<br>
-gs/Resource/Font/URWPalladioL-Roma<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-11 08:33:35 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=283427799129175b4b6338e718aca0c26d917a54">283427799129175b4b6338e718aca0c26d917a54</a>
-<blockquote>
-<p>
- Make W/W* &quot;context&quot; survive text operations.<br>
-<br>
- If we have a text operation between a W/W* operator and the path operation that<br>
- ends the W/W* context, we end up entering an infinite loop because the W/W*<br>
- context prevents us from writing the changes to the graphics state required<br>
- to render the text.<br>
-<br>
- To handle this, we now end the W/W* context, and store the dictionary<br>
- temporarily while we complete the text operation, then restore W/W* context<br>
- after.<br>
-<br>
- It is not clear how this is supposed to interact with the clipping text<br>
- rendering modes, but on the basis of solving an infinite loop, I'm committing<br>
- this, and will address issues if they arise.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-09 10:58: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=0903afb23777cfee2cb2a5015990c174e6a54742">0903afb23777cfee2cb2a5015990c174e6a54742</a>
-<blockquote>
-<p>
- pdfwrite - Fix image writing code when converting colour spaces (old CMS code)<br>
-<br>
- Bug #694401 &quot;pdfwrite produces incorrect pdf file&quot;<br>
-<br>
- The command line for this bug specifies -dPDFSETTINGS=/ebook. This sets a<br>
- number of parameters, specifically it sets ColorConversionStrategy to sRGB.<br>
- The input file contains an image in DeviceGray with 1 bit per component,<br>
- the specified colour conversion strategy means we convert this to RGB.<br>
-<br>
- The original image was drawn with a resolution of 200 dpi, which does not<br>
- trigger monochrome downsampling in this setup (300 dpi). However when<br>
- converted into a colour image it does trigger downsampling as the threshold<br>
- for colour images is 72 dpi in this configuration.<br>
-<br>
- The combination of colour conversion and image downsampling seriously<br>
- confused the horrific code in pdfwrite, and led to use writing out the wrong<br>
- amount of data for the image as well as corrupting the image data as it<br>
- passed through the filters.<br>
-<br>
- This patch sorts this out by setting various parameters, and copying/restoring<br>
- them as required to initialise the various filters correctly.<br>
-<br>
- For some reason this shows a difference with test file Bug691425.pdf but the<br>
- visual appeaance is the same.<br>
-<br>
-gs/devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-09 07:54: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=a9f3d46240cda455d8f42feee2350f40fa26e3e7">a9f3d46240cda455d8f42feee2350f40fa26e3e7</a>
-<blockquote>
-<p>
- Fix a benign compiler warning<br>
-<br>
- Check a return code and take appropriate action, this was a pre-existing<br>
- fault flagged up when the code changed with the prior commit.<br>
-<br>
-gs/devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-08 08:09:12 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8accdfa6986e7247103e80b7c12dd6b39ddf8a4c">8accdfa6986e7247103e80b7c12dd6b39ddf8a4c</a>
-<blockquote>
-<p>
- Remove code supporting obsolete color spaces.<br>
-<br>
-pcl/pccid.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-06 21:05:06 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=392041413cb1d11dff0af986b41f871c19287f56">392041413cb1d11dff0af986b41f871c19287f56</a>
-<blockquote>
-<p>
- Remove Java based PCL viewer and its supporting code.<br>
-<br>
-pcl/pcpage.c<br>
-pl/pjparse.c<br>
-pl/plmain.c<br>
-pl/plmain.h<br>
-tools/viewer/Gpickle.java<br>
-tools/viewer/GpickleObserver.java<br>
-tools/viewer/GpickleThread.java<br>
-tools/viewer/Gview.java<br>
-tools/viewer/JavaDoc/allclasses-frame.html<br>
-tools/viewer/JavaDoc/deprecated-list.html<br>
-tools/viewer/JavaDoc/gpickle.html<br>
-tools/viewer/JavaDoc/gpickleobserver.html<br>
-tools/viewer/JavaDoc/gpicklethread.html<br>
-tools/viewer/JavaDoc/gview.html<br>
-tools/viewer/JavaDoc/help-doc.html<br>
-tools/viewer/JavaDoc/index-all.html<br>
-tools/viewer/JavaDoc/index.html<br>
-tools/viewer/JavaDoc/nav.html<br>
-tools/viewer/JavaDoc/overview-tree.html<br>
-tools/viewer/JavaDoc/package-frame.html<br>
-tools/viewer/JavaDoc/package-list<br>
-tools/viewer/JavaDoc/package-summary.html<br>
-tools/viewer/JavaDoc/package-tree.html<br>
-tools/viewer/JavaDoc/packages.html<br>
-tools/viewer/JavaDoc/serialized-form.html<br>
-tools/viewer/JavaDoc/stylesheet.css<br>
-tools/viewer/Nav.java<br>
-tools/viewer/README<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-06 21:04:35 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2035b67856e69b75c5466d44fd287f1d0cd721b3">2035b67856e69b75c5466d44fd287f1d0cd721b3</a>
-<blockquote>
-<p>
- Debug statement to indicate implicit raster exit.<br>
-<br>
-pcl/rtgmode.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-05 09:07: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=34e2ae40bff4d288da83dcd739e50287bf7c3c2e">34e2ae40bff4d288da83dcd739e50287bf7c3c2e</a>
-<blockquote>
-<p>
- pdfwrite - implement idioms for PScript 5 artificial bld text<br>
-<br>
- Bug #688007 &quot;cjk bold fonts printed many times&quot;<br>
-<br>
- The artifical emboldening of fonts in the pscript 5 DLL works by drawing<br>
- the same text 4 times in slightly different positions. THis causes<br>
- pdfwrite to emit 4 sets of text.<br>
-<br>
- Here we implement idiomns for the range of 'show' operations valid in<br>
- Pscript5, and if the device supports text rendering modes we draw the text<br>
- only once in text rednering mode 2 (fill and then stroke). The Pscript5<br>
- code uses 'sBdx' to determine the offset of the text, but this is actually<br>
- a constant derived by dividing the target print resolution by 300. We use<br>
- a fixed figure derived heuristically instead.<br>
-<br>
- During the work it became apparent that the existing code in pdfwrite to<br>
- handle stroked text didn't work properly as it could emit stroke<br>
- parameters during the course of a text object, which Acrobat ignores. SO<br>
- the code has been altered to exit the text object whenever text is<br>
- stroked. This is inefficient as we might not need to emit any stroke<br>
- parameters, but it solves the problem, and text rendering modes are not<br>
- widely used.<br>
-<br>
- This shows a small progression in pdf-t3-simple.pdf and some small<br>
- differences in other files.<br>
-<br>
-gs/Resource/IdiomSet/Pscript5Idiom<br>
-gs/devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-05 16:16:27 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=27332dab4d0b6ec7bab5cafef86a693c5d600dd7">27332dab4d0b6ec7bab5cafef86a693c5d600dd7</a>
-<blockquote>
-<p>
- Partially address 694378 - mispositiosed graphics.<br>
-<br>
- Implement the GL Frame Advance (FR) technical extension with a simple<br>
- page feed.<br>
-<br>
-pcl/pgconfig.c<br>
-pcl/pgmand.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-02 13:03: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=a8d0fa19f927d045b81ec0380ea7448de38176d9">a8d0fa19f927d045b81ec0380ea7448de38176d9</a>
-<blockquote>
-<p>
- Disable OpenJPEG SSE on Windows again.<br>
-<br>
- Shelly reports that enabling SSE in Windows causes crashes in most of the<br>
- JPX test jobs. At least for the present, disable it.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-03 09:50: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=3123e3ad0299dbc1cefc77f342e5f23e7be28a71">3123e3ad0299dbc1cefc77f342e5f23e7be28a71</a>
-<blockquote>
-<p>
- Fix a minor compiler warning in the previous commit<br>
-<br>
-gs/devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-03 09:05: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=489253b834075391d7826bc81ef52ede34f8289f">489253b834075391d7826bc81ef52ede34f8289f</a>
-<blockquote>
-<p>
- pdfwrite - better identify rectangular clips, and emit as rectangles<br>
-<br>
- Bug #687931 &quot;GS produces large PDF files&quot;<br>
-<br>
- The file uses *many* rectangular clips to draw through, previously pdfwrite<br>
- mostly emitted these as a sequence of lines, because only a small class of<br>
- clip paths could be identified as rectangular.<br>
-<br>
- This commit levers the existing gx_path_is_rectangle to identify many more<br>
- rectangular clip paths, and emit them using the 're' operator instead, which<br>
- is more compact on output.<br>
-<br>
- The specimen file now produces 30% smaller PDF files.<br>
-<br>
- This does introduce some differences, in the main these are very small single<br>
- pixel or one pixel wide lines. In the case of the Quality Logic test suite, the<br>
- 'frame' for the tests is drawn through a clip, and one edge is now slightly<br>
- wider, since it better matches the width of the other edges this is a<br>
- progression. It affects a large number of QL tests.<br>
-<br>
-gs/base/gxcpath.c<br>
-gs/base/gxpath.h<br>
-gs/devices/vector/gdevpdfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-07-02 10:31: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=939e32ff3c8841507aed80435269457f3caac6f5">939e32ff3c8841507aed80435269457f3caac6f5</a>
-<blockquote>
-<p>
- More work on setpagedevice and global allocation mode<br>
-<br>
- The commit 073f7be1671e7fa2dbbc75984e593d2279bb05d7 solved one problem,<br>
- but introduced another. Specifically Ghostscript feiled to start when<br>
- -dSAFER was specified.<br>
-<br>
- The reasons are convoluted, the background is as follows:<br>
-<br>
- Adobe interpreters appear to always return a local VM writeable dictionary<br>
- from currentpagedevice (despite that fact that the spec clearly says its<br>
- read-only). WordPerfect files have, in the past at least, relied upon this<br>
- and tried to write to the dictionary.<br>
-<br>
- To solve this, our currentpagedevice copies child dictionaries to dictionaries<br>
- allocated in local VM (and writeable). This fails if we attempt to do a<br>
- setpagedevice while the VM allocation mode is local, because the parent<br>
- dictionary is in global VM, and we then attempt to put locally allocated<br>
- children in it.<br>
-<br>
- The earlier commit resolved this by forcing the VM allocation mode to local<br>
- during the course of setpagedevice, which meant that the dictionary returned<br>
- by currentpagedevice was allocated in local VM, so it was safe to put the<br>
- child dictionaries in it.<br>
-<br>
- But, if we run with -dSAFER, the in gs_init.ps we do an early call to<br>
- setpagedevice in order to set /.LockSafetyParams. We do this while the VM<br>
- allocation mode is global. Note that setpagedevice stores a pointer to the<br>
- returned dictionary in the graphics state. Now, when we run the Display<br>
- PostScript startup code, it insists that all objects in the 'savedinitialgstate'<br>
- must be in global VM. But we've saved the current page deice there, and it<br>
- was allocated in local VM, which leads to an error.<br>
-<br>
- So in order to satisfy the WP bug, we need to have the children allocated in<br>
- local VM. In order to call setpagedevice when the allocation mode is global<br>
- we need to create the page device dict in local VM. In order to satisfy the<br>
- DPS code, we need to allocate the page device dict in global VM.<br>
-<br>
- Oops.<br>
-<br>
- This commit attempts to work around this by setting the VM allocation mode<br>
- to local for the course of setpagedevice, but *not* when we are executing<br>
- the code for -dSAFER.<br>
-<br>
- This is a hacky solution, and I suspect prone to failure, but probably only<br>
- if we change the startup code, which we rarely do.<br>
-<br>
- No diffrences expected<br>
-<br>
-gs/Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-29 15:53:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=06d63d8edfd5d8eac76b96ea2e66f5cf165b6997">06d63d8edfd5d8eac76b96ea2e66f5cf165b6997</a>
-<blockquote>
-<p>
- Fix a typo in txtwrite, this may be related to bug #694389<br>
-<br>
-gs/devices/vector/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-29 09:38: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=f560b73066ee787678a31973bca411bedc6ca0f6">f560b73066ee787678a31973bca411bedc6ca0f6</a>
-<blockquote>
-<p>
- fix a minor compiler warning<br>
-<br>
-gs/psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-28 09:18:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=13105ccf9c02d29058ab0ff3f9bdb48387ec7b6e">13105ccf9c02d29058ab0ff3f9bdb48387ec7b6e</a>
-<blockquote>
-<p>
- Invalidate device refs on the operand stack when we change device<br>
-<br>
- Bug #690925 &quot;SEGV after &quot;gsave nulldevice currentdevice grestore setdevice&quot;<br>
-<br>
- currentdevice stores a reference containing a pointer to the current device<br>
- structure on the operand stack. If we close the device, then attempt to do<br>
- 'setdevice' using the stored pointer from the operand stack we can get a<br>
- seg fault if we have restored away the device, because the device structure<br>
- memory has been released.<br>
-<br>
- Altered nulldevice and setdevice so that when we change devices we scour<br>
- the operand stack looking for saved references to devices. If we find any<br>
- we NULL the pointer to the device. This allows us to check for a NULL device<br>
- pointer in setdevice and raise an error instead of crashing.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/psi/zdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-27 14:58:13 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d5d3b85af33c679927e908154482fab576922fc0">d5d3b85af33c679927e908154482fab576922fc0</a>
-<blockquote>
-<p>
- Fix bug #694355, incorrect rendering of raster image.<br>
-<br>
- This problem is very similar to bug #693111, and I don't think we have<br>
- a clear handle on how the interpreter should behave when locked out<br>
- commands are received in raster mode (with RTL). For this problem we<br>
- don't shut down graphics when receiving the render algorithm command,<br>
- the other bug involved a transparency command. A new bug will be<br>
- opened to review both of these bugs. Although, both fixes are<br>
- effective and safe, I'm afraid they don't address the underlying<br>
- issue.<br>
-<br>
-pcl/pcpalet.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-27 14:51:50 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b7cb6d314aab998d8b40e1ff782149aebbf06a2">7b7cb6d314aab998d8b40e1ff782149aebbf06a2</a>
-<blockquote>
-<p>
- Reassign devices owned by Alex.<br>
-<br>
-doc/who_owns_what.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-27 15:41:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1fc07e783d8758e4bfdc8b8ebe68a875b30568ae">1fc07e783d8758e4bfdc8b8ebe68a875b30568ae</a>
-<blockquote>
-<p>
- commit 9034712 used abs, which oddly caused many timeouts. Multiplying by<br>
- -1 instead seems to solve this.....<br>
-<br>
-gs/base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-27 15:39: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=9034712f22eff916280f4555d88237da99bcaeda">9034712f22eff916280f4555d88237da99bcaeda</a>
-<blockquote>
-<p>
- When clamping pattern BBox to page, make sure to scan in proper direction<br>
-<br>
- Bug #694385 &quot;endless loop in pattern&quot;<br>
-<br>
- The code for clamping the pattern BBox to the page starts left and below the<br>
- page, and then scans across and up detecting if any part of the pattern is<br>
- on the page.<br>
-<br>
- Unfortunately, this didn't account for negative xstep and ystep. Because<br>
- we are only scanning the area, the easiest solution is just to abs() the<br>
- values, so that we are sure to scan left-right and bottom-top.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-08 09:12:30 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c27113ab96a8010b59652bde975eec68865aebb5">c27113ab96a8010b59652bde975eec68865aebb5</a>
-<blockquote>
-<p>
- Change in behavior for overprint. Fixes bugs 694295 694296 and 694067<br>
-<br>
- With this change we now do simulated overprinting of cmyk AND spot colorants<br>
- for contone cmyk devices by default. If -dSimulateOverprint=false is specified we<br>
- will not simulate overprinting of any colors.<br>
-<br>
- Also, cmyk simulation of spot colors with separation devices is not handled.<br>
- i.e. if you specify -dSimulateOverprint=true -dMaxSpots=0 -sDEVICE=tiffsep1<br>
- you will see the spot colors blended in CMYK space if overprint has been<br>
- specified in the document.<br>
-<br>
- Note that not all overprint situations can be simulated accurately with this<br>
- approach. For example, if I have a spot color that resulted in a CMYK value<br>
- of 0 0 100 0 after the alternate tint transform and then I did an overprint with<br>
- a CMYK value of 0 0 1 0, the color should still be a bright yellow but will actually<br>
- be almost no color. The issue is that we can not distinguish this case from one<br>
- where we had first laid down a CMYK of 0 0 100 0 followed by the overprint of 0 0 1 0<br>
- which should be a light yellow. The documentation has been updated to point this out.<br>
-<br>
- I reviewed all the diffs that came up in the bmpcmp and reviewed the Ghent overprint<br>
- files.<br>
-<br>
-gs/base/gscdevn.c<br>
-gs/base/gscsepr.c<br>
-gs/base/gsdparam.c<br>
-gs/base/gsicc.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsovrc.c<br>
-gs/base/gsstate.c<br>
-gs/base/lib.mak<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-26 17:16: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=073f7be1671e7fa2dbbc75984e593d2279bb05d7">073f7be1671e7fa2dbbc75984e593d2279bb05d7</a>
-<blockquote>
-<p>
- Ensure all objects created for use during setpagdevice are in local VM<br>
-<br>
- Bug #687702 &quot;gs8.15 setpagedevice /invalidaccess&quot;<br>
-<br>
- The problem is caused by currentpagdevice returning a dictionary allocated<br>
- in the current (global) VM. We later create an OutputAttributes dictionary<br>
- which is in local VM, and store it in the dictionary returned. This fails<br>
- of course.<br>
-<br>
- Since these objects are only used internally to construct various intermediate<br>
- structures during the course of a setpagedevice, the easiest solution to this<br>
- is to force the VM allocation mode to local for the duration of setpagedevice.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/gs_setpd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-26 13:18: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=bcc1052afdec7b4da66c832c97bcba990a1863e0">bcc1052afdec7b4da66c832c97bcba990a1863e0</a>
-<blockquote>
-<p>
- Bug #686853 &quot;filenameforall enumerates incompatible with Adobe&quot;<br>
-<br>
- Fix the Unix/Linux file enumeration code to correctly recurse into<br>
- directories.<br>
-<br>
- This causes differences in many of the Quality Logic Postscript LL3 test suite<br>
- tests because it can now overflow the size of the &quot;scratch&quot; string used in the<br>
- tests and that results (correctly) in a rangecheck error from filenameforall.<br>
-<br>
- Obviously, that depends on from where in the directory hierarchy the executable<br>
- is being run, and the contents of the directory structure below that.<br>
-<br>
-gs/base/gp_unifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-24 15:20: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=f13bfba957c536630a241351df49c5007a0664d9">f13bfba957c536630a241351df49c5007a0664d9</a>
-<blockquote>
-<p>
- rework the NTFS file enumeration to rescurse into sub-directories<br>
-<br>
- Bug #686853 &quot;filenameforall enumerates incompatible with Adobe&quot;<br>
-<br>
- Existing code did not recurse into sub-directories whereas Adobe interpreters<br>
- do (but they do not list sub-directory names, just their contents).<br>
-<br>
- In addition the Linux and Windows code has long been incompatible, because<br>
- the Linux code *does* list the sub-directory names, even though it doesn't<br>
- recurse into them.<br>
-<br>
- With this patch the NTFS file system code now recurses and lists the<br>
- sub-directory contents in the same fashion as Adobe.<br>
-<br>
- The Linux file system code needs work. After discussion with Chris we have<br>
- decided not to proceed with the same work on VMS, OS/2 or DOS, as we don't<br>
- even have systems to test the code compilation, let alone its execution.<br>
-<br>
- All these Operating Systems are obselete, and nobody ahs complained about<br>
- the existing code in many years, so we don't expect to offer a bounty<br>
- for adding this. However, if anyone has access to an appropriate system and<br>
- wants to offer us a patch, we will probably adopt it.<br>
-<br>
- No differences expected, the cluster doesn't run NTFS.<br>
-<br>
-gs/base/gp_ntfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-26 13:17: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=16733f6f179bcb98c371915a738b01a4e1f26ac2">16733f6f179bcb98c371915a738b01a4e1f26ac2</a>
-<blockquote>
-<p>
- Add some Encodings listed in the PLRM<br>
-<br>
- Bug #688710 &quot;Fix the Encoding resource category&quot;<br>
-<br>
- As noted int he bug thread I so not consider it worthwhile to tackle some<br>
- of the propsed work described there. However the CE Encoding is missing,<br>
- as are also the ExpertEncoding and ExpertSubsetEncoding resources.<br>
-<br>
- This commit adds all three resources and the NotDefEncoding which is present<br>
- in Adobe Acrobat Distiller. We also revisit the patch (gs-cvs rev<br>
- 6834) originally committed against this bug, which prevented the Subversion<br>
- source control directory being enumerated as an Encoding resource. Since we<br>
- no longer use Subversion, and the current system doesn't rely on hidden<br>
- sub-directories, this is no longer required.<br>
-<br>
- No differences expected<br>
-<br>
-gs/Resource/Encoding/CEEncoding<br>
-gs/Resource/Encoding/ExpertEncoding<br>
-gs/Resource/Encoding/ExpertSubsetEncoding<br>
-gs/Resource/Encoding/NotDefEncoding<br>
-gs/Resource/Init/gs_fntem.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-25 09:05:10 +0100
-</strong>
-<br>Hin-Tak Leung &lt;hintak@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=341dfa13b8ad4afadf8b2a8a7302422755911b36">341dfa13b8ad4afadf8b2a8a7302422755911b36</a>
-<blockquote>
-<p>
- Bug 690692: more robust check for TTF/OTF files<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-25 08:55:08 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=200dc18647ae24995e28607f838d77affbfc7638">200dc18647ae24995e28607f838d77affbfc7638</a>
-<blockquote>
-<p>
- Set colors up correctly when rendering Type 3 glyph<br>
-<br>
- In the 'd1' operator, if the glyph metrics are clearly wrong, we fall back to<br>
- rendering the glyph uncached. The original code failed to do the required<br>
- color setup in this path through the code.<br>
-<br>
- The simplest solution, rather than repeat the same code, is to call the 'd0'<br>
- operator, after appropriate stack manipulations.<br>
-<br>
- Noticed in passing working on an issue from customer 532.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-20 13:24:01 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=10f6e526ec702fd8b74405d3e7461b428bdbdf31">10f6e526ec702fd8b74405d3e7461b428bdbdf31</a>
-<blockquote>
-<p>
- Fix wrong GrayDetection when images have MultipleDataSources true - cust 801.<br>
-<br>
- Since we already had a buffer, we unpack the samples from the planes into the<br>
- buffer using 'spread' to space them so they form a chunky pixel buffer for<br>
- row_has_color. Refactor the unpacking into the buffer out of row_has_color to<br>
- the caller where we have the planes array. Note that the buffer returned from<br>
- the 'unpack' proc may be the original data source so we save that for calling<br>
- row_has_color.<br>
-<br>
-gs/base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-21 07:43: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=8ff1b883db9e7d2cd8c940a5ea7f0e4bad78903d">8ff1b883db9e7d2cd8c940a5ea7f0e4bad78903d</a>
-<blockquote>
-<p>
- Move winrt platform build into &quot;base&quot;.<br>
-<br>
- One file required for the winrt platform was being built in psi/msvc.mak, this<br>
- moves it to winlib.mak with the rest of the platform.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/winlib.mak<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-19 19:10:21 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b405fdcb395f2b48226af7a55a714d4dd3d50a75">b405fdcb395f2b48226af7a55a714d4dd3d50a75</a>
-<blockquote>
-<p>
- Define GS_NO_UTF8 for mingw<br>
-<br>
- Noticed in passing, GS_NO_UTF8 is needed for mingw.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-19 18:14: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=14a88dcf3fb49d1fd31b0a6500e22c7d066a1185">14a88dcf3fb49d1fd31b0a6500e22c7d066a1185</a>
-<blockquote>
-<p>
- Enable SSE2 code in openJPEG on Windows.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-19 17:04: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=10de1e0bf9f3abd9c74401258388067c6e2ec36f">10de1e0bf9f3abd9c74401258388067c6e2ec36f</a>
-<blockquote>
-<p>
- valgrind: fix invalid read error in png devices<br>
-<br>
- Noticed passing, several of the png devices left the downscale factor and<br>
- min feature size entries in the device uninitialized.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/devices/gdevpng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-19 16:25: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=f1b0e276370fd632ac7e18c39cffe9972fe67444">f1b0e276370fd632ac7e18c39cffe9972fe67444</a>
-<blockquote>
-<p>
- Bug 693934: CCITT Fax decode - cope with negative run length<br>
-<br>
- In various places in the fax decode code we coped with the run length being<br>
- negative - in just a few we didn't.<br>
-<br>
- We'll now cope gracefully with negative run lengths in places.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/scfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-19 16:29:42 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b871884a283bbe8d908f47844ffff4cf6f009803">b871884a283bbe8d908f47844ffff4cf6f009803</a>
-<blockquote>
-<p>
- White-space clean-up in gstoraster<br>
-<br>
-gs/cups/gstoraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-19 15:26:12 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1149c245e70fcf6b0445f0958a7c1bb972b26f63">1149c245e70fcf6b0445f0958a7c1bb972b26f63</a>
-<blockquote>
-<p>
- Fixed also the suppression of color management via colord in gstoraster<br>
-<br>
- See http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=712045.<br>
-<br>
-gs/cups/gstoraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-19 14:52:25 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1b87b820854525f9709f19f3bb932e4f75210637">1b87b820854525f9709f19f3bb932e4f75210637</a>
-<blockquote>
-<p>
- Make colord-supplied ICC profile getting applied by gstoraster<br>
-<br>
- Patches from Debian bug #712045:<br>
-<br>
- http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=712045<br>
-<br>
- Thanks to Alexey Galakhov for the bug report and the patches.<br>
-<br>
-gs/cups/gstoraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-19 11:32: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=daceba62fcce274fc62e750ac186b3a9026554ad">daceba62fcce274fc62e750ac186b3a9026554ad</a>
-<blockquote>
-<p>
- PDF interpreter - ignore invalid /DecodeParams for streams<br>
-<br>
- Bug #694353 &quot;**** File has unbalanced q/Q operators (too many Q's) **** endless loop&quot;<br>
-<br>
- The PDF file is invalid, it has a /Filters array with 2 elements, and a<br>
- /DecodeParams array with 1 element. The DecodeParams array must have either<br>
- the same number of elements as the Filters, or not be present (default).<br>
-<br>
- We now test the length of each array and ignore the DecodeParams if the lengths<br>
- are not the same (as we have no way to know which Params relate to which Filter)<br>
-<br>
- No differences expected<br>
-<br>
-gs/Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-19 08:53:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c9ac1bc3caaad5d2ea9e277d1b89a5c56b31c5c">1c9ac1bc3caaad5d2ea9e277d1b89a5c56b31c5c</a>
-<blockquote>
-<p>
- Bug 694357: allow override of gcc's __SSE__ define<br>
-<br>
- OpenJPEG uses gcc's &quot;built-in&quot; preprocessor define of __SSE__ to determine<br>
- whether to use its SSE2 code. As we have a configure option to disable SSE2<br>
- use in Ghostscript, that option now also overrides the gcc define thus<br>
- disabling SSE2 in OpenJPEG, too.<br>
-<br>
- This currently only works for gcc.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-18 16:50: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=fea396d5d3202bf3c6b1207b5c8a17b979d0bb4f">fea396d5d3202bf3c6b1207b5c8a17b979d0bb4f</a>
-<blockquote>
-<p>
- Bug 694318: remove reference to freed resource<br>
-<br>
- When we're about to free a PDF resource object in pdfwrite, make sure we remove<br>
- references to it in the substream stack.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-18 12:02: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=95cd6ab8bf3a8866a5a10571a0c034869a4ba064">95cd6ab8bf3a8866a5a10571a0c034869a4ba064</a>
-<blockquote>
-<p>
- PDF interpreter - handle empty cref by rebuilding it.<br>
-<br>
- Bug #694342 &quot;Error: /typecheck in --run-- reading PDF file&quot;<br>
-<br>
- The PDF interpreter didn't notice that an empty xref (the xref token<br>
- immediately followed by the trailer token) was not a valid xref. Later we<br>
- would attempt to use the empty xref, and fail.<br>
-<br>
- We now check the length of 'Objects' when we find the trailer token and if<br>
- it is 0 we throw an error. This causes the PDF itnerpreter to rebuild the<br>
- xref table by rescanning the whole file.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-18 08:20: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=bd2887990301b12c2b11df323ee726855129a637">bd2887990301b12c2b11df323ee726855129a637</a>
-<blockquote>
-<p>
- Bug 694354: cope being unable to read a candidate font file<br>
-<br>
- On Unix, things like directories can be opened as &quot;files&quot;. In the font code,<br>
- we attempt to open a candidate font file, and if that fails, handle it. We<br>
- then read some data from the file to validate it as a suitable font file. If<br>
- the data we read reveals it to be an unsuitable file, we handle that.<br>
-<br>
- We were not handling the case where we could open the &quot;file&quot; but could not<br>
- read from it.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_fonts.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-17 15:46: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=bd08091d295effb51de2cc7e739870e7b2628e38">bd08091d295effb51de2cc7e739870e7b2628e38</a>
-<blockquote>
-<p>
- Bug 694319: &quot;finalize&quot; a font stream before return an error.<br>
-<br>
- pdfwrite and pswrite could, in the event of an error during font writing, leave<br>
- the &quot;stream&quot; for the font in a) an invalid state, and b) in place for the<br>
- continued writing of the output file.<br>
-<br>
- This caused memory corruption, seg fault etc.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/devices/vector/gdevpdtb.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-17 13:01:43 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=489811e366495db7374f2cf3c71bd4a9bdf77360">489811e366495db7374f2cf3c71bd4a9bdf77360</a>
-<blockquote>
-<p>
- Prevent gstoraster from hanging on Ghostscript failure<br>
-<br>
- Thanks to Olivier Blin for this patch.<br>
-<br>
- Original discription in the bug report (bug 693336):<br>
-<br>
- When gs fails and the input file is bigger than the pipe capicity<br>
- (65536 bytes on Linux), gstoraster will hang. In this case, write()<br>
- will block because the pipe is full and no reader is emptying it. The<br>
- gs child process becomes a zombie, and write() will not fail until its<br>
- zombie is gone, which never happens with the current code.<br>
-<br>
- This patch fixes the issue by adding a child reaper, which will make<br>
- write() fail when the child dies, either because of the SIGCHLD signal<br>
- coming, or because of a broken pipe error in write().<br>
-<br>
-gs/cups/gstoraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-17 08:52: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=579e9024d1bc358fe12bcceb00e1ba1797e473ec">579e9024d1bc358fe12bcceb00e1ba1797e473ec</a>
-<blockquote>
-<p>
- Bug 694319 (related): bounds checking T1 op stack<br>
-<br>
- Add some lower bounds checking for the operand stack, to one of the Type 1<br>
- charstring interpreters used by pdf/ps2write.<br>
-<br>
- This fixes one of the memory corruption problems with Bug693711.pdf.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gxtype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-15 10:00: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=0c9e630460084182f0347570b38aa606a5a8a2e8">0c9e630460084182f0347570b38aa606a5a8a2e8</a>
-<blockquote>
-<p>
- pdfwrite - silence a Valgrind warning by initialising a variable<br>
-<br>
- The memory is uninitialised because the file provokes an error, and<br>
- pdfwrite gets confused about which file it is supposed to be in, The net<br>
- result is that an MD5 hash is not generated and we end up with some memory<br>
- not being initialised.<br>
-<br>
- This simply sets the memory to 0 which silences Valgrind, it makes no<br>
- attempt to improve the output.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-14 09:59:55 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=65744368052b127b596014d55a6ea776808a6640">65744368052b127b596014d55a6ea776808a6640</a>
-<blockquote>
-<p>
- Fix gs_pdf14_device_color_mon_set and remove compiler warnings.<br>
-<br>
- The previous function only set the value to false, and this should<br>
- set the value to the bool 'monitoring' that is the second arg.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gsicc_monitorcm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-14 11:04: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=cb2e0f784882696e930e5077ecb1a2feef76fadf">cb2e0f784882696e930e5077ecb1a2feef76fadf</a>
-<blockquote>
-<p>
- Fix pointer confusion in gs_private_st_ptrs2_final()<br>
-<br>
- The order of the pointer arguments in one of the &quot;sub-macros&quot; used in the<br>
- definition of gs_private_st_ptrs2_final() was wrong.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsstruct.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-12 12:39:13 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f75e1cf3d4f4e4e809e94efc29b4046fe07f00c5">f75e1cf3d4f4e4e809e94efc29b4046fe07f00c5</a>
-<blockquote>
-<p>
- Fix Graydetection for pages after the first color page for cust 801.<br>
-<br>
- We need to restore pageneutralcolor if graydetection is true, but also<br>
- we need to reestablish the monitoring color procedures, so we add a<br>
- gsicc_mcm_begin_monitor for the purpose. We change the pdf14 device<br>
- hook to allow the target device monitoring to be turned on or off.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevp14.h<br>
-gs/base/gdevprn.c<br>
-gs/base/gscms.h<br>
-gs/base/gsdevice.c<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_cms.h<br>
-gs/base/gsicc_monitorcm.c<br>
-gs/base/gsicc_nocm.c<br>
-gs/base/gsicc_replacecm.c<br>
-gs/devices/gdevpbm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-13 08:12:35 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5dd1d9a83d41ea9d2542e435172ff4fa7c163828">5dd1d9a83d41ea9d2542e435172ff4fa7c163828</a>
-<blockquote>
-<p>
- Bug 690639: change the order we do character mapping in TTFs<br>
-<br>
- Instead of combining the encoding from the PDF with the Adobe Glyph List to<br>
- get a comprehensive list of glyph name mappings, then building a character<br>
- code to GID mapping from that, and (potentially) using the TTF post table to<br>
- fill in any gaps, we now build a mapping directly from the AGL, then (possibly)<br>
- fill in any gaps from the TTF post table, and *finally* fill in any remaining<br>
- gaps using the PDF's encoding.<br>
-<br>
- This handles a case where the contents of the TTF cmap table don't match the<br>
- contents of the post table.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-11 18:51:18 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e209e22862bd7af4362e08f1aa8f0025341356f0">e209e22862bd7af4362e08f1aa8f0025341356f0</a>
-<blockquote>
-<p>
- Add tiffscaled32 device (32bpp CMYK output with downscaling)<br>
-<br>
- Update documentation.<br>
-<br>
-gs/base/gxdownscale.c<br>
-gs/base/macos-mcp.mak<br>
-gs/base/openvms.mak<br>
-gs/base/unix-gcc.mak<br>
-gs/base/unixansi.mak<br>
-gs/devices/devs.mak<br>
-gs/devices/gdevtsep.c<br>
-gs/doc/Devices.htm<br>
-gs/psi/msvc.mak<br>
-main/pcl6_gcc.mak<br>
-main/pcl6_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-09 13:54:46 -0400
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=617143bb943a6540c751195c60b68387f2b06b88">617143bb943a6540c751195c60b68387f2b06b88</a>
-<blockquote>
-<p>
- Bug 694270: (valgrind) initialize structure<br>
-<br>
- Initialize the Type 1 state structure before using it.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/devices/gxfcopy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-05 10:06:46 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1cf483079386814249cfa831cfbe7491b59dc602">1cf483079386814249cfa831cfbe7491b59dc602</a>
-<blockquote>
-<p>
- Fix for bug 694293. We are improperly clipping to the soft mask bounding box.<br>
-<br>
- If the background alpha value for the softmask is something other than 0 we cannot<br>
- clip to the soft mask bounding box as regions that are outside this area will be<br>
- using the background alpha as their softmask value. Also, we were not accounting<br>
- for the different size of the softmask when compositing. Progressions occurred in<br>
- three test files with this fix in addition to fixing the customer file.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-16 14:52: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=61961d2828e427134f32a90f7477b4c91aae0c57">61961d2828e427134f32a90f7477b4c91aae0c57</a>
-<blockquote>
-<p>
- Bug 694065: address libtiff issues with WinRT build<br>
-<br>
- The defaullt libtiff I/O functions use some methods proscribed in the WinRT world.<br>
-<br>
- Ghostscript does not rely on these defaults, supplying our own I/O hooks<br>
- when we invoke libtiff.<br>
-<br>
- So, if we're building libtiff into GS (as in the default and preferred<br>
- configuration), we leave out those default calls, and replace them with stubs<br>
- to keep the linker happy. Currently, these are empty stubs, and apply to all<br>
- builds, which may cause issues if anyone relies on linking to our built-in<br>
- libtiff, and uses these calls. If that proves to be the case, we can easily<br>
- fill-in the stubs with appropriate code, but working through the GS I/O<br>
- calls.<br>
-<br>
- This also has the advantage that any port to a weird platform, we only<br>
- need to port the Ghostscript I/O, and we don't have to worry about libtiff.<br>
-<br>
- If we're using a &quot;shared&quot; libtiff, these stubs are not included.<br>
-<br>
- Unfortunately, libtiff does not pass around a context to the memory<br>
- management functions, so we currently still have no method of using the<br>
- Ghostscript memory manager.<br>
-<br>
- Update to libpng 1.6.2<br>
-<br>
- libpng 1.6.x dispenses with one of the function calls (lstrlenA) not allowed<br>
- in the WinRT build.<br>
-<br>
- The other (ExitProcess) we work around in the makefiles, replacing it<br>
- with a simple &quot;exit&quot;. This should never be a problem since we actually<br>
- rely on setjmp/longjmp for libpng error handling, and libpng code checks<br>
- for that option before it will get to the &quot;exit&quot; call.<br>
-<br>
- Re-enable TIFF and PNG devices for WinRT<br>
-<br>
- Rename 'PLATFORM' to 'GSPLATFORM'<br>
-<br>
- nmake (at least in VS2012) defines 'PLATFORM' for certain configurations<br>
- which interfered with our use of it, so make it more Ghostscript-centric.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gs.mak<br>
-gs/base/gstiffio.c<br>
-gs/base/gstiffio.h<br>
-gs/base/macos-mcp.mak<br>
-gs/base/msvclib.mak<br>
-gs/base/openvms.mak<br>
-gs/base/openvms.mmk<br>
-gs/base/png.mak<br>
-gs/base/tiff.mak<br>
-gs/base/unixhead.mak<br>
-gs/base/winlib.mak<br>
-gs/configure.ac<br>
-gs/devices/devs.mak<br>
-gs/devices/gdevtfax.c<br>
-gs/devices/gdevtfnx.c<br>
-gs/devices/gdevtifs.c<br>
-gs/devices/gdevtifs.h<br>
-gs/devices/gdevtsep.c<br>
-gs/libpng/ANNOUNCE<br>
-gs/libpng/CHANGES<br>
-gs/libpng/CMakeLists.txt<br>
-gs/libpng/INSTALL<br>
-gs/libpng/LICENSE<br>
-gs/libpng/Makefile.am<br>
-gs/libpng/Makefile.in<br>
-gs/libpng/README<br>
-gs/libpng/aclocal.m4<br>
-gs/libpng/arm/arm_init.c<br>
-gs/libpng/arm/filter_neon.S<br>
-gs/libpng/autogen.sh<br>
-gs/libpng/config.guess<br>
-gs/libpng/config.h.in<br>
-gs/libpng/config.sub<br>
-gs/libpng/configure.ac<br>
-gs/libpng/contrib/examples/README.txt<br>
-gs/libpng/contrib/examples/iccfrompng.c<br>
-gs/libpng/contrib/examples/pngpixel.c<br>
-gs/libpng/contrib/examples/pngtopng.c<br>
-gs/libpng/contrib/gregbook/Makefile.sgi<br>
-gs/libpng/contrib/gregbook/Makefile.unx<br>
-gs/libpng/contrib/gregbook/readpng.c<br>
-gs/libpng/contrib/gregbook/readpng2.c<br>
-gs/libpng/contrib/gregbook/writepng.c<br>
-gs/libpng/contrib/libtests/fakepng.c<br>
-gs/libpng/contrib/libtests/gentests.sh<br>
-gs/libpng/contrib/libtests/makepng.c<br>
-gs/libpng/contrib/libtests/pngstest.c<br>
-gs/libpng/contrib/libtests/pngunknown.c<br>
-gs/libpng/contrib/libtests/pngvalid.c<br>
-gs/libpng/contrib/libtests/readpng.c<br>
-gs/libpng/contrib/libtests/tarith.c<br>
-gs/libpng/contrib/libtests/timepng.c<br>
-gs/libpng/contrib/pngminim/README<br>
-gs/libpng/contrib/pngminim/decoder/makefile<br>
-gs/libpng/contrib/pngminim/decoder/pngusr.dfa<br>
-gs/libpng/contrib/pngminim/decoder/pngusr.h<br>
-gs/libpng/contrib/pngminim/encoder/README<br>
-gs/libpng/contrib/pngminim/encoder/makefile<br>
-gs/libpng/contrib/pngminim/encoder/pngusr.dfa<br>
-gs/libpng/contrib/pngminim/encoder/pngusr.h<br>
-gs/libpng/contrib/pngminim/preader/makefile<br>
-gs/libpng/contrib/pngminim/preader/pngusr.dfa<br>
-gs/libpng/contrib/pngminim/preader/pngusr.h<br>
-gs/libpng/contrib/pngminus/makefile.std<br>
-gs/libpng/contrib/pngminus/png2pnm.c<br>
-gs/libpng/contrib/pngminus/pnm2png.c<br>
-gs/libpng/contrib/pngsuite/README<br>
-gs/libpng/contrib/pngsuite/ftbbn0g01.png<br>
-gs/libpng/contrib/pngsuite/ftbbn0g02.png<br>
-gs/libpng/contrib/pngsuite/ftbbn0g04.png<br>
-gs/libpng/contrib/pngsuite/ftbbn1g04.png<br>
-gs/libpng/contrib/pngsuite/ftbwn0g16.png<br>
-gs/libpng/contrib/pngsuite/ftbwn1g16.png<br>
-gs/libpng/contrib/pngsuite/ftp0n0g08.png<br>
-gs/libpng/contrib/pngsuite/ftp0n1g08.png<br>
-gs/libpng/contrib/tools/README.txt<br>
-gs/libpng/contrib/tools/checksum-icc.c<br>
-gs/libpng/contrib/tools/chkfmt<br>
-gs/libpng/contrib/tools/cvtcolor.c<br>
-gs/libpng/contrib/tools/fixitxt.c<br>
-gs/libpng/contrib/tools/intgamma.sh<br>
-gs/libpng/contrib/tools/makesRGB.c<br>
-gs/libpng/contrib/tools/sRGB.h<br>
-gs/libpng/contrib/visupng/PngFile.c<br>
-gs/libpng/contrib/visupng/PngFile.h<br>
-gs/libpng/contrib/visupng/VisualPng.c<br>
-gs/libpng/depcomp<br>
-gs/libpng/example.c<br>
-gs/libpng/install-sh<br>
-gs/libpng/libpng-config.in<br>
-gs/libpng/libpng-manual.txt<br>
-gs/libpng/libpng.3<br>
-gs/libpng/libpngpf.3<br>
-gs/libpng/ltmain.sh<br>
-gs/libpng/missing<br>
-gs/libpng/png.5<br>
-gs/libpng/png.c<br>
-gs/libpng/png.h<br>
-gs/libpng/pngconf.h<br>
-gs/libpng/pngerror.c<br>
-gs/libpng/pngget.c<br>
-gs/libpng/pnginfo.h<br>
-gs/libpng/pngmem.c<br>
-gs/libpng/pngpread.c<br>
-gs/libpng/pngpriv.h<br>
-gs/libpng/pngread.c<br>
-gs/libpng/pngrio.c<br>
-gs/libpng/pngrtran.c<br>
-gs/libpng/pngrutil.c<br>
-gs/libpng/pngset.c<br>
-gs/libpng/pngstruct.h<br>
-gs/libpng/pngtest.c<br>
-gs/libpng/pngtest.png<br>
-gs/libpng/pngtrans.c<br>
-gs/libpng/pngwio.c<br>
-gs/libpng/pngwrite.c<br>
-gs/libpng/pngwtran.c<br>
-gs/libpng/pngwutil.c<br>
-gs/libpng/projects/owatcom/libpng.wpj<br>
-gs/libpng/projects/owatcom/pngstest.tgt<br>
-gs/libpng/projects/visualc71/README.txt<br>
-gs/libpng/projects/visualc71/libpng.vcproj<br>
-gs/libpng/projects/visualc71/pngtest.vcproj<br>
-gs/libpng/projects/vstudio/WARNING<br>
-gs/libpng/projects/vstudio/libpng/libpng.vcxproj<br>
-gs/libpng/projects/vstudio/pnglibconf/pnglibconf.vcxproj<br>
-gs/libpng/projects/vstudio/pngstest/pngstest.vcxproj<br>
-gs/libpng/projects/vstudio/pngtest/pngtest.vcxproj<br>
-gs/libpng/projects/vstudio/pngunknown/pngunknown.vcxproj<br>
-gs/libpng/projects/vstudio/pngvalid/pngvalid.vcxproj<br>
-gs/libpng/projects/vstudio/readme.txt<br>
-gs/libpng/projects/vstudio/vstudio.sln<br>
-gs/libpng/projects/vstudio/zlib.props<br>
-gs/libpng/projects/vstudio/zlib/zlib.vcxproj<br>
-gs/libpng/scripts/README.txt<br>
-gs/libpng/scripts/checksym.awk<br>
-gs/libpng/scripts/chkfmt<br>
-gs/libpng/scripts/def.dfn<br>
-gs/libpng/scripts/descrip.mms<br>
-gs/libpng/scripts/dfn.awk<br>
-gs/libpng/scripts/intprefix.dfn<br>
-gs/libpng/scripts/libpng-config-head.in<br>
-gs/libpng/scripts/libpng.pc.in<br>
-gs/libpng/scripts/libtool.m4<br>
-gs/libpng/scripts/ltoptions.m4<br>
-gs/libpng/scripts/ltsugar.m4<br>
-gs/libpng/scripts/ltversion.m4<br>
-gs/libpng/scripts/lt~obsolete.m4<br>
-gs/libpng/scripts/macro.lst<br>
-gs/libpng/scripts/makefile.32sunu<br>
-gs/libpng/scripts/makefile.64sunu<br>
-gs/libpng/scripts/makefile.aix<br>
-gs/libpng/scripts/makefile.bc32<br>
-gs/libpng/scripts/makefile.beos<br>
-gs/libpng/scripts/makefile.bor<br>
-gs/libpng/scripts/makefile.cegcc<br>
-gs/libpng/scripts/makefile.darwin<br>
-gs/libpng/scripts/makefile.dec<br>
-gs/libpng/scripts/makefile.dj2<br>
-gs/libpng/scripts/makefile.elf<br>
-gs/libpng/scripts/makefile.freebsd<br>
-gs/libpng/scripts/makefile.gcc<br>
-gs/libpng/scripts/makefile.hp64<br>
-gs/libpng/scripts/makefile.hpgcc<br>
-gs/libpng/scripts/makefile.hpux<br>
-gs/libpng/scripts/makefile.ibmc<br>
-gs/libpng/scripts/makefile.intel<br>
-gs/libpng/scripts/makefile.knr<br>
-gs/libpng/scripts/makefile.linux<br>
-gs/libpng/scripts/makefile.mips<br>
-gs/libpng/scripts/makefile.msc<br>
-gs/libpng/scripts/makefile.msys<br>
-gs/libpng/scripts/makefile.ne12bsd<br>
-gs/libpng/scripts/makefile.netbsd<br>
-gs/libpng/scripts/makefile.openbsd<br>
-gs/libpng/scripts/makefile.sco<br>
-gs/libpng/scripts/makefile.sggcc<br>
-gs/libpng/scripts/makefile.sgi<br>
-gs/libpng/scripts/makefile.so9<br>
-gs/libpng/scripts/makefile.solaris<br>
-gs/libpng/scripts/makefile.solaris-x86<br>
-gs/libpng/scripts/makefile.std<br>
-gs/libpng/scripts/makefile.sunos<br>
-gs/libpng/scripts/makefile.tc3<br>
-gs/libpng/scripts/makefile.vcwin32<br>
-gs/libpng/scripts/makevms.com<br>
-gs/libpng/scripts/options.awk<br>
-gs/libpng/scripts/pnglibconf.dfa<br>
-gs/libpng/scripts/pnglibconf.h.prebuilt<br>
-gs/libpng/scripts/pnglibconf.mak<br>
-gs/libpng/scripts/prefix.dfn<br>
-gs/libpng/scripts/sym.dfn<br>
-gs/libpng/scripts/symbols.def<br>
-gs/libpng/scripts/symbols.dfn<br>
-gs/libpng/scripts/vers.dfn<br>
-gs/libpng/test-driver<br>
-gs/libpng/test-pngtest.sh<br>
-gs/libpng/test-pngvalid-full.sh<br>
-gs/libpng/test-pngvalid-simple.sh<br>
-gs/libpng/tests/pngstest<br>
-gs/libpng/tests/pngstest-0g01<br>
-gs/libpng/tests/pngstest-0g02<br>
-gs/libpng/tests/pngstest-0g04<br>
-gs/libpng/tests/pngstest-0g08<br>
-gs/libpng/tests/pngstest-0g16<br>
-gs/libpng/tests/pngstest-2c08<br>
-gs/libpng/tests/pngstest-2c16<br>
-gs/libpng/tests/pngstest-3p01<br>
-gs/libpng/tests/pngstest-3p02<br>
-gs/libpng/tests/pngstest-3p04<br>
-gs/libpng/tests/pngstest-3p08<br>
-gs/libpng/tests/pngstest-4a08<br>
-gs/libpng/tests/pngstest-4a16<br>
-gs/libpng/tests/pngstest-6a08<br>
-gs/libpng/tests/pngstest-6a16<br>
-gs/libpng/tests/pngstest-error<br>
-gs/libpng/tests/pngtest<br>
-gs/libpng/tests/pngunknown-IDAT<br>
-gs/libpng/tests/pngunknown-discard<br>
-gs/libpng/tests/pngunknown-if-safe<br>
-gs/libpng/tests/pngunknown-sAPI<br>
-gs/libpng/tests/pngunknown-sTER<br>
-gs/libpng/tests/pngunknown-save<br>
-gs/libpng/tests/pngunknown-vpAg<br>
-gs/libpng/tests/pngvalid-gamma-16-to-8<br>
-gs/libpng/tests/pngvalid-gamma-alpha-mode<br>
-gs/libpng/tests/pngvalid-gamma-background<br>
-gs/libpng/tests/pngvalid-gamma-expand16-alpha-mode<br>
-gs/libpng/tests/pngvalid-gamma-expand16-background<br>
-gs/libpng/tests/pngvalid-gamma-expand16-transform<br>
-gs/libpng/tests/pngvalid-gamma-sbit<br>
-gs/libpng/tests/pngvalid-gamma-threshold<br>
-gs/libpng/tests/pngvalid-gamma-transform<br>
-gs/libpng/tests/pngvalid-progressive-interlace-size<br>
-gs/libpng/tests/pngvalid-progressive-interlace-standard<br>
-gs/libpng/tests/pngvalid-progressive-interlace-transform<br>
-gs/libpng/tests/pngvalid-progressive-standard<br>
-gs/libpng/tests/pngvalid-standard<br>
-gs/psi/msvc.mak<br>
-gs/psi/os2.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-05 08:17:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0de588b3705131067078d9cac84d5bc6ff0a77e9">0de588b3705131067078d9cac84d5bc6ff0a77e9</a>
-<blockquote>
-<p>
- pdfwrite - squelch a couple of minor compiler warnings<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-04 13:46:07 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1271b370117a9622fc255df665c007487e16296f">1271b370117a9622fc255df665c007487e16296f</a>
-<blockquote>
-<p>
- Fix bug 694290 caused by an image totally off the page.<br>
-<br>
- This went away with the change to clipping, commit e0ba422, but we<br>
- might as well fix this long standing issue as well.<br>
-<br>
-gs/base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-04 13:01: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=55fbadd981f3ca78f0920342a7ebaca4eab20cfa">55fbadd981f3ca78f0920342a7ebaca4eab20cfa</a>
-<blockquote>
-<p>
- Fix SEGV when -ZL is used.<br>
-<br>
- The stream state memory is NULL, so use local_memory when printing.<br>
-<br>
-gs/base/gxclread.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-04 10:52:14 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d38f691578b52aa954ec9354b59919026d7e46f7">d38f691578b52aa954ec9354b59919026d7e46f7</a>
-<blockquote>
-<p>
- Fixed GhostPCL -DPACIFY_VALGRIND missing symbol issue.<br>
-<br>
-pl/plplatf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-04 18:34: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=7719dd1084cf57cb415b8a64ea2ee09a6eb39ee2">7719dd1084cf57cb415b8a64ea2ee09a6eb39ee2</a>
-<blockquote>
-<p>
- pdfwrite - silence valgrind warning<br>
-<br>
- Bug #694267<br>
- &quot;Valgrind issues found by fuzzing in process_text_modify_width (gdevpdte.c:1104)&quot;<br>
-<br>
- I'm pretty sure this is functionally benign because the values read are not<br>
- actually used, but setting them to zero silences the warning.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-04 13:14: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=549cf6ae1bf57fc8d84d0598f04a861378e0e5ea">549cf6ae1bf57fc8d84d0598f04a861378e0e5ea</a>
-<blockquote>
-<p>
- pdfwrite - colour management, convert Separation and DeviceN base spaces<br>
-<br>
- When the input is DeviceN or Separation, the color conversion strategy is<br>
- Gray, RGB or CMYK, and the alternate space is not compatible, convert the<br>
- alternate space. We do this by constructing either an exponential (Separation)<br>
- or sampled (DeviceN) function, we sample the end points of each ink,<br>
- convert the alternate space representation to the requested device space<br>
- and use those as the data points ofr the function.<br>
-<br>
- The representation probably isn't that great, since it linearly interpolates<br>
- between the (very few) sample points, but it does the job adequately, and<br>
- preserves the Separation/DeviceN space while still creating an appropriate<br>
- colour space in the output.<br>
-<br>
- No differences expected, this code not in use yet.<br>
-<br>
-gs/devices/vector/gdevpdfc.c<br>
-gs/devices/vector/gdevpdfc.h<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-04 09:44: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=662c5022b6731a4cff0c026c0ef62322aaaf396c">662c5022b6731a4cff0c026c0ef62322aaaf396c</a>
-<blockquote>
-<p>
- pdfwrite - additional error checking on named destinations<br>
-<br>
- Bug #694194 &quot;Seg faults found by fuzzing in pdfmark_DOCVIEW&quot;<br>
-<br>
- The routine for creating a named destination could return an error if the<br>
- destination page was outside the valid range (-2 in this case), but the<br>
- DOCVIEW pdfmark wasn't testing the returned value.<br>
-<br>
- Added code to give a meaningful error and return a rangecheck error when this<br>
- occurs.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-03 13:10:10 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e0ba4228f11f9a5af359915878176efee8dc73f5">e0ba4228f11f9a5af359915878176efee8dc73f5</a>
-<blockquote>
-<p>
- Fix clipping bugs 693509 and 690036.<br>
-<br>
- The Adobe scan conversion rules call for the clip path to use the same<br>
- rule as for filling. Thus we need to apply the 'adjust' to do the any part<br>
- of pixel rule. Differences are expected, but bmpcmp doesn't show any.<br>
-<br>
-gs/base/gxcpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-06-03 08:31: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=761e413514c7f9374f54e8ffef3c1d7ebf824e28">761e413514c7f9374f54e8ffef3c1d7ebf824e28</a>
-<blockquote>
-<p>
- Bug 694272: bounds check TTF outline points flags<br>
-<br>
- Reading the points &quot;flags&quot; from the TTF stream, we weren't bounds checking when<br>
- the flag value is a repeated one, so we could trundle off the end of the buffer.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/ttfmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-31 09:46:10 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1eef08f4aaf485a18422e9fbcfd6ac8cbfb03cdb">1eef08f4aaf485a18422e9fbcfd6ac8cbfb03cdb</a>
-<blockquote>
-<p>
- Temporarily disable BGPrint for the cups device until differences fixed.<br>
-<br>
- By using gdev_prn_output_page background printing is not performed.<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-30 15:48:33 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=483e100c06e647d8ba2d68beef09c1c241fd328d">483e100c06e647d8ba2d68beef09c1c241fd328d</a>
-<blockquote>
-<p>
- Addition of ETS code and project into gs/toolbin/halftone<br>
-<br>
-gs/toolbin/halftone/ETS/COPYING.txt<br>
-gs/toolbin/halftone/ETS/Makefile_avec<br>
-gs/toolbin/halftone/ETS/Makefile_sse2<br>
-gs/toolbin/halftone/ETS/README.txt<br>
-gs/toolbin/halftone/ETS/_eb_sse2.s<br>
-gs/toolbin/halftone/ETS/build.bat<br>
-gs/toolbin/halftone/ETS/eb_avec.c<br>
-gs/toolbin/halftone/ETS/eb_avec.h<br>
-gs/toolbin/halftone/ETS/eb_sse2.s<br>
-gs/toolbin/halftone/ETS/ei03.pdf<br>
-gs/toolbin/halftone/ETS/ets.c<br>
-gs/toolbin/halftone/ETS/ets.h<br>
-gs/toolbin/halftone/ETS/ipview.html<br>
-gs/toolbin/halftone/ETS/test_ets.c<br>
-gs/toolbin/halftone/ETS/tm.h<br>
-gs/toolbin/halftone/ETS/win32/ETS.sln<br>
-gs/toolbin/halftone/ETS/win32/ETS.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-30 15:40:34 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=69cce78d20f9ee34954812e72ad6f3e4bf085374">69cce78d20f9ee34954812e72ad6f3e4bf085374</a>
-<blockquote>
-<p>
- Addition of -dPreBandThreshold information into documentation<br>
-<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-29 21:59:45 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0c55548b5fbf6fabdc7c5766c162b0cd67597627">0c55548b5fbf6fabdc7c5766c162b0cd67597627</a>
-<blockquote>
-<p>
- Fix incorrect Gray Detection on pages after the first color page.<br>
-<br>
- Reported by customer 801. The pageneutralcolor element of the icc_struct<br>
- was not being reset, so once it was set for 'color' all subsequent pages<br>
- would be seen as color.<br>
-<br>
-gs/base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-30 13:47:20 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b09746cd4c822c2a72f146e74ff48c4ca4a94807">b09746cd4c822c2a72f146e74ff48c4ca4a94807</a>
-<blockquote>
-<p>
- Bug 694059: support all available TIFF compressions<br>
-<br>
- Previously, we weren't allowing certain valid (but possibly not terribly<br>
- sensible) combinations of bit depth and compression - for those, tiffsep<br>
- would silently ignore the setting and use a default.<br>
-<br>
- This has been relaxed, although certain combinations are not supported by<br>
- libtiff are still proscribed (CRLE/G4/G3 and multibit per sample - for<br>
- example, 8 bits per sample cannot be combined with CCITT Group 4 fax).<br>
- Those now generate an error message and a rangecheck error.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/devices/gdevtifs.c<br>
-gs/devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-30 14:41:07 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c374882e38fdac7ef766c9ac1ec8674e02bd56bc">c374882e38fdac7ef766c9ac1ec8674e02bd56bc</a>
-<blockquote>
-<p>
- Added support for printer calibration to the gstoraster CUPS filter<br>
-<br>
- For doing calibration printouts the color management in the print filter<br>
- chain needs to get turned off. This is done by calling Ghostscript with the<br>
- &quot;-dUseFastColor&quot; command line option. Inhibiting color management can be done<br>
- via colord, with a command like<br>
-<br>
- colormgr device-inhibit /org/freedesktop/ColorManager/devices/&lt;printer&gt; 0<br>
-<br>
- or by sending the calibration print job with the option &quot;color-management=off&quot;.<br>
-<br>
- Thanks to Richard Hughes for the patch.<br>
-<br>
-gs/cups/colord.c<br>
-gs/cups/colord.h<br>
-gs/cups/gstoraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-29 11:24:02 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=89c224b029357002c48660dae98de2d1e560d4e0">89c224b029357002c48660dae98de2d1e560d4e0</a>
-<blockquote>
-<p>
- Fix for too many entries in an image Decode array reported by cust 532.<br>
-<br>
- This is an out-of spec file, but as usual, since Adobe handles it, so we do too.<br>
- Allow too many by setting over_error to 0 when we load the Decode array.<br>
-<br>
- This required a change to dict_float_array_param so that it will load the<br>
- requested number of elements (and return that count) when over_erro == 0.<br>
-<br>
- Also clean up the indenting and get rid of the unused decode_size variable.<br>
-<br>
-gs/psi/idparam.c<br>
-gs/psi/zimage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-29 11:46:45 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6ceadc6f2da001b183d700186e6b5e622bcb22cf">6ceadc6f2da001b183d700186e6b5e622bcb22cf</a>
-<blockquote>
-<p>
- Add missing include when GS_NO_UTF8=1<br>
-<br>
-gs/base/gp_wgetv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-29 17: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=2d04d5942b3e97b06a7ac4ed767a6c481d4421f4">2d04d5942b3e97b06a7ac4ed767a6c481d4421f4</a>
-<blockquote>
-<p>
- pdfwrite - improve handling of Unicode names<br>
-<br>
- Bug#694277 &quot; Improve pdfmark processing to handle unusual names in named destinations&quot;<br>
-<br>
- We can't handle Unicode names in PDF, technically we should write these as<br>
- strings and enter them in the names table, but we don't have a mechanism for<br>
- that for pdfmarks.<br>
-<br>
- Instead we leave them as names using the special processing in pdfwrite, but<br>
- extended with additional markers. When writing these out pdfwrite converts<br>
- the NULLs to an arbitrary string. This works adequately for the bug as<br>
- these are named destinations, but its possible that other kinds of names<br>
- might be visible in the PDF application and would give the wrong result.<br>
-<br>
- So this is at best a patch.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-gs/devices/vector/gdevpdfr.c<br>
-gs/devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-28 11:17:21 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c2503db1c461d7d3af7c8f69a193fb978d8377b3">c2503db1c461d7d3af7c8f69a193fb978d8377b3</a>
-<blockquote>
-<p>
- Bug 694138: Fix component number validation in ICC colorspace<br>
-<br>
-gs/psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-24 17:40:42 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=69ea64d08a97da7afcfb0790f916f1ff4adf115e">69ea64d08a97da7afcfb0790f916f1ff4adf115e</a>
-<blockquote>
-<p>
- Fix MuPDF fuzzing SEGV<br>
-<br>
- Move the indexing of an array AFTER the check for whether the<br>
- index is suitable.<br>
-<br>
-gs/jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-24 16:22:47 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f40a8ab6a7326d1643852e7c9049a9b875131824">f40a8ab6a7326d1643852e7c9049a9b875131824</a>
-<blockquote>
-<p>
- JBIG2Dec: MUPDF fuzzing SEGV fixes<br>
-<br>
- The changes herein solve SEGVs (and valgrind failures) seen when<br>
- fuzzing mupdf. The following are some files that show these up:<br>
-<br>
- tests_private/fuzzing/mupdf/280.pdf.SIGSEGV.93c.2002<br>
- tests_private/fuzzing/mupdf/1112.pdf.SIGSEGV.9ab.128<br>
- tests_private/fuzzing/mupdf/1136.pdf.SIGSEGV.93c.154<br>
-<br>
-gs/jbig2dec/jbig2_generic.c<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-27 09:23: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=c00e028429fa7bbbe1f3902286d5b3710b670815">c00e028429fa7bbbe1f3902286d5b3710b670815</a>
-<blockquote>
-<p>
- pdfwrite - better support for PageLabels<br>
-<br>
- Bug #693929 &quot; Regression: Error: /undefined in --run--&quot;<br>
-<br>
- This code now properly flattens a PageLabels number tree into a single node<br>
- tree, which it converts to a string for inclusion in the output.<br>
-<br>
- In addition to flattening the tree we also perform considerable error checking<br>
- on the tree construction, and we limit the number of page elements to 1000.<br>
- This is because PostScript strings are limited to 64k and we use a string to<br>
- pass the data to the device for inclusion. If we exceed 1000 elements then<br>
- we simply abort the PageLabels (and print a warning on the back channel)<br>
-<br>
- No differences expected, this is not a printing eleent<br>
-<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-26 13:08:46 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3282874fbe636652df435fdacef4ebc3f3ee426b">3282874fbe636652df435fdacef4ebc3f3ee426b</a>
-<blockquote>
-<p>
- Bug 694087: Detect and correct wrong /Subtype of CID font<br>
-<br>
- This attribute appears to be tested again somewhere else.<br>
- Changing the attribute to the correct value clears the bug.<br>
-<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-26 03:01:24 -0400
-</strong>
-<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9567219b7bd46b1d8a7cfc318788e7dc24bebc21">9567219b7bd46b1d8a7cfc318788e7dc24bebc21</a>
-<blockquote>
-<p>
- Bug 694021: Patch for seg fault related issues<br>
-<br>
- The seg fault is due to the the image decoder trying to use an uninitialized<br>
- GR_stats. This also uncovered a few other errors that are covered here :-<br>
- 1) GR_stats is now initialised in all places to prevent it reaching<br>
- jbig2_arith_decode with fake values<br>
- 2) jbig2_arith_decode has been updated to prevent access outside of the<br>
- jbig2_arith_Qe array which now returns an error in such cases.<br>
- 3) all uses of jbig2_decode_refinement_region now check for a returning error<br>
- and act accordingly.<br>
-<br>
-gs/jbig2dec/jbig2_arith.c<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-gs/jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-26 02:02:38 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7131b2045a957089f2c7eec227c23f5fbe4ee1e7">7131b2045a957089f2c7eec227c23f5fbe4ee1e7</a>
-<blockquote>
-<p>
- Bug 694100: Fix yet another automatic PDF file closure.<br>
-<br>
- Read PDF file more carefully during testing for the stream xref<br>
- and validate the tokens to avoid reading past the EOF and<br>
- closing the file.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-24 16:17: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=2f08dfcd4db7f6a95ac9ee983692d922c09a1ffd">2f08dfcd4db7f6a95ac9ee983692d922c09a1ffd</a>
-<blockquote>
-<p>
- pdfwrite - ignore overly complex PageLabels for now<br>
-<br>
- The current PageLabels code doesn't handle anything except the simplest<br>
- case (/Nums at the page tree root), so ignore anything more complex so<br>
- that we don't throw an error.<br>
-<br>
- More work to do, I want to handle a proper tree.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-24 16:02:21 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=66695586781291ca37d190c537784ccf94595428">66695586781291ca37d190c537784ccf94595428</a>
-<blockquote>
-<p>
- Add trio directory to zip archive target.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-24 13:41: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=735c3bbfecc9bbb5792c85558b4641568e316b9d">735c3bbfecc9bbb5792c85558b4641568e316b9d</a>
-<blockquote>
-<p>
- Bug 691784 - jbig2dec WIN32 DLL with configure<br>
-<br>
- See http://bugs.ghostscript.com/show_bug.cgi?id=691784<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/jbig2dec/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-21 00:47:46 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b44040bb9550d403313baec2bed084f1de50093a">b44040bb9550d403313baec2bed084f1de50093a</a>
-<blockquote>
-<p>
- Fix typo in previous commit.<br>
-<br>
- I'd forced the valgrind code on to ensure it was tested, and forgot to<br>
- disable it before commit.<br>
-<br>
-gs/base/gxclipm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-20 19:18: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=94bf81402c991ca8feb59012078b19b5b5d6a5dd">94bf81402c991ca8feb59012078b19b5b5d6a5dd</a>
-<blockquote>
-<p>
- Bug 693803: Add PACIFY_VALGRIND code for clip_runs_enumerate.<br>
-<br>
-gs/base/gxclipm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-20 15:10: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=ebbcd5b9e67b45c8d7187730d131ff43060aa247">ebbcd5b9e67b45c8d7187730d131ff43060aa247</a>
-<blockquote>
-<p>
- Bug 693807: Add PACIFY_VALGRIND code to mem_true32_copy_mono.<br>
-<br>
- Mask of uninitialised bits at the end of a tile row.<br>
-<br>
-gs/base/gdevm32.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-17 11:02:12 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=54683cf9303c3b9146492a9a3a5f5fbc3a7521bc">54683cf9303c3b9146492a9a3a5f5fbc3a7521bc</a>
-<blockquote>
-<p>
- Bug 693965: Fix SEGV in fuzzing test (corrupt image)<br>
-<br>
- Second attempt to commit this; the first time had a typo in.<br>
-<br>
- The first error given by valgrind is due to the image in this<br>
- file being a 16bpp one with a horizontal flip. This tickles<br>
- an incomplete case within the interpolation code. Not<br>
- surprising as there are more options in that code than anyone<br>
- should be expected to cope with. The code is fixed here.<br>
-<br>
- This leads on to the cause of the crash; the image has a matrix<br>
- with a HUGE x shift on it. This upsets some of the floating<br>
- point calculations used to calculate the render rectangle.<br>
-<br>
- This code has been hardened now to cope with such errors.<br>
-<br>
-gs/base/gxipixel.c<br>
-gs/base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-20 12:14:00 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0956abfbb0b53ecd1e8e276d6b2c603a720e6187">0956abfbb0b53ecd1e8e276d6b2c603a720e6187</a>
-<blockquote>
-<p>
- Revert &quot;Bug 693965: Fix SEGV in fuzzing test (corrupt image)&quot;<br>
-<br>
- This reverts commit 1f80c02083b222e3f005c46e91ab4597de323371. Committed<br>
- too early, sorry.<br>
-<br>
-gs/base/gxipixel.c<br>
-gs/base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-20 09:30:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a8487e333554f19bf8d529b9e7893ad4e16448d1">a8487e333554f19bf8d529b9e7893ad4e16448d1</a>
-<blockquote>
-<p>
- Ensure that PCL bitmap glyphs with no data still execute setcachedevice<br>
-<br>
- This grew out of Bug #694069, in the course of resolving that problem it<br>
- transpired that, if there was no data available for a downloaded bitmap<br>
- character, the PCL interpreter simply returned.<br>
-<br>
- In conjunction with pdfwrite, this caused an endless loop due to the character<br>
- cache being overfilled. We only check the availability of space in the<br>
- character cache in setcachedevice, so its safer to make sure that we do<br>
- call it, thereby avoiding the overfilling.<br>
-<br>
- No differences expected.<br>
-<br>
-pl/plchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-18 14:42:23 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36f1de9b5a937d535cb44bb088572b76a9c5bcbd">36f1de9b5a937d535cb44bb088572b76a9c5bcbd</a>
-<blockquote>
-<p>
- Fix BGPrint mode (copy_paste error that disabled background printing.<br>
-<br>
-gs/base/gdevprn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-17 11:02:12 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1f80c02083b222e3f005c46e91ab4597de323371">1f80c02083b222e3f005c46e91ab4597de323371</a>
-<blockquote>
-<p>
- Bug 693965: Fix SEGV in fuzzing test (corrupt image)<br>
-<br>
- The first error given by valgrind is due to the image in this<br>
- file being a 16bpp one with a horizontal flip. This tickles<br>
- an incomplete case within the interpolation code. Not<br>
- surprising as there are more options in that code than anyone<br>
- should be expected to cope with. The code is fixed here.<br>
-<br>
- This leads on to the cause of the crash; the image has a matrix<br>
- with a HUGE x shift on it. This upsets some of the floating<br>
- point calculations used to calculate the render rectangle.<br>
-<br>
- This code has been hardened now to cope with such errors.<br>
-<br>
-gs/base/gxipixel.c<br>
-gs/base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-16 07:34:06 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f0ff05b449b4ecc9332029faf7e7b186b3e18052">f0ff05b449b4ecc9332029faf7e7b186b3e18052</a>
-<blockquote>
-<p>
- Add words about shared libs on OS X.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/doc/Make.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-15 06:54:53 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eccbb7c6c0c267f6e3b7a2381b0b019140f3d831">eccbb7c6c0c267f6e3b7a2381b0b019140f3d831</a>
-<blockquote>
-<p>
- Added singlePagePDF mode to clusterpush.pl.<br>
-<br>
-gs/toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-14 16:28:22 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=853678e7bd4303cd5a1b5e74dfe257fd896a106c">853678e7bd4303cd5a1b5e74dfe257fd896a106c</a>
-<blockquote>
-<p>
- Remove obsolete USECIEColor option in PCL and PXL.<br>
-<br>
-pcl/pccid.c<br>
-pcl/pcstate.h<br>
-pl/pjparse.c<br>
-pxl/pxcet.txt<br>
-pxl/pximage.c<br>
-pxl/pxink.c<br>
-pxl/pxpthr.c<br>
-pxl/pxsessio.c<br>
-pxl/pxstate.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-14 15:33:24 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=593afcba2b670c6b1051d39d2a73ce1b386b871c">593afcba2b670c6b1051d39d2a73ce1b386b871c</a>
-<blockquote>
-<p>
- Remove obsolete scripts<br>
-<br>
-pxl/pxprint.bat<br>
-pxl/pxprint.tcl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-14 17:39:47 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=397e20418223e2faba856ae80e7945faa1a10e99">397e20418223e2faba856ae80e7945faa1a10e99</a>
-<blockquote>
-<p>
- Add gsicc_monitorcm.c to Win32 project.<br>
-<br>
-gs/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-14 17:24: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=37b08e30586434098c9f6b8dc35fa25de39f468d">37b08e30586434098c9f6b8dc35fa25de39f468d</a>
-<blockquote>
-<p>
- pdfwrite - when using %d in OutputFile, empty glyphs from cache<br>
-<br>
- Bug #694069<br>
-<br>
- When we are using '%d' in the Output File Name, we throw away the PDF font<br>
- resource after every page, but the intperpreter glyph cache remains filled.<br>
-<br>
- This is a problem for type 3 fonts (specifically their PCL equivalents), as<br>
- we won't rerun the glyph description to capture it for a type 3 font, so<br>
- the glyphs don't get captured.<br>
-<br>
- To solve this we empty any existing cache entry before attempting to run the<br>
- glyph. This runs into some more awkwardness with a specific kind of broken<br>
- font (no chacracter data) in some QL test files. We work around that too.<br>
-<br>
-gs/devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-14 11:04: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=e76dc46756e89a14a3348bce12a633d32e4fa831">e76dc46756e89a14a3348bce12a633d32e4fa831</a>
-<blockquote>
-<p>
- Allow command line override for endian setting.<br>
-<br>
- Due bugs in certain versions of autoconf, we use an explicit check for<br>
- endianness instead of the built-in macro. This can result in problems when<br>
- cross compiling.<br>
-<br>
- This override allows command line options to pre-empt the explicit check.<br>
-<br>
- No cluster differences.<br>
-<br>
-configure.ac<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-14 09:27: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=4692f1abb037f49bd5158fb6a988076fdc14754d">4692f1abb037f49bd5158fb6a988076fdc14754d</a>
-<blockquote>
-<p>
- pdfwrite - really make all TrueType fonts symbolic<br>
-<br>
- If we don't subset TrueType fonts, we still want to mark them as symbolic,<br>
- because we never emit a /Encoding, and without that Acrobat (but not<br>
- other readers) is unable to display some glyphs correctly.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-11 16:30:36 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c03495a2c2df7f03d537dbbd53aedc014e0577d0">c03495a2c2df7f03d537dbbd53aedc014e0577d0</a>
-<blockquote>
-<p>
- Add documentation for BGPrint and GrayDetection.<br>
-<br>
-gs/doc/Language.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-09 20:47:31 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a8612112478196d8f047a556fdbb15d17aec7d0">7a8612112478196d8f047a556fdbb15d17aec7d0</a>
-<blockquote>
-<p>
- Add PSFitPage and FitPage options to allow fitting PS files to a page.<br>
-<br>
- The FitPage option is added as a convenience to set all three *FitPage<br>
- options, so -dFitPage is the same as -dEPSFitPage -dPDFFitPage -dPSFitPage.<br>
- The -dPSFitPage option is new and works by establishing the default<br>
- Polcies PageSize to 13.<br>
-<br>
- When the Policy is 3 or 13, the page size matching logic rotates, scales,<br>
- and center a PostScript file's requested page size on the best fit medium.<br>
- When the Policy is 13, the the match_page_size enables the scaling down<br>
- (as with Policy 3) as well as up.<br>
-<br>
- Only populate the InputAttr dictionary with the current page size if<br>
- FIXEDMEDIA is set (explicitly, or impiled by -g) so that only that<br>
- page size is available for match_page_size.<br>
-<br>
- When the policy is 13, we enable the PageSize in the setpagedevice<br>
- merged request even if FIXEDMEDIA is set.<br>
-<br>
- The make_adjustment_matrix has the check for factor &lt; 1 removed since<br>
- this is accounted for in the caller setting the 'scale' boolean (larger).<br>
-<br>
- The documentation in doc/Use.htm is updated for both the -dPSFitPage<br>
- option and the -dFitPage option.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/Resource/Init/gs_setpd.ps<br>
-gs/doc/Use.htm<br>
-gs/psi/zmedia2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-13 17:03: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=790240763991cf42b98b37c9dec22bf67df4c90d">790240763991cf42b98b37c9dec22bf67df4c90d</a>
-<blockquote>
-<p>
- Use the srcdir variable in configure for Luratech<br>
-<br>
- One of the Luratech paths in the configure script wasn't using the srcdir<br>
- variable so would not work correctly for &quot;out of tree&quot; building.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-11 10:30: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=606f3279e00ae250bf883ce45b90d276943ffe84">606f3279e00ae250bf883ce45b90d276943ffe84</a>
-<blockquote>
-<p>
- pdfwrite - don't cache high level pattern filled glyphs<br>
-<br>
- Bug #693946 &quot;High level pattern commit causes a regression&quot;<br>
-<br>
- If we use the cache when a glyph is filled with a high level pattern we will<br>
- get incorrect rendering, as the pattern was not passed down to the low level<br>
- routines. So make sure we don't cache glyphs under these conditions, nor<br>
- consult the cache for existing cached glyphs.<br>
-<br>
- Expected Differences<br>
- 14-07.bin and 19-10.bin should now work correctly<br>
-<br>
-gs/devices/vector/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-10 09:57: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=32954e1a310eb4a3673a0eb815be8d618e17aad4">32954e1a310eb4a3673a0eb815be8d618e17aad4</a>
-<blockquote>
-<p>
- epswrite - flush stream before writing page trailer<br>
-<br>
- Bug #694061 &quot;epswrite generates bad file&quot;<br>
-<br>
- The code (quite deliberately) writes the page trailer *directly to the file*<br>
- before flushing the stream. This resulted in the page trailer being emitted<br>
- part way through a path construction and fill. The fill is completed by the<br>
- flushing of the stream.<br>
-<br>
- In this commit we flush the stream first.<br>
-<br>
- No differences expected, the cluster does not test epswrite.<br>
-<br>
-gs/devices/vector/gdevps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-10 08:31: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=ca6408d4bda6c899374984ba7705e734ff6c9d59">ca6408d4bda6c899374984ba7705e734ff6c9d59</a>
-<blockquote>
-<p>
- documentation - remove duplicated epswrite section in devices.htm<br>
-<br>
-gs/doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-09 09:43: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=1f5bc0eb4bbb1c9512f8c63e953b9d2cd76ca563">1f5bc0eb4bbb1c9512f8c63e953b9d2cd76ca563</a>
-<blockquote>
-<p>
- Bug 693964: handle missing FistChar and Widths<br>
-<br>
- When tailoring scaling a substitute font (based on the Widths array),<br>
- handle non-spec compliant files which are missing FirstChar and Width<br>
- entries from FontDescriptor dictionaries for non-base14 fonts.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-08 17:00:27 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3aa5eb75e645d70f315193869179ec88ff20691c">3aa5eb75e645d70f315193869179ec88ff20691c</a>
-<blockquote>
-<p>
- Bug 693377: Fix warning in rinkj device due to pointer cast.<br>
-<br>
- Cast via size_t to avoid warning.<br>
-<br>
-gs/devices/rinkj/evenbetter-rll.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-08 20:28:46 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d8926b7746b8acbf870b3aed93ba2a4ee799e94b">d8926b7746b8acbf870b3aed93ba2a4ee799e94b</a>
-<blockquote>
-<p>
- Bug 693377: Fix some 32bit specific warnings in gdevmjc.c<br>
-<br>
-gs/contrib/japanese/gdevmjc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-08 13:24:14 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d838c5de6baa30cec31542ae8998fe3d3a5e4b31">d838c5de6baa30cec31542ae8998fe3d3a5e4b31</a>
-<blockquote>
-<p>
- Bug693377: Squash some warnings in libtiff<br>
-<br>
- Avoid warnings about casting pointer to int of a different size<br>
- by casting via size_t. Should be ptrdiff_t really, but we don't<br>
- have that in all cases.<br>
-<br>
-gs/tiff/libtiff/tif_unix.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-08 19:25: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=040915cc3ab82a9b0be77fa4dd27caa330f2ab5c">040915cc3ab82a9b0be77fa4dd27caa330f2ab5c</a>
-<blockquote>
-<p>
- Squash some warnings.<br>
-<br>
- In gs/base/gsroprun1.h we cast a pointer to an int and then &amp; 3<br>
- to find alignment. Given ints are always &gt; 2 bits, this is always<br>
- safe, but the compiler whinges anyway. We'd like to use ptrdiff_t<br>
- instead to avoid the whinging, but it's not defined. So define<br>
- our own using the ARCH_ macros.<br>
-<br>
- In gs/base/gxclrect.c, we check for the size of a type, and then<br>
- shift down by it. The compiler complains that the shift may be<br>
- too large to be defined in C, not realising that this is precisely<br>
- what we have just checked. We work around this by shifting in 2<br>
- stages.<br>
-<br>
-gs/base/gsroprun1.h<br>
-gs/base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-08 11:16:05 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ae3839979568fcb7e4a158cff48eed037830878a">ae3839979568fcb7e4a158cff48eed037830878a</a>
-<blockquote>
-<p>
- Miscellaneous warning and scan build fixes.<br>
-<br>
-gs/devices/gdevpxut.c<br>
-gs/devices/vector/gdevsvg.c<br>
-pcl/pcsfont.c<br>
-pcl/pctext.c<br>
-pxl/pxsessio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-08 13:13:02 +0100
-</strong>
-<br>Paul Gardiner &lt;paul@glidos.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b652073e14ebfccf7324ae05f9bf871502560bf4">b652073e14ebfccf7324ae05f9bf871502560bf4</a>
-<blockquote>
-<p>
- WinRT: add build instructions<br>
-<br>
-gs/doc/Make.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-08 13:31:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b4cde01cf5be3d9caa813532ca93603a36d2f20">4b4cde01cf5be3d9caa813532ca93603a36d2f20</a>
-<blockquote>
-<p>
- Bug 688949: allow Ghostscript to build outside src tree<br>
-<br>
- These changes allow you to run the Ghostscript configure script and make from<br>
- outside the source tree. Allowing the use of a &quot;build directory&quot; so the<br>
- source directory stays unadulterated.<br>
-<br>
- The cluster test through up a load of compiler warnings, but none of them are<br>
- new, as far as I can tell.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Makefile.in<br>
-gs/configure.ac<br>
-gs/cups/cups.mak<br>
-gs/devices/devs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-07 17:11:19 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9eb9408b3ccfdb8f0cf54d8ca9adcc79a102319a">9eb9408b3ccfdb8f0cf54d8ca9adcc79a102319a</a>
-<blockquote>
-<p>
- Fix 693412 fix duplex and number of copies interaction.<br>
-<br>
- Add pcl duplex command if the page count is divisible by the number of<br>
- copies not the raw page count to properly collate duplexing jobs.<br>
- Patch contributed by Binaria Digital.<br>
-<br>
-gs/devices/gdevdljm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-07 15:40:50 +0100
-</strong>
-<br>Paul Gardiner &lt;paul@glidos.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9429a2dbfe6609939185970beb4789bd438624af">9429a2dbfe6609939185970beb4789bd438624af</a>
-<blockquote>
-<p>
- Support building for WinRT<br>
-<br>
-.gitignore<br>
-gs/base/gp_msdll.c<br>
-gs/base/gp_mswin.c<br>
-gs/base/gp_ntfs.c<br>
-gs/base/gp_win32.c<br>
-gs/base/gp_wpapr.c<br>
-gs/base/gp_wsync.c<br>
-gs/base/windows_.h<br>
-gs/base/winrtsup.cpp<br>
-gs/base/winrtsup.h<br>
-gs/ghostscript_rt.vcxproj<br>
-gs/psi/iapi.c<br>
-gs/psi/msvc.mak<br>
-main/pcl6_msvc.mak<br>
-winrt/GhostPDL.sln<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-07 15:34:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=19dc7b855696c15a074067e883a13588aca8774d">19dc7b855696c15a074067e883a13588aca8774d</a>
-<blockquote>
-<p>
- Bug 691555: two jbig2dec patches for libpng14 Cygwin/MinGW<br>
-<br>
- from yselkowitz@users.sourceforge.net<br>
-<br>
- Adding &quot;-lpng -lz&quot; to LIBS causes everything to be linked against them,<br>
- whether or not they need them. Only the jbig2dec executable uses<br>
- libpng; libjbig2dec does not, so this causes a needless dependency on<br>
- libpng and zlib. Instead, define a separate PNG_LIBS variable and use<br>
- it in jpeg2dec_LDADD.<br>
-<br>
- libtool requires the -no-undefined flag on PE platforms (Cygwin/MinGW)<br>
- in order to make a shared library due to the unique requirements of<br>
- DLLs.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/jbig2dec/Makefile.am<br>
-gs/jbig2dec/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-07 15:11:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cfa7da5e8b995023ab56186de1fe1e007619b63f">cfa7da5e8b995023ab56186de1fe1e007619b63f</a>
-<blockquote>
-<p>
- vector device - ensure colour changes are not restored away by clip<br>
-<br>
- Bug #693951 &quot;pswrite/epswrite is changing colors when creating an eps or an ps file from a ps file&quot;<br>
-<br>
- When an image is degenerated into trapezoids, then when writing the trapezoids<br>
- we first set the colour, then ensure any clip path is satisfied, then emit<br>
- the trapezoid and fill it.<br>
-<br>
- However, if a clip path *is* pending, then it will emit a 'grestore' which<br>
- restores away the colour we initially set. This commit ensures that if a<br>
- clip is pending, we set the colour again after completing the clip.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gdevvec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-07 11:56:16 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8128a2c74d319c430a76cca5620a6f4a77505e46">8128a2c74d319c430a76cca5620a6f4a77505e46</a>
-<blockquote>
-<p>
- Bug 693253: have the &quot;-h&quot; output mention fontconfig<br>
-<br>
- When Ghostscript is built to use fontconfig to try to find font files (in<br>
- addition to the &quot;normal&quot; paths), include a note in the &quot;-h&quot; output<br>
- that states fontconfig may be used.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-15 18:35:36 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e64ac4c83a4ae07dc15c4cacd7b60cba6294899a">e64ac4c83a4ae07dc15c4cacd7b60cba6294899a</a>
-<blockquote>
-<p>
- Bug 693843: Add a gs_sprintf() function, and supporting code<br>
-<br>
- Same as sprintf() but certain to be unaffected by localization.<br>
-<br>
- Utilizes the &quot;trio&quot; string library, also added here. There is one modification<br>
- to trio, in trio.c and labelled with &quot;/* GS Modification */&quot; - by default, trio<br>
- is a little aggressive in the point it switches to exponent notation, and the<br>
- patch brings is more line with what we need/expect.<br>
-<br>
- trio also includes a sscanf() function which we can utilise if required.<br>
-<br>
- See the gs-sprintf branch for the individual commits - especially those in the<br>
- trio source, should a trio update ever be pulled in.<br>
-<br>
- This causes rounding differences in the pdfwrite/ps2write output in a number<br>
- of the cluster files. They all appear to be pixel variations.<br>
-<br>
-common/msvc_top.mak<br>
-common/ugcc_top.mak<br>
-gs/Makefile.in<br>
-gs/base/fapiufst.c<br>
-gs/base/gdevdevn.c<br>
-gs/base/gdevp14.c<br>
-gs/base/gp_macio.c<br>
-gs/base/gp_mswin.c<br>
-gs/base/gp_wgetv.c<br>
-gs/base/gs.mak<br>
-gs/base/gsalloc.c<br>
-gs/base/gsdevice.c<br>
-gs/base/gsdparam.c<br>
-gs/base/gsfcmap.c<br>
-gs/base/gsicc_create.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsiodisk.c<br>
-gs/base/gspmdrv.c<br>
-gs/base/gssprintf.c<br>
-gs/base/gssprintf.h<br>
-gs/base/gxblend.c<br>
-gs/base/gxblend1.c<br>
-gs/base/gxclmem.c<br>
-gs/base/gxhintn.c<br>
-gs/base/gxpath.c<br>
-gs/base/gxpcmap.c<br>
-gs/base/lib.mak<br>
-gs/base/md5main.c<br>
-gs/base/mkromfs.c<br>
-gs/base/sdcparam.c<br>
-gs/base/sjbig2.c<br>
-gs/base/spprint.c<br>
-gs/base/stdio_.h<br>
-gs/base/trio.mak<br>
-gs/base/unix-gcc.mak<br>
-gs/base/unixansi.mak<br>
-gs/base/winlib.mak<br>
-gs/base/wrfont.c<br>
-gs/base/write_t1.c<br>
-gs/base/write_t2.c<br>
-gs/contrib/eplaser/gdevescv.c<br>
-gs/contrib/gdevcd8.c<br>
-gs/contrib/gdevdj9.c<br>
-gs/contrib/gdevhl12.c<br>
-gs/contrib/gdevxes.c<br>
-gs/contrib/gomni.c<br>
-gs/contrib/japanese/dviprlib.c<br>
-gs/contrib/japanese/gdevfmlbp.c<br>
-gs/contrib/japanese/gdevfmpr.c<br>
-gs/contrib/japanese/gdevj100.c<br>
-gs/contrib/japanese/gdevlbp3.c<br>
-gs/contrib/japanese/gdevmag.c<br>
-gs/contrib/japanese/gdevnpdl.c<br>
-gs/contrib/lips4/gdevl4r.c<br>
-gs/contrib/lips4/gdevl4v.c<br>
-gs/contrib/pcl3/src/gdevpcl3.c<br>
-gs/cups/gdevcups.c<br>
-gs/devices/gdev3b1.c<br>
-gs/devices/gdev8510.c<br>
-gs/devices/gdevccr.c<br>
-gs/devices/gdevdjet.c<br>
-gs/devices/gdevijs.c<br>
-gs/devices/gdevl31s.c<br>
-gs/devices/gdevpng.c<br>
-gs/devices/gdevsppr.c<br>
-gs/devices/gdevsun.c<br>
-gs/devices/gdevtifs.c<br>
-gs/devices/gdevtsep.c<br>
-gs/devices/gdevupd.c<br>
-gs/devices/gdevwpr2.c<br>
-gs/devices/gdevxini.c<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfb.c<br>
-gs/devices/vector/gdevpdfe.c<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpdfi.c<br>
-gs/devices/vector/gdevpdfm.c<br>
-gs/devices/vector/gdevpdfo.c<br>
-gs/devices/vector/gdevpdfr.c<br>
-gs/devices/vector/gdevpdft.c<br>
-gs/devices/vector/gdevpdfu.c<br>
-gs/devices/vector/gdevpdfv.c<br>
-gs/devices/vector/gdevpdtb.c<br>
-gs/devices/vector/gdevpdtc.c<br>
-gs/devices/vector/gdevpdtf.c<br>
-gs/devices/vector/gdevpdti.c<br>
-gs/devices/vector/gdevpdtt.c<br>
-gs/devices/vector/gdevpdtw.c<br>
-gs/devices/vector/gdevps.c<br>
-gs/devices/vector/gdevpsf1.c<br>
-gs/devices/vector/gdevpsf2.c<br>
-gs/devices/vector/gdevsvg.c<br>
-gs/devices/vector/gdevtxtw.c<br>
-gs/devices/vector/gdevxps.c<br>
-gs/psi/dmmain.c<br>
-gs/psi/dpmain.c<br>
-gs/psi/dscparse.c<br>
-gs/psi/dwimg.c<br>
-gs/psi/dwmainc.c<br>
-gs/psi/dxmain.c<br>
-gs/psi/int.mak<br>
-gs/psi/iparam.c<br>
-gs/psi/iutil.c<br>
-gs/psi/iutil2.c<br>
-gs/psi/msvc.mak<br>
-gs/psi/zbfont.c<br>
-gs/psi/zdouble.c<br>
-gs/psi/zfapi.c<br>
-gs/psi/zfont2.c<br>
-gs/trio/CHANGES<br>
-gs/trio/FILES<br>
-gs/trio/Makefile.in<br>
-gs/trio/README<br>
-gs/trio/autogen.sh<br>
-gs/trio/compare.c<br>
-gs/trio/configure.in<br>
-gs/trio/doc/doc.h<br>
-gs/trio/doc/doc_dynamic.h<br>
-gs/trio/doc/doc_printf.h<br>
-gs/trio/doc/doc_register.h<br>
-gs/trio/doc/doc_scanf.h<br>
-gs/trio/doc/doc_static.h<br>
-gs/trio/doc/footer.html<br>
-gs/trio/doc/header.html<br>
-gs/trio/doc/trio.cfg<br>
-gs/trio/doc/trio.css<br>
-gs/trio/example.c<br>
-gs/trio/html/group___dynamic_strings.html<br>
-gs/trio/html/group___printf.html<br>
-gs/trio/html/group___scanf.html<br>
-gs/trio/html/group___special_quantities.html<br>
-gs/trio/html/group___static_strings.html<br>
-gs/trio/html/group___user_defined.html<br>
-gs/trio/html/index.html<br>
-gs/trio/html/modules.html<br>
-gs/trio/html/trio.css<br>
-gs/trio/install-sh<br>
-gs/trio/maketgz<br>
-gs/trio/regression.c<br>
-gs/trio/strio.h<br>
-gs/trio/trio.c<br>
-gs/trio/trio.h<br>
-gs/trio/triodef.h<br>
-gs/trio/trionan.c<br>
-gs/trio/trionan.h<br>
-gs/trio/triop.h<br>
-gs/trio/triostr.c<br>
-gs/trio/triostr.h<br>
-main/pcl6_gcc.mak<br>
-main/pcl6_msvc.mak<br>
-pcl/pcfontpg.c<br>
-pcl/pcht.c<br>
-pcl/pcstatus.c<br>
-pl/dwimg.c<br>
-pl/dwmainc.c<br>
-pl/pjparse.c<br>
-pl/plmain.c<br>
-pxl/pxerrors.c<br>
-pxl/pxfont.c<br>
-pxl/pxpthr.c<br>
-svg/svg_msvc.mak<br>
-xps/xps_msvc.mak<br>
-xps/xpsttf.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-07 08:24: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=07ba8bea8e98084a156edac611a4ae92545edf06">07ba8bea8e98084a156edac611a4ae92545edf06</a>
-<blockquote>
-<p>
- fix commit 2adc88900956d92433e1d97ca3a22170a462f098<br>
-<br>
- Seems there was a typo in this commit, which is fixed here.<br>
-<br>
-gs/base/gxclread.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-07 08:18: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=50533c139389cdfa7c652eb60b973239033aebc3">50533c139389cdfa7c652eb60b973239033aebc3</a>
-<blockquote>
-<p>
- pdfwrite - get rid of some compiler warnings<br>
-<br>
-gs/devices/vector/gdevpdtb.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-02 17:03:57 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2adc88900956d92433e1d97ca3a22170a462f098">2adc88900956d92433e1d97ca3a22170a462f098</a>
-<blockquote>
-<p>
- Finish GrayDetection implementation and add pnmcmyk example device.<br>
-<br>
- The pnmcmyk device will output a P5 pgm file if the page source colors<br>
- are all (near) neutral, otherwise will output PAM P7 32-bit CMYK.<br>
- This device is intended to be an example for a customer.<br>
-<br>
- Note that there is a conditional compile based on PESSIMISTIC_CMYK_NEUTRAL<br>
- that, if defined, will assume that if any C, M, or Y component has a value<br>
- greater than DEVICE_NEUTRAL the page will be treated as color (even if all<br>
- three components are 100%). This may be what the customer requested.<br>
- The default comparison is based on the C, M, and Y components be close to<br>
- each other (similar to RGB).<br>
-<br>
- Also disable graydetection during clist playback. We don't need worry about<br>
- page mode because colors are already processed as the image is rendered<br>
- into the page buffer, but high level images in the clist would slow down<br>
- if graydetection was performed again.<br>
-<br>
-gs/base/gsicc_monitorcm.c<br>
-gs/base/gxclread.c<br>
-gs/devices/devs.mak<br>
-gs/devices/gdevpbm.c<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-06 17:03:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b04bd6b0bb5098b809b3d06f69e2eb55905af648">b04bd6b0bb5098b809b3d06f69e2eb55905af648</a>
-<blockquote>
-<p>
- pdfwrite - DO not leave dangling references in font/matrix cache<br>
-<br>
- Bug #693948 &quot;%d not working with pcl&quot;<br>
-<br>
- Under some conditions (TrueType fonts, but not CID TT), we end up adding the<br>
- font to the font/matrix cache. However, the font we add is a copy of the<br>
- original.<br>
-<br>
- If we are using %d to emit multiple files, then we free our copies after<br>
- every page. However, we did not purge the cache, leading to stale pointers<br>
- in it. If we then reused a font we could end up trying to use a stale<br>
- pointer with unfortunate results.<br>
-<br>
- This commit adds a 'notify' procedure so that we clear copied fonts from<br>
- the cache when they are released.<br>
-<br>
- This caused one difference in the regression tests, which I do not understand<br>
- but is not visilby different....<br>
-<br>
- Signed-off-by: Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<br>
-gs/devices/vector/gdevpdtb.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-06 07:47:00 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0a3d34cfec18ffd3ae1c6fd29dc3c6d4755fe5a3">0a3d34cfec18ffd3ae1c6fd29dc3c6d4755fe5a3</a>
-<blockquote>
-<p>
- Fix font state variables not propely initialized and add character<br>
- angle state in PXL Pass Thru mode.<br>
-<br>
- We note several progression in T427.BIN and C705.BIN with the change.<br>
-<br>
-pxl/pxpthr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-29 09:40:19 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=73957305ae44e43174cd8173b94c35f9f4ca55b4">73957305ae44e43174cd8173b94c35f9f4ca55b4</a>
-<blockquote>
-<p>
- Add gdev_prn_bg_output_page (and _seekable) to support BGPrint.<br>
-<br>
- Some devices are not compatible with background printing, if they are<br>
- not thread safe (use globals) or update the device structure.<br>
- Simple updates to the device structure can be handled in a device's<br>
- own output_page function that performs any actions needed before<br>
- calling gdev_prn_bg_output_page, then performing any action needed<br>
- after the page is printed (or started in the background). The cups<br>
- device is an example of this.<br>
-<br>
- If the page is printed in the background, it uses a clone of the device<br>
- structure, so any changes to that structure will not be reflected in<br>
- the foreground device.<br>
-<br>
- The devices were reviewed and those that were changed to use gdev_prn_bg<br>
- output_page proc should be safe for background printing, but only<br>
- those that are used in regression testing have been tested by forcing<br>
- BGPrint=true.<br>
-<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevprn.h<br>
-gs/cups/gdevcups.c<br>
-gs/devices/devs.mak<br>
-gs/devices/gdev3852.c<br>
-gs/devices/gdev4081.c<br>
-gs/devices/gdev4693.c<br>
-gs/devices/gdev8510.c<br>
-gs/devices/gdevadmp.c<br>
-gs/devices/gdevatx.c<br>
-gs/devices/gdevbit.c<br>
-gs/devices/gdevbj10.c<br>
-gs/devices/gdevbmp.c<br>
-gs/devices/gdevccr.c<br>
-gs/devices/gdevcdj.c<br>
-gs/devices/gdevcfax.c<br>
-gs/devices/gdevcif.c<br>
-gs/devices/gdevclj.c<br>
-gs/devices/gdevcljc.c<br>
-gs/devices/gdevcslw.c<br>
-gs/devices/gdevdfax.c<br>
-gs/devices/gdevdjet.c<br>
-gs/devices/gdevdjtc.c<br>
-gs/devices/gdevdm24.c<br>
-gs/devices/gdevepsc.c<br>
-gs/devices/gdevepsn.c<br>
-gs/devices/gdevescp.c<br>
-gs/devices/gdevfax.c<br>
-gs/devices/gdevhl7x.c<br>
-gs/devices/gdevicov.c<br>
-gs/devices/gdevimgn.c<br>
-gs/devices/gdevjbig2.c<br>
-gs/devices/gdevjpeg.c<br>
-gs/devices/gdevjpx.c<br>
-gs/devices/gdevl31s.c<br>
-gs/devices/gdevlbp8.c<br>
-gs/devices/gdevlj56.c<br>
-gs/devices/gdevlp8k.c<br>
-gs/devices/gdevlxm.c<br>
-gs/devices/gdevmgr.c<br>
-gs/devices/gdevmiff.c<br>
-gs/devices/gdevn533.c<br>
-gs/devices/gdevo182.c<br>
-gs/devices/gdevokii.c<br>
-gs/devices/gdevpbm.c<br>
-gs/devices/gdevpcx.c<br>
-gs/devices/gdevperm.c<br>
-gs/devices/gdevphex.c<br>
-gs/devices/gdevpjet.c<br>
-gs/devices/gdevplan.c<br>
-gs/devices/gdevplib.c<br>
-gs/devices/gdevpng.c<br>
-gs/devices/gdevpsd.c<br>
-gs/devices/gdevpxut.c<br>
-gs/devices/gdevpxut.h<br>
-gs/devices/gdevrinkj.c<br>
-gs/devices/gdevsgi.c<br>
-gs/devices/gdevsj48.c<br>
-gs/devices/gdevsppr.c<br>
-gs/devices/gdevstc.c<br>
-gs/devices/gdevsunr.c<br>
-gs/devices/gdevtfax.c<br>
-gs/devices/gdevtfnx.c<br>
-gs/devices/gdevtknk.c<br>
-gs/devices/gdevtsep.c<br>
-gs/devices/gdevxcf.c<br>
-gs/devices/vector/gdevlj56.c<br>
-gs/devices/vector/gdevpxut.c<br>
-gs/devices/vector/gdevpxut.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-10 20:24:02 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c947a5c62b9eef2b2b2afcab986a5b7bbb8fc3ad">c947a5c62b9eef2b2b2afcab986a5b7bbb8fc3ad</a>
-<blockquote>
-<p>
- Add BGPrint prn device parameter to render clist pages while parsing.<br>
-<br>
- This enhancement closes the clist files of the page, then starts a<br>
- printing thread (prn_print_page_in_background) to write out the page<br>
- and returns to allow parsing of the next page into a new set of clist<br>
- files while the 'bg printing' thread writes out the data, performing<br>
- compression and other conversion that the BGPrint=false mode performs<br>
- in the main (parsing) thread.<br>
-<br>
- If NumRenderingThreads &gt; 0, the band rendering will also be performed<br>
- for multiple bands in separate threads.<br>
-<br>
- Thus, the parsing of pages after the first will potentially overlap<br>
- the rendering and writing of the previous page. No queue is maintained,<br>
- so the overlap is limited to the next page.<br>
-<br>
- If bg_print.device is not NULL, then we have a page that was rendered<br>
- in the background that we may need to wait for before pprinting the next<br>
- page or exiting. After we call the prn_finish_bg_print, we may need to<br>
- re-open the printer in case it was closed (most commonly due to %d in<br>
- the fname).<br>
-<br>
- When printing in foreground mode, the bg_print.device will be NULL.<br>
-<br>
- Note, We can't use the icc_table created for the foreground since it may<br>
- be in GC'd memory (it must be created with the thread's allocator).<br>
-<br>
- The equivalent_cmyk_colors are needed by the backgorund print device.<br>
- Add .EquivCMYKColors device parameter which is an array of 5 integers per<br>
- spot color. The first integer is 'valid' followed by the 'frac' C, M, Y<br>
- and K values. This allows the gs_putdeviceparams to have the spot color<br>
- information.<br>
-<br>
- The foreground device was relying on the print_page procedure to free<br>
- the separation names from a page before starting the next page. Move<br>
- this to gdev_prn_output_page instead. Also since this is common, we<br>
- don't need it in gdevpsd and gdevtsep print_page functions.<br>
-<br>
- Expected difference when BGPrint=true is 99-01-fixed.PS for all devices<br>
- due to adding the .EquivCMYKColors device parameter.<br>
-<br>
-gs/base/gdevdevn.c<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevprn.h<br>
-gs/base/gxclist.h<br>
-gs/base/gxclpage.c<br>
-gs/base/gxclthrd.c<br>
-gs/base/gxclthrd.h<br>
-gs/base/lib.mak<br>
-gs/devices/gdevplib.c<br>
-gs/devices/gdevpsd.c<br>
-gs/devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-05 10:05: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=a5874589447b76a99eef2114acd12633beed7424">a5874589447b76a99eef2114acd12633beed7424</a>
-<blockquote>
-<p>
- squelch a couple of minor compiler warnings<br>
-<br>
-pcl/pcpatrn.c<br>
-pl/plchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-04 09:13: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=e99c0e5b704954d61bfe5a26c410fdb01a3c48ae">e99c0e5b704954d61bfe5a26c410fdb01a3c48ae</a>
-<blockquote>
-<p>
- Initialise a pointer to non-NULL to silence static analysis warning<br>
-<br>
- The 'dereference of a non-NULL pointer' is incorrect, its not possible to<br>
- reach the questionable de-reference with the pointer NULL but it seems the<br>
- static analyser can't detect that. This should silence it.<br>
-<br>
-gs/devices/vector/gdevpsdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-04 09:11: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=601084bf86031eea15312c27718d13a7beda85a9">601084bf86031eea15312c27718d13a7beda85a9</a>
-<blockquote>
-<p>
- Include a prototype for gs_next)ids to silence a compiler warning<br>
-<br>
-pcl/pcpalet.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-03 10:37: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=a5a841b816c528b6f16a83ec02020db5953dde79">a5a841b816c528b6f16a83ec02020db5953dde79</a>
-<blockquote>
-<p>
- Update CFLAGS for debug build with gcc.<br>
-<br>
- Add debug flags so that as many versions as possible of gcc will include the<br>
- macro expansion data in the debug build.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-03 10:32:16 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7db1a288da4d7838ec801e69f3e2f6bf46598aaa">7db1a288da4d7838ec801e69f3e2f6bf46598aaa</a>
-<blockquote>
-<p>
- Slightly de-macro-fy scfd.c<br>
-<br>
- There were two macros used which were *way* too big for &quot;good practice&quot;<br>
- coding (&quot;get_run&quot; and &quot;invert_data&quot;, and one changed for convenience<br>
- (&quot;skip_data&quot;).<br>
-<br>
- Changing them to functions and testing shows a few seconds penalty for the<br>
- entire test suite - an acceptable trade, IMHO.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/scfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-03 10:19: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=e7de6bf79a5702b79f1960af937955c7f6627e02">e7de6bf79a5702b79f1960af937955c7f6627e02</a>
-<blockquote>
-<p>
- Bug 693940: remove deprecated call from gs/ijs/configure.ac<br>
-<br>
- Thanks to James Cloos for pointing it out.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/ijs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-29 09:02: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=9cd48ce016f8ce490d32679dab5de3cd781f6f85">9cd48ce016f8ce490d32679dab5de3cd781f6f85</a>
-<blockquote>
-<p>
- Add high level pattern support to PCL and HPGL<br>
-<br>
- Unlike the PXL interpreter, but like XPS, the coding has been done in the<br>
- implementation routines rather than at the interpreter level. There are two<br>
- reasons for this; firstly the PCL interpreter already called gx_dev_set_color<br>
- and secondly the HPGL interpreter makes extensive use of macros which weren't<br>
- readily amenable to being altered in a way which would have allowed the<br>
- gs_error_Remap_Color error to be propogated upwards as required.<br>
-<br>
- There are some differences with this commit, they are either very minor or<br>
- progressions (in my opinion).<br>
-<br>
-gs/base/gsptype1.c<br>
-gs/base/gsptype1.h<br>
-pcl/pcdraw.c<br>
-pcl/pcpatrn.c<br>
-pcl/pctop.c<br>
-pcl/pgdraw.c<br>
-pl/plchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-30 11:09: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=1c6f8a9297a2b16c22145a0328734ed137c02215">1c6f8a9297a2b16c22145a0328734ed137c02215</a>
-<blockquote>
-<p>
- pdfwrite - handle Intellifonts as type 3 fonts<br>
-<br>
- In order to deal with high level patterns used as the fill colour for an<br>
- Intellifont, we need to handle Intellifonts as type 3 fonts, just like<br>
- the stick font, and PCL bitmap fonts.<br>
-<br>
- This results in numerous differences; in general text is bolder at<br>
- low resolution, the file 23-15.bin exposes a probable GS bug where the<br>
- glyphs are clipped at higher resolutions.<br>
-<br>
- However, text can now be searched (also copy/paste), and the PDF files are<br>
- potentially smaller due to not having to emit each glyph description every<br>
- time it is used.<br>
-<br>
-gs/devices/vector/gdevpdtd.c<br>
-gs/devices/vector/gdevpdte.c<br>
-gs/devices/vector/gdevpdtf.c<br>
-gs/devices/vector/gdevpdti.c<br>
-gs/devices/vector/gdevpdts.c<br>
-gs/devices/vector/gdevpdtt.c<br>
-gs/devices/vector/gdevpdtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-05-02 09:56:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=437fd175241212c5dad1f045857956f12a588774">437fd175241212c5dad1f045857956f12a588774</a>
-<blockquote>
-<p>
- pdfwrite - fix some compiler warnings introduced with the palette colour fix<br>
-<br>
-pxl/pxgstate.h<br>
-pxl/pxink.c<br>
-pxl/pxpaint.c<br>
-pxl/pxparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-29 17:39: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=1c69af7f3e9830c39eb81961e90691e2ec847342">1c69af7f3e9830c39eb81961e90691e2ec847342</a>
-<blockquote>
-<p>
- pdfwrite - fix buffer overrun in CIDToGIDMap<br>
-<br>
- Bug #693854 &quot;PDFA/2b conversion crashes often&quot;<br>
-<br>
- When converting TrueType fonts into CIDFOnts, because we are creating a PDF/A<br>
- output file, the calculated length of the CIDToGIDMap could be out by one<br>
- as the first CID is 0.<br>
-<br>
- This later led to us writing beyond the end of the buffer, which could cause<br>
- real problems, depending on what was overwritten.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-29 16:18: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=6664f4554a5d63560f94ea99214a9ad289e8e925">6664f4554a5d63560f94ea99214a9ad289e8e925</a>
-<blockquote>
-<p>
- Merge branch 'PCL_palette'<br>
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-26 12:57: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=7086f246fa047bcb9f3e9cfaacfbdae709058b91">7086f246fa047bcb9f3e9cfaacfbdae709058b91</a>
-<blockquote>
-<p>
- Allow devices to inform the PCL interpreter that it must not alter palettes<br>
-<br>
- Bug #692786 &quot;Problem with HPGL paletted colour&quot;<br>
-<br>
- pdfwrite (and potentially other devices) can't cope with situations where the<br>
- interpreter alters the 'palette' (the lookup table in a /Indexed space) after<br>
- the space has been set to be the current color space.<br>
-<br>
- However, if we unilaterally preserve the palette, it seems that this causes<br>
- performance problems (see bug #692786.<br>
-<br>
- Here we add a new special op 'needs_invariant_palette' which allows a device<br>
- to communicate this. We alter the PCL interpreter to inquire the device's<br>
- requirements, and aler pdfwrite to communicate its needs.<br>
-<br>
- This results in &gt; 300 differences with pdfwrite, all of them progressions<br>
-<br>
-gs/base/gdevdflt.c<br>
-gs/base/gxdevsop.h<br>
-gs/devices/vector/gdevpdfi.c<br>
-pcl/pcpalet.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-29 13:01:42 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e4ce3d9147ca6a4f2bdd9a0319b4b7d606492799">e4ce3d9147ca6a4f2bdd9a0319b4b7d606492799</a>
-<blockquote>
-<p>
- pdfwrite - add missing line from last commit<br>
-<br>
-gs/devices/vector/gdevpsdi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-29 11:27:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=efdd46d415d7b117a6c5fcadd7c40facdd0db6af">efdd46d415d7b117a6c5fcadd7c40facdd0db6af</a>
-<blockquote>
-<p>
- pdfwrite - implement bicubic downsampling<br>
-<br>
- Bug #693832 &quot;Implement bicubic image downsampling in pdfwrite&quot;<br>
- Bug #693917 &quot;pdfwrite only downsamples by integer scales&quot;<br>
-<br>
- Adopting the patch from Math supplied in Bug #693832 resolves both<br>
- these problems. No cluster differences as the cluster doesn't test this<br>
- feature.<br>
-<br>
-gs/devices/vector/gdevpsdi.c<br>
-gs/devices/vector/gdevpsds.c<br>
-gs/devices/vector/gdevpsds.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-27 08:18: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=9fac58e19010c5f0772289052082d98f5d89e9a3">9fac58e19010c5f0772289052082d98f5d89e9a3</a>
-<blockquote>
-<p>
- Use &quot;seekable&quot; rather than &quot;positionable&quot;<br>
-<br>
- At Ray's suggestion, tweak the names from the previous commit.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevprn.h<br>
-gs/devices/gdevbmpa.c<br>
-gs/devices/gdevdfax.c<br>
-gs/devices/gdevsgi.c<br>
-gs/devices/gdevtfax.c<br>
-gs/devices/gdevtfnx.c<br>
-gs/devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-25 19:21:36 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8bf1c216211d1bf036369fd731fafd1b30eff168">8bf1c216211d1bf036369fd731fafd1b30eff168</a>
-<blockquote>
-<p>
- Have gdev_prn_open_printer_seekable() work sensibly<br>
-<br>
- If gdev_prn_open_printer_seekable() gets called with the seekable flag set,<br>
- and it can't return a seekable file object, return an error, rather than<br>
- silently ignore the flag.<br>
-<br>
- Add a generic gdev_prn_output_page_positionable() function to replace the one<br>
- that was dedicated to the TIFF devices, and update the TIFF devices and the<br>
- two other devices which require positionable output files to use it.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevprn.h<br>
-gs/devices/gdevdfax.c<br>
-gs/devices/gdevsgi.c<br>
-gs/devices/gdevtfax.c<br>
-gs/devices/gdevtfnx.c<br>
-gs/devices/gdevtifs.c<br>
-gs/devices/gdevtifs.h<br>
-gs/devices/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-25 12:01: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=46d3a7b65de05a0268ce969f8070064bc14913e5">46d3a7b65de05a0268ce969f8070064bc14913e5</a>
-<blockquote>
-<p>
- Bug 693704: Use font name to determine italic-ness<br>
-<br>
- Allow the font name analysis to override the Italic Flags field from the font<br>
- descriptor in determining if a font is italic or oblique.<br>
-<br>
- This results it progressions (when compared to Acrobat, and several other PDF<br>
- readers) in these cluster files:<br>
-<br>
- prfmm.pdf<br>
- CATX2445.pdf<br>
- fts_23_2308.pdf<br>
- 1265_-_portable_collection.pdf<br>
- x_-_Times_New_Roman_wrongly_substituted_regression.pdf<br>
-<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-25 07:48: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=239b3af18363a77785837af64842afe0bc433c67">239b3af18363a77785837af64842afe0bc433c67</a>
-<blockquote>
-<p>
- Small doc updates.<br>
-<br>
- State clearly that the TIFF devices must use a seekable file for output.<br>
-<br>
- Update the description of CropBox - largely paraphrasing the PDFRM.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/doc/Devices.htm<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-24 19:56:45 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=27a54e4b455c4295e5effc8bb6a392b6a44f118c">27a54e4b455c4295e5effc8bb6a392b6a44f118c</a>
-<blockquote>
-<p>
- Bug 693933: Fix division by 0 in monotony check.<br>
-<br>
- Monotony checking procedure caused division by 0 when the start and<br>
- the end points of the interval were the same. Any function on such a<br>
- domain is now considered monotonic.<br>
-<br>
-gs/base/gsfunc3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-24 12:17:54 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ce3ca09ca7e0b489187fc9788aaa795707f17ed1">ce3ca09ca7e0b489187fc9788aaa795707f17ed1</a>
-<blockquote>
-<p>
- Fix broken windows build due to missing #include &quot;stat_.h&quot;<br>
-<br>
-gs/base/gp_mswin.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-24 08:27: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=55bbe8836df1bb8e521a6fb4e79a91d7e0702fb1">55bbe8836df1bb8e521a6fb4e79a91d7e0702fb1</a>
-<blockquote>
-<p>
- Bug 693932 (related): generate meaningful error<br>
-<br>
- Add a gp_fseekable() function, and use it to check the file object opened in<br>
- gdev_prn_open_printer_seekable(). If the file is not seekable, print an error<br>
- message and return an IOerror.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gp.h<br>
-gs/base/gp_mswin.c<br>
-gs/base/gp_os2.c<br>
-gs/base/gp_unifs.c<br>
-gs/base/gp_vms.c<br>
-gs/devices/gdevtifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-22 15:56:11 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e67086e1d63d449900570b30e2b2e1c91ed187a4">e67086e1d63d449900570b30e2b2e1c91ed187a4</a>
-<blockquote>
-<p>
- Initial commit of adding neutral color monitoring<br>
-<br>
- This commit adds in the command line option -dGrayDetection=true/false. When set, the special CMM procedures<br>
- will be inserted to monitor the presence of non-neutral colors. When a non-neutral color is encountered<br>
- no additional monitoring will be preformed. Monitoring is done during the clist writing phase and as such<br>
- high level images are also monitored. CMYK Colors are consider non neutral if C=M=Y=0 (or very close). RGB<br>
- colors are considered neutral if R=G=B or very close and CIELAB colors are considered neutral if a=128 and b=128<br>
- or very close. A fuzzy range can be set for how close we need to be via defines in the code. The<br>
- current values were set based upon using images that were created to be monochrome in Photoshop using ICC<br>
- profiles. Testing for this was performed for a variety of image types. The remaining part of this project,<br>
- which relates to bug number 693583 is to do something useful with the presence of monochrome only data during<br>
- the clist playback phase. The values pageneutralcolor = true and graydetection, which are member variables in<br>
- cmm_dev_profile_t, during clist playback will indicate that the page is neutral. Note that the clist playback<br>
- device should set pageneutralcolor = false during the actual playback to avoid continued monitoring of<br>
- high level image data, which would occur as the data is pushed through the CMM. graydetection is the<br>
- device parameter and as such, pageneutralcolor only has meaning when graydetection = true.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevp14.h<br>
-gs/base/gscms.h<br>
-gs/base/gsdparam.c<br>
-gs/base/gsequivc.c<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_cache.h<br>
-gs/base/gsicc_cms.h<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_monitorcm.c<br>
-gs/base/gsicc_nocm.c<br>
-gs/base/gsicc_replacecm.c<br>
-gs/base/gxclimag.c<br>
-gs/base/gximage.c<br>
-gs/base/gxiparam.h<br>
-gs/base/gxipixel.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-23 00:54:24 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=07abd0c0bbddef1eed84969e9d8b7ba5f548d0d9">07abd0c0bbddef1eed84969e9d8b7ba5f548d0d9</a>
-<blockquote>
-<p>
- Bug 687604: Reject out-of-bounds access to cvt table.<br>
-<br>
- Revert the patch b550e8c460daa0647fd1f4ce63ae3c73edc75a5c because<br>
- it is not needed now, but it causes SEGV when cvt table is missing.<br>
-<br>
-gs/base/ttinterp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-22 21:28:57 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6f51cd7b9d5c2e5185eec30579238bb14863a5e5">6f51cd7b9d5c2e5185eec30579238bb14863a5e5</a>
-<blockquote>
-<p>
- Bug 693930: Accept and ignore null entries in the page tree.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-21 19:20:12 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=11638a77454ace993bf106dab3cd7e182bf1e250">11638a77454ace993bf106dab3cd7e182bf1e250</a>
-<blockquote>
-<p>
- Fix 693836, valgrinds reports read of uninitialized value.<br>
-<br>
- The loop accessed memory past the end of each source line. This did<br>
- not result in an error because we would exit the loop before the data<br>
- was used, but nonetheless it is an invalid read outside the memory<br>
- allocation so we rearrange the loop conditions to avoid it.<br>
-<br>
-gs/base/gdevm24.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-21 11:29:08 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a63c1486c770a810a6cfa24ab397ee3c3c798816">a63c1486c770a810a6cfa24ab397ee3c3c798816</a>
-<blockquote>
-<p>
- Bug 687604: work around another broken TT font<br>
-<br>
- Fallback to rendering unhinted if Freetype returns an Invalid_Reference error.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-19 17:29:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ec87a6d6971f059c4135af3fddd17b34f20c7ae">5ec87a6d6971f059c4135af3fddd17b34f20c7ae</a>
-<blockquote>
-<p>
- pdfwrite - actually assign the structure members to 0<br>
-<br>
-gs/devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-19 14:41:21 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9155d0f3ee7bb9ffc6cb63b21402b5219c7335f2">9155d0f3ee7bb9ffc6cb63b21402b5219c7335f2</a>
-<blockquote>
-<p>
- pdfwrite - initialise some structure members to pacify valgrind<br>
-<br>
- pdf_glyph_widths already sets these to zero, so we only need to bother if<br>
- we aren't using pdf_glyph_widths.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-19 09:35: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=0d3f3ab6ceeaf2b95f9318845bce770cf44efad7">0d3f3ab6ceeaf2b95f9318845bce770cf44efad7</a>
-<blockquote>
-<p>
- Bug 693925: Add some checking for ufst configure option<br>
-<br>
- The two configure scripts now check for the existence of the specified UFST<br>
- directory, and for the existence of fapiufst.mak in that directory.<br>
-<br>
- No cluster differences.<br>
-<br>
-configure.ac<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-19 10:03: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=7e62f84b93a517ac43ebb5d26912a0786b37916e">7e62f84b93a517ac43ebb5d26912a0786b37916e</a>
-<blockquote>
-<p>
- pdfwrite - fix transparency preservation with PDF/A-2<br>
-<br>
- An oversight with the introduction of PDF/A-2 could lead to transparency<br>
- not being preserved, because we tested only the request for PDF/A without<br>
- checking the level required.<br>
-<br>
- No Differences expected, not tested by the cluster.<br>
-<br>
-gs/devices/vector/gdevpdft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-19 00:13:18 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b0ccdcd37d8bf5924bd9572994535c5a1b20169">4b0ccdcd37d8bf5924bd9572994535c5a1b20169</a>
-<blockquote>
-<p>
- Bug 693869: work around errors in dash offset calculation<br>
-<br>
- Make sure that the offsed doesn't exceed the total length of<br>
- the dash pattern. Fix out-of-bounds access and a corresponding<br>
- Valgrind warning.<br>
-<br>
-gs/base/gsline.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-18 11:04:49 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=52d113e470047ea70485de785bc9a3b68731127c">52d113e470047ea70485de785bc9a3b68731127c</a>
-<blockquote>
-<p>
- Fix typo in SVG output device (bug #693922) by Shailesh Mistry.<br>
-<br>
-gs/devices/vector/gdevsvg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-18 09:06: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=f521500bdc2d39ad5f2caf91b3630a1370a08a5f">f521500bdc2d39ad5f2caf91b3630a1370a08a5f</a>
-<blockquote>
-<p>
- Add high level pattern support to the PXL interpreter<br>
-<br>
- Also, fix a possible Seg fault in pdfwrite, which was uncovered by this<br>
- work.<br>
-<br>
- As might be expected this commit does introduce a fairly large number of<br>
- differences in the regression tests. I've looked at them all and I'm happy<br>
- that they are minor differences rather than faults.<br>
-<br>
-gs/devices/vector/gdevpdfb.c<br>
-pxl/pxfont.c<br>
-pxl/pxgstate.c<br>
-pxl/pximage.c<br>
-pxl/pxink.c<br>
-pxl/pxl.mak<br>
-pxl/pxpaint.c<br>
-pxl/pxparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-18 08:34: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=23e6bd304db08011b67b7f45dfcf23885fc0c8a3">23e6bd304db08011b67b7f45dfcf23885fc0c8a3</a>
-<blockquote>
-<p>
- Bug 693921: &quot;refresh&quot; pointer when rendering glyph<br>
-<br>
- Before we call into the gs_fapi_do_char(), refresh the context pointer in the<br>
- FAPI server data - in case the context has been moved by a GC since the font<br>
- was created.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-17 17:46:16 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ece14831a4301dd0291184e1f27729b73d6f350b">ece14831a4301dd0291184e1f27729b73d6f350b</a>
-<blockquote>
-<p>
- Bug 693919: Replace malformed numbers with 0.<br>
-<br>
- Scan BBox elements and replace non-numbers with 0. Our PDF tokenizer<br>
- usually assumes that malformed numerals are names.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-17 14:30:10 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d9a327b4e24043fb153996fdd18a367483d13521">d9a327b4e24043fb153996fdd18a367483d13521</a>
-<blockquote>
-<p>
- Bug 693920: Add missing dereference of an indirect object.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-17 12:29: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=4dfe603dc49aeee09457ea7a0734d7484e0467ea">4dfe603dc49aeee09457ea7a0734d7484e0467ea</a>
-<blockquote>
-<p>
- Add tiff-config directory to .gitignore.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-.gitignore<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-15 19:10: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=b1254130df0da4c311e9761b5784a12c6dad1dc9">b1254130df0da4c311e9761b5784a12c6dad1dc9</a>
-<blockquote>
-<p>
- Have tiff configure run in separate directory.<br>
-<br>
- Run libtiff's configure script in a separate directory to prevent poluting<br>
- libtiff's source directory.<br>
-<br>
- the Ghostscript distclean target has been revised to remove the tiff config<br>
- directory, and the ghostpdl makefile has new distclean and maintainer-clean<br>
- targets.<br>
-<br>
- No cluster differences.<br>
-<br>
-Makefile<br>
-common/msvc_top.mak<br>
-configure.ac<br>
-gs/Makefile.in<br>
-gs/base/gs.mak<br>
-gs/base/lcupsi.mak<br>
-gs/base/tiff.mak<br>
-gs/base/unix-gcc.mak<br>
-gs/base/unixansi.mak<br>
-gs/configure.ac<br>
-gs/psi/msvc.mak<br>
-gs/toolbin/localcluster/clusterpush.pl<br>
-main/pcl6_gcc.mak<br>
-main/pcl6_msvc.mak<br>
-svg/svg_msvc.mak<br>
-xps/xps_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-17 09:23:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c006433024cb996022db86a7e7ec59f103e8efb">1c006433024cb996022db86a7e7ec59f103e8efb</a>
-<blockquote>
-<p>
- Remove the deprecated macos-fw.mak<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/macos-fw.mak<br>
-gs/doc/Develop.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-17 09:24:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=28acb04f77ba58b1507c32d52402e2ff8eaa2e40">28acb04f77ba58b1507c32d52402e2ff8eaa2e40</a>
-<blockquote>
-<p>
- Raise the default VMThreshold from 1Mb to 8Mb<br>
-<br>
- This seems like a fair change based on modern hardware and, in particular<br>
- modern PDF files. In some cases this results in a significant speed<br>
- improvement. It may increase overall memory usage, but testing suggests only<br>
- by an insignificant amount in the vast majority of cases.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zvmem2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-15 09:38: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=407cc61e87b0fd9d44d72ca740af7d3c85dee78d">407cc61e87b0fd9d44d72ca740af7d3c85dee78d</a>
-<blockquote>
-<p>
- &quot;starting_arg_file&quot; should only apply once.<br>
-<br>
- The &quot;starting_arg_file == true&quot; setting should apply to the *first* call to<br>
- lib_file_open() in the context of a given call to runarg(). Previously, it<br>
- remained set for the entire duration of the runarg() call, resulting in the<br>
- current directory being searched for any resource files required by the job.<br>
-<br>
- We also want &quot;starting_arg_file == false&quot; when runarg() is called to execute<br>
- Postscript from a buffer, rather than a file argument.<br>
-<br>
- There is a very small chance this may cause problems with some strange scripts<br>
- or utilities, but I have been unable to prompt such an issue. If one does arise,<br>
- we may have rethink this entirely.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/imainarg.c<br>
-gs/psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-13 23:21:50 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3648ad1d3d1f47df3e4a6e36ff5160e2bff25079">3648ad1d3d1f47df3e4a6e36ff5160e2bff25079</a>
-<blockquote>
-<p>
- Remove spurious address-of operator.<br>
-<br>
-gs/base/gscscie.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-13 01:36:44 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ed31bf693b457ecd13cfa4fc67f12288241448ce">ed31bf693b457ecd13cfa4fc67f12288241448ce</a>
-<blockquote>
-<p>
- Bug 691389: Pacify Valgrind; zero image flip buffer.<br>
-<br>
- When the image has less than 8 scanlines, flipping includes the wild<br>
- end of the buffer and causes warnings in memflip8x8().<br>
-<br>
-gs/base/gxifast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-10 20:13:05 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd414f3582ef95a3b0fd941e62370053126cba5c">cd414f3582ef95a3b0fd941e62370053126cba5c</a>
-<blockquote>
-<p>
- Avoid potential out of bounds memory accesses<br>
-<br>
- In image_render_mono we have code that skips forwards multiple<br>
- pixels at a time without checking for hitting the end of the<br>
- buffer. Fix that here.<br>
-<br>
-gs/base/gximono.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-24 11:23: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=ecc7a199e9307475c37fea0c44d24b85df814ead">ecc7a199e9307475c37fea0c44d24b85df814ead</a>
-<blockquote>
-<p>
- Bug 693488: Improved glyph name aliasing.<br>
-<br>
- Implement a more flexible approach to glyph name aliasing which handles all the<br>
- names in the Adobe Glyph List.<br>
-<br>
- Thanks to John Wehle ( john@feith.com ) for this implementation.<br>
-<br>
- For the time being, you can use &quot;-dUSEOLDGLYPHALIASING&quot; to revert to the old<br>
- code - assuming all goes well, that option will be removed for the release<br>
- following 9.09.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_ttf.ps<br>
-gs/Resource/Init/gs_type1.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-11 17:22: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=4c27c7d63acbf4500eab8d056541535ed5010b5c">4c27c7d63acbf4500eab8d056541535ed5010b5c</a>
-<blockquote>
-<p>
- ps2write - do not emit CIEBased spaces as ICCBased for PostScript<br>
-<br>
- This was an oversight when I was trying to preserve CIEBased colour spaces,<br>
- it turns out that its not possible to preserve them, and I accidentally left<br>
- the code emitting them as ICCBased, which doesn't work in PostScript.<br>
-<br>
- We now fall back to the old approach, in future we hope to use LCMS2 to<br>
- create a CIEBased space from the ICCBased profile for us.<br>
-<br>
- No differences expected, code not enabled by default<br>
-<br>
-gs/devices/vector/gdevpdfc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-02 12:26: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=9ff3e23fcf1c73e83e4bbb797b9033c7a25bf255">9ff3e23fcf1c73e83e4bbb797b9033c7a25bf255</a>
-<blockquote>
-<p>
- Bug 693804: (valgrind) initialize gs_fapi_raster<br>
-<br>
- It's easiest to set the entire struct to zeros, since we need to initalize<br>
- nearly the entire structure anyway, before passing to the scaler/renderer.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/base/gxfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-02 17:23:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=55c01c51ac53d244affde7b683f1f4cff24bcc46">55c01c51ac53d244affde7b683f1f4cff24bcc46</a>
-<blockquote>
-<p>
- Bug 693785: (valgrind) make gx_hld_saved_color_equal() do explicit checks<br>
-<br>
- gx_hld_saved_color_equal() originally did a simple memcmp(), but due to padding<br>
- and GC considerations, that isn't reliable, so it needs to compare the contents<br>
- of the structure explicitly.<br>
-<br>
- This does cause some differences in the PCL cluster tests with pdfwrite.<br>
-<br>
-gs/base/gxhldevc.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-03 16:42:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=312d3c7655e2484e27160478e3120796cf9bbe10">312d3c7655e2484e27160478e3120796cf9bbe10</a>
-<blockquote>
-<p>
- Bug 693736: (valgrind) rejig a call to a function pointer<br>
-<br>
- This is just a rejig to a functionally equivalent form that valgrind seems happier with.<br>
-<br>
- It makes no real difference, but reduces the valgrind &quot;noise&quot; at no expense.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/igc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-10 16:11:05 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d73d2d365efc7331bf1dbfe70e427e8ead829778">d73d2d365efc7331bf1dbfe70e427e8ead829778</a>
-<blockquote>
-<p>
- Bug 693738: Trap bit run search<br>
-<br>
- Fix a valgrind warning. Create a termination zone filled with<br>
- alternating bit pattern to guarantee that a search for a bit run<br>
- ends within the termination zone.<br>
-<br>
-gs/base/scfd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-08 22:42:24 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a3225b70cb1b92ca0f657d99b3bc496e6046fc39">a3225b70cb1b92ca0f657d99b3bc496e6046fc39</a>
-<blockquote>
-<p>
- Fix valgrind issue, bug 693735. image_render_mono condition using UMR.<br>
-<br>
- The psrc scanning loop did not stop at the end of the data in some<br>
- cases. Since data past the image would tend to be variable, this<br>
- would usually stop scanning fairly soon and the 'fit_' macro logic<br>
- in fill/copy routines would make sure to limit the painting to a<br>
- valid area. Strange that this didn't show up in image artifacts.<br>
-<br>
-gs/base/gximono.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-10 00:56:15 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=897c36aa8cd754448bab5b712e48d46e2b117478">897c36aa8cd754448bab5b712e48d46e2b117478</a>
-<blockquote>
-<p>
- Bug 693798: Fix buffer overrun.<br>
-<br>
- When jbig2dec detects that a run of pixels exceeds the image width,<br>
- it clamps the beginning and end of the run to the image width+1.<br>
- Probably, this is done to make runs that are entirely outside of the<br>
- image to leave no marks. This patch adds 1 byte to the image<br>
- buffer to ensure that writing 1 byte beyond the image line is valid.<br>
-<br>
-gs/jbig2dec/jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-09 15:15: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=5f5524b1f2ab76aff70b2b4a896b9474bdfb9501">5f5524b1f2ab76aff70b2b4a896b9474bdfb9501</a>
-<blockquote>
-<p>
- pdfwrite - prevent rounding errors in TrueType widths<br>
-<br>
- See Bug #693825<br>
-<br>
- Rounding errors converting TrueType widths into PostScript/PDF led to us<br>
- emitting lots of tiny glyph movements. These were visually imperceptible<br>
- but led to larger than necessary output, because of all the tiny shifts.<br>
-<br>
- This commit fixes the widths from TrueType fonts to the nearest integer<br>
- which makes it much more likely they will match the entries in the /W or<br>
- /Widths arrays, and thus not result in tiny movements.<br>
-<br>
- The file in Bug #698325 is 5% smaller with this change, and the output PDF<br>
- file does actually match the original more closely (when using a high zoom<br>
- factor and careful inspection)<br>
-<br>
- This does (unsurprisingly) cause a lot of differences in the test suite,<br>
- but I've looked at all of them and can see no definite problems. The<br>
- differences are pretty much single pixel shifts and this can sometimes<br>
- cause low resolution output to be slightly better, or slightly worse.<br>
-<br>
-gs/devices/vector/gdevpdte.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-09 08:33: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=f7567c53867f01e9dd33a1f882bb489dc765b869">f7567c53867f01e9dd33a1f882bb489dc765b869</a>
-<blockquote>
-<p>
- pdfwrite - correct tracking of current point with word spcaing<br>
-<br>
- Bug #693285 &quot;gs adds spaces and breaks formatting of original pdf file&quot;<br>
-<br>
- This one is quite subtle and caused by a number of interacting issues.<br>
-<br>
- Firstly the design grid conversion of TrueType fonts can lead to TT CIDFonts<br>
- ending up with very slightly different widths from the font to the widths in<br>
- the /W array (rounding errors). When emitting text we then use the TJ operator<br>
- and emit tiny movements for each glyph.<br>
-<br>
- The second part then, is the limit we have of 50 movements per TJ operation.<br>
- There's no indication why we have this limit but I assume its some ancient<br>
- version of Acrobat. When we get to 50 moves we close the current line of text<br>
- and begin a new one.<br>
-<br>
- The third part is that, in order to start the new line from the correct x offset<br>
- (so it lines up properly with the previous line), we keep a running track of<br>
- the current position and use that to tell us where to start the new line.<br>
- This value was getting the word spacing value applied to it whenever the<br>
- current character was a space (0x20). However, we only apply the word spacing<br>
- to *single* byte encodings in PDF (unlike PostScript) and the font in this<br>
- particular file doesn't have a single byte range.<br>
-<br>
- To fix this we need to know if the text came from a (a)widthshow operation<br>
- from PDF, or from PostScript. Fortunately the text enumerator already has<br>
- a 'single_byte_space' member which tells us this. If it was from PDF we then<br>
- need to check if the character encoded used 1 byte or more than one, and<br>
- not apply the word spacing if it used more than 1. To this end we now pass<br>
- in the number of bytes to process_text_modify_width.<br>
-<br>
- This change exhibits progressions in fts_20_2001.pdf and fts_22_2202.pdf<br>
-<br>
-gs/devices/vector/gdevpdtc.c<br>
-gs/devices/vector/gdevpdte.c<br>
-gs/devices/vector/gdevpdtt.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-09 09:12:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=496d8d3b8ea3d560dc260b1d03d9ed45b38e6960">496d8d3b8ea3d560dc260b1d03d9ed45b38e6960</a>
-<blockquote>
-<p>
- Bug 693842: Fix a typo in gp_vms.c<br>
-<br>
- There was a &quot;=&quot; instead of &quot;==&quot; mistake in the file name validation code.<br>
-<br>
- Thanks to jond666@hotmail.com for pointing it out.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gp_vms.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-09 09:05: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=17bc8825debb794fc83f832b96da1ef9eead6aa4">17bc8825debb794fc83f832b96da1ef9eead6aa4</a>
-<blockquote>
-<p>
- Bug 693846: Fix configure inclusion of gdevjbig2.dev<br>
-<br>
- There was an error in the configure so that we ended up using &quot;jbig2.dev&quot; in<br>
- both the FEATURE_DEVS and DEVICE_DEVS lists.<br>
-<br>
- It now, correctly, uses gdevjbig2.dev in the DEVICE_DEVS list.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-05 12:24: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=a4ae7c831da7e113665ae53e02b215c62bc3dbbd">a4ae7c831da7e113665ae53e02b215c62bc3dbbd</a>
-<blockquote>
-<p>
- Fix 693841, the symbol set parameter could be read uninitialized.<br>
-<br>
-pxl/pxfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-05 09:52:35 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=002551b7baa1e6e0a10670672d34870c3e229925">002551b7baa1e6e0a10670672d34870c3e229925</a>
-<blockquote>
-<p>
- Read the old page size from the device, not from PCL's state.<br>
-<br>
- The current paper selecting design could already have the new<br>
- requested page size in PCL's state at this point in the code; it was<br>
- possible to miss selecting a new paper size even though there was a<br>
- paper size change.<br>
-<br>
-pcl/pcpage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-05 09:48:36 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c77af98a0ff3d54ce52fb043149cef0a1b83e311">c77af98a0ff3d54ce52fb043149cef0a1b83e311</a>
-<blockquote>
-<p>
- More lenient interpretation of the PJL language variable.<br>
-<br>
- Accept any language variable string that contains the substring &quot;GL&quot;<br>
- to indicate the job should be processed in RTL/HPGL-2 mode.<br>
-<br>
-pcl/pctop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-05 09:46: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=2892a755b3cc1e56f859046154f249afde1dcca0">2892a755b3cc1e56f859046154f249afde1dcca0</a>
-<blockquote>
-<p>
- Initialize PCL completely before XL Passthrough.<br>
-<br>
-pxl/pxpthr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-02 17:12:04 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=86c33715ecf80e58ae4bde341820a6c76b23c288">86c33715ecf80e58ae4bde341820a6c76b23c288</a>
-<blockquote>
-<p>
- Fix memory corruption problem with HPGL/2 page sizes.<br>
-<br>
- Setting a page size in the HPGL/2 code depended on memory in a local<br>
- stack frame. This problem was introduced when custom page size<br>
- support was added to PCL which resulted in reorganizing the paper type<br>
- set up. Unfortunately HPGL/2 - RTL mode was not updated to use the<br>
- new paper setup when the PCL change was made.<br>
-<br>
-pcl/pcpage.c<br>
-pcl/pcpage.h<br>
-pcl/pgconfig.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-04 15:47:47 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=87b4d9c7abb36040079e099600cd31a5917be31d">87b4d9c7abb36040079e099600cd31a5917be31d</a>
-<blockquote>
-<p>
- Remove unneeded tests from ENABLE_VALGRIND macros.<br>
-<br>
- Now gs_alloc_fill is called correctly, I can back out these extra<br>
- tests.<br>
-<br>
-gs/base/gsmdebug.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-04 15:17:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=673511c63137ff5cf5dddcacd7ff5f1cc9f42fd3">673511c63137ff5cf5dddcacd7ff5f1cc9f42fd3</a>
-<blockquote>
-<p>
- Correct a mistake in the memory alloc header code.<br>
-<br>
- In the -Z@ case, I had left offsets in place for filling freed memory in<br>
- i_resize_string() which could cause gs_alloc_fill() to be called with a<br>
- negative length.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-04 01:12:45 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=773c42ffc7e1e96c0bd99c7f577090c8b0684577">773c42ffc7e1e96c0bd99c7f577090c8b0684577</a>
-<blockquote>
-<p>
- Fix ENABLE_VALGRIND problems.<br>
-<br>
- gs_alloc_fill was having a bad interaction with<br>
- VALGRIND_MAKE_MEM_UNDEFINED in corner cases.<br>
-<br>
-gs/base/gsmdebug.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-02 14:45:20 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e9a498db41d0d601ab736687d332b2ab3de2a54">2e9a498db41d0d601ab736687d332b2ab3de2a54</a>
-<blockquote>
-<p>
- Add valgrind.h dependencies to lib.mak to avoid warnings.<br>
-<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-28 07:53: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=5403b7384b203c6b462f8ed3190b7962c929769c">5403b7384b203c6b462f8ed3190b7962c929769c</a>
-<blockquote>
-<p>
- Add an ID to memory allocations.<br>
-<br>
- This is to aid following objects through GC.<br>
-<br>
- This is fairly straight forward with gs_struct_.... type allocations where<br>
- there is a memory manager header structure associated with the allocation,<br>
- so the ID is added to that.<br>
-<br>
- But so called &quot;string&quot; allocations (i_alloc_string() and co) are more tricky<br>
- because these have no header, so these have the ID &quot;tacked on&quot; at the beginning<br>
- of the memory allocation. This means that the memory manager and the garbage<br>
- collector need to &quot;just know&quot; that the extra bytes exist.<br>
-<br>
- The assigning and incrementing of the ID variable (normally) on happen in a<br>
- debug build. The ID variable itself can be left out by adding:<br>
- -DGS_USE_MEMORY_HEADER_ID=0<br>
-<br>
- (or equivalent) to the compiler command line.<br>
-<br>
- Finally, in a debug build, there is a get_mem_hdr_id() convenience function<br>
- you can call from a debugger - it takes a pointer to block of memory, and<br>
- returns the ID assigned to the allocation. Obviously, if the function is called<br>
- on memory automatically allocaed on the stack, it will probably cause bad<br>
- things to happen.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsalloc.c<br>
-gs/base/gxobj.h<br>
-gs/psi/igcstr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-02 03:47:24 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=693c516ad22bb79d7c8c85329ff6a53dc82505fc">693c516ad22bb79d7c8c85329ff6a53dc82505fc</a>
-<blockquote>
-<p>
- Memento: Improve interaction with valgrind.<br>
-<br>
- Ensure that blocks headers are correctly marked accessible/<br>
- unaccessible.<br>
-<br>
-gs/base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-02 11:14: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=b0264dc9764935e548042597ca5d3c08bc513d31">b0264dc9764935e548042597ca5d3c08bc513d31</a>
-<blockquote>
-<p>
- pdfwrite - initialise a return code<br>
-<br>
- Spotted by scan-build, the return code is uninitialised when both stream<br>
- and dictionary have previously been hashed. This would not normally cause a<br>
- problem, but its best to be safe.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-01 16:57:37 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9182dfdce82310e96fbb7b92759dcc913e0f6a2e">9182dfdce82310e96fbb7b92759dcc913e0f6a2e</a>
-<blockquote>
-<p>
- Update valgrind.h to include helgrind header too.<br>
-<br>
- Cope with the version of helgrind being too old that it doesn't<br>
- provide the required macros and causes missing symbol errors.<br>
-<br>
-gs/base/gsinit.c<br>
-gs/base/gxclfile.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclmem.c<br>
-gs/base/valgrind.h<br>
-gs/psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-01 10:32:28 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e4883fdd27201e35b93e9fbdbe5d1f2380a030b">4e4883fdd27201e35b93e9fbdbe5d1f2380a030b</a>
-<blockquote>
-<p>
- Memory squeezing: Unchecked error codes.<br>
-<br>
- Fix unchecked error codes in gs_output_page.<br>
-<br>
-gs/base/gsdevice.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-01 09:51:40 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=952405f72db6ba9f706e75f7cbf66193a575ec98">952405f72db6ba9f706e75f7cbf66193a575ec98</a>
-<blockquote>
-<p>
- Bug 693824: Valgrind problems in interpolated images.<br>
-<br>
- The first of the valgrind problems reported here is a false<br>
- positive; when scaling just a subsection of an image we<br>
- scale extra 'support' pixels. Due to the way this works we<br>
- end up scaling a few extra lines/columns around the rectangle<br>
- we actually need. Some of the input values to these extra<br>
- lines are not copied in, hence we see valgrind complaining<br>
- about uninitialised values.<br>
-<br>
- We fix this with some PACIFY_VALGRIND code to memset the<br>
- input buffers to 0.<br>
-<br>
- This commit also fixes valgrind errors seen later due to<br>
- us trying to color convert color values outside of the<br>
- active region; we fix this by restricting the area we<br>
- color convert. This will give speedups in some cases.<br>
-<br>
-gs/base/gxiscale.c<br>
-gs/base/siscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-01 08:31:11 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=07c3453ee6545e660fe1f7215b0ba5f540b7cd7b">07c3453ee6545e660fe1f7215b0ba5f540b7cd7b</a>
-<blockquote>
-<p>
- Change ownership of JBIG2 to Alex.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-doc/who_owns_what.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-04-01 06:20:14 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=050745afeddbaf506ab4dd92661d583ba6e3eb06">050745afeddbaf506ab4dd92661d583ba6e3eb06</a>
-<blockquote>
-<p>
- Valgrind: Fix spurious warnings in gc<br>
-<br>
- The Ghostscript object headers have a union of bitfields; these are<br>
- arranged so that they are all of the form 1 bit, then n-1 bits<br>
- (where n is a power of 2), so they pad nicely to a nice size.<br>
-<br>
- Specifically they are designed to work like this (as far as I can<br>
- make out) to allow the 'alone' bit to be preserved during gcs<br>
- when the n-1 bit fields are used. Valgrind, I think, finds this<br>
- problematic.<br>
-<br>
- The fix in this commit is simply to initialise both the alone bit<br>
- and the padding bits at the same time (any even halfway decent<br>
- compiler should combine these into a single byte write, so we<br>
- should actually find this new safer code is faster than the previous<br>
- single bit initing code). This is safe because the other unions<br>
- are only used during gc.<br>
-<br>
- Cluster testing shows no differences, and local valgrind runs<br>
- appear cleaner.<br>
-<br>
-gs/base/gsalloc.c<br>
-gs/base/gxobj.h<br>
-gs/psi/igcref.c<br>
-gs/psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-31 04:07:53 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b319291a7a57de7344122269ae56deb65121de60">b319291a7a57de7344122269ae56deb65121de60</a>
-<blockquote>
-<p>
- Memory squeezing fix: zsave: Fix SEGV<br>
-<br>
- When freeing saved spaces due to an allocation failure, unlink the<br>
- space from the linked list of saved ones to prevent gc SEGV later.<br>
-<br>
-gs/psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-30 04:26:01 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fe31fceb7870b24bcf9c5b477f76943abacce75f">fe31fceb7870b24bcf9c5b477f76943abacce75f</a>
-<blockquote>
-<p>
- Memory Squeezing: crash in gc after zsave.<br>
-<br>
- Ensure that the save structure is set up enough to be safely gc'd<br>
- on allocation.<br>
-<br>
-gs/psi/isave.c<br>
-gs/psi/zvmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-30 03:34:04 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d88779e3579db3c9c134ec7c5ee54e7ab4579399">d88779e3579db3c9c134ec7c5ee54e7ab4579399</a>
-<blockquote>
-<p>
- Memory Squeezing: gsicc_manage.c: Check for allocation failures<br>
-<br>
- In faviour places we allocate pname, and then use it without<br>
- checking. Simply add checks.<br>
-<br>
-gs/base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-30 09:26:53 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=97d4e9f31bb0f5d1f8feb97106fc5879bb9a4fcb">97d4e9f31bb0f5d1f8feb97106fc5879bb9a4fcb</a>
-<blockquote>
-<p>
- pdfwrite - ensure a variable is initialised<br>
-<br>
- I can't see a way that this could cause the valgrind complaint in bug<br>
- #693813, but its the only variable in the offending line which is not<br>
- explicitly initialised. So initialise it here just in case.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-29 17:43:14 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f23d8aca44eee8ab1e289b350c968b074b8bec76">f23d8aca44eee8ab1e289b350c968b074b8bec76</a>
-<blockquote>
-<p>
- Memory Squeezing: JPEG compression; avoid double free.<br>
-<br>
- The JPEG compression stream state calls gs_jpeg_destroy, but this may be<br>
- called earlier. If this does get called earlier, ensure that we leave the<br>
- stream in a state where it won't access freed memory.<br>
-<br>
-gs/devices/vector/gdevpsdu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-29 14:16:38 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=852e5451e741515551edd55916a3cf49a5a2540e">852e5451e741515551edd55916a3cf49a5a2540e</a>
-<blockquote>
-<p>
- Fix bug 693576 - bad pxl file generated.<br>
-<br>
- It was possible for the XL driver to produce XL drawing commands<br>
- without setting the color space in advance. Thanks to Hin-Tak Leung<br>
- for the fix.<br>
-<br>
-gs/devices/vector/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-29 11:46:35 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=00ccf0ce1304f3f6a9493138f2fb0cb00f3326f9">00ccf0ce1304f3f6a9493138f2fb0cb00f3326f9</a>
-<blockquote>
-<p>
- Memory squeezing: JPEG encoding stream release<br>
-<br>
- When destroying a JPEG encoding stream, we assume that the setup got<br>
- far enough to have allocated a jmpbuf and a compression struct. Add<br>
- some checks so we cope if this is not the case.<br>
-<br>
-gs/base/sdcte.c<br>
-gs/base/sjpegc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-29 11:14:29 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a68c6641b8b576c88c497d8089b17bc7ec32d383">a68c6641b8b576c88c497d8089b17bc7ec32d383</a>
-<blockquote>
-<p>
- Memory squeezing: LCMS2: BuildGrayInputMatrixPipeline leak<br>
-<br>
- Avoid leak in allocation failure case.<br>
-<br>
-gs/lcms2/src/cmsio1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-29 09:31:07 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=31f437e09d443e1f1ae78f4f909728b45d550695">31f437e09d443e1f1ae78f4f909728b45d550695</a>
-<blockquote>
-<p>
- Memory Squeezing: LCMS2: CLUTElemDup<br>
-<br>
- Check for allocation failures and tidy up if found.<br>
-<br>
-gs/lcms2/src/cmslut.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-29 10:01:18 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ebf32c26d8224ab7c81766c0d516986fd1ce4027">ebf32c26d8224ab7c81766c0d516986fd1ce4027</a>
-<blockquote>
-<p>
- Fix more gnu indent unwanted side effects.<br>
-<br>
- We still have a bit more to do but this fixes the most egregious<br>
- problems.<br>
-<br>
-pcl/pccsbase.c<br>
-pcl/pcht.c<br>
-pcl/pcstatus.c<br>
-pcl/pcsymbol.c<br>
-pcl/pcsymbol.h<br>
-pcl/pctext.c<br>
-pcl/pctop.c<br>
-pcl/pgchar.c<br>
-pcl/pgcolor.c<br>
-pcl/pgconfig.c<br>
-pcl/pgframe.c<br>
-pcl/pggeom.c<br>
-pcl/pglabel.c<br>
-pcl/pglfill.c<br>
-pcl/pgparse.c<br>
-pcl/pgpoly.c<br>
-pcl/pgvector.c<br>
-pcl/rtmisc.c<br>
-pcl/rtrstcmp.c<br>
-pl/pjparse.c<br>
-pl/pjparsei.c<br>
-pl/plftable.h<br>
-pl/plmain.c<br>
-pl/plplatfps.c<br>
-pl/pltop.c<br>
-pxl/pxerrors.c<br>
-pxl/pxfont.c<br>
-pxl/pxgstate.c<br>
-pxl/pxparse.c<br>
-pxl/pxptable.c<br>
-pxl/pxsessio.c<br>
-pxl/pxstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-29 08:29:31 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0250740ec53e8df3f2fcfd96a725574996256524">0250740ec53e8df3f2fcfd96a725574996256524</a>
-<blockquote>
-<p>
- Memory squeezing fix: LCMS2: avoid AllocateToneCurveStruct returning partial built struct.<br>
-<br>
- Simply add an extra check on the last allocation.<br>
-<br>
-gs/lcms2/src/cmsgamma.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-29 08:22:34 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=321c5a324977410d7fac84be174453460a3210a9">321c5a324977410d7fac84be174453460a3210a9</a>
-<blockquote>
-<p>
- Memory squeezing: More LCMS2 fixes.<br>
-<br>
- Fix some broken error code, add some checking where it was missing, and<br>
- fix a potential leak.<br>
-<br>
-gs/lcms2/src/cmscnvrt.c<br>
-gs/lcms2/src/cmslut.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-29 12:43:33 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=44f807320c741d07a38bc565752160ecb8c6f71b">44f807320c741d07a38bc565752160ecb8c6f71b</a>
-<blockquote>
-<p>
- Memory squeezing fix: lcms2 cmsPipeline construction<br>
-<br>
- When creating a new pipeline, lcms would often try to allocate a stage<br>
- and pass it to cmsPipelineInsertStage without checking whether the<br>
- allocation succeeded. cmsPipelineInsertStage would then assert (or crash)<br>
- if it had not.<br>
-<br>
- The fix here is to change cmsPipelineInsertStage to check and return<br>
- an error value. All calling code is then checked to test this return<br>
- value and cope.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-gs/lcms2/include/lcms2.h<br>
-gs/lcms2/src/cmscnvrt.c<br>
-gs/lcms2/src/cmsgmt.c<br>
-gs/lcms2/src/cmsio1.c<br>
-gs/lcms2/src/cmslut.c<br>
-gs/lcms2/src/cmsopt.c<br>
-gs/lcms2/src/cmstypes.c<br>
-gs/lcms2/src/cmsvirt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-29 10:23:50 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8591cc53337147e77e4249a007df12cd17319d08">8591cc53337147e77e4249a007df12cd17319d08</a>
-<blockquote>
-<p>
- pdfwrite - initialise structure member 'stream_md5_valid<br>
-<br>
- Bugs #693759, #693760, #693761<br>
-<br>
- Found by valgrind, there were conditions under which the member would not<br>
- be initialised before we tested it, initialising it to 0 ensures this can't<br>
- happen.<br>
-<br>
- In practice this is unlikely to ever cause a problem, but its best to be safe<br>
- as we could conceivably attempt to access invalid memory locations if this<br>
- member isn't initialised.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-28 17:51:17 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1ef00832581e1167dd3fd33ab499bcd1d895b218">1ef00832581e1167dd3fd33ab499bcd1d895b218</a>
-<blockquote>
-<p>
- Memory squeezing bug: lcms2 MatrixElemTypeFree<br>
-<br>
- Destructors should cope with NULL.<br>
-<br>
-gs/lcms2/src/cmslut.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-28 17:26:36 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=47d384ef4ef6a57b346a05f320a06b08309ed2d9">47d384ef4ef6a57b346a05f320a06b08309ed2d9</a>
-<blockquote>
-<p>
- Memory squeezing fix: gsicc_get_link_profile<br>
-<br>
- Check the return from gsicc_get_profile_handle_buffer for validity<br>
- before using it.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-28 17:18:11 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3dc5a28f2c7fc587f4207a593d2aa32d9565d4c9">3dc5a28f2c7fc587f4207a593d2aa32d9565d4c9</a>
-<blockquote>
-<p>
- Memory squeezing fix: gsicc_alloc_link<br>
-<br>
- Ensure that the gsicc_link_t has a valid wait pointer so that its<br>
- destructor can work safely in the event of the wait semaphore failing<br>
- to allocate.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-28 21:12:18 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1d518660381c8cec7f603ef05eea85e1d683817">b1d518660381c8cec7f603ef05eea85e1d683817</a>
-<blockquote>
-<p>
- Another memory squeeze fix.<br>
-<br>
- Avoid SEGV in gsicc_alloc_link_entry and callers.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_nocm.c<br>
-gs/base/gsicc_replacecm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-28 14:25: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=c8e63f3b0096aac611da379b57590dca9c549aca">c8e63f3b0096aac611da379b57590dca9c549aca</a>
-<blockquote>
-<p>
- Fix 693730, portion of output missing resulting from type overflow.<br>
-<br>
- PCL was storing image's source width and height in unsigned short<br>
- integers which is not sufficient for very large HPGL/RTL plots.<br>
-<br>
-pcl/rtraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-28 19:42:34 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=865db37918a99bdaea8825cb1173389c6541b318">865db37918a99bdaea8825cb1173389c6541b318</a>
-<blockquote>
-<p>
- Another memory squeezing fix.<br>
-<br>
- Check allocations for failures. Free objects in the cleanup path.<br>
-<br>
-gs/base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-28 19:16:56 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=045235372355a640bdf637a6065bfc8597e00b8e">045235372355a640bdf637a6065bfc8597e00b8e</a>
-<blockquote>
-<p>
- More memory squeezing fixes.<br>
-<br>
- Fix unchecked allocations, and ensure functions are capable of<br>
- distinguishing failed allocations from failing to finish normally<br>
- for some other reason.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-28 17:26:44 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fd3220b62484c434a7c64a4f1382a0d05c82c664">fd3220b62484c434a7c64a4f1382a0d05c82c664</a>
-<blockquote>
-<p>
- Memory squeezing fixes.<br>
-<br>
- Unchecked allocations and return codes in the parameter handling.<br>
-<br>
-gs/base/gsdparam.c<br>
-gs/base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-28 13:53:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=120c7069563bc01b5d23d2632803607248c5fca4">120c7069563bc01b5d23d2632803607248c5fca4</a>
-<blockquote>
-<p>
- pdfwrite fix previous commit<br>
-<br>
- Commit 0069ae367e670a80b35d9d333c99acd71dc94108 had a 'typo' and used<br>
- the wrong member of a structure to append a hash. Because the member was<br>
- too small this caused memory corruption and later crashes.<br>
-<br>
- Of course this only exhibits with the same hand-crafted test file....<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-28 13:09:11 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0069ae367e670a80b35d9d333c99acd71dc94108">0069ae367e670a80b35d9d333c99acd71dc94108</a>
-<blockquote>
-<p>
- pdfwrite - fix stream MD5 hashing<br>
-<br>
- Objects in pdfwrite use an MD5 hash to check for equality. The hash is lazily<br>
- created, and stored for later reuse.<br>
-<br>
- The stream object hashing wasn't adding the hash of the dictionary associated<br>
- with the stream to the hash of the stream contents. This meant that 2 streams<br>
- with the same data, but different associated dictionaries, could be wrongly<br>
- identified as equal.<br>
-<br>
- In practice this condition is likely to be extremely rare, it was detected<br>
- while working on the colour code and was caused by using a hand-crafted<br>
- PostScript file which reused many components when constructing multiple<br>
- colour spaces.<br>
-<br>
- No differences expected<br>
-<br>
-gs/devices/vector/gdevpdfo.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-27 17:34:41 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e58a662c5eaa811eafa512e9cc97ae5e1303351">0e58a662c5eaa811eafa512e9cc97ae5e1303351</a>
-<blockquote>
-<p>
- Add non-redudannt (nr) option to clusterpush.pl<br>
-<br>
-gs/toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-27 16:34:39 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=76f9208424f41e4177cda4a468af1b0bb6a5e166">76f9208424f41e4177cda4a468af1b0bb6a5e166</a>
-<blockquote>
-<p>
- Preliminary parsing code for the PXL VendorUnique operator.<br>
-<br>
- Some lower end HP color laser printers use an undocumented diminutive<br>
- PXL-like language based on the VendorUnique operator. This commit<br>
- fleshes out enough of the parsing to get through the PXL in the test<br>
- file attached to 693661 without a syntax error. We've not done<br>
- anything to implement VendorUnique commands beyond parsing.<br>
-<br>
-gs/base/gdevpxat.h<br>
-pxl/pxparse.c<br>
-pxl/pxptable.c<br>
-pxl/pxsessio.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-27 20:48:31 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5f148d93b1c954f28fead816acb5fe7131797cf4">5f148d93b1c954f28fead816acb5fe7131797cf4</a>
-<blockquote>
-<p>
- Memory squeezing fix<br>
-<br>
- If ialloc_init fails part way through, we attempt to free the allocated<br>
- objects, but we do so incorrectly as the object we get passed back is<br>
- actually internal to the allocation that was made (and there were actually<br>
- multiple allocations).<br>
-<br>
- We add a function to do this properly, together with a stern warning<br>
- that this should only be used for allocation error cleanup.<br>
-<br>
-gs/base/gsalloc.c<br>
-gs/base/gsalloc.h<br>
-gs/psi/ialloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-27 09:20:42 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3f07b338211b112f8af3e95dcff87269e770a311">3f07b338211b112f8af3e95dcff87269e770a311</a>
-<blockquote>
-<p>
- Another memory squeeze fix.<br>
-<br>
- Ensure enumerator is initialised enough to survive gc in case<br>
- of later failures.<br>
-<br>
-gs/base/gp_unifs.c<br>
-gs/psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-27 14:46:06 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2ed2393f5a82952ba92e543a43cb39dd44c3050b">2ed2393f5a82952ba92e543a43cb39dd44c3050b</a>
-<blockquote>
-<p>
- Memory squeezing fix<br>
-<br>
- Check for allocation failure.<br>
-<br>
-gs/psi/zcontext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-27 14:34:33 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6f7940e28090a0f4c850e7adad4554c79fb01fb8">6f7940e28090a0f4c850e7adad4554c79fb01fb8</a>
-<blockquote>
-<p>
- More memory squeezing fixes<br>
-<br>
- Clear allocated structures so they can be destructed safely in the<br>
- event of later failures.<br>
-<br>
-gs/base/gsfont.c<br>
-gs/base/gxccman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-27 14:07: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=0466008b327a5b16a051e234e4725ebfa84912f6">0466008b327a5b16a051e234e4725ebfa84912f6</a>
-<blockquote>
-<p>
- Another memory squeezing problem.<br>
-<br>
- Check the result of the allocation in gx_cache_char_init before<br>
- using it.<br>
-<br>
-gs/base/gxccman.c<br>
-gs/base/gxfcache.h<br>
-gs/psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-27 10:00:27 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3d94f55fdc7babe5cbcf35aa0d3bdf43077a3de9">3d94f55fdc7babe5cbcf35aa0d3bdf43077a3de9</a>
-<blockquote>
-<p>
- Fix formatting bugs in halftone generators.<br>
-<br>
-gs/toolbin/halftone/gen_ordered/gen_ordered.c<br>
-gs/toolbin/halftone/gen_stochastic/gen_stochastic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-27 11:58:19 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d7042456a3b0c4da39d5e9bbb46b5e5379c6dc7">0d7042456a3b0c4da39d5e9bbb46b5e5379c6dc7</a>
-<blockquote>
-<p>
- Another memory squeezing fix.<br>
-<br>
- Ensure that the op_array_tables in the interpreter context are set<br>
- up enough that they can safely be garbage collected if allocations<br>
- fail.<br>
-<br>
-gs/psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-27 03:52:51 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3b19ec49702466fa4a05a8b41087ef32c130806d">3b19ec49702466fa4a05a8b41087ef32c130806d</a>
-<blockquote>
-<p>
- More memory squeezing fixes.<br>
-<br>
- Lack of check on allocation success.<br>
-<br>
-gs/psi/icontext.c<br>
-gs/psi/iinit.c<br>
-gs/psi/imainarg.c<br>
-gs/psi/zfont.c<br>
-gs/psi/zpcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-26 14:48:04 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4848f7302726acef5ac8c98030ec1a14ddab06b6">4848f7302726acef5ac8c98030ec1a14ddab06b6</a>
-<blockquote>
-<p>
- More memory squeezing fixes.<br>
-<br>
- Mostly unchecked allocation failures when setting up the gstate.<br>
-<br>
-gs/base/gscolor.c<br>
-gs/base/gsptype1.c<br>
-gs/base/gsstate.c<br>
-gs/base/gxchar.c<br>
-gs/base/gxdcolor.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-26 13:09:49 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d2e030ab25d8b31af22f0532ef813b0ff70e361">7d2e030ab25d8b31af22f0532ef813b0ff70e361</a>
-<blockquote>
-<p>
- Fix various memory squeezing errors.<br>
-<br>
- Mostly these are unchecked allocations, but some are errors in the<br>
- cleanup paths.<br>
-<br>
-gs/base/gslibctx.c<br>
-gs/base/gsmalloc.c<br>
-gs/psi/gs.c<br>
-gs/psi/imain.c<br>
-gs/psi/interp.c<br>
-gs/psi/zgstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-26 08:42:14 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a56fae81ef7f77b1ab6dadf38b1ea7539cfca0e4">a56fae81ef7f77b1ab6dadf38b1ea7539cfca0e4</a>
-<blockquote>
-<p>
- Free path upon fill failing - noticed in code review of ff515a6.<br>
-<br>
-pxl/pxpaint.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-25 15:03:42 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fca91ea554583d6f298f1c803ccf4d395b5dc94f">fca91ea554583d6f298f1c803ccf4d395b5dc94f</a>
-<blockquote>
-<p>
- Fix the fallout of a gnu indent bug introduced with the indentation<br>
- change, commit bc86bd6.<br>
-<br>
- Unfortuntaly, gnu indent 2.2 adds new blank lines after each local<br>
- variable declaration when the user requests that blocks of local<br>
- declaration be separated from the procedure body with a blank line.<br>
- This fix removes the extraneous blank lines.<br>
-<br>
-pcl/pcbiptrn.c<br>
-pcl/pccid.c<br>
-pcl/pccsbase.c<br>
-pcl/pcdither.c<br>
-pcl/pcdraw.c<br>
-pcl/pcfont.c<br>
-pcl/pcfontpg.c<br>
-pcl/pcfrgrnd.c<br>
-pcl/pcfsel.c<br>
-pcl/pcht.c<br>
-pcl/pcindxed.c<br>
-pcl/pcjob.c<br>
-pcl/pclookup.c<br>
-pcl/pcmacros.c<br>
-pcl/pcmtx3.c<br>
-pcl/pcommand.c<br>
-pcl/pcpage.c<br>
-pcl/pcpalet.c<br>
-pcl/pcparse.c<br>
-pcl/pcpatrn.c<br>
-pcl/pcpatxfm.c<br>
-pcl/pcrect.c<br>
-pcl/pcsfont.c<br>
-pcl/pcstatus.c<br>
-pcl/pcsymbol.c<br>
-pcl/pctop.c<br>
-pcl/pcuptrn.c<br>
-pcl/pcursor.c<br>
-pcl/pcwhtidx.c<br>
-pcl/pgchar.c<br>
-pcl/pgcolor.c<br>
-pcl/pgconfig.c<br>
-pcl/pgdraw.c<br>
-pcl/pgfdata.c<br>
-pcl/pgfont.c<br>
-pcl/pgframe.c<br>
-pcl/pggeom.c<br>
-pcl/pginit.c<br>
-pcl/pglabel.c<br>
-pcl/pglfill.c<br>
-pcl/pgmisc.c<br>
-pcl/pgparse.c<br>
-pcl/pgpoly.c<br>
-pcl/pgvector.c<br>
-pcl/rtgmode.c<br>
-pcl/rtmisc.c<br>
-pcl/rtraster.c<br>
-pcl/rtrstcmp.c<br>
-pl/dwimg.c<br>
-pl/dwmainc.c<br>
-pl/dwreg.c<br>
-pl/pjparse.c<br>
-pl/pjparsei.c<br>
-pl/plalloc.c<br>
-pl/plchar.c<br>
-pl/pldict.c<br>
-pl/plfapi.c<br>
-pl/plfont.c<br>
-pl/plht.c<br>
-pl/pllfont.c<br>
-pl/plmain.c<br>
-pl/plsrgb.c<br>
-pl/plsymbol.c<br>
-pl/pluchar.c<br>
-pl/plufont.c<br>
-pl/plulfont.c<br>
-pl/plvocab.c<br>
-pxl/pxffont.c<br>
-pxl/pxgstate.c<br>
-pxl/pximage.c<br>
-pxl/pxink.c<br>
-pxl/pxpaint.c<br>
-pxl/pxparse.c<br>
-pxl/pxpthr.c<br>
-pxl/pxsessio.c<br>
-pxl/pxstate.c<br>
-pxl/pxstream.c<br>
-pxl/pxtop.c<br>
-pxl/pxvalue.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-25 08:47:42 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d2a1f2e9de96d9fe70225302fd304309a19ef787">d2a1f2e9de96d9fe70225302fd304309a19ef787</a>
-<blockquote>
-<p>
- Fix reading uninitialized point (bug #693655), remove obsolete<br>
- supported conditional configurations and refactor.<br>
-<br>
- A logical error in paint_path resulted in reading the cursor<br>
- uninitialized. Early in XL development NEWPATH_AFTER_PAINT and<br>
- NO_SCALED_DASH_PATTERN were added to support incorrect language in the<br>
- specification but their behavior is well established after 3 major<br>
- revisions of the PCL-XL language can be safely removed allowing<br>
- simplification of this code.<br>
-<br>
- Even with those changes the paint_path procedure was much too complex<br>
- to be understandable, it is easy to see how a logical error would go<br>
- unnoticed. We try to refactor the code such that client procedures<br>
- take on some of the lifting and get rid of the gotos in hopes of<br>
- having something cohesive and correct.<br>
-<br>
-pxl/pxpaint.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-21 08:11:33 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=30273c4a9d9949f55dd4553dab614f1d36177377">30273c4a9d9949f55dd4553dab614f1d36177377</a>
-<blockquote>
-<p>
- Remove outdated definition.<br>
-<br>
- PXL always resets the path after drawing single objects (rectangle,<br>
- ellipse, etc.) and newer versions of the specification document this<br>
- correctly consequently the compiler directive and alternate behavior<br>
- can be removed.<br>
-<br>
-pxl/pxpaint.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-26 10:20:25 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7319905b5ba4dc3a3a66a4fa1489b653deb335fc">7319905b5ba4dc3a3a66a4fa1489b653deb335fc</a>
-<blockquote>
-<p>
- pdfwrite - prevent dereference of NULL pointer when no BG/UCR info present<br>
-<br>
- Bug #693728 &quot; Incompatible and large PDF output, and a crash with -dUCRandBGInfo=/Preserve&quot;<br>
-<br>
- The input is XPS and XPS has no concept of BG/UCR, so the pointer to the<br>
- information is NULL. If we had set the parameter -dUCRandBGInfo=/Preserve<br>
- then we would attempt to dereference the NULL Pointer.<br>
-<br>
- We now check the pointer before attempting to dereference it.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-23 13:17:59 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e76a62ee67c16f41f891a01011c7111e31643ebb">e76a62ee67c16f41f891a01011c7111e31643ebb</a>
-<blockquote>
-<p>
- Fix MSVC support of command line FEATURE_DEVS_EXTRA and DEVICE_DEVS_EXTRA<br>
-<br>
- In gs.mak these were both being set, which replaces the definition with nmake.<br>
- Without these, the definition defaults to an empty string anyway.<br>
-<br>
-gs/base/gs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-25 16:28: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=f54adf86c0f25bf9bc391e8df1af5e7ddfc0aca7">f54adf86c0f25bf9bc391e8df1af5e7ddfc0aca7</a>
-<blockquote>
-<p>
- pdfwrite - always fallback for type 4 images if we change colour space<br>
-<br>
- Type 4 (chroma keyed) images can't readily have their colour space changed,<br>
- if we are going to a space with fewer components. For example, if we convert<br>
- a CMYK image to Gray, then many different CMYK values will map to the same<br>
- gray value, leading to parts of the image being masked which should not be.<br>
-<br>
- Technically it is possible to change colour space the other way, but it is<br>
- easier for now to simply cause all such images to use the fallback code if<br>
- we are changing colour space.<br>
-<br>
-gs/devices/vector/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-25 16:24:53 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e3160bc0c25969e6807161f798548b763222e585">e3160bc0c25969e6807161f798548b763222e585</a>
-<blockquote>
-<p>
- Change the colorSpace header entry in generated profiles to make pdfwrite happy<br>
-<br>
- The generated profiles for certain kinds of colour space were being created<br>
- as 3CLR and 4CLR, which is absolutely fine in the general case. However,<br>
- the new pdfwrite code uses the internal 'icc_equivalent' profile generated<br>
- for a CIEBased PostScript colour space (previously pdfwrite generated its<br>
- own profile).<br>
-<br>
- But The PDF Reference says that only Gray, RGB, CMYK and Lab are permissible<br>
- values for the header. So here we pretend that the generated profiles are<br>
- in either RGB or CMYK, so that the emitted PDF will be valid.<br>
-<br>
- Because the profiles are only used to convert into a CIE device-independent<br>
- colour space, which will later be converted into a device space, this 'lie'<br>
- should not cause any problems (these spaces are not currently emitted at any<br>
- other point, and are never used as device profiles).<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gsicc_create.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-22 10:32:07 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=563a2c68351388047d4a21501f8e042a45d0a8db">563a2c68351388047d4a21501f8e042a45d0a8db</a>
-<blockquote>
-<p>
- Bug 693720: make tiffsep(1) depend on the planar device<br>
-<br>
- Update the makefiles to reflect that tiffsep is now a planar based device.<br>
-<br>
- Also fix some of the directory settings.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/msvctail.mak<br>
-gs/base/unix-end.mak<br>
-gs/devices/devs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-22 10:21:47 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2132b46fea22c8b3fc60d18eba0c2ae58162421c">2132b46fea22c8b3fc60d18eba0c2ae58162421c</a>
-<blockquote>
-<p>
- pdfwrite - only process pagelabels for pdfwrite device<br>
-<br>
- Bug #693721 &quot;Regression: file cannot be read starting with<br>
- 5784bfbfba7191cacce5309e88afac0851287460&quot;<br>
-<br>
- The pagelabels are handled as device parameters rather than pdfmarks, because<br>
- the pdfmark syntax can't handle the variety of page labels possible in a<br>
- PDF file.<br>
-<br>
- Of course only the pdfwrite device can handle this device parameter, so we<br>
- need to only perform this if the current device is pdfwrite.<br>
-<br>
- No differences expected, cluster only tests full builds, inclusive of<br>
- the pdfwrite device.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-22 01:38:24 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=86b1d9bea8fbd9f0e7b89730a041f1edd35ee20a">86b1d9bea8fbd9f0e7b89730a041f1edd35ee20a</a>
-<blockquote>
-<p>
- Add mujstest to list of possible user clusterpush jobs.<br>
-<br>
-gs/toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-13 13:14:22 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b9bb3f30028c552be77554b1e7c273625d115d95">b9bb3f30028c552be77554b1e7c273625d115d95</a>
-<blockquote>
-<p>
- Fix bug 693079. Reduce stack usage for pattern_clist playback.<br>
-<br>
- There were a couple of rather large structures on the stack in<br>
- clist_playback_band and in the tile filling. This file goes to<br>
- 4 levels deep of clist_playback_band -- once for the main clist,<br>
- then patterns nested 3 deep.<br>
-<br>
-gs/base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-21 12:55:07 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9428436fa107096fd9826af8ff1a77a8616d4819">9428436fa107096fd9826af8ff1a77a8616d4819</a>
-<blockquote>
-<p>
- Fix compiler warning.<br>
-<br>
-gs/base/gxclip2.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-21 10:57:17 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e4ddd5fbb12bce97f75d8039a863d32b81e2e67f">e4ddd5fbb12bce97f75d8039a863d32b81e2e67f</a>
-<blockquote>
-<p>
- Fix bug 693718: 09-03.PS clist problem with DeviceN devices and patterns.<br>
-<br>
- The clist device doesn't write masked DeviceN colors, so masked<br>
- patterns use the gx_default_fill_path method, but the pattern logic<br>
- optimizes masks that are solid to delete the mask (which is more<br>
- efficient), but then the color must be converted to a non-masked<br>
- color i.e., gx_dc_type_devn instead of gx_dc_type_devn_masked.<br>
-<br>
- This file was very resolution sensitive because the pattern was<br>
- only solid at specific resolutions.<br>
-<br>
- Testing shows significant improvement on comparefiles/PP0001G0.pdf.psdcmyk.300.1<br>
-<br>
-gs/base/gxclip2.c<br>
-gs/base/gxp1fill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-21 17:19: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=52ee1397fa772e6534843dcff6540fa9cb5b5f11">52ee1397fa772e6534843dcff6540fa9cb5b5f11</a>
-<blockquote>
-<p>
- Change jbig2dec license to AGPL to match Ghostscript.<br>
-<br>
- And remove an obsolete &quot;.cvsignore&quot; file.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/jbig2dec/.cvsignore<br>
-gs/jbig2dec/COPYING<br>
-gs/jbig2dec/LICENSE<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-21 11:39:14 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d8da78f4ed1e472f7cfa4589122fc3392959563">1d8da78f4ed1e472f7cfa4589122fc3392959563</a>
-<blockquote>
-<p>
- Bug 693613: add an explicit memory parameter to gs_path_enum_copy_init()<br>
-<br>
- In zpathforall() the path enumerator object is allocated with the current<br>
- allocator for the Postscript VM mode. But gs_path_enum_copy_init() used the<br>
- memory pointer from the graphics state for all it's allocations, and also to<br>
- set the path enumerator's &quot;memory&quot; pointer.<br>
-<br>
- Clearly there was the potential for problems there: in this case, the current<br>
- VM mode was global, but the graphics state was allocated in local. In this<br>
- scenario, we immediately do a GC on *local* VM after zpathforall() and before<br>
- we reach path_continue(). Because the path enumerator was allocated in global<br>
- VM, we skip it during this GC, meaning the copied path and its contents (in<br>
- local VM) were not marked, the memory considered free, and overwritten during<br>
- the compaction phase.<br>
-<br>
- By adding an explicit memory parameter to gs_path_enum_copy_init() we can<br>
- ensure that all the allocations for the path enumerator are consistent, and that<br>
- the memory pointer in the enumerator is also correct.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gspath.h<br>
-gs/base/gspath1.c<br>
-gs/psi/zpath1.c<br>
-gs/psi/zupath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-20 18:20:37 +0000
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f4156a67dae6b3d6ba627a2003617ba773a19ff">8f4156a67dae6b3d6ba627a2003617ba773a19ff</a>
-<blockquote>
-<p>
- Bug 693714: Fix valgrind warnings in downsampler.<br>
-<br>
- When using the special downscalers for 2/3/4, I was miscalculating<br>
- the input pointer for the right to left passes, leading to UMRs.<br>
- Fixed here.<br>
-<br>
- Surprised that no one has complained of bad rendering!<br>
-<br>
-gs/base/gxdownscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-20 08:38:39 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59d1b2b25262c7995e4060ec8388abf059efcf3e">59d1b2b25262c7995e4060ec8388abf059efcf3e</a>
-<blockquote>
-<p>
- Fix a couple of benign compiler warnings.<br>
-<br>
-gs/devices/vector/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-19 16:55:06 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af327b13f517a5a7e74ccafd4c325dd378f509c3">af327b13f517a5a7e74ccafd4c325dd378f509c3</a>
-<blockquote>
-<p>
- pdfwrite - fix non-standard ranges in CIE spaces converted to ICC wiht linework<br>
-<br>
- Bug #693698 &quot;Wrong color in file with pdfwrite&quot;<br>
-<br>
- The specimen file claims to be Lab but actually isn't. The colour components<br>
- are scaled to 0-&gt;100, 0-&gt;255, 0-&gt;255 instead of 0-&gt;100, -128 -&gt; 127, -128 -&gt; 127<br>
-<br>
- While the shading and image code scales the input values into 0-&gt;1 when emitting<br>
- an equivalent ICCBased space, the linework code did not.<br>
-<br>
- This commit addresses that, and also adds code to deal with the same<br>
- issue in the new colour code.<br>
-<br>
- There are a few cluster differences but the results are visually identical<br>
- or extremely similar.<br>
-<br>
-gs/devices/vector/gdevpdfc.c<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpdfg.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-19 09:38: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=0ce371636903391f165830d84dcbf6bc50a889bf">0ce371636903391f165830d84dcbf6bc50a889bf</a>
-<blockquote>
-<p>
- Bug 693611: add missing pointer to pdf14_device gc funcs<br>
-<br>
- The pclist_device was missing from pdf14_device_enum_ptrs() and<br>
- pdf14_device_reloc_ptrs().<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-19 09:55: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=46391b4a374db77027733598ec58989eb1d31e47">46391b4a374db77027733598ec58989eb1d31e47</a>
-<blockquote>
-<p>
- pdfwrite - fix problem with discontinuous xref tables and 64-bit file sizes<br>
-<br>
- Bug #693710 &quot;Regression: Missing output with pdfwrite and 32-bit build&quot;<br>
-<br>
- The update to use 64-bit offsets for file sizes missed a case when finding<br>
- the end of an xref section. This only occurs when an object has been reserved<br>
- for future use, and then not actually used (eg a Destination for a Link on a<br>
- page which is not then produced).<br>
-<br>
- Corrected the type from ulong to gs_offset_t.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-18 20:19:48 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bc86bd69e26b93a38ab7ee06fa2d77fb836b7c84">bc86bd69e26b93a38ab7ee06fa2d77fb836b7c84</a>
-<blockquote>
-<p>
- Indent PCL and XL in accordance with the indentation rules in<br>
- gs/doc/C-style.htm.<br>
-<br>
- The program GNU indent was used to make the changes and we expect<br>
- there will be some manual cleanup over the next few days.<br>
-<br>
-pcl/pcbiptrn.c<br>
-pcl/pcbiptrn.h<br>
-pcl/pccid.c<br>
-pcl/pccid.h<br>
-pcl/pccolor.c<br>
-pcl/pccoord.h<br>
-pcl/pccprint.c<br>
-pcl/pccsbase.c<br>
-pcl/pccsbase.h<br>
-pcl/pcdict.h<br>
-pcl/pcdither.c<br>
-pcl/pcdither.h<br>
-pcl/pcdraw.c<br>
-pcl/pcdraw.h<br>
-pcl/pcfont.c<br>
-pcl/pcfont.h<br>
-pcl/pcfontpg.c<br>
-pcl/pcfontst.h<br>
-pcl/pcfrgrnd.c<br>
-pcl/pcfrgrnd.h<br>
-pcl/pcfsel.c<br>
-pcl/pcfsel.h<br>
-pcl/pcht.c<br>
-pcl/pcht.h<br>
-pcl/pcident.c<br>
-pcl/pcident.h<br>
-pcl/pcimpl.c<br>
-pcl/pcindxed.c<br>
-pcl/pcindxed.h<br>
-pcl/pcjob.c<br>
-pcl/pclookup.c<br>
-pcl/pclookup.h<br>
-pcl/pcmacros.c<br>
-pcl/pcmisc.c<br>
-pcl/pcmtx3.c<br>
-pcl/pcmtx3.h<br>
-pcl/pcommand.c<br>
-pcl/pcommand.h<br>
-pcl/pcpage.c<br>
-pcl/pcpage.h<br>
-pcl/pcpalet.c<br>
-pcl/pcpalet.h<br>
-pcl/pcparam.h<br>
-pcl/pcparse.c<br>
-pcl/pcparse.h<br>
-pcl/pcpatrn.c<br>
-pcl/pcpatrn.h<br>
-pcl/pcpattyp.h<br>
-pcl/pcpatxfm.c<br>
-pcl/pcpatxfm.h<br>
-pcl/pcrect.c<br>
-pcl/pcsfont.c<br>
-pcl/pcstate.h<br>
-pcl/pcstatus.c<br>
-pcl/pcsymbol.c<br>
-pcl/pcsymbol.h<br>
-pcl/pctext.c<br>
-pcl/pctop.c<br>
-pcl/pctop.h<br>
-pcl/pctpm.h<br>
-pcl/pcuptrn.c<br>
-pcl/pcuptrn.h<br>
-pcl/pcursor.c<br>
-pcl/pcursor.h<br>
-pcl/pcwhtidx.c<br>
-pcl/pcwhtidx.h<br>
-pcl/pcxfmst.h<br>
-pcl/pgchar.c<br>
-pcl/pgcolor.c<br>
-pcl/pgconfig.c<br>
-pcl/pgdraw.c<br>
-pcl/pgdraw.h<br>
-pcl/pgfdata.c<br>
-pcl/pgfdata.h<br>
-pcl/pgfont.c<br>
-pcl/pgfont.h<br>
-pcl/pgframe.c<br>
-pcl/pggeom.c<br>
-pcl/pggeom.h<br>
-pcl/pginit.c<br>
-pcl/pginit.h<br>
-pcl/pglabel.c<br>
-pcl/pglfill.c<br>
-pcl/pgmand.h<br>
-pcl/pgmisc.c<br>
-pcl/pgmisc.h<br>
-pcl/pgparse.c<br>
-pcl/pgpoly.c<br>
-pcl/pgstate.h<br>
-pcl/pgvector.c<br>
-pcl/rtgmode.c<br>
-pcl/rtgmode.h<br>
-pcl/rtmisc.c<br>
-pcl/rtmisc.h<br>
-pcl/rtraster.c<br>
-pcl/rtraster.h<br>
-pcl/rtrstcmp.c<br>
-pcl/rtrstcmp.h<br>
-pcl/rtrstst.h<br>
-pl/dwimg.c<br>
-pl/dwimg.h<br>
-pl/dwmainc.c<br>
-pl/dwreg.c<br>
-pl/dwreg.h<br>
-pl/pjparse.c<br>
-pl/pjparse.h<br>
-pl/pjparsei.c<br>
-pl/pjtop.c<br>
-pl/pjtop.h<br>
-pl/plalloc.c<br>
-pl/plapi.h<br>
-pl/plchar.c<br>
-pl/plchar.h<br>
-pl/pldict.c<br>
-pl/pldict.h<br>
-pl/pldraw.c<br>
-pl/pldraw.h<br>
-pl/plfapi.c<br>
-pl/plfapi.h<br>
-pl/plfont.c<br>
-pl/plfont.h<br>
-pl/plftable.h<br>
-pl/plht.c<br>
-pl/plht.h<br>
-pl/plimpl.c<br>
-pl/pllfont.c<br>
-pl/pllfont.h<br>
-pl/plmain.c<br>
-pl/plmain.h<br>
-pl/plparse.h<br>
-pl/plplatf.c<br>
-pl/plplatf.h<br>
-pl/plplatfps.c<br>
-pl/plsrgb.c<br>
-pl/plsrgb.h<br>
-pl/plsymbol.c<br>
-pl/plsymbol.h<br>
-pl/pltop.c<br>
-pl/pltop.h<br>
-pl/pltoputl.c<br>
-pl/pltoputl.h<br>
-pl/pluchar.c<br>
-pl/plufont.c<br>
-pl/plufstlp.c<br>
-pl/plufstlp.h<br>
-pl/plufstlp1.c<br>
-pl/plulfont.c<br>
-pl/plvalue.c<br>
-pl/plvalue.h<br>
-pl/plvocab.c<br>
-pl/realmain.c<br>
-pxl/pxbfont.c<br>
-pxl/pxbfont.h<br>
-pxl/pxdict.h<br>
-pxl/pxerrors.c<br>
-pxl/pxerrors.h<br>
-pxl/pxffont.c<br>
-pxl/pxfont.c<br>
-pxl/pxfont.h<br>
-pxl/pxgstate.c<br>
-pxl/pxgstate.h<br>
-pxl/pximage.c<br>
-pxl/pximpl.c<br>
-pxl/pxink.c<br>
-pxl/pxoper.h<br>
-pxl/pxpaint.c<br>
-pxl/pxparse.c<br>
-pxl/pxparse.h<br>
-pxl/pxptable.c<br>
-pxl/pxptable.h<br>
-pxl/pxpthr.c<br>
-pxl/pxpthr.h<br>
-pxl/pxsessio.c<br>
-pxl/pxstate.c<br>
-pxl/pxstate.h<br>
-pxl/pxstream.c<br>
-pxl/pxtop.c<br>
-pxl/pxvalue.c<br>
-pxl/pxvalue.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-18 16:26: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=962b4bd30b0b85ee5c55d548144e0d4c073a7bfb">962b4bd30b0b85ee5c55d548144e0d4c073a7bfb</a>
-<blockquote>
-<p>
- Remove unnecessary traling $(D) from a &quot;-I&quot; compiler option.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-18 10:59:37 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ec0a5d96d02576c53cef22fe3e9bde5547c2f4ee">ec0a5d96d02576c53cef22fe3e9bde5547c2f4ee</a>
-<blockquote>
-<p>
- pdfwrite - improve handling of broken fonts<br>
-<br>
- Bug #693711 &quot;pdfwrite segfault&quot;<br>
-<br>
- The specimen file contains two fonts which are badly broken, in one case<br>
- the broken data stream decodes to a 'return' operation without a prior<br>
- 'callsubr'. This caused the SEAC detection code to attempt to free memory<br>
- using uninitialised data, which caused a seg fault. We now detect the call<br>
- stack depth, and return an error if we return when no subroutine is executing.<br>
-<br>
- This caused a later heap error, as did the other font, because the regular<br>
- type 1 font interpreter also didn't like the font data, and returned an error.<br>
- This caused us not to write a FontFile resource, but the FontDescriptor<br>
- writing code tried to write one anyway. Fixed by checking that there is a<br>
- FontFile before trying to write one.<br>
-<br>
- The specimen file now runs to completion, but will not embed the broken<br>
- fonts. As a result it will only work 'correctly' on systems which have the<br>
- missing fonts available. Although given that these fonts are broken, it<br>
- seems unlikely these will work anyway.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gxtype1.c<br>
-gs/devices/vector/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-18 08:36:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fe7e1a32165f96d20d696c6b0349d338f1ec3666">fe7e1a32165f96d20d696c6b0349d338f1ec3666</a>
-<blockquote>
-<p>
- Bug 693712: fix the header search path<br>
-<br>
- The new devices directory wasn't correctly added to the list of &quot;-I&quot; compiler<br>
- options.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-17 17:46:54 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba5fb31f9029bf622bea24ac47e089c514981f7f">ba5fb31f9029bf622bea24ac47e089c514981f7f</a>
-<blockquote>
-<p>
- Warning cleanup.<br>
-<br>
-pcl/pcl.mak<br>
-pcl/pcpage.c<br>
-pcl/pctext.c<br>
-pl/pjparse.c<br>
-pl/plfont.c<br>
-pxl/pxerrors.c<br>
-pxl/pxfont.c<br>
-pxl/pxl.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-17 09:49:46 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=473fec16b9ff829b28d0c291eb4fc929f221d3c6">473fec16b9ff829b28d0c291eb4fc929f221d3c6</a>
-<blockquote>
-<p>
- Bug 693658: Avoid overflows in image positioning.<br>
-<br>
- Check for overflows to handle cases when CTM or ImageMatrix is too big.<br>
-<br>
-gs/base/gxifast.c<br>
-gs/base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-16 10:38:07 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=884590d08f332a06ebf3e5db996c32210a5fc8c0">884590d08f332a06ebf3e5db996c32210a5fc8c0</a>
-<blockquote>
-<p>
- Bug 689658: Reject excessive values in CIE color spaces.<br>
-<br>
- Reject CIE color spaces that have any of the attributes out of<br>
- -10000..10000 range to avoid overflows and division by 0.<br>
- This range should be sufficient for any real world color usage.<br>
-<br>
-gs/psi/zcolor.c<br>
-gs/psi/zcrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-16 09:08:05 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=56f34c8243ad078882df0f08cbfc10c6943fb3fe">56f34c8243ad078882df0f08cbfc10c6943fb3fe</a>
-<blockquote>
-<p>
- Bug 693658: Improve validation of image parameters<br>
-<br>
- To avoid overflow, check that parameter is withing the given range<br>
- before the parameter is converted to int. Stop interpolation of 0-width<br>
- or 0-length images because interpolation code divides by 0 in this case.<br>
-<br>
-gs/base/gxiscale.c<br>
-gs/psi/idparam.c<br>
-gs/psi/zimage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-15 10:48:15 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=93bcd2277fe838838c760c4fea827d18a445ba8f">93bcd2277fe838838c760c4fea827d18a445ba8f</a>
-<blockquote>
-<p>
- Bug 692722: Fix garbage in win32 console when using unicode filename.<br>
-<br>
- In Unicode build, wide-char arguments are first converted to UTF-8 and<br>
- may be sent to stdout/stderr. So we must switch the console code page<br>
- to CP_UTF8 during main_utf8() execution to avoid utf-8/local-codepage<br>
- collision.<br>
-<br>
- Thanks to Mathieu Lafon for the patch.<br>
-<br>
-pl/dwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-15 14:32: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=773c69e46e70bdd5482676437dafd2ca83397643">773c69e46e70bdd5482676437dafd2ca83397643</a>
-<blockquote>
-<p>
- Bug 693699: replace all fopen calls with gp_fopen<br>
-<br>
- Only exceptions are those in the platform specific code, and mkromfs.c.<br>
-<br>
- Also, add a preprocessor define so that any unintential calls directly to<br>
- fopen will cause an error.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-gs/base/gp_dvx.c<br>
-gs/base/gp_macio.c<br>
-gs/base/gp_mswin.c<br>
-gs/base/gp_os2.c<br>
-gs/base/gp_unifs.c<br>
-gs/base/gp_unix.c<br>
-gs/base/gp_unix_cache.c<br>
-gs/base/gp_vms.c<br>
-gs/base/gsdevice.c<br>
-gs/base/gsicc_create.c<br>
-gs/base/gsicc_lcms.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsiodev.c<br>
-gs/base/gsiodisk.c<br>
-gs/base/gsiomacres.c<br>
-gs/base/gsroprun.c<br>
-gs/base/gxblend.c<br>
-gs/base/gxblend1.c<br>
-gs/base/gxiodev.h<br>
-gs/base/gxpcmap.c<br>
-gs/base/lib.mak<br>
-gs/base/mkromfs.c<br>
-gs/base/stdio_.h<br>
-gs/base/strmio.c<br>
-gs/contrib/japanese/dviprlib.c<br>
-gs/contrib/japanese/gdevdmpr.c<br>
-gs/contrib/pcl3/eprn/eprnparm.c<br>
-gs/contrib/pscolor/test.c<br>
-gs/devices/vector/gdevtxtw.c<br>
-gs/psi/apitest.c<br>
-gs/psi/gserver.c<br>
-gs/psi/int.mak<br>
-gs/psi/zfile.c<br>
-gs/psi/ziodev2.c<br>
-pl/pjparse.c<br>
-pl/plmain.c<br>
-svg/svg.mak<br>
-svg/svgtop.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-15 10:13:05 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5d49dbfa9c33dc67f7e5dbb0294056976de33521">5d49dbfa9c33dc67f7e5dbb0294056976de33521</a>
-<blockquote>
-<p>
- Bug 693702: fix handling of large glyphs in FAPI/UFST<br>
-<br>
- There was a logical error in the fallback case when a glyph ends up too big<br>
- for a temporary bitmap allocation in the UFST code which caused us to render<br>
- the &quot;notdef&quot; glyph instead of fallback to using the glyph outline to render<br>
- uncached.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/fapiufst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-14 11:59:19 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b243adea0a7684fdb1fe755166816bafddca7666">b243adea0a7684fdb1fe755166816bafddca7666</a>
-<blockquote>
-<p>
- Documentation typo fixed.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-doc/ghostpdl.pdf<br>
-doc/ghostpdl.tex<br>
-doc/ghostpdl.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-14 09:11:07 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5265796a4b8cb3d05dd72695373381135cb99c50">5265796a4b8cb3d05dd72695373381135cb99c50</a>
-<blockquote>
-<p>
- Remove two unused variables and a redundant function call<br>
-<br>
- Flagged by compiler warnings, two variables are unused, and a function call<br>
- to set one of them is not required.<br>
-<br>
- No differences expected<br>
-<br>
-gs/psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-13 13:39:54 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da27879315a810e24fc881680a2ea5e8345c9bc2">da27879315a810e24fc881680a2ea5e8345c9bc2</a>
-<blockquote>
-<p>
- Fix trace device to compile with the new directory structure.<br>
-<br>
- The trace devices were located in the lib.mak file and stopped working<br>
- (the compile broke) when gdevtrac.c was moved to the new devices/<br>
- directory.<br>
-<br>
-gs/base/lib.mak<br>
-gs/devices/devs.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-13 14:10: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=044c2d5eefff2d1c92dc830b4b424856228cd083">044c2d5eefff2d1c92dc830b4b424856228cd083</a>
-<blockquote>
-<p>
- Remove psmono, psgray and psrgb devices.<br>
-<br>
- Only vestige of pswrite remaining is epswrite.<br>
-<br>
- No cluster differences.<br>
-<br>
-doc/who_owns_what.txt<br>
-gs/Makefile.in<br>
-gs/base/macos-mcp.mak<br>
-gs/base/openvms.mak<br>
-gs/base/openvms.mmk<br>
-gs/base/unix-gcc.mak<br>
-gs/base/unixansi.mak<br>
-gs/configure.ac<br>
-gs/devices/devs.mak<br>
-gs/devices/gdevpsim.c<br>
-gs/doc/Devices.htm<br>
-gs/psi/msvc.mak<br>
-gs/psi/os2.mak<br>
-gs/toolbin/pre.chk<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-13 13:33:18 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fe10fefa06fe8405a05d4370ab6deaf14e06b122">fe10fefa06fe8405a05d4370ab6deaf14e06b122</a>
-<blockquote>
-<p>
- Fix '0' return handling from dict_find_string in colour code<br>
-<br>
- Bug #693685 - Wrong assumption about dict_find_string()<br>
-<br>
- It seems that dict_find_string can return 0 when a string is not found in a<br>
- dictionary. This commit updates the code to deal with this (apparently unusual)<br>
- case.<br>
-<br>
- No differences expected<br>
-<br>
-gs/psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-11 16:17:49 -0400
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8a95c1dff88559acbe451fa4b402fdae7f1818b3">8a95c1dff88559acbe451fa4b402fdae7f1818b3</a>
-<blockquote>
-<p>
- Remove pswrite device.<br>
-<br>
- epswrite and, by implication, the pswrite source remain - for now......<br>
-<br>
- No cluster differences.<br>
-<br>
-doc/who_owns_what.txt<br>
-gs/base/macos-mcp.mak<br>
-gs/base/macosx.mak<br>
-gs/base/openvms.mak<br>
-gs/base/openvms.mmk<br>
-gs/base/unix-gcc.mak<br>
-gs/configure.ac<br>
-gs/devices/devs.mak<br>
-gs/devices/vector/gdevps.c<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Use.htm<br>
-gs/psi/msvc.mak<br>
-gs/psi/os2.mak<br>
-gs/toolbin/pre.chk<br>
-main/pcl6_gcc.mak<br>
-main/pcl6_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-13 10:27:56 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea86d8b5f40deff1b226c0a1bc98685f7ce34a02">ea86d8b5f40deff1b226c0a1bc98685f7ce34a02</a>
-<blockquote>
-<p>
- Fix a missing &quot;!endif&quot; in msvclib.mak<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/msvclib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-12 13:29:45 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a7b3f0ce56a0c86b3b9b1c815d0c0a402e2cb3f6">a7b3f0ce56a0c86b3b9b1c815d0c0a402e2cb3f6</a>
-<blockquote>
-<p>
- Add pdfwrite option to clusterpush.pl to run only pdfwrite and ps2write tests.<br>
-<br>
-gs/toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-11 23:09:22 +0000
-</strong>
-<br>unknown &lt;ken@.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b0a5422d62b83d961a2caa5bd271d25e08495b25">b0a5422d62b83d961a2caa5bd271d25e08495b25</a>
-<blockquote>
-<p>
- Check return codes when handling CIE colour space parameters<br>
-<br>
- We weren't checking some parameters, which could lead to seg faults<br>
-<br>
- Bug #693659<br>
-<br>
-gs/psi/zcie.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-11 23:05:55 +0000
-</strong>
-<br>unknown &lt;ken@.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b3b835e19f8a248a16ed68394c16b1e8899cf6ac">b3b835e19f8a248a16ed68394c16b1e8899cf6ac</a>
-<blockquote>
-<p>
- pdfwrite - limit number of pages to limit in spec<br>
-<br>
- Bug #693658 - file 35a5e3ba_39da0975_973319ae_a18c13ca_ce4ba9eb.SIGSEGV.b0b<br>
-<br>
- Reserving pages overflowed an integer, causing us not to reserve enough pages<br>
- we now clamp to 2^32 -1 (see PDF spec, page numbers are defined as integers)<br>
-<br>
- This now runs out of memory and aborts the pdfmark.<br>
-<br>
- No differences expectedd<br>
-<br>
-gs/devices/vector/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-11 17:01:39 -0400
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=943ae1102814d5248fea59b3029fa8723a47527b">943ae1102814d5248fea59b3029fa8723a47527b</a>
-<blockquote>
-<p>
- Bug 693644: Remove leftover stuff about pdfopt and dumphint<br>
-<br>
- No cluster differences<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/unixinst.mak<br>
-gs/doc/Develop.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Use.htm<br>
-gs/man/de/pdfopt.1<br>
-gs/man/pdfopt.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-11 15:40:36 -0400
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9c78f0146d0983382b54e15433c44faabc6fffcc">9c78f0146d0983382b54e15433c44faabc6fffcc</a>
-<blockquote>
-<p>
- Bug 693686: Improve heurisic for vertical metrics from FT<br>
-<br>
- Freetype &quot;derives&quot; vertical metrics when a font does not contain any, so we<br>
- use a heuristic to decide whether to use them, or not. With the revised FAPI<br>
- for use with the non-PS/PDF languages, the &quot;heurstic&quot; was &quot;augmented&quot; with an<br>
- unsuitably simple test - so now that simple test has been replaced with<br>
- an improved heuristic which works for both PS and PCL.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-gs/base/gxfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-10 14:55:13 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a9fa9038c30384eb8bc07aa53d115f6b9d94e46f">a9fa9038c30384eb8bc07aa53d115f6b9d94e46f</a>
-<blockquote>
-<p>
- Bug 693658: Reject encoding array with non-name entries.<br>
-<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-09 20:50:32 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a431d5193985ed563a04ec71a053ddfe14026326">a431d5193985ed563a04ec71a053ddfe14026326</a>
-<blockquote>
-<p>
- Bug 693681: Thansform group /BBox by /Matrix<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-08 17:19:43 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2cdd97670587903d4198ef7455742f0363502bb8">2cdd97670587903d4198ef7455742f0363502bb8</a>
-<blockquote>
-<p>
- Bug 693659: Check that halftone 5 has /Default component.<br>
-<br>
-gs/psi/zht2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-08 16:54:05 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5f5f13ff649293cb66fa8ddcdad4a1e9bedf437f">5f5f13ff649293cb66fa8ddcdad4a1e9bedf437f</a>
-<blockquote>
-<p>
- Bug 693683: remove not needed header.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/fapiufst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-07 16:56:10 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=26a55d3991398f16a71d8369944ac75ab55aa94c">26a55d3991398f16a71d8369944ac75ab55aa94c</a>
-<blockquote>
-<p>
- Bug 693453, remove unnecessary confusing check for a null parameter.<br>
-<br>
- The width parameter is a prerequisite and does not need to be null<br>
- checked.<br>
-<br>
-pl/plchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-08 11:08:40 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d337f132f69f31957b4b409a7958b45bdc2089fe">d337f132f69f31957b4b409a7958b45bdc2089fe</a>
-<blockquote>
-<p>
- pdfwrite - Auto-rotation. Prefer auto-rotate over DSC comments<br>
-<br>
- When auto-rotation is not /None we check both the heuristically determined<br>
- auto-rotate value and (for PostScript input) any DSC document or page level<br>
- comments.<br>
-<br>
- Previously where these conflicted we used the DSC comments, but this seems<br>
- obtuse when the user has asked for auto-rotation. This reverses the default<br>
- so that auto-rotation will be preferred.<br>
-<br>
- Also updated the documentation which incorrectly stated that Orientation<br>
- DSC comments were ignored.<br>
-<br>
- Expected differences<br>
- A few files are now rotated where previously they were not<br>
-<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/doc/Ps2pdf.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-08 10:45:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2ec451c463a73f66891356081f1bc9d3972a0358">2ec451c463a73f66891356081f1bc9d3972a0358</a>
-<blockquote>
-<p>
- Remove a pointless relative path in the VS project<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-08 10:29: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=4aa99bb81e72592ed9adcdf6cfec8fadc001ba62">4aa99bb81e72592ed9adcdf6cfec8fadc001ba62</a>
-<blockquote>
-<p>
- Add the VS project changes for the new devices dir<br>
-<br>
- These changes somehow went awol when I committed the directory reorg.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-07 23:44:25 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7cc7b0adb8203fbc94ce4613e4eefa12d9de0b2c">7cc7b0adb8203fbc94ce4613e4eefa12d9de0b2c</a>
-<blockquote>
-<p>
- Fix compiler warning and trailing whitespace issues.<br>
-<br>
-gs/base/gsequivc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-07 16:18:47 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7fd565cebe1add96bf09527530c1f30365090cc5">7fd565cebe1add96bf09527530c1f30365090cc5</a>
-<blockquote>
-<p>
- Clean up some indents that used tabs.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-12 19:41:09 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c4990bb6f8f4e5d7484b9b183ea9caaa5eaedee">6c4990bb6f8f4e5d7484b9b183ea9caaa5eaedee</a>
-<blockquote>
-<p>
- Remove force of -Z: used during development.<br>
-<br>
-gs/psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-27 15:57:59 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=abc6c492a11f63ee416ecd287d980a0cb134421e">abc6c492a11f63ee416ecd287d980a0cb134421e</a>
-<blockquote>
-<p>
- Finally get rid of band_complexity and write/read color_usage_array from clist.<br>
-<br>
- This also gets rid of the hackish fixed length band_color_usage in the page_info<br>
- in favor of a dynamically allocated structure that has one entry per band.<br>
-<br>
- A few minor git gripes cleaned up for the commit (trailing whitespace) in the<br>
- affected files.<br>
-<br>
-gs/base/gdevppla.c<br>
-gs/base/gdevppla.h<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevprn.h<br>
-gs/base/gxband.h<br>
-gs/base/gxcldev.h<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclist.h<br>
-gs/base/gxclpath.c<br>
-gs/base/gxclread.c<br>
-gs/base/gxclrect.c<br>
-gs/base/gxclthrd.c<br>
-gs/base/gxclutil.c<br>
-gs/base/gxdevbuf.h<br>
-gs/devices/gdevijs.c<br>
-gs/devices/gdevplib.c<br>
-gs/devices/gdevpng.c<br>
-gs/psi/imain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-09 09:31: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=aa5ee8102a4a98c8cef55b4ee9f347b9bdf94036">aa5ee8102a4a98c8cef55b4ee9f347b9bdf94036</a>
-<blockquote>
-<p>
- Optimize PDF 1.4 transparency when using the clist.<br>
-<br>
- Keep track of the bbox for the actual transparency rect in each band,<br>
- and skip pdf14 compositor actions on playback for bands with an empty<br>
- bbox. Bands that only paint to the page level with alpha == 1 don't<br>
- need the compositor. -Z: prints the number of bands skipped.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevprn.c<br>
-gs/base/gsropt.h<br>
-gs/base/gxband.h<br>
-gs/base/gxcldev.h<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclist.h<br>
-gs/base/gxclpath.c<br>
-gs/base/gxclrast.c<br>
-gs/base/gxclread.c<br>
-gs/base/gxclrect.c<br>
-gs/base/gxclutil.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-07 14:06:36 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dde01090d9251f0752583fa0524d0db7e5b1531d">dde01090d9251f0752583fa0524d0db7e5b1531d</a>
-<blockquote>
-<p>
- Fix indeterminate results caused by UMR of render_cond.<br>
-<br>
- Seen with tests_private/pdf/PDFIA1.7_SUBSET/CATX4988.pdf and other<br>
- files (psdcmyk device). Function capture_spot_equivalent_cmyk_colors<br>
- uses a 'temp_profile' but didn't initialize the rendercond<br>
- array which could change the link profile that was generated.<br>
- Also (just in case) set the devicegraytok element.<br>
-<br>
-gs/base/gsequivc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-06 11:17:49 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b2716c4d4862d357d52e3046f512bf4a93b71296">b2716c4d4862d357d52e3046f512bf4a93b71296</a>
-<blockquote>
-<p>
- Fix missing dependency of gxpcolor.h<br>
-<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-07 14:05:59 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0deeb9ece0637d0d1e8f2d6d03cea3e245330856">0deeb9ece0637d0d1e8f2d6d03cea3e245330856</a>
-<blockquote>
-<p>
- Bug 693659: Check that CalRGB is a dictionary.<br>
-<br>
-gs/psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-07 13:40:58 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e43623be06fc7dbae01071ab78b5e9f9e70f133">4e43623be06fc7dbae01071ab78b5e9f9e70f133</a>
-<blockquote>
-<p>
- Bug 693659: Check that halftone name is a name.<br>
-<br>
-gs/psi/zht2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-07 12:41:53 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f972acdde3a09fc37e76826dafec44f8d9ee603">8f972acdde3a09fc37e76826dafec44f8d9ee603</a>
-<blockquote>
-<p>
- Bug 693659: Check for file name buffer overflow.<br>
-<br>
-gs/psi/zfile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-07 09:15:07 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e32682a2530afae04e2d1988da06740d92f7808">2e32682a2530afae04e2d1988da06740d92f7808</a>
-<blockquote>
-<p>
- Bug 693659: Skip empty strings in sfnts array.<br>
-<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-07 00:45:41 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6961e71d7b6b9162f6b75fae60469175a4c8d43e">6961e71d7b6b9162f6b75fae60469175a4c8d43e</a>
-<blockquote>
-<p>
- Bug 692862: Fix stroking problem with antialiasing<br>
-<br>
- The fix for bug 691228 causes problems in some cases; when joining<br>
- two segment that are directly in line with the next, we add a<br>
- circular line cap to ensure correct rendering. Which side of this<br>
- end cap we end up on depends on which direction the line then<br>
- continues in.<br>
-<br>
-gs/base/gxstroke.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-06 09:30:38 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d3d66fddadc345aab1139397e10b1ab200af2c99">d3d66fddadc345aab1139397e10b1ab200af2c99</a>
-<blockquote>
-<p>
- Fix infinite recursion (caused segfault) introduced with commit 70ba7029.<br>
-<br>
- The fix to mem_planar_fill_rectangle_hl_color did not account for the<br>
- devn_masked color type which can also be handled.<br>
-<br>
-gs/base/gdevmpla.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-06 10:15:14 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0f541c553afe098f84f19557e4a19bb18e803b91">0f541c553afe098f84f19557e4a19bb18e803b91</a>
-<blockquote>
-<p>
- Bug 693659: Reject functions with 1-point domain.<br>
-<br>
-gs/psi/zfunc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-26 18:01: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=f1488c5aff54f37ee67759827d4298592af5dbc8">f1488c5aff54f37ee67759827d4298592af5dbc8</a>
-<blockquote>
-<p>
- Move output devices to their own directory.<br>
-<br>
- Also put the vector devices in their own directory, so we have:<br>
- gs/devices<br>
-<br>
- and<br>
-<br>
- gs/devices/vector<br>
-<br>
- This is a first pass - further refinement may be required!<br>
-<br>
- No cluster differences.<br>
-<br>
-common/msvc_top.mak<br>
-common/ugcc_top.mak<br>
-gs/Makefile.in<br>
-gs/autogen.sh<br>
-gs/base/Makefile.in<br>
-gs/base/configure.ac<br>
-gs/base/contrib.mak<br>
-gs/base/devs.mak<br>
-gs/base/gdev3852.c<br>
-gs/base/gdev3b1.c<br>
-gs/base/gdev4081.c<br>
-gs/base/gdev4693.c<br>
-gs/base/gdev8510.c<br>
-gs/base/gdev8bcm.c<br>
-gs/base/gdev8bcm.h<br>
-gs/base/gdevadmp.c<br>
-gs/base/gdevagl.c<br>
-gs/base/gdevagl.h<br>
-gs/base/gdevatx.c<br>
-gs/base/gdevbit.c<br>
-gs/base/gdevbj10.c<br>
-gs/base/gdevbjc.h<br>
-gs/base/gdevbjcl.c<br>
-gs/base/gdevbjcl.h<br>
-gs/base/gdevbmp.c<br>
-gs/base/gdevbmp.h<br>
-gs/base/gdevbmpa.c<br>
-gs/base/gdevbmpc.c<br>
-gs/base/gdevccr.c<br>
-gs/base/gdevcdj.c<br>
-gs/base/gdevcfax.c<br>
-gs/base/gdevcif.c<br>
-gs/base/gdevclj.c<br>
-gs/base/gdevcljc.c<br>
-gs/base/gdevcp50.c<br>
-gs/base/gdevcslw.c<br>
-gs/base/gdevdfax.c<br>
-gs/base/gdevdjet.c<br>
-gs/base/gdevdjtc.c<br>
-gs/base/gdevdljm.c<br>
-gs/base/gdevdljm.h<br>
-gs/base/gdevdm24.c<br>
-gs/base/gdevdsp.c<br>
-gs/base/gdevdsp.h<br>
-gs/base/gdevdsp2.h<br>
-gs/base/gdevepsc.c<br>
-gs/base/gdevepsn.c<br>
-gs/base/gdevescp.c<br>
-gs/base/gdevevga.c<br>
-gs/base/gdevfax.c<br>
-gs/base/gdevfax.h<br>
-gs/base/gdevherc.c<br>
-gs/base/gdevhl7x.c<br>
-gs/base/gdevicov.c<br>
-gs/base/gdevifno.c<br>
-gs/base/gdevijs.c<br>
-gs/base/gdevimgn.c<br>
-gs/base/gdevjbig2.c<br>
-gs/base/gdevjpeg.c<br>
-gs/base/gdevjpx.c<br>
-gs/base/gdevl256.c<br>
-gs/base/gdevl31s.c<br>
-gs/base/gdevlbp8.c<br>
-gs/base/gdevlj56.c<br>
-gs/base/gdevlp8k.c<br>
-gs/base/gdevlxm.c<br>
-gs/base/gdevmac.c<br>
-gs/base/gdevmac.h<br>
-gs/base/gdevmacpictop.h<br>
-gs/base/gdevmacttf.h<br>
-gs/base/gdevmeds.c<br>
-gs/base/gdevmeds.h<br>
-gs/base/gdevmgr.c<br>
-gs/base/gdevmgr.h<br>
-gs/base/gdevmiff.c<br>
-gs/base/gdevmswn.c<br>
-gs/base/gdevmswn.h<br>
-gs/base/gdevmsxf.c<br>
-gs/base/gdevn533.c<br>
-gs/base/gdevo182.c<br>
-gs/base/gdevokii.c<br>
-gs/base/gdevos2p.c<br>
-gs/base/gdevp2up.c<br>
-gs/base/gdevpbm.c<br>
-gs/base/gdevpcfb.c<br>
-gs/base/gdevpcfb.h<br>
-gs/base/gdevpcl.c<br>
-gs/base/gdevpcl.h<br>
-gs/base/gdevpcx.c<br>
-gs/base/gdevpdf.c<br>
-gs/base/gdevpdfb.c<br>
-gs/base/gdevpdfb.h<br>
-gs/base/gdevpdfc.c<br>
-gs/base/gdevpdfc.h<br>
-gs/base/gdevpdfd.c<br>
-gs/base/gdevpdfe.c<br>
-gs/base/gdevpdfg.c<br>
-gs/base/gdevpdfg.h<br>
-gs/base/gdevpdfi.c<br>
-gs/base/gdevpdfj.c<br>
-gs/base/gdevpdfk.c<br>
-gs/base/gdevpdfm.c<br>
-gs/base/gdevpdfo.c<br>
-gs/base/gdevpdfo.h<br>
-gs/base/gdevpdfp.c<br>
-gs/base/gdevpdfr.c<br>
-gs/base/gdevpdft.c<br>
-gs/base/gdevpdfu.c<br>
-gs/base/gdevpdfv.c<br>
-gs/base/gdevpdfx.h<br>
-gs/base/gdevpdt.c<br>
-gs/base/gdevpdt.h<br>
-gs/base/gdevpdtb.c<br>
-gs/base/gdevpdtb.h<br>
-gs/base/gdevpdtc.c<br>
-gs/base/gdevpdtd.c<br>
-gs/base/gdevpdtd.h<br>
-gs/base/gdevpdte.c<br>
-gs/base/gdevpdtf.c<br>
-gs/base/gdevpdtf.h<br>
-gs/base/gdevpdti.c<br>
-gs/base/gdevpdti.h<br>
-gs/base/gdevpdts.c<br>
-gs/base/gdevpdts.h<br>
-gs/base/gdevpdtt.c<br>
-gs/base/gdevpdtt.h<br>
-gs/base/gdevpdtv.c<br>
-gs/base/gdevpdtv.h<br>
-gs/base/gdevpdtw.c<br>
-gs/base/gdevpdtw.h<br>
-gs/base/gdevpdtx.h<br>
-gs/base/gdevpe.c<br>
-gs/base/gdevperm.c<br>
-gs/base/gdevphex.c<br>
-gs/base/gdevpjet.c<br>
-gs/base/gdevplan.c<br>
-gs/base/gdevplib.c<br>
-gs/base/gdevplib.h<br>
-gs/base/gdevpm.h<br>
-gs/base/gdevpng.c<br>
-gs/base/gdevps.c<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevpsdf.h<br>
-gs/base/gdevpsdi.c<br>
-gs/base/gdevpsdp.c<br>
-gs/base/gdevpsds.c<br>
-gs/base/gdevpsds.h<br>
-gs/base/gdevpsdu.c<br>
-gs/base/gdevpsf.h<br>
-gs/base/gdevpsf1.c<br>
-gs/base/gdevpsf2.c<br>
-gs/base/gdevpsfm.c<br>
-gs/base/gdevpsft.c<br>
-gs/base/gdevpsfu.c<br>
-gs/base/gdevpsfx.c<br>
-gs/base/gdevpsim.c<br>
-gs/base/gdevpsu.c<br>
-gs/base/gdevpsu.h<br>
-gs/base/gdevpx.c<br>
-gs/base/gdevpxut.c<br>
-gs/base/gdevpxut.h<br>
-gs/base/gdevrinkj.c<br>
-gs/base/gdevs3ga.c<br>
-gs/base/gdevsco.c<br>
-gs/base/gdevsgi.c<br>
-gs/base/gdevsgi.h<br>
-gs/base/gdevsj48.c<br>
-gs/base/gdevsnfb.c<br>
-gs/base/gdevsppr.c<br>
-gs/base/gdevstc.c<br>
-gs/base/gdevstc.h<br>
-gs/base/gdevstc1.c<br>
-gs/base/gdevstc2.c<br>
-gs/base/gdevstc3.c<br>
-gs/base/gdevstc4.c<br>
-gs/base/gdevsun.c<br>
-gs/base/gdevsunr.c<br>
-gs/base/gdevsvg.c<br>
-gs/base/gdevsvga.c<br>
-gs/base/gdevsvga.h<br>
-gs/base/gdevtfax.c<br>
-gs/base/gdevtfax.h<br>
-gs/base/gdevtfnx.c<br>
-gs/base/gdevtifs.c<br>
-gs/base/gdevtifs.h<br>
-gs/base/gdevtknk.c<br>
-gs/base/gdevtrac.c<br>
-gs/base/gdevtsep.c<br>
-gs/base/gdevtxtw.c<br>
-gs/base/gdevupd.c<br>
-gs/base/gdevvglb.c<br>
-gs/base/gdevwddb.c<br>
-gs/base/gdevwdib.c<br>
-gs/base/gdevwpr2.c<br>
-gs/base/gdevwprn.c<br>
-gs/base/gdevx.c<br>
-gs/base/gdevx.h<br>
-gs/base/gdevxalt.c<br>
-gs/base/gdevxcf.c<br>
-gs/base/gdevxcmp.c<br>
-gs/base/gdevxcmp.h<br>
-gs/base/gdevxini.c<br>
-gs/base/gdevxps.c<br>
-gs/base/gdevxres.c<br>
-gs/base/gxfcopy.c<br>
-gs/base/gxfcopy.h<br>
-gs/base/lib.mak<br>
-gs/base/macos-mcp.mak<br>
-gs/base/macosx.mak<br>
-gs/base/minftrsz.c<br>
-gs/base/minftrsz.h<br>
-gs/base/msvclib.mak<br>
-gs/base/opdfread.h<br>
-gs/base/openvms.mak<br>
-gs/base/openvms.mmk<br>
-gs/base/pcwin.mak<br>
-gs/base/rinkj/evenbetter-rll.c<br>
-gs/base/rinkj/evenbetter-rll.h<br>
-gs/base/rinkj/rinkj-byte-stream.c<br>
-gs/base/rinkj/rinkj-byte-stream.h<br>
-gs/base/rinkj/rinkj-config.c<br>
-gs/base/rinkj/rinkj-config.h<br>
-gs/base/rinkj/rinkj-device.c<br>
-gs/base/rinkj/rinkj-device.h<br>
-gs/base/rinkj/rinkj-dither.c<br>
-gs/base/rinkj/rinkj-dither.h<br>
-gs/base/rinkj/rinkj-epson870.c<br>
-gs/base/rinkj/rinkj-epson870.h<br>
-gs/base/rinkj/rinkj-screen-eb.c<br>
-gs/base/rinkj/rinkj-screen-eb.h<br>
-gs/base/ugcclib.mak<br>
-gs/base/unix-dll.mak<br>
-gs/base/unix-gcc.mak<br>
-gs/base/unixansi.mak<br>
-gs/base/whitelst.c<br>
-gs/base/whitelst.h<br>
-gs/base/winlib.mak<br>
-gs/configure.ac<br>
-gs/contrib/contrib.mak<br>
-gs/devices/contrib.mak<br>
-gs/devices/devs.mak<br>
-gs/devices/gdev3852.c<br>
-gs/devices/gdev3b1.c<br>
-gs/devices/gdev4081.c<br>
-gs/devices/gdev4693.c<br>
-gs/devices/gdev8510.c<br>
-gs/devices/gdev8bcm.c<br>
-gs/devices/gdev8bcm.h<br>
-gs/devices/gdevadmp.c<br>
-gs/devices/gdevatx.c<br>
-gs/devices/gdevbit.c<br>
-gs/devices/gdevbj10.c<br>
-gs/devices/gdevbjc.h<br>
-gs/devices/gdevbjcl.c<br>
-gs/devices/gdevbjcl.h<br>
-gs/devices/gdevbmp.c<br>
-gs/devices/gdevbmp.h<br>
-gs/devices/gdevbmpa.c<br>
-gs/devices/gdevbmpc.c<br>
-gs/devices/gdevccr.c<br>
-gs/devices/gdevcdj.c<br>
-gs/devices/gdevcfax.c<br>
-gs/devices/gdevcif.c<br>
-gs/devices/gdevclj.c<br>
-gs/devices/gdevcljc.c<br>
-gs/devices/gdevcp50.c<br>
-gs/devices/gdevcslw.c<br>
-gs/devices/gdevdfax.c<br>
-gs/devices/gdevdjet.c<br>
-gs/devices/gdevdjtc.c<br>
-gs/devices/gdevdljm.c<br>
-gs/devices/gdevdljm.h<br>
-gs/devices/gdevdm24.c<br>
-gs/devices/gdevdsp.c<br>
-gs/devices/gdevdsp.h<br>
-gs/devices/gdevdsp2.h<br>
-gs/devices/gdevepsc.c<br>
-gs/devices/gdevepsn.c<br>
-gs/devices/gdevescp.c<br>
-gs/devices/gdevevga.c<br>
-gs/devices/gdevfax.c<br>
-gs/devices/gdevfax.h<br>
-gs/devices/gdevherc.c<br>
-gs/devices/gdevhl7x.c<br>
-gs/devices/gdevicov.c<br>
-gs/devices/gdevifno.c<br>
-gs/devices/gdevijs.c<br>
-gs/devices/gdevimgn.c<br>
-gs/devices/gdevjbig2.c<br>
-gs/devices/gdevjpeg.c<br>
-gs/devices/gdevjpx.c<br>
-gs/devices/gdevl256.c<br>
-gs/devices/gdevl31s.c<br>
-gs/devices/gdevlbp8.c<br>
-gs/devices/gdevlp8k.c<br>
-gs/devices/gdevlxm.c<br>
-gs/devices/gdevmac.c<br>
-gs/devices/gdevmac.h<br>
-gs/devices/gdevmacpictop.h<br>
-gs/devices/gdevmacttf.h<br>
-gs/devices/gdevmeds.c<br>
-gs/devices/gdevmeds.h<br>
-gs/devices/gdevmgr.c<br>
-gs/devices/gdevmgr.h<br>
-gs/devices/gdevmiff.c<br>
-gs/devices/gdevmswn.c<br>
-gs/devices/gdevmswn.h<br>
-gs/devices/gdevmsxf.c<br>
-gs/devices/gdevn533.c<br>
-gs/devices/gdevo182.c<br>
-gs/devices/gdevokii.c<br>
-gs/devices/gdevos2p.c<br>
-gs/devices/gdevp2up.c<br>
-gs/devices/gdevpbm.c<br>
-gs/devices/gdevpcfb.c<br>
-gs/devices/gdevpcfb.h<br>
-gs/devices/gdevpcl.c<br>
-gs/devices/gdevpcl.h<br>
-gs/devices/gdevpcx.c<br>
-gs/devices/gdevpe.c<br>
-gs/devices/gdevperm.c<br>
-gs/devices/gdevphex.c<br>
-gs/devices/gdevpjet.c<br>
-gs/devices/gdevplan.c<br>
-gs/devices/gdevplib.c<br>
-gs/devices/gdevplib.h<br>
-gs/devices/gdevpm.h<br>
-gs/devices/gdevpng.c<br>
-gs/devices/gdevpsd.c<br>
-gs/devices/gdevpsim.c<br>
-gs/devices/gdevrinkj.c<br>
-gs/devices/gdevs3ga.c<br>
-gs/devices/gdevsco.c<br>
-gs/devices/gdevsgi.c<br>
-gs/devices/gdevsgi.h<br>
-gs/devices/gdevsj48.c<br>
-gs/devices/gdevsnfb.c<br>
-gs/devices/gdevsppr.c<br>
-gs/devices/gdevstc.c<br>
-gs/devices/gdevstc.h<br>
-gs/devices/gdevstc1.c<br>
-gs/devices/gdevstc2.c<br>
-gs/devices/gdevstc3.c<br>
-gs/devices/gdevstc4.c<br>
-gs/devices/gdevsun.c<br>
-gs/devices/gdevsunr.c<br>
-gs/devices/gdevsvga.c<br>
-gs/devices/gdevsvga.h<br>
-gs/devices/gdevtfax.c<br>
-gs/devices/gdevtfax.h<br>
-gs/devices/gdevtfnx.c<br>
-gs/devices/gdevtifs.c<br>
-gs/devices/gdevtifs.h<br>
-gs/devices/gdevtknk.c<br>
-gs/devices/gdevtrac.c<br>
-gs/devices/gdevtsep.c<br>
-gs/devices/gdevupd.c<br>
-gs/devices/gdevvglb.c<br>
-gs/devices/gdevwddb.c<br>
-gs/devices/gdevwdib.c<br>
-gs/devices/gdevwpr2.c<br>
-gs/devices/gdevwprn.c<br>
-gs/devices/gdevx.c<br>
-gs/devices/gdevx.h<br>
-gs/devices/gdevxalt.c<br>
-gs/devices/gdevxcf.c<br>
-gs/devices/gdevxcmp.c<br>
-gs/devices/gdevxcmp.h<br>
-gs/devices/gdevxini.c<br>
-gs/devices/gdevxres.c<br>
-gs/devices/gxfcopy.c<br>
-gs/devices/gxfcopy.h<br>
-gs/devices/minftrsz.c<br>
-gs/devices/minftrsz.h<br>
-gs/devices/rinkj/evenbetter-rll.c<br>
-gs/devices/rinkj/evenbetter-rll.h<br>
-gs/devices/rinkj/rinkj-byte-stream.c<br>
-gs/devices/rinkj/rinkj-byte-stream.h<br>
-gs/devices/rinkj/rinkj-config.c<br>
-gs/devices/rinkj/rinkj-config.h<br>
-gs/devices/rinkj/rinkj-device.c<br>
-gs/devices/rinkj/rinkj-device.h<br>
-gs/devices/rinkj/rinkj-dither.c<br>
-gs/devices/rinkj/rinkj-dither.h<br>
-gs/devices/rinkj/rinkj-epson870.c<br>
-gs/devices/rinkj/rinkj-epson870.h<br>
-gs/devices/rinkj/rinkj-screen-eb.c<br>
-gs/devices/rinkj/rinkj-screen-eb.h<br>
-gs/devices/vector/gdevagl.c<br>
-gs/devices/vector/gdevagl.h<br>
-gs/devices/vector/gdevlj56.c<br>
-gs/devices/vector/gdevpdf.c<br>
-gs/devices/vector/gdevpdfb.c<br>
-gs/devices/vector/gdevpdfb.h<br>
-gs/devices/vector/gdevpdfc.c<br>
-gs/devices/vector/gdevpdfc.h<br>
-gs/devices/vector/gdevpdfd.c<br>
-gs/devices/vector/gdevpdfe.c<br>
-gs/devices/vector/gdevpdfg.c<br>
-gs/devices/vector/gdevpdfg.h<br>
-gs/devices/vector/gdevpdfi.c<br>
-gs/devices/vector/gdevpdfj.c<br>
-gs/devices/vector/gdevpdfk.c<br>
-gs/devices/vector/gdevpdfm.c<br>
-gs/devices/vector/gdevpdfo.c<br>
-gs/devices/vector/gdevpdfo.h<br>
-gs/devices/vector/gdevpdfp.c<br>
-gs/devices/vector/gdevpdfr.c<br>
-gs/devices/vector/gdevpdft.c<br>
-gs/devices/vector/gdevpdfu.c<br>
-gs/devices/vector/gdevpdfv.c<br>
-gs/devices/vector/gdevpdfx.h<br>
-gs/devices/vector/gdevpdt.c<br>
-gs/devices/vector/gdevpdt.h<br>
-gs/devices/vector/gdevpdtb.c<br>
-gs/devices/vector/gdevpdtb.h<br>
-gs/devices/vector/gdevpdtc.c<br>
-gs/devices/vector/gdevpdtd.c<br>
-gs/devices/vector/gdevpdtd.h<br>
-gs/devices/vector/gdevpdte.c<br>
-gs/devices/vector/gdevpdtf.c<br>
-gs/devices/vector/gdevpdtf.h<br>
-gs/devices/vector/gdevpdti.c<br>
-gs/devices/vector/gdevpdti.h<br>
-gs/devices/vector/gdevpdts.c<br>
-gs/devices/vector/gdevpdts.h<br>
-gs/devices/vector/gdevpdtt.c<br>
-gs/devices/vector/gdevpdtt.h<br>
-gs/devices/vector/gdevpdtv.c<br>
-gs/devices/vector/gdevpdtv.h<br>
-gs/devices/vector/gdevpdtw.c<br>
-gs/devices/vector/gdevpdtw.h<br>
-gs/devices/vector/gdevpdtx.h<br>
-gs/devices/vector/gdevps.c<br>
-gs/devices/vector/gdevpsdf.h<br>
-gs/devices/vector/gdevpsdi.c<br>
-gs/devices/vector/gdevpsdp.c<br>
-gs/devices/vector/gdevpsds.c<br>
-gs/devices/vector/gdevpsds.h<br>
-gs/devices/vector/gdevpsdu.c<br>
-gs/devices/vector/gdevpsf.h<br>
-gs/devices/vector/gdevpsf1.c<br>
-gs/devices/vector/gdevpsf2.c<br>
-gs/devices/vector/gdevpsfm.c<br>
-gs/devices/vector/gdevpsft.c<br>
-gs/devices/vector/gdevpsfu.c<br>
-gs/devices/vector/gdevpsfx.c<br>
-gs/devices/vector/gdevpsu.c<br>
-gs/devices/vector/gdevpsu.h<br>
-gs/devices/vector/gdevpx.c<br>
-gs/devices/vector/gdevpxut.c<br>
-gs/devices/vector/gdevpxut.h<br>
-gs/devices/vector/gdevsvg.c<br>
-gs/devices/vector/gdevtxtw.c<br>
-gs/devices/vector/gdevxps.c<br>
-gs/devices/vector/opdfread.h<br>
-gs/devices/vector/whitelst.c<br>
-gs/devices/vector/whitelst.h<br>
-gs/psi/int.mak<br>
-gs/psi/msvc.mak<br>
-gs/psi/winint.mak<br>
-gs/psi/zfapi.c<br>
-main/pcl6_gcc.mak<br>
-main/pcl6_msvc.mak<br>
-pl/pl.mak<br>
-svg/svg_gcc.mak<br>
-svg/svg_msvc.mak<br>
-xps/xps_gcc.mak<br>
-xps/xps_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-06 01:43:29 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6207ac0c8158b28bd2e9ff8633dd94fc91d98057">6207ac0c8158b28bd2e9ff8633dd94fc91d98057</a>
-<blockquote>
-<p>
- Bug 693659: fix integer overflow in Type 2 font parser.<br>
-<br>
-gs/psi/zfont2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-06 00:44:26 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4147f14b1460c35620cb117821fcb01f3b7a1e3d">4147f14b1460c35620cb117821fcb01f3b7a1e3d</a>
-<blockquote>
-<p>
- Bug 693659: Improve argument validation in ArcfourDecode operator.<br>
-<br>
-gs/psi/zfarc4.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-05 19:08:49 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=70ba7029bc563bab7a24bff27decad5feceba4f8">70ba7029bc563bab7a24bff27decad5feceba4f8</a>
-<blockquote>
-<p>
- Fix indeterminate page background with plank and comparefiles/104-01.ps<br>
-<br>
- This file uses the PS erasepage operator to paint the background to<br>
- a non-white value. The mem_planar_fill_rectangle_hl_color used the<br>
- 'devn' colors without checking the type. With the plank device these<br>
- colors were 'pure' or 'ht_binary' so the devn values were bogus.<br>
- If the color type was binary, an address was used as color values.<br>
- A pure color was OK as long as the number of planes did not exceed<br>
- the size of the gx_color_index and the bytes in the color index<br>
- corresponded to the planes.<br>
-<br>
- Also add warning (DEBUG build) if mem_planar_strip_tile_rect_devn<br>
- ever uses non-devn colors.<br>
-<br>
- Progressions with 104-01.ps, 12-05.PS, 12-07B.PS and 29-07A.PS<br>
-<br>
-gs/base/gdevmpla.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-05 22:24:56 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=04986f44befa8d71e64a94fafc31ee000c48cc78">04986f44befa8d71e64a94fafc31ee000c48cc78</a>
-<blockquote>
-<p>
- Bug 693659: Add check for 0 pointer to zlib message.<br>
-<br>
-gs/base/szlibd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-05 11:52:58 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=675682cee0a3dc6cd346084489712505f5ff3ee4">675682cee0a3dc6cd346084489712505f5ff3ee4</a>
-<blockquote>
-<p>
- Fix image_color_cache_init to avoid using out of range data.<br>
-<br>
- If the indexed color space hival is less than the num_entries in<br>
- the color_cache, the code would just convert using values past<br>
- the end of the lookup data, and image_render_mono_ht did not<br>
- clamp values either.<br>
-<br>
- Seen with pbmraw sumatra/x_-_integer_overflow_in_fz_newpixmap.pdf<br>
- This file shows clear progression, some other files show differences<br>
- but all seem trivial and are pcl files. Maybe a ROP problem.<br>
-<br>
-gs/base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-05 12:48:14 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=69858556e95a2762ef48109ab7b265f2e87e2272">69858556e95a2762ef48109ab7b265f2e87e2272</a>
-<blockquote>
-<p>
- Bug 693659: Fix access to /Colorants entry in DeviceN CSA.<br>
-<br>
-gs/psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-05 01:40:11 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0950755f0dc971ebe2387a587688075751eb0905">0950755f0dc971ebe2387a587688075751eb0905</a>
-<blockquote>
-<p>
- Bug 693659: Fix underflow checking in Type 2 parser.<br>
-<br>
-gs/psi/zfont2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-05 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=486ee97ee8e11cc1edce8998d0a85907c16721f5">486ee97ee8e11cc1edce8998d0a85907c16721f5</a>
-<blockquote>
-<p>
- Bug 693674: introduce memory limit for UFST bitmaps<br>
-<br>
- Previously, UFST had &quot;unlimited&quot; memory for glyph bitmaps. This appears to allow<br>
- bitmaps large enough to cause an overflow in the UFST rendering code.<br>
-<br>
- Now there is a limit on the memory UFST can allocate for a bitmap (tied to the<br>
- maximum &quot;interim&quot; bitmap Ghostscript will allocate when creating an entry for<br>
- the glyph cache).<br>
-<br>
- This has two benefits: prevents the crash by avoiding the rendering overflow in<br>
- UFST, and prevents us from pointlessly allocating huge glyph bitmaps in cases<br>
- where we really want to render from an outline anyway.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gxchar.c<br>
-gs/base/gxchar.h<br>
-gs/base/gxfapi.c<br>
-gs/base/gxfapiu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-05 10:29:02 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=26b50d7d18681f25ae0a435830fb291814b889b1">26b50d7d18681f25ae0a435830fb291814b889b1</a>
-<blockquote>
-<p>
- pdfwrite - new colour code, fix image conversion to base space<br>
-<br>
- An oversight in the code led to images (other than imagemasks) not being<br>
- converted to the specified process colour.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-05 10:08:54 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db3494dbb682781aca7651ffc60d80a8eeefec72">db3494dbb682781aca7651ffc60d80a8eeefec72</a>
-<blockquote>
-<p>
- pdfwrite - new colour code fix a Seg fault with Sep/DeviceN<br>
-<br>
- When converting Separation or DeviceN spaces to a device space we actually<br>
- (currently) write them as ICCBased spaces. But the 'convert' flag was left<br>
- at non-zero, leading to us attempting to convert. Since the original space<br>
- wasn't recorded, this caused a seg fault.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-04 20:43:19 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1625318452fd5e8045b69ed440f17ce58625efce">1625318452fd5e8045b69ed440f17ce58625efce</a>
-<blockquote>
-<p>
- Further improvement and cleanup on clist_copy_planes and the reader.<br>
-<br>
- The clist writer clist_copy_planes (should be / is) never called with<br>
- plane_height == 0, so we pre-calculate the maxheight and use that to<br>
- clamp re.height, rather than doing the /=2 that copy_mono does. Also<br>
- use data_bits_size rather than cbuf_size (even though they are currently<br>
- the same) as the limit for holding all planes of uncmopressed data (for<br>
- the reader call to copy_planes -- NOT including the compression tag byte)<br>
-<br>
- Also add documentation for copy_planes to doc/Drivers.htm<br>
-<br>
- 0002-Change-fill_rectanble_hl_color-calling-sequence-to-i.patch<br>
-<br>
-gs/base/gxclbits.c<br>
-gs/base/gxcldev.h<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclrast.c<br>
-gs/base/gxclrect.c<br>
-gs/base/gxht_thresh.c<br>
-gs/base/gxp1fill.c<br>
-gs/doc/Drivers.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-04 17:52:27 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b4420888ddc9764177a89c1c3d36c64a1253f7b6">b4420888ddc9764177a89c1c3d36c64a1253f7b6</a>
-<blockquote>
-<p>
- Bug 693658: Add DSC continuation support to all operators.<br>
-<br>
-gs/psi/dscparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-04 21:45:02 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=498b2eaa9c0476ba7a5223b554a620776a831442">498b2eaa9c0476ba7a5223b554a620776a831442</a>
-<blockquote>
-<p>
- pdfwrite - fix a compiler warning<br>
-<br>
-gs/base/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-04 15:04:07 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e1c4496d4b0706d125b43dc9b0a8e3c4a1c93e50">e1c4496d4b0706d125b43dc9b0a8e3c4a1c93e50</a>
-<blockquote>
-<p>
- pdfwrite/ps2write - new colour work correct handling of complex /Indexed spaces<br>
-<br>
- Fix conversion of complex Indexed spaces to device spaces. There are some<br>
- odd differences, which I think are due to some kind of rouding in the<br>
- Indexed spaces, need to consult with Michael.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-04 09:53:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2aab19e3b28a001b0f3d3b1424ee54078f420afb">2aab19e3b28a001b0f3d3b1424ee54078f420afb</a>
-<blockquote>
-<p>
- pdfwrite/ps2write - New colour conversion, fix default space detection<br>
-<br>
- When we get a /Indexed space, we check the base space and if it is an ICC<br>
- space we further check to see if it is a space which we substituted for<br>
- one of the device spaces, and if the current strategy means we should not<br>
- convert such a space.<br>
-<br>
- Some missing braces meant that if the test failed we didn't write the colour<br>
- space at all.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-04 09:50: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=4b7bdcea310131174c051bf6f92b9dc2416bc9c3">4b7bdcea310131174c051bf6f92b9dc2416bc9c3</a>
-<blockquote>
-<p>
- pdfwrite/ps2write - New colour code, remove suprious checks<br>
-<br>
- There are some checks against colour space conversions which are appropriate<br>
- for the old code, but not the new, and which fall back to 'LeaveColorUnchanged'<br>
- if triggered.<br>
-<br>
- Only perform these checks if we are using the old colour conversion code to<br>
- prevent the warning and fallback.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gdevpdfc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-03 15:35:16 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef4a83251dc9e404deba855ff4838f405b81db3d">ef4a83251dc9e404deba855ff4838f405b81db3d</a>
-<blockquote>
-<p>
- Fix clist problems with writing and reading bitmaps when planes &gt; 1<br>
-<br>
- When writing, plane data size did not include the height, so sometimes<br>
- cmd_write_buffer would be called between writing the planes. During<br>
- reading, we need to top up the cbuf for all planes including the first<br>
- (pln==0). Also fix some formatting issues.<br>
-<br>
-gs/base/gxclrast.c<br>
-gs/base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-02 20:48:34 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da11422e0d11cad9a0de1615f11f525a1788c442">da11422e0d11cad9a0de1615f11f525a1788c442</a>
-<blockquote>
-<p>
- Add the ability to write HSI compressed Raw files to fuzzy.c.<br>
-<br>
-gs/toolbin/tests/fuzzy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-02 21:06:19 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b87b6dc49e4720cb8d4da0715a823263e84c5e85">b87b6dc49e4720cb8d4da0715a823263e84c5e85</a>
-<blockquote>
-<p>
- Merge branch 'newbranch' - should have been names xpswrite_branch.<br>
-<br>
-gs/base/Makefile.in<br>
-gs/base/configure.ac<br>
-gs/psi/msvc.mak<br>
-main/pcl6_gcc.mak<br>
-main/pcl6_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-02 20:37:28 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c9c89a9628730bfdbe709023735206deb200b378">c9c89a9628730bfdbe709023735206deb200b378</a>
-<blockquote>
-<p>
- Fix problem with multipage output in xpswrite.<br>
-<br>
- It turns out that any device graphics routine has to access the stream<br>
- through the vector device call gdev_vector_stream() to guarantee<br>
- beginpage will be called. A better solution to this problem would be<br>
- to decouple the begin page procedure call and accessing the current<br>
- stream.<br>
-<br>
-gs/base/gdevxps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-02 19:54:57 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8b5840b6e797f2fa6c81c409dcbc14e51b207ab6">8b5840b6e797f2fa6c81c409dcbc14e51b207ab6</a>
-<blockquote>
-<p>
- A first rough cut of the XPS writing device.<br>
-<br>
- This version is limited to high level path drawing and rectangles so<br>
- it is quite limited.<br>
-<br>
-gs/base/Makefile.in<br>
-gs/base/configure.ac<br>
-gs/base/devs.mak<br>
-gs/base/gdevxps.c<br>
-gs/psi/msvc.mak<br>
-main/pcl6_gcc.mak<br>
-main/pcl6_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-03-01 00:56:04 -0500
-</strong>
-<br>Math &lt;mlafon@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7e04ea83379ea210c227f87c9e859e0a3ab2ebfd">7e04ea83379ea210c227f87c9e859e0a3ab2ebfd</a>
-<blockquote>
-<p>
- Bug 693507: check for out-of-bounds access<br>
-<br>
- Report error in get_next_word() functions on out-of-bounds access and<br>
- handling of this error in both arithmetic and huffman decoders.<br>
-<br>
- When decoding a corrupted document, the arithmetic decoder can hit the end<br>
- of the Jbig2 stream. The problem was that get_next_word() returned 0 in<br>
- that case and that this lead to an infinite loop.<br>
-<br>
-gs/jbig2dec/jbig2.c<br>
-gs/jbig2dec/jbig2_arith.c<br>
-gs/jbig2dec/jbig2_arith_iaid.c<br>
-gs/jbig2dec/jbig2_arith_int.c<br>
-gs/jbig2dec/jbig2_generic.c<br>
-gs/jbig2dec/jbig2_huffman.c<br>
-gs/jbig2dec/jbig2_huffman.h<br>
-gs/jbig2dec/jbig2_priv.h<br>
-gs/jbig2dec/jbig2_refinement.c<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-gs/jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-28 13:57:05 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9173f87798321425604340241a2ce3bf20ed9cf0">9173f87798321425604340241a2ce3bf20ed9cf0</a>
-<blockquote>
-<p>
- Remove debug statement inadvertently committed with SMask fix.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-28 15:58:39 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3037c72c3fd81f11813c3a7fdc94a870e17e5c30">3037c72c3fd81f11813c3a7fdc94a870e17e5c30</a>
-<blockquote>
-<p>
- Bug 693615: fix typos in utf8 conversion.<br>
-<br>
- Thanks to Chris Dance for pointing these out.<br>
-<br>
-gs/base/gp_wutf8.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-26 12:04:54 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a4e3e55ca44958a72a3879a565255a2acba8eae5">a4e3e55ca44958a72a3879a565255a2acba8eae5</a>
-<blockquote>
-<p>
- Bug 693115: Fix Smask handling in the interpreter and prevent multiple rendering<br>
-<br>
- The SMask was being rendered before every object, and a subsequent SMask<br>
- set with a 'gs' operator (ExtGState) was being rendered with a previous<br>
- SMask rather than simply replacing it. By setting the SoftMask to a new<br>
- value (neither //null, nor the paramdict) we can still detect that a<br>
- SMask is in effect, and thus create transparency groups as needed, but<br>
- we no longer render the mask multiple times, improving performance.<br>
- In .execmaskgroup, after rendering the SMask into a mask_stack maskbuf,<br>
- zap it, using 'where' to find the ExtGState dictionary that holds it.<br>
-<br>
- All differences seen with cluster regression are either progressions<br>
- or are very minor except sumatra/VOX.pdf with pdfwrite, but this was<br>
- broken previously. Now it's still broken, but differently.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-27 14:00:16 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0df3602a923dff2e834fdd0191b6fd2b8ef523b5">0df3602a923dff2e834fdd0191b6fd2b8ef523b5</a>
-<blockquote>
-<p>
- Fix Profile build on Windows<br>
-<br>
- It seems that the profile: target isn't being recognised in the makefile.<br>
- Possibly because profile has special meaning to nmake? I cannot see an<br>
- alternative profile: target anywhere in our makefiles.<br>
-<br>
- As a fix, I have added profile-target: and we now invoke that.<br>
-<br>
-gs/ghostscript.vcproj<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-26 18:23:26 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d6f83c3aec8ad94b013df125f9feae719c52b941">d6f83c3aec8ad94b013df125f9feae719c52b941</a>
-<blockquote>
-<p>
- Fix for an issue found in Bug 69365. Color space linearity check in shading code.<br>
-<br>
- The transparency device, if one exists should be used with this check.<br>
-<br>
-gs/base/gxshade6.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-26 13:44:47 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1f4996e6547bb89cbd92868224a2101c773c886b">1f4996e6547bb89cbd92868224a2101c773c886b</a>
-<blockquote>
-<p>
- Avoid warning in gp_local_arg_encoding_get_codepoint.<br>
-<br>
-gs/base/gp_win32.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-25 16:44:35 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d62df7283d8618f92b2956b1d36e23c9f0075dd3">d62df7283d8618f92b2956b1d36e23c9f0075dd3</a>
-<blockquote>
-<p>
- txtwrite - fix fallback to single characters.<br>
-<br>
- There were some serious logical flaws in the Unicode creation, when there<br>
- is no Unicode information available and we try to manufacture some.<br>
-<br>
- The glyph name matching was completely broken, and not only failed to match<br>
- glyph names but broke the fallback to the original character codes too.<br>
-<br>
- This seems to do a much better job (and no longer crashes either).<br>
-<br>
- No differences expected, we don't test txtwrite<br>
-<br>
-gs/base/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-25 08:22:15 -0800
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ce794d70d543d4d7de8615dcdc249516c05ff87b">ce794d70d543d4d7de8615dcdc249516c05ff87b</a>
-<blockquote>
-<p>
- Bug 693655: Fix valgrind error in stroking.<br>
-<br>
- The code was treating gaps like dashes, which is fine<br>
- except for the fact that gaps have no tangent entry<br>
- and so we were accessing off the end of a buffer in some<br>
- cases.<br>
-<br>
-gs/base/gxstroke.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-25 08:02:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c73f7af0cbd7305d8b61c2f3de973e8f163971d0">c73f7af0cbd7305d8b61c2f3de973e8f163971d0</a>
-<blockquote>
-<p>
- Remove the executable bits from gdevsvg.c permissions.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gdevsvg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-21 16:58:33 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=95f7ded85191aa93f0c6792cb7dccc0447c698bd">95f7ded85191aa93f0c6792cb7dccc0447c698bd</a>
-<blockquote>
-<p>
- Fix PXL PassThrough test file failure.<br>
-<br>
- C705.BIN failed due to unitialized PCL state variables when switching<br>
- from PXL to PCL mode. Certainly this problem is a regression and must<br>
- have happened when the new variables were added to PCL, but the fix is<br>
- straightforward and we dispense with the usual postmortem history<br>
- investigation.<br>
-<br>
-pxl/pxpthr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-21 19:40: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=380f18a0d97ce4b67b26e011aac391a4a1024b8e">380f18a0d97ce4b67b26e011aac391a4a1024b8e</a>
-<blockquote>
-<p>
- Update Make.htm....<br>
-<br>
- .. to reflect that we now support the &quot;ppc&quot; architecture for universal<br>
- binaries on OS X.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/doc/Make.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-21 14:39:25 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=95ce731715a326cd345cd00b93bfc6e2588d8a33">95ce731715a326cd345cd00b93bfc6e2588d8a33</a>
-<blockquote>
-<p>
- Bug 693645: Add a PPC section to the predefined MacOS X arch.h<br>
-<br>
- As a side effect of this, we should now be able to build universal binaries<br>
- that include PPC.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/arch/osx-x86-x86_64-gcc.h<br>
-gs/arch/osx-x86-x86_64-ppc-gcc.h<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-20 12:14:45 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=52be57a96605ad59c0b3146611276e5ee237cb7e">52be57a96605ad59c0b3146611276e5ee237cb7e</a>
-<blockquote>
-<p>
- Bug 693646: Add /PageCount system parameter<br>
-<br>
- This parameter is documented in PLRM 3 and required by some test files.<br>
- Genoa tests also require /PageCount to be non-decreasing even when<br>
- the job switches between pagedevice and nulldevioce.<br>
-<br>
-gs/psi/icontext.c<br>
-gs/psi/icstate.h<br>
-gs/psi/zusparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-19 10:40:32 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f9bb4bd85d718e1db84d5f1e2a7685b0b3288df6">f9bb4bd85d718e1db84d5f1e2a7685b0b3288df6</a>
-<blockquote>
-<p>
- Bug 693631: Handle a missing metric in the FAPI/UFST code.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/fapiufst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-18 11:34:06 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb3f60161917b1dcb04616a2787b4398be467603">fb3f60161917b1dcb04616a2787b4398be467603</a>
-<blockquote>
-<p>
- Bug 693212: Fix strange artifacts with thin lines.<br>
-<br>
- Ghostscript includes special code for 'thin' lines. These are<br>
- a fudge at best.<br>
-<br>
- To avoid dropouts in such lines, caused by the end points of various<br>
- lines not being drawn, we introduced a further fudge (see bug 687721).<br>
- This would restore the end points on lines in some circumstances.<br>
- This fudge causes the effect reported in bug 693212.<br>
-<br>
- The correct fix should be to completely remove thin line support from<br>
- gs, as at best we are fudging a fudge. Given that this seems unlikely<br>
- to happen, we will make do for now by tweaking the fudge introduced<br>
- for bug 687721 so that it triggers in fewer cases (specifically, it<br>
- will never trigger for horizontal or vertical lines).<br>
-<br>
- This is more in keeping with the intention of that change anyway.<br>
-<br>
- This does produce diffs, but no disastrous ones.<br>
-<br>
-gs/base/gdevddrw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-17 15:33:30 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6811e33b61f3434af519b3af5e4d4aec742848ef">6811e33b61f3434af519b3af5e4d4aec742848ef</a>
-<blockquote>
-<p>
- pdf14_compose_group speedups<br>
-<br>
- Following on from previous commit (pdf14_mark_fill_rectangle speedups)<br>
- we apply similar ideas to pdf14_compose_group.<br>
-<br>
- 1) Reverse loops to count downwards.<br>
-<br>
- 2) Increment tos_pixel and nos_pixel after each pixel to avoid having<br>
- to add x to their index everywhere.<br>
-<br>
- 3) Reduce the number of variables used within the loop.<br>
-<br>
- These fixes do not go as far as the pdf14_mark_fill_rectangle ones<br>
- did; there is still scope for more optimisations here.<br>
-<br>
-gs/base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-25 12:39: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=4c1a3aac35f1b4b7711c2e9e2f0f38fe121f51db">4c1a3aac35f1b4b7711c2e9e2f0f38fe121f51db</a>
-<blockquote>
-<p>
- Command line argument character encoding handling rework.<br>
-<br>
- Recap of the situation: Historically gs has always taken command<br>
- line args in whatever the 'local' encoding of that OS is; for windows<br>
- this means they are encoded as per the currently selected codepage;<br>
- for mac/linux this tends to mean utf8.<br>
-<br>
- Similarly, whenever gs goes to access a file, it would pass the filenames<br>
- to the platform specific file opening code - on windows this would<br>
- assume that it was in the local encoding, and on linux would assume<br>
- utf8.<br>
-<br>
- There are downsides to dealing with codepage encoding - not least the<br>
- fact that some files can't be accessed easily, or that the behaviour<br>
- of PS programs may change according to what platform we are on.<br>
-<br>
- Last year we added code so that gs on windows would run as a unicode app,<br>
- and would take the supplied unicode argv and convert to utf8 before<br>
- passing them to the core of gs. The file reading functions would then<br>
- convert from utf8 back to unicode before opening the files. This<br>
- code was disabled by default, but seemed to work well in tests.<br>
-<br>
- 1 objection was raised to this - namely that we were redefining the<br>
- meaning of the entry points (to take utf8 rather than locally encoded<br>
- args) and that this might break legacy code. So, it was suggested that<br>
- we add a new entry point specifically for utf8, and that we deprecate<br>
- the old entry point.<br>
-<br>
- In starting this work, I spotted another problem; gs supports the<br>
- '@file' arg (where more command line args can be given in a file).<br>
- The current solution of rewriting the command line args does not<br>
- address this.<br>
-<br>
- Instead, we update the gsargs arg handling code with a 'get_codepoint'<br>
- function pointer. We update the arg_next function to use this to<br>
- decode the supplied args (or OPTIONS or file contents) into simple<br>
- unicode characters. We then write these into the returned arg<br>
- string as utf8 (or in the case of GS_NO_UTF8 builds, as 8 bit 'clean'<br>
- characters).<br>
-<br>
- This commit adds a new gsapi_set_arg_encoding function, that allows<br>
- the caller to set the encoding used for the args/strings supplied<br>
- to the subsequent functions. By default, 'local' encoding is assumed,<br>
- hence preserving existing behaviour. By calling:<br>
-<br>
- gs_set_arg_encoding(minst, GS_ARG_ENCODING_UTF8);<br>
-<br>
- we can get the UTF8 encoding that we desire. We leave ourselves scope<br>
- for supporting other encodings (such as EBCDIC?) in the future.<br>
-<br>
- The commit also changes it so that the gs always runs with UTF8 encoding<br>
- internally by default; to avoid it, make with 'GS_NO_UTF8=1'.<br>
-<br>
- For the benefit of windows users we implement UTF16LE encoding (i.e.<br>
- wchar_t's). And we expose this through the gsapi level as<br>
- gsapi_run_fileW (and gsapi_init_with_argsW) so that .net can bind<br>
- nicely to it without any casting trickery being required.<br>
-<br>
- Many thanks to Sags for his tireless efforts and comments while<br>
- this work was underway.<br>
-<br>
-gs/base/gdevwpr2.c<br>
-gs/base/gp.h<br>
-gs/base/gp_mswin.c<br>
-gs/base/gp_ntfs.c<br>
-gs/base/gp_wgetv.c<br>
-gs/base/gp_win32.c<br>
-gs/base/gp_wutf8.c<br>
-gs/base/gsargs.c<br>
-gs/base/gsargs.h<br>
-gs/base/gsdll.h<br>
-gs/base/windows_.h<br>
-gs/doc/API.htm<br>
-gs/psi/dwdll.c<br>
-gs/psi/dwdll.h<br>
-gs/psi/dwmain.c<br>
-gs/psi/dwmainc.c<br>
-gs/psi/dwnodll.c<br>
-gs/psi/dwtext.c<br>
-gs/psi/dwtext.h<br>
-gs/psi/gsdll.c<br>
-gs/psi/gsdll2.def<br>
-gs/psi/gsdll32.def<br>
-gs/psi/gsdll32metro.def<br>
-gs/psi/gsdll64.def<br>
-gs/psi/gsdll64metro.def<br>
-gs/psi/iapi.c<br>
-gs/psi/iapi.h<br>
-gs/psi/imainarg.c<br>
-gs/psi/imainarg.h<br>
-gs/psi/iminst.h<br>
-gs/psi/msvc.mak<br>
-language_switch/pspcl6_msvc.mak<br>
-main/pcl6_msvc.mak<br>
-pl/dwmainc.c<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-18 10:28:30 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f8337b57ab9a311f19b86ed0508bdd0fef8fdded">f8337b57ab9a311f19b86ed0508bdd0fef8fdded</a>
-<blockquote>
-<p>
- Remove repeated TAG settings.<br>
-<br>
- Spotted by Henry, these have been there since before time began (or<br>
- since before the git history at least).<br>
-<br>
-gs/base/gspaint.c<br>
-gs/base/gstext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-16 08:41: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=45ae250e1537eaf71367ac306154ee383a437b88">45ae250e1537eaf71367ac306154ee383a437b88</a>
-<blockquote>
-<p>
- Bug 693643: add UseBigTIFF initializers to tiffpack/lzw<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevtfax.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-15 12:19:20 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ed7fe80176219a7755b8c1fe12ff0ae23c536d49">ed7fe80176219a7755b8c1fe12ff0ae23c536d49</a>
-<blockquote>
-<p>
- ps2write - improve handling of complex colour spaces<br>
-<br>
- Part of the rework on colour handling.<br>
-<br>
- When we write complex spaces (eg /Indexed with a /CIEBased space) and we<br>
- use the underlying space (CIEBased) on its own, we only write the underlying<br>
- space once, and refer to it form the complex space.<br>
-<br>
- However if we use the underlying space first, then it gets 'resolved', ie<br>
- it has all the indirect references replaced. When we then use the complex<br>
- space, any references in the underlying space have already been resolved.<br>
-<br>
- Normally this is not a problem because when we try to resolve any indirect<br>
- references, we check to see if the object is an indirect reference by testing<br>
- a number of its features. This works well but *if* the tint transform is<br>
- already resolved, *and* it has fewer than 2 elements, then this would provoke<br>
- an error, because the code did not test the length of the array (after already<br>
- checking its type) before attempting to extract objects form it.<br>
-<br>
- This patch merely checks the array length and assumes it is not an indirect<br>
- reference if the array is too short.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/opdfread.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-31 10:44: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=f39a68d4f1a1ba7674c5d57fa9347e01526fe6c3">f39a68d4f1a1ba7674c5d57fa9347e01526fe6c3</a>
-<blockquote>
-<p>
- Merge the doc updates from 9.07 branch onto master<br>
-<br>
- Update documentation for release candidate 1<br>
-<br>
- Revise release date and product string for 9.07 release.<br>
-<br>
- Color feature news additions.<br>
-<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pdfopt.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-14 10:11:39 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=df71c577b5ff73c0ec8aa632d92ffbe90215e344">df71c577b5ff73c0ec8aa632d92ffbe90215e344</a>
-<blockquote>
-<p>
- ps2write - colour conversion work Indexed colour spaces<br>
-<br>
- When dealing with /Indexed colour spaces we concretize to the base space,<br>
- if there is no ICC profile associated with the base space then we can't<br>
- use it to get the number of colour components to convert, so use the<br>
- base space Num_components instead.<br>
-<br>
- Prevents crashes with Indexed spaces with complex base types (for example<br>
- /CIEBased spaces)<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-14 08:23:49 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=329259532c31ba1b762cdea12d64a332ee0d2cf8">329259532c31ba1b762cdea12d64a332ee0d2cf8</a>
-<blockquote>
-<p>
- pdfwrite - include a definition to silence a compiler warning<br>
-<br>
-gs/base/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-13 13:44:54 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=536e65260e103bc37705f03350ec4b01c37515a0">536e65260e103bc37705f03350ec4b01c37515a0</a>
-<blockquote>
-<p>
- ps2write - detect the 'standard' ICC replacements for device space<br>
-<br>
- When we get an ICCBased space which is our replacement for one of the device<br>
- spaces, detect it and emit the original space instead.<br>
-<br>
- Should lead to many more device spaces being preserved properly when the<br>
- colour conversion strategy is LeaveColorUnchanged.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpdfg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-13 08:17:20 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9220fe3bacb5a8b82cc7a6b25fb8d6db2456b0da">9220fe3bacb5a8b82cc7a6b25fb8d6db2456b0da</a>
-<blockquote>
-<p>
- pdfwrite - silence more compiler warnings<br>
-<br>
-gs/base/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-13 08:17:03 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b4b0bc9738f132c21ea2f5e8a15c60422bee1e5b">b4b0bc9738f132c21ea2f5e8a15c60422bee1e5b</a>
-<blockquote>
-<p>
- pdfwrite - silence some compiler warnings<br>
-<br>
-gs/base/gdevpsds.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-12 12:47:02 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6b6dabb3ce69162c88a616a61f086164cbe91460">6b6dabb3ce69162c88a616a61f086164cbe91460</a>
-<blockquote>
-<p>
- Initial commit of the Stochastic Threshold Array generation program.<br>
-<br>
-gs/toolbin/halftone/gen_stochastic/gen_stochastic.c<br>
-gs/toolbin/halftone/gen_stochastic/gen_stochastic.sln<br>
-gs/toolbin/halftone/gen_stochastic/gen_stochastic.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-12 09:08:03 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=389fbbbc82693094357d95276a4362d701e380b1">389fbbbc82693094357d95276a4362d701e380b1</a>
-<blockquote>
-<p>
- Update header in screen generation code.<br>
-<br>
-gs/toolbin/halftone/gen_ordered/gen_ordered.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-12 14:57:06 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=602e9553829fe955055da289ca010d72e7b86f7f">602e9553829fe955055da289ca010d72e7b86f7f</a>
-<blockquote>
-<p>
- pdfwrite/ps2write - first part of reworking colour management<br>
-<br>
- This commit provides a new path through the pdfwrite code and uses the ICC<br>
- CMS for linework/text, which it did not previously use. The image code already#<br>
- used the CMS, at least in part.<br>
-<br>
- There is a 'place holder' switch called PDFUseOldCMS, defaulting to true<br>
- at the moment, which controls whether we use the old path or the new.<br>
-<br>
- The new colour code already shows marked improvements with the LeaveColorUnchanged,<br>
- in particular /Separation and /Indexed /Device* colour spaces are now preserved<br>
- when going to PostScript, which they were not before.<br>
-<br>
- There are also some changes which affect the embedding of ICCBased spaces, and seem<br>
- to improve a small number of these.<br>
-<br>
- When enabled this does cause a *large* number of differences, however these<br>
- are all either progressions, or very minor differences, invisible to the naked eye.<br>
-<br>
-gs/base/gdevpdfb.h<br>
-gs/base/gdevpdfg.c<br>
-gs/base/gdevpdfi.c<br>
-gs/base/gdevpdfk.c<br>
-gs/base/gdevpdfp.c<br>
-gs/base/gdevpdfx.h<br>
-gs/base/gdevpsdf.h<br>
-gs/base/gdevpsdi.c<br>
-gs/base/gdevpsds.c<br>
-gs/base/gdevpsds.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-11 13:19:09 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=12798e902f56cc647fbf213ad632d52114b90687">12798e902f56cc647fbf213ad632d52114b90687</a>
-<blockquote>
-<p>
- pdfwrite - fix type 1 to type 2 font converter<br>
-<br>
- Bug #693633 &quot;Font character missing in PDF output - appears in other devices and older versions&quot;<br>
-<br>
- Type 2 fonts are required to start the path operations with a moveto class<br>
- operation, not a lineto, type 1 fonts do not have this restriction. So when<br>
- converting from type 1 to type 2 we must detect if the initial operation is<br>
- a 'line' or a 'move' and emit an explcit 'move' in the case where the first<br>
- operation is a line.<br>
-<br>
- The code to do this was assuming that if there were operands on the stack<br>
- this meant that the glyph width (from the hsbw operator) was present.<br>
- However, this is not true if the font contains any hinting operations as<br>
- the width must be emitted as part of those hints.<br>
-<br>
- This caused the code to emit confused and invalid type 2 CharStrings.<br>
-<br>
- Fixed by adding a boolean to track whether the stack contains the glyph<br>
- width or not, and test that instead of the number of operands.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpsfx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-07 14:42:10 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f15e0f899fd19162d5de8e0963c58f160bd49796">f15e0f899fd19162d5de8e0963c58f160bd49796</a>
-<blockquote>
-<p>
- Bug 693621: Clist logic didn't properly reset after erasepage.<br>
-<br>
- The &quot;normal&quot; page rendering logic works because it flushes the buffer<br>
- memory to the clist, then after the page is printed, it clears out<br>
- the clist data for the next page. By changing the clist_fillpage to<br>
- do this (without actually rendering anything) we now clear out the<br>
- clist for a new page. This has the advantage that any clist operations<br>
- accumulated prior to the fillpage will be discarded, INCLUDING any<br>
- previous fillpage operations which gets rid of duplicate fillpage<br>
- actions which can be time consuming, particularly on embedded systems<br>
- or printers.<br>
-<br>
-gs/base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-07 17:51:46 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=415da137afa2a64cdd6e2bc679c3c269e0d96c73">415da137afa2a64cdd6e2bc679c3c269e0d96c73</a>
-<blockquote>
-<p>
- Bug 693617: Don't allow nesting of BT operators.<br>
-<br>
- Check whether BT operator is executed in a text context and close<br>
- the external context.<br>
-<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-06 16:55:44 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=591a6e95b11f07611f612a691c7e06e169c1fe93">591a6e95b11f07611f612a691c7e06e169c1fe93</a>
-<blockquote>
-<p>
- Bug 392622: Fix handling of big CMap objects.<br>
-<br>
- Add a missing error code check, which caused SEGV when an index points<br>
- beyond the CMap. Fix PS code that truncated CMmaps to 2^17 - 4 bytes.<br>
-<br>
-gs/Resource/Init/pdf_font.ps<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-06 10:17:26 -0700
-</strong>
-<br>Henry Stiles &lt;henrys@henrysx6.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6628fdb771f71c20ad55db026de79d507b42e03">a6628fdb771f71c20ad55db026de79d507b42e03</a>
-<blockquote>
-<p>
- Remove unused GC definitions and declarations.<br>
-<br>
- PCL does not use garbage collection. Having unused definitions<br>
- clutters up the code and gives the false impression the code will work<br>
- with the ghostscript garbage collector built in. The various routines<br>
- to enumerate and relocate pointers have never been maintained and are<br>
- surely out of date.<br>
-<br>
-pcl/pccid.h<br>
-pcl/pccsbase.c<br>
-pcl/pccsbase.h<br>
-pcl/pcdither.c<br>
-pcl/pcdither.h<br>
-pcl/pcdraw.c<br>
-pcl/pcfrgrnd.c<br>
-pcl/pcfrgrnd.h<br>
-pcl/pcht.c<br>
-pcl/pcht.h<br>
-pcl/pcindxed.c<br>
-pcl/pcindxed.h<br>
-pcl/pclookup.c<br>
-pcl/pclookup.h<br>
-pcl/pcpalet.c<br>
-pcl/pcpalet.h<br>
-pcl/pcpatrn.c<br>
-pcl/pcpatrn.h<br>
-pcl/pcpattyp.h<br>
-pcl/pcuptrn.c<br>
-pcl/rtraster.c<br>
-pcl/rtrstcmp.h<br>
-pxl/pxgstate.h<br>
-pxl/pximage.c<br>
-pxl/pxparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-01 14:07:49 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=53e2990bde0966173a954e51c388e4d26af40c15">53e2990bde0966173a954e51c388e4d26af40c15</a>
-<blockquote>
-<p>
- Fix lcms2 64-bit value decoding on big endian systems<br>
- that lack 64-bit types or have these types missed by configuration.<br>
-<br>
- Conflicts:<br>
- gs/lcms2/src/cmsplugin.c<br>
-<br>
-gs/lcms2/src/cmsplugin.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-04 18:15:39 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=81d51fb27178b2a218403ffe350695f27cfa76dd">81d51fb27178b2a218403ffe350695f27cfa76dd</a>
-<blockquote>
-<p>
- Fixes Bug 693616 - GhostPCL locks up with -dFirstPage.<br>
-<br>
- The GL/2 parser should cancel the current command for errors or it is<br>
- possible for the parser to continue without advancing causing an<br>
- infinite loop.<br>
-<br>
-pcl/pgconfig.c<br>
-pcl/pgparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-04 14:01:09 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a14ef732dade2dce6de07edf3a4c10294671a11e">a14ef732dade2dce6de07edf3a4c10294671a11e</a>
-<blockquote>
-<p>
- Fix bug #693608 duplexing command not feeding page.<br>
-<br>
- The PCL select side duplex command does a formfeed unconditionally,<br>
- the other duplex command which sets the duplexing mode does a<br>
- conditional (if page is marked form feed). Before this fix we had<br>
- both conditionally feed.<br>
-<br>
-pcl/pcjob.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-04 18:32:32 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=25291a2f9b01504fbbe70153c07920b016b9f010">25291a2f9b01504fbbe70153c07920b016b9f010</a>
-<blockquote>
-<p>
- pdfwrite - alter escapement of text strings in outlines<br>
-<br>
- Bug 693614 &quot;pdfmark: accented character &quot;c&quot; in titles of generated<br>
- PDF bookmarks is not displayed properly&quot;<br>
-<br>
- I believe this is actually an Acrobat bug, the text string emits the<br>
- Unicode 0x01 0x0d as a binary 0x01 and an escaped character '\n'. This<br>
- follows the rulses for text strings. However Acrobat files to display<br>
- the Title correctly.<br>
-<br>
- Running the file through Distiller I find that the string is emitted as<br>
- 0x01 '\015', the octal representation of 0x0d.<br>
-<br>
- This commit alters the escapement of characters in outlines so that they<br>
- always end up as octal escapes. This seems to pacify Acrobat.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-04 09:56:21 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b0a50081bc45d7b28b4c3dcb1a19a46a66d4216">2b0a50081bc45d7b28b4c3dcb1a19a46a66d4216</a>
-<blockquote>
-<p>
- pdfwrite - fix bug with 64-bit file offsets to permit large files<br>
-<br>
- Bug #693610 &quot; Regression: pdfwrite seg fault with the 32 bit build<br>
- starting with 9b10f8c659ffc643ab71c6180a70da4f39075578&quot;<br>
-<br>
- When doing the work to use 64-bit file offsets, and thus permit files in<br>
- excess of 4GB, I missed an instance.When creating the xref table, if an<br>
- object is unused (which is rare but possible), we need to scan past it in<br>
- the xref offsets temporary file. We do this by calculating the position of<br>
- the next object id in the file.<br>
-<br>
- However, instead of using the size of a gp_offset_t (which is what is written<br>
- into the file) we were still using the size of an unsigned long. Because<br>
- these are the same on a 64-bit build the regular cluster test doesn't catch<br>
- this.<br>
-<br>
- Fixed simply by using the correct size. No differences expected, as explained<br>
- above this only exhibits on platforms where gp_offset_t and unsigned long<br>
- have different sizes.<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-30 16:36:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=060b8b1f34bb73a44978729dd3a49db25861bbab">060b8b1f34bb73a44978729dd3a49db25861bbab</a>
-<blockquote>
-<p>
- pdfwrite: don't try to free static allocated string<br>
-<br>
- If a font is identified as one of the base 14, the font name in BaseFont is<br>
- just a pointer to the entry in the statically declared &quot;standard_font_info&quot;<br>
- table.<br>
-<br>
- Avoid freeing the name if it's marked &quot;is_standard&quot;.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevpdtf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-30 16:22:21 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e982362054609c92d84aa9688246e39a65c4d860">e982362054609c92d84aa9688246e39a65c4d860</a>
-<blockquote>
-<p>
- Bug 693030 - duplexing page problem fixed in PXL output device.<br>
-<br>
- Upon media changes or even duplexing changes the PXL device did not<br>
- switch back to the front page. Thanks to Hin-Tak Leung for fixing<br>
- this.<br>
-<br>
-gs/base/gdevpx.c<br>
-gs/base/gdevpxut.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-30 14:07:41 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=140bfcf881a24e4f915e467a89b8a96592551846">140bfcf881a24e4f915e467a89b8a96592551846</a>
-<blockquote>
-<p>
- Fix Bug #692914 - Postscript MediaType lost.<br>
-<br>
- Thanks to Hin-Tak Leung for adding support for MediaType to PXL output<br>
- drivers.<br>
-<br>
-gs/base/gdevlj56.c<br>
-gs/base/gdevpx.c<br>
-gs/base/gdevpxut.c<br>
-gs/base/gdevpxut.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-30 13:51: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=9fb635f0a6e1695b7a88822c75e22d40a9ba5116">9fb635f0a6e1695b7a88822c75e22d40a9ba5116</a>
-<blockquote>
-<p>
- Bug 693572 (redux): handle missing a glyph outline - again.<br>
-<br>
- It turns out that some devices (pdfwrite!) have a problem with receiving a<br>
- completely empty path for an outline glyph, so......<br>
-<br>
- If the outline is missing, create a path with just a moveto and closepath.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-30 13:37:47 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=508a79ca38cb857229f0e29236e95059a8d54799">508a79ca38cb857229f0e29236e95059a8d54799</a>
-<blockquote>
-<p>
- Bug 693398: avoid marking/reloc'ing unsuitable pointer<br>
-<br>
- The gx_image_enum object contains a pointer (cie_range) to the CIE range in<br>
- the color space, if it's for an image in certain types of CIE space. The<br>
- pointer points *into* an area of allocated memory, and not to the &quot;top&quot; of<br>
- the allocated block. As a result, when garbage collection tries to relocate,<br>
- there isn't a valid header structure, and the values it ends up using for the<br>
- relocation are nonsense.<br>
-<br>
- Removing the cie_range pointer from the GC pointer enumeration is not<br>
- because the color space structure and it's contents can move. Since this is<br>
- a fairly rare case, and the CIE range lookup is trivial, the cie_range<br>
- pointer is replaced with a boolean (so we decide *whether* to use the range<br>
- only once), and then the range itself is retrieved at the time it's used.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gxi12bit.c<br>
-gs/base/gxicolor.c<br>
-gs/base/gximage.h<br>
-gs/base/gximono.c<br>
-gs/base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-27 14:03:05 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=803a59ecfd925dafe325d263ecf0a1734113ffef">803a59ecfd925dafe325d263ecf0a1734113ffef</a>
-<blockquote>
-<p>
- Bug 693590: MT rendering has wrong 'supports_devn' and incomplete color_info<br>
-<br>
- Shadings use the comp_bits, comp_mask and comp_shift which must match<br>
- the main thread's setting, so we copy the color_info from the clist<br>
- device.<br>
-<br>
- Also the thread's icc_struct-&gt;supports_devn must correspond to the main<br>
- thread's device (regressions with psdcmyk detected this).<br>
-<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-29 17:45:45 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1ae60ab98eef2d376b65f9c50ba2840b1577030b">1ae60ab98eef2d376b65f9c50ba2840b1577030b</a>
-<blockquote>
-<p>
- Bug 693026: Fix SEGV when @FILE can't open.<br>
-<br>
- Argument processing happens early during Ghostscript start-up process.<br>
- Be prepared, that not all structures have been initialized yet.<br>
-<br>
-gs/base/gsargs.c<br>
-gs/base/gsargs.h<br>
-gs/base/gsiodev.c<br>
-gs/psi/imainarg.c<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-29 15:12: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=f372552beb9105a8768b6b3002bf29b6a7b7278b">f372552beb9105a8768b6b3002bf29b6a7b7278b</a>
-<blockquote>
-<p>
- Bug 693599: Change the function configure checks for in liblcms2.<br>
-<br>
- The lcms2 API changed at 2.2, adding the cmsGetTransformOutputFormat()<br>
- call. When we're checking if we can use the system's lcms2, change the<br>
- autoconf check to look for cmsGetTransformOutputFormat().<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-29 10:32:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=56337a050812f072a2669b395119e016cb750e60">56337a050812f072a2669b395119e016cb750e60</a>
-<blockquote>
-<p>
- Add the make fix from 1fbd0191 to the Mac specific subtarget.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/unix-dll.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-29 10:12:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1fbd0191d1801fc49e362374a7ca6a387e03b9f8">1fbd0191d1801fc49e362374a7ca6a387e03b9f8</a>
-<blockquote>
-<p>
- Work around a make problem with &quot;so&quot; target<br>
-<br>
- GNU make 3.82 appears to have a bug which causes problems with our &quot;so&quot;<br>
- targets. The &quot;so&quot; targets rely on recursice make calls to build various<br>
- subtargets, the shared library and the two executables that link to the shared<br>
- library.<br>
-<br>
- On the final recursive make call (to build the executables), GNU make 3.82<br>
- wrongly identifies that one dependency (psbase.dev) has changed, and decides it<br>
- must rebuild the shared library. By this stage, however, the compiler options<br>
- have been setup to build an executable, rather than the shared library.<br>
-<br>
- As a result, we build an executable with the name of the shared lib, and<br>
- then try to link that into an executable, which results in linker errors.<br>
-<br>
- As it happens, the use of recursive make calls means we can safely drop a<br>
- dependency, which will prevent make from re-evaluating the problematic target,<br>
- and thus avoiding the problem arising.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/unix-dll.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-29 09:30:56 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=980a1a28a010fcbfa62208f022454e5fa6b8dc2c">980a1a28a010fcbfa62208f022454e5fa6b8dc2c</a>
-<blockquote>
-<p>
- Bump version number to 9.08.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-02-12 15:44: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=76b4193e5d8cb280f4795b0e959657ad695ad54d">76b4193e5d8cb280f4795b0e959657ad695ad54d</a>
-<blockquote>
-<p>
- Revise release date and product string for 9.07 release.<br>
-<br>
- Color feature news additions.<br>
-<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pdfopt.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-01 14:07:49 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8fbcb3a68ca46ff9f56863d19a7c3342b53c220e">8fbcb3a68ca46ff9f56863d19a7c3342b53c220e</a>
-<blockquote>
-<p>
- Fix lcms2 64-bit value decoding on big endian systems<br>
- that lack 64-bit types or have these types missed by configuration.<br>
-<br>
- Conflicts:<br>
- gs/lcms2/src/cmsplugin.c<br>
-<br>
-gs/lcms2/src/cmsplugin.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-31 10:44: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=885d3646213fc2dfacf7a49d6d546e15eaff190e">885d3646213fc2dfacf7a49d6d546e15eaff190e</a>
-<blockquote>
-<p>
- Update documentation for release candidate 1<br>
-<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pdfopt.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-31 09:28: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=dbcde58e3c01b4b9f996d9e962a074e46697698d">dbcde58e3c01b4b9f996d9e962a074e46697698d</a>
-<blockquote>
-<p>
- Add &quot;Release Candidate 1&quot; to GS_PRODUCTFAMILY<br>
-<br>
- Fix release date.<br>
-<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-30 16:22:21 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1db3e495532a23b3c736dd54215ecb82374837fe">1db3e495532a23b3c736dd54215ecb82374837fe</a>
-<blockquote>
-<p>
- Bug 693030 - duplexing page problem fixed in PXL output device.<br>
-<br>
- Upon media changes or even duplexing changes the PXL device did not<br>
- switch back to the front page. Thanks to Hin-Tak Leung for fixing<br>
- this.<br>
-<br>
-gs/base/gdevpx.c<br>
-gs/base/gdevpxut.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-30 14:07:41 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6e13685e1768771f87c94bdb2aaaab4d011d601c">6e13685e1768771f87c94bdb2aaaab4d011d601c</a>
-<blockquote>
-<p>
- Fix Bug #692914 - Postscript MediaType lost.<br>
-<br>
- Thanks to Hin-Tak Leung for adding support for MediaType to PXL output<br>
- drivers.<br>
-<br>
-gs/base/gdevlj56.c<br>
-gs/base/gdevpx.c<br>
-gs/base/gdevpxut.c<br>
-gs/base/gdevpxut.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-30 13:51: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=9c11bdaf7701b2736060ce291ae22fb0105ffaf5">9c11bdaf7701b2736060ce291ae22fb0105ffaf5</a>
-<blockquote>
-<p>
- Bug 693572 (redux): handle missing a glyph outline - again.<br>
-<br>
- It turns out that some devices (pdfwrite!) have a problem with receiving a<br>
- completely empty path for an outline glyph, so......<br>
-<br>
- If the outline is missing, create a path with just a moveto and closepath.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-30 13:37:47 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4704c9dc5d345fa6d81513fe9d5ea13aa199ae01">4704c9dc5d345fa6d81513fe9d5ea13aa199ae01</a>
-<blockquote>
-<p>
- Bug 693398: avoid marking/reloc'ing unsuitable pointer<br>
-<br>
- The gx_image_enum object contains a pointer (cie_range) to the CIE range in<br>
- the color space, if it's for an image in certain types of CIE space. The<br>
- pointer points *into* an area of allocated memory, and not to the &quot;top&quot; of<br>
- the allocated block. As a result, when garbage collection tries to relocate,<br>
- there isn't a valid header structure, and the values it ends up using for the<br>
- relocation are nonsense.<br>
-<br>
- Removing the cie_range pointer from the GC pointer enumeration is not<br>
- because the color space structure and it's contents can move. Since this is<br>
- a fairly rare case, and the CIE range lookup is trivial, the cie_range<br>
- pointer is replaced with a boolean (so we decide *whether* to use the range<br>
- only once), and then the range itself is retrieved at the time it's used.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gxi12bit.c<br>
-gs/base/gxicolor.c<br>
-gs/base/gximage.h<br>
-gs/base/gximono.c<br>
-gs/base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-29 17:45:45 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=295a195f85ced8b965f65bbc1fe6c3cf78c36e51">295a195f85ced8b965f65bbc1fe6c3cf78c36e51</a>
-<blockquote>
-<p>
- Bug 693026: Fix SEGV when @FILE can't open.<br>
-<br>
- Argument processing happens early during Ghostscript start-up process.<br>
- Be prepared, that not all structures have been initialized yet.<br>
-<br>
-gs/base/gsargs.c<br>
-gs/base/gsargs.h<br>
-gs/base/gsiodev.c<br>
-gs/psi/imainarg.c<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-27 14:03:05 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab9615d43302f03ce57fdd8e849ec52e870983e4">ab9615d43302f03ce57fdd8e849ec52e870983e4</a>
-<blockquote>
-<p>
- Bug 693590: MT rendering has wrong 'supports_devn' and incomplete color_info<br>
-<br>
- Shadings use the comp_bits, comp_mask and comp_shift which must match<br>
- the main thread's setting, so we copy the color_info from the clist<br>
- device.<br>
-<br>
- Also the thread's icc_struct-&gt;supports_devn must correspond to the main<br>
- thread's device (regressions with psdcmyk detected this).<br>
-<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-29 15:12: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=62df74b7ef081a9f35028b493843a4624048f7af">62df74b7ef081a9f35028b493843a4624048f7af</a>
-<blockquote>
-<p>
- Bug 693599: Change the function configure checks for in liblcms2.<br>
-<br>
- The lcms2 API changed at 2.2, adding the cmsGetTransformOutputFormat()<br>
- call. When we're checking if we can use the system's lcms2, change the<br>
- autoconf check to look for cmsGetTransformOutputFormat().<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-29 10:32:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c7aa3543e098620d70c5df143513718d3e83b12">3c7aa3543e098620d70c5df143513718d3e83b12</a>
-<blockquote>
-<p>
- Add the make fix from 1fbd0191 to the Mac specific subtarget.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/unix-dll.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-29 10:12:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3233283cfe4370fb826998d14954e4870155c80e">3233283cfe4370fb826998d14954e4870155c80e</a>
-<blockquote>
-<p>
- Work around a make problem with &quot;so&quot; target<br>
-<br>
- GNU make 3.82 appears to have a bug which causes problems with our &quot;so&quot;<br>
- targets. The &quot;so&quot; targets rely on recursice make calls to build various<br>
- subtargets, the shared library and the two executables that link to the shared<br>
- library.<br>
-<br>
- On the final recursive make call (to build the executables), GNU make 3.82<br>
- wrongly identifies that one dependency (psbase.dev) has changed, and decides it<br>
- must rebuild the shared library. By this stage, however, the compiler options<br>
- have been setup to build an executable, rather than the shared library.<br>
-<br>
- As a result, we build an executable with the name of the shared lib, and<br>
- then try to link that into an executable, which results in linker errors.<br>
-<br>
- As it happens, the use of recursive make calls means we can safely drop a<br>
- dependency, which will prevent make from re-evaluating the problematic target,<br>
- and thus avoiding the problem arising.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/unix-dll.mak<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-<h2><a name="Version9.09"></a>Version 9.09 (2013-02-14)</h2>
-
-<p>The 9.09 release was quickly superseded by 9.10 after a bug was found that prevented
--dUeCIEColor from working was discovered. Please use 9.10.
-
-<h2><a name="Version9.07"></a>Version 9.07 (2013-02-14)</h2>
-
-<p>This is the seventh full release in the stable 9.x series.
-
-<p> Highlights in this release include:
-<ul>
-<li>
-<p> As of this release (9.07), Ghostscript and GhostPDL are distributed under
-the GNU Affero General Public License (AGPL).
-</li>
-<li>
-<p> Ghostscript now has the option to be built as thread safe. Note that
-not all devices are thread safe. See the GS_THREADSAFE option in:
-<a href="API.htm#new_instance">GS_THREADSAFE</a>
-</li>
-<li>
-<p> The pdfwrite devices now supports linearized (or optimized for fast web
-view) output directly ("-dFastWebView")
-</li>
-<li>
-<p> The Font API (FAPI) has been moved from the Postscript interpreter (psi)
-into the graphics library (base), and extended to support the other languages
-(PCL/PXL/XPS). All interpreters now use Freetype by default to render all
-viable font types.
-</li>
-<li>
-<p> Ghostscript has been extended to support Postscript string and array
-objects with >64k entries.
-</li>
-<li>
-<p> Ghostscript has been extended to support file sizes >4Gb - in particular
-reading and writing PDF files. As a side effect of this, Ghostscript also now
-supports 64 bit Postscript integer objects.
-</li>
-<li>
-<p> All CMYK devices can now support simulated overprint of spot colors using
-the &quot;-dSimulateOverprint&quot; command line option.
-</li>
-<li>
-<p> Support for use of DeviceN ICC color profiles as the output profile with
-the tiffsep and psdcmyk devices.
-</li>
-<li>
-<p> Support for customized named color handling with DeviceN colors
-</li>
-<li>
-<p> Support for black point compensation
-</li>
-<li>
-<p> Support for K preservation in CMYK to CMYK conversions
-</li>
-<li>
-<p> Support for DeviceLink profiles for graphic, image and text objects
-</li>
-<li>
-<p> Support for custom color replacement
-</li>
-<li>
-<p> Increased control in specifying color conversions as a function of object type
-<p> Full details of the color management features can be found in:
-<a href="GS9_Color_Management.pdf">GS9_Color_Management.pdf</a>
-</li>
-<li>
-<p> Provide BigTIFF output option: the tiff devices can write BigTIFF files
-using the &quot;-dUseBigTIFF&quot; option. This requires libtiff version >=4.0.0 (the
-option is ignored for versions <4.0.0)
-</li>
-<li>
-<p> LittleCMS updated to 2.4
-</li>
-<li>
-<p>Plus the usual round of bug fixes, compatibility changes, and incremental improvements.
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.07_Incompatible_changes"></a>Incompatible changes</h3>
-<p>
-No recorded incompatible changes.
-
-<h3><a name="9.07_changelog"></a>Changelog</h3>
-<p><strong>2013-01-30 16:22:21 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1db3e495532a23b3c736dd54215ecb82374837fe">1db3e495532a23b3c736dd54215ecb82374837fe</a>
-<blockquote>
-<p>
- Bug 693030 - duplexing page problem fixed in PXL output device.<br>
-<br>
- Upon media changes or even duplexing changes the PXL device did not<br>
- switch back to the front page. Thanks to Hin-Tak Leung for fixing<br>
- this.<br>
-<br>
-gs/base/gdevpx.c<br>
-gs/base/gdevpxut.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-30 14:07:41 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6e13685e1768771f87c94bdb2aaaab4d011d601c">6e13685e1768771f87c94bdb2aaaab4d011d601c</a>
-<blockquote>
-<p>
- Fix Bug #692914 - Postscript MediaType lost.<br>
-<br>
- Thanks to Hin-Tak Leung for adding support for MediaType to PXL output<br>
- drivers.<br>
-<br>
-gs/base/gdevlj56.c<br>
-gs/base/gdevpx.c<br>
-gs/base/gdevpxut.c<br>
-gs/base/gdevpxut.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-30 13:51: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=9c11bdaf7701b2736060ce291ae22fb0105ffaf5">9c11bdaf7701b2736060ce291ae22fb0105ffaf5</a>
-<blockquote>
-<p>
- Bug 693572 (redux): handle missing a glyph outline - again.<br>
-<br>
- It turns out that some devices (pdfwrite!) have a problem with receiving a<br>
- completely empty path for an outline glyph, so......<br>
-<br>
- If the outline is missing, create a path with just a moveto and closepath.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-30 13:37:47 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4704c9dc5d345fa6d81513fe9d5ea13aa199ae01">4704c9dc5d345fa6d81513fe9d5ea13aa199ae01</a>
-<blockquote>
-<p>
- Bug 693398: avoid marking/reloc'ing unsuitable pointer<br>
-<br>
- The gx_image_enum object contains a pointer (cie_range) to the CIE range in<br>
- the color space, if it's for an image in certain types of CIE space. The<br>
- pointer points *into* an area of allocated memory, and not to the &quot;top&quot; of<br>
- the allocated block. As a result, when garbage collection tries to relocate,<br>
- there isn't a valid header structure, and the values it ends up using for the<br>
- relocation are nonsense.<br>
-<br>
- Removing the cie_range pointer from the GC pointer enumeration is not<br>
- because the color space structure and it's contents can move. Since this is<br>
- a fairly rare case, and the CIE range lookup is trivial, the cie_range<br>
- pointer is replaced with a boolean (so we decide *whether* to use the range<br>
- only once), and then the range itself is retrieved at the time it's used.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gxi12bit.c<br>
-gs/base/gxicolor.c<br>
-gs/base/gximage.h<br>
-gs/base/gximono.c<br>
-gs/base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-29 17:45:45 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=295a195f85ced8b965f65bbc1fe6c3cf78c36e51">295a195f85ced8b965f65bbc1fe6c3cf78c36e51</a>
-<blockquote>
-<p>
- Bug 693026: Fix SEGV when @FILE can't open.<br>
-<br>
- Argument processing happens early during Ghostscript start-up process.<br>
- Be prepared, that not all structures have been initialized yet.<br>
-<br>
-gs/base/gsargs.c<br>
-gs/base/gsargs.h<br>
-gs/base/gsiodev.c<br>
-gs/psi/imainarg.c<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-27 14:03:05 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab9615d43302f03ce57fdd8e849ec52e870983e4">ab9615d43302f03ce57fdd8e849ec52e870983e4</a>
-<blockquote>
-<p>
- Bug 693590: MT rendering has wrong 'supports_devn' and incomplete color_info<br>
-<br>
- Shadings use the comp_bits, comp_mask and comp_shift which must match<br>
- the main thread's setting, so we copy the color_info from the clist<br>
- device.<br>
-<br>
- Also the thread's icc_struct-&gt;supports_devn must correspond to the main<br>
- thread's device (regressions with psdcmyk detected this).<br>
-<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-29 15:12: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=62df74b7ef081a9f35028b493843a4624048f7af">62df74b7ef081a9f35028b493843a4624048f7af</a>
-<blockquote>
-<p>
- Bug 693599: Change the function configure checks for in liblcms2.<br>
-<br>
- The lcms2 API changed at 2.2, adding the cmsGetTransformOutputFormat()<br>
- call. When we're checking if we can use the system's lcms2, change the<br>
- autoconf check to look for cmsGetTransformOutputFormat().<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-29 10:32:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c7aa3543e098620d70c5df143513718d3e83b12">3c7aa3543e098620d70c5df143513718d3e83b12</a>
-<blockquote>
-<p>
- Add the make fix from 1fbd0191 to the Mac specific subtarget.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/unix-dll.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-29 10:12:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3233283cfe4370fb826998d14954e4870155c80e">3233283cfe4370fb826998d14954e4870155c80e</a>
-<blockquote>
-<p>
- Work around a make problem with &quot;so&quot; target<br>
-<br>
- GNU make 3.82 appears to have a bug which causes problems with our &quot;so&quot;<br>
- targets. The &quot;so&quot; targets rely on recursice make calls to build various<br>
- subtargets, the shared library and the two executables that link to the shared<br>
- library.<br>
-<br>
- On the final recursive make call (to build the executables), GNU make 3.82<br>
- wrongly identifies that one dependency (psbase.dev) has changed, and decides it<br>
- must rebuild the shared library. By this stage, however, the compiler options<br>
- have been setup to build an executable, rather than the shared library.<br>
-<br>
- As a result, we build an executable with the name of the shared lib, and<br>
- then try to link that into an executable, which results in linker errors.<br>
-<br>
- As it happens, the use of recursive make calls means we can safely drop a<br>
- dependency, which will prevent make from re-evaluating the problematic target,<br>
- and thus avoiding the problem arising.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/unix-dll.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-28 17:32:15 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bbfbdf7574e6ac46b65b76b06dea6a4e94d35f31">bbfbdf7574e6ac46b65b76b06dea6a4e94d35f31</a>
-<blockquote>
-<p>
- Bug 693284: Prevent read access violation.<br>
- Check whether there's enough data.<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-28 16:34:20 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ba5e87d05bb2bfff4e475fa21bd8558896ca053">7ba5e87d05bb2bfff4e475fa21bd8558896ca053</a>
-<blockquote>
-<p>
- Bug 693284: Detect missing glyphs and fail.<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-gs/jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-28 15:34:38 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=33794a10191cf1e5c1b41410ee068ba71cf3825c">33794a10191cf1e5c1b41410ee068ba71cf3825c</a>
-<blockquote>
-<p>
- Bug 693284: Conditional inclusion of memento header.<br>
-<br>
-gs/jbig2dec/jbig2.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-28 13:34:01 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ccae004db8b875086995353c299cee196dd326fb">ccae004db8b875086995353c299cee196dd326fb</a>
-<blockquote>
-<p>
- Bug 693284: Break an infinite loop.<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-28 11:56:37 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b6594315066b8ded562111472aa5933c6c54238">4b6594315066b8ded562111472aa5933c6c54238</a>
-<blockquote>
-<p>
- Bug 693284: Fix 32 vs 64-bit typ[e mismatch.<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-28 11:09:04 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eea1deb225c19ab7a29b7ccdb33290d757853f1b">eea1deb225c19ab7a29b7ccdb33290d757853f1b</a>
-<blockquote>
-<p>
- Bug 693284: Don't shift 32-bit value by 32.<br>
-<br>
-gs/jbig2dec/jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-28 09:03:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9cf877b78dbe7d077d1369b07bdaf73ba8415e01">9cf877b78dbe7d077d1369b07bdaf73ba8415e01</a>
-<blockquote>
-<p>
- Handle cases where pointer alignment does not match pointer size.<br>
-<br>
- On some hardware, pointer alignment does not necessarily match the size<br>
- of a pointer - handle that in genarch.<br>
-<br>
- No cluster differences<br>
-<br>
-gs/base/genarch.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-28 08:55: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=8120955272fe1c9d1a8182c2dbba44758d3d3091">8120955272fe1c9d1a8182c2dbba44758d3d3091</a>
-<blockquote>
-<p>
- Fix unaligned pointer access.<br>
-<br>
- In pdf_add_subset_prefix() change so that the hashing code accesses<br>
- the buffer byte at a time, rather than short at a time, and increment<br>
- through the buffer &quot;sizeof(short)&quot; bytes at a time. The former ensures<br>
- we never risk an unaligned memory access on strict alignment<br>
- architectures, and the latter ensures we hash all the relevant data<br>
- correctly.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevpdtb.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-28 08:57:12 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=daeb0a9a52f865e9088c29511fd397d8356ca775">daeb0a9a52f865e9088c29511fd397d8356ca775</a>
-<blockquote>
-<p>
- pdfwrite - record the usage of outlines, articles, named dests and labels<br>
-<br>
- When linearising, I forgot to add the dictionaries, referenced from the<br>
- Catalog, for Outlines, Threads, Named desintations and Page Lanels to<br>
- the usage record. This meant these dictionaries were accidentally<br>
- dropped from the final PDF file.<br>
-<br>
- Here we just record their usage.<br>
-<br>
- No diffrences expected.<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-27 14:06:05 -0500
-</strong>
-<br>Shailesh Mistry &lt;shailesh.mistry@hotmail.co.uk&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=07d5a619b525898759a7468631a6cb775edf5bd6">07d5a619b525898759a7468631a6cb775edf5bd6</a>
-<blockquote>
-<p>
- Bug 691246: Handle inverted symbol region.<br>
-<br>
- Propagate combination operator and also fix an error in coding XNOR<br>
- logical operation.<br>
-<br>
-gs/jbig2dec/jbig2_generic.c<br>
-gs/jbig2dec/jbig2_image.c<br>
-gs/jbig2dec/jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-27 01:46:17 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e140900d2f1eca99ad64c5bdef131cddc55e5ef">0e140900d2f1eca99ad64c5bdef131cddc55e5ef</a>
-<blockquote>
-<p>
- Bug 693513: Detect and reject negative parameters.<br>
-<br>
- Fix detection of negative width and height attributes.<br>
- Add detection of negative number of dictionary symbols.<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-26 21:47:12 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=152d0cec22438acbb6a5cd50a65b0f9f8c729195">152d0cec22438acbb6a5cd50a65b0f9f8c729195</a>
-<blockquote>
-<p>
- Fix bug #693586 - clist error message.<br>
-<br>
- The error was caused by sending image data to the library after the<br>
- page was output, now graphics mode is flushed and closed before the<br>
- page is output. The bug was introduced by ea54a03 which closed<br>
- graphics mode at the time of &quot;end job&quot; which could occur after output<br>
- page. We do need to leave that commit intact as the job could end<br>
- without outputting a page, and the raster state would not be cleaned<br>
- up.<br>
-<br>
-pcl/pcpage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-26 21:43:50 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=386b7ab3dcdf165d6a9cae58a871e0bb78b7bdac">386b7ab3dcdf165d6a9cae58a871e0bb78b7bdac</a>
-<blockquote>
-<p>
- dwmainc.c include file dependencies added to makefile.<br>
-<br>
-main/pcl6_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-26 19:58:46 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e40d514124722e7babf4acaf1db5eb4e372b5f72">e40d514124722e7babf4acaf1db5eb4e372b5f72</a>
-<blockquote>
-<p>
- Bug 693496: Fix 16-bit gray image on CMYK devices on 32-bit platforms.<br>
-<br>
- Use platform-independent way (memcmp) to compare color values instead of<br>
- instead of relying on the word sizes. Old code missed some of the<br>
- color components on 32-bit computers.<br>
-<br>
-gs/base/gxi12bit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-25 22:46:38 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=81a36cc82e8680ac6bf7f0808402bf6ff02920ea">81a36cc82e8680ac6bf7f0808402bf6ff02920ea</a>
-<blockquote>
-<p>
- Bug 693587: Make EOL check a little more strict.<br>
- Don't skip space character after finding \r. Just peek for the following<br>
- \n and stop scanning.<br>
-<br>
-gs/Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-25 15:29:12 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a438b95a287f36b721331c50a4c47985616a0c19">a438b95a287f36b721331c50a4c47985616a0c19</a>
-<blockquote>
-<p>
- Bug 693584: Fix annotation scaling.<br>
-<br>
- Fix incorrect scaling of annotations with appearance subdirectories. Old code<br>
- always failed to find the actual appearance dictionary and used identity<br>
- scaling in such cases.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-25 09:50:41 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5fa93a84163a0e2680ead7e76425c92da24bce5c">5fa93a84163a0e2680ead7e76425c92da24bce5c</a>
-<blockquote>
-<p>
- Another documentation update of the color architecture.<br>
-<br>
-gs/doc/GS9_Color_Management.pdf<br>
-gs/doc/GS9_Color_Management.tex<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-24 21:42:03 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=52cb8e94511a3a5acd8d3a21f6a22cf24d52962e">52cb8e94511a3a5acd8d3a21f6a22cf24d52962e</a>
-<blockquote>
-<p>
- Update of color management document for 9.07 release<br>
-<br>
-gs/doc/GS9_Color_Management.pdf<br>
-gs/doc/GS9_Color_Management.tex<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-24 12:58:58 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=210c9344792bcf95c540f93428562c34104ffb28">210c9344792bcf95c540f93428562c34104ffb28</a>
-<blockquote>
-<p>
- Set stdio streams to binary, bug #693543.<br>
-<br>
- This is exactly the same solution used in gs/base/dwmainc.c. The<br>
- commit also removes extraneous include files. Updating the associated<br>
- dwmain makefile target with the new include file dependencies is<br>
- forthcoming.<br>
-<br>
-pl/dwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-24 12:05: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=400e64a36f1f18e3642b705d926c49c42adc8599">400e64a36f1f18e3642b705d926c49c42adc8599</a>
-<blockquote>
-<p>
- Bug 693571: properly close allocator chunk during save<br>
-<br>
- During a save operation, we &quot;close&quot; the open chunk and save the state of the<br>
- current generation of an allocator before creating a new generation and opening<br>
- a new chunk for the new generation.<br>
-<br>
- After doing that, we try to eliminate any redundant changes listed for the<br>
- &quot;saved&quot; allocator instance. That can end freeing memory in the &quot;closed&quot; chunk,<br>
- leaving it in an unstable state, and causing the garbage collector to try to<br>
- validate already freed memory.<br>
-<br>
- In drop_redundant_changes() we now call alloc_open_chunk() and<br>
- alloc_close_chunk() so that, in event we do disard changes (thus freeing<br>
- memory), the allocator is left in an internally consistent state, and<br>
- avoids confusing the chunk validation code during garbage collection.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-24 11:56:25 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=149811fa66aaaf272a1377e9df1a79f3752e0299">149811fa66aaaf272a1377e9df1a79f3752e0299</a>
-<blockquote>
-<p>
- Update int_freed_top in the correct chunk<br>
-<br>
- In i_free_object() we were identifying the correct chunk for the memory<br>
- address we were freeing, but then always updating int_freed_top in the<br>
- current chunk. This could cause us to fail to consolidate free blocks when<br>
- we possibly could, or to attempt to do so when it would be pointless.<br>
-<br>
- So we now identify whether the address is in the current chunk, and write<br>
- int_freed_top in that, or use the actual chunk pointer for the freed<br>
- memory block.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-24 11:44: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=0f0a42367372cffeb80e32a4244dc74031fda077">0f0a42367372cffeb80e32a4244dc74031fda077</a>
-<blockquote>
-<p>
- Use the correct memory pointer for glyph cache init<br>
-<br>
- The PS interpreter initialised the glyph cache using the &quot;imemory&quot;<br>
- pointer for the cache memory. But if the cache gets resized via<br>
- a setuserparams or setcacheparams, the graphics libarary would then<br>
- use the &quot;stable_memory&quot; pointer to free the original memory, and allocate<br>
- the new. Thus illiciting warning about &quot;memory not owned by allocator&quot; when<br>
- running with -ZA<br>
-<br>
- Switch the PS interpreter initialisation to also use &quot;stable_memory&quot;.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-24 11:36: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=3b2819779786467f3ed6799242947d811186a29a">3b2819779786467f3ed6799242947d811186a29a</a>
-<blockquote>
-<p>
- Change the memory pointer used for if_debug2m()<br>
-<br>
- The cmem pointer can be null in stream_finalize() if it is called from the<br>
- garbage collector. Use the memory pointer from the stream object instead.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/stream.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-23 16:11:32 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=57744bd8af3b06cea888b7a66c8349c5096b748d">57744bd8af3b06cea888b7a66c8349c5096b748d</a>
-<blockquote>
-<p>
- Bug 693572: handle missing a glyph outline.<br>
-<br>
- We purposefully ignore some errors during glyph creation. In that event,<br>
- the path creation for an outline glyph, we weren't checking for the<br>
- outline being missing.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-23 09:06:04 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb8f4582d893aab544597599b9498e38dfa12de4">bb8f4582d893aab544597599b9498e38dfa12de4</a>
-<blockquote>
-<p>
- ps2write - Don't add PageLabels to the Catalog when we get a relevant pdfmark<br>
-<br>
- Bug 693551 &quot; Regression: &quot;Error handled by opdfread.ps : rangecheck&quot; starting with 5784bfbfba7191cacce5309e88afac0851287460&quot;<br>
-<br>
- opdfread.ps doesn't know what to do with a PageLabel, so don't emit them<br>
-<br>
- Not sure why this didn't show up in the original cluster test<br>
-<br>
-gs/base/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-23 08:19:24 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5874ad1dfa17839d499db8b041a5fc9bdbfd6b22">5874ad1dfa17839d499db8b041a5fc9bdbfd6b22</a>
-<blockquote>
-<p>
- Properly initialise 'clip' device<br>
-<br>
- Bug #693575 &quot;segfault with ps2write and -dDisablePAPI&quot;<br>
-<br>
- Although labeled as a PS writer problem this is in fact a general bug. In<br>
- gx_image_fill_masked we call gx_image_fill_masked_start() with a pointer<br>
- to a gx_device * which we expect to be filled in.<br>
-<br>
- This will be the device which accumulates the clip, if the current target<br>
- device can accumulate clips then we use it, otherwise we set up an<br>
- accumulation device.<br>
-<br>
- However there was a path through gx_image_fill_masked_start which did not<br>
- set the device, leading to the variable being left uninitialised and<br>
- causing a later crash.<br>
-<br>
- This patch initialises the variable to the current device before calling<br>
- gx_image_fill_masked_start and also fixes the code path in that routine<br>
- so that it always fills in the device. Just to be safe.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gximask.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-23 08:46:58 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5420903e1cbccc8c27c8e9f82c21efd9fef36366">5420903e1cbccc8c27c8e9f82c21efd9fef36366</a>
-<blockquote>
-<p>
- Silenced compiler warnings in cups/gdevcups.c.<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-22 20:25:18 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f0f048ae68e9b93b536a52c783b566652ab72b3e">f0f048ae68e9b93b536a52c783b566652ab72b3e</a>
-<blockquote>
-<p>
- Bug 693573; Prevent multiple free when MT rendering cannot start any threads<br>
-<br>
- When the MT rendering fails to start any device after the thread's<br>
- chunk allocator was set up, multiple free of the allocator would occur<br>
- because the thread's 'memory' was not set to NULL.<br>
-<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-22 21:24:17 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=76fa834e14471fb54e3dd23802a8c8f53d7fda0e">76fa834e14471fb54e3dd23802a8c8f53d7fda0e</a>
-<blockquote>
-<p>
- Fix warning, missing declaration, in the previous commit<br>
- ea54a0304934c570a51ca5eec216b0480f2b5be5<br>
-<br>
-pcl/pcl.mak<br>
-pcl/pctop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-22 20:07:57 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=81ea731e97a93a5c9e3f59d7f67f8b3aa5c495c8">81ea731e97a93a5c9e3f59d7f67f8b3aa5c495c8</a>
-<blockquote>
-<p>
- Bug 693570: Clear operand stack finishing PDF page.<br>
-<br>
- Clear all objects that may be left behind by PDF command streams.<br>
- Stray composite objects interfere with a restore operator at the<br>
- end of the page.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-22 18:04:09 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=298abec0432d87b25e57b2ab549b1817f396e851">298abec0432d87b25e57b2ab549b1817f396e851</a>
-<blockquote>
-<p>
- Remove a bogus comment, lineprinter font is bound.<br>
-<br>
-pl/plftable.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-22 17:51:08 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea54a0304934c570a51ca5eec216b0480f2b5be5">ea54a0304934c570a51ca5eec216b0480f2b5be5</a>
-<blockquote>
-<p>
- Fixes interpreter crash see bug #693543.<br>
-<br>
- If a PCL job exited in the middle of a raster stream graphics mode was<br>
- not terminated properly at the end of the job, instead we tried to<br>
- shut down graphics later at the time of interpreter shutdown which<br>
- leads to a unordered freeing of resources.<br>
-<br>
-pcl/pctop.c<br>
-pcl/rtgmode.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-22 21:06:37 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=188e13b462ce0d606735b53e22bdba667e391c00">188e13b462ce0d606735b53e22bdba667e391c00</a>
-<blockquote>
-<p>
- CUPS Raster &quot;cups&quot; device: Improvements for pages size matching with PPD<br>
-<br>
- These changes improve the matching of the sizes of the incoming pages with<br>
- the page sizes available for thr printer according to the PPD file.<br>
-<br>
- Instead of stopping to searcg through the PPDs page sizes when a size<br>
- gets found which fits within the limits, we always go through all page<br>
- sizes to find the best match. We consider the best match the size with<br>
- the name given on the command line/by the input file and matching the<br>
- size of the current page within the limits, second level is a match of<br>
- size and margins and third level is only matching the size. If there<br>
- is more than one match of the same level, the product of the<br>
- horizontal and vertival size deviation counts.<br>
-<br>
- In addition, we let the gstoraster wrapper CUPS filter for Ghostscript<br>
- call Ghostscript with all parameters on the command line (especially<br>
- also the page size name) also when the input is PostScript.<br>
-<br>
-gs/cups/gdevcups.c<br>
-gs/cups/gstoraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-18 13:14:15 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2ae1a17c87e2e0d6de13d3a354129ff09668bb32">2ae1a17c87e2e0d6de13d3a354129ff09668bb32</a>
-<blockquote>
-<p>
- Fix Bug 693422. SEGV due to transparency and patterns<br>
-<br>
- This change disables the check when doing the pattern_cache_lookup,<br>
- since transparency ops that set the colorspace may have been omitted<br>
- from bands where they are not needed, but a large pattern may have<br>
- been written to all bands. Thanks to Alex for finding this.<br>
-<br>
-gs/base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-17 14:25:25 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=96a8e3595982078f0bfd6a93cb51e420f25fdc31">96a8e3595982078f0bfd6a93cb51e420f25fdc31</a>
-<blockquote>
-<p>
- Bug 693550: Consider max color index -1 as 255.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-17 18:44:10 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=57a5089f1e2c2a83eceec81dfa2facf5f9fb51e0">57a5089f1e2c2a83eceec81dfa2facf5f9fb51e0</a>
-<blockquote>
-<p>
- Bug 693541: Fix color setup in pdf14_create_clist_device.<br>
-<br>
- When we create a pdf14 clist device (a pdf14cmykspot device, in this<br>
- case) in pdf14_create_clist_device, we are at pains to set the<br>
- num_components and max_components appropriately. At no point do we<br>
- similarly sanitise the depth however.<br>
-<br>
- The fix applied here is an exact parallel to the first commit for<br>
- this bug.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-17 12:22:34 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e57017fa3eaeb1c2034eb0925e0da2f38e286d3">8e57017fa3eaeb1c2034eb0925e0da2f38e286d3</a>
-<blockquote>
-<p>
- Fixes 693552 - regression with polygon handling.<br>
-<br>
- The previous fix, b2796b4d58, did not properly handle the pathological<br>
- case of adding an HPGL/2 sub-polygon to an empty polygon path.<br>
-<br>
-pcl/pgpoly.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-17 17:58: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=2a3bf5a4865d2d97e46742d14814758bb70abf53">2a3bf5a4865d2d97e46742d14814758bb70abf53</a>
-<blockquote>
-<p>
- Bug 693541: Fix 'undefined filename' error<br>
-<br>
- If '%' is used in a separation name (say &quot;45% 286 overprinting 186&quot;),<br>
- then when the file is opened, we interpret the % as a format specifier<br>
- and we complain. Simple fix is to replace '%' with '_' when generating<br>
- the tif filenames.<br>
-<br>
- The file now runs further, and hits another (unrelated) pattern cache<br>
- problem.<br>
-<br>
-gs/base/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-15 13:31:50 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=045ad34f5074874c38e77919db920c5ed45dc5f5">045ad34f5074874c38e77919db920c5ed45dc5f5</a>
-<blockquote>
-<p>
- Bug 693541: Fix planar depth calculation from color_info.<br>
-<br>
- At various places in the code, we assume that for a planar device:<br>
-<br>
- dev-&gt;color_info.depth = dev-&gt;color_info.num_components * plane_depth<br>
-<br>
- This is NOT necessarily the case (due to tag planes etc).<br>
-<br>
- We therefore avoid the need for this calculation by adjusting the<br>
- return value from gxdso_is_native_planar; rather than returning 0<br>
- or 1 (for not-planar or planar), we now return 0 or the depth of<br>
- the planes.<br>
-<br>
- The logic in pdf14_create_clist_device is updated to use this. This<br>
- gets the file mentioned in the bug through to another (seemingly<br>
- unrelated) crash that I will investigate next.<br>
-<br>
-gs/base/gdevdrop.c<br>
-gs/base/gdevmpla.c<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevppla.c<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclist.h<br>
-gs/base/gxcolor2.h<br>
-gs/base/gxdevsop.h<br>
-gs/base/gxht_thresh.c<br>
-gs/base/gxicolor.c<br>
-gs/base/gximono.c<br>
-gs/base/gxp1fill.c<br>
-gs/base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-16 12:08:24 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=37e07e95a5588c2feaba60bbf506a7a9e433a43c">37e07e95a5588c2feaba60bbf506a7a9e433a43c</a>
-<blockquote>
-<p>
- Fix bug 693557: SEGV regression with NumRenderingThreads &gt; 0 in pattern_load<br>
-<br>
- This was due to the pdf14 device changing num_components during clist playback<br>
- when it had not changed during writing the clist. When a pattern tried to load<br>
- it failed the check that the depth of the pattern matched the depth of the<br>
- device. This was traced to picking the pdf14cmyk device during rendering instead<br>
- of the pdf14CMYKspot device because the thread's max_components was set to 4,<br>
- not 14 (as during clist writing). Fix the MaxSeparations in gsdparam to return<br>
- max_components instead of num_components, then fix devn_get_params to pass the<br>
- PageSpotColors param and the setting of num_components in devn_put_params to<br>
- ignore max_separations since that doesn't make sense.<br>
-<br>
-gs/base/gdevdevn.c<br>
-gs/base/gsdparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-16 21:54: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=cb51890a39bb97de55c5ce4734c55cba060d8e79">cb51890a39bb97de55c5ce4734c55cba060d8e79</a>
-<blockquote>
-<p>
- pdf14_mark_rectangle speedups<br>
-<br>
- Customer 532 report 3 files that perform slower than they would like.<br>
- Profiling of these files shows that they all make heavy use of<br>
- fill rectangle calls on a pdf14 device. This means lots of time<br>
- is spent in pdf14_mark_fill_rectangle, and the subsidiary function<br>
- it calls, art_pdf_composite_pixel_alpha_8.<br>
-<br>
- This commit introduces various optimisations:<br>
-<br>
- 1) We avoid the collation/decollation copies for the additive<br>
- case by using a new function (art_pdf_composite_alpha_8_fast) that<br>
- takes the planeheight as an arg. This may do the collation/decollation<br>
- internally if required.<br>
-<br>
- 2) We pull the logic for the 2 fast cases out of<br>
- art_pdf_composite_pixel_alpha_8_fast.<br>
-<br>
- 3) We rejig the loops to count downwards where possible.<br>
-<br>
- 4) We reduce the number of variables in use within the loop by<br>
- updating rowstride/alpha_g_off/shape_off/tag_off etc before the<br>
- loop.<br>
-<br>
- 5) We modify the values of src_alpha and shape before the loop to<br>
- avoid repeated calculations within the loops.<br>
-<br>
- 6) We add a special case loop to handle the num_comp == 1 &amp;&amp; additive<br>
- case (as typically seem with monochrome or grayscale devices). This uses<br>
- an even simpler art_pdf_composite_alpha_8_fast_mono routine (no loops<br>
- and fewer multiplies).<br>
-<br>
- Feedback from customer 532 is that these changes (backported to their<br>
- 8.71 based system) gives a noticable speedup.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gxblend.c<br>
-gs/base/gxblend.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-11 09:55:22 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ed38aa2fffd43cc0b38a4a0d1d66ec304ef0924e">ed38aa2fffd43cc0b38a4a0d1d66ec304ef0924e</a>
-<blockquote>
-<p>
- Fix for issue with transparency B stroke fill operation with softmask<br>
-<br>
- During a B operation (Stroke and fill) with transparency we push a knockout group to make sure<br>
- the stroke blows away the fill rather than blending. When there was a softmask present, we<br>
- were not passing along the soft mask for the fill portions during the group compositing operation.<br>
-<br>
-gs/base/gxblend.c<br>
-gs/base/gxblend.h<br>
-gs/base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-10 12:17:08 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1bc2a56f913ff1fa3f7af06000a4c6dd5c948afd">1bc2a56f913ff1fa3f7af06000a4c6dd5c948afd</a>
-<blockquote>
-<p>
- Fix bug 693361: Rendering threads unsafe use of main thread allocator.<br>
-<br>
- The PCL main thread allocator is not thread safe, and the rendering<br>
- threads would end up using this allocator to form link profiles (in<br>
- the lcms logic) because the device profile had the 'memory' allocator<br>
- set to the main thread's allocator.<br>
-<br>
- The fix found by Robin Watts was to use the thread's device (which<br>
- have a copy of the device profile with the thread's memory allocator,<br>
- set by gs_putdeviceparams) in the call to create_buf_device.<br>
-<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-10 12:08:03 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79e780b55d1e832895b3a9c6aa13017a57d1ca72">79e780b55d1e832895b3a9c6aa13017a57d1ca72</a>
-<blockquote>
-<p>
- Big 693185: Suppress unbalanced q/Q warning.<br>
-<br>
- When the stream run is aborted, the processed part is likely to have<br>
- more q than Q. Reporting this fact to the user is misleading, because<br>
- it's an interpretation artifact rather than the file property.<br>
-<br>
-gs/Resource/Init/pdf_base.ps<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-09 13:26:43 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e8d295679c4b6eabe71256b748282be048b27c05">e8d295679c4b6eabe71256b748282be048b27c05</a>
-<blockquote>
-<p>
- pdfwrite - when handling PaintType 2 fonts, cater for rotatedt text<br>
-<br>
- We handle PaintType 2 fonts in PDF output by leaving them as regular type 1<br>
- fonts but setting the text rendering mode to 1 (stroke). Naturally we also<br>
- have to calculate an appropriate stroke width based on the font matrix,<br>
- text point size and, for PDF, the text matrix.<br>
-<br>
- Previously we handled rotated FontMatrix entries, but didn't check for a<br>
- rotated text matrix, which led to a multiplication by 0 and setting the<br>
- stroke width much too narrow.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-09 02:12:56 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=339fcbd26065c2771a33ea8c805ff70bd097684a">339fcbd26065c2771a33ea8c805ff70bd097684a</a>
-<blockquote>
-<p>
- Bug 693033: Build shading in stopped context.<br>
-<br>
- Move shading dictionary construction into a stopped context. New code<br>
- just drops a shading that cannot be constructed or rendered instead of<br>
- aborting the whole stream run.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-08 14:17:44 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cf46f4c8ce91e6d62c902e58c79267934eed6eda">cf46f4c8ce91e6d62c902e58c79267934eed6eda</a>
-<blockquote>
-<p>
- Bug 693420: Add missing initialization of sim_overprint.<br>
-<br>
- Valgrind detects that sim_overprint is not initialised in this case.<br>
- Normally, gcc has it set to 0 and produces normal output. Setting it<br>
- to 1 creates the same incorrect output as reported.<br>
-<br>
-gs/base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-08 17:45:46 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb5a79b39e4ada667ac2e9c91179da29bafbd129">bb5a79b39e4ada667ac2e9c91179da29bafbd129</a>
-<blockquote>
-<p>
- Fix &quot;fallback&quot; to know about Microtype fonts<br>
-<br>
- In the event that FAPI fails to handle a font, there is a (temporary) fallback<br>
- to the AFS code.<br>
-<br>
- That fallback *must* not be used for the Microtype fonts loaded via UFST, since<br>
- the font loading code uses the error return to determine that we've loaded all<br>
- the fonts from the FCO.<br>
-<br>
- No cluster differences.<br>
-<br>
-pl/plfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-08 17:03: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=693b5421da925b627b7ce573ea7346b5d3611de9">693b5421da925b627b7ce573ea7346b5d3611de9</a>
-<blockquote>
-<p>
- Bug 693538: tweak TTF cmap format 4 parsing.<br>
-<br>
- Empty segments in the cmap table (that is, those where the start character code<br>
- is the same as the end code) aren't ignored, we correctly &quot;fake&quot; a one entry<br>
- segment. It seems, however, that we should *not* do that when the start and<br>
- end codes are zero - in that case, we should ignore it.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_ttf.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-08 08:47: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=3cc531830906a291d4d088e31936a92d7324e53c">3cc531830906a291d4d088e31936a92d7324e53c</a>
-<blockquote>
-<p>
- Switch Ghostscript/GhostPDL to Affero GPL<br>
-<br>
- As discussed on IRC, e-mail and at the last staff meeting.<br>
-<br>
-COPYING<br>
-LICENSE<br>
-gs/LICENSE<br>
-gs/doc/COPYING<br>
-gs/doc/Commprod.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/examples/cjk/all_ac1.ps<br>
-gs/examples/cjk/all_ag1.ps<br>
-gs/examples/cjk/all_aj1.ps<br>
-gs/examples/cjk/all_aj2.ps<br>
-gs/examples/cjk/all_ak1.ps<br>
-gs/examples/cjk/gscjk_ac.ps<br>
-gs/examples/cjk/gscjk_ag.ps<br>
-gs/examples/cjk/gscjk_aj.ps<br>
-gs/examples/cjk/gscjk_ak.ps<br>
-gs/examples/cjk/iso2022.ps<br>
-gs/examples/cjk/iso2022v.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-07 22:05:54 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e49f26eedd54120b615487db37dbdc1429685f79">e49f26eedd54120b615487db37dbdc1429685f79</a>
-<blockquote>
-<p>
- Bug 693539: Add duplex option to gslp utility.<br>
-<br>
- Commit a contributed patch that adds a duplex option to gslp script.<br>
-<br>
-gs/lib/gslp.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-07 13:29:03 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f85458194f235cf9236214b49c385e9bad4e11e">2f85458194f235cf9236214b49c385e9bad4e11e</a>
-<blockquote>
-<p>
- bug 693485: Handle single '~' as EOF in PDF<br>
-<br>
- Accept single '~' as a valid end of stream indicator in PDF files.<br>
- Acrobat Reader accepts this kind of PDF files without warnings.<br>
-<br>
-gs/base/sa85d.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-07 13:53:14 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=27df0d4971de23a82f0284c28aeb6e36cf355e46">27df0d4971de23a82f0284c28aeb6e36cf355e46</a>
-<blockquote>
-<p>
- Bug 693532: Fix GTK+ 2.x fallback.<br>
-<br>
- The conditions under which to test for and use GTK+ 2.x were incorrect.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-07 08:33:05 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e639c0764cc50640135528fa6b0faac233bd87d2">e639c0764cc50640135528fa6b0faac233bd87d2</a>
-<blockquote>
-<p>
- Fix indeterminism with FAPi and artificial bold glyphs<br>
-<br>
- Copy the raster lines from the FAPI bitmap into a temporary, appropriately<br>
- aligned buffer before doing the &quot;smearing&quot;.<br>
-<br>
- Also ensure that the FAPI settings for XL downloaded font and emboldening are<br>
- correct.<br>
-<br>
- Potentially affects all PCL/PXL test files with emboldening and XL fonts.<br>
-<br>
-gs/base/gxfapi.c<br>
-pl/plfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-04 20:34:47 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=def5e256da42d12cf8103fa7481380b6df84aa96">def5e256da42d12cf8103fa7481380b6df84aa96</a>
-<blockquote>
-<p>
- Bug 93512: Add -dUseArtBox option.<br>
-<br>
- ArtBox is often the smallest of all boxes. This option can be useful<br>
- when the file should be cropped to the smallest box without loss of<br>
- the contemt. Thanks to Marcos for the patch.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-04 02:39:34 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5124cc05570819036a7bf689dbed91f57f74ba24">5124cc05570819036a7bf689dbed91f57f74ba24</a>
-<blockquote>
-<p>
- Bug 693528: trap errors in ToUnicode CMap<br>
-<br>
- Read ToUnicode CMap in a stopped context. Ignore the CMap if<br>
- reading fails.<br>
-<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2013-01-02 17:21:24 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af5ba82a0c147b207d276a1acb9daa7bf7665227">af5ba82a0c147b207d276a1acb9daa7bf7665227</a>
-<blockquote>
-<p>
- pdfwritre - change fixed buffer for CIDSystemInfo to dynamic allocation<br>
-<br>
- Bug #693514 &quot;Broken PDF produced from PostScript by Windows 8 Microsoft<br>
- PS Class Driver&quot;<br>
-<br>
- The problem is that the CIDSystemInfo Registry and Ordering produced by<br>
- the Microsoft XPS to PS device is &gt; 32 characters. The code to write the<br>
- CIDSystemInfo used a fixed buffer of 32 characters. If that overflowed we<br>
- returned a limitcheck which caused pdfwrite to attempt a type 3 fallback<br>
- which also failed.<br>
-<br>
- Changed the code to (more logically) allocate a buffer for the temporary<br>
- usage. Also if this fails we return a VMerror which doesn't trigger an<br>
- attempt to fall back to type 3.<br>
-<br>
- No Expected Differences<br>
-<br>
-gs/base/gdevpdtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-28 18:32:37 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bc70bf785efcb1a3f9c995b5d8b4c1c29dc881e5">bc70bf785efcb1a3f9c995b5d8b4c1c29dc881e5</a>
-<blockquote>
-<p>
- Bug 693511: Ignore spurious ET operator<br>
-<br>
- Ignore ET operator when it appears outside of BT context and issue<br>
- a warning.<br>
-<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-28 10:20:44 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fea783c88450639227cfc456557ce16c348c9a67">fea783c88450639227cfc456557ce16c348c9a67</a>
-<blockquote>
-<p>
- Fixed minor typo in documentation.<br>
-<br>
-gs/doc/Make.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-25 13:27:35 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ec5b8eb0ccf0fc6881a6ffd2d190aa40e1faef1c">ec5b8eb0ccf0fc6881a6ffd2d190aa40e1faef1c</a>
-<blockquote>
-<p>
- Bug 693490: Warn about searching external contexts.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-25 12:58:02 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23e7e3054c095cd5157f2f7768f95a75b86f9779">23e7e3054c095cd5157f2f7768f95a75b86f9779</a>
-<blockquote>
-<p>
- Bug 693490: Search all XObject resources.<br>
-<br>
- Adobe Acrobat appears to search all nested XObjects for resource names<br>
- contrary to the PDF specification. This patch follows the reference<br>
- implementation and saves a pointer to XObject resource dictionary on<br>
- the graphic state. When a resource cannot be found in a standard way,<br>
- the stack of graphic states is searched.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-22 12:21:38 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b25fb04f7210656dd987cf23151aec08f4a9f2ee">b25fb04f7210656dd987cf23151aec08f4a9f2ee</a>
-<blockquote>
-<p>
- Documentation update (Bug 693491).<br>
-<br>
-gs/doc/Make.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-22 09:57:10 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6ca50ddca3268fe4626279c591e6fe3dce4c4228">6ca50ddca3268fe4626279c591e6fe3dce4c4228</a>
-<blockquote>
-<p>
- Have the PDF14 device properly set up some of its color info<br>
-<br>
- The lack of setting the comp_bits components in the color info when we have<br>
- the pdf14 CMYKSpot device caused an issue in the shading code. Fixes<br>
- Bug 693480.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-13 11:23:41 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1276ea02ac198b92788e3f6fac704c6ae2c2c4c7">1276ea02ac198b92788e3f6fac704c6ae2c2c4c7</a>
-<blockquote>
-<p>
- Enable proper blending to occur when we draw transparency patterns.<br>
-<br>
- This fixes Bug 693498. Previously we were not getting the blending information to<br>
- the group that we push to draw into. Also, there was a difference in how the clist<br>
- and non-clist pattern cases had to be handled. In the clist case, we do not know<br>
- what the blend mode for a group encompassing the pattern would be until the pattern is<br>
- run through the clist. Hence its logic with respect to transparency required a change.<br>
- Also fixed a bug that occurred when we used the -Zv debug option.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gsptype1.c<br>
-gs/base/gxblend.h<br>
-gs/base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-14 11:45: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=316c27810d36e234fa4b254765e35268cfadbc27">316c27810d36e234fa4b254765e35268cfadbc27</a>
-<blockquote>
-<p>
- Remove some debugging code<br>
-<br>
- left in accidentally.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-13 16:10: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=e5508fa002678eff5012ce09621d2b94c66e55a5">e5508fa002678eff5012ce09621d2b94c66e55a5</a>
-<blockquote>
-<p>
- Allow opt out of GNU make feature.<br>
-<br>
- As we currently only use one GNU make only feature, allow the user<br>
- to opt out of it at configure time with &quot;--without-gnu-make&quot;.<br>
-<br>
- Tested with Sun make and Sun dmake.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/Makefile.in<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-13 18:44:14 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da6307c97ac317a41e518c1db659a9dd88188669">da6307c97ac317a41e518c1db659a9dd88188669</a>
-<blockquote>
-<p>
- Fix pthreads error handling mistake.<br>
-<br>
- This bug was inherited from the mupdf example code I stole it from.<br>
- It seems that pthreads signals errors as non zero, not negative.<br>
-<br>
-gs/psi/apitest.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-13 16:56:09 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=776fe65eb131dd05728d8a448b6e4ce8dea5a9e0">776fe65eb131dd05728d8a448b6e4ce8dea5a9e0</a>
-<blockquote>
-<p>
- Document GS_THREADSAFE option<br>
-<br>
-gs/doc/API.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-13 15: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=e4e84ee2f724710d3a34119c13a621bd32c283d2">e4e84ee2f724710d3a34119c13a621bd32c283d2</a>
-<blockquote>
-<p>
- Bug 693501: have configure detect and handle memalign<br>
-<br>
- OpenJPEG uses memalign, if available, but has a rather poor test for it being<br>
- available.<br>
-<br>
- This change has configure check for memalign, and augment the compiler command<br>
- line to replace memalign with a normal malloc for the OpenJPEG code.<br>
-<br>
- So, several BSD variants, AIX etc should now build okay.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-13 14:59:19 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bbc2e3b761fd58e1cfe155840c0b948e71c5f37d">bbc2e3b761fd58e1cfe155840c0b948e71c5f37d</a>
-<blockquote>
-<p>
- Fix the SHARE_ZLIB build.<br>
-<br>
- Add an EXTRALIBS variable for the aux programs (AUXEXTRALIBS) so that<br>
- the &quot;-l&quot; directives get included, and in the correct position on the<br>
- compiler/linker command line.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/Makefile.in<br>
-gs/base/unix-aux.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-12 10:23:27 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ee7fdd12e17fad500202234e04035d85fb70ebd0">ee7fdd12e17fad500202234e04035d85fb70ebd0</a>
-<blockquote>
-<p>
- Perform range restriction after tint transform of separation color.<br>
-<br>
- Fixes bug 693497. Thanks to Alex for solving the issue before I even had a look at it.<br>
-<br>
-gs/base/gscsepr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-09 09:48:14 -0800
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=363443d8b2e8373541a886ed16ad281bfd6d31f4">363443d8b2e8373541a886ed16ad281bfd6d31f4</a>
-<blockquote>
-<p>
- Fix memory leaks from FAPI/FT glyph data buffers.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-08 17:53:34 -0800
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=078175e8df7835ff4df00e53b256a9c7fbd32ed7">078175e8df7835ff4df00e53b256a9c7fbd32ed7</a>
-<blockquote>
-<p>
- Fix pl_fapi_passfont() return code.<br>
-<br>
- For now we want to fall back to the AFS code if FAPI can't handle a font.<br>
-<br>
- No cluster differences.<br>
-<br>
-pl/plfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-08 22:29:57 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a8e20d4064e3df5fbb347a0cc8176635ce842e33">a8e20d4064e3df5fbb347a0cc8176635ce842e33</a>
-<blockquote>
-<p>
- Fix ARCH_SIZEOF_GX_COLOR_INDEX that mistakenly got committed in git-confusion.<br>
-<br>
- ARCH_SIZEOF_COLOR_INDEX was in a local branch that got had the problem and<br>
- got pushed when trying to work from my confused git repo.<br>
-<br>
-gs/base/gxclutil.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-08 14:46:27 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9305f19f4ce60e9fbd3e15d1f22ceaa28502f95b">9305f19f4ce60e9fbd3e15d1f22ceaa28502f95b</a>
-<blockquote>
-<p>
- Get rid of compiler warnings when SIZEOF_GX_COLOR_INDEX is 4.<br>
-<br>
-gs/base/gxclutil.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-08 10:57:04 -0800
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=024697aa2aec80c2e162a2e7a0707006b418e0e3">024697aa2aec80c2e162a2e7a0707006b418e0e3</a>
-<blockquote>
-<p>
- Fix a little bitrot in the trace device(s).<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gdevtrac.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-07 21:07:17 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=482da0636bf70aea3bd44839e27eee650e430982">482da0636bf70aea3bd44839e27eee650e430982</a>
-<blockquote>
-<p>
- Bug 690778: revert big resource hack.<br>
-<br>
- Revert most of the commit 93ffd5c00fef9f616fa6785106935344f6db69b5,<br>
- which worked around 64K limit in resource dictionaries. gs now can<br>
- create big objects directly.<br>
-<br>
-gs/Resource/Init/pdf_base.ps<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-05 20:36:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=01d43e701413c63dc3d7f85b4c5d748b7b7da8c9">01d43e701413c63dc3d7f85b4c5d748b7b7da8c9</a>
-<blockquote>
-<p>
- Add some missing header dependencies.<br>
-<br>
- No cluster differences.<br>
-<br>
-pl/pl.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-05 19:32: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=0e107d4c37b14c21f5d855b70443873e9e9e9a8e">0e107d4c37b14c21f5d855b70443873e9e9e9a8e</a>
-<blockquote>
-<p>
- Make MAX_TOKEN big enough for large paths<br>
-<br>
- Recommended by Nelson Beebe - his work reviewed a large number of common (and<br>
- not so common) environments, and the largest allowable &quot;monolithic&quot; path is<br>
- 4096 characters, so I've made MAX_TOKEN that size.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/genconf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-05 12:44: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=49571b9821b825cafd9691a7d25dfdeebbf9dd7d">49571b9821b825cafd9691a7d25dfdeebbf9dd7d</a>
-<blockquote>
-<p>
- Various fixes for FAPI/UFST.<br>
-<br>
- Allow the &quot;old school&quot;, non-FAPI PCL/UFST build to continue to work.<br>
-<br>
- Add support for UFST 5.x with FAPI.<br>
-<br>
- For XL format downloaded TTFs, disable hinting.<br>
-<br>
- This causes differences in ~161 cluster PCL test files - that is, files that<br>
- have XL format downloaded Truetype fonts in them.<br>
-<br>
-config.mak.in<br>
-configure.ac<br>
-gs/base/configure.ac<br>
-gs/base/fapi_ft.c<br>
-gs/base/fapiufst.c<br>
-gs/base/gxfapi.c<br>
-gs/base/gxfapiu.c<br>
-gs/psi/zfapi.c<br>
-main/pcl6_gcc.mak<br>
-pl/pl.mak<br>
-pl/plfapi.c<br>
-pl/plftable.h<br>
-pl/pllfont.c<br>
-pl/plulfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-04 08:39:14 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59d840fc9bdcf7d7ebb03d4d2d3f1e4d5d927d14">59d840fc9bdcf7d7ebb03d4d2d3f1e4d5d927d14</a>
-<blockquote>
-<p>
- Bug 693479: add missing CID to glyph index step<br>
-<br>
- For TTF CIDFonts loaded from disk (usually as a substitute), and using an<br>
- Identity ordering, there was a missing step to get from the CID to the TTF<br>
- GID. This caused problems when a PDF included a non-identity CIDToGIDMap.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-03 17:32:56 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5b4cea1173891c7c7252eb790af8357c9065a5ce">5b4cea1173891c7c7252eb790af8357c9065a5ce</a>
-<blockquote>
-<p>
- pdfwrite - improve locaFormat fix<br>
-<br>
- commit 4d20aa6061c6bc802c1ff8e031cfb434dd7fd490 sets the top byte of the<br>
- locaFormat in the HEAD table to be the same as 'indexToLocFormat. It<br>
- should actually always be 0, fixed here.<br>
-<br>
-gs/base/gdevpsft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-03 12:10:12 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d20aa6061c6bc802c1ff8e031cfb434dd7fd490">4d20aa6061c6bc802c1ff8e031cfb434dd7fd490</a>
-<blockquote>
-<p>
- pdfwrite - fix incorrect TrueType locaFormat.<br>
-<br>
- Some TrueType fonts have the locaFormat specified incorrectly in little<br>
- endian format. Our code always writes short loca entries, and sets the<br>
- low order byte of the locaFormat to 0 (short entries).<br>
-<br>
- It wasn't setting the high order byte, because it should never be<br>
- anything other than 0. However these incorrect fonts set the high order<br>
- byte instead of the low order. It seems TrueType consumers treat the format<br>
- as 0 or NOT 0 rather than chekcing the value, which meant we were leaving<br>
- the format incorrectly set.<br>
-<br>
- This simple patch sets both bytes of the format in the HEAD table and fixes<br>
- the problem.<br>
-<br>
- Expected differences<br>
- Bug691850.pdf and Bug691035b.pdf show significant progressions<br>
-<br>
-gs/base/gdevpsft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-12-01 09:44:56 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3a4439baee68c440da7164daf55de04a4d48609a">3a4439baee68c440da7164daf55de04a4d48609a</a>
-<blockquote>
-<p>
- pdfwrite - fix bug in commit a3d00daf5f9abb1209cb750a95e23bc6951c1c63<br>
-<br>
- missed an entry in the PDFDocEncoding lookup table, also fixed a minor<br>
- error message and corrected an index.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-30 17:03:02 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8ebecfe095e4585523fcbddbe1785473e0374b54">8ebecfe095e4585523fcbddbe1785473e0374b54</a>
-<blockquote>
-<p>
- Fix so that the blackpoint is set to a proper enumerated value<br>
-<br>
- Fixes bug 692530<br>
-<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevrinkj.c<br>
-gs/base/gdevxcf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-30 16:51:48 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c8fc6c53f0bce4be54c016ddd78f6cfe4d44419a">c8fc6c53f0bce4be54c016ddd78f6cfe4d44419a</a>
-<blockquote>
-<p>
- Avoid inserting the ICC profile into the halftoned TIFF output files.<br>
-<br>
- Fixes bug 693060<br>
-<br>
-gs/base/gdevtifs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-30 17:04:59 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0bc3c907260275bf96a4d3e894e4a8146ddbb856">0bc3c907260275bf96a4d3e894e4a8146ddbb856</a>
-<blockquote>
-<p>
- Remove .DS_Store files from lcms2 directory<br>
-<br>
- These seem to upset at least one unzipping utility on the Mac, and<br>
- they serve no useful purpose for us.<br>
-<br>
-gs/lcms2/Projects/mac/LittleCMS/.DS_Store<br>
-gs/lcms2/Projects/mac/LittleCMS/._.DS_Store<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-30 16:02:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a3d00daf5f9abb1209cb750a95e23bc6951c1c63">a3d00daf5f9abb1209cb750a95e23bc6951c1c63</a>
-<blockquote>
-<p>
- pdfwrite - convert non-UTF-16BE doc info to UTF-8 assuming PDFDocEncoding<br>
-<br>
- Bug #693477 &quot;Encoding of pdf metadata do not comply with pdf standard&quot;<br>
-<br>
- When processing Document info there is a pdfwrite parameter 'PDFDSCEncoding'<br>
- which, if present, is used to process the string into ASCII. However, if<br>
- this parameter is not supplied, we don't re-encode the string at all. Since<br>
- the XML must be UTF-8, this is potentially a problem.<br>
-<br>
- Since we cannot know the source of the docinfo string (existing PDF, DOCINFO<br>
- pdfmark, or DSC comments in PostScript) we cannot make any judgement about<br>
- the encoding of the string data in the absence of PDFDSCENcoding. So we<br>
- choose to assume that its encoded using PDFDocEncoding if it does not<br>
- have a UTF-16BE BOM (which is the only other format permitted).<br>
-<br>
- This should at least mean that the Docinfo and XML match and are legal.<br>
-<br>
- No differences expected, the cluster doesn't check the XML<br>
-<br>
-gs/base/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-30 07:55:46 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb97932923e94ef0806909718da693bf7655631f">bb97932923e94ef0806909718da693bf7655631f</a>
-<blockquote>
-<p>
- Fix 693269 - CCITT raster not using monochrome palette.<br>
-<br>
- The RTL CCITT raster compression modes always use monochrome colors (a<br>
- palette with 1 bit per index). In our code this is somewhat awkward<br>
- requiring rebuilding the PCL raster and part of the graphics library<br>
- state as the compression mode can be changed after raster mode has<br>
- been entered and initialized with a color palette.<br>
-<br>
-pcl/pccid.c<br>
-pcl/pccid.h<br>
-pcl/pcpalet.h<br>
-pcl/rtgmode.c<br>
-pcl/rtgmode.h<br>
-pcl/rtrstst.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-30 07:46:01 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=df30839b4058ba92dd85883516258ce08eaca628">df30839b4058ba92dd85883516258ce08eaca628</a>
-<blockquote>
-<p>
- Bug 693437 - Improves PCL font selection.<br>
-<br>
- We do not have perfect emulation of PCL font selection by attribute,<br>
- but this change does move us closer to the HP behavior. In particular<br>
- any font family attribute command (bold, italic etc.) cancels a<br>
- pending font selection by id, (i.e. the next selection will not use<br>
- the font id as a selection criteria).<br>
-<br>
-pcl/pcfont.c<br>
-pcl/pcfont.h<br>
-pcl/pcfontpg.c<br>
-pcl/pcfsel.c<br>
-pcl/pcsfont.c<br>
-pcl/pcsymbol.c<br>
-pcl/pctext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-29 09:00:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=64ada98bdec11021ada90ddd21b8d9cdd9ee61a2">64ada98bdec11021ada90ddd21b8d9cdd9ee61a2</a>
-<blockquote>
-<p>
- Make genconf's token buffer big enough for long paths<br>
-<br>
- Thanks to Chen Qi ( Qi.Chen@windriver.com ) for pointing out the problem.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/genconf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-29 08:05:34 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e02795887e3dd4fb75aaa90dc0bcf6d861246f4c">e02795887e3dd4fb75aaa90dc0bcf6d861246f4c</a>
-<blockquote>
-<p>
- Bug 693474: Make ps2pdf14 script executable<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/lib/ps2pdf14<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-29 01:55:36 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9e89056ce7f1998ac22cb274fd0ed29458ee5d35">9e89056ce7f1998ac22cb274fd0ed29458ee5d35</a>
-<blockquote>
-<p>
- Bug 693476: don't dump producer info for valid files<br>
-<br>
- Don't dump producer info when the file is valid but GS cannot<br>
- process it for some reason. For instance, when the password is<br>
- missing or invalid.<br>
-<br>
-gs/Resource/Init/pdf_sec.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-27 11:57:49 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b59e4d156deae8afd6c8eecad3ce8b83b2d7664">9b59e4d156deae8afd6c8eecad3ce8b83b2d7664</a>
-<blockquote>
-<p>
- Bug 693450: Add platform-dependent validation for file name characters.<br>
-<br>
- Add a new function to the portability layer that verifies, whether<br>
- a given character can be used in a file name. Convert separation<br>
- names to valid file names.<br>
-<br>
-gs/base/devs.mak<br>
-gs/base/gdevtsep.c<br>
-gs/base/gp.h<br>
-gs/base/gp_dosfs.c<br>
-gs/base/gp_macio.c<br>
-gs/base/gp_ntfs.c<br>
-gs/base/gp_os2fs.c<br>
-gs/base/gp_unifn.c<br>
-gs/base/gp_vms.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-27 01:04:52 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f27a0b8a47f0faadb6797132d6b9ef00a1823529">f27a0b8a47f0faadb6797132d6b9ef00a1823529</a>
-<blockquote>
-<p>
- Make PDF path construction operators more robust.<br>
-<br>
- Ignore the path construction operator that fails for some reason,<br>
- and continue. Also correct the pdfemptycount value during form<br>
- processing to match reality.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-21 10:15:49 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6f18589768e763238b5c45e46ba55dfef7dd59ae">6f18589768e763238b5c45e46ba55dfef7dd59ae</a>
-<blockquote>
-<p>
- pdfwrite - properly set the PreserveSMask parameter for non-transparent output<br>
-<br>
- The PDF interpreter has historically handled SMasks by passing them directly to<br>
- the device, when the device is pdfwrite. This was altered to use a device<br>
- parameter rather than checking the3 device name.<br>
-<br>
- This did not alter the functionality, which has always bee incorrect when<br>
- pdfwrite is not preserving transparency. We now alter the value of the<br>
- device parameter if we are instead rendering the transparent content to an<br>
- image. SMasks should now behave correctly when using PDF/A-1, PDF/X or<br>
- when setting the CompatibilityLevel to less than 1.4.<br>
-<br>
- No differences expected as this is not cluster tested.<br>
-<br>
-gs/base/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-20 17:19:44 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=481e7652bffc369fd0b7bc5b52aebde2328c4c5d">481e7652bffc369fd0b7bc5b52aebde2328c4c5d</a>
-<blockquote>
-<p>
- Don't use return_error() for something not really an error<br>
-<br>
- Quietens down the -Z# output.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-19 19:38:59 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=123c7fbf7f31e42dff306a6d0b993224387b1b3c">123c7fbf7f31e42dff306a6d0b993224387b1b3c</a>
-<blockquote>
-<p>
- pdfwrite - further TrueType composite glyph improvement. Bug #693444<br>
-<br>
- When we encounter a TrueType composite glyph, we add the 2 component glyphs<br>
- to the table of names, so that we generate a correct CMAP subtable in the<br>
- embedded subset font.<br>
-<br>
- However, the name is based on the GID of the glyph, and if the GID happens<br>
- match a name in the font Encoding (type 42 font) *and* we use the glyph<br>
- which really corresponds to that name (but obviously has a different GID)<br>
- then we would end up with the wrong CMAP generated.<br>
-<br>
- By not removing the GS_MIN_GLYPH_INDEX bias we create a new name which is<br>
- numeric and based on the GID. This guarantees no name collisions.<br>
-<br>
- This leads to a regression in an XPS test file, but I think it is of the<br>
- 'wrong before, differently wrong now' category and propose to ignore it on<br>
- that basis. (its a change in spacing, which cannot be directly affected by<br>
- this change.<br>
-<br>
-gs/base/gxfcopy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-18 09:51:34 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=787b044f67826cfc0c8b9fda01728cb602b4c212">787b044f67826cfc0c8b9fda01728cb602b4c212</a>
-<blockquote>
-<p>
- Bug #693111 fix refinement.<br>
-<br>
- Refine the fix 8bec29de to add a configuration option so individual<br>
- commands can be selected for the unusual behavior of being ignored in<br>
- raster mode. I don't think we have a solid understanding of this<br>
- problem and this makes the fix significantly less likely to result in<br>
- a regression.<br>
-<br>
-pcl/pcommand.h<br>
-pcl/pcparse.c<br>
-pcl/pcpatrn.c<br>
-pcl/rtgmode.c<br>
-pcl/rtgmode.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-17 10:57:53 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8bec29de4c0b67873d1e33e77296eed410be172e">8bec29de4c0b67873d1e33e77296eed410be172e</a>
-<blockquote>
-<p>
- Fixes Bug 693311 - Black rectangle output instead of expected image.<br>
-<br>
- Normally if the PCL interpreter receives a command while processing<br>
- raster or an image, the command is ignored and raster is shut down.<br>
- These so called &quot;locked out&quot; commands do not close out the raster on<br>
- plotters using the HPGL/2-RTL emulation.<br>
-<br>
-pcl/pcparse.c<br>
-pcl/rtgmode.c<br>
-pcl/rtgmode.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-16 14:56:12 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a00be33f0127db231ca42f97e1f8b6ca4f69ecf">6a00be33f0127db231ca42f97e1f8b6ca4f69ecf</a>
-<blockquote>
-<p>
- Bug 693451: avoid notdef &quot;special casing&quot; for cid fonts.<br>
-<br>
- Bug692320.pdf should display as before the FAPI work.<br>
-<br>
-gs/base/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-14 16:52:27 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9cb6ee748223ec3373151047d921d75bbeffc4e9">9cb6ee748223ec3373151047d921d75bbeffc4e9</a>
-<blockquote>
-<p>
- Fix for issues with icc output intent<br>
-<br>
- Proper rendering of the output rendering intent Ghent test files to RGB based devices require that<br>
- the output intent profile is used as a proofing profile. Unfortunately littleCMS does not allow one<br>
- to specify different rendering intents to use when connecting a group of profiles together. This<br>
- is needed to render these files correctly. The solution was to create a device link profile for the<br>
- first rendering intent (e.g perceptual) when going from source to proof. Then the remainder of the<br>
- transforms are handled in a relative colorimetric manner from proof to destination and possibly through<br>
- the device's link profile.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_lcms2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-13 23:20: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=8ebb6896c6f7ba59a6e7dec1267a65a66f817f1c">8ebb6896c6f7ba59a6e7dec1267a65a66f817f1c</a>
-<blockquote>
-<p>
- Use consistent ctm scale for metrics retrieval.<br>
-<br>
- This minimises differences at different resolutions, and uses a scale chosen to<br>
- minimise rounding errors.<br>
-<br>
- Also, fix handling of missing glyph in the glyph metrics retrieval function.<br>
-<br>
- Lots of cluster differences in PCL/PXL tests.<br>
-<br>
-pl/plfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-13 23:18:17 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a372bbae80c5b14cf68d2893db790acfef4a4f86">a372bbae80c5b14cf68d2893db790acfef4a4f86</a>
-<blockquote>
-<p>
- Remove (temporarily?) the Makefile exclusion.<br>
-<br>
- We can't simply exclude Makefile, since the GhostPDL top Makefile is not a derived file.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-13 18:02: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=1e05c7a541280979e0884f8ea1c1cee6eba8f229">1e05c7a541280979e0884f8ea1c1cee6eba8f229</a>
-<blockquote>
-<p>
- Fix the language_switch Windows build with new fapi code.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-language_switch/pspcl6_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-13 17:01:53 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e1af42f1cca2cfb1f3f0c2d9e59e46bb8697fa27">e1af42f1cca2cfb1f3f0c2d9e59e46bb8697fa27</a>
-<blockquote>
-<p>
- pdfwrite - amended white list for font DRM<br>
-<br>
- Copied again from teh Adobe web site, but mergin with the old list rather<br>
- than replacing. It looks like Adobe have changed some of their font names.<br>
-<br>
- This shows a difference in fonts.pdf, beacuse we are now permitted to embed<br>
- Mathematical Pi. THis is a progression<br>
-<br>
-gs/base/whitelst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-13 12:59:17 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c54b37f8a5ad111dbfad499ba1c642ba404f5e93">c54b37f8a5ad111dbfad499ba1c642ba404f5e93</a>
-<blockquote>
-<p>
- Fix a couple of Windows build issues with the new fapi code<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/winlib.mak<br>
-main/pcl6_msvc.mak<br>
-xps/xps_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-01 15:44: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=58937f6debfbed7675a0ce5cb8d0aa629e3fa7b8">58937f6debfbed7675a0ce5cb8d0aa629e3fa7b8</a>
-<blockquote>
-<p>
- Extend/modify FAPI for use by PDLs other than PS/PDF.<br>
-<br>
- All languages take a -dDisableFAPI option which reverts to the AFS code.<br>
-<br>
- On Unuix type systems<br>
- ./configure --disable-fapi<br>
-<br>
- and on Windows, adding &quot;FT_BRIDGE=0&quot;<br>
-<br>
- create builds without the FAPI font handling.<br>
-<br>
- Both of these will be removed as the FAPI code matures.<br>
-<br>
- Move Font API from psi into base.<br>
-<br>
- Split the FAPI functions into the interpreter dependent ones, and the &quot;core&quot;<br>
- functions. Move the core functions into the graphics library.<br>
-<br>
- Change fapi.dev to fapi_ps.dev<br>
-<br>
- Since the old fapi.dev is now split into core and PS dependent parts, the<br>
- old fapi.dev gets renamed as fapi_ps.dev<br>
-<br>
- Basic TrueType support thru FAPI for pcl and pxl.<br>
-<br>
- Doesn't include artificial boldening.<br>
-<br>
- Basic FAPI functions working with XPS interpreter.<br>
-<br>
- (Mostly) Make PCL/UFST work through gs_fapi API<br>
-<br>
- Bug 693188: don't skip glyphs with degenerate matrices<br>
-<br>
- In commit 752397ab, the fix for Bug 692263 was to skip over glyphs when the<br>
- matrix in force for the glyph had a zero scale in either dimension.<br>
-<br>
- It seems that this approach had potentially unfavourable side effects in the<br>
- glyph cache.<br>
-<br>
- So, when we encounter a degenerate matrix rendering a glyph, we now force a<br>
- minimal, non-zero scale before attempting to render the glyph. This placates<br>
- the glyph cache.<br>
-<br>
- Cluster testing shows (tiny) progressions in Bug689006.pdf, Bug690179.pdf,<br>
- and Bug692634.ps, and pixel differences, not identifiable as progressions<br>
- or regressions in Bug690497.pdf and 12-07C.PS.<br>
-<br>
- Conflicts:<br>
-<br>
- gs/psi/fapiufst.c<br>
- gs/psi/ifapi.h<br>
- gs/psi/zfapi.c<br>
-<br>
- Revise gs_fapi_available and zFAPIavailable so they can check for<br>
- a specific fapi server being available (as well as just fapi itself being<br>
- available.<br>
-<br>
- Tidy up header includes, and header dependencies.<br>
-<br>
- Typos, warnings and dependency mistakes.<br>
-<br>
- Handle FAPI having no servers gracefully in PCL and XPS<br>
-<br>
- Use existing API to retrieve glyph metrics.<br>
-<br>
- Fix some PCL/PXL spacing problems.<br>
-<br>
- Improve handling of notdefs in PCL/PXL<br>
-<br>
- Some reformatting.<br>
-<br>
- Update fapi call in xps and fix some merge mistakes.<br>
-<br>
- Change gs_fapi_do_char() parameters to gs_glyph and gs_char types.<br>
-<br>
- Handle GS_NO_CHAR value better.<br>
-<br>
- Remove deprecated char_code entry<br>
-<br>
- Provide method for client to request ttf cmap in fapi.<br>
-<br>
- Skip &quot;unencodable&quot; glyphs (that is character codes whose &quot;decoding&quot; results<br>
- in a gs_no_glyph glyph value).<br>
-<br>
- Fix (finally, I think) the PCL notdef problems, and PCL text orientation.<br>
-<br>
- Also, a GL spacing problem. Amend the Postscript size to work with these<br>
- changes.<br>
-<br>
- FAPI API and warnings clean up.<br>
-<br>
- Identify glyph index or otherwise....<br>
-<br>
- ...in the FAPI PS world.<br>
-<br>
- fix a missing dependency<br>
-<br>
- Include stdint_.h in gxfapi.h....<br>
-<br>
- so int64_t is available. Add dependency.<br>
-<br>
- Fix typo in dependency.<br>
-<br>
- Changes to build gs_fapi on Windows.<br>
-<br>
- Fix a typo<br>
-<br>
- &lt;sigh&gt; another &quot;notdef&quot; handling revision<br>
-<br>
- Add PCL/XL glyph boldening (bitmap smearing) to FAPI.<br>
-<br>
- Remove some debug code accidentally left in.<br>
-<br>
- Provide a &quot;-dDisableFAPI&quot; command line option for pcl/pxl/xps.<br>
-<br>
- It's added in a very noddy way for two reasons: it needs acted upon<br>
- before the interpreter is initialised, and second to make it more<br>
- obvious to remove when we've gained confidence in the new fapi code.<br>
-<br>
- Split fapi server builds out of lib.mak and into separate makefiles.<br>
-<br>
- Add one commercial server build to the Ghostscript/GhostPDL build system, so<br>
- it no longer needs built separately.<br>
-<br>
- Also fix a couple of dependency typos/errors.<br>
-<br>
- Some tweaks to get the build changes working on Windows<br>
-<br>
- Delete makefile....<br>
-<br>
- Revise build changes.<br>
-<br>
- Cluster differences in every PCL/PXL/XPS file with text display in a Truetype/Opentype font (including CFF).<br>
-<br>
-common/msvc_top.mak<br>
-common/ugcc_top.mak<br>
-config.mak.in<br>
-configure.ac<br>
-gs/Resource/Init/gs_fapi.ps<br>
-gs/base/Makefile.in<br>
-gs/base/configure.ac<br>
-gs/base/fapi_bs.mak<br>
-gs/base/fapi_ft.c<br>
-gs/base/fapibstm.c<br>
-gs/base/fapiufst.c<br>
-gs/base/gconf.c<br>
-gs/base/genconf.c<br>
-gs/base/gscdefs.h<br>
-gs/base/gsinit.c<br>
-gs/base/gslibctx.h<br>
-gs/base/gxfapi.c<br>
-gs/base/gxfapi.h<br>
-gs/base/gxfapiu.c<br>
-gs/base/gxfapiu.h<br>
-gs/base/gxfont.h<br>
-gs/base/lib.mak<br>
-gs/base/stub.mak<br>
-gs/base/winlib.mak<br>
-gs/base/wrfont.c<br>
-gs/base/wrfont.h<br>
-gs/base/write_t1.c<br>
-gs/base/write_t1.h<br>
-gs/base/write_t2.c<br>
-gs/base/write_t2.h<br>
-gs/psi/fapi_ft.c<br>
-gs/psi/fapibstm.c<br>
-gs/psi/fapiufst.c<br>
-gs/psi/ifapi.h<br>
-gs/psi/int.mak<br>
-gs/psi/msvc.mak<br>
-gs/psi/wrfont.c<br>
-gs/psi/wrfont.h<br>
-gs/psi/write_t1.c<br>
-gs/psi/write_t1.h<br>
-gs/psi/write_t2.c<br>
-gs/psi/write_t2.h<br>
-gs/psi/zfapi.c<br>
-language_switch/pspcl6_gcc.mak<br>
-main/pcl6_msvc.mak<br>
-pcl/pcfontpg.c<br>
-pcl/pcfsel.c<br>
-pcl/pcl.mak<br>
-pcl/pcsfont.c<br>
-pl/pl.mak<br>
-pl/plchar.c<br>
-pl/plchar.h<br>
-pl/plfapi.c<br>
-pl/plfapi.h<br>
-pl/plfont.c<br>
-pl/plfont.h<br>
-pl/plftable.c<br>
-pl/plftable.h<br>
-pl/pllfont.c<br>
-pl/pllfont.h<br>
-pl/plmain.c<br>
-pl/pluchar.c<br>
-pl/plufont.c<br>
-pl/plufstlp.c<br>
-pl/plufstlp.h<br>
-pl/plufstlp1.c<br>
-pl/plulfont.c<br>
-pxl/pxfont.c<br>
-pxl/pxl.mak<br>
-xps/ghostxps.h<br>
-xps/xps.mak<br>
-xps/xps_msvc.mak<br>
-xps/xpscff.c<br>
-xps/xpsfapi.c<br>
-xps/xpsfapi.h<br>
-xps/xpsttf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-12 20:05:31 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a971121e9e50c672908f1b3185f42d497adf0b02">a971121e9e50c672908f1b3185f42d497adf0b02</a>
-<blockquote>
-<p>
- New PCL-XL paper sizes fixing part of bug 693399.<br>
-<br>
- Thanks to Hin-Tak Leung for providing these new non standard paper<br>
- sizes to support Ricoh specific PCL-XL.<br>
-<br>
-gs/base/gdevpx.c<br>
-gs/base/gdevpxen.h<br>
-gs/base/gdevpxut.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-12 18:24:08 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b2796b4d588d83730c1d97c7fc035454cfe8157a">b2796b4d588d83730c1d97c7fc035454cfe8157a</a>
-<blockquote>
-<p>
- Fix part of bug #693415. HPGL's command to create a sub-polygon<br>
- closed paths unconditionally.<br>
-<br>
- Thanks to Norbert Janssen for providing a fix to conditionally close<br>
- the path only if the current pen is down. The fix revealed another<br>
- problem where PCL was not creating a new sub-path when the current pen<br>
- was up and drawing a circle (CI). This is remedied with issuing a<br>
- &quot;moveto&quot; not &quot;gapto&quot; when starting the circle. Currently the only<br>
- means of doing a moveto explicitly is to temporarily disable the &quot;hpgl<br>
- path mode&quot; while calling the gs_moveto() procedure. This arrangement<br>
- will likely be improved in the future by adding a gapto function to<br>
- the graphics library language interface.<br>
-<br>
- These changes result in fixing the original source problem and several<br>
- improvements in the PCL CET. A few new minor discrepancies<br>
- (regressions) were found in the CET's and another test (all documented<br>
- in the bug), these were either inconsequential or deferrable and we<br>
- feel this change is substantial progress and should not be held up for<br>
- the other issues to be addressed.<br>
-<br>
-pcl/pgdraw.c<br>
-pcl/pgpoly.c<br>
-pcl/pgvector.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-12 10:43:00 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=586d4a1669b0be9c05f7fcc45cbfc72a0dde5026">586d4a1669b0be9c05f7fcc45cbfc72a0dde5026</a>
-<blockquote>
-<p>
- Present clusterpush.pl from pushing Makefile(s).<br>
-<br>
-gs/toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-12 13:23: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=2c38e570321bb56e8c2d2a897502d207028e1c83">2c38e570321bb56e8c2d2a897502d207028e1c83</a>
-<blockquote>
-<p>
- Bug 693436: Resolve issues with FTS and 64 bit PS ints<br>
-<br>
- There was a number parsing case I had missed in special casing CPSI_mode for<br>
- QL test compatibility.<br>
-<br>
- Also, there were some issues with gs_cet.ps - some of the objects it replaced were left<br>
- writeable, and/or were off the wrong type.<br>
-<br>
- Cluster differences: we should now be able to pass all the FTS tests by using gs_cet.ps.<br>
-<br>
-gs/Resource/Init/gs_cet.ps<br>
-gs/psi/iscannum.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-12 13:23:09 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex,com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e6759327b6b8338491bf86ac3aa0179f47dc047d">e6759327b6b8338491bf86ac3aa0179f47dc047d</a>
-<blockquote>
-<p>
- pdfwrite - revert white list change which seemed to cause errors<br>
-<br>
-gs/base/whitelst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-12 11:23:50 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex,com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=24de0d2174103bb98d0c3ffbdf09c1081bbc98ef">24de0d2174103bb98d0c3ffbdf09c1081bbc98ef</a>
-<blockquote>
-<p>
- pdfwrite - update the 'white list' of fonts<br>
-<br>
- Some TrueType fonts have unintentional DRM applied, this commit updates<br>
- the Adobe 'white list' of fonts which may be embedded, even if the DRM<br>
- flags say otherwise.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/whitelst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-11 09:33:12 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39e56129466aa8d0b84c8c1267dbaef9dcefd2bd">39e56129466aa8d0b84c8c1267dbaef9dcefd2bd</a>
-<blockquote>
-<p>
- Fixes 693399, PXL file errors out when color palette is too large.<br>
-<br>
- The color palette should be truncated upon overflow, previously we<br>
- produced an error. Thanks to Hin-Tak Leung for the analysis and fix.<br>
-<br>
-pxl/pxink.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-11 08:41:03 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=774e27302ec3b228f6cef6abf04c18066edd5525">774e27302ec3b228f6cef6abf04c18066edd5525</a>
-<blockquote>
-<p>
- Hin-Tak Leung's fix for bug 693413 - large output file size due to<br>
- images being decimated to rectangles.<br>
-<br>
- The fix allows any orthogonal image, given the color information can<br>
- be properly represented in a PXL, to be converted directly to a PXL<br>
- image. The change has not been cluster tested, the PXL device is<br>
- tested in the overnight testing and there is no practical means to<br>
- test the device's code change with all test files locally, so the<br>
- commit also serves as a test submission.<br>
-<br>
-gs/base/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-09 12:34:01 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a8de3e6dc0152b137c38078d80a3c40517095f91">a8de3e6dc0152b137c38078d80a3c40517095f91</a>
-<blockquote>
-<p>
- Fixes 693385 Font id selection wrong when using SI (Shift In) and SO<br>
- (Shift out) commands and inappropriate switch to ID in font selection.<br>
-<br>
- The SO and SI were decaching the current font table, effectively<br>
- changing font ID selection to family selection. 2 additional and<br>
- closely related changes were provided by Norbert Janssen: the selected<br>
- by id state was being disabled during font selection even if font<br>
- selection had no effect and upon selection be id we were decaching<br>
- both font tables.<br>
-<br>
- All of these changes are certainly in the right direction but seem to<br>
- have unmasked some obscure problems which will be addressed in a<br>
- separate bug. Here are the expected regression test files for this<br>
- commit:<br>
-<br>
- tests_private/pcl/pcl5ccet/18-20.BIN<br>
- tests_private/pcl/pcl5ccet/19-05.BIN<br>
- tests_private/pcl/pcl5ccet/19-11.BIN<br>
- tests_private/pcl/pcl5ccet/19-12.BIN<br>
- tests_private/pcl/pcl5ccet/19-13.BIN<br>
- tests_private/pcl/pcl5ccet/19-14.BIN<br>
- tests_private/pcl/pcl5efts/fts.0280<br>
- tests_private/pcl/pcl5efts/fts.0341<br>
- tests_private/pcl/pcl5efts/fts.0380<br>
-<br>
-pcl/pcfont.c<br>
-pcl/pcfsel.c<br>
-pcl/pctext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-06 15:51: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=a0a4fd51a9c17a1b17d0cc9eccfef51e96ea8d04">a0a4fd51a9c17a1b17d0cc9eccfef51e96ea8d04</a>
-<blockquote>
-<p>
- Bug 693430: missing &quot;fallback&quot; for DecodeParams entry<br>
-<br>
- In a ResuableStreamDecode filter with an array of subfilters (/Filter entry<br>
- in the parameter dictionary). If teh DecodeParams array also exists, and has<br>
- one or more entries set to &quot;null&quot;, we weren't pushing an empty dictionary<br>
- onto the stack for the subsequent call to the filter operator.<br>
-<br>
- The equivalent code for a totally absent DecodeParams array was already<br>
- correct.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/gs_frsd.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-05 21:30:48 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=048b221e76fba80663f073f8312802bcdf168c52">048b221e76fba80663f073f8312802bcdf168c52</a>
-<blockquote>
-<p>
- Bug 693166: Speed images through the clist.<br>
-<br>
- In investigating bug 693166 Ray spotted that the calculation of which<br>
- bands were touched by images was slack in the presence of a clipping<br>
- path - he proposed a simple patch to fix this.<br>
-<br>
- Unfortunately it had a knock on effect where vertical offsets could be<br>
- introduced into the topmost band. This is fixed here by a second small<br>
- change in image_band_box.<br>
-<br>
- Cluster testing shows 10 small changes, all well within the usual<br>
- clist differences.<br>
-<br>
-gs/base/gxclimag.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-05 09:16:10 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=782d5c4083217d7225a843bf6bad254dca4c2e8c">782d5c4083217d7225a843bf6bad254dca4c2e8c</a>
-<blockquote>
-<p>
- Fixes bug #693429 process raw HPGL files.<br>
-<br>
- The PCL parser will now recognize HPGL files if the files start with<br>
- the commands &quot;IN&quot; or &quot;DF&quot; and if the parser is using the RTL<br>
- personality.<br>
-<br>
-pcl/pcl.mak<br>
-pcl/pcparse.c<br>
-pcl/rtmisc.c<br>
-pcl/rtmisc.h<br>
-pcl6/pcl6.xcodeproj/project.pbxproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-02 22:55:24 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=119f9ced7dc9be5f412ed587381627babb29d3ed">119f9ced7dc9be5f412ed587381627babb29d3ed</a>
-<blockquote>
-<p>
- Fix for missing code to grab the device profile. Thanks to sags for finding this.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-01 16:05:13 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0cefc049bdd1eee78f14c97129627af766e022c9">0cefc049bdd1eee78f14c97129627af766e022c9</a>
-<blockquote>
-<p>
- Fix tiffsep and introduce tiffscaled4 device.<br>
-<br>
- The tiffsep device was supposed to be able to be called with<br>
- -dBitsPerComponent set to 1,2,4 or 8 to allow differing bit<br>
- depths of output. This setting would work for the separation<br>
- planes, but would not produce a composite when bpc was not 8<br>
- due to the code not supporting that.<br>
-<br>
- We add code here to generate composites in 1,2 and 4 bit modes<br>
- too, along with some sanity checking of the compression mode.<br>
-<br>
- We also add a tiffscaled4 mode where we produce 1bpc cmyk from<br>
- a downscaled dither of 8bpc cmyk.<br>
-<br>
-gs/base/devs.mak<br>
-gs/base/gdevtsep.c<br>
-gs/base/gxdownscale.c<br>
-gs/base/unixansi.mak<br>
-gs/psi/msvc.mak<br>
-main/pcl6_gcc.mak<br>
-main/pcl6_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-11-01 15:24:04 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex,com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b10f8c659ffc643ab71c6180a70da4f39075578">9b10f8c659ffc643ab71c6180a70da4f39075578</a>
-<blockquote>
-<p>
- pdfwrite/ps2write - enable 64-bit file handling<br>
-<br>
- Subsequent to commit c81c8f1b8740c484ec332080b5ce5f718357694d it is now<br>
- possible to have 64-bit offsets returned by stell, and this makeds it possible,<br>
- for the first time, to write PDF files &gt; 4GB.<br>
-<br>
- There's a fair amount of reworking in here, but we can now produce very large<br>
- temporary files, and from that produce very large PDF and PostScript output.<br>
-<br>
- There are some restrictions; no stream can exceed 2GB and no font can exceed 2GB<br>
-<br>
- As might be expected this is *not* well tested as we don't actually have any<br>
- test files which exercise this. I have tested PDF and PostScript file production<br>
- with a single file which produces a 10GB temporary file, a 7 GB PDF file and a 6GB<br>
- PostScript file.<br>
-<br>
- The resulting PDF file opens with Adobe Acrobat and can Ghostscript, and the<br>
- PostScript file can be consumed by Adobe Distiller and Ghostscript.<br>
-<br>
- Nevertheless, bugs are possible.<br>
-<br>
- No differences expected as this is not lcuster tested.<br>
-<br>
-gs/base/gdevpdf.c<br>
-gs/base/gdevpdfb.c<br>
-gs/base/gdevpdfo.c<br>
-gs/base/gdevpdfu.c<br>
-gs/base/gdevpdfx.h<br>
-gs/base/gdevpdti.c<br>
-gs/base/gdevpsf1.c<br>
-gs/base/gdevpsf2.c<br>
-gs/base/gdevpsft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-29 17:28:05 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=84498da1627a85e340c7670b8c7a617e38b9efb7">84498da1627a85e340c7670b8c7a617e38b9efb7</a>
-<blockquote>
-<p>
- Support PJL language string HP-GL/2.<br>
-<br>
- The language string HP-GL/2 now selects the &quot;RTL&quot; mode in PCL. It<br>
- should also be used to select the language HP-GL/2 upon language<br>
- switch, but only one language string is supported per emulation, and<br>
- the feature is not really needed. Any HPGL/2 rtl file should select<br>
- the PCL emulation anyway because of the character of the input stream<br>
- and the HP-GL/2 PJL command will select the RTL personality.<br>
-<br>
-pcl/pctop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-25 11:19:21 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c81c8f1b8740c484ec332080b5ce5f718357694d">c81c8f1b8740c484ec332080b5ce5f718357694d</a>
-<blockquote>
-<p>
- 64 bit stream offsets and 64 bit PS integers objects<br>
-<br>
- Revise the stream and &quot;gp_&quot; file APIs to support file sizes &gt;4Gb (on suitable<br>
- systems).<br>
-<br>
- I've added a gs_offset_t type which, by default is a 64 bit signed type (this<br>
- matches the standard lib's 64 bit &quot;off_t&quot; type). For ports that may want to<br>
- use an alternative type, define &quot;GS_OFFSET_T&quot; to the desired type on the<br>
- compiler command line.<br>
-<br>
- By default, Ghostscript will now use 64 bit integer objects in Postscript. Again,<br>
- for porting ease, one can opt for 32 bit integer objects by defining PSINT32BIT=1<br>
- on the compiler command line.<br>
-<br>
- The handling of integer objects in various operators has been &quot;augmented&quot; so that<br>
- when working in &quot;CPSI compatibility mode&quot;, intepreting and manipulating integer<br>
- objects will see them &quot;clamped&quot; to 32 bit signed values. This allows Ghostscript<br>
- to still pass the Quality Logic tests which spuriously rely on 32 bit integer<br>
- objects.<br>
-<br>
- There is a minor tweek in the PS interpreter's handling of Truetype fonts (*not*<br>
- Type 42), where the algorithm used to create an XUID relied on 32 bit integers.<br>
-<br>
- There is a small performance penalty in this, but my testing suggests that it is<br>
- smaller than the time resolution of our testing capabilities (i.e. there are<br>
- greater variances between test runs than between the 32 and 64 bit objects code).<br>
-<br>
- We can now interpret PDF files &gt;4Gb.<br>
-<br>
- In addition, the graphics library will now include inttypes.h (in stdint_.h) if<br>
- it is available in order to make the &quot;PRI....&quot; printf and co formatting macros<br>
- available. If inttypes.h is not available, there are fallback definitions of the<br>
- most used of those. These can also be defined on the compiler command line for<br>
- specific ports, if required.<br>
-<br>
- A custom &quot;PRI...&quot; macro has been added in the Postscript interpreter,<br>
- &quot;PRIpsint&quot;, which is defined appropriately when integer objects are 64 or<br>
- 32 bit.<br>
-<br>
- This commit does *not* revise the device API to handle 64 bit integer values<br>
- (in the one case where this is required, we use a string to hold the 64 bit value,<br>
- I suggest continuing this, so the device API remains consistent across ports).<br>
-<br>
- I do expect a bug tail with this, as we start to encounter more &gt;4Gb PDFs.<br>
-<br>
- Cluster differences are restricted to the 3 QL Postscript test jobs that have<br>
- ended up in comparefiles (and thus are not run with the gs_cet.ps setup).<br>
-<br>
-config.mak.in<br>
-configure.ac<br>
-gs/Resource/Init/gs_ttf.ps<br>
-gs/base/Makefile.in<br>
-gs/base/configure.ac<br>
-gs/base/devs.mak<br>
-gs/base/gdevpsf2.c<br>
-gs/base/gdevpsft.c<br>
-gs/base/gdevtifs.c<br>
-gs/base/gp_mswin.c<br>
-gs/base/gp_unifs.c<br>
-gs/base/gsiorom.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclrast.c<br>
-gs/base/lib.mak<br>
-gs/base/scommon.h<br>
-gs/base/sfxfd.c<br>
-gs/base/sfxstdio.c<br>
-gs/base/std.h<br>
-gs/base/stdint_.h<br>
-gs/base/stdpre.h<br>
-gs/base/stream.c<br>
-gs/base/stream.h<br>
-gs/base/strmio.c<br>
-gs/base/strmio.h<br>
-gs/base/tiff.mak<br>
-gs/psi/btoken.h<br>
-gs/psi/fapi_ft.c<br>
-gs/psi/idebug.c<br>
-gs/psi/ilocate.c<br>
-gs/psi/int.mak<br>
-gs/psi/interp.c<br>
-gs/psi/iparam.c<br>
-gs/psi/iref.h<br>
-gs/psi/iscan.c<br>
-gs/psi/iscan.h<br>
-gs/psi/iscanbin.c<br>
-gs/psi/iscannum.c<br>
-gs/psi/iutil.c<br>
-gs/psi/opextern.h<br>
-gs/psi/zarith.c<br>
-gs/psi/zfapi.c<br>
-gs/psi/zfcid0.c<br>
-gs/psi/zfileio.c<br>
-gs/psi/zfjpx.c<br>
-gs/psi/zfrsd.c<br>
-gs/psi/zmisc.c<br>
-gs/psi/zrelbit.c<br>
-gs/psi/ztype.c<br>
-pl/pl.mak<br>
-pl/plfont.h<br>
-pl/pllfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-30 13:05:11 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dfde821467a4770499b52fbfb2c665a74ed379c0">dfde821467a4770499b52fbfb2c665a74ed379c0</a>
-<blockquote>
-<p>
- Fix silly dependency typo in lib.mak.<br>
-<br>
- Thanks to Chris for pointing this out.<br>
-<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-29 20:20:22 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aa7d7ffcc390b05a8e36b6cf85e4688ae69c2a85">aa7d7ffcc390b05a8e36b6cf85e4688ae69c2a85</a>
-<blockquote>
-<p>
- Fix interpolation code to behave consistently in the presence of pdf14.<br>
-<br>
- There are special cases in the setup of the image interpolation code<br>
- designed to kick in in the presence of halftoning devices and either<br>
- limit the amount or change the nature of the interpolation done.<br>
-<br>
- The test for this is confused by the presence of a pdf14 device though.<br>
-<br>
- We move the special cases down into a device specific op call to avoid<br>
- this. This also means that devices can have finer control over exactly<br>
- when these operations are used.<br>
-<br>
- One possibility would be to expose them as device params, but I haven't<br>
- done that here yet.<br>
-<br>
-gs/base/gdevdflt.c<br>
-gs/base/gxdevsop.h<br>
-gs/base/gxiscale.c<br>
-gs/base/lib.mak<br>
-gs/ghostscript.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-28 16:00:01 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49f1bba50c096dee3230e5221db4d5275b8e12e7">49f1bba50c096dee3230e5221db4d5275b8e12e7</a>
-<blockquote>
-<p>
- Fix optional content support for inline images. Because of the lack<br>
- of test cases, the old code has never been tested.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-27 19:10:13 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=88bf2cb37c0cb1c88ea03abb567dc7e0afdfef47">88bf2cb37c0cb1c88ea03abb567dc7e0afdfef47</a>
-<blockquote>
-<p>
- Refined the list of files to exclude in clsuterpush.pl.<br>
-<br>
-gs/toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-22 17:31:27 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=045e544c507b151daebc19aaf21a8b13b6c4a844">045e544c507b151daebc19aaf21a8b13b6c4a844</a>
-<blockquote>
-<p>
- Support rotated images with interpolation.<br>
-<br>
- See bug 690246.<br>
-<br>
- Testing this on the cluster with a patch that enables interpolation<br>
- for all landscape jobs reveals no problems.<br>
-<br>
-gs/base/gxcindex.h<br>
-gs/base/gximage.h<br>
-gs/base/gxipixel.c<br>
-gs/base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-25 16:43:37 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f4b2deea2aa129048014771c19ef9fb3c317de7e">f4b2deea2aa129048014771c19ef9fb3c317de7e</a>
-<blockquote>
-<p>
- Addition of support for the black preservation methods in littleCMS<br>
-<br>
- This is for bug 692223. With this commit now have support to specify black preservation on a object level (e.g. graphic, image or text).<br>
-<br>
-gs/base/gscms.h<br>
-gs/base/gsdparam.c<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_manage.h<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-26 01:04: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=9c3de1fb29628f83ae7d48238e0dd0f3f35ecda1">9c3de1fb29628f83ae7d48238e0dd0f3f35ecda1</a>
-<blockquote>
-<p>
- Fix typo in last commit.<br>
-<br>
- Missing 'int' in definition.<br>
-<br>
-gs/base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-25 20:44:53 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d68bdb872b1071e42dd937ca7526e5e2cfc9bca7">d68bdb872b1071e42dd937ca7526e5e2cfc9bca7</a>
-<blockquote>
-<p>
- Fix problem in interpolation code.<br>
-<br>
- When interpolating, if we are in an indexed space, we should<br>
- only offset by 1 component per sample, not as many components<br>
- as there are in the base space.<br>
-<br>
- This shows up problems with the forthcoming landscape commit,<br>
- but is fixed here separately as it is actually unrelated.<br>
-<br>
-gs/base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-25 13:44:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex,com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=97e17a24e89bb0f893fd43af35e774054e41eadc">97e17a24e89bb0f893fd43af35e774054e41eadc</a>
-<blockquote>
-<p>
- ps2write - while stripping OtherSubrs, don't try to index off stack<br>
-<br>
- The code assmued that a Callsubr operator woudl be preceded by the subr index<br>
- but in this case the subr index is provided by another Subr (crazy font...).<br>
-<br>
- All we need to do is cdheck the stack index, and if its 0, not index from the<br>
- stack but simply write the Callsubr operator.<br>
-<br>
- Fixed Bug #693325<br>
-<br>
- Expected Differences<br>
- tpc2.ps should no longer seg fault on the cluster with ps2write.<br>
-<br>
-gs/base/gdevpsf1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-24 19:10: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=c31725843fc3195970d12baad2916bf4dc3a5097">c31725843fc3195970d12baad2916bf4dc3a5097</a>
-<blockquote>
-<p>
- Bug 693407: Portion of image missing with interpolation<br>
-<br>
- The 'only interpolate the portion of the bitmap required' code was<br>
- going wrong in the case of X flipped bitmaps.<br>
-<br>
-gs/base/gxipixel.c<br>
-gs/base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-24 10:02:00 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f25f5e6f94ada1b3908b85ac68cabe2b9831d803">f25f5e6f94ada1b3908b85ac68cabe2b9831d803</a>
-<blockquote>
-<p>
- Enable default spot name usage when output profile is NCLR<br>
-<br>
- Previously I had added the requirement that we used something like<br>
- -sICCOutputColors=&quot;Cyan, Magenta, Yellow, Black, Orange, Violet&quot;<br>
- when using an NCLR ICC profile for the device profile (valid only for<br>
- tiffsep and psdcmyk devices). This was to ensure proper naming of the<br>
- profile colorants. It was pointed out by a customer that they would<br>
- prefer to have a set of default names so this was now added.<br>
- If -sICCOutputColors is not specified and we are using an NCLR ICC profile,<br>
- then we will have spot colors from the profile named ICC_COLOR_0, ICC_COLOR_1<br>
- etc.<br>
-<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevtsep.c<br>
-gs/base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-23 16:35:54 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=793971fc49dd62d02d92f4761c40f63a29eabd67">793971fc49dd62d02d92f4761c40f63a29eabd67</a>
-<blockquote>
-<p>
- Setting the default line attributes was done 2 places in the code.<br>
-<br>
-pcl/pglfill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-22 16:24:46 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=270fade3cd436aa8abe8d1ef00f4db4ba1f766f3">270fade3cd436aa8abe8d1ef00f4db4ba1f766f3</a>
-<blockquote>
-<p>
- Bug #693381, Norbert Jannsen's fix to track and home the pcl cursor<br>
- appropriately.<br>
-<br>
-pcl/pcommand.c<br>
-pcl/pcpage.c<br>
-pcl/pcpage.h<br>
-pcl/pcstate.h<br>
-pcl/pcursor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-12 19:46:00 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=68dd69edbd8e2728207f18435be933bdca461a6f">68dd69edbd8e2728207f18435be933bdca461a6f</a>
-<blockquote>
-<p>
- Make stcolor device threadsafe by removing static.<br>
-<br>
- Remove from list of unthreadsafe devices.<br>
-<br>
-gs/base/configure.ac<br>
-gs/base/gdevstc.c<br>
-gs/base/gdevstc.h<br>
-gs/base/gdevstc4.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-22 14:47:05 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36d9731f83201002df6a91699f86e84c8d8530b1">36d9731f83201002df6a91699f86e84c8d8530b1</a>
-<blockquote>
-<p>
- Fix -Zb decode flags.<br>
-<br>
- Some of the debugging code that had been changed to provide memory<br>
- pointers to the debugging print functions was attempting to<br>
- retrive a memory pointer from a stream that was on the stack.<br>
- Stack based streams have null memory pointers, resulting in SEGVs<br>
- when the pointers were used.<br>
-<br>
- Revert these calls back to the non threadsafe ones.<br>
-<br>
-gs/base/gximage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-21 11:49: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=16423bc7bb7c800122f04ec16869a88dcb6d69b0">16423bc7bb7c800122f04ec16869a88dcb6d69b0</a>
-<blockquote>
-<p>
- Fixes 693395 default screen vector fill percentage incorrect.<br>
-<br>
- Another inconsistency across HP devices: HP plotters apparently<br>
- default to a 50% fill if the Screened Vector (SV) command requests<br>
- shading but doesn't specify a percentage. On HP Printers the command<br>
- is ignored if the percentage is not provided explicitly.<br>
-<br>
-pcl/pglfill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-16 19:15:34 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0442ce0c95ffb9a33eba5c2303172e029883f2fb">0442ce0c95ffb9a33eba5c2303172e029883f2fb</a>
-<blockquote>
-<p>
- Add in support for spot color overprinting with standard CMYK devices<br>
-<br>
- Currently only the psdcmyk and tiffsep devices provide simulation of spot<br>
- color overprinting. With the following commit it is possible to get<br>
- simulation of overprinting with other CMYK based devices. This is done<br>
- using the command line option -dSimulateOverprint. The simulation is<br>
- achieved by having the overprint device blend the CMYK colorant with what<br>
- ever has currently been drawn.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevp14.h<br>
-gs/base/gscdevn.c<br>
-gs/base/gscms.h<br>
-gs/base/gscsepr.c<br>
-gs/base/gscspace.c<br>
-gs/base/gsdparam.c<br>
-gs/base/gsovrc.c<br>
-gs/base/gsovrc.h<br>
-gs/base/gstrans.h<br>
-gs/base/gxblend.h<br>
-gs/base/gxblend1.c<br>
-gs/base/gxcspace.h<br>
-gs/base/gxoprect.c<br>
-gs/base/gxoprect.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-19 17:32: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=19f407d322ba43e1aff403f625bd4d2a723f5e65">19f407d322ba43e1aff403f625bd4d2a723f5e65</a>
-<blockquote>
-<p>
- pdfwrite - bug #691653 Regression: /undefined in --run-- with pdfwrite starting with r11667<br>
-<br>
- The underlying problem is related to writing an ICCBased space corresponding<br>
- to an Lab space. However, the fallback when this fails does actually work.<br>
-<br>
- The fault was caused by us writing out (and referencing from the page object)<br>
- broen Shading, colourpsace and Pattern entries, which were never actually used.<br>
-<br>
- By removing the references from the page (but continuing to emit the broken<br>
- objects) 'corrects' this, and other files.<br>
-<br>
- Expected Differences : bug689880.pdf should now work.<br>
-<br>
-gs/base/gdevpdfg.c<br>
-gs/base/gdevpdfu.c<br>
-gs/base/gdevpdfv.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-17 23:02:51 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d028b4cb4693468b2cb842a156a52f127262e55">7d028b4cb4693468b2cb842a156a52f127262e55</a>
-<blockquote>
-<p>
- Update source color example file.<br>
-<br>
-gs/toolbin/color/src_color/objsrc_profiles_example.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-17 21:35:16 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=515767b6e4fb37b6259fbe0d6dec429f0d1727f9">515767b6e4fb37b6259fbe0d6dec429f0d1727f9</a>
-<blockquote>
-<p>
- Bug 693390: recover yet another broken PDF file<br>
-<br>
- Recognize and fix a case when &lt;&lt;/ColorSpace/DeviceRGB&gt;&gt; is used instead of CSA.<br>
- Also fix a real bug that prevented definition /DefaultXXX color spaces as<br>
- device color spaces by PDF file.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-16 18:45: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=cf41720e6d559213802caa3f47edb82182cc7565">cf41720e6d559213802caa3f47edb82182cc7565</a>
-<blockquote>
-<p>
- The manner in which the icc profile serial header structure was defined is plagued with alignment problems<br>
-<br>
- This fix avoids the use of the sizeof operation to specify the size of the serial header portion.<br>
- Thanks to Robin for his help in tracking down this issue.<br>
-<br>
-gs/base/gscms.h<br>
-gs/base/gsicc.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gxclist.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-17 09:49: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=a4cbd97bfe01b2c850902d8ee0983eda61fdb64d">a4cbd97bfe01b2c850902d8ee0983eda61fdb64d</a>
-<blockquote>
-<p>
- Bug 693389: add inkcov device to Windows build.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-16 08:51:58 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex,com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2741c775675f23403470cb680adbd0025e716e70">2741c775675f23403470cb680adbd0025e716e70</a>
-<blockquote>
-<p>
- add the 'debugaux' directory to the ignore list for Git<br>
-<br>
-.gitignore<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-13 02:42:15 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba77ca58e9ccf711a975b69c888f34e5371e4628">ba77ca58e9ccf711a975b69c888f34e5371e4628</a>
-<blockquote>
-<p>
- Fix issue with ./configure not correctly checking for files in contrib.<br>
-<br>
- For reasons that aren't clear the code &quot;!(test ...)&quot; doesn't work in<br>
- bash on AIX; this commit replaces it with &quot;! test ...&quot;. Hopefully this<br>
- won't fail on some other operating system.<br>
-<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-12 19:06:08 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d5904741b3e29c481bf0411c7fadd2c297b66828">d5904741b3e29c481bf0411c7fadd2c297b66828</a>
-<blockquote>
-<p>
- Remove statics from lxm3200 device.<br>
-<br>
- Remove this from the list of unthreadsafe devices.<br>
-<br>
-gs/base/configure.ac<br>
-gs/contrib/gdevlx32.c<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-12 18:33: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=f8d61ad9460e59381ca9239c383ec3f91d2e1679">f8d61ad9460e59381ca9239c383ec3f91d2e1679</a>
-<blockquote>
-<p>
- Fix cdj970 and fmlbp devices to be threadsafe.<br>
-<br>
- Avoid use of global variables.<br>
-<br>
- Remove these from the list of unthreadsafe devices.<br>
-<br>
-gs/base/configure.ac<br>
-gs/contrib/gdevdj9.c<br>
-gs/contrib/japanese/gdevfmlbp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-12 17:54:51 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cb6bedc4c5b81c4cb074d1c784573fd96165cc8e">cb6bedc4c5b81c4cb074d1c784573fd96165cc8e</a>
-<blockquote>
-<p>
- Fix cp50 device to avoid use of global.<br>
-<br>
- Move 'int copies' into the device structure.<br>
-<br>
- Remove cp50 from list of un-threadsafe devices.<br>
-<br>
-gs/base/configure.ac<br>
-gs/base/gdevcp50.c<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-12 16:53:18 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=50ecd470347d33cef82fabb02b555f6854345485">50ecd470347d33cef82fabb02b555f6854345485</a>
-<blockquote>
-<p>
- Fix contrib bjc devices to avoid global use.<br>
-<br>
- Should now be threadsafe, so remove these devices from the list of<br>
- thread unsafe ones.<br>
-<br>
-gs/base/configure.ac<br>
-gs/contrib/gdevbjc_.c<br>
-gs/contrib/gdevbjc_.h<br>
-gs/contrib/gdevbjca.c<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-12 16:01: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=96e2afac86b8241e4e2dd758d2caf0c6434a102a">96e2afac86b8241e4e2dd758d2caf0c6434a102a</a>
-<blockquote>
-<p>
- Fix the check for duplicate entries.......<br>
-<br>
- ....in the list of devices excluded from a threadsafe build.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-12 12:39:53 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=821d4c00e4507c0f68fd1eafb00622cbabcd1343">821d4c00e4507c0f68fd1eafb00622cbabcd1343</a>
-<blockquote>
-<p>
- Remove calls to gs_lib_ctx_get_non_gc_memory_t from contrib devices.<br>
-<br>
- This leaves the only calls to gs_lib_ctx_get_non_gc_memory_t being<br>
- from the lcms v1 wrapper code (expected as lcms v1 is not thread<br>
- safe), and from the gp_check_interrupts implementations (though these<br>
- should no longer be required).<br>
-<br>
- Update the list of &quot;not thread safe&quot; devices in configure.ac; lots<br>
- of devices are now thread safe. The ones that remain 'not thread safe'<br>
- are those that use static variables (see bug 693376).<br>
-<br>
-gs/base/configure.ac<br>
-gs/contrib/gdevcd8.c<br>
-gs/contrib/gdevdj9.c<br>
-gs/contrib/gdevgdi.c<br>
-gs/contrib/gdevln03.c<br>
-gs/contrib/gdevlx32.c<br>
-gs/contrib/gdevlx7.c<br>
-gs/contrib/gdevmd2k.c<br>
-gs/contrib/gdevop4w.c<br>
-gs/contrib/gdevxes.c<br>
-gs/contrib/gomni.c<br>
-gs/contrib/japanese/gdev10v.c<br>
-gs/contrib/japanese/gdevalps.c<br>
-gs/contrib/japanese/gdevdmpr.c<br>
-gs/contrib/japanese/gdevespg.c<br>
-gs/contrib/japanese/gdevfmlbp.c<br>
-gs/contrib/japanese/gdevfmpr.c<br>
-gs/contrib/japanese/gdevj100.c<br>
-gs/contrib/japanese/gdevlbp3.c<br>
-gs/contrib/japanese/gdevmag.c<br>
-gs/contrib/japanese/gdevmjc.c<br>
-gs/contrib/japanese/gdevnpdl.c<br>
-gs/contrib/japanese/gdevp201.c<br>
-gs/contrib/japanese/gdevrpdl.c<br>
-gs/contrib/lips4/gdevl4r.c<br>
-gs/contrib/lips4/gdevlprn.c<br>
-gs/contrib/pcl3/eprn/eprnparm.c<br>
-gs/contrib/pcl3/eprn/gdeveprn.c<br>
-gs/contrib/pcl3/src/gdevpcl3.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-12 10:22: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=10c70931c243f9d53c2df8b5f9e92fc93acfd4c9">10c70931c243f9d53c2df8b5f9e92fc93acfd4c9</a>
-<blockquote>
-<p>
- Add a --enable-threadsafe option to configure<br>
-<br>
- This adds -dGS_THREADSAFE to the CFLAGS, *and* filters the devices to remove<br>
- non-threadsafe ones.<br>
-<br>
- The list of non-threadsafe devices is near the top of configure.ac (search<br>
- for NTS_DEVS).<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-11 19:50:58 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7012db5af074788bf7bf14ef3718fe72eae3e701">7012db5af074788bf7bf14ef3718fe72eae3e701</a>
-<blockquote>
-<p>
- Add Release-contrib and Debug-contrib VS Configuration.<br>
-<br>
- Also make the existing Debug-cups configuration show up in the solution<br>
- properties.<br>
-<br>
- Building for any of these configurations only affects the ghostscript<br>
- builds.<br>
-<br>
-common/msvc_top.mak<br>
-gs/base/winlib.mak<br>
-gs/ghostscript.vcproj<br>
-gs/psi/msvc.mak<br>
-main/pcl6_msvc.mak<br>
-win32/GhostPDL.sln<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-11 18:50: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=415be58773ac3ebedbe92c6cbdaa5cda9efebc9a">415be58773ac3ebedbe92c6cbdaa5cda9efebc9a</a>
-<blockquote>
-<p>
- Fix windows compilation of pcl3 devices.<br>
-<br>
- The pcl3 devices include support for a pagecount module that doesn't<br>
- work under windows. The documentation for these devices suggests that<br>
- they can be made to work by predefining EPRN_NO_PAGECOUNTFILE and<br>
- editing the dependencies in the makefile to remove the need for<br>
- pagefile.c.<br>
-<br>
- This commit simplifies that by making that symbol be defined<br>
- automatically on a windows build, and nobbling pagefile.c with a<br>
-<br>
-gs/contrib/pcl3/eprn/eprnparm.c<br>
-gs/contrib/pcl3/eprn/pagecount.c<br>
-gs/contrib/pcl3/eprn/pagecount.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-11 18:49:02 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d45b315e8f88b2d78eccba1a5943e59b3b6b14e">1d45b315e8f88b2d78eccba1a5943e59b3b6b14e</a>
-<blockquote>
-<p>
- Fix typo in commit/commit.mak<br>
-<br>
- The compile rule for gdevp201.obj was broken in a way that doesn't<br>
- matter on unix, but upsets nmake.<br>
-<br>
-gs/contrib/contrib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-11 08:54:32 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=70e02af6a3a80586a506c18343aca7c297cbaae6">70e02af6a3a80586a506c18343aca7c297cbaae6</a>
-<blockquote>
-<p>
- Fix GS_THREADSAFE builds.<br>
-<br>
- mkromfs.c needed to not define some functions in GS_THREADSAFE cases.<br>
-<br>
- gxclutil.c had a mismatch between code to collect stats and code to<br>
- print it.<br>
-<br>
-gs/base/gxclutil.c<br>
-gs/base/mkromfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-11 15:25: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=70488a2214a0ae36ad8ec0ca8b4ae0dff9745eb3">70488a2214a0ae36ad8ec0ca8b4ae0dff9745eb3</a>
-<blockquote>
-<p>
- Tweak gscms interface to avoid use of globals.<br>
-<br>
- Previously the only way to implement gscms_get_clrtname was to use a<br>
- static buffer and to return a pointer to it. We change the interface<br>
- so that gscms_get_clrtname takes a memory pointer, and allocates<br>
- space for the returned thing.<br>
-<br>
- The LCMS2 implementation of this still uses a 256 byte stack based<br>
- buffer as part of it's operation (so could potentially have problems<br>
- with colorants longer than 256 bytes), but there is no way to avoid<br>
- this in the current LCMS interface.<br>
-<br>
-gs/base/gsicc_cms.h<br>
-gs/base/gsicc_lcms.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-10 20:25:02 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e3cac4974512416582461af4776120de5b08c07">8e3cac4974512416582461af4776120de5b08c07</a>
-<blockquote>
-<p>
- Disable stat collection in GS_THREADSAFE builds.<br>
-<br>
- The collection of statistics for debugging is implemented in a<br>
- non-threadsafe way. Disable it in GS_THREADSAFE builds.<br>
-<br>
-gs/base/gxcldev.h<br>
-gs/base/gxclpath.c<br>
-gs/base/gxclutil.c<br>
-gs/base/gxfill.c<br>
-gs/base/gxfill.h<br>
-gs/base/gxifast.c<br>
-gs/base/gxshade6.c<br>
-gs/base/scfe.c<br>
-gs/base/ttinterp.c<br>
-gs/contrib/pcl3/eprn/mediasize.c<br>
-gs/contrib/pcl3/src/pclcap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-10 16:25:10 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dcd936432eb37fc5e3590a9377b1e3521ce70042">dcd936432eb37fc5e3590a9377b1e3521ce70042</a>
-<blockquote>
-<p>
- Fix typo that was setting pattern clist BandHeight using size.x instead of .y<br>
-<br>
- This (AFAICT) didn't hurt because the clist_init_bands forced patterns to be<br>
- nbands == 1, but was wrong and may confuse code that relies on BandHeight.<br>
-<br>
-gs/base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-10 15:25:08 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20693cec8d771eb16412a3296c0a16bbbf2ec852">20693cec8d771eb16412a3296c0a16bbbf2ec852</a>
-<blockquote>
-<p>
- Ensure that all devices have non-NULL memory pointers.<br>
-<br>
- We use the memory pointers to get to the lib_ctx, hence having NULL<br>
- memory pointers in device structures causes headaches.<br>
-<br>
- Checking the comments in gxdevcli.h it seems that memory should<br>
- be NULL iff it's in a static prototype. Therefore anywhere that uses<br>
- gx_device_init and passes a NULL pointer is suspect.<br>
-<br>
- Some places call gx_device_init and then set the memory pointer<br>
- manually afterwards, to ensure that the reference counting is setup<br>
- so that it does not attempt to free the device structure when all<br>
- instances are gone. This is to indicate that the device structure<br>
- is on the stack.<br>
-<br>
- As a neater alternative to this, we offer a gx_device_init_on_stack<br>
- function that does the same thing, but makes this explicit.<br>
-<br>
-gs/base/gsdevice.c<br>
-gs/base/gxacpath.c<br>
-gs/base/gxclip.c<br>
-gs/base/gxclip2.c<br>
-gs/base/gxclip2.h<br>
-gs/base/gxdevcli.h<br>
-gs/base/gxmclip.c<br>
-gs/base/gxmclip.h<br>
-gs/base/gxp1fill.c<br>
-gs/psi/zupath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-09 16:17:53 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3231e8923e2bf4d535340a4d4a4335457c8ad1cf">3231e8923e2bf4d535340a4d4a4335457c8ad1cf</a>
-<blockquote>
-<p>
- gp_check_interrupts GP_THREADSAFE fixes.<br>
-<br>
- When building with GP_THREADSAFE, gs_lib_ctx_get_non_gc_memory_t is<br>
- not defined. This will cause at least 2 versions of gp_check_interrupts<br>
- to fail. We patch them here to at least compile correctly.<br>
-<br>
- Also fix some places where the memory pointers used were invalid.<br>
-<br>
- Also fix a couple of calls to process_interrupts with explicitly NULL<br>
- memory pointers.<br>
-<br>
-gs/base/gp_macpoll.c<br>
-gs/base/gp_mspol.c<br>
-gs/base/sfxstdio.c<br>
-gs/base/stream.c<br>
-gs/psi/iscan.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-09 16:15:37 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1793f3733ddb587a92efae41e188b7131eb2aa57">1793f3733ddb587a92efae41e188b7131eb2aa57</a>
-<blockquote>
-<p>
- Second attempt at fixing debugging printing with clists.<br>
-<br>
- The band file reading stream does not have a valid memory pointer<br>
- as the structure is allocated on the stack, and to have a valid<br>
- memory pointer would make the stream attempt to free the structure<br>
- on a close.<br>
-<br>
- Here we add a 'local_memory' pointer that we use both for debugging<br>
- printing, and for calls to process_interrupts.<br>
-<br>
-gs/base/gxclread.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-10 16:18: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=586f1f5e9a29e1826b70cdd5aa1a77aa6b835f33">586f1f5e9a29e1826b70cdd5aa1a77aa6b835f33</a>
-<blockquote>
-<p>
- Provide way for output pagesize to image size in view___.ps tools.<br>
-<br>
- For viewjpeg.ps and viewgif.ps this adds new procedures &quot;viewJPEGgetsize&quot; and<br>
- &quot;viewGIFgetsize&quot; which return the dimensions of the input impage, thus allowing<br>
- the caller to set the page size.<br>
-<br>
- For viewmiff.ps, viewpbm.ps, viewpcx.ps they take a new parameter &quot;FITPAGE&quot;<br>
- which tell the utilities to fit the page to the image - they still honour the SCALE<br>
- parameter, which is also used when setting the pagesize.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/lib/viewgif.ps<br>
-gs/lib/viewjpeg.ps<br>
-gs/lib/viewmiff.ps<br>
-gs/lib/viewpbm.ps<br>
-gs/lib/viewpcx.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-09 21:17:00 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0dc01b095200fa4e04a9934c58ad97ff50c56916">0dc01b095200fa4e04a9934c58ad97ff50c56916</a>
-<blockquote>
-<p>
- Addition of an internal CMM for direct color replacement of text, graphic and image RGB or CMYK colors<br>
-<br>
- This option is used with the -sSourceObjectICC file. Similar to the option to set None to request that<br>
- no color management be used for a particular object type, here we use the keyword Replace to indicate<br>
- that for that object type the colorants will be replaced by the method set up in gsicc_replacecm.c<br>
- Currently to demonstrate its usage it provides a &quot;negative&quot; color mapping operation.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gscdevn.c<br>
-gs/base/gscms.h<br>
-gs/base/gscsepr.c<br>
-gs/base/gsicc.c<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_cms.h<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_manage.h<br>
-gs/base/gsicc_nocm.c<br>
-gs/base/gsicc_replacecm.c<br>
-gs/base/gxclimag.c<br>
-gs/base/gxcmap.c<br>
-gs/base/gxi12bit.c<br>
-gs/base/gxicolor.c<br>
-gs/base/gximono.c<br>
-gs/base/gxiscale.c<br>
-gs/base/gxshade.c<br>
-gs/base/lib.mak<br>
-gs/ghostscript.vcproj<br>
-xps/xpsgradient.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-09 13:17:25 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a650680c5be1e034b8d4a5f6cd2704ae65182e43">a650680c5be1e034b8d4a5f6cd2704ae65182e43</a>
-<blockquote>
-<p>
- Fixes 693370 - the default join should be none not mitered.<br>
-<br>
-pcl/pgdraw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-08 17:24:48 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6f7a425bbc0b560a776a76293b4a1fdaffc76248">6f7a425bbc0b560a776a76293b4a1fdaffc76248</a>
-<blockquote>
-<p>
- Bug 693328: Ensure that clist reader/writer devices stay in sync.<br>
-<br>
- The number of components records in reader/writers can get out of<br>
- sync due to some 'limiting' code in the writer not being present in<br>
- the reader.<br>
-<br>
- My first attempt at fixing this was to copy those few lines from<br>
- pdf14_create_clist_device into gs_pdf14_device_push, but this caused<br>
- SEGVs in some non-clist cases (72dpi CATX9004.pdf unbanded for example).<br>
-<br>
- Staring at the code a bit it seems odd to open a device and then change<br>
- the number of colors in it; changing the number of colors *then* opening<br>
- it makes much more sense. I have therefore moved the limiting code up<br>
- a few lines in both pdf14_create_clist_device and gs_pdf14_device_push<br>
- and everything seems much happier.<br>
-<br>
- 2 diffs shown in the cluster, 1 clearly a progression, 1 neutral.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-08 19:35: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=92f024cba125df4729f6a51fdf7b59e46fc71457">92f024cba125df4729f6a51fdf7b59e46fc71457</a>
-<blockquote>
-<p>
- Revert commit dcdc149 which broke various cluster tests.<br>
-<br>
- It seems that we can't put a valid mem pointer into the clist<br>
- stream reading code, as the stream code takes this as an indication<br>
- that the stream state should be freed on closedown.<br>
-<br>
-gs/base/gxclread.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-08 17:31: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=b07dca2069a45793b70cb7faf51f53d932144a28">b07dca2069a45793b70cb7faf51f53d932144a28</a>
-<blockquote>
-<p>
- Fix multi-threaded rendering use of wrong gs_memory_t.<br>
-<br>
- When we create rendering threads, we create a gs_memory_t * for each.<br>
- The idea is that every thread should exclusively use its own gs_memory_t<br>
- to avoid conflicts. The gsicc_cache was being setup to use the incorrect<br>
- one.<br>
-<br>
- This was found (by Ray) when investigating bug 693361. This solves<br>
- this particular error, but does not completely solve the bug.<br>
-<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-08 17:28: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=dcdc149c49b2556e2038df4eab0da7f49de46100">dcdc149c49b2556e2038df4eab0da7f49de46100</a>
-<blockquote>
-<p>
- Fix clist stream memory initialisation.<br>
-<br>
- The clist file playback stream has never had it's memory pointer setup<br>
- correctly - probably because it has never needed it. Now it does need it<br>
- due to to the debugging print functions.<br>
-<br>
-gs/base/gxclread.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-08 17:28:32 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=98946c1f9c015a6bbbb55a9401e4eeca47ce7147">98946c1f9c015a6bbbb55a9401e4eeca47ce7147</a>
-<blockquote>
-<p>
- Whitespace tweak.<br>
-<br>
-gs/base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-08 10:30:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f9c849768bdb3553ffeac74b74b04749e91bf4d5">f9c849768bdb3553ffeac74b74b04749e91bf4d5</a>
-<blockquote>
-<p>
- pdfwrite - when resizing arrays due to incrementally downloaded fonts, increase CIDToGODMapLength<br>
-<br>
- When TrueType fonts are incrementally downloaded, its possible for new character<br>
- codes to exceed the number of glyphs originally defined in the TrueType tables.<br>
-<br>
- When this happens we resize various entries in our copy of the font. However<br>
- the change to dynamically storing CIDToGIDMap and CIDSet (for PDF/A) omitted<br>
- to increase the variable recording the array size (although the array was correctly<br>
- resized).<br>
-<br>
- This led to glyphs with CIDs higher than the initial number of glyphs not having<br>
- an entry in CIDToGIDMap, and tehrefore being treated as /.notdef<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gdevpdtf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-07 19:30:21 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6cbb5969cc2edab6417c673194f1c1d019d275ef">6cbb5969cc2edab6417c673194f1c1d019d275ef</a>
-<blockquote>
-<p>
- Bug 693339: Replace malloc() with GS memory allocators in JPX code.<br>
-<br>
- We have 2 implementations of JPX decoding filters based on Luratech<br>
- and OpenJpeg libraries. The Luratech one is now clean. The API to<br>
- the library supports custom memory allocators.<br>
-<br>
- The OpenJpeg case is more difficult. The calls to malloc() in the<br>
- wrapper code has been eliminated, but the library calls malloc()<br>
- directly. To use a custom allcator one has to extend the API and<br>
- change the signatures of all functions that allocate memory.<br>
-<br>
-gs/base/lib.mak<br>
-gs/base/sjpx_luratech.c<br>
-gs/base/sjpx_luratech.h<br>
-gs/base/sjpx_openjpeg.c<br>
-gs/base/sjpx_openjpeg.h<br>
-gs/psi/zfjpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-07 11:26:17 +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=7f4726e7764a09b8d68927924e54d1ad23e284d1">7f4726e7764a09b8d68927924e54d1ad23e284d1</a>
-<blockquote>
-<p>
- Bug 691931: Patch to resolve error in the number parser, the file now renders paths correctly<br>
- but not the text which is not currently supported.<br>
-<br>
-svg/ghostsvg.h<br>
-svg/svgshapes.c<br>
-svg/svgtypes.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-07 11:19:00 +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=8785fa4c81b377abc633cd0baeffb7abd85b45d7">8785fa4c81b377abc633cd0baeffb7abd85b45d7</a>
-<blockquote>
-<p>
- Bug 693239: Prevent segfault due to optional width/height attributes.<br>
-<br>
-svg/svgdoc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-05 22:48:58 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=119de6b66bf1874c545b221a974ce88c78e462e8">119de6b66bf1874c545b221a974ce88c78e462e8</a>
-<blockquote>
-<p>
- more warning fixes<br>
-<br>
-pl/plufont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-05 22:48:11 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=341865d2554ef04c0f873344f2a2d582a8353944">341865d2554ef04c0f873344f2a2d582a8353944</a>
-<blockquote>
-<p>
- more warning fixes<br>
-<br>
-pl/plulfont.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-05 22:39:06 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22ab5ef64b6364534012abecdf29b76402e7a08f">22ab5ef64b6364534012abecdf29b76402e7a08f</a>
-<blockquote>
-<p>
- warning cleanup<br>
-<br>
-pl/pluchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-05 13:11:16 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f5513b716ce5ce510120e2a08a766281d2b00c28">f5513b716ce5ce510120e2a08a766281d2b00c28</a>
-<blockquote>
-<p>
- Allow use of Device Link ICC Profile for source objects<br>
-<br>
- With the -sSourceObjectICC=filename option, it is now possible to specify a device link source<br>
- profile for CMYK/RGB graphic, image and text objects. When such a profile is specified, the mapping<br>
- will go from source directly to device values. Note that the use of a proofing profile is not<br>
- possible and the device profile itself is not used in this transformation. However the device link<br>
- profile that is associated with the device and specified with -sDeviceLinkProfile is included<br>
- in the transform.<br>
-<br>
-gs/base/gscms.h<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_cms.h<br>
-gs/base/gsicc_lcms.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-05 06:40: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=44687f1488b97bc007c6cfb02d4a25bcb3fd94e0">44687f1488b97bc007c6cfb02d4a25bcb3fd94e0</a>
-<blockquote>
-<p>
- pdfwrite - linearisation, correctly prevent buffer overrun<br>
-<br>
- Picked up by the compiler on the Mac.the test was impossible, because a byte<br>
- cannot exceed a value of 255. The value (whcih triggers a buffer flush and reset)<br>
- shuold of course have been 254, as it now is.<br>
-<br>
- No differences ewxpected<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-04 10:43:51 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fc7c0751108e823d311418bfed920a5a4b3ed37b">fc7c0751108e823d311418bfed920a5a4b3ed37b</a>
-<blockquote>
-<p>
- Expansion of spot color replacement to handle the mixing of DeviceN Colors<br>
-<br>
- The named color profile structure will now also be used for mixing of DeviceN colorants.<br>
- This includes an update of the example to show the results.<br>
-<br>
-gs/base/gscdevn.c<br>
-gs/base/gscsepr.c<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_cache.h<br>
-gs/base/lib.mak<br>
-gs/toolbin/color/named_color/named_color_table.txt<br>
-gs/toolbin/color/named_color/named_colors.pdf<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-04 19:19:58 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c0b2a6eb8b26af6f1cea99efd97354ee3c22f28a">c0b2a6eb8b26af6f1cea99efd97354ee3c22f28a</a>
-<blockquote>
-<p>
- These header files should have been added with the warning message<br>
- cleanup commit (deeef25).<br>
-<br>
-pcl/rtmisc.h<br>
-pl/plchar.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-04 13:32:47 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=deeef25f35ff78e75a5ad6d056c481f1b1013c66">deeef25f35ff78e75a5ad6d056c481f1b1013c66</a>
-<blockquote>
-<p>
- Warning cleanup.<br>
-<br>
-pcl/pcdraw.c<br>
-pcl/pcfsel.c<br>
-pcl/pcindxed.c<br>
-pcl/pcl.mak<br>
-pcl/pcpatrn.c<br>
-pcl/pcstatus.c<br>
-pcl/pcuptrn.c<br>
-pcl/pgfdata.c<br>
-pcl/pgfdata.h<br>
-pcl/pgfont.c<br>
-pcl/pgmand.h<br>
-pcl/rtmisc.c<br>
-pl/pl.mak<br>
-pl/plchar.c<br>
-pl/plfont.c<br>
-pl/plfont.h<br>
-pl/plplatf.c<br>
-pl/plsrgb.c<br>
-pl/pluchar.c<br>
-pxl/pxffont.c<br>
-pxl/pxfont.c<br>
-pxl/pxfont.h<br>
-pxl/pxgstate.h<br>
-pxl/pxl.mak<br>
-pxl/pxpthr.c<br>
-pxl/pxpthr.h<br>
-pxl/pxstate.c<br>
-pxl/pxstate.h<br>
-pxl/pxtop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-02 21:51:18 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=18f1da650322713395aceafb25f495149c8f0cda">18f1da650322713395aceafb25f495149c8f0cda</a>
-<blockquote>
-<p>
- Turn on ability to specify no color management from the srcgtag structure for different objects<br>
-<br>
- With this, it is possible in the srcgtag structure to specify that we will not do color management<br>
- for RGB or CMYK graphic, image and text objects. This is done by specifying the keyword None after<br>
- the particular tag. For example &quot;Graphic_CMYK None&quot; in the file that is used with the -sSourceObjectICC<br>
- command option. In the above case, all CMYK source graphics would be mapped using the unmanaged color<br>
- methods (e.g. 255-X) Also we added in support for preserveK, override source ICC and black point<br>
- compensation on an object based case. Had to worry about the case where the profile passes through<br>
- the clist in the commit and had to add in a new parameter to the profile to ensure that the rendering<br>
- conditions are associated with the source profile. Also fixed a bug to keep from changing the number of<br>
- channels in the link format.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gscms.h<br>
-gs/base/gscsepr.c<br>
-gs/base/gsicc.c<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_nocm.c<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclist.h<br>
-gs/base/gxcmap.c<br>
-gs/base/gxi12bit.c<br>
-gs/base/gxicolor.c<br>
-gs/base/gximono.c<br>
-gs/base/gxiscale.c<br>
-gs/base/gxshade.c<br>
-xps/xpsgradient.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-04 10:02: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=44616dd78f9af00a47a4c27e5491537df28cd964">44616dd78f9af00a47a4c27e5491537df28cd964</a>
-<blockquote>
-<p>
- Eliminate last_char global variable.<br>
-<br>
- last_char value is now stored in the pl_font_s structure.<br>
-<br>
-pl/plchar.c<br>
-pl/plfont.c<br>
-pl/plfont.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-03 09:29:47 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=37e1da602cff3378b3d985637dc582f206aa5cd8">37e1da602cff3378b3d985637dc582f206aa5cd8</a>
-<blockquote>
-<p>
- txtwrite - fix a typo causing text to be incorrect<br>
-<br>
- When the text operation was TEXT_FROM_CHARS or TEXT_FROM_SINGLE_CHAR the code<br>
- was referencing the 'bytes' structure member, not the 'chars' structure member.<br>
-<br>
- Also fixed a potential signed/unsigned mismatch in pdfwrite and a 32/64 bit<br>
- mismatch in txtwrite, both picked up by Henry. It would be nice to know why<br>
- the 'new compiler warnings' check didn't flag these, possibly they predate<br>
- that check.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gdevpdf.c<br>
-gs/base/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-01 10:48:01 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ae25729f69a9ece10d6fdbb0c0c213c4e27aea7c">ae25729f69a9ece10d6fdbb0c0c213c4e27aea7c</a>
-<blockquote>
-<p>
- Change to a more sane storage of the color rendering conditions to s common structure type<br>
-<br>
- As more conditions variables are introduced, e.g. rendering intent, black point compensation, preserve black<br>
- etc. it has become clear that we need a structure for these variables making it easy to introduce new ones.<br>
- Also clean up a lot of the usage methods to ensure that proper override occurs without having to set a<br>
- pile of command line options.<br>
-<br>
-gs/Resource/Init/gs_lev2.ps<br>
-gs/base/gdevp14.c<br>
-gs/base/gscms.h<br>
-gs/base/gscspace.c<br>
-gs/base/gsdevice.c<br>
-gs/base/gsdparam.c<br>
-gs/base/gsequivc.c<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_manage.h<br>
-gs/base/gstrans.c<br>
-gs/base/gxclimag.c<br>
-gs/base/gxcmap.c<br>
-gs/psi/zusparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-02 20:37:15 +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=f1a459c6e695f065f036db4a8946ae726ee69eac">f1a459c6e695f065f036db4a8946ae726ee69eac</a>
-<blockquote>
-<p>
- Bug 693285: Apply update of original patch from zeniko. We now check that the symbol dictionary<br>
- being imported is not empty. Also prevent seg faults resulting from the threadsafe update.<br>
-<br>
-gs/base/sjbig2.c<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-02 13:18:25 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=80dc061ed4717eef205be05e764ac4f1b8c67632">80dc061ed4717eef205be05e764ac4f1b8c67632</a>
-<blockquote>
-<p>
- fix mismatched parameter type, possibly associated with bug #693362<br>
-<br>
-pcl/pgfont.c<br>
-pl/plchar.c<br>
-pl/plfont.c<br>
-pl/plfont.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-02 12:48:13 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=281b221f4632ba243efa325663dfb223d42028ff">281b221f4632ba243efa325663dfb223d42028ff</a>
-<blockquote>
-<p>
- Add missing initialisation of override_bp<br>
-<br>
- Fix a Valgrind warning and a possible cause of indeterminism.<br>
-<br>
-gs/base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-02 13:26: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=7c47cd47fc96a2f8af5723dbe777526a7fc64c9a">7c47cd47fc96a2f8af5723dbe777526a7fc64c9a</a>
-<blockquote>
-<p>
- White space and warning fixes for bigtiff commit.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevtfax.c<br>
-gs/base/gdevtifs.c<br>
-gs/base/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-02 11:07: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=5784bfbfba7191cacce5309e88afac0851287460">5784bfbfba7191cacce5309e88afac0851287460</a>
-<blockquote>
-<p>
- Add preservation of PageLabels from input PDF files when using pdfwrite<br>
-<br>
- Bug #692901 &quot;Preserve Page labels from input PDF when the output is PDF&quot;<br>
-<br>
- Because hte defined pdfmark /PAGELABEL is not flexible enough to handle all<br>
- the possible kinds of page labels in PDF, and because it transpires we don't<br>
- emit pdfmarks when producing PostScript with ps2write, this feature does<br>
- not use teh pdfmark syntax.<br>
-<br>
- It does work in a broadly similar way, we create a string from the PageLabels<br>
- entry in the Catalog dictionary (if present) and then pass that via put_params<br>
- with a parameter naem of pdfpagelabels (pdfmark uses a name of pdfmark).<br>
-<br>
- This string is then stored in the Catalog dictionary, and emitted when the<br>
- output PDF is created.<br>
-<br>
- I'm unable to test this against the original report, as no specimen PDF file<br>
- was provided.<br>
-<br>
- No differences expected, this makes no changes in rendering.<br>
-<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/base/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-28 09:23:36 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79af8e5bff7321b6985ea0bd5dd5b4a5a4c2590a">79af8e5bff7321b6985ea0bd5dd5b4a5a4c2590a</a>
-<blockquote>
-<p>
- Provide bigtiff output option.<br>
-<br>
- All the tiff devices now support the device parameter &quot;-dUseBigTIFF&quot; which<br>
- tells them to write their output in &quot;bigtiff&quot; format, rather than &quot;normal&quot;<br>
- tiff.<br>
-<br>
- In the event that we overflow the allowed file size in normal tiff, the existing<br>
- error message is augmented with a hint to try bigtiff output.<br>
-<br>
- To implement the above warning has meant adding warning and error handling hooks<br>
- for libtiff, and also adding file I/O hooks for libtiff.<br>
-<br>
- This requires libtiff version &gt;=4.0.0, so linking with older libtiff versions<br>
- will cause us to ignore the UseBigTIFF setting.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevtfax.c<br>
-gs/base/gdevtfnx.c<br>
-gs/base/gdevtifs.c<br>
-gs/base/gdevtifs.h<br>
-gs/base/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-10-01 08:41: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=b81847783db2c17e11d40feeb0812ff7d129aca9">b81847783db2c17e11d40feeb0812ff7d129aca9</a>
-<blockquote>
-<p>
- Bug #691319 - Preserve Flags (/F) from Text annotations<br>
-<br>
- When creating pdfmarks for the benefit of pdfwrite, the PDF interpreter<br>
- only handles two types of annotation, Text and Link. We were handling the<br>
- Flags entry for Link annotations, but not for Text annotations.<br>
-<br>
- Here we preserve the Flags for text annotations too.<br>
-<br>
- No differences expected, not tested by cluster.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-28 14:40: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=4b9424c7bf7c74613cd004195592d41893dd3bd5">4b9424c7bf7c74613cd004195592d41893dd3bd5</a>
-<blockquote>
-<p>
- Remove more traces of pdfopt from the repository and documentation<br>
-<br>
-gs/doc/Develop.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/lib/pdfopt<br>
-gs/lib/pdfopt.bat<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-28 14:34: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=260ddb3e53ffe852a8994dd00719931ca3f2beec">260ddb3e53ffe852a8994dd00719931ca3f2beec</a>
-<blockquote>
-<p>
- With the addition of linearisation to pdfwrite, pdfopt.ps has become<br>
- redundant. Since it is difficult to maintain, has a number of bugs, and is<br>
- believed not to work properly anyway, it is now deprecagted and hence<br>
- removed from the repository.<br>
-<br>
-gs/lib/pdfopt.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-28 13:08: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=f2a40a3a7edd6d27caeaa19f7f644adf31ee972c">f2a40a3a7edd6d27caeaa19f7f644adf31ee972c</a>
-<blockquote>
-<p>
- pdfwrite - linearisation completion<br>
-<br>
- Update ps2pdf.htm documentation<br>
-<br>
- CHange parameter name to 'FastWebView'<br>
-<br>
- Don't writ the xref on the initial file, as we don't need it and it makes<br>
- the original file slightly smaller, which reduces the chances that we will<br>
- have to pad the linearised file. (The linearised file must be no smaller<br>
- than the original, because we do not close the file, we just seek around and<br>
- rewrite it). Same with the trailer dictionary.<br>
-<br>
- Fix 'rewrite object' so that dictioanry and array objects can be of any size<br>
- previously we had assunmed they would be less than 64k, but some complex<br>
- files broke that.<br>
-<br>
- If the linearised file is smaller than the original, we need to add white<br>
- space to bring it up to the same size, or we will be left with garbage at<br>
- the end. Worse, the garbage may well contain a partial invalid xref.<br>
-<br>
- Remove the check for one page files as Adobe specifically allows linearising<br>
- single page documents....<br>
-<br>
-gs/base/gdevpdf.c<br>
-gs/base/gdevpdfp.c<br>
-gs/doc/Ps2pdf.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-28 07:54: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=3c23fe12abb6a158abf1c515601db7b2f94c5463">3c23fe12abb6a158abf1c515601db7b2f94c5463</a>
-<blockquote>
-<p>
- Reinstate tiffsep1 and svgwrite in the device lists<br>
-<br>
- I accidentally left out tiffsep1 when I consolidated the two lists of TIFF<br>
- devices, so putting it back now.<br>
-<br>
- svgwrite was removed a while ago due to being incomplete and flaky, but there<br>
- has been ongoing interest in the device, some patches posted, so reinstate it<br>
- to make it easier for people to test/debug/develop.<br>
-<br>
- It's included in the &quot;FILES&quot; class of devices.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-27 10:18:27 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3a0483fddf55e091aafa1bd4822bd77b19b481b3">3a0483fddf55e091aafa1bd4822bd77b19b481b3</a>
-<blockquote>
-<p>
- Update Use.htm with ICC command updates.<br>
-<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-27 10:06:51 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=666890f41d3ca928498a8652fa7d102cd9f22191">666890f41d3ca928498a8652fa7d102cd9f22191</a>
-<blockquote>
-<p>
- Update color document with recent changes.<br>
-<br>
-gs/doc/GS9_Color_Management.pdf<br>
-gs/doc/GS9_Color_Management.tex<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-27 17:21: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=53547c0892c48e248a146667f280886b362befc1">53547c0892c48e248a146667f280886b362befc1</a>
-<blockquote>
-<p>
- pdfwrite - linearisation, fix some seg faults<br>
-<br>
- The code was inadvertently incrementing an array index twice, leading to<br>
- out of bounds memory access, and consequent memory corruption.<br>
-<br>
- No differences expected, this is not cluster tested.<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-24 23:15:43 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=408cbb83103ba9cf6996eeebaa02995cd9f535ad">408cbb83103ba9cf6996eeebaa02995cd9f535ad</a>
-<blockquote>
-<p>
- Addition of support for allowing control over the use of black point compensation in color management<br>
-<br>
- Black point compensation is a new extended graphic state entry in the extended graphic<br>
- state with PDF 2.0 . This change adds it to the graphic state. This update also allows<br>
- the same type of override control for black point that we currently have for the<br>
- rendering intent. This includes specification of its use by source object type with<br>
- the use of -sSourceObjectICC for source RGB and CMYK graphic, images and text objects.<br>
- Alternatively, control can be achieved for the whole document via object type<br>
- by specification -dBlackPtComp=0/1. Alternatively, you can specify control<br>
- on an object based method using -dGraphBlackPt=0/1<br>
- -dImageBlackPtComp=0/1 -dTextBlackPtComp=0/1. All of these<br>
- will require the setting of -dOverrideBP to ensure that the document content does not<br>
- interfere with the command line setting. Note that these are not true/false settings<br>
- but integer values like the rendering intent. This is to allow the easy expansion<br>
- to other black point compensation options as described by Bug 692223.<br>
-<br>
-gs/Resource/Init/gs_lev2.ps<br>
-gs/base/gdevp14.c<br>
-gs/base/gscms.h<br>
-gs/base/gscsepr.c<br>
-gs/base/gscspace.c<br>
-gs/base/gsdparam.c<br>
-gs/base/gsequivc.c<br>
-gs/base/gsicc.c<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_manage.h<br>
-gs/base/gsstate.c<br>
-gs/base/gsstate.h<br>
-gs/base/gstrans.c<br>
-gs/base/gxclimag.c<br>
-gs/base/gxcmap.c<br>
-gs/base/gxi12bit.c<br>
-gs/base/gxicolor.c<br>
-gs/base/gximono.c<br>
-gs/base/gxiscale.c<br>
-gs/base/gxistate.h<br>
-gs/base/gxshade.c<br>
-gs/psi/zcolor3.c<br>
-gs/psi/zusparam.c<br>
-gs/toolbin/color/src_color/objsrc_profiles_example.txt<br>
-xps/xpsgradient.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-26 11:02: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=1770ca69b258c571565d9a6fc7bb9fb0ebd539e4">1770ca69b258c571565d9a6fc7bb9fb0ebd539e4</a>
-<blockquote>
-<p>
- Bug 693357: Fix typo<br>
-<br>
- In the big debugging printf commit of the other day, I introduced a<br>
- typo into the luratech jbig2 code. Fixed here.<br>
-<br>
-gs/base/sjbig2_luratech.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-26 10:52:46 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=45ba06c92cf7cb290b1c76f4380606323579e5b9">45ba06c92cf7cb290b1c76f4380606323579e5b9</a>
-<blockquote>
-<p>
- Fix DEBUG mode SEGVs; bug 693359<br>
-<br>
- In at least a couple of places I was reading a memory pointer from a<br>
- structure that wasn't filled in. Simple fixes here.<br>
-<br>
- This solves the crashing with -ZBb in any file with an image pointed<br>
- out by Henry on irc.<br>
-<br>
- I'm sure there will be more such problems due to the wide ranging<br>
- nature of the commit that changed this; hopefully all will be as<br>
- simple to solve as this.<br>
-<br>
-gs/base/gxipixel.c<br>
-gs/base/gxp1fill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-26 09:06:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3894e9c8a3ab125c82048da3bf81515500bb2da0">3894e9c8a3ab125c82048da3bf81515500bb2da0</a>
-<blockquote>
-<p>
- pdfwrite - emit partial pages<br>
-<br>
- previously, if an input file made marks on the page but did not call<br>
- showpage (or equivalent in other languages), pdfwrite would write all the<br>
- objects to the file, but would not add the final partial page to the Pages<br>
- tree, which meant that the final page didn't appear.<br>
-<br>
- It seems that Adobe Acrobat behaves differently, and produces the final page<br>
- under these conditions. This commit changes our behaviour to match the<br>
- observed Adobe behaviour.<br>
-<br>
- This was noticed when running some Quality Logic test files, it appears that<br>
- the cluster runs in a mode where these partial pages were always emitted<br>
- anyway (because of the CET conformance hacks) so there are only a few files<br>
- which display any differences.<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-25 19: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=1deb66b8f5e53f8a560ced10fe777a55e42fc6f2">1deb66b8f5e53f8a560ced10fe777a55e42fc6f2</a>
-<blockquote>
-<p>
- Fix garbage collection troubles with icc code.<br>
-<br>
- Historically, due to lcms/lcms2 allocating stuff using malloc/free<br>
- the profiles haven't been subject to garbage collection. When I<br>
- fixed gscms_create/destroy not being called properly, this caused<br>
- lcms2 to start allocating blocks properly with the gs allocators.<br>
-<br>
- To ensure that these blocks weren't unexpectedly garbage collected<br>
- away, I modified one of the calls from gsicc_cache.c to the gscms<br>
- layer to pass in a non_gc memory pointer. This worked well, but I<br>
- missed a second call in which I should have done the same.<br>
-<br>
- Fixed here. This cures bug 693349.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-21 12:34:16 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=873455f29e399fc5f7b489c50cfb869fdc26cb0d">873455f29e399fc5f7b489c50cfb869fdc26cb0d</a>
-<blockquote>
-<p>
- Simplify mkromfs build dependencies, add needed debug and error printing.<br>
-<br>
- Since mkromfs minimal memory implementation left the gs_lib_ctx set to NULL,<br>
- the errwrite and outwrite functions would de-reference a NULL causing a<br>
- Segmentation violation if gp_unix ever printed anything. This removes the<br>
- need for the gsmisc.o altogether and removes the need for gslibctx.o and<br>
- the dummy gscms functions.<br>
-<br>
-gs/base/mkromfs.c<br>
-gs/base/unix-aux.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-24 09:25:35 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb0ef5ed637757290a88709fa1543585b29ccc54">bb0ef5ed637757290a88709fa1543585b29ccc54</a>
-<blockquote>
-<p>
- Update color management documentation with information about NCLR ICC profile usage.<br>
-<br>
-gs/doc/GS9_Color_Management.pdf<br>
-gs/doc/GS9_Color_Management.tex<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-24 09:22:41 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5176cb8c3882de51e413880ec2818a45a9d7c139">5176cb8c3882de51e413880ec2818a45a9d7c139</a>
-<blockquote>
-<p>
- Fix a few typos.<br>
-<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-21 22:48:37 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8227d2d46b516b75a4383466eb243b725f3124b0">8227d2d46b516b75a4383466eb243b725f3124b0</a>
-<blockquote>
-<p>
- Support for the use of N-CLR ICC output profiles extended to the tiffsep device.<br>
-<br>
- The documentation on the use of this option was also updated.<br>
-<br>
-gs/base/gdevdevn.h<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevtsep.c<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-20 22:55:45 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8a1ca14aab8f3ef6a7ffaa554d4e1d348b7561a7">8a1ca14aab8f3ef6a7ffaa554d4e1d348b7561a7</a>
-<blockquote>
-<p>
- Bulk of work to demonstrate the use of DeviceN ICC output profile.<br>
-<br>
- This adds support to the psdcmyk device as well as the required changes in<br>
- the graphics library. Through the use of the LIMIT_TO_ICC define in gdevpsd, it is<br>
- possible to limit the colorants to those defined by the ICC output profile.<br>
- Setting to 1 will limit it setting to 0 will allow all spots (up to the maximum)<br>
- to be created. If spot names in the document match those in the command line<br>
- with -sICCOutputColors, then those colorants and hence separation will be treated<br>
- the same.<br>
-<br>
-gs/base/gdevpsd.c<br>
-gs/base/gscdevn.c<br>
-gs/base/gscms.h<br>
-gs/base/gscsepr.c<br>
-gs/base/gsequivc.c<br>
-gs/base/gsicc.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_manage.h<br>
-gs/base/gxcmap.c<br>
-gs/base/gxistate.h<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-21 18:49: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=51bc075100060ca1f90dd5d3d6c467597202d27d">51bc075100060ca1f90dd5d3d6c467597202d27d</a>
-<blockquote>
-<p>
- Import LCMS 2.4 (patched)<br>
-<br>
- Here we import LCMS 2.4 with our existing patches into gs.<br>
-<br>
- Cluster testing this shows various changes; most of these are just<br>
- small rounding issues. It is possible that some of this is due to<br>
- Marti adopting our revised 16 -&gt; 8 code and having pushed it further<br>
- through the code than we had.<br>
-<br>
- Also there are changes to the black point compensation code designed<br>
- to more accurately match Adobe. For some test files that have<br>
- deliberately extreme profiles we get noticably different results.<br>
- Supposedly this is because those profiles do not round trip nicely,<br>
- but after discussing it with Michael he says it's nothing to worry<br>
- about.<br>
-<br>
-gs/base/lcms2.mak<br>
-gs/ghostscript.vcproj<br>
-gs/lcms2/AUTHORS<br>
-gs/lcms2/ChangeLog<br>
-gs/lcms2/Makefile.in<br>
-gs/lcms2/Projects/.gitignore<br>
-gs/lcms2/Projects/BorlandC_5.5/lcms2.rc<br>
-gs/lcms2/Projects/BorlandC_5.5/lcmsdll.lk<br>
-gs/lcms2/Projects/BorlandC_5.5/lcmsdll.lst<br>
-gs/lcms2/Projects/VC2008/lcms2_DLL/lcms2_DLL.vcproj<br>
-gs/lcms2/Projects/VC2008/lcms2_static/lcms2_static.vcproj<br>
-gs/lcms2/Projects/VC2010/jpegicc/jpegicc.vcxproj<br>
-gs/lcms2/Projects/VC2010/lcms2.sln<br>
-gs/lcms2/Projects/VC2010/lcms2_DLL/lcms2_DLL.vcxproj<br>
-gs/lcms2/Projects/VC2010/lcms2_DLL/lcms2_DLL.vcxproj.filters<br>
-gs/lcms2/Projects/VC2010/lcms2_static/lcms2_static.vcxproj<br>
-gs/lcms2/Projects/VC2010/lcms2_static/lcms2_static.vcxproj.filters<br>
-gs/lcms2/Projects/VC2010/linkicc/linkicc.vcxproj<br>
-gs/lcms2/Projects/VC2010/psicc/psicc.vcxproj<br>
-gs/lcms2/Projects/VC2010/testbed/testbed.vcxproj<br>
-gs/lcms2/Projects/VC2010/tiffdiff/tiffdiff.vcxproj<br>
-gs/lcms2/Projects/VC2010/tifficc/tifficc.vcxproj<br>
-gs/lcms2/Projects/VC2010/transicc/transicc.vcxproj<br>
-gs/lcms2/Projects/mac/._.DS_Store<br>
-gs/lcms2/Projects/mac/LittleCMS/._.DS_Store<br>
-gs/lcms2/Projects/mac/LittleCMS/Info.plist<br>
-gs/lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/mariama.mode1v3<br>
-gs/lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/mariama.pbxuser<br>
-gs/lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.pbxproj<br>
-gs/lcms2/aclocal.m4<br>
-gs/lcms2/configure<br>
-gs/lcms2/configure.ac<br>
-gs/lcms2/doc/LittleCMS2.3 API.pdf<br>
-gs/lcms2/doc/LittleCMS2.3 Plugin API.pdf<br>
-gs/lcms2/doc/LittleCMS2.3 tutorial.pdf<br>
-gs/lcms2/doc/LittleCMS2.4 API.pdf<br>
-gs/lcms2/doc/LittleCMS2.4 Plugin API.pdf<br>
-gs/lcms2/doc/LittleCMS2.4 tutorial.pdf<br>
-gs/lcms2/include/Makefile.in<br>
-gs/lcms2/include/lcms2.h<br>
-gs/lcms2/include/lcms2_extras.h<br>
-gs/lcms2/include/lcms2_plugin.h<br>
-gs/lcms2/src/Makefile.am<br>
-gs/lcms2/src/Makefile.in<br>
-gs/lcms2/src/cmscam02.c<br>
-gs/lcms2/src/cmscgats.c<br>
-gs/lcms2/src/cmscnvrt.c<br>
-gs/lcms2/src/cmserr.c<br>
-gs/lcms2/src/cmsgamma.c<br>
-gs/lcms2/src/cmsgmt.c<br>
-gs/lcms2/src/cmshalf.c<br>
-gs/lcms2/src/cmsintrp.c<br>
-gs/lcms2/src/cmsio0.c<br>
-gs/lcms2/src/cmsio1.c<br>
-gs/lcms2/src/cmslut.c<br>
-gs/lcms2/src/cmsmd5.c<br>
-gs/lcms2/src/cmsmtrx.c<br>
-gs/lcms2/src/cmsnamed.c<br>
-gs/lcms2/src/cmsopt.c<br>
-gs/lcms2/src/cmspack.c<br>
-gs/lcms2/src/cmspcs.c<br>
-gs/lcms2/src/cmsplugin.c<br>
-gs/lcms2/src/cmsps2.c<br>
-gs/lcms2/src/cmssamp.c<br>
-gs/lcms2/src/cmssm.c<br>
-gs/lcms2/src/cmstypes.c<br>
-gs/lcms2/src/cmsvirt.c<br>
-gs/lcms2/src/cmswtpnt.c<br>
-gs/lcms2/src/cmsxform.c<br>
-gs/lcms2/src/cmsxform.h<br>
-gs/lcms2/src/cmsxform_extras.c<br>
-gs/lcms2/src/lcms2.def<br>
-gs/lcms2/src/lcms2_internal.h<br>
-gs/lcms2/testbed/Makefile.am<br>
-gs/lcms2/testbed/Makefile.in<br>
-gs/lcms2/testbed/testcms2.c<br>
-gs/lcms2/utils/common/utils.h<br>
-gs/lcms2/utils/common/vprf.c<br>
-gs/lcms2/utils/common/xgetopt.c<br>
-gs/lcms2/utils/delphi/lcms2dll.pas<br>
-gs/lcms2/utils/jpgicc/Makefile.in<br>
-gs/lcms2/utils/jpgicc/jpgicc.c<br>
-gs/lcms2/utils/linkicc/Makefile.in<br>
-gs/lcms2/utils/psicc/Makefile.in<br>
-gs/lcms2/utils/tificc/Makefile.in<br>
-gs/lcms2/utils/tificc/tificc.c<br>
-gs/lcms2/utils/transicc/Makefile.in<br>
-gs/lcms2/utils/transicc/transicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-21 19:07:48 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2346369bb7536062946d409f940e865791afc34a">2346369bb7536062946d409f940e865791afc34a</a>
-<blockquote>
-<p>
- Fix typo in previous commit; return NULL in void function.<br>
-<br>
- MSVC and gcc both accept it with a warning, hence I didn't spot it.<br>
- Sorry.<br>
-<br>
-gs/base/gslibctx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-25 00:38:56 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0eae840336f244e5b0d195109e1dd9e104396d87">0eae840336f244e5b0d195109e1dd9e104396d87</a>
-<blockquote>
-<p>
- Arrange for gscms_create/destroy to be called correctly.<br>
-<br>
- gscms_create should be called before any other cms call is made,<br>
- but it's not being. It not being called has meant that lcms has<br>
- always been using malloc/free rather than the gs allocation<br>
- functions. Fix some bugs in those allocation functions that show<br>
- up now they are used.<br>
-<br>
- Also ensure that pointers are correctly enumerated.<br>
-<br>
- Ensure that cms set context pointer actually makes it into links.<br>
-<br>
- Update gscms interface to ensure that errors on gscms_create can<br>
- be responded to.<br>
-<br>
- This work has exposed a problem wrt the context pointer in the<br>
- gscms interface, so we fix that here too.<br>
-<br>
- The theory has always been that we can drop new and different<br>
- CMS engines into ghostscript, by wrapping each one with some code<br>
- that implements the gscms_ functions from gsicc_cms.h.<br>
-<br>
- While this interface was developing, I started to add support for<br>
- a context pointer, but looking back at it, it seems I never<br>
- completed the work and it was left in a state where it was useless.<br>
-<br>
- After much discussion with Michael, we've decided that the best way<br>
- to proceed is to arrange for gscms_create to be called when gs<br>
- starts up (just after the base level allocator is created), and for<br>
- gscms_destroy to be called as gs exits (just before the base level<br>
- allocator is destroyed).<br>
-<br>
- This base level allocator is passed into gscms_create/gscms_destroy<br>
- so it can safely allocate memory. Furthermore, we have done away<br>
- with explicitly passing the cms_context pointer around, as it was<br>
- not really any use in its current form. Instead, we have added<br>
- functions to get/set the context pointer in the gs_lib_ctx.<br>
-<br>
- void *gs_lib_ctx_get_cms_context( const gs_memory_t *mem );<br>
- void gs_lib_ctx_set_cms_context( const gs_memory_t *mem, void *cms_context );<br>
-<br>
- As the gscms functions take mem pointers in all the interesting<br>
- places, this should be sufficient.<br>
-<br>
- As mkromfs calls the gs lib ctx init stuff, we have had to add stubs<br>
- for gscms_create/destroy to mkromfs.c.<br>
-<br>
-gs/base/gscms.h<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_cache.h<br>
-gs/base/gsicc_cms.h<br>
-gs/base/gsicc_lcms.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_nocm.c<br>
-gs/base/gslibctx.c<br>
-gs/base/gslibctx.h<br>
-gs/base/gsmalloc.c<br>
-gs/base/mkromfs.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-21 13:52:25 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8ef93d4d8f33149cb7d244da52d47e82a11f9019">8ef93d4d8f33149cb7d244da52d47e82a11f9019</a>
-<blockquote>
-<p>
- Fix LCMS threading issue with plugin registration.<br>
-<br>
- When registering a plugin, allocations can be done. This can result<br>
- in calls back to the user supplied malloc functions, which assume<br>
- that a cmsContext will be supplied. In the current code there is<br>
- no way to pass a cmsContext into the plugin registration.<br>
-<br>
- We therefore add a new function cmsPluginTHR that does take such a<br>
- context.<br>
-<br>
- Currently this isn't called yet, as gscms_create/destroy aren't correctly<br>
- called.<br>
-<br>
-gs/lcms2/include/lcms2.h<br>
-gs/lcms2/src/cmscnvrt.c<br>
-gs/lcms2/src/cmsgamma.c<br>
-gs/lcms2/src/cmsopt.c<br>
-gs/lcms2/src/cmspack.c<br>
-gs/lcms2/src/cmsplugin.c<br>
-gs/lcms2/src/cmstypes.c<br>
-gs/lcms2/src/lcms2_internal.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-20 20:12:27 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=81946ddaca41eb0726d4435a6217b3e017bd7a8c">81946ddaca41eb0726d4435a6217b3e017bd7a8c</a>
-<blockquote>
-<p>
- Patch LCMS threading bug.<br>
-<br>
- LCMS maintains a ContextID for the sake of the allocator callbacks.<br>
- In the call sequence through, it was losing this and ending up with<br>
- the allocators being called with NULL.<br>
-<br>
- Simple fix.<br>
-<br>
-gs/lcms2/src/cmssamp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-20 17:18: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=7a70a32618642f17104747dc2f5785775b42495b">7a70a32618642f17104747dc2f5785775b42495b</a>
-<blockquote>
-<p>
- pdfwrite - linearisation, correctly renumber resoruces in arrays<br>
-<br>
- The code to renumber resources was only checking for indirect references in<br>
- dictionaries, we need to check arrays as well.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-20 15:47: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=455ecb61885dcceccb23fb16518bb1790c40eb40">455ecb61885dcceccb23fb16518bb1790c40eb40</a>
-<blockquote>
-<p>
- pdfwrite - linearisation bug fixes<br>
-<br>
- Allow return code to be 0 when seeking so we don't lose the first part of<br>
- the linearised file.<br>
-<br>
- If the input job makes marks on the final page, but does not call showpage,<br>
- we discard the final page. This can lead to resources being marked as 'used'<br>
- on pages that no longer exist. We now ignore such usage.<br>
-<br>
- Fix an 'off by 1' error when indexing an array using paeg numbers<br>
- (page numebrs are 1-&gt;n, array is 0-&gt;n-1)<br>
-<br>
- Put a #ifdef round some debug prints so they don't end up in the cluster log<br>
-<br>
- Some resources are only used by other resources (eg Encoding) and should take<br>
- on the Page Usage of their parent. If the parent resource was shared we werne't<br>
- correclty updating the child with all the pages the parent was used on.<br>
-<br>
- Some memory was being double freed causing seg faults.<br>
-<br>
- No differences expetced as cluster doesn't test linearisation.<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-19 16:42:42 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd4826a3a5e3000df0e5f787e3b6ceec88c43885">cd4826a3a5e3000df0e5f787e3b6ceec88c43885</a>
-<blockquote>
-<p>
- Remove gs_lib_ctx_get_non_gc_memory_t in GS_THREADSAFE builds.<br>
-<br>
- gs_lib_ctx_get_non_gc_memory_t relied on a static to implement it,<br>
- so is incompatible with multi-threaded builds. Removing it<br>
- causes various devices/bits of code to break. We fix the<br>
- important (i.e. mostly non-contrib) devices that use it here.<br>
-<br>
- We also rework the gscms/lcms interface code to avoid it too.<br>
-<br>
- With this commit in, helgrind apitests tiger to ppmraw as being<br>
- clean.<br>
-<br>
-gs/base/gdevrinkj.c<br>
-gs/base/gdevxcf.c<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_cms.h<br>
-gs/base/gsicc_lcms.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_manage.h<br>
-gs/base/gslibctx.c<br>
-gs/base/gslibctx.h<br>
-gs/psi/zicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-19 16:16:32 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9ccfc96d8885b419437f985baa7d26db3ff1950a">9ccfc96d8885b419437f985baa7d26db3ff1950a</a>
-<blockquote>
-<p>
- Add some PACIFY_VALGRIND magic for helgrind.<br>
-<br>
- Various bits of code (notably gs_debug, some clist function pointers<br>
- and some constants in lcms) are held in statics. We accept that<br>
- gs_debug is going to be thread unsafe and choose to ignore it.<br>
- The others are initialised multiple times (to the same values) and<br>
- then never changed.<br>
-<br>
- Helgrind is not smart enough to see that these are repeatedly<br>
- updated to the same values, so flags an error every time they are<br>
- written to.<br>
-<br>
- We therefore add a bit of Valgrind magic before these places to<br>
- tell it to ignore these addresses when checking.<br>
-<br>
-gs/base/gsinit.c<br>
-gs/base/gxclfile.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclmem.c<br>
-gs/lcms2/src/cmserr.c<br>
-gs/lcms2/src/cmswtpnt.c<br>
-gs/psi/imain.c<br>
-pl/plplatf.c<br>
-pl/plplatfps.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-19 16:11:58 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9171c68f18ba278aa72df4a30ba89bb5400bdd79">9171c68f18ba278aa72df4a30ba89bb5400bdd79</a>
-<blockquote>
-<p>
- Disable various bits of debugging stats etc for GS_THREADSAFE<br>
-<br>
- Various bits of code use statics to gather statistics in DEBUG<br>
- builds; disable these in GS_THREADSAFE builds as they are<br>
- incompatible with multi-threaded operation.<br>
-<br>
-gs/base/gdevm24.c<br>
-gs/base/gdevm40.c<br>
-gs/base/gdevm48.c<br>
-gs/base/gdevm56.c<br>
-gs/base/gdevm64.c<br>
-gs/base/gxclip.c<br>
-gs/base/gxfill.c<br>
-gs/psi/idict.c<br>
-gs/psi/idstack.c<br>
-gs/psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-19 13:05:20 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e03d8c5aac80eb56cb9097a316dc36bf311d380">2e03d8c5aac80eb56cb9097a316dc36bf311d380</a>
-<blockquote>
-<p>
- Update LCMS2 to avoid race condition in Tag handling.<br>
-<br>
- LCMS2 as supplied (in both 2.3 and 2.4 at least) is broken w.r.t<br>
- multitasking due to a race condition in the Tag handling.<br>
-<br>
- When a TagTypeHandler is needed, it is looked up from a system table.<br>
- The existing code then writes into this table with the ContextID and<br>
- calls the handler. This is a race condition if 2 threads are using<br>
- the same TagTypeHandler at a time.<br>
-<br>
- The fix implemented here is to copy the TagTypeHandler structure to a<br>
- local one, write the ContextID into that, and then call through that.<br>
-<br>
-gs/lcms2/src/cmsio0.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-13 00:40: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=6777c88fab2afc3e6558fda1dfb51110088ede61">6777c88fab2afc3e6558fda1dfb51110088ede61</a>
-<blockquote>
-<p>
- Introduce GS_THREADSAFE define and modify printing calls.<br>
-<br>
- Lots of debugging/error information is printed using eprintf and<br>
- dlprintf etc. These functions do not take a gs_memory_t * and are<br>
- not safe for use within code that runs under multiple instances<br>
- created by gsapi.<br>
-<br>
- Introduce new versions (dmprintf, dmlprintf etc) that DO take a<br>
- gs_memory_ *, and move as much of ghostscript/ghostpdl's usage<br>
- over to these as possible. I have not touched the contrib directory,<br>
- and some locations in the code do not easily have a gs_memory_t<br>
- to hand, so I have left them be.<br>
-<br>
- If the GS_THREADSAFE define is made during building, then the<br>
- functions that don't take an explicit memory handle are #defined<br>
- away to nothing.<br>
-<br>
- If the GS_THREADSAFE define is made, we disable the gsapi check that<br>
- checks for a single init.<br>
-<br>
-gs/base/gdebug.h<br>
-gs/base/gdevabuf.c<br>
-gs/base/gdevbbox.c<br>
-gs/base/gdevdbit.c<br>
-gs/base/gdevdevn.c<br>
-gs/base/gdevdevn.h<br>
-gs/base/gdevdflt.c<br>
-gs/base/gdevdrop.c<br>
-gs/base/gdevfax.c<br>
-gs/base/gdevhl7x.c<br>
-gs/base/gdevifno.c<br>
-gs/base/gdevijs.c<br>
-gs/base/gdevjpx.c<br>
-gs/base/gdevm1.c<br>
-gs/base/gdevm24.c<br>
-gs/base/gdevmr1.c<br>
-gs/base/gdevmr8n.c<br>
-gs/base/gdevnfwd.c<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevpbm.c<br>
-gs/base/gdevpdf.c<br>
-gs/base/gdevpdfu.c<br>
-gs/base/gdevperm.c<br>
-gs/base/gdevplan.c<br>
-gs/base/gdevplib.c<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevpsds.c<br>
-gs/base/gdevpsf2.c<br>
-gs/base/gdevpsft.c<br>
-gs/base/gdevpsfx.c<br>
-gs/base/gdevpx.c<br>
-gs/base/gdevrinkj.c<br>
-gs/base/gdevsppr.c<br>
-gs/base/gdevsvg.c<br>
-gs/base/gdevsvga.c<br>
-gs/base/gdevtrac.c<br>
-gs/base/gdevtsep.c<br>
-gs/base/gdevx.c<br>
-gs/base/gdevxcf.c<br>
-gs/base/gdevxcmp.c<br>
-gs/base/gp_unifs.c<br>
-gs/base/gp_unix.c<br>
-gs/base/gsalloc.c<br>
-gs/base/gsalphac.c<br>
-gs/base/gscdevn.c<br>
-gs/base/gschar0.c<br>
-gs/base/gscie.c<br>
-gs/base/gsciemap.c<br>
-gs/base/gscoord.c<br>
-gs/base/gscsepr.c<br>
-gs/base/gscspace.c<br>
-gs/base/gsequivc.c<br>
-gs/base/gserrors.h<br>
-gs/base/gsfcmap1.c<br>
-gs/base/gsfont.c<br>
-gs/base/gshsb.c<br>
-gs/base/gsht.c<br>
-gs/base/gsht1.c<br>
-gs/base/gshtscr.c<br>
-gs/base/gsicc.c<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_profilecache.c<br>
-gs/base/gsimage.c<br>
-gs/base/gslib.c<br>
-gs/base/gslibctx.c<br>
-gs/base/gsmalloc.c<br>
-gs/base/gsmchunk.c<br>
-gs/base/gsmemory.c<br>
-gs/base/gsmisc.c<br>
-gs/base/gsovrc.c<br>
-gs/base/gspath.c<br>
-gs/base/gspath1.c<br>
-gs/base/gsptype1.c<br>
-gs/base/gsrefct.h<br>
-gs/base/gsstate.c<br>
-gs/base/gsstruct.h<br>
-gs/base/gstrans.c<br>
-gs/base/gstype1.c<br>
-gs/base/gstype2.c<br>
-gs/base/gstype42.c<br>
-gs/base/gxacpath.c<br>
-gs/base/gxalloc.h<br>
-gs/base/gxblend.c<br>
-gs/base/gxblend1.c<br>
-gs/base/gxccache.c<br>
-gs/base/gxccman.c<br>
-gs/base/gxchar.c<br>
-gs/base/gxclbits.c<br>
-gs/base/gxcldev.h<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclip.c<br>
-gs/base/gxclip2.c<br>
-gs/base/gxclipm.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclmem.c<br>
-gs/base/gxclpath.c<br>
-gs/base/gxclrast.c<br>
-gs/base/gxclread.c<br>
-gs/base/gxclrect.c<br>
-gs/base/gxclthrd.c<br>
-gs/base/gxclutil.c<br>
-gs/base/gxcmap.c<br>
-gs/base/gxcpath.c<br>
-gs/base/gxdcconv.c<br>
-gs/base/gxdevndi.c<br>
-gs/base/gxdtfill.h<br>
-gs/base/gxfapiu.c<br>
-gs/base/gxfill.c<br>
-gs/base/gxfillsl.h<br>
-gs/base/gxfilltr.h<br>
-gs/base/gxht.c<br>
-gs/base/gxi12bit.c<br>
-gs/base/gxicolor.c<br>
-gs/base/gxidata.c<br>
-gs/base/gxifast.c<br>
-gs/base/gximag3x.c<br>
-gs/base/gximage.c<br>
-gs/base/gximage3.c<br>
-gs/base/gximono.c<br>
-gs/base/gxipixel.c<br>
-gs/base/gxiscale.c<br>
-gs/base/gxmclip.c<br>
-gs/base/gxp1fill.c<br>
-gs/base/gxpath.c<br>
-gs/base/gxpath.h<br>
-gs/base/gxpcmap.c<br>
-gs/base/gxpflat.c<br>
-gs/base/gxstroke.c<br>
-gs/base/gxtype1.c<br>
-gs/base/lib.mak<br>
-gs/base/sbwbs.c<br>
-gs/base/scfd.c<br>
-gs/base/scfe.c<br>
-gs/base/sdctd.c<br>
-gs/base/sdcte.c<br>
-gs/base/sfilter2.c<br>
-gs/base/sfxfd.c<br>
-gs/base/sfxstdio.c<br>
-gs/base/shc.h<br>
-gs/base/shcgen.c<br>
-gs/base/sidscale.c<br>
-gs/base/siscale.c<br>
-gs/base/sjbig2.c<br>
-gs/base/sjbig2_luratech.c<br>
-gs/base/sjpx_luratech.c<br>
-gs/base/slzwd.c<br>
-gs/base/slzwe.c<br>
-gs/base/std.h<br>
-gs/base/stream.c<br>
-gs/contrib/pcl3/eprn/eprnparm.c<br>
-gs/contrib/pcl3/eprn/eprnrend.c<br>
-gs/contrib/pcl3/eprn/gdeveprn.c<br>
-gs/contrib/pcl3/src/gdevpcl3.c<br>
-gs/cups/gdevcups.c<br>
-gs/psi/fapiufst.c<br>
-gs/psi/ialloc.c<br>
-gs/psi/iapi.c<br>
-gs/psi/idebug.c<br>
-gs/psi/idict.c<br>
-gs/psi/idisp.c<br>
-gs/psi/idstack.c<br>
-gs/psi/igc.c<br>
-gs/psi/igcref.c<br>
-gs/psi/igcstr.c<br>
-gs/psi/igcstr.h<br>
-gs/psi/ilocate.c<br>
-gs/psi/imain.c<br>
-gs/psi/imainarg.c<br>
-gs/psi/iname.c<br>
-gs/psi/interp.c<br>
-gs/psi/ireclaim.c<br>
-gs/psi/isave.c<br>
-gs/psi/iscan.c<br>
-gs/psi/zcie.c<br>
-gs/psi/zcolor.c<br>
-gs/psi/zcontext.c<br>
-gs/psi/zdscpars.c<br>
-gs/psi/zfapi.c<br>
-gs/psi/zfcid0.c<br>
-gs/psi/zfile.c<br>
-gs/psi/zfjbig2.c<br>
-gs/psi/zfjpx.c<br>
-gs/psi/zicc.c<br>
-gs/psi/zpcolor.c<br>
-gs/psi/zvmem.c<br>
-pcl/pccid.c<br>
-pcl/pccid.h<br>
-pcl/pccsbase.c<br>
-pcl/pcfont.c<br>
-pcl/pcfsel.c<br>
-pcl/pcindxed.c<br>
-pcl/pcmacros.c<br>
-pcl/pcpage.c<br>
-pcl/pcparse.c<br>
-pcl/pcpatrn.c<br>
-pcl/pcsfont.c<br>
-pcl/pcsymbol.c<br>
-pcl/pctext.c<br>
-pcl/pctop.c<br>
-pcl/pgconfig.c<br>
-pcl/pgdraw.c<br>
-pcl/pginit.c<br>
-pcl/pglabel.c<br>
-pcl/pgmisc.c<br>
-pcl/pgparse.c<br>
-pcl/pgvector.c<br>
-pl/pjparse.c<br>
-pl/plchar.c<br>
-pl/plfont.c<br>
-pl/pllfont.c<br>
-pl/plmain.c<br>
-pl/plsrgb.c<br>
-pl/plsymbol.c<br>
-pl/plsymbol.h<br>
-pl/pluchar.c<br>
-pl/plulfont.c<br>
-pxl/pxffont.c<br>
-pxl/pxfont.c<br>
-pxl/pxgstate.c<br>
-pxl/pximage.c<br>
-pxl/pxink.c<br>
-pxl/pxparse.c<br>
-pxl/pxpthr.c<br>
-pxl/pxsessio.c<br>
-svg/svgshapes.c<br>
-svg/svgtop.c<br>
-xps/ghostxps.h<br>
-xps/xpsanalyze.c<br>
-xps/xpscff.c<br>
-xps/xpsdoc.c<br>
-xps/xpsglyphs.c<br>
-xps/xpsgradient.c<br>
-xps/xpsimage.c<br>
-xps/xpspage.c<br>
-xps/xpspath.c<br>
-xps/xpsresource.c<br>
-xps/xpstop.c<br>
-xps/xpsttf.c<br>
-xps/xpsxml.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-18 05:06:55 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1fa1eca3be2955e1ed1f8433c18d06417ea85f4c">1fa1eca3be2955e1ed1f8433c18d06417ea85f4c</a>
-<blockquote>
-<p>
- Perl script to drive apitest.<br>
-<br>
- Runs over a given set of devices/set of test files. Run apitest on each<br>
- checking that output/stdout/stderr etc are the same for all threads.<br>
-<br>
-gs/toolbin/apitest.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-09 07:58:30 -0700
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4c74f2aa1128c39a2f75a6626f6a59d4f854dc94">4c74f2aa1128c39a2f75a6626f6a59d4f854dc94</a>
-<blockquote>
-<p>
- Simple apitest program.<br>
-<br>
- Requires pthreads. Build with &quot;make apitest&quot; within gs.<br>
-<br>
- Invoke with a ghostscript like command line: e.g.<br>
-<br>
- bin/apitest -sDEVICE=pdfwrite -o outfile.%d. examples/tiger.eps<br>
-<br>
- The command line must have a -o in it, because it rewrites the<br>
- &quot;outfile.%d.&quot; to be &quot;outfile.%d.THREADNUM&quot; where THREADNUM is 0 to 9<br>
- (change NUM_THREADS in psi/apitest.c to change this).<br>
-<br>
- stdout and stderr are redirected to each stdout.THREADNUM and<br>
- stderr.THREADNUM respectively.<br>
-<br>
-gs/base/ugcclib.mak<br>
-gs/base/unix-end.mak<br>
-gs/base/unixlink.mak<br>
-gs/psi/apitest.c<br>
-gs/psi/iapi.c<br>
-gs/psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-18 09:54: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=88077be834a9034282355e76bac1e76b66778483">88077be834a9034282355e76bac1e76b66778483</a>
-<blockquote>
-<p>
- Add a newline to the end of the file because Visual Studio won't correctly<br>
- compile it otherwise.<br>
-<br>
-gs/base/gscms.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-17 22:47:51 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8d274958209aed769e9804d0704c199b8f5cb4af">8d274958209aed769e9804d0704c199b8f5cb4af</a>
-<blockquote>
-<p>
- Added 'relaxtimeout' option to clusterpush.pl (and to the documentation).<br>
-<br>
-gs/toolbin/localcluster/clusterpush.pl<br>
-gs/toolbin/localcluster/clusterpush.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-12 04:32:52 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=82c3d60735ef1a7e702db6833c1c709edeaca1d4">82c3d60735ef1a7e702db6833c1c709edeaca1d4</a>
-<blockquote>
-<p>
- Initial work towards adding in support for use of DeviceN ICC color profiles as the output profile.<br>
-<br>
-gs/base/gdevpdfk.c<br>
-gs/base/gscms.h<br>
-gs/base/gsdparam.c<br>
-gs/base/gsequivc.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_manage.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-17 08:53:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=928e28bc3521f479eb997eddfd8cffcb7a042cea">928e28bc3521f479eb997eddfd8cffcb7a042cea</a>
-<blockquote>
-<p>
- pdfwrite - improve Outline handling when processing a subset of pages from PDF input<br>
-<br>
- The Outline pdfmarks could get confused if a leaf node was elided due to its<br>
- Viwe or Dest page lying outside the range of pages processed from a PDF file.<br>
- This could lead to nesting going wrong and trying to create more than 32 levels<br>
- of nodes.<br>
-<br>
- This commit moves the checking of the Dest and View pages from the PDF interpreter<br>
- into pdfwrite, which means pdfwrite now needs to pick up the FirstPage and<br>
- LastPage switches. If a destination page lies outside the processed range we<br>
- need to preserve it (so that the tree works out properly), but we don't write<br>
- the View or Dest property, so that we don't point to non-existent pages.<br>
-<br>
- No differences epxected this is not cluster tested.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/base/gdevpdfb.h<br>
-gs/base/gdevpdfm.c<br>
-gs/base/gdevpdfp.c<br>
-gs/base/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-14 23:09:51 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=486dd619f9a705e4f9871974a5f0833964c1f32a">486dd619f9a705e4f9871974a5f0833964c1f32a</a>
-<blockquote>
-<p>
- Bug 688288: Finish transparency structure cleanup<br>
-<br>
- Finish the cleanup started by rev. 0025b68a2df. Remove implementation<br>
- of zdiscardtransparencygroup and zdiscardtransparencymask operators from<br>
- the code base and their invocation from PDF interpreter.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-14 11:11: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=4808e18412d21da480ed7a7628015941fc596a08">4808e18412d21da480ed7a7628015941fc596a08</a>
-<blockquote>
-<p>
- pdfwrite - track form depth when creating forms with BP pdfmark<br>
-<br>
- Bug #693327<br>
-<br>
- In order to properly set the co-ordinate space for patterns inside forms<br>
- we need to know the form's default co-ordinate space. To do this we keep<br>
- a record of the nested form depth. However this wasn't being updated when<br>
- we created a new form with the /BP pdfmark.<br>
-<br>
- This commit fixes that.<br>
-<br>
-gs/base/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-14 09:59:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dfcfd64d31e6e6c5e07dfcb793e0c781e180afd0">dfcfd64d31e6e6c5e07dfcb793e0c781e180afd0</a>
-<blockquote>
-<p>
- pdfwrite, ps2write, txtwrite - add support for RTL DL<br>
-<br>
- Commit 062c0b5847519633e4349cf3a1f0830e529c4842 implements the HPGL/RTL<br>
- Download Character (DL) operation. This commit adds support for the new<br>
- font type defined as part of that update.<br>
-<br>
- Text using the DL font should now be preserved as text using a type 3 font<br>
- in pdfwrite or ps2write, permitting search and copy operations, and should<br>
- be extracted properly by the txtwrite device.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpdtd.c<br>
-gs/base/gdevpdte.c<br>
-gs/base/gdevpdtf.c<br>
-gs/base/gdevpdti.c<br>
-gs/base/gdevpdts.c<br>
-gs/base/gdevpdtt.c<br>
-gs/base/gdevpdtw.c<br>
-gs/base/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-12 10:34: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=0025b68a2df2f7c68cdcf4ebe0b3b9901c6a3698">0025b68a2df2f7c68cdcf4ebe0b3b9901c6a3698</a>
-<blockquote>
-<p>
- Clean up of some of the transparency structures<br>
-<br>
- The graphic state had vestiges of someones attempt to put the transparency<br>
- stack into the graphic state. This is confusing for those looking at the code.<br>
- This clean up is suggested in Bug 688288.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevpdfb.h<br>
-gs/base/gdevpdfg.c<br>
-gs/base/gdevpdft.c<br>
-gs/base/gdevpdfx.h<br>
-gs/base/gsistate.c<br>
-gs/base/gsstate.c<br>
-gs/base/gstparam.h<br>
-gs/base/gstrans.c<br>
-gs/base/gstrans.h<br>
-gs/base/gxdevcli.h<br>
-gs/base/gxistate.h<br>
-gs/base/gzstate.h<br>
-gs/psi/ztrans.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-13 15:58: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=bfae0b91bbe273318284a01d67b746b365827bb6">bfae0b91bbe273318284a01d67b746b365827bb6</a>
-<blockquote>
-<p>
- ps2write - correct %%BoundingBox comment<br>
-<br>
- The upper right y co-ordinate of the bounding box was being incorrectly<br>
- set. Also added the %%HiResBoundingBox comment. Although this is not a<br>
- DSC 3 standard comment it is widely used.<br>
-<br>
- No diffrences expected.<br>
-<br>
-gs/base/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-13 14:53:15 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=44d00dd1bd34e2fb735d4682b73d880e208f92bd">44d00dd1bd34e2fb735d4682b73d880e208f92bd</a>
-<blockquote>
-<p>
- pdfwrite - improve subset font prefix generation<br>
-<br>
- We generate the prefix for a subset font by creating a hash from the<br>
- usage pattern of glyphs in a font. If the font was already subset, and<br>
- 'compact' (ie glyphs are used in order from 1 to n), then it was possible<br>
- to generate the same prefix for two differetn subsets of the same font.<br>
-<br>
- In fact this is always possible, but here we add a heuristic which uses<br>
- the MD5 hash we create for stream objects as an additional hash when<br>
- generating the subset prefix. This does not guarantee that name collisions<br>
- won't occur but should reduce the incidence still further.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gdevpdtb.c<br>
-gs/base/gdevpdtb.h<br>
-gs/base/gdevpdtd.c<br>
-gs/base/gdevpdtd.h<br>
-gs/base/gdevpdtf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-13 14:48:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e8cfe956fe45fa949d22b10e2af665506e49fde4">e8cfe956fe45fa949d22b10e2af665506e49fde4</a>
-<blockquote>
-<p>
- pdfwrite - linearisation, cater for unused objects<br>
-<br>
- If we had an object which wasn't used on any page then we would try to add<br>
- it to the page or shared hints, which we obviously shouldn't, and which could<br>
- potentially cause a seg fault.<br>
-<br>
- With this change we simply don't add such objects to the hints.<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-13 08:31: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=23d410c021a2b038ac5535e9eb028d6a808801ea">23d410c021a2b038ac5535e9eb028d6a808801ea</a>
-<blockquote>
-<p>
- pdfwrite - squash compiler warnings<br>
-<br>
- a couple of compiler warnings on debug print messages.<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-12 16:27:04 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e1ab0bc7410ec278f489a2e0c469a23b7aa17e9">8e1ab0bc7410ec278f489a2e0c469a23b7aa17e9</a>
-<blockquote>
-<p>
- pdfwrite - fix ridiculous typo in last commit....<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-12 16:17: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=119717599c8ab62b037f61b8f042a1eeae39b2f4">119717599c8ab62b037f61b8f042a1eeae39b2f4</a>
-<blockquote>
-<p>
- pdfwrite - linearisation fix stupid mistake causing infinte loop<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-12 12:54: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=a010600d3d99b16251fbfa5fede57d4583978632">a010600d3d99b16251fbfa5fede57d4583978632</a>
-<blockquote>
-<p>
- pdfwrite - fix another compiler warning<br>
-<br>
- This warning didn't show up previously, I have no idea why.<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-12 10:08: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=aa335a8a51261060aab8726fd300161d3b6f4334">aa335a8a51261060aab8726fd300161d3b6f4334</a>
-<blockquote>
-<p>
- pdfwrite - linearisation, tidy up compiler warnings<br>
-<br>
- also remove an accidentally commited change which led to us writing<br>
- invalid xref tables.<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-06 11:33:42 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fc538635d876a99e7cfc32b4c525126093fea67a">fc538635d876a99e7cfc32b4c525126093fea67a</a>
-<blockquote>
-<p>
- Add in option of -dPreBandThreshold=true/false to specify thresholding prior to clist<br>
-<br>
- When halftoning, it may be advantageous from a memory storage to halftone an image pre-clist.<br>
- This adds code to check if the halftoned image at device resolution is smaller than the source<br>
- image. It it is, then the image will by default be rendered before going into the clist.<br>
- This option is turned off through the use of the device parameter -dPreBandThreshold=false<br>
-<br>
-gs/base/gscms.h<br>
-gs/base/gsdparam.c<br>
-gs/base/gsequivc.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gxclimag.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-11 12:51:05 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8c77c16ad0f4e2bd107f6fa1a024c412e889a0ba">8c77c16ad0f4e2bd107f6fa1a024c412e889a0ba</a>
-<blockquote>
-<p>
- Convert BitsPerComponent to an integer when we get a float.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-11 09:53:46 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=062c0b5847519633e4349cf3a1f0830e529c4842">062c0b5847519633e4349cf3a1f0830e529c4842</a>
-<blockquote>
-<p>
- HPGL/RTL DL (Download Character) implementation.<br>
-<br>
-gs/base/gxftype.h<br>
-pcl/pgchar.c<br>
-pcl/pgfdata.c<br>
-pcl/pgfdata.h<br>
-pcl/pgfont.c<br>
-pcl/pgfont.h<br>
-pcl/pglabel.c<br>
-pcl/pgmand.h<br>
-pcl/pgstate.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-07 13:13:30 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=423501bbe9be110622edf4ef001edbd289136ee0">423501bbe9be110622edf4ef001edbd289136ee0</a>
-<blockquote>
-<p>
- A silly typo in an accessor function.<br>
-<br>
- Fortunately, this function is mainly used only for debugging purposes.<br>
-<br>
-pcl/pccid.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-12 14:39:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1245d1ad8e4400b6689132d32ee174041eaa60e4">1245d1ad8e4400b6689132d32ee174041eaa60e4</a>
-<blockquote>
-<p>
- pdfwrite - sanitise linearisation file accesses to be 64-bit<br>
-<br>
- Change all the fteel/fseel calls to use gp_***_64 so that we don't trip<br>
- over a maximum 4Gb.<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-10 16:14:15 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5a1438b9f9d27be7e423300f563833a9d0d03ee4">5a1438b9f9d27be7e423300f563833a9d0d03ee4</a>
-<blockquote>
-<p>
- Fix for an indeterminism in the fast thresholding code<br>
-<br>
- A byte of nonsense data was getting included with the image data to which we were thresholding<br>
- in very special resolution cases.<br>
-<br>
-gs/base/gxicolor.c<br>
-gs/base/gximono.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-10 21:48:00 +0100
-</strong>
-<br>unknown &lt;ken@.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3904374b1a567ecbad3d496fc0cdac354225224a">3904374b1a567ecbad3d496fc0cdac354225224a</a>
-<blockquote>
-<p>
- pdfwrite - linearisation, memory cleanup<br>
-<br>
- Free all the memory used in the course of producing a linearised PDF file.<br>
-<br>
- No differences expected, not tested by cluster<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-09 18:43:52 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3a56f4eb5a9f15795725374b297edab0fb8ebc5d">3a56f4eb5a9f15795725374b297edab0fb8ebc5d</a>
-<blockquote>
-<p>
- Bug 693045: Correctly restore PS stack when PDF stream run aborts.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-09 11:33:53 -0700
-</strong>
-<br>Tor Andersson &lt;tor.andersson@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7de89cff326888d9129b0ae6e4d003fd538b8321">7de89cff326888d9129b0ae6e4d003fd538b8321</a>
-<blockquote>
-<p>
- Merge 'gs/jbig2dec/' from jbig2dec.git using git-subtree<br>
-<br>
- git-subtree-dir: gs/jbig2dec<br>
- git-subtree-mainline: faac14fb1532533a811649cef2b68cf95ec50fdf<br>
- git-subtree-split: 7a82fc0abd135e08875ec4941ba43e832bc1b7f3<br>
-<br>
-gs/jbig2dec/.cvsignore<br>
-gs/jbig2dec/.gitignore<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-29 16:19: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=7a82fc0abd135e08875ec4941ba43e832bc1b7f3">7a82fc0abd135e08875ec4941ba43e832bc1b7f3</a>
-<blockquote>
-<p>
- Remove dependence on jbig2dec auto-generated files<br>
-<br>
- Also provide a workaround for LCMS2 on systems without sqrtf().<br>
-<br>
- No cluster differences<br>
-<br>
-os_types.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-24 15:19: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=3a424b8fa0e30b76b49b9c2f2fe167e5dc653073">3a424b8fa0e30b76b49b9c2f2fe167e5dc653073</a>
-<blockquote>
-<p>
- Update the libpng check to a non-deprecated API call.<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-23 15:09: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=07abb8a54e2d910e3b5a73341b7912948e0d0b61">07abb8a54e2d910e3b5a73341b7912948e0d0b61</a>
-<blockquote>
-<p>
- Bug 693298; Memento tweak for memset compile problem.<br>
-<br>
- Don't define memset if someone has already #defined it. Thanks to<br>
- William Bader.<br>
-<br>
-memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-23 15:03: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=5e5cff776abeb065e2c4ef5092256486fc3a2d35">5e5cff776abeb065e2c4ef5092256486fc3a2d35</a>
-<blockquote>
-<p>
- Revert &quot;Move memento include from jbig2.h to jbig2_priv.h&quot;<br>
-<br>
- This reverts commit 91744cfb2fe5d8b5b66d31077b4b22c6b3c905a2.<br>
-<br>
- This broke the memento build of gs due to the #defining of<br>
- free/realloc. For now, we'll have to live with the include<br>
- in the public header.<br>
-<br>
-jbig2.h<br>
-jbig2_priv.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-23 13: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=91744cfb2fe5d8b5b66d31077b4b22c6b3c905a2">91744cfb2fe5d8b5b66d31077b4b22c6b3c905a2</a>
-<blockquote>
-<p>
- Move memento include from jbig2.h to jbig2_priv.h<br>
-<br>
- There is no need to expose memento outside of jbig2. Thanks to<br>
- zeniko for the discussion in bug 693284 that lead to this.<br>
-<br>
-jbig2.h<br>
-jbig2_priv.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-13 17:03:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=13cc9dc158f12c3f446579655e942e44ac158634">13cc9dc158f12c3f446579655e942e44ac158634</a>
-<blockquote>
-<p>
- Update copyright headers.<br>
-<br>
-config_win32.h<br>
-jbig2.c<br>
-jbig2.h<br>
-jbig2_arith.c<br>
-jbig2_arith.h<br>
-jbig2_arith_iaid.c<br>
-jbig2_arith_iaid.h<br>
-jbig2_arith_int.c<br>
-jbig2_arith_int.h<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-jbig2_halftone.c<br>
-jbig2_halftone.h<br>
-jbig2_huffman.c<br>
-jbig2_huffman.h<br>
-jbig2_hufftab.h<br>
-jbig2_image.c<br>
-jbig2_image.h<br>
-jbig2_image_pbm.c<br>
-jbig2_image_png.c<br>
-jbig2_metadata.c<br>
-jbig2_metadata.h<br>
-jbig2_mmr.c<br>
-jbig2_mmr.h<br>
-jbig2_page.c<br>
-jbig2_priv.h<br>
-jbig2_refinement.c<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_symbol_dict.h<br>
-jbig2_text.c<br>
-jbig2_text.h<br>
-jbig2dec.c<br>
-memcmp.c<br>
-memento.c<br>
-memento.h<br>
-os_types.h<br>
-pbm2png.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-06 17:13:39 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=48fd721f3fb53b3fd10456e508b06d808ee9e647">48fd721f3fb53b3fd10456e508b06d808ee9e647</a>
-<blockquote>
-<p>
- Bug 693256: Free GR_/GB_stats......<br>
-<br>
- ....as long as retaining them is yet to be implemented<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-06 15:24: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=28cc0cf46dc9455545631e54070edc2a8adc15e0">28cc0cf46dc9455545631e54070edc2a8adc15e0</a>
-<blockquote>
-<p>
- Remove files for unsupported build tools.<br>
-<br>
-Jamfile<br>
-SConstruct<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-08 15:51: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=536620333aa7b752506626dce651ede08e2cdbc9">536620333aa7b752506626dce651ede08e2cdbc9</a>
-<blockquote>
-<p>
- Enable Memento to be used with jbig2dec<br>
-<br>
- ./configure or ./autogen.sh as usual, then<br>
- &quot;make XCFLAGS=-DMEMENTO&quot;.<br>
-<br>
- This involves duplicating memento within jbig2dec. We disable the GS<br>
- specific build hacks, and add just one more; if GSBUILD is defined<br>
- then jbig2 uses the version of memento from base, rather than the version<br>
- of memento from inside jbig2. This avoids any potential problems with<br>
- version skew.<br>
-<br>
-Makefile.am<br>
-jbig2.h<br>
-memento.c<br>
-memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-03 22:52:19 +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=e37802e46e06e7c3d9f01d626b244771bcad76a1">e37802e46e06e7c3d9f01d626b244771bcad76a1</a>
-<blockquote>
-<p>
- Bug 693050 : Fix compiler warnings<br>
-<br>
-jbig2_halftone.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-02 22:49:17 +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=1b311c624ce08c9c702ba4e88e2b0d787830334d">1b311c624ce08c9c702ba4e88e2b0d787830334d</a>
-<blockquote>
-<p>
- Bug 693050 : Fix valgrind error in 0CF9 folder<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-02 21:53: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=50d99ce72e1722427415ac745445dc1ca7e67c83">50d99ce72e1722427415ac745445dc1ca7e67c83</a>
-<blockquote>
-<p>
- Bug 693050 : Fix error handling in 0717 folder<br>
-<br>
-jbig2_halftone.c<br>
-jbig2_mmr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-23 23:57:19 +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=576c7d4162890ecee3b7322fd5665a8ae3c2d6d7">576c7d4162890ecee3b7322fd5665a8ae3c2d6d7</a>
-<blockquote>
-<p>
- Bug 693050 : Fix error handling in dcbd folder<br>
-<br>
-jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-23 23:00:47 +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=7feea483a0354e13c42ffa239b9b0c2d00f08428">7feea483a0354e13c42ffa239b9b0c2d00f08428</a>
-<blockquote>
-<p>
- Bug 693050 : Fix error handling in 9557 folder<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-23 22:14:43 +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=6f9608495e1f4b1fcac518378a44e8704d943dd7">6f9608495e1f4b1fcac518378a44e8704d943dd7</a>
-<blockquote>
-<p>
- Bug 693050 : Fix memory leak in 4faa folder<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-23 21:12:19 +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=9df6dfdae0f2ffba6f1335a8a6c5e2a2274e0d84">9df6dfdae0f2ffba6f1335a8a6c5e2a2274e0d84</a>
-<blockquote>
-<p>
- Bug 693050 : Fix error handling in 2908 folder<br>
-<br>
-jbig2_halftone.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-22 22:25: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=8033c8336691c0b833cde32d47f4bbf8d7f4d4f2">8033c8336691c0b833cde32d47f4bbf8d7f4d4f2</a>
-<blockquote>
-<p>
- Bug 693050 : Fix memory leak in 146f folder<br>
-<br>
-jbig2_mmr.c<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-22 16:56:39 +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=a8ca8ed551e2897c422d0b6d46f1bd8ce30311b9">a8ca8ed551e2897c422d0b6d46f1bd8ce30311b9</a>
-<blockquote>
-<p>
- Bug 693050 : Fix minor typos and memory leak in 040d folder<br>
-<br>
-jbig2_arith.c<br>
-jbig2_image.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-20 18:18: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=76c000e507efff47e6f625bddef0a93323a7cc9d">76c000e507efff47e6f625bddef0a93323a7cc9d</a>
-<blockquote>
-<p>
- Bug 690723 : Prevent over writing unallocated memory when parsing an image<br>
-<br>
-jbig2_mmr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-15 19:22:52 +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=9cf138eae6a1ac6554ecc3414224fecb0ba2ec2b">9cf138eae6a1ac6554ecc3414224fecb0ba2ec2b</a>
-<blockquote>
-<p>
- Bug 693050 : Fixes CERT reported issues labelled DestAv<br>
-<br>
-jbig2.c<br>
-jbig2_priv.h<br>
-jbig2_symbol_dict.c<br>
-jbig2_symbol_dict.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-14 17:06: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=1c933c8c1d2beb7b6c6747c29fec58c6d6b8a02c">1c933c8c1d2beb7b6c6747c29fec58c6d6b8a02c</a>
-<blockquote>
-<p>
- Bug 693050 : Fixes CERT reported issues labelled SourceAvNearNull<br>
-<br>
-jbig2_image.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-06 17:16:53 +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=3eff8ef1daf4de5232cb432fd685f6befdac1906">3eff8ef1daf4de5232cb432fd685f6befdac1906</a>
-<blockquote>
-<p>
- Bug 693050 : Fixes CERT reported issue labelled HeapError<br>
-<br>
-jbig2.c<br>
-jbig2_image.c<br>
-jbig2_metadata.c<br>
-jbig2_priv.h<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-05 16:39:39 +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=08bc90379a7bd5d8eead94ae872f6fc6cc93a6fb">08bc90379a7bd5d8eead94ae872f6fc6cc93a6fb</a>
-<blockquote>
-<p>
- Bug 693025 : Correct memory leaks reported by Zeniko<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-31 17:51:51 +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=017f11f142bdea0965f453d64a31ef02b3271cba">017f11f142bdea0965f453d64a31ef02b3271cba</a>
-<blockquote>
-<p>
- Bug 693025: Correct typos reported by Zeniko<br>
-<br>
-jbig2_huffman.c<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-30 17:42: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=90f453a7ea397418ed33966e6b94650efd99284f">90f453a7ea397418ed33966e6b94650efd99284f</a>
-<blockquote>
-<p>
- Bug 693050 : Fixes CERT reported issue labelled DestAvNearNull<br>
-<br>
-jbig2_image.c<br>
-jbig2_page.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-27 23:35:06 +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=26565665591e250cfbda9bc6d8834f8a2922d206">26565665591e250cfbda9bc6d8834f8a2922d206</a>
-<blockquote>
-<p>
- Bug 693050 : Fixes CERT reported issue labelled BranchAvNearNull<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-27 22:47: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=bb27f271e4b508d63ca4f572b733e36977f0cbc4">bb27f271e4b508d63ca4f572b733e36977f0cbc4</a>
-<blockquote>
-<p>
- Bug 693050 : Fixes CERT reported issue labelled BlockMoveAv<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-27 21:43:27 +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=dbf31907db5654184b9e7bca5d700f72deccc9fa">dbf31907db5654184b9e7bca5d700f72deccc9fa</a>
-<blockquote>
-<p>
- Bug 693050 : Fixes CERT reported issue labelled SegFaultOnPc<br>
-<br>
-jbig2_generic.c<br>
-jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-14 18:08:00 +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=4886f1c69e712a730399da308bfb1b731a652cbb">4886f1c69e712a730399da308bfb1b731a652cbb</a>
-<blockquote>
-<p>
- Bug 693025: Updated patch from Zeniko to fix various crashes and leaks<br>
-<br>
-jbig2_halftone.c<br>
-jbig2_huffman.c<br>
-jbig2_image.c<br>
-jbig2_refinement.c<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-09 00:00:31 +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=a27094d1833bf10c9ab3b612182aa23f4eb3044f">a27094d1833bf10c9ab3b612182aa23f4eb3044f</a>
-<blockquote>
-<p>
- Bug 690974: This patch from Gorac implements the generic refinement region decoding procedure for when TPGRON is TRUE.<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-08 23:13:13 +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=a43f448139d0a72688c9191adab0718b9ef43ec5">a43f448139d0a72688c9191adab0718b9ef43ec5</a>
-<blockquote>
-<p>
- Bug 690870: This patch prevents the image compositing occurring if the src is outside of the clip region.<br>
-<br>
-jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-25 19:21:08 +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=33e85ea71051ad64ca4bb8b874dcf8bed9b66e62">33e85ea71051ad64ca4bb8b874dcf8bed9b66e62</a>
-<blockquote>
-<p>
- Bug 691254: This patch prevents the seg fault in Jbig2_042_14.pdf.<br>
-<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-24 13:20:11 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d120cab65c74fe97e4e4512f6a034f0fba0cac5">1d120cab65c74fe97e4e4512f6a034f0fba0cac5</a>
-<blockquote>
-<p>
- Tweak jbig2dec to cope better with NULLs.<br>
-<br>
- Fix various destructors in jbig2dec to cope with being called<br>
- with image = NULL. This cures a problem in mupdf where it SEGVs<br>
- when called on &quot;1239 - skip invalid content streams.pdf&quot; from the<br>
- sumatra test set.<br>
-<br>
-jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-13 10:40:50 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1bfe4ae823054ac2dc94af15246fa489304cf80">b1bfe4ae823054ac2dc94af15246fa489304cf80</a>
-<blockquote>
-<p>
- Bug 691230, basic jbig2 halftone image support.<br>
-<br>
- Thanks to George Gottleuber for this work.<br>
-<br>
-jbig2_halftone.c<br>
-jbig2_halftone.h<br>
-jbig2_mmr.c<br>
-jbig2_mmr.h<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-10 22:24:35 +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=a42adfaa785b05670af63f8767c3ff55636c6686">a42adfaa785b05670af63f8767c3ff55636c6686</a>
-<blockquote>
-<p>
- Bug 691267: Check all realloc error paths.<br>
-<br>
-jbig2.c<br>
-jbig2_huffman.c<br>
-jbig2_page.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-29 20:33:16 +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=1fddee262691d23dc283965c0dbe0e0de2c85bf9">1fddee262691d23dc283965c0dbe0e0de2c85bf9</a>
-<blockquote>
-<p>
- Bug 691267: jbig2dec needs to check malloc() return values<br>
-<br>
- This fix checks all return paths to ensure that the appropriate error<br>
- is returned on failure from any malloc() call within jbig2dec.<br>
-<br>
-jbig2.c<br>
-jbig2_arith.c<br>
-jbig2_arith_iaid.c<br>
-jbig2_arith_int.c<br>
-jbig2_generic.c<br>
-jbig2_halftone.c<br>
-jbig2_huffman.c<br>
-jbig2_image.c<br>
-jbig2_metadata.c<br>
-jbig2_page.c<br>
-jbig2_refinement.c<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-20 10:29:47 +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=f680c2d09d76172f7adee998608a8df0b8d2828c">f680c2d09d76172f7adee998608a8df0b8d2828c</a>
-<blockquote>
-<p>
- Fix 691958: check for an image before marking a page complete. Also update return code to handle errors correctly.<br>
-<br>
-jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-06-01 16:22:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=609901fe1d5496caeae2289ee20d7be965e413b0">609901fe1d5496caeae2289ee20d7be965e413b0</a>
-<blockquote>
-<p>
- Tweak jbig2dec os_types.h for android mupdf build.<br>
-<br>
- If HAVE_STDINT_H is defined we are supposed to be getting our definitions<br>
- from stdint.h. Instead the header defines them anyway. Fix this. This showed<br>
- up when building MuPDF for Android.<br>
-<br>
-os_types.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-05-11 15:39:06 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6e49f7e6d0c680ad0962cf7c620d67aa943c48a7">6e49f7e6d0c680ad0962cf7c620d67aa943c48a7</a>
-<blockquote>
-<p>
- Fixes bug #689870 - add proper big endian number accessors.<br>
-<br>
- Previously only an unsigned accessor was provided and it was being<br>
- used to read both signed and unsigned quantities.<br>
-<br>
-jbig2.c<br>
-jbig2_halftone.c<br>
-jbig2_page.c<br>
-jbig2_priv.h<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-05-11 15:18:11 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ae98887d657761ac4d15881da559bb9ae24f26e7">ae98887d657761ac4d15881da559bb9ae24f26e7</a>
-<blockquote>
-<p>
- Fixes 690889, potential null dereference.<br>
-<br>
- Prevent a theoretical (no test file) null dereference. There are<br>
- several of these cases identified by by static analysis. We believe<br>
- the authors intent was to pass the word stream if the arithmetic state<br>
- was not set, as in the other call of the same function.<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-08-11 16:17:45 +0000
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea866acb21033fd3cfe345352852ea1202ce2e32">ea866acb21033fd3cfe345352852ea1202ce2e32</a>
-<blockquote>
-<p>
- Fix bug # 691532. Do not attempt to clone an image that does not exist, each completed page should have an associated image. We'd like to handle this corrupt file with a better fix, for example the absence of an end page segement is clearly a problem with respect to the specification, but Adobe and Artifex have chosen to support other &quot;off spec&quot; streams so more subtle and less obvious error checking is needed. Thanks to Tim Waugh for analysis on this problem.<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@11622 a1074d23-0009-0410-80fe-cf8c14f379e6<br>
-<br>
-jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-07-30 11:03:27 +0000
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ca94f2ac3ab6cdbb6a36a72cae385afb4f25d4e8">ca94f2ac3ab6cdbb6a36a72cae385afb4f25d4e8</a>
-<blockquote>
-<p>
- On Tru64 the integer types are in inttypes.h and not in stdint.h as in VMS<br>
-<br>
- Bug 691463, required for jbig2dec.<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@11563 a1074d23-0009-0410-80fe-cf8c14f379e6<br>
-<br>
-os_types.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-07-20 09:46:34 +0000
-</strong>
-<br>masaki &lt;masaki@a1074d23-0009-0410-80fe-cf8c14f379e6&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c29b63557cb191f2b9371a06a73a11bc4b8f5544">c29b63557cb191f2b9371a06a73a11bc4b8f5544</a>
-<blockquote>
-<p>
- Add support for user defined huffman table.<br>
-<br>
- This code adds support for segment type 53 segments, which supplies<br>
- inline huffman code table. Bug 689853.<br>
-<br>
- Many thanks to Justin Greer.<br>
-<br>
- git-svn-id: svn+ssh://svn.ghostscript.com/svn/ghostscript/trunk/gs/jbig2dec@11526 a1074d23-0009-0410-80fe-cf8c14f379e6<br>
- (cherry picked from commit e51f8e400e4502d7a6d60ee31890a195f55d1b64)<br>
-<br>
- Signed-off-by: Masaki Ushizaka &lt;masaki@ghostscript.com&gt;<br>
-<br>
-jbig2_huffman.c<br>
-jbig2_huffman.h<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-07-20 08:01:29 +0000
-</strong>
-<br>Masaki Ushizaka &lt;masaki@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d26c7e4f39f76fe70cc61d6dc14d05a042a9be48">d26c7e4f39f76fe70cc61d6dc14d05a042a9be48</a>
-<blockquote>
-<p>
- Fix jbig2_image_set_pixel function prototype<br>
-<br>
- The declaration of jbig2_image_set_pixel was differenct between<br>
- jbig2_image.h and jbig2_image.c (int value vs bool value). And<br>
- prevented compiling it by MSVC comiler in C++ mode.<br>
- This patch fixes it. Bug #691461.<br>
-<br>
-jbig2_image.h<br>
-jbig2_image_pbm.c<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-07-16 09:13:41 +0000
-</strong>
-<br>Masaki Ushizaka &lt;masaki@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c5d61c78c0de785b74b86d4e5298e3cc7b9e2b68">c5d61c78c0de785b74b86d4e5298e3cc7b9e2b68</a>
-<blockquote>
-<p>
- A little fix to allocating memory size<br>
-<br>
-jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-07-15 00:49:09 +0200
-</strong>
-<br>Tor Andersson &lt;tor.andersson@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e12fa07da845515911db8be2f7cfa8ef551061ba">e12fa07da845515911db8be2f7cfa8ef551061ba</a>
-<blockquote>
-<p>
- Use the jbig2_new and jbig2_renew macros instead of calling<br>
- jbig2_alloc and jbig2_realloc directly. Also adds a few typecasts<br>
- and #defines required to compile the source as C++.<br>
-<br>
-jbig2.c<br>
-jbig2_arith.c<br>
-jbig2_arith_iaid.c<br>
-jbig2_generic.c<br>
-jbig2_halftone.c<br>
-jbig2_huffman.c<br>
-jbig2_image.c<br>
-jbig2_metadata.c<br>
-jbig2_page.c<br>
-jbig2_priv.h<br>
-jbig2_refinement.c<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-07-15 00:42:38 +0200
-</strong>
-<br>Tor Andersson &lt;tor.andersson@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=31dd7ef66dbd1c34df08365aa3c36e6391617f37">31dd7ef66dbd1c34df08365aa3c36e6391617f37</a>
-<blockquote>
-<p>
- Update VERSION define in config_win32.h<br>
-<br>
-config_win32.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-07-15 00:41:46 +0200
-</strong>
-<br>Tor Andersson &lt;tor.andersson@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=941b73315a166fe07e0f1a1b81171477285280f7">941b73315a166fe07e0f1a1b81171477285280f7</a>
-<blockquote>
-<p>
- Add Makefile.unix -- a simple makefile for unix-like systems.<br>
-<br>
-Makefile.unix<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-07-15 00:35:58 +0200
-</strong>
-<br>Tor Andersson &lt;tor.andersson@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6066822041bbffd7169fd4bfc19c48daae8f155">f6066822041bbffd7169fd4bfc19c48daae8f155</a>
-<blockquote>
-<p>
- Fix memory leak of the word stream struct.<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-06-22 06:12:54 +0000
-</strong>
-<br>masaki &lt;masaki@a1074d23-0009-0410-80fe-cf8c14f379e6&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad707fba426702631466973e6e80c48d16398b88">ad707fba426702631466973e6e80c48d16398b88</a>
-<blockquote>
-<p>
- Fix for bug 689836 and 691248.<br>
-<br>
- Bug 689836 - Huffman tables with only positive values are decoded incorrectly<br>
- Bug 691248 - jbig2dec doesn't handle 042_11 (Huffman Symbol Region)<br>
-<br>
- This patch fixes mulfunctions seen on standard huffman table K, L, M and N.<br>
- A difference will be seen on tests_private/comparefiles/Bug690360.pdf.<br>
- This file was affected by table K mulfunction and this is a improvement.<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/ghostscript/trunk/gs/jbig2dec/@11415 a1074d23-0009-0410-80fe-cf8c14f379e6<br>
- (cherry picked from commit d59bf48fcaefb0cb531d90cb748c173198a10f54)<br>
-<br>
- Signed-off-by: Masaki Ushizaka &lt;masaki@ghostscript.com&gt;<br>
-<br>
-jbig2_hufftab.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-06-22 05:59:23 +0000
-</strong>
-<br>masaki &lt;masaki@a1074d23-0009-0410-80fe-cf8c14f379e6&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=606ce11fc930769a5bdf920a5902c158be8b3d5f">606ce11fc930769a5bdf920a5902c158be8b3d5f</a>
-<blockquote>
-<p>
- Added test code for every line of each standard huffman tables.<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/ghostscript/trunk/gs/jbig2dec/@11413 a1074d23-0009-0410-80fe-cf8c14f379e6<br>
- (cherry picked from commit aae02dab94f439a69744f4686c81d5633c8816a6)<br>
-<br>
- Signed-off-by: Masaki Ushizaka &lt;masaki@ghostscript.com&gt;<br>
-<br>
-jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-05-15 06:27:41 +0000
-</strong>
-<br>hintak &lt;hintak@a1074d23-0009-0410-80fe-cf8c14f379e6&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a54c8df662d4ab88afef6fcaa6c324030224d77d">a54c8df662d4ab88afef6fcaa6c324030224d77d</a>
-<blockquote>
-<p>
- try to make 'make -f base/unix-gcc.mak so' work<br>
-<br>
- When not run through ./configure, HAVE_CONFIG_H isn't defined and<br>
- the jbig2 codes drop through to generic unknown unix platform - so we put some<br>
- generic unix values here.<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/ghostscript/trunk/gs/jbig2dec/@11254 a1074d23-0009-0410-80fe-cf8c14f379e6<br>
- (cherry picked from commit 27d16d20f97555d2874d9f04b374053ccd0731b7)<br>
-<br>
- Signed-off-by: Masaki Ushizaka &lt;masaki@ghostscript.com&gt;<br>
-<br>
-os_types.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-05-14 04:18:42 +0000
-</strong>
-<br>hintak &lt;hintak@a1074d23-0009-0410-80fe-cf8c14f379e6&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6ef4989dcc7b51c9e8565258aa2a8a63e43d6b35">6ef4989dcc7b51c9e8565258aa2a8a63e43d6b35</a>
-<blockquote>
-<p>
- uint8_t type located in usual header on HP-UX needed for jbig2dec ; bug 688184<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/ghostscript/trunk/gs/jbig2dec/@11238 a1074d23-0009-0410-80fe-cf8c14f379e6<br>
- (cherry picked from commit 15d65a1fded828b25ca20886cd3ca8bb7522a96f)<br>
-<br>
- Signed-off-by: Masaki Ushizaka &lt;masaki@ghostscript.com&gt;<br>
-<br>
-os_types.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-04-21 07:20:14 +0000
-</strong>
-<br>masaki &lt;masaki@a1074d23-0009-0410-80fe-cf8c14f379e6&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f51764fe4b4b31733ac1dc5c3d103106b9594c8d">f51764fe4b4b31733ac1dc5c3d103106b9594c8d</a>
-<blockquote>
-<p>
- A fix for a regression introduced by r11074 (bug 690094).<br>
-<br>
- As I changed image number to be incremented when 'exflag' is false,<br>
- the problem of 'exrunlength' when SDHUFF == 1 was unveiled.<br>
- This fixes it.<br>
- JBIG2 images with SDHUFF == 1 should have been having trouble<br>
- between r11074 and this revision. No other difference expected.<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/ghostscript/trunk/gs/jbig2dec/@11093 a1074d23-0009-0410-80fe-cf8c14f379e6<br>
- (cherry picked from commit 44b9be2b31622c91b8cb3e4acc6160269630d838)<br>
-<br>
- Signed-off-by: Masaki Ushizaka &lt;masaki@ghostscript.com&gt;<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-04-15 09:53:33 +0000
-</strong>
-<br>masaki &lt;masaki@a1074d23-0009-0410-80fe-cf8c14f379e6&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=342ea4778d0ab98d8aabbaf62c2866afb804359d">342ea4778d0ab98d8aabbaf62c2866afb804359d</a>
-<blockquote>
-<p>
- A fix for 690094, &quot;missing letters replaced by little vertical lines&quot;.<br>
-<br>
- This problem was in jbig2dec function jbig2_decode_symbol_dict().<br>
- The image number was not incremented correctly when it built<br>
- symbol dictionary.<br>
- No difference expected, other than JBIG2 pdf files suffered by<br>
- this problem.<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/ghostscript/trunk/gs/jbig2dec/@11074 a1074d23-0009-0410-80fe-cf8c14f379e6<br>
- (cherry picked from commit 75a5fa486571d0a9696976c290960f1bfdc7191b)<br>
-<br>
- Signed-off-by: Masaki Ushizaka &lt;masaki@ghostscript.com&gt;<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-04-14 02:31:58 +0000
-</strong>
-<br>masaki &lt;masaki@a1074d23-0009-0410-80fe-cf8c14f379e6&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb629c8ff915730ff737ca6e4d564cc88ddafb22">eb629c8ff915730ff737ca6e4d564cc88ddafb22</a>
-<blockquote>
-<p>
- Fixed jbig2dec command getopt() parameter for -v option.<br>
-<br>
- Not used by ghostscript itself but worth for standalone debugging.<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/ghostscript/trunk/gs/jbig2dec/@11067 a1074d23-0009-0410-80fe-cf8c14f379e6<br>
- (cherry picked from commit c72d87c7d7b32f0d33d5e5b9e72aca701dd80e01)<br>
-<br>
- Signed-off-by: Masaki Ushizaka &lt;masaki@ghostscript.com&gt;<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-04-14 02:26:16 +0000
-</strong>
-<br>masaki &lt;masaki@a1074d23-0009-0410-80fe-cf8c14f379e6&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1ddf3c7a00c9f216f9a0bbd1285376c1e121dec">b1ddf3c7a00c9f216f9a0bbd1285376c1e121dec</a>
-<blockquote>
-<p>
- Fixed an indent. No influence on code.<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/ghostscript/trunk/gs/jbig2dec/@11066 a1074d23-0009-0410-80fe-cf8c14f379e6<br>
- (cherry picked from commit a6717367dee7a863788d74522e5ace5b548d80e1)<br>
-<br>
- Signed-off-by: Masaki Ushizaka &lt;masaki@ghostscript.com&gt;<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-04-13 09:50:08 +0000
-</strong>
-<br>masaki &lt;masaki@a1074d23-0009-0410-80fe-cf8c14f379e6&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f901b18ac90d291b98a1463e92f8d26c6f320c3e">f901b18ac90d291b98a1463e92f8d26c6f320c3e</a>
-<blockquote>
-<p>
- A fix for 691081, 691206, and part of 690094.<br>
-<br>
- From r9769, jbig2dec wasn't capable of decoding some JBIG2 files<br>
- and throwing a error &quot;jbig2dec FATAL ERROR runlength too large in<br>
- export symbol table (XXX &gt; XX - XX) (segment 0xXX)&quot;.<br>
- This was caused by accidentaly bound checking export symbol table<br>
- size with number of non-export symbol. This fixes it.<br>
- No differences expected, other than JBIG2 files suffered from this<br>
- problem.<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/ghostscript/trunk/gs/jbig2dec/@11057 a1074d23-0009-0410-80fe-cf8c14f379e6<br>
- (cherry picked from commit e2c24fec806a2a84427ecfff9a9bbd078ca460bd)<br>
-<br>
- Signed-off-by: Masaki Ushizaka &lt;masaki@ghostscript.com&gt;<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-02-02 11:09:54 -0800
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=58b513e3ec60feac13ea429c4aff12ea8a8de91d">58b513e3ec60feac13ea429c4aff12ea8a8de91d</a>
-<blockquote>
-<p>
- Bump versioning for the 0.11 release.<br>
-<br>
- The libtool shared library versioning starts with this release.<br>
-<br>
-CHANGES<br>
-configure.ac<br>
-jbig2dec-0.11/CHANGES<br>
-jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-02-02 11:03:37 -0800
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa1bd62f45b780d5c8cbadaf66a25b03688590c5">fa1bd62f45b780d5c8cbadaf66a25b03688590c5</a>
-<blockquote>
-<p>
- The inclusion of JBIG2 in PDF 1.4 is no longer new news.<br>
-<br>
-README<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-02-02 11:03:05 -0800
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da42a22f05eb8af12a797c12bee3e5c121fe2842">da42a22f05eb8af12a797c12bee3e5c121fe2842</a>
-<blockquote>
-<p>
- Correct a whitespace formatting issue in the usage text.<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-02-02 11:01:42 -0800
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd0c94f5c32a01ff8b7d502071495ba475fe8f8a">dd0c94f5c32a01ff8b7d502071495ba475fe8f8a</a>
-<blockquote>
-<p>
- Fix a manpage grammar error.<br>
-<br>
-jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2010-02-02 11:01:10 -0800
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=373b4606ef4b573e855b6be78fabd2496112da3b">373b4606ef4b573e855b6be78fabd2496112da3b</a>
-<blockquote>
-<p>
- Update change log for the 0.11 release.<br>
-<br>
-CHANGES<br>
-jbig2dec-0.11/CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-11-23 16:49:06 -0800
-</strong>
-<br>Ralph Giles &lt;giles@cirrus.local&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a841c2481b35b7bf1bf5970a11ac750ff3a3ee2c">a841c2481b35b7bf1bf5970a11ac750ff3a3ee2c</a>
-<blockquote>
-<p>
- Implement generic region decode with typical prediction.<br>
-<br>
- Patch from Gorac. Ghostscript bugs 690791 and 690913.<br>
-<br>
-jbig2_generic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-11-20 09:46:39 -0800
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad742b847dbb39b1376664d77fae0f8b31ae65f0">ad742b847dbb39b1376664d77fae0f8b31ae65f0</a>
-<blockquote>
-<p>
- Skip generic regions using TPGDON and issue a warning.<br>
-<br>
- We don't yet implement this, and discarding the data is better than<br>
- proceeding with the incorrect decoding proceedures, which generally<br>
- just produce noise. Ghostscript bug 690791.<br>
-<br>
-jbig2_generic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-11-16 11:17:51 -0800
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fd7cb7fa6152573ab11ebfbce45582fa1652f117">fd7cb7fa6152573ab11ebfbce45582fa1652f117</a>
-<blockquote>
-<p>
- Correct bitmap offsets when setting transposed text.<br>
-<br>
- Previously, the code was switching width and height, not just S and T<br>
- coordinates. We now properly decode the 042_19.jb2 test file.<br>
-<br>
- Thanks to Drugo Pedrouvene for pointing out the issue. Bug 690923.<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-10-29 22:00:35 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dcf0bd8c4288ff30d152b3741bc78c9fa055e49c">dcf0bd8c4288ff30d152b3741bc78c9fa055e49c</a>
-<blockquote>
-<p>
- Make -v print only info-level messages by default.<br>
-<br>
- Previously -v set the verbosity level to 9. Anything 3 or greater<br>
- prints all debug messages, which can be quite overwhelming when<br>
- individual decode elements are traced. Now the default with -v is 2.<br>
-<br>
- Run jbig2dec --verbose=3 to recover the old behaviour.<br>
-<br>
-jbig2dec.1<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-10-29 21:59:47 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c1fddcf71a0cd81c02f7b52b757ea20c05f4292a">c1fddcf71a0cd81c02f7b52b757ea20c05f4292a</a>
-<blockquote>
-<p>
- Improve grammar in the usage message.<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-10-29 21:49:49 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cf7917e8948a9296cd6bfdb0a1615287b88b769f">cf7917e8948a9296cd6bfdb0a1615287b88b769f</a>
-<blockquote>
-<p>
- Fix comment formatting.<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-10-29 21:19:54 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7018021f8232f62ff9c6822092405dd0467abb09">7018021f8232f62ff9c6822092405dd0467abb09</a>
-<blockquote>
-<p>
- Update the COPYING file to the text of the GPLv3.<br>
-<br>
- The jbig2dec package is still licensed GPLv2 or later, but we want<br>
- to encourage use under the GPLv3.<br>
-<br>
-COPYING<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-10-29 16:52:50 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f8e18fdeb01cdbd9530804077beed6cac38ef077">f8e18fdeb01cdbd9530804077beed6cac38ef077</a>
-<blockquote>
-<p>
- Have the scons build automatically determine the version string.<br>
-<br>
- SConstruct tries to call 'git describe --tags' which produces a version<br>
- string based on the most recent tag, with the number of commits and<br>
- current commit hash appended if HEAD isn't a tagged revision.<br>
-<br>
- If that command fails (i.e. building from a release tarball or another<br>
- version control system) it attempts to read the CHANGES file and uses<br>
- the first version number there.<br>
-<br>
-SConstruct<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-10-29 16:29:04 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f34a521eba46e811287fb4f35519fc32f0b6d4e8">f34a521eba46e811287fb4f35519fc32f0b6d4e8</a>
-<blockquote>
-<p>
- Update the version number in the scons build description.<br>
-<br>
-SConstruct<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-10-29 16:04:42 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=077b6518dffc75dc74fc5e6990c8529f44cb47a0">077b6518dffc75dc74fc5e6990c8529f44cb47a0</a>
-<blockquote>
-<p>
- Remove the include of ~/.jamrules.<br>
-<br>
- This was part of Tor's original commit, and was intended to set some<br>
- common default options among projects. However, it generates a warning<br>
- when the file is not available, and we now set thing like optimization<br>
- level and warning flags directly.<br>
-<br>
-Jamfile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-10-29 15:59:57 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bba07df1f607891f15bec1f1ace673f23d8360e2">bba07df1f607891f15bec1f1ace673f23d8360e2</a>
-<blockquote>
-<p>
- The jam build no longer requires a config.h.<br>
-<br>
- Instead it sets the needed defines itself.<br>
-<br>
-Jamfile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-10-28 13:45:00 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fe50e6202700ad508c7f91e04330a962970ead5f">fe50e6202700ad508c7f91e04330a962970ead5f</a>
-<blockquote>
-<p>
- Remove _parse_ from the segment decode routines.<br>
-<br>
- Our use wasn't consistent here; some decoders were jbig2_foo() and<br>
- others were jbig2_parse_bar(). Prefer the shorter names and keep<br>
- _parse_ only for the header and dispatch routines which don't themselves<br>
- decode the segment bodies.<br>
-<br>
-jbig2_metadata.c<br>
-jbig2_metadata.h<br>
-jbig2_page.c<br>
-jbig2_priv.h<br>
-jbig2_segment.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-10-28 12:22:40 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d2849e9e31de7cb3a921f9c69a9a4ecfd06feb02">d2849e9e31de7cb3a921f9c69a9a4ecfd06feb02</a>
-<blockquote>
-<p>
- Remove an unused variable.<br>
-<br>
-jbig2_halftone.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-10-28 12:19:57 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b108cbcfc9a2c7d10e70bd2bdc3a3a938ea3adb7">b108cbcfc9a2c7d10e70bd2bdc3a3a938ea3adb7</a>
-<blockquote>
-<p>
- Add prototypes for the publicly referenced halftone functions.<br>
-<br>
- Corrects a missing prototype warning.<br>
-<br>
-jbig2_priv.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-10-28 12:07:19 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=47bd82353ae27eb2c53e7253c39b70ef2e147ab2">47bd82353ae27eb2c53e7253c39b70ef2e147ab2</a>
-<blockquote>
-<p>
- Build optimized with debugging symbols and all warnings under jam.<br>
-<br>
- Previously we used the default rules which are just 'cc'. This aligns<br>
- the behaviour with the other builds and lets of take advantage of jam's<br>
- cleaner output to see warnings more easily.<br>
-<br>
-Jamfile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-07-24 16:33:01 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20e5cd8ca494d3e715bcc38701cfd5923225415d">20e5cd8ca494d3e715bcc38701cfd5923225415d</a>
-<blockquote>
-<p>
- Fix a typo in a debug statement.<br>
-<br>
-jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-07-16 01:52:01 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b76f84cbe3982b71357c727c208401d6645ecad3">b76f84cbe3982b71357c727c208401d6645ecad3</a>
-<blockquote>
-<p>
- Clone and release the page images returned to the client.<br>
-<br>
-jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-07-16 01:32:29 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=70a3ad1514050d5babcc18fb1bd327db1cfbfdc8">70a3ad1514050d5babcc18fb1bd327db1cfbfdc8</a>
-<blockquote>
-<p>
- Remove a specious comment.<br>
-<br>
- Originally I thought we might need to access pages in random order,<br>
- but I don't think this is necessary.<br>
-<br>
-jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-07-16 01:56:34 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=56d7948b4d9f3825a20f0cb6cc26a0a3b6ae34f1">56d7948b4d9f3825a20f0cb6cc26a0a3b6ae34f1</a>
-<blockquote>
-<p>
- Check more return codes from jbig2_image_new().<br>
-<br>
- There are still a number of unchecked instances in jbig2_symbol_dict.<br>
-<br>
-jbig2_generic.c<br>
-jbig2_halftone.c<br>
-jbig2_page.c<br>
-jbig2_refinement.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-07-15 22:28:42 -0700
-</strong>
-<br>Ralph Giles &lt;giles@snow.ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=19dabb532ae37749fdb6c06447e2dfcf0e216e9b">19dabb532ae37749fdb6c06447e2dfcf0e216e9b</a>
-<blockquote>
-<p>
- Check for NULL before freeing metadata or symbol segment results.<br>
-<br>
- This protects against segfault during early termination.<br>
-<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-07-15 22:28:03 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e9e3314b4264e547ce9372b4bcd2f20c50b5357">2e9e3314b4264e547ce9372b4bcd2f20c50b5357</a>
-<blockquote>
-<p>
- Document that jbig2_data_in() can return -1 on fatal errors.<br>
-<br>
-jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-07-15 22:11:21 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f96255c8451e2d07406e2bd5f513f1d0aec34f29">f96255c8451e2d07406e2bd5f513f1d0aec34f29</a>
-<blockquote>
-<p>
- Check the return code from jbig2_data_in().<br>
-<br>
- This avoids printing multiple 'Not a JBIG2 file header' errors on<br>
- corrupt or invalid files.<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-06-17 13:01:40 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1fde432da43cbe5bc34f3a95ee5d2f2466090e52">1fde432da43cbe5bc34f3a95ee5d2f2466090e52</a>
-<blockquote>
-<p>
- Add the jbig2dec manpage to the automake install and dist targets.<br>
-<br>
-Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-06-17 12:29:38 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ff59dbf7c7302a1a55768e0cdcbcdd4661b0b77c">ff59dbf7c7302a1a55768e0cdcbcdd4661b0b77c</a>
-<blockquote>
-<p>
- Manpage updates.<br>
-<br>
- List the file.jbig2 and the embedded global+page stream pair<br>
- invocations separately, since they are exclusive.<br>
-<br>
- Give a more complete description and elaborate on some of the options.<br>
-<br>
- Use dot-macros instead of backslash commands for most of the formatting.<br>
- This isn't any less confusing because of the need to use double quotes<br>
- to enforce whitespace when alternating styles, but I still find it<br>
- more reasonable.<br>
-<br>
- Fix a couple of spelling errors.<br>
-<br>
-jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-06-17 12:26:10 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e11f98fa775d99a531f18f5f4bffc754a205ce8f">e11f98fa775d99a531f18f5f4bffc754a205ce8f</a>
-<blockquote>
-<p>
- Add a manpage for the jbig2dec example client.<br>
-<br>
- Contributed by Sebastian Rassmussen.<br>
-<br>
-jbig2dec.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-06-12 17:16:00 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e20020b1bd4fae157236fc9716cafa17481e3171">e20020b1bd4fae157236fc9716cafa17481e3171</a>
-<blockquote>
-<p>
- Build a shared library with GNU libtool.<br>
-<br>
- Previously we used autoconf and automake, but just build a static<br>
- library. This commit checks for libtoolize in autogen.sh and adds<br>
- support for libtool to the configure.an and Makefile.am scripts.<br>
-<br>
- We use this to build both static and dynamic versions of the jbig2dec<br>
- library, including soname versioning for the later.<br>
-<br>
- Based on a patch by Sebastian Rasmussen.<br>
-<br>
-Makefile.am<br>
-autogen.sh<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-05-29 07:25:13 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ae432288a105122d92f490d2d9cf212dae8aab4">5ae432288a105122d92f490d2d9cf212dae8aab4</a>
-<blockquote>
-<p>
- Initialize the pattern dict data offset to zero before first use.<br>
-<br>
- Warning flagged by Coverity.<br>
-<br>
-jbig2_halftone.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-05-28 23:20:21 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=37e002db7ffce8121bd060c86fd9f0609879e99b">37e002db7ffce8121bd060c86fd9f0609879e99b</a>
-<blockquote>
-<p>
- Bump version after the 0.10 release.<br>
-<br>
-CHANGES<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-05-28 21:49:29 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d287050828a5878bb61e6971220d25674bae77e">0d287050828a5878bb61e6971220d25674bae77e</a>
-<blockquote>
-<p>
- Set release date and package version for the 0.10 release.<br>
-<br>
-CHANGES<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-05-28 21:11:06 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=29d7c56e2aea052d51f33820a3f68f4e4a636c08">29d7c56e2aea052d51f33820a3f68f4e4a636c08</a>
-<blockquote>
-<p>
- Add some missing files to the automake build for distribution.<br>
-<br>
-Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-05-28 20:39:36 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=95e63680521ba68e3c21ca1e2bf9fee3a2c1958d">95e63680521ba68e3c21ca1e2bf9fee3a2c1958d</a>
-<blockquote>
-<p>
- Update changes with major points since the last release.<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-04-01 15:52:17 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e62b3968d0d897bb9a24ba7f75504f476e33ba6">4e62b3968d0d897bb9a24ba7f75504f476e33ba6</a>
-<blockquote>
-<p>
- Bounds check exported symbol run-lengths. CVE-2009-0196.<br>
-<br>
- The final symbol dictionary is built from a combination of symbols<br>
- from referenced dictionaries and new symbols coded in the current<br>
- segment. Because the symbols can be composed and refined, not all<br>
- coded symbols are necessarily exported.<br>
-<br>
- The list of symbols to export from those constructed by the decoding<br>
- process is coded as a series of on/off run-lengths. Previously we<br>
- accepted the value read as the run-length, even though this could<br>
- result in writing off the end of the exported symbol array. This<br>
- commit checks the read value against the number of elements remaining<br>
- in the export array and throws a fatal error if there is an overflow.<br>
-<br>
- Thanks for Alin Rad Pop of Secunia Research for pointing out the issue.<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-05-22 23:21:48 +0200
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=86e0b052dc32de4e0f9a3cbc7dbf27211a2b3182">86e0b052dc32de4e0f9a3cbc7dbf27211a2b3182</a>
-<blockquote>
-<p>
- Fix the jam build to work without config.h.<br>
-<br>
- Previously, the Jamfile assumed a config.h had be created, usually by<br>
- running the configure script, but possibly also created manually. This<br>
- is extra work for those wanting a quick build. Therefore we pass some<br>
- defines on the compiler command line instead.<br>
-<br>
- These are also likely to be wrong: we assume libpng is available on<br>
- all non-windows platforms. It's an incremental improvement, however,<br>
- and actual build-time configuration based on detected resources is<br>
- difficult in Jam.<br>
-<br>
-Jamfile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-05-22 23:14:33 +0200
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e6b447d8bddabc0acd5834fa493110b1bb3e9c7">8e6b447d8bddabc0acd5834fa493110b1bb3e9c7</a>
-<blockquote>
-<p>
- Provide fallbacks in jbig2dec.c if PACKAGE and VERSION aren't defined.<br>
-<br>
- Normally, the configure script defines PACKAGE and VERSION, based on<br>
- its initializers. However, config.h is in fact optional, so we shouldn't<br>
- assume these are set. Since we use these to implement the command<br>
- 'jbig2dec --version', we provide fallbacks in the source file to<br>
- simplify compiling outside the autotools build.<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-04-16 00:08:49 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c7c73d634dda170455d3cd7a1ef08a038e63cbb">3c7c73d634dda170455d3cd7a1ef08a038e63cbb</a>
-<blockquote>
-<p>
- Add a missing include in the halftone code.<br>
-<br>
- jbig2_decode_pattern_dict() calls jbig2_decode_generic_mmr() but<br>
- wasn't including jbig2_mmr.h which declares that function.<br>
-<br>
- Fixes a compiler warning on gcc and clang.<br>
-<br>
-jbig2_halftone.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-04-15 19:26:39 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1a03359b9f267714f60662dc021eef4054ae202">d1a03359b9f267714f60662dc021eef4054ae202</a>
-<blockquote>
-<p>
- Check the return value of sscanf when parsing pbm dimensions.<br>
-<br>
- This is a follow-on to the previous commit. It shouldn't be<br>
- possible to reach the sscanf with less than one digit in the<br>
- parse buffer, but we abort anyway in case sscanf can't find<br>
- anything. If the code could proceed from that point with an<br>
- uninitialized value in the dim array the call to jbig2_image_new()<br>
- could request excessive resources.<br>
-<br>
-jbig2_image_pbm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-04-15 18:41:10 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83c67854e5e0fd06045bd5e8fc53f98e1ddb9b76">83c67854e5e0fd06045bd5e8fc53f98e1ddb9b76</a>
-<blockquote>
-<p>
- Move an eof check out of a while loop where it was never called.<br>
-<br>
- This section was flagged by coverity. Not because the eof check was<br>
- never executed, but because of casting away the possible EOF return<br>
- value of fgetc() inside the while condition. The isdigit() call would<br>
- still terminate the while on eof, and the worst that would happen<br>
- is that the allocated image would be smaller than intended and the<br>
- eof would be caught after trying to read the data, so this was not<br>
- a serious issue.<br>
-<br>
- This commit removes the meaningless eof check inside the digit-copying<br>
- while loop and adds a specific check before. It also avoids copying the<br>
- first non-digit character to the parse buffer, which should resolve the<br>
- coverity warning.<br>
-<br>
-jbig2_image_pbm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-04-01 17:40:01 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b525fc5d325e559dae1f9fb7d3956b8407df3d5">9b525fc5d325e559dae1f9fb7d3956b8407df3d5</a>
-<blockquote>
-<p>
- Ask git to ignore normal build products.<br>
-<br>
-.gitignore<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-04-01 17:38:47 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da580ddc6398b1818fc20036b79a89a7856b0296">da580ddc6398b1818fc20036b79a89a7856b0296</a>
-<blockquote>
-<p>
- Correct a typo in a debug message.<br>
-<br>
-jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-04-01 17:38:19 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c0c36828c7ded70a82bb65affd3cf10ef7ddc5ea">c0c36828c7ded70a82bb65affd3cf10ef7ddc5ea</a>
-<blockquote>
-<p>
- Remove a debug printout.<br>
-<br>
- This was added in f1d00697, but isn't necessary beyond the initial<br>
- testing prior to that commit.<br>
-<br>
-jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-03-31 21:35:17 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=76b6b9ec30859f32293286b3837f17a8252d010c">76b6b9ec30859f32293286b3837f17a8252d010c</a>
-<blockquote>
-<p>
- Close the output pbm file after writing to it.<br>
-<br>
- Resource leak reported by Coverity.<br>
-<br>
-jbig2_image_pbm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-03-31 21:32:38 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ceb71749c865a4a4cd4c5a6ed0b052dff533a76c">ceb71749c865a4a4cd4c5a6ed0b052dff533a76c</a>
-<blockquote>
-<p>
- Rename a local variable to avoid shadowing a function argument.<br>
-<br>
- The code was correct, but confusing. Resolves a Coverity warning.<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-03-31 21:29:09 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fdefccb83e29b399d3c3935ed2ada533fb57bdd0">fdefccb83e29b399d3c3935ed2ada533fb57bdd0</a>
-<blockquote>
-<p>
- Remove unnecessary header includes.<br>
-<br>
-jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-03-31 21:24:16 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=261eb20b93e2fa36f34748be10232160955719cd">261eb20b93e2fa36f34748be10232160955719cd</a>
-<blockquote>
-<p>
- Remove an unnecessary header include.<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-03-30 18:35:21 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f1d00697525dd2d7a5f63f96e01ad0d99e673b13">f1d00697525dd2d7a5f63f96e01ad0d99e673b13</a>
-<blockquote>
-<p>
- Restore the proper size of the huffman symbol length histogram.<br>
-<br>
- The previous size as 256 KB, but LENCOUNT's highest index is PREFLEN<br>
- (or LENMAX - 1, but LENMAX is the largest value of PREFLEN) and that<br>
- comes from a byte member of a Jbig2HuffmanEntry. Therefore 256 members<br>
- are all that is necessary, or 1 KB on most machines.<br>
-<br>
- This was changed in commit a0531af8 (jbig2dec svn c430) apparently in<br>
- the mistaken belief that it needed to scale with the size of the table<br>
- itself. In that revision the previous stack allocation of 256 elements<br>
- was replaced with the 1k, which later became 64k, generally overflowing<br>
- the stack. While 256 elements is a reasonable stack allocation, it's<br>
- safer to continue using the heap.<br>
-<br>
-jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-03-30 18:17:55 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=63e0436a711c59f7fae6cfd721b90428ae19a7b3">63e0436a711c59f7fae6cfd721b90428ae19a7b3</a>
-<blockquote>
-<p>
- Dynamically allocate and initialize the huffman symbol length histogram.<br>
-<br>
- Previously we allocated it on the stack, but it's quite large (256K)<br>
- and we were assuming it was initialized to zero. Issue flagged by<br>
- Coverity.<br>
-<br>
-jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-03-30 18:00:39 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=45f462f813cfef6be8f6755ebe02e8744222b3b1">45f462f813cfef6be8f6755ebe02e8744222b3b1</a>
-<blockquote>
-<p>
- Initialize Jbig2TextRegionParams.sbrat even when it is not used.<br>
-<br>
- This avoids valgrind warnings in a later debug message which<br>
- unconditionally prints them out. After a patch by Alex Cherepanov,<br>
- ghostscript svn commit 9578.<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-03-30 17:45:50 -0700
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e2e186837bedf8211405c14b75c54849241193cd">e2e186837bedf8211405c14b75c54849241193cd</a>
-<blockquote>
-<p>
- Only define vnsprintf on MSVC versions prior to 9.<br>
-<br>
- Visual Studio 2008 defines vnsprintf() in its stdio.h and our mapping<br>
- from _vnsprintf() conflicts. After a patch by Michael Vrhel, ghostscript<br>
- svn commits 8734 and 8735.<br>
-<br>
-config_win32.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-02-27 00:09:03 -0800
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aaed7c2e751f82d585f9b4d94601b48bfd196b6f">aaed7c2e751f82d585f9b4d94601b48bfd196b6f</a>
-<blockquote>
-<p>
- Protect refinement debug image dumps from the normal debug build.<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-02-26 23:53:08 -0800
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5f76927a09fc65adff87042eb0667ded96fef537">5f76927a09fc65adff87042eb0667ded96fef537</a>
-<blockquote>
-<p>
- Add the (unfinished) halftone source to the Jam build.<br>
-<br>
-Jamfile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-02-26 23:46:59 -0800
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d45e847d00a560fcd9a4ae917cda83a6dbf1686">4d45e847d00a560fcd9a4ae917cda83a6dbf1686</a>
-<blockquote>
-<p>
- Update the contact address in the file headers.<br>
-<br>
-config_win32.h<br>
-jbig2.c<br>
-jbig2.h<br>
-jbig2_arith.c<br>
-jbig2_arith.h<br>
-jbig2_arith_iaid.c<br>
-jbig2_arith_iaid.h<br>
-jbig2_arith_int.c<br>
-jbig2_arith_int.h<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-jbig2_halftone.c<br>
-jbig2_huffman.c<br>
-jbig2_huffman.h<br>
-jbig2_hufftab.h<br>
-jbig2_image.c<br>
-jbig2_image.h<br>
-jbig2_image_pbm.c<br>
-jbig2_image_png.c<br>
-jbig2_metadata.c<br>
-jbig2_metadata.h<br>
-jbig2_mmr.c<br>
-jbig2_mmr.h<br>
-jbig2_page.c<br>
-jbig2_priv.h<br>
-jbig2_refinement.c<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_symbol_dict.h<br>
-jbig2_text.c<br>
-jbig2_text.h<br>
-jbig2dec.c<br>
-memcmp.c<br>
-os_types.h<br>
-pbm2png.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-02-26 18:02:37 -0800
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d57cb4f565736e5a8473876dcd56464cd3aba70">4d57cb4f565736e5a8473876dcd56464cd3aba70</a>
-<blockquote>
-<p>
- Regularize the headers and clean up some additional whitespace.<br>
-<br>
-jbig2.c<br>
-jbig2_generic.c<br>
-jbig2_mmr.c<br>
-jbig2_priv.h<br>
-jbig2_symbol_dict.c<br>
-jbig2_symbol_dict.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-02-24 18:29:48 -0800
-</strong>
-<br>Ralph Giles &lt;giles@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=75de8111f83acd49a2eb75bed348cb4fac9f1e97">75de8111f83acd49a2eb75bed348cb4fac9f1e97</a>
-<blockquote>
-<p>
- Remove trailing whitespace.<br>
-<br>
-autogen.sh<br>
-jbig2.h<br>
-jbig2_arith.h<br>
-jbig2_arith_iaid.h<br>
-jbig2_arith_int.h<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-jbig2_huffman.h<br>
-jbig2_image.h<br>
-jbig2_image_pbm.c<br>
-jbig2_image_png.c<br>
-jbig2_metadata.h<br>
-jbig2_mmr.h<br>
-jbig2_symbol_dict.c<br>
-jbig2_symbol_dict.h<br>
-jbig2_text.c<br>
-jbig2_text.h<br>
-memcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2009-02-24 17:13:38 -0800
-</strong>
-<br>Ralph Giles &lt;giles@rain.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4db6758c0acf306c07cea834e22414d2db42b56a">4db6758c0acf306c07cea834e22414d2db42b56a</a>
-<blockquote>
-<p>
- Remove Id and other svn keyword substitution lines.<br>
-<br>
- These were sometimes helpful in backtracking from isolated source<br>
- copies to a specific revision in a centralized version control<br>
- system, but git has poor support for such things. They are also<br>
- much less necessary now that public source repositories are a<br>
- more common part of development workflows.<br>
-<br>
-Jamfile<br>
-Makefile.am<br>
-autogen.sh<br>
-config_win32.h<br>
-configure.ac<br>
-jbig2.c<br>
-jbig2.h<br>
-jbig2_arith.c<br>
-jbig2_arith.h<br>
-jbig2_arith_iaid.c<br>
-jbig2_arith_iaid.h<br>
-jbig2_arith_int.c<br>
-jbig2_arith_int.h<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-jbig2_halftone.c<br>
-jbig2_huffman.c<br>
-jbig2_huffman.h<br>
-jbig2_hufftab.h<br>
-jbig2_image.c<br>
-jbig2_image.h<br>
-jbig2_image_pbm.c<br>
-jbig2_image_png.c<br>
-jbig2_metadata.c<br>
-jbig2_metadata.h<br>
-jbig2_mmr.c<br>
-jbig2_mmr.h<br>
-jbig2_page.c<br>
-jbig2_priv.h<br>
-jbig2_refinement.c<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_symbol_dict.h<br>
-jbig2_text.c<br>
-jbig2_text.h<br>
-jbig2dec.c<br>
-memcmp.c<br>
-os_types.h<br>
-pbm2png.c<br>
-test_jbig2dec.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2008-05-26 18:52:22 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d5db893a4dfe988b1ecea14595f3c7605ee166ea">d5db893a4dfe988b1ecea14595f3c7605ee166ea</a>
-<blockquote>
-<p>
- Work around broken streams created by Xerox WorkCentre products, where<br>
- the final segment length is written as -1. Ghostscript bug 689841.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@468 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2008-05-17 00:08:26 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2dea640032a72f9756cdccd54352c10b18348f56">2dea640032a72f9756cdccd54352c10b18348f56</a>
-<blockquote>
-<p>
- More whitespace cleanup.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@467 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-config_win32.h<br>
-jbig2_arith_iaid.c<br>
-jbig2_halftone.c<br>
-jbig2_huffman.c<br>
-jbig2_hufftab.h<br>
-jbig2_metadata.c<br>
-jbig2_priv.h<br>
-jbig2dec.c<br>
-os_types.h<br>
-pbm2png.c<br>
-sha1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2008-05-16 23:58:59 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f125f9553a1e3c8088cf59df7c983aef3785641a">f125f9553a1e3c8088cf59df7c983aef3785641a</a>
-<blockquote>
-<p>
- Only check for a code length antecedent under RUNCODE32. RUNCODE33 and<br>
- RUNCODE34 specify a repeat of zero so a previous code length isn't<br>
- necessary.<br>
-<br>
- Thanks to Justin Greer for catching this. Ghostscript bug 689835.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@466 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2008-05-16 23:48:20 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c744e7207254f6719eb011a3a0b4984fdfa369dd">c744e7207254f6719eb011a3a0b4984fdfa369dd</a>
-<blockquote>
-<p>
- Clean up trailing whitespace.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@465 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-jbig2_arith.c<br>
-jbig2_arith_int.c<br>
-jbig2_generic.c<br>
-jbig2_image.c<br>
-jbig2_mmr.c<br>
-jbig2_page.c<br>
-jbig2_refinement.c<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2008-05-09 13:54:32 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e4e8acebad09764a3be793082de99bd1679ef0c0">e4e8acebad09764a3be793082de99bd1679ef0c0</a>
-<blockquote>
-<p>
- Runcodes 33 and 34 repeat a zero code length symbol id, not the previous<br>
- symbol like runcode 32.<br>
-<br>
- Thanks to Justin Greer for the fix. Ghostscript bug 689824.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@464 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2008-05-09 13:41:01 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=46555913d6ed4b5479b50f45564ed94c478af863">46555913d6ed4b5479b50f45564ed94c478af863</a>
-<blockquote>
-<p>
- Support for aggregate symbol coding, patch from Ghostscript trunk.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@463 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_refinement.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-jbig2_text.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2008-05-09 13:38:29 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e3092e1ff329e834e0e131ada149c692cff01688">e3092e1ff329e834e0e131ada149c692cff01688</a>
-<blockquote>
-<p>
- Windows build fixes. Patch from Ghostscript trunk.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@462 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-config_win32.h<br>
-msvc.mak<br>
-os_types.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2008-05-07 21:37:02 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=381e60a9cbb6b42136e67e4dd48e67cb438b5a2d">381e60a9cbb6b42136e67e4dd48e67cb438b5a2d</a>
-<blockquote>
-<p>
- Update copyright headers. Ownership has been transferred<br>
- to Artifex.<br>
-<br>
-<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@461 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-config_win32.h<br>
-jbig2.c<br>
-jbig2.h<br>
-jbig2_arith.c<br>
-jbig2_arith.h<br>
-jbig2_arith_iaid.c<br>
-jbig2_arith_iaid.h<br>
-jbig2_arith_int.c<br>
-jbig2_arith_int.h<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-jbig2_halftone.c<br>
-jbig2_huffman.c<br>
-jbig2_huffman.h<br>
-jbig2_hufftab.h<br>
-jbig2_image.c<br>
-jbig2_image.h<br>
-jbig2_image_pbm.c<br>
-jbig2_image_png.c<br>
-jbig2_metadata.c<br>
-jbig2_metadata.h<br>
-jbig2_mmr.c<br>
-jbig2_mmr.h<br>
-jbig2_page.c<br>
-jbig2_priv.h<br>
-jbig2_refinement.c<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_symbol_dict.h<br>
-jbig2_text.c<br>
-jbig2_text.h<br>
-jbig2dec.c<br>
-memcmp.c<br>
-os_types.h<br>
-pbm2png.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2008-05-07 21:30:33 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=86131c28d05eb84cbd8878c2fc6d3a6282b79cbc">86131c28d05eb84cbd8878c2fc6d3a6282b79cbc</a>
-<blockquote>
-<p>
- Set eol-style on the source files.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@460 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-config_win32.h<br>
-jbig2_arith_iaid.c<br>
-jbig2_arith_iaid.h<br>
-jbig2_arith_int.c<br>
-jbig2_arith_int.h<br>
-jbig2_image_png.c<br>
-jbig2_metadata.h<br>
-jbig2_mmr.h<br>
-pbm2png.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2007-11-09 01:13:21 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4446e2678f3bd9faa211a5d5bd50ac8f8c461a42">4446e2678f3bd9faa211a5d5bd50ac8f8c461a42</a>
-<blockquote>
-<p>
- Change the license from GPLv2 to GPLv2 or later.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@459 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-LICENSE<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2007-10-25 22:20:54 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=416c12b80383fe829edf8e986a0d5c860f8fabe6">416c12b80383fe829edf8e986a0d5c860f8fabe6</a>
-<blockquote>
-<p>
- Set appropriate ignores.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@458 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2007-10-25 22:13:42 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e2a295a921ad73b46c69bc33c67d8717b94d9b4e">e2a295a921ad73b46c69bc33c67d8717b94d9b4e</a>
-<blockquote>
-<p>
- Remove some gcc warnings.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@457 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_generic.c<br>
-jbig2_image.h<br>
-jbig2_page.c<br>
-jbig2_refinement.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2007-10-25 22:13:23 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=639e20afb817afd493b3802643f3dcf363962fce">639e20afb817afd493b3802643f3dcf363962fce</a>
-<blockquote>
-<p>
- Update autogen.sh to detect automake 1.10 and later.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@456 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-autogen.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2007-10-25 21:57:25 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6f92ef3754dff5fdf82a809662476c330b25e20c">6f92ef3754dff5fdf82a809662476c330b25e20c</a>
-<blockquote>
-<p>
- Add AM_PROG_CC_C_O as requested by automake 1.10.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@455 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2007-02-06 08:10:58 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad85e74393cfb2667ea1f15756502ea2bc3cf3d9">ad85e74393cfb2667ea1f15756502ea2bc3cf3d9</a>
-<blockquote>
-<p>
- Add a new header for declaring the public text region functions.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@454 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2007-02-05 23:42:18 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=41b78a49bf9e00d0d78532581b7e72836935f3d5">41b78a49bf9e00d0d78532581b7e72836935f3d5</a>
-<blockquote>
-<p>
- Export jbig2_decode_text_region() for use in aggregate symbol encoding<br>
- and stub out the setup for the call. Work in progress implementing<br>
- support for this function.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@453 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_refinement.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2007-02-05 22:59:10 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4cec0516180e0a8a79e88de5fbb12a28b3f64439">4cec0516180e0a8a79e88de5fbb12a28b3f64439</a>
-<blockquote>
-<p>
- Rewrite the test script to use a custom test class.<br>
-<br>
- Previously we used the python unittest module, but we don't use most of<br>
- its features, and it's quite weak for this kind of file-based external<br>
- testing. So we lose on using a familiar api, but this doesn't add much<br>
- code, and we can now add long-desired features like 'xfail' results.<br>
-<br>
- This grew out of work revising the Ghostscript test code for<br>
- parallelization.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@452 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-test_jbig2dec.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2006-07-27 00:54:08 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=94071092c25507e1dd00451f89c0e82d45f65503">94071092c25507e1dd00451f89c0e82d45f65503</a>
-<blockquote>
-<p>
- Bump version number, post release.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@449 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2006-07-26 23:57:39 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9c04190c5824e209be28d5079787c3f05b5c1b3e">9c04190c5824e209be28d5079787c3f05b5c1b3e</a>
-<blockquote>
-<p>
- Update version info for the 0.9 release.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@447 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2006-05-15 21:16:42 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3421407ecff3d48427a0a848f58a0d1affe2c44b">3421407ecff3d48427a0a848f58a0d1affe2c44b</a>
-<blockquote>
-<p>
- Correct a typo resulting in inproper glyph placement with transposed text and a top left reference corner. Fixes bug 688645.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@446 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2006-02-17 20:25:07 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34abc7a906ef9716d01ec93d74036a0be53a742c">34abc7a906ef9716d01ec93d74036a0be53a742c</a>
-<blockquote>
-<p>
- Update my email address; artofcode.com no longer works.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@445 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-sha1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-12-18 18:12:33 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3753ca9c4e9543d34f6e20c5c55eef15fc6afcf8">3753ca9c4e9543d34f6e20c5c55eef15fc6afcf8</a>
-<blockquote>
-<p>
- Correct an invalid return value. Thanks to Leonardo for pointing this<br>
- out.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@444 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-12-06 01:50:08 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d94bdb63779c6d3bfa43197c791912cb954ae109">d94bdb63779c6d3bfa43197c791912cb954ae109</a>
-<blockquote>
-<p>
- Update changelog.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@443 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-12-06 01:47:35 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a9d42d067a6cd01c9f1fd73b00ff9c69c6ba85c6">a9d42d067a6cd01c9f1fd73b00ff9c69c6ba85c6</a>
-<blockquote>
-<p>
- The SBDSOFFSET field is a *signed* 5 bit integer, so we need to sign<br>
- extend when reading the field to get the proper value. We now correctly<br>
- handle the 042_20.jb2 test stream.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@442 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-12-05 23:39:55 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=994516f6db541df5f57d3de4851313af6a260f68">994516f6db541df5f57d3de4851313af6a260f68</a>
-<blockquote>
-<p>
- Add -DJBIG2_DEBUG to the default scons build.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@441 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-SConstruct<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-12-03 07:26:21 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49d3aed4dd6a1adc1ab03702cf324103febae1e6">49d3aed4dd6a1adc1ab03702cf324103febae1e6</a>
-<blockquote>
-<p>
- Fix data for Huffman table B.12.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@440 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_hufftab.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-12-03 03:35:00 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49519f4cfa5ca7d4f06ab11261e86a0d5aa55c64">49519f4cfa5ca7d4f06ab11261e86a0d5aa55c64</a>
-<blockquote>
-<p>
- Correct an operator precedence bug that was corrupting reading of uncompressed<br>
- collective bitmaps. Also improve debugging messages.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@439 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-12-01 23:56:54 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d020e4fcfa9039853e76f0456e65805cff3d19d">0d020e4fcfa9039853e76f0456e65805cff3d19d</a>
-<blockquote>
-<p>
- Promote artimetic debug printout code to JBIG2_DECODE_ARITH from<br>
- plain JBIG2_DEBUG to cut down on noise.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@438 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_arith.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-12-01 21:52:38 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=391a059aad7b801f004b01e17663a4024294d6ef">391a059aad7b801f004b01e17663a4024294d6ef</a>
-<blockquote>
-<p>
- Handle immediate lossless generic regions the same as immediate generic<br>
- regions. Fixes bug 688397.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@437 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-09-01 04:13:36 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b78900486172244c39187e89a085b12f2b6abdb1">b78900486172244c39187e89a085b12f2b6abdb1</a>
-<blockquote>
-<p>
- Some minor corrections and bug fixes.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@436 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-08-31 16:41:42 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a99885954277048b0d73840941dc47ede4c103a">6a99885954277048b0d73840941dc47ede4c103a</a>
-<blockquote>
-<p>
- Make a Jbig2WordStream return zeros past the end of the defined<br>
- buffer, as can happen when the huffman decoder tries to fill<br>
- its 'next_word' lookahead near the end of a segment.<br>
-<br>
- Previously, we just relied on there being some data we could<br>
- read (and then ignore) which usually worked, but caused a<br>
- segfault with the 688080.pdf test file due to chance read<br>
- buffer alignment.<br>
-<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@435 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-08-30 02:05:05 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8acccc58c83123286b0954053a7dd899de5a0630">8acccc58c83123286b0954053a7dd899de5a0630</a>
-<blockquote>
-<p>
- Fix some small bugs and add additional error checking to the<br>
- huffman decoding support.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@434 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_huffman.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-08-28 00:10:20 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e2ff5e373bd8ecda6db43c6b6414c8a3f3248297">e2ff5e373bd8ecda6db43c6b6414c8a3f3248297</a>
-<blockquote>
-<p>
- Comment clean-up.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@433 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_huffman.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-08-25 08:14:21 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d23b5e5b4d8fabdf51d202094ac4259d59dcc974">d23b5e5b4d8fabdf51d202094ac4259d59dcc974</a>
-<blockquote>
-<p>
- Work-in-progress commit of huffman text region support. Fix a number<br>
- of bugs in jbig2_huffman_get_bits() and implement symbol id huffman<br>
- table decode (a custom table is always included inline in the text<br>
- region segment header.)<br>
-<br>
- However, the constructed table gives an out-of-bounds symbol id on<br>
- the first read with the UBC test file.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@432 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_huffman.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-08-23 06:09:55 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d2d97abc0be98770dc506620f5f8921900e55e5e">d2d97abc0be98770dc506620f5f8921900e55e5e</a>
-<blockquote>
-<p>
- Work-in-progress commit of huffman text region support. Initial implemetation of symbol id huffman<br>
- table decode.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@431 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-08-17 20:03:18 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a0531af83d6d29abe2fccb488fa7b741d68cb3fd">a0531af83d6d29abe2fccb488fa7b741d68cb3fd</a>
-<blockquote>
-<p>
- Hack around the lack of subtree support in jbig2_huffman_table_build()<br>
- by allocating a bigger flat table. This should be fixed the correct<br>
- way at some point, but lets us proceed with huffman text region<br>
- decoding implementation in the meantime.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@430 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-08-16 23:57:25 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5bbd972edf6b6441248d4201cd61767fa521cc97">5bbd972edf6b6441248d4201cd61767fa521cc97</a>
-<blockquote>
-<p>
- Work-in-progress commit. Partial implementation of Huffman text region<br>
- support.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@429 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-08-16 21:41:38 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d22a2ed8db5f8d99345b08762cabebcbc5873d64">d22a2ed8db5f8d99345b08762cabebcbc5873d64</a>
-<blockquote>
-<p>
- Copy out the collective bitmap symbols for huffman symbol dictionaries.<br>
-<br>
- Also, some additional debug print pruning.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@428 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-08-16 21:16:22 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c04507a4138266c8266cc01886ca70ae8a9fa93">3c04507a4138266c8266cc01886ca70ae8a9fa93</a>
-<blockquote>
-<p>
- Implement reading an uncompressed collective symbol bitmap.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@427 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-08-16 20:38:03 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=338f0fbd294ee0dc9cbfabd7a15cce0ac657a708">338f0fbd294ee0dc9cbfabd7a15cce0ac657a708</a>
-<blockquote>
-<p>
- Remove huffman debugging printouts. Preserve the state dump functions<br>
- for future use, but #ifdef protect them.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@426 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_huffman.c<br>
-jbig2_huffman.h<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-08-16 20:20:08 +0000
-</strong>
-<br>ray &lt;ray@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=df910b6ffff7ae54db6c2d2430709ebb911eda49">df910b6ffff7ae54db6c2d2430709ebb911eda49</a>
-<blockquote>
-<p>
- Fix for shift right 32 bits of unsigned int being treated as shift right 0.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@425 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-08-04 07:05:05 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=720e508d03bae14bf0e412abb37ad08ecde72e46">720e508d03bae14bf0e412abb37ad08ecde72e46</a>
-<blockquote>
-<p>
- Work-in-progress commit of halftone dictionary implementation. This<br>
- is enabled in the scons build, but not the standard one.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@423 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-SConstruct<br>
-jbig2_halftone.c<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-08-04 07:03:05 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3fb9f08036565d4bd4147283e2e685217b6e4b55">3fb9f08036565d4bd4147283e2e685217b6e4b55</a>
-<blockquote>
-<p>
- bstract the GB_stats size calculation into a function.<br>
- Also some comment cleanup.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@422 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_arith.h<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-07-28 00:59:59 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=45a5c57347f7b7569808933207bb03c8edf30315">45a5c57347f7b7569808933207bb03c8edf30315</a>
-<blockquote>
-<p>
- Warning cleanup. Implement an unoptimized version of the REPLACE image<br>
- composition operator.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@421 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-07-27 23:55:54 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9d9c7e26944b07cda1c81242b66aea7bbdfc1150">9d9c7e26944b07cda1c81242b66aea7bbdfc1150</a>
-<blockquote>
-<p>
- Some code cleanup. Remember the external combination op for region<br>
- segments and use it. Also add the missing REPLACE operator to the<br>
- enum (but not yet implemented in the compositor). Only some routines<br>
- can use this one. Also add some missing prototypes.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@420 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_priv.h<br>
-jbig2_refinement.c<br>
-jbig2_segment.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-07-27 23:49:03 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dcb83f94c6dc0280a8edeb4dc303fc1451bcd881">dcb83f94c6dc0280a8edeb4dc303fc1451bcd881</a>
-<blockquote>
-<p>
- Fix an off-by-one in reading the SBDEFPIXEL and SBCOMBOP fields of<br>
- the text region segment flags, which caused us to clear the region<br>
- background to the wrong value. Bug 688244.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@419 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-07-27 17:29:03 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a8c95e32a1a05dbf5587ff2262ea225f2dd6c2b">4a8c95e32a1a05dbf5587ff2262ea225f2dd6c2b</a>
-<blockquote>
-<p>
- Commit an off-by-one fix from Alex Cherepanov related to bug 688244.<br>
-<br>
- Also #ifdef protect a debug image dump that was preventing compilation<br>
- in Ghostscript.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@418 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-07-27 08:29:56 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d128dbed01e775befd59050c415b5aa7f21562d">0d128dbed01e775befd59050c415b5aa7f21562d</a>
-<blockquote>
-<p>
- Work in progress commit of huffman support. This version is still buggy and<br>
- includes some serious debug spew.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@417 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_huffman.c<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-07-13 16:51:13 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4cc11bea50d585804e93b985e7d7e8504990911b">4cc11bea50d585804e93b985e7d7e8504990911b</a>
-<blockquote>
-<p>
- Work-in-progress check in of huffman symbol dictionary support.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@416 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_huffman.c<br>
-jbig2_huffman.h<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-07-13 16:28:44 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1b6a01e666d0dbcd355c0b84fba43c1d02fb4b37">1b6a01e666d0dbcd355c0b84fba43c1d02fb4b37</a>
-<blockquote>
-<p>
- Move a repeated calculation out of a loop.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@415 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-06-20 11:09:19 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=46ff1e6277a432b9e1d18784ab5c30fc40b45476">46ff1e6277a432b9e1d18784ab5c30fc40b45476</a>
-<blockquote>
-<p>
- Minor cleanup of unimplemented huffman sections.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@414 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-06-19 14:16:14 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1eb7ae738d7af4508d7cbc547c0e386d55821820">1eb7ae738d7af4508d7cbc547c0e386d55821820</a>
-<blockquote>
-<p>
- Properly initialize the decode result field of the segment header struct<br>
- to NULL to avoid problems on free. Bug 688053.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@413 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-06-15 14:09:35 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=84de63772c46a85128b6ada79cd2203918c7dec2">84de63772c46a85128b6ada79cd2203918c7dec2</a>
-<blockquote>
-<p>
- Fail on fatal symbol dict decoding errors.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@412 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-06-08 14:23:43 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e5bdc75cc8afaf2630953f1784381cc6c9305e36">e5bdc75cc8afaf2630953f1784381cc6c9305e36</a>
-<blockquote>
-<p>
- Add support for striped page decode. We still return a full<br>
- page buffer, so there is no savings in memory footprint.<br>
-<br>
- We now decode 042_9.jb2 from the UBC test streams.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@411 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-jbig2.h<br>
-jbig2_generic.c<br>
-jbig2_image.c<br>
-jbig2_page.c<br>
-jbig2_priv.h<br>
-jbig2_refinement.c<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-06-08 14:23:23 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d954b0f143afbf16da24b2ea0a54d88b39af4129">d954b0f143afbf16da24b2ea0a54d88b39af4129</a>
-<blockquote>
-<p>
- Work in progress commit to support huffman text regions. Parse<br>
- and intantiate the huffman tables for text region decoding.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@410 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-06-08 14:20:45 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b28d531ea50bf15cc80cb068192b47b57a8916ce">b28d531ea50bf15cc80cb068192b47b57a8916ce</a>
-<blockquote>
-<p>
- Implement remaining standard huffman tables.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@409 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_huffman.h<br>
-jbig2_hufftab.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-06-08 14:19:35 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2ff386d420a62438df630a8b0ba3a022469cd3f8">2ff386d420a62438df630a8b0ba3a022469cd3f8</a>
-<blockquote>
-<p>
- Turn on -Wall when compiling with gcc.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@408 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-05-24 03:49:47 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0a9dae0a3c665ce5c758f1575e0c8f08075aaf3c">0a9dae0a3c665ce5c758f1575e0c8f08075aaf3c</a>
-<blockquote>
-<p>
- Update the arith and huffman tests to run with the new code. We now<br>
- compile with -DTEST and link to the rest of the library since that's<br>
- required to access the allocator. In theory, that means we have duplicate<br>
- symbols, but GNU ld seems to cope. If it's a problem the test programs can<br>
- be split into separate source files.<br>
-<br>
- Note that the arith test doesn't actually verify its results; it just<br>
- prints the results when compiled with -DJBIG2_DEBUG.<br>
-<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@407 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-jbig2_arith.c<br>
-jbig2_huffman.c<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-05-18 00:42:24 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d78f4fbaac91f43bd14ac7d54c60e8edb0fa5bfe">d78f4fbaac91f43bd14ac7d54c60e8edb0fa5bfe</a>
-<blockquote>
-<p>
- Attempt to hook the self tests into the scons build. This is supposed<br>
- to work with the development version, but does not.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@406 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-SConstruct<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-05-11 07:14:25 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc3a563ea709064bf47147bd817a962e368a5c2a">cc3a563ea709064bf47147bd817a962e368a5c2a</a>
-<blockquote>
-<p>
- Export the pre-defined huffman tables for external use.<br>
-<br>
- Read the huffman fields of the symbol dictionary header and allocate<br>
- appropriate tables and decoder context. This is a prerequisite for<br>
- handling huffman-coded symbol dicts.i<br>
-<br>
- Part of the fix for bug 688009.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@405 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_huffman.c<br>
-jbig2_huffman.h<br>
-jbig2_hufftab.h<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-05-03 02:27:12 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34b95add346fa8b27064e007da4e86eadc466bbd">34b95add346fa8b27064e007da4e86eadc466bbd</a>
-<blockquote>
-<p>
- Allocate a huffman decoder for symbol dictionaries that require it.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@404 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-05-03 02:25:08 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=67a0de3abce1a5ea08260cf937754ecfadbe7b41">67a0de3abce1a5ea08260cf937754ecfadbe7b41</a>
-<blockquote>
-<p>
- Update the huffman decoder interface.<br>
- Move hufftab.h with the static table definitions to only be included once<br>
- from huffman.c.<br>
- Use the client-replaceable jbig2_alloc() instead of bare malloc().<br>
- Add a 'free' call for the huffman state. This just calls jbig2_free().<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@403 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_huffman.c<br>
-jbig2_huffman.h<br>
-jbig2_hufftab.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-05-03 01:10:27 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e2d6eade5dd4755e15db66e539256aa407b6d08">1e2d6eade5dd4755e15db66e539256aa407b6d08</a>
-<blockquote>
-<p>
- Re enable the huffman and arithmetic coder unit tests.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@402 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-05-02 20:49:28 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7fa4382f2f5cac1f1471617a23c9d1affa994e18">7fa4382f2f5cac1f1471617a23c9d1affa994e18</a>
-<blockquote>
-<p>
- Alter our portability fallback implementation of memcmp() to properly return<br>
- negative values is the first argument is &quot;less than&quot; the second. The previous<br>
- one was fine for our purposes, but could cause problems if it was accidentally<br>
- used by client applications.<br>
-<br>
- Thanks to Ray Johnston for pointing this out.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@401 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-memcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-04-28 04:44:30 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=65885f2808d815a4ce41d4712c19dc1dac61b6ab">65885f2808d815a4ce41d4712c19dc1dac61b6ab</a>
-<blockquote>
-<p>
- Add the changelog to the distribution.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@400 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-04-28 04:37:42 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=40379d7c353d1326615e08e64684fdc4065544ec">40379d7c353d1326615e08e64684fdc4065544ec</a>
-<blockquote>
-<p>
- Add experimental scons build file.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@399 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-SConstruct<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-04-28 04:36:32 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0c358eca216ac6fb627a0d920c7fb9eb3f53d014">0c358eca216ac6fb627a0d920c7fb9eb3f53d014</a>
-<blockquote>
-<p>
- Fix implicit cast warnings from MSVC. Bug 687988.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@398 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-04-28 04:35:55 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=26c310efdb8e8a914c36ffe7a4944448144adeef">26c310efdb8e8a914c36ffe7a4944448144adeef</a>
-<blockquote>
-<p>
- Bump the version number for new development work.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@397 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-04-28 04:31:34 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b67e1875a83632bc7e43e44d0a98ccc64c030b94">b67e1875a83632bc7e43e44d0a98ccc64c030b94</a>
-<blockquote>
-<p>
- Update version and changelog for the 0.8 release.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@395 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-04-06 18:14:30 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c49714a02996d398353fe76f51ef084dcaa99602">c49714a02996d398353fe76f51ef084dcaa99602</a>
-<blockquote>
-<p>
- Add an explicit cast to quiet a warning on MSVC. Bug 687988.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@393 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-04-06 00:29:36 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2561fd5c9ed06af167a245e2a09732a68655c8fb">2561fd5c9ed06af167a245e2a09732a68655c8fb</a>
-<blockquote>
-<p>
- Add a cast to in checking a range against an unsigned value.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@392 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-04-05 23:40:12 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cf7b160a37331362d7bcff571e13e57d20193377">cf7b160a37331362d7bcff571e13e57d20193377</a>
-<blockquote>
-<p>
- Minor comment cleanup.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@391 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image_pbm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-04-05 23:39:53 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c5393dfc4025b41895565f5b2a2f1786bffdf980">c5393dfc4025b41895565f5b2a2f1786bffdf980</a>
-<blockquote>
-<p>
- dd a missing break; in the segment release dispatch. Release of symbol<br>
- dictionary segments was falling through and causing a double free of<br>
- the result. Bug 688004.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@390 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-01-19 19:31:33 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c04c341b8cfbd2ee7b58269147a41bf6c24d7b7e">c04c341b8cfbd2ee7b58269147a41bf6c24d7b7e</a>
-<blockquote>
-<p>
- #ifdef out the cygwin stdint-from-sys/types fixup. Newer cygwin seems to provide<br>
- them all, but still not define stdint.h. Bug 687873.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@389 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-os_types.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-01-04 07:05:39 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fdc9d09b305474bffc749d23b51e025bba7fa567">fdc9d09b305474bffc749d23b51e025bba7fa567</a>
-<blockquote>
-<p>
- Correct some memory leaks in text region decoding: properly free arith<br>
- and word stream state, and release refined glyph images after<br>
- compositing.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@388 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-01-04 07:04:17 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3cf2d67fafefb607c8d436f2185d092457274cdb">3cf2d67fafefb607c8d436f2185d092457274cdb</a>
-<blockquote>
-<p>
- Correctly free the (dynamic) glyph array when freeing a symbol<br>
- dictionary.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@387 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-01-04 05:17:39 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad0de34366fd42c8f95d519dccb91115c4278580">ad0de34366fd42c8f95d519dccb91115c4278580</a>
-<blockquote>
-<p>
- Also correctly free the integer arith coding contexts in symbol<br>
- dictionary decode.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@386 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-01-04 05:07:45 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bff29a59cb009b2cb0b397c137e8576e9f3acb0b">bff29a59cb009b2cb0b397c137e8576e9f3acb0b</a>
-<blockquote>
-<p>
- Properly free the arith and word stream states in symbol dictionary decoding.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@385 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-01-04 04:53:16 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=81b746740b074f5a0a8b539bc4954dad5c5797be">81b746740b074f5a0a8b539bc4954dad5c5797be</a>
-<blockquote>
-<p>
- Properly free some segment results when the segment header structures<br>
- are freed. Symbol dictionaries are released, intermediate segment images<br>
- are released if they haven't already been released and nulled after<br>
- their use in the decode process, and metadata structures are properly<br>
- freed.<br>
-<br>
- Resolves all known leaks with the first 7 ubc test streams.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@384 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-jbig2_refinement.c<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-01-04 04:41:56 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=304420e16947853c697c9f50eb9e7c3cdd64f80c">304420e16947853c697c9f50eb9e7c3cdd64f80c</a>
-<blockquote>
-<p>
- Properly free tag and value strings from inside the metadata struct. We<br>
- now assume we own those pointers, which is fine if jbig2_metadata_add()<br>
- is used to construct them.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@383 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_metadata.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-01-04 04:40:18 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e641718f01a0a45ec8cfc89602daa345bb9383f8">e641718f01a0a45ec8cfc89602daa345bb9383f8</a>
-<blockquote>
-<p>
- Minor cleanup: remove an unnecessary check before releasing an immediate<br>
- text region after decode and composite, and simply reference to the page<br>
- image itself.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@382 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-01-04 00:53:10 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e3a50c85fa43ebff2b3164e05cf3988c326cfb27">e3a50c85fa43ebff2b3164e05cf3988c326cfb27</a>
-<blockquote>
-<p>
- Properly free arithmetic coding and word stream states after region<br>
- decode. Also use the allocator defined in the library context instead<br>
- of raw malloc for the arith state.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@381 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_arith.c<br>
-jbig2_generic.c<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-01-04 00:34:16 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=de271483ae5bf0ee87b73b44d9d433d4ca6a920a">de271483ae5bf0ee87b73b44d9d433d4ca6a920a</a>
-<blockquote>
-<p>
- Properly free the decoded page image array on context free.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@380 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2005-01-04 00:32:36 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f72323e48008adb89a21bf01770a9583f456ff36">f72323e48008adb89a21bf01770a9583f456ff36</a>
-<blockquote>
-<p>
- Simplify the ubc teststream hashes.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@379 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-test_jbig2dec.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-23 12:53:49 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb7f46063eb1b3e220c13839ef622c29bcf5834f">eb7f46063eb1b3e220c13839ef622c29bcf5834f</a>
-<blockquote>
-<p>
- Properly mask the last row byte in the shift == 0 compositor<br>
- case. Fixes bug 687843.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@374 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-23 12:07:53 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=99672eb6ce4dad97c3ff22f9768b0073f730331e">99672eb6ce4dad97c3ff22f9768b0073f730331e</a>
-<blockquote>
-<p>
- update changelog.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@373 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-23 11:54:43 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6f0b0d1802ad565e908adac9601e650bdfb8af94">6f0b0d1802ad565e908adac9601e650bdfb8af94</a>
-<blockquote>
-<p>
- Implement a slow general fallback for image compositing. This adds<br>
- support for non-OR composition operators.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@372 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-22 09:34:29 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d9a6439364da7ea94311d69f877ae37485fd1f7">7d9a6439364da7ea94311d69f877ae37485fd1f7</a>
-<blockquote>
-<p>
- Clarify variable references to better match the spec.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@371 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-22 01:36:38 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b62aa9dd9154eba7122c56cab886207dce972cb1">b62aa9dd9154eba7122c56cab886207dce972cb1</a>
-<blockquote>
-<p>
- Trivial whitespace fix.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@370 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-21 22:59:04 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=afe3a66d19d98cf0017f4c7b433ae65b2286e259">afe3a66d19d98cf0017f4c7b433ae65b2286e259</a>
-<blockquote>
-<p>
- replace individual memset calls for clearing images with a new<br>
- jbig2_image_clear() utility function.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@369 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.h<br>
-jbig2_image.c<br>
-jbig2_page.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-21 01:05:59 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d264e8daa8c30ea3d4d43e287bcc97462f244e9e">d264e8daa8c30ea3d4d43e287bcc97462f244e9e</a>
-<blockquote>
-<p>
- Initialize the initial text region segment bitmap to zero.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@368 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-21 00:35:02 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=50493055b3f099f6670df3ab2011af8085ba49c5">50493055b3f099f6670df3ab2011af8085ba49c5</a>
-<blockquote>
-<p>
- Re-assign the return value of jbig2_realloc() when growning the page<br>
- size array. Previously it was dropped which could cause crashes on some<br>
- systems processing documents with more than 4 pages. Thanks to Jan<br>
- Patera for reporting this.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@367 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-13 20:00:09 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=28e7ac27b12c59c271eacca8eb70dc97fe991c5b">28e7ac27b12c59c271eacca8eb70dc97fe991c5b</a>
-<blockquote>
-<p>
- Fix and error return. The normal 'return jbig2_error(ctx, JBIG2_SEVERITY_FATAL,...)'<br>
- idiom doesn't work when the function returns a pointer instead of an error code.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@366 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-08 22:49:47 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a065bcb4b13998d875073212087b2a84aa132cc7">a065bcb4b13998d875073212087b2a84aa132cc7</a>
-<blockquote>
-<p>
- Bump version number post-release, and correct a CHANGES typo.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@365 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-08 21:00:32 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=afc8acb7f41c4569e208301153449c2fd8dbd9da">afc8acb7f41c4569e208301153449c2fd8dbd9da</a>
-<blockquote>
-<p>
- Set the release date.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@360 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-08 20:49:19 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0577ac1d30bd76622e9c2cd36ff573b3e144b19c">0577ac1d30bd76622e9c2cd36ff573b3e144b19c</a>
-<blockquote>
-<p>
- Error if the symbol id indicated for refinement in a refagg symbol<br>
- dictionary segment is out of range. UBC test stream 042_13 triggers<br>
- this, we don't fix this here, only handle the error more verbosely.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@359 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-07 01:37:45 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0aa9e029d3d78790d747b8fd6c62f2f6ffe403f5">0aa9e029d3d78790d747b8fd6c62f2f6ffe403f5</a>
-<blockquote>
-<p>
- Bump the version number for release.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@358 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-07 01:23:24 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=422bfff0efc1eaedd88e5aa876a96ae36fbd13bb">422bfff0efc1eaedd88e5aa876a96ae36fbd13bb</a>
-<blockquote>
-<p>
- Add jbig2_refinement.c to the Jam and MSVC builds.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@357 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Jamfile<br>
-msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-06 05:37:42 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=389ea3e65131d1644f3c894bd67c6dc433ccb0ec">389ea3e65131d1644f3c894bd67c6dc433ccb0ec</a>
-<blockquote>
-<p>
- Code cleanup. The refinement region decode procedures use a 'GR' prefix<br>
- in the spec even when the function is identical to the 'GB' prefix<br>
- variables in the generic region procedures. Change our code to match.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@356 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-06 05:36:28 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=65b51e728aed87dfeb43227218be0c5cc4d642af">65b51e728aed87dfeb43227218be0c5cc4d642af</a>
-<blockquote>
-<p>
- Correct the test for the nominal generic region template 0 AT pixel<br>
- positions. The previous change invoked the optimized routine for the<br>
- wrong template, causing a regression with ubc test stream 042_10.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@355 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_generic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-05 04:15:42 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5bbe12052a1a34c065451a2c10741021caf6887c">5bbe12052a1a34c065451a2c10741021caf6887c</a>
-<blockquote>
-<p>
- Update the changelog<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@354 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-05 04:15:13 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=801c41b10d75f023ff2387aac576f5f3c152a308">801c41b10d75f023ff2387aac576f5f3c152a308</a>
-<blockquote>
-<p>
- Add an unoptimized generic decoder for generic region template 0. We now<br>
- properly decode UBC test stream 042_7.jb2.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@353 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_generic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-05 03:48:36 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b6179196091f01a58c17a79024d7ee5243ab8a2">2b6179196091f01a58c17a79024d7ee5243ab8a2</a>
-<blockquote>
-<p>
- Add a generic but unoptimized handler for generic region arithmetic<br>
- template 3, and an optimized but untested handler for the default AT<br>
- pixel position. We now properly decode 042_6.jb2 from the UBC test<br>
- suite.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@352 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-jbig2_generic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-04 02:29:17 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b8fc23e4731a172600282a65e9602ff1963bfead">b8fc23e4731a172600282a65e9602ff1963bfead</a>
-<blockquote>
-<p>
- Implement non-standard AT positions in the unoptimized version<br>
- of the refinement region template. We now properly decode ubc<br>
- test stream 042_23.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@351 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-04 02:24:11 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=42c0312cc2855d2cc0d83954968c65a8e5e6107d">42c0312cc2855d2cc0d83954968c65a8e5e6107d</a>
-<blockquote>
-<p>
- The gbat and grat content pixel offset arrays are signed.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@350 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-03 17:04:07 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91496de8718924d6b112c093ea51894210ed8d3d">91496de8718924d6b112c093ea51894210ed8d3d</a>
-<blockquote>
-<p>
- Remove the reference image debug dump.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@349 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-03 17:03:02 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c51afb6cce1f14340b7ec8476c64949b469614a7">c51afb6cce1f14340b7ec8476c64949b469614a7</a>
-<blockquote>
-<p>
- #ifdef protect a debug image dump.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@348 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-03 06:55:35 +0000
-</strong>
-<br>raph &lt;raph@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8a90500857d4c0d9a6628196447002efe68a0f46">8a90500857d4c0d9a6628196447002efe68a0f46</a>
-<blockquote>
-<p>
- Implement text refinement regions (SBREFINE = 1 in text segments).<br>
- jbig2dec commandline now decodes 1page-output.jbig2 from bug #687575.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@347 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-01 22:19:57 +0000
-</strong>
-<br>raph &lt;raph@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=74eba6a78944ccfada0ab7dc50f6363cfd225cbf">74eba6a78944ccfada0ab7dc50f6363cfd225cbf</a>
-<blockquote>
-<p>
- Implements IAID procedure for decoding reference symbol id's in symbol<br>
- dict segs (was incorrectly using generic int procedure). Fixes off-by-<br>
- one test for image bounds in jbig2_image_get_pixel and<br>
- jbig2_image_set_pixel.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@346 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-01 19:50:07 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a4d66009ee206247b2d9e61615a6fefbc49468c4">a4d66009ee206247b2d9e61615a6fefbc49468c4</a>
-<blockquote>
-<p>
- Use the correct definition of the SDREFAGG flag to switch GR_stats allocation.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@345 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-01 19:45:29 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=804b91c488cbb7ea22bad56edd0b39384066c908">804b91c488cbb7ea22bad56edd0b39384066c908</a>
-<blockquote>
-<p>
- Correct a typo, and switch allocation of GR_stats on SDREFAGG instead of SDRTEMPLATE.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@344 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-01 19:40:05 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d89f78a5cb864865e102192f5a44d6b149f0bf71">d89f78a5cb864865e102192f5a44d6b149f0bf71</a>
-<blockquote>
-<p>
- Trial implementation of separate GR_stats for refinement arithmetic coding.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@343 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-01 19:26:13 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d489de65d56c8277d5b078759c20a921f429cd63">d489de65d56c8277d5b078759c20a921f429cd63</a>
-<blockquote>
-<p>
- Zero the sdrat values if they are not going to be used. Avoids a UMR in a later debug message.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@342 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-01 18:51:14 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ccb4bbffa33b6c0e33b9bc6844ddf69d155c9eb3">ccb4bbffa33b6c0e33b9bc6844ddf69d155c9eb3</a>
-<blockquote>
-<p>
- Fix an error in REFAGG decoding, and properly warn that REFAGGNINST &gt; 1 isn't yes implemented.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@341 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-01 18:50:06 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f2bc04b3071d5617851f2255e73d3444ac179dfb">f2bc04b3071d5617851f2255e73d3444ac179dfb</a>
-<blockquote>
-<p>
- Update changelog with recent new features.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@340 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-12-01 18:21:52 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8291bc316fc9882c419c9fcd11dbd8f19d497402">8291bc316fc9882c419c9fcd11dbd8f19d497402</a>
-<blockquote>
-<p>
- Protect the refinement region debug output with an #ifdef.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@339 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-11-24 19:35:47 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b588b1a9e9599c5041db8279d953bb3aee57371c">b588b1a9e9599c5041db8279d953bb3aee57371c</a>
-<blockquote>
-<p>
- Implement an unoptimized version of refinement region template 0.<br>
- We now decode ubc test stream 042_21.jb2.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@338 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-11-24 19:29:07 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ccd602286a7f176ffb0fffc68be453d443f0644e">ccd602286a7f176ffb0fffc68be453d443f0644e</a>
-<blockquote>
-<p>
- Invert the check for refinement region movable template<br>
- offsets. This was the last bug in the refinement region<br>
- segment handling code, we now handle the ubc 042_22.jb2<br>
- test file!<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@337 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-11-24 19:26:35 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c3f6e30d4f07e021cc818e584b085456b25865e6">c3f6e30d4f07e021cc818e584b085456b25865e6</a>
-<blockquote>
-<p>
- Rename the refinement region typical prediction flag<br>
- TPGRON in correspondence with the spec.<br>
-<br>
- Also fixes some index comparison errors.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@336 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_generic.h<br>
-jbig2_refinement.c<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-11-24 17:52:32 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a01d4e48567de8c803e993a76b5d7749f597875d">a01d4e48567de8c803e993a76b5d7749f597875d</a>
-<blockquote>
-<p>
- Correct the size of the GB_stats allocation for the refinement<br>
- templates; the sizes were reversed.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@335 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-11-24 17:50:30 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e7c951253f1d39e3a6451cc476f89fd1a5827d97">e7c951253f1d39e3a6451cc476f89fd1a5827d97</a>
-<blockquote>
-<p>
- correct a typo<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@334 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-11-24 17:49:18 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=faf1a86071f89a81fd9c5f34840bb03a90650c50">faf1a86071f89a81fd9c5f34840bb03a90650c50</a>
-<blockquote>
-<p>
- We no longer need the result debug image; page composition is working ok.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@333 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-11-24 07:14:03 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cf1418dc01a996a8f351918a5fd6202ce02a22d5">cf1418dc01a996a8f351918a5fd6202ce02a22d5</a>
-<blockquote>
-<p>
- Implement generic refinement region segment handling. Decoding is still<br>
- not correct.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@332 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_refinement.c<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-11-24 07:13:11 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e161b891ac484992cfff4127332498fb46125fa8">e161b891ac484992cfff4127332498fb46125fa8</a>
-<blockquote>
-<p>
- Clean up some debug messages.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@331 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-jbig2_image.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-11-24 03:03:12 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=581b2c04128ae030deba492ea9a4dfc64a033eae">581b2c04128ae030deba492ea9a4dfc64a033eae</a>
-<blockquote>
-<p>
- Correct a typo in reading the SBRAT offsets in text segments.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@330 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-11-17 19:29:25 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b4c9f4c43bb969875ad842658e269646abaeb96e">b4c9f4c43bb969875ad842658e269646abaeb96e</a>
-<blockquote>
-<p>
- Promote the debugging get/set pixel routines to general availability.<br>
- Also, fix a bit order bug: we follow the pbm convention, where MSb is<br>
- leftmost, not rightmost.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@329 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-jbig2_image.h<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-10-22 22:28:07 +0000
-</strong>
-<br>root &lt;root@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c22eeab4e9a67bb218cb4e03df9ed9bad3b6647">2c22eeab4e9a67bb218cb4e03df9ed9bad3b6647</a>
-<blockquote>
-<p>
- Build an unoptimized version of the refinement template context calculation<br>
- to assist with debugging. This one doesn't seem to work either.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@328 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-10-22 22:21:19 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=65a3e8bfeba6213859690722281ca290fe3e7d20">65a3e8bfeba6213859690722281ca290fe3e7d20</a>
-<blockquote>
-<p>
- minor comment reformatting<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@327 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-10-08 01:29:10 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=872c0bb40abd41f305e2cd27a3673fe2f28b9ea6">872c0bb40abd41f305e2cd27a3673fe2f28b9ea6</a>
-<blockquote>
-<p>
- correct shift offsets<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@326 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-10-03 21:14:57 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=441dc4f503432969833a7124b45e1e98ffe7cb81">441dc4f503432969833a7124b45e1e98ffe7cb81</a>
-<blockquote>
-<p>
- Additional work on refinement region template 1. Context update still<br>
- incorrect.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@325 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-10-02 07:08:22 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5d03d94b2004361b89cbf977ad5519b661c2aea7">5d03d94b2004361b89cbf977ad5519b661c2aea7</a>
-<blockquote>
-<p>
- Commit of work in progress to support refinement region decode. First<br>
- draft of template 1.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@324 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-09-29 14:15:40 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0c8fe23adba1f24273186b4a7379f588437d9f5d">0c8fe23adba1f24273186b4a7379f588437d9f5d</a>
-<blockquote>
-<p>
- Work in progress of refinement region support. Call logic for refagg<br>
- symbol dictionary entries.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@323 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-jbig2_refinement.c<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-09-29 13:48:42 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef32d14a8d786981905bed84313d250d39b6dead">ef32d14a8d786981905bed84313d250d39b6dead</a>
-<blockquote>
-<p>
- Turn on all warnings by default.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@322 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-08-18 01:11:38 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f5e8721505beec15991f7660b67fa9dbfd037b7f">f5e8721505beec15991f7660b67fa9dbfd037b7f</a>
-<blockquote>
-<p>
- correct some property settings in the source repository<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@321 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-test_jbig2dec.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-08-18 01:04:28 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b17636877d0742ea430c1efc646b1e9c68b70014">b17636877d0742ea430c1efc646b1e9c68b70014</a>
-<blockquote>
-<p>
- enable Id keyword substitution on the new file<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@320 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-08-18 01:03:14 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1efb1d79e3dead9e474ff89cd0ce0d6c87d21ca3">1efb1d79e3dead9e474ff89cd0ce0d6c87d21ca3</a>
-<blockquote>
-<p>
- It looks like templates aren't shared between generic and generic refinement decoding, so split<br>
- the routines into separate files.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@319 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_generic.c<br>
-jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-08-13 00:00:17 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=508693c17eb8f052fbcc0ea4976cb326e746c2f0">508693c17eb8f052fbcc0ea4976cb326e746c2f0</a>
-<blockquote>
-<p>
- Work in progress to implement generic refinement regions and aggregate symbol coding.<br>
- Commit to avoid losing work.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@318 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-08-11 16:38:39 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=19918285ec07521885d12a624507435a3da9f473">19918285ec07521885d12a624507435a3da9f473</a>
-<blockquote>
-<p>
- correct a typo in the previous commit<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@317 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-08-10 22:36:14 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a1f9f214d267dced3b00c96708c95e89d674790a">a1f9f214d267dced3b00c96708c95e89d674790a</a>
-<blockquote>
-<p>
- Include stdio.h when required for pbm debug output.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@316 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-08-10 22:34:59 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4813245d60e430c1b9528a4aa018ee6d45b28add">4813245d60e430c1b9528a4aa018ee6d45b28add</a>
-<blockquote>
-<p>
- document previous fix<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@315 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-08-10 22:33:46 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5264ffff604bc9da416b86b6ed382aa75638dc9">b5264ffff604bc9da416b86b6ed382aa75638dc9</a>
-<blockquote>
-<p>
- Properly initialize the page buffer to the default pixel value.<br>
- This caused, among other potential bugs, garbage and overlay<br>
- effects under some malloc implementatons, though not on GNU/Linux.<br>
-<br>
- Fixes Ghostscript bugs 687530 and 687609. Thanks to Oleg Panashchenko<br>
- for analysis.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@314 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-08-06 05:01:36 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=99264987a0799fca10e9ccd0aeff86713878ba67">99264987a0799fca10e9ccd0aeff86713878ba67</a>
-<blockquote>
-<p>
- Actually implement the 'or later' part of the automake version<br>
- detection.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@313 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-autogen.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-07-06 13:32:01 +0000
-</strong>
-<br>tor &lt;tor@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=18b2ab815f85ec97de3dcdc2088d4986f1676b84">18b2ab815f85ec97de3dcdc2088d4986f1676b84</a>
-<blockquote>
-<p>
- added a rudimentary jamfile<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@312 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Jamfile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-04-08 08:40:49 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ca77e2fee1e77118981d33fb1b9ab5803717e343">ca77e2fee1e77118981d33fb1b9ab5803717e343</a>
-<blockquote>
-<p>
- Initialize some variables to avoid spurious warnings from gcc.<br>
-<br>
- These are all used only in one code path or another, so there was no<br>
- danger of unitialized use. However, by the same token we lose nothing by<br>
- setting a default to quiet the warning.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@311 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-04-08 08:36:12 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=09e114b5849ac066755ae1625104896d232ef168">09e114b5849ac066755ae1625104896d232ef168</a>
-<blockquote>
-<p>
- Remove some unused variables. Bug 687413.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@310 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_generic.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2004-03-24 07:49:53 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da420b02de6412f053b759cd04d498762ac62fbe">da420b02de6412f053b759cd04d498762ac62fbe</a>
-<blockquote>
-<p>
- Check for defined(HAVE_CONFIG_H) instead of just a non-false value. Corrects a warning on the<br>
- Intel compiler. Ghostscript bug 687320.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@309 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-os_types.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-12-31 16:38:08 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=365418bd41891ad1627a4bf612dccd51492f6c2c">365418bd41891ad1627a4bf612dccd51492f6c2c</a>
-<blockquote>
-<p>
- Helps to actually increment the version number.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@307 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-12-31 16:29:40 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5715735568f8cdb7cce148b9335933ad20d3cd5">b5715735568f8cdb7cce148b9335933ad20d3cd5</a>
-<blockquote>
-<p>
- Update version and changelog for 0.6 release.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@306 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-12-31 16:25:47 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=297c9b5fdba66116c2e975789ad7d2d640123114">297c9b5fdba66116c2e975789ad7d2d640123114</a>
-<blockquote>
-<p>
- Portability update. Newer cygwin does provide stdint.h, conflicting with the work-around we<br>
- installed for older cygwin. Thanks to Alex Cherpanov for this.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@305 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-os_types.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-12-31 16:25:00 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49cc61770c6fadfa7a4f2a214a7040db129f3a08">49cc61770c6fadfa7a4f2a214a7040db129f3a08</a>
-<blockquote>
-<p>
- Apparently forgot to bump the version number in configure.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@304 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-12-04 16:24:55 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=344fc838a5c35bf4ccef6ec2259b3a317135ab36">344fc838a5c35bf4ccef6ec2259b3a317135ab36</a>
-<blockquote>
-<p>
- Update changelog for 0.5 release.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@301 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-12-04 16:19:42 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a413dad44bd527f43968e32258aed7a20245f5d5">a413dad44bd527f43968e32258aed7a20245f5d5</a>
-<blockquote>
-<p>
- Remove symbol dictionary export routine debugging prints and modify the dump_symbol_dictionary()<br>
- call so that it does not require stdio.h.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@300 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-12-04 16:11:27 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=204d69f4fce9cf5ee00e0fce774a622e9fca109f">204d69f4fce9cf5ee00e0fce774a622e9fca109f</a>
-<blockquote>
-<p>
- We no longer need to artificially recurse when building the list of referred symbol dictionaries<br>
- now that we properly construct an exported result.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@299 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-12-04 15:54:34 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a82d670d005fdd3e4fc877fddcf69ff01f6d53df">a82d670d005fdd3e4fc877fddcf69ff01f6d53df</a>
-<blockquote>
-<p>
- Remove an unused local variable.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@298 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-12-03 05:42:07 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e242d111c02050235102d9e466e9a4d6435f7867">e242d111c02050235102d9e466e9a4d6435f7867</a>
-<blockquote>
-<p>
- Avoid an unitialized variable warning.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@297 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-12-03 00:22:13 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cb7d209f4e106ec97471b98efdce93814326c8cd">cb7d209f4e106ec97471b98efdce93814326c8cd</a>
-<blockquote>
-<p>
- First stab at parsing the export symbol bitfield and building a proper export dictionary.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@296 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-12-01 19:46:01 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0a88581c12e2d029bb42aa7d2c745645a3a5d6fe">0a88581c12e2d029bb42aa7d2c745645a3a5d6fe</a>
-<blockquote>
-<p>
- Split an expression into two pieces to avoid confusion over order of operations.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@295 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-12-01 18:02:00 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=02da65fafcef22d50df76638362b946d6a2ec96b">02da65fafcef22d50df76638362b946d6a2ec96b</a>
-<blockquote>
-<p>
- Add a cast to avoid an incompatible pointer type warning.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@294 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-12-01 17:54:07 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=12ab5048f182dda7a778b678781e604e6d3abbe6">12ab5048f182dda7a778b678781e604e6d3abbe6</a>
-<blockquote>
-<p>
- Prefer uint8_t to byte in some internal functions.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@293 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_generic.c<br>
-jbig2_page.c<br>
-jbig2_priv.h<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-12-01 17:53:45 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8d833614a9cdc49e405d72bbf1658859e4468df1">8d833614a9cdc49e405d72bbf1658859e4468df1</a>
-<blockquote>
-<p>
- Correct a warning. Offset, then cast to non-const, not the other way around.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@292 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_metadata.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-12-01 17:44:19 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7adeea559e68d424dd78ce440536ac2d78fc2a8c">7adeea559e68d424dd78ce440536ac2d78fc2a8c</a>
-<blockquote>
-<p>
- Add a prototype for the extension segment parser.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@291 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_priv.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-11-11 13:49:50 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=018ec13e4a810da97e57725731d80ca3bff4b5af">018ec13e4a810da97e57725731d80ca3bff4b5af</a>
-<blockquote>
-<p>
- Make Jbig2SymbolDict more object like. Work in progress to unify<br>
- inheritance.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@290 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-jbig2_symbol_dict.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-11-11 13:15:00 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5933c48096aca791162c655d9570b2922835cdf6">5933c48096aca791162c655d9570b2922835cdf6</a>
-<blockquote>
-<p>
- Make the symbol dict lookup code public and move it out of jbig2_text.c.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@289 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-jbig2_symbol_dict.h<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-11-10 20:54:09 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=02a9540fdd75a6ed8bfada759b46a42199d84d67">02a9540fdd75a6ed8bfada759b46a42199d84d67</a>
-<blockquote>
-<p>
- Properly quote nested M4 macros. The old code breaks in autoconf 2.58.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@288 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-11-10 17:02:21 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=75c1235ecc921075cb4ec9c2c25e5008d9efad75">75c1235ecc921075cb4ec9c2c25e5008d9efad75</a>
-<blockquote>
-<p>
- Correct arguments to jbig2_image_free().<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@287 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-11-09 13:59:03 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=995e4a01171a87bd2453fb05b13612e76720cd26">995e4a01171a87bd2453fb05b13612e76720cd26</a>
-<blockquote>
-<p>
- Add reference counting to the image structure to permit sharing of the glyph images<br>
- between symbol dictionaries.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@286 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.h<br>
-jbig2_generic.c<br>
-jbig2_image.c<br>
-jbig2_image_pbm.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-11-06 18:08:48 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f2d8d661e4230e61e095e336f1b14c739b62ba0">8f2d8d661e4230e61e095e336f1b14c739b62ba0</a>
-<blockquote>
-<p>
- Fix a bug with text region rendering in the Patent.pdf example file from<br>
- the adobe's encoder.<br>
-<br>
- The problem was that we weren't handling the export/import of symbols<br>
- from dictionaries referred to by the symbol dictionaries referred to by<br>
- the text region segment.<br>
-<br>
- This patch is just a quick fix: we recurse when building the list of<br>
- referred to symbol dictionaries at text region decode time, which<br>
- allows us to get at all the symbols. This works because the adobe<br>
- encoder (at least in this file) always exports all the symbols, imported<br>
- and encoded, in each dictionary. If it did not, we would have offset<br>
- errors in the symbol lookup.<br>
-<br>
- A proper fix requires decoding the exported symbol flags and building an<br>
- export version of SBSYMS to store in the segment result that includes<br>
- the symbols imported from any other dictionaries. All while<br>
- intelligently sharing the decoded glyph data, of course.<br>
-<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@285 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-11-03 16:39:41 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=51ae6b8a96296c1aab50df9d8cee662d09f155bf">51ae6b8a96296c1aab50df9d8cee662d09f155bf</a>
-<blockquote>
-<p>
- Add a missing header. Record warning fixes in the changelog.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@284 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-11-03 16:38:57 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=04b5524d8767196d4331887cfc6641ada5e5bf42">04b5524d8767196d4331887cfc6641ada5e5bf42</a>
-<blockquote>
-<p>
- Add a 'default' case to the output file format switch to clear up some<br>
- warnings.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@283 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-11-03 16:34:12 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d46b5050cb2ba55fbeb32e70ae368e614ff33d5a">d46b5050cb2ba55fbeb32e70ae368e614ff33d5a</a>
-<blockquote>
-<p>
- Remove an unused variable.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@282 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-11-03 16:32:15 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a9edf8c0252898ffb46431e8b5f7bc79d19634f6">a9edf8c0252898ffb46431e8b5f7bc79d19634f6</a>
-<blockquote>
-<p>
- Add string.h for memset().<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@281 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_mmr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-10-31 12:17:33 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e3232929d33a254885ae6b63e2281eda9595af1e">e3232929d33a254885ae6b63e2281eda9595af1e</a>
-<blockquote>
-<p>
- Cosmetic changes to the bootstrap script.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@280 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-autogen.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-10-27 10:28:24 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=350f6edb35cbe35fbb0ac7add1a1c7e46147a763">350f6edb35cbe35fbb0ac7add1a1c7e46147a763</a>
-<blockquote>
-<p>
- Add a cast to correct an MSVC warning.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@279 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-10-01 19:30:10 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e552e5440e5e285d7df43789a444ccba5727d642">e552e5440e5e285d7df43789a444ccba5727d642</a>
-<blockquote>
-<p>
- Remove an unnecessary check for the symbol id &lt; 0 (it's unsigned) and<br>
- correct a type mismatch. Both of these may have been causing warnings on<br>
- MSVC. Thanks to Igor Melichev for tracking down the problem.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@278 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-10-01 17:05:28 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=539a19a063a962277c04f2c36dbdebc9bad28649">539a19a063a962277c04f2c36dbdebc9bad28649</a>
-<blockquote>
-<p>
- Add protection against uninitialized dictionary lists, as can happen for<br>
- example when parsing a huffman-coded dictionary (nyi).<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@277 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-10-01 14:21:19 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1fd3f35b2f031f1cad486daeff3f625588745e33">1fd3f35b2f031f1cad486daeff3f625588745e33</a>
-<blockquote>
-<p>
- Correct an allocation size bug that caused memory access errors when the<br>
- initial buffer handed to jbig_data_in() didn't match the internal 4k<br>
- size. Thanks to Tor for reporting the bug.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@276 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-09-29 15:33:48 +0000
-</strong>
-<br>tor &lt;tor@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bcc1da0257a3f721a4ca95421a996969b8bfb2f6">bcc1da0257a3f721a4ca95421a996969b8bfb2f6</a>
-<blockquote>
-<p>
- Bounds checking and fixed bug with a0 and black background<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@275 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_mmr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-09-04 04:56:28 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=848fce58b72d73a7345e713f26591674bd019c78">848fce58b72d73a7345e713f26591674bd019c78</a>
-<blockquote>
-<p>
- Update the changelog (nothing new to report).<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@274 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-09-03 07:27:00 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c5bd9271ff22faa44bfe4d0120562c52fa964237">c5bd9271ff22faa44bfe4d0120562c52fa964237</a>
-<blockquote>
-<p>
- Add some uint*_t typedefs for cygwin. Cygwin apparently doesn't provide stdint.h, but does define<br>
- some of the types in sys/types.h which conflict with the versions in config_types.h. We only use<br>
- sys/types.h in snprintf.c, but it's pulled in by Ghostscript's portability cruft when we're<br>
- compiling in rather than linking to that program. Thus we must circumvent the config_types.h<br>
- definitions on that platfrom.<br>
-<br>
- After a patch by Alex Cherepanov.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@273 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-os_types.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-09-03 06:40:03 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9d23c17acdea2efdbed778078e377c3325106de2">9d23c17acdea2efdbed778078e377c3325106de2</a>
-<blockquote>
-<p>
- Add double include protection to os_types.h.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@272 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-os_types.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-09-03 02:56:29 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=29466e003185c7d4ea43e3a1633c0aa8a6286e7f">29466e003185c7d4ea43e3a1633c0aa8a6286e7f</a>
-<blockquote>
-<p>
- Apply a patch to support compilation on VMS (as part of Ghostscript with openvms.mmk). Closes<br>
- http://bugs.ghostscript.com/show_bug.cgi?id=686966.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@271 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-os_types.h<br>
-snprintf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-08-01 14:57:32 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a11b2b5223c1f1704105ed5a26c319e7efeba5de">a11b2b5223c1f1704105ed5a26c319e7efeba5de</a>
-<blockquote>
-<p>
- Enable dist-zip since that packaging was the most popular on<br>
- sourceforge.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@270 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-08-01 14:34:10 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cd3bd3d78bb76152b58a6d529a4c34970fb03986">cd3bd3d78bb76152b58a6d529a4c34970fb03986</a>
-<blockquote>
-<p>
- Set release date for 0.4 release.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@267 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-07-16 00:52:05 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b26c92852bd3474fab9730bbcdadf81613ebef7d">b26c92852bd3474fab9730bbcdadf81613ebef7d</a>
-<blockquote>
-<p>
- Replace the if tree for choosing sized int types with an easier to read<br>
- case statement.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@266 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-07-16 00:40:34 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=231a82bff53bdc53098672af60c6436ca99faca4">231a82bff53bdc53098672af60c6436ca99faca4</a>
-<blockquote>
-<p>
- Use JBIG2_DEBUG instead of plain DEBUG for compile-conditional debugging<br>
- output. This reduces unnecessary output when we're compiled with our<br>
- client's CFLAGS. Request from Ray Johnston.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@265 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_arith.c<br>
-jbig2_image.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-06-17 19:24:09 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=69366cad35ef4da5c3c030a4e34c667df2fe900a">69366cad35ef4da5c3c030a4e34c667df2fe900a</a>
-<blockquote>
-<p>
- Automake automatically distributes COPYING, but not LICENSE. :)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@264 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-06-14 11:11:24 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db0078f2e4e5a4db5bf4d489c05a4047a89a0b90">db0078f2e4e5a4db5bf4d489c05a4047a89a0b90</a>
-<blockquote>
-<p>
- Some wording cleanup.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@263 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-06-14 10:20:56 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c98a1913b50905360c05449ca30084ed51c6658a">c98a1913b50905360c05449ca30084ed51c6658a</a>
-<blockquote>
-<p>
- Grant GPL exception for linking to AFPL Ghostscript.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@262 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-LICENSE<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-06-14 10:15:52 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c0bc856d478246a9a5f0f6b264880fee99084a87">c0bc856d478246a9a5f0f6b264880fee99084a87</a>
-<blockquote>
-<p>
- Add banner change to the changelog.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@261 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-06-14 09:40:02 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8cb34f5bcc802d6ce57a78b50dc9c75eb0fe0667">8cb34f5bcc802d6ce57a78b50dc9c75eb0fe0667</a>
-<blockquote>
-<p>
- Turn on keyword substitution so our $Id$ lines get updated in<br>
- subversion.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@260 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-06-13 22:42:55 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=43fcbcd7acbd0b2d64a770ca39590e2356df4337">43fcbcd7acbd0b2d64a770ca39590e2356df4337</a>
-<blockquote>
-<p>
- Update the license headers to use the same legal redirect as Ghostscript<br>
- does. The individual files point to the file LICENSE which contains the<br>
- real license (a pointer to the GPL in COPYING). This simplifies<br>
- remarking for commercial distribution.<br>
-<br>
- Also some minor additional debug prints in the symbol lookup code.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@259 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-LICENSE<br>
-config_win32.h<br>
-jbig2.c<br>
-jbig2.h<br>
-jbig2_arith.c<br>
-jbig2_arith.h<br>
-jbig2_arith_iaid.c<br>
-jbig2_arith_iaid.h<br>
-jbig2_arith_int.c<br>
-jbig2_arith_int.h<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-jbig2_huffman.c<br>
-jbig2_huffman.h<br>
-jbig2_hufftab.h<br>
-jbig2_image.c<br>
-jbig2_image.h<br>
-jbig2_image_pbm.c<br>
-jbig2_image_png.c<br>
-jbig2_metadata.c<br>
-jbig2_metadata.h<br>
-jbig2_mmr.c<br>
-jbig2_mmr.h<br>
-jbig2_page.c<br>
-jbig2_priv.h<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_symbol_dict.h<br>
-jbig2_text.c<br>
-jbig2dec.c<br>
-memcmp.c<br>
-os_types.h<br>
-pbm2png.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-20 12:03:43 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=54850de6b0bf55dd409a699be469a133be564028">54850de6b0bf55dd409a699be469a133be564028</a>
-<blockquote>
-<p>
- Bump version number post-commit.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@258 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-20 10:39:43 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0797f658a74d280ca5bcec76ca932475d3b24be9">0797f658a74d280ca5bcec76ca932475d3b24be9</a>
-<blockquote>
-<p>
- Set date for 0.3 release.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@255 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-20 10:34:03 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cf4c5147c8ecf2babc6a1a816d27ddaf784b2a0f">cf4c5147c8ecf2babc6a1a816d27ddaf784b2a0f</a>
-<blockquote>
-<p>
- Update changelog.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@254 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-20 10:31:54 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4be0d08eaeb704454a7bf1dc95e7b6739fface4e">4be0d08eaeb704454a7bf1dc95e7b6739fface4e</a>
-<blockquote>
-<p>
- Complete implementation of mmr decoding. We now pass another of the ubc test bitstreams!<br>
- (042_3.jb2, mmr generic region) Patch from Tor Andersson.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@253 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_mmr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-20 10:30:43 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=01736665634a1be9b07b275a5a365b56f445d965">01736665634a1be9b07b275a5a365b56f445d965</a>
-<blockquote>
-<p>
- Recorrect a typo in the recommit.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@252 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-os_types.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-07 22:45:42 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=72f228cadf2b189713cdcb92c1cb20facdab0822">72f228cadf2b189713cdcb92c1cb20facdab0822</a>
-<blockquote>
-<p>
- correct a typo.<br>
-<br>
- (recommitted after repository became corrupt. original change date Wed May 7 05:00:33 2003)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@251 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-07 22:44:43 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=96c0fc6a33671822f63d5941e045c8f88e8e3241">96c0fc6a33671822f63d5941e045c8f88e8e3241</a>
-<blockquote>
-<p>
- Add Theo deRaadt's portable (v)snprintf implementation for portability, under<br>
- the BSD license, including advertising. A simple check was added to the configure<br>
- script, but no prototypes, so it may not help any on systems without the functions.<br>
-<br>
- Submission from Jouk Jansen to allow compilation into Ghostscript on OpenVMS.<br>
-<br>
- (recommitted after repository became corrupt. original change date Wed May 7 04:17:39 2003)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@250 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-snprintf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-07 22:41:01 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c65c52c0638fdfd3613fc7becd77410769ac62ec">c65c52c0638fdfd3613fc7becd77410769ac62ec</a>
-<blockquote>
-<p>
- Move HAVE_LIBPNG to the msvc makefile; this shouldn't necessarily be included in the win32 build<br>
- (e.g. in ghostscript) so we only define it in our local msvc makefile.<br>
-<br>
- (recommitted after repository became corrupt. original change Wed May 7 03:48:12 2003)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@249 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-config_win32.h<br>
-msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-07 22:39:09 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1ed232578276caf6e999a2a9c0b6fd8952af659c">1ed232578276caf6e999a2a9c0b6fd8952af659c</a>
-<blockquote>
-<p>
- Further conditionalize the symbol dictionary debug dump: it's now enabled with DUMP_SYMDICT<br>
- instead of just DEBUG.<br>
-<br>
- (recommitted after repository became corrupt. original change date Mon May 5 10:26:31 2003)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@248 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-07 22:34:38 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f525802258cbed79e961d81e15390adf0f597ee">2f525802258cbed79e961d81e15390adf0f597ee</a>
-<blockquote>
-<p>
- Avoid a (spurious) uninitialized variable warning.<br>
-<br>
- (recommitted after repository became corrupt. original change date Mon May 5 10:23:28 2003)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@247 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-07 22:33:22 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e3539c7888e025ebd0847d7099cf0a88b2465c8e">e3539c7888e025ebd0847d7099cf0a88b2465c8e</a>
-<blockquote>
-<p>
- Pass the segment number to fprintf in the default error handler.<br>
-<br>
- (recommitted after repository became corrupt. original change date Mon May 5 10:22:41 2003)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@246 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-07 22:32:15 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5c9498154bb7e722777fcda2294b31535ef06e08">5c9498154bb7e722777fcda2294b31535ef06e08</a>
-<blockquote>
-<p>
- Bump version number post-release.<br>
-<br>
- (recommitted after repository became corrupt. original change date Wed Apr 16 19:42:34 2003)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@245 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-config_win32.h<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-07 22:25:18 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=48db6a4570673a48ee2c911d2259c79437080b54">48db6a4570673a48ee2c911d2259c79437080b54</a>
-<blockquote>
-<p>
- Add brief instructions for building zlib and libpng under MSVC.<br>
- Contributed by Russell Lang.<br>
-<br>
- (recommitted after repository became corrupt. original change date Wed Apr 16 19:00:23 2003)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@242 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-07 16:09:29 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bfea189549eccb3a6f1a81bbd1bbb092ab789b35">bfea189549eccb3a6f1a81bbd1bbb092ab789b35</a>
-<blockquote>
-<p>
- Mention adobe encoder handling in the changelog. We still don't handle multi-page (separate global<br>
- stream) documents properly.<br>
-<br>
- (recommitted after repository became corrupt. original change dated Wed Apr 16 18:45:19 2003)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@241 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-07 16:07:31 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bf2f470f28a35f6670aa9b31214e0624364f992f">bf2f470f28a35f6670aa9b31214e0624364f992f</a>
-<blockquote>
-<p>
- strncasecmp() isn't portable. work around until we can provide our own.<br>
-<br>
- (recommitted after repository became corrupt. original change dated Wed Apr 16 18:44:11 2003)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@240 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-07 16:05:37 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=09f3c413c9112606dc3afae719884151280f4e9d">09f3c413c9112606dc3afae719884151280f4e9d</a>
-<blockquote>
-<p>
- Update changelog for release.<br>
-<br>
- (recommitted after repository became corrupt. original change dated Wed Apr 16 18:13:29 2003)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@239 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-07 16:04:12 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6217b4a900b82dd6af3076e964382a402c0bfbf">a6217b4a900b82dd6af3076e964382a402c0bfbf</a>
-<blockquote>
-<p>
- It turned out not to be feasible to share rules between our MSVC<br>
- makefile and the integration makefile in ghostscript, so remove it.<br>
- msvc.mak is returned to it's previous state except for some additions<br>
- made when common.mak was introduced.<br>
-<br>
- (recommitted after repository became corrupt. original change dated Apr 16 18:10:01 2003)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@238 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-common.mak<br>
-msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-07 16:02:11 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=816d22aedc4bf1bc5d629f3b94b801c2ccf14693">816d22aedc4bf1bc5d629f3b94b801c2ccf14693</a>
-<blockquote>
-<p>
- Remove the warnings flag; -Wall is gcc-specific so we need to turn it on from inside configure if<br>
- at all. There is an AC_COMPILE_WARNINGS() in the GNU ac-archive.<br>
-<br>
- (recommitted after the repository became corrupt. original change dated Wed Apr 16 15:56:27 2003)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@237 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-07 16:00:32 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e3d615c2d58020492dda10a84ac06977a76035ef">e3d615c2d58020492dda10a84ac06977a76035ef</a>
-<blockquote>
-<p>
- MacOS generally has stdint.h available (Apple's tools on MacOS X or recent Metrowerks CodeWarrior)<br>
- but may not be using the autoconf detection. Include it in such cases.<br>
-<br>
- (recommitted after repository became corrupt. original change date Wed Apr 16 15:48:14 2003)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@236 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-os_types.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-07 15:59:19 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b85c55864583c6955e69f192795a66312b6aabd">7b85c55864583c6955e69f192795a66312b6aabd</a>
-<blockquote>
-<p>
- Add -Wall to the CFLAGS.<br>
-<br>
- (recommitted after repository became corrupt. original change date Wed Apr 16 15:45:59 2003)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@235 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-05-07 15:56:59 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9e4350a4eedb67290d35526d526878ab99d8a1a2">9e4350a4eedb67290d35526d526878ab99d8a1a2</a>
-<blockquote>
-<p>
- Change the declaration to match the prototype.<br>
-<br>
- (recommitted after repository became corrupt; original change Wed Apr 16 15:45:15 2003)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@234 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-04-02 16:17:01 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=de8bf02d7172eba62b4d6a66c608cd9d11773d1e">de8bf02d7172eba62b4d6a66c608cd9d11773d1e</a>
-<blockquote>
-<p>
- Free the output filename.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@232 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-04-02 16:12:17 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=246505fd73f229f252b2ad368006ce234a09b7b9">246505fd73f229f252b2ad368006ce234a09b7b9</a>
-<blockquote>
-<p>
- Try to set the output format based on the extension given in -o if any.<br>
- Also fixes a bug where the format was undefined with -o. (yay valgrind!)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@231 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-04-01 21:57:40 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=362445ced69525d1556b72de5c078b87eed56625">362445ced69525d1556b72de5c078b87eed56625</a>
-<blockquote>
-<p>
- Implement the '-t' option for setting the output file format.<br>
- Useful for forcing pbm output even when compiled with png support.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@230 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-04-01 21:00:23 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e07cbaf880581cb1f808e409725d2b94c55a8630">e07cbaf880581cb1f808e409725d2b94c55a8630</a>
-<blockquote>
-<p>
- Allocate sufficient memory for the referred-to segment list.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@229 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-04-01 20:56:59 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f5ff079d941a29486cc74bf08715b2a24c775af5">f5ff079d941a29486cc74bf08715b2a24c775af5</a>
-<blockquote>
-<p>
- Add some additional comments.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@228 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-03-31 21:27:05 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5e95bfa1388379875a3b329b83046b997c15d853">5e95bfa1388379875a3b329b83046b997c15d853</a>
-<blockquote>
-<p>
- Abstract common build rules to a separate makefile to facilitate building into ghostscript.<br>
- Someone should test that msvc.mak still works.<br>
-<br>
- Ideally we'll make autogen.sh re-create common.mak at some point.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@227 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-common.mak<br>
-msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-03-25 00:17:45 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=96f6a87358df7183b9070a8441cce4a2c2e46541">96f6a87358df7183b9070a8441cce4a2c2e46541</a>
-<blockquote>
-<p>
- add some comments<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@226 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-03-23 22:24:24 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f68c407604a7584cbd9c0b2323530b2451b24eb">8f68c407604a7584cbd9c0b2323530b2451b24eb</a>
-<blockquote>
-<p>
- Mention the new subversion repository.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@225 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-README<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-03-10 14:44:01 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=65b4b234ef4c5d12d8d5f9d624d51595f9e8f14f">65b4b234ef4c5d12d8d5f9d624d51595f9e8f14f</a>
-<blockquote>
-<p>
- add a debug message about segment page association<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@222 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-03-05 14:29:35 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f93bc27cbd73b33ac30122d2ca64aab63ce0e327">f93bc27cbd73b33ac30122d2ca64aab63ce0e327</a>
-<blockquote>
-<p>
- Make jbig2_find_segment() part of the public api and move it to jbig2_segment.c.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@221 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.h<br>
-jbig2_segment.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-03-05 12:25:54 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ce9531e0941d40cd301d1c1dfd15d6b0a4289cc8">ce9531e0941d40cd301d1c1dfd15d6b0a4289cc8</a>
-<blockquote>
-<p>
- correct a nested debug #ifdef<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@220 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-03-05 03:32:41 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c63db75d9076c14e2e7f89f4d93950f51a30d606">c63db75d9076c14e2e7f89f4d93950f51a30d606</a>
-<blockquote>
-<p>
- Update copyright dates on new files.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@219 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_metadata.c<br>
-jbig2_metadata.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-03-05 02:44:43 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22881a46c322b45b34e20b9270e825dbe5c2c1a1">22881a46c322b45b34e20b9270e825dbe5c2c1a1</a>
-<blockquote>
-<p>
- Add support for ASCII-format comment extension segments. So far it's just<br>
- useful for printing out the contents through the error callback; eventually<br>
- there should be a public interface of the metadata tables and references from<br>
- the associated ctx/page/segments.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@218 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-jbig2_metadata.c<br>
-jbig2_metadata.h<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-03-04 17:29:24 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f74ab25a2904a70c3e1e017090aed00cbd4cae3">4f74ab25a2904a70c3e1e017090aed00cbd4cae3</a>
-<blockquote>
-<p>
- Code cleanup: re-order a buffer-size check in the segement header parser to avoid a memory leak on<br>
- failure.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@217 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-03-04 16:52:48 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=21c62259b5fa2ca459e5d0285ba35e1498523b95">21c62259b5fa2ca459e5d0285ba35e1498523b95</a>
-<blockquote>
-<p>
- Switch to automake 1.7 and move the options to Makefile.am.<br>
-<br>
- Sorry, calling automake-1.6 on macosx was causing wierd errors. This was just<br>
- easier. I hope that with 1.7 the am maintainers are finally getting things stable.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@216 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-autogen.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-03-04 16:15:36 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=274ae8d1af9e66b43712a2ca589884cea01e9aee">274ae8d1af9e66b43712a2ca589884cea01e9aee</a>
-<blockquote>
-<p>
- Remove the check for malloc. Since we're assuming C99, it will definitely be there, and recent<br>
- versions of autoconf expect to be able to substitute a wrapper than handles malloc(0) a feature<br>
- we don't depend on.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@215 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-03-04 15:39:00 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cb59bb24b925af295e1a387fc72042c143018e0e">cb59bb24b925af295e1a387fc72042c143018e0e</a>
-<blockquote>
-<p>
- Correct a typo in the previous commit.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@214 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-autogen.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-03-04 15:24:58 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e6ad78534cb77c4ae3beb02c2843f6a546794f13">e6ad78534cb77c4ae3beb02c2843f6a546794f13</a>
-<blockquote>
-<p>
- Try to make autogen.sh smarter about automake version mismatch.<br>
-<br>
- This is really silly, but there's a serious problem with incompatibility<br>
- between the various versions of automake, and while there is a mechanism<br>
- for requesting a particular version in the Makefile.am, most<br>
- installations don't make use of this information, and you're supposed to<br>
- know which automake to call. Since this obviates the point of autogen,<br>
- we attempt to match a requested version in AUTOMAKE_HEADERS to likely<br>
- executables. Probably not very robust.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@213 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-autogen.sh<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-02-11 22:59:54 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cfe0afbb44960be129c6d25fe3287d1ecfc15474">cfe0afbb44960be129c6d25fe3287d1ecfc15474</a>
-<blockquote>
-<p>
- Correct some accidentally-introduced line breaks in the sha1 code.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@212 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-sha1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-02-07 05:14:09 +0000
-</strong>
-<br>raph &lt;raph@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5fb176e3daee8d87d1b6a25eb4d71b03a20694ea">5fb176e3daee8d87d1b6a25eb4d71b03a20694ea</a>
-<blockquote>
-<p>
- Debug message for &quot;referred to segment&quot; had an extra level of<br>
- redirection.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@211 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-02-07 05:06:46 +0000
-</strong>
-<br>raph &lt;raph@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=376546a60ce0bf4ff095f234b1d8ad429b6b450b">376546a60ce0bf4ff095f234b1d8ad429b6b450b</a>
-<blockquote>
-<p>
- Fixes: make find_segment search globals, and also fix off-by-one.<br>
- Disable memcpy optimization in jbig2_image_compose, because it's not<br>
- always valid.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@210 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-02-05 15:27:42 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5e048fb252ff7f9b0355e444b0fb65804e68e1c7">5e048fb252ff7f9b0355e444b0fb65804e68e1c7</a>
-<blockquote>
-<p>
- Use a namespace-prefixed, more verbose name for the MMR huffman tables. They<br>
- were of course conflicting with their counterparts in Ghostscript.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@209 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_mmr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-02-05 15:09:59 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fce47c5bcdb3d0fe30fdc0ac0868a27a76198a2a">fce47c5bcdb3d0fe30fdc0ac0868a27a76198a2a</a>
-<blockquote>
-<p>
- Add double-include protection to the public header.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@208 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-02-03 20:04:11 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=66d05e3c767bad968a98b9f63a88b07cb9df624f">66d05e3c767bad968a98b9f63a88b07cb9df624f</a>
-<blockquote>
-<p>
- Provide a default error handler if the client doesn't specify one,<br>
- analogous to what we do with the allocator. Also, check for failure<br>
- of the initial context allocator and improve api description in the<br>
- public header file.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@207 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-jbig2.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2003-01-27 16:49:28 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8fd3ed86d9a6b47715235d32994bd355f5d99f69">8fd3ed86d9a6b47715235d32994bd355f5d99f69</a>
-<blockquote>
-<p>
- add some files to cvsignore<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@206 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-.cvsignore<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-11-14 12:19:14 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5df2b837e72d1d781fcc29c0d21f82222c2e7af4">5df2b837e72d1d781fcc29c0d21f82222c2e7af4</a>
-<blockquote>
-<p>
- Add the three-page test file from appendix h of the jbig2 spec. This version<br>
- was extracted from the final candidate draft but is identical to the officially<br>
- ratified versions.<br>
-<br>
- Note that we can't actually handle this file yet.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@205 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-annex-h.jbig2<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-15 14:57:53 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f24a7a84cca3fefe41cc459baf692fee6f0cd2ce">f24a7a84cca3fefe41cc459baf692fee6f0cd2ce</a>
-<blockquote>
-<p>
- document portability fixes<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@204 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-15 14:54:45 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=73934fd922618a011046c6fcbd844b26854b584f">73934fd922618a011046c6fcbd844b26854b584f</a>
-<blockquote>
-<p>
- Remove //-style comments for the benifit of those not using gcc.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@203 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-jbig2_image_pbm.c<br>
-jbig2_mmr.c<br>
-jbig2_page.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-15 13:52:28 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6d9d6dd41f859c4dd3fb53c4fccc0ca34ca6a87">c6d9d6dd41f859c4dd3fb53c4fccc0ca34ca6a87</a>
-<blockquote>
-<p>
- checkpoint commit: do-nothing -t option for setting output file type.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@202 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-15 11:55:34 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=771b3b4d02bb7f12c9e08cc602261857499ccefb">771b3b4d02bb7f12c9e08cc602261857499ccefb</a>
-<blockquote>
-<p>
- Prepend -lpng -lz to LIBS to preserve link order dependencies.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@201 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-14 16:58:00 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f5911b3cda06461a8f4fab259bb6f86d5453a0bb">f5911b3cda06461a8f4fab259bb6f86d5453a0bb</a>
-<blockquote>
-<p>
- correct order of pow() check<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@200 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-14 16:07:52 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d113ae2198cca92f0c82f55e1cb792fa66cc6004">d113ae2198cca92f0c82f55e1cb792fa66cc6004</a>
-<blockquote>
-<p>
- Add a --with-libpng[=prefix] option. This can be used to specify the<br>
- prefix where libpng is installed (assuming prefix/include, prefix/lib)<br>
- if it's not on the default search path. It can also be used (as --without-libpng)<br>
- to explicitely disable the png output option.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@199 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-14 14:21:15 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=63165e5f84efb734262603fe81633d7d89e18fe8">63165e5f84efb734262603fe81633d7d89e18fe8</a>
-<blockquote>
-<p>
- libpng calls pow() which on some systems means we need -lm.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@198 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-14 11:44:53 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=377728e4294c745faeec8f63523621e3839bb8ee">377728e4294c745faeec8f63523621e3839bb8ee</a>
-<blockquote>
-<p>
- Remove //-style comments.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@197 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image_pbm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-14 10:31:08 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=229557eb1f5fefdb69c63d38140edbbf5c7b6b6b">229557eb1f5fefdb69c63d38140edbbf5c7b6b6b</a>
-<blockquote>
-<p>
- Declare the test vector (strings) as char instead of unsigned char. We already cast to (uint8_t*) before passing to the hash routines, and the declaration caused a signed/unsigned warning in strlen() on some systems. Thanks to Tom Kacvinsky for this one.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@196 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-sha1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-14 10:25:59 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=834b69f7023a5a3ea9c6e853cde1b67cbce29589">834b69f7023a5a3ea9c6e853cde1b67cbce29589</a>
-<blockquote>
-<p>
- remove spurious semicolon. thanks to Tom Kacvinsky for catching this.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@195 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_arith.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-14 10:22:57 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f30fb27aea0ad95045aa6ce8ae51335268762cf7">f30fb27aea0ad95045aa6ce8ae51335268762cf7</a>
-<blockquote>
-<p>
- Fix up file-ending newlines. After a patch from Tom Kacvinsky.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@194 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-sha1.c<br>
-sha1.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-10 10:39:20 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=865f3114b422acadb98f51f9ffdaf92bfe8e680d">865f3114b422acadb98f51f9ffdaf92bfe8e680d</a>
-<blockquote>
-<p>
- refine const ** to const * const * to avoid warnings.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@193 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-07 12:50:33 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=85bf278b42fe3059dc8774d6f257dbc07ac50679">85bf278b42fe3059dc8774d6f257dbc07ac50679</a>
-<blockquote>
-<p>
- Use callbacks for writing png data out to a file. This is necessary when<br>
- dynamically linking to libpng on win32 when different run-times are used<br>
- for each library. Patch from Russell Lang.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@192 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image_png.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-07 10:18:42 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6aa746d4788e43727f93ed58581ef13f45f5e4b1">6aa746d4788e43727f93ed58581ef13f45f5e4b1</a>
-<blockquote>
-<p>
- bump version post release<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@191 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-config_win32.h<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-06 14:35:38 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=45ced1e5e5c2cb8401bc7784297a905aba29051d">45ced1e5e5c2cb8401bc7784297a905aba29051d</a>
-<blockquote>
-<p>
- cvsignore additions<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@190 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-.cvsignore<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-06 11:52:43 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8a586cd6708d8255128081511e072778cd3f0d76">8a586cd6708d8255128081511e072778cd3f0d76</a>
-<blockquote>
-<p>
- fixup install target<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@188 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-06 11:31:53 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=037a0bdc906e729e42ecb6914c722db0a8f27270">037a0bdc906e729e42ecb6914c722db0a8f27270</a>
-<blockquote>
-<p>
- fix a typo<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@186 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image_png.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-06 11:30:58 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b55adb9e7e662440502d9a7a5558ce69f3f1dff">4b55adb9e7e662440502d9a7a5558ce69f3f1dff</a>
-<blockquote>
-<p>
- Wrap the README at 72 character-per-line and add links to the website and<br>
- mailing list.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@184 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-README<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-06 11:27:08 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4fa4291e3366e1794fcb594d5b1c1aea8c293e2f">4fa4291e3366e1794fcb594d5b1c1aea8c293e2f</a>
-<blockquote>
-<p>
- add the msvc makefile to the dist target<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@183 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-06 11:15:29 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bad2f808eed9cae57d030f76b3bb22f57618115e">bad2f808eed9cae57d030f76b3bb22f57618115e</a>
-<blockquote>
-<p>
- Add some casts to avoid MSVC warnings where it improves readability.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@181 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_arith.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-06 10:57:49 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db6ba0ba18e02d73fcfcbdbddde043f8b841130f">db6ba0ba18e02d73fcfcbdbddde043f8b841130f</a>
-<blockquote>
-<p>
- Document png_init_io() not working on win32 when libpng is a dll. Please<br>
- link statically.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@180 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image_png.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-06 10:54:19 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f5debdea11d7e557cacc8d101d2b37784cba2668">f5debdea11d7e557cacc8d101d2b37784cba2668</a>
-<blockquote>
-<p>
- MSVC makefile updates from Russell Lang.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@178 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-05 23:07:54 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9fae8ec8e63aaa7eabdf3a1b87271da507e079d1">9fae8ec8e63aaa7eabdf3a1b87271da507e079d1</a>
-<blockquote>
-<p>
- additional code cleanup inspired by compiler warnings<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@176 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_mmr.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-05 23:00:52 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f8a8d032eda34625e956ad44a607c4243001ea81">f8a8d032eda34625e956ad44a607c4243001ea81</a>
-<blockquote>
-<p>
- remove unused variables<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@174 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-sha1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-05 22:56:51 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b9bdc3ab0c142018713b9ff4155b55525035b061">b9bdc3ab0c142018713b9ff4155b55525035b061</a>
-<blockquote>
-<p>
- Fix incorrect check for error condition; thanks to Russell Lang's MSVC<br>
- compile log for this.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@172 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-05 22:55:02 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=15db0db751e9ea2df2f56c25cce79c02b8bab9be">15db0db751e9ea2df2f56c25cce79c02b8bab9be</a>
-<blockquote>
-<p>
- include string.h for str* prototypes.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@170 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-05 22:47:53 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=19968191d0e439174a62e9db1acda370373014ab">19968191d0e439174a62e9db1acda370373014ab</a>
-<blockquote>
-<p>
- make the buffer rd/wr offsets unsigned ints to avoid signed/unsigned<br>
- warnings. they should really be offset_t, but we're scared to use that<br>
- because no one else does.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@168 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_priv.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-05 22:46:00 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a889e79e5e6b5815428ad9dbe56b11a65c8aa395">a889e79e5e6b5815428ad9dbe56b11a65c8aa395</a>
-<blockquote>
-<p>
- remove an unused variable<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@166 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-05 22:28:15 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c6315036696b95ebec9dbb770283fee37b076fd">2c6315036696b95ebec9dbb770283fee37b076fd</a>
-<blockquote>
-<p>
- Define PACKAGE and VERSION for the win32 build<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@164 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-config_win32.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-05 22:26:21 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=554d849f37c9e0a6b715378feca28c1187fc3c75">554d849f37c9e0a6b715378feca28c1187fc3c75</a>
-<blockquote>
-<p>
- remove an unreferenced variable.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@163 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-05 21:43:26 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=12819e23ead5fb7b54d28df3802d4678c0350a86">12819e23ead5fb7b54d28df3802d4678c0350a86</a>
-<blockquote>
-<p>
- properly pass in the client params with the error callback when opening embedded streams<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@162 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-05 18:06:37 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0f4c012e1c266f010bb0f04b1319e9d5f82308dc">0f4c012e1c266f010bb0f04b1319e9d5f82308dc</a>
-<blockquote>
-<p>
- Add headers and test script to Makefile.am so they get distributed.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@161 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-05 18:06:06 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=84599735f9e9e101f3f7a93002127b60248c7fa3">84599735f9e9e101f3f7a93002127b60248c7fa3</a>
-<blockquote>
-<p>
- remove redundant package and version indications<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@159 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-05 17:10:44 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6455a4bffb866a47732b574d1f2fd105f8b03544">6455a4bffb866a47732b574d1f2fd105f8b03544</a>
-<blockquote>
-<p>
- Add a memcmp() implementation, pulled in by autoconf if it's not available<br>
- or the system version is broken. Don't know where the header's supposed to<br>
- come from, since it defines no symbol for conditionalizing a prototype.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@157 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-memcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-08-05 16:56:19 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d77b454b4a356db81c8db7d0f74e5dc13dc46707">d77b454b4a356db81c8db7d0f74e5dc13dc46707</a>
-<blockquote>
-<p>
- mention reg testing in changelog<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@155 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-20 17:23:15 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0a3078ab2eb1718856a54d53056da4b68d976932">0a3078ab2eb1718856a54d53056da4b68d976932</a>
-<blockquote>
-<p>
- move repeated configuration includes to a new os_types.h<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@153 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-jbig2_arith.c<br>
-jbig2_arith_iaid.c<br>
-jbig2_arith_int.c<br>
-jbig2_generic.c<br>
-jbig2_huffman.c<br>
-jbig2_image.c<br>
-jbig2_image_pbm.c<br>
-jbig2_image_png.c<br>
-jbig2_mmr.c<br>
-jbig2_page.c<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-jbig2dec.c<br>
-os_types.h<br>
-sha1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-20 17:06:04 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a07db105fb7181327662b01282ccae6b69fa67b">7a07db105fb7181327662b01282ccae6b69fa67b</a>
-<blockquote>
-<p>
- require automake 1.6<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@152 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-20 16:19:33 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=988dc4fc92252070dfdc00c7aa44ebc91c2c7a74">988dc4fc92252070dfdc00c7aa44ebc91c2c7a74</a>
-<blockquote>
-<p>
- minor rearrange<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@151 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-sha1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-20 16:09:08 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d306e9ed969ff29bbceb2092ca67d9671e04a6a">4d306e9ed969ff29bbceb2092ca67d9671e04a6a</a>
-<blockquote>
-<p>
- document endian worry<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@150 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-sha1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-20 16:05:14 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=201eeb8a511e28806bf1786ff1b57b8331b34808">201eeb8a511e28806bf1786ff1b57b8331b34808</a>
-<blockquote>
-<p>
- Remove an obsolete AC_SUBST<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@149 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-20 16:07:34 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a61fc54c09021114fae3744f16f4fa6fb79192be">a61fc54c09021114fae3744f16f4fa6fb79192be</a>
-<blockquote>
-<p>
- Space after testing message elipsis.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@148 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-sha1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-20 16:02:24 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bf37c640d04807206926a1fe7b7c501db9225452">bf37c640d04807206926a1fe7b7c501db9225452</a>
-<blockquote>
-<p>
- Replace (optional) linking to the openssl implementation of SHA-1, which<br>
- is not GPL compatible with a native implementation based on Steve Reid's<br>
- public domain implementation from sea-to-sky.net. Our version remains<br>
- public domain, but now requires our autotools-generated headers.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@146 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-configure.ac<br>
-jbig2dec.c<br>
-sha1.c<br>
-sha1.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-17 23:59:29 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=950df8201674a19af5fa5ff61ba7b006b0691edb">950df8201674a19af5fa5ff61ba7b006b0691edb</a>
-<blockquote>
-<p>
- Use the recommended 'generalized' digest api from openssl, still computing<br>
- SHA-1. Treat the hash bytes as unsigned; update the ubc hash values to<br>
- properly printed ones. N.B.: the printing hash still doesn't match the one<br>
- generated by invoking 'openssl dgst -sha1 -hex' on the pbm output with the<br>
- header stripped. I don't understand why.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@144 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-test_jbig2dec.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-17 13:59:47 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e21659fda78e53fdcbed87290a51a178d26788f6">e21659fda78e53fdcbed87290a51a178d26788f6</a>
-<blockquote>
-<p>
- Add a regression test script based on the python unittest framework.<br>
- It looks for known files, runs 'jbig2dec --hash' and compares the result<br>
- to the known correct value. Currently it looks for the ubc test files<br>
- in '../ubc/'<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@143 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-test_jbig2dec.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-17 13:52:53 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d88cf9f4fdb0b874f9544ac54bcbf3b536665096">d88cf9f4fdb0b874f9544ac54bcbf3b536665096</a>
-<blockquote>
-<p>
- comment out debug printouts<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@142 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_mmr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-16 21:19:09 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d8a599b44667b94b66cc94d818ff62ea7826d3d">7d8a599b44667b94b66cc94d818ff62ea7826d3d</a>
-<blockquote>
-<p>
- implement --quiet and --verbose. Verbosity now defaults to '1', which<br>
- only warnings and fatal errors. -v recovers the old behavior. intermediate<br>
- levels can be set with --verbose=n. -q/--quiet is the same as --verbose=0;<br>
- it should supress all messages.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@141 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-15 23:50:47 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=427435dd1db50cb1b88000e6f785fcfe74c3bb0e">427435dd1db50cb1b88000e6f785fcfe74c3bb0e</a>
-<blockquote>
-<p>
- implement --version<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@140 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-15 23:25:30 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dabd594f325487412c44b593b8aae566c3fc9eab">dabd594f325487412c44b593b8aae566c3fc9eab</a>
-<blockquote>
-<p>
- add config_types.h.in, generated by autogen.sh, to the AM MAINTAINERCLEANFILES variable.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@139 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-15 20:01:01 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d53ab5a9d654df525f522afb43c6afeb6c1b6d4b">d53ab5a9d654df525f522afb43c6afeb6c1b6d4b</a>
-<blockquote>
-<p>
- Add a '--hash' cmdline option to print the SHA-1 hash of the decoded<br>
- document. Useful for regression testing. We currently use the openssl/<br>
- libcrypto implemention; there's provision for fallback to a local version<br>
- but I've not written one yet. It should probably just be the default once<br>
- provided.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@138 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-13 01:22:50 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=778b53afed3f8cd0caa85d81a3f1fd0a3a35c446">778b53afed3f8cd0caa85d81a3f1fd0a3a35c446</a>
-<blockquote>
-<p>
- update configure.ac to 2.53, use AC_LIBOBJ() instead of updating LIBOBJS directly<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@137 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-13 01:10:00 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da5605986165e0acfde37fda4dfe594eba8d95d0">da5605986165e0acfde37fda4dfe594eba8d95d0</a>
-<blockquote>
-<p>
- remove 'can define uint32_t as' messages and fix a typo<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@136 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-13 01:04:32 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=31aeca142b98bd794167a31c741bf73b191d6adb">31aeca142b98bd794167a31c741bf73b191d6adb</a>
-<blockquote>
-<p>
- Don't use shell expansions in the init macro arguments; autoconf now provides m4 macros for that.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@135 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-13 00:32:43 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f9e3d8813674fe45ec12a3b75f5ab9024747a41d">f9e3d8813674fe45ec12a3b75f5ab9024747a41d</a>
-<blockquote>
-<p>
- make jbig2_decode_text_region() static<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@134 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-13 00:32:13 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8c096907fe8dd6484d21c45b96ed035fee36b776">8c096907fe8dd6484d21c45b96ed035fee36b776</a>
-<blockquote>
-<p>
- Fix up make_output_filename(), improve usage message.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@133 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-13 00:03:52 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=372fddd151857b3047e1487589e88f4555c0ec9a">372fddd151857b3047e1487589e88f4555c0ec9a</a>
-<blockquote>
-<p>
- ui cleanup. output filename generation is broken<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@132 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-09 10:39:08 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e7ee4564585ddd8cd3ab20af5df840d818be0751">e7ee4564585ddd8cd3ab20af5df840d818be0751</a>
-<blockquote>
-<p>
- protect definitions of TRUE/FALSE<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@131 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_priv.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-09 10:13:13 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=21b56ef9c96211883841f4b55342c805a09619a4">21b56ef9c96211883841f4b55342c805a09619a4</a>
-<blockquote>
-<p>
- Prefer #if defined()<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@130 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-09 10:09:19 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6bb931251b4346a34dca8eafdfa1157c3bf7b339">6bb931251b4346a34dca8eafdfa1157c3bf7b339</a>
-<blockquote>
-<p>
- Correct win32 headers dependency.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@129 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-09 09:49:31 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9f0cd84893d4b71effe4bfd4595d59a5be7f6fc5">9f0cd84893d4b71effe4bfd4595d59a5be7f6fc5</a>
-<blockquote>
-<p>
- We now decode the CVision Starr Report page embedded stream, once extracted from the pdf.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@128 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-09 09:45:32 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=75e38f7a64fa7aace00e9a8a48cdfe1904adecc5">75e38f7a64fa7aace00e9a8a48cdfe1904adecc5</a>
-<blockquote>
-<p>
- Work around missing end-of-page segment in CVision's PDF-embedded jbig2 streams.<br>
- jbig2_complete_page() becomes a public function marking the current page finished<br>
- so the client can call it at end-of-data, since data-shovel interface has no way<br>
- of passing that out-of-band. The segment dispatch calls a new jbig2_parse_end_of_page()<br>
- which does error checking and then calls jbig2_complete_page().<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@126 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.h<br>
-jbig2_page.c<br>
-jbig2_priv.h<br>
-jbig2_segment.c<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-09 09:38:37 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d7d07a0b4a33596ac29f0e3809720e829cf1427b">d7d07a0b4a33596ac29f0e3809720e829cf1427b</a>
-<blockquote>
-<p>
- Correct the dictionary-referral logic in the text segment decoder. Previously<br>
- we were using the decode order index to lookup the referenced segments(s) but<br>
- this breaks if the segment numbers don't begin and 0 and increase one-by-one.<br>
- We now search backward looking for a matching segment number. Should replace<br>
- this with a binary search once we start seeing bigger files.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@125 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-08 19:23:11 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=66b303cfa844f3f8afcebb5d212520cf6de77f7a">66b303cfa844f3f8afcebb5d212520cf6de77f7a</a>
-<blockquote>
-<p>
- additional debug messages<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@124 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_priv.h<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-08 19:21:35 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ca393a748cf39ff0818a4183a6deb272ade44bfb">ca393a748cf39ff0818a4183a6deb272ade44bfb</a>
-<blockquote>
-<p>
- Fix parsing of sequential files.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@123 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-08 14:54:02 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e74e387b2ac9dfb748dc090528bc1debe347afa">0e74e387b2ac9dfb748dc090528bc1debe347afa</a>
-<blockquote>
-<p>
- Add support for building under Microsoft Visual C++ after a patch from Russell Lang. Please test.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@121 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-config_win32.h<br>
-jbig2.c<br>
-jbig2_arith.c<br>
-jbig2_arith_iaid.c<br>
-jbig2_arith_int.c<br>
-jbig2_generic.c<br>
-jbig2_huffman.c<br>
-jbig2_image.c<br>
-jbig2_image_pbm.c<br>
-jbig2_image_png.c<br>
-jbig2_mmr.c<br>
-jbig2_page.c<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-jbig2dec.c<br>
-msvc.mak<br>
-pbm2png.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-08 14:26:03 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=44cbf7cdc4d9c545004218ffc10c41b2fab7c38c">44cbf7cdc4d9c545004218ffc10c41b2fab7c38c</a>
-<blockquote>
-<p>
- Remove the internal include of stdint.h from jbig2.h, enforcing the requirement<br>
- that the calling C file to do so.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@120 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.h<br>
-jbig2_image_pbm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-08 14:19:51 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ea3cbeb28b39fe56c7d791361f969b255fb59bd">7ea3cbeb28b39fe56c7d791361f969b255fb59bd</a>
-<blockquote>
-<p>
- Add a CHANGES document.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@119 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-CHANGES<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-08 14:13:04 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb37c87f0474f8d055520f3cda6fb0ddec667bbf">eb37c87f0474f8d055520f3cda6fb0ddec667bbf</a>
-<blockquote>
-<p>
- add pbm2png to cvsignore<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@117 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-.cvsignore<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-08 14:11:36 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=12c09379bf9380ca153eff8f96ebb84f00d7a000">12c09379bf9380ca153eff8f96ebb84f00d7a000</a>
-<blockquote>
-<p>
- Update pbm2png.c to pass a jbig2 context for the allocator, so that<br>
- it can be linked against the current routines.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@116 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-pbm2png.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-08 14:10:27 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c860cbae3e0b07420dfd2407173673a451a36237">c860cbae3e0b07420dfd2407173673a451a36237</a>
-<blockquote>
-<p>
- Don't look for png.h specifically. This was causing problems with png.h was in an -I in CFLAGS, but not the standard place.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@115 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-08 13:45:50 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af9ddb9b26b13821f97d789f866c09c15bcc254e">af9ddb9b26b13821f97d789f866c09c15bcc254e</a>
-<blockquote>
-<p>
- add config_types.h(.in) to cvsignore<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@114 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-.cvsignore<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-08 13:40:15 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b9d1e45dc2ee18fe0935e174499779f5b2505028">b9d1e45dc2ee18fe0935e174499779f5b2505028</a>
-<blockquote>
-<p>
- Work around stdint.h portability problems. If the C99 header isn't available,<br>
- look for uint32_t in a few other likely headers. Also try and discover appropriate<br>
- sizes and use our own typedefs if no useful header is found.<br>
-<br>
- All this goes into a new generated header file 'config_types.h'. We abuse<br>
- autogen.sh to create the template so it doesn't clutter cvs for non-autotools<br>
- builds.<br>
-<br>
- Include config.h and config_types.h into every file that includes jbig2_priv.h<br>
- so ensure the types are defined.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@112 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-autogen.sh<br>
-configure.ac<br>
-jbig2.c<br>
-jbig2_arith.c<br>
-jbig2_arith_iaid.c<br>
-jbig2_arith_int.c<br>
-jbig2_generic.c<br>
-jbig2_huffman.c<br>
-jbig2_image.c<br>
-jbig2_image_png.c<br>
-jbig2_mmr.c<br>
-jbig2_page.c<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-07 20:38:26 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=63beb9c3beb1b0a0ab3579ab8e7b17b02c0f76f9">63beb9c3beb1b0a0ab3579ab8e7b17b02c0f76f9</a>
-<blockquote>
-<p>
- minor rename<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@111 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_page.c<br>
-jbig2_priv.h<br>
-jbig2_segment.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-07 20:30:57 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c00475e659e7f29c142e879ec3dd9d4b5375ee5">6c00475e659e7f29c142e879ec3dd9d4b5375ee5</a>
-<blockquote>
-<p>
- Handle lossy and intermediate text regions as well as lossless immediate.<br>
- Store the bitmap for intermediate text regions into the segment's result field for later use by a refinement region.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@110 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_segment.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-04 16:33:44 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d85ffd487d624754ce5784fb970e939bc8b9dd5c">d85ffd487d624754ce5784fb970e939bc8b9dd5c</a>
-<blockquote>
-<p>
- API renames. Main loop is now jbig_data_in(data); image=jbig2_page_out();<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@109 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-jbig2.h<br>
-jbig2_page.c<br>
-jbig2_segment.c<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-04 13:54:09 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f94a083d0d5f35721a1fbdd61f2b908ae41b9189">f94a083d0d5f35721a1fbdd61f2b908ae41b9189</a>
-<blockquote>
-<p>
- cvsignore update<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@108 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-.cvsignore<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-04 13:53:38 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4c517739877594997a67dfd383c80c8d3dacc96b">4c517739877594997a67dfd383c80c8d3dacc96b</a>
-<blockquote>
-<p>
- fill out the README<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@107 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-README<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-04 13:34:29 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2048089ff9b99ac20bcfcb4dad4b2238e796db68">2048089ff9b99ac20bcfcb4dad4b2238e796db68</a>
-<blockquote>
-<p>
- Clean up some warnings from MSVC. Thanks to Russell Lang for the report.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@105 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-jbig2_arith_iaid.c<br>
-jbig2_arith_int.c<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-jbig2_image.c<br>
-jbig2_image_pbm.c<br>
-jbig2_mmr.c<br>
-jbig2_page.c<br>
-jbig2_priv.h<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-04 12:08:03 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6515f25ce92cb589a7ed16217dffcc012e08a4ea">6515f25ce92cb589a7ed16217dffcc012e08a4ea</a>
-<blockquote>
-<p>
- Code cleanup (obsuscation?) Turn off excessive debugging output.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@104 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-03 21:51:09 +0000
-</strong>
-<br>raph &lt;raph@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cdac7ee4efe0e16a97c2d564af1b59b60f66e2d3">cdac7ee4efe0e16a97c2d564af1b59b60f66e2d3</a>
-<blockquote>
-<p>
- Fix image compositor. Code is not beautiful, but works.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@103 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-03 19:54:43 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f4a16df4d230a900f2068a268103184da90097e4">f4a16df4d230a900f2068a268103184da90097e4</a>
-<blockquote>
-<p>
- checkpoint compositor development<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@102 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-03 19:43:21 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6820e140bc4b306fb7852ae4994bf6d38f2a906">a6820e140bc4b306fb7852ae4994bf6d38f2a906</a>
-<blockquote>
-<p>
- As per raph's suggestion, switch to byte-wise addressing for the image data.<br>
- It solves some endianness problems, and saves a significant amount of memory<br>
- since page and pattern dictionaries contain many small (&lt; 32 pixels wide)<br>
- images.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@101 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.h<br>
-jbig2_image.c<br>
-jbig2_image_pbm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-03 14:56:15 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=55a01f747fb2b992f7b777f1a2d7ee8cac1e13af">55a01f747fb2b992f7b777f1a2d7ee8cac1e13af</a>
-<blockquote>
-<p>
- Compositors now producing reasonable-looking output.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@100 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-03 00:55:44 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6b872950543e8b6179b301da282baed48ddd6a67">6b872950543e8b6179b301da282baed48ddd6a67</a>
-<blockquote>
-<p>
- checkpoint commit of compositor.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@99 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-03 00:30:20 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=154b1f71742acab16d9106796cede9c3f12a65c8">154b1f71742acab16d9106796cede9c3f12a65c8</a>
-<blockquote>
-<p>
- Oops. Previous stride calculation was correct.<br>
- Also remove obsolete png test code.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@98 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-jbig2_image.c<br>
-jbig2_image_png.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-03 00:10:07 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3b182de2e206756ddcdd715d8f561273f75a62c2">3b182de2e206756ddcdd715d8f561273f75a62c2</a>
-<blockquote>
-<p>
- We've been using (and want) the image stride in bytes, not words.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@97 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.h<br>
-jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-03 00:08:40 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a5f7064637d1d9efe7c0a0920d81f70f99c6d456">a5f7064637d1d9efe7c0a0920d81f70f99c6d456</a>
-<blockquote>
-<p>
- #ifdef the debug fprintf()s. comment cleanup. actually transpose on TRANSPOSED.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@96 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-07-01 19:34:31 +0000
-</strong>
-<br>raph &lt;raph@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c52ccfe9970dc5b709c378d49187ebb2874aa81">6c52ccfe9970dc5b709c378d49187ebb2874aa81</a>
-<blockquote>
-<p>
- Text region decoding now seems to decode 042_10.jb2 correctly. Added<br>
- IAID decoding procedure. Changed jbig2_decode_text_region to use IAID<br>
- procedure. Fixed off-by-one errors in corner alignment calculations.<br>
- Added for (;;) loop for 3c, corresponding to looping over all symbol<br>
- instances in a strip (outer while loop corresponds to looping over all<br>
- strips in the region). Fixed predicates in CURS updating logic.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@94 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-jbig2_arith_iaid.c<br>
-jbig2_arith_iaid.h<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-27 14:02:08 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91c71a44412a052616c45f6e50a0431a103514a8">91c71a44412a052616c45f6e50a0431a103514a8</a>
-<blockquote>
-<p>
- checkpoint in-progress text decoder. close but no data yet.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@93 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-24 23:28:13 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef06d243c1a26abd9223181b8c5751ceb051258e">ef06d243c1a26abd9223181b8c5751ceb051258e</a>
-<blockquote>
-<p>
- another checkpoint of text region decoding work. referred-to segment info is correct now.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@92 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-jbig2_priv.h<br>
-jbig2_segment.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-24 19:09:47 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5613e3f978e406268fe5c42b7da322c0e4bfa7a9">5613e3f978e406268fe5c42b7da322c0e4bfa7a9</a>
-<blockquote>
-<p>
- checkpoint in-progress text region decoding procedures<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@91 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-24 18:44:45 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6752fd2a6859efeabbb29954d5b5d34ec0eb96b">a6752fd2a6859efeabbb29954d5b5d34ec0eb96b</a>
-<blockquote>
-<p>
- use the correct number of bytes in reading the referred-to segment numbers. (still untested)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@90 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-24 18:40:01 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6cb5f391cd0ec8bdc0485780697793b71004429c">6cb5f391cd0ec8bdc0485780697793b71004429c</a>
-<blockquote>
-<p>
- Save referred-to segment numbers. (untested)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@89 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-24 15:51:57 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fcc43c7fb7d236c2c30a2b9eba5fdd52bb84f56a">fcc43c7fb7d236c2c30a2b9eba5fdd52bb84f56a</a>
-<blockquote>
-<p>
- checkpointing work on text region decoder.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@88 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_generic.c<br>
-jbig2_image.c<br>
-jbig2_priv.h<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-22 21:20:38 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=468a9f35baa5c64f3be49f60ba800f72dba501ef">468a9f35baa5c64f3be49f60ba800f72dba501ef</a>
-<blockquote>
-<p>
- Store the decoded symbol dictionary in the result field of the corresponding<br>
- segment.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@86 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-jbig2_symbol_dict.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-22 16:05:45 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f2ac7803db2d376bab0734f3e7629faea7bc7297">f2ac7803db2d376bab0734f3e7629faea7bc7297</a>
-<blockquote>
-<p>
- Gratuitous renaming. Promote the segment header to Jbig2Segment and use it<br>
- to store intermediate results rather than the results objects raph had sketched.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@84 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-jbig2.h<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-jbig2_mmr.c<br>
-jbig2_mmr.h<br>
-jbig2_page.c<br>
-jbig2_priv.h<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_symbol_dict.h<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-22 10:08:43 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7fc72d14be2af5e15866a9124a99b6dafea65dcd">7fc72d14be2af5e15866a9124a99b6dafea65dcd</a>
-<blockquote>
-<p>
- Treat seg_idx=-1 specially in the error callback, since we're using that for<br>
- cases where the segment number is inappropriate or not available.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@83 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-22 09:58:26 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8384a640605066b60d21140504f92d31dd77947f">8384a640605066b60d21140504f92d31dd77947f</a>
-<blockquote>
-<p>
- Interpret '-' as an output filename meaning stdout.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@82 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-22 09:47:31 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=72591b23f58efc91e6b92b85540825f29344d520">72591b23f58efc91e6b92b85540825f29344d520</a>
-<blockquote>
-<p>
- remove the redundant width and height fields from Jbig2GenericRegionParams<br>
- in favor of the dimensions of the passed Jbig2Image<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@81 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-21 23:11:29 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f1012147073d64f79de947930f1ac6b4fca959a">8f1012147073d64f79de947930f1ac6b4fca959a</a>
-<blockquote>
-<p>
- restore original behavior for -DOUTPUT_PBM<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@80 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-21 22:56:54 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=30beab7a07268fe5ccd204fdc621a7fee3489e8f">30beab7a07268fe5ccd204fdc621a7fee3489e8f</a>
-<blockquote>
-<p>
- Update decode_symbol_dict() to use images, fixing a type-related bug from the earlier changes.<br>
- Report debug messages through the official mechanism.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@79 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-21 22:54:03 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=69b79684b3f800c7e22dcd16a1fd28a33d067e92">69b79684b3f800c7e22dcd16a1fd28a33d067e92</a>
-<blockquote>
-<p>
- remove dead code<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@78 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-21 19:11:28 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=acf706d0e91ebcf8b3d73c83d168af6e2de05a25">acf706d0e91ebcf8b3d73c83d168af6e2de05a25</a>
-<blockquote>
-<p>
- remove dead code<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@77 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-21 19:10:02 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=123697184141b211dfd599a1fb2eb94e8079ce5e">123697184141b211dfd599a1fb2eb94e8079ce5e</a>
-<blockquote>
-<p>
- Generic regions decode into Jbig2Image structures, which are then (trivially)<br>
- composited with the page buffer as the final step in handling the segment.<br>
- We now write the page data out at out.png or out.pbm. Compile with -DOUTPUT_PBM<br>
- for the old behavior.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@76 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.h<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-jbig2_image.c<br>
-jbig2_image_pbm.c<br>
-jbig2_mmr.c<br>
-jbig2_mmr.h<br>
-jbig2_page.c<br>
-jbig2_priv.h<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-20 15:42:48 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ed23b26857f9d5324a52730e7504c1a14a2d3161">ed23b26857f9d5324a52730e7504c1a14a2d3161</a>
-<blockquote>
-<p>
- Beginnings of text segment handling. Parse (most of) the text region<br>
- segment header. Move the region segment info parser to jbig2_segment.c<br>
- and jbig2_priv.h since this is shared by all region segment types.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@75 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-jbig2_generic.c<br>
-jbig2_priv.h<br>
-jbig2_segment.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-20 15:40:36 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22320087293f0de716d1e214ee74e1e1da822234">22320087293f0de716d1e214ee74e1e1da822234</a>
-<blockquote>
-<p>
- Fix a precedence bug which prevented using the first page structure.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@74 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-18 13:40:29 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0cad58a5a6857aebb665c79706ba33acabc550fd">0cad58a5a6857aebb665c79706ba33acabc550fd</a>
-<blockquote>
-<p>
- Handle 'page info' segments, and allocate an image buffer based on the page size.<br>
- also adds hooks for final compositing and output of the page buffer.<br>
- in addition, minor code massage and dead code removal; make the image structure<br>
- public.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@72 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-jbig2.h<br>
-jbig2_image.h<br>
-jbig2_page.c<br>
-jbig2_priv.h<br>
-jbig2_segment.c<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-18 09:46:45 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=033b9666bac46060559b74b2f2a620fde5fc7f32">033b9666bac46060559b74b2f2a620fde5fc7f32</a>
-<blockquote>
-<p>
- Add warnings for remaining unhandled segment types. remove dead code.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@71 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-17 21:11:51 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=867871515b0d0bce9d092e66a1a787b45681ad76">867871515b0d0bce9d092e66a1a787b45681ad76</a>
-<blockquote>
-<p>
- add prototypes for segment header routines<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@70 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-17 21:06:38 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5219d82fa11b750c446a1d00d2bc269cea245610">5219d82fa11b750c446a1d00d2bc269cea245610</a>
-<blockquote>
-<p>
- Further segment code rearrangement. Add some comments and promote some bitwise types to unsigned. Also add some diagnostic messages on segment type.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@69 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-17 16:30:20 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dcb620344060d47d77e620d23c0e3e6aa3838f6b">dcb620344060d47d77e620d23c0e3e6aa3838f6b</a>
-<blockquote>
-<p>
- Update the image routines to use the ctx structure for dynamic memory and remove the test framework.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@68 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-jbig2_image.h<br>
-jbig2_image_pbm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-17 13:27:07 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f46505e1adb56bcac9bbf00ec8b264dc50963764">f46505e1adb56bcac9bbf00ec8b264dc50963764</a>
-<blockquote>
-<p>
- add some autotools files to .cvsignore<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@67 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-.cvsignore<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-15 16:16:20 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=559870f8c41c8e7741035e28801cf6f8a911bd25">559870f8c41c8e7741035e28801cf6f8a911bd25</a>
-<blockquote>
-<p>
- actually add the segment header source<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@66 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_segment.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-15 16:02:56 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c47c3b08840eb8e709fad19c018845d2ec00087d">c47c3b08840eb8e709fad19c018845d2ec00087d</a>
-<blockquote>
-<p>
- add segment routines in a separate file. prune the semi-dead jbig2dec.h in<br>
- favor of jbig2.h and jbig2_priv.h. Update to C99 fixed-width types.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@64 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-jbig2.h<br>
-jbig2_huffman.c<br>
-jbig2_huffman.h<br>
-jbig2_hufftab.h<br>
-jbig2_image.c<br>
-jbig2_image_pbm.c<br>
-jbig2_image_png.c<br>
-jbig2_page.c<br>
-jbig2_page.h<br>
-jbig2_priv.h<br>
-jbig2dec.c<br>
-jbig2dec.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-15 15:47:21 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2dce5e044ea710e68b1716ca543800c64ad633aa">2dce5e044ea710e68b1716ca543800c64ad633aa</a>
-<blockquote>
-<p>
- Add -lpng to LIBS when the png library is available.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@63 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-15 14:15:12 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=57c5cda834b84dbec0f4898427bf4283dc2c327d">57c5cda834b84dbec0f4898427bf4283dc2c327d</a>
-<blockquote>
-<p>
- Add page segment parse and dump routines.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@62 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_page.c<br>
-jbig2_page.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-15 14:12:50 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e22ae8f124c9ed5a3ccadbad3a302285d94ffc4c">e22ae8f124c9ed5a3ccadbad3a302285d94ffc4c</a>
-<blockquote>
-<p>
- minor code rearrangement and comments<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@61 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-jbig2_symbol_dict.c<br>
-jbig2_symbol_dict.h<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-05 00:15:57 +0000
-</strong>
-<br>raph &lt;raph@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=43bf50d093b48ad481fc24656b66d34422ac07dc">43bf50d093b48ad481fc24656b66d34422ac07dc</a>
-<blockquote>
-<p>
- Brings code into line with spec. This fixes the SOFTWARE_CONVENTION case<br>
- as well. Thanks to William Rucklidge for spec clarification.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@60 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_arith.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-05 00:03:49 +0000
-</strong>
-<br>raph &lt;raph@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8055e400b7d9b32c355e8c7dc2cf286a59dc1ece">8055e400b7d9b32c355e8c7dc2cf286a59dc1ece</a>
-<blockquote>
-<p>
- Fixes bug in arithmetic integer decoding procedure. Thanks to William<br>
- Rucklidge for providing trace data to help track down the problem.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@59 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_arith_int.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-04 16:51:02 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2d6d6e0c7b2c97e52a3363eae09841a17fe8e272">2d6d6e0c7b2c97e52a3363eae09841a17fe8e272</a>
-<blockquote>
-<p>
- Add pbm import support and a simple 'pbm2png' implementation as a test harness for the image code. No makefile support--just didn't want to lose the code.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@58 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.h<br>
-jbig2_image_pbm.c<br>
-pbm2png.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-06-04 16:47:09 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f508fadb8bfad2296ff963203183ea25ec6d8080">f508fadb8bfad2296ff963203183ea25ec6d8080</a>
-<blockquote>
-<p>
- add some description of the decoder commandline options<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@57 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-05-09 02:29:10 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=693e8b2190c36a706b8b5de4bc3771d8d0acbcd3">693e8b2190c36a706b8b5de4bc3771d8d0acbcd3</a>
-<blockquote>
-<p>
- add getopt implementation for portability to systems w/o getopt_long()<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@55 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-getopt.c<br>
-getopt.h<br>
-getopt1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-05-08 03:03:18 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=04d17fa29806f730e03290b7ab4ee415600ba9e7">04d17fa29806f730e03290b7ab4ee415600ba9e7</a>
-<blockquote>
-<p>
- Code cleanup and rearrangement.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@54 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_mmr.c<br>
-jbig2_symbol_dict.c<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-05-08 02:36:04 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=42ead910c9d9d4e3f6dd69e91be16f5de42ffef7">42ead910c9d9d4e3f6dd69e91be16f5de42ffef7</a>
-<blockquote>
-<p>
- Rename the png output source files, and add pbm output support. Also allow<br>
- writing to a FILE* instead of a filename so we can send things to stdout, etc.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@53 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-jbig2_image.c<br>
-jbig2_image.h<br>
-jbig2_image_pbm.c<br>
-jbig2_image_png.c<br>
-png_image.c<br>
-png_image.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-05-08 02:28:02 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0459e440350325b04aaa0bd1f70120ce1066716b">0459e440350325b04aaa0bd1f70120ce1066716b</a>
-<blockquote>
-<p>
- add autotools files to .cvsignore<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@52 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-.cvsignore<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-05-08 02:27:29 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f12873269a2ab271026afa7640bbba2a73a6a5a7">f12873269a2ab271026afa7640bbba2a73a6a5a7</a>
-<blockquote>
-<p>
- Autoheader and configure fixups.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@51 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-05-08 00:59:20 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab76b7e32ea5c79915b5ebe94a84ae8b4b29ee78">ab76b7e32ea5c79915b5ebe94a84ae8b4b29ee78</a>
-<blockquote>
-<p>
- Rought autotools support.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@50 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-Makefile.am<br>
-autogen.sh<br>
-configure.ac<br>
-makefile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-04-25 23:24:35 +0000
-</strong>
-<br>raph &lt;raph@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0f218050d34326a38a89f07e772a7c4fc350fb10">0f218050d34326a38a89f07e772a7c4fc350fb10</a>
-<blockquote>
-<p>
- Makefile changes to add jbig2_mmr functions.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@49 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-makefile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-04-25 23:24:08 +0000
-</strong>
-<br>raph &lt;raph@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=971100aa3b5f56756fbd31a03ca4212209881f09">971100aa3b5f56756fbd31a03ca4212209881f09</a>
-<blockquote>
-<p>
- Adds partial support for mmr (CCITT 2D fax) decoding. This commit can<br>
- scan Huffman codes, but does not apply the logic to produce run lengths.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@48 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_generic.c<br>
-jbig2_mmr.c<br>
-jbig2_mmr.h<br>
-jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-03-28 08:28:02 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=98a2ac892b58569ae1a5a258c0b502fbf56da0b4">98a2ac892b58569ae1a5a258c0b502fbf56da0b4</a>
-<blockquote>
-<p>
- basic getopt-based commandline parsing<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@47 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-02-19 07:09:16 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef36831c93670a262622d3acad6a208d73d1d81e">ef36831c93670a262622d3acad6a208d73d1d81e</a>
-<blockquote>
-<p>
- simple code cleanup. add license headers, include jbig2dec.h with dead code.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@46 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.h<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-jbig2dec.c<br>
-jbig2dec.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-02-19 05:48:44 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5d215388772fd0c2931cdc4cafca74c1256bfea6">5d215388772fd0c2931cdc4cafca74c1256bfea6</a>
-<blockquote>
-<p>
- Abstract the compiler command.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@45 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-makefile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-02-16 07:25:36 +0000
-</strong>
-<br>raph &lt;raph@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=625abbded569d5ffde7301d497158b0116313f21">625abbded569d5ffde7301d497158b0116313f21</a>
-<blockquote>
-<p>
- Lots of changes: Added template 0 generic decoder. Added &quot;results&quot;<br>
- mechanism to Jbig2Ctx for storing the decoded results, but not yet<br>
- any segments which store their results there. Changed generic region<br>
- API slightly so callers could pass in more context (needed for<br>
- generic region decoding other than generic). Added arithmetic integer<br>
- decoder. Started symbol dictionary decoder. Currently, this decodes<br>
- about 200 symbols from the cvision global dict, then goes haywire.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@43 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-jbig2_arith.c<br>
-jbig2_arith.h<br>
-jbig2_arith_int.c<br>
-jbig2_arith_int.h<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-jbig2_priv.h<br>
-jbig2_symbol_dict.c<br>
-jbig2_symbol_dict.h<br>
-jbig2dec.c<br>
-makefile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-02-15 20:46:30 +0000
-</strong>
-<br>raph &lt;raph@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=107138382e590d3851ba1b5e897a33f2cf27ee4b">107138382e590d3851ba1b5e897a33f2cf27ee4b</a>
-<blockquote>
-<p>
- A good start at generic region decoding. The added jbig2_generic code<br>
- handles GBTEMPLATE=1 with vanilla options and the adaptive template<br>
- pixels in their nominal locations. This is sufficient to successfully<br>
- decode the 042_4.jb2 test stream.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@42 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-jbig2_arith.c<br>
-jbig2_generic.c<br>
-jbig2_generic.h<br>
-jbig2_priv.h<br>
-makefile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-02-13 08:47:18 +0000
-</strong>
-<br>raph &lt;raph@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0a9304dad738268b27556717bf83936c15618506">0a9304dad738268b27556717bf83936c15618506</a>
-<blockquote>
-<p>
- Implementation of new API as discussed on jbig2-dev. Not all logic<br>
- of existing jbig2dec.c has been ported to new codebase - in<br>
- particular, jbig2_read_symbol_dictionary and jbig2_read_page_info.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@41 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-jbig2.h<br>
-jbig2_priv.h<br>
-jbig2dec.c<br>
-jbig2dec.h<br>
-makefile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-02-12 02:19:36 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3a77ab1dd49743f0ed9cc0ad862671f462781bd1">3a77ab1dd49743f0ed9cc0ad862671f462781bd1</a>
-<blockquote>
-<p>
- 'normalize' formatting.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@40 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-02-12 02:19:08 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a2eca8001a79d7df3c848139519bf7b7b9778113">a2eca8001a79d7df3c848139519bf7b7b9778113</a>
-<blockquote>
-<p>
- Standard protection against multiple and C++ inclusion.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@39 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-02-10 01:17:26 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ce1259d7b14345427766fb5c541b41b2c5e1f203">ce1259d7b14345427766fb5c541b41b2c5e1f203</a>
-<blockquote>
-<p>
- Update usage to reflect the embedded stream mode.<br>
- Normalize formatting :)<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@38 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2002-02-09 22:31:53 +0000
-</strong>
-<br>raph &lt;raph@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f0780d5ad41298cf609f8e27d869c534dbcdaa23">f0780d5ad41298cf609f8e27d869c534dbcdaa23</a>
-<blockquote>
-<p>
- Adds some support for &quot;embedded&quot; format, with separate global and page<br>
- streams. Also fixes some minor bugs.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@37 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-08-13 20:31:59 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=30034932cea9e2e37d781763d36b06607b8337be">30034932cea9e2e37d781763d36b06607b8337be</a>
-<blockquote>
-<p>
- Fix image stride calculation, and generate a simpler (checkerboard) test pattern.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@36 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-png_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-08-13 19:51:16 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=595741f11dc91377adf4093b88abccb5b1b30660">595741f11dc91377adf4093b88abccb5b1b30660</a>
-<blockquote>
-<p>
- one-line readme<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@35 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-README<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-08-13 19:50:52 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e42dde61dd9441585efa5874880b1c42dc90687c">e42dde61dd9441585efa5874880b1c42dc90687c</a>
-<blockquote>
-<p>
- start of a .cvsignore<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@34 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-.cvsignore<br>
-jbig2_hufftab.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-08-11 06:46:15 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b82c5a1be026e14a63c6e3ede436acf9590a7610">b82c5a1be026e14a63c6e3ede436acf9590a7610</a>
-<blockquote>
-<p>
- png output now compiles<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@33 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-makefile<br>
-png_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-08-10 23:29:28 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7181b7a84184562ccf72e34c11f75b158b58e61b">7181b7a84184562ccf72e34c11f75b158b58e61b</a>
-<blockquote>
-<p>
- initial image buffer and png output routines<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@32 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_image.c<br>
-jbig2_image.h<br>
-makefile<br>
-png_image.c<br>
-png_image.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-07-05 22:37:44 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=15fbf3afe60b17b958fd38ed902ddae67554f804">15fbf3afe60b17b958fd38ed902ddae67554f804</a>
-<blockquote>
-<p>
- more general huffmann test routine<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@31 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-06-26 00:30:00 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=678523a15572456b68612fafc422d4dee29ca59c">678523a15572456b68612fafc422d4dee29ca59c</a>
-<blockquote>
-<p>
- move the huffman tables to a separate header<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@30 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_huffman.c<br>
-jbig2_huffman.h<br>
-jbig2_hufftab.h<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-06-14 23:09:23 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=47a138b6362c314be4cfd91977ac61b3cf772e0f">47a138b6362c314be4cfd91977ac61b3cf772e0f</a>
-<blockquote>
-<p>
- complain if the file uses the 'random access' layout which we don't handle yet.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@29 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-06-14 08:25:01 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83513ef82b18de95374d8e6c229658735d76af32">83513ef82b18de95374d8e6c229658735d76af32</a>
-<blockquote>
-<p>
- attempt to skip the right number of bytes in long-form segment references.<br>
- attempt to read long page association fields properly. both untested.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@28 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-06-12 23:35:53 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f1a9f2cddd17bc53e0b3952b5f05c7427a493ba7">f1a9f2cddd17bc53e0b3952b5f05c7427a493ba7</a>
-<blockquote>
-<p>
- added parser for the page info segment<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@27 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-06-12 09:56:33 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8a02a862c8fa9f0bb5def02e5ea9ccc1414dabe6">8a02a862c8fa9f0bb5def02e5ea9ccc1414dabe6</a>
-<blockquote>
-<p>
- added complete list of segement types to dump_segment()<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@26 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-06-12 09:15:13 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d498a8c2f375315c2de3c62ea270e447bf0bde44">d498a8c2f375315c2de3c62ea270e447bf0bde44</a>
-<blockquote>
-<p>
- make get_next_word return uint32<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@25 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2dec.c<br>
-jbig2dec.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-06-12 09:09:04 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f77dcdbe70ec1ba574ba25c37de81dfaf27ebc52">f77dcdbe70ec1ba574ba25c37de81dfaf27ebc52</a>
-<blockquote>
-<p>
- more general huffmann test code, borrowing from the arith version.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@24 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-06-10 08:43:48 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bfc0107419650f5f696115c4accf1ab88b923c43">bfc0107419650f5f696115c4accf1ab88b923c43</a>
-<blockquote>
-<p>
- minor comment update<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@23 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_huffman.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-06-10 07:15:10 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c5b572ab3f1e3a243408b84498bb7d7dce808b71">c5b572ab3f1e3a243408b84498bb7d7dce808b71</a>
-<blockquote>
-<p>
- added 'make clean' target<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@22 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-makefile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-06-10 07:09:18 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d9367f7452f9117ce3a7f7649966cb42a2c33995">d9367f7452f9117ce3a7f7649966cb42a2c33995</a>
-<blockquote>
-<p>
- added copyright statements to the source files<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@21 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_arith.c<br>
-jbig2_arith.h<br>
-jbig2_huffman.c<br>
-jbig2_huffman.h<br>
-jbig2dec.c<br>
-jbig2dec.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-06-10 07:03:08 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a2cb3337c3f559fc65d3122d649386c797fbc949">a2cb3337c3f559fc65d3122d649386c797fbc949</a>
-<blockquote>
-<p>
- updated includes for the jbig2dec.h name change<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@20 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_arith.c<br>
-jbig2_huffman.c<br>
-jbig2dec.c<br>
-makefile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-06-10 06:50:58 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4369688dfbf2235ed466f38af4ddd11ab781ceaf">4369688dfbf2235ed466f38af4ddd11ab781ceaf</a>
-<blockquote>
-<p>
- renamed jbig2.* to the more eponymous jbig2dec.*<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@19 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2.c<br>
-jbig2.h<br>
-jbig2dec.c<br>
-jbig2dec.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-05-31 06:23:32 +0000
-</strong>
-<br>raph &lt;raph@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9cd558cd34c857cb3fc15167a754d1619ecc57d3">9cd558cd34c857cb3fc15167a754d1619ecc57d3</a>
-<blockquote>
-<p>
- Fixed API so that context is now an argument to the arithmetic decode<br>
- procedure. Context is also now packed into a byte, and context changes<br>
- are done with a single xor.<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@18 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_arith.c<br>
-jbig2_arith.h<br>
-makefile<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-05-30 21:36:25 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa37e9a7b8c933da66c2850a22c10559f38c68bb">fa37e9a7b8c933da66c2850a22c10559f38c68bb</a>
-<blockquote>
-<p>
- added GPL license<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@16 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-COPYING<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2001-05-30 21:05:43 +0000
-</strong>
-<br>giles &lt;giles@ded80894-8fb9-0310-811b-c03f3676ab4d&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=df5789c4fe4bc7085bac37a70e630c326ffd3965">df5789c4fe4bc7085bac37a70e630c326ffd3965</a>
-<blockquote>
-<p>
- add missing stdio include<br>
-<br>
-<br>
- git-svn-id: http://svn.ghostscript.com/jbig2dec/trunk@15 ded80894-8fb9-0310-811b-c03f3676ab4d<br>
-<br>
-jbig2_arith.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-08 09:58:53 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=faac14fb1532533a811649cef2b68cf95ec50fdf">faac14fb1532533a811649cef2b68cf95ec50fdf</a>
-<blockquote>
-<p>
- Bug 693291: Quote shell variables to support spaces in path.<br>
-<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-10 09:27: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=7254338bbdcc9b80805c644712edd5d24b781fcb">7254338bbdcc9b80805c644712edd5d24b781fcb</a>
-<blockquote>
-<p>
- pdfwrite - linearisation.<br>
-<br>
- First attempt to make pdfwrite emit linearised PDF. THis basiclaly works<br>
- but needs some attention to the shared object table, and memory cleanup<br>
- still needs to be done.<br>
-<br>
- pdfwrite - linearisation project, ma ny changes<br>
-<br>
- Alter rewrite_object to parse the object and alter teh numbers of any objects which it<br>
- references<br>
-<br>
- modify rewrite_object to record the offset of the nely rewritten object in the<br>
- linearised file, so we cna later write an xref.<br>
-<br>
- Numerous 'off by 1' bug fixes relating to object 0 and whether pages are<br>
- numberd from 0 or not.<br>
-<br>
- Write all pages and their objects, and shared objects, in the correct order.<br>
-<br>
- Write a primary xref table.<br>
-<br>
- Record CharProc resource usage by fonts.<br>
-<br>
- pdfwrite - linearisation code<br>
-<br>
- Add code to rewrite the secondary xref with the actual offsets of the objects<br>
-<br>
- Write a dummy primary hint stream<br>
-<br>
- Record the offsets of the primary hint stream and linearisation dictionary.<br>
-<br>
- pdfwrite - linearisation<br>
-<br>
- It turns out that for the hint stream we need to know which objects are used<br>
- on every page (shared or not).<br>
-<br>
- This change laters the record for each resoruce to add an array of integers<br>
- documenting which page(s) the resource is used on, as well as whether it is<br>
- shared or not and so on.<br>
-<br>
- This means that instead of a simple chunk of memory, the record is now a gc<br>
- object, properly tracked and relocated and so on.<br>
-<br>
- Added code to track the location of some more objects in the linearised file,<br>
- for the benefit of the linearisation dictionary.<br>
-<br>
- Added code to rewrite the linearisation dictionary with the final numbers, and the trailer dict with the correct numbers too.<br>
-<br>
- pdfwrite - linearisation various changes<br>
-<br>
- Remove some unused variables to silence compiler warnings<br>
-<br>
- Sort out the object numbering so that the seocond page is object<br>
- number 1 (this is a requirement, but its not obvious in the spec). Make sure<br>
- the 'part 9' objects (Info dict, metadata etc) have number that start after<br>
- all the page objects, unique objects per page, and shared objects.<br>
-<br>
- Move the hint stream generation so that the hint stream is *after* page 1 and its<br>
- resoruces as this is easier to deal with.<br>
-<br>
- pdfwrite - linearisation work<br>
-<br>
- preparing to write hint streams:<br>
-<br>
- first we go back to using a temp file instead of a specific filename (except<br>
- when explicitly debugging).<br>
-<br>
- second we only reorder the existing objects and the linearisation dict.<br>
-<br>
- next we copy these re-oredered objects from the temp file, and insert the<br>
- dummy primary hint stream at the correct location.<br>
-<br>
- Finally we write the primary xref, but taking the size of the inserted hint stream<br>
- into account for the offsets.<br>
-<br>
- In a fit of tidying up, use gp_fseek_64 instead of fseek. Still work to do here.<br>
-<br>
- pdfwrite - linearisation<br>
-<br>
- add preliminary code to write a hint stream (still needs work)<br>
-<br>
- Fix code which wrote teh page object twice for each page.<br>
-<br>
- Various white space tweaking to make the output closer to the MuPDF output<br>
- in an abortive attempt to find out why files are not identified as linearised<br>
- by Acrobat<br>
-<br>
- pdfwrite - linearisation, make files at least 4k<br>
-<br>
- I don't believe it.....<br>
-<br>
- Acrobat won't recognise a file as linearised unless it is at least 4k!<br>
-<br>
- Also added some comments regarding various implementation notes from the<br>
- 1.7 reference<br>
-<br>
- pdfwrite - linearisation, move code into a routine of its own<br>
-<br>
- Modularise the linearisation code somewhat by making it a new routine<br>
- instead of bloating pdf_close still further.<br>
-<br>
- pdfwrite - linearisation, fixes for hint writing<br>
-<br>
-gs/base/gdevpdf.c<br>
-gs/base/gdevpdfb.h<br>
-gs/base/gdevpdfx.h<br>
-gs/base/gdevpdti.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-09 12:24:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b16e0ada5e05737890e5bc340fdb181715ca4794">b16e0ada5e05737890e5bc340fdb181715ca4794</a>
-<blockquote>
-<p>
- Fix the allocation of teh Offsets table so that it doesn't get overrun while<br>
- storing xrefs.<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-09 12:15: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=e6a0ca2b94e4a80d02c2b85044b613d92d416249">e6a0ca2b94e4a80d02c2b85044b613d92d416249</a>
-<blockquote>
-<p>
- fix the size of LastResource so that the Offsets table is large enough to hold all the objects<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-09 11:30: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=b085cd2bb5f95fdf842ad05615e9f411b823d79a">b085cd2bb5f95fdf842ad05615e9f411b823d79a</a>
-<blockquote>
-<p>
- Temporary commit for linearisation code in pdfwrite<br>
-<br>
-gs/base/gdevpdf.c<br>
-gs/base/gdevpdfb.h<br>
-gs/base/gdevpdfe.c<br>
-gs/base/gdevpdfp.c<br>
-gs/base/gdevpdfu.c<br>
-gs/base/gdevpdfx.h<br>
-gs/base/gdevpdtd.c<br>
-gs/base/gdevpdtd.h<br>
-gs/base/gdevpdtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-05 20:03:34 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c26a59a07d226db58c2952aeab65df4d58ee78c2">c26a59a07d226db58c2952aeab65df4d58ee78c2</a>
-<blockquote>
-<p>
- Make sure overprint works with shading pattern. Fix for Bug 693018<br>
-<br>
- For some reason it was believed that overprint was not used with shading patterns<br>
- and so it was disabled. Also had to make sure that the graphic state stored in<br>
- the pattern instance was all up to date with the overprint state.<br>
-<br>
-gs/base/gsptype2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-17 12:43:55 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1ab39e3d51a4d4fc78bd2532ef7141a57db50149">1ab39e3d51a4d4fc78bd2532ef7141a57db50149</a>
-<blockquote>
-<p>
- Enabling of fast threshold code for color source images as well as monochrome images to cmyk devices<br>
-<br>
- Many cases where we could be using the fast thresholding code were disabled due to issues that this<br>
- commit fixes. Some items such as the conversions to planar when the color management transform was<br>
- the identity were not in place. In addition, for subtractive devices, the polarity of the threshold<br>
- array was wrong.<br>
-<br>
-gs/base/gsht.c<br>
-gs/base/gsicc_nocm.c<br>
-gs/base/gxht_thresh.c<br>
-gs/base/gxht_thresh.h<br>
-gs/base/gxicolor.c<br>
-gs/base/gxidata.c<br>
-gs/base/gximage.h<br>
-gs/base/gximono.c<br>
-gs/base/gxipixel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-04 10:04:26 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e7d82066d92d4a4a2709c5dde4c35a4521d029e">4e7d82066d92d4a4a2709c5dde4c35a4521d029e</a>
-<blockquote>
-<p>
- Add overprint support into the pdf14 device group composing<br>
-<br>
- This fixes Bug 693300. This this file had two images. One in a separation color space,<br>
- the other an RGB color space each in their own transparency group.<br>
- Overprint mode was enabled during the spot image drawing, which occurs after the RGB image is drawn.<br>
- During the group pop, there was no code in pdf14_compose_group to account for the overprint condition<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gsovrc.c<br>
-gs/base/gxblend.h<br>
-gs/base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-03 18:44:22 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23796278944b89b2afe2906cb0f725e9c6c8ce11">23796278944b89b2afe2906cb0f725e9c6c8ce11</a>
-<blockquote>
-<p>
- Fix clist_copy_planes to insure that all planes written together. Bug 693234.<br>
-<br>
- The code at 'copy:' checked to make sure that the planes would fit in a<br>
- single cbuf, but did not check to make sure that all of the planes fit in<br>
- the remaining space in the BufferSpace from 'cnext' to 'cend'. The fix is<br>
- to call cmd_write_buffer if all planes don't fit in the current BufferSpace<br>
- so that an 'end_run' byte will not be inserted in the data stream.<br>
-<br>
-gs/base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-04 13:37:28 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c62f5a9f5ead465c1d0fbf2826ba5a00b48a1fdb">c62f5a9f5ead465c1d0fbf2826ba5a00b48a1fdb</a>
-<blockquote>
-<p>
- Fix all GCC warnings in Luratech JPX interface.<br>
-<br>
-gs/base/sjpx_luratech.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-29 16:19: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=40c3e3f2b337d5aad89d49dd9f56bfedf6bcf5e5">40c3e3f2b337d5aad89d49dd9f56bfedf6bcf5e5</a>
-<blockquote>
-<p>
- Remove dependence on jbig2dec auto-generated files<br>
-<br>
- Also provide a workaround for LCMS2 on systems without sqrtf().<br>
-<br>
- No cluster differences<br>
-<br>
-gs/base/Makefile.in<br>
-gs/base/configure.ac<br>
-gs/jbig2dec/Makefile.in<br>
-gs/jbig2dec/aclocal.m4<br>
-gs/jbig2dec/compile<br>
-gs/jbig2dec/config.guess<br>
-gs/jbig2dec/config.h.in<br>
-gs/jbig2dec/config.sub<br>
-gs/jbig2dec/config_types.h.in<br>
-gs/jbig2dec/configure<br>
-gs/jbig2dec/depcomp<br>
-gs/jbig2dec/install-sh<br>
-gs/jbig2dec/ltmain.sh<br>
-gs/jbig2dec/missing<br>
-gs/jbig2dec/mkinstalldirs<br>
-gs/jbig2dec/os_types.h<br>
-gs/jbig2dec/snprintf.c<br>
-gs/jbig2dec/stamp-h1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-03 20:44:43 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=26d8aeede6ce52c5a31720980cfcd096f6bd9f10">26d8aeede6ce52c5a31720980cfcd096f6bd9f10</a>
-<blockquote>
-<p>
- Another softmask memory leak fixed for Bug 693312<br>
-<br>
- Leak was caused by the improper freeing when we have a soft mask created in a band<br>
- where it was not needed.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-03 21:58:34 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=50ed871322720a7e0a01bf7e52509b77529c105e">50ed871322720a7e0a01bf7e52509b77529c105e</a>
-<blockquote>
-<p>
- Bug 693317: ignore multiple tokens between obj and endobj<br>
-<br>
- Detect malformed objects that parse as multiple tokens, replace<br>
- the tokens with null, and issue a warning.<br>
-<br>
-gs/Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-09-03 07:55:32 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e37fa70cb16f286ad00b5573e6d548066d2c913e">e37fa70cb16f286ad00b5573e6d548066d2c913e</a>
-<blockquote>
-<p>
- Fix for memory leak in pdf14 softmask stack. Bug 693312<br>
-<br>
- When a new mask was getting created, it was possible that the stack was already set up with<br>
- softmasks. When blowing away the old mask we need to make sure to go through and clean up<br>
- the stack.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-30 08:10: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=7ade6182ba16cbaf3084a1c9865f265cdd71525f">7ade6182ba16cbaf3084a1c9865f265cdd71525f</a>
-<blockquote>
-<p>
- Bug 692849: Prevent memory corruption by using temp buffer in CCITT decompression.<br>
-<br>
-pcl/rtraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-27 10:12:04 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4bc9598dbefcda47a483ea489409af412467d07f">4bc9598dbefcda47a483ea489409af412467d07f</a>
-<blockquote>
-<p>
- Remove obsolete call to set the path mode. This is now only enable on<br>
- a per graphic basis as needed.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-pcl/pctop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-25 22:02: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=11bb4d6d57ea1a65b254e3013f5d16f406457793">11bb4d6d57ea1a65b254e3013f5d16f406457793</a>
-<blockquote>
-<p>
- Fix another warning detected by Visual Studio (negating an unsigned int).<br>
-<br>
-gs/base/gxfcache.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-25 18:21:28 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f939737f2e6479b815de40f46c20b07f40241124">f939737f2e6479b815de40f46c20b07f40241124</a>
-<blockquote>
-<p>
- Get rid of const warnings with Visual Studio.<br>
-<br>
- There are still warnings, but at least the ones that are easy to fix<br>
- are now gone.<br>
-<br>
-gs/base/gdevdevn.c<br>
-gs/base/gdevdevn.h<br>
-gs/base/gdevdsp.c<br>
-gs/base/gdevmpla.c<br>
-gs/base/gdevp14.c<br>
-gs/base/gxblend.c<br>
-gs/base/gxclip.c<br>
-gs/base/gxipixel.c<br>
-gs/base/gxpcmap.c<br>
-gs/base/gxshade.c<br>
-gs/psi/zcie.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-25 18:18: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=bac3f4be13b133b0c097a6ec426894ddc491f2e0">bac3f4be13b133b0c097a6ec426894ddc491f2e0</a>
-<blockquote>
-<p>
- Change TILE_TYPE_MASK size to avoid a truncation warning from VS.<br>
-<br>
- The value 0x80000000 is problematic for the enum with Visual Studio.<br>
- The TilingType values are from 1 to 3, so 3 bits is plenty.<br>
-<br>
-gs/base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-25 15:15: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=6b12966f995393edb220c4b7bc94bc6eeef48987">6b12966f995393edb220c4b7bc94bc6eeef48987</a>
-<blockquote>
-<p>
- Change hpgl_path_mode to 'bool' (and hpglpathmode PS operators).<br>
-<br>
- In cleaning up some of the type mismatch warnings with VS, this<br>
- needed to be consistent. There are no current users of the PS<br>
- operators, but now these are &lt;bool&gt; .sethpglpathmode - and<br>
- .currenthpglpathmode &lt;bool&gt;.<br>
-<br>
-gs/base/gsstate.c<br>
-gs/base/gsstate.h<br>
-gs/psi/zgstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-24 19:03:34 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d840d02d5fd655c397b08e01a273a4e4e757f96e">d840d02d5fd655c397b08e01a273a4e4e757f96e</a>
-<blockquote>
-<p>
- Bug 692604: improve error messages for invalid arguments.<br>
-<br>
- Inclide the invalid argument in the error message. Suggest to use -s<br>
- instead of -d when the token is an executable name. Most likely,<br>
- the user just tried to define a string.<br>
-<br>
-gs/psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-24 15:29:21 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e6c15fa2ee91c760943a3edd16e123f6879eb45">1e6c15fa2ee91c760943a3edd16e123f6879eb45</a>
-<blockquote>
-<p>
- Bring ghostpdl in-line with jbig2dec<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/jbig2dec/Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-24 01:47:45 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ebe054e32a88a5ea4a52367066f8a8259dd3d5db">ebe054e32a88a5ea4a52367066f8a8259dd3d5db</a>
-<blockquote>
-<p>
- Bug 693299: fix handling of array form of /FilterParms in pdfopt<br>
-<br>
- Array form of /FilterParms attribute was processed like a dictionary,<br>
- smashing the stack, and causing a PS error later.<br>
-<br>
-gs/lib/pdfopt.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-22 12:26:33 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bb15658bdf6b463e62b34e1c3fa779942fa24902">bb15658bdf6b463e62b34e1c3fa779942fa24902</a>
-<blockquote>
-<p>
- Fix clist probelms with copy_planes, writer and reader out of sync.<br>
-<br>
- When uncompressed data was written to the clist with height &gt; 1,<br>
- the last line was not padded. The reader was reading as if all<br>
- lines had the padding. Also fixed cmd_read_short_bits to skip<br>
- the memmove in cases where width_bytes == raster or height == 1.<br>
-<br>
-gs/base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-23 15:12:13 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0279e3ba6819d41a36125fba934aba489e03617b">0279e3ba6819d41a36125fba934aba489e03617b</a>
-<blockquote>
-<p>
- Bug 693298; Memento build tweak for memset.<br>
-<br>
- Don't define memset if someone else has already #defined it. Thanks<br>
- to William Bader.<br>
-<br>
-gs/base/memento.c<br>
-gs/jbig2dec/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-23 15:01: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=2dba4f48cfe258c957da2754547fe22a5cc764f6">2dba4f48cfe258c957da2754547fe22a5cc764f6</a>
-<blockquote>
-<p>
- Fix broken Windows build with patch fb55f251.<br>
-<br>
- This is an extended version of a commit from Ray, fixing a mistake<br>
- that I made. Ray's original version didn't make it into the repo<br>
- due to git problems.<br>
-<br>
- Initialising a struct to { } doesn't work with VS. { 0 } is OK.<br>
-<br>
-gs/base/gsptype1.c<br>
-gs/base/gxcht.c<br>
-gs/base/gxclist.c<br>
-gs/psi/iinit.c<br>
-gs/psi/zmisc2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-23 14:59:05 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=04a0440368a18978049b999722320cbc850c7621">04a0440368a18978049b999722320cbc850c7621</a>
-<blockquote>
-<p>
- Revert &quot;Move memento include from jbig2.h to jbig2_priv.h&quot;<br>
-<br>
- This reverts commit b6dc615180c04d016c6df4e9e7598a0d7c9df02b.<br>
-<br>
- This broke the memento build of gs due to the #defining of<br>
- free/realloc. For now, we'll have to live with the include<br>
- in the public header.<br>
-<br>
-gs/jbig2dec/jbig2.h<br>
-gs/jbig2dec/jbig2_priv.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-23 13: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=b6dc615180c04d016c6df4e9e7598a0d7c9df02b">b6dc615180c04d016c6df4e9e7598a0d7c9df02b</a>
-<blockquote>
-<p>
- Move memento include from jbig2.h to jbig2_priv.h<br>
-<br>
- There is no need to expose memento outside of jbig2. Thanks to<br>
- zeniko for the discussion in bug 693284 that lead to this.<br>
-<br>
-gs/jbig2dec/jbig2.h<br>
-gs/jbig2dec/jbig2_priv.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-23 02:10:20 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2740bef445c51680d831ec40753436291f01760a">2740bef445c51680d831ec40753436291f01760a</a>
-<blockquote>
-<p>
- Bug 693268: reinstate big references.<br>
-<br>
- To make big references compatible with 8-byte alignment on 32-bit Windows<br>
- force ref structure to take 16 bytes by adding a dummy uint64_t member<br>
- to the union.<br>
-<br>
-gs/psi/iref.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-23 00:00:31 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb62043f520985f28ccaf265258ddb31cee79e1e">eb62043f520985f28ccaf265258ddb31cee79e1e</a>
-<blockquote>
-<p>
- Get rid of staticly allocated pseudo-references.<br>
-<br>
- Replace staticly initialized pseudo-references with C strings to<br>
- simplify experiments with reference sizes.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/Resource/Init/gs_res.ps<br>
-gs/psi/iconf.c<br>
-gs/psi/iconf.h<br>
-gs/psi/imain.c<br>
-gs/psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-22 11:20:24 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e53dc6b19a96abed3b4a10c12a284d096b37701">1e53dc6b19a96abed3b4a10c12a284d096b37701</a>
-<blockquote>
-<p>
- More PACIFY_VALGRIND magic<br>
-<br>
- While working on bug 693278, valgrind was showing use of<br>
- uninitialised values. This turns out to be (in part) due to the<br>
- clist recording the padding in bitmaps (which can be uninited).<br>
-<br>
- The PACIFY_VALGRIND magic added here allows this file to run valgrind<br>
- clean.<br>
-<br>
-gs/base/gsptype1.c<br>
-gs/base/gxcht.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-22 09:19:39 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20adaa4a395059c3234c5b49979dc21f70e95bbf">20adaa4a395059c3234c5b49979dc21f70e95bbf</a>
-<blockquote>
-<p>
- Add some PACIFY_VALGRIND stuff for refs.<br>
-<br>
- Seen while investigating bug 693278.<br>
-<br>
-gs/psi/iinit.c<br>
-gs/psi/zmisc2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-22 03:43:09 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb55f251b06fbfdf40cad66432369c4b09aa7627">fb55f251b06fbfdf40cad66432369c4b09aa7627</a>
-<blockquote>
-<p>
- Add code to mask harmless valgrind warnings in DEBUG or PACIFY_VALGRIND builds<br>
-<br>
- Spotted while investigating bug 693278.<br>
-<br>
-gs/base/gsptype1.c<br>
-gs/base/gxclist.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-21 11:44:46 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=69727555e1ff7be4f0af4d8b79f33408181d25ba">69727555e1ff7be4f0af4d8b79f33408181d25ba</a>
-<blockquote>
-<p>
- Bug 693278: SEGV in 09-50.PS - bad enumeration of device colors<br>
-<br>
- Masked device colors were all being enumerated as if they were<br>
- binary halftones. Colored halftones need to be handled differently<br>
- and this was causing this problem. It looks like devn device colors<br>
- should also be handled differently, so changed here too.<br>
-<br>
-gs/base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-20 15:16:18 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d527eade5778811475ea8be4cbba4eeec573b28a">d527eade5778811475ea8be4cbba4eeec573b28a</a>
-<blockquote>
-<p>
- Big 693272; fix SEGV due to optimised interpolation.<br>
-<br>
- When calculating the leftmargin to skip over due to the clipping<br>
- region, we were failing to allow for the fact that dst_width might<br>
- be negative due to an image being horizontally flipped.<br>
-<br>
- Simply using any_abs solves the SEGV and does the right thing, I<br>
- believe.<br>
-<br>
-gs/base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-18 00:22:53 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39fda0d88d35e2df4787b88b7d3e23eb74d59f49">39fda0d88d35e2df4787b88b7d3e23eb74d59f49</a>
-<blockquote>
-<p>
- Bug 692210: fix potential indeterminism in zsetcolor()<br>
-<br>
- The value of a partly-initialized color created by zsetcolor()<br>
- is copied to graphic state and compared with other colors by<br>
- memcmp() in gx_hld_saved_color_equal() Full initialization is<br>
- the easiest way to avoid indeterminism.<br>
-<br>
-gs/psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-17 22:32:25 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=32e1d6b480017d0655b8926b69bb3b7617730665">32e1d6b480017d0655b8926b69bb3b7617730665</a>
-<blockquote>
-<p>
- Bug 692910: fix quoted arguments in ps2epsi.bat<br>
-<br>
- Strip the quotes before assigning the values to environment variables.<br>
- Use the original quoted arguments elsewhere.<br>
-<br>
-gs/lib/ps2epsi.bat<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-17 15:16: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=de8f9636ef6bdbb8af039a44443d7e05c990848e">de8f9636ef6bdbb8af039a44443d7e05c990848e</a>
-<blockquote>
-<p>
- Bug 692040 - automake-1.8 is required in ijs sources<br>
-<br>
- credit to Richard Hughes ( richard@hughsie.com ) for the patch.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/ijs/Makefile.am<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-17 15:09:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d6d4cc55caed5462d7c4b41eb52da93bba854589">d6d4cc55caed5462d7c4b41eb52da93bba854589</a>
-<blockquote>
-<p>
- Bug 692552: Direct building of MacOS X universal binaries<br>
-<br>
- Building universal binaries on OS X is now supported, removing the<br>
- need to build for each architecture, and &quot;lipo&quot; files together.<br>
-<br>
- For this, configure should be called thus:<br>
- ./configure CC=&quot;gcc -arch i386 -arch x86_64&quot; CPP=&quot;gcc -E&quot;<br>
-<br>
- and then invoke &quot;make&quot; normally.<br>
-<br>
- Universal binaries including PPC support are not currently supported.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/arch/osx-x86-x86_64-gcc.h<br>
-gs/base/Makefile.in<br>
-gs/base/configure.ac<br>
-gs/doc/Make.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-09 11:50:21 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fe79c76c8254faba9a2b422543062a577a375fee">fe79c76c8254faba9a2b422543062a577a375fee</a>
-<blockquote>
-<p>
- Bug 692750: have gdevwpr2 &quot;manage&quot; device icc profiles<br>
-<br>
- gdevwpr2 is one of the rare devices that can change its color space during its<br>
- lifetime. Such devices need to &quot;manage&quot; their device ICC profiles directly.<br>
-<br>
- As the cups device is similar, these changes are loosely based on the<br>
- analogous part of gdevcups.c.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevwpr2.c<br>
-gs/base/pcwin.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-17 09:09:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a114739f6e1f8837be17305784fc2ca9cbb6450">9a114739f6e1f8837be17305784fc2ca9cbb6450</a>
-<blockquote>
-<p>
- Bug 693279: font: default base encoding<br>
-<br>
- There is some guess work here: Acrobat appears to be always using<br>
- StandardEcoding as the default encoding for (at least) some non-symbolic<br>
- fonts (rather than, as the spec states, the encoding specified by the font).<br>
- As this is contrary to spec, and we only have a CFF example, I've restricted<br>
- this to only apply to fonts with Subtype Type1C *and* that result in a Type 2<br>
- PS font.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-15 21:32:15 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d5c42d3a14cee808fd889c14805a69adae8eb5b9">d5c42d3a14cee808fd889c14805a69adae8eb5b9</a>
-<blockquote>
-<p>
- Bug 688978: Generate DOCINFO pdfmark<br>
-<br>
- Pass the content of /Info dictionary to the interpreter using<br>
- DOCINFO pdfmark. Also improve error recovery to avoid regression<br>
- on one of our test cases that has broken /Info dictionary.<br>
-<br>
-gs/Resource/Init/pdf_base.ps<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-15 02:19:50 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9c76d00aaf4504cb65fc82771b705c9dc529084a">9c76d00aaf4504cb65fc82771b705c9dc529084a</a>
-<blockquote>
-<p>
- Bug 687950: pass all PDF boxes to pdfmark<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-15 00:27:48 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=437360af2799796c42304faaf9a0cc1e5c6f908c">437360af2799796c42304faaf9a0cc1e5c6f908c</a>
-<blockquote>
-<p>
- Bug 690568: Type usage problem on Itanium.<br>
-<br>
- Commit a contributed patch for Itanium. The patch looks reasonable: size_t is<br>
- a better type than unsigned int to express the offset. The patch has no effect<br>
- on our regression testing.<br>
-<br>
-gs/base/gxobj.h<br>
-gs/psi/igc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-14 18:04:36 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc97d97b74f15a98219f45942485244da1e11bce">dc97d97b74f15a98219f45942485244da1e11bce</a>
-<blockquote>
-<p>
- Add support for 32 bit compile tests in clusterpush.pl<br>
-<br>
-gs/toolbin/localcluster/clusterpush.pl<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-14 13:54:36 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79f9321f6331a6598b6c52887890f0d03afa9f96">79f9321f6331a6598b6c52887890f0d03afa9f96</a>
-<blockquote>
-<p>
- Bug 693273: Use standard setpagedevice instead of a simplified one.<br>
-<br>
- Don't try to save a few milliseconds per page at the expense of correctness.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-13 02:14:41 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=238d6b887693b3dca97ab72d0e669670d8a53079">238d6b887693b3dca97ab72d0e669670d8a53079</a>
-<blockquote>
-<p>
- Partly revert the commit for big objet support.<br>
-<br>
- Unfortunately, 12-byte ref causes SEGV on Win32. 64 and 32 bit Linux<br>
- builds were fine. max object sizes are back to 64K.<br>
-<br>
-gs/psi/iref.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-10 12:12:00 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cfedd260650e7f615ec35cf88bd1bfd00ec502c9">cfedd260650e7f615ec35cf88bd1bfd00ec502c9</a>
-<blockquote>
-<p>
- Fixes 693267 and 693162, the default VMI (vertical motion index) and<br>
- PCL orientaion were not consistent.<br>
-<br>
-pcl/pcpage.c<br>
-pcl/pcursor.c<br>
-pcl/pcursor.h<br>
-pl/pjparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-10 11:59:05 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6dd836c62658cfe38bf2988fd55ee05a9a3870d9">6dd836c62658cfe38bf2988fd55ee05a9a3870d9</a>
-<blockquote>
-<p>
- Adds debug logging for pcl macros.<br>
-<br>
-pcl/pcmacros.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-10 12:59:25 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39c501a222658d754b9ab9540f283d7bd05e19ad">39c501a222658d754b9ab9540f283d7bd05e19ad</a>
-<blockquote>
-<p>
- Fix scaling issues seen with fast halftoning code.<br>
-<br>
- We were missing out the right hand column of source data in images<br>
- (see the turkeys on 09-47N page 2 in comparison to png or<br>
- USE_FAST_CODE=0 renderings); fix this by not subtracting 1 from<br>
- src_size. Don't subtract 1 from data_length (or dest width) either<br>
- to match.<br>
-<br>
- Change dda to do a 'half step' to ensure we are sampling from the<br>
- centre of each pixel (avoids a shift to the right in zoomed up<br>
- images). This requires a new dda init macro - remove the old<br>
- (unused, slower) dda formulation to avoid having to think too hard.<br>
-<br>
-gs/base/gxdda.h<br>
-gs/base/gxicolor.c<br>
-gs/base/gximono.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-10 14:22: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=dba8f75023dc5b1abac7e338a541360a106d9956">dba8f75023dc5b1abac7e338a541360a106d9956</a>
-<blockquote>
-<p>
- Fix bug 690963. Update the plane_extract device for hl color handling.<br>
-<br>
- The plane_extract device (used by pksmraw, pamcmyk32, and bmpsep1 as<br>
- well as gdevbjc_.c) was never updated for many of the newer device<br>
- procedures, including fillpage. This is handled by extending the<br>
- prototype procs for the device so that gx_device_forward_fill_in_procs<br>
- does not use the procs from the target.<br>
-<br>
-gs/base/gdevplnx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-10 15:59:15 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=86f9af6937e76e10a7adad201b06c337b1a9240b">86f9af6937e76e10a7adad201b06c337b1a9240b</a>
-<blockquote>
-<p>
- Increase max object size to 16M.<br>
-<br>
- Increase the size of rsize member of the ref structure from ushort<br>
- to uint_32. This is needed to support large composite objects permitted by current<br>
- PDF specification. On 64-bit systems the actual size of ref didn't change.<br>
- On 32-bit systems the ref has grown to 12 bytes, which caused a couple of<br>
- changes in the alignment and padding code. Finally, the max size of all<br>
- composite objects has been increased to 16M.<br>
-<br>
- This patch leaves large objects exposed PS interpreter.<br>
- Traditional PS limits can be re-imposed on the PS interpreter if<br>
- needed.<br>
-<br>
- The patch results in a couple of progressions on the PDF test base,<br>
- and a few expected differences on PS test files that test traditional<br>
- limits on composite PS objects.<br>
-<br>
-gs/doc/Language.htm<br>
-gs/psi/igcref.c<br>
-gs/psi/int.mak<br>
-gs/psi/iref.h<br>
-gs/psi/zpacked.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-10 13:03:33 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d3ea65bd08665e48525a4f8694276814fdebded7">d3ea65bd08665e48525a4f8694276814fdebded7</a>
-<blockquote>
-<p>
- Correct fast halftoning code in multi plane case.<br>
-<br>
- We were using an incorrect stride in a calculation, resulting in<br>
- corrupted output.<br>
-<br>
-gs/base/gxht_thresh.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-10 09:02: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=c004cd6856445cdb5fccc40b5393ffb72a0d9433">c004cd6856445cdb5fccc40b5393ffb72a0d9433</a>
-<blockquote>
-<p>
- Fix the nsis installer config file.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/psi/nsisinst.nsi<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-09 09:34:02 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23087cc653c4fcaf401715d7f5c6a4509576a21f">23087cc653c4fcaf401715d7f5c6a4509576a21f</a>
-<blockquote>
-<p>
- Merge remote-tracking branches 'origin' and 'origin/OpenJpeg-1.5'<br>
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-09 00:51:35 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=946c6312efc2cbf74875d19fd7b49f3505ab7a81">946c6312efc2cbf74875d19fd7b49f3505ab7a81</a>
-<blockquote>
-<p>
- Apply a patch for CVE-2012-3358<br>
-<br>
- See http://code.google.com/p/openjpeg/source/detail?r=1727<br>
- Other CVE patches are not needed for v.1.5.<br>
-<br>
-gs/openjpeg/libopenjpeg/j2k.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-09 00:45:09 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef85034141b90c05ba0bc5e2ad40f834205b4f2a">ef85034141b90c05ba0bc5e2ad40f834205b4f2a</a>
-<blockquote>
-<p>
- Reapply our patches to OpenJpeg-1.5<br>
-<br>
-gs/openjpeg/libopenjpeg/image.c<br>
-gs/openjpeg/libopenjpeg/j2k.c<br>
-gs/openjpeg/libopenjpeg/jp2.c<br>
-gs/openjpeg/libopenjpeg/jp2.h<br>
-gs/openjpeg/libopenjpeg/openjpeg.c<br>
-gs/openjpeg/libopenjpeg/openjpeg.h<br>
-gs/openjpeg/libopenjpeg/opj_malloc.h<br>
-gs/openjpeg/libopenjpeg/tcd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-08 20:36:38 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e3808ff733ed0d485b67211ad5bcf7aa992c739">4e3808ff733ed0d485b67211ad5bcf7aa992c739</a>
-<blockquote>
-<p>
- Import original OpenJpeg 1.5<br>
-<br>
- This revision doesn't compile. It's here to establish a reference<br>
- for the diffs.<br>
-<br>
-gs/base/openjpeg.mak<br>
-gs/openjpeg/libopenjpeg/CMakeLists.txt<br>
-gs/openjpeg/libopenjpeg/Makefile.am<br>
-gs/openjpeg/libopenjpeg/Makefile.in<br>
-gs/openjpeg/libopenjpeg/cidx_manager.c<br>
-gs/openjpeg/libopenjpeg/cidx_manager.h<br>
-gs/openjpeg/libopenjpeg/cio.c<br>
-gs/openjpeg/libopenjpeg/cio.h<br>
-gs/openjpeg/libopenjpeg/dwt.c<br>
-gs/openjpeg/libopenjpeg/event.c<br>
-gs/openjpeg/libopenjpeg/event.h<br>
-gs/openjpeg/libopenjpeg/image.c<br>
-gs/openjpeg/libopenjpeg/image.h<br>
-gs/openjpeg/libopenjpeg/indexbox_manager.h<br>
-gs/openjpeg/libopenjpeg/j2k.c<br>
-gs/openjpeg/libopenjpeg/j2k.h<br>
-gs/openjpeg/libopenjpeg/j2k_lib.c<br>
-gs/openjpeg/libopenjpeg/j2k_lib.h<br>
-gs/openjpeg/libopenjpeg/jp2.c<br>
-gs/openjpeg/libopenjpeg/jp2.h<br>
-gs/openjpeg/libopenjpeg/mqc.c<br>
-gs/openjpeg/libopenjpeg/openjpeg.c<br>
-gs/openjpeg/libopenjpeg/openjpeg.h<br>
-gs/openjpeg/libopenjpeg/opj_includes.h<br>
-gs/openjpeg/libopenjpeg/opj_malloc.h<br>
-gs/openjpeg/libopenjpeg/phix_manager.c<br>
-gs/openjpeg/libopenjpeg/pi.c<br>
-gs/openjpeg/libopenjpeg/pi.h<br>
-gs/openjpeg/libopenjpeg/ppix_manager.c<br>
-gs/openjpeg/libopenjpeg/t1.c<br>
-gs/openjpeg/libopenjpeg/t2.c<br>
-gs/openjpeg/libopenjpeg/tcd.c<br>
-gs/openjpeg/libopenjpeg/tcd.h<br>
-gs/openjpeg/libopenjpeg/thix_manager.c<br>
-gs/openjpeg/libopenjpeg/tpix_manager.c<br>
-gs/openjpeg/opj_config.h.in.user<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-31 15:25: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=38da6175372319af334d1eb7a4474c98f6881f3d">38da6175372319af334d1eb7a4474c98f6881f3d</a>
-<blockquote>
-<p>
- Pull doc changes from 9.06 release branch.<br>
-<br>
- Update docs for 9.06 release candidate 1.<br>
-<br>
- Update changelog with post 9.06rc1 changes.<br>
-<br>
- Update release date in docs.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pdfopt.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-06 23:37:19 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=402806536e6ce5eb7b76eb7a4c5725ec2bbc4e80">402806536e6ce5eb7b76eb7a4c5725ec2bbc4e80</a>
-<blockquote>
-<p>
- Backport patches CVE problems.<br>
-<br>
- CVE-2009-5030 http://code.google.com/p/openjpeg/source/detail?r=1703<br>
- CVE-2012-1499 http://code.google.com/p/openjpeg/source/detail?r=1330<br>
- CVE-2012-3358 http://code.google.com/p/openjpeg/source/detail?r=1727<br>
-<br>
-gs/openjpeg/libopenjpeg/j2k.c<br>
-gs/openjpeg/libopenjpeg/jp2.c<br>
-gs/openjpeg/libopenjpeg/tcd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-06 18:05:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b3ffd243ae375288c7c08607056dd08dae51018f">b3ffd243ae375288c7c08607056dd08dae51018f</a>
-<blockquote>
-<p>
- Remove devcups from default devices on Windows<br>
-<br>
- Since devcups and its infrastructure were only added to gs to allow gs<br>
- developers who work on Windows to debug cups problems, it's not really<br>
- relevant for normal use.<br>
-<br>
- This change makes it optional, by adding WITH_CUPS=1 to the nmake command<br>
- line arguments.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/ghostscript.vcproj<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-06 17:13:39 +0200
-</strong>
-<br>Sebastian Rasmussen &lt;sebras@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=010b1adedf128a7079729d10ad5a8c1b97c8acec">010b1adedf128a7079729d10ad5a8c1b97c8acec</a>
-<blockquote>
-<p>
- Bug 693256: Free GR_/GB_stats.....<br>
-<br>
- .....as long as retaining them is yet to be implemented<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-06 16:00:08 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ae5e2a73654cb9d2845e053428ebfddd3670c2d">5ae5e2a73654cb9d2845e053428ebfddd3670c2d</a>
-<blockquote>
-<p>
- Workaround libpaper's poor memory management.<br>
-<br>
- libpaper allocates using the stdlib malloc(), and expects the calling code<br>
- to release the memory via stdlib free().<br>
-<br>
- Normally this works fine, but Memento hooks malloc() and free() in the<br>
- pre-processor, so it sees the free() call, but not the malloc() call.<br>
-<br>
- This can result in confusing, spurious errors from memento.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gp_upapr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-06 08:43: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=327da990d82209c411841bbade4fc2a77fb326e7">327da990d82209c411841bbade4fc2a77fb326e7</a>
-<blockquote>
-<p>
- Bug 693223: remove apparently moribund dumphint tool<br>
-<br>
- dumphint.ps and the scripts which call it seem to be of almost no value<br>
- these days, and appear to have suffered &quot;bit rot&quot;. So remove them.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/lib/dumphint<br>
-gs/lib/dumphint.bat<br>
-gs/lib/dumphint.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-04 09:18:50 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ec908d81e3dc999f694356a970f63b66f7e5976">5ec908d81e3dc999f694356a970f63b66f7e5976</a>
-<blockquote>
-<p>
- pdfwrite - fix PDF/X-3 annotation check<br>
-<br>
- The previous commit 7167ebcceae78be8dcec24a059f936a861769cd5 incorrectly<br>
- checked the location of the annotation on the page, and prevented any annotation<br>
- in PDF/X-3 output, whereaas annotations off the page are actually permitted.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpdfm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-03 18:49:32 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=27f22e3a48bafc8a663e08ac1aeb310b302055af">27f22e3a48bafc8a663e08ac1aeb310b302055af</a>
-<blockquote>
-<p>
- First attempt at Windows 8 &quot;Metro&quot; compatibility.<br>
-<br>
- Standard MSVC builds will work for Windows 8 in desktop mode. The<br>
- complexity comes in supporting Windows RT (or &quot;Metro&quot; as Microsoft<br>
- have been calling it). To do Metro builds you need to download<br>
- Microsoft Visual C 2012 Express, and install it into a preview copy<br>
- of Windows 8.<br>
-<br>
- MSVC 2012 Express will not import the existing Solution file (probably<br>
- because it's nmake based), so I've been compiling from the command<br>
- line.<br>
-<br>
- Open a &quot;VS2012 x86 Native Tools Command Prompt&quot; and cd to the gs<br>
- directory. Then use:<br>
-<br>
- nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO=1 METRO=1<br>
-<br>
- to build. For PCL change to main, then use:<br>
-<br>
- nmake -f pcl6_msvc.mak SBR=1 DEVSTUDIO=1 METRO=1<br>
-<br>
- etc.<br>
-<br>
- Things to note:<br>
-<br>
- * There is no message loop in Windows RT and the window handling is<br>
- all via different APIs anyway - so we only support the console<br>
- exe, with no display device.<br>
-<br>
- * We have no registry access so the code just looks at the usual<br>
- environment variables.<br>
-<br>
- * Cups has been disabled (as libcups wants to do useful things like<br>
- http, which won't currently compile under Windows RT).<br>
-<br>
-gs/base/gp_mswin.c<br>
-gs/base/gp_wgetv.c<br>
-gs/base/msvctail.mak<br>
-gs/base/winlib.mak<br>
-gs/psi/dwdll.c<br>
-gs/psi/dwmainc.c<br>
-gs/psi/gsdll32metro.def<br>
-gs/psi/gsdll64metro.def<br>
-gs/psi/msvc.mak<br>
-gs/psi/winint.mak<br>
-language_switch/pspcl6_msvc.mak<br>
-main/pcl6_msvc.mak<br>
-pl/dwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-03 00:32:32 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6070a6f33bebf7538e48219010bc1e4de8341ea8">6070a6f33bebf7538e48219010bc1e4de8341ea8</a>
-<blockquote>
-<p>
- Rip out jasper -- openjpeg is our JPX implementation.<br>
-<br>
-gs/base/Makefile.in<br>
-gs/base/configure.ac<br>
-gs/base/gs.mak<br>
-gs/base/jasper.mak<br>
-gs/base/lib.mak<br>
-gs/base/macgenmcpxml.sh<br>
-gs/base/macos-mcp.mak<br>
-gs/base/msvclib.mak<br>
-gs/base/openvms.mak<br>
-gs/base/openvms.mmk<br>
-gs/base/sjpx.c<br>
-gs/base/sjpx.h<br>
-gs/base/winlib.mak<br>
-gs/jasper/COPYRIGHT<br>
-gs/jasper/INSTALL<br>
-gs/jasper/LICENSE<br>
-gs/jasper/Makefile.am<br>
-gs/jasper/Makefile.in<br>
-gs/jasper/NEWS<br>
-gs/jasper/README<br>
-gs/jasper/acaux/compile<br>
-gs/jasper/acaux/config.guess<br>
-gs/jasper/acaux/config.sub<br>
-gs/jasper/acaux/depcomp<br>
-gs/jasper/acaux/install-sh<br>
-gs/jasper/acaux/ltmain.sh<br>
-gs/jasper/acaux/missing<br>
-gs/jasper/aclocal.m4<br>
-gs/jasper/configure<br>
-gs/jasper/configure.ac<br>
-gs/jasper/data/Makefile.am<br>
-gs/jasper/data/colorprofiles/README<br>
-gs/jasper/data/colorprofiles/erimm.icm<br>
-gs/jasper/data/colorprofiles/esrgb.icm<br>
-gs/jasper/data/colorprofiles/esrgbgrey.icm<br>
-gs/jasper/data/colorprofiles/grey.icm<br>
-gs/jasper/data/colorprofiles/greyromm.icm<br>
-gs/jasper/data/colorprofiles/romm.icm<br>
-gs/jasper/data/colorprofiles/sgray.icm<br>
-gs/jasper/data/colorprofiles/srgb.icm<br>
-gs/jasper/data/colorprofiles/sycc.icm<br>
-gs/jasper/data/images/README<br>
-gs/jasper/data/images/example.mif<br>
-gs/jasper/data/images/example.mif0<br>
-gs/jasper/data/images/feep.pnm<br>
-gs/jasper/data/images/feep2.pnm<br>
-gs/jasper/data/images/goldenears.bmp<br>
-gs/jasper/data/images/goldenears.jpg<br>
-gs/jasper/data/images/goldenears.pnm<br>
-gs/jasper/data/images/goldenears.ras<br>
-gs/jasper/data/images/goldenears_gray.jpg<br>
-gs/jasper/data/images/goldenears_gray.pnm<br>
-gs/jasper/data/images/goldenears_gray.ras<br>
-gs/jasper/data/images/small_16x1.pgm<br>
-gs/jasper/data/images/small_1x1.pgm<br>
-gs/jasper/data/images/stawamuschief.pnm<br>
-gs/jasper/data/images/stawamuschief_gray.pnm<br>
-gs/jasper/data/images/test.pnm<br>
-gs/jasper/doc/README<br>
-gs/jasper/doc/jasper.pdf<br>
-gs/jasper/doc/jpeg2000.pdf<br>
-gs/jasper/jasper.spec<br>
-gs/jasper/jasper.spec.in<br>
-gs/jasper/src/Makefile.am<br>
-gs/jasper/src/Makefile.in<br>
-gs/jasper/src/README<br>
-gs/jasper/src/appl/Makefile.am<br>
-gs/jasper/src/appl/Makefile.in<br>
-gs/jasper/src/appl/dummy.c<br>
-gs/jasper/src/appl/imgcmp.c<br>
-gs/jasper/src/appl/imginfo.c<br>
-gs/jasper/src/appl/jasper.c<br>
-gs/jasper/src/appl/jasper_sdl.c<br>
-gs/jasper/src/appl/jiv.c<br>
-gs/jasper/src/libjasper/Makefile.am<br>
-gs/jasper/src/libjasper/Makefile.in<br>
-gs/jasper/src/libjasper/README<br>
-gs/jasper/src/libjasper/base/Makefile.am<br>
-gs/jasper/src/libjasper/base/Makefile.in<br>
-gs/jasper/src/libjasper/base/jas_cm.c<br>
-gs/jasper/src/libjasper/base/jas_debug.c<br>
-gs/jasper/src/libjasper/base/jas_getopt.c<br>
-gs/jasper/src/libjasper/base/jas_icc.c<br>
-gs/jasper/src/libjasper/base/jas_iccdata.c<br>
-gs/jasper/src/libjasper/base/jas_image.c<br>
-gs/jasper/src/libjasper/base/jas_init.c<br>
-gs/jasper/src/libjasper/base/jas_malloc.c<br>
-gs/jasper/src/libjasper/base/jas_seq.c<br>
-gs/jasper/src/libjasper/base/jas_stream.c<br>
-gs/jasper/src/libjasper/base/jas_string.c<br>
-gs/jasper/src/libjasper/base/jas_tvp.c<br>
-gs/jasper/src/libjasper/base/jas_version.c<br>
-gs/jasper/src/libjasper/bmp/Makefile.am<br>
-gs/jasper/src/libjasper/bmp/Makefile.in<br>
-gs/jasper/src/libjasper/bmp/bmp_cod.c<br>
-gs/jasper/src/libjasper/bmp/bmp_cod.h<br>
-gs/jasper/src/libjasper/bmp/bmp_dec.c<br>
-gs/jasper/src/libjasper/bmp/bmp_enc.c<br>
-gs/jasper/src/libjasper/bmp/bmp_enc.h<br>
-gs/jasper/src/libjasper/dummy.c<br>
-gs/jasper/src/libjasper/include/Makefile.am<br>
-gs/jasper/src/libjasper/include/Makefile.in<br>
-gs/jasper/src/libjasper/include/jasper/Makefile.am<br>
-gs/jasper/src/libjasper/include/jasper/Makefile.in<br>
-gs/jasper/src/libjasper/include/jasper/jas_cm.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_config.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_config_ac.h.in<br>
-gs/jasper/src/libjasper/include/jasper/jas_config_win32.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_debug.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_fix.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_getopt.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_icc.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_image.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_init.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_malloc.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_math.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_seq.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_stream.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_string.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_tvp.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_types.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_version.h<br>
-gs/jasper/src/libjasper/include/jasper/jasper.h<br>
-gs/jasper/src/libjasper/jp2/Makefile.am<br>
-gs/jasper/src/libjasper/jp2/Makefile.in<br>
-gs/jasper/src/libjasper/jp2/jp2_cod.c<br>
-gs/jasper/src/libjasper/jp2/jp2_cod.h<br>
-gs/jasper/src/libjasper/jp2/jp2_dec.c<br>
-gs/jasper/src/libjasper/jp2/jp2_dec.h<br>
-gs/jasper/src/libjasper/jp2/jp2_enc.c<br>
-gs/jasper/src/libjasper/jpc/Makefile.am<br>
-gs/jasper/src/libjasper/jpc/Makefile.in<br>
-gs/jasper/src/libjasper/jpc/jpc_bs.c<br>
-gs/jasper/src/libjasper/jpc/jpc_bs.h<br>
-gs/jasper/src/libjasper/jpc/jpc_cod.h<br>
-gs/jasper/src/libjasper/jpc/jpc_cs.c<br>
-gs/jasper/src/libjasper/jpc/jpc_cs.h<br>
-gs/jasper/src/libjasper/jpc/jpc_dec.c<br>
-gs/jasper/src/libjasper/jpc/jpc_dec.h<br>
-gs/jasper/src/libjasper/jpc/jpc_enc.c<br>
-gs/jasper/src/libjasper/jpc/jpc_enc.h<br>
-gs/jasper/src/libjasper/jpc/jpc_fix.h<br>
-gs/jasper/src/libjasper/jpc/jpc_flt.h<br>
-gs/jasper/src/libjasper/jpc/jpc_math.c<br>
-gs/jasper/src/libjasper/jpc/jpc_math.h<br>
-gs/jasper/src/libjasper/jpc/jpc_mct.c<br>
-gs/jasper/src/libjasper/jpc/jpc_mct.h<br>
-gs/jasper/src/libjasper/jpc/jpc_mqcod.c<br>
-gs/jasper/src/libjasper/jpc/jpc_mqcod.h<br>
-gs/jasper/src/libjasper/jpc/jpc_mqdec.c<br>
-gs/jasper/src/libjasper/jpc/jpc_mqdec.h<br>
-gs/jasper/src/libjasper/jpc/jpc_mqenc.c<br>
-gs/jasper/src/libjasper/jpc/jpc_mqenc.h<br>
-gs/jasper/src/libjasper/jpc/jpc_qmfb.c<br>
-gs/jasper/src/libjasper/jpc/jpc_qmfb.h<br>
-gs/jasper/src/libjasper/jpc/jpc_t1cod.c<br>
-gs/jasper/src/libjasper/jpc/jpc_t1cod.h<br>
-gs/jasper/src/libjasper/jpc/jpc_t1dec.c<br>
-gs/jasper/src/libjasper/jpc/jpc_t1dec.h<br>
-gs/jasper/src/libjasper/jpc/jpc_t1enc.c<br>
-gs/jasper/src/libjasper/jpc/jpc_t1enc.h<br>
-gs/jasper/src/libjasper/jpc/jpc_t2cod.c<br>
-gs/jasper/src/libjasper/jpc/jpc_t2cod.h<br>
-gs/jasper/src/libjasper/jpc/jpc_t2dec.c<br>
-gs/jasper/src/libjasper/jpc/jpc_t2dec.h<br>
-gs/jasper/src/libjasper/jpc/jpc_t2enc.c<br>
-gs/jasper/src/libjasper/jpc/jpc_t2enc.h<br>
-gs/jasper/src/libjasper/jpc/jpc_tagtree.c<br>
-gs/jasper/src/libjasper/jpc/jpc_tagtree.h<br>
-gs/jasper/src/libjasper/jpc/jpc_tsfb.c<br>
-gs/jasper/src/libjasper/jpc/jpc_tsfb.h<br>
-gs/jasper/src/libjasper/jpc/jpc_util.c<br>
-gs/jasper/src/libjasper/jpc/jpc_util.h<br>
-gs/jasper/src/libjasper/jpg/Makefile.am<br>
-gs/jasper/src/libjasper/jpg/Makefile.in<br>
-gs/jasper/src/libjasper/jpg/README<br>
-gs/jasper/src/libjasper/jpg/jpg_cod.h<br>
-gs/jasper/src/libjasper/jpg/jpg_dec.c<br>
-gs/jasper/src/libjasper/jpg/jpg_dummy.c<br>
-gs/jasper/src/libjasper/jpg/jpg_enc.c<br>
-gs/jasper/src/libjasper/jpg/jpg_enc.h<br>
-gs/jasper/src/libjasper/jpg/jpg_jpeglib.h<br>
-gs/jasper/src/libjasper/jpg/jpg_val.c<br>
-gs/jasper/src/libjasper/mif/Makefile.am<br>
-gs/jasper/src/libjasper/mif/Makefile.in<br>
-gs/jasper/src/libjasper/mif/README<br>
-gs/jasper/src/libjasper/mif/mif_cod.c<br>
-gs/jasper/src/libjasper/mif/mif_cod.h<br>
-gs/jasper/src/libjasper/pgx/Makefile.am<br>
-gs/jasper/src/libjasper/pgx/Makefile.in<br>
-gs/jasper/src/libjasper/pgx/pgx_cod.c<br>
-gs/jasper/src/libjasper/pgx/pgx_cod.h<br>
-gs/jasper/src/libjasper/pgx/pgx_dec.c<br>
-gs/jasper/src/libjasper/pgx/pgx_enc.c<br>
-gs/jasper/src/libjasper/pgx/pgx_enc.h<br>
-gs/jasper/src/libjasper/pnm/Makefile.am<br>
-gs/jasper/src/libjasper/pnm/Makefile.in<br>
-gs/jasper/src/libjasper/pnm/pnm_cod.c<br>
-gs/jasper/src/libjasper/pnm/pnm_cod.h<br>
-gs/jasper/src/libjasper/pnm/pnm_dec.c<br>
-gs/jasper/src/libjasper/pnm/pnm_enc.c<br>
-gs/jasper/src/libjasper/pnm/pnm_enc.h<br>
-gs/jasper/src/libjasper/ras/Makefile.am<br>
-gs/jasper/src/libjasper/ras/Makefile.in<br>
-gs/jasper/src/libjasper/ras/ras_cod.c<br>
-gs/jasper/src/libjasper/ras/ras_cod.h<br>
-gs/jasper/src/libjasper/ras/ras_dec.c<br>
-gs/jasper/src/libjasper/ras/ras_enc.c<br>
-gs/jasper/src/libjasper/ras/ras_enc.h<br>
-gs/jasper/src/msvc/Makefile.am<br>
-gs/jasper/src/msvc/Makefile.in<br>
-gs/jasper/src/msvc/README<br>
-gs/jasper/src/msvc/imgcmp.dsp<br>
-gs/jasper/src/msvc/imginfo.dsp<br>
-gs/jasper/src/msvc/jasper.dsp<br>
-gs/jasper/src/msvc/jasper.dsw<br>
-gs/jasper/src/msvc/jiv.dsp<br>
-gs/jasper/src/msvc/libjasper.dsp<br>
-gs/psi/int.mak<br>
-gs/psi/msvc.mak<br>
-gs/psi/nsisinst.nsi<br>
-gs/psi/winint.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-03 09:52: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=7167ebcceae78be8dcec24a059f936a861769cd5">7167ebcceae78be8dcec24a059f936a861769cd5</a>
-<blockquote>
-<p>
- pdfwrite - check annotation placement and Box sizes for PDF/X-3 validity<br>
-<br>
- Bug #693233 &quot;PDF/X-3 created using ghostscript gives preflight errors&quot;<br>
-<br>
- We were not checking the bounds of annotations to ensure they were outside<br>
- the TrimBox or BleedBox (if present). Annotations are not permitted in the<br>
- printable area of a PDF/X-3 file.<br>
-<br>
- In addition we were not checking to see that the TrimBox bounds did not exceed<br>
- the BleedBox or MediaBox.<br>
-<br>
- There seems to be a bug in the Acrobat validation tool which insists that the<br>
- CropBox must not extend past the BleedBox. I can find no justification for<br>
- this in the specification, and indeed the PDF 1.7 spec notes that the CropBox has<br>
- 'no defined relationship with any of the other boundaries' so for now I've chosen<br>
- to ignore this restriction.<br>
-<br>
- No differences expected as PDF/X-3 output is not cluster tested<br>
-<br>
-gs/base/gdevpdf.c<br>
-gs/base/gdevpdfm.c<br>
-gs/base/gdevpdfo.c<br>
-gs/base/gdevpdfo.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-02 23:14:09 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b40b8fdcfdf4fc9f46fd5d2f8e7b88796490970a">b40b8fdcfdf4fc9f46fd5d2f8e7b88796490970a</a>
-<blockquote>
-<p>
- Bug 693185. The limitcheck in validatedevicenspace must match int_remap_color_info_s.<br>
-<br>
- Commit e884e3 masked the failure, but since the test in validatedevicenspace<br>
- used GS_CLIENT_COLOR_MAX_COMPONENTS, the array bounds could still be exceeded.<br>
-<br>
- Note that the confusing error message from the PDF interpreter from comment 1<br>
- still exists unless -dPDFSTOPONERROR is used, which gives a more meaningful<br>
- 'limitcheck' immediately following the 'Do' of the image with 17 DeviceN<br>
- components. Bug 693185 is reopened for the error message as P3.<br>
-<br>
-gs/base/gsccolor.h<br>
-gs/psi/icremap.h<br>
-gs/psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-02 17:27:32 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d8ca80d1cb480702c109414c46e381981c94ddcb">d8ca80d1cb480702c109414c46e381981c94ddcb</a>
-<blockquote>
-<p>
- Get rid of 'icclib' since we now use lcms2 (or optionally lcms).<br>
-<br>
-common/msvc_top.mak<br>
-common/ugcc_top.mak<br>
-gs/base/Makefile.in<br>
-gs/base/gdevpdfk.c<br>
-gs/base/gs.mak<br>
-gs/base/icclib.mak<br>
-gs/base/ijs.mak<br>
-gs/base/macos-mcp.mak<br>
-gs/base/macosx.mak<br>
-gs/base/openvms.mak<br>
-gs/base/openvms.mmk<br>
-gs/base/ugcclib.mak<br>
-gs/base/unix-gcc.mak<br>
-gs/base/unixansi.mak<br>
-gs/base/winlib.mak<br>
-gs/icclib/Licence.txt<br>
-gs/icclib/NOTES<br>
-gs/icclib/Readme.txt<br>
-gs/icclib/icc.c<br>
-gs/icclib/icc.h<br>
-gs/icclib/icc9809.h<br>
-gs/psi/os2.mak<br>
-gs/psi/winint.mak<br>
-gs/psi/zicc.c<br>
-language_switch/pspcl6_gcc.mak<br>
-language_switch/pspcl6_msvc.mak<br>
-main/pcl6_gcc.mak<br>
-main/pcl6_msvc.mak<br>
-svg/svg_gcc.mak<br>
-svg/svg_msvc.mak<br>
-xps/xps_gcc.mak<br>
-xps/xps_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-02 20:34:26 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a884b57b792291a6c713600662ab60718aca3e4f">a884b57b792291a6c713600662ab60718aca3e4f</a>
-<blockquote>
-<p>
- Update documentation for tiffsep planar device<br>
-<br>
- Add in comments about the use of -dMaxSpots as well as the fact that the device,<br>
- and psdcmyk are planar and limited to 64 colorants per page. Also add in a<br>
- hint about using -dMaxSpots when we are processing a Postscript file and bump<br>
- up to the default max limit of 10 colorants. Tested it and it worked nicely.<br>
- Thanks Robin Watts.<br>
-<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevtsep.c<br>
-gs/doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-02 18:27:45 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cfbd3faf503983d35dec119bc4e618e7bae0af30">cfbd3faf503983d35dec119bc4e618e7bae0af30</a>
-<blockquote>
-<p>
- Add -dMaxSpots for tiffsep and psd devices.<br>
-<br>
- psd and tiffsep devices now run with GS_SOFT_MAX_SPOTS spots enabled<br>
- by default (GS_CLIENT_COLOR_MAX_COMPONENTS-4 unless predefined<br>
- differently at build time). The user can change this value using<br>
- -dMaxSpots=X (where 0 &lt;= X &lt;= GS_CLIENT_COLOR_MAX_COMPONENTS-4).<br>
-<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevtsep.c<br>
-gs/base/gsccolor.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-01 17:13: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=974ba5dde88108ba54c10e8c4f2c59fbce2db5cd">974ba5dde88108ba54c10e8c4f2c59fbce2db5cd</a>
-<blockquote>
-<p>
- Add new 'const' compression method for clist bits.<br>
-<br>
- Spot that the compressed bitmap is all identically the same byte<br>
- value (most likely 0 or FF), and if so, send just a single byte.<br>
-<br>
-gs/base/gsbitops.c<br>
-gs/base/gsbitops.h<br>
-gs/base/gxclbits.c<br>
-gs/base/gxcldev.h<br>
-gs/base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-02 09:09: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=fe9465d90b4662eb56c7d0686ea87603b5c238b3">fe9465d90b4662eb56c7d0686ea87603b5c238b3</a>
-<blockquote>
-<p>
- ps2write - don't leave our dictionary on the stack at temination of the output<br>
-<br>
- Bug #693241 &quot; save / restore around pdf2ps output causes invalidrestore&quot;<br>
-<br>
- Although the output of ps2write isn't intended for encapsulation, we do intend<br>
- one day to produce an eps2write (or something) which will be. So we may as<br>
- well fix this now.<br>
-<br>
- Previously we left our internal dictionary on the dictionary stack at the<br>
- end of the output, here we simply 'end' it which removes it from the stack and<br>
- make the output better suited for encapsulation.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-01 22:14: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=2d613c33cda3b5c83ce83a6d9a48a0f5014c922f">2d613c33cda3b5c83ce83a6d9a48a0f5014c922f</a>
-<blockquote>
-<p>
- Fix the -disable-gtk &quot;so&quot; build option<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-01 14:07:49 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=004aeab5298b0a42ff08a1c9e626f41cf799039c">004aeab5298b0a42ff08a1c9e626f41cf799039c</a>
-<blockquote>
-<p>
- Fix lcms2 64-bit value decoding on big endian systems<br>
- that lack 64-bit types or have these types missed by configuration.<br>
-<br>
-gs/lcms2/src/cmsplugin.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-31 16:51:58 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c1532d478d06dcd26d1307942705ce1f05135b7b">c1532d478d06dcd26d1307942705ce1f05135b7b</a>
-<blockquote>
-<p>
- Fix parenthesis typo that caused the return code from sscanf to be ignored.<br>
-<br>
-gs/psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-31 12:26:39 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=60028f89756d3027ddf7f4a1dab09c06d0b1c81a">60028f89756d3027ddf7f4a1dab09c06d0b1c81a</a>
-<blockquote>
-<p>
- Add common unix style scaling suffix support for -d____= parameters.<br>
-<br>
- Supported suffixes are 'k' and 'K' ( *= 1024), 'm' and 'M' ( *= 1024*1024)<br>
- and 'g' and 'G' ( *= 1024*1024*1024). Note that only 1g will not overflow.<br>
- No support is provided for .5g or 1.5g values, but this is better than<br>
- nothing. Both ghostscript and the other ghostpdl apps (that use plmain.c)<br>
- now provide this support.<br>
-<br>
-gs/psi/imainarg.c<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-31 17:53:58 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5876c67ba54ca41499fe4e595d140afa5d0c6120">5876c67ba54ca41499fe4e595d140afa5d0c6120</a>
-<blockquote>
-<p>
- Update tiffsep/tiffsep1 documentation w.r.t downscaler.<br>
-<br>
- Document 32 and 34 ratios. Add extra info to tiffsep1 to distinguish<br>
- it from tiffsep in 1bpp mode.<br>
-<br>
-gs/doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-30 11:17:55 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=19c07c2f90a4fefd149c5e6d32ecb4496f9f01a4">19c07c2f90a4fefd149c5e6d32ecb4496f9f01a4</a>
-<blockquote>
-<p>
- Fix the confusion w.r.t fill_rectangle_hl_color between int and fixed coordinates<br>
-<br>
- This isn't widely used -- for gs_fillpage and for gs_rectfill, but some uses<br>
- were using 'fixed' coordinates (such as gdevpdfd.c) and others implementation<br>
- behaved as if the rect contained 'int' pixel coordinates (gxdcolor.c).<br>
-<br>
-gs/base/gdevabuf.c<br>
-gs/base/gdevdsha.c<br>
-gs/base/gdevmpla.c<br>
-gs/base/gdevnfwd.c<br>
-gs/base/gdevp14.c<br>
-gs/base/gsdps1.c<br>
-gs/base/gsovrc.c<br>
-gs/base/gxclip.c<br>
-gs/base/gxclip2.c<br>
-gs/base/gxclipm.c<br>
-gs/base/gxclrast.c<br>
-gs/base/gxclrect.c<br>
-gs/base/gxdcolor.c<br>
-gs/base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-31 10:50: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=7eabd219b61418db08f1e707deb3dc9e753661f1">7eabd219b61418db08f1e707deb3dc9e753661f1</a>
-<blockquote>
-<p>
- Fix link warnings about bad memset in gdevtsep.c<br>
-<br>
- Due to a mistake on my part, the tiffsep device had a couple of<br>
- memsets in that did nothing; these were intended to clear an array<br>
- of pointers before use. Not clearing the array would only have been<br>
- a problem if we'd hit an error condition in a very small region of<br>
- code, but nonetheless, this is a fix.<br>
-<br>
-gs/base/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-31 08:26: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=1ba0272f00c1de822fff0ac4087446c45f46aeb6">1ba0272f00c1de822fff0ac4087446c45f46aeb6</a>
-<blockquote>
-<p>
- Bump the master version number.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-07 11:49: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=ed033afdc6dcd4a964dd6c54a08e53e807a33a4e">ed033afdc6dcd4a964dd6c54a08e53e807a33a4e</a>
-<blockquote>
-<p>
- Update changelog with post 9.06rc1 changes.<br>
-<br>
- Update release date in docs.<br>
-<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pdfopt.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-08 08:42:26 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22d614c608778edf3fc6ba2481813c9e9e57cc2e">22d614c608778edf3fc6ba2481813c9e9e57cc2e</a>
-<blockquote>
-<p>
- Update product string and release date.<br>
-<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-06 23:37:19 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=291872308da215e1d7e12c8375fcf10dd5e651d2">291872308da215e1d7e12c8375fcf10dd5e651d2</a>
-<blockquote>
-<p>
- Backport patches CVE problems.<br>
-<br>
- CVE-2009-5030 http://code.google.com/p/openjpeg/source/detail?r=1703<br>
- CVE-2012-1499 http://code.google.com/p/openjpeg/source/detail?r=1330<br>
- CVE-2012-3358 http://code.google.com/p/openjpeg/source/detail?r=1727<br>
-<br>
-gs/openjpeg/libopenjpeg/j2k.c<br>
-gs/openjpeg/libopenjpeg/jp2.c<br>
-gs/openjpeg/libopenjpeg/tcd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-06 08:43: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=20157526924fbe59436170085a17e530d08e9807">20157526924fbe59436170085a17e530d08e9807</a>
-<blockquote>
-<p>
- Bug 693223: remove apparently moribund dumphint tool<br>
-<br>
- dumphint.ps and the scripts which call it seem to be of almost no value<br>
- these days, and appear to have suffered &quot;bit rot&quot;. So remove them.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/lib/dumphint<br>
-gs/lib/dumphint.bat<br>
-gs/lib/dumphint.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-02 23:14:09 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e48e87f883df0d39d1409d814c5d15444c3dca07">e48e87f883df0d39d1409d814c5d15444c3dca07</a>
-<blockquote>
-<p>
- Bug 693185. The limitcheck in validatedevicenspace must match int_remap_color_info_s.<br>
-<br>
- Commit e884e3 masked the failure, but since the test in validatedevicenspace<br>
- used GS_CLIENT_COLOR_MAX_COMPONENTS, the array bounds could still be exceeded.<br>
-<br>
- Note that the confusing error message from the PDF interpreter from comment 1<br>
- still exists unless -dPDFSTOPONERROR is used, which gives a more meaningful<br>
- 'limitcheck' immediately following the 'Do' of the image with 17 DeviceN<br>
- components. Bug 693185 is reopened for the error message as P3.<br>
-<br>
-gs/base/gsccolor.h<br>
-gs/psi/icremap.h<br>
-gs/psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-02 20:34:26 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=588c2ee040526fbea470e36e7cbc8e87a503cab9">588c2ee040526fbea470e36e7cbc8e87a503cab9</a>
-<blockquote>
-<p>
- Update documentation for tiffsep planar device<br>
-<br>
- Add in comments about the use of -dMaxSpots as well as the fact that the device,<br>
- and psdcmyk are planar and limited to 64 colorants per page. Also add in a<br>
- hint about using -dMaxSpots when we are processing a Postscript file and bump<br>
- up to the default max limit of 10 colorants. Tested it and it worked nicely.<br>
- Thanks Robin Watts.<br>
-<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevtsep.c<br>
-gs/doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-02 18:27:45 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=836a551b97dd4a8436608b6dcebe8f8fb8632bcd">836a551b97dd4a8436608b6dcebe8f8fb8632bcd</a>
-<blockquote>
-<p>
- Add -dMaxSpots for tiffsep and psd devices.<br>
-<br>
- psd and tiffsep devices now run with GS_SOFT_MAX_SPOTS spots enabled<br>
- by default (ten, unless predefined differently at build time). The<br>
- user can change this value using -dMaxSpots=X (where<br>
- 0 &lt;= X &lt;= GS_CLIENT_COLOR_MAX_COMPONENTS-4).<br>
-<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevtsep.c<br>
-gs/base/gsccolor.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-01 22:14: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=d723d72b3c9f7e171299a5ccc70a5f1ca715a50a">d723d72b3c9f7e171299a5ccc70a5f1ca715a50a</a>
-<blockquote>
-<p>
- Fix the -disable-gtk &quot;so&quot; build option<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-01 14:07:49 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7e7b4ae93066b841c0b1eac539c220b79d7f7a5d">7e7b4ae93066b841c0b1eac539c220b79d7f7a5d</a>
-<blockquote>
-<p>
- Fix lcms2 64-bit value decoding on big endian systems<br>
- that lack 64-bit types or have these types missed by configuration.<br>
-<br>
-gs/lcms2/src/cmsplugin.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-31 17:53:58 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c832985cab3b769d460a3f3e0ae894c2a84fa1ba">c832985cab3b769d460a3f3e0ae894c2a84fa1ba</a>
-<blockquote>
-<p>
- Update tiffsep/tiffsep1 documentation w.r.t downscaler.<br>
-<br>
- Document 32 and 34 ratios. Add extra info to tiffsep1 to distinguish<br>
- it from tiffsep in 1bpp mode.<br>
-<br>
-gs/doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-31 15:25: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=af22330035dc852635b2102353cec1a94504cb88">af22330035dc852635b2102353cec1a94504cb88</a>
-<blockquote>
-<p>
- Update docs for 9.06 release candidate 1.<br>
-<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pdfopt.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-31 10:50: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=76722bee735462eedf4f4c6d9dfa552e3c1f7ebc">76722bee735462eedf4f4c6d9dfa552e3c1f7ebc</a>
-<blockquote>
-<p>
- Fix link warnings about bad memset in gdevtsep.c<br>
-<br>
- Due to a mistake on my part, the tiffsep device had a couple of<br>
- memsets in that did nothing; these were intended to clear an array<br>
- of pointers before use. Not clearing the array would only have been<br>
- a problem if we'd hit an error condition in a very small region of<br>
- code, but nonetheless, this is a fix.<br>
-<br>
-gs/base/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-31 08:40: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=1e7ca769528b822b94ad8d1e498bde44d861637b">1e7ca769528b822b94ad8d1e498bde44d861637b</a>
-<blockquote>
-<p>
- Product string and date updates.<br>
-<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-
-<h2><a name="Version9.06"></a>Version 9.06 (2012-07-31)</h2>
-
-<p>This is the sixth full release in the stable 9.x series.
-
-<p> Highlights in this release include:
-<ul>
-<li>
-<p>PDF/A-2 - pdfwrite now supports the creation of PDF/A-2 files. The 'PDFA'
-command line switch can now take a numeric parameter:
-<ul>
-<li>0 = not PDF/A compliant</li>
-<li>1 = PDF/A-1b compliant</li>
-<li>2 = PDF/A-2b compliant</li>
-</ul>
-<p>Simply specifying &quot;-dPDFA&quot; continues to have the old behaviour of creating PDF/A-1b files.
-For PDF/A-2 the command line should include &quot;-dPDFA=2&quot;.
-<br>
-</li>
-<li>
-<p>pdfwrite &quot;Server mode&quot; - pdfwrite can now be run in &quot;server mode&quot; which allows
-the device to be closed without closing the interpreter. This means it is no
-longer necessary to terminate GS before starting a new PDF conversion. This leads on to:
-<br>
-</li>
-<li>
-<p>pdfwrite now supports the &quot;%d&quot; format in the OutputFile switch. If this is set
-then pdfwrite will output each page of input to an individual file.
-<br>
-</li>
-<li>
-<p>ps2write - recent exposure to a range of PostScript devices has thrown up some
-interesting deficiencies in those devices. ps2write now emits PostScript in
-slightly different ways in order to produce output on a wider variety of devices.
-In some cases this also results in improved print times but it is still important
-to set the resolution appropriately for the output device, especially if the
-input contains transparency.
-<br>
-</li>
-<li>
-<p>Ghostscript can now use output intents defined in PDFs by using the
-&quot;-dUsePDFX3Profile&quot; command line option. See <a href="Use.htm#ICC_color_parameters">ICC Color Parameters</a> for details.
-<br>
-</li>
-<li>
-<p>tiffsep/tiffsep1: support for large numbers of separations improved. The previous
-implementation of those devices utilised a &quot;compressed color encoding&quot; to
-represent the tints for all the plates in one 64 bit value. As the number of
-plates increased, fewer bits were available for the tint for each plate,
-ultimately resulting in an &quot;unencodable pixels&quot; error. These revisions
-remove the reliance on the compressed color encoding, thus ensuring that
-we have a consistent color bit depth, regardless of the number of plates,
-and ensuring the &quot;unencodable pixels&quot; error will never occur.
-<p>Also as a result of these changes, there are substantial performance
-improvements in jobs with separations and transparency.
-<br>
-</li>
-<li>
-<p>tiffsep, psdcmyk and psdrgb now support the &quot;downscaler&quot; functionality.
-This brings the &quot;tiffscaled&quot; style functionality to the DeviceN output devices, so
-jobs can be rendered internally in contone and at a high resolution, and the output
-optionally downsampled by a level specified by &quot;-dDownScaleFactor=n&quot;, and
-also optionally error diffused to 1bpp output.
-<br>
-</li>
-<li>
-<p>Third party libraries: libtiff, libpng, libjpeg , Freetype and zlib have all be updated.
-<br>
-</li>
-<li>
-<p>clist storage, for rendering pages in bands, is now a run-time option: -sBandListStorage={file|memory}.
-<br>
-</li>
-<li>
-<p>Plus the usual round of bug fixes, compatibility changes, and incremental improvements.
-</ul>
-
-<p>In addition, Ghostscript and GhostPDL 8.71 are now unsupported, and those
-still using those versions (or earlier ones) should migrate to 9.x as soon as
-possible since many improvements, features and fixes from the 9.x versions
-are impractical or impossible to back-port to these legacy versions.
-
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.04_Incompatible_changes"></a>Incompatible changes</h3>
-<p>
-No recorded incompatible changes.
-
-<h3><a name="9.06_Changelog"></a>Changelog</h3>
-<p><strong>2012-08-06 23:37:19 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=291872308da215e1d7e12c8375fcf10dd5e651d2">291872308da215e1d7e12c8375fcf10dd5e651d2</a>
-<blockquote>
-<p>
- Backport patches CVE problems.<br>
-<br>
- CVE-2009-5030 http://code.google.com/p/openjpeg/source/detail?r=1703<br>
- CVE-2012-1499 http://code.google.com/p/openjpeg/source/detail?r=1330<br>
- CVE-2012-3358 http://code.google.com/p/openjpeg/source/detail?r=1727<br>
-<br>
-gs/openjpeg/libopenjpeg/j2k.c<br>
-gs/openjpeg/libopenjpeg/jp2.c<br>
-gs/openjpeg/libopenjpeg/tcd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-06 08:43: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=20157526924fbe59436170085a17e530d08e9807">20157526924fbe59436170085a17e530d08e9807</a>
-<blockquote>
-<p>
- Bug 693223: remove apparently moribund dumphint tool<br>
-<br>
- dumphint.ps and the scripts which call it seem to be of almost no value<br>
- these days, and appear to have suffered &quot;bit rot&quot;. So remove them.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/lib/dumphint<br>
-gs/lib/dumphint.bat<br>
-gs/lib/dumphint.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-02 23:14:09 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e48e87f883df0d39d1409d814c5d15444c3dca07">e48e87f883df0d39d1409d814c5d15444c3dca07</a>
-<blockquote>
-<p>
- Bug 693185. The limitcheck in validatedevicenspace must match int_remap_color_info_s.<br>
-<br>
- Commit e884e3 masked the failure, but since the test in validatedevicenspace<br>
- used GS_CLIENT_COLOR_MAX_COMPONENTS, the array bounds could still be exceeded.<br>
-<br>
- Note that the confusing error message from the PDF interpreter from comment 1<br>
- still exists unless -dPDFSTOPONERROR is used, which gives a more meaningful<br>
- 'limitcheck' immediately following the 'Do' of the image with 17 DeviceN<br>
- components. Bug 693185 is reopened for the error message as P3.<br>
-<br>
-gs/base/gsccolor.h<br>
-gs/psi/icremap.h<br>
-gs/psi/zcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-02 20:34:26 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=588c2ee040526fbea470e36e7cbc8e87a503cab9">588c2ee040526fbea470e36e7cbc8e87a503cab9</a>
-<blockquote>
-<p>
- Update documentation for tiffsep planar device<br>
-<br>
- Add in comments about the use of -dMaxSpots as well as the fact that the device,<br>
- and psdcmyk are planar and limited to 64 colorants per page. Also add in a<br>
- hint about using -dMaxSpots when we are processing a Postscript file and bump<br>
- up to the default max limit of 10 colorants. Tested it and it worked nicely.<br>
- Thanks Robin Watts.<br>
-<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevtsep.c<br>
-gs/doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-02 18:27:45 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=836a551b97dd4a8436608b6dcebe8f8fb8632bcd">836a551b97dd4a8436608b6dcebe8f8fb8632bcd</a>
-<blockquote>
-<p>
- Add -dMaxSpots for tiffsep and psd devices.<br>
-<br>
- psd and tiffsep devices now run with GS_SOFT_MAX_SPOTS spots enabled<br>
- by default (ten, unless predefined differently at build time). The<br>
- user can change this value using -dMaxSpots=X (where<br>
- 0 &lt;= X &lt;= GS_CLIENT_COLOR_MAX_COMPONENTS-4).<br>
-<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevtsep.c<br>
-gs/base/gsccolor.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-01 22:14: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=d723d72b3c9f7e171299a5ccc70a5f1ca715a50a">d723d72b3c9f7e171299a5ccc70a5f1ca715a50a</a>
-<blockquote>
-<p>
- Fix the -disable-gtk &quot;so&quot; build option<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-08-01 14:07:49 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7e7b4ae93066b841c0b1eac539c220b79d7f7a5d">7e7b4ae93066b841c0b1eac539c220b79d7f7a5d</a>
-<blockquote>
-<p>
- Fix lcms2 64-bit value decoding on big endian systems<br>
- that lack 64-bit types or have these types missed by configuration.<br>
-<br>
-gs/lcms2/src/cmsplugin.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-31 17:53:58 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c832985cab3b769d460a3f3e0ae894c2a84fa1ba">c832985cab3b769d460a3f3e0ae894c2a84fa1ba</a>
-<blockquote>
-<p>
- Update tiffsep/tiffsep1 documentation w.r.t downscaler.<br>
-<br>
- Document 32 and 34 ratios. Add extra info to tiffsep1 to distinguish<br>
- it from tiffsep in 1bpp mode.<br>
-<br>
-gs/doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-31 15:25: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=af22330035dc852635b2102353cec1a94504cb88">af22330035dc852635b2102353cec1a94504cb88</a>
-<blockquote>
-<p>
- Update docs for 9.06 release candidate 1.<br>
-<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pdfopt.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-31 10:50: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=76722bee735462eedf4f4c6d9dfa552e3c1f7ebc">76722bee735462eedf4f4c6d9dfa552e3c1f7ebc</a>
-<blockquote>
-<p>
- Fix link warnings about bad memset in gdevtsep.c<br>
-<br>
- Due to a mistake on my part, the tiffsep device had a couple of<br>
- memsets in that did nothing; these were intended to clear an array<br>
- of pointers before use. Not clearing the array would only have been<br>
- a problem if we'd hit an error condition in a very small region of<br>
- code, but nonetheless, this is a fix.<br>
-<br>
-gs/base/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-31 08:40: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=1e7ca769528b822b94ad8d1e498bde44d861637b">1e7ca769528b822b94ad8d1e498bde44d861637b</a>
-<blockquote>
-<p>
- Product string and date updates.<br>
-<br>
-gs/base/gscdef.c<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-30 19:05:08 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=443ad5a4885be7abf5a1e0777275eefbc5322cd2">443ad5a4885be7abf5a1e0777275eefbc5322cd2</a>
-<blockquote>
-<p>
- Up default GS_CLIENT_COLOR_MAX_COMPONENTS to 32.<br>
-<br>
- The planar changes have enabled us to increase the default maximum<br>
- number of spot changes to 32. Tests show only a few differences<br>
- due to roundings.<br>
-<br>
- Hopefully we can push it to 64 soon.<br>
-<br>
-gs/base/gsccolor.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-27 13:47:49 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=71c939e116dcffe72bf0c8ece9c647805da7e655">71c939e116dcffe72bf0c8ece9c647805da7e655</a>
-<blockquote>
-<p>
- Pass the data_cs information into the minimal needed clist icc profile information<br>
-<br>
- The knowledge that the source space is gray is needed so that we handle the gray_to_K<br>
- mapping correctly when going out to CMYK devices. Fixes a rendering issue in 29-07A.PS.<br>
- Thanks to Robin Watts for doing a lot of the detective work.<br>
-<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclist.h<br>
-gs/base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-25 23:58: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=428869d288d87d95fbcb5dcf8a0563003ff26294">428869d288d87d95fbcb5dcf8a0563003ff26294</a>
-<blockquote>
-<p>
- Fix bug 693220. The pdf14 device used compressed encoding in clist mode.<br>
-<br>
- The pdf14 device clist mode did not respect the USE_COMPRESSED_ENCODING<br>
- setting always using compressed encoding, and ended up writing pure<br>
- colors with num_bytes == -3. This was undetected because tiffsep1 is not<br>
- part of the regression testing, and because the tiffsep1 device did not<br>
- use 'planar' mode as the tiffsep device did. Also fixed some blanks before<br>
- line ends and tab indents.<br>
-<br>
- Also, since planar mode is more efficient and allows for &gt; 8 colorants<br>
- tiffsep1 was changed to use planar mode, getting rid of the need for<br>
- compressed color encoding in this file (maybe the last one).<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-26 18:55:30 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8dfd92bc9d91105bd678940c20479fc9ecebbbdb">8dfd92bc9d91105bd678940c20479fc9ecebbbdb</a>
-<blockquote>
-<p>
- Fix clist_copy_planes causing clist corruption.<br>
-<br>
- When clist_copy_planes is used with a planar device, it used to<br>
- leave a gap (9 bytes in the debugging example), then write the<br>
- first planes data. Then it would write each subsequent plane (preceeded<br>
- with a single byte gap). Then it would fill in the 9 bytes.<br>
-<br>
- Unfortunately, if the buffer filled up while copying one of the<br>
- non-initial planes in, the date would be copied away and stored before<br>
- the header was filled in.<br>
-<br>
- This leads to clist corruption, and all sorts of problems ranging from<br>
- rendering issues to SEGVs.<br>
-<br>
- The fix is to move the header writing forward to immediately after<br>
- the first plane is successfully written.<br>
-<br>
- This was causing problems with a 72dpi unbanded rendering of<br>
- tests_private/comparefiles/Bug692517.pdf to the psdcmyk device<br>
- with GS_CLIENT_COLOR_MAX_COMPONENTS set to 32, but was also<br>
- causing problems without the change in MAX_COMPONENTS.<br>
-<br>
-gs/base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-26 13:32:36 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f43f3d2016ae165a392fad962cda196e60587f8c">f43f3d2016ae165a392fad962cda196e60587f8c</a>
-<blockquote>
-<p>
- Bug 693147: monitors need max alignmrnt.<br>
- On 32-bit SunOS 5.11 gp_monitor structure need larger alignment than<br>
- 4-byte pointer. Make it an union and add 64-bit attributes to ensure<br>
- proper alignment.<br>
-<br>
-gs/base/gpsync.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-25 16:45:38 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d3bfe9bf857bb804a9bf710cccb36e3b78b9d663">d3bfe9bf857bb804a9bf710cccb36e3b78b9d663</a>
-<blockquote>
-<p>
- Fix so that the image_render_frac handles sep color spaces correctly<br>
-<br>
- The separation color spaces were not being handled properly in this renderer.<br>
- Also, if the device supported devn colors we were not packing them into the<br>
- correct type.<br>
-<br>
-gs/base/gxi12bit.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-25 22:02:00 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c8fc89fe8d72ad87158569825ddf421887c47713">c8fc89fe8d72ad87158569825ddf421887c47713</a>
-<blockquote>
-<p>
- Replace magic 32 number with MAX_COMPONENTS_IN_DEVN<br>
-<br>
-gs/base/gsccolor.h<br>
-gs/psi/icremap.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-24 21:40:05 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e884e39691346b35ea8b87fe26d8d98857689397">e884e39691346b35ea8b87fe26d8d98857689397</a>
-<blockquote>
-<p>
- Change the remap_color_info structure so that we can support up to 32 colorants DeviceN<br>
-<br>
- AR supports up to 32 colorants in a DeviceN color space and this brings us in line with<br>
- that product's limits. Note that if the number of colorants is greater than<br>
- GS_CLIENT_COLOR_MAX_COMPONENTS then we end up using the alternate tint transform.<br>
- Previously, the tint transform would fail if we encountered a color DeviceN color<br>
- space with more that GS_CLIENT_COLOR_MAX_COMPONENTS colorants. This fixes bug 693185<br>
-<br>
-gs/psi/icremap.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-25 13:26:41 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=61fd8053c2c0b653df3d461b791ca3f61767c4f5">61fd8053c2c0b653df3d461b791ca3f61767c4f5</a>
-<blockquote>
-<p>
- Bug 693210: check for scanning big arrays<br>
-<br>
- Check whether the size of an scanned array exceed the current<br>
- max_arra_size and throw /limitcheck. Old code tried to allocate big<br>
- arrays, which caused a cascade of obscure errors.<br>
-<br>
-gs/psi/iscan.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-25 18:12: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=1e0744128be80ff2a0acb48a2c5e018dbb32c168">1e0744128be80ff2a0acb48a2c5e018dbb32c168</a>
-<blockquote>
-<p>
- More fixes for deep color in the clist.<br>
-<br>
- In the previous commit I missed the reading code for the delta color<br>
- form. Updated here.<br>
-<br>
-gs/base/gxclrast.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-25 14:14: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=b750aec711bde8505173622d590eabdda2f3d789">b750aec711bde8505173622d590eabdda2f3d789</a>
-<blockquote>
-<p>
- Bug 692824: only apply word spacing to single byte space<br>
-<br>
- PDF word spacing is defined as only applying to character codes of one byte<br>
- with the value 32. We were using widthshow/awidthshow to implement word<br>
- spacing, but the character matching for those means any character code<br>
- with the value 32 will have the width applied: so both &lt;32&gt; and &lt;0032&gt; will<br>
- have word spacing applied, where only the former should.<br>
-<br>
- I've added two customer operators (.pdfwidthshow and .pdfawidthshow) which the<br>
- PDF interpreter now uses. Those trigger a small additional capability in the<br>
- graphics lib code which ensures space is only allowed to be the single byte<br>
- value 32.<br>
-<br>
- Cluster progressions with this patch seen in fts_20_2001.pdf and<br>
- fts_22_2202.pdf - no other differences.<br>
-<br>
-gs/Resource/Init/pdf_ops.ps<br>
-gs/base/gstext.c<br>
-gs/base/gxchar.c<br>
-gs/base/gxtext.h<br>
-gs/psi/zchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-25 13:40: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=ee0365f54e5d2cd80f5cae501d13d796094d022a">ee0365f54e5d2cd80f5cae501d13d796094d022a</a>
-<blockquote>
-<p>
- Avoid cmd_put_color being confused by deep color.<br>
-<br>
- With high level color, we can have depths that are too bit to fit in<br>
- a gx_color_index. cmd_put_color has no idea how many bits of a<br>
- gx_color_index are used, so assumes that as many bits are used as<br>
- are in the target depth. The encoding used goes wrong when the number<br>
- of bits is bigger it guesses at is bigger than the number of bits in<br>
- a gx_color_index.<br>
-<br>
- The fix is simply to change the writing and reading code to be smarter<br>
- about guessing; when writing/reading a gx_color_index you can never<br>
- need to write more bits than there are actually in a gx_color_index.<br>
-<br>
- While debugging this code, I spotted that the devn_{write,read}_color<br>
- routines were always leaving an unused byte at the end of their commands.<br>
- Trim that here.<br>
-<br>
-gs/base/gxclrast.c<br>
-gs/base/gxclutil.c<br>
-gs/base/gxdcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-25 13:05:35 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7de5b7e3b3c64f8c7dd01df54e8223ab1275684a">7de5b7e3b3c64f8c7dd01df54e8223ab1275684a</a>
-<blockquote>
-<p>
- Remove a couple of unused variables.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-25 08:12:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0caff3862d36e99ba5d14077c58e88bd9a082c83">0caff3862d36e99ba5d14077c58e88bd9a082c83</a>
-<blockquote>
-<p>
- Bug 693216: replace &quot;word-wise&quot; copies with memcpy()<br>
-<br>
- Various places in the blending code used a loop to explicitly copy bytes from<br>
- the input buffer to the output, with the comment that the idiom used was<br>
- actually quicker than using memcpy(). The idiom in question relies on casting<br>
- the byte buffer to a four byte type. This raises the spectre of unaligned<br>
- accesses.<br>
-<br>
- Testing suggests any difference between the word-wise copying and &quot;modern&quot;<br>
- memcpy implementations is non-existent, or too small to measure (my tests<br>
- showed more variation between runs than between the two implementations).<br>
-<br>
- We reckon the memcpy() solution is more maintainable in the long term than<br>
- forcing the buffers into alignment.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-20 15:46: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=a06bb8cfd8791254655889d85a1d37f173f53597">a06bb8cfd8791254655889d85a1d37f173f53597</a>
-<blockquote>
-<p>
- Rework colors_used to be a color_usage bitfield.<br>
-<br>
- Previously, the clist would collate the colors used in a band/page<br>
- by ORing together any color indexs uses into a single gx_color_index.<br>
- This relies on the gx_color_index being able to represent the whole<br>
- depth.<br>
-<br>
- This is dodgy with compressed encoding, and fails entirely with the<br>
- new planar based tiffsep/psdcmyk and high level color stuff, as the<br>
- total depth can far exceed the number of bits available in a<br>
- gx_color_index.<br>
-<br>
- The fix here is to change to using a bitfield (gx_color_usage_bits)<br>
- for this record; this allows us to have up to 64 colorants with a<br>
- standard build.<br>
-<br>
- The code here is still imperfect for all the reasons listed within<br>
- the original code (only works for subtractive spaces, can falsely<br>
- detect 'no colors used', etc), but it is at least consistently<br>
- imperfect now.<br>
-<br>
-gs/base/gdevpbm.c<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevprn.h<br>
-gs/base/gxband.h<br>
-gs/base/gxcldev.h<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclist.h<br>
-gs/base/gxclpath.c<br>
-gs/base/gxclpath.h<br>
-gs/base/gxclread.c<br>
-gs/base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-24 16:28:00 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7319a6de58e1986c5500d6181db158d3084da099">7319a6de58e1986c5500d6181db158d3084da099</a>
-<blockquote>
-<p>
- Bug 693219 - Clarify default output device description<br>
-<br>
- Patch submitted by: roucaries.bastien+gs@gmail.com<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/man/gs.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-24 15:16:46 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83f1aed5358d314cc52b5c243f94bbecb1e4469b">83f1aed5358d314cc52b5c243f94bbecb1e4469b</a>
-<blockquote>
-<p>
- When unpacking 16 bit image data, unpack it all.<br>
-<br>
- Ensure we don't miss the last one off. Differences appear on the right<br>
- hand edge of the images when rendering:<br>
-<br>
- gs -dNOINTERPOLATE -o out-%d.psd -sDEVICE=psdcmyk -r300 -dMaxBitmap=10000 fts_02_0200.pdf<br>
-<br>
- vs<br>
-<br>
- gs -dNOINTERPOLATE --debug=memfill-empty -o out-%d.psd -sDEVICE=psdcmyk -r300 -dMaxBitmap=10000 fts_02_0200.pdf<br>
-<br>
-gs/base/gxi16bit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-23 17:19: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=ef036b230f33ce1d9cdd135655319d3828ca6008">ef036b230f33ce1d9cdd135655319d3828ca6008</a>
-<blockquote>
-<p>
- Bug 693204: Fix masked devn uncolored pattern error<br>
-<br>
- In the old (non device n) code copy_portrait calls<br>
- gx_dc_default_fill_masked which calls gx_device_color_fill_rectangle<br>
- (actually gx_dc_pure_masked_fill_rect).<br>
-<br>
- In the new code copy_portrait calls gx_dc_devn_fill_masked. This<br>
- function is almost identical, but results in calls to the<br>
- fill_rectangle_hl_color device procedure. This turns out to be<br>
- clist_fill_rectangle_hl_color, which tries to cmd_put_drawing_color.<br>
- This fails (and indeed would have failed in the old code) as we cannot<br>
- serialise a masked color.<br>
-<br>
- If instead of calling the device procedure to fill_rectangle_hl_color,<br>
- we call the device color procedure to fill a rectangle, this exactly<br>
- mirrors the old code, and indeed results in calls to the<br>
- fill_rectangle_hl_color code in a way that don't give errors.<br>
-<br>
-gs/base/gxdcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-23 14:27: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=f661e5225bb017d15b50c2aecda7d4283f8f3aa9">f661e5225bb017d15b50c2aecda7d4283f8f3aa9</a>
-<blockquote>
-<p>
- Bug 693205: check for &quot;sane&quot; page dimensions in x11 drivers<br>
-<br>
- In the x11 devices, the page size is used to request the window dimensions from<br>
- X, and X does not support 0 x 0 sized windows.<br>
-<br>
- If a page size is, or rounds to 0 x 0, inform the user, and return a<br>
- rangecheck error.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gdevxini.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-23 14:15:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7dfac701b8a36395a88a69b3a1e9eeaaa70c6b0b">7dfac701b8a36395a88a69b3a1e9eeaaa70c6b0b</a>
-<blockquote>
-<p>
- Bug 693208: improve error feedback (when we can)<br>
-<br>
- Have configure check for the presence of strerror() and if it's available,<br>
- have gp_strerror() call it.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/Makefile.in<br>
-gs/base/configure.ac<br>
-gs/base/gp_unix.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-22 13:30:12 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9ef234a8a065f2240173bd1d5131418d171fbf4a">9ef234a8a065f2240173bd1d5131418d171fbf4a</a>
-<blockquote>
-<p>
- Another fix for bug 692542 for garbled output with NumRenderingThreads &gt; 1.<br>
-<br>
- The multi-threaded rendering &quot;predicts&quot; which direction to start threads,<br>
- but the 'next_band' calculation in clist_get_band_from_thread was not<br>
- correct if the thread prediction was incorrect as it would be if the<br>
- device requested bands in other than the normal order as happens when<br>
- the device makes multiple rendering passes (psdcmyk) or NumCopies &gt; 1.<br>
-<br>
- Also, depending on the number of bands, 'clist_teardown_render_threads'<br>
- could free the main thread's 'data' area, then later point the cdev-&gt;data<br>
- to the freed block, also leaving one of the thread's data blocks leaked<br>
- (releasing the chunk memory for the thread would free this, so the leak<br>
- would be temporary).<br>
-<br>
-gs/base/gxclist.h<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-20 22:46:02 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5a7b42637b166615c3c1e3b553bd86d1dced329b">5a7b42637b166615c3c1e3b553bd86d1dced329b</a>
-<blockquote>
-<p>
- Fix so that when we are doing the sep devices with spots the blend spaces for transparency remain separated<br>
-<br>
- This fixes bug 693144 first part which is the segv for Bug6992217.pdf which likely existed prior to the<br>
- planar change for the sep devices. The issue with 12-07C.PS is different. In any event, the<br>
- issue was that there was a fill with a pattern in a softmask and there was an RGB transparency group<br>
- within the pattern. With the separation devices, the blending space is maintained as a subtractive<br>
- space to allow blending of all the spot colorants which means that the parent group is always maintained.<br>
- There is a discussion about this in the PDF specification with respect to spot colors and transparency<br>
- blending. In any event, the current code has some confusion since the decision as to if we should use<br>
- the group color space was based upon the device name (e.g. pdf14cmykspot) which became a problem when we<br>
- had the pdf14clistgray device when the pattern was a clist.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-20 15:33: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=9986753fb7e45556980e5b661dedba2fe9d2f92c">9986753fb7e45556980e5b661dedba2fe9d2f92c</a>
-<blockquote>
-<p>
- ps2write - Emit a %%BeginResource for FOntFile resources<br>
-<br>
- Previously we were emittign an %%EndResource comment but not a %%BeginResource<br>
-<br>
- No differences sxpected<br>
-<br>
-gs/base/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-20 13:48: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=3f0bee24591c8f690bd121fee272d925247ce307">3f0bee24591c8f690bd121fee272d925247ce307</a>
-<blockquote>
-<p>
- Stamp on a warning in fapiufst.c<br>
-<br>
- Sort out the path length, and parameters to strncat() with the stand gs maximum path length value.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/fapiufst.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-19 19:02:04 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39f5af403d9cf49b9419a85e3569436907ade65d">39f5af403d9cf49b9419a85e3569436907ade65d</a>
-<blockquote>
-<p>
- Solve psdcmyk SEGVs when max components reaches 32.<br>
-<br>
- Max components reaching 32 means that the total depth reaches 256.<br>
- Attempting to pack 256 into a byte for the clist leads to obvious<br>
- problems.<br>
-<br>
-gs/base/gsptype1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-20 00:03:13 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1213e26fd9d71526855e1978c7440f7175413fcb">1213e26fd9d71526855e1978c7440f7175413fcb</a>
-<blockquote>
-<p>
- Bug 693199: Ignore broken %%ViewingOrientation<br>
-<br>
- Add a check whether the comment has been parsed successfully.<br>
- If not, ignore the comment.<br>
-<br>
-gs/psi/zdscpars.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-20 10:27: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=01dc18e8418fc44a993840f0aeaf741929c1921a">01dc18e8418fc44a993840f0aeaf741929c1921a</a>
-<blockquote>
-<p>
- ps2write - Always ascii hex encode the eexec portion of type 1 fonts<br>
-<br>
- Bug #693197 &quot;ps2write outputs Type 1 fonts in pfb format&quot;<br>
-<br>
- Technically it is possible for the eexec portion of a type 1 font to be in<br>
- binary or ascii hex. Because we always ascii85 encode binary data if the<br>
- device does not support it, we left eexec portion as binary.<br>
-<br>
- However it seems that at least some printers (Kyocera, possibly others) are<br>
- unable to deal with this.<br>
-<br>
- This patch means that we alays use ascii hex data for the eexec encrypted<br>
- portion of a type 1 font. We did consider making this a command line option<br>
- but were unable to find any other tools which emitted binary here so opted<br>
- simply to conform.<br>
-<br>
- All the investigation and the original patch (see bug report) by Chris Liddell<br>
-<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpdtb.c<br>
-gs/base/gdevpsf1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-19 15:40:03 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=04392ddc8b6a369b0ec4dfd9d0e9c894d1aa729e">04392ddc8b6a369b0ec4dfd9d0e9c894d1aa729e</a>
-<blockquote>
-<p>
- Fix bug 692542. NumRenderingThreads &gt; 1 failed with planar devices.<br>
-<br>
- The tile_cache_size was inconsistent resulting in the 'data' area<br>
- being miscalculated if the prn_device was set up in planar mode.<br>
-<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-19 13:16:29 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c7f3d73ea47bba783872ac193585601a4760dcfd">c7f3d73ea47bba783872ac193585601a4760dcfd</a>
-<blockquote>
-<p>
- Fix for bug in the named color example support<br>
-<br>
- When the example in gs\toolbin\color\named_color is run we get a segv. It was due to<br>
- the name information not getting set up in the nameed color structure that the example uses.<br>
- It essentially uses an ICC for with the named spot color data packed into the buffer.<br>
-<br>
-gs/base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-19 12:42:38 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ddc361cee517d73f4977c7600d9853cc1813ad1f">ddc361cee517d73f4977c7600d9853cc1813ad1f</a>
-<blockquote>
-<p>
- Fix of bug in setting source based rendering intent for RGB objects<br>
-<br>
- There were several typos caused by copy and past of the CMYK code for<br>
- setting rendering intents. Thanks to Stefan Lietermann for finding this.<br>
-<br>
-gs/base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-18 23:05:23 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=17a42fca39c61c256cc5bab4d343f6bf38ae5109">17a42fca39c61c256cc5bab4d343f6bf38ae5109</a>
-<blockquote>
-<p>
- Add in support for copy_planes into the overprint device<br>
-<br>
- The copy_planes procedure is used during the default copy_alpha_hl_color and if we<br>
- are going out to the overprint device, we need to make sure to copy only those<br>
- planes that are specified in the drawn components vector. We also needed to<br>
- distinguish from this case and a copy_planes coming from the pattern tiling code.<br>
- This was done by adding in a copy_alpha_hl_color proc for the overprint device that<br>
- sets a flag and calls the default copy_alpha_hl_color so that later when we get<br>
- back to the overprint device's copy_planes proc we will know to do the over print<br>
- rather than just pass things along to the target device. Fixes Bug 693184.<br>
-<br>
-gs/base/gsovrc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-19 16:37: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=44b01d274db5272055de6afb3d72788b6db84d53">44b01d274db5272055de6afb3d72788b6db84d53</a>
-<blockquote>
-<p>
- Bug 693188: don't skip glyphs with degenerate matrices<br>
-<br>
- In commit 752397ab, the fix for Bug 692263 was to skip over glyphs when the<br>
- matrix in force for the glyph had a zero scale in either dimension.<br>
-<br>
- It seems that this approach had potentially unfavourable side effects in the<br>
- glyph cache.<br>
-<br>
- So, when we encounter a degenerate matrix rendering a glyph, we now force a<br>
- minimal, non-zero scale before attempting to render the glyph. This placates<br>
- the glyph cache.<br>
-<br>
- Cluster testing shows (tiny) progressions in Bug689006.pdf, Bug690179.pdf,<br>
- and Bug692634.ps, and pixel differences, not identifiable as progressions<br>
- or regressions in Bug690497.pdf and 12-07C.PS.<br>
-<br>
-gs/psi/fapi_ft.c<br>
-gs/psi/fapibstm.c<br>
-gs/psi/fapiufst.c<br>
-gs/psi/ifapi.h<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-18 20:57:54 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=71ddb93b2b679c980a4024fcc1089c2d56abc3ab">71ddb93b2b679c980a4024fcc1089c2d56abc3ab</a>
-<blockquote>
-<p>
- Recognise Darken and Lighten as idempotent rendering modes.<br>
-<br>
- No need to set the lop_pdf14 bit, and consequently makes files that<br>
- use stroking with Darken/Lighten much faster. See Bug 693173.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-18 13:11:35 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8a25653ddb875c29172b62eff48bec0147d09aab">8a25653ddb875c29172b62eff48bec0147d09aab</a>
-<blockquote>
-<p>
- Update scrollbar handling in Windows windows.<br>
-<br>
- Drag ghostscript kicking and screaming into the 1980s by adding<br>
- proportional scrollbar handling.<br>
-<br>
-gs/psi/dwimg.c<br>
-gs/psi/dwtext.c<br>
-pl/dwimg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-17 12:52:59 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d7b56aa8c3b39e58d2b5faefd33ecb7e377f097e">d7b56aa8c3b39e58d2b5faefd33ecb7e377f097e</a>
-<blockquote>
-<p>
- Fix for bug in clist copy planes procedure.<br>
-<br>
- The clist copy planes procedure was not indexing through the planes during the clist writing.<br>
- The 2nd plane was getting replicated into all the other subsequent planes. This is a bug fix<br>
- for 693061. I also added a message for when we are in debug and going out to a device that<br>
- supports devn color to notify us of a case where we have DeviceN color spaces with \None colorants.<br>
- As mentioned in bug 693061 Comment 5 this causes a problem for the composite preview in the<br>
- separation devices. Ink amounts for the separations will be correct, but without having the \None<br>
- colorant ink amounts, the preview is not going to be correct.<br>
-<br>
-gs/base/devs.mak<br>
-gs/base/gsequivc.c<br>
-gs/base/gxclrect.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-13 13:05: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=a88326f1ca382092c889ffa9be1abe857c118a34">a88326f1ca382092c889ffa9be1abe857c118a34</a>
-<blockquote>
-<p>
- Bug 693166: Optimise interpolation<br>
-<br>
- When interpolating, ghostscript pays no heed to the clipping rectangle.<br>
- Hence if we scale (say) a 256x256 image up to (say)17067x17067, even<br>
- though only a small portion of the scaled up image is actually visible<br>
- we scale the whole lot only to throw away 90%+ of it.<br>
-<br>
- To fix this, we have to extend the capabilities of the interpolation<br>
- code.<br>
-<br>
- The existing code already copes with only being given data for a<br>
- subsection of the image (for when we split images in the clist, I<br>
- guess). This rectangle is referred to in the code as being 'the<br>
- subrectangle we are rendering', when it's actually 'the subtrectangle<br>
- we are being given data for'. We update the description to be more<br>
- accurate.<br>
-<br>
- We introduce a new rectangle, 'the render rectangle' to indicate the<br>
- subrectangle that we are actually rendering - this will always be a<br>
- subset of the data rectangle.<br>
-<br>
- If we are given a clipping rectangle, we read the outer bbox from it,<br>
- and map this back into the source space of the image; we intersect this<br>
- with the data rectangle to get the render rectangle.<br>
-<br>
- We update the scaling stream filter to set an 'Active' flag to say<br>
- whether we are inside the render rectangle or not. If not, we can<br>
- safely skip lines in their totality. By default we leave this set to<br>
- 1, so that any scaling cores that aren't updated to know about this<br>
- will perform in the old way.<br>
-<br>
- We update the scaling code to make use of the Active flag; whole lines<br>
- are skipped if we aren't in the active region, and if we are, we skip<br>
- prefixes/suffixes of unused pixels.<br>
-<br>
- We update the scaling cores themselves to avoid calculating values<br>
- outside the active regions.<br>
-<br>
- Note that for simplicity we still allocate space as if we were<br>
- accessing the whole line. We still calculate contributions for the whole<br>
- of the images; to do otherwise would require significant changes to<br>
- the weight generation code, and this isn't a huge consumer of time.<br>
-<br>
-gs/base/gximage.h<br>
-gs/base/gxipixel.c<br>
-gs/base/gxiscale.c<br>
-gs/base/siscale.c<br>
-gs/base/sisparam.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-17 13: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=cbcd1dc873db397af0866f9fd54a70421dc6692f">cbcd1dc873db397af0866f9fd54a70421dc6692f</a>
-<blockquote>
-<p>
- Tweak interpolation calculations<br>
-<br>
- In preparation for the next commit, tweak the image interpolation<br>
- calculations; rather than doing a matrix multiplication and then<br>
- only using the X coords from it, change to doing both width and<br>
- height calculations in the same way.<br>
-<br>
- This causes various (350ish) small changes in interpolation output<br>
- due to rounding issues.<br>
-<br>
-gs/base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-16 22:16:35 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f12f569672d84a1846905c41701fca52f8dc55e">2f12f569672d84a1846905c41701fca52f8dc55e</a>
-<blockquote>
-<p>
- Bug 689376: fix //name handling on command prompt.<br>
-<br>
- We allocate %statementedit in the system memory. When a is read from<br>
- the command prompt we use gs_scan_token() to determine, whether the<br>
- line has a complete token. If the line has immediately evaluated names,<br>
- gs_scan_token() fails. This is interpreted as the end of the input.<br>
- If the line buffer has a complete token, the buffer is rescanned<br>
- and everything is fine. Otherwise, scanning a prematurely closed buffer<br>
- causes an error.<br>
-<br>
- All we need to do to fix this is to force local memory allocation<br>
- instead of inheriting system memory from %statementedit. The scanned<br>
- token is discarded after determining whether the input line is<br>
- complete.<br>
-<br>
-gs/psi/ziodev.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-16 13:00: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=b49d3c75a70cbdcdb2214f22ad1a1f62f1bb90fc">b49d3c75a70cbdcdb2214f22ad1a1f62f1bb90fc</a>
-<blockquote>
-<p>
- ps2write - create document %%BoundingBox from teh individual page Bounding boxes<br>
-<br>
- Bug #693181<br>
-<br>
- The document level BoundingBox is supposed to be the intersection of the<br>
- boundingbox of all the pages, whereas in fact it is the device media size.<br>
-<br>
- Now we create the document BoundingBox by taking largest dimensions from all<br>
- the pages in the output.<br>
-<br>
- NB the BoundingBox for each page is given from the media request, so this is<br>
- not a true BoundingBox anyway, but at least it is better then before.<br>
-<br>
-gs/base/gdevpdfu.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-14 16:25:13 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=479b462ffa4663a71a88d185aaf7cc5c4f5d1903">479b462ffa4663a71a88d185aaf7cc5c4f5d1903</a>
-<blockquote>
-<p>
- Replaced an '==' that was incorrectly being used for equality testing in configure with '='.<br>
-<br>
-gs/tiff/configure<br>
-gs/tiff/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-13 12:25: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=808f39dd443b1e475f6d9bfd320d79d793124d3f">808f39dd443b1e475f6d9bfd320d79d793124d3f</a>
-<blockquote>
-<p>
- Bug 692684: stack variable corruption<br>
-<br>
- In alloc_restore_step_in(), we have to make sure that, whenever we back up<br>
- a memory space to the previous save level, we hold onto the gc_status.psignal<br>
- pointer, and put it into the restored memory space. In case the &quot;save&quot;<br>
- happened during an earlier call to interp() and co.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/isave.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-13 14:14:47 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fef9eef583d2ac227d3f9037785e27f1d5ecfc0d">fef9eef583d2ac227d3f9037785e27f1d5ecfc0d</a>
-<blockquote>
-<p>
- Fix for missing variable set in overprint code from enhancement of simulated RGB overprint<br>
-<br>
- Fixes Bug 693085<br>
-<br>
-gs/base/gscspace.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-13 16:15:22 -0400
-</strong>
-<br>Wendy &lt;wendyst2@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cdf018f4dc9e7765a8c3851c2e66edaad5642a0b">cdf018f4dc9e7765a8c3851c2e66edaad5642a0b</a>
-<blockquote>
-<p>
- Add missing '\n' to the last line, required by MSVC 7.<br>
-<br>
-gs/base/gxcldev.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-13 13:54:36 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=57fe0115f01724b3c50812678c63924d008a01d9">57fe0115f01724b3c50812678c63924d008a01d9</a>
-<blockquote>
-<p>
- pdfwrite - code cleanup<br>
-<br>
- Deprecated the undocumented 'MaxViewerMemorySize' parameter whcih wasn't in<br>
- fact being used anywhere useful.<br>
-<br>
- Deprecated the 'pdf_write_and_free_all_resoruces' function which is not used<br>
- after deprecating MaxViewerMemorySize.<br>
-<br>
- Deprecated the function 'pdf_glyph_origin' as it is unused<br>
-<br>
- made 'write-font_resources' non-static so it can be called from pdf_close<br>
-<br>
- Deprecated pdf_close_text_document and moved the code (which actually writes<br>
- fonts and font descriptors) into pdf_close so that its easier to follow the<br>
- control flow. Also cleaned up the code so that it isn't one huge 'if' test<br>
- but each function call is separated out for easier debugging.<br>
-<br>
- Made a number of '#if 0' blocks into '#ifdef DEPRECATED_906'. All blocks of<br>
- code marked this way will be removed after the release of 9.06.<br>
-<br>
- Removed a number of cases where we had #define labels with a bug number, these<br>
- now use the #ifdef DEPRECATED_906 lable or are simply removed and the code<br>
- compiled in.<br>
-<br>
- Simlarly with '#define RIGHT_SBW' and '#if !RIGHT_SBW'<br>
-<br>
- Updated the ps2ps2.htm document to remove the reference to MaxViewerMemorySize.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-gs/base/gdevpdf.c<br>
-gs/base/gdevpdfb.h<br>
-gs/base/gdevpdfc.c<br>
-gs/base/gdevpdfp.c<br>
-gs/base/gdevpdfu.c<br>
-gs/base/gdevpdfx.h<br>
-gs/base/gdevpdt.h<br>
-gs/base/gdevpdte.c<br>
-gs/base/gdevpdtf.h<br>
-gs/base/gdevpdtt.c<br>
-gs/base/gdevpdtw.c<br>
-gs/base/gdevpsds.c<br>
-gs/doc/Ps2ps2.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-12 11:56:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9d73413d5ccb44b11a644848422dfb17e51eb7da">9d73413d5ccb44b11a644848422dfb17e51eb7da</a>
-<blockquote>
-<p>
- Changes to build on msys/mingw<br>
-<br>
- Allows all the system header presence macros previously set in unix-aux.mak to<br>
- be set by configure instead. The tests remain unix-aux.mak for backwards<br>
- compatibility.<br>
-<br>
- This also changes those macros to the &quot;tri-value&quot; style:<br>
- undefined, defined 0 and defined 1.<br>
-<br>
- Also removes jbig2dec/config_types.h from source control.<br>
-<br>
- No cluter differences.<br>
-<br>
-gs/base/Makefile.in<br>
-gs/base/configure.ac<br>
-gs/base/dirent_.h<br>
-gs/base/gp_unifn.c<br>
-gs/base/gp_unifs.c<br>
-gs/base/openvms.mak<br>
-gs/base/pipe_.h<br>
-gs/base/time_.h<br>
-gs/base/unix-aux.mak<br>
-gs/doc/Make.htm<br>
-gs/jbig2dec/config_types.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-12 17:15:13 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aa35587db7ba9dc469060d30d3313b318ca45bd5">aa35587db7ba9dc469060d30d3313b318ca45bd5</a>
-<blockquote>
-<p>
- make the SEAC detector and type 1 -&gt; type 2 charstring converter tolerate broken fonts<br>
-<br>
- Bug #693170 &quot;ps2pdf crashes on a given file&quot;<br>
-<br>
- The fonts in the PostScript file are invalid in that some of the glyphs do not<br>
- end with an 'endchar' or other valid termination operator. This was causing<br>
- a buffer overrun which eventually could cause access to invalid memory and a crash.<br>
-<br>
- Added limit checking where it was missing and choose to return an 'unknown'<br>
- error so that code which is able to handle this can detect the condition. Code<br>
- which is not expecting this contdition will continue to signal an error.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpsfx.c<br>
-gs/base/gxtype1.c<br>
-gs/base/gxtype1.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-12 15:44: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=82ef3429ec2f3fc891a2f61455027842b7aa7581">82ef3429ec2f3fc891a2f61455027842b7aa7581</a>
-<blockquote>
-<p>
- Revert &quot;Move GC flag from stack to gs_lib_ctx.&quot;<br>
-<br>
- This reverts commit 39b0a515d5101cf48ae35f1ebb14e4558cb78e88.<br>
-<br>
- That commit doubled the runtime in cluster testing, so presumably<br>
- gc was being triggered too often.<br>
-<br>
-gs/base/gslibctx.h<br>
-gs/psi/imain.c<br>
-gs/psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-12 08:42:38 -0400
-</strong>
-<br>SaGS &lt;sags5495@hotmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b2e2def97f5b1664dc3d8e2be942a2de5857b802">b2e2def97f5b1664dc3d8e2be942a2de5857b802</a>
-<blockquote>
-<p>
- Bug 693155: 'resourceforall' returns truncated names for /CMap resources.<br>
-<br>
- (A)<br>
- Comments say that gs_init.ps::.generate_dir_list_templates_with_length returns<br>
- the legth of the &quot;directory&quot; part, but if actually returned the length of<br>
- &quot;[base] directory&quot; + &quot;template&quot; - 1.<br>
-<br>
- (B)<br>
- gs_res.ps::ResourceForAll passes part of the real &quot;directory&quot; (the &quot;Category/&quot;)<br>
- as part of the &quot;template&quot; argument of .generate_dir_list_templates_with_length,<br>
- but failed to take into consideration the length of this string when cutting<br>
- &quot;directory&quot; from the full filespec in order to remain with the resource name.<br>
-<br>
- Note that .generate_dir_list_templates_with_length does not check if its<br>
- &quot;template&quot; argument contains directories too so cannot adjust the returned<br>
- length. The code as written intends to deal with resource names that include<br>
- .file_name_separator (see discussion on Bug 688737 &quot;'resourceforall' truncates<br>
- names of file-based resources&quot;); such a resource name would be<br>
- &quot;Times/Cyrillic&quot;.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-12 13:29:24 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=29a16f87849a874cd872fc8e2beab2b3986eea51">29a16f87849a874cd872fc8e2beab2b3986eea51</a>
-<blockquote>
-<p>
- Bug 693171: Patch OpenJPEG to avoid SEGVs with broken files.<br>
-<br>
- Patch from Shailesh Mistry. In the case of corrupt files, tiles<br>
- were failing to be allocated, leaving the code attempting to<br>
- work with non existent tiles. The fix is to spot the failure,<br>
- mark the tiles as being non-existence and then to check this<br>
- before accessing them.<br>
-<br>
-gs/openjpeg/libopenjpeg/j2k.c<br>
-gs/openjpeg/libopenjpeg/tcd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-12 11:44: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=514595fc2cc84f51efdef563cf7a35a0050902e5">514595fc2cc84f51efdef563cf7a35a0050902e5</a>
-<blockquote>
-<p>
- Bug 693038 - allow gsx to build against GTK+ 3.x<br>
-<br>
- Patch from galtgendo@gmail.com applied with changes to maintain compatibility<br>
- with GTK+ 2.x, and replace a function deprecated in GTK+ 3.x.<br>
-<br>
- This patch drops GTK+ 1.x support.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/configure.ac<br>
-gs/psi/dxmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-12 09:20:35 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b6252440c644b4f172c517a931fd3da73828f64c">b6252440c644b4f172c517a931fd3da73828f64c</a>
-<blockquote>
-<p>
- Fix for OpenJPEG build on FreeBSD<br>
-<br>
- Make sure OpenJPEG does not try to use memalign() on FreeBSD systems.<br>
-<br>
- Credit to Alex Zimnitsky ( aavzz@yandex.ru ) for the patch.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/openjpeg/libopenjpeg/opj_malloc.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-12 00:11:37 -0400
-</strong>
-<br>SaGS &lt;sags5495@hotmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e0deadb4b3661e6c4e0811b45d1c251e124632be">e0deadb4b3661e6c4e0811b45d1c251e124632be</a>
-<blockquote>
-<p>
- Remove an additional, incorrect, search for resources,<br>
- intended for OpenVMS only.<br>
-<br>
- ResourceForAll used a 2nd template for searching file-based resources,<br>
- GenericResourceDir + Category<br>
- + .file_name_separator + originaltemplate + .file_name_separator + &quot;*&quot;<br>
- in addition to the standard<br>
- GenericResourceDir + Category + .file_name_separator + originaltemplate<br>
- This was documented as needed for OpenVMS, but it results in<br>
- dev:[genericresourcedir.Category]originaltemplate]* (&quot;]&quot; twice)<br>
- which is definitely invalid. It is also unnecessary, the &quot;standard&quot; one is OK.<br>
-<br>
- For other platforms, this 2nd form may or may not be syntacticly valid (&quot;*?&quot;,<br>
- coming in form the original template, in the &quot;directory&quot; part), but it's<br>
- definitely not useful.<br>
-<br>
- Of course, it remains the question what was the intent of the person who added<br>
- these lines (in case we should keep the code but fix it). I considered:<br>
-<br>
- - &quot;dev:[genericresourcedir.Category.*]template&quot;, but this searches one<br>
- directory level too deep.<br>
- - &quot;dev:[genericresourcedir.Category]template;*&quot;, but this would load all<br>
- versions of a same file. Definitely not what we want, because we may end<br>
- with an obsolete (old) copy of the resource.<br>
- - &quot;dev:[genericresourcedir.Category]template.*&quot;, but this is unnecessary. And<br>
- maybe more important is that the exact template used is the responsability<br>
- of the caller; I see no reason for ResourceForAll to modify it.<br>
-<br>
- The most precise documentation on OpenVMS path syntax I found is &quot;Guide to<br>
- OpenVMS File Applications&quot;<br>
- &lt;http://h71000.www7.hp.com/doc/731final/documentation/pdf/ovms_731_file_app.pdf&gt;<br>
- available from &lt;http://h71000.www7.hp.com/doc/os83_index.html&gt;.<br>
- I also asked on comp.os.vms, and the response I got confirmed the form used is<br>
- invalid.<br>
-<br>
-gs/Resource/Init/gs_res.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-11 23:17:36 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39b0a515d5101cf48ae35f1ebb14e4558cb78e88">39b0a515d5101cf48ae35f1ebb14e4558cb78e88</a>
-<blockquote>
-<p>
- Move GC flag from stack to gs_lib_ctx.<br>
-<br>
- Move the GC flag from the stack, where it can go out of scope to<br>
- lib context structure (gs_lib_ctx_t), which is allocated quite<br>
- early in stable memory and never goes out of scope.<br>
-<br>
- Revert the commit a39e4831ba0d74d742b365f3b3b1af192731303c for the<br>
- bug 692684 because it didn't really fix anything. That patch just<br>
- changed the stack layout and masked the effect of writing into an<br>
- out-of-scope location.<br>
-<br>
- The sample file 34_all.PS no longer causes SEGV but continues to<br>
- have a resolution-dependant rendering of one character.<br>
-<br>
-gs/base/gslibctx.h<br>
-gs/psi/imain.c<br>
-gs/psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-11 18:27:44 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c304a350330b3e333b34c048de009967f1a6caa1">c304a350330b3e333b34c048de009967f1a6caa1</a>
-<blockquote>
-<p>
- Fixed typos in comments.<br>
-<br>
-gs/base/lcms.mak<br>
-gs/base/lcms2.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-11 15:51: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=4f6b98548bec2c10b10207d4f25b805fc393ade8">4f6b98548bec2c10b10207d4f25b805fc393ade8</a>
-<blockquote>
-<p>
- Bug 693176: write transparent type2 pattern color to clist<br>
-<br>
- When using a clist, ensure that the all the color space data for the<br>
- pattern gets written to the clist, *and* that the clist correctly<br>
- records all the relevant transparency data.<br>
-<br>
- I'm at a loss to explain how COMPILE_INITS influenced this, but this<br>
- change brings the clist/non-clist output and code in line with each<br>
- other.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-10 15:03:49 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c7d2fbfef2ea176472c4459b3772ef3ac496ee5d">c7d2fbfef2ea176472c4459b3772ef3ac496ee5d</a>
-<blockquote>
-<p>
- Expanded -dDOINTERPOLATE section of Use.htm based on Robin's description of same.<br>
-<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-09 14:04:16 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f5d0a752ccd610aa4a3946e30e2a0917cacacf28">f5d0a752ccd610aa4a3946e30e2a0917cacacf28</a>
-<blockquote>
-<p>
- Fix for mistake in commit 951adcd6 . which was the xps transparency fix<br>
-<br>
- Fixes the reopening of bug 693042<br>
-<br>
-xps/xpspath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-09 14:12:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=711883fd711772b7856e19207cc64f829033e254">711883fd711772b7856e19207cc64f829033e254</a>
-<blockquote>
-<p>
- Bug 693172: Truetype: disable hinting for broken glyph program<br>
-<br>
- In the AFS Truetype code, if we encounter a glyph with a broken bytecode<br>
- program reset and retry the glyph with the bytcode interpreter disabled.<br>
-<br>
- This reflects what the FAPI/Freetype does, and what most other TTF consumers<br>
- seem to do.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/ttfmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-07 13:50:54 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c1815bdb424390c21289287d13f7e8747792c098">c1815bdb424390c21289287d13f7e8747792c098</a>
-<blockquote>
-<p>
- Simplify the ICC options PS code to do a single .setuserparams2<br>
-<br>
- Use an array of names to collect all options that were set from the command<br>
- line and then do a single .setuserparams2 invocation.<br>
-<br>
-gs/Resource/Init/gs_lev2.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-06 16:38:55 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=149974a4a14999d5e336911b262600e5fa950e18">149974a4a14999d5e336911b262600e5fa950e18</a>
-<blockquote>
-<p>
- Fixes bug 693162, shifted text due to Vertical Motion Index command not<br>
- resetting the cursor to the home position.<br>
-<br>
-pcl/pcpage.c<br>
-pcl/pcursor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-06 00:15:51 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=74897ff7aeecb9a76dde73a6554444b40a89beec">74897ff7aeecb9a76dde73a6554444b40a89beec</a>
-<blockquote>
-<p>
- Use .setuserparams2 instead of .setuserparams when setting the ICC user params<br>
-<br>
- Thanks to Chris for pointing this out. If we use .setuserparams then in gs_lev2.ps the<br>
- various user params such as /DefaultCMYKProfile are set. This sets the profile<br>
- in the icc manager properly to what ever was set on the command line.<br>
- Unfortunately, the currentuserparams dictionary (or what ever object it is)<br>
- that is maintained by the interpreter is not updated with the same value, but<br>
- instead it has an old default value that it obtained from an earlier call of<br>
- .currentuserparams. During a vm_reclaim, context_state_store stores the<br>
- outdated userparam information and then context_state_load does a call to<br>
- set_user_params with this outdated userparams information. setuserparams2<br>
- takes care of this by getting the interpreters list in sync at the time we do<br>
- the setting of the parameter. Fixes bug 693159<br>
-<br>
-gs/Resource/Init/gs_lev2.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-29 17:39:31 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=951adcd68cf899a472b8c280e58fd7ff589badd3">951adcd68cf899a472b8c280e58fd7ff589badd3</a>
-<blockquote>
-<p>
- Fix in XPS interpreter to ensures we only push the smallest transparency group needed + more<br>
-<br>
- For a path that included an opacity mask, the XPS interpreter was pushing a soft mask<br>
- that included the entire page (it actually just looked at the current clip path). This<br>
- fix incorporates the path that we are filling in the computation of the transparency group<br>
- size. Also, there were issues with the softmasks in general that were causing them to be<br>
- double applied. Fixes 693042 and also provides improvements for 690951. Also this should fix 693137 and 692892<br>
-<br>
-gs/base/gspath.c<br>
-gs/base/gstrans.c<br>
-gs/base/gstrans.h<br>
-gs/base/gxpath.h<br>
-gs/base/lib.mak<br>
-gs/psi/ztrans.c<br>
-xps/ghostxps.h<br>
-xps/xpsglyphs.c<br>
-xps/xpsgradient.c<br>
-xps/xpsimage.c<br>
-xps/xpsopacity.c<br>
-xps/xpspage.c<br>
-xps/xpspath.c<br>
-xps/xpstile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-04 17:32:21 +0200
-</strong>
-<br>Tor Andersson &lt;tor@ccxvii.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f71f5166422d5c61cb13c6078b2dfb1c3234db7">2f71f5166422d5c61cb13c6078b2dfb1c3234db7</a>
-<blockquote>
-<p>
- Implement XPS style simulations using shearing and fill+stroke.<br>
-<br>
- Special case for pdfwrite to pass through Tr mode without using charpath<br>
- by looking for PreserveTrMode in the device parameters.<br>
-<br>
- Fixes bug 689278.<br>
-<br>
-xps/ghostxps.h<br>
-xps/xpsglyphs.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-03 22:52:19 +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=31d9fb2b771272d7ba4712d8887c668d0e86d82e">31d9fb2b771272d7ba4712d8887c668d0e86d82e</a>
-<blockquote>
-<p>
- Bug 693050 : Fix compiler warnings<br>
-<br>
-gs/jbig2dec/jbig2_halftone.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-03 15:48: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=0bc05670e841517b8a2041999c19c19507874a4a">0bc05670e841517b8a2041999c19c19507874a4a</a>
-<blockquote>
-<p>
- pdfwrite - when we have /Indexed space or non-identity transfer use lossless compression<br>
-<br>
- Bug #689506<br>
-<br>
- level 1 output from PScript5.dll can create a fake 'Indexed' space by using<br>
- a non-identity transfer function. Also if we do have a real /Indexed space,<br>
- then using lossy compression or downsmapling (other than Subsample) results<br>
- in garbage output.<br>
-<br>
- Previously we disabled compression and subsampling when either condition was<br>
- true, but this leads to large files under some conditions. The code here instead<br>
- overrides any downsampling and uses Subsample instead, and selects a lossless<br>
- compression scheme.<br>
-<br>
- This results in smaller files for some conditions without affecting ordinary files.<br>
-<br>
- Also removed a line with a C++ style comment<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-03 14:55: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=ceac6867c04ef61e5529b0af14a2c4b641ca4206">ceac6867c04ef61e5529b0af14a2c4b641ca4206</a>
-<blockquote>
-<p>
- Bug 693164: PDF (partially) ignore tr mode for type 3 fonts<br>
-<br>
- The PDF spec states that: &quot;The text rendering mode has no effect on text<br>
- displayed in a Type 3 font&quot; - unfortunately, not only does Acrobat not<br>
- behave like that, it behaves differently with various versions Acrobat.<br>
- Worse, Acrobat X Pro seems to produce different results depending on how you<br>
- load the file!<br>
-<br>
- This change makes GS match Acrobat X Pro, which ignores text rendering modes<br>
- for Type 3 fonts, except mode 3 (non-marking).<br>
-<br>
- As well as the problem file now working, this causes tiny differences in outline<br>
- for Bug692129.pdf, chartab.pdf. It causes a progression with pdf-t3-simple.pdf<br>
- which now renders more like Acro X.<br>
-<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-02 22:49:17 +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=e9bbff5f116eccd87946df28fced66ba42cbad1d">e9bbff5f116eccd87946df28fced66ba42cbad1d</a>
-<blockquote>
-<p>
- Bug 693050 : Fix valgrind error in 0CF9 folder<br>
-<br>
-gs/jbig2dec/jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-07-02 21:53: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=aad5317a0e77dac6fd2766b99c12c3ca7874c7d4">aad5317a0e77dac6fd2766b99c12c3ca7874c7d4</a>
-<blockquote>
-<p>
- Bug 693050 : Fix error handling in 0717 folder<br>
-<br>
-gs/jbig2dec/jbig2_halftone.c<br>
-gs/jbig2dec/jbig2_mmr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-01 14:05:03 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3a5a524ea71a58cc0e9e0200bb98a2fc341ec033">3a5a524ea71a58cc0e9e0200bb98a2fc341ec033</a>
-<blockquote>
-<p>
- Fix for broken AA support for devices that support the devn color type<br>
-<br>
- This fix involved the addition of a copy_alpha_hl_color for passing along the devn color<br>
- value when doing the copy_alpha procedure. This required support through the clist,<br>
- special handing in the pdf14 device and a default procedure for the operation.<br>
- The only devices that should be affected are tiffsep and psdcmyk. Support for 16bit psd<br>
- devices may have issues and I will go back to check on this later as a customer is waiting<br>
- for this for 8 bit tiffsep.<br>
-<br>
-gs/base/gdevabuf.c<br>
-gs/base/gdevdbit.c<br>
-gs/base/gdevdflt.c<br>
-gs/base/gdevmem.c<br>
-gs/base/gdevmem.h<br>
-gs/base/gdevmpla.c<br>
-gs/base/gdevnfwd.c<br>
-gs/base/gdevp14.c<br>
-gs/base/gsdcolor.h<br>
-gs/base/gspaint.c<br>
-gs/base/gxccman.c<br>
-gs/base/gxcldev.h<br>
-gs/base/gxclip.c<br>
-gs/base/gxclip.h<br>
-gs/base/gxclip2.c<br>
-gs/base/gxclipm.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclpath.h<br>
-gs/base/gxclrast.c<br>
-gs/base/gxclrect.c<br>
-gs/base/gxdevcli.h<br>
-gs/base/gxdevice.h<br>
-gs/base/gxdevmem.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-28 10:53:31 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=58d67647585fdb2707ccdb5eccc0123c77fbe495">58d67647585fdb2707ccdb5eccc0123c77fbe495</a>
-<blockquote>
-<p>
- Bug 693156 - incorrect units.<br>
-<br>
- PCL distinguishes between device units and native units, and before<br>
- this change we had interpreted them to be the same, resulting in what<br>
- appeared to resolution dependencies in HPGL/2 - RTL. The native units<br>
- can now be set by the PJL resolution given on the command line<br>
- independent of the physical units of the device.<br>
-<br>
-pcl/pcjob.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-28 11:07:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc797976bca27ea5c706d93f5fcb42b5386cc6ed">dc797976bca27ea5c706d93f5fcb42b5386cc6ed</a>
-<blockquote>
-<p>
- pdfwrite - store widths for regular fonts when there is a vertical displacement.<br>
-<br>
- Bug #691369 &quot;Widths array in font dictionary contains incorrect values for rotated text&quot;<br>
-<br>
- Similar to bug #692365 but this time for regular fonts not CIDFonts. If there<br>
- is any vertcial displacement of the glyph then we did not store teh glyph<br>
- width, leading to it being emitted as 0.<br>
-<br>
- Fix is very similar also.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gdevpdte.c<br>
-gs/base/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-27 09:34: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=2ff29d1f499451c63ddb8b3cc152cb2eda4b5e33">2ff29d1f499451c63ddb8b3cc152cb2eda4b5e33</a>
-<blockquote>
-<p>
- pdfwrite - record glyph vertical metrics evne when the position vector has a vertical shift<br>
-<br>
- Bug #692365<br>
-<br>
- The store_glyph_width routine returns &gt;0 if there is any vertical shift in<br>
- addition to a width, this is defined as 'not safe to cache'. The routine<br>
- pdf_glyph_widths ORs that into its return value and passes the data back.<br>
-<br>
- scan_cmap_text was checking that value before recording the width, and not<br>
- recording it if it was &gt; 0. This is incorrect, at least when in vertical writing<br>
- mode, as this is the only place that we record the vertical metrics for use<br>
- in the W2 array. If we don't record them here this information is lost. Also<br>
- we don't need to worry about the vertical movement here as that is dealt with<br>
- elswewhere by modifying the text matrix.<br>
-<br>
- This was leading to pdfwrite emitting a /W2 entry with all 0 values [0 0 0]<br>
- which caused significant misplacement of glyphs.<br>
-<br>
- Expected Differences<br>
- Bug692576.ps exhibits a progression<br>
-<br>
-gs/base/gdevpdtc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-27 09:07:06 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d026537beaf869a2792cf5d97e8b5c3555875f28">d026537beaf869a2792cf5d97e8b5c3555875f28</a>
-<blockquote>
-<p>
- Bug 693158: initialise the fapi_raster structure before use<br>
-<br>
- Fixes several valgrind errors about use of uninitialised values.<br>
-<br>
- No cluster differences expected.<br>
-<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-27 07:50: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=bc9efbeb2e69cd6d1aac4d14f30ba3b170e6a8f7">bc9efbeb2e69cd6d1aac4d14f30ba3b170e6a8f7</a>
-<blockquote>
-<p>
- Fix a small typo in README.txt<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-README.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-26 15:34:44 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=526c580e272ee15c488b9fe4845482a30ce05eef">526c580e272ee15c488b9fe4845482a30ce05eef</a>
-<blockquote>
-<p>
- Bug 693064: raise maximum possible GS_CLIENT_COLOR_MAX_COMPONENTS to 32<br>
-<br>
- By default we support a maximum of 14 components. Supposedly this can be<br>
- increased by raising GS_CLIENT_COLOR_MAX_COMPONENTS to a larger number<br>
- on startup, but this starts to cause problems in various places throughout<br>
- the code.<br>
-<br>
- The first such place is in the bpc_to_depth function (found in gdevdevn<br>
- and various other places), where the calculation goes wrong for anything<br>
- above 31 components at 8 bpc. We fix that here.<br>
-<br>
- This allows us to get to 32 components. To raise it above 32 presents<br>
- problems on most architectures as the code assumes elsewhere that we<br>
- can use a bitmask to represent which components are present.<br>
-<br>
- We may be able to tweak the code to use a uint64_t instead, in which<br>
- case we can probably get to 64 components; is that high enough?<br>
-<br>
-gs/base/gdevdevn.c<br>
-gs/base/gdevrinkj.c<br>
-gs/base/gdevxcf.c<br>
-gs/base/gxclist.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-24 11:11:52 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49fd8e8156bb5b751ff8a03e86ea61cb9c496a6b">49fd8e8156bb5b751ff8a03e86ea61cb9c496a6b</a>
-<blockquote>
-<p>
- Bug 693142: Fix shape of highlight annotation.<br>
-<br>
- Draw rotated highlight annotation correctly. Fix a bug in calculation<br>
- of the centers of the small arcs at the ends of the highlighted area.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-23 23:57:19 +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=5eff06782ad8c9b09f132add0d5f8a7458e0c7b2">5eff06782ad8c9b09f132add0d5f8a7458e0c7b2</a>
-<blockquote>
-<p>
- Bug 693050 : Fix error handling in dcbd folder<br>
-<br>
-gs/jbig2dec/jbig2_page.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-23 23:00:47 +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=b93322df872c8ff026127ea54fe86d3d940f1866">b93322df872c8ff026127ea54fe86d3d940f1866</a>
-<blockquote>
-<p>
- Bug 693050 : Fix error handling in 9557 folder<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-23 22:14:43 +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=ed7a9680adc24f0063455196d817810ff623f32a">ed7a9680adc24f0063455196d817810ff623f32a</a>
-<blockquote>
-<p>
- Bug 693050 : Fix memory leak in 4faa folder<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-23 21:12:19 +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=b306b997740d3ad904d8dc6b82ee981b1db52bd2">b306b997740d3ad904d8dc6b82ee981b1db52bd2</a>
-<blockquote>
-<p>
- Bug 693050 : Fix error handling in 2908 folder<br>
-<br>
-gs/jbig2dec/jbig2_halftone.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-22 22:25: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=8c497936e37bdf430b87fd65db3fa6070716fcdf">8c497936e37bdf430b87fd65db3fa6070716fcdf</a>
-<blockquote>
-<p>
- Bug 693050 : Fix memory leak in 146f folder<br>
-<br>
-gs/jbig2dec/jbig2_mmr.c<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-22 16:56:39 +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=b73adca0e4e3b9ad4a2e4fd5ba16f845362fa37b">b73adca0e4e3b9ad4a2e4fd5ba16f845362fa37b</a>
-<blockquote>
-<p>
- Bug 693050 : Fix minor typos and memory leak in 040d folder<br>
-<br>
-gs/jbig2dec/jbig2_arith.c<br>
-gs/jbig2dec/jbig2_image.c<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-gs/jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-20 18:18: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=dc77e931b2a6118092bac21b4dd38bc10d41e644">dc77e931b2a6118092bac21b4dd38bc10d41e644</a>
-<blockquote>
-<p>
- Bug 690723 : Prevent over writing unallocated memory when parsing an image<br>
-<br>
-gs/jbig2dec/jbig2_mmr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-19 11:57:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9eb67bc021dda346896786e0d813245387649ce2">9eb67bc021dda346896786e0d813245387649ce2</a>
-<blockquote>
-<p>
- Fix a parallel build problem......<br>
-<br>
- A couple of places that depend upon gconfig.h had their dependency listed as<br>
- being gconfxx.h (would be created dynamically by its own target) and would<br>
- then copy gconfxx.h to gconfig.h (I have no idea why this extra complication<br>
- is there, but.....).<br>
-<br>
- With an unfortunate, but not uncommon confluence of two make instances, both<br>
- instances could end up trying to copy gconfxx.h to gconfig.h, thus causing<br>
- Unix &quot;cp&quot; (at least) to throw an error, and the build to fail.<br>
-<br>
- Now gconfig.h has its own target (which depends on gconfxx.h), and that<br>
- target is where gconfxx.h is copied to gconfig.h, thus allowing make to<br>
- correctly track the creation of the file.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gs.mak<br>
-gs/base/lib.mak<br>
-gs/psi/int.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-18 16:51:30 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7f98970a6c0e641e87eb202dc2087814249d0408">7f98970a6c0e641e87eb202dc2087814249d0408</a>
-<blockquote>
-<p>
- Add 3:2 and 3:4 downscaling to tiffsep/psd/downscaler.<br>
-<br>
- Currently the downscaler can only downscale in integer increments. To<br>
- accomodate a potential need to efficiently scale 1200 -&gt; 800 and<br>
- 600 -&gt; 800 dpi, we introduce new functionality to allow 3:2 and 3:4<br>
- scaling modes.<br>
-<br>
- We shoehorn these into the existing scaler system by using DownScaleFactor<br>
- settings of 32 and 34 respectively; any other DownScaleFactor &gt; 8 will<br>
- give a rangecheck error.<br>
-<br>
- This has required some changes within the downscaler code itself, and<br>
- will require more changes in any device that wants to use these. Currently<br>
- the cores are only provided in the planar modes; hence tiffsep and psd are<br>
- the only devices that have been updated to work with this.<br>
-<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevtifs.c<br>
-gs/base/gdevtsep.c<br>
-gs/base/gxdownscale.c<br>
-gs/base/gxdownscale.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-18 13:42: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=7cd694d6e98719b77095069007e472334e16dd0e">7cd694d6e98719b77095069007e472334e16dd0e</a>
-<blockquote>
-<p>
- Check for opacity 0.0 in xps transparency analysis.<br>
-<br>
- Objects with opacity 0.0 are skipped by the parser, so we don't<br>
- have to install transparency device for them.<br>
-<br>
-xps/xpsanalyze.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-01 12:16:08 +0100
-</strong>
-<br>Tor Andersson &lt;tor@ccxvii.net&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=32c5d9122cf7ea813755d079f80445e6f2d842f4">32c5d9122cf7ea813755d079f80445e6f2d842f4</a>
-<blockquote>
-<p>
- Move the has_transparency flag into the xps context.<br>
-<br>
- Patterns to set the uses_transparency flag. The current transparency scan<br>
- doesn't resolve resources that have been inherited from a higher level.<br>
- Doing this would require rewriting the entire transparency scanning and<br>
- involve a lot more parsing. Instead we reuse the results from the<br>
- original transparency scan we do at the beginning of the page.<br>
-<br>
- Fix bug 692513.<br>
-<br>
-xps/ghostxps.h<br>
-xps/xpspage.c<br>
-xps/xpstile.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-18 10:01:46 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0a33ed5b599d73509d0cde7e84e257e89ff1c1fb">0a33ed5b599d73509d0cde7e84e257e89ff1c1fb</a>
-<blockquote>
-<p>
- Fix comment delineation.<br>
-<br>
- I accidentally used the wrong comment delineator when I updated the copyright.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/toolbin/pdfinflt.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-15 19:22:52 +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=64984bdf351dc27e40cbe5af5751dcdfcb448366">64984bdf351dc27e40cbe5af5751dcdfcb448366</a>
-<blockquote>
-<p>
- Bug 693050 : Fixes CERT reported issues labelled DestAv<br>
-<br>
-gs/jbig2dec/jbig2.c<br>
-gs/jbig2dec/jbig2_priv.h<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-gs/jbig2dec/jbig2_symbol_dict.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-15 14:38: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=28a37f219de0bbd04bef9026812cbb9ea42a9910">28a37f219de0bbd04bef9026812cbb9ea42a9910</a>
-<blockquote>
-<p>
- Add a default shared lib extension.<br>
-<br>
- Just a minor tweak so the dynamic library extension is set to *something*<br>
- even on unrecognised platforms.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-15 14:01: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=7c9a1a772cef2339c110238b40c73e8039dca2eb">7c9a1a772cef2339c110238b40c73e8039dca2eb</a>
-<blockquote>
-<p>
- Revert some copyrights accidentally changed in the recent revamp<br>
-<br>
- Three files which are copyright FSF.<br>
-<br>
- Thanks to zeniko for spotting the mistake.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/jbig2dec/getopt.c<br>
-gs/jbig2dec/getopt.h<br>
-gs/jbig2dec/getopt1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-15 13:44: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=cd2cb0829b3a8ffe0e8a3bd87c08941663d691f9">cd2cb0829b3a8ffe0e8a3bd87c08941663d691f9</a>
-<blockquote>
-<p>
- Bug 693113: configure set shared lib file extension<br>
-<br>
- Have the configure set the file extension for the shared library. This is<br>
- purely to handle Apple's (pointless?) decision to make OS X use &quot;.dylib&quot; as<br>
- the shared library extension, rather than the &quot;.so&quot; used by every other<br>
- Unix-a-like.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/Makefile.in<br>
-gs/base/configure.ac<br>
-gs/base/macos-mcp.mak<br>
-gs/base/macosx.mak<br>
-gs/base/unix-dll.mak<br>
-gs/base/unix-gcc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-15 08:35:50 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=570984d2074289bb06261112d26bc323725c321e">570984d2074289bb06261112d26bc323725c321e</a>
-<blockquote>
-<p>
- Bug 693119: Tweak EOL detection after 'stream'<br>
-<br>
- Modify EOL processing after 'stream' operator to accept a new class of<br>
- broken PDF files. GS now stops skipping spaces when it finds '\n' or a<br>
- non-space character.<br>
-<br>
-gs/Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-14 17:06: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=8988c41bf227e5f370fba7592bfd18e85330b0c2">8988c41bf227e5f370fba7592bfd18e85330b0c2</a>
-<blockquote>
-<p>
- Bug 693050 : Fixes CERT reported issues labelled SourceAvNearNull<br>
-<br>
-gs/jbig2dec/jbig2_image.c<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-gs/jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-14 16:36: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=53cc9631a7725b0f6a20d815252c3a23b978d8ee">53cc9631a7725b0f6a20d815252c3a23b978d8ee</a>
-<blockquote>
-<p>
- Update pdf_info.ps to report the UserUnit for a page, if present.<br>
-<br>
- This allows users to correctly calculate media and crop sizes from the<br>
- relevant 'Box' arrats.<br>
-<br>
- Not cluster tested<br>
-<br>
-gs/toolbin/pdf_info.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-13 14:24:18 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d8fd89891d07d4b04cf180c3f5a4ac4388c769ce">d8fd89891d07d4b04cf180c3f5a4ac4388c769ce</a>
-<blockquote>
-<p>
- Fixes Bug 692991 - XL assembler and dissasembler now work with python 3.<br>
-<br>
- Thanks to Hin-Tak Leung for these changes.<br>
-<br>
-tools/pxlasm.py<br>
-tools/pxldis.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-13 13:29:35 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=76aad1b9e4eb2ae30d42b995a3ba8998b8e0820f">76aad1b9e4eb2ae30d42b995a3ba8998b8e0820f</a>
-<blockquote>
-<p>
- Bug 690585 - Use the defalt strip copy rop routine when the<br>
- destination is not included.<br>
-<br>
- Thanks to Hin-Tak Leung for this fix.<br>
-<br>
- CLUSTER UNTESTED<br>
-<br>
-gs/base/gdevpx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-13 18:40: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=c87f2d826726f8b1108d233096fa6fd4a872b020">c87f2d826726f8b1108d233096fa6fd4a872b020</a>
-<blockquote>
-<p>
- Fix parameter passed to dict_find_string()<br>
-<br>
- Parameter was a ref *, should have been a ref **.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zchar42.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-13 18:37: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=e786619c57be0c846051ec264eb80b69a9ca42de">e786619c57be0c846051ec264eb80b69a9ca42de</a>
-<blockquote>
-<p>
- Bug 693116: disable lzma compression in libtiff<br>
-<br>
- lzma is not part of base line tiff, but is enabled by default in libtiff, since<br>
- we only support base line, disable lzma.<br>
-<br>
- No cluster differences.<br>
-<br>
-configure.ac<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-13 13:15: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=85be3180530043232160745b04af9d293bd60fad">85be3180530043232160745b04af9d293bd60fad</a>
-<blockquote>
-<p>
- Squash a warning in commit fae7be45<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/int.mak<br>
-gs/psi/zchar42.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-13 11:14:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39433fce0a15c5cae831848edd4cefd55019a241">39433fce0a15c5cae831848edd4cefd55019a241</a>
-<blockquote>
-<p>
- Update copyright &quot;headers&quot;.<br>
-<br>
- As agreed on IRC and via e-mail:<br>
-<br>
- Reinstate the reference to the LICENSE file.<br>
-<br>
- Remove copyright references to Aladdin Enterprises and artofcode (some<br>
- references remain in comments about historical copyright assignments, and<br>
- the like), in favour of Artifex copyright notices.<br>
-<br>
- Update copyright dates.<br>
-<br>
- Remove the $Id$ &quot;tag&quot;.<br>
-<br>
- Since the move to git, the $Id$ &quot;tag&quot; comment in each file is redundant.<br>
-<br>
- No cluster differences.<br>
-<br>
-Makefile<br>
-autogen.sh<br>
-common/cp.bat<br>
-common/gccdefs.mak<br>
-common/generic.mak<br>
-common/msvc_top.mak<br>
-common/msvcdefs.mak<br>
-common/mv.bat<br>
-common/pcdefs.mak<br>
-common/rm.bat<br>
-common/sgidefs.mak<br>
-common/ugcc_top.mak<br>
-common/unixdefs.mak<br>
-config.mak.in<br>
-configure.ac<br>
-gs/Resource/CIDFont/ArtifexBullet<br>
-gs/Resource/CMap/Identity-UTF16-H<br>
-gs/Resource/ColorSpace/DefaultCMYK<br>
-gs/Resource/ColorSpace/DefaultGray<br>
-gs/Resource/ColorSpace/DefaultRGB<br>
-gs/Resource/ColorSpace/TrivialCMYK<br>
-gs/Resource/ColorSpace/sGray<br>
-gs/Resource/ColorSpace/sRGB<br>
-gs/Resource/Decoding/FCO_Dingbats<br>
-gs/Resource/Decoding/FCO_Symbol<br>
-gs/Resource/Decoding/FCO_Unicode<br>
-gs/Resource/Decoding/FCO_Wingdings<br>
-gs/Resource/Decoding/Latin1<br>
-gs/Resource/Decoding/StandardEncoding<br>
-gs/Resource/Decoding/Unicode<br>
-gs/Resource/Encoding/Wingdings<br>
-gs/Resource/Init/FCOfontmap-PCLPS2<br>
-gs/Resource/Init/Fontmap.GS<br>
-gs/Resource/Init/cidfmap<br>
-gs/Resource/Init/gs_agl.ps<br>
-gs/Resource/Init/gs_btokn.ps<br>
-gs/Resource/Init/gs_cet.ps<br>
-gs/Resource/Init/gs_cff.ps<br>
-gs/Resource/Init/gs_cidcm.ps<br>
-gs/Resource/Init/gs_ciddc.ps<br>
-gs/Resource/Init/gs_cidfm.ps<br>
-gs/Resource/Init/gs_cidfn.ps<br>
-gs/Resource/Init/gs_cidtt.ps<br>
-gs/Resource/Init/gs_cmap.ps<br>
-gs/Resource/Init/gs_cspace.ps<br>
-gs/Resource/Init/gs_css_e.ps<br>
-gs/Resource/Init/gs_dbt_e.ps<br>
-gs/Resource/Init/gs_diskf.ps<br>
-gs/Resource/Init/gs_diskn.ps<br>
-gs/Resource/Init/gs_dpnxt.ps<br>
-gs/Resource/Init/gs_dps.ps<br>
-gs/Resource/Init/gs_dps1.ps<br>
-gs/Resource/Init/gs_dps2.ps<br>
-gs/Resource/Init/gs_dscp.ps<br>
-gs/Resource/Init/gs_epsf.ps<br>
-gs/Resource/Init/gs_fapi.ps<br>
-gs/Resource/Init/gs_fntem.ps<br>
-gs/Resource/Init/gs_fonts.ps<br>
-gs/Resource/Init/gs_frsd.ps<br>
-gs/Resource/Init/gs_icc.ps<br>
-gs/Resource/Init/gs_il1_e.ps<br>
-gs/Resource/Init/gs_img.ps<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/Resource/Init/gs_l2img.ps<br>
-gs/Resource/Init/gs_lev2.ps<br>
-gs/Resource/Init/gs_ll3.ps<br>
-gs/Resource/Init/gs_mex_e.ps<br>
-gs/Resource/Init/gs_mgl_e.ps<br>
-gs/Resource/Init/gs_mro_e.ps<br>
-gs/Resource/Init/gs_pdf_e.ps<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-gs/Resource/Init/gs_res.ps<br>
-gs/Resource/Init/gs_resmp.ps<br>
-gs/Resource/Init/gs_setpd.ps<br>
-gs/Resource/Init/gs_statd.ps<br>
-gs/Resource/Init/gs_std_e.ps<br>
-gs/Resource/Init/gs_sym_e.ps<br>
-gs/Resource/Init/gs_trap.ps<br>
-gs/Resource/Init/gs_ttf.ps<br>
-gs/Resource/Init/gs_typ32.ps<br>
-gs/Resource/Init/gs_typ42.ps<br>
-gs/Resource/Init/gs_type1.ps<br>
-gs/Resource/Init/gs_wan_e.ps<br>
-gs/Resource/Init/pdf_base.ps<br>
-gs/Resource/Init/pdf_cslayer.ps<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/Resource/Init/pdf_font.ps<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/Resource/Init/pdf_ops.ps<br>
-gs/Resource/Init/pdf_rbld.ps<br>
-gs/Resource/Init/pdf_sec.ps<br>
-gs/Resource/Init/xlatmap<br>
-gs/Resource/SubstCID/CNS1-WMode<br>
-gs/Resource/SubstCID/GB1-WMode<br>
-gs/Resource/SubstCID/Japan1-WMode<br>
-gs/Resource/SubstCID/Korea1-WMode<br>
-gs/arch/windows-x64-msvc.h<br>
-gs/arch/windows-x86-msvc.h<br>
-gs/autogen.sh<br>
-gs/base/ConvertUTF.c<br>
-gs/base/ConvertUTF.h<br>
-gs/base/Makefile.in<br>
-gs/base/aes.c<br>
-gs/base/aes.h<br>
-gs/base/all-arch.mak<br>
-gs/base/assert_.h<br>
-gs/base/bench.c<br>
-gs/base/catmake<br>
-gs/base/configure.ac<br>
-gs/base/contrib.mak<br>
-gs/base/cp.bat<br>
-gs/base/cp.cmd<br>
-gs/base/ctype_.h<br>
-gs/base/devs.mak<br>
-gs/base/dirent_.h<br>
-gs/base/dos_.h<br>
-gs/base/echogs.c<br>
-gs/base/errno_.h<br>
-gs/base/expat.mak<br>
-gs/base/fcntl_.h<br>
-gs/base/freetype.mak<br>
-gs/base/gconf.c<br>
-gs/base/gconf.h<br>
-gs/base/gdbflags.h<br>
-gs/base/gdebug.h<br>
-gs/base/gdev3852.c<br>
-gs/base/gdev3b1.c<br>
-gs/base/gdev4081.c<br>
-gs/base/gdev4693.c<br>
-gs/base/gdev8510.c<br>
-gs/base/gdev8bcm.c<br>
-gs/base/gdev8bcm.h<br>
-gs/base/gdevabuf.c<br>
-gs/base/gdevadmp.c<br>
-gs/base/gdevagl.c<br>
-gs/base/gdevagl.h<br>
-gs/base/gdevatx.c<br>
-gs/base/gdevbbox.c<br>
-gs/base/gdevbbox.h<br>
-gs/base/gdevbit.c<br>
-gs/base/gdevbj10.c<br>
-gs/base/gdevbjc.h<br>
-gs/base/gdevbjcl.c<br>
-gs/base/gdevbjcl.h<br>
-gs/base/gdevbmp.c<br>
-gs/base/gdevbmp.h<br>
-gs/base/gdevbmpa.c<br>
-gs/base/gdevbmpc.c<br>
-gs/base/gdevccr.c<br>
-gs/base/gdevcdj.c<br>
-gs/base/gdevcfax.c<br>
-gs/base/gdevcif.c<br>
-gs/base/gdevclj.c<br>
-gs/base/gdevcljc.c<br>
-gs/base/gdevcp50.c<br>
-gs/base/gdevcslw.c<br>
-gs/base/gdevdbit.c<br>
-gs/base/gdevdcrd.c<br>
-gs/base/gdevdcrd.h<br>
-gs/base/gdevddrw.c<br>
-gs/base/gdevddrw.h<br>
-gs/base/gdevdevn.c<br>
-gs/base/gdevdevn.h<br>
-gs/base/gdevdfax.c<br>
-gs/base/gdevdflt.c<br>
-gs/base/gdevdgbr.c<br>
-gs/base/gdevdjet.c<br>
-gs/base/gdevdjtc.c<br>
-gs/base/gdevdljm.c<br>
-gs/base/gdevdljm.h<br>
-gs/base/gdevdm24.c<br>
-gs/base/gdevdrop.c<br>
-gs/base/gdevdsha.c<br>
-gs/base/gdevdsp.c<br>
-gs/base/gdevdsp.h<br>
-gs/base/gdevdsp2.h<br>
-gs/base/gdevemap.c<br>
-gs/base/gdevepsc.c<br>
-gs/base/gdevepsn.c<br>
-gs/base/gdevescp.c<br>
-gs/base/gdevevga.c<br>
-gs/base/gdevfax.c<br>
-gs/base/gdevfax.h<br>
-gs/base/gdevherc.c<br>
-gs/base/gdevhit.c<br>
-gs/base/gdevhl7x.c<br>
-gs/base/gdevicov.c<br>
-gs/base/gdevifno.c<br>
-gs/base/gdevijs.c<br>
-gs/base/gdevimgn.c<br>
-gs/base/gdevjbig2.c<br>
-gs/base/gdevjpeg.c<br>
-gs/base/gdevjpx.c<br>
-gs/base/gdevl256.c<br>
-gs/base/gdevl31s.c<br>
-gs/base/gdevlbp8.c<br>
-gs/base/gdevlj56.c<br>
-gs/base/gdevlp8k.c<br>
-gs/base/gdevlxm.c<br>
-gs/base/gdevm1.c<br>
-gs/base/gdevm16.c<br>
-gs/base/gdevm2.c<br>
-gs/base/gdevm24.c<br>
-gs/base/gdevm32.c<br>
-gs/base/gdevm4.c<br>
-gs/base/gdevm40.c<br>
-gs/base/gdevm48.c<br>
-gs/base/gdevm56.c<br>
-gs/base/gdevm64.c<br>
-gs/base/gdevm8.c<br>
-gs/base/gdevmac.c<br>
-gs/base/gdevmac.h<br>
-gs/base/gdevmacpictop.h<br>
-gs/base/gdevmacttf.h<br>
-gs/base/gdevmeds.c<br>
-gs/base/gdevmeds.h<br>
-gs/base/gdevmem.c<br>
-gs/base/gdevmem.h<br>
-gs/base/gdevmgr.c<br>
-gs/base/gdevmgr.h<br>
-gs/base/gdevmiff.c<br>
-gs/base/gdevmpla.c<br>
-gs/base/gdevmpla.h<br>
-gs/base/gdevmr1.c<br>
-gs/base/gdevmr2n.c<br>
-gs/base/gdevmr8n.c<br>
-gs/base/gdevmrop.h<br>
-gs/base/gdevmrun.c<br>
-gs/base/gdevmrun.h<br>
-gs/base/gdevmswn.c<br>
-gs/base/gdevmswn.h<br>
-gs/base/gdevmsxf.c<br>
-gs/base/gdevmx.c<br>
-gs/base/gdevn533.c<br>
-gs/base/gdevnfwd.c<br>
-gs/base/gdevo182.c<br>
-gs/base/gdevokii.c<br>
-gs/base/gdevos2p.c<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevp14.h<br>
-gs/base/gdevp2up.c<br>
-gs/base/gdevpbm.c<br>
-gs/base/gdevpccm.c<br>
-gs/base/gdevpccm.h<br>
-gs/base/gdevpcfb.c<br>
-gs/base/gdevpcfb.h<br>
-gs/base/gdevpcl.c<br>
-gs/base/gdevpcl.h<br>
-gs/base/gdevpcx.c<br>
-gs/base/gdevpdf.c<br>
-gs/base/gdevpdfb.c<br>
-gs/base/gdevpdfb.h<br>
-gs/base/gdevpdfc.c<br>
-gs/base/gdevpdfc.h<br>
-gs/base/gdevpdfd.c<br>
-gs/base/gdevpdfe.c<br>
-gs/base/gdevpdfg.c<br>
-gs/base/gdevpdfg.h<br>
-gs/base/gdevpdfi.c<br>
-gs/base/gdevpdfj.c<br>
-gs/base/gdevpdfk.c<br>
-gs/base/gdevpdfm.c<br>
-gs/base/gdevpdfo.c<br>
-gs/base/gdevpdfo.h<br>
-gs/base/gdevpdfp.c<br>
-gs/base/gdevpdfr.c<br>
-gs/base/gdevpdft.c<br>
-gs/base/gdevpdfu.c<br>
-gs/base/gdevpdfv.c<br>
-gs/base/gdevpdfx.h<br>
-gs/base/gdevpdt.c<br>
-gs/base/gdevpdt.h<br>
-gs/base/gdevpdtb.c<br>
-gs/base/gdevpdtb.h<br>
-gs/base/gdevpdtc.c<br>
-gs/base/gdevpdtd.c<br>
-gs/base/gdevpdtd.h<br>
-gs/base/gdevpdte.c<br>
-gs/base/gdevpdtf.c<br>
-gs/base/gdevpdtf.h<br>
-gs/base/gdevpdti.c<br>
-gs/base/gdevpdti.h<br>
-gs/base/gdevpdts.c<br>
-gs/base/gdevpdts.h<br>
-gs/base/gdevpdtt.c<br>
-gs/base/gdevpdtt.h<br>
-gs/base/gdevpdtv.c<br>
-gs/base/gdevpdtv.h<br>
-gs/base/gdevpdtw.c<br>
-gs/base/gdevpdtw.h<br>
-gs/base/gdevpdtx.h<br>
-gs/base/gdevpe.c<br>
-gs/base/gdevperm.c<br>
-gs/base/gdevphex.c<br>
-gs/base/gdevpipe.c<br>
-gs/base/gdevpjet.c<br>
-gs/base/gdevplan.c<br>
-gs/base/gdevplib.c<br>
-gs/base/gdevplib.h<br>
-gs/base/gdevplnx.c<br>
-gs/base/gdevplnx.h<br>
-gs/base/gdevpm.h<br>
-gs/base/gdevpng.c<br>
-gs/base/gdevppla.c<br>
-gs/base/gdevppla.h<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevprn.h<br>
-gs/base/gdevprna.c<br>
-gs/base/gdevprna.h<br>
-gs/base/gdevps.c<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevpsdf.h<br>
-gs/base/gdevpsdi.c<br>
-gs/base/gdevpsdp.c<br>
-gs/base/gdevpsds.c<br>
-gs/base/gdevpsds.h<br>
-gs/base/gdevpsdu.c<br>
-gs/base/gdevpsf.h<br>
-gs/base/gdevpsf1.c<br>
-gs/base/gdevpsf2.c<br>
-gs/base/gdevpsfm.c<br>
-gs/base/gdevpsft.c<br>
-gs/base/gdevpsfu.c<br>
-gs/base/gdevpsfx.c<br>
-gs/base/gdevpsim.c<br>
-gs/base/gdevpsu.c<br>
-gs/base/gdevpsu.h<br>
-gs/base/gdevpx.c<br>
-gs/base/gdevpxat.h<br>
-gs/base/gdevpxen.h<br>
-gs/base/gdevpxop.h<br>
-gs/base/gdevpxut.c<br>
-gs/base/gdevpxut.h<br>
-gs/base/gdevrinkj.c<br>
-gs/base/gdevrops.c<br>
-gs/base/gdevs3ga.c<br>
-gs/base/gdevsco.c<br>
-gs/base/gdevsgi.c<br>
-gs/base/gdevsgi.h<br>
-gs/base/gdevsj48.c<br>
-gs/base/gdevsnfb.c<br>
-gs/base/gdevsppr.c<br>
-gs/base/gdevstc.c<br>
-gs/base/gdevstc.h<br>
-gs/base/gdevstc1.c<br>
-gs/base/gdevstc2.c<br>
-gs/base/gdevstc3.c<br>
-gs/base/gdevstc4.c<br>
-gs/base/gdevsun.c<br>
-gs/base/gdevsunr.c<br>
-gs/base/gdevsvg.c<br>
-gs/base/gdevsvga.c<br>
-gs/base/gdevsvga.h<br>
-gs/base/gdevtfax.c<br>
-gs/base/gdevtfax.h<br>
-gs/base/gdevtfnx.c<br>
-gs/base/gdevtifs.c<br>
-gs/base/gdevtifs.h<br>
-gs/base/gdevtknk.c<br>
-gs/base/gdevtrac.c<br>
-gs/base/gdevtsep.c<br>
-gs/base/gdevtxtw.c<br>
-gs/base/gdevupd.c<br>
-gs/base/gdevvec.c<br>
-gs/base/gdevvec.h<br>
-gs/base/gdevvglb.c<br>
-gs/base/gdevwddb.c<br>
-gs/base/gdevwdib.c<br>
-gs/base/gdevwpr2.c<br>
-gs/base/gdevwprn.c<br>
-gs/base/gdevx.c<br>
-gs/base/gdevx.h<br>
-gs/base/gdevxalt.c<br>
-gs/base/gdevxcf.c<br>
-gs/base/gdevxcmp.c<br>
-gs/base/gdevxcmp.h<br>
-gs/base/gdevxini.c<br>
-gs/base/gdevxres.c<br>
-gs/base/genarch.c<br>
-gs/base/genconf.c<br>
-gs/base/gendev.c<br>
-gs/base/genht.c<br>
-gs/base/gp.h<br>
-gs/base/gp_dosfe.c<br>
-gs/base/gp_dosfs.c<br>
-gs/base/gp_dvx.c<br>
-gs/base/gp_getnv.c<br>
-gs/base/gp_mac.c<br>
-gs/base/gp_mac.h<br>
-gs/base/gp_macio.c<br>
-gs/base/gp_macpoll.c<br>
-gs/base/gp_mktmp.c<br>
-gs/base/gp_msdll.c<br>
-gs/base/gp_msdos.c<br>
-gs/base/gp_mshdl.c<br>
-gs/base/gp_mslib.c<br>
-gs/base/gp_mspol.c<br>
-gs/base/gp_msprn.c<br>
-gs/base/gp_mswin.c<br>
-gs/base/gp_mswin.h<br>
-gs/base/gp_nsync.c<br>
-gs/base/gp_ntfs.c<br>
-gs/base/gp_os2.c<br>
-gs/base/gp_os2.h<br>
-gs/base/gp_os2fs.c<br>
-gs/base/gp_os2pr.c<br>
-gs/base/gp_os9.c<br>
-gs/base/gp_paper.c<br>
-gs/base/gp_psync.c<br>
-gs/base/gp_stdia.c<br>
-gs/base/gp_stdin.c<br>
-gs/base/gp_strdl.c<br>
-gs/base/gp_sysv.c<br>
-gs/base/gp_unifn.c<br>
-gs/base/gp_unifs.c<br>
-gs/base/gp_unix.c<br>
-gs/base/gp_unix_cache.c<br>
-gs/base/gp_upapr.c<br>
-gs/base/gp_vms.c<br>
-gs/base/gp_wgetv.c<br>
-gs/base/gp_win32.c<br>
-gs/base/gp_wpapr.c<br>
-gs/base/gp_wsync.c<br>
-gs/base/gp_wutf8.c<br>
-gs/base/gpcheck.h<br>
-gs/base/gpgetenv.h<br>
-gs/base/gpmisc.c<br>
-gs/base/gpmisc.h<br>
-gs/base/gpsync.h<br>
-gs/base/gs.mak<br>
-gs/base/gs_dll_call.h<br>
-gs/base/gs_mgl_e.h<br>
-gs/base/gs_mro_e.h<br>
-gs/base/gsalloc.c<br>
-gs/base/gsalloc.h<br>
-gs/base/gsalpha.c<br>
-gs/base/gsalpha.h<br>
-gs/base/gsalphac.c<br>
-gs/base/gsalphac.h<br>
-gs/base/gsargs.c<br>
-gs/base/gsargs.h<br>
-gs/base/gsbitcom.c<br>
-gs/base/gsbitmap.h<br>
-gs/base/gsbitops.c<br>
-gs/base/gsbitops.h<br>
-gs/base/gsbittab.c<br>
-gs/base/gsbittab.h<br>
-gs/base/gsccode.h<br>
-gs/base/gsccolor.h<br>
-gs/base/gscdef.c<br>
-gs/base/gscdefs.h<br>
-gs/base/gscdevn.c<br>
-gs/base/gscdevn.h<br>
-gs/base/gscedata.c<br>
-gs/base/gscedata.h<br>
-gs/base/gscencs.c<br>
-gs/base/gscencs.h<br>
-gs/base/gschar.c<br>
-gs/base/gschar.h<br>
-gs/base/gschar0.c<br>
-gs/base/gscicach.c<br>
-gs/base/gscicach.h<br>
-gs/base/gscie.c<br>
-gs/base/gscie.h<br>
-gs/base/gsciemap.c<br>
-gs/base/gscindex.h<br>
-gs/base/gsclipsr.c<br>
-gs/base/gsclipsr.h<br>
-gs/base/gscms.h<br>
-gs/base/gscolor.c<br>
-gs/base/gscolor.h<br>
-gs/base/gscolor1.c<br>
-gs/base/gscolor1.h<br>
-gs/base/gscolor2.c<br>
-gs/base/gscolor2.h<br>
-gs/base/gscolor3.c<br>
-gs/base/gscolor3.h<br>
-gs/base/gscolorbuffer.c<br>
-gs/base/gscolorbuffer.h<br>
-gs/base/gscompt.h<br>
-gs/base/gscoord.c<br>
-gs/base/gscoord.h<br>
-gs/base/gscparam.c<br>
-gs/base/gscpixel.c<br>
-gs/base/gscpixel.h<br>
-gs/base/gscpm.h<br>
-gs/base/gscrd.c<br>
-gs/base/gscrd.h<br>
-gs/base/gscrdp.c<br>
-gs/base/gscrdp.h<br>
-gs/base/gscrypt1.c<br>
-gs/base/gscrypt1.h<br>
-gs/base/gscscie.c<br>
-gs/base/gscsel.h<br>
-gs/base/gscsepr.c<br>
-gs/base/gscsepr.h<br>
-gs/base/gscspace.c<br>
-gs/base/gscspace.h<br>
-gs/base/gscssub.c<br>
-gs/base/gscssub.h<br>
-gs/base/gsdcolor.h<br>
-gs/base/gsdevice.c<br>
-gs/base/gsdevice.h<br>
-gs/base/gsdevmem.c<br>
-gs/base/gsdfilt.c<br>
-gs/base/gsdfilt.h<br>
-gs/base/gsdll.h<br>
-gs/base/gsdllwin.h<br>
-gs/base/gsdparam.c<br>
-gs/base/gsdpnext.h<br>
-gs/base/gsdps.c<br>
-gs/base/gsdps.h<br>
-gs/base/gsdps1.c<br>
-gs/base/gsdsrc.c<br>
-gs/base/gsdsrc.h<br>
-gs/base/gsequivc.c<br>
-gs/base/gsequivc.h<br>
-gs/base/gserrors.h<br>
-gs/base/gsexit.h<br>
-gs/base/gsfcid.c<br>
-gs/base/gsfcid2.c<br>
-gs/base/gsfcmap.c<br>
-gs/base/gsfcmap.h<br>
-gs/base/gsfcmap1.c<br>
-gs/base/gsflip.c<br>
-gs/base/gsflip.h<br>
-gs/base/gsfname.c<br>
-gs/base/gsfname.h<br>
-gs/base/gsfont.c<br>
-gs/base/gsfont.h<br>
-gs/base/gsfont0.c<br>
-gs/base/gsfont0c.c<br>
-gs/base/gsfunc.c<br>
-gs/base/gsfunc.h<br>
-gs/base/gsfunc0.c<br>
-gs/base/gsfunc0.h<br>
-gs/base/gsfunc3.c<br>
-gs/base/gsfunc3.h<br>
-gs/base/gsfunc4.c<br>
-gs/base/gsfunc4.h<br>
-gs/base/gsgc.h<br>
-gs/base/gsgcache.c<br>
-gs/base/gsgcache.h<br>
-gs/base/gsgdata.c<br>
-gs/base/gsgdata.h<br>
-gs/base/gshsb.c<br>
-gs/base/gshsb.h<br>
-gs/base/gsht.c<br>
-gs/base/gsht.h<br>
-gs/base/gsht1.c<br>
-gs/base/gsht1.h<br>
-gs/base/gshtscr.c<br>
-gs/base/gshtx.c<br>
-gs/base/gshtx.h<br>
-gs/base/gsicc.c<br>
-gs/base/gsicc.h<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_cache.h<br>
-gs/base/gsicc_cms.h<br>
-gs/base/gsicc_create.c<br>
-gs/base/gsicc_create.h<br>
-gs/base/gsicc_lcms.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_manage.h<br>
-gs/base/gsicc_nocm.c<br>
-gs/base/gsicc_profilecache.c<br>
-gs/base/gsicc_profilecache.h<br>
-gs/base/gsimage.c<br>
-gs/base/gsimage.h<br>
-gs/base/gsimpath.c<br>
-gs/base/gsinit.c<br>
-gs/base/gsio.h<br>
-gs/base/gsiodev.c<br>
-gs/base/gsiodevs.c<br>
-gs/base/gsiodisk.c<br>
-gs/base/gsiomacres.c<br>
-gs/base/gsiorom.c<br>
-gs/base/gsiorom.h<br>
-gs/base/gsipar3x.h<br>
-gs/base/gsiparam.h<br>
-gs/base/gsiparm2.h<br>
-gs/base/gsiparm3.h<br>
-gs/base/gsiparm4.h<br>
-gs/base/gsistate.c<br>
-gs/base/gsjconf.h<br>
-gs/base/gsjmorec.h<br>
-gs/base/gslib.c<br>
-gs/base/gslib.h<br>
-gs/base/gslibctx.c<br>
-gs/base/gslibctx.h<br>
-gs/base/gsline.c<br>
-gs/base/gsline.h<br>
-gs/base/gslparam.h<br>
-gs/base/gsmalloc.c<br>
-gs/base/gsmalloc.h<br>
-gs/base/gsmatrix.c<br>
-gs/base/gsmatrix.h<br>
-gs/base/gsmchunk.c<br>
-gs/base/gsmchunk.h<br>
-gs/base/gsmdebug.h<br>
-gs/base/gsmemlok.c<br>
-gs/base/gsmemlok.h<br>
-gs/base/gsmemory.c<br>
-gs/base/gsmemory.h<br>
-gs/base/gsmemraw.h<br>
-gs/base/gsmemret.c<br>
-gs/base/gsmemret.h<br>
-gs/base/gsmisc.c<br>
-gs/base/gsnamecl.c<br>
-gs/base/gsnamecl.h<br>
-gs/base/gsncdummy.c<br>
-gs/base/gsncdummy.h<br>
-gs/base/gsnogc.c<br>
-gs/base/gsnogc.h<br>
-gs/base/gsnotify.c<br>
-gs/base/gsnotify.h<br>
-gs/base/gsovrc.c<br>
-gs/base/gsovrc.h<br>
-gs/base/gspaint.c<br>
-gs/base/gspaint.h<br>
-gs/base/gsparam.c<br>
-gs/base/gsparam.h<br>
-gs/base/gsparam2.c<br>
-gs/base/gsparams.c<br>
-gs/base/gsparams.h<br>
-gs/base/gsparamx.c<br>
-gs/base/gsparamx.h<br>
-gs/base/gspath.c<br>
-gs/base/gspath.h<br>
-gs/base/gspath1.c<br>
-gs/base/gspath2.h<br>
-gs/base/gspcolor.c<br>
-gs/base/gspcolor.h<br>
-gs/base/gspenum.h<br>
-gs/base/gspmdrv.c<br>
-gs/base/gspmdrv.h<br>
-gs/base/gspmdrv.rc<br>
-gs/base/gsptype1.c<br>
-gs/base/gsptype1.h<br>
-gs/base/gsptype2.c<br>
-gs/base/gsptype2.h<br>
-gs/base/gsrect.h<br>
-gs/base/gsrefct.h<br>
-gs/base/gsromfs0.c<br>
-gs/base/gsrop.c<br>
-gs/base/gsrop.h<br>
-gs/base/gsroprun.c<br>
-gs/base/gsroprun1.h<br>
-gs/base/gsroprun24.h<br>
-gs/base/gsroprun8.h<br>
-gs/base/gsropt.h<br>
-gs/base/gsroptab.c<br>
-gs/base/gsserial.c<br>
-gs/base/gsserial.h<br>
-gs/base/gsshade.c<br>
-gs/base/gsshade.h<br>
-gs/base/gsstate.c<br>
-gs/base/gsstate.h<br>
-gs/base/gsstruct.h<br>
-gs/base/gsstype.h<br>
-gs/base/gstext.c<br>
-gs/base/gstext.h<br>
-gs/base/gstparam.h<br>
-gs/base/gstrans.c<br>
-gs/base/gstrans.h<br>
-gs/base/gstrap.c<br>
-gs/base/gstrap.h<br>
-gs/base/gstype1.c<br>
-gs/base/gstype1.h<br>
-gs/base/gstype2.c<br>
-gs/base/gstype42.c<br>
-gs/base/gstypes.h<br>
-gs/base/gsuid.h<br>
-gs/base/gsutil.c<br>
-gs/base/gsutil.h<br>
-gs/base/gswin.rc<br>
-gs/base/gsxfont.h<br>
-gs/base/gx.h<br>
-gs/base/gxacpath.c<br>
-gs/base/gxalloc.h<br>
-gs/base/gxalpha.h<br>
-gs/base/gxarith.h<br>
-gs/base/gxband.h<br>
-gs/base/gxbcache.c<br>
-gs/base/gxbcache.h<br>
-gs/base/gxbitfmt.h<br>
-gs/base/gxbitmap.h<br>
-gs/base/gxbitops.h<br>
-gs/base/gxblend.c<br>
-gs/base/gxblend.h<br>
-gs/base/gxblend1.c<br>
-gs/base/gxccache.c<br>
-gs/base/gxccman.c<br>
-gs/base/gxcdevn.h<br>
-gs/base/gxchar.c<br>
-gs/base/gxchar.h<br>
-gs/base/gxchrout.c<br>
-gs/base/gxchrout.h<br>
-gs/base/gxcht.c<br>
-gs/base/gxcid.h<br>
-gs/base/gxcie.h<br>
-gs/base/gxcindex.h<br>
-gs/base/gxclbits.c<br>
-gs/base/gxcldev.h<br>
-gs/base/gxclfile.c<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclio.h<br>
-gs/base/gxclip.c<br>
-gs/base/gxclip.h<br>
-gs/base/gxclip2.c<br>
-gs/base/gxclip2.h<br>
-gs/base/gxclipm.c<br>
-gs/base/gxclipm.h<br>
-gs/base/gxclipsr.h<br>
-gs/base/gxclist.c<br>
-gs/base/gxclist.h<br>
-gs/base/gxcllzw.c<br>
-gs/base/gxclmem.c<br>
-gs/base/gxclmem.h<br>
-gs/base/gxclpage.c<br>
-gs/base/gxclpage.h<br>
-gs/base/gxclpath.c<br>
-gs/base/gxclpath.h<br>
-gs/base/gxclrast.c<br>
-gs/base/gxclread.c<br>
-gs/base/gxclrect.c<br>
-gs/base/gxclthrd.c<br>
-gs/base/gxclthrd.h<br>
-gs/base/gxclutil.c<br>
-gs/base/gxclzlib.c<br>
-gs/base/gxcmap.c<br>
-gs/base/gxcmap.h<br>
-gs/base/gxcolor2.h<br>
-gs/base/gxcomp.h<br>
-gs/base/gxcoord.h<br>
-gs/base/gxcpath.c<br>
-gs/base/gxcpath.h<br>
-gs/base/gxcspace.h<br>
-gs/base/gxctable.c<br>
-gs/base/gxctable.h<br>
-gs/base/gxcvalue.h<br>
-gs/base/gxdcconv.c<br>
-gs/base/gxdcconv.h<br>
-gs/base/gxdcolor.c<br>
-gs/base/gxdcolor.h<br>
-gs/base/gxdda.h<br>
-gs/base/gxdevbuf.h<br>
-gs/base/gxdevcli.h<br>
-gs/base/gxdevice.h<br>
-gs/base/gxdevmem.h<br>
-gs/base/gxdevndi.c<br>
-gs/base/gxdevndi.h<br>
-gs/base/gxdevrop.h<br>
-gs/base/gxdevsop.h<br>
-gs/base/gxdht.h<br>
-gs/base/gxdhtres.h<br>
-gs/base/gxdhtserial.c<br>
-gs/base/gxdhtserial.h<br>
-gs/base/gxdither.h<br>
-gs/base/gxdownscale.c<br>
-gs/base/gxdownscale.h<br>
-gs/base/gxdtfill.h<br>
-gs/base/gxfapiu.c<br>
-gs/base/gxfapiu.h<br>
-gs/base/gxfarith.h<br>
-gs/base/gxfcache.h<br>
-gs/base/gxfcid.h<br>
-gs/base/gxfcmap.h<br>
-gs/base/gxfcmap1.h<br>
-gs/base/gxfcopy.c<br>
-gs/base/gxfcopy.h<br>
-gs/base/gxfdrop.c<br>
-gs/base/gxfdrop.h<br>
-gs/base/gxfill.c<br>
-gs/base/gxfill.h<br>
-gs/base/gxfillsl.h<br>
-gs/base/gxfilltr.h<br>
-gs/base/gxfillts.h<br>
-gs/base/gxfixed.h<br>
-gs/base/gxfmap.h<br>
-gs/base/gxfont.h<br>
-gs/base/gxfont0.h<br>
-gs/base/gxfont0c.h<br>
-gs/base/gxfont1.h<br>
-gs/base/gxfont42.h<br>
-gs/base/gxfrac.h<br>
-gs/base/gxftype.h<br>
-gs/base/gxfunc.h<br>
-gs/base/gxgetbit.h<br>
-gs/base/gxhintn.c<br>
-gs/base/gxhintn.h<br>
-gs/base/gxhintn1.c<br>
-gs/base/gxhldevc.c<br>
-gs/base/gxhldevc.h<br>
-gs/base/gxht.c<br>
-gs/base/gxht.h<br>
-gs/base/gxht_thresh.c<br>
-gs/base/gxht_thresh.h<br>
-gs/base/gxhtbit.c<br>
-gs/base/gxhttile.h<br>
-gs/base/gxhttype.h<br>
-gs/base/gxi12bit.c<br>
-gs/base/gxi16bit.c<br>
-gs/base/gxiclass.h<br>
-gs/base/gxicolor.c<br>
-gs/base/gxidata.c<br>
-gs/base/gxifast.c<br>
-gs/base/gximag3x.c<br>
-gs/base/gximag3x.h<br>
-gs/base/gximage.c<br>
-gs/base/gximage.h<br>
-gs/base/gximage1.c<br>
-gs/base/gximage2.c<br>
-gs/base/gximage3.c<br>
-gs/base/gximage3.h<br>
-gs/base/gximage4.c<br>
-gs/base/gximask.c<br>
-gs/base/gximask.h<br>
-gs/base/gximono.c<br>
-gs/base/gxino12b.c<br>
-gs/base/gxino16b.c<br>
-gs/base/gxiodev.h<br>
-gs/base/gxiparam.h<br>
-gs/base/gxipixel.c<br>
-gs/base/gxiscale.c<br>
-gs/base/gxistate.h<br>
-gs/base/gxline.h<br>
-gs/base/gxlum.h<br>
-gs/base/gxmatrix.h<br>
-gs/base/gxmclip.c<br>
-gs/base/gxmclip.h<br>
-gs/base/gxobj.h<br>
-gs/base/gxoprect.c<br>
-gs/base/gxoprect.h<br>
-gs/base/gxp1fill.c<br>
-gs/base/gxp1impl.h<br>
-gs/base/gxpageq.c<br>
-gs/base/gxpageq.h<br>
-gs/base/gxpaint.c<br>
-gs/base/gxpaint.h<br>
-gs/base/gxpath.c<br>
-gs/base/gxpath.h<br>
-gs/base/gxpath2.c<br>
-gs/base/gxpcache.h<br>
-gs/base/gxpcmap.c<br>
-gs/base/gxpcolor.h<br>
-gs/base/gxpcopy.c<br>
-gs/base/gxpdash.c<br>
-gs/base/gxpflat.c<br>
-gs/base/gxrplane.h<br>
-gs/base/gxsample.c<br>
-gs/base/gxsample.h<br>
-gs/base/gxsamplp.h<br>
-gs/base/gxshade.c<br>
-gs/base/gxshade.h<br>
-gs/base/gxshade1.c<br>
-gs/base/gxshade4.c<br>
-gs/base/gxshade4.h<br>
-gs/base/gxshade6.c<br>
-gs/base/gxstate.h<br>
-gs/base/gxstdio.h<br>
-gs/base/gxstroke.c<br>
-gs/base/gxsync.c<br>
-gs/base/gxsync.h<br>
-gs/base/gxtext.h<br>
-gs/base/gxtmap.h<br>
-gs/base/gxttf.h<br>
-gs/base/gxttfb.c<br>
-gs/base/gxttfb.h<br>
-gs/base/gxtype1.c<br>
-gs/base/gxtype1.h<br>
-gs/base/gxxfont.h<br>
-gs/base/gzacpath.h<br>
-gs/base/gzcpath.h<br>
-gs/base/gzht.h<br>
-gs/base/gzline.h<br>
-gs/base/gzpath.h<br>
-gs/base/gzspotan.c<br>
-gs/base/gzspotan.h<br>
-gs/base/gzstate.h<br>
-gs/base/icclib.mak<br>
-gs/base/ijs.mak<br>
-gs/base/instcopy<br>
-gs/base/jasper.mak<br>
-gs/base/jbig2.mak<br>
-gs/base/jerror_.h<br>
-gs/base/jpeg.mak<br>
-gs/base/jpegxr.mak<br>
-gs/base/lcms.mak<br>
-gs/base/lcms2.mak<br>
-gs/base/lcups.mak<br>
-gs/base/lcupsi.mak<br>
-gs/base/ldf_jb2.mak<br>
-gs/base/lib.mak<br>
-gs/base/locale_.h<br>
-gs/base/lwf_jp2.mak<br>
-gs/base/macgenmcpxml.sh<br>
-gs/base/macos-fw.mak<br>
-gs/base/macos-mcp.mak<br>
-gs/base/macos_carbon_d_pre.h<br>
-gs/base/macos_carbon_pre.h<br>
-gs/base/macos_classic_d_pre.h<br>
-gs/base/macosx.mak<br>
-gs/base/macsystypes.h<br>
-gs/base/malloc_.h<br>
-gs/base/math_.h<br>
-gs/base/md5.c<br>
-gs/base/md5.h<br>
-gs/base/md5main.c<br>
-gs/base/memento.c<br>
-gs/base/memento.h<br>
-gs/base/memory_.h<br>
-gs/base/minftrsz.c<br>
-gs/base/minftrsz.h<br>
-gs/base/mkromfs.c<br>
-gs/base/msvccmd.mak<br>
-gs/base/msvclib.mak<br>
-gs/base/msvctail.mak<br>
-gs/base/mv.bat<br>
-gs/base/mv.cmd<br>
-gs/base/opdfread.h<br>
-gs/base/openjpeg.mak<br>
-gs/base/openvms.mak<br>
-gs/base/openvms.mmk<br>
-gs/base/pcwin.mak<br>
-gs/base/pipe_.h<br>
-gs/base/png.mak<br>
-gs/base/png_.h<br>
-gs/base/rinkj/evenbetter-rll.c<br>
-gs/base/rinkj/evenbetter-rll.h<br>
-gs/base/rinkj/rinkj-byte-stream.c<br>
-gs/base/rinkj/rinkj-byte-stream.h<br>
-gs/base/rinkj/rinkj-config.c<br>
-gs/base/rinkj/rinkj-config.h<br>
-gs/base/rinkj/rinkj-device.c<br>
-gs/base/rinkj/rinkj-device.h<br>
-gs/base/rinkj/rinkj-dither.c<br>
-gs/base/rinkj/rinkj-dither.h<br>
-gs/base/rinkj/rinkj-epson870.c<br>
-gs/base/rinkj/rinkj-epson870.h<br>
-gs/base/rinkj/rinkj-screen-eb.c<br>
-gs/base/rinkj/rinkj-screen-eb.h<br>
-gs/base/rm.bat<br>
-gs/base/rm.cmd<br>
-gs/base/sa85d.c<br>
-gs/base/sa85d.h<br>
-gs/base/sa85x.h<br>
-gs/base/saes.c<br>
-gs/base/saes.h<br>
-gs/base/sarc4.c<br>
-gs/base/sarc4.h<br>
-gs/base/sbcp.c<br>
-gs/base/sbcp.h<br>
-gs/base/sbhc.c<br>
-gs/base/sbhc.h<br>
-gs/base/sbtx.h<br>
-gs/base/sbwbs.c<br>
-gs/base/sbwbs.h<br>
-gs/base/scanchar.h<br>
-gs/base/scantab.c<br>
-gs/base/scf.h<br>
-gs/base/scfd.c<br>
-gs/base/scfdgen.c<br>
-gs/base/scfdtab.c<br>
-gs/base/scfe.c<br>
-gs/base/scfetab.c<br>
-gs/base/scfparam.c<br>
-gs/base/scfx.h<br>
-gs/base/scommon.h<br>
-gs/base/sdcparam.c<br>
-gs/base/sdcparam.h<br>
-gs/base/sdct.h<br>
-gs/base/sdctc.c<br>
-gs/base/sdctd.c<br>
-gs/base/sdcte.c<br>
-gs/base/sddparam.c<br>
-gs/base/sdeparam.c<br>
-gs/base/seexec.c<br>
-gs/base/setjmp_.h<br>
-gs/base/sfilter.h<br>
-gs/base/sfilter2.c<br>
-gs/base/sfxboth.c<br>
-gs/base/sfxcommon.c<br>
-gs/base/sfxfd.c<br>
-gs/base/sfxstdio.c<br>
-gs/base/shc.c<br>
-gs/base/shc.h<br>
-gs/base/shcgen.c<br>
-gs/base/shcgen.h<br>
-gs/base/sidscale.c<br>
-gs/base/sidscale.h<br>
-gs/base/siinterp.c<br>
-gs/base/siinterp.h<br>
-gs/base/simscale.c<br>
-gs/base/simscale.h<br>
-gs/base/siscale.c<br>
-gs/base/siscale.h<br>
-gs/base/sisparam.h<br>
-gs/base/sjbig2.c<br>
-gs/base/sjbig2.h<br>
-gs/base/sjbig2_luratech.c<br>
-gs/base/sjbig2_luratech.h<br>
-gs/base/sjpeg.h<br>
-gs/base/sjpegc.c<br>
-gs/base/sjpegd.c<br>
-gs/base/sjpege.c<br>
-gs/base/sjpx.c<br>
-gs/base/sjpx.h<br>
-gs/base/sjpx_luratech.c<br>
-gs/base/sjpx_luratech.h<br>
-gs/base/sjpx_openjpeg.c<br>
-gs/base/sjpx_openjpeg.h<br>
-gs/base/slzwc.c<br>
-gs/base/slzwd.c<br>
-gs/base/slzwe.c<br>
-gs/base/slzwx.h<br>
-gs/base/smd5.c<br>
-gs/base/smd5.h<br>
-gs/base/smtf.c<br>
-gs/base/smtf.h<br>
-gs/base/spdiff.c<br>
-gs/base/spdiffx.h<br>
-gs/base/spngp.c<br>
-gs/base/spngpx.h<br>
-gs/base/spprint.c<br>
-gs/base/spprint.h<br>
-gs/base/spsdf.c<br>
-gs/base/spsdf.h<br>
-gs/base/srdline.h<br>
-gs/base/srld.c<br>
-gs/base/srle.c<br>
-gs/base/srlx.h<br>
-gs/base/ssha2.c<br>
-gs/base/ssha2.h<br>
-gs/base/sstring.c<br>
-gs/base/sstring.h<br>
-gs/base/stat_.h<br>
-gs/base/std.h<br>
-gs/base/stdint_.h<br>
-gs/base/stdio_.h<br>
-gs/base/stdpn.h<br>
-gs/base/stdpre.h<br>
-gs/base/stream.c<br>
-gs/base/stream.h<br>
-gs/base/strimpl.h<br>
-gs/base/string_.h<br>
-gs/base/strmio.c<br>
-gs/base/strmio.h<br>
-gs/base/szlibc.c<br>
-gs/base/szlibd.c<br>
-gs/base/szlibe.c<br>
-gs/base/szlibx.h<br>
-gs/base/szlibxx.h<br>
-gs/base/tiff.mak<br>
-gs/base/time_.h<br>
-gs/base/ttcalc.c<br>
-gs/base/ttcalc.h<br>
-gs/base/ttcommon.h<br>
-gs/base/ttconf.h<br>
-gs/base/ttconfig.h<br>
-gs/base/ttfinp.c<br>
-gs/base/ttfinp.h<br>
-gs/base/ttfmain.c<br>
-gs/base/ttfmemd.c<br>
-gs/base/ttfmemd.h<br>
-gs/base/ttfoutl.h<br>
-gs/base/ttfsfnt.h<br>
-gs/base/ttinterp.c<br>
-gs/base/ttinterp.h<br>
-gs/base/ttload.c<br>
-gs/base/ttload.h<br>
-gs/base/ttmisc.h<br>
-gs/base/ttobjs.c<br>
-gs/base/ttobjs.h<br>
-gs/base/tttables.h<br>
-gs/base/tttype.h<br>
-gs/base/tttypes.h<br>
-gs/base/ugcclib.mak<br>
-gs/base/unistd_.h<br>
-gs/base/unix-aux.mak<br>
-gs/base/unix-dll.mak<br>
-gs/base/unix-end.mak<br>
-gs/base/unix-gcc.mak<br>
-gs/base/unixansi.mak<br>
-gs/base/unixhead.mak<br>
-gs/base/unixinst.mak<br>
-gs/base/unixlink.mak<br>
-gs/base/valgrind.h<br>
-gs/base/vdtrace.c<br>
-gs/base/vdtrace.h<br>
-gs/base/version.mak<br>
-gs/base/vms_x_fix.h<br>
-gs/base/vmsmath.h<br>
-gs/base/whitelst.c<br>
-gs/base/whitelst.h<br>
-gs/base/windows_.h<br>
-gs/base/winlib.mak<br>
-gs/base/winplat.mak<br>
-gs/base/x_.h<br>
-gs/base/zlib.mak<br>
-gs/cups/colord.c<br>
-gs/cups/colord.h<br>
-gs/cups/cups.mak<br>
-gs/cups/gdevcups.c<br>
-gs/cups/gstopxl.in<br>
-gs/cups/gstoraster.c<br>
-gs/cups/pxlcolor.ppd<br>
-gs/cups/pxlmono.ppd<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Changes.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/Hershey.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/gs.css<br>
-gs/doc/index.html<br>
-gs/doc/pscet_status.txt<br>
-gs/doc/thirdparty.htm<br>
-gs/examples/waterfal.ps<br>
-gs/freetype/src/gzip/adler32.c<br>
-gs/freetype/src/gzip/zconf.h<br>
-gs/freetype/src/gzip/zutil.c<br>
-gs/freetype/src/gzip/zutil.h<br>
-gs/ijs/Makefile.am<br>
-gs/ijs/configure.ac<br>
-gs/jasper/src/libjasper/base/jas_cm.c<br>
-gs/jasper/src/libjasper/base/jas_getopt.c<br>
-gs/jasper/src/libjasper/base/jas_image.c<br>
-gs/jasper/src/libjasper/base/jas_malloc.c<br>
-gs/jasper/src/libjasper/base/jas_seq.c<br>
-gs/jasper/src/libjasper/base/jas_stream.c<br>
-gs/jasper/src/libjasper/base/jas_string.c<br>
-gs/jasper/src/libjasper/base/jas_tvp.c<br>
-gs/jasper/src/libjasper/bmp/bmp_cod.c<br>
-gs/jasper/src/libjasper/bmp/bmp_cod.h<br>
-gs/jasper/src/libjasper/bmp/bmp_dec.c<br>
-gs/jasper/src/libjasper/bmp/bmp_enc.c<br>
-gs/jasper/src/libjasper/include/jasper/jas_cm.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_debug.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_fix.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_getopt.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_image.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_malloc.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_math.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_seq.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_stream.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_string.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_tvp.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_types.h<br>
-gs/jasper/src/libjasper/include/jasper/jas_version.h<br>
-gs/jasper/src/libjasper/jp2/jp2_cod.c<br>
-gs/jasper/src/libjasper/jp2/jp2_cod.h<br>
-gs/jasper/src/libjasper/jp2/jp2_enc.c<br>
-gs/jasper/src/libjasper/jpc/jpc_bs.c<br>
-gs/jasper/src/libjasper/jpc/jpc_bs.h<br>
-gs/jasper/src/libjasper/jpc/jpc_cod.h<br>
-gs/jasper/src/libjasper/jpc/jpc_cs.c<br>
-gs/jasper/src/libjasper/jpc/jpc_cs.h<br>
-gs/jasper/src/libjasper/jpc/jpc_dec.c<br>
-gs/jasper/src/libjasper/jpc/jpc_dec.h<br>
-gs/jasper/src/libjasper/jpc/jpc_enc.c<br>
-gs/jasper/src/libjasper/jpc/jpc_enc.h<br>
-gs/jasper/src/libjasper/jpc/jpc_fix.h<br>
-gs/jasper/src/libjasper/jpc/jpc_flt.h<br>
-gs/jasper/src/libjasper/jpc/jpc_math.c<br>
-gs/jasper/src/libjasper/jpc/jpc_mct.c<br>
-gs/jasper/src/libjasper/jpc/jpc_mct.h<br>
-gs/jasper/src/libjasper/jpc/jpc_mqcod.c<br>
-gs/jasper/src/libjasper/jpc/jpc_mqcod.h<br>
-gs/jasper/src/libjasper/jpc/jpc_mqdec.c<br>
-gs/jasper/src/libjasper/jpc/jpc_mqdec.h<br>
-gs/jasper/src/libjasper/jpc/jpc_mqenc.c<br>
-gs/jasper/src/libjasper/jpc/jpc_mqenc.h<br>
-gs/jasper/src/libjasper/jpc/jpc_qmfb.c<br>
-gs/jasper/src/libjasper/jpc/jpc_qmfb.h<br>
-gs/jasper/src/libjasper/jpc/jpc_t1cod.c<br>
-gs/jasper/src/libjasper/jpc/jpc_t1cod.h<br>
-gs/jasper/src/libjasper/jpc/jpc_t1dec.c<br>
-gs/jasper/src/libjasper/jpc/jpc_t1dec.h<br>
-gs/jasper/src/libjasper/jpc/jpc_t1enc.c<br>
-gs/jasper/src/libjasper/jpc/jpc_t1enc.h<br>
-gs/jasper/src/libjasper/jpc/jpc_t2cod.c<br>
-gs/jasper/src/libjasper/jpc/jpc_t2cod.h<br>
-gs/jasper/src/libjasper/jpc/jpc_t2dec.c<br>
-gs/jasper/src/libjasper/jpc/jpc_t2dec.h<br>
-gs/jasper/src/libjasper/jpc/jpc_t2enc.c<br>
-gs/jasper/src/libjasper/jpc/jpc_t2enc.h<br>
-gs/jasper/src/libjasper/jpc/jpc_tagtree.c<br>
-gs/jasper/src/libjasper/jpc/jpc_tagtree.h<br>
-gs/jasper/src/libjasper/jpc/jpc_tsfb.c<br>
-gs/jasper/src/libjasper/jpc/jpc_tsfb.h<br>
-gs/jasper/src/libjasper/jpc/jpc_util.c<br>
-gs/jasper/src/libjasper/jpg/jpg_cod.h<br>
-gs/jasper/src/libjasper/pgx/pgx_cod.h<br>
-gs/jasper/src/libjasper/pnm/pnm_cod.c<br>
-gs/jasper/src/libjasper/pnm/pnm_cod.h<br>
-gs/jasper/src/libjasper/pnm/pnm_dec.c<br>
-gs/jasper/src/libjasper/pnm/pnm_enc.c<br>
-gs/jasper/src/libjasper/ras/ras_cod.c<br>
-gs/jasper/src/libjasper/ras/ras_cod.h<br>
-gs/jasper/src/libjasper/ras/ras_dec.c<br>
-gs/jasper/src/libjasper/ras/ras_enc.c<br>
-gs/jbig2dec/config_types.h<br>
-gs/jbig2dec/config_types.h.in<br>
-gs/jbig2dec/config_win32.h<br>
-gs/jbig2dec/getopt.c<br>
-gs/jbig2dec/getopt.h<br>
-gs/jbig2dec/getopt1.c<br>
-gs/jbig2dec/jbig2.c<br>
-gs/jbig2dec/jbig2.h<br>
-gs/jbig2dec/jbig2_arith.c<br>
-gs/jbig2dec/jbig2_arith.h<br>
-gs/jbig2dec/jbig2_arith_iaid.c<br>
-gs/jbig2dec/jbig2_arith_iaid.h<br>
-gs/jbig2dec/jbig2_arith_int.c<br>
-gs/jbig2dec/jbig2_arith_int.h<br>
-gs/jbig2dec/jbig2_generic.c<br>
-gs/jbig2dec/jbig2_generic.h<br>
-gs/jbig2dec/jbig2_halftone.c<br>
-gs/jbig2dec/jbig2_halftone.h<br>
-gs/jbig2dec/jbig2_huffman.c<br>
-gs/jbig2dec/jbig2_huffman.h<br>
-gs/jbig2dec/jbig2_hufftab.h<br>
-gs/jbig2dec/jbig2_image.c<br>
-gs/jbig2dec/jbig2_image.h<br>
-gs/jbig2dec/jbig2_image_pbm.c<br>
-gs/jbig2dec/jbig2_image_png.c<br>
-gs/jbig2dec/jbig2_metadata.c<br>
-gs/jbig2dec/jbig2_metadata.h<br>
-gs/jbig2dec/jbig2_mmr.c<br>
-gs/jbig2dec/jbig2_mmr.h<br>
-gs/jbig2dec/jbig2_page.c<br>
-gs/jbig2dec/jbig2_priv.h<br>
-gs/jbig2dec/jbig2_refinement.c<br>
-gs/jbig2dec/jbig2_segment.c<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-gs/jbig2dec/jbig2_symbol_dict.h<br>
-gs/jbig2dec/jbig2_text.c<br>
-gs/jbig2dec/jbig2_text.h<br>
-gs/jbig2dec/jbig2dec.c<br>
-gs/jbig2dec/memcmp.c<br>
-gs/jbig2dec/memento.c<br>
-gs/jbig2dec/memento.h<br>
-gs/jbig2dec/os_types.h<br>
-gs/jbig2dec/pbm2png.c<br>
-gs/jbig2dec/snprintf.c<br>
-gs/lib/FAPIconfig-FCO<br>
-gs/lib/FCOfontmap-PCLPS3<br>
-gs/lib/FCOfontmap-PS3<br>
-gs/lib/Fontmap.ATB<br>
-gs/lib/Fontmap.ATM<br>
-gs/lib/Fontmap.OS2<br>
-gs/lib/Fontmap.SGI<br>
-gs/lib/Fontmap.Sol<br>
-gs/lib/Fontmap.URW-136.T1<br>
-gs/lib/Fontmap.URW-136.TT<br>
-gs/lib/Fontmap.Ult<br>
-gs/lib/Fontmap.VMS<br>
-gs/lib/PDFA_def.ps<br>
-gs/lib/PDFX_def.ps<br>
-gs/lib/acctest.ps<br>
-gs/lib/addxchar.ps<br>
-gs/lib/align.ps<br>
-gs/lib/caption.ps<br>
-gs/lib/cat.ps<br>
-gs/lib/cid2code.ps<br>
-gs/lib/decrypt.ps<br>
-gs/lib/docie.ps<br>
-gs/lib/dumphint<br>
-gs/lib/dumphint.bat<br>
-gs/lib/dumphint.ps<br>
-gs/lib/dvipdf<br>
-gs/lib/eps2eps<br>
-gs/lib/eps2eps.bat<br>
-gs/lib/eps2eps.cmd<br>
-gs/lib/font2c<br>
-gs/lib/font2c.bat<br>
-gs/lib/font2c.cmd<br>
-gs/lib/font2c.ps<br>
-gs/lib/font2pcl.ps<br>
-gs/lib/gs_ce_e.ps<br>
-gs/lib/gs_cmdl.ps<br>
-gs/lib/gs_fform.ps<br>
-gs/lib/gs_il2_e.ps<br>
-gs/lib/gs_kanji.ps<br>
-gs/lib/gs_ksb_e.ps<br>
-gs/lib/gs_lgo_e.ps<br>
-gs/lib/gs_lgx_e.ps<br>
-gs/lib/gs_pfile.ps<br>
-gs/lib/gs_rdlin.ps<br>
-gs/lib/gs_wl1_e.ps<br>
-gs/lib/gs_wl2_e.ps<br>
-gs/lib/gs_wl5_e.ps<br>
-gs/lib/gsbj<br>
-gs/lib/gsbj.bat<br>
-gs/lib/gsdj<br>
-gs/lib/gsdj.bat<br>
-gs/lib/gsdj500<br>
-gs/lib/gsdj500.bat<br>
-gs/lib/gslj<br>
-gs/lib/gslj.bat<br>
-gs/lib/gslp<br>
-gs/lib/gslp.bat<br>
-gs/lib/gslp.ps<br>
-gs/lib/gsnd<br>
-gs/lib/gsnd.bat<br>
-gs/lib/gsndt.bat<br>
-gs/lib/gsnup.ps<br>
-gs/lib/gssetgs.bat<br>
-gs/lib/gssetgs32.bat<br>
-gs/lib/gssetgs64.bat<br>
-gs/lib/gst.bat<br>
-gs/lib/gstt.bat<br>
-gs/lib/ht_ccsto.ps<br>
-gs/lib/image-qa.ps<br>
-gs/lib/impath.ps<br>
-gs/lib/jispaper.ps<br>
-gs/lib/jobseparator.ps<br>
-gs/lib/landscap.ps<br>
-gs/lib/level1.ps<br>
-gs/lib/lines.ps<br>
-gs/lib/lp386.bat<br>
-gs/lib/lp386r2.bat<br>
-gs/lib/lpgs.bat<br>
-gs/lib/lpr2.bat<br>
-gs/lib/lprsetup.sh<br>
-gs/lib/markhint.ps<br>
-gs/lib/markpath.ps<br>
-gs/lib/mkcidfm.ps<br>
-gs/lib/opdfread.ps<br>
-gs/lib/packfile.ps<br>
-gs/lib/pcharstr.ps<br>
-gs/lib/pdf2dsc<br>
-gs/lib/pdf2dsc.bat<br>
-gs/lib/pdf2dsc.ps<br>
-gs/lib/pdf2ps<br>
-gs/lib/pdf2ps.bat<br>
-gs/lib/pdf2ps.cmd<br>
-gs/lib/pdfopt<br>
-gs/lib/pdfopt.bat<br>
-gs/lib/pdfopt.ps<br>
-gs/lib/pdfwrite.ps<br>
-gs/lib/pf2afm<br>
-gs/lib/pf2afm.bat<br>
-gs/lib/pf2afm.cmd<br>
-gs/lib/pf2afm.ps<br>
-gs/lib/pfbtopfa<br>
-gs/lib/pfbtopfa.bat<br>
-gs/lib/pfbtopfa.ps<br>
-gs/lib/pftogsf.bat<br>
-gs/lib/ppath.ps<br>
-gs/lib/pphs<br>
-gs/lib/pphs.ps<br>
-gs/lib/prfont.ps<br>
-gs/lib/printafm<br>
-gs/lib/printafm.ps<br>
-gs/lib/ps2ai.ps<br>
-gs/lib/ps2ascii<br>
-gs/lib/ps2ascii.bat<br>
-gs/lib/ps2ascii.cmd<br>
-gs/lib/ps2ascii.ps<br>
-gs/lib/ps2epsi<br>
-gs/lib/ps2epsi.bat<br>
-gs/lib/ps2epsi.cmd<br>
-gs/lib/ps2epsi.ps<br>
-gs/lib/ps2pdf<br>
-gs/lib/ps2pdf.bat<br>
-gs/lib/ps2pdf.cmd<br>
-gs/lib/ps2pdf12<br>
-gs/lib/ps2pdf12.bat<br>
-gs/lib/ps2pdf12.cmd<br>
-gs/lib/ps2pdf13<br>
-gs/lib/ps2pdf13.bat<br>
-gs/lib/ps2pdf13.cmd<br>
-gs/lib/ps2pdf14<br>
-gs/lib/ps2pdf14.bat<br>
-gs/lib/ps2pdf14.cmd<br>
-gs/lib/ps2pdfwr<br>
-gs/lib/ps2pdfxx.bat<br>
-gs/lib/ps2ps<br>
-gs/lib/ps2ps.bat<br>
-gs/lib/ps2ps.cmd<br>
-gs/lib/ps2ps2<br>
-gs/lib/ps2ps2.bat<br>
-gs/lib/ps2ps2.cmd<br>
-gs/lib/rollconv.ps<br>
-gs/lib/showchar.ps<br>
-gs/lib/stcinfo.ps<br>
-gs/lib/stcolor.ps<br>
-gs/lib/stocht.ps<br>
-gs/lib/traceimg.ps<br>
-gs/lib/traceop.ps<br>
-gs/lib/type1enc.ps<br>
-gs/lib/type1ops.ps<br>
-gs/lib/uninfo.ps<br>
-gs/lib/unix-lpr.sh<br>
-gs/lib/unprot.ps<br>
-gs/lib/viewcmyk.ps<br>
-gs/lib/viewgif.ps<br>
-gs/lib/viewjpeg.ps<br>
-gs/lib/viewmiff.ps<br>
-gs/lib/viewpbm.ps<br>
-gs/lib/viewpcx.ps<br>
-gs/lib/viewps2a.ps<br>
-gs/lib/viewrgb.ps<br>
-gs/lib/wftopfa<br>
-gs/lib/wftopfa.ps<br>
-gs/lib/winmaps.ps<br>
-gs/lib/wmakebat.bat<br>
-gs/lib/wrfont.ps<br>
-gs/lib/zeroline.ps<br>
-gs/man/de/dvipdf.1<br>
-gs/man/de/font2c.1<br>
-gs/man/de/gsnd.1<br>
-gs/man/de/pdf2dsc.1<br>
-gs/man/de/pdf2ps.1<br>
-gs/man/de/pdfopt.1<br>
-gs/man/de/printafm.1<br>
-gs/man/de/ps2ascii.1<br>
-gs/man/de/ps2pdf.1<br>
-gs/man/de/ps2ps.1<br>
-gs/man/de/wftopfa.1<br>
-gs/man/dvipdf.1<br>
-gs/man/eps2eps.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pdfopt.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-gs/psi/bfont.h<br>
-gs/psi/btoken.h<br>
-gs/psi/dmmain.c<br>
-gs/psi/dmmain.r<br>
-gs/psi/dpmain.c<br>
-gs/psi/dscparse.c<br>
-gs/psi/dscparse.h<br>
-gs/psi/dstack.h<br>
-gs/psi/dwdll.c<br>
-gs/psi/dwdll.h<br>
-gs/psi/dwimg.c<br>
-gs/psi/dwimg.h<br>
-gs/psi/dwmain.c<br>
-gs/psi/dwmain.rc<br>
-gs/psi/dwmainc.c<br>
-gs/psi/dwnodll.c<br>
-gs/psi/dwreg.c<br>
-gs/psi/dwreg.h<br>
-gs/psi/dwres.h<br>
-gs/psi/dwtext.c<br>
-gs/psi/dwtext.h<br>
-gs/psi/dwtrace.c<br>
-gs/psi/dwtrace.h<br>
-gs/psi/dxmain.c<br>
-gs/psi/dxmainc.c<br>
-gs/psi/estack.h<br>
-gs/psi/fapi_ft.c<br>
-gs/psi/fapibstm.c<br>
-gs/psi/fapiufst.c<br>
-gs/psi/files.h<br>
-gs/psi/ghost.h<br>
-gs/psi/gs.c<br>
-gs/psi/gsdll.c<br>
-gs/psi/gsdll2.rc<br>
-gs/psi/gsdll32.rc<br>
-gs/psi/gserver.c<br>
-gs/psi/gsos2.rc<br>
-gs/psi/ialloc.c<br>
-gs/psi/ialloc.h<br>
-gs/psi/iapi.c<br>
-gs/psi/iapi.h<br>
-gs/psi/iastate.h<br>
-gs/psi/iastruct.h<br>
-gs/psi/ibnum.c<br>
-gs/psi/ibnum.h<br>
-gs/psi/ichar.h<br>
-gs/psi/ichar1.h<br>
-gs/psi/icharout.h<br>
-gs/psi/icid.h<br>
-gs/psi/icie.h<br>
-gs/psi/icolor.h<br>
-gs/psi/iconf.c<br>
-gs/psi/iconf.h<br>
-gs/psi/icontext.c<br>
-gs/psi/icontext.h<br>
-gs/psi/icremap.h<br>
-gs/psi/icsmap.h<br>
-gs/psi/icstate.h<br>
-gs/psi/iddict.h<br>
-gs/psi/iddstack.h<br>
-gs/psi/idebug.c<br>
-gs/psi/idebug.h<br>
-gs/psi/idict.c<br>
-gs/psi/idict.h<br>
-gs/psi/idictdef.h<br>
-gs/psi/idicttpl.h<br>
-gs/psi/idisp.c<br>
-gs/psi/idisp.h<br>
-gs/psi/idosave.h<br>
-gs/psi/idparam.c<br>
-gs/psi/idparam.h<br>
-gs/psi/idsdata.h<br>
-gs/psi/idstack.c<br>
-gs/psi/idstack.h<br>
-gs/psi/ierrors.h<br>
-gs/psi/iesdata.h<br>
-gs/psi/iestack.h<br>
-gs/psi/ifapi.h<br>
-gs/psi/ifcid.h<br>
-gs/psi/ifilter.h<br>
-gs/psi/ifilter2.h<br>
-gs/psi/ifont.h<br>
-gs/psi/ifont1.h<br>
-gs/psi/ifont2.h<br>
-gs/psi/ifont42.h<br>
-gs/psi/ifrpred.h<br>
-gs/psi/ifunc.h<br>
-gs/psi/ifwpred.h<br>
-gs/psi/igc.c<br>
-gs/psi/igc.h<br>
-gs/psi/igcref.c<br>
-gs/psi/igcstr.c<br>
-gs/psi/igcstr.h<br>
-gs/psi/igstate.h<br>
-gs/psi/iht.h<br>
-gs/psi/iimage.h<br>
-gs/psi/iimage2.h<br>
-gs/psi/iinit.c<br>
-gs/psi/iinit.h<br>
-gs/psi/ilevel.h<br>
-gs/psi/ilocate.c<br>
-gs/psi/imain.c<br>
-gs/psi/imain.h<br>
-gs/psi/imainarg.c<br>
-gs/psi/imainarg.h<br>
-gs/psi/imemory.h<br>
-gs/psi/iminst.h<br>
-gs/psi/iname.c<br>
-gs/psi/iname.h<br>
-gs/psi/inamedef.h<br>
-gs/psi/inameidx.h<br>
-gs/psi/inames.h<br>
-gs/psi/inamestr.h<br>
-gs/psi/inobtokn.c<br>
-gs/psi/inouparm.c<br>
-gs/psi/int.mak<br>
-gs/psi/interp.c<br>
-gs/psi/interp.h<br>
-gs/psi/iosdata.h<br>
-gs/psi/iostack.h<br>
-gs/psi/ipacked.h<br>
-gs/psi/iparam.c<br>
-gs/psi/iparam.h<br>
-gs/psi/iparray.h<br>
-gs/psi/ipcolor.h<br>
-gs/psi/iplugin.c<br>
-gs/psi/iplugin.h<br>
-gs/psi/ireclaim.c<br>
-gs/psi/iref.h<br>
-gs/psi/isave.c<br>
-gs/psi/isave.h<br>
-gs/psi/iscan.c<br>
-gs/psi/iscan.h<br>
-gs/psi/iscanbin.c<br>
-gs/psi/iscanbin.h<br>
-gs/psi/iscannum.c<br>
-gs/psi/iscannum.h<br>
-gs/psi/isdata.h<br>
-gs/psi/isstate.h<br>
-gs/psi/istack.c<br>
-gs/psi/istack.h<br>
-gs/psi/istkparm.h<br>
-gs/psi/istream.h<br>
-gs/psi/istruct.h<br>
-gs/psi/itoken.h<br>
-gs/psi/iutil.c<br>
-gs/psi/iutil.h<br>
-gs/psi/iutil2.c<br>
-gs/psi/iutil2.h<br>
-gs/psi/ivmem2.h<br>
-gs/psi/ivmspace.h<br>
-gs/psi/main.h<br>
-gs/psi/mkfilelt.cpp<br>
-gs/psi/msvc.mak<br>
-gs/psi/msvc32.mak<br>
-gs/psi/msvc64.mak<br>
-gs/psi/nsisinst.nsi<br>
-gs/psi/oparc.h<br>
-gs/psi/opcheck.h<br>
-gs/psi/opdef.h<br>
-gs/psi/oper.h<br>
-gs/psi/opextern.h<br>
-gs/psi/os2.mak<br>
-gs/psi/ostack.h<br>
-gs/psi/psromfs.mak<br>
-gs/psi/sfilter1.c<br>
-gs/psi/store.h<br>
-gs/psi/winint.mak<br>
-gs/psi/wrfont.c<br>
-gs/psi/wrfont.h<br>
-gs/psi/write_t1.c<br>
-gs/psi/write_t1.h<br>
-gs/psi/write_t2.c<br>
-gs/psi/write_t2.h<br>
-gs/psi/zalg.c<br>
-gs/psi/zarith.c<br>
-gs/psi/zarray.c<br>
-gs/psi/zbfont.c<br>
-gs/psi/zbseq.c<br>
-gs/psi/zcfont.c<br>
-gs/psi/zchar.c<br>
-gs/psi/zchar1.c<br>
-gs/psi/zchar2.c<br>
-gs/psi/zchar32.c<br>
-gs/psi/zchar42.c<br>
-gs/psi/zchar42.h<br>
-gs/psi/zcharout.c<br>
-gs/psi/zcharx.c<br>
-gs/psi/zcid.c<br>
-gs/psi/zcidtest.c<br>
-gs/psi/zcie.c<br>
-gs/psi/zcie.h<br>
-gs/psi/zcolor.c<br>
-gs/psi/zcolor.h<br>
-gs/psi/zcolor1.c<br>
-gs/psi/zcolor2.c<br>
-gs/psi/zcolor3.c<br>
-gs/psi/zcontext.c<br>
-gs/psi/zcontrol.c<br>
-gs/psi/zcrd.c<br>
-gs/psi/zcsdevn.c<br>
-gs/psi/zcsindex.c<br>
-gs/psi/zcspixel.c<br>
-gs/psi/zcssepr.c<br>
-gs/psi/zdevcal.c<br>
-gs/psi/zdevice.c<br>
-gs/psi/zdevice2.c<br>
-gs/psi/zdfilter.c<br>
-gs/psi/zdict.c<br>
-gs/psi/zdosio.c<br>
-gs/psi/zdouble.c<br>
-gs/psi/zdpnext.c<br>
-gs/psi/zdps.c<br>
-gs/psi/zdps1.c<br>
-gs/psi/zdscpars.c<br>
-gs/psi/zfaes.c<br>
-gs/psi/zfapi.c<br>
-gs/psi/zfarc4.c<br>
-gs/psi/zfbcp.c<br>
-gs/psi/zfcid.c<br>
-gs/psi/zfcid0.c<br>
-gs/psi/zfcid1.c<br>
-gs/psi/zfcmap.c<br>
-gs/psi/zfdctd.c<br>
-gs/psi/zfdcte.c<br>
-gs/psi/zfdecode.c<br>
-gs/psi/zfile.c<br>
-gs/psi/zfile.h<br>
-gs/psi/zfile1.c<br>
-gs/psi/zfileio.c<br>
-gs/psi/zfilter.c<br>
-gs/psi/zfilter2.c<br>
-gs/psi/zfilterx.c<br>
-gs/psi/zfimscale.c<br>
-gs/psi/zfjbig2.c<br>
-gs/psi/zfjpx.c<br>
-gs/psi/zfmd5.c<br>
-gs/psi/zfont.c<br>
-gs/psi/zfont0.c<br>
-gs/psi/zfont1.c<br>
-gs/psi/zfont2.c<br>
-gs/psi/zfont32.c<br>
-gs/psi/zfont42.c<br>
-gs/psi/zfontenum.c<br>
-gs/psi/zfproc.c<br>
-gs/psi/zfrsd.c<br>
-gs/psi/zfrsd.h<br>
-gs/psi/zfsample.c<br>
-gs/psi/zfsha2.c<br>
-gs/psi/zfunc.c<br>
-gs/psi/zfunc.h<br>
-gs/psi/zfunc0.c<br>
-gs/psi/zfunc3.c<br>
-gs/psi/zfunc4.c<br>
-gs/psi/zfzlib.c<br>
-gs/psi/zgeneric.c<br>
-gs/psi/zgstate.c<br>
-gs/psi/zhsb.c<br>
-gs/psi/zht.c<br>
-gs/psi/zht1.c<br>
-gs/psi/zht2.c<br>
-gs/psi/zht2.h<br>
-gs/psi/zicc.c<br>
-gs/psi/zicc.h<br>
-gs/psi/zimage.c<br>
-gs/psi/zimage2.c<br>
-gs/psi/zimage3.c<br>
-gs/psi/ziodev.c<br>
-gs/psi/ziodev2.c<br>
-gs/psi/ziodevs.c<br>
-gs/psi/ziodevsc.c<br>
-gs/psi/zmath.c<br>
-gs/psi/zmatrix.c<br>
-gs/psi/zmedia2.c<br>
-gs/psi/zmisc.c<br>
-gs/psi/zmisc1.c<br>
-gs/psi/zmisc2.c<br>
-gs/psi/zmisc3.c<br>
-gs/psi/zncdummy.c<br>
-gs/psi/zpacked.c<br>
-gs/psi/zpaint.c<br>
-gs/psi/zpath.c<br>
-gs/psi/zpath1.c<br>
-gs/psi/zpcolor.c<br>
-gs/psi/zpdfops.c<br>
-gs/psi/zrelbit.c<br>
-gs/psi/zrop.c<br>
-gs/psi/zshade.c<br>
-gs/psi/zstack.c<br>
-gs/psi/zstring.c<br>
-gs/psi/zsysvm.c<br>
-gs/psi/ztoken.c<br>
-gs/psi/ztrans.c<br>
-gs/psi/ztrap.c<br>
-gs/psi/ztype.c<br>
-gs/psi/zupath.c<br>
-gs/psi/zusparam.c<br>
-gs/psi/zutf8.c<br>
-gs/psi/zvmem.c<br>
-gs/psi/zvmem2.c<br>
-gs/psi/zwinutf8.c<br>
-gs/toolbin/GenSubstCID.ps<br>
-gs/toolbin/afmutil.py<br>
-gs/toolbin/bughunt.sh<br>
-gs/toolbin/color/icc_creator/ICC_Creator/CIELAB.h<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_Creator.cpp<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_Creator.h<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.cpp<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.h<br>
-gs/toolbin/color/icc_creator/ICC_Creator/icc_create.cpp<br>
-gs/toolbin/color/icc_creator/ICC_Creator/icc_create.h<br>
-gs/toolbin/color/icc_creator/README.txt<br>
-gs/toolbin/drawafm.ps<br>
-gs/toolbin/encs2c.ps<br>
-gs/toolbin/errlist.tcl<br>
-gs/toolbin/extractFonts.ps<br>
-gs/toolbin/extractICCprofiles.ps<br>
-gs/toolbin/gen_ldf_jb2.py<br>
-gs/toolbin/genfontmap.ps<br>
-gs/toolbin/gitlog2changelog.py<br>
-gs/toolbin/gsmake<br>
-gs/toolbin/gsmake.tcl<br>
-gs/toolbin/halftone/gen_ordered/README<br>
-gs/toolbin/halftone/gen_ordered/gen_ordered.c<br>
-gs/toolbin/headers.tcl<br>
-gs/toolbin/jpxtopdf.c<br>
-gs/toolbin/leaks.tcl<br>
-gs/toolbin/makehist.tcl<br>
-gs/toolbin/memory.py<br>
-gs/toolbin/ocheck.py<br>
-gs/toolbin/pdf_info.ps<br>
-gs/toolbin/pdfinflt.ps<br>
-gs/toolbin/pre.tcl<br>
-gs/toolbin/precheck.tcl<br>
-gs/toolbin/pscet_status.pl<br>
-gs/toolbin/smoke.ps<br>
-gs/toolbin/split_changelog.py<br>
-gs/toolbin/suite.tcl<br>
-gs/toolbin/tests/build_revision.py<br>
-gs/toolbin/tests/check_all.py<br>
-gs/toolbin/tests/check_comments.py<br>
-gs/toolbin/tests/check_dirs.py<br>
-gs/toolbin/tests/check_docrefs.py<br>
-gs/toolbin/tests/check_source.py<br>
-gs/toolbin/tests/cmpi.py<br>
-gs/toolbin/tests/compare_checksumdb.py<br>
-gs/toolbin/tests/compare_checksums.py<br>
-gs/toolbin/tests/dump_checksum.py<br>
-gs/toolbin/tests/dump_checksum_plus.py<br>
-gs/toolbin/tests/dump_checksum_raw.py<br>
-gs/toolbin/tests/fuzzy.c<br>
-gs/toolbin/tests/get_baseline_log.py<br>
-gs/toolbin/tests/get_baselines.py<br>
-gs/toolbin/tests/gscheck_all.py<br>
-gs/toolbin/tests/gscheck_fuzzypdf.py<br>
-gs/toolbin/tests/gscheck_pdfwrite.py<br>
-gs/toolbin/tests/gscheck_raster.py<br>
-gs/toolbin/tests/gscheck_testfiles.py<br>
-gs/toolbin/tests/gsconf.py<br>
-gs/toolbin/tests/gsparamsets.py<br>
-gs/toolbin/tests/gssum.py<br>
-gs/toolbin/tests/gstestgs.py<br>
-gs/toolbin/tests/gstestutils.py<br>
-gs/toolbin/tests/gsutil.py<br>
-gs/toolbin/tests/make_baselinedb.py<br>
-gs/toolbin/tests/make_testdb.py<br>
-gs/toolbin/tests/make_two_pdfversions<br>
-gs/toolbin/tests/make_two_versions<br>
-gs/toolbin/tests/myoptparse.py<br>
-gs/toolbin/tests/rasterdb.py<br>
-gs/toolbin/tests/revert_baseline<br>
-gs/toolbin/tests/revert_pdfbaseline<br>
-gs/toolbin/tests/run_nightly.py<br>
-gs/toolbin/tests/run_parallel<br>
-gs/toolbin/tests/run_regression.py<br>
-gs/toolbin/tests/testdiff.py<br>
-gs/toolbin/tests/update_baseline.py<br>
-gs/toolbin/tests/update_specific<br>
-gs/toolbin/tmake.tcl<br>
-gs/zlib/ChangeLog<br>
-gs/zlib/adler32.c<br>
-gs/zlib/compress.c<br>
-gs/zlib/crc32.c<br>
-gs/zlib/deflate.c<br>
-gs/zlib/deflate.h<br>
-gs/zlib/test/example.c<br>
-gs/zlib/test/minigzip.c<br>
-gs/zlib/trees.c<br>
-gs/zlib/uncompr.c<br>
-gs/zlib/zconf.h<br>
-gs/zlib/zconf.h.cmakein<br>
-gs/zlib/zconf.h.in<br>
-gs/zlib/zutil.c<br>
-gs/zlib/zutil.h<br>
-language_switch/pspcl6_gcc.mak<br>
-language_switch/pspcl6_msvc.mak<br>
-pcl/pcbiptrn.c<br>
-pcl/pcbiptrn.h<br>
-pcl/pccid.c<br>
-pcl/pccid.h<br>
-pcl/pccolor.c<br>
-pcl/pccoord.h<br>
-pcl/pccprint.c<br>
-pcl/pccsbase.c<br>
-pcl/pccsbase.h<br>
-pcl/pcdict.h<br>
-pcl/pcdither.c<br>
-pcl/pcdither.h<br>
-pcl/pcdraw.c<br>
-pcl/pcdraw.h<br>
-pcl/pcfont.c<br>
-pcl/pcfont.h<br>
-pcl/pcfontpg.c<br>
-pcl/pcfontst.h<br>
-pcl/pcfrgrnd.c<br>
-pcl/pcfrgrnd.h<br>
-pcl/pcfsel.c<br>
-pcl/pcfsel.h<br>
-pcl/pcht.c<br>
-pcl/pcht.h<br>
-pcl/pcident.c<br>
-pcl/pcident.h<br>
-pcl/pcimpl.c<br>
-pcl/pcindxed.c<br>
-pcl/pcindxed.h<br>
-pcl/pcjob.c<br>
-pcl/pcl.mak<br>
-pcl/pcl_top.mak<br>
-pcl/pclookup.c<br>
-pcl/pclookup.h<br>
-pcl/pcmacros.c<br>
-pcl/pcmisc.c<br>
-pcl/pcmtx3.c<br>
-pcl/pcmtx3.h<br>
-pcl/pcommand.c<br>
-pcl/pcommand.h<br>
-pcl/pcpage.c<br>
-pcl/pcpage.h<br>
-pcl/pcpalet.c<br>
-pcl/pcpalet.h<br>
-pcl/pcparam.h<br>
-pcl/pcparse.c<br>
-pcl/pcparse.h<br>
-pcl/pcpatrn.c<br>
-pcl/pcpatrn.h<br>
-pcl/pcpattyp.h<br>
-pcl/pcpatxfm.c<br>
-pcl/pcpatxfm.h<br>
-pcl/pcrect.c<br>
-pcl/pcsfont.c<br>
-pcl/pcstate.h<br>
-pcl/pcstatus.c<br>
-pcl/pcsymbol.c<br>
-pcl/pcsymbol.h<br>
-pcl/pctext.c<br>
-pcl/pctop.c<br>
-pcl/pctop.h<br>
-pcl/pctpm.h<br>
-pcl/pcuptrn.c<br>
-pcl/pcuptrn.h<br>
-pcl/pcursor.c<br>
-pcl/pcursor.h<br>
-pcl/pcwhtidx.c<br>
-pcl/pcwhtidx.h<br>
-pcl/pcxfmst.h<br>
-pcl/pgchar.c<br>
-pcl/pgcolor.c<br>
-pcl/pgconfig.c<br>
-pcl/pgdraw.c<br>
-pcl/pgdraw.h<br>
-pcl/pgfdata.c<br>
-pcl/pgfdata.h<br>
-pcl/pgfont.c<br>
-pcl/pgfont.h<br>
-pcl/pgframe.c<br>
-pcl/pggeom.c<br>
-pcl/pggeom.h<br>
-pcl/pginit.c<br>
-pcl/pginit.h<br>
-pcl/pglabel.c<br>
-pcl/pglfill.c<br>
-pcl/pgmand.h<br>
-pcl/pgmisc.c<br>
-pcl/pgmisc.h<br>
-pcl/pgparse.c<br>
-pcl/pgpoly.c<br>
-pcl/pgstate.h<br>
-pcl/pgvector.c<br>
-pcl/rtgmode.c<br>
-pcl/rtgmode.h<br>
-pcl/rtmisc.c<br>
-pcl/rtraster.c<br>
-pcl/rtraster.h<br>
-pcl/rtrstcmp.c<br>
-pcl/rtrstcmp.h<br>
-pcl/rtrstst.h<br>
-pl/dwimg.c<br>
-pl/dwimg.h<br>
-pl/dwmainc.c<br>
-pl/dwreg.c<br>
-pl/dwreg.h<br>
-pl/dwres.h<br>
-pl/pjparse.c<br>
-pl/pjparse.h<br>
-pl/pjparsei.c<br>
-pl/pjtop.c<br>
-pl/pjtop.h<br>
-pl/pl.mak<br>
-pl/plalloc.c<br>
-pl/plalloc.h<br>
-pl/plapi.h<br>
-pl/plchar.c<br>
-pl/pldebug.h<br>
-pl/pldict.c<br>
-pl/pldict.h<br>
-pl/pldraw.c<br>
-pl/pldraw.h<br>
-pl/plfont.c<br>
-pl/plfont.h<br>
-pl/plftable.c<br>
-pl/plftable.h<br>
-pl/plht.c<br>
-pl/plht.h<br>
-pl/plimpl.c<br>
-pl/pllfont.c<br>
-pl/pllfont.h<br>
-pl/plmain.c<br>
-pl/plmain.h<br>
-pl/plparse.h<br>
-pl/plplatf.c<br>
-pl/plplatf.h<br>
-pl/plplatfps.c<br>
-pl/plsrgb.c<br>
-pl/plsrgb.h<br>
-pl/plsymbol.c<br>
-pl/plsymbol.h<br>
-pl/pltop.c<br>
-pl/pltop.h<br>
-pl/pltoputl.c<br>
-pl/pltoputl.h<br>
-pl/pluchar.c<br>
-pl/plufont.c<br>
-pl/plulfont.c<br>
-pl/plvalue.c<br>
-pl/plvalue.h<br>
-pl/plvocab.c<br>
-pl/plvocab.h<br>
-pl/realmain.c<br>
-psi/psi.mak<br>
-psi/psitop.c<br>
-pxl/pxasm.ps<br>
-pxl/pxattr.h<br>
-pxl/pxbfont.c<br>
-pxl/pxbfont.h<br>
-pxl/pxbfont.ps<br>
-pxl/pxcet.txt<br>
-pxl/pxdict.h<br>
-pxl/pxdiff.txt<br>
-pxl/pxenum.h<br>
-pxl/pxerrors.c<br>
-pxl/pxerrors.h<br>
-pxl/pxffont.c<br>
-pxl/pxfont.c<br>
-pxl/pxfont.h<br>
-pxl/pxfts.txt<br>
-pxl/pxgstate.c<br>
-pxl/pxgstate.h<br>
-pxl/pximage.c<br>
-pxl/pximpl.c<br>
-pxl/pxink.c<br>
-pxl/pxl.mak<br>
-pxl/pxlib.txt<br>
-pxl/pxoper.h<br>
-pxl/pxpaint.c<br>
-pxl/pxparse.c<br>
-pxl/pxparse.h<br>
-pxl/pxptable.c<br>
-pxl/pxptable.h<br>
-pxl/pxpthr.c<br>
-pxl/pxpthr.h<br>
-pxl/pxsessio.c<br>
-pxl/pxspec.txt<br>
-pxl/pxstate.c<br>
-pxl/pxstate.h<br>
-pxl/pxstream.c<br>
-pxl/pxsymbol.ps<br>
-pxl/pxsymbol.psc<br>
-pxl/pxsymbol.psh<br>
-pxl/pxtag.h<br>
-pxl/pxtop.c<br>
-pxl/pxvalue.c<br>
-pxl/pxvalue.h<br>
-svg/ghostsvg.h<br>
-svg/svg.mak<br>
-svg/svg_gcc.mak<br>
-svg/svg_msvc.mak<br>
-svg/svgcolor.c<br>
-svg/svgcolorlist.h<br>
-svg/svgdoc.c<br>
-svg/svgshapes.c<br>
-svg/svgtop.c<br>
-svg/svgtransform.c<br>
-svg/svgtypes.c<br>
-svg/svgxml.c<br>
-tools/gslite/gslt.h<br>
-tools/gslite/gslt_font.h<br>
-tools/gslite/gslt_font_api.c<br>
-tools/gslite/gslt_font_api.h<br>
-tools/gslite/gslt_font_api_test.c<br>
-tools/gslite/gslt_font_cache.c<br>
-tools/gslite/gslt_font_cff.c<br>
-tools/gslite/gslt_font_encoding.c<br>
-tools/gslite/gslt_font_glyph.c<br>
-tools/gslite/gslt_font_int.h<br>
-tools/gslite/gslt_font_test.c<br>
-tools/gslite/gslt_font_ttf.c<br>
-tools/gslite/gslt_image.c<br>
-tools/gslite/gslt_image.h<br>
-tools/gslite/gslt_image_jpeg.c<br>
-tools/gslite/gslt_image_png.c<br>
-tools/gslite/gslt_image_test.c<br>
-tools/gslite/gslt_image_threads_test.c<br>
-tools/gslite/gslt_image_tiff.c<br>
-tools/gslite/gslt_init.c<br>
-tools/gslite/gslt_stubs.c<br>
-tools/gslite/gslt_test.c<br>
-tools/null.pxl<br>
-tools/suite.tcl<br>
-xps/ghostxps.h<br>
-xps/xps.mak<br>
-xps/xps_gcc.mak<br>
-xps/xps_msvc.mak<br>
-xps/xpsanalyze.c<br>
-xps/xpscff.c<br>
-xps/xpscolor.c<br>
-xps/xpscommon.c<br>
-xps/xpscrc.c<br>
-xps/xpsdoc.c<br>
-xps/xpsfont.c<br>
-xps/xpsglyphs.c<br>
-xps/xpsgradient.c<br>
-xps/xpshash.c<br>
-xps/xpsimage.c<br>
-xps/xpsjpeg.c<br>
-xps/xpsjxr.c<br>
-xps/xpsmem.c<br>
-xps/xpsopacity.c<br>
-xps/xpspage.c<br>
-xps/xpspath.c<br>
-xps/xpspng.c<br>
-xps/xpsresource.c<br>
-xps/xpstiff.c<br>
-xps/xpstile.c<br>
-xps/xpstop.c<br>
-xps/xpsttf.c<br>
-xps/xpsutf.c<br>
-xps/xpsvisual.c<br>
-xps/xpsxml.c<br>
-xps/xpszip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-13 12:22: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=fae7be45fb7f2e9be889c07dc9d29e7ea1975dc9">fae7be45fb7f2e9be889c07dc9d29e7ea1975dc9</a>
-<blockquote>
-<p>
- Bug 692365: Don't derive metrics for CIDFontType 2.<br>
-<br>
- pdfwrite uses zchar42_set_cache() to get the glyph metrics for a glyph from<br>
- CIDFontType 2 font. It turns out, that function contained the same faking<br>
- of vertical metrics as the FAPI code originally had. That's a problem because<br>
- a PS font without vertical metrics should be treated as horizontal, regardless<br>
- of the wmode value.<br>
-<br>
- We *only* want to derive vertical metrics for TTF fonts read from disk being<br>
- used to emulate a missing CIDFont with wmode 1.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zchar42.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-11 14:09: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=b4dbdb142e340596d9a8b440ca415832c39caef2">b4dbdb142e340596d9a8b440ca415832c39caef2</a>
-<blockquote>
-<p>
- Update libjpeg to 8d.<br>
-<br>
-gs/jpeg/Makefile.in<br>
-gs/jpeg/README<br>
-gs/jpeg/aclocal.m4<br>
-gs/jpeg/change.log<br>
-gs/jpeg/cjpeg.1<br>
-gs/jpeg/cjpeg.c<br>
-gs/jpeg/config.guess<br>
-gs/jpeg/config.sub<br>
-gs/jpeg/configure<br>
-gs/jpeg/configure.ac<br>
-gs/jpeg/depcomp<br>
-gs/jpeg/install-sh<br>
-gs/jpeg/install.txt<br>
-gs/jpeg/jaricom.c<br>
-gs/jpeg/jcarith.c<br>
-gs/jpeg/jccoefct.c<br>
-gs/jpeg/jccolor.c<br>
-gs/jpeg/jconfig.mc6<br>
-gs/jpeg/jctrans.c<br>
-gs/jpeg/jdarith.c<br>
-gs/jpeg/jdatadst.c<br>
-gs/jpeg/jdatasrc.c<br>
-gs/jpeg/jdcoefct.c<br>
-gs/jpeg/jdcolor.c<br>
-gs/jpeg/jdmaster.c<br>
-gs/jpeg/jmemmgr.c<br>
-gs/jpeg/jmorecfg.h<br>
-gs/jpeg/jpegint.h<br>
-gs/jpeg/jpeglib.h<br>
-gs/jpeg/jpegtran.c<br>
-gs/jpeg/jquant1.c<br>
-gs/jpeg/jquant2.c<br>
-gs/jpeg/jutils.c<br>
-gs/jpeg/jversion.h<br>
-gs/jpeg/libjpeg.txt<br>
-gs/jpeg/ltmain.sh<br>
-gs/jpeg/structure.txt<br>
-gs/jpeg/transupp.c<br>
-gs/jpeg/transupp.h<br>
-gs/jpeg/usage.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-11 11:37:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2214fb3da464f702ab4bd46d653aef1c9b69d483">2214fb3da464f702ab4bd46d653aef1c9b69d483</a>
-<blockquote>
-<p>
- Update zlib to 1.2.7<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/zlib/CMakeLists.txt<br>
-gs/zlib/ChangeLog<br>
-gs/zlib/FAQ<br>
-gs/zlib/INDEX<br>
-gs/zlib/Makefile<br>
-gs/zlib/Makefile.in<br>
-gs/zlib/README<br>
-gs/zlib/adler32.c<br>
-gs/zlib/algorithm.txt<br>
-gs/zlib/amiga/Makefile.pup<br>
-gs/zlib/amiga/Makefile.sas<br>
-gs/zlib/as400/bndsrc<br>
-gs/zlib/as400/compile.clp<br>
-gs/zlib/as400/readme.txt<br>
-gs/zlib/as400/zlib.inc<br>
-gs/zlib/compress.c<br>
-gs/zlib/configure<br>
-gs/zlib/contrib/README.contrib<br>
-gs/zlib/contrib/amd64/amd64-match.S<br>
-gs/zlib/contrib/asm586/README.586<br>
-gs/zlib/contrib/asm586/match.S<br>
-gs/zlib/contrib/asm686/README.686<br>
-gs/zlib/contrib/asm686/match.S<br>
-gs/zlib/contrib/delphi/ZLib.pas<br>
-gs/zlib/contrib/delphi/zlibd32.mak<br>
-gs/zlib/contrib/dotzlib/DotZLib.build<br>
-gs/zlib/contrib/dotzlib/DotZLib.chm<br>
-gs/zlib/contrib/dotzlib/DotZLib/AssemblyInfo.cs<br>
-gs/zlib/contrib/dotzlib/DotZLib/ChecksumImpl.cs<br>
-gs/zlib/contrib/dotzlib/DotZLib/CircularBuffer.cs<br>
-gs/zlib/contrib/dotzlib/DotZLib/CodecBase.cs<br>
-gs/zlib/contrib/dotzlib/DotZLib/Deflater.cs<br>
-gs/zlib/contrib/dotzlib/DotZLib/DotZLib.cs<br>
-gs/zlib/contrib/dotzlib/DotZLib/GZipStream.cs<br>
-gs/zlib/contrib/dotzlib/DotZLib/Inflater.cs<br>
-gs/zlib/contrib/dotzlib/DotZLib/UnitTests.cs<br>
-gs/zlib/contrib/dotzlib/readme.txt<br>
-gs/zlib/contrib/gcc_gvmat64/gvmat64.S<br>
-gs/zlib/contrib/infback9/infback9.c<br>
-gs/zlib/contrib/infback9/inftree9.c<br>
-gs/zlib/contrib/infback9/inftree9.h<br>
-gs/zlib/contrib/inflate86/inffas86.c<br>
-gs/zlib/contrib/masm686/match.asm<br>
-gs/zlib/contrib/masmx64/gvmat64.asm<br>
-gs/zlib/contrib/masmx64/gvmat64.obj<br>
-gs/zlib/contrib/masmx64/inffas8664.c<br>
-gs/zlib/contrib/masmx64/inffasx64.asm<br>
-gs/zlib/contrib/masmx64/inffasx64.obj<br>
-gs/zlib/contrib/masmx64/readme.txt<br>
-gs/zlib/contrib/masmx86/bld_ml32.bat<br>
-gs/zlib/contrib/masmx86/gvmat32.asm<br>
-gs/zlib/contrib/masmx86/gvmat32.obj<br>
-gs/zlib/contrib/masmx86/gvmat32c.c<br>
-gs/zlib/contrib/masmx86/inffas32.asm<br>
-gs/zlib/contrib/masmx86/inffas32.obj<br>
-gs/zlib/contrib/masmx86/match686.asm<br>
-gs/zlib/contrib/masmx86/mkasm.bat<br>
-gs/zlib/contrib/masmx86/readme.txt<br>
-gs/zlib/contrib/minizip/ChangeLogUnzip<br>
-gs/zlib/contrib/minizip/Makefile.am<br>
-gs/zlib/contrib/minizip/MiniZip64_Changes.txt<br>
-gs/zlib/contrib/minizip/MiniZip64_info.txt<br>
-gs/zlib/contrib/minizip/configure.ac<br>
-gs/zlib/contrib/minizip/crypt.h<br>
-gs/zlib/contrib/minizip/ioapi.c<br>
-gs/zlib/contrib/minizip/ioapi.h<br>
-gs/zlib/contrib/minizip/iowin32.c<br>
-gs/zlib/contrib/minizip/iowin32.h<br>
-gs/zlib/contrib/minizip/make_vms.com<br>
-gs/zlib/contrib/minizip/miniunz.c<br>
-gs/zlib/contrib/minizip/minizip.c<br>
-gs/zlib/contrib/minizip/minizip.pc.in<br>
-gs/zlib/contrib/minizip/mztools.c<br>
-gs/zlib/contrib/minizip/mztools.h<br>
-gs/zlib/contrib/minizip/unzip.c<br>
-gs/zlib/contrib/minizip/unzip.h<br>
-gs/zlib/contrib/minizip/zip.c<br>
-gs/zlib/contrib/minizip/zip.h<br>
-gs/zlib/contrib/pascal/zlibd32.mak<br>
-gs/zlib/contrib/pascal/zlibpas.pas<br>
-gs/zlib/contrib/puff/Makefile<br>
-gs/zlib/contrib/puff/puff.c<br>
-gs/zlib/contrib/puff/puff.h<br>
-gs/zlib/contrib/puff/pufftest.c<br>
-gs/zlib/contrib/puff/zeros.raw<br>
-gs/zlib/contrib/testzlib/testzlib.c<br>
-gs/zlib/contrib/vstudio/readme.txt<br>
-gs/zlib/contrib/vstudio/vc10/miniunz.vcxproj<br>
-gs/zlib/contrib/vstudio/vc10/miniunz.vcxproj.filters<br>
-gs/zlib/contrib/vstudio/vc10/miniunz.vcxproj.user<br>
-gs/zlib/contrib/vstudio/vc10/minizip.vcxproj<br>
-gs/zlib/contrib/vstudio/vc10/minizip.vcxproj.filters<br>
-gs/zlib/contrib/vstudio/vc10/minizip.vcxproj.user<br>
-gs/zlib/contrib/vstudio/vc10/testzlib.vcxproj<br>
-gs/zlib/contrib/vstudio/vc10/testzlib.vcxproj.filters<br>
-gs/zlib/contrib/vstudio/vc10/testzlib.vcxproj.user<br>
-gs/zlib/contrib/vstudio/vc10/testzlibdll.vcxproj<br>
-gs/zlib/contrib/vstudio/vc10/testzlibdll.vcxproj.filters<br>
-gs/zlib/contrib/vstudio/vc10/testzlibdll.vcxproj.user<br>
-gs/zlib/contrib/vstudio/vc10/zlib.rc<br>
-gs/zlib/contrib/vstudio/vc10/zlibstat.vcxproj<br>
-gs/zlib/contrib/vstudio/vc10/zlibstat.vcxproj.filters<br>
-gs/zlib/contrib/vstudio/vc10/zlibstat.vcxproj.user<br>
-gs/zlib/contrib/vstudio/vc10/zlibvc.def<br>
-gs/zlib/contrib/vstudio/vc10/zlibvc.sln<br>
-gs/zlib/contrib/vstudio/vc10/zlibvc.vcxproj<br>
-gs/zlib/contrib/vstudio/vc10/zlibvc.vcxproj.filters<br>
-gs/zlib/contrib/vstudio/vc10/zlibvc.vcxproj.user<br>
-gs/zlib/contrib/vstudio/vc7/miniunz.vcproj<br>
-gs/zlib/contrib/vstudio/vc7/minizip.vcproj<br>
-gs/zlib/contrib/vstudio/vc7/testzlib.vcproj<br>
-gs/zlib/contrib/vstudio/vc7/zlib.rc<br>
-gs/zlib/contrib/vstudio/vc7/zlibstat.vcproj<br>
-gs/zlib/contrib/vstudio/vc7/zlibvc.def<br>
-gs/zlib/contrib/vstudio/vc7/zlibvc.sln<br>
-gs/zlib/contrib/vstudio/vc7/zlibvc.vcproj<br>
-gs/zlib/contrib/vstudio/vc8/miniunz.vcproj<br>
-gs/zlib/contrib/vstudio/vc8/minizip.vcproj<br>
-gs/zlib/contrib/vstudio/vc8/testzlib.vcproj<br>
-gs/zlib/contrib/vstudio/vc8/testzlibdll.vcproj<br>
-gs/zlib/contrib/vstudio/vc8/zlib.rc<br>
-gs/zlib/contrib/vstudio/vc8/zlibstat.vcproj<br>
-gs/zlib/contrib/vstudio/vc8/zlibvc.def<br>
-gs/zlib/contrib/vstudio/vc8/zlibvc.sln<br>
-gs/zlib/contrib/vstudio/vc8/zlibvc.vcproj<br>
-gs/zlib/contrib/vstudio/vc9/miniunz.vcproj<br>
-gs/zlib/contrib/vstudio/vc9/minizip.vcproj<br>
-gs/zlib/contrib/vstudio/vc9/testzlib.vcproj<br>
-gs/zlib/contrib/vstudio/vc9/testzlibdll.vcproj<br>
-gs/zlib/contrib/vstudio/vc9/zlib.rc<br>
-gs/zlib/contrib/vstudio/vc9/zlibstat.vcproj<br>
-gs/zlib/contrib/vstudio/vc9/zlibvc.def<br>
-gs/zlib/contrib/vstudio/vc9/zlibvc.sln<br>
-gs/zlib/contrib/vstudio/vc9/zlibvc.vcproj<br>
-gs/zlib/crc32.c<br>
-gs/zlib/crc32.h<br>
-gs/zlib/deflate.c<br>
-gs/zlib/deflate.h<br>
-gs/zlib/doc/algorithm.txt<br>
-gs/zlib/doc/rfc1950.txt<br>
-gs/zlib/doc/rfc1951.txt<br>
-gs/zlib/doc/rfc1952.txt<br>
-gs/zlib/doc/txtvsbin.txt<br>
-gs/zlib/example.c<br>
-gs/zlib/examples/README.examples<br>
-gs/zlib/examples/enough.c<br>
-gs/zlib/examples/gun.c<br>
-gs/zlib/examples/gzlog.c<br>
-gs/zlib/examples/gzlog.h<br>
-gs/zlib/examples/zlib_how.html<br>
-gs/zlib/examples/zpipe.c<br>
-gs/zlib/examples/zran.c<br>
-gs/zlib/gzclose.c<br>
-gs/zlib/gzguts.h<br>
-gs/zlib/gzio.c<br>
-gs/zlib/gzlib.c<br>
-gs/zlib/gzread.c<br>
-gs/zlib/gzwrite.c<br>
-gs/zlib/infback.c<br>
-gs/zlib/inffast.c<br>
-gs/zlib/inffast.h<br>
-gs/zlib/inffixed.h<br>
-gs/zlib/inflate.c<br>
-gs/zlib/inflate.h<br>
-gs/zlib/inftrees.c<br>
-gs/zlib/inftrees.h<br>
-gs/zlib/make_vms.com<br>
-gs/zlib/minigzip.c<br>
-gs/zlib/msdos/Makefile.bor<br>
-gs/zlib/msdos/Makefile.dj2<br>
-gs/zlib/msdos/Makefile.emx<br>
-gs/zlib/msdos/Makefile.msc<br>
-gs/zlib/msdos/Makefile.tc<br>
-gs/zlib/nintendods/Makefile<br>
-gs/zlib/nintendods/README<br>
-gs/zlib/old/Makefile.emx<br>
-gs/zlib/old/zlib.html<br>
-gs/zlib/projects/README.projects<br>
-gs/zlib/projects/visualc6/README.txt<br>
-gs/zlib/projects/visualc6/example.dsp<br>
-gs/zlib/projects/visualc6/minigzip.dsp<br>
-gs/zlib/projects/visualc6/zlib.dsp<br>
-gs/zlib/projects/visualc6/zlib.dsw<br>
-gs/zlib/qnx/package.qpg<br>
-gs/zlib/test/example.c<br>
-gs/zlib/test/infcover.c<br>
-gs/zlib/test/minigzip.c<br>
-gs/zlib/treebuild.xml<br>
-gs/zlib/trees.c<br>
-gs/zlib/trees.h<br>
-gs/zlib/uncompr.c<br>
-gs/zlib/watcom/watcom_f.mak<br>
-gs/zlib/watcom/watcom_l.mak<br>
-gs/zlib/win32/DLL_FAQ.txt<br>
-gs/zlib/win32/Makefile.bor<br>
-gs/zlib/win32/Makefile.emx<br>
-gs/zlib/win32/Makefile.gcc<br>
-gs/zlib/win32/Makefile.msc<br>
-gs/zlib/win32/README-WIN32.txt<br>
-gs/zlib/win32/zlib.def<br>
-gs/zlib/win32/zlib1.rc<br>
-gs/zlib/zconf.h<br>
-gs/zlib/zconf.h.cmakein<br>
-gs/zlib/zconf.h.in<br>
-gs/zlib/zconf.in.h<br>
-gs/zlib/zlib.3<br>
-gs/zlib/zlib.3.pdf<br>
-gs/zlib/zlib.h<br>
-gs/zlib/zlib.map<br>
-gs/zlib/zlib.pc.cmakein<br>
-gs/zlib/zlib.pc.in<br>
-gs/zlib/zlib2ansi<br>
-gs/zlib/zutil.c<br>
-gs/zlib/zutil.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-11 09:11: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=3c419d97583ed1c234d53bd9c0efac2ef9fff320">3c419d97583ed1c234d53bd9c0efac2ef9fff320</a>
-<blockquote>
-<p>
- Update libtiff to 4.0.1.<br>
-<br>
- Remove globals from tif_pixarlog.c<br>
-<br>
- Re-apply commit 786269bafff68f1965b1536acef11f25e0cd44d0<br>
-<br>
- Also reapply some portability changes to tiffiop.h.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/tiff/ChangeLog<br>
-gs/tiff/HOWTO-RELEASE<br>
-gs/tiff/Makefile.am<br>
-gs/tiff/Makefile.in<br>
-gs/tiff/Makefile.vc<br>
-gs/tiff/README<br>
-gs/tiff/RELEASE-DATE<br>
-gs/tiff/TODO<br>
-gs/tiff/VERSION<br>
-gs/tiff/aclocal.m4<br>
-gs/tiff/autogen.sh<br>
-gs/tiff/build/Makefile.am<br>
-gs/tiff/build/Makefile.in<br>
-gs/tiff/config/config.guess<br>
-gs/tiff/config/config.sub<br>
-gs/tiff/config/depcomp<br>
-gs/tiff/config/install-sh<br>
-gs/tiff/config/ltmain.sh<br>
-gs/tiff/config/missing<br>
-gs/tiff/config/mkinstalldirs<br>
-gs/tiff/configure<br>
-gs/tiff/configure.ac<br>
-gs/tiff/configure.com<br>
-gs/tiff/contrib/Makefile.am<br>
-gs/tiff/contrib/Makefile.in<br>
-gs/tiff/contrib/acorn/Makefile.acorn<br>
-gs/tiff/contrib/acorn/Makefile.am<br>
-gs/tiff/contrib/acorn/Makefile.in<br>
-gs/tiff/contrib/acorn/ReadMe<br>
-gs/tiff/contrib/acorn/SetVars<br>
-gs/tiff/contrib/acorn/cleanlib<br>
-gs/tiff/contrib/acorn/convert<br>
-gs/tiff/contrib/acorn/install<br>
-gs/tiff/contrib/addtiffo/Makefile.am<br>
-gs/tiff/contrib/addtiffo/Makefile.in<br>
-gs/tiff/contrib/addtiffo/addtiffo.c<br>
-gs/tiff/contrib/addtiffo/tif_overview.c<br>
-gs/tiff/contrib/addtiffo/tif_ovrcache.c<br>
-gs/tiff/contrib/addtiffo/tif_ovrcache.h<br>
-gs/tiff/contrib/dbs/Makefile.am<br>
-gs/tiff/contrib/dbs/Makefile.in<br>
-gs/tiff/contrib/dbs/tiff-bi.c<br>
-gs/tiff/contrib/dbs/tiff-grayscale.c<br>
-gs/tiff/contrib/dbs/tiff-palette.c<br>
-gs/tiff/contrib/dbs/tiff-rgb.c<br>
-gs/tiff/contrib/dbs/xtiff/Makefile.am<br>
-gs/tiff/contrib/dbs/xtiff/Makefile.in<br>
-gs/tiff/contrib/dbs/xtiff/patchlevel.h<br>
-gs/tiff/contrib/dbs/xtiff/xtiff.c<br>
-gs/tiff/contrib/dbs/xtiff/xtifficon.h<br>
-gs/tiff/contrib/iptcutil/Makefile.in<br>
-gs/tiff/contrib/iptcutil/iptcutil.c<br>
-gs/tiff/contrib/mac-cw/Makefile.am<br>
-gs/tiff/contrib/mac-cw/Makefile.in<br>
-gs/tiff/contrib/mac-cw/Makefile.script<br>
-gs/tiff/contrib/mac-cw/README<br>
-gs/tiff/contrib/mac-cw/mac_main.c<br>
-gs/tiff/contrib/mac-cw/mac_main.h<br>
-gs/tiff/contrib/mac-cw/metrowerks.note<br>
-gs/tiff/contrib/mac-cw/mkg3_main.c<br>
-gs/tiff/contrib/mac-cw/version.h<br>
-gs/tiff/contrib/mac-mpw/BUILD.mpw<br>
-gs/tiff/contrib/mac-mpw/Makefile.am<br>
-gs/tiff/contrib/mac-mpw/Makefile.in<br>
-gs/tiff/contrib/mac-mpw/README<br>
-gs/tiff/contrib/mac-mpw/libtiff.make<br>
-gs/tiff/contrib/mac-mpw/mactrans.c<br>
-gs/tiff/contrib/mac-mpw/port.make<br>
-gs/tiff/contrib/mac-mpw/tools.make<br>
-gs/tiff/contrib/mac-mpw/top.make<br>
-gs/tiff/contrib/mfs/Makefile.am<br>
-gs/tiff/contrib/mfs/Makefile.in<br>
-gs/tiff/contrib/mfs/mfs_file.c<br>
-gs/tiff/contrib/pds/Makefile.am<br>
-gs/tiff/contrib/pds/Makefile.in<br>
-gs/tiff/contrib/pds/tif_imageiter.c<br>
-gs/tiff/contrib/pds/tif_imageiter.h<br>
-gs/tiff/contrib/pds/tif_pdsdirread.c<br>
-gs/tiff/contrib/pds/tif_pdsdirwrite.c<br>
-gs/tiff/contrib/ras/Makefile.am<br>
-gs/tiff/contrib/ras/Makefile.in<br>
-gs/tiff/contrib/ras/ras2tif.c<br>
-gs/tiff/contrib/ras/tif2ras.c<br>
-gs/tiff/contrib/stream/Makefile.am<br>
-gs/tiff/contrib/stream/Makefile.in<br>
-gs/tiff/contrib/stream/tiffstream.cpp<br>
-gs/tiff/contrib/stream/tiffstream.h<br>
-gs/tiff/contrib/tags/Makefile.am<br>
-gs/tiff/contrib/tags/Makefile.in<br>
-gs/tiff/contrib/tags/listtif.c<br>
-gs/tiff/contrib/tags/maketif.c<br>
-gs/tiff/contrib/tags/xtif_dir.c<br>
-gs/tiff/contrib/tags/xtiffio.h<br>
-gs/tiff/contrib/tags/xtiffiop.h<br>
-gs/tiff/contrib/win_dib/Makefile.am<br>
-gs/tiff/contrib/win_dib/Makefile.in<br>
-gs/tiff/contrib/win_dib/Tiffile.cpp<br>
-gs/tiff/contrib/win_dib/tiff2dib.c<br>
-gs/tiff/html/Makefile.am<br>
-gs/tiff/html/Makefile.in<br>
-gs/tiff/html/bugs.html<br>
-gs/tiff/html/build.html<br>
-gs/tiff/html/document.html<br>
-gs/tiff/html/images/Makefile.in<br>
-gs/tiff/html/index.html<br>
-gs/tiff/html/man/Makefile.in<br>
-gs/tiff/html/man/TIFFClose.3tiff.html<br>
-gs/tiff/html/man/TIFFDataWidth.3tiff.html<br>
-gs/tiff/html/man/TIFFError.3tiff.html<br>
-gs/tiff/html/man/TIFFFlush.3tiff.html<br>
-gs/tiff/html/man/TIFFGetField.3tiff.html<br>
-gs/tiff/html/man/TIFFOpen.3tiff.html<br>
-gs/tiff/html/man/TIFFPrintDirectory.3tiff.html<br>
-gs/tiff/html/man/TIFFRGBAImage.3tiff.html<br>
-gs/tiff/html/man/TIFFReadDirectory.3tiff.html<br>
-gs/tiff/html/man/TIFFReadEncodedStrip.3tiff.html<br>
-gs/tiff/html/man/TIFFReadEncodedTile.3tiff.html<br>
-gs/tiff/html/man/TIFFReadRGBAImage.3tiff.html<br>
-gs/tiff/html/man/TIFFReadRGBAStrip.3tiff.html<br>
-gs/tiff/html/man/TIFFReadRGBATile.3tiff.html<br>
-gs/tiff/html/man/TIFFReadRawStrip.3tiff.html<br>
-gs/tiff/html/man/TIFFReadRawTile.3tiff.html<br>
-gs/tiff/html/man/TIFFReadScanline.3tiff.html<br>
-gs/tiff/html/man/TIFFReadTile.3tiff.html<br>
-gs/tiff/html/man/TIFFSetDirectory.3tiff.html<br>
-gs/tiff/html/man/TIFFSetField.3tiff.html<br>
-gs/tiff/html/man/TIFFWarning.3tiff.html<br>
-gs/tiff/html/man/TIFFWriteDirectory.3tiff.html<br>
-gs/tiff/html/man/TIFFWriteEncodedStrip.3tiff.html<br>
-gs/tiff/html/man/TIFFWriteEncodedTile.3tiff.html<br>
-gs/tiff/html/man/TIFFWriteRawStrip.3tiff.html<br>
-gs/tiff/html/man/TIFFWriteRawTile.3tiff.html<br>
-gs/tiff/html/man/TIFFWriteScanline.3tiff.html<br>
-gs/tiff/html/man/TIFFWriteTile.3tiff.html<br>
-gs/tiff/html/man/TIFFbuffer.3tiff.html<br>
-gs/tiff/html/man/TIFFcodec.3tiff.html<br>
-gs/tiff/html/man/TIFFcolor.3tiff.html<br>
-gs/tiff/html/man/TIFFmemory.3tiff.html<br>
-gs/tiff/html/man/TIFFquery.3tiff.html<br>
-gs/tiff/html/man/TIFFsize.3tiff.html<br>
-gs/tiff/html/man/TIFFstrip.3tiff.html<br>
-gs/tiff/html/man/TIFFswab.3tiff.html<br>
-gs/tiff/html/man/TIFFtile.3tiff.html<br>
-gs/tiff/html/man/fax2ps.1.html<br>
-gs/tiff/html/man/fax2tiff.1.html<br>
-gs/tiff/html/man/gif2tiff.1.html<br>
-gs/tiff/html/man/libtiff.3tiff.html<br>
-gs/tiff/html/man/pal2rgb.1.html<br>
-gs/tiff/html/man/ppm2tiff.1.html<br>
-gs/tiff/html/man/ras2tiff.1.html<br>
-gs/tiff/html/man/raw2tiff.1.html<br>
-gs/tiff/html/man/rgb2ycbcr.1.html<br>
-gs/tiff/html/man/sgi2tiff.1.html<br>
-gs/tiff/html/man/thumbnail.1.html<br>
-gs/tiff/html/man/tiff2bw.1.html<br>
-gs/tiff/html/man/tiff2pdf.1.html<br>
-gs/tiff/html/man/tiff2ps.1.html<br>
-gs/tiff/html/man/tiff2rgba.1.html<br>
-gs/tiff/html/man/tiffcmp.1.html<br>
-gs/tiff/html/man/tiffcp.1.html<br>
-gs/tiff/html/man/tiffcrop.1.html<br>
-gs/tiff/html/man/tiffdither.1.html<br>
-gs/tiff/html/man/tiffdump.1.html<br>
-gs/tiff/html/man/tiffgt.1.html<br>
-gs/tiff/html/man/tiffinfo.1.html<br>
-gs/tiff/html/man/tiffmedian.1.html<br>
-gs/tiff/html/man/tiffset.1.html<br>
-gs/tiff/html/man/tiffsplit.1.html<br>
-gs/tiff/html/man/tiffsv.1.html<br>
-gs/tiff/html/tools.html<br>
-gs/tiff/html/v3.9.0beta.html<br>
-gs/tiff/html/v3.9.1.html<br>
-gs/tiff/html/v3.9.2.html<br>
-gs/tiff/html/v4.0.0.html<br>
-gs/tiff/libtiff-4.pc.in<br>
-gs/tiff/libtiff/Makefile.am<br>
-gs/tiff/libtiff/Makefile.in<br>
-gs/tiff/libtiff/Makefile.vc<br>
-gs/tiff/libtiff/libtiff.def<br>
-gs/tiff/libtiff/libtiff.map<br>
-gs/tiff/libtiff/libtiffxx.map<br>
-gs/tiff/libtiff/mkg3states.c<br>
-gs/tiff/libtiff/oog_table.h<br>
-gs/tiff/libtiff/t4.h<br>
-gs/tiff/libtiff/tif_acorn.c<br>
-gs/tiff/libtiff/tif_apple.c<br>
-gs/tiff/libtiff/tif_atari.c<br>
-gs/tiff/libtiff/tif_aux.c<br>
-gs/tiff/libtiff/tif_close.c<br>
-gs/tiff/libtiff/tif_codec.c<br>
-gs/tiff/libtiff/tif_color.c<br>
-gs/tiff/libtiff/tif_compress.c<br>
-gs/tiff/libtiff/tif_config.h.in<br>
-gs/tiff/libtiff/tif_config.vc.h<br>
-gs/tiff/libtiff/tif_config.wince.h<br>
-gs/tiff/libtiff/tif_dir.c<br>
-gs/tiff/libtiff/tif_dir.h<br>
-gs/tiff/libtiff/tif_dirinfo.c<br>
-gs/tiff/libtiff/tif_dirread.c<br>
-gs/tiff/libtiff/tif_dirwrite.c<br>
-gs/tiff/libtiff/tif_dumpmode.c<br>
-gs/tiff/libtiff/tif_error.c<br>
-gs/tiff/libtiff/tif_extension.c<br>
-gs/tiff/libtiff/tif_fax3.c<br>
-gs/tiff/libtiff/tif_fax3.h<br>
-gs/tiff/libtiff/tif_fax3sm.c<br>
-gs/tiff/libtiff/tif_flush.c<br>
-gs/tiff/libtiff/tif_getimage.c<br>
-gs/tiff/libtiff/tif_jbig.c<br>
-gs/tiff/libtiff/tif_jpeg.c<br>
-gs/tiff/libtiff/tif_jpeg_12.c<br>
-gs/tiff/libtiff/tif_luv.c<br>
-gs/tiff/libtiff/tif_lzma.c<br>
-gs/tiff/libtiff/tif_lzw.c<br>
-gs/tiff/libtiff/tif_msdos.c<br>
-gs/tiff/libtiff/tif_next.c<br>
-gs/tiff/libtiff/tif_ojpeg.c<br>
-gs/tiff/libtiff/tif_open.c<br>
-gs/tiff/libtiff/tif_packbits.c<br>
-gs/tiff/libtiff/tif_pixarlog.c<br>
-gs/tiff/libtiff/tif_predict.c<br>
-gs/tiff/libtiff/tif_predict.h<br>
-gs/tiff/libtiff/tif_print.c<br>
-gs/tiff/libtiff/tif_read.c<br>
-gs/tiff/libtiff/tif_stream.cxx<br>
-gs/tiff/libtiff/tif_strip.c<br>
-gs/tiff/libtiff/tif_swab.c<br>
-gs/tiff/libtiff/tif_thunder.c<br>
-gs/tiff/libtiff/tif_tile.c<br>
-gs/tiff/libtiff/tif_unix.c<br>
-gs/tiff/libtiff/tif_version.c<br>
-gs/tiff/libtiff/tif_warning.c<br>
-gs/tiff/libtiff/tif_win3.c<br>
-gs/tiff/libtiff/tif_win32.c<br>
-gs/tiff/libtiff/tif_write.c<br>
-gs/tiff/libtiff/tif_zip.c<br>
-gs/tiff/libtiff/tiff.h<br>
-gs/tiff/libtiff/tiffconf.h.in<br>
-gs/tiff/libtiff/tiffconf.vc.h<br>
-gs/tiff/libtiff/tiffconf.wince.h<br>
-gs/tiff/libtiff/tiffio.h<br>
-gs/tiff/libtiff/tiffio.hxx<br>
-gs/tiff/libtiff/tiffiop.h<br>
-gs/tiff/libtiff/tiffvers.h<br>
-gs/tiff/libtiff/uvcode.h<br>
-gs/tiff/m4/acinclude.m4<br>
-gs/tiff/m4/libtool.m4<br>
-gs/tiff/m4/ltoptions.m4<br>
-gs/tiff/m4/ltversion.m4<br>
-gs/tiff/m4/lt~obsolete.m4<br>
-gs/tiff/man/Makefile.in<br>
-gs/tiff/man/TIFFClose.3tiff<br>
-gs/tiff/man/TIFFDataWidth.3tiff<br>
-gs/tiff/man/TIFFError.3tiff<br>
-gs/tiff/man/TIFFFlush.3tiff<br>
-gs/tiff/man/TIFFGetField.3tiff<br>
-gs/tiff/man/TIFFOpen.3tiff<br>
-gs/tiff/man/TIFFPrintDirectory.3tiff<br>
-gs/tiff/man/TIFFRGBAImage.3tiff<br>
-gs/tiff/man/TIFFReadDirectory.3tiff<br>
-gs/tiff/man/TIFFReadEncodedStrip.3tiff<br>
-gs/tiff/man/TIFFReadEncodedTile.3tiff<br>
-gs/tiff/man/TIFFReadRGBAImage.3tiff<br>
-gs/tiff/man/TIFFReadRGBAStrip.3tiff<br>
-gs/tiff/man/TIFFReadRGBATile.3tiff<br>
-gs/tiff/man/TIFFReadRawStrip.3tiff<br>
-gs/tiff/man/TIFFReadRawTile.3tiff<br>
-gs/tiff/man/TIFFReadScanline.3tiff<br>
-gs/tiff/man/TIFFReadTile.3tiff<br>
-gs/tiff/man/TIFFSetDirectory.3tiff<br>
-gs/tiff/man/TIFFSetField.3tiff<br>
-gs/tiff/man/TIFFWarning.3tiff<br>
-gs/tiff/man/TIFFWriteDirectory.3tiff<br>
-gs/tiff/man/TIFFWriteEncodedStrip.3tiff<br>
-gs/tiff/man/TIFFWriteEncodedTile.3tiff<br>
-gs/tiff/man/TIFFWriteRawStrip.3tiff<br>
-gs/tiff/man/TIFFWriteRawTile.3tiff<br>
-gs/tiff/man/TIFFWriteScanline.3tiff<br>
-gs/tiff/man/TIFFWriteTile.3tiff<br>
-gs/tiff/man/TIFFbuffer.3tiff<br>
-gs/tiff/man/TIFFcodec.3tiff<br>
-gs/tiff/man/TIFFcolor.3tiff<br>
-gs/tiff/man/TIFFmemory.3tiff<br>
-gs/tiff/man/TIFFquery.3tiff<br>
-gs/tiff/man/TIFFsize.3tiff<br>
-gs/tiff/man/TIFFstrip.3tiff<br>
-gs/tiff/man/TIFFswab.3tiff<br>
-gs/tiff/man/TIFFtile.3tiff<br>
-gs/tiff/man/bmp2tiff.1<br>
-gs/tiff/man/fax2ps.1<br>
-gs/tiff/man/fax2tiff.1<br>
-gs/tiff/man/gif2tiff.1<br>
-gs/tiff/man/libtiff.3tiff<br>
-gs/tiff/man/pal2rgb.1<br>
-gs/tiff/man/ppm2tiff.1<br>
-gs/tiff/man/ras2tiff.1<br>
-gs/tiff/man/raw2tiff.1<br>
-gs/tiff/man/rgb2ycbcr.1<br>
-gs/tiff/man/sgi2tiff.1<br>
-gs/tiff/man/thumbnail.1<br>
-gs/tiff/man/tiff2bw.1<br>
-gs/tiff/man/tiff2pdf.1<br>
-gs/tiff/man/tiff2ps.1<br>
-gs/tiff/man/tiff2rgba.1<br>
-gs/tiff/man/tiffcmp.1<br>
-gs/tiff/man/tiffcp.1<br>
-gs/tiff/man/tiffcrop.1<br>
-gs/tiff/man/tiffdither.1<br>
-gs/tiff/man/tiffdump.1<br>
-gs/tiff/man/tiffgt.1<br>
-gs/tiff/man/tiffinfo.1<br>
-gs/tiff/man/tiffmedian.1<br>
-gs/tiff/man/tiffset.1<br>
-gs/tiff/man/tiffsplit.1<br>
-gs/tiff/man/tiffsv.1<br>
-gs/tiff/port/Makefile.am<br>
-gs/tiff/port/Makefile.in<br>
-gs/tiff/port/dummy.c<br>
-gs/tiff/port/getopt.c<br>
-gs/tiff/port/libport.h<br>
-gs/tiff/port/strcasecmp.c<br>
-gs/tiff/port/strtoull.c<br>
-gs/tiff/test/Makefile.am<br>
-gs/tiff/test/Makefile.in<br>
-gs/tiff/test/ascii_tag.c<br>
-gs/tiff/test/bmp2tiff_palette.sh<br>
-gs/tiff/test/bmp2tiff_rgb.sh<br>
-gs/tiff/test/check_tag.c<br>
-gs/tiff/test/common.sh<br>
-gs/tiff/test/gif2tiff.sh<br>
-gs/tiff/test/images/README.txt<br>
-gs/tiff/test/images/logluv-3c-16b.tiff<br>
-gs/tiff/test/images/minisblack-1c-16b.tiff<br>
-gs/tiff/test/images/minisblack-1c-8b.pgm<br>
-gs/tiff/test/images/minisblack-1c-8b.tiff<br>
-gs/tiff/test/images/minisblack-2c-8b-alpha.tiff<br>
-gs/tiff/test/images/miniswhite-1c-1b.pbm<br>
-gs/tiff/test/images/miniswhite-1c-1b.tiff<br>
-gs/tiff/test/images/palette-1c-1b.tiff<br>
-gs/tiff/test/images/palette-1c-4b.tiff<br>
-gs/tiff/test/images/palette-1c-8b.bmp<br>
-gs/tiff/test/images/palette-1c-8b.gif<br>
-gs/tiff/test/images/palette-1c-8b.tiff<br>
-gs/tiff/test/images/rgb-3c-16b.tiff<br>
-gs/tiff/test/images/rgb-3c-8b.bmp<br>
-gs/tiff/test/images/rgb-3c-8b.ppm<br>
-gs/tiff/test/images/rgb-3c-8b.tiff<br>
-gs/tiff/test/long_tag.c<br>
-gs/tiff/test/ppm2tiff_pbm.sh<br>
-gs/tiff/test/ppm2tiff_pgm.sh<br>
-gs/tiff/test/ppm2tiff_ppm.sh<br>
-gs/tiff/test/rewrite_tag.c<br>
-gs/tiff/test/short_tag.c<br>
-gs/tiff/test/strip.c<br>
-gs/tiff/test/strip_rw.c<br>
-gs/tiff/test/tiff2pdf.sh<br>
-gs/tiff/test/tiff2ps-EPS1.sh<br>
-gs/tiff/test/tiff2ps-PS1.sh<br>
-gs/tiff/test/tiff2ps-PS2.sh<br>
-gs/tiff/test/tiff2ps-PS3.sh<br>
-gs/tiff/test/tiff2rgba-logluv-3c-16b.sh<br>
-gs/tiff/test/tiff2rgba-minisblack-1c-16b.sh<br>
-gs/tiff/test/tiff2rgba-minisblack-1c-8b.sh<br>
-gs/tiff/test/tiff2rgba-minisblack-2c-8b-alpha.sh<br>
-gs/tiff/test/tiff2rgba-miniswhite-1c-1b.sh<br>
-gs/tiff/test/tiff2rgba-palette-1c-1b.sh<br>
-gs/tiff/test/tiff2rgba-palette-1c-4b.sh<br>
-gs/tiff/test/tiff2rgba-palette-1c-8b.sh<br>
-gs/tiff/test/tiff2rgba-rgb-3c-16b.sh<br>
-gs/tiff/test/tiff2rgba-rgb-3c-8b.sh<br>
-gs/tiff/test/tiffcp-g3-1d-fill.sh<br>
-gs/tiff/test/tiffcp-g3-1d.sh<br>
-gs/tiff/test/tiffcp-g3-2d-fill.sh<br>
-gs/tiff/test/tiffcp-g3-2d.sh<br>
-gs/tiff/test/tiffcp-g3.sh<br>
-gs/tiff/test/tiffcp-g4.sh<br>
-gs/tiff/test/tiffcp-logluv.sh<br>
-gs/tiff/test/tiffcp-split-join.sh<br>
-gs/tiff/test/tiffcp-split.sh<br>
-gs/tiff/test/tiffcp-thumbnail.sh<br>
-gs/tiff/test/tiffcrop-R90-logluv-3c-16b.sh<br>
-gs/tiff/test/tiffcrop-R90-minisblack-1c-16b.sh<br>
-gs/tiff/test/tiffcrop-R90-minisblack-1c-8b.sh<br>
-gs/tiff/test/tiffcrop-R90-minisblack-2c-8b-alpha.sh<br>
-gs/tiff/test/tiffcrop-R90-miniswhite-1c-1b.sh<br>
-gs/tiff/test/tiffcrop-R90-palette-1c-1b.sh<br>
-gs/tiff/test/tiffcrop-R90-palette-1c-4b.sh<br>
-gs/tiff/test/tiffcrop-R90-palette-1c-8b.sh<br>
-gs/tiff/test/tiffcrop-R90-rgb-3c-16b.sh<br>
-gs/tiff/test/tiffcrop-R90-rgb-3c-8b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-logluv-3c-16b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-minisblack-1c-16b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-minisblack-1c-8b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-minisblack-2c-8b-alpha.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-miniswhite-1c-1b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-palette-1c-1b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-palette-1c-4b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-palette-1c-8b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-rgb-3c-16b.sh<br>
-gs/tiff/test/tiffcrop-doubleflip-rgb-3c-8b.sh<br>
-gs/tiff/test/tiffcrop-extract-logluv-3c-16b.sh<br>
-gs/tiff/test/tiffcrop-extract-minisblack-1c-16b.sh<br>
-gs/tiff/test/tiffcrop-extract-minisblack-1c-8b.sh<br>
-gs/tiff/test/tiffcrop-extract-minisblack-2c-8b-alpha.sh<br>
-gs/tiff/test/tiffcrop-extract-miniswhite-1c-1b.sh<br>
-gs/tiff/test/tiffcrop-extract-palette-1c-1b.sh<br>
-gs/tiff/test/tiffcrop-extract-palette-1c-4b.sh<br>
-gs/tiff/test/tiffcrop-extract-palette-1c-8b.sh<br>
-gs/tiff/test/tiffcrop-extract-rgb-3c-16b.sh<br>
-gs/tiff/test/tiffcrop-extract-rgb-3c-8b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-logluv-3c-16b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-minisblack-1c-16b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-minisblack-1c-8b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-minisblack-2c-8b-alpha.sh<br>
-gs/tiff/test/tiffcrop-extractz14-miniswhite-1c-1b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-palette-1c-1b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-palette-1c-4b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-palette-1c-8b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-rgb-3c-16b.sh<br>
-gs/tiff/test/tiffcrop-extractz14-rgb-3c-8b.sh<br>
-gs/tiff/test/tiffdump.sh<br>
-gs/tiff/test/tiffinfo.sh<br>
-gs/tiff/test/tifftest.h<br>
-gs/tiff/tools/Makefile.am<br>
-gs/tiff/tools/Makefile.in<br>
-gs/tiff/tools/Makefile.vc<br>
-gs/tiff/tools/bmp2tiff.c<br>
-gs/tiff/tools/fax2ps.c<br>
-gs/tiff/tools/fax2tiff.c<br>
-gs/tiff/tools/gif2tiff.c<br>
-gs/tiff/tools/pal2rgb.c<br>
-gs/tiff/tools/ppm2tiff.c<br>
-gs/tiff/tools/ras2tiff.c<br>
-gs/tiff/tools/rasterfile.h<br>
-gs/tiff/tools/raw2tiff.c<br>
-gs/tiff/tools/rgb2ycbcr.c<br>
-gs/tiff/tools/sgi2tiff.c<br>
-gs/tiff/tools/sgisv.c<br>
-gs/tiff/tools/thumbnail.c<br>
-gs/tiff/tools/tiff2bw.c<br>
-gs/tiff/tools/tiff2pdf.c<br>
-gs/tiff/tools/tiff2ps.c<br>
-gs/tiff/tools/tiff2rgba.c<br>
-gs/tiff/tools/tiffcmp.c<br>
-gs/tiff/tools/tiffcp.c<br>
-gs/tiff/tools/tiffcrop.c<br>
-gs/tiff/tools/tiffdither.c<br>
-gs/tiff/tools/tiffdump.c<br>
-gs/tiff/tools/tiffgt.c<br>
-gs/tiff/tools/tiffinfo.c<br>
-gs/tiff/tools/tiffmedian.c<br>
-gs/tiff/tools/tiffset.c<br>
-gs/tiff/tools/tiffsplit.c<br>
-gs/tiff/tools/ycbcr.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-09 01:16:35 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=63a26299f47bb9931a2b47772c95c38594535041">63a26299f47bb9931a2b47772c95c38594535041</a>
-<blockquote>
-<p>
- Update the example build line given at the top of bmpcmp.c<br>
-<br>
-gs/toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-07 17:21: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=3cb19e101513e8fa99f86e959a493d7d57b9a69a">3cb19e101513e8fa99f86e959a493d7d57b9a69a</a>
-<blockquote>
-<p>
- Indentation fixes, plus avoid SEGVs in low memory cases.<br>
-<br>
- If allocations fail, spot that and return an error rather than<br>
- dereferencing NULL pointers.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-08 15:51: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=e0fd2c6fe5cdba60e0252993319408ce8962afd3">e0fd2c6fe5cdba60e0252993319408ce8962afd3</a>
-<blockquote>
-<p>
- Enable Memento to be used with jbig2dec<br>
-<br>
- ./configure as usual, then &quot;make XCFLAGS=-DMEMENTO&quot;.<br>
-<br>
- This involves duplicating memento within jbig2dec. We disable the GS<br>
- specific build hacks, and add just one more; if GSBUILD is defined<br>
- then jbig2 uses the version of memento from base, rather than the version<br>
- of memento from inside jbig2. This avoids any potential problems with<br>
- version skew.<br>
-<br>
-gs/base/jbig2.mak<br>
-gs/jbig2dec/Makefile.in<br>
-gs/jbig2dec/jbig2.h<br>
-gs/jbig2dec/memento.c<br>
-gs/jbig2dec/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-08 13:02: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=d7d86ee955e58d18f4ff3071c0f41c4e3f75aaea">d7d86ee955e58d18f4ff3071c0f41c4e3f75aaea</a>
-<blockquote>
-<p>
- Update libpng to version 1.5.10<br>
-<br>
- Minor build revisions to deal with new libpng version:<br>
-<br>
- We copy the predefined pnglibconf.h into the build directory, and have<br>
- libpng include it from there (it's less invasive than running the libpng<br>
- configure script).<br>
-<br>
- We have to use the same kind of compiler incantation as lcms.mak because<br>
- libpng 1.5.x suffers compatibility problems with /Za in Visual Studio<br>
- as lcms does.<br>
-<br>
- Minor revision to XPS png reading code to cope with libpng 1.5.x API:<br>
-<br>
- Primarily, the 1.5.x API has made the png_info data type opaque to the calling<br>
- code, so all access to the it contains *must* be done through function calls.<br>
-<br>
- No cluster differences expected.<br>
-<br>
-gs/base/png.mak<br>
-gs/libpng/ANNOUNCE<br>
-gs/libpng/CHANGES<br>
-gs/libpng/CMakeLists.txt<br>
-gs/libpng/INSTALL<br>
-gs/libpng/KNOWNBUG<br>
-gs/libpng/LICENSE<br>
-gs/libpng/Makefile.am<br>
-gs/libpng/Makefile.in<br>
-gs/libpng/README<br>
-gs/libpng/TODO<br>
-gs/libpng/Y2KINFO<br>
-gs/libpng/aclocal.m4<br>
-gs/libpng/arm/filter_neon.S<br>
-gs/libpng/autogen.sh<br>
-gs/libpng/config.guess<br>
-gs/libpng/config.h.in<br>
-gs/libpng/config.sub<br>
-gs/libpng/configure<br>
-gs/libpng/configure.ac<br>
-gs/libpng/contrib/README.txt<br>
-gs/libpng/contrib/gregbook/COPYING<br>
-gs/libpng/contrib/gregbook/Makefile.sgi<br>
-gs/libpng/contrib/gregbook/Makefile.unx<br>
-gs/libpng/contrib/gregbook/Makefile.w32<br>
-gs/libpng/contrib/gregbook/README<br>
-gs/libpng/contrib/gregbook/makevms.com<br>
-gs/libpng/contrib/gregbook/readpng.c<br>
-gs/libpng/contrib/gregbook/readpng2.c<br>
-gs/libpng/contrib/gregbook/readpng2.h<br>
-gs/libpng/contrib/gregbook/rpng-win.c<br>
-gs/libpng/contrib/gregbook/rpng-x.c<br>
-gs/libpng/contrib/gregbook/rpng2-win.c<br>
-gs/libpng/contrib/gregbook/rpng2-x.c<br>
-gs/libpng/contrib/gregbook/writepng.c<br>
-gs/libpng/contrib/libtests/pngvalid.c<br>
-gs/libpng/contrib/pngminim/README<br>
-gs/libpng/contrib/pngminim/decoder/README<br>
-gs/libpng/contrib/pngminim/decoder/gather.sh<br>
-gs/libpng/contrib/pngminim/decoder/makefile<br>
-gs/libpng/contrib/pngminim/decoder/pngusr.dfa<br>
-gs/libpng/contrib/pngminim/decoder/pngusr.h<br>
-gs/libpng/contrib/pngminim/encoder/README<br>
-gs/libpng/contrib/pngminim/encoder/dummy_inflate.c<br>
-gs/libpng/contrib/pngminim/encoder/gather.sh<br>
-gs/libpng/contrib/pngminim/encoder/makefile<br>
-gs/libpng/contrib/pngminim/encoder/pngusr.dfa<br>
-gs/libpng/contrib/pngminim/encoder/pngusr.h<br>
-gs/libpng/contrib/pngminim/preader/README<br>
-gs/libpng/contrib/pngminim/preader/gather.sh<br>
-gs/libpng/contrib/pngminim/preader/makefile<br>
-gs/libpng/contrib/pngminim/preader/pngusr.dfa<br>
-gs/libpng/contrib/pngminim/preader/pngusr.h<br>
-gs/libpng/contrib/pngminus/makefile.std<br>
-gs/libpng/contrib/pngminus/png2pnm.c<br>
-gs/libpng/contrib/pngsuite/README<br>
-gs/libpng/contrib/pngsuite/ftbbn1g04.png<br>
-gs/libpng/contrib/pngsuite/ftbbn2c16.png<br>
-gs/libpng/contrib/pngsuite/ftbbn3p08.png<br>
-gs/libpng/contrib/pngsuite/ftbgn2c16.png<br>
-gs/libpng/contrib/pngsuite/ftbgn3p08.png<br>
-gs/libpng/contrib/pngsuite/ftbrn2c08.png<br>
-gs/libpng/contrib/pngsuite/ftbwn1g16.png<br>
-gs/libpng/contrib/pngsuite/ftbwn3p08.png<br>
-gs/libpng/contrib/pngsuite/ftbyn3p08.png<br>
-gs/libpng/contrib/pngsuite/ftp0n1g08.png<br>
-gs/libpng/contrib/pngsuite/ftp0n2c08.png<br>
-gs/libpng/contrib/pngsuite/ftp0n3p08.png<br>
-gs/libpng/contrib/pngsuite/ftp1n3p08.png<br>
-gs/libpng/contrib/visupng/PngFile.c<br>
-gs/libpng/contrib/visupng/PngFile.h<br>
-gs/libpng/contrib/visupng/README.txt<br>
-gs/libpng/contrib/visupng/VisualPng.c<br>
-gs/libpng/contrib/visupng/VisualPng.dsp<br>
-gs/libpng/contrib/visupng/resource.h<br>
-gs/libpng/depcomp<br>
-gs/libpng/example.c<br>
-gs/libpng/install-sh<br>
-gs/libpng/libpng-1.2.42.txt<br>
-gs/libpng/libpng-1.2.44.txt<br>
-gs/libpng/libpng-config.in<br>
-gs/libpng/libpng-manual.txt<br>
-gs/libpng/libpng.3<br>
-gs/libpng/libpng.pc.in<br>
-gs/libpng/libpngpf.3<br>
-gs/libpng/ltmain.sh<br>
-gs/libpng/mkinstalldirs<br>
-gs/libpng/png.5<br>
-gs/libpng/png.c<br>
-gs/libpng/png.h<br>
-gs/libpng/pngconf.h<br>
-gs/libpng/pngdebug.h<br>
-gs/libpng/pngerror.c<br>
-gs/libpng/pnggccrd.c<br>
-gs/libpng/pngget.c<br>
-gs/libpng/pnginfo.h<br>
-gs/libpng/pngmem.c<br>
-gs/libpng/pngpread.c<br>
-gs/libpng/pngpriv.h<br>
-gs/libpng/pngread.c<br>
-gs/libpng/pngrio.c<br>
-gs/libpng/pngrtran.c<br>
-gs/libpng/pngrutil.c<br>
-gs/libpng/pngset.c<br>
-gs/libpng/pngstruct.h<br>
-gs/libpng/pngtest.c<br>
-gs/libpng/pngtest.png<br>
-gs/libpng/pngtrans.c<br>
-gs/libpng/pngusr.dfa<br>
-gs/libpng/pngvcrd.c<br>
-gs/libpng/pngwio.c<br>
-gs/libpng/pngwrite.c<br>
-gs/libpng/pngwtran.c<br>
-gs/libpng/pngwutil.c<br>
-gs/libpng/projects/beos/x86-shared.proj<br>
-gs/libpng/projects/beos/x86-shared.txt<br>
-gs/libpng/projects/beos/x86-static.proj<br>
-gs/libpng/projects/beos/x86-static.txt<br>
-gs/libpng/projects/cbuilder5/libpng.bpf<br>
-gs/libpng/projects/cbuilder5/libpng.bpg<br>
-gs/libpng/projects/cbuilder5/libpng.bpr<br>
-gs/libpng/projects/cbuilder5/libpng.cpp<br>
-gs/libpng/projects/cbuilder5/libpng.readme.txt<br>
-gs/libpng/projects/cbuilder5/libpngstat.bpf<br>
-gs/libpng/projects/cbuilder5/libpngstat.bpr<br>
-gs/libpng/projects/cbuilder5/zlib.readme.txt<br>
-gs/libpng/projects/netware.txt<br>
-gs/libpng/projects/owatcom/libpng.tgt<br>
-gs/libpng/projects/owatcom/libpng.wpj<br>
-gs/libpng/projects/owatcom/pngconfig.mak<br>
-gs/libpng/projects/owatcom/pngtest.tgt<br>
-gs/libpng/projects/owatcom/pngvalid.tgt<br>
-gs/libpng/projects/visualc6/README.txt<br>
-gs/libpng/projects/visualc6/libpng.dsp<br>
-gs/libpng/projects/visualc6/libpng.dsw<br>
-gs/libpng/projects/visualc6/pngtest.dsp<br>
-gs/libpng/projects/visualc71/PRJ0041.mak<br>
-gs/libpng/projects/visualc71/README.txt<br>
-gs/libpng/projects/visualc71/README_zlib.txt<br>
-gs/libpng/projects/visualc71/libpng.sln<br>
-gs/libpng/projects/visualc71/libpng.vcproj<br>
-gs/libpng/projects/visualc71/pngtest.vcproj<br>
-gs/libpng/projects/visualc71/zlib.vcproj<br>
-gs/libpng/projects/vstudio/libpng/libpng.vcxproj<br>
-gs/libpng/projects/vstudio/pnglibconf/pnglibconf.vcxproj<br>
-gs/libpng/projects/vstudio/pngtest/pngtest.vcxproj<br>
-gs/libpng/projects/vstudio/pngvalid/pngvalid.vcxproj<br>
-gs/libpng/projects/vstudio/readme.txt<br>
-gs/libpng/projects/vstudio/vstudio.sln<br>
-gs/libpng/projects/vstudio/zlib.props<br>
-gs/libpng/projects/vstudio/zlib/zlib.vcxproj<br>
-gs/libpng/projects/wince.txt<br>
-gs/libpng/projects/xcode/Info.plist<br>
-gs/libpng/projects/xcode/libpng.xcodeproj/.gitignore<br>
-gs/libpng/projects/xcode/libpng.xcodeproj/project.pbxproj<br>
-gs/libpng/scripts/README.txt<br>
-gs/libpng/scripts/checksym.awk<br>
-gs/libpng/scripts/chkfmt<br>
-gs/libpng/scripts/def.dfn<br>
-gs/libpng/scripts/descrip.mms<br>
-gs/libpng/scripts/libpng-config-head.in<br>
-gs/libpng/scripts/libpng-config.in<br>
-gs/libpng/scripts/libpng.icc<br>
-gs/libpng/scripts/libpng.pc-configure.in<br>
-gs/libpng/scripts/libpng.pc.in<br>
-gs/libpng/scripts/makefile.32sunu<br>
-gs/libpng/scripts/makefile.64sunu<br>
-gs/libpng/scripts/makefile.acorn<br>
-gs/libpng/scripts/makefile.aix<br>
-gs/libpng/scripts/makefile.amiga<br>
-gs/libpng/scripts/makefile.atari<br>
-gs/libpng/scripts/makefile.bc32<br>
-gs/libpng/scripts/makefile.beos<br>
-gs/libpng/scripts/makefile.bor<br>
-gs/libpng/scripts/makefile.cegcc<br>
-gs/libpng/scripts/makefile.cygwin<br>
-gs/libpng/scripts/makefile.darwin<br>
-gs/libpng/scripts/makefile.dec<br>
-gs/libpng/scripts/makefile.dj2<br>
-gs/libpng/scripts/makefile.elf<br>
-gs/libpng/scripts/makefile.freebsd<br>
-gs/libpng/scripts/makefile.gcc<br>
-gs/libpng/scripts/makefile.gcmmx<br>
-gs/libpng/scripts/makefile.hp64<br>
-gs/libpng/scripts/makefile.hpgcc<br>
-gs/libpng/scripts/makefile.hpux<br>
-gs/libpng/scripts/makefile.ibmc<br>
-gs/libpng/scripts/makefile.intel<br>
-gs/libpng/scripts/makefile.knr<br>
-gs/libpng/scripts/makefile.linux<br>
-gs/libpng/scripts/makefile.mingw<br>
-gs/libpng/scripts/makefile.mips<br>
-gs/libpng/scripts/makefile.msc<br>
-gs/libpng/scripts/makefile.ne12bsd<br>
-gs/libpng/scripts/makefile.netbsd<br>
-gs/libpng/scripts/makefile.nommx<br>
-gs/libpng/scripts/makefile.openbsd<br>
-gs/libpng/scripts/makefile.os2<br>
-gs/libpng/scripts/makefile.sco<br>
-gs/libpng/scripts/makefile.sggcc<br>
-gs/libpng/scripts/makefile.sgi<br>
-gs/libpng/scripts/makefile.so9<br>
-gs/libpng/scripts/makefile.solaris<br>
-gs/libpng/scripts/makefile.solaris-x86<br>
-gs/libpng/scripts/makefile.std<br>
-gs/libpng/scripts/makefile.sunos<br>
-gs/libpng/scripts/makefile.tc3<br>
-gs/libpng/scripts/makefile.vcawin32<br>
-gs/libpng/scripts/makefile.vcwin32<br>
-gs/libpng/scripts/makefile.watcom<br>
-gs/libpng/scripts/makevms.com<br>
-gs/libpng/scripts/options.awk<br>
-gs/libpng/scripts/png32ce.def<br>
-gs/libpng/scripts/pnglibconf.dfa<br>
-gs/libpng/scripts/pnglibconf.h.prebuilt<br>
-gs/libpng/scripts/pnglibconf.mak<br>
-gs/libpng/scripts/pngos2.def<br>
-gs/libpng/scripts/pngw32.def<br>
-gs/libpng/scripts/pngw32.rc<br>
-gs/libpng/scripts/pngwin.rc<br>
-gs/libpng/scripts/smakefile.ppc<br>
-gs/libpng/scripts/sym.dfn<br>
-gs/libpng/scripts/symbols.def<br>
-gs/libpng/scripts/symbols.dfn<br>
-gs/libpng/scripts/vers.dfn<br>
-gs/libpng/test-pngtest.sh<br>
-gs/libpng/test-pngvalid-full.sh<br>
-gs/libpng/test-pngvalid-simple.sh<br>
-xps/xpspng.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-08 13:21:44 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a85db51fecf74ba66bada63afece1799d58681ce">a85db51fecf74ba66bada63afece1799d58681ce</a>
-<blockquote>
-<p>
- Update bmpcmp png reading to cope with 8bit grayscale pngs.<br>
-<br>
- This used to work, but became broken with the device n support (when I<br>
- stripped out the 8bpp operating modes)<br>
-<br>
-gs/toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-08 11:05: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=304d22a1744fa6ac07355703069cacd54f0c3ac4">304d22a1744fa6ac07355703069cacd54f0c3ac4</a>
-<blockquote>
-<p>
- Move 'HighLevelDevice' from pdfwrite to gdevvec.c so vector devices inherit it.<br>
-<br>
- The 'HighLevelDevice' parameter was only defined for pdfwrite/ps2write, here<br>
- we remove it from there and instead put it in the 'vector' device, so that<br>
- all deices based on the vector device will have the paramter set.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpdfb.h<br>
-gs/base/gdevpdfp.c<br>
-gs/base/gdevpdfx.h<br>
-gs/base/gdevvec.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-07 16:47:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c8138bc1db9b3627a2ba1047568c385568061d0">1c8138bc1db9b3627a2ba1047568c385568061d0</a>
-<blockquote>
-<p>
- pdfwrite - fix handling of transparent images from PDF interpreter<br>
-<br>
- The PDF interperter can insert extra groups when dealing with transparent<br>
- images, which we don't want to emit in the output PDF. These are marked<br>
- by a 'image_with_SMask' flag.<br>
-<br>
- Previously we stored a boolean in the device structure, and tested that, if<br>
- it was true we skipped the begin and transparency group operations.<br>
-<br>
- It turns out that it is possible to get a new group *inside* the generated<br>
- group we are skipping, if that happens then the second group would reset<br>
- the flag. This led to us skipping the 'begin' but not the 'end' with predictabley<br>
- bad consequences.<br>
-<br>
- In this commit we alter the boolena to an unsigned int, and treat it as a<br>
- series of bits. We flip the bits based on the 'FormDepth' which we track<br>
- separately. This allows up to 32 levels of nesting which ought to be enough<br>
- to deal even with Cairo files.<br>
-<br>
- Expected differences<br>
- Bug689897.pdf exhibits small differences, not visually apparent. I believe this<br>
- is a progression but its so slight as to be difficult to tell.<br>
-<br>
-gs/base/gdevpdft.c<br>
-gs/base/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-07 13:20:08 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=683bcefa2a8a05fb57d2d0d2d7aebf16de6bd11d">683bcefa2a8a05fb57d2d0d2d7aebf16de6bd11d</a>
-<blockquote>
-<p>
- Add new '--debug=gc-disable' flag to completely disable gc.<br>
-<br>
- Because I don't have any more hair to pull out.<br>
-<br>
-gs/base/gdbflags.h<br>
-gs/psi/interp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-06 23:02: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=eb4f815d9b21a42280acb7ad2447ce69577b4ae5">eb4f815d9b21a42280acb7ad2447ce69577b4ae5</a>
-<blockquote>
-<p>
- Fix pdf14_push_transparency_state stack handling.<br>
-<br>
- Rather than creating a new mask and adding it as the previous one,<br>
- we should be making the new mask the topmost one on the stack.<br>
-<br>
- This way pop and push correctly do the opposite thing.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-06 17:16:53 +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=6d24d5b9135f8ef6aa4da51a03952d5b39beb59a">6d24d5b9135f8ef6aa4da51a03952d5b39beb59a</a>
-<blockquote>
-<p>
- Bug 693050 : Fixes CERT reported issue labelled HeapError<br>
-<br>
-gs/jbig2dec/jbig2.c<br>
-gs/jbig2dec/jbig2_image.c<br>
-gs/jbig2dec/jbig2_metadata.c<br>
-gs/jbig2dec/jbig2_priv.h<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-gs/jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-06 10:48: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=a0c6b9f271d715f122c01fc0fbbfd8d6cdf9c372">a0c6b9f271d715f122c01fc0fbbfd8d6cdf9c372</a>
-<blockquote>
-<p>
- Bug 693002 (again): fix doc and example file install list<br>
-<br>
- There were a number of missing files from the Unix install targets for<br>
- the documentation and example files. Also, there were a few files in the<br>
- list which no longer exist.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/unixinst.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-06 09:23:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=07799bffd70992116da89ed4d1717ce441f71461">07799bffd70992116da89ed4d1717ce441f71461</a>
-<blockquote>
-<p>
- Bug 693094 related: missing libtiff build failure.<br>
-<br>
- If libtiff is missing, we correctly disabled the devices classified as<br>
- &quot;tiff devices&quot;, but left the &quot;fax devices&quot; in place, and the fax devices<br>
- depend on libtiff.<br>
-<br>
- We'll now disable *all* the libtiff dependent devices if libtiff is not found.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-06 09:38: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=cf75bee36e3a42f1bc253563a11169b47b92d307">cf75bee36e3a42f1bc253563a11169b47b92d307</a>
-<blockquote>
-<p>
- pdfwrite - don't write CIDSet for subset CIDFonts when emitting PDF/A-2<br>
-<br>
- The specification for CIDSet has changed for PDF/A-2 and I am currently<br>
- unable to create a CIDSet which the Acrobat pre-flught tool will validate.<br>
-<br>
- Since PDF/A-2 now makes CIDSet optional, this commit omits it when we are<br>
- producing PDF/A-2, so that we can create a valid file.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-05 17:44:16 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5fdae25deb3fa189f9d01a573fa77c2ec0f968ba">5fdae25deb3fa189f9d01a573fa77c2ec0f968ba</a>
-<blockquote>
-<p>
- Complete support for HPGL/2 new fill code, bug 692809.<br>
-<br>
- The new implementation which eliminates many unnecessary &quot;moveto's&quot;<br>
- resulted in unexpected improvements in several CET files where<br>
- creating a new subpath caused a join to be missing.<br>
-<br>
-pcl/pgdraw.c<br>
-pcl/pgdraw.h<br>
-pcl/pgpoly.c<br>
-pcl/pgvector.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-31 15:23:12 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d303c79851b02aa810525bdaa4751c8247b66912">d303c79851b02aa810525bdaa4751c8247b66912</a>
-<blockquote>
-<p>
- A new state variable added that indicates if a high level device is in use.<br>
-<br>
-pcl/pcstate.h<br>
-pcl/pctop.c<br>
-pl/plmain.c<br>
-pl/plmain.h<br>
-pl/pltop.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-19 16:53: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=8cbdd395e653227966a682b9b2de869565b49b5e">8cbdd395e653227966a682b9b2de869565b49b5e</a>
-<blockquote>
-<p>
- Fixes 693049 - incorrect ccitt raster output.<br>
-<br>
- The CCITT filter was initialized to an additive color space instead of<br>
- subtractive. Problem analyzed by Shailesh Mistry.<br>
-<br>
-pcl/rtraster.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-16 15:26:11 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=868eda64307dabd30e308e07962346ef5991d3e3">868eda64307dabd30e308e07962346ef5991d3e3</a>
-<blockquote>
-<p>
- Changes to support the new fill code which allows filling when the pen is up.<br>
-<br>
- With the graphics library implementation of the hpgl/2 style fill code<br>
- it is necessary to avoid unnecessary consecutive moveto's which were<br>
- harmless in the previous code. In particular, closepath works<br>
- differently if there are 2 or more consecutive moveto's. Using normal<br>
- PostScript style paths the closepath will return to the last moveto in<br>
- the path, the new code will convert a consecutive moveto to &quot;gapto&quot;<br>
- and retain the first moveto and closepath will return to the original<br>
- moveto.<br>
-<br>
-pcl/pgconfig.c<br>
-pcl/pgdraw.c<br>
-pcl/pglabel.c<br>
-pcl/pgpoly.c<br>
-pcl/pgvector.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-07 07:45:46 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c89c0b750594deac1b091776d18a9f0ed718ab60">c89c0b750594deac1b091776d18a9f0ed718ab60</a>
-<blockquote>
-<p>
- Debugging for dumping data from PCL commands that specify byte data<br>
- and a data length.<br>
-<br>
-pcl/pcparse.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-18 15:29:05 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3e81e6caf112d59e31c17924ee89d7f3abddd7b1">3e81e6caf112d59e31c17924ee89d7f3abddd7b1</a>
-<blockquote>
-<p>
- Fix bug 693034 -- correct comment in gxdevcl.h for GX_CINFO_UNKNOWN_SEP_LIN<br>
-<br>
-gs/base/gxdevcli.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-05 16:39:39 +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=54144189c8093c5c09d2f50d8cd57abc34ddd385">54144189c8093c5c09d2f50d8cd57abc34ddd385</a>
-<blockquote>
-<p>
- Bug 693025 : Correct memory leaks reported by Zeniko<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-05 09:48:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad53769b1d690e790750f01bd6420fb2b8b76279">ad53769b1d690e790750f01bd6420fb2b8b76279</a>
-<blockquote>
-<p>
- Bug 693088: fix romfs?.dev dependency typo<br>
-<br>
- The two romfs?.dev targets had ECHO_XE in their dependencies, and it shouldbe<br>
- ECHOGS_XE.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-04 17:02:46 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5b52e4534a2a7b9bc5d19a749df60e636ac4aa65">5b52e4534a2a7b9bc5d19a749df60e636ac4aa65</a>
-<blockquote>
-<p>
- Tweak filenames from RAW_DUMP debugging code.<br>
-<br>
- Output 2 digits before &quot;)&quot;.<br>
-<br>
- In multistage output, put 'a', 'b', 'c' etc after &quot;)&quot; to ensure<br>
- that they appear in alphasorted results in the same order as they<br>
- are produced.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gxblend.c<br>
-gs/base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-04 15:22: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=316a85cd0c7311716e85dc8f5ab32e36301e829c">316a85cd0c7311716e85dc8f5ab32e36301e829c</a>
-<blockquote>
-<p>
- pdfwrite - Make sure TT fonts in PDF files are named using the PDF font name<br>
-<br>
- Bug #693086<br>
-<br>
- The problem was that the TrueType code used by the PDF interpreter uses the<br>
- font name from the TrueType font, not the name from the PDF file. If two<br>
- subsets are present then pdfwrite is unable to distinguish them if the<br>
- Encodings are apparently the same (as they are here) as the fonts have have<br>
- the same name internally, even though they are different in the PDF.<br>
-<br>
- TrueType CIDFonts already take the font naem form the PDF file and apply that<br>
- so here we simply do the same for regular TrueType fonts.<br>
-<br>
- This causes a small difference in Bug689073.pdf, apparently becuase it<br>
- contains two fonts called Arial,Bold<br>
-<br>
-gs/Resource/Init/gs_ttf.ps<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-03 13:37:58 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6e24b063febdc3286015e94854cac156e70e2f1">a6e24b063febdc3286015e94854cac156e70e2f1</a>
-<blockquote>
-<p>
- Rename pdf_open_document() to pdfwrite_pdf_open_document() to avoid a<br>
- name conflict with mupdf.<br>
-<br>
-gs/base/gdevpdf.c<br>
-gs/base/gdevpdfp.c<br>
-gs/base/gdevpdfu.c<br>
-gs/base/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-01 11:50:32 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c7aeb590a7a435d746a9400a15f8392746ac53c4">c7aeb590a7a435d746a9400a15f8392746ac53c4</a>
-<blockquote>
-<p>
- Addition of capability for overprint simulation for CMYK colorants with RGB target device<br>
-<br>
- To have an RGB device do this simulation of CMYK overprinting you should have the device set<br>
- its opmode in color info from GX_CINFO_OPMODE_UNKNOWN to GX_CINFO_OPMODE_RGB. In addition,<br>
- to ensure consistent color in the document you should use the -dUseFastColor option since<br>
- simulated RGB overprinting uses unmanaged color transformations.<br>
-<br>
- The fix required the addition of a compositor parameter which was a k value to be make use<br>
- when we had K overprinting occurring.<br>
-<br>
- To port this fix to an earlier ghostscript release (pre-ICC) you will want to create a<br>
- gx_set_overprint_DeviceRGB procedure for the gs_color_space_type_DeviceRGB type. This will<br>
- be similar to gx_set_overprint_DeviceCMYK except it will end up calling gx_set_overprint_rgb<br>
- instead of gx_set_overprint_cmyk. See changes in gsicc.c.<br>
-<br>
-gs/base/gscdevn.c<br>
-gs/base/gscsepr.c<br>
-gs/base/gscspace.c<br>
-gs/base/gsicc.c<br>
-gs/base/gsovrc.c<br>
-gs/base/gsovrc.h<br>
-gs/base/gxcspace.h<br>
-gs/base/gxdevcli.h<br>
-gs/base/gxoprect.c<br>
-gs/base/gxoprect.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-01 20:11:09 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20e81025390c8487cb9794b37148f4bee9063bdc">20e81025390c8487cb9794b37148f4bee9063bdc</a>
-<blockquote>
-<p>
- Update RAW_DUMP_AS_PAM to cope with tag planes, and greyscale spaces.<br>
-<br>
-gs/base/gxblend.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-06-01 09:21:38 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1558100af4820b8718e7e346c3225d48eecf07c">b1558100af4820b8718e7e346c3225d48eecf07c</a>
-<blockquote>
-<p>
- Fix minor typo in German man page - Bug 693080<br>
-<br>
-gs/man/de/pdf2dsc.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-31 17:51:51 +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=9cddb4c193c6123140c6f7b1960db34025f86e40">9cddb4c193c6123140c6f7b1960db34025f86e40</a>
-<blockquote>
-<p>
- Bug 693025: Correct typos reported by Zeniko<br>
-<br>
-gs/jbig2dec/jbig2_huffman.c<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-31 14:43: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=da9b12c5056369c5593d5b3604e787052fdd2f13">da9b12c5056369c5593d5b3604e787052fdd2f13</a>
-<blockquote>
-<p>
- pdfwrite - properly mark cos_stream as closed when closing associated stream<br>
-<br>
- Bug #6930 &quot;Regression: /rangecheck in --pdfmark-- starting with 25b6a2cdeb5a90bb7803958f2bf15b618fbcf120&quot;<br>
-<br>
- Commit 25b6a2cdeb5a90bb7803958f2bf15b618fbcf120 was a little too<br>
- enthusiastic. In addition to properly closing the streams, I inadvertently<br>
- removed the code which marks the pdfwrite cos_stream object as closed when<br>
- we close the stream.<br>
-<br>
- Ordinarily this doesn't matter, but the pdfmark code checks to maek sure the<br>
- stream associated with a named object is closed when it is used, and the<br>
- removal of the code left it apparently open, causing the error.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpdti.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-31 10:59: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=33dda0841be40cc8da9f350d10749ce8f4142fb7">33dda0841be40cc8da9f350d10749ce8f4142fb7</a>
-<blockquote>
-<p>
- pdfwrite - memory problems, don't free dictionary parameter lists too early<br>
-<br>
- Bug #693069 &quot;Regression: lockup with pdfwrite&quot;<br>
-<br>
- The image dictioanry parameter lists for distillerparams were being freed<br>
- after they were added to the 'parent' parameter list. If the same memory<br>
- should then be reused for another parameter, the parent list would end up<br>
- with corrupted linked list pointers leading to a variety of problems<br>
- includign seg faults and loops.<br>
-<br>
- Although this appears as a regression its not really. The existing code only<br>
- worked by fluke, all that the offending commit did was change he memory<br>
- layout, triggering the problem.<br>
-<br>
- My initial feeling was that the c_param_write code should 'deep copy' dict<br>
- parameters, just as it does for other complex objects. However reviewing the<br>
- existing usage makes it clear that this is *not* what is done at present.<br>
-<br>
- Instead the list is simply inserted, and only freed when the parent list is<br>
- released. This seems to me to be poor design, because other complex types<br>
- are handled differntly, but that's the way it is. Copying the dictionary<br>
- would mean reviewing all the places that use it and modifying them. It<br>
- makes more sense to alter the pdfwrite code so that it doesn't release and<br>
- free the dictioanry list.<br>
-<br>
- Took the opportunity to refactor a few places in the code which use massive<br>
- 'if' clauses which call code. This construct is confusing and difficult to<br>
- debug.<br>
-<br>
- No expected differences<br>
-<br>
-gs/base/gdevpsdp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-30 17:42: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=c579ff60fd8f7a83d46a87ed0813536871c4d13e">c579ff60fd8f7a83d46a87ed0813536871c4d13e</a>
-<blockquote>
-<p>
- Bug 693050 : Fixes CERT reported issue labelled DestAvNearNull<br>
-<br>
-gs/jbig2dec/jbig2_image.c<br>
-gs/jbig2dec/jbig2_page.c<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-gs/jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-29 11:04:55 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9623d013b27cd25257fa21ddb7d2df9c75f3e52d">9623d013b27cd25257fa21ddb7d2df9c75f3e52d</a>
-<blockquote>
-<p>
- Fix for mistake in hashcode setting for CMM used with UseFastColor option<br>
-<br>
- Fixes bug 693036<br>
-<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_nocm.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-28 13:05:00 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f30e8944b915936befffbadc036e1de16659914e">f30e8944b915936befffbadc036e1de16659914e</a>
-<blockquote>
-<p>
- Add 16bpp support to downscaler.<br>
-<br>
- Currently unused, but passes local tests with James Cloos' proposed<br>
- psdcmyk16 and psdrgb16 devices.<br>
-<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevtsep.c<br>
-gs/base/gxdownscale.c<br>
-gs/base/gxdownscale.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-27 23:35:06 +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=c3c704eeab14e5d6401edd69867b06c812ce8f5a">c3c704eeab14e5d6401edd69867b06c812ce8f5a</a>
-<blockquote>
-<p>
- Bug 693050 : Fixes CERT reported issue labelled BranchAvNearNull<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-27 22:47: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=321055631457902050df08e645b0f91536cdd417">321055631457902050df08e645b0f91536cdd417</a>
-<blockquote>
-<p>
- Bug 693050 : Fixes CERT reported issue labelled BlockMoveAv<br>
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-27 21:43:27 +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=fb006f93c6fb6278a58886e0f72a5836c674ed22">fb006f93c6fb6278a58886e0f72a5836c674ed22</a>
-<blockquote>
-<p>
- Bug 693050 : Fixes CERT reported issue labelled SegFaultOnPc<br>
-<br>
-gs/jbig2dec/jbig2_generic.c<br>
-gs/jbig2dec/jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-26 09:07: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=13922518fea2f417ff2d2dfa153c95396616e8ae">13922518fea2f417ff2d2dfa153c95396616e8ae</a>
-<blockquote>
-<p>
- pdfwrite - remove unused variable to silence compiler warning<br>
-<br>
- Although the warning is flagged as new, I don't think it is, its just that<br>
- the variable declaration has moved to a new line as a result of a commit<br>
- and so it appears to be new.<br>
-<br>
- In any event, the variable is unused and has been removed.<br>
-<br>
-gs/base/gdevpsf1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-25 17:55: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=fad17657f6f583dbdef5a634d0f11dd79e446ffe">fad17657f6f583dbdef5a634d0f11dd79e446ffe</a>
-<blockquote>
-<p>
- Bug 693070: psdrgb wasn't giving corrupted output.<br>
-<br>
- There were actually 2 bugs in here. The first one was spotted and<br>
- fixed by James Cloos - many thanks; the arguments to memcpy were<br>
- reversed.<br>
-<br>
- The second one was to do with the fact that postscript operation<br>
- now thinks it has 14 colors. When we encode/decode, we were packing<br>
- the colors into a word in such a way that we were losing the interesting<br>
- ones off the top. Reverse the order of packing, and all is well.<br>
-<br>
- This still leaves an &quot;interesting&quot; fact about this device; we loop:<br>
-<br>
- for (chan_idx = 0; chan_idx &lt; num_comp; chan_idx++)<br>
- ...<br>
- for (j = 0; j &lt; xc-&gt;height; j++)<br>
- ...<br>
- get_bits_rectangle<br>
-<br>
- So, in the case where we have n components, and more than 1 band<br>
- we'll be rendering the entire file n times - despite the fact that<br>
- we request all the colors each time!<br>
-<br>
-gs/base/gdevpsd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-25 16:35:19 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c9e30044d1d698701091c9913a81e4b3688a134">1c9e30044d1d698701091c9913a81e4b3688a134</a>
-<blockquote>
-<p>
- Add new -debug=validate-chunks debug flag.<br>
-<br>
- This causes a validation to be run after every operator is interpreted.<br>
-<br>
- Also, update the chunk validation code to give more informative error<br>
- messages when problems are found. (For instance, if a reference is<br>
- found to be duff, it's often the source of that reference you are<br>
- interested in, not the reference itself).<br>
-<br>
-gs/base/gdbflags.h<br>
-gs/base/gsmisc.c<br>
-gs/psi/ialloc.h<br>
-gs/psi/ilocate.c<br>
-gs/psi/interp.c<br>
-gs/psi/zvmem.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-25 14:12: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=c6f9e998b9ab277f85815b927a841c26c507928a">c6f9e998b9ab277f85815b927a841c26c507928a</a>
-<blockquote>
-<p>
- pdfwrite - fix /OtherSubr stripping with Multiple Master fonts<br>
-<br>
- Commit:<br>
- 9f656faebac150c6aceca16c5ef6a78b92b6da43<br>
-<br>
- exposed a problem with this code, when we are stripping /OtherSubrs from MM<br>
- fonts, the new CharString could be larger than the original (this can't<br>
- happen for non-MM fonts). Because we only allocated a buffer big enough to<br>
- hold the original (unstripped) data, we ended up with a buffer overflow.<br>
-<br>
- The code now calls the 'strip' routine twice, the first time to calculate<br>
- how big a buffer will be required, the second time to actually do the work.<br>
-<br>
- This will fix the crash in test-setweightvector.ps introduced by the<br>
- earlier commit<br>
-<br>
-gs/base/gdevpsf1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-25 14:08: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=9f656faebac150c6aceca16c5ef6a78b92b6da43">9f656faebac150c6aceca16c5ef6a78b92b6da43</a>
-<blockquote>
-<p>
- pdfwrite - address problems with stringwidth and composite fonts<br>
-<br>
- Bug #693059 &quot;Asian fonts placed badly with pdfwrite output&quot;<br>
-<br>
- The problem here was caused by the way that pdf_process_string deals with 'widths'<br>
- when responding to a strginwidth operation versus a regular show.<br>
-<br>
- When handling stringwidth the width of each glyph is added to the enumerator<br>
- 'returned.total_width'. However, when handling a regular show, the width of<br>
- the glyphs are simply stored directly into 'returned.total_width'.<br>
-<br>
- To handle the latter case the higher level code maintains its own total width<br>
- but that was getting confused when a stringwidth was used.<br>
-<br>
- Ideally we would fix pdf_process_string to behave the same whether in response<br>
- to a stringwidht or a show, but that routine is called from other places and<br>
- making it coherent looks difficult. Instead we now process stringwidth<br>
- differently form show, and don't accuulate wodths when we have a steingwidth<br>
- operation in the higher level composite font code routines.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpdtc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-24 09:03:09 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e21f69e10ddd68ea807773a8b57e10d23bd74a4f">e21f69e10ddd68ea807773a8b57e10d23bd74a4f</a>
-<blockquote>
-<p>
- Fix a couple of error messages in bmpcmp<br>
-<br>
-gs/toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-23 15:53:53 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e13b5cf5b8c7db67f88c5da62eeb8c8a4d077436">e13b5cf5b8c7db67f88c5da62eeb8c8a4d077436</a>
-<blockquote>
-<p>
- Update psdcmyk and psdrgb to use the downscaler.<br>
-<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-23 10:18:56 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=27afc73a71b9c059b9d5358ed816cdf50e0a1f08">27afc73a71b9c059b9d5358ed816cdf50e0a1f08</a>
-<blockquote>
-<p>
- Fix 2 'unused variable' warnings in downscaler.<br>
-<br>
-gs/base/gxdownscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-22 20:42: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=ce801afb90764b4863dab9e51bc18082222fb3ce">ce801afb90764b4863dab9e51bc18082222fb3ce</a>
-<blockquote>
-<p>
- Unroll some loops in the downscaler for speed.<br>
-<br>
- Time to render first 10 pages of pdf_reference17.pdf to tiff:<br>
- @200dpi = 5.2s<br>
- @600dpi downscaled by 3 = 7.2s (before this)<br>
- @600dpi downscaled by 3 = 6.5s (after this)<br>
-<br>
-gs/base/gxdownscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-22 13:35: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=15cc33536ada0b4cb105110a48df0132539c54db">15cc33536ada0b4cb105110a48df0132539c54db</a>
-<blockquote>
-<p>
- Add downscaler functionality to tiffsep.<br>
-<br>
- Update tiffsep to call the downscaler. This means adding MinFeatureSize<br>
- and DownScaleFactor to tiffsep. Also add BitsPerComponent to allow us to<br>
- specify 8 (default) or 1 (monochrome). MinFeatureSize is ignored except<br>
- in monochrome mode.<br>
-<br>
- This has meant slight reworking of the downscaler to cope with planar<br>
- buffers, and its use of get_bits_rectangle rather than get_bits.<br>
-<br>
- Also updated docs, and fixed some leaks on memory allocation failures<br>
- within tiffsep.<br>
-<br>
-gs/base/gdevtsep.c<br>
-gs/base/gxdownscale.c<br>
-gs/base/gxdownscale.h<br>
-gs/base/lib.mak<br>
-gs/doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-21 08:54: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=4677f28c2a0bf72a6bc89e785cc651d3deedc043">4677f28c2a0bf72a6bc89e785cc651d3deedc043</a>
-<blockquote>
-<p>
- txtwrite - Bug #693046 handle TEXT_FROM_CHARS and TEXT_FROM_SINGLE_CHAR ops<br>
-<br>
- I seem to have overlooked these operations when writing the original code,<br>
- probably because I couldn't' find any test cases. However PCL seems to make<br>
- extensive use of them, and the lack of code causes access outside array<br>
- boundaries.<br>
-<br>
- Fixed here in a simplistic fashion, which seems to work well.<br>
-<br>
- No differences expected, txtwrite is not cluster tested<br>
-<br>
-gs/base/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-20 16:31:14 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=535d11e8a1d667a3d71680b27f18e4a89df98b2d">535d11e8a1d667a3d71680b27f18e4a89df98b2d</a>
-<blockquote>
-<p>
- Bug 693044: fix pdfopt utility.<br>
-<br>
- Disable checking for the max pdf object number during PDF linearisation,<br>
- because linearisation adds a few new objects to the PDF file.<br>
-<br>
-gs/lib/pdfopt.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-18 14:32:56 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=40cc976eae680d6a6f1297c5a0d556a37e9eb4b8">40cc976eae680d6a6f1297c5a0d556a37e9eb4b8</a>
-<blockquote>
-<p>
- txtwrite - clean up some benign silly compiler warnings<br>
-<br>
-gs/base/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-18 12:56: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=44869447f94a15ae0082b89668576636e4c39575">44869447f94a15ae0082b89668576636e4c39575</a>
-<blockquote>
-<p>
- txtwrite - add a 'do nothing' rop device method to avoid errors<br>
-<br>
-gs/base/gdevtxtw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-16 14:55:02 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1831d329606c767069dbc706632c4b30db4488ce">1831d329606c767069dbc706632c4b30db4488ce</a>
-<blockquote>
-<p>
- Attempt to fix dashing in hpgl path mode.<br>
-<br>
- We were giving up dashing as soon as we hit the first gap in a path.<br>
- Fix by treating gaps as an 'ink off' dash segment.<br>
-<br>
-gs/base/gxpdash.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-16 18:22: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=422773777f1e6df2fd4decb3ca6b65801acfc1ac">422773777f1e6df2fd4decb3ca6b65801acfc1ac</a>
-<blockquote>
-<p>
- Update bmpcmp to cope with rgb and greyscale psd files.<br>
-<br>
- Also have a better stab at handling spot equivalent colors.<br>
-<br>
- CLUSTER_UNTESTED.<br>
-<br>
-gs/toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-15 20:00:19 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8610551db7cc10c72d7a6bbfaa7ffe61d521a5d9">8610551db7cc10c72d7a6bbfaa7ffe61d521a5d9</a>
-<blockquote>
-<p>
- Memento tweak: Allow MEMENTO_LEAKONLY to be defined by command line<br>
-<br>
- Currently Memento undefines MEMENTO_LEAKONLY at the top of memento.c.<br>
-<br>
- Change it here not to do that, so it can be supplied as part of a<br>
- CFLAGS or XCFLAGS line.<br>
-<br>
- CLUSTER_UNTESTED.<br>
-<br>
-gs/base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-15 19:44:50 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a846030605e04c09265241853ed5ac3442c258e9">a846030605e04c09265241853ed5ac3442c258e9</a>
-<blockquote>
-<p>
- Leak checking tweaks; memory finalisation and param handling<br>
-<br>
- When Ghostscript shuts down, it closes its malloc handler, which frees<br>
- all the outstanding blocks it knows about. This is unhelpful behaviour<br>
- when checking for leaks, so we disable this freeing in MEMENTO builds.<br>
-<br>
- Also, the Ghostscript arg handling code is quite keen on 'arg_copy'ing<br>
- args only to pass them into routines that immediate copy them again<br>
- into heap allocated buffers. These copies are then allowed to leak.<br>
-<br>
- Where it is obviously safe, avoid these copies. Where it's not so clear<br>
- free them (using a new arg_free function).<br>
-<br>
-gs/base/gsargs.c<br>
-gs/base/gsargs.h<br>
-gs/base/gsmalloc.c<br>
-gs/psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-15 18:22: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=b549f7df132df28783e34ef6839812b691c9eed5">b549f7df132df28783e34ef6839812b691c9eed5</a>
-<blockquote>
-<p>
- Bug 693039: Fix Memento crashes<br>
-<br>
- After reallocing a block, it is best to avoid reading from the old<br>
- location. (Read flags, then realloc, then write flags).<br>
-<br>
- Also some minor tweaks to avoid warnings etc.<br>
-<br>
-gs/base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-15 12:10:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=be37389c29534ffd9ce6bb31353f4f8c0273bfd3">be37389c29534ffd9ce6bb31353f4f8c0273bfd3</a>
-<blockquote>
-<p>
- Add a bunch of derived files to .gitignore<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-.gitignore<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-15 12:08: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=676ca45571121495de22c02ac7b03da14f75525c">676ca45571121495de22c02ac7b03da14f75525c</a>
-<blockquote>
-<p>
- Call libtiff configure from ghostpdl configure.<br>
-<br>
- We had worked around the lack of a ghostpdl configure script by calling the<br>
- libtiff configure from the Makefile - which is a horrible hack.<br>
-<br>
- Now that ghostpdl has a configure script, we can do the right thing, and call<br>
- the libtiff script from the ghostodl one.<br>
-<br>
- No cluster differences.<br>
-<br>
-Makefile<br>
-configure.ac<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-14 21:00:46 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=827e5420e2d0b3c1bb3b9e656c27236ac650eacc">827e5420e2d0b3c1bb3b9e656c27236ac650eacc</a>
-<blockquote>
-<p>
- Really remove derived files from jbig2dec directory<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/jbig2dec/config.h<br>
-gs/jbig2dec/libtool<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-14 18:08:00 +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=26ac0d3505530c6782dffeeaa053328a481afcb0">26ac0d3505530c6782dffeeaa053328a481afcb0</a>
-<blockquote>
-<p>
- Bug 693025: Updated patch from Zeniko to fix various crashes and leaks<br>
-<br>
-gs/jbig2dec/jbig2_halftone.c<br>
-gs/jbig2dec/jbig2_huffman.c<br>
-gs/jbig2dec/jbig2_image.c<br>
-gs/jbig2dec/jbig2_refinement.c<br>
-gs/jbig2dec/jbig2_segment.c<br>
-gs/jbig2dec/jbig2_symbol_dict.c<br>
-gs/jbig2dec/jbig2_text.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-14 14:26: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=2699766796d407f04e790ca1374f68be00532847">2699766796d407f04e790ca1374f68be00532847</a>
-<blockquote>
-<p>
- remove an unused variable to silence a compiler warning<br>
-<br>
-gs/base/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-14 13:35:51 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8ea8d0df81d2552a3470bbf708b91fb4467a5be2">8ea8d0df81d2552a3470bbf708b91fb4467a5be2</a>
-<blockquote>
-<p>
- pdfwrite - memory fixes. don't track pdf_font_cache in GS fonts<br>
-<br>
- pdfwrite maintains a 'font cache' of PDF font objects which are related to<br>
- GS fonts. Previously these were tracked by adding a pointer to the GS font,<br>
- and freeing the memory when the font was unloaded, by using the gs_notify_register<br>
- callback.<br>
-<br>
- This causes problems when we are in 'file per page' mode. We want to discard<br>
- and rebuild the font cache at the end of each page, so we don't try to<br>
- reuse font objects. But if we discard the memory, the font is still pointing<br>
- at it. This causes later memory problems.<br>
-<br>
- The simplest solution is to stop tracking the elements in the GS fonts. This<br>
- means that an element will persist and be stale after the font goes out of<br>
- scope, but its a fairly small amount of memory per font. We now clean up the<br>
- PDF font cache and all the elements in pdf_close along with all the other memory.<br>
-<br>
- The 'file per page' mode using the '-sOutputFilename=%d.pdf' syntax now seems<br>
- to work correctly. There does not seem to be any great amount of memory leakage<br>
- now either.<br>
-<br>
- The next step is to implement a 'server' mode application and use that to<br>
- check that there are no remaining memory leaks<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-11 09:57:23 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6b31a6466c0819db229cbde420c72789eecdbe2d">6b31a6466c0819db229cbde420c72789eecdbe2d</a>
-<blockquote>
-<p>
- Add missing part of commit to prevent access to freed memory.<br>
-<br>
- Somehow when applying this part of the reverted patch, this line (the<br>
- one that actually prevented the access to freed memory) was missed.<br>
-<br>
-gs/base/gsicc_profilecache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-11 16:33: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=f9c1df276e998fc754d5c0e416c606cc5404a495">f9c1df276e998fc754d5c0e416c606cc5404a495</a>
-<blockquote>
-<p>
- pdfwrite - memory clean up. Clear outlines<br>
-<br>
- The outline objects are released in write_outline, but the entries in the<br>
- device were not previously cleared leaving them pointing to freed memory.<br>
-<br>
-gs/base/gdevpdf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-11 11:38: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=08d715446bb97015d16e085aa8f8c4bd8f73c2cc">08d715446bb97015d16e085aa8f8c4bd8f73c2cc</a>
-<blockquote>
-<p>
- pdfrite - memory cleanup, free Annotations<br>
-<br>
- Annotations weren't being freed along with their enclosing Page structure<br>
- Add some comments about what is stored where, and when it is released, in<br>
- a few places<br>
-<br>
-gs/base/gdevpdf.c<br>
-gs/base/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-10 13:24:15 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=54ecaf86c6fa0c4a31fb17e0c21361cb134ec376">54ecaf86c6fa0c4a31fb17e0c21361cb134ec376</a>
-<blockquote>
-<p>
- CIELAB vector and CIELAB images have to use a slightly different remap proc.<br>
-<br>
- The image data is already scaled as needed for the ICC code to handle directly.<br>
- Vector colors require the decode from real CIELAB values. This fix was missing<br>
- in the in image interpolation code. Fix for Bug 692885<br>
-<br>
-gs/base/gxiscale.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-11 15:07:43 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79925e26467289515d4cf499d2c3a2d3b1cdcaa4">79925e26467289515d4cf499d2c3a2d3b1cdcaa4</a>
-<blockquote>
-<p>
- Delay of obtaining handles from CMM for default profiles<br>
-<br>
- Obtaining the profiles handles for all the default profiles in<br>
- the ICC manager eats up a tiny amount of time on startup. For<br>
- some customers that start and stop gs over and over instead of<br>
- running in server mode, this startup time is an issue. This<br>
- fix performs the initialization in a lazy manner, obtaining the<br>
- profile handle only when finally needed.<br>
-<br>
- This commit also fixed some issues with images that are in the<br>
- LAB color space.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gscdevn.c<br>
-gs/base/gscsepr.c<br>
-gs/base/gsicc.c<br>
-gs/base/gsicc.h<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_manage.h<br>
-gs/base/gstrans.c<br>
-gs/base/gxclimag.c<br>
-gs/base/gxcmap.c<br>
-gs/base/gxicolor.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-09 22:01: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=c6d74690be87eb37ca5b4590ed6b44673e4125c7">c6d74690be87eb37ca5b4590ed6b44673e4125c7</a>
-<blockquote>
-<p>
- Fix bug 692372 and bug 693001 to free semaphores without leaking memory.<br>
-<br>
- The original fix (fe8d7b6) for 692372 released the semaphores, but resulted<br>
- in memory leaks of many other parts of the imager state. The leak was fixed<br>
- by reverting the above change. This change insures that sempahores are not<br>
- leaked by adding 'finalization' to the icc_linkcache and icc_link structs.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-gs/base/gsistate.c<br>
-gs/base/gsstruct.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-09 09:56:00 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=055ed5f7a69ad5cf4181cf337abf2245df668c01">055ed5f7a69ad5cf4181cf337abf2245df668c01</a>
-<blockquote>
-<p>
- Prevent reference to freed memory when freeing the profile cache.<br>
-<br>
-gs/base/gsicc_profilecache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-09 09:51: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=af974d1bd4b4f0470e77d28eb0cdcb72def2de76">af974d1bd4b4f0470e77d28eb0cdcb72def2de76</a>
-<blockquote>
-<p>
- Revert &quot;Fix bug 692372: Add finalize for imager_state to ref_count decrement icc structs.&quot;<br>
-<br>
- This reverts commit fe8d7b6aebfed3c724a860e31ff170764d5429dc.<br>
- This commit resulted in a subsantial memory leak detected with PCL. See<br>
- bug 693001. The finalization should be for the icc structs that have<br>
- semaphores.<br>
-<br>
-gs/base/gsicc_profilecache.c<br>
-gs/base/gsistate.c<br>
-gs/base/gsstate.c<br>
-gs/base/gxistate.h<br>
-gs/base/gzstate.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-09 13:07: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=0ee6bd45c59c2ae99ec30cba4dae22d1f2e20dc4">0ee6bd45c59c2ae99ec30cba4dae22d1f2e20dc4</a>
-<blockquote>
-<p>
- Remove a couple of derived files from jbig2dec.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/jbig2dec/libtool<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-09 09:52: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=a32c42253c299d55d44ad39ba3d998fcebbef7ba">a32c42253c299d55d44ad39ba3d998fcebbef7ba</a>
-<blockquote>
-<p>
- pdfwrite - memory cleanup; use correct allocater, don't free tracked object<br>
-<br>
- Previously the code to free font resources was using the wrong memory<br>
- allocator to free some objects, fixed here.<br>
-<br>
- It also seems that, contrary to what I thought Function resources *are*<br>
- tracked by 'last_resource' in teh pdfwrite device structure. So its important<br>
- not to free those twice.<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpdf.c<br>
-gs/base/gdevpdtf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-07 19:14: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=365df54880adff1bd0b7d983c440fb518250c9f0">365df54880adff1bd0b7d983c440fb518250c9f0</a>
-<blockquote>
-<p>
- Fix a warning in zfapi.c<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-07 17:47:33 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=949993da66cd9850ce47c7319465aed42585b261">949993da66cd9850ce47c7319465aed42585b261</a>
-<blockquote>
-<p>
- Tweak bmpcmp error message<br>
-<br>
-gs/toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-07 16:34: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=fee1ab3e7e38c3e2bd82a855d7bdec2c18751320">fee1ab3e7e38c3e2bd82a855d7bdec2c18751320</a>
-<blockquote>
-<p>
- Bug 693023: fix $Blend in Type 1 font serialization<br>
-<br>
- When serializing a MultipleMaster font, we were writing both a 'boiler plate'<br>
- $Blend procedure, and a broken $Blend from the font dictionary - broken because<br>
- the code to read the procedure from the dictionary ignored name objects.<br>
-<br>
- In general, this was fine, as all the current FAPI scalers ignore the $Blend.<br>
- A problem arose because the code which calculated size of the procedure did<br>
- handle PS name objects, so we ended up with unitialized bytes trailing the<br>
- dictionary data, which could cause the scaler to error.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/write_t1.c<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-03 12:13:06 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b81312d205a2f9b89f40da4b4f6b67bcacd8ef1">7b81312d205a2f9b89f40da4b4f6b67bcacd8ef1</a>
-<blockquote>
-<p>
- Fix for issues in use of /SeparationOrder and /SeparationColorNames<br>
-<br>
- Several issues and quite a bit of confusion in the code with respect<br>
- to this option. I believe this should clear some things up.<br>
- Documentation still needs to be updated as to how this option functions<br>
- and what devices it actually works with. Note that<br>
- SeparationOrder and SeparationColorNames really only works for the<br>
- tiffsep device. The psdcmyk device was never really set up for use<br>
- with this option. Not sure if we want to add it. Also, I discovered<br>
- that with the disabling of compressed color encoding, the tiffsep1<br>
- device renders incorrectly. I had not converted this device to planar<br>
- as I had thought that it performed halftoning during rendering. I<br>
- did not realize it was rendering 8 bit data and then doing<br>
- a thresholding operation. We may want to just move this to a planar<br>
- based device. In that case, we could use the fast planar halftoning.<br>
-<br>
- Note that with this fix, the device will only create output for the<br>
- colorants listed in /SeparationOrder. The psdcmyk device was not<br>
- making use of the /SeparationOrder information properly. It is now<br>
- which makes for some different renderings in the ps3cet/29-07*.ps test<br>
- files which exercise /SeparationOrder changes. In such a case, the<br>
- device will not output any missing colorants, which previously<br>
- it was doing.<br>
-<br>
-gs/base/gdevdevn.c<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-05 11:21: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=c5f91f9fa29922713d3751654dda09ccc8518801">c5f91f9fa29922713d3751654dda09ccc8518801</a>
-<blockquote>
-<p>
- pdfwrite - memory leaks with CIDFonts<br>
-<br>
- Move the code to free font resources from the 'pdf close' into a separate<br>
- routine in the font handling module. Additionally call it for CIDFont<br>
- resoruces as well as Font resources (the code copes with freeing both)<br>
-<br>
- No differences expected<br>
-<br>
-gs/base/gdevpdf.c<br>
-gs/base/gdevpdtf.c<br>
-gs/base/gdevpdtf.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-05 01:03:31 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=922400e9056ad46a27e0ab5964213415061bd801">922400e9056ad46a27e0ab5964213415061bd801</a>
-<blockquote>
-<p>
- Bug 693027: Add missing spot color extraction from shading patterns.<br>
-<br>
- Old code processed all patterns as tiled patterns and missed the<br>
- shading color space.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-04 15:19: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=b2b2473f2064b4abd835449b761e46fdbb5a47f1">b2b2473f2064b4abd835449b761e46fdbb5a47f1</a>
-<blockquote>
-<p>
- Bring the gs/jbig2dec directory in line with jbig2dec repos.<br>
-<br>
- Mainly autoconf source files like configure.ac<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/jbig2dec/Makefile.in<br>
-gs/jbig2dec/aclocal.m4<br>
-gs/jbig2dec/annex-h.jbig2<br>
-gs/jbig2dec/autogen.sh<br>
-gs/jbig2dec/compile<br>
-gs/jbig2dec/config.guess<br>
-gs/jbig2dec/config.h<br>
-gs/jbig2dec/config.h.in<br>
-gs/jbig2dec/config.sub<br>
-gs/jbig2dec/configure<br>
-gs/jbig2dec/depcomp<br>
-gs/jbig2dec/install-sh<br>
-gs/jbig2dec/libtool<br>
-gs/jbig2dec/ltmain.sh<br>
-gs/jbig2dec/missing<br>
-gs/jbig2dec/pbm2png.c<br>
-gs/jbig2dec/stamp-h1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-19 16:44: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=19e1c90a1185b681e081cc50ea64a73e8fd8f9b7">19e1c90a1185b681e081cc50ea64a73e8fd8f9b7</a>
-<blockquote>
-<p>
- pdfwrite - address memory leaks<br>
-<br>
- First pass at cleaning up pdfwrite's memory 'management'.<br>
-<br>
- Add clean up code in pdf_close for fonts, font descriptors, type 3 CharProc<br>
- and Pattern resources.<br>
-<br>
- Since we only need the object number for a reference we now create a new<br>
- type of cos object 'reference'. This only contains the object ID so that<br>
- we cna write out the reference. We also set the ID to 0 after we write it<br>
- as this will allow us to free the object. (id == 0 is a crazy reference<br>
- counting thing, it seems)<br>
-<br>
- Free the 'aside' associated with a pattern after releasing it.<br>
-<br>
- free ExtGState resources at close.<br>
-<br>
- There was no code to free CMaps, none at all. Added routines to free regular<br>
- CMaps and ToUnicode CMaps, and added code to pdfwrite to call these in order<br>
- to actually free CMap resources.<br>
-<br>
- When manufacturing a BaseFont, if we already have a BaseFont name, dispose<br>
- of it before assigning a new one. Previously this leaked the string<br>
- containing the name.<br>
-<br>
- release font resoruce objects<br>
-<br>
- when freeing a font descriptor, free the object as well as the glyphs<br>
-<br>
- Free copied base font FontName string on close<br>
-<br>
- This is opaque data specific to each font type, so we may need to add<br>
- specific cleanup routines, but this is a start.<br>
-<br>
- Secondly, when pdfwrite copeis a font it makes 2 copies, a subset and a<br>
- complete copy. However the complete copy can fail because of an unused<br>
- glyph. So we dicard the complete copy and carry on with the subset. In<br>
- this case we didnt' clean up the 'complete' copy.<br>
-<br>
- Modified the previous code into one routine to free copied fonts, when we<br>
- discard a (complete) copied font during font copying free the font copy.<br>
-<br>
- free Encoding from copied fonts if present<br>
-<br>
- Also, change the text for font freeing so it makes sense.<br>
-<br>
- Free copied font 'data' when freeing copied font<br>
-<br>
- Free the 'base_font' structure when freeing FontDescriptors<br>
-<br>
- release colour spaces.<br>
-<br>
- Make a routine to free colour spaces, and have it free the 'serialized'<br>
- color space memory.<br>
-<br>
- Free the page dictionary when we free pages.<br>
-<br>
- We seem to have (at least) two different kinds of param lists which are used<br>
- to deal with getting/setting device params. The PostScript interpreter uses<br>
- 'ref_params' and the PCL interpreter uses 'c_params'.<br>
-<br>
- The problem is that 'ref_params_end_write_collection' frees the list memory<br>
- but 'c_params_end_write_collection' does not. Since these are accessed through<br>
- methods in the list, we don't know whether we need to free the memory or not.<br>
- This leads to a memory leak when using the PCL interpreter.<br>
-<br>
- I suspect this is a bug in the implementation, but for now I've modified<br>
- 'ref_params_end_write_collection' so that it nulls the pointer to the list<br>
- when it frees it. The code in gdevdsp.c can then test to see whether the<br>
- memory needs to be freed (non-NULL) or not.<br>
-<br>
- For some reason this leads to a Seg Fault with fts_09_0923.pdf, but I<br>
- can't see why. I believe this is unrelated, so will investigate it further<br>
- after this work is completed.<br>
-<br>
- Also changed a typecast to eliminate a warning<br>
-<br>
- create a routine to clean up the 'text data' and call it. Add the<br>
- 'standard fonts' to the clenaup in there.<br>
-<br>
- Clean up a number of allocations (name index stack, namespace<br>
- stack etc).<br>
-<br>
- Add code to free Funtiocn resource dictionaries, objects and resources,<br>
-<br>
- These were missed previously, because the development was done in PCL and<br>
- teh PCL interpreter can't trigger the use of Functions.<br>
-<br>
- Add code to clean up Shading and group dictionary resources. Add code to<br>
- clear the resource chains on close so that we don't end up trying to use<br>
- freed memory pointers.<br>
-<br>
-gs/base/gdevpdf.c<br>
-gs/base/gdevpdfc.c<br>
-gs/base/gdevpdfg.h<br>
-gs/base/gdevpdfi.c<br>
-gs/base/gdevpdfo.c<br>
-gs/base/gdevpdfo.h<br>
-gs/base/gdevpdfu.c<br>
-gs/base/gdevpdfv.c<br>
-gs/base/gdevpdfx.h<br>
-gs/base/gdevpdt.c<br>
-gs/base/gdevpdt.h<br>
-gs/base/gdevpdtb.c<br>
-gs/base/gdevpdtd.c<br>
-gs/base/gdevpdtd.h<br>
-gs/base/gdevpdtf.c<br>
-gs/base/gdevpdti.c<br>
-gs/base/gdevpdti.h<br>
-gs/base/gdevpsdp.c<br>
-gs/base/gsfcmap.c<br>
-gs/base/gsfcmap.h<br>
-gs/base/gxfcmap.h<br>
-gs/base/gxfcopy.c<br>
-gs/base/gxfcopy.h<br>
-gs/psi/iparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-01 12:29:03 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=714b375a58593b62a38c3fa5dfacd0fae2d7d1f9">714b375a58593b62a38c3fa5dfacd0fae2d7d1f9</a>
-<blockquote>
-<p>
- Bug 693006: Guess malformed numbers.<br>
-<br>
- If an unknown PDF operator has only [-.0-9], consider it a malformed<br>
- number and replace with 0.<br>
-<br>
-gs/Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-01 01:41:25 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=885289be955a17cb75a401a71d3b6529c755e96b">885289be955a17cb75a401a71d3b6529c755e96b</a>
-<blockquote>
-<p>
- Fix for another indeterminism from 60640aeb33b18f9a9fcd76fc6f1083d7c7635f2<br>
-<br>
-gs/base/gxdcolor.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-05-01 01:41:18 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c51dd0ad9b442a05844e1b8eb3e4b511af8c0392">c51dd0ad9b442a05844e1b8eb3e4b511af8c0392</a>
-<blockquote>
-<p>
- Optimize transparency bbox for image SMask.<br>
-<br>
- SMask with GreyBackground != 1.0 needs to use parent bbox, but image<br>
- SMask only paint the image area so the BC cannot affect areas outside.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-30 15:11:38 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af102f5fe9a91a071b2d01c3e8ee35a0c99275ea">af102f5fe9a91a071b2d01c3e8ee35a0c99275ea</a>
-<blockquote>
-<p>
- Fix for indeterminism introduced in 60640aeb33b18f9a9fcd76fc6f1083d7c7635f24<br>
-<br>
- The shading code was using the number of components of the target device<br>
- in making a linearity determination. It should make use of the destination<br>
- ICC profile in that computation.<br>
-<br>
-gs/base/gsicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-29 23:36:02 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e8f8eed2369d5e8709acd0aa65306758aa322e3d">e8f8eed2369d5e8709acd0aa65306758aa322e3d</a>
-<blockquote>
-<p>
- Initialize color procs for clip list accumulator<br>
-<br>
- There are calls made during filling with this device to get the black point<br>
- of the device due to some ROP related call. The device did not have any<br>
- procedures for mapping colors or for decode and encode. Fix for Bug 692720.<br>
-<br>
-gs/base/gxacpath.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-30 15:27: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=3cde6d6d3d24a0930d591df9914ddda194d13b37">3cde6d6d3d24a0930d591df9914ddda194d13b37</a>
-<blockquote>
-<p>
- Bug 692459: stop tiffsep(1) overwriting pages already written<br>
-<br>
- The tiffsep and tiffsep1 devices both get closed and reopen when the separations<br>
- change (communicated by put_params). Previously this caused the output files to<br>
- be closed and reopened - not a problem when writing each page to its own set of<br>
- files, but when writing multipage tiffs, it resulted in all pages up to that<br>
- point to be overwritten.<br>
-<br>
- We now have tiffsep and tiffsep1 handle their own file &quot;management&quot;, and prevent<br>
- output files from being closed and reopened when the device is closed and<br>
- reopened due to a put_params call.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-27 18:46:27 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=60640aeb33b18f9a9fcd76fc6f1083d7c7635f24">60640aeb33b18f9a9fcd76fc6f1083d7c7635f24</a>
-<blockquote>
-<p>
- * Change of the tiffsep and psdcmyk device to planar devices.<br>
-<br>
- This change in these devices was made to remove the 64 bit limitation of<br>
- our existing color encoding which limits us to 8 colorants without<br>
- compressed color encoding. The motivation for this work is that even<br>
- with compressed color encoding we were starting<br>
- to encounter files with transparency in particular that exceeded the<br>
- capabilities of encoding, leading to dropped colors. With this fix, we<br>
- encode through the clist the DeviceN color values. The buffers for the<br>
- devices are maintained as planar buffers and fills occur with the high level<br>
- device colors.<br>
-<br>
- Support was added to handle the devn color type through the shading code. The old<br>
- code would have supported only 8 colorants in a shading.<br>
-<br>
- Support was also added to the transparency code to enable the use of the put_image<br>
- procedure which for the planar device saves quite a bit of time since we can do the<br>
- copy_planes proc directly from the pdf14 planar buffer to the planar memory device buffer.<br>
- The pdf14 device also had to support fill_rectangle_hl_color.<br>
-<br>
- Changes were also made to the pattern tiling code so that we avoid any planar to chunky and<br>
- back to planar conversions. These were being done to handle ROPs. Even when there were<br>
- not any ROPs to perform we were going through strip_tile_rop operations since the<br>
- gx_default_strip_tile_rectangle did not support planar to planar. That support is added<br>
- with this commit.<br>
-<br>
- Support had to be added to the overprint compositor to support the new color type with<br>
- fill_rectangle_hl_color.<br>
-<br>
- Support had to be added to the clist for fill_rectangle_hl_color. This required changes<br>
- on both the writing and reading side. It is possible that the amount of data written<br>
- for these commands could be reduced and that is commented in the code.<br>
-<br>
- Support also had to be added to the clip device and the mask_clip device as well<br>
- for uncolored patterns. Also the tile clip device required support and the transparency device<br>
- required support for copy_planes. This last function needs to be optimized.<br>
-<br>
- Both of the separation devices (tiffsep and psdcmyk) that we currently have are updated to<br>
- support this method. There is an #if option in each device file to return the<br>
- code back to the old chunky format.<br>
-<br>
- A new device procedure for handling strip tiling of masks with devn colors had<br>
- to be added. Functionality was only required for the mem planar and clist devices.<br>
-<br>
- Also, it was found that the tiffsep and psdcmyk devices were maintaining separations<br>
- (spot colors) across pages. That is if page 1 had a spot color, subsequent pages<br>
- created a separation for that spot<br>
- even if those pages did not contain it. This was fixed so that separations for a page<br>
- are only created for the spots that occur on that page.<br>
-<br>
- A fix was also made to ensure that we had proper handling for the None colorants when<br>
- they are part of the DeviceN color space.<br>
-<br>
-gs/base/devs.mak<br>
-gs/base/gdevbbox.c<br>
-gs/base/gdevdbit.c<br>
-gs/base/gdevdevn.c<br>
-gs/base/gdevdevn.h<br>
-gs/base/gdevdflt.c<br>
-gs/base/gdevdsha.c<br>
-gs/base/gdevmem.c<br>
-gs/base/gdevmem.h<br>
-gs/base/gdevmpla.c<br>
-gs/base/gdevmx.c<br>
-gs/base/gdevnfwd.c<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevpdfi.c<br>
-gs/base/gdevppla.c<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevtsep.c<br>
-gs/base/gscdevn.c<br>
-gs/base/gscicach.c<br>
-gs/base/gscms.h<br>
-gs/base/gscsepr.c<br>
-gs/base/gsdcolor.h<br>
-gs/base/gsdps1.c<br>
-gs/base/gsequivc.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsovrc.c<br>
-gs/base/gsptype1.c<br>
-gs/base/gxblend.h<br>
-gs/base/gxblend1.c<br>
-gs/base/gxcldev.h<br>
-gs/base/gxclimag.c<br>
-gs/base/gxclip.c<br>
-gs/base/gxclip.h<br>
-gs/base/gxclip2.c<br>
-gs/base/gxclipm.c<br>
-gs/base/gxclist.c<br>
-gs/base/gxclpath.c<br>
-gs/base/gxclpath.h<br>
-gs/base/gxclrast.c<br>
-gs/base/gxclrect.c<br>
-gs/base/gxcmap.c<br>
-gs/base/gxdcolor.c<br>
-gs/base/gxdcolor.h<br>
-gs/base/gxdevcli.h<br>
-gs/base/gxdevice.h<br>
-gs/base/gxdevsop.h<br>
-gs/base/gxgetbit.h<br>
-gs/base/gxht.c<br>
-gs/base/gxicolor.c<br>
-gs/base/gxp1fill.c<br>
-gs/base/gxp1impl.h<br>
-gs/base/gxpcmap.c<br>
-gs/base/gxpcolor.h<br>
-gs/base/gxshade6.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-26 15:11:18 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd09a0706ab09a54f5fbb05c63420c86375b45bf">dd09a0706ab09a54f5fbb05c63420c86375b45bf</a>
-<blockquote>
-<p>
- Memento tweaks; add Memento_breakOnFree/Realloc functionality.<br>
-<br>
- Memento_breakOnFree(address) will cause a breakpoint when the block<br>
- including a given address is freed. If the block is realloced (and<br>
- hence moves elsewhere) the breakpoint is not triggered until the new<br>
- block is itself freed.<br>
-<br>
- Memento_breakOnRealloc(address) will cause a breakpoint when the block<br>
- including a given address is freed or realloced.<br>
-<br>
-gs/base/memento.c<br>
-gs/base/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-25 17:33:59 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=012aef926d1e33cc64c32bf8e94ef92a299d73f9">012aef926d1e33cc64c32bf8e94ef92a299d73f9</a>
-<blockquote>
-<p>
- Bug 692243: Replace dictionary look-up with .execn<br>
-<br>
- Replace a fragment that stores line width in a dictionary with an equivalent<br>
- code that uses execution stack and .execn . These tricks are needed to keep<br>
- the stack depth constant.<br>
-<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-25 00:08:53 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=70d513095fba13b20e6bba5bb77805b5233028d1">70d513095fba13b20e6bba5bb77805b5233028d1</a>
-<blockquote>
-<p>
- Bug 692243: Fix a typo in absolute value comparison.<br>
-<br>
-gs/Resource/Init/pdf_ops.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-24 17:35:10 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f1830075608195e2976751303d220fda3f796abb">f1830075608195e2976751303d220fda3f796abb</a>
-<blockquote>
-<p>
- Bug 692969: Don't verify PDF 1.5 xref.<br>
-<br>
- Don't verify stream xref table because we cannot repair PDF files with<br>
- new object format. Such verification only increases the chance that the<br>
- file fails.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-24 15:06:16 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=430e9e345c84912f953161aa843b37f235c97708">430e9e345c84912f953161aa843b37f235c97708</a>
-<blockquote>
-<p>
- Bug 693000: Verify /Subtype of CIDFont resource.<br>
-<br>
- Check whether CIDFont resource refers to a Type 1 file and process<br>
- it accordingly.<br>
-<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-24 17:48:12 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5d2134b8ebea14594411580776f1bce5c40363c">b5d2134b8ebea14594411580776f1bce5c40363c</a>
-<blockquote>
-<p>
- Add gx_forward_copy_planes.<br>
-<br>
- Add this to the overprint device.<br>
-<br>
-gs/base/gdevnfwd.c<br>
-gs/base/gsovrc.c<br>
-gs/base/gxdevice.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-24 10:15:59 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c2a982ffda019b2822799a918d53022ec06342fa">c2a982ffda019b2822799a918d53022ec06342fa</a>
-<blockquote>
-<p>
- Pacify Valgrind: don't calculate unused values from undefined data.<br>
-<br>
-gs/lcms2/src/cmsopt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-24 10:19:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f10560765a226f668b72fd9b8298d644cbce08ab">f10560765a226f668b72fd9b8298d644cbce08ab</a>
-<blockquote>
-<p>
- Bug 693002: Add recently added files to install-doc target.<br>
-<br>
- thirdparty.htm WhatIsGS.htm GS9_Color_Management.pdf<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/unixinst.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-23 23:44:18 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d561224d1495321d40012230abbcf835b298f557">d561224d1495321d40012230abbcf835b298f557</a>
-<blockquote>
-<p>
- Bug 692983: Require EOD mark in ASCII85 string.<br>
-<br>
- Make sure that ASCII85-encoded string is terminated with '~&gt;' and<br>
- throw an error if it isn't. Old code accepted EOF as a valid<br>
- termination for a string token.<br>
-<br>
-gs/base/sa85d.c<br>
-gs/base/sa85d.h<br>
-gs/psi/iscan.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-23 20:03:50 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ec092a2630dd215a317f509ca283fc5cfb4e8b02">ec092a2630dd215a317f509ca283fc5cfb4e8b02</a>
-<blockquote>
-<p>
- Planar device memory setup tweaks.<br>
-<br>
- When setting up a memory planar device, we currently build a mask<br>
- out of the plane information supplied to us about how to pack<br>
- colors into a gx_color_index. This seems like a reasonable thing to<br>
- do as we will always need to pack colors into a gx_color_index at<br>
- some point.<br>
-<br>
- As part of his work on tiffsep, Michael is about to lift this<br>
- requirement though, enabling us to cope with larger numbers of<br>
- spots. The code as is fails on certain machines/compilers due to<br>
- C's undefined behaviour when shifting by more bits than are in the<br>
- variable. We spot this case explicitly, and don't bother checking<br>
- for overlap in this case.<br>
-<br>
-gs/base/gdevmpla.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-23 15:51: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=3a8fbd9c52897cccce7cb6e61e06acb1fe8bff7f">3a8fbd9c52897cccce7cb6e61e06acb1fe8bff7f</a>
-<blockquote>
-<p>
- Fix uninitialised variable access<br>
-<br>
- Previous commit highlighted a missing a return value check which could result<br>
- in an uninitialised variable being accessed.<br>
-<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-23 13:36: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=f57b7562c79a9e3649e95e7bafa6193b571154bb">f57b7562c79a9e3649e95e7bafa6193b571154bb</a>
-<blockquote>
-<p>
- Handle the remaining CIDFonts that FAPI was missing.<br>
-<br>
- This causes a number of cluster file differences, almost all are the usual<br>
- single pixel differences. There are few cases slightly better, and a few<br>
- slightly worse.<br>
-<br>
- One file is a &quot;regression&quot; (depending on your point of view) which is badq.pdf<br>
- where the two contours making up the lower case &quot;q&quot; both go in the same<br>
- direction, so non-zero winding for filling results in the &quot;loop&quot; in the &quot;q&quot;<br>
- being completely filled.<br>
-<br>
- The font is to blame here, but I will continue to look into a solution for<br>
- Freetype.<br>
-<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-21 13:46:37 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b40ce1e58c211008831971f3866cb49e912a1e4f">b40ce1e58c211008831971f3866cb49e912a1e4f</a>
-<blockquote>
-<p>
- bmpcmp: Error handling tweaks.<br>
-<br>
- When failing to match a page due to differences in number of colors<br>
- or sizes etc, output the page number and continue looking at other<br>
- pages in the file.<br>
-<br>
-gs/toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-20 13:52:33 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a943658240231bede6cd5f04d7f1bfa713918ccf">a943658240231bede6cd5f04d7f1bfa713918ccf</a>
-<blockquote>
-<p>
- Fixes 692992. Implicit closepaths not properly detected.<br>
-<br>
- GL/2 closepaths, implicitly detected when the first point of a subpath<br>
- and last are equal, were not recognized in some cases because we were<br>
- doing a comparison of transformed floating point values, the<br>
- comparison is now done correctly in fixed point.<br>
-<br>
- Many regression test files have progressions where the first and last<br>
- point of a path now have a proper join where one did not exist before.<br>
-<br>
-pcl/pgdraw.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-14 22:29:40 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=579e0e04b0d83d4364c9c4e42dcced8ca85fc634">579e0e04b0d83d4364c9c4e42dcced8ca85fc634</a>
-<blockquote>
-<p>
- Remove obsolete bug list.<br>
-<br>
-tools/bug-list.txt<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-20 14:58: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=b9350f4a92c1765d13afbff3e6a4576c33290d91">b9350f4a92c1765d13afbff3e6a4576c33290d91</a>
-<blockquote>
-<p>
- Default to Windows UNICODE file names &quot;off&quot;.<br>
-<br>
- Bring the PCL build in-line with Ghostscript so that the halding of UNICODE file names<br>
- is disabled in the default build.<br>
-<br>
- As with Ghostscript, adding &quot;USEUNICODE=1&quot; to the nmake parameters will enable that code.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-main/pcl6_msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-20 07:20:16 +0100
-</strong>
-<br>Chris Liddell &lt;Chris.Liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=67a924e4b93987d2c915a161ce67bdf9c1d6d4a5">67a924e4b93987d2c915a161ce67bdf9c1d6d4a5</a>
-<blockquote>
-<p>
- Bug 692962: fix endian issue with lcms2 i/face<br>
-<br>
- In the lcms2 interface code, am endian flag was being set on big endian<br>
- platforms, and it shouldn't be.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsicc_lcms2.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-19 14:27:57 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d252b4f9d3a949778894a86bb71cc2206fce11cf">d252b4f9d3a949778894a86bb71cc2206fce11cf</a>
-<blockquote>
-<p>
- Bug 692968: regenerate some appearances.<br>
-<br>
- Regenerate appearance streams when it is requested by the file<br>
- and implemented in PDF interpreter. (NeedAppearances is set)<br>
- Otherwise, continue to use appearance streams provided by the<br>
- file.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-17 10:39: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=2d76c9849ea165176dc836f926ba1604e8e85513">2d76c9849ea165176dc836f926ba1604e8e85513</a>
-<blockquote>
-<p>
- Small change to djet500C device.<br>
-<br>
- Remove an optimisation that seems to cause issues with newer HP Deskjets.<br>
-<br>
- The device previously would determine how much (if any) of the right side<br>
- of a given scanline was blank, and drop those samples - thus avoiding sending<br>
- unmarked samples to the printer.<br>
-<br>
- On recent Deskjets, this resulted those unmarked samples printing black. We<br>
- retain the similar optimisation for skipping entirely unmarked scanlines.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gdevdjtc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-16 10:32: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=adb39bd6b16e20c7c6cf235518fc98ab242552e7">adb39bd6b16e20c7c6cf235518fc98ab242552e7</a>
-<blockquote>
-<p>
- Fix segfault caused by change in zcharx (34f32ee) seen with 11-13.PS.<br>
-<br>
- Under some error conditions, the 'penum' was not being set, and we would<br>
- de-reference whatever (undefined) value was laying around. Initialize it<br>
- to NULL and check before clearing pointers. I couldn't get this to fail<br>
- in a debug or profile build -- only a release build.<br>
-<br>
-gs/psi/zcharx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-16 09:04:39 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=67894626809b89f813d3ed580210ee11da72af52">67894626809b89f813d3ed580210ee11da72af52</a>
-<blockquote>
-<p>
- Fix segfault in 12-13.PS CET. Yet another ref counted pointer not being cleared.<br>
-<br>
-gs/base/gscscie.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-15 16:53:58 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ffedf4d9c97b1f502e47bab7aed8ee2531c3de5c">ffedf4d9c97b1f502e47bab7aed8ee2531c3de5c</a>
-<blockquote>
-<p>
- Fix ref counting of CIEBased 'params' during alloc_restore_all with 11-19.PS CET.<br>
-<br>
- The 'const' had to be broken to allow the pointer to be set to NULL when the object is freed<br>
- due to reference count going to zero. Debug build showed an error message due to ref_count<br>
- going below zero, but since this is referencing freed memory, can cause a segfault.<br>
-<br>
-gs/base/gscscie.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-12 11:55:50 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34f32ee8cb08590aeaaab23d1e14ee48c9932fb2">34f32ee8cb08590aeaaab23d1e14ee48c9932fb2</a>
-<blockquote>
-<p>
- Fix 692707. Clear pointers in text_enum when freeing the widths array.<br>
-<br>
- When an error occurred (as with the CET ILLEGAL test in 33_all.ps) the widths array would be freed,<br>
- but the pointer in the gs_text_enum_t (text.x_widths, text.y_widths) was not cleared.<br>
-<br>
-gs/psi/zcharx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-14 12:52:51 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fd34d1533bfef0ec2a12500ea8b9fe80249cb990">fd34d1533bfef0ec2a12500ea8b9fe80249cb990</a>
-<blockquote>
-<p>
- bmpcmp: Flip psdcmyk images to be the right way up.<br>
-<br>
-gs/toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-13 19:36:36 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=365d6f549be4f8fd289adb06078d568ae37b108a">365d6f549be4f8fd289adb06078d568ae37b108a</a>
-<blockquote>
-<p>
- Update bmpcmp to (at least try to) honour the color mapping for psd spots.<br>
-<br>
- We read the color info for the spots, and we try to apply it when mapping<br>
- down to cmyk. It's entirely possible that the color information needs<br>
- to be inverted or reordered or something, but I don't have anything<br>
- that can display psd files to check.<br>
-<br>
- Talk to Michael about this when he returns. This is better than nothing.<br>
-<br>
-gs/toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-27 03:11:02 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1579963f90d1bfff7fa7e6e7a0417fa8be266b4">d1579963f90d1bfff7fa7e6e7a0417fa8be266b4</a>
-<blockquote>
-<p>
- Support HPGL style path handling.<br>
-<br>
- HPGL handles paths slightly differently to the postscript imaging model.<br>
-<br>
- When a path is filled, successive moveto's are treated as linetos.<br>
- (i.e. the 'place we close the path to' is left at the first moveto,<br>
- and the area remains fillable). Stroking is unaffected however.<br>
-<br>
- To model this in Ghostscript we add a new path segment type 's_gap'.<br>
- The filling code treats this as a lineto. The stroking code is updated<br>
- to not stroke such edges (and not to break the subpath at this point).<br>
-<br>
- We add a new parameter to the imager state (hpgl_path_mode), new<br>
- accessor functions (gs_sethpglpathmode, gs_currenthpglpathmode),<br>
- and new postscript operators (.sethpglpathmode and .currenthpglpathmode).<br>
-<br>
- If hpgl path mode is set to a non-zero value, then path construction<br>
- treats movetos in an open subpath as gaptos.<br>
-<br>
- Currently this is disabled (see pcl/pctop.c for where it would be<br>
- enabled) until we get the pcl interpreter to generate paths in<br>
- exactly the right form.<br>
-<br>
- Still to do:<br>
- * Update PDF write to spot such paths and to convert them as<br>
- appropriate when writing out.<br>
-<br>
-gs/base/gdevpdfd.c<br>
-gs/base/gdevtrac.c<br>
-gs/base/gdevvec.c<br>
-gs/base/gspath.c<br>
-gs/base/gspath1.c<br>
-gs/base/gspenum.h<br>
-gs/base/gsstate.c<br>
-gs/base/gsstate.h<br>
-gs/base/gxclpath.c<br>
-gs/base/gxclpath.h<br>
-gs/base/gxclrast.c<br>
-gs/base/gxcpath.c<br>
-gs/base/gxistate.h<br>
-gs/base/gxline.h<br>
-gs/base/gxpath.c<br>
-gs/base/gxpath.h<br>
-gs/base/gxpath2.c<br>
-gs/base/gxpcopy.c<br>
-gs/base/gxpdash.c<br>
-gs/base/gxstroke.c<br>
-gs/base/gxttfb.c<br>
-gs/base/gzpath.h<br>
-gs/doc/Language.htm<br>
-gs/psi/zgstate.c<br>
-pcl/pctop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-13 18:51:34 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=34b74d7bb34390ad75ba8ca52b6bd5e94e85a51e">34b74d7bb34390ad75ba8ca52b6bd5e94e85a51e</a>
-<blockquote>
-<p>
- bmpcmp: Another attempt to make cmyk + spots psdcmyk files work.<br>
-<br>
- Hopefully this should work; we now make the diff map, then<br>
- convert down to cmyk (by dropping the spots), then convert<br>
- cmyk -&gt; rgb.<br>
-<br>
- Next step is to add the spots into the cmyk as we map down.<br>
-<br>
-gs/toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-13 18:34:00 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=42af17e78ebac4e31e4694d949ef5dfadeacb4fd">42af17e78ebac4e31e4694d949ef5dfadeacb4fd</a>
-<blockquote>
-<p>
- Update bmpcmp so that it saves pngs from bpp &gt; 32 psdcmyk images<br>
-<br>
- I'd forgotten to update the png saving code.<br>
-<br>
-gs/toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-12 16:41: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=35908068027eb9b7d2a6d1adaf371bc9fdeeb800">35908068027eb9b7d2a6d1adaf371bc9fdeeb800</a>
-<blockquote>
-<p>
- Modified to not ignore error codes, no expected differences.<br>
-<br>
-gs/base/gxp1fill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-12 09:34:32 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1b355f679fd03a5d5d334b6d74202d9c3d58110b">1b355f679fd03a5d5d334b6d74202d9c3d58110b</a>
-<blockquote>
-<p>
- Fix 692970 - device reference counting incorrect.<br>
-<br>
- The tile clipping device did not properly release its reference to the<br>
- target device.<br>
-<br>
-gs/base/gxclip2.c<br>
-gs/base/gxclip2.h<br>
-gs/base/gxp1fill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-11 14:42:51 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3769efbb709889aae39f905dd04b72a81bc37f3d">3769efbb709889aae39f905dd04b72a81bc37f3d</a>
-<blockquote>
-<p>
- Fix make clean for GhostPDL.<br>
-<br>
-common/ugcc_top.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-11 09:50: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=42c6f088344544b5e854899e4126e0d3ec4ee496">42c6f088344544b5e854899e4126e0d3ec4ee496</a>
-<blockquote>
-<p>
- Slight hack in gsmchunk.c for Memento builds.<br>
-<br>
- In Memento builds we nobble the chunk manager to only put a single<br>
- block in each chunk. As such, the debugging is much nicer if we<br>
- label the chunks with the block name rather than &quot;chunk_mem_node_add&quot;.<br>
-<br>
-gs/base/gsmchunk.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-10 18:04:39 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ebc8452e68710ace66b3acca4d1701bfa6f59143">ebc8452e68710ace66b3acca4d1701bfa6f59143</a>
-<blockquote>
-<p>
- Add Memento_label calls to gs_heap_alloc_bytes malloc calls.<br>
-<br>
- Should get us a lot more information in the debug output of<br>
- Memento.<br>
-<br>
-gs/base/gsmalloc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-10 17:49:33 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=113beaf41ec17de71a57ffda7324442fe2000623">113beaf41ec17de71a57ffda7324442fe2000623</a>
-<blockquote>
-<p>
- Tidy up pattern accumulator device handling code.<br>
-<br>
- Hopefully slightly more comprehensible. Does the same job as before.<br>
-<br>
-gs/base/gxpcmap.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-09 09:32:12 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=612f02c29f356c44ca72ec31eb6a64b65d7e7d04">612f02c29f356c44ca72ec31eb6a64b65d7e7d04</a>
-<blockquote>
-<p>
- Print out message from bmpcmp.c if no differences detected.<br>
-<br>
-gs/toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-08 15:40:42 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5e0dd327627f3c5dfe50f51ab583b5d696957972">5e0dd327627f3c5dfe50f51ab583b5d696957972</a>
-<blockquote>
-<p>
- Prefaced bmpcmp.c error messages with 'bmpcmp:'.<br>
-<br>
-gs/toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-06 23:43:04 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5431c68e9c666e3c8010202e9501f101f6725d9">b5431c68e9c666e3c8010202e9501f101f6725d9</a>
-<blockquote>
-<p>
- Remove the need for seeking in bmpcmp when reading psdcmyk files.<br>
-<br>
- The cluster likes to drive bmpcmp from pipes.<br>
-<br>
-gs/toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-06 14:22:33 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=554b5c6088a1f53a648b5702a3245bdbba884ffa">554b5c6088a1f53a648b5702a3245bdbba884ffa</a>
-<blockquote>
-<p>
- Fixed bmpcmp.c to properly set *cmyk in psd_read().<br>
-<br>
-gs/toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-06 16:53: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=20dcd26801be3d10bd5ebd596b50eaa3908050be">20dcd26801be3d10bd5ebd596b50eaa3908050be</a>
-<blockquote>
-<p>
- Add psdcmyk support to bmpcmp.<br>
-<br>
- bmpcmp now reads psdcmyk files. It will read all n planes (cmyk +<br>
- spots) and search in them for diffs. When it comes to output<br>
- the differences are highlighted correctly in the diff image,<br>
- but only the cmyk planes are used to create the output images<br>
- (i.e. spots are not mapped down to cmyk currently).<br>
-<br>
-gs/toolbin/bmpcmp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-05 16:21:05 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e97d23a41580b3609a7b98dc90c4a59c6d093e8">8e97d23a41580b3609a7b98dc90c4a59c6d093e8</a>
-<blockquote>
-<p>
- Bug 692967: drop incorrect filter parameters.<br>
-<br>
- Check for an empty array given as filter parameters and<br>
- intrrpret it as no parameters.<br>
-<br>
-gs/Resource/Init/pdf_base.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-05 11:06:36 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c3679722d0c3ade2f644bad1c5b7fafde8de5fb6">c3679722d0c3ade2f644bad1c5b7fafde8de5fb6</a>
-<blockquote>
-<p>
- Add the 32-bit Memento directories to .gitignore<br>
-<br>
-.gitignore<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-02 17:47: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=6e7d591ae3b2dab7808406e6052a4b79b05f2633">6e7d591ae3b2dab7808406e6052a4b79b05f2633</a>
-<blockquote>
-<p>
- Fix a makefile typo....<br>
-<br>
- Back in an previous commit, I made a typo for the cross platform makefile<br>
- variables - I used '_D_' instead of 'D_'<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-04-02 17:08: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=82eb1a659a96fcd834d0e673c7c8f36781499959">82eb1a659a96fcd834d0e673c7c8f36781499959</a>
-<blockquote>
-<p>
- Bug 692761: some errors reported by cppcheck<br>
-<br>
- Patch from Joshua Beck ( jxb091000@utdallas.edu ) addressing issues<br>
- identified by cppcheck.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/genconf.c<br>
-gs/base/gsiomacres.c<br>
-gs/base/mkromfs.c<br>
-gs/psi/dwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-30 13:36:37 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1ff339b6aca7087e32be7516fda9ef0b9df38e72">1ff339b6aca7087e32be7516fda9ef0b9df38e72</a>
-<blockquote>
-<p>
- Bug 692767: Render shading as a group.<br>
-<br>
- Render shading as an isolated group if the file has a soft mask.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-30 11:59:14 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8eb4118573d2d6959f8578a10f9d76ce9d802799">8eb4118573d2d6959f8578a10f9d76ce9d802799</a>
-<blockquote>
-<p>
- PDF interpreter - preserve CIDSystemInfo in embedded CID fonts<br>
-<br>
- The PDF interpreter was not preserving the CIDSystemInfo from CIDFonts in<br>
- PDF files (the TrueType code did not allow for this to be done)<br>
-<br>
- Updated the TrueType CIDFont building code to accept a CIDSystemInfo dictionary<br>
- as a parameter, and teh PDF interpreter to pass it form the original<br>
- CIDFont.<br>
-<br>
- No differences expected as this is not tested<br>
-<br>
-gs/Resource/Init/gs_ttf.ps<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-29 08:50:13 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=67e3458154d8ef718be5a495aa64dc77c59393fe">67e3458154d8ef718be5a495aa64dc77c59393fe</a>
-<blockquote>
-<p>
- Fix bugs 692542 and 692706, bad rendering of copies after first page with NumRenderingThreads &gt; 1<br>
-<br>
- The clist_get_band_from_thread logic would get confused as to the lookahead_direction if the<br>
- requested thread was the first or last and the most recent previously rendered thread didn't<br>
- match.<br>
-<br>
-gs/base/gxclthrd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-29 16:05: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=0604c2368ca3fd75be1c26ce6c7697cbce55968f">0604c2368ca3fd75be1c26ce6c7697cbce55968f</a>
-<blockquote>
-<p>
- Fix a minor compiler warning by casting a pointer.<br>
-<br>
-gs/base/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-29 11:38: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=be6456331f4cff58f11f681450166fe2309e2ad5">be6456331f4cff58f11f681450166fe2309e2ad5</a>
-<blockquote>
-<p>
- pdfwrite - when a Charstring is not found for a glyph use the /.notdef width instead of 0<br>
-<br>
- Bug #692944 the file uses an embedded font which does not include a /space<br>
- glyph, but proceeds to use the space anyway. We were using a widht of 0 in<br>
- this case but the file programmatically spaces glyphs to a predefined size.<br>
- This was causing the PDF to be incorrectly spaced.<br>
-<br>
- We now use the width of the /.notdef glyph instead for sizing calculations,<br>
- since this si the glyph which will eventually be used.<br>
-<br>
- This exhibits a small difference in 30-06.ps but since this is testing<br>
- missing glyphs in a QL test file, I'm going to accept it as a difference in<br>
- order to improve the result with files of this type.<br>
-<br>
-gs/base/gdevpdte.c<br>
-gs/base/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-29 02:23:20 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23e8552bb2c1849c118d9f5d81f5629ebe436acb">23e8552bb2c1849c118d9f5d81f5629ebe436acb</a>
-<blockquote>
-<p>
- Bug 692886: use sequential page numbers in PDF collections.<br>
-<br>
- Use sequential page numbering for -dFirstPage and -dLastPage parameters<br>
- when they are used with PDF Collections.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-28 13:52:27 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aa9f730f07f8d471c222956e6a532ab2698ef58e">aa9f730f07f8d471c222956e6a532ab2698ef58e</a>
-<blockquote>
-<p>
- Fix bug 692688: pdf14_copy_alpha did not move the source data pointer when adjusting for y&lt;rect.p.y<br>
-<br>
- The pdf14_copy_alpha doesn't use the 'fit_copy' macro since that macro has specific variables<br>
- embedded, but the when the 'h' and 'y' are adjusted, the source data pointer needs to move to<br>
- the first line that will be used.<br>
-<br>
-gs/base/gdevp14.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-28 17:03: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=a1075141f25f7bf38bf372f9ccc65dfd9c0c8baa">a1075141f25f7bf38bf372f9ccc65dfd9c0c8baa</a>
-<blockquote>
-<p>
- Bug 692950: further revise falling back to unhinted rendering.<br>
-<br>
- In the FAPI/FT interface, we caught some errors from Freetype to do with the<br>
- byte code hinting in TrueType fonts - when they occur we retry the glyph<br>
- rendering with hinting disabled.<br>
-<br>
- This commit expands that to *any* error from the byte code interpreter will<br>
- now cause us to retry unhinted.<br>
-<br>
- (the core problem in this case seems to be scale depending operations in the<br>
- font program, which is supposed not to be permitted).<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/fapi_ft.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-27 19:29:56 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5b50a46f4ed3e54fec6727a1ad52258e5d32b0a9">5b50a46f4ed3e54fec6727a1ad52258e5d32b0a9</a>
-<blockquote>
-<p>
- Add -sBandListStorage={file|memory} option and default to no bitmap compression if file clist.<br>
-<br>
- Also alphabetize the clist options and remove the arbitrary 10000 minimum for MaxBitmap<br>
- (now -dMaxBitmap=0 is legal). The change to not compress bitmaps (using CCITT) when going<br>
- to disk based clist improves performance.<br>
-<br>
-gs/base/gdevprn.c<br>
-gs/base/gdevprn.h<br>
-gs/base/gxclbits.c<br>
-gs/base/gxclist.c<br>
-gs/base/lib.mak<br>
-gs/doc/Language.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-26 18:57: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=6a13e642324435d92f2f79f6c28b5f25758a249c">6a13e642324435d92f2f79f6c28b5f25758a249c</a>
-<blockquote>
-<p>
- Ensure FAPI uses appropriate glyph name for metrics.<br>
-<br>
- Found investigating a customer 532 report: Ghostscript &quot;augments&quot; glyph names<br>
- under certain circumstances, and depending on the font type, FAPI may have to<br>
- remove that augmentation (mainly when disc based fonts are being used).<br>
-<br>
- FAPI was then using the un-augmented glyph name to read the glyph metrics,<br>
- which caused the wrong metrics to be used because the metrics(s) dictionary was<br>
- created with the augmented glyph name in place.<br>
-<br>
- Causes a difference in the cluster file Bug691031.pdf - this is<br>
- progression.<br>
-<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-26 14:44: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=9ca16b047d2ee4dc862aa18465c80c2250c213c5">9ca16b047d2ee4dc862aa18465c80c2250c213c5</a>
-<blockquote>
-<p>
- Bug 692938: fix link error on AIX<br>
-<br>
- AIX 5.x (probably others) don't have memalign, so update the conditions<br>
- under which openjpeg will (try to) use memalign to exclude AIX systems.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/openjpeg/libopenjpeg/opj_malloc.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-22 15:08:43 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=701b769786f6e2b036df8427c17c6a5dc294a672">701b769786f6e2b036df8427c17c6a5dc294a672</a>
-<blockquote>
-<p>
- pdfwrite - update CIDSet emission for PDF/A-2 compatibility<br>
-<br>
- This completes the work for creation of PDF/A-2 files. Note that Acrobat X<br>
- preflight complains about the CIDSet we include in PDF/A-2 files. However I<br>
- believe that the current code is correct, and that the Acrobat preflight is<br>
- incorrect. The PDF-Tools validator is completely happy with our CIDSet.<br>
-<br>
- I'm unable to fathom what it is the Acrobat preflight tool wants. The old<br>
- PDF/A-1 CIDSet is flagged as invalid, as is every premutation of values I<br>
- can think of.<br>
-<br>
- In the absence of any example file to look at, or a definitive resource on<br>
- the subject, I'm comitting this and concluding the development. I will of<br>
- course be happy to work on the CIDSet emission if someone can bring more<br>
- information.<br>
-<br>
- No differences expected PDF/A is not tested by the cluster.<br>
-<br>
-gs/base/gdevpdtd.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-21 09:36:40 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b68ee69570803001a959721209fff6a2e4430f84">b68ee69570803001a959721209fff6a2e4430f84</a>
-<blockquote>
-<p>
- Improves 692527 - the missing characters now print and the prototype<br>
- svg device now works with many more files.<br>
-<br>
- Before this change very few jobs would work, the color state wasn't<br>
- updated properly.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gdevsvg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-21 14:22: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=8031fd574e3949cf1e17eed0372034e522580dca">8031fd574e3949cf1e17eed0372034e522580dca</a>
-<blockquote>
-<p>
- Bug 692850: FAPI: clamp fixed-point overflows instead of error.<br>
-<br>
- This job ends up with an insanely big scale factor when trying rendering glyphs<br>
- from a font. Obviously that ends up too big to render to a bitmap in the<br>
- font renderer, so we build a path instead.<br>
-<br>
- Previously, during FAPI path extraction, if the coordinates overflowed what we<br>
- can represent in our fixed point representation, give a rangecheck error. But<br>
- the AFS code seems to clamp the coordinate to something we can represent, and<br>
- carry on.<br>
-<br>
- Do the same in FAPI.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/psi/zfapi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-15 11:51: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=0c0f193bc6673fd4c6c257fd8c6fe740882c6023">0c0f193bc6673fd4c6c257fd8c6fe740882c6023</a>
-<blockquote>
-<p>
- Another Freetype fix.<br>
-<br>
- From:<br>
- http://git.savannah.gnu.org/cgit/freetype/freetype2.git/commit/?id=b43e0f44<br>
-<br>
-gs/freetype/src/type1/t1load.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-14 14:49:19 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb20f1cf128936c871e1ccb8161db382e866336a">eb20f1cf128936c871e1ccb8161db382e866336a</a>
-<blockquote>
-<p>
- Backport incremental interface fix from FT git.<br>
-<br>
- http://git.savannah.gnu.org/cgit/freetype/freetype2.git/commit/?id=9a55cb<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/freetype/src/type1/t1load.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-14 14:48:31 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=078d7ccbeb5250c93b758c6566d368c11c1da986">078d7ccbeb5250c93b758c6566d368c11c1da986</a>
-<blockquote>
-<p>
- Update to Freetype 2.4.9<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/freetype/ChangeLog<br>
-gs/freetype/Jamfile<br>
-gs/freetype/README<br>
-gs/freetype/autogen.sh<br>
-gs/freetype/builds/amiga/makefile<br>
-gs/freetype/builds/amiga/makefile.os4<br>
-gs/freetype/builds/amiga/smakefile<br>
-gs/freetype/builds/amiga/src/base/ftsystem.c<br>
-gs/freetype/builds/mac/FreeType.m68k_cfm.make.txt<br>
-gs/freetype/builds/mac/FreeType.m68k_far.make.txt<br>
-gs/freetype/builds/mac/FreeType.ppc_carbon.make.txt<br>
-gs/freetype/builds/mac/FreeType.ppc_classic.make.txt<br>
-gs/freetype/builds/mac/ftmac.c<br>
-gs/freetype/builds/symbian/bld.inf<br>
-gs/freetype/builds/symbian/freetype.mmp<br>
-gs/freetype/builds/toplevel.mk<br>
-gs/freetype/builds/unix/.gitignore<br>
-gs/freetype/builds/unix/aclocal.m4<br>
-gs/freetype/builds/unix/config.guess<br>
-gs/freetype/builds/unix/config.sub<br>
-gs/freetype/builds/unix/configure<br>
-gs/freetype/builds/unix/configure.ac<br>
-gs/freetype/builds/unix/configure.raw<br>
-gs/freetype/builds/unix/detect.mk<br>
-gs/freetype/builds/unix/freetype-config.in<br>
-gs/freetype/builds/unix/freetype2.in<br>
-gs/freetype/builds/unix/ftconfig.in<br>
-gs/freetype/builds/unix/install-sh<br>
-gs/freetype/builds/unix/ltmain.sh<br>
-gs/freetype/builds/vms/ftconfig.h<br>
-gs/freetype/builds/vms/ftsystem.c<br>
-gs/freetype/builds/win32/vc2005/freetype.vcproj<br>
-gs/freetype/builds/win32/vc2005/index.html<br>
-gs/freetype/builds/win32/vc2008/freetype.vcproj<br>
-gs/freetype/builds/win32/vc2008/index.html<br>
-gs/freetype/builds/win32/vc2010/freetype.sln<br>
-gs/freetype/builds/win32/vc2010/freetype.vcxproj<br>
-gs/freetype/builds/win32/vc2010/freetype.vcxproj.filters<br>
-gs/freetype/builds/win32/vc2010/index.html<br>
-gs/freetype/builds/win32/visualc/freetype.dsp<br>
-gs/freetype/builds/win32/visualc/freetype.vcproj<br>
-gs/freetype/builds/win32/visualc/index.html<br>
-gs/freetype/builds/win32/visualce/freetype.dsp<br>
-gs/freetype/builds/win32/visualce/freetype.vcproj<br>
-gs/freetype/builds/win32/visualce/index.html<br>
-gs/freetype/builds/wince/vc2005-ce/freetype.vcproj<br>
-gs/freetype/builds/wince/vc2005-ce/index.html<br>
-gs/freetype/builds/wince/vc2008-ce/freetype.vcproj<br>
-gs/freetype/builds/wince/vc2008-ce/index.html<br>
-gs/freetype/configure<br>
-gs/freetype/devel/ftoption.h<br>
-gs/freetype/docs/CHANGES<br>
-gs/freetype/docs/GPL.TXT<br>
-gs/freetype/docs/GPLv2.TXT<br>
-gs/freetype/docs/INSTALL<br>
-gs/freetype/docs/INSTALL.ANY<br>
-gs/freetype/docs/INSTALL.UNIX<br>
-gs/freetype/docs/LICENSE.TXT<br>
-gs/freetype/docs/PROBLEMS<br>
-gs/freetype/docs/UPGRADE.UNIX<br>
-gs/freetype/docs/VERSION.DLL<br>
-gs/freetype/docs/formats.txt<br>
-gs/freetype/docs/reference/.gitignore<br>
-gs/freetype/docs/reference/ft2-base_interface.html<br>
-gs/freetype/docs/reference/ft2-basic_types.html<br>
-gs/freetype/docs/reference/ft2-bdf_fonts.html<br>
-gs/freetype/docs/reference/ft2-bitmap_handling.html<br>
-gs/freetype/docs/reference/ft2-bzip2.html<br>
-gs/freetype/docs/reference/ft2-cache_subsystem.html<br>
-gs/freetype/docs/reference/ft2-cid_fonts.html<br>
-gs/freetype/docs/reference/ft2-computations.html<br>
-gs/freetype/docs/reference/ft2-font_formats.html<br>
-gs/freetype/docs/reference/ft2-gasp_table.html<br>
-gs/freetype/docs/reference/ft2-glyph_management.html<br>
-gs/freetype/docs/reference/ft2-glyph_stroker.html<br>
-gs/freetype/docs/reference/ft2-glyph_variants.html<br>
-gs/freetype/docs/reference/ft2-gx_validation.html<br>
-gs/freetype/docs/reference/ft2-gzip.html<br>
-gs/freetype/docs/reference/ft2-header_file_macros.html<br>
-gs/freetype/docs/reference/ft2-incremental.html<br>
-gs/freetype/docs/reference/ft2-index.html<br>
-gs/freetype/docs/reference/ft2-lcd_filtering.html<br>
-gs/freetype/docs/reference/ft2-list_processing.html<br>
-gs/freetype/docs/reference/ft2-lzw.html<br>
-gs/freetype/docs/reference/ft2-mac_specific.html<br>
-gs/freetype/docs/reference/ft2-module_management.html<br>
-gs/freetype/docs/reference/ft2-multiple_masters.html<br>
-gs/freetype/docs/reference/ft2-ot_validation.html<br>
-gs/freetype/docs/reference/ft2-outline_processing.html<br>
-gs/freetype/docs/reference/ft2-pfr_fonts.html<br>
-gs/freetype/docs/reference/ft2-quick_advance.html<br>
-gs/freetype/docs/reference/ft2-raster.html<br>
-gs/freetype/docs/reference/ft2-sfnt_names.html<br>
-gs/freetype/docs/reference/ft2-sizes_management.html<br>
-gs/freetype/docs/reference/ft2-system_interface.html<br>
-gs/freetype/docs/reference/ft2-toc.html<br>
-gs/freetype/docs/reference/ft2-truetype_engine.html<br>
-gs/freetype/docs/reference/ft2-truetype_tables.html<br>
-gs/freetype/docs/reference/ft2-type1_tables.html<br>
-gs/freetype/docs/reference/ft2-user_allocation.html<br>
-gs/freetype/docs/reference/ft2-version.html<br>
-gs/freetype/docs/reference/ft2-winfnt_fonts.html<br>
-gs/freetype/docs/release<br>
-gs/freetype/include/freetype/config/ftconfig.h<br>
-gs/freetype/include/freetype/config/ftheader.h<br>
-gs/freetype/include/freetype/config/ftoption.h<br>
-gs/freetype/include/freetype/config/ftstdlib.h<br>
-gs/freetype/include/freetype/freetype.h<br>
-gs/freetype/include/freetype/ftbbox.h<br>
-gs/freetype/include/freetype/ftbzip2.h<br>
-gs/freetype/include/freetype/ftcache.h<br>
-gs/freetype/include/freetype/ftchapters.h<br>
-gs/freetype/include/freetype/fterrdef.h<br>
-gs/freetype/include/freetype/fterrors.h<br>
-gs/freetype/include/freetype/ftgasp.h<br>
-gs/freetype/include/freetype/ftglyph.h<br>
-gs/freetype/include/freetype/ftmoderr.h<br>
-gs/freetype/include/freetype/ftoutln.h<br>
-gs/freetype/include/freetype/ftrender.h<br>
-gs/freetype/include/freetype/ftstroke.h<br>
-gs/freetype/include/freetype/fttypes.h<br>
-gs/freetype/include/freetype/internal/autohint.h<br>
-gs/freetype/include/freetype/internal/ftdriver.h<br>
-gs/freetype/include/freetype/internal/ftobjs.h<br>
-gs/freetype/include/freetype/internal/ftpic.h<br>
-gs/freetype/include/freetype/internal/ftrfork.h<br>
-gs/freetype/include/freetype/internal/ftserv.h<br>
-gs/freetype/include/freetype/internal/ftstream.h<br>
-gs/freetype/include/freetype/internal/fttrace.h<br>
-gs/freetype/include/freetype/internal/pcftypes.h<br>
-gs/freetype/include/freetype/internal/pshints.h<br>
-gs/freetype/include/freetype/internal/services/svbdf.h<br>
-gs/freetype/include/freetype/internal/services/svcid.h<br>
-gs/freetype/include/freetype/internal/services/svgldict.h<br>
-gs/freetype/include/freetype/internal/services/svmm.h<br>
-gs/freetype/include/freetype/internal/services/svpostnm.h<br>
-gs/freetype/include/freetype/internal/services/svpscmap.h<br>
-gs/freetype/include/freetype/internal/services/svpsinfo.h<br>
-gs/freetype/include/freetype/internal/services/svsfnt.h<br>
-gs/freetype/include/freetype/internal/services/svttcmap.h<br>
-gs/freetype/include/freetype/internal/services/svttglyf.h<br>
-gs/freetype/include/freetype/internal/sfnt.h<br>
-gs/freetype/include/freetype/internal/t1types.h<br>
-gs/freetype/include/freetype/internal/tttypes.h<br>
-gs/freetype/include/freetype/t1tables.h<br>
-gs/freetype/include/freetype/tttables.h<br>
-gs/freetype/modules.cfg<br>
-gs/freetype/objs/.gitignore<br>
-gs/freetype/src/autofit/afangles.c<br>
-gs/freetype/src/autofit/afcjk.c<br>
-gs/freetype/src/autofit/afcjk.h<br>
-gs/freetype/src/autofit/afdummy.c<br>
-gs/freetype/src/autofit/afdummy.h<br>
-gs/freetype/src/autofit/aferrors.h<br>
-gs/freetype/src/autofit/afglobal.c<br>
-gs/freetype/src/autofit/afglobal.h<br>
-gs/freetype/src/autofit/afhints.c<br>
-gs/freetype/src/autofit/afhints.h<br>
-gs/freetype/src/autofit/afindic.c<br>
-gs/freetype/src/autofit/aflatin.c<br>
-gs/freetype/src/autofit/aflatin.h<br>
-gs/freetype/src/autofit/aflatin2.c<br>
-gs/freetype/src/autofit/afloader.c<br>
-gs/freetype/src/autofit/afloader.h<br>
-gs/freetype/src/autofit/afmodule.c<br>
-gs/freetype/src/autofit/afpic.c<br>
-gs/freetype/src/autofit/afpic.h<br>
-gs/freetype/src/autofit/aftypes.h<br>
-gs/freetype/src/autofit/afwarp.c<br>
-gs/freetype/src/autofit/autofit.c<br>
-gs/freetype/src/autofit/rules.mk<br>
-gs/freetype/src/base/basepic.c<br>
-gs/freetype/src/base/basepic.h<br>
-gs/freetype/src/base/ftadvanc.c<br>
-gs/freetype/src/base/ftbase.c<br>
-gs/freetype/src/base/ftbase.h<br>
-gs/freetype/src/base/ftbitmap.c<br>
-gs/freetype/src/base/ftcalc.c<br>
-gs/freetype/src/base/ftdbgmem.c<br>
-gs/freetype/src/base/ftglyph.c<br>
-gs/freetype/src/base/ftinit.c<br>
-gs/freetype/src/base/ftmac.c<br>
-gs/freetype/src/base/ftobjs.c<br>
-gs/freetype/src/base/ftoutln.c<br>
-gs/freetype/src/base/ftpatent.c<br>
-gs/freetype/src/base/ftpic.c<br>
-gs/freetype/src/base/ftrfork.c<br>
-gs/freetype/src/base/ftstream.c<br>
-gs/freetype/src/base/ftstroke.c<br>
-gs/freetype/src/base/ftsystem.c<br>
-gs/freetype/src/base/fttype1.c<br>
-gs/freetype/src/bdf/README<br>
-gs/freetype/src/bdf/bdf.h<br>
-gs/freetype/src/bdf/bdfdrivr.c<br>
-gs/freetype/src/bdf/bdfdrivr.h<br>
-gs/freetype/src/bdf/bdferror.h<br>
-gs/freetype/src/bdf/bdflib.c<br>
-gs/freetype/src/bzip2/Jamfile<br>
-gs/freetype/src/bzip2/ftbzip2.c<br>
-gs/freetype/src/bzip2/rules.mk<br>
-gs/freetype/src/cache/ftcbasic.c<br>
-gs/freetype/src/cache/ftccache.c<br>
-gs/freetype/src/cache/ftccache.h<br>
-gs/freetype/src/cache/ftccback.h<br>
-gs/freetype/src/cache/ftccmap.c<br>
-gs/freetype/src/cache/ftcerror.h<br>
-gs/freetype/src/cache/ftcglyph.c<br>
-gs/freetype/src/cache/ftcglyph.h<br>
-gs/freetype/src/cache/ftcmanag.c<br>
-gs/freetype/src/cache/ftcmanag.h<br>
-gs/freetype/src/cache/ftcmru.c<br>
-gs/freetype/src/cache/ftcsbits.c<br>
-gs/freetype/src/cache/ftcsbits.h<br>
-gs/freetype/src/cff/cffdrivr.c<br>
-gs/freetype/src/cff/cfferrs.h<br>
-gs/freetype/src/cff/cffgload.c<br>
-gs/freetype/src/cff/cffload.c<br>
-gs/freetype/src/cff/cffload.h<br>
-gs/freetype/src/cff/cffobjs.c<br>
-gs/freetype/src/cff/cffparse.c<br>
-gs/freetype/src/cff/cffparse.h<br>
-gs/freetype/src/cff/cffpic.c<br>
-gs/freetype/src/cff/cffpic.h<br>
-gs/freetype/src/cff/cfftoken.h<br>
-gs/freetype/src/cff/cfftypes.h<br>
-gs/freetype/src/cff/rules.mk<br>
-gs/freetype/src/cid/ciderrs.h<br>
-gs/freetype/src/cid/cidgload.c<br>
-gs/freetype/src/cid/cidload.c<br>
-gs/freetype/src/cid/cidobjs.c<br>
-gs/freetype/src/cid/cidparse.c<br>
-gs/freetype/src/cid/cidriver.c<br>
-gs/freetype/src/cid/cidriver.h<br>
-gs/freetype/src/gxvalid/gxvcommn.c<br>
-gs/freetype/src/gxvalid/gxvcommn.h<br>
-gs/freetype/src/gxvalid/gxverror.h<br>
-gs/freetype/src/gxvalid/gxvfeat.c<br>
-gs/freetype/src/gxvalid/gxvjust.c<br>
-gs/freetype/src/gxvalid/gxvkern.c<br>
-gs/freetype/src/gxvalid/gxvmod.c<br>
-gs/freetype/src/gxvalid/gxvmod.h<br>
-gs/freetype/src/gxvalid/gxvmort.c<br>
-gs/freetype/src/gxvalid/gxvmort0.c<br>
-gs/freetype/src/gxvalid/gxvmort1.c<br>
-gs/freetype/src/gxvalid/gxvmort2.c<br>
-gs/freetype/src/gxvalid/gxvmort5.c<br>
-gs/freetype/src/gxvalid/gxvmorx.c<br>
-gs/freetype/src/gxvalid/gxvmorx0.c<br>
-gs/freetype/src/gxvalid/gxvmorx1.c<br>
-gs/freetype/src/gxvalid/gxvmorx2.c<br>
-gs/freetype/src/gxvalid/gxvmorx5.c<br>
-gs/freetype/src/gxvalid/gxvprop.c<br>
-gs/freetype/src/gxvalid/gxvtrak.c<br>
-gs/freetype/src/gzip/ftgzip.c<br>
-gs/freetype/src/lzw/ftlzw.c<br>
-gs/freetype/src/lzw/ftzopen.c<br>
-gs/freetype/src/otvalid/otverror.h<br>
-gs/freetype/src/otvalid/otvmod.c<br>
-gs/freetype/src/otvalid/otvmod.h<br>
-gs/freetype/src/pcf/README<br>
-gs/freetype/src/pcf/pcf.h<br>
-gs/freetype/src/pcf/pcfdrivr.c<br>
-gs/freetype/src/pcf/pcfdrivr.h<br>
-gs/freetype/src/pcf/pcferror.h<br>
-gs/freetype/src/pcf/pcfread.c<br>
-gs/freetype/src/pfr/pfrdrivr.c<br>
-gs/freetype/src/pfr/pfrdrivr.h<br>
-gs/freetype/src/pfr/pfrerror.h<br>
-gs/freetype/src/pfr/pfrload.c<br>
-gs/freetype/src/pfr/pfrobjs.c<br>
-gs/freetype/src/psaux/afmparse.c<br>
-gs/freetype/src/psaux/psauxerr.h<br>
-gs/freetype/src/psaux/psauxmod.c<br>
-gs/freetype/src/psaux/psauxmod.h<br>
-gs/freetype/src/psaux/psconv.c<br>
-gs/freetype/src/psaux/psobjs.c<br>
-gs/freetype/src/psaux/t1cmap.c<br>
-gs/freetype/src/psaux/t1decode.c<br>
-gs/freetype/src/pshinter/pshnterr.h<br>
-gs/freetype/src/pshinter/pshpic.c<br>
-gs/freetype/src/pshinter/pshpic.h<br>
-gs/freetype/src/pshinter/rules.mk<br>
-gs/freetype/src/psnames/psmodule.c<br>
-gs/freetype/src/psnames/psnamerr.h<br>
-gs/freetype/src/psnames/pspic.c<br>
-gs/freetype/src/psnames/pspic.h<br>
-gs/freetype/src/psnames/pstables.h<br>
-gs/freetype/src/psnames/rules.mk<br>
-gs/freetype/src/raster/ftraster.c<br>
-gs/freetype/src/raster/ftrend1.c<br>
-gs/freetype/src/raster/rasterrs.h<br>
-gs/freetype/src/raster/rastpic.c<br>
-gs/freetype/src/raster/rastpic.h<br>
-gs/freetype/src/raster/rules.mk<br>
-gs/freetype/src/sfnt/rules.mk<br>
-gs/freetype/src/sfnt/sfdriver.c<br>
-gs/freetype/src/sfnt/sferrors.h<br>
-gs/freetype/src/sfnt/sfntpic.c<br>
-gs/freetype/src/sfnt/sfntpic.h<br>
-gs/freetype/src/sfnt/sfobjs.c<br>
-gs/freetype/src/sfnt/ttcmap.c<br>
-gs/freetype/src/sfnt/ttcmap.h<br>
-gs/freetype/src/sfnt/ttload.c<br>
-gs/freetype/src/sfnt/ttmtx.c<br>
-gs/freetype/src/sfnt/ttsbit.c<br>
-gs/freetype/src/smooth/ftgrays.c<br>
-gs/freetype/src/smooth/ftsmerrs.h<br>
-gs/freetype/src/smooth/ftsmooth.c<br>
-gs/freetype/src/smooth/ftspic.c<br>
-gs/freetype/src/smooth/ftspic.h<br>
-gs/freetype/src/smooth/rules.mk<br>
-gs/freetype/src/tools/apinames.c<br>
-gs/freetype/src/tools/docmaker/.gitignore<br>
-gs/freetype/src/tools/glnames.py<br>
-gs/freetype/src/truetype/rules.mk<br>
-gs/freetype/src/truetype/ttdriver.c<br>
-gs/freetype/src/truetype/tterrors.h<br>
-gs/freetype/src/truetype/ttgload.c<br>
-gs/freetype/src/truetype/ttgload.h<br>
-gs/freetype/src/truetype/ttgxvar.c<br>
-gs/freetype/src/truetype/ttinterp.c<br>
-gs/freetype/src/truetype/ttinterp.h<br>
-gs/freetype/src/truetype/ttobjs.c<br>
-gs/freetype/src/truetype/ttobjs.h<br>
-gs/freetype/src/truetype/ttpic.c<br>
-gs/freetype/src/truetype/ttpic.h<br>
-gs/freetype/src/truetype/ttpload.c<br>
-gs/freetype/src/type1/t1afm.c<br>
-gs/freetype/src/type1/t1driver.c<br>
-gs/freetype/src/type1/t1driver.h<br>
-gs/freetype/src/type1/t1errors.h<br>
-gs/freetype/src/type1/t1gload.c<br>
-gs/freetype/src/type1/t1gload.h<br>
-gs/freetype/src/type1/t1load.c<br>
-gs/freetype/src/type1/t1objs.c<br>
-gs/freetype/src/type1/t1objs.h<br>
-gs/freetype/src/type1/t1parse.c<br>
-gs/freetype/src/type1/t1tokens.h<br>
-gs/freetype/src/type42/t42drivr.c<br>
-gs/freetype/src/type42/t42drivr.h<br>
-gs/freetype/src/type42/t42error.h<br>
-gs/freetype/src/type42/t42objs.c<br>
-gs/freetype/src/type42/t42objs.h<br>
-gs/freetype/src/type42/t42parse.c<br>
-gs/freetype/src/winfonts/fnterrs.h<br>
-gs/freetype/src/winfonts/winfnt.c<br>
-gs/freetype/src/winfonts/winfnt.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-20 16:56:36 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dcf401ee8172aaff5363b2fc86e166f73225e429">dcf401ee8172aaff5363b2fc86e166f73225e429</a>
-<blockquote>
-<p>
- Close the device before exiting PCL, XPS and friends.<br>
-<br>
- The languages deallocated the memory associated with a device but<br>
- never did the associated gs_closedevice(). This might have some<br>
- effect on 692816 where indeterminate output was observed on stdout.<br>
- Without the close device call the &quot;OutputFile&quot; was never actually<br>
- closed (fclose), and so there might have been a missing flush. All of<br>
- that is speculation, I wasn't able to reproduce the indeterminism -<br>
- but we want the closedevice anyway so here it is.<br>
-<br>
-pl/plmain.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-20 11:35:04 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=731707a165665554577d3779fdeb93eb49ab2a52">731707a165665554577d3779fdeb93eb49ab2a52</a>
-<blockquote>
-<p>
- Fix Visual Studio PROFILE=1 builds so that Instrumented performance analyzer works.<br>
-<br>
- We were missing the /PROFILE linker option.<br>
-<br>
-gs/psi/msvc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-19 18:02:47 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a2371ed3ee29b5470dd892b78249d64d8f4466f4">a2371ed3ee29b5470dd892b78249d64d8f4466f4</a>
-<blockquote>
-<p>
- Clean up warnings.<br>
-<br>
- Clean up a couple of warnings I introduced in:<br>
- f63237e1bb9a85124349ec0d0eae58737d7cb5ee<br>
-<br>
- No cluster differences expected.<br>
-<br>
-gs/base/gxccache.c<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-19 10:06:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d6f83dfa81a2073c3d1f67a30aee7e8407e4685a">d6f83dfa81a2073c3d1f67a30aee7e8407e4685a</a>
-<blockquote>
-<p>
- ps2write - work-around bugs in Brother printer CCITTFaxDecode filter<br>
-<br>
- Raised on irc by Till Kamppeter, see Ubuntu bug :<br>
-<br>
- https://bugs.launchpad.net/ubuntu/+source/cups/+bug/955553<br>
-<br>
- After much work by Chris Liddell and Bruce Stough it transpires that at<br>
- least some Brother printers have a bug in their CCITTFaxDecode filter,<br>
- especially with small amounts of data.<br>
-<br>
- Since the ps2write otuput for bitmapped glyhs (which is required when the<br>
- input is a CIDFont) always uses the CCITTFax filter, this led to corrupted<br>
- output from the Brother (Note this is a bug in the *printer* not ps2write)<br>
-<br>
- This patch adds a new command line parameter 'NoT3CCITT' which disables<br>
- compression of bitmapped glyphs. It should only be used with printers which<br>
- have a problem with CCITTFax data, and in that case should also be used with<br>
- the EncodeMonoImages switch to disable compression of monochrome images. Eg:<br>
-<br>
- -dNoT3CCITT -dEncodeMonoImages=false<br>
-<br>
- No differences expected as these are not tested by our regression tests<br>
-<br>
-gs/base/gdevpdfb.c<br>
-gs/base/gdevpdfb.h<br>
-gs/base/gdevpdfp.c<br>
-gs/base/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-18 22:34:39 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c558e93a7f63b470880ea44fbf883c61de4b13a">1c558e93a7f63b470880ea44fbf883c61de4b13a</a>
-<blockquote>
-<p>
- Bug 692589: Copy CIDSystemInfo from PDF to CMap<br>
-<br>
- Collect CIDSystemInfo attributes from PDF CMap dictionary and copy<br>
- them to the embedded CMap resource.<br>
-<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-16 14:25:06 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2cd895c6ad8e4e1ace368d04a783bf0cccb30f3c">2cd895c6ad8e4e1ace368d04a783bf0cccb30f3c</a>
-<blockquote>
-<p>
- Fixes Bug 692931 - Regression: seg fault<br>
-<br>
- The ICC parameters were set when the interpreter was allocated before<br>
- the the command line options were actually set, resulting in a crash.<br>
-<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-16 09:35:53 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=25b6a2cdeb5a90bb7803958f2bf15b618fbcf120">25b6a2cdeb5a90bb7803958f2bf15b618fbcf120</a>
-<blockquote>
-<p>
- pdfwrite - cure memory leaks caused by 'aside' streams<br>
-<br>
- When writing an object it can happen that pdfwrite needs to write another<br>
- object (Eg a ToUnicode CMap in a font), it does this with an 'aside' which<br>
- opens a Ghostscritp stream to contain the data.<br>
-<br>
- The code to do this uses low level access to the stream code, but it did<br>
- not previously correctly free the memory used by the stream and its associated<br>
- buffer leading to memory leaks.<br>
-<br>
- By closing the entire stream when we close the filters we get the stream and<br>
- all its memory freed, so we do that here to cure the memory leak.<br>
-<br>
- Inspecting the four other cases in the pdfwrite code they appear to be OK.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gdevpdti.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-16 00:51:54 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ca6e4653abdc2921e44f416633b7d5e4bc5f4382">ca6e4653abdc2921e44f416633b7d5e4bc5f4382</a>
-<blockquote>
-<p>
- Add indexed color space support to the ICC extraction tool.<br>
-<br>
- Recognize ICC color spaces referenced by indexed color spaces and<br>
- process them the same way as stand-alone ICC color spaces.<br>
-<br>
-gs/toolbin/extractICCprofiles.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-15 12:07:51 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=044b6ca010ecb8f264fcd4b3515051c037659967">044b6ca010ecb8f264fcd4b3515051c037659967</a>
-<blockquote>
-<p>
- Fix for broken setting of Default ICC profiles<br>
-<br>
- A recent change http://git.ghostscript.com/?p=ghostpdl.git;a=commit;h=d6f504174bd51d22cc43b2f87bee8c275c004cc1<br>
- broke the ability to set the profiles. Previously there was a check in gsicc_set_profile to<br>
- avoid reseting the profiles. Once removed, the call from gsicc_init_manager was always blowing<br>
- away any non default settings for the defaults. A check was added into gsicc_init_manager to<br>
- avoid this.<br>
-<br>
-gs/base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-15 09:58:51 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=72fe9304f98beff3c97347d6e402bb812136de49">72fe9304f98beff3c97347d6e402bb812136de49</a>
-<blockquote>
-<p>
- Fix for memory issue in icc user params<br>
-<br>
- The icc user parameters where improperly being set as being persistent<br>
- for the user params list when they were not. In the case when we are<br>
- using the output intent profile, one of the default profiles is freed<br>
- and replaced by the output intent profile. In this case, the default<br>
- profile contained the string that was used for the user params. During<br>
- a VMreclaim, we would then go and restore the user params and<br>
- unfortunately this default one had been freed.<br>
-<br>
-gs/base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-14 09:15:36 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=82d1d263a13ccfe64e78cd0e6f1cf1a275adcb9c">82d1d263a13ccfe64e78cd0e6f1cf1a275adcb9c</a>
-<blockquote>
-<p>
- Update of Use.htm to include description of -dUsePDFX3Profile<br>
-<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-02 10:52:19 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d8c46688c07cec9e58f492223d1a9c92f4374e4">1d8c46688c07cec9e58f492223d1a9c92f4374e4</a>
-<blockquote>
-<p>
- Output Intent Implementation Part 2<br>
-<br>
- The interpreter part of the output intent plus fixes in the c code.<br>
- Thanks to Alex for his help on this.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-gs/Resource/Init/pdf_main.ps<br>
-gs/base/gsicc_manage.c<br>
-gs/psi/zicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-13 22:45:00 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0eae84aaf7a1c27f077d4aff3050ae48bb5a6aaa">0eae84aaf7a1c27f077d4aff3050ae48bb5a6aaa</a>
-<blockquote>
-<p>
- Fix for broken tiff devices due to use of huge signed number in overflow test<br>
-<br>
- 0xFFFFFFFF is used in a calculation to see how close we are to the 4G limit in<br>
- a tiff file. Problem was this was cast as a long which, in a 32 bit<br>
- system ends up being -1.<br>
-<br>
-gs/base/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-13 10:13: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=aa131f2321abe0e65415242a4563fbf3fba005fa">aa131f2321abe0e65415242a4563fbf3fba005fa</a>
-<blockquote>
-<p>
- Make -dPDFA backwards compatible, equivalent to -dPDFA=1<br>
-<br>
- As of commit d0371d9 the actual device parameter was changed to be an int.<br>
- This change detects if it is defined as a boolean and sets it to 1 if so.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-13 09:37: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=d21eb36fda00dcfefc2e65c2202cb0536562385d">d21eb36fda00dcfefc2e65c2202cb0536562385d</a>
-<blockquote>
-<p>
- pdfwrite - correction to PDF/A processing<br>
-<br>
- The previous commit for PDF/A prcoessing did not properly check the PDF/A<br>
- level in the PostScript handlers, and treated any setting as being PDF/A.<br>
- In fact only settings greater than 0 shuold be checked, 0 means 'not PDF/A'<br>
-<br>
- Add code in gdev_pdf_put_params to ensure that PDFA has a permitted value<br>
- (0-&gt;2) and signal rangecheck if not.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/Resource/Init/gs_cspace.ps<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-gs/base/gdevpdfp.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-13 09:20:59 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d0371d915bae6b3d52487d49e470b0e560837ab2">d0371d915bae6b3d52487d49e470b0e560837ab2</a>
-<blockquote>
-<p>
- pdfwrite - first pass at PDF/A-2 output<br>
-<br>
- This is the first part of making it possible to produce PDF/A-2b output from<br>
- pdfwrite.<br>
-<br>
- The PDFA switch has changed from a boolean to an integer, where the value gives<br>
- the level of PDF/A compatibility. This has knock-on effects throughout the<br>
- C and PostScript code which has been revised to expect an integer instead<br>
- of boolean value.<br>
-<br>
- When PDFA has the value 2 we no longer flatten transparency, and we write<br>
- '2' in the pdfaid field in the XMP metadata.<br>
-<br>
- PDF/A-1b output still seems to work correctly, but it is unlikely that the<br>
- work so far is sufficient for correct PDF/A-2 output.<br>
-<br>
- No differences expected as the cluster does not test PDF/A output.<br>
-<br>
-gs/Resource/Init/gs_cspace.ps<br>
-gs/Resource/Init/gs_pdfwr.ps<br>
-gs/base/gdevpdfb.c<br>
-gs/base/gdevpdfc.c<br>
-gs/base/gdevpdfe.c<br>
-gs/base/gdevpdfg.c<br>
-gs/base/gdevpdfj.c<br>
-gs/base/gdevpdfm.c<br>
-gs/base/gdevpdfo.c<br>
-gs/base/gdevpdfp.c<br>
-gs/base/gdevpdfu.c<br>
-gs/base/gdevpdfx.h<br>
-gs/base/gdevpdtb.c<br>
-gs/base/gdevpdtd.c<br>
-gs/base/gdevpdte.c<br>
-gs/base/gdevpdtf.c<br>
-gs/base/gdevpdti.c<br>
-gs/base/gdevpdtt.c<br>
-gs/base/gdevpdtw.c<br>
-gs/doc/Ps2pdf.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-12 21:57:09 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bdcf6ae7c1dab92c48715982ae804211dc558a78">bdcf6ae7c1dab92c48715982ae804211dc558a78</a>
-<blockquote>
-<p>
- Bug 692851: Implement the case of bps &lt; 8 for Luratech JPX decoder<br>
-<br>
- Implement a missing case of Luratech JPX with components &gt; 1, and<br>
- bps &lt; 8. Also fix incorrect bit shift calculation in OpenJpeg<br>
- part.<br>
-<br>
-gs/base/sjpx_luratech.c<br>
-gs/base/sjpx_openjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-10 00:15:41 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5352d4cf5b3fd17a22b4a126fe5d5fdceb0ad7b6">5352d4cf5b3fd17a22b4a126fe5d5fdceb0ad7b6</a>
-<blockquote>
-<p>
- Revert &quot;Support HPGL style path handling. (Work in progress)&quot;<br>
-<br>
- This reverts commit 93bf2df8f6a6b2ed60a8c3f5037865b8646243db.<br>
-<br>
-gs/base/gdevpdfd.c<br>
-gs/base/gdevtrac.c<br>
-gs/base/gdevvec.c<br>
-gs/base/gspath.c<br>
-gs/base/gspath1.c<br>
-gs/base/gspenum.h<br>
-gs/base/gsstate.c<br>
-gs/base/gsstate.h<br>
-gs/base/gxclpath.c<br>
-gs/base/gxcpath.c<br>
-gs/base/gxistate.h<br>
-gs/base/gxline.h<br>
-gs/base/gxpath.c<br>
-gs/base/gxpath.h<br>
-gs/base/gxpath2.c<br>
-gs/base/gxpcopy.c<br>
-gs/base/gxpdash.c<br>
-gs/base/gxstroke.c<br>
-gs/base/gxttfb.c<br>
-gs/base/gzpath.h<br>
-gs/psi/zgstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-09 15:31:50 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b89c0e35a15e3a786da346d3cd63d0c558a9fb6a">b89c0e35a15e3a786da346d3cd63d0c558a9fb6a</a>
-<blockquote>
-<p>
- Hack to fix memento.c build problem on Mac OS X.<br>
-<br>
-gs/base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-09 13:53:55 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc98b15546522ce28edad3f129f1ae8e05300a34">dc98b15546522ce28edad3f129f1ae8e05300a34</a>
-<blockquote>
-<p>
- Change compression of the tiffsep device composite output to match the separations.<br>
-<br>
- Previous to this commit the tiffsep device would always write out<br>
- an uncompressed composite file; the separation files were lzw<br>
- compressed by default and this could be changed via the -sCompression=<br>
- option. Now the compression of the composite file is the same as<br>
- that of the separation files.<br>
-<br>
- Fixes Bug 692907.<br>
-<br>
-gs/base/gdevtsep.c<br>
-gs/doc/Devices.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-27 03:11:02 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=93bf2df8f6a6b2ed60a8c3f5037865b8646243db">93bf2df8f6a6b2ed60a8c3f5037865b8646243db</a>
-<blockquote>
-<p>
- Support HPGL style path handling. (Work in progress)<br>
-<br>
- HPGL handles paths slightly differently to the postscript imaging model.<br>
-<br>
- When a path is filled, successive moveto's are treated as linetos.<br>
- (i.e. the 'place we close the path to' is left at the first moveto,<br>
- and the area remains fillable). Stroking is unaffected however.<br>
-<br>
- To model this in Ghostscript we add a new path segment type 's_gap'.<br>
- The filling code treats this as a lineto. The stroking code is updated<br>
- to not stroke such edges (and not to break the subpath at this point).<br>
-<br>
- We add a new parameter to the imager state (hpgl_fill_mode), new<br>
- accessor functions (gs_sethpglfillmode, gs_currenthpglfillmode),<br>
- and new postscript operators (.sethpglfillmode and .currenthpglfillmode).<br>
-<br>
- If hpgl fill mode is set to a non-zero value, then path construction<br>
- treats movetos in an open subpath as gaptos.<br>
-<br>
- Still to do:<br>
- * Double check the output from this code matches HPGL.<br>
- * Update the clist code to send hpgl fill mode changes.<br>
- * Update PDF write to spot such paths and to convert them as<br>
- appropriate when writing out.<br>
-<br>
-gs/base/gdevpdfd.c<br>
-gs/base/gdevtrac.c<br>
-gs/base/gdevvec.c<br>
-gs/base/gspath.c<br>
-gs/base/gspath1.c<br>
-gs/base/gspenum.h<br>
-gs/base/gsstate.c<br>
-gs/base/gsstate.h<br>
-gs/base/gxclpath.c<br>
-gs/base/gxcpath.c<br>
-gs/base/gxistate.h<br>
-gs/base/gxline.h<br>
-gs/base/gxpath.c<br>
-gs/base/gxpath.h<br>
-gs/base/gxpath2.c<br>
-gs/base/gxpcopy.c<br>
-gs/base/gxpdash.c<br>
-gs/base/gxstroke.c<br>
-gs/base/gxttfb.c<br>
-gs/base/gzpath.h<br>
-gs/psi/zgstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-09 17:58:13 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91b362b05a16c4d74f9309d92fa7387899fed53a">91b362b05a16c4d74f9309d92fa7387899fed53a</a>
-<blockquote>
-<p>
- Fix typo in last commit that stopped Memento builds working.<br>
-<br>
- Committed before VS had saved out. Sorry.<br>
- CLUSTER_UNTESTED.<br>
-<br>
-gs/base/memento.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-09 16:57:13 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c66ce76a0c6f8edb075f28ffe1e8f326cc9eb40c">c66ce76a0c6f8edb075f28ffe1e8f326cc9eb40c</a>
-<blockquote>
-<p>
- Updated Memento pulled in from mupdf. Plus nesting fixes.<br>
-<br>
- Bring in Memento from MuPDF (where it has had some more tweaks<br>
- added). Fix the nested display code. Add hack to ignore prev/next<br>
- pointers in chunk blocks.<br>
-<br>
- CLUSTER_UNTESTED.<br>
-<br>
-gs/base/memento.c<br>
-gs/base/memento.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-09 14:47:43 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=75bc089fe804d692d8ac86a6f19be807980084f3">75bc089fe804d692d8ac86a6f19be807980084f3</a>
-<blockquote>
-<p>
- Fix Memento GhostPDL builds to actually build Memento on windows.<br>
-<br>
- Windows makefiles were failing to pass the MEMENTO flag down due<br>
- to some makefile wackiness.<br>
-<br>
- CLUSTER_UNTESTED.<br>
-<br>
-common/msvc_top.mak<br>
-gs/base/msvclib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-09 10:41:29 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7629dfecfafa5b3fc82b3767a786b732a0b17645">7629dfecfafa5b3fc82b3767a786b732a0b17645</a>
-<blockquote>
-<p>
- colour handling - ensure ink names are maintained in the name table while in use<br>
-<br>
- Bug #692884 &quot;Empty Spotcolor Name in generated PDF&quot;<br>
-<br>
- The ink name wasn't being marked as 'in use' by the colour space structure<br>
- and so was being freed by a garbage collection, resulting in an empty name.<br>
-<br>
- Robin Watts supplied this patch which allows us to *much* more easily mark<br>
- names as in use, and also kindly updated the colour handling as well.<br>
-<br>
- No differences expected.<br>
-<br>
-gs/base/gscdevn.c<br>
-gs/base/gscsepr.c<br>
-gs/base/gslib.c<br>
-gs/base/gsstruct.h<br>
-gs/psi/igc.c<br>
-pl/plplatf.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-07 17:56:47 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e76a4d070d7d6d90cc7d09849108bca806a9b253">e76a4d070d7d6d90cc7d09849108bca806a9b253</a>
-<blockquote>
-<p>
- Change the icc user parameter operators to use the graphics state not<br>
- the imager state.<br>
-<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_manage.h<br>
-gs/psi/zusparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-07 17:43:07 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ff83bab4ddf49c5bbbce9a37cfa8e4d5c42c9009">ff83bab4ddf49c5bbbce9a37cfa8e4d5c42c9009</a>
-<blockquote>
-<p>
- Add MEMENTO to preprocessor definition list in the VS solution.<br>
-<br>
- No difference to builds, but may make intellisense work better<br>
- for Memento builds.<br>
-<br>
-gs/ghostscript.vcproj<br>
-win32/language_switch.vcproj<br>
-win32/pcl.vcproj<br>
-win32/svg.vcproj<br>
-win32/xps.vcproj<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-07 17:41:32 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b47dc4f294e2b267d139001c6c749603e6ba2570">b47dc4f294e2b267d139001c6c749603e6ba2570</a>
-<blockquote>
-<p>
- Tweak rm.bat (and hence fix 'clean' builds on windows)<br>
-<br>
- Cope with -r command. Add /Q flag to erase call (so it doesn't prompt<br>
- before deleting).<br>
-<br>
-gs/base/rm.bat<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-07 17:13: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=f63237e1bb9a85124349ec0d0eae58737d7cb5ee">f63237e1bb9a85124349ec0d0eae58737d7cb5ee</a>
-<blockquote>
-<p>
- Problems with glyphs, T1 patterns and transparecy.....<br>
-<br>
- From investigations of a problem reported by customer 532.<br>
-<br>
- When imaging a cached glyph, if the glyph bitmap cannot be inserted into the<br>
- clist tile cache, we'd normally resort to degenerating the glyph bitmap into<br>
- rectangles, and writing those to the clist. When the glyph is filled with a<br>
- tiling (Type 1) pattern, this means going through the pattern tiling code.<br>
-<br>
- The problem is when transparency is involved (i.e. if the pattern is in a trans<br>
- group, or contains a transparency group) the tiling code cannot reliably<br>
- degerate to rectangles at this stage. This usually just works due to the various<br>
- fallbacks in the clist writing code and the glyph imaging code, but<br>
- occasionally glyphs can either disappear, or other problems occur.<br>
-<br>
- This change makes us use that &quot;fallback&quot; route for all glyphs when we're<br>
- filling a glyph with a type 1 pattern, with transprency involved and we're<br>
- writing to a clist device.<br>
-<br>
- NOTE: this is analogous to what the FAPI does in similar circumstances for<br>
- uncached glyphs.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/gsptype1.c<br>
-gs/base/gsptype1.h<br>
-gs/base/gxccache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-06 09:06:55 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23e37b6fc4d79741007cc18d770bb3e449e53014">23e37b6fc4d79741007cc18d770bb3e449e53014</a>
-<blockquote>
-<p>
- Fix the checks in gdevtsep.c missed by commit e954dd4683c35dbd66de3e045d979ebbf20c4d72<br>
-<br>
- Henry pointed out that my e954dd4683c35dbd66de3e045d979ebbf20c4d72<br>
- fix was incomplete; this commit replaces the remaining max_long<br>
- references with 2^32-1.<br>
-<br>
-gs/base/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-01 13:47:18 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0611ef428368816b4f123003df98263e674eab5a">0611ef428368816b4f123003df98263e674eab5a</a>
-<blockquote>
-<p>
- Add command line parsing for icc user parameters.<br>
-<br>
-pcl/pctop.c<br>
-pl/plmain.c<br>
-pl/plmain.h<br>
-pl/pltop.h<br>
-pxl/pxtop.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-05 19:21:53 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e954dd4683c35dbd66de3e045d979ebbf20c4d72">e954dd4683c35dbd66de3e045d979ebbf20c4d72</a>
-<blockquote>
-<p>
- Fix detection of TIFF file size overflow in tiffsep.<br>
-<br>
- The TIFF spec limits files to 4 Gigs. The code to detect attempts<br>
- to write files that were larger than this in gdevtsep.c was broken<br>
- on systems were a long != 32 bit.<br>
-<br>
- Fixes Bug 692896.<br>
-<br>
-gs/base/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-29 12:55:19 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d6f504174bd51d22cc43b2f87bee8c275c004cc1">d6f504174bd51d22cc43b2f87bee8c275c004cc1</a>
-<blockquote>
-<p>
- User params reset issue of icc profile strings<br>
-<br>
- If the user params end up getting set during a vmreclaim<br>
- while we are in a swapped icc profile situation when<br>
- processing a softmask we were ending up freeing profiles<br>
- that should not have been freed. This issue was masked<br>
- by a check that was disallowing profiling settings in<br>
- the manager once they were already set. Also discovered<br>
- issues with a corner case where we have a softmask that<br>
- includes a pattern with a softmask.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gscms.h<br>
-gs/base/gsicc_manage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-03 16:41:59 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=32463b4fe74f855e39be7b5eb74d8be444fffae3">32463b4fe74f855e39be7b5eb74d8be444fffae3</a>
-<blockquote>
-<p>
- Fix 692893 gl/2 rectangles not properly placed.<br>
-<br>
- When resetting the hpgl/2 page parameters we were setting scaling to<br>
- its default value overriding any setting in the PCL job. HP does not<br>
- reset the scaling as might be expected.<br>
-<br>
-pcl/pginit.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-03 11:03:53 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0c98813be9c1a24bbcf9ca0c1d4127cb4aa4209f">0c98813be9c1a24bbcf9ca0c1d4127cb4aa4209f</a>
-<blockquote>
-<p>
- Fixes bug 692894, orientation of pcl pages incorrect.<br>
-<br>
- This is a case of the current code emulating undocumented behavior<br>
- incorrectly. It appears the HP printers resets the print direction<br>
- upon receiving a new page size command. Previously we tried to emulate<br>
- this by not resetting the logical page orientation which is incorrect<br>
- but happened to print the tests we had correctly.<br>
-<br>
-pcl/pcpage.c<br>
-pcl/pcstate.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-17 13:51:23 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9d10c339014b9e554116ef55c697f50109071bb2">9d10c339014b9e554116ef55c697f50109071bb2</a>
-<blockquote>
-<p>
- Better error handling in the absence of fonts.<br>
-<br>
-pcl/pcfsel.c<br>
-pcl/pctext.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-02 22:34:20 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7180b9328f00fb5df41e6d019e16f70ae4f66ec7">7180b9328f00fb5df41e6d019e16f70ae4f66ec7</a>
-<blockquote>
-<p>
- Clean up of distclean target in Makefile.<br>
-<br>
- Improve the distclean target so that the Memento obj and bin directory<br>
- contents are deleted and also remove the debug, pg, memento, and<br>
- production obj and bin directories.<br>
-<br>
-gs/base/Makefile.in<br>
-gs/base/gs.mak<br>
-gs/base/unix-dll.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-02 11: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=ceef3232c1fce21f65d4ba43bb54eaf678389bfd">ceef3232c1fce21f65d4ba43bb54eaf678389bfd</a>
-<blockquote>
-<p>
- Bug 692891: don't hack the libjpeg mem manager....<br>
-<br>
- When linking with a shared libjpeg library, don't include the non-public<br>
- libjpeg API hack to replace it's low level memory manager with Ghostscript's.<br>
- But still do so when using our &quot;local&quot; libjpeg source.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/sjpegc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-02 11:41: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=aa3a2bb36828d07c2b71ff0a37f784d8e6fb0f5a">aa3a2bb36828d07c2b71ff0a37f784d8e6fb0f5a</a>
-<blockquote>
-<p>
- Fix the &quot;WHICH_CMS&quot; setting.....<br>
-<br>
- ...so it uses the $(D_) and $(_D_) variables instead of -D directly.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-01 11:06:54 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2a57a68efe18dd4f7898b180400a95d7baccfbc2">2a57a68efe18dd4f7898b180400a95d7baccfbc2</a>
-<blockquote>
-<p>
- pdfwrite - Improve handling of PCL downloaded TrueType fonts<br>
-<br>
- Bug #692629. PCL TrueType fonts are missing some important tables for the<br>
- purposes of pdfwrite. In particular the CMAP table, which makes it impossible<br>
- to create glyph names.<br>
-<br>
- This causes an error which *should* have resulted in pdfwrite falling back to<br>
- bitmaps. In the case of a single glyph, or a string where the fiirst glyph fails,<br>
- this did work correctly, but when one or more initial glyphs did work, the<br>
- calling code did not expect an error from TrueType fonts and failed to cope<br>
- properly by continuing to process the remaining glyphs.<br>
-<br>
- Added TrueType fonts to the list which may error in this fashion.<br>
-<br>
- Expected Differences:<br>
- AS40AOJ3.BIN<br>
- LW97DOJ2.BIN<br>
- SW108OJ2.BIN<br>
- VerdanaItalic.prn<br>
- bug689100.xl<br>
- bug689905.xl<br>
-<br>
- All exhibit significant progressions (text was previously missing)<br>
-<br>
-gs/base/gdevpdtt.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-03-01 07:43:13 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=867fb8607edd04b0b1c8e8bd635347a542b0f50f">867fb8607edd04b0b1c8e8bd635347a542b0f50f</a>
-<blockquote>
-<p>
- Bug 692602: revise script vs job confusion<br>
-<br>
- Slight revision to the previous change, again from jrnieder@gmail.com.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/man/gs.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-29 16:46: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=90e6a864f0e4b4b0e6d6a0a1258295cf1cb3e1a6">90e6a864f0e4b4b0e6d6a0a1258295cf1cb3e1a6</a>
-<blockquote>
-<p>
- Bug 692602: revise SAFER section in the man page<br>
-<br>
- patch courtesy of Jonathan Nieder ( jrnieder@gmail.com ).<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/man/gs.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-29 11:20:50 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3648acb1e3fd3e07faceedde1a71e1b282e25de3">3648acb1e3fd3e07faceedde1a71e1b282e25de3</a>
-<blockquote>
-<p>
- Revert &quot;Support HPGL style path handling.&quot;<br>
-<br>
- This reverts commit 43f3cdae4bdf00c09fdd69c53c03fb99d0b4aca1.<br>
-<br>
- This caused unexpected changes in many postscript files. Reverting<br>
- until I can figure out why.<br>
-<br>
-gs/base/gdevpdfd.c<br>
-gs/base/gdevtrac.c<br>
-gs/base/gdevvec.c<br>
-gs/base/gspath.c<br>
-gs/base/gspath1.c<br>
-gs/base/gspenum.h<br>
-gs/base/gsstate.c<br>
-gs/base/gsstate.h<br>
-gs/base/gxclpath.c<br>
-gs/base/gxclpath.h<br>
-gs/base/gxclrast.c<br>
-gs/base/gxcpath.c<br>
-gs/base/gxistate.h<br>
-gs/base/gxline.h<br>
-gs/base/gxpath.c<br>
-gs/base/gxpath.h<br>
-gs/base/gxpath2.c<br>
-gs/base/gxpcopy.c<br>
-gs/base/gxpdash.c<br>
-gs/base/gxstroke.c<br>
-gs/base/gxttfb.c<br>
-gs/base/gzpath.h<br>
-gs/doc/Language.htm<br>
-gs/psi/zgstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-29 08:31: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=34b2e8fd2c33a7fc349b0c51046c3d0c99b74d0c">34b2e8fd2c33a7fc349b0c51046c3d0c99b74d0c</a>
-<blockquote>
-<p>
- pdfwrite - Fix XMP ModDate metaData<br>
-<br>
- The XMP metadata Modification date was being written using the Creation<br>
- date instead of the Modification date.<br>
-<br>
- No differences expected, metadata is not checked by regression tests<br>
-<br>
-gs/base/gdevpdfe.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-28 12:01:12 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e228753bde054e549c8643cf726c951a512a4a6">8e228753bde054e549c8643cf726c951a512a4a6</a>
-<blockquote>
-<p>
- Another fix to fuzzy.c dealing with different sized input files.<br>
-<br>
-gs/toolbin/tests/fuzzy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-27 03:11:02 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=43f3cdae4bdf00c09fdd69c53c03fb99d0b4aca1">43f3cdae4bdf00c09fdd69c53c03fb99d0b4aca1</a>
-<blockquote>
-<p>
- Support HPGL style path handling.<br>
-<br>
- HPGL handles paths slightly differently to the postscript imaging model.<br>
-<br>
- When a path is filled, successive moveto's are treated as linetos.<br>
- (i.e. the 'place we close the path to' is left at the first moveto,<br>
- and the area remains fillable). Stroking is unaffected however.<br>
-<br>
- To model this in Ghostscript we add a new path segment type 's_gap'.<br>
- The filling code treats this as a lineto. The stroking code is updated<br>
- to not stroke such edges (and not to break the subpath at this point).<br>
-<br>
- We add a new parameter to the imager state (hpgl_path_mode), new<br>
- accessor functions (gs_sethpglpathmode, gs_currenthpglpathmode),<br>
- and new postscript operators (.sethpglpathmode and .currenthpglpathmode).<br>
-<br>
- If hpgl path mode is set to a non-zero value, then path construction<br>
- treats movetos in an open subpath as gaptos.<br>
-<br>
- Still to do:<br>
- * Update PDF write to spot such paths and to convert them as<br>
- appropriate when writing out.<br>
-<br>
-gs/base/gdevpdfd.c<br>
-gs/base/gdevtrac.c<br>
-gs/base/gdevvec.c<br>
-gs/base/gspath.c<br>
-gs/base/gspath1.c<br>
-gs/base/gspenum.h<br>
-gs/base/gsstate.c<br>
-gs/base/gsstate.h<br>
-gs/base/gxclpath.c<br>
-gs/base/gxclpath.h<br>
-gs/base/gxclrast.c<br>
-gs/base/gxcpath.c<br>
-gs/base/gxistate.h<br>
-gs/base/gxline.h<br>
-gs/base/gxpath.c<br>
-gs/base/gxpath.h<br>
-gs/base/gxpath2.c<br>
-gs/base/gxpcopy.c<br>
-gs/base/gxpdash.c<br>
-gs/base/gxstroke.c<br>
-gs/base/gxttfb.c<br>
-gs/base/gzpath.h<br>
-gs/doc/Language.htm<br>
-gs/psi/zgstate.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-24 22:37:26 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0d095e8511ec1469b0ef4cb741d1fba9363570e7">0d095e8511ec1469b0ef4cb741d1fba9363570e7</a>
-<blockquote>
-<p>
- Movement of code for setting ICC system/user params into graphics lib.<br>
-<br>
- The code that set the system/user params related to ICC profiles was<br>
- contained in the zusparam.c file. This file is not used with the<br>
- other languages (e.g. xps and pcl). The functions that do the actual<br>
- work have been moved to gsicc_manage reducing any code duplication for<br>
- the other languages.<br>
-<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_manage.h<br>
-gs/psi/zusparam.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-25 14:54:03 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6d93192f3469bedb51f73abc0a1f8f71d3bfba24">6d93192f3469bedb51f73abc0a1f8f71d3bfba24</a>
-<blockquote>
-<p>
- Bug 692878: Convert Type 4 image with invalid mask to Type 1<br>
-<br>
- Improve the revision 3de55841eefb38c751772ac767c5abab155d7d91.<br>
- Convert Type 4 images with invalid /Mask attribute to Type 1<br>
- images. Previous version used the mask [1 0] in such cases,<br>
- which was not compatible with pdfwrite.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-25 15:07:08 +0000
-</strong>
-<br>unknown &lt;ken@.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d97d5dcfcfb580177566b0f03d75048485683ac">7d97d5dcfcfb580177566b0f03d75048485683ac</a>
-<blockquote>
-<p>
- Bug #692880 Correct the initial Windows display device flags for PCL<br>
-<br>
- The flags used for the Windows display device were incorrect and caused<br>
- at least some rasterops not to display correctly.<br>
-<br>
- No expetced differences, the display device, and Windows builds, are not<br>
- cluster tested.<br>
-<br>
-pl/dwmainc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-24 21:25:08 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b9971445d1460a3b0c57b176c73d722ed6db99e1">b9971445d1460a3b0c57b176c73d722ed6db99e1</a>
-<blockquote>
-<p>
- Add &quot;-I directories&quot; option.<br>
-<br>
- Add a new form of -I option similar to -o, where the directory list<br>
- is taken from the next parameter. This form is more convenient to use<br>
- on UN*X command line with tilda expansion.<br>
-<br>
-gs/doc/Use.htm<br>
-gs/psi/imainarg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-24 20:45:31 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9178d875547dafe5f89ae7bbbe9f4fd83e18000c">9178d875547dafe5f89ae7bbbe9f4fd83e18000c</a>
-<blockquote>
-<p>
- Bug 692867: ignore PDF path operators without current point<br>
-<br>
- Run l, c, v, y in a stopped context. When they fail (presumably<br>
- with /nocurrentpoint), ignore the operator and continue.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-21 11:30:58 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2c4aa5f1a90ee03aacce58f24b819cab3bdd1625">2c4aa5f1a90ee03aacce58f24b819cab3bdd1625</a>
-<blockquote>
-<p>
- Fix for bug 692865. Make XPS interpreter use ICC color spaces for default<br>
-<br>
- The XPS interpreter was still using Device color spaces for its default<br>
- color spaces. This fix has it use ICC color spaces by default which<br>
- is required by the spec. This revealed an issue with the color space<br>
- handling of the opacity masks. These were getting drawn in sRGB color<br>
- space but the transparency group is linear gray. Since we are drawing<br>
- the opacity mask as a luminosity mask that is gray we ended up<br>
- mapping through a nonlinearity.<br>
-<br>
-gs/base/gscspace.c<br>
-gs/base/gscspace.h<br>
-gs/base/gxblend.c<br>
-xps/ghostxps.h<br>
-xps/xpsgradient.c<br>
-xps/xpsimage.c<br>
-xps/xpsopacity.c<br>
-xps/xpspage.c<br>
-xps/xpstop.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-24 18:39:09 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=77a8045048a4aaa727f700187816170d7fbd072c">77a8045048a4aaa727f700187816170d7fbd072c</a>
-<blockquote>
-<p>
- Bug 692832: Drop setcachedevice calls with large arguments.<br>
-<br>
- Reject setcachedevice arguments that are too big and, probably, invalid.<br>
- The threshold, 32000, is arbitrary. Normal fonts have the values about 1000.<br>
-<br>
-gs/base/gxchar.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-24 18:27:41 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9aedcfcd26aea249e0a06061f4d2e579fa5cdffc">9aedcfcd26aea249e0a06061f4d2e579fa5cdffc</a>
-<blockquote>
-<p>
- Bug 692859: Add Portfolio support to pdf_info.ps<br>
-<br>
- Enumerate PDF subfiles in PDF collection (=portfolio) and apply<br>
- the old pdf_info.ps to every component.<br>
-<br>
-gs/toolbin/pdf_info.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-23 01:25:59 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3de55841eefb38c751772ac767c5abab155d7d91">3de55841eefb38c751772ac767c5abab155d7d91</a>
-<blockquote>
-<p>
- Bug 692851: Fix OpenJpeg JPX with components &gt; 1, and bps &lt; 8<br>
-<br>
- Fix packing of multi-component color values with bps &lt; 8 into the<br>
- output stream. This results in progressions on Bug691843.pdf, and<br>
- minor differences in Bug690147.pdf<br>
-<br>
-gs/base/sjpx_openjpeg.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-22 09:40:31 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b105c3678ff3c22ab65995953b4599d8c5c37a7e">b105c3678ff3c22ab65995953b4599d8c5c37a7e</a>
-<blockquote>
-<p>
- Typo fix in non color managed transform<br>
-<br>
- Thanks to Peter Skarpetis for finding this.<br>
-<br>
-gs/base/gxblend1.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-22 11:27:16 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b4a8edb730e25f5c03103a2bb687e223a440d990">b4a8edb730e25f5c03103a2bb687e223a440d990</a>
-<blockquote>
-<p>
- Bug 692852: Broken /Mask in 1 bpc /Indexed images<br>
-<br>
- Following AR9 implementation, add special processing for<br>
- repairing a broken /Mask attribute of 1 bpc indexed images.<br>
- Ignore the whole Mask if its first element is out of range.<br>
- Replace the second component with 1 when it's out of range.<br>
-<br>
-gs/Resource/Init/pdf_draw.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-20 06:23:06 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ed07da9075aa82bc0c4335228cc9c934e6efdb45">ed07da9075aa82bc0c4335228cc9c934e6efdb45</a>
-<blockquote>
-<p>
- Revert 2e807ab6d4eecfce43561b9e8d5b66386a5165ee and fix fuzzy.c correctly.<br>
-<br>
-gs/toolbin/tests/fuzzy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-19 15:45:43 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e277c5e8d76325f56259a4f930caa166a594cfc0">e277c5e8d76325f56259a4f930caa166a594cfc0</a>
-<blockquote>
-<p>
- Improve image performance by rotating Width 1 images to Height 1.<br>
-<br>
- The image code makes a call to 'image_render' for each line of the Height. This defeats the joining<br>
- of any same color pixels into a larger rectangle and also creates extra overhead. Problem analyzed<br>
- with profiles from cust 532 file &quot;PWTTQ1CC.pdf&quot;. Regression testing shows some single pixel differences<br>
- presumably due to rounding, but no obvious problems.<br>
-<br>
-gs/psi/zimage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-18 09:28:14 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e807ab6d4eecfce43561b9e8d5b66386a5165ee">2e807ab6d4eecfce43561b9e8d5b66386a5165ee</a>
-<blockquote>
-<p>
- Make fuzzy not lock up when comparing images of different sizes.<br>
-<br>
-gs/toolbin/tests/fuzzy.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-16 20:03:26 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d00354a21670d16f00c96228591b3d8213d6a590">d00354a21670d16f00c96228591b3d8213d6a590</a>
-<blockquote>
-<p>
- Fix interpolation of indexed colorspaces.<br>
-<br>
- WMB1102317A01.pdf (supplied by a customer) shows a problem with<br>
- Interpolation of Index colorspaces.<br>
-<br>
- Specifically, we have an Indexed DeviceGrey space (which is, in<br>
- the new world order, an Indexed ICC space, with 1 component).<br>
-<br>
- At line 678 of gxiscale.c we correctly detect that pcs-&gt;type-&gt;index<br>
- is Indexed, and therefore use the base space as the 'actual' space.<br>
-<br>
- At line 683 we find the concrete space (which in this case is<br>
- exactly the same space). We then decide whether we are working in<br>
- an icc world, or a device_color world by checking for the presence<br>
- of icc data. The old code used to (incorrectly) check pcs (the<br>
- indexed space), when it should really have checked the concrete<br>
- space.<br>
-<br>
- The remaining changes in the code are purely tidying:<br>
-<br>
- * avoid calling concrete_space a second time (when pconcs already<br>
- holds the answer)<br>
- * pass pconcs as an arg when calling pconcs-&gt;type-&gt;remap_concrete_color<br>
- rather than pactual_cs. At that point pactual_cs and pconcs must<br>
- be identical, but it's nicer to be consistent.<br>
-<br>
- This produces 3 differences in the cluster tests, all in the cups<br>
- tests. These can be reproduced locally using tiffsep.<br>
-<br>
- comparefiles/148-11.ps.cups.300.1<br>
- Definite progression<br>
-<br>
- PDFIA1.7_SUBSET/CATX1028.pdf.cups.300.1<br>
- Looks like progression to me<br>
-<br>
- ps/ps3cet/12-07B.PS.cups.300.1<br>
- Definite progressions on page 12-15. A problem still exists on<br>
- page 12 though, but that's unaffected by this change.<br>
-<br>
-gs/base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-16 18:16:16 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=21579b00e53b97cd655f164bb92c5280c586e365">21579b00e53b97cd655f164bb92c5280c586e365</a>
-<blockquote>
-<p>
- Output helpful debug warning when tif output would be too large.<br>
-<br>
- Currently we just raise a rangecheck, which can be very confusing.<br>
-<br>
- CLUSTER_UNTESTED.<br>
-<br>
-gs/base/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-15 19:03:56 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=43b14b24fcc13d816dd41ca335d52cd3074bd0d8">43b14b24fcc13d816dd41ca335d52cd3074bd0d8</a>
-<blockquote>
-<p>
- Update garbage collection to cope with pdf14_compressed_color_list.<br>
-<br>
- A second list of compressed colors was recently added to the<br>
- gdevn_params structure, but this wasn't added to the garbage<br>
- collection routines. Fixed here.<br>
-<br>
-gs/base/gdevp14.c<br>
-gs/base/gdevpsd.c<br>
-gs/base/gdevtsep.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-15 19:02:34 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d375ea1908bfe1770b108a6c7d1e7cdbe38b99f2">d375ea1908bfe1770b108a6c7d1e7cdbe38b99f2</a>
-<blockquote>
-<p>
- Fix Division by Zero in interpolated scaler.<br>
-<br>
- If we find we are scaling an image to be zero width or<br>
- height, handle the image without interpolation.<br>
-<br>
-gs/base/gxiscale.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-14 18:11:15 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0a0aa751d8cb5d49052a0c4ed3ae38ad66b9fb8e">0a0aa751d8cb5d49052a0c4ed3ae38ad66b9fb8e</a>
-<blockquote>
-<p>
- Fix 692857, wrong current unit initialization in HPGL/2-RTL.<br>
-<br>
- The code was actually written fixed once correcly but then was broken<br>
- with a bad fix (5ad194f) largely because we didn't have good bookkeeping<br>
- for the original fix. Hopefully now that we have an associated bug<br>
- report and test file a similar problem won't happen again.<br>
-<br>
-pcl/pcjob.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-14 14:57:07 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=00a96d35b30d77f8dfbc8ae12326c81053fc50c9">00a96d35b30d77f8dfbc8ae12326c81053fc50c9</a>
-<blockquote>
-<p>
- Fix Bug 692854; tweak gdev_prn color procs.<br>
-<br>
- A previous commit (cf37ea5) changed the prn device macros to<br>
- duplicate map_color_rgb/map_rgb_color to encode/decode_color.<br>
- I thought this was safe as the default color encoding/decoding<br>
- functions were actually implemented as encode/decode, rather<br>
- than map_ variants.<br>
-<br>
- Unfortunately, this falls down when other devices (such as the<br>
- tiffscaled ones) provide genuine map_ functions rather than<br>
- encode/decodes.<br>
-<br>
- So, a small tweak to the macros is required; we now duplicate<br>
- to encode/decode only if specifically told to - and the macros<br>
- that use the defaults specifically say to. Other devices should<br>
- remain unchanged.<br>
-<br>
-gs/base/gdevprn.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-13 08:46:29 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba2a8e63783227033506688bebccf664b2b922c7">ba2a8e63783227033506688bebccf664b2b922c7</a>
-<blockquote>
-<p>
- C portion for making use of output intent ICC profile.<br>
-<br>
- This commit puts into place the c-code for making use of an<br>
- ICC profile stream from the PDF interpreter for setting of the<br>
- output intent. This is done through the use of zset_outputintent.<br>
- This function will make the various settings of the icc profiles<br>
- in the device and in the icc manager based upon the process model<br>
- of the target device and the icc profile of the output intent. It<br>
- will be up to the interpreter to make the call to .set_outputintent<br>
- with the proper output intent ICCBased dictionary on the top of the<br>
- stack. This should be done in the interpreter after the device has<br>
- been set up and all the default ICC profiles are in place. The<br>
- interpreter should make the call if we have specified -dUsePDFX3Profile.<br>
- The first output intent that is present in the file should be used,<br>
- unless someone specifies a different intent through the use of<br>
- –dOutputIntent=x . In this case, the x+1 output intent (if it<br>
- exists) will be used. Note that if the particular output intent does<br>
- not include an ICC profile entry (DestOutputProfile), then the output<br>
- intent will not be used. In this case, we will eventually want to<br>
- specify what the OutputConditionIdentifier was for that particular<br>
- intent if it was missing the DestOutputProfile.<br>
-<br>
-gs/base/gdevpdfk.c<br>
-gs/base/gscms.h<br>
-gs/base/gsequivc.c<br>
-gs/base/gsicc_manage.c<br>
-gs/base/gsicc_manage.h<br>
-gs/psi/int.mak<br>
-gs/psi/zicc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-12 21:14:34 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7aa3debb84673b38d805aa6de1afce60f0d6c6ab">7aa3debb84673b38d805aa6de1afce60f0d6c6ab</a>
-<blockquote>
-<p>
- Improve character fills, bug #692849.<br>
-<br>
- The unusual loops inside the characters (graphic 3 and 8 center of<br>
- page) were caused by trying to edge stick and arc fonts which aren't<br>
- outlines but paths (stroked fonts).<br>
-<br>
-pcl/pgdraw.c<br>
-pcl/pglabel.c<br>
-pcl/pgmisc.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-10 18:13:00 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bcdb21c092a4a788d7252cc1b560aa427743a197">bcdb21c092a4a788d7252cc1b560aa427743a197</a>
-<blockquote>
-<p>
- Improvements for bug 692849.<br>
-<br>
- Better emulation of HP printers in the absence of a requested pattern.<br>
-<br>
-pcl/pcl.mak<br>
-pcl/pglfill.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-10 11:29:16 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a81f5d7f83271e2e3e0fb28ad32c9fb337c8553a">a81f5d7f83271e2e3e0fb28ad32c9fb337c8553a</a>
-<blockquote>
-<p>
- Bug 692849, missing green filled boxes fixed.<br>
-<br>
- The green boxes for fill type 22 (user defined) were missing because<br>
- the download pattern command was disabled in HPGL-2/RTL mode.<br>
-<br>
-pcl/pcuptrn.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-09 17:24:34 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1bf302eec20ce9b543aee523b441dd7adc677cc0">1bf302eec20ce9b543aee523b441dd7adc677cc0</a>
-<blockquote>
-<p>
- Remove relic data files used by the wts device.<br>
-<br>
-CMYK.icc<br>
-Makefile<br>
-link.icc<br>
-sRGB.icc<br>
-wts_dump_0<br>
-wts_plane_0<br>
-wts_plane_1<br>
-wts_plane_2<br>
-wts_plane_3<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-09 17:15:41 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e2867c6bcb2dc6cf9325e9ac87f980684469dee4">e2867c6bcb2dc6cf9325e9ac87f980684469dee4</a>
-<blockquote>
-<p>
- PCL shared library build for unix.<br>
-<br>
-Makefile<br>
-common/ugcc_top.mak<br>
-main/pcl6_gcc.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-10 17:24:00 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a13600f1c241c3e36dbe4973e9d78a8934b16004">a13600f1c241c3e36dbe4973e9d78a8934b16004</a>
-<blockquote>
-<p>
- Further clipping optimisations.<br>
-<br>
- When clipping the region to be used for an image plot, reduce the<br>
- rectangle by the outer box of the clipping path before checking to<br>
- see if a clip is needed or not.<br>
-<br>
- This enables us to avoid a clipping device in more cases.<br>
-<br>
-gs/base/gxclip.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-10 17:20:36 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cf37ea5d017193c76341aafd60e35d3b1826046f">cf37ea5d017193c76341aafd60e35d3b1826046f</a>
-<blockquote>
-<p>
- Prn device changes to encode/decode_color.<br>
-<br>
- At the moment, prn devices do not implement encode_decode/color,<br>
- choosing instead to provide map_rgb_color/map_color_rgb which<br>
- just get called through a 'backwards compatibility' layer.<br>
-<br>
- In fact, they actually implement encode/decode_rgb rather than<br>
- map_rgb_color/map_color_rgb, so we just copy the entries here.<br>
-<br>
- No changes expected in cluster.<br>
-<br>
-gs/base/gdevprn.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-09 00:00:31 +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=082c31b99fd38ebb1a9bc678d06ac9791db2e222">082c31b99fd38ebb1a9bc678d06ac9791db2e222</a>
-<blockquote>
-<p>
- Bug 690974: This patch from Gorac implements the generic refinement region<br>
- decoding procedure for when TPGRON is TRUE.<br>
-<br>
-gs/jbig2dec/jbig2_refinement.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-08 23:13:13 +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=8b150573a88276849b32b359030fc195786d2be8">8b150573a88276849b32b359030fc195786d2be8</a>
-<blockquote>
-<p>
- Bug 690870: This patch prevents the image compositing occurring if the src<br>
- is outside of the clip region.<br>
-<br>
-gs/jbig2dec/jbig2_image.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-08 09:50:34 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=059dfa8389ff1dde2bb35237b12f72c6fd62da9b">059dfa8389ff1dde2bb35237b12f72c6fd62da9b</a>
-<blockquote>
-<p>
- Fix for bug 682719. Fix bad icc profiles in examples/annots.pdf<br>
-<br>
- The ICC profiles in annots.pdf were missing all sorts of required information in<br>
- the header.<br>
-<br>
-gs/examples/annots.pdf<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-08 08:40:12 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a2390c3b6be80d1147f1ef60c16c70d75033a475">a2390c3b6be80d1147f1ef60c16c70d75033a475</a>
-<blockquote>
-<p>
- Amend date and update changelog for 9.05 release.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pdfopt.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-01 10:59:52 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eed3745432f9bce3e20d9b634d78d1a72dbbf040">eed3745432f9bce3e20d9b634d78d1a72dbbf040</a>
-<blockquote>
-<p>
- Update docs for 9.05 release candidate.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-08 15:01:57 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0816e3b87ec1843a31e3075a4fa382e844a46158">0816e3b87ec1843a31e3075a4fa382e844a46158</a>
-<blockquote>
-<p>
- Bug #688227 Alter the PostScript 'show' operators so that the show enumerator is in local VM<br>
-<br>
- As described in the bug, it seems to be technically possible for a local font to be<br>
- referenced from a show enumerator. If the enumerator is in global VM this<br>
- causes a garbage collector crash.<br>
-<br>
- This code modifies the PostScript 'show' family of operators so that the<br>
- enumerator is always allocated from local VM, avoiding the problem.<br>
-<br>
- There is no specimen or method of reproduction supplied in the bug report so<br>
- this is rather speculative, however it runs a cluster test without problem.<br>
- If it does cause any problems we should simply revert this change.<br>
-<br>
- As part of this change it was noticed that there are a number of procedures<br>
- defined in gschar.c which are apparently dead code and these have been removed.<br>
-<br>
- No expected differences.<br>
-<br>
-gs/base/gschar.c<br>
-gs/base/gschar.h<br>
-gs/psi/zchar.c<br>
-gs/psi/zcharx.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-07 09:23:30 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a6a7d7b62d5bb5cbe00c1051d8a9cb749e43fe86">a6a7d7b62d5bb5cbe00c1051d8a9cb749e43fe86</a>
-<blockquote>
-<p>
- pdfwrite - fallback to 'LeaveColorunchanged' if we cannot deal with color conversion<br>
-<br>
- Some of the PDFSETTINGS collection of settings set the ColorConversionStrategy<br>
- to spaces which may not be possible (in the current architecture) to convert<br>
- every colour space into. For example ICCBased spaces. This causes a fairly<br>
- incomprehensible error to be thrown.<br>
-<br>
- In future we intend to do a better job with colour taking advantage of the<br>
- built-in colour management, but for now we simply choose to change the<br>
- ColorConversionStrategy to 'LeaveColorUnchanged' and emit a warning.<br>
-<br>
- Bug #692030 and Bug #692108<br>
-<br>
- No Expected Differences as this is not tested by the cluster<br>
-<br>
-gs/base/gdevpdfc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-06 12:01:53 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e448aeaf3d3d572bf4e91d9acdf3fa623ed9b6fb">e448aeaf3d3d572bf4e91d9acdf3fa623ed9b6fb</a>
-<blockquote>
-<p>
- Clipping optimisations; avoid needless clipping device.<br>
-<br>
- When filling a mask, check any clipping path given; if it trivially<br>
- includes all the mask, then don't bother creating a clipping<br>
- device. If it trivially excludes, then don't bother plotting at all.<br>
- If the bbox partially covers the area, then reduce the area<br>
- of the mask.<br>
-<br>
- This gives a 6-8% speedup of customer 532's test files; they are<br>
- filling a mask with a halftone, which breaks down into lots of<br>
- short run, 1 pixel high rectangles. Avoiding the clipping device<br>
- avoids lots of function call overhead.<br>
-<br>
-gs/base/gdevdbit.c<br>
-gs/base/gxclip.c<br>
-gs/base/gxcpath.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-06 15:37:04 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=09a47e5c2b0fff0d2598e38305bc3d0bc050a26f">09a47e5c2b0fff0d2598e38305bc3d0bc050a26f</a>
-<blockquote>
-<p>
- Remove overzealous call to image_init_clues.<br>
-<br>
- Investigation of customer 532's problem files lead Ray to<br>
- spot that we are blowing away the color clues on every call to<br>
- image_render_mono (called for every scanline in an image at<br>
- least), rather than just once per image.<br>
-<br>
- Here, therefore, we change to call image_init_clues in<br>
- gs_image_class_3_mono (the function that returns image_render_mono)<br>
- rather than in image_render_mono itself.<br>
-<br>
-gs/base/gximono.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-06 15:25:33 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea8d2baefa33457d89b4daa8a80dd1898a362bd3">ea8d2baefa33457d89b4daa8a80dd1898a362bd3</a>
-<blockquote>
-<p>
- Remove last vestiges of halftone cache.<br>
-<br>
- Back in 2002 code was committed (as part of the DeviceN work) that<br>
- removed the halftone cache from the image state. The last vestiges<br>
- of this were functions:<br>
-<br>
- gx_check_tile_cache_current<br>
- gx_check_tile_cache<br>
- gx_check_tile_size<br>
-<br>
- All these were hardwired to return a constant value, but the calls<br>
- to them were never removed from the code.<br>
-<br>
- Here, we remove those calls. No differences should be given.<br>
-<br>
-gs/base/gxht.c<br>
-gs/base/gximono.c<br>
-gs/base/gxipixel.c<br>
-gs/base/gzht.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-06 10:55:59 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=013136f0e1050dc25c441fdf49dbfeb21ce0ee7a">013136f0e1050dc25c441fdf49dbfeb21ce0ee7a</a>
-<blockquote>
-<p>
- Bug 692838: fix building against system zlib<br>
-<br>
- Commit 75ff1314c3de8fb5df702211b6effb6df2b87faa broke building against the<br>
- system zlib by adding an explicit dependency on a file in the &quot;local&quot; zlib<br>
- source directory.<br>
-<br>
- Ensure that dependency only applies when building non-shared zlib.<br>
-<br>
- Also, at some point, the mkromfs with shared zlib has been broken, so fix that<br>
- by passing the &quot;-lz&quot; option to the CCAUX compiler variable.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/Makefile.in<br>
-gs/base/configure.ac<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-04 21:14:04 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=75ff1314c3de8fb5df702211b6effb6df2b87faa">75ff1314c3de8fb5df702211b6effb6df2b87faa</a>
-<blockquote>
-<p>
- Added dependencies to base/lib.mak.<br>
-<br>
-gs/base/gs.mak<br>
-gs/base/lib.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-04 11:09:47 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=051ed7e56c0d3ef36149c45610bd19a0e55647c0">051ed7e56c0d3ef36149c45610bd19a0e55647c0</a>
-<blockquote>
-<p>
- ps2write - Handle nested patterns better<br>
-<br>
- Patterns inside patterns were not working properly, because PDF and PostScript<br>
- handle this differently. opdfread.ps resets teh graphics state CTM to the<br>
- identity when drawing patterns, because the PDF spec says patterns are always<br>
- referenced to the default co-ordinate space and in order that the matrix gets<br>
- applied correctly we need to reset the CTM.<br>
-<br>
- However, when the pattern is inside another pattern, the defualt co-ordinate<br>
- space is that of the enclosing pattern, so restting the CTM is a problem. We<br>
- can't simply avoid the reset as normal patterns would stop working. We can't<br>
- 'undo#' the pattern matrix in PostScript, because we don't know what the<br>
- resolution scaling was.<br>
-<br>
- So we track the pattern depth in ps2write, and the accumulated matrix transforms<br>
- from all the patterns so far. Then we apply that accumulated matrix to any new<br>
- pattern when the pattern depth is not zero.<br>
-<br>
- This works, but is not 100% reliable, 2 patterns inside a single parent would<br>
- be concatenated, resulting in the second pattern being incorrect. However the<br>
- nested pattern situation is rare enough that I'm going to leave this as it is.<br>
-<br>
- Expected Differences:<br>
- 09_47N.pdf<br>
- Bug6901014_org_Chromium_AN03F.pdf<br>
-<br>
- these files now work correctly with ps2write.<br>
-<br>
-gs/base/gdevpdfb.h<br>
-gs/base/gdevpdfi.c<br>
-gs/base/gdevpdfv.c<br>
-gs/base/gdevpdfx.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-03 17:50:37 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e7c3c6e02fac1a6e24030a2815645610b42fde47">e7c3c6e02fac1a6e24030a2815645610b42fde47</a>
-<blockquote>
-<p>
- Fixes 692387, the font rotation code did not work properly for some<br>
- rotations.<br>
-<br>
- There are many progressions and small character placement adjustments<br>
- in many regression files. The latter due to how the rotation matrix<br>
- is now calculated with a rounded angle.<br>
-<br>
-pcl/pglabel.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-02 17:31:27 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2cffba33ed7bb6aafe9176688535eab290cb20f0">2cffba33ed7bb6aafe9176688535eab290cb20f0</a>
-<blockquote>
-<p>
- RTL mode's print direction is always rotated with respect to the<br>
- physical page size.<br>
-<br>
-pcl/pcpage.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-03 16:18: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=84abcb901a8451ece9f23fda4b17f670b335eb07">84abcb901a8451ece9f23fda4b17f670b335eb07</a>
-<blockquote>
-<p>
- Propogate dynmic device flags to 'so' subtarget.<br>
-<br>
- When I brought the Makefile into line with convention for some of the FLAGS<br>
- variables, I forgot to add the new 'AC_CFLAGS' value to the subtarget for<br>
- the dynamic library build.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/unix-dll.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-03 16:20:25 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=03ab853b064b491cb463e392fe6988e904d76fd5">03ab853b064b491cb463e392fe6988e904d76fd5</a>
-<blockquote>
-<p>
- CUPS Raster: Fixed rotating of input pages with unknown sizes<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-02 21:02:26 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d0b64a75d54948b3f07da0128bb0002523a39040">d0b64a75d54948b3f07da0128bb0002523a39040</a>
-<blockquote>
-<p>
- CUPS Raster: More on improving page size fitting<br>
-<br>
- Raised the tolerance of matching the document's page sizes with the PPD's<br>
- page sizes on the short dimension to 2 %. This also covers the overspray<br>
- full-bleed page sizes of HPLIP.<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-02 20:43:22 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2d4fac37ee36948c0b30e6b95292b68f718cafdc">2d4fac37ee36948c0b30e6b95292b68f718cafdc</a>
-<blockquote>
-<p>
- Merge branch 'master' of ghostscript.com:/home/git/ghostpdl<br>
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-02 12:14:41 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=72887eac758eba7638258b6b375347ee16efbbdc">72887eac758eba7638258b6b375347ee16efbbdc</a>
-<blockquote>
-<p>
- Add 4 new raster decompression methods to PCL.<br>
-<br>
- HPGL/2 and RTL plotters support the following decompression methods:<br>
- uncompressed block (#4), CCITT group 3 1 dimensional (#6), CCITT group<br>
- 3 2 dimensional (#7), CCITT group 4 2 dimensional (#8). These have<br>
- gotten little testing we only have a couple test files at the current<br>
- time.<br>
-<br>
-pcl/pcl.mak<br>
-pcl/rtgmode.c<br>
-pcl/rtraster.c<br>
-pcl/rtrstcmp.c<br>
-pcl/rtrstcmp.h<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-02 19:37:07 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49be0086211ef92988468cee4bad5d361b8b6c7d">49be0086211ef92988468cee4bad5d361b8b6c7d</a>
-<blockquote>
-<p>
- Improved page size matching in the CUPS Raster output device<br>
-<br>
- The tolerances when comparing the page sizes in the document with the<br>
- sizes in the PPD file are changed to 1% for the short dimension of the<br>
- page and 5% for the long dimension. The 1% for the short dimension is<br>
- more or less the same as the 5.0pt used before (on letter or A4<br>
- paper). The 5% can cover the half inch deviation which HP puts into<br>
- the sheet length for their duplex paper sizes on ink jets.<br>
-<br>
- If there is no matching paper size in the PPD and therefore the paper<br>
- size is considered custom, the page will be rotated in the case that<br>
- it does not fit into the maximum custom paper size (= printer<br>
- dimensions) but fits rotated.<br>
-<br>
- With these measures, pages with slightly incorrectly defined size or<br>
- slightly incorrectly defined sizes in the PPD file (like the different<br>
- entries for one and the same paper size in the PPDs of HPLIP) will<br>
- find their size in the PPD and so rotated if needed.<br>
-<br>
- This avoids cut-off print outs or even crashes of the printer<br>
- (https://bugs.launchpad.net/ubuntu/+source/linux/+bug/917148) due to<br>
- landscape pages not getting rotated.<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 12:55:34 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ee811255187a9367a090ce542e78c13912e92ca6">ee811255187a9367a090ce542e78c13912e92ca6</a>
-<blockquote>
-<p>
- Device Link and Proof Profile fix<br>
-<br>
- If a proofing profile or a device link profile are<br>
- specified, the link transform is more than likely not going<br>
- to be identity. This fix ensures that the transform<br>
- is properly applied.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 18:20:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a68dde56d66d7a5b9aabf0c742efb77b5fbdca03">a68dde56d66d7a5b9aabf0c742efb77b5fbdca03</a>
-<blockquote>
-<p>
- Bug 690473: scale substitute fonts to fit in Widths.<br>
-<br>
- Compare the width of the glyphs in a substitute font with those in the PDF<br>
- Widths array, and scale the font down to fit better, if necessary. This<br>
- does not add scaling up the font.<br>
-<br>
- This changes a number of cluster files - most are progressions, some are just<br>
- different (no worse, no better), none that I consider regressions.<br>
-<br>
-gs/Resource/Init/pdf_font.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 15:28:05 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d630ef2c042179ecf0443b15b488194690f6b980">d630ef2c042179ecf0443b15b488194690f6b980</a>
-<blockquote>
-<p>
- Make device link profile work with lcms2. Also update documentation and add error handling.<br>
-<br>
- The device link profile handling was put in place when we had lcms 1.8 but was not ported<br>
- over to the 2.0 interface.<br>
-<br>
-gs/base/gsicc.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 18:04: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=306f7dce4e74bc715a91dd892eab78f856cf11da">306f7dce4e74bc715a91dd892eab78f856cf11da</a>
-<blockquote>
-<p>
- Have gitlog2changelog.py use html code for &quot;quote&quot; char<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/toolbin/gitlog2changelog.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 17:49:42 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c61e0b90b63dbef94f75e370ccef9dd5a077c26">3c61e0b90b63dbef94f75e370ccef9dd5a077c26</a>
-<blockquote>
-<p>
- Add new &quot;WhatIsGS.htm&quot; document<br>
-<br>
- This explains how Ghostscript, GhostPCL, GhostXPS, etc are related.<br>
-<br>
-gs/doc/Readme.htm<br>
-gs/doc/WhatIsGS.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 11:26:31 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ddedf257534b7c628442d92f771dc8240cf546a7">ddedf257534b7c628442d92f771dc8240cf546a7</a>
-<blockquote>
-<p>
- Bug 691483: Fix access to PDF collections.<br>
-<br>
- Fix a bug in enumeration of a name tree that prevented acceaa to some<br>
- files in the PDF file collection when the name tree was more than<br>
- one level deep.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 12:01:53 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=26a96f7660a921d80dba77ef0220845918cfd4a8">26a96f7660a921d80dba77ef0220845918cfd4a8</a>
-<blockquote>
-<p>
- Have plver.mak use Ghostscript version.mak version number<br>
-<br>
- No (significant) cluster differences.<br>
-<br>
-common/msvc_top.mak<br>
-pl/pl.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 08:12:14 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20cd9c7595492684ac564789afeb2df1b6066554">20cd9c7595492684ac564789afeb2df1b6066554</a>
-<blockquote>
-<p>
- ps2write - silence a benign compiler warning<br>
-<br>
- Picked up by scan-build; presumably this only gets run for commits, not<br>
- for regular cluster tests as it didn't show up previously.<br>
-<br>
-gs/base/gdevpdfc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 20:26:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ca932b9ee0a84e7725b347d9fc99ef8b2b3ad8c8">ca932b9ee0a84e7725b347d9fc99ef8b2b3ad8c8</a>
-<blockquote>
-<p>
- gitlog2changelog.py use html sequence for '&amp;'<br>
-<br>
- Thanks to SaGS for pointing it out.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/toolbin/gitlog2changelog.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 18:14: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=69d0fee61911ef6044b07cd7b36bc2148e6bb214">69d0fee61911ef6044b07cd7b36bc2148e6bb214</a>
-<blockquote>
-<p>
- Tweak gitlog2changelog.py to avoid trailing whitespace<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/toolbin/gitlog2changelog.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 17: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=08a189c3b72e6bf89ae938b0bbacbbf113e0e346">08a189c3b72e6bf89ae938b0bbacbbf113e0e346</a>
-<blockquote>
-<p>
- Improve the html output of the changelog generator.<br>
-<br>
- There were some compatibility problems with the html from the git log to<br>
- html changelog generator - such as including '&lt;' and '&gt;' characters in<br>
- text to be displayed.<br>
-<br>
- Also, improve the actual formatting slightly.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/toolbin/gitlog2changelog.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 17:46:27 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5dd29e182ea1fec5e504558173bbb875501d04a1">5dd29e182ea1fec5e504558173bbb875501d04a1</a>
-<blockquote>
-<p>
- Move the JPEG XR code to a separate section......<br>
-<br>
- ... for non-GPL compatible, open source licensed code.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/doc/thirdparty.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 13:32:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef2a4bfbf4f590635277299bf0e0d7aaea1f392b">ef2a4bfbf4f590635277299bf0e0d7aaea1f392b</a>
-<blockquote>
-<p>
- ps2write - correctly convert ICCBased *image* colour spaces<br>
-<br>
- Previously we handled ICCbased spaces by pretending they were device spaces<br>
- with the same number of components as the ICCBased space. This works<br>
- suprisingly well, but fails utterly for Lab spaces where images come out<br>
- completely incorrect.<br>
-<br>
- We now convert the image data to the current device space. We do not yet handle<br>
- vector colour spaces, this will be handled by a future rewrite of the colour<br>
- handling to permit much better control over colour space handling.<br>
-<br>
- This change causes quite a number o differences in the regression suite.<br>
- These fall into one of 4 causes:<br>
-<br>
- 1) Colour space conversion; previously ICCBases spaces with 1 or 4 components<br>
- would be handled as grey or CMYK respectively. They are now converted to the<br>
- device space (RGB by default). This causes some colour changes, especially<br>
- in halftoned output with a 1 component space. These are not incorrect as can<br>
- be seen from the contone output<br>
-<br>
- 2) There are some minor shifts in colour caused by correctly handling the<br>
- ICCBased space, in general these are progressions (especially the Altona<br>
- suite).<br>
-<br>
- 3) Handling of Lab colour spaces. These now work correctly where previously<br>
- they did not. Especially catx4929.pdf and IA3Z3476.pdf<br>
-<br>
- 4) Honouring rendering intents. Files hwich used a rendering intent now are<br>
- correctly converted. cf Bug #691926, comment 3.<br>
-<br>
- 5) There seems to be a possible problem with converting some CalRGB spaces,<br>
- the resulting output seems 'blue' with respect to the Acrobat otuput. In the<br>
- case of 1 file which contains scanned images of books, it is clear from the<br>
- original book covers that the output is incorrect. Michael suggest this may be<br>
- a White POitn problem. A separate bug report will be filed for this. Ghostscript<br>
- rendering of the original matches the ps2write output.<br>
-<br>
-gs/base/gdevpdfc.c<br>
-gs/base/gdevpdfg.h<br>
-gs/base/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 13:25:17 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=58e2df820785b88a544f625de35fbcb39c35b305">58e2df820785b88a544f625de35fbcb39c35b305</a>
-<blockquote>
-<p>
- Update LICENSE<br>
-<br>
- Revise the LICENSE file to reflect the latest Adobe CMap license<br>
- conditions, and to note that there is an Artifex copyright CMap in the<br>
- CMap directory.<br>
-<br>
- Also, add a note about the JPEX XR source license.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/LICENSE<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 13:23:18 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=523697346bbc88bf309cb44b47f53516c33917f7">523697346bbc88bf309cb44b47f53516c33917f7</a>
-<blockquote>
-<p>
- Increment Ghostscript version on master to 9.06.<br>
-<br>
- No (important) cluster differences.<br>
-<br>
-gs/Resource/Init/gs_init.ps<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-08 08:42: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=593431146ef93a53744a04c2a571a6f1f40b0084">593431146ef93a53744a04c2a571a6f1f40b0084</a>
-<blockquote>
-<p>
- Remove &quot;RELEASE CANDIDATE&quot; from product string.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/gscdef.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-08 08:40:12 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c1d20ffdb4d184c9019ee7f58bc279c6d633d05d">c1d20ffdb4d184c9019ee7f58bc279c6d633d05d</a>
-<blockquote>
-<p>
- Amend date and update changelog for 9.05 release.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/version.mak<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/WhatIsGS.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pdfopt.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-03 16:18: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=dd4c7f1f03aa7ea18d43db224126502725af91ba">dd4c7f1f03aa7ea18d43db224126502725af91ba</a>
-<blockquote>
-<p>
- Propogate dynmic device flags to 'so' subtarget.<br>
-<br>
- When I brought the Makefile into line with convention for some of the FLAGS<br>
- variables, I forgot to add the new 'AC_CFLAGS' value to the subtarget for<br>
- the dynamic library build.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/unix-dll.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-03 16:20:25 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e837609b2955680dc59ca4f357076be7cd819a46">e837609b2955680dc59ca4f357076be7cd819a46</a>
-<blockquote>
-<p>
- CUPS Raster: Fixed rotating of input pages with unknown sizes<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-02 21:02:26 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c3464da3ee42b8af645af6eadabea4977d948b1a">c3464da3ee42b8af645af6eadabea4977d948b1a</a>
-<blockquote>
-<p>
- CUPS Raster: More on improving page size fitting<br>
-<br>
- Raised the tolerance of matching the document's page sizes with the PPD's<br>
- page sizes on the short dimension to 2 %. This also covers the overspray<br>
- full-bleed page sizes of HPLIP.<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-02 19:37:07 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c12ed06596207d895739b41e5c920af0aa48a2ff">c12ed06596207d895739b41e5c920af0aa48a2ff</a>
-<blockquote>
-<p>
- Improved page size matching in the CUPS Raster output device<br>
-<br>
- The tolerances when comparing the page sizes in the document with the<br>
- sizes in the PPD file are changed to 1% for the short dimension of the<br>
- page and 5% for the long dimension. The 1% for the short dimension is<br>
- more or less the same as the 5.0pt used before (on letter or A4<br>
- paper). The 5% can cover the half inch deviation which HP puts into<br>
- the sheet length for their duplex paper sizes on ink jets.<br>
-<br>
- If there is no matching paper size in the PPD and therefore the paper<br>
- size is considered custom, the page will be rotated in the case that<br>
- it does not fit into the maximum custom paper size (= printer<br>
- dimensions) but fits rotated.<br>
-<br>
- With these measures, pages with slightly incorrectly defined size or<br>
- slightly incorrectly defined sizes in the PPD file (like the different<br>
- entries for one and the same paper size in the PPDs of HPLIP) will<br>
- find their size in the PPD and so rotated if needed.<br>
-<br>
- This avoids cut-off print outs or even crashes of the printer<br>
- (https://bugs.launchpad.net/ubuntu/+source/linux/+bug/917148) due to<br>
- landscape pages not getting rotated.<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-01 11:06: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=f945ac6dd076b367fb9a9d8851cca783049b77a0">f945ac6dd076b367fb9a9d8851cca783049b77a0</a>
-<blockquote>
-<p>
- Change product string to &quot;RELEASE CANDIDATE 1&quot;<br>
-<br>
-gs/base/gscdef.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-01 10:59:52 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5f1a49cb3b05b5fed23e7eab99d6e036f16921dd">5f1a49cb3b05b5fed23e7eab99d6e036f16921dd</a>
-<blockquote>
-<p>
- Update docs for 9.05 release candidate.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 12:55:34 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ffca2758193c517edf1d20c6af17acd85f8d5f99">ffca2758193c517edf1d20c6af17acd85f8d5f99</a>
-<blockquote>
-<p>
- Device Link and Proof Profile fix<br>
-<br>
- If a proofing profile or a device link profile are<br>
- specified, the link transform is more than likely not going<br>
- to be identity. This fix ensures that the transform<br>
- is properly applied.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 15:28:05 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dbf3d3403bc928c183b0674aa5adbb6263d56e42">dbf3d3403bc928c183b0674aa5adbb6263d56e42</a>
-<blockquote>
-<p>
- Make device link profile work with lcms2. Also update documentation and add error handling.<br>
-<br>
- The device link profile handling was put in place when we had lcms 1.8 but was not ported<br>
- over to the 2.0 interface.<br>
-<br>
-gs/base/gsicc.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 18:04: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=55049debcc22152c42a62b1fc350eb087125be5a">55049debcc22152c42a62b1fc350eb087125be5a</a>
-<blockquote>
-<p>
- Have gitlog2changelog.py use html code for &quot;quote&quot; char<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/toolbin/gitlog2changelog.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 17:49:42 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6123f6bc89a9c682dd0e0b8cb62d526fdca1b50a">6123f6bc89a9c682dd0e0b8cb62d526fdca1b50a</a>
-<blockquote>
-<p>
- Add new &quot;WhatIsGS.htm&quot; document<br>
-<br>
- This explains how Ghostscript, GhostPCL, GhostXPS, etc are related.<br>
-<br>
-gs/doc/Readme.htm<br>
-gs/doc/WhatIsGS.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 11:26:31 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1216fd5e30a1a09b8b381d4e43d795728a030cc8">1216fd5e30a1a09b8b381d4e43d795728a030cc8</a>
-<blockquote>
-<p>
- Bug 691483: Fix access to PDF collections.<br>
-<br>
- Fix a bug in enumeration of a name tree that prevented acceaa to some<br>
- files in the PDF file collection when the name tree was more than<br>
- one level deep.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 08:12:14 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0a549a4395c169a547e95a2905650dbc05388794">0a549a4395c169a547e95a2905650dbc05388794</a>
-<blockquote>
-<p>
- ps2write - silence a benign compiler warning<br>
-<br>
- Picked up by scan-build; presumably this only gets run for commits, not<br>
- for regular cluster tests as it didn't show up previously.<br>
-<br>
-gs/base/gdevpdfc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 12:01:53 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4003b18b598c81df02d3d2c043276d54e7de7c6d">4003b18b598c81df02d3d2c043276d54e7de7c6d</a>
-<blockquote>
-<p>
- Have plver.mak use Ghostscript version.mak version number<br>
-<br>
- No (significant) cluster differences.<br>
-<br>
-common/msvc_top.mak<br>
-pl/pl.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 20:39: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=613b796e44ad8e29d9b4f8166a8b19796f1a024c">613b796e44ad8e29d9b4f8166a8b19796f1a024c</a>
-<blockquote>
-<p>
- Change a couple of '&amp;' to &amp;amp;<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 20:26:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f58e15f60683f2be163e0a64ef1a86141a0d45c3">f58e15f60683f2be163e0a64ef1a86141a0d45c3</a>
-<blockquote>
-<p>
- gitlog2changelog.py use html sequence for '&amp;'<br>
-<br>
- Thanks to SaGS for pointing it out.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/toolbin/gitlog2changelog.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 18:14: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=7a9e90a4710a90ce3d12da590280e91166eb2dc5">7a9e90a4710a90ce3d12da590280e91166eb2dc5</a>
-<blockquote>
-<p>
- Tweak gitlog2changelog.py to avoid trailing whitespace<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/toolbin/gitlog2changelog.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 18:00: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=4aaa5f1594df678db91e3e9e913d1b27d5f7cd05">4aaa5f1594df678db91e3e9e913d1b27d5f7cd05</a>
-<blockquote>
-<p>
- Update docs in prep for 9.05 release candidate<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pdfopt.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 17:59: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=60ef9ebafb60f60cb709f7cb48ff15b94bad45fe">60ef9ebafb60f60cb709f7cb48ff15b94bad45fe</a>
-<blockquote>
-<p>
- Change product string in prep for 9.05 release candidate<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 17:46:27 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=16195b5e1c104405e095753bc1343597cad32a28">16195b5e1c104405e095753bc1343597cad32a28</a>
-<blockquote>
-<p>
- Move the JPEG XR code to a separate section......<br>
-<br>
- ... for non-GPL compatible, open source licensed code.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/doc/thirdparty.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 17: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=4961e763aeb795e7dc91dc64575837d170cca367">4961e763aeb795e7dc91dc64575837d170cca367</a>
-<blockquote>
-<p>
- Improve the html output of the changelog generator.<br>
-<br>
- There were some compatibility problems with the html from the git log to<br>
- html changelog generator - such as including '&lt;' and '&gt;' characters in<br>
- text to be displayed.<br>
-<br>
- Also, improve the actual formatting slightly.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/toolbin/gitlog2changelog.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 13:32:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c3cc9b71fb9f1fe64556ecad34418bb4cf44ba7f">c3cc9b71fb9f1fe64556ecad34418bb4cf44ba7f</a>
-<blockquote>
-<p>
- ps2write - correctly convert ICCBased *image* colour spaces<br>
-<br>
- Previously we handled ICCbased spaces by pretending they were device spaces<br>
- with the same number of components as the ICCBased space. This works<br>
- suprisingly well, but fails utterly for Lab spaces where images come out<br>
- completely incorrect.<br>
-<br>
- We now convert the image data to the current device space. We do not yet handle<br>
- vector colour spaces, this will be handled by a future rewrite of the colour<br>
- handling to permit much better control over colour space handling.<br>
-<br>
- This change causes quite a number o differences in the regression suite.<br>
- These fall into one of 4 causes:<br>
-<br>
- 1) Colour space conversion; previously ICCBases spaces with 1 or 4 components<br>
- would be handled as grey or CMYK respectively. They are now converted to the<br>
- device space (RGB by default). This causes some colour changes, especially<br>
- in halftoned output with a 1 component space. These are not incorrect as can<br>
- be seen from the contone output<br>
-<br>
- 2) There are some minor shifts in colour caused by correctly handling the<br>
- ICCBased space, in general these are progressions (especially the Altona<br>
- suite).<br>
-<br>
- 3) Handling of Lab colour spaces. These now work correctly where previously<br>
- they did not. Especially catx4929.pdf and IA3Z3476.pdf<br>
-<br>
- 4) Honouring rendering intents. Files hwich used a rendering intent now are<br>
- correctly converted. cf Bug #691926, comment 3.<br>
-<br>
- 5) There seems to be a possible problem with converting some CalRGB spaces,<br>
- the resulting output seems 'blue' with respect to the Acrobat otuput. In the<br>
- case of 1 file which contains scanned images of books, it is clear from the<br>
- original book covers that the output is incorrect. Michael suggest this may be<br>
- a White POitn problem. A separate bug report will be filed for this. Ghostscript<br>
- rendering of the original matches the ps2write output.<br>
-<br>
-gs/base/gdevpdfc.c<br>
-gs/base/gdevpdfg.h<br>
-gs/base/gdevpdfi.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 13:25:17 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2bb769a5b1ff2d1b8a5e6f0320cb210befe3f5bd">2bb769a5b1ff2d1b8a5e6f0320cb210befe3f5bd</a>
-<blockquote>
-<p>
- Update LICENSE<br>
-<br>
- Revise the LICENSE file to reflect the latest Adobe CMap license<br>
- conditions, and to note that there is an Artifex copyright CMap in the<br>
- CMap directory.<br>
-<br>
- Also, add a note about the JPEX XR source license.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/LICENSE<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-
-<h2><a name="Version9.05"></a>Version 9.05 (2012-02-08)</h2>
-
-<p>This is the fifth full release in the stable 9.x series.
-
-<p> Highlights in this release include:
-<ul>
-<li><p>Ghostscript's PDF interpreter is now able to make use of the DroidSansFallback
-TrueType font to automatically substitute for missing CIDFonts. Whilst it is
-<b>always</b> best to ensure the original CIDFont is available for the best
-and most accurate output, the ability to make an automatic substitution will
-be valuable for those merely viewing or proofing such files.
-</li>
-<li><p>This release includes support for a proofing ICC profile. The command option
-is specified using -sProofProfile=filename. With this option, the color output will
-emulate what would be obtained had the source file been rendered on a device defined
-by the proofing profile.
-(See <a href="GS9_Color_Management.pdf">GS9_Color_Management.pdf</a> for details.)
-</li>
-<li><p>This release includes support for a device link ICC profile. The command option
-is specified using -sDeviceLinkProfile=filename. With this option, the device link profile
-is added to the end of the link transform from source to destination. In this case, one can
-include a command line option like &quot;-sDevice=tiff32nc -sOutputICCProfile=srgb.icc
--sDeviceLinkProfile=linkRGBtoCMYK.icc&quot; and source colors will be mapped through sRGB
-and through the device link profile to CMYK values for the device.
-(See <a href="GS9_Color_Management.pdf">GS9_Color_Management.pdf</a> for details.)
-</li>
-<li><p>Ghostscript now supports "unmanaged color transformations" for source DeviceXXX
-colors (in other words, they use a simplistic conversion, rather than the ICC profile
-based color workflow). This is beneficial in uses where performance takes precedence
-over ultimate color fidelity (the command line parameter -dUseFastColor enables this).
-</li>
-<li><p>The font set distributed with Ghostscript has been changed to the standard
-35 Postscript-compatible fonts distributed by URW.
-</li>
-<li><p>Ghostscript now includes a simple ink-coverage device, contributed by
-Sebastian Kapfer (inkconv).
-</li>
-<li><p>The TIFF, JPEG and PNG output devices now support embedding of the device ICC profile
-in the output file.
-</li>
-<li><p>Ghostscript now ships modified OpenJPEG sources for JPEG2000 decoding (replacing
-JasPer - although JasPer is still included for this release). Performance, reliability
-and memory use whilst decoding JPX streams are all improved (in many cases, significantly).
-</li>
-<li><p>jbig2dec now has simple halftone region support.
-</li>
-<li><p>The ps2write device has had a large number of output quality and stability
-improvements.
-</li>
-<li><p>The txtwrite output was modified so that it more closely matches the output from
-MuPDF, if requested. Note that the algorithms used by the two products are not
-identical and may return slightly differing results.
-</li>
-</ul>
-<br>(See <a href="Devices.htm#TXT">Devices.htm</a> for details)
-<p>
-<br>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.05_Incompatible_changes"></a>Incompatible changes</h3>
-<p>
-No recorded incompatible changes.
-
-<h3><a name="9.05_Changelog"></a>Changelog</h3>
-<p><strong>2012-02-03 16:18: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=dd4c7f1f03aa7ea18d43db224126502725af91ba">dd4c7f1f03aa7ea18d43db224126502725af91ba</a>
-<blockquote>
-<p>
- Propogate dynmic device flags to 'so' subtarget.<br>
-<br>
- When I brought the Makefile into line with convention for some of the FLAGS<br>
- variables, I forgot to add the new 'AC_CFLAGS' value to the subtarget for<br>
- the dynamic library build.<br>
-<br>
- No cluster differences.<br>
-<br>
-gs/base/unix-dll.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-03 16:20:25 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e837609b2955680dc59ca4f357076be7cd819a46">e837609b2955680dc59ca4f357076be7cd819a46</a>
-<blockquote>
-<p>
- CUPS Raster: Fixed rotating of input pages with unknown sizes<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-02 21:02:26 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c3464da3ee42b8af645af6eadabea4977d948b1a">c3464da3ee42b8af645af6eadabea4977d948b1a</a>
-<blockquote>
-<p>
- CUPS Raster: More on improving page size fitting<br>
-<br>
- Raised the tolerance of matching the document's page sizes with the PPD's<br>
- page sizes on the short dimension to 2 %. This also covers the overspray<br>
- full-bleed page sizes of HPLIP.<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-02 19:37:07 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c12ed06596207d895739b41e5c920af0aa48a2ff">c12ed06596207d895739b41e5c920af0aa48a2ff</a>
-<blockquote>
-<p>
- Improved page size matching in the CUPS Raster output device<br>
-<br>
- The tolerances when comparing the page sizes in the document with the<br>
- sizes in the PPD file are changed to 1% for the short dimension of the<br>
- page and 5% for the long dimension. The 1% for the short dimension is<br>
- more or less the same as the 5.0pt used before (on letter or A4<br>
- paper). The 5% can cover the half inch deviation which HP puts into<br>
- the sheet length for their duplex paper sizes on ink jets.<br>
-<br>
- If there is no matching paper size in the PPD and therefore the paper<br>
- size is considered custom, the page will be rotated in the case that<br>
- it does not fit into the maximum custom paper size (= printer<br>
- dimensions) but fits rotated.<br>
-<br>
- With these measures, pages with slightly incorrectly defined size or<br>
- slightly incorrectly defined sizes in the PPD file (like the different<br>
- entries for one and the same paper size in the PPDs of HPLIP) will<br>
- find their size in the PPD and so rotated if needed.<br>
-<br>
- This avoids cut-off print outs or even crashes of the printer<br>
- (https://bugs.launchpad.net/ubuntu/+source/linux/+bug/917148) due to<br>
- landscape pages not getting rotated.<br>
-<br>
-gs/cups/gdevcups.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-01 11:06: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=f945ac6dd076b367fb9a9d8851cca783049b77a0">f945ac6dd076b367fb9a9d8851cca783049b77a0</a>
-<blockquote>
-<p>
- Change product string to &quot;RELEASE CANDIDATE 1&quot;<br>
-<br>
-gs/base/gscdef.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-02-01 10:59:52 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5f1a49cb3b05b5fed23e7eab99d6e036f16921dd">5f1a49cb3b05b5fed23e7eab99d6e036f16921dd</a>
-<blockquote>
-<p>
- Update docs for 9.05 release candidate.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 12:55:34 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ffca2758193c517edf1d20c6af17acd85f8d5f99">ffca2758193c517edf1d20c6af17acd85f8d5f99</a>
-<blockquote>
-<p>
- Device Link and Proof Profile fix<br>
-<br>
- If a proofing profile or a device link profile are<br>
- specified, the link transform is more than likely not going<br>
- to be identity. This fix ensures that the transform<br>
- is properly applied.<br>
-<br>
-gs/base/gsicc_cache.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 15:28:05 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dbf3d3403bc928c183b0674aa5adbb6263d56e42">dbf3d3403bc928c183b0674aa5adbb6263d56e42</a>
-<blockquote>
-<p>
- Make device link profile work with lcms2. Also update documentation and add error handling.<br>
-<br>
- The device link profile handling was put in place when we had lcms 1.8 but was not ported<br>
- over to the 2.0 interface.<br>
-<br>
-gs/base/gsicc.c<br>
-gs/base/gsicc_lcms2.c<br>
-gs/doc/Use.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 18:04: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=55049debcc22152c42a62b1fc350eb087125be5a">55049debcc22152c42a62b1fc350eb087125be5a</a>
-<blockquote>
-<p>
- Have gitlog2changelog.py use html code for &quot;quote&quot; char<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/toolbin/gitlog2changelog.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 17:49:42 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6123f6bc89a9c682dd0e0b8cb62d526fdca1b50a">6123f6bc89a9c682dd0e0b8cb62d526fdca1b50a</a>
-<blockquote>
-<p>
- Add new &quot;WhatIsGS.htm&quot; document<br>
-<br>
- This explains how Ghostscript, GhostPCL, GhostXPS, etc are related.<br>
-<br>
-gs/doc/Readme.htm<br>
-gs/doc/WhatIsGS.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 11:26:31 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1216fd5e30a1a09b8b381d4e43d795728a030cc8">1216fd5e30a1a09b8b381d4e43d795728a030cc8</a>
-<blockquote>
-<p>
- Bug 691483: Fix access to PDF collections.<br>
-<br>
- Fix a bug in enumeration of a name tree that prevented acceaa to some<br>
- files in the PDF file collection when the name tree was more than<br>
- one level deep.<br>
-<br>
-gs/Resource/Init/pdf_main.ps<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 08:12:14 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0a549a4395c169a547e95a2905650dbc05388794">0a549a4395c169a547e95a2905650dbc05388794</a>
-<blockquote>
-<p>
- ps2write - silence a benign compiler warning<br>
-<br>
- Picked up by scan-build; presumably this only gets run for commits, not<br>
- for regular cluster tests as it didn't show up previously.<br>
-<br>
-gs/base/gdevpdfc.c<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-31 12:01:53 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4003b18b598c81df02d3d2c043276d54e7de7c6d">4003b18b598c81df02d3d2c043276d54e7de7c6d</a>
-<blockquote>
-<p>
- Have plver.mak use Ghostscript version.mak version number<br>
-<br>
- No (significant) cluster differences.<br>
-<br>
-common/msvc_top.mak<br>
-pl/pl.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 20:39: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=613b796e44ad8e29d9b4f8166a8b19796f1a024c">613b796e44ad8e29d9b4f8166a8b19796f1a024c</a>
-<blockquote>
-<p>
- Change a couple of '&amp;' to &amp;amp;<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/doc/History9.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 20:26:30 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f58e15f60683f2be163e0a64ef1a86141a0d45c3">f58e15f60683f2be163e0a64ef1a86141a0d45c3</a>
-<blockquote>
-<p>
- gitlog2changelog.py use html sequence for '&amp;'<br>
-<br>
- Thanks to SaGS for pointing it out.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/toolbin/gitlog2changelog.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 18:14: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=7a9e90a4710a90ce3d12da590280e91166eb2dc5">7a9e90a4710a90ce3d12da590280e91166eb2dc5</a>
-<blockquote>
-<p>
- Tweak gitlog2changelog.py to avoid trailing whitespace<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/toolbin/gitlog2changelog.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 18:00: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=4aaa5f1594df678db91e3e9e913d1b27d5f7cd05">4aaa5f1594df678db91e3e9e913d1b27d5f7cd05</a>
-<blockquote>
-<p>
- Update docs in prep for 9.05 release candidate<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/doc/API.htm<br>
-gs/doc/C-style.htm<br>
-gs/doc/Commprod.htm<br>
-gs/doc/DLL.htm<br>
-gs/doc/Deprecated.htm<br>
-gs/doc/Details8.htm<br>
-gs/doc/Details9.htm<br>
-gs/doc/Develop.htm<br>
-gs/doc/Devices.htm<br>
-gs/doc/Drivers.htm<br>
-gs/doc/Fonts.htm<br>
-gs/doc/Helpers.htm<br>
-gs/doc/History1.htm<br>
-gs/doc/History2.htm<br>
-gs/doc/History3.htm<br>
-gs/doc/History4.htm<br>
-gs/doc/History5.htm<br>
-gs/doc/History6.htm<br>
-gs/doc/History7.htm<br>
-gs/doc/History8.htm<br>
-gs/doc/History9.htm<br>
-gs/doc/Install.htm<br>
-gs/doc/Issues.htm<br>
-gs/doc/Language.htm<br>
-gs/doc/Lib.htm<br>
-gs/doc/Make.htm<br>
-gs/doc/News.htm<br>
-gs/doc/Projects.htm<br>
-gs/doc/Ps-style.htm<br>
-gs/doc/Ps2epsi.htm<br>
-gs/doc/Ps2pdf.htm<br>
-gs/doc/Ps2ps2.htm<br>
-gs/doc/Psfiles.htm<br>
-gs/doc/Readme.htm<br>
-gs/doc/Release.htm<br>
-gs/doc/Source.htm<br>
-gs/doc/Unix-lpr.htm<br>
-gs/doc/Use.htm<br>
-gs/doc/Xfonts.htm<br>
-gs/doc/gs-vms.hlp<br>
-gs/doc/thirdparty.htm<br>
-gs/man/dvipdf.1<br>
-gs/man/font2c.1<br>
-gs/man/gs.1<br>
-gs/man/gslp.1<br>
-gs/man/gsnd.1<br>
-gs/man/pdf2dsc.1<br>
-gs/man/pdf2ps.1<br>
-gs/man/pdfopt.1<br>
-gs/man/pf2afm.1<br>
-gs/man/pfbtopfa.1<br>
-gs/man/printafm.1<br>
-gs/man/ps2ascii.1<br>
-gs/man/ps2epsi.1<br>
-gs/man/ps2pdf.1<br>
-gs/man/ps2pdfwr.1<br>
-gs/man/ps2ps.1<br>
-gs/man/wftopfa.1<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 17:59: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=60ef9ebafb60f60cb709f7cb48ff15b94bad45fe">60ef9ebafb60f60cb709f7cb48ff15b94bad45fe</a>
-<blockquote>
-<p>
- Change product string in prep for 9.05 release candidate<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/base/version.mak<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 17:46:27 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=16195b5e1c104405e095753bc1343597cad32a28">16195b5e1c104405e095753bc1343597cad32a28</a>
-<blockquote>
-<p>
- Move the JPEG XR code to a separate section......<br>
-<br>
- ... for non-GPL compatible, open source licensed code.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/doc/thirdparty.htm<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 17: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=4961e763aeb795e7dc91dc64575837d170cca367">4961e763aeb795e7dc91dc64575837d170cca367</a>
-<blockquote>
-<p>
- Improve the html output of the changelog generator.<br>
-<br>
- There were some compatibility problems with the html from the git log to<br>
- html changelog generator - such as including '&lt;' and '&gt;' characters in<br>
- text to be displayed.<br>
-<br>
- Also, improve the actual formatting slightly.<br>
-<br>
- CLUSTER_UNTESTED<br>
-<br>
-gs/toolbin/gitlog2changelog.py<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 13:32:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c3cc9b71fb9f1fe64556ecad34418bb4cf44ba7f">c3cc9b71fb9f1fe64556ecad34418bb4cf44ba7f</a>
-<blockquote>
-<p>
- ps2write - correctly convert ICCBased *image* colour spaces
-<br>
-
-<br>
- Previously we handled ICCbased spaces by pretending they were device spaces
-<br>
- with the same number of components as the ICCBased space. This works
-<br>
- suprisingly well, but fails utterly for Lab spaces where images come out
-<br>
- completely incorrect.
-<br>
-
-<br>
- We now convert the image data to the current device space. We do not yet handle
-<br>
- vector colour spaces, this will be handled by a future rewrite of the colour
-<br>
- handling to permit much better control over colour space handling.
-<br>
-
-<br>
- This change causes quite a number o differences in the regression suite.
-<br>
- These fall into one of 4 causes:
-<br>
-
-<br>
- 1) Colour space conversion; previously ICCBases spaces with 1 or 4 components
-<br>
- would be handled as grey or CMYK respectively. They are now converted to the
-<br>
- device space (RGB by default). This causes some colour changes, especially
-<br>
- in halftoned output with a 1 component space. These are not incorrect as can
-<br>
- be seen from the contone output
-<br>
-
-<br>
- 2) There are some minor shifts in colour caused by correctly handling the
-<br>
- ICCBased space, in general these are progressions (especially the Altona
-<br>
- suite).
-<br>
-
-<br>
- 3) Handling of Lab colour spaces. These now work correctly where previously
-<br>
- they did not. Especially catx4929.pdf and IA3Z3476.pdf
-<br>
-
-<br>
- 4) Honouring rendering intents. Files hwich used a rendering intent now are
-<br>
- correctly converted. cf Bug #691926, comment 3.
-<br>
-
-<br>
- 5) There seems to be a possible problem with converting some CalRGB spaces,
-<br>
- the resulting output seems 'blue' with respect to the Acrobat otuput. In the
-<br>
- case of 1 file which contains scanned images of books, it is clear from the
-<br>
- original book covers that the output is incorrect. Michael suggest this may be
-<br>
- a White POitn problem. A separate bug report will be filed for this. Ghostscript
-<br>
- rendering of the original matches the ps2write output.
-<br>
-
-<br>
-gs/base/gdevpdfc.c
-<br>
-gs/base/gdevpdfg.h
-<br>
-gs/base/gdevpdfi.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-30 13:25:17 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2bb769a5b1ff2d1b8a5e6f0320cb210befe3f5bd">2bb769a5b1ff2d1b8a5e6f0320cb210befe3f5bd</a>
-<blockquote>
-<p>
- Update LICENSE
-<br>
-
-<br>
- Revise the LICENSE file to reflect the latest Adobe CMap license
-<br>
- conditions, and to note that there is an Artifex copyright CMap in the
-<br>
- CMap directory.
-<br>
-
-<br>
- Also, add a note about the JPEX XR source license.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/LICENSE
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-28 01:24:50 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e25d12238406245ade09eaeb3dd815933f7bcb2">4e25d12238406245ade09eaeb3dd815933f7bcb2</a>
-<blockquote>
-<p>
- Bug 692704: Don't reset PageSpotColors after every page
-<br>
-
-<br>
- Don't reset PageSpotColors after every PDF page. Do it once when
-<br>
- PDF is closed. first, this resetting serves no useful purpose.
-<br>
- Second, this change avoids re-initialisation of tiffsep and psdcmyk
-<br>
- devices, which causes overwriting of the first page.
-<br>
-
-<br>
- The fix results in progressions in all multi-page PDF files on
-<br>
- psdcmyk device.
-<br>
-
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-27 09:57: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=d385d65cddb8770c0b6e08d0a34609d0951eab1f">d385d65cddb8770c0b6e08d0a34609d0951eab1f</a>
-<blockquote>
-<p>
- Add a link in Readme.htm to the new thirdparty.htm
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/doc/Readme.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-26 16:58:02 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b6cc2a2539097d71ec200591788134703a2840a1">b6cc2a2539097d71ec200591788134703a2840a1</a>
-<blockquote>
-<p>
- XPS Whitespace handling fix
-<br>
-
-<br>
- Update the xps point reading code to use strtod rather than atof;
-<br>
- this returns us an updated string pointer, rather than relying
-<br>
- on us second-guessing where it may end up.
-<br>
-
-<br>
- Change xps_get_point to return this updated pointer, and change some
-<br>
- calls of this to avoid having to skip whitespace (and potentially
-<br>
- getting it wrong) after the call.
-<br>
-
-<br>
- Spotted as part of the commit to take the latest XPS changes into
-<br>
- MuPDF.
-<br>
-
-<br>
-xps/ghostxps.h
-<br>
-xps/xpspath.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-26 15:17:34 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8eb237bc17ea481f75f482288c854ca42b31466b">8eb237bc17ea481f75f482288c854ca42b31466b</a>
-<blockquote>
-<p>
- ps2write - do not allow Widths aray to alter /.notdef width.
-<br>
-
-<br>
- The way the Widths array works, if the Encoding has a /.notdef entry then
-<br>
- the width of the /.notdef is altered to that width.
-<br>
-
-<br>
- If we have an earlier re-assignment, this breaks the assigned width.
-<br>
-
-<br>
- The file catx1490.pdf relies on a ./notdef to draw a 'box' (crazy but
-<br>
- that's what it does). If we redefine the width tehn it is incorrect.
-<br>
-
-<br>
- Expected differences
-<br>
- Catx1490.pdf
-<br>
- Bug691221.pdf
-<br>
- Bug689757.pdf
-<br>
- THe latter two are minor differences, but slight progressions
-<br>
-
-<br>
-gs/base/opdfread.h
-<br>
-gs/lib/opdfread.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-26 11:07:06 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=043a20124c63ee48f874e8a9d869098d099c6d19">043a20124c63ee48f874e8a9d869098d099c6d19</a>
-<blockquote>
-<p>
- Have the &quot;configure&quot; build cope with missing &quot;contrib&quot;
-<br>
-
-<br>
- For the Artifex commercial release, we remove the files from the contrib
-<br>
- directory. This meant a successful build had to be &quot;configured&quot; with the
-<br>
- --without-contrib option.
-<br>
-
-<br>
- Now, configure looks for a specific file in &quot;contrib&quot;, and if it is not there
-<br>
- the contributed drivers are automatically disabled.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-25 19:58: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=0fb4785ef74fd22b8c1cced5ec16bd28d5bcc666">0fb4785ef74fd22b8c1cced5ec16bd28d5bcc666</a>
-<blockquote>
-<p>
- Fix Bug 692343 - ignore invalid padding length bytes.
-<br>
-
-<br>
- AES streams contain padding at the end to bring them up to 16
-<br>
- byte chunks. The last byte of the plaintext is supposed to be
-<br>
- a value between 1 and 16 telling us how many bytes to ignore
-<br>
- from the last one? (Why 16? 15 would make more sense).
-<br>
-
-<br>
- If the padding byte was out of range we would previously have
-<br>
- thrown an error. Here we change to just warn and set the
-<br>
- padding length to 0. This means we'll err on the side of making
-<br>
- the stream too long, which is better than the alternative.
-<br>
-
-<br>
-gs/base/saes.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-25 19:21:08 +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=845ac2669008d3c8daf6461c0fda3b0496d7443e">845ac2669008d3c8daf6461c0fda3b0496d7443e</a>
-<blockquote>
-<p>
- Bug 691254: This patch prevents the seg fault in Jbig2_042_14.pdf.
-<br>
-
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c
-<br>
-gs/jbig2dec/jbig2_text.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-25 08:14:22 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=679964341b8543bc37bf3cb783f12434af829f64">679964341b8543bc37bf3cb783f12434af829f64</a>
-<blockquote>
-<p>
- ps2write - properly check number of components when converting Image type 3/4
-<br>
-
-<br>
- The code to limit optimisation of image type 3 or 4 into an imagemask was
-<br>
- testing to see if the routine which returned the numebr of components in
-<br>
- the colour space was a particular routine, instead of testing the return
-<br>
- value of that routine to see if it was 1.
-<br>
-
-<br>
- Expected Differences
-<br>
- Bug689717.pdf
-<br>
- ImageProb2.pdf
-<br>
- 12-07c.ps
-<br>
- all now render correctly or (in the case of 12-07c.ps) exhibit useful
-<br>
- progressions, when converted to PostScript using ps2write
-<br>
-
-<br>
-gs/base/gdevpdfi.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-24 12:59:20 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83ce7cf6c9252c39e280040b12db1dcfbd8a7cb2">83ce7cf6c9252c39e280040b12db1dcfbd8a7cb2</a>
-<blockquote>
-<p>
- Fix for bug 692733. Pattern clist improperly cleared.
-<br>
-
-<br>
- The pattern code was performing an initial clear of the pattern. This is OK
-<br>
- when the pattern is not a clist since the mask was not drawn in when this
-<br>
- fill occurs (seee gx_erase_colored_pattern). Unfortunately this rect fill
-<br>
- was getting into the pattern clist which is should not.
-<br>
-
-<br>
-gs/base/gxpcmap.c
-<br>
-gs/psi/zpcolor.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-24 16:44:07 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1fab5a6b3945ba46fadd326e01f25e94f8af0886">1fab5a6b3945ba46fadd326e01f25e94f8af0886</a>
-<blockquote>
-<p>
- Note that we patch lcms2 in thirdparty.htm
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/doc/thirdparty.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-24 16:22: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=345be99ff34a6023dd28c06869ff8db41a3c640c">345be99ff34a6023dd28c06869ff8db41a3c640c</a>
-<blockquote>
-<p>
- Add a file detailing our use of third party libraries.
-<br>
-
-<br>
- Including, name, version, purpose, license and URL.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/doc/thirdparty.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-24 13:20:11 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb56842749e5430ed18d938eb78d1cf24c3e9759">fb56842749e5430ed18d938eb78d1cf24c3e9759</a>
-<blockquote>
-<p>
- Tweak jbig2dec to cope better with NULLs.
-<br>
-
-<br>
- Fix various destructors in jbig2dec to cope with being called
-<br>
- with image = NULL. This cures a problem in mupdf where it SEGVs
-<br>
- when called on &quot;1239 - skip invalid content streams.pdf&quot; from the
-<br>
- sumatra test set.
-<br>
-
-<br>
-gs/jbig2dec/jbig2_image.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-24 12:03: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=a92b0c487e0e003a6a69b93acb7c1ef84d2f9683">a92b0c487e0e003a6a69b93acb7c1ef84d2f9683</a>
-<blockquote>
-<p>
- Add details to Make.htm about Luratech
-<br>
-
-<br>
- Make it clear that if there, Luratech will be used automatically.
-<br>
-
-<br>
- Add details about disabling automatic Luratech inclusion.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/doc/Make.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-24 11:49: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=672fba9c5396ff7079e166a7535b879deffd801a">672fba9c5396ff7079e166a7535b879deffd801a</a>
-<blockquote>
-<p>
- Bug 691184: update doc and example for getenv in cidfmap
-<br>
-
-<br>
- Add information to the cidfmap section of Use.htm mentioning the ability to
-<br>
- use &quot;getenv&quot; to influence paths to font files in cidfmap.
-<br>
-
-<br>
- And fix the example in cidfmap.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/Resource/Init/cidfmap
-<br>
-gs/doc/Use.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-24 11:44:34 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=997f750a5dd4cf70b18d011e3297dd7c8f4abd97">997f750a5dd4cf70b18d011e3297dd7c8f4abd97</a>
-<blockquote>
-<p>
- Bug 692810: fix OpenJPEG section of configure --help
-<br>
-
-<br>
- I forgot to reverse the logic of the help message when I made OpenJPEG the
-<br>
- default JPEG2000 decoder - so the option is now to *disable* it.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-23 22:52:33 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1f3469404c599093df2e6c8157ac70111b0c80e2">1f3469404c599093df2e6c8157ac70111b0c80e2</a>
-<blockquote>
-<p>
- Revert &quot;Addition of objects to support the output intent.&quot;
-<br>
-
-<br>
- This reverts commit 89546758c858d53c105dfc73fc4d108171b8437d.
-<br>
-
-<br>
- Something appears to be wrong with this when I was doing some other testing
-<br>
- although it did ok in the cluster push.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gsdparam.c
-<br>
-gs/base/gsequivc.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-23 09:59:35 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=89546758c858d53c105dfc73fc4d108171b8437d">89546758c858d53c105dfc73fc4d108171b8437d</a>
-<blockquote>
-<p>
- Addition of objects to support the output intent.
-<br>
-
-<br>
- This doesn't do anything yet. There will be another commit for the
-<br>
- PDF interpreter to make use of these objects.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gsdparam.c
-<br>
-gs/base/gsequivc.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-23 11:12:04 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=315a899b2f9bd8be2f247550a05d807a8c698f07">315a899b2f9bd8be2f247550a05d807a8c698f07</a>
-<blockquote>
-<p>
- ps2write/pdfwrite - Don't arbitrarily change VVECTOR0 flag in type 1 info
-<br>
-
-<br>
- Way back in 2003 code was added 'in lieu of proper CDevProc processing' to
-<br>
- alter the behaviour of pdfwrite. In particular a flag was set which always
-<br>
- causes pdfwrite to handle width chnages.
-<br>
-
-<br>
- However, we do now handle CDevProc correctly, and the arbitrary assignment
-<br>
- of this flag causes serious problems for pdfwrite &amp; ps2write in the
-<br>
- (admittedly rare and unreasonable) case where the FontMatrix of an already
-<br>
- used font is modified.
-<br>
-
-<br>
- Expected Differences:
-<br>
- 14-12.ps
-<br>
- 16-05.ps
-<br>
-
-<br>
- Both now work better with ps2write and pdfwrite, though not 100% correct
-<br>
-
-<br>
-gs/base/gxtype1.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-21 14:07:15 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d0d411c0830b81fa9fb38e3f938ac855fde9a6e3">d0d411c0830b81fa9fb38e3f938ac855fde9a6e3</a>
-<blockquote>
-<p>
- Bug 692798: Ignore the request for undefined color space.
-<br>
-
-<br>
- Ignore the attempt to set an undefined color spece resource,
-<br>
- issue a warning, and continue.
-<br>
-
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-18 12:32:13 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eaaa284dcd5901de156c52c0dc0aff78816e4b81">eaaa284dcd5901de156c52c0dc0aff78816e4b81</a>
-<blockquote>
-<p>
- Fix for bug 692787. Rending Intent aliased with Blending mode in clist
-<br>
-
-<br>
- When I had added the rendering intent into the clist misc parameters I did not
-<br>
- have enough bits to fit everything into a single byte.
-<br>
-
-<br>
-gs/base/gxclpath.c
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-20 15:26:15 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cf6946a1762b975a0450e0d11bdcb13889cdd877">cf6946a1762b975a0450e0d11bdcb13889cdd877</a>
-<blockquote>
-<p>
- Add a note about building on Mac.......
-<br>
-
-<br>
- .....with MacPorts installed.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/doc/Make.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-18 09:31:53 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5e7702813865b8c149f7a8462491d4ca72e70e8e">5e7702813865b8c149f7a8462491d4ca72e70e8e</a>
-<blockquote>
-<p>
- Fix pdfwrite and other vector devices for changing filename and separate pages
-<br>
-
-<br>
- Previously vector devices did not allow changing OutputFile and (most) did not support the %d
-<br>
- OutputFile to generate single page files (pswrite was the exception). The function used by
-<br>
- pswrite was generalized and renamed gx_outputfile_is_separate_pages for general use. If this
-<br>
- returns true vector devices will close and reopen after each page. The PageCount will then be
-<br>
- used in the formation of the filename for the next page.
-<br>
-
-<br>
- Since vector devices open an write the OutputFile when the device is opened the file will be
-<br>
- written even if there is no input, and if a format specifier is used in the OutputFile, then
-<br>
- an extra blank page will be written (maybe this will be fixed later).
-<br>
-
-<br>
- For example, now pdfwrite can be used in server mode by changing the OutputFile device param
-<br>
- which will cause the current collection of pages to be written to the PDF file, and a new
-<br>
- PDF will be started. This is most useful from gsapi calls, but creating two PDF's from one
-<br>
- invocation of gs via the command line would be:
-<br>
- gs -sDEVICE=pdfwrite -o tiger.pdf examples/tiger.eps \
-<br>
- -c &quot;&lt;&lt; /OutputFile (colorcir.pdf) &gt;&gt; setpagedevice&quot; \
-<br>
- -f examples/colorcir.ps
-<br>
-
-<br>
-gs/base/gdevpdf.c
-<br>
-gs/base/gdevps.c
-<br>
-gs/base/gdevpx.c
-<br>
-gs/base/gdevsvg.c
-<br>
-gs/base/gdevvec.c
-<br>
-gs/base/gsdevice.c
-<br>
-gs/base/gxdevice.h
-<br>
-gs/doc/Ps2pdf.htm
-<br>
-gs/doc/Use.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-19 10:37: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=7d0f46b66b275c794dd87525e066e84ccabb4f96">7d0f46b66b275c794dd87525e066e84ccabb4f96</a>
-<blockquote>
-<p>
- Bug 692801: Fix build with shared lcms2 and &quot;so&quot; target
-<br>
-
-<br>
- The targets for the lcms2 integration were mixed up, meaning the shared
-<br>
- lib build had a couple of dependencies on our &quot;local&quot; lcms2 source files.
-<br>
-
-<br>
- The &quot;so&quot; target failed because the compiler for the lcms2 integration
-<br>
- code used the wrong compiler variable (and consequently dropped some
-<br>
- vital flags).
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-19 09:41:53 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a75b5a720684d6e599c28cae9abb9357aa97d7b3">a75b5a720684d6e599c28cae9abb9357aa97d7b3</a>
-<blockquote>
-<p>
- ps2write - alter /NumCopies handling.
-<br>
-
-<br>
- Previously we mimicked /NumCopies and /#copies by using copypage. This is
-<br>
- unreliable because copypage differs on level 3 devices and won't work as
-<br>
- expected. Also it breaks DSC compliance and is probably undesirable with
-<br>
- other PostScript processors such as CUPS.
-<br>
-
-<br>
- This commit alters the behaviour so that we use copypage only if the flag
-<br>
- DoNumCopies is true *and* we ProduceDSC is not true. This changes the
-<br>
- default to match pdfwrite and what I think is most logical while preserving
-<br>
- the ability to use copypage in environments where its use can be supported.
-<br>
-
-<br>
- Expected Differences
-<br>
- Any files using /NumCopies or /#copies will behave differently, producing
-<br>
- fewer (blank!) pages than before. In our test suite I think this only
-<br>
- affects the Quality Logic files. In particular 268-03.ps and 29-07b.ps
-<br>
-
-<br>
-gs/base/gdevpdf.c
-<br>
-gs/doc/Ps2ps2.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-18 12:24:15 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2a7bf50f7cb797b0f3213eb091960700c0ff50e6">2a7bf50f7cb797b0f3213eb091960700c0ff50e6</a>
-<blockquote>
-<p>
- Integrates the new URW WingDing font.
-<br>
-
-<br>
- For reasons unknown URW has named the font NewDingbats. This will
-<br>
- result in many healthy progressions in the regression test suite.
-<br>
-
-<br>
-pl/plftable.c
-<br>
-urwfonts/NewDingbats.ttf
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-18 12:05:36 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=71bb3ba36e2d15ec409185c69716c7cf40b89ea2">71bb3ba36e2d15ec409185c69716c7cf40b89ea2</a>
-<blockquote>
-<p>
- Prevent double file close on font file.
-<br>
-
-<br>
- Introduced with the recent change to close font files at
-<br>
- initialization. If a file in the font directory could not be found in
-<br>
- the font table (was not a known font) the file would be closed twice.
-<br>
-
-<br>
-pl/pllfont.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-18 10:22:47 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=406c8ff0f0414294e52d27d706db51dd11f83725">406c8ff0f0414294e52d27d706db51dd11f83725</a>
-<blockquote>
-<p>
- PJL support for the resolution variable.
-<br>
-
-<br>
- The PJL resolution variable is now properly supported, for example &quot;PJL
-<br>
- SET RESOLUTION = 300&quot; will see the resolution for the next job to 300
-<br>
- but will be overridden if -r is given directly on the command line.
-<br>
- Note the PJL resolution is only one value, there is no way to specify
-<br>
- asymmetric resolution as there is with the -r option.
-<br>
-
-<br>
-pcl/pcjob.c
-<br>
-pcl/pcstate.h
-<br>
-pcl/pctop.c
-<br>
-pl/pjparse.c
-<br>
-pl/plmain.c
-<br>
-pl/plmain.h
-<br>
-pl/pltop.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-17 14:45:50 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b3e60553237af409e4d23d5c8dd39eb136665752">b3e60553237af409e4d23d5c8dd39eb136665752</a>
-<blockquote>
-<p>
- Close PCL font files after initial read.
-<br>
-
-<br>
- Upon startup PCL reads all the font files to gather attribute
-<br>
- information but the files were being left open wasting file handles.
-<br>
- This change closes the files.
-<br>
-
-<br>
-pl/pllfont.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-17 14:42:43 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ad194fca3c799f3928d714567a17c5d8361a424">5ad194fca3c799f3928d714567a17c5d8361a424</a>
-<blockquote>
-<p>
- Reverts 3ab47d0e1e357a16cf5b35747b10b26d99b4d6f0, bad fix.
-<br>
-
-<br>
- Now that we have a larger corpus of hpgl/2-rtl files it is clear this
-<br>
- fix cannot be right, something must have been wrong with the analysis,
-<br>
- unfortunately the, referenced test file from the logs (&quot;sprinkler&quot;)
-<br>
- seems to be gone.
-<br>
-
-<br>
-pcl/pcjob.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-12 15:31:35 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39eb74a7a55793f6acdc473efd014a95a93f7542">39eb74a7a55793f6acdc473efd014a95a93f7542</a>
-<blockquote>
-<p>
- Shell script to convert HPGL/2-RTL to PDF.
-<br>
-
-<br>
- Aside from the obvious purpose of converting hpgl/2 files to pdf, the
-<br>
- script demonstrates how to use the bounding box device to find the
-<br>
- extant of the graphics in the gl/2 file and then use those bounding
-<br>
- box coordinates to defiine a plot size for the file so there is no
-<br>
- white space margin. This is commonly needed as the plot size command
-<br>
- in GL/2 files specifies a plot much larger than needed.
-<br>
-
-<br>
-tools/plot2pdf.sh
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-12 12:07:37 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dbab71fabce6bdeda5f478a077f739457e88f542">dbab71fabce6bdeda5f478a077f739457e88f542</a>
-<blockquote>
-<p>
- Refines '-J' option to process Exit Language properly.
-<br>
-
-<br>
- The previous set up sent a truncated string to the PJL parser so Exit
-<br>
- Language was never returned. Now all the output is sent and the Exit
-<br>
- Language code is required otherwise an error is returned.
-<br>
-
-<br>
-pl/plmain.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-12 09:47:07 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=84cb959e0a2ed1cb0a898b8e2bebf120f55ebc57">84cb959e0a2ed1cb0a898b8e2bebf120f55ebc57</a>
-<blockquote>
-<p>
- Allow multiple PJL commands with the -J option.
-<br>
-
-<br>
- Previously only 1 PJL command could be issued on the command line with
-<br>
- the -J option. Now multiple commands may be issued by separating
-<br>
- commands with a semicolon:
-<br>
-
-<br>
- pcl6 -lRTL -J&quot;@PJL DEFAULT PLOTSIZEOVERRIDE=ON;\
-<br>
- @PJL DEFAULT PLOTSIZE1=10000;@PJL DEFAULT PLOTSIZE2=8000&quot;
-<br>
-
-<br>
- Unfortunately, the odd behavior of HP's PJL parser does not allow
-<br>
- whitespace before &quot;@PJL&quot; which should start a new command each on a
-<br>
- different line, similarly there can be no leading white space at the
-<br>
- beginning or after a semicolon.
-<br>
-
-<br>
-pl/plmain.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-18 10:27: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=0c2d126b790a81d2f9338834429cc46fcc84dab2">0c2d126b790a81d2f9338834429cc46fcc84dab2</a>
-<blockquote>
-<p>
- Bug 692788: Wrong and missing manpage links in unixinst.mak
-<br>
-
-<br>
- Patch from Stefan Bruens ( stefan.bruens@rwth-aachen.de ).
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/unixinst.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-18 08:33:00 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=25198491321b0540910d9aaa6dcc4367f2098dab">25198491321b0540910d9aaa6dcc4367f2098dab</a>
-<blockquote>
-<p>
- Bug 692789: add some buffer limit protection.
-<br>
-
-<br>
- In one place add buffer overrun protection and error out, and in another,
-<br>
- error out if the incoming string is greater than the buffer length (in this
-<br>
- case there would be no buffer overrun, as we only read a buffer full of
-<br>
- data).
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/echogs.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-16 11:23:18 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91f728c058e3ab4705e53916d07597c7a755c730">91f728c058e3ab4705e53916d07597c7a755c730</a>
-<blockquote>
-<p>
- Fix pdfwrite's stringwidth for text rendering mode 3
-<br>
-
-<br>
- pdfwrite provides it's own &quot;low level&quot stringwidth code, which includes code to
-<br>
- convert the resulting coordinates into user space. Unexplicably, this
-<br>
- conversion to user space was *not* applied when text rendering more 3 was in
-<br>
- force.
-<br>
-
-<br>
- This caused a problem for a pending enhancement.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/gdevpdte.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-16 10:19:50 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3efaa3a6fabad09a4442f281fdbccc33f0474ea0">3efaa3a6fabad09a4442f281fdbccc33f0474ea0</a>
-<blockquote>
-<p>
- ps2write - Prevent charpath optimisation to Tr for ps2write
-<br>
-
-<br>
- As a legacy of the old Text rendering mode code there is an optimisation in
-<br>
- pdfwrite which detects sequences such as &quot;true charpath gsave fill grestore
-<br>
- stroke&quot; and converts them to Text rendering mode 2.
-<br>
-
-<br>
- However, ps2write doesn't support text rendering modes, so if the colour changes
-<br>
- then this produces incorrect output.
-<br>
-
-<br>
- Disabling the optimisation when the device is ps2write cures the problem.
-<br>
-
-<br>
- Expected Differences
-<br>
- Progressions in:
-<br>
- Bug687817.ps
-<br>
- Bug690164.ps
-<br>
- Catx6562.pdf
-<br>
-
-<br>
- Small (single pixel) diffferences in a number of files due to the emission
-<br>
- of a path rather than executing charpath.
-<br>
-
-<br>
-gs/base/gdevpdfd.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-13 10:16:03 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=85a94168a4e64199b5a237dbf0d262f5e457440f">85a94168a4e64199b5a237dbf0d262f5e457440f</a>
-<blockquote>
-<p>
- Fix typo in document. 9.05 not 9.5
-<br>
-
-<br>
-gs/doc/GS9_Color_Management.pdf
-<br>
-gs/doc/GS9_Color_Management.tex
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-13 10:40:50 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a9e65e32b4a12c0f5de8ed6a3dcd38b3216f3ae1">a9e65e32b4a12c0f5de8ed6a3dcd38b3216f3ae1</a>
-<blockquote>
-<p>
- Bug 691230, basic jbig2 halftone image support.
-<br>
-
-<br>
- Thanks to George Gottleuber for this work.
-<br>
-
-<br>
-gs/base/jbig2.mak
-<br>
-gs/jbig2dec/jbig2_halftone.c
-<br>
-gs/jbig2dec/jbig2_halftone.h
-<br>
-gs/jbig2dec/jbig2_mmr.c
-<br>
-gs/jbig2dec/jbig2_mmr.h
-<br>
-gs/jbig2dec/jbig2_segment.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-13 14:23:19 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=993377ba237144726cd25e2d8851c70090370dd4">993377ba237144726cd25e2d8851c70090370dd4</a>
-<blockquote>
-<p>
- Optimise TetrahedralInterp16 in lcms2
-<br>
-
-<br>
- Port Michaels optimisations from lcms1, and further tweak
-<br>
- for speed.
-<br>
-
-<br>
-gs/lcms2/src/cmsintrp.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-13 13:45:44 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e03b7f4769120ba60224cc6484b8766b386e054">8e03b7f4769120ba60224cc6484b8766b386e054</a>
-<blockquote>
-<p>
- Better lcms2 support in autoconf build
-<br>
-
-<br>
- Make reverting to lcms a configure option, make lcms2 the default in configure
-<br>
- allow linking of the system lcms2.
-<br>
-
-<br>
- Improve the feedback a little.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-13 01:02: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=4e400364e182ae838a9a844ea40c4cca8d33bc09">4e400364e182ae838a9a844ea40c4cca8d33bc09</a>
-<blockquote>
-<p>
- Silence lcms2 warnings.
-<br>
-
-<br>
- Make a few functions static. Announce some in the headers.
-<br>
-
-<br>
- Fix some #ifdefferey.
-<br>
-
-<br>
-gs/base/gsicc_lcms2.c
-<br>
-gs/lcms2/include/lcms2.h
-<br>
-gs/lcms2/src/cmspack.c
-<br>
-gs/lcms2/src/cmstypes.c
-<br>
-gs/lcms2/src/cmsxform.c
-<br>
-gs/lcms2/src/lcms2_internal.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-12 16:05:09 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cf11f0f7e68ac576138e49ab8d2c05a0121c6997">cf11f0f7e68ac576138e49ab8d2c05a0121c6997</a>
-<blockquote>
-<p>
- Change default cms to be lcms2 (for autogen.sh builds).
-<br>
-
-<br>
- Continuation of commit 319474974fe4ddb99d29e8d3976afcc25f0e54ba.
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-12 11:22:18 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8aa37658b48f4fbda7551598f8de216f2d3dd33d">8aa37658b48f4fbda7551598f8de216f2d3dd33d</a>
-<blockquote>
-<p>
- Update of color documentation
-<br>
-
-<br>
- The new document includes several figures. Rather than clutter the tree with the additional figures that LaTeX uses in creating the pdf, I removed the figures folder. The new LaTeX file uses PDFLaTeX to create the pdf rather than the dvi2ps approach.
-<br>
-
-<br>
-gs/doc/GS9_Color_Management.pdf
-<br>
-gs/doc/GS9_Color_Management.tex
-<br>
-gs/doc/figures/Ghost.eps
-<br>
-gs/doc/figures/Overview.eps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-12 15:23:20 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=afad2d730c8f5f6137791259fab3c45fda0f6862">afad2d730c8f5f6137791259fab3c45fda0f6862</a>
-<blockquote>
-<p>
- ps2write - When converting shaded fills to image+clip, preserve insidenes rule
-<br>
-
-<br>
- ps2write cannot preserve a fill with a Shading pattern, so it converts these
-<br>
- to an image and a clip (the path to fill is converted to a clip path).
-<br>
-
-<br>
- However it did not preserve the 'insideness' winding rule which meant that
-<br>
- both eofill and fill were converted to 'clip' when eofill should be converted
-<br>
- to eoclip.
-<br>
-
-<br>
- Expected Differences
-<br>
- fts_31_3110.pdf
-<br>
- fts_31_3115.pdf
-<br>
- fts_31_3118.pdf
-<br>
- 09-47A.ps
-<br>
- 09-47B.ps
-<br>
- 09-47C.ps
-<br>
- 09-47D.ps
-<br>
- 09-47E.ps
-<br>
- 09-47G.ps
-<br>
- 09-47H.ps
-<br>
- 09-47I.ps
-<br>
- 09-47J.ps
-<br>
- 09-47K.ps
-<br>
- 09-47L.ps
-<br>
- 09-47M.ps
-<br>
- 18-02A.ps
-<br>
- 18-02B.ps
-<br>
- 18-02F.ps
-<br>
- 23-12W.ps
-<br>
-
-<br>
- All show progressions with ps2write
-<br>
-
-<br>
-gs/base/gdevpdfd.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-11 11:25:41 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6b83ef318aaf22b84cdeca55ba40208b9c3caad">f6b83ef318aaf22b84cdeca55ba40208b9c3caad</a>
-<blockquote>
-<p>
- Port color transform speedups from lcms1 to lcms2.
-<br>
-
-<br>
- Use a chameleonic header file to generate optimised transform
-<br>
- functions.
-<br>
-
-<br>
-gs/base/lcms2.mak
-<br>
-gs/lcms2/src/cmspack.c
-<br>
-gs/lcms2/src/cmsxform.c
-<br>
-gs/lcms2/src/cmsxform.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-10 14:41:36 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=defb2b18e49123f4cad571070156a27ece868652">defb2b18e49123f4cad571070156a27ece868652</a>
-<blockquote>
-<p>
- Adds the bbox device.
-<br>
-
-<br>
-main/pcl6_gcc.mak
-<br>
-main/pcl6_msvc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-10 21:16:10 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f50368d684e84fe63579494b3e3efe0e4f39f98c">f50368d684e84fe63579494b3e3efe0e4f39f98c</a>
-<blockquote>
-<p>
- Clean up of the icc color code.
-<br>
-
-<br>
- Remove objects and redundant functions that were introduced over the
-<br>
- past couple years. Found these while writing the documentation.
-<br>
-
-<br>
-gs/base/gdevpdfi.c
-<br>
-gs/base/gdevpsd.c
-<br>
-gs/base/gdevrinkj.c
-<br>
-gs/base/gdevxcf.c
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gscsepr.c
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gsicc_cache.h
-<br>
-gs/base/gsicc_cms.h
-<br>
-gs/base/gsicc_lcms.c
-<br>
-gs/base/gsicc_lcms2.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/base/gsicc_nocm.c
-<br>
-gs/base/gxcmap.c
-<br>
-xps/xpsgradient.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-10 18:27:46 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9e2df6f6194c5091dbfc6bde2218569645f5c89a">9e2df6f6194c5091dbfc6bde2218569645f5c89a</a>
-<blockquote>
-<p>
- Make fuzzy not seg fault when comparing images of different sizes.
-<br>
-
-<br>
- Horrible hack to allow fuzzy to compare two files that have different
-<br>
- dimensions (necessary when compareing outupt from muPDF vs. Ghostscript).
-<br>
-
-<br>
-gs/toolbin/tests/fuzzy.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-10 23:05:58 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=319474974fe4ddb99d29e8d3976afcc25f0e54ba">319474974fe4ddb99d29e8d3976afcc25f0e54ba</a>
-<blockquote>
-<p>
- Change default cms to be lcms2 (for non-windows builds)
-<br>
-
-<br>
- Forgot to change the unix builds. Expect lots of small changes in
-<br>
- the cluster.
-<br>
-
-<br>
-common/ugcc_top.mak
-<br>
-gs/base/macos-mcp.mak
-<br>
-gs/base/macosx.mak
-<br>
-gs/base/openvms.mak
-<br>
-gs/base/unix-gcc.mak
-<br>
-gs/base/unixansi.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-10 22:24:35 +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=c0573245db4f03c6cdca24906d73151a4e9be3c9">c0573245db4f03c6cdca24906d73151a4e9be3c9</a>
-<blockquote>
-<p>
- Bug 691267: Check all realloc error paths.
-<br>
-
-<br>
-gs/base/sjbig2.c
-<br>
-gs/jbig2dec/jbig2.c
-<br>
-gs/jbig2dec/jbig2_huffman.c
-<br>
-gs/jbig2dec/jbig2_page.c
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c
-<br>
-gs/jbig2dec/jbig2_text.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-10 22:09:28 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e1c54b4c4cbc12185e44a758dcfae8f6095fa6c">4e1c54b4c4cbc12185e44a758dcfae8f6095fa6c</a>
-<blockquote>
-<p>
- Add 2 more files missing from solution.
-<br>
-
-<br>
- CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/ghostscript.vcproj
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-10 22:08:28 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9d23e07f6895eb581eaea17bf812be9f89d207b3">9d23e07f6895eb581eaea17bf812be9f89d207b3</a>
-<blockquote>
-<p>
- Change default cms to lcms2.
-<br>
-
-<br>
- Expect lots of small changes.
-<br>
-
-<br>
-gs/base/winlib.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-10 19:47:56 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2468c2bce2ae03750ccab220b16fa6a62b31135f">2468c2bce2ae03750ccab220b16fa6a62b31135f</a>
-<blockquote>
-<p>
- Move icc34.h from lcms directory to gs/base
-<br>
-
-<br>
- It's not supplied as part of the lib, and we need it for lcms,
-<br>
- lcms2, the non-cmm cmm and the creation tools, so having it
-<br>
- somewhere central seems sensible.
-<br>
-
-<br>
-gs/base/icc34.h
-<br>
-gs/base/lcms.mak
-<br>
-gs/base/lcms2.mak
-<br>
-gs/base/lib.mak
-<br>
-gs/lcms/include/icc34.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-10 19:45:25 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1a09075987875224abdaf8d6c62fdf40895ba98">d1a09075987875224abdaf8d6c62fdf40895ba98</a>
-<blockquote>
-<p>
- LCMS2 fix: MSVC version check uses &lt;= rather than &lt;
-<br>
-
-<br>
- Checking for &lt;= 1400 includes VS2005. The intent is to only include
-<br>
- VS2003. Change to &lt; and all is well.
-<br>
-
-<br>
-gs/lcms2/src/lcms2_internal.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-10 19:16:34 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=df2872f8b3cff582871ae15f4c3221bcb6e607fc">df2872f8b3cff582871ae15f4c3221bcb6e607fc</a>
-<blockquote>
-<p>
- Add lcms2 entries to Visual Studio Solution.
-<br>
-
-<br>
- Doesn't make any difference to building - just enables us to search
-<br>
- for code etc more easily.
-<br>
-
-<br>
-gs/ghostscript.vcproj
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-10 10:55:10 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3996236547b4f6b2c4e0d60cd7b4196c33123ac0">3996236547b4f6b2c4e0d60cd7b4196c33123ac0</a>
-<blockquote>
-<p>
- Update of our lcms2 directory to 2.3 release
-<br>
-
-<br>
-gs/lcms2/AUTHORS
-<br>
-gs/lcms2/ChangeLog
-<br>
-gs/lcms2/Projects/BorlandC_5.5/lcms2.rc
-<br>
-gs/lcms2/Projects/VC2008/lcms2.rc
-<br>
-gs/lcms2/Projects/VC2010/lcms2.rc
-<br>
-gs/lcms2/Projects/mac/.DS_Store
-<br>
-gs/lcms2/Projects/mac/LittleCMS/.DS_Store
-<br>
-gs/lcms2/bin/Bin.txt
-<br>
-gs/lcms2/bin/Thumbs.db
-<br>
-gs/lcms2/configure
-<br>
-gs/lcms2/configure.ac
-<br>
-gs/lcms2/doc/LittleCMS2.0 API.pdf
-<br>
-gs/lcms2/doc/LittleCMS2.0 Plugin API.pdf
-<br>
-gs/lcms2/doc/LittleCMS2.0 tutorial.pdf
-<br>
-gs/lcms2/doc/LittleCMS2.1 API.pdf
-<br>
-gs/lcms2/doc/LittleCMS2.1 Plugin API.pdf
-<br>
-gs/lcms2/doc/LittleCMS2.1 tutorial.pdf
-<br>
-gs/lcms2/doc/LittleCMS2.3 API.pdf
-<br>
-gs/lcms2/doc/LittleCMS2.3 Plugin API.pdf
-<br>
-gs/lcms2/doc/LittleCMS2.3 tutorial.pdf
-<br>
-gs/lcms2/doc/src.zip
-<br>
-gs/lcms2/include/icc34.h
-<br>
-gs/lcms2/include/lcms2.h
-<br>
-gs/lcms2/lcms2.pc.in
-<br>
-gs/lcms2/src/cmscgats.c
-<br>
-gs/lcms2/src/cmscnvrt.c
-<br>
-gs/lcms2/src/cmserr.c
-<br>
-gs/lcms2/src/cmsio1.c
-<br>
-gs/lcms2/src/cmslut.c
-<br>
-gs/lcms2/src/cmsnamed.c
-<br>
-gs/lcms2/src/cmsopt.c
-<br>
-gs/lcms2/src/cmspack.c
-<br>
-gs/lcms2/src/cmsplugin.c
-<br>
-gs/lcms2/src/cmssm.c
-<br>
-gs/lcms2/src/cmstypes.c
-<br>
-gs/lcms2/src/cmsvirt.c
-<br>
-gs/lcms2/src/cmswtpnt.c
-<br>
-gs/lcms2/src/cmsxform.c
-<br>
-gs/lcms2/src/lcms2.def
-<br>
-gs/lcms2/src/lcms2_internal.h
-<br>
-gs/lcms2/testbed/USWebCoatedSWOP.icc
-<br>
-gs/lcms2/testbed/UncoatedFOGRA29.icc
-<br>
-gs/lcms2/testbed/sRGBSpac.icm
-<br>
-gs/lcms2/testbed/sRGB_Color_Space_Profile.icm
-<br>
-gs/lcms2/testbed/sRGB_v4_ICC_preference.icc
-<br>
-gs/lcms2/testbed/test1.icc
-<br>
-gs/lcms2/testbed/test2.icc
-<br>
-gs/lcms2/testbed/test3.icc
-<br>
-gs/lcms2/testbed/test4.icc
-<br>
-gs/lcms2/testbed/test5.icc
-<br>
-gs/lcms2/testbed/testcms2.c
-<br>
-gs/lcms2/utils/common/vprf.c
-<br>
-gs/lcms2/utils/delphi/lcms2.dll
-<br>
-gs/lcms2/utils/linkicc/linkicc.c
-<br>
-gs/lcms2/utils/samples/roundtrip.c
-<br>
-gs/lcms2/utils/tificc/tificc.c
-<br>
-gs/lcms2/utils/transicc/transicc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-09 11:06:41 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20a53310422c41df4f48deef3f704b39c291a5f2">20a53310422c41df4f48deef3f704b39c291a5f2</a>
-<blockquote>
-<p>
- PLOTSIZEROTATE is no longer used with the current scheme to initialize
-<br>
- HPGL-2/RTL (see last few commits).
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-pl/pjparse.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-09 10:48:58 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=96726af52822d442cceb1531c1d12bd6141ac322">96726af52822d442cceb1531c1d12bd6141ac322</a>
-<blockquote>
-<p>
- The previous standalone GL/2 mode is incompatible with how the
-<br>
- transformations are set up in PCL. We have found that plots for
-<br>
- standalone mode can be viewed properly in HPGL-2/RTL mode. We think
-<br>
- this is the best alternative for now, if we get into the business of
-<br>
- emulating individual plotters the issue can be revisited.
-<br>
-
-<br>
-pcl/pgdraw.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-08 12:57:46 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e6d68e396ec5842af5b8cb5cb226c9de1f46d31">1e6d68e396ec5842af5b8cb5cb226c9de1f46d31</a>
-<blockquote>
-<p>
- The HPGL-2/RTL work of the last few commits introduce a regression -
-<br>
- disabling bound coordinates in normal PCL mode.
-<br>
-
-<br>
-pcl/pgdraw.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-07 22:09:50 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d18b90db02540b1bf1005537aa38b42ef2486f43">d18b90db02540b1bf1005537aa38b42ef2486f43</a>
-<blockquote>
-<p>
- Implements transformations and clipping needed by HPGL/2-RTL. The
-<br>
- previous setup was only appropriate for HPGL standalone mode and only
-<br>
- appeared to work based on the small number of example files we had at
-<br>
- the time.
-<br>
-
-<br>
-pcl/pcpage.c
-<br>
-pcl/pgconfig.c
-<br>
-pcl/pgdraw.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-07 22:02:59 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9f40ae210f923553413e44135e796fcb981ec34e">9f40ae210f923553413e44135e796fcb981ec34e</a>
-<blockquote>
-<p>
- Presentation mode 3 and clipping when the cap is coincident with the
-<br>
- logical page is not seen in the HPGL-2/RTL examples we have. There
-<br>
- might be something more complicated going on here, it would be
-<br>
- difficult to determine without a device to run experiments.
-<br>
-
-<br>
-pcl/rtgmode.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-07 21:58:50 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3687f6b4cbafd91d5f29c604f86a56a5b118001f">3687f6b4cbafd91d5f29c604f86a56a5b118001f</a>
-<blockquote>
-<p>
- Support the geometry option on the command line, note this really
-<br>
- duplicates the functionality of setting a media size using PJL, but we
-<br>
- implement it anyway because users prefer the familiarity of the
-<br>
- option.
-<br>
-
-<br>
-pcl/pcpage.c
-<br>
-pcl/pcstate.h
-<br>
-pcl/pctop.c
-<br>
-pl/plmain.c
-<br>
-pl/plmain.h
-<br>
-pl/pltop.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-07 21:35:57 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=275066d79d9f01a90f0fd91bc8448c5746cbac2c">275066d79d9f01a90f0fd91bc8448c5746cbac2c</a>
-<blockquote>
-<p>
- The default top and left margin are 0 in HPGL-2/RTL mode, not the standard
-<br>
- PCL values.
-<br>
-
-<br>
-pcl/pcpage.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-07 21:09:37 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5a1eda769a573ef37e2930502c25bfab8d1fb457">5a1eda769a573ef37e2930502c25bfab8d1fb457</a>
-<blockquote>
-<p>
- The transformation setup for HPGL-2 and RTL was really only correct
-<br>
- for standalone mode (GL only). So we have to save the entry operand
-<br>
- to the &quot;Enter HPGL/2 command&quot; in the state so it can be used when the
-<br>
- transformation matrices are recalculated.
-<br>
-
-<br>
-pcl/pcommand.c
-<br>
-pcl/pcstate.h
-<br>
-pcl/pgdraw.c
-<br>
-pcl/rtmisc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-07 20:50:17 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9632b092e1d3ea35c855ae1ccba78fd2e4695d9a">9632b092e1d3ea35c855ae1ccba78fd2e4695d9a</a>
-<blockquote>
-<p>
- Remove unnecessary warning of dubious origin.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-pcl/pcursor.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-20 18:19:40 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9d5c4a0e75e89618e08418ec50809bcbc9886fcf">9d5c4a0e75e89618e08418ec50809bcbc9886fcf</a>
-<blockquote>
-<p>
- Conditionalize a debug message.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-pl/plfont.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-20 11:45:52 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bddfe691c7caae4653cb9ad46645443274fe42a2">bddfe691c7caae4653cb9ad46645443274fe42a2</a>
-<blockquote>
-<p>
- The new ICC flow does not require CRD's and we now do not selectively
-<br>
- choose halftones based on setting from the palette vs. the foreground,
-<br>
- the latter, an implemented but never used feature.
-<br>
-
-<br>
-pcl/pcdraw.c
-<br>
-pcl/pcht.c
-<br>
-pcl/pcht.h
-<br>
-pcl/pcpatrn.c
-<br>
-pcl/pgdraw.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-08 16:32:03 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=acf3f93fa0b9b0b0af938d0517045446e0d94042">acf3f93fa0b9b0b0af938d0517045446e0d94042</a>
-<blockquote>
-<p>
- Add missing '\n' before EOF.
-<br>
-
-<br>
- Add missing '\n' to the last line of gdevp14.c.
-<br>
- This caused compilation errors on MSVC 7.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-06 12: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=de1badc8e7dcf9b2728f46c5a187a2b76a1bf682">de1badc8e7dcf9b2728f46c5a187a2b76a1bf682</a>
-<blockquote>
-<p>
- ps2write - Properly handle masked images with interpolation
-<br>
-
-<br>
- ps2write converts type 3 and 4 (masked) images into an image and clip
-<br>
- combination. The clip is created from the mask, and the image is rendered
-<br>
- to a memory device. Note that the memory device canvas is just large enough to
-<br>
- contain the image.
-<br>
-
-<br>
- The image is drawn as a series of rectangular fills, and our 'local conveter'
-<br>
- device shifts these from the original page location to the correct (relocated to 0,0)
-<br>
- position in the memory device.
-<br>
-
-<br>
- However, if interpolation is true for the image, then we don't get a series
-<br>
- of rectangular fills, we get a 'copy_color' instead which the converter
-<br>
- device didn't handle. Adding a copy_color method which properly translates the
-<br>
- image position solves the problem.
-<br>
-
-<br>
- Expected Differences
-<br>
- Progressions in Bug691210.pdf, 12-07B.ps and 12-07C.ps
-<br>
-
-<br>
-gs/base/gdevpdfd.c
-<br>
-gs/base/gdevpdfx.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-06 11:49:13 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=62633d12eb583116c0a0e1f888c283977cb593b2">62633d12eb583116c0a0e1f888c283977cb593b2</a>
-<blockquote>
-<p>
- Bug 692764: check Freetype is new enough
-<br>
-
-<br>
- We must use Freetype v 2.4.0 at the earliest, so configure will now check that
-<br>
- if being asked to use a shared Freetype lib.
-<br>
-
-<br>
- Add a configure check for Freetype shared lib that doesn't depend on pkg-config.
-<br>
-
-<br>
- Move the warning about falling back to the deprecated AFS code to the end of
-<br>
- the configure output.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-05 22:09:09 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c3bf6f733b8aed99f2a87058b8689c063beae9a0">c3bf6f733b8aed99f2a87058b8689c063beae9a0</a>
-<blockquote>
-<p>
- Fixed missing Rendering Intent Override in gs_lev2.ps
-<br>
-
-<br>
- In creating some examples and writing the documentation I
-<br>
- discovered that this was missing and so none of the
-<br>
- rendering intent settings were working.
-<br>
-
-<br>
-gs/Resource/Init/gs_lev2.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-05 13:41:17 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da508b027e16d926f2e200fd6ff17d58f3392855">da508b027e16d926f2e200fd6ff17d58f3392855</a>
-<blockquote>
-<p>
- Added the ability to clusterpush.pl mupdf.
-<br>
-
-<br>
- This feature is still largely untested and known problems remain,
-<br>
- in particular there is an issue with the wrong information in the
-<br>
- email report for the first mupdf clusterpush following a ghostscript
-<br>
- clusterpush.
-<br>
-
-<br>
-gs/toolbin/localcluster/clusterpush.pl
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-05 10:05:51 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f45061bbea6a75abe17187fd06b67ad36fc7e779">f45061bbea6a75abe17187fd06b67ad36fc7e779</a>
-<blockquote>
-<p>
- Fix memory issue when creating source color structure
-<br>
-
-<br>
- One of the objects in the source color structure was getting allocated in
-<br>
- GC memory where it should have been in non-GC memory.
-<br>
-
-<br>
-gs/base/gsicc_manage.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-05 16:13:07 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d3bd93d8da482714c30e58731829cac4f9e3510e">d3bd93d8da482714c30e58731829cac4f9e3510e</a>
-<blockquote>
-<p>
- Add RAW_DUMP_AS_PAM option.
-<br>
-
-<br>
- If RAW_DUMP_AS_PAM is enabled, then (where possible) we RAW_DUMP
-<br>
- blends as pam rather than raw files. Easier for people without
-<br>
- full photoshop to handle.
-<br>
-
-<br>
-gs/base/gxblend.c
-<br>
-gs/base/gxblend.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-03 17:50:07 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e503591e1cc9d6f6c4c91fd5e0500df0cb6df21b">e503591e1cc9d6f6c4c91fd5e0500df0cb6df21b</a>
-<blockquote>
-<p>
- Revise example in comments.
-<br>
-
-<br>
- Revise the example using &quot;getenv&quot; to correcly account for the return values of getenv.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/Resource/Init/cidfmap
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-03 16:10: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=c974aa83b814e9bf9c3e1b29493edb8cd5ed8091">c974aa83b814e9bf9c3e1b29493edb8cd5ed8091</a>
-<blockquote>
-<p>
- Bug 692641 (again): prevent symbol name clash
-<br>
-
-<br>
- Another case where our &quot;internal&quot; SHA symbols could clash with the &quot;real&quot;
-<br>
- OpenSSL ones if libgs is being statically linked. As before, trivial rename
-<br>
- to avoid this (courtesy of Alan Hourihane - alanh@fairlite.co.uk).
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/sha2.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-03 13:08:07 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d48a3d162fd38aaa2582e32565c07df41e7c02cb">d48a3d162fd38aaa2582e32565c07df41e7c02cb</a>
-<blockquote>
-<p>
- pdfwrite/ps2write - Properly validate BitsPerComponent for images
-<br>
-
-<br>
- Suprisingly (to me) the BitsPerComponent value for images is not validated
-<br>
- at the interpreter (language) level, but is handled in the graphics library.
-<br>
-
-<br>
- pdfwrite and ps2write were not validating the BitsPerComponent, other than
-<br>
- to check it was 8 or less, and so could create invalid images in the PDF or
-<br>
- PostScritp output.
-<br>
-
-<br>
- This commit adds the missing checks.
-<br>
-
-<br>
- Expected Differences
-<br>
- 12-07a.ps - ps2write no longer produces an invalid PostScript file
-<br>
- 12-07a.ps - pdfwrite no longer produces an invalid PDF file
-<br>
- 12-02.ps - ps2write no longer produces an invalid PostScript file
-<br>
- 12-02.ps - pdfwrite no longer produces an invalid PDF file
-<br>
-
-<br>
-gs/base/gdevpdfi.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2012-01-03 09:20:05 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8cfb57fdd350cbda7578226b150ed0014d5949c9">8cfb57fdd350cbda7578226b150ed0014d5949c9</a>
-<blockquote>
-<p>
- ps2write - fix uncoloured Pattern spaces with a complex colour space
-<br>
-
-<br>
- Certain kinds of colour space, eg /Separation, can have a function which
-<br>
- converts to the alternate space. If one of these was used as the colour
-<br>
- space for an uncoloured pattern then the function was not properly loaded
-<br>
- from the object defuinition, leading to an invalid colour space declaration.
-<br>
-
-<br>
- This tests the initial space to see if it is /Pattern and if it is, checks
-<br>
- to see if the pattern is uncoloured (the array contains more than /Pattern).
-<br>
- If so we test the colour space and, if it is an array, process the array as
-<br>
- a colour space, which properly dereferences all the elements.
-<br>
-
-<br>
-
-<br>
- Expected Differences:
-<br>
- 09-47a.ps, 09-47b.ps and 18-02b.ps should now work correctly.
-<br>
-
-<br>
-gs/base/opdfread.h
-<br>
-gs/lib/opdfread.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-28 14:37:49 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e681a04de79896406946d5487efe0a37eb6d2b2">4e681a04de79896406946d5487efe0a37eb6d2b2</a>
-<blockquote>
-<p>
- Proof and DeviceLink ICC profile support
-<br>
-
-<br>
- This enables the use of the device link and/or a proofing profile. When
-<br>
- present, the transformations are as follows
-<br>
- src profile -&gt; PCS -&gt; proof -&gt; PCS -&gt; proof -&gt; PCS -&gt; device profile -&gt; device link
-<br>
- where PCS is the profile connection space. The CMM obviously would
-<br>
- normally mash these together in a single transform. This is what
-<br>
- occurs in lcms.
-<br>
-
-<br>
- This implies that the output color space for the device link
-<br>
- profile must match the color model for the real target device and
-<br>
- that the input color space for the device link profile must match
-<br>
- the color space specified for the device profile.
-<br>
- Still need to do some additional testing and update documentation.
-<br>
-
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gsicc_cache.h
-<br>
-gs/base/gsicc_cms.h
-<br>
-gs/base/gsicc_lcms.c
-<br>
-gs/base/gsicc_lcms2.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gxi12bit.c
-<br>
-gs/base/gxicolor.c
-<br>
-gs/base/gximono.c
-<br>
-gs/base/gxiscale.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-22 09:55:25 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d4625c5b5a262501fefabe68f2bbea000dcecb52">d4625c5b5a262501fefabe68f2bbea000dcecb52</a>
-<blockquote>
-<p>
- Movement of proof profile an device link profile to device.
-<br>
-
-<br>
- The proofing profile and the device link profile are now in the device's
-<br>
- profile structure. This makes it much easier to include in the proofing
-<br>
- profile and/or the device link profile during the link transformation
-<br>
- creation. This commit includes all the changes except for the actual
-<br>
- creation of the link with the proof. That will come in a separate commit
-<br>
- since there are a lot of changes in this commit and I want to spend
-<br>
- a little more time on that to make it clean and
-<br>
- dependent upon the capabilities of the CMM. The reason is that there are
-<br>
- some CMMs that support the chaining together of multiple transformations and
-<br>
- some that do not. Those that do not may not be able to handle both a
-<br>
- proofing profile AND a device link profile. We want to handle that case
-<br>
- gracefully.
-<br>
-
-<br>
-gs/Resource/Init/gs_lev2.ps
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gdevpdfk.c
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gsdparam.c
-<br>
-gs/base/gsequivc.c
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gsicc_cache.h
-<br>
-gs/base/gsicc_lcms.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_nocm.c
-<br>
-gs/base/gxcmap.c
-<br>
-gs/base/gxi12bit.c
-<br>
-gs/base/gxicolor.c
-<br>
-gs/base/gximono.c
-<br>
-gs/base/gxiscale.c
-<br>
-gs/base/gxshade.c
-<br>
-gs/psi/zusparam.c
-<br>
-xps/xpsgradient.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-23 11:50:08 -0800
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=63571a25cbd787573f0c4918abe7c783f5e5209c">63571a25cbd787573f0c4918abe7c783f5e5209c</a>
-<blockquote>
-<p>
- Memento/Valgrind integration tweak.
-<br>
-
-<br>
- Ensure block header is set to be readable when reading blk-&gt;tail
-<br>
- to avoid spurious read errors.
-<br>
-
-<br>
-gs/base/memento.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-23 15:56:43 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1430adef1955c8c85001b2fbcd371bfccfead179">1430adef1955c8c85001b2fbcd371bfccfead179</a>
-<blockquote>
-<p>
- ps2write - Correct the DecodeLMN matrix creation for a CalGray -&gt; CIEBasedA
-<br>
-
-<br>
- When converting a CalGray to a CIEBasedA dpace, the Gamma from the CalGray is
-<br>
- used to create a DecodeLMN array. However the code only created a single
-<br>
- executable array, when it is required to be an array of 3 procedures.
-<br>
-
-<br>
- Expected Diffrences
-<br>
- 09-34.ps no longer fails when converted via ps2write
-<br>
-
-<br>
-gs/base/opdfread.h
-<br>
-gs/lib/opdfread.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-23 08:06:18 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1ca1565f903490bd71dcc8182e69d4ab5eb6c3a">b1ca1565f903490bd71dcc8182e69d4ab5eb6c3a</a>
-<blockquote>
-<p>
- Initialise a pointer to silence a compiler warning
-<br>
-
-<br>
- In fact this is benign, the code can't get here without previously allocating
-<br>
- and initialising the pointer, but that takes place in another branch and
-<br>
- static analysis can't reveal that.
-<br>
-
-<br>
-gs/base/gdevtxtw.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-22 16:21:10 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e758e15df0497f85c6843b57e65a6d7f072cf815">e758e15df0497f85c6843b57e65a6d7f072cf815</a>
-<blockquote>
-<p>
- Prevent a crash trying to get MissingWidth from sa non-CID font in txtwrite
-<br>
-
-<br>
-gs/base/gdevtxtw.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-22 15:29:26 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2eb7ab1f1e57d118259ae7bf2fce9c2872152478">2eb7ab1f1e57d118259ae7bf2fce9c2872152478</a>
-<blockquote>
-<p>
- Txtwrite - initialise members of an array, silences compiler warning.
-<br>
-
-<br>
-gs/base/gdevtxtw.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-22 14:45:17 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b90f64665896669124bb6f219a77a556371c67c8">b90f64665896669124bb6f219a77a556371c67c8</a>
-<blockquote>
-<p>
- Revise DisplayHandle documentation in API.htm
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/doc/API.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-22 14:47:24 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e391e19723bad3de19beb2fa584f0d9c8b62cac9">e391e19723bad3de19beb2fa584f0d9c8b62cac9</a>
-<blockquote>
-<p>
- Correctly read all parameters in put_params as well as get_params
-<br>
-
-<br>
- Fixes the txtwrite device with the language switch build
-<br>
-
-<br>
-gs/base/gdevtxtw.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-22 12:42:53 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1eb9f0069dce7d626118333fd51477d734daa88e">1eb9f0069dce7d626118333fd51477d734daa88e</a>
-<blockquote>
-<p>
- Add the txtwrite device to PCL and language switch and supply a method
-<br>
- for get_page_device in txtwrite (prevents SEGV)
-<br>
-
-<br>
-gs/base/gdevtxtw.c
-<br>
-main/pcl6_gcc.mak
-<br>
-main/pcl6_msvc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-21 12:25:57 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=157a91639635abad452872cf521f743bbadb0c68">157a91639635abad452872cf521f743bbadb0c68</a>
-<blockquote>
-<p>
- Addition of debug output for icc color conversions
-<br>
-
-<br>
- To get detailed information about ICC profile allocations,
-<br>
- mappings, profile creations from PS color objects and
-<br>
- link creations use the command line option --debug=icc
-<br>
-
-<br>
-gs/base/gdbflags.h
-<br>
-gs/base/gsciemap.c
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gxclthrd.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-21 17:51:31 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e99a07ab13789ae7d561390bf0f07721fbf4917">4e99a07ab13789ae7d561390bf0f07721fbf4917</a>
-<blockquote>
-<p>
- Clean up some target mess left over from earlier commit.
-<br>
-
-<br>
- I missed some changes from the removal of the old installer, some
-<br>
- targets were still there which relied on the removed files.
-<br>
-
-<br>
- Also, a name didn't make any sense.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/psi/msvc.mak
-<br>
-gs/psi/winint.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-21 17:07: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=2cba2590e1a8edfef6f0b13f8d392a756f889690">2cba2590e1a8edfef6f0b13f8d392a756f889690</a>
-<blockquote>
-<p>
- Bug 692089 (prt 2): Update Install.htm with 64 bit versions of Windows binaries
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/doc/Install.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-21 17:00: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=37053da2b828df8101be25eed9bfadf3c13dbd7b">37053da2b828df8101be25eed9bfadf3c13dbd7b</a>
-<blockquote>
-<p>
- Bug 692089 (prt 1): install gssetgs.bat suitable for current installer.
-<br>
-
-<br>
- As the istaller knows whether it is installer the 32 bit or 64 bit version
-<br>
- of Ghostscript, the installer now chooses between two gssetgs.bat versions
-<br>
- so that the other batch files find the appropriate GS exe.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/lib/gssetgs32.bat
-<br>
-gs/lib/gssetgs64.bat
-<br>
-gs/psi/msvc.mak
-<br>
-gs/psi/nsisinst.nsi
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-21 16:56:47 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a11f84267931e805148ed63025002851d3f3d2eb">a11f84267931e805148ed63025002851d3f3d2eb</a>
-<blockquote>
-<p>
- Remove source files for the old Ghostscript installer.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/psi/dwinst.cpp
-<br>
-gs/psi/dwinst.h
-<br>
-gs/psi/dwsetup.cpp
-<br>
-gs/psi/dwsetup.h
-<br>
-gs/psi/dwsetup.rc
-<br>
-gs/psi/dwuninst.cpp
-<br>
-gs/psi/dwuninst.h
-<br>
-gs/psi/dwuninst.rc
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-21 15:20: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=83b1e0429c3ab74da7dd1c9b78401671bac4d6f6">83b1e0429c3ab74da7dd1c9b78401671bac4d6f6</a>
-<blockquote>
-<p>
- Make OpenJPEG the default for JPXDecode.
-<br>
-
-<br>
- This introduces differences for all the cluster tests with JPX encoded image
-<br>
- data in them.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-21 13:23:57 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4bcc37370e97105ae3d4aff085b15541a7cd6a51">4bcc37370e97105ae3d4aff085b15541a7cd6a51</a>
-<blockquote>
-<p>
- Bug 692754: have configure setup endian setting for lcms
-<br>
-
-<br>
- The lcms header files have some educated guesses for the current platform
-<br>
- big/little endianness, but they are not comprehensive (for example, PA-RISC
-<br>
- HP UX defeats it).
-<br>
-
-<br>
- So, add a test to our configure scripts, and pass the setting as required as a
-<br>
- compiler option for lcms. NOTE: I added an explicit test for endianness because
-<br>
- the autoconf built-in test has problems in recent releases.
-<br>
-
-<br>
- Also, noticed in passing: revise the other explicit compile/link tests to use
-<br>
- the AC_LANG_PROGRAM() macro - currently not doing so produces a warning, but
-<br>
- the implication is future versions will throw an error.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-config.mak.in
-<br>
-configure.ac
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/configure.ac
-<br>
-gs/base/lcms.mak
-<br>
-gs/base/lcms2.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-21 09:16:50 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=39182690d9d7242d7a8e6e2f5fe9aff52d0ee3ab">39182690d9d7242d7a8e6e2f5fe9aff52d0ee3ab</a>
-<blockquote>
-<p>
- ps2write - Use Font level Resources for type 3 font CharProcs
-<br>
-
-<br>
- Part of Bug #691928, file tpc2.ps. It is possible (in PDF) for a font to have
-<br>
- Resources separately from teh page stream. This is properly catered for in
-<br>
- PDF interpreters.
-<br>
-
-<br>
- However, ps2write's prolog only allowed resources defined at the page level
-<br>
- when executing CharProc procedures from a type 3 font (because we are in the
-<br>
- page stream at the time, not the font object).
-<br>
-
-<br>
- If the type 3 font executes findfont, and the font is not defined at the page
-<br>
- level (often the case for the Quark q font and other substitutes) then the
-<br>
- font cannot be found. Due to a quirk of the way fonts are defined, the *first*
-<br>
- page to use the type 3 font always includes definitions for any fonts used by
-<br>
- the type 3 font, so this problem only exhibits on mutiple page documents.
-<br>
-
-<br>
- This was tricky to fix, we cannot simply replace the Resources in the current
-<br>
- Context, as we need to return to the pre-existing Context after running the
-<br>
- CharProc. Additionally, type 3 fonts can execute other type 3 fonts which may
-<br>
- themselves call other fonts. It was neccesary to implement a stack of saved
-<br>
- resources in order to deal with this situation.
-<br>
-
-<br>
- Expected Differences
-<br>
- tpc2.ps should now work properly with ps2write
-<br>
-
-<br>
-gs/base/opdfread.h
-<br>
-gs/lib/opdfread.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-20 11:42:18 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa34b3ab12b15f5e1ace688f00c28a75667afdb4">fa34b3ab12b15f5e1ace688f00c28a75667afdb4</a>
-<blockquote>
-<p>
- Fix for bug 691998 avoid the creation of the CRD cache.
-<br>
-
-<br>
- Since we are using ICC profiles to define the output color to not create the
-<br>
- cache for the CRD.
-<br>
-
-<br>
-gs/psi/zcrd.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-19 17:54: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=c85b3957cb896af69d8b7f630a56635cc0eb7a8c">c85b3957cb896af69d8b7f630a56635cc0eb7a8c</a>
-<blockquote>
-<p>
- Revise the SSE2 tests to work with Sun cc compiler
-<br>
-
-<br>
- The Sun/Oracle C compiler doesn't throw an error when compiling SSE2 code
-<br>
- without the requisite SSE2 command line option, and building non-
-<br>
- optimized.
-<br>
-
-<br>
- This commit applies a more stringent test, and ensures we use the optimized
-<br>
- build option when we do the test build/link.
-<br>
-
-<br>
- Also, adds some use feedback for the SSE2, byteswap intrinsic and byteswap
-<br>
- header tests.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-configure.ac
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-19 15:33: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=6a4ff3a5c387f8958016b3678d919373c57ec5bd">6a4ff3a5c387f8958016b3678d919373c57ec5bd</a>
-<blockquote>
-<p>
- CIDFont substitution tweak for *Light,Bold fonts
-<br>
-
-<br>
- When we have to substitute for a &quot;Light&quot; style CIDFont which has been made
-<br>
- bold, don't apply artificial emboldening unless the substitute font is
-<br>
- also a &quot;Light&quot;.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/Resource/Init/pdf_font.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-19 08:00:17 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=269ddabfb17657114b8e09b0c2fb2ee8440d92df">269ddabfb17657114b8e09b0c2fb2ee8440d92df</a>
-<blockquote>
-<p>
- Check a return code, silences a compiler warning and is more robust
-<br>
-
-<br>
-gs/base/gxfcopy.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-17 14:08:37 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=464ef7f26f33b3f8a5d4c8732674e75a6aff39dc">464ef7f26f33b3f8a5d4c8732674e75a6aff39dc</a>
-<blockquote>
-<p>
- Bug 692747: Trap errors in operator sh and continue.
-<br>
-
-<br>
- Execute .shfill operator in a stopped contect, trap errors,
-<br>
- issue a warning, and continue.
-<br>
-
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-15 13:54:15 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea9a951756d495c6b8e427cbcea80fb94f9ccaa5">ea9a951756d495c6b8e427cbcea80fb94f9ccaa5</a>
-<blockquote>
-<p>
- Bug 687297: Revert to the URW fonts
-<br>
-
-<br>
- Revert to using the &quot;pristine&quot; URW fonts.
-<br>
-
-<br>
- Cluster differences: every job which uses one of the base 35 fonts.
-<br>
-
-<br>
-gs/Resource/Font/CenturySchL-Bold
-<br>
-gs/Resource/Font/CenturySchL-BoldItal
-<br>
-gs/Resource/Font/CenturySchL-Ital
-<br>
-gs/Resource/Font/CenturySchL-Roma
-<br>
-gs/Resource/Font/Dingbats
-<br>
-gs/Resource/Font/NimbusMonL-Bold
-<br>
-gs/Resource/Font/NimbusMonL-BoldObli
-<br>
-gs/Resource/Font/NimbusMonL-Regu
-<br>
-gs/Resource/Font/NimbusMonL-ReguObli
-<br>
-gs/Resource/Font/NimbusRomNo9L-Medi
-<br>
-gs/Resource/Font/NimbusRomNo9L-MediItal
-<br>
-gs/Resource/Font/NimbusRomNo9L-Regu
-<br>
-gs/Resource/Font/NimbusRomNo9L-ReguItal
-<br>
-gs/Resource/Font/NimbusSanL-Bold
-<br>
-gs/Resource/Font/NimbusSanL-BoldCond
-<br>
-gs/Resource/Font/NimbusSanL-BoldCondItal
-<br>
-gs/Resource/Font/NimbusSanL-BoldItal
-<br>
-gs/Resource/Font/NimbusSanL-Regu
-<br>
-gs/Resource/Font/NimbusSanL-ReguCond
-<br>
-gs/Resource/Font/NimbusSanL-ReguCondItal
-<br>
-gs/Resource/Font/NimbusSanL-ReguItal
-<br>
-gs/Resource/Font/StandardSymL
-<br>
-gs/Resource/Font/URWBookmanL-DemiBold
-<br>
-gs/Resource/Font/URWBookmanL-DemiBoldItal
-<br>
-gs/Resource/Font/URWBookmanL-Ligh
-<br>
-gs/Resource/Font/URWBookmanL-LighItal
-<br>
-gs/Resource/Font/URWChanceryL-MediItal
-<br>
-gs/Resource/Font/URWGothicL-Book
-<br>
-gs/Resource/Font/URWGothicL-BookObli
-<br>
-gs/Resource/Font/URWGothicL-Demi
-<br>
-gs/Resource/Font/URWGothicL-DemiObli
-<br>
-gs/Resource/Font/URWPalladioL-Bold
-<br>
-gs/Resource/Font/URWPalladioL-BoldItal
-<br>
-gs/Resource/Font/URWPalladioL-Ital
-<br>
-gs/Resource/Font/URWPalladioL-Roma
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-14 16:23:24 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3875e5a471e3f9b9b4a2f5ea03e37b59fcd8913c">3875e5a471e3f9b9b4a2f5ea03e37b59fcd8913c</a>
-<blockquote>
-<p>
- Bug 690779 (pt2): revisions to CIDFont substition.
-<br>
-
-<br>
- The original code (commit 18a51701) didn't work well with pdfwrite, so this
-<br>
- revision handles substition by modifying the CIDFont resource .map dictionary.
-<br>
- This means that the &quot;fake&quot; CIDFont is created with the requested parameters
-<br>
- from the start.
-<br>
-
-<br>
- Also, add command line paramters and environment variables to control the
-<br>
- path to and file name of the subsitute TTF.
-<br>
-
-<br>
- Differences in Bug692320.pdf.
-<br>
-
-<br>
- No other cluster differences.
-<br>
-
-<br>
-gs/Resource/Init/gs_cidfm.ps
-<br>
-gs/Resource/Init/pdf_font.ps
-<br>
-gs/doc/Use.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-14 09:10: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=ce35f1657aac012a492f05f61b56a605243fe83e">ce35f1657aac012a492f05f61b56a605243fe83e</a>
-<blockquote>
-<p>
- Re-enable CDevProc for substituted CIDFonts.
-<br>
-
-<br>
- Previously, CDevProc execution was disabled for CIDFonts which had been
-<br>
- substituted by a TTF (through cidfmap, for example) because the index that
-<br>
- gets passed to zchar_set_cache() is the TTF GID, not the CID, and the
-<br>
- CDevProc requires the CID.
-<br>
-
-<br>
- We can, however, retrieve the CID from the text enumerator, and pass that to
-<br>
- the CDevProc, which is what this commit implements.
-<br>
-
-<br>
- Cluster differences in Bug692320.pdf because we now reposition glyphs with the
-<br>
- CDevProc where we previously were not.
-<br>
-
-<br>
- No other differences.
-<br>
-
-<br>
-gs/psi/zcharout.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-13 12:47:57 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=863d3d5383aaf59a04715115f72651cbbb3d8435">863d3d5383aaf59a04715115f72651cbbb3d8435</a>
-<blockquote>
-<p>
- Fix for bug 688387; Type 3 image range checking is too restrictive.
-<br>
-
-<br>
- Modified version of patch from Olavi Sakari.
-<br>
-
-<br>
- For explicit masking, regenerate the mask matrix from the image
-<br>
- matrix, with scaling changes to allow for different widths/heights.
-<br>
-
-<br>
- Cluster testing shows differences in:
-<br>
- tests_private/comparefiles/468-01.ps (We now match acrobat)
-<br>
- tests_private/comparefiles/Bug690237.pdf (rounding diffs, fine)
-<br>
- tests_private/ps/ps3cet/12-07C.PS (content now appears)
-<br>
-
-<br>
-gs/base/gximage3.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-13 11:19:08 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=93bdb2010c0c1ce074c3cd4bddc6a77f6808d920">93bdb2010c0c1ce074c3cd4bddc6a77f6808d920</a>
-<blockquote>
-<p>
- Common subexpression elimination - no expected changes.
-<br>
-
-<br>
-pcl/pcindxed.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-12 21:58:38 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e04069bf8549eba33e7ba71398769609b72d2026">e04069bf8549eba33e7ba71398769609b72d2026</a>
-<blockquote>
-<p>
- Reorganize the initialization of the pen width and residual palette
-<br>
- color entries. In particular, the pen width initialization was
-<br>
- incorrect, applying default pen widths to pens that shouldn't be
-<br>
- reset. This changes result in progressions for the following files:
-<br>
-
-<br>
- tests_private/pcl/pcl5ccet/31-09.BIN
-<br>
- tests_private/pcl/pcl5ccet/34-03.BIN
-<br>
- tests_private/xl/pcl6cet3.0/C705.bin
-<br>
-
-<br>
-pcl/pcindxed.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-12 09:58:43 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=abf148da6950f4f39d57603fb316584ea0975fa7">abf148da6950f4f39d57603fb316584ea0975fa7</a>
-<blockquote>
-<p>
- Addresses 692051, the palette string's allocated size always
-<br>
- matches the number of entries in the palette times 3 (bytes).
-<br>
-
-<br>
-pcl/pcindxed.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-12 09:57:30 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0880ae03de6174fc13c3016a1c0f49c850047df7">0880ae03de6174fc13c3016a1c0f49c850047df7</a>
-<blockquote>
-<p>
- Make fuction static.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-pcl/pcpalet.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-12 09:54:30 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a074d9ebc08bda2680133ae3fc09fd9ff55637be">a074d9ebc08bda2680133ae3fc09fd9ff55637be</a>
-<blockquote>
-<p>
- Fix long standing problem where too many palette entries were
-<br>
- initialized. This was not an issue with a fixed static palette but
-<br>
- with the new dynamic palettes forthcoming this would cause writing
-<br>
- past the end of the palette data string.
-<br>
-
-<br>
-pcl/pcindxed.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-09 09:37:26 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dea0afb058b76ea57832f6e48a0bfc080898e9cb">dea0afb058b76ea57832f6e48a0bfc080898e9cb</a>
-<blockquote>
-<p>
- Back out valgrind workarounds to resize and initialize indexed color
-<br>
- spaces. A more complete solution is forthcoming.
-<br>
-
-<br>
-pcl/pcindxed.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-08 23:18:54 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aacecd032249027269e896ebc0abada3a8e82945">aacecd032249027269e896ebc0abada3a8e82945</a>
-<blockquote>
-<p>
- Extra debugging support for PCL color spaces.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-pcl/pccid.c
-<br>
-pcl/pccid.h
-<br>
-pcl/pccsbase.c
-<br>
-pcl/pcindxed.c
-<br>
-pcl/pcpatrn.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-13 15:21:42 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5f5921ad464e39676328705c874485e66a6d6469">5f5921ad464e39676328705c874485e66a6d6469</a>
-<blockquote>
-<p>
- Fix crash when using a TrueType substitute for a missing CIDFont with pdfwrite
-<br>
-
-<br>
- The changes to better handle PCL fonts accidentally left out an important
-<br>
- test which could lead to a seg fault if a PDF file was processed which
-<br>
- contained a reference to a non-embedded CIDFont, and we had defined a
-<br>
- TrueType substitute to use instead.
-<br>
-
-<br>
- This restores the old behaviour of exiting with an error.
-<br>
-
-<br>
- Bug692320 should no longer seg fault with cluster testing.
-<br>
-
-<br>
-gs/base/gdevpdtt.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-13 11:46:53 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=18a5170163b690647f70d58e4c9d75873cd1324b">18a5170163b690647f70d58e4c9d75873cd1324b</a>
-<blockquote>
-<p>
- Bug 690779: Provide fallback for missing CIDFonts in PDF
-<br>
-
-<br>
- Rather than throw an error when a PDF references a CIDFont that is not
-<br>
- available, we'll now fall back to using DroidSansFallback.ttf, by default.
-<br>
-
-<br>
- This gives a reasonable analogue of other PDF consumers' behavior.
-<br>
-
-<br>
- Results in extensive differences in Bug692320.pdf because we now complete
-<br>
- content streams, and image the text they contain, rather than skipping
-<br>
- them. NOTE: this does not make the output from Bug692320.pdf &quot;correct&quot;, but
-<br>
- arguably makes it &quot;less wrong&quot;.
-<br>
-
-<br>
- Other than that, no differences.
-<br>
-
-<br>
-gs/DroidSansFallback.NOTICE
-<br>
-gs/Resource/CIDFSubst/DroidSansFallback.ttf
-<br>
-gs/Resource/CIDFont/ArtifexBullet
-<br>
-gs/Resource/Init/gs_ciddc.ps
-<br>
-gs/Resource/Init/gs_cidfm.ps
-<br>
-gs/Resource/Init/gs_init.ps
-<br>
-gs/Resource/Init/gs_ttf.ps
-<br>
-gs/Resource/Init/pdf_font.ps
-<br>
-gs/Resource/Init/xlatmap
-<br>
-gs/doc/Use.htm
-<br>
-gs/psi/psromfs.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-12 15:38:32 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=405d67e60c1b943f4faeed728bace0f2103a7ec8">405d67e60c1b943f4faeed728bace0f2103a7ec8</a>
-<blockquote>
-<p>
- Bug 692736: fix logic contolling FAPI's bitmap production.
-<br>
-
-<br>
- Non-marking operations (such as stringwidth) sometimes require FAPI to produce
-<br>
- a bitmap. We were taking the &quot;slegdehammer&quot; approach of always producing a
-<br>
- bitmap, and throwing it away when not required.
-<br>
-
-<br>
- This commit fixes the decision on whether we should produce a bitmap.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/psi/fapi_ft.c
-<br>
-gs/psi/zfapi.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-12 14:29: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=77f2e7c475bdf79e478d59c878d6ae30c53c5a17">77f2e7c475bdf79e478d59c878d6ae30c53c5a17</a>
-<blockquote>
-<p>
- Add missing dependencies for gdevicov.c.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-10 16:41:06 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=70b1623bf91ea2a75da69f40caefb7efa56f49d9">70b1623bf91ea2a75da69f40caefb7efa56f49d9</a>
-<blockquote>
-<p>
- Add ink coverage device: inkconv. Resolves Bug 692665.
-<br>
-
-<br>
- Add the inkcov device, written by sebastian.kapfer@physik.uni-erlangen.de.
-<br>
- This dummy device produce output listing the percentage of pixels
-<br>
- containing c, m, y, and k ink.
-<br>
-
-<br>
- No cluster differences expected since this device isn't tested by the
-<br>
- cluster.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-gs/base/gdevicov.c
-<br>
-gs/base/lib.mak
-<br>
-gs/base/macos-mcp.mak
-<br>
-gs/base/macosx.mak
-<br>
-gs/base/openvms.mak
-<br>
-gs/base/unix-gcc.mak
-<br>
-gs/base/unixansi.mak
-<br>
-gs/ghostscript.vcproj
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-09 10:01:57 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a2555a91fbc2fa73a6e2f8f4035b58b4ff5ae57">9a2555a91fbc2fa73a6e2f8f4035b58b4ff5ae57</a>
-<blockquote>
-<p>
- Bug 692686: use same scan conversion settings for &quot;clip&quot; as for &quot;fill&quot;
-<br>
-
-<br>
- The PDF job in question renders most of its text as simple text render mode 0,
-<br>
- but about three glyphs are done using tr mode 7, and showing an image through
-<br>
- the resulting clip.
-<br>
-
-<br>
- The problem is that when we image a glyph, we use fill_adjust 0 (rather than the
-<br>
- default of ~0.3), otherwise glyphs are overly bold. When using one of the clip
-<br>
- text modes in PDF, however, we still used the default fill_adjust, which
-<br>
- resulted in an overly &quot;bold&quot; clip path.
-<br>
-
-<br>
- This causes a number of cluster differences: several are progressions, the
-<br>
- others are pixel differences - mostly cases where resolution and/or zoom level
-<br>
- affect whether we precisely match Acrobat.
-<br>
-
-<br>
-gs/Resource/Init/pdf_ops.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-09 10:07: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=5359a2d0bf10568102f85d797a91c0595518ae23">5359a2d0bf10568102f85d797a91c0595518ae23</a>
-<blockquote>
-<p>
- Do not use hexadecimal names for type42 Charstrings and Encoding
-<br>
-
-<br>
- Bug #692711 - When creating CharStrings and Encoding for an embedded
-<br>
- TrueType font, to create a type 42 font, we need to supply numeric names
-<br>
- according to the spec. We were doing this using hex values which has the
-<br>
- unfortunate effect of creating 5 of the names as /A to /F.
-<br>
-
-<br>
- These are not numeric! In fact they duplicate 5 of the Ghostscript
-<br>
- standard names. While this is not actually a problem when rendering, it
-<br>
- *is* a problem for ps2write because it uses the names to rebuild the font
-<br>
- for embedding. If the name is one of the standard names then it leads
-<br>
- (through complex routes) to us creating a CMAP subtable where the GID is
-<br>
- not correct, we use the value of the stadnard name instead of the correct
-<br>
- numeric value.
-<br>
-
-<br>
- By using decimal numbers we avoid this problem.
-<br>
-
-<br>
- This change exhibits progressions in the regression files Bug688421.pdf
-<br>
- (which is now 100% correct with the earlier fixes for composite glyphs)
-<br>
- and Bug691121.pdf
-<br>
-
-<br>
-gs/Resource/Init/gs_ttf.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-09 09:43:53 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db2cf48ecc2e287d2685c4b43fa7bcaa0fde1721">db2cf48ecc2e287d2685c4b43fa7bcaa0fde1721</a>
-<blockquote>
-<p>
- Bug 692730: fix confusion in stream opening for FAPI/FT
-<br>
-
-<br>
- When I wrote the custom stream code so that Freetype uses the Ghostscript
-<br>
- stream functions, I misunderstood a couple of aspects of the Ghostscript
-<br>
- stream opening code, especially where paths did not include a Postscript
-<br>
- device.
-<br>
-
-<br>
- I believe this resolves that.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/psi/fapi_ft.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-08 21:35:46 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8ac67fdf4beb52a8f804b146a13af208004c6f88">8ac67fdf4beb52a8f804b146a13af208004c6f88</a>
-<blockquote>
-<p>
- Fix for accidental changes in ghostscript.vcproj during previous commit.
-<br>
-
-<br>
- Problem was caused by the fact that I add added a file that I wanted in the
-<br>
- project display but I am running a newer version of visual studio compared to
-<br>
- what we maintain in the trunk.
-<br>
-
-<br>
-gs/ghostscript.vcproj
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-06 12:52:31 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=592047c6c30012f86ada508870554c9eff9a749a">592047c6c30012f86ada508870554c9eff9a749a</a>
-<blockquote>
-<p>
- Allow use of unmanaged color transformations for source DeviceXXX colors
-<br>
-
-<br>
- This introduces a CMM that can hand back &quot;links&quot; to gs where the
-<br>
- links in this case contain pointers to the simple procedures that
-<br>
- transform between the various color spaces. This CMM (or non-CMM) can
-<br>
- be invoked when we encounter DeviceRGB, DeviceGray or DeviceCMYK color
-<br>
- spaces by use of the parameter -dUseFastColor.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gdevpsd.c
-<br>
-gs/base/gdevrinkj.c
-<br>
-gs/base/gdevxcf.c
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gsdparam.c
-<br>
-gs/base/gsequivc.c
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gsicc_cache.h
-<br>
-gs/base/gsicc_cms.h
-<br>
-gs/base/gsicc_lcms.c
-<br>
-gs/base/gsicc_lcms2.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_nocm.c
-<br>
-gs/base/gxblend.c
-<br>
-gs/base/gxblend.h
-<br>
-gs/base/gxcmap.c
-<br>
-gs/base/gxi12bit.c
-<br>
-gs/base/gxicolor.c
-<br>
-gs/base/gxipixel.c
-<br>
-gs/base/gxiscale.c
-<br>
-gs/base/lib.mak
-<br>
-gs/ghostscript.vcproj
-<br>
-xps/xpsgradient.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-08 15:18:16 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2ab94321918a4d4575435361e685836016ee9368">2ab94321918a4d4575435361e685836016ee9368</a>
-<blockquote>
-<p>
- Removed cgm devices. Fixed Bug 692401.
-<br>
-
-<br>
- No cluster differences expected, since the cluster doesn't test any of the cgm devices.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-gs/base/devs.mak
-<br>
-gs/base/gdevcgm.c
-<br>
-gs/base/gdevcgml.c
-<br>
-gs/base/gdevcgml.h
-<br>
-gs/base/gdevcgmx.h
-<br>
-gs/doc/Develop.htm
-<br>
-gs/doc/Drivers.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-07 15:32:14 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f52122736b932c511a02b095d056cfb3a19a7fa8">f52122736b932c511a02b095d056cfb3a19a7fa8</a>
-<blockquote>
-<p>
- Bug 692641: Misc build fixes for static systems
-<br>
-
-<br>
- Patch contributed by Alan Hourihane ( alanh@fairlite.co.uk ) to improve
-<br>
- compatibility with system which need static linking. So disable dynmic devices
-<br>
- unless they explicitly enabled, rename our internal SHA functions so they don't
-<br>
- clash when libssl is linked in.
-<br>
-
-<br>
- Finally, a fix so configure doesn't assume pkgconfig availability (although it
-<br>
- is widely available, it is not &quot;standard&quot;).
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-gs/base/sha2.c
-<br>
-gs/base/sha2.h
-<br>
-gs/base/ssha2.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-06 13:38:01 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3d64dd5fa86827f374ded02b220cf9bddbc852c7">3d64dd5fa86827f374ded02b220cf9bddbc852c7</a>
-<blockquote>
-<p>
- Another parital fix for Bug 692434.
-<br>
-
-<br>
-gs/base/gdevddrw.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-06 13:34:47 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0b21c79855e8f50a218a478bf9fc9d10e20c4db4">0b21c79855e8f50a218a478bf9fc9d10e20c4db4</a>
-<blockquote>
-<p>
- Partial fix for Bug 692434, removed some of the memcmp() of structures.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/base/gdevdevn.c
-<br>
-gs/base/gdevpdfg.c
-<br>
-gs/base/gdevpdti.c
-<br>
-gs/base/gdevpdts.c
-<br>
-gs/base/gdevprn.c
-<br>
-gs/base/gsequivc.h
-<br>
-gs/base/gsfont.c
-<br>
-gs/base/gsmatrix.c
-<br>
-gs/base/gsmatrix.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-06 19:20:28 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9335aeee4aab3e7454c827fc3a327437dec85637">9335aeee4aab3e7454c827fc3a327437dec85637</a>
-<blockquote>
-<p>
- Bug 692526: Partial fix (clipping path initialisation)
-<br>
-
-<br>
- Ghostscript paths have a 'local_segments' structure inside them
-<br>
- enabling them to be allocated entirely on the stack. Clipping
-<br>
- paths contain paths, so have the same structure. When a new
-<br>
- clipping path is initialised on the stack, it can share the
-<br>
- segments from an existing clipping path.
-<br>
-
-<br>
- If this existing clipping path is on the stack, and 'goes away'
-<br>
- (due to garbage collection etc) the new clipping path can be left
-<br>
- holding pointers to invalid data. As such there is code in the gs
-<br>
- lib to detect that a clipping path is being asked to share
-<br>
- segments from another stack allocated clipping path, and to refuse.
-<br>
-
-<br>
- The file referenced in the bug runs into exactly this situation.
-<br>
- It is however entirely safe, as the lifespan of the second clipping
-<br>
- path is 'nested' safely within the lifespan of the original.
-<br>
-
-<br>
- I have therefore introduced another function that allows the
-<br>
- initialisation to be done as long as the caller guarantees that it
-<br>
- is safely nested.
-<br>
-
-<br>
- This is sufficient to avoid the warning messages, and the file now
-<br>
- runs to completion successfully.
-<br>
-
-<br>
- So why is this only a partial fix?
-<br>
-
-<br>
- The original code refuses to initialise the clip path, and returns
-<br>
- a (negative) error code. This is caught by the calling code and
-<br>
- various things are not done. Later, a compositor comes to be shut
-<br>
- down, and pdf14_compose_group is called.
-<br>
-
-<br>
- This finds that maskbuf != NULL, but maskbuf-&gt;transfer_fn == NULL.
-<br>
- This leads to a SEGV.
-<br>
-
-<br>
- Something (presumably in the cleanup code that should be handling
-<br>
- the error) is leaving the compositor in an unexpected state however.
-<br>
-
-<br>
- The code change here stops the error return code, so the cleanup code
-<br>
- is not called, and the regression is fixed. It leaves the broken
-<br>
- cleanup code in there though - I'll leave the bug open until this is
-<br>
- fixed.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gxcpath.c
-<br>
-gs/base/gxfill.c
-<br>
-gs/base/gxpath.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-05 11:36:19 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a7b85f9823b1a1dea1530716a3e2fb3dd2f75c9c">a7b85f9823b1a1dea1530716a3e2fb3dd2f75c9c</a>
-<blockquote>
-<p>
- Fix for bug 692567. Knockout support in pdf14_copy_alpha
-<br>
-
-<br>
- During a combined stroke and fill we push a knockout group for the stroke. This was not being handled properly in the pdf14 device's copy_alpha operation.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-17 10:19:42 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2cde54397abe935ff96300a4ac2588b40ad68d2b">2cde54397abe935ff96300a4ac2588b40ad68d2b</a>
-<blockquote>
-<p>
- Embedding of device ICC profile into JPEG output device
-<br>
-
-<br>
- Addresses bug 692186. This includes the fix to make sure the profile
-<br>
- is not used for pdfwrite image output.
-<br>
-
-<br>
-gs/base/gdevjpeg.c
-<br>
-gs/base/gdevpsdu.c
-<br>
-gs/base/sdct.h
-<br>
-gs/base/sdcte.c
-<br>
-gs/psi/zfdcte.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-04 20:58:58 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=224672fa4af11c4723c38ea11b4d51503a96f609">224672fa4af11c4723c38ea11b4d51503a96f609</a>
-<blockquote>
-<p>
- Fix for bug 692717. Initialization of ICC profile data range in pdf14_put_image
-<br>
-
-<br>
- The ICC profile that is used to specify the PDF14 image data was not having its
-<br>
- range values properly initialized.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-12-03 22:33:04 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fd7c24da5b84f99605a38108c8cc0bfae813fbf4">fd7c24da5b84f99605a38108c8cc0bfae813fbf4</a>
-<blockquote>
-<p>
- Fix for bug 692692. Anti-alias with pdf14 device.
-<br>
-
-<br>
- This fixes several bugs that were present in the pdf14 copy alpha
-<br>
- procedure.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-29 20:33:16 +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=d20a6cb9f12682804af2e74ec5d6bb75ca9d5410">d20a6cb9f12682804af2e74ec5d6bb75ca9d5410</a>
-<blockquote>
-<p>
- Bug 691267: jbig2dec needs to check malloc() return values
-<br>
-
-<br>
- This fix checks all return paths to ensure that the appropriate error
-<br>
- is returned on failure from any malloc() call within jbig2dec.
-<br>
-
-<br>
-gs/base/sjbig2.c
-<br>
-gs/jbig2dec/jbig2.c
-<br>
-gs/jbig2dec/jbig2_arith.c
-<br>
-gs/jbig2dec/jbig2_arith_iaid.c
-<br>
-gs/jbig2dec/jbig2_arith_int.c
-<br>
-gs/jbig2dec/jbig2_generic.c
-<br>
-gs/jbig2dec/jbig2_halftone.c
-<br>
-gs/jbig2dec/jbig2_huffman.c
-<br>
-gs/jbig2dec/jbig2_image.c
-<br>
-gs/jbig2dec/jbig2_metadata.c
-<br>
-gs/jbig2dec/jbig2_page.c
-<br>
-gs/jbig2dec/jbig2_refinement.c
-<br>
-gs/jbig2dec/jbig2_segment.c
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c
-<br>
-gs/jbig2dec/jbig2_text.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-28 10:06: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=79de8a34f93165b5839f9fcbd75be9ca0048fd21">79de8a34f93165b5839f9fcbd75be9ca0048fd21</a>
-<blockquote>
-<p>
- Bug 692694: unaligned memory access in image ht code.
-<br>
-
-<br>
- When image data does not land exactly on the necessary alignment for SSE2
-<br>
- optimisations, we handle the &quot;left over&quot; samples on their own, before the
-<br>
- suitably aligned samples. When we come to copy the halftoned data to the
-<br>
- target device, we first handle the &quot;left over&quot; samples, and then the
-<br>
- SSE2 aligned samples in separate calls to copy_mono/copy_plane. The &quot;left
-<br>
- over&quot; samples never number more than 16.
-<br>
-
-<br>
- Previously, after dealing with the non-SSE2 aligned samples, we'd increment
-<br>
- the samples pointer two bytes (to skip the up to 16 bits of unaligned samples).
-<br>
- The problem is, that causes us to 32 bits at time, on 16 bit aligned boundaries,
-<br>
- which on SPARC causes a bus error.
-<br>
-
-<br>
- We now use the copy_mono/copy_plane API parameter which gives the function an
-<br>
- offset into the samples which is should use before starting the operation.
-<br>
- Implementations of copy_mono/copy_plane must handle non-aligned samples
-<br>
- gracefully anyway.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/gxht_thresh.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-27 13:23:46 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a39e4831ba0d74d742b365f3b3b1af192731303c">a39e4831ba0d74d742b365f3b3b1af192731303c</a>
-<blockquote>
-<p>
- Bug 692684: stop gcc optimization bug.
-<br>
-
-<br>
- Divide gs_main_init2() into two functions to work around a bug in
-<br>
- gcc 4.5.1 with -O2 option. The bug caused gcc to drop 2nd
-<br>
- assignment to i_ctx_p and resulted in SEGV error later on.
-<br>
-
-<br>
-gs/psi/imain.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-25 17:37:39 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa65667a25048b730e629bd4d8544d621cae2810">fa65667a25048b730e629bd4d8544d621cae2810</a>
-<blockquote>
-<p>
- Clean-up txtwrite device.
-<br>
-
-<br>
- Make debug tracing use a special flag instead of DEBUG.
-<br>
- Fix two cases of '=' used instead of '=='.
-<br>
- Fix all gcc warnings.
-<br>
- Add proper dependencies to the makefile.
-<br>
-
-<br>
-gs/base/devs.mak
-<br>
-gs/base/gdevtxtw.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-25 12:24:11 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e46cb584f6ab876828bb5c7943881cfbbc549e43">e46cb584f6ab876828bb5c7943881cfbbc549e43</a>
-<blockquote>
-<p>
- Add missing txtwrite device to autoconf-based build.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-25 15:50:42 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=979f2182372d924ce69f8d904e87173107209b6b">979f2182372d924ce69f8d904e87173107209b6b</a>
-<blockquote>
-<p>
- ps2write - fix conversion of escaped string to Hex string
-<br>
-
-<br>
- This is used when Indexed spac es are encountered, the lookup table is
-<br>
- created as an escaped string, but written to the output as a Hex string.
-<br>
- The conversion was not catering for the 'special' escaped characters,
-<br>
- \r, \n, \b, \t and \f
-<br>
-
-<br>
- This results in a number of differences, casreful comparison shows them all
-<br>
- to be progressions:
-<br>
-
-<br>
- Bug6901014_launch_leaflet.pdf
-<br>
- annot-fit-bbox-in-rect.pdf
-<br>
- 0.pdf
-<br>
- 01_001.pdf
-<br>
- 148-11.ps
-<br>
- 1_2001.pdf
-<br>
- Altona.Page_3.2002-09-27.pdf
-<br>
- Altona_Technical_1v1_x3.pdf
-<br>
- Bug687840.pdf
-<br>
- Bug689083.pdf
-<br>
- Bug689189.pdf
-<br>
- Bug689362.pdf
-<br>
- Bug689748.pdf
-<br>
- Bug690109.pdf
-<br>
- Bug690348.pdf
-<br>
- Bug690395.pdf
-<br>
- Bug690489.pdf
-<br>
- Bug690559.pdf
-<br>
- Bug691045.pdf
-<br>
- Bug691228.pdf
-<br>
- Bug691335.eps
-<br>
- Bug691734.ps
-<br>
- Bug691740.pdf
-<br>
- Bug691816.pdf
-<br>
- Bug691941.pdf
-<br>
- Bug692365.pdf
-<br>
- H00216q.pdf
-<br>
- MagicEye.pdf
-<br>
- NECPNTD.pdf
-<br>
- Openhuis_pdf_zw.pdf
-<br>
- PixelisAd.pdf
-<br>
- RealCities.pdf
-<br>
- S2_Digitalproof-Forum_x3k.pdf
-<br>
- adesso2.pdf
-<br>
- bulletin.pdf
-<br>
- dave.pdf
-<br>
- file.pdf
-<br>
- file2.pdf
-<br>
- japan.ps
-<br>
- korea.ps
-<br>
- messenger.pdf
-<br>
- messenger16.pdf
-<br>
- p2b-100.pdf
-<br>
- CATX0249.pdf
-<br>
- CATX1028.pdf
-<br>
- CATX1421.pdf
-<br>
- CATX1593.pdf
-<br>
- CATX2050.pdf
-<br>
- CATX2181.pdf
-<br>
- CATX2447.pdf
-<br>
- CATX2905.pdf
-<br>
- CATX2937.pdf
-<br>
- CATX3740.pdf
-<br>
- CATX3783.pdf
-<br>
- CATX4574.pdf
-<br>
- CATX4879.pdf
-<br>
- CATX4998.pdf
-<br>
- CATX5365.pdf
-<br>
- CATX6460.pdf
-<br>
- CATX7581.pdf
-<br>
- CATX7762.pdf
-<br>
- CATX8839.pdf
-<br>
- CATX9297.pdf
-<br>
- IA3Z0248.pdf
-<br>
- IA3Z0440.pdf
-<br>
- IA3Z1148.pdf
-<br>
- IA3Z1284.pdf
-<br>
- IA3Z3096.pdf
-<br>
- IA3Z3100.pdf
-<br>
- IA3Z3298.pdf
-<br>
- IA3Z3881.pdf
-<br>
- IA3Z4393.pdf
-<br>
- IA3Z4925.pdf
-<br>
-
-<br>
-gs/base/gdevpdfu.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-25 15:27: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=3f99f9c568fa7a93ce4ca5acdc0c8fed6cf505bd">3f99f9c568fa7a93ce4ca5acdc0c8fed6cf505bd</a>
-<blockquote>
-<p>
- Add a &quot;dummy&quot; call to validate UFST font.
-<br>
-
-<br>
- It turns out that UFST's CGIFfont() call does little or no validation of the
-<br>
- font for which it is creating an object. So, add a &quot;dummy&quot; call to
-<br>
- CGIFfont_metrics() which will return an error if, for example, a request
-<br>
- for a font index which doesn't exist in the current FCO is made.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/psi/fapiufst.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-21 20:31:09 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83788c03875545d620e6885e4f5ab4af08f8f55b">83788c03875545d620e6885e4f5ab4af08f8f55b</a>
-<blockquote>
-<p>
- Bug 692666: grid fit images.
-<br>
-
-<br>
- The file in bug 692666 draws many thin horizontal rectangles, then draws
-<br>
- 1 pixel high images on top of each one. Current gs 'thickens' the
-<br>
- rectangles (due to the 'any part of a pixel' rule), and they overwrite
-<br>
- the previously drawn image - hence it appears black.
-<br>
-
-<br>
- The problem is thus that the images are not similarly stretched.
-<br>
-
-<br>
- Images are not supposed to use the &quot;any part of a pixel&quot; rule, where
-<br>
- vectors are, but the fact this file works in acrobat would seem to
-<br>
- contradict that. Instead we try a simple fix; if we are using the
-<br>
- 'any part of a pixel' file (i.e. fill_adjust != 0), and we meet an
-<br>
- ImageMask image that is either 1 pixel high, or 1 pixel wide, then we
-<br>
- ensure that it is 'stretched' to completely fill any pixels that it
-<br>
- touches.
-<br>
-
-<br>
- We specifically do NOT perform this stretching if we are in the process
-<br>
- of rendering a glyph.
-<br>
-
-<br>
- This produces various rendering diffs, none that offensive.
-<br>
-
-<br>
-gs/base/gxipixel.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-23 15:36:11 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4298afc461ec583637d5ce2b41facc40403867d5">4298afc461ec583637d5ce2b41facc40403867d5</a>
-<blockquote>
-<p>
- Correct CIDSet and CIDToGIDMap generation when LastChar &gt; number of glyphs
-<br>
-
-<br>
- More CIDSet work. WHen LastChar is &gt; number of glyphs in font (already a subset)
-<br>
- we were setting the length of the CIDToGIDMap and the CIDSet to the LastChar
-<br>
- value. This should be LastChar + 1 to allow for the /.notdef.
-<br>
-
-<br>
- No differences expected, this only happens when generating PDF/A which is not tested.
-<br>
-
-<br>
-gs/base/gdevpdtd.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-22 17:58:47 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7cf40e90d53c0a86b05561985608d3d292025a00">7cf40e90d53c0a86b05561985608d3d292025a00</a>
-<blockquote>
-<p>
- Bug 692681: handle invalid Encoding arrays in Type 3 fonts
-<br>
-
-<br>
- Distiller quietly converts the contents the contents of a Type 3 font's encoding
-<br>
- array to names (at least if they are integer objects), whilst CPSI throws an
-<br>
- error.
-<br>
-
-<br>
- We will now do as Distiller and convert to name objects, unless we are in &quot;CPSI
-<br>
- compatibility mode&quot;, when we will throw an error.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/psi/zbfont.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-19 00:02:59 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=365dd132567f8007176ca48d36741b6c98d4a514">365dd132567f8007176ca48d36741b6c98d4a514</a>
-<blockquote>
-<p>
- Bug 692512: fts_10xx.xps shows white lines in pattern.
-<br>
-
-<br>
- The matrix used for the pattern is skewed; this was enough to avoid
-<br>
- my previous fix being used. Amend the tests to cope with the skewed
-<br>
- case too. We may need to cope with 90 degree rotated/skewed cases too.
-<br>
-
-<br>
-gs/base/gsptype1.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-18 23:59:14 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6fc9006fb9e381c42308d7d7967fdcac5f31e26d">6fc9006fb9e381c42308d7d7967fdcac5f31e26d</a>
-<blockquote>
-<p>
- Bug 692512: Disable stroke adjust in xps to avoid gradient issues.
-<br>
-
-<br>
- The fts_1003.xps file has a series of parallel lines (as separate
-<br>
- strokes) to make up a gradient. Having stroke adjust enabled
-<br>
- causes gaps (white lines) to appear between them.
-<br>
-
-<br>
- Tests show that simply disabling stroke adjust all the time gives
-<br>
- nasty effects (thickening of lines). We therefore disable it just
-<br>
- for patterns here. This is enough to fix the current bug.
-<br>
-
-<br>
-xps/xpstile.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-22 08:15:27 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5cce07051c3616c250a960ae48759a1c1af2fb47">5cce07051c3616c250a960ae48759a1c1af2fb47</a>
-<blockquote>
-<p>
- ps2write - only execute setpagedevice if /PageSize changes
-<br>
-
-<br>
- Bug #692691
-<br>
-
-<br>
- The ps2write output (being based on pdfwrite) always emits a /MediaBox as
-<br>
- this is a required key for PDF. Previously the PostScript prolog would
-<br>
- always emit a setpagedevice using the MediaBox as the PageSize entry.
-<br>
-
-<br>
- This caused a problem for CUPS as it inserts PPD code into the ps2write
-<br>
- output, and if this enables Duplex then each invocation of setpagedevice
-<br>
- will flush the accumulated output, which defeats Duplex.
-<br>
-
-<br>
- The prolog code now tests the current page size and only executes
-<br>
- setpagedevice if the newly requested size differs from the current size. In
-<br>
- a simple attempt to ignore small differences we round the current and requested
-<br>
- media sizes, and convert to integers before comparison.
-<br>
-
-<br>
- No differences expected in regression tests
-<br>
-
-<br>
-gs/base/opdfread.h
-<br>
-gs/lib/opdfread.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-21 18:56:17 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8a14c04c93138fab042063999af3610ea7b9852a">8a14c04c93138fab042063999af3610ea7b9852a</a>
-<blockquote>
-<p>
- Revisions for Freetype custom stream use.
-<br>
-
-<br>
- There were some subtleties of FT's custom stream use that I misunderstood:
-<br>
- unused entries in the structures must be null/zero, and the stream length
-<br>
- is required data.
-<br>
-
-<br>
- Also, reorganise the code so building the stream object is contained in
-<br>
- a dedicated function.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/psi/fapi_ft.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-21 11:10:22 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fc8350604816f8314cb8c6355bfb9335feab5561">fc8350604816f8314cb8c6355bfb9335feab5561</a>
-<blockquote>
-<p>
- Fix one of the casts from b6cd8ce7351fc7bb759b5b7dcea7e74b2abb3850
-<br>
-
-<br>
- The cast in the calls to hpgl_args_add_int() in pcl/pgconfig.c:hpgl_IR()
-<br>
- was wrong. The entire second argument needed to be cast to int32, not
-<br>
- just the results of the division. This caused regressions in a bunch
-<br>
- of the nightly/cluster test files, e.g.:
-<br>
-
-<br>
- main/obj/pcl6 -sDEVICE=ppmraw -r75 -o test.ppm fts.1930
-<br>
-
-<br>
-pcl/pgconfig.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-21 15:38:07 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=590dcb6b2df9f4722b4f78607d35bd9c374624b1">590dcb6b2df9f4722b4f78607d35bd9c374624b1</a>
-<blockquote>
-<p>
- Bug 692672: slightly revise symbolic fonts in PDFs
-<br>
-
-<br>
- This is a slightly better of approximation of what Acrobat does in the out
-<br>
- of spec condition when a font has both an encoding in the font object and
-<br>
- the symbolic flag set in the descriptor's flags entry.
-<br>
-
-<br>
- If the flags say symbolic, *and* the font contains a symbol cmap table,
-<br>
- ignore Encoding if there is one, treat as symbolic.
-<br>
-
-<br>
- If the flags say symbolic, and the font doesn't have a symbol cmap, but we do
-<br>
- have an Encoding, treat it as non-symbolic if we don't have an Encoding, try
-<br>
- the MacRoman cmap table.
-<br>
-
-<br>
- Finally, if none of that works, remove the Encoding, and treat it as
-<br>
- non-symbolic. This part is the biggest guess at Acrobat's behavior.
-<br>
-
-<br>
- The various tests used in investigating what Acrobat does are attached to the
-<br>
- bug (692672).
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/Resource/Init/gs_ttf.ps
-<br>
-gs/Resource/Init/pdf_font.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-21 08:55:17 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bd108fc1a4b52c885a8e26362f346c0cd2fb6670">bd108fc1a4b52c885a8e26362f346c0cd2fb6670</a>
-<blockquote>
-<p>
- Update to Commit 63a5fe390d2534f6b48e2dd58f46ed9941582e83
-<br>
-
-<br>
- This added detection of URW font names and their replacement with base 14
-<br>
- font names, when the fonts are not embedded. One of the Base 14 names
-<br>
- was not correct.
-<br>
-
-<br>
-gs/base/gdevpdtb.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-21 08:47:51 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e2215693fe25a78865632b6bbbd52a3b4f2ab95c">e2215693fe25a78865632b6bbbd52a3b4f2ab95c</a>
-<blockquote>
-<p>
- Fix some minor return code inconsistencies.
-<br>
-
-<br>
- Bug #692682, spotted by Alex, fix up a couple of inconsistent return values.
-<br>
-
-<br>
-gs/base/gdevpdfo.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-21 08:12: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=cd8f3973ac735480fcd02de9e0214de80ea79e94">cd8f3973ac735480fcd02de9e0214de80ea79e94</a>
-<blockquote>
-<p>
- ps2write - fix handling of format 4 CMAP subtables in TrueType fonts
-<br>
-
-<br>
- Bug #692687. Format 4 CMAP subtables are intended for use where the range
-<br>
- of glyphs are not continuous, but the code for building a CharStrings
-<br>
- dictionary (to handle the font as type 42) was treating them as if they
-<br>
- were continuous, and starting from 0.
-<br>
-
-<br>
- This led to the CharStrings dictionary, which maps glyph names to TrueType
-<br>
- Glyph IDS, being built incorrectly and incorrect, mostly /.notdef, glyphs
-<br>
- being used.
-<br>
-
-<br>
- Regression testing shows no regressions and the following test files exhibit
-<br>
- progressions:
-<br>
- Bug6901014_Additional_testcase.pdf
-<br>
- Bug6901014_SMP_Warwick_14.pdf
-<br>
- Altona.Page_3.2002-09-27.pdf
-<br>
- Altona_Technical_1v1_x3.pdf
-<br>
- Bug687828.pdf
-<br>
- Bug688421.pdf
-<br>
- Bug688946.pdf
-<br>
- Bug689014.pdf
-<br>
- Bug689754.ps
-<br>
- Bug690269.ps
-<br>
- Bug691116.pdf
-<br>
- Bug691733.ps
-<br>
- Faktura.pdf
-<br>
- altona_technical_1v2_x3.pdf
-<br>
- test_multipage_prob.pdf
-<br>
- type42_glyph_index.ps
-<br>
- CATX4030.pdf
-<br>
- CATX9201.pdf
-<br>
- IA3Z4488.pdf
-<br>
-
-<br>
-gs/base/opdfread.h
-<br>
-gs/lib/opdfread.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-21 01:26:01 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ae0f7a3be733a04293a757f6ae395391339b78f5">ae0f7a3be733a04293a757f6ae395391339b78f5</a>
-<blockquote>
-<p>
- Finish interface to OpenJpeg library.
-<br>
-
-<br>
- This version handles all out tests correctly, although all files
-<br>
- show minor differences in color values. The build process has
-<br>
- not been changed and continues to build Jasper by default.
-<br>
-
-<br>
-gs/base/sjpx_openjpeg.c
-<br>
-gs/base/sjpx_openjpeg.h
-<br>
-gs/openjpeg/libopenjpeg/image.c
-<br>
-gs/openjpeg/libopenjpeg/jp2.c
-<br>
-gs/openjpeg/libopenjpeg/jp2.h
-<br>
-gs/openjpeg/libopenjpeg/openjpeg.c
-<br>
-gs/openjpeg/libopenjpeg/openjpeg.h
-<br>
-gs/openjpeg/libopenjpeg/tcd.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-20 10:29:47 +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=f7f2daea2778213306a3edfe87a8f72af494427a">f7f2daea2778213306a3edfe87a8f72af494427a</a>
-<blockquote>
-<p>
- Fix 691958: check for an image before marking a page complete.
-<br>
- Also update return code to handle errors correctly.
-<br>
-
-<br>
-gs/jbig2dec/jbig2_page.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-20 10:43:51 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=44049d64ebd14bd76f94d87cd0fd55ea725f7510">44049d64ebd14bd76f94d87cd0fd55ea725f7510</a>
-<blockquote>
-<p>
- Update ownership.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-doc/who_owns_what.txt
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-18 14:42:40 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=38cb1fd0cb7f38e6d7cf4b4fe06809865ccd0fff">38cb1fd0cb7f38e6d7cf4b4fe06809865ccd0fff</a>
-<blockquote>
-<p>
- Fix 692559, integrate Josef Hinteregger's patch to detect a font
-<br>
- directory without fonts and continue gracefully.
-<br>
-
-<br>
-pl/pllfont.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-18 14:09:04 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3457a11ec419dcce4cd9e444674967b4dd5e8740">3457a11ec419dcce4cd9e444674967b4dd5e8740</a>
-<blockquote>
-<p>
- The indeterminism in the test file TIFFOffsetA4PL.pcl was caused by
-<br>
- the new custom page size implementation. The new code updates the
-<br>
- current page structure instead of creating a new one - later the page
-<br>
- size logic doesn't recognize a page size change and doesn't clear the
-<br>
- page (erasepage) properly. The custom page size implementation is
-<br>
- less than ideal, but the simple fix here is to just erase the page
-<br>
- unconditionally when the custom page size command is received. There
-<br>
- was no bug reported for this problem.
-<br>
-
-<br>
-pcl/pcpage.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-17 17:59:41 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f482ab7c57e8a20f760be5b329bee528a66e7927">f482ab7c57e8a20f760be5b329bee528a66e7927</a>
-<blockquote>
-<p>
- Capitalize a symbolic constant.
-<br>
-
-<br>
-pcl/pcpage.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-17 17:44:49 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b9a1eeaa1fce33270957e302e09189c6202f1a5">7b9a1eeaa1fce33270957e302e09189c6202f1a5</a>
-<blockquote>
-<p>
- Fix 692677, in passthrough mode we initialize the PCL interpreter with
-<br>
- the paper size current in PXL's state. Previously the there could be
-<br>
- a mismatch in paper size which could lead to, for example, an A4
-<br>
- memory buffer erased as if it were LETTER, this left a small strip at
-<br>
- the bottom of the page uninitialized.
-<br>
-
-<br>
-pxl/pxpthr.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-17 17:43:05 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fdb03e00c09a32d23a831cecfea9f4b1955b9b7a">fdb03e00c09a32d23a831cecfea9f4b1955b9b7a</a>
-<blockquote>
-<p>
- A new interface procedure to allow the languages to invoke the PJL parser.
-<br>
-
-<br>
-pl/pjparsei.c
-<br>
-pl/pjtop.c
-<br>
-pl/pjtop.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-17 17:39:28 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fc3aa53aafc7b73ae9703d253ae4040658e22b74">fc3aa53aafc7b73ae9703d253ae4040658e22b74</a>
-<blockquote>
-<p>
- The &quot;wide a4&quot; state variable could be used unitialized when using
-<br>
- custom paper sizes.
-<br>
-
-<br>
-pcl/pcpage.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-15 11:26:36 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=27806596e3c2820064788bba903cc569ce89f1e7">27806596e3c2820064788bba903cc569ce89f1e7</a>
-<blockquote>
-<p>
- Removal of WTS from code.
-<br>
-
-<br>
- Plan is to suggest the use of screens generated with gs\toolbin\halftone\gen_ordered
-<br>
-
-<br>
-gs/base/gdevdflt.c
-<br>
-gs/base/gp.h
-<br>
-gs/base/gsdcolor.h
-<br>
-gs/base/gsdps1.c
-<br>
-gs/base/gsht.c
-<br>
-gs/base/gsht1.c
-<br>
-gs/base/gshtscr.c
-<br>
-gs/base/gslibctx.h
-<br>
-gs/base/gswts.c
-<br>
-gs/base/gswts.h
-<br>
-gs/base/gxbitfmt.h
-<br>
-gs/base/gxclread.c
-<br>
-gs/base/gxdcolor.c
-<br>
-gs/base/gxdcolor.h
-<br>
-gs/base/gxdevcli.h
-<br>
-gs/base/gxdevndi.c
-<br>
-gs/base/gxdht.h
-<br>
-gs/base/gxdhtserial.c
-<br>
-gs/base/gxht.h
-<br>
-gs/base/gxshade.c
-<br>
-gs/base/gxwts.c
-<br>
-gs/base/gxwts.h
-<br>
-gs/base/lib.mak
-<br>
-gs/doc/Language.htm
-<br>
-gs/ghostscript.vcproj
-<br>
-gs/psi/zusparam.c
-<br>
-pl/plsrgb.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-17 12:05:24 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aef9ee68391088d1c7e371a6f1e3fa4092688eae">aef9ee68391088d1c7e371a6f1e3fa4092688eae</a>
-<blockquote>
-<p>
- Revert &quot;Embedding of device ICC profile into JPEG output device&quot;
-<br>
-
-<br>
- This reverts commit 23a2b8e765a4d56cfeacddaaaa497e817bec499e.
-<br>
- Need to see how this screws up pdfwrite.
-<br>
-
-<br>
-gs/base/gdevjpeg.c
-<br>
-gs/base/sdct.h
-<br>
-gs/base/sdcte.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-17 10:19:42 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=23a2b8e765a4d56cfeacddaaaa497e817bec499e">23a2b8e765a4d56cfeacddaaaa497e817bec499e</a>
-<blockquote>
-<p>
- Embedding of device ICC profile into JPEG output device
-<br>
-
-<br>
- Addresses bug 692186.
-<br>
-
-<br>
-gs/base/gdevjpeg.c
-<br>
-gs/base/sdct.h
-<br>
-gs/base/sdcte.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-16 10:32:30 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6fbdd32889dfa9d318170e63245755057bb8b401">6fbdd32889dfa9d318170e63245755057bb8b401</a>
-<blockquote>
-<p>
- Save ICC profile in TIFF and PNG device output.
-<br>
-
-<br>
- This addresses Bug 692183. The patch for the TIFF case was not
-<br>
- quite sufficient due to changes in the device profile structure,
-<br>
- issues regarding the separations from the tiffsep device, and
-<br>
- how we handle the case when the output profile is CIELAB.
-<br>
-
-<br>
-gs/base/gdevpng.c
-<br>
-gs/base/gdevtifs.c
-<br>
-gs/base/gdevtsep.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-15 18:02:06 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3a088c1913fae07ea8016ef29853610741e16851">3a088c1913fae07ea8016ef29853610741e16851</a>
-<blockquote>
-<p>
- Bug 692683: revise FAPI/FT code so it uses the GS file handling
-<br>
-
-<br>
- When the Freetype interface was called to create a font object with a path
-<br>
- to the font file, it previously simply passed the path into Freetype, and
-<br>
- left it to handle the file details.
-<br>
-
-<br>
- This revision changes that so that we build a custom Freetype stream object
-<br>
- which uses the Ghostscript file API to access the data. We generally prefer
-<br>
- to operate that way anyway, and (more importantly) this allows FT &quot;direct&quot;
-<br>
- acccess to font files stored in our ROM filesystem.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/psi/fapi_ft.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-15 17:25:27 +0000
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=445f78bf167f27a5358bff72d314d6ecc83a5384">445f78bf167f27a5358bff72d314d6ecc83a5384</a>
-<blockquote>
-<p>
- Add a wildcard to CIDFont mkromfs parameter
-<br>
-
-<br>
- To correctly including the _contents_ of the Resource/CIDFont directory
-<br>
- when building the rom filesystem, we need a wildcardm, so it ends up
-<br>
- as &quot;Resource/CIDFont/*&quot;
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/psi/psromfs.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-14 22:37:28 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f0b1c2aefaed5ba17fea69848c0b5489b541c4cf">f0b1c2aefaed5ba17fea69848c0b5489b541c4cf</a>
-<blockquote>
-<p>
- Clarification of the gen_ordered settings and README.
-<br>
-
-<br>
- The current default value for -s (size of the super cell) is 1
-<br>
- which indicates that them smallest possible size should be used.
-<br>
- This occurs regardless of the requested quantization levels.
-<br>
- This is clarified in the README and a message is displayed
-<br>
- during the creation of the screen providing a minimum suggested
-<br>
- value for -s to achieve the number of requested levels.
-<br>
-
-<br>
-gs/toolbin/halftone/gen_ordered/README
-<br>
-gs/toolbin/halftone/gen_ordered/gen_ordered.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-14 10:10:05 -0800
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0cf2574289f8825620dd805f49f1cfaab04f005b">0cf2574289f8825620dd805f49f1cfaab04f005b</a>
-<blockquote>
-<p>
- Addition of thresholding functions for subtractive color spaces.
-<br>
-
-<br>
- Previously, I had swapped the threshold and the image data to handle the subtractive case.
-<br>
- Unfortunately due to the way things were written that caused issues. So for now we added
-<br>
- unique functions for the subtractive case to avoid an additional conditional in the low
-<br>
- level part of the code.
-<br>
-
-<br>
-gs/base/gxht_thresh.c
-<br>
-gs/base/gxht_thresh.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-14 18:11:44 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3becda050c87511153170a85c7d3414e9a78e189">3becda050c87511153170a85c7d3414e9a78e189</a>
-<blockquote>
-<p>
- Squash some more PCL warnings.
-<br>
-
-<br>
- Implicit typecasts made explicit.
-<br>
-
-<br>
-gs/base/gdevclj.c
-<br>
-pcl/pcrect.c
-<br>
-pl/plchar.c
-<br>
-pxl/pxerrors.c
-<br>
-pxl/pxgstate.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-14 12:19:32 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=96ab69c8bcc1bcf3e366b494ed099dc5b46009fe">96ab69c8bcc1bcf3e366b494ed099dc5b46009fe</a>
-<blockquote>
-<p>
- Planar rop fixes; extensive changes throughout code.
-<br>
-
-<br>
- The changes here are largely forced upon us by the rop source device,
-<br>
- the internal mechanism used within the gs lib to cope with performing
-<br>
- rop operations with drawing operations. The rop source device is
-<br>
- created and is given a 'source'. Any operations then done to that device
-<br>
- are then passed on to its target device rewritten into a form that will
-<br>
- cause the output to be ropped with the source.
-<br>
-
-<br>
- This causes problems when the source is in planar format (such as when
-<br>
- the source is a pattern tile intended for use on a planar device). There
-<br>
- is no way to call strip_copy_rop with planar data currently, neither
-<br>
- can it easily be shoehorned through. We therefore add a new
-<br>
- 'strip_copy_rop2' entrypoint that takes an additional 'planar_height'
-<br>
- parameter that gives the number of lines of data before the next
-<br>
- planes data starts.
-<br>
-
-<br>
- We add implementations of this call throughout the code; some are
-<br>
- very simple (bbox, null, trace, clip, clip2, clip2, tile_clip etc).
-<br>
- Others 'common up' with the strip_copy_rop (gx_default,
-<br>
- mem_planar).
-<br>
-
-<br>
- The underlying memory devices should never be called with strip_copy_rop2
-<br>
- as the planar data will always be rewritten to chunky format before
-<br>
- this happens. We are free to change this approach later if we want.
-<br>
-
-<br>
- The gx_rop_source_t structure used by the rop source device is extended
-<br>
- to have a new planar_height field, and the rop source device itself
-<br>
- extended to pass this on. Various places that create this structure now
-<br>
- initialise that correctly.
-<br>
-
-<br>
- The clist reader/writer is updated to send the extra planar_height
-<br>
- field through and call strip_cop_rop or strip_copy_rop2 as appropriate.
-<br>
-
-<br>
- In a similar vein, we are forced to change the copy_plane entry point
-<br>
- to be copy_planes (as it is impossible (or very hard at least) for the
-<br>
- rop source device to implement copy_plane).
-<br>
-
-<br>
- This incorporates changes from Michael to the new &quot;fast threshold&quot; image
-<br>
- halftoning code to make it use the new copy_planes operation.
-<br>
-
-<br>
-gs/base/gdevbbox.c
-<br>
-gs/base/gdevdflt.c
-<br>
-gs/base/gdevdrop.c
-<br>
-gs/base/gdevmem.h
-<br>
-gs/base/gdevmpla.c
-<br>
-gs/base/gdevnfwd.c
-<br>
-gs/base/gdevrops.c
-<br>
-gs/base/gdevtrac.c
-<br>
-gs/base/gxacpath.c
-<br>
-gs/base/gxcht.c
-<br>
-gs/base/gxcldev.h
-<br>
-gs/base/gxclimag.c
-<br>
-gs/base/gxclip.c
-<br>
-gs/base/gxclip.h
-<br>
-gs/base/gxclip2.c
-<br>
-gs/base/gxclipm.c
-<br>
-gs/base/gxclist.c
-<br>
-gs/base/gxclrast.c
-<br>
-gs/base/gxclrect.c
-<br>
-gs/base/gxdcolor.c
-<br>
-gs/base/gxdcolor.h
-<br>
-gs/base/gxdevcli.h
-<br>
-gs/base/gxdevice.h
-<br>
-gs/base/gxht.c
-<br>
-gs/base/gxht_thresh.c
-<br>
-gs/base/gxht_thresh.h
-<br>
-gs/base/gxicolor.c
-<br>
-gs/base/gximage.h
-<br>
-gs/base/gximono.c
-<br>
-gs/base/gxp1fill.c
-<br>
-gs/base/gxpcmap.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-14 08:31:38 -0800
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=940b007282d74686a20aa5cf434d20353680344c">940b007282d74686a20aa5cf434d20353680344c</a>
-<blockquote>
-<p>
- Fixed a template -&gt; templat for the Luratech build.
-<br>
-
-<br>
-gs/base/gdevpsdi.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-14 10:39:24 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=08dc12934adaa27978ec264dbf9c691a18d8c429">08dc12934adaa27978ec264dbf9c691a18d8c429</a>
-<blockquote>
-<p>
- ps2write - improve TrueType composite glyph handling
-<br>
-
-<br>
- Bug #692626, #696264.
-<br>
-
-<br>
- When emitting a TrueType font from a CIDFont with TrueType outlines if a
-<br>
- glyph was a composite glyph we did not create an entry in name table for
-<br>
- any components of the glyph which were not already present in the output
-<br>
- font.
-<br>
-
-<br>
- This caused problems creating the CMAP subtable for the embedded TrueType
-<br>
- font.
-<br>
-
-<br>
- This patch shows progressions with ps2write and files CATX4638.pdf, bug690450.pdf.
-<br>
- A regresison with pdfwrite and file bug688421.pdf and a difference in
-<br>
- Bug 691121.pdf with pswrite (wrong before, differnetly wrong now)
-<br>
-
-<br>
- Despite the regression I'm committing it, as it shows significant improvements
-<br>
- for ps2write.
-<br>
-
-<br>
-gs/base/gxfcopy.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-12 19:44:39 +0100
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ed8664ed1a8a797d949270d707966aadefb3b9e8">ed8664ed1a8a797d949270d707966aadefb3b9e8</a>
-<blockquote>
-<p>
- Renamed the PXL CUPS filter from &quot;pstopxl&quot; to &quot;gstopxl&quot;, as like &quot;gstoraster&quot;
-<br>
- it understands both PostScript and PDF as input.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-gs/cups/cups.mak
-<br>
-gs/cups/gstopxl.in
-<br>
-gs/cups/pstopxl.in
-<br>
-gs/cups/pxlcolor.ppd
-<br>
-gs/cups/pxlmono.ppd
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-11 21:09:02 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8c3d5996d379818c8c0422bb8330840d0fb12645">8c3d5996d379818c8c0422bb8330840d0fb12645</a>
-<blockquote>
-<p>
- Bug 692675: drop ivalid filter parameters.
-<br>
-
-<br>
- Check for /dicttype instead of null. Drop null and invalid filter
-<br>
- parameters at once.
-<br>
-
-<br>
-gs/Resource/Init/pdf_base.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-11 14:09:09 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a015bf889ea43c050fcf652c37d3c786483e243">9a015bf889ea43c050fcf652c37d3c786483e243</a>
-<blockquote>
-<p>
- The PXL assembler and dissassembler had the incorrect attribute code
-<br>
- for PCLSelectFont and the PCLSelectFont attribute name was missing
-<br>
- from a debug name table.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-pxl/pxptable.c
-<br>
-tools/pxlasm.py
-<br>
-tools/pxldis.py
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-11 00:07:57 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d53286dbb42db66166b7af2f68a63baf7da43791">d53286dbb42db66166b7af2f68a63baf7da43791</a>
-<blockquote>
-<p>
- Fix 690417 - new PCL command &quot;set logical page&quot;. This allows the user
-<br>
- to provide arbitrary width, height and offsets which are then
-<br>
- associated with the currently selected paper.
-<br>
-
-<br>
-pcl/pcl.mak
-<br>
-pcl/pcpage.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-10 21:57:16 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b6cd8ce7351fc7bb759b5b7dcea7e74b2abb3850">b6cd8ce7351fc7bb759b5b7dcea7e74b2abb3850</a>
-<blockquote>
-<p>
- Squash warnings in pcl/pxl.
-<br>
-
-<br>
- Mostly making type coercions explicit.
-<br>
-
-<br>
-pcl/pcbiptrn.c
-<br>
-pcl/pccid.c
-<br>
-pcl/pccsbase.c
-<br>
-pcl/pcfont.c
-<br>
-pcl/pcfontpg.c
-<br>
-pcl/pcfsel.c
-<br>
-pcl/pcindxed.c
-<br>
-pcl/pcjob.c
-<br>
-pcl/pcpage.c
-<br>
-pcl/pcpatrn.c
-<br>
-pcl/pcrect.c
-<br>
-pcl/pcsfont.c
-<br>
-pcl/pctext.c
-<br>
-pcl/pcuptrn.c
-<br>
-pcl/pcursor.c
-<br>
-pcl/pgconfig.c
-<br>
-pcl/pgframe.c
-<br>
-pcl/pgpoly.c
-<br>
-pcl/rtgmode.c
-<br>
-pcl/rtmisc.c
-<br>
-pcl/rtraster.c
-<br>
-pl/pjparse.c
-<br>
-pl/plchar.c
-<br>
-pl/plsrgb.c
-<br>
-pxl/pxink.c
-<br>
-pxl/pxsessio.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-10 20:49:55 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=42aa659090c896b807745b4eba81335dbd8e8d92">42aa659090c896b807745b4eba81335dbd8e8d92</a>
-<blockquote>
-<p>
- Replace 'this' with 'self'.
-<br>
-
-<br>
- Using C++ reserved words in ghostscript is bad form, especially as
-<br>
- MSVC gets confused by them when debugging.
-<br>
-
-<br>
- I haven't changed the use of 'this' in zlib as it's not ours to change.
-<br>
-
-<br>
-gs/base/gscicach.c
-<br>
-gs/base/gsgcache.c
-<br>
-gs/base/gxclist.c
-<br>
-gs/base/gxhintn.c
-<br>
-gs/base/gxhintn1.c
-<br>
-gs/base/gximono.c
-<br>
-gs/base/gxpflat.c
-<br>
-gs/base/gxttfb.c
-<br>
-gs/base/ttfmain.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-10 20:11: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=d81dffe6142ead8245baacf12f3b2ae4fe20b206">d81dffe6142ead8245baacf12f3b2ae4fe20b206</a>
-<blockquote>
-<p>
- Squash warnings in MSVC build.
-<br>
-
-<br>
- All self evident, really. Lots of char's that should be bytes etc.
-<br>
-
-<br>
-gs/base/gdevclj.c
-<br>
-gs/base/gdevpdtw.c
-<br>
-gs/base/gdevtsep.c
-<br>
-gs/base/gp_wgetv.c
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gxicolor.c
-<br>
-gs/base/gxipixel.c
-<br>
-gs/base/sidscale.c
-<br>
-pcl/pcht.c
-<br>
-pcl/rtmisc.c
-<br>
-pl/plchar.c
-<br>
-pl/plfont.c
-<br>
-xps/xpspath.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-10 19:09:05 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d182ddaf5d46dc68d7f266fcb7f4de1ed64b7b56">d182ddaf5d46dc68d7f266fcb7f4de1ed64b7b56</a>
-<blockquote>
-<p>
- Replace all uses of 'template' with 'templat'.
-<br>
-
-<br>
- Using C++ reserved words is bad form, if only because they upset MSVC
-<br>
- when debugging.
-<br>
-
-<br>
-gs/base/gdevcfax.c
-<br>
-gs/base/gdevfax.c
-<br>
-gs/base/gdevjbig2.c
-<br>
-gs/base/gdevjpeg.c
-<br>
-gs/base/gdevjpx.c
-<br>
-gs/base/gdevpdfd.c
-<br>
-gs/base/gdevpdfi.c
-<br>
-gs/base/gdevpdfm.c
-<br>
-gs/base/gdevpdfo.c
-<br>
-gs/base/gdevpdfu.c
-<br>
-gs/base/gdevpdfv.c
-<br>
-gs/base/gdevpsdi.c
-<br>
-gs/base/gdevpsdp.c
-<br>
-gs/base/gdevpsds.c
-<br>
-gs/base/gdevpsdu.c
-<br>
-gs/base/gdevpsim.c
-<br>
-gs/base/genconf.c
-<br>
-gs/base/gsfunc4.c
-<br>
-gs/base/gsptype1.c
-<br>
-gs/base/gsptype2.c
-<br>
-gs/base/gsptype2.h
-<br>
-gs/base/gstrans.c
-<br>
-gs/base/gxclbits.c
-<br>
-gs/base/gxcllzw.c
-<br>
-gs/base/gxclmem.c
-<br>
-gs/base/gxclzlib.c
-<br>
-gs/base/gxcolor2.h
-<br>
-gs/base/gxidata.c
-<br>
-gs/base/gxiscale.c
-<br>
-gs/base/gxpcmap.c
-<br>
-gs/base/scommon.h
-<br>
-gs/base/sdct.h
-<br>
-gs/base/sdctd.c
-<br>
-gs/base/sdcte.c
-<br>
-gs/base/smd5.c
-<br>
-gs/base/spsdf.c
-<br>
-gs/base/ssha2.c
-<br>
-gs/base/stream.c
-<br>
-gs/psi/fapi_ft.c
-<br>
-gs/psi/ifilter.h
-<br>
-gs/psi/ifrpred.h
-<br>
-gs/psi/ifwpred.h
-<br>
-gs/psi/iscan.c
-<br>
-gs/psi/zfapi.c
-<br>
-gs/psi/zfdctd.c
-<br>
-gs/psi/zfdcte.c
-<br>
-gs/psi/zfdecode.c
-<br>
-gs/psi/zfile.c
-<br>
-gs/psi/zfilter.c
-<br>
-gs/psi/zfilter2.c
-<br>
-gs/psi/zfproc.c
-<br>
-gs/psi/zfrsd.c
-<br>
-gs/psi/zmisc1.c
-<br>
-gs/psi/zpcolor.c
-<br>
-gs/psi/zshade.c
-<br>
-pxl/pximage.c
-<br>
-pxl/pxink.c
-<br>
-xps/xpsjpeg.c
-<br>
-xps/xpstiff.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-10 11:08:56 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=108bf3d9fd2770c1b97a4eabcd4f09dd13c7fe18">108bf3d9fd2770c1b97a4eabcd4f09dd13c7fe18</a>
-<blockquote>
-<p>
- Fix several problems with the 16-bit PS output from gen_ordered.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/toolbin/halftone/gen_ordered/gen_ordered.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-10 10:35:57 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=73770f28c263a514a318aa91af24b26814062bd1">73770f28c263a514a318aa91af24b26814062bd1</a>
-<blockquote>
-<p>
- Change options and README for gen_ordered.c and fix 16-bit PS output.
-<br>
-
-<br>
- Also add check for missing value for an option (get_arg returning NULL) and add specific 'format' for
-<br>
- 16-bit .raw (raw16) (reserving the -b option for number of bits 1, 2, 4) for multi-level threshold
-<br>
- arrays.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/toolbin/halftone/gen_ordered/README
-<br>
-gs/toolbin/halftone/gen_ordered/gen_ordered.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-10 09:01:28 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cde0561c8ffc71c231a0aeff399852c43ab7a9e8">cde0561c8ffc71c231a0aeff399852c43ab7a9e8</a>
-<blockquote>
-<p>
- Move the ordered dither screen creation tool to toolbin/halftone/gen_ordered.
-<br>
-
-<br>
- Previously this was buried under the toolbin/color directory. Also by putting it into gen_ordered, we
-<br>
- prepare for the addition of gen_stochastic and threshold_remap tools related halftone tools. Michael
-<br>
- Vrhel as agreed with this change.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/toolbin/color/halftone/README
-<br>
-gs/toolbin/color/halftone/halfttoning.sln
-<br>
-gs/toolbin/color/halftone/halfttoning/halftone.c
-<br>
-gs/toolbin/color/halftone/halfttoning/halfttoning.vcproj
-<br>
-gs/toolbin/halftone/gen_ordered/README
-<br>
-gs/toolbin/halftone/gen_ordered/gen_ordered.c
-<br>
-gs/toolbin/halftone/gen_ordered/gen_ordered.sln
-<br>
-gs/toolbin/halftone/gen_ordered/gen_ordered.vcproj
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-31 18:39:24 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1da2a46ed9f6ae0b0afc5fd4417943a36e532171">1da2a46ed9f6ae0b0afc5fd4417943a36e532171</a>
-<blockquote>
-<p>
- More work on bug 690538: introduce macros for color rounding.
-<br>
-
-<br>
- Introduce new macros to gxcvalue.h header file that defines helpful macros
-<br>
- for colour depth changing.
-<br>
-
-<br>
- COLROUND macros do rounding (16-&gt;n bits), COLDUP macros do bit duplication
-<br>
- (n-&gt;16 bits). Use these macros in various places throughout the code.
-<br>
-
-<br>
- Also tweak the gx_color_value_to_byte macro to round in the same way.
-<br>
-
-<br>
- Colors for devices that use these functions are now rounded in the same way
-<br>
- that lcms does.
-<br>
-
-<br>
- Change as many encode_color routines as I can find to use this new code
-<br>
- rather than simply truncating.
-<br>
-
-<br>
-gs/base/gdevbit.c
-<br>
-gs/base/gdevcdj.c
-<br>
-gs/base/gdevdevn.c
-<br>
-gs/base/gdevdsp.c
-<br>
-gs/base/gdevperm.c
-<br>
-gs/base/gdevplan.c
-<br>
-gs/base/gdevplib.c
-<br>
-gs/base/gdevpsd.c
-<br>
-gs/base/gdevrinkj.c
-<br>
-gs/base/gdevtsep.c
-<br>
-gs/base/gdevxcf.c
-<br>
-gs/base/gxblend1.c
-<br>
-gs/base/gxcmap.c
-<br>
-gs/base/gxcvalue.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-09 17:46:06 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ccf3ba715990923281126bd9b300aa645d7a1d6">4ccf3ba715990923281126bd9b300aa645d7a1d6</a>
-<blockquote>
-<p>
- Squash some warnings produced in the last memento fix.
-<br>
-
-<br>
- giving me a warning on MSVC).
-<br>
-
-<br>
- Remove unused variable.
-<br>
-
-<br>
-gs/psi/zmisc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-09 16:29:24 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36e4f24d76e9f33bf5b531b8bd7d2c31ebee9153">36e4f24d76e9f33bf5b531b8bd7d2c31ebee9153</a>
-<blockquote>
-<p>
- Properly finalize the DCT-writing memory device to avoid memory leaks
-<br>
-
-<br>
- Bug #692670 &quot;Ghostscript uses 2 gigs of memory reading file&quot;. When writing
-<br>
- images a JPEG the pdfwrite code creates a memory device temporarily. It
-<br>
- was not, however, finalizing the device. Previously this did not cause a
-<br>
- problem, but with the ICC colour work, this left the ICC buffers set up,
-<br>
- causing a ~6Kb per image memory leak.
-<br>
-
-<br>
- This commit explicitly finalizes the device, which frees the memory and
-<br>
- gets rid of the leak.
-<br>
-
-<br>
- No differences expected
-<br>
-
-<br>
-gs/base/gdevpsdi.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-09 13:12:49 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=136065f0fcaa871376561a1c81c16c7d9b2bb3c7">136065f0fcaa871376561a1c81c16c7d9b2bb3c7</a>
-<blockquote>
-<p>
- Memento 'list blocks' tweaks.
-<br>
-
-<br>
- Make Memento_listBlocks() function non-static.
-<br>
-
-<br>
- Add new Memento_listNewBlocks() function.
-<br>
-
-<br>
- Add flags word to Memento block header, only 1 bit of which is used
-<br>
- curently (to indicate that a block is new since the last listNewBlocks
-<br>
- call).
-<br>
-
-<br>
- Add .mementolistnewblocks postscript operator.
-<br>
-
-<br>
- Add (commented out) code in gs_init.ps to call vmreclaim and then
-<br>
- .mementolistnewblocks at the end of each showpage. This allows
-<br>
- tracking of blocks that 'leak' during each page (where 'leak' doesn't
-<br>
- necessarily mean truly leak).
-<br>
-
-<br>
-gs/Resource/Init/gs_init.ps
-<br>
-gs/base/memento.c
-<br>
-gs/base/memento.h
-<br>
-gs/psi/zmisc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-08 08:25: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=138d68e2d7dd5567c7a24740ec71858e24342a1f">138d68e2d7dd5567c7a24740ec71858e24342a1f</a>
-<blockquote>
-<p>
- Fix type 1 font copying code SEAC scanner.
-<br>
-
-<br>
- When embedding type 1/CFF fotns the code scans the glyphs to see is any of
-<br>
- them are SEAC (Single Encoding Accented Characters) glyphs and expands
-<br>
- them if they are.
-<br>
-
-<br>
- The CFF parsing was skipping over the 'shotint' operator (itself an awful hack)
-<br>
- instead of pushing the value onto the stack. If the shortint was the index
-<br>
- for a /Subr this led to the wrong Subr being called. Because Subrs expect
-<br>
- parameters on the stack, calling the wrong one leads to stack cuorruption
-<br>
- and in this case caused a crash.
-<br>
-
-<br>
- No differences expected.
-<br>
-
-<br>
-gs/base/gxtype1.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-08 02:40:09 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3c5ba8fd910be3985212b104f2c111556db4b871">3c5ba8fd910be3985212b104f2c111556db4b871</a>
-<blockquote>
-<p>
- Bug 692648: dead code in gdevcp50.c
-<br>
-
-<br>
- Remove ineffective error checks after functiom calls. Real error
-<br>
- processing is done at the end of the function, when device is
-<br>
- closed. Found by Coverity.
-<br>
-
-<br>
-gs/base/gdevcp50.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-08 02:16:57 -0500
-</strong>
-<br>Tim Waugh &lt;twaugh@redhat.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5915259f6800b600fff1af9e4d40f5dddee8f477">5915259f6800b600fff1af9e4d40f5dddee8f477</a>
-<blockquote>
-<p>
- Bug 692649: dead code in gxi12bit.c and gxicolor.c
-<br>
-
-<br>
- The dead fragments are rudiments (rather than logic problems)
-<br>
- and so can be safely removed. Found by Coverity.
-<br>
-
-<br>
-gs/base/gxi12bit.c
-<br>
-gs/base/gxicolor.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-08 01:57:42 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=724390c14c6f52489d83df18f7cfcd6a4be7bced">724390c14c6f52489d83df18f7cfcd6a4be7bced</a>
-<blockquote>
-<p>
- Bug 692647: Mistaken comparison instead of assignment.
-<br>
-
-<br>
- Fix two obvious typos in a contributed Japanese driver.
-<br>
-
-<br>
-gs/contrib/japanese/gdevmjc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-08 01:33:49 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=595309e7b1883b985756510ee210bd3176a0da3a">595309e7b1883b985756510ee210bd3176a0da3a</a>
-<blockquote>
-<p>
- Bug 692598: bad sizeof() usage in gxfcopy.c
-<br>
-
-<br>
- Use the right type to calculate the size of an array of unsigned long.
-<br>
- Old code used sizeof(gs_glyph *) instead of sizeof(unsigned long).
-<br>
- Memory corruption was possible when sizeof(long) &gt; sizeof(void *).
-<br>
- The problem was found by Coverity.
-<br>
-
-<br>
-gs/base/gxfcopy.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-08 01:26:56 -0500
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a6124a3870a07ff19562559e6d155560d22c01d">4a6124a3870a07ff19562559e6d155560d22c01d</a>
-<blockquote>
-<p>
- Fix a typo s/elseif/elsif/ in clusterpush.pl
-<br>
-
-<br>
-gs/toolbin/localcluster/clusterpush.pl
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-07 10:53:09 -0700
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91ce46e08ae37a9c5116bc379b7712c10df5a8f2">91ce46e08ae37a9c5116bc379b7712c10df5a8f2</a>
-<blockquote>
-<p>
- Fix 692614 - the unsolid pattern should be used when the gl/2 white
-<br>
- pattern is specified. Also, progressions noted in PCL5 CET 32-01.
-<br>
-
-<br>
-pcl/pcpatrn.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-07 16:52:38 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a4230e24b386ac647b0562cb2bf34c25043a1903">a4230e24b386ac647b0562cb2bf34c25043a1903</a>
-<blockquote>
-<p>
- Change to clusterpush to allow filters.
-<br>
-
-<br>
- Change here (and throughout cluster code) to allow filtering of the jobs
-<br>
- to be scheduled.
-<br>
-
-<br>
- Rather than simply doing:
-<br>
-
-<br>
- clusterpush.pl gs
-<br>
-
-<br>
- you can now do:
-<br>
-
-<br>
- clusterpush.pl gs filter=ppmraw
-<br>
-
-<br>
- and have it only test the ppmraw files. Or you can specifiy a list
-<br>
- of filters that must all pass:
-<br>
-
-<br>
- clusterpush.pl xps filter=ppmraw,xpsfts-a4
-<br>
-
-<br>
- This will test the xpsfts-a4 files through the ppmraw device only.
-<br>
- Or you can specify several filters to broaden the scope:
-<br>
-
-<br>
- clusterpush.pl gs filter=ppmraw,72 filter=pgmraw,300
-<br>
-
-<br>
- And it will test ppmraw files at 72 dpi and pgmraw files at 300dpi.
-<br>
-
-<br>
- The filtering is done on the 'test' string formed by the cluster
-<br>
- code (that is, test__file__path.device.res.band)
-<br>
-
-<br>
-gs/toolbin/localcluster/clusterpush.pl
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-07 12:10:16 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ab54e1549793df22e0eddf43033494ea6ab0544b">ab54e1549793df22e0eddf43033494ea6ab0544b</a>
-<blockquote>
-<p>
- Fix for (part of) Bug 692513. (xps pattern white lines)
-<br>
-
-<br>
- XPS renders with the &quot;pixel centres covered&quot; rule, rather than the
-<br>
- &quot;any part of a pixel&quot; rule. As such fill_adjust is 0. This exposes
-<br>
- limitations in ghostscripts pattern tile handling code.
-<br>
-
-<br>
- When we come to create a pattern tile, if the pattern is (for instance)
-<br>
- 7.5x7.5 device pixels in size, we round this to the nearest integer
-<br>
- and end up with an 8x8 pattern tile. For PS/PDF (which has a non zero
-<br>
- fill_adjust) the pattern will still cause the entire range of pattern
-<br>
- pixels to be drawn.
-<br>
-
-<br>
- With XPS (and it's 0 fill_adjust) the patterns frequently leave gaps
-<br>
- around the edge of the enlarged tile, resulting in white lines in the
-<br>
- final image.
-<br>
-
-<br>
- My first attempt at a fix for this was to scale the pattern up by
-<br>
- the appropriate amount to ensure it filled the pattern tile (8/7.5
-<br>
- in the example). This works, but causes thousands of diffs; having
-<br>
- examined them all in a bmpcmp, it feels like a win, to me.
-<br>
-
-<br>
- However, consulting with Tor and Michael and checking the XPS spec
-<br>
- leads me to believe that that we shouldn't be using TilingType 1
-<br>
- anyway; xps patterns are supposed to be accurately positioned (if not
-<br>
- accurately rendered). As such we should be using TilingType 2.
-<br>
-
-<br>
- The patch here therefore forces XPS to use TilingType 2. This does not
-<br>
- solve the problem in itself, as we can still get these white lines.
-<br>
- Furthermore the definition of what TilingType 2 does in postscript
-<br>
- prohibits us from scaling the pattern cell.
-<br>
-
-<br>
- The solution adopted here, therefore, is to spot that we are using
-<br>
- TilingType 2, and a fill adjust of 0, and to translate the pattern
-<br>
- by half the change in size; this should ensure that 'edge to edge'
-<br>
- pattern cells should cover all the pixel centres appropriate and
-<br>
- the white lines should disappear.
-<br>
-
-<br>
- This appears to work except for one disappearing grid in Page 2 of
-<br>
- tests_private/xps/xpsfts-a4/fts_01xx.xps.ppmraw.72.0. I will look
-<br>
- into this before pushing this commit.
-<br>
-
-<br>
-gs/base/gscoord.c
-<br>
-gs/base/gscoord.h
-<br>
-gs/base/gsptype1.c
-<br>
-xps/xpstile.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-06 13:54:03 -0800
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=61074849e40ec86302e06bf0ef18f0872f8cf99a">61074849e40ec86302e06bf0ef18f0872f8cf99a</a>
-<blockquote>
-<p>
- Fix bug 692623. clist_get_data and clist_put_data changed to use int64_t offset.
-<br>
-
-<br>
- The above functions are used by gx_dc_pattern_read_raster and gx_dc_pattern_write_raster
-<br>
- which are instances of the dev_color_proc_read and dev_color_proc_write procs of the
-<br>
- gx_device_color_type_s struct. The definitions for all color types is changed to use
-<br>
- int64_t (as well as the prototype) and the stdint_.h is added to gxdcolor.h.
-<br>
-
-<br>
-gs/base/gsptype1.c
-<br>
-gs/base/gxcht.c
-<br>
-gs/base/gxclist.c
-<br>
-gs/base/gxclist.h
-<br>
-gs/base/gxdcolor.c
-<br>
-gs/base/gxdcolor.h
-<br>
-gs/base/gxht.c
-<br>
-gs/base/gxwts.c
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-07 13:28:56 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b9bcbb7d1ae61b2ccf5a6761a176ead71d327d27">b9bcbb7d1ae61b2ccf5a6761a176ead71d327d27</a>
-<blockquote>
-<p>
- Fix a couple of benign compiler warnings.
-<br>
-
-<br>
-gs/base/gdevpdtw.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-07 02:17:07 -0500
-</strong>
-<br>Tim Waugh &lt;twaugh@redhat.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1440326b1ef9a8aa539e9a2a6f8d0c32b1e879b">d1440326b1ef9a8aa539e9a2a6f8d0c32b1e879b</a>
-<blockquote>
-<p>
- Bug 692651: fix possible 0 dereference in error handler.
-<br>
-
-<br>
- At the end of gstate_alloc_parts(), gstate_free_parts() might be
-<br>
- called with parts-&gt;path == 0; but gx_path_free() will de-reference it.
-<br>
- Found using Coverity.
-<br>
-
-<br>
-gs/base/gsstate.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-07 10:48: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=c4e3f9c1d245e374eb30cc179e27bdcd2746812c">c4e3f9c1d245e374eb30cc179e27bdcd2746812c</a>
-<blockquote>
-<p>
- Bug 692661: setup dict and op stacks for executing a &quot;charproc&quot;
-<br>
-
-<br>
- When an (invalid!!) Type 1 font has a procedure instead of a charstring
-<br>
- we weren't setting up the stacks correctly in FAPI before executing the
-<br>
- proc.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/psi/zfapi.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-07 09:57:41 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=63a5fe390d2534f6b48e2dd58f46ed9941582e83">63a5fe390d2534f6b48e2dd58f46ed9941582e83</a>
-<blockquote>
-<p>
- pdfwrite - Improve font naming when standard fonts are not embedded.
-<br>
-
-<br>
- Bug #692608; When the input is PCL, 'standard' font names are used (eg Courier),
-<br>
- and font embedding is false, the output PDF file contains the names of the
-<br>
- URW fonts which are used as substittues for the standard fonts.
-<br>
-
-<br>
- This means that the resulting PDF needs to be read on a system with URW fonts
-<br>
- installed, or the fonts will be substituted, which may result in poor choices.
-<br>
-
-<br>
- By instead embedding the correct original (standard) font name we can get
-<br>
- better substitution.
-<br>
-
-<br>
- Thanks to Hin-Tak Leung for the original work and the patch which has been
-<br>
- adopted with slight modifications to pacify compilers.
-<br>
-
-<br>
- No diffreences expected.
-<br>
-
-<br>
-gs/base/gdevpdtb.c
-<br>
-gs/base/gdevpdtb.h
-<br>
-gs/base/gdevpdtd.c
-<br>
-gs/base/gdevpdtw.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-07 00:27:34 -0500
-</strong>
-<br>Tim Waugh &lt;twaugh@redhat.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=184e6fe81072d94489223ce4d4a9ba085843258c">184e6fe81072d94489223ce4d4a9ba085843258c</a>
-<blockquote>
-<p>
- Bug 692653: fix base pattern color space check.
-<br>
-
-<br>
- Old code tested an uninitialized value instead of the base color
-<br>
- space, found using Coverity.
-<br>
-
-<br>
-gs/base/gsptype1.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-06 10:59: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=850145bc08fd8ebcc4cc9c6827cde750d9ed9acf">850145bc08fd8ebcc4cc9c6827cde750d9ed9acf</a>
-<blockquote>
-<p>
- Bug 692470: remove sscanf() in CFF code
-<br>
-
-<br>
- On Linux (at least) the locale affects the behaviour of sscanf(): certain
-<br>
- languages use a comma (&quot;,&quot;) for the decimal point, rather than a full stop
-<br>
- (&quot;.&quot;). Setting one of those locales (such as Spanish) causes sscanf() to fail
-<br>
- when parsing a number with a fractional component in the CFF interpreter.
-<br>
-
-<br>
- Replace the sscanf() call in the CFF interpreter with a call to Ghostscript
-<br>
- PS interpreter's internal scan_number() function which is unaffected by locale.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/psi/zfont2.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-04 10:02: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=2a3a329ab0ee0e2f4971ee0327ae78d532399619">2a3a329ab0ee0e2f4971ee0327ae78d532399619</a>
-<blockquote>
-<p>
- Bug 692646: remove bad call to memcmp()
-<br>
-
-<br>
- The memcmp() to compare the matrices (to decide if we need to rescale the font)
-<br>
- was the address of the pointer to the matrix, rather than the pointer itself.
-<br>
-
-<br>
- This change addresses that by changing the memcmp() to an explicit check for
-<br>
- the equality of each element of the arrays. The reason I've opted for this is
-<br>
- because, for example, [1 -0 0 1 0 0] == [1 0 0 1 0 0] which an explicit
-<br>
- equality check will evaluate correctly, but a memcmp() will fail the check.
-<br>
-
-<br>
- This causes what seems to be a progression in comparefiles/Bug689006.pdf.
-<br>
- Other than that, no cluster differences are expected.
-<br>
-
-<br>
-gs/psi/zfapi.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-03 18:00: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=42146da35d49aa1debc683d7285fcd8cefc1f9f8">42146da35d49aa1debc683d7285fcd8cefc1f9f8</a>
-<blockquote>
-<p>
- Let configure check for time.h
-<br>
-
-<br>
- Recent Linux distributions defeat the check in unix-aux.mak for sys/time.h
-<br>
- with the hard coded path. So have configure check for it, and its
-<br>
- setting take precedence over the unix-aux.mak.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-config.mak.in
-<br>
-configure.ac
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-02 19:32:04 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d42d005f6adcb9e6911418a6b61c43df87fb7513">d42d005f6adcb9e6911418a6b61c43df87fb7513</a>
-<blockquote>
-<p>
- Fix for (part of) bug 692513.
-<br>
-
-<br>
- When drawing the a radial shading, we approximate the join between the
-<br>
- two circles by 4 tensor patches based on joining the 4 quadrants of
-<br>
- the circles in question. The order in which these were being drawn was
-<br>
- causing unexpected overwriting of pixels.
-<br>
-
-<br>
- Here I have rejigged the order in which they are drawn to solve the
-<br>
- problem.
-<br>
-
-<br>
- Cluster testing shows various progressions, and only one regression.
-<br>
- This has been noted as Bug 692657, and shows signs of it being an
-<br>
- independent bug.
-<br>
-
-<br>
-gs/base/gxshade1.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-02 19:34:50 +0000
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1bcd6274fbe15784fa0726f234b0608b994abbd7">1bcd6274fbe15784fa0726f234b0608b994abbd7</a>
-<blockquote>
-<p>
- Fix MEMENTO build; pacify valgrind code was in the wrong place.
-<br>
-
-<br>
- I'd added a memset to pacify valgrind, but had left it in the
-<br>
- middle of variable declarations; gcc was accepting this, but
-<br>
- MSVC was (rightly) complaining. Simple fix is to move it down.
-<br>
-
-<br>
- CLUSTER_UNTESTED as cluster does not test MEMENTO builds.
-<br>
-
-<br>
-gs/base/gxcht.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-03 11:11:27 +0000
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc592c4162673a99932cdcdc64b39e0abe5aff9e">cc592c4162673a99932cdcdc64b39e0abe5aff9e</a>
-<blockquote>
-<p>
- Further enhance txtwrite output; detect blocks of text.
-<br>
-
-<br>
- Yet another output mode for txtwrite will now attempt to detect blocks of
-<br>
- text and output the blocks. This is similar to the MuPDF '-ttt' output
-<br>
- but, since the algorithm is entirely different, the output will not be
-<br>
- identical.
-<br>
-
-<br>
- Updated the documentation in devices.htm.
-<br>
-
-<br>
- No differences expected, txtwrite is not regression tested.
-<br>
-
-<br>
-gs/base/gdevtxtw.c
-<br>
-gs/doc/Devices.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-11-02 15:10:25 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=65486b6c7533f0be9e15a8380729fdb5032e0bef">65486b6c7533f0be9e15a8380729fdb5032e0bef</a>
-<blockquote>
-<p>
- Fix for bug 692639. PDF14 mono device initialization.
-<br>
-
-<br>
- With the fix of the max_gray initialization in pdf14 device to avoid halftoning during interpolation of images (see description in 2b91a85069d421465220a83c82ea491733d15017)
-<br>
- a conflict occurred when checking if the device was separable and
-<br>
- linear. Setting of the dither_grays for the pdf14 gray device
-<br>
- fixes this issue.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-31 12:36: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=e4a9ab0594ccb8beb43c0bc83ba0b41deeb128ff">e4a9ab0594ccb8beb43c0bc83ba0b41deeb128ff</a>
-<blockquote>
-<p>
- Fix stroke_adjust logic; apply adjust in fewer cases.
-<br>
-
-<br>
- In 'adjust_stroke', we decide whether to apply stroke adjustment or not.
-<br>
- With the logic as it stands, the only time we DO NOT apply stroke
-<br>
- adjustment is when stroke adjustment is disabled, AND we have a diagonal
-<br>
- stroke segment.
-<br>
-
-<br>
- My understanding of stroke adjustment is that it is only supposed to
-<br>
- apply when we have a horizontal or vertical line, AND when it is
-<br>
- configured on. In line with this, I have changed the logic so that
-<br>
- we DO NOT apply stroke adjustment either when stroke adjustment is
-<br>
- disable, OR we have a diagonal stroke segment.
-<br>
-
-<br>
- This produces many thousands of differences in the cluster testing, but
-<br>
- having looked through the first bmpcmp load of them (1000 files), they
-<br>
- all look to be exactly as expected with no changes so horrific as to
-<br>
- stop this commit.
-<br>
-
-<br>
-gs/base/gxstroke.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-30 02:45:48 -0400
-</strong>
-<br>Tim Waugh &lt;twaugh@redhat.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=78727e97d82435052df2f8e0333e47671bafbc59">78727e97d82435052df2f8e0333e47671bafbc59</a>
-<blockquote>
-<p>
- Bug 692594: gdevijs: add missing error check.
-<br>
-
-<br>
- Add missing error check, found using Coverity.
-<br>
-
-<br>
-gs/base/gdevijs.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-30 00:20:30 -0400
-</strong>
-<br>Tim Waugh &lt;twaugh@redhat.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8adebdf0f6e87f36792637ff88db874ea86fd803">8adebdf0f6e87f36792637ff88db874ea86fd803</a>
-<blockquote>
-<p>
- Bug 692596: fix memory leaks in rinkj-epson870.c.
-<br>
-
-<br>
- There were a few memory leaks in rinkj-epson870.c in error handling
-<br>
- branches, found using Coverity.
-<br>
-
-<br>
-gs/base/rinkj/rinkj-epson870.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-29 23:46:28 -0400
-</strong>
-<br>Tim Waugh &lt;twaugh@redhat.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af01406940d211167c202cbc54c3ff7ad31d5c0e">af01406940d211167c202cbc54c3ff7ad31d5c0e</a>
-<blockquote>
-<p>
- Bug 692595: fix memory leaks in gp_unix_cache.c
-<br>
-
-<br>
- There were some memory leaks in gp_unix_cache.c, found using Coverity.
-<br>
-
-<br>
-gs/base/gp_unix_cache.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-29 20:03:40 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9c803e62759fd9d38c088aa8c24d71640ecfb51d">9c803e62759fd9d38c088aa8c24d71640ecfb51d</a>
-<blockquote>
-<p>
- Added a final return to --debug message.
-<br>
-
-<br>
-gs/base/gsmisc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-29 21:54:51 -0400
-</strong>
-<br>Tim Waugh &lt;twaugh@redhat.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=66567074a91d05a27f2439cbcc43e2d2301a776f">66567074a91d05a27f2439cbcc43e2d2301a776f</a>
-<blockquote>
-<p>
- Bug 692597: bad sizeof() usage in base/sdcparam.c
-<br>
-
-<br>
- Taking sizeof() of an array parameter gives the size of the pointer,
-<br>
- not the array; found using Coverity.
-<br>
-
-<br>
-gs/base/sdcparam.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-29 18:14:14 -0400
-</strong>
-<br>Tim Waugh &lt;twaugh@redhat.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4c00d4bc5eb87191674463af9444c457ac361c07">4c00d4bc5eb87191674463af9444c457ac361c07</a>
-<blockquote>
-<p>
- Bug 692599: fix bad sizeof() usage in base/sha2.c
-<br>
-
-<br>
- sizeof() was being used incorrectly in base/sha2.c,
-<br>
- found using Coverity.
-<br>
-
-<br>
-gs/base/sha2.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-29 14:09:56 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6116f7e9633c7c112c09c048b317de34c060ba5b">6116f7e9633c7c112c09c048b317de34c060ba5b</a>
-<blockquote>
-<p>
- Bug 692502: add missing dereference of an indirect object.
-<br>
-
-<br>
- Fix access to indirect /Names and /Nums objects in name and number
-<br>
- trees, respectively.
-<br>
-
-<br>
-gs/Resource/Init/pdf_base.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-29 16:47:58 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d8089a9dcf0971a1131f8391049c602a61852f65">d8089a9dcf0971a1131f8391049c602a61852f65</a>
-<blockquote>
-<p>
- Bug 692634: handle skipping &quot;cached&quot; outline glyphs
-<br>
-
-<br>
- Avoid trying to access a FAPI outline when glyph scaling has collapsed to zero.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/psi/zfapi.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-28 15:45:56 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=38e7372c539bcc6174c42be2d438d8311da2cff2">38e7372c539bcc6174c42be2d438d8311da2cff2</a>
-<blockquote>
-<p>
- Fix ppm color reversal in bmpcmp.
-<br>
-
-<br>
- When I did the recent speedups, I inadvertantly reversed the rgb order
-<br>
- when reading ppm files. Fixed here.
-<br>
-
-<br>
-gs/toolbin/bmpcmp.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-28 01:59:47 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6dc04dcacd37256f8d0c61cec49975ba67297873">6dc04dcacd37256f8d0c61cec49975ba67297873</a>
-<blockquote>
-<p>
- Bug 692590: Ignore self-referencing /SMask attribute.
-<br>
-
-<br>
- Check whether /SMask attribute points to its own dictionary and
-<br>
- ignore it when it does.
-<br>
-
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-19 13:26:44 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7b2b1f7f7989ab0106627f420e7a4848619355df">7b2b1f7f7989ab0106627f420e7a4848619355df</a>
-<blockquote>
-<p>
- Fix enhancement bug 692615: Create a platform specific hook to set the serialnumber
-<br>
-
-<br>
- The main change is to add the hook, but for common platforms, try to get a reasonably
-<br>
- unique serialnumber based on the hardware (we hope). Initial platform in this patch is
-<br>
- only Windows. We would like to support linux/unix and mac OS/X. If the mechanism fails,
-<br>
- just return gs_serialnumber set from GS_SERIALNUMBER in gscdefs.c
-<br>
-
-<br>
-gs/base/gp.h
-<br>
-gs/base/gp_dvx.c
-<br>
-gs/base/gp_mac.c
-<br>
-gs/base/gp_msdos.c
-<br>
-gs/base/gp_os2.c
-<br>
-gs/base/gp_unix.c
-<br>
-gs/base/gp_vms.c
-<br>
-gs/base/gp_wgetv.c
-<br>
-gs/psi/imain.c
-<br>
-gs/psi/zmisc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-22 23:51:42 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b91a85069d421465220a83c82ea491733d15017">2b91a85069d421465220a83c82ea491733d15017</a>
-<blockquote>
-<p>
- Fix for Bug 692505 XPS patterns with transparency.
-<br>
-
-<br>
- There were essentially three issues two in the xps interpreter and one in the graphics library.
-<br>
-
-<br>
- First in the xps interpreter we need to know if the pattern object has transparency and to
-<br>
- set up the pattern object for the graphics library so that the graphics library will
-<br>
- know to push the pdf14 device on the pattern accumulator object.
-<br>
-
-<br>
- We also had the issue that we were not undoing the pre-multiplied alpha in the tiff image
-<br>
- in the interpreter.
-<br>
-
-<br>
- Second issue is that in ghostscript, we call pattern_paint_finish from
-<br>
- the pdf interpreter when we are all done setting things up for the pattern. This is now
-<br>
- handled prior to the call before gx_pattern_cache_add_entry which is where it is done in
-<br>
- pattern_paint_finish.
-<br>
-
-<br>
- Also, some debugging of the mask stack was added in gdevp14.c. This was needed to track down
-<br>
- a bug that become visible when I added in the pattern transparency support. The issue
-<br>
- was that the parent PDF14 device may often have a valid soft mask in its mask stack if there
-<br>
- had been a previous soft mask push. Since we made the soft mask state be part of the q Q
-<br>
- operations in the PDF interpreter (the soft mask is actually part of the extended graphics state
-<br>
- in PDF), we have to make sure to pop the soft mask we we are all
-<br>
- done using it in the XPS interpreter. I added the appropriate commands for that.
-<br>
-
-<br>
- There was also an issue that cropped up with the pdf14 device and the interaction of the image
-<br>
- interpolation code. We always interpolate image in XPS and it turned out that if we had an
-<br>
- opacity mask pattern created with an image we installed a gray pdf14 device for the pattern.
-<br>
- The interpolation code was incorrectly using halftoning for the pdf14 gray device due to the
-<br>
- color info settings in that device.
-<br>
-
-<br>
- This commit results in many progressions in PDF and XPS (450 differences). In PDF, if the
-<br>
- target was a gray devices and the content had
-<br>
- interpolated images with transparency we see progressions due to the fact that we were improperly
-<br>
- halftoning the images when the trans device is a contone device. In XPS, several missing
-<br>
- figures now are visible and we correctly handle tiling with objects that have transparency.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gxpcmap.c
-<br>
-gs/base/lib.mak
-<br>
-xps/xpsgradient.c
-<br>
-xps/xpsimage.c
-<br>
-xps/xpsopacity.c
-<br>
-xps/xpstile.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-27 13:44:05 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=58722d520578050aad3d81c0f5fb477bc701a944">58722d520578050aad3d81c0f5fb477bc701a944</a>
-<blockquote>
-<p>
- Fix warning; initial_decode was declared to return an int rather than void.
-<br>
-
-<br>
- initial_decode never returns a value, neither does any caller check for
-<br>
- one. Change it to be void.
-<br>
-
-<br>
-gs/base/gxiscale.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-27 13:24:08 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f75ccf57f4d052652204f6508f4f9949d3448840">f75ccf57f4d052652204f6508f4f9949d3448840</a>
-<blockquote>
-<p>
- Correct direction of implication for gs_debug_flags.
-<br>
-
-<br>
- I had incorrectly implemented the implication table; a =&gt; A rather than
-<br>
- A =&gt; a. Corrected here.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/gdbflags.h
-<br>
-gs/base/gdebug.h
-<br>
-gs/base/gsmisc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-27 10:42:18 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=59b1c64adb147a209b6468a669146edf13973a4b">59b1c64adb147a209b6468a669146edf13973a4b</a>
-<blockquote>
-<p>
- Make txtwrite 'XML' output compatible with MuPDF output.
-<br>
-
-<br>
- The txtwrite device now outputs 'XML' (something like XML) in a compatible
-<br>
- fashion to the '-ttt' output from MuPDF. It does not yet attempt to create
-<br>
- blocks of text, it just outputs the data it received as it received it,
-<br>
- there is no ordering of the data whatsoever. The format is compatible with
-<br>
- the MuPDF format though.
-<br>
-
-<br>
- No differences expected, txtwrie is not cluster tested.
-<br>
-
-<br>
-gs/base/gdevtxtw.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-24 16:07:50 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=97e6cdad5061fe92d16aae87524fe985c8436796">97e6cdad5061fe92d16aae87524fe985c8436796</a>
-<blockquote>
-<p>
- Fix bug 692618. Crash and Object not in any chunk error and VMerror.
-<br>
-
-<br>
- Actually two problems showed up after the previous commit related to this bug. A crash
-<br>
- could occur (or cause &quot;Object not in any chunk&quot;) because the pdf14 device did not use
-<br>
- stable_memory for separation names. The second issue was a VMerror when the decision
-<br>
- for banded (clist) mode was flawed, because if the device supported separations the
-<br>
- estimates for transparency buffers was too small because the call to
-<br>
- gdev_prn_allocate_memory was sometimes called with new_width, hew_height = 0,0 which
-<br>
- expected the 0,0 to be ignored. The new_width and new_height are only used from
-<br>
- gdev_prn_reallocate_memory.
-<br>
-
-<br>
- The non-encodable pixel issue still remains.
-<br>
-
-<br>
-gs/base/gdevmem.c
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gdevprn.c
-<br>
-gs/base/gstrans.h
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-26 16:40: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=cf8815855af78ddc9d4d9bebafbb21bff603e71d">cf8815855af78ddc9d4d9bebafbb21bff603e71d</a>
-<blockquote>
-<p>
- Bug 692605: resolve FAPI/UFST matrix clash
-<br>
-
-<br>
- The Microtype fonts require a unit design grid, but many jobs assume that the
-<br>
- standard fonts set have a design grid of 1000x1000. For those two conflicting
-<br>
- requirements to be satisfied, the UFST integration layer has to compensate
-<br>
- for the scaling.
-<br>
-
-<br>
- As usual with the UFST code, that exposed a host of other problems, including
-<br>
- failing to produce a bitmap sometimes when one is require for the glyph cache
-<br>
- and failing to handle a glyph too big for UFST to image (i.e. fallback to an
-<br>
- outline) in some cases.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/Resource/Init/gs_fapi.ps
-<br>
-gs/psi/fapiufst.c
-<br>
-gs/psi/zfapi.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-25 20:30:29 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e8f10150dd2404757d648a1568c1002dd5310b4">8e8f10150dd2404757d648a1568c1002dd5310b4</a>
-<blockquote>
-<p>
- More gs_debug_flags fixes.
-<br>
-
-<br>
- Today, I am less than competent. Hopefully this will fix it.
-<br>
-
-<br>
- My previous attempt to move gs_debug_flags from header to c file was
-<br>
- thrwarted by my missing an 'extern' out.
-<br>
-
-<br>
- This now compiles on both linux and windows without warnings, I think.
-<br>
-
-<br>
-gs/base/gdebug.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-25 20:19:24 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5f56c0c13c92232c9f77b548476fa10f1aec28f">b5f56c0c13c92232c9f77b548476fa10f1aec28f</a>
-<blockquote>
-<p>
- Fix silly mistake in gs_debug_flags changes.
-<br>
-
-<br>
- I'd inadvertently caused the gs_debug_flags tables to be built in every
-<br>
- object that included gdebug.h.
-<br>
-
-<br>
- Move them into gsmisc.c.
-<br>
-
-<br>
-gs/base/gdebug.h
-<br>
-gs/base/gsmisc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-25 19:37: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=f1a8b636cc4fe9419b31ed21c62b6e8d40fa4f1e">f1a8b636cc4fe9419b31ed21c62b6e8d40fa4f1e</a>
-<blockquote>
-<p>
- Fix warning; remove static definition for non-existent function.
-<br>
-
-<br>
- I added, then removed a function, and left a static prototype in place
-<br>
- that was causing a warning. Remove that.
-<br>
-
-<br>
- CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/psi/imainarg.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-25 19:04:13 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=370a5fae98c76c76df84ad35f79ce849a7ecf015">370a5fae98c76c76df84ad35f79ce849a7ecf015</a>
-<blockquote>
-<p>
- Add 'implication' table for gs_debug operations.
-<br>
-
-<br>
- Previously setting an upper case debug flag would imply the lower case
-<br>
- equivalent. Now we extend (break) that system so that any flag can
-<br>
- imply any other flag (and indeed we can have a chain of implied flags).
-<br>
-
-<br>
- This frees up lots of uppercase flags for us to use.
-<br>
-
-<br>
-gs/base/gdbflags.h
-<br>
-gs/base/gdebug.h
-<br>
-gs/base/gsmisc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-25 16:27:57 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d644cdc4b16cb92a70af3fea16c40cd39bc700a6">d644cdc4b16cb92a70af3fea16c40cd39bc700a6</a>
-<blockquote>
-<p>
- Add new 'long form' debugging flags.
-<br>
-
-<br>
- Add a table of 'known' debugging flags to ghostscript (gdbflags.h). These
-<br>
- list all the currently defined -Z flags, together with 'long form' names
-<br>
- for them (i.e. --debug=tiling will do the same as -Zt).
-<br>
-
-<br>
- Add a new routine to list the known flags (and hook this up so that
-<br>
- --debug on the command line lists the flags).
-<br>
-
-<br>
- Add a new routine to parse a set of flags passed to --define= on the
-<br>
- command line (and hook that up).
-<br>
-
-<br>
- The code that does:
-<br>
-
-<br>
- if_debug6('c',...)
-<br>
-
-<br>
- all remains unchanged, but we now have the ability to add new flags,
-<br>
- and to do:
-<br>
-
-<br>
- if_debug6(gs_debug_flag_whatever, ...)
-<br>
-
-<br>
- in the same way. This frees us from the limitations of only having
-<br>
- a limited number of easily representable 'character' flags.
-<br>
-
-<br>
-gs/base/gdbflags.h
-<br>
-gs/base/gdebug.h
-<br>
-gs/base/gsmisc.c
-<br>
-gs/doc/Use.htm
-<br>
-gs/ghostscript.vcproj
-<br>
-gs/psi/imainarg.c
-<br>
-pl/plmain.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-17 21:12:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b7bcf1a9efdbcd8c0ebac2eeece8c81f61d18396">b7bcf1a9efdbcd8c0ebac2eeece8c81f61d18396</a>
-<blockquote>
-<p>
- Tiny whitespace fix.
-<br>
-
-<br>
- CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/base/gxicolor.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-25 08:28:31 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f9f50966fe6baecb1c9ebefa44594e7c21d9d194">f9f50966fe6baecb1c9ebefa44594e7c21d9d194</a>
-<blockquote>
-<p>
- Make common warning message only output when pcl font parsing
-<br>
- debugging is enabled (-Z=).
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-pl/plfont.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-25 10:05: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=cf7e75532e0f16c819954b71a686fb5b83c47c61">cf7e75532e0f16c819954b71a686fb5b83c47c61</a>
-<blockquote>
-<p>
- Add UTF-8 as an output option to the txtwrite device.
-<br>
-
-<br>
- The TextFormat parameter now has three values; 0, 1 or 2 to allow for 'XML'
-<br>
- output with full information, simple UCS2 or simple UTF-8 output.
-<br>
-
-<br>
- Altered the meanings of the TextFormat so that 0 is now the 'XML' output
-<br>
- which allows a more sensible selection of 1 for UCS2 or 2 for UTF-8, since
-<br>
- these output foramts are otherwise identical. Modified the default to be
-<br>
- '2' (UTF-8).
-<br>
-
-<br>
- Updated the documentation in devices.htm.
-<br>
-
-<br>
- Also removed a number of C++ comments.
-<br>
-
-<br>
- No differences expected, this device is not cluster tested.
-<br>
-
-<br>
-gs/base/gdevtxtw.c
-<br>
-gs/doc/Devices.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-24 16:48: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=b5fa52b7e60a7eb23b77c4fd117ed37eb04263b5">b5fa52b7e60a7eb23b77c4fd117ed37eb04263b5</a>
-<blockquote>
-<p>
- Bug #692621 Ensure that when copying width information, we create an array as large as the new MaxCID value
-<br>
-
-<br>
- Commit 312255297353a9f62b5090e9137586a8ecfc8601 create the new MaxCID entry
-<br>
- for CIDFont type 0 fonts which use a GlyphDirectory. We must use the same
-<br>
- value when creating the arrays to store the widths of the glyphs, or we will
-<br>
- no have a large enough array, leading to soem glyphs getting the Default Width.
-<br>
-
-<br>
- No differences expected
-<br>
-
-<br>
-gs/base/gdevpdtt.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-22 19:43:48 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=33e827eb32d282a550e2f7a9fdb786dd777b0903">33e827eb32d282a550e2f7a9fdb786dd777b0903</a>
-<blockquote>
-<p>
- Bug 692622: spurious warnings on Indexed colour spaces.
-<br>
-
-<br>
- Fix indexed color space processing code that miscalculated
-<br>
- the length of an index table when the table stream was compressed.
-<br>
-
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-20 22:11:00 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ebbcae24116a37b2f32f52bc7330383752f903f">7ebbcae24116a37b2f32f52bc7330383752f903f</a>
-<blockquote>
-<p>
- Fix bug 692618. Clear pointers to compressed color structured in pdf14 device.
-<br>
-
-<br>
- After the devn compressed color structures were freed, the pointers were not reset to
-<br>
- NULL so subsequent GC would trace into freed or re-used memory. -Z? showed errors and,
-<br>
- depending on memory contents and usage could result in a seg fault. Also add 'mem'
-<br>
- element to the compressed_color_list structure to be used when freeing to avoid
-<br>
- confusion about the correct allocator.
-<br>
-
-<br>
- Issue with non-encodable colors is _not_ fixed by this, only the segfault.
-<br>
-
-<br>
-gs/base/gdevdevn.c
-<br>
-gs/base/gdevdevn.h
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-21 23:27:50 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a298a05dcf4ce3f1f530759680a2f65c3e72e3fc">a298a05dcf4ce3f1f530759680a2f65c3e72e3fc</a>
-<blockquote>
-<p>
- Fix to handle tiff associated alpha images correctly in XPS
-<br>
-
-<br>
- TIFF images in XPS can come with an alpha channel that may or may
-<br>
- not be premultiplied. In our existing XPS flow, we currently store
-<br>
- the alpha channel in a separate channel and treat it as an image mask
-<br>
- in the graphics library. This is fine, but if the image data was
-<br>
- premultiplied by the alpha data, we will need to undo this operation
-<br>
- otherwise we end up applying the mask on image data that is already
-<br>
- scaled by the alpha data.
-<br>
-
-<br>
-xps/xpstiff.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-21 10:52: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=312255297353a9f62b5090e9137586a8ecfc8601">312255297353a9f62b5090e9137586a8ecfc8601</a>
-<blockquote>
-<p>
- Font copying does not work with CIDFonts using dictioanry form of GlyphDirectory
-<br>
-
-<br>
- Bug #692573, the font copying code uses 'slots' to record glyph data, which
-<br>
- are entries in an array. The index into the array can be a name or a CID.
-<br>
-
-<br>
- This assumes that CIDCount (the number of glyphs in the font) is the same as
-<br>
- the maximum CID (ie the range is continuous), which is generally true.
-<br>
- However, the dictionary form of GlyphDirectory allows for discontinuous CIDs.
-<br>
- This meant that the array was too small to use the CID as an index.
-<br>
-
-<br>
- Fixing this efficeintly would mean completely rewriting the code in gxfcopy.c
-<br>
- so that it uses some kind of dictionary structure instead of an array. Instead
-<br>
- I've chosen to find the highest CID in the font (by enumerating the GlyphDirectory)
-<br>
- and use that to create he array with enough entries. Inefficient use of memory
-<br>
- but it saves having to re-architect the code.
-<br>
-
-<br>
- The text that was previously missing is now present, and this reveals a new
-<br>
- problem, some of the text is incorrectly spaced after conversion with pdfwrite.
-<br>
- I'll open this as a new bug.
-<br>
-
-<br>
- No differences expected
-<br>
-
-<br>
-gs/base/gxfcid.h
-<br>
-gs/base/gxfcopy.c
-<br>
-gs/psi/zfcid.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-20 23:04:31 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=41faddadc03e389f4f1b3c3d9a4f6bdf36ebbfb1">41faddadc03e389f4f1b3c3d9a4f6bdf36ebbfb1</a>
-<blockquote>
-<p>
- Fix for bug 692511 Dash cap rendering in XPS
-<br>
-
-<br>
- There was an issue that we were setting both the end cap and the dash
-<br>
- caps to the starting cap value for the stroke when we went through
-<br>
- clist rendering. Page mode worked correctly. Clusterpush shows no
-<br>
- diffs with XPS rendering since all tests are done in Page mode.
-<br>
-
-<br>
-gs/base/gxclpath.c
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-19 23:27:30 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91dc74950f0a9ce391de0f0f1f0be5220a68db04">91dc74950f0a9ce391de0f0f1f0be5220a68db04</a>
-<blockquote>
-<p>
- Fix for Bug 692510 white space XPS interpreter fix
-<br>
-
-<br>
- XPS interpreter was not very robust in its handling of white space in
-<br>
- many locations. I created a general function to handle this in place
-<br>
- of the many uses of sscanf in the interpreter.
-<br>
-
-<br>
-xps/ghostxps.h
-<br>
-xps/xpsgradient.c
-<br>
-xps/xpspath.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-19 14:53:30 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=856eedc584a224bd311fa7688fc29ba487521dfb">856eedc584a224bd311fa7688fc29ba487521dfb</a>
-<blockquote>
-<p>
- Fix for Bug 692509. Issues with parsing of dashed line attributes.
-<br>
-
-<br>
- Problem was caused by a space preceding the ending quote, which gave
-<br>
- the dashed line lengths.
-<br>
-
-<br>
-xps/xpspath.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-19 10:29:18 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3d3e4f5d6e83539fc5a5877ef6d1e3591ec25c49">3d3e4f5d6e83539fc5a5877ef6d1e3591ec25c49</a>
-<blockquote>
-<p>
- Memento buld tweak; valgrind warnings quieted for temporary buffers.
-<br>
-
-<br>
- Temporary buffers are used in the planar device and the color halftoning.
-<br>
- These are uninitialised by default, which means that the last 'part byte'
-<br>
- transferred is thought of as being undefined in valgrind.
-<br>
-
-<br>
- In memento builds we memset them to 0 to avoid this.
-<br>
-
-<br>
- CLUSTER_UNTESTED as memento builds are not testing in the cluster.
-<br>
-
-<br>
-gs/base/gdevmpla.c
-<br>
-gs/base/gxcht.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-19 10:25:27 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=99f7cf83e2bef8b1d61126c065328f7f91ba1fce">99f7cf83e2bef8b1d61126c065328f7f91ba1fce</a>
-<blockquote>
-<p>
- Add some more excludes to the clusterpush.pl rsync.
-<br>
-
-<br>
- Specifically, avoid the memento, profiling and 64bit directories
-<br>
- as well as any .pngs.
-<br>
-
-<br>
- CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/toolbin/localcluster/clusterpush.pl
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-19 10:23:14 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bace25f82cd2d84d951a33eb5a9797435f50b836">bace25f82cd2d84d951a33eb5a9797435f50b836</a>
-<blockquote>
-<p>
- Remove rop_source member from gxp1fill.c
-<br>
-
-<br>
- When set, this member variable was only ever set to be the same as
-<br>
- the 'source' member variable, and then forced to be non-NULL.
-<br>
-
-<br>
- By doing this forcing at the last moment, we get exactly the same
-<br>
- behaviour with less confusing code.
-<br>
-
-<br>
- No differences shown during cluster testing.
-<br>
-
-<br>
-gs/base/gxp1fill.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-19 17:31: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=e383ccc9e7f56435a8f89cf65125ee1eb6a880e5">e383ccc9e7f56435a8f89cf65125ee1eb6a880e5</a>
-<blockquote>
-<p>
- Fix FAPI charpath handling.
-<br>
-
-<br>
- The way FAPI appended the segments of a charpath to the current path was
-<br>
- incorrect, and in extremely rare cases could cause an error (due to an
-<br>
- attempt to draw outside the established bounding box in the path
-<br>
- structure).
-<br>
-
-<br>
- ps3cet/11-20.PS now runs without a &quot;Font Renderer Plugin .... error&quot;
-<br>
-
-<br>
- Other than 11-20.PS, no cluster differences expected.
-<br>
-
-<br>
-gs/psi/zfapi.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-18 22:12:24 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=357009d7fc55166a6e8f9da539e1f785d05e9b6c">357009d7fc55166a6e8f9da539e1f785d05e9b6c</a>
-<blockquote>
-<p>
- Maintain 16bit precision in threshold array creation.
-<br>
-
-<br>
- Also add option to output either 8bit or 16bit data
-<br>
- including a type 16 halftone dictionary
-<br>
-
-<br>
-gs/toolbin/color/halftone/halfttoning/halftone.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-17 12:26:17 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d0f6ec0fc64eba04cc85693d16bc7158599578b">4d0f6ec0fc64eba04cc85693d16bc7158599578b</a>
-<blockquote>
-<p>
- Fix bug 691978: Ignore PS vmreclaim requests for GC. Only GC when vmthreshold exceeded.
-<br>
-
-<br>
- Some poorly designed PostScript creators make liberal use of '2 vmreclaim' which would
-<br>
- trigger a full GC (mark/scan/reloc) pass each time. The document with the bug did this
-<br>
- &gt; 10,000 times. Since the vmthreshold already triggers GC when the allocated amount
-<br>
- exceeds the threshold, we don't need to really do anything when a job requests GC.
-<br>
- Change &quot;internal&quot; (infrequent) interpreter uses to use '2 .vmreclaim'. Speeds up the
-<br>
- file from the bug by 79X !
-<br>
-
-<br>
- Also fix areas that didn't update i_ctx_p after running the interpreter (which may do
-<br>
- a GC) and a minor typo in gs.c noticed while scanning for all instances of this.
-<br>
-
-<br>
-gs/Resource/Init/gs_init.ps
-<br>
-gs/Resource/Init/gs_lev2.ps
-<br>
-gs/psi/gs.c
-<br>
-gs/psi/idisp.c
-<br>
-gs/psi/imain.c
-<br>
-psi/psitop.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-17 20:48:26 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bcfc1a94c76d84511cec09673e220b8bf15823e9">bcfc1a94c76d84511cec09673e220b8bf15823e9</a>
-<blockquote>
-<p>
- Make it possible to output turn on sequence for ordered dithered screens
-<br>
-
-<br>
- This enables us to use the linearize_threshold program that Ray wrote to apply a TRC
-<br>
- to our screen.
-<br>
-
-<br>
-gs/toolbin/color/halftone/halfttoning/halftone.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-17 15:57:50 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=253285f2a4cb681d601817185d6dba083d8b117e">253285f2a4cb681d601817185d6dba083d8b117e</a>
-<blockquote>
-<p>
- Addition of support for different vertical and horizontal resolution in ordered dithered screen creation.
-<br>
-
-<br>
- The support for this was already in place in the code. It was only was a matter of getting the parameters set.
-<br>
-
-<br>
-gs/toolbin/color/halftone/halfttoning/halftone.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-17 20:15:56 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=312a786bd935908c2c0c0cb428ae066b7f01a8e3">312a786bd935908c2c0c0cb428ae066b7f01a8e3</a>
-<blockquote>
-<p>
- Fix pxlasm.py on windows.
-<br>
-
-<br>
- pxlasm.py outputs to stdout. On windows stdout is not binary safe by
-<br>
- default. Fix it with a couple of lines cribbed from stackoverflow.
-<br>
-
-<br>
- I have now successfully used pxldis and pxlasm on windows.
-<br>
-
-<br>
-tools/pxlasm.py
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-17 11:08:18 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0f20243b7ec6ea8f6a9b7826ac8ca2e1cebbacda">0f20243b7ec6ea8f6a9b7826ac8ca2e1cebbacda</a>
-<blockquote>
-<p>
- Fix longstanding color halftone limitation.
-<br>
-
-<br>
- gx_dc_ht_colored_fill_rectangle in gxcht.c contains a long standing
-<br>
- limitation (bug/defect), in that when doing strip_copy_rop with
-<br>
- subrectangles, it fails to offset the source samples for each call.
-<br>
- This is noted in the form of a comment.
-<br>
-
-<br>
- This is fixed here.
-<br>
-
-<br>
- There appears to be an underlying bug in this code (or in the code it
-<br>
- calls) in that the 'optimisation' case (do it all in a single
-<br>
- tile, rather than subdividing) gives different results to the normal
-<br>
- (subdividing) case. See bug 692609.
-<br>
-
-<br>
- This can be shown with tests_private/pcl/pcl5cats/Subset/PWEP6SC1.BIN
-<br>
- at 300dpi with or without banding to the plank or pamcmyk4 device.
-<br>
-
-<br>
- The limitation that this patch fixes does NOT solve the problem - but
-<br>
- I fixed it in the hopes that it would. Committing the code here as it's
-<br>
- an improvement anyway.
-<br>
-
-<br>
-gs/base/gxcht.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-17 00:35:20 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=85e64010450ebafb453b4028356a6ccd20e440b8">85e64010450ebafb453b4028356a6ccd20e440b8</a>
-<blockquote>
-<p>
- Bug 692574: libjasper: creating temp failed due to buffer overflow.
-<br>
-
-<br>
- Increase the size of a temp file buffer to accomodate larger path names
-<br>
- needed for mkstemp (instead of tmpnam that was used originally).
-<br>
- Thanks to Henk Jan Priester for the patch.
-<br>
-
-<br>
-gs/jasper/src/libjasper/include/jasper/jas_stream.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-14 23:00:03 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e92d2916a189d19213d830956a2e02f7cfb6872">2e92d2916a189d19213d830956a2e02f7cfb6872</a>
-<blockquote>
-<p>
- Addition of dot shape specification in ordered dither screen threshold array creation.
-<br>
-
-<br>
- This provides a number of example dot shapes including, circles, diamonds, lines and
-<br>
- inverted circles. Also cleaned up the code a bit.
-<br>
-
-<br>
-gs/toolbin/color/halftone/halfttoning/halftone.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-14 19:17: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=9cbeac223ffa44dd6cac3954e1f420501d5f29ae">9cbeac223ffa44dd6cac3954e1f420501d5f29ae</a>
-<blockquote>
-<p>
- Silence a clang warning
-<br>
-
-<br>
-gs/base/gdevpdtt.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-14 17:07: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=7b498fc5e1d0532f60e70e244edfc58bbeb18a50">7b498fc5e1d0532f60e70e244edfc58bbeb18a50</a>
-<blockquote>
-<p>
- Fix planar device bug; tiles becoming corrupted on gc.
-<br>
-
-<br>
- The relocation code for memory devices had not been updated to cope
-<br>
- with planar stuff; as such only the first 'mdev-&gt;height' line pointers
-<br>
- were being updated. This was showing up in plank vs pamcmyk4 testing
-<br>
- as some planes of patterns being corrupted.
-<br>
-
-<br>
-gs/base/gdevmem.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-14 15:17:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=419d3f8f787d90a71623b27100972eca64d03cc1">419d3f8f787d90a71623b27100972eca64d03cc1</a>
-<blockquote>
-<p>
- Better preservation of PDF text rendering modes in pdfwrite.
-<br>
-
-<br>
- Bug #688267, #692243. The 'swapcolors' is now moved into pdfwrite, instead
-<br>
- of being performed in PostScript in the PDF interpreter. The 'spaced'
-<br>
- variants of show now perform simlar techniques to the 'pdfwrite' text rendering
-<br>
- routines, when teh device supports text rendering modes.
-<br>
-
-<br>
- Caveats: pdfwrite always emits text enclosed in gsave/grestore. Because of
-<br>
- this we cannot preserve any of the text rendering modes involoving clipping
-<br>
- as the grestore also restores the clip path! So we subtract 4 from the mode
-<br>
- and emit the text that way, then handle the clip separately.
-<br>
-
-<br>
- Because text_process doesn't expect to receive gs_error_Remap_Color errors
-<br>
- (which cause the interpreter to run Pattern PaintProcs usually) we can't
-<br>
- set the stroke colour during text processing (which is how it worked before).
-<br>
- Instead we set the colours during text_begin. We don't actually write the colours
-<br>
- to the PDF file at that point though, because that causes problems synchronising
-<br>
- graphics states. Instead we leave the emission of the colour unchanged, we
-<br>
- just evaluate the colours in text_begin.
-<br>
-
-<br>
- There is some weirdness in the PDF interpreter which I do not understand.
-<br>
- Most cases are surrounded by 'currentlinewidth exch.......setlinewidth'
-<br>
- which preserves the current line width in case we have to change it for
-<br>
- stroked text. In one case, however, this causes files to fail with an error.
-<br>
-
-<br>
- I have tried without success to unravel the PDF interpreter to figure out
-<br>
- what is going on. Since I can't work it out I have created a dictionary,
-<br>
- stored the linewidth in that, and then pulled it back out and restored at
-<br>
- the end. I did try wrapping a gsave/grestore round the operation (taking
-<br>
- care to preserve the modfified currentpoint) but that caused even more
-<br>
- problems. Again I have no idea why.
-<br>
-
-<br>
- I would like Alex to look into this so I'm leaving one of the bugs open
-<br>
- and re-assigning to him. Also he will probably want to reformat the code
-<br>
- I've added to the PDF interpreter.
-<br>
-
-<br>
-gs/Resource/Init/pdf_ops.ps
-<br>
-gs/base/gdevpdfb.h
-<br>
-gs/base/gdevpdfg.c
-<br>
-gs/base/gdevpdfx.h
-<br>
-gs/base/gdevpdte.c
-<br>
-gs/base/gdevpdts.c
-<br>
-gs/base/gdevpdts.h
-<br>
-gs/base/gdevpdtt.c
-<br>
-gs/base/gserrors.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-14 10:40: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=83d6f1c5d048d70e89c3e13ef11f87a28e414a7a">83d6f1c5d048d70e89c3e13ef11f87a28e414a7a</a>
-<blockquote>
-<p>
- Squash a couple of warning in the previous commit.
-<br>
-
-<br>
- No functional change.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/psi/fapi_ft.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-14 10:19: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=056c8a6dc2409db6ac06ead1fc1b58b277400b04">056c8a6dc2409db6ac06ead1fc1b58b277400b04</a>
-<blockquote>
-<p>
- Bug 692578: improve FAPI/FT handling of non-square resolutions
-<br>
-
-<br>
- The previous code only worked correctly for glyphs rotated by a multiple
-<br>
- of 90 degrees, any interim rotation would show a shearing effect.
-<br>
-
-<br>
- We'll now apply the &quot;non-squareness&quot; scaling in the matrix, rather in the
-<br>
- resution which we pass to Freetype. We have to do this because Freetype
-<br>
- treats the resolution as being in &quot;glyph space&quot;, which means it is &quot;incorrect&quot;
-<br>
- for any rotated/sheared glyph.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/psi/fapi_ft.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-12 22:16: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=b49fc2b7fbd16c81a3480660d27d36ebe94ab6d2">b49fc2b7fbd16c81a3480660d27d36ebe94ab6d2</a>
-<blockquote>
-<p>
- Fix Bug 692584. Fix wrong sprintf format specifier types. Thanks to Arthur Ford.
-<br>
-
-<br>
-gs/base/gdevtxtw.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-11 16:08:00 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c5cc5db0746981baaad4c07cca370541254e03be">c5cc5db0746981baaad4c07cca370541254e03be</a>
-<blockquote>
-<p>
- Fix PDFFitPage when PDF orientation doesn't match page orientation.
-<br>
-
-<br>
- There was logic to determine if the pdf Box (after /Rotate is applied) orientation
-<br>
- matches the orientation of the PageSize (landscape vs. portrait), but the rotation to
-<br>
- make the image match the Page orientation was missing. Previously this caused the
-<br>
- scaling to be wrong and caused the image to be clipped. Adding the 90 degree rotate
-<br>
- fixes it. Feature needed by customer 531.
-<br>
-
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-12 20:15:51 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6accc37afd5d124c1feaea6481a771f2d1e6662">c6accc37afd5d124c1feaea6481a771f2d1e6662</a>
-<blockquote>
-<p>
- Solve more plank rop problems with the clist.
-<br>
-
-<br>
- In the planar memory device, protect against C's broken %. As we don't
-<br>
- replicate the textures, ensure we only set the size for a single repetition.
-<br>
-
-<br>
- When placing new tiles into the clist, ensure we calculate the number of
-<br>
- bytes used correctly (previously reuse of tile n would fail as tile n+1
-<br>
- would have overwritten its data).
-<br>
-
-<br>
-gs/base/gdevmpla.c
-<br>
-gs/base/gxclbits.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-12 17:22: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=0d472d36958ba10ce3e5747f91776ad2d53530c7">0d472d36958ba10ce3e5747f91776ad2d53530c7</a>
-<blockquote>
-<p>
- Bug 692534: revert to unit matrix for Microtype fonts.
-<br>
-
-<br>
- I changed the MT fonts to use a &quot;conventional&quot; Type 1 font matrix to
-<br>
- make a Quality Logic file &quot;work&quot; as expected - it's a daft test which
-<br>
- makes the invalid assumption that the fonts in the standard font set
-<br>
- will *always* use a 1000x1000 design matrix. That assumption is invalid
-<br>
- since nothing in the spec dictates that the standard fonts must be Type 1
-<br>
- (clearly as in this case we're using MT fonts!), nor even that Type 1
-<br>
- fonts have to use a 1000x1000 font matrix.
-<br>
-
-<br>
- As the change breaks a valid file, to try to satisfy a file which relies
-<br>
- on an invalid assumption, I'm reverting it.
-<br>
-
-<br>
- CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/Resource/Init/gs_fapi.ps
-<br>
-gs/psi/fapiufst.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-12 16:59:24 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1a9f315d20871be0498bd7a1fc94cbd2a47ebc4f">1a9f315d20871be0498bd7a1fc94cbd2a47ebc4f</a>
-<blockquote>
-<p>
- Bug 692550: address scanline alignment in halftone
-<br>
-
-<br>
- Apply Ghostscript's usual raster memory alignment to interim
-<br>
- bitmap memory for the threshold halftone code. This ensures
-<br>
- scanlines are correctly aligned for mem_mono_copy_mono(), and
-<br>
- prevents a bus error on SPARC.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/base/gxht_thresh.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-12 16:23:45 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6ed8f824fc3ca41ba0296131646d10e29657bda">f6ed8f824fc3ca41ba0296131646d10e29657bda</a>
-<blockquote>
-<p>
- Fix more plank rop problems (shown in plank vs pamcmyk4 testing)
-<br>
-
-<br>
- I'd missed one case where we are writing a texture bitmap to the clist,
-<br>
- so we were only writing the first plane.
-<br>
-
-<br>
- I'd also missed a case when reading bits back from the clist (showed
-<br>
- up with 1x1 textures).
-<br>
-
-<br>
-gs/base/gxclbits.c
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-12 13:36:22 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d670fb3473fbb455881125086f649e416ea755fe">d670fb3473fbb455881125086f649e416ea755fe</a>
-<blockquote>
-<p>
- Bug 689450: deal with invalid font entry in res dict.
-<br>
-
-<br>
- In the event that an entry in a resource dictionary for a font is or
-<br>
- references an invalid object type (i.e. not a dictionary), issue a
-<br>
- warning and use the same logic as we do for a missing font resource.
-<br>
-
-<br>
- For this error, we'll also honor the PDFSTOPONERROR setting.
-<br>
-
-<br>
- In addition, as I was touching the logic around the same place, this
-<br>
- commit changes the missing font resource case to also honor PDFSTOPONERROR.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/Resource/Init/pdf_font.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-12 00:58:50 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=237f8f0204a7e11db79fa60ec21503cfd0953116">237f8f0204a7e11db79fa60ec21503cfd0953116</a>
-<blockquote>
-<p>
- Remove duplicated line from gxicolor.c
-<br>
-
-<br>
- In my previous commit I inadvertantly duplicated a line. Fixed here.
-<br>
- No ill effects, but removing for neatness.
-<br>
-
-<br>
-gs/base/gxicolor.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-11 22:07:39 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fc7bfc56e9132ade936d92e397cc8820bb8a8115">fc7bfc56e9132ade936d92e397cc8820bb8a8115</a>
-<blockquote>
-<p>
- Fix uninitialised 'num_planes' in texture for strip_copy_rop call.
-<br>
-
-<br>
- Was causing some differences in plank vs pamcmyk4 testing.
-<br>
-
-<br>
-gs/base/gxcht.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-11 10:02: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=e96836194b0eb6085f59d41feb445d60f946dda9">e96836194b0eb6085f59d41feb445d60f946dda9</a>
-<blockquote>
-<p>
- Fix of bugs in halftone ordered screen creation code
-<br>
-
-<br>
- This fixes several bugs. Including fixes for issues with modulo operation on negative numbers,
-<br>
- integer division, faulty logic that prevented maximum lpi screens and non-dithered ordered screens.
-<br>
-
-<br>
-gs/toolbin/color/halftone/halfttoning/halftone.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-11 17:36:48 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fecf36b333ddac3e469512be536a498382741003">fecf36b333ddac3e469512be536a498382741003</a>
-<blockquote>
-<p>
- Fix Bug 692569; SEGV in threshold halftoning code.
-<br>
-
-<br>
- penum-&gt;xci can be negative in clist rendering of landscape cases.
-<br>
- The % operator in C is broken (or at least counter-intuitive) so
-<br>
- the code goes wrong; fix it up with some tweaks to the logic
-<br>
- afterwards.
-<br>
-
-<br>
- In a future commit, we'll move from % 16 to &amp; 15 (does the right thing,
-<br>
- and is a lot faster).
-<br>
-
-<br>
- No differences expected.
-<br>
-
-<br>
-gs/base/gxicolor.c
-<br>
-gs/base/gximono.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-10 11:42:29 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ce12e824d7e4cb5e54f8ba730cbf6939d20834e">5ce12e824d7e4cb5e54f8ba730cbf6939d20834e</a>
-<blockquote>
-<p>
- Fix Bug 692224: Handle transparent background with custom fillpage in pngalpha
-<br>
-
-<br>
- The previous hack looked for the entire page being filled with white and then filled
-<br>
- with transparent (0xffffffff). With a pngalpha_fillpage we simply fill with that color
-<br>
- which actually allows the page to be filled with non-transparent white if desired.
-<br>
- Remove the pngalpha_fill_rectangle hack.
-<br>
-
-<br>
-gs/base/gdevpng.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-09 01:10:38 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f790680acba5c1574728d5ff40124f9e27762d2a">f790680acba5c1574728d5ff40124f9e27762d2a</a>
-<blockquote>
-<p>
- Bug 692571: Fix ouf-of-buffer access in Luratech jb2 interface.
-<br>
-
-<br>
- Luratech jb2 library can requiet data outside of the input buffer
-<br>
- if it is fed a corrupted data stream. The old code tried to detect
-<br>
- this but failed because of the missed signed-to-unsighed promotion.
-<br>
-
-<br>
-gs/base/sjbig2_luratech.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-07 21:36: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=c760cef454473970972260b5b1c7ab078711e43d">c760cef454473970972260b5b1c7ab078711e43d</a>
-<blockquote>
-<p>
- Resolve more plank/pamcmyk4 differences (banding).
-<br>
-
-<br>
- When coding planar data into the clist, I'd missed the 'short' case,
-<br>
- and so only the first plane was being coded; this was causing knock
-<br>
- on effects of rectangles being wrong giving large blocks of color
-<br>
- in the output.
-<br>
-
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-07 12:49: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=62166be1e0beaa765daf96b77a8e6b1ee99a9b52">62166be1e0beaa765daf96b77a8e6b1ee99a9b52</a>
-<blockquote>
-<p>
- Remove the 'return' from the macro gx_set_dev_color
-<br>
-
-<br>
- Macros shouldn't do a return, its highly surprising to a developer. In addition
-<br>
- I need access to the return value for pdfwrite, and potentially other
-<br>
- devices may do so as well. In this case the return value is Remap_color
-<br>
- which happens when a Pattern is set.
-<br>
-
-<br>
- No differences expected in regression tests.
-<br>
-
-<br>
-gs/base/gsdps1.c
-<br>
-gs/base/gsimage.c
-<br>
-gs/base/gspaint.c
-<br>
-gs/base/gstext.c
-<br>
-gs/base/gxccache.c
-<br>
-gs/base/gxdcolor.h
-<br>
-pl/plchar.c
-<br>
-pl/pldraw.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-06 07:24:57 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1225753bd332857b02e546d20bc35d821fd20f58">1225753bd332857b02e546d20bc35d821fd20f58</a>
-<blockquote>
-<p>
- Improve PDFFitPage to center the PDF Box on the page.
-<br>
-
-<br>
- This was requested by customer 531 and seems reasonable. We didn't document exactly
-<br>
- where the PDF was placed on the page after 'fitting', so centering seems like an
-<br>
- acceptable behavior, so I didn't add a command line option to lower/left position.
-<br>
- If we get any complaints, we can add this.
-<br>
-
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-05 11:30: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=d5f1e72357d77dbb03abe0442ac8b8b09d27ceb6">d5f1e72357d77dbb03abe0442ac8b8b09d27ceb6</a>
-<blockquote>
-<p>
- Fix bug 692568. Set up initial clist_color_info to match pdf14 device.
-<br>
-
-<br>
- For the funky RGBW device, since it is 4 component additive color the pdf14 logic chose
-<br>
- a pdf14_clist_RGB_device which has 3 components and a depth of 24. The clist logic uses
-<br>
- the clist_color_info.depth which was never set correctly to match the pdf14 device (depth
-<br>
- = 24), so it wrote 32-bits and only read 24, causing the clist reader to bomb.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-04 10:30:56 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49e6b0c7144a4a694271e2f24edf03b16ecc14e1">49e6b0c7144a4a694271e2f24edf03b16ecc14e1</a>
-<blockquote>
-<p>
- Require CUPS_DEBUG2 to enable noisy gdevcups messages instead of just DEBUG
-<br>
-
-<br>
- Using a DEBUG build with the cups device was extremely slow and painful for complex
-<br>
- files. This is easy to enable via build -DCUPS_DEBUG2 or uncommenting the #define
-<br>
- in gdevcups.c
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-03 19:51:15 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=77e2fb25375f50389bfe6942507a0a513fa83ee9">77e2fb25375f50389bfe6942507a0a513fa83ee9</a>
-<blockquote>
-<p>
- Fix for Bug 692507
-<br>
-
-<br>
- The image interpolation code did not make use of the proper unpacking
-<br>
- routine when the data was 16bit and we were using the faster ICC
-<br>
- based renderer, which avoided the conversion to the frac type.
-<br>
-
-<br>
-gs/base/gxino16b.c
-<br>
-gs/base/gxiscale.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-03 17:15:53 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e776cc41b9da0a535adde126464d6af906b082ae">e776cc41b9da0a535adde126464d6af906b082ae</a>
-<blockquote>
-<p>
- Fix for Bug 692553; SEGV in fast thresholding halftoning code.
-<br>
-
-<br>
- Stupid C got the % operation wrong.
-<br>
-
-<br>
- In this instance, it gives an unexpected negative value causing out of
-<br>
- bounds offsets. Simple fix is to offset by the period if it's negative.
-<br>
-
-<br>
-gs/base/gxht_thresh.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-29 19:07:44 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3420c5c029771eee268d049fe9b6869221b18d48">3420c5c029771eee268d049fe9b6869221b18d48</a>
-<blockquote>
-<p>
- Add num_planes to gx_strip_bitmap for planar devices.
-<br>
-
-<br>
- Here we alter all existing uses (that I can find) to set num_planes
-<br>
- as appropriate.
-<br>
-
-<br>
- We update the clist code to encode/decode the new num_planes field. In
-<br>
- order to fit the extra bit required to signal that this is present into
-<br>
- the encoding byte we optimise the representation of depth down to 4 bits
-<br>
- from 5.
-<br>
-
-<br>
- We remove the lop_t_is_planar hack as we now have a cleaner scheme for
-<br>
- signalling it.
-<br>
-
-<br>
- This should hopefully remove the last differences between pamcmyk4 and
-<br>
- plank.
-<br>
-
-<br>
-gs/base/gdevdbit.c
-<br>
-gs/base/gdevdrop.c
-<br>
-gs/base/gdevmpla.c
-<br>
-gs/base/gdevmr2n.c
-<br>
-gs/base/gsptype1.c
-<br>
-gs/base/gsropt.h
-<br>
-gs/base/gxbitmap.h
-<br>
-gs/base/gxcht.c
-<br>
-gs/base/gxclbits.c
-<br>
-gs/base/gxcldev.h
-<br>
-gs/base/gxclimag.c
-<br>
-gs/base/gxclist.h
-<br>
-gs/base/gxclrast.c
-<br>
-gs/base/gxht.c
-<br>
-gs/base/gximage3.c
-<br>
-gs/base/gxp1fill.c
-<br>
-gs/base/gxpcmap.c
-<br>
-gs/doc/Drivers.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-10-02 22:26:58 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8e6d888502506e061241f2cdeb7c3f76d4dfb04f">8e6d888502506e061241f2cdeb7c3f76d4dfb04f</a>
-<blockquote>
-<p>
- Bug 692560: read objects with invalid obj# as nulls.
-<br>
-
-<br>
- According to PDF spec, objects with invalid object numbers should
-<br>
- be considered null objects. GS finally implements this.
-<br>
-
-<br>
-gs/Resource/Init/pdf_base.ps
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-30 12:46:53 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3380bef5e77ddfaa8aab496a4da13fd297480bd1">3380bef5e77ddfaa8aab496a4da13fd297480bd1</a>
-<blockquote>
-<p>
- Fix for bug 692558
-<br>
-
-<br>
- Issue was that the pdf14 device profile was getting set from an ICC profile that
-<br>
- was contained in the source profile for the transparency group. This needs to
-<br>
- be detected when we are getting the device parameters.
-<br>
-
-<br>
-gs/base/gsdparam.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-30 17:52:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b39b7cbfcf8719b9f41153ccf6172fbf8f800642">b39b7cbfcf8719b9f41153ccf6172fbf8f800642</a>
-<blockquote>
-<p>
- Some tweaks to allow &quot;make so&quot; to build in Mac OSX.
-<br>
-
-<br>
- The change still results in a &quot;.so&quot; object file, rather than usual Mac
-<br>
- &quot;.dylib&quot; file, but other than the name, they are internally identical.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/configure.ac
-<br>
-gs/base/unix-dll.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-30 16:00: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=b295fcef1b5a32e299f50f99248ae05099bd757d">b295fcef1b5a32e299f50f99248ae05099bd757d</a>
-<blockquote>
-<p>
- Remove the option to build with an external LCMS
-<br>
-
-<br>
- Given the extent which our bundled LittleCMS has diverged from the
-<br>
- official release, remove the capability to build with another, at least
-<br>
- until there is an lcms release incorprating the fixes we require.
-<br>
-
-<br>
- No cluster differences
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-30 10:30: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=54ee17d027c6be432a742ca5d313a56ac317361f">54ee17d027c6be432a742ca5d313a56ac317361f</a>
-<blockquote>
-<p>
- Bug 692561: fix handling of tr 3 in setshowstate
-<br>
-
-<br>
- In setshowstate we have to work around buggy PDFs in a manner which
-<br>
- means we &quot;show&quot; the text in question, but then rely on a charpath
-<br>
- operation to update the current point accurately. The problem was
-<br>
- that the currentpoint had already been updated by the show operation.
-<br>
-
-<br>
- This change ensures we return the currentpoint to the correct position
-<br>
- before doing to charpath to get the accurate text advance.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/Resource/Init/pdf_ops.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-29 15:45:04 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=63f2476edccc4860312737b61e86c929c340cb72">63f2476edccc4860312737b61e86c929c340cb72</a>
-<blockquote>
-<p>
- Bug 692557: Tolerate null XObjects
-<br>
-
-<br>
- Check for null XObjects during PDF resource enumeration and
-<br>
- ignore them. Since null objects can appear anywhere in PDF file,
-<br>
- the sample file was OK, but GS didn't handle this case before.
-<br>
-
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-28 20:44:53 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=03b20ec31afa843d5a4bac878568f60abcdea5fc">03b20ec31afa843d5a4bac878568f60abcdea5fc</a>
-<blockquote>
-<p>
- Fix for Bug 692494 and Bug 692433. Overprint issues.
-<br>
-
-<br>
- The fix for bug 692494 involved making sure that we use the original floating point values in
-<br>
- determining if we have a nonzero component so that overprint mode occurs properly
-<br>
- for very small values. Thanks to Ken and Ray for the initial analysis on this bug.
-<br>
-
-<br>
- A study of 692433 revealed that AR does not do overprint simulation when the source
-<br>
- ICC profile does not match the destination profile. To test this, I created a
-<br>
- test file that had 2 overlapping fills with CMYK values that were specified by
-<br>
- SWOP CMYK values. If the simulation profile in AR matched this profile, then overprinting
-<br>
- was properly displayed by AR. If not, then overprinting was not displayed. This
-<br>
- makes sense as the overprinted inks really should be in the color space for the
-<br>
- target device. Hence, if the source and destination profiles do not match we will
-<br>
- not be showing overprint This test file is called overprint_icc.pdf and will be added to
-<br>
- our test files.
-<br>
-
-<br>
-gs/base/gscspace.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-29 16:15: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=86bd5228ef5f88b747dd228a4b90938d3c9defa5">86bd5228ef5f88b747dd228a4b90938d3c9defa5</a>
-<blockquote>
-<p>
- Speed optimisations to bmpcmp
-<br>
-
-<br>
- pam/pnm/pgm reading was using repeated fgetc calls. Change it here to
-<br>
- use fread and then shuffle the buffer around.
-<br>
-
-<br>
-gs/toolbin/bmpcmp.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-29 16:03: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=9b60dc77805746ca685e272abe9b3f056320d612">9b60dc77805746ca685e272abe9b3f056320d612</a>
-<blockquote>
-<p>
- Partial fix for planar device pattern rop problems.
-<br>
-
-<br>
- plank vs pamcmyk4 tests have revealed various files still rendering wrongly
-<br>
- in plank format. These are to do with a halftone being rendered as a pattern
-<br>
- and then used as part of a rop.
-<br>
-
-<br>
- Specifically, if the 'rop source' device is used, then it is fed a pattern
-<br>
- tile that is in planar format. When this calls strip_copy_rop, the pattern
-<br>
- tiles data is used as the 'T' field; strip_copy_rop assumes that both T
-<br>
- and S are always in chunky format, and so garbage is read for the T plane.
-<br>
-
-<br>
- The fix, implemented here, is to spot that the pattern tile is planar, and
-<br>
- to set a new bit (lop_t_is_planar) in the lop to indicate this fact. The
-<br>
- planar device can then catch this bit and can handle it.
-<br>
-
-<br>
- Currently, this is implemented by doing a planar_to_chunky operation into
-<br>
- a temporary buffer, performing the strip_copy_rop, and then freeing the
-<br>
- buffer. Later we may well implement cores that can cope with the common
-<br>
- cases with T being still in planar form.
-<br>
-
-<br>
- This commit only fixes unbanded operation; currently when the clist writer
-<br>
- puts the tile into the clist, it has no way of indicating that the tile
-<br>
- is in planar format, hence only writes 1/4 of the data. I need to talk to
-<br>
- Ray and Michael about this. This is broken already, so this commit shouldn't
-<br>
- make anything worse.
-<br>
-
-<br>
- I have updated the docs (out of date since 1998, at least) in related areas,
-<br>
- and fixed some broken english.
-<br>
-
-<br>
-gs/base/gdevdrop.c
-<br>
-gs/base/gdevmpla.c
-<br>
-gs/base/gsropt.h
-<br>
-gs/base/gxcht.c
-<br>
-gs/base/gxp1fill.c
-<br>
-gs/doc/Drivers.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-29 14:35: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=d4741818da0a3f9a5a7ab98c328795dde6f850cb">d4741818da0a3f9a5a7ab98c328795dde6f850cb</a>
-<blockquote>
-<p>
- Add Memento targets to unix/autoconf makefiles.
-<br>
-
-<br>
- Add new targets to unix makefiles (pcl-memento, xps-memento etc) that
-<br>
- build executables into memobj. Parallels the work done with the windows
-<br>
- builds.
-<br>
-
-<br>
-Makefile
-<br>
-common/ugcc_top.mak
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/macosx.mak
-<br>
-gs/base/ugcclib.mak
-<br>
-gs/base/unix-end.mak
-<br>
-gs/base/unix-gcc.mak
-<br>
-gs/base/unixansi.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-18 17:01:43 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fe8d7b6aebfed3c724a860e31ff170764d5429dc">fe8d7b6aebfed3c724a860e31ff170764d5429dc</a>
-<blockquote>
-<p>
- Fix bug 692372: Add finalize for imager_state to ref_count decrement icc structs.
-<br>
-
-<br>
- The graphics atates were being freed by the 'alloc_restore_all' done during gs_lib_finit
-<br>
- but the icc_link_cache was not getting its ref_count decremented, so it never freed the
-<br>
- semaphore which caused handles to be lost by windows. The rc_gsicc_profile_cache_free
-<br>
- function is also fixed to save the 'next' pointer to avoid dereferencing freed memory.
-<br>
-
-<br>
- Note that we _should_ be able to call gs_imager_state_release to decrement the counts
-<br>
- of ALL of the elements, but the ref counting of the other elements is _so_ badly
-<br>
- maintained that some elements (dev_ht and halftone) are prematurely freed by this.
-<br>
- This change is enough to fix the bug and pass cluster regression.
-<br>
-
-<br>
-gs/base/gsicc_profilecache.c
-<br>
-gs/base/gsistate.c
-<br>
-gs/base/gsstate.c
-<br>
-gs/base/gxistate.h
-<br>
-gs/base/gzstate.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-28 09:33:31 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=02bdba18be7f2b78ca03d3f4126cef830eab28eb">02bdba18be7f2b78ca03d3f4126cef830eab28eb</a>
-<blockquote>
-<p>
- Fixes 692544, an &quot;off by one&quot; error in the parser caused a pcl data
-<br>
- scanning command at the end of a stream to be skipped. No expected
-<br>
- differences.
-<br>
-
-<br>
-pcl/pcparse.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-28 09:32:07 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f21756f217abc06b41d09946cffad083c8992ac5">f21756f217abc06b41d09946cffad083c8992ac5</a>
-<blockquote>
-<p>
- Change to new indenting style, no expected differences.
-<br>
-
-<br>
-pcl/pcparse.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-28 11:29:27 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=326f67e01b02936dfdf5d51b918e3d1878765282">326f67e01b02936dfdf5d51b918e3d1878765282</a>
-<blockquote>
-<p>
- Bug 692551. Remove .min for compatibility with other interpreters.
-<br>
-
-<br>
-gs/lib/prfont.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-27 11:36:28 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=48e7b9e6aaf93eded227a089b94f90db209476ff">48e7b9e6aaf93eded227a089b94f90db209476ff</a>
-<blockquote>
-<p>
- Fix for Bug 692378
-<br>
-
-<br>
- The function which decodes runs of compressed color values was not reseting
-<br>
- the solid color value as we looped through the line. So, if it was altered
-<br>
- during one compressed color decode in the line, subsequent values were affected.
-<br>
-
-<br>
-gs/base/gdevdevn.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-27 09:15: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=ddf450125929a9c261b3f7f99ec29c8da69b0207">ddf450125929a9c261b3f7f99ec29c8da69b0207</a>
-<blockquote>
-<p>
- Bug 692529: reduce potential rounding errors in FAPI/FT
-<br>
-
-<br>
- Tweak the heuristic used for avoiding over/underflow problems when converting
-<br>
- scaling to pass into Freetype. This change distributes the over/underflow
-<br>
- protection more evenly between Freetype's resolution, size and matrix
-<br>
- parameters. This prevents the resolution parameter from getting excessively
-<br>
- small, and grid fitting producing unacceptable rounding errors.
-<br>
-
-<br>
- This causes differences in about 20 cluster jobs, they are all small changes
-<br>
- in the position of glyphs - neither regressions nor progressions.
-<br>
-
-<br>
-gs/psi/fapi_ft.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-26 13:19:34 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f97a9171cfb7f1081040a7bd56c4238105e6865a">f97a9171cfb7f1081040a7bd56c4238105e6865a</a>
-<blockquote>
-<p>
- Fix for bug 692537
-<br>
-
-<br>
- Need to make sure that the color mapping information (what colorants are supported and what
-<br>
- their index is) is updated in gx_set_overprint_DeviceN before setting up the overprint information.
-<br>
-
-<br>
-gs/base/gscdevn.c
-<br>
-gs/base/gsovrc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-26 12:03: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=692f2f74da514b5ba42179ea357263aa77caacd7">692f2f74da514b5ba42179ea357263aa77caacd7</a>
-<blockquote>
-<p>
- Fix cmyk 1bpc planar rop SEGVs.
-<br>
-
-<br>
- The new cmyk 1bpc planar rop code does not cope with transparent rops.
-<br>
- Reflect this in the if's surrounding the code that calls it.
-<br>
-
-<br>
-gs/base/gdevmpla.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-24 08:42:38 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3ee407fafffce3d680039f0f094081e46d9bc6d3">3ee407fafffce3d680039f0f094081e46d9bc6d3</a>
-<blockquote>
-<p>
- Fix so that fast thresholding code works with simple orders.
-<br>
-
-<br>
- Simple orders are those that are represented by shifts of a smaller template.
-<br>
-
-<br>
-gs/base/gsht.c
-<br>
-gs/base/gxht_thresh.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-23 23:23:02 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=545cd811c4a2c33c472f302088a10a807e98d9be">545cd811c4a2c33c472f302088a10a807e98d9be</a>
-<blockquote>
-<p>
- Fix for Bug 692339
-<br>
-
-<br>
- Threshold creation code in the tiffsep1 code was not handled correctly when the dorder was a simple form
-<br>
- that included a repeated shift.
-<br>
-
-<br>
-gs/base/gdevtsep.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-23 20:26:09 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=24ff7262bc333194c27c463b88fd54a1217faac7">24ff7262bc333194c27c463b88fd54a1217faac7</a>
-<blockquote>
-<p>
- More optimisations to planar_cmyk4bit_strip_copy_rop
-<br>
-
-<br>
- Fix some bugs that would again only show up when width &gt; 8.
-<br>
-
-<br>
- Add a new case (the hairiest) to the function. The others should all be
-<br>
- easier from here on in if we decide to do them.
-<br>
-
-<br>
- CLUSTER_UNTESTED as plank is not enabled on pcl yet.
-<br>
-
-<br>
-gs/base/gdevmpla.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-23 17:00: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=5688545987a05f38359298e7649bdebe8e87dcaf">5688545987a05f38359298e7649bdebe8e87dcaf</a>
-<blockquote>
-<p>
- Bug 692532: fix setting the ICCProfilesDir userparam
-<br>
-
-<br>
- Change from .setuserparams to .setuserparams2 when setting the
-<br>
- ICCProfilesDir entry so that the Postscript world dictionary gets updated
-<br>
- along with the internal values stored in the current context.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/Resource/Init/gs_lev2.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-23 16:35:10 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f7a01d98266270908f041b1d2b78b2777cc577a8">f7a01d98266270908f041b1d2b78b2777cc577a8</a>
-<blockquote>
-<p>
- Fix to planar_cmyk4bit_strip_copy_rop.
-<br>
-
-<br>
- The previous version would have gone wrong for any use of the new case
-<br>
- where width &gt; 8. I missed this as (presumably) my test case doesn't
-<br>
- exercise the new code, and the cluster is not testing plank on pcl files.
-<br>
-
-<br>
-gs/base/gdevmpla.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-23 15:16: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=2946424a03da33d2f00d27626c4692f8942f7f04">2946424a03da33d2f00d27626c4692f8942f7f04</a>
-<blockquote>
-<p>
- More planar_cmyk4bit_strip_copy_rop optimisations.
-<br>
-
-<br>
- Firstly, fix a bug that was present in the previous version; cproc,
-<br>
- mproc and yproc could not be set when they were used. Also, we
-<br>
- incorrectly failed to check for scolors being non NULL before calling
-<br>
- this routine.
-<br>
-
-<br>
- We fix this latter problem, by implementing the scolors == NULL case.
-<br>
-
-<br>
- This drastically speeds up the time for pcl/pcl5cats/Subset/PL2KCSC2.BIN
-<br>
- (plank 300dpi, banded).
-<br>
-
-<br>
-gs/base/gdevmpla.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-23 12:09: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=1f426395a41ef2fc8a68b24b9970194127d0def2">1f426395a41ef2fc8a68b24b9970194127d0def2</a>
-<blockquote>
-<p>
- Fix some minor compiler warnings introduced in commit
-<br>
- 237f153545faec22782b64016b5f14dabb4cf6ed
-<br>
-
-<br>
-gs/base/gdevpsf1.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-23 11:23:35 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7e048c5e4c4ea35d22801196af1e6bc8886e87d5">7e048c5e4c4ea35d22801196af1e6bc8886e87d5</a>
-<blockquote>
-<p>
- Bug 692532 (part): catch error return, prevent crash.
-<br>
-
-<br>
- This fixes the crash by catching an error, but doesn't fix the underlying
-<br>
- problem of not finding the ICC profile file.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/gstrans.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-23 11:03: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=237f153545faec22782b64016b5f14dabb4cf6ed">237f153545faec22782b64016b5f14dabb4cf6ed</a>
-<blockquote>
-<p>
- Bug #692488 add limited support for MM fonts to ps2write
-<br>
-
-<br>
- ps2write currently emits MM fonts with the WeightVector but no other parts
-<br>
- of the font, and so it is not a valid MM font. However it also emits MM
-<br>
- OtherSubr calls in the CharString, which is not legal and causes errors.
-<br>
-
-<br>
- This code parses (but does not interpret) the Subrs and CharStrings and
-<br>
- removes the blending values, leaving only the base values.
-<br>
-
-<br>
- This is not a comprehensive solution, the parser can be defeated by a
-<br>
- sufficiently convoluted CharString/Subr combination and in addition the
-<br>
- code should really blend the vlaues instead of discarding them. This would
-<br>
- require writing a new version of 'psf_convert_type1_to_type2' which emits
-<br>
- type 1 CharStrings instead of type 2. The bug has been left open and
-<br>
- converted to an enhancement to reflect this ambition.
-<br>
-
-<br>
- This code shows 2 progressions in the regression test suite:
-<br>
- test-setweightvector.ps
-<br>
- fts_20_2005.pdf
-<br>
-
-<br>
-gs/base/gdevpsf1.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-23 00:50:34 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36a46a8bfdf60fb682d5acf200b9da7d5d57ed51">36a46a8bfdf60fb682d5acf200b9da7d5d57ed51</a>
-<blockquote>
-<p>
- Optimise mem_planar_copy_color_4to1 (table based version).
-<br>
-
-<br>
- Performance testing plank shows tests_private/comparefiles/knight.pdf
-<br>
- taking a much longer time with plank than pamcmyk4. A large amount of
-<br>
- time seems to be spend in mem_planar_copy_color_4to1.
-<br>
-
-<br>
- The implementation seems to fare badly on x86 due to branches skipping
-<br>
- ahead that cannot be predicted. A table based implementation seems to
-<br>
- halve the runtime of the problem file (300dpi, no banding).
-<br>
-
-<br>
-gs/base/gdevmpla.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-22 18:14: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=65092efad877169870f9d907eda46a9b8298c1aa">65092efad877169870f9d907eda46a9b8298c1aa</a>
-<blockquote>
-<p>
- Add special case code for rops in cmyk 1bpc planar space.
-<br>
-
-<br>
- We add special case code to speed planar rops. Should give identical
-<br>
- results to the original method of doing it (planar_to_chunky, cmyk
-<br>
- to rgb, apply rop, cmyk back to rgb and split out to planes), but
-<br>
- rolls all that into a single traversal of the data, and doesn't
-<br>
- call the map functions for every single pixel.
-<br>
-
-<br>
- Speeds 600 dpi unbanded planks processing of lj5200_pcl6_mono_PWTW51DC.prn
-<br>
- from 58 seconds to 22.
-<br>
-
-<br>
-gs/base/gdevmpla.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-21 17:57: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=53900176669849e91b2563ea57568db41e55d2d9">53900176669849e91b2563ea57568db41e55d2d9</a>
-<blockquote>
-<p>
- Add special case for faster planar rops in greyscale and rgb modes.
-<br>
-
-<br>
- If we're doing a planar rop, and (S is either unused, or constant) and
-<br>
- (T is either unused, or constant), and (we're in rgb or greyscale), then
-<br>
- we can treat each component separately. This avoids pulling the planes
-<br>
- together, converting to rgb, doing the rop, converting back to cmyk and
-<br>
- splitting back out again.
-<br>
-
-<br>
- I had hoped to use a variant of this code to do cmyk rops too, but that
-<br>
- turned out to be impossible; even if we 'rewrite' the rop on entry to
-<br>
- change it from an rgb one to a cmy one, the non-orthogonal nature of the
-<br>
- K plane bites us.
-<br>
-
-<br>
- CLUSTER_UNTESTED as not currently enabled on the cluster.
-<br>
-
-<br>
-gs/base/gdevmpla.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-21 17:48:51 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=33e280b132b5527e4a9cb5683d10f9395f45bb92">33e280b132b5527e4a9cb5683d10f9395f45bb92</a>
-<blockquote>
-<p>
- Add map_color_rgb functions to cmyk plan devices (required for rops).
-<br>
-
-<br>
- Contrary to the documentation, it is important to provide a map_color_rgb
-<br>
- so that rops work.
-<br>
-
-<br>
- CLUSTER_UNTESTED as only the plank device is enabled in testing, and that
-<br>
- one is unchanged.
-<br>
-
-<br>
-gs/base/gdevplan.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-21 17:39:45 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e2b027a201b1aeeebfff807a45f1e1cb021dc0e">1e2b027a201b1aeeebfff807a45f1e1cb021dc0e</a>
-<blockquote>
-<p>
- Add 24bit case to pack_planar_from_standard (also fix &lt;=8 bit case)
-<br>
-
-<br>
- pack_planar_to_standard is missing the 24 bit case; trivially add it in.
-<br>
-
-<br>
- Also, the &lt;= 8 bit case looks horribly broken to me; rewrite it here,
-<br>
- keeping old code around in case I am (again) proven to be a loon.
-<br>
-
-<br>
- CLUSTER_UNTESTED as this code isn't executed in any tests currently.
-<br>
-
-<br>
-gs/base/gdevdrop.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-21 16:18: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=16aebf73c4eb716b5393bf0912b7b740a3867bf8">16aebf73c4eb716b5393bf0912b7b740a3867bf8</a>
-<blockquote>
-<p>
- Bug 692300: Allow cidfmap to have paths to CIDFont files
-<br>
-
-<br>
- Revise the cidfmap handling so that it can be used to point Ghostscript
-<br>
- at Postscript CIDFont files that are outside the normal resource search
-<br>
- path (i.e. not in &quot;Resource/CIDFont&quot;).
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/Resource/Init/gs_cidfm.ps
-<br>
-gs/doc/Use.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-20 16:14:27 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=36925c8f0864e8ecd54625011696d4bcdbc26fcc">36925c8f0864e8ecd54625011696d4bcdbc26fcc</a>
-<blockquote>
-<p>
- Fix for bug 692517
-<br>
-
-<br>
- The icc_table member variable needs to be allocated in stable memory. This way
-<br>
- it is not freed during a restore. This was occurring when we had a clist
-<br>
- device member variable in a pattern followed by a restore.
-<br>
-
-<br>
-gs/base/gxclist.c
-<br>
-gs/base/gxclist.h
-<br>
-gs/base/gxclread.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-20 09:58: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=40bdfff14aa2d3190526f44d4ef81d3c8c65be3f">40bdfff14aa2d3190526f44d4ef81d3c8c65be3f</a>
-<blockquote>
-<p>
- Bug #692520 (partial, pdfwrite portion only) fix return testing
-<br>
-
-<br>
- The cos_c_string_value function returns a pointer (to a parameter passed to it!)
-<br>
- which is cast to an int and tested for negativity. This is terrible practice.
-<br>
- On 64- bit machines the pointer doesn't fit into an int and on 32-bit machines it
-<br>
- will erroneously detect an error if a valid pointer exceeeds 2GB.
-<br>
-
-<br>
- The only reason for the test is to allow the funciton call to be included
-<br>
- in the body of an 'if' test, which is a hideous way of constructing the
-<br>
- code.
-<br>
-
-<br>
- This commit reformats the code, and does away with the irrelevant return code
-<br>
- test.
-<br>
-
-<br>
- No differences expected, this path is not tested by the cluster.
-<br>
-
-<br>
-gs/base/gdevpdfc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-19 17:20:51 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6e2eda3cca4f8e13a9139c77aad5da524fa62d76">6e2eda3cca4f8e13a9139c77aad5da524fa62d76</a>
-<blockquote>
-<p>
- Avoid mixed double float operations.
-<br>
-
-<br>
- On my machine moving over to float to avoid the mixed double/float operation slowed things
-<br>
- down even more. We may want to revisit this later. Diffs were minor and had about
-<br>
- 10 percent speed up on interpolation with this change.
-<br>
-
-<br>
-gs/base/siscale.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-19 15:39:42 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a44f19c56f98f3d700f617701d581e6932c964a9">a44f19c56f98f3d700f617701d581e6932c964a9</a>
-<blockquote>
-<p>
- FAPI/UFST revisions.
-<br>
-
-<br>
- 1) Modify FAPI/UFST to use a chunk allocator for its memory (this reflects a
-<br>
- similar change in FAPI/FT).
-<br>
-
-<br>
- 2) &quot;Side-port&quot; changes from the integration project for customer 532.
-<br>
-
-<br>
- 3) Address a couple of stability/output error problems that came up testing
-<br>
- the above changes.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/Resource/Init/gs_fapi.ps
-<br>
-gs/psi/fapiufst.c
-<br>
-gs/psi/zfapi.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-19 13:52: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=13028e7b90dba007183c4b64a5d6b1363e30c993">13028e7b90dba007183c4b64a5d6b1363e30c993</a>
-<blockquote>
-<p>
- Bug #692515, array index out of bounds (static analysis)
-<br>
-
-<br>
- The routine pdf_SepCMYK_ConvertToRGB accessed element 5 of an array
-<br>
- passed as a parameter, when it should have accessed element 4 in order to
-<br>
- convert a CMYK value into an RGB value.
-<br>
-
-<br>
- The code path is only exercised when creating PDF/A or PDF/X, the
-<br>
- ProcessColorModel is DeviceRGB, and the input contains a /Separation or
-<br>
- /DeviceN colour space with a DeviceCMYK /Alterenate space.
-<br>
-
-<br>
- No differences expected.
-<br>
-
-<br>
-gs/base/gdevpdfc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-16 15:15:45 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=64a7f79fbc184fddc10f635cfeabf8c44db46d90">64a7f79fbc184fddc10f635cfeabf8c44db46d90</a>
-<blockquote>
-<p>
- Fix MSVC gs Profile builds.
-<br>
-
-<br>
- In my recent rework of the makefiles, I broke gs profile builds (in that
-<br>
- they were built as release builds). Trivial fix.
-<br>
-
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-15 20:36: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=50d947b5f4801d1042166acbd8b5aed982f57697">50d947b5f4801d1042166acbd8b5aed982f57697</a>
-<blockquote>
-<p>
- Allow planar device to make use of special getbits handling for 1bit cmyk.
-<br>
-
-<br>
- We have a special function gx_get_bits_copy_cmyk_1bit, used to quickly
-<br>
- map cmyk (1bpc) to rgb. Our use of this is dependant on the
-<br>
- gxdso_is_std_cmyk_1bit call. Unfortunately this was broken for planar
-<br>
- devices, so plank was never getting the speed benefits of this routine.
-<br>
- Fixed here.
-<br>
-
-<br>
-gs/base/gdevmpla.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-14 12:40: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=6aa157b438ac69f9732b9f7b29e8570cceb50e8e">6aa157b438ac69f9732b9f7b29e8570cceb50e8e</a>
-<blockquote>
-<p>
- Fix for bug 692323. Performs color management before spatial interpolation with enlargements.
-<br>
-
-<br>
- This avoids expensive color management operations when we are doing spatial interpolation.
-<br>
- Also a code reduction with this commit.
-<br>
-
-<br>
-gs/base/gxiscale.c
-<br>
-gs/base/sidscale.c
-<br>
-gs/base/siinterp.c
-<br>
-gs/base/siscale.c
-<br>
-gs/base/sisparam.h
-<br>
-gs/psi/zfimscale.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-14 13:29: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=d4c7212427ea85c6d8d9c9a46a178af54c9b96d3">d4c7212427ea85c6d8d9c9a46a178af54c9b96d3</a>
-<blockquote>
-<p>
- Bug 691991: allow extra compile/link flags.
-<br>
-
-<br>
- The XCFLAGS and XLDFLAGS should be available to be specified as parameters to
-<br>
- &quot;make&quot;, but they were being used by the autoconf tools. This change moves the
-<br>
- autconf set flags into their own variables, leaving XCFLAGS and XLDFLAGS for
-<br>
- use at the make command line. Similarly, it adds an XTRALIBS variable which
-<br>
- can also be set from the make command line.
-<br>
-
-<br>
- This is a slight modification of a patch originally from William Bader.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-13 14:03:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83e1c7b77e8a23ed0683b3677a7cccba94ad5fe8">83e1c7b77e8a23ed0683b3677a7cccba94ad5fe8</a>
-<blockquote>
-<p>
- Bug 692491: change FAPI/Freetype to use chunk allocator
-<br>
-
-<br>
- Previously FAPI/FT was using the heap allocator, which caused performance
-<br>
- problems due to its linear search of allocated blocks to validate before
-<br>
- freeing a block. The linear searching was fixed previously, but on some
-<br>
- platforms the C lib's malloc/free are bottlenecks, so using a chunk
-<br>
- allocator instance makes sense for allocate/release pattern we see from
-<br>
- Freetype.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/psi/fapi_ft.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-10 10:23:50 -0500
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e5d8d4d6514600f49a6aae2811e3b6fd33c2ef54">e5d8d4d6514600f49a6aae2811e3b6fd33c2ef54</a>
-<blockquote>
-<p>
- Speed up heap freeing (gs_heap_free_object) by avoiding search.
-<br>
-
-<br>
- Inspired by Bug #687475. Remove the search through every allocated block
-<br>
- when freeing a heap block. Drastically increases the speed. Will hopefully
-<br>
- help other things too.
-<br>
-
-<br>
- If people really want to test that blocks are valid on free, build with
-<br>
- Memento, which captures this in a much more useful way.
-<br>
-
-<br>
-gs/base/gsmalloc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-10 10:09:23 -0500
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1e3da08d9eb07a9d9650f5deeccf376da6db5722">1e3da08d9eb07a9d9650f5deeccf376da6db5722</a>
-<blockquote>
-<p>
- Update xcode project to allow profiling.
-<br>
-
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/ghostscript.xcscheme
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/language_switch.xcscheme
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/pcl.xcscheme
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/svg.xcscheme
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/xps.xcscheme
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-09 13:40:30 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3329928934123e2d3033309aa79c6ca18d975528">3329928934123e2d3033309aa79c6ca18d975528</a>
-<blockquote>
-<p>
- Update lcms2.1 to lcms2.2 plus fix some bit rot
-<br>
-
-<br>
- Checked to see if this fixed Bug 692121 and unfortunately it did not. Working to create this with
-<br>
- tools contained in lcms2 so that I can kick the issue up to Marti.
-<br>
-
-<br>
-gs/base/gsicc_lcms2.c
-<br>
-gs/base/lib.mak
-<br>
-gs/lcms2/AUTHORS
-<br>
-gs/lcms2/COPYING
-<br>
-gs/lcms2/ChangeLog
-<br>
-gs/lcms2/Makefile.in
-<br>
-gs/lcms2/Projects/BorlandC_5.5/lcms2.rc
-<br>
-gs/lcms2/Projects/VC2008/lcms2.rc
-<br>
-gs/lcms2/Projects/VC2010/lcms2.rc
-<br>
-gs/lcms2/Projects/VC2010/resource.h
-<br>
-gs/lcms2/aclocal.m4
-<br>
-gs/lcms2/config.guess
-<br>
-gs/lcms2/config.sub
-<br>
-gs/lcms2/configure
-<br>
-gs/lcms2/configure.ac
-<br>
-gs/lcms2/include/Makefile.in
-<br>
-gs/lcms2/include/lcms2.h
-<br>
-gs/lcms2/install-sh
-<br>
-gs/lcms2/ltmain.sh
-<br>
-gs/lcms2/src/Makefile.in
-<br>
-gs/lcms2/src/cmscnvrt.c
-<br>
-gs/lcms2/src/cmserr.c
-<br>
-gs/lcms2/src/cmsgamma.c
-<br>
-gs/lcms2/src/cmsgmt.c
-<br>
-gs/lcms2/src/cmsio0.c
-<br>
-gs/lcms2/src/cmsio1.c
-<br>
-gs/lcms2/src/cmslut.c
-<br>
-gs/lcms2/src/cmsnamed.c
-<br>
-gs/lcms2/src/cmspack.c
-<br>
-gs/lcms2/src/cmstypes.c
-<br>
-gs/lcms2/src/cmsxform.c
-<br>
-gs/lcms2/src/lcms2_internal.h
-<br>
-gs/lcms2/testbed/Makefile.am
-<br>
-gs/lcms2/testbed/Makefile.in
-<br>
-gs/lcms2/testbed/testcms2.c
-<br>
-gs/lcms2/utils/delphi/lcms2dll.pas
-<br>
-gs/lcms2/utils/jpgicc/Makefile.in
-<br>
-gs/lcms2/utils/linkicc/Makefile.in
-<br>
-gs/lcms2/utils/psicc/Makefile.in
-<br>
-gs/lcms2/utils/tificc/Makefile.in
-<br>
-gs/lcms2/utils/transicc/Makefile.in
-<br>
-gs/lcms2/utils/transicc/transicc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-09 16:27:04 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5f82fe2ef9d4d21950f9cf76c82911b9f977e2b1">5f82fe2ef9d4d21950f9cf76c82911b9f977e2b1</a>
-<blockquote>
-<p>
- Bug 692492: Accept empty xref sections.
-<br>
-
-<br>
- Change xref parser to accept xref sections that have no entries.
-<br>
-
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-08 21: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=7d59aae1041ac22608f7f470f3f3644c1f7523bd">7d59aae1041ac22608f7f470f3f3644c1f7523bd</a>
-<blockquote>
-<p>
- Fix for patterns with plank device, transparency, and clist.
-<br>
-
-<br>
- It turns out that when we right the tile raster for the clist we don't
-<br>
- really know what the &quot;true&quot; target of the pattern is only the final
-<br>
- target device. In this particular situation, the target for the pattern
-<br>
- is a pdf14 device, the tile has no transparency, and the final target
-<br>
- is a planar device. When ended up assuming the tile was planar which
-<br>
- it was not and ended up with a seg fault
-<br>
-
-<br>
-gs/base/gsptype1.c
-<br>
-gs/base/gxcolor2.h
-<br>
-gs/base/gxpcmap.c
-<br>
-gs/base/gxpcolor.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-08 13:59: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=968040d1ef877607fb6b6bed67e7c2d54c0b4dd1">968040d1ef877607fb6b6bed67e7c2d54c0b4dd1</a>
-<blockquote>
-<p>
- Add massively hacky and horrible clang_wrapper to xcode build.
-<br>
-
-<br>
- This is REALLY nasty, but seems to work; at least I get sensible
-<br>
- results thrown back into Xcode when I build with analyze.
-<br>
-
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/project.xcworkspace/xcuserdata/robin.xcuserdatad/UserInterfaceState.xcuserstate
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/project.xcworkspace/xcuserdata/robin.xcuserdatad/WorkspaceSettings.xcsettings
-<br>
-xcode/Makefile
-<br>
-xcode/clang_wrapper.c
-<br>
-xcode/resolve.sh
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-07 23:37:29 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=618f03fce59282255e7d251875dd1d9ff5b35bf6">618f03fce59282255e7d251875dd1d9ff5b35bf6</a>
-<blockquote>
-<p>
- Remove unused variable introduced in last commit.
-<br>
-
-<br>
-gs/base/gdevplan.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-07 20:27:26 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a505dc016f8d34444f7b431a220320e005df201">6a505dc016f8d34444f7b431a220320e005df201</a>
-<blockquote>
-<p>
- Put map_color_rgb function back into planar devices to fix pcl
-<br>
-
-<br>
- It appears that the rop code requires map_color_rgb to work properly.
-<br>
- Reinstate the old functions to get us up and running.
-<br>
-
-<br>
-gs/base/gdevplan.c
-<br>
-gs/base/gdevplib.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-07 00:28:21 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b3ee2cd07fc7bdfbc3014316f0d4f7da54c900ee">b3ee2cd07fc7bdfbc3014316f0d4f7da54c900ee</a>
-<blockquote>
-<p>
- Bug 692352: excessive memory use by shading
-<br>
-
-<br>
- Reduce memory usege in smooth shading by running the shading code
-<br>
- in save-restore contest. Although resolved shading is no longer
-<br>
- cached by PDF interpreter, reduced memory usage greatly speeds-up
-<br>
- processing of the files with many shadings.
-<br>
-
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-06 20:42: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=5426550f44025e7ec5c802b27d379f7ffee5ed01">5426550f44025e7ec5c802b27d379f7ffee5ed01</a>
-<blockquote>
-<p>
- New simple xcode project for GhostPDL/Ghostscript.
-<br>
-
-<br>
- Still very experimental, but seems to build. Debugging seems to work.
-<br>
-
-<br>
- Analysis doesn't work (usefully) yet due to clang not reporting full
-<br>
- pathnames. This can be solved by a wrapper. TODO: Write it.
-<br>
-
-<br>
-xcode/GhostPDL.xcodeproj/default.pbxuser
-<br>
-xcode/GhostPDL.xcodeproj/project.pbxproj
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/project.pbxproj
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/project.xcworkspace/contents.xcworkspacedata
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/project.xcworkspace/xcuserdata/robin.xcuserdatad/UserInterfaceState.xcuserstate
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/project.xcworkspace/xcuserdata/robin.xcuserdatad/WorkspaceSettings.xcsettings
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/GhostPDL.xcscheme
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/ghostscript.xcscheme
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/language_switch.xcscheme
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/pcl.xcscheme
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/svg.xcscheme
-<br>
-xcode/GhostPDL/GhostPDL.xcodeproj/xcshareddata/xcschemes/xps.xcscheme
-<br>
-xcode/Makefile
-<br>
-xcode/clang_wrapper.sh
-<br>
-xcode/xcode.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-06 12:22:46 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=15e70ed9fc7b28a02b9eff6491fe5137cedc7798">15e70ed9fc7b28a02b9eff6491fe5137cedc7798</a>
-<blockquote>
-<p>
- genarch tweak for cross-compiling; supply ready made arch files.
-<br>
-
-<br>
- Previously genarch would unconditionally generate an arch.h file for the
-<br>
- current platform every time it was called. This fails for cross-compiling,
-<br>
- forcing the makefile to be edited every time. In this commit we add a
-<br>
- tweak that solves this problem.
-<br>
-
-<br>
- Now, genarch can optionally copy an existing arch.h file; if the make
-<br>
- (or nmake) invocation has TARGET_ARCH_FILE=path/to/existing-arch.h added
-<br>
- to it, then instead of generating an arch.h for the current (host)
-<br>
- platform, it will instead copy the supplied one (assumed to be appropriate
-<br>
- for the target platform).
-<br>
-
-<br>
- MSVC builds are updated here to automatically pick a TARGET_ARCH_FILE
-<br>
- based upon the WIN64 define. This should allow us to build 32bit binaries
-<br>
- on a 64bit box from the Visual Studio solution. We still cannot build
-<br>
- 64bit binaries on a 32bit box using the unedited solution, as we have
-<br>
- no way to detect the type of box we are on, and hence cannot select
-<br>
- the appropriate AUX compiler to use.
-<br>
-
-<br>
- A new directory, 'gs/arch' is added, containing the 2 windows msvc arch.h
-<br>
- files. More files can be added in future, ideally keeping to the
-<br>
- &lt;os&gt;-&lt;architecture&gt;-&lt;toolset&gt;.h naming convention.
-<br>
-
-<br>
-gs/arch/windows-x64-msvc.h
-<br>
-gs/arch/windows-x86-msvc.h
-<br>
-gs/base/genarch.c
-<br>
-gs/base/lib.mak
-<br>
-gs/ghostscript.vcproj
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-05 15:46: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=cb5b14133b516323694dcb99c7594337e84d5e3f">cb5b14133b516323694dcb99c7594337e84d5e3f</a>
-<blockquote>
-<p>
- Add Memento configuration to Visual Studio projects (and gs makefile)
-<br>
-
-<br>
- When swapping between memento and non-memento builds, a complete rebuild
-<br>
- is required due to the pervasive nature of the memento defines. As such
-<br>
- it makes sense to have it as a separate configuration in the project.
-<br>
-
-<br>
- Memento directories are named 'memobj', 'memobj64', 'membin' etc in
-<br>
- keeping with 'debugobj', and 'profobj' etc.
-<br>
-
-<br>
- Also, take the opportunity to fix a couple of small things in the visual
-<br>
- studio files. Firstly, the 64 bit profile build targets were incorrect
-<br>
- (weren't setting paths etc).
-<br>
-
-<br>
- Secondly, we remove the use of nmake /A for the rebuild step, and instead
-<br>
- rely on an explicit clean call, then a rebuild; this means we get
-<br>
- consistent results for a rebuild compared to a clean then a build.
-<br>
-
-<br>
- As part of this work, we add logic to the (MSVC) makefiles to detect
-<br>
- MEMENTO=1 and PROFILE=1. If set, these change the default DEBUG, TDEBUG
-<br>
- and DEBUGSYM flags as appropriate, and change the default output
-<br>
- directory names. This keeps the invocations from Visual Studio sane
-<br>
- (as I found lots of mistakes in them as I looked through).
-<br>
-
-<br>
- Also fix some places where we were failing to set and pass on
-<br>
- BINDIR/PSOBJDIR resulting in stray directories being created.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-common/msvc_top.mak
-<br>
-gs/ghostscript.vcproj
-<br>
-gs/psi/msvc.mak
-<br>
-language_switch/pspcl6_msvc.mak
-<br>
-main/pcl6_msvc.mak
-<br>
-psi/psi.mak
-<br>
-svg/svg_msvc.mak
-<br>
-win32/GhostPDL.sln
-<br>
-win32/ReadMe.txt
-<br>
-win32/language_switch.vcproj
-<br>
-win32/pcl.vcproj
-<br>
-win32/svg.vcproj
-<br>
-win32/xps.vcproj
-<br>
-xps/xps_msvc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-05 10:20:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2fab16e3cbf8b2a18aa82c6beee76e261e530b9f">2fab16e3cbf8b2a18aa82c6beee76e261e530b9f</a>
-<blockquote>
-<p>
- Bug 692365: Don't derive metrics for CIDFontType 2.
-<br>
-
-<br>
- If the metrics don't exist in a CID font, we attempt to derive &quot;sane&quot;
-<br>
- metrics from the bounding box information. This is problematic since a
-<br>
- font (even with WMode 1) missing vertical metrics should be treated as a
-<br>
- horizontal (i.e. WMode 0).
-<br>
-
-<br>
- However, we *do* still want to derive vertical metrics, for a vertical
-<br>
- writing font when we're using a Truetype font as a substitute for a
-<br>
- &quot;real&quot; CIDFont.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/psi/zfapi.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-04 10:26: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=6b7da277a6b7477b0d7114a6203d4112c0ad631f">6b7da277a6b7477b0d7114a6203d4112c0ad631f</a>
-<blockquote>
-<p>
- Fix glyph cleanup after error
-<br>
-
-<br>
- When cleaning up the freetype glyph after a glyph interpretation error
-<br>
- use the glyph type field in the glyph structure to differentiate between
-<br>
- freeing an outline or a bitmap glyph - rather than the glyph type we
-<br>
- requested.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/psi/fapi_ft.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-03 20:38:47 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=42582272f2b4dce1ccd5c600a2d6dc71794b4d3e">42582272f2b4dce1ccd5c600a2d6dc71794b4d3e</a>
-<blockquote>
-<p>
- Bug 692033: fix LZWEncode filter
-<br>
-
-<br>
- Increment code size before writing out EOD when the last code reaches
-<br>
- the current limit code. Fix incorrect bytes or decoding errors at
-<br>
- the end of some LZW-encoded streams.
-<br>
-
-<br>
-gs/base/slzwe.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-03 09:19:49 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a2a8987a7c7d0f98dcf640f72e64256c1f84eb2">6a2a8987a7c7d0f98dcf640f72e64256c1f84eb2</a>
-<blockquote>
-<p>
- Remove the insistence on DeviceGray or DeviceCMYK from pdfa_def.ps and remove
-<br>
- the directive not to use DeviceRGB from the documentation.
-<br>
-
-<br>
- There is no requirement in the PDF/A-1 specification that prevents the use of
-<br>
- DeviceRGB.
-<br>
-
-<br>
-gs/doc/Ps2pdf.htm
-<br>
-gs/lib/PDFA_def.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-01 18:32: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=c1a22bfd63734c93fc8d9df65e58f83fbd6a3376">c1a22bfd63734c93fc8d9df65e58f83fbd6a3376</a>
-<blockquote>
-<p>
- Bug 692481: Fix for remainder of issue; oversize JPEG data causes hang.
-<br>
-
-<br>
- If the JPEG lib exits without decoding anything, and the buffer was full,
-<br>
- attempt a compaction; if the compaction succeeds (bytes were saved), then
-<br>
- continue, otherwise bale with an error to avoid us infinitely looping
-<br>
- as we repeatedly try to decode the same data.
-<br>
-
-<br>
- The 'buffer is full' condition is the tricky one; we cannot know the
-<br>
- exact size of the buffer, but we can know the minimum size we requested,
-<br>
- so we use that as a close approximation.
-<br>
-
-<br>
- Also tweak the pxl handling of error conditions passed back from the
-<br>
- jpeg decoder. Ensure that pxls use of streams set the templates.
-<br>
-
-<br>
-gs/base/sdctd.c
-<br>
-pxl/pximage.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-01 11:35:52 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f1c4efc10e7aad61f08e979493773a29d973c43c">f1c4efc10e7aad61f08e979493773a29d973c43c</a>
-<blockquote>
-<p>
- Speed up of lcms 16bit tetrahedral interpolation code.
-<br>
-
-<br>
- This color table interpolation is used primarily where we have 16 bit image data or
-<br>
- are doing spatial interpolation of image data. The change introduces
-<br>
- some very minor changes across quite a few files that have 16 bit
-<br>
- data or for which spatial interpolation is occurring. No changes occur at the white
-<br>
- or black table points.
-<br>
-
-<br>
- The code differences involved moving the decision tree outside the loop and performing
-<br>
- the normalization divide by an add and shift.
-<br>
-
-<br>
- This change can be readily moved to lcms2.
-<br>
-
-<br>
-gs/lcms/src/cmsintrp.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-02 17:16:22 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8b660e2678b3c6f4592269d14e3767aca3dd51e0">8b660e2678b3c6f4592269d14e3767aca3dd51e0</a>
-<blockquote>
-<p>
- Bug #692136 Change the FontBBox we use when a type 3 font has a NULL bbox.
-<br>
-
-<br>
- PCL creates type 3 fonts where the BBox is 0 0 0 0. This causes Acrobat problems,
-<br>
- so we replace it with a 'default'. Previously this was 0 0 1000 1000, but this
-<br>
- is incorrect for the type 3 fonts created from PCL, and makes it impossible
-<br>
- to search/highlight text in the resulting PDF.
-<br>
-
-<br>
- We now check for a type 3 font with an all zero BBox, and instead use 0 0 1 -1
-<br>
- which for PCL fonts works well. Regression tests show no differences with this
-<br>
- change, and hopefully its no more incorrect than it was before.
-<br>
-
-<br>
- No differences expected.
-<br>
-
-<br>
-gs/base/gdevpdtt.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-02 11:43: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=f2d80d64b5f863ba17f428b96967fe1c1ce0d870">f2d80d64b5f863ba17f428b96967fe1c1ce0d870</a>
-<blockquote>
-<p>
- Bug 692484 - Fix build failure with gold linker...
-<br>
- ....due to freetype underlinking.
-<br>
-
-<br>
- Credit to Timo Gurr ( timo.gurr@gmail.com ) for the patch
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-02 10:09:42 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ee226f558f5b73005ba0594cd3861ce431c08a1b">ee226f558f5b73005ba0594cd3861ce431c08a1b</a>
-<blockquote>
-<p>
- Bug 692483 - Fix the unix install to include {Details,History}9.htm
-<br>
-
-<br>
- Credit to Timo Gurr ( timo.gurr@gmail.com ) for the patch.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/unixinst.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-01 09:54:53 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2881a8db54afddc1708febaa1de51e6808a416f9">2881a8db54afddc1708febaa1de51e6808a416f9</a>
-<blockquote>
-<p>
- Make sure planar pattern buffer size is correctly computed for clist writing.
-<br>
-
-<br>
-gs/base/gsptype1.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-01 17:15: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=a00c728c4c3ffa2392765294bc21b90b6e38496f">a00c728c4c3ffa2392765294bc21b90b6e38496f</a>
-<blockquote>
-<p>
- Bug 692481; partial fix - jpeg data with excess 0xFFs.
-<br>
-
-<br>
- Ghostscript passes buffers full of data to the jpeg library. The jpeg
-<br>
- library decodes one (or more) scanlines of data from this data and
-<br>
- returns it to ghostscript.
-<br>
-
-<br>
- In the event that the jpeg library can't decode an entire scanline from
-<br>
- the buffer supplied, it 'suspends' itself (i.e. restores its internal
-<br>
- state to the beginning of the last scanline, and returns having consumed
-<br>
- no data).
-<br>
-
-<br>
- This means that if we ever have a scanline of jpeg data that is too large
-<br>
- to fit in the stream buffer, we will go into an infinite loop.
-<br>
-
-<br>
- This commit is a partial fix for the issue; if we return from the jpeg
-<br>
- lib having consumed no data and having produced no output, we attempt to
-<br>
- compact the data in the jpeg stream. We do this by compacting strings of
-<br>
- 0xFF bytes to a single 0xFF byte. (Strings of 0xFF bytes are forbidden by
-<br>
- the spec, but are treated by the library as a single one).
-<br>
-
-<br>
- This is sufficient to solve the problem with the supplied corrupted file,
-<br>
- but still leaves us vulnerable to files that have more than 0x800 bytes
-<br>
- in any given single scanline.
-<br>
-
-<br>
- A proper fix would require us to spot that the buffer was 'full' and that
-<br>
- the compaction process saved no bytes. Spotting that the compaction
-<br>
- process saved no bytes is easy. Spotting that the buffer is 'full' is not
-<br>
- currently possible as stream-&gt;cbsize is not available at the point
-<br>
- where the test needs to be done.
-<br>
-
-<br>
-gs/base/sdctd.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-09-01 08:29: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=ad0cf1990ae540252f68c50fa4627ed3b1752b89">ad0cf1990ae540252f68c50fa4627ed3b1752b89</a>
-<blockquote>
-<p>
- Bug #692457 If a PCL pattern turns out to be a flat fill, still update the saved colour.
-<br>
-
-<br>
- If a PCL pattern turned out to be a simple colour (black or white) we optimise
-<br>
- the output and don't emit a pattern. However, we do still need to update the
-<br>
- saved colour in our private state, because we will still be changing the colour. If
-<br>
- we don't do that then our saved state does not reflect the actual content of
-<br>
- the PDF file, and we can emit incorrect colours.
-<br>
-
-<br>
- No differences expected.
-<br>
-
-<br>
-gs/base/gdevpdfg.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-31 18:32:40 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a2d547dd3378afdb63681e9262e3bedd2abb3e53">a2d547dd3378afdb63681e9262e3bedd2abb3e53</a>
-<blockquote>
-<p>
- Memento fixes; Memento code in gsalloc was broken.
-<br>
-
-<br>
- The memento code in gsalloc.c intended to allow for memory squeezing
-<br>
- was inadvertantly relying on C extensions. Fixed here.
-<br>
-
-<br>
- CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/base/gsalloc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-31 18:06: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=af34c29e19ce012f71cb3713d4756ee43d6aa1d0">af34c29e19ce012f71cb3713d4756ee43d6aa1d0</a>
-<blockquote>
-<p>
- Fix mem buffer raster calc in height=1 case.
-<br>
-
-<br>
- gs -r72 -sDEVICE=plank -o o.ppm tests_private/pdf/PDFIA1.7_SUBSET/CATX0198.pdf
-<br>
-
-<br>
- would SEGV when run, due to a planar pattern buffer of 1x1 being created;
-<br>
- this would calculate a bad raster value, which was then copied into the
-<br>
- pattern tile, and would cause problems.
-<br>
-
-<br>
-gs/base/gdevmpla.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-30 18:24:57 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fc3adb358eb5c0175fc5e24d7f275ffe2ac39fb9">fc3adb358eb5c0175fc5e24d7f275ffe2ac39fb9</a>
-<blockquote>
-<p>
- Bug 692409: check file name length
-<br>
-
-<br>
- Check the length of a file name argument and throw /limitcheck when
-<br>
- it exceed the size of the internal buffer. Avoid undefined behaviour
-<br>
- and possible security issues.
-<br>
-
-<br>
-gs/base/gdevprn.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-30 19:22:35 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b898bdf0ba77853f4af9da4e39141189a1580a1">2b898bdf0ba77853f4af9da4e39141189a1580a1</a>
-<blockquote>
-<p>
- Change planar devices to use encode/decode_color only.
-<br>
-
-<br>
- Simplify the code by removing deprecated color mapping functions. In
-<br>
- particular this fixes a problem whereby encode_color for the plank
-<br>
- device was returning a color index encoded as rgb, and hence confusing
-<br>
- the overprint device.
-<br>
-
-<br>
- CLUSTER_UNTESTED as the plan* and plib* devices are not tested at the moment.
-<br>
-
-<br>
-gs/base/gdevplan.c
-<br>
-gs/base/gdevplib.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-30 19:21:44 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=605557a6e3741abe837445da32f378a7bb751e8f">605557a6e3741abe837445da32f378a7bb751e8f</a>
-<blockquote>
-<p>
- Minor whitespace adjustment.
-<br>
-
-<br>
- Correct indentation to avoid confusing simpletons like me.
-<br>
- CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/base/gsbitops.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-30 10:22:45 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b08778372c45bdf77e60db7374d1d18b6b340b10">b08778372c45bdf77e60db7374d1d18b6b340b10</a>
-<blockquote>
-<p>
- Bug 692054: clear currentpoint after stroking empty path
-<br>
-
-<br>
- Make gs compatible with Adobe implementation and avoid creation
-<br>
- of an uninitialized currentpoint value. Flag currentpoint as not
-<br>
- defined after stroking an empty path.
-<br>
-
-<br>
-gs/base/gspaint.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-29 20:24: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=619bfae87817cbb5633853f943dd3c7b101568c9">619bfae87817cbb5633853f943dd3c7b101568c9</a>
-<blockquote>
-<p>
- Bug 692476: simple non-trans tiling to planar devices - workaround.
-<br>
-
-<br>
- Non transparent tiling of 'simple' coloured pattern tiles fails when
-<br>
- going to planar devices. In this commit we simply disable the simple
-<br>
- path in this case. Testing seems to indicate that everything will work
-<br>
- OK now.
-<br>
-
-<br>
- Bug 692476 has been opened to remind us to optimise this when possible.
-<br>
-
-<br>
-gs/base/gxp1fill.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-29 18:39:57 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d0f9685b775092c820e3b4748f0fe09eb7880a55">d0f9685b775092c820e3b4748f0fe09eb7880a55</a>
-<blockquote>
-<p>
- Disable mono threshold based halftoning for cmyk planar devices
-<br>
-
-<br>
- Currently we allow the mono threshold based halftoning routines to be
-<br>
- called for CMYK planar devices. Disable this for now as it doesn't work.
-<br>
- When we have the rest of the planar device testing out correctly we'll
-<br>
- revisit this, debug it, and reenable it.
-<br>
-
-<br>
-gs/base/gximono.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-29 13:50:25 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=385edc256d11fd9c0d9ae6af1e94ea145b15b393">385edc256d11fd9c0d9ae6af1e94ea145b15b393</a>
-<blockquote>
-<p>
- Tweak bmpcmp to put the threshold and window settings into the meta files.
-<br>
-
-<br>
- Useful for debugging. CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/toolbin/bmpcmp.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-29 00:39:26 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a8dbb2a904d52a9cce21db397b0918ce2d733214">a8dbb2a904d52a9cce21db397b0918ce2d733214</a>
-<blockquote>
-<p>
- Bug 692447: Handle unfinished 'W' mode.
-<br>
-
-<br>
- When the content stream sets 'W' or 'W*' clip modes but doesn't
-<br>
- complete them with a filling operator, Ghostscript leaves a
-<br>
- dictionary on the dictionary stack that interferes with PDF graphic
-<br>
- state processing. This patch does the following:
-<br>
- - drops &quot;W&quot; in the sequence 'W Q&quot;
-<br>
- - ignores graphic state changes, e.g. in &quot;W 0 G&quot;
-<br>
- - takes into account possible presence of non-graphic-state
-<br>
- dictionaries during clean-ups.
-<br>
-
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-gs/Resource/Init/pdf_ops.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-29 01:49:41 +0200
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d4b6f695ca058a36141e4f81313533c819def73">4d4b6f695ca058a36141e4f81313533c819def73</a>
-<blockquote>
-<p>
- Make plank and pamcmyk4 files easier to compare.
-<br>
-
-<br>
- Change pamcmyk4 files so that MAXVALUE is 255 (instead of 1) and add
-<br>
- a comment to the plank file header.
-<br>
-
-<br>
-gs/base/gdevpbm.c
-<br>
-gs/base/gdevplan.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-26 10:05: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=7fee00e442130e0aa3118fec975882008e750ebd">7fee00e442130e0aa3118fec975882008e750ebd</a>
-<blockquote>
-<p>
- Allow planar devices to store patterns as bitmaps not clist only
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/gxpcmap.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-26 18:41:36 +0200
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a9b386efabd5aab3913554641c66306e6bd79b58">a9b386efabd5aab3913554641c66306e6bd79b58</a>
-<blockquote>
-<p>
- Add the various plan* devices to the default build.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-26 09:20:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e665cacbe15d9cedb09334451cedd223a38a5ac3">e665cacbe15d9cedb09334451cedd223a38a5ac3</a>
-<blockquote>
-<p>
- Bug 692435: fix PDF pre-rendering spot color search.
-<br>
-
-<br>
- Before we start rendering a page, we search the resources for the page
-<br>
- (including its descendent objects), so that we can pass the information
-<br>
- to the device prior to rendering. What we weren't doing was searching
-<br>
- the parents of the page object (we were, however, doing so during the
-<br>
- stream interpetation for rendering), thus in rare, but valid files, we
-<br>
- could miss setting up the page device for spot colors.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-23 10:31:03 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=aa715abee9f38daba6c9504495dca309e8e3ed64">aa715abee9f38daba6c9504495dca309e8e3ed64</a>
-<blockquote>
-<p>
- Fix so pattern debug code dumps planar bitmap.
-<br>
-
-<br>
-gs/base/gxpcmap.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-23 16:26:24 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cb54af824c8f0aa343167b1e8b99dd1d53e47955">cb54af824c8f0aa343167b1e8b99dd1d53e47955</a>
-<blockquote>
-<p>
- non-clist pattern rendering for planar devices.
-<br>
-
-<br>
-gs/base/gxp1fill.c
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-25 19:02:57 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c2f005a525f49bf43fb796908e0ab9c4b6ed58a4">c2f005a525f49bf43fb796908e0ab9c4b6ed58a4</a>
-<blockquote>
-<p>
- Another typo in News.htm and History9.htm
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/doc/History9.htm
-<br>
-gs/doc/News.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-25 18:28:37 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=409b62a948d75263131e09fd9a9e389d704d2b4c">409b62a948d75263131e09fd9a9e389d704d2b4c</a>
-<blockquote>
-<p>
- Add copy_plane operation to tile_clip device (gxclip2.c)
-<br>
-
-<br>
- Just a copy of copy_color, with an extra plane field.
-<br>
-
-<br>
- Not currently ever called, but required as work towards solving the
-<br>
- planar pattern issues, we believe.
-<br>
-
-<br>
-gs/base/gxclip2.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-25 17:35:36 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cf495c68e94b061c89eca678bf863775ce1b8a53">cf495c68e94b061c89eca678bf863775ce1b8a53</a>
-<blockquote>
-<p>
- Bug 692461: Typos in News.htm and History9.htm
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/doc/History9.htm
-<br>
-gs/doc/News.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-05 20:49:57 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8005a687146fd19ca5e6a80cfc2f20b9fd675e41">8005a687146fd19ca5e6a80cfc2f20b9fd675e41</a>
-<blockquote>
-<p>
- Remove unused variable in shading code.
-<br>
-
-<br>
- km is never used, so remove it. No cluster differences expected.
-<br>
-
-<br>
-gs/base/gxshade6.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-24 11:20: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=8cbd67605010b927192acb590b9a1fd8bf45a2a3">8cbd67605010b927192acb590b9a1fd8bf45a2a3</a>
-<blockquote>
-<p>
- Bug #692344 Make sure we do not dereference a NULL clip path when freeing
-<br>
-
-<br>
- When creating the 'privately allocated' parts of a gstate it is possible to
-<br>
- fail to allocate a clip path. In this case we free the clip path, but if its
-<br>
- notbeen allocated then it is NULL, and the free routine unconditionally
-<br>
- de-references it.
-<br>
-
-<br>
- Added a NULL pointer to check to prevent this. I *believe* this fixes the bug
-<br>
- but just changing the code made the allocation succeed when I tested it, so I
-<br>
- am not absolutely certain. This patch does fix a genuine failure though.
-<br>
-
-<br>
-gs/base/gxcpath.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-24 01:40:56 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=827b098f50d296dd0c9399ec82f1988c1de7b62d">827b098f50d296dd0c9399ec82f1988c1de7b62d</a>
-<blockquote>
-<p>
- Bug 692445, tolerate short xref entries
-<br>
-
-<br>
- Fix a bug in the code that handles invalid xref entries and try
-<br>
- to continue processing by repositioning PDF stream after the actial
-<br>
- end of the entry.
-<br>
-
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-23 16:24:53 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c88a42f2409c30b3d2b955922efd8e00714c1cc">1c88a42f2409c30b3d2b955922efd8e00714c1cc</a>
-<blockquote>
-<p>
- Forcing of clist only rendering of patterns if target device is planar.
-<br>
-
-<br>
- This enables us to achieve proper rendering until we get the procedures straight
-<br>
- for the non-clist case.
-<br>
-
-<br>
-gs/base/gxpcmap.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-23 10:35:04 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f215836c60865eaa2da4bed711215eae2b906c49">f215836c60865eaa2da4bed711215eae2b906c49</a>
-<blockquote>
-<p>
- Revert &quot;Fix for Bug 687695.&quot; Fixes Bug 692454
-<br>
-
-<br>
- This reverts commit c7404eceab4d308c67130f43e9a4d4c0b58cd73c.
-<br>
- That commit broke all the tiff devices.
-<br>
-
-<br>
-gs/base/gdevdgbr.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-23 13:15:25 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ec7e68e9054c8b1e91f588a358101c24d281555b">ec7e68e9054c8b1e91f588a358101c24d281555b</a>
-<blockquote>
-<p>
- Bug #692105. Increase the maximum input/output dimesnions of sampled functions.
-<br>
-
-<br>
- The maximum number of inputs and outputs allowed in a sampled function is a
-<br>
- compile-time value. This particular PDF file had 20 colorants, and a sampled
-<br>
- function with 20 inputs and 4 outputs to convert it into CMYK.
-<br>
-
-<br>
- This broke the maximu, even though GS had been compiled with GS_CLIENT_COLOR_MAX_XOMPONENTS
-<br>
- increased to allow the PostScript version (which doesn't use a sampled function)
-<br>
- to complete.
-<br>
-
-<br>
- This patch permits a new compile-time define GS_CLIENT_SAMPLED_FN_MAX_COMPONENTS
-<br>
- which can be used to increase this value. If this is not declared then we now use
-<br>
- the GS_CLIENT_COLOR_MAX_COMPONENTS as it is likely we will encounter sampled functiosn
-<br>
- with that many components
-<br>
-
-<br>
- No differences expected
-<br>
-
-<br>
-gs/base/gsfunc0.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-22 15:42:10 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ebc42b7b7b27977bac17a9f5a9f0626bcfdf8a16">ebc42b7b7b27977bac17a9f5a9f0626bcfdf8a16</a>
-<blockquote>
-<p>
- Fix pattern matrix problems when the pattern is used in a Form and creating PDF.
-<br>
-
-<br>
- Bug #691800 exhibited a problem using a Shading (type 2 pattern) in a form.
-<br>
- This is unusual because hte only way to get a Form out of pdfwrite is to involve transparency.
-<br>
-
-<br>
- When a pattern is used in a form, we do not apply the current CTM, but the
-<br>
- CTM of the enclosing context. In this case we were still applying the outermost
-<br>
- context, not the CTM of the page stream (which is the enclosing context of the form).
-<br>
-
-<br>
- Fixing this revealed other problems.
-<br>
-
-<br>
- I've moved the form counting out of the transparency group and into the form
-<br>
- dictionary creation code where it makes much more sense. This allows me to
-<br>
- change the 'FormDepth' checks so that we only undo the page content scaling
-<br>
- if the formdepth is 0.
-<br>
-
-<br>
- In the long run we may need to keep a stack of gstatas (or more accurately the
-<br>
- CTM) so that if we get nested forms we can apply the correct CTM to any patterns
-<br>
- in the form. For now, this isn't required, we don't have any test files which nest
-<br>
- more than 1 form deep.
-<br>
-
-<br>
- This fixes Bug #691800. I also see progressions in the following files:
-<br>
-
-<br>
- Bug6901014_CityMap-evince-pdftopdf.pdf
-<br>
- Bug691783.pdf
-<br>
- fts_04_0403.pdf
-<br>
- fts_06_0608.pdf
-<br>
- fts_09_0919.pdf
-<br>
- fts_12_1202.pdf
-<br>
- fts_12_1205.pdf
-<br>
- fts_14_1416.pdf
-<br>
- fts_15_1508.pdf
-<br>
- fts_15_1510.pdf
-<br>
- fts_15_1512.pdf
-<br>
- fts_15_1514.pdf
-<br>
- fts_15_1516.pdf
-<br>
- fts_15_1518.pdf
-<br>
- fts_15_1520.pdf
-<br>
- fts_28_2803.pdf
-<br>
- fts_28_2804.pdf
-<br>
- fts_31_3107.pdf
-<br>
-
-<br>
-gs/base/gdevpdft.c
-<br>
-gs/base/gdevpdfv.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-19 08:42:14 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c387412a0267a51fb1b6d3a51c7e70a20533bd50">c387412a0267a51fb1b6d3a51c7e70a20533bd50</a>
-<blockquote>
-<p>
- Added comments regarding compare_gdev_prn_space_params().
-<br>
-
-<br>
- Added a couple of comments to the header files that declare the
-<br>
- structures that compare_gdev_prn_space_params() compares warning
-<br>
- that changes/additions to the structures will require changes to
-<br>
- that function as well.
-<br>
-
-<br>
- No expected cluster differences since no code changed.
-<br>
-
-<br>
-gs/base/gdevprn.h
-<br>
-gs/base/gxband.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-19 15:14: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=493fddf61a96d6dc07c3f376bbb052990ec6a742">493fddf61a96d6dc07c3f376bbb052990ec6a742</a>
-<blockquote>
-<p>
- Bug 689283: latest pcl3/doc/reports.txt file
-<br>
-
-<br>
- Our contrib/pcl3 was already at the latest release, but the reports.txt
-<br>
- file had additions post-release.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/contrib/pcl3/doc/reports.txt
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-19 14:00: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=fa67a1d0f4b31841d02f2b6322b53da8a3874cfd">fa67a1d0f4b31841d02f2b6322b53da8a3874cfd</a>
-<blockquote>
-<p>
- Bug 692426 (tweak): eliminate warning
-<br>
-
-<br>
- If unix-aux.mak finds sys/time.h exists, make definition it adds to
-<br>
- gconfig_.h conditional on it not being defined already (it can now
-<br>
- be defined in the compiler flags as setup by configure).
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/unix-aux.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-19 13:38: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=0ab8cd1259dc76f6b3465f1ccd08a7509428e021">0ab8cd1259dc76f6b3465f1ccd08a7509428e021</a>
-<blockquote>
-<p>
- Reinstate Identity-UTF16-H and UniHojo-UCS2-H CMaps
-<br>
-
-<br>
- We need these in order to use Truetype fonts to emulate CIDFonts,
-<br>
- see gs_ciddc.ps
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/Resource/CMap/Identity-UTF16-H
-<br>
-gs/Resource/CMap/UniHojo-UCS2-H
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-19 11:48: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=714766fb1546616f09dafa8c9d7b4563dd10c65c">714766fb1546616f09dafa8c9d7b4563dd10c65c</a>
-<blockquote>
-<p>
- Bug 692426: let configure check for sys/time.h
-<br>
-
-<br>
- The configure script will now check for whether sys/time.h exists, so we
-<br>
- don't rely on hard coded path check in unix-aux.mak - the checks in
-<br>
- unix-aux.mak remain for the benefit of those who maintain their own
-<br>
- makefiles.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-18 23:10:20 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c7404eceab4d308c67130f43e9a4d4c0b58cd73c">c7404eceab4d308c67130f43e9a4d4c0b58cd73c</a>
-<blockquote>
-<p>
- Fix for Bug 687695.
-<br>
-
-<br>
- Patch supplied by Shailesh Mistry
-<br>
-
-<br>
-gs/base/gdevdgbr.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-18 23:06:49 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cb9c046b29cc449fb8e147a4117b7b81dec934a0">cb9c046b29cc449fb8e147a4117b7b81dec934a0</a>
-<blockquote>
-<p>
- Fix for compiler warnings
-<br>
-
-<br>
- CLUSTER UNTESTED
-<br>
-
-<br>
-gs/base/gxipixel.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-17 08: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=942ebdc7700baf85bac4ed76af2fd845f8b7edd3">942ebdc7700baf85bac4ed76af2fd845f8b7edd3</a>
-<blockquote>
-<p>
- Fix for bug 692083. Improper decode scaling was occurring during creation of the color cache.
-<br>
-
-<br>
-gs/base/gxipixel.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-18 08:36: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=22ff0a3aad850d34d203a629735a94a2e253682a">22ff0a3aad850d34d203a629735a94a2e253682a</a>
-<blockquote>
-<p>
- Bug #689290 Handle image masks with a height of 1.
-<br>
-
-<br>
- Adopting the patch supplied by Shailesh Mistry which properly processes
-<br>
- soft mask images with a height of 1.
-<br>
-
-<br>
- This also allows us to do away with an ugly hack to avoid an endless loop.
-<br>
- By not processing single scan line images we would exit gx_image3x_plane_data
-<br>
- returning '1' which meant we hadn't processed all the data, which led to
-<br>
- gx_image3x_plane_data being called again, indefinitely....
-<br>
-
-<br>
- The file for bug 689290 now processes correctly with all devices.
-<br>
- In addition fts_26_2604.pdf when converted to PDF shows differences, I'm
-<br>
- not sure why, but they are impossible to detect visually so I don't think
-<br>
- we should be concerned.
-<br>
-
-<br>
-gs/base/gximag3x.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-17 10:31: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=766df64767959a3c69357cb8698b4c286957af4d">766df64767959a3c69357cb8698b4c286957af4d</a>
-<blockquote>
-<p>
- Suppress some warnings in gdevcups.c
-<br>
-
-<br>
- As cups_set_color_info() now does things that can fail, it has to return
-<br>
- an error value (getting rid of the &quot;code set but never used&quot; warning).
-<br>
-
-<br>
- Also, add a &quot;default:&quot; case to a switch to get rid of the warning about
-<br>
- enum values not handled in a switch - the default case does nothing, so
-<br>
- behaviour is unchanged.
-<br>
-
-<br>
- Finally, tidy up the initialization of an array of arrays of arrays, getting
-<br>
- rid of a warning about missing braces.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-16 19:49:21 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b75eacf6a9b3a66265a0194ab21e0971f6e0b44c">b75eacf6a9b3a66265a0194ab21e0971f6e0b44c</a>
-<blockquote>
-<p>
- Missed a couple of files that should have been changed as part of the previous commit.
-<br>
-
-<br>
-common/msvc_top.mak
-<br>
-gs/doc/Develop.htm
-<br>
-main/pcl6_gcc.mak
-<br>
-main/pcl6_msvc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-16 19:19:32 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a49306bd0942aaea1bd035d285977c3f1cec0c2e">a49306bd0942aaea1bd035d285977c3f1cec0c2e</a>
-<blockquote>
-<p>
- Bug 692400. Removed imdi and related devices (wtsimdi and wtscmyk).
-<br>
-
-<br>
- Devices were example devices that have been obsoleted by ICC color
-<br>
- management.
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/configure.ac
-<br>
-gs/base/devs.mak
-<br>
-gs/base/gdevimdi.c
-<br>
-gs/base/gdevwts.c
-<br>
-gs/base/gs.mak
-<br>
-gs/base/macos-mcp.mak
-<br>
-gs/base/macosx.mak
-<br>
-gs/base/msvclib.mak
-<br>
-gs/base/openvms.mak
-<br>
-gs/base/ugcclib.mak
-<br>
-gs/base/unix-gcc.mak
-<br>
-gs/base/unixansi.mak
-<br>
-gs/base/wtsimdi.c
-<br>
-gs/ghostscript.vcproj
-<br>
-gs/imdi/Jamfile
-<br>
-gs/imdi/LICENSE
-<br>
-gs/imdi/README
-<br>
-gs/imdi/arch.h
-<br>
-gs/imdi/cctiff.c
-<br>
-gs/imdi/cgen.c
-<br>
-gs/imdi/config.h
-<br>
-gs/imdi/copyright.h
-<br>
-gs/imdi/imdi.c
-<br>
-gs/imdi/imdi.h
-<br>
-gs/imdi/imdi_gen.c
-<br>
-gs/imdi/imdi_gen.h
-<br>
-gs/imdi/imdi_imp.h
-<br>
-gs/imdi/imdi_k.c
-<br>
-gs/imdi/imdi_k.h
-<br>
-gs/imdi/imdi_tab.c
-<br>
-gs/imdi/imdi_tab.h
-<br>
-gs/psi/msvc.mak
-<br>
-gs/psi/os2.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-16 23:59: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=781b7387334f9c9d98220567f59e5fe1843ad43d">781b7387334f9c9d98220567f59e5fe1843ad43d</a>
-<blockquote>
-<p>
- Bug 691922: handle color model change in gdevcups.c
-<br>
-
-<br>
- Revise the previous method for setting a suitable ICC profile when the cups
-<br>
- color model changes, and ensure that the raster memory gets recreated
-<br>
- afterwards.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-16 16:48:01 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9c074dc8c611a9d225a50ae690dcc8250542c7e9">9c074dc8c611a9d225a50ae690dcc8250542c7e9</a>
-<blockquote>
-<p>
- Fixes 691820 by removing the device, the authors in the contrib.mak
-<br>
- and source code file (gdevlx50.c) have been sent email the device is
-<br>
- broken.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-gs/contrib/contrib.mak
-<br>
-gs/contrib/gdevlx50.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-16 22:45: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=58d19521e19252f45ec0d4c212fe938580fbeb54">58d19521e19252f45ec0d4c212fe938580fbeb54</a>
-<blockquote>
-<p>
- Sort line endings problem.
-<br>
-
-<br>
-gs/openjpeg/libopenjpeg/opj_malloc.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-16 08:57:46 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=399c536b8c8fda93071e2895ab88ea11b92e1eb5">399c536b8c8fda93071e2895ab88ea11b92e1eb5</a>
-<blockquote>
-<p>
- Bug 688651. Change EPSON ESC/P change color command from ascii to unsigned char.
-<br>
-
-<br>
- I don't have an Epson printer to test this with, but it seems
-<br>
- reaonable that the command would not use and ascii parameter.
-<br>
-
-<br>
-gs/base/gdevepsc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-16 16:30:01 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d9c04fa861359debdf95d698549a08253283d45f">d9c04fa861359debdf95d698549a08253283d45f</a>
-<blockquote>
-<p>
- Correct a typo checking if we really need to change profiles.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/gsicc_manage.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-16 02:30:38 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d8da050fcfcb6bd62024ab007d4ad2c6a7b8920b">d8da050fcfcb6bd62024ab007d4ad2c6a7b8920b</a>
-<blockquote>
-<p>
- CUPS Raster: Improved recognition of black pixels on CMYK -&gt; RGBW conversion
-<br>
-
-<br>
- To improve on bug 691922.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-15 23:47:55 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1920f21e245e9e1c1ed9e8df1314b4b548088db5">1920f21e245e9e1c1ed9e8df1314b4b548088db5</a>
-<blockquote>
-<p>
- Set correct default color profiles for all color spaces of the CUPS Raster device
-<br>
-
-<br>
- If no output profile is supplied by the user via
-<br>
- &quot;-sOutputICCProfile=...&quot;, set a default profile appropriate to the
-<br>
- selected color space (RGBish additive, CMYKish subtractive, or
-<br>
- grayscale). This should really be the last piece of the fix for bug
-<br>
- 691922.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-15 23:10:14 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=05b517bd3d350e08c08604dcf72741188b4d586e">05b517bd3d350e08c08604dcf72741188b4d586e</a>
-<blockquote>
-<p>
- Eliminated compiler warning in gdevcups.c.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-15 11:57:26 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=78272d055d4c1ca8fbd301130473d00f611bd64e">78272d055d4c1ca8fbd301130473d00f611bd64e</a>
-<blockquote>
-<p>
- Fixed compiler warning in base/gdevprn.c.
-<br>
-
-<br>
-gs/base/gdevprn.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-15 14:04:17 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb6b63157d90bed5df4b5dd134b5581b4a38ae39">eb6b63157d90bed5df4b5dd134b5581b4a38ae39</a>
-<blockquote>
-<p>
- Let the CUPS Raster output device generate RGBW as defined in the CUPS documentation
-<br>
-
-<br>
- The CUPS Raster output device (&quot;cups&quot;) has an RGBW output color
-<br>
- space. This was intended to produce standard RGB plus an extra channel
-<br>
- which marks true black pixels by being 0 and for all non-black pixels
-<br>
- having all bits set to 1. This mode is designed to control the use of
-<br>
- black ink or toner for black text in printed documents.
-<br>
-
-<br>
- The RGBW output of Ghostscript's CUPS Raster output device was
-<br>
- actually inverted CMYK, an RGBW which is known to be used by
-<br>
- projectors.
-<br>
-
-<br>
- The HPLIP printer drivers worked around this bug being able to
-<br>
- understand both modes correctly and so printouts on HP printers were
-<br>
- correct before, too, but we need to follow the documentation of CUPS,
-<br>
- so that if other printer manufacturers/driver developers make use of
-<br>
- the RGBW mode get correct results.
-<br>
-
-<br>
- This finally fixes bug 691922.
-<br>
-
-<br>
- CUPS documentation:
-<br>
-
-<br>
- http://www.cups.org/documentation.php/doc-1.5/spec-raster.html
-<br>
-
-<br>
- Section: Pixel Value Coding, CUPS_CSPACE_RGBW
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-15 01:39:00 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=28f0da42cbffd79ba747a3e14a899dda5e7a4bd7">28f0da42cbffd79ba747a3e14a899dda5e7a4bd7</a>
-<blockquote>
-<p>
- Fix for Bug 692375. Comparing two structures with memcmp() is a bad idea.
-<br>
-
-<br>
- Code in gdevprn.c relied on memcmp() to compare two structures;
-<br>
- this isn't allowed by C since there can be gaps in the structure
-<br>
- due to padding. This issue was exposed when llvm-gcc became the
-<br>
- default compiler in Xcode 4. The fix is to compare the structures
-<br>
- element by element.
-<br>
-
-<br>
- For more information see: http://c-faq.com/struct/compare.html
-<br>
-
-<br>
- No expected cluster difference since none of the cluster nodes use
-<br>
- llvm-gcc.
-<br>
-
-<br>
-gs/base/gdevprn.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-15 07:58:13 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f369ae5a30143cdfc27df96de9b1b5bab1c72c6f">f369ae5a30143cdfc27df96de9b1b5bab1c72c6f</a>
-<blockquote>
-<p>
- Bug #692422. When creating a UUID for PDF files, an earlier change added
-<br>
- 'uuid:' to the XML.
-<br>
-
-<br>
- This potentially caused a buffer overrun leading to a string not being
-<br>
- NULL-terminated and causing a corrupted UUID to be written. Although I
-<br>
- am unable to reproduce this, this patch resolves the problem for the customer.
-<br>
-
-<br>
-gs/base/gdevpdfe.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-13 10:15: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=3c15d3495e4e47a41938710bf2657d0c674f1e55">3c15d3495e4e47a41938710bf2657d0c674f1e55</a>
-<blockquote>
-<p>
- Fix for bug 692392. This makes sure that the transfer function is only applied to the K channel when we are mapping gray to CMYK.
-<br>
- Also fix for case in which interpolation of 12bit images does not work when using the ICC rendering operation.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gdevplnx.c
-<br>
-gs/base/gsciemap.c
-<br>
-gs/base/gsequivc.c
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gxcmap.c
-<br>
-gs/base/gxcmap.h
-<br>
-gs/base/gxi12bit.c
-<br>
-gs/base/gxiscale.c
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-12 18:34: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=97aef7a14df2e7e552592cf4a79c28747948d106">97aef7a14df2e7e552592cf4a79c28747948d106</a>
-<blockquote>
-<p>
- Add the relevant part of the OpenJPEG code to our repos.
-<br>
-
-<br>
- We only need the &quot;library&quot; part, not the example apps and third party
-<br>
- libraries (only used by the example apps), and they add up to a lot of space.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/openjpeg/libopenjpeg/CMakeLists.txt
-<br>
-gs/openjpeg/libopenjpeg/Makefile.am
-<br>
-gs/openjpeg/libopenjpeg/Makefile.in
-<br>
-gs/openjpeg/libopenjpeg/bio.c
-<br>
-gs/openjpeg/libopenjpeg/bio.h
-<br>
-gs/openjpeg/libopenjpeg/cio.c
-<br>
-gs/openjpeg/libopenjpeg/cio.h
-<br>
-gs/openjpeg/libopenjpeg/dwt.c
-<br>
-gs/openjpeg/libopenjpeg/dwt.h
-<br>
-gs/openjpeg/libopenjpeg/event.c
-<br>
-gs/openjpeg/libopenjpeg/event.h
-<br>
-gs/openjpeg/libopenjpeg/fix.h
-<br>
-gs/openjpeg/libopenjpeg/image.c
-<br>
-gs/openjpeg/libopenjpeg/image.h
-<br>
-gs/openjpeg/libopenjpeg/int.h
-<br>
-gs/openjpeg/libopenjpeg/j2k.c
-<br>
-gs/openjpeg/libopenjpeg/j2k.h
-<br>
-gs/openjpeg/libopenjpeg/j2k_lib.c
-<br>
-gs/openjpeg/libopenjpeg/j2k_lib.h
-<br>
-gs/openjpeg/libopenjpeg/jp2.c
-<br>
-gs/openjpeg/libopenjpeg/jp2.h
-<br>
-gs/openjpeg/libopenjpeg/jpt.c
-<br>
-gs/openjpeg/libopenjpeg/jpt.h
-<br>
-gs/openjpeg/libopenjpeg/mct.c
-<br>
-gs/openjpeg/libopenjpeg/mct.h
-<br>
-gs/openjpeg/libopenjpeg/mqc.c
-<br>
-gs/openjpeg/libopenjpeg/mqc.h
-<br>
-gs/openjpeg/libopenjpeg/openjpeg.c
-<br>
-gs/openjpeg/libopenjpeg/openjpeg.h
-<br>
-gs/openjpeg/libopenjpeg/opj_includes.h
-<br>
-gs/openjpeg/libopenjpeg/opj_malloc.h
-<br>
-gs/openjpeg/libopenjpeg/pi.c
-<br>
-gs/openjpeg/libopenjpeg/pi.h
-<br>
-gs/openjpeg/libopenjpeg/raw.c
-<br>
-gs/openjpeg/libopenjpeg/raw.h
-<br>
-gs/openjpeg/libopenjpeg/t1.c
-<br>
-gs/openjpeg/libopenjpeg/t1.h
-<br>
-gs/openjpeg/libopenjpeg/t1_generate_luts.c
-<br>
-gs/openjpeg/libopenjpeg/t1_luts.h
-<br>
-gs/openjpeg/libopenjpeg/t2.c
-<br>
-gs/openjpeg/libopenjpeg/t2.h
-<br>
-gs/openjpeg/libopenjpeg/tcd.c
-<br>
-gs/openjpeg/libopenjpeg/tcd.h
-<br>
-gs/openjpeg/libopenjpeg/tgt.c
-<br>
-gs/openjpeg/libopenjpeg/tgt.h
-<br>
-gs/openjpeg/opj_config.h.in.user
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-12 22:24:32 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=46b4ee6b5ef44838ea5c60aeeab76047a666d561">46b4ee6b5ef44838ea5c60aeeab76047a666d561</a>
-<blockquote>
-<p>
- Fixed landscape orientation printing of PXL drivers pxlmono/pxlcolor
-<br>
-
-<br>
- Bug 692128.
-<br>
-
-<br>
- Thanks to Tim Waugh from Red Hat for the patch.
-<br>
-
-<br>
-gs/base/gdevpxut.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-12 18:19: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=5d45b3c3bc664f7e8a81e85c812dd100543d4cd9">5d45b3c3bc664f7e8a81e85c812dd100543d4cd9</a>
-<blockquote>
-<p>
- Bug 690054: fix a bunch of warnings in base/
-<br>
-
-<br>
- A couple were real functional problems (left-overs from old API
-<br>
- versions), the rest were the usual benign but irritating noise.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/gdevimdi.c
-<br>
-gs/base/gdevokii.c
-<br>
-gs/base/gdevphex.c
-<br>
-gs/base/gdevsunr.c
-<br>
-gs/base/gdevtsep.c
-<br>
-gs/base/gdevwts.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-12 15:33: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=78fe552263a621714c8335ec46f4493121856192">78fe552263a621714c8335ec46f4493121856192</a>
-<blockquote>
-<p>
- Bug 690566: small conformance changes to PPD
-<br>
-
-<br>
- Include change so (I think) the PPDs are now conformant, but leave out the
-<br>
- ones that change the default media.
-<br>
-
-<br>
- Credit to Werner Fink ( werner@suse.de ) for the changes.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/lib/cbjc600.ppd
-<br>
-gs/lib/cbjc800.ppd
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-12 15:18: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=8c523f7a77a4f8f3da47bdb452f8df7cc30812ce">8c523f7a77a4f8f3da47bdb452f8df7cc30812ce</a>
-<blockquote>
-<p>
- Bug 690565: bring the header include up-to-date.
-<br>
-
-<br>
- Pull in the tiny part of the patch in the above bug that is relevant
-<br>
- to the current source.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/contrib/lips4/gdevl4v.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-12 14:05:14 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d9e044eeec3f747be7a0d8270b52cd8a8b4d88c5">d9e044eeec3f747be7a0d8270b52cd8a8b4d88c5</a>
-<blockquote>
-<p>
- Bug 692188: CMS code doesn't compile using HP cc compiler
-<br>
-
-<br>
- Fix for lcms definition of &quot;LCMS_INLINE&quot; on the HP compiler.
-<br>
-
-<br>
- Credit to Ian Ashley ( ian.ashley@opentext.com ) for the patch.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/lcms/include/lcms.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-12 13:52: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=091636d3d688823d3c4062471700085ca8c91fd1">091636d3d688823d3c4062471700085ca8c91fd1</a>
-<blockquote>
-<p>
- Bug 692417: fix a configure problem on OpenBSD
-<br>
-
-<br>
- credit to Henk Jan Priester ( hjpriester@gmail.com ) for the patch.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-12 13:43: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=cacd7dc3e8c6ab4d601330161cd44e3e66eecefa">cacd7dc3e8c6ab4d601330161cd44e3e66eecefa</a>
-<blockquote>
-<p>
- Bug 691430: Make OpenJPEG a configure-able option.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/configure.ac
-<br>
-gs/base/openjpeg.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-09 11:52:06 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8cf0fb4b1e6ee17bdc0fe5e198b593244c89281d">8cf0fb4b1e6ee17bdc0fe5e198b593244c89281d</a>
-<blockquote>
-<p>
- Fixes for various compiler warnings in the ICC code
-<br>
-
-<br>
-gs/base/gdevxcf.c
-<br>
-gs/base/gscdevn.c
-<br>
-gs/base/gsciemap.c
-<br>
-gs/base/gsdparam.c
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gsicc_cache.h
-<br>
-gs/base/gsicc_create.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/base/gxclimag.c
-<br>
-gs/base/gxcmap.c
-<br>
-gs/psi/zcie.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-10 21:27:35 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d63a63c74e7d84aeb48024526b6af7ecaf343733">d63a63c74e7d84aeb48024526b6af7ecaf343733</a>
-<blockquote>
-<p>
- Fix the Mac platform test in the luratech section.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-10 10:27:03 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=edd256d908da6ad77d3e595febffcc3717d5e900">edd256d908da6ad77d3e595febffcc3717d5e900</a>
-<blockquote>
-<p>
- Bug 692367: add gs_memory_t arg to finalize method
-<br>
-
-<br>
- By adding a gs_memory_t argument to the object &quot;finalize&quot; method, we can
-<br>
- dispense with the pointer-pun hackery that stores the memory context
-<br>
- in an extra struct array element of the IO device table, so it's availabe
-<br>
- in the finalize method.
-<br>
-
-<br>
- Although primarily addresses one hack, this commit touches a number of files
-<br>
- because it affects every object with a &quot;finalize&quot; method.
-<br>
-
-<br>
- This also addresses an error condition cleanup of a partially create IO
-<br>
- device table.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/gdevdevn.c
-<br>
-gs/base/gdevpdf.c
-<br>
-gs/base/gdevpsd.c
-<br>
-gs/base/gdevtsep.c
-<br>
-gs/base/gsalloc.c
-<br>
-gs/base/gscspace.c
-<br>
-gs/base/gsdevice.c
-<br>
-gs/base/gsfcid.c
-<br>
-gs/base/gsfont.c
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gsiodev.c
-<br>
-gs/base/gsmalloc.c
-<br>
-gs/base/gsmchunk.c
-<br>
-gs/base/gsstype.h
-<br>
-gs/base/stream.c
-<br>
-gs/psi/igc.c
-<br>
-gs/psi/igc.h
-<br>
-gs/psi/iname.c
-<br>
-gs/psi/isave.c
-<br>
-gs/psi/zdscpars.c
-<br>
-gs/psi/zfjbig2.c
-<br>
-xps/xpsfont.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-09 23:57:26 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ac24676ec25007066576852934cdfaacd8aae91">7ac24676ec25007066576852934cdfaacd8aae91</a>
-<blockquote>
-<p>
- The first OpenJPEG effort.
-<br>
-
-<br>
- Add JPEG 2000 implementation based on OpenJPEG library.
-<br>
- This revision does yet not support the following features:
-<br>
- - CMYK and eYCC color spaces
-<br>
- - downsampled color planes
-<br>
- - alpha transparency planes.
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/gs.mak
-<br>
-gs/base/lib.mak
-<br>
-gs/base/macos-mcp.mak
-<br>
-gs/base/openjpeg.mak
-<br>
-gs/base/sjpx_openjpeg.c
-<br>
-gs/base/sjpx_openjpeg.h
-<br>
-gs/base/winlib.mak
-<br>
-gs/psi/int.mak
-<br>
-gs/psi/msvc.mak
-<br>
-gs/psi/zfjpx.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-09 20:07:12 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b8671d7d27c3d203a55e3f357c1435d1dfd72a3">9b8671d7d27c3d203a55e3f357c1435d1dfd72a3</a>
-<blockquote>
-<p>
- Add includes for error handling. Windows build failed to link for me without these.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/gp_mshdl.c
-<br>
-gs/base/gsicc_lcms.c
-<br>
-gs/base/lib.mak
-<br>
-gs/base/winlib.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-09 22:56:26 +0700
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1eb77139f09b98671e8e83b921f1c351df4ecb84">1eb77139f09b98671e8e83b921f1c351df4ecb84</a>
-<blockquote>
-<p>
- Fix (currently harmless) typo in gxdownscale.c
-<br>
-
-<br>
- I was testing adjust_width before accessing adjust_width_proc, when
-<br>
- it would have been better to test adjust_width_proc. Currently
-<br>
- adjust_width != 0 is true iff adjust_width_proc != NULL, so no
-<br>
- harm other than possible warnings.
-<br>
-
-<br>
-gs/base/gxdownscale.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-09 09:41:07 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f2ecf42738966678a8826d8de9c60c4f3684600">8f2ecf42738966678a8826d8de9c60c4f3684600</a>
-<blockquote>
-<p>
- Remove gserror.h, its contents have been moved to gserrors.h so we
-<br>
- only need have one include file to use for error reporting.
-<br>
-
-<br>
-gs/base/gdevdbit.c
-<br>
-gs/base/gdevhit.c
-<br>
-gs/base/gdevimdi.c
-<br>
-gs/base/gdevm1.c
-<br>
-gs/base/gdevpipe.c
-<br>
-gs/base/gp_mshdl.c
-<br>
-gs/base/gp_msprn.c
-<br>
-gs/base/gp_nsync.c
-<br>
-gs/base/gp_os2pr.c
-<br>
-gs/base/gp_psync.c
-<br>
-gs/base/gp_win32.c
-<br>
-gs/base/gp_wsync.c
-<br>
-gs/base/gsbitops.c
-<br>
-gs/base/gscencs.c
-<br>
-gs/base/gserror.h
-<br>
-gs/base/gserrors.h
-<br>
-gs/base/gsfname.c
-<br>
-gs/base/gsicc_lcms.c
-<br>
-gs/base/gsicc_lcms2.c
-<br>
-gs/base/gsiomacres.c
-<br>
-gs/base/gsmalloc.c
-<br>
-gs/base/gsmisc.c
-<br>
-gs/base/gsparamx.c
-<br>
-gs/base/gstext.c
-<br>
-gs/base/gsutil.c
-<br>
-gs/base/gx.h
-<br>
-gs/base/gxclfile.c
-<br>
-gs/base/gxdownscale.c
-<br>
-gs/base/lib.mak
-<br>
-gs/base/minftrsz.c
-<br>
-gs/base/saes.c
-<br>
-gs/base/sarc4.c
-<br>
-gs/base/scfparam.c
-<br>
-gs/base/sdcparam.c
-<br>
-gs/base/sddparam.c
-<br>
-gs/base/sdeparam.c
-<br>
-gs/base/sfxcommon.c
-<br>
-gs/base/sfxstdio.c
-<br>
-gs/base/shcgen.c
-<br>
-gs/base/simscale.c
-<br>
-gs/base/sjbig2.c
-<br>
-gs/base/sjbig2_luratech.c
-<br>
-gs/base/sjpegd.c
-<br>
-gs/base/sjpx.c
-<br>
-gs/base/sjpx_luratech.c
-<br>
-gs/base/spsdf.c
-<br>
-gs/base/szlibc.c
-<br>
-gs/base/winlib.mak
-<br>
-gs/ghostscript.vcproj
-<br>
-gs/psi/fapi_ft.c
-<br>
-gs/psi/int.mak
-<br>
-gs/psi/os2.mak
-<br>
-gs/psi/zicc.c
-<br>
-pcl/pcl.mak
-<br>
-pcl/pgfdata.c
-<br>
-pl/pl.mak
-<br>
-pl/plchar.c
-<br>
-pl/pldraw.c
-<br>
-pl/plfont.c
-<br>
-pl/pluchar.c
-<br>
-pl/plufont.c
-<br>
-pl/plulfont.c
-<br>
-pxl/pxl.mak
-<br>
-pxl/pxoper.h
-<br>
-pxl/pxparse.c
-<br>
-svg/ghostsvg.h
-<br>
-svg/svg.mak
-<br>
-tools/gslite/gslt_font_api.c
-<br>
-tools/gslite/gslt_font_api_test.c
-<br>
-tools/gslite/gslt_font_int.h
-<br>
-tools/gslite/gslt_font_test.c
-<br>
-tools/gslite/gslt_image.c
-<br>
-tools/gslite/gslt_image_jpeg.c
-<br>
-tools/gslite/gslt_image_png.c
-<br>
-tools/gslite/gslt_image_tiff.c
-<br>
-xps/ghostxps.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-08 04:36:56 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=02ced7b54e8c10bb6ded0efff72990a88ec50027">02ced7b54e8c10bb6ded0efff72990a88ec50027</a>
-<blockquote>
-<p>
- Add backtrace to memento SEGV handler.
-<br>
-
-<br>
- Simple backtrace handling; thanks to Tor for the pointer to the
-<br>
- stackoverflow article.
-<br>
-
-<br>
- This only works with libc based compilers, and may possibly get the
-<br>
- bottom couple of entries on the stack wrong. It also doesn't give
-<br>
- file and line references, but it does at least give the function
-<br>
- names.
-<br>
-
-<br>
- Other suggestions in the article offered other ways of working, but
-<br>
- they all rely on other libraries, or non-portable features, so this
-<br>
- seems the best possible first step.
-<br>
-
-<br>
-gs/base/memento.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-06 16:33:49 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4b069b32b3c09eef440d5770d654208c0930c54a">4b069b32b3c09eef440d5770d654208c0930c54a</a>
-<blockquote>
-<p>
- Improved squeeze2html.pl script; add -q option.
-<br>
-
-<br>
- New -q option to omit 'green' runs from the file. Saves substantially
-<br>
- on disc space.
-<br>
-
-<br>
- It may now be better to use this as a pipe from a gs process doing
-<br>
- memory squeezing to save disc space. e.g:
-<br>
-
-<br>
- MEMENTO_SQUEEZEAT=1 gs -sDEVICE=png16m -o /dev/null tiger.eps |
-<br>
- squeeze2html.pl -q | gzip -9c &gt; out.html.gz
-<br>
-
-<br>
- (the theory being that the omission of 'green' runs saves more space
-<br>
- than the html overhead).
-<br>
-
-<br>
- The output of the above invocation *without* going through squeeze2html.pl
-<br>
- hit 2.7Gig before I killed it, so be warned!
-<br>
-
-<br>
-gs/toolbin/squeeze2html.pl
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-06 14:05:20 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2168e49ea9aa05ef23110addea20c3f29b66bae6">2168e49ea9aa05ef23110addea20c3f29b66bae6</a>
-<blockquote>
-<p>
- Fix for Bug 690137
-<br>
-
-<br>
- The attempts to get the range properly set up for when we have an ICC profile for CIELAB.
-<br>
- The issue is that we may have vector drawings that are encoded across the range of real
-<br>
- CIELAB values like [100,0] [-128, 127] [-128, 127]. Image data of course is not encoded
-<br>
- in this form. This fix corrects for this difference.
-<br>
-
-<br>
-gs/base/devs.mak
-<br>
-gs/base/gdevpdfi.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/psi/zicc.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-06 14:28:11 -0700
-</strong>
-<br>Robin Watts &lt;robin@peeves.(none)&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bfa6e6513b95f51fda49666b6a28af6c60c66e1b">bfa6e6513b95f51fda49666b6a28af6c60c66e1b</a>
-<blockquote>
-<p>
- First version of script to make memento squeezing memory readable.
-<br>
-
-<br>
- Build gs with Memento enabled: make debug XCFLAGS=&quot;-DMEMENTO&quot;
-<br>
-
-<br>
- Then run a mem squeeze:
-<br>
-
-<br>
- MEMENTO_SQUEEZEAT=1 gs -sDEVICE=png16m -o /dev/null tiger.eps 2&gt;&amp;1 &gt; log
-<br>
-
-<br>
- Then this script will turn 'log' into something much more readable.
-<br>
-
-<br>
- squeeze2html.pl &lt; log &gt; out.html
-<br>
-
-<br>
- Though you may want to use:
-<br>
-
-<br>
- head -10000 log | squeeze2html.pl &gt; out.html
-<br>
-
-<br>
- to control the size.
-<br>
-
-<br>
- Red boxes are squeezepoints where we SEGV. Yellow are points where we leak.
-<br>
- Green where we complete cleanly.
-<br>
-
-<br>
- To reproduce a single point (say number 52) in the debugger use:
-<br>
-
-<br>
- MEMENTO_FAILAT=52 gdb --args gs -sDEVICE=png16m -o /dev/null tiger.eps
-<br>
-
-<br>
- Then 'run' when gdb starts.
-<br>
-
-<br>
-gs/toolbin/squeeze2html.pl
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-05 16:45: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=bd0ffdf2bfd324656206b93498b2814ad2d4e36d">bd0ffdf2bfd324656206b93498b2814ad2d4e36d</a>
-<blockquote>
-<p>
- Pull final doc changes from the gs904 branch to master.
-<br>
-
-<br>
- &quot;Bring the changelog up to date since the RC, and revise the date.&quot;
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/doc/API.htm
-<br>
-gs/doc/C-style.htm
-<br>
-gs/doc/Commprod.htm
-<br>
-gs/doc/DLL.htm
-<br>
-gs/doc/Deprecated.htm
-<br>
-gs/doc/Details8.htm
-<br>
-gs/doc/Details9.htm
-<br>
-gs/doc/Develop.htm
-<br>
-gs/doc/Devices.htm
-<br>
-gs/doc/Drivers.htm
-<br>
-gs/doc/Fonts.htm
-<br>
-gs/doc/Helpers.htm
-<br>
-gs/doc/History1.htm
-<br>
-gs/doc/History2.htm
-<br>
-gs/doc/History3.htm
-<br>
-gs/doc/History4.htm
-<br>
-gs/doc/History5.htm
-<br>
-gs/doc/History6.htm
-<br>
-gs/doc/History7.htm
-<br>
-gs/doc/History8.htm
-<br>
-gs/doc/History9.htm
-<br>
-gs/doc/Install.htm
-<br>
-gs/doc/Issues.htm
-<br>
-gs/doc/Language.htm
-<br>
-gs/doc/Lib.htm
-<br>
-gs/doc/Make.htm
-<br>
-gs/doc/News.htm
-<br>
-gs/doc/Projects.htm
-<br>
-gs/doc/Ps-style.htm
-<br>
-gs/doc/Ps2epsi.htm
-<br>
-gs/doc/Ps2pdf.htm
-<br>
-gs/doc/Ps2ps2.htm
-<br>
-gs/doc/Psfiles.htm
-<br>
-gs/doc/Readme.htm
-<br>
-gs/doc/Release.htm
-<br>
-gs/doc/Source.htm
-<br>
-gs/doc/Unix-lpr.htm
-<br>
-gs/doc/Use.htm
-<br>
-gs/doc/Xfonts.htm
-<br>
-gs/doc/gs-vms.hlp
-<br>
-gs/man/dvipdf.1
-<br>
-gs/man/font2c.1
-<br>
-gs/man/gs.1
-<br>
-gs/man/gslp.1
-<br>
-gs/man/gsnd.1
-<br>
-gs/man/pdf2dsc.1
-<br>
-gs/man/pdf2ps.1
-<br>
-gs/man/pdfopt.1
-<br>
-gs/man/pf2afm.1
-<br>
-gs/man/pfbtopfa.1
-<br>
-gs/man/printafm.1
-<br>
-gs/man/ps2ascii.1
-<br>
-gs/man/ps2epsi.1
-<br>
-gs/man/ps2pdf.1
-<br>
-gs/man/ps2pdfwr.1
-<br>
-gs/man/ps2ps.1
-<br>
-gs/man/wftopfa.1
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-05 16:15: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=4916cc6cd1a8d5eb8ef411b4c00952dfea44b36f">4916cc6cd1a8d5eb8ef411b4c00952dfea44b36f</a>
-<blockquote>
-<p>
- Merge doc changes from the gs904 branch to master.
-<br>
-
-<br>
- &quot;Update the docs, version numbers, and dates for 9.04 rc1&quot;
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/doc/API.htm
-<br>
-gs/doc/C-style.htm
-<br>
-gs/doc/Commprod.htm
-<br>
-gs/doc/DLL.htm
-<br>
-gs/doc/Deprecated.htm
-<br>
-gs/doc/Details8.htm
-<br>
-gs/doc/Details9.htm
-<br>
-gs/doc/Develop.htm
-<br>
-gs/doc/Devices.htm
-<br>
-gs/doc/Drivers.htm
-<br>
-gs/doc/Fonts.htm
-<br>
-gs/doc/Helpers.htm
-<br>
-gs/doc/History1.htm
-<br>
-gs/doc/History2.htm
-<br>
-gs/doc/History3.htm
-<br>
-gs/doc/History4.htm
-<br>
-gs/doc/History5.htm
-<br>
-gs/doc/History6.htm
-<br>
-gs/doc/History7.htm
-<br>
-gs/doc/History8.htm
-<br>
-gs/doc/History9.htm
-<br>
-gs/doc/Install.htm
-<br>
-gs/doc/Issues.htm
-<br>
-gs/doc/Language.htm
-<br>
-gs/doc/Lib.htm
-<br>
-gs/doc/Make.htm
-<br>
-gs/doc/News.htm
-<br>
-gs/doc/Projects.htm
-<br>
-gs/doc/Ps-style.htm
-<br>
-gs/doc/Ps2epsi.htm
-<br>
-gs/doc/Ps2pdf.htm
-<br>
-gs/doc/Ps2ps2.htm
-<br>
-gs/doc/Psfiles.htm
-<br>
-gs/doc/Readme.htm
-<br>
-gs/doc/Release.htm
-<br>
-gs/doc/Source.htm
-<br>
-gs/doc/Unix-lpr.htm
-<br>
-gs/doc/Use.htm
-<br>
-gs/doc/Xfonts.htm
-<br>
-gs/doc/gs-vms.hlp
-<br>
-gs/man/dvipdf.1
-<br>
-gs/man/font2c.1
-<br>
-gs/man/gs.1
-<br>
-gs/man/gslp.1
-<br>
-gs/man/gsnd.1
-<br>
-gs/man/pdf2dsc.1
-<br>
-gs/man/pdf2ps.1
-<br>
-gs/man/pdfopt.1
-<br>
-gs/man/pf2afm.1
-<br>
-gs/man/pfbtopfa.1
-<br>
-gs/man/printafm.1
-<br>
-gs/man/ps2ascii.1
-<br>
-gs/man/ps2epsi.1
-<br>
-gs/man/ps2pdf.1
-<br>
-gs/man/ps2pdfwr.1
-<br>
-gs/man/ps2ps.1
-<br>
-gs/man/wftopfa.1
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-05 09:02:28 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a537abc3001a8a1919672a6d936521eba40615a">6a537abc3001a8a1919672a6d936521eba40615a</a>
-<blockquote>
-<p>
- 9.04 NEWS file.
-<br>
-
-<br>
-NEWS
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-05 12:07: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=74264d5900bb6e4a5cacadfb67db198dcd5fef4e">74264d5900bb6e4a5cacadfb67db198dcd5fef4e</a>
-<blockquote>
-<p>
- Ensure Win UNICODE/UTF8 code is disabled for ls build
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-language_switch/pspcl6_msvc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-05 12:05:23 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b5ae769f4f5ac9c72f2e960314d0e44c7655e85a">b5ae769f4f5ac9c72f2e960314d0e44c7655e85a</a>
-<blockquote>
-<p>
- Remove a now spurious debug message.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-04 15:14:05 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7e4051fa5cde4102b2d3e1d53b528e0797718a10">7e4051fa5cde4102b2d3e1d53b528e0797718a10</a>
-<blockquote>
-<p>
- Fix 692369 add erasepage back to device initialization in the language
-<br>
- switch build.
-<br>
-
-<br>
-psi/psitop.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-04 12:59:49 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b00d53f8060554976be107b5009b96b76fbd46b6">b00d53f8060554976be107b5009b96b76fbd46b6</a>
-<blockquote>
-<p>
- Added a couple of dependencies to fix parallel make.
-<br>
-
-<br>
-gs/base/lib.mak
-<br>
-gs/contrib/contrib.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-04 14:40:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3e07ccf224b0811b017fd41d1fdb24310240294a">3e07ccf224b0811b017fd41d1fdb24310240294a</a>
-<blockquote>
-<p>
- Bug 691586: again, ensure that GS knows when cups changes the media size
-<br>
-
-<br>
- Move the fix for Bug 692393 to immediately after the call to
-<br>
- gdev_prn_put_params() - before the call to gx_device_set_media_size()
-<br>
- as that can also change the device's width and height settings.
-<br>
-
-<br>
- With this fix, I have also removed the temporary workaround put in place
-<br>
- with commits 16c410fc29575abffb60926949433653186915fd and
-<br>
- bd33c8f57b1a6e3d365ef0efd8dd7571a14310fa.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-04 10:05: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=2f4dd0504e9a51dd1c4ad2da1c5135b9e4c67d26">2f4dd0504e9a51dd1c4ad2da1c5135b9e4c67d26</a>
-<blockquote>
-<p>
- Revise Luratech section of build docs.......
-<br>
-
-<br>
- ... to reflect that we now look for the Luratech code under
-<br>
- gs/luratech/ldf_jb2 and gs/luratech/lwf_jp2 instead of gs/lwf_jp2 and
-<br>
- gs/ldf_jb2
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/doc/Make.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-03 17:44: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=b5ef299133e7248ca88819d2fa446828e173ad24">b5ef299133e7248ca88819d2fa446828e173ad24</a>
-<blockquote>
-<p>
- Bug 692393: ensure GS realises cups changed the page dimensions.
-<br>
-
-<br>
- After having done media selection from the cups media list, we need to
-<br>
- ensure that GS realises that page dimensions in the device structure
-<br>
- may have changed since the raster memory was last created - this ensures
-<br>
- that GS will reallocate the memory, and correctly setup the
-<br>
- line_ptrs array for the new page size.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-02 18:19:35 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ff6e0443bb89434f5c37790fbbf0a5467c2ce2d3">ff6e0443bb89434f5c37790fbbf0a5467c2ce2d3</a>
-<blockquote>
-<p>
- Memento_failThisEvent addition and usage in chunk allocator.
-<br>
-
-<br>
- Add a new Memento function (Memento_failThisEvent) and calls to it from
-<br>
- the chunk allocator. This should allow us to do memory squeezing tests
-<br>
- that check chunk allocator allocations too.
-<br>
-
-<br>
- Tweaks to Memento to ensure it defines MEMENTO_HAS_FORK on both unix
-<br>
- and macosx automatically.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/base/gsalloc.c
-<br>
-gs/base/memento.c
-<br>
-gs/base/memento.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-02 18:32:09 +0100
-</strong>
-<br>Robin Watts &lt;robin.watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49f11634e3ade5a0ffaf3d2de4389d59fcfb4769">49f11634e3ade5a0ffaf3d2de4389d59fcfb4769</a>
-<blockquote>
-<p>
- Remove unused rectangle arg from shading internals. Add comments.
-<br>
-
-<br>
- Tiny changes, done while trying to follow the code in search of
-<br>
- a bugfix.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/base/gxshade1.c
-<br>
-gs/base/gxshade6.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-02 09:38: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=60dd70326d2294a0927696ad261d4aa92c67d5a4">60dd70326d2294a0927696ad261d4aa92c67d5a4</a>
-<blockquote>
-<p>
- Typo in opdfread header file 'excp' should have been 'exp'.
-<br>
-
-<br>
- Fixes bug #692387
-<br>
-
-<br>
-gs/base/opdfread.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-01 15:36:52 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4eee9bcfcc2ab0f6be5e997a3c8d87fafab60c4e">4eee9bcfcc2ab0f6be5e997a3c8d87fafab60c4e</a>
-<blockquote>
-<p>
- Remove an extra copy of gs_cet.ps from %rom% .
-<br>
-
-<br>
-gs/psi/psromfs.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-01 16:15: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=c0040ecf8553bdd9f8028fe5f816af24e5070d29">c0040ecf8553bdd9f8028fe5f816af24e5070d29</a>
-<blockquote>
-<p>
- Backout accidental commit of bbb8f98; &quot;Alexs patch.&quot;
-<br>
-
-<br>
- As part of investigations into 692352 I committed Alex's patch locally.
-<br>
- Unfortunately, I then let it escape into the wider world.
-<br>
-
-<br>
- Backing it out now with apologies to everyone.
-<br>
-
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-01 16:28:52 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f23b5bbfec46882da955409e70a0bfbff6f43827">f23b5bbfec46882da955409e70a0bfbff6f43827</a>
-<blockquote>
-<p>
- Fixes on the gstoraster CUPS filter
-<br>
-
-<br>
- 1. gstoraster crashes when run outside CUPS (bug #692384)
-<br>
-
-<br>
- 2. All error messages issued by gstoraster are without newline (bug #692385)
-<br>
-
-<br>
- Thanks to Tim Waugh from Red Hat for the patches.
-<br>
-
-<br>
-gs/cups/colord.c
-<br>
-gs/cups/gstoraster.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-01 12:18:25 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bd33c8f57b1a6e3d365ef0efd8dd7571a14310fa">bd33c8f57b1a6e3d365ef0efd8dd7571a14310fa</a>
-<blockquote>
-<p>
- Tweak to tkampeters previous commit to workaround bug 691586.
-<br>
-
-<br>
- Avoid warnings given on some platforms about &quot;unreachable code&quot; by
-<br>
- using an informative #define.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-01 13:05:09 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=16c410fc29575abffb60926949433653186915fd">16c410fc29575abffb60926949433653186915fd</a>
-<blockquote>
-<p>
- CUPS Raster output device: Ignore RIP_MAX_CACHE environment variable
-<br>
-
-<br>
- Ghostscript is (at least currently) not able to work with hard-limited
-<br>
- space parameters. It crashes with a segmentation fault on many input
-<br>
- files then. Leaving the setting of these parameters fully automatic
-<br>
- Ghostscript works just fine. As in most distributions (Currently all
-<br>
- except Debian, Ubuntu, and their derivatives) CUPS imposes a hard
-<br>
- limit via the RIP_MAX_CACHE environment variable, the only way to
-<br>
- assure reliable working of Ghostscript is to ignore the parameter,
-<br>
- leaving the space parameters in automatic mode. For CUPS this should
-<br>
- be no regression, as print queues with other Ghostscript drivers (like
-<br>
- pxlcolor, ljet4, ...) worked without hard limits all the time and no
-<br>
- one complained.
-<br>
-
-<br>
- To ignore this RIP_MAX_CACHE we simply add a &quot;return&quot; right at the
-<br>
- beginning of this function. It will be removed when a real fix gets
-<br>
- into place.
-<br>
-
-<br>
- See http://bugs.ghostscript.com/show_bug.cgi?id=691586
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-01 00:37:33 -0700
-</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e57a8e14f12ef4a4a62f471be55c13ada2aef159">e57a8e14f12ef4a4a62f471be55c13ada2aef159</a>
-<blockquote>
-<p>
- Changes to clusterpush.pl documentation.
-<br>
-
-<br>
-gs/toolbin/localcluster/clusterpush.txt
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-30 17:48:14 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=951dee021a45d501e159a3b08624979604e906f5">951dee021a45d501e159a3b08624979604e906f5</a>
-<blockquote>
-<p>
- Fix bug 692349: UNICODE build of gs not available with VS2003 or VS6.
-<br>
-
-<br>
- Apply a slightly tweaked version of alexchers patch to define wmemset
-<br>
- when it's not provided by the headers.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/psi/dwtext.c
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-28 18:14:34 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bbb8f980f19149b769f602dd4594aa6ec6ceeb29">bbb8f980f19149b769f602dd4594aa6ec6ceeb29</a>
-<blockquote>
-<p>
- Alexs patch.
-<br>
-
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-30 11:56:53 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6c5f9661790b886a681b8926126875e6df59cbb1">6c5f9661790b886a681b8926126875e6df59cbb1</a>
-<blockquote>
-<p>
- Added &quot;-dNOINTERPOLATE&quot; to the Ghostscript command lines of the CUPS filters
-<br>
-
-<br>
- This makes rendering significantly faster and the output of normal
-<br>
- files comming as print jobs from applications does not show any
-<br>
- visible difference.
-<br>
-
-<br>
-gs/cups/gstoraster.c
-<br>
-gs/cups/pstopxl.in
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-29 14:01: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=0132422fe0543a9473b1605a79f2dd46018de4e2">0132422fe0543a9473b1605a79f2dd46018de4e2</a>
-<blockquote>
-<p>
- Another fix for cups RGBW. This gets the color set up properly for RGB.
-<br>
-
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-29 15:27:13 -0400
-</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=87045a3280e268a52f0d738d34f2a6a3ea093406">87045a3280e268a52f0d738d34f2a6a3ea093406</a>
-<blockquote>
-<p>
- Bug 691184: Improve comments in cidfmap file.
-<br>
-
-<br>
- Add a comment to cidfmap file that shows how to use getenv operator
-<br>
- to construct a path dynamically.
-<br>
-
-<br>
-gs/Resource/Init/cidfmap
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-29 12:18:04 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=84177fe99ebd2fa75abe690e0f2a0ef7d7b762e1">84177fe99ebd2fa75abe690e0f2a0ef7d7b762e1</a>
-<blockquote>
-<p>
- Fix for cups RGBW color space so that transparency works properly.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-29 08:14:04 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c90da1237c8d88547377511e7b9d27348f3d7b31">c90da1237c8d88547377511e7b9d27348f3d7b31</a>
-<blockquote>
-<p>
- A test for fixing RGBW in gdevcups.c
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-29 19:40:45 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3d6c383d5e6c9eb23c3b150f4b7e87dc3cb3cf2b">3d6c383d5e6c9eb23c3b150f4b7e87dc3cb3cf2b</a>
-<blockquote>
-<p>
- Speedup for Mementos checking of freed filled blocks.
-<br>
-
-<br>
- Check an (aligned) int at a time rather than a byte at a time.
-<br>
-
-<br>
- CLUSTER_UNTESTED as this is not enabled.
-<br>
-
-<br>
-gs/base/memento.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-29 15:42:49 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=802e977e87ba0d96445e06aa83f32dd31a79f677">802e977e87ba0d96445e06aa83f32dd31a79f677</a>
-<blockquote>
-<p>
- Fix compile_inits=1 ufst builds; don't compact the FCOfontmap-PCLPS2 file.
-<br>
-
-<br>
- The FCOfontmap-PCLPS2 file isn't *really* postscript, so don't compact
-<br>
- it. Fixes bug 692383 (at least for the non 9.04 case).
-<br>
-
-<br>
-gs/psi/psromfs.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-29 10:16: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=217f9712df606e4dedc8afe1220e6b30df627516">217f9712df606e4dedc8afe1220e6b30df627516</a>
-<blockquote>
-<p>
- Increment version number for &quot;master&quot;.
-<br>
-
-<br>
-gs/Resource/Init/gs_init.ps
-<br>
-gs/base/version.mak
-<br>
-pl/pl.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-29 09:40: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=1689828742df05af2f82d3b70f16b8c9457aeed1">1689828742df05af2f82d3b70f16b8c9457aeed1</a>
-<blockquote>
-<p>
- Change the expected directory for luratech.
-<br>
-
-<br>
- For the build system to automatically include the luratech JPX and JBIG2
-<br>
- code, we previously checked for the existence of lwf_jp2 and ldf_jb2
-<br>
- directories under the Ghostscript source dir. This changes it to check
-<br>
- for &lt;gs&gt;/luratech/lwf_jp2 and &lt;gs&gt;/luratech/ldf_jb2 instead.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-28 22:28:37 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c99e0da7b93c065dc22e185e89a48f702c5ab417">c99e0da7b93c065dc22e185e89a48f702c5ab417</a>
-<blockquote>
-<p>
- Restore X11 device to the default unix device.
-<br>
-
-<br>
- In setting up autoconf to detect X11 (9b7298f) the X11 devices were
-<br>
- not put back at the beginning of the device list and so were no longer
-<br>
- the default device.
-<br>
-
-<br>
-main/pcl6_gcc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-28 17:16:35 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4f2d3c7b6c8e08a39de3ef1490562937d0f539ff">4f2d3c7b6c8e08a39de3ef1490562937d0f539ff</a>
-<blockquote>
-<p>
- Changes to lcms v1 to spot failed allocations.
-<br>
-
-<br>
- lcms v1 sometimes forgets to deal with failed allocations. Patch at
-<br>
- least some of these problems.
-<br>
-
-<br>
- Driven by bug 692352. Sufficient to make it run to completion now.
-<br>
-
-<br>
-gs/lcms/src/cmsgmt.c
-<br>
-gs/lcms/src/cmslut.c
-<br>
-gs/lcms/src/cmsps2.c
-<br>
-gs/lcms/src/cmssamp.c
-<br>
-gs/lcms/src/cmsvirt.c
-<br>
-gs/lcms/src/cmswtpnt.c
-<br>
-gs/lcms/src/cmsxform.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-28 17:08:58 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=393685fddae380778e970345dbdca60274a31e69">393685fddae380778e970345dbdca60274a31e69</a>
-<blockquote>
-<p>
- Check for failure to allocate icclink in shading.
-<br>
-
-<br>
- When calling shade_init_fill_state, check for a return code to indicate
-<br>
- failure. Trigger this case when an attempt to allocate an icclink
-<br>
- fails.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/base/gxshade.c
-<br>
-gs/base/gxshade.h
-<br>
-gs/base/gxshade1.c
-<br>
-gs/base/gxshade4.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-28 15:07:14 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d91b0da2e3dd20561724d574f21882f703bd861c">d91b0da2e3dd20561724d574f21882f703bd861c</a>
-<blockquote>
-<p>
- Fix typo in rc_decrement description string.
-<br>
-
-<br>
- Simple typo fix. CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-28 14:03: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=e82868f118963df1c86f288ea5b7e50116be75b2">e82868f118963df1c86f288ea5b7e50116be75b2</a>
-<blockquote>
-<p>
- Work around a bug in gcc 3.4.6 on SPARC.
-<br>
-
-<br>
- gcc 3.4.6 SPARC (possibly versions/ports) when compiling:
-<br>
- &quot;psc-&gt;feof(psc-&gt;file)&quot; seems to be unable to differentiate between
-<br>
- &quot;feof&quot; element in the structure, and &quot;feof()&quot; function from the
-<br>
- std library, and as a result gives a syntax error.
-<br>
-
-<br>
- So I've renamed the structure entry &quot;peof&quot;, and the other two file
-<br>
- handling function pointers similarly.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/mkromfs.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-28 10:21: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=1ae27b694439c3f7f9d721cbc2c832247e18f4aa">1ae27b694439c3f7f9d721cbc2c832247e18f4aa</a>
-<blockquote>
-<p>
- Disable the Windows UNICODE/UTF8 code for now.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-27 22:12:41 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=32b447cba35edb7272eacfef755edec4a174e01e">32b447cba35edb7272eacfef755edec4a174e01e</a>
-<blockquote>
-<p>
- Update of Use.htm to include new color control options.
-<br>
-
-<br>
-gs/doc/Use.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-27 16:25:19 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b3dbb094608e2d5699c6d77d42f4919c0299a02a">b3dbb094608e2d5699c6d77d42f4919c0299a02a</a>
-<blockquote>
-<p>
- Fix Bug 692368; SEGV with clist transparency pattern in clist rendering.
-<br>
-
-<br>
- The invocation/file given in the bug uses banded rendering (clist).
-<br>
- While drawing a band, it uses a pattern with transparency, that is
-<br>
- itself rendered by a clist (using the new pattern clist code).
-<br>
-
-<br>
- A fill rectangle is being done that tries to call the pattern clist
-<br>
- tiling code without the fill_trans_buffer having been setup, and
-<br>
- this causes a SEGV.
-<br>
-
-<br>
- The reason for this appears to be that the device used by the
-<br>
- banded isn't a pdf14 device - instead it's a clipper device wrapping
-<br>
- the pdf14 device. The clipper device does not call gx_forward_fill_path,
-<br>
- but instead calls gx_default_fill_path, meaning that the special
-<br>
- pdf14 handling done to setup the fill_trans_buffer isn't done.
-<br>
-
-<br>
- Making the commit call onwards to gx_forward_fill_path doesn't solve the
-<br>
- problem either, as that results in no actual clipping being done.
-<br>
-
-<br>
- The fix, therefore appears to be to implement a clipping version of
-<br>
- fill_path.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gxclip.c
-<br>
-gs/base/gxclip.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-27 22:14:10 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bf9dc23000675d406d73d987dcc168f6b875ef75">bf9dc23000675d406d73d987dcc168f6b875ef75</a>
-<blockquote>
-<p>
- Fixed the problem that PCL-XL output files got huge after introduction of color management
-<br>
-
-<br>
- The pxlmono and pxlcolor output devices produce PCL XL (PCL 6). With
-<br>
- the introduction of color management, the size of the output files
-<br>
- often got 10 times larger as before and so PCL XL jobs often did not
-<br>
- print as they exhausted the memory of the printer.
-<br>
-
-<br>
- According to the contributor of this patch, Shailesh Mistry, the PDFs
-<br>
- leading to that problem have a DeviceRGB image which is translated
-<br>
- into an ICC profile and passed up but the pcl/pxl can not handle
-<br>
- it. This patch looks for incoming ICC profiles and resolves it into
-<br>
- the base colour which can be handled at this level.
-<br>
-
-<br>
- The patch returns the size of the PCL XL output files to the old
-<br>
- values from Ghostscript 8.x.
-<br>
-
-<br>
- Fixes bug 692329.
-<br>
-
-<br>
-gs/base/gdevpx.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-27 20:37:20 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6ab36cb4256fbd9aa005b79e317ff0993f4acf3e">6ab36cb4256fbd9aa005b79e317ff0993f4acf3e</a>
-<blockquote>
-<p>
- Fixes on the &quot;pstopxl&quot; CUPS filter
-<br>
-
-<br>
- 1. Use POSIX and not Perl regular expressions with sed. This makes the
-<br>
- script working on a wider scope of systems (Bug #692328).
-<br>
-
-<br>
- 2. Switch the Ghostscript output device &quot;pxlmono&quot; if the &quot;pxlcolor&quot; is
-<br>
- used but &quot;Gray&quot; chosen as &quot;ColorModel&quot; setting. Monochrome
-<br>
- &quot;BitsPerPixel&quot; settings do not work with &quot;pxlcolor&quot;.
-<br>
-
-<br>
-gs/cups/pstopxl.in
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-27 10:41:14 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9dca5a4f0eb97ccd33f2503b5e1106c4e1747c5e">9dca5a4f0eb97ccd33f2503b5e1106c4e1747c5e</a>
-<blockquote>
-<p>
- Fix for Windows Display Device showing gray only
-<br>
-
-<br>
- This returns the use of DeviceGrayToK=true/false to set
-<br>
- if the user wants DeviceGray to map to K only for a
-<br>
- CMYK device. Also, this fixes a problem where high
-<br>
- level gray scale images were always going to composite
-<br>
- an not K only. Bug 692204.
-<br>
-
-<br>
-gs/base/gsdparam.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gxclrast.c
-<br>
-gs/psi/zdevice.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-27 09:14:04 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=927c37a3adec70858787de954cfc620801bf65e5">927c37a3adec70858787de954cfc620801bf65e5</a>
-<blockquote>
-<p>
- Replacement of default gray ICC profile with Artifex generated versions
-<br>
-
-<br>
- I reviewed the bmpcmp results and the relatively few diffs are minor.
-<br>
-
-<br>
-gs/iccprofiles/default_gray.icc
-<br>
-gs/iccprofiles/sgray.icc
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-26 16:19:42 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=68a0f6217428daf297d73589821b62ba2e862d0f">68a0f6217428daf297d73589821b62ba2e862d0f</a>
-<blockquote>
-<p>
- Bug 692376, synchronize the cmap file to Ken Lunde's sourceforge
-<br>
- release.
-<br>
-
-<br>
-gs/Resource/CMap/90ms-RKSJ-UCS2
-<br>
-gs/Resource/CMap/90pv-RKSJ-UCS2
-<br>
-gs/Resource/CMap/90pv-RKSJ-UCS2C
-<br>
-gs/Resource/CMap/Adobe-CNS1-B5pc
-<br>
-gs/Resource/CMap/Adobe-CNS1-ETenms-B5
-<br>
-gs/Resource/CMap/Adobe-CNS1-H-CID
-<br>
-gs/Resource/CMap/Adobe-CNS1-H-Host
-<br>
-gs/Resource/CMap/Adobe-CNS1-H-Mac
-<br>
-gs/Resource/CMap/Adobe-CNS1-UCS2
-<br>
-gs/Resource/CMap/Adobe-GB1-GBK-EUC
-<br>
-gs/Resource/CMap/Adobe-GB1-GBpc-EUC
-<br>
-gs/Resource/CMap/Adobe-GB1-H-CID
-<br>
-gs/Resource/CMap/Adobe-GB1-H-Host
-<br>
-gs/Resource/CMap/Adobe-GB1-H-Mac
-<br>
-gs/Resource/CMap/Adobe-GB1-UCS2
-<br>
-gs/Resource/CMap/Adobe-Japan1-90ms-RKSJ
-<br>
-gs/Resource/CMap/Adobe-Japan1-90pv-RKSJ
-<br>
-gs/Resource/CMap/Adobe-Japan1-H-CID
-<br>
-gs/Resource/CMap/Adobe-Japan1-H-Host
-<br>
-gs/Resource/CMap/Adobe-Japan1-H-Mac
-<br>
-gs/Resource/CMap/Adobe-Japan1-PS-H
-<br>
-gs/Resource/CMap/Adobe-Japan1-PS-V
-<br>
-gs/Resource/CMap/Adobe-Japan1-UCS2
-<br>
-gs/Resource/CMap/Adobe-Japan2-0
-<br>
-gs/Resource/CMap/Adobe-Korea1-H-CID
-<br>
-gs/Resource/CMap/Adobe-Korea1-H-Host
-<br>
-gs/Resource/CMap/Adobe-Korea1-H-Mac
-<br>
-gs/Resource/CMap/Adobe-Korea1-KSCms-UHC
-<br>
-gs/Resource/CMap/Adobe-Korea1-KSCpc-EUC
-<br>
-gs/Resource/CMap/Adobe-Korea1-UCS2
-<br>
-gs/Resource/CMap/B5pc-UCS2
-<br>
-gs/Resource/CMap/B5pc-UCS2C
-<br>
-gs/Resource/CMap/CNS01-RKSJ-H
-<br>
-gs/Resource/CMap/CNS02-RKSJ-H
-<br>
-gs/Resource/CMap/CNS03-RKSJ-H
-<br>
-gs/Resource/CMap/CNS04-RKSJ-H
-<br>
-gs/Resource/CMap/CNS05-RKSJ-H
-<br>
-gs/Resource/CMap/CNS06-RKSJ-H
-<br>
-gs/Resource/CMap/CNS07-RKSJ-H
-<br>
-gs/Resource/CMap/CNS15-RKSJ-H
-<br>
-gs/Resource/CMap/ETen-B5-UCS2
-<br>
-gs/Resource/CMap/GB-RKSJ-H
-<br>
-gs/Resource/CMap/GBK-EUC-UCS2
-<br>
-gs/Resource/CMap/GBT-RKSJ-H
-<br>
-gs/Resource/CMap/GBpc-EUC-UCS2
-<br>
-gs/Resource/CMap/GBpc-EUC-UCS2C
-<br>
-gs/Resource/CMap/HK-RKSJ-H
-<br>
-gs/Resource/CMap/Hojo-EUC-H
-<br>
-gs/Resource/CMap/Hojo-EUC-V
-<br>
-gs/Resource/CMap/Hojo-H
-<br>
-gs/Resource/CMap/Hojo-RKSJ-H
-<br>
-gs/Resource/CMap/Hojo-V
-<br>
-gs/Resource/CMap/Identity-UTF16-H
-<br>
-gs/Resource/CMap/Identity-UTF16-V
-<br>
-gs/Resource/CMap/KSC-RKSJ-H
-<br>
-gs/Resource/CMap/KSC2-RKSJ-H
-<br>
-gs/Resource/CMap/KSCms-UHC-UCS2
-<br>
-gs/Resource/CMap/KSCpc-EUC-UCS2
-<br>
-gs/Resource/CMap/KSCpc-EUC-UCS2C
-<br>
-gs/Resource/CMap/TCVN-RKSJ-H
-<br>
-gs/Resource/CMap/UCS2-90ms-RKSJ
-<br>
-gs/Resource/CMap/UCS2-90pv-RKSJ
-<br>
-gs/Resource/CMap/UCS2-B5pc
-<br>
-gs/Resource/CMap/UCS2-ETen-B5
-<br>
-gs/Resource/CMap/UCS2-GBK-EUC
-<br>
-gs/Resource/CMap/UCS2-GBpc-EUC
-<br>
-gs/Resource/CMap/UCS2-KSCms-UHC
-<br>
-gs/Resource/CMap/UCS2-KSCpc-EUC
-<br>
-gs/Resource/CMap/UniCNS-UTF16-H
-<br>
-gs/Resource/CMap/UniCNS-UTF32-H
-<br>
-gs/Resource/CMap/UniCNS-UTF8-H
-<br>
-gs/Resource/CMap/UniGB-UTF16-H
-<br>
-gs/Resource/CMap/UniGB-UTF32-H
-<br>
-gs/Resource/CMap/UniGB-UTF8-H
-<br>
-gs/Resource/CMap/UniHojo-UCS2-H
-<br>
-gs/Resource/CMap/UniHojo-UCS2-V
-<br>
-gs/Resource/CMap/UniHojo-UTF16-H
-<br>
-gs/Resource/CMap/UniHojo-UTF16-V
-<br>
-gs/Resource/CMap/UniHojo-UTF32-H
-<br>
-gs/Resource/CMap/UniHojo-UTF32-V
-<br>
-gs/Resource/CMap/UniHojo-UTF8-H
-<br>
-gs/Resource/CMap/UniHojo-UTF8-V
-<br>
-gs/Resource/CMap/UniJIS-UTF16-H
-<br>
-gs/Resource/CMap/UniJIS-UTF32-H
-<br>
-gs/Resource/CMap/UniJIS-UTF8-H
-<br>
-gs/Resource/CMap/UniJIS2004-UTF16-H
-<br>
-gs/Resource/CMap/UniJIS2004-UTF32-H
-<br>
-gs/Resource/CMap/UniJIS2004-UTF8-H
-<br>
-gs/Resource/CMap/UniJISX0213-UTF32-H
-<br>
-gs/Resource/CMap/UniJISX02132004-UTF32-H
-<br>
-gs/Resource/CMap/UniKS-UTF16-H
-<br>
-gs/Resource/CMap/UniKS-UTF32-H
-<br>
-gs/Resource/CMap/UniKS-UTF8-H
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-26 15:56:48 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9adac36488e3a7dd6ed92b80dfcfb1b2866ef50b">9adac36488e3a7dd6ed92b80dfcfb1b2866ef50b</a>
-<blockquote>
-<p>
- Fix broken build - make requires tab separators, not spaces.
-<br>
-
-<br>
-gs/base/devs.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-25 16:29: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=0eaf43f99eaeadda5118335ec1feb26db1733aed">0eaf43f99eaeadda5118335ec1feb26db1733aed</a>
-<blockquote>
-<p>
- Further updates to mkromfs ps compaction.
-<br>
-
-<br>
- Refactor the postscript compaction routines into a state machine.
-<br>
- Add options to compact using binary postscript encodings, currently
-<br>
- disabled until we drop language level 1 from the interpreter.
-<br>
-
-<br>
- Further refactor it to allow it to work from a generic file-like
-<br>
- interface, rather than a file. This enables us to use it on the
-<br>
- merged file (which is held in memory, not on disc) too.
-<br>
-
-<br>
- With binary encoding enabled we get the rom down to 6.8Meg. Without
-<br>
- that we get 7.1Meg. Without any compaction, 7.8Meg.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/base/mkromfs.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-26 20:21:29 +0100
-</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d2d1f22ddf751fe2d6e3f9c5821fbc30a102a6a">7d2d1f22ddf751fe2d6e3f9c5821fbc30a102a6a</a>
-<blockquote>
-<p>
- Include only one copy of hte Adbove Glyph List
-<br>
-
-<br>
- ps2write and text write both need copies of the Adobe Glyph List, we were
-<br>
- holding one copy each, this commit makes them use the same information, saving space.
-<br>
-
-<br>
- Also resolves Bug #688709 &quot;Updated Adobe Glyph List&quot;
-<br>
-
-<br>
- No differences expected.
-<br>
-
-<br>
-gs/base/devs.mak
-<br>
-gs/base/gdevagl.c
-<br>
-gs/base/gdevagl.h
-<br>
-gs/base/gdevpdfu.c
-<br>
-gs/base/gdevtxtw.c
-<br>
-gs/base/gs_agl.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-25 09:05:44 -0700
-</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cb048fc7c5fdfe82550b8f0a80de2ff5fd64739f">cb048fc7c5fdfe82550b8f0a80de2ff5fd64739f</a>
-<blockquote>
-<p>
- Fix freeing of monitor and semaphores for ICC cache. Bug 692372, customer 580.
-<br>
-
-<br>
- Rather than gs_free_object, monitors and semaphores should be freed with the functions
-<br>
- which clean up and OS interface parts, gx_monitor_free and gx_semaphore_free. By not
-<br>
- doing this we were leaving handles in use on Windows.
-<br>
-
-<br>
-gs/base/gsicc_cache.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-26 12:16:04 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0644acdc8866c32e16df09fae182efa3cddb23d5">0644acdc8866c32e16df09fae182efa3cddb23d5</a>
-<blockquote>
-<p>
- Change of Default CMYK profile to one created by us to emulate V2 SWOP with reduced footprint.
-<br>
-
-<br>
- Reviewed differences from this commit. With bmpcmp -16 the diffs amounted to halftone differences
-<br>
- with nothing visible.
-<br>
-
-<br>
-gs/iccprofiles/default_cmyk.icc
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-23 00:46: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=6039e0750306e2c3442b03c9ed5f7afee33a5540">6039e0750306e2c3442b03c9ed5f7afee33a5540</a>
-<blockquote>
-<p>
- mkromfs improvements, plus associated makefile changes.
-<br>
-
-<br>
- Enable Rays code to flatten the gs startup postscript files into one.
-<br>
- The code failed if the line length was too short, and could corrupt
-<br>
- data when splitting over 2 blocks. Both fixed.
-<br>
-
-<br>
- Also add -C and -B options to allow us to compact other postscript
-<br>
- files (without flattening). Very simple operation, but seems effective.
-<br>
-
-<br>
- Saves 640k on rom size after compression.
-<br>
-
-<br>
- Cluster testing shows 6 changes to the halftoning on cups files.
-<br>
- Impossible to tell if they are progressions or regressions, but
-<br>
- seems unlikely to be caused by this.
-<br>
-
-<br>
-gs/base/mkromfs.c
-<br>
-gs/psi/psromfs.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-26 14:49:26 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5e687126be8f4b7bc870fc58530f9343392670b5">5e687126be8f4b7bc870fc58530f9343392670b5</a>
-<blockquote>
-<p>
- Bug 691699: user specified cups install paths.
-<br>
-
-<br>
- Not quite as the bug describes, but we now implement --with-cups-serverbin,
-<br>
- --with-cups-serverroot and --with-cups-datadir to allow the user to
-<br>
- override the paths normally read from the cups-config utility.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-26 13:15: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=1094db4129bb70f9f7a0222683bc7f299cf4629a">1094db4129bb70f9f7a0222683bc7f299cf4629a</a>
-<blockquote>
-<p>
- Bug 691956: make installing the cups tools optional
-<br>
-
-<br>
- Introduces a --with-cups-install option to configure. To include the
-<br>
- cups tools and associated data files in Ghostscript's &quot;install&quot; target
-<br>
- you will have to specify &quot;--with-cups-install&quot; at configure time.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/configure.ac
-<br>
-gs/cups/cups.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-25 22:42:34 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eaec68d05c8d223cb97d89b6a3a9a96e550feeb2">eaec68d05c8d223cb97d89b6a3a9a96e550feeb2</a>
-<blockquote>
-<p>
- Change of default_rgb.icc to our own sRGB ICC profile.
-<br>
-
-<br>
- This results in very minor color diffs in a few files. I reviewed the diffs and everything is fine.
-<br>
-
-<br>
-gs/iccprofiles/default_rgb.icc
-<br>
-gs/iccprofiles/srgb.icc
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-25 19:03:42 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7ddcbdfbded0bae41818eeed4470686c911f2bc7">7ddcbdfbded0bae41818eeed4470686c911f2bc7</a>
-<blockquote>
-<p>
- Fixes 692360 - the x11cmyk get bits procedure would only work properly
-<br>
- with a client supplied data pointer.
-<br>
-
-<br>
-gs/base/gdevxalt.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-25 12:34: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=b9ff4a970e22194ecc894fe2460b88bc01726067">b9ff4a970e22194ecc894fe2460b88bc01726067</a>
-<blockquote>
-<p>
- Fixes 689502 - remove obsolete scripts.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/lib/bdftops
-<br>
-gs/lib/bdftops.bat
-<br>
-gs/lib/bdftops.cmd
-<br>
-gs/lib/bdftops.ps
-<br>
-gs/lib/fixmswrd.pl
-<br>
-gs/lib/pv.sh
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-05 09:02:28 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91954fa8aadd8f7168a4bfa5e219c5c73a5e7477">91954fa8aadd8f7168a4bfa5e219c5c73a5e7477</a>
-<blockquote>
-<p>
- 9.04 NEWS file.
-<br>
-
-<br>
-NEWS
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-05 12:07: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=24dd98a5274a3c43bb2b8d09ad3a29faa77e2aa8">24dd98a5274a3c43bb2b8d09ad3a29faa77e2aa8</a>
-<blockquote>
-<p>
- Ensure Win UNICODE/UTF8 code is disabled for ls build
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-language_switch/pspcl6_msvc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-05 12:05:23 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fac99700ffb230eaa4563dafd5af07033e5c608e">fac99700ffb230eaa4563dafd5af07033e5c608e</a>
-<blockquote>
-<p>
- Remove a now spurious debug message.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-05 09:47:19 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba7dbfdcaf930889e8f278629d646685ccf69405">ba7dbfdcaf930889e8f278629d646685ccf69405</a>
-<blockquote>
-<p>
- Prep the 9.04 release.
-<br>
-
-<br>
- Remove the &quot;RELEASE CANDIDATE&quot; string, bring the changelog up to date since
-<br>
- the RC, and revise the date.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/gscdef.c
-<br>
-gs/base/version.mak
-<br>
-gs/doc/API.htm
-<br>
-gs/doc/C-style.htm
-<br>
-gs/doc/Commprod.htm
-<br>
-gs/doc/DLL.htm
-<br>
-gs/doc/Deprecated.htm
-<br>
-gs/doc/Details8.htm
-<br>
-gs/doc/Details9.htm
-<br>
-gs/doc/Develop.htm
-<br>
-gs/doc/Devices.htm
-<br>
-gs/doc/Drivers.htm
-<br>
-gs/doc/Fonts.htm
-<br>
-gs/doc/Helpers.htm
-<br>
-gs/doc/History1.htm
-<br>
-gs/doc/History2.htm
-<br>
-gs/doc/History3.htm
-<br>
-gs/doc/History4.htm
-<br>
-gs/doc/History5.htm
-<br>
-gs/doc/History6.htm
-<br>
-gs/doc/History7.htm
-<br>
-gs/doc/History8.htm
-<br>
-gs/doc/History9.htm
-<br>
-gs/doc/Install.htm
-<br>
-gs/doc/Issues.htm
-<br>
-gs/doc/Language.htm
-<br>
-gs/doc/Lib.htm
-<br>
-gs/doc/Make.htm
-<br>
-gs/doc/News.htm
-<br>
-gs/doc/Projects.htm
-<br>
-gs/doc/Ps-style.htm
-<br>
-gs/doc/Ps2epsi.htm
-<br>
-gs/doc/Ps2pdf.htm
-<br>
-gs/doc/Ps2ps2.htm
-<br>
-gs/doc/Psfiles.htm
-<br>
-gs/doc/Readme.htm
-<br>
-gs/doc/Release.htm
-<br>
-gs/doc/Source.htm
-<br>
-gs/doc/Unix-lpr.htm
-<br>
-gs/doc/Use.htm
-<br>
-gs/doc/Xfonts.htm
-<br>
-gs/doc/gs-vms.hlp
-<br>
-gs/man/dvipdf.1
-<br>
-gs/man/font2c.1
-<br>
-gs/man/gs.1
-<br>
-gs/man/gslp.1
-<br>
-gs/man/gsnd.1
-<br>
-gs/man/pdf2dsc.1
-<br>
-gs/man/pdf2ps.1
-<br>
-gs/man/pdfopt.1
-<br>
-gs/man/pf2afm.1
-<br>
-gs/man/pfbtopfa.1
-<br>
-gs/man/printafm.1
-<br>
-gs/man/ps2ascii.1
-<br>
-gs/man/ps2epsi.1
-<br>
-gs/man/ps2pdf.1
-<br>
-gs/man/ps2pdfwr.1
-<br>
-gs/man/ps2ps.1
-<br>
-gs/man/wftopfa.1
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-04 14:40:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e173d22697b5489624783a805311337d053e53fe">e173d22697b5489624783a805311337d053e53fe</a>
-<blockquote>
-<p>
- Bug 691586: again, ensure that GS knows when cups changes the media size
-<br>
-
-<br>
- Move the fix for Bug 692393 to immediately after the call to
-<br>
- gdev_prn_put_params() - before the call to gx_device_set_media_size()
-<br>
- as that can also change the device's width and height settings.
-<br>
-
-<br>
- With this fix, I have also removed the temporary workaround put in place
-<br>
- with commits 16c410fc29575abffb60926949433653186915fd and
-<br>
- bd33c8f57b1a6e3d365ef0efd8dd7571a14310fa.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-04 10:05: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=6fc00870dd9d1e17709b532f425578b229a61544">6fc00870dd9d1e17709b532f425578b229a61544</a>
-<blockquote>
-<p>
- Revise Luratech section of build docs.......
-<br>
-
-<br>
- ... to reflect that we now look for the Luratech code under
-<br>
- gs/luratech/ldf_jb2 and gs/luratech/lwf_jp2 instead of gs/lwf_jp2 and
-<br>
- gs/ldf_jb2
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/doc/Make.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-03 17:44: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=a26ed9754118ab5a6027346f2e4d0c41077dfc1c">a26ed9754118ab5a6027346f2e4d0c41077dfc1c</a>
-<blockquote>
-<p>
- Bug 692393: ensure GS realises cups changed the page dimensions.
-<br>
-
-<br>
- After having done media selection from the cups media list, we need to
-<br>
- ensure that GS realises that page dimensions in the device structure
-<br>
- may have changed since the raster memory was last created - this ensures
-<br>
- that GS will reallocate the memory, and correctly setup the
-<br>
- line_ptrs array for the new page size.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-01 16:28:52 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e6f2128efc15316a586813ff314bc037b1d36856">e6f2128efc15316a586813ff314bc037b1d36856</a>
-<blockquote>
-<p>
- Fixes on the gstoraster CUPS filter
-<br>
-
-<br>
- 1. gstoraster crashes when run outside CUPS (bug #692384)
-<br>
-
-<br>
- 2. All error messages issued by gstoraster are without newline (bug #692385)
-<br>
-
-<br>
- Thanks to Tim Waugh from Red Hat for the patches.
-<br>
-
-<br>
-gs/cups/colord.c
-<br>
-gs/cups/gstoraster.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-30 17:48:14 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9fcefea7e6e770efed7a237c3fc0e8649fba342a">9fcefea7e6e770efed7a237c3fc0e8649fba342a</a>
-<blockquote>
-<p>
- Fix bug 692349: UNICODE build of gs not available with VS2003 or VS6.
-<br>
-
-<br>
- Apply a slightly tweaked version of alexchers patch to define wmemset
-<br>
- when it's not provided by the headers.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/psi/dwtext.c
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-01 12:18:25 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=690a9464f7a7ff524519587b95ba8505b0f823d9">690a9464f7a7ff524519587b95ba8505b0f823d9</a>
-<blockquote>
-<p>
- Tweak to tkampeters previous commit to workaround bug 691586.
-<br>
-
-<br>
- Avoid warnings given on some platforms about &quot;unreachable code&quot; by
-<br>
- using an informative #define.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-08-01 13:05:09 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b4c67383d9e71b468b5384b7a63095864d3a9ae7">b4c67383d9e71b468b5384b7a63095864d3a9ae7</a>
-<blockquote>
-<p>
- CUPS Raster output device: Ignore RIP_MAX_CACHE environment variable
-<br>
-
-<br>
- Ghostscript is (at least currently) not able to work with hard-limited
-<br>
- space parameters. It crashes with a segmentation fault on many input
-<br>
- files then. Leaving the setting of these parameters fully automatic
-<br>
- Ghostscript works just fine. As in most distributions (Currently all
-<br>
- except Debian, Ubuntu, and their derivatives) CUPS imposes a hard
-<br>
- limit via the RIP_MAX_CACHE environment variable, the only way to
-<br>
- assure reliable working of Ghostscript is to ignore the parameter,
-<br>
- leaving the space parameters in automatic mode. For CUPS this should
-<br>
- be no regression, as print queues with other Ghostscript drivers (like
-<br>
- pxlcolor, ljet4, ...) worked without hard limits all the time and no
-<br>
- one complained.
-<br>
-
-<br>
- To ignore this RIP_MAX_CACHE we simply add a &quot;return&quot; right at the
-<br>
- beginning of this function. It will be removed when a real fix gets
-<br>
- into place.
-<br>
-
-<br>
- See http://bugs.ghostscript.com/show_bug.cgi?id=691586
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-30 11:56:53 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83abb6ca67829a1273ed4fdfc894a6af44c5c5ad">83abb6ca67829a1273ed4fdfc894a6af44c5c5ad</a>
-<blockquote>
-<p>
- Added &quot;-dNOINTERPOLATE&quot; to the Ghostscript command lines of the CUPS filters
-<br>
-
-<br>
- This makes rendering significantly faster and the output of normal
-<br>
- files comming as print jobs from applications does not show any
-<br>
- visible difference.
-<br>
-
-<br>
-gs/cups/gstoraster.c
-<br>
-gs/cups/pstopxl.in
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-29 14:01: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=83c7aba31ab324d015a39ec23ab9eb861c23d787">83c7aba31ab324d015a39ec23ab9eb861c23d787</a>
-<blockquote>
-<p>
- Another fix for cups RGBW. This gets the color set up properly for RGB.
-<br>
-
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-29 12:18:04 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db4b6b6d07c2b4a97bd0add6e3169874ec2d1af7">db4b6b6d07c2b4a97bd0add6e3169874ec2d1af7</a>
-<blockquote>
-<p>
- Fix for cups RGBW color space so that transparency works properly.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-29 08:14:04 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1d700d4d052e3a9a061e5d6c61e3a4a30e5135d">d1d700d4d052e3a9a061e5d6c61e3a4a30e5135d</a>
-<blockquote>
-<p>
- A test for fixing RGBW in gdevcups.c
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-29 10:12:26 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=43f6fff7185f868104f6ba4afc102af4f9fe8f3f">43f6fff7185f868104f6ba4afc102af4f9fe8f3f</a>
-<blockquote>
-<p>
- Update the docs, version numbers, and dates for 9.04 rc1
-<br>
-
-<br>
-gs/base/gscdef.c
-<br>
-gs/base/version.mak
-<br>
-gs/doc/API.htm
-<br>
-gs/doc/C-style.htm
-<br>
-gs/doc/Commprod.htm
-<br>
-gs/doc/DLL.htm
-<br>
-gs/doc/Deprecated.htm
-<br>
-gs/doc/Details8.htm
-<br>
-gs/doc/Details9.htm
-<br>
-gs/doc/Develop.htm
-<br>
-gs/doc/Devices.htm
-<br>
-gs/doc/Drivers.htm
-<br>
-gs/doc/Fonts.htm
-<br>
-gs/doc/Helpers.htm
-<br>
-gs/doc/History1.htm
-<br>
-gs/doc/History2.htm
-<br>
-gs/doc/History3.htm
-<br>
-gs/doc/History4.htm
-<br>
-gs/doc/History5.htm
-<br>
-gs/doc/History6.htm
-<br>
-gs/doc/History7.htm
-<br>
-gs/doc/History8.htm
-<br>
-gs/doc/History9.htm
-<br>
-gs/doc/Install.htm
-<br>
-gs/doc/Issues.htm
-<br>
-gs/doc/Language.htm
-<br>
-gs/doc/Lib.htm
-<br>
-gs/doc/Make.htm
-<br>
-gs/doc/News.htm
-<br>
-gs/doc/Projects.htm
-<br>
-gs/doc/Ps-style.htm
-<br>
-gs/doc/Ps2epsi.htm
-<br>
-gs/doc/Ps2pdf.htm
-<br>
-gs/doc/Ps2ps2.htm
-<br>
-gs/doc/Psfiles.htm
-<br>
-gs/doc/Readme.htm
-<br>
-gs/doc/Release.htm
-<br>
-gs/doc/Source.htm
-<br>
-gs/doc/Unix-lpr.htm
-<br>
-gs/doc/Use.htm
-<br>
-gs/doc/Xfonts.htm
-<br>
-gs/doc/gs-vms.hlp
-<br>
-gs/man/dvipdf.1
-<br>
-gs/man/font2c.1
-<br>
-gs/man/gs.1
-<br>
-gs/man/gslp.1
-<br>
-gs/man/gsnd.1
-<br>
-gs/man/pdf2dsc.1
-<br>
-gs/man/pdf2ps.1
-<br>
-gs/man/pdfopt.1
-<br>
-gs/man/pf2afm.1
-<br>
-gs/man/pfbtopfa.1
-<br>
-gs/man/printafm.1
-<br>
-gs/man/ps2ascii.1
-<br>
-gs/man/ps2epsi.1
-<br>
-gs/man/ps2pdf.1
-<br>
-gs/man/ps2pdfwr.1
-<br>
-gs/man/ps2ps.1
-<br>
-gs/man/wftopfa.1
-<br>
-pl/pl.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-29 09:40: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=d248b98753421668ca683d074709a9422267b9ba">d248b98753421668ca683d074709a9422267b9ba</a>
-<blockquote>
-<p>
- Change the expected directory for luratech.
-<br>
-
-<br>
- For the build system to automatically include the luratech JPX and JBIG2
-<br>
- code, we previously checked for the existence of lwf_jp2 and ldf_jb2
-<br>
- directories under the Ghostscript source dir. This changes it to check
-<br>
- for &lt;gs&gt;/luratech/lwf_jp2 and &lt;gs&gt;/luratech/ldf_jb2 instead.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-28 22:28:37 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea57ffb4eb8e3c2bd9ae80547cd7ad011631e212">ea57ffb4eb8e3c2bd9ae80547cd7ad011631e212</a>
-<blockquote>
-<p>
- Restore X11 device to the default unix device.
-<br>
-
-<br>
- In setting up autoconf to detect X11 (9b7298f) the X11 devices were
-<br>
- not put back at the beginning of the device list and so were no longer
-<br>
- the default device.
-<br>
-
-<br>
-main/pcl6_gcc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-28 17:16:35 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c1cfbc2655dce2a1c3cc73caf0af54a51db61bfe">c1cfbc2655dce2a1c3cc73caf0af54a51db61bfe</a>
-<blockquote>
-<p>
- Changes to lcms v1 to spot failed allocations.
-<br>
-
-<br>
- lcms v1 sometimes forgets to deal with failed allocations. Patch at
-<br>
- least some of these problems.
-<br>
-
-<br>
- Driven by bug 692352. Sufficient to make it run to completion now.
-<br>
-
-<br>
-gs/lcms/src/cmsgmt.c
-<br>
-gs/lcms/src/cmslut.c
-<br>
-gs/lcms/src/cmsps2.c
-<br>
-gs/lcms/src/cmssamp.c
-<br>
-gs/lcms/src/cmsvirt.c
-<br>
-gs/lcms/src/cmswtpnt.c
-<br>
-gs/lcms/src/cmsxform.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-28 17:08:58 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0f6629c581fb56ca33fb7ec57d757ea96f236887">0f6629c581fb56ca33fb7ec57d757ea96f236887</a>
-<blockquote>
-<p>
- Check for failure to allocate icclink in shading.
-<br>
-
-<br>
- When calling shade_init_fill_state, check for a return code to indicate
-<br>
- failure. Trigger this case when an attempt to allocate an icclink
-<br>
- fails.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/base/gxshade.c
-<br>
-gs/base/gxshade.h
-<br>
-gs/base/gxshade1.c
-<br>
-gs/base/gxshade4.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-28 15:07:14 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f31edd69e23236fbae4b986883df8e0f43f15af6">f31edd69e23236fbae4b986883df8e0f43f15af6</a>
-<blockquote>
-<p>
- Fix typo in rc_decrement description string.
-<br>
-
-<br>
- Simple typo fix. CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-28 10:21: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=2364173a3ea2ac1e58b53a68e775d98157035b03">2364173a3ea2ac1e58b53a68e775d98157035b03</a>
-<blockquote>
-<p>
- Disable the Windows UNICODE/UTF8 code for now.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-27 22:12:41 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cf056ad9ccf42b8c31e6c84ed0ee6d30e0fb7455">cf056ad9ccf42b8c31e6c84ed0ee6d30e0fb7455</a>
-<blockquote>
-<p>
- Update of Use.htm to include new color control options.
-<br>
-
-<br>
-gs/doc/Use.htm
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-27 16:25:19 +0100
-</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=12faa934ff19d95f08fc9db33d7a6b288ba67ee2">12faa934ff19d95f08fc9db33d7a6b288ba67ee2</a>
-<blockquote>
-<p>
- Fix Bug 692368; SEGV with clist transparency pattern in clist rendering.
-<br>
-
-<br>
- The invocation/file given in the bug uses banded rendering (clist).
-<br>
- While drawing a band, it uses a pattern with transparency, that is
-<br>
- itself rendered by a clist (using the new pattern clist code).
-<br>
-
-<br>
- A fill rectangle is being done that tries to call the pattern clist
-<br>
- tiling code without the fill_trans_buffer having been setup, and
-<br>
- this causes a SEGV.
-<br>
-
-<br>
- The reason for this appears to be that the device used by the
-<br>
- banded isn't a pdf14 device - instead it's a clipper device wrapping
-<br>
- the pdf14 device. The clipper device does not call gx_forward_fill_path,
-<br>
- but instead calls gx_default_fill_path, meaning that the special
-<br>
- pdf14 handling done to setup the fill_trans_buffer isn't done.
-<br>
-
-<br>
- Making the commit call onwards to gx_forward_fill_path doesn't solve the
-<br>
- problem either, as that results in no actual clipping being done.
-<br>
-
-<br>
- The fix, therefore appears to be to implement a clipping version of
-<br>
- fill_path.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gxclip.c
-<br>
-gs/base/gxclip.h
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-27 22:14:10 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3639f0da216f0472658b37ee96726b80abdc7d56">3639f0da216f0472658b37ee96726b80abdc7d56</a>
-<blockquote>
-<p>
- Fixed the problem that PCL-XL output files got huge after introduction of color management
-<br>
-
-<br>
- The pxlmono and pxlcolor output devices produce PCL XL (PCL 6). With
-<br>
- the introduction of color management, the size of the output files
-<br>
- often got 10 times larger as before and so PCL XL jobs often did not
-<br>
- print as they exhausted the memory of the printer.
-<br>
-
-<br>
- According to the contributor of this patch, Shailesh Mistry, the PDFs
-<br>
- leading to that problem have a DeviceRGB image which is translated
-<br>
- into an ICC profile and passed up but the pcl/pxl can not handle
-<br>
- it. This patch looks for incoming ICC profiles and resolves it into
-<br>
- the base colour which can be handled at this level.
-<br>
-
-<br>
- The patch returns the size of the PCL XL output files to the old
-<br>
- values from Ghostscript 8.x.
-<br>
-
-<br>
- Fixes bug 692329.
-<br>
-
-<br>
-gs/base/gdevpx.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-27 20:37:20 +0200
-</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d6e940a92e47f0110438cf2f9bd6ebffa2f9e211">d6e940a92e47f0110438cf2f9bd6ebffa2f9e211</a>
-<blockquote>
-<p>
- Fixes on the &quot;pstopxl&quot; CUPS filter
-<br>
-
-<br>
- 1. Use POSIX and not Perl regular expressions with sed. This makes the
-<br>
- script working on a wider scope of systems (Bug #692328).
-<br>
-
-<br>
- 2. Switch the Ghostscript output device &quot;pxlmono&quot; if the &quot;pxlcolor&quot; is
-<br>
- used but &quot;Gray&quot; chosen as &quot;ColorModel&quot; setting. Monochrome
-<br>
- &quot;BitsPerPixel&quot; settings do not work with &quot;pxlcolor&quot;.
-<br>
-
-<br>
-gs/cups/pstopxl.in
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-27 10:41:14 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fead331855bddda90406d220e84fe5a284b2daa9">fead331855bddda90406d220e84fe5a284b2daa9</a>
-<blockquote>
-<p>
- Fix for Windows Display Device showing gray only
-<br>
-
-<br>
- This returns the use of DeviceGrayToK=true/false to set
-<br>
- if the user wants DeviceGray to map to K only for a
-<br>
- CMYK device. Also, this fixes a problem where high
-<br>
- level gray scale images were always going to composite
-<br>
- an not K only. Bug 692204.
-<br>
-
-<br>
-gs/base/gsdparam.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gxclrast.c
-<br>
-gs/psi/zdevice.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-27 09:14:04 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc18980047abde427405973a6c9452959fb8e93c">dc18980047abde427405973a6c9452959fb8e93c</a>
-<blockquote>
-<p>
- Replacement of default gray ICC profile with Artifex generated versions
-<br>
-
-<br>
- I reviewed the bmpcmp results and the relatively few diffs are minor.
-<br>
-
-<br>
-gs/iccprofiles/default_gray.icc
-<br>
-gs/iccprofiles/sgray.icc
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-26 12:16:04 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cdbc852a9220c324b9094c448e29ce3548a5b8c3">cdbc852a9220c324b9094c448e29ce3548a5b8c3</a>
-<blockquote>
-<p>
- Change of Default CMYK profile to one created by us to emulate V2 SWOP with reduced footprint.
-<br>
-
-<br>
- Reviewed differences from this commit. With bmpcmp -16 the diffs amounted to halftone differences
-<br>
- with nothing visible.
-<br>
-
-<br>
-gs/iccprofiles/default_cmyk.icc
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-25 22:42:34 -0700
-</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dca23749d5222c591927e78fd4f79a8d649ecd7c">dca23749d5222c591927e78fd4f79a8d649ecd7c</a>
-<blockquote>
-<p>
- Change of default_rgb.icc to our own sRGB ICC profile.
-<br>
-
-<br>
- This results in very minor color diffs in a few files. I reviewed the diffs and everything is fine.
-<br>
-
-<br>
-gs/iccprofiles/default_rgb.icc
-<br>
-gs/iccprofiles/srgb.icc
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-25 19:03:42 -0600
-</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba7054ed86bdb26c1c19aad0d5a4313e8b96c4df">ba7054ed86bdb26c1c19aad0d5a4313e8b96c4df</a>
-<blockquote>
-<p>
- Fixes 692360 - the x11cmyk get bits procedure would only work properly
-<br>
- with a client supplied data pointer.
-<br>
-
-<br>
-gs/base/gdevxalt.c
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-25 12:34: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=2ed6a01d99cc63f9953be1e29b9d05643e9ada73">2ed6a01d99cc63f9953be1e29b9d05643e9ada73</a>
-<blockquote>
-<p>
- Fixes 689502 - remove obsolete scripts.
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/lib/bdftops
-<br>
-gs/lib/bdftops.bat
-<br>
-gs/lib/bdftops.cmd
-<br>
-gs/lib/bdftops.ps
-<br>
-gs/lib/fixmswrd.pl
-<br>
-gs/lib/pv.sh
-<br>
-<p>
-</blockquote>
-<hr>
-<p><strong>2011-07-26 13:15: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=7ec7b1463507ba578e123dc15f4219472a09930f">7ec7b1463507ba578e123dc15f4219472a09930f</a>
-<blockquote>
-<p>
- Bug 691956: make installing the cups tools optional
-<br>
-
-<br>
- Introduces a --with-cups-install option to configure. To include the
-<br>
- cups tools and associated data files in Ghostscript's &quot;install&quot; target
-<br>
- you will have to specify &quot;--with-cups-install&quot; at configure time.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/configure.ac
-<br>
-gs/cups/cups.mak
-<br>
-<p>
-</blockquote>
-<hr>
-<hr size=20>
-
-<h2><a name="Version9.04"></a>Version 9.04 (2011-08-05)</h2>
-
-<p>This is the fourth full release in the stable 9.x series.
-
-<p>This release includes fixes and solutions for a number of serious problems
-from the earlier 9.x releases and so we <b>strongly</b> encourage those using
-earlier 9.x releases to upgrade to this new version, to reap the benefits of
-those fixes.
-
-<p>In addition, those still using Ghostscript 8.71 and earlier should begin
-migration to 9.x soon since many improvements, features and fixes from the 9.x
-versions are impractical to back-port to these legacy versions.
-
-<p> Highlights in this release include:
-<ul>
-<li>
-Transition source base to git source control - not a big deal for most users,
-but an important change for those who develop Ghostscript and GhostPDL.
-<br>
-</li>
-<li>
-This release introduces flexibility for controlling color based upon the
-graphic object type. In particular, it is now possible to specify unique
-output ICC profiles and rendering intents for vector graphic, image and text
-portions of a document. It is also possible to override source color
-specifications and use specified ICC profiles and rendering intents for
-RGB and CMYK vector graphics, images and text portions of a document. Finally,
-DeviceGray source colors can now easily be specified to map either to K only
-or composite CMYK when the output device supports CMYK colorants.
-<br>
-</li>
-<li>
-New tiffscaled8 and tiffscaled24 devices. Add new tiffscaled8 and tiffscaled24
-devices, copied and modified from tiffscaled. These output grayscale and 24bit rgb
-instead of tiffscaleds mono output. MinFeatureSize is ignored for these devices as
-it's meaningless for contone output. Downscaling is also now supported for png16m
-and pnggray, and a new pngmonod device has been implemented which uses grayscale
-rendering internally and then downscales/min_feature_sizes/error diffuses to monochrome.
-<br>
-</li>
-<li>
-The PDF interpreter will now try to continue interpreting a PDF after encountering
-an error in a stream. The previous bevahior can be reinstated by passing
--dPDFSTOPONERROR to Ghostscript.
-<br>
-</li>
-<li>
-Re-enable x11alpha as the default device on Unix systems, now that compatibility
-problems between anti-aliased output and transparency are resolved.
-<br>
-</li>
-<li>
-Update libjpeg to version 8c.
-<br>
-</li>
-<li>
-<u><b> Experimental Text output/extraction device</b></u>
-<p> The txtwrite device has undergone some development, and now has genuine
-functionality. It accepts any input format which GhostPDL supports, and uses a
-combination of methods to try and determine the Unicode values for any text
-contained in the document.
-
-<p>The code descends a hierarchy of methods in this process, starting with the
-most reliable and only falling back to less reliable methods when better methods
-fail. The current hierarchy is as follows:
-
-<ol>
-<li> ToUnicode CMaps (PostScript or PDF) or GlyphNamesToUnicode tables (PostScript).</li>
-<li> Glyph names of the form 'unixxxx'.</li>
-<li> Glyph names defined in the Adobe Glyph List document.</li>
-<li> Input character code.</li>
-</ol>
-
-<p>Method 1 is highly reliable, method 4 is a best guess and not terribly
-reliable, though it will work for many files. It is probably most reliable
-for PostScript and PCL files.
-
-<p> The device currently has one parameter 'TextFormat' which controls whether
-the output is Unicode text reflecting the layout of the original document
-(-dTextFormat=0) or a format intended for use by developers which includes the
-Unicode text and some formatting information, such as the size and position of
-the text, and the font in use (-dTextFormat=1).
-
-<p> Note that his device does not do OCR (Optical Character Recognition) it is
-not capable of finding 'text' which is part of an image. However it will recover
-the 'invisible' text from PDF documents which have been scanned and OCR'ed
-by Acrobat for searching. Such text has a render mode of 3.
-
-<p> This is the first release of this code and is very much an alpha release, we
-expect problems.
-
-<p> In particular the TextFormat=0 output is likely to be incorrect, and will
-only work with top-to-bottom left-to-right text. It will probably also be
-confused by landscape documents printed on portrait media.
-
-<p> TextFormat=1 should be more reliable, but there may be cases where text is
-dropped from the output. Text in PostScript documents using charpath is not yet
-supported for example.
-
-<p> We do encourage feedback on the state of this device, and would be
-interested in hearing what kind of output would be useful for developers
-using TextFormat=1. For now, however, please do not raise bugs through Bugzilla,
-instead please send feedback to the gs-devel mailing list.
-<br>
-</li>
-<li>
-<u><b> Experimental Unicode/UTF8 Support on Windows</b></u>
-<p>This release introduces some experimental build-time optional support
-for UNICODE pathnames on Windows. Essentially this works by following
-the model that Linux (and MacOS) have followed for years.
-
-<p>If this code is enabled, then the way ghostscript handles command lines,
-registry settings, file accesses and other api calls with top bit set
-characters in (i.e. codes >= 128) will change. The net benefit of this
-change is that ghostscript will now be able to cope with accessing
-files with unicode characters (i.e. codes >= 256) in their pathnames.
-
-<p>This behavior is all completely transparent to users, with the exception
-of those calling the gsapi functions with strings including 'extended
-ascii' (i.e. characters with codes >= 128 and <= 255). These characters
-include accented latin characters, such as u + umlaut, a + grave etc.
-The changes required for code that is affected by this are relatively
-minor, but as this is a change to the current API, we are announcing
-it in advance, and inviting comments.
-
-<p>As of the 9.04 release, the code is disabled. For those who wish to
-experiment you will need to build Ghostscript from source, and either
-pass USEUNICODE=1 when you invoke nmake or edit psi/msvc.mak to remove
-the /DWINDOWS_NO_UNICODE option from CFLAGS.
-
-<p>WARNING: Our intention, subject to feedback, is to enable this by
-default in near-future releases (hopefully, the next major release).
-If you make use of the affected APIs you should be prepared for the
-change to occur - be aware, however, that the current code is
-experimental and, depending on the feedback we get, maybe subject
-to change.
-
-<p>NOTE: this whole change refers to file paths, command line parameters
-and so on - it does not imply that we have unilaterally extended
-Postscript to understand UNICODE.
-
-<p>More details:
-
-<p>To give an example, suppose we have a file 'EXAMPLE' we'd like to
-invoke ghostscript on, where 'EXAMPLE' is actually a string that
-contains some characters with codes >= 128.
-
-<p>On Linux (or MacOS X), when ghostscript is called from a shell, e.g.
-
-<p> gs EXAMPLE
-
-<p>the command is UTF8 encoded; this means that characters with codes < 128
-are left unchanged, and characters >= 128 are encoded into multiple bytes.
-This encoded string is then passed to the standard 'main' entrypoint in
-the gs executable.
-
-<p>Ghostscript proceeds internally without any special handling of these
-multibyte characters at all. When it comes to access files it therefore
-passes out the UTF8 encoded strings to the standard OS file handling
-routines. These routines are designed to take pathnames in UTF8 format,
-and thus the files are accessed as normal.
-
-<p>If the Ghostscript executable outputs these (or other) strings to its
-stdout, the shell again converts the output from UTF8 back to unicode in
-order to display it.
-
-<p>The net effect is that the caller can seamlessly pass in unicode filenames,
-has his fileaccesses work out and gets unicode output without the core
-of ghostscript ever having to worry about it.
-
-<p>The code change discussed here endeavours to make Windows follow the same
-pattern as closely as possible.
-
-<p>When Windows executables are invoked, they can either be called through
-an 'ascii' entrypoint (main), or through a unicode ('wide') entrypoint
-(wmain). The difference is invisible to the caller, except that unicode
-executables can accept characters >= 256 in their invocations.
-
-<p>The new code changes ghostscript from being an ascii executable to being
-a unicode one. The Windows specific outer layer takes the unicode
-command string and UTF8 encodes it before passing it to the ghostscript
-core.
-
-<p>Similarly, the Windows specific filing system calls are updated to
-accept utf8 encoded strings from the core, and to convert them to
-unicode before operating on them.
-
-<p>The Windows gui app (gswin32.exe, NOT gswin32c.exe) is also updated to
-convert stdin/stdout between unicode and utf8 as appropriate, allowing
-unicode strings to be copied/pasted to/from other apps.
-
-<p>All of this should be completely transparent to the user, and no code
-changes should be required. The one area where changes may be required
-are where ghostscript is invoked through the gsapi functions.
-
-<p>Currently, on Linux (and MacOS X) any strings sent over the gsapi are
-assumed to be utf8 encoded (and thus can represent any Unicode
-character). On Windows, they are assumed simply to be in extended ASCII
-(and can therefore represent any character < 256 in the current codepage).
-With the proposed change, Windows will move to be in step with Linux.
-No differences will be caused to anyone who only uses chars <= 128,
-but those people using character codes between 128 and 256 (or indeed
-wanting to use higher codes) will need to utf8 encode the strings before
-calling gsapi functions.
-
-<p>Such encoding/decoding is a very simple process, and code for both
-directions can be found in psi/dwmain.c, psi/dwmainc.c and psi/dwtext.c.
-
-<p> Again, we welcome feedback on this feature, in this case problems
-or suggestions about the implementation can be submitted via Bugzilla
-but for detailed discussion about the approach for which we opted, it
-would be more beneficial discuss it (preferably) on our IRC channel
-#ghostscript on freenode.net, or on the gs-devel mailing list.
-<br>
-</li>
-</ul>
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.04_Incompatible_changes"></a>Incompatible changes</h3>
-
-<p> Deprecated file "gs/base/errors.h" removed, psi/ierrors.h should be used
-instead.
-
-<p> The eXternal Fonts (XFonts) functionality, marked as deprecated in 9.02
-has now been fully removed.
-
-<p>
-No other recorded incompatible changes.
-
-<h3><a name="9.04_Changelog"></a>Changelog</h3>
-<p><strong>2011-08-04 14:40:12 +0100
-</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e173d22697b5489624783a805311337d053e53fe">e173d22697b5489624783a805311337d053e53fe</a>
-<blockquote>
-
-<br>
- Bug 691586: again, ensure that GS knows when cups changes the media size
-<br>
-
-<br>
- Move the fix for Bug 692393 to immediately after the call to
-<br>
- gdev_prn_put_params() - before the call to gx_device_set_media_size()
-<br>
- as that can also change the device's width and height settings.
-<br>
-
-<br>
- With this fix, I have also removed the temporary workaround put in place
-<br>
- with commits 16c410fc29575abffb60926949433653186915fd and
-<br>
- bd33c8f57b1a6e3d365ef0efd8dd7571a14310fa.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-08-04 10:05:13 +0100></a>
-2011-08-04 10:05: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=6fc00870dd9d1e17709b532f425578b229a61544">6fc00870dd9d1e17709b532f425578b229a61544</a>
-<blockquote>
-
-<br>
- Revise Luratech section of build docs.......
-<br>
-
-<br>
- ... to reflect that we now look for the Luratech code under
-<br>
- gs/luratech/ldf_jb2 and gs/luratech/lwf_jp2 instead of gs/lwf_jp2 and
-<br>
- gs/ldf_jb2
-<br>
-
-<br>
- CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/doc/Make.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-08-03 17:44:55 +0100></a>
-2011-08-03 17:44: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=a26ed9754118ab5a6027346f2e4d0c41077dfc1c">a26ed9754118ab5a6027346f2e4d0c41077dfc1c</a>
-<blockquote>
-
-<br>
- Bug 692393: ensure GS realises cups changed the page dimensions.
-<br>
-
-<br>
- After having done media selection from the cups media list, we need to
-<br>
- ensure that GS realises that page dimensions in the device structure
-<br>
- may have changed since the raster memory was last created - this ensures
-<br>
- that GS will reallocate the memory, and correctly setup the
-<br>
- line_ptrs array for the new page size.
-<br>
-
-<br>
- No cluster differences.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-08-01 16:28:52 +0200></a>
-2011-08-01 16:28:52 +0200</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e6f2128efc15316a586813ff314bc037b1d36856">e6f2128efc15316a586813ff314bc037b1d36856</a>
-<blockquote>
-
-<br>
- Fixes on the gstoraster CUPS filter
-<br>
-
-<br>
- 1. gstoraster crashes when run outside CUPS (bug #692384)
-<br>
-
-<br>
- 2. All error messages issued by gstoraster are without newline (bug #692385)
-<br>
-
-<br>
- Thanks to Tim Waugh from Red Hat for the patches.
-<br>
-
-<br>
-gs/cups/colord.c
-<br>
-gs/cups/gstoraster.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-30 17:48:14 +0100></a>
-2011-07-30 17:48:14 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9fcefea7e6e770efed7a237c3fc0e8649fba342a">9fcefea7e6e770efed7a237c3fc0e8649fba342a</a>
-<blockquote>
-
-<br>
- Fix bug 692349: UNICODE build of gs not available with VS2003 or VS6.
-<br>
-
-<br>
- Apply a slightly tweaked version of alexchers patch to define wmemset
-<br>
- when it's not provided by the headers.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/psi/dwtext.c
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-08-01 12:18:25 +0100></a>
-2011-08-01 12:18:25 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=690a9464f7a7ff524519587b95ba8505b0f823d9">690a9464f7a7ff524519587b95ba8505b0f823d9</a>
-<blockquote>
-
-<br>
- Tweak to tkampeters previous commit to workaround bug 691586.
-<br>
-
-<br>
- Avoid warnings given on some platforms about &quot;unreachable code&quot; by
-<br>
- using an informative #define.
-<br>
-
-<br>
- No cluster differences expected.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-08-01 13:05:09 +0200></a>
-2011-08-01 13:05:09 +0200</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b4c67383d9e71b468b5384b7a63095864d3a9ae7">b4c67383d9e71b468b5384b7a63095864d3a9ae7</a>
-<blockquote>
-
-<br>
- CUPS Raster output device: Ignore RIP_MAX_CACHE environment variable
-<br>
-
-<br>
- Ghostscript is (at least currently) not able to work with hard-limited
-<br>
- space parameters. It crashes with a segmentation fault on many input
-<br>
- files then. Leaving the setting of these parameters fully automatic
-<br>
- Ghostscript works just fine. As in most distributions (Currently all
-<br>
- except Debian, Ubuntu, and their derivatives) CUPS imposes a hard
-<br>
- limit via the RIP_MAX_CACHE environment variable, the only way to
-<br>
- assure reliable working of Ghostscript is to ignore the parameter,
-<br>
- leaving the space parameters in automatic mode. For CUPS this should
-<br>
- be no regression, as print queues with other Ghostscript drivers (like
-<br>
- pxlcolor, ljet4, ...) worked without hard limits all the time and no
-<br>
- one complained.
-<br>
-
-<br>
- To ignore this RIP_MAX_CACHE we simply add a &quot;return&quot; right at the
-<br>
- beginning of this function. It will be removed when a real fix gets
-<br>
- into place.
-<br>
-
-<br>
- See http://bugs.ghostscript.com/show_bug.cgi?id=691586
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-30 11:56:53 +0200></a>
-2011-07-30 11:56:53 +0200</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=83abb6ca67829a1273ed4fdfc894a6af44c5c5ad">83abb6ca67829a1273ed4fdfc894a6af44c5c5ad</a>
-<blockquote>
-<p>
- Added &quot;-dNOINTERPOLATE&quot; to the Ghostscript command lines of the CUPS filters
-<br>
-
-<br>
- This makes rendering significantly faster and the output of normal
-<br>
- files comming as print jobs from applications does not show any
-<br>
- visible difference.
-<br>
-
-<br>
-gs/cups/gstoraster.c
-<br>
-gs/cups/pstopxl.in
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-29 14:01:58 -0700></a>
-2011-07-29 14:01: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=83c7aba31ab324d015a39ec23ab9eb861c23d787">83c7aba31ab324d015a39ec23ab9eb861c23d787</a>
-<blockquote>
-
-<br>
- Another fix for cups RGBW. This gets the color set up properly for RGB.
-<br>
-
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-29 12:18:04 -0700></a>
-2011-07-29 12:18:04 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db4b6b6d07c2b4a97bd0add6e3169874ec2d1af7">db4b6b6d07c2b4a97bd0add6e3169874ec2d1af7</a>
-<blockquote>
-
-<br>
- Fix for cups RGBW color space so that transparency works properly.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-29 08:14:04 -0700></a>
-2011-07-29 08:14:04 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1d700d4d052e3a9a061e5d6c61e3a4a30e5135d">d1d700d4d052e3a9a061e5d6c61e3a4a30e5135d</a>
-<blockquote>
-
-<br>
- A test for fixing RGBW in gdevcups.c
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-29 10:12:26 +0100></a>
-2011-07-29 10:12:26 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=43f6fff7185f868104f6ba4afc102af4f9fe8f3f">43f6fff7185f868104f6ba4afc102af4f9fe8f3f</a>
-<blockquote>
-
-<br>
- Update the docs, version numbers, and dates for 9.04 rc1
-<br>
-
-<br>
-gs/base/gscdef.c
-<br>
-gs/base/version.mak
-<br>
-gs/doc/API.htm
-<br>
-gs/doc/C-style.htm
-<br>
-gs/doc/Commprod.htm
-<br>
-gs/doc/DLL.htm
-<br>
-gs/doc/Deprecated.htm
-<br>
-gs/doc/Details8.htm
-<br>
-gs/doc/Details9.htm
-<br>
-gs/doc/Develop.htm
-<br>
-gs/doc/Devices.htm
-<br>
-gs/doc/Drivers.htm
-<br>
-gs/doc/Fonts.htm
-<br>
-gs/doc/Helpers.htm
-<br>
-gs/doc/History1.htm
-<br>
-gs/doc/History2.htm
-<br>
-gs/doc/History3.htm
-<br>
-gs/doc/History4.htm
-<br>
-gs/doc/History5.htm
-<br>
-gs/doc/History6.htm
-<br>
-gs/doc/History7.htm
-<br>
-gs/doc/History8.htm
-<br>
-gs/doc/History9.htm
-<br>
-gs/doc/Install.htm
-<br>
-gs/doc/Issues.htm
-<br>
-gs/doc/Language.htm
-<br>
-gs/doc/Lib.htm
-<br>
-gs/doc/Make.htm
-<br>
-gs/doc/News.htm
-<br>
-gs/doc/Projects.htm
-<br>
-gs/doc/Ps-style.htm
-<br>
-gs/doc/Ps2epsi.htm
-<br>
-gs/doc/Ps2pdf.htm
-<br>
-gs/doc/Ps2ps2.htm
-<br>
-gs/doc/Psfiles.htm
-<br>
-gs/doc/Readme.htm
-<br>
-gs/doc/Release.htm
-<br>
-gs/doc/Source.htm
-<br>
-gs/doc/Unix-lpr.htm
-<br>
-gs/doc/Use.htm
-<br>
-gs/doc/Xfonts.htm
-<br>
-gs/doc/gs-vms.hlp
-<br>
-gs/man/dvipdf.1
-<br>
-gs/man/font2c.1
-<br>
-gs/man/gs.1
-<br>
-gs/man/gslp.1
-<br>
-gs/man/gsnd.1
-<br>
-gs/man/pdf2dsc.1
-<br>
-gs/man/pdf2ps.1
-<br>
-gs/man/pdfopt.1
-<br>
-gs/man/pf2afm.1
-<br>
-gs/man/pfbtopfa.1
-<br>
-gs/man/printafm.1
-<br>
-gs/man/ps2ascii.1
-<br>
-gs/man/ps2epsi.1
-<br>
-gs/man/ps2pdf.1
-<br>
-gs/man/ps2pdfwr.1
-<br>
-gs/man/ps2ps.1
-<br>
-gs/man/wftopfa.1
-<br>
-pl/pl.mak
-<br>
-<p>
-</blockquote>
-
-
-<p><strong><a name=2011-07-29 09:40:34 +0100></a>
-2011-07-29 09:40: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=d248b98753421668ca683d074709a9422267b9ba">d248b98753421668ca683d074709a9422267b9ba</a>
-<blockquote>
-
-<br>
-Change the expected directory for luratech.
-<br>
-
-<br>
-For the build system to automatically include the luratech JPX and JBIG2
-<br>
-code, we previously checked for the existence of lwf_jp2 and ldf_jb2
-<br>
-directories under the Ghostscript source dir. This changes it to check
-<br>
-for &lt;gs&gt;/luratech/lwf_jp2 and &lt;gs&gt;/luratech/ldf_jb2 instead.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-28 22:28:37 -0600></a>
-2011-07-28 22:28:37 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ea57ffb4eb8e3c2bd9ae80547cd7ad011631e212">ea57ffb4eb8e3c2bd9ae80547cd7ad011631e212</a>
-<blockquote>
-
-<br>
-Restore X11 device to the default unix device.
-<br>
-
-<br>
-In setting up autoconf to detect X11 (9b7298f) the X11 devices were
-<br>
-not put back at the beginning of the device list and so were no longer
-<br>
-the default device.
-<br>
-
-<br>
-main/pcl6_gcc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-28 17:16:35 +0100></a>
-2011-07-28 17:16:35 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c1cfbc2655dce2a1c3cc73caf0af54a51db61bfe">c1cfbc2655dce2a1c3cc73caf0af54a51db61bfe</a>
-<blockquote>
-
-<br>
-Changes to lcms v1 to spot failed allocations.
-<br>
-
-<br>
-lcms v1 sometimes forgets to deal with failed allocations. Patch at
-<br>
-least some of these problems.
-<br>
-
-<br>
-Driven by bug 692352. Sufficient to make it run to completion now.
-<br>
-
-<br>
-gs/lcms/src/cmsgmt.c
-<br>
-gs/lcms/src/cmslut.c
-<br>
-gs/lcms/src/cmsps2.c
-<br>
-gs/lcms/src/cmssamp.c
-<br>
-gs/lcms/src/cmsvirt.c
-<br>
-gs/lcms/src/cmswtpnt.c
-<br>
-gs/lcms/src/cmsxform.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-28 17:08:58 +0100></a>
-2011-07-28 17:08:58 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0f6629c581fb56ca33fb7ec57d757ea96f236887">0f6629c581fb56ca33fb7ec57d757ea96f236887</a>
-<blockquote>
-
-<br>
-Check for failure to allocate icclink in shading.
-<br>
-
-<br>
-When calling shade_init_fill_state, check for a return code to indicate
-<br>
-failure. Trigger this case when an attempt to allocate an icclink
-<br>
-fails.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gxshade.c
-<br>
-gs/base/gxshade.h
-<br>
-gs/base/gxshade1.c
-<br>
-gs/base/gxshade4.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-28 15:07:14 +0100></a>
-2011-07-28 15:07:14 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f31edd69e23236fbae4b986883df8e0f43f15af6">f31edd69e23236fbae4b986883df8e0f43f15af6</a>
-<blockquote>
-
-<br>
-Fix typo in rc_decrement description string.
-<br>
-
-<br>
-Simple typo fix. CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-
-<h3><a name="9.04_changelog"></a>Changelog</h3>
-<p><strong><a name=2011-07-28 10:21:31 +0100></a>
-2011-07-28 10:21: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=2364173a3ea2ac1e58b53a68e775d98157035b03">2364173a3ea2ac1e58b53a68e775d98157035b03</a>
-<blockquote>
-
-<br>
-Disable the Windows UNICODE/UTF8 code for now.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-27 22:12:41 -0700></a>
-2011-07-27 22:12:41 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cf056ad9ccf42b8c31e6c84ed0ee6d30e0fb7455">cf056ad9ccf42b8c31e6c84ed0ee6d30e0fb7455</a>
-<blockquote>
-
-<br>
-Update of Use.htm to include new color control options.
-<br>
-
-<br>
-gs/doc/Use.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-27 16:25:19 +0100></a>
-2011-07-27 16:25:19 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=12faa934ff19d95f08fc9db33d7a6b288ba67ee2">12faa934ff19d95f08fc9db33d7a6b288ba67ee2</a>
-<blockquote>
-
-<br>
-Fix Bug 692368; SEGV with clist transparency pattern in clist rendering.
-<br>
-
-<br>
-The invocation/file given in the bug uses banded rendering (clist).
-<br>
-While drawing a band, it uses a pattern with transparency, that is
-<br>
-itself rendered by a clist (using the new pattern clist code).
-<br>
-
-<br>
-A fill rectangle is being done that tries to call the pattern clist
-<br>
-tiling code without the fill_trans_buffer having been setup, and
-<br>
-this causes a SEGV.
-<br>
-
-<br>
-The reason for this appears to be that the device used by the
-<br>
-banded isn't a pdf14 device - instead it's a clipper device wrapping
-<br>
-the pdf14 device. The clipper device does not call gx_forward_fill_path,
-<br>
-but instead calls gx_default_fill_path, meaning that the special
-<br>
-pdf14 handling done to setup the fill_trans_buffer isn't done.
-<br>
-
-<br>
-Making the commit call onwards to gx_forward_fill_path doesn't solve the
-<br>
-problem either, as that results in no actual clipping being done.
-<br>
-
-<br>
-The fix, therefore appears to be to implement a clipping version of
-<br>
-fill_path.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gxclip.c
-<br>
-gs/base/gxclip.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-27 22:14:10 +0200></a>
-2011-07-27 22:14:10 +0200</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3639f0da216f0472658b37ee96726b80abdc7d56">3639f0da216f0472658b37ee96726b80abdc7d56</a>
-<blockquote>
-
-<br>
-Fixed the problem that PCL-XL output files got huge after introduction of color management
-<br>
-
-<br>
-The pxlmono and pxlcolor output devices produce PCL XL (PCL 6). With
-<br>
-the introduction of color management, the size of the output files
-<br>
-often got 10 times larger as before and so PCL XL jobs often did not
-<br>
-print as they exhausted the memory of the printer.
-<br>
-
-<br>
-According to the contributor of this patch, Shailesh Mistry, the PDFs
-<br>
-leading to that problem have a DeviceRGB image which is translated
-<br>
-into an ICC profile and passed up but the pcl/pxl can not handle
-<br>
-it. This patch looks for incoming ICC profiles and resolves it into
-<br>
-the base colour which can be handled at this level.
-<br>
-
-<br>
-The patch returns the size of the PCL XL output files to the old
-<br>
-values from Ghostscript 8.x.
-<br>
-
-<br>
-Fixes bug 692329.
-<br>
-
-<br>
-gs/base/gdevpx.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-27 20:37:20 +0200></a>
-2011-07-27 20:37:20 +0200</strong>
-<br>Till Kamppeter &lt;till.kamppeter@gmail.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d6e940a92e47f0110438cf2f9bd6ebffa2f9e211">d6e940a92e47f0110438cf2f9bd6ebffa2f9e211</a>
-<blockquote>
-<p>
- Fixes on the &quot;pstopxl&quot; CUPS filter
-<br>
-
-<br>
-1. Use POSIX and not Perl regular expressions with sed. This makes the
-<br>
-script working on a wider scope of systems (Bug #692328).
-<br>
-
-<br>
- 2. Switch the Ghostscript output device &quot;pxlmono&quot; if the &quot;pxlcolor&quot; is
-<br>
- used but &quot;Gray&quot; chosen as &quot;ColorModel&quot; setting. Monochrome
-<br>
- &quot;BitsPerPixel&quot; settings do not work with &quot;pxlcolor&quot;.
-<br>
-
-<br>
-gs/cups/pstopxl.in
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-27 10:41:14 -0700></a>
-2011-07-27 10:41:14 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fead331855bddda90406d220e84fe5a284b2daa9">fead331855bddda90406d220e84fe5a284b2daa9</a>
-<blockquote>
-
-<br>
-Fix for Windows Display Device showing gray only
-<br>
-
-<br>
-This returns the use of DeviceGrayToK=true/false to set
-<br>
-if the user wants DeviceGray to map to K only for a
-<br>
-CMYK device. Also, this fixes a problem where high
-<br>
-level gray scale images were always going to composite
-<br>
-an not K only. Bug 692204.
-<br>
-
-<br>
-gs/base/gsdparam.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gxclrast.c
-<br>
-gs/psi/zdevice.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-27 09:14:04 -0700></a>
-2011-07-27 09:14:04 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dc18980047abde427405973a6c9452959fb8e93c">dc18980047abde427405973a6c9452959fb8e93c</a>
-<blockquote>
-
-<br>
-Replacement of default gray ICC profile with Artifex generated versions
-<br>
-
-<br>
-I reviewed the bmpcmp results and the relatively few diffs are minor.
-<br>
-
-<br>
-gs/iccprofiles/default_gray.icc
-<br>
-gs/iccprofiles/sgray.icc
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-26 12:16:04 -0700></a>
-2011-07-26 12:16:04 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cdbc852a9220c324b9094c448e29ce3548a5b8c3">cdbc852a9220c324b9094c448e29ce3548a5b8c3</a>
-<blockquote>
-
-<br>
-Change of Default CMYK profile to one created by us to emulate V2 SWOP with reduced footprint.
-<br>
-
-<br>
-Reviewed differences from this commit. With bmpcmp -16 the diffs amounted to halftone differences
-<br>
-with nothing visible.
-<br>
-
-<br>
-gs/iccprofiles/default_cmyk.icc
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-25 22:42:34 -0700></a>
-2011-07-25 22:42:34 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dca23749d5222c591927e78fd4f79a8d649ecd7c">dca23749d5222c591927e78fd4f79a8d649ecd7c</a>
-<blockquote>
-
-<br>
-Change of default_rgb.icc to our own sRGB ICC profile.
-<br>
-
-<br>
-This results in very minor color diffs in a few files. I reviewed the diffs and everything is fine.
-<br>
-
-<br>
-gs/iccprofiles/default_rgb.icc
-<br>
-gs/iccprofiles/srgb.icc
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-25 19:03:42 -0600></a>
-2011-07-25 19:03:42 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ba7054ed86bdb26c1c19aad0d5a4313e8b96c4df">ba7054ed86bdb26c1c19aad0d5a4313e8b96c4df</a>
-<blockquote>
-
-<br>
-Fixes 692360 - the x11cmyk get bits procedure would only work properly
-<br>
-with a client supplied data pointer.
-<br>
-
-<br>
-gs/base/gdevxalt.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-25 12:34:59 -0600></a>
-2011-07-25 12:34: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=2ed6a01d99cc63f9953be1e29b9d05643e9ada73">2ed6a01d99cc63f9953be1e29b9d05643e9ada73</a>
-<blockquote>
-
-<br>
-Fixes 689502 - remove obsolete scripts.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/lib/bdftops
-<br>
-gs/lib/bdftops.bat
-<br>
-gs/lib/bdftops.cmd
-<br>
-gs/lib/bdftops.ps
-<br>
-gs/lib/fixmswrd.pl
-<br>
-gs/lib/pv.sh
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-26 13:15:44 +0100></a>
-2011-07-26 13:15: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=7ec7b1463507ba578e123dc15f4219472a09930f">7ec7b1463507ba578e123dc15f4219472a09930f</a>
-<blockquote>
-
-<br>
-Bug 691956: make installing the cups tools optional
-<br>
-
-<br>
-Introduces a --with-cups-install option to configure. To include the
-<br>
- cups tools and associated data files in Ghostscript's &quot;install&quot; target
-<br>
- you will have to specify &quot;--with-cups-install&quot; at configure time.
-<br>
-
-<br>
-No cluster differences.
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/configure.ac
-<br>
-gs/cups/cups.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-25 16:25:20 +0100></a>
-2011-07-25 16:25:20 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f62ce181e3a68d7f652d9e903c70bd1a67423782">f62ce181e3a68d7f652d9e903c70bd1a67423782</a>
-<blockquote>
-
-<br>
-Bug 692367: NULL out pointers for three tables in the context
-<br>
-
-<br>
- Add &quot;finalize&quot; methods for gs_name_table, io_device_table and
-<br>
-font_dir tables which ensure that the pointers in the lib
-<br>
-context are set to NULL when the memory is released.
-<br>
-
-<br>
-No cluster differences.
-<br>
-
-<br>
-gs/base/gsfont.c
-<br>
-gs/base/gsiodev.c
-<br>
-gs/base/gsstruct.h
-<br>
-gs/base/gxfcache.h
-<br>
-gs/psi/iname.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-25 16:19:19 +0100></a>
-2011-07-25 16:19: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=7dee8c1639a55e5b6ae4051afcfed9caa82e48b5">7dee8c1639a55e5b6ae4051afcfed9caa82e48b5</a>
-<blockquote>
-
-<br>
-Remove the last traces of OPDFReadProcsetPath
-<br>
-
-<br>
-The old Procsets had to be moved from PostScript resources to C files, in order that
-<br>
-ps2write work with non-PostScript interpreters (XPS, PCL). As a result the
-<br>
-old OPDFReadProcsetPath is no longer used and has been removed.
-<br>
-
-<br>
-gs/Resource/Init/gs_pdfwr.ps
-<br>
-gs/base/gdevpdf.c
-<br>
-gs/base/gdevpdfb.h
-<br>
-gs/base/gdevpdfp.c
-<br>
-gs/base/gdevpdfu.c
-<br>
-gs/base/gdevpdfx.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-25 09:05:05 +0100></a>
-2011-07-25 09:05: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=1562de0f7dc0615ed1397f42a7ad0eb23f4dcf22">1562de0f7dc0615ed1397f42a7ad0eb23f4dcf22</a>
-<blockquote>
-
-<br>
-Add some minimal documentation regarding the txtwrite device to devices.htm.
-<br>
-
-<br>
-gs/doc/Devices.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-25 08:44:42 +0100></a>
-2011-07-25 08:44:42 +0100</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4e6a7b5c6fc0c202ba0d962cd19578162e1ce726">4e6a7b5c6fc0c202ba0d962cd19578162e1ce726</a>
-<blockquote>
-
-<br>
-Add functionality to the textwrite device.
-<br>
-
-<br>
-The existing textwrite device was a null device which emitted nothing. This
-<br>
-version actually extracts text from input documents. It uses ToUnicode CMaps,
-<br>
-GlyphNames2Unicode tables and glyph names in an attempt to map incoming text into
-<br>
-Unicode (UTF-16) values.
-<br>
-
-<br>
-It currently has one switch 'TextFormat' which has two possible values, 0 or 1.
-<br>
--dTextFormat=0 outputs a 'layout' representation of the original text. This
-<br>
-will attempt to produce text output which is similar in appearance to the original.
-<br>
-
-<br>
--dTextFormat=1 simply emits all the text as it is encountered, along with information
-<br>
-about the text state. It outputs the Font name, point size, rendering mode and
-<br>
-writing mode (WMode) as well as the start and ending co-ordinates of the text on the page
-<br>
-and the Unicode string representing the text. This is intended for those who
-<br>
-would like to manipulate the text into other formats.
-<br>
-
-<br>
-The Adobe Glyph Names list is now embedded in the executable twice, in two
-<br>
-incompatible forms. A future enhanvement will be to only embed the list once.
-<br>
-
-<br>
-gs/base/gdevagl.h
-<br>
-gs/base/gdevtxtw.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-24 16:03:31 -0400></a>
-2011-07-24 16:03:31 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=128b9fce26e82ef38cedded8fc35a4c99ef55bee">128b9fce26e82ef38cedded8fc35a4c99ef55bee</a>
-<blockquote>
-
-<br>
-Fix a trivial Valgrind warning.
-<br>
-
-<br>
-Reorder a logical expression to prevent the access to an unitialized
-<br>
-value. The only effect of the patch is some noise reduction in the
-<br>
-Valgrind log.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-24 16:38:35 +0000></a>
-2011-07-24 16:38:35 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=961a9a98ecff7a30503ee0bd5d2973263114def7">961a9a98ecff7a30503ee0bd5d2973263114def7</a>
-<blockquote>
-
-<br>
-Backout commit 7f5d3d7; 8 bit display device palette change.
-<br>
-
-<br>
-Reverting earlier commit made to attempt to fix bug 692235. While
-<br>
-this change does give the display device a much nicer palette
-<br>
-to work with in 8 bits, it will break with all code that currently
-<br>
-exists to interface to the display device, such as gsview, as the
-<br>
-palette is not exported with the data.
-<br>
-
-<br>
-Due to the looming release and the questions remaining to be answered
-<br>
-on the bug, we pull the change for now.
-<br>
-
-<br>
-gs/base/gdevdsp.c
-<br>
-gs/psi/dpmain.c
-<br>
-gs/psi/dwimg.c
-<br>
-gs/psi/dxmain.c
-<br>
-pl/dwimg.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-20 23:28:19 -0700></a>
-2011-07-20 23:28:19 -0700</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=68bf978d614ec610333abd6a51b88fc3e05689f7">68bf978d614ec610333abd6a51b88fc3e05689f7</a>
-<blockquote>
-
-<br>
-Fix compiler warnings.
-<br>
-
-<br>
- Check return code from &quot;get_profile&quot; dev_proc in gs_nulldevice.c and get rid of the
-<br>
-implicit declaration for gdev_mem_set_planar.
-<br>
-
-<br>
-gs/base/gsdevice.c
-<br>
-gs/base/gxpcmap.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-22 10:36:36 -0700></a>
-2011-07-22 10:36:36 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d3302b1176683dc9e4cb5cb8ed9f42bffa0888ee">d3302b1176683dc9e4cb5cb8ed9f42bffa0888ee</a>
-<blockquote>
-
-<br>
-Fix for bug 692204. This forces DeviceGray to K only for CMYK devices.
-<br>
-
-<br>
-This is performed by default now. To return to a composite type mapping
-<br>
-that makes use of the true DeviceProfile, use the option -dDeviceGrayToK=false.
-<br>
-This commit includes a fix to rename the device member variable
-<br>
-icc_array to icc_struct to reduce confusion in reading the code.
-<br>
-
-<br>
-gs/Resource/Init/gs_lev2.ps
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gdevpdfk.c
-<br>
-gs/base/gdevtfnx.c
-<br>
-gs/base/gdevtsep.c
-<br>
-gs/base/gdevvec.c
-<br>
-gs/base/gdevxini.c
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gsdevice.c
-<br>
-gs/base/gsdparam.c
-<br>
-gs/base/gsequivc.c
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gsicc_cache.h
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/base/gslib.c
-<br>
-gs/base/gxclthrd.c
-<br>
-gs/base/gxcmap.c
-<br>
-gs/base/gxdevcli.h
-<br>
-gs/base/gximag3x.c
-<br>
-gs/iccprofiles/gray_to_k.icc
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-21 20:42:33 +0100></a>
-2011-07-21 20:42:33 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7f5d3d7b298bbabc13a484e38e749d572d817bc8">7f5d3d7b298bbabc13a484e38e749d572d817bc8</a>
-<blockquote>
-
-<br>
-Fix bug 692235: Rendering to 8bit colors shows bad colors.
-<br>
-
-<br>
-The display device uses an RGBK space for 8 bit rendering. Currently
-<br>
-this corresponds to a palette of 96 colors; 2 bits each for R,G,B,
-<br>
-supplemented by 16 greys.
-<br>
-
-<br>
-This review alters it to use a 6x6x6 RGB cube, supplemented by 40 grey
-<br>
-levels.
-<br>
-
-<br>
-In fact, this is slightly wasteful as we repeat the black and white
-<br>
-representations as color and as greyscale, but it's a huge improvement
-<br>
-on what we had before.
-<br>
-
-<br>
-No cluster differences expected as we don't test the display device.
-<br>
-
-<br>
-gs/base/gdevdsp.c
-<br>
-gs/psi/dpmain.c
-<br>
-gs/psi/dwimg.c
-<br>
-gs/psi/dxmain.c
-<br>
-pl/dwimg.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-22 23:27:18 -0400></a>
-2011-07-22 23:27:18 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4c2a089d0378402f374cb9004ac0faa3ff82d3c3">4c2a089d0378402f374cb9004ac0faa3ff82d3c3</a>
-<blockquote>
-
-<br>
-Bug 692361, trap errors produced by --token--
-<br>
-
-<br>
-Thap errors thrown by --token--, adjust the stack, and rethrow.
-<br>
-Rev. 4c6809dfa1c539d757c30f572922e05cd1436698 made the errors
-<br>
-that occur during reading of the contents steam recoverable,
-<br>
-but missed the case, when the error happens in the --token--.
-<br>
-
-<br>
-gs/Resource/Init/pdf_base.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-21 21:50:59 -0700></a>
-2011-07-21 21:50:59 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9d37cdcdbcb3b3bb23d0eab06d1683735303d5e1">9d37cdcdbcb3b3bb23d0eab06d1683735303d5e1</a>
-<blockquote>
-
-<br>
-Fix for bug 692364 in which we were were not handing the initial DeviceGray profiles correctly
-<br>
-
-<br>
-When the graphic state is started, the color spaces are first set to DeviceGray. In certain documents
-<br>
-this is then the color space that is used for drawing and in fact the erase page will initially
-<br>
-occur with this color space. If I have a destination ICC profile like CIELAB, then this is
-<br>
-a problem since we will end up mapping DeviceGray to RGB with the old procedures giving us a
-<br>
-CIELAB value of [255 255 255] which is a very bright red. With this fix we in the
-<br>
-DeviceGray mapping we fix the colorspace to be ICC based and pass then handle the procedure with
-<br>
-the ICC mapping. A minor fix was also needed in the pdf14device put_image where we use a
-<br>
-DeviceGray color space, which happens to have an ICC profile. We now correctly create the
-<br>
-ICC profile. Note that this will cause significant diffs in the cluster push as DeviceGray
-<br>
-colors that were mapped to pure K before for a CMYK device (due to the fact that we were not
-<br>
-installing the proper color space) will now map to composite black. This
-<br>
-issue will be addressed shortly by another commit where we by default map all DeviceGray
-<br>
-colors to K only in the CMYK devices.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gxcmap.c
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-21 16:40:21 +0100></a>
-2011-07-21 16:40: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=554ce829a9eb59da437541e2efbc646d9edc2805">554ce829a9eb59da437541e2efbc646d9edc2805</a>
-<blockquote>
-
-<br>
-Fix Bug 692355; gswin32 has garbage chars in window title bars.
-<br>
-
-<br>
-Existing ghostscript includes windows.h without defining UNICODE, but
-<br>
-calls the unicode versions of functions where appropriate. Here we
-<br>
-move to defining UNICODE before including windows.h, but we keep to
-<br>
-the practise of calling A or W specific variants as much as possible.
-<br>
-
-<br>
-Partly this is because of time before the release, but mostly a fear
-<br>
-that this might lead to a Pandoras box of changes.
-<br>
-
-<br>
-gs/psi/dwtext.c
-<br>
-gs/psi/dwtext.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-19 20:02:50 +0100></a>
-2011-07-19 20:02:50 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c9a8f8b3b0327bb62fc79cfe93d6bd79f997a2b6">c9a8f8b3b0327bb62fc79cfe93d6bd79f997a2b6</a>
-<blockquote>
-
-<br>
-pdf14 'dirty' rect optimisations.
-<br>
-
-<br>
-Rename 'bbox' to 'dirty' - makes the purpose of the field much clearer.
-<br>
-
-<br>
-Export dirty rectangle pointer in gx_pattern_trans_t structure.
-<br>
-
-<br>
-Remove automatic expansion of 'dirty' rects to full rect boundary.
-<br>
-
-<br>
-Ensure tiling code sets dirty rectangle as expected.
-<br>
-
-<br>
-Remove debugging printfs.
-<br>
-
-<br>
-Testing shows 491 differences. 16 or so real changes (all neutral or
-<br>
-progressions), but most of them in the cups device. Manual testing
-<br>
-shows no changes at all - no idea what's going on there.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gdevp14.h
-<br>
-gs/base/gxblend1.c
-<br>
-gs/base/gxp1fill.c
-<br>
-gs/base/gxpcolor.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-20 15:24:58 -0400></a>
-2011-07-20 15:24:58 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a1159926a8094f19bcacddf0503b5a06edd9184">4a1159926a8094f19bcacddf0503b5a06edd9184</a>
-<blockquote>
-
-<br>
-Bug 692362, tolerate stream object without stream.
-<br>
-
-<br>
-Check for the case, where the modified stream dictionary is missing
-<br>
-/File attribute (probably, because the original stream object was
-<br>
-missing the stream body) and substitute an empty stream.
-<br>
-
-<br>
-gs/Resource/Init/pdf_base.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-20 20:03:02 +0000></a>
-2011-07-20 20:03:02 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=145a853a0f9ed9d58b76413a5c77aa026500af93">145a853a0f9ed9d58b76413a5c77aa026500af93</a>
-<blockquote>
-
-<br>
-Add finalize function to pattern clist device.
-<br>
-
-<br>
-This may need to do more than it does, but the immediate drive for
-<br>
-this is to correctly drop the reference count on the target device
-<br>
-on closedown. This is sufficient to stop the SEGV seen on the final
-<br>
-garbage collection done on stars.pdf.
-<br>
-
-<br>
-The garbage collector was finding an unfreed pdf14 device, and stepping
-<br>
-into the target onto to find that the target had been destroyed already.
-<br>
-
-<br>
-No cluster differences shown in testing.
-<br>
-
-<br>
-gs/base/gxpcmap.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-20 10:29:47 -0700></a>
-2011-07-20 10:29:47 -0700</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=10cd4a92cd64252635c3c7f9a189f857bc59bf97">10cd4a92cd64252635c3c7f9a189f857bc59bf97</a>
-<blockquote>
-
-<br>
-Fix for missing ICCProfilesDir during some device init. Move profiledir to gs_lib_ctx.
-<br>
-
-<br>
-The business of trying to keep the profile directory in the device and keeping it in
-<br>
-sync with the value used in the icc_manager led to problems when some devices were
-<br>
-initialized. This change moves the profiledir (and its len) into the gs_lib_ctx_t
-<br>
-(pseudo- global) which is accessible by the icc_manager and devices via the
-<br>
-gs_memory_t pointer.
-<br>
-
-<br>
-Remove the no longer needed functions to set and sync the profile in the device and
-<br>
-replace gsicc_set_icc_directory with gs_lib_ctx_set_icc_directory.
-<br>
-
-<br>
-Thanks to Michael Vrhel for adding to this patch to make it build on linux and
-<br>
-build the other parsers.
-<br>
-
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gsdevice.c
-<br>
-gs/base/gsdparam.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/base/gslibctx.c
-<br>
-gs/base/gslibctx.h
-<br>
-gs/base/lib.mak
-<br>
-gs/base/msvclib.mak
-<br>
-gs/psi/int.mak
-<br>
-gs/psi/zdevice.c
-<br>
-gs/psi/zusparam.c
-<br>
-pcl/pctop.c
-<br>
-psi/psitop.c
-<br>
-pxl/pxpthr.c
-<br>
-pxl/pxtop.c
-<br>
-svg/svgtop.c
-<br>
-xps/xpstop.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-20 11:43:40 -0700></a>
-2011-07-20 11:43:40 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b07cfe2e168d004ed1a4365e985d90c88fa61725">b07cfe2e168d004ed1a4365e985d90c88fa61725</a>
-<blockquote>
-
-<br>
-Fix for Bug 692074. Make sure the ht thresholding code writes out device white and device black.
-<br>
-
-<br>
-This should also fix a polarity issue that we had with the plank device.
-<br>
-
-<br>
-gs/base/gxht_thresh.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-20 18:24:31 +0000></a>
-2011-07-20 18:24:31 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9a91acb5411b457383e59ed4bbefeb0247862228">9a91acb5411b457383e59ed4bbefeb0247862228</a>
-<blockquote>
-
-<br>
-Reverse the polarity of cups 'gray' colorspaces.
-<br>
-
-<br>
-Cups colspace 0 is the inverse of colspace 3.
-<br>
-
-<br>
-gs/toolbin/bmpcmp.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-20 14:48:55 +0100></a>
-2011-07-20 14:48: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=467b64692f0b74244fd0bc0748309d05b2f09294">467b64692f0b74244fd0bc0748309d05b2f09294</a>
-<blockquote>
-
-<br>
-Remove the eXternal Fonts functionality.
-<br>
-
-<br>
-The XFonts feature was of very limited utility these days, and
-<br>
-was deprecated a couple of releases ago. This commit removes
-<br>
-the unloved and rather bit-rotten feature completely.
-<br>
-
-<br>
- This does not really &quot;fix&quot; Bug 692357, but renders it pointless.
-<br>
-
-<br>
-No cluster differences.
-<br>
-
-<br>
-gs/base/devs.mak
-<br>
-gs/base/gdevmac.c
-<br>
-gs/base/gdevmac.h
-<br>
-gs/base/gdevmacxf.c
-<br>
-gs/base/gdevx.c
-<br>
-gs/base/gdevx.h
-<br>
-gs/base/gdevxini.c
-<br>
-gs/base/gdevxres.c
-<br>
-gs/base/gdevxxf.c
-<br>
-gs/base/gxccache.c
-<br>
-gs/base/gxccman.c
-<br>
-gs/base/gxchar.c
-<br>
-gs/base/gxchar.h
-<br>
-gs/base/gxfcache.h
-<br>
-gs/base/macos-mcp.mak
-<br>
-gs/doc/Xfonts.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-20 14:36:10 +0100></a>
-2011-07-20 14:36: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=5ca50b1770ae583490954f1546b17bad421fbc9f">5ca50b1770ae583490954f1546b17bad421fbc9f</a>
-<blockquote>
-
-<br>
-Bug 692359: Retain WMode from CMaps embedded in PDFs
-<br>
-
-<br>
-The read_CMap procedure skips everything in the embedded
-<br>
-CMap file stream except the actual character ranges (as does
-<br>
-Acrobat), thus we lose the WMode setting (if present) from
-<br>
-the stream. Nor were we propagating the value from the PDF
-<br>
-CMap stream dict.
-<br>
-
-<br>
-This revision ensures we propagate the WMode value the PDF
-<br>
-CMap stream dictionary (if present), which matches Acrobat's
-<br>
-behaviour.
-<br>
-
-<br>
-No cluster differences.
-<br>
-
-<br>
-gs/Resource/Init/pdf_font.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-19 21:57:35 -0600></a>
-2011-07-19 21:57:35 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a46123967e919fdd557411d2b0d177e6be2722e3">a46123967e919fdd557411d2b0d177e6be2722e3</a>
-<blockquote>
-
-<br>
-Fixes 692234 premature erasepage.
-<br>
-
-<br>
-The page was being erased before the postscript interpreter was
-<br>
-properly initialized. In particular for the crash in this bug a
-<br>
-default halftone has to be installed before erasepage.
-<br>
-
-<br>
-psi/psitop.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-19 17:12:23 +0100></a>
-2011-07-19 17:12: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=a6ec8697315e39dabd565a1ca114d3b42f006324">a6ec8697315e39dabd565a1ca114d3b42f006324</a>
-<blockquote>
-
-<br>
-Small Memento tweaks.
-<br>
-
-<br>
-When moving a block to the tail of the freelist, ensure that its next pointer
-<br>
-is set to NULL.
-<br>
-
-<br>
-When doing 'setParanoia' ensure that any existing countdown is reset.
-<br>
-
-<br>
-No cluster changes.
-<br>
-
-<br>
-gs/base/memento.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-19 10:05:14 +0100></a>
-2011-07-19 10:05:14 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=923d5ca0673442a9e8d4921812ac4fbd75433140">923d5ca0673442a9e8d4921812ac4fbd75433140</a>
-<blockquote>
-
-<br>
-Fix a warning I introduced, and a couple of others
-<br>
-
-<br>
-gs/base/gdevpng.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-18 10:46:05 -0700></a>
-2011-07-18 10:46:05 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9ed6be44e85f03f4a22064b698b3c0ea8c818b53">9ed6be44e85f03f4a22064b698b3c0ea8c818b53</a>
-<blockquote>
-
-<br>
-Fix so that rendering intent makes it properly through clist along with expanded RI capabilities
-<br>
-
-<br>
-This fixes bug 692139, also adds support for the ability to override the
-<br>
-internal rendering intent(s) with an externally set rendering intent. Also,
-<br>
-it is possible to specify specific rendering intents for RGB graphics, images
-<br>
-and text as well as CMYK graphic images and text. Progressions occur in the
-<br>
-regression test suite. In particular the file icc_rendering_intent.pdf at 300dpi
-<br>
-now renders correctly.
-<br>
-
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gxclimag.c
-<br>
-gs/base/gxclpath.c
-<br>
-gs/base/gxclrast.c
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-18 17:07:08 +0100></a>
-2011-07-18 17:07:08 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=385f519d34703ba88d107649fb59452617590194">385f519d34703ba88d107649fb59452617590194</a>
-<blockquote>
-
-<br>
-Remove the PNG_INTERNAL define from the PNG device.
-<br>
-
-<br>
-PNG_INTERNAL being defined exposes libpng's internal APIs which we should
-<br>
-certainly not be using, and do not appear to. I'm guess that this was
-<br>
-done to work around an issue in an earlier libpng version, and is no
-<br>
-longer relevant.
-<br>
-
-<br>
-No cluster differences
-<br>
-
-<br>
-gs/base/gdevpng.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-17 09:45:35 -0700></a>
-2011-07-17 09:45:35 -0700</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=44a2fd0bb1e2dd12e9ba475da0bdbb93081325d5">44a2fd0bb1e2dd12e9ba475da0bdbb93081325d5</a>
-<blockquote>
-
-<br>
-Fix crashes and assertion on 32-bit Windows builds. Bugs 692347, 692348.
-<br>
-
-<br>
-Thanks to SaGS for these fixes. Assertion and crash were found during final checkout of
-<br>
-the 9.03 release, as well as on the master branch. Partly these problems came from the
-<br>
-UTF-8 changes.
-<br>
-
-<br>
- VS treats the &quot;char&quot; type as signed by default. When extended characters are promoted
-<br>
-to ints, the values are negative in the range -128 to -1. These values (except -1
-<br>
- which conflicts with EOF) are not valid for the &quot;is*()&quot; family of functions.
-<br>
-
-<br>
-For GS_ registry entries that are not set, the utf8 version of 'gp_getenv_registry()'
-<br>
-incorrectly returned an 'insufficient buffer space' verdict and let the 'needed
-<br>
-buffer size' to 0 (cbData = 0 after 'RegQueryValueExW()'). The call to fetch the
-<br>
-value was then made also with a 0-sized buffer, did the same thing, and left the
-<br>
-buffer for the value undefined. There were also other problems, for example
-<br>
-non-REG_SZ entries were ignored only when the value was actually requested (not
-<br>
-during the request for the buffer size) and the function was doing 'free(wp)' with
-<br>
-wp == NULL in a few cases.
-<br>
-
-<br>
-No cluster differences.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/gp_wgetv.c
-<br>
-gs/base/gsargs.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-18 12:52:55 +0100></a>
-2011-07-18 12:52: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=80f11f7c17fd2d58eded8e8721a6932a0384f5f5">80f11f7c17fd2d58eded8e8721a6932a0384f5f5</a>
-<blockquote>
-
-<br>
-Fix plane calculations in planar pattern management.
-<br>
-
-<br>
-The calculation of the depth/shift to use depth in planar pattern management
-<br>
-was wrong due to a silly typo.
-<br>
-
-<br>
-This doesn't make it work, just solves an obvious problem.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gxpcmap.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-16 15:22:03 +0000></a>
-2011-07-16 15:22:03 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ed9ba4062880109265bf286cb2e3fdc7527fe841">ed9ba4062880109265bf286cb2e3fdc7527fe841</a>
-<blockquote>
-
-<br>
-Pattern accumulator changes to support planar output devices.
-<br>
-
-<br>
-When creating the memory buffer for a painttype 1 pattern tile, check
-<br>
-to see if the underlying device is planar - if it is, then create the
-<br>
-memory buffer as planar too.
-<br>
-
-<br>
-The code to tile out the planar pattern buffers still needs fixing, but
-<br>
-this allows halftoning jobs to run to completion at least.
-<br>
-
-<br>
-No cluster differences shown.
-<br>
-
-<br>
-gs/base/gxpcmap.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-16 12:58:35 +0000></a>
-2011-07-16 12:58:35 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a438a9f7d363f76013e1c614fc0818fe081875ad">a438a9f7d363f76013e1c614fc0818fe081875ad</a>
-<blockquote>
-
-<br>
-Fix pattern cache tile accounting.
-<br>
-
-<br>
-When putting tiles into the pattern cache, we estimate the size we need
-<br>
-up front (or in the clist case, calculate it exactly). We then clear
-<br>
-that many bytes in the pattern cache, and add the new tile using that
-<br>
-estimated size. When we come to evict we recalculate the exact size and
-<br>
-evict based on that.
-<br>
-
-<br>
-This causes a mismatch whereby the pattern cache thinks it has the wrong
-<br>
-number of bits cached. When this is an underestimation, we just end up
-<br>
-using more memory than we'd like. When it overestimates however, we can
-<br>
-get into an infinite loop trying to evict things.
-<br>
-
-<br>
-The fix is to record the number of bits we've accounted for in every
-<br>
-tile and thus always count the same coming out as we did coming in.
-<br>
-
-<br>
-If we really want to account for the correct values rather than the
-<br>
-estimate we can do that, but we must adjust pcache->bits_cache and
-<br>
-ctile->used appropriately.
-<br>
-
-<br>
-No bug associated with this, but it was triggered by a forthcoming
-<br>
-commit to make the pattern accumulator use planar buffers for planar
-<br>
-devices.
-<br>
-
-<br>
-No differences in cluster testing.
-<br>
-
-<br>
-gs/base/gsptype1.c
-<br>
-gs/base/gxpcmap.c
-<br>
-gs/base/gxpcolor.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-15 20:03:50 -0600></a>
-2011-07-15 20:03:50 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b7298f794a4d9bdf5f2bc9dd8401cbfa458a018">9b7298f794a4d9bdf5f2bc9dd8401cbfa458a018</a>
-<blockquote>
-
-<br>
-Autoconf changes for X11 and threads.
-<br>
-
-<br>
-config.mak.in
-<br>
-configure.ac
-<br>
-main/pcl6_gcc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-15 18:46:37 +0100></a>
-2011-07-15 18:46: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=10fa3cdcae73e526d6279e5a70522d821d08469d">10fa3cdcae73e526d6279e5a70522d821d08469d</a>
-<blockquote>
-
-<br>
-Set the defines needed to build luratech on WIN64
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-15 10:42:30 -0700></a>
-2011-07-15 10:42:30 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bfc0768f53bf96acfbbcf184fe83a09d85b4f5b4">bfc0768f53bf96acfbbcf184fe83a09d85b4f5b4</a>
-<blockquote>
-
-<br>
-Addition of an destination ICC profile for demonstrating the setting of rendering intent
-<br>
-
-<br>
-gs/toolbin/color/src_color/cmyk_des_renderintent.icc
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-15 15:12:02 +0100></a>
-2011-07-15 15:12: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=2472633cba1418733d079dea15f624c3649bf6dc">2472633cba1418733d079dea15f624c3649bf6dc</a>
-<blockquote>
-
-<br>
-Fix the shared library builds.
-<br>
-
-<br>
-The corrected dependencies in lib.mak broke the shared lib bulids,
-<br>
-so the rules needed split up to cover the shared and non-shared
-<br>
-cases.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-gs/base/gs.mak
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-15 14:35:04 +0100></a>
-2011-07-15 14:35: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=b0277439b2de03cfcae9282f02021bec72aaa91a">b0277439b2de03cfcae9282f02021bec72aaa91a</a>
-<blockquote>
-
-<br>
-Resolve a build issue with 64 Windows.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/msvctail.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-15 12:51:00 +0100></a>
-2011-07-15 12:51:00 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9be999c3d781ff92b5498d8cc89b0d2c1fcdc69e">9be999c3d781ff92b5498d8cc89b0d2c1fcdc69e</a>
-<blockquote>
-
-<br>
-Fix crashes due to uninitialised reschedule and time_slice procs.
-<br>
-
-<br>
-Freek Kempe reports problems when ghostscript is built with just
-<br>
-psl3 and pdf FEATURE_DEVS, due to the context entries for
-<br>
-time_slice_proc and reschedule_proc being uninitialised.
-<br>
-
-<br>
-We take on a (very slightly modified) version of his suggested fix;
-<br>
-they are now initialised to a dummy procedure, and can be overridden
-<br>
-by zcontext_init later if required.
-<br>
-
-<br>
-No cluster differences seen.
-<br>
-
-<br>
-gs/psi/icontext.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-15 08:57:45 +0100></a>
-2011-07-15 08:57: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=7d56fdb732eda354c1c0ccd53e62306caf4f600f">7d56fdb732eda354c1c0ccd53e62306caf4f600f</a>
-<blockquote>
-
-<br>
-Small formatting change for the html changelog
-<br>
-
-<br>
-gs/toolbin/gitlog2changelog.py
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-15 08:51:36 +0100></a>
-2011-07-15 08:51:36 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fc670d3f5dd1e066a838165acec54b2859b1ed78">fc670d3f5dd1e066a838165acec54b2859b1ed78</a>
-<blockquote>
-
-<br>
-Increment the Ghostscript version number to 9.04.
-<br>
-
-<br>
-gs/Resource/Init/gs_init.ps
-<br>
-gs/base/version.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-15 07:01:39 +0100></a>
-2011-07-15 07:01: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=7e299cc60681c53113f513f95a940ef0349219f9">7e299cc60681c53113f513f95a940ef0349219f9</a>
-<blockquote>
-
-<br>
-Fix an error in the Win64 building of genarch.exe
-<br>
-
-<br>
-It was using AUXDIR instead of AUX for the path.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/msvctail.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-14 14:19:37 -0700></a>
-2011-07-14 14:19:37 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f98534e2952fb2c2bfa5a3604233d69c76713a41">f98534e2952fb2c2bfa5a3604233d69c76713a41</a>
-<blockquote>
-
-<br>
-Addition of support to override the document specified rendering intent(s)
-<br>
-
-<br>
-Also this includes fixes so that if the source color profiles are specified
-<br>
-the rendering intents associated with those will be used.
-<br>
-
-<br>
-gs/Resource/Init/gs_lev2.ps
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/psi/zusparam.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-14 16:07:03 +0100></a>
-2011-07-14 16:07:03 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fb5f2b5f317f9df6a1258ba53c17da84292cafee">fb5f2b5f317f9df6a1258ba53c17da84292cafee</a>
-<blockquote>
-
-<br>
-Small fix to changes for Bug 688528.
-<br>
-
-<br>
-The fix for Bug 688528 contained a conditional error checking for
-<br>
-a return value of greater than zero when in fact it should be
-<br>
-greater than or equal to zero.
-<br>
-
-<br>
-No cluster differences.
-<br>
-
-<br>
-gs/base/gdevvec.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-14 10:08:02 +0100></a>
-2011-07-14 10:08: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=7694aad7c0d84ea8c95acff6ca9b189016c280d1">7694aad7c0d84ea8c95acff6ca9b189016c280d1</a>
-<blockquote>
-
-<br>
-Revise error/warning on PDF missing CIDFont.
-<br>
-
-<br>
-Now that GS will attempt to continue interpreting a PDF after an error
-<br>
-in a given content stream, revise the message we emit when he hit a
-<br>
-missing CIDFont in a PDF condition to reflect that. If PDFSTOPONERROR
-<br>
-keep the previous message.
-<br>
-
-<br>
- Also, add a &quot;flush&quot; at the end of each message to ensure they don't get
-<br>
-mangled by later, high priority messages.
-<br>
-
-<br>
-No cluster differences.
-<br>
-
-<br>
-gs/Resource/Init/pdf_font.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-14 10:03:35 +0100></a>
-2011-07-14 10:03:35 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=62ce501c977ae1a6cb5c38dac545616111c51ed2">62ce501c977ae1a6cb5c38dac545616111c51ed2</a>
-<blockquote>
-
-<br>
-Compile out the Unicode path/parameter code with VC7 and before
-<br>
-
-<br>
- Visual C 7 (Visual Studio 2003) and earlier do not have all the &quot;wide char&quot;
-<br>
-related library functions needed for the Windows Unicode path and
-<br>
-parameter handling, causing a link error.
-<br>
-
-<br>
-So when building with VC7 and earlier, leave out the Unicode stuff.
-<br>
-
-<br>
-No cluster differences.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-13 14:34:32 -0700></a>
-2011-07-13 14:34:32 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ed92ea1c85f7ee188d0ab242e72ca2f220367ed8">ed92ea1c85f7ee188d0ab242e72ca2f220367ed8</a>
-<blockquote>
-
-<br>
-Addition of ICC profile for demonstrating use of rendering intent on source color
-<br>
-
-<br>
-gs/toolbin/color/src_color/cmyk_src_renderintent.icc
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-13 10:08:29 -0700></a>
-2011-07-13 10:08:29 -0700</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=880f2b2b80ce8f1506b2ec9d81ba73737dfaa4af">880f2b2b80ce8f1506b2ec9d81ba73737dfaa4af</a>
-<blockquote>
-
-<br>
-Add flush after -sGenericResourceDir warning message.
-<br>
-
-<br>
- I often have seen this message get garbled by having other messages on stderr &quot;jump in&quot;
-<br>
- so that the message on stdout gets split up. The &quot;flush&quot; prevents that.
-<br>
-
-<br>
-gs/Resource/Init/gs_res.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-12 19:26:21 -0700></a>
-2011-07-12 19:26:21 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=46db3bca63834ae3b3881022fbc9300de8690d10">46db3bca63834ae3b3881022fbc9300de8690d10</a>
-<blockquote>
-
-<br>
-Fix so that when the null device is installed it is initialized with the proper icc directory
-<br>
-
-<br>
-This fixes issues on windows when going to the bbox device but there are still issues on linux.
-<br>
-
-<br>
-gs/base/gsdevice.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-12 14:07:22 -0700></a>
-2011-07-12 14:07: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=6b237cb27450a0d09ad982bd45e2e15829ae974f">6b237cb27450a0d09ad982bd45e2e15829ae974f</a>
-<blockquote>
-
-<br>
-Addition of code to support source color management dependent upon the graphic type
-<br>
-
-<br>
-Also fix of the example file that demonstrates this feature.
-<br>
-
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/base/gxclimag.c
-<br>
-gs/examples/text_graph_image_cmyk_rgb.pdf
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-12 20:11:46 +0100></a>
-2011-07-12 20:11:46 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a06634a969ea9b0db2d0840d8641847247056145">a06634a969ea9b0db2d0840d8641847247056145</a>
-<blockquote>
-
-<br>
-Update autoconf build and the Windows build to use Luratech
-<br>
-if the directories are found where we expect.
-<br>
-
-<br>
-Include options on each build to disable using Luratech explicitly.
-<br>
-
-<br>
-Document the change in Make.htm
-<br>
-
-<br>
-No cluster differences.
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/configure.ac
-<br>
-gs/doc/Make.htm
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-12 19:15:33 +0100></a>
-2011-07-12 19:15: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=15d3904a43b2dddda12ed842000d9668c2aff8d7">15d3904a43b2dddda12ed842000d9668c2aff8d7</a>
-<blockquote>
-
-<br>
-Add a simple git log to html changelog script.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/toolbin/gitlog2changelog.py
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-12 17:28:45 +0100></a>
-2011-07-12 17:28: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=89de03454ba02713403571cb1cdd1312ae818f81">89de03454ba02713403571cb1cdd1312ae818f81</a>
-<blockquote>
-
-<br>
-Bug 692338: address performance regression in FAPI
-<br>
-
-<br>
-Previously I changed FAPI to only dispose of the outline or
-<br>
-bitmap part of the Freetype glyph, intead of the entire
-<br>
-internal glyph object, so as avoid freeing, re-allocating
-<br>
-and initialising a glyph object for every glyph. That seemed
-<br>
-to cause a memory leak, so I reverted it.
-<br>
-
-<br>
-This commit does it properly, addresing the memory leak by
-<br>
-correctly freeing the memory that Freetype returns to us
-<br>
-*containing* the pointer to the bitmap or outline, as well
-<br>
-as the bitmap/outline data.
-<br>
-
-<br>
-This is measurably quicker than the previous method.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/psi/fapi_ft.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-12 06:50:46 -0700></a>
-2011-07-12 06:50:46 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b6a234634d7987890851cb4375e0520ba8dd0750">b6a234634d7987890851cb4375e0520ba8dd0750</a>
-<blockquote>
-
-<br>
-Addition of code to support override of internal ICC profiles
-<br>
-
-<br>
-gs/Resource/Init/gs_lev2.ps
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/psi/zicc.c
-<br>
-gs/psi/zusparam.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-11 09:22:20 +0100></a>
-2011-07-11 09:22:20 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=99cbbdaad585b78dfd32db6dc59c08f9743d8d6a">99cbbdaad585b78dfd32db6dc59c08f9743d8d6a</a>
-<blockquote>
-
-<br>
-Add debugbin to the list of directories to ignore.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/toolbin/localcluster/clusterpush.pl
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-11 09:14:34 +0100></a>
-2011-07-11 09:14: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=ee688b964bee8f9562ce92835b2478f88b0dbe31">ee688b964bee8f9562ce92835b2478f88b0dbe31</a>
-<blockquote>
-
-<br>
-Bug 692327: Support libpng 1.5.x API
-<br>
-
-<br>
-Revise to support the latest libpng API, conditionally compiled based on
-<br>
-the PNG_LIBPNG_VER_MINOR.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gdevpng.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-10 13:14:04 -0700></a>
-2011-07-10 13:14:04 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d1a349055450612218848e8d15fb6c1a4cc22f5b">d1a349055450612218848e8d15fb6c1a4cc22f5b</a>
-<blockquote>
-
-<br>
-Addition of pdf example file to demonstrate source color graphic object control
-<br>
-
-<br>
-gs/examples/text_graph_image_cmyk_rgb.pdf
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-10 12:54:02 -0700></a>
-2011-07-10 12:54:02 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2065f62ecb27abd974803207a0be160264944401">2065f62ecb27abd974803207a0be160264944401</a>
-<blockquote>
-
-<br>
-reorganization of files for demonstrating source color control based upon graphic type.
-<br>
-
-<br>
-gs/toolbin/color/icc_creator/effects/cmyk_src_cyan.icc
-<br>
-gs/toolbin/color/icc_creator/effects/cmyk_src_magenta.icc
-<br>
-gs/toolbin/color/icc_creator/effects/cmyk_src_yellow.icc
-<br>
-gs/toolbin/color/icc_creator/effects/rgb_source_blue.icc
-<br>
-gs/toolbin/color/icc_creator/effects/rgb_source_green.icc
-<br>
-gs/toolbin/color/icc_creator/effects/rgb_source_red.icc
-<br>
-gs/toolbin/color/src_color/cmyk_src_cyan.icc
-<br>
-gs/toolbin/color/src_color/cmyk_src_magenta.icc
-<br>
-gs/toolbin/color/src_color/cmyk_src_yellow.icc
-<br>
-gs/toolbin/color/src_color/objsrc_profiles_example.txt
-<br>
-gs/toolbin/color/src_color/rgb_source_blue.icc
-<br>
-gs/toolbin/color/src_color/rgb_source_green.icc
-<br>
-gs/toolbin/color/src_color/rgb_source_red.icc
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-10 12:19:33 -0700></a>
-2011-07-10 12:19:33 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=213fd2eb89c8a818c546cb888fde6bb67d481c07">213fd2eb89c8a818c546cb888fde6bb67d481c07</a>
-<blockquote>
-
-<br>
-Addition of special effect ICC CMYK source profiles
-<br>
-
-<br>
-A set of CMYK based profiles for demonstrating the usage of source
-<br>
-color graphic object type dependent color management
-<br>
-
-<br>
-gs/toolbin/color/icc_creator/effects/cmyk_src_cyan.icc
-<br>
-gs/toolbin/color/icc_creator/effects/cmyk_src_magenta.icc
-<br>
-gs/toolbin/color/icc_creator/effects/cmyk_src_yellow.icc
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-10 09:39:21 -0700></a>
-2011-07-10 09:39:21 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f24c2cb3f3e030068e48b9c608ebf87e70679547">f24c2cb3f3e030068e48b9c608ebf87e70679547</a>
-<blockquote>
-
-<br>
-Addition of special effect RGB ICC profiles
-<br>
-
-<br>
-These profiles are for use in demonstrating the use of graphic object
-<br>
-specific color management on source RGB objects.
-<br>
-
-<br>
-gs/toolbin/color/icc_creator/effects/rgb_source_blue.icc
-<br>
-gs/toolbin/color/icc_creator/effects/rgb_source_green.icc
-<br>
-gs/toolbin/color/icc_creator/effects/rgb_source_red.icc
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-09 22:47:53 -0700></a>
-2011-07-09 22:47:53 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=048a939c8c5880d1f89f3f61df78e147910cb1d0">048a939c8c5880d1f89f3f61df78e147910cb1d0</a>
-<blockquote>
-
-<br>
-Fix for bug 692333.
-<br>
-
-<br>
-Caused by insufficient testing for change in color run when spot colors
-<br>
-are present during the DeviceN color rendering. Cluster push shows a
-<br>
-diff in Bug691425.pdf bmpcmp seemed OK.
-<br>
-
-<br>
-gs/base/gxicolor.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-08 14:11:52 -0700></a>
-2011-07-08 14:11: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=ec7d65ce2cccbc97a2b696ceecb2ba7d329eff79">ec7d65ce2cccbc97a2b696ceecb2ba7d329eff79</a>
-<blockquote>
-
-<br>
-Fix initialization in gs_nulldevice (PS nulldevice operator) Bug 692334.
-<br>
-
-<br>
-The gs_nulldevice was setting the get_profile proc to gx_forward_get_profile so the
-<br>
-icc_array was coming from the current device in the graphics state but that did not
-<br>
-match the color_info num_components and polarity leading to incorrect values returned
-<br>
-if gscms_transform_color_buffer set the OutputFormat to 1 (for the nulldevice) of a
-<br>
-link handle, but a subsequent call to gscms_transform_color with the same link handle
-<br>
-expected more than one component.
-<br>
-
-<br>
-The initialization of the default profile can only be done if the io_device_table has
-<br>
-been initialized since this function is called during gs_lib_init1 with the table NULL.
-<br>
-
-<br>
-This change fixes 12-07D.ps differences introduced in the 'tagfix' patch, but does NOT
-<br>
-introduce any changes to gscms_transform_color_buffer to avoid changing the number
-<br>
-of components or issue a warning as mentioned in the bug.
-<br>
-
-<br>
-EXPECTED_DIFFERENCES:
-<br>
-
-<br>
-12-07D should revert to the output prior to the tagfix change (06df93f)
-<br>
-
-<br>
-gs/base/gsdevice.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-08 16:41:47 -0700></a>
-2011-07-08 16:41:47 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c48d47e85a27149ecbd84512c8ed80e3d3ab498c">c48d47e85a27149ecbd84512c8ed80e3d3ab498c</a>
-<blockquote>
-
-<br>
-Fix for graphic tag setting during forward procedure.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/gdevnfwd.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-08 12:52:25 -0700></a>
-2011-07-08 12:52:25 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c72586e85c6c8953cf3a1cbc32b48949c7622bb4">c72586e85c6c8953cf3a1cbc32b48949c7622bb4</a>
-<blockquote>
-
-<br>
-Rename variables and objects to be denoted as source graphic tags
-<br>
-
-<br>
-With recent commit of changes to object tags as being a graphic type tag
-<br>
-it made sense to rename the source color object types similarly.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/psi/zusparam.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-08 11:42:37 -0700></a>
-2011-07-08 11:42:37 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4df7c79bc1c4df59818ddbc53b20eb1315e7cb48">4df7c79bc1c4df59818ddbc53b20eb1315e7cb48</a>
-<blockquote>
-
-<br>
-Rename of misnamed file.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/toolbin/color/icc_creator/effects/k_only..txt
-<br>
-gs/toolbin/color/icc_creator/effects/k_only.txt
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-23 11:55:14 -0700></a>
-2011-06-23 11:55:14 -0700</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=06df93f6babc540b8e29ae7cc1fcaed888142d52">06df93f6babc540b8e29ae7cc1fcaed888142d52</a>
-<blockquote>
-
-<br>
-Rename object_tag to graphics_type_tag and move to the device for MT rendering.
-<br>
-
-<br>
-The memory->gs_lib_ctx->BITTAG hack was inherently NOT safe for use by multiple
-<br>
-rendering threads. Devices that want to encode the tag info in the gx_color_index
-<br>
-need the tag, so we have moved this to the device structure. Multiple rendering
-<br>
-threads each have unique buffer devices, so this allows clist playback to set
-<br>
-and use the appropriate tag as the bands are played back without thread
-<br>
-interference.
-<br>
-
-<br>
-Rename the gs_object_tag_type_t to gs_graphics_type_t to make it more unique for
-<br>
-grep based searching and prevent confusion with other uses of the term 'object'.
-<br>
-Move the enum to gscms.h with the 'set' functions prototyped in gxdevcli.h.
-<br>
-
-<br>
-Just as for the device's cmm_dev_profile_t information, the tag needs to be
-<br>
-forwarded by devices in the chain (clipper, compositor) so that these 'helper'
-<br>
-filtering devices don't interfere with the setting of the tag. The tag value is
-<br>
-maintained in all devices in the chain so a 'get_graphics_type_tag' dev_proc
-<br>
-is not needed -- the dev->graphics_type_tag can be access directly.
-<br>
-
-<br>
-Previously, tags were not recorded except for devices that enabled tags.
-<br>
-Now tags are tracked for all devices for use in selecting an ICC profile
-<br>
-and a device can signal that it maintains tags by setting GS_DEVICE_ENCODES_TAGS
-<br>
-for use by compositors that want to know whether or not to maintain a tag
-<br>
-plane, such as the pdf14 device.
-<br>
-
-<br>
-Also replace the old 'get_object_type' that the anti-aliasing used with the
-<br>
-single approach for consistency and to cure problems (not identifed) with using
-<br>
-AA when other devices are interposed in the chain (clipper, compositor).
-<br>
-
-<br>
-EXPECTED_DIFFERENCES:
-<br>
-
-<br>
-Various 12-07D.PS PS LL3 CET files will show color differences on page 3 (GLOBINT)
-<br>
-as described in Bug692334.
-<br>
-
-<br>
-gs/base/gdevabuf.c
-<br>
-gs/base/gdevbit.c
-<br>
-gs/base/gdevddrw.c
-<br>
-gs/base/gdevdflt.c
-<br>
-gs/base/gdevimdi.c
-<br>
-gs/base/gdevmem.c
-<br>
-gs/base/gdevnfwd.c
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gdevprn.h
-<br>
-gs/base/gdevpsd.c
-<br>
-gs/base/gdevrinkj.c
-<br>
-gs/base/gdevrops.c
-<br>
-gs/base/gdevwts.c
-<br>
-gs/base/gdevxcf.c
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gscsepr.c
-<br>
-gs/base/gsdevice.c
-<br>
-gs/base/gsdps1.c
-<br>
-gs/base/gsequivc.c
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/base/gsimage.c
-<br>
-gs/base/gslibctx.c
-<br>
-gs/base/gslibctx.h
-<br>
-gs/base/gsnamecl.c
-<br>
-gs/base/gsncdummy.c
-<br>
-gs/base/gspaint.c
-<br>
-gs/base/gstext.c
-<br>
-gs/base/gstrans.c
-<br>
-gs/base/gsutil.c
-<br>
-gs/base/gsutil.h
-<br>
-gs/base/gxacpath.c
-<br>
-gs/base/gxblend1.c
-<br>
-gs/base/gxclip.c
-<br>
-gs/base/gxclipm.c
-<br>
-gs/base/gxclist.c
-<br>
-gs/base/gxclrast.c
-<br>
-gs/base/gxcmap.c
-<br>
-gs/base/gxdevcli.h
-<br>
-gs/base/gxdevice.h
-<br>
-gs/base/gxi12bit.c
-<br>
-gs/base/gxicolor.c
-<br>
-gs/base/gximono.c
-<br>
-gs/base/gxiscale.c
-<br>
-gs/base/gxistate.h
-<br>
-gs/base/gxpcmap.c
-<br>
-gs/base/gxshade.c
-<br>
-xps/xpsgradient.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-08 14:12:51 +0100></a>
-2011-07-08 14:12:51 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=73c09fa015d1e5a19083001bc343abbb67992c9d">73c09fa015d1e5a19083001bc343abbb67992c9d</a>
-<blockquote>
-
-<br>
-Fix Bug 692331: SEGV in image interpolation.
-<br>
-
-<br>
-In fixing bug 692225, it seems I broke this.
-<br>
-
-<br>
-In the setup code that decides whether decoding is required or not, I
-<br>
-was incorrectly choosing to use the 'decode' case, when in fact the
-<br>
-'decoding' is done later for CIE colorspaces. As such I should have used
-<br>
-the no-decode case.
-<br>
-
-<br>
-Fixing this appears to cure the problem.
-<br>
-
-<br>
-gs/base/gxiscale.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-08 11:14:08 +0100></a>
-2011-07-08 11:14:08 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=02a53b643780f40f5d8947272eabb947002c40b3">02a53b643780f40f5d8947272eabb947002c40b3</a>
-<blockquote>
-
-<br>
-Bug 692322: Clarify in ps2pdf manpage that output goes to cwd by default.
-<br>
-
-<br>
-Credit to Jonathan Nieder &lt;jrnieder@gmail.com&gt;.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/man/ps2pdf.1
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-07 20:50:35 +0000></a>
-2011-07-07 20:50:35 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0e0db1ca146d82f6a1b0ae90f7146e7d65ffbba9">0e0db1ca146d82f6a1b0ae90f7146e7d65ffbba9</a>
-<blockquote>
-
-<br>
-Fix bug 692330: SEGV in clist memfile fseek.
-<br>
-
-<br>
-The icc unserialise profile code ftells, then reads, then fseeks to
-<br>
-maintain the position of the stream. The fseek was leaving the stream
-<br>
-in an illegal state (the pointer was exactly at the end of the last
-<br>
-block at the end of the file). Internally we are supposed to always
-<br>
-have memory allocated for us to write into, and in this circumstance
-<br>
-we didn't.
-<br>
-
-<br>
-The fseek code was actually correct, as was the ftell code. The problem
-<br>
-lay in the fwrite code that left the stream in an illegal state.
-<br>
-
-<br>
-The fix is simply to change the fwrite logic slightly; we are guaranteed
-<br>
-to have space on entry to the loop, so we just need to ensure we have
-<br>
-space on exit.
-<br>
-
-<br>
-Cluster testing shows no differences (or none due to this change at least).
-<br>
-
-<br>
-gs/base/gxclmem.c
-<br>
-gs/base/gxclread.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-06 23:12:51 -0600></a>
-2011-07-06 23:12:51 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91c925158fd8bb84c0d44dff2ec4888dc4d6168e">91c925158fd8bb84c0d44dff2ec4888dc4d6168e</a>
-<blockquote>
-
-<br>
-Updates PDL README.txt
-<br>
-
-<br>
-README.txt
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-07 13:47:03 +0100></a>
-2011-07-07 13:47:03 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8191a2e349d1f8787b2f4805d770fa8b11f82d18">8191a2e349d1f8787b2f4805d770fa8b11f82d18</a>
-<blockquote>
-
-<br>
-Bug 688528-addendum: quell warnings and handle errors.
-<br>
-
-<br>
-gs/base/gdevvec.c
-<br>
-gs/base/gsdevice.c
-<br>
-gs/base/gximag3x.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-07 10:41:27 +0100></a>
-2011-07-07 10:41: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=dadc4955945d8004785ed13095ea9ea79c0f13a6">dadc4955945d8004785ed13095ea9ea79c0f13a6</a>
-<blockquote>
-
-<br>
-Bug 688528: set ICC profiles for interal uses of bbox device.
-<br>
-
-<br>
-If we create a bbox device internally (i.e. not as an output device)
-<br>
-we must still ensure that the device has ICC profiles set in it. In
-<br>
-this case, it simply inherits the profile array from the parent
-<br>
-device.
-<br>
-
-<br>
-This also meant moving the ICC manager initialization to before the
-<br>
- device &quot;open&quot; call in gs_setdevice_no_erase() because the device set
-<br>
- can also open another device (in this case, pswrite's &quot;open&quot; has the
-<br>
-effect, via the vector device, of setting a bbox device instance, so
-<br>
-there must be an array of ICC profiles at that stage for bbox to
-<br>
-inherit.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gdevvec.c
-<br>
-gs/base/gsdevice.c
-<br>
-gs/base/gslib.c
-<br>
-gs/base/gximag3x.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-06 22:05:43 -0400></a>
-2011-07-06 22:05:43 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=73bfbe4b5f6e7090c2b6aad0183ddc8a186d5788">73bfbe4b5f6e7090c2b6aad0183ddc8a186d5788</a>
-<blockquote>
-
-<br>
-Fix Cygwin build.
-<br>
-
-<br>
-Some Cygwin tools use \r\n line endings. Add transliteration of \r
-<br>
-to the space character to compensate for this lossage.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-06 17:29:24 -0600></a>
-2011-07-06 17:29:24 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7531d50c7b6dec596e142ff555f3cbfc28613abe">7531d50c7b6dec596e142ff555f3cbfc28613abe</a>
-<blockquote>
-
-<br>
-Shailesh Mistry's fix for 692311 - corrupt character rendering.
-<br>
-
-<br>
-In adaptive compression mode the seed row for delta row compression
-<br>
-was not properly cleared. With this change the code is now compatible
-<br>
-with HP monochrome printers, previously the Artifex code was
-<br>
-compatible with HP Color Laserjets. We do not implement a device
-<br>
-specific switch - for example the new code could be enabled if the
-<br>
-current mode of emulation was PCL5E (mono PCL) and not PCL5C (color
-<br>
-PCL) allowing emulation of both product types. However the corrupt
-<br>
-character output of HP color printers is probably never an intended
-<br>
-result.
-<br>
-
-<br>
-pcl/rtraster.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-05 11:04:27 -0600></a>
-2011-07-05 11:04:27 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6e1c268d0ceb3d39e33d242132a917ac27cc2491">6e1c268d0ceb3d39e33d242132a917ac27cc2491</a>
-<blockquote>
-
-<br>
-Fix allocator and cleanup.
-<br>
-
-<br>
-Use global allocator in the font directory not the local allocator in
-<br>
-the graphics state. Move the cache size assignment to the end of the
-<br>
-procedure after any error can occur and trivial style changes.
-<br>
-
-<br>
-gs/base/gsfont.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-29 23:29:44 -0600></a>
-2011-06-29 23:29:44 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=00dbc00bbbbc5dd7d3ec4fce2ac5ed72a4e13bde">00dbc00bbbbc5dd7d3ec4fce2ac5ed72a4e13bde</a>
-<blockquote>
-
-<br>
-Implement gs_setcachesize properly.
-<br>
-
-<br>
-The previous implementation simply set the cache size state value but
-<br>
-didn't attempt to rebuild the cache. The new font cache size is
-<br>
-provided by size operand of setcacheparams.
-<br>
-
-<br>
-We also limit the size operand to the values discovered used by CPSI, the
-<br>
-range is device dependent and the CPSI range appears reasonable.
-<br>
-
-<br>
-gs/base/gsfont.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-23 12:58:53 -0600></a>
-2011-06-23 12:58: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=ee351ae182d5f5fabe36f0ce9216a4da39c1c831">ee351ae182d5f5fabe36f0ce9216a4da39c1c831</a>
-<blockquote>
-
-<br>
-Removes obsolete code.
-<br>
-
-<br>
-The is callback used to be used to delete all characters from the
-<br>
-cache, we don't do that anymore.
-<br>
-
-<br>
-pcl/pcfont.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-18 18:03:44 -0600></a>
-2011-06-18 18:03:44 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f91aa55a593789c3e342f649e1ebd7f575008e2c">f91aa55a593789c3e342f649e1ebd7f575008e2c</a>
-<blockquote>
-
-<br>
-Fix bug #692246 infinite loop searching the character table.
-<br>
-
-<br>
-Set up the number of characters in the table and the maximum amount of
-<br>
-memory used by the font cache such that we maintain the invariant that
-<br>
-we will run out of memory before running out of table entries. Thanks
-<br>
-to Shailesh Mistry for assistance in analyzing this problem.
-<br>
-
-<br>
-gs/base/gxccman.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-06 13:30:23 +0100></a>
-2011-07-06 13:30:23 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e5a37634a8e15a945e7f5ea4aca68ab8e1e34d3a">e5a37634a8e15a945e7f5ea4aca68ab8e1e34d3a</a>
-<blockquote>
-<p>
- Bug 692318: Ensure that compiler flags are used for the &quot;aux&quot; files.
-<br>
-
-<br>
-For a normal host build, the build tools (genarch, genconf etc) should be
-<br>
-built with the same compiler flags as Ghostscript/Ghost*. In this case
-<br>
-the integer type used for encoded color values was not getting used
-<br>
-when compiling genarch.
-<br>
-
-<br>
-Also, add a warning when tiffsep does have to skip one or more plates, with
-<br>
-a pointer to the relevant documentation. Lastly, update the doc to reflect
-<br>
-that the contone preview output may not be as expected if the job uses
-<br>
-overprint.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-common/ugcc_top.mak
-<br>
-gs/base/gdevtsep.c
-<br>
-gs/base/msvccmd.mak
-<br>
-gs/base/msvctail.mak
-<br>
-gs/base/unix-aux.mak
-<br>
-gs/doc/Devices.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-04 23:55:57 -0400></a>
-2011-07-04 23:55:57 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=836ac602259ed7e6dfa2845ce78c5fcb516c72e1">836ac602259ed7e6dfa2845ce78c5fcb516c72e1</a>
-<blockquote>
-
-<br>
-Bug 692026: Replace vsprintf() with vsnprintf()
-<br>
-
-<br>
-vsnprintf() is a safer function. No new compatibility problams are
-<br>
-expected because vsnprintf() is already used it in Ghostscript.
-<br>
-
-<br>
-gs/base/gxttfb.c
-<br>
-gs/base/rinkj/rinkj-byte-stream.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-02 13:50:28 -0700></a>
-2011-07-02 13:50:28 -0700</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=02ef306436f521a059356bbe41805499204051fc">02ef306436f521a059356bbe41805499204051fc</a>
-<blockquote>
-
-<br>
-Change to using encode_color instead of map_rgb_color since map_rgb_color are obsolete.
-<br>
-
-<br>
-The encode_color proc replaced this and devices may not have it set to a valid proc.
-<br>
-Detected under certain circumstances with the tiffsep device using compressed color
-<br>
-encoding.
-<br>
-
-<br>
-gs/base/gdevmem.c
-<br>
-gs/base/gdevmr1.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-01 16:46:32 -0400></a>
-2011-07-01 16:46:32 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c841237f86505fad348295dfb17aea45beed4c89">c841237f86505fad348295dfb17aea45beed4c89</a>
-<blockquote>
-
-<br>
-Bug 692320: check page count type.
-<br>
-
-<br>
-Check the type of /Count attrubute before using it. Reject invalid
-<br>
-values and types and scan the page tree instead.
-<br>
-
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-01 18:03:19 +0100></a>
-2011-07-01 18:03:19 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=52d2decab7955e61a605ab44acb88a08eb79b9cb">52d2decab7955e61a605ab44acb88a08eb79b9cb</a>
-<blockquote>
-
-<br>
-Clist change for plane rop operations.
-<br>
-
-<br>
-If strip_copy_rop is called with the 'lop_planar' indicator bit set in
-<br>
-the rop, it should encode just a planes worth of data.
-<br>
-
-<br>
-The reading side of clists works without change, I believe.
-<br>
-
-<br>
-gs/base/gxclrect.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-07-01 12:31:54 +0100></a>
-2011-07-01 12:31:54 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e14ea75d716da7ecdef2211a5d60e46deec55b9f">e14ea75d716da7ecdef2211a5d60e46deec55b9f</a>
-<blockquote>
-
-<br>
-Fix clist planar device detection.
-<br>
-
-<br>
-When the clist interrogates a device to see if it is a planar one, it was
-<br>
-getting the wrong answer due to only the planar memory buffer device
-<br>
-responding to the question. We fix the main planar device to respond too
-<br>
-here.
-<br>
-
-<br>
-Also, any device that doesn't understand the is_native_planar question
-<br>
-would respond -1; the existing code would take this to mean that it is
-<br>
-planar. The code now only triggers on positive responses.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gdevppla.c
-<br>
-gs/base/gxclist.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-30 12:17:08 -0700></a>
-2011-06-30 12:17:08 -0700</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=93b4821ada53277b61efb87cbb12eb6a6f71ced0">93b4821ada53277b61efb87cbb12eb6a6f71ced0</a>
-<blockquote>
-
-<br>
-FIx segfaults caused by missing prototype causing pointer truncation.
-<br>
-
-<br>
-The gs_state_memory() function prototype is in gxstate.h but this was not being included
-<br>
-by this file, so on 64-bit builds it truncatad the memory pointer to 32-bits. Tripped over
-<br>
-on the macpro when doing ps2write. Problematic call was line 1086.
-<br>
-
-<br>
-gs/base/gdevpdfd.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-30 20:02:09 +0100></a>
-2011-06-30 20:02:09 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0038b2fadb34d57f5d43d51d313eb8bc121e929b">0038b2fadb34d57f5d43d51d313eb8bc121e929b</a>
-<blockquote>
-
-<br>
-Fix error in plib and plan devices not properly closing down.
-<br>
-
-<br>
-plib_close and plan_close were failing to call the underlying device
-<br>
-close method, hence leaking.
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/base/gdevplan.c
-<br>
-gs/base/gdevplib.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-30 18:19:30 +0100></a>
-2011-06-30 18:19:30 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b62b3a9ce165ebca357ebf6b4e2ff4cae8d630d3">b62b3a9ce165ebca357ebf6b4e2ff4cae8d630d3</a>
-<blockquote>
-
-<br>
-Fix leak of icc_profile in clist playback.
-<br>
-
-<br>
-When reading an icc_profile profile from the clist we were forgetting to
-<br>
-decrement it's reference count, and so it was being leaked.
-<br>
-
-<br>
-Also fix a whitespace issue.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gscspace.h
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-30 17:05:19 +0100></a>
-2011-06-30 17:05:19 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5baa14a107150a5ba4189ff830f21bfdd7da528c">5baa14a107150a5ba4189ff830f21bfdd7da528c</a>
-<blockquote>
-
-<br>
-More Makefile dependency tweaks.
-<br>
-
-<br>
-Limit our insistence on gnu make (for order only dependencies) to
-<br>
-the autoconf generated makefiles.
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/gs.mak
-<br>
-gs/base/openvms.mak
-<br>
-gs/base/unix-gcc.mak
-<br>
-gs/base/unixhead.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-30 16:42:24 +0100></a>
-2011-06-30 16:42:24 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=396fa30df058ccd35375a08e5385fa4251d4b714">396fa30df058ccd35375a08e5385fa4251d4b714</a>
-<blockquote>
-
-<br>
-Various Memento changes.
-<br>
-
-<br>
-Add MEMENTO_LEAKONLY option to speed Memento (avoids filling memory and
-<br>
-checking the filled values for consistency).
-<br>
-
-<br>
-Also, rewrite freelist management to avoid delays when making room.
-<br>
-
-<br>
-Memento in MEMENTO_LEAKONLY now runs almost as fast as normal code.
-<br>
-
-<br>
-Also change gsalloc.c and gsmchunk.c to fall through to the normal malloc
-<br>
-(and hence Memento) for all blocks (when MEMENTO is defined). No changes
-<br>
-to normal operation.
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/base/gsalloc.c
-<br>
-gs/base/gsmchunk.c
-<br>
-gs/base/malloc_.h
-<br>
-gs/base/memento.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-30 14:24:17 +0100></a>
-2011-06-30 14:24: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=44a609ed782883815571bcbc1ed7a602db03c786">44a609ed782883815571bcbc1ed7a602db03c786</a>
-<blockquote>
-
-<br>
-Another attempt at proper directory dependencies.
-<br>
-
-<br>
-The previous attempt failed due to directories getting their timestamp
-<br>
-updated whenever the contents changed - hence causing stuff to be
-<br>
-always out of date.
-<br>
-
-<br>
-The 'correct' fix appears to be to use order only dependencies. We do
-<br>
-this in a portable way by defining a MAKEDIRS variable, that should
-<br>
-always be the last dependency listed. Unix builds define this to
-<br>
- &quot;| directories&quot;, windows builds leave it blank.
-<br>
-
-<br>
-Testing this work in turn showed up more problems with device
-<br>
-dependencies - also fixed here.
-<br>
-
-<br>
-gs/base/devs.mak
-<br>
-gs/base/gs.mak
-<br>
-gs/base/ijs.mak
-<br>
-gs/base/jpeg.mak
-<br>
-gs/base/lib.mak
-<br>
-gs/base/msvclib.mak
-<br>
-gs/base/openvms.mak
-<br>
-gs/base/unix-aux.mak
-<br>
-gs/base/unix-dll.mak
-<br>
-gs/base/unix-end.mak
-<br>
-gs/base/unixhead.mak
-<br>
-gs/base/unixinst.mak
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-30 13:55:54 +0100></a>
-2011-06-30 13:55: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=93df8de63350ec70d38cc79494a47cf0a6e172b9">93df8de63350ec70d38cc79494a47cf0a6e172b9</a>
-<blockquote>
-
-<br>
-More changes for CIDSet.
-<br>
-
-<br>
-Make sure that if the CID (LastChar) is greater than num_glyphs, then use LastChar
-<br>
-for the length of CIDSet and CIDToGIDMap.
-<br>
-
-<br>
-gs/base/gdevpdtd.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-29 21:39:01 +0100></a>
-2011-06-29 21:39: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=4a65a114f83a6826679625ef8686c1f43c648b43">4a65a114f83a6826679625ef8686c1f43c648b43</a>
-<blockquote>
-
-<br>
-Fix leaks in icc code seen during performance testing.
-<br>
-
-<br>
-Whilst performance testing the new thresholding code against the plank
-<br>
-device as follows:
-<br>
-
-<br>
-pcl6.exe -sDEVICE=plank -o nul: -r600 lj4700_pcl5_color_AC8Z51CC.prn
-<br>
-
-<br>
-various leaks were seen (I used Memento to see them).
-<br>
-
-<br>
-This fixes at least some of them, namely those due to us forgetting to free
-<br>
-a buffer used to read an icc profile into from the clist.
-<br>
-
-<br>
-Various small bits of error case code is also fixed here.
-<br>
-
-<br>
-gs/base/gxclrast.c
-<br>
-gs/base/gxclread.c
-<br>
-gs/base/gxicolor.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-29 21:39:58 +0100></a>
-2011-06-29 21:39:58 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3992ee84c892ed2fcc16b3bd0e89d7e9d878bbaa">3992ee84c892ed2fcc16b3bd0e89d7e9d878bbaa</a>
-<blockquote>
-
-<br>
-Add STDDIRS dependencies to unix-aux too.
-<br>
-
-<br>
-This prevented configured debug gs builds from working (and possibly others).
-<br>
-
-<br>
-gs/base/unix-aux.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-29 20:55:42 +0100></a>
-2011-06-29 20:55:42 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22f63a9438d563c3f36a2e652784d53be028bd7d">22f63a9438d563c3f36a2e652784d53be028bd7d</a>
-<blockquote>
-
-<br>
-Tweak to gsicc_manage.c to avoid potential leak.
-<br>
-
-<br>
-Examining the code, if gsicc_set_icc_directory is called with namelen=0
-<br>
-then the existing code will allocate a 1 byte buffer and store it in
-<br>
-the icc_manager.
-<br>
-
-<br>
-If the same function is called again, in the same way, this buffer
-<br>
-will not be freed before it is overwritten.
-<br>
-
-<br>
-The fix is simply to test for icc_manager->profiledir being non NULL
-<br>
-rather than the namelen > 0.
-<br>
-
-<br>
-gs/base/gsicc_manage.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-29 15:10:03 +0100></a>
-2011-06-29 15:10: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=3a26f3c1aa08e6bd4b4550e066da449fb61ee2cf">3a26f3c1aa08e6bd4b4550e066da449fb61ee2cf</a>
-<blockquote>
-
-<br>
-Makefile dependency fixes.
-<br>
-
-<br>
-Ray pointed out yesterday that the gs makefile has a malformed dependency
-<br>
-rule ensuring that the object dirs are created before any compilation
-<br>
-is done. This doesn't show itself when make is invoked to use a single
-<br>
-build task at once, but parallel invocations (e.g. make -f 5) can fall
-<br>
-foul fof it.
-<br>
-
-<br>
-The fix is to properly make every .$(OBJ) file depend on STDDIRS.
-<br>
-
-<br>
-gs/base/lib.mak
-<br>
-gs/base/msvclib.mak
-<br>
-gs/base/msvctail.mak
-<br>
-gs/base/unix-end.mak
-<br>
-gs/base/unixhead.mak
-<br>
-gs/psi/msvc.mak
-<br>
-gs/toolbin/checkdeps.pl
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-29 08:17:46 +0100></a>
-2011-06-29 08:17: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=865dca5781dcb4fea12d1349d4f7392d7d809c42">865dca5781dcb4fea12d1349d4f7392d7d809c42</a>
-<blockquote>
-
-<br>
-Change the documented default settings for ps2write to match reality.
-<br>
-
-<br>
-gs/doc/Ps2ps2.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-28 21:55:44 -0400></a>
-2011-06-28 21:55:44 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c6a8de32823db74a0da27187b7fb049b337c2573">c6a8de32823db74a0da27187b7fb049b337c2573</a>
-<blockquote>
-
-<br>
-Bug 692305: Remove -dSAFER from pfbtopfa
-<br>
-
-<br>
-Remove -dSAFER flag from pfbtopfa and wftopfa scripts because it
-<br>
-interferes with the the normal operation of Ghostscript and serves
-<br>
-no purpose. No client code is executed by these utilities.
-<br>
-
-<br>
-gs/lib/pfbtopfa
-<br>
-gs/lib/pfbtopfa.bat
-<br>
-gs/lib/wftopfa
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-28 21:54:31 +0100></a>
-2011-06-28 21:54: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=31cb1ff75d4a77ac32854a68f56d973d06b5da10">31cb1ff75d4a77ac32854a68f56d973d06b5da10</a>
-<blockquote>
-
-<br>
-Bug 692310 Add another fallback case for an FT error.
-<br>
-
-<br>
-Add a fallback for the FT_Err_Invalid_Reference error from Freetype.
-<br>
-As this is a hinting error, we'll fall back to rendering the glyph
-<br>
-unhinted.
-<br>
-
-<br>
-No cluster differences.
-<br>
-
-<br>
-gs/psi/fapi_ft.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-28 20:09:11 +0100></a>
-2011-06-28 20:09:11 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a1ee78a6de94b8b4292b9ce3b71b54ed3ae7502b">a1ee78a6de94b8b4292b9ce3b71b54ed3ae7502b</a>
-<blockquote>
-
-<br>
-Fix for Bug 692303, antialiasing problems.
-<br>
-
-<br>
-In trying to fix Bug 692081, I'd inadvertantly broken antialiased
-<br>
-operation on shapes with multiple 'alpha=0'/'alpha-non-zero'
-<br>
-transitions.
-<br>
-
-<br>
-My understanding of Peters line accumulator macros was incomplete.
-<br>
-This new version seems to fix both cases.
-<br>
-
-<br>
-gs/base/gsbitops.h
-<br>
-gs/base/gxcindex.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-28 20:08:40 +0100></a>
-2011-06-28 20:08:40 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d44e8a15bfa263b54b369940db9d8ec97d4fc48">4d44e8a15bfa263b54b369940db9d8ec97d4fc48</a>
-<blockquote>
-
-<br>
-Fix typo in comment.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/gxfill.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-28 13:12:34 +0100></a>
-2011-06-28 13:12:34 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=11fa4e84f504bdbd9e78495cf5214e49554383b0">11fa4e84f504bdbd9e78495cf5214e49554383b0</a>
-<blockquote>
-
-<br>
-More 'aux' makefile changes.
-<br>
-
-<br>
-Configured gs builds were still not putting the aux directory in the
-<br>
-right place. Reworked here.
-<br>
-
-<br>
-This has meant changing the horrible 'RELDIR' hack for a slightly
-<br>
-less horrible hack using 'BUILDDIRPREFIX'. In turn this has meant
-<br>
-that the shared object targets have one mroe layer of recursion in
-<br>
-the make, but it's still at the top level, and (arguably) clearer
-<br>
-now than it was before.
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/configure.ac
-<br>
-gs/base/gs.mak
-<br>
-gs/base/macos-fw.mak
-<br>
-gs/base/macosx.mak
-<br>
-gs/base/ugcclib.mak
-<br>
-gs/base/unix-dll.mak
-<br>
-gs/base/unix-end.mak
-<br>
-gs/base/unix-gcc.mak
-<br>
-gs/base/unixansi.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-27 20:09:20 -0400></a>
-2011-06-27 20:09:20 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=680d0f9b0a30de60c3289b827714be3f5adc65b1">680d0f9b0a30de60c3289b827714be3f5adc65b1</a>
-<blockquote>
-
-<br>
-Rename -dPDFNOSTOPPED to -dPDFSTOPONERROR
-<br>
-
-<br>
-gs/Resource/Init/gs_init.ps
-<br>
-gs/Resource/Init/pdf_base.ps
-<br>
-gs/doc/Use.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-27 19:34:37 -0400></a>
-2011-06-27 19:34:37 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=66700ec35f74a6e049ed6654283418a6d23bfb3e">66700ec35f74a6e049ed6654283418a6d23bfb3e</a>
-<blockquote>
-
-<br>
-Bug 692301: Support /Filter array with /JPXDecode
-<br>
-
-<br>
-Fix a bug in /JPXDecode filter handler that generated bad
-<br>
-/DecodeParms when /JPXDecode filter was used in a /Filter
-<br>
-array. Remove some obsolete code related to /JPXDecode.
-<br>
-
-<br>
-gs/Resource/Init/pdf_base.ps
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-27 14:06:27 -0400></a>
-2011-06-27 14:06:27 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f08f6f0c1b9bae95387534617005df0b4b7e46f">2f08f6f0c1b9bae95387534617005df0b4b7e46f</a>
-<blockquote>
-
-<br>
-Add -dPDFNOSTOPPED option.
-<br>
-
-<br>
-Norrmally, PDF interpreter tries to repair all problems in PDF files.
-<br>
--dPDFNOSTOPPED option skips some of the stopped contexts. On error,
-<br>
-instead of printing a warning and continue, PDF interpreter drops into
-<br>
-a PostScript error handler that prints detailed information about the
-<br>
-problem and kills the job.
-<br>
-
-<br>
-gs/Resource/Init/gs_init.ps
-<br>
-gs/Resource/Init/pdf_base.ps
-<br>
-gs/doc/Use.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-27 09:22:30 -0600></a>
-2011-06-27 09:22:30 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9b9d97a5a2c299595048c72fa10e1a2b2845ff58">9b9d97a5a2c299595048c72fa10e1a2b2845ff58</a>
-<blockquote>
-
-<br>
-Add planar device to the Windows build.
-<br>
-
-<br>
-main/pcl6_msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-27 14:35:52 +0100></a>
-2011-06-27 14:35: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=5e292c6c611659105f9bbc50ad33518c97a1923d">5e292c6c611659105f9bbc50ad33518c97a1923d</a>
-<blockquote>
-
-<br>
-bug #692304 Don't emit '0 g' for 'erasepage'
-<br>
-
-<br>
-showpage causes a fill of an empty path, apparently as part of the erasepage mechanism.
-<br>
-When used with pdfwrite, with -dUseCIEColor -dPDFA and no Output Intent specified
-<br>
-this can lead to us emitting a '0 g' in a PDF/A file, whic his only valid if an OutputIntent is specified.
-<br>
-
-<br>
-Fixed by ignoring empty paths. Despite the comment in gdev_pdf_fill_path we
-<br>
-do not seem to need to do this for text or clips. Probably since I moved the
-<br>
-'pdf_set_drawing_color' code out of pdf_reset_color so that we could write colours in a text context.
-<br>
-
-<br>
-This exhibits one progression, with ps2write 'Bug6901014_CImg_flyer.pdf' now
-<br>
-draws all the output instead of dropping portions of it due to a 'nocurrentpoint' error.
-<br>
-
-<br>
-gs/base/gdevpdfd.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-26 11:20:33 +0100></a>
-2011-06-26 11:20: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=f3b1a56bb0c5d716868b7914bee6c3740f3f035a">f3b1a56bb0c5d716868b7914bee6c3740f3f035a</a>
-<blockquote>
-
-<br>
-Update to libjpeg 8c.
-<br>
-
-<br>
-Combines (from libs-update branch) the commits:
-<br>
-
-<br>
-Commit a vanilla copy of libjpeg-8c.
-<br>
-
-<br>
-And the makefile changes to let it build.
-<br>
-
-<br>
-Commit our patch to the libjpeg source.
-<br>
-
-<br>
-Add our patches to the jpeg-8c src.
-<br>
-
-<br>
-This changes every cluster test which contains DCT/JPEG data, but
-<br>
-they are all very small colour shifts that are invisible
-<br>
-to the naked eye - as expected by this type of update.
-<br>
-
-<br>
-gs/base/jpeg.mak
-<br>
-gs/jpeg/Makefile.am
-<br>
-gs/jpeg/Makefile.in
-<br>
-gs/jpeg/README
-<br>
-gs/jpeg/aclocal.m4
-<br>
-gs/jpeg/ansi2knr.c
-<br>
-gs/jpeg/cderror.h
-<br>
-gs/jpeg/cdjpeg.h
-<br>
-gs/jpeg/change.log
-<br>
-gs/jpeg/cjpeg.1
-<br>
-gs/jpeg/cjpeg.c
-<br>
-gs/jpeg/ckconfig.c
-<br>
-gs/jpeg/coderules.doc
-<br>
-gs/jpeg/coderules.txt
-<br>
-gs/jpeg/config.guess
-<br>
-gs/jpeg/config.sub
-<br>
-gs/jpeg/configure
-<br>
-gs/jpeg/configure.ac
-<br>
-gs/jpeg/depcomp
-<br>
-gs/jpeg/djpeg.1
-<br>
-gs/jpeg/djpeg.c
-<br>
-gs/jpeg/example.c
-<br>
-gs/jpeg/filelist.doc
-<br>
-gs/jpeg/filelist.txt
-<br>
-gs/jpeg/install-sh
-<br>
-gs/jpeg/install.doc
-<br>
-gs/jpeg/install.txt
-<br>
-gs/jpeg/jaricom.c
-<br>
-gs/jpeg/jcapimin.c
-<br>
-gs/jpeg/jcarith.c
-<br>
-gs/jpeg/jccoefct.c
-<br>
-gs/jpeg/jcdctmgr.c
-<br>
-gs/jpeg/jchuff.c
-<br>
-gs/jpeg/jchuff.h
-<br>
-gs/jpeg/jcinit.c
-<br>
-gs/jpeg/jcmainct.c
-<br>
-gs/jpeg/jcmarker.c
-<br>
-gs/jpeg/jcmaster.c
-<br>
-gs/jpeg/jconfig.bcc
-<br>
-gs/jpeg/jconfig.cfg
-<br>
-gs/jpeg/jconfig.dj
-<br>
-gs/jpeg/jconfig.doc
-<br>
-gs/jpeg/jconfig.mac
-<br>
-gs/jpeg/jconfig.manx
-<br>
-gs/jpeg/jconfig.mc6
-<br>
-gs/jpeg/jconfig.sas
-<br>
-gs/jpeg/jconfig.st
-<br>
-gs/jpeg/jconfig.txt
-<br>
-gs/jpeg/jconfig.vc
-<br>
-gs/jpeg/jconfig.vms
-<br>
-gs/jpeg/jconfig.wat
-<br>
-gs/jpeg/jcparam.c
-<br>
-gs/jpeg/jcphuff.c
-<br>
-gs/jpeg/jcprepct.c
-<br>
-gs/jpeg/jcsample.c
-<br>
-gs/jpeg/jctrans.c
-<br>
-gs/jpeg/jdapimin.c
-<br>
-gs/jpeg/jdapistd.c
-<br>
-gs/jpeg/jdarith.c
-<br>
-gs/jpeg/jdatadst.c
-<br>
-gs/jpeg/jdatasrc.c
-<br>
-gs/jpeg/jdcoefct.c
-<br>
-gs/jpeg/jdct.h
-<br>
-gs/jpeg/jddctmgr.c
-<br>
-gs/jpeg/jdhuff.c
-<br>
-gs/jpeg/jdhuff.h
-<br>
-gs/jpeg/jdinput.c
-<br>
-gs/jpeg/jdmainct.c
-<br>
-gs/jpeg/jdmarker.c
-<br>
-gs/jpeg/jdmaster.c
-<br>
-gs/jpeg/jdphuff.c
-<br>
-gs/jpeg/jdsample.c
-<br>
-gs/jpeg/jdtrans.c
-<br>
-gs/jpeg/jerror.h
-<br>
-gs/jpeg/jfdctflt.c
-<br>
-gs/jpeg/jfdctfst.c
-<br>
-gs/jpeg/jfdctint.c
-<br>
-gs/jpeg/jidctflt.c
-<br>
-gs/jpeg/jidctint.c
-<br>
-gs/jpeg/jidctred.c
-<br>
-gs/jpeg/jmorecfg.h
-<br>
-gs/jpeg/jpegint.h
-<br>
-gs/jpeg/jpeglib.h
-<br>
-gs/jpeg/jpegtran.1
-<br>
-gs/jpeg/jpegtran.c
-<br>
-gs/jpeg/jutils.c
-<br>
-gs/jpeg/jversion.h
-<br>
-gs/jpeg/libjpeg.doc
-<br>
-gs/jpeg/libjpeg.map
-<br>
-gs/jpeg/libjpeg.txt
-<br>
-gs/jpeg/ltconfig
-<br>
-gs/jpeg/ltmain.sh
-<br>
-gs/jpeg/makcjpeg.st
-<br>
-gs/jpeg/makdjpeg.st
-<br>
-gs/jpeg/makeadsw.vc6
-<br>
-gs/jpeg/makeapps.ds
-<br>
-gs/jpeg/makeasln.v10
-<br>
-gs/jpeg/makecdep.vc6
-<br>
-gs/jpeg/makecdsp.vc6
-<br>
-gs/jpeg/makecfil.v10
-<br>
-gs/jpeg/makecmak.vc6
-<br>
-gs/jpeg/makecvcx.v10
-<br>
-gs/jpeg/makeddep.vc6
-<br>
-gs/jpeg/makeddsp.vc6
-<br>
-gs/jpeg/makedfil.v10
-<br>
-gs/jpeg/makedmak.vc6
-<br>
-gs/jpeg/makedvcx.v10
-<br>
-gs/jpeg/makefile.ansi
-<br>
-gs/jpeg/makefile.bcc
-<br>
-gs/jpeg/makefile.cfg
-<br>
-gs/jpeg/makefile.dj
-<br>
-gs/jpeg/makefile.manx
-<br>
-gs/jpeg/makefile.mc6
-<br>
-gs/jpeg/makefile.mms
-<br>
-gs/jpeg/makefile.sas
-<br>
-gs/jpeg/makefile.unix
-<br>
-gs/jpeg/makefile.vc
-<br>
-gs/jpeg/makefile.vms
-<br>
-gs/jpeg/makefile.wat
-<br>
-gs/jpeg/makejdep.vc6
-<br>
-gs/jpeg/makejdsp.vc6
-<br>
-gs/jpeg/makejdsw.vc6
-<br>
-gs/jpeg/makejfil.v10
-<br>
-gs/jpeg/makejmak.vc6
-<br>
-gs/jpeg/makejsln.v10
-<br>
-gs/jpeg/makejvcx.v10
-<br>
-gs/jpeg/makelib.ds
-<br>
-gs/jpeg/makeproj.mac
-<br>
-gs/jpeg/makerdep.vc6
-<br>
-gs/jpeg/makerdsp.vc6
-<br>
-gs/jpeg/makerfil.v10
-<br>
-gs/jpeg/makermak.vc6
-<br>
-gs/jpeg/makervcx.v10
-<br>
-gs/jpeg/maketdep.vc6
-<br>
-gs/jpeg/maketdsp.vc6
-<br>
-gs/jpeg/maketfil.v10
-<br>
-gs/jpeg/maketmak.vc6
-<br>
-gs/jpeg/maketvcx.v10
-<br>
-gs/jpeg/makewdep.vc6
-<br>
-gs/jpeg/makewdsp.vc6
-<br>
-gs/jpeg/makewfil.v10
-<br>
-gs/jpeg/makewmak.vc6
-<br>
-gs/jpeg/makewvcx.v10
-<br>
-gs/jpeg/makljpeg.st
-<br>
-gs/jpeg/maktjpeg.st
-<br>
-gs/jpeg/missing
-<br>
-gs/jpeg/rdbmp.c
-<br>
-gs/jpeg/rdjpgcom.1
-<br>
-gs/jpeg/rdjpgcom.c
-<br>
-gs/jpeg/rdppm.c
-<br>
-gs/jpeg/rdswitch.c
-<br>
-gs/jpeg/structure.doc
-<br>
-gs/jpeg/structure.txt
-<br>
-gs/jpeg/testimg.bmp
-<br>
-gs/jpeg/testimg.jpg
-<br>
-gs/jpeg/testimg.ppm
-<br>
-gs/jpeg/testimgp.jpg
-<br>
-gs/jpeg/transupp.c
-<br>
-gs/jpeg/transupp.h
-<br>
-gs/jpeg/usage.doc
-<br>
-gs/jpeg/usage.txt
-<br>
-gs/jpeg/wizard.doc
-<br>
-gs/jpeg/wizard.txt
-<br>
-gs/jpeg/wrppm.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-26 23:12:38 -0700></a>
-2011-06-26 23:12:38 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5b7a917fa6d092f76a0400e1bce70d02b8b724f1">5b7a917fa6d092f76a0400e1bce70d02b8b724f1</a>
-<blockquote>
-
-<br>
-Fix for compiler complaint.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/gsicc_manage.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-25 11:07:25 -0700></a>
-2011-06-25 11:07:25 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f4e1d4b280f6e6ff73d630e2b103a1a6b50c03d9">f4e1d4b280f6e6ff73d630e2b103a1a6b50c03d9</a>
-<blockquote>
-
-<br>
-Fix for icc directory and icc device profile initialization.
-<br>
-
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gsdevice.c
-<br>
-gs/base/gsdparam.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/base/lib.mak
-<br>
-gs/psi/zdevice.c
-<br>
-pcl/pctop.c
-<br>
-psi/psitop.c
-<br>
-pxl/pxpthr.c
-<br>
-pxl/pxtop.c
-<br>
-svg/svgtop.c
-<br>
-xps/xpstop.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-24 18:46:51 +0100></a>
-2011-06-24 18:46:51 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7af1ebacdb9947ea5197523bcda7764431769e8f">7af1ebacdb9947ea5197523bcda7764431769e8f</a>
-<blockquote>
-
-<br>
-Add copy_plane to rop source device.
-<br>
-
-<br>
-This uses 'creative engineering' (aka a blatant hack) to allow copy_color
-<br>
- to be implemented in the &quot;rop source&quot; device.
-<br>
-
-<br>
-We implement a copy_plane entrypoint for the rop source device, that
-<br>
-does exactly the same as copy_color, except that it abuses the lop
-<br>
-value passed to the gx_device_color_fill_rectangle by setting a new
-<br>
-bit (lop_planar) and pickling the plane number into the high bits.
-<br>
-
-<br>
-This is detected in mem_planar_strip_copy_rop and unpicked to a call
-<br>
-to the appropriate plane.
-<br>
-
-<br>
-Care must be taken when doing rops on the planar device, as
-<br>
-processing any rop on the device that involves 'D' calls get_bit_rectangle
-<br>
-which can cause a call to convert from planar to chunky if mishandled.
-<br>
-The solution is to ensure that we always remove our get_bits_rectangle
-<br>
-implementation when passing on a ropping call.
-<br>
-
-<br>
-gs/base/gdevmpla.c
-<br>
-gs/base/gdevrops.c
-<br>
-gs/base/gsropt.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-24 17:38:55 +0100></a>
-2011-06-24 17:38: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=0c927bb3e177b5b34ebb1b1f7fa2d9669614fbaf">0c927bb3e177b5b34ebb1b1f7fa2d9669614fbaf</a>
-<blockquote>
-
-<br>
-Bug 692274: handle vastly different magnitudes in x/y scale
-<br>
-
-<br>
-If the difference in the scale on the x and y axes is large
-<br>
-(in this case, a factor of 1000), the value scaling we do
-<br>
-to pass into Freetype can run over/under flow when applied
-<br>
-to both. The solution is to apply the value scaling
-<br>
-separately for x and y axes. But the quality is very
-<br>
-marginally better when the two are scaled together, so we
-<br>
-do that normally, and only fall back to the separate handling
-<br>
-when the x and y scales differ by more than 512.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/psi/fapi_ft.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-24 12:11:48 +0100></a>
-2011-06-24 12:11:48 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=90324e2c6466978f3c01e4a5a3c27d916b9ba9fa">90324e2c6466978f3c01e4a5a3c27d916b9ba9fa</a>
-<blockquote>
-
-<br>
-Fix 'aux' cluster breakages. Move aux into obj.
-<br>
-
-<br>
-Move aux directories into the appropriate obj directories.
-<br>
-Makes cleaning easier, and is neater overall.
-<br>
-
-<br>
-Also fix some unrelated problems with cleaning in the msvc builds.
-<br>
-
-<br>
-common/msvc_top.mak
-<br>
-common/pcdefs.mak
-<br>
-gs/base/all-arch.mak
-<br>
-gs/psi/msvc.mak
-<br>
-gs/psi/os2.mak
-<br>
-gs/toolbin/localcluster/clusterpush.pl
-<br>
-main/pcl6_gcc.mak
-<br>
-main/pcl6_msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-23 12:53:01 -0600></a>
-2011-06-23 12:53:01 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7f2d55272963b039a472adbd26bb9a111e5d31ac">7f2d55272963b039a472adbd26bb9a111e5d31ac</a>
-<blockquote>
-
-<br>
-Use filenames instead of stdin and stdout.
-<br>
-
-<br>
-The original example c programs used stdin and stdout instead of
-<br>
-reading directly from files. The C programs were changed to use files
-<br>
-but the associated shell script wasn't updated.
-<br>
-
-<br>
-tools/GOT/dotags.sh
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-22 21:39:01 +0100></a>
-2011-06-22 21:39: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=ca0f4ff4a0df386dd4d494a418f09336d06c2451">ca0f4ff4a0df386dd4d494a418f09336d06c2451</a>
-<blockquote>
-
-<br>
-Cross compilation (AUX) changes to ghostscript and ghostpdl.
-<br>
-
-<br>
-Introduce a new 'aux' directory and appropriate defines to allow
-<br>
-easier cross-compilation of gs/ghostpdl.
-<br>
-
-<br>
-common/gccdefs.mak
-<br>
-common/generic.mak
-<br>
-common/msvc_top.mak
-<br>
-common/ugcc_top.mak
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/all-arch.mak
-<br>
-gs/base/gs.mak
-<br>
-gs/base/lib.mak
-<br>
-gs/base/msvccmd.mak
-<br>
-gs/base/msvctail.mak
-<br>
-gs/base/unix-aux.mak
-<br>
-gs/base/unix-end.mak
-<br>
-gs/base/zlib.mak
-<br>
-gs/psi/msvc.mak
-<br>
-gs/psi/os2.mak
-<br>
-main/pcl6_gcc.mak
-<br>
-main/pcl6_msvc.mak
-<br>
-pl/pl.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-22 20:05:15 +0100></a>
-2011-06-22 20:05: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=3b3261eca08cd73ca355b28fe5125c98d411820d">3b3261eca08cd73ca355b28fe5125c98d411820d</a>
-<blockquote>
-
-<br>
-Bug 692297: reinstate the proper way to release FT glyphs.
-<br>
-
-<br>
-FT_Glyph_Done is the correct method for freeing both bitmap and
-<br>
-outline glyphs from Freetype.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/psi/fapi_ft.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-22 10:46:18 -0700></a>
-2011-06-22 10:46:18 -0700</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f8c4663d5108ca0b7416bf35ba37a8bb63f0b8ed">f8c4663d5108ca0b7416bf35ba37a8bb63f0b8ed</a>
-<blockquote>
-
-<br>
-Improve documentation about gsapi_set_poll
-<br>
-
-<br>
-gs/doc/API.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-22 10:17:32 -0700></a>
-2011-06-22 10:17:32 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b28982145ccdea3a39f7ad13d7f5c8a00f14f83d">b28982145ccdea3a39f7ad13d7f5c8a00f14f83d</a>
-<blockquote>
-
-<br>
-Replace previous commit file with smaller file.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/examples/text_graphic_image.pdf
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-22 10:12:33 -0700></a>
-2011-06-22 10:12:33 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=314d8b86434396afe96ce915dbb1cb0ff01b2047">314d8b86434396afe96ce915dbb1cb0ff01b2047</a>
-<blockquote>
-
-<br>
-Addition of simple example file with text graphic and image objects.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/examples/text_graphic_image.pdf
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-22 09:05:28 -0700></a>
-2011-06-22 09:05:28 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e3def0b758231cd1c5c0510945cef0dd3d938393">e3def0b758231cd1c5c0510945cef0dd3d938393</a>
-<blockquote>
-
-<br>
-Support for fast thresholding to CMYK planar devices
-<br>
-
-<br>
-Code works for various orientations for color as well as indexed (mono) images.
-<br>
-There is an inversion (polarity) issue remaining to track down as well as one potential
-<br>
-rendering issue during the buffer clean up with landscape images. These
-<br>
-will be resolved shortly. For now, code is sufficiently complete to begin
-<br>
-timing testing and optimizations. To use specify
-<br>
-
-<br>
--dCOLORSCREEN -sDEVICE=plank
-<br>
-
-<br>
-and enable processing of color images by setting use_fast_thresh = true
-<br>
-on line 67 in gxicolor.c
-<br>
-
-<br>
-gs/base/gxht_thresh.c
-<br>
-gs/base/gxht_thresh.h
-<br>
-gs/base/gxicolor.c
-<br>
-gs/base/gxidata.c
-<br>
-gs/base/gximono.c
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-21 18:52:03 +0100></a>
-2011-06-21 18:52: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=fef629cab877b0bbf4f86777f37038d1f37de838">fef629cab877b0bbf4f86777f37038d1f37de838</a>
-<blockquote>
-
-<br>
-Fix cut/paste tiffscaled typo in docs.
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/doc/Devices.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-21 16:45:52 +0100></a>
-2011-06-21 16:45: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=368e14c73337b42a24299445a660f029d2c26861">368e14c73337b42a24299445a660f029d2c26861</a>
-<blockquote>
-
-<br>
-Reinstate the configure check for cups/raster.h.
-<br>
-
-<br>
-Several Linux distributions seem to have neglected to make
-<br>
-the cups development package depend on the cupsimage
-<br>
-development package, but we need both for the cups device.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-21 12:31:45 +0100></a>
-2011-06-21 12:31: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=dfc53c791d8a121273bd22bbc0c04fd3ed375cdf">dfc53c791d8a121273bd22bbc0c04fd3ed375cdf</a>
-<blockquote>
-
-<br>
-Bug #692218 Create comatible CIDSet
-<br>
-
-<br>
-The fix in Bug 692218 did not (apparently) work for the SolidWorks
-<br>
-PDF/A validator. This patch sets the number of entries in a CIDSet to
-<br>
-be the number of glyphs in the font program, and makes the number of entries
-<br>
-in a CIDToGIDMap the same.
-<br>
-
-<br>
-Together with the commit 27b740 here:
-<br>
-
-<br>
-http://ghostscript.com/pipermail/gs-cvs/2011-June/013024.html
-<br>
-
-<br>
-this now seems to work correctly.
-<br>
-
-<br>
-gs/base/gdevpdtd.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-21 12:08:58 +0100></a>
-2011-06-21 12:08:58 +0100</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=136934cf60977e5ca6c1a77f8fd4d30a8512b206">136934cf60977e5ca6c1a77f8fd4d30a8512b206</a>
-<blockquote>
-
-<br>
-Allow pdfwrite and ps2write to use 64-bit file pointers raising the 4Gb file limit.
-<br>
-
-<br>
-Bug #692290 ps2write and pdfwrite have been using gp_open_scratch_file,
-<br>
-fseek and ftell, which limit the size of a temporary file to 4GB. This
-<br>
-commit uses gp_open_scratch_file_64, gp_ftell_64 and gp_fseek_64 whcih
-<br>
-should allow 64-bit file access on systems which support it.
-<br>
-
-<br>
-Unfortunately I haven't been able to concoct a test for this, so the
-<br>
-64-bit code is not tested. However it continues to work normally with the
-<br>
-clustre regression tests.
-<br>
-
-<br>
-gs/base/gdevpdf.c
-<br>
-gs/base/gdevpdfo.c
-<br>
-gs/base/gdevpdfp.c
-<br>
-gs/base/gdevpdfu.c
-<br>
-gs/base/gdevpdfx.h
-<br>
-gs/base/gdevpsu.c
-<br>
-gs/base/gdevpsu.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-20 17:57:46 +0100></a>
-2011-06-20 17:57:46 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=da1152191fb97516b82303ab187b08c971bfd360">da1152191fb97516b82303ab187b08c971bfd360</a>
-<blockquote>
-
-<br>
-Fix Bug 692057, 'hang' while converting mask->rectangle list.
-<br>
-
-<br>
-Previously the clip accumulator code would attempt to add a new
-<br>
-rectangle would always search backwards from the tail of the
-<br>
-list when looking for a new place to insert a rectangle.
-<br>
-
-<br>
-This works well when rectangles are coming in at (or near) the
-<br>
-end of the list. For cases where this doesn't happen we quickly
-<br>
-break down to O(n^2) operation.
-<br>
-
-<br>
-The example file on the bug shows one such circumstance, where
-<br>
-we process a landscape image; this results in the masks coming
-<br>
-in as '8 bit columns'. The first column accumulates nicely,
-<br>
-subsequent ones do not.
-<br>
-
-<br>
-The fix here, as suggested by Chris Liddell, is to store the
-<br>
-'last insert point', and to search from that. Locality of
-<br>
-reference should pay off here and lead to much improved
-<br>
-performance. Certainly tests with the example file show that we
-<br>
-complete within 2.5 minutes on my machine, compared to 1.5 minutes
-<br>
-with -dMaxPatternBitmap=32000000, and an unknown time over 5 minutes
-<br>
-with the old code.
-<br>
-
-<br>
-gs/base/gxacpath.c
-<br>
-gs/base/gxcpath.c
-<br>
-gs/base/gxcpath.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-20 09:56:37 -0600></a>
-2011-06-20 09:56:37 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=19f10a95bae408363a77f5a2fd05f69350269cb7">19f10a95bae408363a77f5a2fd05f69350269cb7</a>
-<blockquote>
-
-<br>
-Merge branch 'deprecate_crd_and_cleanup'
-<br>
-
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-03 00:15:50 -0600></a>
-2011-06-03 00:15:50 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=476256194a8886951885a4e9ce71972504161192">476256194a8886951885a4e9ce71972504161192</a>
-<blockquote>
-
-<br>
-Deprecate CRDs in PCL
-<br>
-
-<br>
-pcl/pccrd.c
-<br>
-pcl/pccrd.h
-<br>
-pcl/pcdraw.c
-<br>
-pcl/pcfrgrnd.c
-<br>
-pcl/pcfrgrnd.h
-<br>
-pcl/pcl.mak
-<br>
-pcl/pcommand.c
-<br>
-pcl/pcpalet.c
-<br>
-pcl/pcpalet.h
-<br>
-pcl/pcpatrn.c
-<br>
-pcl/pcpattyp.h
-<br>
-pcl/pcstate.h
-<br>
-pcl/pctop.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-02 16:55:55 -0600></a>
-2011-06-02 16:55:55 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1c1c457a4262f1ef539ec75792c57494c8a746b2">1c1c457a4262f1ef539ec75792c57494c8a746b2</a>
-<blockquote>
-
-<br>
-Trivial warning fixes
-<br>
-
-<br>
-pcl/pcindxed.c
-<br>
-pcl/pcpage.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-02 14:18:35 -0600></a>
-2011-06-02 14:18:35 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=854a16b3eefc0d3b434f446db84e3a9317eda49e">854a16b3eefc0d3b434f446db84e3a9317eda49e</a>
-<blockquote>
-
-<br>
-Make page size procedure robust against paper size table changes.
-<br>
-
-<br>
-pcl/pcpage.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-01 11:52:40 -0600></a>
-2011-06-01 11:52:40 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b89ab3397895d41818170a7f4ea893bbb1580e79">b89ab3397895d41818170a7f4ea893bbb1580e79</a>
-<blockquote>
-
-<br>
-Clean up warnings and problems identified with static analysis.
-<br>
-
-<br>
-pcl/pcstatus.c
-<br>
-pcl/pctext.c
-<br>
-pcl/pctop.c
-<br>
-pcl/pcuptrn.c
-<br>
-pcl/pgdraw.c
-<br>
-pcl/pglabel.c
-<br>
-pcl/pgvector.c
-<br>
-pl/pjparse.c
-<br>
-pl/plchar.c
-<br>
-pxl/pxfont.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-27 14:30:10 -0600></a>
-2011-05-27 14:30:10 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=22b24ea5e3006b4cdc0394c9360423f02b6d3bf9">22b24ea5e3006b4cdc0394c9360423f02b6d3bf9</a>
-<blockquote>
-
-<br>
-Code cleanup directed by static analysis tools.
-<br>
-
-<br>
-Changes function not properly made static, removes unread and unused
-<br>
-variables.
-<br>
-
-<br>
-pxl/pxpthr.c
-<br>
-pxl/pxsessio.c
-<br>
-pxl/pxtop.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-27 13:48:38 -0600></a>
-2011-05-27 13:48:38 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=00d4d232283b2eb6c9820618d04b5d4c9eb8a7b3">00d4d232283b2eb6c9820618d04b5d4c9eb8a7b3</a>
-<blockquote>
-
-<br>
-Makes procedure static.
-<br>
-
-<br>
-pcl/pctop.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-27 13:45:03 -0600></a>
-2011-05-27 13:45: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=d98ceb81d6d45f4a2bc49b2f28dd16fe94fea601">d98ceb81d6d45f4a2bc49b2f28dd16fe94fea601</a>
-<blockquote>
-
-<br>
-Fixes static analyzer discovered logic error.
-<br>
-
-<br>
-With an array size of 0, the line dash pattern should not be accessed.
-<br>
-
-<br>
-pxl/pxgstate.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-20 15:43:34 +0100></a>
-2011-06-20 15:43: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=9d0ded9edc84704afd3724b3c7810c035dc4e699">9d0ded9edc84704afd3724b3c7810c035dc4e699</a>
-<blockquote>
-
-<br>
-Permit the calculation of CIDSet and CIDToGIDMap size, for PDF/A validation
-<br>
-
-<br>
-The SolidWorks PDF/A validator complains about the CIDSet we produce for
-<br>
-embedded TrueType fonts, converted to CIDFonts, when creating PDF/A files.
-<br>
-
-<br>
-I'm still not exactly sure what its complaining about but I'm working with
-<br>
-our customer to resolve this. In the meantime, this code makes it easier
-<br>
-to play with teh emission of CIDSet and CIDToGIDMap.
-<br>
-
-<br>
-gs/base/gdevpdtb.c
-<br>
-gs/base/gdevpdtd.c
-<br>
-gs/base/gdevpdtf.c
-<br>
-gs/base/gdevpdtf.h
-<br>
-gs/base/gdevpdtw.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-20 11:17:26 +0100></a>
-2011-06-20 11:17: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=27b7404218093f3d1cf414b52721c8a24dbc2746">27b7404218093f3d1cf414b52721c8a24dbc2746</a>
-<blockquote>
-
-<br>
-ps2write output crashes with limitcheck error after converting large documents
-<br>
-
-<br>
-Adopting patch from 'Steve166' (bug # 692172) with a little gratuitous
-<br>
-reformatting. (note that opdfread.ps is now compiled in as opdfread.h)
-<br>
-
-<br>
-This converts the directory of objects from an array to a dictionary of dictionaries
-<br>
-which allows for a more or less unlimited (64k*64k) number of objects.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/opdfread.h
-<br>
-gs/lib/opdfread.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-20 03:12:22 -0700></a>
-2011-06-20 03:12:22 -0700</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0700f67de273e92f06a1e4a0e67e3d023fc29442">0700f67de273e92f06a1e4a0e67e3d023fc29442</a>
-<blockquote>
-
-<br>
-Added dependencies to various makefiles to fix parallel make.
-<br>
-
-<br>
-gs/base/lib.mak
-<br>
-gs/contrib/contrib.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-17 23:20:30 +0000></a>
-2011-06-17 23:20:30 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=29c7111f3fc5eb4878e875674750c79b1bd85bcc">29c7111f3fc5eb4878e875674750c79b1bd85bcc</a>
-<blockquote>
-
-<br>
-Add gdevplan.c to ghostscript visual studio project.
-<br>
-
-<br>
-Should have done this earlier, but forgot. CLUSTER UNTESTED as windows
-<br>
-only.
-<br>
-
-<br>
-gs/ghostscript.vcproj
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-17 21:08:49 +0100></a>
-2011-06-17 21:08:49 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=75e1e089f68480b68bb9548ba1e6cf0b9d0f73e0">75e1e089f68480b68bb9548ba1e6cf0b9d0f73e0</a>
-<blockquote>
-
-<br>
-Fix windows compile breakage; missing definition of int64_t.
-<br>
-
-<br>
- Simply add a #include &quot;stdint_.h&quot; to the top of a file; breakage
-<br>
-presumably caused by the dependency changes done earlier.
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/base/gstparam.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-17 12:34:26 -0700></a>
-2011-06-17 12:34:26 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b058182285c21ff142e46997fd3b8510b6993d66">b058182285c21ff142e46997fd3b8510b6993d66</a>
-<blockquote>
-
-<br>
-Fix for improper offset in contone data. Halftone project only.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/gxicolor.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-17 12:32:11 -0700></a>
-2011-06-17 12:32:11 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=096e21027a7ff99cf0e3d0d1e24dac29b2d69f12">096e21027a7ff99cf0e3d0d1e24dac29b2d69f12</a>
-<blockquote>
-
-<br>
-Fix for Bug 692286 - Image too light -- not fully opaque
-<br>
-
-<br>
-when I did some of the work on the compositor queue I had set things up so that the
-<br>
-update of the blend parameters would be written only into the same bands as the group
-<br>
-push. The approach of writing only in the bands of the group bounding box will not
-<br>
-work in general, for example if we have nested groups that only partially overlap. The
-<br>
-solution is that we have to write the blend parameters in all bands.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-17 10:37:44 -0700></a>
-2011-06-17 10:37:44 -0700</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ee45ee90570975275ad6b826b377d6852b651b6a">ee45ee90570975275ad6b826b377d6852b651b6a</a>
-<blockquote>
-
-<br>
-Fix bug 692254 performance problem with pattern that bbox overflowed fixed.
-<br>
-
-<br>
-The compute_inst_matrix relied on the gx_translate_to_fixed but when the
-<br>
-tx, ty was outside the valid area (txy_fixed_valid false) the float2fixed
-<br>
-would overflow and change the sign. This killed the performance when the
-<br>
-j0, i0 loop in tile by steps calculated a VERY large loop range from large
-<br>
-negative to large positive value.
-<br>
-
-<br>
-The gx_path_translate may not be needed for in this path, but it is included
-<br>
-since that was in the gx_path_translate_to_fixed. Quick check showed that the
-<br>
-path is empty as expected, but the call is harmless.
-<br>
-
-<br>
-gs/base/gsptype1.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-17 19:43:09 +0100></a>
-2011-06-17 19:43:09 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9dd7c86d0619a9293f6476092765b86abab3baf1">9dd7c86d0619a9293f6476092765b86abab3baf1</a>
-<blockquote>
-
-<br>
-Move planar dev_spec_op into core planar device.
-<br>
-
-<br>
-Rather than having plib and plan devices provide a dev_spec_op that
-<br>
-responds to gxdso_is_native_planar, put the responsibility for this
-<br>
-into the core planar memory device.
-<br>
-
-<br>
-This not only simplifies the code, it actually fixes a problem whereby
-<br>
-the memory device was overwriting it with the default.
-<br>
-
-<br>
-gs/base/gdevmpla.c
-<br>
-gs/base/gdevplan.c
-<br>
-gs/base/gdevplib.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-03 09:55:57 -0700></a>
-2011-06-03 09:55:57 -0700</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a2a0b404be0365a2f789e154733ab51db3b3aa99">a2a0b404be0365a2f789e154733ab51db3b3aa99</a>
-<blockquote>
-
-<br>
-Add an example that uses PostScript to do simple transparency.
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/examples/transparency_example.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-17 17:53:53 +0000></a>
-2011-06-17 17:53:53 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f80bc7001e2e250348a6db82aa50d25d18848b66">f80bc7001e2e250348a6db82aa50d25d18848b66</a>
-<blockquote>
-
-<br>
-Enable plan devices in non-windows builds.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/unix-gcc.mak
-<br>
-main/pcl6_gcc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-17 17:11:27 +0000></a>
-2011-06-17 17:11:27 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ed123916f3f3373d5648011ea03c3cd969e00c1">4ed123916f3f3373d5648011ea03c3cd969e00c1</a>
-<blockquote>
-
-<br>
-Fix for Bug 692285: phase shift in patterns in long image.
-<br>
-
-<br>
-The phase for a pattern mask was being held in a short, rather
-<br>
-than in an int. Unsurprisingly this caused problems when the
-<br>
-phase overflowed. Simple fix is to use an int instead.
-<br>
-
-<br>
-Cluster testing shows no changes.
-<br>
-
-<br>
-gs/base/gsdcolor.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-17 13:21:05 +0100></a>
-2011-06-17 13:21: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=b8326c843f0d14b55b7b5cc3694977df73d4a0e4">b8326c843f0d14b55b7b5cc3694977df73d4a0e4</a>
-<blockquote>
-
-<br>
-Remove circular dependency involving gscms.h.
-<br>
-
-<br>
-Robin Watts identified that gscms.h relies on gsutil.h
-<br>
-which relies on gxstate.h, which relies on gscspace.h which
-<br>
-relies on gscms.h
-<br>
-
-<br>
-Adding a couple of opaque declarations to gscspace.h (along with
-<br>
-relevant declaration guards) removes this circular dependency.
-<br>
-
-<br>
-No cluster differences.
-<br>
-
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gscspace.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-17 09:43:21 +0100></a>
-2011-06-17 09:43:21 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af98a55ac576545d9495cef0884462b7b2fb8205">af98a55ac576545d9495cef0884462b7b2fb8205</a>
-<blockquote>
-
-<br>
-Tidy up some of the GS<->FT number conversions.
-<br>
-
-<br>
-gs/psi/fapi_ft.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-17 09:49:14 +0000></a>
-2011-06-17 09:49:14 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7a8971739d33a18dd7d433adcabf2e2dea5b6ba8">7a8971739d33a18dd7d433adcabf2e2dea5b6ba8</a>
-<blockquote>
-
-<br>
-New lib.mak dependency checker, and update lib.mak using it.
-<br>
-
-<br>
-Invoke gs/toolbin/checkdeps.pl and it performs rudimentary
-<br>
-and easily confused checks on the dependencies in lib.mak.
-<br>
-It may be simple, but it spots MANY problems, the important
-<br>
-of which are fixed here.
-<br>
-
-<br>
-It gets easily confused by files not being in the expected
-<br>
-paths (but these are easy for an operator to spot and ignore).
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gxstroke.c
-<br>
-gs/base/lib.mak
-<br>
-gs/toolbin/checkdeps.pl
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-17 09:30:32 +0100></a>
-2011-06-17 09:30: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=2cd56d061e655569ec473d605caae9552355a59f">2cd56d061e655569ec473d605caae9552355a59f</a>
-<blockquote>
-
-<br>
-Bug 689546: Add clist.dev to the core lib dependencies.
-<br>
-
-<br>
-I previously noted that the clist device is essentially always required
-<br>
-now, but I used a less than ideal method to address it: having it as
-<br>
-a dependency of the gdevprn.o object.
-<br>
-
-<br>
-The correct solution, done here, is to include the clist device in the
-<br>
-libs.dev file, thus making it a direct requirement of the core lib.
-<br>
-
-<br>
-No cluster differences.
-<br>
-
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-16 12:11:41 -0700></a>
-2011-06-16 12:11:41 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=449e9c8909e5e0cbf92497f1d95bfe60e8e89f6e">449e9c8909e5e0cbf92497f1d95bfe60e8e89f6e</a>
-<blockquote>
-
-<br>
-Addition of copy_plane command for clist
-<br>
-
-<br>
-The command closely mimics the copy_mono command and as such shares its
-<br>
-command operator. With a bit of work it would be possible to get some minor
-<br>
-code reduction but the recursive nature of the functions makes it a bit
-<br>
-tricky.
-<br>
-
-<br>
-gs/base/gxcldev.h
-<br>
-gs/base/gxclimag.c
-<br>
-gs/base/gxclist.c
-<br>
-gs/base/gxclist.h
-<br>
-gs/base/gxclrast.c
-<br>
-gs/base/gxclrect.c
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-16 14:55:07 +0100></a>
-2011-06-16 14:55: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=e34770c45cefbe6c4cf2d564269ff849282dd10f">e34770c45cefbe6c4cf2d564269ff849282dd10f</a>
-<blockquote>
-
-<br>
-Second attempt to add plan devices.
-<br>
-
-<br>
-Add new 'plan' family of planar devices.
-<br>
-
-<br>
-Equivalent to the plib devices, but without the necessity to always band,
-<br>
-and not using the band donor.
-<br>
-
-<br>
-From the end users point of view, these output ppm etc and are probably
-<br>
-therefore not that useful as is. They serve the twin purposes of allowing
-<br>
-us to test planar output, and to act as a basis for devices that need
-<br>
-planar non-interlaced output.
-<br>
-
-<br>
-The development of these devices showed a problem with
-<br>
-gx_get_bits_return_pointer in the planar case. When called, it would
-<br>
-assume that the start of the first line of the first plane was at
-<br>
-'base', and that subsequent planes could be reached by adding
-<br>
-raster * height to it. Unfortunately, clist_rasterize_lines resets the
-<br>
-buffer device at the end, so that height is unrelated (often 1).
-<br>
-
-<br>
-The fix implemented here is to change gx_get_bits_return_pointer to take
-<br>
-a pointer to the line pointers, rather than a direct base value. This
-<br>
-means we can always find the subsequent planes correctly.
-<br>
-
-<br>
-In my initial attempt at this, I broke the code by failing to notice that
-<br>
-gdevmem.c passes the same base pointer to gx_get_bits_copy. Fixed here.
-<br>
-Cluster testing shows it be OK this time around.
-<br>
-
-<br>
-gs/base/devs.mak
-<br>
-gs/base/gdevdgbr.c
-<br>
-gs/base/gdevmem.c
-<br>
-gs/base/gdevmpla.c
-<br>
-gs/base/gdevplan.c
-<br>
-gs/base/gdevplib.c
-<br>
-gs/base/gxgetbit.h
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-16 11:49:18 +0000></a>
-2011-06-16 11:49:18 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=11e242eae4d9c78a556b030ef5e69cb0c94e0d48">11e242eae4d9c78a556b030ef5e69cb0c94e0d48</a>
-<blockquote>
-
-<br>
-Backout previous commit of 'plan' devices.
-<br>
-
-<br>
-The previous commit caused large numbers of changes. Back it out while
-<br>
-I investigate why.
-<br>
-
-<br>
-gs/base/devs.mak
-<br>
-gs/base/gdevdgbr.c
-<br>
-gs/base/gdevmem.c
-<br>
-gs/base/gdevmpla.c
-<br>
-gs/base/gdevplan.c
-<br>
-gs/base/gdevplib.c
-<br>
-gs/base/gxgetbit.h
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-16 10:00:33 +0100></a>
-2011-06-16 10:00:33 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=583e964a55bf50dc28d1467fd9e9bad7bc03849a">583e964a55bf50dc28d1467fd9e9bad7bc03849a</a>
-<blockquote>
-
-<br>
-Add new 'plan' family of planar devices.
-<br>
-
-<br>
-Equivalent to the plib devices, but without the necessity to always band,
-<br>
-and not using the band donor.
-<br>
-
-<br>
-From the end users point of view, these output ppm etc and are probably
-<br>
-therefore not that useful as is. They serve the twin purposes of allowing
-<br>
-us to test planar output, and to act as a basis for devices that need
-<br>
-planar non-interlaced output.
-<br>
-
-<br>
-gs/base/devs.mak
-<br>
-gs/base/gdevdgbr.c
-<br>
-gs/base/gdevmem.c
-<br>
-gs/base/gdevmpla.c
-<br>
-gs/base/gdevplan.c
-<br>
-gs/base/gdevplib.c
-<br>
-gs/base/gxgetbit.h
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-14 18:56:03 +0100></a>
-2011-06-14 18:56: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=a36cd9f5c60607dfbc12caadb0987b89ecfa27e7">a36cd9f5c60607dfbc12caadb0987b89ecfa27e7</a>
-<blockquote>
-
-<br>
-Update gx_path_print (and gx_path_dump) to output postscript.
-<br>
-
-<br>
-Same information as before is output, just in a a slightly different
-<br>
-order. This means we can paste it back into a postscript file with
-<br>
-less editing.
-<br>
-
-<br>
-CLUSTER_UNTESTED as this is never called in production code.
-<br>
-
-<br>
-gs/base/gxpath.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-14 19:15:29 +0100></a>
-2011-06-14 19:15:29 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c442d7d0d5b11addc39519b155b93b3677c11c4d">c442d7d0d5b11addc39519b155b93b3677c11c4d</a>
-<blockquote>
-
-<br>
-Add memento.c/memento.h to VS project
-<br>
-
-<br>
-Forgot to add these when they were created.
-<br>
-
-<br>
-CLUSTER_UNTESTED as windows only.
-<br>
-
-<br>
-gs/ghostscript.vcproj
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-16 09:56:47 +0100></a>
-2011-06-16 09:56:47 +0100</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7de54e55e57f4046196c0909da247f98ef26b46d">7de54e55e57f4046196c0909da247f98ef26b46d</a>
-<blockquote>
-
-<br>
-Extend the uuid change in commit g0b7cd7c to cover Instance UIDs as well as Document UIDs.
-<br>
-
-<br>
-No differences expetced.
-<br>
-
-<br>
-gs/base/gdevpdfe.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-15 19:36:31 +0100></a>
-2011-06-15 19:36: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=45663bbeb798d7a851546a4d6ccf8954e16696ae">45663bbeb798d7a851546a4d6ccf8954e16696ae</a>
-<blockquote>
-<p>
- (pdfwrite) Bug #692280 &quot;Incorrect ToUnicode CMap when the input is a PDF with a 2-byte ToUnicode&quot;
-<br>
-
-<br>
-The code was handling Type 0 fonts as if they were type 1, which meant a maximum
-<br>
-of 256 entries. Fixed by treating them as TrueType CIDFonts (2 byte codes, maximum
-<br>
-64K entries)
-<br>
-
-<br>
-This may need later testing with more extensive collections of conts, we possibly should treat them as regular CIDFotns.
-<br>
-
-<br>
-gs/base/gdevpdte.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-15 12:18:16 -0400></a>
-2011-06-15 12:18:16 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=10fad95042303b1996d8565a40d8ca4d5c4eed06">10fad95042303b1996d8565a40d8ca4d5c4eed06</a>
-<blockquote>
-
-<br>
-Dump unchanged MediaBox and CropBox values.
-<br>
-
-<br>
-Output unmodified values of /MediaBox and /CropBox attributes.
-<br>
-This is done on request from a customer, but should also benefit
-<br>
-every pdf_info.ps user. This change is not backward compatible.
-<br>
-
-<br>
-gs/toolbin/pdf_info.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-15 01:53:26 -0400></a>
-2011-06-15 01:53:26 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=28ab2c1fafd763c7ab1074c91bf217bbbc871fe7">28ab2c1fafd763c7ab1074c91bf217bbbc871fe7</a>
-<blockquote>
-
-<br>
-Bug 691335: Fix Photoshop EPS separations.
-<br>
-
-<br>
-Use DSC comments to get separation names. If the output device supports
-<br>
-separations (i.e. has big /MaxSeparations attribute), set /SeparationColorNames
-<br>
-accordingly. Fix DSC handler; make it ignore the comments after %%EndComments
-<br>
-to avoid handling of DSC comments in nested EPS documents. Drop strange
-<br>
-code that runs tint transform function when any of the colorant names is
-<br>
-is a standard name (Gray, Red, Cyan, ...).
-<br>
-
-<br>
-gs/Resource/Init/gs_epsf.ps
-<br>
-gs/psi/zcolor.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-14 16:52:57 +0100></a>
-2011-06-14 16:52: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=0b7cd7ca121ac440d5607cc6795ba8bcd7c20c85">0b7cd7ca121ac440d5607cc6795ba8bcd7c20c85</a>
-<blockquote>
-<p>
- (pdfwrite) Bug #692268 &quot;pdfwrite sets xapMM:DocumentID incorrectly&quot;
-<br>
-
-<br>
-The XML emission in pdfwrite was simply pasting the UUID as a hex string,
-<br>
-whereas the spec says it must be a URI.
-<br>
-
-<br>
-This change adds the 'uri:' which is required for compliance.
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gdevpdfe.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-26 10:58:31 +0100></a>
-2011-05-26 10:58: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=cba939306ceacde74aac1d9b69ca6cf08ce1ebce">cba939306ceacde74aac1d9b69ca6cf08ce1ebce</a>
-<blockquote>
-
-<br>
-Use correct enumerator for PCL type 3 fonts in pdfwrite
-<br>
-
-<br>
-Part of the change for type 3 fonts from PCL used the wrong enumerator.
-<br>
-The code relies on a text enumerator actually being a show enumerator,
-<br>
-which is guaranteed true if we use the right one, but may not be if we
-<br>
-use the wrong one.
-<br>
-
-<br>
-This didn't seem to be causing any problems, but fixed anyway.
-<br>
-
-<br>
-gs/base/gdevpdtt.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-11 20:52:20 -0400></a>
-2011-06-11 20:52:20 -0400</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49ae789184ebb094c29b14a6778e8fa823f6637a">49ae789184ebb094c29b14a6778e8fa823f6637a</a>
-<blockquote>
-
-<br>
-Bug 691706: Keep page number with /View
-<br>
-
-<br>
-If we have a View and a Page, but no matrix (not required if we have
-<br>
-a /View [/Fit]) then do not discard the page number but use it as a
-<br>
-/Page argument (adding one because pdfmark starts from page 1, not 0).
-<br>
-
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-11 16:26:11 -0700></a>
-2011-06-11 16:26:11 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=03bce08fdcb15702abf4cafbe8723dc8b9b7bd6f">03bce08fdcb15702abf4cafbe8723dc8b9b7bd6f</a>
-<blockquote>
-
-<br>
-Fix for aliasing of icc link hash code
-<br>
-
-<br>
-This fixes a problem that existed in the computation of the ICC
-<br>
-hash code. This was the source of the problem in Bug 692265 (bug fixed with
-<br>
-this commit in file gsicc_cache.c). Also some error checking code and
-<br>
-addition of code to handle the transfer function when doing the fast
-<br>
-thresholding of color images.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gsicc_lcms.c
-<br>
-gs/base/gxcmap.c
-<br>
-gs/base/gxcmap.h
-<br>
-gs/base/gxicolor.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-11 10:27:53 -0400></a>
-2011-06-11 10:27:53 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4c6809dfa1c539d757c30f572922e05cd1436698">4c6809dfa1c539d757c30f572922e05cd1436698</a>
-<blockquote>
-
-<br>
-Bug 692252: Trap contents stream errors
-<br>
-
-<br>
-Run PDF operator streams in a stopped context. Stop processing of the
-<br>
-stream on error, but continue to process rest of the file. Remove a
-<br>
-hack that defined 'inf' as 0.
-<br>
-
-<br>
-gs/Resource/Init/pdf_base.ps
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-10 00:10:39 -0400></a>
-2011-06-10 00:10:39 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f256d925aba7bd2c552e3598b5782bc3ab09cf4f">f256d925aba7bd2c552e3598b5782bc3ab09cf4f</a>
-<blockquote>
-
-<br>
-Bug 692258: Search annots, forms, patterns for fonts.
-<br>
-
-<br>
-Besides the contents, look into annotations to identify fonts used by
-<br>
-the PDF file. Add recursive enumeration of Form and Pattern resources.
-<br>
-
-<br>
-gs/toolbin/pdf_info.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-09 16:07:15 +0100></a>
-2011-06-09 16:07: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=ce51b64c335d6c995c003497988d0327c64985cb">ce51b64c335d6c995c003497988d0327c64985cb</a>
-<blockquote>
-
-<br>
-Add Sags unicode patch for gswin32c stdin/out.
-<br>
-
-<br>
-Patch from Sags to read/write stdin/stdout as unicode and convert
-<br>
-to/from utf8 when passing to/reading from the core.
-<br>
-
-<br>
-Once again, build with WINDOWS_NO_UNICODE to preserve old behaviour.
-<br>
-
-<br>
-See bug 692770.
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/psi/dwmainc.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-09 16:11:00 +0100></a>
-2011-06-09 16:11:00 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c39c030b850848540a5df1fc25c4dc76ee90040b">c39c030b850848540a5df1fc25c4dc76ee90040b</a>
-<blockquote>
-
-<br>
-More unicode changes for gswin32
-<br>
-
-<br>
-Taken on (most of) a patch from Russell Lang to dwtext.c, with bugfixes
-<br>
-to the changes I made yesterday. The bits of the patch I didn't take
-<br>
-on, were to do with running gswin32 as a true Unicode application.
-<br>
-
-<br>
-Currently we are an ANSI application with a Unicode window. Moving to
-<br>
-be a true Unicode application may have knock on effects I am unsure of
-<br>
-(and would certainly leave us different to gswin32c.exe). I don't think
-<br>
-we lose anything by staying as we are.
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/psi/dwtext.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-09 12:09:38 +0100></a>
-2011-06-09 12:09: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=752397ab6f16aad4147d6e7101373edd7c9d14d5">752397ab6f16aad4147d6e7101373edd7c9d14d5</a>
-<blockquote>
-
-<br>
-Bug 692263 spot and elide glyphs with zero dimensions.
-<br>
-
-<br>
-A glyph with a zero scale in either dimension could cause divide by
-<br>
-zero errors in a number of places in the FAPI *interface* code
-<br>
-(that is: fapi_ft.c, fapiufst.c and fapibstm.c). So catch and handle
-<br>
-the case early by skipping such case. The wrinkle is charpath operations
-<br>
-which *must* create a path, even of zero dimensions.
-<br>
-
-<br>
-No cluster differences.
-<br>
-
-<br>
-gs/psi/fapi_ft.c
-<br>
-gs/psi/fapibstm.c
-<br>
-gs/psi/fapiufst.c
-<br>
-gs/psi/ifapi.h
-<br>
-gs/psi/zfapi.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-08 18:36:35 +0100></a>
-2011-06-08 18:36:35 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=199498069233c98424567d22964dd1934c9f766e">199498069233c98424567d22964dd1934c9f766e</a>
-<blockquote>
-
-<br>
-Windows gs console window unicode changes.
-<br>
-
-<br>
-Changes to dwtext.c to allow unicode operation.
-<br>
-
-<br>
-The window is created as a Unicode one, so we get unicode character codes
-<br>
-delivered to us as they are typed. We convert these incoming key codes
-<br>
-into utf8, as the gs core expects. Any output from the core is converted
-<br>
-from utf8 to unicode, and the window now displays unicode.
-<br>
-
-<br>
-The net effect is that the window looks like it's behaving exactly like
-<br>
-a unix window does.
-<br>
-
-<br>
-The copy and paste functions are updated to cut and paste unicode too.
-<br>
-
-<br>
-As usual, building with WINDOWS_NO_UNICODE preserves existing behaviour
-<br>
-(useful for windows 95/98/me builds).
-<br>
-
-<br>
-The sole difference in behaviour is that the copy function now removes
-<br>
-trailing blank lines from the output, as this is never what you want.
-<br>
-
-<br>
-CLUSTER_UNTESTED as windows only changes.
-<br>
-
-<br>
-gs/psi/dwtext.c
-<br>
-gs/psi/dwtext.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-08 14:55:28 +0100></a>
-2011-06-08 14:55: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=afda147d56efff03ff6967a91a0436732d7b38fc">afda147d56efff03ff6967a91a0436732d7b38fc</a>
-<blockquote>
-
-<br>
-Tweaks to windows makefiles.
-<br>
-
-<br>
-Eliminate some noise during windows builds. Thanks to Norbert Janssen for
-<br>
-this.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/msvctail.mak
-<br>
-main/pcl6_msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-08 10:05:21 +0100></a>
-2011-06-08 10:05: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=3367282be8da9713c0cd7a95a56c59a6b4e69a6e">3367282be8da9713c0cd7a95a56c59a6b4e69a6e</a>
-<blockquote>
-
-<br>
-Add file missed from last nights commit, 232b1d3.
-<br>
-
-<br>
-Forgot to add the new file :(
-<br>
-
-<br>
-gs/base/gp_wutf8.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-07 15:25:57 -0700></a>
-2011-06-07 15:25:57 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a436e0f9992ab5734b21b796a02ed0976ba1d5b">6a436e0f9992ab5734b21b796a02ed0976ba1d5b</a>
-<blockquote>
-
-<br>
-Work toward getting fast thresholding for color output devices and color input images
-<br>
-
-<br>
-To make my life easier, this updates msvc.mak to include the planar devices.
-<br>
-Changes in image_render_mono_ht to work towards the case where the output device is not mono.
-<br>
-Minor fixes in gxicolor.c in the portion of code that steps through the planes.
-<br>
-Addition of copy_plan operations in gxht_thresh.c for CMYK planar devices.
-<br>
-Addition of clip_copy_plane for the clip device (thanks Robin Watts).
-<br>
-
-<br>
-gs/base/gxht_thresh.c
-<br>
-gs/base/gxht_thresh.h
-<br>
-gs/base/gxicolor.c
-<br>
-gs/base/gximono.c
-<br>
-gs/base/lib.mak
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-08 00:02:44 +0100></a>
-2011-06-08 00:02:44 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=232b1d36ad90b8d8be357033a80162fdd9de7aa8">232b1d36ad90b8d8be357033a80162fdd9de7aa8</a>
-<blockquote>
-
-<br>
-More work on unicode handling under windows.
-<br>
-
-<br>
-Continuing from commit 0ea739147, fix other issues, including:
-<br>
-
-<br>
-* OpenPrinter calls changed to use OpenPrinterW.
-<br>
-* FindFirstFile/FindNextFile changed to use FindFirstFileW/FindNextFileW.
-<br>
-* gp_getenv windows specific registry lookups changed to use unicode
-<br>
-versions.
-<br>
-* GetProfileString changed to use GetProfileStringW.
-<br>
-* Add unicode changes to gswin32 as well as gswin32c.exe.
-<br>
-
-<br>
-This hopefully concludes the bulk of the work on unicode support. Possible
-<br>
-areas to consider in future include:
-<br>
-
-<br>
-* changing gswin32 so that cut and pasting operates in unicode
-<br>
-* make gswin32 display text in unicode
-<br>
-* modify stdin to go from unicode to utf8, and stdout to go from utf8
-<br>
-back to unicode.
-<br>
-
-<br>
-I hope no idea if any of those are possible or not.
-<br>
-
-<br>
-Testing seems to indicate that this all works OK, but I am not ideally
-<br>
-set up here.
-<br>
-
-<br>
-For safety, I have introduced a WINDOWS_NO_UNICODE define. If this is
-<br>
-predefined during a build then this will cause the code to drop back to
-<br>
-the old mode of operation.
-<br>
-
-<br>
-gs/base/gdevwpr2.c
-<br>
-gs/base/gp_msprn.c
-<br>
-gs/base/gp_mswin.c
-<br>
-gs/base/gp_mswin.h
-<br>
-gs/base/gp_ntfs.c
-<br>
-gs/base/gp_wgetv.c
-<br>
-gs/base/msvctail.mak
-<br>
-gs/base/windows_.h
-<br>
-gs/base/winlib.mak
-<br>
-gs/ghostscript.vcproj
-<br>
-gs/psi/dwmain.c
-<br>
-gs/psi/dwmainc.c
-<br>
-gs/psi/msvc.mak
-<br>
-pl/dwmainc.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-06 22:13:07 -0400></a>
-2011-06-06 22:13:07 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8b90a80fe86364c0b6c1cad12cfb241c66943c24">8b90a80fe86364c0b6c1cad12cfb241c66943c24</a>
-<blockquote>
-
-<br>
-Bug 688064: Add AdjustWidth=WIDTH
-<br>
-
-<br>
-Extend AdjustWidth option to support adjustment to any width. This option
-<br>
-now accepts the following values;
-<br>
-0 - no adjustment, the same as before
-<br>
-1 - low res fax adjustments, the same as before
-<br>
->1 - adjust to the given width, regardless of the document width.
-<br>
-
-<br>
-gs/base/gdevfax.c
-<br>
-gs/base/gdevpng.c
-<br>
-gs/base/gdevtifs.c
-<br>
-gs/base/gdevtifs.h
-<br>
-gs/base/gxdownscale.c
-<br>
-gs/base/gxdownscale.h
-<br>
-gs/base/minftrsz.c
-<br>
-gs/base/minftrsz.h
-<br>
-gs/doc/Devices.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-06 21:00:41 +0100></a>
-2011-06-06 21:00: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=f92a542b0475a12f4724d3e57f232cafbe17ce50">f92a542b0475a12f4724d3e57f232cafbe17ce50</a>
-<blockquote>
-
-<br>
-Bug 691118: Fix radial shading bug
-<br>
-
-<br>
-Bug 691118 describes a bug with radial shadings in a PDF file.
-<br>
-
-<br>
-Back in r7982 (git 69a43b0) (16 May 2007) Igor introduced some cunning
-<br>
-code to speed radial shadings. It would spot that the shading was large
-<br>
-in comparison with the area being filled, and produce a smaller,
-<br>
-equivalent shading.
-<br>
-
-<br>
-Essentially, it would take the destination rectangle, and figure out
-<br>
-where in the shading the 'extremes' of that rectangle would come from
-<br>
-(allowing for distortion in shape generation) and ensure that the newly
-<br>
-generated shading covered the same area.
-<br>
-
-<br>
-Either the corners of the rectangle could be extremes, or points on the
-<br>
-side. The code for the points on the sides was broken due to a typo
-<br>
-causing the X and Y cases to be switched.
-<br>
-
-<br>
-All that is required to solve the bug is to change the == to !=.
-<br>
-
-<br>
-In researching the problem however, I recommented lots of the code to
-<br>
-make it more comprehensible (to me at least!) along with introducing
-<br>
-some temporary variables to make it clearer and avoid needless
-<br>
-recomputation of values. I am committing this as I believe it's a step
-<br>
-forward for the code, even though it doesn't actually make a
-<br>
-difference.
-<br>
-
-<br>
-48 differences in non-pdfwrite/ps2write tests. 11 in pdfwrite, 17 in
-<br>
-ps2write. Checked with bmpcmp, all unnoticable to the naked eye, so
-<br>
-presumably progressions.
-<br>
-
-<br>
-gs/base/gxshade1.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-06 14:59:09 +0100></a>
-2011-06-06 14:59:09 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=82dc5982726c8ea05c3be6faa2f370a62f11a94a">82dc5982726c8ea05c3be6faa2f370a62f11a94a</a>
-<blockquote>
-
-<br>
-Fix Bug 689737: antialiasing issues with patterns.
-<br>
-
-<br>
-Bug 689737 shows mismatches between rendering with and without
-<br>
-antialiasing when PaintType 2 patterns are used.
-<br>
-
-<br>
-Following Michaels analysis of the bug, the fix seems to be very simple;
-<br>
-when opening a pattern accumulator device, if the PaintType is 2, then
-<br>
-set color_info.anti_alias.graphics_bits to 1. We also set
-<br>
-color_info.anti_alias.text_bits to 1, even though this is unlikely to
-<br>
-make a difference if freetype is used.
-<br>
-
-<br>
-No expected cluster differences as antialiasing isn't used in any
-<br>
-cluster tests.
-<br>
-
-<br>
-This commit also removes a FIXME (as I've checked with Michael), and
-<br>
-improves the commenting on the device proc structure (which I'd done
-<br>
-when trying a different device proc based fix, but is an improvement
-<br>
-anyway).
-<br>
-
-<br>
-gs/base/gxpcmap.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-05 23:42:14 -0400></a>
-2011-06-05 23:42:14 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a0720527bcabb2732c3c06dfe3cae1f9c9ea9318">a0720527bcabb2732c3c06dfe3cae1f9c9ea9318</a>
-<blockquote>
-
-<br>
-Bug 692252: define 'inf' as 0
-<br>
-
-<br>
-Work around a bug in PDF file that has 'inf' instead of a number
-<br>
-in the content stream. Define a PDF operator 'inf' that returns 0
-<br>
-and issues a warning.
-<br>
-
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-04 22:04:12 +0100></a>
-2011-06-04 22:04: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=0ea739147fd02ee0e63e58c036bb63fa841ddd3c">0ea739147fd02ee0e63e58c036bb63fa841ddd3c</a>
-<blockquote>
-
-<br>
-Bug 691222: Make windows build use UTF-8 encoding.
-<br>
-
-<br>
-We change the windows builds to use the 'wmain' rather than 'main'
-<br>
-entrypoints. This means we get the command line supplied in 'wchar_t's
-<br>
-rather than chars. We convert back to chars using UTF-8 encoding, and
-<br>
-call (what was) the main entrypoint.
-<br>
-
-<br>
-This means that we can cope with unicode filenames/paths etc.
-<br>
-
-<br>
-To match the encoding, we therefore need to wrap every use of the
-<br>
-filenames with the associated utf-8 -> wchar_t conversion and use
-<br>
-the unicode file access functions (_wfopen instead of fopen etc)
-<br>
-instead.
-<br>
-
-<br>
-Simple testing seems to indicate that this works. I think I've got
-<br>
-every occurence of file access, but it's possible I've missed some. If so
-<br>
-I'll fix them piecemeal as they are reported.
-<br>
-
-<br>
-This should solve bug 691222, and hopefully 691117.
-<br>
-
-<br>
-gs/base/gp_mswin.c
-<br>
-gs/psi/dwmainc.c
-<br>
-pl/dwmainc.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-04 22:09:58 +0100></a>
-2011-06-04 22:09:58 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4aff3e0d813cb00eb62db9720cf99b2d419f999a">4aff3e0d813cb00eb62db9720cf99b2d419f999a</a>
-<blockquote>
-
-<br>
-Move various uses of fopen to use gp_fopen.
-<br>
-
-<br>
-For portability we should be using gp_fopen, not fopen.
-<br>
-
-<br>
-gs/base/gdevdevn.c
-<br>
-gs/base/gdevimdi.c
-<br>
-gs/base/gdevrinkj.c
-<br>
-gs/base/gdevtxtw.c
-<br>
-gs/base/gdevwts.c
-<br>
-gs/psi/imainarg.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-04 00:35:37 -0700></a>
-2011-06-04 00:35:37 -0700</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=77b456f298aeabaa4b27b63a9ead0aa0470ac5b8">77b456f298aeabaa4b27b63a9ead0aa0470ac5b8</a>
-<blockquote>
-
-<br>
-Removed HAVE_HYPOT from configure scripts.
-<br>
-
-<br>
-This revision disables checking for a system hypot() function and is
-<br>
-a followup to 7dcc68ce753175a9c686021d53a061253e2787c3 which modified
-<br>
-math_.h to always use our internal hypot() function.
-<br>
-
-<br>
-No expected cluster differences.
-<br>
-
-<br>
-config.mak.in
-<br>
-configure.ac
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/configure.ac
-<br>
-gs/base/macosx.mak
-<br>
-gs/base/unix-gcc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-03 17:33:51 +0100></a>
-2011-06-03 17:33:51 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=31174084f95474f9c0edfd4c534c3b1654c02255">31174084f95474f9c0edfd4c534c3b1654c02255</a>
-<blockquote>
-
-<br>
-Fix bug 692226; stray pixels in skewed masked image
-<br>
-
-<br>
-When painting a masked image, we first plot a scanlines worth of
-<br>
-mask pixels to a mask plane. This is then used in a clipping device to
-<br>
-clip the image pixels that follow thereafter.
-<br>
-
-<br>
-In the code that plots the masked pixels it currently gathers up 'runs'
-<br>
-of identical pixels and plots them all at once. This works fine for
-<br>
-portrait and landscape images, but for skewed ones has problems due to
-<br>
-rounding errors. By plotting large runs of pixels at once, we can a) get
-<br>
-gaps between subsequent rows of masked pixels, and b) get a mismatch
-<br>
-between the pixels covered by the mask and the image. These manifest
-<br>
-as holes in the image.
-<br>
-
-<br>
-The image code already has a comment in it to the effect that we cannot
-<br>
-amalgamate large blocks due to rounding errors.
-<br>
-
-<br>
-This fix therefore extends this policy (of not amalgamating) to skewed
-<br>
-masked images too.
-<br>
-
-<br>
-426 non-pdfwrite/pswrite differences expected. 79 pdfwrite. 31 ps2write.
-<br>
-Checked with bmpcmp and all seem either progressions or neutral.
-<br>
-
-<br>
-gs/base/gximono.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-03 19:07:47 +0100></a>
-2011-06-03 19:07:47 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9c5325b7778074c3add1f682058260d7f8154386">9c5325b7778074c3add1f682058260d7f8154386</a>
-<blockquote>
-
-<br>
-Add clip_copy_plane device procedure.
-<br>
-
-<br>
-Cut and pasted with obvious changes from clip_copy_mono. Nothing remarkable
-<br>
-worth mentioning.
-<br>
-
-<br>
-Not used in current code, so CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/base/gxclip.c
-<br>
-gs/base/gxclip.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-03 17:32:09 +0100></a>
-2011-06-03 17:32:09 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7c8855aed043415063ad7472eb2af4320d4544eb">7c8855aed043415063ad7472eb2af4320d4544eb</a>
-<blockquote>
-
-<br>
-Add rasterop to FEATURE_DEVS in msvc makefile.
-<br>
-
-<br>
-The rasterop module is already added by default under unix, so this moves
-<br>
-windows into line.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-03 12:29:50 -0400></a>
-2011-06-03 12:29:50 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=636788a8e6d2133a7e3294ee4e1b573c64e1254a">636788a8e6d2133a7e3294ee4e1b573c64e1254a</a>
-<blockquote>
-
-<br>
-Bug 691906, Drop symbolic flag with named encodings.
-<br>
-
-<br>
-PDF font descriptor has 3 attributes that affect whether the TT font
-<br>
-is processed as symbolic one. The spec is not clear what to do when
-<br>
-the attributes conflict. This revision consigers fonts that have
-<br>
-/WinAnsiEncoding or /MacRomanEncoding as non-symbolic regardless of
-<br>
-the flags.
-<br>
-
-<br>
-gs/Resource/Init/pdf_font.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-02 20:49:27 -0700></a>
-2011-06-02 20:49:27 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6558511800f1f467b66e8e220b80ac99d6ee6f69">6558511800f1f467b66e8e220b80ac99d6ee6f69</a>
-<blockquote>
-
-<br>
-Addition of code to parse the file for the source object color description
-<br>
-
-<br>
-The file toolbin/color/src_color/objsrc_profiles_example.txt provides example
-<br>
-content where we have the key word for the profile, the profile and the rendering
-<br>
-intent. Next step is to implement the usage of these profiles in the link
-<br>
-construction.
-<br>
-
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/toolbin/color/src_color/objsrc_profiles_example.txt
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-02 12:38:40 +0100></a>
-2011-06-02 12:38:40 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=585cac9d3aa6bca9e877c3e12ef3e28fd4f7f571">585cac9d3aa6bca9e877c3e12ef3e28fd4f7f571</a>
-<blockquote>
-
-<br>
-Fix bug 691152; gradients appear 'stepped'.
-<br>
-
-<br>
-The original bug report was that tiffsep and tiff24nc give noticably
-<br>
-different results. This turns out to be because tiffsep is set to use
-<br>
-non 'linear-and-separable' colours.
-<br>
-
-<br>
-When shadings are rendered, they are 'decomposed' down into smaller
-<br>
-and smaller regions, until they are smaller than a given threshold.
-<br>
-These regions are then filled either with linear filled traps (in the
-<br>
-linear and separable case) or with constant colour (in the non linear
-<br>
-and separable case). This means that we can get away with a larger
-<br>
-threshold in the linear and separable case (tiff24nc) and still see
-<br>
-smooth results.
-<br>
-
-<br>
-The original version of the code (pre SVN rev 7936) used to decompose
-<br>
-until the regions were smaller than a pixel. At rev 7936 this was
-<br>
-upped to be 1 point (1/72 of an inch) (or 1 pixel, whatever was
-<br>
-larger). Reverting to this original code solves the problem by making
-<br>
-the constant color regions small enough so that they still look
-<br>
-smooth.
-<br>
-
-<br>
-There would therefore appear to be several possible approaches to
-<br>
-solve the problem:
-<br>
-
-<br>
-1) We could back out the change in 7936. This trades time (27% in the
-<br>
-worst measured test case) for correctness.
-<br>
-
-<br>
-2) We could change tiffsep to use linear and separable colours.
-<br>
-
-<br>
-I've opted for an approach based on 1) here, because a bmpcmp clearly
-<br>
-shows easily visible differences in some files in other devices, for
-<br>
-example:
-<br>
-
-<br>
-tests_private/comparefiles/470-01.ps.pgmraw.300.0
-<br>
-
-<br>
-By default, the code now operates as pre revision 7936. Should the
-<br>
-change in speed be considered unacceptable, gs can be build with the
-<br>
-symbol MAX_SHADING_RESOLUTION defined to maximum dpi to which shadings
-<br>
-should be decomposed; building with -DMAX_SHADING_RESOLUTION=72 will
-<br>
-give the same results as the existing code.
-<br>
-
-<br>
-gs/base/gxshade6.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-01 11:12:31 -0600></a>
-2011-06-01 11:12:31 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4132ef5d36ff63b2b84f9864b7240609ac84ac38">4132ef5d36ff63b2b84f9864b7240609ac84ac38</a>
-<blockquote>
-
-<br>
-Enhance autoconf tests for SSE2 and byte swapping support.
-<br>
-
-<br>
-Previously we only checked if the test programs compile, now we check
-<br>
-if they compile and link.
-<br>
-
-<br>
-configure.ac
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-01 16:22:40 +0100></a>
-2011-06-01 16:22:40 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f83e6d48c33ff1edd2aecbe4482b8a1374808951">f83e6d48c33ff1edd2aecbe4482b8a1374808951</a>
-<blockquote>
-
-<br>
-Tweak jbig2dec os_types.h for android mupdf build.
-<br>
-
-<br>
-If HAVE_STDINT_H is defined we are supposed to be getting our definitions
-<br>
-from stdint.h. Instead the header defines them anyway. Fix this. This showed
-<br>
-up when building MuPDF for Android.
-<br>
-
-<br>
-gs/jbig2dec/os_types.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-06-01 09:47:56 -0400></a>
-2011-06-01 09:47:56 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e895d3aae94fa6ca1c53c4e7a47f5894ee3c5943">e895d3aae94fa6ca1c53c4e7a47f5894ee3c5943</a>
-<blockquote>
-
-<br>
-Bug 591335: Get ink names from images.
-<br>
-
-<br>
-Fixes a bug in indexed color space handler that prevented proper
-<br>
-recursion into the base color space, and add /Image /XObject
-<br>
-to the list of resources that are searched for separation color names.
-<br>
-
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-31 23:39:45 -0400></a>
-2011-05-31 23:39:45 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=db4af9eaf902dbac931ca8c88c586df9d160fb72">db4af9eaf902dbac931ca8c88c586df9d160fb72</a>
-<blockquote>
-
-<br>
-Bug 692245: Make pattern handler more robust.
-<br>
-
-<br>
-Make pattern handling code tolerant to pattern streams that leave
-<br>
-some junk on the operand stack.
-<br>
-
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-31 09:23:10 -0700></a>
-2011-05-31 09:23: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=000e8614d2229335ed269f9ebc9a42e33b035f83">000e8614d2229335ed269f9ebc9a42e33b035f83</a>
-<blockquote>
-
-<br>
-Fix for issues in the setting of the newer ICC device parameters
-<br>
-
-<br>
-This fixes issues that were introduced when I added the new device
-<br>
-parameters for rendering intent. Also, this adds in a new structure
-<br>
-for defining different ICC profiles for the SOURCE colors
-<br>
-of objects (e.g. text image graphic). This will be set as a user
-<br>
-parameter and stored in the icc manager. Next step in this is
-<br>
-to get things initialized and then use the associated profiles.
-<br>
-
-<br>
-gs/Resource/Init/gs_lev2.ps
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gsdparam.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/psi/zusparam.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-31 01:14:21 -0700></a>
-2011-05-31 01:14:21 -0700</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d0055ac144c1f1a51e906976b85e8e2119b5a2db">d0055ac144c1f1a51e906976b85e8e2119b5a2db</a>
-<blockquote>
-
-<br>
-Change rsync max-size in clusterpush.pl to 10 megs.
-<br>
-
-<br>
-To prevent accidently transferring large log files to the casper during
-<br>
-a clusterpush the rsync in that script was limited to 2.5 megs via the
-<br>
-the --max-size option. However a recently added source file, imdi_k.c,
-<br>
-is 2.6 megs, so the max-size limit has been increased to 10 megs.
-<br>
-
-<br>
-gs/toolbin/localcluster/clusterpush.pl
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-31 00:19:38 -0400></a>
-2011-05-31 00:19:38 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=16e928c697f4282c830ab57b7e16347b0b5b086f">16e928c697f4282c830ab57b7e16347b0b5b086f</a>
-<blockquote>
-
-<br>
-Bug 692242, drop outlines without /Title.
-<br>
-
-<br>
-Ignore outlines without a required /Title attribute and
-<br>
-issue a warning.
-<br>
-
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-30 20:26:53 +0100></a>
-2011-05-30 20:26:53 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91b9580bf09b81126d6a99c6fe3e0048972fe3d0">91b9580bf09b81126d6a99c6fe3e0048972fe3d0</a>
-<blockquote>
-
-<br>
-Fix Bug 692225. Interpolate and Decode don't play nice.
-<br>
-
-<br>
-Bug 692225 gives an example where an Image with both a Decode array
-<br>
-and interpolation set to true gives bad results.
-<br>
-
-<br>
-The problem was with a branch of the if in image_render_interpolate_icc
-<br>
-that was assuming that any decode array given was [0 1]. The fix here is
-<br>
-simply to test for whether need_decode is set.
-<br>
-
-<br>
-No changes seen on clusterpushing.
-<br>
-
-<br>
-Check this with Michael quand il sont retourne.
-<br>
-
-<br>
-gs/base/gxiscale.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-30 14:21:02 +0100></a>
-2011-05-30 14:21:02 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9fd0b414427b58fc79dae23cb11607ea5fcd0890">9fd0b414427b58fc79dae23cb11607ea5fcd0890</a>
-<blockquote>
-
-<br>
-Updated gitpush.sh script.
-<br>
-
-<br>
-Fixed script in light of kens experiences. Better error messages, more
-<br>
-thorough (i.e. any!) checking. Some documentation in the script.
-<br>
-
-<br>
-gs/toolbin/localcluster/gitpush.sh
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-28 18:04:24 +0100></a>
-2011-05-28 18:04:24 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=543fd70fd3b6afc75a767ba1a41663ec3a982866">543fd70fd3b6afc75a767ba1a41663ec3a982866</a>
-<blockquote>
-
-<br>
-Excellently crufty gitpush script to interface with cluster.
-<br>
-
-<br>
-In your local git repo, do the following:
-<br>
-
-<br>
-git remote add regression@ghostscript.com:/home/regression/cluster/gitbridge/ghostpdl
-<br>
-
-<br>
-Ensure that you are setup to be able to ssh into ghostscript.com as the
-<br>
-regression user.
-<br>
-
-<br>
-Then:
-<br>
-
-<br>
-git config alias.cluster '!gs/toolbin/localcluster/gitpush.sh'
-<br>
-
-<br>
-Then you can:
-<br>
-
-<br>
-git cluster <blah>
-<br>
-
-<br>
-in exactly the same way as we used to be able to be able to:
-<br>
-
-<br>
-gs/toolbin/localcluster/clusterpush.pl <blah>
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/toolbin/localcluster/gitpush.sh
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-28 08:49:10 +0100></a>
-2011-05-28 08:49: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=94f1a552f75647f142b85e5f30c075c19dde0084">94f1a552f75647f142b85e5f30c075c19dde0084</a>
-<blockquote>
-
-<br>
-Bug 692240: Gracefully handle incomplete FontBBox arrays.
-<br>
-
-<br>
-The FAPI code would throw an error if the FontBBox array had fewer
-<br>
-than four values. We'll now replace the broken array with a valid
-<br>
-one.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/psi/zfapi.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-27 10:15:08 -0700></a>
-2011-05-27 10:15:08 -0700</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20520230859eaa315a52731c1361be650c7e4999">20520230859eaa315a52731c1361be650c7e4999</a>
-<blockquote>
-
-<br>
-Bug 692237. Fix memfile_unlink to use %p instead of 0x%0x
-<br>
-
-<br>
-When the change was made (8e0f0dfb Ralph Giles 2008-09-10 21:35:24) the unlink
-<br>
-was missed. The %p is more portable in that it handles 32 or 64 bit addresses
-<br>
-as strings. Thanks to Norbert Janssen for finding this.
-<br>
-
-<br>
-gs/base/gxclmem.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-27 18:07:10 +0100></a>
-2011-05-27 18:07: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=5974e9171854673d86e0c47a1d1cfef1ff9a5cb1">5974e9171854673d86e0c47a1d1cfef1ff9a5cb1</a>
-<blockquote>
-
-<br>
-Address a compiler warning.
-<br>
-
-<br>
-No cluster differences.
-<br>
-
-<br>
-gs/psi/imain.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-27 17:32:36 +0100></a>
-2011-05-27 17:32:36 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6a743893666fa2c00244f291b83208e5cb961a27">6a743893666fa2c00244f291b83208e5cb961a27</a>
-<blockquote>
-
-<br>
-Bug 692238: fix a couple of typos in News.htm.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/doc/News.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-27 15:58:28 +0100></a>
-2011-05-27 15:58: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=9a83627c1c0015a446fbf087848e98234a2bdddb">9a83627c1c0015a446fbf087848e98234a2bdddb</a>
-<blockquote>
-
-<br>
-Bug 692220: have the lib file arrays extend as required.
-<br>
-
-<br>
-Previously we had a hard limit of GS_MAX_LIB_DIRS on the number of entries
-<br>
-allowed in the lib search path. This change makes GS_MAX_LIB_DIRS the
-<br>
-default space available, but allows the arrays to extend as required.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/psi/imain.c
-<br>
-gs/psi/imainarg.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-27 10:15:37 +0100></a>
-2011-05-27 10:15: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=96da6c46750074869c5bcaeeba7e204d8df83a16">96da6c46750074869c5bcaeeba7e204d8df83a16</a>
-<blockquote>
-
-<br>
-Have clusterpush.pl check for/use CLUSTER_USER env var.
-<br>
-
-<br>
-For anyone that uses a different local login than their user name
-<br>
-for the cluster, rather than have to specify the user name on the
-<br>
-command line every time, you can now set CLUSTER_USER in your
-<br>
-shell, and clusterpush.pl will use that, before going to check
-<br>
-USER and USERNAME as before.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/toolbin/localcluster/clusterpush.pl
-<br>
-gs/toolbin/localcluster/clusterpush.txt
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-26 11:20:10 -0700></a>
-2011-05-26 11:20:10 -0700</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=998fc31cc9bd717190b0313eb246c14fe6303602">998fc31cc9bd717190b0313eb246c14fe6303602</a>
-<blockquote>
-
-<br>
-Restore Makefile to clusterpush.pl file list.
-<br>
-
-<br>
-Removed Makefile from the list of files excluded from the rsync
-<br>
-operation in clusterpush.pl since the ghostpdl Makefile is not
-<br>
-built by a configure/autogen.sh operation.
-<br>
-
-<br>
-gs/toolbin/localcluster/clusterpush.pl
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-26 01:09:55 -0700></a>
-2011-05-26 01:09:55 -0700</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eb0b920bd993d1b03478c9ba4dfc54e995ec7bac">eb0b920bd993d1b03478c9ba4dfc54e995ec7bac</a>
-<blockquote>
-
-<br>
-Fix minor typo.
-<br>
-
-<br>
-gs/base/gsmchunk.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-25 23:47:04 -0600></a>
-2011-05-25 23:47:04 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ec6afb99389c13414a43820908e090841b6bcd75">ec6afb99389c13414a43820908e090841b6bcd75</a>
-<blockquote>
-
-<br>
-Fixes Bug 692232 - landscape printed on portrait media.
-<br>
-
-<br>
-Add the ability to pass postscript names on the command line - so now
-<br>
-AutoRotatePages can be set. The other way of fixing this - specifying
-<br>
-a different MediaBox would be awkward in the current PCL design.
-<br>
-
-<br>
-pl/plmain.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-24 08:08:35 -0700></a>
-2011-05-24 08:08:35 -0700</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=25de59220e9472e6de1acc046c317141a1751770">25de59220e9472e6de1acc046c317141a1751770</a>
-<blockquote>
-
-<br>
-Fix for Bug 692217 nested trans_pattern_clist SEGV
-<br>
-
-<br>
-This was caused by a clip device created for tiling a mask with a transparent
-<br>
-pattern rendered with a clist. The clip device used for rendering did not
-<br>
-get its color_info updated when its target (pdf14) changed the color_info,
-<br>
-specifically the depth.
-<br>
-
-<br>
-Fixed by grabbing the target color_info after calling the target's compositor.
-<br>
-
-<br>
-gs/base/gdevnfwd.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-25 20:55:29 -0400></a>
-2011-05-25 20:55:29 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b8a35e6cf6f0394487c9e46d989ea57dd0e4203d">b8a35e6cf6f0394487c9e46d989ea57dd0e4203d</a>
-<blockquote>
-
-<br>
-Bug 692229, rename variables in Luratech license blocks.
-<br>
-
-<br>
-Change variable names in rarely compiled blocks related to Luratech
-<br>
-license key to match the declarations.
-<br>
-
-<br>
-gs/base/sjpx_luratech.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-25 19:55:04 +0000></a>
-2011-05-25 19:55:04 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1de7e6dcb4a89cfdbc93ef176cee17f2e1b430f3">1de7e6dcb4a89cfdbc93ef176cee17f2e1b430f3</a>
-<blockquote>
-
-<br>
-Revised clusterpush.pl; msys git operation
-<br>
-
-<br>
-Changes to accomodate clusterpushing from windows msys git shells.
-<br>
-This relies on various other tools being added to the path. See
-<br>
-forthcoming email.
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/toolbin/localcluster/clusterpush.pl
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-25 11:11:25 +0000></a>
-2011-05-25 11:11:25 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=177d0f5ef5d3d2f992b10750e072dc91696c92cc">177d0f5ef5d3d2f992b10750e072dc91696c92cc</a>
-<blockquote>
-
-<br>
-Update gitsetup.h; remove --local.
-<br>
-
-<br>
-Remove a --local from a command that upsets old versions of git, while
-<br>
-not making a difference to later versions. Thanks to Ray for pointing this
-<br>
-out.
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/toolbin/gitsetup.sh
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-25 06:54:07 +0000></a>
-2011-05-25 06:54:07 +0000</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ebefadf4428a0fd4ca4607221bb59e2e0343b35b">ebefadf4428a0fd4ca4607221bb59e2e0343b35b</a>
-<blockquote>
-
-<br>
-Fix executable property to +x.
-<br>
-
-<br>
-gs/toolbin/gitsetup.sh
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-24 16:23:32 +0100></a>
-2011-05-24 16:23:32 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8151aa54b8a71e5c9929bb43390a9be1b4b8d042">8151aa54b8a71e5c9929bb43390a9be1b4b8d042</a>
-<blockquote>
-
-<br>
-Add gitsetup.sh to gs/toolbin.
-<br>
-
-<br>
-Simple script for doing the 'obvious' configuration to a freshly checked
-<br>
-out git clone of ghostscript.
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/toolbin/gitsetup.sh
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-24 07:53:59 -0700></a>
-2011-05-24 07:53:59 -0700</strong>
-<br>Robin Watts <robin@peeves.(none)><br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4dc31e78ea0b58973f5a97319eafcbc10e5b9f2b">4dc31e78ea0b58973f5a97319eafcbc10e5b9f2b</a>
-<blockquote>
-
-<br>
-Add autoconf check for bswap32/byteswap.h availability.
-<br>
-
-<br>
-As per bug 692211, add some autoconf magic to detect the presence of
-<br>
-__builtin_bswap32 and/or byteswap.h.
-<br>
-
-<br>
-No expected cluster changes.
-<br>
-
-<br>
-config.mak.in
-<br>
-configure.ac
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/configure.ac
-<br>
-gs/base/gsropt.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-24 12:38:27 +0100></a>
-2011-05-24 12:38:27 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=38720da47205c029d9bee6c3b792791b6f39277d">38720da47205c029d9bee6c3b792791b6f39277d</a>
-<blockquote>
-
-<br>
-mem_mono_copy_mono optimisations.
-<br>
-
-<br>
-Working on Norberts latest test files, I have changed mem_mono_copy_mono
-<br>
-to only use copy_rop if the runs are large enough for it to get a
-<br>
-benefit. Currently this threshold is set to 32 pixels (1 word).
-<br>
-
-<br>
-This is sufficiently high that we get 9.01 or better performance on all the
-<br>
-test files, but might benefit from further tuning later.
-<br>
-
-<br>
-gs/base/gdevm1.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-24 08:35:18 +0100></a>
-2011-05-24 08:35:18 +0100</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b246d9d85c119f101956ba07cf9e1c8b9f510b49">b246d9d85c119f101956ba07cf9e1c8b9f510b49</a>
-<blockquote>
-
-<br>
-pdfwrite : set bit 0 of CIDSet.
-<br>
-
-<br>
-Set the CID 0 bit of the CIDSet array, so that this glyph is marked as
-<br>
-being present, when converting TrueType fonts to CIDFonts for PDF/A
-<br>
-output.
-<br>
-
-<br>
-CID 0 is required to be present for all CIDFonts, it is the /.notdef
-<br>
-equivalent.
-<br>
-
-<br>
-gs/base/gdevpdtd.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-20 20:45:41 +0100></a>
-2011-05-20 20:45: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=99b6056dda5ccf74a270d5ca3dbbe2319dc2c219">99b6056dda5ccf74a270d5ca3dbbe2319dc2c219</a>
-<blockquote>
-
-<br>
-Fix for pdfwritten fts_42xx.xps crashing in transparency stuff.
-<br>
-
-<br>
-See Bug 692219. This may well be patching symptoms rather than correctly
-<br>
-addressing the problem, but it's low impact, and shouldn't create any new
-<br>
-problems. We can always back it out after michael has had time to look.
-<br>
-
-<br>
-gs/base/gxblend1.c
-<br>
-gs/base/gxpcmap.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-23 15:42:46 +0100></a>
-2011-05-23 15:42:46 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=86e887eab1634dc9bceec1e1479c11fe03835e96">86e887eab1634dc9bceec1e1479c11fe03835e96</a>
-<blockquote>
-
-<br>
-mem_mono_strip_copy_rop_dev opts; non-texture 'short' case.
-<br>
-
-<br>
-Attempt to optimise for latest test cases from Norbert.
-<br>
-
-<br>
-Use reverted, and optimised old code for the width < 32 no texture case.
-<br>
-
-<br>
-gs/base/gdevm1.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-23 16:41:17 +0100></a>
-2011-05-23 16:41: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=54796e82370348412811db945b95c42953ce0957">54796e82370348412811db945b95c42953ce0957</a>
-<blockquote>
-
-<br>
-Bug #692202 Bug in display_raster function
-<br>
-
-<br>
-The calculation of bytewidth, the number of bytes required for a row of
-<br>
-pixels, only worked correctly when the colour depth was a multiple of 8.
-<br>
-
-<br>
-Since the device is a display device, and has since become used as a
-<br>
-general method for getting data out of GS, this is not reasonable
-<br>
-(monochrome and greyscale devices are less than 8 bits)
-<br>
-
-<br>
-Modified as suggested by Martin Osieka to round up the calculation.
-<br>
-
-<br>
-gs/base/gdevdsp.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-23 08:08:23 +0100></a>
-2011-05-23 08:08: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=7fcb89d46d42eb8806d226d3eb39a64f2ad0fe08">7fcb89d46d42eb8806d226d3eb39a64f2ad0fe08</a>
-<blockquote>
-
-<br>
-Squash a very minor compiler warning
-<br>
-
-<br>
-gs/base/gdevpdtt.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-22 22:23:49 +0100></a>
-2011-05-22 22:23:49 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b7d52f725a7c4ef939469f757687a86252fade9c">b7d52f725a7c4ef939469f757687a86252fade9c</a>
-<blockquote>
-
-<br>
-Add Memory squeezing functionality to Memento.
-<br>
-
-<br>
-If you build with MEMENTO_HAS_FORK predefined, then in-app memory
-<br>
-squeezing is enabled.
-<br>
-
-<br>
-export MEMENTO_SQUEEZEAT=1 then run the app, and it will do some magic
-<br>
- with repeated forks to test the &quot;failure to allocate&quot; paths through the code.
-<br>
-
-<br>
-All the allocation events before the MEMENTO_SQUEEZEATth one will proceed
-<br>
-as normal. After that, on every allocation, the code will fork. The child
-<br>
-will proceed with every allocation failing until the program exits
-<br>
-(hopefully cleanly, but sometimes leaking memory, sometimes dying with a
-<br>
-SEGV due to failure to cleanup properly). When the child exits, the
-<br>
-parent carries on execution (until the next allocation, when the same fork
-<br>
-process happens again).
-<br>
-
-<br>
-CLUSTER_UNTESTED as disabled by default.
-<br>
-
-<br>
-gs/base/memento.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-22 08:36:29 -0700></a>
-2011-05-22 08:36:29 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1be218b08069f483ba53eacddc6f7cfbe96957ea">1be218b08069f483ba53eacddc6f7cfbe96957ea</a>
-<blockquote>
-
-<br>
-Fixes in ICC profile handling and device parameters
-<br>
-
-<br>
-This fixes some issues that were encountered when setting ICC
-<br>
-profiles on the command line. One issue is that the put_profile
-<br>
-procedure needs to be initialized a bit earlier which required
-<br>
-a change in gdevprn.h In addition, when the output profile is
-<br>
-specified to be the CIELAB profile and there is transparency in
-<br>
-the file there was a rc issue with the profile when going through
-<br>
-the clist. This also includes code to handle the rendering intent device
-<br>
-parameters for object types.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gdevprn.h
-<br>
-gs/base/gscdevn.c
-<br>
-gs/base/gsdparam.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/base/gxclthrd.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-22 08:32:34 -0700></a>
-2011-05-22 08:32:34 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=185b6f5db3771f6501d55b7b0b6c6ca8663b24c5">185b6f5db3771f6501d55b7b0b6c6ca8663b24c5</a>
-<blockquote>
-
-<br>
-Update of ICC Creator
-<br>
-
-<br>
-Update to ICC creator project to enable the creation of special effect profiles.
-<br>
-Also addition of profiles to demonstrate object dependent color management.
-<br>
-
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_Creator.rc
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.cpp
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.h
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/icc_create.cpp
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/icc_create.h
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/resource.h
-<br>
-gs/toolbin/color/icc_creator/effects/black_output.icc
-<br>
-gs/toolbin/color/icc_creator/effects/c_only.txt
-<br>
-gs/toolbin/color/icc_creator/effects/cyan_output.icc
-<br>
-gs/toolbin/color/icc_creator/effects/k_only..txt
-<br>
-gs/toolbin/color/icc_creator/effects/m_only.txt
-<br>
-gs/toolbin/color/icc_creator/effects/magenta_output.icc
-<br>
-gs/toolbin/color/icc_creator/effects/y_only.txt
-<br>
-gs/toolbin/color/icc_creator/effects/yellow_output.icc
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-22 00:03:57 -0400></a>
-2011-05-22 00:03:57 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=70912a68940b1361e8d33a239a57280eead00bfc">70912a68940b1361e8d33a239a57280eead00bfc</a>
-<blockquote>
-
-<br>
-Fix optional inline image skipping.
-<br>
-
-<br>
-Use newly created function that calculates the number of components
-<br>
-of a given image and fix calculation of the inline image size that
-<br>
-is used to skip optional inline images.
-<br>
-
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-21 01:15:49 -0400></a>
-2011-05-21 01:15:49 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3ac9479be8db8eb44f3787d54a171747b61c2b44">3ac9479be8db8eb44f3787d54a171747b61c2b44</a>
-<blockquote>
-
-<br>
-Bug 692213: verify /Default* colorspaces.
-<br>
-
-<br>
-Check that the number of components of /DefaultGray, /DefaultRGB, and
-<br>
-/DefaultCMYK is correct, and reject inappropriate color spaces.
-<br>
-
-<br>
-Also fix the code that forces update of the color space at the
-<br>
-beginning of the page when the page defines any of /Defailt* color
-<br>
-spaces. This hack has been written long ago but it was unreachable.
-<br>
-
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-20 19:59:16 +0100></a>
-2011-05-20 19:59: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=4c64b898e1dc2b3532e0fe6c18a292fa58843207">4c64b898e1dc2b3532e0fe6c18a292fa58843207</a>
-<blockquote>
-
-<br>
-Merge branch 'Type3_PCL'
-<br>
-
-<br>
-gs/base/gdevpdtd.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-20 19:43:55 +0100></a>
-2011-05-20 19:43: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=83318bd849910c6c79f0ea5cb11912557ac01307">83318bd849910c6c79f0ea5cb11912557ac01307</a>
-<blockquote>
-
-<br>
-Final type 3 font modifications for PCL
-<br>
-
-<br>
-We need to probe the glyph cache in process_text_modify_width as well
-<br>
-process_text_return_width, this is a possible path through the code,
-<br>
-depending on the exact combination of text operations.
-<br>
-
-<br>
-Remove debugging code
-<br>
-
-<br>
-Tidy up some declarations and casting of poitners to make compilers
-<br>
-happy.
-<br>
-
-<br>
-gs/base/gdevpdte.c
-<br>
-gs/base/gdevpdtt.c
-<br>
-gs/base/gxccache.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-20 12:03:14 +0100></a>
-2011-05-20 12:03:14 +0100</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=96b967aac2176d9cd96167cc1430bb76074d6384">96b967aac2176d9cd96167cc1430bb76074d6384</a>
-<blockquote>
-
-<br>
-Add some prints to caching
-<br>
-
-<br>
-Set the FtonMatrix to the identity when making the CTM the identity, so that these don't get applied twice.
-<br>
-
-<br>
-gs/base/gdevpdtt.c
-<br>
-gs/base/gxccache.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-19 13:51:24 +0100></a>
-2011-05-19 13:51: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=0b8df1bfb7f5496ba5b644b21c7586fda6dcdc46">0b8df1bfb7f5496ba5b644b21c7586fda6dcdc46</a>
-<blockquote>
-
-<br>
-Add some extra debugging printouts
-<br>
-
-<br>
-Fix log2_scale and depth when creating and testing cache entries in order
-<br>
-to make sure they are coherent (we don't actually use the entries so the
-<br>
-values aren't important, as long as they are the same)
-<br>
-
-<br>
-When using PCL bitmap fonts we do want to note glyphs set with setcharwidth
-<br>
-as cached, as well as those with setcachedevice. (the same is not true
-<br>
-for PostScript)
-<br>
-
-<br>
-gs/base/gdevpdte.c
-<br>
-gs/base/gdevpdti.c
-<br>
-gs/base/gdevpdtt.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-17 15:53:56 +0100></a>
-2011-05-17 15:53:56 +0100</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=49921ad78b31af5ab8803d6de886d93106c0db0c">49921ad78b31af5ab8803d6de886d93106c0db0c</a>
-<blockquote>
-
-<br>
-Add another new font type 'ft_PCL_user_defined' for the PCL bitmap
-<br>
-font.
-<br>
-
-<br>
-Update various parts of the code to treat the new font the same as a
-<br>
-PostScript type 3 font.
-<br>
-
-<br>
-In pdfwrite, if we capture a CharpProcs, and its for a PCL bitmap font
-<br>
-then add a cache entry. We do NOT do this for most other fonts, only
-<br>
-when rendering a glyph. When assembling text, if the font is a PCL
-<br>
-bitmap font, tehn after checking to see if we've already used it, check
-<br>
-to see if there is a cache entry. If the PCL job has reused this character
-<br>
-code with a different bitmap it will haev flushed the cache entry. If we
-<br>
-font this has happened then capture the new glyph. NB if we are capturing
-<br>
-a new definition (font->used[[] is valid) then we know this is a redefinition
-<br>
-so capture into a different font using the old style 'default' implementation.
-<br>
-
-<br>
-gs/base/gdevpdtd.c
-<br>
-gs/base/gdevpdte.c
-<br>
-gs/base/gdevpdtf.c
-<br>
-gs/base/gdevpdti.c
-<br>
-gs/base/gdevpdts.c
-<br>
-gs/base/gdevpdtt.c
-<br>
-gs/base/gdevpdtw.c
-<br>
-gs/base/gstext.c
-<br>
-gs/base/gxchar.c
-<br>
-gs/base/gxftype.h
-<br>
-gs/base/gxpaint.c
-<br>
-pcl/pgfont.c
-<br>
-pl/plfont.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-13 19:57:44 +0100></a>
-2011-05-13 19:57: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=97fbf9fd981cdda1d6db80c2a808e3935b1809f3">97fbf9fd981cdda1d6db80c2a808e3935b1809f3</a>
-<blockquote>
-
-<br>
-Apparently missed in previous commit. Update so that stick fonts are
-<br>
-identified as such to pdfwrite.
-<br>
-
-<br>
-gs/base/gdevpdtd.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-13 19:53:56 +0100></a>
-2011-05-13 19:53:56 +0100</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fa801aa476fc200d397f0c72c383462eaad88267">fa801aa476fc200d397f0c72c383462eaad88267</a>
-<blockquote>
-
-<br>
-Add a new font type 'ft_GL2_stick_user_defined' and use it as the FontType
-<br>
-of the HP/GL2 stick font. Modify code throughout to treat it the same as
-<br>
-'ft_user_defined', ie a type 3 font.
-<br>
-
-<br>
-Allow pdfwrite to attach a type 3 'PDF font' to a stick font (normally the
-<br>
-types are required to be the same).
-<br>
-
-<br>
-Alter the way we calculate the 'default' device matrix during stick font
-<br>
-accumulation so that we get better stroke widhts.
-<br>
-
-<br>
-Now that we cna identify a stick font, check for anamorphic scaling before
-<br>
-accumulating the glyphs. If anamorphic scaling, then *don't* treat this as
-<br>
-a font. THis is because the stroke width will be inconsistent.
-<br>
-
-<br>
-gs/base/gdevpdte.c
-<br>
-gs/base/gdevpdtf.c
-<br>
-gs/base/gdevpdti.c
-<br>
-gs/base/gdevpdts.c
-<br>
-gs/base/gdevpdtt.c
-<br>
-gs/base/gdevpdtw.c
-<br>
-gs/base/gstext.c
-<br>
-gs/base/gxchar.c
-<br>
-gs/base/gxftype.h
-<br>
-gs/base/gxpaint.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-12 16:04:17 +0100></a>
-2011-05-12 16:04: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=6a1c8f107029e92509dfbcaf4aaf1d691d27abe5">6a1c8f107029e92509dfbcaf4aaf1d691d27abe5</a>
-<blockquote>
-
-<br>
-Alter the way we handle missing glyph names, use the saem code as for
-<br>
-composite fonts.
-<br>
-
-<br>
-Don't assume the CharProc matrix will be upright when creating the dummy
-<br>
-'initial' matrix, copy and scale all the values.
-<br>
-
-<br>
-gs/base/gdevpdtt.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-11 15:46:23 +0100></a>
-2011-05-11 15:46: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=d2ce995693b6c279ea207081728f6906a02e718a">d2ce995693b6c279ea207081728f6906a02e718a</a>
-<blockquote>
-
-<br>
-More type 3 font madness
-<br>
-
-<br>
-Use the device level 'PS_accumulator' flag in various places instead of
-<br>
-the more kludgy test against penuym->pte_default being NULL.
-<br>
-
-<br>
-If we don't get a glyph name back from the interpreter (PCL) then invent
-<br>
-one instead of giving up with an error.
-<br>
-
-<br>
-If we are not a type 3 accumulator, then don't undo the factor of 100
-<br>
-scaling applied to the device width and height, we only do that for PS.
-<br>
-
-<br>
-Add a routine to return a special 'initial' matrix during the course of
-<br>
-type 3 accumulation. The PCL stick font uses this to set the line width
-<br>
-and we need to account for various PS/PDF scaling which will otherwise
-<br>
-be ignored.
-<br>
-
-<br>
-Make sure we don't try and accumulate a charproc when its being run for a
-<br>
-charpath operation.
-<br>
-
-<br>
-gs/base/gdevpdfb.h
-<br>
-gs/base/gdevpdfx.h
-<br>
-gs/base/gdevpdtt.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-06 15:35:13 +0100></a>
-2011-05-06 15:35:13 +0100</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bc6a5bdd6329a0027d0c162e29eda277f85c2a8a">bc6a5bdd6329a0027d0c162e29eda277f85c2a8a</a>
-<blockquote>
-
-<br>
-Type PCL fonts again.
-<br>
-
-<br>
-Put back the matrix scaling in pdf_text_set_cache, even though the matrix
-<br>
-shoudl always be the identity here when running PCL. Best to be safe.
-<br>
-
-<br>
-set_charproc_attrs emitted a 'd1' setcachedevice, but didn't check if
-<br>
-the glyph was flipped. For PCL this led to ury being less than lly, and
-<br>
-so the glyph was elided. Added check to make sure these are correct. This
-<br>
-required removal of 'const' from an arry as well.
-<br>
-
-<br>
-gs/base/gdevpdfx.h
-<br>
-gs/base/gdevpdti.c
-<br>
-gs/base/gdevpdtt.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-06 15:06:22 +0100></a>
-2011-05-06 15:06:22 +0100</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8730b9f1c3c1977805a9f0ad830b0268170343c4">8730b9f1c3c1977805a9f0ad830b0268170343c4</a>
-<blockquote>
-
-<br>
-More type 3 changes
-<br>
-
-<br>
-Don't scale the CTM by 100 (done for FreeType) when handling PCL fonts
-<br>
-in install_charproc_accum, set the boolean to complete_charproc_accum so
-<br>
-that we don't 'undo' the factor of 100 scaling when the font is PCL.
-<br>
-
-<br>
-Add code to set_charproc_attrs to determine whether this is a 'scale 100'
-<br>
-(ie PostScript) type 3 font or not, if its not then don't undo the scaling
-<br>
-by 100 of the CTM.
-<br>
-
-<br>
-When accumulating a chraproc, before setting the CTM to identity matrix
-<br>
-also set the current point to 0,0, which ensures that that the current point
-<br>
-doesn't get baked into the character description. Also invalidate the
-<br>
-'char_tm' txy_fixed_valid member of the graphics state, this will force
-<br>
-a recalculation of char_tm using the new identity matrix.
-<br>
-
-<br>
-gs/base/gdevpdfx.h
-<br>
-gs/base/gdevpdti.c
-<br>
-gs/base/gdevpdtt.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-06 12:29:38 +0100></a>
-2011-05-06 12:29: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=1b7695b7f2fe4dac0e228294b944b667e617e822">1b7695b7f2fe4dac0e228294b944b667e617e822</a>
-<blockquote>
-
-<br>
-More PCL type 3 improvements
-<br>
-
-<br>
-Add code to initialise the returned character code, so that the charproc
-<br>
-is assigned the correct character code. Further test for PCL fonts in
-<br>
-pdf_text_set_cache and don't try to use a show enumerator to get the
-<br>
-'output_char_code' when we are doing PCL, instead use the one from the
-<br>
-text enumerator 'returned' structure. Normally this would not be valid
-<br>
-yet as this is filled in after we've completed the 'show', but we
-<br>
-set this before startig the show, from the text string, so that it will be
-<br>
-valid.
-<br>
-
-<br>
-gs/base/gdevpdtt.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-06 11:49:19 +0100></a>
-2011-05-06 11:49: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=3791899545ad61db983158e468d29de85153f94a">3791899545ad61db983158e468d29de85153f94a</a>
-<blockquote>
-
-<br>
-More type 3 PCL fonts
-<br>
-
-<br>
-Attempt to get gsave/grestore counting correct by addig requied gs_gsave.
-<br>
-Add code to invalidate the char_ctm as we have altered the CTM to identity
-<br>
-for capture, and don't want to use the char_ctm (values are restored later).
-<br>
-
-<br>
-gs/base/gdevpdtt.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-05 15:26:17 +0100></a>
-2011-05-05 15:26: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=1ccea133c3b21570c6400337dbe260791da8807d">1ccea133c3b21570c6400337dbe260791da8807d</a>
-<blockquote>
-
-<br>
-Add in basic handling for PCL type 3 fonts. Now setss up the accumulator
-<br>
-patches the enumerator procs so that the pdfwrite set_cache is used when
-<br>
-setcachedevice is issued.
-<br>
-
-<br>
-Text matrices are wrong in many places leading to empty output.
-<br>
-
-<br>
-gs/base/gdevpdtt.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-05 14:50:33 +0100></a>
-2011-05-05 14:50: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=fa5cce2824ade8c280adf370686e20e661d0c3e3">fa5cce2824ade8c280adf370686e20e661d0c3e3</a>
-<blockquote>
-
-<br>
-Add handler for PCL type 3 fonts. For now this throws an error, just while
-<br>
-I make sure it doesn't break any PS/PDF files.
-<br>
-
-<br>
-gs/base/gdevpdtt.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-05 13:15:19 +0100></a>
-2011-05-05 13:15: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=f5cc30c83a05acacfd9c2e18b72e7e716c38d024">f5cc30c83a05acacfd9c2e18b72e7e716c38d024</a>
-<blockquote>
-
-<br>
-File missed in previous commit
-<br>
-
-<br>
-gs/base/gdevpdtt.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-05 13:13:27 +0100></a>
-2011-05-05 13:13: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=7838510e494245cc5e5349f2ea0d5ff9028c96d0">7838510e494245cc5e5349f2ea0d5ff9028c96d0</a>
-<blockquote>
-
-<br>
-Add better PCL type 3 font handling, step 1
-<br>
-
-<br>
-First, break all the code for starting and stopping accumulators
-<br>
-into procedures, because the existing code is too hard to read.
-<br>
-
-<br>
-gs/base/gdevpdfb.c
-<br>
-gs/base/gdevpdfb.h
-<br>
-gs/base/gdevpdfx.h
-<br>
-gs/base/gdevpdti.c
-<br>
-gs/base/gdevpdtt.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-29 16:42:30 +0100></a>
-2011-04-29 16:42: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=947e90ad0229b6333d6eb61e7f54ac33b200ab28">947e90ad0229b6333d6eb61e7f54ac33b200ab28</a>
-<blockquote>
-
-<br>
-initial changes for capturing PCL type 3 fonts in pdfwrite
-<br>
-
-<br>
-Seems to be OK now with PS/PCL, does not crash any longer with PCL, but capture is incorrect.
-<br>
-
-<br>
-gs/base/gdevpdfb.c
-<br>
-gs/base/gdevpdfb.h
-<br>
-gs/base/gdevpdfx.h
-<br>
-gs/base/gdevpdti.c
-<br>
-gs/base/gdevpdtt.c
-<br>
-gs/base/gdevpdtt.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-20 18:22:37 +0100></a>
-2011-05-20 18:22: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=1ab5da13a846b9fde15c2863b6b75ae5b28d22d8">1ab5da13a846b9fde15c2863b6b75ae5b28d22d8</a>
-<blockquote>
-
-<br>
-Bug 692218: Incorrect CIDtoGIDMap length causing crash.
-<br>
-
-<br>
-In pdfwrite's pdf_convert_truetype_font_descriptor() function,
-<br>
-the lengths of both the CIDtoGIDMap and the CIDSet were being set
-<br>
-to the number of in use CID's in the font, whereas they need to
-<br>
-be, and were being filled, as being LastChar + 1 entries long.
-<br>
-
-<br>
-As well as memory corruption, the contents would have been wrong,
-<br>
-too.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gdevpdtd.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-20 12:46:09 +0000></a>
-2011-05-20 12:46:09 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0805588e9bcaec02b4eef4582db6ab23ae8ea1b1">0805588e9bcaec02b4eef4582db6ab23ae8ea1b1</a>
-<blockquote>
-
-<br>
-Fix Bug 692216. Remove zero height traps from shadings.
-<br>
-
-<br>
-The simplified file in Bug 692216 shows a division by zero error when
-<br>
-filling a trapezoid with zero height. The fix is simply to update
-<br>
-the code not to draw zero height traps.
-<br>
-
-<br>
-This should be safe as any fill adjustment is done well before this point.
-<br>
-
-<br>
-The cluster shows just one difference. Looking at it in a bmpcmp it does
-<br>
-look suspicious, but it's not clear whether it's a progression or a
-<br>
-regression. Ken informs me he's seen the same differences before with
-<br>
-unrelated changes, so perhaps it's an indeterminism.
-<br>
-
-<br>
-The code seems more sensible this way round anyway.
-<br>
-
-<br>
-gs/base/gxshade6.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-20 07:58:28 +0100></a>
-2011-05-20 07:58: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=c6341648ed83b1a3dde948bdf8bcf54a2f275fe5">c6341648ed83b1a3dde948bdf8bcf54a2f275fe5</a>
-<blockquote>
-
-<br>
-Reinstate x11alpha as the default device on Unix.
-<br>
-
-<br>
-With the recent revisions to make transparency play nicely
-<br>
-with anti-aliased output, should now be safe to use as the
-<br>
-default device.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-19 14:55:52 -0600></a>
-2011-05-19 14:55: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=9de72911de76b582f028c70564b1539f913b517c">9de72911de76b582f028c70564b1539f913b517c</a>
-<blockquote>
-
-<br>
-Make directories silently.
-<br>
-
-<br>
-The previous mkdir incantantation had unwanted warning messages if the
-<br>
-directory already existed. Thanks to Norbert Janssen for the patch.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-common/msvc_top.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-18 19:04:26 -0600></a>
-2011-05-18 19:04: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=413e6e5a1c7ccc3d86678a54e93130ca182f9e98">413e6e5a1c7ccc3d86678a54e93130ca182f9e98</a>
-<blockquote>
-
-<br>
-Simplify the svg device state.
-<br>
-
-<br>
-Represent colors directly with color indices not strings.
-<br>
-This will address bug 691886 indirectly but wasn't the motivation
-<br>
-for changing the state value types.
-<br>
-
-<br>
-gs/base/gdevsvg.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-16 13:28:46 -0600></a>
-2011-05-16 13:28:46 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=86da13321eaa87a01b804af3619d30f8a7263f5e">86da13321eaa87a01b804af3619d30f8a7263f5e</a>
-<blockquote>
-
-<br>
-Decrease debugging verbosity.
-<br>
-
-<br>
-Change default printing to be conditonal on high level device
-<br>
-debug flag '_'.
-<br>
-
-<br>
-gs/base/gdevsvg.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-19 18:32:07 +0100></a>
-2011-05-19 18:32: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=4812b7189345fa94075445d8e8d5eef7eb04cdab">4812b7189345fa94075445d8e8d5eef7eb04cdab</a>
-<blockquote>
-
-<br>
-Explicitly disable libtiff's jbig code.
-<br>
-
-<br>
-Add the --disable-jbig option to both Ghostscript and GhostPDL's
-<br>
-calls to the libtiff configure script, otherwise, if the build
-<br>
-system has libjbig installed, libtiff's jbig code is enabled,
-<br>
-and we don't want/need it.
-<br>
-
-<br>
-Bug 692214.
-<br>
-
-<br>
-Makefile
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-19 16:58:33 +0000></a>
-2011-05-19 16:58:33 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8f4b7b96b14df2bef1564e00c72f087f72bb8f56">8f4b7b96b14df2bef1564e00c72f087f72bb8f56</a>
-<blockquote>
-
-<br>
-More Memento tweaks. Thanks to Dave Thomas.
-<br>
-
-<br>
-Remove unused variables/unneeded inits.
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/base/memento.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-19 15:26:05 +0000></a>
-2011-05-19 15:26:05 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b35b5d610738a521cfe6374965a8f6c4d6b5d477">b35b5d610738a521cfe6374965a8f6c4d6b5d477</a>
-<blockquote>
-
-<br>
-Correct memset prototype in memento.c. D'Oh.
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/base/memento.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-19 15:34:31 +0100></a>
-2011-05-19 15:34: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=44e59fd123729ba05f8728f01d13406d3e283855">44e59fd123729ba05f8728f01d13406d3e283855</a>
-<blockquote>
-
-<br>
-Merge branch 'patt_trans_clist'
-<br>
-
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-19 15:01:14 +0100></a>
-2011-05-19 15:01:14 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3bf453e7987830459ca677c8fa1b93fbd6c4a7e3">3bf453e7987830459ca677c8fa1b93fbd6c4a7e3</a>
-<blockquote>
-
-<br>
-Fix for icc profile refcounting.
-<br>
-
-<br>
-Take new reference before discarding old one, lest we throw away the
-<br>
-last reference and then can't pick it up again.
-<br>
-
-<br>
-This solves the SEGV with:
-<br>
-
-<br>
-gs\debugbin\gswin32c.exe -sDEVICE=ppmraw -o out.ppm
-<br>
--r300 ..\ghostpcl\tests_private\comparefiles\Bug689690.pdf
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-19 13:35:37 +0100></a>
-2011-05-19 13:35:37 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bc9e69257a1605d67aca0cd121e167d7e0ae22be">bc9e69257a1605d67aca0cd121e167d7e0ae22be</a>
-<blockquote>
-
-<br>
-Merge branch 'master' into patt_trans_clist
-<br>
-
-<br>
-I expect this to leave me with all files working except for Bug689690.pdf
-<br>
-which has profile reference counting problems introduced from the trunk.
-<br>
-
-<br>
-For example:
-<br>
-gs\debugbin\gswin32c.exe -sDEVICE=ppmraw -o out.ppm
-<br>
--r300 ..\ghostpcl\tests_private\comparefiles\Bug689690.pdf
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-18 15:57:45 +0000></a>
-2011-05-18 15:57:45 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5cff633dff1b8b91afb97925f8a4f7781db5a9b2">5cff633dff1b8b91afb97925f8a4f7781db5a9b2</a>
-<blockquote>
-
-<br>
-Fix SEGV in tile_rect_trans_simple.
-<br>
-
-<br>
-If the left hand copy region started to the right of the subtile that was
-<br>
-actually populated, we would attempt a copy with a negative length. Simple
-<br>
-fix is to check for this case.
-<br>
-
-<br>
-This should resolve the 5 xps SEGVs.
-<br>
-
-<br>
-gs/base/gxp1fill.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-17 23:37:56 +0000></a>
-2011-05-17 23:37:56 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=128650aac51fcf723428b8a902c4e3af7d1d058f">128650aac51fcf723428b8a902c4e3af7d1d058f</a>
-<blockquote>
-
-<br>
-Fix SEGV in Bug691538.pdf.
-<br>
-
-<br>
-Local testing with:
-<br>
-gs -dNOGC -Z@? -r300 -sDEVICE=pbmraw -dMaxBitmap=30000000 -o nul: ..\ghostpcl\tests_private\comparefiles\Bug691538.pdf
-<br>
-
-<br>
-shows a SEGV on windows with a debug build. Removing the reference
-<br>
-decrement solves it and doesn't show any leaks.
-<br>
-
-<br>
-Oddly the cluster doesn't show the SEGV any more, but it did previously.
-<br>
-
-<br>
-gs/base/gxpcmap.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-17 18:13:17 +0100></a>
-2011-05-17 18:13: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=6780bf7996f1d5a0be5b0dc55e89ea48bf89980e">6780bf7996f1d5a0be5b0dc55e89ea48bf89980e</a>
-<blockquote>
-
-<br>
-Memento realloc fix.
-<br>
-
-<br>
-Memento was filling the 'new' section of realloced blocks incorrectly,
-<br>
-resulting in memory overwrites.
-<br>
-
-<br>
-gs/base/memento.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-17 15:53:01 +0100></a>
-2011-05-17 15:53: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=ce8bddd7cef1f9e0d2c2ae28b82d513a6cfa9dce">ce8bddd7cef1f9e0d2c2ae28b82d513a6cfa9dce</a>
-<blockquote>
-
-<br>
-Merge branch 'master' into patt_trans_clist
-<br>
-
-<br>
-gs/base/gdevnfwd.c
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gstrans.c
-<br>
-gs/base/gxclrast.c
-<br>
-gs/base/gxdevice.h
-<br>
-gs/ghostscript.vcproj
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-17 15:42:11 +0100></a>
-2011-05-17 15:42:11 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1b7bf4222988019f17a454ce7a6b841d586c3d4d">1b7bf4222988019f17a454ce7a6b841d586c3d4d</a>
-<blockquote>
-
-<br>
-Comment and error code handling tweaks to gdevp14.c
-<br>
-
-<br>
-Correct a typo, update a comment, and avoid a SEGV in the case where
-<br>
-an allocation of an iccsmask fails.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-17 15:38:38 +0100></a>
-2011-05-17 15:38: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=6283d613595f2c42a461d2cb8cfddb2e0a6fc168">6283d613595f2c42a461d2cb8cfddb2e0a6fc168</a>
-<blockquote>
-
-<br>
-Tiny tweak to leaks.tcl
-<br>
-
-<br>
-Tweak leaks.tcl so it doesn't think the file is empty if 'memory allocated'
-<br>
-is on the first line of the log.
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/toolbin/leaks.tcl
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-17 15:23:24 +0100></a>
-2011-05-17 15:23:24 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ec504eeddfd5e17ca5f1b4e58090fb0c1b15201">4ec504eeddfd5e17ca5f1b4e58090fb0c1b15201</a>
-<blockquote>
-
-<br>
-Rework colorspace ref counting of cmm_icc_profile_data.
-<br>
-
-<br>
-Previously the code seemed to be trying to take one reference to
-<br>
-cmm_icc_profile_data for every reference taken to the colorspace. We rework
-<br>
-this here to only take a single reference to cmm_icc_profile_data for each
-<br>
-colorspace. This solves at least one SEGV.
-<br>
-
-<br>
-gs/base/gscdevn.c
-<br>
-gs/base/gscscie.c
-<br>
-gs/base/gscspace.c
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gxipixel.c
-<br>
-gs/base/gxshade.c
-<br>
-gs/psi/zicc.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-12 17:49:46 +0100></a>
-2011-05-12 17:49:46 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a0ac4ac2082132905463703ddd8b6db6fd95e4fb">a0ac4ac2082132905463703ddd8b6db6fd95e4fb</a>
-<blockquote>
-
-<br>
-Squash another warning; gdevp14.c.
-<br>
-
-<br>
-Remove an unused variable definition (that is shadowed later on).
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-12 17:41:17 +0100></a>
-2011-05-12 17:41: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=d40646d2f1c48c174fad480c03309707b16659c7">d40646d2f1c48c174fad480c03309707b16659c7</a>
-<blockquote>
-
-<br>
-Squash warning.
-<br>
-
-<br>
-Remove unused variable, left over from merge.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/gdevnfwd.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-12 17:01:59 +0100></a>
-2011-05-12 17:01: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=6d910ef6207e3704f1050cd46c481ac81b681261">6d910ef6207e3704f1050cd46c481ac81b681261</a>
-<blockquote>
-
-<br>
-Fix SEGVs seen due to icc profile data being freed.
-<br>
-
-<br>
-If we swap the ICC profile data for a colorspace due to starting/stopping
-<br>
-use of an smask, we must also adjust the reference counts. Hopefully this
-<br>
-will solve all the SEGVs we see. It does solve at least one.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-12 15:26:56 +0100></a>
-2011-05-12 15:26:56 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4d9eb7298700e0b4c484f164805d556c03c22b24">4d9eb7298700e0b4c484f164805d556c03c22b24</a>
-<blockquote>
-
-<br>
-Merge branch 'master' into patt_trans_clist
-<br>
-
-<br>
-Conflicts:
-<br>
-gs/base/gdevnfwd.c
-<br>
-gs/base/gxdevice.h
-<br>
-gs/toolbin/bmpcmp.c
-<br>
-
-<br>
-All trivially resolved except for gdevnfwd.c where I backed out one of the
-<br>
-fixes from 8ae4342 on instruction from Michael.
-<br>
-
-<br>
-gs/base/gdevnfwd.c
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gstrans.c
-<br>
-gs/base/gxclip.c
-<br>
-gs/base/gxdevice.h
-<br>
-gs/base/gxpcmap.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-04 20:00:50 +0100></a>
-2011-05-04 20:00:50 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9d8dc0278374c7c5bb4868a1ed356b8b5f8ece8a">9d8dc0278374c7c5bb4868a1ed356b8b5f8ece8a</a>
-<blockquote>
-
-<br>
-Whitespace fixes + Return from gx_forward_create_compositor.
-<br>
-
-<br>
-Fix up some stray trailing whitespace.
-<br>
-
-<br>
-Also, gx_forward_create_compositor was neglecting to return a value.
-<br>
-
-<br>
-gs/base/gdevnfwd.c
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-03 20:36:49 -0700></a>
-2011-05-03 20:36:49 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8ae4342084cbfc46782ca3fc23b4965f910f3c51">8ae4342084cbfc46782ca3fc23b4965f910f3c51</a>
-<blockquote>
-
-<br>
-Fixes for 2 issues. If a clip device is inserted in front of a pdf14 compositor, the ICC profile of the clip device needs to be updated if the compositor action results in a device profile change. Also fix so that when the soft mask ICC profiles are swapped in or out the graphic state ICC profiles are also updated.
-<br>
-
-<br>
-gs/base/gdevnfwd.c
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-03 17:30:58 +0100></a>
-2011-05-03 17:30:58 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e0e5e5c874d7546805558a00bec9c54ebd0770e5">e0e5e5c874d7546805558a00bec9c54ebd0770e5</a>
-<blockquote>
-
-<br>
-Backout strokeafterfill stuff, as it proved unnecessary.
-<br>
-
-<br>
-Remove commit eaae298 as it turns out not to be required.
-<br>
-
-<br>
-gs/base/gspaint.c
-<br>
-gs/base/gspath.h
-<br>
-gs/base/gxistate.h
-<br>
-gs/psi/zpaint.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-02 19:39:22 +0000></a>
-2011-05-02 19:39:22 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=04eef3817a5a6d3fee054338629b1e50eaa4ee0f">04eef3817a5a6d3fee054338629b1e50eaa4ee0f</a>
-<blockquote>
-
-<br>
-Merge branch 'master' into patt_trans_clist
-<br>
-
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-02 19:28:39 +0000></a>
-2011-05-02 19:28:39 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=df2175e571369df32fc66e375357bc69976c5fed">df2175e571369df32fc66e375357bc69976c5fed</a>
-<blockquote>
-
-<br>
-Put back default map_rgb_color forwarding.
-<br>
-
-<br>
-At some point around the creation of this branch (which corresponded to our
-<br>
-move from SVN to git) we lost a line in gdevnfwd.c that sets up a default
-<br>
-forwarding for map_rgb_color. We don't know why it went, so we're putting it
-<br>
-back in. This probably hasn't caused any problems as it's a deprecated
-<br>
-function now.
-<br>
-
-<br>
-gs/base/gdevnfwd.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-02 20:02:59 +0100></a>
-2011-05-02 20:02: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=8eed15b976995b889a2498b064b53397a7d164a1">8eed15b976995b889a2498b064b53397a7d164a1</a>
-<blockquote>
-
-<br>
-Add gxdevsop.h to VS solution.
-<br>
-
-<br>
-Don't know why this wasn't in before...
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/ghostscript.vcproj
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-02 19:50:04 +0100></a>
-2011-05-02 19:50:04 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8d52d58da97faadd2dcd009f9a5381e87182789d">8d52d58da97faadd2dcd009f9a5381e87182789d</a>
-<blockquote>
-
-<br>
-Pacify valgrind (and improve performance?) with tiny change.
-<br>
-
-<br>
-A tiny change to gxclrast.c where we initialise state_tile.size.{x,y}.
-<br>
-This stops valgrind giving warnings. While the code works OK without
-<br>
-this (I believe), it can cause various %, /, gcd operations. These are
-<br>
-all expensive operations and are neatly sidestepped by the simple
-<br>
-expedient of setting the variable to 0 to start with.
-<br>
-
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-02 18:32:06 +0000></a>
-2011-05-02 18:32:06 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4cd416d1e5f46c01ce9827b803035a939872e7f7">4cd416d1e5f46c01ce9827b803035a939872e7f7</a>
-<blockquote>
-
-<br>
-Fix clipping problems with composited pattern clists.
-<br>
-
-<br>
-When using a clist to fill a clipped area with a pattern, the current
-<br>
-code can drop the clipping device out of the chain. This change solves that
-<br>
-problem.
-<br>
-
-<br>
-When we create a new compositor, we generally want that compositor to become
-<br>
-the top device in the chain, so all new drawing commands go to it. In the
-<br>
-pattern clist case however, we don't create a new compositor - we reuse an
-<br>
-existing one. It's important in this case *not* to take this as our new
-<br>
-target, otherwise the higher devices in the chain (such as the clipper
-<br>
-device) are lost.
-<br>
-
-<br>
-This was shown when rendering pattrans_big.pdf at 300dpi banded to the pkm
-<br>
-device.
-<br>
-
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-02 11:21:50 -0700></a>
-2011-05-02 11:21:50 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d33714d197a3335ad34d21e70fc767cf42b369d">1d33714d197a3335ad34d21e70fc767cf42b369d</a>
-<blockquote>
-
-<br>
-Fix for typo in pointer name during initialization of shape buffer during transparency pattern filling.
-<br>
-
-<br>
-gs/base/gxp1fill.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-02 18:53:00 +0100></a>
-2011-05-02 18:53:00 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=600aa9cc10d4439823de265d2805617154294ee7">600aa9cc10d4439823de265d2805617154294ee7</a>
-<blockquote>
-
-<br>
-Quiet valgrind warning, and remove misleading init.
-<br>
-
-<br>
-When run with valgrind on:
-<br>
-
-<br>
-gs -sDEVICE=pbmraw -r300 -dMaxBitmap=100000000 -o out.pbm Bug690189c.pdf
-<br>
-
-<br>
-Valgrind complains that params.GrayBackground is used without being
-<br>
-initialised. We fix this here by amending gs_trans_mask_params_init.
-<br>
-
-<br>
-In so doing, we note that in zbegintransparencymaskgroup we were setting
-<br>
-params.ColorSpace, only to call gs_trans_mask_params_init and have it
-<br>
-overwrite it. To avoid confusion we therefore remove this needless init.
-<br>
-
-<br>
-No cluster differences seen in testing.
-<br>
-
-<br>
-gs/base/gstrans.c
-<br>
-gs/psi/ztrans.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-02 14:51:26 +0100></a>
-2011-05-02 14:51:26 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1dbe20d53a4443a70692e9b7807cfb8a158229d0">1dbe20d53a4443a70692e9b7807cfb8a158229d0</a>
-<blockquote>
-
-<br>
-Add support for cups (1bpp) files to bmpcmp.
-<br>
-
-<br>
-gs/toolbin/bmpcmp.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-30 17:55:42 +0100></a>
-2011-04-30 17:55:42 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eaae298fcfe31efda0166786c5624ef8fefd0e12">eaae298fcfe31efda0166786c5624ef8fefd0e12</a>
-<blockquote>
-
-<br>
-Add new .strokeafterfill ps operator/graphics state bit.
-<br>
-
-<br>
-We add a new .strokeafterfill ps operator that takes a bool, and sets it in
-<br>
-the graphics state. The intention is that this will allow us to spot the
-<br>
-case where we are executing the stroke part of a combined 'fill and stroke'
-<br>
-operation (as required by pdf). This should allow us to solve the
-<br>
-remaining problems with the pdf14/knockout group.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gspaint.c
-<br>
-gs/base/gspath.h
-<br>
-gs/base/gxistate.h
-<br>
-gs/psi/zpaint.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-29 19:41:50 +0100></a>
-2011-04-29 19:41:50 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=96339fd0f400d7c0534a8ff73c355787d7773297">96339fd0f400d7c0534a8ff73c355787d7773297</a>
-<blockquote>
-
-<br>
-Correct typo in comment. CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/base/gxfillsl.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-29 19:39:27 +0100></a>
-2011-04-29 19:39:27 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6ac5520977be5b3ee198c155ef395c6406962db4">6ac5520977be5b3ee198c155ef395c6406962db4</a>
-<blockquote>
-
-<br>
-Whitespace fixes.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gsicc.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-27 22:41:28 -0700></a>
-2011-04-27 22:41:28 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c9de3e70e4027fb86dde6079a48b29cfd6825c72">c9de3e70e4027fb86dde6079a48b29cfd6825c72</a>
-<blockquote>
-<p>
- Revert &quot;MSVC changes plus gitignore for patt_trans_clist&quot;
-<br>
-
-<br>
-This reverts commit 01c9c2bd3dbd8be851b2e8dde68885413807e704.
-<br>
-
-<br>
-.gitignore
-<br>
-gs/ghostscript.vcproj
-<br>
-win32/GhostPDL.sln
-<br>
-win32/GhostPDL.suo
-<br>
-win32/language_switch.vcproj
-<br>
-win32/language_switch.vcproj.michaelv-PC.michaelv.user
-<br>
-win32/pcl.vcproj
-<br>
-win32/pcl.vcproj.michaelv-PC.michaelv.user
-<br>
-win32/svg.vcproj
-<br>
-win32/svg.vcproj.michaelv-PC.michaelv.user
-<br>
-win32/xps.vcproj
-<br>
-win32/xps.vcproj.michaelv-PC.michaelv.user
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-27 22:27:39 -0700></a>
-2011-04-27 22:27: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=4b191e99538574a67178a8a4df0e19f380d47403">4b191e99538574a67178a8a4df0e19f380d47403</a>
-<blockquote>
-
-<br>
-Fix for reference counting issue of the compositor device at
-<br>
-the end of the clist playback. In most cases, the compositor rc
-<br>
-should be 1 at this point and so the device is closed and then
-<br>
-freed. The case, when it is not 1 is when we have a pattern
-<br>
-that has a transparency and is stored in a clist. In this case
-<br>
-the target for the pattern clist device is the main pdf14 device and
-<br>
-we increment the rc during this assignment. So, when the
-<br>
-playback completes, the rc of the compositor is 2. We do not
-<br>
-want to close and free the compositor, since it is part of the
-<br>
-main clist that we have going on. Instead we only want to
-<br>
-decrement the rc. The test file pattrans_big.pdf is now
-<br>
-handled correctly but has a rendering/tiling issue it appears.
-<br>
-
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-27 22:20:56 -0700></a>
-2011-04-27 22:20:56 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=01c9c2bd3dbd8be851b2e8dde68885413807e704">01c9c2bd3dbd8be851b2e8dde68885413807e704</a>
-<blockquote>
-
-<br>
-MSVC changes plus gitignore for patt_trans_clist
-<br>
-
-<br>
-.gitignore
-<br>
-gs/ghostscript.vcproj
-<br>
-win32/GhostPDL.sln
-<br>
-win32/GhostPDL.suo
-<br>
-win32/language_switch.vcproj
-<br>
-win32/language_switch.vcproj.michaelv-PC.michaelv.user
-<br>
-win32/pcl.vcproj
-<br>
-win32/pcl.vcproj.michaelv-PC.michaelv.user
-<br>
-win32/svg.vcproj
-<br>
-win32/svg.vcproj.michaelv-PC.michaelv.user
-<br>
-win32/xps.vcproj
-<br>
-win32/xps.vcproj.michaelv-PC.michaelv.user
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-27 18:43:52 +0000></a>
-2011-04-27 18:43:52 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=82437e248e95c3e9830720feaf5030d37950b091">82437e248e95c3e9830720feaf5030d37950b091</a>
-<blockquote>
-
-<br>
-Whitespace fixups.
-<br>
-
-<br>
-gs/base/gxpcmap.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-27 18:42:10 +0000></a>
-2011-04-27 18:42:10 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bdbb2b5da2ad758d07dfefc84b2a53c00ba091d4">bdbb2b5da2ad758d07dfefc84b2a53c00ba091d4</a>
-<blockquote>
-
-<br>
-Revert SVN commit 12934, ref count checking before free in gxclrast.c
-<br>
-
-<br>
-A couple of weeks ago, I applied a wild stab in the dark to solve a problem
-<br>
-that I cannot now locate. Having discussed it with Michael it seems that this
-<br>
-was (at best) just masking another problem (the incorrect ref count
-<br>
-initialisation of compositors). This has been fixed, so my faulty attempt
-<br>
-can be backed out.
-<br>
-
-<br>
-We leave a debug only check in there to catch this situation. This should be
-<br>
-replaced by an assert when we have such things.
-<br>
-
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-27 15:25:22 +0100></a>
-2011-04-27 15:25: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=bdfb4cf85e6c7d78dbeecfb8c6dd06c1eed14714">bdfb4cf85e6c7d78dbeecfb8c6dd06c1eed14714</a>
-<blockquote>
-
-<br>
-Fix overflow in pattern tile size estimation code.
-<br>
-
-<br>
-gs/base/gxpcmap.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-27 10:46:22 +0000></a>
-2011-04-27 10:46:22 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1540df197675f2935c6d743927ad25df0396dfff">1540df197675f2935c6d743927ad25df0396dfff</a>
-<blockquote>
-
-<br>
-Merge branch 'master' into patt_trans_clist
-<br>
-
-<br>
-gs/base/gstrans.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-26 13:23:00 -0700></a>
-2011-04-26 13:23:00 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=212d2dba16a53088ba6de69266603db847069ec7">212d2dba16a53088ba6de69266603db847069ec7</a>
-<blockquote>
-
-<br>
-Check to make sure an empty deviceN params member does not lead to an improper path during the device creation.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-26 19:40:25 +0100></a>
-2011-04-26 19:40:25 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=696ee8153b72d20484e66f5da43b6ee6027fddc4">696ee8153b72d20484e66f5da43b6ee6027fddc4</a>
-<blockquote>
-
-<br>
-Remove partial merge left over from svn conversion.
-<br>
-
-<br>
-gs/base/gsptype1.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-02-09 21:38:24 +0000></a>
-2011-02-09 21:38:24 +0000</strong>
-<br>mvrhel <mvrhel@a1074d23-0009-0410-80fe-cf8c14f379e6><br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ebf1da59669bb51701c3df9747ebe3f4fe9f6b26">ebf1da59669bb51701c3df9747ebe3f4fe9f6b26</a>
-<blockquote>
-
-<br>
-Work on the pattern transparency clist code.
-<br>
-
-<br>
-A squashed and rebased patch based on the following svn commits.
-<br>
-
-<br>
-Author: robin <robin@a1074d23-0009-0410-80fe-cf8c14f379e6>
-<br>
-Date: Tue Apr 19 12:40:00 2011 +0000
-<br>
-
-<br>
-Various fixes to the transparency clist branch to correctly use
-<br>
-just the subrectangle of transparency tiles that is actually present.
-<br>
-
-<br>
-Getting this in before the Great Git Change this afternoon.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/branches/patt_trans_clist_gs@12407 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-Author: ray <ray@a1074d23-0009-0410-80fe-cf8c14f379e6>
-<br>
-Date: Fri Apr 8 16:56:48 2011 +0000
-<br>
-
-<br>
-A couple of minor fixes that help things along, get past compile errors.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/branches/patt_trans_clist_gs@12379 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-Author: mvrhel <mvrhel@a1074d23-0009-0410-80fe-cf8c14f379e6>
-<br>
-Date: Wed Feb 9 21:38:24 2011 +0000
-<br>
-
-<br>
-Initial commit of work so far on getting the pattern transparency
-<br>
-clist code working. Much of this comes from work that Ray and I did
-<br>
-for customer 532. The remaining portion of the work is primarily
-<br>
-in pdf14_tile_pattern_fill in gdevp14.c, where we need to make
-<br>
-sure that the group that we are going to push is the intersection
-<br>
-with the rect from trans pattern since we only use the part that we
-<br>
-drew into in the pattern creation and not the whole group buffer. I
-<br>
-had not worked on this in a few weeks so I don't have more details
-<br>
-right now. I will spend a day on it this week to see exactly what
-<br>
-remains to be done.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/branches/patt_trans_clist_gs@12137 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gdevnfwd.c
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gdevp14.h
-<br>
-gs/base/gsptype1.c
-<br>
-gs/base/gsptype1.h
-<br>
-gs/base/gstrans.c
-<br>
-gs/base/gstrans.h
-<br>
-gs/base/gxclip.c
-<br>
-gs/base/gxdevice.h
-<br>
-gs/base/gxp1fill.c
-<br>
-gs/base/gxpcmap.c
-<br>
-gs/base/gxpcolor.h
-<br>
-gs/psi/zpcolor.c
-<br>
-gs/psi/ztrans.c
-<br>
-svg/svgdoc.c
-<br>
-xps/xpspage.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-19 15:27:07 +0100></a>
-2011-05-19 15:27: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=e60ed1f615f7347dc9318b2c8e17851fb3a6199a">e60ed1f615f7347dc9318b2c8e17851fb3a6199a</a>
-<blockquote>
-
-<br>
-Address bug 692211; byteswap.h not present on FreeBSD.
-<br>
-
-<br>
-After googling it seems like the correct thing to do is to use gcc builtin
-<br>
-intrinsics for byteswapping from 4.3 upwards, and to use byteswap.h
-<br>
-for all other versions of gcc >= 2.0. This should address the problem.
-<br>
-
-<br>
-gs/base/gsropt.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-19 12:28:06 +0000></a>
-2011-05-19 12:28:06 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f66aa4e491ecff0a5787c4f4a8c8ace1cb7d3432">f66aa4e491ecff0a5787c4f4a8c8ace1cb7d3432</a>
-<blockquote>
-
-<br>
-Minor tweaks to memento.
-<br>
-
-<br>
-Improve debugging output, documentation. Fix the time at which the sequence
-<br>
-counter is incremented to give less confusing messages. Add Memento_inited
-<br>
-function to breakpoint on.
-<br>
-
-<br>
-Not enabled in cluster so, CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/base/lib.mak
-<br>
-gs/base/memento.c
-<br>
-gs/base/memento.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-18 12:28:05 -0600></a>
-2011-05-18 12:28:05 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ef883a068ea54fca1569e5389f7ccfa6aa01e6a8">ef883a068ea54fca1569e5389f7ccfa6aa01e6a8</a>
-<blockquote>
-
-<br>
-Merge branch 'pcl_documentation'
-<br>
-
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-14 15:15:32 -0600></a>
-2011-05-14 15:15:32 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=21503ee8197c9707f8ced1c92593c4e279687ee2">21503ee8197c9707f8ced1c92593c4e279687ee2</a>
-<blockquote>
-
-<br>
-Long overdue update of the PCL documentation.
-<br>
-
-<br>
-doc/ghostpdl.pdf
-<br>
-doc/ghostpdl.tex
-<br>
-doc/ghostpdl.txt
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-18 17:48:10 +0100></a>
-2011-05-18 17:48:10 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=62b57818e9117c1ebfe32894464ab12956826f7d">62b57818e9117c1ebfe32894464ab12956826f7d</a>
-<blockquote>
-
-<br>
-Workaround SEGV in clist with fillpage (Bug 692076).
-<br>
-
-<br>
-This is a simple patch for the symptoms, not a proper cure, but it suffices
-<br>
-to get it out of regression test error lists.
-<br>
-
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-18 15:05:28 +0100></a>
-2011-05-18 15:05: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=1a7d4d447c2fc05240ab258f4eb232080fd1fb5f">1a7d4d447c2fc05240ab258f4eb232080fd1fb5f</a>
-<blockquote>
-
-<br>
-Revise 64 bit build options for VS2010.
-<br>
-
-<br>
-Mainly, there was come confusion between the WIN64 setting
-<br>
-for the type of build, and the BUILD_SYSTEM setting for
-<br>
-whether the system is 32 or 64 bit.
-<br>
-
-<br>
-NOTE: 64 bit builds on 32 bit systems do not work, and
-<br>
-I do not intend to attempt to make them work.
-<br>
-
-<br>
-Bug 692126
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/psi/msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-18 08:21:21 +0100></a>
-2011-05-18 08:21:21 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f9cf64f56577b593f424c7d661b5fb8ea7a53216">f9cf64f56577b593f424c7d661b5fb8ea7a53216</a>
-<blockquote>
-
-<br>
-Reinstate the Mememto build rules.....
-<br>
-
-<br>
-....that went AWOL with commit 447c1a791d28fb72b196f75356bc411ef45afbdd
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-17 23:43:14 -0700></a>
-2011-05-17 23:43:14 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=447c1a791d28fb72b196f75356bc411ef45afbdd">447c1a791d28fb72b196f75356bc411ef45afbdd</a>
-<blockquote>
-
-<br>
-Fix for MT crashes in lcms
-<br>
-
-<br>
-It turns out that lcms is can not safely share
-<br>
-profiles between threads when creating links. This
-<br>
-was fixed by placing a mutex lock around the profile
-<br>
-creation. It also turns out that lcms can not
-<br>
-use the same link to do transformations between threads.
-<br>
-This was solved by disabling the shared cache between
-<br>
-the threads. Finally there was a race condition in
-<br>
-reference counting the device ICC profile in the pdf14
-<br>
-device. Also, this commit includes a fix for a memory
-<br>
-leak in the pdf_mask object in gdevp14.
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gsicc_lcms.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gxcldev.h
-<br>
-gs/base/gxclthrd.c
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-17 22:33:15 +0100></a>
-2011-05-17 22:33: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=8d9bc767c0c59a7effa7652cbcbde14ab82de249">8d9bc767c0c59a7effa7652cbcbde14ab82de249</a>
-<blockquote>
-
-<br>
-Make Memento work with valgrind, plus fix unix build issues.
-<br>
-
-<br>
-Various fixes for Memento, most especially to ensure it works with
-<br>
-Valgrind (lots of valgrind calls to make memory readable/hide it again).
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/lib.mak
-<br>
-gs/base/memento.c
-<br>
-gs/base/memento.h
-<br>
-gs/base/unix-aux.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-17 15:29:53 -0400></a>
-2011-05-17 15:29:53 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cbe9dcfc93812aae26ffd5c2bebbe5b2dc1a4623">cbe9dcfc93812aae26ffd5c2bebbe5b2dc1a4623</a>
-<blockquote>
-
-<br>
-Bug 692209: tolerate missing /Length in PDF stream.
-<br>
-
-<br>
-Add branches that deal with a missing /Length attribute in the
-<br>
-PDF string directory. The sample file misspells /Length as /Lenght
-<br>
-but the patch addresses a more general problem.
-<br>
-
-<br>
-gs/Resource/Init/pdf_base.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-17 11:28:50 -0700></a>
-2011-05-17 11:28:50 -0700</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=784c8aa262a2a71659ce2d882c424e0254368a10">784c8aa262a2a71659ce2d882c424e0254368a10</a>
-<blockquote>
-
-<br>
-Fix ref counting for icc_array
-<br>
-
-<br>
-Copy the icc_array BEFORE putdeviceparams so we don't end up creating extra ones, and bump the shared icc_array.
-<br>
-
-<br>
-The finalize when the device is freed will decrement the ref count.
-<br>
-
-<br>
-gs/base/gxclthrd.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-17 18:13:17 +0100></a>
-2011-05-17 18:13: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=bc9c681b53babcab8d5e6bd102bfb0c51b8b7ed1">bc9c681b53babcab8d5e6bd102bfb0c51b8b7ed1</a>
-<blockquote>
-
-<br>
-Memento realloc fix.
-<br>
-
-<br>
-Memento was filling the 'new' section of realloced blocks incorrectly,
-<br>
-resulting in memory overwrites.
-<br>
-
-<br>
-CLUSTER_UNTESTED as Memento is not enabled by default.
-<br>
-
-<br>
-gs/base/memento.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-17 12:03:33 +0000></a>
-2011-05-17 12:03:33 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2b7e6a4174a58cf0c395e4950a428a722607f860">2b7e6a4174a58cf0c395e4950a428a722607f860</a>
-<blockquote>
-
-<br>
-Initial commit of new Memento module (attempt #2)
-<br>
-
-<br>
-Memento is a simple memory checking module; it helps to track memory
-<br>
-corruption and leaks. To use it, build with -DMEMENTO.
-<br>
-
-<br>
-Still to do: Valgrind integration.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/lib.mak
-<br>
-gs/base/malloc_.h
-<br>
-gs/base/memento.c
-<br>
-gs/base/memento.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-15 15:50:40 -0700></a>
-2011-05-15 15:50:40 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1787ce3393956701e6241b8efc6f575887c3f5c1">1787ce3393956701e6241b8efc6f575887c3f5c1</a>
-<blockquote>
-
-<br>
-Change in device ICC profile handling
-<br>
-
-<br>
-This is the major portion of the code needed to achieve object dependent
-<br>
-color management. This fixes the problems that existed in the
-<br>
-previous code with the device parameters and introduces an array of
-<br>
-ICC profiles in the device structure. The code was cluster pushed and
-<br>
-showed some very minor differences in a couple files but they appear to be
-<br>
-OK with bmpcmp. I still need to do further testing to verify that all the
-<br>
-functionality is correct (e.g. make sure setting the text profile properly
-<br>
-affects the text only). In addition, the rendering intent options need to be
-<br>
-implemented.
-<br>
-
-<br>
-I also need to check that nothing was broken with respect to MT
-<br>
-rendering and some of the devices that are not tested with cluster
-<br>
-pushing (e.g. the display device and the x11alpha device).
-<br>
-
-<br>
-gs/base/devs.mak
-<br>
-gs/base/gdevbit.c
-<br>
-gs/base/gdevnfwd.c
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gdevpdf.c
-<br>
-gs/base/gdevpdfk.c
-<br>
-gs/base/gdevpng.c
-<br>
-gs/base/gdevpsdi.c
-<br>
-gs/base/gdevtfnx.c
-<br>
-gs/base/gdevtsep.c
-<br>
-gs/base/gdevxini.c
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gscsepr.c
-<br>
-gs/base/gsdevice.c
-<br>
-gs/base/gsdparam.c
-<br>
-gs/base/gsequivc.c
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/base/gstrans.c
-<br>
-gs/base/gxclrast.c
-<br>
-gs/base/gxclthrd.c
-<br>
-gs/base/gxcmap.c
-<br>
-gs/base/gxdevcli.h
-<br>
-gs/base/gxdevice.h
-<br>
-gs/base/gxi12bit.c
-<br>
-gs/base/gxicolor.c
-<br>
-gs/base/gximag3x.c
-<br>
-gs/base/gximono.c
-<br>
-gs/base/gxiscale.c
-<br>
-gs/base/lib.mak
-<br>
-gs/psi/zdevice.c
-<br>
-gs/psi/zusparam.c
-<br>
-pcl/pctop.c
-<br>
-psi/psi.mak
-<br>
-psi/psitop.c
-<br>
-pxl/pxpthr.c
-<br>
-pxl/pxtop.c
-<br>
-svg/svgtop.c
-<br>
-xps/xpstop.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-13 10:52:18 -0700></a>
-2011-05-13 10:52:18 -0700</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c622f66846aa6b8124b1dffed7dbdaedabedd93f">c622f66846aa6b8124b1dffed7dbdaedabedd93f</a>
-<blockquote>
-
-<br>
-Modified clusterpush.pl to not rsync Makefiles
-<br>
-
-<br>
-Modified clusterpush.pl to not rsync Makefiles and config.log files.
-<br>
-Also removed the various files that have been moved to the cluster.git
-<br>
-repository.
-<br>
-
-<br>
-No expected cluster differences.
-<br>
-
-<br>
-gs/toolbin/localcluster/bmps2html.pl
-<br>
-gs/toolbin/localcluster/build.pl
-<br>
-gs/toolbin/localcluster/cachearchive.pl
-<br>
-gs/toolbin/localcluster/checkSize.pl
-<br>
-gs/toolbin/localcluster/clustermaster.pl
-<br>
-gs/toolbin/localcluster/clustermonitor.cgi
-<br>
-gs/toolbin/localcluster/clustermonitor.pl
-<br>
-gs/toolbin/localcluster/clusterpull.sh
-<br>
-gs/toolbin/localcluster/clusterpush.pl
-<br>
-gs/toolbin/localcluster/compare.pl
-<br>
-gs/toolbin/localcluster/comparerevs.pl
-<br>
-gs/toolbin/localcluster/dashboard.html
-<br>
-gs/toolbin/localcluster/nightly.pl
-<br>
-gs/toolbin/localcluster/pngs2html.pl
-<br>
-gs/toolbin/localcluster/readlog.pl
-<br>
-gs/toolbin/localcluster/readme
-<br>
-gs/toolbin/localcluster/run.pl
-<br>
-gs/toolbin/localcluster/setupcluster
-<br>
-gs/toolbin/localcluster/weekly.sh
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-13 09:42:41 -0700></a>
-2011-05-13 09:42:41 -0700</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7dcc68ce753175a9c686021d53a061253e2787c3">7dcc68ce753175a9c686021d53a061253e2787c3</a>
-<blockquote>
-
-<br>
-Modified math_.h to use our hypot().
-<br>
-
-<br>
-The system hypot() function gives slightly different results on Linux vs
-<br>
-Mac OS X systems for same input values. This minor difference results
-<br>
-in rendering variations in some files, confounding the regression
-<br>
-test system.
-<br>
-
-<br>
-This revision changes math_.h to use our hypot() in all cases instead
-<br>
-of the system one (previously our function was used on those platforms
-<br>
-where there was no system hypot() function).
-<br>
-
-<br>
-Testing by Robin shows that our function is faster than the system one,
-<br>
-so another reason to make this change.
-<br>
-
-<br>
-Fixes Bug 692197.
-<br>
-
-<br>
-Cluster differences on some nodes expected in:
-<br>
-
-<br>
-tests_private__pcl__pcl5ccet__28-10.BIN ppmraw
-<br>
-tests_private__pcl__pcl5ccet__32-01.BIN pbmraw
-<br>
-tests_private__pcl__pcl5cfts__fts.2210a pbmraw
-<br>
-tests_private__pcl__pcl5efts__fts.1810 ppmraw
-<br>
-tests_private__pcl__pcl5efts__fts.2132 pbmraw
-<br>
-tests_private__pcl__pcl5efts__fts.2291 pbmraw
-<br>
-tests_private__pcl__pcl5efts__fts.2350 pbmraw
-<br>
-
-<br>
-gs/base/math_.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-13 09:33:29 +0000></a>
-2011-05-13 09:33:29 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4bd5322f27e9b95716323bdd000e312418a59676">4bd5322f27e9b95716323bdd000e312418a59676</a>
-<blockquote>
-
-<br>
-Further tweak to lcms cached transforms.
-<br>
-
-<br>
-Use int comparisons rather than memcmp. No differences shown in cluster
-<br>
-testing.
-<br>
-
-<br>
-gs/lcms/src/cmsxform.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-12 23:14:47 +0000></a>
-2011-05-12 23:14:47 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3767ee67758778d00c9c5c879ade41fc9f41c83b">3767ee67758778d00c9c5c879ade41fc9f41c83b</a>
-<blockquote>
-
-<br>
-Simplify LCMS cached transform template.
-<br>
-
-<br>
-I'd overengineered the cached transform template code; the cache is
-<br>
-reset on every format change, so there is no need to check for that
-<br>
-in the transform function.
-<br>
-
-<br>
-No expected performance increase, but the code is less complex. No
-<br>
-differences seen in cluster testing. CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/lcms/src/cmsxform.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-12 17:57:55 +0100></a>
-2011-05-12 17:57: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=8bcf5d9dd0c4088a811f85121addb238c9240478">8bcf5d9dd0c4088a811f85121addb238c9240478</a>
-<blockquote>
-
-<br>
-Add new lcms source/header file to ghostscript.vcproj.
-<br>
-
-<br>
-No cluster differences as this isn't tested. CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/ghostscript.vcproj
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-12 16:06:08 +0000></a>
-2011-05-12 16:06:08 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d324305b11fd0bb399c868fe87b26cb768dc06c5">d324305b11fd0bb399c868fe87b26cb768dc06c5</a>
-<blockquote>
-
-<br>
-LCMS (v1) Optimisations for CachedXFORM etc.
-<br>
-
-<br>
-Optimise CachedXFORM (and related functions) by using a 'template' header
-<br>
-file and repeatedly including it with different options to generate
-<br>
-different specific versions of the code.
-<br>
-
-<br>
-This gives a 10% improvement on 568.40345_VO_nr_3_vpeSR18.xl (a file where
-<br>
-most of the time is spent in clipping).
-<br>
-
-<br>
-No expected cluster differences. I've just done a full test with a bmpcmp
-<br>
-and it showed no differences, but in light of what happened last time I
-<br>
-committed this, I am not going to use the magic rune to stop the cluster
-<br>
-rechecking it on commit.
-<br>
-
-<br>
-gs/base/lcms.mak
-<br>
-gs/lcms/include/lcms.h
-<br>
-gs/lcms/src/cmspack.c
-<br>
-gs/lcms/src/cmsxform.c
-<br>
-gs/lcms/src/cmsxform.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-12 15:08:01 +0100></a>
-2011-05-12 15:08: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=e79fff7a2b215103c795b74d4abe162bf8ca3486">e79fff7a2b215103c795b74d4abe162bf8ca3486</a>
-<blockquote>
-
-<br>
-Change PSI so -Z! works by default in debug builds.
-<br>
-
-<br>
-Previously, the -Z! option (to show the name of each PS operator as it is
-<br>
-executed) has only been available in DEBUG builds that specifically use
-<br>
-the DEBUG_TRACE_PS_OPERATORS option. This change ensures that it is available
-<br>
-in ALL debug builds, and in any release build where the
-<br>
-DEBUG_TRACE_PS_OPERATORS symbol is predefined.
-<br>
-
-<br>
-The reason for historically having it as a separate option was because
-<br>
-checking for whether the ! debug flag was set on every operator was felt
-<br>
-to be too large an overhead. I have arranged the code so that this overhead
-<br>
-is minimised now - in debug builds we only get the extra overhead when
-<br>
-the -Z! is specified on the command line.
-<br>
-
-<br>
-In normal release builds there is no change to the overhead. In release
-<br>
-builds with DEBUG_TRACE_PS_OPERATORS, the same overheads apply as in
-<br>
-DEBUG builds (that is a small additional overhead when -Z! is not used
-<br>
-and a larger one when it is).
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/psi/iinit.c
-<br>
-gs/psi/iinit.h
-<br>
-gs/psi/interp.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-11 15:39:06 -0600></a>
-2011-05-11 15:39:06 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7d77dabf5a1e24118455a5c0417ae75c5d5dcf60">7d77dabf5a1e24118455a5c0417ae75c5d5dcf60</a>
-<blockquote>
-
-<br>
-Fixes bug #689870 - add proper big endian number accessors.
-<br>
-
-<br>
-Previously only an unsigned accessor was provided and it was being
-<br>
-used to read both signed and unsigned quantities.
-<br>
-
-<br>
-gs/jbig2dec/jbig2.c
-<br>
-gs/jbig2dec/jbig2_halftone.c
-<br>
-gs/jbig2dec/jbig2_page.c
-<br>
-gs/jbig2dec/jbig2_priv.h
-<br>
-gs/jbig2dec/jbig2_segment.c
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c
-<br>
-gs/jbig2dec/jbig2_text.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-11 15:18:11 -0600></a>
-2011-05-11 15:18:11 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7c309e8a33333da3c124732bb6b00b0701e85579">7c309e8a33333da3c124732bb6b00b0701e85579</a>
-<blockquote>
-
-<br>
-Fixes 690889, potential null dereference.
-<br>
-
-<br>
-Prevent a theoretical (no test file) null dereference. There are
-<br>
-several of these cases identified by by static analysis. We believe
-<br>
-the authors intent was to pass the word stream if the arithmetic state
-<br>
-was not set, as in the other call of the same function.
-<br>
-
-<br>
-gs/jbig2dec/jbig2_symbol_dict.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-11 17:12:59 +0000></a>
-2011-05-11 17:12:59 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2bde8dc655c36ef729964980aa373c26dbe873e5">2bde8dc655c36ef729964980aa373c26dbe873e5</a>
-<blockquote>
-
-<br>
-Backout 6469f73 pending investigation of unexpected differences.
-<br>
-
-<br>
-gs/base/lcms.mak
-<br>
-gs/lcms/include/lcms.h
-<br>
-gs/lcms/src/cmspack.c
-<br>
-gs/lcms/src/cmsxform.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-11 16:17:05 +0000></a>
-2011-05-11 16:17:05 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6469f738123e0c212473f11d38e88bb3650a9087">6469f738123e0c212473f11d38e88bb3650a9087</a>
-<blockquote>
-
-<br>
-LCMS (v1) optimisations for CachedXFORM etc.
-<br>
-
-<br>
-Optimise CachedXFORM (and related functions) by using a 'template' header
-<br>
-file and repeatedly including it with different options to generate
-<br>
-different specific versions of the code.
-<br>
-
-<br>
-This gives a 10% improvement on 568.40345_VO_nr_3_vpeSR18.xl (a file where
-<br>
-most of the time is spent in clipping).
-<br>
-
-<br>
-No expected cluster differences.
-<br>
-
-<br>
-gs/base/lcms.mak
-<br>
-gs/lcms/include/lcms.h
-<br>
-gs/lcms/src/cmspack.c
-<br>
-gs/lcms/src/cmsxform.c
-<br>
-gs/lcms/src/cmsxform.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-02 19:50:04 +0100></a>
-2011-05-02 19:50:04 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1d07f53add51362ce5887b599f2dcb360f9cf348">1d07f53add51362ce5887b599f2dcb360f9cf348</a>
-<blockquote>
-
-<br>
-Pacify valgrind (and improve performance?) with tiny change.
-<br>
-
-<br>
-A tiny change to gxclrast.c where we initialise state_tile.size.{x,y}.
-<br>
-This stops valgrind giving warnings. While the code works OK without
-<br>
-this (I believe), it can cause various %, /, gcd operations. These are
-<br>
-all expensive operations and are neatly sidestepped by the simple
-<br>
-expedient of setting the variable to 0 to start with.
-<br>
-
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-10 19:29:49 +0100></a>
-2011-05-10 19:29:49 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6f6de913f2f20914ed641a0331e405011d6565b">f6f6de913f2f20914ed641a0331e405011d6565b</a>
-<blockquote>
-
-<br>
-Add LAND_BITS define to landscape mono halftoning code.
-<br>
-
-<br>
-The monochrome halftone thresholding code relies on collating incoming
-<br>
-scanline data into 'scancolumn' buffers. When we have 16 bytes in these
-<br>
-buffers, they halftoned and flushed through copy_mono.
-<br>
-
-<br>
-copy_mono would prefer to work with longer than 16 byte runs, so we
-<br>
-remove the hardcoded 16s from throughout the code and replace it with
-<br>
-a #defined value. A side effect of this is that the code becomes
-<br>
-slightly clearer.
-<br>
-
-<br>
-Sadly, it seems this doesn't give the expected speedups; testing here
-<br>
-indicates that both 32 and 128 run slower, possibly due to cache effects.
-<br>
-
-<br>
-Nonetheless we commit the code in case inspiration strikes us later on.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gsiparam.h
-<br>
-gs/base/gxht_thresh.c
-<br>
-gs/base/gximono.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-10 19:24:55 +0100></a>
-2011-05-10 19:24: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=21cfb2e3b6c0d15c84b748586c51969daae58345">21cfb2e3b6c0d15c84b748586c51969daae58345</a>
-<blockquote>
-
-<br>
-LCMS performance tweak; ToFixedDomain/FromFixedDomain.
-<br>
-
-<br>
-Make ToFixedDomain/FromFixedDomains #defines rather than inline functions.
-<br>
-MSVC doesn't inline them, and they are used in speed critical areas.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/lcms/include/lcms.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-02 18:53:00 +0100></a>
-2011-05-02 18:53:00 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=eef6a4d712a79a5f8d5f48f43c2572d5f002fc38">eef6a4d712a79a5f8d5f48f43c2572d5f002fc38</a>
-<blockquote>
-
-<br>
-Quiet valgrind warning, and remove misleading init.
-<br>
-
-<br>
-Cherry picked from patt_trans_clist branch to fix bug 692138.
-<br>
-
-<br>
-When run with valgrind on:
-<br>
-
-<br>
-gs -sDEVICE=pbmraw -r300 -dMaxBitmap=100000000 -o out.pbm Bug690189c.pdf
-<br>
-
-<br>
-Valgrind complains that params.GrayBackground is used without being
-<br>
-initialised. We fix this here by amending gs_trans_mask_params_init.
-<br>
-
-<br>
-In so doing, we note that in zbegintransparencymaskgroup we were setting
-<br>
-params.ColorSpace, only to call gs_trans_mask_params_init and have it
-<br>
-overwrite it. To avoid confusion we therefore remove this needless init.
-<br>
-
-<br>
-No cluster differences seen in testing.
-<br>
-
-<br>
-gs/base/gstrans.c
-<br>
-gs/psi/ztrans.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-10 09:16:17 +0000></a>
-2011-05-10 09:16:17 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1cf87e28636a4922505e9c486b59e64c857717f">b1cf87e28636a4922505e9c486b59e64c857717f</a>
-<blockquote>
-
-<br>
-Optimisations for mem_mono_strip_copy_rop_dev.
-<br>
-
-<br>
-Now that mem_mono_strip_copy_rop_dev is working reliably, cut out the
-<br>
-excess debugging code so we can see the wood for the trees.
-<br>
-
-<br>
-To cope with situations where we get narrow texture tiles, reinstate the
-<br>
-old code (as rop_run relies on longer runs to get traction). Add new cases
-<br>
-for no-textures to avoid nested loops etc.
-<br>
-
-<br>
-This all seems to help with the performance of cicero_call.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gdevm1.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-10 08:39:19 +0000></a>
-2011-05-10 08:39:19 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2429ef51f12477d083bfcd3f15f97f90bb653b52">2429ef51f12477d083bfcd3f15f97f90bb653b52</a>
-<blockquote>
-
-<br>
-Optimisations to gximono.c; special case the spp_out == 1 case.
-<br>
-
-<br>
-Simple optimisations to the hotspots in image_render_mono_ht.
-<br>
-
-<br>
-No real differences seen in cluster testing.
-<br>
-
-<br>
-gs/base/gximono.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-09 23:46:09 +0000></a>
-2011-05-09 23:46:09 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bf8d753f7346c0c97bd4109f0684993ab0a46041">bf8d753f7346c0c97bd4109f0684993ab0a46041</a>
-<blockquote>
-
-<br>
-New gxdda.h formulation.
-<br>
-
-<br>
-Rejig the gxdda macros slightly. We store more 'natural' values internally
-<br>
-and get code that optimises slightly better.
-<br>
-
-<br>
-No differences expected in cluster testing (1 SEGV shown in my testing, but
-<br>
-I think that's random).
-<br>
-
-<br>
-gs/base/gxdda.h
-<br>
-gs/base/gxi12bit.c
-<br>
-gs/base/sidscale.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-10 00:21:21 -0400></a>
-2011-05-10 00:21:21 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0f5928344123e31229d31eb81e3f09b528170e38">0f5928344123e31229d31eb81e3f09b528170e38</a>
-<blockquote>
-
-<br>
-Execute linkdest procedure in a stopped context to trap errors caused
-<br>
-by out-of-range link destinations that can occur in an invalid files or
-<br>
-during processing of a page range. Bug 692200.
-<br>
-
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-09 14:47:48 -0600></a>
-2011-05-09 14:47:48 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=df4e669177f7757a5c054084f4990599bef5c355">df4e669177f7757a5c054084f4990599bef5c355</a>
-<blockquote>
-
-<br>
-Remove unused file should have been committed with e55d362f.
-<br>
-
-<br>
-gs/base/gsnorop.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-09 13:16:31 -0600></a>
-2011-05-09 13:16:31 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e55d362f3370b4bff0d72dc58c4b7a08b0dba71a">e55d362f3370b4bff0d72dc58c4b7a08b0dba71a</a>
-<blockquote>
-
-<br>
-Incorporate raster operation library into the core graphics library.
-<br>
-
-<br>
-We were going to fold the roblib in for simplicity, more recently
-<br>
-the graphics library code has been refactored such that the raster op
-<br>
-library is always required. For example operations previously done in
-<br>
-the copy_mono code are now done with the raster op code.
-<br>
-
-<br>
-CLUSTER_UNTESTED
-<br>
-
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/lib.mak
-<br>
-gs/base/msvclib.mak
-<br>
-gs/base/ugcclib.mak
-<br>
-language_switch/pspcl6_gcc.mak
-<br>
-language_switch/pspcl6_msvc.mak
-<br>
-main/pcl6_gcc.mak
-<br>
-main/pcl6_msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-05 16:16:22 +0100></a>
-2011-05-05 16:16:22 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=60d4b088c6d314079643a92a3c4e983b116600a9">60d4b088c6d314079643a92a3c4e983b116600a9</a>
-<blockquote>
-
-<br>
-Use defined default page size for nullpage device.
-<br>
-
-<br>
- The nullpage device previously used a 1&quot;x1&quot; default page size, this changes it
-<br>
-to use the same default setting as other page devices (this can be Letter or
-<br>
-A4, set in a makefile).
-<br>
-
-<br>
-Also, add some lower bounds checking to gslp.ps so that it will error out if
-<br>
-the page size is too small to hold at least one line of text.
-<br>
-
-<br>
-No cluster difference expected.
-<br>
-
-<br>
-gs/base/gdevnfwd.c
-<br>
-gs/lib/gslp.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-08 11:26:15 -0700></a>
-2011-05-08 11:26:15 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c677c48f278aba56d45bf2601ed5d152287540f1">c677c48f278aba56d45bf2601ed5d152287540f1</a>
-<blockquote>
-
-<br>
-Fix for compiler warning
-<br>
-
-<br>
-gs/base/gsdevice.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-07 23:21:38 -0700></a>
-2011-05-07 23:21:38 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b1d311f06250a07d4c360e67369980d199722694">b1d311f06250a07d4c360e67369980d199722694</a>
-<blockquote>
-
-<br>
-Significant change in how the device profile is handled in ghostscript. This
-<br>
-change adds in a new device procedure called get_profile, which is going to
-<br>
-typically be set to gx_forward_get_profile or gx_default_get_profile. Most
-<br>
-internal devices like the pattern accumulator, the clip device, memory devices,
-<br>
-will use the gx_forward_get_profile procedure. In this way, the profile is
-<br>
-typically only maintained by the the target device. The gdevp14 device is the significant internal device that takes special handling due to the way that it
-<br>
-can change its ICC profile based upon the current transparency group color space. The get_profile procedure also passes along information about the object
-<br>
-type so that we will be able to easily add in the device dependent color
-<br>
-management. The rendering intent, which can also be object dependent is also returned by the call. This change has been cluster tested and showed no differences.
-<br>
-
-<br>
-gs/base/gdevbit.c
-<br>
-gs/base/gdevdflt.c
-<br>
-gs/base/gdevmem.c
-<br>
-gs/base/gdevnfwd.c
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gdevprn.c
-<br>
-gs/base/gdevrops.c
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gscsepr.c
-<br>
-gs/base/gsdevice.c
-<br>
-gs/base/gsequivc.c
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gstrans.c
-<br>
-gs/base/gxccman.c
-<br>
-gs/base/gxclip.c
-<br>
-gs/base/gxclipm.c
-<br>
-gs/base/gxclist.c
-<br>
-gs/base/gxcmap.c
-<br>
-gs/base/gxcmap.h
-<br>
-gs/base/gxdevcli.h
-<br>
-gs/base/gxdevice.h
-<br>
-gs/base/gxi12bit.c
-<br>
-gs/base/gxicolor.c
-<br>
-gs/base/gximag3x.c
-<br>
-gs/base/gximono.c
-<br>
-gs/base/gxiscale.c
-<br>
-gs/base/gxpcmap.c
-<br>
-gs/contrib/opvp/gdevopvp.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-06 08:57:07 -0400></a>
-2011-05-06 08:57:07 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a065765cd3529d17ba687954d8f4deacd8319247">a065765cd3529d17ba687954d8f4deacd8319247</a>
-<blockquote>
-
-<br>
-Add a missing check of the return value from runarg(). Bug 692189.
-<br>
-
-<br>
-gs/psi/imainarg.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-06 01:13:51 -0400></a>
-2011-05-06 01:13:51 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2822d8a9f4186aa14f3913258841b74ff87309cf">2822d8a9f4186aa14f3913258841b74ff87309cf</a>
-<blockquote>
-
-<br>
-Check the type of /File and /Length attributes during XForm identification
-<br>
-to avoud confusion with appearance subdictionary, which can include any
-<br>
-attributes (including /File or /Length) pointing to a dictionary. Bug 692192.
-<br>
-
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-04 15:38:22 +0000></a>
-2011-05-04 15:38:22 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2756e4d6160f73af7bf5ed913af207914aeee588">2756e4d6160f73af7bf5ed913af207914aeee588</a>
-<blockquote>
-
-<br>
-Invert bmpcmps reading of cups files.
-<br>
-
-<br>
-I had black <-> white. Easy fix.
-<br>
-
-<br>
-gs/toolbin/bmpcmp.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-04 15:08:36 +0100></a>
-2011-05-04 15:08: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=e97bf09450c5a08b591e0fca4ef59a21fb78b6ef">e97bf09450c5a08b591e0fca4ef59a21fb78b6ef</a>
-<blockquote>
-
-<br>
-Fix bmpcmp to read cups colorspace=0 files too.
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/toolbin/bmpcmp.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-04 00:45:28 -0400></a>
-2011-05-04 00:45:28 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2f0b609805f1abf42b4b10dd721d9fef3001a847">2f0b609805f1abf42b4b10dd721d9fef3001a847</a>
-<blockquote>
-
-<br>
-Accept and skip any number of whitespace characters (including
-<br>
-just spaces) after the entry count in the xref table. Remove /lineeq
-<br>
-and /linene procedures that are no longer used. Bug 692177.
-<br>
-
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-03 08:58:18 -0600></a>
-2011-05-03 08:58:18 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=af70515f6dcd1ffae90250697325fee224182e17">af70515f6dcd1ffae90250697325fee224182e17</a>
-<blockquote>
-
-<br>
-Retain or bias the reference count of the rop texture device.
-<br>
-
-<br>
-The image code was using the rop texture device without any reference
-<br>
-counting, explicitly freeing the device when it was done. That was
-<br>
-fine if the device was the only device in the chain, however, linking
-<br>
-in other devices could lead indirectly to unintended freeing of the
-<br>
-rop device. A crash was seen in the the XL test file C705.BIN but
-<br>
-only with halftoning at particular resolutions like 72 dpi. We did
-<br>
-not study why the crash was limited to particular resolutions and
-<br>
-devices.
-<br>
-
-<br>
-gs/base/gxipixel.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-03 17:45:45 +0100></a>
-2011-05-03 17:45:45 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=afcbace446526e29bae11ce53bac5769a409e56f">afcbace446526e29bae11ce53bac5769a409e56f</a>
-<blockquote>
-
-<br>
-Add gx_device_dump debugging function.
-<br>
-
-<br>
-In DEBUG builds gx_device_dump(gx_device *dev, char *text); prints a
-<br>
-recursive listing of devices, their refcounts and names, and targets.
-<br>
-
-<br>
-If anyone spots a forwarding device this doesn't work with, please let me
-<br>
-know.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gdevnfwd.c
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gxdevcli.h
-<br>
-gs/base/gxdevsop.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-03 16:39:13 +0000></a>
-2011-05-03 16:39:13 +0000</strong>
-<br>Robin Watts &lt;robin@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6d5e2bde4fe7a42bdd631fb0756f4fafc460ec41">6d5e2bde4fe7a42bdd631fb0756f4fafc460ec41</a>
-<blockquote>
-
-<br>
-Fix copy_plane; was always copying into plane 0.
-<br>
-
-<br>
-When writing copy_plane, I had neglected to offset into the data
-<br>
-according to the plane required.
-<br>
-
-<br>
-CLUSTER_UNTESTED.
-<br>
-
-<br>
-gs/base/gdevmpla.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-02 14:51:26 +0100></a>
-2011-05-02 14:51:26 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a78476dd0be85f69885f2614be5ab614b03c9168">a78476dd0be85f69885f2614be5ab614b03c9168</a>
-<blockquote>
-
-<br>
-Add support for cups (1bpp) files to bmpcmp.
-<br>
-
-<br>
-gs/toolbin/bmpcmp.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-02 20:41:12 +0100></a>
-2011-05-02 20:41: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=cc3562ce331bc45a89cebd49c91e10149b5a90b2">cc3562ce331bc45a89cebd49c91e10149b5a90b2</a>
-<blockquote>
-
-<br>
-Solve windows debug build crash on exit with cups device.
-<br>
-
-<br>
-It seems that the cups device takes it upon itself to close the output file
-<br>
-rather than leaving it for the ghostscript core to close as every other
-<br>
-device does. This upsets the windows DLL file handling.
-<br>
-
-<br>
-The solution is simply to remove the lines that close the file. I've
-<br>
-checked both with Till and Ken, and they concur. Thanks.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/cups/gdevcups.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-05-02 14:32:18 +0100></a>
-2011-05-02 14:32: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=e784a5443d0bee380d1ad32055ad3075e3aa0995">e784a5443d0bee380d1ad32055ad3075e3aa0995</a>
-<blockquote>
-
-<br>
-Change error return to remove confusion over meaning.
-<br>
-
-<br>
-When we encounter a font whose charstring has been replaced with a PS
-<br>
-procedure, we were returning FT_Err_Invalid_File_Format, and using that
-<br>
-as a hint we should try to execute it as a PS procedure. This
-<br>
-turns out to be problematic as it is also the error return generated by
-<br>
-Freetype for an invalid charstring. In the case of an invalid charstring
-<br>
-we should fall back to the notdef, not attempt to execute the object as
-<br>
-Postscript.
-<br>
-
-<br>
-So, change the error return value that *we* generate, and subsequently
-<br>
-check for, to FT_Err_Unknown_File_Format, which FT should never,
-<br>
-normally, generate during glyph interpretation. This means, in this
-<br>
-case, we correctly identify a failed attempt to interpret a charstring,
-<br>
-and use the notdef fallback - instead of, eventually, throwing an
-<br>
-error.
-<br>
-
-<br>
-Bug 692176.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/psi/fapi_ft.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-30 19:01:53 +0100></a>
-2011-04-30 19:01:53 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5091054103f3b07bbae8ab2fc75e6c6cc3fd7a86">5091054103f3b07bbae8ab2fc75e6c6cc3fd7a86</a>
-<blockquote>
-
-<br>
-Remove unused variable.
-<br>
-
-<br>
-gs/base/gdevpng.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-30 18:11:47 +0100></a>
-2011-04-30 18:11:47 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dcae57315a683272c799545783694c43545b6fe0">dcae57315a683272c799545783694c43545b6fe0</a>
-<blockquote>
-
-<br>
-Fix PNG device error when no downscale specified.
-<br>
-
-<br>
-When I introduced the downscaling to selected png devices, I neglected to
-<br>
-set a sensible default value for downscale factor. This means that if you
-<br>
-attempt to set any device parameters, without specifying -dDownScaleFactor
-<br>
-then you get a rangecheck error. This commit fixes that.
-<br>
-
-<br>
-No cluster changes expected.
-<br>
-
-<br>
-gs/base/gdevpng.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-30 08:38:31 -0400></a>
-2011-04-30 08:38:31 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c98ade33d2b8fbc0ca6579c6d9e0ceb425374b0c">c98ade33d2b8fbc0ca6579c6d9e0ceb425374b0c</a>
-<blockquote>
-
-<br>
-Normalize pattern /BBox in PDF interpreter before passing it to PS
-<br>
-to avoid a /rangecheck error. Bug 692174.
-<br>
-
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-27 22:27:39 -0700></a>
-2011-04-27 22:27: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=b128a1424550b3462348bd40ecd768356cdb08ae">b128a1424550b3462348bd40ecd768356cdb08ae</a>
-<blockquote>
-
-<br>
-Fix for reference counting issue of the compositor device at
-<br>
-the end of the clist playback. In most cases, the compositor rc
-<br>
-should be 1 at this point and so the device is closed and then
-<br>
-freed. The case, when it is not 1 is when we have a pattern
-<br>
-that has a transparency and is stored in a clist. In this case
-<br>
-the target for the pattern clist device is the main pdf14 device and
-<br>
-we increment the rc during this assignment. So, when the
-<br>
-playback completes, the rc of the compositor is 2. We do not
-<br>
-want to close and free the compositor, since it is part of the
-<br>
-main clist that we have going on. Instead we only want to
-<br>
-decrement the rc. The test file pattrans_big.pdf is now
-<br>
-handled correctly but has a rendering/tiling issue it appears.
-<br>
-
-<br>
-This commit (from the patt_trans_clist_branch) has been cherry-picked
-<br>
-to the trunk to solve the SEGV in bug #692160. This leaves pdf14
-<br>
-compositors leaking though.
-<br>
-
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-28 20:23:29 +0100></a>
-2011-04-28 20:23:29 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1553ea878b414b4ac389f7cec4c2076bc52be966">1553ea878b414b4ac389f7cec4c2076bc52be966</a>
-<blockquote>
-
-<br>
-Stop compiler turning for loop into memset in halftoning code.
-<br>
-
-<br>
-The msvc compiler cleverly spots that a for loop can be turned
-<br>
-into a memset. Unfortunately it can't know that the values for
-<br>
-which the loop is called are normally so small that the calling
-<br>
-of the function costs more than simply doing the stores.
-<br>
-
-<br>
-The fix is to cast the pointer to which we are storing to be
-<br>
-volatile. This saves a significant chunk of runtime for:
-<br>
-
-<br>
-pcl6.exe -sDEVICE=bit -r600 -o null: -dLeadingEdge=3
-<br>
-cicero_call_CRF03-all-in_adobe-8_358p_xNuv288.xl
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/gxht_thresh.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-28 17:19:14 +0100></a>
-2011-04-28 17:19:14 +0100</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=dd0ead1acfd2cf2fea4e417afdd4b52b06d8c3ad">dd0ead1acfd2cf2fea4e417afdd4b52b06d8c3ad</a>
-<blockquote>
-
-<br>
-Ensure optimization flags get propogated for lcms
-<br>
-
-<br>
-An inconcistency between definitions in the Unix and Windows builds meant
-<br>
-that on Windows several compiler flags (including that for optimization)
-<br>
-was not being used when buliding the lcms source files. The confusion
-<br>
-stems from Ghostscript requiring /Za to compile, and lcms failing to
-<br>
-compile with /Za.
-<br>
-
-<br>
-Bug 692173.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/msvccmd.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-28 16:20:38 +0100></a>
-2011-04-28 16:20: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=98a891175a74e4fdbdd2b5dc10a7fa60b9f75e16">98a891175a74e4fdbdd2b5dc10a7fa60b9f75e16</a>
-<blockquote>
-
-<br>
-Add special case runrops for rops 0xF0 and CC (copy S and copy T).
-<br>
-
-<br>
-This is in response to Norberts complaints about the speed of 9.02 with
-<br>
-cicero_call_CRF03-all-in_adobe-8_358p_xNuv288.xl and others.
-<br>
-
-<br>
-gs/base/gsroprun.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-28 09:01:05 +0100></a>
-2011-04-28 09:01: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=26e55117205eaf76dfa6011c29e287f84ec99799">26e55117205eaf76dfa6011c29e287f84ec99799</a>
-<blockquote>
-
-<br>
-Change to include psi/ierrors.h.
-<br>
-
-<br>
-psitop.c previously included the deprecated header file base/errors.h
-<br>
-which has now been removed. psi/ierrors.h is the correct header to
-<br>
-include.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-psi/psitop.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-28 08:10:39 +0100></a>
-2011-04-28 08:10: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=7132af8bb76824feb241374cf152349995b6cc10">7132af8bb76824feb241374cf152349995b6cc10</a>
-<blockquote>
-
-<br>
-Remove the deprecated errors.h file.
-<br>
-
-<br>
-Related to Bug 692151 in that it rendered the bug invalid.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-gs/base/errors.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-25 18:58:52 -0600></a>
-2011-04-25 18:58: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=0361e41b57f8f4d798eb42e6320e6e96c355169d">0361e41b57f8f4d798eb42e6320e6e96c355169d</a>
-<blockquote>
-
-<br>
-PJL filesystem commands can be made static.
-<br>
-
-<br>
-Warning cleanup - make local functions static.
-<br>
-
-<br>
- Use %s if the argument is not literal to address the warning &quot;format
-<br>
- not a string literal and no format arguments&quot;.
-<br>
-
-<br>
-Presumably a format specifier could appear in the character array
-<br>
-resulting in an argument mismatch.
-<br>
-
-<br>
-pl/pjparse.c
-<br>
-pl/pjparsei.c
-<br>
-pl/plmain.c
-<br>
-pxl/pxtop.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-25 17:53:50 -0600></a>
-2011-04-25 17:53:50 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=732dc98f92f2132f21811cf8b2612c1091e65050">732dc98f92f2132f21811cf8b2612c1091e65050</a>
-<blockquote>
-
-<br>
-Partially refactor image api so it can be shared between pcl and pxl,
-<br>
-also to move away from using the obsolete image api.
-<br>
-
-<br>
-pl/pldraw.c
-<br>
-pl/pldraw.h
-<br>
-pxl/pximage.c
-<br>
-pxl/pxink.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-26 19:20:25 +0100></a>
-2011-04-26 19:20:25 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=262c866a71d08c1709484d95ffb3639f53156078">262c866a71d08c1709484d95ffb3639f53156078</a>
-<blockquote>
-
-<br>
-Fix for bug 692081. Antialiasing patterns results in white holes.
-<br>
-
-<br>
-gx_default_copy_alpha simulates alpha by weighted average of RGB values.
-<br>
-When the alpha value is zero, the current implementation reads the current
-<br>
-background value, and just writes it back. This has the effect of making
-<br>
-any device that watches what devices get written to think that that pixel
-<br>
-is solid. (One such device is the pattern tile device where it collects what
-<br>
-pixels have been marked, and what haven't).
-<br>
-
-<br>
-The CORRECT way to do this is to stop the line accumulation at that point,
-<br>
-flush everything to there, then start again a pixel later.
-<br>
-
-<br>
-Doing this solves the bug, and causes no cluster changes.
-<br>
-
-<br>
-gs/base/gdevdbit.c
-<br>
-gs/base/gxcindex.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-26 12:37:14 +0100></a>
-2011-04-26 12:37:14 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=11b5fb512393a6e9d9bdf6c076dc388ebd8c7c3f">11b5fb512393a6e9d9bdf6c076dc388ebd8c7c3f</a>
-<blockquote>
-
-<br>
-Fix warnings (unused variables and missing cases in switches).
-<br>
-
-<br>
-gs/base/gdevddrw.c
-<br>
-gs/base/gstrans.c
-<br>
-gs/base/gxblend1.c
-<br>
-gs/base/gxiscale.c
-<br>
-gs/base/gxstroke.c
-<br>
-gs/psi/zicc.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-26 10:34:46 +0100></a>
-2011-04-26 10:34:46 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a349c53ca01df5e425f25d1fa14d38c43d95b60c">a349c53ca01df5e425f25d1fa14d38c43d95b60c</a>
-<blockquote>
-
-<br>
-Removed unused variables to quiet warnings.
-<br>
-
-<br>
-gs/base/gdevtifs.c
-<br>
-gs/base/gxdownscale.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-25 22:56:41 -0700></a>
-2011-04-25 22:56:41 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=79e14a10307ba37bcf00af1b05c1c52875d9774a">79e14a10307ba37bcf00af1b05c1c52875d9774a</a>
-<blockquote>
-
-<br>
-Fix for multithreaded rendering crash that can occur due to race conditions between threads with the increment and decrement of the icc link cache object during the rendering of the bands. Fix involved place a lock around the operations. Thanks to Ray for helping with this.
-<br>
-
-<br>
-gs/base/gxclrast.c
-<br>
-gs/base/gxclthrd.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-25 17:37:09 -0700></a>
-2011-04-25 17:37:09 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=03cb94a9da2cddd2b7055e8565dd797c67bf56f4">03cb94a9da2cddd2b7055e8565dd797c67bf56f4</a>
-<blockquote>
-
-<br>
-Fix for memory leak in gdevp14 device. This involved making sure the overprint compositor was initialized retained with a ref count of 1 like the pdf14 device.
-<br>
-
-<br>
-gs/base/gsovrc.c
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-26 00:53:07 +0100></a>
-2011-04-26 00:53: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=16789dc892db636719383c2542aa9cec04092e4d">16789dc892db636719383c2542aa9cec04092e4d</a>
-<blockquote>
-
-<br>
-Fix memory overwrite in png devices.
-<br>
-
-<br>
-In my fiddling with the png devices the other day to add downscaling, I
-<br>
-omitted to extend the size of two of them (png16m and png48). This meant
-<br>
-that png16m was overwriting 8 bytes of memory after its device structure.
-<br>
-
-<br>
-Fix this to solve a SEGV when DownScaleFactor is used.
-<br>
-
-<br>
-gs/base/gdevpng.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-24 20:35:45 -0400></a>
-2011-04-24 20:35:45 -0400</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f5a6de969ae67a2318115c5e8e6e2b3b06fc58f3">f5a6de969ae67a2318115c5e8e6e2b3b06fc58f3</a>
-<blockquote>
-
-<br>
-Split large beginbfrange..endbfrange blocks in ToUnicode CMaps into
-<br>
- speed up operand stack manipulation, esp. &quot;counttomark -3 roll&quot;. Bug 691908.
-<br>
-
-<br>
-gs/Resource/Init/pdf_font.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-25 09:31:32 -0600></a>
-2011-04-25 09:31:32 -0600</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3b66709cafd05910f2442250e12d1918f239c34b">3b66709cafd05910f2442250e12d1918f239c34b</a>
-<blockquote>
-
-<br>
-The new custom paper size implementation introduced a bug in
-<br>
-passthrough mode requiring additional state setup when we switch from
-<br>
-PXL to PCL state.
-<br>
-
-<br>
-pcl/pcpage.c
-<br>
-pxl/pxpthr.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-22 15:40:50 -0600></a>
-2011-04-22 15:40:50 -0600</strong>
-<br>henrys &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=460ff495a31f8a87d0ed677eed2660fca79369fc">460ff495a31f8a87d0ed677eed2660fca79369fc</a>
-<blockquote>
-
-<br>
-Revision 43a5362 modified a global variable. We address that by
-<br>
-making the page table a dynamic member of the pcl state.
-<br>
-
-<br>
-pcl/pcommand.c
-<br>
-pcl/pcpage.c
-<br>
-pcl/pcstate.h
-<br>
-pcl/pcxfmst.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-20 23:25:50 -0600></a>
-2011-04-20 23:25:50 -0600</strong>
-<br>henrys &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=e5a9f968265abc47a85811e620c79bedf87b1da0">e5a9f968265abc47a85811e620c79bedf87b1da0</a>
-<blockquote>
-
-<br>
-Josef Hinteregger's patch to implement custom paper sizes in PJL and PCL,
-<br>
-bug #691587.
-<br>
-
-<br>
-pcl/pcpage.c
-<br>
-pl/pjparse.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-20 23:20:34 -0700></a>
-2011-04-20 23:20:34 -0700</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4ddefa258ee17e359429c901ef8a0a8f3b234083">4ddefa258ee17e359429c901ef8a0a8f3b234083</a>
-<blockquote>
-
-<br>
-Fix to stop reset of ICC profile directory to the default directory (which is the romfs) when there is a VMreclaim. Previously if the VMreclaim happens while we are still in the process of initializing the icc manager this can cause a crash. This was the source of the crash with the tiffsep device when COMPILE_INITS=0.
-<br>
-
-<br>
-gs/base/gsicc_manage.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-22 18:08:10 +0100></a>
-2011-04-22 18:08:10 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1b3908faa01c7ef6197374a27b1a5861f0a383fe">1b3908faa01c7ef6197374a27b1a5861f0a383fe</a>
-<blockquote>
-
-<br>
-Extend downscaling to png devices too (from tiffscaled).
-<br>
-
-<br>
-Extract the code to do downscaling/min feature size from tiffscaled{,8,24}
-<br>
-into a new gx_downscaler class. Make tiffscaled{,8,24} call this new class
-<br>
-with no change in functionality.
-<br>
-
-<br>
-Make png devices call this new code. Only png16m and pnggray are actually
-<br>
-affected by downscaling though. Add a new pngmonod device to do grayscale
-<br>
-rendering internally and to downscale/min_feature_size/error diffuse to
-<br>
-monochrome.
-<br>
-
-<br>
-gs/base/devs.mak
-<br>
-gs/base/gdevpng.c
-<br>
-gs/base/gdevprn.c
-<br>
-gs/base/gdevtifs.c
-<br>
-gs/base/gxdownscale.c
-<br>
-gs/base/gxdownscale.h
-<br>
-gs/base/lib.mak
-<br>
-gs/base/macos-mcp.mak
-<br>
-gs/base/macosx.mak
-<br>
-gs/base/openvms.mak
-<br>
-gs/base/unix-gcc.mak
-<br>
-gs/base/unixansi.mak
-<br>
-gs/doc/Devices.htm
-<br>
-gs/ghostscript.vcproj
-<br>
-gs/psi/msvc.mak
-<br>
-gs/psi/os2.mak
-<br>
-main/pcl6_gcc.mak
-<br>
-main/pcl6_msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-20 10:40:58 -0700></a>
-2011-04-20 10:40:58 -0700</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8a203b909d59f8aa649492c23fa570afe3a61565">8a203b909d59f8aa649492c23fa570afe3a61565</a>
-<blockquote>
-
-<br>
-Revert of a4c4877b35b6782ef64b382713eaa6bcd4eca8d6 since we decided to rename the directories back to their before svn => git transition names.
-<br>
-
-<br>
-gs/toolbin/localcluster/clusterpush.pl
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-20 09:17:25 -0700></a>
-2011-04-20 09:17:25 -0700</strong>
-<br>mvrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=20b6c78ff6fb123bc11a068ca329a96d2452b529">20b6c78ff6fb123bc11a068ca329a96d2452b529</a>
-<blockquote>
-
-<br>
-Fix for issue when creating ICC profiles from DEF/G structures. As a few progressions and fixes bug 692156 and likely bug 691977
-<br>
-
-<br>
-gs/base/gsicc_create.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-19 21:23:01 -0700></a>
-2011-04-19 21:23:01 -0700</strong>
-<br>Marcos H. Woehrmann &lt;marcos.woehrmann@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a4c4877b35b6782ef64b382713eaa6bcd4eca8d6">a4c4877b35b6782ef64b382713eaa6bcd4eca8d6</a>
-<blockquote>
-
-<br>
-Modified clusterpush.pl to account for the new directory structure introduced with the svn => git transition.
-<br>
-
-<br>
-gs/toolbin/localcluster/clusterpush.pl
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-20 14:56:12 +0100></a>
-2011-04-20 14:56: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=0f57eacebce435c7da518b2d17638036a3ae5a40">0f57eacebce435c7da518b2d17638036a3ae5a40</a>
-<blockquote>
-
-<br>
-Add bin directories to .gitignore file.
-<br>
-
-<br>
-Also add some comments with useful lines that people might want to copy
-<br>
-to their local .git/info/exclude file.
-<br>
-
-<br>
-.gitignore
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-20 14:46:26 +0100></a>
-2011-04-20 14:46:26 +0100</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c10532c1b2e63dd6d6d95f1a0b578eb865ff4d9a">c10532c1b2e63dd6d6d95f1a0b578eb865ff4d9a</a>
-<blockquote>
-
-<br>
-New tiffscaled8 and tiffscaled24 devices.
-<br>
-
-<br>
-Add new tiffscaled8 and tiffscaled24 devices, copied and modified from
-<br>
-tiffscaled. These output greyscale and 24bit rgb instead of tiffscaleds
-<br>
-mono output. MinFeatureSize is ignored for these devices as it's meaningless
-<br>
-for contone output.
-<br>
-
-<br>
-Error Diffusion is still done, but is almost certainly a waste of time - it
-<br>
-was just simpler to make the code work this way. If performance is an issue,
-<br>
-we can remove that later.
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-gs/base/devs.mak
-<br>
-gs/base/gdevtifs.c
-<br>
-gs/base/gdevtifs.h
-<br>
-gs/base/gdevtsep.c
-<br>
-gs/base/macos-mcp.mak
-<br>
-gs/base/openvms.mak
-<br>
-gs/base/unix-gcc.mak
-<br>
-gs/base/unixansi.mak
-<br>
-gs/doc/Devices.htm
-<br>
-gs/psi/msvc.mak
-<br>
-main/pcl6_gcc.mak
-<br>
-main/pcl6_msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-20 00:00:45 +0200></a>
-2011-04-20 00:00:45 +0200</strong>
-<br>Tor Andersson <tor.andersson@artifex.com><br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f6e8c8d24c4a2f66b45ce04ab544aaf8b305a0d1">f6e8c8d24c4a2f66b45ce04ab544aaf8b305a0d1</a>
-<blockquote>
-
-<br>
-Change GS_PRODUCTFAMILY to say GIT instead of SVN PRERELEASE.
-<br>
-
-<br>
-gs/base/gscdef.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-19 23:58:23 +0200></a>
-2011-04-19 23:58:23 +0200</strong>
-<br>Tor Andersson <tor.andersson@artifex.com><br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c91007a224a533fb7582646d98b6bf1721f4f297">c91007a224a533fb7582646d98b6bf1721f4f297</a>
-<blockquote>
-
-<br>
-Clean up file permissions.
-<br>
-
-<br>
-COPYING.AFPL
-<br>
-gs/examples/golfer.eps
-<br>
-gs/examples/tiger.eps
-<br>
-gs/ghostscript-ufst.vcproj
-<br>
-gs/ghostscript.vcproj
-<br>
-gs/psi/winint.mak
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff.sln
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff.vb
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff.vbproj
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Application.Designer.vb
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Application.myapp
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/AssemblyInfo.vb
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Resources.Designer.vb
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Resources.resx
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Settings.Designer.vb
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Settings.settings
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Acrobat2Tiff.xml
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Interop.Acrobat.dll
-<br>
-tools/cmpi/cmpi.bkl
-<br>
-tools/cmpi/cmpi.cpp
-<br>
-tools/cmpi/cmpi.dsp
-<br>
-tools/cmpi/cmpi.dsw
-<br>
-tools/cmpi/cmpi.pro
-<br>
-tools/cmpi/cmpi.rc
-<br>
-tools/cmpi/cmpi.sln
-<br>
-tools/cmpi/cmpi.suo
-<br>
-tools/cmpi/cmpi.vcp
-<br>
-tools/cmpi/cmpi.vcproj
-<br>
-tools/cmpi/cmpi.vcw
-<br>
-tools/cmpi/descrip.mms
-<br>
-tools/cmpi/makefile.bcc
-<br>
-tools/cmpi/makefile.dmc
-<br>
-tools/cmpi/makefile.dms
-<br>
-tools/cmpi/makefile.dos
-<br>
-tools/cmpi/makefile.gcc
-<br>
-tools/cmpi/makefile.sc
-<br>
-tools/cmpi/makefile.unx
-<br>
-tools/cmpi/makefile.va
-<br>
-tools/cmpi/makefile.vc
-<br>
-tools/cmpi/makefile.wat
-<br>
-tools/tiger.svg
-<br>
-tools/xps2tiff/README
-<br>
-tools/xps2tiff/xps2tiff.sln
-<br>
-tools/xps2tiff/xps2tiff/AssemblyInfo.cpp
-<br>
-tools/xps2tiff/xps2tiff/stdafx.cpp
-<br>
-tools/xps2tiff/xps2tiff/xps2tiff.cpp
-<br>
-tools/xps2tiff/xps2tiff/xps2tiff.vcproj
-<br>
-win32/GhostPDL.sln
-<br>
-win32/ReadMe.txt
-<br>
-win32/language_switch.vcproj
-<br>
-win32/pcl.vcproj
-<br>
-win32/svg.vcproj
-<br>
-win32/xps.vcproj
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-19 23:49:56 +0200></a>
-2011-04-19 23:49:56 +0200</strong>
-<br>Tor Andersson <tor.andersson@artifex.com><br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=781969994b5381ba4bed03beef217f9bde6e7c58">781969994b5381ba4bed03beef217f9bde6e7c58</a>
-<blockquote>
-
-<br>
-Indent with spaces and strip trailing whitespace.
-<br>
-
-<br>
-gs/Resource/Init/gs_agl.ps
-<br>
-gs/Resource/Init/gs_btokn.ps
-<br>
-gs/Resource/Init/gs_cet.ps
-<br>
-gs/Resource/Init/gs_cff.ps
-<br>
-gs/Resource/Init/gs_cidcm.ps
-<br>
-gs/Resource/Init/gs_ciddc.ps
-<br>
-gs/Resource/Init/gs_cidfm.ps
-<br>
-gs/Resource/Init/gs_cidfn.ps
-<br>
-gs/Resource/Init/gs_cidtt.ps
-<br>
-gs/Resource/Init/gs_cmap.ps
-<br>
-gs/Resource/Init/gs_cspace.ps
-<br>
-gs/Resource/Init/gs_css_e.ps
-<br>
-gs/Resource/Init/gs_dbt_e.ps
-<br>
-gs/Resource/Init/gs_diskf.ps
-<br>
-gs/Resource/Init/gs_diskn.ps
-<br>
-gs/Resource/Init/gs_dpnxt.ps
-<br>
-gs/Resource/Init/gs_dps.ps
-<br>
-gs/Resource/Init/gs_dps1.ps
-<br>
-gs/Resource/Init/gs_dps2.ps
-<br>
-gs/Resource/Init/gs_dscp.ps
-<br>
-gs/Resource/Init/gs_epsf.ps
-<br>
-gs/Resource/Init/gs_fapi.ps
-<br>
-gs/Resource/Init/gs_fntem.ps
-<br>
-gs/Resource/Init/gs_fonts.ps
-<br>
-gs/Resource/Init/gs_frsd.ps
-<br>
-gs/Resource/Init/gs_icc.ps
-<br>
-gs/Resource/Init/gs_il1_e.ps
-<br>
-gs/Resource/Init/gs_img.ps
-<br>
-gs/Resource/Init/gs_init.ps
-<br>
-gs/Resource/Init/gs_l2img.ps
-<br>
-gs/Resource/Init/gs_lev2.ps
-<br>
-gs/Resource/Init/gs_ll3.ps
-<br>
-gs/Resource/Init/gs_mex_e.ps
-<br>
-gs/Resource/Init/gs_mgl_e.ps
-<br>
-gs/Resource/Init/gs_mro_e.ps
-<br>
-gs/Resource/Init/gs_pdf_e.ps
-<br>
-gs/Resource/Init/gs_pdfwr.ps
-<br>
-gs/Resource/Init/gs_res.ps
-<br>
-gs/Resource/Init/gs_resmp.ps
-<br>
-gs/Resource/Init/gs_setpd.ps
-<br>
-gs/Resource/Init/gs_statd.ps
-<br>
-gs/Resource/Init/gs_std_e.ps
-<br>
-gs/Resource/Init/gs_sym_e.ps
-<br>
-gs/Resource/Init/gs_trap.ps
-<br>
-gs/Resource/Init/gs_ttf.ps
-<br>
-gs/Resource/Init/gs_typ32.ps
-<br>
-gs/Resource/Init/gs_typ42.ps
-<br>
-gs/Resource/Init/gs_type1.ps
-<br>
-gs/Resource/Init/gs_wan_e.ps
-<br>
-gs/Resource/Init/pdf_base.ps
-<br>
-gs/Resource/Init/pdf_cslayer.ps
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-gs/Resource/Init/pdf_font.ps
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-gs/Resource/Init/pdf_ops.ps
-<br>
-gs/Resource/Init/pdf_rbld.ps
-<br>
-gs/Resource/Init/pdf_sec.ps
-<br>
-gs/base/ConvertUTF.c
-<br>
-gs/base/ConvertUTF.h
-<br>
-gs/base/aes.c
-<br>
-gs/base/aes.h
-<br>
-gs/base/assert_.h
-<br>
-gs/base/ctype_.h
-<br>
-gs/base/dirent_.h
-<br>
-gs/base/dos_.h
-<br>
-gs/base/echogs.c
-<br>
-gs/base/errno_.h
-<br>
-gs/base/errors.h
-<br>
-gs/base/fcntl_.h
-<br>
-gs/base/gconf.c
-<br>
-gs/base/gconf.h
-<br>
-gs/base/gdebug.h
-<br>
-gs/base/gdev3852.c
-<br>
-gs/base/gdev3b1.c
-<br>
-gs/base/gdev4081.c
-<br>
-gs/base/gdev4693.c
-<br>
-gs/base/gdev8510.c
-<br>
-gs/base/gdev8bcm.c
-<br>
-gs/base/gdev8bcm.h
-<br>
-gs/base/gdevabuf.c
-<br>
-gs/base/gdevadmp.c
-<br>
-gs/base/gdevatx.c
-<br>
-gs/base/gdevbbox.c
-<br>
-gs/base/gdevbbox.h
-<br>
-gs/base/gdevbit.c
-<br>
-gs/base/gdevbj10.c
-<br>
-gs/base/gdevbjc.h
-<br>
-gs/base/gdevbjcl.c
-<br>
-gs/base/gdevbjcl.h
-<br>
-gs/base/gdevbmp.c
-<br>
-gs/base/gdevbmp.h
-<br>
-gs/base/gdevbmpa.c
-<br>
-gs/base/gdevbmpc.c
-<br>
-gs/base/gdevccr.c
-<br>
-gs/base/gdevcdj.c
-<br>
-gs/base/gdevcfax.c
-<br>
-gs/base/gdevcgm.c
-<br>
-gs/base/gdevcgml.c
-<br>
-gs/base/gdevcgml.h
-<br>
-gs/base/gdevcgmx.h
-<br>
-gs/base/gdevcif.c
-<br>
-gs/base/gdevclj.c
-<br>
-gs/base/gdevcljc.c
-<br>
-gs/base/gdevcp50.c
-<br>
-gs/base/gdevcslw.c
-<br>
-gs/base/gdevdbit.c
-<br>
-gs/base/gdevdcrd.c
-<br>
-gs/base/gdevdcrd.h
-<br>
-gs/base/gdevddrw.c
-<br>
-gs/base/gdevddrw.h
-<br>
-gs/base/gdevdevn.c
-<br>
-gs/base/gdevdevn.h
-<br>
-gs/base/gdevdfax.c
-<br>
-gs/base/gdevdflt.c
-<br>
-gs/base/gdevdgbr.c
-<br>
-gs/base/gdevdjet.c
-<br>
-gs/base/gdevdjtc.c
-<br>
-gs/base/gdevdljm.c
-<br>
-gs/base/gdevdljm.h
-<br>
-gs/base/gdevdm24.c
-<br>
-gs/base/gdevdsha.c
-<br>
-gs/base/gdevdsp.c
-<br>
-gs/base/gdevdsp.h
-<br>
-gs/base/gdevdsp2.h
-<br>
-gs/base/gdevemap.c
-<br>
-gs/base/gdevepsc.c
-<br>
-gs/base/gdevepsn.c
-<br>
-gs/base/gdevescp.c
-<br>
-gs/base/gdevevga.c
-<br>
-gs/base/gdevfax.c
-<br>
-gs/base/gdevfax.h
-<br>
-gs/base/gdevherc.c
-<br>
-gs/base/gdevhit.c
-<br>
-gs/base/gdevhl7x.c
-<br>
-gs/base/gdevifno.c
-<br>
-gs/base/gdevijs.c
-<br>
-gs/base/gdevimdi.c
-<br>
-gs/base/gdevimgn.c
-<br>
-gs/base/gdevjbig2.c
-<br>
-gs/base/gdevjpeg.c
-<br>
-gs/base/gdevjpx.c
-<br>
-gs/base/gdevl256.c
-<br>
-gs/base/gdevl31s.c
-<br>
-gs/base/gdevlbp8.c
-<br>
-gs/base/gdevlj56.c
-<br>
-gs/base/gdevlp8k.c
-<br>
-gs/base/gdevlxm.c
-<br>
-gs/base/gdevm1.c
-<br>
-gs/base/gdevm16.c
-<br>
-gs/base/gdevm2.c
-<br>
-gs/base/gdevm24.c
-<br>
-gs/base/gdevm32.c
-<br>
-gs/base/gdevm4.c
-<br>
-gs/base/gdevm40.c
-<br>
-gs/base/gdevm48.c
-<br>
-gs/base/gdevm56.c
-<br>
-gs/base/gdevm64.c
-<br>
-gs/base/gdevmac.c
-<br>
-gs/base/gdevmac.h
-<br>
-gs/base/gdevmacpictop.h
-<br>
-gs/base/gdevmacttf.h
-<br>
-gs/base/gdevmacxf.c
-<br>
-gs/base/gdevmeds.c
-<br>
-gs/base/gdevmeds.h
-<br>
-gs/base/gdevmem.c
-<br>
-gs/base/gdevmem.h
-<br>
-gs/base/gdevmgr.c
-<br>
-gs/base/gdevmgr.h
-<br>
-gs/base/gdevmiff.c
-<br>
-gs/base/gdevmpla.h
-<br>
-gs/base/gdevmr1.c
-<br>
-gs/base/gdevmr2n.c
-<br>
-gs/base/gdevmrop.h
-<br>
-gs/base/gdevmrun.c
-<br>
-gs/base/gdevmrun.h
-<br>
-gs/base/gdevmswn.c
-<br>
-gs/base/gdevmswn.h
-<br>
-gs/base/gdevmsxf.c
-<br>
-gs/base/gdevn533.c
-<br>
-gs/base/gdevnfwd.c
-<br>
-gs/base/gdevo182.c
-<br>
-gs/base/gdevokii.c
-<br>
-gs/base/gdevos2p.c
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gdevp14.h
-<br>
-gs/base/gdevp2up.c
-<br>
-gs/base/gdevpbm.c
-<br>
-gs/base/gdevpccm.c
-<br>
-gs/base/gdevpccm.h
-<br>
-gs/base/gdevpcfb.c
-<br>
-gs/base/gdevpcfb.h
-<br>
-gs/base/gdevpcl.c
-<br>
-gs/base/gdevpcl.h
-<br>
-gs/base/gdevpcx.c
-<br>
-gs/base/gdevpdf.c
-<br>
-gs/base/gdevpdfb.c
-<br>
-gs/base/gdevpdfb.h
-<br>
-gs/base/gdevpdfc.c
-<br>
-gs/base/gdevpdfc.h
-<br>
-gs/base/gdevpdfd.c
-<br>
-gs/base/gdevpdfe.c
-<br>
-gs/base/gdevpdfg.c
-<br>
-gs/base/gdevpdfg.h
-<br>
-gs/base/gdevpdfi.c
-<br>
-gs/base/gdevpdfj.c
-<br>
-gs/base/gdevpdfk.c
-<br>
-gs/base/gdevpdfm.c
-<br>
-gs/base/gdevpdfo.c
-<br>
-gs/base/gdevpdfo.h
-<br>
-gs/base/gdevpdfp.c
-<br>
-gs/base/gdevpdfr.c
-<br>
-gs/base/gdevpdft.c
-<br>
-gs/base/gdevpdfu.c
-<br>
-gs/base/gdevpdfv.c
-<br>
-gs/base/gdevpdfx.h
-<br>
-gs/base/gdevpdt.c
-<br>
-gs/base/gdevpdt.h
-<br>
-gs/base/gdevpdtb.c
-<br>
-gs/base/gdevpdtb.h
-<br>
-gs/base/gdevpdtc.c
-<br>
-gs/base/gdevpdtd.c
-<br>
-gs/base/gdevpdtd.h
-<br>
-gs/base/gdevpdte.c
-<br>
-gs/base/gdevpdtf.c
-<br>
-gs/base/gdevpdtf.h
-<br>
-gs/base/gdevpdti.c
-<br>
-gs/base/gdevpdti.h
-<br>
-gs/base/gdevpdts.c
-<br>
-gs/base/gdevpdts.h
-<br>
-gs/base/gdevpdtt.c
-<br>
-gs/base/gdevpdtt.h
-<br>
-gs/base/gdevpdtv.c
-<br>
-gs/base/gdevpdtv.h
-<br>
-gs/base/gdevpdtw.c
-<br>
-gs/base/gdevpdtw.h
-<br>
-gs/base/gdevpdtx.h
-<br>
-gs/base/gdevpe.c
-<br>
-gs/base/gdevperm.c
-<br>
-gs/base/gdevphex.c
-<br>
-gs/base/gdevpipe.c
-<br>
-gs/base/gdevpjet.c
-<br>
-gs/base/gdevplib.c
-<br>
-gs/base/gdevplnx.c
-<br>
-gs/base/gdevplnx.h
-<br>
-gs/base/gdevpm.h
-<br>
-gs/base/gdevpng.c
-<br>
-gs/base/gdevppla.c
-<br>
-gs/base/gdevppla.h
-<br>
-gs/base/gdevprn.c
-<br>
-gs/base/gdevprn.h
-<br>
-gs/base/gdevprna.c
-<br>
-gs/base/gdevprna.h
-<br>
-gs/base/gdevps.c
-<br>
-gs/base/gdevpsd.c
-<br>
-gs/base/gdevpsdf.h
-<br>
-gs/base/gdevpsdi.c
-<br>
-gs/base/gdevpsdp.c
-<br>
-gs/base/gdevpsds.c
-<br>
-gs/base/gdevpsds.h
-<br>
-gs/base/gdevpsdu.c
-<br>
-gs/base/gdevpsf.h
-<br>
-gs/base/gdevpsf1.c
-<br>
-gs/base/gdevpsf2.c
-<br>
-gs/base/gdevpsfm.c
-<br>
-gs/base/gdevpsft.c
-<br>
-gs/base/gdevpsfu.c
-<br>
-gs/base/gdevpsfx.c
-<br>
-gs/base/gdevpsim.c
-<br>
-gs/base/gdevpsu.c
-<br>
-gs/base/gdevpsu.h
-<br>
-gs/base/gdevpx.c
-<br>
-gs/base/gdevpxen.h
-<br>
-gs/base/gdevpxop.h
-<br>
-gs/base/gdevpxut.c
-<br>
-gs/base/gdevpxut.h
-<br>
-gs/base/gdevrinkj.c
-<br>
-gs/base/gdevrops.c
-<br>
-gs/base/gdevs3ga.c
-<br>
-gs/base/gdevsco.c
-<br>
-gs/base/gdevsgi.c
-<br>
-gs/base/gdevsgi.h
-<br>
-gs/base/gdevsj48.c
-<br>
-gs/base/gdevsnfb.c
-<br>
-gs/base/gdevsppr.c
-<br>
-gs/base/gdevstc.c
-<br>
-gs/base/gdevstc.h
-<br>
-gs/base/gdevstc1.c
-<br>
-gs/base/gdevstc2.c
-<br>
-gs/base/gdevstc3.c
-<br>
-gs/base/gdevstc4.c
-<br>
-gs/base/gdevsun.c
-<br>
-gs/base/gdevsunr.c
-<br>
-gs/base/gdevsvg.c
-<br>
-gs/base/gdevsvga.c
-<br>
-gs/base/gdevsvga.h
-<br>
-gs/base/gdevtfax.c
-<br>
-gs/base/gdevtfax.h
-<br>
-gs/base/gdevtfnx.c
-<br>
-gs/base/gdevtifs.c
-<br>
-gs/base/gdevtifs.h
-<br>
-gs/base/gdevtknk.c
-<br>
-gs/base/gdevtrac.c
-<br>
-gs/base/gdevtsep.c
-<br>
-gs/base/gdevtxtw.c
-<br>
-gs/base/gdevupd.c
-<br>
-gs/base/gdevvec.c
-<br>
-gs/base/gdevvec.h
-<br>
-gs/base/gdevvglb.c
-<br>
-gs/base/gdevwddb.c
-<br>
-gs/base/gdevwdib.c
-<br>
-gs/base/gdevwpr2.c
-<br>
-gs/base/gdevwprn.c
-<br>
-gs/base/gdevwts.c
-<br>
-gs/base/gdevx.c
-<br>
-gs/base/gdevx.h
-<br>
-gs/base/gdevxalt.c
-<br>
-gs/base/gdevxcf.c
-<br>
-gs/base/gdevxcmp.c
-<br>
-gs/base/gdevxcmp.h
-<br>
-gs/base/gdevxini.c
-<br>
-gs/base/gdevxres.c
-<br>
-gs/base/gdevxxf.c
-<br>
-gs/base/genarch.c
-<br>
-gs/base/genconf.c
-<br>
-gs/base/gendev.c
-<br>
-gs/base/genht.c
-<br>
-gs/base/gp.h
-<br>
-gs/base/gp_dosfe.c
-<br>
-gs/base/gp_dosfs.c
-<br>
-gs/base/gp_dvx.c
-<br>
-gs/base/gp_getnv.c
-<br>
-gs/base/gp_mac.c
-<br>
-gs/base/gp_mac.h
-<br>
-gs/base/gp_macio.c
-<br>
-gs/base/gp_macpoll.c
-<br>
-gs/base/gp_mktmp.c
-<br>
-gs/base/gp_msdll.c
-<br>
-gs/base/gp_msdos.c
-<br>
-gs/base/gp_mshdl.c
-<br>
-gs/base/gp_mslib.c
-<br>
-gs/base/gp_mspol.c
-<br>
-gs/base/gp_msprn.c
-<br>
-gs/base/gp_mswin.c
-<br>
-gs/base/gp_mswin.h
-<br>
-gs/base/gp_nsync.c
-<br>
-gs/base/gp_ntfs.c
-<br>
-gs/base/gp_os2.c
-<br>
-gs/base/gp_os2.h
-<br>
-gs/base/gp_os2fs.c
-<br>
-gs/base/gp_os2pr.c
-<br>
-gs/base/gp_os9.c
-<br>
-gs/base/gp_paper.c
-<br>
-gs/base/gp_psync.c
-<br>
-gs/base/gp_stdia.c
-<br>
-gs/base/gp_stdin.c
-<br>
-gs/base/gp_strdl.c
-<br>
-gs/base/gp_sysv.c
-<br>
-gs/base/gp_unix.c
-<br>
-gs/base/gp_unix_cache.c
-<br>
-gs/base/gp_upapr.c
-<br>
-gs/base/gp_vms.c
-<br>
-gs/base/gp_wgetv.c
-<br>
-gs/base/gp_win32.c
-<br>
-gs/base/gp_wpapr.c
-<br>
-gs/base/gp_wsync.c
-<br>
-gs/base/gpcheck.h
-<br>
-gs/base/gpgetenv.h
-<br>
-gs/base/gpmisc.c
-<br>
-gs/base/gpmisc.h
-<br>
-gs/base/gs_agl.h
-<br>
-gs/base/gs_dll_call.h
-<br>
-gs/base/gs_mgl_e.h
-<br>
-gs/base/gs_mro_e.h
-<br>
-gs/base/gsalloc.c
-<br>
-gs/base/gsalloc.h
-<br>
-gs/base/gsalpha.c
-<br>
-gs/base/gsalpha.h
-<br>
-gs/base/gsalphac.c
-<br>
-gs/base/gsalphac.h
-<br>
-gs/base/gsargs.c
-<br>
-gs/base/gsargs.h
-<br>
-gs/base/gsbitcom.c
-<br>
-gs/base/gsbitmap.h
-<br>
-gs/base/gsbitops.c
-<br>
-gs/base/gsbittab.c
-<br>
-gs/base/gsbittab.h
-<br>
-gs/base/gsccode.h
-<br>
-gs/base/gsccolor.h
-<br>
-gs/base/gscdef.c
-<br>
-gs/base/gscdefs.h
-<br>
-gs/base/gscdevn.c
-<br>
-gs/base/gscdevn.h
-<br>
-gs/base/gscedata.c
-<br>
-gs/base/gscedata.h
-<br>
-gs/base/gscencs.c
-<br>
-gs/base/gscencs.h
-<br>
-gs/base/gschar.c
-<br>
-gs/base/gschar.h
-<br>
-gs/base/gschar0.c
-<br>
-gs/base/gscicach.c
-<br>
-gs/base/gscicach.h
-<br>
-gs/base/gscie.c
-<br>
-gs/base/gscie.h
-<br>
-gs/base/gsciemap.c
-<br>
-gs/base/gscindex.h
-<br>
-gs/base/gsclipsr.c
-<br>
-gs/base/gsclipsr.h
-<br>
-gs/base/gscms.h
-<br>
-gs/base/gscolor.c
-<br>
-gs/base/gscolor.h
-<br>
-gs/base/gscolor1.c
-<br>
-gs/base/gscolor1.h
-<br>
-gs/base/gscolor2.c
-<br>
-gs/base/gscolor2.h
-<br>
-gs/base/gscolor3.c
-<br>
-gs/base/gscolor3.h
-<br>
-gs/base/gscolorbuffer.c
-<br>
-gs/base/gscolorbuffer.h
-<br>
-gs/base/gscompt.h
-<br>
-gs/base/gscoord.c
-<br>
-gs/base/gscoord.h
-<br>
-gs/base/gscparam.c
-<br>
-gs/base/gscpixel.c
-<br>
-gs/base/gscpixel.h
-<br>
-gs/base/gscpm.h
-<br>
-gs/base/gscrd.c
-<br>
-gs/base/gscrd.h
-<br>
-gs/base/gscrdp.c
-<br>
-gs/base/gscrdp.h
-<br>
-gs/base/gscrypt1.c
-<br>
-gs/base/gscrypt1.h
-<br>
-gs/base/gscscie.c
-<br>
-gs/base/gscsel.h
-<br>
-gs/base/gscsepr.c
-<br>
-gs/base/gscsepr.h
-<br>
-gs/base/gscspace.c
-<br>
-gs/base/gscspace.h
-<br>
-gs/base/gscssub.c
-<br>
-gs/base/gscssub.h
-<br>
-gs/base/gsdcolor.h
-<br>
-gs/base/gsdevice.c
-<br>
-gs/base/gsdevice.h
-<br>
-gs/base/gsdevmem.c
-<br>
-gs/base/gsdfilt.c
-<br>
-gs/base/gsdfilt.h
-<br>
-gs/base/gsdll.h
-<br>
-gs/base/gsdllwin.h
-<br>
-gs/base/gsdparam.c
-<br>
-gs/base/gsdpnext.h
-<br>
-gs/base/gsdps.c
-<br>
-gs/base/gsdps.h
-<br>
-gs/base/gsdps1.c
-<br>
-gs/base/gsdsrc.c
-<br>
-gs/base/gsdsrc.h
-<br>
-gs/base/gsequivc.c
-<br>
-gs/base/gsequivc.h
-<br>
-gs/base/gserror.h
-<br>
-gs/base/gserrors.h
-<br>
-gs/base/gsexit.h
-<br>
-gs/base/gsfcid.c
-<br>
-gs/base/gsfcid2.c
-<br>
-gs/base/gsfcmap.c
-<br>
-gs/base/gsfcmap.h
-<br>
-gs/base/gsfcmap1.c
-<br>
-gs/base/gsflip.c
-<br>
-gs/base/gsflip.h
-<br>
-gs/base/gsfname.c
-<br>
-gs/base/gsfname.h
-<br>
-gs/base/gsfont.c
-<br>
-gs/base/gsfont.h
-<br>
-gs/base/gsfont0.c
-<br>
-gs/base/gsfont0c.c
-<br>
-gs/base/gsfunc.c
-<br>
-gs/base/gsfunc.h
-<br>
-gs/base/gsfunc0.c
-<br>
-gs/base/gsfunc0.h
-<br>
-gs/base/gsfunc3.c
-<br>
-gs/base/gsfunc3.h
-<br>
-gs/base/gsfunc4.c
-<br>
-gs/base/gsfunc4.h
-<br>
-gs/base/gsgc.h
-<br>
-gs/base/gsgcache.c
-<br>
-gs/base/gsgcache.h
-<br>
-gs/base/gsgdata.c
-<br>
-gs/base/gsgdata.h
-<br>
-gs/base/gshsb.c
-<br>
-gs/base/gshsb.h
-<br>
-gs/base/gsht.c
-<br>
-gs/base/gsht.h
-<br>
-gs/base/gsht1.c
-<br>
-gs/base/gsht1.h
-<br>
-gs/base/gshtscr.c
-<br>
-gs/base/gshtx.c
-<br>
-gs/base/gshtx.h
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gsicc.h
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gsicc_cache.h
-<br>
-gs/base/gsicc_cms.h
-<br>
-gs/base/gsicc_create.c
-<br>
-gs/base/gsicc_create.h
-<br>
-gs/base/gsicc_lcms.c
-<br>
-gs/base/gsicc_lcms2.c
-<br>
-gs/base/gsicc_manage.c
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/base/gsicc_profilecache.c
-<br>
-gs/base/gsicc_profilecache.h
-<br>
-gs/base/gsimage.c
-<br>
-gs/base/gsimage.h
-<br>
-gs/base/gsimpath.c
-<br>
-gs/base/gsinit.c
-<br>
-gs/base/gsio.h
-<br>
-gs/base/gsiodev.c
-<br>
-gs/base/gsiodevs.c
-<br>
-gs/base/gsiodisk.c
-<br>
-gs/base/gsiomacres.c
-<br>
-gs/base/gsiorom.c
-<br>
-gs/base/gsiorom.h
-<br>
-gs/base/gsipar3x.h
-<br>
-gs/base/gsiparam.h
-<br>
-gs/base/gsiparm2.h
-<br>
-gs/base/gsiparm3.h
-<br>
-gs/base/gsiparm4.h
-<br>
-gs/base/gsistate.c
-<br>
-gs/base/gsjconf.h
-<br>
-gs/base/gsjmorec.h
-<br>
-gs/base/gslib.c
-<br>
-gs/base/gslib.h
-<br>
-gs/base/gslibctx.c
-<br>
-gs/base/gslibctx.h
-<br>
-gs/base/gsline.c
-<br>
-gs/base/gsline.h
-<br>
-gs/base/gslparam.h
-<br>
-gs/base/gsmalloc.c
-<br>
-gs/base/gsmalloc.h
-<br>
-gs/base/gsmatrix.c
-<br>
-gs/base/gsmatrix.h
-<br>
-gs/base/gsmchunk.c
-<br>
-gs/base/gsmchunk.h
-<br>
-gs/base/gsmdebug.h
-<br>
-gs/base/gsmemlok.c
-<br>
-gs/base/gsmemlok.h
-<br>
-gs/base/gsmemory.c
-<br>
-gs/base/gsmemory.h
-<br>
-gs/base/gsmemraw.h
-<br>
-gs/base/gsmemret.c
-<br>
-gs/base/gsmemret.h
-<br>
-gs/base/gsmisc.c
-<br>
-gs/base/gsnamecl.c
-<br>
-gs/base/gsnamecl.h
-<br>
-gs/base/gsncdummy.c
-<br>
-gs/base/gsncdummy.h
-<br>
-gs/base/gsnogc.c
-<br>
-gs/base/gsnogc.h
-<br>
-gs/base/gsnorop.c
-<br>
-gs/base/gsnotify.c
-<br>
-gs/base/gsnotify.h
-<br>
-gs/base/gsovrc.c
-<br>
-gs/base/gsovrc.h
-<br>
-gs/base/gspaint.c
-<br>
-gs/base/gspaint.h
-<br>
-gs/base/gsparam.c
-<br>
-gs/base/gsparam.h
-<br>
-gs/base/gsparam2.c
-<br>
-gs/base/gsparams.c
-<br>
-gs/base/gsparams.h
-<br>
-gs/base/gsparamx.c
-<br>
-gs/base/gsparamx.h
-<br>
-gs/base/gspath.c
-<br>
-gs/base/gspath.h
-<br>
-gs/base/gspath1.c
-<br>
-gs/base/gspath2.h
-<br>
-gs/base/gspcolor.c
-<br>
-gs/base/gspcolor.h
-<br>
-gs/base/gspenum.h
-<br>
-gs/base/gspmdrv.c
-<br>
-gs/base/gspmdrv.h
-<br>
-gs/base/gsptype1.c
-<br>
-gs/base/gsptype1.h
-<br>
-gs/base/gsptype2.c
-<br>
-gs/base/gsptype2.h
-<br>
-gs/base/gsrect.h
-<br>
-gs/base/gsrefct.h
-<br>
-gs/base/gsromfs0.c
-<br>
-gs/base/gsrop.c
-<br>
-gs/base/gsrop.h
-<br>
-gs/base/gsroprun.c
-<br>
-gs/base/gsropt.h
-<br>
-gs/base/gsroptab.c
-<br>
-gs/base/gsserial.c
-<br>
-gs/base/gsserial.h
-<br>
-gs/base/gsshade.c
-<br>
-gs/base/gsshade.h
-<br>
-gs/base/gsstate.c
-<br>
-gs/base/gsstate.h
-<br>
-gs/base/gsstruct.h
-<br>
-gs/base/gsstype.h
-<br>
-gs/base/gstext.c
-<br>
-gs/base/gstext.h
-<br>
-gs/base/gstparam.h
-<br>
-gs/base/gstrans.c
-<br>
-gs/base/gstrans.h
-<br>
-gs/base/gstrap.c
-<br>
-gs/base/gstrap.h
-<br>
-gs/base/gstype1.c
-<br>
-gs/base/gstype1.h
-<br>
-gs/base/gstype2.c
-<br>
-gs/base/gstype42.c
-<br>
-gs/base/gstypes.h
-<br>
-gs/base/gsuid.h
-<br>
-gs/base/gsutil.c
-<br>
-gs/base/gsutil.h
-<br>
-gs/base/gswts.c
-<br>
-gs/base/gswts.h
-<br>
-gs/base/gsxfont.h
-<br>
-gs/base/gx.h
-<br>
-gs/base/gxacpath.c
-<br>
-gs/base/gxalloc.h
-<br>
-gs/base/gxalpha.h
-<br>
-gs/base/gxarith.h
-<br>
-gs/base/gxband.h
-<br>
-gs/base/gxbcache.c
-<br>
-gs/base/gxbcache.h
-<br>
-gs/base/gxbitfmt.h
-<br>
-gs/base/gxbitmap.h
-<br>
-gs/base/gxbitops.h
-<br>
-gs/base/gxblend.c
-<br>
-gs/base/gxblend.h
-<br>
-gs/base/gxblend1.c
-<br>
-gs/base/gxccache.c
-<br>
-gs/base/gxccman.c
-<br>
-gs/base/gxcdevn.h
-<br>
-gs/base/gxchar.h
-<br>
-gs/base/gxchrout.c
-<br>
-gs/base/gxchrout.h
-<br>
-gs/base/gxcht.c
-<br>
-gs/base/gxcid.h
-<br>
-gs/base/gxcie.h
-<br>
-gs/base/gxcindex.h
-<br>
-gs/base/gxclbits.c
-<br>
-gs/base/gxcldev.h
-<br>
-gs/base/gxclfile.c
-<br>
-gs/base/gxclimag.c
-<br>
-gs/base/gxclio.h
-<br>
-gs/base/gxclip.c
-<br>
-gs/base/gxclip.h
-<br>
-gs/base/gxclip2.c
-<br>
-gs/base/gxclip2.h
-<br>
-gs/base/gxclipm.c
-<br>
-gs/base/gxclipm.h
-<br>
-gs/base/gxclipsr.h
-<br>
-gs/base/gxclist.c
-<br>
-gs/base/gxclist.h
-<br>
-gs/base/gxcllzw.c
-<br>
-gs/base/gxclmem.c
-<br>
-gs/base/gxclmem.h
-<br>
-gs/base/gxclpage.c
-<br>
-gs/base/gxclpage.h
-<br>
-gs/base/gxclpath.c
-<br>
-gs/base/gxclpath.h
-<br>
-gs/base/gxclrast.c
-<br>
-gs/base/gxclread.c
-<br>
-gs/base/gxclrect.c
-<br>
-gs/base/gxclthrd.c
-<br>
-gs/base/gxclthrd.h
-<br>
-gs/base/gxclutil.c
-<br>
-gs/base/gxcmap.c
-<br>
-gs/base/gxcmap.h
-<br>
-gs/base/gxcolor2.h
-<br>
-gs/base/gxcomp.h
-<br>
-gs/base/gxcoord.h
-<br>
-gs/base/gxcpath.c
-<br>
-gs/base/gxcpath.h
-<br>
-gs/base/gxcspace.h
-<br>
-gs/base/gxctable.c
-<br>
-gs/base/gxctable.h
-<br>
-gs/base/gxcvalue.h
-<br>
-gs/base/gxdcconv.c
-<br>
-gs/base/gxdcconv.h
-<br>
-gs/base/gxdcolor.c
-<br>
-gs/base/gxdcolor.h
-<br>
-gs/base/gxdda.h
-<br>
-gs/base/gxdevbuf.h
-<br>
-gs/base/gxdevcli.h
-<br>
-gs/base/gxdevmem.h
-<br>
-gs/base/gxdevndi.c
-<br>
-gs/base/gxdevndi.h
-<br>
-gs/base/gxdevrop.h
-<br>
-gs/base/gxdevsop.h
-<br>
-gs/base/gxdht.h
-<br>
-gs/base/gxdhtres.h
-<br>
-gs/base/gxdhtserial.c
-<br>
-gs/base/gxdhtserial.h
-<br>
-gs/base/gxdither.h
-<br>
-gs/base/gxdtfill.h
-<br>
-gs/base/gxfapiu.c
-<br>
-gs/base/gxfapiu.h
-<br>
-gs/base/gxfarith.h
-<br>
-gs/base/gxfcache.h
-<br>
-gs/base/gxfcid.h
-<br>
-gs/base/gxfcmap.h
-<br>
-gs/base/gxfcmap1.h
-<br>
-gs/base/gxfcopy.c
-<br>
-gs/base/gxfcopy.h
-<br>
-gs/base/gxfdrop.c
-<br>
-gs/base/gxfdrop.h
-<br>
-gs/base/gxfill.c
-<br>
-gs/base/gxfill.h
-<br>
-gs/base/gxfillsl.h
-<br>
-gs/base/gxfilltr.h
-<br>
-gs/base/gxfillts.h
-<br>
-gs/base/gxfixed.h
-<br>
-gs/base/gxfmap.h
-<br>
-gs/base/gxfont.h
-<br>
-gs/base/gxfont0.h
-<br>
-gs/base/gxfont0c.h
-<br>
-gs/base/gxfont1.h
-<br>
-gs/base/gxfont42.h
-<br>
-gs/base/gxfrac.h
-<br>
-gs/base/gxftype.h
-<br>
-gs/base/gxfunc.h
-<br>
-gs/base/gxgetbit.h
-<br>
-gs/base/gxhintn.c
-<br>
-gs/base/gxhintn.h
-<br>
-gs/base/gxhintn1.c
-<br>
-gs/base/gxhldevc.c
-<br>
-gs/base/gxhldevc.h
-<br>
-gs/base/gxht.c
-<br>
-gs/base/gxht.h
-<br>
-gs/base/gxht_thresh.c
-<br>
-gs/base/gxht_thresh.h
-<br>
-gs/base/gxhtbit.c
-<br>
-gs/base/gxhttile.h
-<br>
-gs/base/gxhttype.h
-<br>
-gs/base/gxi12bit.c
-<br>
-gs/base/gxi16bit.c
-<br>
-gs/base/gxiclass.h
-<br>
-gs/base/gxicolor.c
-<br>
-gs/base/gxidata.c
-<br>
-gs/base/gxifast.c
-<br>
-gs/base/gximag3x.c
-<br>
-gs/base/gximag3x.h
-<br>
-gs/base/gximage.c
-<br>
-gs/base/gximage.h
-<br>
-gs/base/gximage1.c
-<br>
-gs/base/gximage2.c
-<br>
-gs/base/gximage3.c
-<br>
-gs/base/gximage3.h
-<br>
-gs/base/gximage4.c
-<br>
-gs/base/gximask.c
-<br>
-gs/base/gximask.h
-<br>
-gs/base/gximono.c
-<br>
-gs/base/gxino12b.c
-<br>
-gs/base/gxino16b.c
-<br>
-gs/base/gxiodev.h
-<br>
-gs/base/gxiparam.h
-<br>
-gs/base/gxipixel.c
-<br>
-gs/base/gxiscale.c
-<br>
-gs/base/gxistate.h
-<br>
-gs/base/gxline.h
-<br>
-gs/base/gxlum.h
-<br>
-gs/base/gxmatrix.h
-<br>
-gs/base/gxmclip.c
-<br>
-gs/base/gxmclip.h
-<br>
-gs/base/gxobj.h
-<br>
-gs/base/gxoprect.c
-<br>
-gs/base/gxoprect.h
-<br>
-gs/base/gxp1fill.c
-<br>
-gs/base/gxp1impl.h
-<br>
-gs/base/gxpageq.c
-<br>
-gs/base/gxpageq.h
-<br>
-gs/base/gxpaint.c
-<br>
-gs/base/gxpaint.h
-<br>
-gs/base/gxpath.c
-<br>
-gs/base/gxpath.h
-<br>
-gs/base/gxpath2.c
-<br>
-gs/base/gxpcache.h
-<br>
-gs/base/gxpcmap.c
-<br>
-gs/base/gxpcolor.h
-<br>
-gs/base/gxpcopy.c
-<br>
-gs/base/gxpdash.c
-<br>
-gs/base/gxpflat.c
-<br>
-gs/base/gxrplane.h
-<br>
-gs/base/gxsample.c
-<br>
-gs/base/gxsample.h
-<br>
-gs/base/gxsamplp.h
-<br>
-gs/base/gxshade.c
-<br>
-gs/base/gxshade.h
-<br>
-gs/base/gxshade1.c
-<br>
-gs/base/gxshade4.c
-<br>
-gs/base/gxshade4.h
-<br>
-gs/base/gxshade6.c
-<br>
-gs/base/gxstate.h
-<br>
-gs/base/gxstdio.h
-<br>
-gs/base/gxstroke.c
-<br>
-gs/base/gxsync.c
-<br>
-gs/base/gxsync.h
-<br>
-gs/base/gxtext.h
-<br>
-gs/base/gxtmap.h
-<br>
-gs/base/gxttf.h
-<br>
-gs/base/gxttfb.c
-<br>
-gs/base/gxttfb.h
-<br>
-gs/base/gxtype1.c
-<br>
-gs/base/gxtype1.h
-<br>
-gs/base/gxwts.c
-<br>
-gs/base/gxwts.h
-<br>
-gs/base/gxxfont.h
-<br>
-gs/base/gzacpath.h
-<br>
-gs/base/gzcpath.h
-<br>
-gs/base/gzht.h
-<br>
-gs/base/gzline.h
-<br>
-gs/base/gzpath.h
-<br>
-gs/base/gzspotan.c
-<br>
-gs/base/gzspotan.h
-<br>
-gs/base/gzstate.h
-<br>
-gs/base/jerror_.h
-<br>
-gs/base/locale_.h
-<br>
-gs/base/macos_carbon_d_pre.h
-<br>
-gs/base/macos_carbon_pre.h
-<br>
-gs/base/macos_classic_d_pre.h
-<br>
-gs/base/macsystypes.h
-<br>
-gs/base/malloc_.h
-<br>
-gs/base/math_.h
-<br>
-gs/base/md5.c
-<br>
-gs/base/md5.h
-<br>
-gs/base/md5main.c
-<br>
-gs/base/memory_.h
-<br>
-gs/base/minftrsz.c
-<br>
-gs/base/mkromfs.c
-<br>
-gs/base/opdfread.h
-<br>
-gs/base/pipe_.h
-<br>
-gs/base/png_.h
-<br>
-gs/base/rinkj/evenbetter-rll.c
-<br>
-gs/base/rinkj/evenbetter-rll.h
-<br>
-gs/base/rinkj/rinkj-byte-stream.c
-<br>
-gs/base/rinkj/rinkj-byte-stream.h
-<br>
-gs/base/rinkj/rinkj-config.c
-<br>
-gs/base/rinkj/rinkj-config.h
-<br>
-gs/base/rinkj/rinkj-device.c
-<br>
-gs/base/rinkj/rinkj-device.h
-<br>
-gs/base/rinkj/rinkj-dither.c
-<br>
-gs/base/rinkj/rinkj-dither.h
-<br>
-gs/base/rinkj/rinkj-epson870.c
-<br>
-gs/base/rinkj/rinkj-epson870.h
-<br>
-gs/base/rinkj/rinkj-screen-eb.c
-<br>
-gs/base/rinkj/rinkj-screen-eb.h
-<br>
-gs/base/sa85d.c
-<br>
-gs/base/sa85d.h
-<br>
-gs/base/sa85x.h
-<br>
-gs/base/saes.c
-<br>
-gs/base/saes.h
-<br>
-gs/base/sarc4.c
-<br>
-gs/base/sarc4.h
-<br>
-gs/base/sbcp.c
-<br>
-gs/base/sbcp.h
-<br>
-gs/base/sbhc.c
-<br>
-gs/base/sbhc.h
-<br>
-gs/base/sbtx.h
-<br>
-gs/base/sbwbs.c
-<br>
-gs/base/sbwbs.h
-<br>
-gs/base/scanchar.h
-<br>
-gs/base/scantab.c
-<br>
-gs/base/scf.h
-<br>
-gs/base/scfd.c
-<br>
-gs/base/scfdgen.c
-<br>
-gs/base/scfdtab.c
-<br>
-gs/base/scfe.c
-<br>
-gs/base/scfetab.c
-<br>
-gs/base/scfparam.c
-<br>
-gs/base/scfx.h
-<br>
-gs/base/scommon.h
-<br>
-gs/base/sdcparam.c
-<br>
-gs/base/sdcparam.h
-<br>
-gs/base/sdct.h
-<br>
-gs/base/sdctd.c
-<br>
-gs/base/sdcte.c
-<br>
-gs/base/sddparam.c
-<br>
-gs/base/sdeparam.c
-<br>
-gs/base/seexec.c
-<br>
-gs/base/setjmp_.h
-<br>
-gs/base/sfilter.h
-<br>
-gs/base/sfilter2.c
-<br>
-gs/base/sfxboth.c
-<br>
-gs/base/sfxcommon.c
-<br>
-gs/base/sfxfd.c
-<br>
-gs/base/sfxstdio.c
-<br>
-gs/base/sha2.c
-<br>
-gs/base/sha2.h
-<br>
-gs/base/shc.c
-<br>
-gs/base/shc.h
-<br>
-gs/base/shcgen.c
-<br>
-gs/base/shcgen.h
-<br>
-gs/base/sidscale.c
-<br>
-gs/base/sidscale.h
-<br>
-gs/base/siinterp.c
-<br>
-gs/base/siinterp.h
-<br>
-gs/base/simscale.c
-<br>
-gs/base/simscale.h
-<br>
-gs/base/siscale.c
-<br>
-gs/base/siscale.h
-<br>
-gs/base/sisparam.h
-<br>
-gs/base/sjbig2.c
-<br>
-gs/base/sjbig2.h
-<br>
-gs/base/sjbig2_luratech.c
-<br>
-gs/base/sjbig2_luratech.h
-<br>
-gs/base/sjpeg.h
-<br>
-gs/base/sjpegc.c
-<br>
-gs/base/sjpegd.c
-<br>
-gs/base/sjpege.c
-<br>
-gs/base/sjpx.c
-<br>
-gs/base/sjpx_luratech.c
-<br>
-gs/base/sjpx_luratech.h
-<br>
-gs/base/slzwc.c
-<br>
-gs/base/slzwd.c
-<br>
-gs/base/slzwe.c
-<br>
-gs/base/slzwx.h
-<br>
-gs/base/smd5.c
-<br>
-gs/base/smd5.h
-<br>
-gs/base/smtf.c
-<br>
-gs/base/smtf.h
-<br>
-gs/base/spdiff.c
-<br>
-gs/base/spdiffx.h
-<br>
-gs/base/spngp.c
-<br>
-gs/base/spngpx.h
-<br>
-gs/base/spprint.c
-<br>
-gs/base/spprint.h
-<br>
-gs/base/spsdf.c
-<br>
-gs/base/spsdf.h
-<br>
-gs/base/srdline.h
-<br>
-gs/base/srld.c
-<br>
-gs/base/srle.c
-<br>
-gs/base/srlx.h
-<br>
-gs/base/ssha2.c
-<br>
-gs/base/sstring.c
-<br>
-gs/base/sstring.h
-<br>
-gs/base/stat_.h
-<br>
-gs/base/std.h
-<br>
-gs/base/stdint_.h
-<br>
-gs/base/stdio_.h
-<br>
-gs/base/stdpn.h
-<br>
-gs/base/stdpre.h
-<br>
-gs/base/stream.c
-<br>
-gs/base/stream.h
-<br>
-gs/base/strimpl.h
-<br>
-gs/base/string_.h
-<br>
-gs/base/strmio.h
-<br>
-gs/base/szlibc.c
-<br>
-gs/base/szlibe.c
-<br>
-gs/base/szlibx.h
-<br>
-gs/base/szlibxx.h
-<br>
-gs/base/time_.h
-<br>
-gs/base/ttcalc.c
-<br>
-gs/base/ttcalc.h
-<br>
-gs/base/ttcommon.h
-<br>
-gs/base/ttconf.h
-<br>
-gs/base/ttconfig.h
-<br>
-gs/base/ttfinp.c
-<br>
-gs/base/ttfinp.h
-<br>
-gs/base/ttfmain.c
-<br>
-gs/base/ttfmemd.c
-<br>
-gs/base/ttfmemd.h
-<br>
-gs/base/ttfoutl.h
-<br>
-gs/base/ttfsfnt.h
-<br>
-gs/base/ttinterp.c
-<br>
-gs/base/ttinterp.h
-<br>
-gs/base/ttload.c
-<br>
-gs/base/ttload.h
-<br>
-gs/base/ttmisc.h
-<br>
-gs/base/ttobjs.c
-<br>
-gs/base/ttobjs.h
-<br>
-gs/base/tttables.h
-<br>
-gs/base/tttype.h
-<br>
-gs/base/tttypes.h
-<br>
-gs/base/unistd_.h
-<br>
-gs/base/valgrind.h
-<br>
-gs/base/vdtrace.c
-<br>
-gs/base/vdtrace.h
-<br>
-gs/base/vms_x_fix.h
-<br>
-gs/base/vmsmath.h
-<br>
-gs/base/whitelst.c
-<br>
-gs/base/whitelst.h
-<br>
-gs/base/windows_.h
-<br>
-gs/base/wtsimdi.c
-<br>
-gs/base/x_.h
-<br>
-gs/contrib/defs.h
-<br>
-gs/contrib/eplaser/gdevescv.c
-<br>
-gs/contrib/eplaser/gdevescv.h
-<br>
-gs/contrib/gdevbjc_.c
-<br>
-gs/contrib/gdevbjc_.h
-<br>
-gs/contrib/gdevbjca.c
-<br>
-gs/contrib/gdevcd8.c
-<br>
-gs/contrib/gdevdj9.c
-<br>
-gs/contrib/gdevgdi.c
-<br>
-gs/contrib/gdevhl12.c
-<br>
-gs/contrib/gdevln03.c
-<br>
-gs/contrib/gdevlx32.c
-<br>
-gs/contrib/gdevlx50.c
-<br>
-gs/contrib/gdevlx7.c
-<br>
-gs/contrib/gdevmd2k.c
-<br>
-gs/contrib/gdevop4w.c
-<br>
-gs/contrib/gdevxes.c
-<br>
-gs/contrib/gomni.c
-<br>
-gs/contrib/japanese/dviprlib.c
-<br>
-gs/contrib/japanese/dviprlib.h
-<br>
-gs/contrib/japanese/gdev10v.c
-<br>
-gs/contrib/japanese/gdevalps.c
-<br>
-gs/contrib/japanese/gdevdmpr.c
-<br>
-gs/contrib/japanese/gdevespg.c
-<br>
-gs/contrib/japanese/gdevfmlbp.c
-<br>
-gs/contrib/japanese/gdevfmpr.c
-<br>
-gs/contrib/japanese/gdevj100.c
-<br>
-gs/contrib/japanese/gdevlbp3.c
-<br>
-gs/contrib/japanese/gdevmag.c
-<br>
-gs/contrib/japanese/gdevmjc.c
-<br>
-gs/contrib/japanese/gdevmjc.h
-<br>
-gs/contrib/japanese/gdevml6.c
-<br>
-gs/contrib/japanese/gdevnpdl.c
-<br>
-gs/contrib/japanese/gdevp201.c
-<br>
-gs/contrib/japanese/gdevrpdl.c
-<br>
-gs/contrib/lips4/gdevl4r.c
-<br>
-gs/contrib/lips4/gdevl4v.c
-<br>
-gs/contrib/lips4/gdevlips.c
-<br>
-gs/contrib/lips4/gdevlips.h
-<br>
-gs/contrib/lips4/gdevlprn.c
-<br>
-gs/contrib/lips4/gdevlprn.h
-<br>
-gs/contrib/opvp/gdevopvp.c
-<br>
-gs/contrib/opvp/opvp.h
-<br>
-gs/contrib/opvp/opvp_0_2_0.h
-<br>
-gs/contrib/opvp/opvp_common.h
-<br>
-gs/contrib/pcl3/eprn/eprnfs.c
-<br>
-gs/contrib/pcl3/eprn/eprnparm.c
-<br>
-gs/contrib/pcl3/eprn/eprnrend.c
-<br>
-gs/contrib/pcl3/eprn/gdeveprn.h
-<br>
-gs/contrib/pcl3/eprn/mediasize.c
-<br>
-gs/contrib/pcl3/eprn/mediasize.h
-<br>
-gs/contrib/pcl3/eprn/pagecount.c
-<br>
-gs/contrib/pcl3/ps/calign.ps
-<br>
-gs/contrib/pcl3/ps/levels-test.ps
-<br>
-gs/contrib/pcl3/src/pcl3opts.c
-<br>
-gs/contrib/pcl3/src/pclcap.c
-<br>
-gs/contrib/pcl3/src/pclcomp.c
-<br>
-gs/contrib/pcl3/src/pclgen.c
-<br>
-gs/contrib/pcl3/src/pclgen.h
-<br>
-gs/contrib/pcl3/src/pclscan.c
-<br>
-gs/contrib/pcl3/src/pclscan.h
-<br>
-gs/contrib/pcl3/src/pclsize.c
-<br>
-gs/contrib/pcl3/src/pclsize.h
-<br>
-gs/contrib/pscolor/black.ps
-<br>
-gs/contrib/pscolor/color.ps
-<br>
-gs/contrib/pscolor/input.ps
-<br>
-gs/contrib/pscolor/test.c
-<br>
-gs/icclib/icc.c
-<br>
-gs/icclib/icc.h
-<br>
-gs/icclib/icc9809.h
-<br>
-gs/ijs/ijs.c
-<br>
-gs/ijs/ijs_client.c
-<br>
-gs/ijs/ijs_client.h
-<br>
-gs/ijs/ijs_client_example.c
-<br>
-gs/ijs/ijs_exec_unix.c
-<br>
-gs/ijs/ijs_exec_win.c
-<br>
-gs/ijs/ijs_server.c
-<br>
-gs/ijs/ijs_server.h
-<br>
-gs/ijs/ijs_server_example.c
-<br>
-gs/ijs/ijs_spec.ps
-<br>
-gs/imdi/arch.h
-<br>
-gs/imdi/cctiff.c
-<br>
-gs/imdi/cgen.c
-<br>
-gs/imdi/config.h
-<br>
-gs/imdi/copyright.h
-<br>
-gs/imdi/imdi.c
-<br>
-gs/imdi/imdi.h
-<br>
-gs/imdi/imdi_gen.c
-<br>
-gs/imdi/imdi_gen.h
-<br>
-gs/imdi/imdi_imp.h
-<br>
-gs/imdi/imdi_k.c
-<br>
-gs/imdi/imdi_k.h
-<br>
-gs/imdi/imdi_tab.c
-<br>
-gs/imdi/imdi_tab.h
-<br>
-gs/lib/EndOfTask.ps
-<br>
-gs/lib/PDFA_def.ps
-<br>
-gs/lib/PDFX_def.ps
-<br>
-gs/lib/acctest.ps
-<br>
-gs/lib/addxchar.ps
-<br>
-gs/lib/align.ps
-<br>
-gs/lib/bdftops.ps
-<br>
-gs/lib/caption.ps
-<br>
-gs/lib/cat.ps
-<br>
-gs/lib/cid2code.ps
-<br>
-gs/lib/docie.ps
-<br>
-gs/lib/dumphint.ps
-<br>
-gs/lib/font2c.ps
-<br>
-gs/lib/font2pcl.ps
-<br>
-gs/lib/gs_ce_e.ps
-<br>
-gs/lib/gs_cmdl.ps
-<br>
-gs/lib/gs_fform.ps
-<br>
-gs/lib/gs_il2_e.ps
-<br>
-gs/lib/gs_kanji.ps
-<br>
-gs/lib/gs_ksb_e.ps
-<br>
-gs/lib/gs_lgo_e.ps
-<br>
-gs/lib/gs_lgx_e.ps
-<br>
-gs/lib/gs_pfile.ps
-<br>
-gs/lib/gs_rdlin.ps
-<br>
-gs/lib/gs_wl1_e.ps
-<br>
-gs/lib/gs_wl2_e.ps
-<br>
-gs/lib/gs_wl5_e.ps
-<br>
-gs/lib/gslp.ps
-<br>
-gs/lib/gsnup.ps
-<br>
-gs/lib/image-qa.ps
-<br>
-gs/lib/impath.ps
-<br>
-gs/lib/jispaper.ps
-<br>
-gs/lib/landscap.ps
-<br>
-gs/lib/lines.ps
-<br>
-gs/lib/markhint.ps
-<br>
-gs/lib/markpath.ps
-<br>
-gs/lib/mkcidfm.ps
-<br>
-gs/lib/opdfread.ps
-<br>
-gs/lib/packfile.ps
-<br>
-gs/lib/pcharstr.ps
-<br>
-gs/lib/pdf2dsc.ps
-<br>
-gs/lib/pdfopt.ps
-<br>
-gs/lib/pdfwrite.ps
-<br>
-gs/lib/pf2afm.ps
-<br>
-gs/lib/pfbtopfa.ps
-<br>
-gs/lib/ppath.ps
-<br>
-gs/lib/pphs.ps
-<br>
-gs/lib/prfont.ps
-<br>
-gs/lib/printafm.ps
-<br>
-gs/lib/ps2ai.ps
-<br>
-gs/lib/ps2ascii.ps
-<br>
-gs/lib/ps2epsi.ps
-<br>
-gs/lib/rollconv.ps
-<br>
-gs/lib/showchar.ps
-<br>
-gs/lib/stcinfo.ps
-<br>
-gs/lib/stcolor.ps
-<br>
-gs/lib/stocht.ps
-<br>
-gs/lib/traceimg.ps
-<br>
-gs/lib/traceop.ps
-<br>
-gs/lib/type1enc.ps
-<br>
-gs/lib/type1ops.ps
-<br>
-gs/lib/uninfo.ps
-<br>
-gs/lib/unprot.ps
-<br>
-gs/lib/viewcmyk.ps
-<br>
-gs/lib/viewgif.ps
-<br>
-gs/lib/viewjpeg.ps
-<br>
-gs/lib/viewmiff.ps
-<br>
-gs/lib/viewpbm.ps
-<br>
-gs/lib/viewpcx.ps
-<br>
-gs/lib/viewps2a.ps
-<br>
-gs/lib/viewrgb.ps
-<br>
-gs/lib/wftopfa.ps
-<br>
-gs/lib/winmaps.ps
-<br>
-gs/lib/wrfont.ps
-<br>
-gs/lib/zeroline.ps
-<br>
-gs/psi/bfont.h
-<br>
-gs/psi/btoken.h
-<br>
-gs/psi/dmmain.c
-<br>
-gs/psi/dpmain.c
-<br>
-gs/psi/dscparse.c
-<br>
-gs/psi/dscparse.h
-<br>
-gs/psi/dstack.h
-<br>
-gs/psi/dwdll.c
-<br>
-gs/psi/dwdll.h
-<br>
-gs/psi/dwimg.c
-<br>
-gs/psi/dwimg.h
-<br>
-gs/psi/dwinst.h
-<br>
-gs/psi/dwmain.c
-<br>
-gs/psi/dwmainc.c
-<br>
-gs/psi/dwnodll.c
-<br>
-gs/psi/dwreg.c
-<br>
-gs/psi/dwreg.h
-<br>
-gs/psi/dwres.h
-<br>
-gs/psi/dwsetup.h
-<br>
-gs/psi/dwtext.c
-<br>
-gs/psi/dwtext.h
-<br>
-gs/psi/dwtrace.c
-<br>
-gs/psi/dwtrace.h
-<br>
-gs/psi/dwuninst.h
-<br>
-gs/psi/dxmain.c
-<br>
-gs/psi/dxmainc.c
-<br>
-gs/psi/estack.h
-<br>
-gs/psi/fapi_ft.c
-<br>
-gs/psi/fapibstm.c
-<br>
-gs/psi/fapiufst.c
-<br>
-gs/psi/files.h
-<br>
-gs/psi/ghost.h
-<br>
-gs/psi/gs.c
-<br>
-gs/psi/gsdll.c
-<br>
-gs/psi/gserver.c
-<br>
-gs/psi/ialloc.c
-<br>
-gs/psi/ialloc.h
-<br>
-gs/psi/iapi.c
-<br>
-gs/psi/iapi.h
-<br>
-gs/psi/iastate.h
-<br>
-gs/psi/iastruct.h
-<br>
-gs/psi/ibnum.c
-<br>
-gs/psi/ibnum.h
-<br>
-gs/psi/ichar.h
-<br>
-gs/psi/ichar1.h
-<br>
-gs/psi/icharout.h
-<br>
-gs/psi/icid.h
-<br>
-gs/psi/icie.h
-<br>
-gs/psi/icolor.h
-<br>
-gs/psi/iconf.c
-<br>
-gs/psi/iconf.h
-<br>
-gs/psi/icontext.c
-<br>
-gs/psi/icontext.h
-<br>
-gs/psi/icremap.h
-<br>
-gs/psi/icsmap.h
-<br>
-gs/psi/icstate.h
-<br>
-gs/psi/iddict.h
-<br>
-gs/psi/iddstack.h
-<br>
-gs/psi/idebug.c
-<br>
-gs/psi/idebug.h
-<br>
-gs/psi/idict.c
-<br>
-gs/psi/idict.h
-<br>
-gs/psi/idictdef.h
-<br>
-gs/psi/idicttpl.h
-<br>
-gs/psi/idisp.c
-<br>
-gs/psi/idisp.h
-<br>
-gs/psi/idosave.h
-<br>
-gs/psi/idparam.c
-<br>
-gs/psi/idparam.h
-<br>
-gs/psi/idsdata.h
-<br>
-gs/psi/idstack.c
-<br>
-gs/psi/idstack.h
-<br>
-gs/psi/ierrors.h
-<br>
-gs/psi/iesdata.h
-<br>
-gs/psi/iestack.h
-<br>
-gs/psi/ifapi.h
-<br>
-gs/psi/ifcid.h
-<br>
-gs/psi/ifilter.h
-<br>
-gs/psi/ifilter2.h
-<br>
-gs/psi/ifont.h
-<br>
-gs/psi/ifont1.h
-<br>
-gs/psi/ifont2.h
-<br>
-gs/psi/ifont42.h
-<br>
-gs/psi/ifrpred.h
-<br>
-gs/psi/ifunc.h
-<br>
-gs/psi/ifwpred.h
-<br>
-gs/psi/igc.c
-<br>
-gs/psi/igc.h
-<br>
-gs/psi/igcref.c
-<br>
-gs/psi/igcstr.c
-<br>
-gs/psi/igcstr.h
-<br>
-gs/psi/igstate.h
-<br>
-gs/psi/iht.h
-<br>
-gs/psi/iimage.h
-<br>
-gs/psi/iimage2.h
-<br>
-gs/psi/iinit.c
-<br>
-gs/psi/iinit.h
-<br>
-gs/psi/ilevel.h
-<br>
-gs/psi/ilocate.c
-<br>
-gs/psi/imain.c
-<br>
-gs/psi/imain.h
-<br>
-gs/psi/imainarg.h
-<br>
-gs/psi/imemory.h
-<br>
-gs/psi/iminst.h
-<br>
-gs/psi/iname.c
-<br>
-gs/psi/iname.h
-<br>
-gs/psi/inamedef.h
-<br>
-gs/psi/inameidx.h
-<br>
-gs/psi/inames.h
-<br>
-gs/psi/inamestr.h
-<br>
-gs/psi/inobtokn.c
-<br>
-gs/psi/inouparm.c
-<br>
-gs/psi/interp.h
-<br>
-gs/psi/iosdata.h
-<br>
-gs/psi/iostack.h
-<br>
-gs/psi/ipacked.h
-<br>
-gs/psi/iparam.c
-<br>
-gs/psi/iparam.h
-<br>
-gs/psi/iparray.h
-<br>
-gs/psi/ipcolor.h
-<br>
-gs/psi/iplugin.c
-<br>
-gs/psi/iplugin.h
-<br>
-gs/psi/ireclaim.c
-<br>
-gs/psi/iref.h
-<br>
-gs/psi/isave.c
-<br>
-gs/psi/isave.h
-<br>
-gs/psi/iscanbin.c
-<br>
-gs/psi/iscanbin.h
-<br>
-gs/psi/iscannum.c
-<br>
-gs/psi/iscannum.h
-<br>
-gs/psi/isdata.h
-<br>
-gs/psi/isstate.h
-<br>
-gs/psi/istack.c
-<br>
-gs/psi/istack.h
-<br>
-gs/psi/istkparm.h
-<br>
-gs/psi/istream.h
-<br>
-gs/psi/istruct.h
-<br>
-gs/psi/iutil.c
-<br>
-gs/psi/iutil.h
-<br>
-gs/psi/iutil2.c
-<br>
-gs/psi/iutil2.h
-<br>
-gs/psi/ivmem2.h
-<br>
-gs/psi/ivmspace.h
-<br>
-gs/psi/main.h
-<br>
-gs/psi/oparc.h
-<br>
-gs/psi/opcheck.h
-<br>
-gs/psi/opdef.h
-<br>
-gs/psi/oper.h
-<br>
-gs/psi/opextern.h
-<br>
-gs/psi/ostack.h
-<br>
-gs/psi/sfilter1.c
-<br>
-gs/psi/store.h
-<br>
-gs/psi/wrfont.c
-<br>
-gs/psi/wrfont.h
-<br>
-gs/psi/write_t1.c
-<br>
-gs/psi/write_t1.h
-<br>
-gs/psi/write_t2.c
-<br>
-gs/psi/write_t2.h
-<br>
-gs/psi/zalg.c
-<br>
-gs/psi/zarith.c
-<br>
-gs/psi/zarray.c
-<br>
-gs/psi/zbfont.c
-<br>
-gs/psi/zbseq.c
-<br>
-gs/psi/zcfont.c
-<br>
-gs/psi/zchar.c
-<br>
-gs/psi/zchar1.c
-<br>
-gs/psi/zchar2.c
-<br>
-gs/psi/zchar32.c
-<br>
-gs/psi/zchar42.c
-<br>
-gs/psi/zchar42.h
-<br>
-gs/psi/zcharout.c
-<br>
-gs/psi/zcharx.c
-<br>
-gs/psi/zcid.c
-<br>
-gs/psi/zcidtest.c
-<br>
-gs/psi/zcie.c
-<br>
-gs/psi/zcie.h
-<br>
-gs/psi/zcolor.c
-<br>
-gs/psi/zcolor.h
-<br>
-gs/psi/zcolor1.c
-<br>
-gs/psi/zcolor2.c
-<br>
-gs/psi/zcolor3.c
-<br>
-gs/psi/zcontext.c
-<br>
-gs/psi/zcontrol.c
-<br>
-gs/psi/zcrd.c
-<br>
-gs/psi/zcsdevn.c
-<br>
-gs/psi/zcsindex.c
-<br>
-gs/psi/zcspixel.c
-<br>
-gs/psi/zcssepr.c
-<br>
-gs/psi/zdevcal.c
-<br>
-gs/psi/zdevice.c
-<br>
-gs/psi/zdevice2.c
-<br>
-gs/psi/zdfilter.c
-<br>
-gs/psi/zdict.c
-<br>
-gs/psi/zdosio.c
-<br>
-gs/psi/zdouble.c
-<br>
-gs/psi/zdpnext.c
-<br>
-gs/psi/zdps.c
-<br>
-gs/psi/zdps1.c
-<br>
-gs/psi/zdscpars.c
-<br>
-gs/psi/zfaes.c
-<br>
-gs/psi/zfapi.c
-<br>
-gs/psi/zfarc4.c
-<br>
-gs/psi/zfbcp.c
-<br>
-gs/psi/zfcid.c
-<br>
-gs/psi/zfcid0.c
-<br>
-gs/psi/zfcid1.c
-<br>
-gs/psi/zfcmap.c
-<br>
-gs/psi/zfdctd.c
-<br>
-gs/psi/zfdcte.c
-<br>
-gs/psi/zfdecode.c
-<br>
-gs/psi/zfile.c
-<br>
-gs/psi/zfile.h
-<br>
-gs/psi/zfile1.c
-<br>
-gs/psi/zfileio.c
-<br>
-gs/psi/zfilter.c
-<br>
-gs/psi/zfilter2.c
-<br>
-gs/psi/zfilterx.c
-<br>
-gs/psi/zfimscale.c
-<br>
-gs/psi/zfjbig2.c
-<br>
-gs/psi/zfjpx.c
-<br>
-gs/psi/zfmd5.c
-<br>
-gs/psi/zfont.c
-<br>
-gs/psi/zfont0.c
-<br>
-gs/psi/zfont1.c
-<br>
-gs/psi/zfont2.c
-<br>
-gs/psi/zfont32.c
-<br>
-gs/psi/zfont42.c
-<br>
-gs/psi/zfontenum.c
-<br>
-gs/psi/zfproc.c
-<br>
-gs/psi/zfrsd.c
-<br>
-gs/psi/zfrsd.h
-<br>
-gs/psi/zfsample.c
-<br>
-gs/psi/zfunc.c
-<br>
-gs/psi/zfunc.h
-<br>
-gs/psi/zfunc0.c
-<br>
-gs/psi/zfunc3.c
-<br>
-gs/psi/zfunc4.c
-<br>
-gs/psi/zfzlib.c
-<br>
-gs/psi/zgeneric.c
-<br>
-gs/psi/zgstate.c
-<br>
-gs/psi/zhsb.c
-<br>
-gs/psi/zht.c
-<br>
-gs/psi/zht1.c
-<br>
-gs/psi/zht2.c
-<br>
-gs/psi/zht2.h
-<br>
-gs/psi/zicc.c
-<br>
-gs/psi/zicc.h
-<br>
-gs/psi/zimage.c
-<br>
-gs/psi/zimage2.c
-<br>
-gs/psi/zimage3.c
-<br>
-gs/psi/ziodev2.c
-<br>
-gs/psi/ziodevs.c
-<br>
-gs/psi/ziodevsc.c
-<br>
-gs/psi/zmath.c
-<br>
-gs/psi/zmatrix.c
-<br>
-gs/psi/zmedia2.c
-<br>
-gs/psi/zmisc.c
-<br>
-gs/psi/zmisc1.c
-<br>
-gs/psi/zmisc2.c
-<br>
-gs/psi/zmisc3.c
-<br>
-gs/psi/zncdummy.c
-<br>
-gs/psi/zpacked.c
-<br>
-gs/psi/zpaint.c
-<br>
-gs/psi/zpath.c
-<br>
-gs/psi/zpath1.c
-<br>
-gs/psi/zpcolor.c
-<br>
-gs/psi/zpdfops.c
-<br>
-gs/psi/zrelbit.c
-<br>
-gs/psi/zrop.c
-<br>
-gs/psi/zshade.c
-<br>
-gs/psi/zstack.c
-<br>
-gs/psi/zstring.c
-<br>
-gs/psi/zsysvm.c
-<br>
-gs/psi/ztrans.c
-<br>
-gs/psi/ztrap.c
-<br>
-gs/psi/zupath.c
-<br>
-gs/psi/zusparam.c
-<br>
-gs/psi/zutf8.c
-<br>
-gs/psi/zvmem.c
-<br>
-gs/psi/zvmem2.c
-<br>
-gs/psi/zwinutf8.c
-<br>
-gs/toolbin/GenSubstCID.ps
-<br>
-gs/toolbin/bmpcmp.c
-<br>
-gs/toolbin/color/halftone/halfttoning/halftone.c
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/CIELAB.h
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_Creator.h
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.h
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/icc34.h
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/icc_create.h
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/resource.h
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/stdafx.h
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/targetver.h
-<br>
-gs/toolbin/drawafm.ps
-<br>
-gs/toolbin/encs2c.ps
-<br>
-gs/toolbin/extractFonts.ps
-<br>
-gs/toolbin/extractICCprofiles.ps
-<br>
-gs/toolbin/genfontmap.ps
-<br>
-gs/toolbin/jpxtopdf.c
-<br>
-gs/toolbin/pdf_info.ps
-<br>
-gs/toolbin/pdfinflt.ps
-<br>
-gs/toolbin/tests/fuzzy.c
-<br>
-pcl/pcbiptrn.c
-<br>
-pcl/pccid.c
-<br>
-pcl/pccolor.c
-<br>
-pcl/pccprint.c
-<br>
-pcl/pccrd.c
-<br>
-pcl/pccrd.h
-<br>
-pcl/pccsbase.c
-<br>
-pcl/pccsbase.h
-<br>
-pcl/pcdict.h
-<br>
-pcl/pcdraw.c
-<br>
-pcl/pcfont.c
-<br>
-pcl/pcfont.h
-<br>
-pcl/pcfontpg.c
-<br>
-pcl/pcfrgrnd.c
-<br>
-pcl/pcfrgrnd.h
-<br>
-pcl/pcfsel.c
-<br>
-pcl/pcfsel.h
-<br>
-pcl/pcht.c
-<br>
-pcl/pcht.h
-<br>
-pcl/pcimpl.c
-<br>
-pcl/pcindxed.c
-<br>
-pcl/pcindxed.h
-<br>
-pcl/pcjob.c
-<br>
-pcl/pclookup.c
-<br>
-pcl/pclookup.h
-<br>
-pcl/pcmacros.c
-<br>
-pcl/pcmisc.c
-<br>
-pcl/pcmtx3.c
-<br>
-pcl/pcmtx3.h
-<br>
-pcl/pcommand.c
-<br>
-pcl/pcommand.h
-<br>
-pcl/pcpage.c
-<br>
-pcl/pcpalet.c
-<br>
-pcl/pcpalet.h
-<br>
-pcl/pcparse.c
-<br>
-pcl/pcparse.h
-<br>
-pcl/pcpatrn.c
-<br>
-pcl/pcpatrn.h
-<br>
-pcl/pcpattyp.h
-<br>
-pcl/pcpatxfm.c
-<br>
-pcl/pcpatxfm.h
-<br>
-pcl/pcrect.c
-<br>
-pcl/pcsfont.c
-<br>
-pcl/pcstate.h
-<br>
-pcl/pcstatus.c
-<br>
-pcl/pcsymbol.c
-<br>
-pcl/pcsymbol.h
-<br>
-pcl/pctext.c
-<br>
-pcl/pctop.c
-<br>
-pcl/pctop.h
-<br>
-pcl/pctpm.h
-<br>
-pcl/pcuptrn.c
-<br>
-pcl/pcursor.c
-<br>
-pcl/pcwhtidx.c
-<br>
-pcl/pcxfmst.h
-<br>
-pcl/pgchar.c
-<br>
-pcl/pgcolor.c
-<br>
-pcl/pgconfig.c
-<br>
-pcl/pgdraw.c
-<br>
-pcl/pgdraw.h
-<br>
-pcl/pgfdata.c
-<br>
-pcl/pgfdata.h
-<br>
-pcl/pgfont.c
-<br>
-pcl/pgframe.c
-<br>
-pcl/pggeom.c
-<br>
-pcl/pggeom.h
-<br>
-pcl/pglabel.c
-<br>
-pcl/pglfill.c
-<br>
-pcl/pgmisc.c
-<br>
-pcl/pgmisc.h
-<br>
-pcl/pgparse.c
-<br>
-pcl/pgpoly.c
-<br>
-pcl/pgstate.h
-<br>
-pcl/rtgmode.c
-<br>
-pcl/rtgmode.h
-<br>
-pcl/rtmisc.c
-<br>
-pcl/rtraster.c
-<br>
-pcl/rtrstcmp.c
-<br>
-pcl/rtrstcmp.h
-<br>
-pcl/rtrstst.h
-<br>
-pl/dwimg.c
-<br>
-pl/dwimg.h
-<br>
-pl/dwmainc.c
-<br>
-pl/dwreg.c
-<br>
-pl/dwreg.h
-<br>
-pl/dwres.h
-<br>
-pl/pjparse.c
-<br>
-pl/pjparse.h
-<br>
-pl/pjparsei.c
-<br>
-pl/pjtop.c
-<br>
-pl/pjtop.h
-<br>
-pl/plalloc.c
-<br>
-pl/plalloc.h
-<br>
-pl/plapi.h
-<br>
-pl/plchar.c
-<br>
-pl/pldict.c
-<br>
-pl/pldict.h
-<br>
-pl/pldraw.c
-<br>
-pl/plfont.c
-<br>
-pl/plfont.h
-<br>
-pl/plftable.c
-<br>
-pl/plht.c
-<br>
-pl/plimpl.c
-<br>
-pl/pllfont.c
-<br>
-pl/plmain.c
-<br>
-pl/plplatf.c
-<br>
-pl/plplatf.h
-<br>
-pl/plplatfps.c
-<br>
-pl/plsrgb.c
-<br>
-pl/plsymbol.c
-<br>
-pl/plsymbol.h
-<br>
-pl/pltop.c
-<br>
-pl/pltop.h
-<br>
-pl/pltoputl.c
-<br>
-pl/pltoputl.h
-<br>
-pl/pluchar.c
-<br>
-pl/plufont.c
-<br>
-pl/plulfont.c
-<br>
-pl/plvocab.c
-<br>
-psi/psitop.c
-<br>
-pxl/pxasm.ps
-<br>
-pxl/pxbfont.c
-<br>
-pxl/pxbfont.ps
-<br>
-pxl/pxerrors.h
-<br>
-pxl/pxffont.c
-<br>
-pxl/pxfont.c
-<br>
-pxl/pxgstate.c
-<br>
-pxl/pxgstate.h
-<br>
-pxl/pximage.c
-<br>
-pxl/pximpl.c
-<br>
-pxl/pxink.c
-<br>
-pxl/pxoper.h
-<br>
-pxl/pxpaint.c
-<br>
-pxl/pxparse.c
-<br>
-pxl/pxparse.h
-<br>
-pxl/pxpthr.c
-<br>
-pxl/pxsessio.c
-<br>
-pxl/pxstate.c
-<br>
-pxl/pxstate.h
-<br>
-pxl/pxstream.c
-<br>
-pxl/pxsymbol.ps
-<br>
-pxl/pxtop.c
-<br>
-pxl/pxvalue.c
-<br>
-pxl/pxvalue.h
-<br>
-svg/ghostsvg.h
-<br>
-svg/svgcolor.c
-<br>
-svg/svgdoc.c
-<br>
-svg/svgshapes.c
-<br>
-svg/svgtop.c
-<br>
-svg/svgtransform.c
-<br>
-svg/svgtypes.c
-<br>
-svg/svgxml.c
-<br>
-tools/GOT/detag.c
-<br>
-tools/GOT/tagimage.c
-<br>
-tools/gslite/gslt.h
-<br>
-tools/gslite/gslt_alloc.c
-<br>
-tools/gslite/gslt_alloc.h
-<br>
-tools/gslite/gslt_font.h
-<br>
-tools/gslite/gslt_font_api.c
-<br>
-tools/gslite/gslt_font_api.h
-<br>
-tools/gslite/gslt_font_api_test.c
-<br>
-tools/gslite/gslt_font_cache.c
-<br>
-tools/gslite/gslt_font_cff.c
-<br>
-tools/gslite/gslt_font_encoding.c
-<br>
-tools/gslite/gslt_font_glyph.c
-<br>
-tools/gslite/gslt_font_int.h
-<br>
-tools/gslite/gslt_font_test.c
-<br>
-tools/gslite/gslt_font_ttf.c
-<br>
-tools/gslite/gslt_image.c
-<br>
-tools/gslite/gslt_image.h
-<br>
-tools/gslite/gslt_image_jpeg.c
-<br>
-tools/gslite/gslt_image_png.c
-<br>
-tools/gslite/gslt_image_test.c
-<br>
-tools/gslite/gslt_image_threads_test.c
-<br>
-tools/gslite/gslt_image_tiff.c
-<br>
-tools/gslite/gslt_init.c
-<br>
-tools/gslite/gslt_test.c
-<br>
-tools/tt2pcl.c
-<br>
-tools/xps2tiff/xps2tiff/stdafx.h
-<br>
-xps/xpsgradient.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-19 23:40:49 +0200></a>
-2011-04-19 23:40:49 +0200</strong>
-<br>Tor Andersson <tor.andersson@artifex.com><br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0b17959f31afe3baffbc328e7f92e88e634ad8b8">0b17959f31afe3baffbc328e7f92e88e634ad8b8</a>
-<blockquote>
-
-<br>
-Introduce end-of-line normalization.
-<br>
-
-<br>
-.gitattributes
-<br>
-.gitignore
-<br>
-COPYING.AFPL
-<br>
-gs/.gitignore
-<br>
-gs/Resource/Init/FAPIcidfmap
-<br>
-gs/Resource/Init/FAPIconfig
-<br>
-gs/Resource/Init/FAPIfontmap
-<br>
-gs/Resource/Init/gs_agl.ps
-<br>
-gs/Resource/Init/gs_mgl_e.ps
-<br>
-gs/Resource/Init/gs_mro_e.ps
-<br>
-gs/base/gdevplib.c
-<br>
-gs/base/gs_agl.h
-<br>
-gs/base/gs_mgl_e.h
-<br>
-gs/base/gs_mro_e.h
-<br>
-gs/base/gsicc_lcms2.c
-<br>
-gs/base/gxht_thresh.c
-<br>
-gs/base/gxht_thresh.h
-<br>
-gs/base/lcups.mak
-<br>
-gs/base/lcupsi.mak
-<br>
-gs/base/opdfread.h
-<br>
-gs/base/whitelst.c
-<br>
-gs/base/whitelst.h
-<br>
-gs/cups/libs/filter/image-colorspace.c
-<br>
-gs/doc/Details9.htm
-<br>
-gs/doc/GS9_Color_Management.tex
-<br>
-gs/doc/History9.htm
-<br>
-gs/doc/figures/Overview.eps
-<br>
-gs/expat/examples/elements.dsp
-<br>
-gs/expat/examples/outline.dsp
-<br>
-gs/expat/expat.dsw
-<br>
-gs/expat/lib/expat.dsp
-<br>
-gs/expat/lib/expat_static.dsp
-<br>
-gs/expat/lib/expatw.dsp
-<br>
-gs/expat/lib/expatw_static.dsp
-<br>
-gs/expat/tests/benchmark/benchmark.dsp
-<br>
-gs/expat/tests/benchmark/benchmark.dsw
-<br>
-gs/expat/xmlwf/xmlwf.dsp
-<br>
-gs/freetype/builds/win32/vc2005/freetype.sln
-<br>
-gs/freetype/builds/win32/vc2005/freetype.vcproj
-<br>
-gs/freetype/builds/win32/vc2008/freetype.sln
-<br>
-gs/freetype/builds/win32/vc2008/freetype.vcproj
-<br>
-gs/freetype/builds/win32/visualc/freetype.dsp
-<br>
-gs/freetype/builds/win32/visualc/freetype.dsw
-<br>
-gs/freetype/builds/win32/visualc/freetype.sln
-<br>
-gs/freetype/builds/win32/visualc/freetype.vcproj
-<br>
-gs/freetype/builds/win32/visualce/freetype.dsp
-<br>
-gs/freetype/builds/win32/visualce/freetype.dsw
-<br>
-gs/freetype/builds/win32/visualce/freetype.vcproj
-<br>
-gs/freetype/builds/wince/vc2005-ce/freetype.sln
-<br>
-gs/freetype/builds/wince/vc2005-ce/freetype.vcproj
-<br>
-gs/freetype/builds/wince/vc2008-ce/freetype.sln
-<br>
-gs/freetype/builds/wince/vc2008-ce/freetype.vcproj
-<br>
-gs/ghostscript-ufst.vcproj
-<br>
-gs/ghostscript.vcproj
-<br>
-gs/jasper/src/msvc/imgcmp.dsp
-<br>
-gs/jasper/src/msvc/imginfo.dsp
-<br>
-gs/jasper/src/msvc/jasper.dsp
-<br>
-gs/jasper/src/msvc/jasper.dsw
-<br>
-gs/jasper/src/msvc/jiv.dsp
-<br>
-gs/jasper/src/msvc/libjasper.dsp
-<br>
-gs/jpegxr/APP.rc
-<br>
-gs/jpegxr/APP.vcproj
-<br>
-gs/jpegxr/DLL.rc
-<br>
-gs/jpegxr/DLL.vcproj
-<br>
-gs/jpegxr/JPEG-XR.sln
-<br>
-gs/lcms/Delphi/Samples/MAKETEST.BAT
-<br>
-gs/lcms/Delphi/Samples/gamutchk.pas
-<br>
-gs/lcms/Projects/BorlandC_5.5/lcms.rc
-<br>
-gs/lcms/Projects/BorlandC_5.5/lcmsdll.lk
-<br>
-gs/lcms/Projects/BorlandC_5.5/lcmsdll.lst
-<br>
-gs/lcms/Projects/BorlandC_5.5/mklcmsdll.bat
-<br>
-gs/lcms/Projects/VC2005/Python.vcproj
-<br>
-gs/lcms/Projects/VC2005/Testbed.vcproj
-<br>
-gs/lcms/Projects/VC2005/icc2ps.vcproj
-<br>
-gs/lcms/Projects/VC2005/icclink.vcproj
-<br>
-gs/lcms/Projects/VC2005/icctrans.vcproj
-<br>
-gs/lcms/Projects/VC2005/jpegicc.vcproj
-<br>
-gs/lcms/Projects/VC2005/lcms.rc
-<br>
-gs/lcms/Projects/VC2005/lcms.sln
-<br>
-gs/lcms/Projects/VC2005/lcms.vcproj
-<br>
-gs/lcms/Projects/VC2005/lcmsdll.vcproj
-<br>
-gs/lcms/Projects/VC2005/tiffdiff.vcproj
-<br>
-gs/lcms/Projects/VC2005/tifficc.vcproj
-<br>
-gs/lcms/Projects/VC2008/Python.vcproj
-<br>
-gs/lcms/Projects/VC2008/Testbed.vcproj
-<br>
-gs/lcms/Projects/VC2008/icc2ps.vcproj
-<br>
-gs/lcms/Projects/VC2008/icclink.vcproj
-<br>
-gs/lcms/Projects/VC2008/icctrans.vcproj
-<br>
-gs/lcms/Projects/VC2008/jpegicc.vcproj
-<br>
-gs/lcms/Projects/VC2008/lcms.rc
-<br>
-gs/lcms/Projects/VC2008/lcms.sln
-<br>
-gs/lcms/Projects/VC2008/lcms.vcproj
-<br>
-gs/lcms/Projects/VC2008/lcmsdll.vcproj
-<br>
-gs/lcms/Projects/VC2008/tiffdiff.vcproj
-<br>
-gs/lcms/Projects/VC2008/tifficc.vcproj
-<br>
-gs/lcms/Projects/VC6/Python.dsp
-<br>
-gs/lcms/Projects/VC6/Python.plg
-<br>
-gs/lcms/Projects/VC6/Testbed.dsp
-<br>
-gs/lcms/Projects/VC6/Testbed.plg
-<br>
-gs/lcms/Projects/VC6/icc2ps.dsp
-<br>
-gs/lcms/Projects/VC6/icclink.dsp
-<br>
-gs/lcms/Projects/VC6/icctrans.dsp
-<br>
-gs/lcms/Projects/VC6/jpegicc.dsp
-<br>
-gs/lcms/Projects/VC6/lcms.dsp
-<br>
-gs/lcms/Projects/VC6/lcms.dsw
-<br>
-gs/lcms/Projects/VC6/lcms.rc
-<br>
-gs/lcms/Projects/VC6/lcmsdll.dsp
-<br>
-gs/lcms/Projects/VC6/tifficc.dsp
-<br>
-gs/lcms/Projects/VC7/Python.vcproj
-<br>
-gs/lcms/Projects/VC7/Testbed.vcproj
-<br>
-gs/lcms/Projects/VC7/icc2ps.vcproj
-<br>
-gs/lcms/Projects/VC7/icclink.vcproj
-<br>
-gs/lcms/Projects/VC7/icctrans.vcproj
-<br>
-gs/lcms/Projects/VC7/jpegicc.vcproj
-<br>
-gs/lcms/Projects/VC7/lcms.rc
-<br>
-gs/lcms/Projects/VC7/lcms.sln
-<br>
-gs/lcms/Projects/VC7/lcms.vcproj
-<br>
-gs/lcms/Projects/VC7/lcmsdll.vcproj
-<br>
-gs/lcms/Projects/VC7/tiffdiff.vcproj
-<br>
-gs/lcms/Projects/VC7/tifficc.vcproj
-<br>
-gs/lcms2/Projects/VC2010/lcms2_static/lcms2_static.vcxproj
-<br>
-gs/lcms2/utils/delphi/delphidemo.dpr
-<br>
-gs/lcms2/utils/delphi/delphidemo.dproj
-<br>
-gs/lcms2/utils/delphi/demo1.pas
-<br>
-gs/lcms2/utils/delphi/lcms2dll.pas
-<br>
-gs/lcms2/utils/matlab/icctrans.c
-<br>
-gs/lib/opdfread.ps
-<br>
-gs/libpng/contrib/visupng/VisualPng.dsp
-<br>
-gs/libpng/contrib/visupng/VisualPng.dsw
-<br>
-gs/libpng/contrib/visupng/VisualPng.rc
-<br>
-gs/libpng/projects/cbuilder5/libpng.bpf
-<br>
-gs/libpng/projects/cbuilder5/libpng.bpg
-<br>
-gs/libpng/projects/cbuilder5/libpng.bpr
-<br>
-gs/libpng/projects/cbuilder5/libpng.cpp
-<br>
-gs/libpng/projects/cbuilder5/libpngstat.bpf
-<br>
-gs/libpng/projects/cbuilder5/libpngstat.bpr
-<br>
-gs/libpng/projects/visualc6/libpng.dsp
-<br>
-gs/libpng/projects/visualc6/libpng.dsw
-<br>
-gs/libpng/projects/visualc6/pngtest.dsp
-<br>
-gs/libpng/projects/visualc71/libpng.sln
-<br>
-gs/libpng/projects/visualc71/libpng.vcproj
-<br>
-gs/libpng/projects/visualc71/pngtest.vcproj
-<br>
-gs/libpng/projects/visualc71/zlib.vcproj
-<br>
-gs/psi/dw64c.def
-<br>
-gs/psi/dwmain64.def
-<br>
-gs/psi/gsdll64.def
-<br>
-gs/psi/msvc.mak
-<br>
-gs/psi/msvc64.mak
-<br>
-gs/psi/nsisinst.nsi
-<br>
-gs/tiff/man/tiffcrop.1
-<br>
-gs/toolbin/color/halftone/README
-<br>
-gs/toolbin/color/halftone/halfttoning.sln
-<br>
-gs/toolbin/color/halftone/halfttoning/halftone.c
-<br>
-gs/toolbin/color/halftone/halfttoning/halfttoning.vcproj
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator.sln
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_Creator.rc
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_Creator.vcproj
-<br>
-gs/toolbin/color/icc_creator/ucr_bg.txt
-<br>
-gs/toolbin/gen_ldf_jb2.py
-<br>
-gs/toolbin/pdf_info.ps
-<br>
-gs/zlib/contrib/dotzlib/DotZLib.build
-<br>
-gs/zlib/contrib/dotzlib/DotZLib.sln
-<br>
-gs/zlib/contrib/dotzlib/DotZLib/AssemblyInfo.cs
-<br>
-gs/zlib/contrib/dotzlib/DotZLib/ChecksumImpl.cs
-<br>
-gs/zlib/contrib/dotzlib/DotZLib/CircularBuffer.cs
-<br>
-gs/zlib/contrib/dotzlib/DotZLib/CodecBase.cs
-<br>
-gs/zlib/contrib/dotzlib/DotZLib/Deflater.cs
-<br>
-gs/zlib/contrib/dotzlib/DotZLib/DotZLib.cs
-<br>
-gs/zlib/contrib/dotzlib/DotZLib/DotZLib.csproj
-<br>
-gs/zlib/contrib/dotzlib/DotZLib/GZipStream.cs
-<br>
-gs/zlib/contrib/dotzlib/DotZLib/Inflater.cs
-<br>
-gs/zlib/contrib/dotzlib/DotZLib/UnitTests.cs
-<br>
-gs/zlib/contrib/masm686/match.asm
-<br>
-gs/zlib/contrib/masmx64/bld_ml64.bat
-<br>
-gs/zlib/contrib/masmx64/gvmat64.asm
-<br>
-gs/zlib/contrib/masmx64/inffas8664.c
-<br>
-gs/zlib/contrib/masmx64/inffasx64.asm
-<br>
-gs/zlib/contrib/masmx86/bld_ml32.bat
-<br>
-gs/zlib/contrib/masmx86/gvmat32.asm
-<br>
-gs/zlib/contrib/masmx86/gvmat32c.c
-<br>
-gs/zlib/contrib/masmx86/inffas32.asm
-<br>
-gs/zlib/contrib/masmx86/mkasm.bat
-<br>
-gs/zlib/contrib/vstudio/vc7/miniunz.vcproj
-<br>
-gs/zlib/contrib/vstudio/vc7/minizip.vcproj
-<br>
-gs/zlib/contrib/vstudio/vc7/testzlib.vcproj
-<br>
-gs/zlib/contrib/vstudio/vc7/zlib.rc
-<br>
-gs/zlib/contrib/vstudio/vc7/zlibstat.vcproj
-<br>
-gs/zlib/contrib/vstudio/vc7/zlibvc.def
-<br>
-gs/zlib/contrib/vstudio/vc7/zlibvc.sln
-<br>
-gs/zlib/contrib/vstudio/vc7/zlibvc.vcproj
-<br>
-gs/zlib/contrib/vstudio/vc8/miniunz.vcproj
-<br>
-gs/zlib/contrib/vstudio/vc8/minizip.vcproj
-<br>
-gs/zlib/contrib/vstudio/vc8/testzlib.vcproj
-<br>
-gs/zlib/contrib/vstudio/vc8/testzlibdll.vcproj
-<br>
-gs/zlib/contrib/vstudio/vc8/zlib.rc
-<br>
-gs/zlib/contrib/vstudio/vc8/zlibstat.vcproj
-<br>
-gs/zlib/contrib/vstudio/vc8/zlibvc.def
-<br>
-gs/zlib/contrib/vstudio/vc8/zlibvc.sln
-<br>
-gs/zlib/contrib/vstudio/vc8/zlibvc.vcproj
-<br>
-gs/zlib/projects/visualc6/example.dsp
-<br>
-gs/zlib/projects/visualc6/minigzip.dsp
-<br>
-gs/zlib/projects/visualc6/zlib.dsp
-<br>
-gs/zlib/projects/visualc6/zlib.dsw
-<br>
-pl/dwimg.c
-<br>
-pl/dwimg.h
-<br>
-pl/dwmainc.c
-<br>
-pl/dwreg.c
-<br>
-pl/dwreg.h
-<br>
-pl/dwres.h
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff.sln
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff.vb
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff.vbproj
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Application.Designer.vb
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Application.myapp
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/AssemblyInfo.vb
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Resources.Designer.vb
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Resources.resx
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Settings.Designer.vb
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/Acrobat2Tiff/Settings.settings
-<br>
-tools/Acrobat2Tiff/Acrobat2Tiff/bin/Release/Acrobat2Tiff.xml
-<br>
-tools/GOT/detag.c
-<br>
-tools/GOT/tagimage.c
-<br>
-tools/cmpi/cmpi.bkl
-<br>
-tools/cmpi/cmpi.cpp
-<br>
-tools/cmpi/cmpi.dsp
-<br>
-tools/cmpi/cmpi.dsw
-<br>
-tools/cmpi/cmpi.pro
-<br>
-tools/cmpi/cmpi.rc
-<br>
-tools/cmpi/cmpi.sln
-<br>
-tools/cmpi/cmpi.vcp
-<br>
-tools/cmpi/cmpi.vcproj
-<br>
-tools/cmpi/cmpi.vcw
-<br>
-tools/cmpi/descrip.mms
-<br>
-tools/cmpi/makefile.bcc
-<br>
-tools/cmpi/makefile.dmc
-<br>
-tools/cmpi/makefile.dms
-<br>
-tools/cmpi/makefile.dos
-<br>
-tools/cmpi/makefile.gcc
-<br>
-tools/cmpi/makefile.sc
-<br>
-tools/cmpi/makefile.unx
-<br>
-tools/cmpi/makefile.va
-<br>
-tools/cmpi/makefile.vc
-<br>
-tools/cmpi/makefile.wat
-<br>
-tools/xps2tiff/README
-<br>
-tools/xps2tiff/xps2tiff.sln
-<br>
-tools/xps2tiff/xps2tiff/AssemblyInfo.cpp
-<br>
-tools/xps2tiff/xps2tiff/stdafx.cpp
-<br>
-tools/xps2tiff/xps2tiff/stdafx.h
-<br>
-tools/xps2tiff/xps2tiff/xps2tiff.cpp
-<br>
-tools/xps2tiff/xps2tiff/xps2tiff.vcproj
-<br>
-win32/GhostPDL.sln
-<br>
-win32/language_switch.vcproj
-<br>
-win32/pcl.vcproj
-<br>
-win32/svg.vcproj
-<br>
-win32/xps.vcproj
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-19 14:01:55 +0000></a>
-2011-04-19 14:01:55 +0000</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1eadba53383fad842dbc5e72ca137914a83b63e6">1eadba53383fad842dbc5e72ca137914a83b63e6</a>
-<blockquote>
-
-<br>
-Changes to localcluster code to attempt to implement bmpcmphead. This certainly
-<br>
-doesn't break anything, but I don't actually ever seem to get any differences
-<br>
-out when running bmpcmphead.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12408 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/toolbin/localcluster/build.pl
-<br>
-gs/toolbin/localcluster/clustermaster.pl
-<br>
-gs/toolbin/localcluster/run.pl
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-19 10:06:23 +0000></a>
-2011-04-19 10:06: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=c9e506d7e910f6560c97a81de704296236a782cb">c9e506d7e910f6560c97a81de704296236a782cb</a>
-<blockquote>
-
-<br>
-Fix for bug 692152.
-<br>
-
-<br>
-We 'bend' the size of pattern tiles, against the spec, ostensibly to better
-<br>
-match Acrobat. The fix here is simply to avoid such bending in the case where
-<br>
-TilingType is 2. According to the spec, TilingType 2 says specifically not
-<br>
-to use the same device pixel size for every repeat of the pattern, and that
-<br>
-is exactly what we were doing.
-<br>
-
-<br>
-This cures the original bug, and produces 464 changes in the cluster tests.
-<br>
-Some (like ps3cet/18-02B.PS) are clear progressions. Others are less obviously
-<br>
-improvements, but comparison with Acrobat (and discussion with Ken/Chris)
-<br>
-shows that it's no worse than before, just 'different'.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12405 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gsptype1.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-18 22:58:18 +0000></a>
-2011-04-18 22:58:18 +0000</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a05ab8a88d5bc33c068a8e05ecba5f1adf3f3645">a05ab8a88d5bc33c068a8e05ecba5f1adf3f3645</a>
-<blockquote>
-
-<br>
-Fix reading of an embedded ICC profile from DSC comments and a
-<br>
-potential SEGV when the value of /N exceeds 8. Bug 692156.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12404 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/Resource/Init/gs_icc.ps
-<br>
-gs/psi/zcolor.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-18 20:34:34 +0000></a>
-2011-04-18 20:34:34 +0000</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=64bfc773be69bd422c95bca132c47782a421dc3a">64bfc773be69bd422c95bca132c47782a421dc3a</a>
-<blockquote>
-
-<br>
-Further movement toward getting fast thresholding operations working for CMYK output devices. Addition of special op to detect if a device is a planar type, creation of threshold screen for all the planes and spatial resampling of color input to output resolution for portrait case. A commit to get things in trunk before we convert from SVN to git.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12403 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gdevdflt.c
-<br>
-gs/base/gdevplib.c
-<br>
-gs/base/gxdevsop.h
-<br>
-gs/base/gxht_thresh.c
-<br>
-gs/base/gxicolor.c
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-18 18:41:26 +0000></a>
-2011-04-18 18:41:26 +0000</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=25152b1f7b5317ef1c3efd438a4d5ce26bcca5ba">25152b1f7b5317ef1c3efd438a4d5ce26bcca5ba</a>
-<blockquote>
-
-<br>
-Consider any xref entry with 0 offset as a free entry. Earlier revisions
-<br>
-rebuilt the xref table when offset == 0 but generation != 0.
-<br>
-However, rebuilding is an unreliable process and should be avoided if
-<br>
-possible. Bug 692159.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12402 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-18 07:58:13 +0000></a>
-2011-04-18 07:58:13 +0000</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7169dc6a5af38e1955c660813ed6e62392dc0deb">7169dc6a5af38e1955c660813ed6e62392dc0deb</a>
-<blockquote>
-
-<br>
-Add a fallback check for libpaper support.
-<br>
-
-<br>
-Older versions of autogen appear to have a bug which causes the AC_CHECK_LIB
-<br>
-macro to mis-identify the libpaper development library as being present when
-<br>
-it is not.
-<br>
-
-<br>
-So add a second check check based on the presence of paper.h using
-<br>
-AC_CHECK_HEADER().
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12401 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/configure.ac
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-16 14:21:57 +0000></a>
-2011-04-16 14:21:57 +0000</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=848275e2554bb57ebf2e12dabc47fc2922e7b877">848275e2554bb57ebf2e12dabc47fc2922e7b877</a>
-<blockquote>
-
-<br>
-Instead of searching for %%EOF marker (which is often damaged) and browsing the
-<br>
-file backwards, search for 'startxref' and take the next token as an xref
-<br>
-position. Besides fixing the reported bug, this greatly simplifies the search
-<br>
-for xref position. Bug 692153.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12400 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/Resource/Init/pdf_base.ps
-<br>
-gs/Resource/Init/pdf_main.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-14 20:59:18 +0000></a>
-2011-04-14 20:59:18 +0000</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3be81f880b7f0a31d3c213ad4245d0bbfeb0b5ef">3be81f880b7f0a31d3c213ad4245d0bbfeb0b5ef</a>
-<blockquote>
-
-<br>
-code to support rendering color source images to a mono device using thresholding. The code is currently disabled pending additional testing.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12397 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gxicolor.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-13 22:17:12 +0000></a>
-2011-04-13 22:17:12 +0000</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4a3666ee2833e877a26ef75fece00fd6fad14c93">4a3666ee2833e877a26ef75fece00fd6fad14c93</a>
-<blockquote>
-
-<br>
-Reorganization of thresholding code to make it easier to get the threshold operation working for color images as input as well as the case when we go to a cmyk planar device.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12396 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gxht_thresh.c
-<br>
-gs/base/gxht_thresh.h
-<br>
-gs/base/gxicolor.c
-<br>
-gs/base/gximono.c
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-13 16:21:07 +0000></a>
-2011-04-13 16:21:07 +0000</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3791878570227c7f5f1c07891c066fab3db2e5d3">3791878570227c7f5f1c07891c066fab3db2e5d3</a>
-<blockquote>
-
-<br>
-Fix reference counting of compositors in clist rendering; previously
-<br>
-the code assumed that it was the only claimant of a compositor and
-<br>
-closed/freed the device regardless of the reference count.
-<br>
-
-<br>
-Cluster testing shows no differences.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12394 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gxclrast.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-13 13:30:03 +0000></a>
-2011-04-13 13:30:03 +0000</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=29ff2a6f7d27ac9b19887ecc9243a6a8bc6aa9b8">29ff2a6f7d27ac9b19887ecc9243a6a8bc6aa9b8</a>
-<blockquote>
-
-<br>
-Fix (pdfwrite) : Restore TT->CIDFOnt conversion
-<br>
-
-<br>
-When creating PDF/A output, the Acrobat pre-flight tool throws out subset TrueType fonts
-<br>
-which are symbolic. Its not clear why, since the spec says that subset TrueType fonts
-<br>
-are permitted and does not require any additional information (such as /CharSet for
-<br>
-type 1 fonts).
-<br>
-
-<br>
-If we instead create a CIDFont with a CIDSet, then the pre-flight tool is happy (and
-<br>
-also, usefully, doesn't complain about multiple CMAP subtables), so here we spot
-<br>
-that there is no preferred Encoding (always the case with Symbolic fonts) and make
-<br>
-the conversion.
-<br>
-
-<br>
-No differences expected.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12393 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gdevpdtf.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-13 04:47:52 +0000></a>
-2011-04-13 04:47:52 +0000</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=124ab469aa0ad450a46d909e99c1b5d7072e646b">124ab469aa0ad450a46d909e99c1b5d7072e646b</a>
-<blockquote>
-
-<br>
-Fix for PCL when NumRenderingThreads > 0. PCL uses a memory allocator that is
-<br>
-not thread safe (chunk memory) but the mt rendering needs a thread safe base
-<br>
-allocator since the main thread may be allocating as well as the rendering
-<br>
-threads. This problem was seen with a couple of 'performance' documents, but
-<br>
-could fail on any document. Bug 692111 for customer #661.
-<br>
-
-<br>
-cluster testing showed no regressions, as expected since it didn't use MT
-<br>
-rendering.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12392 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gsalloc.c
-<br>
-gs/base/gsmalloc.c
-<br>
-gs/base/gsmchunk.c
-<br>
-gs/base/gsmemlok.c
-<br>
-gs/base/gsmemory.h
-<br>
-gs/base/gsmemret.c
-<br>
-gs/base/gxclread.c
-<br>
-gs/base/gxclthrd.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-12 20:08:59 +0000></a>
-2011-04-12 20:08:59 +0000</strong>
-<br>Ray Johnston &lt;ray.johnston@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=fdac37730cb0f86e8cd1efad2c49243c5ea5ec0b">fdac37730cb0f86e8cd1efad2c49243c5ea5ec0b</a>
-<blockquote>
-
-<br>
-Add some more useful stuff to pdf_info.ps: Default dumps Media paramters and
-<br>
-fonts that are needed, but not embedded and standard fonts. Media parameters
-<br>
-now include Rotate value and states if the page has transparency.
-<br>
-
-<br>
-Also allow this to be used more conveniently with the -- syntax:
-<br>
-gs {-q} -- toolbin/pdf_info.ps inputfile.pdf
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12391 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/toolbin/pdf_info.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-12 15:19:15 +0000></a>
-2011-04-12 15:19: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=78bb9a6585153e2cf0cbcc689706cd89d68b5b7b">78bb9a6585153e2cf0cbcc689706cd89d68b5b7b</a>
-<blockquote>
-
-<br>
-Fix PostScript colour handling
-<br>
-
-<br>
- Bug #692116 &quot;gs crash while executing stop operator&quot;
-<br>
-
-<br>
-The problem was caused by a mismatch between the graphics library and the PostScript
-<br>
-interpreter. When executing setcachedevice the graphcis library can set the colour
-<br>
-space to DeviceGray. Because it is unaware of the 'higher level' members of the graphics
-<br>
-state which belong to the PostScript interpreter it does not, and cannot, set the
-<br>
-*PostScript* graphics state colour space to the same space.
-<br>
-
-<br>
-Normally this does not matter, because after the glyph is complete the colour space is
-<br>
-restored. However, if a currentgray/currentrgb/currentcmyk operator is executed after
-<br>
-the graphics library has set the space to DeviceGray, but before it has restored the
-<br>
-space, then the PostScript space will be incorrect. This leads to the PostScript
-<br>
-handling trying to access more elements from the stack than 'currentcolor' put there
-<br>
-(currentcolor uses the underlying space, not the PostScript space), and causes errors.
-<br>
-
-<br>
-There isn't a really good way to handle this, because we can't put information about
-<br>
-the PostScript state into the graphics library. So I've chosen to check the underlying
-<br>
-colour space when processing currentgray etc, and if the space in the graphics
-<br>
-library is DeviceGray and does not match the expected PostScript space, then instead
-<br>
-of raising an error we proceed as if the PostScript space had been DeviceGray all
-<br>
-along.
-<br>
-
-<br>
-No differences expected
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12389 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/psi/zcolor.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-12 09:12:59 +0000></a>
-2011-04-12 09:12:59 +0000</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1b48fe7a0a2bd2aa49cd6cbf0ec5de3abcab7c89">1b48fe7a0a2bd2aa49cd6cbf0ec5de3abcab7c89</a>
-<blockquote>
-
-<br>
-Fix the GS_LIB registry value.
-<br>
-
-<br>
- The GS_LIB registry entry was missing the &quot;lib&quot; directory.
-<br>
-
-<br>
-Also, tidy up some of the uninstall rules.
-<br>
-
-<br>
-No cluster differences.
-<br>
-
-<br>
-Bug 692140
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12388 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/psi/nsisinst.nsi
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-12 06:44:27 +0000></a>
-2011-04-12 06:44:27 +0000</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f0a9ab32440ecade2d301187489805284cbf1a9d">f0a9ab32440ecade2d301187489805284cbf1a9d</a>
-<blockquote>
-
-<br>
-Forgot to save the readme
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12387 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/toolbin/color/icc_creator/README.txt
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-12 06:38:17 +0000></a>
-2011-04-12 06:38:17 +0000</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d90c248c90cb8e12c6613d32b347846a64f91ca6">d90c248c90cb8e12c6613d32b347846a64f91ca6</a>
-<blockquote>
-
-<br>
-Addition of one more profile, which is a CMYK profile but which only outputs in the K channel and a ifdef in the code to generate this thing.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12386 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/toolbin/color/icc_creator/ICC Profiles/cmyk_k_ouput_only.icc
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/icc_create.cpp
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-12 06:17:59 +0000></a>
-2011-04-12 06:17:59 +0000</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a031163dc9ada140b6e606582c29c9515fc7d839">a031163dc9ada140b6e606582c29c9515fc7d839</a>
-<blockquote>
-
-<br>
-Fix for an issue related to white point for the cmyk profile also fix for when UCR/BG is used in the profile creation.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12385 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/toolbin/color/icc_creator/ICC Profiles/ps_emulate_cmyk.icc
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/icc_create.cpp
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-12 05:11:30 +0000></a>
-2011-04-12 05:11:30 +0000</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6acec66087ba2de2d99c42c9e1d33cdb89473089">6acec66087ba2de2d99c42c9e1d33cdb89473089</a>
-<blockquote>
-
-<br>
-Addition of ICC profiles that properly emulate the PS color mappings
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12384 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/toolbin/color/icc_creator/ICC Profiles/ps_emulate_cmyk.icc
-<br>
-gs/toolbin/color/icc_creator/ICC Profiles/ps_emulate_gray.icc
-<br>
-gs/toolbin/color/icc_creator/ICC Profiles/ps_emulate_rgb.icc
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-12 05:02:03 +0000></a>
-2011-04-12 05:02:03 +0000</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=151535c554165c2f03fbe07098cc45fb0b341f67">151535c554165c2f03fbe07098cc45fb0b341f67</a>
-<blockquote>
-
-<br>
-Fix for bugs in ICC creator tool related primarily to the CMYK profile for simulating PS color conversions. Added in a option so that we do the CPSI like conversion and also added in the ability to define UCR/BG and pack those mappings into ICC profiles. These fixes were needed to take care of an issue found by customer 850.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12383 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/toolbin/color/halftone/README
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/CIELAB.h
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_Creator.rc
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.cpp
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.h
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/icc_create.cpp
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/icc_create.h
-<br>
-gs/toolbin/color/icc_creator/ICC_Creator/resource.h
-<br>
-gs/toolbin/color/icc_creator/README.txt
-<br>
-gs/toolbin/color/icc_creator/ucr_bg.txt
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-11 15:59:22 +0000></a>
-2011-04-11 15:59:22 +0000</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=4509a49f66c24f3a5590aadaaee30325676df877">4509a49f66c24f3a5590aadaaee30325676df877</a>
-<blockquote>
-
-<br>
-Fix (colour handling) : crash when executing 'stop'
-<br>
-
-<br>
-This is part of the fix for bug #692116. The crash in that report is caused because the
-<br>
-continuation procedures for the colour handling are sometimes pushed with a
-<br>
-push_mark_estack where the opproc has a value of 0. This is not valid and I always
-<br>
-intended to fix it, but forgot.
-<br>
-
-<br>
-This changes all uses of push_mark_estack so that the opproc is set to a valid routine
-<br>
-which does nothing, thus solving the crash and exposing the real problem. The only
-<br>
-reason we get a crash is because we are executing stop as part of the error handler,
-<br>
-because currentgray returned an error.
-<br>
-
-<br>
-No differences expected.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12382 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/psi/zcolor.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-09 07:06:43 +0000></a>
-2011-04-09 07:06:43 +0000</strong>
-<br>Alex Cherepanov &lt;alex.cherepanov@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6cb2c7110447967b01f19415ae0ff0f8dd1a251b">6cb2c7110447967b01f19415ae0ff0f8dd1a251b</a>
-<blockquote>
-
-<br>
-Add special processing for a broken PDF file that uses bare stream
-<br>
-dictionaries instead of ICCBased color space arrays. Bug 692213.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12381 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/Resource/Init/pdf_draw.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-08 17:03:54 +0000></a>
-2011-04-08 17:03:54 +0000</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=0791cc859ad38053ab3d3eef50169ac259f771cb">0791cc859ad38053ab3d3eef50169ac259f771cb</a>
-<blockquote>
-
-<br>
-Fix for x11alpha device when the source file has transparency. Two issues existed. One, found by henry, was that the target device of the x11alpha device was not inheriting the icc profile of the x11alpha device. The other was that the x11alpha device was using the bbox compositor procedure, which has some operations in it related to checking if the device has a target and the pdf14 device will target the target of the bbox device. This is not what we want for the x11alpha device. This should fix a lot of the x11alpha bugs Basically any source files that had transparency would have failed prior to this fix.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12380 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gdevxini.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-08 13:34:53 +0000></a>
-2011-04-08 13:34:53 +0000</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=507cbee1403b20b2c3fec692f746f41d9d985566">507cbee1403b20b2c3fec692f746f41d9d985566</a>
-<blockquote>
-
-<br>
-Fix Bug 692129. If an image is scaled to zero height and interpolation
-<br>
-is on, we end up mallocing a zero byte buffer and then overrunning it.
-<br>
-
-<br>
-The fix is to detect this scaling, and still allocate a 1 pixel high
-<br>
-buffer.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12378 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/siscale.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-08 08:48:17 +0000></a>
-2011-04-08 08:48:17 +0000</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1b6c7591e0f62007e4cf690d2f2fcbb56be9f989">1b6c7591e0f62007e4cf690d2f2fcbb56be9f989</a>
-<blockquote>
-
-<br>
-Fix GSLite : update to changes in decode_glyph method
-<br>
-
-<br>
-Revision 12374 altered the decode_glyph font method to take an additional parameter,
-<br>
-the character code. This commit updates the GSLite code routines to take the extra
-<br>
-parameter
-<br>
-
-<br>
-No differences expected, I don't think this is tested (or even compiled)
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12377 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-tools/gslite/gslt_font_api.c
-<br>
-tools/gslite/gslt_font_cff.c
-<br>
-tools/gslite/gslt_font_ttf.c
-<br>
-tools/gslite/gslt_test.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-08 08:36:35 +0000></a>
-2011-04-08 08:36:35 +0000</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=cc053e229b4a2dd03ff83673bfb819be51e970c3">cc053e229b4a2dd03ff83673bfb819be51e970c3</a>
-<blockquote>
-
-<br>
-Fix XPS and PCL interpreters : Change to decode_glyph routine
-<br>
-
-<br>
-The decode_glyph font method was changed to pass in the character code in revision
-<br>
-12374, but I missed the fact that these methods also exist in the XPS and PCL
-<br>
-interpreters.
-<br>
-
-<br>
-This revision simply updates the methods with the additional parameter.
-<br>
-
-<br>
-No differences expected.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12376 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-pl/plfont.c
-<br>
-xps/xpscff.c
-<br>
-xps/xpsttf.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-07 15:52:45 +0000></a>
-2011-04-07 15:52: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=a69dfc3caebd4f16ab8ba7f1c888bdbed6e5dbce">a69dfc3caebd4f16ab8ba7f1c888bdbed6e5dbce</a>
-<blockquote>
-
-<br>
-Resolve a path problem when running mkcidfm.ps.
-<br>
-
-<br>
-mkcidfm.ps did not handle the path to the Windows
-<br>
-font directory using back slash directory delimiters
-<br>
-so the nsis script now replaces all the back slash
-<br>
-delimiters with forward slash, with which mkcidfm.ps
-<br>
-works correctly.
-<br>
-
-<br>
-Bug 691511
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12375 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/psi/nsisinst.nsi
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-07 15:48:21 +0000></a>
-2011-04-07 15:48:21 +0000</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=24c562b9bcedcd9e6bd1d63a06c09eba52a24cbd">24c562b9bcedcd9e6bd1d63a06c09eba52a24cbd</a>
-<blockquote>
-
-<br>
-Fix (pdfwrite) : Not using ToUnicode CMaps under some conditions
-<br>
-
-<br>
- Bug #692119 &quot;Cannot copy text from Ghostscript generated PDF/A document&quot;
-<br>
-
-<br>
-The PDF interpreter converts ToUnicode CMaps into GlyphNames2Unicode dictionaries, to
-<br>
-do this it uses the Encoding to convert the character codes into glyph names. Of course
-<br>
-for CIDFonts we don't want to do this, and so when there is no Encoding we instead
-<br>
-put the Unicode value directly into the dictionary using the CID as an index.
-<br>
-
-<br>
-If the font has no Encoding (which is optional in PDF) then we do the same for a
-<br>
-regular font. However, by the time pdfwrite sees the font we have had to add an Encoding
-<br>
-as its not valid for us to define a regular font with no Encoding.
-<br>
-
-<br>
-So pdfwrite converts the character code into a (bogus) glyph name, and then tries to
-<br>
-look up that glyph name in the GlyphNames2Unicode dictionary. Obviously this fails.
-<br>
-
-<br>
-I've extended the 'decode_glyph' call so that it takes both the glyph name and the
-<br>
-character code, for CID fonts the character code is always -1. If the glyph name can't
-<br>
-be found in the GlyphNames2Unicode dictionary then we try to use the character code
-<br>
-instead.
-<br>
-
-<br>
-This works for this test case, and I don't think its likely to produce worse results
-<br>
-than the old code. Regression tests show no differences, but since they don't test
-<br>
-ToUnicode CMaps they weren't expected to. My own tests seem to be OK but I can't say
-<br>
-I'm terribly sure about this one.
-<br>
-
-<br>
-Expected Differences
-<br>
-None
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12374 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gdevpdtc.c
-<br>
-gs/base/gdevpdte.c
-<br>
-gs/base/gsfont.c
-<br>
-gs/base/gxfont.h
-<br>
-gs/psi/bfont.h
-<br>
-gs/psi/zbfont.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-07 03:30:16 +0000></a>
-2011-04-07 03:30:16 +0000</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=8170bf69742a320e7e28bffa58cbf0f0f14f2eb0">8170bf69742a320e7e28bffa58cbf0f0f14f2eb0</a>
-<blockquote>
-
-<br>
-Fix for 692123. It was necessary to make sure that the blending state of the pdf14 device is updated when we have the alpha buffer device installed in front of the pdf14 device.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12373 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gdevdflt.c
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gspaint.c
-<br>
-gs/base/gstrans.c
-<br>
-gs/base/gstrans.h
-<br>
-gs/base/gxdevsop.h
-<br>
-gs/base/lib.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-06 18:33:27 +0000></a>
-2011-04-06 18:33:27 +0000</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c03e320614893bb304b6c63e02a597d0153df031">c03e320614893bb304b6c63e02a597d0153df031</a>
-<blockquote>
-
-<br>
-Change lcms2 memory handling and update lib.
-<br>
-
-<br>
-As of this commit, we can (and do) run a completely unchanged library.
-<br>
-
-<br>
-This includes our tiny tweak to be able to get the input/output formats for
-<br>
-a given transform. Also update our interface code so that we use the plugin
-<br>
-mechanism to redirect malloc/free etc through us rather than hacking the
-<br>
-code direct. Thanks to Marti Maria for both of these.
-<br>
-
-<br>
-No cluster changes as this code is not tested. CLUSTER_UNTESTED.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12372 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gsicc_lcms2.c
-<br>
-gs/lcms2/AUTHORS
-<br>
-gs/lcms2/ChangeLog
-<br>
-gs/lcms2/Makefile.in
-<br>
-gs/lcms2/configure
-<br>
-gs/lcms2/configure.ac
-<br>
-gs/lcms2/doc/LittleCMS2.1 API.pdf
-<br>
-gs/lcms2/include/Makefile.in
-<br>
-gs/lcms2/include/lcms2.h
-<br>
-gs/lcms2/src/Makefile.in
-<br>
-gs/lcms2/src/cmscnvrt.c
-<br>
-gs/lcms2/src/cmserr.c
-<br>
-gs/lcms2/src/cmsxform.c
-<br>
-gs/lcms2/src/lcms2_internal.h
-<br>
-gs/lcms2/testbed/Makefile.in
-<br>
-gs/lcms2/utils/jpgicc/Makefile.in
-<br>
-gs/lcms2/utils/linkicc/Makefile.in
-<br>
-gs/lcms2/utils/linkicc/linkicc.1
-<br>
-gs/lcms2/utils/linkicc/linkicc.c
-<br>
-gs/lcms2/utils/psicc/Makefile.in
-<br>
-gs/lcms2/utils/tificc/Makefile.in
-<br>
-gs/lcms2/utils/transicc/Makefile.in
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-06 17:41:50 +0000></a>
-2011-04-06 17:41:50 +0000</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a54df2d2b0e78777a037ceacfba76dd47d9993d3">a54df2d2b0e78777a037ceacfba76dd47d9993d3</a>
-<blockquote>
-
-<br>
-Resolve a crash to due an unexpected CMap object type.
-<br>
-
-<br>
-The code was not checking that the CMap object was a string or an array (of
-<br>
-strings) before trying read bytes from it. If the CMap actually turned out
-<br>
-to be an unexpected object, such as an integer, it would cause a crash.
-<br>
-
-<br>
-Credit to Ken Sharp for the patch.
-<br>
-
-<br>
-Bug 692124
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12371 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/psi/zfapi.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-06 12:13:55 +0000></a>
-2011-04-06 12:13:55 +0000</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d97f8c354d97c8ec941c2d4b702b7d17ab0e03b3">d97f8c354d97c8ec941c2d4b702b7d17ab0e03b3</a>
-<blockquote>
-
-<br>
-Fix (ps2write/pdfwrite) : bitmapped font problem
-<br>
-
-<br>
-When producing an inline image representing a glyph which could not be embedded as text,
-<br>
-the code emitted the matrix setup for the image before opening the context. If there
-<br>
-was (for example) a pending text operation this caused the matrix setup to appear in
-<br>
-the text context instead of the image context, leading to the image disappearing.
-<br>
-
-<br>
-Opening the image context before emitting the matrix solves the problem.
-<br>
-
-<br>
-Expected Differences
-<br>
-The output from ps2write (resolution = 300 dpi) with the file
-<br>
-'metrics_no_bbox.ps'
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12370 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gdevpdfb.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-05 15:01:49 +0000></a>
-2011-04-05 15:01: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=2d72418b094cb62501d6af82a845848d01134119">2d72418b094cb62501d6af82a845848d01134119</a>
-<blockquote>
-
-<br>
-The FAPI code was relying on the result of gx_compute_text_oversampling()
-<br>
-to ascertain whether anti-aliasing is in force.
-<br>
-
-<br>
-This is insufficient, as it turns out, and we actually need to base the
-<br>
-decision on the alpha bits as requested by the device.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-Bug 692120.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12369 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/psi/zfapi.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-04 16:33:13 +0000></a>
-2011-04-04 16:33:13 +0000</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=f4a6e441bbe26758d4d3d9c62c369fde2b0e9643">f4a6e441bbe26758d4d3d9c62c369fde2b0e9643</a>
-<blockquote>
-
-<br>
-Squash some warnings in the lcms v2 interface code. No expected differences.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12368 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gsicc_lcms2.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-04 14:42:57 +0000></a>
-2011-04-04 14:42:57 +0000</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b359a954d93cd140b3e000c107854b021ccd9189">b359a954d93cd140b3e000c107854b021ccd9189</a>
-<blockquote>
-
-<br>
-Squash 4 warnings in the lcmvs v1 stuff.
-<br>
-
-<br>
-No cluster differences expected (and testing shows none, so CLUSTER_UNTESTED).
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12367 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gsicc_cms.h
-<br>
-gs/base/gsicc_manage.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-04 07:40:55 +0000></a>
-2011-04-04 07:40:55 +0000</strong>
-<br>Ken Sharp &lt;ken.sharp@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=1f92f1449bf208c8f7a878c8f149ca67cd62ab49">1f92f1449bf208c8f7a878c8f149ca67cd62ab49</a>
-<blockquote>
-
-<br>
-Alter the generation of Decode array entries for images using Indexed colour spaces by
-<br>
-using bit shifting instead of simple 'exp' operator.
-<br>
-
-<br>
-No differences expected, code is equivalent.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12366 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/opdfread.h
-<br>
-gs/lib/opdfread.ps
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:40:27 +0000></a>
-2011-04-03 20:40:27 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b58247cecc1fd272e12adc26890d912346dd92c5">b58247cecc1fd272e12adc26890d912346dd92c5</a>
-<blockquote>
-<p>
- Bug 689093 #21/ HTML compatibility:
-<br>
- Do not use SHORTTAGS (the &quot;&lt;tag ... /&gt;&quot; form) in HTML.
-<br>
-
-<br>
-Bug 689093 #21/ HTML compatibility
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12365 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/doc/Drivers.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:39:48 +0000></a>
-2011-04-03 20:39:48 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=d52ff94dea3bb3db0dc4c9ee1c8e89d48b1fb7ed">d52ff94dea3bb3db0dc4c9ee1c8e89d48b1fb7ed</a>
-<blockquote>
-
-<br>
-Bug 689093 #20/ HTML compatibility
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12364 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/doc/API.htm
-<br>
-gs/doc/C-style.htm
-<br>
-gs/doc/Changes.htm
-<br>
-gs/doc/Commprod.htm
-<br>
-gs/doc/DLL.htm
-<br>
-gs/doc/Deprecated.htm
-<br>
-gs/doc/Develop.htm
-<br>
-gs/doc/Devices.htm
-<br>
-gs/doc/Drivers.htm
-<br>
-gs/doc/Fonts.htm
-<br>
-gs/doc/Helpers.htm
-<br>
-gs/doc/Hershey.htm
-<br>
-gs/doc/History1.htm
-<br>
-gs/doc/History2.htm
-<br>
-gs/doc/History3.htm
-<br>
-gs/doc/History4.htm
-<br>
-gs/doc/History5.htm
-<br>
-gs/doc/History6.htm
-<br>
-gs/doc/History7.htm
-<br>
-gs/doc/Install.htm
-<br>
-gs/doc/Issues.htm
-<br>
-gs/doc/Language.htm
-<br>
-gs/doc/Lib.htm
-<br>
-gs/doc/Make.htm
-<br>
-gs/doc/News.htm
-<br>
-gs/doc/Projects.htm
-<br>
-gs/doc/Ps-style.htm
-<br>
-gs/doc/Ps2epsi.htm
-<br>
-gs/doc/Ps2pdf.htm
-<br>
-gs/doc/Ps2ps2.htm
-<br>
-gs/doc/Psfiles.htm
-<br>
-gs/doc/Readme.htm
-<br>
-gs/doc/Release.htm
-<br>
-gs/doc/Source.htm
-<br>
-gs/doc/Unix-lpr.htm
-<br>
-gs/doc/Use.htm
-<br>
-gs/doc/Xfonts.htm
-<br>
-gs/doc/index.html
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:39:13 +0000></a>
-2011-04-03 20:39:13 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=591b83fa9500a99ff8d24ddd7aa8962bd44312d6">591b83fa9500a99ff8d24ddd7aa8962bd44312d6</a>
-<blockquote>
-
-<br>
-Bug 689093 #19/ CSS conformance:
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12363 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/doc/gs.css
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:39:01 +0000></a>
-2011-04-03 20:39:01 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=464ee97310cd5c003d3683f2a2ceb16691394813">464ee97310cd5c003d3683f2a2ceb16691394813</a>
-<blockquote>
-
-<br>
-Bug 689093 #18bis/ SVN damage:
-<br>
-Replace ijs\ijs_spec.pdf, with a good copy.
-<br>
-
-<br>
-This file is currently damaged in the SVN Repository. The damage seem to have
-<br>
-happened during the conversion of the Repository from CVS to Subversion. This copy
-<br>
-of the file comes from the last CVS version available; the copy in the 1st SVN
-<br>
- checkout I have is already damaged. Note the &quot;/CreationDate&quot; inside the pdf is the
-<br>
-same as in the current (damaged) version and the last change to this file is very
-<br>
-old, so this file's substantive content did not change after the migration to SVN.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12362 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/ijs/ijs_spec.pdf
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:38:09 +0000></a>
-2011-04-03 20:38:09 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bbb639d51f543398c6e318075656af4857ad58b5">bbb639d51f543398c6e318075656af4857ad58b5</a>
-<blockquote>
-<p>
- Bug 689093 #18/ SVN damage:
-<br>
-<br>
-
-<br>
- This patch changes files that contain &quot;$Id...&quot; as text in order to
-<br>
- protect the apparent keyword from being expanded by SubVersion. The
-<br>
- methods used are as follows:
-<br>
- - for HTML: use the numeric entity "&#36;" instead of &quot;$&quot;.
-<br>
- - for C and Python: if the parser finds 2 consecutive string
-<br>
- literals, separated by nothing but whitespace, then it
-<br>
- automatically treats them as if it were a single, longer, string
-<br>
- obtained from concatenating the 2 original ones. Thus, the patch
-<br>
- replaces '"$Id"' =&gt; '"$" "Id$"'.
-<br>
-
-<br>
- git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12361 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/scfdgen.c
-<br>
-gs/doc/C-style.htm
-<br>
-gs/doc/Deprecated.htm
-<br>
-gs/doc/Details.htm
-<br>
-gs/doc/Details8.htm
-<br>
-gs/doc/Details9.htm
-<br>
-gs/doc/Develop.htm
-<br>
-gs/doc/Devices.htm
-<br>
-gs/doc/Drivers.htm
-<br>
-gs/doc/Hershey.htm
-<br>
-gs/doc/History1.htm
-<br>
-gs/doc/History2.htm
-<br>
-gs/doc/History3.htm
-<br>
-gs/doc/History4.htm
-<br>
-gs/doc/History5.htm
-<br>
-gs/doc/History6.htm
-<br>
-gs/doc/History7.htm
-<br>
-gs/doc/History8.htm
-<br>
-gs/doc/History9.htm
-<br>
-gs/doc/Install.htm
-<br>
-gs/doc/Issues.htm
-<br>
-gs/doc/Make.htm
-<br>
-gs/doc/Ps-style.htm
-<br>
-gs/doc/Release.htm
-<br>
-gs/doc/Use.htm
-<br>
-gs/toolbin/gen_ldf_jb2.py
-<br>
-gs/toolbin/split_changelog.py
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:27:35 +0000></a>
-2011-04-03 20:27:35 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5ff3a16a18372eff2b65054ced9b0cd283ad1ea9">5ff3a16a18372eff2b65054ced9b0cd283ad1ea9</a>
-<blockquote>
-
-<br>
-<br>
- looks like a SVN keyword, toolbin\split_changelog.py outputs it as-is
-<br>
- to HTML and later SVN expands it as a keyword. The result is the text
-<br>
- displayed differs. This patch extends the substitutions done for
-<br>
- character entities to include &quot;$&quot; =&gt; "&#36;"; there won't be any
-<br>
- &quot;$&quot;-as-text, and thus no "$Keyword..$"-as-text, anymore.
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12360 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/toolbin/split_changelog.py
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:25:28 +0000></a>
-2011-04-03 20:25:28 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=5b7d759adc6fb7f5ab85b72c195aaa4cc8a9882b">5b7d759adc6fb7f5ab85b72c195aaa4cc8a9882b</a>
-<blockquote>
-
-<br>
- toolbin\split_changelog.py encodes text coming from log messages as
-<br>
- utf-8. The patch changes it to output a &quot;&lt;meta/&gt;&quot; element specifying
-<br>
- the charset used, otherwise browsers that are not set for utf-8 by
-<br>
- default won't necessarily display the file correctly [if message
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12359 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/doc/Details.htm
-<br>
-gs/doc/Details8.htm
-<br>
-gs/doc/Details9.htm
-<br>
-gs/doc/History8.htm
-<br>
-gs/doc/History9.htm
-<br>
-gs/toolbin/split_changelog.py
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:25:06 +0000></a>
-2011-04-03 20:25:06 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=399081713e3314b04fa4404e870434f0bacb4590">399081713e3314b04fa4404e870434f0bacb4590</a>
-<blockquote>
-
-<br>
-Bug 689093 #15 (note: there's no #14)/ HTML conformance
-<br>
- explicitly declare the encoding used. Files Details(|8|9).htm and
-<br>
- History(8|9).htm may need extended characters coming from commit logs, and will
-<br>
- be handled by a later patch. Other files only need 7-bit ASCII.
-<br>
-
-<br>
- This patch also contains a small change not related to HTML-conformance:
-<br>
- a missing space in doc\Language.htm (&quot;... for[NO SPACE HERE]1-, ...&quot;).
-<br>
-
-<br>
- git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12358 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/doc/Language.htm
-<br>
-gs/doc/Make.htm
-<br>
-gs/doc/Ps2pdf.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:24:56 +0000></a>
-2011-04-03 20:24:56 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ce833816683f46ec1acd966c4c86a01a33b2f687">ce833816683f46ec1acd966c4c86a01a33b2f687</a>
-<blockquote>
-<p>
- Bug 689093 #13/ HTML conformance:
-<br>
- 'align=&quot;middle&quot;' should be 'align=&quot;center&quot;'
-<br>
-
-<br>
- &quot;Middle&quot; is only for vertical alignment (&quot;valign=&quot;); for the
-<br>
- horizontal alignment use &quot;center&quot;.
-<br>
-
-<br>
- git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12357 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/doc/Deprecated.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:24:48 +0000></a>
-2011-04-03 20:24:48 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=394631da0981713367ca2472be75445bd0fb0d56">394631da0981713367ca2472be75445bd0fb0d56</a>
-<blockquote>
-
-<br>
-Bug 689093 #12 (note: there's no #11)/ HTML conformance
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12356 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/doc/Changes.htm
-<br>
-gs/doc/Deprecated.htm
-<br>
-gs/doc/Details9.htm
-<br>
-gs/doc/Devices.htm
-<br>
-gs/doc/Drivers.htm
-<br>
-gs/doc/History9.htm
-<br>
-gs/doc/Make.htm
-<br>
-gs/doc/News.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:24:30 +0000></a>
-2011-04-03 20:24:30 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a17d948ba8edffee3d5cdd710ed495da93d72bda">a17d948ba8edffee3d5cdd710ed495da93d72bda</a>
-<blockquote>
-
-<br>
-Bug 689093 #10/ HTML conformance
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12355 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/doc/API.htm
-<br>
-gs/doc/DLL.htm
-<br>
-gs/doc/Deprecated.htm
-<br>
-gs/doc/Devices.htm
-<br>
-gs/doc/Drivers.htm
-<br>
-gs/doc/Fonts.htm
-<br>
-gs/doc/Helpers.htm
-<br>
-gs/doc/Install.htm
-<br>
-gs/doc/Language.htm
-<br>
-gs/doc/Lib.htm
-<br>
-gs/doc/Make.htm
-<br>
-gs/doc/Projects.htm
-<br>
-gs/doc/Ps-style.htm
-<br>
-gs/doc/Ps2epsi.htm
-<br>
-gs/doc/Ps2pdf.htm
-<br>
-gs/doc/Ps2ps2.htm
-<br>
-gs/doc/Psfiles.htm
-<br>
-gs/doc/Release.htm
-<br>
-gs/doc/Source.htm
-<br>
-gs/doc/Unix-lpr.htm
-<br>
-gs/doc/Use.htm
-<br>
-gs/doc/Xfonts.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:24:19 +0000></a>
-2011-04-03 20:24:19 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=01a5f1374998c9d24e021ee8851ae36cb58a8230">01a5f1374998c9d24e021ee8851ae36cb58a8230</a>
-<blockquote>
-
-<br>
-Bug 689093 #09/ HTML conformance
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12354 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/doc/History6.htm
-<br>
-gs/doc/History7.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:24:04 +0000></a>
-2011-04-03 20:24:04 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2692aa2af43e7f1d3655fabad728ceca9157f9b5">2692aa2af43e7f1d3655fabad728ceca9157f9b5</a>
-<blockquote>
-
-<br>
-Bug 689093 #08/ HTML conformance
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12353 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/doc/Details8.htm
-<br>
-gs/doc/History8.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:23:39 +0000></a>
-2011-04-03 20:23:39 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7215a52b4ae31ceb807da776b2c06f368dc9e275">7215a52b4ae31ceb807da776b2c06f368dc9e275</a>
-<blockquote>
-
-<br>
-Bug 689093 #07/ HTML conformance
-<br>
-gs/doc/Details.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:22:54 +0000></a>
-2011-04-03 20:22:54 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=9be02f9987043d2f1c4ea6bb1da403e9bbeaa535">9be02f9987043d2f1c4ea6bb1da403e9bbeaa535</a>
-<blockquote>
-
-<br>
-Bug 689093 #06/ HTML conformance
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12351 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/toolbin/split_changelog.py
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:22:27 +0000></a>
-2011-04-03 20:22:27 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=33674899f2fca8b2ed947862131bc57eb99c749a">33674899f2fca8b2ed947862131bc57eb99c749a</a>
-<blockquote>
-
-<br>
-Bug 689093 #05/ HTML conformance
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12350 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/doc/API.htm
-<br>
-gs/doc/C-style.htm
-<br>
-gs/doc/Deprecated.htm
-<br>
-gs/doc/Details8.htm
-<br>
-gs/doc/Develop.htm
-<br>
-gs/doc/Devices.htm
-<br>
-gs/doc/Drivers.htm
-<br>
-gs/doc/History5.htm
-<br>
-gs/doc/History6.htm
-<br>
-gs/doc/History7.htm
-<br>
-gs/doc/History8.htm
-<br>
-gs/doc/Issues.htm
-<br>
-gs/doc/Language.htm
-<br>
-gs/doc/Make.htm
-<br>
-gs/doc/Ps-style.htm
-<br>
-gs/doc/Release.htm
-<br>
-gs/doc/Use.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:21:59 +0000></a>
-2011-04-03 20:21:59 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=6b853264c8be1ce8efdf0f511889647d2e3251fa">6b853264c8be1ce8efdf0f511889647d2e3251fa</a>
-<blockquote>
-
-<br>
-Bug 689093 #04/ HTML conformance
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12349 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/doc/Details8.htm
-<br>
-gs/doc/History8.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:21:48 +0000></a>
-2011-04-03 20:21:48 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=24d88fd4b1c8c57e01ba295de69b6ff8a7c3431b">24d88fd4b1c8c57e01ba295de69b6ff8a7c3431b</a>
-<blockquote>
-
-<br>
-Bug 689093 #03/ HTML conformance
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12348 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/toolbin/split_changelog.py
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:20:32 +0000></a>
-2011-04-03 20:20:32 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=81cda2e93b17532409bdea39168db92bf2552919">81cda2e93b17532409bdea39168db92bf2552919</a>
-<blockquote>
-
-<br>
-Bug 689093 #02/ HTML conformance:
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12347 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/doc/API.htm
-<br>
-gs/doc/C-style.htm
-<br>
-gs/doc/Commprod.htm
-<br>
-gs/doc/DLL.htm
-<br>
-gs/doc/Deprecated.htm
-<br>
-gs/doc/Details8.htm
-<br>
-gs/doc/Details9.htm
-<br>
-gs/doc/Develop.htm
-<br>
-gs/doc/Devices.htm
-<br>
-gs/doc/Drivers.htm
-<br>
-gs/doc/Fonts.htm
-<br>
-gs/doc/Helpers.htm
-<br>
-gs/doc/History1.htm
-<br>
-gs/doc/History2.htm
-<br>
-gs/doc/History3.htm
-<br>
-gs/doc/History4.htm
-<br>
-gs/doc/History5.htm
-<br>
-gs/doc/History6.htm
-<br>
-gs/doc/History7.htm
-<br>
-gs/doc/History8.htm
-<br>
-gs/doc/History9.htm
-<br>
-gs/doc/Install.htm
-<br>
-gs/doc/Issues.htm
-<br>
-gs/doc/Language.htm
-<br>
-gs/doc/Lib.htm
-<br>
-gs/doc/Make.htm
-<br>
-gs/doc/News.htm
-<br>
-gs/doc/Projects.htm
-<br>
-gs/doc/Ps-style.htm
-<br>
-gs/doc/Ps2epsi.htm
-<br>
-gs/doc/Ps2pdf.htm
-<br>
-gs/doc/Ps2ps2.htm
-<br>
-gs/doc/Psfiles.htm
-<br>
-gs/doc/Readme.htm
-<br>
-gs/doc/Release.htm
-<br>
-gs/doc/Source.htm
-<br>
-gs/doc/Unix-lpr.htm
-<br>
-gs/doc/Use.htm
-<br>
-gs/doc/Xfonts.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-03 20:19:46 +0000></a>
-2011-04-03 20:19:46 +0000</strong>
-<br>Gheorghe Savulescu &lt;sags@ghostscript.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a5a20b7b8c0443ac5fd8c88bdb3af37390e4bf5c">a5a20b7b8c0443ac5fd8c88bdb3af37390e4bf5c</a>
-<blockquote>
-
-<br>
-Bug 689093 #01/ HTML conformance
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12346 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/toolbin/makehist.tcl
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-01 23:17:22 +0000></a>
-2011-04-01 23:17:22 +0000</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2674c673a3f4f29c9ca1620c36a97e0bd89c0e18">2674c673a3f4f29c9ca1620c36a97e0bd89c0e18</a>
-<blockquote>
-
-<br>
-Remove temporary development definition used to identify the graphics
-<br>
-library supported the new ICC code.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12345 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gsicc_manage.h
-<br>
-pcl/pctop.c
-<br>
-pxl/pxgstate.c
-<br>
-pxl/pxpthr.c
-<br>
-pxl/pxtop.c
-<br>
-xps/xpstop.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-01 22:58:42 +0000></a>
-2011-04-01 22:58:42 +0000</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ad470fdd8c23d7597260ec1c068da69075e1d7f8">ad470fdd8c23d7597260ec1c068da69075e1d7f8</a>
-<blockquote>
-
-<br>
-Fixes 691870 where the banding code was using an ICC color and the
-<br>
- &quot;setcolorspace&quot; so the image type was not being set to icc, we do this
-<br>
-"setcolorspace" so the image type was not being set to icc, we do this
-<br>
-now explicitly in the PCL/XL code now.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12344 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-pxl/pxgstate.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-01 18:42:42 +0000></a>
-2011-04-01 18:42:42 +0000</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a51bd3e408207936f0e795280a71253695a9d57e">a51bd3e408207936f0e795280a71253695a9d57e</a>
-<blockquote>
-
-<br>
-Add 2 files missed in commit 12341. These ones WILL have mattered.
-<br>
-Apoligies for this. A combination of git svn eating my first attempt
-<br>
-at committing it, and my own base level of incompetence caused this.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12343 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gsicc_cms.h
-<br>
-gs/base/gsicc_lcms.c
-<br>
-gs/base/lcms2.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-01 18:38:52 +0000></a>
-2011-04-01 18:38: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=b3ce17fce356461895d536c65d39defdb0137b06">b3ce17fce356461895d536c65d39defdb0137b06</a>
-<blockquote>
-
-<br>
-Add file that somehow got missed in the lcms2 commit (r12340).
-<br>
-
-<br>
-Not enabled by default so CLUSTER_UNTESTED.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12342 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gsicc_lcms2.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-01 18:05:33 +0000></a>
-2011-04-01 18:05:33 +0000</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b3703b36cb5544d9defd00780d814caed4eae5b4">b3703b36cb5544d9defd00780d814caed4eae5b4</a>
-<blockquote>
-
-<br>
-Fix so that we have proper antialiasing with softmasks. Fixes bug 687674
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12341 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-01 18:00:12 +0000></a>
-2011-04-01 18:00:12 +0000</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=50ecc84d5463bd013f794a9dd53254c2e295a85e">50ecc84d5463bd013f794a9dd53254c2e295a85e</a>
-<blockquote>
-
-<br>
-Initial import of LittleCMS v2.1 into the Ghostscript/GhostPDL
-<br>
-build, with simple integration. LittleCMS version 1 is still used by default,
-<br>
-so no cluster differences expected.
-<br>
-
-<br>
-The version of little cms imported was taken from the lcms git repository,
-<br>
-commit 314bc7201d340ab303b36a0ade2c37cf40b83a3b, and then a couple of
-<br>
-small tweaks were applied:
-<br>
-
-<br>
-* lcms2 currently offers no way to get the input/output format for a
-<br>
-transform, so I add 2 functions (cmsGetTransformInputFormat and
-<br>
-cmsGetTransformOutputFormat) to do this.
-<br>
-
-<br>
-* lcms2 currently offers no easy way to redirect malloc/free operations
-<br>
-away from it's internal implementation, so we add a define (LCMS_USER_ALLOC)
-<br>
-to allow us to be able to define our own functions. This mirrors the
-<br>
-work done in lcms1 by Michael, I believe.
-<br>
-
-<br>
-The choice of which version of lcms to build with is made by the WHICH_CMS
-<br>
-define option in the makefile. Currently this is set to lcms by default,
-<br>
-but can be changed to lcms2 to allow lcms2 to be used instead.
-<br>
-
-<br>
-To make this work, various small tweaks have been required. Firstly, we
-<br>
-rename gsicc_littlecms.h to gsicc_cms.h, reflecting the fact that this is
-<br>
-not littlecms specific - rather, it defines the interface that any cms
-<br>
-would have to provide in order to work with Ghostscript/GhostPDL.
-<br>
-
-<br>
-Secondly, we rename gsicc_littlecms.c to gsicc_lcms.c to make the makefile
-<br>
-macros easier.
-<br>
-
-<br>
-We add a gsicc_lcms2.c file (derived from copying and editing gsicc_lcms.c)
-<br>
-that interfaces with lcms2.
-<br>
-
-<br>
-Currently lcms2 builds and appears to run without crashing, but gives
-<br>
-differing results in some cases. This will need to be solved before we can
-<br>
-swap over to using lcms2 by default.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12340 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-common/msvc_top.mak
-<br>
-common/ugcc_top.mak
-<br>
-gs/base/Makefile.in
-<br>
-gs/base/configure.ac
-<br>
-gs/base/gs.mak
-<br>
-gs/base/gsicc.c
-<br>
-gs/base/gsicc_cache.c
-<br>
-gs/base/gsicc_littlecms.c
-<br>
-gs/base/gsicc_littlecms.h
-<br>
-gs/base/gsicc_manage.h
-<br>
-gs/base/gxi12bit.c
-<br>
-gs/base/gxicolor.c
-<br>
-gs/base/gximono.c
-<br>
-gs/base/gxipixel.c
-<br>
-gs/base/lcms.mak
-<br>
-gs/base/lib.mak
-<br>
-gs/base/macos-mcp.mak
-<br>
-gs/base/macosx.mak
-<br>
-gs/base/msvclib.mak
-<br>
-gs/base/openvms.mak
-<br>
-gs/base/ugcclib.mak
-<br>
-gs/base/unix-gcc.mak
-<br>
-gs/base/unixansi.mak
-<br>
-gs/base/winlib.mak
-<br>
-gs/ghostscript.vcproj
-<br>
-gs/lcms2/AUTHORS
-<br>
-gs/lcms2/COPYING
-<br>
-gs/lcms2/ChangeLog
-<br>
-gs/lcms2/INSTALL
-<br>
-gs/lcms2/Lib/BC/BC.txt
-<br>
-gs/lcms2/Lib/MS/MS.TXT
-<br>
-gs/lcms2/Makefile.am
-<br>
-gs/lcms2/Makefile.in
-<br>
-gs/lcms2/NEWS
-<br>
-gs/lcms2/Projects/BorlandC_5.5/lcms2.rc
-<br>
-gs/lcms2/Projects/BorlandC_5.5/lcmsdll.lk
-<br>
-gs/lcms2/Projects/BorlandC_5.5/lcmsdll.lst
-<br>
-gs/lcms2/Projects/BorlandC_5.5/mklcmsdll.bat
-<br>
-gs/lcms2/Projects/VC2008/jpegicc/jpegicc.vcproj
-<br>
-gs/lcms2/Projects/VC2008/lcms2.rc
-<br>
-gs/lcms2/Projects/VC2008/lcms2.sln
-<br>
-gs/lcms2/Projects/VC2008/lcms2_DLL/lcms2_DLL.vcproj
-<br>
-gs/lcms2/Projects/VC2008/lcms2_static/lcms2_static.vcproj
-<br>
-gs/lcms2/Projects/VC2008/linkicc/linkicc.vcproj
-<br>
-gs/lcms2/Projects/VC2008/psicc/psicc.vcproj
-<br>
-gs/lcms2/Projects/VC2008/resource.h
-<br>
-gs/lcms2/Projects/VC2008/testbed/testbed.vcproj
-<br>
-gs/lcms2/Projects/VC2008/tiffdiff/tiffdiff.vcproj
-<br>
-gs/lcms2/Projects/VC2008/tifficc/tifficc.vcproj
-<br>
-gs/lcms2/Projects/VC2008/transicc/transicc.vcproj
-<br>
-gs/lcms2/Projects/VC2010/jpegicc/jpegicc.vcproj
-<br>
-gs/lcms2/Projects/VC2010/jpegicc/jpegicc.vcxproj
-<br>
-gs/lcms2/Projects/VC2010/jpegicc/jpegicc.vcxproj.filters
-<br>
-gs/lcms2/Projects/VC2010/lcms2.rc
-<br>
-gs/lcms2/Projects/VC2010/lcms2.sln
-<br>
-gs/lcms2/Projects/VC2010/lcms2_DLL/lcms2_DLL.vcproj
-<br>
-gs/lcms2/Projects/VC2010/lcms2_DLL/lcms2_DLL.vcxproj
-<br>
-gs/lcms2/Projects/VC2010/lcms2_DLL/lcms2_DLL.vcxproj.filters
-<br>
-gs/lcms2/Projects/VC2010/lcms2_static/lcms2_static.vcproj
-<br>
-gs/lcms2/Projects/VC2010/lcms2_static/lcms2_static.vcxproj
-<br>
-gs/lcms2/Projects/VC2010/lcms2_static/lcms2_static.vcxproj.filters
-<br>
-gs/lcms2/Projects/VC2010/linkicc/linkicc.vcproj
-<br>
-gs/lcms2/Projects/VC2010/linkicc/linkicc.vcxproj
-<br>
-gs/lcms2/Projects/VC2010/linkicc/linkicc.vcxproj.filters
-<br>
-gs/lcms2/Projects/VC2010/psicc/psicc.vcproj
-<br>
-gs/lcms2/Projects/VC2010/psicc/psicc.vcxproj
-<br>
-gs/lcms2/Projects/VC2010/psicc/psicc.vcxproj.filters
-<br>
-gs/lcms2/Projects/VC2010/resource.h
-<br>
-gs/lcms2/Projects/VC2010/testbed/testbed.vcproj
-<br>
-gs/lcms2/Projects/VC2010/testbed/testbed.vcxproj
-<br>
-gs/lcms2/Projects/VC2010/testbed/testbed.vcxproj.filters
-<br>
-gs/lcms2/Projects/VC2010/tiffdiff/tiffdiff.vcproj
-<br>
-gs/lcms2/Projects/VC2010/tiffdiff/tiffdiff.vcxproj
-<br>
-gs/lcms2/Projects/VC2010/tiffdiff/tiffdiff.vcxproj.filters
-<br>
-gs/lcms2/Projects/VC2010/tifficc/tifficc.vcproj
-<br>
-gs/lcms2/Projects/VC2010/tifficc/tifficc.vcxproj
-<br>
-gs/lcms2/Projects/VC2010/tifficc/tifficc.vcxproj.filters
-<br>
-gs/lcms2/Projects/VC2010/transicc/transicc.vcproj
-<br>
-gs/lcms2/Projects/VC2010/transicc/transicc.vcxproj
-<br>
-gs/lcms2/Projects/VC2010/transicc/transicc.vcxproj.filters
-<br>
-gs/lcms2/Projects/mac/._.DS_Store
-<br>
-gs/lcms2/Projects/mac/LittleCMS/._.DS_Store
-<br>
-gs/lcms2/Projects/mac/LittleCMS/English.lproj/InfoPlist.strings
-<br>
-gs/lcms2/Projects/mac/LittleCMS/Info.plist
-<br>
-gs/lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/mariama.mode1v3
-<br>
-gs/lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/mariama.pbxuser
-<br>
-gs/lcms2/Projects/mac/LittleCMS/LittleCMS.xcodeproj/project.pbxproj
-<br>
-gs/lcms2/Projects/mac/LittleCMS/LittleCMS_Prefix.pch
-<br>
-gs/lcms2/Projects/mac/LittleCMS/TestBed-Info.plist
-<br>
-gs/lcms2/README.1ST
-<br>
-gs/lcms2/aclocal.m4
-<br>
-gs/lcms2/autogen.sh
-<br>
-gs/lcms2/bin/Bin.txt
-<br>
-gs/lcms2/bin/Thumbs.db
-<br>
-gs/lcms2/config.guess
-<br>
-gs/lcms2/config.sub
-<br>
-gs/lcms2/configure
-<br>
-gs/lcms2/configure.ac
-<br>
-gs/lcms2/depcomp
-<br>
-gs/lcms2/doc/LittleCMS2.0 API.pdf
-<br>
-gs/lcms2/doc/LittleCMS2.0 Plugin API.pdf
-<br>
-gs/lcms2/doc/LittleCMS2.0 tutorial.pdf
-<br>
-gs/lcms2/doc/LittleCMS2.1 API.pdf
-<br>
-gs/lcms2/doc/LittleCMS2.1 Plugin API.pdf
-<br>
-gs/lcms2/doc/LittleCMS2.1 tutorial.pdf
-<br>
-gs/lcms2/include/Makefile.am
-<br>
-gs/lcms2/include/Makefile.in
-<br>
-gs/lcms2/include/icc34.h
-<br>
-gs/lcms2/include/lcms2.h
-<br>
-gs/lcms2/include/lcms2_plugin.h
-<br>
-gs/lcms2/install-sh
-<br>
-gs/lcms2/lcms2.pc.in
-<br>
-gs/lcms2/ltmain.sh
-<br>
-gs/lcms2/missing
-<br>
-gs/lcms2/src/Makefile.am
-<br>
-gs/lcms2/src/Makefile.in
-<br>
-gs/lcms2/src/cmscam02.c
-<br>
-gs/lcms2/src/cmscgats.c
-<br>
-gs/lcms2/src/cmscnvrt.c
-<br>
-gs/lcms2/src/cmserr.c
-<br>
-gs/lcms2/src/cmsgamma.c
-<br>
-gs/lcms2/src/cmsgmt.c
-<br>
-gs/lcms2/src/cmsintrp.c
-<br>
-gs/lcms2/src/cmsio0.c
-<br>
-gs/lcms2/src/cmsio1.c
-<br>
-gs/lcms2/src/cmslut.c
-<br>
-gs/lcms2/src/cmsmd5.c
-<br>
-gs/lcms2/src/cmsmtrx.c
-<br>
-gs/lcms2/src/cmsnamed.c
-<br>
-gs/lcms2/src/cmsopt.c
-<br>
-gs/lcms2/src/cmspack.c
-<br>
-gs/lcms2/src/cmspcs.c
-<br>
-gs/lcms2/src/cmsplugin.c
-<br>
-gs/lcms2/src/cmsps2.c
-<br>
-gs/lcms2/src/cmssamp.c
-<br>
-gs/lcms2/src/cmssm.c
-<br>
-gs/lcms2/src/cmstypes.c
-<br>
-gs/lcms2/src/cmsvirt.c
-<br>
-gs/lcms2/src/cmswtpnt.c
-<br>
-gs/lcms2/src/cmsxform.c
-<br>
-gs/lcms2/src/lcms2.def
-<br>
-gs/lcms2/src/lcms2_internal.h
-<br>
-gs/lcms2/testbed/Makefile.am
-<br>
-gs/lcms2/testbed/Makefile.in
-<br>
-gs/lcms2/testbed/USWebCoatedSWOP.icc
-<br>
-gs/lcms2/testbed/UncoatedFOGRA29.icc
-<br>
-gs/lcms2/testbed/bad.icc
-<br>
-gs/lcms2/testbed/sRGBSpac.icm
-<br>
-gs/lcms2/testbed/sRGB_Color_Space_Profile.icm
-<br>
-gs/lcms2/testbed/sRGB_v4_ICC_preference.icc
-<br>
-gs/lcms2/testbed/testcms2.c
-<br>
-gs/lcms2/testbed/testthread.cpp
-<br>
-gs/lcms2/testbed/toosmall.icc
-<br>
-gs/lcms2/utils/common/utils.h
-<br>
-gs/lcms2/utils/common/vprf.c
-<br>
-gs/lcms2/utils/common/xgetopt.c
-<br>
-gs/lcms2/utils/delphi/delphidemo.dpr
-<br>
-gs/lcms2/utils/delphi/delphidemo.dproj
-<br>
-gs/lcms2/utils/delphi/delphidemo.res
-<br>
-gs/lcms2/utils/delphi/demo1.dfm
-<br>
-gs/lcms2/utils/delphi/demo1.pas
-<br>
-gs/lcms2/utils/delphi/lcms2dll.pas
-<br>
-gs/lcms2/utils/jpgicc/Makefile.am
-<br>
-gs/lcms2/utils/jpgicc/Makefile.in
-<br>
-gs/lcms2/utils/jpgicc/iccjpeg.c
-<br>
-gs/lcms2/utils/jpgicc/iccjpeg.h
-<br>
-gs/lcms2/utils/jpgicc/jpgicc.1
-<br>
-gs/lcms2/utils/jpgicc/jpgicc.c
-<br>
-gs/lcms2/utils/linkicc/Makefile.am
-<br>
-gs/lcms2/utils/linkicc/Makefile.in
-<br>
-gs/lcms2/utils/linkicc/linkicc.1
-<br>
-gs/lcms2/utils/linkicc/linkicc.c
-<br>
-gs/lcms2/utils/matlab/icctrans.c
-<br>
-gs/lcms2/utils/matlab/lcms_rsp
-<br>
-gs/lcms2/utils/psicc/Makefile.am
-<br>
-gs/lcms2/utils/psicc/Makefile.in
-<br>
-gs/lcms2/utils/psicc/psicc.1
-<br>
-gs/lcms2/utils/psicc/psicc.c
-<br>
-gs/lcms2/utils/samples/Makefile.am
-<br>
-gs/lcms2/utils/samples/Makefile.in
-<br>
-gs/lcms2/utils/samples/itufax.c
-<br>
-gs/lcms2/utils/samples/mkcmy.c
-<br>
-gs/lcms2/utils/samples/mkgrayer.c
-<br>
-gs/lcms2/utils/samples/mktiff8.c
-<br>
-gs/lcms2/utils/samples/roundtrip.c
-<br>
-gs/lcms2/utils/samples/vericc.c
-<br>
-gs/lcms2/utils/samples/wtpt.1
-<br>
-gs/lcms2/utils/samples/wtpt.c
-<br>
-gs/lcms2/utils/tificc/Makefile.am
-<br>
-gs/lcms2/utils/tificc/Makefile.in
-<br>
-gs/lcms2/utils/tificc/tifdiff.c
-<br>
-gs/lcms2/utils/tificc/tificc.1
-<br>
-gs/lcms2/utils/tificc/tificc.c
-<br>
-gs/lcms2/utils/transicc/Makefile.am
-<br>
-gs/lcms2/utils/transicc/Makefile.in
-<br>
-gs/lcms2/utils/transicc/transicc.1
-<br>
-gs/lcms2/utils/transicc/transicc.c
-<br>
-gs/psi/int.mak
-<br>
-gs/psi/msvc.mak
-<br>
-gs/psi/os2.mak
-<br>
-main/pcl6_gcc.mak
-<br>
-main/pcl6_msvc.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-01 16:44:50 +0000></a>
-2011-04-01 16:44:50 +0000</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=b960ff15c895dbe5a7d6baf470ad8a12949ad054">b960ff15c895dbe5a7d6baf470ad8a12949ad054</a>
-<blockquote>
-
-<br>
-Fix for mistaken double allocation of threshold array object. Thanks to ray for finding this.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12339 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gsht.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-04-01 16:39:59 +0000></a>
-2011-04-01 16:39:59 +0000</strong>
-<br>Michael Vrhel &lt;michael.vrhel@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=66adf73f5cbaa010b6a7ee730384c3a58752bff3">66adf73f5cbaa010b6a7ee730384c3a58752bff3</a>
-<blockquote>
-
-<br>
-Fix so that anti-aliasing works when the source file contains transparency. This involved the addition of a copy_alpha procedure for the gdevp14 device. In addition, the anti-aliasing parameters for the target device are passed along to the gdevp14 device. The gdevp14 clist device uses the forward copy alpha operation, so that we end up using the clist_copy_alpha operation. Then during the clist reading phase we use the gdevp14 device's copy_alpha command.
-<br>
-
-<br>
-There are two things that I do need to do in relation to this commit. One is that the operation that actually computes and applies the alpha associated with the transparency needs to be optimized so that we are not doing floating point math. Also, support needs to be added for knockout fills. However, for the vast majority of files with transparency we should now have support with -dGraphicAlphaBits and -dTextAlphaBits.
-<br>
-
-<br>
-I will open a bug on the two outstanding issues so that I don't forget.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12338 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gdevnfwd.c
-<br>
-gs/base/gdevp14.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-03-31 17:30:58 +0000></a>
-2011-03-31 17:30:58 +0000</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=7825ac4552256609c8060b5af13bb168170db6eb">7825ac4552256609c8060b5af13bb168170db6eb</a>
-<blockquote>
-
-<br>
-Bug #692100, padding was being treated inconsistently within 2
-<br>
-procedures resulting in UMR's and incorrect results. I'm afraid we
-<br>
-still don't understand the details of HP's seemingly bug-ridden
-<br>
-padding implementation but this fix at least makes the code internally
-<br>
-consistent.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12337 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-pxl/pximage.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-03-31 17:22:23 +0000></a>
-2011-03-31 17:22:23 +0000</strong>
-<br>Henry Stiles &lt;henry.stiles@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=91b7f320484904d60e8cf017611f5a8da4a6c685">91b7f320484904d60e8cf017611f5a8da4a6c685</a>
-<blockquote>
-<p>
- Fixes 692109, the &quot;no argument case&quot; of the HPGL/2 INPUT RELATIVE
-<br>
-Fixes 692109, the "no argument case" of the HPGL/2 INPUT RELATIVE
-<br>
-command did not properly initialized the operands to their defaults.
-<br>
-Only likely to be seen in unusual test cases. Fixes indeterminacy
-<br>
-in CET 32-07.BIN reported in the regression tests.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12336 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-pcl/pgconfig.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-03-31 15:36:32 +0000></a>
-2011-03-31 15:36:32 +0000</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=65ea9547d5760284c68da6b6b413d335e4e68ed1">65ea9547d5760284c68da6b6b413d335e4e68ed1</a>
-<blockquote>
-
-<br>
-The last of Hintak's (usable) improvements to the nsis installer
-<br>
-script, plus a tweak or two.
-<br>
-
-<br>
-Make the cidfmap generation a tickbox option on the final page.
-<br>
-
-<br>
-Add a link to the uninstaller from the Start Menu group.
-<br>
-
-<br>
-No cluster differences
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12335 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/psi/nsisinst.nsi
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-03-30 15:33:28 +0000></a>
-2011-03-30 15:33: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=700f41807524588d82a674c3618322f71bbe9d7b">700f41807524588d82a674c3618322f71bbe9d7b</a>
-<blockquote>
-
-<br>
-Bring the nsis installer script and it's caller up
-<br>
-to date.
-<br>
-
-<br>
-Vast majority of the credit to Hintak for this.
-<br>
-
-<br>
-No cluster differences.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12334 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/psi/nsisinst.nsi
-<br>
-gs/psi/winint.mak
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-03-30 12:23:41 +0000></a>
-2011-03-30 12:23:41 +0000</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=c428998ab5d6b6f164de9474c25ee788ae4ef77f">c428998ab5d6b6f164de9474c25ee788ae4ef77f</a>
-<blockquote>
-
-<br>
-Squash a warning in a device call.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12333 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gxclpath.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-03-30 11:13:37 +0000></a>
-2011-03-30 11:13:37 +0000</strong>
-<br>Tor Andersson <tor.andersson@artifex.com><br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=807af34ac8671f03b8c73cca2cdbebca796c716e">807af34ac8671f03b8c73cca2cdbebca796c716e</a>
-<blockquote>
-
-<br>
-xps: Fix bug when parsing cluster mappings.
-<br>
-
-<br>
-We incorrectly encoded and emitted all characters in a
-<br>
-Many-to-One cluster mapping, resulting in extraneous characters
-<br>
-where ligatures were used. A (2:1) cluster map for the ligature
-<br>
- &quot;fi&quot; has two characters (f, i) and one glyph (fi). We showed it
-<br>
-as two glyphs (fi, i) instead of skipping the second character
-<br>
-while decoding the cluster map.
-<br>
-
-<br>
-This fixes multiple errors in MXDW/TypeSamples.xps
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12332 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-xps/xpsglyphs.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-03-30 10:17:57 +0000></a>
-2011-03-30 10:17:57 +0000</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=2e594aee0d69b99a17fa9cd3cf21696773afde43">2e594aee0d69b99a17fa9cd3cf21696773afde43</a>
-<blockquote>
-
-<br>
-Add gs/doc to Visual Studio project, enabling documentation to be easily
-<br>
-edited in the Visual Studio editor.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12331 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/ghostscript.vcproj
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-03-30 10:17:42 +0000></a>
-2011-03-30 10:17:42 +0000</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=790f395b044a7e7179c3ca918e30475827c8a30b">790f395b044a7e7179c3ca918e30475827c8a30b</a>
-<blockquote>
-
-<br>
-Add documentation for dev_spec_op to Devices.htm.
-<br>
-
-<br>
-No cluster changes.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12330 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/doc/Drivers.htm
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-03-30 10:17:26 +0000></a>
-2011-03-30 10:17:26 +0000</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=a243545401bf0fdb8b1a18e7e5379119c56aecfa">a243545401bf0fdb8b1a18e7e5379119c56aecfa</a>
-<blockquote>
-
-<br>
-Add new copy_plane device procedure; arguments as for copy_color with an
-<br>
-extra int to identify which plane we want to work on.
-<br>
-
-<br>
- The call effectively says &quot;Copy this pixmap into the specified plane of this
-<br>
- device&quot;. It is envisaged that it will only be defined for planar devices.
-<br>
-
-<br>
-For now clients can detect whether or not to use this based on whether the
-<br>
-function pointer is non NULL. If need be (to cope with forwarding devices)
-<br>
-we can add a dev_spec_op.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12329 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gdevdflt.c
-<br>
-gs/base/gdevmpla.c
-<br>
-gs/base/gxdevcli.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-03-30 10:17:10 +0000></a>
-2011-03-30 10:17:10 +0000</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=3bdda000eabced6e4c015af4c6dbb5b02f1abdda">3bdda000eabced6e4c015af4c6dbb5b02f1abdda</a>
-<blockquote>
-
-<br>
-Add new dev_spec_op operation for spotting that a device maps colours in
-<br>
-the 'standard' 1bit cmyk way, and use that rather than manually checking
-<br>
-function pointers. This allows bitcmyk, pamcmyk4 and plibk devices to
-<br>
-correctly spot the optimisation in get_bits (used for rops that use D).
-<br>
-
-<br>
-Testing locally indicates that the special case is now taken, but that no
-<br>
-differences are seen in the results (as we would hope).
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12328 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gdevdflt.c
-<br>
-gs/base/gdevdgbr.c
-<br>
-gs/base/gdevdrop.c
-<br>
-gs/base/gxclpath.c
-<br>
-gs/base/gxdevsop.h
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-03-30 10:16:54 +0000></a>
-2011-03-30 10:16: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=f81e8f47c06572ecc4f7e3fcc03ca4db60507ce4">f81e8f47c06572ecc4f7e3fcc03ca4db60507ce4</a>
-<blockquote>
-
-<br>
-Tweak dev_spec_op implementations so that they correctly forward through
-<br>
-to the 'default' (or base) implementations for unknown operations. Stupid
-<br>
-of me to have got this wrong initially, as it is one of the main purposes
-<br>
-of this mechanism.
-<br>
-
-<br>
-No cluster differences expected.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12327 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gdevnfwd.c
-<br>
-gs/base/gdevpdfd.c
-<br>
-gs/base/gdevpdfi.c
-<br>
-gs/base/gxacpath.c
-<br>
-<p>
-</blockquote>
-
-<p><strong><a name=2011-03-30 10:15:18 +0000></a>
-2011-03-30 10:15:18 +0000</strong>
-<br>Robin Watts &lt;Robin.Watts@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=bca8531f23845a6c70cf938fb0ab1bc6e9f14fd9">bca8531f23845a6c70cf938fb0ab1bc6e9f14fd9</a>
-<blockquote>
-
-<br>
-Add new dev_spec_op call to device procs table, along with gxdevsop.h header
-<br>
-that defines the operation enumeration for it.
-<br>
-
-<br>
-Move existing calls of pattern_manage across to using dev_spec_op instead.
-<br>
-Add comments to the pattern management definitions noting that it is
-<br>
-deprecated and should not be used.
-<br>
-
-<br>
-No cluster differences (aside from indeterminisms).
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12326 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/base/gdevbbox.c
-<br>
-gs/base/gdevdflt.c
-<br>
-gs/base/gdevdrop.c
-<br>
-gs/base/gdevnfwd.c
-<br>
-gs/base/gdevp14.c
-<br>
-gs/base/gdevpdfb.h
-<br>
-gs/base/gdevpdfd.c
-<br>
-gs/base/gdevpdfi.c
-<br>
-gs/base/gdevpdfx.h
-<br>
-gs/base/gdevrops.c
-<br>
-gs/base/gscolor3.c
-<br>
-gs/base/gsimage.c
-<br>
-gs/base/gsptype1.c
-<br>
-gs/base/gsptype2.c
-<br>
-gs/base/gxacpath.c
-<br>
-gs/base/gxcldev.h
-<br>
-gs/base/gxclip.c
-<br>
-gs/base/gxclip2.c
-<br>
-gs/base/gxclipm.c
-<br>
-gs/base/gxclist.c
-<br>
-gs/base/gxclrect.c
-<br>
-gs/base/gxdevcli.h
-<br>
-gs/base/gxdevice.h
-<br>
-gs/base/gxdevsop.h
-<br>
-gs/base/gxfill.c
-<br>
-gs/base/gximask.c
-<br>
-gs/base/gxpcmap.c
-<br>
-gs/base/gxshade6.c
-<br>
-gs/psi/zpcolor.c
-xps/xpstile.c
-<p>
-</blockquote>
-
-<p><strong><a name=2011-03-30 09:26:50 +0000></a>
-2011-03-30 09:26:50 +0000</strong>
-<br>Chris Liddell &lt;chris.liddell@artifex.com&gt;<br>
-<a href="http://git.ghostscript.com/?p=ghostpdl.git;a=commitdiff;h=ed774ca984d2566b00e212d130644abd5529235f">ed774ca984d2566b00e212d130644abd5529235f</a>
-<blockquote>
-
-<br>
-Update version number post-release.
-<br>
-
-<br>
-git-svn-id: http://svn.ghostscript.com/ghostscript/trunk@12325 a1074d23-0009-0410-80fe-cf8c14f379e6
-<br>
-
-<br>
-gs/Resource/Init/gs_init.ps
-<br>
-gs/base/gscdef.c
-<br>
-gs/base/version.mak
-<br>
-<p>
-</blockquote>
-<hr size=20>
-
-<h2><a name="Version9.02"></a>Version 9.02 (2011-03-30)</h2>
-
-<p>This is the third release in the stable 9.x series.
-
-<p>This is an &quot;out of order&quot; release, primarily to ensure the
-GPL Ghostscript release remains in version &quot;lock-step&quot; with the
-Artifex commercial release.
-
-<p> Highlights in this release include:
-
-<p>For monochrome devices, there is a new halftone technique for sampled
-image data. The existing technique is very efficient (and is is still used)
-for large areas of color, such as an area fill, but encountered performance
-problems dealing with sampled image data where a given colour value only
-covered a few pixels at a time. The new approach applies the halftone threshold
-array directly to the image samples.
-
-<p> Further performance, memory use, and stability improvements with the new
-features introduced in 9.00, as well as Unix/Linux build fixes, plus the usual
-assorted bug fixes.
-
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.02_Incompatible_changes"></a>Incompatible changes</h3>
-
-<p>
-No recorded incompatible changes.
-
-<h3><a name="9.02_Changelog"></a>Changelog</h3>
-<p><strong><a name="2011-03-30T064801.334550Z"></a>
-2011-03-30T06:48:01.334550Z chrisl</strong></p>
-<blockquote>
-<pre>
-Extend the SSE2 check in both configure scripts.
-
-The check now attempts to declare a variable of a type missing in older
-versions of gcc.
-
-Bug 692102
-
-No cluster differences expected.
-
-</pre>
-<p>[base/configure.ac /trunk/ghostpdl/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-28T084948.387061Z"></a>
-2011-03-28T08:49:48.387061Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Reduce duplication of changelog and news by deprecating Changes.htm and
-Details#.htm.
-
-The information will now be in two places only: the highlights summary
-in News.htm, and the detailed changes in History#.htm.
-
-Update related documentation and html links to reflect this change.
-
-CLUSTER_UNTESTED
-</pre>
-<p>[doc/Changes.htm doc/Readme.htm doc/Details9.htm doc/Release.htm]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-26T145106.549590Z"></a>
-2011-03-26T14:51:06.549590Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for issue found by Chris where we have a soft mask embedded in a softmask
-and graphic state pushes and pops occurring. In this case, the soft mask stack
-that is saved gets out of sync compared to the one in the context state.
-Use of the stack count can catch the issue and correct it. Also a rename of
-one of the variables in the pdf14 code to make it easier to debug.</pre>
-<p>[base/gdevp14.c base/gdevp14.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-25T121205.657797Z"></a>
-2011-03-25T12:12:05.657797Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Fixes concerning the compatibility of the OpenPrinting Vector (&quot;opvp&quot;)
-output device with Ghostscript 9.x.
-
-1. If there is any ICCColor based image in the PostScript input, GS crashes.
-2. Fallback when path is too complex for some kinds of printers. This problem
-already existed in GS 8.x.
-
-Thanks to Koji Otani from BBR Inc., Japan.
-
-</pre>
-<p>[contrib/opvp/gdevopvp.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-25T102206.357287Z"></a>
-2011-03-25T10:22:06.357287Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-The code was erroneously attempting to get a glyph name for a case where
-we already had a glyph index for a Truetype font.
-
-Add a check for object type before trying to get a string from a name object.
-
-
-Bug 692095
-
-No cluster differences expected.
-
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-24T172617.397320Z"></a>
-2011-03-24T17:26:17.397320Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Resolve build issues with language_switch and UFST.
-
-I had (wrongly) assumed that the PCL/language_switch builds with UFST
-and COMPILE_INITS=1 would have the relevant paths correctly setup for
-the PS/PDF world to access the Microtype FCOs. It turns out they are
-done in an incompatible manner.
-
-So, I've renamed the path variables (in the makefiles) so there isn't
-a clash between PCL and PS/PDF, ensured that the variables are correctly
-passed through recursive (n)make calls, and tidied up the FAPI options
-for the language_switch build.
-
-Not only does this allow language_switch to build with the UFST, but the
-Postscript interpreter does now use FAPI/UFST to access the Microtype fonts
-for the built-in fonts, and uses FAPI/Freetype for downloaded fonts.
-
-Bug 692093
-
-No cluster differences expected.
-
-</pre>
-<p>[/trunk/ghostpdl/common/msvc_top.mak /trunk/ghostpdl/language_switch/pspcl6_msvc.mak /trunk/ghostpdl/main/pcl6_gcc.mak psi/msvc.mak base/Makefile.in psi/int.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-24T042223.459616Z"></a>
-2011-03-24T04:22:23.459616Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for compiler warning.</pre>
-<p>[base/gdevp14.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-23T213420.429081Z"></a>
-2011-03-23T21:34:20.429081Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-This commit fixes several issues.
-
-Memory leaks in the PDF14 device as well as the separation devices.
-Fixes in PDF14 device so the the color encoder and decoder are properly updated
-if soft masks occur with spot colors.
-Proper copying of the devicen parameters to the clist devices in the MT
-rendering. This was the source of a problem when doing multi-threaded
-rendering to separation devices.
-
-This fixes bug 692087</pre>
-<p>[base/gdevp14.c base/gsicc_cache.c base/gxclutil.c base/gdevpsd.c base/lib.mak base/gdevp14.h base/gxclthrd.c base/gdevtsep.c base/gdevdevn.c base/gxblend.c base/gdevdevn.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-21T112417.021832Z"></a>
-2011-03-21T11:24:17.021832Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for memory leaks in the pdf14 device. These could occur with softmask and
-graphic state changes as well as when we are going to a tiffsep device. </pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-20T014019.345427Z"></a>
-2011-03-20T01:40:19.345427Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for bug 692087 crashes. num_bytes - bytes_dropped was ending up negative
-in cases where the transparency device was reducing the number of colorants
-compared to the target device (mainly when we had a softmask) which was getting
-passed into the clist as an unsigned value. Now when this occurs we just use
-the encoding of the full color value. </pre>
-<p>[base/gxclutil.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-19T045652.259544Z"></a>
-2011-03-19T04:56:52.259544Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-A temp fix for bugs 692038 and 692065. The clist devices that are created for
-the threads now inherit the icc profile from the target device. I need to set
-things up so that the device profile is no longer reference counted since we
-could have a race condition problem if the different threads are incrementing
-and decrementing the count and if the command is not atomic on a particular
-architecture. The plan will be to no longer ref count the device profile but
-to have it maintained until the the actual target device is destroyed. There
-will be a bit of work to do with respect to the pdf14 device, which can have
-a device profile that is different than the actual target device. That profile
-can be altered with the transparency group pushes and pops.</pre>
-<p>[base/gxclthrd.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-19T003237.910024Z"></a>
-2011-03-19T00:32:37.910024Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix for some strange rendering with PDF 1.7 FTS files when we have shading and
-transparency and are both filling and stroking text (Text Rendering modes 2
-and 6). Customer 532.
-
-</pre>
-<p>[Resource/Init/pdf_ops.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-18T051608.669973Z"></a>
-2011-03-18T05:16:08.669973Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix so that image_parent_type is properly initialized during clist image
-reading.</pre>
-<p>[base/gsiparm4.h base/gximage1.c base/gximage4.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-17T152458.552348Z"></a>
-2011-03-17T15:24:58.552348Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Escape/quote the UFST path settings in the makefile so that the macros
-correctly expand to strings.
-
-Bug 692082
-
-No cluster differences expected
-
-CLUSTER_UNTESTED
-</pre>
-<p>[base/Makefile.in]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-17T095453.062174Z"></a>
-2011-03-17T09:54:53.062174Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Uncached glyphs were ignoring rendering mode 3, and being imaged
-directly to the device - for cached glyphs the decision occurred
-in the &quot;show machinery&quot;.
-
-This wasn't my first choice solution, but all the others I tried
-caused problems with later use of a cached glyph (which wasn't
-actually cached), or problems with pdfwrite, pswrite or ps2write.
-
-
-Bug 692004
-
-No cluster differences expected.
-
-</pre>
-<p>[base/gspaint.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-17T094116.074991Z"></a>
-2011-03-17T09:41:16.074991Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Fix some issue where user specified devices didn't get the requisite
-&quot;$(DD)&quot; and &quot;.dev&quot; runes added to them.
-
-Also, rearrange the &quot;pre-declared&quot; device strings to be more
-consistent within configure.ac
-
-
-Bug 692062
-
-No cluster differences expected.
-
-
-</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-15T175917.340024Z"></a>
-2011-03-15T17:59:17.340024Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add special case mem_planar_copy_color_4to1 code for copying bits
-from 4 1 bit planes into 1 4 bit chunky plane.
-
-This helps with performance of the plibk device.
-
-No cluster differences expected.</pre>
-<p>[base/gdevmpla.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-15T083505.386182Z"></a>
-2011-03-15T08:35:05.386182Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (ps2write) : Indexed colour images have incorrect /Decode
-
-Bug #691924 &quot;Differences in colour with ps2write&quot;
-
-The problem was due to the opdfread code generating a /Decode for an Indexed
-colour space where the value was [0 2^n] and should be [0 ((2^n) - 1)]. This
-caused the highest image sample to be mapped to 1 past the end of the samples
-in the colour space.
-
-Normally this doesn't matter, because the values are clamped to 'hival' in the
-Indexed space. In this case, however, the image was 2 bpp (4 values) but the
-colour space was defined as a full 256 indices, with only the first 4 bein
-used.
-
-The incorrect Decode caused the image sample value 3 to be looked up as colour
-space sample 4, which was set to all 0 (black) causing incorrect colour values.
-
-</pre>
-<p>[base/opdfread.h lib/opdfread.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-14T154615.599171Z"></a>
-2011-03-14T15:46:15.599171Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Reintroduce commented out PACIFY_VALGRIND definition in gximono.c - without it
-the comment makes no sense.
-
-Add new PACIFY_VALGRIND code (and commented out definition) in
-gxht_threshold.c.
-
-Fix some line endings.
-
-No real code change, so no cluster differences expected.
-
-</pre>
-<p>[base/gximono.c base/gxht_thresh.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-14T151608.036660Z"></a>
-2011-03-14T15:16:08.036660Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix an indetermism in the halftoning code. When mapping a y offset into a
-row index for a halftone tile, special care needs to be taken when y is
-negative. Proof (as if more were needed) that the % operator in C is evil.
-
-The command in question was a cutdown version of C306.bin rendered at 600bpi
-to pbmraw with dMaxBitmap=10000.
-
-It now runs into a clist UMR. Will keep looking.</pre>
-<p>[base/gximono.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-14T135351.702509Z"></a>
-2011-03-14T13:53:51.702509Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (ps2write) : Don't set a default halftone.
-
-Bug #691923 &quot;Differences in dithered output with ps2write&quot;
-
-The PDF interpreter emits a setpagdevice between every page of output, in case
-the media size has changed. The implementation of setpagedevice resets the
-halftone to be the default halftone (106 lpi 45 degree line screen).
-
-This is a problem for ps2write, and potantially pdfwrite, as there is no way to
-differentiate between a default halftone set by setpagdevice, and a halftone
-contained in the input file.
-
-To avoid embedding an unhelpful halftone, we now check the device parameter
-'/HighLevelDevice' in the setpagedevice implementation, and if it is present
-and true, we do not call .setdefaulthalftone.
-
-Also updates documentation on device parameters.
-
-This causes differences on every 1-bit rendering test (ie pkmraw) of the
-ps2write output file, so approximately 1300 differences are to be expected.
-</pre>
-<p>[doc/Drivers.htm Resource/Init/gs_setpd.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-14T130003.503443Z"></a>
-2011-03-14T13:00:03.503443Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix Bug 692064. Tiffscaled device was checking on page print time that the
-expected size of the page wouldn't make the page too large to fit in a file.
-This code was copied from the tiffgray device (as we render internally in
-8bpp). As we output in monochrome however (and may use compression) the
-test is in fact bogus, and should simply be removed. We do that here.
-
-It's entirely possible that we should be removing the test from the
-tiffgray device too - most systems with 32bit longs support large files these
-days, and compression may apply here too anyway. I'll leave this until it
-becomes an issue though.
-
-No cluster differences expected.</pre>
-<p>[base/gdevtsep.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-13T115708.378919Z"></a>
-2011-03-13T11:57:08.378919Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Some updates to the new device parameters. It turned out that the intended
-parameter Type32ToUnicode was incorrectly implemented. This should actually
-have used the WantsToUnicode parameter, because the code actually controls the
-processing of GlyphNames2Unicode tables from Windows PostScript.
-
-This means we no longer need the Type32ToUnicode parameter and it has been
-removed.
-
-Added initial documentation of these parameters.
-
-This appears to cause some differences in Bug690829.ps rendered at 300 dpi.
-This is a surprise, because the changes should have no effect on devices other
-than pdfwrite/ps2write, but the new result is better than the old, so this is
-a progression.
-</pre>
-<p>[Resource/Init/gs_pdfwr.ps base/gdevpdfx.h base/gdevpdfp.c doc/Drivers.htm base/gdevpdfb.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-13T012149.785339Z"></a>
-2011-03-13T01:21:49.785339Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Remove spurious debug printout inserted in rev 12141 line 780:
-1 index == 0 index ==
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-11T192457.067395Z"></a>
-2011-03-11T19:24:57.067395Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Change the default value for the 'AllowPSRepeat' so that it defaults to allowed
-instead of disallowed (doh!) This is important for those devices which don't
-set the device parameter.
-
-No differences expected.
-</pre>
-<p>[psi/zfunc4.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-11T171451.124213Z"></a>
-2011-03-11T17:14:51.124213Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Remove a #if 0 accidentally left in the commit for revision 12282. Also
-initialise a variable, just in case.
-
-No differences expected.
-</pre>
-<p>[psi/zfunc4.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-11T165834.690669Z"></a>
-2011-03-11T16:58:34.690669Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-The final removal of the reliance on testing the device name to influence
-interpreter behaviour.
-
-This tests the /AllowPSRepeat paramter and flags an error if a function tries
-to use 'repeat' when it is disallowed.
-
-Still to do: write some documentation on these new parameters.
-
-No differences expected.
-</pre>
-<p>[psi/zfunc4.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-11T151440.609962Z"></a>
-2011-03-11T15:14:40.609962Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Add the new third party library directories to the Windows nmake zip file
-target.
-
-No cluster differences.
-
-Bug 691944
-
-Credit to: Gennadiy Tsarenkov.
-
-CLUSTER_UNTESTED
-
-</pre>
-<p>[psi/winint.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-11T150756.095474Z"></a>
-2011-03-11T15:07:56.095474Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Rejig the romfs targets so that unix make can follow the dependencies.
-
-This should prevent the pointless rebuilding of the romfs C source.
-
-Bug 692053
-
-No cluster differences expected.
-
-</pre>
-<p>[base/lib.mak base/unix-aux.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-11T090424.536166Z"></a>
-2011-03-11T09:04:24.536166Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Some (broken) TrueType fonts have out of order loca tables, which can result
-in the calculated glyph data lengths being larger than the actual
-available glyph data. Normally this does not cause a problem, but if the glyph
-in question is in the final bytes of the stream, we encounter an unexpected
-end of data condition when creating the glyph data buffer to pass into
-Freetype.
-
-So the FAPI interface code will now ignore that error, and adjust the byte
-length to correctly reflect the number of bytes available in the buffer.
-
-It is safe to do this because, in the event we have a genuine out-of-data
-condition, Freetype will return an error when it tries to interpret the
-glyph outline.
-
-Bug 692043
-
-No cluster differences expected.
-
-</pre>
-<p>[psi/fapi_ft.c psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-11T054519.450208Z"></a>
-2011-03-11T05:45:19.450208Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Fix missing header problem on older versions of MSVC.
-</pre>
-<p>[base/gsropt.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-11T041539.316030Z"></a>
-2011-03-11T04:15:39.316030Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-A reorganization of the halftone code in preparation of doing thresholding of
-color images. This basically pulls out some code pieces that will be shared
-in all the image thresholding cases. No differences expected
-(or seen in the cluster push).</pre>
-<p>[base/gxht_thresh.h base/lib.mak base/gximono.c base/gxicolor.c base/gxht_thresh.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-10T173138.501799Z"></a>
-2011-03-10T17:31:38.501799Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-I missed one change in commit 12274. The detection of chunky modes should
-look at num_planes being &lt;= 1, not == 1.
-
-I tested this locally and then clearly missed it when cluster pushing.
-</pre>
-<p>[base/gdevdrop.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-10T165615.200283Z"></a>
-2011-03-10T16:56:15.200283Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Planar device is broken w.r.t rops in a cmyk space - this commit fixes it.
-
-The planar memory device sets itself to use gx_default_strip_copy_rop
-rather than mem_strip_copy_rop. mem_strip_copy_rop knows that rops on
-cmyk pixels should actually convert to rgb, perform the rop, and convert
-back again, but doesn't know how to convert the results back when it's in
-planar mode. gs_default_strip_copy_rop can cope with planar mode, but doesn't
-know to convert to rgb first.
-
-The first fix included here is to extend mem_strip_copy_rop to know how to
-write back to planar format, and then to make the planar memory device use
-mem_strip_copy_rop.
-
-This then exposes various flaws in mem_strip_copy_rop, including the fact
-that it relies on being able to set the offset in get_bits calls when this
-is sometimes not possible. We therefore fix the code to manage offsets
-by explicitly updating them.
-
-Also, the raster used in mem_strip_copy_rop was incorrect - we use the
-correct one and get much better results.
-
-No cluster differences expected as the planar device is not tested.
-
-</pre>
-<p>[base/gdevdrop.c base/gdevmpla.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-10T164220.394889Z"></a>
-2011-03-10T16:42:20.394889Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-The routines in gdevplib.c intended to map colors in cmyk form back to rgb
-were incorrect. Fixed here.
-
-No differences expected as this files isn't linked in by default.
-
-CLUSTER_UNTESTED
-
-
-</pre>
-<p>[base/gdevplib.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-10T162704.913812Z"></a>
-2011-03-10T16:27:04.913812Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove the buffer blanking done in gximono.c. Previously removing this would
-have caused indeterminisms. With the additional fix in here to limit
-offset_bits to dest_width, however, we should get stable results.
-
-This gives various differences in output (81 in pcl, presumably more in PDF
-and PS). Bmpcmp of the pcl ones shows them as all progressions.
-
-</pre>
-<p>[base/gximono.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-10T145508.103488Z"></a>
-2011-03-10T14:55:08.103488Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Update the remaining PostScript files (mostly the PDF interpreter) to use the
-new device parameters instead of explicitly checking for the device being named
-'pdfwrite' or 'ps2write'.
-
-Some more modification is still required, but we're nearly there. We will
-continue to check the device names in gs_pdfwr.ps when setting up the default
-state for those specific devices.
-
-Although not strictly a Distiller device, ps2write declares itself to be
-'IsDistiller'. This is because some PostScript test files were found to behave
-differently if the distillerparams operators were available, in particular
-files would be oriented differently if the device was deemed to be a Distiller.
-
-</pre>
-<p>[Resource/Init/gs_pdfwr.ps Resource/Init/pdf_font.ps Resource/Init/pdf_draw.ps base/gdevpdfb.h Resource/Init/gs_setpd.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-10T073145.990562Z"></a>
-2011-03-10T07:31:45.990562Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Ignore null object when it is used instead of the gstate dictionary.
-Bug 692050.
-</pre>
-<p>[Resource/Init/pdf_main.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-10T061917.004672Z"></a>
-2011-03-10T06:19:17.004672Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Change all instances of true, false, and null to //true, //false, and //null
-to avoid interferance from PS files that redefine them. Bug 692041.
-</pre>
-<p>[Resource/Init/gs_typ32.ps Resource/Init/gs_cidfm.ps Resource/Init/gs_mgl_e.ps Resource/Init/pdf_rbld.ps Resource/Init/gs_resmp.ps Resource/Init/gs_dscp.ps Resource/Init/gs_fonts.ps Resource/Init/gs_wan_e.ps Resource/Init/gs_mex_e.ps Resource/Init/gs_ttf.ps Resource/Init/gs_cspace.ps Resource/Init/gs_cff.ps Resource/Init/gs_dps1.ps Resource/Init/gs_lev2.ps Resource/Init/pdf_sec.ps Resource/Init/gs_l2img.ps Resource/Init/gs_cet.ps Resource/Init/gs_dbt_e.ps Resource/Init/gs_pdf_e.ps Resource/Init/gs_statd.ps Resource/Init/gs_fapi.ps Resource/Init/gs_pdfwr.ps Resource/Init/gs_cidfn.ps Resource/Init/pdf_main.ps Resource/Init/gs_dps.ps Resource/Init/gs_res.ps Resource/Init/gs_ll3.ps Resource/Init/gs_css_e.ps Resource/Init/gs_epsf.ps Resource/Init/pdf_draw.ps Resource/Init/gs_dpnxt.ps Resource/Init/gs_icc.ps Resource/Init/gs_mro_e.ps Resource/Init/pdf_ops.ps Resource/Init/gs_init.ps Resource/Init/pdf_font.ps Resource/Init/gs_ciddc.ps Resource/Init/gs_trap.ps Resource/Init/gs_cidtt.ps Resource/Init/gs_diskn.ps Resource/Init/gs_fntem.ps Resource/Init/pdf_base.ps Resource/Init/gs_sym_e.ps Resource/Init/gs_img.ps Resource/Init/gs_btokn.ps Resource/Init/gs_cidcm.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-10T005808.762234Z"></a>
-2011-03-10T00:58:08.762234Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for bug 692038.
-
-This fixes 3 issues when using a CIELAB based profile for the output device
-ICC profile.
-
-One was a problem when handling separation color spaces when they had the ALL
-entry and we were going to an additive device. AR does a 1-INK level for the
-device values and no color management. We were doing the same, but this approach
-will not work if our destination color space is CIELAB. Now if we are headed toward
-CIELAB we do the 1-INK to RGB and then transform to CIELAB.
-
-Another was that transparency blending should never be done in CIELAB or similar type
-color spaces. With transparency, the PDF14 device inherits the profile for the target
-device and if the transparency groups don't specify a color space we would end up blending
-in CIELAB. The solution was to detect this situation and use the defaultRGB profile for blending.
-Conversion to CIELAB occurs during the pdf14 put image operation.
-
-Finally, with shading in transparency, we need to make sure to pass along the transparency device
-through the shading parameters whenever we have a color mismatch between the pdf14 device and the
-target device so that the shading will occur in the proper color space.
-
-These changes are all related to a non-tested cluster case when we have -sOutputICCProfile=lab.icc</pre>
-<p>[base/gdevp14.c base/gxcmap.c base/gstrans.c base/gxclist.h base/gdevtfnx.c base/gsfunc0.c base/devs.mak base/gsicc.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-09T213258.461339Z"></a>
-2011-03-09T21:32:58.461339Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add gxht_thresh.{c,h} to Visual C project.
-
-CLUSTER_UNCHECKED</pre>
-<p>[ghostscript.vcproj]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-09T144440.068733Z"></a>
-2011-03-09T14:44:40.068733Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Disable PACIFY_VALGRIND in gximono.c. This define is intended to enable
-extra code that can be performed so as to ensure that valgrind doesn't
-report false positives. As such, disabling it should have no adverse
-effects.
-
-Unfortunately, it seems that in the portrait case, if we don't blank the
-threshold array before we run, we get diffs. I have therefore taken this
-memset out of the PACIFY_VALGRIND case and forced it to always happen.
-This probably points to a bug and should be investigated properly.
-
-No cluster differences expected.
-
-</pre>
-<p>[base/gximono.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-08T200017.821965Z"></a>
-2011-03-08T20:00:17.821965Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Simple optimisations to non SSE2 versions of halftoning code. There is
-probably (certainly!) more performance to come with loop unrolling etc,
-but this at least gets us the cheap win of avoiding repeated array accessing,
-only setting, not blanking bits etc.
-
-Cluster tests show no changes.
-
-</pre>
-<p>[base/gxht_thresh.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-08T174051.077420Z"></a>
-2011-03-08T17:40:51.077420Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Change to gsroprun1.h to avoid over/underreading the source/texture buffers.
-
-Given a valid byte range we expand that to the smallest enclosing CHUNK range
-and guarantee never to access out of that range. Previously we could read
-one CHUNK before/after it.
-
-If this is a problem, simply ensure that CHUNK is byte rather than int on
-your platform. This now behaves better than the original code which would
-access one byte before/after the defined range.
-
-No cluster differences seen in testing.
-
-</pre>
-<p>[base/gsroprun1.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-08T163516.023687Z"></a>
-2011-03-08T16:35:16.023687Z Tor Andersson</strong></p>
-<blockquote>
-<pre>
-Add PNG reading support to the bmpcmp tool.</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-08T151842.397978Z"></a>
-2011-03-08T15:18:42.397978Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Update to use the new device parameter /PreserveTrMode instead of explicitly checking
-for the device name being 'pdfwrite'.
-
-No differences expected.
-</pre>
-<p>[Resource/Init/pdf_ops.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-08T082754.788378Z"></a>
-2011-03-08T08:27:54.788378Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Activate the new device parameters, and modify the resource code to use the first one
-(AllowIncrementalCFF) instead of testing for the pdfwrite device name.
-
-No differences expected.
-</pre>
-<p>[Resource/Init/gs_cidfn.ps base/gdevpdfp.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-08T002607.330315Z"></a>
-2011-03-08T00:26:07.330315Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-When using PACIFY_VALGRIND, don't call the memory blanking when the
-mallocs have failed.
-
-This should cure the SEGVs that were introduced, but otherwise cause no
-changes.
-
-</pre>
-<p>[base/gximono.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-07T221929.253652Z"></a>
-2011-03-07T22:19:29.253652Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Initialize ht landscape structure to zero when in portrait case. There is
-a conditional test on the value later.</pre>
-<p>[base/gximono.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-07T215702.879011Z"></a>
-2011-03-07T21:57:02.879011Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Correct line endings (were DOS, should be Unix).
-
-No cluster differences.
-
-CLUSTER_UNTESTED
-
-</pre>
-<p>[base/gxht_thresh.h base/gxht_thresh.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-07T211712.494498Z"></a>
-2011-03-07T21:17:12.494498Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add new debugging define to gximono.c, PACIFY_VALGRIND.
-
-This enables various small tweaks in the code that stop valgrind throwing
-errors. We believe that all the errors thrown are false positives, but
-we enable this define anyway until we've sorted the current indeterminisms.
-We'll disable it in a few days when we have solved the problems and check that
-it really doesn't cause any more.
-
-Cluster results unknown; probably no change. If this solves indetermisms
-then we'll need to understand why.
-
-</pre>
-<p>[base/gximono.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-07T211156.916525Z"></a>
-2011-03-07T21:11:56.916525Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix typos, one in a comment, one in an id string.
-
-No cluster differences.
-
-CLUSTER_UNTESTED
-
-</pre>
-<p>[base/gxipixel.c base/gzspotan.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-07T185808.149818Z"></a>
-2011-03-07T18:58:08.149818Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for improper indexing of reversed portrait image line. We were off
-by one byte and ended up with one byte not set. Def. a source of
-indeterminism. Thanks to Robin for tracking this down.</pre>
-<p>[base/gximono.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-07T154013.201330Z"></a>
-2011-03-07T15:40:13.201330Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Undo revision 12243. The revision makes a debug print dependent on the value of the
-'size_set' variable. Unfortunately, this variable is not defined in the cups_get_matrix
-routine. It is defined in the other places it is used (cups_put_params).
-
-This prevents a debug build from compiling on Windows, and I can't see how it would
-work on any other OS when built for debug.
-
-Reverted the change in order to build debug versions of Ghostscript.
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-07T142111.345196Z"></a>
-2011-03-07T14:21:11.345196Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Redo revision 12248 in a way which (hopefully!) doesn't cause seg faults.
-
-Still no differences expected....
-</pre>
-<p>[base/gdevpdfx.h base/gdevpdfp.c base/gdevpdfb.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-07T124047.052280Z"></a>
-2011-03-07T12:40:47.052280Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Account for fonts in which (some) charstrings have been replaced with
-Postscript procedures when FAPI decides an outline, or just a width
-is required. The previous code only handled this case for rendered
-glyphs from Freetype.
-
-Bug 692029
-
-No cluster differences expected.
-
-
-
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-07T111219.973357Z"></a>
-2011-03-07T11:12:19.973357Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-pdfwrite &amp; ps2write enhancement
-
-Add some new keys to the device parameters dictionary for these devices. These will be
-used to replace the explicit tests against the device name in various places in future
-commits.
-
-These will also later be documented and their use suggested for any devices requiring
-the same capabilities.
-
-No differences expected, these are not used yet.</pre>
-<p>[base/gdevpdfp.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-07T094302.986503Z"></a>
-2011-03-07T09:43:02.986503Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Update the second place where we may have to reset the Freetype glyph object.
-
-Again, this means we only free the outline or bitmap data, and just let
-Freetype &quot;reset&quot; its glyph object between glyphs.
-
-No cluster differences expected.
-
-</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-07T070812.439689Z"></a>
-2011-03-07T07:08:12.439689Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix for compositor device chaining in the pdf14 device. This was detected in a
-file that did overprint along with transparency. The pdf14 device incremented the
-ref_count for the overprint_device, but never decremented it since the 'finalize'
-of the pdf14 device was left at NULL rather than being set to the gx_forward_finalize
-function which should be used. The gx_device_set_target, rather than rc_assign does
-the proper set of the finalize proc pointer so that reference counts for the device
-chain are properly maintained. Detected by customer 532 since their device freed
-the clist buf_device resulting in the overprint_device having a 'target' pointer
-to freed memory, causing a SEGV when the 'finalize' function executed.
-
-No regressions expected since in the normal code, the GC frees the devices that
-were left unreferenced by the free of the pdf14 device.
-</pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-06T165219.765042Z"></a>
-2011-03-06T16:52:19.765042Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix to use proper DDA incrementation for interpolation.
-We still maintain special loops for when there is no scalin
-or for when it is 2x. This should fix the intdeterminism issues.
-Tested performance on customer files and no significant difference
-was observed. About 1500 cluster differences will be reported with
-this fix.</pre>
-<p>[base/lib.mak base/gximono.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-06T111548.120325Z"></a>
-2011-03-06T11:15:48.120325Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Instead of destroying and recreating freetype's glyph object for every glyph
-we need to render, we can just free the &quot;transient&quot; parts: the bitmap or the
-outline.
-
-Saves a very small amount of time, and potentially reduces memory pool
-fragmentation.
-
-No cluster differences expected.
-
-</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-05T174646.608714Z"></a>
-2011-03-05T17:46:46.608714Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Do not do debug output of an uninitialized variable
-
-Thanks to Richard Hughes (hughsient at gmail dot com) for the patch.
-
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-04T192750.114304Z"></a>
-2011-03-04T19:27:50.114304Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Correction on Richard Hughes' patch for color management in the CUPS filters.
-</pre>
-<p>[cups/colord.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-04T175100.067911Z"></a>
-2011-03-04T17:51:00.067911Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Fix a warning and type error. Code should produce the same results,
-so no testing.
-
-CLUSTER_UNTESTED
-
-</pre>
-<p>[base/gdevdgbr.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-04T133411.568425Z"></a>
-2011-03-04T13:34:11.568425Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add FIXME to gximono.c about possible future optimisation, so it is not
-forgotten.
-
-CLUSTER_UNTESTED
-
-</pre>
-<p>[base/gximono.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-04T093504.845642Z"></a>
-2011-03-04T09:35:04.845642Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Only attempt to create files in the &quot;cups&quot; directory if it exists.
-</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-04T064529.360251Z"></a>
-2011-03-04T06:45:29.360251Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Reorganization of threshold code to move all the thresh holding operations into a new file. </pre>
-<p>[base/gxht_thresh.h base/lib.mak base/gximono.c base/gximage.h base/gxht_thresh.c base/gsiparam.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-04T061653.560659Z"></a>
-2011-03-04T06:16:53.560659Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Add missing test for /packedarraytype during recursive dereferencing
-of composite PDF objects. Bug 692018, customer 850.
-</pre>
-<p>[Resource/Init/pdf_base.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-03T222022.363870Z"></a>
-2011-03-03T22:20:22.363870Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-The get_bits() device call was assumed to return copied data and fill
-in the allocated memory pointed to by the variable row, in fact the
-gets_bit call can also just return a pointer and row is never
-initialized, now we detect that. This broke raster operations for the
-display device and appears to have resulted in the use of
-uninitialized data in other files. A sampling of changed files showed
-single pixel differences in files.
-
-</pre>
-<p>[base/gdevdgbr.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-03T202923.683592Z"></a>
-2011-03-03T20:29:23.683592Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Update plibc and plibk to output pams when built with DEBUG_DUMP.
-
-No cluster differences possible as this code is not used in cluster testing.
-
-CLUSTER_UNTESTED</pre>
-<p>[base/gdevplib.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-03T202343.920044Z"></a>
-2011-03-03T20:23:43.920044Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add new pamcmyk4 device. Identical to pamcmyk32 device, but works in 1 bit
-per component, rather than 8.
-
-No cluster differences expected as this code isn't tested.</pre>
-<p>[psi/msvc.mak base/unix-gcc.mak base/gdevpbm.c base/devs.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-03T175148.590954Z"></a>
-2011-03-03T17:51:48.590954Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Enabling of thresholding code as default image rendering of monochrome/indexed
-images for monochrome devices. This will result in about 2432 differences reported.
-I stepped through them in a bmpcmp to check for serious issues. The minor halftone
-differences were due to the fact that we step in the device space for pixel replication
-in the threshold code but step in source space for the rect fill code. Enabling this
-code now will make it easier to track issues as we expand the use of the thresholding code.</pre>
-<p>[base/gximono.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-03T154846.192376Z"></a>
-2011-03-03T15:48:46.192376Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add plib device (c and h) files to ghostscript project file.
-
-No cluster differences expected as project file is not used by cluster.
-
-CLUSTER_UNTESTED</pre>
-<p>[ghostscript.vcproj]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-03T000827.251299Z"></a>
-2011-03-03T00:08:27.251299Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Added the ability to specify bmpcmp in addition to a normal clusterpush.pl
-operation. Both commands will be queued in the correct order.
-
-Examples:
-
-./clusterpush.pl gs bmpcmp
-./clusterpush.pl bmpcmp gs pcl xps ls
-
-Note that the order of the options is not signficant.
-
-The command line parser for clusterpush.pl changed signficantly with this
-revision. It should be backwards compatible with the previous version
-but it's possible that subtle differences exist. If a clusterpush.pl
-command line behaves differently than you expect please open a bug.
-
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/clusterpush.pl toolbin/localcluster/clusterpush.txt]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-02T221239.208205Z"></a>
-2011-03-02T22:12:39.208205Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix rop operation on plib device. Previously, I'd disabled get_bits_rectangle
-on the buffer device as the data is normally in the format we need it in
-anyway, so it's a NOP. Unfortunately it's needed for rop operation, so
-reintroduce it.
-
-To avoid infinite loops, we have to cope with GB_RETURN_POINTER. This is
-easy to add to the gdevmpla.c device, but it's less clear that adding it
-into the mem device is the right thing to do. We therefore introduce a
-shim function to cope with GB_RETURN_POINTER with the mem device.
-
-No cluster differences expected as this is disabled by default.
-
-Testing shows that the planar device is now very close to the non planar
-equivalent.</pre>
-<p>[base/gdevplib.c base/gdevmpla.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-02T205046.635530Z"></a>
-2011-03-02T20:50:46.635530Z regression</strong></p>
-<blockquote>
-<pre>
-Minor bug fixes and improvements to the cluster system, the most
-signifcant of which is the addition of &quot;CLUSTER_UNTESTED&quot; detection.
-If this keyword appears anywhere within the log message of a commit that
-revision will not be tested by the cluster.
-
-Less interesting changes include:
-
-Fix for bmpcmp if large numbers of differences are produced
-
-Addition of 'svn cleanup' calls before 'svn update' to handle nodes that
-crashed during previous 'svn update' and left the repositories locked
-
-Set status of all nodes to idle after jobs are completed.
-
-Fix bugs that caused bmpcmp completed emails to be appended to the
-previous message.
-
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/pngs2html.pl toolbin/localcluster/build.pl toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-02T185123.645025Z"></a>
-2011-03-02T18:51:23.645025Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Introduction of a member variable in gs_image1_t, which will let us know the
-original source type of the image. For example if, the parent source were type3
-this spawns two type1 images. One for the mask and one for the image data. The
-mask is rendered using image render simple. If the image is monochrome or indexed,
-it is rendered with the renderer in gximono.c . If we are going to a halftone
-monochrome device, we end up using the fast threshold based renderer which has its
-interpolation stepping in device space as opposed to source space. This causes very
-minor differences between the mask and the image data. To avoid this, we use the old
-rect_fill code for the image type3 data to ensure a more exact spatial match.</pre>
-<p>[base/gximono.c base/gximage1.c base/gximage2.c base/gximage3.c base/gximage4.c base/gximage.h base/gximag3x.c base/gsiparam.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-02T133952.433442Z"></a>
-2011-03-02T13:39:52.433442Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix bmpcmp bug; the map array was being incorrectly sized, resulting in
-occasional memory corruption.
-
-No cluster differences expected.</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-02T000925.760114Z"></a>
-2011-03-02T00:09:25.760114Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Debug output for gdevplibm (monochrome planar interlaced bands) was broken
-and writing malformed pbms. Simple fix - move the mono output code to the
-mono branch of the if rather than the grey one.
-
-No cluster differences expected.</pre>
-<p>[base/gdevplib.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-01T193056.622647Z"></a>
-2011-03-01T19:30:56.622647Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove DOS line endings from .gitignore files.</pre>
-<p>[.gitignore /trunk/ghostpdl/.gitignore]</p>
-</blockquote>
-
-<p><strong><a name="2011-03-01T171830.158752Z"></a>
-2011-03-01T17:18:30.158752Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for error introduced in non-SSE2 code when I removed the inclusion
-of the transfer function into the threshold values.</pre>
-<p>[base/gximono.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-28T223128.419926Z"></a>
-2011-02-28T22:31:28.419926Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Added color management support to the CUPS ...toraster filters
-
-Replaced the ...toraster filters by one filter executable, gstoraster,
-written in C. This filter converts both PostScript and PDF input into
-the CUPS Raster format using Ghostscript with the &quot;cups&quot; output
-device, controlled by settings in the print queue's PPD file, by
-command line options, and by settings embedded in a PostScript input
-stream. This is now done with color management based on
-printer-specific ICC profiles referenced in the PPD file or supplied
-by the color management daemon colord. The CUPS PPD extensions
-concerning color management
-(http://www.cups.org/documentation.php/doc-1.4/spec-ppd.html) are made
-use of if used and the colord daemon is used if it is present. colord
-is accessed via D-Bus, but the new filter can also be compiled without
-D-Bus and in this case only the CUPS PPD extensions and ICC profiles
-assigned to the print queue are used for color management.
-
-Thanks to Richard Hughes for the patch.
-
-</pre>
-<p>[cups/pstoraster.in cups/pstoraster.convs cups/gstoraster.c cups/pdftoraster.c cups/cups.mak base/Makefile.in cups/colord.c base/configure.ac cups/gstoraster.convs cups/pdftoraster.convs cups/colord.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-28T203043.994348Z"></a>
-2011-02-28T20:30:43.994348Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-X offset in custom 24 -&gt; 888 planar copy_color routine was being miscalculated.
-Simple fix.
-
-No cluster differences expected as this is untested.</pre>
-<p>[base/gdevmpla.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-28T193534.539587Z"></a>
-2011-02-28T19:35:34.539587Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove silly debugging hack left in gdevmpla.c by accident. Only affects
-planar 888 devices (i.e. none enabled by default).
-
-No cluster differences expected.</pre>
-<p>[base/gdevmpla.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-28T193237.270892Z"></a>
-2011-02-28T19:32:37.270892Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add simple .gitignore files.</pre>
-<p>[.gitignore /trunk/ghostpdl/.gitignore]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-28T104811.852106Z"></a>
-2011-02-28T10:48:11.852106Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Silence a compiler (scan-build) warning about a variable never being used.</pre>
-<p>[base/gdevpdfo.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-28T052346.157854Z"></a>
-2011-02-28T05:23:46.157854Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for mis-scale on decode for render mono cache. Fixes improper rendering
-of 148-11.ps with new halftone code.</pre>
-<p>[base/gxipixel.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-27T232610.406657Z"></a>
-2011-02-27T23:26:10.406657Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Removal (or inactivation) of code to include inverse of transfer function in
-the threshold values. Also minor fix for scaling issue in halftone code in
-portrait mode. Code is inactive so no regression diffs expected.</pre>
-<p>[base/gximono.c base/gsht.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-27T232330.287293Z"></a>
-2011-02-27T23:23:30.287293Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for a bug that was introduced with the ICC branch. This was causing a
-mismatch between banded an unbanded rendering and in particular had rendering
-errors in banded mode when rendering PS and PDF files that had a non identity
-transfer function. Minor progression diffs in many files with very visible
-progressions in 246-01.ps, 258-01.ps as examples. What was happening is that
-when running in clist mode, we were not recognizing that a transfer function was
-present when doing the ICC branch. Stumble upon this working the transfer function
-in with the new threshold based halftoning code.</pre>
-<p>[base/gxipixel.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-27T015228.834714Z"></a>
-2011-02-27T01:52:28.834714Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix for PDF with ASCII85Decode filter that has a dictionary (even if empty)
-instead of a 'null' for the params. Stack has the param dict second on the
-stack, not third. Bug 692003, customer 700.
-</pre>
-<p>[Resource/Init/pdf_base.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-26T191752.838303Z"></a>
-2011-02-26T19:17:52.838303Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-TCUPS Raster driver: The macros in the cups_put_params() function
-could access uninitialized variables when logging error messages and
-this could lead to a segmentation fault, making Ghostscript crashing
-and many jobs not printed. Debian bug #615202.
-
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-26T184059.351498Z"></a>
-2011-02-26T18:40:59.351498Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix for PDF 1.7 fts_08_0808.pdf which can clip the corner of the really wide
-diagonal (magenta) stroke when banding is used. This was due to the 'extension'
-of a square line cap being incorrectly calculated. Customer 532 issue.
-</pre>
-<p>[base/gxstroke.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-26T182508.170267Z"></a>
-2011-02-26T18:25:08.170267Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix BUILD_SYSTEM conditional for 64 vs. 32 and add 'for Win64' message
-to help avoid confusion during setup.
-</pre>
-<p>[psi/winint.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-25T235750.833144Z"></a>
-2011-02-25T23:57:50.833144Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix bug reported by &quot;new customer feb 2011&quot;, whereby gs 8.71 on an embedded
-ppc platform is getting the colours on an image in a pdf wrong.
-
-Debugging shows that in gs_indexed_limit_and_lookup we take a floating point
-value, clip it, convert it to an int and use it to lookup which colour to use.
-On the reference x86 run we have a value of 1 (0x3f800000 as an IEEE float).
-On the ppc we have 0.999999 (0x3f7fffff as an IEEE float). This tiny difference
-results in values of 1 and 0 respectively when converted to the int, giving
-the wrong colour.
-
-The fix here is to add a small epsilon before conversion.
-
-A quick experiment in adding 0.5 rather than epsilon shows worse results.
-
-15 cluster differences in testing, none that actually survived a bmpcmp.
-
-
-</pre>
-<p>[base/gscolor2.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-25T194939.160812Z"></a>
-2011-02-25T19:49:39.160812Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix so that we only do the fast code if we are in portrait or landscape mode.
-Skewed objects will have to use the rect fill method.</pre>
-<p>[base/gximono.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-25T193355.727547Z"></a>
-2011-02-25T19:33:55.727547Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Addition of code to incorporate the inverse of the transfer curve into the
-threshold matrix. If the curve is an inverting type (e.g. 0 to 1 and 1 to 0)
-then a the thresholding comparison is switched. Also, if the curve is not
-monotonic, it can not be inverted and we revert to the old rect fill method.
-This commit has the code disabled so there should not be any regressions.</pre>
-<p>[base/lib.mak base/gximono.c base/gzht.h base/gxdht.h base/gsht.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-25T181349.002375Z"></a>
-2011-02-25T18:13:49.002375Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Set the GS_DLL to gsdll64.dll for a 64-bit build. The file list was correct,
-but the registry was not. Related to bug 691975 but not verified (I just
-checked the registry using regedit).
-</pre>
-<p>[psi/dwsetup.cpp]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-25T074221.024741Z"></a>
-2011-02-25T07:42:21.024741Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Revise how the UFST setting are handled in the makefiles.
-
-The previous version relied on GNU make extensions (specifically
-conditionals), whilst this version does not.
-
-No cluster differences expected.
-
-</pre>
-<p>[base/lib.mak psi/msvc.mak base/Makefile.in psi/int.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-24T111312.751072Z"></a>
-2011-02-24T11:13:12.751072Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Hopefully the final iteration of allowing SHARE_ZLIB
-to work correctly with COMPILE_INITS=1.
-
-This version changes only Unix-like builds, so Windows need
-not suffer, and also removes the reliance GNU make specific
-extensions.
-
-Bug 691986
-
-
-No cluster differences.
-
-</pre>
-<p>[base/unix-aux.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-24T005108.210054Z"></a>
-2011-02-24T00:51:08.210054Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add new plib family of devices (PLanar Interlaced Buffer). These 5 devices
-(plib = r8g8b8, plibg = g8, plibm = mono, plibc = c8m8y8k8, plibk = c1m1y1k1)
-use a new 'band donor' interface to request a band buffer, pass back
-rendered bands, and release bands at the end of the page.
-
-The idea is that other firmware can implement this simple interface, and
-Ghostscript can thus easily drive systems that expect planar interlaced
-input.
-
-On the whole there is relatively little new code here; the majority of the
-work is done using the existing planar device with the odd tweak here and
-there. Firstly, we lift the (artifical) constraints of the number of components
-supported (so greyscale is accepted as a planar device for simplicity).
-We spot the num_components = 1 case and just use the existing memory device
-interface.
-
-Secondly, we add a fast 888chunky to 888planar unpacking routine for use
-with copy_color.
-
-Within the plib device itself, we make use of the facility to set the line
-indexes to allow for interlaced operation. It would be easy to extend this
-device to offer planar non-interlaced operation too built on the same band
-donor interface simply by omitting this code.
-
-For debugging purposes we have options within the plib devices to store the
-data returned in each band into pxm files (as appropriate to the number of
-components). This code is deactivated by default as the output of this
-device is via the band donor interface, not the output file.
-
-No cluster differences expected as this code is disabled currently.
-
-Next job: discuss with Marcos how to cluster test this.
-
-</pre>
-<p>[base/gdevplib.c base/gdevmpla.c base/gdevplib.h base/gdevppla.c base/devs.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-23T160025.505362Z"></a>
-2011-02-23T16:00:25.505362Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Introduce and enable 8 bit rop run templated code.
-
-No cluster differences shown.
-
-</pre>
-<p>[base/gsroprun8.h base/lib.mak base/gsroprun.c ghostscript.vcproj]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-23T144145.053687Z"></a>
-2011-02-23T14:41:45.053687Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Remove commented out code left over from commit 12192</pre>
-<p>[base/lib.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-23T115400.145784Z"></a>
-2011-02-23T11:54:00.145784Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Reintroduce runrop changes to Visual Studio solution lost in recent merge
-(r12189).
-
-No cluster differences expected.
-
-</pre>
-<p>[ghostscript.vcproj]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-23T082540.039813Z"></a>
-2011-02-23T08:25:40.039813Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Revision to the changes for using the system zlib.
-
-r12184 caused problems on Windows.
-
-This approach uses configure to determine whether
-freetype should use the system zlib, based on whether
-Ghostscript is using the system zlib.
-
-Windows, of course, doesn't use configure, so it will
-never attempt to the use the system zlib.
-
-Bug 691986
-
-No cluster differences expected
-
-</pre>
-<p>[base/freetype.mak base/Makefile.in base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-23T032618.063337Z"></a>
-2011-02-23T03:26:18.063337Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Temporary fix to turn off fast code for cases where the bps of the index image is not 8bps</pre>
-<p>[base/gximono.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-23T010908.645858Z"></a>
-2011-02-23T01:09:08.645858Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Undo of rev 12184 by commenting out the changes for now. This change broke the windows build. </pre>
-<p>[base/lib.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-22T213158.870907Z"></a>
-2011-02-22T21:31:58.870907Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix warnings caused by merging the halftone branch to the trunk in r12189.
-
-No cluster differences expected.
-
-</pre>
-<p>[base/gxipixel.c base/gximono.c base/gsht.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-22T200337.651092Z"></a>
-2011-02-22T20:03:37.651092Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Forgot this file inthe last commit. Sorry!
-
-</pre>
-<p>[base/gsroprun24.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-22T195243.275685Z"></a>
-2011-02-22T19:52:43.275685Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Merge of halftone branch into the trunk. The new rendering code is actually
-disabled with this commit. As such, there should not be any testing
-differences.</pre>
-<p>[base/gxipixel.c base/lib.mak base/Makefile.in base/gxcie.h /trunk/gs base/gsht.c base/gxcmap.c psi/msvc.mak ghostscript.vcproj base/gximono.c base/gzht.h base/gxidata.c base/configure.ac base/gxdht.h base/gxcmap.h base/gxicolor.c base/gximage.h base/gsciemap.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-22T193857.296889Z"></a>
-2011-02-22T19:38:57.296889Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add templated 24bit rops. Clusterpushing seems to indicate this works.
-
-No cluster differences expected.
-
-</pre>
-<p>[base/lib.mak base/gsroprun.c base/gsroprun1.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-22T161008.900201Z"></a>
-2011-02-22T16:10:08.900201Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Tweak to allow compressed romfs to be built when we're configured
-to use the system's zlib rather than our own.
-
-As a side effect of this, freetype is now configured to use the
-same zlib instance as Ghostscript (instead of freetype's own
-subset of zlib sources).
-
-Bug 691986
-
-No cluster differences expected.
-
-</pre>
-<p>[base/freetype.mak base/lib.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-22T154409.440053Z"></a>
-2011-02-22T15:44:09.440053Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add new gsroprun files to Visual Studio solution.
-
-No cluster differences expected.
-
-</pre>
-<p>[ghostscript.vcproj]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-22T152803.132855Z"></a>
-2011-02-22T15:28:03.132855Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix DO_FILL_RECT_BY_COPY_ROP code, and enable it by default.
-
-The only thing wrong with the code before is the case when strip_tile_rectangle
-is called with both color0 and color1 being gx_no_color_index. That translates
-to rop=0xAA (i.e. D - no change). This is actually a special case that means
-it's really doing a copy_color operation. We handle this by punting in the
-same way as the old code used to.
-
-No cluster differences expected.
-
-</pre>
-<p>[base/gdevm1.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-22T001816.845591Z"></a>
-2011-02-22T00:18:16.845591Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Enable mono_copy_mono implemented in terms of mono_copy_rop.
-
-Very small changes to the code to ensure that the copied area is correctly
-clipped, this now gives identical results to the existing code, but should
-be faster.
-
-The tile_rectangle code is still misbehaving - will fix this in later
-revisions (I hope).
-
-No cluster differences expected.
-
-</pre>
-<p>[base/gdevm1.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-21T171210.825257Z"></a>
-2011-02-21T17:12:10.825257Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Recommit of 12163 to the trunk.
-
-The fit_copy macro checks for the start address being off the top of the
-screen, and clips it to zero. When it does this, it does: data -= y * raster,
-which gives problems if raster is a uint ( as uint * int == uint in C) and
-data is a 64 bit pointer.
-
-The fix is simply to cast the result to an int before using it. This solves
-various SEGVs with the mono_copy_mono using mono_copy_rop code.
-
-No cluster differences expected.
-
-</pre>
-<p>[base/gxdevice.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-21T160425.039434Z"></a>
-2011-02-21T16:04:25.039434Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-The structure containing the pthreads native elements making up a
-gp_semaphore structure was ending up incorrectly aligned on
-sparc32 Linux systems, and caused a bus error. Annoyingly, sparc32
-uses 32 bit pointers but requires 64 bit aligment.
-
-This change enforces maximum alignment for the elements of
-gp_semaphore, for the current platform.
-
-No cluster differences expected.
-
-Bug 691989
-
-</pre>
-<p>[base/lib.mak base/gpsync.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-21T122920.951013Z"></a>
-2011-02-21T12:29:20.951013Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix stupid typo in gsroprun.c that was causing templated rops to be different
-to non templated rops. With this fixed the cluster shows identical results
-(modulo indeterminisms), but the templated code is faster - so enable by
-default.
-
-No cluster differences expected.
-
-</pre>
-<p>[base/gsroprun.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-20T124120.382249Z"></a>
-2011-02-20T12:41:20.382249Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Initial reorganisation of code towards using copy_rops for copy_mono.
-
-Split the guts of mem_mono_strip_copy_rop out into a separate function
-mem_mem_strip_copy_rop_dev. This new function handles the actual copy in
-device space, leaving the original to cope with fiddling the rop according
-to colors.
-
-This 'inner' function is moved to gdevm1.c so it is present in both gs
-and ghostpcl builds. The existing (bitrotted) code in gdevm1.c to
-'USE_COPY_ROP' is revamped to call mem_strip_copy_rop_dev, but is disabled
-currently as the cluster is showing a few differences that need to be
-tracked down.
-
-Also, this introduces new code to do gsroprun's using code in a generic
-header file that gets repeatedly #included with different options. This
-code is currently disabled until we can verify that it gives identical
-results. The new 'templated' code uses native ints where possible, and
-(in initial limited testing) seems to perform better than copy_mono.
-
-No cluster differences expected.
-
-</pre>
-<p>[base/gdevmem.h base/lib.mak base/gsroprun.c base/gdevm1.c base/gsropt.h base/gsroprun1.h base/gdevmr1.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-19T070113.923016Z"></a>
-2011-02-19T07:01:13.923016Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Add a missing check for null value during PDF resource enumeration.
-Bug 691892, customer 532.
-</pre>
-<p>[Resource/Init/pdf_main.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-18T132259.764503Z"></a>
-2011-02-18T13:22:59.764503Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Committing fix for Bug 689031 submitted by Shailesh Mistry under the
-bug bounty program. Tests out fine (1 minor difference, looks like a
-progression to me).
-
-See bug for full discussion, but basically this removes a few calls to
-path_position_valid in exchange for accessing the equivalent data kept
-locally.
-
-
-</pre>
-<p>[base/gxchar.c base/gzpath.h base/gxccache.c base/gspath1.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-18T115125.345393Z"></a>
-2011-02-18T11:51:25.345393Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Enhancement (pdfwrite) : performance improvement
-
-Bug #691946 &quot;Conversion to PDF becomes slower and slower&quot;
-
-There are many places where pdfwrite compares composite objects for equality. This can
-be a very slow process, depending on the nature of the object, and becomes progressively
-slower as more object are added to storage.
-
-Previously we had added a MD5 hash to the stream data of a cos_stream in order to
-improve the performance when checking fonts for equality, this change takes the whole
-process much further. We now store an MD5 'fingerprint' for each composite object,
-initially this is not computed and is marked as not valid.
-
-Whenever an equality test takes place we check to see if the composite object has an MD5
-hash calculated, and if it does, we compare the MD5 hashes. If it does not then we
-compute an MD5 hash, store it, and mark it as valid. Note that for cos_stream types
-we store *two* hashes, one for the dictionary and one for the stream data.
-
-If we alter the contents of a composite object then we mark its MD5 hash as invalid so
-that we recompute it on the next occurence. Technically there could be a problem if
-a composite object contains a composite object, and the descendant object is altered
-after the MD5 hash is calculated for the parent. However this should not occur given
-the way these structures are used (these are pdfwrite internal structures, *not* PS or
-PDF objects available to the interpreter).
-
-This very significantly improves performance on some files, the test file for bug
-#691946 takes 2642 seconds without this change (and DetectDuplicateImages true) while
-it takes 963 seconds after this change.
-
-Note that this change depends on revision 12169 and should ideally be used with
-revisions 12168 to 12171 inclusive.
-
-No other differences expected.
-</pre>
-<p>[base/gdevpdfo.c base/gdevpdfo.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-18T113756.561896Z"></a>
-2011-02-18T11:37:56.561896Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : images being scaled incorrectly
-
-Found while dealing with other problems. pdfwrite uses the image 'height' (rendered
-height) and number of lines of data to calculate a 'scale' which it then applies to
-the current Transformation Matrix in order to calculate an image matrix.
-
-However, when an image was detected as a duplicate, the scale factor was calculated
-from the first image's dimensions, and then applied to the CTM for the second matrix.
-
-This did not appear to cause problems for PostScript and PDF but causes serious bugs
-in a number of PCL files, and was clearly incorrect. We now save and restore the
-height and width when substituting images to prevent this problem
-
-</pre>
-<p>[base/gdevpdfj.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-18T113207.033929Z"></a>
-2011-02-18T11:32:07.033929Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-enhancement (pdfwrite) : Allow duplication image detection to be disabled
-
-pdfwrite tests every (non-inline) image against every other stored image to see if it is
-a duplicate, and if so does not embed the duplicate in the output but simply references
-the original.
-
-This can be slow for files with many images (each stored image must be checked when a
-new image is encountered) and may be of limited benefit.
-
-The new flag DetectDuplicateImages (default true) can be used to enable or disable
-this behaviour
-
-No differences expected
-</pre>
-<p>[base/gdevpdfj.c base/gdevpdfx.h base/gdevpdfp.c doc/Ps2pdf.htm base/gdevpdfb.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-18T112524.853829Z"></a>
-2011-02-18T11:25:24.853829Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Correction to an equality test
-
-This fixes a long-standing bug when checking the equality of patterns.
-
-We need to ensure when substituting patterns that neither of the patterns is already
-substituted. But the code only tested one of the patterns (and was a duplicate of
-another test), which led to incorrect results. This should always have been a problem
-but for some reason seems to have been masked in previous releases. New code for
-testing equality of composite objects revealed the problem.
-
-No differences expected, as the problem is only revealed with code which follows in a
-subsequent commit.
-</pre>
-<p>[base/gdevpdfi.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-18T111523.457563Z"></a>
-2011-02-18T11:15:23.457563Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix a typo in an enumerated type. No differences expected.
-</pre>
-<p>[base/gxhldevc.h base/gxhldevc.c base/gdevpdfg.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-15T163659.934186Z"></a>
-2011-02-15T16:36:59.934186Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Double the allowed space for cached chars and increase the maximum
-byte size of a single glyph that can be cached.
-</pre>
-<p>[base/gsfont.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-15T150755.282721Z"></a>
-2011-02-15T15:07:55.282721Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix for building the gs***w64.exe self extracting installer compatible with
-the new 64-bit binary naming and makefile macro (BUILD_SYSTEM)
-</pre>
-<p>[psi/winint.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-15T092128.927211Z"></a>
-2011-02-15T09:21:28.927211Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Ensure that the OpenPrinting drivers get removed from the drivers list
-if iconv/libiconv are not available.
-
-The strings used to identify the drivers in the list were incorrect.
-
-</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-14T203933.924424Z"></a>
-2011-02-14T20:39:33.924424Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix Bug 691917. In revision 11146 I made op_array_table_global and
-op_array_table_local be elements of the context rather than being
-globals, and changed all the code to access these elements through
-the context.
-
-Unfortunately I forgot to cope with when new contexts are generated by
-forking execution. The correct fix is, I believe to simply copy the
-op_table pointers over to the new context. This has been done here, and
-seems to solve the reported bug.
-
-No cluster differences expected.
-
-</pre>
-<p>[psi/zcontext.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-14T110439.509187Z"></a>
-2011-02-14T11:04:39.509187Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Removed a tab accidentally introduced in rev 12082.
-</pre>
-<p>[Resource/Init/cidfmap]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-10T171423.128533Z"></a>
-2011-02-10T17:14:23.128533Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Ensure that a --build option is propogated to the other
-configure scripts we call.
-
-</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-10T132158.493309Z"></a>
-2011-02-10T13:21:58.493309Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-fix error in revision 12140
-
-When fetching the size of the stream for a /Indexed colour space, omitted to check if the
-/Length of the stream was an indirect object. Now dereference the object if this is the
-case.
-
-Should fix the 14 files with errors introduced in 12140.
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-10T104326.255155Z"></a>
-2011-02-10T10:43:26.255155Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix : colour space handling bug and improved handling of broken ICC space
-
-Bug #691941 &quot;Interpretation of PDF aborts with /typecheck&quot;
-
-The PDF file in the specimen contains an invalid colour space of the form:
-
-/Indexed [/ICCBased &lt;&lt;/N 1 /Alternate [/Indexed /DeviceRGB 255 7 0 R]&gt;&gt;] 255 7 0 R]
-
-The number of components in the ICCBased specification is incorrect, as the profile has
-3 channels. This was not detected previously. Falling back to the /Alternate we see
-that we have a /Indexed space depending on a /Indexed space which is also invalid, but
-we choose to ignore this.
-
-There was also a bug in the colour space handling for ICCbased spaces which caused a
-typecheck if the alternate space was a /Indexed space.
-
-Finally, the PDF interpreter is updated so that when given a stream as the data source
-for a /Indexed space it reads and returns a string which is the greater of the declared
-size of the stream, or the calculated size required, given the number of components.
-Previously we always returned the calculated size, which was too little in this case
-as the number of components in the ICCBased space is incorrect.
-
-With these changes the (invalid) specimen file runs to completion.
-
-No differences expected.
-</pre>
-<p>[psi/zcolor.c psi/zicc.c Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-10T103323.506445Z"></a>
-2011-02-10T10:33:23.506445Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix Bug #691918
-
-Update the Unicode decodings applied to TrueType fonts to match the latest Adobe glyph
-list. Fixes some problems with incorrect mappings and adds numerous new mappings. A
-similar but less extensive change is made to the FCO_Unicode mappings as well.
-
-Thanks to SaGS for the work on this problem.
-
-No differences expected as these are only used for ToUnicode CMaps.</pre>
-<p>[Resource/Decoding/Unicode Resource/Decoding/FCO_Unicode]</p>
-</blockquote>
-<hr size=20>
-
-<h2><a name="Version9.01"></a>Version 9.01 (2011-02-07)</h2>
-
-<p>This is the second release in the stable 9.x series.
-
-<p> Highlights in this release include:
-
-<p> A new, robust CFF parser implemented in C (replacing the previous
-Poscript one),
-
-<p> tiffscaled device - this renders internally as tiffgray, but then
-downsamples by an integer scale factor (specified by -dDownScaleFactor=n)
-and error diffuses to 1bpp output. The tiffscaled device also implements
-limited minimum feature size functionality; by setting -dMinFeatureSize
-to 1, 2 or 3, the device output is guaranteed to generate minimum dot
-sizes as multiples of the final resolution, useful for devices that
-offer finer position control than dot size control.
-
-
-<p> Add DSC compatible output in ps2write.
-
-<p> Windows makefiles now support 64 bit builds on 64 bit systems.
-
-<p> A number of performance, memory use, and stability improvements with the new
-features introduced in 9.00, plus the usual bug fixes.
-
-<p> We have also dropped support for Watcom and Borland development environments.
-These had not been maintained for some time, and were suffering "bit rot".
-
-
-<p>For a list of open issues, or to report problems,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.01_Incompatible_changes"></a>Incompatible changes</h3>
-
-<p>
-No recorded incompatible changes.
-
-<h3><a name="9.01_Changelog"></a>Changelog</h3>
-
-<p><strong><a name="2011-02-07T141027.833602Z"></a>
-2011-02-07T14:10:27.833602Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Some updates to the details of the UFST and Freetype related
-information.
-
-Plus adding the warning about Xfonts pending removal.
-</pre>
-<p>[doc/Make.htm doc/Xfonts.htm]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-05T152932.296497Z"></a>
-2011-02-05T15:29:32.296497Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-As we plan to deprecate Xfonts in a future release, add a
-warning message to this effect when an Xfont is used, as follows:
-
-&quot;Warning: the Xfonts feature is deprecated and will be removed in a future release.&quot;
-
-No cluster differences expected.
-
-</pre>
-<p>[base/gxccman.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-05T152725.033646Z"></a>
-2011-02-05T15:27:25.033646Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Merge r12117 from the &quot;halftone&quot; branch into trunk, the original commit
-comment says:
-
-Fix bug in bit devices rgb mapping procedure; in the ncomp == 1 case it
-was only setting the first component. This was causing indeterminisms in
-calling code, which has been giving vastly different timings in Norberts
-tests.
-
-This has apparently been here since revision 3318.
-
-</pre>
-<p>[base/gdevbit.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-04T155142.379449Z"></a>
-2011-02-04T15:51:42.379449Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix problem with shifting in gsroprun.c. I had systematically got this
-wrong throughout the code, but fixed it everywhere except this one
-case in an earlier commit. This completes the fix.
-
-No cluster changes expected.
-
-</pre>
-<p>[base/gsroprun.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-03T123028.178697Z"></a>
-2011-02-03T12:30:28.178697Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-A final tweak to the FAPI/UFST code to keep C compilers
-less liberal than gcc happy (specifically Visual C).
-
-No functional changes.
-
-</pre>
-<p>[psi/fapiufst.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-02T182757.905008Z"></a>
-2011-02-02T18:27:57.905008Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-A couple of minor UFST related tweaks to account for differences between
-UFST 6.2 and UFST 5.x.
-
-</pre>
-<p>[psi/fapiufst.c base/gxfapiu.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-02T171809.939035Z"></a>
-2011-02-02T17:18:09.939035Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Change Windows makefiles extensively for 64-bit issues:
-1. Command line nmake works now for 32-bit build on 64-bit OS
-2. 64-bit builds use different directories for objects to allow 32 and
-64 bit builds to be alternated without confusion. 64-bit objects have
-'64' suffix to the 32-bit objects which remain in the same places
-3. 64-bit binaries are now named uniquely, e.g. gsdll64.dll and gswin64.exe
-Binaries coexist in 'bin' directory since names are unique.
-4. 'Style' changes to the makefiles to remove the '32' suffix from files
-that are not 32-bit specific -- hopefully will prevent future confusion.
-
-Tested with VS 2005 and VS 2008 as well as with GhostPDL.sln (to make sure
-the pcl, xps, and language_switch builds don't break.
-</pre>
-<p>[psi/msvc64.mak psi/gsdll64.def psi/dwsetup.cpp psi/msvc.mak psi/dwmain.c psi/dw64c.def psi/msvc32.mak psi/dwmain64.def psi/dwdll.c base/msvctail.mak psi/dwimg.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-02T153453.024741Z"></a>
-2011-02-02T15:34:53.024741Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Remove 4 cases where lines had apparently spurious leading spaces, this seriously
-confused nmake and refused to build on Windows.
-
-No cluster differences expected.
-</pre>
-<p>[psi/msvc32.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-02T151453.428205Z"></a>
-2011-02-02T15:14:53.428205Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (ps2write) : Enable ps2write on PCL
-
-Bug #691881 &quot;ps2write broken with GhostPCL&quot;
-
-ps2write formerly required 4 'resource' PostScript files stored on disk in order to
-write a PostScript header to the output file. These files have now been converted into
-'C' header files and included in the source in earlier revisions.
-
-This commit removes the last barrier to ps2write working with PCL (and other
-non-PostScript languages) by removing a disk-based check for opdfread.ps.
-
-No differences expected.
-</pre>
-<p>[base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-02T145537.673202Z"></a>
-2011-02-02T14:55:37.673202Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add cups files to VS project. This is a very simple, clean patch to the
-gs visual studio project file, so (famous last words) can't affect the
-cluster build and shouldn't conflict with anyone else.
-
-</pre>
-<p>[ghostscript.vcproj]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-02T141215.676565Z"></a>
-2011-02-02T14:12:15.676565Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-A set of changes to make it easier to use the UFST with Ghostscript
-and to get us closer to having the option of the UFST handling font
-types other than the Microtype fonts.
-
-The UFST build, using the default COMPILE_INITS=1 will now include
-the Microtype FCO files in the rom file system along with the other
-initialisation files (it does not currently strip out the normal
-Postscript fonts in Resource/Fonts), and setup default values for
-the various paramters required to have Ghostscript use the
-Microtype fonts (these can still be overridden on the command
-line). For the build with COMPILE_INITS=0, the default paths
-will use the path to the UFST you specify for configure, or
-nmake on Windows.
-
-
-Included in this revision are changes to prevent the UFST version
-5.x (or less) from trying to handle non-Microtype fonts, and allow
-it to safely fall back to the Freetype (or a.n.other FAPI plugin).
-UFST 6.2 or better will try to handle all fonts types, but this is
-not yet reliable.
-
-Currently, this code only replaces the UFST memory management on
-UFST 6.2 and above (this is purely because I haven't time to test
-this capability on UFST 5 yet).
-
-A further change will be committed shortly to the UFST 5 sources
-to force the UFST to use the Ghostscript stream IO instead of the
-standard lib file IO on the Windows builds (this has been in place
-for the Unix/Linux UFST builds for some time).
-
-
-
-</pre>
-<p>[psi/zfapi.c base/Makefile.in Resource/Init/gs_fntem.ps base/configure.ac psi/fapiufst.c base/gxfapiu.c psi/msvc32.mak Resource/Init/gs_fapi.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-02T133054.074131Z"></a>
-2011-02-02T13:30:54.074131Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-The ps2write dependency on the new header files was incorrect (over-enthusiastic
-copy and paste error)
-</pre>
-<p>[base/devs.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-02T112307.465859Z"></a>
-2011-02-02T11:23:07.465859Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Allow building with the system (shared) lcms library.
-
-Bug 691644.
-
-</pre>
-<p>[base/lib.mak base/Makefile.in base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-02T092815.868989Z"></a>
-2011-02-02T09:28:15.868989Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Remove the check on opdfread.ps from gs_pdfwr.ps as this is no longer shipped as a
-PostScript file in /gs/Resource</pre>
-<p>[Resource/Init/gs_pdfwr.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-02T084611.323868Z"></a>
-2011-02-02T08:46:11.323868Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Update two make files that had dependencies on opdfread.ps, which has been removed from
-the PostScript file system.</pre>
-<p>[psi/psromfs.mak base/unixinst.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-02T082743.587977Z"></a>
-2011-02-02T08:27:43.587977Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-It seems that three of the files removed in revision 12093 are used by devices other
-than ps2write. Replacing those files.
-</pre>
-<p>[Resource/Init/gs_mro_e.ps Resource/Init/gs_agl.ps Resource/Init/gs_mgl_e.ps lib/gs_mro_e.ps lib/gs_agl.ps lib/gs_mgl_e.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-02T081436.361918Z"></a>
-2011-02-02T08:14:36.361918Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix ps2write : Don't depend on the PS file system for resources.
-
-ps2write needs up to 4 resource files which are normally stored in the PostScript ROM
-file system. However on PCL and other languages these resources are (obviously) not
-present, so the output is incomplete.
-
-Move the relevant files from PostScript into 'C' as header files. Remove the files from
-the PostScript file system to save ROM file system space. Put the removed files into
-the gs/lib folder for safe-keeping. Add the .h files as dependencies for gdevpdfu.c in
-the build system so that changes to these files cause a rebuild.
-
-No differences expected.
-</pre>
-<p>[base/opdfread.h Resource/Init/gs_mro_e.ps Resource/Init/gs_agl.ps Resource/Init/gs_mgl_e.ps base/gs_mro_e.h lib/opdfread.ps base/gs_agl.h base/gs_mgl_e.h Resource/Init/opdfread.ps base/gdevpdfu.c lib/gs_mro_e.ps base/devs.mak lib/gs_agl.ps lib/gs_mgl_e.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-01T221144.446124Z"></a>
-2011-02-01T22:11:44.446124Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Fix for missing arch.h when compiling gdevcups.c with parallel make.
-</pre>
-<p>[base/devs.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-01T214627.115736Z"></a>
-2011-02-01T21:46:27.115736Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix for PDF 1.7 fts_09_0910.pdf where the /Font is in an ExtGState instead of
-set by the Tf operator. In this case, the font is an indirect reference, not
-a font resource name. Reported by customer 532.
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-01T170750.035956Z"></a>
-2011-02-01T17:07:50.035956Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Freetype expects the resolution we supply it to be in
-&quot;glyph orientation&quot; - not a problem until we have a
-non-square resolution, and rotated glyphs!
-
-Bug 691920.
-
-</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-01T140046.378487Z"></a>
-2011-02-01T14:00:46.378487Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Always write a ToUnicode CMap for TrueType fonts
-
-Bug #691907 &quot;PDFs with TrueType fonts from Windows PostScript files not searchable&quot;
-
-Patch from SaGS.
-
-When choosing whether to embed a ToUnicode CMap, always embed if the font type is
-TrueType. This is because TT fonts are always embedded as symbolic, and we now no longer
-add Encodings to Symbolic TT fonts (violates spec), which results in PDF files where the
-text is unsearchable and cannot be successfully copy/pasted in the absence of a
-ToUnicode CMap.
-
-It is possible that the ToUnicode CMap is incorrectly generated, but this is no worse
-than having no CMap at all.
-
-No expected differences since ToUnicode CMaps are not used in rendering.
-</pre>
-<p>[base/gdevpdtw.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-01T115726.132691Z"></a>
-2011-02-01T11:57:26.132691Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add new 'Profile' configuration to Visual Studio targets. This builds
-objects/binaries with debugging symbols enabled, but otherwise full
-optimisation.
-
-The changes are entirely within the VS files, except for a few small tweaks
-to the MSVC makefile. These changes should mean that it is possible to use
-the makefiles in a way that doesn't rely on recursive make calls (even though
-we leave the 'debug' targets in for now that do use that).
-
-No cluster differences expected or shown in testing.
-
-</pre>
-<p>[/trunk/ghostpdl/win32/xps.vcproj ghostscript.vcproj /trunk/ghostpdl/win32/GhostPDL.sln /trunk/ghostpdl/win32/pcl.vcproj /trunk/ghostpdl/win32/svg.vcproj psi/msvc32.mak /trunk/ghostpdl/win32/language_switch.vcproj]</p>
-</blockquote>
-
-<p><strong><a name="2011-02-01T083427.091701Z"></a>
-2011-02-01T08:34:27.091701Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : permit symbolic fonts in PDF/A output
-
-Bug #691877 &quot;Invalid text when converting to PDF/A&quot;
-
-TrueType fonts were being emitted as non-symbolic when PDF/A output was selected. This
-was causing the text to be incorrect, because the fonts actually are symbolic and
-Acrobat was unable to apply the correct decoding.
-
-This will result in more text being unsearchable/copyable but the rendering result is
-correct, which is more important.
-
-No differences expected, PDF/A output not tested on the cluster.</pre>
-<p>[base/gdevpdtd.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-31T181010.028647Z"></a>
-2011-01-31T18:10:10.028647Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-While searching for performance on an ARM based dev board, I developed 2
-new versions of the skip_white_pixels macro. The first uses native int sized
-checking, and should be faster on long run matching. I have as yet been unable
-to find any files that show this expected speedup.
-
-The second should be faster on architectures (such as ARM) where the tradeoff
-in the test is different (and where pointer arithmetic is cheaper than array
-indexing).
-
-Both versions are disabled by default until the case for their existence has
-been proven, but are committed here to avoid bitrot.
-
-No cluster differences expected, as the default code does not change.
-
-</pre>
-<p>[base/scf.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-31T123210.322306Z"></a>
-2011-01-31T12:32:10.322306Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Tweak to the PxM output code; spot that the output is /dev/null (or nul:)
-and avoid saving it. This is a port of code from gdevbit and gdevwts, and is
-purely useful for testing/timing/profiling purposes.
-
-No cluster differences expected.
-
-</pre>
-<p>[base/gdevpbm.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-31T111953.283257Z"></a>
-2011-01-31T11:19:53.283257Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Revert minor changes accidentally committed in revision 12082.
-</pre>
-<p>[Resource/Init/Fontmap.GS Resource/Init/cidfmap lib/PDFA_def.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-31T111505.175916Z"></a>
-2011-01-31T11:15:05.175916Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Add the two new make files required for the altered CUPS build, these were accidentally
-omitted in revision 12080.
-</pre>
-<p>[Resource/Init/Fontmap.GS base/lcups.mak Resource/Init/cidfmap lib/PDFA_def.ps base/lcupsi.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-31T110911.349638Z"></a>
-2011-01-31T11:09:11.349638Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Undo changes to PDFX_def.ps accidentally committed as part of the CPS changes.
-</pre>
-<p>[lib/PDFX_def.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-31T110611.139867Z"></a>
-2011-01-31T11:06:11.139867Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-More changes for CUPS, mostly to the build system.
-
-We now build the CUPS device unconditionally on Windows, using the recently added local
-partial copy of the CUPS library sources. This change also builds CUPS on Linux either
-using the system shared libraries (if available) or using the same partial copy of the
-library sources, if *specifically* directed to use this.
-
-On Windows CUPS is now always built and installed. On Unix systems the behavious is as
-follows:
-
-./configure cups not installed - no cups device
-./configure cups is installed - cups device linked to system cups shared libraries.
-./configure --disable-cups - no cups device, regardless of cups libs installed
-on system
-./configure --with-local-cups - cups device with the partial cups code, regardless of
-cups libs installed on system
-./configure --with-local-cups --disable-cups results in no cups device.
-
-No differences expected as the cluster should still build and run with the system
-CUPS libraries just as it always has.
-</pre>
-<p>[base/winlib.mak lib/PDFX_def.ps base/unix-end.mak base/gs.mak cups/cups.mak base/Makefile.in base/configure.ac cups/libs/configlinux.h psi/msvc32.mak base/msvclib.mak base/devs.mak base/msvctail.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-29T153532.332503Z"></a>
-2011-01-29T15:35:32.332503Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-More changes to the CUPS sources so they will compile on various systems:
-
-language.c - if __APPLE__ is true, includes code which uses what I think is Carbon
-Framework calls and structures, but does not #include any of the .h files.
-Modified to #undef __APPLE__ to avoid this.
-
-ppd.c - Same problem as for MSVC, the include file string.h seems to prevent the C
-string.h being included, and so leaves strchr undefined. Now unconditionally
-provide a prototype for strchr.
-
-localize.c - Another problem with string.h. This doesn't exist on the MSVC build, but
-unconditionally providing a prototype fro strcmp doesn't cause an error.
-
-The code now builds on MSVC, Linux and Mac. Lots of warnings, but I don't propose to
-try and deal with those as they would require extensive alterations to the CUPS
-sources.
-
-No differences expected as this code is not yet in use.
-</pre>
-<p>[cups/libs/cups/localize.c cups/libs/cups/language.c cups/libs/cups/ppd.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-28T132120.983748Z"></a>
-2011-01-28T13:21:20.983748Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Further rop run optimisations.
-
-* Add mechanism for dumping ROPs used (including frequency and runlength).
-Disabled by default.
-* Add special case code for most common rops (invert and xor).
-* Correct '1bit colors' code in various cases.
-
-Cluster pushing shows no differences.
-
-</pre>
-<p>[base/gsroprun.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-28T122737.269985Z"></a>
-2011-01-28T12:27:37.269985Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Optimisations to mem_mapped8_copy_mono. Driven initially by a desire to
-speed up 100pagemono.pxl on ARM devices, but useful on all architectures.
-This work may end up being subsumed by the run_rop work, but is a worthwhile
-stepping stone.
-
-On x86 this speeds 100pagemono.pxl in greyscale 600dpi from 4.2 seconds to
-3.6seconds. On ARM it shows a definite improvement too, but I don't have
-figures to hand.
-
-Clusterpush shows no changes.
-
-</pre>
-<p>[base/gdevm8.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-27T143346.308935Z"></a>
-2011-01-27T14:33:46.308935Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Update the CUPS sources so that they can be compiled under Windows.
-
-1) Remove config.h which was a Linux configure result, replace with configwin.h (from
-the CUPS distribution for Windows) and configlinux.h which is config,h renamed. We
-will copy and use the correct version at make time.
-
-2) cups/debug.c guard the use of pthread_mutex so that we don't try to use it if
-HAVE_PTHREAD_H is not defined, as the variable will not be declared. Guard use of
-cups_debug_filter and cups_filter with a #ifndef WIN32 as these variables are not
-defined in a Windows build. Replace gettimeofday with a Windows equivalent when
-building on Windows as this function is not available.
-
-3) ppd.c Add a definition of strchr when building for Windows. The use of an include
-file called string.h confuses MSVC and it does not include the C string.h which leaves
-strchr undefined.
-
-4) string.h When defining equivalents to strcasecmp and strncasecmp, also define the
-HAVE_* variables so that inclusion order doesn't lead to these being undefined when
-we have declared equivalents.
-
-5) image-bmp.c Guard the declaration of the BI_* constants with a #ifndef WIN32 as
-these are Windows constants and already defined on a Windows build.
-
-6) image-colorspace.c Define cbrt() in terms of pow() when WIN32 is set as the MSVC
-compiler does not define a cube root function.
-
-7) image-tiff.c Guard inclusion of unistd.h when HAVE_LIBTIFF is true as this include
-file does not ship with MSVC on Windows.
-
-
-These have been supplied to the CUPS development group, and at least some of the
-problems are likely resolved in a newer version of CUPS.
-
-No differences expected.
-</pre>
-<p>[cups/libs/cups/debug.c cups/libs/filter/image-bmp.c cups/libs/cups/string.h cups/libs/configwin.h cups/libs/config.h cups/libs/configlinux.h cups/libs/cups/ppd.c cups/libs/filter/image-tiff.c cups/libs/filter/image-colorspace.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-27T130715.912561Z"></a>
-2011-01-27T13:07:15.912561Z Tor Andersson</strong></p>
-<blockquote>
-<pre>
-Relax version check in JPEG-XR to allow older version HDP and WDP images.</pre>
-<p>[jpegxr/cr_parse.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-26T181028.996727Z"></a>
-2011-01-26T18:10:28.996727Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Fix the message for the new IJS check to read IJS, instead of jpeg!
-
-</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-26T145140.178552Z"></a>
-2011-01-26T14:51:40.178552Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-revert accidentally committed file.
-</pre>
-<p>[base/jpeg.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-26T122536.497890Z"></a>
-2011-01-26T12:25:36.497890Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Allow IJS code to be linked as a library instead of using our distributed source.
-
-This will permit distributions which include a separately built libijs to link the
-the system's libijs.
-
-Bug 691904
-
-</pre>
-<p>[base/winlib.mak base/gdevijs.c base/ijs.mak base/jpeg.mak base/ugcclib.mak base/macosx.mak base/Makefile.in base/configure.ac base/unix-gcc.mak base/unixansi.mak psi/msvc32.mak base/devs.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-26T010440.273776Z"></a>
-2011-01-26T01:04:40.273776Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Old gs assumed TrueType font collections occur only as external resource.
-It turned out that PDF can have embedded TrueType collection. So this patch
-replaces --setfileposition-- with {... () /SubFileDecode filter flushfile}
-for forward search. Bug 691908, customer 870.
-</pre>
-<p>[Resource/Init/gs_ttf.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-25T120322.384476Z"></a>
-2011-01-25T12:03:22.384476Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Add code to define cbrt, strcasecmp and stncasecmp when compiling for Windows, as these
-are not present in the MSVC run-time.
-
-Also alter the initialisation of the gs_cups_device structure. Previously this set three
-matrices by including empty braces '{}', but MSVC throws a compilation error on this.
-Altered to {0x00} which is not quite the same, but it compiles (with a warning from gcc)
-and is no worse than leaving the members uninitialised.
-
-No differences expected.
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-24T235139.084611Z"></a>
-2011-01-24T23:51:39.084611Z Tor Andersson</strong></p>
-<blockquote>
-<pre>
-Add JPEG-XR makefile and library to XPS build.</pre>
-<p>[/trunk/ghostpdl/xps/xps.mak /trunk/ghostpdl/xps/xps_msvc.mak base/jpegxr.mak /trunk/ghostpdl/xps/xps_gcc.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-24T235123.771340Z"></a>
-2011-01-24T23:51:23.771340Z Tor Andersson</strong></p>
-<blockquote>
-<pre>
-Import JPEG-XR reference software.
-
-ITU-T Rec. T.835 (ex T.JXR-5) | ISO/IEC 29199-5.
-JPEG XR reference software 1.8 (September 2009).</pre>
-<p>[jpegxr/jpegxr.h jpegxr/io.c jpegxr/jpegxr_pixelformat.c jpegxr/api.c jpegxr/my_getopt-1.5/getopt.h jpegxr/stdint_minimal.h jpegxr/r_strip.c jpegxr/qp.tab.c jpegxr/JPEG-XR.sln jpegxr/cw_emit.c jpegxr/w_strip.c jpegxr/x_strip.c jpegxr/qp.tab.h jpegxr/r_parse.c jpegxr/r_tile_spatial.c jpegxr/app_resource.h jpegxr/Makefile jpegxr/DLL.rc jpegxr/cr_parse.c jpegxr/APP.vcproj jpegxr/w_tile_frequency.c jpegxr/COPYRIGHT.txt jpegxr/jxr_priv.h jpegxr/my_getopt-1.5/LICENSE jpegxr/sample.qp jpegxr jpegxr/file.c jpegxr/my_getopt-1.5/my_getopt.c jpegxr/dllmain.c jpegxr/algo.c jpegxr/file.h jpegxr/my_getopt-1.5/my_getopt.h jpegxr/w_emit.c jpegxr/my_getopt-1.5 jpegxr/dll_resource.h jpegxr/qp_lexor.c jpegxr/README.txt jpegxr/flags.c jpegxr/DLL.vcproj jpegxr/versions-windows.txt jpegxr/jpegxr.c jpegxr/qp_lexor.lex jpegxr/r_tile_frequency.c jpegxr/qp_parse.y jpegxr/w_tile_spatial.c jpegxr/APP.rc jpegxr/init.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-24T181640.240500Z"></a>
-2011-01-24T18:16:40.240500Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-We want to be able to use planar buffers in a line interleaved format.
-Unfortunately, at the moment the planar device is hardcoded to use
-contiguous buffers. Fortunately this appears to be a 1 line fix; rather than
-calculting raster from the width, we instead calculate it as the difference
-between line pointers.
-
-This does assume that we can always safely read line_ptrs[1], even if we only
-have 1 line in the band. (The value is unimportant in this case, but we must
-be able to read it without crashing.)
-
-
-</pre>
-<p>[base/gdevmpla.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-24T145630.755196Z"></a>
-2011-01-24T14:56:30.755196Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Make sure the X11 drivers get removed from the DEVICE_DEVS declaration
-if the --enable-dynamic option is give to configure. Also, fix up the
-the non shared library builds, so they will still work with
---enable-dynamic (only really useful for debugging).
-
-Bug 691905.
-
-Reorganise and correct the names of the devices specified in
-configure.ac so that the options --with-drivers=[FILES,PRINTERS,X11]
-actually work.
-
-Finally, make the &quot;make debug&quot; compiler options originate from
-configure, instead of being hard coded into the Makefile. A first
-step in making some of useful debugging features of modern compilers
-available when we can.
-
-</pre>
-<p>[base/Makefile.in base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-20T042302.586888Z"></a>
-2011-01-20T04:23:02.586888Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Search for 'trailer' harder: at the end and at the beginning of the file.
-This helps to recover some more of broken linearized files.
-Bug 691894, customer 580.
-</pre>
-<p>[Resource/Init/pdf_rbld.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-19T202554.918598Z"></a>
-2011-01-19T20:25:54.918598Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Revision 12038 revealed a bug in the transparency code; an operation with
-a blend mode of 'Normal' and a solid alpha would be allowed to use the
-fast stroking code, even though it had transparency in due to being a pattern.
-
-Here we fix the code to check for transparency. As noted on bug 691900 this
-test treats all type 2 patterns as being transparent, so could be improved.
-
-The cluster differences this gives have been checked and correct the
-regressions of revision 12038.
-
-
-</pre>
-<p>[base/gdevp14.c base/gstrans.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-19T180059.394482Z"></a>
-2011-01-19T18:00:59.394482Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Bug 691897 shows a PDF that is much slower when transparency is enabled than
-when it is not. The time is primarily spent in the stroke filling code due
-to the fact that when transparency is enabled strokes need to be rendered
-all at once, rather than segment by segment. This causes the scan conversion
-code to have to work much harder.
-
-In fact, the code uses solid alpha and &quot;compatible&quot; blend mode for most
-strokes, so we would be perfectly safe to use the normal mechanism. The
-code attempts to recognise this case already, but was only spotting &quot;Normal&quot;
-blend mode and not it's synonym &quot;Compatible&quot;. We now roll the two together.
-
-Cluster testing shows this produces various differences; none to do with
-blending, all to do with different roundings in the positions of the stroked
-paths. Bug 690845 is open for this already.
-
-</pre>
-<p>[base/gdevp14.c base/gstrans.c base/gstparam.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-18T215256.712015Z"></a>
-2011-01-18T21:52:56.712015Z regression</strong></p>
-<blockquote>
-<pre>
-Temporarily add 75 dpi pgmraw output to GhostPCL and disable ps2write output to the cluster regressions.
-</pre>
-<p>[toolbin/localcluster/build.pl]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-18T102212.280482Z"></a>
-2011-01-18T10:22:12.280482Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Resolve some problems with the shared library build on Sparc/Solaris,
-with the SunStudio tools.
-
-Have configure select between the GNUism -soname and the more convetional
--h option to set the &quot;internal&quot; name of the shared library.
-
-SunStudio 12 has changed the default optimization level option for cc to
-be -O3 (previously was -02), which results in Ghostscript crashing.
-
-No cluster differences expected.
-
-Bug 689490
-
-</pre>
-<p>[base/macosx.mak base/Makefile.in base/configure.ac base/unix-dll.mak base/unix-gcc.mak base/macos-mcp.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-17T213708.425154Z"></a>
-2011-01-17T21:37:08.425154Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-I don't know any version of VC compiler that can compile embedded assembly
-code in Luratech JPEG 2000 library. (and other compilers are excluded on
-the preprocessor level). So the library is now always compiled with
-NO_ASSEMBLY flag. Perhaps, a new version of the library will be better.
-</pre>
-<p>[psi/msvc32.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-17T173350.118892Z"></a>
-2011-01-17T17:33:50.118892Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add code for using run_rops for 8 and 24 bit targets too. Cluster testing shows
-that this gives the same results, but limited local testing suggests the setup
-costs mean this isn't yet a win. Therefore leaving disabled for now.
-
-</pre>
-<p>[base/gdevmr8n.c base/gsroprun.c base/gsropt.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-17T121139.376205Z"></a>
-2011-01-17T12:11:39.376205Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove unused lop_ral definitions, and move pdf14 lop bit down into the freed
-space (for neatness).
-
-No changes expected in cluster.
-
-</pre>
-<p>[base/gsropt.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-16T012536.175335Z"></a>
-2011-01-16T01:25:36.175335Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Added missing std.h dependency to gstoptab.c to fix parallel make
-under linux.
-</pre>
-<p>[base/lib.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-15T160130.937666Z"></a>
-2011-01-15T16:01:30.937666Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-First commit of new scheme for rop acceleration; offer functions that do
-'runs' of rops rather than single rops. This enables us to hide optimised
-versions (or even dynamically created code) under a single interface.
-
-The current code is only used in 1bpp cases, but is already showing a
-signficant speed up, with lots of scope for future optimisations.
-
-No cluster differences shown.
-
-</pre>
-<p>[base/lib.mak base/gsroprun.c base/gsropt.h base/gdevmr1.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-15T155350.166886Z"></a>
-2011-01-15T15:53:50.166886Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix loooong standing bug in rop3_swap_S_T, in that it doesn't actually work.
-This shouldn't affect anything as it's not currently used, but WILL be used
-in my next commit.
-
-</pre>
-<p>[base/gsropt.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-14T185846.405071Z"></a>
-2011-01-14T18:58:46.405071Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Bracket off gs_debug_c with #ifdef DEBUG so it is not called in
-production builds.
-
-</pre>
-<p>[base/gxht.c base/gxclimag.c base/gxttfb.c base/gxpcmap.c base/gxccman.c base/gsfcmap1.c base/gspaint.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-14T165647.376046Z"></a>
-2011-01-14T16:56:47.376046Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Changes to the Unix configure based builds to tidy up specifying
-subsets of output devices.
-
-Some devices were always being included regardless of the options
-given to configure, resolved by tidying up the macro expansions
-in Makefile.in done by the configure script.
-
-Also the page device and clist device are effectively required by
-all configurations, so those are now included in the core build.
-
-Finally, the contrib/gomni.c driver relied on two functions in
-base/gdevbmpc.c which is an optional driver, so configuring
-the Omni driver to be built it, and bmp16 not would result
-in undefined symbols. contrib/gomni.c now has its own
-equivalents of those functions.
-
-The bbox device remains as the ultimate &quot;fallback&quot; device.
-
-Bug 689546
-
-</pre>
-<p>[base/lib.mak contrib/gomni.c base/Makefile.in base/configure.ac base/devs.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-13T161939.522851Z"></a>
-2011-01-13T16:19:39.522851Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Remove the bogus C++ requirement in the copy of Jasper we
-ship with Ghostscript by recreating the autotools related
-files for Jasper.
-
-I can't be sure, but it seems that a bug in one of the
-autotools originally used for our Jasper had a bug which
-resulted in C++ being misidentified as a required,
-rather than optional, feature of the build environment.
-
-Bug 691563.
-
-No cluster differences expected.
-
-
-
-</pre>
-<p>[jasper/src/libjasper/jpc/Makefile.in jasper/src/libjasper/bmp/Makefile.in jasper/configure.ac jasper/src/libjasper/jpg/Makefile.in jasper/src/appl/Makefile.in jasper/src/libjasper/include/Makefile.in jasper/src/libjasper/ras/Makefile.in jasper/src/Makefile.in jasper/aclocal.m4 jasper/src/libjasper/pnm/Makefile.in jasper/src/libjasper/jp2/Makefile.in jasper/configure jasper/src/msvc/Makefile.in jasper/src/libjasper/pgx/Makefile.in jasper/Makefile.in jasper/src/libjasper/Makefile.in jasper/src/libjasper/include/jasper/Makefile.in jasper/src/libjasper/base/Makefile.in jasper/src/libjasper/mif/Makefile.in]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-13T143733.986698Z"></a>
-2011-01-13T14:37:33.986698Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix Bug 689698 by prefixing scan_token (and other externally exported
-scanning related symbols) by gs_.
-
-No changes in cluster testing (other than 1 timeout, and 2 indeterminisms).
-
-
-</pre>
-<p>[psi/ztoken.c psi/ztype.c psi/imain.c psi/iscan.c psi/itoken.h psi/ziodev.c psi/interp.c psi/iscan.h psi/imainarg.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-12T211153.461044Z"></a>
-2011-01-12T21:11:53.461044Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix Bug 691682 - cryptic error messages when misspecifying compression type
-for tiff devices.
-
-This patch makes the tiff devices take heed of errors propogated up from the
-tiff library. This means we'll now drop out at the first error rather than
-carry on through and give a broken file at the end silently.
-
-Also, we output a more helpful error message in the case where the
-compression type is misselected.
-
-Cluster testing shows no changes.
-
-</pre>
-<p>[base/gdevtifs.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-11T213354.972732Z"></a>
-2011-01-11T21:33:54.972732Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for a number of issues found by Ray with the halftone creation tool.
-
-These include a crash for a divide by zero in the gcd function (caused failure
-at 0 degree screen generation)
-Fix so that the Holladay screen is no longer created as an output option.
-Fix in ppm output header.
-Fix in how the lpi is selected.
-Fix for when we have a screen that has essentially one dot (also caused a crash).
-Addition of a ReadMe.
-
-A lot more testing is needed, in particular, the dithering of the dots in the
-macro-screens needs additional testing and the relationship between the desired
-number of quantization levels and the size of the screen needs to be properly
-computed. There is a list of features that need to be added described in the ReadMe. </pre>
-<p>[toolbin/color/halftone/halfttoning/halfttoning.vcproj toolbin/color/halftone/README toolbin/color/halftone/halfttoning/halftone.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-11T011759.815496Z"></a>
-2011-01-11T01:17:59.815496Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Add output modes for PostScript HalftoneType 3 threshold arrays (-ps) and
-PPM files (-ppm) that have the width in the file rather than only encoded
-in the filename. The -ppm mode is untested and marginally useful.
-
-The -ps mode was tested (on Windoze) with:
-
-toolbin/color/halftone/Debug/halfttoning.exe -ps -r 300 -l 23 -a 45
-
-gswin32c -r300 -dDisplayFormat=16#20102 -c &quot;(Screen_Holladay_Shift10_20x10.ps) \
-run sethalftone (examples/tiger.eps) run&quot;
-
-The result doesn't look very good, but at least it runs and we can examine
-the problems.
-</pre>
-<p>[toolbin/color/halftone/halfttoning/halftone.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-11T004920.559732Z"></a>
-2011-01-11T00:49:20.559732Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Hopefully a fix for indeterminism introduced in rev 12005. The
-source of this was that the cups and psdcmyk device are now using
-the older slower color image rendering function due to the fact that
-they have non-standard color mapping procedures. Missing parenthesis
-were introduced when the ICC branch was merged into the trunk which was
-the source of the issue. This was causing a check for color range mask
-testing even when the image was not a type 4.</pre>
-<p>[base/gxicolor.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-10T220019.847574Z"></a>
-2011-01-10T22:00:19.847574Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Added the source code of the CUPS libraries to the Ghostscript source
-package
-
-Like with zlib, libpng, libjpeg, ... it is now possible to
-build the complete Ghostscript (including the CUPS Raster output
-device) on systems where there is no CUPS library available.
-
-Note that currently only the CUPS library source code is added, the
-results of the ./configure run in the Makedefs and config.h files, and
-the Makefiles are stripped to only build the libraries and nothing
-else. The CUPS ./configure command line which was used to obtain
-makedefs and config.h was
-
-./configure --enable-static --without-shared --disable-dbus --without-php \
---disable-slp --disable-gssapi --disable-ldap --disable-ssl \
---disable-cdsassl --disable-gnutls --disable-openssl --disable-pam \
---disable-dnssd --disable-launchd
-
-This way the built CUPS libraries do not need any system services or
-hardware interfaces of Linux. In addition to standard libraries they
-use only libz, libpng, libjpeg, and libtiff. These libraries
-Ghostscript needs anyway and copies of their source code also ship
-with Ghostscript.
-
-What is still missing is the integration into the build system of
-Ghostscript and also the operating-system-independent base/cups.mak
-file (like base/png.mak etc.).
-
-No changes expected in the built Ghostscript as the code is not yet
-integrated in the build system.
-
-</pre>
-<p>[cups/libs/cups/backend.c cups/libs/cups/testadmin.c cups/libs/filter/image-pix.c cups/libs/cups/testoptions.c cups/libs/cups/backend.h cups/libs/cups/http-private.h cups/libs/filter/image.c cups/libs/cups/testpwg.c cups/libs/filter/image-sun.c cups/libs/cups/ppd-private.h cups/libs/filter/image.h cups/libs/filter/error.c cups/libs/cups/Dependencies cups/libs/cups/ipp-private.h cups/libs/cups/md5passwd.c cups/libs/cups/notify.c cups/libs/cups/dir.c cups/libs/cups/testarray.c cups/libs/cups/file.c cups/libs/cups/testhttp.c cups/libs/filter/image-png.c cups/libs/filter/image-zoom.c cups/libs/cups/getdevices.c cups/libs/cups/transcode.c cups/libs/cups/dir.h cups/libs/cups/globals.c cups/libs/cups/testppd.c cups/libs/filter/image-tiff.c cups/libs/cups/file.h cups/libs/filter/image-pnm.c cups/libs/cups/transcode.h cups/libs/cups/testipp.c cups/libs/cups/globals.h cups/libs/filter cups/libs/filter/image-photocd.c cups/libs/cups/options.c cups/libs/cups/emit.c cups/libs/cups/localize.c cups/libs/cups/tempfile.c cups/libs cups/libs/cups/testcups.c cups/libs/cups/custom.c cups/libs/cups/pwg-media.c cups/libs/cups/util.c cups/libs/cups/array.c cups/libs/cups/pwg-ppd.c cups/libs/cups/testi18n.c cups/libs/cups/http.c cups/libs/filter/image-jpeg.c cups/libs/filter/Dependencies cups/libs/cups/array.h cups/libs/cups/http-addrlist.c cups/libs/cups/language.c cups/libs/cups/ppd.c cups/libs/cups/http.h cups/libs/cups/md5.c cups/libs/cups/debug.c cups/libs/cups/ipp.c cups/libs/cups/language.h cups/libs/cups/ppd.h cups/libs/cups/backchannel.c cups/libs/cups/http-support.c cups/libs/cups/mark.c cups/libs/cups/md5.h cups/libs/cups/snmp-private.h cups/libs/cups/debug.h cups/libs/cups/Makefile cups/libs/cups/ipp.h cups/libs/cups/dest.c cups/libs/config.h cups/libs/cups/auth.c cups/libs/cups/ipp-support.c cups/libs/filter/common.c cups/libs/cups/langprintf.c cups/libs/filter/image-sgilib.c cups/libs/cups/raster.h cups/libs/filter/common.h cups/libs/cups/attr.c cups/libs/filter/image-private.h cups/libs/cups/sidechannel.c cups/libs/cups/testsnmp.c cups/libs/cups/usersys.c cups/libs/cups cups/libs/cups/cups.h cups/libs/cups/sidechannel.h cups/libs/cups/i18n.h cups/libs/Makedefs cups/libs/cups/testconflicts.c cups/libs/filter/image-colorspace.c cups/libs/cups/adminutil.c cups/libs/cups/http-addr.c cups/libs/filter/interpret.c cups/libs/cups/request.c cups/libs/cups/versioning.h cups/libs/cups/md5-apple.h cups/libs/cups/adminutil.h cups/libs/cups/file-private.h cups/libs/cups/encode.c cups/libs/filter/image-gif.c cups/libs/cups/snprintf.c cups/libs/cups/string.c cups/libs/filter/Makefile cups/libs/cups/getputfile.c cups/libs/filter/image-bmp.c cups/libs/cups/pwg-private.h cups/libs/cups/pwg-file.c cups/libs/cups/string.h cups/libs/filter/raster.c cups/libs/cups/page.c cups/libs/cups/getifaddrs.c cups/libs/cups/snmp.c cups/libs/filter/image-sgi.c cups/libs/cups/testfile.c cups/libs/cups/testlang.c cups/libs/filter/image-sgi.h cups/libs/cups/conflicts.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-10T032952.464842Z"></a>
-2011-01-10T03:29:52.464842Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Add support for MSVC 10 to msvc32.mak .
-</pre>
-<p>[psi/msvc32.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-09T021919.656942Z"></a>
-2011-01-09T02:19:19.656942Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for color related warnings in bug 691459</pre>
-<p>[base/gxi12bit.c base/lib.mak base/gxiscale.c base/gsicc_manage.c base/gxcmap.h base/gxicolor.c base/gscspace.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-08T195651.307278Z"></a>
-2011-01-08T19:56:51.307278Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Don't discard encoding of a TrueType PDF font when it is not embedded.
-Ghyph indexes vary between font versions, and encoding-based mapping
-yelds better results in this case. Bug 691693.
-</pre>
-<p>[Resource/Init/pdf_font.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-08T194231.743686Z"></a>
-2011-01-08T19:42:31.743686Z regression</strong></p>
-<blockquote>
-<pre>
-Additional changes to support ps2write in the cluster (and nightly and weekly) regression.
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/readlog.pl toolbin/localcluster/build.pl toolbin/localcluster/run.pl toolbin/localcluster/compare.pl]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-08T175607.987718Z"></a>
-2011-01-08T17:56:07.987718Z regression</strong></p>
-<blockquote>
-<pre>
-Add ps2write testing to the cluster regression.
-</pre>
-<p>[toolbin/localcluster/build.pl]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-08T175526.179279Z"></a>
-2011-01-08T17:55:26.179279Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Fix the code that repairs missing or incorrect /Subtype attribute. Write
-a valid attribute (always /Type1) into the font resource. This helps to
-avoid confusion caused by an invalid value later on. Bug 691872.
-</pre>
-<p>[Resource/Init/pdf_font.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-08T105004.294111Z"></a>
-2011-01-08T10:50:04.294111Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Fixed typo.
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-08T104712.179146Z"></a>
-2011-01-08T10:47:12.179146Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-CUPS Raster device: Some clean-up.
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-08T103656.827100Z"></a>
-2011-01-08T10:36:56.827100Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-CUPS Raster: Another approach to fix both bug #691733 and #690435: Set _old
-values at the beginning of the cups_put_params() function.
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-07T233317.663910Z"></a>
-2011-01-07T23:33:17.663910Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-CUPS Raster output device: Use positive values (1) as dummy values to mark
-that the color depth has changed and therefore memory needs to get rallocated
-
-WEith this both bug #691733 and bug #690435 get fixed, but this is not
-necessarily he right and best solution.
-
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-07T140517.614099Z"></a>
-2011-01-07T14:05:17.614099Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Fixed search-and-replace error in &quot;cups&quot; output device, bug 691871.
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-07T044942.455234Z"></a>
-2011-01-07T04:49:42.455234Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix so that we do not do the ICC optimized flow for color images when our
-target device does not have standard color mapping procedures. This occurs
-for example, in the case for the CUPs device where the color mapping procedures
-map CMYK, RGB and Gray to the current CUPs device color space. For standard
-gray, RGB and CMYK devices these procedures are avoided as the CMM performs
-all the required mappings. This commit will show differences in the files for the
-cups device as well as the psdcmyk device, which also should be using the non-optimized
-flow due to the use of CMYK + spot colorants, which will not be managed correctly by
-the CMM in general. The differences int the psdcmyk files that do not have extra spot
-colorants are tiny. This should fix bug 691760.</pre>
-<p>[base/gxi12bit.c base/gdevp14.c base/lib.mak base/gxcmap.c base/gxiscale.c base/gdevnfwd.c base/gxcmap.h base/gxicolor.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-06T191856.657732Z"></a>
-2011-01-06T19:18:56.657732Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Fix a cut-ant-paste error in setting QuantTables for JPXEncode filter.
-Bug 691868.
-</pre>
-<p>[base/sdeparam.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-06T110852.017177Z"></a>
-2011-01-06T11:08:52.017177Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Minor enhancement to ps2write for DSC output, remove trailing EOF.
-
-Prevent ps2write emitting a trailing EOF (0x04) byte when producing DSC-compliant
-output. The emission of this byte was leading to warnings about the output containing
-binary.
-
-No differences expected.
-</pre>
-<p>[base/gdevpdf.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-05T173542.089947Z"></a>
-2011-01-05T17:35:42.089947Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Reverting of commit 11995</pre>
-<p>[base/gxipixel.c base/lib.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-05T160522.763938Z"></a>
-2011-01-05T16:05:22.763938Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-ps2write DSC enhancement. Alter the default setting of CompressPages and CompressFonts to
-true. Gives better conforming output at present (as well as smaller output)
-</pre>
-<p>[Resource/Init/gs_pdfwr.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-05T154341.972063Z"></a>
-2011-01-05T15:43:41.972063Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix three compiler warnings in revision 11997
-</pre>
-<p>[base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-05T152839.325806Z"></a>
-2011-01-05T15:28:39.325806Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Use the &quot;x11&quot; output device as default output device for an X-enabled
-Ghostscript, as &quot;x11alpha&quot; is too buggy
-
-The simple call &quot;gs &lt;file&gt;&quot; is a common call to check a PostScript
-file when debugging printing problems. Unfortunately, this call uses
-the &quot;x11alpha&quot; output device which has a lot of bugs, especially on
-complex input files. This makes easily a wrong impression of the input
-file then. Having a somewhat inferior screen output quality (no
-anti-aliasing) is no problem as the mentioned Ghostscript call is only
-used for debugging purposes.
-
-</pre>
-<p>[base/Makefile.in]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-05T141741.770782Z"></a>
-2011-01-05T14:17:41.770782Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-ps2write DSC enhancement. Belt and braces approach when emitting a serialised array/proc
-
-This code should break an (already serialised) array or procedure emission if the total
-length of the data to write exceeds 255 bytes. The data will be broken at name, array,
-string or procedure tokens (ie '/', '[', '(', '&lt;') or a space character. If none of
-these occurs in the preceding 255 bytes then we emit a line break anyway and carry on.
-
-I do not have any test cases which exercise this code path with a data size &gt; 255
-bytes, so I'm not certain that it works as expected.
-
-No differences expected as the regression test doesn't exercise ps2write.
-</pre>
-<p>[base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-04T185636.226711Z"></a>
-2011-01-04T18:56:36.226711Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Fix spelling errors in a German man page. Thanks to Peter Dyballa for
-the patch. Bug 691863.
-</pre>
-<p>[man/de/gsnd.1]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-04T181941.129921Z"></a>
-2011-01-04T18:19:41.129921Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix so that the presence of source black and white are properly detected
-with the ICC color management changes. This detection is useful for the
-optimization of certain ROPs. Previously black and white were detected
-from looking at the device color. This was a problem since the device
-black color is usually not pure for a CMYK printer with the ICC changes.
-This fix updates the detection function so that it looks at the source
-color and maps it to the default RGB color space where black and white
-are well defined.
-</pre>
-<p>[base/gxipixel.c base/lib.mak]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-04T163538.827232Z"></a>
-2011-01-04T16:35:38.827232Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-More DSC-compliant ps2write work.
-
-When emitting strings for ps2write, write them as hex strings instead of regular
-strings, if the ps2write output is to be DSC-compliant, break the hex strings every
-255 bytes or less. Prepend and append newlines to the hex string when emitting
-DSC-compliant PostScript to ensure that preceding or following data doesn't cause the
-line length to exceed 255 bytes.
-
-No differences expected as ps2write is not currently regression tested.
-</pre>
-<p>[base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-04T104832.930138Z"></a>
-2011-01-04T10:48:32.930138Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Write ToUnicode CMap files which Acrobat likes
-
-Bug #691862 (and also bug #691849) &quot;Unable to copy text from the converted PDF&quot;
-
-It seems the Adobe documentation lies (or more generously is inconsistent). The
-CMap tech note (5014) says that entries are not zero padded, so values less
-than 256 are emitted as single bytes, values 256-&gt;65535 are two bytes etc.
-However the ToUnicode CMap tech note (5411) says:
-
-&quot;Because a “ToUnicode” mapping file is used to covert from CIDs (which begin at
-decimal 0, which is expressed as 0x0000 in hexadecimal notation) to Unicode
-code points, the following “codespacerange” definition, without exception,
-shall always be used: 1 begincodespacerange &lt;0000&gt; &lt;FFFF&gt;endcodespacerange&quot;
-
-(This is somewhat restrictive, since CIDs can exceed 2 bytes, even though
-UTF-16 can't, I could forsee a need to map high CIDs to lower UTF-16 values)
-
-Finally, the PDF Reference (1.7) says:
-
-&quot;The CMap file must contain begincodespacerange and endcodespacerangeoperators
-that are consistent with the encoding that the font uses. In particular, for a
-simple font, the codespace must be one byte long.&quot;
-
-So the PDF Reference conflicts with the tech note which it references!
-
-In fact none of the above seems to be quite what Acrobat actually does.
-
-It seems that Acrobat does not care what size (in bytes) the codespacerange is,
-no matter what kind of font is present. However it *does* care what size the
-bfrange entries are. For simple fonts the bfrange entries must be single bytes,
-for CIDFonts the bfrange entries must be two bytes. Deviation in either case
-leads to files which Acrobat cannot process and either causes errors or
-incorrect text when copying and pasting.
-
-Changed the ToUnicode emission (mostly restoring revision 11170 which was removed in
-revision 11795 because of bug #691849) so that we emit single byte bfrange and
-codespacerange arguments for simple (non-CID) fonts, and emit double byte, padded with
-00 arguments to bfrange and codespacerange for CID fonts.
-
-No differences expected as this only affects text search/copy in Acrobat.
-</pre>
-<p>[base/gsfcmap.c base/gdevpdte.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-03T201958.048424Z"></a>
-2011-01-03T20:19:58.048424Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Don't bump the 'used' element of the chunk manager structure if the allocation
-of a chunk fails. Thanks to Norbert Janssen for noticing this. Bug 691720.
-</pre>
-<p>[base/gsmchunk.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-03T185800.432432Z"></a>
-2011-01-03T18:58:00.432432Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-The optimization in gdevdgbr to detect a device with a &quot;plain&quot; cmyk 1
-bit to rgb mapping was broken because the procedure
-cmyk_1bit_map_color_rgb() is obsolete. The hack here is to detect
-output formats compatible with gx_get_bits_copy_cmyk_1bit() which is
-significantly faster since it does not have to call the device color
-decode procedure. The device API should have a member that indicates
-the most frequently encountered pixel organizations.
-</pre>
-<p>[base/gdevdgbr.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-03T162021.454447Z"></a>
-2011-01-03T16:20:21.454447Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Decode image samples with single precision calculations only. This
-area of the code is performance sensitive and there is no need to
-convert to and from doubles. Also, &quot;image_set_gray&quot; is now inline but
-still not enabled.
-
-</pre>
-<p>[base/gximono.c base/gximage.h]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-03T143356.098558Z"></a>
-2011-01-03T14:33:56.098558Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix ps2write : Attach Encoding for symbolic TrueType fonts
-
-The recent change to not attach Encodings to Sy,bolic TrueType fonts, as per the PDF
-spec, meant that ps2write also wrote symbolic TT fonts without a /Encoding. This is not
-ideal, because opdfread.ps then attaches a default StandardEncoding to the font. This
-simply will not work correctly.
-
-After some experimentation with extracting (in PostScript) the POST table from the TT
-font, sense prevailed. This patch modifies the condition so that if we are producing
-output for ps2write we continue to attach a /Encoding. (in this case it doesn't
-matter whether we are producing DSC output, we always want the Encoding)
-
-No differences expected.
-</pre>
-<p>[base/gdevpdtt.c]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-03T062152.574265Z"></a>
-2011-01-03T06:21:52.574265Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Adjust pdfemptycount variable during .execgroup execution to reflect the
-actual stack count. Avoid errors in sc1/scn caused by wrong operand count.
-Bug 691624.
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2011-01-01T161749.255469Z"></a>
-2011-01-01T16:17:49.255469Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Change all &quot;/foo /bar load def&quot; into &quot;/foo {bar} bind 0 get def&quot;
-in PDF interpreter to ebable operator redefinition with -dDELAYBIND.
-Bug 691669, customer 850.
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-31T062359.391706Z"></a>
-2010-12-31T06:23:59.391706Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Trap errors that may happen during loading of embedded fonts and try
-to load the font by the name. Bug 691045.
-</pre>
-<p>[Resource/Init/pdf_font.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-30T190959.966731Z"></a>
-2010-12-30T19:09:59.966731Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Use -fPIC instead of -KPIC on SunOS for &quot;so&quot; target when compiler is gcc.
-Bug 690630, customer 200.
-</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-30T141142.974030Z"></a>
-2010-12-30T14:11:42.974030Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Clip excessive size of the radial gradient extensions to the fixed point
-range. To avoid trivial differences, try the old fixed point function first
-and use new floating point one only when the old function fails. Bug 691775.
-</pre>
-<p>[base/gspath.h base/gxshade1.c base/gspath.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-29T130145.722135Z"></a>
-2010-12-29T13:01:45.722135Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Ignore transparency group XObject without /Group attribute and issue a
-warning about it. Bug 691854.
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-28T031357.856572Z"></a>
-2010-12-28T03:13:57.856572Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Implement correct defaults for /FontMatrix attribute in composite CFF
-font following analysis by Ken and Masaki (see the comment). Bug 690724.
-</pre>
-<p>[psi/zfont2.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-27T233439.189121Z"></a>
-2010-12-27T23:34:39.189121Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Fix unterminated string used by &quot;%%CreationDate:&quot; comment in ps2write
-device. Partial fix for 691853.
-</pre>
-<p>[base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-24T110847.918403Z"></a>
-2010-12-24T11:08:47.918403Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Put a check in place to ensure that the UFST pre version 6
-does not attempt to handle anything other than its own
-Microtype fonts.
-
-This ensures that the UFST 5.x FAPI plugin can coexist
-safely with the Freetype FAPI plugin.
-
-
-</pre>
-<p>[psi/fapiufst.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-24T095039.994493Z"></a>
-2010-12-24T09:50:39.994493Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Where FAPI finds a TTF glyf description to pass into the target font
-library, fix the decision on the length of the offset to the glyph
-data. Previously, the condition was wrong, and always ended up reading
-2 bytes for the offset.
-
-Bug 691850
-
-
-No cluster differences expected.
-
-
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-24T002830.327488Z"></a>
-2010-12-24T00:28:30.327488Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Limit the use of -rdynamic flag to GCC on Linux. This flags is supported
-by GCC only if the platform has ELF executable format. Bug 691453.
-</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-23T143936.123969Z"></a>
-2010-12-23T14:39:36.123969Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-fix pdfwrite : Always write 2 bytes for ToUnicode CMap ranges
-
-Bug #691849 &quot;pdfwriter regression: pdf text element is broken&quot;
-
-revision 11170 modified CMap emission so that bfchar/bfrange entries less than 256 were
-emitted as a single byte, as specified in the CMAp specification. However ToUnicode
-CMaps don't follow the normal specification (I suspect this is a bug which has been
-pickled into the spec by Adobe), and require that values always have 2 bytes.
-
-reverted 11170 so that we write 2 byte ToUnicode CMap entries.
-
-No differences expected.</pre>
-<p>[base/gsfcmap.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-23T114120.825457Z"></a>
-2010-12-23T11:41:20.825457Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-ps2write enhancement
-
-Initialise the SetPageSize flag to true when ProduceDSC is set, so that page sizes are
-properly requested by the output PostScript file.
-
-No differences expected.
-</pre>
-<p>[base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-22T184813.456231Z"></a>
-2010-12-22T18:48:13.456231Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Initial commit of code for creating halftone screens. This code needs
-additional debugging, especially in the case of edge parameters. It
-will currently create threshold arrays based upon desired lpi, angle,
-quantization levels, and device resolution. The method is restricted
-to angles that are the arctangent of rational numbers. Every attempt is
-made to achieve the requested lpi by using the rational angle that achieves
-an lpi over the requested value. Since there is a trade off between lpi
-and quantization levels, the requested quantization levels are obtained
-through dithering of the dot cells within the supercell. Essentially, the
-dots within the supercell do not all take on the same values and can grow at
-different rates in a visually pleasing manner. There is still a bit of work
-to do still on this dithering as well as controlling the rate of growth for
-the dots.</pre>
-<p>[toolbin/color/halftone toolbin/color/halftone/halfttoning.sln toolbin/color/halftone/halfttoning/halfttoning.vcproj toolbin/color/halftone/halfttoning toolbin/color/halftone/halfttoning/halftone.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-22T161758.830786Z"></a>
-2010-12-22T16:17:58.830786Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Just remove a commented out line of code that should have been removed before commit.
-</pre>
-<p>[base/gdevpdfb.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-22T140556.481488Z"></a>
-2010-12-22T14:05:56.481488Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-More enhancement work for type 3 fonts with PCL
-
-Previously we set the horizontal advance argument to the d1 (setcachedevice) operator to
-0, and set the Widths entry to 0, for all type 3 bitmap fonts created by rendering the
-original font.
-
-This was required to prevent regression errors with the test suite when we altered the
-type 3 font accumulation so that it made more effort to preserve the input character
-code, in an attempt to improve searching.
-
-Revision 11969 fixes a problem with cached characters which was leading to the /Widths
-array containing garbage values. With that revision we can now properly set the 'd1'
-horizontal advance, and also set the /Widths array correctly.
-
-No expected differences
-</pre>
-<p>[base/gdevpdfb.c base/gdevpdti.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-22T135829.830017Z"></a>
-2010-12-22T13:58:29.830017Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix ps2write/pdfwrite : Up date the show enumerator with the cached character width
-
-When capturing a character bitmap on the first time it is rendered, pdfwrite and
-ps2write get the width of the glyph in the cache device. This is then used to update
-values in the show enumerator, and these values are used as the Widths entry for the
-glyph.
-
-When imaging an already cached character, however, the enumerator values are not updated
-which can lead to garbage (uninitialised data) being written as values in the /Widths
-array. This patch takes the value from the cached character 'wxy' and updates the show
-enumerator 'wxy' with it. This is then used as the value for the /Widths array.
-
-Bug #691836, zweiseit01d4-1.pdf, limitcheck --nostringval--
-
-No differences expected.
-</pre>
-<p>[base/gxccache.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-22T003556.638864Z"></a>
-2010-12-22T00:35:56.638864Z regression</strong></p>
-<blockquote>
-<pre>
-Fixed bug with r11967 that redirected output to the wrong directory on the
-cluster nodes.
-</pre>
-<p>[toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-21T230747.064606Z"></a>
-2010-12-21T23:07:47.064606Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Attempt to remove obj directories before build and report failure.
-This detects the situation where a user manually built on one of
-the cluster nodes, leaving an obj directory that can't be overwritten
-by the cluster software.
-</pre>
-<p>[toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-21T230104.915150Z"></a>
-2010-12-21T23:01:04.915150Z regression</strong></p>
-<blockquote>
-<pre>
-Merge run.pl and build.pl with nightly regression versions.
-</pre>
-<p>[toolbin/localcluster/clustermonitor.pl toolbin/localcluster/build.pl toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-21T175345.618494Z"></a>
-2010-12-21T17:53:45.618494Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Revise how we set the font types which FAPI should handle, and
-ensure that the &quot;dummy&quot; CharStrings dict we set up for Microtype
-fonts doesn't get replaced.
-
-Bug 691810
-
-No cluster differences expected.
-
-</pre>
-<p>[Resource/Init/gs_fntem.ps Resource/Init/gs_fapi.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-21T104401.003179Z"></a>
-2010-12-21T10:44:01.003179Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Handle Charstrings being replaced by a procedure. This can happen
-even with Microtype fonts (which &quot;pretend&quot; to be Type 1, but don't
-actually use CharStrings).
-
-This commit also includes some UFST 6.x related changes, the complete
-UFST 6.x integration should follow in the not too distant future.
-
-Bug 691834
-
-Not cluster differences.
-
-
-</pre>
-<p>[psi/fapiufst.c base/gxfapiu.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-20T163854.977548Z"></a>
-2010-12-20T16:38:54.977548Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-When we're handling a Type42 font in FAPI, handle the possibility that
-the &quot;CharString&quot; we get might be a null object, by falling back to
-the notdef glyph.
-
-Bug 691848
-
-
-No cluster differences expected.
-
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-18T192714.937495Z"></a>
-2010-12-18T19:27:14.937495Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Implement correct bit packing for an indexed image with 4 bit/pixel color
-depth in the interface to Luratech JPX library. Bug 691843, customer 532.
-</pre>
-<p>[base/sjpx_luratech.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-18T152443.064303Z"></a>
-2010-12-18T15:24:43.064303Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Bug #691835
-
-Temporary work-around. It is possible to get into gsicc_init_device_profile with the
-graphics state pointer (pgs) being NULL. This happens if ps2write or pdfwrite convert
-a masked image into a regular image.
-
-Because pgs is dereferenced without checking for NULL, this causes a crash.
-
-Its not immediately clear to me if I need to modify ps2write/pdfwrite so that this
-condition doesn't occur, but for now, if pgs is NULL we return from the routine in order
-to prevent a crash.
-
-No differences expected
-</pre>
-<p>[base/gsicc_manage.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-17T165835.097740Z"></a>
-2010-12-17T16:58:35.097740Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Install the CJK examples.
-</pre>
-<p>[base/unixinst.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-17T165651.880152Z"></a>
-2010-12-17T16:56:51.880152Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Mention &quot;ps2pdf14&quot; in the man page for ps2pdf.
-</pre>
-<p>[man/ps2pdf.1 man/de/ps2pdf.1]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-17T165453.331106Z"></a>
-2010-12-17T16:54:53.331106Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Let Ghostscript work with the libjasper provided by the system.
-</pre>
-<p>[base/sjpx.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-17T165049.932561Z"></a>
-2010-12-17T16:50:49.932561Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-pphs is a script and not a library, put it into the correct group of files in the Makefile.
-</pre>
-<p>[base/unixinst.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-17T164802.245525Z"></a>
-2010-12-17T16:48:02.245525Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Fix stone-old security advisory CVE-2009-4270.
-</pre>
-<p>[base/gsmisc.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-17T164302.736497Z"></a>
-2010-12-17T16:43:02.736497Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Build gsx and gsc executables correctly as executables and not as shared libraries.
-</pre>
-<p>[base/unix-dll.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-17T001641.356524Z"></a>
-2010-12-17T00:16:41.356524Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Removed patch noise file.
-</pre>
-<p>[contrib/pcl3/eprn/eprnrend.c.orig]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-16T170024.131587Z"></a>
-2010-12-16T17:00:24.131587Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Don't clamp rectfill to the page.
-
-Bug #691839 &quot;Invalid EPS conversion with -dEPSCrop&quot;
-
-Rectangular fills (and only the special case of rectangles) were being clamped to the
-width/height of the device when emitted. This can cause problems when a matrix is in
-force which reduces the actual co-ordinates, in this case a Pattern with a 0.25 scaling.
-
-The clamping caused co-ordinates to be reduced, and part of the fill went missing.
-
-The comment indicated this was to 'work-around' the limit in Acrobat of 32k on user
-co-ordinates, but this is too sever a clamp to apply, also the general case path code
-does not apply this limit. Altered to make the limit the 32k enforced by Acrobat.
-
-</pre>
-<p>[base/gdevpdfd.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-15T161254.275384Z"></a>
-2010-12-15T16:12:54.275384Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-pdfwrite enhancement : Final DSC changes
-
-Fix a compiler warning, make ProduceDSC=true the default condition so that we create
-DSC-compliant PostScript unless told otherwise.
-
-Update the documentation for pswrite and ps2write in devices.htm and Ps2ps2.htm. Note
-that pswrite is now deprecated.
-
-Modify the pdf2ps and ps2ps scripts to use ps2write instead of pswrite.
-
-No differences expected.
-</pre>
-<p>[lib/pdf2ps doc/Ps2ps2.htm lib/pdf2ps.cmd lib/pdf2ps.bat lib/ps2ps doc/Devices.htm base/gdevpdfu.c lib/ps2ps.cmd base/gdevpdfb.h lib/ps2ps.bat]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-15T082258.985898Z"></a>
-2010-12-15T08:22:58.985898Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-pdfwrite enhancement : more DSC related activity
-
-Defer the output of the header and the opdfread.ps 'prcoset' until the output file is
-closed. This allows us to count the pages and emit the %%Pages: comment in the header
-instead of at the end of the file.
-
-Fix the PageBoundingBox comment to have two % characters instead of one.
-
-Check for a new flag 'DSC_OPDFREAD' at the start of opdfread.ps (and write its
-definition as part of the header emission in ps2write). If present this prevents the
-SetupPageView routine from using setmatrix to reset the CTM to the one saved during
-document setup. Because the DSC-compliant output puts save/restore around each page
-we don't need to reset the matrix, and the reset prevents the output from working
-properly with psnup. If the flag is not present, it is treated as false.
-
-The output now works with GSView, psselect and psnup. The only remaining work is to
-track the usage of ProcessDSC and see if we can reuse any of the comments parsed out
-of the input.
-
-No differences expected
-</pre>
-<p>[base/gdevpdfx.h base/gdevpdf.c Resource/Init/opdfread.ps base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-13T115736.965203Z"></a>
-2010-12-13T11:57:36.965203Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-pdfwrite enhancement : DSC output
-
-Add some more comments, and re-arrange a few to make better sense. Initial tests
-indicate the output of the code with ProduceDSC does not introduce any new errors.
-
-Still to do: See if we can re-order the output so that we can write the %%Pages: comment
-in the header with the correct number of pages. This requires us to defer writing the
-header and ProceSet until the end of the job.
-
-No differences expected.
-</pre>
-<p>[base/gdevpdfg.h base/gdevpdf.c base/gdevpdfe.c base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-12T161859.870768Z"></a>
-2010-12-12T16:18:59.870768Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Make const_90_degrees an external variable to stop smart optimizers from
-converting angle/const_90_degrees to angle*(1/const_90_degrees). Bug 689794.
-</pre>
-<p>[base/gsmisc.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-11T230225.039826Z"></a>
-2010-12-11T23:02:25.039826Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Don't break ANSI aliasing rules. Use memcpy() to assign Ghostscript classes
-i.e. structures of different type. Fix SEGV on GCC 4.5.1, release build.
-Thanks to ubitux@gmail.com for analysis of the problem. Bug 691831.
-</pre>
-<p>[base/gximag3x.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-10T195053.800825Z"></a>
-2010-12-10T19:50:53.800825Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Removal of Smask_is_CIE flag in the code as well as removal of code that
-is no longer used in the soft mask rendering.</pre>
-<p>[base/gdevp14.c base/gdevp14.h base/gstrans.c base/gstparam.h base/gxblend.c base/gstrans.h base/gxblend.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-10T132611.089772Z"></a>
-2010-12-10T13:26:11.089772Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-pdfwrite enhancement : More work towards DSC compliance
-
-This is a resubmission of revision 11941, with some additional changes so that it
-doesn't crash with pdfwrite on Linux systems.
-
-We now pass around the 'type' of an object much more when writing. This is so that
-we can emit &quot;%%BeginResource/%%EndResource&quot; comment pairs around the resources we write.
-It is also required so that we *don't* write these comments around pages.
-
-The code now emits %%BeginProlog, then writes the opdfread.ps procedure. It then writes
-all the various resources used in the document, each with a reasonable DSC comment. Then
-it writes %%EndProlog. After this come the page descriptions, each is written with a
-%%Page: comment and a %%PageTrailer. Finally we write the %%Trailer, %%Pages
-comment (NB we write %%Pages: (atend) in the header comments as we don't know how many
-pages there will be until the end) and %%EOF.
-
-The resources are mostly defined as being of type 'file', as most of them are not normal
-PostScript resources. The DSC specification says under the %%BeginResource definition
-(file note on p72) &quot;The enclosed segment is a fragment of PostScript language code or
-some other item that does not fall within the other resource categories&quot; and so this
-seems the best type to use for our purposes.
-
-The output is now minimally DSC compliant, though there are a few other comments I'd
-like to add if possible. Given the way the file is created we are always going to have a
-large prolog, and that will need to be copied to all the pages if they are split
-individually, in order to make sure that all the required resources are present.
-
-Technically we could follow the resource chain and write %%IncludeResource comments,
-at the page level at least, but this is probably more effort than it is realistically
-worth.
-
-Still need to add some more DSC comment types, and run some extensive testing.
-
-No differences expected currently. Minimal testing with GSView suggests that the output
-so far is DSC-compliant as-is.
-</pre>
-<p>[base/gdevpdfk.c base/gdevpdfm.c base/gdevpdfx.h base/gdevpdfo.c base/gdevpdf.c base/gdevpdfb.c base/gdevpdtd.c base/gdevpdfc.c base/gdevpdfo.h base/gdevpdfe.c base/gdevpdfu.c base/gdevpdtw.c base/gdevpdfg.c base/gdevpdti.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-10T030640.558274Z"></a>
-2010-12-10T03:06:40.558274Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Apply proper alpha blending to compute luminosity of mask per the PDF
-specification. Fixes bug 691822</pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-09T165055.001506Z"></a>
-2010-12-09T16:50:55.001506Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-undo revision 11941 and 11942 as this causes seg faults on Linux.
-</pre>
-<p>[base/gdevpdfk.c base/gdevpdfm.c base/gdevpdfx.h base/gdevpdfo.c base/gdevpdf.c base/gdevpdfb.c base/gdevpdtd.c base/gdevpdfc.c base/gdevpdfo.h base/gdevpdfe.c base/gdevpdfu.c base/gdevpdtw.c base/gdevpdfg.c base/gdevpdti.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-09T153910.142451Z"></a>
-2010-12-09T15:39:10.142451Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-A change to how we get the advance width of the glyph from Freetype.
-
-Previously, we used the data in the glyph metrics structure, which
-are scaled, and the undid the scaling. This is correct method for
-everything except the horizontal and vertical advance distances.
-
-We now get the two advance distances from the glyph structure,
-and tell Freetype not to scale them, this avoids the rounding
-errors that occur due to Freetype's fixed point number
-format. It also saves the (less significant) error when we
-previously unscaled the value, and saves a couple of
-fairly large double precision calculations.
-
-This does cause a number of changes in the regression suite,
-the vast majority are pixel or so differences in glyph
-positions. A very few are improvements.
-
-Bugs 691778 and 691777
-
-</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-09T143526.421173Z"></a>
-2010-12-09T14:35:26.421173Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-fix pdfwrite
-
-Revision 11941 had a typo in gdevpdf.c which spelled %%EndProlog with too many %
-characters.
-</pre>
-<p>[base/gdevpdf.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-09T142046.589285Z"></a>
-2010-12-09T14:20:46.589285Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-pdfwrite enhancement : More work towards DSC compliance
-
-We now pass around the 'type' of an object much more when writing. This is so that
-we can emit &quot;%%BeginResource/%%EndResource&quot; comment pairs around the resources we write.
-It is also required so that we *don't* write these comments around pages.
-
-The code now emits %%BeginProlog, then writes the opdfread.ps procedure. It then writes
-all the various resources used in the document, each with a reasonable DSC comment. Then
-it writes %%EndProlog. After this come the page descriptions, each is written with a
-%%Page: comment and a %%PageTrailer. Finally we write the %%Trailer, %%Pages
-comment (NB we write %%Pages: (atend) in the header comments as we don't know how many
-pages there will be until the end) and %%EOF.
-
-The resources are mostly defined as being of type 'file', as most of them are not normal
-PostScript resources. The DSC specification says under the %%BeginResource definition
-(file note on p72) &quot;The enclosed segment is a fragment of PostScript language code or
-some other item that does not fall within the other resource categories&quot; and so this
-seems the best type to use for our purposes.
-
-The output is now minimally DSC compliant, though there are a few other comments I'd
-lie to add if possible. Given the way the file is created we are always going to have a
-large prolog, and that will need to be copied to all the pages if they are split
-individually, in order to make sure that all the required resources are present.
-
-Technically we could follow the resource chain and write %%IncludeResource comments,
-at the page level at least, but this is probably more effort than it is realistically
-worth.
-
-Still need to add some more comments, and run some extensive testing.
-
-No differences expected currently. Minimal testing with GSView suggests that the output
-so far is DSC-compliant as-is.
-
-</pre>
-<p>[base/gdevpdfk.c base/gdevpdfm.c base/gdevpdfx.h base/gdevpdfo.c base/gdevpdf.c base/gdevpdfb.c base/gdevpdtd.c base/gdevpdfc.c base/gdevpdfo.h base/gdevpdfe.c base/gdevpdfu.c base/gdevpdtw.c base/gdevpdfg.c base/gdevpdti.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-07T141420.090005Z"></a>
-2010-12-07T14:14:20.090005Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-pdfwrite enhancement : more work towards DSC compliant ps2write output
-
-This should now output pages in the correct order, with %%Page:/%%PageTrailer
-comments.
-Still need to address Resource comments and definitions.
-
-Committed so that a user can try out the code. No differences expected.
-</pre>
-<p>[base/gdevpdf.c base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-06T203042.463413Z"></a>
-2010-12-06T20:30:42.463413Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for bug 691466. Problem was caused by the DeviceN alternate color
-space being Lab and the color values not being properly decoded to enable
-use of the lab ICC profile. A few progressions in the cluster data base
-with this commit.</pre>
-<p>[base/gscdevn.c base/gdevp14.c base/gsicc.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-06T163946.324844Z"></a>
-2010-12-06T16:39:46.324844Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Bring JPX Luratech decoder up to the level of Jasper decoder.
-1. Don't expand indexed colors when the PDF expects an indexed color space.
-Fix rendering of the sample file attached to the bug.
-2. Recognize indexed CMYK color space and accept the palettes that are shorter
-than 256 colors. Fix comparefiles/Bug689362.pdf
-3. Fix memory corruption that happened with 4-bit-per-pixel grayscale image
-and pack the nibbles by PS rules. Fix comparefiles/Bug690174.pdf
-
-Luratech now renders every file in our test suite correctly. We don't have
-tests for low values of bits per plane. Bug 691816, customer 532.
-</pre>
-<p>[base/sjpx_luratech.c base/sjpx_luratech.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-06T160730.222320Z"></a>
-2010-12-06T16:07:30.222320Z regression</strong></p>
-<blockquote>
-<pre>
-Limit clusterpush.pl bmpcmp jobs to 10 megs of changes per file in addition
-to the 100 changes per file limit.
-</pre>
-<p>[toolbin/localcluster/checkSize.pl toolbin/localcluster/clustermonitor.pl toolbin/localcluster/clustermaster.pl toolbin/localcluster/build.pl toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-04T211237.349224Z"></a>
-2010-12-04T21:12:37.349224Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for bug 691724. The issue was due to a bug in the code that creates
-equivalent ICC profiles from CIEABC types. This has a pile of progressions
-in the cluster data base. I stepped through them with bmpcmp and they
-appeared to be correct to me. I also altered the DefaultRGB PS color space
-to by in-sync with the D50 ICC sRGB based default that we are currently using. </pre>
-<p>[base/gsicc_create.c Resource/ColorSpace/DefaultRGB]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-04T120200.835522Z"></a>
-2010-12-04T12:02:00.835522Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Remove some extraneous debugging code and variables left in accidentally with the commit
-for revision 11932.
-</pre>
-<p>[base/gxfcopy.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-04T115313.468703Z"></a>
-2010-12-04T11:53:13.468703Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Hashing /Subrs didn't check all subrs.
-
-Bug #691815 &quot;ps2pdf fails on attached ps file&quot;
-
-The new code for hashing /Subrs, to improve font checking performance, stopped comparing
-/Subrs between two fonts as soon as either font had an error getting a specific /Subr.
-
-However it transpires that some fonts can have a null object for a /Subr (used to skip
-Subrs that do nothing), and this returns a typecheck error. This led to two fonts which
-differed only in the fact that one has (and uses) more Subrs than the other being
-perceived as identical. This could lead to pdfwrite using the wrong font when
-converting type 1 into CFF fonts and cause errors.
-
-The code now continues checking remainign /Subrs if a typecheck error occurs, and as an
-additional measure also checks the number of /Subrs in each font before deciding if
-they are compatible.
-
-</pre>
-<p>[base/gxfont1.h base/gxfcopy.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-03T092028.129989Z"></a>
-2010-12-03T09:20:28.129989Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Work around Acrobat bug with /Encoding
-
-Bug #691809 &quot;Regression: some PDF files produced by GhostPCL r11913 cannot be read by
-Acrobat 8.2.5&quot;
-
-Acrobat 4 &amp; 8 have a peculiar bug, if a type 3 font (may affect other font types, but
-it seems unlikely) has a WinAnsiEncoding, and no /Differences, then text set in that
-font is not displayed by these versions of Acrobat. This may be limited to glyphs
-which consist of a bitmap only.
-
-Forcing the emission of a /Differences array for each glyph used results in these
-versions of Acrobat displaying correctly (even though the 'differences' are in fact the
-standard Encodings).
-
-This does seem to be quite definitely an Acrobat bug which we are working around, no
-other PDF consumer seems to have a problem with these files.
-
-</pre>
-<p>[base/gdevpdti.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-02T181653.794801Z"></a>
-2010-12-02T18:16:53.794801Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Remove unused variable.</pre>
-<p>[base/gxblend.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-02T170945.886919Z"></a>
-2010-12-02T17:09:45.886919Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for bug 691803. This provides a fix for cases where we have soft masks
-embedded within other soft masks. Such rare cases are detected and when they
-occur and the soft mask type is luminosity, the alpha channel of the soft
-mask buffer is pre-blended with the luminosity data to give the proper mask
-values. There appears to a be change in fts_33xx.xps from this commit.
-However, it appears to me that this file was not being rendered properly,
-compared to the windows xps viewer, prior to the commit either. I will file
-a bug related to this issue.</pre>
-<p>[base/gdevp14.c base/gdevp14.h base/gxblend.c base/gxblend.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-02T095828.497029Z"></a>
-2010-12-02T09:58:28.497029Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-minor bug, warning message point to incorrect source directory.
-
-Bug #691811 &quot;incorrect error message&quot;
-
-Simply alter the source path in a warning.
-
-No differences expected.
-</pre>
-<p>[psi/imain.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-01T164120.443841Z"></a>
-2010-12-01T16:41:20.443841Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Additional debug code to help in soft mask problems.</pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-12-01T051655.267986Z"></a>
-2010-12-01T05:16:55.267986Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix so that the blend compositor actions are only removed from the clist
-compositor queue if they are completely over-ridden by a subsequent compositor
-action. Previously no check was made to see that the same settings were being
-up-dated by the new action.
-
-This fixes two P1 customer bugs and has several progressions in the test suite
-but one file Bug691783.pdf has both regressions and progressions. I will get
-the page 18 regressions into a bug.</pre>
-<p>[base/gdevp14.c base/gxclimag.c base/gxcldev.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-29T211232.441057Z"></a>
-2010-11-29T21:12:32.441057Z regression</strong></p>
-<blockquote>
-<pre>
-Additonal improvement in the cluster's ability to be able to recover from
-machines going down late in the run. Machines are put into a standby state
-when there are no jobs left to send and they have processed all of their jobs
-until all machines are in the standby state, then all the machines are released
-from standby and can upload their logs
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-29T185503.883221Z"></a>
-2010-11-29T18:55:03.883221Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for issues with the default ICC directory. The PS interpreter now checks
-if the default name is OK before setting to LIBPATH/iccprofiles . Also, the
-current name is first tested before we prepend with the directory name, to avoid
-doing double applications of the profile directory. Thanks to Ray for the fixes
-in gs_lev2.ps</pre>
-<p>[base/gsicc_manage.c Resource/Init/gs_lev2.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-29T183038.060525Z"></a>
-2010-11-29T18:30:38.060525Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for bug 691748. The idle optimizations for the softmask are not
-really valid since we have since created the proper bounding box for
-the soft mask in a previous commit. In the cluster push testing, some
-files came back as having problems with the psdcmyk device. Checking,
-it appears that these issues are not related to this fix but are another
-bug. I am working on this now and will submit a bug.</pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-29T144517.958276Z"></a>
-2010-11-29T14:45:17.958276Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Due to &quot;lazy evaluation&quot; of softmask groups, the graphics state can change between
-the creation of the softmask group form, and when it is executed.
-
-We'll now save the gstate and (most of) the ExtGState when the softmask group is
-defined, and then set both before evaluting the object. A few ExtGState entries
-are not easily set directly, so those are missing.
-
-This partially fixes Bug 691157, and fixes Bugs 690351, 691348 and 690535. It
-also resolves the remaining issue with 690535.
-
-Cluster differences as follows:
-Bug690535.pdf (noted above)
-Bug690022.pdf, Bug690115.pdf, Bug690208.pdf, fts_26_2601.pdf and
-fts_26_2603.pdf are all improved when compared to Acrobat.
-
-A few xps-&gt;pdf conversions thru pdfwrite render differently, but they were
-wrong before, and slightly differently wrong now. I believe the PDFs are
-&quot;incorrect&quot;.
-
-
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-29T143525.792013Z"></a>
-2010-11-29T14:35:25.792013Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Type 3 font capture and charpath operations
-
-Bug #691033 &quot;Regression: 14-01.PS fails with pdfwrite&quot;
-
-The first time a type 3 glyphis encountered we start a charproc accumulatiopn and
-exit to run the BuildChar/BuildGlyph. On return to the text processing, if the
-operation was a charpath, this would take precedence over closing the accumulator which
-would lead to significant later problems.
-
-Modified the code path to allow for the charproc accumulation to finish and if this is
-a charpath operation to rerun the operation using the newly captured glyph program.
-
-Note this can only occur if the first operation on a given glyph in a type 3 font is
-for a charpath.
-
-</pre>
-<p>[base/gdevpdtt.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-27T182343.131547Z"></a>
-2010-11-27T18:23:43.131547Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : pointers not marked for garbage collection
-
-Bug #691779 &quot;SegFault with pdfwrite and more than one cid font&quot;
-
-pdfwrite does lazy creation of Identity ToUnicode CMaps for inclusion in output PDF
-files (2 CMaps, one for horizontal and one for vertical writing). These pointers were
-not marked for the garabge collector, but were stored directly in the pdf device
-structure.
-
-The CMaps were assigned to a pdfont resource type, where the pointer to the CMap *was*
-marked for the garbage collector. This meant that if the pdfont resource was moved as
-a result of garbage collection, the CMap could be moved as well. This left a dangling
-pointer in the device structure.
-
-If another font resource required an identity CMap then the now garbage pointer from
-the device structure would be assigned. If the new font resource was moved as a result
-of garbage collection, then the attempt to relocate the CMap would fail and cause a
-crash.
-
-Fixed by marking the pointers in the device structure for the garbage collector.
-
-No differences expected.
-</pre>
-<p>[base/gdevpdfx.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-26T105951.673656Z"></a>
-2010-11-26T10:59:51.673656Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Update the FAPI/UFST interface to correctly scale the points when retrieving an outline.
-Since FAPI now expects points in 32.32 fixed point form.
-</pre>
-<p>[psi/fapiufst.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-25T210322.187304Z"></a>
-2010-11-25T21:03:22.187304Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix for bug 691785.
-
-The bitmap mask clip device has a long standing bug when attempting to clip
-a bitmap through a 1bpp bitmap (gxclipm.c, clip_runs_enumerate, line 283ish).
-
-The code detects runs of 'on' pixels in the mask. It then keeps the last run
-it found in a 1 place buffer (called 'previous'). This therefore represents
-the previous run found. Whenever we find a new run, we check to see if we can
-add it to the previous run to try to form a larger (vertical) rectangle. If
-we can't, we should write the previous rectangle out and remember the current
-one.
-
-Unfortunately the code was writing the current rectangle out, rather than the
-previous one. This has the effect of losing the first run on most lines out.
-
-130 differences shown in cluster testing; confirmed in bmpcmp as
-progressions.
-
-</pre>
-<p>[base/gxclipm.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-25T091213.562173Z"></a>
-2010-11-25T09:12:13.562173Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Remove a now-unused variable to silence a compiler warning.
-
-No differences expected.</pre>
-<p>[base/gdevpdfb.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-24T221834.999818Z"></a>
-2010-11-24T22:18:34.999818Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Style clean up of gdevp14.c for white space, comments, long lines and dead code.</pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-24T174439.808162Z"></a>
-2010-11-24T17:44:39.808162Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix so that we handle the \B command properly when we have transparency. The stroke
-should be drawn in a knock-out fashion rather than blended with the fill. This was
-achieved by adding in the push of a knockout transparency group for the stroke operation.
-The opacity for that group had to be 1 rather than what ever the current graphic state was
-(otherwise you end up with the opacity applied twice). That change revealed an issue in the
-clist when a transparency group is pushed where the opacity for the pdf14 clist device was
-being altered without having the information passed into the clist. Fixing that required a
-few changes to make sure that the blend parameter changes for the transparency group end up
-written in the same bands as the group push rather than all bands like the normal blend parameter
-change compositor action does. A few changes were needed in the clist compositor writing code to
-make sure that this special blend parameter change did not push a new cropping item on the cropping
-stack. This commit results in a lot of progressions. However, the cluster push revealed a couple
-files fts_06_0608.pdf.pdf.ppmraw for example, which may have an issue. These are being checked and
-if found to be an issue a new bug report will be filed.</pre>
-<p>[Resource/Init/pdf_ops.ps base/gdevp14.c base/gxclimag.c base/gxblend.c base/gstrans.h base/gxblend.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-24T162125.266704Z"></a>
-2010-11-24T16:21:25.266704Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-pdfwrite enhancement : attempt to make PCL bitmap fonts into searchable type 3
-
-In general pdfwrite only resorts to making a bitmap from a font when it cannot handle
-the original font type, which is rare for PostScript, PDF and XPS. However all PCL
-bitmap fonts are handled this way.
-
-When this happens, the bitmap is stored into a general type 3 font, a 'bucket' where all
-such glyphs are stored. When this font is full, a new one is started and so on. The text
-stored in the PDF page stream references the correct type 3 font, but usually the
-character code will be unrelated to the original character code.
-
-For PCL bitmap fonts pdfwrite actually starts by creating a type 3 font to hold the
-PCL bitmaps, but doesn't use it. This patch tries to store the bitmaps in the type
-3 font where possible, using the character code from the original PCL document.
-Although this will not create searchable text in the general case, it does seem that
-there are a good number of PCL documents which do use an ASCII encoding and so will
-produce a searchable PDF file.
-
-There are several caveats:
-
-1) This only works at all with cached glyphs. Glyphs which are too big to fit in the
-cache are instead rendered as images, not text at all. The cache has a compiled limit
-of 2500 for the height of the bitmap, but this needs to take the resolution which is
-being used for rendering into account. The default resolution for pdfwrite is 720 dpi
-which means that bitmaps larger than ~125 rows will not be cached. (see below for more)
-
-2) Certain kinds of text operations can't be handled at all; any case where a character
-code does, or may, exceed 256 cannot be handled. These cases are handled as before by
-placing in a special font with a unique character code and called from there.
-
-3) If the font matrix is not the identity we cannot handle the glyphs, as the bitmaps
-stored in the cache already include any transformations present in the Fontmatrix and
-we can't undo those transformations to the bitmap. In practice this means that if the
-canvas orientation (not the media) is not portrait, then this will cause the text to
-be non-searchable.
-
-4) The Acrobat searching algorithm does not work very well with this kind of text. In
-our case each glyph is individually positioned on the page rather than being written
-as a continuous stream of characters. Acrobat seems unable to find more than about
-three glyphs in succession this way.
-
-
-There is no further scope for improvement in pdfwrite as far as I can see. The only
-way to handle this better would be to make changes in the PCL interpreter so that the
-bitmap PCL font is created as an actual font (probably a TrueType). This would mean that
-the text would be stored in the PDF file as real text, the FontMatrix would not be a
-problem, caching would not be an issue. This is probably a large project, but I suspect
-less of a pain than this enhancement was.
-
-Caching
-========
-In gsfont.c is a #define:
-#define blimit_LARGE 2500 /* blimit/upper - max size of a single cached char */
-
-Increasing this will allow larger glyphe to be cached. There is another limit in
-gxchar.c:
-static const uint MAX_TEMP_BITMAP_BITS = 80000;
-
-This should not be altered. Care should be exercised if increasing the maximum size
-of cached characters as these are emitted in the PDF file as inline images in a type
-3 font. The PDF spec recommends that inline images should not exceed 4Kb and some
-consumers may not be able to cope with images which exceed this limit.
-
-</pre>
-<p>[base/gdevpdfb.c base/gdevpdti.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-23T160144.675647Z"></a>
-2010-11-23T16:01:44.675647Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix chunk_free_all_remaining typo so that mulitple object chunk list gets
-traversed and freed first, then the single object chunk list. Thanks to
-Norbert Janssen for spotting this. Bug 691791.
-</pre>
-<p>[base/gsmchunk.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-23T153628.976110Z"></a>
-2010-11-23T15:36:28.976110Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix for Bug 691783. A tiny tweak to that submitted by Sebastian Rasmussen.
-Many thanks!
-
-When closing down render threads we check to see if the underlying
-allocator had to be wrapped to make it thread safe. If it was, we free the
-wrapped version too. Unfortunately the test to see &quot;did we have to wrap it&quot;
-was accessing memory we'd just freed.
-
-The fix is to move the code that finds the underlying allocator to before
-we free the memory.
-
-Cluster testing shows no differences.
-
-</pre>
-<p>[base/gxclthrd.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-23T123356.433376Z"></a>
-2010-11-23T12:33:56.433376Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-In an effort to understand the shading code I put together a 'map' of the
-function calls as comments. This has been hanging around my harddisc for ages
-and I'm now committing it to avoid it being lost.
-
-Comment change only - no cluster changes expected.
-
-</pre>
-<p>[base/gxshade1.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-23T084610.878077Z"></a>
-2010-11-23T08:46:10.878077Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Revert revision 11901.
-
-Because of the way that PCL draws bitmap fonts directly to the cache there is no
-possibility of making uncached glyphs work properly. Also the code for cached glyphs is
-much too forgiving and attempts to add glyphs which cannot be handled. Finally there is
-no provision for type 3 fonts with non-identity matrices. Because the bitmaps in the
-cache already have the scaling/rotation/shearing and clipping applied, we cannot have
-a type 3 font with a non-identity matrix.
-
-The code will be revised and recommitted.
-</pre>
-<p>[base/gdevpdti.h base/gdevpdfx.h base/gdevpdfb.c base/gdevpdt.h base/gdevpdti.c base/gdevpdfi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-20T225509.754787Z"></a>
-2010-11-20T22:55:09.754787Z regression</strong></p>
-<blockquote>
-<pre>
-Improved the cluster code's ability to be able to recover from machines going down late in the run.
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-18T192131.928351Z"></a>
-2010-11-18T19:21:31.928351Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Ensure we set SHARE_FT correctly when we end up using the system installed
-freetype library.
-
-Bug 691776.
-
-No cluster differences expected.
-
-</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-18T005220.670104Z"></a>
-2010-11-18T00:52:20.670104Z regression</strong></p>
-<blockquote>
-<pre>
-Two changes to the local cluster system:
-
-1. A warnings check is now performed on the code under test (both commit
-and user tests).
-
-2. In order to better recover from nodes going offline near the end
-of a cluster run nodes are paused after all their jobs have been sent.
-This way the jobs from an unresponsive node that isn't detected until
-all jobs have been distributed can be reassigned.
-
-Also some minor cleanup (dividing the clustermaster log into .log and
-.dbg files, supressing some uneeded debugging messages, etc.)
-
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/readlog.pl toolbin/localcluster/pngs2html.pl toolbin/localcluster/build.pl toolbin/localcluster/run.pl toolbin/localcluster/cachearchive.pl toolbin/localcluster/compare.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-16T224926.969992Z"></a>
-2010-11-16T22:49:26.969992Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix for PCL that uses the chunk allocator (which is not inherently thread safe)
-when NumRenderingThreads &gt; 1. Adds 'is_thread_safe' to the gs_memory_status so
-that clist_setup_render_threads can wrap an unsafe allocator in a locking wrapper.
-
-Also restore the optimizations to the chunk memory allocator to keep two lists
-(one for multiple object chunks and another for single object chunks) and fixes
-the chunk_free_object so that the correct list is chosen. Even if not found on
-the selected list, the other list will be scanned and a diagnostic printed if
-the wrong chunk list was selected (belt and suspenders). My testing with the
-lj*.prn files did not show this problem.
-</pre>
-<p>[base/lib.mak base/gsmemlok.c base/gsmchunk.c base/gxclthrd.c base/gsmalloc.c base/gsmemret.c base/gsalloc.c base/gsmemory.h base/gsmemraw.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-16T144831.620067Z"></a>
-2010-11-16T14:48:31.620067Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix so that the initial gray color spaces in the graphic state are properly color
-managed. Previously, if we immediately started drawing in the document with a gray
-color space, the initial un-managed color space in the graphic state was used
-and this was not associated with the specified gray source profile. With this
-fix we initialize the stroking and filling color spaces to be ICC color spaces
-associated with the profile for default_gray in the icc manager. Also a fix for
-an issue in littleCMS. When merging profiles, littleCMS will often do an optimization
-where it approximates 1-D LUTs with an exponent operation for use during merging and
-interpolation of the profile structures. If the curve is very steep, as in like a step
-function, it should not do this approximation. This was an issue when we had profiles
-that provided thresholding operations with their 1-D LUTs. I spoke with Marti about
-this issue a couple weeks ago. This commit will create over 6000 differences in the
-regression test. I reviewed many of these and they all are minor differences in gray
-colors as expected. These are differences where we were drawing unmanaged colors.</pre>
-<p>[base/gsicc_manage.c psi/zusparam.c base/gsicc_manage.h lcms/src/cmsgmt.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-16T143357.040738Z"></a>
-2010-11-16T14:33:57.040738Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-pdfwrite enhancement : attempt to make PCL bitmap fonts into searchable type 3
-
-In general pdfwrite only resorts to making a bitmap from a font when it cannot handle
-the original font type, which is rare for PostScript, PDF and XPS. However all PCL
-bitmap fonts are handled this way.
-
-When this happens, the bitmap is stored into a general type 3 font, a 'bucket' where all
-such glyphs are stored. When this font is full, a new one is started and so on. The text
-stored in the PDF page stream references the correct type 3 font, but usually the
-character code will be unrelated to the original character code.
-
-For PCL bitmap fonts pdfwrite actually starts by creating a type 3 font to hold the
-PCL bitmaps, but doesn't use it. This patch tries to store the bitmaps in the type
-3 font where possible, using the character code from the original PCL document.
-Although this will not create searchable text in the general case, it does seem that
-there are a good number of PCL documents which do use an ASCII encoding and so will
-produce a searchable PDF file.
-
-There are 3 parts to this enhancement:
-
-1) Cached glyphs. When the current font is a type 3 font, and the text operation is
-one which might result in an ASCII character code, and we can manufacture a glyph name
-for the resulting character code, store the glyph in the type 3 font (rather than the
-general 'bucket' font), using the character code and glyph name. Glyphs which can't
-be handled this way for any reason are still stored in the general recipient 'bucket'
-font.
-
-2) Uncached glyphs. Glyphs which are too large for the cache are rendered as images. The
-image handling code has been extensively reworked to try and detect this situation and,
-if the criteria for cached glyphs above also holds true, to store the image as a glyph
-in a type 3 font and draw text in the PDF content stream instead of an image. Images
-which do not fulfil these criteria are still handled as images.
-
-3) Recached glyphs. If the glyph cache fills up, glyphs will be flushed to make space.
-If a glyph is then reused we go through the caching case again (for large glyphs which
-are uncached we end up repeating the code every time the glyph is used). We now attempt
-to spot this by determining that the glyph in the font has already been used, and rather
-than storing a new copy of the glyph, as the old code did, we simply emit text into
-the page content stream.
-
-Note that there is a recommendation that inline images in PDF should not exceed 4KB.
-Since CharProcs must use inline images, bitmaps which exceed this size will be rendered
-as images, not text (they will also exceed the cache size and so are always rendered
-uncached).
-
-</pre>
-<p>[base/gdevpdti.h base/gdevpdfx.h base/gdevpdfb.c base/gdevpdt.h base/gdevpdti.c base/gdevpdfi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-16T135836.196330Z"></a>
-2010-11-16T13:58:36.196330Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Prefer character codes &lt; 256 during construction of /CharStrings and
-/Encoding attributes of a symbolic Type 42 font. Bug 691753.
-</pre>
-<p>[Resource/Init/gs_ttf.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-15T183050.012584Z"></a>
-2010-11-15T18:30:50.012584Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-reverts 11877 which needs a bit more work</pre>
-<p>[base/gsmchunk.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-15T091150.168011Z"></a>
-2010-11-15T09:11:50.168011Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Fix a memory leak when interpolating image data. We were allocating a colour
-management buffer for every interpolated scan line from the currently
-buffered image data, but only releasing the last one.
-
-We'll now allocate the buffer (and initialise the buffer desc structure)
-only once, and free the buffer once when we're done.
-
-No cluster differences expected.
-
-Bug 691772
-
-(NOTE: the test file for this still appears to go into an infinite loop
-during interpolation).
-
-</pre>
-<p>[base/gxiscale.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-14T211615.954493Z"></a>
-2010-11-14T21:16:15.954493Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Make a macro for the default ICC profile name and set it in the proper locations.</pre>
-<p>[base/gsicc_manage.c psi/zusparam.c base/gsicc_manage.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-06T153618.568592Z"></a>
-2010-11-06T15:36:18.568592Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for a string handling bug that occurred when the device ICC profile name
-was smaller than the default device profile name. Also, additional code to
-ensure that the ICC path and the device profile name are properly combined
-when needed. Finally, if the device profile name is given as an absolute
-name the icc directory is not added to it.</pre>
-<p>[base/lib.mak base/gsdparam.c base/gsicc_manage.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-05T221205.617541Z"></a>
-2010-11-05T22:12:05.617541Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix so that when compositing with tags, the tos tag data has no effect on
-the nos tag data if the pixel alpha value is 0. Fixes Bug 691752.</pre>
-<p>[base/gxblend1.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-05T155335.817121Z"></a>
-2010-11-05T15:53:35.817121Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-In the event that we've decided not to cache a glyph generated by FAPI, we
-need to make sure that zsetcachedevice2() doesn't opt to try to cache said
-glyph. To do that we were setting in_cachedevice to CACHE_DEVICE_NOT_CACHING
-before calling zchar_set_cache(), and setting it back to its previous value
-on return. Unfortunately, a font with a CDevProc causes the call to
-zsetcachedevice2() to be delayed until after execution of the CDevProc, so
-in_cachedevice was (probably) no longer set to CACHE_DEVICE_NOT_CACHING.
-
-Amongst other effects, this caused some anti-aliased glyphs to be render
-with incorrect, scaling as well as the potential for marking glyphs to have
-empty (but valid) cached bitmaps.
-
-Expected cluster differences: fts_23_2306.pdf at 72dpi shows some (benign)
-pixel differences on the pattern filled glyphs - this is actually a behaviour
-progression, as it is caused by cache being properly bypassed for an uncached
-glyph, rather than the glyph being rendered uncached but the cache receiving
-an emtpy glyph.
-
-Bug 691750.
-
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-04T191308.201769Z"></a>
-2010-11-04T19:13:08.201769Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Increase in curve size to enable sharper cut offs (i.e. no interpolation of
-curve points) for thresholding profiles. </pre>
-<p>[toolbin/color/icc_creator/ICC_Creator/icc_create.cpp]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-03T204407.993086Z"></a>
-2010-11-03T20:44:07.993086Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix to avoid potential crash instead of error if an improper file name
-is given for the device ICC profile.</pre>
-<p>[base/gsicc_manage.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-02T171624.985382Z"></a>
-2010-11-02T17:16:24.985382Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Remove some unnecessary, and detrimental endian related code
-in the GS/lcms interface.
-
-Bug 691696
-
-No cluster differences expected.
-
-</pre>
-<p>[base/gsicc_cache.c base/gsicc_littlecms.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-11-01T235927.933765Z"></a>
-2010-11-01T23:59:27.933765Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Performance fix so that the md5 code is not used to hash the rendering
-conditions for the icc link. </pre>
-<p>[base/gsicc_cache.c base/gscms.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-31T032619.022477Z"></a>
-2010-10-31T03:26:19.022477Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Optimize large allocations in the chunk memory manager maintaining separate lists
-for chunks with only a single block (that will never have any free space) from
-the multiple object chunks which are searched for free space when the requests
-are for small objects. Testing with a 28 files benchmark suite shows improvements
-against rev 11876 by over 9% (real time), to get within 2% of version 8.71.
-(testing 600 dpi ppmraw to /dev/null on peeves).
-</pre>
-<p>[base/gsmchunk.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-30T034036.798714Z"></a>
-2010-10-30T03:40:36.798714Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Check for negative object nunbers and consider such objects as null.
-Bug 691740, customer 384.
-</pre>
-<p>[Resource/Init/pdf_base.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-29T234030.279741Z"></a>
-2010-10-29T23:40:30.279741Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix so that the image clues array is dynamically allocate only when needed
-as opposed to being a static array in gx_image_enum. clues is used only
-in the case of monochrome or indexed with bps &lt;= 8 and masked images.
-Another optimization to do is to make it allocate only 2 entries for the
-masked case rather than all 256.</pre>
-<p>[base/gxipixel.c base/gxidata.c base/gximage.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-29T193548.071618Z"></a>
-2010-10-29T19:35:48.071618Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Revision 10823 removed an optimization to strength reduce the logical
-operation when rendering an image - the optimization in fact was
-incorrect (see the bug referenced in the commit entry #691147) however
-the optimization is correct and gives us a good speedup if the current
-color is black. This is due to the peculiarities of the pcl
-transparency model which only effects the opacity/transparency of
-white.
-</pre>
-<p>[base/gxipixel.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-29T163741.020300Z"></a>
-2010-10-29T16:37:41.020300Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Added features and fixed bugs to enable creation of thresholding ICC profiles.</pre>
-<p>[toolbin/color/icc_creator/ICC_Creator/icc_create.h toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.h toolbin/color/icc_creator/ICC_Creator/resource.h toolbin/color/icc_creator/ICC_Creator/ICC_Creator.rc toolbin/color/icc_creator/ICC_Creator/icc_create.cpp toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.cpp]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-29T090542.895454Z"></a>
-2010-10-29T09:05:42.895454Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix : DeviceN not permitting multiple identical inks
-
-Bug #691740
-
-The DeviceN checking code did not permit multiple inks to have the same name. The
-comment in the code says this is not permitted, but I am unable to find any
-documentation in any of the specifications in support of this, and other interpreters
-(including CPSI) do not make this restriction.
-
-Restriction removed, and also the 'continuation' procedures used for much of the colour
-space parsing/validation have been given names so that future error messages use these
-instead of printing the function address.
-
-No differences expected.
-</pre>
-<p>[base/gscdevn.c psi/zcolor.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-28T204114.761110Z"></a>
-2010-10-28T20:41:14.761110Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Addition in profile creation tool to create Gray ICC profiles with
-abrupt thresholds. Needed for solution to bug 691737</pre>
-<p>[toolbin/color/icc_creator/ICC_Creator/icc_create.h toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.h toolbin/color/icc_creator/ICC_Creator/resource.h toolbin/color/icc_creator/ICC_Creator/ICC_Creator.rc toolbin/color/icc_creator/ICC_Creator/icc_create.cpp toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.cpp]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-28T195751.569853Z"></a>
-2010-10-28T19:57:51.569853Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for issues that arise when the embedded icc profile is the same as one
-of the default icc profiles and we are using pdfwrite. This should fix 691731.</pre>
-<p>[base/gsicc_create.c base/gsicc_manage.c base/gscms.h base/gsciemap.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-28T190245.723574Z"></a>
-2010-10-28T19:02:45.723574Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Marcos points out that tiffscaled with -rR -dDownScaleFactor=D can produce
-different sized images than just using -r(R*D) and a normal tiff device.
-(Bug 691730). I'll concede he's probably right that this isn't ideal.
-
-The difference was caused by me rounding the size up on a downscale so that
-no information is lost.
-
-This patch removes the rounding up. We can always add it again later if
-we actually find a file where it makes a difference.
-
-No expected cluster differences.
-
-</pre>
-<p>[base/gdevtifs.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-28T150037.200667Z"></a>
-2010-10-28T15:00:37.200667Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Work around the &quot;no rule to make target&quot; with tif_config.h (actually it
-affects tiffconf.h, too). This involves the rather unpleasant requirement
-of calling a configure script (for libtiff) from a makefile (the top level
-makefile for the ghostpdl builds). It must be done there, before the PDL
-specific makefiles start setting CFLAGS, which confuses the configure.
-
-Also, update the GS dist-clean and GhostPDL clean targets to remove
-the two tiff header files generated during the tiff configure.
-
-THIS IS NOT A FIX! It really is a &quot;workaround&quot;.
-
-Bug 691700.
-
-
-</pre>
-<p>[/trunk/ghostpdl/Makefile base/Makefile.in]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-28T061253.429268Z"></a>
-2010-10-28T06:12:53.429268Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Code to speed up cases where a file contains a lot of small images that are
-embedded in the clist as high level images. Previously, for every high level
-image, the serialized ICC source data was read out of the clist at a different
-clist file location, which required a fseek, a fread and then another fseek.
-This occurred even if all the images shared the same profile. The cost of
-file i/o for this can become significant if we have a lot of images. With
-this commit, the reading of the profile data is delayed and will only occur
-if a link using that profile does not already exist in the link cache. </pre>
-<p>[base/gxclpath.c base/gxclimag.c base/gxclist.h base/gxclrast.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-28T041255.507828Z"></a>
-2010-10-28T04:12:55.507828Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Added dependencies to devs.mak to allow minftrsz.c to compile with concurrent make.
-
-</pre>
-<p>[base/devs.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-27T233042.045125Z"></a>
-2010-10-27T23:30:42.045125Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix compiler warning.
-
-No expected differences.
-
-</pre>
-<p>[base/gdevtifs.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-27T194801.087645Z"></a>
-2010-10-27T19:48:01.087645Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add new version of tiffscaled device, that supports -dMinFeatureSize=2.
-(Solves bug 691718).
-
-Also add support for AdjustWidth in tiffscaled device.
-
-Also update documentation.
-
-No expected differences.
-
-</pre>
-<p>[base/gdevfax.h base/gdevtifs.c base/minftrsz.c base/gdevtifs.h base/gdevtsep.c base/minftrsz.h doc/Devices.htm base/gdevfax.c base/gdevtfnx.c base/gdevtfax.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-27T124549.361211Z"></a>
-2010-10-27T12:45:49.361211Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix Bug 691727.
-
-Black and White Tiff based devices were not respecting the AdjustWidth
-parameter. Fax based devices were applying it regardless, non faxed based
-devices were not applying it at all. The documentation says they should
-all default to applying it, but be controlled by the option.
-
-In this commit, we change so that all black and white tiff based devices
-(except tiffscaled) respect this parameter. We default to applying it in
-fax devices, and not applying it in non-fax devices, so default behaviour
-does not change. We also update the docs.
-
-No expected differences.
-
-</pre>
-<p>[doc/Devices.htm base/gdevtfax.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-27T111838.076346Z"></a>
-2010-10-27T11:18:38.076346Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix Bug 691726, memory corruption in tiffscaled device when
-(resolution % DownScaleFactor) != 0.
-
-The problem specifically occurred when the page had 'stray' lines at the end.
-The code I had written to cope with this was calling the Tiff writing code
-with the wrong row number, causing the tiff lib to try to extend the buffer.
-This, it seems, is a bad thing.
-
-The miscalculation is fixed here, and the bug goes away.
-
-No expected cluster differences.
-
-</pre>
-<p>[base/gdevtifs.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-26T235413.691521Z"></a>
-2010-10-26T23:54:13.691521Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix bug reported by Norbert Janssen. Inaccuracies in the floating point maths
-can cause 'no-scales' to look like 'downscales', and so high level images are
-skipped.
-
-This shouldn't actually matter in most cases as the two rendering paths should
-give the same results, but when people hook the clist for their own purposes
-this can cause problems. The workaround is to introduce a fudge factor and to
-accept very slight downscales.
-
-Thanks to Norbert for the first version of this patch.
-
-Minimal differences in cluster testing due to bug 691697.
-
-
-</pre>
-<p>[base/gxclimag.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-26T203032.970049Z"></a>
-2010-10-26T20:30:32.970049Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for RGB byte order expected by new CMM compared to imdi libray.</pre>
-<p>[base/gdevwts.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-26T202245.373077Z"></a>
-2010-10-26T20:22:45.373077Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Silence gcc warning.
-
-</pre>
-<p>[base/gdevfax.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-26T194135.752819Z"></a>
-2010-10-26T19:41:35.752819Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Removal of accidental commit of my own path for the wts halftone planes.
-
-</pre>
-<p>[base/gdevwts.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-26T185049.267717Z"></a>
-2010-10-26T18:50:49.267717Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix so that wtsimidi device works again. I had the device using the wrong
-structure for maintaining its device link that maps the contone RGB data to
-CMYK.</pre>
-<p>[base/gdevwts.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-26T181015.277289Z"></a>
-2010-10-26T18:10:15.277289Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add Rays MinFeatureSize magic. Ray had originally integrated this into the
-fax devices, which had the effect of working for the tiff based fax
-devices too. Unfortunately the reworking of the tiff based devices to
-use libtiff meant that the output function changed, causing the patch to
-stop working with those devices.
-
-Here we split the new code out into a separate .c/.h pair, so it can be
-used by both tiff and fax devices, and hook it up to all the black and
-white tiff devices (except tiffscaled) and to the fax based ones.
-
-We also document the device (including it's current limitations).
-
-No expected changes.
-
-</pre>
-<p>[base/gdevfax.h base/gdevtifs.c base/minftrsz.c base/gdevtifs.h ghostscript.vcproj base/minftrsz.h base/gdevtsep.c doc/Devices.htm base/gdevfax.c base/gdevtfnx.c base/devs.mak base/gdevtfax.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-26T141424.874268Z"></a>
-2010-10-26T14:14:24.874268Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Generate fully opaque mask when /SMaskInData attribute is specified in PDF
-but JPX stream has no opacity channel. Fix the case of missing images on
-Luratech decoder in fts_17_1717.pdf and fts_17_1718.pdf.
-</pre>
-<p>[base/sjpx_luratech.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-25T165126.885213Z"></a>
-2010-10-25T16:51:26.885213Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Change the interface to Luratech JPX library to extract image data or
-opacity depending on the alpha parameter.
-</pre>
-<p>[base/sjpx_luratech.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-25T155910.973330Z"></a>
-2010-10-25T15:59:10.973330Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix pdfwrite : Do not emit DeviceRGB/CMYK as an Alternate when disallowed by PDF/A or X
-
-If a /Separation colour space had an /Alternate of /DeviceRGB or DeviceCMYK it was not
-checked to see if it was valid for PDF/A or PDF/X production, if these were set.
-
-As a result invalid PDF/A or PDF/X files could be written.
-
-The code now tests these flags and if the base space is not valid, converts to an
-appropriate base space by; sampling the tint transform function at 0 and 1, converting
-the resulting colours to the appropriate base space (using the Red Book methods for
-DeviceRGB/DeviceCMYK conversion), creating a new linear interpolation function for
-the new base space, using the converted sampled values for /Co and C1.
-
-The new base space is then written to the PDF file.
-
-No differences expected as we don't test PDF/A and PDF/X on the cluster.</pre>
-<p>[base/gdevpdfc.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-25T062322.846885Z"></a>
-2010-10-25T06:23:22.846885Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Move initialization of state-&gt;alpha flag to the place where it has effect.
-</pre>
-<p>[base/sjpx_luratech.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-25T043951.229054Z"></a>
-2010-10-25T04:39:51.229054Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Merge rev. 11790, 11795, 11802, 11805, 11809, 11810, 11812, 11813, 11818
-into the trunk. JPX files without SMaskInData are now rendered correctly.
-Other JPX files are rendered incorrectly. Trunk PostScript code and Jasper
-use separate access to opacity and data. Luratech is still using pixel-
-interleaved format.
-</pre>
-<p>[base/sjpx_luratech.c base/sjpx_luratech.h psi/msvc32.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-25T041646.177854Z"></a>
-2010-10-25T04:16:46.177854Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Rev. 11785 have introduced double decrement of the reference counter in
-gx_pattern_cache_free_entry() that caused warnings with -Z? option and
-SEGV on Windows, esp. with Luratech JPX library. This patch resolves
-all warnings and crashes. Bug 691714.
-</pre>
-<p>[base/gxpcmap.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-24T222355.448411Z"></a>
-2010-10-24T22:23:55.448411Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Implement /SMaskInData using images with /SMask and separate streams for the
-mask and image data. Our /ImageType 103 seems to have issues and cannot be
-used directly. /JPXDecode filter now takes /Alpha parameter, which controls
-whether opacity or image data stream is extracted.
-
-This commit introduces a PS error on pdfwrite device in fts_18_1805.pdf
-and a few other files with the same image. However, this image has never
-been combined with SMask before and the actual bug may predate the commit.
-Bug 691489, customer 532.
-</pre>
-<p>[base/sjpx.c Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-23T223817.069244Z"></a>
-2010-10-23T22:38:17.069244Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Move checking for /JPXDecode filter in front of checking for missing color
-spaces to handle /SMaskInData attribute in all cases. Fix handling of filter
-arrays and a wrong name /DecodeParms.
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-22T092910.157074Z"></a>
-2010-10-22T09:29:10.157074Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Add a debug-clean target (which in turn calls the existing debugclean target)
-to be more consistent with the ghostpdl langauge builds.
-
-No cluster differences expected.
-
-</pre>
-<p>[base/Makefile.in]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-22T075212.054756Z"></a>
-2010-10-22T07:52:12.054756Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Remove a spurious space that was causing a compiler warning, and remove an unused
-function, also causing a compiler warning.
-</pre>
-<p>[base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-22T063849.083740Z"></a>
-2010-10-22T06:38:49.083740Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Make oforce_recursive more robust in preparation to SMaskInData commit.
-Don't execute tint transform functions and similar executable arrays
-that may be added by our PDF interpreter to PDF objects.
-</pre>
-<p>[Resource/Init/pdf_base.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-22T041930.192593Z"></a>
-2010-10-22T04:19:30.192593Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Recognize /SMaskInData attribute as an indicator that the page has
-transparency features. Establish a base level for a future regression
-testing.
-</pre>
-<p>[Resource/Init/pdf_main.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-21T155737.250433Z"></a>
-2010-10-21T15:57:37.250433Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-More DSC work. Altered Procset emission to strip comments (but not line endings), as
-some of the ProcSets included %%BeginPrologue and %%EndPrologue comments which isn't
-(I don't think) allowed. Also makes the output file smaller.
-
-When producing DSC output, don't set the FitPages/RoatePages/CenterPages/SetPageSize
-operations.
-
-Don't permit the entire file to be compressed when emitting DSC PostScript
-(clearly won't be DSC compliant that way)
-
-Produce some very basic DSC Comments; the correct header, %%Pages, %%Beginprologue.
-%%EndPrologue, %%EndComments.
-
-Don't emit %PDF header when producing DSC PostScript.
-
-Count the number of pages and emit a %%Pages: comment at the end of the file. Don't
-write the Info dict when producing DSC PostScript. Emit %%Trailer and $$EOF.
-</pre>
-<p>[base/gdevpdf.c base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-21T140927.225155Z"></a>
-2010-10-21T14:09:27.225155Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Updated the cluster new node instructions to test the cups device
-when verifying the installation is complete.
-
-</pre>
-<p>[toolbin/localcluster/readme]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-21T133900.821724Z"></a>
-2010-10-21T13:39:00.821724Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Added the cups dev repositories to the cluster node sertup read.me
-
-</pre>
-<p>[toolbin/localcluster/readme]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-21T111731.420556Z"></a>
-2010-10-21T11:17:31.420556Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-When producing DSC compliant PostScript from ps2write, do not emit the following;
-Pages tree, outlines, articles, named destinations, PageLabels array, document metadata,
-document Catalog, threads, encrypt dictionary, xref, trailer.
-
-These objects are not required by PostScript, and cannot be easily
-placed in a DSC-conforming file. This does mean that, unlike the general output from
-ps2write, the output file is *not* a valid PDF file and cannot be opened as such by a
-PDF consumer.
-
-No differences expected.
-</pre>
-<p>[base/gdevpdf.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-21T110740.293085Z"></a>
-2010-10-21T11:07:40.293085Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Correct a bug in revision 11828 which tried to copy too many bytes from the source
-buffer, if fewer bytes were read then were requested, when copying a ProcSet.
-</pre>
-<p>[base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-21T082247.321512Z"></a>
-2010-10-21T08:22:47.321512Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Remove some unused variables to silence compiler warnings.
-</pre>
-<p>[base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-21T024848.797956Z"></a>
-2010-10-21T02:48:48.797956Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Don't search for a font named / on disk, because operator findlibfile
-throws an error in this case. Just fail the request when such font is
-not defined in VM. Bug 691698, customer 384.
-</pre>
-<p>[Resource/Init/gs_res.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-20T170027.929678Z"></a>
-2010-10-20T17:00:27.929678Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add a helpful valgrind header, and call it from gsmdebug.h.
-
-The valgrind header here serves 2 purposes.
-
-Firstly, it insulates us from platforms on which Valgrind does not exist -
-if we build without defining ENABLE_VALGRIND then no dependency on any
-valgrind headers exists. The standard Valgrind macros are all defined in
-this header to do nothing, so they can safely be called in our code
-without needing ugly #ifdef ENABLE_VALGRIND wrapping.
-
-Secondly, it insulates us from changes in the valgrind/memcheck.h file -
-if ENABLE_VALGRIND is defined we will use whatever version is defined by
-the system. If new macros are defined by new versions of valgrind/memcheck.h
-we simply need to add new 'empty' definitions to valgrind.h.
-
-To start with, the only use of this code is to mark the contents of newly
-allocated blocks as being undefined. Thanks to AlexCher for spotting a
-cunning place to do this.
-
-</pre>
-<p>[base/valgrind.h base/gsmdebug.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-20T165951.575415Z"></a>
-2010-10-20T16:59:51.575415Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Add /ZapfDingbats to the list of known symbolic fonts, which ignore bogus
-/Encoding attribute. Fix fts_23_2300.pdf rendering.
-</pre>
-<p>[Resource/Init/pdf_font.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-20T160528.326890Z"></a>
-2010-10-20T16:05:28.326890Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Initial work on DSC compliant PostScript. When ProduceDSC is true, do not strip the
-ProcSet, this is because DSC-compliant files have a line limit of 256. Later we will
-want to wrap the ProcSet emissions with %%BeginResource/%%EndResource as well.
-
-No effect if ProduceDSC is not true, so no differences expected.
-</pre>
-<p>[base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-20T144548.119859Z"></a>
-2010-10-20T14:45:48.119859Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Add a new switch to ps2write, working title 'ProduceDSC'. This will be used to control
-whether the output of ps2write is DSC-compliant or not.
-
-No differences expected.
-</pre>
-<p>[base/gdevpdfx.h base/gdevpdfp.c base/gdevpdfb.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-20T105923.603495Z"></a>
-2010-10-20T10:59:23.603495Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Disable the use of high level images in the clist if we are downscaling;
-this serves 2 purposes.
-
-Firstly, it fixes the potential problems with banded/unbanded mismatch
-of rendering due to the 'support' calculations done in the high level image
-code. These calculations are no longer correct for downscales since the
-change to use a simpler interpolated image scaler.
-
-Secondly, when downscaling we will probably end up copying more data than
-we would if we just kept the original, so high level images are a bad idea
-anyway.
-
-This *should* produce no differences, but actually produces lots.
-
-Most of these might be ignorable (slight rendering differences that appear to
-result in the new images being a little lighter, but a significant number
-appear to be noticable progressions, which hints that the high level image
-clist code is broken. Specifically high level images fail to render the
-same as the non high level code does. In particular halftoning seems to
-be enabled for some examples when high level images are used, for no good
-reason. This has been opened as bug 691697.
-
-
-</pre>
-<p>[base/gxclimag.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-20T102150.512085Z"></a>
-2010-10-20T10:21:50.512085Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Unpack a hideously complex if statement into a series of if statements.
-Any reasonable compiler (if such a thing can be said to exist) should
-compile to the same code, but this is a lot easier to use under a debugger/
-read.
-
-No changes expected in testing (and clusterpush agrees).
-
-
-</pre>
-<p>[base/gxclimag.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-19T080432.778817Z"></a>
-2010-10-19T08:04:32.778817Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Update CFF interpreter to handle gsubr while searching for SEAC
-
-Bug #691680 &quot;PDF Writer drops many accented characters&quot;
-
-pdfwrite makes use of a routine 'gs_type1_piece_codes' while copying fonts to determine
-if a glyph is a SEAC, and therefore includes two subsidiary glyphs. This code was
-updated previously (rev 10076) but on encountering a callgsubr in a CFF font, assumed
-that the glyph was not a SEAC&gt;
-
-This patch adds support for callgsubr and continues searching glyphs which use a gsubr
-to see if the gsubr is actually a SEAC type endchar.
-
-No differences expected.
-</pre>
-<p>[base/gxtype1.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-18T154420.143696Z"></a>
-2010-10-18T15:44:20.143696Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Silence a compiler warning from my previous commit.
-
-</pre>
-<p>[psi/zchar42.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-18T141144.566085Z"></a>
-2010-10-18T14:11:44.566085Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-In a CIDType2 font with a gsub table, when/if we substitute the glyph index
-with an index for a vertical glyph, make sure we change the value of the
-Truetype glyph index, and *not* the value of the Postscript CID.
-
-Bug 691692
-
-No cluster differences expected.
-
-</pre>
-<p>[psi/zchar42.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-16T155253.774342Z"></a>
-2010-10-16T15:52:53.774342Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix pdfwrite: Don't use CFF font format if CompatibilityLevel &lt; 1.2
-
-We permit CompatibilityLevel down to 1.1, but PDF 1.1. doesn't support CFF (Type 1C)
-fonts, so don't use this format if CompatibilityLevel &lt; 1.2.
-
-No differences expected.
-</pre>
-<p>[base/gdevpdfp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-15T151236.033471Z"></a>
-2010-10-15T15:12:36.033471Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Scale up type 3 font outlines to give more accuracy
-
-Bug #691383, #691287, #691595 various type 3 font problems.
-
-Although this is being fixed for the FreeType implementation, the Artifex font
-interpreter had similar problems.
-
-The issue is caused by using an identity scale at 72 dpi to capture font outlines.
-Quark often uses a type 3 font which runs a type 1 font, in order to achieve text
-special effects, such as stroke+fill. The stroke was achieved by a 'charpath/fill'
-combination, because pdfwrite doesn't have a charpath, this meant that the path was
-captured and emitted. Because the scale was so low, the interpreter could run out of
-arithmetic precision, resulting in poorly formed outlines.
-
-We can't simply use the CTM in force at the time, as that includes the font scale, but
-we need to use something other than the identity. A scale facto of 1000 proved too
-likely to cause arithmetic overflow, or clipping, and also meant writing large values
-to the PDF file, which is inefficient. A factor of 10 turned out to be insufficient, so
-a factor of 100 has been used.
-
-Because the CharProc is effectively interpreted at the page level, this can result in
-large values being used for paths, so we need to scale the device width and height by
-100 as well, to prevent clipping (and undo it afterwards!)
-
-</pre>
-<p>[base/gdevpdtt.c base/gdevpdti.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-15T150705.687999Z"></a>
-2010-10-15T15:07:05.687999Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-With the latest release of Freetype, reinstate the &quot;sensible&quot; method of
-limiting the size of the bitmap that we let Freetype create. It is
-limited to 1.5x the current maximum cacheable glyph bitmap, as it is *vital*
-that we avoid creating an outline when the cache expects a bitmap,
-but not a problem if we create a bitmap for a non-cached glyph.
-
-Bug 691569.
-
-No cluster differences expected.
-
-</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-15T142151.952651Z"></a>
-2010-10-15T14:21:51.952651Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Properly scale co-ordinates into Acrobat's range
-
-When emitting various co-ordinates pdfwrite is careful to stay within +/- 32,767 in
-order to ensure all versions of Acrobat can properly deal with them. To achieve this it
-emits a matrix which scales values up, and then writes the co-ordinates scaled down
-by this factor. Thus ensuring that they stay within permitted values, but are still
-correct.
-
-However, when emitting a rectangular fill, the scale was applied backwards, the
-co-ordinates were scaled *up* instead of down by the scale factor. This led to wildly
-incorrect values being written for rectangular paths.
-
-No differences expected with this in the test suite, however it forms part of the fix
-for type 3 fonts which will follow and does rely on this change.
-</pre>
-<p>[base/gdevpdfd.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-14T202315.984226Z"></a>
-2010-10-14T20:23:15.984226Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-The image_set_gray function needed to take the address of the pointer
-to the device color, the parameter should have been passed by
-reference, as it must be set to &amp;penum-&gt;clues[sample_value].dev_color
-and returned. We'd like to get rid of the macro entirely and use the
-image_set_gray as an inline function but have not tested performance.
-The function might be too complex for inlining on some compilers.
-</pre>
-<p>[base/gximono.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-14T150601.276381Z"></a>
-2010-10-14T15:06:01.276381Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-In gx_alloc_char_bits() the &quot;target&quot; device can be NULL, in which case
-avoid trying to decrement the ICC profile object for the target device.
-
-patch credit to William Bader.
-
-Bug 691651.
-
-No cluster differences expected.
-
-</pre>
-<p>[base/gxccman.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-14T150156.645831Z"></a>
-2010-10-14T15:01:56.645831Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-If we're passed an unexpected object instead of a glyph name object
-fall back to rendering the notdef.
-
-This is not identical, but is closer to the behaviour of the AFS code
-under these conditions.
-
-Highlighted by Bug 691656.
-
-No cluster differences expected.
-
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-14T145736.364971Z"></a>
-2010-10-14T14:57:36.364971Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Rename libpng.mak to png.mak to make it consistent with the other
-third part libraries.
-
-Bug 691681
-
-No cluster differences expected.
-
-</pre>
-<p>[base/openvms.mmk base/ugcclib.mak base/libpng.mak base/Makefile.in base/unix-gcc.mak base/macos-mcp.mak base/winlib.mak base/png.mak psi/os2.mak base/openvms.mak base/macosx.mak base/configure.ac /trunk/ghostpdl/common/ugcc_top.mak psi/msvc32.mak base/unixansi.mak base/msvclib.mak base/devs.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-14T142322.009615Z"></a>
-2010-10-14T14:23:22.009615Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-CUPS Raster output device: Fixed access to uninitialized variable, the margins array is only set when size_set is true (bug #691683).
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-14T115731.187468Z"></a>
-2010-10-14T11:57:31.187468Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Rename libtiff.mak to tiff.mak to be more consistent with the other third party libs.
-
-Bug 691681
-
-No cluster differences expected.
-
-</pre>
-<p>[base/winlib.mak base/tiff.mak base/Makefile.in /trunk/ghostpdl/common/ugcc_top.mak base/unix-gcc.mak base/unixansi.mak base/libtiff.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-13T171459.959208Z"></a>
-2010-10-13T17:14:59.959208Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix 2 build warnings in gdevtifs.c
-
-No expected differences.
-
-</pre>
-<p>[base/gdevtifs.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-13T160151.166726Z"></a>
-2010-10-13T16:01:51.166726Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add new tiffscaled device. This renders internally as tiffgray, but then
-downsamples by an integer scale factor (specified by -dDownScaleFactor=n)
-and error diffuses to 1bpp output.
-
-This device is also included in pcl builds (windows ones at least), enabling
-a solution for dropouts caused by rendering pcl at 200dpi. (Render at 600dpi
-and scale down by a factor of 3). This should hopefully solve bug 690085.
-
-Future work to consider: work on bringing libtiff based devices into unix PCL
-builds, consider stochastic thresholding rather than FS error diffusion.
-
-</pre>
-<p>[base/gdevtifs.c base/openvms.mak base/gdevtifs.h base/gdevtsep.c base/configure.ac base/unix-gcc.mak doc/Devices.htm base/unixansi.mak psi/msvc32.mak base/gdevtfnx.c base/macos-mcp.mak base/devs.mak base/gdevtfax.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-13T104804.352147Z"></a>
-2010-10-13T10:48:04.352147Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-We have far fewer font Decodings than there are &quot;well known&quot; Encodings, so
-assuming that for such an Encoding we always have a predefined Decoding
-is problematic.
-
-We'll now try to find a predefined Decoding, and if one isn't found
-we'll derive one from the Encoding (as we previously did only for
-non-well known Encodings).
-
-Bug 691677
-
-No cluster differences expected.
-
-</pre>
-<p>[Resource/Init/gs_fntem.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-12T232736.478231Z"></a>
-2010-10-12T23:27:36.478231Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove unused variable in siscale.c that was causing warnings.
-
-No expected differences.
-
-</pre>
-<p>[base/siscale.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-12T162632.204667Z"></a>
-2010-10-12T16:26:32.204667Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Update interpolation filter. When we are downscaling an image on either axis
-we now use a simpler (less computationally complex) linear interpolation
-filter rather than the existing mitchell filter.
-
-For downscaling the difference in quality between mitchell and simple
-linear interpolation is not that noticable. (But the CPU/memory usage is a
-quarter what it would be for proper mitchell downscaling).
-
-What is noticable is that the existing downscaling code is 'bent' to avoid
-having to hold more than 8 temporary scaled scanlines of the image. The effect
-of this is to incorrectly limit the pixels that actually go into contributing
-to an output pixel, producing dropouts.
-
-We update the code here to remove this limit. This means that downscales
-may potentially take more memory and more computation to perform, but the
-overall quality is better.
-
-Regression tests show both noticable and unnoticable differences in files that
-enable interpolation (270 or so). The noticable differences are all that the
-new output looks smoother, at the expense of losing some contrast and solving
-some 'jaggy' looking edges.
-
-Testing with my custom dropout test file shows a huge improvement with the
-new code. I'll add this to the test repo shortly.
-
-</pre>
-<p>[base/siscale.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-12T055216.851470Z"></a>
-2010-10-12T05:52:16.851470Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for a large memory leak that can occur when a pattern cache entry
-is freed and a transparency buffer exists in the entry. A problem was
-that the pdf14 device, which contains pointers to the buffer, had its
-close device procedure set to forward due to the device being set in a
-disabled state during pattern_paint_finish. The close device proc for
-the pdf14 device contains the calls to actually free the buffers so this
-was not occurring (instead we were forwarding to another device). In addition,
-the pdf14 device itself was not being destroyed. With this commit, when the
-pattern entry is freed, the pdf14 device is now closed, which frees the buffers,
-and the pdf14 device is properly reference count decremented to result in the
-device itself getting freed. Regression run revealed no problems.</pre>
-<p>[psi/zpcolor.c base/gxpcmap.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-11T075326.581165Z"></a>
-2010-10-11T07:53:26.581165Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Update Freetype to 2.4.3
-
-Revise fapi_ft.c to take into account new font(s) being added to Freetype's
-&quot;tricky&quot; font list. &quot;Tricky&quot; fonts need the bytecode interpreter to produce
-&quot;correct&quot; output. But for GS, in the case of (even &quot;tricky&quot;) fonts which
-produce an error in the bytecode interpreter, we want to try to produce
-some output, even just a notdef glyph. So in the non-hinted, and notdef
-fallback cases, remove the &quot;tricky&quot; flag from the Freetype face.
-
-No cluster differences expected.
-
-
-</pre>
-<p>[freetype/src/pshinter/pshalgo.c psi/fapi_ft.c freetype/builds/unix/config.sub freetype/src/type42/t42parse.c freetype/builds/win32/visualce/freetype.dsp freetype/docs/reference/ft2-toc.html freetype/docs/reference/ft2-computations.html freetype/builds/unix/configure.ac freetype/builds/wince/vc2008-ce/index.html freetype/builds/unix/ftconfig.in freetype/src/sfnt/ttload.c freetype/ChangeLog.23 freetype/docs/reference/ft2-sizes_management.html freetype/src/cache/ftccache.c freetype/docs/reference/ft2-quick_advance.html freetype/include/freetype/freetype.h freetype/configure freetype/docs/reference/ft2-pfr_fonts.html freetype/docs/reference/ft2-gasp_table.html freetype/docs/reference/ft2-system_interface.html freetype/builds/unix/configure freetype/docs/reference/ft2-mac_specific.html freetype/docs/reference/ft2-basic_types.html freetype/docs/reference/ft2-lcd_filtering.html freetype/src/truetype/ttgload.c freetype/docs/reference/ft2-cid_fonts.html freetype/include/freetype/internal/ftobjs.h freetype/docs/reference/ft2-winfnt_fonts.html freetype/docs/reference/ft2-bitmap_handling.html freetype/docs/reference/ft2-cache_subsystem.html freetype/Jamfile freetype/include/freetype/ftimage.h freetype/src/base/ftobjs.c freetype/builds/win32/visualce/index.html freetype/docs/reference/ft2-glyph_variants.html freetype/docs/reference/ft2-glyph_stroker.html freetype/builds/win32/visualc/freetype.vcproj freetype/docs/reference/ft2-sfnt_names.html freetype/docs/reference/ft2-raster.html freetype/include/freetype/ftlcdfil.h freetype/builds/win32/visualce/freetype.vcproj freetype/docs/reference/ft2-bdf_fonts.html freetype/docs/reference/ft2-truetype_tables.html freetype/src/truetype/ttobjs.c freetype/builds/unix/config.guess freetype/include/freetype/config/ftconfig.h freetype/docs/reference/ft2-glyph_management.html freetype/src/autofit/aflatin.c freetype/src/raster/ftraster.c freetype/builds/win32/visualc/index.html freetype/builds/wince/vc2005-ce/index.html freetype/docs/reference/ft2-version.html freetype/docs/reference/ft2-gx_validation.html freetype/docs/reference/ft2-multiple_masters.html freetype/src/cff/cffgload.c freetype/docs/reference/ft2-base_interface.html freetype/docs/reference/ft2-header_file_macros.html freetype/builds/win32/vc2005/index.html freetype/src/cid/cidgload.c freetype/docs/reference/ft2-ot_validation.html freetype/builds/unix/unix-cc.in freetype/builds/wince/vc2005-ce/freetype.vcproj freetype/src/base/ftsynth.c freetype/src/winfonts/winfnt.c freetype/devel/ftoption.h freetype/builds/win32/vc2005/freetype.vcproj freetype/docs/reference/ft2-index.html freetype/builds/win32/vc2008/freetype.vcproj freetype/src/cache/ftcsbits.c freetype/docs/reference/ft2-outline_processing.html freetype/docs/reference/ft2-lzw.html freetype/src/truetype/ttpload.c freetype/src/smooth/ftgrays.c freetype/builds/win32/visualc/freetype.dsp freetype/src/truetype/ttinterp.c freetype/docs/reference/ft2-module_management.html freetype/src/cff/cffload.c freetype/docs/reference/ft2-user_allocation.html freetype/src/base/ftstream.c freetype/src/truetype/ttinterp.h freetype/builds/unix/configure.raw freetype/docs/reference/ft2-type1_tables.html freetype/src/sfnt/ttpost.c freetype/builds/win32/vc2008/index.html freetype/src/cff/cffobjs.c freetype/docs/reference/ft2-font_formats.html freetype/builds/wince/vc2008-ce/freetype.vcproj freetype/docs/reference/ft2-incremental.html freetype/src/smooth/ftsmooth.c freetype/ChangeLog freetype/docs/VERSION.DLL freetype/docs/reference/ft2-truetype_engine.html freetype/include/freetype/ftcache.h freetype/docs/reference/ft2-list_processing.html freetype/docs/reference/ft2-gzip.html freetype/README freetype/include/freetype/ftmodapi.h freetype/docs/CHANGES]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-10T055109.780940Z"></a>
-2010-10-10T05:51:09.780940Z regression</strong></p>
-<blockquote>
-<pre>
-Various minor fixed to the local cluster code:
-
-clustermonitor.pl now deals with terminal windows being resize
-clustermaster.pl logs messages to clustermaster.log
-build.pl now adds -dcupsColorSpace=0 to command line
-run.pl now longer runs fuzzy after bmpcmp
-
-</pre>
-<p>[toolbin/localcluster/clustermonitor.pl toolbin/localcluster/clustermaster.pl toolbin/localcluster/build.pl toolbin/localcluster/run.pl toolbin/localcluster/compare.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-08T144218.915016Z"></a>
-2010-10-08T14:42:18.915016Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Process text in Tr 3 even if the Widths are non-standard
-
-Bug #691605 &quot;Invisible text not preserved by pdfwrite&quot;
-
-The problem was that if text in text rendering mode 4 (neither stroke nor fill) used a
-font where the entries in the FontDescriptor /Widths array did not match the actual
-widths in the font, the code took a path where the glyphs were not added to the 'used'
-list, and so were never emitted.
-
-Text in regular fonts where the /Widths array was missing, or matched the widths in the
-font (as the spec says they must) worked correctly.
-
-Fixed by processing text whose operation properties include TEXT_RENDER_MORE_3 the
-same as text with the TEXT_DO_DRAW property.</pre>
-<p>[base/gdevpdte.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-08T134241.451688Z"></a>
-2010-10-08T13:42:41.451688Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Remove an unused variable (flagged by static analysis).
-</pre>
-<p>[base/gdevpsdi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-08T133705.002251Z"></a>
-2010-10-08T13:37:05.002251Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Prevent a possible attempt to memset a NULL pointer. This was probably safe since the
-size of the memset would be 0 bytes, but its best to be safe.
-</pre>
-<p>[base/gdevpdtt.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-08T133400.715868Z"></a>
-2010-10-08T13:34:00.715868Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Remove an unused variable (flagged by static analysis)</pre>
-<p>[base/gdevpdfi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-08T133111.163393Z"></a>
-2010-10-08T13:31:11.163393Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-A stringwidth operation does not always result in a call to fapi_finish_render()
-which can cause Freetype glyph objects to not be freed.
-
-Add a firewall so we don't simply overwrite the pointer to the Freetype glyph
-object, but correctly dispose of the object.
-
-Bug 691668
-
-No cluster differences expected.
-
-</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-08T120124.908534Z"></a>
-2010-10-08T12:01:24.908534Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Check encoding compatibility when finding base fonts
-
-Bug #691656 &quot;crash in Chinese font: /typecheck in --.FAPIBuildGlyph--&quot;
-
-A typecheck error is not a crash of course, but when using the built in font interpreter
-this did not produce an error, silently discarded the text instead. This was still
-incorrect.
-
-The problem is caused when dealing with type 0 fonts and producing multiple type 1 fonts
-to handle the large number of glyphs. The code for finding an existing font (in order
-to minimise the number of new fonts) or create a new font, did not consider the
-encoding of an existing font when trying to match it (this did work for regular fonts).
-
-This could lead to a font with an incompatible encoding being used, which caused an
-error later in text processing where a routine is supposed to be guaranteed no font
-encoding problems. That led to an attempted fallback to the 'bitmapped type 3 font'
-solution, but the text processing was passing ridiculous values to the font interpreter.
-
-In the old font code this caused a silent discard of the text, with the FreeType code
-it produces an error.
-
-Fixed by checking the base font we find to see if its encoding is compatible with the
-current text encoding, and manufacturing a new font if it is not.
-
-No differences expected.
-</pre>
-<p>[base/gdevpdtt.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-08T050927.837431Z"></a>
-2010-10-08T05:09:27.837431Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix for miscalculation of clist_color_info.depth when tags are part of
-the PDF14 device color. While 8 * num_components is usually enough, when
-we have tags, we need the extra byte. Seen with fts_16_1601.pdf in clist
-mode on HEAD and with customer 532 code when PDF14_transparency + tags is
-included.
-</pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-07T135949.890609Z"></a>
-2010-10-07T13:59:49.890609Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Put back some statements. It turns out that we can either have gcc be warning free or
-the static analysis warning free. The problem is gs_note_error which uses
-gs_log_error, on a release build gs_log_error is defined as the error value.
-
-If we don't do something with that value then gcc complains that the 'statement has no
-effect'. So the code was set like this:
-
-ecode = gs_note_error(error code);
-
-But if we want to actually ignore the error and just note the problem, then we don't use
-ecode and the static analysis complains that the variable is unused....
-
-I'd rather have no warnings from gcc so I've restored that.
-</pre>
-<p>[base/gdevpdfj.c base/gdevpdfp.c base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-07T124954.318945Z"></a>
-2010-10-07T12:49:54.318945Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-More changes to silence static analysis warnings. Mostly removing unused variables or
-assignments.
-</pre>
-<p>[base/gdevpdfj.c base/gdevpdfm.c base/gdevpdfp.c base/gdevpdtb.c base/gdevpdtc.c base/gdevpdtd.c base/gdevpdtt.c base/gdevpdtf.c base/gdevpdfu.c base/gdevpdti.c base/gdevpdfi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-07T083558.544234Z"></a>
-2010-10-07T08:35:58.544234Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Silence (hopefully) some compiler warnings.
-</pre>
-<p>[base/gdevpdf.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-07T080415.270260Z"></a>
-2010-10-07T08:04:15.270260Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Remove some unused variables and assignments flagged by static analysis.</pre>
-<p>[base/gdevpdfg.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-07T075743.664608Z"></a>
-2010-10-07T07:57:43.664608Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix a potential NULL pointer dereference flagged by static analysis.
-
-Other potential occurrences flagged by the analyser in this module are deemed not to be
-possible, as these are picked up at a higher level.
-
-For instance, dereferencing a pointer to a path structure in a path handling method. We
-can assume the path pointer is not NULL as we would not be called if the path was empty.
-</pre>
-<p>[base/gdevpdfd.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-07T075009.274081Z"></a>
-2010-10-07T07:50:09.274081Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Static analysis discovered two variables being altered that are not subsequently used.
-Although this is safe, removed the code anyway.
-</pre>
-<p>[base/gdevpdfb.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-07T074913.279339Z"></a>
-2010-10-07T07:49:13.279339Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-static analysis found that the result of fread was not being used. Add code to test the
-result and flag a warning if expected data not read.</pre>
-<p>[base/gdevpdf.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-06T140332.653153Z"></a>
-2010-10-06T14:03:32.653153Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix for part 2 of Bug 691484, valgrind warnings about uninitialised values
-in clist code.
-
-The problem is that we are writing out a cmd_block without initialising it all.
-The fix is simply to initialise it (using a memset, so accounting for all
-padding bytes too) before starting to use it.
-
-This stops the valgrind warnings. No changes in localcluster testing.
-
-
-</pre>
-<p>[base/gxclist.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-06T134815.425458Z"></a>
-2010-10-06T13:48:15.425458Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Add some body parentheses to 'if' statements in order to silence some clang warnings.
-</pre>
-<p>[base/gdevpdfp.c base/gdevpdtf.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-06T120646.017717Z"></a>
-2010-10-06T12:06:46.017717Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Whitespace tweaks to gxiscale.c. The complexity in the file is more than
-enough for my tiny brain without expecting it to cope with inconsistent
-indentation too :)
-
-</pre>
-<p>[base/gxiscale.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-05T213811.272406Z"></a>
-2010-10-05T21:38:11.272406Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix for part 1 of bug 691484 - uninitialised memory usage in clist code.
-
-The FAPI code copies bitmaps and pads them out so that each raster line
-is appropriately aligned. Previously the padding bytes were left
-uninitialised. Unfortunately the clist code reads the padding when
-compressing the bitmaps, which a) upsets valgrind and b) means that the
-exact size of the clist will vary from run to run.
-
-Here we tweak the copying code to ensure that the padding bytes are always
-set to zero.
-
-No differences shown in local cluster. This solves part 1 of the bug.
-
-
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-05T202754.714250Z"></a>
-2010-10-05T20:27:54.714250Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Clean up of a few comments about device profiles</pre>
-<p>[base/gsicc_manage.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-05T201810.046358Z"></a>
-2010-10-05T20:18:10.046358Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for error in detecting the presence of a device profile set in the
-command line. Unfortunately, the device was not being reset from the
-default profile based upon the setting.</pre>
-<p>[base/gsicc_manage.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-05T135722.688207Z"></a>
-2010-10-05T13:57:22.688207Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Add missing decoding of #nn escape to encrypted PDF reader. Besides fixing the
-bug sample file, this patch also corrects a colorant name in IA3Z0440.pdf on
-psdcmyk device. Bug 691636.
-</pre>
-<p>[Resource/Init/pdf_sec.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-05T124816.473671Z"></a>
-2010-10-05T12:48:16.473671Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : ConvertCMYKImagesToRGB not working
-
-Bug #691647 &quot;-dConvertCMYKImagesToRGB no longer works&quot;
-
-Originally caused by the conversion to the ICC workflow, which meant that all images
-appear to be in a ICC space, and only images originally natively CMYK are converted.
-
-Probing the ICC space using the provided utility to return the original colour space
-allows the code to work, but reveals a more serious error. The code in
-psdf_setup_image_filteres() alters the image colour space and decrements the reference
-count of the original colour space.
-
-This seems logically correct, and in one of the three calling paths it is correct, but
-under one of the other two conditions it causes a crash. The routine
-pdf_begin_typed_image_impl() makes two copies of the original image parameters, and
-when it does so it does *not* increment the reference counts of any counted objects.
-This copied data is presented to the image filter setup several times, and if CMUK
-to RGB conversion is going on the original colour space is decremented each time. This
-leads to obvious problems.
-
-The simplest solution would be to increment the reference counts when the copy is made,
-but that would mean checking all the error condition break outs, and decrementing the
-reference count in each case.
-
-Since the colour space is only decremented in the filter setup, this patch increments
-the count before the call, and if the colour space is the same afterwards (whether
-an error occurred or not) decrements it back again. If the colour space changes we do
-not decrement the space of course, as the filter setup routine has done that.
-
-In addition, extended the test for whether CMYK images should be converted to include
-the original test of the native space, in case we get here after an image has been
-converted to a base space and no longer has an ICC space.
-
-No expected differences, this configuration is not tested by the regression suite.
-</pre>
-<p>[base/gdevpsdi.c base/gdevpdfi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-05T121046.672154Z"></a>
-2010-10-05T12:10:46.672154Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix for part 1 of Bug 691635, supplied by Norbert Janssen. Many thanks.
-
-In the recent work to remove global variables where possible, I had failed to
-change an instance of iodev_default to be iodev_default(mem).
-
-No expected changes.
-
-</pre>
-<p>[base/gsiodisk.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-03T161300.326561Z"></a>
-2010-10-03T16:13:00.326561Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Change the order of operands in a logical expression to avoid dereferencing
-an uninitialized variable. Bug 690214.
-</pre>
-<p>[psi/zfont2.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-01T193606.952768Z"></a>
-2010-10-01T19:36:06.952768Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Drop support for these less popular compilers. This will be the first step to
-changing to project files for Windows.
-</pre>
-<p>[base/wctail.mak base/watclib.mak base/bcwin32.mak base/gp_iwatc.c base/watcw32.mak base/wccommon.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-10-01T025815.408387Z"></a>
-2010-10-01T02:58:15.408387Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Replace sequential CFF parser coded in PostScript with a parser that uses
-direct access to the data and coded in C. Solve numerous problems caused by
-the old parser. New -dOLDCFF option can revert to the old parser. Differences
-in 16-01.PS.pdf and 16-01.PS.pdf are progressions.
-</pre>
-<p>[doc/Use.htm psi/int.mak psi/zfont1.c psi/zfont2.c Resource/Init/gs_cff.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-29T155022.840688Z"></a>
-2010-09-29T15:50:22.840688Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix calculation of offset to tag plane in pdf14_mark_fill_rectangle to cure
-writing past the end of an allocated buffer. Detected with customer 532 on
-fts_08_0808.pdf. Only affects devices with object tagging (bitrgbtags).
-</pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-28T123641.051799Z"></a>
-2010-09-28T12:36:41.051799Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Don't unreasonably limit the PDF output level
-
-Bug #691318 &quot; -dCompatibilityLevel=1.6 produces PDF 1.5&quot;
-
-Although the highest output level for pdfwrite features is 1.5, it is possible to use
-pdfmarks to create a PDF file which uses higher level features. In this case its
-reasonable to have pdfwrite produce a higher level PDF file.
-
-This patch allows pdfwrite to produce output up to PDF 1.7, the highest currently
-specified.
-
-No differences expected.
-</pre>
-<p>[base/gdevpdfp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-28T122613.182021Z"></a>
-2010-09-28T12:26:13.182021Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : allow for UserPasword and OwnerPassword in page device
-
-Bug #691256 &quot;OwnerPassword and UserPassword don't work as device parameters&quot;
-
-pdfwrite sets up encryption filters when the device is opened, and the device is not
-(currently) closed until Ghostscript shuts down. This means that changes to the page
-device dictionary which require a restart (eg the encryption parameters) do not affect
-the current setup, though they may be (incorrectly) written when the device is closed.
-
-This patch addresses the specific issue of OwnerPassword by closing the device if the
-password is changed *and* we have not yet written any pages. If we have already begun
-the output when a password change occurs then we ignore it and flag a warning.
-
-This is also a first step in the direction of making pdfwrite open and close properly
-so that we don't need to restart Ghostscript to use it.
-
-No expected differences.
-</pre>
-<p>[base/gdevpdfp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-27T120517.449032Z"></a>
-2010-09-27T12:05:17.449032Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (Fonts): Prevent xfont being used in composefont
-
-On platforms supporting X-Windows xfonts can be used with Ghostscript, however we don't
-want to find an xfont (eg Courier) when using composefont to create a CID-Keyed instance
-as this will not work.
-
-Test to see if the top level font is a type 0, and if it is, don't search for a matching
-xfont, but instead go through the usual PostScript machinery.
-
-No differences expected.
-</pre>
-<p>[base/gxchar.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-27T093355.410495Z"></a>
-2010-09-27T09:33:55.410495Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite/ps2write) : Don't dereference mask colour spaces
-
-Bug #691106 &quot;-sDEVICE=pdfwrite -dConvertCMYKImagesToRGB=true&quot;
-
-When checking to see if an image needs to be converted to RGB, the image space is
-checked to see if it is CMYK. However an image mask does not have a colour space (it
-is NULL), firstly so that we can tell its an image mask, and secondly because masks
-genuinely do not have a colour space, they take on the current colour.
-
-Attempting to dereference the NULL colour space causes a crash. Since a mask never
-needs converting to RGB, we short circuit the test by detecting a NULL colour space.
-
-</pre>
-<p>[base/gdevpsdi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-25T020822.451780Z"></a>
-2010-09-25T02:08:22.451780Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-For long time ps2pdf*.bat files failed when they were used with some
-options and a single argument. findstr is now used to identify
-options by the leading '-' and handle this case. Bug 691622.
-</pre>
-<p>[lib/ps2pdf.bat lib/ps2pdf12.bat lib/ps2pdf13.bat lib/ps2pdf14.bat]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-24T132507.243032Z"></a>
-2010-09-24T13:25:07.243032Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-For disk based TTFs, only lookup the character code in the TTF cmap if the font is
-not using an Identity ordering.
-
-No cluster differences expected.
-
-Bug 691623.
-
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-24T090334.206583Z"></a>
-2010-09-24T09:03:34.206583Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (TrueType fonts) : memory leak
-
-Bug #691088 This does not affect the PostScript/PDF interpreters which now use FreeType
-but is relevant still for XPS and PCL.
-
-A buffer was allocated to contain the GSUB table from the TT font, but was never freed
-leading to memory leaks. I've adopted the same approach as that taken for the 'glyph
-length' array and added a notification procedure which is called when the font is
-released, and that procedure frees the GSUB buffer.
-
-At the same time, removed the functions:
-add_quadratic_curve
-append_simple
-check_component
-
-These were only called by each other, or by append_component which had already been
-removed as unused.
-
-No expected differences.
-</pre>
-<p>[base/gstype42.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-24T032745.689228Z"></a>
-2010-09-24T03:27:45.689228Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Removal of debug code that was accidentally committed.</pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-23T194527.249371Z"></a>
-2010-09-23T19:45:27.249371Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix so that objects tag information makes it through transparency rendering
-AND the clist. An issue was that the pdf14 encode and decode procedures are
-used as opposed to the target device encode and decode procedures and it is
-through a value in the color index that we currently communicate the object
-type through the clist. When we are in page rendering mode, it is easy to
-get the current object from mem-&gt;gs_lib_ctx-&gt;BITTAG, but this is not set
-correctly in clist rendering if for example a glyph is stored in the clist as a
-mask fill. Instead the information about the object is extracted from the color
-index. So, to make this work, we had to introduce an encode method for the
-pdf14 device that incorporates the tag information and also make sure that the bit
-depth for the pdf14 color info value is incremented appropriately so that the extra
-byte is stored and extracted from the clist. The object type is then recovered
-during the pdf14 mark fill rect procedure. This was tested with the updated
-bitrgbtags device using a custom file that has overlapping text, image and path
-objects with varying transparency amounts. </pre>
-<p>[base/gdevp14.c base/gsimage.c base/gsutil.h base/gstext.c base/gsdps1.c base/gdevbit.c base/gdevmem.c base/gxblend1.c base/gspaint.c base/gdevddrw.c base/gsutil.c base/gxclrast.c base/gxblend.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-23T144650.766627Z"></a>
-2010-09-23T14:46:50.766627Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Final part of the fix for bug 691612.
-
-Currently the code blindly sets the &quot;lop_pdf14&quot; whenever the pdf14 device is
-in use. This forces the 'lop_is_idempotent' test to fail, which in turn forces
-slower cases to be taken through the code.
-
-This patch alters that logic, so that the pdf14 device can leave that bit
-unset if the parameters are set up in such a way that the lop really can
-be idempotent (i.e. normal blending, solid alphas etc).
-
-This vastly improves the speed of rendering non-alpha content, so we are no
-longer penalised for having just a small amount of transparent content on a
-page.
-
-Testing shows 398 files that change, but bmpcmp reveals these all to be very
-small changes to do with whether individual pixels are filled or not. This
-is consistent with the typical mismatches between special case and normal
-renderings, so can safely be ignored for now.
-
-
-</pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-23T121757.296649Z"></a>
-2010-09-23T12:17:57.296649Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-As part of the investigation into bug 691612, we noticed that the clist
-band playback code doesn't call the device stroke_path method, but instead
-calls the default implementation directly.
-
-In order the fix the bug, we'd like it to call through the device version
-(pdf14_stroke_path). Consensus is that it's an oversight that it's not calling
-the device version already, and tests indicate no differences (*) so this
-patch changes it to call via the vector.
-
-(* Actually regression testing shows 2 pdfwrite differences, but they are
-in unbanded tests, so can't be executing this code, so are probably just
-indeterminisms).
-
-</pre>
-<p>[base/gxclrast.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-23T104633.821569Z"></a>
-2010-09-23T10:46:33.821569Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-As part of the investigation into bug 691612, a problem was found with the
-rop3_is_idempotent (and hence lop_is_idempotent) macros. This patch fixes
-this definition and adds some more comments explaining the rop operations.
-
-Thanks to lpd for confirming this change.
-
-This produces 78 differences in the regression tests, bmpcmp reveals these to
-all be neutral or progressions (in some cases, significant progressions).
-
-
-</pre>
-<p>[base/gsropt.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-23T081636.207911Z"></a>
-2010-09-23T08:16:36.207911Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Do not write Encodings with Symbolic TrueType fonts
-
-Bug #690744, #691036, #691319. The PDF specification makes it clear that Symbolic
-TrueType fonts should not have a FontDescriptor which contains an Encoding entry.
-pdfwrite has specifically been doing this, the reason being (code comments) :
-
-* We write True Types with Symbolic flag set.
-* PDF spec says that &quot;symbolic font should not specify Encoding entry&quot;
-* (see section 5.5, the article &quot;Encodings for True Type fonts&quot;, paragraph 3).
-* However Acrobat Reader 4,5,6 fail when TT font with no Encoding
-* appears in a document together with a CID font with a non-standard CMap
-* (AR 4 and 5 claim &quot;The encoding (CMap) specified by a font is corrupted.&quot;
-* (we read it as &quot;The encoding or CMap specified by a font is corrupted.&quot;,
-* and apply the 1st alternative)). We believe that AR is buggy,
-* and therefore we write an Encoding with non-CID True Type fonts.
-* Hopely other viewers can ignore Encoding in such case. Actually in this case
-* an Encoding doesn't add an useful information.
-
-Since this is working around a bug in old versions of Acrobat, and the presence of an
-Encoding causes preflight errors and is specifically forbidden in PDF/A, this work
-around has been removed. I would like to check recent versions of Acrobat to see if
-this issue persists, but am unable to find an example file. The change predates the
-adoption of Subversion, the first logged change is October 2003.
-
-</pre>
-<p>[base/gdevpdtt.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-22T151320.906048Z"></a>
-2010-09-22T15:13:20.906048Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Removed unused label from base/gxicolor.c that caused compiler warning.
-
-Fixes Bug #691633 reported by Norbert Janssen.
-
-</pre>
-<p>[base/gxicolor.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-21T120352.655546Z"></a>
-2010-09-21T12:03:52.655546Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Add the new entries for produce outlines and maximum bitmap size
-to the FAPI server declarations in the UFST and Bitstream code.
-
-No cluster differences expected.
-
-Bug 691634
-
-</pre>
-<p>[psi/fapiufst.c psi/fapibstm.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-20T012614.070109Z"></a>
-2010-09-20T01:26:14.070109Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Fix end-of-file detection in reusable streams. Don't try to read non-existing
-blocks after the last one. Just return EOF flag and the data that are already
-in the buffer. Bug 691625.
-</pre>
-<p>[psi/zfrsd.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-17T102936.728794Z"></a>
-2010-09-17T10:29:36.728794Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-In revision 11723 I'd copied a prototype, but forgotten to edit the name.
-(bytes_copy_rectangle to bytes_copy_rectangle_zero_padding).
-This was resulting in a couple of warnings about 'no previous prototype'.
-
-No expected differences.
-
-</pre>
-<p>[base/gsbitops.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-17T064427.206613Z"></a>
-2010-09-17T06:44:27.206613Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Removal of unused variable introduced in last commit.</pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-17T054048.428712Z"></a>
-2010-09-17T05:40:48.428712Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Addition of support to enable persistence of objects tag information through
-transparency rendering. In the current code base, transparency blending
-erases all knowledge about the objects that were drawn and blended, setting
-the entire object to image type. With this commit, the tag information is
-retained through blending by doing a bit-wise or of the tag values. When a
-evice supports tags, the pdf14 device will create an additional plane to
-maintain the tag data information. Blending of the tag information occurs
-in pdf14_mark_fill_rectangle, pdf14_mark_fill_rectangle_ko_simple and
-pdf14_compose_group. A new device procedure called put_image is added.
-This is called by the pdf14_put_image operation, which enables the communication
-of the tag information to the target device. pdf14_put_image will first attempt
-to pass the alpha channel and the image data not scaled by the alpha channel and
-the tag data to the target device. The planar offset location of the alpha and
-tag data is communicated in the put_image procedure interface. If the target
-device cannot handle this form of the data, it should return 0. The
-pdf14_put_image operation will then blend the alpha data and attempt the
-put_image again but this time with an alpha offset of 0 to indicate that there
-is no alpha data. Note that the alpha data remains valid for those devices that
-still want the alpha but also want to have the graphics library do a premultiplcation
-of the alpha with the data. Details of this interface will be added to the documentation.
-In addition, the bitrgbtags device is being updated to demonstrate the use of the
-put_image procedure.</pre>
-<p>[base/gdevp14.c base/gxdevcli.h base/gxclist.c base/gdevp14.h base/gdevbbox.c cups/gdevcups.c base/gsovrc.c base/gxblend.c base/gxblend1.c base/gdevprn.c base/gsutil.c base/gxblend.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-16T145706.777148Z"></a>
-2010-09-16T14:57:06.777148Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Fix a problem introduced by the rev. 11497 that broke ps2pdf*.bat scripts
-when they receive optional arguments. The bug results from interaction between
-&quot;shift&quot; and %~dp0 that is used after the &quot;shift&quot;.
-</pre>
-<p>[lib/ps2pdf.bat lib/ps2pdf12.bat lib/ps2pdf13.bat lib/ps2pdf14.bat]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-16T110931.082242Z"></a>
-2010-09-16T11:09:31.082242Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Another partial fix for Bug 690993. The sole remaining Valgrind warning
-is that memcpy is called on overlapping src/dst blocks in cmd_read_data.
-
-Investigation supports this, and suggests that we should be using memmove
-instead. This does stop the error, and leaves us valgrind warning free.
-
-This also appears to resolve the indeterminism, in that repeated runs
-of the command line given in the bug return identical results.
-
-The bug remains open though, as there is still a mismatch between banded and
-non-banded mode.
-
-No expected differences.
-
-</pre>
-<p>[base/gxclrast.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-16T110547.689000Z"></a>
-2010-09-16T11:05:47.689000Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Partial 'fix' for Bug 690993. When encoding a bitmap into a clist, we
-copy it into a block with potentially larger padding requirements. These
-extra padding bytes were left undefined, causing subsequent attempts to
-compress the bitmap to cause valgrind to give warnings.
-
-The fix is simply to introduce and use a new function that copies a bitmap
-and zeros the padding. This should eliminate the warnings, produce better
-compression, and (more importantly) mean that every run uses the same amount
-of memory, hence eliminating potential odd effects where clists may be of
-different lengths on different runs.
-
-This still leaves bug 690993 open.
-
-No expected differences.
-
-</pre>
-<p>[base/gsbitops.c base/gsbitops.h base/gxclbits.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-15T081552.075230Z"></a>
-2010-09-15T08:15:52.075230Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (ps2write) : Bug #689419 &quot;Text missing if nested BT with opdfread.ps&quot;
-
-Type 3 fonts which select another font and then draw text from it (a common feature of
-Quark Xpress) can result in nested 'BT' operators when processed by ps2write.
-
-The opdfread prologue does not cater for this, specifically the TextMatrix is not saved
-and restored around a BT/ET pair. If the text matrix is altered by the font
-selection, then the 'ET' will not restore the old matrix leading to incorrectly sized or
-disappearing text.
-
-The patch (supplied by SaGS) saves the TextMatrix in a stack (stored in an array) and
-restores the matrix after an ET, in case it is nested. Currently this allows for
-nesting up to 20 deep, which should be more than adequate. Note that if we were to
-encounter a nested BT with no ET this would still fail, but in this case the file
-produced by ps2write would be invalid, and the missing ET should be fixed.
-
-No differences expected, the regression suite doesn't test ps2write.
-</pre>
-<p>[Resource/Init/opdfread.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-14T125809.089527Z"></a>
-2010-09-14T12:58:09.089527Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Don't colour convert SMask images
-
-Bug #690612 &quot;PDF sRGB conversion loses images&quot;
-
-The handling of SMask images in pdfwrite is a bit convoluted. These are handled by
-converting initially to a DevicePixel colour space, then detecting that later and
-replacing with a DeviceGray space. However, after doing so, if ColorConversionStrategy
-was set, the space (and image samples) would be converted to another colour space. This
-is not legal for SMask images.
-
-This code simply checks to see if the image is an SMask before setting colour conversion
-and doesn't convert the colour space/samples if it is and SMask.
-
-No expected differences.
-</pre>
-<p>[base/gdevpdfi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-14T090706.998296Z"></a>
-2010-09-14T09:07:06.998296Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix a compiler warning.</pre>
-<p>[base/gdevpdfo.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-14T080603.949247Z"></a>
-2010-09-14T08:06:03.949247Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-pdfwrite enhancement : performance improvement with type 3 fonts
-
-Bug #690575 &quot;PS to PDF Conversion extremely slow (possibly endless)&quot;
-
-The type 3 font code assembles CharProcs for type 3 fonts by writing them individually
-into a 'cos_stream'. Each time a new one is completed it is compared to all the existing
-CharProcs to see if it is a duplicate. This was done by fseek/fread/memcmp operations.
-
-As the number of CharProcs increases, the time spent seeking, reading and comparing
-the data increases dramatically and performance becomes very poor. Not only that, but
-the test is actually done twice for each new CharProc.
-
-This patch tackles the problem by creating an md5 hash of the data written to a
-cos_write_stream (a subclassed cos_stream) as it is written. The cos_stream 'equal'
-routine checks to see if the md5 hash is valid and if it is then compares the hashes.
-If the md5 hash is not valid (ie not a cos_write_stream) then it uses the old
-seek/read/compare mechanism. This will improve the performance of any stored data
-if it is stored using a cos_write_stream and compared against other data of the same
-type. (I don't believe we do this anywhere else currently, but I'm not suer)
-
-This does improve the performance significantly, and the code no longer spends most of
-its time waiting for I/O operations to complete. It is still slow, but this is the
-result of using lots of type 3 fonts. Because of the way these must be processed in
-order to capture the outlines they are never going to be fast.
-
-In my test this runs 2-3 times faster than before. There should be no differences in
-output from the old code.
-</pre>
-<p>[base/gdevpdfo.c base/gdevpdfo.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-14T074911.816447Z"></a>
-2010-09-14T07:49:11.816447Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Bump version number to 9.01 and associated changes.
-
-</pre>
-<p>[base/gscdef.c base/version.mak Resource/Init/gs_init.ps]</p>
-</blockquote>
-<hr size=20>
-
-<h2><a name="Version9.00"></a>Version 9.00 (2010-09-14)</h2>
-
-<p>This is the first release in the stable 9.x series.
-
-<p>This release includes a move to an ICC-based color rendering workflow. The
-design allows easy integration of 3rd party color management modules (CMMs)
-and management of DeviceN and spot source colors with ICC profiles as well
-as with non-ICC proprietary methods. The default CMM is the well known littleCMS.
-Postscript color objects and non-ICC CIE-based PDF color spaces are converted to
-equivalent ICC profiles enabling complete color management for all color spaces by
-an ICC-based CMM. New command line options enable the specification of gray, rgb
-and cmyk default ICC profiles as well as output device ICC profiles. The new
-work flow provides performance improvements in the rendering of images, shadings
-and transparencies. In addition, the color conversions are designed to work
-efficiently in multithreaded display list (c-list) rendering through the use of a
-shared link cache. Finally, proper ICC based rendering now occurs for ALL XPS
-objects including Named colors, N-Channel colors and images with internally embedded
-ICC profiles.
-
-<p>The second major change in this release is that glyph rendering for all font types
-except Type 3 is now handled by Freetype (via a much improved and enhanced Font API).
-The most obvious benefit of this is a complete, and proven implementation of the
-TrueType byte code interpreter (now unencumbered by patents).
-
-<p> Another major change is that the Postscript interpreter's graphics state now
-stores two separate colour space settings for stroking and filling, to better
-support the stroke and fill colours required by the PDF interpreter.
-
-<p>Finally, support for optional content has been added to the PDF interpreter.
-
-<p> This release also includes a number of improvements to the pdfwrite device
-to improve reliability and quality with PCL and XPS input. Many improvements to
-the support of JPX images in PDF files, PDF annotation rendering and the usual
-number of general bug and robustness fixes.
-
-<p>For security reasons, Ghostscript no longer searches the current directory
-by default. Use -P option to revert to old behavior.
-
-<p>For a list of open issues, or to report problems with this release,
-please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-
-<h3><a name="9.00_Incompatible_changes"></a>Incompatible changes</h3>
-
-<p>
-No recorded incompatible changes.
-
-<h3><a name="9.00_Changelog"></a>Changelog</h3>
-
-<p><strong><a name="2010-09-13T150940.310889Z"></a>
-2010-09-13T15:09:40.310889Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Commit the missing header changes from the previous checkin.
-</pre>
-<p>[psi/ifapi.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-13T145346.788657Z"></a>
-2010-09-13T14:53:46.788657Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Another revision of the FAPI code. Due to a problem in Freetype which needs
-further investigation, we cannot produce an outline, then decide to produce
-a bitmap if it is small enough. We work around this by producing a bitmap,
-and if it is too large, dispose of it, and retry with an outline, thus although
-we still risk larger than ideal memory use, it is very short lived. A glyph
-too large to be cached (for which we will now usually use an outline) does
-not suffer from the Freetype issue mentioned above.
-
-The maximum allowable bit for Freetype to produce is now 1.5 x the maximum
-cache bitmap as set in the Postscript state - it is set larger than the
-cache bitmap since it is *vital* that if GS expects a bitmap to be cache
-we supply a bitmap. Given that the bounding boxes arrived at the GS cache
-device and the Freetype rendering code arrived at slightly differently, there
-would be the chance of edge cases where FAPI would produce an outline, when
-the cache expects a bitmap. Allowing FAPI plenty of leeway avoids that.
-
-The calculation to convert a quadratic to a cubic spline in the
-Freetype interface code was slightly wrong.
-
-Also, FAPI now sets the fill adjust to 0 for filling outline glyph, instead
-of inhereting the value from the originating graphics state, which gives
-*much* more consistent output between the bitmap and outline cases, and
-addresses the slightly excessive boldness observed for outline glyphs since
-the adoption of Freetype/FAPI as the default font scaler/renderer.
-
-Finally, support for the existing Ghostscrit text anti-aliasing
-capability is improved.
-
-Bug 691604
-
-</pre>
-<p>[psi/fapi_ft.c psi/zfapi.c psi/fapiufst.c psi/fapibstm.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-13T102534.372202Z"></a>
-2010-09-13T10:25:34.372202Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Revert revisions 11690 and later from the FAPI code (and revert version no. to 9.00)
-to get a &quot;good&quot; base version, in preparation for a corrected version of the changes
-in 11690 (and subsequent changes in the FAPI code).
-
-</pre>
-<p>[psi/fapi_ft.c psi/zfapi.c base/version.mak Resource/Init/gs_init.ps psi/ifapi.h psi/fapiufst.c psi/fapibstm.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-09T135148.502020Z"></a>
-2010-09-09T13:51:48.502020Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Fix a case where /Width attribute was not checked for null.
-Bug 691602, customer 700.
-</pre>
-<p>[Resource/Init/pdf_font.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-09T072652.042155Z"></a>
-2010-09-09T07:26:52.042155Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Fix broken version number in gs_init.ps in trunk
-</pre>
-<p>[Resource/Init/gs_init.ps]</p>
-</blockquote>
-
-
-<p><strong><a name="2010-09-09T062654.427296Z"></a>
-2010-09-09T06:26:54.427296Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Add a couple of &quot;.0&quot;s to ensure we get floating point division
-to arrive at intermediate values for the conic to cubic
-spline conversion.
-
-</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-09T034512.738999Z"></a>
-2010-09-09T03:45:12.738999Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for compiler complaint from commit of rev 11700</pre>
-<p>[base/gdevpdfb.c base/devs.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-08T232036.969829Z"></a>
-2010-09-08T23:20:36.969829Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix to enable proper mask filling with patterns that have transparency.
-Major change is in gdevp14.c where begin_type_image and mask_fill procedures
-now will (if we are filling with a pattern that has transparency) push a
-transparency group. When we are finished processing the image, the group is
-popped which enables proper blending. There remains an issue with a special
-file that Ken created when it is run in c-list mode. A new bug will be opened
-for this issue. Thanks to Ray for helping with this project and finding a
-bounding box issue in the creation of the transparency group during c-list
-reading.</pre>
-<p>[base/gdevp14.c base/gxclimag.c base/gsptype1.c base/lib.mak base/gxpcmap.c base/gdevpdfb.c base/gsptype1.h base/gstrans.c base/gxpcolor.h base/gxblend1.c base/gxp1fill.c base/gxp1impl.h base/gdevpdfi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-08T162242.112334Z"></a>
-2010-09-08T16:22:42.112334Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : incorrect pattern matrix calculation
-
-Bug #690504 &quot;ps2write does not work with asymmetric resolutions, like 600x1200dpi &quot;
-
-The problem was caused by frankly totally incorrect calculations when generating the
-/Matrix for a pattern. Because we always see the CTM including the resolution scaling
-but need to output a matrix with this removed, we scale the CTM by the inverse of the
-resolution scaling.
-
-But the calculation simply divided the CTM through by the scale factors, which is
-totally incorrect and fails badly if the matrix involves rotation. The code now
-correctly creates and multiplies a scale matrix. Note, the order of multiplication is
-important here.
-
-No differences expected.
-</pre>
-<p>[base/gdevpdfv.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-08T083015.885002Z"></a>
-2010-09-08T08:30:15.885002Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Slight refinement in the how the FAPI character generation detects we are
-producing anti-aliased glyphs.
-
-Also, it seems that when assigning variable value to a second, larger data
-type, whilst gcc promotes the data type before the assignment, MSVC promotes
-the variable later, so shifting a 32 bit integer up during an assignment to
-a 64 bit integer variable works find on gcc, but MSVC loses the most
-significant bits. So we need to force the promotion to happen with a cast.
-
-Bug 691588
-
-</pre>
-<p>[psi/fapi_ft.c psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-07T165136.404533Z"></a>
-2010-09-07T16:51:36.404533Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Add a further header to ifapi.h required for Unix/Linux builds, and
-add the two additional headers to ifapi.h's dependencies.
-
-</pre>
-<p>[psi/ifapi.h psi/int.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-07T162646.989782Z"></a>
-2010-09-07T16:26:46.989782Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Pull in gp.h in ifapi.h for the int64_t type - it seems to be required on Windows.</pre>
-<p>[psi/ifapi.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-07T153217.143998Z"></a>
-2010-09-07T15:32:17.143998Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Some fairly substantial changes to the FAPI code to get very high resolutions and
-anti-aliased text working reliably.
-
-For AA text, we now make *sure* to produce outlines for non-cached glyphs, thus
-the GS path code can anti-alias correctly (for cached glyphs, the &quot;show&quot; machinery
-does the anti-aliasing from the cache bitmap).
-
-The high res problems were highlighted by the bbox device (which runs at 4000 dpi).
-To resolve these the width and height parameters for Freetype had to have value
-overflow compensation added, to match the existing underflow compensation.
-
-FAPI/Freetype also now will only create a glyph bitmap if the bitmap size is smaller
-than the allowable glyph cache bitmap. It may still produce a bitmap for a non-cached
-glyph, if the cache is full, but the individual glyph bitmap is not larger than the
-allowable glyph item - this is allow for better consistency when we're near the limit
-of the total cache size.
-
-Finally, the FAPI outline retrieval code now requires 32.32 fixed point variables (rather
-than the previous 16.16), which prevents overflow, and improves accuracy. If also provides
-us with the opportunity to check for overflow/underflow of the GS internal fixed point
-variables, before calling the GS path code.
-
-There are quite a few cluster changes. I have checked them all, and one is a progression
-(missing glyphs now render) and the rest are the pixel level differences expected by
-having GS render a path, rather than Freetype - most are due to Freetype grid fitting to
-the glyph bitmap, and GS grid fitting to the page raster.
-
-Bug 691592 - bbox issue
-Bug 691588 - anti-aliasing
-
-
-
-
-</pre>
-<p>[psi/fapi_ft.c psi/zfapi.c psi/ifapi.h psi/fapiufst.c psi/fapibstm.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-06T101425.582663Z"></a>
-2010-09-06T10:14:25.582663Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : string not being re-encoded
-
-Bug #690441 &quot; Files render properly with gs, but are misformatted by ps2pdf&quot;
-
-A Coverity fix in revision 9072 prevented a crash, but also circumvented code that was
-essential to run under some conditions. (This is described by comments in the code as a
-'trick'). The routine created a text string with the encoded text for a font with a
-custom encoding derived from a CIDFont with an unusual CMap.
-
-In order to avoid the potential crash, but still re-encode the string, which is
-essential, the relevant portion of the code has been copied and is exercised instead of
-executing 'pdf_reserve_char_code_in_pdfont()'. This produces the reencoded string we
-need, but if the encoding fails, where we would have caused a crash by dereferencing a
-NULL pointer, we instead return an error.
-
-No differences expected, we obviously don't have a test case in the regression suite.
-</pre>
-<p>[base/gdevpdtt.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-03T154954.010009Z"></a>
-2010-09-03T15:49:54.010009Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix for hang condition in the stream logic for the luratech JPXDecode.
-We need to return EOFC with the final bit of data. Found with PDF 1.7 FTS.
-</pre>
-<p>[base/sjpx_luratech.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-03T083132.767708Z"></a>
-2010-09-03T08:31:32.767708Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-A Type 0 font dictionary in a PDF which contained a spurious FontDescriptor
-object confused the interpreter, which resulted in creating a Font resource
-directly, rather than instantiating the DescendantFonts for the Type 0.
-
-We'll now remove the spurious entry from the Type 0 dictionary, to prevent
-any on-going confusion.
-
-No cluster differences expected.
-
-Bug 691589
-
-</pre>
-<p>[Resource/Init/pdf_font.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-03T072106.059509Z"></a>
-2010-09-03T07:21:06.059509Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-typo, misplaced quote in revision 11684
-</pre>
-<p>[lib/lpgs.bat]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-03T071933.619992Z"></a>
-2010-09-03T07:19:33.619992Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Typo, misplaced quote in revision 11684
-</pre>
-<p>[lib/pdfopt.bat]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-03T065244.087509Z"></a>
-2010-09-03T06:52:44.087509Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-More Windows batch file madness.
-
-Guard all path expansion with quotes, since the Windows command shell processor is too
-stupid to do so, even when expanding variables/arguments itself.
-
-Add a trailing separator to the %TEMP% variable before specifying the filename, as
-apparently some setups don't get a trailing separator by default. A paired separator
-(ie \\) doesn't seem to cause a problem so this ought to be safe even if the setup
-does have a trailing separator.
-
-</pre>
-<p>[lib/pf2afm.bat lib/gsdj500.bat lib/ps2ascii.bat lib/ps2pdfxx.bat lib/lpr2.bat lib/gsndt.bat lib/gstt.bat lib/eps2eps.bat lib/pdf2dsc.bat lib/gsbj.bat lib/ps2epsi.bat lib/gsdj.bat lib/dumphint.bat lib/ps2ps2.bat lib/gsnd.bat lib/font2c.bat lib/pdfopt.bat lib/gst.bat lib/pdf2ps.bat lib/ps2pdf.bat lib/gslj.bat lib/bdftops.bat lib/pfbtopfa.bat lib/ps2pdf12.bat lib/ps2pdf13.bat lib/ps2pdf14.bat lib/lpgs.bat lib/gslp.bat lib/ps2ps.bat lib/pftogsf.bat]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-02T155750.419060Z"></a>
-2010-09-02T15:57:50.419060Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Remove a couple of duplicated font names form the embedding white list, and reduce the
-list length #define appropriately.</pre>
-<p>[base/whitelst.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-02T141539.116953Z"></a>
-2010-09-02T14:15:39.116953Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Include the header file purely to get the prototype for the function, otherwise gcc
-complains.
-</pre>
-<p>[base/whitelst.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-02T135013.043694Z"></a>
-2010-09-02T13:50:13.043694Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-pdfwrite enhancement
-
-The addition of code to test and honour the 'embedding flags' in TrueType fonts has
-led to problems because PostScript producers are embedding type 42 fonts in the
-PostScript which are non-embeddable and worse use a custom non-reversible encoding,
-so that the resulting PDF file has garbage text when a normally encoded font is used
-as a replacement.
-
-It seems that Adobe has published a 'white list' of fonts which have been granted
-at least some embeddable rights. It isn't obvious if these are fonts which were type
-1 (and therefore could be converted to TrueType and get incorrect embedding rights) or
-if the fonts were originally released as TrueType with the wrong embedding rights.
-
-In any event, this list has now been added to pdfwrite; if a font is encountered which
-has restricted embedding, then its name will be checked against this list, if it is
-found in the list then it will be considered as embeddable. We have already
-encountered one font on this list which has a slightly different name to the original
-(a space was removed) so spaces in the font names are ignored.
-
-This list will have to change over time, and we may find other examples of characters
-which we want to handle specially (eg oumlaut treated as o and e)
-
-No differences expected as this is not tested in the current regression suite.
-</pre>
-<p>[base/whitelst.c base/gdevpdtf.c base/devs.mak base/whitelst.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-01T184752.658366Z"></a>
-2010-09-01T18:47:52.658366Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Update the release notes, dates etc for a second 9.00 release candidate
-</pre>
-<p>[doc/History7.htm doc/Projects.htm doc/History8.htm doc/History9.htm man/dvipdf.1 man/ps2ascii.1 doc/Use.htm doc/Readme.htm doc/Source.htm doc/Deprecated.htm man/ps2epsi.1 doc/Install.htm doc/API.htm doc/Issues.htm doc/DLL.htm doc/Drivers.htm man/pfbtopfa.1 doc/Release.htm doc/Commprod.htm doc/Xfonts.htm doc/Devices.htm doc/Language.htm man/gs.1 man/pf2afm.1 doc/Ps2ps2.htm doc/Fonts.htm man/printafm.1 doc/Ps2pdf.htm doc/Develop.htm doc/Helpers.htm man/pdf2dsc.1 doc/Psfiles.htm doc/Lib.htm doc/gs-vms.hlp man/font2c.1 man/gsnd.1 base/version.mak man/pdfopt.1 man/pdf2ps.1 man/ps2pdf.1 doc/Make.htm doc/Details8.htm doc/Details9.htm doc/Unix-lpr.htm doc/C-style.htm doc/Ps-style.htm doc/History1.htm doc/History2.htm man/gslp.1 man/wftopfa.1 doc/History3.htm man/ps2ps.1 doc/Ps2epsi.htm doc/History4.htm man/ps2pdfwr.1 doc/History5.htm doc/History6.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-01T174918.515475Z"></a>
-2010-09-01T17:49:18.515475Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Update the release notes for the second 9.00 release candidate.
-</pre>
-<p>[doc/History9.htm doc/News.htm doc/Details9.htm doc/Details.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-01T135934.488373Z"></a>
-2010-09-01T13:59:34.488373Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Silence some compiler warnings.
-
-Altered a static function to 'void' from 'int' as it returns no values and the callers
-don't test any putative return value.
-
-#ifdef a boolean declaration, as the code which uses it has been #ifdef'ed
-
-Add some parameters to two functions, so that they match the prototypes, the
-parameters are not used in these functions.
-
-</pre>
-<p>[base/gdevpdfk.c base/gdevpdfc.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-09-01T060851.456140Z"></a>
-2010-09-01T06:08:51.456140Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix to avoid issues with subtractive monochrome devices when we have
-transparency. The gray device pdf14 prototype is used in this case.
-VERY limited testing indicates that this fixes a crash with the cups
-device with its default settings and gives proper rendering. More
-complete testing is required to ensure that proper blending is being
-performed and to investigate the other process color models that the
-cups device supports (e.g. cmy). </pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-31T232115.562664Z"></a>
-2010-08-31T23:21:15.562664Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Revert back to having pdfwrite handle what to do with PS color spaces
-instead of using the V4 profile that gsicc_create generates. Also, fix a
-few issues that existed with pdfwrites handling of those spaces, in particular
-adjustments are made for non D50 white points. D50 is the required white point
-for the ICC profile. About 189 pdfwrite test files will report differences.
-I went through them with bmpcmp. Since the profiles that were generated
-differ between gsicc_create and pdfwrite minor color differences exist. In
-addition, there were some regressions that existed, which this revision will
-fix. </pre>
-<p>[psi/zcolor.c base/gdevpdfk.c psi/zimage.c base/gdevpdfc.c base/gsciemap.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-31T153427.935572Z"></a>
-2010-08-31T15:34:27.935572Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : linewidth corruption when Tr is 1
-
-Bug #690436 &quot; (regression) re-distilling pdf causes R graphics to go block-single-color.&quot;
-
-The problem was cause din the pdfwrite-specific text rendering routines. When the text
-render mode is 1 (stroke), the linewidth is adjusted by the current text matrix. However
-the routine to do this is called each time any element of the text 'graphics state'
-changes. So if multiple calls to (eg) Td were made, the linewidth would be altered
-even though there had been no change in 'w'.
-
-Fixed by getting the current linewidth before the text rendering routine, and setting
-it back to this value after the text rendering routine.
-
-No expected differences. However z400454b01d4-1.pdf seems to exhibit some minor
-differences which I am unable to reproduce locally. They are so minor that bmpcmp
-ignores them, and on my tests the PDF files are identical bar the date/time stamps
-and other metadata. I don't believe this is a real difference.
-</pre>
-<p>[Resource/Init/pdf_ops.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-28T220455.196791Z"></a>
-2010-08-28T22:04:55.196791Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Implement rendering of /Highlight annotation. Acrobat always uses transparency
-and ignores appearance streams. Bug 691572, customer 532.
-
-Progressions or minor differences (when the annotation has an appearance
-stream) are observed in annots.pdf, CATX1385.pdf, CATX6166.pdf, CATX6508.pdf,
-CATX7659.pdf, CATX8255.pdf, IA3Z4030.pdf, fts_32_3225.pdf
-</pre>
-<p>[Resource/Init/pdf_main.ps Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-27T135414.847396Z"></a>
-2010-08-27T13:54:14.847396Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : faulty matrix transformations for Pattern dictionaries
-
-Bug #690398 &quot;Geometric issue with pattern&quot;
-The problem is the definition of the default co-ordinate space. When a Pattern is at the
-page level or drawn inside a form, we need to remove our 0.1 scaling in order to return
-to the 'default co-ordinate space'. However, when painted on a form nested inside a
-form, the default co-ordinate space is the parent form, so we don't need to undo
-the scaling.
-
-This is the same problem addressed for shading dictionaries in revision 11347.
-
-</pre>
-<p>[base/gdevpdfv.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-27T121054.938774Z"></a>
-2010-08-27T12:10:54.938774Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : FormDepth not tracked properly.
-
-Part of the fix for Bug#690398. In order to know whether a pattern matrix should be
-converted to the top level CTM, or to an enclosing Form CTM, we track the Form Depth
-by noting when transparency groups begin and end (currently this is the only way to get
-a form output by pdfwrite).
-
-There was a problem with mask groups, because although pdf_begin_transparency_mask calls
-pdf_begin_transparency_group, pdf_end_transparency_mask doe snot call
-pdf_end_transparency_group. This resulted in the depth being incremented at the start
-of the mask, but not decremented at the end, so patterns could be emitted at the page
-level but with the CTM for a Form level, leading to missing content.
-
-Fixed by decrementing the FormDepth appropriately.
-
-</pre>
-<p>[base/gdevpdft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-27T120246.764612Z"></a>
-2010-08-27T12:02:46.764612Z regression</strong></p>
-<blockquote>
-<pre>
-Added the ability to specify which regression test files will only be
-run during nightly regression testing (i.e. not for commit regression
-tests). To skip files add them, one per line, to the nightly_only.lst
-file in the corresponding directory (creating this file if none exists).
-See tests_private/customer_tests/nightly_only.lst for an example.
-
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/readlog.pl toolbin/localcluster/build.pl toolbin/localcluster/run.pl toolbin/localcluster/compare.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-26T233428.641761Z"></a>
-2010-08-26T23:34:28.641761Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Implement rendering of /Squiggly annotation without an appearance stream.
-Bug 691572, customer 532.
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-26T154951.752958Z"></a>
-2010-08-26T15:49:51.752958Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Remove an unused local variable (gcc compiler warning)
-
-No differences expected
-</pre>
-<p>[base/gdevpdf.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-24T213729.611143Z"></a>
-2010-08-24T21:37:29.611143Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Merge a couple of corrections from the 9.00 tag.
-</pre>
-<p>[doc doc/History9.htm doc/News.htm doc/Details9.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-24T203140.602213Z"></a>
-2010-08-24T20:31:40.602213Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Merge doc changes from 9.00 and bump version number to 9.01
-</pre>
-<p>[doc/Projects.htm man/dvipdf.1 man/ps2ascii.1 doc/Use.htm man/ps2epsi.1 doc/DLL.htm doc/Drivers.htm doc/Release.htm man/gs.1 doc/Ps2pdf.htm man/printafm.1 psi/psromfs.mak psi/dxmain.c toolbin/tests/check_dirs.py doc/Helpers.htm psi/dxmainc.c man/gsnd.1 man/pdfopt.1 base/version.mak Resource/Init/gs_init.ps man/ps2pdf.1 man/pdf2ps.1 doc/News.htm doc/Details8.htm doc/Make.htm doc/Unix-lpr.htm doc/Details9.htm doc/History1.htm doc/History2.htm man/wftopfa.1 doc/History3.htm doc/History4.htm doc/Details.htm man/ps2ps.1 doc/History5.htm doc/History6.htm doc/History7.htm doc/History8.htm doc/History9.htm doc/Readme.htm doc/Source.htm doc/Deprecated.htm /trunk/gs doc/Install.htm doc/Changes.htm doc/API.htm doc/Issues.htm man/pfbtopfa.1 doc/Commprod.htm doc/Xfonts.htm doc/Devices.htm doc/Language.htm psi/dmmain.c doc/Fonts.htm doc/Ps2ps2.htm man/pf2afm.1 doc/Develop.htm man/pdf2dsc.1 psi/dmmain.r doc/Psfiles.htm doc/Lib.htm doc/gs-vms.hlp man/font2c.1 doc/C-style.htm doc/Ps-style.htm man/gslp.1 doc/Ps2epsi.htm man/ps2pdfwr.1]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-24T134629.931715Z"></a>
-2010-08-24T13:46:29.931715Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Enhancement - Font copying (pdfwrite)
-
-Bug #691573 &quot; invalidfont in xshow&quot;. The file does in fact contain an invalidfont, the
-type 42 embedded fonts are defined by adding /.notdef to the CharStrings dictionary as
-if it were the Encoding array. The key /.notdef is added 256 times with values ranging
-from 0 to 255. Of course only the last one is actually defined.
-
-This means that when we come to copy the /.notdef glyph for our font copy, the type 42
-GID is 255. However the font does not contain a glyph with GID 255, so the copy of the
-font fails.
-
-Although this is an illegal font, Adobe Acrobat Distiller does produce a PDF file from
-it. In order to duplicate this, code has been added when copying a font. If we fail to
-copy a glyph, and the glyph is /.notdef and the GID is non-zero, we try to copy a glyph
-with GID 0 instead. If that fails we error out, otherwise we use the glyph with GID 0.
-(TrueType font /.notdef glyph has GID 0)
-
-This works for the supplied file but is not, of course, a guaranteed solution since
-another badly formed font may not contain a glyph with GID 0.
-
-No Expected Differences
-</pre>
-<p>[base/gxfcopy.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-24T122959.958275Z"></a>
-2010-08-24T12:29:59.958275Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-In preparation for the release, add my username to real name mapping
-in AUTHORS, add an initially empty History9.htm, and update News.htm
-to point to it.
-
-</pre>
-<p>[doc/History9.htm doc/News.htm doc/AUTHORS]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-23T164947.032287Z"></a>
-2010-08-23T16:49:47.032287Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : errors in XMP metadata parsing
-
-Bug #691562 &quot;ERROR -15 closing pdfwrite device&quot;.
-
-This use of a DOCINFO pdfmark exposed 3 separate bugs in pdfwrite's handling of XMP
-metadata.
-
-1) Decoding an escaped PostScript string. Unescaped characters and octal escapes worked
-correctly, but non-octal escapes moved the index into the string one place too many.
-
-2) The escape '\b' (backspace) wasn't handled and returned incorrect data. Although not
-tested by this issue, the form feed (\f) also wasn't handled.
-
-3) When converting UTF16 data to UTF-8, the end of the destination (UTF-8) buffer was
-calculated incorrectly, causing a spurious buffer overrun error.
-
-The code now handles the missing escapes, does not advance the character position after
-decoding a non-octal escape and correctly defines the end of buffer. After this the
-Title string displays the same in Acrobat as the same pdfmark sent through Adobe
-Distiller.
-
-No expected differences as this only affects the document metadata.
-</pre>
-<p>[base/gdevpdfe.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-21T080346.086781Z"></a>
-2010-08-21T08:03:46.086781Z Lars Uebernickel</strong></p>
-<blockquote>
-<pre>
-Remove unnecessary version checks for libtiff in configure.ac.
-
-Since the local copy is preferred over the system's (see r11635), comparing the
-version of the two libraries is unnecessary.
-
-</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-20T160722.239869Z"></a>
-2010-08-20T16:07:22.239869Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-When we produce a glyph uncached, and it's to be filled with a
-pattern colour space *and* there is PDF transparency involved
-force FAPI to (try to) produce an outline (for lower level
-code to use as a clip) instead of a bitmap (to use as a
-mask).
-
-This does produce some pixel level differences in a few
-cluster files, but improves a load of PDF 1.7 FTS jobs.
-
-Bug 691550
-
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-19T040105.188148Z"></a>
-2010-08-19T04:01:05.188148Z henrys</strong></p>
-<blockquote>
-<pre>
-Fix bug #691564. The assignment of the target device did not use the
-proper reference counting assignment procedure resulting in a lost
-reference to the target device.
-</pre>
-<p>[base/gxpcmap.c]</p>
-</blockquote>
-
-
-<p><strong><a name="2010-08-17T143158.354019Z"></a>
-2010-08-17T14:31:58.354019Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Skip opacity and unknown components during reading of JPX image data. This
-improves image quality (compared to the previous state that interpreted an
-opacity channel as yet another data sample) and serves as a transition to full
-support of opacity in JPX images. Bug 691489, customer 532.
-</pre>
-<p>[base/sjpx.h psi/zfjpx.c base/sjpx.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-17T012218.729560Z"></a>
-2010-08-17T01:22:18.729560Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Don't include opacity channels in the number-of-components count.
-Recognize general ICC profile (type 3) and construct a corresponding
-ICC-based color space. Bug 691470, customer 532.
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-15T094903.044306Z"></a>
-2010-08-15T09:49:03.044306Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Ensure we only check the compatibility of the system libtiff
-if we're actually going to use it.
-
-No cluster differences expected.
-
-Bug 691548
-</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-15T094221.565047Z"></a>
-2010-08-15T09:42:21.565047Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-The &quot;shortcut&quot; for rendering masks use by the FAPI code for uncached
-glyph bitmaps (gx_image_fill_masked) is only safe, in the general case
-when drawing &quot;plain&quot; colours to the output. For complex colour spaces
-(like patterns) we must use the &quot;long hand&quot; version.
-
-This causes minor pixel level differences in some cluster tests (due
-to rounding differences), and some (very small) progressions: there
-are differences in about 20 cluster jobs.
-
-Bug 691549.
-
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-14T211029.198491Z"></a>
-2010-08-14T21:10:29.198491Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Fix a memory corruption problem introduced by the rev. 11588 on some systems.
-Free the string returned by systempapername() but don't free the static string
-returned by defaultpapername() . Bug 691557.
-</pre>
-<p>[base/gp_upapr.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-13T194628.340691Z"></a>
-2010-08-13T19:46:28.340691Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite( : Invalid compression filter emitted.
-
-Bug #691556 &quot;Images compressed with the RunLengthDecode filter are invalid&quot; A typo in
-gdevpdfx.h caused the /Filter entry of an image dictionary to be written with a
-trailing comma if the filter was RunLength.
-
-No differences expected
-</pre>
-<p>[base/gdevpdfx.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-12T181430.164084Z"></a>
-2010-08-12T18:14:30.164084Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-pstoraster: Removed unneeded &quot;-dDEBUG&quot; from Ghostscript command line.
-</pre>
-<p>[cups/pstoraster.in]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-12T181047.335830Z"></a>
-2010-08-12T18:10:47.335830Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-CUPS Raster output device: Do verbose degug logging only if compiled in debug mode. Bug 690581.
-
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-12T063908.575092Z"></a>
-2010-08-12T06:39:08.575092Z regression</strong></p>
-<blockquote>
-<pre>
-Added support for regression testing of the cups device.
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/build.pl toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-12T025540.283339Z"></a>
-2010-08-12T02:55:40.283339Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix to handle case where the profiledir is NOT set AND there is a change in
-the process color model for the device AFTER a profile had already been set. </pre>
-<p>[base/gsicc_manage.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-12T014217.270497Z"></a>
-2010-08-12T01:42:17.270497Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Implement variable text rendering for widget annotations.
-Bug 691536, customer 532.
-</pre>
-<p>[Resource/Init/pdf_main.ps Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-11T233148.385487Z"></a>
-2010-08-11T23:31:48.385487Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for indeterminism issue that was introduced with changes in 16bit image
-handling. Last subpixel element was not getting unpacked properly. </pre>
-<p>[base/gxi16bit.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-11T230548.288399Z"></a>
-2010-08-11T23:05:48.288399Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Another compiler complaint fix. Proper cast of device.</pre>
-<p>[base/gdevpsdi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-11T213103.877037Z"></a>
-2010-08-11T21:31:03.877037Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for compiler error due to implicit declaration</pre>
-<p>[base/gdevpsdi.c base/devs.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-11T185451.837319Z"></a>
-2010-08-11T18:54:51.837319Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix so that if the device process color model changes the profile is updated accordingly.</pre>
-<p>[base/gsicc_manage.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-11T161745.421152Z"></a>
-2010-08-11T16:17:45.421152Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Fix bug # 691532. Do not attempt to clone an image that does not exist,
-each completed page should have an associated image. We'd like to handle
-this corrupt file with a better fix, for example the absence of an end page
-segement is clearly a problem with respect to the specification, but Adobe and
-Artifex have chosen to support other &quot;off spec&quot; streams so more subtle
-and less obvious error checking is needed. Thanks to Tim Waugh for analysis on
-this problem.
-</pre>
-<p>[jbig2dec/jbig2_page.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-11T152222.427529Z"></a>
-2010-08-11T15:22:22.427529Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Add some words about the ps2write device to the devices documentation.
-</pre>
-<p>[doc/Devices.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-10T164420.491267Z"></a>
-2010-08-10T16:44:20.491267Z regression</strong></p>
-<blockquote>
-<pre>
-
-Several minor changes to the cluster regression system, the most
-signifcant of which are:
-
-seg. faults are now reported for every case (previously they were only
-reported if they were new)
-
-skip.lst files are now checked for errors
-
-changes to gs/psi now test the pcl/pxl/xps products since changes to
-Ghostscript can affect the pdfwrite path
-
-the tests_private/pdf/PDF_1.7_FTS repository was added
-
-
-</pre>
-<p>[toolbin/localcluster/clustermonitor.pl toolbin/localcluster/clustermaster.pl toolbin/localcluster/readlog.pl toolbin/localcluster/build.pl toolbin/localcluster/run.pl toolbin/localcluster/compare.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-10T162019.775613Z"></a>
-2010-08-10T16:20:19.775613Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Commit to move the ICC profile for the device within the device structure.
-This will make it easier to handle dynamic changes that may occur to the
-process color model for the device. Also a move of device profiles into non gc
-memory and removal of any references to profiles to the GC. A few progressions
-occur with this commit including Bug689918.pdf testpage.pdf. </pre>
-<p>[base/gxi12bit.c base/gsdevice.c base/gdevpdfk.c base/gxpcmap.c base/gxdevice.h /trunk/ghostpdl/xps/xpsgradient.c base/gdevprn.c base/gdevpsdi.c base/gscsepr.c base/gscpixel.c base/gxcmap.c base/gdevbit.c base/gxclip.c base/gxicolor.c base/gximag3x.c base/gscspace.c base/gsicc.c base/gscdevn.c base/gscolor2.c base/lib.mak base/gxiscale.c base/gsicc_manage.c base/gxcspace.h base/gscicach.c base/gdevnfwd.c base/gxdevcli.h base/gdevp14.c psi/zdevice.c base/gsicc_create.c base/gsicc_cache.c base/gdevp14.h base/gsicc_cache.h base/gxccman.c base/gscms.h base/gxclist.h psi/zusparam.c base/gxshade.c base/gxblend.c base/gsequivc.c base/gsciemap.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-10T091550.312005Z"></a>
-2010-08-10T09:15:50.312005Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Enhancement : pdfwrite
-
-performance enhancement for pdfwrite when handling files with large amounts of text.
-
-Bug #689859 &quot;Performance comparison versions 7.07 and 8.62 on HP-UX ia64&quot; Alex's
-analysis shows that pdfwrite was spending a lot of time trying to to see if two type 1
-fonts were the same before deciding whether a glyph could be added to a font, or was
-already present in a font copy.
-
-Most of the time was spent extracting and comparing /Subrs. The new code creates a hash
-(MD5) of both the local and global Subrs (if present) and stores that in the type 1
-'data' field in the font (16 bytes). The hashes are created by pdfwrite only as they
-are required, so there is no performance penalty for rendering. The hash comparison is
-considerably quicker than the long winded Subrs comparison.
-
-For many files the performance difference is minimal but for file containing lots of
-pages, mostly composed of text, there is a considerable saving. The text files run in
-about 60% of the time they did before this change.
-
-</pre>
-<p>[base/gxfont1.h base/gxfcopy.c psi/zfont1.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-10T081335.250205Z"></a>
-2010-08-10T08:13:35.250205Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-A small revision to the fix for Bug 691326: the glyphs array must have
-at least one entry.
-
-No cluster differences expected.
-
-Bug 691343
-</pre>
-<p>[Resource/Init/gs_ttf.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-09T004131.173587Z"></a>
-2010-08-09T00:41:31.173587Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Free the pattern-clist devices that are created (and left for the GC to
-free) when pattern-clist patterns are used with a device that is using the
-clist for the page. Those that were allocated during the print_page clist
-playback would be those that leaked. Since the devices were closed, this
-could lead to GC referencing objects that were invalid. Related to, but
-not the final fix to Bug 691527.
-</pre>
-<p>[base/gxpcmap.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-09T000727.505245Z"></a>
-2010-08-09T00:07:27.505245Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Remove spurious &quot;cvx&quot; operators after .pushextendedgstate and
-.popextendedgstate . Do .popextendedgstate after checking that &quot;Q&quot;
-has a correspondingh &quot;q&quot;. Bug 691538.
-</pre>
-<p>[Resource/Init/pdf_ops.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-07T155808.066501Z"></a>
-2010-08-07T15:58:08.066501Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Implement rendering of Widget annotation border background specified by
-/BC and /BG entries of the appearance characteristics dictionary /MK.
-Bug 691524, customer 532.
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-06T202111.891509Z"></a>
-2010-08-06T20:21:11.891509Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix segfault seen with fts_17_1704.pdf when the clist playback of patterns
-that had been stored as clists were attempted to be read from the clist
-as bitmaps. This happened when -dMaxPatternBitmap=1000000 was used which
-is smaller than the default, confusing a HACK that attempted to force
-the use of the pattern-clist mode. Also remove some #if 0 idle code.
-</pre>
-<p>[base/gsptype1.c base/gxpcmap.c base/gxcolor2.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-06T172216.521958Z"></a>
-2010-08-06T17:22:16.521958Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-I missed a couple of now unused variables in the previous commit.
-</pre>
-<p>[psi/iname.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-06T154921.355481Z"></a>
-2010-08-06T15:49:21.355481Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Add documentation on -dMaxPatternBitmap=# parameter in the 'Improving
-Performance' section of the Use.htm file. The actual parameter was
-added in rev 11605.
-</pre>
-<p>[doc/Use.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-06T150300.994141Z"></a>
-2010-08-06T15:03:00.994141Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Prevent doing a gc &quot;unmark&quot; on memory already (potentially)
-freed.
-
-Relates to Bug 691380. I could not reproduce the seg fault
-as reported, but valgrind reported the write to freed memory
-in the same place as the reported seg fault.
-
-</pre>
-<p>[psi/iname.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-06T111522.616992Z"></a>
-2010-08-06T11:15:22.616992Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix pdfwrite
-There is a hack in type 3 font creation in pdfwrite which increases the FontMatrix if
-all the elements are very small, apparently Acrobat is unable to cope with very small
-FontMatrix entries.
-
-However, if all the entries are 0, it ends up running round a loop multiplying by 10
-indefinitely. This change simply avoids the loop if all the matrix elements are 0.
-Naturally this isn't a useful font, its a Quality Logic test file.
-
-</pre>
-<p>[base/gdevpdtt.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-06T111140.511965Z"></a>
-2010-08-06T11:11:40.511965Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Revision 11600 introduced a sever regression with text in XPS files. This revision
-addresses that by only applying the fix to preserve glyph data when the text operation
-is TEXT_FROM_SINGLE_GLYPH as this is the only case where the affected union is a glyph
-not a pointer to a series of glyphs, and is therefore the only case which is affected.
-
-Expected Differences: All XPS files with text should again work correctly.
-</pre>
-<p>[base/gdevpdte.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-06T082720.529691Z"></a>
-2010-08-06T08:27:20.529691Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Revise some of the FAPI related information.
-
-</pre>
-<p>[doc/Use.htm doc/Make.htm doc/Develop.htm doc/Psfiles.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-06T055342.503244Z"></a>
-2010-08-06T05:53:42.503244Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Implement rendering of standard Stamp and Text annotations. Ghostscript uses
-different font than Acrobat in Stamp icons and uses the same icon for the Text
-annotation regardless of the /Name attribute. Bug 691525, customer 532.
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-06T042459.663647Z"></a>
-2010-08-06T04:24:59.663647Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Add a new paramter MaxPatternBitmap with a default value of 8Mb. Formerly
-the pattern_clist mode would be used when the bitmap size exceeded 1Mb
-and prior to rev 11___ this calculation was flawed and could allow pattern
-bitmaps as large as 64Mb to avoid the pattern_clist mode. While the clist
-based pattern tiling is slow, setting the threshold to 8Mb should be rare
-enough to minimize performance impact. Bug 691512.
-</pre>
-<p>[base/gsdevice.c base/gdevp14.c base/gxdevcli.h base/gsdparam.c base/gxpcmap.c base/gxdevice.h base/gdevbit.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-05T232612.261846Z"></a>
-2010-08-05T23:26:12.261846Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-CUPS Raster output device: Segmentation fault on mid-job changes of the color depth.
-
-This patch prevents the crash by forcing a memory reallocation on
-color depth changes. The approach principally works but we did not
-decide yet whether it is the final solution, as Michael Vrhel is still
-doing major changes in the color handling. Bug 690435.
-
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-05T191611.698734Z"></a>
-2010-08-05T19:16:11.698734Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix comment about no support for BITS=4
-</pre>
-<p>[lib/viewrgb.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-05T191400.403158Z"></a>
-2010-08-05T19:14:00.403158Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Minor correction to usage string left over from when this was split out
-from setupgs.
-</pre>
-<p>[psi/mkfilelt.cpp]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-05T174036.908437Z"></a>
-2010-08-05T17:40:36.908437Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-The &quot;show&quot; machinery expected that even non-marking text operations
-(such as stringwidth) would result in a glyph bitmap which
-could be cached (assuming the glyph would be a candidate for the
-cache with a normal marking operation, like show).
-
-FAPI, however, did not create a glyph bitmap for non-marking
-operations, thus the cache would receive a valid, but
-&quot;empty&quot; glyph. This caused Postscript that used stringwidth
-before a show to sometimes &quot;lose&quot; glyphs, by using the empty
-cached glyph.
-
-FAPI's behaviour now matches the expectations of the show/cache
-management code.
-
-Causes cluster differences in Bug688372.ps, fts_31_3111.pdf, and
-14-08.PS, these are all progressions.
-
-Bug 691517
-
-</pre>
-<p>[psi/fapi_ft.c psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-05T154939.430735Z"></a>
-2010-08-05T15:49:39.430735Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite)
-A piece of data (pointer to glyph data) was stored and passed into a routine
-'process_text_modify_width' which expected the glyph data to remain unchanged but
-modified the text enumerator data. This doesn't work if the glyph data is a pointer
-to the text enumerator data. NB the text enumerator is saved and restored around the
-call.
-
-Modified so that the calling routine makes a copy of the glyph data before calling
-'process_text_modify_width'.
-
-This should prevent 13-10.ps from entering an infinite loop.
-</pre>
-<p>[base/gdevpdte.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-04T231524.779084Z"></a>
-2010-08-04T23:15:24.779084Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix for Bug 691504 (gs taking a long time to render a file).
-
-Revision 8694 changes code from using a simple cast to an int to using
-a call to (int)floor. This fixes problems, but costs a factor of 3 in
-processing time for heavily tiled files.
-
-Here we change to using a macro version of floor instead. This removes
-the function call and NaN handling overheads and returns us to the
-same kind of performance as we had before.
-
-We apply the same change throughout the file (i.e. all the calls to (int)floor,
-not just the two changed in r8694.
-
-There is still scope for optimising this code further, but this closes the
-regression.
-
-No differences seen in local cluster testing.
-
-</pre>
-<p>[base/gxp1fill.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-04T225904.842835Z"></a>
-2010-08-04T22:59:04.842835Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Implement rendering of Underline and StrikeOut annotations without
-appearance streams. Bug 691526, customer 532.
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-03T120247.197684Z"></a>
-2010-08-03T12:02:47.197684Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix : FAPI (no bug number, discovered working on a different problem)
-
-Another place where the FAPI code assumes that a text enumerator is a show_enum and
-casts it as such. While this is true for rendering, it is not the case when capturing
-glyphs for pdfwrite.
-
-Altered the code to test if the enumerator is a show_enum and if not, to get the
-graphics state from the enumerator 'pis' pointer instead if possible. Signal an error
-if this is not possible.
-
-No differences expected.
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-03T080213.862491Z"></a>
-2010-08-03T08:02:13.862491Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Enhancement : PDF interpreter. Bug #691503
-
-When creating an outline (/OUT pdfmark), especially for the pdfwrite device, check the
-destination page to see that it lies between FirstPage and LastPage; if it does not, then
-don't emit it. This is an extension to the existing control which checked that the
-destination page wasn't greater than the number of pages in the PDF file.</pre>
-<p>[Resource/Init/pdf_main.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-03T075650.987568Z"></a>
-2010-08-03T07:56:50.987568Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-In the section 'Using Unicode True Type fonts', replace the example CSI array with one
-whose values are strings, not names. These must be string values.
-</pre>
-<p>[doc/Use.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-02T213029.939498Z"></a>
-2010-08-02T21:30:29.939498Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Partly revert rev. 11392 that over-simplified the check for a valid obj line
-in the PDF file. Use --search-- to reject impossible cases but revert to the
-old logic to verify the results. Bug 691502.
-</pre>
-<p>[Resource/Init/pdf_rbld.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-02T164500.756282Z"></a>
-2010-08-02T16:45:00.756282Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Fix a compiler warning about a missing prototype for free()
-caused by my previous commit.
-</pre>
-<p>[base/lib.mak base/gp_upapr.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-02T134903.975996Z"></a>
-2010-08-02T13:49:03.975996Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Fix a memory leak. Free the paper name string allocated amd
-returned by libpaper.
-</pre>
-<p>[base/gp_upapr.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-02T092004.666066Z"></a>
-2010-08-02T09:20:04.666066Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Missing ';' in r11586 replaced. Should build now.</pre>
-<p>[base/gdevpdfx.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-02T090647.523074Z"></a>
-2010-08-02T09:06:47.523074Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix a few minor compiler warnings from gcc. No differences expected.
-</pre>
-<p>[base/gdevpdfx.h base/gdevpdf.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-02T063925.229115Z"></a>
-2010-08-02T06:39:25.229115Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Applied patch to fix &quot;imagen&quot; output device (bug 690561).
-</pre>
-<p>[base/gdevimgn.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-08-01T085915.942136Z"></a>
-2010-08-01T08:59:15.942136Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Remove the now redundant --disable-cairo directives.
-
-</pre>
-<p>[toolbin/localcluster/readme toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-31T160737.431496Z"></a>
-2010-07-31T16:07:37.431496Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Remove the &quot;dead&quot; devcairo device.
-
-No cluster differences expected.
-
-Bug 690009
-
-</pre>
-<p>[ghostscript.vcproj base/configure.ac base/gdevcairo.c base/devs.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-31T154539.194094Z"></a>
-2010-07-31T15:45:39.194094Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Reapply r11570
-
-Copying converted samples to the output raster used the byte
-length of the input raster, rather than the byte length of
-the converted data. Change to use the correct length.
-
-Bug 691494 - credit to SaGS for the patch.
-
-</pre>
-<p>[base/gdevdbit.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-31T150424.124204Z"></a>
-2010-07-31T15:04:24.124204Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-No need to install Resources and iccprofiles if COMPILE_INITS=1
-
-When COMPILE_INITS=1, the mentioned directories are not used and just waste
-disk space and also confusing. Bug 689253.
-
-</pre>
-<p>[base/unixinst.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-31T003707.940018Z"></a>
-2010-07-31T00:37:07.940018Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix the calculation of the size of the pattern bitmap by correcting the
-calculation of the effective depth (bits per pixel). PaintType 2 is the
-uncolored (mask == 1 bit per pixel) mode, PaintType 1 is colored, thus
-needs the full target device color_info.depth bits per pixel. Bug 691514
-detected running the PDF 1.7 FTS for customer 532.
-</pre>
-<p>[base/gxpcmap.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T231352.534878Z"></a>
-2010-07-30T23:13:52.534878Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Distinguish the two uses of cdev - one from icc merge, one the from very old lpd code (bug 691463).
-
-This causes a warning when building with gcc, msvc, and also DEC CC.
-
-</pre>
-<p>[base/gdevbbox.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T213419.596701Z"></a>
-2010-07-30T21:34:19.596701Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Removed unneeded &quot;;&quot; characters from C code to silence warnings of DEC CC (bug 691463)
-
-</pre>
-<p>[contrib/gdevbjc_.h base/gxpcolor.h base/strmio.h base/gdevrinkj.c base/gdevbit.c base/gdevpdtf.h base/gsovrc.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T203848.303275Z"></a>
-2010-07-30T20:38:48.303275Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-configure script: Hide error message when &quot;sed&quot; does not have a &quot;--version&quot; option.
-</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T200921.607711Z"></a>
-2010-07-30T20:09:21.607711Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Tips about cross-compiling 64-bit ghostscript on 32-bit windows
-
-This procedure is slightly simplier(?) than the cross-compiling instruction
-which Russell removed with r9807 about a year ago. Note that
-ARCH_STRUCT_ALIGN_MOD mentioned in Russell's instruction was removed
-r6773 (in 2006) and note also that all the &quot;genconf&quot; references in r9807
-should be &quot;genarch&quot; instead.
-
-</pre>
-<p>[doc/Make.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T171523.787490Z"></a>
-2010-07-30T17:15:23.787490Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for bug 691488.
-
-This commit fixes the issues that we are seeing with the JPEG2000 images in
-the FTS files EXCEPT for the issues related to SmaskInData. Those images
-will be addressed in a separate commit and will now be handled in bug
-691470.
-With this commit, support is in place for faster 16 bit image rendering due
-to the improved ICC support, which lets us avoid the multiple conversions from
-16 bit to frac to float to unsigned short to byte which occurred in the old
-flow. Also, the jasper interface will now, when it encounters a 16 bit or
-12 bit image, use the higher bit depth renderer and pass the data along.
-Previously, we were truncating to 8bits in our jasper interface. These
-changes have been regression tested and checked with bmpcmp.
-
-
-</pre>
-<p>[base/gxi12bit.c base/lib.mak base/gxi16bit.c Resource/Init/gs_lev2.ps Resource/Init/gs_res.ps base/sjpx.c Resource/Init/pdf_draw.ps base/gximage.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T171346.325084Z"></a>
-2010-07-30T17:13:46.325084Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for double to float conversion warnings. Bug 691498. </pre>
-<p>[base/gsicc_create.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T170659.251898Z"></a>
-2010-07-30T17:06:59.251898Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-rollback to revision 11564, 11565 broke the build</pre>
-<p>[base/gxi12bit.c base/lib.mak base/gxi16bit.c contrib/gdevbjc_.h base/gdevbbox.c base/gxpcolor.h Resource/Init/gs_res.ps Resource/Init/pdf_draw.ps base/gsovrc.h base/gdevpdtf.h base/gsicc_create.c autogen.sh Resource/Init/gs_lev2.ps base/strmio.h base/configure.ac base/gdevrinkj.c base/sjpx.c base/gdevbit.c base/gximage.h base/gdevdbit.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T142707.462183Z"></a>
-2010-07-30T14:27:07.462183Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for bug 691488.
-
-This commit fixes the issues that we are seeing with the JPEG2000 images
-in the FTS files EXCEPT for the issues related to SmaskInData. Those images
-will be addressed in a separate commit and will now be handled in bug 691470.
-With this commit, support is in place for faster 16 bit image rendering due to
-the improved ICC support, which lets us avoid the multiple conversions from 16
-bit to frac to float to unsigned short to byte which occurred in the old flow.
-Also, the jasper interface will now, when it encounters a 16 bit or 12 bit image,
-use the higher bit depth renderer and pass the data along. Previously, we were
-truncating to 8bits in our jasper interface. These changes have been regression
-tested and checked with bmpcmp.
-
-
-</pre>
-<p>[base/gxi12bit.c base/lib.mak base/gxi16bit.c Resource/Init/gs_lev2.ps Resource/Init/gs_res.ps base/sjpx.c Resource/Init/pdf_draw.ps base/gximage.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T140814.058178Z"></a>
-2010-07-30T14:08:14.058178Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Copying converted samples to the output raster used the byte
-length of the input raster, rather than the byte length of
-the converted data. Change to use the correct length.
-
-Bug 691494 - credit to SaGS for the patch.
-
-</pre>
-<p>[base/gdevdbit.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T135952.334818Z"></a>
-2010-07-30T13:59:52.334818Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for double to float conversion warnings. Bug 691498</pre>
-<p>[base/gsicc_create.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T113715.489627Z"></a>
-2010-07-30T11:37:15.489627Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Distinguish the two uses of cdev - one from icc merge, one the from very old lpd code (bug 691463).
-
-This causes a warning when building with gcc, msvc, and also DEC CC.
-
-</pre>
-<p>[base/gdevbbox.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T112007.130600Z"></a>
-2010-07-30T11:20:07.130600Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Suppressed error message during ./configure if &quot;sed&quot; does not support &quot;--version&quot; (bug 691463)
-</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T111617.321612Z"></a>
-2010-07-30T11:16:17.321612Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Removed unneeded &quot;;&quot; characters from C code to silence warnings of DEC CC (bug 691463)
-</pre>
-<p>[contrib/gdevbjc_.h base/gxpcolor.h base/strmio.h base/gdevrinkj.c base/gdevbit.c base/gdevpdtf.h base/gsovrc.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T111247.691429Z"></a>
-2010-07-30T11:12:47.691429Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Removed unneeded quotes in autogen.sh.
-</pre>
-<p>[autogen.sh]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T111035.977735Z"></a>
-2010-07-30T11:10:35.977735Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-On Tru64 stdint.h does not exist but the types required by jbig2 are in inttypes.h there (bug 691463).
-
-</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T110327.732163Z"></a>
-2010-07-30T11:03:27.732163Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-On Tru64 the integer types are in inttypes.h and not in stdint.h as in VMS
-
-Bug 691463, required for jbig2dec.
-
-</pre>
-<p>[base/stdint_.h jbig2dec/os_types.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T110025.895059Z"></a>
-2010-07-30T11:00:25.895059Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Replace &quot;==&quot; bashism by &quot;=&quot; in configure.ac
-
-&quot;==&quot; is a bash extension. See bash's manpage recommending &quot;=&quot; for posix
-compliance (bug 691463). This causes various tests to fail and resulted
-in the link failure from mis-detecting omni.
-
-</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T105644.338677Z"></a>
-2010-07-30T10:56:44.338677Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-'%' in printf() needs to be '%%'
-
-Tru64 C issues a warning (bug 691463).
-</pre>
-<p>[base/mkromfs.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T105330.576036Z"></a>
-2010-07-30T10:53:30.576036Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Removed duplicate AC_PATH_PROG(pkg-config) check in ./configure.
-
-The extra check caused
-
-./configure: !: not found
-
-messages on some platforms. Bug 691463.
-
-</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T101447.310782Z"></a>
-2010-07-30T10:14:47.310782Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Update documentation as --enable-dynamics is no longer required for &quot;make so&quot; to work.
-</pre>
-<p>[doc/Make.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T101041.906626Z"></a>
-2010-07-30T10:10:41.906626Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Added some missing initializations in DeviceN
-
-This should have been part of the DeviceN change. If left unset,
-the code path assumes color display and goes down the color display
-path and eventually segfaults. Bug 690428.
-</pre>
-<p>[base/gdevxcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T095623.737093Z"></a>
-2010-07-30T09:56:23.737093Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Fix time-struct related build failure with SunStudio (bug 691453).
-
-Apparently many platforms and compilers, including gcc and intel C,
-require both &lt;sys/time.h&gt; and &lt;time.h&gt;. This patch just adds Sun Pro C
-to the list of such platforms and compilers.
-
-</pre>
-<p>[base/time_.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T094551.500432Z"></a>
-2010-07-30T09:45:51.500432Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Avoid that the x11 output device can create huge windows which crash the X server. Bug 690444.
-</pre>
-<p>[base/gdevxini.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-30T085817.493418Z"></a>
-2010-07-30T08:58:17.493418Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Assorted fixes for the modularized X11 output device
-
-All object files destined for shared libraries needed to be compiled
-with -fPIC but this is not the case for gsparamx.c, gdevemap.c, and
-gdevxcmp.c which are required by other parts to be built as standard.
-
-This change makes x11 not depend on gsparamx.c and gdevemap.c (and not
-geeting them included in the shared library X11.so). gsparamx.c is
-part of psdf and is usually included and available, and gdevemap.c is
-small enough to be inserted completely where it is used.
-
-gdevxcmp.c is addressed by building it with &#36;(GLCCSHARED) and not with
-&#36;(GLCC).
-
-In addition, &#36;(CC_SHARED) is only used for object files, rather than
-for linking, so DYNAMIC_CFLAGS is more appropiate here than
-DYNAMIC_LDLAGS.
-
-Bug 691510
-
-</pre>
-<p>[base/gdevxxf.c base/Makefile.in base/devs.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-29T182806.621749Z"></a>
-2010-07-29T18:28:06.621749Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Add a comment recommending -sstdout=%stderr with -sOutputFile=- to prevent
-PostScript files that print from messing up the output. Bug 691507.
-</pre>
-<p>[doc/Use.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-29T142919.627579Z"></a>
-2010-07-29T14:29:19.627579Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove unused variable left over from removal of pattern_cache_alt.
-
-No expected changes.
-
-</pre>
-<p>[base/gsstate.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-29T140539.594612Z"></a>
-2010-07-29T14:05:39.594612Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : try not to write out invalid xref
-
-Exposed by bug #691503. There are circumstances under which we create a reference to a
-/Page object which does not yet exist (creating an outline tree for example). In this
-case we create a reference to the page, and set its initial offset to the current
-position in the PDF file. When we later write the real object we update the position
-to reflect the point in the file where it is actually stored.
-
-However, if we don't actually ever write the object (in the case above, because
-LastPage is set before the destination page), then the object remains pointing to the
-wrong location in the file. This is then written into the xref table, and this confuses
-the current version of Ghostscript.
-
-The patch creates new pages with an offset of 0 (which is always invalid because the
-PDF header means the minimum offset for any object is 15). If the page is later
-created then the offset gets updated. If it is not written, however, we now check in
-the xref writing code to see if an object has an offset of 0. If it does, then we
-break the xref table up and do not write an xref entry for the missing object.
-
-Ghostscript is happy with this and processes the file.
-
-NB the proper fix is to not emit the Outline entry for the page which will not be
-present in the output, and a patch has been suggested to achieve this. This code has
-some uses, however, as it may prevent this kind of problem in the future. It also
-permits objects to be created and never referenced (presumably because they are never
-used) without leaving invalid entries in the xref, which might be useful.
-
-No expected differences.
-</pre>
-<p>[base/gdevpdf.c base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-29T135953.090810Z"></a>
-2010-07-29T13:59:53.090810Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Two changes for two primarily pdfwrite problems with FAPI/FT.
-
-The first is to only replace whichever of BuildGlyph or BuildChar
-procedures the original font actually contained, replacing both
-regardless confused some of &quot;decoding&quot; code elsewhere in GS
-(op_show_continue_dispatch()) and we ended up receiving a valid
-glyph to render instead of notdef. In this case we ended up incorrectly
-stroking a charpath (this was seen with Quark's Type 3 &quot;special effects&quot;
-font). With rendering output this resulted in a boldening effect on the glyph,
-in pdfwrite, the result was strange extra lines through the glyph.
-
-The second change is to due pdfwrite's use of a unit matrix for some of
-its work. This resulted in small glyph metrics rounding to zero within
-Freetype, and pdfwrite thinking a glyph had a width of zero. So make
-the scale value at which we consider a glyph to be &quot;small&quot; an order of magnitude
-larger, which gets compensated for in the calculation of Freetype's final
-matrix.
-
-Unfortunately this does cause ~2600 differences in the cluster tests: some
-are progressions, most are pixel differences due to rounding differences
-because the scaling numbers have changed in Freetype.
-
-Fixes Bug 691383
-
-</pre>
-<p>[psi/fapi_ft.c psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-28T184446.282683Z"></a>
-2010-07-28T18:44:46.282683Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix bug #691493. Revert some of the work done for gs_2_colors.
-
-I had needlessly attempted to have 2 pattern_cache's, one for stroking
-colors and one for non-stroking colors. Given that the pattern_cache is
-indexed by color id number, this is not necessary as all the data can
-live happily in just one instance.
-
-This removes the problem seen in the bug (where it was getting into an
-infinite loop trying to populate the cache).
-
-Local cluster testing shows this produces 57 differences, all (I think)
-non-determinisms.
-
-
-</pre>
-<p>[base/gsstate.c base/gxistate.h base/gsistate.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-28T123751.588339Z"></a>
-2010-07-28T12:37:51.588339Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-CUPS Raster output device &quot;cups&quot;: Improved support for rendering jobs with high memory demands.
-
-Let Ghostscript determine the memory buffer sizes automatically (as it
-does with all the other output devices) if the environment variable
-RIP_MAX_CACHE is not set, zero, or does not begin with a number (like
-&quot;auto&quot;). If RIP_MAX_CACHE defines a valid value, use the actual value
-for BufferSpace and not 1/10 of it. MaxBitmap is the maximum buffer
-size to be used when rendering in full page mode, BufferSpace is the
-buffer size used in banding mode. Banding mode is used if MaxBitmap is
-too small to hold one page. Bug 691499.
-
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-28T092249.016213Z"></a>
-2010-07-28T09:22:49.016213Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add new gp_thread_start, gp_thread_finish abstraction, and deprecate old
-gs_create_thread function. Adapt multiple rendering thread code to use
-this new style instead. Hopefully this should solve the problems seen
-in rare cases when a test thread doesn't get scheduled until after the
-DLL has exited and the code isn't around any more.
-
-No expected differences.
-
-This code has been tested with MSVC and on linux with pthreads. While it
-should work with Borland and Watcom (as all the headers appear consistent)
-I have not been able to properly test it. Therefore the code is currently
-configured to fall back to the old code, thus hopefully guaranteeing that
-this commit won't make the operation under Borland/Watcom any worse than
-it is now. This fallback is controlled by a single define for each of
-these systems in gp_wsync.c, so it's easy to test. If users can report
-success with the new code we can remove the fallback trivially.
-
-
-</pre>
-<p>[base/gp_wsync.c base/gxclthrd.c base/gp_nsync.c base/gp_psync.c base/gxclthrd.h base/gpsync.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-28T073652.403693Z"></a>
-2010-07-28T07:36:52.403693Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-As pointed out by SaGS in Bug #691440, comment 5(C) there was a typo in revision 11498,
-a '&gt;&gt;' was accidentally dropped form the batch file.
-</pre>
-<p>[lib/ps2pdf.bat]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-27T071003.221027Z"></a>
-2010-07-27T07:10:03.221027Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Add missing free of the new bitmap data.
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-27T070247.392994Z"></a>
-2010-07-27T07:02:47.392994Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Slightly revise comment for why we might need to create a new bitmap
-in fapi_finish_render_aux()
-
-No cluster differences expected.
-
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-26T084833.786696Z"></a>
-2010-07-26T08:48:33.786696Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-A much better solution for Bug 691328.
-
-The bitmap data coming from a font scaler/renderer may not have its raster
-alignment as Ghostscript expects, so in the event that is the case, create
-a bitmap which is GS compatible in the FAPI layer, before calling any
-further operations on it.
-
-This reverts the previous &quot;hack&quot; from r11362.
-
-No cluster differences expected.
-
-</pre>
-<p>[base/gsbitops.c psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-24T225746.607791Z"></a>
-2010-07-24T22:57:46.607791Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Render 3D annotations (using appearance stream) on the printer device even
-if Print flag (0x4) is not set. This is done following AR8 and AR9 example
-but contrary to PDF 1.7 spec. Bug 691486, customer 532.
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-23T200128.232264Z"></a>
-2010-07-23T20:01:28.232264Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Make *clean targets remove generated tif*.h files. Bug 691485.
-</pre>
-<p>[base/gs.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-23T190145.196186Z"></a>
-2010-07-23T19:01:45.196186Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Remove .dividesfnts procedure, which is not needed by PS interpreter after
-the introduction and use of string_array_access_proc() way back in
-revision 176. FreeType doesn't require a particular way to split sfnts
-either. ps2write includes procedures to create a well formed Type 42 from
-a TrueType font.
-
-The error is caused by .dividesfnts only spliting strings when the split
-offset is even. The sample file has a *long* run of cases where the split
-offsets are odd. When an even offset is finally found, the number of buffered
-bytes exceeds the maximum length of the string causing /rangecheck error.
-Thanks to Chris Liddell for the analysis of the problem.
-Bug 691473, customer 532.
-</pre>
-<p>[Resource/Init/gs_ttf.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-23T092028.484085Z"></a>
-2010-07-23T09:20:28.484085Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Commit the correct change for Bug 691427
-
-
-
-</pre>
-<p>[base/lib.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-23T082243.299979Z"></a>
-2010-07-23T08:22:43.299979Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Change the gsicc* targets from using GCFLAGS to CFLAGS. This ensure that the
-options for building .so objects are correct.
-
-Additionally, add the extra dependencies to the sodebug target so it works
-correctly.
-
-No cluster differences expected.
-
-Bug 691427
-
-</pre>
-<p>[base/lib.mak base/unix-dll.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-23T025737.996803Z"></a>
-2010-07-23T02:57:37.996803Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Handle the case when, contrary to the spec, default viewing optional content
-configuration dictionary has /BaseState attribute equal /OFF. Mark all OCGs
-/OFF and unmark ON UCGs. Bug 691491, customer 532.
-</pre>
-<p>[Resource/Init/pdf_main.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-21T192614.458296Z"></a>
-2010-07-21T19:26:14.458296Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for bug 691478
-
-Note that string objects that are maintained as user params must be either
-allocated in non-gc memory or be a constant in the executable. The problem stems
-from the way userparams are retained during garbage collection in a param_list
-(collected by currentuserparams). For some reason this param_list does not get
-the pointers to strings relocated during the GC. Note that the param_dict itself
-is correctly updated by reloc, it is just the pointers to the strings in the
-param_list that are not traced and updated. In this particular case, ICCProfilesDir
-sets a string in the icc_manager. When a reclaim occurs, the string is relocated
-(when in non-gc memory and when it is noted to the gc with the proper object
-descriptor). Then if a set_icc_directory occurs, the user params pointer has NOT
-been updated and validation problems will occur. Fix for this was to make the string
-not known to the GC and to allocate in non-gc memory. When icc manager is deallocated,
-the string is also deallocated.</pre>
-<p>[base/gsicc_manage.c psi/zusparam.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-21T000316.900862Z"></a>
-2010-07-21T00:03:16.900862Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix so that non-isolated transparency groups are rendered correctly. This fixes a
-rendering issue with fts_25_2524 and with a few in the test suite. A future optimization
-will be to avoid the extra buffer push if the blend mode is normal, since in that case we
-can draw directly into the parent buffer.</pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-20T094634.095118Z"></a>
-2010-07-20T09:46:34.095118Z Masaki Ushizaka</strong></p>
-<blockquote>
-<pre>
-Add support for user defined huffman table.
-
-This code adds support for segment type 53 segments, which supplies
-inline huffman code table. Bug 689853.
-
-Many thanks to Justin Greer.
-
-
-</pre>
-<p>[jbig2dec/jbig2_segment.c jbig2dec/jbig2_huffman.c jbig2dec/jbig2_text.c jbig2dec/jbig2_symbol_dict.c jbig2dec/jbig2_huffman.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-20T082305.218485Z"></a>
-2010-07-20T08:23:05.218485Z Masaki Ushizaka</strong></p>
-<blockquote>
-<pre>
-Catching up to the latest jbig2dec source.
-
-This includes following jbig2dec git commits:
-
-commit d26c7e4f39f76fe70cc61d6dc14d05a042a9be48
-Author: Masaki Ushizaka &lt;masaki@ghostscript.com&gt;
-Date: Tue Jul 20 08:01:29 2010 +0000
-
-Fix jbig2_image_set_pixel function prototype
-
-The declaration of jbig2_image_set_pixel was differenct between
-jbig2_image.h and jbig2_image.c (int value vs bool value). And
-prevented compiling it by MSVC comiler in C++ mode.
-This patch fixes it. Bug #691461.
-
-commit c5d61c78c0de785b74b86d4e5298e3cc7b9e2b68
-Author: Masaki Ushizaka &lt;masaki@ghostscript.com&gt;
-Date: Fri Jul 16 09:13:41 2010 +0000
-
-A little fix to allocating memory size
-
-commit e12fa07da845515911db8be2f7cfa8ef551061ba
-Author: Tor Andersson &lt;tor.andersson@gmail.com&gt;
-Date: Thu Jul 15 00:49:09 2010 +0200
-
-Use the jbig2_new and jbig2_renew macros instead of calling
-jbig2_alloc and jbig2_realloc directly. Also adds a few typecasts
-and #defines required to compile the source as C++.
-
-commit 31dd7ef66dbd1c34df08365aa3c36e6391617f37
-Author: Tor Andersson &lt;tor.andersson@gmail.com&gt;
-Date: Thu Jul 15 00:42:38 2010 +0200
-
-Update VERSION define in config_win32.h
-
-commit 941b73315a166fe07e0f1a1b81171477285280f7
-Author: Tor Andersson &lt;tor.andersson@gmail.com&gt;
-Date: Thu Jul 15 00:41:46 2010 +0200
-
-Add Makefile.unix -- a simple makefile for unix-like systems.
-
-commit f6066822041bbffd7169fd4bfc19c48daae8f155
-Author: Tor Andersson &lt;tor.andersson@gmail.com&gt;
-Date: Thu Jul 15 00:35:58 2010 +0200
-
-Fix memory leak of the word stream struct.
-
-
-No visible difference expected.
-
-
-
-
-</pre>
-<p>[jbig2dec/config_win32.h jbig2dec/jbig2.c jbig2dec/jbig2_image_pbm.c jbig2dec/jbig2_metadata.c jbig2dec/jbig2_image.c jbig2dec/jbig2_huffman.c jbig2dec/jbig2_text.c jbig2dec/jbig2_priv.h jbig2dec/jbig2_image.h jbig2dec/jbig2_refinement.c jbig2dec/jbig2dec.c jbig2dec/jbig2_arith_iaid.c jbig2dec/jbig2_halftone.c jbig2dec/Makefile.unix jbig2dec/jbig2_segment.c jbig2dec/jbig2_arith.c jbig2dec/jbig2_symbol_dict.c jbig2dec/jbig2_generic.c jbig2dec/jbig2_page.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-20T055604.938511Z"></a>
-2010-07-20T05:56:04.938511Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Remove noisy warnings if embedded icc profile is not valid. In those
-cases, we use the default and move on. </pre>
-<p>[psi/zicc.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-19T212235.957060Z"></a>
-2010-07-19T21:22:35.957060Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for Bug691474. Source of error was due to icc hash code being read from clist
-after the transfer function. It should have been read prior to the transfer function.
-This was the first file we have seen that had a soft mask with a transfer function.
-Also fix for rendering of this file. The softmasks only uses the alpha channel as
-opposed to the luminosity of the object. Progression with CityMap-evnice.pdf in test
-suite. That file must have a alpha style softmask.</pre>
-<p>[base/gdevp14.c base/gstparam.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-19T154536.535276Z"></a>
-2010-07-19T15:45:36.535276Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-
-Update trunk to FreeType 2.4.1
-
-The important change (from Ghostscript's point of view) is that the previously
-patented TrueType hinting operations have been enabled by default after the
-expiration of the patents in question.
-
-This change (the hinting being enabled) causes 3060 non-pdfwrite cluster
-changes, and 655 pdfwrite changes - these are expected, and are
-progressions.
-
-</pre>
-<p>[freetype/builds/unix/config.sub freetype/src/pshinter/pshglob.c freetype/src/base/ftpfr.c freetype/src/pshinter/pshglob.h freetype/src/type1/t1objs.c freetype/docs/DEBUG freetype/builds/win32/w32-dev.mk freetype/src/type1/t1objs.h freetype/docs/reference/ft2-gasp_table.html freetype/src/pshinter freetype/docs/INSTALL.CROSS freetype/src freetype/docs/reference/ft2-lcd_filtering.html freetype/src/truetype/ttgload.c freetype/builds/win32/win32-def.mk freetype/src/type1 freetype/builds/wince/vc2005-ce freetype/src/truetype/ttgload.h freetype/src/tools/ftrandom/ftrandom.c freetype/devel/ft2build.h freetype/src/tools/docmaker/formatter.py freetype/src/autofit/Jamfile freetype/src/bdf/module.mk freetype/docs/reference/ft2-glyph_stroker.html freetype/include/freetype/config/ftheader.h freetype/src/cff/Jamfile freetype/src/cff/cffparse.c freetype/src/raster/ftraster.c freetype/src/cff/cffparse.h freetype/src/cff/cffcmap.c freetype/src/raster/ftraster.h freetype/src/cff/cffcmap.h freetype/src/raster/ftrend1.c freetype/include/freetype/internal/services/svttglyf.h freetype/builds/wince/vc2005-ce/freetype.vcproj freetype/src/raster/ftrend1.h freetype/docs/INSTALL.ANY freetype/src/psnames/module.mk freetype/src/base/ftutil.c freetype/src/autofit/afglobal.c freetype/src/cache/ftcsbits.c freetype/builds/mac/ftmac.c freetype/src/autofit/afglobal.h freetype/src/pcf/rules.mk freetype/src/base/ftsystem.c freetype/src/cache/ftcsbits.h freetype/builds/amiga/include/freetype freetype/builds/mac/FreeType.m68k_cfm.make.txt freetype/src/psaux/psaux.c freetype/builds/ansi freetype/src/cff/module.mk freetype/src/pshinter/rules.mk freetype/src/pcf/pcfread.c freetype/src/bdf/bdflib.c freetype/docs/reference/ft2-list_processing.html freetype/include/freetype/ftcache.h freetype/src/pcf/pcfread.h freetype/builds/unix/ft2unix.h freetype/src/raster/Jamfile freetype/builds/atari/FREETYPE.PRJ freetype/src/gzip/rules.mk freetype/src/pshinter/pshalgo.c freetype/include/freetype/internal/services/svcid.h freetype/include/freetype/ftincrem.h freetype/src/lzw freetype/builds/compiler/bcc-dev.mk freetype/src/pshinter/pshalgo.h freetype/src/tools/test_afm.c freetype/src/psnames/psnamerr.h freetype/src/cache/ftccache.c freetype/src/cache/ftcmru.c freetype/include/freetype/config/ftstdlib.h freetype/src/cid/cidtoken.h freetype/vms_make.com freetype/include/freetype/freetype.h freetype/docs/INSTALL.UNIX freetype/src/cache/ftccache.h freetype/src/cache/ftcmru.h freetype/src/tools/cordic.py freetype/src/pfr/Jamfile freetype/src/pfr/pfrload.c freetype/src/pfr/pfr.c freetype/builds/amiga/src freetype/src/pfr/pfrload.h freetype/include/freetype/fterrdef.h freetype/builds/detect.mk freetype/src/tools/ftrandom freetype/docs/reference/ft2-cache_subsystem.html freetype/builds/win32/vc2005 freetype/src/type1/t1gload.c freetype/builds/win32/vc2008 freetype/src/base/ftbbox.c freetype/builds/dos freetype/src/otvalid/otvgdef.c freetype/src/type1/t1gload.h freetype/include/freetype/ftsystem.h freetype/docs/reference/ft2-glyph_variants.html freetype/src/bdf/bdferror.h freetype/builds/unix/aclocal.m4 freetype/src/gxvalid/rules.mk freetype/docs/reference/ft2-bdf_fonts.html freetype/src/pcf/pcf.c freetype/src/otvalid/rules.mk freetype/include/freetype/internal/services/svotval.h freetype/src/bdf/Jamfile freetype/src/gxvalid/gxvbsln.c freetype/src/pfr/pfrdrivr.c freetype/src/pcf/pcf.h freetype/builds/compiler/win-lcc.mk freetype/src/type1/Jamfile freetype/src/pfr/pfrdrivr.h freetype/src/pcf/pcferror.h freetype/src/sfnt/ttsbit0.c freetype/src/base/ftmac.c freetype/builds/mac/FreeType.ppc_classic.make.txt freetype/src/base/ftgloadr.c freetype/src/base/ftbase.c freetype/docs freetype/builds/win32/vc2005/freetype.vcproj freetype/docs/reference/.gitignore freetype/src/base/ftbase.h freetype/builds/compiler freetype/src/gxvalid/gxvmort0.c freetype/src/bdf/bdf.c freetype/builds/amiga/src/base/ftsystem.c freetype/src/bdf/bdf.h freetype/src/cff/cff.c freetype/src/gxvalid/gxvalid.c freetype/builds/win32/w32-lcc.mk freetype/include/freetype/internal/services freetype/include/freetype/internal/psaux.h freetype/src/gxvalid/gxvalid.h freetype/autogen.sh freetype/src/base/fttype1.c freetype/docs/reference/ft2-type1_tables.html freetype/src/autofit/afmodule.c freetype/builds/unix/detect.mk freetype/include freetype/src/autofit/afmodule.h freetype/builds/vms freetype/src/pfr/pfrcmap.c freetype/objs/README freetype/builds/dos/dos-wat.mk freetype/builds/exports.mk freetype/src/pfr/pfrcmap.h freetype/src/psaux/Jamfile freetype/src/cff/cffpic.c freetype/builds/amiga/smakefile freetype/src/base/ftdebug.c freetype/src/gzip/inflate.c freetype/src/cff/cffpic.h freetype/src/type1/t1driver.c freetype/src/otvalid/otvbase.c freetype/include/freetype/ftmoderr.h freetype/src/gxvalid/gxvopbd.c freetype/src/type1/t1driver.h freetype/builds/win32/vc2005/freetype.sln freetype/builds/mac freetype/builds/atari freetype/builds/compiler/visualage.mk freetype/builds/newline freetype/builds/vms/ftsystem.c freetype/src/base/basepic.c freetype/src/type1/t1parse.c freetype/src/otvalid/otvmath.c freetype/src/gxvalid/gxvmort1.c freetype/src/base/basepic.h freetype/src/psnames/rules.mk freetype/src/type1/t1parse.h freetype/docs/reference/ft2-winfnt_fonts.html freetype/src/pcf/Jamfile freetype/src/gzip/Jamfile freetype/src/base/ftbdf.c freetype/builds/mac/ascii2mpw.py freetype/builds/unix/.gitignore freetype/src/raster/module.mk freetype/src/type1/t1afm.c freetype/src/cid/cidobjs.c freetype/include/ft2build.h freetype/include/freetype/internal/services/svgxval.h freetype/include/freetype/internal/ftrfork.h freetype/builds/win32/ftdebug.c freetype/src/tools freetype/src/type1/t1afm.h freetype/src/type1/t1tokens.h freetype/src/pshinter/pshrec.c freetype/src/cid/cidobjs.h freetype/builds/dos/dos-emx.mk freetype/src/pshinter/pshrec.h freetype/src/autofit/autofit.c freetype/builds/win32/w32-wat.mk freetype/builds/wince/vc2008-ce freetype/src/truetype/ttobjs.c freetype/include/freetype/ftchapters.h freetype/src/type1/t1errors.h freetype/include/freetype/ftlzw.h freetype/src/otvalid/otvgsub.c freetype/src/truetype/ttobjs.h freetype/src/tools/apinames.c freetype/src/winfonts/fnterrs.h freetype/src/cache/ftcache.c freetype/builds/win32/visualc/freetype.sln freetype/include/freetype/ftglyph.h freetype/docs/reference/ft2-gx_validation.html freetype/builds/vms/ftconfig.h freetype/builds/win32/vc2005/index.html freetype/builds/unix/unixddef.mk freetype/src/raster/rasterrs.h freetype/src/autofit/aflatin2.c freetype/builds/dos/detect.mk freetype/src/type42/Jamfile freetype/src/base/ftpic.c freetype/builds/wince freetype/src/autofit/aflatin2.h freetype/builds/win32/w32-mingw32.mk freetype/include/freetype/fttypes.h freetype/src/cache/ftcglyph.c freetype/src/gxvalid/gxvmort2.c freetype/builds/link_std.mk freetype/src/cache/ftcglyph.h freetype/src/pshinter/pshinter.c freetype/src/cache/Jamfile freetype/src/tools/test_bbox.c freetype/include/freetype/internal/services/svpsinfo.h freetype/src/type42/t42types.h freetype/builds/os2/os2-dev.mk freetype/builds/mac/ftlib.prj.xml freetype/src/gxvalid/gxvmort.c freetype/src/raster/rastpic.c freetype/builds/win32/vc2008/index.html freetype/src/gxvalid/gxvmort.h freetype/src/gxvalid/README freetype/src/raster/rastpic.h freetype/src/tools/docmaker/docbeauty.py freetype/builds/amiga/include freetype/docs/reference/ft2-incremental.html freetype/src/gzip/ftgzip.c freetype/include/freetype/ftcid.h freetype/include/freetype/internal/services/svpfr.h freetype/builds/compiler/watcom.mk freetype/builds/dos/dos-gcc.mk freetype/src/sfnt/module.mk freetype/src/psnames freetype/docs/INSTALL freetype/src/type1/t1load.c freetype/src/gzip/inftrees.c freetype/src/gzip freetype/builds/amiga/src/base/ftdebug.c freetype/docs/INSTALL.VMS freetype/src/type1/t1load.h freetype/src/gzip/inftrees.h freetype/src/pfr/pfrsbit.c freetype/src/gxvalid/gxvfeat.c freetype/src/cff/cfftoken.h freetype/include/freetype/internal/ftgloadr.h freetype/docs/PROBLEMS freetype/builds/wince/vc2008-ce/freetype.sln freetype/src/pfr/pfrsbit.h freetype/src/truetype/Jamfile freetype/src/gxvalid/gxvfeat.h freetype/builds/unix/configure freetype/docs/reference/ft2-basic_types.html freetype/src/otvalid freetype/src/gxvalid/gxvkern.c freetype/docs/INSTALL.MAC freetype/src/cid/Jamfile freetype/include/freetype/ftmm.h freetype/builds/symbian/freetype.mmp freetype/src/base/ftglyph.c freetype/src/sfnt freetype/src/otvalid/otverror.h freetype/docs/UPGRADE.UNIX freetype/src/autofit/afcjk.c freetype/src/autofit/aftypes.h freetype/src/sfnt/sfdriver.c freetype/src/psaux/afmparse.c freetype/src/autofit/afcjk.h freetype/src/sfnt/sfobjs.c freetype/src/base/ftobjs.c freetype/src/sfnt/sfdriver.h freetype/src/psaux/afmparse.h freetype/src/sfnt/sfobjs.h freetype/src/pfr/rules.mk freetype/docs/reference/ft2-sfnt_names.html freetype/builds/win32/visualc/freetype.vcproj freetype/builds/atari/deflinejoiner.awk freetype/src/psaux/module.mk freetype/src/base/ftstroke.c freetype/src/base/ftfstype.c freetype/docs/GPL.TXT freetype/src/base/ftbitmap.c freetype/src/pshinter/pshpic.c freetype/src/winfonts freetype/builds/dos/dos-def.mk freetype/src/pshinter/pshpic.h freetype/builds/win32/w32-gcc.mk freetype/src/psnames/pstables.h freetype/src/sfnt/rules.mk freetype/builds/wince/vc2005-ce/index.html freetype/src/autofit/afpic.c freetype/docs/raster.txt freetype/builds/atari/FNames.SIC freetype/builds/atari/ATARI.H freetype/src/autofit/afpic.h freetype/src/otvalid/otvgpos.c freetype/docs/reference/ft2-multiple_masters.html freetype/src/cff/cffdrivr.c freetype/docs/reference/ft2-base_interface.html freetype/src/cid/cidriver.c freetype/builds/mac/README freetype/src/otvalid/otvgpos.h freetype/include/freetype/ftgasp.h freetype/builds/unix/unix-cc.in freetype/src/autofit/afindic.c freetype/src/cff/cffdrivr.h freetype/src/cid/cidriver.h freetype/src/autofit/afindic.h freetype/docs/INSTALL.GNU freetype/src/raster freetype/builds/unix/ft-munmap.m4 freetype/src/winfonts/module.mk freetype/src/sfnt/ttkern.c freetype/docs/reference/ft2-index.html freetype/src/gzip/infutil.c freetype/src/sfnt/sferrors.h freetype/src/psaux/t1cmap.c freetype/src/sfnt/ttkern.h freetype/src/gxvalid/gxvmort4.c freetype/src/gzip/infutil.h freetype/include/freetype/ttnameid.h freetype/src/psaux/t1cmap.h freetype/builds/os2/detect.mk freetype/src/gzip/zconf.h freetype/docs/reference/ft2-user_allocation.html freetype/src/base/ftpatent.c freetype/src/truetype/rules.mk freetype/src/truetype freetype/src/base/ftadvanc.c freetype/src/tools/docmaker/tohtml.py freetype/builds/unix/unix-dev.mk freetype/src/otvalid/otvcommn.c freetype/src/otvalid/otvalid.c freetype/include/freetype/config/ftmodule.h freetype/src/otvalid/otvcommn.h freetype/src/otvalid/otvalid.h freetype/include/freetype/ftxf86.h freetype/include/freetype/internal/ftserv.h freetype/Jamrules freetype/src/type1/module.mk freetype/builds/win32/vc2008/freetype.sln freetype/src/base/ftapi.c freetype/docs/VERSION.DLL freetype/docs/LICENSE.TXT freetype/docs/reference/ft2-gzip.html freetype/builds/compiler/emx.mk freetype/include/freetype/ftstroke.h freetype/builds/unix/unix.mk freetype/include/freetype/ftlist.h freetype/include/freetype/ftbitmap.h freetype/objs/.gitignore freetype/src/type42/t42parse.c freetype/src/bdf/bdfdrivr.c freetype/modules.cfg freetype/docs/reference/ft2-toc.html freetype/docs/reference/ft2-computations.html freetype/builds/win32/visualce/freetype.dsp freetype/ChangeLog.20 freetype/src/cid/ciderrs.h freetype/src/type42/t42parse.h freetype/ChangeLog.21 freetype/builds/unix/configure.ac freetype/ChangeLog.22 freetype/builds/unix/ftconfig.in freetype/builds/beos freetype/ChangeLog.23 freetype/src/bdf/bdfdrivr.h freetype/builds/win32/visualce/freetype.dsw freetype/include/freetype/tttables.h freetype/docs/reference/ft2-quick_advance.html freetype/builds/unix/freetype2.in freetype/src/cid/module.mk freetype/src/autofit/afdummy.c freetype/src/gxvalid freetype/docs/reference/ft2-mac_specific.html freetype/src/tools/chktrcmp.py freetype/include/freetype/internal/services/svxf86nm.h freetype/src/autofit/afdummy.h freetype/src/pcf/pcfdrivr.c freetype/include/freetype/internal/ftobjs.h freetype/builds/symbian/bld.inf freetype/src/gxvalid/gxvmort5.c freetype/src/psnames/Jamfile freetype/src/pcf/pcfdrivr.h freetype/builds/unix/ftsystem.c freetype/docs/MAKEPP freetype/Jamfile freetype/builds/win32/visualce/index.html freetype/builds/compiler/gcc-dev.mk freetype/include/freetype/ftotval.h freetype/src/tools/test_trig.c freetype/src/tools/docmaker/content.py freetype/include/freetype/ftadvanc.h freetype/builds freetype/include/freetype/internal/services/svpostnm.h freetype/builds/unix/mkinstalldirs freetype/src/cff/rules.mk freetype/src/gzip/zlib.h freetype/src/type42/t42error.h freetype/src/smooth/module.mk freetype/src/sfnt/sfnt.c freetype/docs/reference/ft2-truetype_tables.html freetype/builds/compiler/gcc.mk freetype/builds/unix/config.guess freetype/src/otvalid/Jamfile freetype/src/autofit/afloader.c freetype/include/freetype/internal/services/svkern.h freetype/builds/beos/beos-def.mk freetype/src/autofit/afloader.h freetype/src/cache/ftcerror.h freetype/src/sfnt/Jamfile freetype/src/psaux/psobjs.c freetype/src/gzip/infcodes.c freetype/src/truetype/ttpic.c freetype/src/psaux/psobjs.h freetype/docs/reference/ft2-header_file_macros.html freetype/src/pshinter/pshnterr.h freetype/docs/reference/ft2-ot_validation.html freetype/src/base/ftcalc.c freetype/src/gzip/infcodes.h freetype/src/truetype/ttpic.h freetype/src/bdf/rules.mk freetype/include/freetype/internal/tttypes.h freetype/src/psaux freetype/builds/unix/freetype2.m4 freetype/docs/reference/ft2-outline_processing.html freetype/src/gxvalid/gxvmorx0.c freetype/include/freetype/internal/ftvalid.h freetype/include/freetype/fterrors.h freetype/builds/win32/visualc/freetype.dsp freetype/src/gzip/infblock.c freetype/builds/win32/visualc/freetype.dsw freetype/src/base/ftlcdfil.c freetype/include/freetype/internal/ftmemory.h freetype/src/type1/type1.c freetype/include/freetype/ftpfr.h freetype/src/gzip/infblock.h freetype/src/type42/rules.mk freetype/src/tools/ftrandom/Makefile freetype/src/pshinter/module.mk freetype/builds/amiga/include/freetype/config/ftmodule.h freetype/src/gxvalid/gxvmorx.c freetype/docs/formats.txt freetype/builds/amiga/makefile.os4 freetype/src/cff/cffobjs.c freetype/src/smooth/ftsmooth.c freetype/src/gxvalid/gxvmorx.h freetype/include/freetype/ftoutln.h freetype/src/cff/cffobjs.h freetype/docs/reference/ft2-truetype_engine.html freetype/builds/beos/detect.mk freetype/src/smooth/ftsmooth.h freetype/include/freetype/ftsynth.h freetype/src/winfonts/rules.mk freetype/src/tools/ftrandom/README freetype/src/pcf freetype/docs/CHANGES freetype freetype/src/base freetype/src/base/ftotval.c freetype/include/freetype/tttags.h freetype/src/autofit freetype/src/truetype/module.mk freetype/include/freetype/internal/autohint.h freetype/src/tools/glnames.py freetype/src/sfnt/ttload.c freetype/src/gxvalid/gxvfgen.c freetype/builds/atari/gen-purec-patch.sh freetype/src/sfnt/ttload.h freetype/src/pfr/pfrtypes.h freetype/docs/reference/ft2-system_interface.html freetype/builds/win32/w32-bcc.mk freetype/src/pcf/README freetype/src/gxvalid/gxvtrak.c freetype/include/freetype/internal/ftdriver.h freetype/objs freetype/include/freetype/ftgzip.h freetype/include/freetype/internal/services/svbdf.h freetype/src/base/ftrfork.c freetype/src/smooth/rules.mk freetype/src/base/rules.mk freetype/src/gxvalid/gxvmorx1.c freetype/src/autofit/afwarp.c freetype/src/cid/cidload.c freetype/include/freetype/ftgxval.h freetype/src/autofit/afwarp.h freetype/builds/win32/w32-intl.mk freetype/include/freetype/internal/services/svgldict.h freetype/src/cid/cidload.h freetype/src/gxvalid/gxvprop.c freetype/docs/reference/ft2-raster.html freetype/include/freetype/ftlcdfil.h freetype/src/type42/type42.c freetype/src/tools/docmaker/sources.py freetype/src/raster/rules.mk freetype/src/truetype/ttgxvar.c freetype/src/pshinter/Jamfile freetype/src/truetype/ttdriver.c freetype/src/gxvalid/Jamfile freetype/src/truetype/ttgxvar.h freetype/src/pfr/pfrgload.c freetype/builds/unix/unix-lcc.mk freetype/src/Jamfile freetype/src/pshinter/pshmod.c freetype/src/autofit/aflatin.c freetype/src/truetype/ttdriver.h freetype/src/base/ftsnames.c freetype/src/pfr/pfrgload.h freetype/src/pshinter/pshmod.h freetype/include/freetype/internal/ftcalc.h freetype/include/freetype/ftrender.h freetype/builds/unix freetype/src/base/ftgasp.c freetype/src/autofit/aflatin.h freetype/src/base/ftdbgmem.c freetype/src/smooth/ftspic.c freetype/include/freetype/t1tables.h freetype/src/cid/cidgload.c freetype/src/base/ftoutln.c freetype/src/smooth/ftspic.h freetype/builds/compiler/intelc.mk freetype/src/base/ftwinfnt.c freetype/src/base/ftsynth.c freetype/src/cid/cidgload.h freetype/include/freetype/internal/internal.h freetype/src/sfnt/ttbdf.c freetype/src/lzw/ftlzw.c freetype/src/sfnt/ttbdf.h freetype/builds/win32/vc2008/freetype.vcproj freetype/builds/win32/w32-bccd.mk freetype/src/truetype/ttpload.c freetype/src/gxvalid/gxvmorx2.c freetype/src/truetype/ttinterp.c freetype/src/lzw/rules.mk freetype/src/truetype/ttpload.h freetype/src/base/ftxf86.c freetype/src/base/ftstream.c freetype/src/truetype/ttinterp.h freetype/src/sfnt/ttcmap.c freetype/builds/ansi/ansi.mk freetype/include/freetype/internal/services/svmm.h freetype/src/pfr freetype/builds/compiler/ansi-cc.mk freetype/src/sfnt/ttcmap.h freetype/src/gxvalid/module.mk freetype/src/gxvalid/gxvjust.c freetype/builds/toplevel.mk freetype/src/truetype/tterrors.h freetype/builds/win32 freetype/builds/symbian freetype/src/pcf/pcfutil.c freetype/src/cid/type1cid.c freetype/src/pcf/pcfutil.h freetype/src/base/ftgxval.c freetype/builds/win32/visualce freetype/include/freetype/internal/pshints.h freetype/builds/amiga freetype/builds/amiga/src/base freetype/builds/win32/w32-icc.mk freetype/src/sfnt/ttmtx.c freetype/src/psnames/psmodule.c freetype/src/sfnt/ttmtx.h freetype/builds/wince/vc2008-ce/index.html freetype/src/psaux/psauxmod.c freetype/src/pfr/module.mk freetype/src/base/ftcid.c freetype/src/psnames/psmodule.h freetype/include/freetype/ftsnames.h freetype/src/psaux/psauxmod.h freetype/README.git freetype/configure freetype/src/gzip/inffixed.h freetype/src/bdf freetype/docs/reference/ft2-pfr_fonts.html freetype/src/sfnt/ttcmapc.h freetype/docs/reference freetype/builds/os2/os2-gcc.mk freetype/builds/compiler/bcc.mk freetype/builds/link_dos.mk freetype/docs/reference/ft2-cid_fonts.html freetype/include/freetype/ftwinfnt.h freetype/builds/unix/freetype-config.in freetype/src/pfr/pfrobjs.c freetype/src/base/Jamfile freetype/docs/release freetype/include/freetype/ftimage.h freetype/src/lzw/ftzopen.c freetype/src/pfr/pfrobjs.h freetype/src/lzw/Jamfile freetype/src/truetype/truetype.c freetype/Makefile freetype/src/base/fttrigon.c freetype/builds/win32/w32-vcc.mk freetype/src/lzw/ftzopen.h freetype/src/autofit/afhints.c freetype/builds/unix/install.mk freetype/src/autofit/afhints.h freetype/builds/win32/visualce/freetype.vcproj freetype/include/freetype/ftmac.h freetype/src/psaux/rules.mk freetype/src/type1/rules.mk freetype/src/cache/ftcimage.c freetype/src/psnames/pspic.c freetype/builds/atari/README.TXT freetype/src/cache/ftcimage.h freetype/include/freetype/config/ftconfig.h freetype/src/cid/cidparse.c freetype/src/psnames/pspic.h freetype/src/cff/cfferrs.h freetype/src/cid/cidparse.h freetype/docs/reference/ft2-version.html freetype/src/smooth/Jamfile freetype/src/tools/docmaker freetype/src/gzip/adler32.c freetype/src/tools/docmaker/.gitignore freetype/include/freetype/internal/sfnt.h freetype/docs/reference/README freetype/builds/compiler/unix-lcc.mk freetype/src/winfonts/winfnt.c freetype/devel/ftoption.h freetype/builds/wince/ftdebug.c freetype/src/gzip/zutil.c freetype/src/sfnt/sfntpic.c freetype/builds/unix/unix-def.in freetype/src/winfonts/winfnt.h freetype/builds/os2/os2-def.mk freetype/src/smooth/smooth.c freetype/src/gzip/zutil.h freetype/src/sfnt/sfntpic.h freetype/devel freetype/src/smooth/ftgrays.c freetype/src/raster/ftmisc.h freetype/docs/reference/ft2-module_management.html freetype/src/gxvalid/gxvmorx4.c freetype/include/freetype/internal/pcftypes.h freetype/src/pfr/pfrerror.h freetype/src/smooth/ftgrays.h freetype/src/winfonts/Jamfile freetype/builds/beos/beos.mk freetype/src/raster/raster.c freetype/include/freetype/internal/services/svwinfnt.h freetype/docs/CUSTOMIZE freetype/include/freetype/config freetype/builds/unix/configure.raw freetype/include/freetype/internal/t1types.h freetype/builds/wince/vc2008-ce/freetype.vcproj freetype/docs/reference/ft2-font_formats.html freetype/src/otvalid/module.mk freetype/include/freetype/internal/services/svpscmap.h freetype/ChangeLog freetype/include/freetype/fttrigon.h freetype/builds/win32/visualc freetype/src/cache/ftcmanag.c freetype/docs/FTL.TXT freetype/src/sfnt/ttsbit.c freetype/README freetype/src/cache/ftcmanag.h freetype/src/sfnt/ttsbit.h freetype/builds/mac/FreeType.ppc_carbon.make.txt freetype/builds/wince/vc2005-ce/freetype.sln freetype/docs/reference/ft2-sizes_management.html freetype/src/type42/t42drivr.c freetype/src/psaux/psconv.c freetype/include/freetype/ftbdf.h freetype/include/freetype/ftsizes.h freetype/src/type42/t42drivr.h freetype/src/cff freetype/include/freetype/internal/services/svtteng.h freetype/src/psaux/psconv.h freetype/include/freetype/internal/ftdebug.h freetype/src/tools/docmaker/docmaker.py freetype/src/gxvalid/gxverror.h freetype/src/autofit/module.mk freetype/include/freetype/internal/ftstream.h freetype/src/cff/cfftypes.h freetype/builds/modules.mk freetype/src/smooth freetype/docs/reference/ft2-bitmap_handling.html freetype/src/gxvalid/gxvmorx5.c freetype/src/gxvalid/gxvmod.c freetype/builds/freetype.mk freetype/include/freetype/internal/ftpic.h freetype/src/type42 freetype/src/gxvalid/gxvmod.h freetype/include/freetype/ftbbox.h freetype/src/otvalid/otvmod.c freetype/builds/unix/install-sh freetype/src/psnames/psnames.c freetype/builds/os2 freetype/src/cid/rules.mk freetype/src/psaux/psauxerr.h freetype/src/type42/t42objs.c freetype/src/otvalid/otvmod.h freetype/src/cache/ftccmap.c freetype/src/cache/ftcbasic.c freetype/src/cache freetype/src/smooth/ftsmerrs.h freetype/src/type42/t42objs.h freetype/include/freetype/internal/services/svttcmap.h freetype/version.sed freetype/builds/amiga/include/freetype/config/ftconfig.h freetype/src/psaux/t1decode.c freetype/docs/reference/ft2-glyph_management.html freetype/src/autofit/rules.mk freetype/src/tools/docmaker/utils.py freetype/builds/win32/visualc/index.html freetype/src/psaux/t1decode.h freetype/builds/ansi/ansi-def.mk freetype/src/otvalid/otvjstf.c freetype/src/type42/module.mk freetype/src/cff/cffgload.c freetype/src/autofit/aferrors.h freetype/src/gxvalid/gxvlcar.c freetype/builds/amiga/makefile freetype/include/freetype/internal/services/svsfnt.h freetype/src/bdf/README freetype/src/base/ftinit.c freetype/src/cff/cffgload.h freetype/src/cache/ftccback.h freetype/include/freetype/internal freetype/src/base/ftmm.c freetype/src/pcf/module.mk freetype/docs/TODO freetype/docs/reference/ft2-lzw.html freetype/src/tools/Jamfile freetype/builds/win32/detect.mk freetype/builds/unix/ltmain.sh freetype/src/autofit/afangles.c freetype/include/freetype/config/ftoption.h freetype/src/gxvalid/gxvcommn.c freetype/src/cff/cffload.c freetype/include/freetype freetype/src/autofit/afangles.h freetype/builds/compiler/visualc.mk freetype/src/gxvalid/gxvcommn.h freetype/src/cff/cffload.h freetype/builds/mac/FreeType.m68k_far.make.txt freetype/builds/amiga/include/freetype/config freetype/src/sfnt/ttpost.c freetype/src/sfnt/ttpost.h freetype/src/cid freetype/src/cache/rules.mk freetype/include/freetype/ttunpat.h freetype/builds/amiga/README freetype/include/freetype/ftmodapi.h freetype/include/freetype/internal/fttrace.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-18T053008.091459Z"></a>
-2010-07-18T05:30:08.091459Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Implement halftones type 6, 10, 16 in PDF interpreter.
-Use default halftone when the halftone type is incorrect.
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-18T000337.786299Z"></a>
-2010-07-18T00:03:37.786299Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Recognize enumerated color space #12 as CMYK following JPX baseline spec.
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-17T212339.853613Z"></a>
-2010-07-17T21:23:39.853613Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Re-implement handling of named page sizes to avoid dependence on
-the definitions of compatibility operators (a4, letter, etc.)
-in userdict. Bug 691458.
-</pre>
-<p>[Resource/Init/gs_init.ps Resource/Init/gs_setpd.ps Resource/Init/gs_statd.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-17T000709.985181Z"></a>
-2010-07-17T00:07:09.985181Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Remove unused variables CC_D and CC_INT from all makefiles.
-</pre>
-<p>[psi/os2.mak base/unixhead.mak base/bcwin32.mak base/openvms.mak base/watcw32.mak base/msvccmd.mak base/wccommon.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-16T204049.337914Z"></a>
-2010-07-16T20:40:49.337914Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Fix the bug that prevented recognition of GenericResourceDir/Category/Name
-as a valid resource path and required inclusion of GenericResourceDir in
-the search path to find the same resource by searching.
-
-New procedure does the following:
-1. Returns GenericResourceDir/Category/Name if it exists.
-2. Searches for Category/Name in LIBPATH. Returns actual path if found.
-3. For non-existing resources return the same path as (1).
-
-Old implementation added GenericResourceDir twice, didn't close files,
-used system memory, called expensive procedures twice, etc.
-
-Regression testing shows trivial differences in 23-07.ps, which prints
-the length of ResourceFileName procedure.
-This is a partial fix for bug 691408.
-</pre>
-<p>[Resource/Init/gs_res.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-16T195803.971410Z"></a>
-2010-07-16T19:58:03.971410Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Prepend icc directory to device profile name if the default name is
-used so that we have it during clist reading. This is a fix for the
-iccprofiles/ problem in 691408 when compile inits is not used. Also,
-fix so that the profile name is allocated in non-gc memory. This was
-a source of issues with the userparams dict not seeming to be traced
-or at least not getting its members relocated if a profile in the icc
-manager was relocated. This fixes the breaking of the psdcmyk device
-in rev 11499. Also removal of spurious warning messages.</pre>
-<p>[base/gsicc_manage.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-15T204206.487509Z"></a>
-2010-07-15T20:42:06.487509Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Change pdf14_put_image so that the gx_default_begin_typed_image will
-be able to call the device's 'begin_image' which is often hooked for
-device specific (hardware accelerated) image rendering. This avoids
-the default image rendering which results in LOTS of fill_rectangle
-calls. Found with customer 532.
-</pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-15T192838.670595Z"></a>
-2010-07-15T19:28:38.670595Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-The other half of the version.mak change.
-</pre>
-<p>[Resource/Init/gs_init.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-15T181417.190964Z"></a>
-2010-07-15T18:14:17.190964Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Update version to 9.00 PRE-RELEASE (with a bogus date, but before Aug 1)
-This will serve to notify folks what the next release will be (not 8.72)
-</pre>
-<p>[base/version.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-15T144939.770856Z"></a>
-2010-07-15T14:49:39.770856Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Improve Ghostscript operation when current directory is not included in the
-search path.
-1. Make file path separators at the end of LIBPATH entries optional to reduce
-the number of trivial configuration errors.
-2. Search LIBPATH list for valid iccprofiles/ directory as a sibling to
-(Resource) and set it as a default to ensure a valid default.
-This code follows /GenericResourceDir example.
-3. Make sure that the path name derived from /GenericFontDir is is not
-searched but other font file names are searched. Earlier code relied on
-a feature of .libfile not searching for an absolute path and failed
-when the path was relative.
-Partial fix for bugs 691350, 691408.
-</pre>
-<p>[Resource/Init/gs_lev2.ps Resource/Init/gs_fonts.ps Resource/Init/gs_res.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-15T054255.376283Z"></a>
-2010-07-15T05:42:55.376283Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Add copying default ICC profiles to disk-install location. This is necessary
-for the builds with COMPILE_INITS=0, which looks for ICC profiles on disk.
-Thanks to Hin-Tak for the patch. Bug 691449.
-</pre>
-<p>[base/unixinst.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-14T212533.726848Z"></a>
-2010-07-14T21:25:33.726848Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Allow the CUPS Raster backend alternatively output compressed (version 2)
-CUPS Raster data (bug #689885).
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-13T183029.088597Z"></a>
-2010-07-13T18:30:29.088597Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Ensure the local variable into which we read Truetype cmap table data
-(platform ID, encoding ID etc) is actually large enough to hold all
-the data we read into it.
-
-Bug 691452 (part 1)
-
-No cluster differences expected.</pre>
-<p>[base/gsfcid2.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-13T082456.010563Z"></a>
-2010-07-13T08:24:56.010563Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Update the documentation on producing PDF/X to make it clear that -sProcessColorModel
-is an absolute requirement, even when using -dUseCIEColor, and that the PDFA_def.ps
-file must be edited, at the very least to alter the ICCProfile entry.
-
-Also made some minor syntax changes in PDF/A and PDF/X documentation for greater clarity.
-</pre>
-<p>[doc/Ps2pdf.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-13T070459.625768Z"></a>
-2010-07-13T07:04:59.625768Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for Bug 691444. Issue was introduced when interpolation max output range
-was set to be 65535 so that the output could be fed directly into CMM.
-Problem was for HT output devices like pbmraw the interpolation filter
-ignored the max range setting and used a max value of the frac range as
-output. This fixes a number of files that had regressions. Files checked
-with bmpcmp.</pre>
-<p>[base/sidscale.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-13T012010.578834Z"></a>
-2010-07-13T01:20:10.578834Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for bug 691445. pdf14 mapping procs were not paying attention to the
-trans device in the imager state. bmpcmp showed that this fixed several
-files.</pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-12T150357.186505Z"></a>
-2010-07-12T15:03:57.186505Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-In the event the FAPI code has to replace the FontBBox array, make sure the new
-array is marked executable.
-
-No cluster differences expected.</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-11T152614.804339Z"></a>
-2010-07-11T15:26:14.804339Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for overprint regressions introduced with icc branch merge. Review of bmp
-compares reveals that this fixes a number of issues hence the large number of
-differences with the commit. There is one regression introduced with this commit,
-which is IA3Z0302.pdf.pdf.pkmraw.300 page 2 a bug will be opened for this. Also,
-review of Atona_Technical_1v1_x3.pdf.pam.72 reveals there some overprint issues may
-still exist with bitmap and halftone image overprinting on top of spotcolors when
-Overprint is true and and Overprint mode is set to On. This issue may have existed
-prior to the icc commit. Will open a bug to investigate.</pre>
-<p>[base/gsicc_create.c base/gxcspace.h base/gscspace.c base/gsicc.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-10T012854.795367Z"></a>
-2010-07-10T01:28:54.795367Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix 'status' operator to return false when the IODevice prefix is
-not found instead of undefinedfilename. Found while working on 691408.
-</pre>
-<p>[psi/zfile.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-09T183119.790276Z"></a>
-2010-07-09T18:31:19.790276Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix to use stable memory for profiledir in icc_manager structure and change
-all 'current_' functions to return the actual value set, the default, or
-an empty string if no default. Also set the default ICCProfilesDir to
-%rom%iccprofiles which will work if COMPILE_INITS=1. This should also be
-set by the PS init code (see bug 691408).
-</pre>
-<p>[psi/zusparam.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-09T094017.170342Z"></a>
-2010-07-09T09:40:17.170342Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Improve Windows batch files.
-Bug #691440 &quot;Windows bat files use relative paths and write to non-temp dir&quot;
-
-As suggested by Bjorn Martensson in bug #691440. Altered all batch files which call
-other batch files so that they prepend the call with the location the original
-batch file was executed from. This allows batch files such as ps2pdf.bat to be called
-from locations other than the Ghostscript 'lib' directory.
-
-Also altered the location of temporary files created by the batch files to the Windows
-temporary folder by using the %TEMP% environment variable. If this variable is not set
-for some reason then this will still default to the current directory, as it does now.
-This allows batch files to be run from directories which are read only.
-
-Since these files are not used by our (Linux) cluster there will be no differences. I
-have tested a number of the scripts, but not all of them. The ones I have tested seem
-to work well.
-
-I finally found a reference which states that the %~d batch parameter was introduced
-to Windows in NT4, this means that these batch files will likely fail on older versions
-of Windows (ie Windows 3.x/95/98). I don't believe we need to support such antiquated
-Operating Systems any further.</pre>
-<p>[lib/pf2afm.bat lib/gsdj500.bat lib/ps2ascii.bat lib/ps2pdfxx.bat lib/lpr2.bat lib/gsndt.bat lib/gstt.bat lib/eps2eps.bat lib/pdf2dsc.bat lib/gsbj.bat lib/ps2epsi.bat lib/gsdj.bat lib/dumphint.bat lib/ps2ps2.bat toolbin/msvcxml.bat lib/gsnd.bat lib/font2c.bat lib/pdfopt.bat lib/gst.bat lib/pdf2ps.bat lib/ps2pdf.bat lib/gslj.bat lib/bdftops.bat lib/pfbtopfa.bat lib/ps2pdf12.bat lib/ps2pdf13.bat lib/ps2pdf14.bat lib/gslp.bat lib/lpgs.bat lib/ps2ps.bat lib/pftogsf.bat]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-08T200159.912724Z"></a>
-2010-07-08T20:01:59.912724Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Extend the experimental ENABLE_TRAP_AMALGAMATION code to the
-TEMPLATE_slant_into_trapezoids cases too. The current code generates 3
-trapezoids; the new code will (if the option is enabled) attempt to
-amalgamate the top/bottom traps into the middle one.
-
-Enabling this code (but disabling the existing code for trap amalgamation)
-shows no differences. Enabling all the trap amalgamation code shows 888
-differences, all fairly innocuous.
-
-As this code is going in disabled, no cluster differences are expected.
-
-</pre>
-<p>[base/gxfillts.h base/gxfill.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-08T162020.892723Z"></a>
-2010-07-08T16:20:20.892723Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Update the Ghostscript man page to reflect the new default for -P option
-made by the rev. 11494.
-</pre>
-<p>[man/gs.1]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-07T212755.422122Z"></a>
-2010-07-07T21:27:55.422122Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-clusterpush.pl with no options now tests language_switch build as well as gs, pcl, and xps.
-
-Also some minor documentation improvements.
-</pre>
-<p>[toolbin/localcluster/clusterpush.pl toolbin/localcluster/readme]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-07T174709.812924Z"></a>
-2010-07-07T17:47:09.812924Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Dont't search for initialization files in the current directory first
-by default because this leads to well-known security and confusion problems.
-Do this only on the user's request by -P switch. Also revert rev. 11468,
-which is no longer needed. Bug 691350.
-</pre>
-<p>[base/openvms.mmk psi/zfile.c doc/Use.htm base/bcwin32.mak base/ugcclib.mak base/Makefile.in base/unix-gcc.mak base/macos-mcp.mak toolbin/msvcxml.bat psi/os2.mak base/watclib.mak base/openvms.mak base/macosx.mak base/watcw32.mak psi/msvc32.mak base/unixansi.mak base/msvclib.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-07T134957.894248Z"></a>
-2010-07-07T13:49:57.894248Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix : temporary memory device not finalized.
-
-clist_init_data creates a temporary memory device in order to &quot;get the memory planarity
-set up&quot;, using a local variable to hold the device. When the function exits the
-variable goes out of scope and disappears.
-
-Because the memory device is a forwarding device it increments the reference count of
-its target, but because it is never finalized it does not decrement the reference count
-when it is destroyed, leading to an incorrect target reference count.
-
-This only affects pdfwrite at present, but it prevents valid PDF files being written
-because the file is only terminated when the pdfwrite device reference count reaches
-0 and the pdfwrite device is closed.
-
-Added calls to finalize the device before discarding it.
-
-No expected differences.
-</pre>
-<p>[base/gxclist.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-06T222732.077335Z"></a>
-2010-07-06T22:27:32.077335Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Increase the max number of color components to 14 to accomodate a new
-record (13) found in the wild. Bug 691425.
-</pre>
-<p>[base/gsccolor.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-06T092540.558632Z"></a>
-2010-07-06T09:25:40.558632Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Named destinations with no /Page not working properly
-
-Bug #691344 &quot;REGRESSION: ps2pdf of 8.70 generates correct hyperlinks but not ps2pdf of
-8.71&quot;
-
-The revisions 9779 and 9788 fixed a problem where DOCVIEW pdfmarks without a /Page or
-/View entry were producing invalid PDF files, and a problem with DEST pdfmarks arising
-from it.
-
-Because DOCVIEW and DEST pdfmarks share some common code in pdfwrite to create a
-Destination annotation in the outptu PDF, this still left some confusion in the code.
-The problem was that DOCVIEW pdfmarks need not contain Page or View data, but named
-destinations *must*, but pdfmarks need not specify, in which case the current page is
-used.
-
-Added a parameter to pdf_make_dest which allows us to differentiate the two cases and
-use the current page number for a named destination if no page is supplied.
-
-The regression suite can't test this non-printing feature, so no differences are
-expected.
-</pre>
-<p>[base/gdevpdfm.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-06T070453.806003Z"></a>
-2010-07-06T07:04:53.806003Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Improve handling an error condition as suggested by Alex Cherepanov in Bug #691435,
-comment 9. </pre>
-<p>[base/gdevpdfj.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-06T001144.270183Z"></a>
-2010-07-06T00:11:44.270183Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix BAND_LIST_STORAGE=memory to handle files that create compressed memory
-files &gt; 2Gb. Also add code to make the reporting of these file sizes a bit
-better, but portability may still be an issue. Reference Bug 690199 for
-customers 850 and 531.
-
-</pre>
-<p>[base/gxclmem.c base/gxclist.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-05T235146.696108Z"></a>
-2010-07-05T23:51:46.696108Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Replace all '==' executable names with '//== exec' in Ghostscript start-up
-code because MS driver redefines '==' in a way that requires write access to
-the top dictionary, and this is not always the case. Bug 689957.
-</pre>
-<p>[Resource/Init/gs_cmap.ps Resource/Init/gs_pdfwr.ps Resource/Init/pdf_main.ps Resource/Init/gs_resmp.ps Resource/Init/pdf_font.ps Resource/Init/gs_fonts.ps Resource/Init/pdf_base.ps Resource/Init/pdf_sec.ps Resource/Init/gs_ttf.ps Resource/Init/pdf_draw.ps Resource/Init/gs_cff.ps Resource/Init/gs_fapi.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-05T161838.343520Z"></a>
-2010-07-05T16:18:38.343520Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Set svn:ignore property for all remaining generated files in jasper,
-jbig2dec, and tiff directories.
-</pre>
-<p>[tiff/contrib/iptcutil tiff/contrib/tags tiff/build tiff/tools tiff tiff/contrib tiff/contrib/mac-mpw tiff/contrib/acorn tiff/html jasper/src/libjasper/include/jasper tiff/contrib/mac-cw tiff/contrib/dbs tiff/html/images tiff/man tiff/contrib/win_dib tiff/html/man tiff/libtiff tiff/test tiff/contrib/addtiffo jbig2dec tiff/port tiff/contrib/ras tiff/contrib/mfs tiff/contrib/pds tiff/contrib/dbs/xtiff tiff/contrib/stream]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-05T151009.278642Z"></a>
-2010-07-05T15:10:09.278642Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Add a pair of parentheses to silence a gcc compiler warning. Also extend the comment
-slightly to be a little more informative.
-
-No differences expected.
-</pre>
-<p>[base/gdevpdfj.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-05T051316.304757Z"></a>
-2010-07-05T05:13:16.304757Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Use the presence of /CIDSystemInfo instead of /Subtype value to decide
-whether the object is a CID font. The former is required by Acrobat, the
-latter appears to be ignored by Acrobat, and so may be wrong. Bug 691426.
-</pre>
-<p>[Resource/Init/pdf_font.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-05T012343.139942Z"></a>
-2010-07-05T01:23:43.139942Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-test for emptiness of HAVE_FONTCONFIG is better than non-yes-ness of
-enable_fontconfig;
-fine-tuning of r11448 to --disable-cairo when fontconfig is not available or
-user-disabled</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-05T011830.861454Z"></a>
-2010-07-05T01:18:30.861454Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-new/renamed documentation file libpng-1.2.44.txt missed in r11482 for
-libpng 1.2.42-&gt;1.2.44 upgrade</pre>
-<p>[libpng/libpng-1.2.44.txt]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-04T190417.740307Z"></a>
-2010-07-04T19:04:17.740307Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Reaplly Hin-Tak's patch, rev. 11453, which was rolled back by the rev. 11462.
-
-Apply diff between stock 1.2.42 &lt;-&gt; 1.2.44 to upgrade to libpng 1.2.44
-- bug
-fixes - CVE-2010-1205. Bug 691438.
-</pre>
-<p>[libpng/pngrtran.c libpng/scripts/makefile.gcmmx libpng/contrib/pngminim/encoder/gather.sh libpng/scripts/makefile.sgi libpng/scripts/makefile.sco libpng/scripts/makefile.hpgcc libpng/KNOWNBUG libpng/projects/xcode/libpng.xcodeproj/project.pbxproj libpng/scripts/pngos2.def libpng/scripts/makefile.nommx libpng/scripts/makefile.linux libpng/pngmem.c libpng/png.c libpng/contrib/pngminim/decoder/gather.sh libpng/scripts/makefile.64sunu libpng/scripts/makefile.elf libpng/scripts/libpng-config-head.in libpng/png.h libpng/CMakeLists.txt libpng/pngrio.c libpng/pngpread.c libpng/Y2KINFO libpng/scripts/makefile.netbsd libpng/pngwio.c libpng/pngrutil.c libpng/scripts/makefile.hpux libpng/scripts/makefile.darwin libpng/scripts/makefile.sggcc libpng/README libpng/contrib/pngminim/decoder/makefile libpng/scripts/makefile.32sunu libpng/libpngpf.3 libpng/scripts/makefile.solaris-x86 libpng/libpng-1.2.42.txt libpng/contrib/pngminim/preader/makefile libpng/scripts/makefile.solaris libpng/pngwtran.c libpng/contrib/pngminim/preader/gather.sh libpng/scripts/makefile.mingw libpng/scripts/makefile.aix libpng/scripts/makefile.hp64 libpng/scripts/png32ce.def libpng/scripts/makefile.beos libpng/scripts/makefile.ne12bsd libpng/pngread.c libpng/scripts/pngw32.def libpng/pngget.c libpng/INSTALL libpng/scripts/makefile.cegcc libpng/CHANGES libpng/contrib/pngminim/encoder/makefile libpng/projects/wince.txt libpng/libpng.3 libpng/example.c libpng/scripts/makefile.so9 libpng/pngwrite.c libpng/pngconf.h libpng/pngset.c libpng/LICENSE libpng/png.5 libpng/pngwutil.c libpng/scripts/makefile.openbsd libpng/scripts/makefile.dec libpng/scripts/README.txt libpng/scripts/makefile.cygwin libpng/pngtest.c libpng/ANNOUNCE libpng/scripts/libpng.pc.in]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-03T002940.754683Z"></a>
-2010-07-03T00:29:40.754683Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-missed linker defines needed to build under 64-bit windows in a
-previous commit r11388 for bug 691302</pre>
-<p>[psi/msvc32.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-01T215829.492747Z"></a>
-2010-07-01T21:58:29.492747Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Bubble up of error when allocation of default profile cmm handle fails. Fix for bug 691429</pre>
-<p>[base/gsicc_manage.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-01T211355.381754Z"></a>
-2010-07-01T21:13:55.381754Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-revert r11469(r11455) - wrong fix to bug 690428</pre>
-<p>[base/gdevxcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-01T190829.177579Z"></a>
-2010-07-01T19:08:29.177579Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Enhancement (pdfwrite) : Fall back to Flate instead of JPEG when an image turns out
-short.
-
-Bug #691435 &quot;any PDFSETTINGS besides /default gives dictfull error&quot;
-
-There are two problems; firstly when an error is encountered closing a filter the
-error code (-1 or -2 usually) is returned and interpreted as a regular GS error,
-resulting in ridiculous error messages. Modified to return ioerror instead.
-
-Secondly, when an image terminates with insufficient data and pdfwrite is creating a
-DCT encoded image, we can't complete the image. In this case try to fall back to the
-simple Flate compressed stream instead.
-
-No differences expected.
-</pre>
-<p>[base/gdevpdfj.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-01T171423.564053Z"></a>
-2010-07-01T17:14:23.564053Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for Bug 691431. This was caused by a PS CIE color space being
-used for a transparency group color space. That really should not
-be allowed since those color spaces are unidirectional. They are
-installed though when -dUseCIEColor is used with a PDF file that has
-transparency. Solution is to use the default ICC profiles for the group
-color space when this occurs.</pre>
-<p>[base/gstrans.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-01T121920.914734Z"></a>
-2010-07-01T12:19:20.914734Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Revert revision 11472 as it breaks almost every file in the cluster tests,
-and it's preventing other meaningful work being done.
-
-</pre>
-<p>[base/gp_unifn.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-01T004157.037474Z"></a>
-2010-07-01T00:41:57.037474Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-reapply 11457</pre>
-<p>[base/gs_dll_call.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-01T004043.889090Z"></a>
-2010-07-01T00:40:43.889090Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-reapply 11456</pre>
-<p>[base/gp_unifn.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-01T003616.428446Z"></a>
-2010-07-01T00:36:16.428446Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-reapply 11454 for outdated config.guess config.sub. see original commit log</pre>
-<p>[jpeg/config.guess jpeg/config.sub]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-01T003305.624689Z"></a>
-2010-07-01T00:33:05.624689Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-typo that causes linker error if one does not do make clean between builds</pre>
-<p>[base/lib.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-07-01T000022.982087Z"></a>
-2010-07-01T00:00:22.982087Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-reapply r11455 - see original commit log for details</pre>
-<p>[base/gdevxcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-30T233411.835858Z"></a>
-2010-06-30T23:34:11.835858Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-security patch from Werner Fink, to disable loading init files from
-group/world-writable directories - bug 691350</pre>
-<p>[psi/zfile.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-30T221202.295636Z"></a>
-2010-06-30T22:12:02.295636Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Initialize profile member variables that are part of serialization.
-Fix for Bug 691433
-</pre>
-<p>[base/gsicc_manage.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T180629.735123Z"></a>
-2010-06-29T18:06:29.735123Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-remove obsolete clusterpush scripts.
-</pre>
-<p>[/trunk/ghostpdl/tools/clusterpush.sh toolbin/clusterpush.sh]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T171745.269232Z"></a>
-2010-06-29T17:17:45.269232Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-revert back to 11450.
-</pre>
-<p>[/trunk/ghostpdl/main/pcl6_gcc.mak libpng/pngrtran.c libpng/scripts/makefile.gcmmx base/ugcclib.mak libpng/contrib/pngminim/encoder/gather.sh /trunk/ghostpdl/xps/xpspath.c base/unix-gcc.mak libpng/scripts/makefile.sgi base/gp_unifn.c base/macos-mcp.mak libpng/scripts/makefile.sco libpng/scripts/makefile.hpgcc /trunk/ghostpdl/main/pcl6_msvc.mak libpng/KNOWNBUG libpng/projects/xcode/libpng.xcodeproj/project.pbxproj libpng/scripts/pngos2.def base/macosx.mak libpng/scripts/makefile.nommx libpng/scripts/makefile.linux jpeg/config.guess base/unixansi.mak libpng/pngmem.c base/msvclib.mak libpng/png.c libpng/contrib/pngminim/decoder/gather.sh libpng/scripts/makefile.64sunu jpeg/config.sub libpng/scripts/libpng-config-head.in libpng/scripts/makefile.elf libpng/png.h base/lib.mak libpng/CMakeLists.txt libpng/pngrio.c libpng/Y2KINFO libpng/pngpread.c libpng/scripts/makefile.netbsd /trunk/ghostpdl/xps/xps_msvc.mak libpng/pngwio.c libpng/pngrutil.c libpng/scripts/makefile.hpux libpng/scripts/makefile.darwin libpng/scripts/makefile.sggcc /trunk/ghostpdl/xps/xpsglyphs.c libpng/README doc/Make.htm libpng/contrib/pngminim/decoder/makefile libpng/scripts/makefile.32sunu libpng/libpngpf.3 libpng/scripts/makefile.solaris-x86 /trunk/ghostpdl/language_switch/pspcl6_msvc.mak libpng/libpng-1.2.42.txt libpng/contrib/pngminim/preader/makefile libpng/libpng-1.2.44.txt libpng/scripts/makefile.solaris base/Makefile.in libpng/pngwtran.c libpng/contrib/pngminim/preader/gather.sh /trunk/ghostpdl/xps/xpstile.c /trunk/ghostpdl/xps/xpsgradient.c libpng/scripts/makefile.hp64 base/gs_dll_call.h libpng/scripts/makefile.aix libpng/scripts/makefile.mingw libpng/scripts/png32ce.def /trunk/ghostpdl/common/msvc_top.mak libpng/scripts/makefile.beos base/watclib.mak /trunk/ghostpdl/xps/xpsopacity.c libpng/scripts/makefile.ne12bsd libpng/pngread.c /trunk/ghostpdl/xps/xpspage.c libpng/scripts/pngw32.def libpng/pngget.c libpng/INSTALL libpng/scripts/makefile.cegcc libpng/CHANGES libpng/contrib/pngminim/encoder/makefile libpng/libpng.3 libpng/example.c libpng/projects/wince.txt base/bcwin32.mak libpng/scripts/makefile.so9 libpng/pngconf.h libpng/pngwrite.c libpng/pngset.c libpng/LICENSE libpng/png.5 libpng/pngwutil.c base/openvms.mak base/gdevxcmp.c libpng/scripts/makefile.openbsd libpng/scripts/makefile.dec base/watcw32.mak base/unix-dll.mak libpng/scripts/README.txt libpng/scripts/makefile.cygwin psi/msvc32.mak libpng/pngtest.c libpng/ANNOUNCE /trunk/ghostpdl/xps/xpsimage.c libpng/scripts/libpng.pc.in]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T070829.009258Z"></a>
-2010-06-29T07:08:29.009258Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-more cygwin/mingw-related patches from Jan Nieuwenhuizen (lilypond/gub) ; this
-one depends on features of GNU make, so it is added as comments to avoid
-breaking build with non-GNU make</pre>
-<p>[base/unix-dll.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T070545.877229Z"></a>
-2010-06-29T07:05:45.877229Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-avoid re-define _Windows if it is already defined; one of the cygwin/mingw-related
-patches from Jan Nieuwenhuizen (lilypond/gub)</pre>
-<p>[base/gs_dll_call.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T070425.796552Z"></a>
-2010-06-29T07:04:25.796552Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-cygwin is one platform which uses the unix file name interface but is
-sensitive to binary/text mode; one of the cygwin/mingw-related patches from
-Jan Nieuwenhuizen (lilypond/gub)</pre>
-<p>[base/gp_unifn.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T064759.438186Z"></a>
-2010-06-29T06:47:59.438186Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-gx_device_has_color() was changed 8 years ago in the deviceN commit (r2925),
-from just color_info.numcomponents &gt; 1 to
-|| (dev)-&gt;color_info.gray_index == GX_CINFO_COMP_NO_INDEX .
-
-This has some unfortunate side-effect for continuous tone gray devices which
-doesn't support transparency, such as a 8-bit gray X11 display, which goes
-down the wrong code path. These are quite rare so it took 7 years for the bug
-(bug 690428) to be seen.
-
-</pre>
-<p>[base/gdevxcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T060526.121392Z"></a>
-2010-06-29T06:05:26.121392Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-updating jpeg config.sub config.guess to that from
-libpng 1.2.44; bug 690486</pre>
-<p>[jpeg/config.guess jpeg/config.sub]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T053019.407679Z"></a>
-2010-06-29T05:30:19.407679Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-apply diff between stock 1.2.42 &lt;-&gt; 1.2.44 to upgrade to
-libpng 1.2.44 - bug fixes - CVE-2010-1205</pre>
-<p>[libpng/pngrtran.c libpng/scripts/makefile.gcmmx libpng/contrib/pngminim/encoder/gather.sh libpng/scripts/makefile.sgi libpng/scripts/makefile.sco libpng/scripts/makefile.hpgcc libpng/KNOWNBUG libpng/projects/xcode/libpng.xcodeproj/project.pbxproj libpng/scripts/pngos2.def libpng/scripts/makefile.nommx libpng/scripts/makefile.linux libpng/pngmem.c libpng/png.c libpng/contrib/pngminim/decoder/gather.sh libpng/scripts/makefile.64sunu libpng/scripts/makefile.elf libpng/scripts/libpng-config-head.in libpng/png.h libpng/CMakeLists.txt libpng/pngrio.c libpng/pngpread.c libpng/Y2KINFO libpng/scripts/makefile.netbsd libpng/pngwio.c libpng/pngrutil.c libpng/scripts/makefile.hpux libpng/scripts/makefile.darwin libpng/scripts/makefile.sggcc libpng/README libpng/contrib/pngminim/decoder/makefile libpng/scripts/makefile.32sunu libpng/libpngpf.3 libpng/scripts/makefile.solaris-x86 libpng/libpng-1.2.42.txt libpng/libpng-1.2.44.txt libpng/contrib/pngminim/preader/makefile libpng/scripts/makefile.solaris libpng/pngwtran.c libpng/contrib/pngminim/preader/gather.sh libpng/scripts/makefile.mingw libpng/scripts/makefile.aix libpng/scripts/makefile.hp64 libpng/scripts/png32ce.def libpng/scripts/makefile.beos libpng/scripts/makefile.ne12bsd libpng/pngread.c libpng/scripts/pngw32.def libpng/pngget.c libpng/INSTALL libpng/scripts/makefile.cegcc libpng/CHANGES libpng/contrib/pngminim/encoder/makefile libpng/libpng.3 libpng/projects/wince.txt libpng/example.c libpng/scripts/makefile.so9 libpng/pngwrite.c libpng/pngconf.h libpng/pngset.c libpng/LICENSE libpng/png.5 libpng/pngwutil.c libpng/scripts/makefile.openbsd libpng/scripts/makefile.dec libpng/scripts/README.txt libpng/scripts/makefile.cygwin libpng/pngtest.c libpng/ANNOUNCE libpng/scripts/libpng.pc.in]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T052507.282125Z"></a>
-2010-06-29T05:25:07.282125Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-change documentation as --enable-dynamics is no longer required
-for &quot;make so&quot; to work</pre>
-<p>[doc/Make.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T052009.043972Z"></a>
-2010-06-29T05:20:09.043972Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-split lcms code build into arch-specific targets; try to make both windows
-inline assembly and unix &quot;make so&quot; work simultaneously; bug 691427</pre>
-<p>[base/watclib.mak base/lib.mak base/bcwin32.mak base/openvms.mak base/ugcclib.mak base/macosx.mak base/watcw32.mak base/Makefile.in base/unix-gcc.mak base/unixansi.mak psi/msvc32.mak base/macos-mcp.mak base/msvclib.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T051638.524502Z"></a>
-2010-06-29T05:16:38.524502Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-move the DYNAMIC_* defines out of the --enable-dynamic condition so that it
-applies generally; try to &quot;make so&quot; work with just
-./configure ; many bugs ask for make so to work</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T043410.440639Z"></a>
-2010-06-29T04:34:10.440639Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-switch autoconf png test away from testing for a soon-to-be-obsolete routine
-to one we actually use, to smooth over the libpng 1.2.x to 1.4.x
-transition; bug 691111</pre>
-<p>[jbig2dec/configure.ac base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T041547.742872Z"></a>
-2010-06-29T04:15:47.742872Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-make --disable-fontconfig imples --disable-cairo; bug 690690</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T040453.158322Z"></a>
-2010-06-29T04:04:53.158322Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-tries to remove empty *obj/*bin directories when invoking &quot;make distclean&quot;; bug 690871</pre>
-<p>[base/unix-end.mak base/Makefile.in base/unix-dll.mak base/unix-gcc.mak base/unixansi.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T034817.519902Z"></a>
-2010-06-29T03:48:17.519902Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-check for GNU sed and switch to alternative sed options if sed is non-GNU; bug 691292</pre>
-<p>[cups/pstopxl.in base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T034430.895095Z"></a>
-2010-06-29T03:44:30.895095Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-Part 2 of update (new files) posted to 687983, corrected for current svn HEAD.</pre>
-<p>[contrib/pscolor/black.pdf contrib/pscolor/color.pdf contrib/pscolor/colorsplit.vcproj contrib/pscolor/black.ps contrib/pscolor/color.ps contrib/pscolor/common.mak contrib/pscolor/input.ps contrib/pscolor/windows.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T034118.718227Z"></a>
-2010-06-29T03:41:18.718227Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-Part 1 of the update (modifications to checked-in files)
-to the pscolor code posted in 687983, corrected for current svn head.
-
-</pre>
-<p>[contrib/pscolor/Makefile contrib/pscolor/test.c contrib/pscolor/instream.yy]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T033846.508455Z"></a>
-2010-06-29T03:38:46.508455Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-ijs communication should be all binary; left-over uncommitted patch from past ijs-related work</pre>
-<p>[ijs/ijs_server_example.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T033445.878285Z"></a>
-2010-06-29T03:34:45.878285Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-implements ./configure --with-ufst=UFST_ROOT_DIR ; bug 691293</pre>
-<p>[doc/Make.htm base/Makefile.in base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T023238.254860Z"></a>
-2010-06-29T02:32:38.254860Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Removal of static prototype that has no function.</pre>
-<p>[base/gsicc_cache.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-29T005032.521441Z"></a>
-2010-06-29T00:50:32.521441Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix lack of end-of-line in file.</pre>
-<p>[base/gsicc_littlecms.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-28T150431.998704Z"></a>
-2010-06-28T15:04:31.998704Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Fix a typo, thanks to Ken for spotting this in review.
-</pre>
-<p>[base/gxpcmap.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-28T105053.201708Z"></a>
-2010-06-28T10:50:53.201708Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Warnings of problems within lcms only occur now in debug mode. Fix for Bug 691401</pre>
-<p>[base/gsicc_littlecms.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-28T051659.820980Z"></a>
-2010-06-28T05:16:59.820980Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Interface with lcms so that the memory allocators make use of ghostscript's
-allocator. This required fixing a few bugs in littlecms where he was using
-free instead of _cmsFree and also having lcms.h provide the prototypes if the
-external mem alloc is defined. Performed cluster push with no problem. Thanks
-to Henry for helping me track down a 64 bit issue.</pre>
-<p>[lcms/include/lcms.h base/lib.mak lcms/src/cmslut.c base/lcms.mak lcms/src/cmsio1.c base/gsicc_littlecms.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-26T200613.718954Z"></a>
-2010-06-26T20:06:13.718954Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-The ad hoc gstate setup for patterns should not call grestore after
-gsave when erasing colored patterns because it results in
-&quot;wraparound&quot;, creating another gstate (no saved gstate exists when the
-pattern is painted), see gsstate.c:gs_grestore() vs
-gsstate.c:gs_grestore_only(). Thanks to Ken Sharp for noticing the the
-extra gstate. No expected differences.
-</pre>
-<p>[base/gxpcmap.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-26T175906.494303Z"></a>
-2010-06-26T17:59:06.494303Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-This file should have been checked in with revision 11433 which will
-not compile without this change.
-</pre>
-<p>[base/gdevpxat.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-25T120050.643763Z"></a>
-2010-06-25T12:00:50.643763Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Provide more robust behaviour when FT fails to render a glyph. Inistead
-of silently continuing when FT errors on a glyph, we'll now attempt to use
-the notdef, if the notdef triggers an error, we signal the error to the GS
-world. This ensures that any time we expect processing to continue there is
-valid glyph information available to the cache and other downstream devices.
-This causes one regression difference with 34_all.PS, where an extra TTF
-notdef is rendered.
-
-Bug 691416</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-24T071111.011423Z"></a>
-2010-06-24T07:11:11.011423Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Remove a couple of currently unused variables to silence a harmless compiler warning.
-</pre>
-<p>[base/gdevpsft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-23T171440.891928Z"></a>
-2010-06-23T17:14:40.891928Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Simplify and fix the implementation of operator --mul--, which mishandled
-some cases like &quot;16#80000000 -1 mul&quot;. Bug 691412.
-</pre>
-<p>[psi/zarith.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-23T155639.786311Z"></a>
-2010-06-23T15:56:39.786311Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-This patch adds limited support for TrueType collection fonts to pdfwrite and ps2write.
-
-In the PostScript world TTC fonts are never passed down to pdfwrite, we only ever see
-TrueType fonts. XPS, however, can pass back TrueType collection SNFTS data. This patch
-uses the first font from the TrueType collection and writes that to the output file.
-This may be too limited and may require further work in future.
-
-</pre>
-<p>[base/gdevpsft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-23T143308.852324Z"></a>
-2010-06-23T14:33:08.852324Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for bug691415. When equivalent ICC profile is already created we
-should just use it. Thanks to Ken for getting the details together.</pre>
-<p>[base/gscsepr.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-23T050213.734047Z"></a>
-2010-06-23T05:02:13.734047Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for 691359. Problem tracked down by Alex.
-
-What lcms is trying to do is to figure out the best prelinearization
-for the incoming data prior to doing the CLUT interpolation. In the
-case when the input is RGB based and the output Gray, lcms was using
-uninitialized data in constructing is prelinearization.
-Tangentially related, there could still be problems with what lcms is
-doing here if the number of Input channels is 1 and the number of Output
-channels is 3. In that case, it is possible (but not likely) that I could
-have radically different gamma behavior in each of the RGB channels. Trans
-in such a case would be constructed based upon only one curve based on the
-red channel. In the real world, this is probably not a problem but ideally
-it would be optimal to use something that provides the best prelinearization
-in all three channels. That is an optimization for Marti to do and perhaps
-is already in lcms2.</pre>
-<p>[lcms/src/cmsgmt.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-22T145459.999510Z"></a>
-2010-06-22T14:54:59.999510Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Erase patterns with the color white instead of filling the pattern
-bitmap with 0 or 255.
-
-Previously the initialization was only used when anti aliasing was
-enabled, now initial erasing is done for all colored patterns,
-eliminating a long standing UMR in the pcl code where the pattern was
-combined with the destination/source with indeterminate results. The
-UMR manifested in frequent regression reports in the pcl tests
-(c321.bin for example), these reports should go away with this change,
-though (NB) the change only masks the underlying issue.
-
-</pre>
-<p>[psi/zpcolor.c base/gxpcmap.c base/gxpcolor.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-22T061254.377174Z"></a>
-2010-06-22T06:12:54.377174Z Masaki Ushizaka</strong></p>
-<blockquote>
-<pre>
-Fix for bug 689836 and 691248.
-
-Bug 689836 - Huffman tables with only positive values are decoded incorrectly
-Bug 691248 - jbig2dec doesn't handle 042_11 (Huffman Symbol Region)
-
-This patch fixes mulfunctions seen on standard huffman table K, L, M and N.
-A difference will be seen on tests_private/comparefiles/Bug690360.pdf.
-This file was affected by table K mulfunction and this is a improvement.
-
-</pre>
-<p>[jbig2dec/jbig2_hufftab.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-22T060012.605983Z"></a>
-2010-06-22T06:00:12.605983Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Revert rev. 7964 and use a different approach: allocate all structures
-and proceed with their initialization only if all allocations were
-successful. Fix memory corruption that happens at the PostScript
-stack overflow. Bug 691295.
-</pre>
-<p>[psi/idosave.h psi/ialloc.c psi/isave.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-22T055923.952778Z"></a>
-2010-06-22T05:59:23.952778Z Masaki Ushizaka</strong></p>
-<blockquote>
-<pre>
-Added test code for every line of each standard huffman tables.
-
-</pre>
-<p>[jbig2dec/jbig2_huffman.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-22T051553.089456Z"></a>
-2010-06-22T05:15:53.089456Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Add a /.notdef entry to /CharStrings dictionary if it's missing from an
-embedded Type1 font. Bug 691406, customer 130.
-</pre>
-<p>[Resource/Init/pdf_font.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-21T164155.147464Z"></a>
-2010-06-21T16:41:55.147464Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Removal of improper error message. Source of a potential access violation.</pre>
-<p>[base/gsicc_manage.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-21T150703.992218Z"></a>
-2010-06-21T15:07:03.992218Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Add the 'gs_error_Remap_Color' pseudo-error, a duplicate -f e_Remap_Color in the
-PostScript interpreter, to the 'base' error list so that PDL clients other than
-PostScript can make use of it for high-level pattern support.
-</pre>
-<p>[base/gserrors.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-21T011418.832712Z"></a>
-2010-06-21T01:14:18.832712Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-auto-detect host as *BSD and use a differently named obj directory;
-no effect on non-*BSDs. fixes bug 687214</pre>
-<p>[base/Makefile.in base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-21T003243.898825Z"></a>
-2010-06-21T00:32:43.898825Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-adding more borland-related build tips; part of borland build fixes (bug 691400)</pre>
-<p>[doc/Make.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-21T001242.541103Z"></a>
-2010-06-21T00:12:42.541103Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-got some garbage in the beginning of the file introduced in an earlier commit</pre>
-<p>[doc/Install.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-21T000112.712437Z"></a>
-2010-06-21T00:01:12.712437Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-nsis-based installer script, makefile adaptation, documentation update; bug 691363</pre>
-<p>[psi/winint.mak doc/Release.htm psi/nsisinst.nsi doc/Install.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-20T233847.757390Z"></a>
-2010-06-20T23:38:47.757390Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-borland build fix (bug 691400): borland defines P_tmpdir but not
-_P_tmpdir; similiar difference between borlandc and msvc has been
-seen with setmode/_setmode in the ijs code in ijs/ijs_server.c</pre>
-<p>[jasper/src/libjasper/base/jas_stream.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-20T233224.162240Z"></a>
-2010-06-20T23:32:24.162240Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-borland build fix (bug 691400): update and complete documentation on
-working around for too-many-warnings-equal-error problem of borland c++</pre>
-<p>[doc/Make.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-20T232934.775566Z"></a>
-2010-06-20T23:29:34.775566Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-borland fix (bug 691400): Borland c++ does not support c99 LL nor
-ULL, but use i64/ui64 like MSVC for 64-bit integer literals</pre>
-<p>[base/sha2.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-20T231137.618908Z"></a>
-2010-06-20T23:11:37.618908Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-4 borland build fixes (bug 691400):
-
-- hook up libtiff
-- build mkromfs
-- build import library *.lib corresponding to the dll
-- build the split-out make_filelist (see also r11388 for Bug 691302,
-which does it for msvc)
-
-</pre>
-<p>[base/bcwin32.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-20T230349.551572Z"></a>
-2010-06-20T23:03:49.551572Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-borland build does not create the obj and bin directories. part of borland build fix (691400)</pre>
-<p>[base/bcwin32.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-20T225732.647408Z"></a>
-2010-06-20T22:57:32.647408Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-defines a unix target, since win32 requires specific compiler flags;
-HP-UX make/MS nmake both issues a warning and borland make issues an
-error for duplicate targets; fixes bug 691337, and also part of the
-problems with borland build (bug 691400)</pre>
-<p>[base/libtiff.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-20T034503.823204Z"></a>
-2010-06-20T03:45:03.823204Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Fix malformed ICC profile generation on big endian systems, which was caused
-by confusion between internal and external representation of an integer.
-</pre>
-<p>[base/gsicc_create.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-20T030150.289956Z"></a>
-2010-06-20T03:01:50.289956Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Don't leave wild bytes at the end of a generated ICC profile. Fix Valgrind
-warnings and spurious hash value differences.
-</pre>
-<p>[base/gsicc_create.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-18T235923.662717Z"></a>
-2010-06-18T23:59:23.662717Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix so that when the CIE color spaces are released, the icc equivalent
-space is also rc decremented as is the profile.</pre>
-<p>[base/gscscie.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-18T180659.517404Z"></a>
-2010-06-18T18:06:59.517404Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for memory leak in creation of icc profile from def(g) objects.</pre>
-<p>[base/gsicc_create.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-18T020013.716745Z"></a>
-2010-06-18T02:00:13.716745Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Use operator --search-- instead of --token-- during PDF rebuilding
-to reduce the load on the name table, slightly improve the speed, and
-work around the bug 691005 in a few cases.
-</pre>
-<p>[Resource/Init/pdf_rbld.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-17T202333.279930Z"></a>
-2010-06-17T20:23:33.279930Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-adjust self-reference of bswin32.mak to correct location.
-Part 1 of fix to bug 691400</pre>
-<p>[base/bcwin32.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-17T200330.325885Z"></a>
-2010-06-17T20:03:30.325885Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-mentioning -P-/-P and further reference to the INITIALIZATION FILES and
-Use.htm in the man page. bug 691350</pre>
-<p>[man/gs.1]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-17T194605.887718Z"></a>
-2010-06-17T19:46:05.887718Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-add missing type def for gsicc_create_mashed_clut</pre>
-<p>[base/gsicc_create.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-17T193839.362075Z"></a>
-2010-06-17T19:38:39.362075Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-split make_filelist functionality out of setupgs, to allow UAC restriction
-during packaging of the installer. Bug 691302</pre>
-<p>[psi/dwsetup.cpp psi/winint.mak psi/msvc32.mak psi/mkfilelt.cpp]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-17T193128.160475Z"></a>
-2010-06-17T19:31:28.160475Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-add info about silent batch installation; bug 691268</pre>
-<p>[doc/Install.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-17T192820.229863Z"></a>
-2010-06-17T19:28:20.229863Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-rc_decrement any icc objects that may exist in the imager state that was
-created for handling the conversion from PS CIE objects to ICC profiles.</pre>
-<p>[base/gscie.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-17T180435.295987Z"></a>
-2010-06-17T18:04:35.295987Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Free up tag list when done creating icc profile from PDF cal type.</pre>
-<p>[base/gsicc_create.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-17T171334.616951Z"></a>
-2010-06-17T17:13:34.616951Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Change to help track down any memory leaks related to the new icc code.
-Also fix so that gs_init_iccmanager copies the null character from the default
-profile string names. There was a mismatch between what happened here and what
-happens when the default user params are set. This was causing the profiles to
-reset in the manager when they did not need to be.</pre>
-<p>[base/gsicc_manage.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-17T092018.689467Z"></a>
-2010-06-17T09:20:18.689467Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (FAPI) move two FAPI related members from the show enumerator structure to the text
-enumerator structure. This ensures that these members are always available for rendering
-and eliminates a GPF caused when a device's text_begin method returns a text enumerator
-rather than the show enumerator returned by gx_default_text_begin.
-
-No differences expected.
-</pre>
-<p>[base/gxchar.h base/gxtext.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-16T061125.298134Z"></a>
-2010-06-16T06:11:25.298134Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-a few more CRLF eol and svn property corrections</pre>
-<p>[zlib/contrib/dotzlib/LICENSE_1_0.txt zlib/contrib/vstudio/readme.txt zlib/contrib/masmx64/readme.txt base/gsicc_cache.h base/gsicc_manage.c base/gsicc_manage.h zlib/projects/visualc6/README.txt zlib/contrib/dotzlib/readme.txt]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-15T171715.944441Z"></a>
-2010-06-15T17:17:15.944441Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Rename of a few functions to match documentation, update of gdevwts.c to
-use new color architecture, addition of minor utility functions for use in gxps.
-This should not generate regressions.</pre>
-<p>[base/lib.mak base/gsicc_littlecms.h base/gsicc_cache.h base/gsicc_manage.c base/gscms.h base/gdevwts.c base/gsicc_manage.h base/gsicc_littlecms.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-15T165440.171304Z"></a>
-2010-06-15T16:54:40.171304Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Update of Color Architecture document in preparation for release of GS 9.0</pre>
-<p>[doc/Color_Architecture.tex doc/figures/XPS_Integer_Gray_RGB_Image.eps doc/figures/Overview.eps doc/figures/XPS_DeviceN.eps doc/figures/PDF_Render.eps doc/figures/XPS_Render.eps doc/GS9_Color_Management.pdf doc/figures/XPS_Vector_Color.eps doc/figures/XPS_RGB_Image_Float.eps doc/figures/PS_Spec.eps doc/Color_Architecture.pdf doc/GS9_Color_Management.tex doc/figures/PS_Render.eps doc/figures/PDF_Spec.eps]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-14T231027.633844Z"></a>
-2010-06-14T23:10:27.633844Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Modified line endings from CRLF -&gt; LF and propset to native.
-</pre>
-<p>[base/gsicc_cache.c base/gsicc_cache.h base/gsicc_manage.c base/gsicc_manage.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-14T184247.881614Z"></a>
-2010-06-14T18:42:47.881614Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Fix yet another case where memcpy() copies a memory block on itself.
-This doesn't cause any problems on Linux or Windows but violates the
-spec and irks Valgrind. Bug 691394.
-</pre>
-<p>[base/gsline.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-14T180749.834071Z"></a>
-2010-06-14T18:07:49.834071Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Remove the &quot;&lt;font&gt; is being rendered with FAPI=&lt;renderer&gt;&quot;
-messages. But leave a warning if we fall back to the old GS renderer.</pre>
-<p>[Resource/Init/gs_fapi.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-14T111907.131026Z"></a>
-2010-06-14T11:19:07.131026Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : limit composite object sizes when producing PDF/A
-
-Bug #691370 &quot;Dictionary size not limited for PDF/A-1&quot;
-
-The PDF/A specification insists that the implementation limitations of Acrobat as
-defined in PDF 1.4 should be followed when producing PDF/A files. Accordingly this
-limits the size of dictionaries to 4095 and arrays to 8191 when producing PDF/A output.
-
-Since there is no way to ignore the problem, setting the PDFACompatibiltyPolicy to 1
-'don't emit the object, carry on producing PDF/A' can't be made to work. Since the
-user has expressed a desire for an output file, we fall back to Policy 0 'Produce a
-regular PDF file' instead.
-
-Also extend PDFACompatibilityPolicy to include policy 2 'abort'.
-
-No test file for this case, no differences expected.
-</pre>
-<p>[base/gdevpdfo.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-14T111418.794921Z"></a>
-2010-06-14T11:14:18.794921Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Extend to PDF/X emission the enhancement in revision 11369 which prevents emitting
-invalid PDF/A files when glyphs are missing from fonts.
-</pre>
-<p>[base/gdevpdte.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-14T111240.380849Z"></a>
-2010-06-14T11:12:40.380849Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Update the ps2pdf documenataion to reflect the fact that PDF/X-3 conversion now also
-uses the PDFACompatibilityPolicy to control behaviour when a conforming file cannot be
-produced.
-
-Also applied some general grammatical correction to the text.
-</pre>
-<p>[doc/Ps2pdf.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-14T093417.990404Z"></a>
-2010-06-14T09:34:17.990404Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) : Don't emit invalid PDF/A files
-
-Bug #691383 &quot;pdfwrite emits invalid PDF/A when glyphs are missing in the input font.&quot;
-
-If the input file references glyphs which are not in the font, then we could emit a
-PDF/A file which also referenced glyph which were not present in the fonts embedded
-in the PDF file.
-
-This patch uses the PDFACompatibilityPolicy to control the action in this case, and
-avoid emitting invalid PDF/A files.
-
-Also extended the functionality of the PDFACompatibilityPolicy to allow the user to
-abort PDF file production when a valid PDF/A file cannot be produced.
-
-No expected differences as PDF/A production is not tested by regression code.
-</pre>
-<p>[base/gdevpdfm.c base/gdevpdte.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-12T151956.267658Z"></a>
-2010-06-12T15:19:56.267658Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-The ICC profile file name buffer was too small to accommodate the
-trailing null appended by strcat resulting in an invalid write to
-memory.
-</pre>
-<p>[base/gsicc_manage.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-11T172406.899434Z"></a>
-2010-06-11T17:24:06.899434Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-In the event of a FreeType error when scaling a font face, don't clean
-up the FT data, but leave it to the garbage collector
-to call the font object's &quot;finalize&quot; function, which will then
-clean up the FT data.
-Secondly, add code to deal with very low resolutions underflowing some of FT's
-fixed point code (similar to code for small scale factors).
-Bug 691381
-</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-11T075337.156852Z"></a>
-2010-06-11T07:53:37.156852Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix pdfwrite - device reference counting problem with patterns and XPS
-
-When using XPS as the input PDL, and pdfwrite as the output device, the pdfwrite device
-was counted up by pattern accumulator allocation, but the clist accumulator never
-counted the device down, leading to a reference count &gt; 1 at EOJ. This meant that
-the pdfwrite device wasn't closed, since pdfwrite only emits the PDF file when it is
-closed this led to invalid unfinished PDF files.
-
-The code here modifies the behaviour of the pattern management so that we don't use the
-'clist' path for accumulating patterns *if* the device can accumulate patterns itself
-*and* the PDL doesn't have_pattern_streams (to avoid pathological PDF file problems)
-
-This resolves the issue with device reference counts and all the FTS XPS files now
-produce complete PDF files.
-</pre>
-<p>[base/gxpcmap.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-10T161108.241878Z"></a>
-2010-06-10T16:11:08.241878Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-When extracting a path from the FAPI world (for a charpath, for example),
-only close the path if it has been &quot;opened&quot;.
-This prevents empty paths from non-marking glyphs resulting in a point being
-rendered on the page.
-Another part of Bug 691252.
-This change causes ~195 differences to be reported on the cluster, but they
-are all progressions.
-
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-10T140640.549557Z"></a>
-2010-06-10T14:06:40.549557Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Make the rendering of the Truetype notdef glyph optional with the FAPI interface
-(as per the previous behaviour).
-A few cluster differences are expected as we have test files which use the TTF notdef,
-I have checked all the differences, and they are correct.
-This is part of Bug 691252
-
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-09T185909.419344Z"></a>
-2010-06-09T18:59:09.419344Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Update comparerevs.pl script so that it no longer ignores hash values
-on files taht have a non-zero error return. It now only ignores hash
-values on timeouts (because runs can easily produce different numbers of
-pages on each run).
-
-Also, the output is updated to show error values together with hash results.
-Error values are now always in brackets, on a red background.
-
-</pre>
-<p>[toolbin/localcluster/comparerevs.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-08T162039.058317Z"></a>
-2010-06-08T16:20:39.058317Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-In bytes_copy_rectangle() clamp the length of each row to be copied to the
-stride of the raster. This takes care of problems copying bitmaps from FT
-(or potentially other font libraries) which use different alignment to
-the &quot;internal&quot; rasters. Bug 691328.</pre>
-<p>[base/gsbitops.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-08T010410.677952Z"></a>
-2010-06-08T01:04:10.677952Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Check whether the font has /Encoding before trying to use it. Recent FAPI
-changes give /BuildChar procedure to all fonts including CIDFont resources.
-So the check for non-null pfdata-&gt;BuildChar no longer guaranteed that the
-font has /Encoding. Bug 691311.
-</pre>
-<p>[psi/zchar.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-07T171420.171809Z"></a>
-2010-06-07T17:14:20.171809Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for Bug 691368.
-
-lcms appears not to check its handles of link transforms when a profile is
-released, to clear out xform-&gt;InputProfile. Probably due to the fact that
-lcms may not expect a change of the formatters after the link is created.
-That would imply that we would need to create links based upon data types,
-which is not so efficient. Disable this check in lcms since it is only related
-to named color profiles, which we will not run into. Will kick this up to Marti.</pre>
-<p>[lcms/src/cmspack.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-06T180036.332831Z"></a>
-2010-06-06T18:00:36.332831Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for Bug 691367. Seg fault should no longer occur. If an attempt is
-made to set a color space in the graphic state and the ICC manager's
-profiles have not yet been initialized, it will be taken care of. </pre>
-<p>[base/gsicc_manage.c base/gscspace.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-05T200355.912155Z"></a>
-2010-06-05T20:03:55.912155Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Don't copy memory block into itself; clear a Valgrind warning.
-</pre>
-<p>[base/gsdparam.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-05T192040.615579Z"></a>
-2010-06-05T19:20:40.615579Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for indeterminisms in some PS files where the alternate tint transform
-color space for a DeviceN or Separation color space is CIE based. Previously
-we were returning either CMYK, or RGB based based upon the channel count for
-the CIE space. Now we are returning an equivalent ICC based color space. Also
-minor fix for uninitialized memory in generated profile.</pre>
-<p>[base/gscdevn.c base/gsicc_create.c base/gscsepr.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-03T165717.441589Z"></a>
-2010-06-03T16:57:17.441589Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-observe minst-&gt;search_here_first condition in file search; bug 691350</pre>
-<p>[psi/zfile.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-03T003207.629281Z"></a>
-2010-06-03T00:32:07.629281Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-Adding -P- and -dSAFER to many POSIX shell scripts, win32 and OS/2 batch scripts; bug 691355</pre>
-<p>[lib/bjc610b4.upp lib/bjc610b6.upp lib/lp386.bat lib/bjc610b7.upp lib/bjc610b8.upp lib/gsndt.bat lib/pdf2dsc lib/eps2eps.bat lib/st640plg.upp lib/ras8m.upp lib/ras24.upp lib/pv.sh lib/bj8oh06n.upp lib/necp2x.upp lib/stc600p.upp lib/pfbtopfa.bat lib/stc640p.upp lib/wftopfa lib/ps2ps lib/stc2s_h.upp lib/stc500ph.upp lib/ps2ps.cmd lib/pphs lib/stcany_h.upp lib/pf2afm lib/gsdj500 lib/dnj750c.upp lib/pf2afm.cmd lib/stc600pl.upp lib/stc800pl.upp lib/gsbj lib/ps2epsi lib/ps2epsi.cmd lib/dnj750m.upp lib/dumphint lib/gsnd lib/font2c lib/gsdj.bat lib/pdfopt lib/ras32.upp lib/ps2ps2.bat lib/pdf2ps lib/ps2pdf.cmd lib/pdf2ps.cmd lib/stc500p.upp lib/cdj690.upp lib/stc600ih.upp lib/st640p.upp lib/stc_h.upp lib/gslj.bat lib/stcany.upp lib/stc800ih.upp lib/bdftops.bat lib/stc_l.upp lib/ras1.upp lib/gslp.bat lib/lpgs.bat lib/st640ihg.upp lib/ras3.upp lib/stc1520h.upp lib/ras4.upp lib/stc300.upp lib/bj8ts06n.upp lib/eps2eps lib/ps2ascii.bat lib/eps2eps.cmd lib/stc2_h.upp lib/pdf2dsc.bat lib/stc.upp lib/stc300bl.upp lib/stc300bm.upp lib/bj8pp12f.upp lib/pfbtopfa lib/stc800p.upp lib/bjc610a0.upp lib/bj8gc12f.upp lib/st640pg.upp lib/bjc610a1.upp lib/cdj690ec.upp lib/bjc610a2.upp lib/ps2ps.bat lib/bjc610a3.upp lib/bjc610a4.upp lib/bjc610a5.upp lib/bj8hg12f.upp lib/stc2.upp lib/st640pl.upp lib/bjc610a6.upp lib/printafm lib/bjc610a7.upp lib/pf2afm.bat lib/gsdj500.bat lib/bjc610a8.upp lib/ps2pdfxx.bat lib/lpr2.bat lib/lp386r2.bat lib/stc200_h.upp lib/unix-lpr.sh lib/gsdj lib/necp2x6.upp lib/ps2ps2 lib/ps2epsi.bat lib/gsbj.bat lib/bj8pa06n.upp lib/ps2ps2.cmd lib/dumphint.bat lib/cdj550.upp lib/gslj lib/gsnd.bat lib/font2c.bat lib/bdftops lib/pdfopt.bat lib/pdf2ps.bat lib/st640ih.upp lib/gslp lib/ps2pdfwr lib/bjc610b1.upp lib/bjc610b2.upp lib/dvipdf lib/ps2ascii lib/bjc610b3.upp lib/pftogsf.bat]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-02T174539.111970Z"></a>
-2010-06-02T17:45:39.111970Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Introduce new ENABLE_TRAP_AMALGAMATION build define. If set at build time
-then code is introduced to gxfillts.h to try to amalgamate some of the
-rectangles produced into the surrounding trapezoids.
-
-This can cause small rendering differences due to the difference in rounding
-within scan conversion and trap extraction.
-
-The option is disabled by default.
-
-No expected differences with it disabled. 439 non pdfwrite differences, 99
-differences with it enabled.
-
-</pre>
-<p>[base/gxfillts.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-02T083707.985901Z"></a>
-2010-06-02T08:37:07.985901Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Revision 11348 accidentally included a number of font definitions in an updated cidfmap,
-This removes those definitions, which should not be present.
-</pre>
-<p>[Resource/Init/cidfmap]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-02T082923.801870Z"></a>
-2010-06-02T08:29:23.801870Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Documentation change
-Updated the comments at the head of the file to make it plain that the entries in the
-CSI array must be strings, not names. Although this is clearly documented in use.htm
-we have recently had several reports in which users have been trying to set name values
-in the array.
-
-Also added a pointer to the documentation as a further hint.
-</pre>
-<p>[Resource/Init/cidfmap]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-02T074657.542525Z"></a>
-2010-06-02T07:46:57.542525Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix pdfwrite, faulty matrix transformations for Shading dictionaries
-
-Bug #691352 &quot;cairo pdf mis-distilled&quot;
-
-Patterns in PDF are unpleasantly complicated by the need to transform the pattern to
-the 'default co-ordinate space'. Normally this means that we undo the resolution scaling
-which is normally applied to the CTM.
-
-For page streams this works well, but for forms the 'default co-ordinate space' is
-the space of the parent. For one level of form there is therefore no difference between
-the page and the form. When forms are nested however, the lower form's space becomes
-that of the parent. This means that patterns inside forms, which are nested inside
-another form, need to be transformed to the parent form co-ordinate space, not the
-page space.
-
-Since we don't currently emit forms from pdfwrite for anything except transparency
-groups what this means in practice is that we don't undo the CTM transformation if
-we are rendering a pattern inside a form, nested inside at least one other form.
-
-</pre>
-<p>[base/gdevpdfx.h base/gdevpdft.c base/gdevpdfv.c base/gdevpdfb.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-06-01T174120.224359Z"></a>
-2010-06-01T17:41:20.224359Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Rename of gsicccache.c/h to gsicc_cache.c/h and gsiccmanage.c/h to
-gsicc_manage.c/h to fall in line with the name space of the other files
-that came from the icc branch. Currently working on the documentation
-and it is clear that this is needed (and I wish I had done it earlier).</pre>
-<p>[/trunk/ghostpdl/pxl/pxpthr.c /trunk/ghostpdl/pxl/pxl.mak /trunk/ghostpdl/xps/ghostxps.h base/gsiccmanage.c base/gxshade1.c base/gsiccmanage.h base/gscsepr.c base/gxshade4.c base/gxshade6.c /trunk/ghostpdl/pxl/pxtop.c base/gxcmap.c ghostscript.vcproj base/gsistate.c /trunk/ghostpdl/pcl/pcl.mak base/gdevrinkj.c base/gdevwts.c base/gdevxcf.c base/gxicolor.c base/devs.mak base/gsicc.c base/gdevimdi.c base/gscdevn.c base/gxclread.c base/gdevpsd.c base/lib.mak base/gxiscale.c base/gsicc_manage.c psi/int.mak /trunk/ghostpdl/pxl/pxgstate.c /trunk/ghostpdl/pcl/pctop.c base/gsicc_manage.h psi/zicc.c psi/zdevice.c base/gdevp14.c base/gsstate.c base/gsicc_cache.c base/gsicc_create.c psi/zcie.c base/gsicccache.c base/gxclist.c base/gsicc_cache.h base/gsicccache.h base/gstrans.c base/gscms.h base/gxidata.c base/gdevpdfc.c base/gxblend.c base/gxshade.c psi/zusparam.c base/gdevpdfg.c base/gxp1fill.c base/gxclrast.c base/gsciemap.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-31T144914.514014Z"></a>
-2010-05-31T14:49:14.514014Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-for &quot;ln -s base/unix-gcc.mak Makefile; make&quot; builds, do
-not modularize X, nor build most of the modularzed linux modules,
-since they depend on the linux GNU linker</pre>
-<p>[base/unix-gcc.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-31T144108.956692Z"></a>
-2010-05-31T14:41:08.956692Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-another attempt to make &quot;ln -s base/unix-gcc.mak Makefile; make&quot;
-to work; libtiff really want configure so we hook it in</pre>
-<p>[base/libtiff.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-31T095814.532526Z"></a>
-2010-05-31T09:58:14.532526Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-more icc branch merge related change to make
-&quot;make -f base/unix-gcc.mak&quot; and other targets work&quot;</pre>
-<p>[base/unix-gcc.mak base/unixansi.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-28T180708.826907Z"></a>
-2010-05-28T18:07:08.826907Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Fixes bug #690793. PJL Formlines was not set correctly if the paper
-size changed. Also, refactors such that PXL and PJL get paper sizes
-from the same source table.
-
-</pre>
-<p>[/trunk/ghostpdl/pl/pl.mak /trunk/ghostpdl/pxl/pxl.mak /trunk/ghostpdl/pl/pjparse.c /trunk/ghostpdl/pxl/pxsessio.c /trunk/ghostpdl/pxl/pxstate.h base/gdevpxen.h base/gdevpxut.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-27T210221.460781Z"></a>
-2010-05-27T21:02:21.460781Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix so that shading strokes that go through the clist transparency code
-communicate the transparency device so that the proper color information
-is used as opposed to the color information related to the final target
-device. This should fix the indeterminism with bug688807.pdf when going
-out to a monochrome device.</pre>
-<p>[base/gdevp14.c base/gxshade.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-27T153001.093150Z"></a>
-2010-05-27T15:30:01.093150Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Forward declarations for statics functions were accidentally placed in
-the header file instead of the c file.
-</pre>
-<p>[base/gdevp14.c base/gdevp14.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-27T004457.701730Z"></a>
-2010-05-27T00:44:57.701730Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for indeterminism when using psdcmyk device and interpolated images.
-For cases where the device profile has fewer components than the actual
-number of device colorants we need to use the slower interpolation code.
-Otherwise we end up encoding uninitialized memory. </pre>
-<p>[base/gxiscale.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-26T220150.106123Z"></a>
-2010-05-26T22:01:50.106123Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for bug690218. For clist reader the pdf14 device was getting its color
-information set based upon the number of spot colorants in the page. The real
-number should be based upon the number of actual components the device is capable
-of handling. This occurs when using separation device with a limited set of
-colorants invoked via a command like
--c &quot;&lt;&lt; /SeparationColorNames [ /Cyan /Magenta /Yellow /Black ]
-
-/SeparationOrder [ /Cyan /Magenta /Yellow /Black ] &gt;&gt; setpagedevice&quot;</pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-26T181652.113331Z"></a>
-2010-05-26T18:16:52.113331Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Improvements and fixes in icc search path description and bolder alert with
-respect to Windows delimiter \&quot; interpretation . Thanks to Ray.</pre>
-<p>[doc/Use.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-26T160836.881438Z"></a>
-2010-05-26T16:08:36.881438Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-The languages (pcl, xps, pclxl) debug builds were broken with the icc
-branch merge, gs_abort() is not supported. The code has been changed
-similarly to the old exit upon failed assertion code in gsalloc.c
-where gs_abort() is replaced with return, fixes bug #691340.
-</pre>
-<p>[base/gsicc_profilecache.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-26T030702.463936Z"></a>
-2010-05-26T03:07:02.463936Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Addition of lcms and new icc files to Visual studio solution. Also did a
-little organizing of the files in the explorer window base folder.</pre>
-<p>[ghostscript.vcproj]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-25T204302.039929Z"></a>
-2010-05-25T20:43:02.039929Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Update of documentation, clarifying the search methods used for finding the icc profiles.</pre>
-<p>[doc/Use.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-25T193823.177347Z"></a>
-2010-05-25T19:38:23.177347Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Removal of iccprofiles/ from default icc profile names and post-pend %rom%
-with iccprofiles/ . This is in preparation for having the ps init code
-initialize a default value for ICCProfilesDir (which will be ./iccprofiles/ )
-so that code works with COMPILE_INITS=0 when not in the base directory and
-when -sICCProfilesDir is not specified on the command line.</pre>
-<p>[base/gsiccmanage.c base/gsiccmanage.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-25T171559.119523Z"></a>
-2010-05-25T17:15:59.119523Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-make static some private functions to remove compiler warnings</pre>
-<p>[contrib/gdevgdi.c base/gdevcairo.c contrib/gdevlx50.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-25T171427.480893Z"></a>
-2010-05-25T17:14:27.480893Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-make private functions static to silence some missing prototype warning</pre>
-<p>[imdi/cgen.c imdi/imdi_k.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-25T171318.238667Z"></a>
-2010-05-25T17:13:18.238667Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-silent one compiler warning</pre>
-<p>[base/gxstroke.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-25T135021.339560Z"></a>
-2010-05-25T13:50:21.339560Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix copy CIDFontType 2 properly
-Bug #690930 &quot;Unicode Output: DEVICE=pdfwrite&quot;
-
-When making a copy of a CIDFont with TrueType outlines (CIDFontType 2) for the
-benefit of pdfwrite, do not simply copy the subst_CID_on_WMode structure member as
-this will be restored away along with the font at end of page. Instead make a new
-structure and store that in the copied font.
-
-
-No differences expected, local cluster test shows a few but I think (hope) these are
-related to the ICC branch merge.</pre>
-<p>[base/gxfcopy.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-25T102209.642632Z"></a>
-2010-05-25T10:22:09.642632Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Bug 691336: Resolve some confusion between the original global variable
-removal changes, and subsequent changes, that could result in warning emprintf
-calls using a memory pointer that could not exist at that stage.
-</pre>
-<p>[psi/fapiufst.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-25T083157.775100Z"></a>
-2010-05-25T08:31:57.775100Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Silence a couple of gcc compiler warnings introduced with the ICC merge.
-</pre>
-<p>[base/gdevpdfk.c base/gdevpdfc.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-24T230659.017275Z"></a>
-2010-05-24T23:06:59.017275Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-Another bunch of CRLF to LF's.
-
-find . -type f | grep -v 'svn-base' | xargs file | grep CRLF | \
-grep -v -E '\.(dsp|dsw|sln|rc):' | grep -v -E \
-'(cbuilder5|masm|dotzlib|vstudio|BorlandC_5.5|visualc6)' | cut -d ':' -f 1 | \
-xargs -n 1 svn propset svn:eol-style native
-find . -type f | grep -v 'svn-base' | xargs file | grep CRLF | \
-grep -v -E '\.(dsp|dsw|sln|rc):' | grep -v -E \
-'(cbuilder5|masm|dotzlib|vstudio|BorlandC_5.5|visualc6)' | cut -d ':' -f 1 | \
-xargs dos2unix
-
-</pre>
-<p>[tiff/nmake.opt psi/zcolor.h toolbin/color/icc_creator/ICC_Creator/stdafx.h lib/cat.ps toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.cpp toolbin/color/icc_creator/example/cielab_values.txt toolbin/color/icc_creator/ICC_Creator/icc34.h contrib/lxm3200-tweaked/LICENSE toolbin/color/icc_creator/README.txt toolbin/color/icc_creator/ICC_Creator/ICC_Creator.cpp toolbin/color/named_color/named_color_table.txt zlib/contrib/testzlib/testzlib.txt lib/Fontmap.URW-136.T1 toolbin/color/icc_creator/example/tritone_names.txt zlib/contrib/testzlib/testzlib.c toolbin/color/icc_creator/ICC_Creator/CIELAB.h toolbin/color/icc_creator/ICC_Creator/icc_create.h base/gsicc_profilecache.c toolbin/color/icc_creator/ICC_Creator/stdafx.cpp toolbin/color/icc_creator/ICC_Creator/resource.h base/gsicc_profilecache.h toolbin/color/icc_creator/example/tritone_cielab.txt base/gsicc_create.c toolbin/color/icc_creator/ICC_Creator/targetver.h toolbin/color/icc_creator/ICC_Creator/ICC_CreatorDlg.h toolbin/color/icc_creator/ICC_Creator/res/ICC_Creator.rc2 psi/zcie.h psi/write_t2.c base/gsicc_create.h toolbin/color/icc_creator/example/color_names.txt base/gscms.h toolbin/color/icc_creator/ICC_Creator/icc_create.cpp toolbin/color/icc_creator/ICC_Creator/ICC_Creator.h psi/fapibstm.c lib/Fontmap.URW-136.TT]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-24T223400.748368Z"></a>
-2010-05-24T22:34:00.748368Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-remove some more CR's and more eol-style native.
-
-find . -type f -exec file {} \; |grep 'CRLF' | grep -v '/Projects' | \
-grep -v 'svn-base' | cut -f 1 -d ':' | xargs -n 1 svn propset \
-svn:eol-style native
-find . -type f -exec file {} \; |grep 'CRLF' | grep -v '/Projects' | \
-grep -v 'svn-base' | cut -f 1 -d ':' | xargs -n 1 dos2unix
-
-</pre>
-<p>[lcms/Delphi/delphidemo.dof lcms/src/makefile.simple lcms/Delphi/demo1.pas lcms/python/testbed/srgb2xyz.py lcms/Delphi/Samples/create.pas lcms/python/testbed/srgb2lab.py lcms/Delphi/delphidemo.dpr lcms/python/testbed/cam02.py lcms/makefile.simple lcms/samples/makefile.simple lcms/Delphi/Samples/TEST.PAS lcms/Delphi/delphidemo.cfg lcms/python/testbed/createmsh.py lcms/python/testbed/lab2adobe.py lcms/Delphi/Samples/testfrm.pas lcms/Delphi/Samples/testwp.pas lcms/src/lcms.def lcms/Delphi/Samples/getxyz.pas]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-24T222637.131050Z"></a>
-2010-05-24T22:26:37.131050Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-manually fixing the last few files which escaped fileutils' identification.
-
-</pre>
-<p>[lcms/python/lcms.py lcms/COPYING lcms/src/cmscam97.c lcms/aclocal.m4 lcms/ltmain.sh lcms/README.1ST lcms/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-24T222052.689626Z"></a>
-2010-05-24T22:20:52.689626Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-Changes c/c++/shell script/english text to native text and strip off CR.
-
-find . -type f -exec grep -l '\r\n' {} \; | grep -v 'svn-base' | \
-grep -v '\.vcproj' | grep -v '/Projects' | xargs -n 1 file | \
-grep -E '(ASCII C\+\+ program text|ISO\-8859 English text|ASCII \
-C program text|shell script text executable)' | cut -f 1 -d ':' |\
-xargs dos2unix
-find . -type f -exec grep -l '\r\n' {} \; | grep -v 'svn-base' | \
-grep -v '\.vcproj' | grep -v '/Projects' | xargs -n 1 file | grep -E \
-'(ASCII C\+\+ program text|ISO\-8859 English text|ASCII C program text|\
-shell script text executable)' | cut -f 1 -d ':' | xargs svn propset \
-svn:eol-style native
-
-
-</pre>
-<p>[lcms/doc/TUTORIAL.TXT lcms/matlab/icctrans.c lcms/src/cmswtpnt.c lcms/tifficc/getopt.c lcms/src/cmsgamma.c lcms/src/cmsnamed.c lcms/samples/vprf.c lcms/src/cmserr.c lcms/samples/mkcmy.c lcms/src/cmsmtrx.c lcms/src/cmsxform.c.orig lcms/samples/icc2ps.c lcms/python/lcms_wrap.cxx lcms/tifficc/tiffdiff.c lcms/src/cmssamp.c lcms/samples/xgetopt.c lcms/Delphi/lcmsdll.pas lcms/include/icc34.h.in lcms/src/cmsmatsh.c lcms/src/cmspack.c lcms/jpegicc/jpegicc.c lcms/jpegicc/iccjpeg.c lcms/samples/icctrans.c lcms/testbed/testcms.c lcms/samples/mktiff8.c lcms/jpegicc/iccjpeg.h lcms/tifficc/tifficc.c lcms/src/cmsvirt.c lcms/src/cmspcs.c lcms/samples/icclink.c lcms/src/cmsgmt.c lcms/src/cmsio0.c lcms/src/cmsio1.c lcms/samples/mkgrayer.c lcms/filter.c lcms/python/lcms.i lcms/src/cmsxform.c lcms/src/cmsintrp.c lcms/src/cmscnvrt.c lcms/include/lcms.h lcms/doc/LCMSAPI.TXT lcms/src/cmscgats.c lcms/src/cmscam02.c lcms/include/icc34.h lcms/src/cmslut.c lcms/src/cmsps2.c lcms/samples/wtpt.c lcms/samples/itufax.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-24T220741.207483Z"></a>
-2010-05-24T22:07:41.207483Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-remove executable bits from files which don't need them.
-
-find . -type f -executable -exec file {} \; \
-| grep -v 'shell script text executable' \
-| cut -f 1 -d ':' |xargs -n 1 svn propdel svn:executable
-
-The last commit was created by:
-
-
-find . -type f -executable -exec file {} \; \
-| grep 'script text executable' \
-| cut -f 1 -d ':' |xargs -n 1 svn propset svn:eol-style native
-
-</pre>
-<p>[lcms/Projects/VC6/lcms.rc lcms/Projects/VC7/lcms.rc lcms/bin/Bin.txt lcms/Delphi/Samples/create.pas lcms/samples/vprf.c lcms/configure.ac lcms/README.1ST lcms/lcms.pc.in lcms/Projects/VC2008/lcms.sln lcms/testbed/sRGBSpac.icm lcms/Projects/VC2008/lcms.vcproj lcms/python/testbed/lab2adobe.py lcms/Delphi/demo1.dfm lcms/samples/xgetopt.c lcms/Projects/VC2005/icclink.vcproj lcms/Projects/VC6/icclink.dsp lcms/Projects/VC7/lcms.vcproj lcms/src/cmscam97.c lcms/testbed/testcms.c lcms/Projects/VC6/icc2ps.dsp lcms/Projects/VC7/icctrans.vcproj lcms/python/testbed/srgb2lab.py lcms/Projects/VC7/tifficc.vcproj lcms/filter.c lcms/Projects/VC6/lcms.dsp lcms/Delphi/delphidemo.cfg lcms/Projects/VC7/icc2ps.vcproj lcms/Projects/VC6/lcms.dsw lcms/Delphi/Samples/testwp.pas lcms/Projects/VC7/lcms.sln lcms/Projects/VC2008/tifficc.vcproj lcms/Projects/VC2005/resource.h lcms/python/testbed/whtpnt.py lcms/doc/TUTORIAL.TXT lcms/src/cmswtpnt.c lcms/Projects/VC2005/Python.vcproj lcms/Projects/BorlandC_5.5/mklcmsdll.bat lcms/include/Makefile.am lcms/Projects/VC7/jpegicc.vcproj lcms/install.gcc lcms/samples/wtpt.1 lcms/Projects/BorlandC_5.5/lcmsdll.lk lcms/src/cmserr.c lcms/makefile.simple lcms/Projects/BorlandC_5.5/lcms.rc lcms/samples/mkcmy.c lcms/src/cmsmtrx.c lcms/Makefile.am lcms/python/testbed/sRGB Color Space Profile.icm lcms/Projects/VC2008/jpegicc.vcproj lcms/Projects/VC7/lcmsdll.vcproj lcms/AUTHORS lcms/samples/icc2ps.1 lcms/Projects/VC2008/resource.h lcms/src/makefile.simple lcms/samples/mktiff8.c lcms/python/testbed/virtprf.py lcms/python/testbed/clamp.py lcms/Projects/BorlandC_5.5/lcmsdll.lst lcms/src/cmsvirt.c lcms/src/cmspcs.c lcms/src/cmsio0.c lcms/python/testbed/cam02.py lcms/Projects/VC6/resource.h lcms/src/cmsxform.c lcms/python/lcms.i lcms/src/cmsintrp.c lcms/Projects/VC2008/lcmsdll.vcproj lcms/jpegicc/jpegicc.1 lcms/COPYING lcms/Projects/VC2005/lcms.rc lcms/samples/icctrans.1 lcms/Projects/VC7/tiffdiff.vcproj lcms/src/cmscgats.c lcms/Projects/VC2008/lcms.rc lcms/tifficc/tifficc.1 lcms/src/cmscam02.c lcms/matlab/icctrans.matlab.pdf lcms/python/testbed/createmsh.py lcms/src/cmslut.c lcms/tifficc/Makefile.am lcms/Lib/MS/MS.TXT lcms/samples/wtpt.c lcms/Projects/VC6/tifficc.dsp lcms/Projects/VC7/Testbed.vcproj lcms/python/testbed/gamma.py lcms/samples/itufax.c lcms/python/Makefile.am lcms/Delphi/demo1.pas lcms/src/cmsgamma.c lcms/Projects/VC6/Python.dsp lcms/Projects/VC2008/Python.vcproj lcms/src/cmsnamed.c lcms/src/cmsxform.c.orig lcms/Projects/VC6/lcmsdll.dsp lcms/Projects/VC2008/Testbed.vcproj lcms/Projects/VC2005/lcms.vcproj lcms/python/testbed/AdobeRGB1998.icc lcms/samples/icc2ps.c lcms/tifficc/tiffdiff.c lcms/samples/makefile.simple lcms/Delphi/Samples/TEST.PAS lcms/src/cmssamp.c lcms/NEWS lcms/samples/Makefile.am lcms/Projects/VC2005/icctrans.vcproj lcms/Projects/VC2005/tifficc.vcproj lcms/Delphi/lcmsdll.pas lcms/Projects/VC2008/icctrans.vcproj lcms/include/icc34.h.in lcms/Delphi/delphidemo.dof lcms/Projects/VC6/lcms.opt lcms/src/cmsmatsh.c lcms/src/cmspack.c lcms/Projects/VC6/Python.plg lcms/jpegicc/jpegicc.c lcms/samples/icctrans.c lcms/Delphi/Samples/MAKETEST.BAT lcms/Projects/VC2005/icc2ps.vcproj lcms/ltmain.sh lcms/Delphi/Samples/gamutchk.pas lcms/tifficc/tifficc.c lcms/Projects/VC2005/lcms.sln lcms/src/cmsio1.c lcms/Projects/VC6/Testbed.dsp lcms/INSTALL lcms/Projects/VC7/icclink.vcproj lcms/jpegicc/makefile.simple lcms/jpegicc/Makefile.am lcms/Projects/VC2005/jpegicc.vcproj lcms/samples/icclink.1 lcms/Delphi/Samples/testfrm.pas lcms/Projects/VC6/jpegicc.dsp lcms/Projects/VC6/icctrans.dsp lcms/src/lcms.def lcms/Delphi/demo1.dcu lcms/Delphi/Samples/getxyz.pas lcms/matlab/icctrans.c lcms/ChangeLog lcms/Projects/VC2008/icclink.vcproj lcms/tifficc/getopt.c lcms/Lib/BC/BC.txt lcms/testbed/makefile.simple lcms/Projects/VC6/Testbed.plg lcms/Delphi/delphidemo.dpr lcms/testbed/Makefile.am lcms/Projects/VC2005/lcmsdll.vcproj lcms/Projects/VC7/resource.h lcms/Projects/VC7/Python.vcproj lcms/Delphi/demo1.ddp lcms/python/testbed/cam97.py lcms/jpegicc/iccjpeg.c lcms/python/testbed/constant.py lcms/Projects/VC2005/tiffdiff.vcproj lcms/python/testbed/srgb2xyz.py lcms/python/testbed/info.py lcms/jpegicc/iccjpeg.h lcms/Projects/VC2008/tiffdiff.vcproj lcms/Projects/VC2008/icc2ps.vcproj lcms/src/Makefile.am lcms/samples/icclink.c lcms/src/cmsgmt.c lcms/Projects/VC2005/Testbed.vcproj lcms/samples/mkgrayer.c lcms/include/lcms.h lcms/Delphi/delphidemo.res lcms/src/cmscnvrt.c lcms/python/swig_lcms lcms/doc/LCMSAPI.TXT lcms/python/testbed/sRGB2adobe.py lcms/tifficc/makefile.simple lcms/include/icc34.h lcms/src/cmsps2.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-24T220213.500457Z"></a>
-2010-05-24T22:02:13.500457Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-make all shell scripts in the lcms directory eol-style native.
-</pre>
-<p>[lcms/depcomp lcms/compile lcms/missing lcms/config.guess lcms/config.sub lcms/install-sh lcms/mkinstalldirs lcms/configure]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-24T183616.496917Z"></a>
-2010-05-24T18:36:16.496917Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Add missing EOL to the last line in one of the new ICC files
-because MSVC 6 requires this.
-</pre>
-<p>[base/gsiccmanage.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-24T163158.315172Z"></a>
-2010-05-24T16:31:58.315172Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Merge of icc_work branch into trunk.
-These changes make the color architecture of the graphics library ICC-based.
-All colors are now managed in terms of ICC profiles including PS CIE color
-spaces, for which equivalent ICC profiles are created. A big feature of
-this change is that it makes it very easy to interface a color management
-module (CMM) to ghostscript. The default CMM is now littleCMS and the
-interface to littleCMS is contained in gsicc_littlecms.c .
-New member variables were added to the imager state including an ICC manager,
-which stores the default ICC profiles; a link cache, which reduces the cost of
-creating links between ICC profiles, and a profile cache which stores color
-spaces created from PS CIE, PDF CalRGB and PDF CalGray colors spaces.
-A new directory named iccprofiles has been added. It contains the default
-ICC profiles used if none are specified in the command line. If
-COMPILE_INITS=1, these will be included in the ROM file system. The new
-command line options related to ICC profiles are described in the Use.htm
-documentation.
-For c-list based rendering, all ICC profiles used in the rendering are stored in
-the c-list. During multi-threaded c-list reading, a link cache is associated with
-the primary reader device and is shared amongst the various threads.
-Efficiency improvements were made in the handling of soft mask groups, shading
-smoothness calculations, and color image rendering.
-For details on the branch, please see the commits that were made within the
-branch. There remain indeterminisms to fix. The files affected include
-Bug688807.pdf, Bug688845.eps, Bug690208.pdf, 09-34.PS, CATX0988.pdf,
-CATX1028.pdf, CATX1101.pdf, CATX5529.pdf.
-Rendering issues to investigate include Bug689830.pdf, fts43xx.xps (page 3)
-(shopping cart image), Bug689880.pdf, Bug691002.pdf, Bug689968.pdf,
-Bug688584.ps (page 4), catx4949.pdf.
-Note that the number of differences generated with the merge amounts to
-pretty much every file.
-Thanks to everyone who helped and provided input in this work, especially
-Ray Johnston.
-</pre>
-<p>[base/gdevpdfk.c base/gxclimag.c doc/Use.htm base/gdevdflt.c psi/icie.h base/gxpcmap.c base/gxpcolor.h lcms base/gscsepr.c base/gxshade4.c base/gxclthrd.c base/gxcmap.c base/gscscie.c base/gdevwts.c base/gsistate.c base/msvclib.mak base/gxclpage.c base/gscolor2.c base/gsicc_profilecache.c base/gxistate.h base/gscolor2.h base/gsicc_profilecache.h iccprofiles base/gdevp14.c base/gsicc_create.c base/gdevp14.h base/gsicc_create.h psi/write_t2.c psi/zusparam.c base/gdevpbm.c psi/zcolor.c psi/ztrans.c base/gdevpdft.c base/gxshade1.c /trunk/gs base/gdevpsdi.c psi/ireclaim.c psi/os2.mak base/watclib.mak Resource/Init/gs_lev2.ps base/gdevpsdu.c base/gscie.c base/gxclutil.c base/gscolor3.c base/gdevpsd.c base/gscie.h base/gxiscale.c base/gxcldev.h Resource/Init/gs_res.ps base/gxifast.c base/gxdevcli.h base/openvms.mak base/watcw32.mak base/gscms.h psi/msvc32.mak base/gsalloc.c base/lcms.mak base/gxp1fill.c base/gximage.h base/gsciemap.c base/gdevpx.c psi/zcsdevn.c base/ugcclib.mak base/unix-gcc.mak base/gsovrc.c base/gxcie.h base/macos-mcp.mak base/gxshade6.c base/macosx.mak base/gsccolor.h base/gdevrinkj.c base/unixansi.mak base/devs.mak base/gsicc.c base/gxipixel.c base/lib.mak psi/zimage.c base/gsicc.h psi/dxmain.c psi/dxmainc.c Resource/Init/pdf_draw.ps base/gscolor.c Resource/Init/pdf_ops.ps psi/zdevice.c psi/zcie.c psi/zdpnext.c base/gxclist.c psi/zcie.h base/gximono.c base/gxidata.c base/gstrans.c psi/iimage.h base/gdevpdfb.c base/gxclist.h base/gxshade.c base/gstrans.h base/gxclrast.c psi/zncdummy.c base/gxshade.h toolbin/color base/gsiccmanage.c base/Makefile.in base/gdevpdfv.c base/gsiccmanage.h base/gsicc_littlecms.c base/gxclpath.c base/gsicc_littlecms.h psi/icontext.c base/gxclpath.h base/gsstruct.h base/gdevxcf.c base/gxicolor.c base/gscspace.c base/gdevimdi.c base/gscdevn.c base/gscolor1.c base/gxclread.c base/gscspace.h base/bcwin32.mak base/gsdparam.c base/gs.mak psi/zshade.c base/gdevbbox.c psi/int.mak base/gxcspace.h psi/zicc.c base/gsstate.c base/winlib.mak base/gsicccache.c psi/zicc.h psi/zimage3.c base/gsicccache.h base/gdevpdfc.c base/gstparam.h base/gxblend.c base/gdevpdfg.c base/gxblend.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-24T020113.653152Z"></a>
-2010-05-24T02:01:13.653152Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Recognize Corel tint transform function and replace it with an equivalent
-calculator function. Bug 690986.
-</pre>
-<p>[psi/zfunc4.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-23T001525.592930Z"></a>
-2010-05-23T00:15:25.592930Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Decide whether load a CFF font as a simple font or a CIDFont based on the
-/Subtype of the font object instead of the /Subtype of the font stream.
-Acrobat appears to ignore the latter. Bug 691334.
-</pre>
-<p>[Resource/Init/pdf_font.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-22T091730.088324Z"></a>
-2010-05-22T09:17:30.088324Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Explicit pointer cast to silence a gcc compiler warning.
-</pre>
-<p>[base/gxp1fill.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-21T151607.910956Z"></a>
-2010-05-21T15:16:07.910956Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Following Acrobat implementation but contrary to TTF spec, consider cmap entry
-that has endCode &lt; startCode as an entry with endCode == startCode.
-According to the spec, &quot;to use these arrays, it is necessary to search for the
-first endCode that is greater than or equal to the character code to be
-mapped. If the corresponding startCode is less than or equal to the character
-code ...&quot;. I.e. an entry with endCode &lt; startCode should have no effect.
-Thanks to Ken for the patch. Bug 691326.
-</pre>
-<p>[Resource/Init/gs_ttf.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-21T081456.354805Z"></a>
-2010-05-21T08:14:56.354805Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix: device reference counting problem with patterns and clipping
-
-Bug #690572 more details here. The problem was caused by installing a clip device while
-drawing a pattern tile. This patch initialises the finalize member of the structure
-where the clip device will be created to NULL. If a clip device is required, the member
-will be initialised to a real routine. After drawing the pattern cell, if the finalize
-routine is non-NULL we execute it.
-
-This correctly dereferences the forwarded device if we create a clipping device.
-
-</pre>
-<p>[base/gxp1fill.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-21T063511.431787Z"></a>
-2010-05-21T06:35:11.431787Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-adding missing dependencies so that setupgs and uninstgs can be built ahead or independent of the main targets</pre>
-<p>[psi/winint.mak psi/msvc32.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-20T073106.101672Z"></a>
-2010-05-20T07:31:06.101672Z regression</strong></p>
-<blockquote>
-<pre>
-The clustermaster.pl code now checks the pid in the lock file to see if the
-task is running. Also no longer test pdfwrite with the language switch build.
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/build.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-20T062443.585523Z"></a>
-2010-05-20T06:24:43.585523Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-Fix up the eol-style of the rest of the executable files by hand.
-Remove executable bit from toolbin/bmpcmp.c
-
-</pre>
-<p>[toolbin/bmpcmp.c jbig2dec/ltmain.sh tiff/config/ltmain.sh libpng/contrib/pngminim/encoder/gather.sh libpng/contrib/pngminim/preader/gather.sh libpng/scripts/libpng-config-body.in libpng/contrib/pngminim/decoder/gather.sh toolbin/tests/gsvalidate.py]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-20T061020.265063Z"></a>
-2010-05-20T06:10:20.265063Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-Set other type of shell script as native text.
-
-find . -type f -executable -exec file {} \; | \
-grep 'script text executable' | grep -v 'POSIX' | \
-cut -f 1 -d ':' |xargs -n 1 svn propset svn:eol-style native
-
-</pre>
-<p>[toolbin/localcluster/bmps2html.pl toolbin/tests/dump_checksum.py toolbin/tests/gscheck_testfiles.py toolbin/tests/dump_checksum_plus.py toolbin/localcluster/readlog.pl toolbin/search-svn-revs toolbin/localcluster/clustermonitor.cgi toolbin/localcluster/clusterpush.pl toolbin/tests/dump_checksum_raw.py toolbin/localcluster/compare.pl toolbin/localcluster/comparerevs.pl toolbin/tests/find_unique_file.py toolbin/localcluster/clustermaster.pl toolbin/localcluster/weekly.sh toolbin/localcluster/build.pl toolbin/tests/build_revision.py toolbin/htmldiff.pl toolbin/tests/compare_checksumdb.py toolbin/tests/update_baseline.py toolbin/tests/make_baselinedb.py toolbin/tests/validate.py toolbin/bugsByEngineer.pl toolbin/localcluster/clusterpull.sh toolbin/tests/regen_filelist.py toolbin/localcluster/pngs2html.pl toolbin/localcluster/nightly.pl freetype/builds/mac/ascii2mpw.py toolbin/tests/compare_checksums.py toolbin/tests/run_nightly.py toolbin/tests/regen_baseline.py toolbin/tests/myoptparse.py toolbin/tests/get_baselines.py toolbin/tests/run_regression.py toolbin/localcluster/setupcluster toolbin/localcluster/clustermonitor.pl toolbin/tests/testdiff.py toolbin/tests/updatelistpdf.py toolbin/tests/run_series.py toolbin/tests/updatelist.py toolbin/localcluster/run.pl toolbin/tests/get_baseline_log.py toolbin/performance.pl toolbin/localcluster/cachearchive.pl toolbin/tests/make_testdb.py toolbin/tests/collate.py]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-20T060141.643170Z"></a>
-2010-05-20T06:01:41.643170Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-Set all identifiable shell script as native text
-
-find . -type f -executable -exec file {} \; | \
-grep 'POSIX shell script text executable' | \
-cut -f 1 -d ':' |xargs -n 1 svn propset svn:eol-style native
-
-</pre>
-<p>[libpng/missing cups/pstoraster.in libpng/test-pngtest.sh cups/pstopxl.in libpng/install-sh jbig2dec/configure libpng/configure contrib/pcl3/ppd/catppd toolbin/clusterpush.sh libpng/depcomp jpeg/install-sh jbig2dec/config.guess contrib/pcl3/lib/if-pcl3 freetype/configure libpng/config.guess jasper/configure tiff/config/missing jbig2dec/config.sub jpeg/configure libpng/config.sub tiff/config/install-sh jpeg/config.guess zlib/configure jpeg/config.sub tiff/config/depcomp libpng/scripts/libpng-config-head.in tiff/config/compile libpng/scripts/libpng-config.in libpng/autogen.sh tiff/config/config.guess jbig2dec/mkinstalldirs jpeg/ltconfig tiff/config/config.sub libpng/mkinstalldirs contrib/epson740/ps-to-printer.fpi_rh5.2 jasper/acaux/missing jasper/acaux/install-sh tiff/autogen.sh freetype/builds/unix/install-sh freetype/builds/unix/mkinstalldirs tiff/configure jasper/acaux/depcomp jasper/acaux/compile tiff/config/mkinstalldirs jasper/acaux/config.guess contrib/pcl3/lib/cups-pcl3 jasper/acaux/config.sub]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-20T055235.456761Z"></a>
-2010-05-20T05:52:35.456761Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-Avoid raw carriage returns in configure which confuses svn
-
-This is a known bug apparently of autoconf 2.63 which was fixed. Here is the upstream log entry:
-http://git.savannah.gnu.org/gitweb/?p=autoconf.git;a=commitdiff;h=cb34ecf
-
-2008-10-27 Eric Blake &lt;ebb9@byu.net&gt;
-
-Avoid raw carriage return in scripts.
-* lib/autoconf/status.m4 (_AC_OUTPUT_FILES_PREPARE): Generate CR
-via tr, rather than with literal byte.
-* THANKS: Update.
-Reported by Steven R. Loomis; patch suggested by Thomas Dickey.
-
-
-</pre>
-<p>[jbig2dec/configure]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-19T145138.835112Z"></a>
-2010-05-19T14:51:38.835112Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Some work towards (but not a complete cure for) bug 691030.
-
-Previously XXX_slant_into_trapezoids would check for 2 'simple' cases,
-and bale into the fully general fill_slant_adjust function otherwise.
-The simple cases were where the top span was a subset of the bottom one, or
-vice versa.
-
-Unfortunately the way the code to test for these cases was originally written,
-one of these special cases could be used for shaped with vertical sides, and
-the other couldn't.
-
-By rewriting the test slightly, both cases can be used with trapezoids that
-have one vertical side.
-
-For good measure we also extract the 'rectangle' case out separately.
-
-Cluster testing shows no differences (barring a couple of indeterminisms).
-
-This reduces the output from 5 shapes (2 rectangles, 3 traps) to 3 (2
-rectangles, 1 trap). One of the rectangles is still a repeat, but it's
-a step in the right direction.
-
-
-
-</pre>
-<p>[base/gxfillts.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-19T100905.486708Z"></a>
-2010-05-19T10:09:05.486708Z Masaki Ushizaka</strong></p>
-<blockquote>
-<pre>
-Bug 691291. Fix reading uninitialized memory.
-
-The change I made in r10603 had a problem comparing with
-uninitialized data when using Roman fonts.
-The side effect was slowing down font rendering a little.
-In this change I added extra initializer and made
-intention of the 'if' condition more clear.
-No difference on outputs expected nor observed by localcluster
-tests.</pre>
-<p>[base/gschar0.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-19T074220.717044Z"></a>
-2010-05-19T07:42:20.717044Z Masaki Ushizaka</strong></p>
-<blockquote>
-<pre>
-Follow-up to r11278. Removing jbig2dec/config.h.
-
-r11278 enabled jbig2dec/configure to be run.
-I agree with the change but jbig2dec/config.h was also under
-subversion control. With r11278, after someone runs
-'configure' or 'autogen.sh', jbig2dec/config.h become
-modified status.
-jbig2dec/config.h doesn't need to be here. Deleting.
-
-Related bug: 691304 &amp; 691312.</pre>
-<p>[jbig2dec/config.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-18T224039.023883Z"></a>
-2010-05-18T22:40:39.023883Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-define -DHAVE_CONFIG_H and run jbig2dec/configure from top-level configure.
-The fixes some portability issues seen on opensolaris; further follow-up to bug 691304</pre>
-<p>[base/Makefile.in base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-18T222947.346946Z"></a>
-2010-05-18T22:29:47.346946Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-typo in one word. bug 691323</pre>
-<p>[doc/Readme.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-18T222313.250745Z"></a>
-2010-05-18T22:23:13.250745Z regression</strong></p>
-<blockquote>
-<pre>
-Minor changes to cluster code:
-
-support language switch build testing
-recover from disk full errors
-automatically create directories needed for new nodes in run.pl
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/clusterpull.sh toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-18T122248.908526Z"></a>
-2010-05-18T12:22:48.908526Z Masaki Ushizaka</strong></p>
-<blockquote>
-<pre>
-Disabling compiler warnings for discarding 'const'.
-
-</pre>
-<p>[jasper/src/libjasper/base/jas_image.c jasper/src/libjasper/include/jasper/jas_image.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-18T085518.202611Z"></a>
-2010-05-18T08:55:18.202611Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Bug 691313: remove the IBM Omni driver from the default build on Linux.
-Previously it could be excluded by giving configure &quot;--without-omni&quot;,
-this revision reverses the logic, so Omni can be include by giving
-configure &quot;--with-omni&quot;.</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-18T043225.607601Z"></a>
-2010-05-18T04:32:25.607601Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Change the order in which jobs that take too long are killed on the cluster
-nodes to prevent leftover jobs when running bmpcmp.
-</pre>
-<p>[toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-17T154838.534341Z"></a>
-2010-05-17T15:48:38.534341Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix - type 1/CFF font interpreter.
-The gs_type1_piece_codes routine interprets a type 1 or CFF glyph program to determine
-whether the glyph is composed of two subglyphs (a SEAC).
-
-There was a problem with the CFF opcode cntrmask which did not cater for the case where
-it is called with a number of operands on the stack. In this case the operands are to
-be interpreted as vstem hints. Because this was not done, the interpreter had the wrong
-number of hints, and so did not interpret enough of the following bytes as mask data for
-the cntrmask operation. This led to attempting to interpret data as operands, which
-caused corrupted glyphs as well as potential crashes.
-
-This does not appear to be tested by any of our current test files (according to a
-cluster test), so no differences are expected.
-</pre>
-<p>[base/gxtype1.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-17T082506.874101Z"></a>
-2010-05-17T08:25:06.874101Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-white space change only, committed to make a regression run as the test for the
-previous revision was interrupted.</pre>
-<p>[psi/write_t1.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-17T075543.268496Z"></a>
-2010-05-17T07:55:43.268496Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Silence some compiler and make warnings.
-</pre>
-<p>[psi/write_t1.c psi/int.mak psi/write_t1.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-17T043957.140765Z"></a>
-2010-05-17T04:39:57.140765Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-adding check for header stringprep.h; fix bug 691312</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-17T035931.965365Z"></a>
-2010-05-17T03:59:31.965365Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-Fixes portability issue properly with r11256 (which is identical with r11520),
-first discovered by Ralph 6 months ago with r10520
-which results in its being reverted in r10540 .
-
-******************************
-Revert c10520 which causes problems with the MSVC build.
-
-&#36;(CC_) enforces 'ansi' C under msvc32.mak, disabling any Microsoft
-extensions. This often causes problems with 3rd party libraries
-which try to take advantage of those extensions.
-
-This means that the -fPIC flag is again not propagated in the GCC
-build; this is just to unbreak the build until I can test a different
-solution which works on both platforms.
-******************************
-As Ralph explained then, some of libtiff requires non-ansi extensions to work.
-
-The main culpit is tif_win32.c (which includes &lt;windows.h&gt;) and some of the
-file IO flags not being defined. So this commit fix the ansi issue properly.
-
-</pre>
-<p>[tiff/libtiff/tiffiop.h base/libtiff.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-17T034702.654413Z"></a>
-2010-05-17T03:47:02.654413Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-fix windows build breakage in r11249
-
-This change (defining TIFFCONFIG_SUFFIX) should have been part of
-r11249 (create tif_config.h for non-autoconf build)
-which in turn should have been part of
-r11241 (hook up libtiff with non-autoconf build via
-&quot;make -f base/unix-gcc.mak&quot; and &quot;make -f base/unixansi.mak&quot;)
-
-The explanation is that in r10317 where Lars originally hooked up libtiff,
-tif_config.h is generated by libtiff/configure (which is driven by the
-top-level configure), but special provision is provided for non-autoconf build
-(win32 and VMS) by copying from a canned header file.
-If one chooses to bypass the top-level configure, *on every platform*
-(win32, VMS, and non-autoconf unix build), one must provide similiar special
-provision as well.
-
-Personally I'll prefer not to support non-autoconf unix build.
-
-</pre>
-<p>[base/unix-gcc.mak base/unixansi.mak base/libtiff.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-16T183240.253209Z"></a>
-2010-05-16T18:32:40.253209Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Changes to the nightly regression testing system to support weekly testing.
-</pre>
-<p>[toolbin/localcluster/nightly.pl toolbin/localcluster/weekly.sh toolbin/localcluster/runNightly.pl toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T105714.279373Z"></a>
-2010-05-15T10:57:14.279373Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-rename PDEP to TIFFDEP to avoid clashing with PDEP from libpng.mak; bug 691299</pre>
-<p>[base/libtiff.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T105547.722308Z"></a>
-2010-05-15T10:55:47.722308Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-comment out a later duplcate definition; bug 691299</pre>
-<p>[base/lib.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T095005.378608Z"></a>
-2010-05-15T09:50:05.378608Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-latest version of these files from Adobe's web site: http://download.macromedia.com/pub/opensource/cmap/</pre>
-<p>[Resource/CMap/UniGB-UTF8-H Resource/CMap/UniJIS2004-UTF32-H Resource/CMap/UniJIS2004-UTF16-H Resource/CMap/UniJIS2004-UTF8-H Resource/CMap/UniCNS-UTF32-H Resource/CMap/UniJISX0213-UTF32-H Resource/CMap/UniCNS-UTF16-H Resource/CMap/UniJIS-UTF32-H Resource/CMap/UniCNS-UTF8-H Resource/CMap/UniJIS-UTF16-H Resource/CMap/UniGB-UTF32-H Resource/CMap/UniJIS-UTF8-H Resource/CMap/UniJISX02132004-UTF32-H Resource/CMap/UniGB-UTF16-H]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T094615.270585Z"></a>
-2010-05-15T09:46:15.270585Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Add skeleton support for the Bitstream font engine. In its current form this only allows
-for type 1 PostScritp fonts, CFF is trivial to add, as should be support for Bitstream's
-own compressed format. Addition of type 42/TrueType fonts should be patterned after
-FreeType, as there is support in Bitstream for a callback to provide TrueType
-outlines. There is no such provision for PostScript fonts.
-
-To build; define BITSTREAM_BRIDGE=1 and BITSTREAM_ROOT=&quot;&quot;, the root should point one
-level above the 'core' directory. In the current code this would be :
-&quot;/bitstream/FontFusion 4.5a SDK&quot;
-</pre>
-<p>[psi/zfapi.c psi/ifapi.h psi/write_t1.c psi/int.mak psi/msvc32.mak psi/fapibstm.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T081759.395641Z"></a>
-2010-05-15T08:17:59.395641Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-better way of defining SOC_LOADER when try ing to do &quot;make -f base/unix-gcc.mak so&quot;</pre>
-<p>[base/unix-dll.mak base/unix-gcc.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T080646.613460Z"></a>
-2010-05-15T08:06:46.613460Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-The final part of trying to &quot;ln -s base/unix-gcc.mak Makefile ; make so&quot; work.
-
-There were some fundamental problems with the older version: The so target really
-should be built in three distinct stages with three different FLAGS - the
-utils (genarch, gechogs) executable part, the shared library part, and the two final
-executable part. The library should be built with the shared-object flags, but neither
-of the utils nor the final executables should be built with &quot;-shared&quot;, since they are
-executables and not libraries. Hope this is clear.
-
-There is also a little problem from SOC_LOADER not being defined if this file
-is not used from ./configure's Makefile.
-
-</pre>
-<p>[base/unix-dll.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T075816.778296Z"></a>
-2010-05-15T07:58:16.778296Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-use CC_ instead of CC like everywhere else, to make the &quot;so&quot; target work</pre>
-<p>[base/libtiff.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T063020.380857Z"></a>
-2010-05-15T06:30:20.380857Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-&quot;-shared&quot; is a linker flag and not a compiler (object code
-generation) flag; another piece of trying to
-make &quot;make -f base/unix-gcc.mak&quot; work</pre>
-<p>[base/unix-gcc.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T062741.486639Z"></a>
-2010-05-15T06:27:41.486639Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-try to make 'make -f base/unix-gcc.mak so' work
-When not run through ./configure, HAVE_CONFIG_H isn't defined and
-the jbig2 codes drop through to generic unknown unix platform - so we put some
-generic unix values here.
-
-</pre>
-<p>[jbig2dec/os_types.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T062335.840946Z"></a>
-2010-05-15T06:23:35.840946Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-correct documentation on how make so should work -
-./configure --enable-dynamic is required</pre>
-<p>[doc/Make.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T033629.389869Z"></a>
-2010-05-15T03:36:29.389869Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-adding new header dependencies from the recent remove-globals effort</pre>
-<p>[base/lib.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T031349.664716Z"></a>
-2010-05-15T03:13:49.664716Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-adding a needed include to silent a compiler warning introduced by the
-recent remove-globals effort</pre>
-<p>[base/gslibctx.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T031231.280935Z"></a>
-2010-05-15T03:12:31.280935Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-another fix to bug 691306
-This was broken in r2746 (June 2002) which nobody has noticed for 8 years.
-This code path is only used for 'make -f unixansi.mak' (very generic unix cc compiler).
-
-</pre>
-<p>[base/gp_unifs.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T030909.671905Z"></a>
-2010-05-15T03:09:09.671905Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-generate tif_config.h if it is not there. part of fixes to bug 691306</pre>
-<p>[base/libtiff.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T030653.120732Z"></a>
-2010-05-15T03:06:53.120732Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-adding comments about the vga devices being Linux specific</pre>
-<p>[base/unix-gcc.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T030554.250134Z"></a>
-2010-05-15T03:05:54.250134Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-part of fix to bug 691306.
-
-These two devices has been broken since r2925 (DeviceN, August 2002),
-but not built by default at all. They were blindly enabled in
-unix-gcc.mak amongst the ESP merge from Till, and it would appear that
-nobody has noticed since the merge (8.57-8.60) until now.
-
-</pre>
-<p>[base/gdevl256.c base/gdevvglb.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T025814.802157Z"></a>
-2010-05-15T02:58:14.802157Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-freetype2 dependency in base/unixansi.mak to
-make &quot;make -f base/unixansi.mak&quot; work;
-another part for bug 691306</pre>
-<p>[base/unixansi.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T025722.770443Z"></a>
-2010-05-15T02:57:22.770443Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-freetype2 dependency in base/unix-gcc.mak to
-make &quot;make -f base/unix-gcc.mak&quot; work; bug 691306</pre>
-<p>[base/unix-gcc.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T025530.474135Z"></a>
-2010-05-15T02:55:30.474135Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-add documentation about the default internal resolution for pdfwrite is 720dpi</pre>
-<p>[doc/Ps2pdf.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T025408.145913Z"></a>
-2010-05-15T02:54:08.145913Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-add documentation about how to force-embedding the basic 14 fonts</pre>
-<p>[doc/Ps2pdf.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-15T025247.037525Z"></a>
-2010-05-15T02:52:47.037525Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-fix an obvious typo in the makefile</pre>
-<p>[base/libtiff.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-14T164605.198340Z"></a>
-2010-05-14T16:46:05.198340Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Added support to unix-gcc.mak and unixansi.mak to build/use libtiff
-(also fixed some typos and made the device lists more similar).
-
-Note because of the FreeType code these files do not work with
-the current head (they work with ghostscript-8.71).
-
-Fixes Bug 691301.
-
-</pre>
-<p>[base/unix-gcc.mak base/unixansi.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-14T042314.678757Z"></a>
-2010-05-14T04:23:14.678757Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-remove one extra tab introduced in r10994; non-GNU Make on Tru64 and HP-UX is
-picky. Bug 688184 and bug 691299</pre>
-<p>[psi/psromfs.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-14T042029.682174Z"></a>
-2010-05-14T04:20:29.682174Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-HP compiler quirk - apparently the same workaround is needed for SUN Pro C and
-GCC 1.x (see a few lines before this change) ; bug 688184</pre>
-<p>[contrib/opvp/opvp.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-14T041842.997881Z"></a>
-2010-05-14T04:18:42.997881Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-uint8_t type located in usual header on HP-UX needed for jbig2dec ; bug 688184</pre>
-<p>[jbig2dec/os_types.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-14T041654.357328Z"></a>
-2010-05-14T04:16:54.357328Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-fix conflicting types against HP-UX system header in jasper; bug 688184</pre>
-<p>[jasper/src/libjasper/include/jasper/jas_types.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-13T200808.900471Z"></a>
-2010-05-13T20:08:08.900471Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Nudge the windows solution/makefiles closer to supporting 64 bit builds
-by defining WIN64 and amending makefiles to pass the define on through
-recursive calls.
-
-</pre>
-<p>[/trunk/ghostpdl/win32/xps.vcproj ghostscript-ufst.vcproj ghostscript.vcproj /trunk/ghostpdl/win32/pcl.vcproj /trunk/ghostpdl/win32/svg.vcproj psi/msvc32.mak /trunk/ghostpdl/main/pcl6_msvc.mak /trunk/ghostpdl/win32/language_switch.vcproj]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-13T164947.848287Z"></a>
-2010-05-13T16:49:47.848287Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-adding NULL check before closedevice - bug report 691296 and patch from Tim Waugh. Thanks.</pre>
-<p>[base/gdevbbox.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-13T085542.013750Z"></a>
-2010-05-13T08:55:42.013750Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Changes only in white space, to provoke another regression test.
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-13T083002.236776Z"></a>
-2010-05-13T08:30:02.236776Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-No changes, just an attempt to provoke some regression runs.</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-13T080516.555333Z"></a>
-2010-05-13T08:05:16.555333Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix FAPI interface
-There is code in the FAPI interface for replacing a font's /FontBBox entry, this
-sometimes has to create a new array to insert into the dictionary, if the old array is
-not suitable for storing real values.
-
-The code to do this continued using ref_assign_old, as it had done for replacing the
-values in an existing array. This appears to be incorrect, when created the refs in a
-new array are uninitialised so attempting to use ref_assign_old tries to use
-uninitialised data.
-
-Modified to use ref_assign_new instead, as indicated by the comments in store.h
-
-This *may* reduce some of the non-deterministic behaviour, possibly with files such
-as ShadowText.eps
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-12T084416.052741Z"></a>
-2010-05-12T08:44:16.052741Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Elimate an irksome compiler warning introduced in r11221</pre>
-<p>[psi/zcolor.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-12T014318.946640Z"></a>
-2010-05-12T01:43:18.946640Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-adding documentation about the -dDisableFAPI=true switch in various places</pre>
-<p>[doc/Use.htm doc/Make.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-11T220522.389565Z"></a>
-2010-05-11T22:05:22.389565Z regression</strong></p>
-<blockquote>
-<pre>
-The local cluster now tests the language switch build (ls).
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/build.pl toolbin/localcluster/clusterpush.pl toolbin/localcluster/run.pl toolbin/localcluster/clusterpush.txt]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-11T212119.118628Z"></a>
-2010-05-11T21:21:19.118628Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add x64 platform target to Visual Studio projects. I can't
-test it myself due to not having a 64bit Windows setup,
-but it at least starts building and then falls over when
-it tries to run a 64bit exe as part of the build process.
-
-
-
-</pre>
-<p>[/trunk/ghostpdl/win32/xps.vcproj ghostscript-ufst.vcproj /trunk/ghostpdl/win32/pcl.vcproj /trunk/ghostpdl/win32/svg.vcproj /trunk/ghostpdl/win32/language_switch.vcproj]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-11T210209.407086Z"></a>
-2010-05-11T21:02:09.407086Z regression</strong></p>
-<blockquote>
-<pre>
-Minor improvement to cluster node log collection code.
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-11T204110.123188Z"></a>
-2010-05-11T20:41:10.123188Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-bmpcmp was reporting the wrong page number for images, due to me forgetting
-to increment the imagecount when images were loaded. Fixed here.
-
-</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-11T172501.376580Z"></a>
-2010-05-11T17:25:01.376580Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Bugs 690356 and 690832: have the colour space object take a copy of string
-data associated with an indexed colour space lookup table. This prevents the
-colour space finalising code (gx_final_Indexed) freeing the contents of a
-Postscript object which may still be in use.</pre>
-<p>[psi/zcolor.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-11T154421.967848Z"></a>
-2010-05-11T15:44:21.967848Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (FAPI)
-The PDF interpreter, when a font is missing, and it has the 'small caps' flag set,
-creates a substitute by altering the CharStrings of the substitute font, replacing
-the lower case glyph CharStrings with procedures which 'show' the upper case glyph at a
-reduced size.
-
-This ends up in the FAPI code as a t_mixedarray type which was being missed by the check
-for a t_array, added previously to handle arbitrary procedures in a type 1 font. After
-extending the check to include t_mixedarray it was clear that the SEAC processing was
-also messing up the dictionary lookup, so it was necessary to restore a value which
-had been overwritten in case a SEAC turned up.
-
-zero-length-font.pdf should now work as it does without FAPI, no other differences
-expected.
-</pre>
-<p>[psi/fapi_ft.c psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-11T143432.672494Z"></a>
-2010-05-11T14:34:32.672494Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Revise the UFST interface code for PCL/PXL and GS to work with the changes to
-eliminate global variables in the Artifex code base.
-NOTE: the UFST_REENTRANT configuration was broken, and still is (it has been
-since the creation of gxfapiu.[ch] files. To be resolved in the future. At
-this time, therefore, no build integrating UFST can be thread safe.
-
-
-</pre>
-<p>[/trunk/ghostpdl/pl/plulfont.c psi/fapiufst.c base/gxfapiu.c base/gxfapiu.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-11T132443.420456Z"></a>
-2010-05-11T13:24:43.420456Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix for bug 691249 - error caused by failing to initialise new member of
-libctx that was previously a global.
-
-We now memset the contents of libctx to 0 after mallocing it, and then
-explicitly set the non-zero/NULL/false values. This is safer long term as
-it protects us from making the same mistake in future.
-
-</pre>
-<p>[base/gslibctx.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-11T124144.704781Z"></a>
-2010-05-11T12:41:44.704781Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-replace &quot;/*&quot; by &quot;&lt;slash&gt;&lt;star&gt;&quot; to avoid
-compiler warning about comments inside comment </pre>
-<p>[base/mkromfs.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-11T115510.416074Z"></a>
-2010-05-11T11:55:10.416074Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Debug code for helping in debug of 689737. The pattern that is created is 1
-bpp. With this code the pattern bit map is dumped for opening with photoshop
-as a raw 8bit image. The source of the problem appears to be incorrect
-creation of the pattern bit map when GraphicAlphaBits is set to greater than
-1.</pre>
-<p>[base/gxpcmap.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-11T093516.657505Z"></a>
-2010-05-11T09:35:16.657505Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (fonts)
-Bug #691290 &quot;new freetype code gives error /typecheck in definefont&quot;
-
-When creating a Decoding from an Encoding array, treat null objects the same as /.notdef
-(ie not encoded).
-
-No differences expected.
-</pre>
-<p>[Resource/Init/gs_fntem.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-10T151725.103327Z"></a>
-2010-05-10T15:17:25.103327Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (FreeType) : illegal use of setcurrentpoint not handled as per Adobe.
-Bug #691172, file type1-ce1_setcurrentpoint.ps
-
-The PostScript file includes a font which illegally uses setcurrentpoint to establish an
-absolute x/y position. The spec is quite clear that this operator is *only* meaningful
-when processing the results of an OtherSubr, so this usage is definitely illegal.
-
-Not only does it use setcurrentpoint but, unlike previous uses we have seen, it does not
-simply establish 0,0 as the initial point, which can be safely ignored, it actually
-uses it to displace the outline vertically.
-
-FreeType normally just puts two uninitialised variables on the stack, ignores the
-setcurrentpoint and pops the two dummy values. Instead, we now push the current x and
-y co-ordinates when we get a '0 callothersubr'. In setcurrentpoint we then use the
-top two values on the stack to set the current point. This now works for the illegal
-usage seen here, the previous illegal usage, and does not break well-formed fonts
-which actually use the OtherSubrs to set the point.
-
-</pre>
-<p>[freetype/src/psaux/t1decode.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-10T122909.676516Z"></a>
-2010-05-10T12:29:09.676516Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Retry of fix for Bug 69048 (this one actually builds...) Again this should
-only be a factor when using GraphicsAlphaBits. The fix was to make sure
-that when GraphicsAlphaBits is used we initialize the pattern bits buffer.
-Otherwise the get_bits operation used during the gx_default_copy_alpha grabs
-uninitialized memory. Since we do not test with GraphicsAlphabits in the
-regression testing I don't expect there to be any differences.</pre>
-<p>[base/lib.mak base/gxpcmap.c base/gxdevmem.h base/gdevabuf.c base/gspaint.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-10T015742.574530Z"></a>
-2010-05-10T01:57:42.574530Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Reversion to 11210 until I figure out what went wrong...</pre>
-<p>[base/gsutil.h base/lib.mak base/gxpcmap.c base/gspaint.c base/gsutil.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-09T231059.799862Z"></a>
-2010-05-09T23:10:59.799862Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for Bug 690487. This should only be a factor when using GraphicsAlphaBits.
-The fix was to make sure that when GraphicsAlphaBits is used we initialize the
-pattern bits buffer. Otherwise the get_bits operation used during the
-gx_default_copy_alpha grabs uninitialized memory. Since we do not test with
-GraphicsAlphabits in the regression testing I don't expect there to be any
-differences.</pre>
-<p>[base/gsutil.h base/lib.mak base/gxpcmap.c base/gspaint.c base/gsutil.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-08T223046.926748Z"></a>
-2010-05-08T22:30:46.926748Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Update license headers of a few retaining files with AFPL header.
-Bug 691285.
-</pre>
-<p>[Resource/Decoding/StandardEncoding Resource/Decoding/Latin1]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-08T212213.614092Z"></a>
-2010-05-08T21:22:13.614092Z regression</strong></p>
-<blockquote>
-<pre>
-Whitespace changes only.
-</pre>
-<p>[toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-08T211223.981766Z"></a>
-2010-05-08T21:12:23.981766Z regression</strong></p>
-<blockquote>
-<pre>
-Minor changes to cluster software:
-
-Check svn commands for errors and retry.
-
-Gather individual logs and md5sums after each job is completed
-rather than at the end of all jobs.
-</pre>
-<p>[toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-08T204725.658412Z"></a>
-2010-05-08T20:47:25.658412Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Minor changes to the cluster software:
-
-Added a lock file to the clusterpull.sh task
-Updated the documentation to explain how to temporarily disable a node.
-
-</pre>
-<p>[toolbin/localcluster/clusterpull.sh toolbin/localcluster/readme]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-08T155646.469253Z"></a>
-2010-05-08T15:56:46.469253Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Detect and break an infinite loop when some of the image data source are
-at EOF, some are not, and the image code doesn't take more data.
-Bug 691285.
-</pre>
-<p>[psi/zimage.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-08T095955.023824Z"></a>
-2010-05-08T09:59:55.023824Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Initialise a structure to silence a Coverity warning.</pre>
-<p>[base/gdevpdfj.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-08T085757.923764Z"></a>
-2010-05-08T08:57:57.923764Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Really, properly, silence the gcc compiler this time....</pre>
-<p>[base/gdevpdte.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-07T143008.276765Z"></a>
-2010-05-07T14:30:08.276765Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix clist_band_height to use the macro defined in gxband.h as other
-code does to prevent future bitrot. Also use macros for the clist_ cfname,
-cfile, bfname, bfile.</pre>
-<p>[base/gxclist.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-07T142318.978837Z"></a>
-2010-05-07T14:23:18.978837Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix number of elements in the BAND_PARAMS_INITIAL initializer macro to
-correspond to the size of gx_band_params_t (needed since rev 5751).</pre>
-<p>[base/gxband.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-07T121650.113521Z"></a>
-2010-05-07T12:16:50.113521Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Silence some compiler warnings about not checking the return value from fread.</pre>
-<p>[base/gdevpdf.c base/gdevpdfu.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-07T121247.989467Z"></a>
-2010-05-07T12:12:47.989467Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Initialise the members of a local structure to silence a (spurious) compiler and
-Coverity warning.</pre>
-<p>[base/gdevpdte.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-07T081729.050795Z"></a>
-2010-05-07T08:17:29.050795Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Silence a GCC compiler warning, no differences expected.</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-06T160427.459137Z"></a>
-2010-05-06T16:04:27.459137Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove gs_debug_out global variable as it is never used.
-
-No differences expected or seen with local cluster testing.
-
-</pre>
-<p>[base/bench.c base/gsmisc.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-06T160343.016324Z"></a>
-2010-05-06T16:03:43.016324Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Update overprint device to avoid writing back to 3 global variables
-({generic,no,sep}_overptint_procs). We still have those global variables
-but each instantiated device takes copies of them and does any writing back
-into the copies. This is part of the work for bug 691207.
-
-No differences expected or shown by local cluster testing.
-
-</pre>
-<p>[base/gsovrc.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-06T160028.103268Z"></a>
-2010-05-06T16:00:28.103268Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Move gs_interp_reschedule_proc, gs_interp_time_slice_proc, and
-gs_interp_time_slice_ticks into context to avoid global variables as
-part of the work for bug 691207.
-
-No differences expected or seen with local cluster testing.
-
-</pre>
-<p>[psi/icontext.c psi/zcontext.c psi/icstate.h psi/interp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-06T152510.815510Z"></a>
-2010-05-06T15:25:10.815510Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (FAPI &amp; FreeType)
-
-Bug #691284 &quot;Error: /unknownerror in --.FAPIBuildChar&quot;
-The issue is caused because the PostScript file adds to an existing type 1 font a
-CharString entry which is not in type 1 CharString format. I would have thought this
-to be illegal but other PostScript interpreters (specifically Distiller) are happy
-with it.
-
-Modifed the FAPI interface so that after retrieving a type 1, non-CID, CharString we
-test to see if it is a procedure, if it is, then we return an error from the FAPI
-code to the caller (in this case the FreeType interface).
-
-Modified the FreeType interface so that if the CharString retrieval returns an error
-we return a specific (otherwise unused) error to the caller, in this case the
-FreeType engine. On return from FreeType to the interface we test for the specific
-FreeType error (FT_ERR_Invalid_File_Format) and if this is detected then instead of
-returning an error to FAPI, we add one to the character index (to ensure it isn't 0)
-and return that to FAPI.
-
-Finally, in the FAPI code, after 'rendering' the glyph, if we were returned a value
-&gt; 0 then we assume that 'something went wrong' with the CharString. As a last-ditch
-effort we use the return value -1 to retrieve the CharString, and then 'exec' it.
-
-NB if we fail to retrieve the CharString at this level, we return an invalidfont error.
-
-
-</pre>
-<p>[psi/fapi_ft.c psi/zfapi.c psi/ifapi.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-06T030441.737028Z"></a>
-2010-05-06T03:04:41.737028Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Fix compilation errors on Visual C that wants &quot;ui64&quot; suffix instead of &quot;ULL&quot;
-for &quot;unsigned long long&quot; numerals.
-</pre>
-<p>[base/sha2.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-05T203019.371369Z"></a>
-2010-05-05T20:30:19.371369Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove 2 unused globals. These should have been removed as part of 11146.
-
-No differences expected.
-
-</pre>
-<p>[psi/iinit.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-05T195805.790577Z"></a>
-2010-05-05T19:58:05.790577Z regression</strong></p>
-<blockquote>
-<pre>
-Minor changes to the local cluster:
-
-Report md5sum differences even in files that generate an error during processing.
-Archive the email and log files for all revisions, including those which had compile errors.
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/compare.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-05T181421.583279Z"></a>
-2010-05-05T18:14:21.583279Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-More work towards bug 691207 (global variable removal).
-
-There are 4 places is xps where we do eprintfs that access mem_err_print.
-This resolves 1, the other 3 should never be called in files we support.
-
-Resolve 4 const warnings from jasper.
-
-Remove 2 calls to gs_lib_ctx_get_non_gc_memory_t from the cups driver. This
-means the only places left calling this are devices in gs\contrib.
-
-Convert calls to errprint_nomem to calls to errprint (in gdevx.c, gxttb.c,
-gdevupd.c)
-
-The only places using mem_err_print are therefore:
-
-* calls to debug printing functions
-* devices in gs/contrib calling gs_lib_gtx_get_non_gc_memory, errprint_nomem,
-and eprintf.
-* jasper calling eprintf.
-* gdevsco.c (but that seems intrinsically single threaded to me as only one
-thing can be using the console at a time, presumably)
-* signal handlers in os2 and iwatc for catching numeric exceptions.
-* Various devices in gs/base still call errprintf_nomem - some in DEBUG only
-code, but some not.
-* The gs_throw_imp function.
-
-I think this may be as good as we can get at this point.
-
-No differences expected, or shown by local cluster testing.
-
-</pre>
-<p>[/trunk/ghostpdl/xps/xpsfont.c base/gdevx.c base/gdevupd.c base/gxttfb.c cups/gdevcups.c jasper/src/libjasper/base/jas_image.c jasper/src/libjasper/include/jasper/jas_image.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-05T162549.238174Z"></a>
-2010-05-05T16:25:49.238174Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-More work for bug 691207 (remove global vars). Change the gp_ interface and
-all its implementations to pass a gs_memory_t in some cases to allow eprintf
-calls to be made safely.
-
-Also fix a 'const' warning in pxl/pxfont.c and pcl/pcsymbol.c
-
-No differences expected, or shown by local cluster testing.
-
-</pre>
-<p>[base/gp_os2.c base/gdevos2p.c base/gsdevice.c psi/zfile.c base/gp_os2pr.c base/gp_vms.c base/gdevwprn.c base/gxclfile.c base/gp_iwatc.c base/gp_os2.h base/gp_os9.c base/gdevwpr2.c /trunk/ghostpdl/pcl/pcsymbol.c /trunk/ghostpdl/xps/xpstop.c base/gp_unix.c /trunk/ghostpdl/psi/psitop.c base/gp_unifs.c base/gp.h base/gp_macio.c base/bench.c base/gdevpdf.c base/gp_os2fs.c /trunk/ghostpdl/pxl/pxfont.c base/gp_mswin.c base/gp_dvx.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-05T064720.379288Z"></a>
-2010-05-05T06:47:20.379288Z Masaki Ushizaka</strong></p>
-<blockquote>
-<pre>
-A fix for 691164 &quot;PDF loads blank when not Administrator on Vista using GS 8.7&quot;.
-
-The problem was in JasPer library. It tried to create temporary file in
-current directory (HAVE_MKSTEMP), or root directory (Windows and others).
-When those directories are read only, it failed to decode images.
-
-This patch introduces searching of TMPDIR, TEMP and TMP environment varibales
-and use them for temporary files.
-
-Localcluster test reported no differences.
-
-</pre>
-<p>[jasper/src/libjasper/base/jas_stream.c jasper/src/libjasper/include/jasper/jas_stream.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-05T030800.170436Z"></a>
-2010-05-05T03:08:00.170436Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-adding --ldflags to cups.mak ; bug 690268</pre>
-<p>[cups/cups.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-04T231146.700325Z"></a>
-2010-05-04T23:11:46.700325Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-Incoporate the reporter's suggested change to config.guess , bug 69020
-
-It appears that the same change is already in automake-1.11 (and after 1.7),
-so the change is correct. If we merge with upstream again, it is possible that
-this might be overwritten. Hopefully when that happens, the config.guess from
-newer upstream will have this change.
-</pre>
-<p>[jasper/acaux/config.guess]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-04T225233.245666Z"></a>
-2010-05-04T22:52:33.245666Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-minor wording and grammar corrections. Bug 690005</pre>
-<p>[doc/Use.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-04T190537.567635Z"></a>
-2010-05-04T19:05:37.567635Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-A couple of calls to eprintf missed from the previous commit.
-
-No expected changes.
-
-</pre>
-<p>[base/gsfcid.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-04T190451.514942Z"></a>
-2010-05-04T19:04:51.514942Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Improved the localcluster readme instructions.
-</pre>
-<p>[toolbin/localcluster/readme]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-04T184712.330141Z"></a>
-2010-05-04T18:47:12.330141Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-As part of the work for bug 691207 (remove global variables) we introduce
-a new set of macros, &quot;emprintfX&quot;. These do the same as the &quot;eprintfX&quot;
-macros, except they take an explicit memory reference rather than using
-the mem_err_print global.
-
-The plan is to move everything possible over to using emprintf, leaving
-callers of eprintf as 'unsafe' in multithreaded builds.
-
-This review changes all callers of eprintf in ghostscript except:
-gdevsco.c, gp_iwatc.c, gp_macio.c, gp_mswin.c, gp_os2.c, gp_os2pr.c,
-gp_unifs.c, gp_vms.c, gsfid.c, contrib\*, jasper\*.
-
-1 instance in gzspotan.c remains unchanged, but it should never be used.
-
-Local cluster testing shows no build problems.
-
-</pre>
-<p>[psi/fapi_ft.c base/gdevpdfj.c base/gsdevice.c base/gdevos2p.c psi/zfapi.c base/gdevijs.c base/gdevpdfm.c base/gdevpx.c base/gxclfile.c base/gdevpdtb.c base/gdevpdfp.c base/gdevpdtc.c psi/fapiufst.c base/gdevpdtf.c base/gdevpdfu.c base/gxblend1.c base/gspaint.c base/gdevxini.c base/gxcmap.c base/gxclthrd.c base/gdevpsdu.c base/gdevpdtt.c base/gstype42.c base/gdevpsft.c base/gsmisc.c base/gdevsgi.c base/gxclmem.c base/gxttfb.c base/std.h base/gslib.c base/gxtype1.c base/gzspotan.c psi/imainarg.c base/gdevpe.c base/gdevsun.c base/gdevxcmp.c psi/imain.c base/gsiorom.c base/gdevpdf.c base/gdevtsep.c contrib/japanese/gdevdmpr.c base/gxclrast.c base/gdevpdfi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-04T160329.077971Z"></a>
-2010-05-04T16:03:29.077971Z regression</strong></p>
-<blockquote>
-<pre>
-Changed casper3.ghostscript.com to casper.ghostscript.com (no reason to test this, how can it possibly fail?).
-
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/build.pl toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-04T123427.748154Z"></a>
-2010-05-04T12:34:27.748154Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-As part of the efforts towards bug 691207 (global variables must be removed)
-this commit reduces the reliance on mem_err_print.
-
-Currently all calls to errwrite and errflush get the stdin/out/err details
-from a global mem_err_print. For multithreaded gs this will result in output
-going to the wrong place if any of them are redirected. This review splits
-errwrite into 2 variants, errwrite and errwrite_nomem. The first takes an
-explicit mem pointer. The second continues to assume a global one.
-
-The plan is to make everything possible use the first. Currently debugging
-calls and some 'stubborn' devices continue to call errwrite_nomem.
-
-Local cluster testing shows no differences.
-
-
-</pre>
-<p>[base/gdevos2p.c base/gdevsppr.c base/gdevpdfm.c base/gdevsunr.c base/gdevpx.c base/gdevupd.c base/gdevimgn.c base/gdevwpr2.c base/ttfmain.c base/ttfoutl.h base/gp_unifs.c /trunk/ghostpdl/psi/psitop.c base/gdev4693.c /trunk/ghostpdl/xps/xpsfont.c base/strmio.c /trunk/ghostpdl/pxl/pxtop.c contrib/pcl3/src/gdevpcl3.c base/gsmisc.c base/gdevwddb.c base/gsargs.c base/szlibd.c /trunk/ghostpdl/pl/plmain.c base/gxttfb.c base/std.h base/gdevifno.c /trunk/ghostpdl/xps/xpscff.c /trunk/ghostpdl/pcl/pctop.c contrib/pcl3/eprn/gdeveprn.c base/gdevcdj.c psi/ziodevsc.c base/gdevx.c base/gslibctx.c contrib/pcl3/eprn/eprnparm.c toolbin/localcluster/run.pl base/gdevhl7x.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-03T165735.641421Z"></a>
-2010-05-03T16:57:35.641421Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Fix compiler warning (return from incompatible pointer type)
-introduced with making the font cache part of the library context,
-revision 11165.
-</pre>
-<p>[psi/isave.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-03T164816.934577Z"></a>
-2010-05-03T16:48:16.934577Z Lars Uebernickel</strong></p>
-<blockquote>
-<pre>
-Applied Michael Constant's patch to support reading 256-bit AES encrypted PDFs
-(bug #690702).
-
-Minor modifications were made to the original patch to make it work with the
-current trunk.
-
-Aaron Gifford's SHA-2 implementation is included (BSD licensed).
-
-Libidn is added as an optional dependency to support unicode passwords. If it
-is not installed, only ASCII passwords are supported.
-
-
-</pre>
-<p>[base/errno_.h psi/zfaes.c psi/gs.c base/saes.c base/lib.mak base/sha2.c doc/Use.htm base/saes.h base/Makefile.in psi/int.mak psi/zutf8.c base/sha2.h base/locale_.h psi/zpdfops.c psi/zfsha2.c psi/zwinutf8.c psi/winint.mak base/ssha2.c base/configure.ac Resource/Init/pdf_sec.ps psi/msvc32.mak base/ssha2.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-03T132552.802113Z"></a>
-2010-05-03T13:25:52.802113Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) incorrect ToUnicode CMap.
-Bug #691274 &quot;Missing or incorrect ToUnicode when using Identity ordering&quot;
-
-pdfwrite emits ToUnicode CMaps in PDF files which always use 2 bytes for the key
-length. That is 0x21 is represented as &lt;0021&gt;, since these are hex strings there should
-in fact be no difference between &lt;21&gt; and &lt;0021&gt;. It is clear from the ToUnicode
-Mapping file tutorial that this is correct for mapping files.
-
-However, a PDF file is not a CMap file. It appears that Acrobat does not like
-beginbfrange data which is padded with zeros (it seems happy with codespacerange and
-destination codes which are 0 padded though).
-
-This patch outputs ToUnicode CMaps which are not padded with 0, ie 0x21 is emitted as
-&lt;0021&gt;, for the srcCodeLo and SrcCodeHi parameters in a beginbfrange operation. The
-destination codes remain zero-padded.
-
-Technically this would be incorrect for a real CMap file, but we don't write those
-out so this should not be an issue. The change is limited to ToUnicode CMaps and does
-not affect any other kind of CMap.
-
-I believe the change will affect the data emitted for the beginbfrange,
-beginbfchar, begincidchar, beginnotdefchar, beginnotdefrange and begincidrange
-operators. It does *not* affect the begincodespacerange operator; although Acrobat
-Distiller writes this without zero padding tests show that Acrobat is happy reading
-zero-padded code space ranges.
-
-ToUnicode information is not used in rendering PDF files, so regression testing should
-show no differences. Local testing of a limited number of files doesn't reveal any
-problems, but this change has not been well tested.
-</pre>
-<p>[base/gsfcmap.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-03T041330.766321Z"></a>
-2010-05-03T04:13:30.766321Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-Fix unix so build regression; fixes regression from r9948 which was committed for bug 690695</pre>
-<p>[base/unix-dll.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-03T035903.969165Z"></a>
-2010-05-03T03:59:03.969165Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-fixes multiple jpeg devices listed in gs -h (bug 691176)</pre>
-<p>[base/libtiff.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-03T031434.052929Z"></a>
-2010-05-03T03:14:34.052929Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-Rewording build instructions for unix systems, and adding more warnings about
-instructions for legacy old systems being deprecated; bug 691264.
-</pre>
-<p>[doc/Make.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-02T001952.718987Z"></a>
-2010-05-02T00:19:52.718987Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Script to generate an html page that graphically show the differences
-between local cluster regression run results between arbitrary revisions.
-
-Usage information given in file. Must be run on the cluster master machine
-(i.e. casper).
-
-
-</pre>
-<p>[toolbin/localcluster/comparerevs.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-01T232233.008186Z"></a>
-2010-05-01T23:22:33.008186Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Continue work to remove globals (691207). The font cache is no longer
-global but part of the library context.
-</pre>
-<p>[psi/isave.h psi/bfont.h base/gslibctx.c psi/zfcid0.c psi/zfcid1.c psi/zfont.c psi/zfont0.c psi/zfont1.c psi/zbfont.c psi/zusparam.c base/gslibctx.h psi/zfont32.c psi/zfont42.c psi/isave.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-01T092324.281883Z"></a>
-2010-05-01T09:23:24.281883Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Modify the 'C' defaults of the pdfwrite device
-
-Bug #691259 &quot;HPGL graphic followed by raster graphic results in incorrect pdf&quot;
-The pdfwrite device is initialised in 'C', and then partly overridden by PostScript
-initialisation. The problem is that non-PostScript input does not (cannot) execute the
-PostScript initialisation, and so the defaults are left as those done in 'C'.
-
-Not only do these defaults not match the documented defaults in ps2pdf.htm, they are
-not particularly well selected. In this case the problem was caused by sending image
-data at 150 dpi, but only a single scan line at a time. The default setting for
-pdfwrite was to downsample image data to 72 dpi, this caused us to subsample (the
-default downsampling) by a factor of more than 2, which led to our single scan line
-becoming less than half a scan line, and so disappearing altogether.
-
-This patch addresses this issue by altering a number of the defaults to more sensible
-values. In particular we disable downsampling and enable image compression for gray
-and colour images. This has the fortunate result of making most PDF output files
-smaller than before, even though we are now storing more image data.
-
-</pre>
-<p>[base/gdevpsdf.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-05-01T015946.738263Z"></a>
-2010-05-01T01:59:46.738263Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Check all PDF files for transparency features because some files have
-incorrect version number but Acrobat renders them just fine. Bug 691273.
-</pre>
-<p>[Resource/Init/pdf_main.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-30T155408.117709Z"></a>
-2010-04-30T15:54:08.117709Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Testing a white space change for cluster regression tests, this will be overwritten later.</pre>
-<p>[base/gdevpsdf.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-29T215134.733741Z"></a>
-2010-04-29T21:51:34.733741Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-rev 11149 for fixing bug 691014 had still some compiler warnings. This rev fixes them.
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-29T183244.398974Z"></a>
-2010-04-29T18:32:44.398974Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove the 'parent' parameter from gs_malloc_init calls. It only serves to
-allow libctx's to be shared between instances, and we'll never want to do
-that. It's unused at the moment anyway, so this doesn't impact anything.
-
-No expected differences.
-
-</pre>
-<p>[psi/gs.c base/gsinit.c base/gslib.c base/gsmalloc.c /trunk/ghostpdl/pl/plalloc.c psi/iapi.c base/gsmalloc.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-29T041915.713592Z"></a>
-2010-04-29T04:19:15.713592Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-Doubling the arbitrary 0x100000 alloc size limit; the alloc_size_is_ok() check is
-complied out and replaced with DO_NOTHING in release build so this has effect only
-on debug builds. Fixes Bug 691271 .
-
-</pre>
-<p>[base/gsalloc.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-28T231901.308642Z"></a>
-2010-04-28T23:19:01.308642Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Eliminate some warnings in gxcht.c (keep shifts &lt; size of uint).
-
-No local cluster differences reported, or expected.
-
-</pre>
-<p>[base/gxcht.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-28T223701.089543Z"></a>
-2010-04-28T22:37:01.089543Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Fixed segfaults caused by setting and changing the page geometry parameters incorrectly (bug #691014).
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-28T215729.180527Z"></a>
-2010-04-28T21:57:29.180527Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Associate cached font instance with PDF font resource dictionary instead of
-font descriptor. The latter may be shared by font resource dictionaries with
-different encodings causing incorrect rendering. Bug 690714.
-</pre>
-<p>[Resource/Init/pdf_font.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-28T202441.808400Z"></a>
-2010-04-28T20:24:41.808400Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Move op_array_table_global and op_array_table_local away from being
-globals and into i_ctx_p. This requires various knock on changes
-throughout the code to enable them to be recovered from the context
-(which may itself need to be recovered from a memory pointer).
-
-Also, the garbage collection is altered slightly; rather than the
-op_arrays being special cased (as special objects that have to have
-their component parts registered as roots for the garbage collection) we
-move them inline into i_ctx_t and amend the gc routines for that
-structure. Thanks to Alex for his help with this.
-
-No differences expected, or shown with local cluster testing.
-
-</pre>
-<p>[psi/iinit.c psi/icontext.c psi/imain.c psi/idebug.c psi/icstate.h psi/interp.c psi/igc.c psi/opdef.h psi/zmisc.c psi/iutil.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-28T201940.848310Z"></a>
-2010-04-28T20:19:40.848310Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Simple fix to remove dict_default_pack from being a global bool.
-(Make it an enum instead).
-
-No changes expected or shown by local cluster testing.
-
-</pre>
-<p>[psi/idict.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-28T171852.709002Z"></a>
-2010-04-28T17:18:52.709002Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Ensure that multiplication gets applied prior to type casting.</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-28T144102.575217Z"></a>
-2010-04-28T14:41:02.575217Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add missing cast to fapi_ft.c to quiet a warning. This was missed out of
-yesterdays commit of such fixes.
-
-No expected diffs.
-
-</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-28T114024.316225Z"></a>
-2010-04-28T11:40:24.316225Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Small tweaks to Ghostscript initialisation to check for malloc failures etc.
-This would very rarely have been a problem in current code, but would be
-more of an issue in multithreaded operation as running out of memory
-while forking a new instance is more likely.
-
-No expected differences, but the local cluster code seems to be claiming
-differences for an unchanged tree at the moment, so if 3 or so non-pdfwrite
-errors and 1800ish pdfwrite errors show up, it's not because of this.
-
-</pre>
-<p>[psi/gs.c psi/imain.c base/gsmalloc.c psi/iapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-27T160605.631664Z"></a>
-2010-04-27T16:06:05.631664Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Add back in a call removed in (a merging) error in my previous commit (11137).</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-27T145314.939131Z"></a>
-2010-04-27T14:53:14.939131Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Bug 691260: make the FAPI and Freetype related warning messages debug only,
-and depend on -Zm for the FAPI warnings or -Z1 for the Freetype warnings.
-Also address compiler warnings in fapi_ft.c.</pre>
-<p>[psi/fapi_ft.c psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-27T142708.849186Z"></a>
-2010-04-27T14:27:08.849186Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Silence some warnings, either by including new headers or by introducing
-explicit casts.
-
-No differences shown by local cluster testing (of pcl and gs only as xps is
-currently broken).
-
-</pre>
-<p>[base/gxdcconv.c base/gsptype1.c base/gdevpx.c base/gstrans.c base/gdevrinkj.c base/gxfill.c base/gxstroke.c psi/zmisc.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-27T095626.779813Z"></a>
-2010-04-27T09:56:26.779813Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Made the CUPS Raster output device working in a multi-threaded mode, removing all
-global variables. Thanks to James Cloos for the patch. Fixes bug #691241.
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-26T152928.937213Z"></a>
-2010-04-26T15:29:28.937213Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Remember the allocator in the dynamically allocated scanner_state to ensure
-proper deallocation. Current allocation may be reset when a PS error occurs.
-Bug 691167.
-</pre>
-<p>[psi/ztoken.c psi/iscan.c psi/iscan.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-26T090435.569612Z"></a>
-2010-04-26T09:04:35.569612Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Ensure that the BuildChar object is not the null object before trying access its contents.
-</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-26T055846.519692Z"></a>
-2010-04-26T05:58:46.519692Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Change so that when a graphic state is restored, the overprint compositor
-action only occurs if there is a change from the current overprint state.
-This fixes a problem in one of the files associated with bug 691014. In
-the particular file, overprint compositor actions were getting placed into
-a pattern clist. The file in fact had no overprint settings.
-Ran regression test, no differences expected.</pre>
-<p>[base/gsstate.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-25T234756.048527Z"></a>
-2010-04-25T23:47:56.048527Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Add ANSI/ASME Y14.1 A - F paper sizes named ANSI_A - ANSI_F for completeness.
-Bug 691217.
-</pre>
-<p>[Resource/Init/gs_statd.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-25T224548.099475Z"></a>
-2010-04-25T22:45:48.099475Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Minor clean-ups: Added some parantheses to casts and initialized allocated memory.
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-25T223209.854994Z"></a>
-2010-04-25T22:32:09.854994Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-(empty)</pre>
-<p>[base/gximono.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-25T215242.447453Z"></a>
-2010-04-25T21:52:42.447453Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Introduced a real get_color_comp_index() method, to fix bug #690338 correctly.
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-25T184728.775496Z"></a>
-2010-04-25T18:47:28.775496Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Add -dNONATIVEFONTMAP option to disable the use of font map and corresponding
-fonts installed on underlying platform. This may be needed to ensure consistent
-rendering on the platforms with different fonts, for instance,
-during regression testing. Bug 691240.
-</pre>
-<p>[doc/Use.htm Resource/Init/gs_fonts.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-25T004140.540207Z"></a>
-2010-04-25T00:41:40.540207Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix for Bug 691014. Problem was caused by the fact that we had a soft
-mask present and a pattern with no transparency. This means the PDF14
-device is installed and more importantly that transparency state pushes
-and pops occur to keep the softmask in sync with the graphic state. This
-particular files pattern is installed as a clist, which happens to not have
-any transparency. The transparency state pushes and pops were getting placed
-into the pattern clist when the Q and q operations occurred in the pattern, which
-was causing problems since the pattern clist device had no pdf14 device installed to
-handle such commands.
-The solution is to check, when a transparency compositor action is to occur, if the
-current device is a pattern accumulator or a pattern-clist device. If it is, then
-the pattern instance is checked to see if it has transparency. If it does not, then
-the transparency state chance is ignored. This all occurs on the clist writing phase
-in the gs_trans functions.
-
-In addition, a fix was made so that the pdf14custom device sets up it's color information
-correctly. For subtractive devices that do not have cmyk process colorants the custompdf14
-device is installed. This pdf14 device was obtaining its color_info from the target device.
-The pdf14 device must be continuous tone even if the target device is not.
-
-Ran a regression test and saw no differences.</pre>
-<p>[base/gdevp14.c base/lib.mak base/gstrans.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-24T222126.893815Z"></a>
-2010-04-24T22:21:26.893815Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Remove rudimentary code that maps out-of-range character codes to 0 causing
-dictionary overflow in some cases. Unlike earlier array, dictionary
-representation of 'cmap' table doesn't need this. Bug 691253, customer 780.
-</pre>
-<p>[Resource/Init/gs_ttf.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-23T125600.372874Z"></a>
-2010-04-23T12:56:00.372874Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Resolve issues with the language_switch Ghostscript build for Windows, since
-Freetype enabled became the default for the normal GS build.
-</pre>
-<p>[/trunk/ghostpdl/common/msvc_top.mak /trunk/ghostpdl/language_switch/pspcl6_msvc.mak /trunk/ghostpdl/psi/psitop.c psi/msvc32.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-23T041050.732099Z"></a>
-2010-04-23T04:10:50.732099Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Fix of minor memory leak found by Ray. maskbuf entry of transparency ctx
-object was not getting freed. The large mask buffer, which is a member
-variable of maskbuf was getting freed but not this 12 byte structure.
-No expected differences.</pre>
-<p>[base/gdevp14.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-23T032533.581070Z"></a>
-2010-04-23T03:25:33.581070Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Always load CFF font as a CIDFont when it is used as a descendant font of a
-composite font in PDF file. Bug 691253.
-</pre>
-<p>[Resource/Init/pdf_font.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-22T122816.186930Z"></a>
-2010-04-22T12:28:16.186930Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Trap errors that happen in the font reader, issue a warning, and proceed as
-if the font was not embedded. Bug 691242.
-</pre>
-<p>[Resource/Init/pdf_font.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-22T042000.389442Z"></a>
-2010-04-22T04:20:00.389442Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Don't use precompiled headers on MSVC 6 and 7 because it causes compilation
-error C2006 in freetype, which uses #include MACRO .
-</pre>
-<p>[base/msvccmd.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-21T195107.227636Z"></a>
-2010-04-21T19:51:07.227636Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Add missing header file from revision 11097.
-
-</pre>
-<p>[base/gdevpdtd.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-21T192613.171574Z"></a>
-2010-04-21T19:26:13.171574Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Revert macro magic from gserror.h introduced in r11097, due to it being
-broken when used as an expression. Sorry.
-
-</pre>
-<p>[base/gserror.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-21T181256.928835Z"></a>
-2010-04-21T18:12:56.928835Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Another set of very simple tweaks to a range of source files to remove
-warnings. Nothing contentious in here I hope!
-
-base/gdevpdf.c: Make the fact we're ignoring the return value of fread
-explicit by casting to void.
-
-base/gdevsj48.c: Remove unused var.
-
-base/gdevtknk.c: Avoid gcc warning by not needlessly assigning within
-expression.
-
-base/gdevimgn.c: Fix type declaration, make function static.
-
-base/gxdcolor.c: Remove unused var.
-
-base/gdevwts.c: Comment out unused function, cast unused return value from
-fread to void, remove unused vars.
-
-base/gdevo182.c: Be more explicit in type definition to stop warning.
-
-base/gdevlp8k.c: Remove unused var.
-
-base/gdevpdfu.c: Cast unused return value from fread to void.
-
-base/gdevlbp8.c: Cast unused return value from fread to void.
-
-base/gdevokii.c: Explicit cast to int to shut up stupid compiler.
-
-base/gdevpdtd.c: Add const to arg to avoid warning.
-
-base/gserror.h: Do some macro magic to ensure that the macro always evaluates
-it's arg strictly once, insists on being followed by a semicolon, and behaves
-well with surrounding if/else structures etc.
-
-base/gxp1fill.c: Remove unused var.
-
-</pre>
-<p>[base/gdevlbp8.c base/gdevtknk.c base/gdevsj48.c base/gdevo182.c base/gdevpdf.c base/gdevimgn.c base/gdevokii.c base/gdevpdtd.c base/gxdcolor.c base/gdevwts.c base/gdevlp8k.c base/gdevpdfu.c base/gxp1fill.c base/gserror.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-21T175508.584502Z"></a>
-2010-04-21T17:55:08.584502Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix for a problem in the rinkj driver for Epson Stylus Photo 2200.
-The code was accessing indexes 4,5,6 in plane_offsets[6] and hence was
-running off the end of the array. This was causing a warning at compile time
-but never caused a segv as it was merely corrupting the next entry in the
-structure which was reset to 0 shortly afterwards.
-
-Presumably the offset for one of the planes would be wrong though causing
-a loss of quality.
-
-</pre>
-<p>[base/rinkj/rinkj-epson870.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-21T172331.243056Z"></a>
-2010-04-21T17:23:31.243056Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove several occurrences of calls to gs_lib_ctx_get_non_gc_memory_t().
-The only code that now needs this is gp_macpoll.c and gp_mspol.c for when
-CHECK_INTERRUPTS is defined. This reduces the need for mem_err_print.
-
-The only other code that uses mem_err_print is errflush() and errwrite().
-Potentially these could be nobbled for a multithreaded build.
-
-The changes here rely on the memory pointers being set up correctly. While
-local cluster testing gives this a clean bill of health, it's possible that
-problems will appear with files in the wider world - we'll just have to fix
-these as they are reported.
-
-</pre>
-<p>[base/gdevjpeg.c base/sjpx_luratech.c base/strmio.c base/gxttfb.c psi/zfdctd.c base/sdctc.c psi/zfdcte.c psi/zfjpx.c base/sjpx.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-21T150847.471495Z"></a>
-2010-04-21T15:08:47.471495Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Move CPSI_mode from being a global to living in the libctx, as part of the
-efforts for bug 691207 (remove global variables).
-
-I originally tried moving CPSI_mode into the imager state, which would have
-been slightly nicer, but had to abandon this due to problems interacting
-with the command list code. My first thought to make this work was to
-push the value of CPSI_mode into the clist at initial clist creation time.
-As the setting of CPSI_mode isn't vectored through the device, we can't
-detect changes in its setting, but then changing CPSI_mode during the
-lifespan of a clist would give unpredictable results anyway in many cases.
-
-Sadly this was doomed to failure as if a page device is started up that
-uses the clist code to do banding, then the command list is created before
-CPSI_mode is enabled, and we'd operate with the incorrect value.
-
-Moving CPSI_mode into libctx means we keep exactly the same behaviour as
-we have now. This has required various functions throughout the code to
-pass a gs_memory_t * around.
-
-Localcluster testing reveals no problems.
-
-</pre>
-<p>[psi/zfunc3.c psi/zupath.c base/gsdps1.c base/gdevdevn.c base/gxblend1.c base/gspaint.c base/gxstroke.c psi/zmisc.c base/gdevperm.c base/gxdcconv.c base/gdevpsds.c base/gxcmap.c base/gxdcconv.h psi/zfont.c base/gdevrinkj.c base/gdevbit.c base/gsmisc.c base/gxfill.c base/gdevxcf.c base/gxicolor.c base/gdevpsd.c psi/zimage.c base/gsfont.c contrib/opvp/gdevopvp.c base/gsfont.h base/gsstate.c base/gslibctx.c base/gsstate.h psi/zcharx.c psi/zusparam.c base/gslibctx.h base/gsequivc.c psi/zchar.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-21T072014.808042Z"></a>
-2010-04-21T07:20:14.808042Z Masaki Ushizaka</strong></p>
-<blockquote>
-<pre>
-A fix for a regression introduced by r11074 (bug 690094).
-
-As I changed image number to be incremented when 'exflag' is false,
-the problem of 'exrunlength' when SDHUFF == 1 was unveiled.
-This fixes it.
-JBIG2 images with SDHUFF == 1 should have been having trouble
-between r11074 and this revision. No other difference expected.
-
-</pre>
-<p>[jbig2dec/jbig2_symbol_dict.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-20T185236.186732Z"></a>
-2010-04-20T18:52:36.186732Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-A series of tiny changes to various files to stop compiler warnings.
-Nothing contentious in here, so I hope component owners don't object.
-
-psi/zpdfops.c: Make zpdfinkpath function static.
-
-psi/zcie.c: cie_cache_finish1 is an unused function; #if 0 it with a note.
-
-psi/zicc.c: Remove 2 unused variables from a function.
-
-psi/zcolor.c: Add a 'default' case to a switch to stop a 'variable RGB
-might be used uninitialised' warning. Remove out of date comment and make
-zswapcolors static.
-
-psi/zfcid1.c: Convert some unused variables to comments.
-
-base/gp_unix_cache.c: Make the fact we are ignoring the return value from
-fread explicit by casting to void.
-
-base/gstype42.c: Move an unused var into a #if 0 section, comment out an
-unused function.
-
-base/gstrans.c: Use 'any_abs' rather than 'abs' (to avoid abs being used
-without definition).
-
-base/gxshade6.c: Remove unused function
-
-base/gxclfile.c: Make the fact we are ignoring the return value to freopen
-explicit by casting to void.
-
-</pre>
-<p>[base/gxshade6.c psi/zcolor.c psi/zicc.c psi/zcie.c base/gp_unix_cache.c base/gxclfile.c base/gstrans.c base/gstype42.c psi/zfcid1.c psi/zpdfops.c base/echogs.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-19T161513.462842Z"></a>
-2010-04-19T16:15:13.462842Z Lars Uebernickel</strong></p>
-<blockquote>
-<pre>
-Made oog_encode in tif_luv.c reentrant by precalculating oog_tables.
-
-oog_tables was calculated on-demand when writing TIFF files in LogLuv Encoding.
-Since it didn't depend on anything dynamic, I replaced this code with a static
-const array. The array only consisted of 100 ints - the net library size
-actually went down a few bytes after this change.
-
-This is part of bug #691207 (global variables must be removed).
-
-</pre>
-<p>[tiff/libtiff/oog_table.h tiff/libtiff/tif_luv.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-19T115627.260655Z"></a>
-2010-04-19T11:56:27.260655Z Lars Uebernickel</strong></p>
-<blockquote>
-<pre>
-Removed global variables in libtiff's tif_pixarlog.c.
-
-This is part of #691207 (global variables must be removed).
-
-</pre>
-<p>[tiff/libtiff/tif_pixarlog.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-19T094714.697946Z"></a>
-2010-04-19T09:47:14.697946Z Lars Uebernickel</strong></p>
-<blockquote>
-<pre>
-Removed TIFFReassignTagToIgnore in the local libtiff copy.
-
-It wasn't reentrant due to static variables and has been deprecated for a while
-now. GhostScript does not use it at all. Libtiff HEAD also has this function
-removed, it was only kept in 3.x for backwards compatibility.
-
-</pre>
-<p>[tiff/libtiff/tif_dir.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-15T185800.960218Z"></a>
-2010-04-15T18:58:00.960218Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-New Visual Stdio project file for building ufst version of ghostscript.
-
-Currently assumes that the ufst code will be found in C:\ufst, but this can
-be edited in the nmake invocation lines within the Project settings.
-
-</pre>
-<p>[ghostscript-ufst.vcproj]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-15T184131.569934Z"></a>
-2010-04-15T18:41:31.569934Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Update msvc32.mak with various ufst make targets. This allows a
-ghostscript-ufst Visual Studio project to be constructed.
-
-No differences to existing builds.
-
-</pre>
-<p>[psi/msvc32.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-15T171330.072845Z"></a>
-2010-04-15T17:13:30.072845Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove invalid_file_stream and invalid_file_entry global variables,
-as part of the effort for bug 691207 (remove global variables).
-
-We move invalid_file_stream to be a non-gc chunk allocated to be in
-i_ctx_t, and invalid_file_entry can then be replaced by
-i_ctx_p-&gt;invalid_file_stream. The only tricky bits are a) the need to ensure
-that i_ctx_p is available everywhere where it is needed, and b) making sure
-that invalid_file_stream doesn't move when i_ctx_p is relocated.
-
-No changes shown by localcluster testing (though a previous version of the
-patch did fail during gc, so the relavent code is getting tested).
-
-</pre>
-<p>[psi/zfile.c psi/ztoken.c psi/zcontrol.c psi/zshade.c psi/zcontext.c psi/zfcid0.c psi/zfcid1.c psi/zicc.c psi/zfrsd.c psi/icontext.c psi/zvmem.c psi/ziodev.c psi/zfileio.c psi/interp.c psi/icstate.h psi/files.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-15T161310.848189Z"></a>
-2010-04-15T16:13:10.848189Z Lars Uebernickel</strong></p>
-<blockquote>
-<pre>
-Backported and applied libtiff patches from libtiff bugs #2125 and #2125.
-These get rid of some of the global variables in libtiff (in particular
-rgb_refblackwhite and whitepoint in tif_aux.c).
-
-This is part of the multi-threaded gs effort (bug #691207).
-
-</pre>
-<p>[tiff/libtiff/tif_dirinfo.c tiff/libtiff/tif_aux.c tiff/libtiff/tif_dir.c tiff/man/TIFFGetField.3tiff tiff/libtiff/tif_dir.h tiff/libtiff/tif_ojpeg.c tiff/libtiff/tif_jpeg.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-15T144836.373936Z"></a>
-2010-04-15T14:48:36.373936Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix for bug 691244, reported/patch supplied by Norbert Janssen. In
-revision 11045, I'd moved some globals into the libctx, which is
-accessed via the gs_memory_t pointer. This has required certain
-functions to now take a gs_memory_t pointer as an extra arg. In
-this particular case the gs_memory_t pointer in question could be
-NULL. The fix is to use one obtained from gs_lib_ctx_get_non_gc_memory_t,
-a call to which happens conveniently to be on the previous line.
-
-gs_lib_ctx_get_non_gs_memory_t is going to be painful to remove later on,
-but at least this fix gets us up and running again now.
-
-No expected differences.
-
-</pre>
-<p>[base/strmio.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-15T095333.313864Z"></a>
-2010-04-15T09:53:33.313864Z Masaki Ushizaka</strong></p>
-<blockquote>
-<pre>
-A fix for 690094, &quot;missing letters replaced by little vertical lines&quot;.
-
-This problem was in jbig2dec function jbig2_decode_symbol_dict().
-The image number was not incremented correctly when it built
-symbol dictionary.
-No difference expected, other than JBIG2 pdf files suffered by
-this problem.
-</pre>
-<p>[jbig2dec/jbig2_symbol_dict.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-15T083048.171463Z"></a>
-2010-04-15T08:30:48.171463Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Resolve a Freetype build problem on Mac - solution suggested by Tor and Henry.
-
-</pre>
-<p>[base/freetype.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-14T192956.362613Z"></a>
-2010-04-14T19:29:56.362613Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Update the clist band list compressor code to work without using global
-variables as part of the workd for bug 691207 (remove global variables).
-
-The old code used to call a function to read an initialise global structure,
-then based on that allocate storage and copy the structure into it. The new
-code essentially does 2 calls; one that serves to get the size, and another
-that serves to initialise the newly allocated structure.
-
-To facilitate testing, this introduces a new TEST_BAND_LIST_COMPRESSION
-define. If built with this as a define, the code sets the compression
-threshold to 1K, thus forcing the use of compression. A local cluster
-push with this in reveals just one problem, and that seems to be in the
-existing code whereby inflateEnd can be incorectly called on a NULL derived
-pointer. A fix for that is included too.
-
-No expected differences.
-
-</pre>
-<p>[base/gxcllzw.c base/gxclmem.c base/lib.mak base/gxclzlib.c base/gxclmem.h base/szlibd.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-14T162511.391305Z"></a>
-2010-04-14T16:25:11.391305Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Reverse the previous build options for Freetype integration: now
---disable-freetype for configure on Unix type systems or pass FT_BRIDGE=0
-to nmake on Windows if you do not want to integrate Freetype.
-</pre>
-<p>[base/configure.ac psi/msvc32.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-14T160329.953276Z"></a>
-2010-04-14T16:03:29.953276Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix FreeType FAPI
-No bug for this (probably should be). Noticed while testing that using a TrueType to
-replace a missing CIDFont (ie entry in cidfmap) was rendering the wrong glyphs, and
-applying a vertical advance.
-
-The incorrect glyph seems to be because we were incorrectly stating that the character
-index was not a glyph ID, which it is in this case.
-
-The second problem was more difficult. FreeType manufactures vertical advance metrics
-for all TrueType glyphs, we override those in the incremental interface callback, but
-when the TT is a CIDFont on disk, we don't use the incremental interface and so have
-no opportunity to override the metric.
-
-Addressed this by checking in load_glyph to see if the current font is not type 1
-(ie its TT), *is* a CIDFont, and is not a vertical font (WMode is 0). In this case
-we simply override the vertical advance and maek it 0.
-</pre>
-<p>[psi/fapi_ft.c psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-14T141119.891045Z"></a>
-2010-04-14T14:11:19.891045Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Move real_time_0 from being a static variable in zmisc.c to being an entry
-int libctx. Instead of initialisation happening in zmisc it now happens in
-gslibctx.c. Part of the effort for bug 691027 (remove global vars).
-
-This variable isn't strictly speaking necessary, but apparently some FTS
-tests behave better if realtime starts from 0, and it isn't a big problem.
-
-No differences shown in localcluster testing.
-
-</pre>
-<p>[base/gslibctx.c base/gslibctx.h psi/zmisc.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-14T100331.189133Z"></a>
-2010-04-14T10:03:31.189133Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-a few more comments about some microsoft CJK fonts</pre>
-<p>[lib/mkcidfm.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-14T023158.209185Z"></a>
-2010-04-14T02:31:58.209185Z Masaki Ushizaka</strong></p>
-<blockquote>
-<pre>
-Fixed jbig2dec command getopt() parameter for -v option. Not used by
-ghostscript itself but worth for standalone debugging.</pre>
-<p>[jbig2dec/jbig2dec.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-14T022616.603254Z"></a>
-2010-04-14T02:26:16.603254Z Masaki Ushizaka</strong></p>
-<blockquote>
-<pre>
-Fixed an indent. No influence on code.</pre>
-<p>[jbig2dec/jbig2_symbol_dict.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-13T145216.370358Z"></a>
-2010-04-13T14:52:16.370358Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Gets rid us of 2 global variables in jasper (jas_image_numfmts and
-jas_image_fmtinfos). In so doing we take the liberty of simplifiying
-jasper's startup. The configured codecs (we only use 2: jpc and jp2)
-were set at compile time anyway so the the methods to &quot;add formats&quot;
-and &quot;clear formats&quot; have been replaced with a static table.
-
-</pre>
-<p>[jasper/src/appl/imgcmp.c jasper/src/appl/jasper.c jasper/src/appl/imginfo.c jasper/src/libjasper/base/jas_image.c jasper/src/libjasper/base/jas_init.c jasper/src/libjasper/include/jasper/jas_image.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-13T142959.699580Z"></a>
-2010-04-13T14:29:59.699580Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove BITTAG global variable by moving it into the libctx, as part of
-efforts towards bug 691207 (multithreaded gs). This has required several
-accessor functions to gain gs_memory_t * arguments.
-
-No differences expected, or shown by localcluster testing.
-
-</pre>
-<p>[base/gsnamecl.c base/gsutil.h base/gslibctx.c base/gdevbit.c base/gslibctx.h base/gsutil.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-13T130654.792469Z"></a>
-2010-04-13T13:06:54.792469Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix FreeType
-A prior update which re-initialised a glyph index to prevent old Metrics override
-values persisting after a glyph was discarded did not check the ft_inc_int member of
-the 'FF_face' structure before dereferncing it, leading to a potential crash if the
-font was not incrementally loaded.
-
-The code now checks the value before attempting to dereference the pointer.
-</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-13T125040.024266Z"></a>
-2010-04-13T12:50:40.024266Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Modify FAPI support files
-Moved FAPIConfig, FAPIcidfmap and FAPIfontmap from the 'lib' directory to the
-'Resource/Init' directory, so that they get built in when COMPILE_INITS=1.
-
-Also modified gs_fapi.ps to contain default values for the contents of FAPIConfig which
-map all fonts to the FAPI engine (FreeType for now). Modified FAPIConfig so that the
-usual contents are commented out. This should allow the possibility of overriding the
-default values by putting new values in FAPIConfig.
-</pre>
-<p>[lib/FAPIcidfmap lib/FAPIfontmap lib/FAPIconfig Resource/Init/FAPIcidfmap Resource/Init/FAPIfontmap Resource/Init/FAPIconfig Resource/Init/gs_fapi.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-13T121542.067350Z"></a>
-2010-04-13T12:15:42.067350Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Move global variables from gshtscr.c (screen_accurate_screens,
-screen_min_screen_levels, screen_use_wts) into libctx. This has
-meant updating the functions to read/write these to take a
-gs_memory_t pointer too. Part of the efforts for bug 691207.
-
-No differences shown by localcluster testing.
-
-</pre>
-<p>[base/gshtscr.c base/gxht.h psi/zusparam.c base/gslibctx.h base/gsht.c base/gsht1.c psi/zht.c psi/zht2.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-13T095008.611008Z"></a>
-2010-04-13T09:50:08.611008Z Masaki Ushizaka</strong></p>
-<blockquote>
-<pre>
-A fix for 691081, 691206, and part of 690094.
-
-From r9769, jbig2dec wasn't capable of decoding some JBIG2 files and throwing
-a error &quot;jbig2dec FATAL ERROR runlength too large in export symbol table
-(XXX &gt; XX - XX) (segment 0xXX)&quot;.
-This was caused by accidentaly bound checking export symbol table size with
-number of non-export symbol. This fixes it.
-No differences expected, other than JBIG2 files suffered from this problem.
-</pre>
-<p>[jbig2dec/jbig2_symbol_dict.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-13T093822.017180Z"></a>
-2010-04-13T09:38:22.017180Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Minor revision to FAPI code to better ensure GS errors in callbacks
-survive through the font renderer library.</pre>
-<p>[psi/fapi_ft.c psi/zfapi.c psi/ifapi.h psi/fapiufst.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-13T032558.022387Z"></a>
-2010-04-13T03:25:58.022387Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Make the CIESpaces array and its elements constant so it is not
-confused with global modifiable data.
-</pre>
-<p>[psi/zcolor.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-12T104443.428786Z"></a>
-2010-04-12T10:44:43.428786Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Remove the hardcoded identity matrix in the Type 1 serialization code in
-favour of the new FAPI call allowing the interface code to dictate the matrix
-to be used.</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-10T093554.039788Z"></a>
-2010-04-10T09:35:54.039788Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Remove extraneous debug statement in revision 11050.</pre>
-<p>[Resource/Init/gs_fapi.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-10T092850.393011Z"></a>
-2010-04-10T09:28:50.393011Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-FAPI Enhancement
-We need a way in the initial release where we set FreeType as the default font scaler to
-switch it off and revert back to the Ghostscript internal font scaler, in case there
-are significant problems. Bug #691237
-
-This allows the user to either send PostScript or set a command line value to create
-a key called DisableFAPI, if the value is true then FAPI will no longer be active, and
-so the GS font scaler will be used.
-
-Can also be set with -dDisableFAPI=true at the command line.
-</pre>
-<p>[Resource/Init/gs_fapi.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-09T182238.657773Z"></a>
-2010-04-09T18:22:38.657773Z regression</strong></p>
-<blockquote>
-<pre>
-Fixed a recently introduced bug in the cluster that caused gs head to
-be used when compiling GhostPCL/GhostXPS even if a previous revision
-should have been used (as is the case when two or more commits occur
-while the cluster is busy).
-</pre>
-<p>[toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-09T174920.410599Z"></a>
-2010-04-09T17:49:20.410599Z regression</strong></p>
-<blockquote>
-<pre>
-Minor tweaks/improvements to the cluster code:
-
-Fixed bug which occasionally left jobs running on macpro.
-
-Clusterpush.pl when run with user==Michael Vrhel now compares to icc_work branch.
-
-Report all icc_work branch errors (not just new ones).
-
-Collect time to run information.
-
-No longer cache mupdf results.
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/build.pl toolbin/localcluster/run.pl toolbin/localcluster/cachearchive.pl toolbin/localcluster/compare.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-09T145126.314389Z"></a>
-2010-04-09T14:51:26.314389Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix UFST and enhance FAPI
-Define a new API call for FAPI to allow font engines to replace a FontMatrix. This is
-to allow FreeType to replace the FotnMatrix with the identity as it makes the 2-step
-scaling performed by FreeType simpler.
-
-Modified compute_em_scale so that it uses the new API call instead of blindly replacing
-the FontMatrix.
-
-Restored the calculation in FAPI_do_char which unwinds the FontMatrix from the CTM
-when calculating the scale factor. Use the new API call to retrieve the desired
-FontMatrix rather than pulling it directly from the font as before.
-</pre>
-<p>[psi/fapi_ft.c psi/zfapi.c psi/ifapi.h psi/fapiufst.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-09T081356.362732Z"></a>
-2010-04-09T08:13:56.362732Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix Bug #691180
-This alters the described 'odd behaviour' of the font substitution code whereby fonts
-whose name does not contain either 'Serif' or 'Sans' are substituted with Helvetica,
-but those which contain 'Italic' are substituted with Times. Italic fonts are now
-treated the same as Oblique fonts, and substituted with Helvetica, unless the font
-is identified as a serif font.
-
-This may cause some substitution differences with regression files.</pre>
-<p>[Resource/Init/gs_fonts.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-08T214254.260278Z"></a>
-2010-04-08T21:42:54.260278Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Move io_device_table from being a global static in gsiodev.c into
-the library context. In order to retrieve it we need to update
-lots of functions to take a gs_memory_t * as well.
-
-Localcluster testing shows no expected differences.
-
-</pre>
-<p>[base/gsdevice.c psi/zfile.c base/gdevupd.c base/gsiodev.c base/gxdevice.h psi/ziodev2.c base/gdevprn.c psi/ziodevsc.c base/sfxcommon.c psi/zfrsd.c base/gxiodev.h base/strmio.c base/gslibctx.c base/gsfname.c psi/ziodev.c base/gdevtsep.c psi/zcrd.c base/gslibctx.h base/gsfname.h base/gdevps.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-08T160550.601517Z"></a>
-2010-04-08T16:05:50.601517Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix TrueType interpreter Bug #691227
-Another nasty hack for another broken TrueType font. In this case the font tries to
-execute a DeltaP instruction with an argument greater than the number of points in the
-glyph, which is an error.
-
-FreeType's interpreter has this comment
-
-/* XXX: Because some popular fonts contain some invalid DeltaP */
-/* instructions, we simply ignore them when the stacked */
-/* point reference is off limit, rather than returning an */
-/* error. As a delta instruction doesn't change a glyph */
-/* in great ways, this shouldn't be a problem. */
-
-This patch more or less mimics this in our code.
-</pre>
-<p>[base/ttinterp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-08T155431.828558Z"></a>
-2010-04-08T15:54:31.828558Z Ralph Giles</strong></p>
-<blockquote>
-<pre>
-Remove the commented out invocations of autoheader and aclocal/automake
-in the autotools bootstrap script.
-
-The various autotools modules must be invoked in a specific order, and
-usually with non-default options. We only use autoconf in our build,
-not any of the other tools which layer on top of it, but I had left
-their invocations in the script, but commented out, so make it easier
-to add them at a later date.
-
-It's been some years since autogen.sh was added, and we still have no
-plans to adopt automake. Also, the script didn't include support for
-libtoolize (which is glibtoolize of MacOS X) nor for detecting the
-appropriate automake version, so it seems simpler to just remove the
-commented out lines to avoid confusion.
-</pre>
-<p>[autogen.sh]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-08T153926.443280Z"></a>
-2010-04-08T15:39:26.443280Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Stop a function scope static from being static as nothing was gained by it,
-and this removes it from the list of global variables as part of the efforts
-for bug 691207 (multithreaded safety).
-
-No expected differences.
-
-</pre>
-<p>[base/gdevupd.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-08T152926.540666Z"></a>
-2010-04-08T15:29:26.540666Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Change a static (that happens to be const) to be a static const to remove
-it from the global variable list for bug 691207.
-
-No expected differences.
-
-</pre>
-<p>[base/gdevifno.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-08T152228.719732Z"></a>
-2010-04-08T15:22:28.719732Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove globals from gdevmgr.c as part of efforts on bug 691207 (multithreaded
-safety).
-
-Move 5 tables from being file level statics to living in the device structure.
-
-Checked by doing back to back builds and verifying that the same output is
-given for tiger.eps in both cases.
-
-No expected differences.
-
-</pre>
-<p>[base/gdevmgr.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-08T151651.654028Z"></a>
-2010-04-08T15:16:51.654028Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove the function scope static variables from gdevcdj.c as part of the
-efforts for bug 691207 (multithreaded safety). These only affect the
-ESC/P driver.
-
-There are 4 variables in play here. real_rows doesn't actually need to be
-static at all as it is always set before being used. The other 3 (ln_idx,
-vskip1 and vskip2) all go into the 'ep_globals' structure.
-
-There is a subtle change in behaviour here; previously these variables were
-initialised to zero on execution start (and again on every flush). Now they
-are initialised to zero at the start of every page (and again on every flush).
-This means that leftover vskips are no longer carried forwards from page to
-page. This seems like a good thing to me.
-
-</pre>
-<p>[base/gdevcdj.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-08T143041.679319Z"></a>
-2010-04-08T14:30:41.679319Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Make a table of 4 zeros be static const, and update the cast where they are
-used to also be static const. This should remove them from the global variable
-list in bug 691207.
-
-</pre>
-<p>[contrib/japanese/gdev10v.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-08T115629.059369Z"></a>
-2010-04-08T11:56:29.059369Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove global variables in gdevcdj.c as part of the effort for bug 691207.
-
-The ESC/P based printing code in gdevcdj.c uses various global variables; we
-gather them into a struct here, and pass the struct between the 2 functions
-concerned.
-
-This device isn't used in the default build, so no point in testing with the
-localcluster. Enabling it locally and doing before/after tests shows that
-identical results are given for rendering tiger.eps.
-
-A side effect of this commit is to remove the nasty shadowing of the img_rows
-variable (doubly nasty because of it's use within a macro). This meant that I
-had the code wrong for a while, so I know the test is actually testing the
-right thing.
-
-</pre>
-<p>[base/gdevcdj.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-07T171846.406090Z"></a>
-2010-04-07T17:18:46.406090Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove global variable lbp8_end from gdevlbp8.c - it was permanently NULL
-so removing it isn't hard, or risky. This will help towards the &quot;No global
-variables&quot; goal (bug 691207).
-
-No expected differences.
-
-</pre>
-<p>[base/gdevlbp8.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-07T132337.938542Z"></a>
-2010-04-07T13:23:37.938542Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Revise the interface code and the use of FT so that both use GS managed
-memory, rather than the stdlib memory routines (malloc/free and co.).</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-07T131357.741241Z"></a>
-2010-04-07T13:13:57.741241Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix for bug 691228, problems with wide strokes with round caps/joins with
-antialiasing enabled.
-
-2 small problems in the same code. In the antialiased case, we stroke by
-forming 2 paths (one up either side of the line) and then reverse one and
-concatenate it. This should happen whenever we meet a closepath, but due to
-a misplaced return, was being missed out in some round join cases.
-
-Also, when using a round join in the case where 2 lines meet 'in-line' we
-would inadvertently leave the point on the wrong side of the line.
-
-No changes in localcluster testing as this only affects antialiased results
-and that's not tested currently.
-
-</pre>
-<p>[base/gxstroke.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-06T192640.921375Z"></a>
-2010-04-06T19:26:40.921375Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Another attempt to fix Bug 691115. This corrects the clipping of a trapezoid
-to a rectangle within the shading code. My previous attempt had failed to
-allow for one case.
-
-This causes 116 non-pdfwrite diffs, and 23 pdfwrite ones, all checked using
-bmpcmp and found to be acceptable.
-
-</pre>
-<p>[base/gxshade6.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-06T171554.520182Z"></a>
-2010-04-06T17:15:54.520182Z Michael Vrhel</strong></p>
-<blockquote>
-<pre>
-Update of fuzzy to report average and max color errors. This is useful
-for continuous tone images only. If the max error reaches the largest
-possible, the calculations for these values are not performed.</pre>
-<p>[toolbin/tests/fuzzy.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-06T141443.252652Z"></a>
-2010-04-06T14:14:43.252652Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix FAPI and FreeType interface.
-The Metrics override was broken, the code to retrieve the /Metrics entries (1 to 4
-values) stored the results in an array in a different order to the code which read the
-values back.
-
-In addition the FreeType code did not reset the 'glyph_metrics_index' if a glyph had no
-metrics override, which could lead to us using the metrics overrides from a prior glyph
-if we had already encountered one using an override.
-</pre>
-<p>[psi/fapi_ft.c psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-06T100831.160988Z"></a>
-2010-04-06T10:08:31.160988Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix FreeType.
-The revision 11012 fixed a problem with an invalid font but accidentally introduced a
-regression because an 'else' clause was missed.
-</pre>
-<p>[freetype/src/psaux/psobjs.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-06T081444.802475Z"></a>
-2010-04-06T08:14:44.802475Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Resolve two compiler warnings - no behaviour change expected</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-05T235000.539571Z"></a>
-2010-04-05T23:50:00.539571Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-adding comments about using globs not expandable by shell; bug 691229</pre>
-<p>[base/mkromfs.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-05T172412.188391Z"></a>
-2010-04-05T17:24:12.188391Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-adding escaped quotes around &#36;0 in &quot;basename &#36;0&quot; ; 2nd part of bug 691219</pre>
-<p>[lib/pdf2ps lib/eps2eps lib/pfbtopfa lib/ps2epsi lib/ps2pdfwr lib/ps2ps lib/dumphint lib/ps2ps2 lib/dvipdf lib/pdfopt]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-05T172210.077618Z"></a>
-2010-04-05T17:22:10.077618Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-adding escaped quotes around &#36;0 in &quot;dirname &#36;0&quot; ; bug 691219</pre>
-<p>[lib/printafm lib/eps2eps lib/pdf2dsc lib/gsbj lib/ps2epsi lib/gsdj lib/dumphint lib/gsnd lib/font2c lib/pdfopt lib/pdf2ps lib/ps2pdf lib/gslj lib/pfbtopfa lib/bdftops lib/ps2pdf12 lib/ps2pdf13 lib/ps2pdf14 lib/gslp lib/wftopfa lib/ps2pdfwr lib/ps2ps lib/pphs lib/pf2afm lib/gsdj500]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-05T171334.259627Z"></a>
-2010-04-05T17:13:34.259627Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-adding reference to msmin04, msgoth04 and ngulim,nbantang; fixes the remaining issues in bug 689456</pre>
-<p>[lib/mkcidfm.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-05T154847.768122Z"></a>
-2010-04-05T15:48:47.768122Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix line endings. The previous commit (11012) accidentally used DOS line endings which
-made it appear every line in the file was different.
-</pre>
-<p>[freetype/src/psaux/psobjs.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-05T153111.441559Z"></a>
-2010-04-05T15:31:11.441559Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix FreeType
-When using bitmaps from a TrueType/Type42 font FreeType uses a heuristic approach to
-synthesize vertical metrics for the glyphs, including a horizontal advance. As in the
-past, this works well as long as the client knows whether the advance direction is
-horizontal or vertical and uses the correct advance.
-
-However we don't know that, so we don't want the vertical advance.
-
-Its easiest jut to have FreeType ignore embedded bitmaps and use the outlines, in which
-case we don't get the invented vertical advance. Not only that but the rendered bitmap
-is a better match for the cases where we don't have a pre-built bitmap, so consistency
-is improved with this patch as well.
-</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-05T152725.365922Z"></a>
-2010-04-05T15:27:25.365922Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix FreeType
-The test file objlune_font2_mine.ps contains a Type 1 font which has a technically
-invalid glyph. The glyph executes a 'lineto' class operation before a 'moveto' class
-operation.
-
-Although illegal it seems that all other PostScript RIPs ignore this requirement, this
-patch removes the error check in FreeType to conform with other interpreters.
-</pre>
-<p>[freetype/src/psaux/psobjs.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-05T113332.361294Z"></a>
-2010-04-05T11:33:32.361294Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Update the to latest FT code from the FT git repository.</pre>
-<p>[freetype/src/pshinter/pshglob.c freetype/src/base/ftpfr.c freetype/src/pshinter/pshglob.h freetype/src/type1/t1objs.c freetype/docs/DEBUG freetype/src/type1/t1objs.h freetype/docs/INSTALL.CROSS freetype/src/truetype/ttgload.c freetype/src/truetype/ttgload.h freetype/src/tools/ftrandom/ftrandom.c freetype/devel/ft2build.h freetype/src/tools/docmaker/formatter.py freetype/src/autofit/Jamfile freetype/src/bdf/module.mk freetype/include/freetype/config/ftheader.h freetype/src/cff/Jamfile freetype/src/cff/cffparse.c freetype/src/raster/ftraster.c freetype/src/cff/cffparse.h freetype/src/cff/cffcmap.c freetype/src/raster/ftraster.h freetype/src/cff/cffcmap.h freetype/src/raster/ftrend1.c freetype/include/freetype/internal/services/svttglyf.h freetype/src/raster/ftrend1.h freetype/builds/wince/vc2005-ce/freetype.vcproj freetype/docs/INSTALL.ANY freetype/src/psnames/module.mk freetype/src/base/ftutil.c freetype/src/autofit/afglobal.c freetype/src/cache/ftcsbits.c freetype/src/autofit/afglobal.h freetype/src/pcf/rules.mk freetype/src/base/ftsystem.c freetype/src/cache/ftcsbits.h freetype/src/psaux/psaux.c freetype/src/cff/module.mk freetype/src/pshinter/rules.mk freetype/src/pcf/pcfread.c freetype/src/bdf/bdflib.c freetype/src/pcf/pcfread.h freetype/include/freetype/ftcache.h freetype/src/raster/Jamfile freetype/src/gzip/rules.mk freetype/src/pshinter/pshalgo.c freetype/include/freetype/ftincrem.h freetype/include/freetype/internal/services/svcid.h freetype/src/pshinter/pshalgo.h freetype/src/psnames/psnamerr.h freetype/src/tools/test_afm.c freetype/src/cache/ftccache.c freetype/src/cache/ftcmru.c freetype/include/freetype/config/ftstdlib.h freetype/src/cid/cidtoken.h freetype/include/freetype/freetype.h freetype/vms_make.com freetype/src/cache/ftccache.h freetype/src/cache/ftcmru.h freetype/docs/INSTALL.UNIX freetype/src/tools/cordic.py freetype/src/pfr/Jamfile freetype/src/pfr/pfr.c freetype/src/pfr/pfrload.c freetype/src/pfr/pfrload.h freetype/include/freetype/fterrdef.h freetype/src/type1/t1gload.c freetype/src/base/ftbbox.c freetype/src/otvalid/otvgdef.c freetype/src/type1/t1gload.h freetype/include/freetype/ftsystem.h freetype/src/bdf/bdferror.h freetype/src/gxvalid/rules.mk freetype/src/pcf/pcf.c freetype/src/bdf/Jamfile freetype/src/gxvalid/gxvbsln.c freetype/include/freetype/internal/services/svotval.h freetype/src/otvalid/rules.mk freetype/src/pfr/pfrdrivr.c freetype/src/pcf/pcf.h freetype/src/type1/Jamfile freetype/src/pfr/pfrdrivr.h freetype/src/pcf/pcferror.h freetype/src/sfnt/ttsbit0.c freetype/src/base/ftmac.c freetype/src/base/ftgloadr.c freetype/src/base/ftbase.c freetype/builds/win32/vc2005/freetype.vcproj freetype/src/base/ftbase.h freetype/src/gxvalid/gxvmort0.c freetype/src/bdf/bdf.c freetype/src/bdf/bdf.h freetype/src/gxvalid/gxvalid.c freetype/src/cff/cff.c freetype/include/freetype/internal/psaux.h freetype/src/gxvalid/gxvalid.h freetype/autogen.sh freetype/src/base/fttype1.c freetype/src/autofit/afmodule.c freetype/src/autofit/afmodule.h freetype/src/pfr/pfrcmap.c freetype/src/pfr/pfrcmap.h freetype/src/psaux/Jamfile freetype/src/cff/cffpic.c freetype/src/base/ftdebug.c freetype/src/gzip/inflate.c freetype/src/cff/cffpic.h freetype/src/type1/t1driver.c freetype/src/otvalid/otvbase.c freetype/include/freetype/ftmoderr.h freetype/src/gxvalid/gxvopbd.c freetype/src/type1/t1driver.h freetype/src/base/basepic.c freetype/src/type1/t1parse.c freetype/src/otvalid/otvmath.c freetype/src/gxvalid/gxvmort1.c freetype/src/base/basepic.h freetype/src/psnames/rules.mk freetype/src/type1/t1parse.h freetype/src/pcf/Jamfile freetype/src/gzip/Jamfile freetype/src/base/ftbdf.c freetype/src/type1/t1afm.c freetype/src/raster/module.mk freetype/src/cid/cidobjs.c freetype/include/ft2build.h freetype/include/freetype/internal/services/svgxval.h freetype/include/freetype/internal/ftrfork.h freetype/src/type1/t1tokens.h freetype/src/type1/t1afm.h freetype/src/pshinter/pshrec.c freetype/src/cid/cidobjs.h freetype/src/pshinter/pshrec.h freetype/src/truetype/ttobjs.c freetype/src/autofit/autofit.c freetype/include/freetype/ftchapters.h freetype/src/type1/t1errors.h freetype/include/freetype/ftlzw.h freetype/src/truetype/ttobjs.h freetype/src/otvalid/otvgsub.c freetype/src/tools/apinames.c freetype/src/winfonts/fnterrs.h freetype/src/cache/ftcache.c freetype/include/freetype/ftglyph.h freetype/builds/win32/vc2005/index.html freetype/src/raster/rasterrs.h freetype/src/autofit/aflatin2.c freetype/src/type42/Jamfile freetype/src/base/ftpic.c freetype/src/autofit/aflatin2.h freetype/include/freetype/fttypes.h freetype/src/cache/ftcglyph.c freetype/src/gxvalid/gxvmort2.c freetype/src/pshinter/pshinter.c freetype/src/cache/ftcglyph.h freetype/src/tools/test_bbox.c freetype/src/cache/Jamfile freetype/src/type42/t42types.h freetype/include/freetype/internal/services/svpsinfo.h freetype/src/gxvalid/gxvmort.c freetype/src/raster/rastpic.c freetype/builds/win32/vc2008/index.html freetype/src/gxvalid/gxvmort.h freetype/src/gxvalid/README freetype/src/tools/docmaker/docbeauty.py freetype/src/raster/rastpic.h freetype/src/gzip/ftgzip.c freetype/include/freetype/ftcid.h freetype/include/freetype/internal/services/svpfr.h freetype/src/sfnt/module.mk freetype/src/type1/t1load.c freetype/docs/INSTALL freetype/src/gzip/inftrees.c freetype/docs/INSTALL.VMS freetype/src/type1/t1load.h freetype/src/gzip/inftrees.h freetype/src/pfr/pfrsbit.c freetype/src/cff/cfftoken.h freetype/src/gxvalid/gxvfeat.c freetype/include/freetype/internal/ftgloadr.h freetype/docs/PROBLEMS freetype/src/pfr/pfrsbit.h freetype/src/gxvalid/gxvfeat.h freetype/src/truetype/Jamfile freetype/src/gxvalid/gxvkern.c freetype/docs/INSTALL.MAC freetype/src/cid/Jamfile freetype/src/base/ftglyph.c freetype/include/freetype/ftmm.h freetype/src/otvalid/otverror.h freetype/docs/UPGRADE.UNIX freetype/src/autofit/afcjk.c freetype/src/autofit/aftypes.h freetype/src/psaux/afmparse.c freetype/src/sfnt/sfdriver.c freetype/src/autofit/afcjk.h freetype/src/sfnt/sfobjs.c freetype/src/base/ftobjs.c freetype/src/psaux/afmparse.h freetype/src/sfnt/sfdriver.h freetype/src/sfnt/sfobjs.h freetype/src/pfr/rules.mk freetype/src/psaux/module.mk freetype/src/base/ftstroke.c freetype/src/base/ftfstype.c freetype/docs/GPL.TXT freetype/src/base/ftbitmap.c freetype/src/pshinter/pshpic.c freetype/src/pshinter/pshpic.h freetype/src/psnames/pstables.h freetype/src/sfnt/rules.mk freetype/builds/wince/vc2005-ce/index.html freetype/src/autofit/afpic.c freetype/docs/PATENTS freetype/docs/raster.txt freetype/src/autofit/afpic.h freetype/src/cff/cffdrivr.c freetype/src/otvalid/otvgpos.c freetype/src/cid/cidriver.c freetype/src/cff/cffdrivr.h freetype/include/freetype/ftgasp.h freetype/src/autofit/afindic.c freetype/src/otvalid/otvgpos.h freetype/src/cid/cidriver.h freetype/src/autofit/afindic.h freetype/docs/INSTALL.GNU freetype/src/winfonts/module.mk freetype/src/sfnt/ttkern.c freetype/src/gzip/infutil.c freetype/src/sfnt/sferrors.h freetype/src/psaux/t1cmap.c freetype/src/sfnt/ttkern.h freetype/src/gxvalid/gxvmort4.c freetype/src/gzip/infutil.h freetype/include/freetype/ttnameid.h freetype/src/psaux/t1cmap.h freetype/src/gzip/zconf.h freetype/src/base/ftpatent.c freetype/src/truetype/rules.mk freetype/src/base/ftadvanc.c freetype/src/tools/docmaker/tohtml.py freetype/src/otvalid/otvalid.c freetype/src/otvalid/otvcommn.c freetype/include/freetype/config/ftmodule.h freetype/include/freetype/ftxf86.h freetype/src/otvalid/otvalid.h freetype/src/otvalid/otvcommn.h freetype/include/freetype/internal/ftserv.h freetype/Jamrules freetype/src/type1/module.mk freetype/src/base/ftapi.c freetype/docs/VERSION.DLL freetype/docs/LICENSE.TXT freetype/include/freetype/ftstroke.h freetype/include/freetype/ftlist.h freetype/include/freetype/ftbitmap.h freetype/src/type42/t42parse.c freetype/src/bdf/bdfdrivr.c freetype/modules.cfg freetype/builds/win32/visualce/freetype.dsp freetype/src/cid/ciderrs.h freetype/ChangeLog.20 freetype/ChangeLog.21 freetype/src/type42/t42parse.h freetype/ChangeLog.22 freetype/src/bdf/bdfdrivr.h freetype/include/freetype/tttables.h freetype/src/cid/module.mk freetype/src/autofit/afdummy.c freetype/src/tools/chktrcmp.py freetype/include/freetype/internal/services/svxf86nm.h freetype/src/autofit/afdummy.h freetype/include/freetype/internal/ftobjs.h freetype/src/pcf/pcfdrivr.c freetype/src/gxvalid/gxvmort5.c freetype/src/pcf/pcfdrivr.h freetype/src/psnames/Jamfile freetype/docs/MAKEPP freetype/Jamfile freetype/builds/win32/visualce/index.html freetype/include/freetype/ftotval.h freetype/src/tools/test_trig.c freetype/src/tools/docmaker/content.py freetype/include/freetype/ftadvanc.h freetype/include/freetype/internal/services/svpostnm.h freetype/src/cff/rules.mk freetype/src/gzip/zlib.h freetype/src/type42/t42error.h freetype/src/smooth/module.mk freetype/src/sfnt/sfnt.c freetype/src/autofit/afloader.c freetype/src/otvalid/Jamfile freetype/include/freetype/internal/services/svkern.h freetype/src/autofit/afloader.h freetype/src/cache/ftcerror.h freetype/src/psaux/psobjs.c freetype/src/sfnt/Jamfile freetype/src/gzip/infcodes.c freetype/src/truetype/ttpic.c freetype/src/psaux/psobjs.h freetype/src/base/ftcalc.c freetype/src/pshinter/pshnterr.h freetype/src/gzip/infcodes.h freetype/src/truetype/ttpic.h freetype/src/bdf/rules.mk freetype/include/freetype/internal/tttypes.h freetype/src/gxvalid/gxvmorx0.c freetype/include/freetype/internal/ftvalid.h freetype/include/freetype/fterrors.h freetype/builds/win32/visualc/freetype.dsp freetype/src/gzip/infblock.c freetype/src/base/ftlcdfil.c freetype/include/freetype/internal/ftmemory.h freetype/src/type1/type1.c freetype/include/freetype/ftpfr.h freetype/src/gzip/infblock.h freetype/src/pshinter/module.mk freetype/src/tools/ftrandom/Makefile freetype/src/type42/rules.mk freetype/src/gxvalid/gxvmorx.c freetype/docs/formats.txt freetype/src/cff/cffobjs.c freetype/src/smooth/ftsmooth.c freetype/src/gxvalid/gxvmorx.h freetype/src/cff/cffobjs.h freetype/include/freetype/ftoutln.h freetype/src/smooth/ftsmooth.h freetype/include/freetype/ftsynth.h freetype/src/tools/ftrandom/README freetype/src/winfonts/rules.mk freetype/docs/CHANGES freetype/src/base/ftotval.c freetype/include/freetype/tttags.h freetype/src/truetype/module.mk freetype/include/freetype/internal/autohint.h freetype/src/tools/glnames.py freetype/src/sfnt/ttload.c freetype/src/gxvalid/gxvfgen.c freetype/src/sfnt/ttload.h freetype/src/pfr/pfrtypes.h freetype/src/gxvalid/gxvtrak.c freetype/src/pcf/README freetype/include/freetype/internal/ftdriver.h freetype/include/freetype/ftgzip.h freetype/src/base/ftrfork.c freetype/include/freetype/internal/services/svbdf.h freetype/src/smooth/rules.mk freetype/src/gxvalid/gxvmorx1.c freetype/src/base/rules.mk freetype/src/autofit/afwarp.c freetype/src/cid/cidload.c freetype/include/freetype/ftgxval.h freetype/src/autofit/afwarp.h freetype/include/freetype/internal/services/svgldict.h freetype/src/cid/cidload.h freetype/src/gxvalid/gxvprop.c freetype/include/freetype/ftlcdfil.h freetype/src/tools/docmaker/sources.py freetype/src/type42/type42.c freetype/src/raster/rules.mk freetype/src/truetype/ttgxvar.c freetype/src/pshinter/Jamfile freetype/src/truetype/ttdriver.c freetype/src/gxvalid/Jamfile freetype/src/truetype/ttgxvar.h freetype/src/pfr/pfrgload.c freetype/src/Jamfile freetype/src/pshinter/pshmod.c freetype/src/truetype/ttdriver.h freetype/src/autofit/aflatin.c freetype/src/pfr/pfrgload.h freetype/src/base/ftsnames.c freetype/src/pshinter/pshmod.h freetype/include/freetype/internal/ftcalc.h freetype/include/freetype/ftrender.h freetype/src/base/ftgasp.c freetype/src/autofit/aflatin.h freetype/src/base/ftdbgmem.c freetype/docs/TRUETYPE freetype/src/smooth/ftspic.c freetype/include/freetype/t1tables.h freetype/src/cid/cidgload.c freetype/src/base/ftoutln.c freetype/src/smooth/ftspic.h freetype/src/base/ftsynth.c freetype/src/base/ftwinfnt.c freetype/src/cid/cidgload.h freetype/include/freetype/internal/internal.h freetype/src/sfnt/ttbdf.c freetype/src/sfnt/ttbdf.h freetype/src/lzw/ftlzw.c freetype/builds/win32/vc2008/freetype.vcproj freetype/src/truetype/ttpload.c freetype/src/gxvalid/gxvmorx2.c freetype/src/truetype/ttinterp.c freetype/src/lzw/rules.mk freetype/src/truetype/ttpload.h freetype/src/truetype/ttinterp.h freetype/src/base/ftxf86.c freetype/src/base/ftstream.c freetype/src/sfnt/ttcmap.c freetype/include/freetype/internal/services/svmm.h freetype/src/sfnt/ttcmap.h freetype/src/gxvalid/module.mk freetype/src/gxvalid/gxvjust.c freetype/src/truetype/tterrors.h freetype/src/pcf/pcfutil.c freetype/src/cid/type1cid.c freetype/src/pcf/pcfutil.h freetype/src/base/ftgxval.c freetype/include/freetype/internal/pshints.h freetype/src/sfnt/ttmtx.c freetype/src/psnames/psmodule.c freetype/src/sfnt/ttmtx.h freetype/src/psaux/psauxmod.c freetype/builds/wince/vc2008-ce/index.html freetype/src/pfr/module.mk freetype/src/psnames/psmodule.h freetype/src/base/ftcid.c freetype/include/freetype/ftsnames.h freetype/src/psaux/psauxmod.h freetype/README.git freetype/configure freetype/src/sfnt/ttcmapc.h freetype/src/gzip/inffixed.h freetype/include/freetype/ftwinfnt.h freetype/src/pfr/pfrobjs.c freetype/src/base/Jamfile freetype/include/freetype/ftimage.h freetype/docs/release freetype/src/pfr/pfrobjs.h freetype/src/lzw/ftzopen.c freetype/src/truetype/truetype.c freetype/src/lzw/Jamfile freetype/Makefile freetype/src/lzw/ftzopen.h freetype/src/base/fttrigon.c freetype/src/autofit/afhints.c freetype/src/autofit/afhints.h freetype/builds/win32/visualce/freetype.vcproj freetype/include/freetype/ftmac.h freetype/src/psaux/rules.mk freetype/src/type1/rules.mk freetype/src/cache/ftcimage.c freetype/src/psnames/pspic.c freetype/src/cache/ftcimage.h freetype/include/freetype/config/ftconfig.h freetype/src/cid/cidparse.c freetype/src/psnames/pspic.h freetype/src/cff/cfferrs.h freetype/src/cid/cidparse.h freetype/src/smooth/Jamfile freetype/src/gzip/adler32.c freetype/include/freetype/internal/sfnt.h freetype/docs/reference/README freetype/src/winfonts/winfnt.c freetype/devel/ftoption.h freetype/src/sfnt/sfntpic.c freetype/src/gzip/zutil.c freetype/src/winfonts/winfnt.h freetype/src/smooth/smooth.c freetype/src/sfnt/sfntpic.h freetype/src/gzip/zutil.h freetype/src/smooth/ftgrays.c freetype/src/raster/ftmisc.h freetype/src/gxvalid/gxvmorx4.c freetype/src/winfonts/Jamfile freetype/include/freetype/internal/pcftypes.h freetype/src/smooth/ftgrays.h freetype/src/pfr/pfrerror.h freetype/src/raster/raster.c freetype/include/freetype/internal/services/svwinfnt.h freetype/docs/CUSTOMIZE freetype/builds/unix/configure.raw freetype/include/freetype/internal/t1types.h freetype/builds/wince/vc2008-ce/freetype.vcproj freetype/src/otvalid/module.mk freetype/ChangeLog freetype/include/freetype/internal/services/svpscmap.h freetype/include/freetype/fttrigon.h freetype/docs/FTL.TXT freetype/src/cache/ftcmanag.c freetype/src/sfnt/ttsbit.c freetype/README freetype/src/cache/ftcmanag.h freetype/src/sfnt/ttsbit.h freetype/src/type42/t42drivr.c freetype/src/psaux/psconv.c freetype/include/freetype/ftbdf.h freetype/include/freetype/ftsizes.h freetype/src/type42/t42drivr.h freetype/src/psaux/psconv.h freetype/include/freetype/internal/services/svtteng.h freetype/include/freetype/internal/ftdebug.h freetype/src/tools/docmaker/docmaker.py freetype/src/gxvalid/gxverror.h freetype/src/autofit/module.mk freetype/include/freetype/internal/ftstream.h freetype/src/cff/cfftypes.h freetype/src/gxvalid/gxvmorx5.c freetype/src/gxvalid/gxvmod.c freetype/include/freetype/internal/ftpic.h freetype/src/gxvalid/gxvmod.h freetype/include/freetype/ftbbox.h freetype/src/otvalid/otvmod.c freetype/src/psnames/psnames.c freetype/src/cid/rules.mk freetype/src/psaux/psauxerr.h freetype/src/type42/t42objs.c freetype/src/otvalid/otvmod.h freetype/src/cache/ftccmap.c freetype/src/cache/ftcbasic.c freetype/src/type42/t42objs.h freetype/src/smooth/ftsmerrs.h freetype/include/freetype/internal/services/svttcmap.h freetype/version.sed freetype/src/psaux/t1decode.c freetype/src/autofit/rules.mk freetype/src/tools/docmaker/utils.py freetype/builds/win32/visualc/index.html freetype/src/psaux/t1decode.h freetype/src/type42/module.mk freetype/src/otvalid/otvjstf.c freetype/src/autofit/aferrors.h freetype/src/cff/cffgload.c freetype/src/gxvalid/gxvlcar.c freetype/include/freetype/internal/services/svsfnt.h freetype/src/base/ftinit.c freetype/src/bdf/README freetype/src/cache/ftccback.h freetype/src/cff/cffgload.h freetype/src/base/ftmm.c freetype/src/pcf/module.mk freetype/docs/TODO freetype/src/tools/Jamfile freetype/src/autofit/afangles.c freetype/include/freetype/config/ftoption.h freetype/src/cff/cffload.c freetype/src/gxvalid/gxvcommn.c freetype/src/autofit/afangles.h freetype/src/cff/cffload.h freetype/src/gxvalid/gxvcommn.h freetype/src/sfnt/ttpost.c freetype/src/sfnt/ttpost.h freetype/src/cache/rules.mk freetype/include/freetype/ttunpat.h freetype/include/freetype/ftmodapi.h freetype/include/freetype/internal/fttrace.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-05T100359.155794Z"></a>
-2010-04-05T10:03:59.155794Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Fix the FAPI implementation of finding the appropriate bytes for a given
-character code from an array of strings representing a CMap.</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-02T123123.439338Z"></a>
-2010-04-02T12:31:23.439338Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-'Fix' FAPI with FreeType.
-
-FreeType's hinting is worse than useless for type 1 fonts, its actually harmful. It
-distorts the glyph shape because it hints an unscaled outline. While it would be best
-to fix FreeType's hinting this is a large project. For now this patch disables FreeType
-hinting when handling type 1 fonts.
-
-This resolves many spacing issues as well as fixing the stroke/fill mismatch with
-ia3z3519.pdf and the incorrectly scaled outline in womanface.pdf.
-</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-02T091923.286738Z"></a>
-2010-04-02T09:19:23.286738Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Extend Ken's change to avoid using FT's &quot;synthetic&quot; vertical metrics
-for Type42 fonts to cover all fonts using TTF outlines (so CIDType 2 fonts, as
-well).</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-02T090653.941441Z"></a>
-2010-04-02T09:06:53.941441Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix a bug in the FreeType scan conversion.
-
-A multiply and divide to calculate the slope of a line did not account for the
-possibility of overflow during multiplication. Using the supplied SMulDiv routine fixes
-the problem.
-
-The patch has been supplied upstream to the FreeType development team.
-</pre>
-<p>[freetype/src/raster/ftraster.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-04-01T133252.153614Z"></a>
-2010-04-01T13:32:52.153614Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Slight tidy up to gs_2_colors code: Given that the cie_joint_caches_alt is
-now kept in the imager state rather than the graphics state, move the
-reference counting/initialisation for the same into the imager state
-too. No difference in operation, but just a bit tidier.
-
-No expected differences, though the cluster may show 2colCIEtest.pdf as
-failing if it hasn't propogated around the nodes yet.
-
-</pre>
-<p>[base/gsstate.c base/gsistate.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-31T154306.179195Z"></a>
-2010-03-31T15:43:06.179195Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Bounds check the correct object when looking up a CID map</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-31T144031.704728Z"></a>
-2010-03-31T14:40:31.704728Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Correct a logical error/typo in the fallback to non-hinted condition.</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-31T132201.442343Z"></a>
-2010-03-31T13:22:01.442343Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Prevent applying the nominalWidthX for T2 fonts, when FT already applies
-it for us. Previously, the code was actually erroneously adding the
-defaultWidthX. Since this use of nominalWidthX *may* be renderer dependent,
-it is now controlled by the can_replace_metrics() call.</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-31T131641.790764Z"></a>
-2010-03-31T13:16:41.790764Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-In the even a glyph name is not found in the CharStrings dictionary, fall
-back to using the .notdef (instead of returning an error).</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-31T130744.152960Z"></a>
-2010-03-31T13:07:44.152960Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-For certain errors from FT, retry interpretting the glyph without hinting - this more
-closely matches the existing behaviour.</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-31T113210.299125Z"></a>
-2010-03-31T11:32:10.299125Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Remove unused variable. No expected differences.
-
-</pre>
-<p>[base/gsstate.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-31T012018.778513Z"></a>
-2010-03-31T01:20:18.778513Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Temporary reversion of previous mkromfs commit to remove -g until it works
-correctly (fooled by a GS_LIB environment variable during testing)
-</pre>
-<p>[psi/psromfs.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-30T225953.311321Z"></a>
-2010-03-30T22:59:53.311321Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Implement '-g' option in mkromfs to fold in some of the older 'genint'
-functions (collect all init files into a single gs_init.ps, strip
-whitespace and comments). Also change mkromfs so that wildcard expansion
-must be specified using '*' on the command line which also means that
-single explicit files can now be put into the %rom% file system.
-
-Add many missed dependencies to the list for the 'gsromfs.c' %rom% file
-system (CMap, ColorSpace, Decoding, Encoding, Font, IdiomSet, ProcSet,
-SubstCID) and separate out miscellenaeous files.
-
-Remove old geninit references from makefiles: psi/int.mak psi/os2.mak,
-base/bcwin32.mak, base/msvctail.mak, base/winlib.mak, base/macos-mcp.mak,
-base/openvms.mak, base/lib.mak, base/unix-aux.mak base/watcw32.mak,
-base/wctail.mak
-</pre>
-<p>[base/wctail.mak psi/os2.mak base/lib.mak base/bcwin32.mak base/openvms.mak base/mkromfs.c base/gs.mak base/watcw32.mak psi/psromfs.mak psi/int.mak base/unix-aux.mak base/macos-mcp.mak base/msvctail.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-30T184034.337393Z"></a>
-2010-03-30T18:40:34.337393Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix bug 691132 by ensuring that whenever we set a line width, we set
-it to the absolute value of the line width. This seems consistent with
-PDF, and cures the clipping problem in PCL referred to by the bug.
-
-No expected differences.
-
-</pre>
-<p>[base/gxline.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-30T144656.884951Z"></a>
-2010-03-30T14:46:56.884951Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-In the gs_2_colors branch I had made 2 copies of the color state and swapped
-between them. I had included dev_ht as part of this 'split' state, which
-was a significant contributor to the slowdown due to it forcing repeated
-writing of the halftone data to the clist. Also, it required significant
-extra work on every setscreen or setcolorscreen operation.
-
-Discussions with Henry/Ray/Kens et al lead to the realisation this wasn't
-required. This patch therefore backs out the dev_ht split, and the changes
-to zsetscreen and zsetcolorscreen. Additional code is however required to
-clear the 'alternative' dev_color when a halftone is installed to stop the
-'swapped out' color pointing to an illegal halftone cache.
-
-This runs through local testing with no diffs showing (though some
-strangeness was observed with an earlier version of this patch in
-regression testing - Marcos has captured this with bug 691223).
-
-This seems to have helped with the largest slowdowns, but there are still
-significant differences in some cases. Very preliminary investigations seem
-to show more time being spent in the interpreter/gc mechanism. Continuing
-to investigate.
-
-
-</pre>
-<p>[base/gsstate.c base/gxistate.h base/gsht.c base/gxdcolor.h base/gzstate.h psi/zht.c psi/zht1.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-30T101657.091024Z"></a>
-2010-03-30T10:16:57.091024Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-New Fontmap files for the URW fonts, both type 1 and TrueType formats.
-
-The file Fontmap.URW-136.T1 contains definitions for the type 1 fonts (the URW PFB
-fonts must be in the search path).
-
-The file Fontmap.URW-136.TT contains definitions for the TrueType fonts (the URW TTF
-fonts must be in the search path).
-
-Currently neither of these work 100% because of problems with the URW font sets
-(several incorrectly named fonts, and in one case an illegal type 1 font)
-
-</pre>
-<p>[lib/Fontmap.URW-136.T1 lib/Fontmap.URW-136.TT]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-29T191049.447074Z"></a>
-2010-03-29T19:10:49.447074Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Drop 'loca' entries that point beyond 'glyf' table during re-spliting
-sfnts glyfs strings. Bug 691221.
-</pre>
-<p>[Resource/Init/gs_ttf.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-29T075249.284823Z"></a>
-2010-03-29T07:52:49.284823Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Change the FT interface code so we always use metrics retrieved from Freetype,
-rather than attempting to &quot;fabricate&quot; metrics (which have already
-been handled correctly by FT).</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-27T015955.922560Z"></a>
-2010-03-27T01:59:55.922560Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix compilation error in pngs2html.pl (forgot to define variable).
-
-</pre>
-<p>[toolbin/localcluster/pngs2html.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-26T102856.873949Z"></a>
-2010-03-26T10:28:56.873949Z Masaki Ushizaka</strong></p>
-<blockquote>
-<pre>
-A leftover from r10603 (Makefile change).</pre>
-<p>[base/lib.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-26T002016.302228Z"></a>
-2010-03-26T00:20:16.302228Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Updated localcluster bmpcmp html generation script. Bitmaps produced are now
-zoomable.
-
-
-</pre>
-<p>[toolbin/localcluster/pngs2html.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-24T124759.902550Z"></a>
-2010-03-24T12:47:59.902550Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix for bug 691115.
-
-In some circumstances, the shading code can get all the way to the point of
-marking the screen/page without ever clipping to the relavent region. This
-produces cases where we &quot;draw outside the lines&quot;. Often this is masked by
-the fact that we only ever draw as far out of the lines as would be covered
-by an area of constant color (typically a small area).
-
-The fix for this is to spot the unclipped case when we come to render
-trapezoids to the screen, and to clip the trapezoid into (at most) 3
-smaller trapezoids.
-
-This causes 104 non-pdfwrite differences, and 24 pdfwrite ones. Examination
-using localcuster bmpcmp shows them all to be acceptable.
-
-</pre>
-<p>[base/gxshade6.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-24T120547.469905Z"></a>
-2010-03-24T12:05:47.469905Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Tweak to bmpcmp: Darken the third image (the diff image) to make changes
-stand out better.
-
-</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-24T001027.875727Z"></a>
-2010-03-24T00:10:27.875727Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Correct DOS line endings in bmpcmp.c.
-
-Fix bug whereby areas with no changes in were still be saved out.
-
-</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-23T191432.177681Z"></a>
-2010-03-23T19:14:32.177681Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Correct problem with bmpcmp whereby certain sizes of changed areas within
-images could cause overlapping output bitmaps. This causes problems with
-the output of bitmaps now due to the new 'in-place' generation of the diff
-bitmap. Fixed by choosing sizes more smartly.
-
-</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-23T090216.120692Z"></a>
-2010-03-23T09:02:16.120692Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-CUPS Raster output device: Error out correctly with the return_error() macro
-and not with &quot;gs_exit(); exit()&quot;, force banding mode as there are
-files which do not render otherwise (Bug #691170).
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-23T000659.853037Z"></a>
-2010-03-23T00:06:59.853037Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Code clean-ups in the &quot;cups&quot; output device to fix the segfaults
-in bug #691170 and bug #691014 (but does not fix the bugs yet).
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-22T141842.718453Z"></a>
-2010-03-22T14:18:42.718453Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Handle CID fonts whose GDBytes != 2 - previously GDBytes was hardcoded as 2.</pre>
-<p>[psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-22T064308.806820Z"></a>
-2010-03-22T06:43:08.806820Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Added the ability to specify bmpcmp options when running clusterpush.pl, e.g.:
-
-clusterpush.pl bmpcmp -w 9 -t 10
-
-No validation is done on the options; bad options will result in no bmpcmp output being generated.
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/readlog.pl toolbin/localcluster/build.pl toolbin/localcluster/clusterpush.pl toolbin/localcluster/run.pl toolbin/localcluster/compare.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-21T050150.135122Z"></a>
-2010-03-21T05:01:50.135122Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Fixed maxdiffs argument in bmpcmp.c (was acting as maxpage).
-</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-21T032353.245152Z"></a>
-2010-03-21T03:23:53.245152Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Fixed a couple of compiler warnings in bmpcmp.c
-</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-19T183004.447497Z"></a>
-2010-03-19T18:30:04.447497Z Ralph Giles</strong></p>
-<blockquote>
-<pre>
-Compute AES cypher tables at compile time instead of run time.
-
-The aes implementation needs some tables of data to perform its
-calculations. In a thread-safety review, Henry spotted that the
-tables were global variables with no mutex isolation.
-
-I believe this is actually ok. There is a static flag marking whether
-the tables are initialized. If they are not, a call to aes_setkey_*
-will invoke aes_gen_tables to initialize them, then set the flag.
-However, aes_gen_tables operates deterministically, always writing
-the same data sequence to the globals. So while there is a race
-where two threads could be executing aes_gen_tables at the same time,
-or while another thread is accessing the same tables, there is no
-read-modify-write step which could create inconsistent data.
-
-Nevertheless, the tables are small relative to our application, and
-there is a compile time option XYSSL_AES_ROM_TABLES which generates
-the data at compile time and stores it static const. This commit
-turns on that option, allowing the compiler to put the data in a
-non-writable segment and making the careful thread safety analysis
-above unnecessary.
-
-There should be no difference in behaviour, and Henry has verified
-that the two code paths result in identical table data.</pre>
-<p>[base/aes.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-18T113938.599047Z"></a>
-2010-03-18T11:39:38.599047Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Update the list of face substitutions in .substitutefaces to include all the fonts we
-define in Fontmap.GS (if not already defined).
-
-Bug #691180, if we have a font defined in the Fontmap then we don't use the additional
-information in a PDF file FontDescriptor. Instead we stick with whatever font the PS
-substitution comes up with (if the font is not present). If a member of the family is
-not defined we do use the FontDescriptor. This can lead to different choices for the
-substitute font. By defining the font in the substitutefaces array we can attempt to get
-a consistent result.
-
-This *will* lead to differences in the regression suite as we are now substituting
-different fonts for some missing faces. Apparently only with the test file for this
-bug though.</pre>
-<p>[Resource/Init/gs_fonts.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-18T005710.529905Z"></a>
-2010-03-18T00:57:10.529905Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Merge gs_2_colors branch down to trunk.
-
-This adds a new set of color state information to the graphics/imager
-state, along with a new non-standard postscript operator .swapcolors to
-toggle between them.
-
-The Postscript interpreter is updated to use one set of color information
-for stroking, and the other for all non-stroking colors.
-
-This produces differences in just 2 pdfwrite tests, due to rounding errors
-due to changes in the way pdf with non-zero rendering modes is emitted now.
-
-</pre>
-<p>[psi/zcolor.c base/gsdps1.c base/gdevpdft.c base/gxccache.c /trunk/gs base/gspaint.c base/gscsepr.c base/gsimage.c base/gxchar.c base/gsptype1.c base/gxcmap.c psi/interp.c base/gzstate.h psi/dmmain.c base/gscspace.c base/gscolor1.c base/gscdevn.c base/gscolor2.c base/gscie.c base/gxistate.h psi/psromfs.mak psi/dxmain.c base/gxcspace.h base/gxhldevc.c psi/dxmainc.c psi/dmmain.r Resource/Init/pdf_draw.ps psi/zht1.c base/gscolor.c psi/zicc.c psi/zchar1.c base/gxpaint.c base/gsstate.c Resource/Init/pdf_ops.ps psi/zcie.c base/gstext.c Resource/Init/pdf_font.ps base/gstrans.c psi/zht.c base/gsequivc.c base/gxdcolor.h psi/igstate.h base/gspcolor.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-17T214113.190501Z"></a>
-2010-03-17T21:41:13.190501Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-bmpcmp tweak to allow maximum/minimum bitmap sizes to be set from the
-command line.
-
-</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-17T201225.972208Z"></a>
-2010-03-17T20:12:25.972208Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-MSVC whinges when asked to shift by 32 or more bits at once. Simple tweaks
-to fool the compiler and eliminate warnings.
-
-No expected differences.
-
-</pre>
-<p>[base/gdevm64.c base/gdevm56.c base/gdevm48.c base/gdevm40.c base/gxclrast.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-17T185412.480084Z"></a>
-2010-03-17T18:54:12.480084Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Tweak to gxcmap.c to remove warnings about shifting by more than 32 bits on
-MSVC builds.
-
-No expected differences.
-
-</pre>
-<p>[base/gxcmap.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-17T173027.541399Z"></a>
-2010-03-17T17:30:27.541399Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Revised bmpcmp.
-* Redone command line handling
-* Ability to read PAMs (so we can read CMYK stuff now)
-* &quot;Fuzzy&quot; behaviour (both compatible and exhaustive modes)
-* New behaviour using map bitmap to avoid rediffing multiple times.
-* CMYK -&gt; RGB conversion as last step before PNG/BMP writing.
-
-Still to do:
-* Output number of fuzzy matches etc to the meta file.
-
-</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-15T191855.825828Z"></a>
-2010-03-15T19:18:55.825828Z Lars Uebernickel</strong></p>
-<blockquote>
-<pre>
-Change default TIFF strip size to one megabyte.
-
-Many fax readers have problems reading TIFF images which are chunked into
-strips, and one megabyte is larger than the biggest expected fax page. Hence,
-ghostscript's default TIFF output will be accepted by those readers.
-
-
-</pre>
-<p>[base/gdevtifs.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-15T190043.589302Z"></a>
-2010-03-15T19:00:43.589302Z Lars Uebernickel</strong></p>
-<blockquote>
-<pre>
-Write TIFF directories before the page data. This might help bug #691172 and
-probably some other non-conforming TIFF readers.
-
-</pre>
-<p>[base/gdevtifs.c base/gdevtsep.c base/gdevtfnx.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-15T152155.436137Z"></a>
-2010-03-15T15:21:55.436137Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Don't throw an error when a filter returns 0 bytes and a normal return code.
-This often happens with eexecDecode filter, which has to return the control
-to the interpreter after every space character since Adobe no longer adds
-zeros at the end of the encoded block. Document new return code 2 used by
-eexecDecode filter. Bug 690909.
-</pre>
-<p>[base/sstring.c base/seexec.c psi/iscan.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-15T145615.278449Z"></a>
-2010-03-15T14:56:15.278449Z Lars Uebernickel</strong></p>
-<blockquote>
-<pre>
-Partial fix for bug #691172: The tiff resolution tags are floating point values
-and need to be passed as such to TIFFSetField.
-
-</pre>
-<p>[base/gdevtifs.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-15T074438.447170Z"></a>
-2010-03-15T07:44:38.447170Z Lars Uebernickel</strong></p>
-<blockquote>
-<pre>
-Applied Tim Waugh's patch from bug #691171: A NULL check for the argument of
-TIFFCleanup was missing, which caused a segfault when opening the output device
-failed for any of the devices in gdevtfax.c.
-
-</pre>
-<p>[base/gdevtfax.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-15T063434.317078Z"></a>
-2010-03-15T06:34:34.317078Z regression</strong></p>
-<blockquote>
-<pre>
-Added support for mupdf testing in local regression suite.
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/readlog.pl toolbin/localcluster/build.pl toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-15T063125.268888Z"></a>
-2010-03-15T06:31:25.268888Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-Changes to the local cluster code:
-
-added bmpcmp documentation to clusterpush.txt
-new file, runNightly.pl, for nightly regression testing
-readlog.pl, build.pl, and run.pl changes for nightly regression use
-</pre>
-<p>[toolbin/localcluster/readlog.pl toolbin/localcluster/build.pl toolbin/localcluster/runNightly.pl toolbin/localcluster/run.pl toolbin/localcluster/clusterpush.txt]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-11T173630.596061Z"></a>
-2010-03-11T17:36:30.596061Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Apply a change submitted to FT and accepted - see FT bug #27442</pre>
-<p>[freetype/src/raster/ftraster.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-11T050122.057384Z"></a>
-2010-03-11T05:01:22.057384Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-
-Run svn update on the ghostscript source even for clusterpush runs to make sure that bmpcmp.c is current.
-
-</pre>
-<p>[toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-10T174109.765460Z"></a>
-2010-03-10T17:41:09.765460Z regression</strong></p>
-<blockquote>
-<pre>
-
-Minor cleanup of the local cluster code.
-
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/pngs2html.pl toolbin/localcluster/build.pl toolbin/localcluster/run.pl toolbin/localcluster/compare.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-10T164226.014885Z"></a>
-2010-03-10T16:42:26.014885Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix bug in bmpcmp.c: When reading images from multi-image sets, we stop
-the comparison process as soon as we fail to find any differences in the
-current image. With this fix we correctly keep searching to the end.
-
-</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-10T150557.116970Z"></a>
-2010-03-10T15:05:57.116970Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Change how we derive the glyph metrics from FT: we now interpret the glyph
-description only once, scaled and hinted, and then calculate the metrics
-from that. It's more accurate, accounts for hints that extend the glyph outline
-and should be a worthwhile speed improvement.</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-10T125150.027959Z"></a>
-2010-03-10T12:51:50.027959Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Change the condition under which we update the overprint device when restoring
-a graphics state to be more relaxed; rather than updating if the overprint
-state has changed we now update if it was enabled, or it if it is enabled.
-
-The logic behind this is that it will still fire in all the same conditions
-it did before, but will also fire when we restore from a state that had it
-enabled to another state that had it enabled. This should be entirely
-harmless, but will allow the state to be updated in the case where a
-colorspace has been updated.
-
-This causes 2 differences in the tests, that only show up in psd files.
-All indications seem to be that these files really are identical. But if
-they aren't, I believe they should be progressions, rather than regressions.
-
-This moves the trunk more into line with the output of the gs_2_colors branch.
-
-</pre>
-<p>[base/gsstate.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-10T061323.278865Z"></a>
-2010-03-10T06:13:23.278865Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-
-Added local modes to build.pl and run.pl in preparation for use as part of the nightly regression.
-
-</pre>
-<p>[toolbin/localcluster/build.pl toolbin/localcluster/run.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-10T051959.535554Z"></a>
-2010-03-10T05:19:59.535554Z Ray Johnston</strong></p>
-<blockquote>
-<pre>
-Fix for SEGV with the psdcmyk device on 258-01.ps. This was a fundamental memory
-problem with any device that used the compressed_color_list functions in gdevdevn.c
-since a 'restore' could free structures which were still needed by the device.
-Use stable_memory to avoid this. Bug 691150.
-</pre>
-<p>[base/gdevdevn.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-09T172707.400171Z"></a>
-2010-03-09T17:27:07.400171Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Another tweak to the local cluster bmpcmp html page generation. I managed to
-miss renaming the images in the second column.
-
-</pre>
-<p>[toolbin/localcluster/pngs2html.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-09T172239.470336Z"></a>
-2010-03-09T17:22:39.470336Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Another tweak to the localcluster bmpcmp html page generation javascript;
-quote the string to avoid it being converted to an int.
-
-
-</pre>
-<p>[toolbin/localcluster/pngs2html.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-09T172235.452303Z"></a>
-2010-03-09T17:22:35.452303Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Let pdftoraster not exit before the Ghostscript sub-process finishes. Thanks to Tim Waugh from Red Hat for the patch.
-</pre>
-<p>[cups/pdftoraster.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-09T171522.155871Z"></a>
-2010-03-09T17:15:22.155871Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix pngs2html.pl to number images according to both directory and image
-number (needed now as images restart from 0 within each directory). This
-really should fix the bmpcmp html output.
-
-</pre>
-<p>[toolbin/localcluster/pngs2html.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-09T170842.132281Z"></a>
-2010-03-09T17:08:42.132281Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-More fixes for the bmpcmp html page generations javascript.
-
-Change code to pass numbers to swap() rather than strings as javascripts
-conversion of strings to ints is... unhelpful.
-
-</pre>
-<p>[toolbin/localcluster/bmps2html.pl toolbin/localcluster/pngs2html.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-09T165048.278966Z"></a>
-2010-03-09T16:50:48.278966Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Misplaced bracket in the javascript meant that only the first images would
-swap on mouseover properly. Fixed here.
-
-
-</pre>
-<p>[toolbin/localcluster/bmps2html.pl toolbin/localcluster/pngs2html.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-09T163921.328229Z"></a>
-2010-03-09T16:39:21.328229Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix javascript problems in bmpcmp output page generation. What sort of
-stupid broken language depends on whitespace?
-
-</pre>
-<p>[toolbin/localcluster/bmps2html.pl toolbin/localcluster/pngs2html.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-09T163506.527087Z"></a>
-2010-03-09T16:35:06.527087Z Till Kamppeter</strong></p>
-<blockquote>
-<pre>
-Fixes on CUPS Raster output device:
-- Fixed memory reallocation on bitmap size change. Reallocation is not only
-needed when dimendions and margins change, but also when the color depth
-changes. Fixes bugs #691029 and #691108.
-- Fixed arrayoption() macro in cups_put_params() function. Array values did
-not get actually set in cups.header data structure. Bug only showed via
-a compiler warning.
-- Silenced compiler warning by presetting c0..c3 in cups_map_cmyk() to zero.
-</pre>
-<p>[cups/gdevcups.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-09T162931.666786Z"></a>
-2010-03-09T16:29:31.666786Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Attempted fix for bmpcmp output javascript problems with the coordinate
-tracking.
-
-</pre>
-<p>[toolbin/localcluster/pngs2html.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-09T161159.669918Z"></a>
-2010-03-09T16:11:59.669918Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix typos in the javascript code for pngs2html.pl and bmps2html.pl; this should
-get at least some of it working, but the coord stuff still baffles me.
-
-Also fix a typo that was causing the wrong &quot;third image&quot; to appear.
-
-</pre>
-<p>[toolbin/localcluster/bmps2html.pl toolbin/localcluster/pngs2html.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-09T014606.865448Z"></a>
-2010-03-09T01:46:06.865448Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-
-Fixed longstanding bug fuzzy.c that caused pbm files to be misread.
-
-</pre>
-<p>[toolbin/tests/fuzzy.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-08T215705.576067Z"></a>
-2010-03-08T21:57:05.576067Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-updating documentation to mention how to run mkcidfm.ps manually; bug 688437</pre>
-<p>[doc/Use.htm]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-08T215437.005008Z"></a>
-2010-03-08T21:54:37.005008Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-convert font file name to lowser case before matching; make it possible for upper case ARIALUNI.TTF to match; bug 688437</pre>
-<p>[lib/mkcidfm.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-08T214956.216990Z"></a>
-2010-03-08T21:49:56.216990Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-updating windows CJK font substitution list for more commonly found MS CJK fonts; bug 688437</pre>
-<p>[lib/mkcidfm.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-08T214715.240330Z"></a>
-2010-03-08T21:47:15.240330Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-revert to r8185 version of the korean example - it was removed in r8190 and a
-corrupted version r9325 was subsequently checked in; found during fixing bug
-688437 (incompete font substitution list)</pre>
-<p>[examples/cjk/gscjk_ak.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-08T162053.842289Z"></a>
-2010-03-08T16:20:53.842289Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Ongoing bug fixes for #690448.
-The FreeType code will synthesize vertical metrics for TrueType (Type 42) fonts which do
-not contain a vmtx table. This includes the vertical advance, which will be returned
-to the FAPI code, and used even if there were originally no vertical metrics and the
-font should not have any vertical advance.
-
-Modified the metrics override callback, called by FT, so that if the font is a TT font,
-and this is a vertical metrics call, we set the advance to 0. This prevents the
-synthesized metrics from incorrectly advancing the glyph vertically.
-
-This may eventually be a problem if we find a CIDFont with Type42 outlines which relies
-on the vmtx table in the font rather than the Metrics2 or CDevProc overrides to position
-the glyphs. Since this facility was only added in CPSI 3011 it is unlikely we will ever
-encounter such a font. THis has not been done at present, as the information (WMode=1)
-is not currently available to the code called from FreeType to override the metrics,
-and would need to be added.
-
-Also, fixed an issue where the 'advance_v' member of the metrics structure was left
-uninitialised if a horizontal override took place. This could cause glyphs to be
-mis-positioned vertically.
-</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-08T154120.817468Z"></a>
-2010-03-08T15:41:20.817468Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-revert revision 10871, we will tackle this problem in the FAPI FreeType interface code
-instead of in FreeType itself.
-
-</pre>
-<p>[psi/fapi_ft.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-08T152257.356559Z"></a>
-2010-03-08T15:22:57.356559Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-revert revision 10871, we will address the matter of FreeType creating synthetic vertical
-metrics when none exist by overriding the synthetic metrics in the FAPI FreeType interface
-code instead.
-</pre>
-<p>[freetype/src/truetype/ttgload.c freetype/include/freetype/freetype.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-08T092849.484133Z"></a>
-2010-03-08T09:28:49.484133Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-Latest improvements to the FAPI/FT bridge code. This code resolves the
-issues with font matrices which do more than just scale. It is not yet
-&quot;finished&quot;, but is too big a step forward to risk losing.</pre>
-<p>[psi/fapi_ft.c psi/zfapi.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-05T210134.974121Z"></a>
-2010-03-05T21:01:34.974121Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-
-Added bmpcmp option to clusterpush.pl.
-
-</pre>
-<p>[toolbin/localcluster/clusterpush.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-05T192534.812546Z"></a>
-2010-03-05T19:25:34.812546Z regression</strong></p>
-<blockquote>
-<pre>
-
-Export results of local cluster bmpcmp command to web.
-
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-05T165000.654216Z"></a>
-2010-03-05T16:50:00.654216Z regression</strong></p>
-<blockquote>
-<pre>
-
-Update the local cluster code to use the new pbm-&gt;png mode of bmpcmp.
-
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/build.pl toolbin/localcluster/run.pl toolbin/localcluster/compare.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-05T164710.049203Z"></a>
-2010-03-05T16:47:10.049203Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-
-Minor changes due to bugzilla update.
-
-</pre>
-<p>[toolbin/bugsByEngineer.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-05T132434.158774Z"></a>
-2010-03-05T13:24:34.158774Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix FreeType
-Ongoing fixes for bug #690448. In this case FreeType generates vertical metrics for
-TrueType (in our case Type 42) fonts which lack vhea/vmtx tables, which is generally
-the case.
-
-These metrics are useful to a 'normal' TrueType consumer which has a notion of the
-orientation of the writing direction. However in PostScript we don;t know that, so we
-apply both the horizontal and vertical advance widths.
-
-If the vertical advance should be 0 (because its not specified) then creating one causes
-the glyphs to be misplaced.
-
-This code adds a new load flag to FreeType 'FT_LOAD_NO_SYNTHETIC_METRICS', and sets
-this flag in the FAPI FreeType interface code, which prevents FreeType from manufacturing a bogus vertical advance.
-</pre>
-<p>[psi/fapi_ft.c freetype/src/truetype/ttgload.c freetype/include/freetype/freetype.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-05T092347.698736Z"></a>
-2010-03-05T09:23:47.698736Z Lars Uebernickel</strong></p>
-<blockquote>
-<pre>
-Open tiffsep and tiffsep1 output files as seekable.
-
-All files written by libtiff have to be seekable when writing multiple pages,
-because libtiff tries to access previously written page dictionaries. This
-fixes bug 691160.
-
-</pre>
-<p>[base/gdevtsep.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-05T070113.637667Z"></a>
-2010-03-05T07:01:13.637667Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-
-Fix pbm reading and png writing in bmpcmp.c.
-
-</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-05T053224.962092Z"></a>
-2010-03-05T05:32:24.962092Z regression</strong></p>
-<blockquote>
-<pre>
-
-Added pngs2html.pl to repository: take a directory full of png files
-generated by the increasingly poorly named bmpcmp.c and generate web pages
-(like bmps2html.pl but without the bmp-&gt;png conversion).
-
-</pre>
-<p>[toolbin/localcluster/pngs2html.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-03T212107.833457Z"></a>
-2010-03-03T21:21:07.833457Z Ralph Giles</strong></p>
-<blockquote>
-<pre>
-Flip images from RGB to BGR pixel format when reading ppm files,
-and flip them back to RGB when writing png files.
-
-This adapts all the current routines to assume the BGRx storage
-format used by the bmp image format for the internal representation,
-as is already done with the row order.</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-03T212104.624166Z"></a>
-2010-03-03T21:21:04.624166Z Ralph Giles</strong></p>
-<blockquote>
-<pre>
-Also save the difference image as a png when bmpcmp is compiled with HAVE_LIBPNG.</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-03T203001.695369Z"></a>
-2010-03-03T20:30:01.695369Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Fix stupid memory overwrite bug on bmp load.
-
-</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-03T200329.767395Z"></a>
-2010-03-03T20:03:29.767395Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-bmpcmp.c tweaks: Add (largely untested) code to allow &quot;plain&quot; (ascii) ppm,
-pgm, pbm files. Also fix some compile warnings on 64bit platforms. Now
-compiles cleanly with -Wall.
-
-
-</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-03T190712.236947Z"></a>
-2010-03-03T19:07:12.236947Z Ralph Giles</strong></p>
-<blockquote>
-<pre>
-Add optional support for png output to the bmpcmp utility.
-
-When compiled with the HAVE_LIBPNG preprocessor symbol defined, and
-linking with libpng, the utility will save its output focus images
-in RGB png format. Currently, only 32 bit RGBx pixel data is supported.</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-02T224902.357333Z"></a>
-2010-03-02T22:49:02.357333Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Attempt to fix the javascript in the created files. The change to use
-numeric filenames padded to 5 chars had broken the javascript. This
-might fix it.
-
-</pre>
-<p>[toolbin/localcluster/bmps2html.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-02T212636.100914Z"></a>
-2010-03-02T21:26:36.100914Z regression</strong></p>
-<blockquote>
-<pre>
-
-More changes towards having a bmpcmp running on the local cluster.
-
-</pre>
-<p>[toolbin/localcluster/bmps2html.pl toolbin/localcluster/clustermaster.pl toolbin/localcluster/build.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-02T211259.888859Z"></a>
-2010-03-02T21:12:59.888859Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Updated bmpcmp to avoid inverting pnms on reading.
-
-Also improve reading of non 32bpp bitmaps - still not quite right.
-
-</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-02T001558.939654Z"></a>
-2010-03-02T00:15:58.939654Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-
-Added partial support for &quot;clusterpush.pl bmpcmp&quot; (which will allow
-users to generate bitmap comparisons of their most recent clusterpush
-job and trunk).
-
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/build.pl toolbin/localcluster/clusterpush.pl toolbin/localcluster/run.pl toolbin/localcluster/compare.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-01T174440.662743Z"></a>
-2010-03-01T17:44:40.662743Z Ralph Giles</strong></p>
-<blockquote>
-<pre>
-Add support to the autoconf and msvc builds to compile in a copy of
-the FreeType2 library from local source.
-
-Previously, the FAPI bridge for freetype required that the library
-be compiled externally and include and link flags passed through
-the FT_CFLAGS and FT_LIBS makefile variables. We now include a copy
-of the freetype source in the tree, to make it easier to find a
-compatible version of the source and to simplify building for
-platforms that don't provide a system freetype.
-
-Now, to enable both freetype and the FAPI bridge, pass --enable-freetype
-to the configure script. This will set FT_BRIDGE=1 and the other required
-variables. The configure script will prefer local source in gs/freetype2
-to the copy in gs/freetype to simplify testing against upstream.
-
-To enable freetype in the msvc build, pass FT_BRIDGE=1 on the nmake command
-line.
-
-Note that the fallback is now FT_BRIDGE=0, not FT_BRIDGE undefined; this
-will require changes in any custom top-level makefiles.
-</pre>
-<p>[base/winlib.mak doc/Make.htm base/gs.mak base/Makefile.in psi/int.mak base/configure.ac psi/msvc32.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-03-01T153456.724940Z"></a>
-2010-03-01T15:34:56.724940Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Fixes bug #691154 and the regressions associated with revision 10823.
-Unfortunately, performance-wise, the wtsimdi device must always use a
-contone buffer until we've had a chance to see which raster operations
-can be eliminated correctly.
-</pre>
-<p>[base/gdevwts.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-28T225702.883228Z"></a>
-2010-02-28T22:57:02.883228Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-First half of patch from John Wehle for bug 691149 - vac C compiler on AIX 5.2 does
-not like function with a void prototype returning a void function e.g.
-
-------------------
-void func1();
-
-void funct2() {
-return funct1();
-}
-------------------
-
-The 2nd half of the submitted patch was committed as part of r10826 .
-
-</pre>
-<p>[base/gdevpx.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-28T172609.949555Z"></a>
-2010-02-28T17:26:09.949555Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Fixes part of 691149 - void function returning value, thanks to John
-Wehle for the fix. Also, there were several compiler warnings in this
-file related to the casting of the gs memory type pointer which have
-been cleaned up as well.
-</pre>
-<p>[base/gsnogc.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-28T145200.838160Z"></a>
-2010-02-28T14:52:00.838160Z Hin-Tak Leung</strong></p>
-<blockquote>
-<pre>
-The distclean make target should call pgclean to clean up profile build also.</pre>
-<p>[base/Makefile.in]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-28T011926.994088Z"></a>
-2010-02-28T01:19:26.994088Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Following PDF reference, version 1.7, section 10.10, crop /TrimBox and /CropBox
-by the /MediaBox. Bug 691145.
-</pre>
-<p>[Resource/Init/pdf_main.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-27T232931.437722Z"></a>
-2010-02-27T23:29:31.437722Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Fixes bug #691147 customer 861, the optimization to strength reduce
-the raster operation here is wrong, it is premised on the assumption
-the colors are opaque. If either texture or source is transparent the
-strength reduction which effectively ignores the source or pattern is
-wrong and it will subsequently cause opaque painting. We've simply
-removed the optimization instead of conditionalizing on opaque cases,
-because tests indicate the reduction not that significant. The
-example in the bug report was reduced from a file in the XL ATS 305
-test suite. The following customer reported bugs in that test suite
-are fixed by this change:
-
-FH905UJ1.BIN pp 1,2,3,4
-FH906UJ1.BIN pp 1-6
-MA2K7UJ2.BIN pp 1-10
-PW2K6UJ1.BIN pp 2
-PWTTDUJ3.BIN pp 1
-</pre>
-<p>[base/gxipixel.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-27T202413.417473Z"></a>
-2010-02-27T20:24:13.417473Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Upgrade Adobe Glyph List to v. 2.0. AGL is used for character mapping in
-non-symbolic TrueType fonts in PDF files. Bug 691116.
-</pre>
-<p>[Resource/Init/gs_agl.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-27T165647.050522Z"></a>
-2010-02-27T16:56:47.050522Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Add missing newline in a TTF debug message.
-</pre>
-<p>[Resource/Init/gs_ttf.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-26T171128.684024Z"></a>
-2010-02-26T17:11:28.684024Z Ralph Giles</strong></p>
-<blockquote>
-<pre>
-Correct a typo in the freetype makefile which prevented the inclusion
-of ftlzw.c.
-</pre>
-<p>[base/freetype.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-26T064131.056673Z"></a>
-2010-02-26T06:41:31.056673Z Ralph Giles</strong></p>
-<blockquote>
-<pre>
-Fixes to our makefile for the third-party freetype library.
-
-I'd missed a number of &quot;optional&quot; files in the original commit, but
-didn't notice because other dependencies, which themselves link to
-the system freetype library on linux were providing definitions of
-the missing symbols. These are now included in our build.
-
-We now generate freetype.dev by copying freetype_&#36;(SHARE_FT) within
-freetype.mak, the same was this option is handled in the other third-
-party makefiles.
-
-We set native line endings and Id keyword substitution for this file
-in the Subversion repository.
-</pre>
-<p>[base/freetype.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-25T110459.765077Z"></a>
-2010-02-25T11:04:59.765077Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-add quotes around the expansion of DEVSTUDIO variable when it's used for
-the recursive nmake call for debug targets - in case it has white space in it.</pre>
-<p>[psi/msvc32.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-25T082146.259499Z"></a>
-2010-02-25T08:21:46.259499Z Masaki Ushizaka</strong></p>
-<blockquote>
-<pre>
-Fix for bug 691103. The pdfwrite device now considers FDArray fonts'
-FontMatrix and writes correct W/W2/DW/DW2 widths for CIDFont with unusual
-FontMatrix. This also fixes a problem gs_font::orig_FontMatrix not being
-initialized for CIDFont.
-Bug687832.pdf and Bug690834.ps will show differences which are improvements.
-</pre>
-<p>[Resource/Init/gs_cidfn.ps base/gdevpdtt.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-24T202657.347460Z"></a>
-2010-02-24T20:26:57.347460Z Ralph Giles</strong></p>
-<blockquote>
-<pre>
-Add a generic makefile for compiling the freetype library
-as part of the Ghostscript monolithic build.
-
-Including makefiles should define FTSRCDIR, FTGENDIR and FTOBJDIR,
-similar to other third party libraries.
-</pre>
-<p>[base/freetype.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-24T195905.197182Z"></a>
-2010-02-24T19:59:05.197182Z Ralph Giles</strong></p>
-<blockquote>
-<pre>
-Copy our local branch of the freetype library source into the gs tree.
-
-This was the intended result of commit 10804, but an ommitted path element
-placed it in the repository root instead.
-</pre>
-<p>[freetype]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-24T193811.435012Z"></a>
-2010-02-24T19:38:11.435012Z Ralph Giles</strong></p>
-<blockquote>
-<pre>
-Correct a typo in a dependency specification for wrfont.c.
-
-The typo (stdio_h for stdio__h) prevented the dependency on arch.h
-from being declared, generating a temporary error in a sufficiently
-parallel make invocation.
-</pre>
-<p>[psi/int.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-24T192711.525322Z"></a>
-2010-02-24T19:27:11.525322Z regression</strong></p>
-<blockquote>
-<pre>
-
-Changed naming scheme for regressions from 00000-00000 to 00000 (i.e. no longer treat Ghostscript and GhostPDL revisions independently).
-
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/run.pl toolbin/localcluster/cachearchive.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-24T182235.905364Z"></a>
-2010-02-24T18:22:35.905364Z Ralph Giles</strong></p>
-<blockquote>
-<pre>
-Move the fontconfig check into the libraries section of the configure script.
-</pre>
-<p>[base/configure.ac]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-24T181645.225914Z"></a>
-2010-02-24T18:16:45.225914Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-ensure the DEVSTUDIO value is propagated when we recursively nmake for the debug targets.</pre>
-<p>[psi/msvc32.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-24T172823.116518Z"></a>
-2010-02-24T17:28:23.116518Z Ralph Giles</strong></p>
-<blockquote>
-<pre>
-Remove a spurious circular symlink accidentally included in the libpng-1.2.42
-source import.
-</pre>
-<p>[libpng/libpng]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-24T095802.654907Z"></a>
-2010-02-24T09:58:02.654907Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix, ignore a class of broken TrueType font.
-Bug #691121 &quot;gs stops in interpreting tt instructions&quot;. The font executes an MDRP
-instruction with point number 28, the glyph only contains 28 points numbered 0 to 27 so
-the interpreter (correctly) flags an error.
-
-Windows and FT both appear to silently ignore the error and the instruction (definitely
-the case for FreeType). Modified Ins_MDRP to simply return if the indicated point is
-outside the number of points in this case.
-</pre>
-<p>[base/ttinterp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-23T222918.142249Z"></a>
-2010-02-23T22:29:18.142249Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Fixes bug 690967, a diagnostic problem with dumping memory the debug
--ZA option. See the comment in the code for details, the change has
-no effect on production builds.
-</pre>
-<p>[base/gsalloc.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-23T215815.181686Z"></a>
-2010-02-23T21:58:15.181686Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Fix obviously wrong code in .fixsethalftonescreen procedure that is used by
-the setscreen (and setcolorscreen) procedure and caused a PS error if the
-third 'proc' argument to setscreen is a read-only Halftone type 1 dictionary.
-Thanks to Jonathan Dagresta for the patch. Bug 691130, customer 1130.
-</pre>
-<p>[Resource/Init/gs_dps2.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-23T205621.262529Z"></a>
-2010-02-23T20:56:21.262529Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Simplify sed script that extracts libTiff version number for compatibility
-with AIX sed. Include our portable header before tiff.h to make sure that
-all stdint types are found. Bug 691102.
-</pre>
-<p>[base/gdevtifs.c base/gdevtsep.c base/configure.ac base/gdevtfnx.c base/devs.mak base/gdevtfax.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-23T100154.545437Z"></a>
-2010-02-23T10:01:54.545437Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite)
-Bug #691133. If producing PDF/A output. and a DOCINFO pdfmark string was UTF_16BE
-encoded *and* contained a numeric character, then decode_escape incorrectly consumed
-any numeric characters following the first octal byte of the UTF16 code.
-
-This was caused by decode_escape assuming that octal sequences are terminated by
-non-numeric characters which is clearly wrong. The octal escape decoding loop is now
-terminated when :
-1) 3 numeric characters are read from the string
-2) No more data is available in the string
-3) A non-numeric character is encountered in the string.
-
-</pre>
-<p>[base/gdevpdfe.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-22T114533.943563Z"></a>
-2010-02-22T11:45:33.943563Z Chris Liddell</strong></p>
-<blockquote>
-<pre>
-resolve inappropriate variable type (signed vs unsigned) and comparisons with
-the wrong variable when writing the local subrs info to the serialized T2 Private
-dictionary.</pre>
-<p>[psi/write_t2.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-21T175724.841443Z"></a>
-2010-02-21T17:57:24.841443Z regression</strong></p>
-<blockquote>
-<pre>
-
-Added regression testing of the icc_work branch to the local cluster.
-
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/run.pl toolbin/localcluster/cachearchive.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-21T035726.068286Z"></a>
-2010-02-21T03:57:26.068286Z Marcos H. Woehrmann</strong></p>
-<blockquote>
-<pre>
-
-Add cast to bmpcmp.c to quiet useless compiler warning.
-
-</pre>
-<p>[toolbin/bmpcmp.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-21T035151.891247Z"></a>
-2010-02-21T03:51:51.891247Z regression</strong></p>
-<blockquote>
-<pre>
-Several minor changes to local cluster code to improve reliability and increase performance.
-
-</pre>
-<p>[toolbin/localcluster/clustermaster.pl toolbin/localcluster/build.pl toolbin/localcluster/run.pl toolbin/localcluster/compare.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-21T033829.059238Z"></a>
-2010-02-21T03:38:29.059238Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Update pdf2dsc.ps to match the changes in pdf_main.ps introduced by
-the rev. 10341. Thanks to William Bader for the patch. Bug 691124.
-</pre>
-<p>[lib/pdf2dsc.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-21T025705.611462Z"></a>
-2010-02-21T02:57:05.611462Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Include stat_.h before estack.h, which defines esp macro.
-Prevent a spurious macro substitution in Cygwin version of signal.h.
-Bug 691123, customers 661.
-</pre>
-<p>[psi/zfapi.c psi/int.mak]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-17T170227.004947Z"></a>
-2010-02-17T17:02:27.004947Z Henry Stiles</strong></p>
-<blockquote>
-<pre>
-Adds placeholder files to trunk so the other languages (pcl, xps and
-svg) can built with the icc branch and trunk. Each of these files
-will be replaced with real files when the icc branch is merged into
-the trunk.
-</pre>
-<p>[base/lcms.mak base/gsiccmanage.h]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-16T181257.832463Z"></a>
-2010-02-16T18:12:57.832463Z Robin Watts</strong></p>
-<blockquote>
-<pre>
-Tiny tweaks to clusterpush.pl to make it work on windows. First, wrap the
-&#36;HOME directory in additional quotes to allow for awkward windows users
-with spaces in their names. Secondly, add a crude mapping for people whos
-windows names are not the same as the usernames. This can unquestionably
-be done more nicely, but the simple version will do for now.
-
-</pre>
-<p>[toolbin/localcluster/clusterpush.pl]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-16T170749.079920Z"></a>
-2010-02-16T17:07:49.079920Z Alex Cherepanov</strong></p>
-<blockquote>
-<pre>
-Add missing dereferencing of indirect objects in /Mask array.
-Bug 691112, customers 870.
-</pre>
-<p>[Resource/Init/pdf_draw.ps]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-12T152723.315268Z"></a>
-2010-02-12T15:27:23.315268Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Sort out some minor benign compiler warnings. No differences expected.
-</pre>
-<p>[base/gdevpdfe.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-12T151716.629322Z"></a>
-2010-02-12T15:17:16.629322Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix colour processing. It was possible for nested ICCBased colour spaces (ie an ICCBased
-space whose Alternate is another ICCBased space) to cause segmentation faults.
-
-This was due to the fact that the conversion to base colour continuation procedure
-'currentbasecolor_cont' was supposed to scan the space from the initial declaration
-each time round a loop. However a reassignment of an array pointer caused it to
-rescan from the last processed colour array instead.
-
-Normally this does not cause problems, but in the case of nested ICCBased it caused
-us to generate an error.
-
-Fixed by re-initialising the array pointer at the start of the loop.
-</pre>
-<p>[psi/zcolor.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-11T162820.347398Z"></a>
-2010-02-11T16:28:20.347398Z Ken Sharp</strong></p>
-<blockquote>
-<pre>
-Fix (pdfwrite) bug #691104 &quot;pdfwrite emits garbage in the XMP metadata when DOCINFO
-pdfmarks contain UTF-16BE text strings&quot;
-
-There were several problems. Firstly the undoing of PostScript string escapes was wrong,
-Octal escapes consumed too many characters, and several escape sequences weren't
-recognised.
-
-Secondly the XMP emission didn't expect to receive UTF-16BE strings and didn't convert
-them to UTF-8 for inclusion in the metadata.
-
-This patch fixes the broken octal escapes, adds teh unprocessed escapes and checks the
-DOCINFo strings before sending to XMP. If they include the UTF-16BE Byte Order Mark
-then convert the strings to UTF-8.
-</pre>
-<p>[base/gdevpdfe.c]</p>
-</blockquote>
-
-<p><strong><a name="2010-02-10T202733.989189Z"></a>
-2010-02-10T20:27:33.989189Z Ralph Giles</strong></p>
-<blockquote>
-<pre>
-Bump the versioning after the 8.71 release.
-</pre>
-<p>[base/gscdef.c base/version.mak Resource/Init/gs_init.ps doc/News.htm]</p>
-</blockquote>
-
-<!-- [2.0 end contents] ==================================================== -->
-<!-- [3.0 begin visible trailer] =========================================== -->
+<h3><a name="9.55.0_changelog"></a>Changelog</h3>
+<p>From 9.55.0 onwards, in recognition of how unwieldy very large HTML files can become
+(History9.html had reached 8.1Mb!), we intend to only include the summary highlights (above).
+<p>For anyone wanting the full details of the changes in
+a release, we ask them to look at the history in our public git repository:
+<a href="https://git.ghostscript.com/?p=ghostpdl.git;a=shortlog;h=refs/tags/ghostpdl-9.55.0">ghostpdl-9.55.0</a> log.
+<p>If this change does not draw negative feedback, History?.htm file(s) will be removed from the release archives.
<hr>
<p>
@@ -250672,7 +261,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Install.htm b/doc/Install.htm
index c3da7e60..955f6b05 100644
--- a/doc/Install.htm
+++ b/doc/Install.htm
@@ -430,7 +430,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Internal.htm b/doc/Internal.htm
index 0361a485..e6da2844 100644
--- a/doc/Internal.htm
+++ b/doc/Internal.htm
@@ -108,7 +108,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Language.htm b/doc/Language.htm
index 51965ae6..ffbf9880 100644
--- a/doc/Language.htm
+++ b/doc/Language.htm
@@ -102,6 +102,11 @@
<li><a href="#GlyphNames2Unicode">GlyphNames2Unicode</a></li>
<li><a href="#MultipleResourceDirectories">Multiple Resource directories</a></li>
</ul>
+<li><a href="#PDF_scripting">Scripting the PDF interpreter</a></li>
+<ul>
+<li><a href="#PS_functions">PostScript functions</a></li>
+<li><a href="#PDF_PS_operators">PostScript operators</a></li>
+</ul>
</ul></blockquote>
<!-- [1.2 end table of contents] =========================================== -->
@@ -1744,7 +1749,10 @@ the <code>BufferSpace</code> parameter, not <code>BandBufferSpace</code>.</p>
<dd>The height of bands when banding. 0 means use the largest band height
that will fit within the <code>BandBufferSpace</code> (or <code>BufferSpace</code>,
if <code>BandBufferSpace</code> is not specified). If <code>BandHeight</code>
-is larger than the number of lines that will fit in the buffer, opening the device will fail.</dd>
+is larger than the number of lines that will fit in the buffer, opening the device will fail.
+If the value is -1, the BandHeight will automatically be set to the page height
+(1 band for the entire page). This is primarily for developers debugging clist issues.
+</dd>
</dl>
<dl>
@@ -2041,6 +2049,247 @@ specifying an absolute path. The default value for
a default invocation with a PostScript installer
will install resource files into <code>/gs/Resource</code>.</p>
+<h2><a name="PDF_scripting"></a>Scripting the PDF interpreter</h2>
+
+<h3><a name="PS_functions"></a>PostScript functions</h3>
+
+<p>We have not previously documented the internals of the Ghostscript PDF interpreter, but we have, on
+occasion, provided solutions that rely upon scripting the interpreter from PostScript. This was
+possible because the interpreter was written in PostScript.</p>
+
+<p>From release 9.55.0 Ghostscript comes supplied with two PDF interpreters, the original written in PostScript
+and a brand-new interpreter written in C. While the new interpreter can be run as part of the GhostPDL family
+it has also been integrated into Ghostscript, and can be run from the PostScript environment in a similar fashion
+to the old interpreter. We plan to deprecate, and eventually remove, the old interpreter and carry on with the new one.</p>
+
+<p>Because we have supplied solutions in the past based on the old interpreter, we have had to implement
+the same capabilities in the integration of the new interpreter. Since this has meant discovering which internal
+portions were being used, working out how those function, and duplicating them anew, it seemed a good time to
+document these officially, so that in future the functionality would be available to all.</p>
+
+<p>The following functions existed in the original PDF interpreter and have been replicated for the new
+interpreter. It should be possible to use these for the forseeable future.</p>
+
+<dt><code>&ltfile&gt runpdf - </code></dt>
+<dd> Called from the modified PostScript run operator (which copies stdin to a temp
+ file if required). Checks for PDF collections, processes all requested pages.</dd>
+
+<p><dt><code>&ltfile&gt runpdfbegin -</code></dt>
+<dd> This must be called before performing any further operations. Its exact action depends on which
+interpreter is being used, but it essentially sets up the environment to process the file as a PDF</dd></p>
+
+<p><dt><code>&ltint&gt pdfgetpage &ltpagedict&gt | &ltnull&gt</code></dt>
+<dd> int is a number from 1 to N indicating the desired page number from
+ the PDF file. Returns the a dictionary containing various informational key/value pairs.
+ If this fails, returns a null object.</dd></p>
+
+<p><dt><code> - pdfshowpage_init -</code></dt>
+<dd> In the PostScript PDF interpreter this simply adds 1 to the /DSCPageCount value in a dictionary.
+It has no effect in the new PDF interpreter but is maintained for backwards compatibility.</dd></p>
+
+<p><dt><code>&ltpagedict&gt pdfshowpage_setpage &ltpagedict&gt</code></dt>
+<dd> Takes a dictionary as returned from pdfgetpage, extracts various
+ parameters from it, and sets the media size for the page, taking into
+ account the boxes, and requested Box, Rotate value and PDFFitPage.</dd></p>
+
+<p><dt><code>&ltpagedict&gt pdfshowpage_finish -</code></dt>
+<dd> Takes a dictionary as returned from pdfgetpage, renders the page content
+ executes showpage to transfer the rendered content to the device.</dd></p>
+
+<p><dt><code>- runpdfend -</code></dt>
+<dd> Terminates the PDF processing, executes restore and various cleanup activities.</dd></p>
+
+<p><dt><code>&ltfile&gt pdfopen &ltdict&gt</code></dt>
+<dd> Open a PDF file and read the header, trailer
+ and cross-reference.</dd></p>
+
+<p><dt><code>&ltdict&gt pdfclose -</code></dt>
+<dd> Terminates processing the original PDF file object. The dictionary parameter
+ should be the one returned from pdfopen</dd></p>
+
+<p><dt><code>&ltpagedict&gt pdfshowpage -</code></dt>
+<dd> Takes a dictionary returned from pdfgetpage and calls the pdfshowpage_init
+ pdfshowpage_setpage, pdfshowpage_finish trio to start the page, set up the
+ media and render the page.</dd></p>
+
+<p><dt><code>&ltint&gt &ltint&gt dopdfpages -</code></dt>
+<dd> The integers are the first and last pages to be run from the file. Runs a loop from
+ the fist integer to the last. NOTE! If the current dictionary contains a PDFPageList
+ array then we 'get' the entry from the array corresponding to the current loop
+ index, and use that to determine whether we should draw the page. Otherwise we
+ simply draw the page. Uses pdfshowpage to actually render the page.</dd></p>
+
+<p><dt><code>- runpdfpagerange &ltint&gt &ltint&gt</code></dt>
+<dd> Processes the PostScript /FirstPage, /LastPage and /PageList parameters. These are used together to build an internal array
+ of page numbers to run, which is used by dopdfpages to actually process the pages if PageList is present,
+ and a FirstPage and LastPage value. Despite the name this function does not actually 'run' any pages at all.</dd></p>
+
+<p>Normal operation simply calls runpdf with an opened-for-read PostScript file object. The table below shows the normal
+calling sequence</p>
+
+<blockquote><table>
+<tr valign="bottom">
+ <th align="left">Function</th>
+ <th>&nbsp;&nbsp;</th>
+ <th align="left">Calls</th>
+ <th>&nbsp;&nbsp;</th>
+ <th align="left">Calls</th>
+ <th>&nbsp;&nbsp;</th>
+ <th align="left">Calls</th></tr>
+<tr valign="top">
+ <td>runpdf</td>
+ <td>&nbsp;</td>
+ <td>runpdfbegin</td>
+ <td>&nbsp;</td>
+ <td>pdfopen</td>
+ <td>&nbsp;</td>
+ <td>&nbsp;</td></tr>
+<tr valign="top">
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>process_trailer_attrs</td>
+ <td>&nbsp;</td>
+ <td>&nbsp;</td></tr>
+<tr valign="top">
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>runpdfpagerange</td>
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>&nbsp;</td></tr>
+<tr valign="top">
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>dopdfpages</td>
+ <td>&nbsp;</td>
+ <td>pdfgetpage</td>
+ <td>&nbsp;</td></tr>
+<tr valign="top">
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>pdfshowpage</td>
+ <td>&nbsp;</td>
+ <td>pdfshowpage_init</td></tr>
+<tr valign="top">
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>pdfshowpage_setpage</td></tr>
+<tr valign="top">
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>pdfshowpage_finish</td></tr>
+<tr valign="top">
+ <td>&nbsp;</td>
+ <td>&nbsp;</td>
+ <td>runpdfend</td>
+ <td>&nbsp;</td>
+ <td>pdfclose</td>
+ <td>&nbsp;</td></tr>
+</table></blockquote>
+
+<p>It is important to get the number of spots and the presence of transparency correct when
+rendering. Failure to do so will lead to odd output, and potentially crahses. This can be important in situations
+such as N-up ordering.</p>
+<p>As an example, if we have 2 A4 pages and want to render them side-by-side on A3 media, we might set up
+the media size to A3, draw the first page contents, translate the origin, draw the second page contents
+and then render the final content. If the first PDF page did not contain transparency, but the second did, it
+would be necessary to set /PageHasTransparency before drawing the first PDF page.</p>
+
+<h3><a name="PDF_PS_operators"></a>PostScript operators interfacing to the PDF interpreter</h3>
+<p>The PostScript functions documented above must somehow interface with the actual PDF interpreter, and this is done
+using a small number of custom PostScript operators. These operators do not exist in standard PostScript; they
+are specific to the Ghostscript implementation. These operators are documented here for the benefit of any
+developers wishing to use them directly.</p>
+
+<p><dt><code>dict .PDFInit &ltPDFContext&gt</code></dt>
+<dd> Initialises an instance of the PDF interpreter. dict is an optional dictionary that contains any interpreter-level
+switches, such as PDFDEBUG, this is used to set the initial state of the PDF interpreter.
+The return value is a PDFcontext object which is an opaque object to be used with the other PDF operators.</dd></p>
+
+<p><dt><code>filename PDFcontext .PDFFile -</code></dt>
+<dd> Opens a named file and associates it with the instance of the PDF interpreter.
+Filename is a string containing a fully qualified path to the PDF file to open, this file must have been made accesible
+by setting --permit-file-read.
+</dd></p>
+
+<p><dt><code>file PDFcontext .PDFStream -</code></dt>
+<dd> Takes an already open (disk-based) file and associates it with the instance of the PDF interpreter.
+</dd></p>
+
+<p><dt><code>PDFcontext .PDFClose -</code></dt>
+<dd> If the context contains an open PDF file which was opened via the .PDFfile operator, this closes the file.
+Files associated with the context by the .PDFStream operator are unaffected. Regardless of the source it then shuts down the PDF interpreter and frees the associated memory.
+</dd></p>
+
+<p><dt><code>PDFcontext .PDFInfo dict</code></dt>
+<dd> PDFcontext is a PDFcontext object returned from a previous call to .PDFInit.
+The returned dictionary contains various key/value pairs with useful file level information:
+<blockquote>
+ <code>/NumPages</code> int<br>
+ <code>/Creator</code> string<br>
+ <code>/Producer</code> string<br>
+ <code>/IsEncrypted</code> boolean<br>
+</blockquote>
+</dd></p>
+
+<p><dt><code>PDFcontext .PDFMetadata -</code></dt>
+<dd> PDFcontext is a PDFcontext object returned from a previous call to .PDFInit.
+For the benefit of high level devices, this is a replacement for 'process_trailer_attrs' which is a seriously misnamed function now.
+This function needs to write any required output intents, load and send Outlines to the device, copy the Author, Creator, Title, Subject
+and Keywords from the Info dict to the output device, copy Optional Content Properties (OCProperties) to the output device.
+If an AcroForm is present send all its fields and link widget annotations to fields, and finally copy the PageLabels. If we add support for anything else, it will be here too..
+</dd></p>
+
+<p><dt><code>PDFcontext int .PDFPageInfo -</code></dt>
+<dd> The integer argument is the page number to retrieve information for.
+Returns a dictionary with the following key/value pairs:
+<blockquote>
+ <code>/UsesTransparency</code> true|false<br>
+ <code>/SpotColours</code> array of names, may be empty|<br>
+ <code>/MediaBox</code> [llx lly urx ury]<br>
+ <code>/HasAnnots</code> true|false<br>
+ <code>/FontsUsed</code> array of names, may be empty.<br>
+</blockquote>
+May also contain (if they are present in the Page dictionary)
+<blockquote>
+ <code>/ArtBox</code> [llx lly urx ury]<br>
+ <code>/CropBox</code> [llx lly urx ury]<br>
+ <code>/BleedBox</code> [llx lly urx ury]<br>
+ <code>/TrimBox</code> [llx lly urx ury]<br>
+ <code>/UserUnit</code> int<br>
+</blockquote>
+</dd></p>
+
+<p><dt><code>PDFcontext int .PDFDrawPage -</code></dt>
+<dd> PDFcontext is a PDFcontext object returned from a previous call to .PDFInit.
+The integer argument is the page number to be processed.
+Interprets the page content stream(s) of the specified page using the current graphics state.
+</dd></p>
+
+<p><dt><code>PDFcontext int .PDFDrawAnnots -</code></dt>
+<dd> PDFcontext is a PDFcontext object returned from a previous call to .PDFInit.
+The integer argument is the page number to be processed.
+Renders the Annotations (if any) of the specified page using the current graphics state
+For correct results, the graphics state when this operator is run should be the same as when
+PDFDrawPage is executed.
+</dd></p>
+
+<p>Note: The PDFcontext object created by PDFInit must (clearly) have a PDF file associated
+with it before you can usefully use it. Attempting to use a PDFcontext with
+any of the processing operators (eg .PDFDrawPage) before using either .PDFStream of .PDFFile
+to associate a file with the context will result in an error.
+</p>
<!-- [2.0 end contents] ==================================================== -->
<!-- [3.0 begin visible trailer] =========================================== -->
@@ -2060,7 +2309,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Lib.htm b/doc/Lib.htm
index c5fed2c4..bd986be5 100644
--- a/doc/Lib.htm
+++ b/doc/Lib.htm
@@ -1037,7 +1037,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Make.htm b/doc/Make.htm
index b8be1e18..f2a3528f 100644
--- a/doc/Make.htm
+++ b/doc/Make.htm
@@ -1462,7 +1462,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/News.htm b/doc/News.htm
index b73856a5..3d9784d4 100644
--- a/doc/News.htm
+++ b/doc/News.htm
@@ -65,14 +65,6 @@ earlier versions, see the history documents:
<blockquote>
<a href="History9.htm">History of Ghostscript versions 9.n</a><br>
-<a href="History8.htm">History of Ghostscript versions 8.n</a><br>
-<a href="History7.htm">History of Ghostscript versions 7.n</a><br>
-<a href="History6.htm">History of Ghostscript versions 6.n</a><br>
-<a href="History5.htm">History of Ghostscript versions 5.n</a><br>
-<a href="History4.htm">History of Ghostscript versions 4.n</a><br>
-<a href="History3.htm">History of Ghostscript versions 3.n</a><br>
-<a href="History2.htm">History of Ghostscript versions 2.n</a><br>
-<a href="History1.htm">History of Ghostscript versions 1.n</a>
</blockquote>
<p>For other information, see the <a href="Readme.htm">Ghostscript
@@ -85,35 +77,50 @@ overview</a>.
<!-- [1.0 end visible header] ============================================== -->
<!-- [2.0 begin contents] ================================================== -->
-<h2><a name="Version9.54.0"></a>Version 9.54.0 (2021-03-30)</h2>
-<p>The 9.54.0 release is a maintenance release, and also adds new functionality.
-<br>
+<h2><a name="Version9.55.0"></a>Version 9.55.0 (2021-09-27)</h2>
<p> Highlights in this release include:
<ul>
+<p>This release includes the fix for the <code>%pipe%</code> security issue (CVE-2021-3781).
+</li>
+<li>
+<p><b>New PDF Interpreter:</b> This is an entirely new implementation written in C (rather than
+PostScript, as before). For a full discussion of this change and reasons for it see:
+<a href="https://ghostscript.com/pdfi.html">Changes Coming to the PDF Interpreter</a>.
+<p>In this (9.55.0) release, the new PDF interpreter is disabled by default in Ghostscript,
+but can be used by specifying <code>-dNEWPDF</code>. We hope to make it the default in 9.56.0, and
+fully deprecate the PostScript implementation shortly after that (depending on the feedback
+we get).
+<p>This also allows us to offer a new executable (<code>gpdf</code>, or <code>gpdfwin??.exe</code>
+on Windows) which is <i>purely</i> for PDF input. For this release, those new binaries are not included
+in the "install" make targets, nor in the Windows installers (they will be from 9.56.0 onwards).
+<p>We would ask that as many users as possible take the opportunity to test with the new PDF implementation
+(i.e. using <code>-dNEWPDF</code> on your gs command line), and discuss any problems with us, before
+the new implementation becomes the default.
+</li>
<li>
-<p>Overprint simulation is now available to all output devices, allowing
-quality previewing/proofing of PostScript and PDF jobs that rely on overprint.
-See the <code>-dOverprint</code> option documentation in:
-<a href="Use.htm#Overprint">Overprint</a>
+<p>The pdfwrite device now supports &quot;passthrough&quot; for JPX/JPG2000 data images (as well as the
+already supported JPEG/DCT Encoded). That means that if no rescaling or color conversion of the image data
+is required, the encoded/compressed image data from the input file will be written unchanged to the output,
+preventing potential image degradation caused by decompressing and recompressing.
</li>
<li>
-<p>The &quot;docxwrite&quot; device adds the ability to output to Microsoft Word
-&quot;docx&quot; format. See: <a href="VectorDevices.htm#DOCX">docxwrite</a>
+<p>The Ghostscript/GhostPDL demo apps for C, C#, Java and Python have all had improvements and the
+C#/Java/Python language bindings have now been documented, see <a href="language-bindings/index.html">Ghostscript Language Bindings</a>
</li>
<li>
-<p>The pdfwrite device is now capable of using the Tesseract OCR engine when it is
-built into Ghostscript to improve searchability and copy and paste functionality when
-the input lacks the metadata for that purpose. See: <a href="VectorDevices.htm#UseOCR">UseOCR</a>
+<p>The Zugferd compliant PDF generating definitions (<code>lib/zugferd.ps</code>) have been updated and expanded to support the
+current version (2.1.1) of the Zugferd spec, and optionally different versions of the specification.
</li>
<li>
-<p>Ghostscript/GhostPDL now includes a &quot;map text to black&quot;
-function, where text drawn by an input job (except when drawn using a
-Type 3 font) can be forced to draw in solid black. See:
-<a href="Use.htm#BlackText">BlackText</a>
+<p>The PCL/m output devices now support Duplex/Tumble.
</li>
<li>
-<p>Ghostscript/GhostPDL now supports simple N-up imposition &quot;internally&quot;. See:
-<a href="Use.htm#NupControl">NupControl</a>
+<p>The internal support for &quot;n-up&quot; style simple imposition (introduced in 9.54.0) has been extended and improved
+for better support across all input formats.
+</li>
+<li>
+<p>Ghostscript now supports object specific halftone - for example, different halftones can be specified for text and
+images, reflecting the differing needs of rendering those two types of object.
</li>
<li>
<p>Our efforts in code hygiene and maintainability continue.
@@ -136,12 +143,25 @@ community demand for the feature.
</ul>
<p>For a list of open issues, or to report problems,
please visit <a href="http://bugs.ghostscript.com/">bugs.ghostscript.com</a>.
-<h3><a name="9.54.0_Incompatible_changes"></a>Incompatible changes</h3>
+<h3><a name="9.55.0_Incompatible_changes"></a>Incompatible changes</h3>
<h4>Included below are incompatible changes from recent releases (the
specific release in question listed in parentheses). We include these,
for now, as we are aware that not everyone upgrades with every release.</h4>
<ul>
<li>
+<p>(9.55.0) Changes to the <code>device API</code>. This will affect developers and maintainers of
+Ghostscript devices. Firstly, and most importantly, the way device-specific "procs" are specified has
+been rewritten to make it (we think!) clearer and less confusing. See
+<a href="Drivers.htm">The Interface between Ghostscript and Device Drivers</a> and
+<a href="https://www.notion.so/artifexsoftware/The-Great-Device-Rework-Of-2021-94092fe1395d4a088b91462f0ca5038a">The Great Device Rework Of 2021</a>
+for more details.
+</li>
+<li>
+<p>(9.55.0) The command line options <code>-sGraphicsICCProfile=___</code>, <code>-dGraphicsIntent=#</code>, <code>-dGraphicsBlackPt=#</code>,
+<code>-dGraphicsKPreserve=#</code> have been changed to <code>-sVectorICCProfile=___</code>, <code>-dVectorIntent=#</code>, <code>-dVectorBlackPt=#</code>,
+<code>-dVectorKPreserve=#</code>.
+</li>
+<li>
<p>(9.53.0) As of 9.53.0, we have (re-)introduced the patch level to the version number,
this helps facilitate a revised policy on handling security related issues.
<p><strong>Note for GSView Users:</strong>The patch level addition breaks GSView 5 (it is
@@ -149,13 +169,6 @@ hardcoded to check for versions <code>704-999</code>. It is possible, but not gu
a GSView update might be forthcoming to resolve this.
</li>
<li>
-<p>(9.52) As of 9.52, the Windows binaries released by the Ghostscript development
-team are built with Microsoft Visual Studio 2019. As a result, Microsoft Windows XP and
-earlier are no longer supported by these binaries. This does not imply we are, or will
-start relying upon features only available in VS2019, so the <code>nmake</code> Makefiles
-will continue to allow older Visual Studio versions (back to VS2005) to build Ghostscript.
-</li>
-<li>
<p>(9.52) <code>-dALLOWPSTRANSPARENCY</code>: The transparency compositor (and related
features), whilst we are improving it, remains sensitive to being driven correctly, and
incorrect use can have unexpected/undefined results. Hence, as part of improving security
@@ -166,9 +179,9 @@ As we made "SAFER" the default mode, that became unacceptable, hence the new opt
<li>
<p>(9.50) There are a couple of subtle incompatibilities between the old and new SAFER
implementations. Firstly, as mentioned in the 9.50 release notes, SAFER now leaves
-standard Postcript functionality unchanged (except for the file access limitations).
-Secondly, the interaction with <code>save</code>&sol;<code>restore</code> operations,
-see <a href="Use.htm#Safer">SAFER</a>.
+standard PostScript functionality unchanged (except for the file access limitations).
+Secondly, the interaction with <code>save</code>&sol;<code>restore</code> operations
+has changed. See <a href="Use.htm#Safer">SAFER</a>.
<p><strong>Important Note for Windows Users</strong>:
<br>
The file/path pattern matching is case sensitive, even on Windows. This is a
@@ -181,16 +194,20 @@ in that it now supports (although does not enforce) case sensitivity.
only non-standard and undocumented operators. Nevertheless, it is possible that
any integrations or utilities that rely on those non-standard and undocumented
operators may stop working or may change behaviour.
-<p>If you encounter such a case, please contact us (either the #ghostscript IRC channel,
+<p>If you encounter such a case, please contact us (<a href="https://discord.gg/H9GXKwyPvY">Discord<a>,
+<a href="https://web.libera.chat/#ghostscript">#ghostscript IRC channel</a>,
or the gs-devel mailing list would be best), and we'll work with you to either find an
alternative solution or return the previous functionality, if there is genuinely no other
option.
</li>
</ul>
-<h3><a name="9.54.0_changelog"></a>Changelog</h3>
-
-<p>See the <a href="History9.htm">history file</a> for complete log
-of changes.
+<h3><a name="9.55.0_changelog"></a>Changelog</h3>
+<p>From 9.55.0 onwards, in recognition of how unwieldy very large HTML files can become
+(History9.html had reached 8.1Mb!), we intend to only include the summary highlights (above).
+<p>For anyone wanting the full details of the changes in
+a release, we ask them to look at the history in our public git repository:
+<a href="https://git.ghostscript.com/?p=ghostpdl.git;a=shortlog;h=refs/tags/ghostpdl-9.55.0">ghostpdl-9.55.0</a> log.
+<p>If this change does not draw negative feedback, History?.htm file(s) will be removed from the release archives.
<!-- [2.0 end contents] ==================================================== -->
@@ -212,7 +229,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Ps-style.htm b/doc/Ps-style.htm
index 84f7dd43..f10c1fdf 100644
--- a/doc/Ps-style.htm
+++ b/doc/Ps-style.htm
@@ -539,7 +539,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Ps2epsi.htm b/doc/Ps2epsi.htm
index 7a545a9c..b2c8daea 100644
--- a/doc/Ps2epsi.htm
+++ b/doc/Ps2epsi.htm
@@ -219,7 +219,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Psfiles.htm b/doc/Psfiles.htm
index 07cccb25..9aa40395 100644
--- a/doc/Psfiles.htm
+++ b/doc/Psfiles.htm
@@ -884,7 +884,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Readme.htm b/doc/Readme.htm
index de4d7e7e..df69c6ac 100644
--- a/doc/Readme.htm
+++ b/doc/Readme.htm
@@ -569,7 +569,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Release.htm b/doc/Release.htm
index 4d10992d..bc53b7e0 100644
--- a/doc/Release.htm
+++ b/doc/Release.htm
@@ -835,7 +835,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/SavedPages.htm b/doc/SavedPages.htm
index 383548b6..2d9ffa38 100644
--- a/doc/SavedPages.htm
+++ b/doc/SavedPages.htm
@@ -307,7 +307,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Source.htm b/doc/Source.htm
index e998bf78..bf1c1887 100644
--- a/doc/Source.htm
+++ b/doc/Source.htm
@@ -455,7 +455,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Unix-lpr.htm b/doc/Unix-lpr.htm
index ce3bc4d3..bd0fa0b3 100644
--- a/doc/Unix-lpr.htm
+++ b/doc/Unix-lpr.htm
@@ -294,7 +294,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/Use.htm b/doc/Use.htm
index 64339dfc..1fca0569 100644
--- a/doc/Use.htm
+++ b/doc/Use.htm
@@ -619,6 +619,20 @@ Ghostscript is normally built to interpret both PostScript and PDF files, examin
<p>Here are some command line options specific to PDF</p>
<dl>
+<dt><code>-dNEWPDF</code></dt>
+<dd>From release 9.55.0 Ghostscript incorporates two complete PDF interpreters; the original
+long-standing interpreter is written in PostScript but there is now a new interpreter written
+in C.
+<p>At present the old PostScript-based interpreter remains the default, in future releases the
+new C-based interpreter will become the default, though we would encourage people to experiment
+with the new interpreter and send us feedback. While there are two interpreters the command-line
+switch NEWPDF will allow selection of the existing interpreter when false and the new interpreter
+when true.</p>
+
+</dd>
+</dl>
+
+ <dl>
<dt><code>-dPDFFitPage</code></dt>
<dd>Rather than selecting a PageSize given by the PDF MediaBox, BleedBox (see -dUseBleedBox),
TrimBox (see -dUseTrimBox), ArtBox (see -dUseArtBox), or CropBox (see -dUseCropBox),
@@ -2776,7 +2790,7 @@ The only option strings are as follows:
to the leftmost place on the next row until the nest is complete.
<p>
A partially filled nest will be output when the <code>-sNupControl=</code> string is changed,
- or when Ghostscript exits.
+ when Ghostscript exits, or when the page size changes.
<p>
Pages are scaled to fit the requested number horizontally and vertically, maintaining the
aspect ratio. If the scaling selected for fitting the nested pages leaves space horizontally
@@ -2790,6 +2804,14 @@ The only option strings are as follows:
the partially filled master page will be output.
</li>
</ul>
+<p>Printer devices typically reallocate their memory whenever the transparency use
+of a page changes (from one page having transparency, to the next page not having
+transparency, or vice versa). This would cause problems with Nup, possibly leading
+to lost or corrupt pages in the output. To avoid this, the Nup device changes
+the parameters of the page to always set the PageUsesTransparency flag. While this
+should be entirely transparent for the user and not cause extra transparency blending
+operations during the standard rendering processes for most devices, it may cause
+devices to use the clist rather than PageMode.
</dd>
</dl>
@@ -3116,18 +3138,38 @@ device supports those colorants. It is also possible for these devices to
<dt><code>-sICCOutputColors=</code><em>"Cyan, Magenta, Yellow, Black, Orange, Violet"</em></dt>
<dd>For the psdcmyk and tiffsep separation devices, the device ICC profile can
be an NCLR profile, which means something that includes non-traditional inks
-like Orange, Violet, etc. In this case, the list of the colorant names in the
+like Orange, Violet, etc. In this case, the list of the color names in the
order that they exist in the profile must be provided with this command line
-option. Note that if a colorant name that is specified for the profile occurs also within
-the document (e.g. "Orange" above), then these colorants will be associated with
-the same separation. It is possible through a compile time option LIMIT_TO_ICC
-defined in gdevdevn.h to restrict the output colorants of the psdcmyk and tiffsep
-device to the colorants of the ICC profile or to allow additional spot colorants
-in the document to be created as different separations. If restricted, the other
-spot colorants will go through the alternate tint transform and then be mapped to
-the color space defined by the NCLR profile. If an NCLR ICC profile is specified
+option. Note that if a color name that is specified for the profile occurs also within
+the document (e.g. "Orange" above), then these color names will be associated with
+the same separation. Additional names beyond those of the ICC profile component count
+can be included. In this case, those components will be installed into the tiffsep
+or psdcmyk device list of colors, following the ICC profile colors.
+The number of spot colors (those that go beyond the standard CMYK colors)
+allowed by tiffsep or psdcmyk can be set using -dMaxSpots=#. The default
+value for this is currently set to 10 (GS_SOFT_MAX_SPOTS).
+As an example consider the case where we wish to use a 6CLR ICC profile that
+includes Orange and Violet, but
+need the device to include a specialty color component such as
+Varnish, which does not appear in the document and is not handled by the 6CLR ICC
+profile. In addition, we desire
+to allow one more spot color of the document to come through to our device. For
+this case using
+ <code>-sICCOutputColors=</code><em>"Cyan, Magenta, Yellow, Black, Orange, Violet, Varnish"</em>
+ <code>-dMaxSpots=</code><em>4</em>
+ <code>-sOutputICCProfile=</code><em>My_6CLR_Profile.icc</em>
+would provide the desired outcome. Note that it is up to the device or
+through the use of -sNamedProfile (see below) to involve the setting
+of any values in the Varnish channel. However, if an All color value is encountered
+in the document, the Varnish component will have its value
+set as will the Orange and Violet values (Likewise if a spot color named Varnish is
+encountered in the document the Varnish component will be used for the values).
+The All value is typically used
+for placing registration targets on separations.
+Finally, note that if an NCLR ICC profile is specified
and ICCOutputColors is not used, then a set of default names will be used for
- the extra colorants (non-CMYK) in the profile.</dd>
+the extra colorants (non-CMYK) in the profile. These names are given as ICC_COLOR_N for
+the Nth non-CMYK channel.</dd>
</dl>
<dl>
@@ -3213,7 +3255,7 @@ PRESERVE_K_PLANE approach. This is only valid when using littleCMS for
</dl>
<dl>
- <dt><code>-sGraphicICCProfile=</code><em>filename</em></dt>
+ <dt><code>-sVectorICCProfile=</code><em>filename</em></dt>
<dd>Set the ICC profile that will be associated with
the output device for vector-based graphics (e.g. Fill,
Stroke operations).
@@ -3224,20 +3266,20 @@ as the profile. This can be used to obtain more saturated
</dl>
<dl>
- <dt><code>-dGraphicIntent=</code><em>0/1/2/3</em></dt>
-<dd>Set the rendering intent that should be used with graphic objects. The
+ <dt><code>-dVectorIntent=</code><em>0/1/2/3</em></dt>
+<dd>Set the rendering intent that should be used with vector-based graphic objects. The
options are the same as specified for -dRenderIntent.</dd>
</dl>
<dl>
- <dt><code>-dGraphicBlackPt=</code><em>0/1</em></dt>
- <dd>Specify if black point compensation should be used for graphic objects.</dd>
+ <dt><code>-dVectorBlackPt=</code><em>0/1</em></dt>
+ <dd>Specify if black point compensation should be used for vector-based graphic objects.</dd>
</dl>
<dl>
- <dt><code>-dGraphicKPreserve=</code><em>0/1/2</em></dt>
+ <dt><code>-dVectorKPreserve=</code><em>0/1/2</em></dt>
<dd>Specify if black preservation should be used when mapping
-from CMYK to CMYK for graphic objects. The
+from CMYK to CMYK for vector-based graphic objects. The
options are the same as specified for -dKPreserve.</dd>
</dl>
@@ -3312,7 +3354,7 @@ control in the specification of source colors see
<dd>
This option provides an extreme level of override control to
specify the source color spaces and rendering intents to use
-with graphics, images and text for both RGB and CMYK source
+with vector-based graphics, images and text for both RGB and CMYK source
objects. The specification is made through a file that contains
on a line a key name to specify the object type (e.g. Image_CMYK)
followed by an ICC profile file name, a rendering intent
@@ -5367,7 +5409,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/VectorDevices.htm b/doc/VectorDevices.htm
index c457150e..44e909c4 100644
--- a/doc/VectorDevices.htm
+++ b/doc/VectorDevices.htm
@@ -416,6 +416,7 @@ Cells in the table below containing '=' mean that the value of the parameter is
<tr valign=top><td><code>UseFlateCompression</code><td><td><a href="#note_2">(2)</a><td><td>true<td><td>=<td><td>=<td><td>=<td><td>=
<tr valign=top><td><code>UsePrologue</code><td><td><a href="#note_0">(0)</a><td><td>false<td><td>=<td><td>=<td><td>=<td><td>=
<tr valign=top><td><code>PassThroughJPEGImages</code><td><td><a href="#note_15">(15)</a><td><td>true<td><td>=<td><td>=<td><td>=<td><td>=
+<tr valign=top><td><code>PassThroughJPXImages</code><td><td><a href="#note_16">(16)</a><td><td>true<td><td>=<td><td>=<td><td>=<td><td>=
</table></blockquote>
<p>
@@ -555,12 +556,22 @@ The default value of <code>CompressPages</code> is <code>false</code> for ps2wri
<a name="note_15">(note 15)</a>
When <code>true</code> image data in the source which is encoded using the DCT (JPEG) filter will not be decompressed
and then recompressed on output. This prevents the multiplication of JPEG artefacts caused by lossy compression.
-</code><code>PassThroughJPEGImages</code> currently only affects simple JPEG images. It has no effect on JPX (JPEG2000) encoded images,
+</code><code>PassThroughJPEGImages</code> currently only affects simple JPEG images. It has no effect on JPX (JPEG2000) encoded images (see below)
or masked images. In addition this parameter will be ignored if the pdfwrite device needs to modify the source data. This can happen if the image
is being downsampled, changing colour space or having transfer functions applied. Note that this parameter essentially overrides
the 'EncodeColorImages' and 'EncodeGrayImages' parameters if they are false, the image will still be written with a DCTDecode filter. NB this
feature currently only works with PostScript or PDF input, it does not work with PCL, PXL or XPS input.
+<p>
+<a name="note_16">(note 16)</a>
+When <code>true</code> image data in the source which is encoded using the JPX (JPEG 2000) filter will not be decompressed
+and then recompressed on output. This prevents the multiplication of JPEG artefacts caused by lossy compression.
+</code><code>PassThroughJPXImages</code> currently only affects simple JPX encoded images. It has no effect on JPEG encoded images (see above)
+or masked images. In addition this parameter will be ignored if the pdfwrite device needs to modify the source data. This can happen if the image
+is being downsampled, changing colour space or having transfer functions applied. Note that this parameter essentially overrides
+the 'EncodeColorImages' and 'EncodeGrayImages' parameters if they are false, the image will still be written with a JPXDecode filter. NB this
+feature currently only works with PostScript or PDF input, it does not work with PCL, PXL or XPS input.
+
<h4><a name="Color_Conversion_and_Management"></a>Color Conversion and Management</h4>
<p>
As of the 9.11 pre-release, the color management in the pdfwrite family has been substantially
@@ -859,7 +870,8 @@ The following options are useful for creating PDF 1.3 files:
<dt><code>-dHaveTransparency=<em>boolean</em></code>
<dd>With <code>CompatibilityLevel &ge; 1.4</code> it specifies
whether the target viewer can handle PDF 1.4 transparency objects.
-If not, transparency objects are converted into plain images.
+If not, the page is converted into a single plain image with all
+transparency flattened.
Default value is <code>true</code>.
</dl>
@@ -1473,7 +1485,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/WhatIsGS.htm b/doc/WhatIsGS.htm
index ed897ad2..00e5f0f0 100644
--- a/doc/WhatIsGS.htm
+++ b/doc/WhatIsGS.htm
@@ -77,27 +77,34 @@ There are various products in the Ghostscript family; this document describes wh
<!-- [2.0 begin contents] ================================================== -->
-<h2><a name="Ghostscript/GhostPDF"></a>Ghostscript/GhostPDF</h2>
+<h2><a name="Ghostscript"></a>Ghostscript</h2>
<p>Ghostscript is an interpreter for PostScript<a href="#foot1">&#174;</a> and Portable Document Format (PDF) files.</p>
<p>Ghostscript consists of a PostScript interpreter layer, and a graphics library. The graphics library is shared with all the other products in the Ghostscript family, so all of these technologies are sometimes referred to as Ghostscript, rather than the more correct GhostPDL.</p>
-<p>GhostPDF is an interpreter built on top of Ghostscript to handle PDF files.
-Currently GhostPDF relies on extensions to the PostScript language/imaging model,
-and so cannot be used independently of the Ghostscript PostScript interpreter
-component. As such GhostPDF is an umbrella term used to refer to both these
-extensions and the interpreter code.</p>
-
-<p>Many people (including the authors) frequently just refer to Ghostscript
-as supporting PDF and only specifically mention GhostPDF when wanting to make
-the distinction between the PostScript and PDF support.</p>
-
-<p>Binaries for Ghostscript and GhostPDF (included in the Ghostscript binaries) for various systems can be downloaded from <a href="http://www.ghostscript.com/download">here</a>.
+<p>Binaries for Ghostscript and (seel below) GhostPDF (included in the Ghostscript binaries) for various systems can be downloaded from <a href="http://www.ghostscript.com/download">here</a>.
The source can be found in both the Ghostscript and GhostPDL downloads from
the same site.</p>
<hr>
+<h2><a name="GhostPDF"></a>GhostPDF</h2>
+
+<p>Prior to release 9.55.0 GhostPDF was an interpreter for the PDF page description language
+built on top of Ghostscript, and written in the PostScript programming language. From 9.55.0
+onwards there is a new GhostPDF executable, separate from Ghostscript and written in C
+rather than PostScript.</p>
+
+<p>This new interpreter has also been integrated into Ghostscript itself, in order to
+preserve the PDF functionality of that interpreter. For now, the old PostScript-based
+interpreter remains the default, but the new interpreter is built-in alongside it.</p>
+
+<p>The intention is that the new interpreter will replace the old one, which will be withdrawn.</p>
+
+<p>It is possible to control which interpreter is used with the NEWPDF command-line switch. When
+this is false (the current default) the old PostScript-based interpreter is used, when NEWPDF
+is true then the new C-based interpreter is used.</p>
+
<h2><a name="GhostPDL"></a>GhostPDL</h2>
<p>Historically, we’ve used GhostPDL as an umbrella term to encompass our entire line of products. We've now brought all these disparate products together into a single package, called, appropriately enough, GhostPDL.</p>
@@ -169,7 +176,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/GS9_Color_Management.tex b/doc/colormanage/GS9_Color_Management.tex
index fc980e86..ce68110f 100644
--- a/doc/GS9_Color_Management.tex
+++ b/doc/colormanage/GS9_Color_Management.tex
@@ -37,19 +37,19 @@
\begin{titlepage}
-\begin{center}{\huge \bf Ghostscript 9.50 Color Management\\} \vspace{0.5in} {\Large Michael J.
-Vrhel, Ph.D.\\} {\Large Artifex Software\\} {\Large 7 Mt. Lassen Drive, A-134\\} {\Large San Rafael, CA 94903, USA\\}
+\begin{center}{\huge \bf Ghostscript 9.54 Color Management\\} \vspace{0.5in} {\Large Michael J.
+Vrhel, Ph.D.\\} {\Large Artifex Software\\} {\Large 1305 Grant Avenue, Suite 200\\} {\Large Novato, CA 94945, USA\\}
{\Large www.artifex.com\\}
\end{center}
\vspace*{0.5in}
\begin{abstract}
-This document provides information about the color architecture in Ghostscript 9.50. The document is suitable for users who wish to
+This document provides information about the color architecture in Ghostscript 9.54. The document is suitable for users who wish to
obtain accurate color with their output device as well as for developers who wish to customize Ghostscript to achieve a higher
level of control and/or interface with a different color management module.
\end{abstract}
\begin{center}
\vspace*{0.25in}
-Revision 1.65
+Revision 1.66
\vspace*{0.25in}
\capstartfalse
\begin{figure}[h]
@@ -74,7 +74,7 @@ Revision 1.65
With release 9.0, the color architecture of Ghostscript was updated to primarily use the ICC\cite{ICC} format for its color management needs. Prior to this release, Ghostscript's color architecture was based heavily upon PostScript\cite{PS} Color Management (PCM). This is due to the fact that Ghostscript was designed prior to the ICC format and likely even before there was much thought about digital color management. At that point in time, color management was very much an art with someone adjusting controls to achieve the proper output color.
-Today, almost all print color management is performed using ICC profiles as opposed to PCM. This fact along with the desire to create a faster, more flexible design was the motivation for the color architectural changes in release 9.0. Since 9.0, several new features and capabilities have been added. As of the 9.50 release, features of the color architecture include:
+Today, almost all print color management is performed using ICC profiles as opposed to PCM. This fact along with the desire to create a faster, more flexible design was the motivation for the color architectural changes in release 9.0. Since 9.0, several new features and capabilities have been added. As of the 9.54 release, features of the color architecture include:
\begin{itemize}
\item Easy to interface different CMMs (Color Management Modules) with Ghostscript.
\item ALL color spaces are defined in terms of ICC profiles.
@@ -85,12 +85,12 @@ Today, almost all print color management is performed using ICC profiles as oppo
\item Operates efficiently in a multithreaded environment.
\item Handles named colors (spots) with ICC named color profile or proprietary format.
\item ICC color management of Device-N colors or alternatively customizable spot color handing.
-\item Includes object type (e.g. image, graphic, text), rendering intent and black point compensation into the computation of the linked transform.
+\item Includes object type (e.g. image, vector graphics, text), rendering intent and black point compensation into the computation of the linked transform.
\item Ability to override document embedded ICC profiles with Ghostscript's default ICC profiles.
-\item Easy to specify unique {\bf source} ICC profiles to use with graphic, image and text objects.
-\item Easy to specify unique {\bf destination} ICC profiles to use with graphic, image and text objects.
-\item Easy to specify different rendering intents (perceptual, colorimetric, saturation, absolute colorimetric) for graphic, image and text objects.
-\item Easy to specify different black point compensation settings for graphic, image and text objects.
+\item Easy to specify unique {\bf source} ICC profiles to use with vector graphic, image and text objects.
+\item Easy to specify unique {\bf destination} ICC profiles to use with vector graphic, image and text objects.
+\item Easy to specify different rendering intents (perceptual, colorimetric, saturation, absolute colorimetric) for vector graphic, image and text objects.
+\item Easy to specify different black point compensation settings for vector graphic, image and text objects.
\item Ability to make use of a PDF output intent ICC profile.
\item Ability to use an NCLR ICC output profile when rendering to a separation device.
\item Control to force gray source colors to black ink only when rendering to output devices that support black ink.
@@ -99,6 +99,7 @@ Today, almost all print color management is performed using ICC profiles as oppo
\item Ability to monitor for the presence of color on individual pages, which is useful for certain print systems.
\item Ability to specify different default transparency blending color spaces.
\item Ability to specify a post rendering ICC profile for certain devices.
+\item Ability to accurately simulate overprinting with spot colors regardless of the output device color capabilities.
\end{itemize}
The document is organized to first provide a high level overview of the architecture. This is followed by details of the various functions and structures, which include the information necessary to interface other color management modules to Ghostscript as well as how to interface specialized color handling operations.
@@ -113,7 +114,7 @@ Figure \ref{fig:ICC_ARCH} provides a graphical overview of the various component
\item The color management module (CMM), which is the engine that provides and performs the transformations (e.g. little CMS).
\item The profiles associated with the device, which include profiles dependent upon object type, a proofing profile and a device link profile.
\end{itemize}
-In the typical flow, when a thread is ready to transform a buffer of data, it will request a linked transform from the link cache. When requesting a link, it is necessary to provide information to the CMM, which consists of a source color space, a destination color space, an object state (e.g. text, graphic, or image), black point compensation setting and a rendering type (e.g. perceptual, saturation, colorimetric). The linked transform provides a mapping directly from the source color space to the destination color space. If a linked transform for these settings does not already exist in the link cache, a linked transform from the CMM will be obtained (assuming there is sufficient memory -- if there is not sufficient memory then the requesting thread will need to wait). Depending upon the CMM, it is possible that the CMM may create a lazy linked object (i.e. create the real thing when it is asked to transform data). At some point, a linked transform will be returned to the requesting thread. The thread can then use this mapping to transform buffers of data through calls through an interface to the external CMM. Once the thread has completed its use of the link transform, it will notify the link cache. The link cache will then be able to release the link when it needs additional cache space due to other link requests.
+In the typical flow, when a thread is ready to transform a buffer of data, it will request a linked transform from the link cache. When requesting a link, it is necessary to provide information to the CMM, which consists of a source color space, a destination color space, an object state (e.g. text, vector graphic, or image), black point compensation setting and a rendering type (e.g. perceptual, saturation, colorimetric). The linked transform provides a mapping directly from the source color space to the destination color space. If a linked transform for these settings does not already exist in the link cache, a linked transform from the CMM will be obtained (assuming there is sufficient memory -- if there is not sufficient memory then the requesting thread will need to wait). Depending upon the CMM, it is possible that the CMM may create a lazy linked object (i.e. create the real thing when it is asked to transform data). At some point, a linked transform will be returned to the requesting thread. The thread can then use this mapping to transform buffers of data through calls through an interface to the external CMM. Once the thread has completed its use of the link transform, it will notify the link cache. The link cache will then be able to release the link when it needs additional cache space due to other link requests.
\begin{figure}
\begin{center}
@@ -209,7 +210,7 @@ Similarly, it is possible to turn off or on black point compensation for the col
\noindent where 0 implies compensation is off and 1 implies that compensation if on. Integer values were used instead of boolean for this command to enable easy expansion of the option to different types of black point compensation methods.\\
-It is also possible to make use of the special black preserving controls that exist in littleCMS. The command line option
+It is also possible to make use of the special black preserving controls that exist in littleCMS. The command line option\\
\textcolor{red}{-dKPreserve = 0 / 1 / 2}\\
@@ -274,23 +275,23 @@ Note that if -sSourceObjectICC is used to specify device link ICC profiles to ma
It is often desired to perform unique mappings based upon object types. For example, one may want to perform one color transformation on text colors to ensure a black text and a different transformation on image colors to ensure perceptually pleasing images and yet another transformation on graphics to create saturated colors. To achieve this, Ghostscript provides an unprecedented amount of color control based upon object type.
-The following commands, enable one to specify unique {\bf output} ICC profiles, rendering intents, black point compensation and black preserving methods for text, graphic and image objects. As shown in Figure \ref{fig:ICC_ARCH}, these profiles are stored in the device structure. Specifically, the command options are:\\
+The following commands, enable one to specify unique {\bf output} ICC profiles, rendering intents, black point compensation and black preserving methods for text, vector graphic, and image objects. As shown in Figure \ref{fig:ICC_ARCH}, these profiles are stored in the device structure. Specifically, the command options are:\\
-\textcolor{red}{-sGraphicICCProfile = filename}\\
+\textcolor{red}{-sVectorICCProfile = filename}\\
-\noindent Sets the ICC profile that will be associated with the output device for vector-based graphics (e.g. solid color Fill, Stroke operations). This option can be used to obtain more saturated colors for graphics. Care should be taken to ensure that the number of colorants associated with the device is the same as the profile. \\
+\noindent Sets the ICC profile that will be associated with the output device for vector graphics (e.g. solid color Fill, Stroke operations). This option can be used to obtain more saturated colors for graphics. Care should be taken to ensure that the number of colorants associated with the device is the same as the profile. \\
-\textcolor{red}{-dGraphicIntent = intent}\\
+\textcolor{red}{-dVectorIntent = intent}\\
-\noindent Sets the rendering intent that should be used with the profile specified above by -sGraphicICCProfile. The options are the same as specified for -dRenderIntent.\\
+\noindent Sets the rendering intent that should be used with the profile specified above by -sVectorICCProfile. The options are the same as specified for -dRenderIntent.\\
-\textcolor{red}{-dGraphBlackPt = 0 / 1}\\
+\textcolor{red}{-dVectorBlackPt = 0 / 1}\\
-\noindent Sets the black point compensation setting that should be used with the profile specified above by -sGraphicICCProfile.\\
+\noindent Sets the black point compensation setting that should be used with the profile specified above by -sVectorICCProfile.\\
-\textcolor{red}{-dGraphicKPreserve = 0 / 1 / 2}\\
+\textcolor{red}{-dVectorKPreserve = 0 / 1 / 2}\\
-\noindent specifies the black preserving method that should be used from mapping CMYK to CMYK for graphic objects. The
+\noindent specifies the black preserving method that should be used from mapping CMYK to CMYK for vector graphic objects. The
options are the same as specified for -dKPreserve.\\
\textcolor{red}{-sImageICCProfile = filename}\\
@@ -332,34 +333,34 @@ In addition to being able to have the output ICC profile dependent upon object t
\textcolor{red}{-sSourceObjectICC = filename}\\
-This option provides an extreme level of override control to specify the source color spaces, rendering intents and black point compensation to use with graphics, images and text for source objects. The specification is made through a file that contains on a line, a key name to specify the object type (e.g. Image\_CMYK) followed by an ICC profile file name, a rendering intent number (0 for perceptual, 1 for colorimetric, 2 for saturation, 3 for absolute colorimetric), a black point compensation value (0 or 1), a boolean to indicate if source ICC profiles should be overridden, and a value for the CMYK objects to indicate if any type of black preservation should be used when going from CMYK to CMYK transformations. An example file is given in ./gs/toolbin/color/src\_color/objsrc\_profiles\_example.txt. Profiles to demonstrate this method of specification are also included in this folder. Note that if objects are colorimetrically specified through this mechanism, other operations like -sImageIntent, -dOverrideICC, have no affect.\\
+This option provides an extreme level of override control to specify the source color spaces, rendering intents and black point compensation to use with vector graphics, images and text for source objects. The specification is made through a file that contains on a line, a key name to specify the object type (e.g. Image\_CMYK) followed by an ICC profile file name, a rendering intent number (0 for perceptual, 1 for colorimetric, 2 for saturation, 3 for absolute colorimetric), a black point compensation value (0 or 1), a boolean to indicate if source ICC profiles should be overridden, and a value for the CMYK objects to indicate if any type of black preservation should be used when going from CMYK to CMYK transformations. An example file is given in ./gs/toolbin/color/src\_color/objsrc\_profiles\_example.txt. Profiles to demonstrate this method of specification are also included in this folder. Note that if objects are colorimetrically specified through this mechanism, other operations like -sImageIntent, -dOverrideICC, have no affect.\\
The example file mentioned above contains the following tab delimited lines\\
\begin{tabular}{llllll}
-Graphic\_CMYK & cmyk\_src\_cyan.icc & 0 & 1 & 0 & 0 \\
+Vector\_CMYK & cmyk\_src\_cyan.icc & 0 & 1 & 0 & 0 \\
Image\_CMYK & cmyk\_src\_magenta.icc & 0 & 1 & 0 & 0 \\
Text\_CMYK & cmyk\_src\_yellow.icc & 0 & 1 & 0 & 0 \\
-Graphic\_RGB & rgb\_source\_red.icc & 0 & 1 & 0 & \\
+Vector\_RGB & rgb\_source\_red.icc & 0 & 1 & 0 & \\
Image\_RGB & rgb\_source\_green.icc & 0 & 1 & 0 & \\
Text\_RGB & rgb\_source\_blue.icc & 0 & 1 & 0 & \\
\end{tabular}\\
-\noindent where the first item in the line is the key word, the second item in the line is the file name of the {\bf source} ICC profile to use for that object type, the third item specifies the rendering intent, the fourth item specifies the black point compensation setting, the fifth term indicates if source ICC profiles should be overridden, and the sixth term which should only be there for CMYK source objects indicates if any type of black preservation should be performed if we are going to a CMYK color space. Note that not all types need to be specified. It is possible to have only a single type specified in the file (e.g. Image\_CMYK). The other items would render in a normal default fashion in this case. Note that it is necessary to include all the possible options in each line. That is, ``Graphic\_CMYK cmyk\_src\_cyan.icc 0'' is not a valid line but must include settings for the next three values as given above for Graphic\_CMYK. In addition to CMYK and RGB types given above, the user can also specify Graphic\_GRAY, Image\_GRAY and Text\_GRAY objects.
+\noindent where the first item in the line is the key word, the second item in the line is the file name of the {\bf source} ICC profile to use for that object type, the third item specifies the rendering intent, the fourth item specifies the black point compensation setting, the fifth term indicates if source ICC profiles should be overridden, and the sixth term which should only be there for CMYK source objects indicates if any type of black preservation should be performed if we are going to a CMYK color space. Note that not all types need to be specified. It is possible to have only a single type specified in the file (e.g. Image\_CMYK). The other items would render in a normal default fashion in this case. Note that it is necessary to include all the possible options in each line. That is, ``Vector\_CMYK cmyk\_src\_cyan.icc 0'' is not a valid line but must include settings for the next three values as given above for Vector\_CMYK. In addition to CMYK and RGB types given above, the user can also specify Vector\_GRAY, Image\_GRAY and Text\_GRAY objects.
In addition, it is possible to have unique color management methods for these object types through two special names which are ``None'' and ``Replace''. For example, if our file contained the following two lines\\
\begin{tabular}{ll}
-Graphic\_CMYK & None \\
+Vector\_CMYK & None \\
Text\_CMYK & Replace \\
\end{tabular}\\
-\noindent then graphic CMYK source objects will not be color managed but instead will go through the standard Postscript mapping methods (e.g. 255-X). CMYK text objects will go through the color replacement color management route which is provided for those developers who wish to provide direct output replacement colors for a given incoming source color. This is currently implemented in the function gsicc\_rcm\_transform\_general, which is in the file gsicc\_replacecm.c. The current implementation computes the color negative of the source color as a demonstration. Note that the replaced color should be in the device's color space. The entire contents of the file, gsicc\_replacecm.c are provided as an example for developers.
+\noindent then vector graphic CMYK source objects will not be color managed but instead will go through the standard Postscript mapping methods (e.g. 255-X). CMYK text objects will go through the color replacement color management route which is provided for those developers who wish to provide direct output replacement colors for a given incoming source color. This is currently implemented in the function gsicc\_rcm\_transform\_general, which is in the file gsicc\_replacecm.c. The current implementation computes the color negative of the source color as a demonstration. Note that the replaced color should be in the device's color space. The entire contents of the file, gsicc\_replacecm.c are provided as an example for developers.
In addition, one can specify a device link ICC profile to use with a particular source object type when mapping to the destination color space. This is done by simply using a notation such as\\
\begin{tabular}{llllll}
-Graphic\_RGB & linkRGBtoCMYK.icc & 0 & 1 & 0 & \\
+Vector\_RGB & linkRGBtoCMYK.icc & 0 & 1 & 0 & \\
\end{tabular}\\
\noindent in the -sSourceObjectICC file, where linkRGBtoCMYK.icc is the device link ICC profile file name. Note that the rendering intent etc are still specified but their effect is dependent upon the CMM that is hooked in with Ghostscript. With the current use of lcms, these values have no effect with device link profiles. Note also that if the device ICC profile is an NCLR profile, it is possible that the device link profiles specified in the -sSourceObjectICC file can have a destination color space that is either CMYK or NCLR.
@@ -373,7 +374,7 @@ In the first example, copy the files in ./gs/toolbin/color/src\_color/ to ./iccp
% \leavevmode \epsfysize=3.0in
\includegraphics*[width=2.5in]{figures/text_graph_image_cmyk_rgb.pdf}
\end{center}
- \caption{Example file with mixed content. The file includes RGB and CMYK text, graphics, and iamges}
+ \caption{Example file with mixed content. The file includes RGB and CMYK text, vector graphics, and images}
\label{fig:normal}
\end{figure}
@@ -390,12 +391,12 @@ In the first example, copy the files in ./gs/toolbin/color/src\_color/ to ./iccp
\label{fig:object_based_color}
\end{figure}
-Figure \ref{fig:normal} displays the source file text\_graph\_image\_cmyk\_rgb.pdf rendered with default settings and Figure \ref{fig:source_icc} displays the result when rendered using -sSourceObjectICC = objsrc\_profiles\_example.txt. The profiles specified in objsrc\_profiles\_example.txt are designed to render object types to the color specified in their name when used as a source profile. In this case, RGB graphics, images and text are rendered red, green and blue respectively and CMYK graphics, images and text are rendered cyan, magenta and yellow respectively.\\
+Figure \ref{fig:normal} displays the source file text\_graph\_image\_cmyk\_rgb.pdf rendered with default settings and Figure \ref{fig:source_icc} displays the result when rendered using -sSourceObjectICC = objsrc\_profiles\_example.txt. The profiles specified in objsrc\_profiles\_example.txt are designed to render object types to the color specified in their name when used as a source profile. In this case, RGB vector graphics, images and text are rendered red, green and blue respectively and CMYK vector graphics, images and text are rendered cyan, magenta and yellow respectively.\\
Modifying the contents of the objsrc\_profiles\_example.txt file to\\
\begin{tabular}{llllll}
-Graphic\_CMYK & cmyk\_src\_renderintent.icc & 0 & 1 & 0 & 0\\
+Vector\_CMYK & cmyk\_src\_renderintent.icc & 0 & 1 & 0 & 0\\
Image\_CMYK & cmyk\_src\_renderintent.icc & 1 & 1 & 0 & 0 \\
Text\_CMYK & cmyk\_src\_renderintent.icc & 2 & 1 & 0 & 0 \\
\end{tabular}\\
@@ -415,7 +416,7 @@ Text\_CMYK & cmyk\_src\_renderintent.icc & 2 & 1 & 0 & 0 \\
For another example of object dependent color management, copy the files in\\
./toolbin/color/icc\_creator/effects to ./iccprofiles. Now specify unique output ICC profiles for different object types using the command line options\\
-\noindent -sGraphicICCProfile = yellow\_output.icc\\
+\noindent -sVectorICCProfile = yellow\_output.icc\\
-sImageICCProfile = magenta\_output.icc\\
-sTextICCProfile = cyan\_output.icc\\
@@ -425,11 +426,11 @@ cyan\_output.icc, yellow\_output.icc and magenta\_output.icc render a color that
Finally, in yet another example, we can demonstrate the effect of rendering intent for different objects using the command line options\\
\begin{tabular}{l}
--sGraphicICCProfile = cmyk\_des\_renderintent.icc\\
+-sVectorICCProfile = cmyk\_des\_renderintent.icc\\
-sImageICCProfile = cmyk\_des\_renderintent.icc\\
-sTextICCProfile = cmyk\_des\_renderintent.icc\\
-dImageIntent = 0\\
--dGraphicIntent = 1\\
+-dVectorIntent = 1\\
-dTextIntent = 2\\
\end{tabular}\\
@@ -1181,7 +1182,7 @@ Reading Massachusetts, 1999.
\end{thebibliography}
\vspace*{1.25in}
-Copyright (c) 2019-2021, Artifex Software Inc. All rights reserved.
+Copyright (c) 2021, Artifex Software Inc. All rights reserved.
\end{document}
diff --git a/doc/colormanage/figures/DeviceN_Figure1.pdf b/doc/colormanage/figures/DeviceN_Figure1.pdf
new file mode 100644
index 00000000..4769b7da
--- /dev/null
+++ b/doc/colormanage/figures/DeviceN_Figure1.pdf
Binary files differ
diff --git a/doc/colormanage/figures/Object_Color.pdf b/doc/colormanage/figures/Object_Color.pdf
new file mode 100644
index 00000000..f4e206a7
--- /dev/null
+++ b/doc/colormanage/figures/Object_Color.pdf
@@ -0,0 +1,19819 @@
+%PDF-1.5 %
+1 0 obj <</Metadata 268 0 R/Pages 2 0 R/OCProperties<</D<</RBGroups[]/ON[71 0 R]/Order 70 0 R>>/OCGs[71 0 R]>>/Type/Catalog>> endobj 268 0 obj <</Subtype/XML/Length 29573/Type/Metadata>>stream
+<?xpacket begin="" id="W5M0MpCehiHzreSzNTczkc9d"?>
+<x:xmpmeta xmlns:x="adobe:ns:meta/" x:xmptk="Adobe XMP Core 4.1-c036 46.277092, Fri Feb 23 2007 14:17:08 ">
+ <rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#">
+ <rdf:Description rdf:about=""
+ xmlns:dc="http://purl.org/dc/elements/1.1/">
+ <dc:format>application/pdf</dc:format>
+ <dc:title>
+ <rdf:Alt>
+ <rdf:li xml:lang="x-default">Object_Color</rdf:li>
+ </rdf:Alt>
+ </dc:title>
+ </rdf:Description>
+ <rdf:Description rdf:about=""
+ xmlns:xap="http://ns.adobe.com/xap/1.0/"
+ xmlns:xapGImg="http://ns.adobe.com/xap/1.0/g/img/">
+ <xap:CreatorTool>Adobe Illustrator CS3</xap:CreatorTool>
+ <xap:CreateDate>2017-02-01T09:21:01-07:00</xap:CreateDate>
+ <xap:ModifyDate>2017-02-01T09:21:01-08:00</xap:ModifyDate>
+ <xap:MetadataDate>2017-02-01T09:21:01-08:00</xap:MetadataDate>
+ <xap:Thumbnails>
+ <rdf:Alt>
+ <rdf:li rdf:parseType="Resource">
+ <xapGImg:width>256</xapGImg:width>
+ <xapGImg:height>192</xapGImg:height>
+ <xapGImg:format>JPEG</xapGImg:format>
+ <xapGImg:image>/9j/4AAQSkZJRgABAgEASABIAAD/7QAsUGhvdG9zaG9wIDMuMAA4QklNA+0AAAAAABAASAAAAAEA&#xA;AQBIAAAAAQAB/+4ADkFkb2JlAGTAAAAAAf/bAIQABgQEBAUEBgUFBgkGBQYJCwgGBggLDAoKCwoK&#xA;DBAMDAwMDAwQDA4PEA8ODBMTFBQTExwbGxscHx8fHx8fHx8fHwEHBwcNDA0YEBAYGhURFRofHx8f&#xA;Hx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8f/8AAEQgAwAEAAwER&#xA;AAIRAQMRAf/EAaIAAAAHAQEBAQEAAAAAAAAAAAQFAwIGAQAHCAkKCwEAAgIDAQEBAQEAAAAAAAAA&#xA;AQACAwQFBgcICQoLEAACAQMDAgQCBgcDBAIGAnMBAgMRBAAFIRIxQVEGE2EicYEUMpGhBxWxQiPB&#xA;UtHhMxZi8CRygvElQzRTkqKyY3PCNUQnk6OzNhdUZHTD0uIIJoMJChgZhJRFRqS0VtNVKBry4/PE&#xA;1OT0ZXWFlaW1xdXl9WZ2hpamtsbW5vY3R1dnd4eXp7fH1+f3OEhYaHiImKi4yNjo+Ck5SVlpeYmZ&#xA;qbnJ2en5KjpKWmp6ipqqusra6voRAAICAQIDBQUEBQYECAMDbQEAAhEDBCESMUEFURNhIgZxgZEy&#xA;obHwFMHR4SNCFVJicvEzJDRDghaSUyWiY7LCB3PSNeJEgxdUkwgJChgZJjZFGidkdFU38qOzwygp&#xA;0+PzhJSktMTU5PRldYWVpbXF1eX1RlZmdoaWprbG1ub2R1dnd4eXp7fH1+f3OEhYaHiImKi4yNjo&#xA;+DlJWWl5iZmpucnZ6fkqOkpaanqKmqq6ytrq+v/aAAwDAQACEQMRAD8AMv8AnMyBpW8nBeo/SVNw&#xA;B/x6eORkWMiln/OOmk29pZSayqx2808/1abWbprZVtzGpf0LYsZJBJIjVZmUAjbiQpJuxgV5uw0u&#xA;OMok0ZS7q/Hx5M6u/wAxbe0udUit55Ltp7tvq8MYYq0colVnaJA7/DG6kmQAHbcsDxlxAmq3DmmE&#xA;bEZCiBv1N8+nuQt1r2n6t+lbO/1d5YIH9SzgjWrLKxaRJGJoxSob7VD8Wwpyx8MyBAO/f3dzacZH&#xA;00Jdfd3V+LYrZXIs4nWG7nFy9y0ruGeiqECRoqhg3LdwzEk8TTJ6bTDFe/FxN0NPw2Zb2xT817u6&#xA;1iz0mZqMwe5a4b0oouMjOooApB4FV5AkAHenSuU6iQG347nV9qECgOX47/j79i82+qyW89VVkcHZ&#xA;/hNPf9oZimQIdPzffvkbn/gny/z3f9G2fI+/oJXLo8m4J3hV2KuxV2KuxV2KrJpPShkkpXgpanSt&#xA;BXDEWaYylQJSqLUfMUkauun2dGANPrktRUV3/wBFzJOPCDXFL/Sj/i3Bjm1RF8GP/lZL/qmu+veY&#xA;60+oWVfD67L/ANkuDgw/zpf6Uf8AFsvE1X8zH/ysl/1TVrO+1J7tbe9tYYOcbyRtDO81fTZAQwaK&#xA;Gn94PHIzxw4biSd+or9J7meLLlM+HJGMbBO0jLlXfGPemGUOWg7+7uIZIY4FQtLyLNJWgCLXtluO&#xA;IIJPRpyzkCBGt1nqav4W/wDw+P7vzR+9/o/atS51NywQ2xKHi4+OoNAaH6CDj+781/e/0ftVtKvH&#xA;vLFLiRQjsXVlU1FUcptX/VxzQEJUE6fKckBI+f2GkXlTcleqXmopqFrZ2ckMPqwzzySzRPMKQtEo&#xA;UKkkXX1ute2ZGKEOAylZogbGud+R7nB1GXL4sceMxHFGRsgy+kxHSUf5yzh5m/5brL/pDl/7KsPF&#xA;h/my/wBMP+IXw9V/Px/8q5f9VFqHzE5YJqFiSh4uBZy1BoDQ/wCleBrjxYf5sv8ATD/iF8PVfz8f&#xA;/KuX/VRMdNnluNOtbiXj6s0McknAELyZQTQEsQKnxyrLERmQOQLkaeZljjI8yB9yIytudirsVdir&#xA;wn/nKGwtbr/DBuRVEN8pPXiHEFWFWTccfHMTVTMapqyHk8n0e0vNBd1j4xIHLtHI7fvHYihiVlZf&#xA;hCVLMOJG3hlWDtAwPeHJ0evlh25xPRnd/LYLp8Z06WS7t6qHjubZIH9UNMwmjVC/MKnwMzksuwDc&#xA;W45ssMxmmTA7cz7/ALHb4coyTMo/p/Z+r70hudJt7YSTyI0N0ZD+wSyuHJKtH8TgoCFpTx6bjMae&#xA;jnLIfVsKPLv5bD3Fxo6OUsxkZefz+KQ6rqmq2+ox6fa2j3F1QL6YbmWfaR5aQtM/FVbdeq8SNqUy&#xA;7JqJQFXQHU/t83Ly5ZYyB07yzzyfpN/fyfXp9OSb0JfrP6JmH1lZA3KJHoWUskbsQvGoBO9MjkhI&#xA;AGQ4t9+/l+NmnUYATHiPXf5bf2eaE85/l75WEh1DSHWOyvF9SCZkV4zzbkI4vjY7Iy7k7bVBqMw9&#xA;ViOICQ+l1mbTcAs/2d3z3+T3JNT1XS/LWixaXYm7H6OUhnEp+OKKL04mEKSspkDMeRFBxp3GZmL6&#xA;R7mpL5PO/nX6u9ynleZI61igYStOEMxjq6qlKiP94QpPgK9TYlncbB0VhWjAHcFTv4qdx8jgVvFX&#xA;Yq7FXYqo3v8AvHP/AMY3/wCInJ4/qHvYZfpPuQdvNFBY+tM6xQxRq8krkKqqsYJZidgAMMx6j71w&#xA;i4gDuDH/AC75n0vzrYy3VhNNaNp19LEjoU5MEDLHJxkU/BLG9aMoINR+zXLNRp5YiAeoRHICSOoZ&#xA;GK/pS1rufq9xU/7ODID+7PvH++a5f3sf6svvij8qchL9S/3qtflN/wAQy2H0S+DRk+uPxY5+Yfnt&#xA;PKWm28scBvNQu5kS2tQDRkV09arD7PwNxXr8RGxFct0un8WVXQbclxgZ/wAMeafWEWnyzNqdoWJv&#xA;UV2cO/BxxAU+mx4g0A7A+OY8okGiiExOIkOR3X+Xf+OTH/xkn/5PPl2q+v4D7g4+h/uh75f7oplm&#xA;O5aT6j/ykFl/zA3v/Jy1zJh/cy/rR+6bg5P8ah/wvJ/usaSfmJ56TylpttLHAbzULuZEtrUA0dFd&#xA;fWqw+z8DcV6/ERsRXDpdP4squg5mS4wM/wCGPNPbGPT5pv0nasxN4quzB5ODjiAp9NjxB4qN+Ncx&#xA;5RINFGOYnESHI7orRv8Ajj2P/MPF/wAQGTz/AN5L3lq0v91D+qPuRmVOQ7FXYq7FXiX/ADklcvFL&#xA;5cRWp6i3xKluKtxNtQHpXc1/tzC1o2DRmjdPMrHUvrSpLKyX0sx+3NJ6jpyBHDpzqvOuw7DNVONE&#xA;sRSf6XHdreT3FvALiS0glmltwJK27SKq+sxBALQkVHwhfnUZseyZ1OuknY9m5PXwk0D+P2ICt3d3&#xA;LB1lv9RuayO9JXkKxIQvJqyGixoORbbbsM25zjGZWPkOlDn+2ncePHHKXF8OEe79fkhdTWxTzDpp&#xA;guZYpbVpJYXjkKS8mYensnpn4mO/iA3EHodH/KGSR4ugdTPXZJSuW47mR2DTafbR6vFMsNw8jRCC&#xA;YKVlhK1V+DBkZFcUqa1YUG4NN1p9VHKL/h5fHydti1Iyx5VHv8/233ofU9fvr3T47GZlisInjdwP&#xA;idpU5kFmpy41lNAVp0+nU9oaoT9AHLn934/Q6jX54SNAGx3/AKntn6B1DV9A0GWx1RtOaCyjDMkb&#xA;VcSJE3RJIuP93Tv1zPw/QPcHFCzRfKvnKz1WKa/8zSX1lCeRjMfBpa8yVZakLQv1qdh0FARYlk13&#xA;pltduHledSooBDcTwinXdYnQH54FUP0BY/79vP8ApNvP+quKu/QFj/v28/6Tbz/qrirv0BY/79vP&#xA;+k28/wCquKpLJow0bzJp13aX1666reNb3NpPcyTQBFsZ5fgSQtRi8CHnXltSvHbFWS3v+8c//GN/&#xA;+InJ4/qHvYZfpPuYz5k0e81vy2+k2t/+jvrSxLPcKjO/pBVLIvF4qF6UNajjUU3yObis8Jo373M7&#xA;K1UME45JQ46HLpdddjy++ks8ueSl8vXkcljfMLNY/TmtTH/eHj9ouXNDzPPb9RzB0+DPE3kynJz5&#xA;/wBpqnE1EfE1Ms4qHHziAK/R+Pey6Mk6lZk9TbT/APEoM2Q/uz7x/vmmX97H+rL74pjlTkJfqX+9&#xA;Vr8pv+IZbD6JfBoyfXH4sT1byBoWp+YZNdvpbme7aMQxQu6GGJQvH92hSoNatuftEnNdq9EM4oyn&#xA;EWDsR0+BdzHtTJHTHTAREJXfOzfx+HLknXlrSbbSYDZW00s0QZnX1mVivKnwrxCjjtX5k5fgwjHH&#xA;hBNebp8OEY40CT70w8u/8cmP/jJP/wAnnzN1X1/AfcGrQ/3Q98v90UyzHctJ9R/5SCy/5gb3/k5a&#xA;5kw/uZf1o/dNwcn+NQ/4Xk/3WNj2s+RdE1fX/wBN38s890kP1eCFjEIokAb7C+nyLcnZqsxNT8hm&#xA;q1eiGcUZTiLHIjp8Hfw7UyR00tPEAQnfFzs38a5bbBNfLmlW2kwrZW00s0PNnX1mVivIfZXiFHHa&#xA;vzOX4MIxx4QTXm6jDhGONAk+9ONG/wCOPY/8w8X/ABAZlZ/7yXvLHS/3UP6o+5GZU5DsVdirsVeA&#xA;f85WTzwv5VeMBgPr9YzWhNbYDoV8fHMbUC6a8gt5L5dmkutRBkdLRndPqyGORrUgmpDuC0ifCARs&#xA;dq9M1+SIAaTA8wzW+s7exW0k4fWLK8cRtdWrrcRqqtQ1oeUvwozsibrv9J0GoOKVnYVy7/j0/scj&#xA;R6s4ZeX6UJDqtus5ktiLlbTh6xsXUyEh1QFCnqbtxAVwrb+2byWvxR6/Vff+O6ne/nsVbG78uX3f&#xA;q80Pa2ekaheLqkWqve3MMixSC42lpE6uaqBC8fqFG4gb03+0WA5zKTEVWx/Hm8/xHqnwvdQvbG2S&#xA;5vS0Fp+4tlkUMsUbAq7KtPTVhT9kCgpToKZeLXCOPgMemx8+n9vN2On1QGPhIHkRz8vl+PMFMrWt&#xA;bhGV0cuhUlnCAbcHKj4aonjmvyZJZJcUubr8mQzkTLm+lvLqKnl/TEUgqtpAFI2FBGvTOgxfQPc2&#xA;BMMsV2KuxV2KuxVJdf8A+Or5b/7aMn/dOu8VTiWMSRvG1QrqVNOtCKYQaNokLFPLNR038zlmkCWl&#xA;5fxiUxWrw3dlZcIFk4qzx/GJCY961U9qbCuSc8T/AAR/2X/FOCNHkArxsnyx/wDVNDx6X+ZDTJFJ&#xA;puoKOJaWUapZN2ooCcQR8Vd9/wCg8aH8yP8Asv8Aik/lMn+rZPlj/wCqbM/JcPmdmll1+1ntGt0E&#xA;Nkk1xbXPKNiObFreOI8v3S/aJ6/PITygihER91/pJbMOmMZcUpyntW/D/vYx7mVZS5SS+bIdbOmi&#xA;fQ15apDJH6SkRsDG8irNtK8a1ERZh8Q3GWQnw3tdtWTFxUbII7q/SCwlLbz4WAfyfAoQUci501hI&#xA;eRFVP1cFBRQ24P2qdjkvEj/NH+y/Ww8GX8+X+x/4lfZv+YMV280fk76uoLLAVu9KSQCtAzOkTfaH&#xA;YDHxI/zR/sv1r4Mv58v9j/xL0DRYZIdKtVlha3maMSTW7usjRySfHIhdKI3FmIqu3hkMkzI2WzFi&#xA;EI8IRuQbEh83QX/1OO80y1NzqUJ9KJQ0i/upWUyf3csFf7terdsshllEEDkfIHl7/e0ZNPCchI3x&#xA;AEbEjnV8j5Bhwi1RmWvkNolXl6oa8LE0qF4lOVNxU7HbpkvGPl/pY/qR+Wj3y/00v1us59aiuHnj&#xA;8iXFuVNLcrelZACtCzOjNTvsB0+4vjHy/wBLH9S/lo98v9NL9b0fTUCadaoIWtwsMYEDsXaOij4G&#xA;YklivSuVykZEk8y244CEREcgKRGRZuxV2KuxVgn5meSdJ80Xmk/X7Ke+ezS6NtbxTxwRu7mFikpY&#xA;q5DCP9hgRv8AMA4xLm34ccZbyNAEMR8xeWfJN1psU2j2tsupcU4vasttAXj4fWSUNY14JRuSLVxs&#xA;KtQ5j6rTgwMh0+5nnwSESQKr7vx9zGdQ0qCHRNQt9PMaXCKzSOfVEM4uAyu/wO/FlWNuLvyVT4dF&#xA;0vFRsnb8U6oR4r72D+RJNPGpcBNDa2UduRb3t6OPN4pAQfglj4Kzsuz8tgB3BGTON8+bdGXDvVhW&#xA;h0nUpbiz1jR4Irm2uJOOqW2n3Ec37u4YiMyJIqIso9VhWrU78aHGgBUunK2An0CdwWkbnk1zIqoq&#xA;usQKiRpEYCRVVFZW4ty5UNdthmNINkcg2AtV1DUvRcXECNNG8ccU9VX0FIIeT1p4iGNHjqffseOS&#xA;gCY7uTRkKD6O8rMzeWdIZ92aytyxoRuYlrsdxm+xfSPc1UmeTV2KuxV2KuxVJdf/AOOr5b/7aMn/&#xA;AHTrvFU6xVgf5l33ky3vdKXzHc3VrJ6dy9hLakAhgYQ+6gyBqH4abU5V3phViOk6n+VVvrB1O180&#xA;6vNeSSQxu78mEhilHBC/1cFldkUU5UK8adsVe1YFdiriaAk9Bvtv+rFXjt/r35Z3Op3mpzarq+ia&#xA;jqZjmuEt2ZDIvoxJEtLdZo24rGaAksCz+1CqN/LzX/y/sbtH03VdQEmsNHDFpl3T0llZY1BVYo0Q&#xA;Ptw5ciNttqYoeq4EuxV2KvN/Nek6NpuumWfVdT0t9X9Wee4snIgIUxRBZIwzMSrSALwjr8dW2GxV&#xA;OPy+sNI9F9U0bVri/wBNnjjhihYGO3BVFPqpGQDydCtWPXEqzDArsVdirsVdiqRahrt4+vR6FpSx&#xA;/W1i+s3lzOrPFDFXioCKyF3Y9uQ2zNxaeIxeLO+G6AHMn7dnWZ9ZM5xgxVxVxSJ3AHuBFk+8IXVN&#xA;T832Fpqb+jaXElrAk9lIsciRzNycSRuDIeDbLTcj+EJxxEAxJG+4O9cvIebseyoznqfD1FeGaqUB&#xA;Xfdg8XLbb430CulecYL7yanmExES+kRNZr9oXSn02txyp8Rm+Ba+2Uyx1Knaajs449UcN7Xsf6PP&#xA;i/0u5Q/krzTquv8AlC18wTxQxtcmQm3iV/gSKVojuzHkfgr2zWduZs2lgZ4gJiH1A8+HqRv07urb&#xA;2loMen1MsIJ9NbnzAPd5sjM7yOiwMpDLyZyCQAenQjrlY1ksuSAwmMomPFI+R+mt+ct6HkfjrOCg&#xA;beaaf+aHmG5n8xaYsdlca9YajNpWhadDFKGupIQjGeWszenCqv8AvG6L4k0U7NrejWH6XTTlOomC&#xA;fUQpaRbVWiiLUrxX1GdvbkT9AxVgZ82/mLF5s0byzdjSob/VdPmv5GWC4dIHh4gw1FwOe7fbFPkc&#xA;Kso0zzZZIljp+u3tla+Y51CXFhFMpAuOPJo0qSakbqp+IjAqpbeefJ90UFvq9tKZLn6igSQEm6A5&#xA;GDb/AHZx349cVW+WPOmieZJtRj02X1P0dcvauTUF/TVeTgED4ebFR40r0OKp9irsVSXX/wDjq+W/&#xA;+2jJ/wB067xVOsVdiqlHa2sc8txHCiTz8fWlVQHfiKLyYCrUGwriqrirsVdiqB1yWGDSLu7lgS5F&#xA;lG12kUgBBktx6qHcGhDKCD2O+Ko7FXYq7FXYqslt4JqerGklOnNQ1K0Pf5Yq6KGGJSsSLGpNSqgK&#xA;Knvtiq/FXYq7FXYq7FWI6jZaho/m+TzDbWct/Y31sIL2K3o00bx04SKhpzBCgUB8fbNpiyQy4PCJ&#xA;EZRNi+R8r6Oh1GLJp9WdRGJnCcakI8wRyNdeVbefkitX1LUrvRbx4tMuPTkUR20BX/SJGJqzFASE&#xA;QAbcjUnsNq4U8cY0OIE+XJ6DsnKcuYSkPDgP52xPw6eXXnsOpRZeXL+080Xl2sbnyxOyaytoF/ej&#xA;UCDGyCMb0rSU/wCVTAZgxH87l8He5dZCenjG/wB+Lx304Od3/sfdaK/KbT9Q0vyJYaZqVrLa3toZ&#xA;xNFIv+/J5JF4kVB+Fxg1cxKRI3H7Gv2gzQy6yWTHISjKqryiAyXT0MMEgMbJR2YLTcjtT6M5v2e0&#xA;5w4pRMDj/eSO/cT6fs28nV55WRvezwu08jeZk1rzX5z0e0vtK81w6lcX2jerCxhv7GQJWzmjr/ux&#xA;lNOhU7/LoGh7L5R8wahrWlJcalo91ol+oAubK6A2c9fTdSQ67deviMCsU1u11R/zp0HVI9OupNMs&#xA;tPuLO5vkiJiWW5ZWT4u6j9phsMKpPp/lfWIfMmoaXqnlu51BJ9cl1nTNaF9INPjjlufWSSWATpxn&#xA;gB4qqxktQdF3wKsgsNc0/wDMKPzzb+XrhrLWJp7O/wBLWE/WLZI1VI9SoW4epNwo4Xf0yBu3LCrL&#xA;/IFrq9hqfmizvtOmt4Z9Xur+1vWMZhmiuBGY+FGL12PKq7YFZHqMOvSSqdOvLW2iC0dLi1kuGLV6&#xA;hkuLcAU7U+nFUJ9U85/9XTTv+4dP/wBl2KpK9p5vh8yaPJrWpWl3ZSak/wBTgtrV4Xjpp13uXaWT&#xA;Y/ykE1/a7YqzTFXYq7FXYq7FXYqlnmn/AJRjV/8AmCuP+TTYqmeKuxV2KuxV2KuxV2KuxV2KuxV2&#xA;KuxVLNe8zaHoNuk+q3S26yEiFKM8khFK8I0DO1KitBt3yzHilM1EWWnPqMeKPFMiMfNi9v8AnJ5V&#xA;kmCTQXttEf8Aj4khV0HzWF5ZP+EzNl2VnAvhdVj9otHKXDx17wQPmyE+cNCdIzYzfpJ5VDpHZATf&#xA;C3Qu4Ijj/wBmwzS6rV48H94a+93kBx7x3aTzZYowF/BcacrbLLcqhi8PilheVE/2ZGUaftTBlNRl&#xA;v57M5YpBO+ubBrdirsVdirsVdirsVdiqS6//AMdXy3/20ZP+6dd4qnWKuxV2KpX+nWe8vLW2065u&#xA;TYyrBPLGbdU5tDHPRfUmjY/BMvbFV/6Vvv8AqzXn/B2f/ZRirv0rff8AVmvP+Ds/+yjFUu8wzaxq&#xA;GhahY2mlXUVzc28kUTu9nx5OpADfv2+E9CQK06YqjbfUtUS3iSbSryWZUUSS8rMcmAoWoJwBU4qq&#xA;fpW+/wCrNef8HZ/9lGKu/St9/wBWa8/4Oz/7KMVWtrU0RjNxpl1BE8kcXqu1syq0riNKhJnb7TDo&#xA;MVTPFXYq7FXYq7FXYq7FXYq+cde1qbXdbutWmYsJ3K2it/uu2Un0kAqePw/E1P2iTnZ9m6YYsQP8&#xA;Uty+V9v9oSz6iQv0QNAe5LpX4hUVlWWVlihDGgMjnio+85drtUMGGWQ/wguB2dopanPHGATZ3roO&#xA;peseVINO0lY9OtGAikBLV2Z5qVMjdKs9Nz8s8H7QyTzSOSe8rfbNLh8KIgBUQNmTsqspVgGVhQg7&#xA;gg5qwXKUNI1D9EWOqW7pJLbaXGLq1RPiYW8isREv+o8ThfBeI7Z3vYuqObD6ucdnBzRopcn5qWL3&#xA;E9qunyvc2z8JOEkRiblLFDE0UpIV1kknAr+zQlqCldvTUn/lXzPaeY9Ma/tkMSrK8TROQXUoaVYD&#xA;py+0vitD3wKnOKuxV2KuxV2KpLr/APx1fLf/AG0ZP+6dd4qnWKuxV2KpLoH/AB1fMn/bRj/7p1pi&#xA;qdYqk/m/WLnRvLV/qdtGsk9tHyQPUotWCmR6EHhGDzbcbA4qkN352Oi3wsru8j1g3AE0UluEjaOI&#xA;PBC60BZZZOd0rhAQeHvTkVSe1/OA2ukB7yza+vIldZmiZIuUixyXA+Ag8YzDERz6c/h740h6VbPO&#xA;9tE88YhnZFaWENzCORVlDADlQ7VpgSqYql2v/wC8MX/MZZf9RkWKpjirsVdiqQebdR1yyhtjpcTs&#xA;rmX15Y4WuWVkiZoU9NN+MkgCs3YdxXkFWJp+YPna3LQXXl959QiNw31aNpRzT62IY2KrbvJwjRgT&#xA;JGHUgj/K4lWSeWvMnmDVNWuIL7R202xSJjE8gn9QyI4VlYvFFF0O3BmB6qSK0CsnxV2Kvm/zHpMn&#xA;l7V73TbkFI7UtJau3R7QkmJ1O1aL8Lf5QOdj2fq4zwizvEb/AAfLu2+y8mPVERFjJL0+89Pmk1vD&#xA;PRbxvh1D4ZIif91MpDoi+ABA5eOaHWk6gSEv4hT7P2P2Hi0WmGOA9dby7y9W0bUrPVrJbqAhoz8M&#xA;sZ3KSD7Ubj+Zc8v1OGWKRhLYhzYi2Rabefu5I53FIRzEjH9jf7RP8tOua/LDcEdXFzQ4SitIt7++&#xA;sdU1C0lNrLqEYh0uVl6RxK3pzFSD9qSV2G32eJpnb9jaQ4cPq+qW7q807KU3Gjfmwv7i21azW2l5&#xA;Cp5O8SlSQPVdObb/AAht2Gx8c27SyHyraea7aCVfMN1BdSmhia35UBJYvXkiHuOPttTapCUyu7O5&#xA;ncNFfz2oAoUhWAgnxPqxSH8cVUP0Vff9Xm8/4Cz/AOyfFXfoq+/6vN5/wFn/ANk+Ku/RV9/1ebz/&#xA;AICz/wCyfFXfoq+/6vN5/wABZ/8AZPirG9Ssr7Sdf0e+1TX3udOk1F/Rt7lLeGOEnT7vcyqqsxJ2&#xA;G4X2xVkn+JfLn/V1s/8ApIi/5qxV3+JfLn/V1s/+kiL/AJqxVZL5p8tRxvI2qWpVAWIWZHagFdlU&#xA;lifYDFUu8l6tpmrT+YL/AEy5ju7KbUU9OeJgykrYWisKjurAgjscVUdZ/MLT9I1HV7G9tpBLptml&#xA;9bcSD9bV2EZjirSkiyvGhB/nU18FVRPzH8qx2cc19eLazNHDJLbhZJShnUsqgonx04kHj0O2NK23&#xA;mvyHbRsv1i3SOyKzhVhaimQORJGFT4to3qydKGuKoObzj+V0HO1e4sh6Sem1uIC1EKvcMvBYz8I9&#xA;J3bsCpruMKo6T8xPJNvEjSapFGjCXipWQECAEvVeNRsppUfF+zXBSorSPOOgaxftZabM9xIsP1hn&#xA;EUqxhPVeGhdlUcucTbYqr+Y5I49OjeRgiC8sqsxAA/0uLucVRX6T03/lrh/5GL/XFVP9OaKLqK0N&#xA;/b/Wp/7mD1U9R6fyLWrfRiqrqTTJp100BdZlhkMTRqHcMFPEqpDBmr0FDirzqfzT+Y+j6ebq4svr&#xA;Fh6Zke9vkRJUZYIyytFbmKimdnCcgGNKfyklCJHmz8y0uVafy1GF/crWNZJGdW4GX4lJCCjsw5V4&#xA;0oanFULB5t/NaK2+PQvWb/SZPWlgfk1Z5mgiWKJ6qBGESrVP7RO+Ks88vXOp3OlpNqcfpXZkmDJw&#xA;MXwLM4jIQsxAMYXqcCUyxVJPN/lTTPMujXFjeQRvMYpFs7hqhoZXWgdXWjjelaHcbHJwmYnYsZY4&#xA;yriF0Qfk8His0IpKrpKhKTQOaMkiHi6N0NVYEHMjxCXvsEIZIiQ5FEwq9vL6tpI9rLsC8LcagdAy&#xA;/Zan+UDmLqNJjzD1i2zJpoT5j5M2/LjTLjXdQvr/AFaWS9sLRUt4YZeIgecn1H5RoER/TUJ9pSKt&#xA;4jMPH2bgxH0x3893l+1+GExCJvveqZlundirsVdirsVdirsVdiqS6/8A8dXy3/20ZP8AunXeKp1i&#xA;rsVWyRxyxtHIoeNwVdGAKlSKEEHqDiqS+XI44tS8xRxqEjTUIwqKAAANOs6AAYq1q/knQNWvDeX0&#xA;Ty3Hxem/Mgx84WgfhT7PJG/4IBhuBiqRL5E8gwa88RnmTVkt0ujG9xJtbw0jEgDfAVUgAnt7YbVK&#xA;5fys8ra/pVvqHl6/dLa9aKZrib1bmOeCNXVVCM8OxMnIMa7bD4TjapifKvkdvL8uq3d9cTabbm5u&#xA;bm5MsqxLK0U9rfTCEDihk9aYycV6kkdBQKmh/Lfy2TcH/SV+uRyQ3gS4kQTJKKFZFQqG47ldtqnD&#xA;ao/SfKOk6XqL6hamb6zJG0UhaQlWVn9Tddl2YsR4VOBVXzNb29xpiRTxJNE13ZBo5FDKf9Li6g7Y&#xA;qqf4a8uf9Wqz/wCkeL/mnFVi+VvLKXcV4mk2a3UG8EwgjDoa1qh4/CfcYqx/UE8920+oXNhbyXV6&#xA;ZpPqpeaI2Ztm4eiqwNJEfUTj8ZPHq9Gb4RhVQ09vzSjvVtXt4E043MrNcyss8gt3ueSAN6waqxMw&#xA;oVOwSm/IYqoX1v8AmhBqEklkpuLKO7ubi3haaPk0cscqRRPydPgjdEcDlvzoacMVUJtb/Oi1sTdS&#xA;6NbzsiJLJBEsbOtPU9VAq3LNJRQhUIKk7DFVH9Kfm9qnl+Rk09YpLmN1jMSJbzqOLiNlaS6Sj+qq&#xA;8qrxMZ5Lv8GKvT8CuxVifmj8udK1u6e/gmfT9ScASzxgPHLxACmaI05EAUqrK3iaAZISIc7SdoZM&#xA;H08u5JLb8nqyj69rDSW/7UdtAIHPt6jyT0HjRa+BGSOQuZl7cyyFACLPtN02x02xhsbGFbe0gHGK&#xA;Jegqak1O5JJqSdydzlbppSJNnmicUOxV2KuxV2KuxV2KuxVJdf8A+Or5b/7aMn/dOu8VTrFXYq7F&#xA;Ul0D/jq+ZP8Atox/9060xVOsVYl5o8jza5rMOoC6W3EMccJCqS8kB9UXNs56enOsy1puCoOKsfg/&#xA;KjXo7O3g/TiRvb26QiSOJwGCQ+ibcgyf7zSECRlG/Ku/fDaoYflDr6xcI9SsoVcXHNEt5Aqm4gv4&#xA;OK0kX4ANQU078B4YqzLyv5Wu9I1TVr+6uluZNSlMgK+sCFaWSVUcPK8f7r1vTQoingo5V2oFZJiq&#xA;Xa//ALwxf8xll/1GRYqmOKuxV2Ksa85aR5i1FIhpFx6QWC5jKieS2K3MqoLa4LRg8lhZWJQ9a1oa&#xA;UxVjGrW/5vwXVu0N7zV5JrVDEsLJ8YT0ZpUFu/FaxtzJ+zWg64UMi8u2nn1Nbll127jm05UlSGOM&#xA;xgFuUfByqxK24VurbfhillWBXyj5x/PH809L88a3pFlrCGC21K6t7SA2tuVjgWR0QFjCXYoOJ719&#xA;+7GQJaiSykeZ/wA8BpbXi66l1AZAsVzbWto4MVaGT+6pXboAd69qUzTph0IafHLNfKuuee7zTY7q&#xA;41M3XrCoJht0VOJKsKrGnhvXoclDDjA33LGWXITsqeZPPl95cto59U1ML6pIijiiidm4rUkfCNhs&#xA;vzI8cjk8GIshAnk70qs/zhjvGCw6m6EhT+9giXdjQDYHfIwngPl81M8g6p4fNPmP/lr/AOScX/NO&#xA;Zf5bH3NX5ifetPmrzJ/y2f8AJOL/AJpx/LY+771/MT73oVo7yWkLuau8asx6VJAJzVyFEuyidlXI&#xA;pdirsVdirsVSXX/+Or5b/wC2jJ/3TrvFU6xV2KuxVKbrypoV1dzXcsD/AFi4YNO6TTR8mVFjBIR1&#xA;FeCKOnbFVL/Bvl//AHzN/wBJNz/1UxtXf4N8v/75m/6Sbn/qpjapX5p8paZD5c1KexMtvdQ28ksU&#xA;31i4fjwUsaAyUrQbYVTKPyZoQjUSRSmSg5lbm5AJpvQergtV3+DfL/8Avmb/AKSbn/qpjau/wb5f&#xA;/wB8zf8ASTc/9VMbVUg8p6DBPHMkEhkiYOnOed1DKaqeLuymh33GKpvirsVdirsVdirsVdir4O8/&#xA;y8PzE82vwS4dtV1CkpJDQ8LuRWUAleVVC+IFdsiTTAvQfyi/Mg6RNDZ3XrXGnKGjEc0wkSFSyD4Y&#xA;f2G+Bz1p8XzLWRyEMCN30rqImjh/vI4EZljEjniOUjBEUdBVnYKvicthKI5rOMjyeD/mf+Wf5g+c&#xA;PNFz+jzD9R06ERwPczCIzMUWR44Rv+0acmotagtts5ZAnZjjxmt3kur6X5o8v6xa6PfxG1vrR1ZL&#xA;dwBXcsrLIAUdeo5BiMp4L5c0kVzfS3lxbi80GxurpT9YmhV5OQ4kkjqRQdc2eOZMRbgyjukvmnzx&#xA;5b0C3maWYT3cZKLaRn4mcVBXkRx+Eg8vDBPURjzO6xxkvV7PzJo0OmaW97dw2Ul7aLcQQzSBCyJG&#xA;ryceXHlwDb5rSb3dpEUEbput6PqbSrp95DdNBx9ZYnDMnOvHkBuOVDT5HwwJRuKuxV2KuxVJdf8A&#xA;+Or5b/7aMn/dOu8VTrFXYq7FXYq7FXYqlnmn/lGNX/5grj/k02KpnirsVdirsVdirsVdirsVdirs&#xA;Vdir421q9022/MjzBb3LIbd9dvZJ4uCyM4N3IJhRxx5GNqA1p09zmOZG+rUea86t+XsVxJBps8CR&#xA;3KxtJPMkUrxSRqQyxepKAFepYmuxO3SmWe5lTPNG/OTR7Ty+bK+1GK/FvxlslkeNWJj4zRhnDyHl&#xA;HMKKadgdjthiDW5ZApJpXmjSZYrO6uNdv4y8kjQRm8bhLxIZ1JrzZVBC7OKD3JJRIc6VFai+g+ab&#xA;RY9Q1SQ3DxSi0vRdyXSW4mchpFiaSjI5iCuFXYA0BYYRI9EHzTKTXvNGhaLfLYeY7TW7e3s5gltc&#xA;W0tvNGFibjLFcyK1XVgtEYmtae+WQnMdWHBEvnG51ueSes4kDOSUL8XlFTRvjAT9oGnw5A87C8L7&#xA;OuVtW0byfc3Hl641zhpY9K4tfU9S3d4oP5CopIB1rWq7ZJtVPIur+X4fMF1pej+VtQ0qabgl/dTo&#xA;wRREkjwGXmzMvIE8aivxb4qznUrbVJljFhepZlSfULwiblXp1ZKUwKgP0b5q/wCr3D/0hD/qrirv&#xA;0b5q/wCr3D/0hD/qrirv0b5q/wCr3D/0hD/qriqTT6b5ot/NOiz6nrMd9p8l+621ktqsJjYaddVf&#xA;1AxJrv8ACa+Ne2Ks0xV2KoSXWNIikaKW+t45UNHRpUDA+BBO2Krf07on/Vwtv+R0f9cVbj1nSJHW&#xA;OO+t3kchURZUJJOwAAOKoi4ube2iM1xKkMK0DSSMFUFiFFSaDcmmKoG61Py7d2s1rcX1s8E6NFKn&#xA;roKo4KsKhgRUHtiqr+ndE/6uFt/yOj/riqItry0ukL208c6KeLNEwcBqA0JUnehxVQbW9GR2Rr+2&#xA;V0Yo6mVAQymjAiuxBFDirX6d0T/q4W3/ACOj/riq6HV9JmlSGG9gkmkqEjSVGZiAWNADU7AnFUXi&#xA;rsVdirsVdirsVfEH5kaT6vnTzI9tBfmc6xqDPxtSYyGuGHwN6nI1rXsD4bZjeJESNkMLHex2x8na&#xA;ybieVFaKH7USqJo+xQAAx15UO7fPrgOpgPNTIIy48kumnUiWdSQqkhZXqwA3ZAlSpJ60FPDIR1aT&#xA;II60tdUFlpVqllcxXGlnU2luOBVWF2gW3MbV5fC6ktUAgeOXnPDvUFPJLCWfS7Zfqkn12KC7ilZo&#xA;1IZ55bp4zUkk0W5UVI2INOgweLDvDIe9IU8u3k0TQNbywKCnB2gYH7LEhnVATXl3PUfLKzqQGMzv&#xA;stu/y1t5iDBdSiSR1ciZWSIjuCKF1+FuvsRxwR1QuioIfa/lSJ4vK+jxOKPHY2ysNjQiFQem2ZYO&#xA;zJNMKuxV2KuxV2KpLr//AB1fLf8A20ZP+6dd4qnWKuxVKrA/vrob73Eu30rhQtu9Stpbm50i1ukj&#xA;1lLX6zHCxIIVyyRydDyUOnxUrTavUVlwHh4ui3vTrlrltPiNyiRz/WbUOsbF0/3pj6MVQn/gciqJ&#xA;1r/eJP8AmItf+omPAlVRvhJJ2Bbc/M4UJZa6odTisdU0WaG80q5jLOxdlJBK8WQcG+JaMCjcd9ju&#xA;MlOBiaPMKCCLRumf706l/wAxK/8AUNDkEoPQTS1kG/8AvZqG3/R7LhQqXepW0tzc6Ra3SR6ylr9Z&#xA;jhYkEK5ZI5Oh5KHT4qVptXqKy4Dw8XRb3pzNctNpRuURJ/rDc1jYulfq032WIU0+YyKpvgS7FXYq&#xA;7FXYq7FXzX5q8pec5/NOtTwaPfSW819cvBIkLlWRpWKspANQQds0+XDIyO3VxZCVlLE8l+fDSmi3&#xA;69vigf29sh4Eu4oqXcvPkzz2eui3u53Jgf8ACgweBPuKal3Lv8G+eR8P6Hv6U/5Z5P6Y+DPuK1Lu&#xA;Wf4N89V20S+G9a+g/wAvDD4E+4oqTY8o+fgTTRr+g7fV5OvtQY+BPuKal3OPlPz8o20bUD1BUwSk&#xA;fgMIxT7ivq7n0voaSx6Lp6TKUlS2hWRGFGDCMAgjxBzcQ5BygjckrsVdirsVdiqS6/8A8dXy3/20&#xA;ZP8AunXeKp1irsVSaGZ4ReypE8zJNOywpxDORxIVS7ItT0HIge+JTEWQCa8/7N3mOgeWfP1j5gl8&#xA;2Xlosms30jLdWizrxWAkfu+RkcU6BRvx4rTMaXaOrP7vwo+EKo2L8+u3y6lu7cxYBlhLSGUhEeq9&#xA;uL/Yj+3ps9Ru35WanwurUA/9HEWZTQiNa/3iT/mItf8AqJjwKxX8yIPM2oaAdI0G29R7+Qx31wzr&#xA;GsVsCS4qZI3JfZaAMCvIHqMjPNPH6oR4pD3fpdl2XHTGZOolUQNgOZPyI+7ekL5A0nW/Lto+iXEN&#xA;dLtwWtLkyKSWLfEvAMxHMlm8Aa+OVYtXqM54s0IwNdP7TfvdHixyhkmNzjMiYknp0HTp5De+9mem&#xA;f706l/zEr/1DQ5e5SWWE9xBpF5NbQG5uEuNSaG2DBPUcXcpVObbLyO1T0xLKEQZAE0L59zzrQPLP&#xA;n6x8wS+bLy0WTWb6RlurRZ14rASP3fIyOKdAo348VpmNLtHVn934UfCFUbF+fXb5dS29uYsAywlp&#xA;DKQiPVe3F/sR/b02epStyuNLP/Ly/wD1DzZlOOmuBLsVdirsVdirsVeSal5u8yWq+Ykh8wSS6vp2&#xA;oi20fSTBaSNcxkIeBijhWZvtmrKw6ZrjmkL9W4O3J6nFocMvDvHUJwuUrl6ee9mVfAs21DV9Un1D&#xA;SdFgYWV5ewG61CVQHaGNAOSR8gV5M548iNsyJZJExiNidy8hqJ1kGOB79/IfrViXg1lLJdeBEsMi&#xA;tZyvAblZGCmOWIFKmgB2YEe2SB4ZgcV+RY3U64unLa3lUf5la5D5KfUj5qNx5rS9kgtNEaGzYXIj&#xA;uREEaGGBZhyQ1qHG+b78rE5K4fRXPfbb3rxkDnu9g1a31rUNEWLT7ttG1GY27PcKsUzwoJUa4RRK&#xA;kkbMYg6KWQiprmpPNyGB6PeecL3V/N9s3mq4ii8t3tuts88Fh6TwfV0nlW5KWqtRqt8SFSMCsjtv&#xA;zP8ALV1PJb2yXU1wLM6lawrCedzaKVDSwKSK8eYPBuL0/ZxVTsPzS0LVNLutQ0e2utQitbEag/pL&#xA;HTixYLEWL8VlPpklG+JRuRiqbeSfMFx5h8qaVrNxbNaT39pBcSREUXlLEshMfxMeFW+Gu+Kp3irs&#xA;VdirsVSXX/8Ajq+W/wDtoyf9067xVOsVU7q5itbaa5mqIoEaSQqpY8UHI0VQWJoOgxV5+/5g6IY2&#xA;ktpwFuJjLDOzWxVkkXkBwkubdwfh7+BwoUJ/P1ujW4aUslyZkinjhtpIg1vxEoeRb5kQqZF+0Rua&#xA;d8UojTvP+k3t5b6K5dby4uojBLIsEMTelLE7Kp+sTF27DjWv0HFDJvN2tafpllALqTjJPcQ+hHUL&#xA;z9KZJH+Jysa0RSaswGAJY7ced7FrmQQXlvGAamJ59Od1qK/ERqCfMbYVQknnu0Q3YluUiksXljuY&#xA;ZEtI5A0P94Fja/DvQinwg17Yqyfyt5j0rVLTUNSt5QsJkFw0TMjSpEIVQO6RtIVDGFuPiBUYqx62&#xA;866QLErb3UI9S6uZYppJrIK8dxcSTR0inuraUFlYEcl+g9cULJ/PFvG9ur3UdLlpI4ZVFm0ReIKX&#xA;VpRqBRWHqLszDqPHFKK0jz1o19rFnpjXCfWLe4q85e2SEmWFo440ZLicSO7yqAEJr9BxQz3Al2Ku&#xA;xV2KuxV2KvPG/LvWLxdce7e2tL66v/0pot9bSySSW06qqqG5RR/CQnxUO/hmF+Wkburuw74dqY4e&#xA;GI8UoxhwTBAqQ+Z+Cbz6F5muJdM1uQ2kXmGwUw3EUckjW1xEwHMcmjV4yWqV+E08Tk5YpkiW3EPt&#xA;ee1uGJyieEnb+dtt3bX8/sV20rW7nzJb61JBBB9TtZYY7czM3qSSbirCP4Vr3oT7ZIQkcgkdgGnw&#xA;5HIJnagwxPy688H8vrryfLDpDC9uJZZL9rm4k9NZpvVqkJtVq61+E8xm6/M4/FE/Vt5D9bPglw1s&#xA;9N0ewOnaTZaeZmuDZ28VuZ3+1J6SBObbndqVOa+cuKRPe2gUwnTPIvmB73z0mq/VItO83VEL2s8s&#xA;k0INr9VPJWhhXcfFs2345FKn5V8s/mFpGn+jNa6D9d062a2sLqASQm8cKqRy3Tei7RKFqzrHUs3g&#xA;MKqflr8vPM/l+fWNPtLi2m8va7bNNdLLLIJ4dUmjKXMsKLCIzDKaHjyWnYDpgVlH5f6XrekeTtJ0&#xA;jWUt0vNNtYbMfVZHljZLeJYlcs6RGr8ORHHatN+uKpi+h2TuzmS7BYkkLeXaip32AlAH0Yq1+gLH&#xA;/ft5/wBJt5/1VxV36Asf9+3n/Sbef9VcVd+gLH/ft5/0m3n/AFVxVj9x5V0fSvMujahaLN9bvdRk&#xA;+syS3E0oamnXdPgd2Wop9qnL3xVmOKoHW0vJNLnjtIY7iWQKjQyhWVo2YLKOLFVY+mWoGIBOx2xV&#xA;gVv5b81y3SC40DSIoYZeIufqlq0kkMjFXbh6jCNljK7Bm5UNeowoVrK08822k6Zz8s6dNeulwNWt&#xA;EFvDCkjSxSRvEwZuStwJaoqWAO1BilTsrjzWdTCp+X1lbGydBFcepbqUU/ZaJwoWoWlQjbHbFUf5&#xA;3Hmiadhb+XbTW7aGRktY51H929ty9bmZP2bgUKenXiKg8qYql9roFzFq3pt5Q042srXB+sJbhfii&#xA;/wB5SwaQ8BJSrEA8fhFD9pVCGuZvMSmO3vfy+h1BJpnR7yORIwGeQyB2g/0gqGeZyW9WldyVrspT&#xA;Dyi+t28q6a/kaHTNPvSsN/cwzRrGIxASxMRBZx6lVAJGzd6bqofUfLetjUohZeUNHmt3uGia5nt4&#xA;WMEX1hUFwazhrjla8mK0Rg9Ou+KojStM85RrexXPl3SYES09bTfRt43U3TskkkEnK6B6xoOQADMv&#xA;IkcVDKory/pt8+swi/8AJFhpscNT+l4ntncvGx9NlRR6qcqct2aleppUqs5wK7FXYq7FXYq7FXYq&#xA;kfnDzbY+WNJN9coZ5pGEVnaIaNLKQTx5b8VABZm7DxNAa8mQQFlv0+nllmIx5l5Bd/mn57uZzKl+&#xA;lih+zb20ELIo/wBadJXJ96j5DNZLXTJ2elxdhYgPUSSj9K/OnzNGTpt1bW97dMoMeokGIRVJANxG&#xA;nwycv2eBTpv45bDXbbjd0Xa+lhpT6Td9EUfOnnIsX/SzKxNeCwW/pjetADGz8f8AZ198j+cnbzn5&#xA;ybMfJnnt9Wuf0ZqcccGpcS8EkVRDOq/a4qxZkdepUk7bg9QM3DnE/e5mDOJ+9mOXuQ7FXYq7FXYq&#xA;7FXYqkuv/wDHV8t/9tGT/unXeKp1irsVS2LWjN6jQWNxLHHLLD6imAAtDI0b0DSq1OSHtiq/9J3P&#xA;/Vtuf+Ctv+q2KuTVWNxBDLZTw/WGKJI5hK8gjPvwkduiHtiqrqGoR2SRM0bytPIIY44+PIswJ/bZ&#xA;F6Ke+KqX6Tuf+rbc/wDBW3/VbFXfpO5/6ttz/wAFbf8AVbFVXT9QS9SUrG8LQSGGSOTjyDAA/sM6&#xA;9GHfFVBdXdy/pWFxIiSSR8wYACY3KMRylU0qvcYqu/Sdz/1bbn/grb/qtirS6xS5treazngN05ii&#xA;dzCV5rG8tDwkc/ZjPbFUwxV2KuxV2KuxV2KuxV4z+dktw3mXToXr9Xisme322LySkTb+wjjzW9oE&#xA;7Do9H2BGNyP8TzTUtUttPhEk1WZzxiiTd3PXatBt3J2zD0+nnllwxd7qNTDDHikhNF1WWeCeZokR&#xA;5Zm5oGLUoAqitF/ZA7Zk5tBwSoncPnPavaBnnkSGZ6bqkV0ojb4Z1HxKdwadSDlU8Ri6WweScaS7&#xA;x67pMkbFZFvrZVYdaSSrE4/2Ubsp9jk9MfWHI0x9YeleYfO/6H1Yaati1yxt1uPXD8Y15S+nxkPF&#xA;uNFq5O+wrSlSNw7hGeVPM48wWtzOLOS0FvMYQJNw4Cq3JWoP5qU7YFTvFXYq7FXYq7FUl1//AI6v&#xA;lv8A7aMn/dOu8VTrFXYqkmg/7zSbf8fmob/9HsmFCjPr+lXus33laG5MerxWYuWZRy9NZCUBqp2d&#xA;CUbiabMtK9rDhkIcf8JNI4hdIoi5WbS1uZElmFy4aSNSin/R5qfCWcj/AILK2S7Xvt6X/wAxqf8A&#xA;JuTAq3V9ZstF0O51W+JS1soTLIAV5NQbIvIqC7tRVFdyRlmPGZyERzLEmha2zla8lt9VsLtZNMvI&#xA;InWJo2+NWBdJEYsvEsrioKdhkZRMSQeYSDapoP8Aeap/zGv/AMm48il2mV9N6Cv+kXfy/wB6XwoQ&#xA;c+v6Ve6zfeVobkx6vFZi5ZlHL01kJQGqnZ0JRuJpsy0r2sOGQhx/wk0jiF0qXK3C3ehLcSLLMLxw&#xA;8iKUVv8AQ7nfiS1PvytKe4EuxV2KuxV2KuxV2KsR/MfyS/mbTYWs3WPVbBme0aQkI6yUEsTkA0D8&#xA;VNabEDtXKM+EZI05mh1hwT4hy6vl/wA1Wmp23mK6tNQtZbW5suMBgkG61USMQVLKQ3MfEpoQBmf2&#xA;TpvDxknmS5XaOtjmnYPpAUNMlurOVn9IvbSUMiDZwwFAyg9fA5fq9DLJ6o83nddiE94/UnsGvafD&#xA;NHMJiHRg3Di/MjuOFOW/yzUz00zYMS6mGGYlye5+RPJmo/pGLWtVhNrHbAtYWklPVZ3Ur60q/sUR&#xA;iFQ71NTQgZXptPw7nm7bTafh3PNP/M2i+bru9S50LVlsaJGnCQFkXi0hlYR0ZHaQOm7D4eG32jTL&#xA;cxJbby/+bBkE1zr1v6oorcV4oQjOA6xiMqOSv3r25cuK4VZ1cG8SAfVkjnnFBSVzEp8TyVJP+I4F&#xA;Qnr+Y/8Alhs/+kuX/smxV3r+Y/8Alhs/+kuX/smxV3r+Y/8Alhs/+kuX/smxV3r+Y/8Alhs/+kuX&#xA;/smxVK0s/N195gtp9SisbbStOuDcWvoSSyXDsbWWAq3JETjWcty2O1OP7WKslxV2Ksf0t5o9OuHg&#xA;RXnF1qPpJIxRGf65LxDMFcqCepCmnhiUwAsXy/Hu+9gGifl15o0vUDrj31pN5hnmeW6nPIREOalR&#xA;xjU/EWblQD8Mw5ZteZGPFAYtqH6/T+lv7dOHPlhPTR4PDH8V79O89NvjzekM/K6049vrT0/6Rpcz&#xA;XHXa99vS/wDmNT/k3JgViX5geU9a81HTbBLiC30K3b1b5WYmaWSnFQo9JgvFOXxc/wBrpsMpz5NR&#xA;GJOAxE+hl/YXaaDPpceOfixM5yFDuH+yHP3dOe6Y+TtM1XSLT9H3csElrG6/UVhrVVJJZWBVQBuC&#xA;Ke+HFLPKzmIlLy/sDoNJgliiYn6enx52nmg/3mqf8xr/APJuPLXLQ6Ndrpt0bP0/rnqXwtvXJEXq&#xA;eu/D1ONW48qVp2xPkyx8PEOL6b3rnTz3RPy680aXqB1x760m8wzzPLdTnkIiHNSo4xqfiLNyoB+G&#xA;Ycs2vMjHigMW1D9fp/S3dunDnywnpo8Hhj+K9+neem3x5vQ7tuV7oZ6/6bJ/1B3OZrjJ5gS7FXYq&#xA;7FXYq7FXYq7FXjv53+QtRu7mPzPpUDXHCJYNTtol5ScUJMc6qoq9A3F+4AU9AaZ+i1AgeE8i1zjb&#xA;xZZEdeSsGXxBqM24ILQzf8rPIl/5k1y0v5ISug2MqTz3Lj4JmibksMVRR6uvx02C1HUjMDWakCPC&#xA;OZbYQ6vpTNQ3OxV2KuxV2KuxV2KuxV2KuxVDandy2em3d5FAbmW2hkmjtlNGkZELBATWhYimKvNY&#xA;vN+oGI2qabq9rI0s9zVdNVt55HmkjV5p05BS2x9NSaDbemFDptf8yIYn9HVDavG8kgNjCtypSV4l&#xA;Hoc/i5+nyAD8qEVWu2Konyl5p1nUNWtLa70+9WBbyYRyTWvpyKFgkUPP8arEhrtTm3LbpuFU+8+a&#xA;8NLk0kPFIY3neYzxxmfgYYzRWiVkajep9qoVaVY4hLGoPN0t1cAJc6jb+pJ6aIdPh+Fi4HHiJncc&#xA;ea/a3+nFCFl85atZCSWb65JNE7fVkW2geGYJI0a8pFkVowzI1QVBpuNt8VZZ5U8xetous3/oSPc2&#xA;8ktxLDw9FXYRAqsTOzVBVB8Rp1xKscPnwtCkapfWryPJcVSxUlfVZpXjDTTJz4cuojBIoQKHdVbc&#xA;+ZtTjEEkdxfTWsiyGWlnCkyenKsIpC7qX5OwHwmvtscVVvLvnGbUNd06zuFuJIYryQ2srW4WRibd&#xA;4wZeL8Y0/esQfiJoPHZV6dgS7FXYq7FXYq7FXYq7FXYqld15V8r3d013d6PY3F05Be4ltoXkJHQl&#xA;2UthEiqaABQABQDYAdAMCuxV2KuxV2KuxV2KuxV2KuxV2KtMKqR0qKV/2sVeen8tPNp0qCyPne/+&#xA;sQRlBfgSiRviLAuonox36nem3ToVTfUPLXnY3k1xpXmn6rDKxkFlLaJcIGZgaCSR2dV4igVdh4YF&#xA;XeUtG8/Wc63HmXzDHqSvEyyWMNtFHEknwUeOVVjkP2W2Yfte1cVV/MmjeZ77VLO40rUhZ2cKMt1b&#xA;lnHrFiNvhB4/DUch8Q7Yqlln5W87x2c8dxrpkkdozEOcp2SOVW/eUDqOckb0HX06E/EaFChLoP5r&#xA;yyhX163EUbJIhRVTl8NHjcrCCd9wfD3oQpZF5bsvNVs1yNdv4L2NuH1QQpwKULc+TEDlUcaeHieu&#xA;BUu1/wAvebr3VZrjT9X+qWLQ8I7XnKKycCA5KUK8XIb4T8XGh2Jwqonyz51+oW6x66Y76OUu0rM8&#xA;ihDGi8SpAElXVm+JduVN6bqp55bs/MNraSrrl8t/dNJyjkRVQKnEDjRUj7gnp3wKm2KuxV2KuxV2&#xA;KuxV/9k=</xapGImg:image>
+ </rdf:li>
+ </rdf:Alt>
+ </xap:Thumbnails>
+ </rdf:Description>
+ <rdf:Description rdf:about=""
+ xmlns:xapMM="http://ns.adobe.com/xap/1.0/mm/"
+ xmlns:stRef="http://ns.adobe.com/xap/1.0/sType/ResourceRef#">
+ <xapMM:DocumentID>uuid:856DC46CA2E8E61197A7F8FF6900583D</xapMM:DocumentID>
+ <xapMM:InstanceID>uuid:12e58ac3-8f78-412c-8871-939a3574f34a</xapMM:InstanceID>
+ <xapMM:DerivedFrom rdf:parseType="Resource">
+ <stRef:instanceID>uuid:846DC46CA2E8E61197A7F8FF6900583D</stRef:instanceID>
+ <stRef:documentID>uuid:9C3FF37FE0E4E611B98DC6AFDF0978C8</stRef:documentID>
+ </xapMM:DerivedFrom>
+ </rdf:Description>
+ <rdf:Description rdf:about=""
+ xmlns:xapTPg="http://ns.adobe.com/xap/1.0/t/pg/"
+ xmlns:stDim="http://ns.adobe.com/xap/1.0/sType/Dimensions#"
+ xmlns:xapG="http://ns.adobe.com/xap/1.0/g/">
+ <xapTPg:NPages>1</xapTPg:NPages>
+ <xapTPg:HasVisibleTransparency>False</xapTPg:HasVisibleTransparency>
+ <xapTPg:HasVisibleOverprint>True</xapTPg:HasVisibleOverprint>
+ <xapTPg:MaxPageSize rdf:parseType="Resource">
+ <stDim:w>792.000000</stDim:w>
+ <stDim:h>612.000000</stDim:h>
+ <stDim:unit>Points</stDim:unit>
+ </xapTPg:MaxPageSize>
+ <xapTPg:PlateNames>
+ <rdf:Seq>
+ <rdf:li>Cyan</rdf:li>
+ <rdf:li>Magenta</rdf:li>
+ <rdf:li>Yellow</rdf:li>
+ <rdf:li>Black</rdf:li>
+ </rdf:Seq>
+ </xapTPg:PlateNames>
+ <xapTPg:SwatchGroups>
+ <rdf:Seq>
+ <rdf:li rdf:parseType="Resource">
+ <xapG:groupName>Default Swatch Group</xapG:groupName>
+ <xapG:groupType>0</xapG:groupType>
+ </rdf:li>
+ </rdf:Seq>
+ </xapTPg:SwatchGroups>
+ </rdf:Description>
+ <rdf:Description rdf:about=""
+ xmlns:pdf="http://ns.adobe.com/pdf/1.3/">
+ <pdf:Producer>Adobe PDF library 8.00</pdf:Producer>
+ </rdf:Description>
+ </rdf:RDF>
+</x:xmpmeta>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+<?xpacket end="w"?>
+endstream endobj 2 0 obj <</Count 1/Type/Pages/Kids[5 0 R]>> endobj 71 0 obj <</Intent 72 0 R/Usage 73 0 R/Name(Layer 1)/Type/OCG>> endobj 72 0 obj [/View/Design] endobj 73 0 obj <</CreatorInfo<</Subtype/Artwork/Creator(Adobe Illustrator 13.0)>>>> endobj 70 0 obj [71 0 R] endobj 5 0 obj <</Parent 2 0 R/Contents 263 0 R/BleedBox[0.0 0.0 792.0 612.0]/PieceInfo<</Illustrator 6 0 R>>/ArtBox[24.0 31.7139 765.863 580.024]/MediaBox[0.0 0.0 792.0 612.0]/Thumb 267 0 R/TrimBox[0.0 0.0 792.0 612.0]/Resources<</XObject<</Im10 174 0 R/Im0 76 0 R/Im1 78 0 R/Im2 174 0 R/Im3 174 0 R/Im4 174 0 R/Im5 174 0 R/Im6 174 0 R/Im7 174 0 R/Im8 174 0 R/Im9 174 0 R>>/ProcSet[/PDF/ImageC]/Properties<</MC0 71 0 R>>/ExtGState<</GS0 74 0 R/GS1 253 0 R>>>>/Type/Page/LastModified(D:20170201092100-07'00')>> endobj 263 0 obj <</Length 133764/Filter/FlateDecode>>stream
+HlWI$)jZ!>$J? _a>ٗ?=k8~,s13oǿ!zӶGH-9oŔo/_ ]He_B=#3T"cegYwEp'?QQYK~jy#x3v\^x<# jFzqtZZKB4^?V`K&||2xstzWлɫeHL=Ǚ /3Uh3ha[<6r&32wG#?yaZI8!tuY;
+c]%ڞJ|&3iq{C= JgC շ;$&Tgp}<vItxD/HVf:\aJ(&<cH"Л pj >"DԮʐps:6 o
+aҊ`q$(@Ex(&y浕D1K@x+RF6GS2fhpK l*XhSM
+VD
+fBYmnP% ~{ 8C+|Hz,Ze&ҥ!}mf ;;~\Uڲ ő\: Ȭ$`X /S;
+
+L+ XAL6T.s>
+'SE(PQ`Aj=X-Mݾ]ZSv
+ GSb!1eD~n)cPwc4d2v%(t?.0
+2{ k
+&F/<QQT*,5N>Q c(fI<9-tM|ҭ5ymIWɣ M.W-m H?-xlhNpŋZ&Ƌ^Ԍ
+$FDܼ2밅N҂R!R#c?,.ҩn**W)4in+4*Pm%NPklUf\pd/?{.${[(.甧Q1aP9[Hksr L疹&'{ H0p@!<f*5]-' oę2[$Sg<'ۦQY~[&5."E$j_s&gBy%]xh%/p-)ϓEM<&Ԥ,*L؅T6T)>]7`
+ʴMi/(Fbr\kE}A;=V=&JF1QAM!88VE`K >FȱܜFi0ipu7zkF .e)FJkaɊyA h)KbpivNTzɟe^Ui΃?;'ŠTPTl AmK]J_zdu{gM0E+#p-\?.lݺ+%h,p
+Ͱk5Mɍ%t36Wm $t +uCS!OI5"MӠB_OxbMwWE UřX?Ur$ 
+a "4zQ@)~v'PGV5ziRBw@vWHQ R<*!۳g%RBN>Qc[<0&Њ҄&.z:Wu3,DF!jYA6yU[ZVqgWҹ41 oM(+I<(˚<'c+=/D#FѹiVH1|h _?< Y 3{ VnΟB7I垏qBFrUww%7V6MtvLOfe0كm,+x~gڶ$׺&t=(f}_Rh..fL FX< 8jVO$jһ^Z{)66JD_uUMslUX58MiRkH$bW;@ r`f%\}#,Vlh"i/nuB9uzF蛿itT'SL\nGDEĞr'U,#BȚDk[&̉2:`5Hy(":Sn1PQCfU8; UiZvvfT,hEr8{Z3wȏfDbz8-䴞ÜQ 8ƲdRć/ɮ aO#R)EO[
+>; #:32$_pnuYqf=\9 h=~MK]C8!ds)-&u0QDiLE|pXB{xhM|+-QqYRJoͅ<WwŠva oi 0$)WjmSҫ
+R~!mLXurVQŋΕ$I 2m#0]fK c1eܭG k*EĐ0F@VԳbH<t7&Zʑ|n735L{g;>FBZTbr@4|x_7WgبGfRPR΂T-TUlf9m8dkcT%
++|;lCkwzu$Cj鲞'Y~9$b4 Wz0~yz'w{p⿢汞'R'ڂ&9Kvpce5IXbOۇenK%ִO-VaRD6ڶ58[}f |Y}cy%9<?!)l0yJtx>-,t; %bۗ (̖{2E@%BWf u:mx,V Ӛ@+*hE]Ihys/&Y<iCвb%6mG"?͈ܲ=変 (JxkRB9^aA~̗B3br=/D#FϹҊY _D~8< YkWI)OԶdS O"H@x˖Tf\(7\?Kҽ-nlbۼng.`W@ܬ8`_njM80-Om}.ٯ&{[.~}Ņyo-pT$H~&+BWۣʹy/
+5f.ʨ[f4ɥF-[ -2S3@H0VjN UMutlF. Ԣ^KYOX_xLw`S/'!󒻻-HRӼ/)S\;?(*~Fz# SȼKK~rCqnt <C.н !GMr)2EZl`]B*Q:R;‰ePd4!zJ:\Y5ء$Hw6wgHQj?Tn=_ X=#&8S`gu`Xa ƹ΁N@>d{q)$ƽ0.F-x
+r숍Jglgpc kRۮDG2`!f=QJcɡ(6j
+m%ayr$7 loGFBBH{ɮQsRQll{#T N`D܃#;8Am¡cPzӵ0x3q?M|9zT× -K)ҏ]1C܆Mi]H0ǍG;'#%L/[ s1Ls0pilQFd$u=)ba*6*Rgۗ
+bQ2oc4s {\BF7
+M0aؿ<~mGeIFTGEx :ě/c4G~_CJܦKtSG#7ClЫ $/"o/&+zԷ^;8E7aEV\aR< UfhSV@S)9IR
+tQ\]NY.}bJ󿶝dX'Uxӌ=w1zթAh}'n
+`èxa5r&Vi(5J^jy2zD˵/WSJ^9J@SZ1zi"f㻟AX4y Βq\FZϠRsmXrb(ÙM&̂o>$2`Je2"6y:,Lb5z*BZ2jsUZ]שq%ɑw' ]TQىK~6/+×flzM^MN=Y=R1,PNM~f
+
+4W B4نaX;`jƗf/V)!{9qk_!}VUA\qLPd|Q$3Ek0d&F&2p2Kѵ`gA€8|Jzn~+CPMZw֌BCCX-SCVcʤ(TV[t]QVJIJ <\wV-9%][2c)AJT!u ]$XnIٝnk{Hzz8!ʺKɧGE ," sfP>A
+jxy~ k-7tW -=5a  V?%Kr\ZEl Hzz?
+b$)r++)zoJ9e-EZ? T^A?"6{("K
+">\߈3%x/ŶsRL;%#Zcَ>E1Јr
+[>!_aL?m7oԞ1|#
+%2. s 6V o8bQ$ݏ}u`6្4jy9 bC1gEیl=(L|G{[,(Xe@HŵB+8 V@*,ld2w;7l$Qn0H3󦵿$2 +3WBciJrAЊb;-țϜv@mq v/3L
+w8Wh$~ɝꁢ[(=B- MlED- 3UE Iy㨮/J1T-j=OD2)V<gV=hв=6xDzZهm`b>Ňl(fA5yhmuxuD_7﫧ǯo/]Yj>9n]1Dޚ
+Ƒ«|MCٺzT&ηSi5"C^kqO2m1!h v&4=UAo̎+aT N8O`}E:Rvȝ:mnt10u$u:0&A,g9t$94CQ h^<נQ ՚;Vk4:~j / Dy"uNzaQ*{?A[Vcʽc
+m]f XtInq|T-l!6=p5'epWb肋vkM5Qa{yJPi%$HЏ΂ߥ,ŭ}GxdR $O{UC@:M Iěr7Z?^i]zMZBfMYTr @uͶ{?
+}5tm#CbVX&iώ$kt)8mĭDv+5L<ŝVT˶eXXj.e]zC!
+V>Z _ ă5i;?w,GC躟ey;DMf'l-yv)[{Trtxaza]c !EV⺌ǂ?р6,"@Mdh7}1?'"<EnldaTmٮnr*:oakE8|%UMe4OlD}OyEҞb .߰RaL:3񊷖eLjvriw*B[ |
+e";HZcIw͠n1ub\vy^2:W.2[{-N-EXPub7~xTۅ!M]ˠ\b 1?*wHT
+
+2%ImT4($Cp';$uiZPp2sGԤh(r @5i Bdz܃S2oGCgz%:+i"`
+iIc
+HTU#z U/O7;$@ @uY/Eed
+*F
+}lq6d<Gdv3#TW{ز7@-H[GLҰ)Y4i6/L5l֞Ji3I]&M,{84eMʹvԼjhQiR4>U&֘'"i˹5ufs v"0ܝ'5^8L}(L:5OśGNĔ695M-7E
+uxAe=
+*r~-J[OO//:oq %Ir7$zգTuB7#.T4עt>\խѴSL)?U'_?@:W@J+Ku $ bc*M?Aej1[{w!E7li0np9VdYD.fZ`Ш^}B}V5 n0)R2e@942xEn$U(:m1,k8cC;yOv\Sw_gQ^1<&W3|LJ޵y,3~
+qUqwܔgiؖf.c~p_ză[nA-35ש*臲l-0<33d<2ڸ
+FׅBOJ>
+P¥P8
+'yv?"asDkA!>#*wi"Jr9/tbР&ٚKn]MCIIfn'͠Z NP܂"O0d&CXA!3c"G(JP{c8 ,:4>mzshx.r';3,>}48N>UCqZPw;ѧI`a.z<Rb?=-Zu4Z_Rc)t\0O"mbG{r(4bcJ}R]{:ߤgSiki FkEZ(Ɖ % x$MY|9л~k &w`*"P[tB
+z)oA\4_ru(ݭr9k>;%ڣ/H]'[ UZc鏫w<~JQ%u-n/
+Bjc Rd)Hv5Cn$Ca6 v$=c;Y
+z *)|V#6yZNE=bT?ϾQB}G\5؁*/6j' D/ݪx쉐&en9z9:۲pTѤ旨@I2Ux8v:^J *b&jmI|
+~s1զn(^Rw#S>6+OT8/i7hhwlhTK,cUJ5Hm rYF/_0ˡa_.@
+j?_$%ӒoZ&_Xʿǂܫ~2PZa jZq)𻅳L}tn;:>6cLVgt^nobUi4WH$Hz= ÁL{~`,dƨ6 ދ/
+.\uӏ71Kﺄb@ ʿBSgc&4S1.@ԭ4tdg(SoYKEZ+h\=1TwQ,q`0zДSm8d23F@~S0z-$ͳtmU#Q>UM}VIj~"$w͌a⪾4u'DVP8YkDSjɬ:C֩.#1>xCJ*ٔfE@&%= :"v.}>)Nyj>$'z
+2u| (s#
+~sLl 靾aE\j2L!e|݊֐
+-{<H[ eg*NQA[AdgAc2j݋l,ߦQ&Ǜ)u*g58bql2S/S{:
+? _R$AXAICiZ怮fC뽇F4$+
+vom",8*[ߖ47 {H/);.(X(_i建CMʦ*Sm0L>MoJkw^v+}AJ4$0Z
+E0 &8B6*Gq\v\ Q$r.qr0%/v `khXѽ'Ywm)a[dJ2 ¥f=pש[}v.i=U{k'Yp8+N$į?4&O>TĨw!h~c@W7u7^U.Pn`n+RӸEa
+x~|UY~cG ϡyO[@5&8f%y T>N|8[_⇎Hv?o20vP^6]Dkk"L! orAPM=>r} p08^`gO_p&HsGn>OnsbJ`WzAs S-l)E6u5پ $i)VzTq[uZ
+gMMRÃJj9oMtTo6EٔP 4ǥ>4$݄teL&7?A$I]k$uW)^ JLaGAϛ, Q` 6՟>NKɚ|~غ
+!&xM!,#ڣsvZ ژ (@*V-v4 ѯqC-.ҤjDtzl7ӰX$C^S Ɔ00
+x嚵ppvt@dH
+*<  _4WhsC  6pt¢f.^(Ӥe8]:@`RxD6H(cb&X`KBtD_u_pZDn@i~bL^ C8~Ub%<N{oDEUfrg6`+|H%JbI<c,:r]Ih?n<.#trPGlKK;N򨑒F!z(ii`˔ Y0sa,s!&1D -ˤ7&6@em0,:Yk<LC7Ȣ@_2|oll4@5:Fbj߃ױtRwͮ= ;8?r`R}Cc>nR5Er;@oNeЈnáL@6} [plld3Kx-J&2-KNLwx2p#d|Alėm*;ySh*!RT5q%&s#lb}I;
+ʤX18eqa3v֍b?(e|n3N Qw~sBuT}=^?(4o/Ӟe_Dhyp^i2σh?:@1ד9,4x`A>(,#4d47;E~c (O*utW>$<xbX| sXvU&IY Wʙ0F."L
+s0
+&O9(bL<;t
+\+
+XyN팳>h5b
+ESMN0a)r`6
+uvjQcꄓӷNFw^'讪-a RpB .y7[/
+=
+i*]2ebу ᷷yփU-NyN'-:Džֻ'08Cl^Suj)-B˖n3EN衳S9:D/9v O^ڽիDmEt[inX;׻:Z(c٦.>n,3EcT%(Ḫ&!&)ʬGA|U+LF[ Tu, 4'Uk?]TJ[bJʹEE$/|gHdAx_K;\]fgER\"fy$WsMV?O{KrK5bY29e:pIZ@D.Q)W/"΍;D1%1SGS'dmS?tJ9I!fxe`M!*,u vd߰%}K'8`!{Iֳy
+7;b-޺x"<DVJ=WtoX띣&ՈCMLq.i
+tr+I|i>q4ĥf׶3
+,܄֘a'n]B I,uET$1Uh걑5ƩƪPU"Ϋik;Մj<e*32|2&e+[#AN6K6\T?DǾSo$}7=sPYSj gI y8ew %7J-,>~`| ǻmi2
+i\pDh'$<tEjNSld[](Si赦m6VKE8$fhku](<v^TmW UXEkk+|(dQXTyi;%![t/'zT{f'*ȗJ@"7JQau@')EjŶ6-;ܻAc8K
+}a/fsv@s;T=8PQQ>ѶoE=>(0TJ{o^l
+Tj8 ^$Mön]m`
+L{p5Ǐz'0eoj&!E˜Gwh1;m=B9QWBE-s!Uw)E0(o_Q+ 3k N72ύsa(G| ?Fn䙎}0{r9?HDњ&[?AvJH
+>,ꆢ_>M)ȫԩ4oΠά\Osg"YDs*G10 Oć⑃/ akQQQl}vxF.S`ֆn;?Uapݳ?qA%e-fP;n2 ?QL=
+<uء)pո
+  Yϥ1~,JבT8}ԥJ3t[ts.nה U/y`I' .[gHU8!yԒq{.#/2(~7Ǚ"C*B'Mu/F#=MF
+:!Z?khlCTE4;:(Qn`cžD^zg.F|~Mwl D~eԪU" h;r32!
+Z(0oQho't{m#zd3OU~o9KDI;O7ZQKsq.)*7s>4<x;89+4:9* OjJȓ;H1-
+bbv[ėD 6mR;pP8 VhKJTI \1#|F[+qQm% -uA<(beG’f(ː%6:))z IVA;vnҊ0组".ïx[ @Bw񮑺TUixܬY
+5 D&yD0>xQ
+ծ+!sP~$I]mTSPfЫ"Fոsj9Q7B*fS TfD]p&/A 0>
+˽鴝8ʹ:echowr<Fx<bjN=30pjjz)=5Erh|ة f[gPI8Flwr=ls/M
+(Z@*MgZslLO}juVQ*ڶGW#ƌU ̠N.j?zjQ0}b@֫&#0-X bGe ȬU9%_"E_K<|$?G:Gm[}>:hQ897awx
+Ps?Hac>K:Fj^]gQu>uU?g8np}µJtvMB$MލJ`qsjMÇĚDDp,Vhz%:V $qRyFzIϵ#pHGi@&qЖsp2Zo/dd(fi n37zϚ~J-nл6󷑇aRR.(Ðoٱ
+0m5(>˂ 1_P^^ޑv,X갪x+RH'N1EL%K`Z)ERvHLe%S0rԫ
+<2 I༈xE;'م7H~T5vI_(`JsRD:Ѣ_uTJoڼ B&u".TQan1\ U:uٶNO.)^t]Rw,*dFcڽ+]Ev
+R# vF!w ^פ7%SdgK2Q X
+mOQT;f_\zj8IT]Q"=,;
+]c7RZK{Oo]FHH{ֳnrJ CTO VhGc|-IITB ɐ6*r{}Q0E o0|$*[>K= BhN ER]1itfGw`|i
+R_#n(6o>@(]IqR-'`SGsnNǤ-II
+;nVQS,!b}i)3J'R|KW6 8~5
+.ҩ~U4Z\4%ā)"5Sߺ٫jgyTh!Y d5gu'Lb=2٭1Tt=@#@;(~YghP\\K̙&#Q\dvZg~.{*m[SmxtPZX`]bZ5ӞSlU}ה 厃*C?.aS<J"`x,y(n__2EQP?NV g0ʰQYN^u~JLƍ*kOF=vnk&_fW+Fq{܇zH|D+ \WX#!o~|b1Ƣ&& {0Itׄ6}0r I):6e#+
+`5>)
+3vlMIuؗCdA>5, X&tTMnsuXf{5`APEE1SdpM"@u;}Ի
+[Ռ=*
+l&zEыqWVS$sBv)0B?1mu4nӲ0wvV"3~<3 s/<cA]"zk rDe*iّY0rV`tKBؔR R';}P<c+iKU,<W7uVkݼZnDz3 z/JSw]2 P,M _",o4}p082ͩh|#'Q|/nوOGK+?<>x^oBӍB09/pw
+izjs,e*tX[qi( b Jh(03_`;ikC{", 俣KM%T<ݯ"FQWݐOܓ%+3?^6yC#aV:V UFI'T
+| ٟ`|h´јFfsS4D' t| -VG
+]yE\CK8Fqߑvȧ U\/X׶mrSBΛ&y|[y $--HCAr8ay\ y;\6e+X8ÊmMu*6$ Kw5ʞӑ#Jcic FC'HnL԰*.֌ gyٛnh΅:e[۽m:ZR3g֫cM5mP4BiC9I rAܽl^<3+o>kz4ޔ(G$/UcIRy@u<KĂ$~/a*򛻇ogWP{p _]͎۶=Y}{COwx!:ˍN7y52`QpcG%lh]/m[,ԇs'ƐF˨,nWMTF/u7h~`Z7'U֡ snTҊbKCVP鳋k $FR0V~i/?);g~bĽ]"(R B~ے9_^q)ʳݝSO[mǯ:tG"/c's}ɦ
+gvPga✸RT~'ݬPg0e2\U׎t=ʙ^*&F&hRLapU~#Aq."+ խ˧3jOeXDv`Ȱ(Lz`LnkOrV'[b
+)Ɯ.]Ysjap%jjF eIyPQ9E77R^\|F*FH+^(+svݞJ:nB}!aor]?bYTڏyv
+p)t5']X%Wh>MtRܳ%
+v4KێPhdeBʦfqIs]4h}T󮿪 Cu'PbΒ՛0 AEL39Tus;jz
+z@ l9x% 8X_ M׽>"cC o]R;I&5d@B<pjNi
+2{ٚ/%b8tQ!Y*Mu!C*2ߖ2fkhY*܈@]ұWF nCݓ!?%.#U"WJ$l
+4xJkTK܀
+ka% +|1]Bx@8 ǭ+6Y%sm^|oYr&>^RwU56UKΤ-W1V$mVUPcr;0`_fr>,Ewl]巑9icR؇E[ebODnS3z"p0"*(ڿٮ,;Vl }`>ɴ$SI[aaq@XfhR#ghJVDşpeU+lJ`Zg2d>[]\E+j.9ka$T6Mk
+e;X)蝗:(AҗԳgĿ-/P"ř;ί*J7 ܫ 4PhKdk|5hiuW &RnkxQWq6a4ƑJ]$Y;h{BV5[}EY{Plf^9TFV7»)`B) dJ,Z_wmڌ8J"gچv-2+[$ֳ7UM{(*=v㐕e[h1İiXEbh5֕|HU~/r8:1NQ0}ܪx)fԁ|hH,WSdE_p2{ 8$.TG<⧰.{++xodՏ[U߽>ů:+B·vd
+p![JǨ[HN6mذ
+wCmؠ8{(̈<zҮ H͑ *
+D@(vW:o3 tǀ, , *mࠀM^}mI-F<P˩:|Q&9M#\\ q.ňМ7su_ |kKo;QlQgA$BQa\5q`&z!.ۣQ|h`PJ\xâzpJ>:OYE.  M u$xRkvAJKsͩw+ޘr˫$YU껷 *Q-p:01`-S
+j
+|TR5Od~&փr
+޲QXTf !ޥdmW㳎" Kdy#uJot4$ra+
+g~P `s©CAG%Pf}VpzB%ՈzS{Pej`]fOMZӛ48
+D[!2 ̀, 2PϸڨUM(&` '.j J]*
+LTEOELPэFn^A-'$Hy}(ށEbب;I˥ÓPnlpcjB*#(uA cL U,Fc˭SJ[NGZԤِIu4]׼.n)nrKU.)PA9$Si| T8ī3_yO,gr8ң+Jՙ:>%Lzg2H(|7HrDĘIP w.s4yo0Ԫdps>x߸sp>` *"1}X S"8{I>YcZr#uN %w9[scDPAJI Qe _0U?v|XF ׌n`$*:ϋ"u)F lu&DX"dņE~rZ~<Ar~zxH;b*{tkۉF`x+/Pb4lgABӸyAܳ*  q&5F8Cmj rW.#0k6Z]þN6@yi[ ="s[wq&(Y={6
+rmNW:wjሓm=*MKI餸V2vXBgJf;,@#GS&4w/r԰V
+yjtc
+mj%ˋ
+/p, @[1Pu Х,Sa7,gˆ&Y^\.r
++ݑNgiDYMhWD۵ڙtOlΉ2/}ʰr6.vaX:>(c[[ӄ׹ik2OwS]
+@.>.F&#
+sԊ
+4lj@k稈VQJUߐ&PV.́Ɣn_R]̞XƪR{^t oQ`g]|:#CD4_lE_*Ӱ-:\t6b)EN\iMn? ~?&HPb.߮u|Fpj0W%Fe]E?
+:%vn۳KБ䵸 ](RJR\jnT+ݲѩw#A
+3Z|_j*QcFk&qi[̅Om^pP)cnEp~Ivd][Eo
+c<{-e<ut` 4ڴ\\dFZAY)ܞʗ鷐8̩-EBa(?p{X H QvhqDjQTw:7V]Sh6W[?)2w,r鐿"2^ԼL*8E3gqF'tB
+tFaYS]t\zkq`h5%.p̋l;at`C*w>H"̵/QMMVk[>Q3Jܓq=w>K=ԱԠL%FDmy XQ4\7UzMGg9À9h1s 1)☌KN^K\B
+5*DB˥!"-|{?*%Gw e) ~yP?~9%~i^%a텞S3C㝁ԫɀk ɚ"V}bz\Xwdpnۊ
+sUpꭸbu-yMo?7MIAB΀P6UǦ]a/FZLX"*goOrह!wlJ#/-]1m^E1;<T
+wf|yl===>^XQ߸);S 0_Pu3piU.2AC"uҊqypOfxksou5m
+;͘-mf&_'rL\ӧiG)4r5=
+˃ wm h~g=!GMMdzj9yF(EF%,Wi6WAµd!-˹!<^+CCZMuGrbg~e@1UJ'j RWΆ"6K͆j<Zn;Pµ:dSm-zTezψT̥dI!ԛlԣN5~huşx
+xwm B:*ntMe
+ރt0W%keftRpZJcwf [?vuMw$lJZyО%}ozԥ~X E‘
+{|n^AZI-Q/y4<6[s)y%)X~280@ՎǏ,`dn jn
+[KʥU>8 rYk?Ud`CCX#_ 1 i=&ŭI&nOxnx?.DSƙI_nx?=ג^ImUGrzßSB?s.}n+vR@-_Y(r.vJ
+dćݷ(X*ӱpsT?bx3 II9_ tI/j%:ĴT&.[hS.Dkh!Gæ&Z2$|X"
+8X:4'yCsFAe_y 3!o#>ww0U#
+8D~:Y *K~Y\JFNKv6Ľㅓ8k
+CCGSc|{-q𢜅ׯ/> ͔*8rgxBq8yZ愙ᠦB!Ef*πZ7v$ rm~Po;Ĝbȴ<%a ʗPbrwnhbwHR{*QB&~ aqTF@쁴r\>IF ÐMƬX ,\02 =?:ƛl8LyYc`k'qr$/O)cexb 1\pRw`F*Mb@փ.XbIt֏TSE`CEp'.*v̈́Y6
+Q@t-4FPMGK8%lȚO頑}hQ4z
+ȹtZyYؒvoM%v]%ɕ:l_ TD38G/\M
+}YU1NFSp1-afJje0 s:`RFqa8juWOw%K[*+>!!9*)L!6h-=T?TUuäWԷ5V9{Av?2k>Le 1QT̨!dm+ Gj &u"FɒwE`xL}7| K.q B!Bfe!} #.i/1jKaѱ06Pg!LFem -5:Өw$R
+ANO틺z$zʒFVh_^<rRp7f]w5]SBz54fw$Yx̝ظxS/Qm˿ԥ3noovooFFۜ=-D5QBO%Vb3/S8rdfMM]Խٞ&}pn1vYIY QWf[̒2,4I0CmĚop鍵߽`Hū+8Y0e!Xl͢>dGuìI-Ynۭ-
+hOҊ6_VȤB-L ꬢU_r/.lВhǏN/JPrمI!_pT%gpkpLXA(hV.
+⢜+-3ʢpS2^$QL@f^;#a*dP}M6ڞ <}5sPk4MAn$z7D3ڻ{~栻@Փj?=
+wmgcڙt>rb(dP7 @g@<ci! 3jWfhc󁊣0
+!
+JSay^_9
+qj̬&yЙ4F\ z
+J:0D0Lxj|?5`j`+k-ӹ0 ^lRǂWFӴ5 :߷|8L#6Tu|td,p/J8V)֟MmUP4ɳM /?ubiYo[ٰeE~a؃Izs[[TtCyS7,w )/b8#?֤MԊESp$~1]f3<q=W)/, 0 պ͵!#\gTڒej,;Z|^ز O{;k*N>α G`.xd-AMM1l5`Srm0([/7Nzz9Gn3iu|MJW~<ƛww3b[56kq/3qZCx^h^#?P_psɸ9k~[<eOws\m]tg (U٣TR5'~>!5k)STKGTXD^sK Jn)I
+~sĒ5ת<XJUA*FJF^]:ȱ:N[-e_R ~;oQ:_<7MAKMa!i g!U[oւB7:}Rj"ncźZE8ŧkrX۾#±|l,0u}֭Dh5K-MDxۥ)$'\
+o [lRL¢]D Ow&+5yGs>H,vr+7},Mae)s4̷p|G6o/qЪ&(=}!bg
+B3Ujɪe7U5-9"QC_TY?`j4 UkU rhFx/ cdqˎpX}As׿~75y7<!+*S%<ڬ >_T.viTVv=1B5~vO5
+᩵O)Q
+AS?>Ħxצady\h<zVt'~hW*|?9tڹ9!RO"*>?K[zƙI#۬>Ȟ)rzPDIuo3~}%k9ͬsVSzc t,68
+:mJ_]U-*gN1[K cQ~* Po?]fjgw<ja'K[kǀy-mSKU0)%Qo謲eԱvX"a)@"`iǣ.iL$;ka =^\xɊ.tBmk;Q'4떕7+ 툋;}lbM`r _v9rq]M^o)%UWg{W<ns`TU{?je{Sʼ$ŝ#ƃGM\=ɭ%M;BLjQqOo(gnM~Du#+^QO7{mYLXg۝#n,ӯGےG^F#D]RǡuOKHbTJV@q,qi,ܕqTԾNbn`j;6|`R5GL2;{ՊrvȤKJ<wsV>&ӣ(OCl,Ö(Q >Hgi,wkg[5m27`ʩօy:lU)qpKlTSoQ&m7-}X#w U'C6Lk>/nt=>bˌV/I} f
+ $AF|Pݞsܪ+v!Hy!2ecM#\Eb"*ݚf} ͜.B[] j;w !QZ6;ʃ@t3aCSKD'@p2ME>ASrJ VO81yř4ʣAK(-Æiըx9UԧM9ʻtm1 kSiG=~ҾFfx[?خIrSa#ǘ3$V9w͈nJڎ[(_at@Nz64C.:LFv<[k-yKbUjS.B;ߢZJtc9o):~8@؟S;Ud`U!Wznx
+<R vp?maJ?p}Bɭ׿_B}&'au1W0\Rs%Y;UzdQXO&6(ŭPaќjN;"^^NI2>&Z8QQ]E]R>iʄ.i`.wPyȃ.-
+R~}hjQA}?pu\4r
+~<QyQ;Hz0]I](RJR0 _
+u[j!o|K]Gn
+/yBf24j=Yz[̅O@XEE ׊i]%KnjP_$Gwn;C4VJ;IhClU\ݷ2Ūֆn2k ~EY ?iLjTqw1=k7AE%ȑHVM7ؓrDD*ndD9h-"ɩ"'DSockIUa z6jg 2$C"QcvLV5fzWOY}(:c
+& yjK 38^SIb1~F\M;I}fǑNkhi><\cжXoZh՗85Ԉi~ 76$s$ƥ޷֞ͫ2'+ךֵ6$g$5<􉨱C{"dqyY\KSMnBjdL\K%8:{O25;R$vQMHbr
+mm/qGyM^Zk99[ƦlVY-e(՚
+dTob LǢ1l!A8˛?uu`Kзddj@(88.ʸ
+;8Ԩ :W~(
+a\~oZzew97N_(3=ыk'8h]T'$cHXkm &ڌD-ת BJyt1{9?I|%X4 rΐ"R+ybEQw ?dڐ;XT+`4#}mrv PeM!:՚ i>V#E$e%^dE\Ns8ءvg:6.3w~ ?y Z8mÏ0CY|:fpfh<W[}'mLxρL2k8pI_ fX60Z^tj6Nx_9ȿ?zF$m
+R)Y6SL!K աiT`3]
+)
+ ҅F-r>`嗵z x/P[vȤNEDD}"k-s yr; LS"{ļ9*KxlJ<U%Anv
+Vk*Hˍ%ZQ㄃ꪑRGg
+}H:glN2Xn]TɈd˙/ec UX̨@ugW}4&Bo=9tgÀx~U˕w˰6܃
+y
+{>Sq~)ƷkBԛG"OА$G\q֫I~H"B{aWt.Lv?&r쏛$X9Q)1_foj$.`tkv/ML/^N!nj572@생bPd:pEzQ14֡hv
+KiYxy,2  !bV<͕Gnuv*0a [S0
+9Cͱ
+&sP@K$s96K|ih:]'щX4:3𽰗51RMexW;]7e,??#Ia
+nK+4bu T{!{\m[CZ:,vV#'#/L)m
+ ,c2Ly]Pq 4T,XtW`aFN,\vť`[iM?ܭ lXJ\PvWq xT'̶ZJ*&[L<p6S^RXETL$ <^<MNWkǂ/\TT<Љ(lCܩ-並* >/V5
+YseE";ro.\KߔZçk4j*^EtxCd? Tdn6G.+,3IDlbR@Ϣivy/mST7we(FPƀ%P7qKv @8Q)<1ΰ}$V4"EiB kea/n\<qx( M:Oʳ"ikuh csEn=v55UCs|1#"7(N(|bԽxg뷛!:+I*x9؝,s0LqIEm]Ԣrc'g&SASYOg$vWYOqv7NT#7 jߕ%!QX=AS
+=߬Al~~l_׊^t{
+{%rq찮2@W/6EpQ
+C[t $`>N߅o?>l2i
+X('7Idz~Q,tZdUN9*R٪&yq񩛜> M)'g\>sYuc-YaTйo <; LFYȘ.G3_Iwf]+ga7(
+g({Zӏ~5ER,HgbiF!uMuP֊ջ,nC T=DX֊TɋYcX%M4ݩϳ6:="!wzSJDxf@bFE񅼢V)~S.D_jǽ"W ^lKcd\yܢS[+NV83>D qoMYZuU`y&h1[oW?\.lpb:haa5Fج΂1i}|i
+gі$vS>KY f!b@HKY^hp. 8u|n~-N Y._ tS@).TK!(8nrڇ+R!aiP9eßZé-De&f_6ɿƁN/aβg3K4|ELgӭMyw`ѻy'XQprFk,\5š캙$` \)?k˦C<\ II@nu Ak̠IH=Pr4^kn'dO ,dkqG g*]nڎTa*%P#ȕ][싱(F%U*q  罀뿿I^6ؽnVP 91jq<+M76*c,M:~,SLmqJ_QQg7Ǭʉ!^Td`n.z0 *c&BK)(ơSsS
+/mŶ.᫾E//ч gۉ |w0J[}5&G鞉K0\OAVPQ$^e O4*}0',Wk{ ]پ%(
+_@ ?ǘ3z$Kնabd2"q
+?DZݷau[Rh:Φ@\$ㆺ1,M)"A\`rlXYx4/2гUWbL71cX)R`:]7"Q-p#;=4l1؁\*EqN`ػ}ۅpgVZyoYMlw)SdسfI[B&Rv{mP -[־W=1=Zw"O" X~ʼn8ӦVF7cSIG5Γ1LʹLՙ!άBYvKoϚz۸W3
+;[>/T?jl^nNA*['N}q)/wrؾ7FYZ؝84{:/zb=pnkO,*,#_ocuY7,U|䦗P!n;3[A!g f.?e֚Ot6zj]*KViv\ݬo_idDjCҚo[5%1c[Z8t7zE+ WԦɳ@7rW, HqUBϰmY6BKaRݼ`@BKVՄKeNƪ]Qݨ֗jO@#in?/kQ %\umE74qg ű~CKG|[Mܚw JHɬ]/vrob00~;+lx4̢oalV`@)!#NUm^n<6"(eFdsS_6"9%:ouAo9uOoA)d;!VlYdڝvx\"j<Q'Hi&,LϢy2C!;!P*n2Nid%"Y;03.Pnڃ Ӣv4NMZ:/:|#٪b"UU'u(o۸3$]-Pz2ʡRb,v<(I=Ve?sw
+AYKv 4ռmǃA~ڝr8CRѢ/S,[b3ߡ[ig@5vV$ez_MZQl[0&L~ Ǘ(zSb嶚[iϹֆd5F*ahrOB{1sZvt,!j%UrTnݡɣ;-+ 6dj\[
+[4d 7Zl r?0u+ؑ
+ҌsJJV:xsU<PpʌeႺ10 0>μ"8D#Y=Kj w=IPdG2t(M$0W`-WnP_2U,xXn\`&6'ly-FW4IՇֈ'aBz%JRTpKKtTSN#Ժb53YeWQ4ɭL~ۘRo9?*b'IHo7T\4q,W=P"QK6sMXv+♫ Sw{m_k_:14AhHC F/2eP[^Ĝ| ؜\Gt伏pύ, ߙ 뵊vN/>f(+GF#`|ե 1gO"~߰n2i!-4n%n飼ܛF? 2]bumگ2虡١3]~|@SQy(4qgk->\62Qnm,oHv^o!|j_. pCR2$;L}_zԷm*{yn$yg:$5*`sr!fkQbQ[<|IV]@wղ[[N+I#! +DK$ KcyIrף`_L4J!ZcYfVNH1d: p7,L/'s%F;+1WQ0=%r|0ܟ_~8_SVG_nB¢OHa-r
+*Gz9I_ˁ__|
+Cp)9Ueѿ2s H=A^YޕU?jZ;,q8w{i`S J-Ȣ<tZx!)gS[ZFāL$'taa2Lz<@͵0xehӫr"LO4"l#B鵁_Ov:qaY"Rdj$S Jzf[ę(R~W D gϙyF`G¤B k.Ykd)[/P^BE#}k^Z
+~,@eSI$\O8{WҳZwTL8}s ܪrŅIB}uCI=,:˳Ğ>C!7th瀚3vܮ*}L.dUOQo7U/}p~xFO~ml$zl-_eB%YD>n702i"NE5p$='YK(7,|f kPL0r!eUg!cGkdbrMƩaEzS h%=YBV.t M "-19[7Mw Ywf}J_X#1f7u8^v&ԇ0lxͨ"Sŧ q<L-3Wqv/m"yUB0dr&ڦJU,D̻0@o9uן ؊;q2
+dz~5 VD5Ѐ2~ԋ
+=K*X I,7 VFPx/vdDaR1k2s1:");Wj*9"͡J<ogmyKI 5;$̵Ad$XHy3e8"ɴ 0bc Q-;5[Um1=RM)"ي0nW-aLk~%9DuDEF-
+5WKl_D4Pve^N얁Z+=_-/YxלTOZ;@/=
+!!YGdG|%&8EDs!nEkBu@2`~YU|nw)+S߰םǵ0d/VQSoWiZ]X3DZ
+ I VLdlBrwc"koekSB_ҳXK(`#ASniH}< 3?~ǢO%|O&@KsJ&U#[_MG-^|VB6:dFȐwdHMk9!b2dʁ]s#V}υiN Gb
+#\P&\j
+v~u& ɠW/ ?q<&$B+9b2yqZv7lbI=[Nhm7y+i
+Yږ~y`Wr?'A]3zǭE /||Pv/98?rmԬ
+/l)eܦ𲅨 46%Ww[>-Ip{ozVK~Nl 1:v!{vх^BvlS
++8Kt
++7̵4rBolfY<Kތ{}6zY#y/Wߙ֩Z_S6Ψ4@A4=0Ԩ>] qMc7uىY
+8lK}`-=79$]g@^櫣s }*Ґ΍U3^Dy$qbYH4%_yMDЌ۫*?o1ujM2vُ7H#~:ڛ?81>n1ɀ"ttjK z0F) zS`a*$enl|="P@.q
+ru][윒gns٧p:/VfPTN>h/
+m^7z!r84%&؊ler˄ԛxn 》sǶ͈/F
+ tS8j^ gݜ!1Iјػ9XA[mg&fMqk^+[.As..E.a01vوW_Cba"Gh[.īO1{ IgX_\_FN9ܨd,*uUxuoW5b|CY(R|(ڍ&đ1?AKo<2Qq(wG87PYٲ/jTmq{;N9-v\Z>h<0:B@x-ž!vn@nݐҧ nInFy`c(MQiT6"ք:XfdwT<T_xL"Jƅ^6ɮ!,`cdzJI+sw!rӦ\7 5V̵Wcv&EmE4DB7ai*B.1e&duaOA6X6>vQEucoRbrB?{;8Ćb[\gM8P:6qGtQp=V9:vuy6/"3G>i+.rbYoaop4T R@._[Zo>E&:Q\hGՎ x$ *َ+(ǂf%X3`kQ9p0ٮ;v$)ehg0ыiLշa()5`usތ0pD<xM> )nL%Cj-sCy!%o~L6"PO
+X@Ǫ&=6o7Dp&^\ϸ`G sNCR "bIYgtg=\ 0cǾvw:gf /vpIEL2cTsl+͊39z QBdz&???^QOB!Kc^BVwol
+QFJG)noȣfy?j>gG;7ub4[]+(2[dpU()dGuY,As1B0׎s
+Et;LSJS%\I}ZИHWӃyW=/F ;`١{P}J:an:{C_AN;9;m|Y+QRZ$N+)QgOoK]edEHUqYԻYT{ug*0wcsSdo&/]}յ47N\C"{G <lL.sq>f]ӲT 9 d2u rPXB2>^hlhz_wR3vj:+͵T9wsf}D7> V}JHèxC!Gsy+C'g1`*%0U} 15bY^SyH
+#)OlEfwhIm *j^UdMmHbS yھ:k
+rɣsֵ=6KOz$ˋGͭ#nͻjyEpY{|z8I^bnub}ǣKPgĤ
+ Ov|JzrC"0s_Ц:$ B]U$R(gCۦ7W *
+Q.|}X[: yfVXB Ayس*uV w4.Dk١<ܣ"HLXx!~ ReMr'@=eȋ~*r o'#y4Q`CiQx4|Qԇ]SɁmySiG]~fо_fxk)pz?3<Q է 2eAIc[6;_w,T8)N;$z֒[6€{Ls5"{hBs4Ovr8LKLE]xMqr׏ﴧ!-|]b#Oi
+Vۏ[k d,VYgi\̚msL2q}'}5x]PhEzigּM;T` 9|L
+"M7dcR#8=s]yu|]nhMT%]%Ir8^ =c 9FF[Pr$8B<Fd:`͑GQUk-E kXNd+M'i欸g@ksӴm"A|,԰FW˛XDu2B W3}҇`*^<~D5v*Xշ;ƴb_h PUڙZŗ; aҞaH}s<'
+3m]pt HrQ<l)(؎zC6CZZATl|-.cS|W
+=ռkq
+'fP?
+e u'8 & rͻ25DzB~'ٻpT!}ba(ۭ…]Hf IĽ./64Pa!!y^HqՑE8bIj޴lH[=SdOhmypҰum)(ULp1rvr
+a9ǫ;n1iؽ>§ЃvTW'b{i'ڲ8VSZ\zFE; B EVeLRm+qխpj|3f'͏z(G wc#
+TϜ&͸7qTh{nVX2@.QD<D$~5[C0@Kk(,#f+<y϶GWLK; k ἼPϓKVfbz ϳ`V __P \PҸ"/n9?&?Vg5Cb۪vTgTߴ-ij›GŔSjݜg?c4JֶmE-%S=f?bɯ
+C.U1<2˗)`~br@#o=x6>1Sۗ3~$? mp3 $KCH1, 
+8m+˚ĥ=m\fYbk& ZXF5 fWa2m8\a:ElxJ2ENB/@+E{!e긖
+pOl.UVw\D0#1+ǜ -9-ω& 3lWK%*jXϝYɓF,Hv1AlvxT
+\Z u(0rmlF $A$`N[/TV8m٧ċc< =B8b}ްKh⻎4gT~d02Aؑ6FOXH.3e[<Mx1&4h}; r߸4\m09꺟]k[MJU1]}"jD`֪v[Lն$f)%Kۥ#[dKydh:%Q{ELAl^t[k{߲WwJtꨖ
+dp]UWI4DML:b-AظqtLhܽU;nq5(oZq=Tf|ڬ;t=@
+z οo _Z@d1NF#ƤʚWENԉ`lvM$ZۃD!&(~h{l}A屃^PڱrQ
+h'#kcl?Ժu oԙ|r6U;wmk#ߩ0Ng:^v\xQwĤ!c/L ,:V<b)5 D[oRbZkO6 '(شZᛨπp]]ZWkI+\Jo(:(#bY@%f}rO{"[㺶ﺮqzLUkbSo/iڦfk ER7ۃx͗5q}pE3 E݀Xޱt^Ie
+"E6 s1͟An_)ӥ(k@˪7:P4xt鿌m:RaD4\IS]КdyU,<S. }zƦAk
++½G9.꬝m=45F{1vSv^
+ -+ຫ]o0\i:]zy ]72 =Lڳ̑p
+_[҇7?*B:6z
+nb@>񕆃.'D8
+O$(qQiD2 ]Z]lz>Bg<YL˄3OɦNCF-}^pZƈiJqz%gI=D&C46sX/:O-t NEycq/pHy)K89;
+ViQH;cKJu ' -TU3
+ӕ]Z΄ ]U)z%ݮ6K{&o;Etfl=+&kYѸdU Q=W̨H.hZAOꤝ~SCZ*c#jqrzI-GCeQZ̑MC3kLlv EÉ/B-/tV@ qIDZxS!#?CETS\",?8E\$t2,/vL_vr!ڌmrK2/ՌQRp!BW&FM 8U!pkk ^˗Z&`??VKI
+uA
+BxZtD1#g!qh7Sn`UGyZ2}ͯK8pR;e}h~tgBcA%g
+=/.oHuPquWY<)ɱ5qr ݯMPax7j3qJ xL[ʞȦtc v i-
+wgT
+_0">-@
+`fyGvXq"0S:TL$i!kmjʲ[eBT@9gׯMVx::\u&6<{\(5ϊL&\%s~o]:wC F4T:jK M_=B G
+%PbZخq x+ܗg ̩}_&$TJ$sɫE0Y?pg[/~X>
+:<ԝӆ> Em!HH}C4yBy0.,8E
+F/Qm@I s9K\47VI@L8QX)&<Yv`82D Y$n |Cco~ث9 Y]>A: h9-KZ-,Y#Q<YM~Rd6*tLCW CsSKL43+
+! fg~v_dHOűJiZlݙC_)g9uqK6oj u1tDɁ,"c[Kp(pgu;Z݃_XWu7.{޽,zE˝=R吔M($6[4gcX<^(Y&d߳вs4%kҭOWpq߇!^ j|ZX#Ebdw|[Dy_)VÙR)n=.eT(a%%'J3.ڽpzEesHe¸?͋z1 ݳitBQxśv
+m1ORb96|C:$̧edwviiJbfOkdY vJU-MʦI:>Iyp -Xcmqς0:">N9IM
+@ܟ1T  z-M+cߤ
+1q\.Ucf
+}jϿ`||R\- MA1d/ufP Y4d1M8[e=ikd޳M<+x6n*?9,D/+by~^2TM'fxҎPSvp=µ08}I{]CD,Y~8?ȦsT<jIBJ&Ӯv\|>S+وh;1t!>Zꝩ;h4E'ڋ^$p0$ S~ P r`ȷp:M 9JV%NF4~SyƸsg9[bqR`mU8ru2?g3 'm&&܊0m+qrIQʆ}k?C@N^!͎"҄K<% :T8xUYH23=ES [Rwg3&^q$ 8e51k{R|YNy7"c,WGMQ,}GбLRX~!/>A,j5>|,:@TtRn.kgDH}dՔvf̞WuFϬ.GS=sE
+tǏ'EEnQ8Dmt~-misqMUO[y,kTŏۥ{NF\iښoIbNe">JDu'K8(e9Dzq\$Aʷ78R;
+Q
+x>L %짠61~%VĹqn.FԍYTXG*y?%Fks- +  Rc̪ 5xY6̇=㽠f@8=΀۽s:ϡy}L.X'ŧ]6ٻ`FI{)?2tsLj,$rވ0U}3Bn`Q[\ L 'HR8*H8cX61q>-ݬ7 #E%?OA掾!"9 GW(4%lWI; Ix>^}M@>(ԓ8\y>[*TFcЖyڇeѹ[(zFOVaZ|_}\=03;8ޭvZh0yjUK3ԄxPU6UC[f$<zՠИ@r&:54U$BX}8[<}rRvt.n NىQ߫g-HF2GE:?Lynz['34b
+P=ܽ j:B$D^`>1Y=W
+/WYp\qQgG㜓d1s{WC+Z{؂J
+K/ 4%Hp~αN$ĉI &EɏdWm˚^*~ñۼΌq?*b<UEf/DJP4H a/A I]Tzq I3c:hH>E͡EHvk:4CZƛK~0>/˧
+n6%v[wpw &E6Kz:57w[`iT%&Y s^ߖ%Ym\4S2pjذ~췽u9וaaN0 0|!/^ܳs{J`)@.:zAe@H7WV^2e*ƾB$rQ߲ kgyx*gaވZ.Mh$0s`Y׆ޝz&3 w,&Ů[%=}u=ռk{9a7NAw rBX%_1/1/"¿ohκQԯ Q
+/fP?euחyx,EheZn]ֻcG,\w %Pu{ e…VV0t 6 H,LN5bY?\]'v:'ę^
+$Cf a
+ 3>):qxPą!5tk>X2p+@$
+\MW"ph| y qZk@\uVU 8 RJCFep1 aGXVb>;;0Ce6b0;3K|RI)DjfC^&4ZE'WJIG$=|c1=01 __9+K'䭿?x<wj$mZbj4Y, PYyK;KD^ٮIrSa˖?ǘ340xŻfDR*4PpmSmi
+šKޓ%T wOhhz0ԑ@[4ؼ>I'.7 ѓ[G1I_q%7W&1v@CPI&'- D혔,4HK"P '. X~D"R^PYԕc{n^Ub
+߯Q$͜˶,xAcizX3& z Ihr<y
+ya"[tDhCA:f(pVKZ#yf%:M dhֵ49H{#j
+ZPb|Ar?扒Z*6.SHfH? 3lhH)ĊC4Eq1
+cUX&_hi֝AY t<Y$/,+*tP[-(B積!wg$yr<<h8*e;͇:V5û
+[-Rϖ Du.Ucev
+܌Me}1Z VyHE< 尌jL[4\ewC&8y]I`lWl/4PɹEݙ!<Àtp]X8k
+x'i౉"4P/qCDgde@NkR/~0#>&kCCJx ϻP 6DQ?( 5hV}B6襊ƉMd_,\2p}Wf+ѐM
+"]mN"<O묔: DT
+kcpMXϻo˂ Dep] a
+l kZ)-'ѷl˸*
+q P{HE/R&?od+s%t/Vox8IMP_#ԎZyd\giWOSۇ ysY=z`r픺`~ '&Tg+y fZ>ݛ鏸z]Oӟ/OEer80e<MELwXpuhpA~QX GJ ,ZHyfttɧF QRn$`:ĵb z@4*~Ŀ\Y%leRӸ!B"R'R s:y<qbOu7=AMYD .|~S~1G-ohgƱpE&LwEiGS>88E`"h~cNb|gBZ7|
+ͩc#fNX`pkCgyQ+,oMp
+S/4G *iZ/6B*v˃ԩd;J8ɾIg $%sȢ[)e푏T_wzН3Ɣq(MTu9`b楱2SݤcZMs.mu$G%Mj@-syC BQF9jCy}%gtno/dDͣLZun][k2/>Dq ѡDiSnW^z1TOuNVcF#:+T&_#RQ=eG!EZaflu7tw^0 Z05
+&AKU#@W w,$<FT~_As^ |ki{(ήaWA!=3E jEZNN`!Tb Hɯod͝q4|i!a>3Rc.'ܓLz!H¿u<SidgqYuAcq#%}ǛLn' R 1V{˒ 2z|<v%e"g4Xlz+> [H6&z̖7Z~
+oTW:;(Jw(F-8L_Czre<Mz@r #yKU@'5KXoVF)9WKnmkڀd6=d 1Hy{gtO?U,]@5
+ t@VrFiQ$QI{#Ec0<d"qm2Q sR$ {geKjR-hqW*fr
+;ިjfQ^M6`W,9/yxT3N*gd:e[ۨNEQ#"i5TFqb`P\9"׍󆙉["NDsm!`8Tm
+WJE%==a#%* VQ0(;'+JA7\43e{ίirRH_ j"EPi5!7B=-ApHFb+*`{/)nP1SzD<
+4249;=yN G:ksAyԚয়*E%y?QO)HЧxE8d?g9 f|SvL9|w#GS1v#=kBQ]ƐibܜܸO*6cq yl&Wg@-J@\P#]W=Ѝ'6]~&j[X<TgeR~9⠈d KNr$Ȑ$S"^,(|W 
+ ͞=uh7~<23JJSƅ@glWZR(w_ʛQp}h8>|^i$z_TuRت 1w%Pkzڸ%Ve=+24gq!HF(X;Ue
+%47Uy2Pg汻3T ^Y.ẔQ"aUcXa7#%sUPEXul!'n"> m2'0k}&:Dl$IX7nbܮGYz=no~Y䤱L}ƛE$q_,>MH Eж,k2"JP̠\eH
+yWd_AvZ ՟  qgV[N N TD<uf^/<? X__ަQ*0ىe
+^ 85 ql"=zX
+E2ą2tk>uߒv`|c_s8;(8C%A[ƅݡ-3`%Ue旰ɰGGN:7ڵ7v >GߧMtV|iQ5k2BdiO%56aۜE M*
+OC *{FT}!"a9ߊS\]'H2J+Rq|"MׁJ<0N JIK5+]r2ĵ
+]DS- dzU%kRdM3`7}M!(s5RW!:.ʜ%":@Dzk)`(8X+sze]N]H8PW$x>cf+U e
+(BTSD[u
+*6YOx8#."XZbMꀍ]^Uh yFvLi-)lkCN7 k>9jNM.rUF$+Aqr]~4cIAľwv*Fq﯏TWNY#^m췽u9וaaN<0 0| /^}ݳӼo% f}@Z@H7WV2e*>.B$rQ߲ kw{x*â #]!PIaĂ/) ᇫ5zw4_cOe\aBQY*)WE[ͳW#_v~ې,GdGl#&8EDsa4gv(ׄ(d |z;xp)+S_uNM)ݷ׫pZ]XWXD I VLdlBrwJE^:`G*_ҳX~ĥU]
+[0YtNSnaiHf̈́ȟR?Sڼ s%U=[_MG-Y/E>+!CG#d(RZNV9kN3HUgξr4'j#DL!C],r=:hs,}=n~[K:xȲH˅qٻpdл$GnLj
+R: SXW?6|Bg8 i<@>qk LxZO5Gms|aG8tbt2@@k5kC\)\l&=%4/F^Rnw {ɾ;)Lz|n̽p=?<`A͔2gKo<04V~+H>U)^˫n1vB-וZ
+'KnHE; s|gQXMxR]vr[;SϮݸ[cOg$z=Od8/Y)tª=!˭T"^|PUWll} m\|Śx+U5I+meETrA3:bKmŰs&U^CGO"[
+5dQ"h!{ԵJ=d5L "14d$PF' xGAҴ r¦@"ls *3da⮹mǯTRn*Q\yiP &=4-JJG$  nΎȅgL߯|_*fwW/6=&߃Tg5?-1Z
+R#*oږlV>:QSMs_؝icպmj۶\햊3΃yPKU.yp>
+y/1)/' 4 M޾|B WbU _`/JK<%
+U(Y;=c $,$mτYbj/M+ .Z~)ӭWs`5t /iCA$3kJdkU"PxtFgIh.vJ>o`ebj7K֙y壬PG89=k/+Ȝ-:-ω& KSl״a8CuXqbI14 ]}7K,e, @PqP#JGN1Mْ@lT=L]وMd7n˺-Jngʱ,qߧ t=y#`!#ߴ I_!Q  錾9eXKQFm Nv=]tr]jF9E{tUgoG =\de1U~ AO&\/[51O-i6 N[hc2ӥHq$nE.a.o
+&,*OLj,uAvrČ|zu)]"(mLFgy6_o鴍Wn ('!Cz续 ~/Q8;:
+ ܱ<rx-7d; )_r)\rgq=]y(ve濏[MǯN8גj#1cU-#;?6\d~ųtF
+OKQ^r n|@it#Ui M+:Ӗ20u<<.-Gar_|!^p!t gaW~i.0͌T KnPmd\VbZ&!h,C[> 42 .!-ղ%ի^gQ́mww("JI;L
+~KN0eId=^\-*yUh񛂅s'nRt1|!#4u Umn}j1gXH ?W4p1lh@t
+w (uRU_WI "?#V{`Ϙo* ]Y ՞4wE<zSp.fj[p*#ح9Xlb.PH|"KhB\}Fߏ.㜏 {05<4^ZjSkUj![c=[_F] `3ˣ|]C;~AG0QdAUrocA,yl'Ɖ=D4˘Kjw;nA٠&SܕlJR @<bC+mZO u4Kd-OXHbN578A"r)< -+;r;{2R<%f}DYq#My+M #~mUKY׏hF,)I|zBgDU#`.53jDWWD
+OlCMyO;)N 8nZECxbe=R8,8? UoѮ c ݙHmXNǗǝ vzyR`s5zɩM]K>|uooK;yF!qEʸ EW½M{>1ens-!f?ݤڮSy}ZOB+ )KAeB%-X_qX y:iD`)h
+-!Ki#2S}f*>[)WUUK V,3vYfX,Zާ;oebPN>j)c_FД!qY^ۊ˂Q{`([}ڶ͈}?EA('J9$-f'w6pH,; .`,ß&ۜ_j8,ЬmY.0jKLT@mxmm
+/@AJ8^clvV/qOHb;: @R;fhmsr_4x!/[p P8 qG[A=: iy䚪#oG=E8O|Qua>1
+3|`k;>1.#"=%ҍFղ8Ke1#tnj ƔWsuF0kw:lvyu&z>Lge^jvӆSI7 xsW#cZraؾOxmYc ׋fDRF
+MBy@a;ɺoZ`BxKkczcәqWg'َzH 4r?𬴧F6uBhh~i"#v~%-%My#S
+3vEEȩCg
+UIUBrcؘl;L/1oU=A'Anu 1ٛ4xӣA&BʀoU;W|Mͳ5k*V2J˳uc[i
+ӛGɍX履0[HϺubgR@V&uqC1{)Ew/b]7)αb(ܣY,!ɾpV߄e֞<V &L
+l#و la:, zuIIq!{fVuh,;h|JI Ah<qBaM&T]QM=ǻgQlaX$g#i.רFqfASs~"fFm^|0EH '=u>78?7bUNTHU>y:)ؤu=(~
+S3}oW:diƤW
+?VP xEh+5H:`I
+ȏ_uwT؝PvJxTC9Y=Jnij=ծw 㕼Nƙn-P#kmVvNl@Py(/bbiq~V5 =C3 Em5V񯰿x ?bCUtPY6Qځ_\"M_o(K,AQ)]Pa|<+ C%j t9R
+F !N
+5HR'V\[$ '!@*fkwy."^Vd<wYR{sv}\0լupR!N^L8k^Epm#׵ 0l([ 2؂D L@! ftXN>FZgUU\NYt>5X@rQf\2"pfXY}wM֤f}
+Ds/A^G90^0`p ::JC94.! *o[7L#سɻΖ# kӦiG¾jо
+[k?p_5<h ]RuR*j-s`6e*T];ߢ[q{Lk:E9~48ԟIql**#$U*YYƁg}Bj69@lw># w ZN< Jogj*wLM/ 4d-bΊ|p=O
+YαxkQ{h0
+yO91pb>?Un$I1
+3ߣ]26,g<vs𨶴%6Ŋ@_vՠy.$߲4yrAz1 M@ 6m7YdsTHx
+usw+@5ܯVG]F]<.|Kafb,~dEPB{[dq@*@6_r"l_i Y C/g=pmĠڡ]7OӴEgvVW{yȱQF@;itp5۶JdX}hPY:I|^jgTk;oWj; =,u-$f%<"ib'h
+l%Y \+򺇌\wf|-)2Ț.Meh}?4Ha~gVP6uXX܅5/ _‹gi<;=,t _@GH7W V^"aǾs+!sfe8`>ӣ'zXI 3g'
+z>CuVP0$1Gr}W]a԰~{ˇ 5T
+*3(?xۏ}pUFRwk[]uJkK{&ɣUX]cJֶt9ZJ8bm!l>2ʗ)`邾br^@#A'ƐOo_L4“V\??@0S,5!(-~DXb.ld Wq4M1>vBoQþPG'V\qhVL;UT
+hCˤxjb͎.1V
+f%En ?%ܺ4ogo`SpLg1GXǬ.Qݯs5!_Bݺ&>+٧3w7P~zt5"8IxCM'$\P׶߶tˠb[ bqMVTknBs:baEe_@3+:'s7QR43)$x?xw~زo⏝Z]vqQjla [L^em0̞ӔjC
+2b )|nhF=Rm[} iа}>>b2,pNS5֊ v$[y7^
+K=*\;H>d1i8lσSe|/  ڔuϣF}%﬚d`"J-J6(-Al"Zumv$5$.Cg84-p*]Gu)Ve]קT
+K=5-d^كMY!R]-ߍ'M?W⬔\]eL"3@0!. ؓMH*8)|?ı DE`&J
+X?aAkCEf#P6Re#i %#uKtlʶi>%]TKI_ik[]5u$9;^F؇W%"XG57z*j[,3e[<Mux1&2(}; r߸4\M09꺟]k[MJU1]y"jD`֪v[LŶf %K%#[dK,ydh:%Q{RELAl^t[k{߲WwJtꨎ
+dpMUWI4DLL:b-AظqtLhܽU;ꖺnq5z(oZqTf|;t=@
+y οo _Z@d1RFUI ƝI5T$H,߷BBMPdYz3z5.1ۂrugOcӽ cgRgKv'G>l?Ժu oԙ|r6U;wmk#ߩ0Ng^v\xQwĤ!c+L ,:V<b)5 D[oRbZkO '(سZᛨπp]]ZWkI+\Jo(:(#bY@%f}rO{"[㺶ﺮqzLUkbSo/iڦ/t@"s\A GHHK˚>8]ᢙn@Nw:2
+: ML+Ǩqϸ21jNπh!a0~ *V)EP]y_*tx~Ly?L2{uny&a.W-HXN<ՠgærͭ7yܮ6 tR YHv6]dXu+ʟYf`1?bpJvOS"mRޢO儹ϠTRKQրUouhp0tBaѥˆЧi&
+]p~ M
+҅Zrz CӔSK&<z>(Lׇhl"=^tɣ[4XMe(//pHy)K89;
+ViQH;cKJu ' -TU3
+ӕ]Z΄ ]U)z%ݮ6K{&o;Etfl=+&kYѸdU Q=W̨H.hZAOꤝ~SCZ*c#jqrzI-GCeQZ̑MC3kLlv EÉ/B-/tV@ qIDZxS!#?CETS\",_L".`\U;/^
+m|iEKb5c;?(AՀ$Q'l%NUlHZ­V؏#R(1
+2'#7SLSiX/B]h~!V7iY{ܥo5<o콴aUd^DL_&NY-7qy]1XPI
+l9V9҆n
+xpvq;e(YvW,-=H5axaCU?\]b-i;`gm2ed]r $5P.mdHԥ8 <JTW7>yTb':'׽e<Do7l>3ajM0xS'\Nz
+g$-:{()}gIf㼳EimKZ< 5܅jSMWjQ~Vk7[~,u4Ed,ÔyZêeS.Z2>YM,߆A"N~kA+|ER)s,1˶/aaz`*4 ݕ
+.X{p,^P# RC;OU(
+LVR=У>4kVx: 6#|6p4{j,x@0~G@Qt
+rMP_}
+myd,o @Cǽ:wpE݆<tL:~dt̯K.BR|g/g\MS坧?xL7Jo<1a<x ɍ^<fp!~ȋgxy6<x}ǝu
+J?B
+F=,'r
+_D_.:y
+ 2(΃ّ̿pB#MZL
+jR+s Wb.&d^ 4G.ŔV"v4ROkCꭦL=zg.ڠg%Qg:6𨨃&*|WR:n+DE|h>崸UE '(a?cwZd1x`F[4H S_#@=}>osɈÕH&oi
+t *1ذG:LbCu?iXğ^z?$ٳ}!ٕ1knW,A =c$!?Wcj9~(攼1T9*s@$]:dSK;pt\-UsPCK·Pȫ*bb9jmV/SVNQmR};r$QqG"̪~zz!p^fӮJ_`su
+V]s8fc9ݏ6LcqҏEiU) )dymFS
+5RFض6S_Q&ㅶ˃gT>B\uxӚOŻ=|J8qV"yujf
+ Or|zz5'V uv!Hy!i4yXWix*ݍ՗/f,9a)
+]0 \{nuv"o޵/ȇDyk٩U
+ѷC<26,g3kidG-),G lw wj
+36ϮxFv$9(@TSDu
+
+6UOx8d#.8%De.WoB>65S
+SCn"rxJ1bfo ?V!5 0sV)n½S;uAkZBM-]ƺԗXPIiXk
+'fP?
+e u'~'<.2`/<)?Bw\.;ޅޥP ?u{a,. I 6'0kMz= T
+ Tg(rr(kgٶw5NtFg<i~-G=RLܭWC,RxѶP
+͖Ȧ1klLiH61m*yU L2`QC
+}il*8UkF疝ڞorm:,fQ9)Q{δ8a&&7nNV,.$&Ċ,؜~G ]=Feq}ũt8G&1W!$ŧHʣEHG9'Ld͊eK*ݬoVT]qSYg}~="Lfusե􇞯#&ÑZ::=*&;1ڭ܋301- K9vQ\c n}TtXlZ95[;եt4Կq,]^-dfCCٛ_(:uizǯIG#8H~u&
+EFf[X 7D^ +zWV4빬r%tPm,yduT QǴxW*k< .tڍ}*T~ۉt6\ZƢ>TߗG]W
+E:iu=ȬV#/ߊy
+MJŨ׫)(VJ&WPysDU!r `
+XPjhJbaCĬ4J g@:.pFv?^7i\0
+ I|F&_-´didOYJGPvR
+Ls$sّ~'GgK24oECN(yWܐ3<-,ՈZnB +'M_;&O7_'9jLsl9"֬U6ƛF w f #7Y9˩U:E./R@%HƷNiOב^_N(VrZjǔi_ͺ8Ih5F~u #l3_7aowed`ry2:}/Ĩe4a7"5qjc
+J  ZEuWɞ*Ȉ,6 GUl.PsǀA;JkufVqg̍W,sJ%;^7YwfƮ%GhS'q
+V G<g;͈X^M^h1n'Es#^EdTIUoHXKB5*Cɤ"؂8UtT.mCO0If^ޫk|ΦA7DuvXWuO%w
+yh0O*OOxA LtY?-:;!
+"-W*xN( \ F+>Y¡+l@'h;(":s$+ɔHkoin w$ ?lg٫DyTg_QmkftQ۶Kηx8!P 'WMκ+mنP㋽<z>R UtNu) paݖ̃Y]ŢҒ@XH vD6H*k–vIXjtu&ZE*0hf;sԶ\vmo*ZxlGcDȂ+^F_D0ypK_B?jm+~`
+%u+V7IT}_}ȐE@
+bu)u=FH̛isGLpUmI+
+};pXv{2vkⷸ:%zPXRXpur"/Yo*~8pLU]`hwmV)Lojˇxճsʗz=‚I={сCon`w} 0l+K7e7uNyMg.ANv},NJлB-:Uѽ3?= +?¦ŕ9B|i7q=Zmb^{ES1[dz|ק]_lp1S
+K |^pPn8>2RIF\G,(Y2^ 7MlkTЃ~lցʬ9 firo4x+}'qwsq`2/=Qtޝ1haՌR>\#;j8Z j@rh\oEzDjYgX7)˼~8AbWgGKwOOKX49Co{^U[BwàDj&,]eA?lL(
+E+gHuz1b>(Kc{dN>Ð\n5ns,͠~K &116 L(]r)
+93=aʆ,g{=yo8"HuY=s$ s5.(9302a܌u`oahvJlF[jP#_vܚ|}V1h; C"0>Lz*{vFOp 7&'NYަn>yng^Yc'FN Y=)5HWW_vReշ 5H7P_ÎT_8ߌMn`}"(J[<W8eF9kxRExbKiqNRU1;xLͬچnÕeWa7x 1(☯xCߞ+5?HV{Bh9_p)55a3a2YY|)ec޳Fu&Iȳy7T4qZ]b:v].Bf(`b1s֍Ezw+iQ[3Pki+ƀ BSr°e,cwhOq:| d76g֧əd^V*ΙgͲyۦ^YsPk
+VX%}|4÷c?z"ze-UI+(/
+g[BښvZ9Xpz킥Ƶ"x@SPyhK"MaŇ'[F&l&U$ ^Fr`%%Krv jmqP~koSKsC,,:WK 7[hK\I}T'#"ߣeH+0mQ%9+L.W3m4F64_`m*Sh>SY*A;ͩ-5Xa pf/G劦s-"ԏ9cms"Tۥ_@H
+梐#l WoNT h&+~=f{Ʈ yK8[g+lV'eRL-
+Ζ_["98u.l&Gv9KmnJ=m,+(4lWIwYuCavR:J>2PF0Dլ C;Ml맛k? !
+º j1@eNZMJ& ?tL-䡮>_
+]s_ѹRIkuXD%im %M:ʓRX@Z(f:v_psIw/e`ڡvڞɁ!bsj1SIV|NyEB ~;] d\t8I3gAYH$s;§I ׀AKkYU}riמvݬ.Y-e^W6Y%1Ըl|?3
+| G cugx'ci.%= ~Nbi-٢*8?B2)v U:E=<9|;r+wO#&rn7ϰ1.fE2`]y7/Sq68hz9s8(0ao g$_gPۅRt=+ҭ+p]*^\~%3lݻ56130qWRc e󲬥]T١Z|C蕥_BE |PV^DTCե0@pzwthx+Zv9:^ouuVun?q Q{*BKR";~ᱻCM8Tp8דː~Kzieʲd{|i3i?T$M~ Br^@?ͅXy/Y:
+>vkXҢk mj[ASx QL-\gYQ/P <l7ƖmE,,FO̓ǙQؙ=7;}̌.n-M.jYaQEAW'>8jH
+$~%PhلlO<vFQvw,?U?@ʲM K)`7
+H{]p]w2D_JZG)3iht^Bclma=.[y%b'l>Qm1JS@2VWiKт6,s̳9Ό>r2MGrTD"ZZ1;G4R9mB؟?ɝ.;T&
+\xr
+{Sɴw[;xS5D>ښfӪqs:1 S  3LSќ"6^Y]}`u;
+3܁CSW0%IkZk2(܄˰Xe.^JxEl@#2]1zjOdx<fK*΄"*Ri܏<6b#[#oʄFxq|k =[[h-;9$z="H5ED7:a^?&
+~U=vB@ʦBƿE^kOЖdE!@ t;F^P4!q˥(%~ߗVwuYy` 9zй^+I™x؃)+~^px3f ,;)$L'38{:~bM<Ѕ[47>ySPy #=SvxN7 Qe /r236?J)6%
+7TYz'{=}~QU/"1jW&'ybj/waq; 3XTa
+g.M@9+%:o5jw#=MWgW9-}i;ovS{90R^.WF_
+#4mGWgC$" 9BVf~YI 73%-QaFoMsX~Ɛ(P-5B7ƳA](KY!Ga<l(np _G1yBrrc@h_Ga9
+O5J8LW"pnuHZ1S >Z
+|`=Y
+ inZt>†Kx
+C")2S)|szx<z
+?ܪS PM¯y3).x)p$t=>7+KO<OzW\(S>hOk)Rww)l&m7 ,}${\M[7gMׯTb_sC/or3ƾk-8+@>a62C>-§,ĎgHԞڙj?1"f1T5+ƽe 7n
+qqܣ\1Ƈ򪩣\|z<
+47 h0cq<C걩Q-xVARwT^_O
+ kmVYMT[u>!CN,JqP[g%S381qwEf1pj~"Kf},
+!3
+NRߖD7tЍ=dL͙X.d
+ pH25a<n:iQ+2'SLb X8);hq C+sT7[O煋̢ᑀ #V! ❄RTU93Kt@BRU^_ǯ.]|ގ"Xxtn,4keNPHccu3
+ܥB:#O@G'D!mRwlbx$p+F3<A/Hisa 7CfV(n3JQۊO&SbknRh
+(8%0!?g A;//)0R7L H)o/Ҹ9,R٧.|ptk ( RѤoT)u*Tuޒl'o8Kj
+*)8 ԰EI>>gyKE7]9i\%
+ze
+ͬkUų7u"SϯQ~ePjd!{/˘l"ش@3
+eo)~8r@r;Jj&K(0LCC2<ŨeM[5s0G4d*kcyޢA+o!洲Z@J,q׮bXmP2LԪ`/ej3Ex*R }+/f֚wdך2]K=@`Ψ[t8Q[ہ܍A΍:lR\}ZΕM׺%q>!}e 1[R(i9S jJb5 ձ(L~dž35mَό(vd%ZyH{qo<т%56YE ȯ'8 2NS\wf1 o%*3dʭͷ&*;wO%7jDx4dh$9<ҝI^
+#
+
+8Pܼ.A
+WX.'$g$ o6`+،?@|SuӓF@/m)\kٕatLnoGH∟TDnCki&Yk4K.8Fו9`m: N&-p9hfߖ^%9vGtߧ 4pـɅ~CdUuiy! #+^DPlm*RYteamsАM!j
+#^苅;_>˯/
+J?3qNxL?0'Q8iQ)}zOLqM<8YE;GRK|I̺~!)X'Ivuf5zԫMejP{}ped$Ó-ۑXw>
+ QH:\
+uK#~Aueq۞l @t4Eh۴q*uhcmX;qUisG@OYY%`:ΛĢ$Hֳ&Uw
+Ծy
+%b>pXm q
+ ?
+i"pAD2g37|{@0YcGJ$MHjlEȤଠiT]W6Zqx$v:\N=f@LaT iۼ"&Un7xj ;5vM[eߘZ(TrsI 'kq۱KQ:5:-Xk;⻶UPiL7} }ٵyNtmF%(&502 Ya|/F乏~ARѢ! b N"3D#$C"kT?lbXJŠ馇+^QgRyY\|JP
+̫K $v6H3#*LՎny>Wk#9ϋ[Tq+V <a,}в]s›lFLzզkQ{t"vc!'&e0U@^D%^]7O\ƽu8:y2%$d-|LI־^MHG_<^xdvFu+dhOr/Lf¨Z$ k14/'ȸ YًTbZdk7q"?n(6]=Db}~:۷@nE 8i.!|Y׎uQRlqc.R
+[QtKͦ $HYڞSX\GY*Ym6a3d̮"0$r0B2E1/)d/%6/|CLέfy8.f<"a"YRk6
+f-Ka#t*h؅+E.Oѐ.1S)v`|Q<yLڥ'8Ra̠P0iyX%$gO~|N)DznfO}Н%5$"|*//"_g3aGBOTi<~ado08 j6Xb)A 8[VJZ*?
+4 8[|Mn(U:v
+pzѾ> g
+ʪrFwn
+3F\AY|ƝZ8 gfVYT.<$xZew>p>Fn*xh1G; \hLf)
+դbÝ߼[TU.$t"oV6Hf3.D3)zT.QM{qMWdƞG{Ytk.&!UyJDW粧R
+RѼF`JJY#e
+ŘOܝhq yTPGybԎ<*pipW|ofO5GPG
+g#}TH<"jWmx6J !x|7G[W/9&Xb*·#
+0uSMWYPV}U售GYudn%IyUe
+z!QVxJQV4䫬
+G`1P@+7+QM
+,%P?鵮wV\~$6)\\\,TA]Aֈwk'?#j
+*Vxih{ EG'6z9"0{7`r aO|?*xy
+PSNedH}j0k8垰eiU4 tG
+onji8kJo<iwyayKrS-/λ#jGn=篣({*D$BO^GGn"yփ5ʞ&in ԍ @S ؚgNis6<_sK{#E0rscW;D=![`^U]+zzG^"%L #KahfSwK`h,"Ly$} _u7 L%Lxw%b5s!`_pɭ/mC%@MKk| i%]8/| I$
+!0-Ԡ!}17, b#PzoX^<3P[TkZ؆ 5d<.f7@ʹrvE!6Pl3;ŅL
+6 I(QFRuFQ5?VONYCVNUp$8d,M *&I)1$[*&N%fga(8pTa٣pխ*y8ERӅL⒒8ƾa*
+~-5F!9{Y;ZGYsӁq19`6W}_ 99{=%%t=iVjB"
+5;T,g3vidx+c]^9/@2/F: .b1]\R{:w%Ŋ`f ꣸Kk!*҃&)v&dVo,\Xvt beV6̑J,;=/X%Wj,
+8+4
+Y/`@n&~LJIit0+( gq$StKQtBO>%=wdۑ(HV-l #.0.X]dc<QoXLUE+
+& 2ֽN8˺a芭ŝ{^6y
+ᕡc6hu]~nrzVgN=ZXI©Rh`Ҟ>Tgn (Ĕ?_b 'H1Dȫwn)~#pqcI)+n䌵P
+˅fr]z9TE1hTc}mP"Ε[LۏTMm:vODtV=8kLw|4(L~X>$tJ.O:6cPMpC5WOwguMTc&hh}FOģ}$$)a≜\<5n*7nw.'Jt؟QF`׃yz=Rst"@oScM3a~.vOOk F?gN"v=#pq
+
+{
+aa's:|
+`6Z1L鄭Րl-gG@ciV?>pd;?{ 8gCla8aJaؾO tJc Je^
+M dĭK&&"M(pTŭk Y ԡ`,V!|izdqg UL[jސ*fնUA*>X 9#UL~@DP,@-|Yp>z GbZ<8J9t).nlK!ސtY.bFY"ɏ,nC7x ŁC֖Lm<d1l^zunb:_YL+bҜ#فvO &˜ԯ0F8~s$I
+<0x@u hwq&KHcHd{]1Ѧw B]ޅГ-OJT< UNNT!@\rOYbSzف 2z
+2$E
+.
+M=|HSl^sB*٭>Ğ<lK!!l 4rݜ dҎk6k[zY@2ֶ6F]|H!@;i}Q6kg;kփֆ9K XamkomC;eopX"hۚZ|62hwڶ. m탂m=m;ؗﴍTg@סmڷd7m6PEr^m_zhhJ,m3aCx͘Z٤+fo٩&k"m.yK+
+j‰4:=Ia`կEȄyA 0aNϨUd1?6˛U+ / eΗo|cI.>mDz!!&d
+v&cVP5eVAZXUwE-ync)<ǣGE5ȉ)Cʉ:b
+B%C3(&'TfS$%pJYT9fbrJaBjiʿ-nnS`m727ew{7T:yHL nqrwИ"SSgp.^.c
+!댖Ӗ+1PFj/^U8{96ňȄT.b5А7'۽$ -)l!:Xtwp1:NR4taV6а)G^q v'1[y =FKo}g1{AW
+ VMG”_UcGXhX~5Z_c`s0udid5Y27\&hmЏ,oO:l>(Uk)WfbR΄^#6qvh}\);`d+M=GiahHХu5Tʟ +Yi =~Zտs\>+YS{gH\
+jr?BPaRntιMʫb5[N
+(0,KFir"\*\L))%wC
+[
+xhj$4aa
+uչ3
+endstream endobj 267 0 obj <</Length 2124/Filter[/ASCII85Decode/FlateDecode]/BitsPerComponent 8/ColorSpace 265 0 R/Width 99/Height 76>>stream
+8;Z\74`B(E(oA(s)<u,1UeP$7dW!d1UdNM6?6g?.;$BJqW;7<nU#@+LK-YB?3sZ^o
+'Au7a@VX>a5t`.%*=>/V!X&1@qAsq['(7(lb0V:b61K1ih=Ei!fA/1T:&[q?1t6,$
+o06Qpq02b!)+_g3.mrNT2PFW(lS*PB:l9A)jBiZq`<1Po0;;`'8]Gd%0Y3edasa(r
+F`+5_&I!iT/Y&[TiC_+1/.eOOfi*b5<Tf5!0S0U.YQ0#*cOXYMJ2[#tB[U;4(LsLT
+\JDX,f]bK)K$Z$+H1,!k:`8B)Pl-cCr3r9]*R=&q=^[0p^3]'pQ.d.!fUI_/Bo$,A
+(<lTG74]:F2LLgp@*XhWPHuCM]'<F.8fVTRS_M9]V+k?H+9Aqehd"VJ46tV;qCqU%
+VOM&"pp9;`74CV>',S96:?XLClM1".7I5OnjsuFFp@]_@JA/j('N)]9V_Sr0/t('M
+Ffc_\LJl=(nmA)(f#/AU^Jhl9Q+kUbQ+6Pppd-?]4JP'_Eq<XX()e[n9<\^#($.kr
+/>lhiSQthbJ(u-=Y17T!<sHKD7%OuR_Frl?1R;MOQ5[8(GC'St"3Vu'6YU#$<1L'Y
+S]:4T-j9+b[eh]F^$1a4_ud\Y8Q%5:GF@VedZr(JbZIp024G#i3r4B:<G_Dd<AiC5
+La#P\fsm5WdUrjn'b0_&oYgQg]IWsi'lnaeBCk^j2kOtSqrY1NYZMVH>H*hs8dFrP
+fR3Z)U`=%c=;b[$03)saL_A&0F5V&`J;&dd@HWjqG%"6!*O+ON56#-<!.fj1VCN>&
+Gi24;pj+fY=U<8n/98K#/;W\(-PkHnSAk1=Hi%ce7o0@2WBNmTMV(j>G!/tQ`]j0-
+?R*b+-#"gB8[4B&-=rUdIL-,mNB<6Z)(Nhh-e0G^--DeV\7F\[9#X])HMMjn&<BY:
+`KRXL`a!gpZL[H+PUa_UjlO+t]0!lk/4)-=2<r=`XB:g^4KM_-Y>f47Ek,EVO-g+!
+Z<%rRD%4Zi#0p]Hph8G,A9k]oG%i^]-<2QI@d/)Ca[A5a`2Yci1tW&A8;i]IqnT;!
+3JNrJTLDj/X6]<'L[,KC_pP^r+d3^^?V8^*#1@k%1rN7\?IS44>D\H&W,Q%!qcD?8
+8Q6]2&%L.$\\(HqOW0YUL`'tMXl1C8OcHgYH*N@io0PI_Z>%87*d:9[4WcjOI=;M^
+Ih)'KjL'ZaPib\8oM[S/1l&!Hl#\tV_NS>rZkTfW0d#Veg<9d%+1u-U%"ZUkF=iCb
+`)[._%dTKGS$M;.!":tQ"XXk<>unYSOrj4-2.R\A*k0[@eSaja+`sM)DGuUg%hP1(
+B;d&3lWmV#jI\,"]IQB4cR2_)(ara8G1qLTM_O.]5]jN-$WMk:o3,FZQ.si+";.?*
+M+it30AXui!JAU/d@4k$9R\c55.QZ:4p?TWe3p$V#^L#$!`q`ha_)2Rr%Q$pSgjM`
+[Fr>D#2u9g'@<b4=?VL@@MW)Pk!otK9.k05ZJfsY4#eD:E*d\S[4LTW#f37L%`3g]
+*o&`fK1gL@!s(>@%g7P]Ig@BU55KeT8dICM_Q9EBKl,\`(u'9UMoACl5V2p">9SpD
+hu-oI/7+:\i4%BUW`3)/@7%*d,8SW5IDPfF/4O91dAY`85.oLGf3+7IWud=)phV;:
+La1,s0;),.Mp[I1Me;QhZbBMu$ac2$].o4S<R0tueEbn'0k.qm>Ar"1J[XNd.!ss3
+pDV-pWP#g/;AOd=?u[Mqgro$bAM!D@o.$u$74?F2g#Tk4/,Q./]cMcjq8!-u8saDk
+s$g^fgHW)&8-pP5M*Q6`Zm!<*k^?SY"1t`e0E_b>P,+L`WMTOlir'%`>2;JgTMQFn
+&E9*,M#=f\dKV6lY:_<YI=0r?6h+9&8cjgAL52$Cb4E,]/W34%!"Nkk,!76O=Ys6\
+^5A6?>Jm1?.K$7dLVUgC9X[usKZ,qdAWTVnSj_lJrG;Xifd_)Ya81"7NA(uXK[h&u
++Vo".U,#$ZD2Qp!mW?oi5q<r,3kD#'$@fD%X)%&&?[*m^>:5,.k81XCKhW+ji8`VH
+m;Ik1Ne&+>#24_QX0ekW-B),:,6qOhUJkDqR:I\W*CR>B7$[K3+N3RL9<B!]me\=m
+aF=9lq6e-W~>
+endstream endobj 74 0 obj <</OPM 1/BM/Normal/CA 1.0/OP false/SMask/None/ca 1.0/AIS false/op false/Type/ExtGState/SA true>> endobj 253 0 obj <</OPM 1/BM/Normal/CA 1.0/OP true/SMask/None/ca 1.0/AIS false/op true/Type/ExtGState/SA true>> endobj 174 0 obj <</Intent/RelativeColorimetric/Subtype/Image/Length 4317/Filter/FlateDecode/Name/X/BitsPerComponent 8/ColorSpace/DeviceCMYK/Width 99/DecodeParms<</Columns 99/Predictor 15/BitsPerComponent 4/Colors 4>>/Height 108/Type/XObject>>stream
+H PW_3 .QT47r:"催H<ZĸR[1эZ]M⚍$Ɗ&Ҹ5g+^AaDN9Ņ
+Q) 54(",re>o5'1uEDFgnHXN8ɽ"[ޡe H֩I4Fj4tM$w][HDKNŃt!yUKK>0tJLGED1ݐFYI9uI$"UKD44$$&c#
+V+RhH &r' =1QmnFT6O\FKϚ-o<k՜(ӒڎSO"!tuM/%u2^Lq ۲&sO}#&kzdDrڛspjh٠(*7L 1 i ׬.Գ^GDU7
+Y2b t!C!/1Id~( iuްAJ:h(o5 ӑroW%:pB(=uАИ;M , 7!Yh2 0OU4duC-KkgY`f-HanTˑC U̸w(vf5XyuEP`ޠ&8^TsiZ o@7HyrUlљ$'@
+nz3ǺoNDcP6!Ks{`jz/ FbE
+|X9X75)ᆲoM `1 d79;g>EuA U?r{nZ[P
+Cd7ԑ0cW7<GNYsLܠHu;I`_Ye%67퀤<^ ^ǯ;A[
+><\ω r!ώ3 7*]q!"oƴN؍#Y)ȁ׭T<Ewo,7}k;
+wz
+{76w/&{6daoGLnx=.^D/* GvmTOWtxfyq;,<g;H'jUR y\V+'<(G a IҍksbNS+w< ImbKOdN9<Hsܠe<;$87`H#tft
+vFW8(
+\J &?+yYU㿇u
+ mU: ♍!N=<Rt/$AN݅Ep&/G?EgJtURt P8
+>erC[mU* P-9:^~=VtXkKxnѢLbcL91Fdz D.E~-
+_@aDJm f wdt;1Q I 8ϏbsD#]y<Pw@{7ޕ G@jKN8?!pEM~-]Jԍl4cK#"dy⡛Wnek>穒c].}ӫ랄{g UϟV%T~.nxN1p^o|gswo/o9[{6y}k=au‡vֱ~WeG@oc=<wn&o_Vein$j*JD`&ʤg'|PK-Kr0 56ajd-uCl:0 r'brLL䆕MB #`05"&,f:ܵ =tоfЍtIZN,gMn@0-H~p@lb%7RLp_ pCph\n
+(CRED
+ UP\&+&
+E͢^q6bHhTK4X
+endstream endobj 76 0 obj <</Intent/RelativeColorimetric/Subtype/Image/Length 1702820/Filter/FlateDecode/Name/X/BitsPerComponent 8/ColorSpace/DeviceCMYK/Width 768/DecodeParms<</Columns 768/Predictor 15/BitsPerComponent 4/Colors 4>>/Height 576/Type/XObject>>stream
+HTyTSW[vb@!a"RmqRAAb
+VGebV2Vu%UvaGvBǜ3}w}~~Њy3>\]Dz`Nb%:5><FSh|z1K;eۥd1c% яf\[t e >9 f|]ܩ:,$L^̢ 'z?fǜ-#wF'i/Zl)kÖ%49C;Sa1&ofϬ_lz֍ףr.0>4yFKn1~;uG29CcfGxga;sP>HYBPIn
+*|i3k|,8t 15olC{caLys\F7eOrFδfduF tz k|Ζ192H  <C#8NS5:tIOQc3yC&#t| \ s_x5|Gp\9Pϒ;螦^1#((cFai{PooYstmM֛Vg!X##4 
+'0(oyYhA6L<ӆ[?XLsӵ[j=n}zzpb*Ԟ"̞9⓲ARXtv}z; [<mvlM|c:UdKU)ئ"آ6/jYsjFٴzAk[U=6F20f-B6F^\L}}Sa?p閽gZ$;v]mZ7)N{snmL1aIJVrX~\ܢ\h_A52:7K}:Ss3ӆ J\Kzy4%lPz@wb_.zy]7Ϝ+/ˎX3mp3*:ߠc3sL-:MbDAw5u<;GH@zixZXǓ]u[[[⊢nZX][*(OrqIx9^Kҙ˛of_!F
+|,D%NJeD+3}L`/ #q+v1Q^Zuz.Z/uJJ=tb Dqp9.Zx 4#JQpMt"Srڨ_&—tգഢIL@L+L[ òc w{c6 ǰ۰8U2f b}8
+(l DB P@}?G2OCuH:fxY1z,$3zƥմWB(p鸙ѓ5Щؽ~P7I}Q,(5A֝(jq(-60Ā6#Q/"e/c u u h]OOnQ#OE#x6;WPI ~orհ)"\Ibʸ)Y/GS=xF2U-幮A4Z9Z<R#o==(s-7cjkC0
+
+L8`W, }`C_<d`P? D3yMH9Sn48]ynqFvtv?@/f:E|mp| B2 Ag8
+ cOvއs8hƫ
+قγ [ͻK5?vhM.[Q3ĕ$ɋIQ->Т:ֲֺǶ*@j{jEZ,-kEE7
+HJ HB^d3<nf~\Qy:AY}m⩆NI\E&0D!Y⪗ܜ_AjJ@7Kx~?z_KIPxh`r슑ʄƖT~c~+bm=ʪNX:tSYRStYNՒK7S%0d}1&e:ۗ
+N,6 z{ gZWKŜ,T}}ek_V{9gPn);ױMqM:|ƅ)[.}+{m쳲u{>?ꏧWڛqAH ֬Fe&qޔR>0.'"]*oۗ'ogo٫8-K?XX_!Xa-ձ 鞦-;~)CV!{Ƹ
+f'ET؀IF[JdUiJ H#t!B;s Ixeiӕr!!u~DH "=aкfW X
+_Ô)HxobďbbHP,oh"52)b:)FiF<'A7NIȒZ̙OsZFrELN54LҰ|<{Z0q`6vFTTlN+6 }T'.쿗P8 (7pg3_YswBG[c"
+F8kaKU憄_(yίԺ+.%GcS6E~$-NoI V
+څ O
+Zl]gp7 ,I xpgt\ 0ZػRK~%qAPE3Z(LI)XWS]]Y6pS
+[eGOЗN?۴]qR{$onq "J{r_ oƕ WIvvSgw眾3ls Vԗ}QQ#Fa AĆ ~@
+@q*cA]T_'6gzIi.êK7,cvއq=7A1H*KvG?ɮ ֿIDp"Qyy|sn[~W+sVo@"<bT&Fo#vOr"@|^a䈡,˶u7ZP^m]/j4{B3#kƭ:bh/hhDiP
+ȹ!&
+Ih`=|_w,JӆՍf^Rw^^]pѬ`r6Γꊒ{%~EPgYz赴"uJZ]B_\+OS``)pS?wT'oU|juowf%w9rn%:uGݧ34~iϛ~Kkͫ QٸBU.yQqq.󨦮4%/!bXa  jP*Kǥ2PӺt3u*Z\^ZG@ ,AH!yK2>侼w?xW+?_^.x܅ڬsUOլ]/=Z| [r.n~;kN~N=v[|^џrܾbm^0se_//?yE>;N^hW.yoxvl3%ұ/^U,>8df@Xؐ#N)"պo{NYl* {%# )\U,Qam+? c!oVH+S'~8-fDUTRh)Uʛ* RJ"tJ[\1$gs_I_ĕ4/n\s<Ss12ba:؈ᢃJRE n/}$\z&3J}fϺOħW'fjC9BU3W
+7Lȓ JϱޏN:j'Q>3g>]iCAa-#[}rui'֧\x|1!P4㝭,P|pk͎+Ͽa٣6̎8^#lvgi 3n<\:zٲ5 G[nݪVC7$!qwTxG77Iٯw{?tڱ3 pN2ؘ ~[$|ߢAt
+j(`&
+T0A
+RuT W V9RX* ?ڀz7v8lU-h
+ k]&X-L6B1 {@{/~XNPv wJ)u` #0cAx#
+Y>ks>]8w3Mj<O%Mw ` 4݂PcQJma*0.jl`1<oi<"ٮh~h՟׭T?#Z:A]V$_V$g=.wTCj-Ͳ_s7j80/L
+VMo t>*y(#D
+TS& tvk^a_+z Vve% xo RI텤s9S G//PJЀdTECRb*zg2^QM]i
+k l -mNb-3|l"?(bٺvI1Qi4HG_quV.Y<*W\oşCO7o =ڜ ?i;2g!Kta&b嚛/Zv9ܲw͚[K]R-㱴[`{@Qڎ+C$7+)?4|?_D᧢_=.v N>7hUѵM.z:-2hTӲ+|#&XI9bOV<P04(4]&N-1HTWl)a;n008&=dճ~“
+,Ow5Ĝq=mc 뜜t:'!<Z`@dP:N-9A
+dž6
+&ߤQ 3(]=T~
+6$] 7:DWA4=O+g +.K g䲴F.51p_FzS(ݶ@
+E5&/f/08 LH
+߻-dy.a?aa>+ec;i0NG٠ɠP새.D1x@}kcE5yʃ+tSqa熾9A'z`
+(UZOa[U׮n[ZzUWYP9
+J$@0$LD2 MW䏕 r*$`
+ &\mo%MvL,~5T /6LZ,zrPo(zݒ:Xei%uI
+/?]cݟ.4~{N:Resbۅn{9eNGn1p׋s꓿xb o,=׃<(Ju^too6нvqE%Ƕz'nj88c퓣7=_n߲<QQy]EmiF,gYp`"ADhGD>!zbr_vp t7>T^]3xg)//\P0fT@gW=ʚS}?s^̜uR3U'<O&mh%ˠZ+ @PSga?@ 'J;4#ƲY```p25cn!߮@JX c!Lo|uY7`ŽsiW%Q;)eX߻yUa'qRMul8E\{4 3GEh-9Һ=@ȯwyQu]>~E'O}feN!q8cWL.gdl,߷~byEN/(EBE%7 +r޹5^3=^vveBq֘O큵:X* IXd.z9^ #W
+v~v$9YD"n1]pDGF6d .@w pܹ#{TX=YÔJ0*
+0uJuucj t/\?xj]/+"]ŏ72j*{@BX5A
+Nz\騣Gj;*n.x@2:ʪ $5 $lYPss_~)"ECbF=%8`  xN!`m6)R1qءu~nSشZ@|ᛥeQ[Y9"g5C7y2f*;ZSԗ1G+ȡf)q~\19=#B\C$Od`q9 L
+a%ziQR@ma;`/JVycƵ룯6oO.SƵqōd=h\SҰpZYGLI//=U3sMOj%Yem"s^szE'e~%! H~hq37ǚiJvw9ִ?bզ+SWyfmOQ?,'ޭ[|zo\ f^p~yISnUtv 4K ѲV΍8_smE({狷?Weǫ<~m5RM˭|Wpy_K{Ӛc/d|CR3qyN'tO薒3 v^Y#5NZq&k_右:4/R}7Weߜ5'.m
+Y0iS#Td&fĊ
+^2bͶ7EPjzskVPnW~bAs ϩzU4),wMXTS<s~哴Ĥژo#:C룡 JCU^}Gar kj|ŚoxL7V*e^Tgpj?<qP=<G˵RzX95yaC enn?q|Y_}!x <lG: s<), mϦ=՘\P1.[t}6͙nJ]2R ͼR1CQ'[v]>t/tvѽ'x1][?akG*SWOcli?U~z҅"vʙWk6@Ko΍9Ք{ #Nw9
+sJQy5[[
+ ڞ%]??4gI(۝HaNh#6  `? ~H'}ݗ6r'YmPN'-L?ב#\ְ7`=ޘ
+65
+2/&{j,/YEmj?wS*@;MA P@4E8O?>Ub"B"ahYȢu]:
+,q#Ri%M2# f6 5;ANCGsZG+S)ШT=~~ryo,/ 4#&Ib7Bө KաHwH_o?}@2irjo$_Rn η];ބĵ5Mkk프'y kxr^c2f=cdB-dj.(ekJ {Q4ER@ǚǢ-Hv>-4΁D&E.H`GDvC0Xj$Ð|"{;t.j
+'#B G"́$H63haV}Ón ڭHOUY~ tllLocJ ~p05v@1`Nptl
+p
+62Ɯ@pY>kdj@Ie#N 6'ڭYM6DMWr,E4s%.Y@
+dKAX`!P;#-#ve=l#9i39s WX@ߖ43
+-caY1<0L3k M n]Cî ,J ܾ7R0|9CȯvC"Pd-b&|JU?XҰ!˵[j[Hq-;dx¢$(D<<ZUJe
+Ȏ(l΀Kn< ~[c7W)-YRTy_Yڔ{.CtiCJ4H`K.ڻ#{Uwu05.Xg-^dsZŵ󪎯ۓC|ٺO1 GfiJN錳ϲ~:I~'?%d5FdݕC<٘-_smvCkrr6,ziVen%\Iy7+cfOM|mw~|q~c<cl !ufF51
+u^y}$Ә甝y,PY `dTt;ʴ֎:k54FHYi?O
+ N!Km ?d
+wB ]
+p|Bjmds\<<Ɛj*zIQW8$"|PbnEi_c'ղ"8aޡ7܅6ŽpIW3ϸZxy[h{DsbwOIA֨+׏V&W:%W8mE0 ! J* ,@ 8G!
+a
+|x}?4
+%KnHj" qZ
+}o;_aoJ `^3<c3Ah!h,5.
+͊e`)RZpbed^yRxUUD+C/W 9[iIq[v[Ƽ3[c
+g*N vV L}t:|DzwȂǩ'/e>LR @٢̠#GuBYˢu )[NrOM=TuZCñdU?V5ddʑ7f] l×%vZyc?t_p&\{. HvfZ <ĎSjR")OV_~'bahQ ?iQQ\\y7l;!{E JEE
+_
+`U,n$6Q鼶. w~j>)Oc=rYW)>WS5&FWyfzjpn, )նQHӌkf_~&l&^$ݘyPvc_љNzsqE窿wsCU_̽|ֈabԽ$Պ?P!2<=Dl T_aؙmYה9mcV}9
+ Y'_qv(~u]4Q4OR,8hDÍ̓82@@gLj f@Rۓ4t[@B  УfNӇ*uz*_QݬVLI`kJ@]ƀzk1Fg;,H? Zɤ
+#?Α)𨘥[ո93'bo=o}yb)2]*Fru!2$5LL .xq9rSE9BN' "N0j/mFb +j-.-C
+ @_M @ 0`j!TAUI ~e;Deof^K @@ȁA@`CK[UyY6@aqȶ(K%9 72j46t=vI-Qڿ2JOD>Ի.ᯁߐ]48} _Ƨ\9,Q.I%Ʋ$YvkVnpn]i_ dgE:@n+l[RqVD PFL:Ljৰ&Z+ǝ5rI 5b[S"}SZmGFiW_dQ>%ia^%AWYy]4XY~.q?ivW6nc|޹'/IVt:,W]roB?t^i .X5:fso"NS6ļJ >?UxmǕҶ=I4asZyNoTU8ýI;oF -HH8nrLPt!ME)mݶw>8}zw`]]QZP٣ӻݧ}KqW@ikr+涥,ݿ< ]P٧e.ulwi\fc]W9ɜA9uiMa6wY%uDYfwqNZSҩkMޛ#4a.yiSM`Zgྶ(d(3$IQ6f^yǻČ]7M87C
+wŁ;;KyeoݺE!.r]rU߬?j1<Î u?_7ѾTgd'q-¸!0SN|L@hΈNSӜA9Ϩi MR''uS '3 pinMhQLq
+kْ$h%<Ú
+IH@:D@4 EzDuQ}FgFEqV\A)&tqB& $@gsOy%*Gh3 aBX#:@t!N%w m#j[w,$˥n2C
+;pnmc5kp(-m&[FmMֺ5"yͳȴJ"XB fi)`P=1#Z{vZ׌{ ĿJWMzV̱* FH
+įįY BAVn@- vp t >=LF 8gBYaˊzLɁgNJ߼YaA_
+Sa8`d'aMDx{a+CX Y#\3"|R,ҐO?
+{Q[oP
+VqY3b" m)aC
+ Snf<_@%3ѣ0CT0 X
+(v}
++ˋ]^LOA9}G^W{^{GfiGFu;=nuK:8tHcqkη3<\Cus%^Ewb.܎]\=Ρ}̈PsD89[Āy thvi{N d3ei!A%'hiSޤT^8y;}/O9_+ʌɊ?>kВs<usjV5S.s#P`–`FKCq梷ANEA
+a*eyW{T3 vV{k  Š1J|k\`p~: ]ty\`l}j5.-6=ܪ;آ佟vE˼Z3ѵՕUG,۞W kl
+-+b0=- z|ژk5&ߌܵoVs~am' ).~3YBU, \#2tpό(?i7u濌yTSW_}%@Ha0YDj]b#8ڣXSi.8jZ.,
+3(
+AaIB/?ywws^,:?Nh/*; 02̏1$ڪzEu lZR.# N mt n6  7sMS0M!
+pZT@oC " =
+Z-9|? ) 맂}BrL:w
+`=?{TB*hJG8Iᴈ_蹇P.FEG
+0
+dr SDkGp
+{</b6Ny~^蘖'4y^ȠЈ3
+EzȒiE`Qڙ)gԉ1O5aɚuk3IUig 4=YdlZ~eyz~t7v7p|xu#8N&G1cvx;OQV9f!Gc̒Kfdi ""i݀s(Nk<yO%n P;dN:b(KA)P\-w l"j@"zg뱂0ɔ$ f k-E:5
+B1 31efP',&
+MP@KcA)n$9 |Aa",\'2P4e#x[CJv>~ݼ/J+e#~v@}D2Tw*lBpL1=8~{9\ƕ~ف&SOb>qg#W<pz_~-3w?wnYMyxoc$S G١>:ݠb'Q:*jdi+
+_:[byG8>/<jK]?…vO^N9^o/eԕ$d#! da ",H)@ֱX:QGZm3Zku3JձbEP 2TD,e{_sr߻{ݗKܵ%kKPC3g4?MkKvZZsy&[P/
+m GuESRAྰ~[vw.=rOF|z}{Qz]{qJ}WђϲAgdX85qJA0/~c!43-[k7dV=,/;|g'ҳjHż
+ٵk-%?ݿ3$?lF9-Sפi?,t>
+`=]G.%۔3]kop%z!엚Ts Zg{oCH<ֻ/Kw$7M^aH/`u7ʶ' Z I$L iA$-@5ϥ$,Z;E
+$
+\MY&HAF)5P'ҍt}źLwX"(n/*V<H<hH ⏿K^/|Pi8yFf7]`RKhE3
+H1< Un\ N|(3f眙Jqtޱ"ʝ]=q(ƹ 0ps.,y<- Nf& o7H-e̓ /`WK_k.3=\sxHt $ )`G MAjƁ=\w0 h
+?-3jE}{{[{q}Ǿ \odGԇ
+)zֿ+a,$)Z=d(Z3_E,nUdiLX՘ <(vۚ_WX{4vkI^__~=Jߐt=xpN;p/ Bc24$z϶$_|-bﶨo94WH+iJ{8UZUɭT\(5zqN|9d
+5v ]18c`$5U`2oP+?i> Q>1='}?RS>SMYanC[HvQ1?1.|1q4T.7ouM,K=}T5L#_wI5x\]  ~v`$.
+ =x**JB %Iؽ]|{H dلԭt{6x5"DI/3)gAyatG^~׹ikn=~kpnMB`~]|PAm\سʵU(:VV"6af=nbUF)K
+SO;z ٮe!3y7^?ڔԅ 59_=ޞ4wlNyq᳓S5<fĢ"J'Uމ==>_yqg۬ ?v<3q8Yyg]x{ܾuqi/M)ei6_.YRg
+;PtW=xo|6_Zρ7E?v/?"0,0/?WW[W]ocj*JuaRiilPa:FEƬռsUΫY_V]_uC/ս t~d4y~{ް&60<4<WύɯWplKkFAn e\`k˯޽4]򢣽hI#wŶ0Q$)ll  h,$^?ȫM}ȾFZHA)mW\Xy0Ι[umiˏ#eou 5AqW ;)@[vMO6Gǯz~k}nt%Z/>ۙ:?tIfr˄\h'c[/|GWR J9ê4d$dQL,er+<pGTA#aBfatif#rJ@(Mȭƌm^_s Hkڣ }Z{d/A7b aXmi. ١Z:G jx#٣{=2b/1ѽsL044XEJ1J[찊Iۙ "~XɈ–4J
+*p"9Яu0/0o`
+\(c fb=wj~PDOI%utj-/S"+'i{+Oѻ,a;}@Ht8t :
+DN {OʳV. rELit%-皅*jOuI
+H}|;B#H^B9f|L4
+2=m[<Ku54t?g=#6Dtzj/fp^E@Dmy4<Yڰʘh3eؙd{D%LbdPX'@9[ղD즽_u=qbY֛[v/?76/&HRHiA:֧l QOJNs>O@vX 4
+~B[(8AE0+͖Iw2Gszv\%~o;kl@ fZjdhY(նiy*'ja,UB2$dq9s~s_Cԥ6D$4٪ElؙcdpxܠRsP~pIC>dU+CCJC3Llh@L/Uy EE?~sֵ+`8|GP!%a{ses{87;Vs:s%[
+"G,|PV
+<"k/qaމC#c-tu!P=PP=ȸ/:0 l
+^'z{P-oaa`z@(t7)0m@ލ0dbLTHmaLLw mEɬ,` @w
+k4
+ئv,$E 7a$HK9HF`oab8EI< +q@lHl
+@q<qxBQSý'h4,7 2 ar3ݢt]ݍjW~@/K?DdTv?rR+Z|0R.C1hK{F{xi<4<!D:A[G[~
+1KPsۆEjK`:䝾ov QGБFpC-)@iE P'JP8n? ލpH-)Iw; O
+
+aA4xB*'zJv}Ɣ$0]@CoROXg8,04
+VMu+eŸX/&4+`$KZE"
+nbAZb-/5-Ѷ4i"At 77ABaR^%j< N> ѓ̈́!Q4r B>>E:M .u=jF)y 9i!8c-
+N"n&4zFN%.oLaնr4}zӾC5;o[SX\'|EwCY2{1?d@*tJO8Vy5=/?CR"{og
+FeUE6iocSԝ_lXW줖v0*Q Bٝ՜.*DVrUGqZ'698( b7
+AP/FUe`DEU]9Օ"7FmKƍyز6AXȞ'-I/y=o(8-D/!$8 jI6U7g,=wWuAddte.5RV9s
+ݢ'Z}vJʓkC6տ.bm9 I\z a+3ϩ/=w~Mܐ򞝟Bio\ Z0&Lu=GVȕSsjef82*8<o@7\j| OIS\Zu+g>z|-Wb^Xfo&$AaF2a 3cr 
+^9I&)zsTAPF$a9/0c~nP^QM%k
+Jڀ)ˆ-5BK Sb=y<A8כ̀+1DL*MH3dXƕQ<1+][6
+ 'g>R]mĈX8\Dv&X8J"D8NE|0Qx(k(& 3w$/\ =!Ml<zN^aYF H !;.
+&UɦRp/M"
+h+ᣡJ!2\5}EY?JEQMjw WJGeE1O'LXQlYB
+C p
+b XýLri&BҏH1|i!W_h`ĿLF)Id$ []=EML0:=O>»G19IA_(k)K}&(
+Qkc p@Pmn|SwƀIlײ`r=gO_<ܟQ)sm/g=~&SDG{
+j¼˽i &}{`Қv<q
+jsk8Kئǭؕhv}4Aj;u#2뗢=Hٛڞ_.G_ Icv;μCWz<Gz Cݎ.&_=?wouiMHm:a&1BmW|yvDmctDv肬Eʾxӟ6q}=i~Nκd]%NH-dݵ]GS)ǨCOV
+@`}}oSk@[o{>U6)34`
+:cXu|}@)ydnX[5+b}JԵŒVH`.-!.sڏAAܫRzĠN(AvӋ&@Əl Əv`z"n;3;s\^D3HvoHoAN"!06q}'H
+l[rD/j-TZKr2iӳlٙf&.XdA@lzF{3FWI.& =#'n?L(5d71 PT?<Ze6B㛥hH@X IH6#@-Yq8 [Hyx0):, LҚ&ZtKe>k^|/cK3 -l̎*xz TiޡoY+W :y1+mA$2C^ryn嚳Ynl«10ysXH+%C+kHP0^ie߷}ٮ,96xaUi{zhqGVwFyIDAہ]yÅe }T;%`
+7GkXIQAx133k m+
+B%ҀC6cc/ NRKk09v/$kT]9!Ёu70
+ %8X?b-*ű*ю9hpXaeRa̝hcÚ&"'w+H/ _y%hCPnVa_3踹+'xg>3tNzQzE{Ir{\v'_wLܥgL2Kh(`(0pczѺVuX?p>W^]:4r1~}YT
+yK&V:NI"R+u臄 Zu"A͵ȰL , F[p^014
+MLS1[@ywz_x X2y%nUIY^8S,8®;?ȧ\ͻ7O.}R"<4ՉfA:-Q4a!BPbK{6dvӛu
+wh?("U^ݖk5eƖ75lT q]/kK37'Vo03z"wG}/IuVed(;z~޶?Nɻmd|uW!ǺBKd|{s넿lJ њqjz+Tlz g|jᆝR~SnGן,*ΩpQwW/m-Gw7}\TmKyYjvks~Nsw8zBO8Q#v蒖e CぴPT&Iy g6o^Z:buJ[EҵK{TfMRj6Cjn?yپ특$3*6&zck/t7q\mݷl]dɕcH8
+
+N(!h҄I!4)0IIRCi%8 18,:,KdW'C|}oڞgmy;RCGku֕umj^Xֶ箮]|7{@2/`Mڴ?fbȆ
+)2=BXDʙG3qJaB'# O
++$wH oFx_HŔ?0qh-hZvkA1gVJψ(cBj(e2ET;B@)ח
+]nS~N?ޜ,4_ND
+J&.T7cVEA6@}*TNc!~!2 ~8_ 7'<I4
+I$39`9
+1M+!@ccJqmop2!
+84KH+iH?}ҝÇ;G[mGaR.\[2 $Y/eFC{/U?Tfe=!ҏU4y.8y!p.B6H"rdRA-X^dlᖱc[%m4Cr\wĴL߆C/kX6@ְ/Yh
+q$<OVVG5Ħ5A&*6N*3nVߐMMNiH[[{#%vȾ=ʏض * ei5)j?M=RDL*d?+[IFnh*n,KP]WY]!JA=v,y]T`ma
+CGP
+>
+Ϯt,0sy=Zޢu ׵^ͪ/OʺU:xR#\NY5u:z,lS^J}UuaP~Oт}<!y#h0%$bF`.]=;ݮ*ZV{JT=-~GiOxWZPfCt`dű mͿ:Zd%d=̌JVz2$ud.QۋT cvqMFNoL&*8XD̴ !-S4Q:#0>Ā
+(Na02`Rփg̳K .ߠC̠}F
+A[X`
+(?kT}MCDIN`O+@:h4L4Kh0޺1vczi&)
+à%3L$y0XQi ԌII"$vO#v]Y
+Eqh)0Dυ@m>蹠FA+B 7
+CК&Wu/u0L;*BnK-y
+ꅌgKwWq~R6N](;o)؄d9Fy97AA`JL_{+C.u<\S< j I] -fDyTSWǓd [#.T*;BDDcmVzbv:shXQX J7D*V@HHKJv} msr}/<\kRm=WmyIt4Lz(LJ ش闄\=@_d{Xyſx+>P԰kc+F;4u2c#}y; -
+LAzT1Xӽ-./ԶPtU& !X"{Xuo˱C}"ͣ =}*;|-Qyn~1' ^K;xҪ Z>.Oھ[Fm57]xʾ>ۻŕսu|XP˞Ol+:i1pՙM8H~Cѿ_8#\s\X߲kβG-|u?]R!u+ֲܶ"QPpY\
+b`ŕ5sJ?*sRH=IEGAyP6TO?`H ,Śfe;\pҶӒt^qtg[{)KLP1|Qݢ)7+ `NMρe74k2E*!W/+J wɏwOR-Ek&hZUhfp̆
+o<|lV
+ l|r2i$xeA
+jO5Po8 IAB]F晇ȼ)9kTk5m!rFQIեG\<~ڊlԔꟄ0CE`TDZܓhۄ%yH{
+ED{FQQ S?N#kLQX34Rx˜HPL'"; eՐqLyJ5q vEㆧc
+6ijclܘ(X:+,#<50byޞv^E@O_i2bcT 9AHH=DR ;2!ÐZ`>N R20Yd_X
+b?;Πdn^+ 
+ړBfaC@h6hM"" Z{;YWө2KAeh Q ;R<PsJ?"dP`s˧02'F+=1Q`
+~sHM:?fn3}i&W/8닧G5o"5࿰01n\Ϙ+{~+  }QAUcQT& a2E-#GjUmU+cvbe* egpZ} @ ٓ7:3NOysb07C:
+iR'0 +
+o"A$of!^aC1,Xq Q0C3IE``!A0 zL
+QuÒ7hM`6 hJ桙iqzmy'p6Z ld kwں6FG?hڳ? fvK.wCJsk j;6Gu􄄵|qF?`py# &+`JPאV~oF7[V~} zmsguN.HNբ}UIΜt"a߅q#b^F f L(a}{O0(Utu4mmJrZŨqt4 H~+L o~g
+3`l'B"[7ߠ}Eڭzd"p9.̛8y
+kj oXeA`[*_RMRA'n\y[{cRw);l1SN}l -F%x,`5ce7 Za*ՙ9yWO|2X9%׏xQ{[{eGׇ#yD|^Xamż%Y;~F&vI 83#E+QZpTs/),~~/>cɁG7>;~mOJ5pاh:g GN`܃d*yȌuǞ>O)vw<c7S.|2o; =7V\7:>#x*5Ӛt'.ܞ
+6YT _]Yg>( F'3`C{6H]qcCeS˂Lw:|rƊ_[ F͇QĊ) j﫪N_/vȔ0v;74*t{{y;t>P|G]H|[]Xܣ- ګCa~rKeDêƺ}{64BT'Yv*9ݼ=qG|Wݎ5[!s7}Φ;?nRR\TTWS]Ӕfw&Z_/ί>5XutM4$DӌRAMв @{'`y95\qd[ŏ֝z]H UCCl_\|>IOW8&HjsV
+xu˯ϻϮLqN'1˦ N}${ߏ):1KcDR@ڇdq6>c "iM7q
+rD%EXgGSl+औJ%$*"
+9Nu HNx;DL= 雄F@~A
+$S;Fq_SSb5mih$SJ I:$Π&z:Rh`fp Qu4I DMB*MT󒙁3 |]=˅TDng/wU0l.d 7y#Qv+5voV(J4lG/ҁ0d^":HDto$giY-0 B
+BX<nuDѰ"Vi3X:qTP*(:JA-
+B@%$l&!!lM2$Й?~9ͽ⤸90
+dp2U
+ 9h22c2Sγ m#<0khl]vi3U͏_4xKhÐuG1r+f,L~H >248,cR;yjM}`sд,7nYs@8OYL LO LLC
+Rne pP׃l/Qq=V\`C͎lMPrc$o[
+ht,>~yoX=gRMe|QI_WfWܱ|kZ=xchCT{ lȮAZ]=lՁm:5XC]$YvvIh'Ҏi!Zt/A8Ʉ:Ԧ(V~d]%.]?Q#y_.y)&G77|bEѾ;mLUemU=*J3v?cg~z9+PӉiu|Q&$GV٧'\>2[t9mQ3*3#\
+
+pqs*`/l[yeBkN>PzaVOQ]9v\~H7nUSW__YQy n 琸rl-\wbYSSUkś#J⢲زqLiaĦʸ%g^ڸ;ITlzRte50ϊVmm"yʔ[kSjn' NXs/FLEa8ntY8$"<"!y8=oW_ Qv55)Q*bLzM
+R PHꭣ^{m^Gx:zBPr"XKN$@&_m997CA)s wc"+X>AKxwMVc6#VZ4!`otsLn>|%yE$/C7SMv0} k5܅Y`xbIAigL pd ;ʞR:A4 tDaY *GQYhX BX<j S @8cGL,$QRlrk|ؓt \|G2r d0iXC$&{#&ԶDޞ"QsC*W֨ʁ+qrmR @\!sqfor`] V`Y Ti܏6c W :n1m+B0Gi:~NKKko
+ [$b"2ҼWٷ붯|wCűMS\Ӳ.RyHsx $Z
+mL~Q3tEXjLTQms:PZ~ex>Ki cL-_r,0,Ԏ*5:L#"Ihr5VpLz6}"k
+uMdC=nx7Ks>Jx" nv^_t ݸtہٽ;m/ʮΦ'̜]|3Etꫤ{I~;=`?_z'kĽVzFҭ 5_:^OzbZJic1H[<j#-Rvp}D<N$ϽX2.`+My@ҳ -) ^>hlolW ~=o([y;b/lYr1-ˌ=n=L;]o}~A<(w~&7DqC/[cӛk/o>z#.:? W((a3)uڛ3=:ԫɧ|Vͱ̪aO-:*#-c|s|~Fh0R eB~jeA\/I.I-T cj#¡`$.]PYTUreQ$ %I;O3<_1jݶ򸤆wXͰoo:&7:^އ/::7&׼
+Y'$,~{铑Bee0H&=lY EۚAabIg%x{+˵!ӃU-0QRCȩ:'(+qLym]6 ]R
+nes~7:7.Jv2(SSsKyy_~l߹.&gf5ISB+@
+VZZ-DE!"*,.Ǣ,ȵB-m(rh3M13Im˛y/~[֮?
+ap`D9 ,hh|̕TqqT+7mL]Hݼg>f-5w%4nh$:jad<.KB#A)!R”! c<EX.츒 ~H嵒*UqXՊA* {$> Rᖐ[J1ʹV)m#TRI^Hv [JhDd|f
+HBAvH7鐌Gf<unzTM#҅E-ŬiCC`3kca;@E&{;0~]l\.FA+uN4ï#D7jXzX(C:,*vLw@7TX?vL$";L bN0D^w0 q6 )'u*,f|<DOD8) NOG
+sG+>XM~KFgI2vJo<.~?̙qhԌ{>Bb<C0ÀHC<.B
+ Aqf qB(@E<L\3pXTqܸo4McyDa?&b\qsE!/Oz{TP^*Ӎ7gDdP6yQtJ^_l,2Ӯ?]$ $r^6Ӂ "8'#[OqcڬkWgN?q<eyq9#t1B A >ӷ\7+/~Â%;6|D#I&e<XovS~z
+1Hrtk{C3d'KJw^ jŢ3毻W7|Ӕ۷'P/(~LR7gǟ2/ɬY{# FA"}C
+Ň]W,Gݖ^T[OnFnn\F;n36>>0y᳴'l>a{hٝ]?xq[na矿iݕ[skYC$~|e]y[5fï㚸
+_ߟُ,PQ;/ymӳɶE7T˦eg7mٱk^{'x]⢚su%粊oV,j,Y.27_J_|-9.PpzySfmk gUd|¯~~yKwmAk(hN-sqi%o=n[Χ6UdlurŦSjGF٭ @-#JvFeSq'kvk@(2Ua TEp
+z eáh N?Nf<l60TG+g1/BÈ|SMt`f9e<\IwJp:qOe*^F4cy
+׺ Wzjzu?xˢe~3n_Anݑr[ l[ t0""Yi֩1DSAs.\(=%l[^;W-l`S SnTh1 x`3L~ M\/f
+؀/1WQ iXD0?lHFFl=`*@h0-ayb1@~?$XTGj{~B %q}J hj&8
+@3d :Ss=1!R`Ø.vI$1l Mhxh*LA)ߓsXgD@
+fW=tN
+hMh2M4G' opFF
+5o6$Vs.q1aeH|Lrĸ#!99 ݸ Dv+G~\R[1b-LB1msI"lOHZu׶dtۍTT꿜QrWf<ו]z{+K箻|R\)))ҤP`#@T4P0BVzS\lykz%¤x1{d/\`:'!RMP
+5۩?6J=Ӻ!~o! Ɋ͕=}i~:24e]˭μ԰nw=I'69tǥs+~.Mh/M:ٱ9tƸ}Uߏ:b=nH6Kw=ъ@Yns~T>֛&MtݶFqch=[>>
+X!C 9
+T_(:.8aߢx4@`ֹuٲO̟CbGAz8Ҋ^
+2 eFA`g[ἆC(x
+ Gˏ o#>g-K#qőBӫ_ȯn\dʘ<jѧM?SZL`r8k =?Bq*V~Li:*|cΛ="}]N
+&^i=R[@vh݈(4]TNd?Oki8OK:%lιӶ6<+ e.[QvF+DZq*8VkE:KZ[eE\PmÖ&$!B澠N8wKr8͊YvS/7f~0Fhg>2^ Vų?Fԉc*_^DmlC݉C_xNfSh׿]L/)Y1+߭:wiZݏ>+/p}=Vi+њmp}oq[Y'qk ~{T'32usO-[wΚ.}OTO#7tkϡY'ҵ;={zd6a~+XH P-If>՛_}s?궊ꉅǿq }iΙ%5g2Ug3g&gJx@޺ө):67v9Q:֬\}ͬu+05d~8*mQ~yJ\Aٲ% +n^*,/7ew &W8PRFNn[\uGwlA[*bpH]G\iY˗ goS7n6'$<.2Y%ş/_k #Yԇy++y+ r/ARyѢ{ zpsg)ْl,QF/Xm8{9@VD,D0
+c*Gt`lM:b#^0?dĢ& PE`Q39`
+Clv8| KB^<HL%4BR~ NU
+fmt0h6o'`!p'E|4&v<֛<NIr8PM
+A> rp>|8B Ci#ɓ,Y
+^N IJ/,`RL2,m
+fA$ \
+ !Vs=[:N;
+ >&"Zg( nP;%K/bu
+J(P
+{&U\yJ3пOѻ3.Mxb"PpeuX/ lڨa ,n<:=µMca@j5pBA 4P 4& 5zj01h v'ԧOeA߷ v(`Y#L\[sjō Y[{ǏZ\yAz
+o. *$L*&N}ޥ]Rq=߷Nxbh g(k*m7z@X5$?<cYɾ ,-
+A6YpR|y>Z([qCAV In܄ ]L&3|_*! \Wenv pgsPqW-DՉ<uA!n#4lrV^Wh5}ͭF9nTİ 쩫x><&ZX"9`MP dc~Q6)K t5G3ܡnT7#6FD =eV"Gvwhu#ni!:qM~lLPb(fXh}TvIZ:IWB5^(j
+^FsPr5,$ a*Ɖ\`„t ZIK`A-:lgT7ᢐ9 2{r Qe}0p4X!0
+icĎ,2 <c@;Yh'w`)%PI(Dĩ Ddh5$V3GCiTEAkP #
+{R@0]PMei
+
+i)<\@@j
+j~ )dm=XW{Z[u'q;fTl 4a? r8X'Y;Ň~7( @1uѓ9WLG~=ɽH jg>?rsyQZ3A H%@0- 37krҿNf͟mFd
+BSѥʅ9/A2?o׍C <[H{ zlKg{OC <ޟfsu؆z;ֹR.ovfkš̖x ]t*Rb3g_vլfTӾy ˫md= >!7<J"=vo샯3VYᡋOe֌d}qS ,ٿ7ӌԼU o.&Y;؛Sξu轸>}wfE'\qsgZ'Y"1""Qw
+N9ViڭٝNyHg[I6GG,bٴdV/Zv;`kYej"+ q8&v7H7L\Ϲc;r55s[+a?9_x>&yҩl_nڧ${w<RVHuסyQ޹uk3{?۳]~y%Q%e [B_0"hcP}WHS;%;T]98 Q
+Q.Q^9M1n[b:-M"k7E.XmbG4x}R'?Yx㮚Gk
+7E, //Fkzy>h^`2| g+e)Yx((R685MɃ<Urq`` h}g.RX$/ttvtIXVLŃߨ˭dQ< ևz3vֿopdvF,eWӘ3f#v8~ᇅ7p8< 9-f[Sz{ӕdÕdkGoD̮x(NV7{&vewgn<1
+6di%2Yk@
+$uJidO+h ?×ӰB1E}^H Dh $P(NRb`i.oJhf5]9- b yA a$ B 4\GD
+\j/`'=8wp3Bms"uj/ïެܗG?/,a6WRw)3/8xۙr>4Wb]2+KޔٹU9y5=Z\Tøcycs!%+ FoAG=UZskGeWsw73?omN ̊K=ZW^k؊/VikZ<5KKl;zZؕ~/}K佤1ؙ, GD7펴^d늳8ޒ`{9}o};6̱ʵ^٢I5M?؟dqh iΡ/N6(}in1yN9T za'bҭY+6y,My43~o͸7J
+Jt5neB蚃a֙-;SZTtnK
+x^xTdR&I޺U\}+ ݼ*JCxѯa&Ϝ-J]m͵U li>RMbIǴ w:n?] C붽*އ<R_I:g?-_5R԰<ŭf ûNU!H)(pE½1#F~=0Hޏ6C.{\g[IXG^+6 ̝1 GZ3^Cv<uz3n潝I8
+vihiPkp
+q1V^ju\<3>Jᳩ+x;FԳ@ #<0= 6PFnVDM=ML\3B{W\n_QښKr˯9[(y%+ PJĂ>կܺB{c={6 0
+s+y>1x{^;}Xr_Eg\X1yB\{ :+E\"lh [zm%du-°چ„WZX\|ǗCGT 7=Xb]TUК5"WԴF.mX|w__T"
+%~Vt%m͏W.jS$Jw͕e nn p Kb*LT7:6)CeXCC6,yeOT]7 O,3D5/W1QI_pK-ɋy$<rO WJ>ViHnbpeX+_=~ kB4!'& 1#`}#YwL2߳sC`!cfgNhn`6Cf<lhKNSltW'73]\pOK&ra,",{S}{SMη[?Hyͨ{V nj
+Zzu+]<++G~{BzdۗdWJ cT
+2 3RCq9y?FY{Ȋvܬ,|&cϹ7v5Nvy[%w |OT!.p([߳?a|#-JVm#Cz.)=L?ceGX~?kܣ/.kyRlmSuHxS}H5*WA6(_:>ZZ"6|xL]0
+=A~N羏ɼQ$L// ˪,ά:tMÎ 5mgE9 /{UE$aR݆Ci4A{_\t塠Nܞݚ٘[p`;%2
+g]=ؕEw'\nꓟ1G$8l`/yKaI%kߑXe}jCG~ˋȔ03DE]9:/zS0s6x;emBG͙MIua?;:2o/>Ԝ[NUF'/$3/0758fdv$Eq룋whLxeaE^y&yTSW,, @SʪuNzSSҪXǞhg:=c+"beU@SbHHH^B}3}{˻ `sͭ57ʷ]۾ZqZj QSјSٔ]ޜVyE6m*ټ4|wL\<<Rܿ,9;p0bނ­7rJ2zjה߯Y[Y]QSqz}EWu֎kYۯt4lﺞGѝ [<Ô<n}ۻ {fЧGu!Y΅!K
+D)v4;k_r*U*}QiهUʴ:Z5RtzS#I?Q'/;WPş7+;qZ]`”T<޵jZ)`aPpCX6#}R.rQ0jNZq)|$@ \
+BfiሁɳY8nprLeYtNY N;,`t:932d "hMR{b jrƒhaSm
+?,-#Sx(5qO>M3:#=7gy6ñf<D8)n AiӁR !ԏYn+vى`/h.bps @~^Td]KW3f K`Q3"i>Jz<"cf8cu. j8
+SO铹I
+~oT F-)ЇSCȐZ% @X֔YR`HhJTBq@i#TڸE”sDH`P]SP' d
+T+h6aOTل6=ȟG"B.!E\d%FGX@B+ 1> 0G2γ&= yH8nYy6y泀 d>ECTBq0a,^:0lHDnëzeK/?ޝ]YRo}x
+wͼ } B_QMρ_֢[j<)O>0v.$g~G@<0r\H~;nތbagvl֖%nu]kb*dW*~.=reN?8B6(:y{ݒƁw_۵:A=wvgfژ~L_F~۫0(jn*̻ٶ%vƵ- 2Z
+scV-n_`I@nFg_vFW_VFw_檞5+:{|=f 1gҮo_V}inXmtx}31+[z8?{N,4TDy8JU):3u(`|2 z҇BSZ5gbMlFjsAҘS[Uʰ@ ]O^95
+$]l fB0
+j;'_'w:YgOfu;ɴ9|&iZyb؆ohin fsȤvs"
+KiLPk0qR9I!IMr2E)"1BR!H`NH&hLb-'pV15D#hr RiDK
+<SMbxSQwBޚO G,
+>-v!`
+S;iFUJpNASh%CQb
+74auGX LlGx!7SmwvPo7;HpvUbV ` vM4n_ǣ]JV‹*hOߺ2V qL
+n?.h911U_/4
+TG_::2zFǾ9m2kJpnB’I RVhAEDEGıX[+NݐuRVTԂ0
+*0"d#3&|7gK9}_=,V&Y1xO$,X/^}{I&EF!p ^ĥ\MAP;V@q==ھ \sAxh iA4^(U5qAXa$!p_Q2]4K3@&Aa6P9506HX}kb>af_J` nG!I{$r0N\r"EnVg̪Lg )t]eˀ[AUY5e_SgoW)X4A7TAeTG"jby58
+?~8dG'S O}H(#nj<!;n}z;qE9<>]-yE(
+ޠix<v}jlYmW-Y*raH)+OKYjŭ;+S^V `E5w=x҄{I) *3J*3]zSq
+o#0 IqƉ7ܮJMXk]_j܆^|\6IK~^1Ο^T=L\iQM)@Ao6{>}fz&ed׋Px85R
+Ij\ 74 Yp(oι|r/aI}=SH:-Tc-c&Ŭ%MD5iQtdL'TKЎ̾?DL A#[kh?G?ɰQgq#v
+nČ1Z 4c
+L+NoCmb"Nt
+j, ߠrL-
+,󘉹"B2(qF;Hw=89a4jYLµZߍFރ h{(X@$>,?jwc:BR0өe/T0ȭ$ <V!2*uGHȀ)Q=En:M|2#[b$z!YKHC!]c5:Z@6r]Fx'*3bK8Fb #H2m%\{4Tk~13$=B2 ^T87$SgU'] #:THE.ա1qm1]{go?CD\$q>0CV̡2BVBLa)b
+,/cp(3#1|Px}A?(6_=3% 쁮R V?Zkp
+
+Sl - -0)5=O;q~ ,EꔊPzh t>{ͳ9IB')[ץlt4N I|{v=z]C,<jrۧrsl~)ԏ5>69ѱ=A5yv%sw$nn9\?x]r-3/oxueYz&=s~3ǡcWvSfkcWwD;n۵8]pޛ-W[wڮ
+2bJyc YX.-455D˚1pO+߂P#f$ĸS zEM<Z[D$%P"l%`19-# UesX$1Hƨ-J2`]хOA 3PCլZ6 уMA 5M
+䈂0*p
+WGUd^ צ21T0"5s%_fÒ8
+↡"4.冾VfYf餕ӛYMeӴM႖;jf.i .0"⮈ν>.s>)5)
+ @BgXH@b
+ QT'4' Z(0
+]`r,H5D5h<#w6q<#m6H3i ZN)SK`9C@f7`OE,
+`[""GXa*{ė
+GnJ۸u?lR첁<; I^J44ۡD-vSu6V3-B;ɫ=U#8 O'3,|e
+y&z6Cݫ;ph|Fo4vIk(j$#St6"q/X$ ZXXH)]N"o!ח ‘yd/o 7
+<$Tt\B(;(!?<n&I7Ge4>g1=|p 4 sȜ`<3' `
+q^7P|FHlOj>HHMfSVa kfS~fٕcj/[o852u"@dB[CÚojH
+-[Q^hW$'C_OT>9R%sN߰xcCr[ F_o[Я[a?.Vϣv43]'5tn˹q],SgtRkV=\)lcTvu>h пMInZ{6Tvmz3{)yt0{s}a}+gh a7Usy^ϞWOrɫ%(x+[WL
+-ϥ@* .%{P <|+vzUYZ齃:q]CVc[O^dIMjy4zYJE9k_:pěZ_Gq&乒J
+wy[WXm TS<cx7ߗh_䴞aUBmgKqƂ
+ o>EA FیVB>/<b:@p>{bD4A^H3BX<}.g$ LƩeO0 $)%-! %G zbX?#(Xᔀ4CEhұ$U!q9"T!2W' .Zܸ@5~:k = ^00/u( =`;4HCx"J %*D% S'jhԃAz?+ `mP.bvS4eM>
+ ݂""!$! I[ٓ ]{w}"¾Ott9dň۔2Nf̿ۖT֓n^nIᒰi}dj(ݖY[+]W6sx !ma-LcŰ3q"l '>GyÎ ·9y_~uí=(\{_amCSBk^f؈w}mzTcOrt`b͛;QW>/xU9`*:~IuA댯Yug=-99;v?lݑ\޸3!/nWNeeNnEEnNieޮ2(<{Gƪʆ[xYQqN!Q whWα/΄0Golĝ屹MIui{$iz\f{V[U\FkM|r{㖭Ob66<KP<-iOZ5J ʈRX<sctΗܹ
+bRvcRo)5G+ǽ*zܙ<7u3٧>7z7DŽdM#)mԄߤBx[X,I|q[a֋H֗HY
+!-,g
+e]Ħ$‘/k84h C:h'<~Л2\:2sa~b7iKoy+Ћ$](_=ܶ;9k[/)Oٜ&hgo襦O8iÓw6)Dj]Sw
+GVk48
+fO^vs]pTj\f=\g=ܔ3>Y/O}RJZ
+ TLH@}1b&Vρ!Pՠ4Ltn۩->#.6EZ@:_X
+@b^
+aV
+,e!\@(<ГO^୚2B$ !1|?X j՘8 L@,H|<Nc
+7N KjFQT$nJ'VZeHomUB>&)weX_#&0c%(tf̋%1wqgOG4(
+Ov?ȝ:h
+p9,s
+:@[MuW8mzI~[C0G Yl{ldg86`mh "gYɖ9^~GmLHEwidX`pw"bYuOc@Nq^#ٝC]QJUyXt7)z5B `~-#SGjr*tփedYXu?@}%?x﫽g^L>LX1xWMjԓ+_[dtvTf7=o) ɭI-M I6'my_ښsʞ-ɩmqYU1{D=+ݘhSf[uOfKuB_\{wg37͝q~t/TG k*Y0!@h!
+k[,*kDz+ꪈ. @
+遀!Ν{f$gfΜ} 4,zXA 8^ ")cE[!Ox^iOO|`NVc
+5I~I6(avCۍQ֫W48{?rq{p3­Mc
+X
+m` p_O c@(
+R~z,@G
+al3 P޺v
+2uÂ,@Bb$&zfп(aa0@ `h00GijG©X@b"0!Њ 5DzͰM| Yz!eH<,
+E$][m,c#Dcc9tkyyoaʰEqmFOm`a@o⠓B(`
+FViMV?r >e_j<B|9Hx>+&y8o4NwO>98JRL˾X8*S췫v"jxCZնp eIҾ8}c&!ϝ!|Q`Qk$\VЮwR˹bWF?;o`Ljn)û*W*GՇ?HU$j_J>S: ޴{ ܷc#@+)#\Ok_VfP|d'>:CjS@)P/)@JTҋ\z0xN f0Oũ?=/?!90*҆]'r/0c3 ٘jcNpYd!0`r ;!$M&>!l ?"!sT!q8N8HuV:,y}%A򷕛(Y:'y}E 7T, T9} j2I( t(IMDksdߠ)2Ĩ9zc`l=H5o"HnX8-{T-p7Ь0u BbqPppnQhw5.A|Zb_REǬcbe=.kW9jTP)}1Ї_c`fWAA$no<u_-Mqޗ}`ο_u^(]Y^(ENfh빬m9΄lrf)-|8o1,I(⅑thj
+uZ!aFzuQ;Jҙ%Q^ǹ>_w,D״Xz=5žLBDS#pLJ3#;TO]P [ΜhERS1y
+Fe 6ƥR{.~9"rO\<ZvZEõ tslld=䁤}1c8-ohPzokGu>3IWN9T߳۹C}h.Ƕ m-(|xmI=ܧVSÖĚ>;\IVq^iAEUSeGϔ瑜٘%ZRX*!YX}W1f}9 >?H}vNjwLf?X5{<l
+)*7J{A;߅R
+a0@1-ؘz{_ɇ_v˂kT~ nJgP:7wiڵD| ٙG8$٩Y˒DjMz2-CvH
+Xhi.1% pYDɱ%v-P<
+5|
+ϰkߖwS-mU=RB2
+|
+| R#e0MR[FyM(WlU&j hkI\[<G+d j#1Ε &A n˧4jזMLXӮhz]DAꄬuHnㅎ++On[1 4>1[o)BAXn[l%]R {mKǻ΅u{_6 {AU[qKU27/Vl{[U ]~vo[v})6%*}߻;T;7DiCj9!̡DK/m|=;Qa2XJ. DQ PwnW{@L| 5'ҞS~5I杦rWºCp#*떇5<VCO\)kv+j4aszWa+6AȖa r:l!̇ re!V {tO
+vG'I|)ofq "I8tn]Ǹ?h[CVS>$K g@\eà&6˞
+'x|Ɔ Sb<7xY?m.3O6c8qWa"Qvlkob*2rzdca6Ԓ|ExHkw$5KM~8WJ[qM&=UINFogA;R #)hҙX-FPdc=?q9zsgӾsl}]A10۬Ow|x`˚
+/*ONJO*w:wFyFfMAunՁ۞oTv) j7,L{TW33Ƀ wԢh[PD+R]vO]݅U졭.ۢBW==hk]+B[Ҋ<I
+N~~/ ~xHkXJ.B6,}3ǗXw?&>R^y*g{] =碶 _f^ eSg֮Lb5 M/sZ>.Ǹ1Z15ac^:菅XȄ
+p?ယ&owã yCPᄅ>2sB<̊QȰ'pژ'pG0Ƃb hÞGBu4!CD1S)ob'A@&` P1@
+"f`&
+0qR0\hZVSXD@5BH(蓢:@yc1q~~N j3_\2g'icX
+F2]M
+ ZIlV%#3g߅q0\/Gb;i[<_aEkz-(;ЄmUp6SZ-^3_rޱx
+VңOwta#cA/e~z}Q"L۾Wdl9,[Cg[?eϬ|'Q
+D!@۱<Bjǩm-:xi=Ȱ%+ $a'@cg޻-:&ĝo%}Pwߕ;rVqgOEGOznUG"zL (6B`ť)yƅEW9se?r ]t^<<~?
+y'yo <vy_kG{m(0Or>v!TUں.NP(Nnݓ_Q1?m9.)/IkScc6TmkcZb4nj'4'4j5e"wޓTZO^6М)_ZpmK-_u\ i&ί<y
+4{m-ԕ}s"[١d[ysGTEGV]oq;)V"U$GutDhN $EUO E- :AT%4VϬސ.(mH7oX/KNmMj.Ox]dtsKfޘcۯ}+(a !Z9z{_x,%Vfu0n,H Ywfc( ^7X߰Ώ V*tm\Ҟ\{GN嶖6%UK3RjRc*fW7g$eTHpLy[SUrȦ9iOp{옼?ykl#5?s[\9Ilj"6?Z}ԆG]I+%=ō(ijU!cb]"ӭ 8I1g댁MF l ur V` ڽqV[V6Noe_XI-yꁟ1h0qp#f/M3Ric fNk
+h
+,xe
+@BH
+SYt<OA+,$D^DW/hI?ФȔcxCZ
+ߨz~Z
+dē:2sJHSuVZB 5fucjRIÀ1 W
+%<
+wXaeSb횺ʹ0_,OjH6Ŗm(gME{V|C lL̔V&դlHoIHog6US֥氺JEf05U풄7|G-jl)9tx'd07#@1e(~3t8b|o蕞݂];onVm ,SoW2Ku@5uq!$$BvBQpBպRkG\qq(uT*R } H" >q&w}ܜc%X3QZw:6yt:^¿['`I4&Hd~!1ԟ?nݓ?]Pʍ ۼl
+fi;
+(ת1VqQ
+ߤnrXx!o$Y?! ticpQcƚMuA~mu BC f%+6r"nu@Lkg1aV._вK+^EFVXw|eqĚOWƖF=*OUeٍWz/4}fF`ds m
+ Yvuϸ_6M0,n)W+8F,tVj6_mݖX[WYKJcF=m^-9Qc_qU|Lh`0i\U}]IV75t4ٚ A{o.ۤoR*n%ZQ rlm?yg:~
+~Wy_ן-ÚxA}n1v~_jtZ@NA"O+dҜ<0}5TG54@(r0`k (%W؂{%8b$ĥ;#yKTxDg򗫭,r-nXoy2@Cj*atr0
+,AAbE1H&A:jvYS#€W (T(T3T'݅;z E䤭0ܵZ= *UA@PdցV,׎*=>.
+~ud"urR2OV"
+irSPYr#+(گwxXt맲n?ӂԿah-ƨ\`+t~9Ϧ{^K aKQ+vi7`0!,
+- Y 'R
+J&ah R `D
+*otFlӣbDe~`4/a2O`P7) Y۞wf,8_J_"q8L
+F"f]Ĝ>E]_t_xD|4
+\$;'*>D',}aC[evK
+N'ʲPP1.ib+< @SVb|!d qE憣\+د6]TCKDzI{D]+%9'^^9|&ӹo&e<JȺs<˘ OuJh;rY:=ɸhIщ1#愁.1cSNo5DR5ۢ?@,Ed]z#jcJ8Qs:/9- 0R!eSlR,3{S,\gSYdk7'_i4Df6_V.3S#|QJ )z?|BBC5%dx%6d{4]Q=V 8|QT|cXDm.r`yK;{/\H''S/xhxir6t$i^&\yь78^>3<8e/僎@q2(t t 4Zy$H$w=(לSzn%vS1,Χqd|+u7",!tXGv+9-\T5ɲhvЮ{5Q\\W|bX#pdIse磋_E!s矡/?K FgJ'|̅˱wPkjݟc]ݑ:xrm{CqG"!=z:)?2 ҌVoz85:zgv~SfԨY2{ l)zjμV;NJKw{Sv]3u=C+ V~2yYx-Ԃ}T>L6L
+>@„;:~eqomt!V T Uz}g6exYi>;짧tTxB4'DZ9PuOV<BߌoQ\؈Z<MI RЌ0!my&toVMiF g@>P0[h f״bMشD4єLÀg$ j*6I̲.j\`4&ԇ 8U</eԕ=TH ;Ġ,m([aP42XQdq,Z :8X+Su=8V@Q\qAM"K d`e1Ȟ7sww?I&Yg @DhriqH#r(aSḴ0QÀƝL[?H
+0dtI}TIGeNvz2 PL/IŝPyq*,ɩO BXIM]+`3݀vv Z
+Ca пK,uc:\N|},dN6Fb.?
+*O曕
+CzSj1FY8
+nRolZ;qj>)$*/՝zkVj;!^l/ 䡜7AE>kNhi)L,r Ƹ\rP
+1A DX|/v>ii/-"+:Rу7 kcn5%yqucuJ[ɽU﯈|c͢jzmfae_rt牑Vmٌլ#5kWGVm<=>}mJY<{U)2 ?_O6t̩ѬCM@Xշaѽ51MqN=vё|`,0A
+rii+Q<˷|TX1ʻ"N9{eiA
+d/r[=E'dGor>ozL,=[g{2WZ}/KuGevE~Vg9kS$s܎3,i9o[`fgv\˜ge(%y\$GZ_IFvK2w$m5_w E.2*Ҡb+:
+~hYrxgNAC:痷.^6K4,re֮?{uS7vUnY~=U#-SB M!)<QFI7tRWg23|*+ɗ=ܾk+xXoQL^m]<Vce?A%:V6ޫZtD4WxڥMm;9OҗjR.OmJ;?5א}6mYtQp]c:
+0^&`gAev|}u9 ~)SP|{y=/wӾ2iӪzqwjog^Vj$bQ(N(A A|.Ct@EtzG(h@qoKFeĆ iKc`| É@Dt tgT00. ;c9䉑$
+AX 6@QR hf| .v2œXG2TRYP&EVMlEHύhr4 Oɟ;I60
+Y=B&я+FQ2+ڽ4gKY1Ag:< $8Q ͎hjԐVc:dT3Gԯc1-0P p0UA= _qP$}q3OcrJ<XȅNL̡
+ɮ@:{8cL9ls"h)1J慹Q/*)D"S0Fƣ0 1iq;M)Z-8pf5:]Rq,npcαr>/-1>qC_d,`!aa!G4~Pc;ZOO& a;#b(Z&jH_=,jZﺚQ;ǿd{8Ү[;WquyW WLf]|EvzQ"KbvXg?xZz2iJkmh܈ (C8L'."!p U
+?uҵGՌs$gەg;4{7["E,(H? Ǣ:O,&K=cy{a>F &
+ր[뽐gd^Kڕ ꜋[؟ާo_Hɶ8J&1%݈vd|u+t't`#.sW)h7W&51 eɦoH$˱
+Ft.$yTSg! KH4!6)U*fGZp+Z\kKQ[ˠ2Q@Ɗ3,#[ʒ$dBYnB߽gKC:KHVgxּv۫{m
+A95u`;ubW魓E%.!}'U^ݲv%+Kޫ|5QacE+ZtJg1!׆CJ@8&O
+Uq'-ʀa` XZѝpkGΏ^xswbyg!LI:,L||7
+L{wH~t<wφV6j*{ۯ)zUYXu#+q_2jﭺ󒴒# Wl*۾ֵ魍}OX-wukE]WXǘo_pʪ⺻޿s)0wCJMv03 g͏7O< pD%s_7k6ԙVrl;eeʲZykZrSmLi]/?HOۚƮΘenn]@AeQɒ0>c:#7h`p]D_`X'rX)i}o2 yynt_ɾtwvu/>n0ǷXE!Rj-9q `kfu !'7ES9sp\trvQ(%שu5uNilNK}/k^ey\ݑX۞QۦЈWuoIyлk]km.]O*rC!^@ 1ވ^F<j4`Ix{FԤU d$Կˈ
+H4x< dXXF5Dp0ctT? urZ^0Z{~I
+#aJ>P !R|S"%;H70
+S\ g.g$0=(㕺X$(
+2/wRo8-H:7@>'P"@R{$a
+2bhOgd} d<sTBi#iV6h貥|ٱ'SWHE&„Q?6?4rY/O x|[^2}fc}Ɨ<f}MSmO*t^]QY\ӪǤaTp'S
+4)̈Jf
+  aSX>;R[%r$݋ #wTUyµD˓0; 'g[doNuNG鈸E" 3/dL0\$CK\iPyς*ѳ 6L4gh%N%P?.B|b_KCPFn a^a%/ ]Ƹ
+111l*/Y;3?Exe|8aqgSO; \p,m,4|,j+v [K=^iYeVt'}]s"nSIJO"hȂoĞ{p+g~ubpBרgчr^8wDZrGh9ҴeoZhR wk{04il 64AVgksv9uh~`쥕4yC@Kd[3Bhîc;Sfq86Ͷxо1OJ ދОHzϹ׺S:.BavRGir%sF8| ?cYL᡽# z`f_OTLJ/Y5*TCd-3V=&-g͒>y)kCňߕss}:ԐXoXzN,
+@uiT/aЃu1<ګ;N6GF|~yeDEe=<s?׼Ǒ79{gꮅ֧yVWx*ټo51^J_O
+2&chbS}.WZQj:\h%ަ@5Hz=jH7o XǍ?}m!iŪ+(H bi$l -'Y- dW5|11 O-((LǷh~} MrZBpDNgy'Eֵ|;"%"j^*=-Ґ_%yB )!57 ٺ.1zkCz8Y"a 5
+Lbx
+)n iKVR0q:kxԄXCy4Ƒ>\}/AW'x40 rM
+%>("6I P[/55%$
+ jdYf6)]3h+39@sT4M@Gmrh
+ e M]FD)@
+"`! $x}ލ;G-Wut22@DM YD9"'#kAI$='Zzc7j{`hm026Gm`0:Mu%ƺ#x&T{
+'^ϋ"(s\EE
+4H
+w!zV^&tGR
+'h͢ gSi6\&C"e3 F ln gJJi)'U:95L2ԓS%muay%v䊠y3VVMmr*D0;)c_|sqQ -Yr&/Y
+-AzEƍ&_S.q/I8_m#D,\xG&>R^
+p]VaY\Ǵ'`sA
+Hz͡s;#!-/\4;=pElh=P(рJNZ0"`
+ٽ@mg0~,oZi:VKk ;"RAC/f<UO~y*'6d˝iiG=UeVa23v$y3$-?ܵ'Q8{gibr3OD^_Qbl1<Mu]:mõ,PqM=kmXN:1SP[x5 ԉVZa/vX`l*j]]Ӷu ~(n)
+0[٤l=Gj 3!?M0ktA$J7Ώ$^D~m?OIR/sI$r4=- $LFg{NV/|]0gV@)u(BAZT
+^YT(&'`9Hb8FW{D-RD\w ;%AكU}E[/o?7fg210/_Ezr$3dnEm+<Qiaop CW m[{ۓ:nOvQDUדJ
+$'=_?xrIlBxu N8_nωԱyR%"iʘveLyoPK;g:uw߃ 4zO^9 ZF5\>~ؔR6eMz=W&iԚxqËq49dr4~:SΉZK2<J*iJYr9U.fEϪ#OjVN]V%],HzpmJ-&RxC1C_϶c
+~ᙞyOX8U;r>pmOSah[
+G7pBO0J3]>{ؼ9ιV'<igg]-1%OES33ɩ\KpiWuM k6n +*񗷴.mm//oeƕk7V<n.-kz'>zgeC{Պ'˛VuV+>x/Oߢj{j'e.-EE, =g/şE=y z\jG4|`2v_}ZE:ۋ˞>Y^ i%mH:0}ὙuW, <d
+CO׵T 7ȝPD}!= pLnd\;L-ZU޶^x…a]Q^YYjٷ]oEEQcwj^P!Os̿ٹf׎jmxu`@grȾp"љdDH^KIMqrSh?@OGt0
+ ~2@8a{ Ȗ8)cC1nJږVa$!$0L0{װD4t
+Ll:4;ۆ 쀁+(@m0K쵳Eol%nlR*4 ,`Pe0P2
+NഐArRnJBMAb@dHR۾a߅_655i'ygǓ.^IN~<]*|.ws; %^w_m&#r/?ۯTqsGߩi}(>8!q՟h>C"/tV_",f[v+oog_3]2>'ӟyKr~\}^ ^(ȏ1Pml;FY/kQARۼW{
+4u%''v0{}iQ[cVgtXKDhyv`@vi);eW{UYFO㯈c嗺w\4_fkͪTۈ=$c"cRRQ-mFbpv&>J2G12WZX+m[uʂy޵}Z16iDK$OryAܘ007 ,#}Ԧ}4yBrih__4nG8$_ o) 5^f5VushyJWz^x=T=SGbqפҠP o6
+qAȴǹf֏O\HfSx:δ ~"A  ۠ s_ǧl7o_~jGr徾o+/?хR@>ϼP|b}v_tkO>/4- {
+B>˯Z^tomPBKKab!OA GXs/XK'{
+&KU mjxّH.N۶97wN]_J/)I/*w S]<<Bмc!g֞}L詮3\I=%'{1\D(F>֓|]#@b4 $`|w$)'͉KikO}w(K;Kodm/ċ<>=|qŕyŻUg_8
+(UGs_\[{>x.מ՘]'v<ï2g_z>'a˪2VI_TQFe|L wDU[v~|KWW,}*ymƱ/Jtg{_>`gR"JSoɺQz85a !)S xk%mckbK5kDGkkNx[</ޟd}Hfy8 xn_r46Xv}uPݱ-;p^S&6 k:@68eq?px5)F)Gms~zgEgl:@4㉆yŽAi/.{U]^(}yMѢ욒Eo.y[*)MeʼnY3^UV-*L,͈/kȜ1+)3i4qZ x/.c'kW[tkAfGAZTQ_QrAvs=?^cyL韚訥GFӃ̟+Wl3R`-ӍIiwf"e\*M¸Җeŵ/.5mzry=ȧ>sEҾ2*GZY&xZ-6'ƖM??X+fp;: !Ȑa'1ohr
+X&`%ۍj&WPQi۪b'={D7| oave0a`YzBfqMT/(317x
+2@ћ90 8:S
+ %JHBX7gʇ34 })l>z P"%zŃ}w[z!G<LoMv/OoOtK<>vc]NW;d&?B1tNwkv^{<@vqq퍆ֵk㓞Bf@;tto݇/5XJo/@
+e6cAbN(<8e^~os|ܹӵЋ?m׭tb!ol ֑VCQJ4(vy}Q9}1wDxQ~ A>{C }[\wmq|ڳiTн436^h(^ȉyXhC(' )0HU;QJvS&>=S "$U5 jWcЀĮEH8˜(%Č
+Uiz/I% &[%+VgV$YI÷\.j΋lcfvJ ; jgp# |=J3
+#izpiXQ~}'˅.\t,<Lm (xq#Z #yͨR$Cn<Mk[*sޜ{RCW@w;Pw}۱<8̟w}v/y=pՏ˒;.&4G.y<=Gnef2H#\,,OȲ( U=a״5cM/m8t~;[o6 X3
+y.rK{l)mN/џpv鏳ꏥb{}_^<Cie)$R
+Ÿ1%%{zf4r"/4JQp!gcF#*p_heLA
+*00y1ry3UΓu?)ʌ)u{j~(|A
+3"ח'7'd&nͲCRJ/3WccjU,
+7*v}+(@|hAB
+vWt=moy\Z٫o|'k=Z#Lwb- {F0|,ʌw ޙ͇|ʬU+idjX`A#1DkDM(S:KFb 74G7uuϒ & Oyb_H -ui%:5kVU
+Z_[,pcCr
+f_kuue AWYpo`re^k "PLy?w,l3gI9C𘶣/PSm'و;&FPvspg$UDMAA?l6dB5_bW?.WFJ,k)р.JJ5Z`]:TSp/k]MDP+jCT6M}=+to,ϲP|^ˣ]e?Ȫ1r
+-R3"'Xɉ~€mπ*tʇa*?+_ `AP<Y̓5pJ3S'c
+<3"M pB C + M *> CXRd\,g-a
+2Fh3c!c,c0sF
+)HA}4Pk
+kؖI&^
+穎
+GO,HW&LEiŭ3oV:~6nWu:N 7fqQgoaWd9=>9]'. tds\z5- 4
+L-(s!>/~KhA *yvuU/G6ɷ<FJe\H3űDj4zg0xf>=;-5 ?Q_o}^{[}_tEv-tbEwD3IlE7IFudPK_ۇ CB
+&ϸ:ѦK d{?]w->۶f
+ZPjy=%өB_O? n7<V68,SHR9mX s8./BQ$gS\5J!Oϕ_BIIYpd2i祧(.d)i,N?}hcfjESȦ98dwZu ÂnzLKqe?'3yqȞOn3m~ӣ%ٛO]OZv:*oWoX嚴G6yZÊ<b4 Mw3ڙFQ 1#Xf.t :U^am˚0eH
+-#*uFjj[.\qֹg6dV]z-mqvRnnSϸ]n%}5gAi׺_^Kz@NaLm ~20K`<} q4\,Z3&☸}7f_-Ӽk,C+Uo@ WVUOaO`p+v?$w`椥w[w6%V4oij ^S*i\rkQ[8k(Rz$*ۈr 'd?;hxz6$P1 r9:3ETt,6OW XS[fu؛5auV*d^. ]Ʒ+B[BCڂ}Wp!Z^/uVEqĝ$J g L]o{+y. !!!A*SU.qűmOcj=Nq*.Kk:!%a /+ e3wνwOwcȶEs4]T/ori
+ qZcK+G,|s;m.9Q|O@L4O?U9 _^:ݙwj?|ߛܪ1ә9w\7'qyta˸ G6G
+zןsafTywYdC7*C&q PXp<D@C}y Fxz
+хyuTV=:,&ДI`ʰG>%m]z`=1D"ؒ12/c:"He4]@UleLAp> H=*0,v[V^c@@@G:"v`
+:ڣ%3t
+1Mk
+Y kIm(e~jM) ^,]7$Ȑ~o{VNNF~µ֣3dd[{wKv%9Rz5Q
+H
+G')x_k91ң7jX&K\
+pK$9eocYX,q* ?jUuwGj:KjKRn 8]Y-;Z3r5-i9Fٜ){yZ o3%fcuA=fiL.?OvVƲjR<&e .QJOMmMY_d6e46f緼ef :̂yM9-o3Sۻ26tuvwuvmhʖ4r?[߻;y 7,Ɛ6\nN:%O^ooL(
+2P&=A2Z
+̀n[t!9F 5X
+!)(7
+h.!E!6  I20
+0ڀ=@aQ1UBxB* ~rAZg@]Պ}P^S޾
+ 7)ERARDi](f,B"9%0H#P>(rAo%jH"&ph`鲜$"ȑXYMC
+V!hh`Q&E;(,2 Uhf's),294G P
+3 u% K٢U}NF9sVyf=;>O㳤)R C_ +4#8:ͯp'Lktȏ~$W+˨m/ιǿn'۵je^!QQIj+2l[FY"p-YijeQa5ZMDv{Dt5=L"}ycwV~w9>}#:-=v޵o )h2E.JFgkyJkLq >*J9F* 1Gj5%2 }*>jv۾[3?xSetHrC?7x`qkdŃu Һ"W*fWL-[Fw-ӦsG
+)I<f2cيSG9ǔ̣
+k=&}e:3Y~aq2G!0fr(n2>?-5ކ|Q 
+rE b$95)5ݎJug М Gj[g;<Xrη֦6}GO#WNW?tbޮ'8qO .S敶9m{K'7
+?ukduxNehO.~acJBxB#D>E Ձ{WS׍c|y޲/vl]vgUeܟ}WN7O)6\ާ[{s-JbL KSn4/s 77fb$^"Fo"fFbj,ظ , V{Iqn/S`}-1
+lϙ%GKwO^oL~Ҿ1qۯR:AfVS_XH9^F<9*yfC`oNUd殮N˓Uf7TgjI!GJHRuy ӯ VnxkXIEϒ7Uen
+ԭ"Xd0jA0J1IYkv%v'f6vebcs֪޻[Xas9s:}5QK/? ޣ{&` ;9e-`~i=ـ35`8̚ꆢڗy yaW{ʋ&b1[xP"&FE~^uL|Ł]{W vhHB]Kx|Djzxۀ31=ǚcltpd |hx,)DnQIjEDGHP{DGLԍ9Ffu41 l,f-JLb
+TԪTd"fa
+a1PDD^id8GBpt<3^aglt ^rqj"*k |DM0ž_3@9P #!qAOF&rCG:fl,u|Mh> cɵ|fRcYL }v 3ĢM:VȌ֟?ere\/tZ-",V 
+Vbϐ8PT zh(6`7]o
+ЎARh/u5sa\<TX}n4P.TpdbQJT{Ĉ΍d(FIRӅI1 uA;(oam
+8*wD2HFRRĨ sXKqHn쳌20F"F"cR& uA$Dw*wG䋑
+F?Mc@2
+D9|=v 8 _hP}pJ sF\]3#wS'rL竇V*HRb5k?Sv
+rFZ6)e<@#zA~)=nIi$38d1ݒ6e=i*'1ϙHw=xJq7xyare~qN:>8P<ot(H,w,Hgd& qq|Jy3m.TrC2P, Cl! 4[
+H`=pB0P G{",jB{H;!M I0
+~Z('qꁵ2MWPlFR$X
+C eC7)I*9zsz^ ?pG/q[
+lErC>582ֿ? ys<
+mwH+V%x!?wƜ/J5i7/jؓW]čעII#5P~oY/ӓN?Ίs8E՟di \,(i9Ms^ΘѲbٷyQbd zLDMuhDC?khuTNoƫAh4k
+l2Z瀖?R}K
+aB'ھtˑĦnsh^7h_eJz)
+-mTC
+C&1)Cc2g\Y#ordck5/5d}U0"Mcb(y%0ueͭ?\>_x | ܗ-זBWj
+ʰ ha@9w
+{=:xwR=]Ī0O^[}?cӊ8m2Û,pGm76wjztwyڵL-MR^crvo;ӄ~Fx
+H?3+Zb >tRdkHf1GT7m_W{wtջ mDRG'=ョs뀯H 3x1yf`~Ɨ,Ɲ{>{\S:^{FuT{k=Aý6Ϛ_\qhD}!x;r}ՎԀ0 ʺwo |W׎L
+ '9U>J5{rs8ʲ
+VZİ^Ll\ ])}v]\S*VUTb5L*%2mDh]ɂ&E[/A/ 7y8Q
+Oh`
+b|El| c.dDl#@pe̠ %<%<DEOfp&" I5 k+V7,,Vqm5'LEխWGխ׀ XI:
+f* <|T+2 B
+.heH &5kBu5ysbC<4mW, tJ ƫ\m<"tbue!'!\V\hm钪OiZ˔?S?+ /d_Y$aSP`qRGiZVѩ2v\pZpTaH’$B7ag9}=qk8n^iCWM8Nl`v)HN ~
+#8i9M۪gQ
+nZu3!wPi v vAKaz 2;g#T ᨜_8eDzdе34hrǜ=+ie (4jt&E*-h1 X #\BKaC2,721b @LHgI~%@%$` # #{JeZy)n`-qp=k B} .zCF/ ~7nظE9 
+4,`)f G^裗`&jفB ilgh*Θ13nr( L4Z@4dgQX@ИC$+Ίtȴ դ'ld釿LZf2 Cr`#</.6 /&B[MCTo@0Q猱ui'[y17vk-9. gW 9/}zڃr~vQ^Nh{/(mzsw୞l;9DRa&DS,zB-#GqmnE, ?!rMӏQ XaEth,l4[YY9`$`@#?
+\."yyؕv}+mKDYkzpYwzpEw*??YWRmnp|8rEٛK+͋V8&[4<"־Rߵ͞e} m'j;.F^gF 4rMeY[v~P0ՍMCEwB #v>t:{9]OkH_ئV%)kP`XQu=c!ekbӃ'}. P^˴[Ҕ}xߡks+:Og?;w²Ӌrv*?mύ3ܹ|57Vܓ}=,'o0ͦO(xb(F֡gkRW[smXIUϓԼLZPicSW _$^~"}\=c6 !jECslx?6%6MṚ洰{]8JaJX[/A"fqGr?fu$r>pvq=r|R@-26E^fyFpI4ѢCj bͬ/%:!(p:0~.Ky%_^`4]ƙ h)/.UqHq7Vy_yE;6pqꎯ˫8ٝYWДia?9v^|9]_<3O PXo6j٫Gi=kzya~cal!%Fymge"{/dzJ.ϸW6̈́Y{ׯc<Rݜ,Ӷ^hwW((+ uv7ErʮiCe!4~?dZ,z
+;6GVMUn=i۰U/οI#߮Ozy.Q[и{oYL=H)z:j҃)x]=F6nJiib~|ĉ1"t0$F.<IkEWCH|ӋI-5Q'7VLn%VGԿl|8z#ʨ֊0/*8&x.&g&}
+@G9rL2}~v}f}޼77o}*ycߖ'e<T|jsd5DCcĸNut~PJAA"Vgj?z<9B5T]{/mhτ5 +o\칥%sn=\4'~]zt=pӧvź. ǔ'[~_;\
+ѺtWKR_,WU>A7SQ%ڲ׎쯿R:1Oௌ;LrX@݄!
+LMpP.pXV
+ƥ$Dz̶XWG()$ m^%ūd6%0`
+ ix-{h[_AF98G%>uKGeGySOٓ\
+$st D»
+ޘ4_I?_aOuHа>- '>Ѻ=c噖c
+6%y9lC~wT׍?_a'=?J>3Pؼi̕U#D :Wye']}RqM"z夫WfpUC$ d
+̕M;*to⟶m}8Y׉EHJTvv5.\޲LcFTfa~YZ‚ :
+
+\3%fcsڄqBhU31Fc҃dv=-28n0jDCq=0áfPd $
+P샦JQ|(F '6F4
+,ǔg5dtm ]  s!bbRkF~y:bo} \>i?vj7^N8P;tPz&uۜ_@VW ԕ0uJf>Q~(nT$|?+=z~J.<hwAjF `o@h
+S `5
+KujP= ܓ-f&дEM屍ė9#9iOgj /']E
+#;nE=My0v`oyw⯴)qys Hc#f_bi yw-ㅰPxϠJ;v-~u 6pѤV&{ٗk`4qRNO\EXaF( `2\䗾iuR9< `id\3tkL?;r-ƻ'Z{S=^x7x˸)sw#8`jO Tv B ;;tŎseyIg/f.yoٜ_S}77 xZ+"+:-6)[6ig'Ԇ%V&pF|S*RT'r9 )Q[7gE>sރ{3/1xs&&|hr/Rp-)o~Yf3Jh` -@{4m5Q/BܼXRUVq&+g#I0 daҹX$PTeB%vh!Xo U?qڼ͗T8Vi_\a_5B=ףz}ĉS"8jiCz\#,^/7c6R{kv|x߄</=y+m"o?p{n\:=/Y>:Y}!b
+#u b[˨]%{ITVwqxNoaY=a\2y嬤.^D'M0%R"s>ҮUnjԏm mat7Xiݥ"WN„ELOM[UxҺ;vS{铷p jS֒{]fbe햸ꦔhH+Jw9%ޝ:bZ*bk7Tz=2K=ˍhI o
+6yR?{02o_J`D6)\Ђ37)pzΠDO#Τ2flR
+=VL>A3f22u.hZ3Fw
+`9RVw
+B1
+ % YH_q]8禝]
+lTb 9(Cмúhe _lK_:Е"y,#S$ʇ5N*9؏!#Wf=$/ ‚S~
+!
+3QaNjᲢD& B%],<B\q4@}zRbafn0N<`B<C+BRg 7֬zYGa_įZKUl
+HE%M0,z
+T(1ha^THdaЯ@6ШU0jaf܅+ϊ'{{Ŏrf1EK\%ֵ\@hj}2ݣy26tvl-O;lwµ@^
+;b H[
+:p/.hE hLC4k£{<ʝ½9A<8!µV@.>\u¿=J' \+AITFg
+v SDLپs~a]D!!ŀH'7M
+!J lF4t$<2oC;o3x'b4xd'(.Ù"\RY=OC_ԝœ^O[[:k}|eRˌ5fiO)zl):xuqƗ.͊ 2ο=cA[! ֈnYx S7nR6KƇiP8=YX֟[~ߒE{0v!-sF7N>(R`]|KXuyDDt2=HIia#¾`zY{FDɀϖ΍D?LJ)!}]JI_l0kwYZQ~аٗb *¡UWNNNȹhMs«j[+tQi⹑!7zK2q~xYO~ۋ^_K/=yL_*/e{-` Z~m|UW/5^O>c[ݓƌ䚶 ړmO[
+t-ԣ-xIoDr7UY;gaXVI\!r"=فs+(_/:RPQubYޙ?
+] ͨge=Ȣ6Rm)4v3՗M b.F j(zi%&6yp#M㮓}tf nM :1|QW˭F˞
+ %HؕHeu'EIa`&Ű7&hv;nc(naF7o;Alx8$tT+oo$L<Gm3`eVe})DY{3 0L44O4,@R -c3:2
+U˩UQɭήHx_%q&;Q8oݟKHx{؟Hin쎌bE~@z{@alnk%#^_RUP֜OEZ9'o}ENQe (
+l>z-wW DiDO֧Lw_'S=,Mg ]Ӕ[\f[']OTOM\ćHF<y~gƛ,67j<VY4
+&kE`X`X;.<$/yIH@ $!aߔՅ)RXP*`ǙquiaiN8(j n,
+
+lM-!%3{&w~4ù'7񵎭QnƫQqM=q*UNYZB7C0Z"b\"S z2j!) $;J[ V
+OC,7Z%$EhyβMؙ
+y3{ܣSv1 p
+7ڋ1/Sq !CA 1
+x]Hc&F_)B
+>3TQwTͫ{/sn}v
+aOTwka͈',6`<
+SgӜPl (7iȠ 6mSjʹ6;3@î 6X@qGmI؆.=^6ꎼOǖwT1\xsh/ X9^(M{߱]+p˅OArtœ?nвutc1Gh/>B.4 ;<jէhqPrx&b3@d@V:h,oę:\Ȫˆݬ}Il[zBmߣ?J |!^55y)@?ϸ8ȮO0q{&/cTxgx`u1]ޞ}aCSKxWی啐{ɑ?`M!IGW Z(.CH%3=+JCEi Z]ELHWDkW2H3KX1W_ۃȲ7\}+A٭"o`[B)ESS^cT~T{bS哂 ҫ <z?@H[7<IkJyUۑTӒagdM9{N35U ='^}}}֜y]Ma_:~G( MqgGώ\bi.ctxg@8};ъ]`+LBXqWߴnLaӀB$ȑk(Q}wc~y2Hinq_ɲG?<;ڸ«575M>|#"#.+Nkab;/n+8[ܬm>t}~LX%:=ig91nax]oچgiIC_U#xw$Ӯ
+#Rg
+ڱŁ*knՖ._Mq;ƈ2@6a4/jĒ"jĈ;Ìam`/g}YV|M{N< Ԅm_ck_fG6>0$Sa*^ܵ^ǜF4ufV2Pgo}r%#?XoÚG_PӖ\*LmhNO} Urwc
+g%̃
+!@А<dJ&LN1
+H*H:%8Q]$ä$04Gah2A&L@2Y+L!" 4QNh&Š( F#T"!@">v`&`Is%Ve]&̡K/qMl/Y
+Ȝ* ]3;mg}v`'.-2x>%!
+%QB"3}b/Ő9n>1kLDs3P@\"Fr
+F:Is]SY`{L.I2%F["ߺ$dµkb*HZcI$-Q`KR-]iW:wUAڀS8i@Кp d013A d:(:(lBv2e(q@& H/6*:NU4R*kƣdLV -X1R"2
+kiȹ8vxNps}&쮴'3e^my~p`1rphGa˝?xZ仳h2ʐH(2<Iou\6[}(9IՑQ`Z$-(P Kk#qdT:yWx_~1UOqϺ-E᜞ъR@固*A)[/nο1RYuw?IHծvت߹~n5GH%5,,Kzipj#&GJIQmsmʸnnz DF )Q
+ NLGVCN,@",Iܳжc>'caKCK ck}WNLfek'lYaK=nC@N<3ȅs"*J1MK2&9 ?l39r39Vog6ٲd9Mَ}:;N}AzAHĊ<WLTq׹ŃEECt~k z#\ :8TpiPidzW/lzyipo֗zRW1XC]W{R+4[*ϵ=֚w[=mܝ Ք]tOygU>J:?߻cKӚΧUU)GudW14I/o1vG5$ptN!B"" xU;>c՝}x## 1! !1@Bt&;W]Uկ/jfJ7G|ujŶs/=q3 "u
+>-9|XrVp\v^t'5FLuA[Pwb=4?^!
+kD>܍VIYԂ)+^f[7|͟]-voy^Ϫ=ku?z^3ng|R 8XSЫ6g֗,_Z^PjitekF1%KEYCG&Y^Q-](K[ ԩzrC9s'\#]UpYG'g;9'Y'/re,O+N}Z2&+&3viFݥK֭L)3_REcfؒU?/kB)nV$tϞ>+˹椽 I
+RuAT5̑JNlO  iU-gIr-,eM,PԲeK2rj-N
+DeaQ"@`;# v`J( uNM $"J:_= 2H|
+w޸01ěq %:. 8$䰇AYτX\ΟTP̘ȧmפr3a:8J2,[7
+uO"]v~5u&oΌ$qjU
+>u@rJx D qd \SjͰ7[c`3\0QdAݠez
+ FXܤf!hE K1jÅ0
+9#].'ud\N~?8EB qȧu~ :RJzg %`w!Y:=1;!K@(>'>^g &J+8(B{iM4^9^8} p<gF
+0 `y؏$XϬk﷉IwY\rY|.&49ߐ3BK
+$ `)+ZUjN;:Ӯ;L]OZUZQTD}#
+"GE7ߋv?N_<Of't #{{_/F6tX@Zl]O~`|{~?W™oGԟQ?3sݮKdn؟a#0 6yJ<a-$p^<a8(A8"tzKvXp
+@]bj^Fe?P0+:!/ J'-]L@%lNP;`,X\9E:hl*,J2{
+Bq|' \ǍaBÄ02
+ SCRJ~ȝ̃4K,B'b=l,DqefIfQo@r@S/2
+e$_~
+z57E_R{$~
+
+1s$!`8CYqpoaT}sduQh:J~4r1`f#S/tfRO;)ܸ`|7Y'i;sוo>R
+جCYK!-h ғ̡$^E֡tu<߄P aՃ>"ARl0@}k1!!AHa2B[<{yR;iUЁ^=Ҡ=oZ`iR8m:=bLdpZ.W[wvo=߯KgZ5ikTnuԁ42雰խjIa<0@$Z[0l|9 nccOÔ8Cr& O Ȕ6[D>!Yt[6Ly#=_RAYiZ^m$6VX{4(K)ۢpJ 0iI RF- ~Ɡk?l3g%l0͊qq{8 ~F4:EM n`tr¥_MN?!\xh9,f7P܆QWnߴs-$\cv}
+O
+uϚ B*8:"%rx!W#[wB:,}~ǿnw rj&-um/~ISM:&Z,vI꿕8;noo҂ _7d&MU: C-c=ڿ;)<=F͍37=WxxvW%z\wa+K"$ʅXIms\t>?B|j*+%#xSFw{n{WAKWiKwys)xv;9+%ڧÁ5!euJ‚*UV*AA}~&m<@RsȶT ڔ3]Z[:ۃ}ijM>>F{fuDc1(=nCVÃ$Rנ]3ۦ7\:@.e}
+'LG
+#\Jè>k鴚@:H
+]eT|jԘ҃q4S;F],:muKzBuyW=H,l;ΐ٩KA p(M¼P]kЪHU'Teڞe&v'cU0I s"}~C4Gl,7%0|,4r@gz9b\DjxbuhM!TKJ@Yu%MmN-RvngEU!$,Z,€gXEXllCnۊmGQicW]'._x,W^ Dܣ
+2W r"M{!o {p\T@,rgyV9̃4
+<
+@%,( |B0
+DE1/$ ̲(aœ$7HR7N癔f.g&|1'bYGBzPŁkgUX9jYM9'^lx~ʲ C,DZA,>F5v~mm:5!d0Ql4*G<z[ck&!ϖڗƿ"Miѿ-)vY}JLuLrX"/%ꖙJr>/G'ﻜIm =vpo~<{?;Ӷ74.!$1~}^CBHncbГ֤{ଖu3VkbyU}fHu%7l_|:qJ/A 0OooʪHM|-FM0ӪF-mx}>SL! WY#eh}n#s}]Il(GD a"BF :
+GL@ 1[9. fːZfk1,P}.1(fH?wjΜ9PGəҹrAѼzfA V‸7Ab0RҷA$(~[uwWe_d@;X!WB:4y׾!5>q.U w `r坼5 5xq⺞ߪ>E4au*sDuYu)EdW%Gg&G?(=UQŁE ={eէMd\-c/X⻹{ /na(8_KM̩bwݡO>j?mq~Q ?~X~0 -GJ1p=4k?^9+3ʇ{ξ'>z2ZRrS{X/7O!*4atlϲ#>Ӊ AV#ny;48gƷ}KB)=F$ʅ C*K%ާ#nCw~L UvJHE՗}YF^5 q`iqLeש틿;:ҜaO2<k9Wf`@խB@~ uPA,|UUO+_.
+h$|Ӿٿ)uMq[Ƽ|3,EmqnybTAY\L۸yo>{KN޸v|r玂8,kKl~Y3l{xaulxqºXы]̭N z޲;85Qה.떭ťŅk"[ʃ#kD↲1eu"phu
+
+ j\ 
+Po p2sY `BL (n03o€DBzX
++!
+~`<t:ةGylj>\#uhdC\(
+P
+dد%bQ<bZvKj0!JLR xu7NX:D(21>
+ !;Ag4:KiX~gֆnġyC=bFkcCʪ@ #';Zd7KO ,-\}ֆg~TMW8"9?iD!߽3,yQ!oٜ](8j
+YBY};ss޻{~y xaMA9 TK@kz/\<ߚI祥^ :K\U1o>ac0ۦ䌔8"<-,8>|l"3ZԷ
+W}bϱ;=KU^M[72m~s?0REJ Y{j.n:o'gO)AnǾ- ڶ={6uKT _uZ;b붨Mmm+vDcKlxCG\TkG8%e㺍7:H}jiuvJiMɥkK긾IvFYE<VTg?O嵙IɀtkS^ŕ7dƖ7f
+0c2/,H`!( , <cb<\kdST6)ZjIS6m `]zpvX.3Ev/DiF$Ɲb4\ޠVĒM0TF6jDQ aDMSTm)^TOӡX0
+."4 |]z2XXgSV.X
+01kV
+@$ń2PC~@RXٟ
+(=\0 /6b/cXi 1UQ 0KP?!$ <?IID?&1" Y6-bpxvx
+$&I$"6Ǘ" 5 @qUy@QjAِMa5;=m86&>Gm0ٗʹ/
+#\= sl$و-zlD쟢|Y0_GXN]~IBcI͵%9!yBFt AtXj^T!Gl>54۩,"HxiQΰG
+p!H0!V +P tua-2)u@&hV]1Ө|kC8! `y=wè'ǯTCcW#>nj gսM xͷ?n}שSQqow$me|?kSP:"iDl\ERͲ+NG
+)>5^nmgWUdrkx{_<ٓ[[έeTg?uhi)3 O#_t!,6aA/n+'aƞMWFE'59D|&MGR>}
+v
+&tKi߷eXOE+|F{-b%51%2qaQlD5&1aK<-fV?s[v7KL=ghx? "ӹ:L%Dxb&QL,Fs54&' nBFCd2`0:êbАLxH.* yVE 105A,>iFns_U`(K2VDZTe,bBcpYoNE ٪Q *͢@n\6
+  WlH_ĴZoỳD`M01bQc/6AlCMQNO8G QGfڞjE8!d"[I!#x G[^ 7
++$ de"2ЙSVNդR38eC)A$XVF/JދBj6$"]/up
+CF
+j!H8'I9E:7|%ыW/~~S`" ⽑#'9Js }!jnBzU-[^G8nuӷ\%$]4u AkzS˝3:!vjgRanE;\J 8[N/ۢvpHc$gl8ݡ_`\y1`kB|s $x^
+g]
+ԇ۬^&Mcj0EYjY|MuֶsY_( I8\8ְp,H
+!Zor#T7٪M$W'3*RJwfrX`e33J}3+X:Si[Evrvj-Ry^W_ sf+&+63UN<A [pm wl`fYԔj nUlW4%ē#<n,H3g=g#CurbO4T4! F()z8BLNO M1_T/?0CVXe
+ǃX;77u>- E> p13zF993D&ʇ0Dn^DИ}/1MIMY̲̒;hǥ& zB5#܄
+XH$w-8_ +zPCyzQX/uCE&|=X:GPh:ldnf<%_6:X(jIBP. 3uk]l^88PJ
+"h@b  Ҍ-lA7gi \Gv ps9|Bz 1_031GH+
+ Te39^6U5 (Qk&f
+\H{FxC޶
+ (G[$3r 
+%{0IGYI% A h;
+hHq z !ù[
+}Ԝykx!/S;R9PߵaV=i nhe涶[B|ۋ#6 ׸#
+)ph1Fqx]鞚K z8gv޸rGc])+MV]_UaSO;|+Q.h*|5]
+ޅcg:
+2Hv8
+s&8e A0P8My8=ۂ|ϴ̅n 0
+{E'dkG,e-FN-7aa)v< e\>$
+<z*ed\D+i#S+c z!߬6{rF;%T+:)i7pW,DJbt{Xi\'0
+f1ᎧXbb& e~<sGO>ٻnJ|U3`7.#ShVOϥj>?,9,cH&9ݛ|NGrYmmr@N.Tg?BIB!#G i[S۹w>|ۢ,)|c^]WU>XK{,y/2 ^έ7:7(KmV4W6tT\ތ$rUJص&w6 B!o 0.a
+.>ݹ:su)8?قc/wEy4$?w&POM~5_~UuEN*]֩o>mV*oF K1ߑMYt-G ˂E-C7܀ J`L0By GD
+I!) 5B(z{{[KZ6*__w
+1~Xpb_V-l(x|!r΢}Vt<),8c٧Շ_Ժު[Ҁț2*
+l)muETV5?koʃK0swJU+;w%ugW&
+hx<ſ8S2SXP$p8C)eȞV=lgRuDMg&^afGF<j쾰!,vɏ[gh}gu/ڌ-
+(7*ɡqZq,ϣeDS Jg0)f)eL8&!s
+P$|RZ`dZ[ <` S ³3M
+rENa h ol[:Jy
+DOsZ@i:ǢrLj` +X\n
+}cb\TMZxLIHXC} O]OQyT4!97)204 KBY=
+8$Yb%.È #ɣ5Ȉ=Y=DBt=G(hؾID _AA{82(~Զ]~Ê2*6
+='|t &ޥ@
+QRA + X¸дA5+~tMmeuLEj;хi됙?q R=b4/q:I.ʠSl/ C,Zq\^?vcN;9|  :3}%Y̤殴FQfg}Eб-=+4}UWU^^suU.6W=sgѥ}}{/_KeZM6 N_ 5_{8@$@jFpzaazs
+nH~cX?$'WegOḘ72jJp I@"I vE=,Nsj;umDZǙzZ[T
+! T{"-Lm/(X^+0bR,mn3p' nCКAmr8 |M'v0$-nfܔQIC_i}D5S~4HPD,ov&pn78f?S-4 ;L6elwPʡHVb:~ls?e 7>0.K%rz)cm\VX:K8{G°035\ QCAgQ5VB9Tc* Cco}!CYwG
+@w12*zW 2nGW77)Y bsde޷ʏAm:n`Gaz8|puPd>ɿqh 6ܱȧ{wSfQ]إ=?)[ą un{cU^M|m]yg 8=wlhosB& H~ko>>tnD
+
+}mTċĂ$|3Qic^NC}v6DTY$ _*zY"zkUu%ֲTPKyt/K "$lIbdW?w5> ʗeqwf4TՖ=),).zXs`òso=;rtRJ3
+fL^Xދ`< znxg4QJY[&(d :%x04׊:Ť'yT̲he@3kҍP
+Br.= 4Vo0 d
+ItGi6}Q p_"_}ݖ
+
+}MM*V*Y
+C$xIEALkӤ  0:?O<gU3A7 Lqr#?nbׂHs:fÏ]kDaϼ3am,%H5j1>E,٢R-Z <|+e6x]SnԴ;bX93>޺OYh% )ޭt5vZL3Hj:&iSBppqS8x1u:yFOTXi+b&,,ʡh%
+ 7j!@u԰1"7=,/&W0^( y<am(߈#f|%(PmkN$$FGs9v@s7FNOdfrφ&.m<rKiéFOg&oۚggA9bqgmѱu pm' k4Y*e.ce/ץǍHc4Ը39^\6=!%9O'8l}/`s;£-w67E
+vF>޻-m-U\Q%2Gw77X۵n@,|M7J%R lÏ[$f\?~h>$1:(!wquJzM18݋izS;?8IFq8&b@~R^p@B*oP-wk@mK"o3O$ ?~oGVG܎GɏwhNf4%i9Jzo)d;hO%8p] ;{:sWu?MJ-GtD@TQ^`2vRWk0jP`<Bg^ŵIcH;jT,m~P|dol8Xkuݯ
+_KF ȮbrUl&`װv
+4)]1ݛT. =e  W@
+#"~'`,l.%NNL42 )Pi > $ӈMb&vyMS0jQ,B-5 )xF@6܈$ݠ6#߀o@J#$8^,A
+< $#@ha4x^SziG(L̝iG2 %& pd8)2
+{\N X:['5"0N
+mXMMy5ToݸߤO" JaD׎zt*fxRZ*ulJUTobԋo: 42
+Q~h0/~ꈻ=k\#_`0O»`wy#ioZS<KN}ְ獋?MKh˟/2J۶S߅e+JGJBJFHj{/z!F&uۓq7_8ȗN2\N4SpK
+U>J~'|Y /o瑻Q' k;Oǖ9V Ή#sD3GTny{z]QOOS啌|CfpMP``gHGx2f"ۯRR(\ϭȏ<|z ZY-aU+`p/G~|7EۆVi\Um
+ɵ,1a9dC^yU3 U"[!s@lvSWxvݦ9ddWҷ(g/oyҖ<ok[kZ4NטdsK΍͘k- ]Az7D\5ѻyU]yU:)iDZ{'pޭw.w^NEں;՚>2VU*l_q:d!qNOtw6FpuMâc1s`n)a139=` C$ڍSuC+1$+" RRrgLM*,YȠO2o?sp/=x#JߞynSNyuA6 l~]b1w;Xs*.fQ95>I
+ZMG &|~Z`oAčE!HF`3EK a%bsKo*m*Ͼ޽Yzk]i?קY@\\.OɱPī/]\Dcxd X.'bLli
+n*ä`CP$ۄ᠌^Fl*iтn/ `
+Oй$O22Z$7к
+o:N
+l?H Os;(!w `Nxgg`~^eCp¢OKHTbSt qGѣU
+CIQ,;oֆg82Oi(*k(B(EhӐEVEϤ 0jyA1X3"rGLC@0j:#<`SЙP$m51"-z&߬eDL3Cm0˜4j&2V
+aW
+9jo}D/?K!(Q} ?Wz%aO<4cd<lG!(QBh0 PZ_N`5U{$GH
+Q Ԍ PD|jGwHu}VG ~񅑝?wHc"A?`%R4w{ʕWd] _>׹;ן$'8DW?M>8*9:">=?|Wҷ{EE*\C ovWӻ 1r=Ew^E|8~wK ֟I96d04
+
+לkdt}Bwl^\p~v9*}[[o~1ovdrZLx5fr_F"Ô`ܔptuž[Ц/ ?0s}^طByq/ aëg;Jf[+ִ=+]T>X:P0XM-OS~-粶&ۚL`Bn=ߚsg<ՍU 5H1oegw.ړqehwCk;>^<_AA|ErQtPCq7IG'_=K/on5"c-> ֗
+Dc^v)4?
+PhJg F­Pt 수WHP%Xz ^Gr;t$G 5g) P84 c+>?&+s<ڿt߁3=7W[cW?7}F󶪦ʪ[˶4ޮ*kjl).]^ygߍ~Ys`ljuYXVP
+h6^MVkM`OVӮO;=ʑ?+߶%Y /@dv;J(6uwu?n\ 84'qPJ B8x`!O)qfzi_߅|m>.ٝ٠0gzQރOzm||/'&9}~sFǶwm۱PQKwEQkWYqG[Mz=͓-@Oa1{ zKom)#X }|ġSYͯ64jR;ĮR;)ÛnoM9IZ^V}e M+slVH~4H92+x) ' @30Zx$'\ۭ,LF91Ċ' Q)ʟrDg<\LAKL%|I9Rp5ADن
+N"d|IZLB!"ڤ'6AjF&ՠa\DcQL3>
+,å',"4b\MįQ n,ApKϫӂ$P=3ƣ%hr$ePUgVLQ"D%,:Ai2H<ͺX+^pN+a8J;Tć*D.O͊E1{ܕ921ָ7p*
+czaIeFB\dtv>:O"g <rP5@#t֛pɁv)o
+G<{)KK|0 rCd-e*DZPzbj44"a ,yJ,: :0<-
+Ҡ7t0JRI>$ãưäT7:l/USV`J<x"Aj<`35LE$-MB.8`<Ђka!cpFFSL(Ɣ3Td E,
+n26ȼZ ݺ1YYj3SV5MReVEwl3r ,H@7P  opo@`Мsf|;)ۻ sl2%ӧ=,IuG)Ě,+o0'+yK.7f2o_eޙ"#g*wKSl*F&3n9"SԃU/{~U=qR'<BטɊ#6 w&
+lSYuo 8Ƨ[L#O͎, D{8b>-`]ws[.ȏ]6[mzܺ9Lk[ngQrbM릢MF~ogwE8Km2.߱*'[VSHA0T9c@k=ABLj)04<ԣ~"m4vFx8E졪qH}?R,U6qxVP0=fB& 3nOx
+oj
+ohD
+!cfnXNӆOBZB;8 C.r4bNb<A ^ njU҇f_cG;z}{ z
+ng :C^=%)
+EB@z[kd= If+ڱƈt!; V
+E@kU7؆ * AL2W 4KV*D5
+eRbXQ!( *&M
+EJ~0!ʷD10
+4#c/mр1 jl`Pcjl aNKك]XB!8MBH @
+2nRh
+hl,?s68 $씚28VIf" 'VZRn5#ԐEZ
+@дZ)vy ͊=u.e7n}OKр΍Ky}6Z *(˓.w -Hlr9SCԼ+gE9Us|bǃ=_UKO
+m ol:̉nm`%;hx_>oO oٝc/-=|rdz:Aߢ|CaSU6P
+L|~PqH?o{d
+?ig@; 54]O@޶Mm 󿨮=^ihFiTHMFU(/u|!\-h &o9I,VëUi҉l4yKC:Ots(A?ZA :% I;rM#)@jZXWݧDgҁ_RwV~L+P.s+z2Bj${ |rVx|+{'3+% yۃewNv>{>z;}h?-b>~*͆|Zx%x_u:1}t@6͇gd,l|Fx.^?gG!z(؇~a+kѫPfU|]n0(ni[0Ԏ1[2!Q)F(w1OT `KD׍ ;_ -_bbJWYM|Pw$Qա{5ǒJX9Ok*X5 )qUi Wa:GTv%sɭ͑oX!]5Sګ^WImapR4d64[@̻怤NVhbG]X=IxN#1NR +z8l
+z{g[o8phw[pī,fECFTikND̰{cjR["*ӣkZS941a3F6ڰJN:$=^ۗR)HǘdZp?eԕe_HIX%! RptTAEj33gcF:v,Tc*1l Id'{d1|Η&{U VծƬ}AzeH}YrÉe=`^`{NᵼGڥ#˔.|Y$6RUʡ/{zUSPt/8vM,k3Wќ8a&)NZY4A|VgdЭ,fLY_SS͊v>imp_/J0 ~8G> ukv`uݭ7/m.4Ι斮
+!>`4E "D.>Ad? Q190ɁB4@#'|7¦x4.&pu~C3N[&$8/Lt'2aaE8B&5)9@XMCbhqL&Ms&\F,†8 |DBs(FyI/qxeC1 X~7 9 qY65ˠc?<LAŔͬ\"C$38
+:4cJ:f~@ϖx̀ |9. 5<=S>#0
+<M癜f7f[@b"\mc֟Śf
+k,;w]޴0WS[~f}GN,<>q8`s{OsW]ܹmT|>;crYOH6Эh#iMS*4QڤkU_|}wot@f's5;%L'8יunƦUye>uz<'=h'(5YRe)Fwli;<̦@!
+O䞚>uspFk+Sb0W#V^Ycýj>Guі{;v~iAIƹkછ.D@{[{{+sd\\;@{O\'d'7*頾J|zSüYkL -繕bDOKWV],i:{lhMwxkʕ]uokV7U[(^c=yд_zz@_՟0_GSJxQy+q2ՓZ)01}vuG;3Ӎ7H[FǖGz2TGHرpq28R*N?9 o „`ƀY"]V^R(/m.4R6}y[]~3K-mObMy6ԑ9h.4;,i BdtđS˺mٵک88g($uz$n:әLSמq}cWt:[Iܰ -J`{Oc7U
+oOh/f}ύFlpzd_8/2J/ >J0
+o?&>bF< 5S[~or[_ۯ܆ %
+ E`Z$L?DB$
+ ',0@ePB4@Nw(pa#aEGdnlCPE-=`
+>f
+ˢ2)z<> SL>pf 6i Szx+):޴f0Y+X\)e'*4yT 7M( e14՟tq`Q#(':x\O ԨuѸ~/" 8bJM9F Q6o#A!HQ2QR
+3I
+pe/ |Ū?ioz^~^YSݱTvACFTq`#l؇g'Z3NOi/ǎ˓yGO8ͤ+ЃcK/[ gg[EG?v3Aڂ<-dՇ5Ne= Zs#[HAh}rNGgVov|ZJ>]\oɟؾZ<xrDyPYt'B $,!ȑ+CNGeڱFwj٪)GqEJ
+IHE8  }eW^:>C184)h??;t{XѓW\h7\ə.>RqBȁSKdg?k^Ӝc0ZMbV߇:
+p|;Lx]! 2~/BH##_k*1qvʰ}Nk<N+?a&-+)~JwG]O9Ԑ^i{=EW+uM!cCv$=B@WK4j?Sv?x %q^ e14|f@Z,fe~O(:lp `5}4-2vDx/gQ,eK.FT/+FU@Mc׃*DwUwE?Y5/˓%gb~pbU>~8;3nyG+l?;uv+缥jP} 78Z<-JIÑA۸nnKXiUΫ\sq2+=
+4h& T,}لB X4hXm[cǀz:[ aj
+ qLҋ֝W-;/~lcWzbm[AhޮGܜ֚㔬ttJmmNꩋIooL@ [R#yhoHHokLLoiğ-d7զe6קfMonLM{Ҵ'i8')Tq ^!Hzښkc{ೡ˼&ї'K 9}ZeNhJ7oPvxGO|d{W˓tz;w$r+Z&m=$l9Qݐr_!'& ]#:g!x.)i|J(>Ml ZDBt9uk556Vݒ[ӚTߟɩigdi UT@4?`;F{G}{c|&vsz'}Ƹ~ ^h=#1.w@ p(2+P1xbpg0ΐ"j94xکtHLq0[7kLbhzUoXs,0fnW;9啐ڙG'r ?ZPVppg4Hjxɝ|7eGpFX,S lRprL _S]mA&lYGU9ZV`e q&#.6sOa3I&m.Ak7 @b%mޭ9-,8ZW<Vҩ9za7ۭ=n
+ӛ`MFG% ù=è%RִۜW ì۲B\fX. J3RIZ#djptZ^uv#/R Қi6JE#^ O|)cc0/lI4)P2q
++yc
+tnT"#L;'OfAAj7v [I-Fϩ6F/,q2vQn[VeD98I1G.hKŮiuɖ(7Ux&6pNGTpMQX*"|IZ轻(./ { :owvs"BFTUSd
+d#\ᇓzw
+}No_w5Gdս,vMHHﲬw=zӂ~9Pґ^"LatW6\ppMuF.=d
+?uЋ΃?k> ]G;
+lG:Z`D8b]B
+lE$` ] gוT^t|CM4-owBMU, S[',ŭLūcVv%F\QkXS8ۭr<,j<j4*{ ߵ}0ijc أm ԧ'W2@
+E( P&0q?3-a;$,A"m6q+MM
+ aB
+| ΄
+xYŋ
+4[|haK֐c)1fӠ&`
+S?lOcTɤtrőp3bg%r tq9uqJKWyNF *Oܯ;U%3Ǟm9ٷA{ظUyR[sCyDEI3{]׆wOtl,8ߙ]kU1˩k'~S-zطSmJT7*LZ8_?sU/~~VuS-wal=U]:6>Z_pk ?RR߾eʑu rnljݴzrKYR~<p=o +%žXe^%*poYyך bM>W{l
+5ہM A OH2Aom gpP^0xΌ7륿"kt5eف/\Ly?O,]T^lUxK_y9iNJO7mS6JtSl+y˚^<۸uy8d|>{G4{cYU'o=Y7p*ku?p*~t?B4?P|bیV~ۺvjݣي,u3XRxy%Ɇ v" "(z(G@ƒADF &'zz
+9v'F'{RTx6z,cpd|~J_I!#Yl
+ey*Tл}{e}E]C<|s"o_|sU9(*((5QC[u
+BtUأNyF
+Շ0D7,B
+ʂL4)3Ofr4SqiBfh M᷇( Z{|fx#P#H5$F_ &PP
+Q#Z|lo2&-d@F<+$-z5/7p21z b-$K';/C9^Sɾ5b)~rEVQ̨ ذ#> uz  
+ t2qQ#N^t9]Dz;gS/Y8+}:qotݹ3]|Zՠ1
++7 )c.._O8T$^ƕ(m3wƗT煷7o/$?6c6Lv')˾ϋpJџ*s'otyK#wsɼ;}&Iy)ԅw~95}.KiMKc9UL˘@ݛ0r+y{<`w;o|PژPEx 3GI>JٺB|Y{ Gd.6;^Չ$N@ X0`|MĝNvv:L:m&ΤMGkSĆ`0XܷlcH]H$-+=vg7}>䏭|f7U4L/*߷ 8z1)OTGAwU*PlmOM[j*T4*uOOf寏3qMw?mVqg_^7-egoߔߟewtGX΋c a<wTdsw HƀBP
+E B8 ~,ҍC>C:b' (#I.
+H8BQ1^?m]&~ֿׯgíߝ֙ko>vJ;fOmyBtܩ'U)}8vmG+ƮnfWOp~zƯ5~ WFw@Z
+`
+!^P9fPQ-,./-ɲWk!KQX4-cBc2[.`MK6xxNy{%mzFN5lr3[lӈlل:@Y9 KG'NN)9U51XV10R]5twҋ G{M)#= ]jvߘ\]M fpq p؝
+APYa@1RH0.n-"I3R#ͯVq*#FR"Pr{d\>8Xw`nCyA%tE= !n22}L/׸v-7}ڷ8Imz|zww
+$\e*3 ,}ˬ[02=,[˔z6@62Zw^W]Զnѥ
+&h(H5o0$I[f#_dَdg/LzbL )6H73 Ά+kp$YlÓ"SmnsjvgZd ”-3cvF?^
+%j
+DfJ93
++@ rHrw=?~կ~F ta R PaVYIYU]40I kVfz3M$Tg"!ȫ:EZ^dꡳ?8}UwִńU4'*v3'][<P)__wz۵Soz5X{lB
+ܢެ[GY3 52$'.7 4vB0b>cWSu m 8ia8eM}L/;¾7|pKPg<ۣ}kDjL+sK3_y1 Q֜#~iX G96%f1n~F
+;s/}oސܒu5s$!F zhOtNnj:DS\ͷDQ0ƳWP1]kV+`m;=W߷f %&Ðt-Zz~tڳ] ]tLhݍ~ >e9}
+sߵ>2H puٝ[I^qwz3Sہ;yo c^M9!Ei.˥PW<mG4neN3bS d|ή@nGKPx4\P+7E^
+w9aDqH5@Jw Q:5
+
+_1ĕ ivuGarD]qZz#LBPCk>Wؔӈ҆QPP.IU%>o k
+2-iǃ݇N];CiKG-" j6pAa!#Z8v0X-j
+@Q qm
+2mK@#l
+4@>9$ÇplrM8ƍv Po07 g¤}Q"̪FGWktL@N&Io~ƒq3̸ 3DҴ~G=G%
+C0 j\uWX
+
+0ށ5
+:!ǧu<Nk9aƣt2R4ơGo-@Pߜ%=Q.{u0DLӋW)m
+VHHH8>N!
+'{B$?xº·MmKxvr]5?{]KY0 o,e^Y[þܐw1YyscV\ C uԗhİl e gE8.;^7 T_Ce؈ϺUr||f8$8B7AI&RQ8?D '^ҥi7D0@0F*y9P.{ Wi1qNnLű-, }py1%'q', 7ٱΈF΋q^$bt= %mxLŰUzjJi2JQetUtW @:g) RkQ (
+ją
+[/S
++14*h<TDn
+7X
+f:3/0M| TJalL+QSBΰSȚ:8qHB*b)%Lӿ
+J؎Hp3P$"K@&8(‚(fM1@Ji2# Ml +IMl
+~Pp$a'X A"l2):\|^eCb/­ 1+p9w(Xt1-cpj@U0@ +͠I&Br&
+)T)W ĵ/q.?
+sQP Oh^pqL&D6V@A"
+FHjQ"W
+N~U
+O=ߥjizP ?;s%
+XJ⻭? _\'K׆pǟ7J&8IIa9yW9z\p|5r{/ :m2ùs>SWȮ)Wwv7(j+[}@[FUѢlk(io8s{pP4S}]jq߫UTV WVVTۋ 7wj_} P/+䵸Tu4V{u֔V)des&˷ </(./QޗXQxR[( 4qgXUN&Ke={-u|6/MΜx[8pEeE} =^Mߵu歃mM-[-7[ZQ@Cwg5n
+0ۢ@}7 1h A&KfWTN]L?0Ѩu|-')$D%TmPYCL C YdUt1:OBQu3U4R!=EC␎.i) >dHy]D$N4bbB lBE )@6J f" Kcud$4OF"F ʦQ 
+ey8(pdm#ŭ[dWG+.٣xz^?cB\d|={"KOT3w s^~*xs0m"+'D"+F?}Bȏب 1? ¦q
+2fW&GR%aQpfhN؉*y m4ԵסwGߜl.mo@)lJ
+㣼6jg"AMs9n`Ѷ`
+q0[ 8}@w`w'mX^hN9"L p!+9?0(8ֵ \[$߆ X-!dE=H8Sq
+CW $A@a͢n
+V#
+}׬`Hpj$Z(s>tkt>z6!w>*g4\ӧQڹp襺7t7ˁg:~KᒘVq䯪#'~/H7{y~ӭ}|= X"D  m8,uf-eriHMziG4J7Wy%8>Xm!d^+fYΣse|q܆iuX^
+ܘ~W|akUo!V
+8)- H Ԛ$N%Go(6@l{[t5<=2P@?H/<'(bX<7Ⱦc^n{f]%L>o޾ &QJbEc^VYmL5ٙuYUܼ\a,:Uyʤ暤4/9]ٲ'a'zl{prx5ii~Qp>WW=UplT<gw4յFoK~9} :/»mX`wohHPM ;wo|
+Fj
+k뒕E M5u^CQ$DM@Q>$Xh: MyDi}M h&
+YSn>u
+XпSH΄[<WP
+5zQc}4@d^yy7aHRFl fF-1빊yu܆Ux;Ϊb9P Uymj-FجDZ l aPUX eʟ WbJS^)hrba^nqs2KWcL ZP\bxLz0
+`Ks|ݓ1U
+TG#m;eUwU6.VMax_G.XZ9X;4.[6
+'w賅ͳ|f;#9b\#xNXMaTpQ\llEo(?-w?~3q>К]}ݹ-4g=F8`gEM($=bswR<OgӠlga>d Oտ|9|[qehO=wH/OL\ruDžmy
+77-"`[S}AOd{e %ډ>X0{6tZ;;'cmoo==ݙ=ORzVdO{Rj;5AII-Z^6Mڒ7vP\&M\g
+(TNrTNۂ΁%Oju2,L?ryܫ뺿^nC}{{[^ihkkhߪb߃g_ji֕7uvķ :͍n \}ۍXZ CYriCPn<Ii>'AyJi7NH -F&mOe)S'/a"@_Md@,YX<bB(Q 7rCQJqH)BW`s8ʆ&a9bD+?Ya
+P Uf͍;X2 %ܜ7{ld#Lͨؾ#L
+ܔ/'B›1N @܄hP.]c ;ed!3U1l<4*H,|M
+ ]Xt(ᚩ"SH vE@-H EPg4O<QeMe2OT!
+ fd+qm)<cOP*KQb{hK`ϋ
+,"@RMcx:/kvLXb޺U̪={zmձkGQm8% 'k0\vjj3~ov:4-s?^>{Wu~'Cc;RmHP&P7C` 34<d(JV=]_{g-˘ZD( rz)@E`
+ܵe+W׼i- םGZ,-lѵbKŝϿ׵d  7oxl(<.fQ;َc78zS&vE?<+ 6 `#1 @$&MUwh]]mZuJ٣]UYV6m$@
+s6m|=׾!oF|>K l1B+nѷk諭_aʛs=}} _h:YQ\)Z>R
+_1nnh}K>~dnO+aKsMV ?s
+L QO/Ջ/zϯO_/MW$FrcR߬&c QSQ<.f)Z2c)'xEjXQZa#_a? -[mh,U2lG#VVx"ګL_V-ŲU}ri
+M+U_k+Q5>W^=y#;gx fXݽ3MN5?9vO:88ut艑'ͧ5a$靶cz'uM<?rzGO>ny|ţƮ͟zF>l8~f -Ã-Ca}z~`{']`mP{뇦[kln}ufe]#Fs ډfGhǫG+5O)75ՆWyUEyiQVfHsziFQ\qC7@"^κm<{zz:w=ߎ[-؜`~V3v|cXRӾP񭓗h;?pY`|׌gnGεbՎ>?P%KS)gcc&>gzDVis'u/5u 0j@5VUWPiT K,>)P4?_P6k>rF<]-Xve)ǁ(NX 
+/0!|ؕTgp#~:uaqp9\e<B^ˆ2Ӷ]\W±ELs
+FP1dl,ekjL3%+*eڂ|@ߓ6b*G##
+)zSB*ov$<H&1bd.Ŵ`S9&ہj1G@V`cA'w
+ے~njrg.T|iLa\^U˟sUtG5uq<y$I!A {*&Z`;Z{=s3ujU`AM@0I l d# $>as_77|m`mEct+3*ǩ.]b
+p*>x v
+B8;]>!#x-q@^u$űϱ_Ϝ dljOqKwt^LylH^5|4;rbЯpok\~_ﲋ*q>k"j_ڲ-
+
+y z0F&ngⓄ{7+}cÍaW2
+dw@?]5cJHëp#ic9ᓦX~k*b~ PϸO5뇙ww!sWm"!ri+8W1b 3|וEvpk=(LxA= l@ascO;WTQjV|cہkl/cĩ17OMOJ)d4>@GCQ* 9;7G e#lx`6{}辧}9ϸw^%sʅ+ާVn󌭁cd׈v{zdwT)~4 FaL[i+2`Ȉ<5H'> qU|THav I!%H?ph-0|6x4Taym找;%g"N>8c@]_a_\\ryeBsgJ*Ϟf{3K{AiEF$O6#T=I4*[uɵ*׏S,J6+t@7@˜DܞK
+&0Cͯj&]*
+]aE>LOZF krkW7p8\'9
+%V ɫNm+W$anZ[onNG{6L]ٙ]Y]=m=-0콟vxno}06$ yJՖٚ^R
+l
+
+Vfz.0P9s~q JTL
+˰(mJ^X
+; %sf)E
+Űu-r ׼
+ӥ
+]'<fb+ˬLU8:Nٸx%5U$P4JE3I,O Y,Z]EnJaA氅
+cZ t|w3'
+ukc:Nԅ"YᏻŖ~B8XmEEE# bdK_Be*%fhSQKm>@sЇ!a8ڨCꇰuQU]7,cW;QxpÖqG$às@QDOjwaƁ00`<K
+`\0aZ[oix '&k?P1I._ˢޣdER+2k-3 G-R^(yvc>zՓϟrU=UYt$$ppėga8_Oh uvw~ţRٜKc橫23PA^C2ٚG&דn.|wWp=6ϋo+;48[}},>\j@W~G"ǍV7Ln:]$J!OQ9](Hd'ij.XW筗zvн9qlrjݸWOE{|OXR ) /?`r2/s
+~_|}1'316A|,/fK A
+s2MÈ& ,gqr;ޜ#> W@,l!;b
+`#~~#n~chVσ
+#s,bA(FSH -
+q,1Y‚G({\obT)q€qA WBS1D1q͑t"Hxd
+xH@R'q ^6'[[Q]"xgJPTI ~F ]T"41YRqh\)lz@FOъ fޒ.AG'-CMdt7r1I0۔s}Ԁ5t[FX@Y5$qCp #Aq7 <Q9݄ lc<v"ƁH
+cqG/.9#
+'c\,c
+S1KN\g?ּ7Ome[nղ/V 8[ξiϭwWK:o6Vg(ygcT>HR4:*+ ,y 85eg6T5/V+rRL+h.|0 N𜇵$yp3a]s)XyDz) 1)ntoyΊVRt@@Hd
+hj:XHp귭'|{=ל_ڳ虭ھt懕.m[onkW[.߿v}[^>CM;{3Ƿ-ᆖ+dޫi#aX[T?{en'Vv|Ktb7rʕd_zRw]~xqM}Nu>ӡŧ7M{p`U?ϟm\pԤl2pvZWni^puiM.*gy Z띲hj^`}(Cs+=O-,4,ՀµV֙Z_rٙn@yaڬm;O^|m6:ۺ}߱-ڰVvwnֽsn,}a)asSR٫D:N_#Y,_?Y#0;W*GLEOGgUϩFQ{Ky{<ԾU5{_xڜˆUWWwWxQ=V_zwl}a=;X<͗?d61qUbrzswѼm9&M跾6޶_8`8~{6fa10`
+ǘV] Yg|B63iF*fHi4Ľp*FHN5%}NΫl̡.o=9ӥק]{Vʮ>;[qsT*3qsa[݇+hG4G55}#M~vX57zP׀
+U*w4ڣM}>گkjwniZ{[t=}0G{Z껆[5=T-=ͨ
+N[
+r^T
+۸2xE٦bvE;6Jr& oQ #ro
+ŎMIeK(vς_o\mg:BvC!ǖPmTM([
+Y"ZRe[f׈ʄ"C $qd!8l
+ J
+PbHHF( xq b4FaGT 78"6*aNf`V*Z\I0oH*(AJ0TkPD0s@$'T"#w21zLNN23
+=-V F71>pv>_nJ!p@H [uFv@fgyR)mI4[4%J'%
+ Q6rQh$[DJsL]
+n2BIsH>q.T?zCZe^K3'-D (Jh
+JȊ/ wk>?K AV|U_sşA3tK@B*"WiT_FGŌHfPp@tߠckq(91!Ǚ>$8{,rhXb[Bߎ pqP A
+dL-u
+,eAkYt-Hxj{q_>>Ak0o%wc>F=Ĕq]b$syIcH0&l>C  Gq)Wz7[нkd<\V+^F'E8:/(^"SW<;|?eٹsGo\;|gj;*5nkH yݕ=5=85$T;\ǽP4K<JlU6hjBLf#=ȟB* B+UPP
+MNE,\g%aOST^wMͦNzr=x`P?J\|u ^R <:H #ׅ6o ͈,UٛUַ+xww+M L+/;x9Oڶ'xImYv^p74gǗvis3d4sާ>}k .MZSRHcW s6W4p*aV4;[PTs3k2<
+j2dUW5=~#.HP0slGGBvUSn*%cm9M¸ަMba(Ew>T>itx+-mJ^6M4SAaXӐ/[[Dm 8Hl%㵞<ʲ~?!?{oM󝍟M‡G|a%;*=p<}gmy֎ٰ{ߓS&ؕ!hMDHz/;Gt'Gp_Dړ_&FǙ!I߰4hXg4ڳK?0{$7fD vE u uD p0?g.ܣB[X̶Ѥ<2 g&t|vR -ܵF 
+0 
+ 1gF#s:Sl [lUgn}ޠk#'`[^}dEzia巎[F+~}2y&:h^H㊛ӊilsvZ5G;x֌B!++Et6QH*-.NF]g`
+~ `OFLbƝlP8MNަia
+nԭs fC'gI\s-yܜ+(A" Y;W"& f& `%;IW
+,z) A;xH^\X’fM?
+d`
+,qBU.…@|@>{SrZ BjUL rXHM0APyH
+dNh.&ϯYJVm$;xɭm[aVu!_5p>};̐߷A.(0EcَҎ jUaVl(V
+TPh?+R& Eg2+KකEY)g-f D5Li*(e.au@0@Șowov턠n[v>>z;=1!Sjy,;ouYaE 'kP3X2P5n jTa!riN73&~{B : Le䠖HyYViN;U3 o‘}\т~P^@]j 96=a-jJ0a0
+
+TKM fƫҞ6 U ܬ23Q ]ɡ_?B&~{,k%RV'ΪYDuJ>M+nDwшo+1;mKI DK]K_k-LqS'qkBSNbvj Y|^cXLEdOE<+EgʸZRxq]j70w³}c\8랸em7昅BR/(6̅+$[uLM:yLazyth˨KU)UT
+Qs0RO%U
+OjXB4 wz-oF:
+1Drgu)v%`S͕ɵլDVMmR3vfܿ΄ N؋$^;odYD8K(!B kaDy<a ?.pRpS\9wG솛MN0l \#STQ<Qy22Ex#:N&Ipbā92_ˆzr.&+յ:ɶ.ƷM9LR)Wj( 4!&i+% ih C:А`@b8n&i]+V+Yy{ԃQYzdX~f쩫nnו7^\,`Ž+6ݽ\/g-†esw9z?kgw.xyt]MLc[AAJ5_tu7߸֣ץcLaq"̎$N$pV'"bAb`y$b`DFdLIHJ JߣzUnNmdc~boB-11EI?ر)Ă$0 \,$<,I8NP,CQƂ2IWK<a V_8 jȝ|;,V>MXM9(&|A+kI %b+$8"&xL:QytB, "W\?EhTSəB܍ȰTJE8hK@  '$9yܟ3XU p^Q?0d0L% h7y0>"H&HH@<b43A`qJdQ4AbhXD!j$,S40iӕֳS:#U
+`2
+flKu3ڀf}vQN^nYj[T&xd*ǮѥHD03֘Y`}h
+P@'傀5
+N9zBmXmsNul\OU='Gʼ$ ?3g
+#IPfAL?9ԥ²@
+͠0lw 6]Kc~dΙ]Yen6DjDCғ Y.ue`
+T3Wճ:Fbҧr\ ŧl| *,Bb_ӾKxv|׵'Gw}pzxzpڡ{5_>zMSͷ'끎&fZjηVO>j=5bvn(ƫw5_=pVh_`wHWXOޖ/vcDgӌLu`hLXyv׏?T T8zP˽U@MO;[tʶҖ5m񁜠oU7ߙh885=>399uX3swp_[foֵݾX}ZյM7
+JotK GXP4 AX 'P.3<*ϣ03d"pAJ&ddN6a[$:R#Em4u`U$v)7J!@@P$9 &i[ νr~ =£GB|'"=Ӹ@ ƹlX(ty6Ttx\¦{l<ヘM\^A)3nLrdGJGqܬƝL x6ҷrs tGfґ%Cyt/]]Dy _Cw4g y2!*q řq\<J򲥨*njDED,̚ Ym,^+ y`<
+0/qN9P:Nb"Y&9b!7! *1A5KJI$d~[
+pk&B-!, ɞ
+ju]޶St9c٭8c;;c
++um9x{
+Vejd=XA5Reޖ PN]RƵګ_^7~W+Ys7:Gܩ@D؉iEvJpq]I
+٦ ֈ82i<?GɍyOB>Y6>s*-;͢'A< _dxW>]
+i bxp#åUCEa#a5ChUcEy!#y! crq)_/@Bn/nA͌?MZCiYޗ t Mg6r5IҴvvF'+ ']R+;S[;OQoK\
+7QəerMrӚ:s=u/
+[{ZqdDzT1/!F:C҄\Z
+8N
+e֒,=Ӟ-5O(請gjmK@&):尲:R>Y p?])g%_jx>v?S|z?~Y­`
+ydlIgoݗڜ֖ݗ5 fC-@hrGx[yJH dvFy/WqQwQȷHRNauiH(Wlz.g$P%+Z)fw^.&J8:o`1aB!-TlN G(|=0ߛ);*rLˀu3"^fgk ilׇihh
++KigG H*ϯe|a]IEd?rl >0͐#}ǣ`^Ndgn(
+ `a#N8YQ[N!N*Ah6PHƄ}0a
+wͪFckgkקzj}sXvw]/9)XVrU
+ DY1m%VZB7lق+MxMӒరEN+HxыZ7̆Niro'c%$dߴuV*0XvYߔk= hњA;0Ѡr@meFTb}
+]P1 TmO䲞֓ R iD/`*Ll&CgDKLxiv"iQ> I%`
+n{Q:3lÈYvdT!-}4
+.e8S{Smm{8#=X{WA6Y ke$!`@>Q9w=y}>B钮
+:?`'fM?h,I@(a'yj;5pE๋D
+iDb+@q
+&2n:VZcuX,K-۲ N!Wp H 4Ӑ6)\L-!L i4fn \ll0ے,ɲ[jVm{owo\;KZ<!rh]6Jt
+ug }!!yU<$xOl"X_j׳th`ђE.
+,2 Z
+r; B#yD[#|`0 -JNG:62Gy#:_mLelցz?8{lԦ˹o/E+O]*uRS_C%ѮatI:wEeSwލ۹|H+H@ռ
+@(U,O jg␚Dq)W:}*6
+sƧ֧"T^;hbtIgh0AX3ği8x:@LuڅT 죍@Ռxꮘ%R=.sebTV,HT:y8ר
+&-*o)>1UeuRW
+VC:'gJj^UilmsU8T6d+& pP K|l;*1?lza;!MpQfdRJ|]5(<(
+
+{a*Kگ6B\nzS4lx pب%Z_ܮqO]y'6Fd"gv'\E]1QA
+ɒbHZh 
+؝xu֣{W#~e5ҭ.Q0886
+ D +,S0宫H1<8惉
+W0-/0 a=dzg ?NM7uD}86W -Vͻ<yF׵_sĜzm:pßb{]}߬8ͫ ~ߌϯ=̆R?⯬4ۓ?_|RmˍmqM;Ċn @5dⲾءy_-<΂oq&І_נo4_B։%Uwf z5@ҏ'_bGn6-{p{έv̸4RTi D")̹ej-9ۨX
+$z`'@aBcN*L
+Zp㎙CVWG;l:?[v[na;yg߾޾ x/1wb3#tcC8ޔ>E_mZ`{s}sG\:6>L=ۢ8XnWꯅWٮVmZqѵwPojSMc]W?4{PSyHHB
+(uQuծvaשtwtlt|TWQ"uUD$$! !$!suw3SASwL}]uBs>bٯ ^~[ɫKڞCھ^^o9>x#畿>/~ˑ=ǮҏvN9y~ٝ ֎w|B"`tZ+s39niɷ Ɠ
+a6^
+$]ꛕ{Um6=v«egu_5]zz쏺/tT6S4(2tQF 1058p{]0)T\ %)XLFIdNoKę$A
+$R,
+|'w t Z.AQR#g6@s$x{^RA\.o#["S*q -NYe$!1/d
+K,mB ]
+CrLBTï0*#jJU5I"zqL*"[0p4[#gLvhY"'\
+sOcYX@dJDH R#>jnCyS#-0]@`A1e9X7'ĔٸL!ʌ@)n!*̘⨝ M$ +A6CF-°& Hb
+0dKI!Z2ye|)lb ?Αl`O!>P2K*M(o/I-E3O6s|4h҈PE@D8z[ޚ@p>Iҽ!>cאee|0IuhoŤZ6y ]L_ˡ,FyD_N G@$ I_ Y"=ra7*;!P
+P<|Ɋe7V! N< 
+7?,>dH́V}mxGot?ȃ]z'.D+/w|B3=Kܥ&kG $ϣ݃A:nCD=Yzo|N zT
+d?]vfOl 8s@Yϋ̲Y%]vp;xEm 9N(zݰYR+-m8Pۅcy0`CW9ooݗn9uX+dMR9!=}&mNk65Yr RzpXHMljW Ъ[?1'/槞M6*`5+>5Ї޵OʣZGr)1,e%]3DI1Zq$C#&1 b\̨$< t8:V%$'rJBDۧg3%4Įsm#A^ˎ2'ݡ=ߏDu\T<Ukb%ObO/Bs%sӔ]Y䫪Ӟ0m7"ͱ8fo՟3Gߠ+n0vv7kq&XruX (ɶmvkrn=gт, 1?u㾼
+H]*XcXAh^!C&'pn 4LK!I&A:*84;@,d[`` n#:/ږ:* Q!9b
+d0;9` 3-N-fYBN @ pbMM\ >)Y_ ẹ8
+5Y&1"!0cƤ?hREb̨tʋ
+\RQMpm
+NNۨ0uLSVVR,1+xdn]ԻuX0~˒Ν pIY e~UgG̚)*]GYIi?Dk%יe2XfV0صyc8H%hv?vpQ51YZ"q=l{ؗ^E'#|-HeIwS%"ȪRC8&@ǚ\7:N@X1e+ϼ4|o˾9KF/űDo; j pf8$n7&m-:4H0 %_7Q\sL0눳8lع#egOиw<9
+rU\=U~.|<e,'xl~(
+UX)!Ϟ$z6JNu+T^UQyͅ#ܹ|cJ VHQ,k'!X]Q(B<gNȊ&Z
+L0юnNhiBjbj+( VHe;>z}~=+<y2𘹴:Te]y<1eXfo\eMSKxO&W>n#Kn/E·\o̾$ܮ  $v@ 7uOf6M. WF]f5t[]6UuX[ƍ3#p n3M7zi)"Y2q/s*~ȴQF&k{mΩSZYe>q}`O.,12سm~xk}{_#אu-Mmֺ-Me|ˏAd:%]bz*ES%:#rJă‘jbF)MgSuJeahSLҸeFD"8R!=Ss
+:@la*&C|A,b >D
+7!MW͡D!q@UP$h+NԁQ;dm k1Ys1e%8R[! f2&q[ṩi4M9;fOg=&vTX agsur* .i+6ɲA QyF&SB-](ԍ=%wGtDG-i&9]6vD0(&Gp ۛèLG"F,EGU|
+ǣPxbC" "gH -j FhK
+t(Ȟ((h]P=%˕q*0 "P#]j Z&J (& :\@3֘nM4W$-f͠fD9S&nBvQ+~R*I"ȒDR9e
+`2j8TFģ4@Q?Of0@H"F(I844F(r(P3
+$@
+;vˮw<)0}߱aZuڼ=?|mW.n~fQbz_}[~WrzUzF<.ࣂy H~84$#a,0G",~.B%jtD%-Q@- %"y]rk=+; >|KqIj6-fHJBVCVQ]鼺%zҩ]Gz?='w7x̓ߞ}ܱ#?KEMYF$=:y r J3rTD"W *KIL&N;L۴i;iC?d4iIw7f311xGTE@@ɇߜ3gΜsLImcQLIfg%mKלԙn g?uK7vV-۸ ejQ^#jPZW=|_Nit6j;x2۟I
+l]Uv eU Za{)07}Zuy onܥ\7)?~֯xi^{w;[?|f7*g[ۿs5_:K5_i>Gt
+
+xV-iR:LGэ/l=:~-o9ӤQ+* V;ku麁yQՔGG+]̾OOt)dm5a7+ܧs5o'[j*A?Ǖ\!Sgت6yZeuvݮѮVt+\2G``i5RI:C">Ta4.0%R/LY{_q3-6 @-;ο9yw':_%P9;2?x?xVz]Ñb~0 K>-9zkN?.mQTA`
+=η43i{ʠ >,-*lʄYKtK1i/(CR8L$*P%Qp{כTI<*>w~*a z-Ƀ9S2j2Z iM-!`ɎPM +ŹK[ĥ'7W-CD^pIKN~i0Xif>,+  q182hWV@KǦ|~fڔ^7gVmie^ h[+y=ƗMA)4%umq}TnHl!MDt'0f)ؽx(%%IҏXf`ud.bXFČcbgƬV„ >, 9OH:pԠ@;VP
+"PN,=Cv 7l"avYco(M a=C8i :ᅍI܈͍+coՂ̄ XI+(+e
+aanJ1`F#aA)G z
+>p:fl.F堒dPm>A܅t%Ԗ"!Bpt* '{G(V@xhJ`&FԸuÇ"J`4
+ yG@9~`
+;$zU mGW>XBVh Hr
+
+v܁7^jj <f~Iݖ=Oo\%
+>X9V=
+.$}T?{u, ;gCxh ?ƄWܮz K|,_v\yvOn{?_<'.?yƄ2Z X>-l'*Qě LA@."JaK!|}Vhr6vPΥ`bG4ɑCiġɴhjJVX<*Vq듏Bg`՜`.+o1ݻyٻ Q,) Ro=j~{f MEDAq|WQM >MQz!z`ޗI|4v2O_|^YUS%O|1YNlQw
+S侩\Nh'k2̤H'iD450XJKd"ګ̥F؉-RYUF|*'ի+c_LG>H
+z3y}lv?/7?[/bl6PtgIh% ؄)I,N:E1c 6.B6Ц'i}_xQD%FSX4`Βi!j%2_kc
+;.(PO jaL*@ VISi
+?lj@V##*2c3hACkM!Կ|mJt| bv a 6}Վv_rbݖ8[g|qYxq: ި"E *
+jCp! T:`0smtpy _8yGA
+5lv5*|тFYርUA-pv#wN%$)1^ɮ(1Iu
+!,ɇfo
+6F}CReLyPS
+_ӱUH>V OjpqkZpMB-y0C
+Qv)BBF?b"o
+c4k0U-N= BqΦ0i^@53(EIҸ='qx944n` ~]ef}4/l[!RVNk? [CLԢ]+?+Dҿx7qzx2~ɓ3{g0@R<;}Dbp`HeTb:É`0Q%[q.jS#rgm!Q2!] @H1"" 9f^o
+C= N,p e}La`
+<9x5VSt
+b
+c/kihR? 堧ƹ,֣W;>X߮X,#x{"0h,L6Ia[X6S
+H2 d]2hƚ pɄl)+[
+?S7?8~Gn
+ۦLva
+
+Ҷv爽د548[Hߏ~Ȼ4KO?Dc;<b2Kd;5KBҴ=db! aȼh-T27IĎ/f̅t}TiJ4KYBr\TK}brAK]2볜m3Ok
+tOg@iVTP@[U{v`:,Yϭ[9*Pۿ _h_8)6o_M|(Љ܆97F?s
+DzA튶BŠ\:61o$dLh$Ua6wHVoK[k~m]J^(d)MId3R+vٛAJAu<'afZi<]̱LJƸ1~eQIȫҡ|,͠Ttwlޮho(B5`pg^ӂJ(CAZ
+KYZu
+E*(#P_`A
+H}?*^X0*N3.! g*~gT$ ?.bxJUs!u5Rs$=!7$hޏ镉iJefӑ1L-JN3W屧e+:15dO(.PnKhQDžHdgNs`V|RJ8hš
+bL(aP $_OT4.۽Ë;J!YMV`N
+8&+1^*My y 3DC
+x}']m\r-M>^Wچ v~᪡)3pV6,MZ#Ҡe$M={m]Wݏ¥RUG-ͽ}[^lXwnEvzh a6hvEX⨃$׆-A"n.CX.3P3n]*ؾW=\9z?~|}:Ƹn^ͽrI|tMi.Ә3 c `c/^w;&`ٷ,em2Hm3LGJUU7U4Rd2LP&J`}bl0U::ty\Kگ?)Sd{|7__m_̝+\X'ʥm9'qm’
+vȰ2- uFB<97
+mZTp,B7LI:6h|x2,}2
+3[.~R׹>}c=C{>PxWtGE'&
+ -R@Iq0~z ' Yi@WPIE!bڄ[CM'̱ "xSTn|hC^p&
+1=aebxgy˸;"n̋^,/c-;={(g-#q2ɮ`  oO p,CbV
+B^2;!%=+IPa[`FmlIeNbf;ȀSC!Rv(
+I
+DXG
+PVdUlUڄUuC_3+Pٴ0׊fmɍW`@9[i.ƞ=Ary 3)ʷ 'C;AϰS\&Ɠ(g j^O;!=EC^X([#Vq AH1n.1@EF1'jQJz`٫&*`5Yc")R|Yf)_cI,LIcRA"EL<
+hޙd<1
+1JvDn,7 Ӕ\AM IH
+c!
+7[tYgn8^
+?-0l
+gibsn7aޝ̓Z&]VJUv|^ ǩv! j>Ѱ.\7o("L;”ﺳXvVn۳`ٸoNe#bfPPHV!}H4w.]y`qYo' & dJK_,jz7cҮ}=|T<q\,ML_mr" Ɣċӽr*BPjۜF>Kp# _<F$, gap")]1a#q'c'젶1v@&g{vPW%4)q`ĵ(=ZT^3 3)Tb2çZESxEw#Wn!{mg؏ZO&<:[D;E((
+$<I r~ B-
+oʑ< 7l= ~2|<hz0R3
+I>\^'O5GqeBIN@0g_+^.@k~&ZAFX0 #)@Cj3#p02҃/z~;+%=%%=5+I
+'q}J&^a8 PSkv8%zՂ;3Zj&GTZwɁ EAm+lu<+ "X6@팘&Ɂod$62 40=UQy#*br;^v뮌]YU))-i6zP{kGDvFvJ}vr+Nvx&\xwۖYYpr[&'ۨw~:_?|cvy[<ͻi 9+5#%]]RJUmv&NYS!ciOfU>h8c];Yg}dgKa /U8ZsǼ?>ϕRށA~n7[5`ֶ*# ZFؚhFa=lK"pӔ^nB脈DLJU2\в1iCܒyhhr2@Vm'[ p
+r` $ܐoOy7߼磞9Iq]VsMTʐHHHOmb΋^"X6ZoA`B"C@y؋EFX|WA=8YhCR$QLۼ˦=<Mvԉc,xVB`%&ޮg[Lx)L6GNXF${tS-jb1E$c7ѣGƸIn+=or,V`atD-#Tk!rHԝt$j>?|p978+
+QTQ2`M,bx.Y@b6.5`A@H`)|'99!]D"zEDծ " !b"&'!؈pFo0ȬA(Cti}1
+}Z*G2,Ԅ T@DEUv#vIB9RSʗW >
+4?h˸G}0xJV%Qn!u#
+HSTH%Bk4 ث8 Vcj h\gHъ 'AuPZ
+R%I7K`?^!Ŵ
+7귆/(N_,#}Iv,E/Dž[}|+""œK2
+G_Y@0 @IbxnDH Nr@xCC<b;/sÙg'>7.3ac$FcaպZªöFwř6eMz<cqe_U_Q
+<ä,s̖9#z5o
+r,1l1vcWmxJA +0x6`qt!!Nz|VuMW>=é9tUr͟@} H.)/==rUom3=
+Z7Gv~
+nBJ9 ])0 <`yd:y\Q?
+v<:j']ְΈ6tޱ񂜉4ʄTD)4#eV
+"K.8bcs\g3N"d O}߳;}~{aDG㣑C=qoo׍}=:V'w]'k> }|z?ߝ7/[-N]V6  2GqeB~bf*v{#6& c)u%\1M
+N0538fcy2ӜrYWsKBב%h.Bpn#F4C\\xFR0(k*ђql)S\
+VLm
+^. gᬫ<_g.*]+J,zy)Ofs˲A)ݛ34S$/!MوVBZJVf5X5}
+K,s*,|/:2\ \\ے] 4RE%4Bm<gֆ'Xu$0ɶd.k5ô,Ӻn*2<2VV[H80xEj*U$6Ɔi[P5*RTP:8(0SMϡ1ɔSM:^MIp ͷ#{ a
+Bkl?GDr`& .
+vRfܔ,rHRTeRGϋ-rC+Eij;4S (G棕)
+!&ĺ(acV{# 4-?aʐ6r.EPQ(1.%"፤)KZ8K ʡ<ğ@$
+#8
+#
+3L<DxCrR@uoH޳wFX'_
+w^u5 8DltT~sGk$W *˟hڃnG!D"PO A)<M "@P=`NZ
+NI3fa&TD˞[+ϩJgUBRmBS3$*ryP ƴ5YN&w*J҄:։^Q4qֆQw=mb-]Ń77*;uTޟ)~7JC#|(^oUTqA閴w-I[
+z][Ml  _U6 窋6Zzk =ͭGkĮv EyfnBk4}MEPs^J^~LT0kuh_,_(^Z'o*>J7T10PR|NbBYtwppO&Y 7Rz⠊Pa\hWMk/: xnX(Urs!o dkRd pXӒ)68&F`x5+ yJӡΥ ksҝ-굣q;1X)!c8HEBY0
+R!$|dǙ +g&Ώk4T6Aڭ^|[$zeqjyfyvyb}Z69)d)޲OCS}NpkOb-\.
+يe6C&
+=(0}%̅)`?~[%]$!% #|5GvbMwf䄦pzypVMKwP>:EkQϋO%OxmY\WiwĽW_y$2X>U<{һ͏˥7ˣ3MξB#c"vM9cjW=kX$-VMk _^9/v|6.f ΝCNVP _?(juv j=pzտ&~,3 ߥ?WDuu/I ?1cb{zwy']GiWtRCR$xvD)FGkMCcUӷvI_KY:k;K} C[L4`,cU8aN@/{rPx5ٴSUv:rI)᫡  oH!S8;¡V=pRS²+0nPYRks)ЬRY,~(YXTxYO[8džN&`hB 5 Y
+`RNLՅLD1-F#39lc
+@ `@0'Qa$CVn$Vo:(}(7\1#inR^O4p=d
+
+P}:`V 0+{xH2G!7(3H7ҡ`nSWq:D묁
+QcYM ÒaXtޜ ]>>y B.xv} 1쳌^tE )s"=W+ =c(,FA۰j!} Q\-k vcWP |G˾&گ+LۛmK$״.1, l["X|֤uo.aM.7?ȣea<*;
+>>i0<Lk}<
+sB6MRk"m#Xq24)&UPPW*4_ ?%쟗/䈳|sřl`~ŝ)̗'X%]q2+߻LHWW w'/(Ou)M:֋N/O,&w)K
+eG<+^OZ["K}{S\î
+;"Rv"Σ{×q'^Pn)oa@Cj|p$ଵ:E˞uɒ=%{hxQ@vn;>PP;^a(&KSVT5VPK[óƔ ۉ1uvG۝*m<Wo*}c>lb;;ς]س1R-3
+ذkoû-im
+%map{E \F:Q{I H;rhw67q<I +I9./|Ћ.*Y]IL#\ր&
+Sixt&+jt=K>a+n7s@;찣j'vW6V5C'@w޴WcŜDkVB[72RԮ"TQ1)tq>;UTMS
+JBS#RÏVG
+^7KI%䃗TހӬiޢ
+}MuT_X)T^*N
+Ӗi
+)lL5$FT @]˅_U'ĖWG
+ >]
+O ne|G
+`,R4ViKĴB_Ff+jxi.,I;!OHBHx' ʶ0VQiN]]uvӺ:δ;֪n+*]㣋 B$IBB@< t{ϙ;߹g~2OPr S4; gL JIɐ9H LQ c4 rXjn<ܫeyl弆ke?C ֤ O!-9㌉BdHAQ'C)ipе26P֨O*iR(BOĤHKJ+9奬9bԤjP*я-d>#ȯ{1g49e3
+dz*@9;+襞 V)LEQ v$aI^zŇfӫHi HK."kYڐ4*"Oc 12mQ1LYű^3[kKTFTnI\TAIg(⠅"Yi
+$ ɜkM'ݙܥY2'<cC0dx\ ׾ B6*C]
+Lll1z0QDUsOa~s[gv9KYbcrxoaI}l9m\sFȱ$lCE#<]F'05!t-4RBڴ
+K2 +%a*"\5Nl\Vz-U%-(q҆bX!aJ+E <l`+$L<4pT\
+8`XP6uKF扴@L /B{S|3y%6l1!E"8H'<. &h_^PKI"2J8J!"jaCT?iRl$
+BS". 4(Z[~@ Z kUB!לj "#@ڸͱϭI/0g͑]هtLBq /C."zvӿi<tJ;Z3 v5b}1
+B<R21MFmtдMm tvp]~O_?vt/x#'nUU󎒮0 ~O:8;9مv ǫq5⫑M+=cF7띥os?L[l<Hv Nr.uKwlӷeUxunv'Nzna׷5rR;gZ}-Cʺ*pM<=mԞ'-a3 t1ٖhxTcP] sRv"KZk۔_rz:9f|j,r.G/3{ؚ%_oWN
+@{ӯ(_)~>SטD旔Ol _</?؛,FbEf2y Ѳ
+t!KubMZt{.X1& 0!CjB5yWMzYabPWSȿxX[0h|QSVINovCCmR=X
+ޙyx H 
+Gtƴuq6 ~0 B.#X(MH[M6:MӺUݤ6͢\IUH c wlc^i'?w\q5Sw>KHлYp[_*ж4~fp ^74~fpfi}T+kegMEwKh^re{IZ=f[*;ݬQѯnm
+!_kzPUkeVv>yqwkϹYb&Ot ug zMga*b=+B wrYf7H&B/N>U'Tk*n]&y.k8N?_P&{4;'S?(QT?/ҏIJtG;&>jժG*?h<*kUh&ʪ5ʪg+vjeiOKg ‚BnH2o)fͬ)w7{?~hɗCC&H`?aܻ0L+h:˲$}V) >fESUr3r{,ilR߫l}y[<s]NUԝ# -ӷ[tNV*;@=ook5c~v'FԦC\;oc%V3[ Pu1p#vw26j0y}sogÓuO<rƃuG5ֶXF5( C }}7FaUK~kWN. qUbW}_R<LQKN0hMH W#o
+I ᡖ! gRE(}\ՅCXS A9R<* $I )|6@S
+h
+U}5b̡إ4krj(Z«͕{r#q-go/ Fa(?6?|9 /8x Ч1" pBRb4-37ݙC9э̜&!7 3"36md :NgJ׈ Z)X O:j.#$Ck$ٳbZyU*iv5f,6U57[YͮAց1bCb]mq6߳__b l|qM3*MrsΕ>h~ӄ2`):ZB pѹ\2N ]\rVg,y5!݅Eoifv"BMBJ T\HȲ_X+5`
+V84+iE7d"I̞d)j'|q"rk Ѹ8 w F7ַRN MC
+(AぷϦ}yy>_UMwuĕ[ȿ._õ/k.`EaVMv*8909\ob6KOpNp_[-*L3ŴUEWU^̾[rv|qq{
+;ӳFC4ҊD?SJ'nϛoC?۾uya+hk|WDEtpޫ֜_˶4D-Wxk>|xhS9S2ƫi0r]Y{J?&4cIΤvSzOVz$e@ ݑN{w ѺϾu#V
++n?j\syQ&οq΅
+=9Qw.\XvpA[Q}ͺ/P~6]Rاc<wHh{tdWORp4֭HNu)=> 7_-]`$pC($aSn$#{
+@x4T
+| w@wb*o3s'tݏ㧠||_Yn^ m̹н5+ۿyFͨM"8]s0#LK"HUd| OQՑʤ!26M"j9/d|~2_i 3r=<rǑHY8@_Vz,o ÒGDLX݌DYw_OgA1qG%PJK h NA.0 6+sLNȩVeZD1SlXΆZSѽ&0d%f(LGH XgvL|]7ǖKXS};8
+zlQd猒PZN`&66WN9X]X[PW'ݏĕV$ N S2qR vn0f72;<ȫ\h5pH#3Њ2<X YAx@aӁqY{RoD ]}II%bqLXv&Ʒ$t x:s5)/[Of S: AnXW+0ϘyHsZ6wňVݝ(gˮ
+6쩳t+
+@mp#9M퓜E@uUo::>aECuߧ@TWfD s;9DV94M[V "J쇽+bu FY!p6ۍHܟ7✀]ke BZQ%+>xDo#\M<ܰZk ((zko@Q[V7-+ c3_V, `A`Vl. MX
+wL-rkb@a;&sС
+YC`cKrWS!8u0㘅X EzE, hZhtrfJ
+*;[#14xՐef?<@vC"NKt(yf6O>פۃI)%NFt=.'_(R:<b/EBi%4+Qi@-1.hr?%/v4@\dyKQBӃmsWf
+slƱ;9t;ձz\ek0tlxۻ+:+)+e*Aƕ5g|(֚?ڵZ{wVCF3(S {gޜu(<7=n73{y*Z2evÜŵD&8s*i,R&_ƤkӆqOere|4VNQ&2̚ g'A/z3M/L0mL7hK5%+h%  d:!4PI#4)ЇDCLгm 7v18QoĘXgFriiKaeaL;qcST q
+N@'v ;gY;x+J֦PElhb%Iakhֲt  N$1e`8nOY>,^vF| oDYZS>i;{lݷkV.}/{0s8DbMе;gR6 KӢ+]3[vg̱;MEwUJO@ɣ)bBkpO3+{/e2!${8ӘG$Nvʂ
+ۧ/2i:qUW*eDhA)K5 MS_haفn;Ş.5wwwsč燾jU#ߠQt+2hʿ?QÛKnx!k-2nY(r/Ҹ5+˻&Z
+ﺎ&D>:$/F[[KG]N`-s
+rK6ǼĹ_=~?0෍mlllMl¼Rᑦ4I 4i#M?m6uJJS+-egZ.MJ $$#i#8 cc;e6෍L㫣su=OwɄ6o%ZjOCXS{쩝[6zhvbvI0*FpDjlM;8F!0AsF?>C?G1z~"+٘^w&t>9=4jd遜4ߚ<ryXWG}vuh.n>4k<c_uu5>PC8q_wN|wD1=+Q*\_(i"Ǖ? Z$#^bs=u `W6=tXjbjJ!/w*'t]6sSb
+|WPKP4 ccMU>[8>5Q~kR 7VV}7?h[ 7^[w^8jL|ri=?Wo?w}k̵=W@ vH62,["Ξzp p|;_^xQp v+!2l̵O-Ai k?a,؅P5Mm` :֠35NݘaTcHֽD~Z?M)۵jUV-(z8/}Ϫ)QU/|+|JY?~W{nthpG31IW'Y$ETq-zFi2pO-}O#_|ݍ?T-u S m#U}ە}
+%JR٦V\|Zҩ8.4<5zultF6?%*_8%Z{)_XM@x2Iwr5<o%|~BIď0{,ml(Az *LQZ0' +FZF
+6Xl#[Ha6
+#PC^; Q~%)dbH<t0•F퀪mDHyD<Gg7RGՇC?}WчΟ]Y{ϙS3RGxx2;oA>ir1PI6=aꎀS\qzO5J9{jg5MV4.ϊZ64Kh K\ep"OKW2}LzM.%pÛRr3\|tGH%e/&),[ߊDt5-HY`ޮdBHzLTRs9XE^o3G:YGC 2 }~)I!j8d
+fN.xG<&-8< >*yT݄qC$ q26.TL萅@F3QZf7A@PĊ$Vѥ ;°N|QY@Qw!##P9 ӊ@
+*}9 P2,!Ib^03c4'0ޑș@Nq6x:ـ67DrS NS!($w`8N|+u9 nlA&)R(4$pHEdhU !/uE2?
+o2.V {%od܆,KPaF:GQ`.
+ڨ5Ù G,D
+}͍7WK%ăm܈42*d1>I Cdذa9eU+slr0̂gll>Ҏؖ?\>Y#ɉ
+/ dVYΎu2y88õGG"l.,C.rF*#NR0Ը8" B
+O 8%cd}x\I{ f8MVw(!{4?}Qtk{2Ǽ*Z猭cٻɺ67o;=:9>LVCPL8օ|WڦЕ#t&
+;P PAֳ@mb/k& r"3LKo-,eT
+#* D&Rm ~Z+t$HO@12p 8WyZ)?YiLYIy=nnS{`gIm"\אǵkgޙCsoS{hBVT
+14d#%xGx(2n{َ˵6rכ;pրk6]=>i^$Ц;"O"HkU!U+<bL]3=YȬ>a4ŋRl6U
+cu(茕E@jVȒLCzN
+k"KhC
+v,fà%L"1Ħµn2Bcnz r1[ /b&n[ФmYSx}xv`"Nt(Ql^|
+KzjCSf%EȊ isib}1!ihtZ0>'$z:38  О}>^R6 KNm_ɦw2LN<3SRuD4Cm04g]]E=!Xm؃W֯MKPHkn3Jo346lx], “uY ;8`~UIi)LkJtm| W'.I~8x<qGҞu&c`**~D(呬rףJ/1]I]$ٰSDz#e;K.I9trpbcGav=os=:| ?/m('}ɴ؁є݀֒F cMM@ad;M'{_5
+uOZT;\&Q[&ZZPsK܁7)9S= ']="VKCDZ9]),"on9`joǜIVA4ylSq'8aq NĉȠ@PBB91*CCSBǺNcX7Qd0BIwBa;۱3>H=z~~~?Y}BlZ+ 1EN}hfN,qrn -SQTAuP;5eO@-cXrF%jO1hE`.8H½]Uz5~@o ߥO`zB]ԧ޶bh]%wxvlז5:QR`2lZe_|7}󇹝l;O[ٯ7@(ǟHw1ڧPWܑn<6v5!-ٱ 9x_sWv‘\ne__x7Mr#/nn=&;[K'.޻cv>T6v5BqfD,$KR͔lnL=)k42lXG[o7Liؤ~6'5ՏU7ozjз)7WhS\MoAoßSޏ\Xs8[(
+ ZUP+Ga ӡ
+ ZY)`3,
++`錠
+,p OV`#⣰W#K4nA,Qa+!f4Deb%-&5ߞpїkZC՗!;\3j)#!%EHӄiZT`,1Dy:lpvf KR7[y5]2X)r)&/ąfoǾ/8yv\ae&o,+yy x-aL:T.>@-^G30zewKKKT.[2L廝lQL!QdZE+NS@떴cL S\*
+ a?`+⅍xTR2ic64i3N P{΄⠖RL;ƹ "آ
+` +FΒ0asY% vcٙ%"+%~,3!c51',sS\1ҟf i2*%y.œ1 !' 2\dJIB6dC\<X?K<2xB\-NPi7K]O-yf۶ ƣɹO(AkahNօfe?!|ld^,Wl" K$4mSH9*,ʄ0-jgr^ztcm]dtg@AM=c_o+
+ kM LKv7?ZGs֋_A~;!R8NզhV[;&so6}2tW{>w .==gt\>zyiN>|X}M빾xO~ ?l_g^>~Ȯ,%H( r8tPS1޲efa"(ʭQIch<I65jkٚLj*ɪ1dM2ј#*x<zz%G1&p#!'n>Sh[3x~Avȕ[IO|LF
+#$.aϹ;}}&_ zp\+?z3paS
+H+^y
+W@^BWX;3 [4c \\RezM
+L(&o~ę20ǔbkaYfqSld&8AG45TfHH[6r(*}}Oyk_D~հ;$.%bꐩTv<}d^L0I*YecٸY;EUd.iD1 wd\\
+RӤ~Ⱦh՝`T9Nn
+ Ba
+:aa\/}}92sEHHl9p& x-ލ_wmbn/"Fƻv%kD.9ii5#ѲI72gvY t.jqiY(g9qm¶V`0(ѿ
+qI:=p8CgJ+~l"ȧi$>8.,¡VbsmXٌ0߽9c8o5yZ~룭1P~0 {D?ZBބ …(N"⒟t; (5C!=FGW
+FU@U9zunhxY#6yM㙄VMzpkNEMhӤ Y&z=iק`œ8$$Q)!U`I{Y&Yfl]?Gv*W*&_R}^2{Wo }-}/ŷ3zw̾(jQMY=֯wN~#zWmӿ.J^1dѕO4'ҺFuKs'n\pV#f"7ɛ}6Mo-h9NW)ӷ3ҽTRr _|䖳xC<ej!fDlSOzyi{g+>ie۴MgF+>sx?cE'CtW'szX>TW?_[<`,B^B U"j8| wF>'S{4v&п
+B)b&xgGO9էՒfI h]L.s8w֩2b=w fp@,^]4d;|ky98Y,`)
+(ڀhAںZŒ.Ђ1Oף X0CZAZl)!n3<Eċ g]1e5ĦON +Ab#ZBxguFQd11>ѵ΢8l_
+)
+4`Fk*XulY\iVM2h
+,e9U 3ccv fApv$ p#YI701k)*tJ4FM1;L
+i#p70Fz Jx
+?
+ECI` رg% ۆ~ܻv^^Ayo׾*yOWΔ|i}܇J'5͚2 I"
+zh]94.PwȮh:s#_<RѿpPkòMѐ]t&-m^}kN9͏w@ Gww,Y=bP%l;8]G<*ccJ(Si^FC1vJݸmUʱu㙦'sK~1O;kjPձ{׾[}{wmox8ztrmoW V;p-~٭O|l~z}#KuLo\G-v/D9e VKVd!ܑeI/J[\bl7 ztc7mcjebgx&jӧ[k O/ هY{̃~0PMQyDG}]9~m{w}tszêޙnNE
+s] <'P-߀Q:﹫b^~7Sp>Sy":~?Hn[ș̹H;F;| `^tb~;}y7QoHf։#f
+AgZcl;@7 o1z`;mn x|72}J+K0;""&.D n-qI4tʉ&q:tajjja*N鉚
+n
+ުs[s>ϵwmʡ+ _mx>0v`7']2Uϖo>t~^Qگ^j/̝uX_z?c${M=OwKuJW.럿mMk'ZU5M]jV O4ׁWěޗ߭>66rF@Mo$ [5C᪖Aey\|zimk e>F ێ?8~ehϥ)ޫ2qw:?f_rig31.k&߽v4 (Il*oH)N B*Jiy0/_]N)4SҺʖ&&踲M5\ъDF/1,HtBZq$mK1p-|߼Ӱ,/-vC7
+Wwkui^HohmsօyBk(bެP-dyD.X5
+5h2tZX? }`؆}u%3ܗy҇9%~H_+{<ю1>UTF3αj&~}Hشki\cf@ަy'kN+gJeƥ|mQ[$Ɨ1}B]9 "j3pQS`zTFpit.hҤ6)Ij!<L@9xElUX$WE'1UZd= ݂\148-(H% d7r7dd..m8 )>$tP@"b~W ]-* R|n8bƔ:<Ɣc=ZY hVr ݅ۧ`9E=ĝyp
+?JL8OLn/t}\9YBx/ep;!&z?|2n;N{
+$PTaᣓ^
+KH 1I?ve0\6*bgn8`!R+NѝaSRO< yڰ
+[ʡjHUlL[0(w1NQƊCLZ8R: ,SV=$O6~O5zt{s4k |%29̭=fЭv ~v36wmӕG3rh;ږ0scpPUh*:RR(i5Y֐nU|}""tR(E=)]$3AB6P&*7jFch.?υY\NډsРF9H+xˀVNߍS#XG8 c0Q@g88 0͏OZ0c+!@gD
+JȌLh~
+wYAY18 a?g% *2(-aOe2ܐpۨ)>#܉#eXEVB G#)># PF;pSB B{1K;lj`
+zQDEzji۝4̱LI3gINk^*Pr(U^Xt_fyz>!NDF-.x"VP+ӓdP&Vmҗuv
+% Ekn A`ua3ళEgs΂>s@͜%tUܘPF=c#f(I蕵?Ȼ}4+{րn4ۯoW?=^þoٱȫZEEt\;Y\V}rFU~t벿v
+*PL_\X9bDyL bde1Ց5غ[!rTZ)sʳڜ
+O62}瓃 ɡ"-=eÉ BoڡX δvut8MBt"Z<K ,$ 0)>6GWIG_zSbv p^;@grrys1mXY]/m@`ct16rzugm2~{e[6N+ۑ+`8۝2Z8
+\a>]PSzzQ_af }e즁fqql$QZJmVGw*q\kkqp;ϴ:?ܷ<{_b6IYJyz('uLD Pn2@ Og~~`~-02G{,q`,mM/6ud9d
+Y'h "bGB>p6<
+C(`:M$bX13yb">37!BBj΄ -1GG/#z(2FVhx3
+:Sm Rx=P.jL*nH9~K\Gϲᗉ/jwOٟHpn֥Zb_i&(ZH7H&ҵ6JR1judRKDK9bdrrrFQ`8,KߏenIjq$M-c"?o:< n]&Kz;, M[1Cɭ |
+q{$ww&Ĕ.ޱz8GҖ$pֲαt'-SAYn8GN̖R[E6z#9j!1Q?ʁF)/ENqik(@Y+bGonQcJtTe -q?Dv&H2T b\ ('nSDw2M?;#lKץco֑am_M \][AqM.af
+dJ(}<X
+acG, ]qܲKPlsI .EΡ) \ʊN֭3uIi[QaM.Ya
+sT(0pAѮET&qYC&IC"'"G;!lm3v]24ϭ&?© 3Bv &|h^e{7
+_]( 8_s: uEB d? +(SgkДCu߈a43j}[CQF#f4:i"QL<ТN
+1#K#1Kc󢸱9Q|`D![Ž~z2;o9?s~鋁ޮ5+[;*F^"Do ɞKڞ]nyvEkG9<Jwiݾۦn^z~-q\h1Y:Q:
+R֜Hd<C.=2ҩ<+H m푰&sNcUVVd] -OTli!জBdC^zΣDRN>zxʿCAMO
+]&?]Mz2u5G}OBuf'JGU]ϏԚ{A
+樈l ֭
+⛝z\8Pj6U^LLS|NB3$98KkNb3&b{5"J h!v W)Q1yTSOD4sHgp(}_dDrm*1!..8#<-1Ȗ &` h~-7
+٠Y^tF[rbHNՇd]LNхjջJ|1Uզk&:LZOQ3q|#~6$ba p^O1۵:̽<%2hy]Vߐ14\]@)üYg U9,:%LW K@~@f`
+-Am!p.'ms!zCIحiB`xkޚ7Iʔ+A;\*֓ $WВr8i&HR&( g`+Z(3˶g"oD4WJ]. sq}^5;=̣7[\߳i#V
+\
+n[֨5JΘUh<{]Y-*soW=+E5#o6F @txQ#1C~rpd'?2C,?h;.|b9R
+~#X@KKdjHv 
+OTNϙ
+X@M_W}c_~)YoVk7ufpD@*
+e9DPOijtkLdv̋fn&N[N/UPA"X3!Bҧ;.SWS4br^ۯfz3ܢqOc_}yB{>vZV4eM.Mk
+7 @u%Kjg^UIOn^Y@Dț3W͕qG#[,gҢm$1d
+Y+,<&vax-pH8ǗY$F.X2/ IOġŸȳPQRڹ9Fّd=R=<BbLݛ;ގu6RrİPGpȕh {ZފssHOzz/7x/oG}pnxzj˅W+׊Aq'x?w_]<2<>1ܥ{dz@ztCo%͠Ec- --߯>AaNNu?t{T_m@/uk2shU<2,nzhmMt4M֎Mj&E;7Ɣ"JTn9P<*PU(ٗϜ?L_v)mK.ղSlw6EV-&Ϯ0ϑzI`mP\dE/Up5ӣBȤ I84# 5U@j#lcfjL%Vqn<c{cvHU+7q [\*xYSPkt4qy@t%_jW5<=T;&dk,Lv!Uo_+i*$^3èVEa~QS5Zzι|){ƿpoqG»'u_Tu{w U%՝J
+]gT
+]Wgqo+*g=ޚG5_݉' {{[{ZJE}G%K8~fzٵ4hA^Z) bW9îHBT7) Y:e1sMU
+˧eBDQW!UU
+βY\_u&C>-r"KPNd΁,BP ʞY 1"+0L V5b4YYpC: /¸a4*,BAB3J BȻO51
+!:ތBlBnJ(5 %휒; 3opJᘒj9&<I'('e
+!.bQAa%ܯbk<Sj40H Z\ZG=$sXOi`l:RYQ`0n
+BrZElGF/%|{2>L`{QV)|NN d/c=MyA|ѩnrSp=L0%ȝ`ůվx)7vEFXE? /c:W3X3Ng&kO6=;N3#Kf8% /}:vA0e4RVny
+Z!znHi^ MnpoW=aE#mS3]{ݨP8+iv\Ǖ?eqAQDx!)"
+xhM❦6m7ff;;;mwM7v3QcTNPh}Y <r;J-՝
+]
+g5?%ߓ1I?߷|ٕUalVMY-ec1޸]Y;!v,~=f>X؋Z|}a
+1lzvВ~i%<u~A1L`ƅHꨆѶ)L^AN'!c=+bws:Ώ߾TɍRbPv_7QT' ը/f zo~3REau
+<CUTt_S|<s,{szx;lg@{=sگPYL|y8u޽[b35ψJG ~'ZdA͟\`2)bx3Q3g=F d vӨZ<s{ n/~. 5[ߺ ,[,^^o}awn67W^޻yyaaG]o5_כ./u0_.Om+bdi{?l{G>&gV1 ^hK{2KMi.Hr
+CEWuȗ7oՂf^%x<%40j<SAafwN L6 tN'?=MԟF.Zh6Ya+5x%!|>TИV>\O/63yl^;si<F 9fNMX)TMq2 P D$ӒbG)qC54@igSZ@
+Š%b&I4 : c<G"N&)Q/`Yܾ̜ޞ,6\n{~c߂Ѵd8RHq,F=% B4&PF)Lp2]Hr\LdgXn
+#K*: Vb_h >J)yHRQ=LАvAV) Zz~|Sq!4ȶ⑰?YPVnrV!4P @PvIp'c&nq#nIgsn0Z\].S7b)%fbi)g0 ! ZZ&'35" U3"042L*,A=E1L"5 կ`T\dvS~ԏl֗ O4"g9!=l6/z}k+Kd{<:iPgayqX,NMP18@RN"o<o` <3iLK'*u$VHDPW䡔mIk΢<kCtheB&aIv%}0醲]QG=5m;Zd@6bUVҙ| Ơ$Fj B%G-ZXyq:0x !FX0t)ۼ߀__y빹:s\',h7^~?IgI|'$ z6GGtǴyql .1Ā12! JmcinI5iTUZ5)25&[,)BK` #6 >0l?{W}~|\%ӦY"$>Mc;31n%W
+TƱzC'34jm2#"커hMH7-r2
+CKEOF6q &:jř
+уh? Vl
+F O:݀'k0ljǣJR*<ۭ&a D6o6m4pǍ':qxNdg/
+>`^ %hGФC}$gw օC}Xw =hk30F2fQ);xM.'ќV|.0=0
+q\ p\0,^*M֖uV~R}?m靟뾎+Ra lev~Cʾݭ7ESƝzp/7>k/>om~%{+?qxcFTh.UoECOdNVO!d5|+\#/;Zg
+Nw0zrNċi>we61Wk<U_EMCcX(Fx
+G7E8ɷ9dxQjSV#lk٬l@&LIӅ+Ye=|"%4n+PȾt]k uj*I: pV it2' $ޟvZ敦Kd.\=_ Χ:]5ךsIjS
+HZջTf,SU#L禃F,%L/*wH0DJ
+n`q`,qJBm<%w8 ٿu4J'8?Ӱ?@ v'c<,œpA7t䊌:pG(StݮN?g>?(~$QȾeQXa{G}Mz)0)ҖFqXM֐6pm{:ީ*aϴB
+2u1WEq"֔ wAɜy3;,(eY"dP9TdeN '
+oGrƤ*(7U9D@AZ#δN4dg3dw^tfݴ/x1dnm;NƶX끢(ȥ(E@?yy?yLI*5:dPk[}6EP[kU+Њ@kK?hyȹ6F޸LryB9?!k'
+PuktFPJɱYX0o]w{cQEb7S*UF-W2[Ξ2? ~ACMߞU++E͹J|`]R
+xQϯ#2/oV6j#Ks-b ^WX/Ƚ3fz0^i,7ֱfī2a|%) {#CjѱQVKlgzPLH&#ZD= .5
+ޘckɍX-Y1revK;Oed:Ga::p5Qm,ED )TeҀ,Z%0sRLV2p$NBeIx:6,Y< G$?x4baĭhz҉$A0
+`]a
+CyKO+0+"BT9 f|R"=fԄuhxT3W˩sֺ&(RQ\:=G \
+Nt0G&ъ0FfEhdVUx.Kџ`RlH@nO"8E9`Qf=
+_=,EvnSH]
+ma;L Fᦛk^N[kGu$.lݥm  ̮bP@ݒ͝TPԍbmư4pS.7U@qoP<;43-"}F:vMbu)f ~W&k `(~_s:&6Gpsh^bv#4+H$v;=r˛Ka7_CK&Pfdq̌*>Ac2ґ1L0``@H9BL#N
+FH3&9D*siuI>ǐnSy%˾(9T:a-m\Qa[#豷^YQ@Z
+@鸩YQp5ˊ
+0QcoQC`xQ^T
+U&>
+͛o޼}~/#TL"K5Z˂hu>ȝŻ?qI3J@.( r.҃?~$Y@S?[w[_gvtYK)6f}7!m.cC'@9
+ A ndxIEI-(]3UxY .WUGxu1%ar5fb\%߈k\
+^,\+^#(DVQq{IVމ/Ayҽ{;-nʜ˳[W9% d2RK'ǘLPi9LX5O
+^V1I4C\6a1f- m#.78oY yމLZpbݡ"D`OKDrf;gT
+]`STfQ|>TA'v1H φgSq~3%[Q$r"h%{C\8EVV?G`yX%ȀN]
+&۽xUm_%Mm1G8?yK쏣x)$%!Ůa>grSW۹L&cm;%'-D煀,^"pb`%&Q
+mvtn-p5` +[ނw90ڦV_F@련W%~!%`'_
+ _^ ]}
+h `n=s ,̍{SnC}B7(5_e}zk~p|}Uܯe7o=DXޖ,GXTRPª-/x[T+$)Hp+~[ȴy:~I;r%ߠ>>[]]U(<9ӵ3o,3($IkQ7 4wv| aÃ]/N:*O*Rth:f 3 "_ ]I<XJQW\wGIx7ᓹke΢F"g= b65XJP<zisAss&..c.t 6CU_\o:~:~`*!
+YmEfP{X<I+s$b&OeSQN:H1R#|4e:*Q5JIS)?wM
+"F9A%j )իb*UQdr:Gћߓp Π,>ؓSw9L9>:K,a@^_w@o53$s*+ m\M[J%DB.xњVpOPF(0& u¡OIBMM@\e+S4H~0{%ς/,?4|.6&OObR%x0 ԗTG71Lq
+djLن86)ߡlt<s$k&dNVMoV|2cVjQF?KiH4TBBR 2S%JYɇpvDM^3?&(teIo“Ma\8
+A"A ȃB"@;|??ߧF+e
+%W$5ȣHݣ9RV2?F8^ȂePhAC9cL5F 4%N#id# aK^aK|*R\7Mw3۞]̺VuS5ϔ8tt[O(E?B. Wz2&(*Hr:_:
+<g⼟@$0/^<%S}nP<99~O(ԀOq^o%s _XX…<(r̃C6;Wx9c.Vi_C]@I5Of7 -D#0ept#◚
+iVW1yN{N.:
+AAA.m}|SRY#}U-.|4ļk!=Ynܠؗ{ ıf,،to$Ql',%?CfD]XwBdL8 # 9჉qKǼiY`&b&E#xL
+Cp2#a2^dF%eؖVdϸX)00UcySW\6̿53/c."kc=O݃d]J>ũC7i
+2MIޒhUژQH[hX.ӟ3c066 x ^L4igRUUUUUVFv&i'i`cc0`ٽ|{Ͻҹyxi}7?3+cpn@8Wly-}ӗ;e}!IG @7
+(VjRUn*ʛ
+4۫8&,45#籔x|թ8| m0Y&c3_3UrIFQ{Tn\vei{-x
+]سL<t!ZQ J3̰%9LM`­qf~iM2fG ݴcB.Ԑu}7b5$J
+k8_jbfr1&$,/nJ[iU u%?`mH[etSx6
+Tq6aM!ƺ(sl6
+&b5X[Ԭp]Jyԝrtǜ,9B;ı\Yx %ݑo,jт0B)pOO@Y XTڢBbkVbM!Z!eP <–zBv*+ە`u+Zz{]`6
+_W{Q` ѲN)I ^DFNMb+@ wh>dUCa(0™;[Y¯fէ\UPO CB3cͬ-h]Z6˟%A pR|Ot \:spBba/#g<r)&&`'%a[9Y l ف]9->s@TEuɿ+8.lՇ׊pܑ'])K |~qU;e`|@lFw+.$*"a\9>`d"J]$d),;
+`<'
+`DQvMLj1
+aܼ+AoKbO5,"ᬺY8omʪ+;MʳH3/Hy!Q O;[i9 WF;5tmpVw=c|kF4J~I}ks6fJzn~?9 e%sJ&ϢDe9NT&ḷ "kiYO3YZqK}/kos;Í.uǼ]/ 1OWb7< `8"$!7 x(lSiwwZuETDC@N#1mxxg?ޙys$ءo\
+
+AksN朼ڮꂺ7՗hgq30pS^忿<sge.Pg! wSVkI^sptE .glt9=įGxPC-7vhOzzl<  |7kƺ0?.E0aIrT_2uR@e8X69zb/O~k%i>* ,x;S> /vO?hN{\sl,0*K:dŠlVDXb͆H"GQ|Z*LL{Ҫ.(Ey/׻AK震R*#;yaO uc_rV`,is| XqzmĂv!P,bq,,v=n-:億?C]g ulBVC!ћb6}#s~%`
+^gog Z]/my̯B1B3vxul&왁>uٻqek뿇|uy37?`G_>w@b;doF;n3,@'vQCr Z“;z;͕[A;**:z򷛗OEN2ėe' rVQ/<O o
+m)plRTrm*!f|<(8˓CA!Ƴ5镝nLδdvv64IMFAAEQ0xEQ ҇tgoyww`|+9+ 9|D~p,XQx&Uj2IP`(|$zN58R K
+ q{nAnn^ڝT) ?Hݥ vhOm@lX''x݄&9PeP
+@6P6P
+匈a@@ ;0w݆s2k/}w?}OE]9Z&TrTLfrZF
+`LMR"}S5SlTU5Rek|&PX*t-K ER$g9UlVfOcwkJEBQ<]ثFVи _9 Tc\J˥t\659#mLzCEEe䒇WCVdi'>i-뇄;(_?Y82_Z7/ @Jryp<U{әYu~I[{MWcmS?^]g(t$1Ӂr(kp: ~lPFl ~L%>%SyGkZ1{`N 47Cٕƞ޾0[_Po>8q;YƾT{_
+*TbLvt_wqًfF}Gٟ ~|ݟWTt4]*jsW/ޭѯ~/yS$R$g_ o$ #ļOn{뉏v35)oE0u_".? / ɪ^:gAQWP@!7
+nӍL֣CagksQ}rE@Y]VOB>m K# >< `a~a,
++"ƶ^'30$*-A[[!G(H^Λ\Tq0zsL Y9"ľr$s>MޠlvA|hZn5g(U3}ݥ+Ђ2.~x."뱪YV+OOMiKOuI[WEIGW9iJ+m+9%QD@bN$GdI%T٢xPi9n:C:ރU
+T\GT!oU T*ڄKK;*:;ʂPQ]\sGmy[gJM+Tή.hͮ=cT_52. @O5 ʿx(x,
+CPBDE$SPXiZ<9ĮY0FTe*m~.q'Dd} 2$*h#TWQYg}agq[!0p`| 3*tvh z|
+;f'1 +#?J#,F ;R53
+: B)` +Xwd0 hcvʸwiE6gGmQ{bM/b'&'%2jOz 񝉤?{R]O2xhGpp).(la!41AVHV
+&dcX/nb>8%C0Bv ϭ!p(,Gp 1C E.1@n?K #)cqwbu,ޏysGszͬQ?/eD,S4t[JZi&-k8M7J%Z\P<.^񈱫eprG1٧>l~<3{(mOU=QMbjR2
+&_mVrVq!)W?h8cwN|NUNW=g7?^;^.~95<,` ?ޚ>Eo}[򣝇[Be<?e>^څ@R^&XNtlLס
+0Fy'#%h*#6s,9HQD1%.:qళ"[A 2,p B ,Gip |+ 2GL,'cX|&B,1}a4=!8B B.q 5dk4VR@A!
+O]v˞6r@ Cb<,2Eؓ3pƃ$*Eb%Ge zɾjm2~ߺ,*qcjkhᛮ [/y}Q UW/5$6ZxTg
+h9"ȠASȁ̜!!ߛ&{&V}憠ѶP ȟPBB),!r_VerK8`GVJ޲h\pf]Ƥ3酁 Ƽ𼿝jdZ1[_F5NZ\Rfo;8Gn941|o dzԋ 3bℰsR37.ǚ5mZк\#s%N_lJ@94-޶Ykj/ڛ;B}vyr
+p>=[7d{1M]-d)A,@ H1 9P5 N8v+!Ě [aJhĈ1.m¥8h\˳{.W 몪b }6`Y6J&$f$Jbi҄E2Fq
+ @IF1%{kTʔM o`FX)?[kɢ:0
+ٍ<ԄZ) I@絅3nTYKKі-OXe.)-2ж ~~p=[翀!
+Ua=.9`31-*(vjwN#RKLB2Hhn=h`q6wkۮ֎fy|+`mL[ϰ9n7ttG@H)&DN#6,dم$?赏du}۰MӠ}`~=:I/m/XDj)'ڄ
+^TrNo a%&.6[iVQ! * "n->?b6s:1S-tG'={9_KX[}6\lc9r^90r{"W5G?Ԝ
+%S1c)xl/Pʸ,Gۗ˓(]ag_!ﶢ&UcNj4ꫳ;B$),`406d1; gژ u:Xg 3#4␉0LlL*$Im9#+K6ꪣ//|ta>ˍ?E\o9XR,%vC9&d]hړ
+bY~J`^VMyڋ_^;|k񖛥<<s7^m%W:g:Y? ȯQx_SGӆzD}l~ǕovR_TEm>uP,_yv :e@ְO˽9w+j_xO#ݟ(oq|RDl< 9T?>sv;
+C};` M[]R|_|ӏ\]+tJPf۰iq|DpBAXtDl0PF`
+0A1+~1&-{]X !̛#.],>}M;4
+Vv'Y F )Տk(/~4ͧ3g祐s9Mge@,?SR#˗*su>GG!AUi,@!#=P?Q5NUS>0 ?W0SC\
+Sr臁jWhU]Gkۂ`'[rk{*#a 0ыǣXby!]FrJZmU =ڌF餴l"0@d^BPrtbjӌCci%#2)4m2C=y} '6,jW?/, (v@yv#
+ګ?(F{v|@\@w^wm$͑7Ž&F]鑦b;hg`91 .qnN͋#`eNk RI7/g]Ƈ`IHۜ)ټvbh B(K8Uh|gw,{ZKhj)#3VyVBdDI5MI`*b3 <b& 2Bƒ0 (f 5Kb %j ٥ŤFQsfadDV-i {0
+7No&Zba= {vHZO>l MtOG`g#܃8'!$!BxCH hm׎Uvnvӭ՝utjc]DAG < 'y@!!M7w=g?~>Tm!\ $JL?",O
+f"1O</]'E]
+}28`ISDU9RCgq\o WԐKctK]䜠J=Jx5DwP7.wQ?ɪ!<Ei
+WBhZcs1 Qv5&YtXfS^|qv`cWHz/y=k'Z7T,̯M3K=JYh/`{[Znd2xŊZ8A w♫-
+Z<Av`H@
+"sX:HPn`%lq#!Y^(5ᄒ@'CcwOLbdƊ->;w~+b&0WD@;)TB9DLBh%g0W570VaO-
+3L8m$ƭ *ƾA6Padh<fF"8L(
+@&ӽvEqw%Q$g+,r¸CZph3h2xX)%'0BKX ]bA!4ں͖fsj4wԙ;MwKiJN_>%;=$Tж: 遲+s/>_?!]q0wHAP3krq\6ㆢqAdQq&FIcڞt=g:̹MUMxh\TdP%?:><7 Timш
+Ć-Dx\< 7ywzr捼OV Szox'5 zmc[^<]0z޶ Լ_QVNuu_} COoMt0Q<dz$2d|,?/B},+Uó>o_n)o̼Le.cRT+K6ky?d~ָ̿ +Q(a5$myŻ .o~k~ ]1<]| X-Ոԃ>}st׃O1[A3' I @(d
+N%x4&_a/3ᥑ8Wk7]5@Z>%p"<2: }*_FF[Ku2]DV1i&.HFP -f"AUhHC0 \Gj?P~{%FL8YxMAI7},ym bmiY ҹIA杤C=*Rj_S"^Yjpb&oYٕጣl-lG\]c6V؞oJㄬ$NFn ;Y<+jTE |),?P2~ ` ݈g(Y-g+U\M5,#9#<ңyak)?Tr[̵ZX/t,1+Fy63bo,]ő |=dJnJksڤ#ѓ 8u;q՟`xq4R~ȂWPBdIsTMi(؁Ҩ؝-UDfIcH$rEP -<:.*>bñBam>3wL4f9=
+X@SJcHN 04`!=̵j]>^MfB
+AwEZ_#76lE@ji.cmIsn*>a9((3GRcPU'=?u{_R/8^4Z}QAu=蘨 w
+$h8vP_,xKNZZ@J h٩tLsf-@~>`X|i=Ưq8|};եbGTR+s'?O>K]?%\ݺO#ƕէ֟m:A"[1$)j+(j<ZƏdɺ"سt@cOqȅ#j6(`$DAJd$Oز]~7VF2ͼS& =n9.4#GU[^ZWQ
+w8ڑˈk<EC;AuntuғHU#I2&ʩ(_Md
+xK  KV<O)w獵O<oFUi]re>_RqHvW|PbOq}v^d)K'1˅Vڬ^P(hR})߫)UYOh[;E.bݣq\AM_y
+@3TzMidtDȔ ~Mad(|HЫ,
+[[~ĭ4ܥWk AM琬V|ͪڇU u-^Q4% jTv
+'wcKټBd(S"t !EP N-KRdr B:/L
+0`)!,PcA{,( Ѥ4ےJp[Hn3:gB<I$K`auS,#4E#gcf7}+P*C"=3
+O 2` ΁kmT%)E਍#ޤq/|C+f?ʕ]Ш9s$YAkgS핶7隸>nC{F;+ֵP-,da1#/V5ЗP^Ⱦ}'
+nBC"V53 fo֜g+bz@ثe|>*`\4%/."L(9"ƲK] L AY@=1땴Nޙ&8E웜 xwPϸ5x/p,澱 x! 2lGږaKXBpMQư̫nZ70rP†''q{ w"< `/;;7z^Q[A@w>n }{
+qwzCt ح~;۾Ѕ%?8v*ïߡ^|g,.ٯ'4
+3e C~ӫ-Jϣpsƻ/;aAJDg4MYI(ؤU>'a2%Q ꧳x\f@_~^`y#~MN'<sM44$c
+NaR>EʐQ0N&?]5čgfjuhrȩ!qnʃ
+<_
+V!F7* IZVsp§ , 0|mko!u.q@OɘdgHJ$t@-de
+\g*/ds|N?y=b3q Kwӱ^_eӥM*?<s?lWYGJ?Qveo']ߤ/|z1yג j%=M~Y۬?;'A8*]b =f7sꏶtV3 {|(qP랱;o@nn<اQnΦQ5.XmBO9Qn3n zh^3-ZžO E4t
+1ys444%M!U
+YAfh4#[5r2v&GW;h-tWo6ǜ1JQuzsi|)W]Ii= U=Y^K{/Ks
+-;1ЭμLCLB<fQIh?AB&vtͰ
+{2w4Dו?}f]QAhVޘ
+#/.`
+[(ՓbRCF캱 Kc{dnIuFI5x㘖
+&qٍZcVbۍ&]Pdm:$Eo#of;uR!:# ^(3
+^0=]y|A
+2A >ܑT`n 7 h_ڦq:9!2-Ebx,@x .QV{s
+V #"[Y*ܣ4q*= G<`Qp*d pnf߽pycB~OX_{GQ@Nj?BP|޾"}{W#՝k=XkhG\է}Q$P[9#eN i^ɿy*Z:5=Ek‖ΙyE*e9wgZE&T݂_,E'f¤G^xvB-,@@C'A!0s|C'; hERIf145-F
+T!
+)y{|Р$:M%^Bպv]V-
+ZиW/O465]nS 7"mP W7z{h kGKZ#EQnE30>,>u*n(ݜ{X5@k׮|?s釱̓mGM̯ {\wխN߫y_A>=ޚWukꮉg W&ZeSҶi^2NLs578==%ݚN`
+
+z,ǭ#<oompckg
+=s&5Mŭ9DF"\֦n/b^ 1-Qj6fs*k2O*\%nVek6xLf-γYyMZIPGȏ`rtƑ%9F8fbs=m <*k|K2beė 9dȲhd
+-*,Ŕh0u2ć %TWD
+zhsd\{EF7Zri *HeyZ&%а*\qp)PK-
+cPOD swQ{xʼH1]3{~Z~ pz?%4n'w$'wgC^4n׏XwOtx pPwfg|<fF~ؔΎӵ27bQصR)-oO"[БAtH"\‰; I;v hGtʞMY$I$y]A xDK {Dlj'nXO@ (Nui><4#1<
+/eq-9$@B.rBH@NQ@EWЮun;;Zǵ;k
+VD.1@@ @$"rHUd}y^<z~]]cdzw>7Jlkzgq7ݶoxV͈卝@od;a1«~]}~@ޝ$?fLR. NH/Jġ]㷶"=kL>0bH-I <|9$QR 7[t|fG.]q)# )=L@#c
+z-9ҏe1nVUE!tD4
+t.p24b@ɑdls._.fg1|w~R^}&Oov=+ٍǤ|u#DwFuxZ~{Fv/BҐ^z+'<]qxwSŹ3>SO>I\yuF(HyK)
+Ǭ^?J
+jr)
+BG9θ7hW*$o-ug+eg3|?x7V5P+sώ|w-ȶa7}f ZĄ[_ZƄ ͓ͣ$fՌJ5V}ul
+:7ju.<zu.
+m@nN&A+襱#pO!l1Jh
+E8mp4b!A54fB @7hSfd1P&Ld>4O 8MPڜ2s[
+;8_2V-Ԥ˪4H:S=YmgkkGu% )_V <}:r?rD^+dB7[>mP(~53M)e4OUd0%
+G,糺> z*P$OΔj
+Cns!󴼚][QSy57OSR)KQ\c+@B)?h#NOkGq C5r
+`+Of|oۓؕ)>ZDLRm$i(zV TTXQ{Vp1=SCoCVê\p_p|u\?w8Ý y>i-̱%8Ơ<-05(
+k9E;?"f-ќ0}Umi@b?=`;zbxc]v\PZ` rLr<Ӥ1RNDHM]]wR [J]8r*
+(RQ-1PɥFJb]Z "Y`+i"U
+Y")s@MXO8@,TbG¸HXXZ,A ;cfH҃i&ٻ
+#U>eb<Ij)̓w{]yfnfK_a)|<m{bˌHY-3l/.!(0#EZUXfa.%,&EsBL4"u_JrI:HH8d)J@0c> "%@,ӉlM;dЛT0l^Px!'wNlSH(<f֫QVp-=ךv&`Of 5kJtXY) œh`(mux0332\$ M)2=U+aVM[umv:]2pj5?v(ُ9~
+4.?)(H% X-,Z]JB]S)0"4wF ip"*++daY/ذ9)X"c'XA3H>1Pb,б$ʔ"2@dhP s8LfDо X[!'$ ϢLwR= # 2Hu$JC^23(i$wM'?N-a[Nwm'4V8?kòȧl
+kx M" )ŤIhw;QTq<K[ `p
+Q_v0/-]WV\/(Gխ
+#m{5bm-F/àYs_LgAkoc-/&:^tp
+0Tq6zߗ#$;}ƉOݷ56;x\Qnӆ,CP08z/D2{htDѫ'?>Wh+*ql)p32: D)P'k-55tHEtIjQg\<6BJ ϛnTi}=|@|?]MNxWf7x>gwOj9YhfRk2Ok:ⲜIΆ"-dɦVp/$1;WȲ8oq< !fvԡ^qJo< w^/HW^~|c42.]඗ k[+Vc YfeVO9ӵx2]젖t~xDE*o$1VƊIܙZBF[M8aDwI.N\o&J*»#7A,mXl(hxE9Z"A.֛rÜvN/Q5VhlF^Vs!g5KnSѥg9=-ީW/@?}gg?Q]rwJMrU߷r\;I?\: J38x "`|@ d&۬L/to:7fv$lf "^r*ʡhD<ݾ:GVH"Kjēј^:.[jάKdQ
+ *7mbos<ςHRm;olM<:q vmVе8R׫ץ[*).s({A@amya@f9˛OtH;;{1@l7;]s򛪎aa|P;M~ G>^ƻC&[:AM.M ogYVlݨ/TWm}tIU y'
+f֟q
+юnoJ1U3a-TmcB! weÒo~th߱ƻ?3~ݏpm8+oV=Lo,ٺLXlӈ MI/
+~~T" zG@9RFj &^kp"Њk>KiO쁾8}1p֏649ރ׎{!g/1á!L`׎:P[Cc9Lt&WEҪQZ!۶m+ĺ)zVj8+7p׸YJ5 ܮ𫳪(x2m3)n[/O{0s)$4W
+JbttiβBR%,_rSG \˅Rxq\>,h!ǹC_ȅ,;4X:pi]5~w%ξB)cY-c&C)ݨ+g5
+8lt8=;n
+"\4!Pц3 '쬍0>oVf1\sn*sՁ*P
+/ Tqt6]r4b<'o˰0 # -bxQ5b\*W YyO]sR$:BDr-ֻ=ZiR;yAU@ᄍ@l 3d&kZp7xI3_vCHGaӷcSalřis l{l ^gԤ NCdFH/ QY/z }}\A6|>w\)"GҏhZ@_Hnlww˻nr@1xP ʩ,|G
+qALކ]:+/^<WP;̖E8a:@a<>rb!4ET;}`Ё#TQ(t#Tѱ JUͦF԰ $H'SW9M884
+'ə=޹yzO{?o-Wq
+kM9| TNlTpJ*c䇺GA7_/
+h|K8*ǨiqmMK̻h}~%M
+rDl\[5Wa:yeV2/wSU7< 5,0ňBV-ob \ee U
+\Dծc˄h٤a`v',LKO_WDt
+FoCνcvgnր2ۭ%$P3m5'°&0eWєeU é/+cXXsաӗ_x*6Z9J8Τ&h5$Jv2dLГSn˛!Rsi&PŦ,NEe-zftDŽ23G{ߤ~ē>O&;kܧ30~7S#}k
+
+~LLҥS"Om^n;y:<PP9]?v3
+:2 5 )hLq(ZKmZHE.c^`盺q9NPѓ(0Z3n]ZqUFjn0o|89y+^pcjE˽ 57j7jU[=77_#e\RъudVL1gf ~0]\XG9;=g9烙
+8Jz/iqp!pʁ/; q4S7JLWҕ*IgTTS때L
+
+M42
+K#'AM4 $,la+䕱ԍwiVoh889Mu&BkdAX5p|!
+E>f?)1d`<`..ļE:fdHy g"qH=BF
+*%*xٝg?}?
+8HmwD] P fG :'kXYE s2|ʙsDsvjF$-΅';g!8l ;90g"l  @Nܮ봄!65BXv*,ĸLh9 n=6HԊ0p̲daV`9Xܲb o!z`0(
+u9cVWb*4,xeނA`p
+jc<؝ŭ(mH軥0g-:ޱ"W̡K ON,+WL
+>wŔ
+\/n A)AdQI1jz]2.էĪ
+#T8Ќ;:}7&oOYce orp_DL~s/Xb..6?8e@Vs7(kQ\7J }\V*wTeSWV!`8E>蕰*Јr&C*hd~qP%1 xDfW'Y7F>7}E>:8E>'l/
++hܡVJp3v3
+2Y@ 4LHz961NNAgR|pAqtqV;YgF`!~ȃS#6P?B=VJ?J/M/˥ًr\Aig\Q)]QAD.5&٘nnfsLmv&퇶NftlMvf$6&Q
+
+U c>9w<_ɅU[^Ѕ+ʠH+a2[>b3MwfR
+-/[ly@](1]*Tٞ3Jv-ÔYaГv3ېdW⬬ոM֥f
+sg Z %"̢R.tBGvy
+hz؂̸1cB164+%нBVHu($&vR6d*"mJH6ȸ"n R%Bfq
+SWy2(vZ&ҍ\il$t^ch1Hsvh}$u 3d-Ic #jp ŶG0|g:AͲEjZo t %C
+kMր& HA^~BCN1ÍI|9΃.2 <(S3Eo&p9ܬ`(@zc< P %b]a4j;Dm@ڍ` 8w$M,.'$+wcm@\$ik"m qY
+Ѻh^⍛|$0v3eMBmq`IRhkti5$5c+jGy,yT@Є;ȋna۠E^o.1Gw"AqCz` ;oV0N4k{64XW6c[u
+caM~F)R
+%w h_ 4(n/@4愓Xv
+w
+ZtX)j5vT#г{7Y0SzGN<=yhN[Qi5hv=mTr8N,~#~|,I)o8~3O?}XsFy_|Y]9E%w}Gy׿l|
+B/xxzp~)SrzcOO- ~p~Ykm7۬/m_U^=~upwx~~t8_ocDK6X>4(≀SN9UPDCTNLbqLagӝl;lv]7Mdb&h<QDPn!ϼ{?ϓΌ\L4?,/ɦ@Jj0/bH`l)JM
+֤ U0AH l2 7\"`N"yAd
+ hS%v+#ScD^Pߚ3Dix]Ni1vvp+t
+0*3)28;)2REI]Y6?:;+D_
+~}ٝ?1tgJ~jss!G[Յ]Zo<MfiEY}gdW?'*NUKǫN'e٪S~{ u\NԖ{ fC$UkUOB|zc++_țd=/+O4wU~]8u P
+AbL"(f87^vuࣙE'UvK&XwG{o?(
+`:%Xdu+lA*6K,
+61idg-P9ȣBTc¶kRˀ+ hp95H
+R*mO5PwL]#,G A1!gg~
+Vˆ3$oȊ KXYaa U-"ESʼn3D8nkdy65ɶOJR xL,x<AQ$K>J! A<V459JJv#,L'
+U؋`3,} K$P.cED4kmr3?OBd4KHFfKHQ<3L@Ao4WCcF$ѨQa'-p!I\L<1OsW^O-A(m*YHc3tUƀ%g"gB)
+ztp x5HPc6S24jzԔ7̣ZN!At :#qm_k6&#f&CE,B27!iۂN%2r
+byfiO>Mc.佤T?L(Χt.q-xӛ]
+$ȏ JfcxYA/mmz|tCW&զГNUv!_Q̽/vkJݫg>+l`OH9QZZoƨ؅!-fMlۏ4SlZOmXʶ:sj:W[ukYe
+\1 d+,mKG;)s`E-|Kb!f_N?},{XzD6qY
+ΫHH8-Pn_mp:r-^n+?>#Ï@y@i !?al[/8G1
+=JH){W:Who:S\
+*vvrs?6RJYGk 歠{䄶t"NfvRRYTf+%5)E#g[IY@@&\F5 LI[LMGLև7uy |Y;,CM}U8\.`%력d2<a':ˆJw`iq9Zl1t6 פޚ'z1(-Gg?+!׏B8)@)B|0%tۓ2XM:bQ[R61p*xEʸӃĝz/Ὂ-~0Rn%TP)@]|i߫ .uAܐoĭ_\Sx`7>q#.u #!RE/Qw\zµ`{ׯ +aJ)8R3zf2 ۝5U|$Qn=*[&<2$907;xrc×^X٪`PA1hT[dVe(qׯU͕gTsew-.}Z9e[$t{<UtLuOLK貣wZU=NԅV_4=0ae,іo5z~]FPQ&!-}zU~=kfK0pl[bK d8؅$Ot
+h_2"nl0<y'"m=Keq@@@D[?(!jbPhI6ɶI'NgM/vti6춳3Mww6&$M( D9K@CPogwߋy~>}5'U'|OnL2UoB Y,E," -̖WmB뚪 9g]S,t8j*].A{S=3]!2/[+Fp|&vxKh{yy1/{EWE 8_Rz
+2A
+m9B)PE_
+ӽ@R N> ;x%PQOr&+E2J~|r $N3JnBNf!㹖HaKlF+>X ;Ì6{;>{v_ :CQfkl 4㤖8e{Ӻ39_LKfHsSj)*Ж*QF!rJvi
+d5O^Cr8&IkR*Deee
+%
+^. aY:Ǩ^Ѫ#sԚ$Y irC\KK,]!U9u7pEq_IbQub X(Y,d(S,uxq*b+F(1O-R?l9@y\7-9KfNchi A31l(V$AWȊH-%8Β$)kPpo " (FMMtDd줷mv{olNζng1q&^#ޣ(D|DEA͇9/9
+>p]Vzysr!C[JZuVnRW
+'i2C?lMoR(|W}%ɯ
+=ſs?uG?tq[EWiN՜#j&n g3ق_zHip]6j+woT%tMC52Zbn(U*DYܧ
++]P8?sǼв]y@&[/8}?{9ϕ~y( ( E5e:ˎy'pT*nP5$M3w35- ΀9'[יM{:#[6~vFYR?ԺXHqxWT׌=(<>~;Oʛe'[iDz]UH}.tbTOLlea0iinxM!<MzlaIjGEg}_pzz)sٍS&y샱?l]+=x'岦؎K9c]|ňd`̠䙟1CY6N"qIڃyIDI͞$Va0k aWK% mG{zz.Nkѿ Lx wYيzkQZ8⫏lhmYOn'6i]}xsm^Rf6*,]*korUaJZk]m*<ꐳ+piXdcgd9K
+?. v~W_J:3RNmfj6oָę7(1+ވ?`=^ιN5ykX v fU45l95o_M$,hvX#\XΦsk =n&%X;@1EXWqe5kj/
+yymȝ7ߩj7C[~΁<"6,bqϢFm+5u/15 _G;7T<}޵O/\):}"Yf3:GًMrNd!P# ,R^/uP}gMV|8hܛMu*S?>J*|~ #R
+}:yO!_N|3"
+bJ_Κku{ټӧK"Y-kEB_־tmuyx}eK_oLV\!rΤXI7uzgOr:hI6Iz\o L
++6lˢTԽl;7.r㞥LN9#KLq7p蔹0&}1]k>;L@ުQ+J"u5C˓EŢ5͸sbܺ9MK%!mBVSxչ
+9]!_l z՞e /=.!o1U;Zc'Wu$TR$͋g1{z6 J7p)
+TD!
+
+y
+8/ju4v6ۘ/o7 $ܒ!qhw@sX*9w7W>o+<;QcEoߕ`ISG^IWQAOK"J] e%MҲF~$+GPD 瓟ϳ? ZlG
+FkrRm2̥oݹӎЂnxV*ةԼd悫˟<PT|R/}S{&;DY{ٓ{_6X77OiC/3_^Wͽ؏KrqCE CE@
+|Iܦm.N;H`4u`p-zv
+O vݽp囏j2At3DT8B>Ki&S_/ƿ=|}sy<
+VZD+5sFټI aaM,U>cV;6g+X'6CIH8uz6TαM1*tw*1Ұո1Qo2qO B<ˆ{pf(_ܔ,$v ʝ 1G'6dƦ& ?K(<r©,+CX_p&#=}1ϦT hڧ# -ڕa0VXh&'4Uiͤo2YJp^\B8'"tu(a~1A(6!czeݡ6^p4
+,`QdGp7jb
+"=P5?W&d3N=z-Зϖ d+>j ?O4yy
+~9E撓e (
+\
+j{G ő̺=R GZ gxyh`
+Rҁ zB9]g !z2xS^?kB 4%HNj4WY99UBf` ^[
+ndB!lw|‘;[OL؈e@N6Ѓ(M[c|b^Z`tběJ"E\+nf)qK¬4+$+e&FFig =
+Io6d5͵Mp R=Ĵ`-4a-J -) +/ƭpM Qm A|זY hND{@m0 <}O2rI^220 ~;įGrRG"{#{{IG]XBȋ@HCwwq+e{UZz8g
+%fzƴɐ%f,9TnaOLԬdGkz ׉t:P
+ zAvz~vQo՗
+Kg,
+Z6۟:NL,ތY7dǕ|Z~Bh䵒}0h}8iPHRYtWeX3ФUԷɫGUW/8i/PN^9unCӪOZ5)ZAڗ i:^uu Onl-5\QMYQ@5B/RQdmqv*ZE;C]jϩR-JdO" ! !2,Bs~yh\Bp.͖e3cE .!_ H;dm
+`Ϭ>dKl}f)ydul!0ty{*8(]gu3;j
+|w[sr\BVm 5NCj_7yJ eX;­ S2?^oŒ+=jOt/ѦL"U~D?1FAر>(
+ btmtz9nGLpʨ"4rŌ`{<}J2Z" ;G`C`*:%'YT~I/g˚h Lؓ| K_`rZa~h78Ex^@:1A-~ QAn,('Ixu>[^N)SvJKԯz8t?Ӛs_/&P+Qu<X:d.VQ0ħ\e}9xLU4/)w |6]$UbF#t yYʕR 5cS[쌪I47Rwx{{mUZU~WQٽ?xЗMkkON5&evܮZ
+A/=T0 s
+:j)@[+x?\84 MQUHҊ3xMIFvj!(4 ZoF6](I,lYOQ▚Ԃ?S7r3vI9Jid`:ilp f 5"9Fpdh
+iYH_9=NEk°Kؼ-j5jQ1rw}Ƕy;j\u&Aai|%3yF)~cK×5͘ Lf 4("1&a
+<iѥΠ|'z6H\a 4FD.&go <pz<tʚ'351SN]K'[KvRT(cKfna2W:S{`8gr#:DYh^0 eT
+PEڜ^VP}
+fa6|q7uH 1CzW{0 xOG3gfZcUo kE2xY ]"CMzXC5`7jv[4x<GF=1!3b{j~Sۺ>5d
+plx+;HŅw|B7A:_ܪ:|KtP>mznθ}`F;~
+ ǧ%|j0/%Q$?.P5o75қ\8&9\'.W%*P)='߫>#W$^yc"1.I{%Vd$ƻҞnQa\:m,GYU) 
+z؞2 e:m-@9`+w
+l
+.o%;9Sژ :&ˤLr=&Qy
+~T6'!er q Q~3WoӯH'_ޠy4M Ֆ{r*&i[[!/5CjZg؉Uk,AsSg^`FczSHʃj 8~IoEn"P#Rk Ҧ#g%6f.J쾞fk{Ҿ#^׺Xú
+
+9me
+kzwWwsDUYJmD97X]Qy3#ʦiaT01?@D Q\ƸL&g R2\ .grL:?7WbFIj><(3 (*$"DNJ " Mnnv?ffwmm;l\
+ *"}g>_<sKV[v)Bo^yuoH_QrQ[e&KkΚ_4GD^Cw^h=y5oW3>620K(gzyz`굢~#Nn}[UKAtFJ듩ι;{r:ՃM͋MI$ySLܴ,a|e3@ m9u y yr|֒}?̯_`}"ߕRJxlךK(v]8u%7Eh.2>3\xyJG矟6?~)\U{kwe7Jz䗳p)D:_Elz15O_T+z,ŀ3Z$B {p˙א=UFcgqtzG;P
+4M@ѻEE 98g89NM'<.+躼ڑW^YFa0.[ կbiFELQtF1iUZH'T|F̤
+-z6jɷKݝۀǑK0<$b)˛ĔZ6-
+ {ǻYeAs]iɌMI_O
+i0kjaS3G9y
+`o!aŠ:O)qSPuT@{av>jx=cpgA05BS})fP8y.oB&=vO#xc0?%Ϛé3}8tE*b8*YdVC_4NLhIɖ؄ S|HcXCYG ӨFJ-ax"4>NLM`ISDAMq0%!-zTi c7v&.E5rf_]-K
+ќv'C\Ic?j+5+)Wv)J/ "]"VUrTN`I<4%>]|/wՄոNٞǗ;><peuA-oQnY߯TȨ_"?Yʅ;'y )uLu K&/ %uCR1iE5DcQW]p=s^J;Z2K
+h??ߏ&^>H糌r욞JN!5_0+յêZQyTڒW(+k=$Sdg*:ELly6?m`p
+
+}y|*3Gў-V*U:![(Uyz^&xA#
+}CjA;v3܃H}7 Fmfކ76qgj?3GS07{>oW2l\<?]hHOrUOsKeM`g;宨!5es34y9 (@HE"Rȴy=fSz}@ӽTh4>IiK:8w] ⭫C368ڐ5%
+[hC8:0.)hs2.5tB2a7 ֶ.m'ޚoӀVm*}`* , .ɠb/ @
+Vo7( zlrvFChՁϹ"x-L0jy
+0!SXm
+9TukW'F&z/)p[NTr;2܈jY6IIj'4HN8%FɃ|ēחd52sr
+z,
+/&(Ҙ14~"x`)ѳI?awo'ҷH um`PL~:MiH9ץekSQݺd> 9DFqݺǾi8,!>s  Ϫ0H + x]LlSAE[ܗ"Z]_q*?ENZ_O
+Yv/sZ<2<Թ&tG0s+(}-`tƜ7M[͙kR7b2{KiQ˞"fi޼B1 /%?}v2aeƃq\8E(މ"(cL&nvIw3;t2NnI1P QQFQ4jz~|39<oB@ Jor&:ɛw/Eg"lE5gzVePٖ)r $n+F4|?,'fѥ <ӮRgʗ <VTLWi8dtx{l{T!
+ mQⷌ\?޻=Ǯ2o&5A{I*EΙ' cdvO4zmf޲M4$Ly-
+I!00/GhbeCH )DL`J{hΩ(c⪽
+#Mu)^ 0!p#G(d< >uX ~vVe+ac~ q7p>S"n#`ֶ2+,q+;mNΊ] bA A@~R%HHpq{?y$P aǘ1iQP6t7KTN~a'gbO|}`,CvCy{EYP^;
+mGb`/8K_اCTb(/fy/7ְ*HE|57eqHvZՓYqw& o v`.T܆Cr$|fnqjF b:>Y?!#k 䰕c)$  !;4sF7}#,%hCs;q8&>JC7;xd{ spf1C ⣊fZ\M^T~uä|K8PN2L9Qe{lS9>QYQwJMks2`^I+Wъ禊yC=WVjTN+KgKg$
+6m{ ME6=ErU%c ߌ\n=صQw୚:|ݶXPNe˸ ۃ2#мI@CRjZE^T;+'=qW8Ѕuc]JM
+yO3zk+/Dys'3.Ⱦs!13_\5 sm]ݴe7D1x,:VA}%o>8ۯb$`nl(;S̠j LQ fmn!4}m,(ey"d!!DIcFeF|S;?!"H%%h 53_@?~0?DZ7 0vFxzW~iޟYq^^`a(j[ҐtT" W3:J+KS_)3W#EB^i@*`
+(T[zGx !aUty 1mun~yD,,ݦ
+#[1m\~ZTI!L\BahL
+[h-tN+/ўAWHRыqd,@w`H =;Z3y<eɟ,ȣs4.
+Ǘw
+\BφZ|f~zܰ7iEƮk1Nz^ Ҁ/i­A~y[`ܜ5mc'u
+(m@AYVD Qli@YVn ,-hEKc5`V%0f],j qrhDM@Om3@haY_*0!hâVDh;89[;uڝMgEhamSRBq*
+ޯJaI  :z%_6 K2s=m6̰Acd ;d 13% șSl\O%'\O7 gMW׆Ձrݨ#ӷ!A0}I}5^y۵SoRTլ2y R|Lbu ̮,H
+9%xp~K6oؿ]"I:Vb1!T >PoDW~GhDrtL3#~=t ~\>Vt0J\УLN8r~jXHPޜs %iVr`\F)()J9PAN-'zFR?USm|D15a
+-1Bc@1<TF{l 6*q-3F-dywfkĵ
+CuqIlj7⡞ex+7ˮNƹ󧽮,_ eǚ| $czD&>d`탑1AA+W{_~l X{wa1j@
+"j(R)щ*qJ8cS d/հ#7 W{Gzi5
+}ayZqc7S^;)}LTJV$14d^ ᰓH\O''g偩St8(.HBTB,=L|7E
+l[DDLOCgW|/M .OZ7b(yNgXPW%2 J;*(8APx xgMbM:Ivcn;E&nۦmbԘD'}"b3ϫ<<s{iM鳸juu-U6``؆6
+;Y@С%cHFL(Кei `= .sfbq>.`w'2eMO^>5A.P|T
+lW6n@JAVUOyŬ+cm2 #ZTADt
+S|%[U_?zqwkG? ?.~rk2\(/󲼆P*'J_Rˆ_dyy~/'g(?c]E^v'[+?VJxfz ^1XC4XM/gT_&ݐUQnTB:rӄk)7Obx/4&4 -x`@Qȍ\V,^ӎ^3fvvn:v>l6M6ٝl3Ivukkb=PPAeQQ?;3o'7ynoS*$Y-˺j`
+Sj7øvZ(5ܽ
+ۜHTTi+1E vKkAlkC'd5K /d }8sVdQx$55u-BV$C)pά_ϸ[@W`KlpϾ]gOt7/+_Zh/T\ ^GGŧ_?>su{Aї_ӾQ?8hO(??Ug,BNcGiLfLKgMLTSgLxm1%n$Fc* ŇoC1;EtKq "x gcQRoC_|v~13`N0\C ,4
+%.S29+1
+%Vt쐅74/r|̠Bϗ;h
+%oYU0T^a5ap9dY$nh^U)EkMئk'"ݝO1t{qu}e+qUQ7I-us]i2c_Tyd,;WBIѨ}t*7I}Cʱ̢:D0;\d\ V#X4:`T:InMFGQQe98ի3$$?()qI2^U5dzJjnf_޼ *#CѸ qܰDqDNm! b+=psOQFyO;ԅP(Z`4WF2vq5X`2 P?n?ݗ*XMw !xLU,FKy-t,cTuX1a@t~$andK^Ktl"Vא1KՓwt=
+a[ߝb^/-x1ng;\ˇHu'el@)ιve-BOO0se{c mZ)M}fi87o`ӄ2i0#tVR]Usb q &hQ%KD*T Z|AzC^0S٤&4y]`?7o0fo,@܍m4</{U%a
+d.b3p
+}(R_ AdTipBSc3Klwν}2#(n
+Ψ!h?G*f/tĽ郠d(>9 ETbKUbm*P K)x2f
+3Č0Phwx#5kec5"mX[Gk.gjsb~}휴L:7u荕hj'zŁpHr؈`.1 ?xQO%-e͘_b4
+bNM1Ҧ%UǞ A~uo#G֝>c"6 xڶԧf5YUQ
+^}]u!Mi7<:vx-vYvE[q ,kqoH^2p4J*DdF1D;I}/ {|R\ s+8sEDpS,m- o;az{ ~i=`gmmy;N5ö98:o~unPHD{)ͽE~-sa(6-gbzt XHvSIrWAKQZצNkWT>D8\C:},#Ӝ-0QN 4фiI0"ͽA)\(g&"{ L\+.揪Jd!.5 ͚lΚBmo;R=r7ҕ!r|"ɀw­;%wχ3V3V "zXH3P%o hl
+_ŒL [[/<+Ox,<cgDƈttSb
+M(!*E&*2K-J<`^O6FښK\4o] )mhx@6m ?bc=ThEL -3;'.JKOlOt4}
+[r80 sV[;&7eۓ#>Ktcc"h4!m/nAL8tҊ_qSl&] JIc;u?e,&+$`tck]xC\-`crykuٲcv Yqp0g n Bz:7# 3ؼ9 xxƆ;?olM7ľ]}3A,6!nm_g[S+ݹ]Kkd|@{:sNp=33 P!$DX<I"%
+:iPGPC4Ā!fhDPH.S'sqE͸,e ![#O]cSMl]32UӁ6O+M&[rS\:SԚĸ,~xRl1/|ZӐ|I:Yb
+8I降¼ L@91ee(; P%iOlh&izӀӚ۔ٔҲ:R3ۅYͭ9ܬ, +㒰; >tݚ_
+&-mJѦQAR:N/NdK)i$E3"O0DM*"4LѤ)9G&k|M c ϱj.Ɣ/
+>12Q-{FBɾT0ʣ\Ĥ+{aM?6Bf( j}IjX$+y'‰,G<
+9?D/"V{S*bzWbt<fdTRJ1gIbE/)C2Z@N'Iľ Q K1S\RCkI~čX7$
+ QKC¥X³8pu 񺢉T'kJ6n+NHtVݚP>'St8`4UCnE#rFvo}?. "{S_]_㝺S H f
+<X=c'l]fxWkVj;pUq?1,IcWĨ*"[%0igmGdmdDK9#с,HDgH iNBUyNtYx8.%q0 P&sfs!8n["K(Ɉ\2c等LωCB>9N$9^}wЋ3ǰ ]
+V%/l¡5¡ "²lPO1E&\ ;q3h#j"㌧#UѺ`2NWg% hY^%8+% h!;~LG !GVh(JOeҥ ;횲-d+jqJtKRl;|Bہ-ӷcReiyM;ijHB[X4؛+'c
+IRޞVl7Ӯ=ɹZpgCޙ@;vrzB&)>I|8s+G((ٲtx
+Z*r*H 5~<^ 4|o*jMŭ%6A1WGZGB95]df Wg%)ņΤ;*r,h@Q%@;qr3wj>$—KY$NMd\94PwܖQ0aj\iK:T5z{ZtV'U%_֨RJ
+O?^_]oY.4W(cJRM LyMI+3eQ@Fy%$f{/Gh
+@'(hyr7?MiAlJ=E#a392_J{} |79OBE&O6rdC1$v)eGMQEY'䷋@/ZJ6Tim w8*\HGYJ@C)8ZVjXrCCy]]-Ydf:UW|y_A݁=ȼ_CY~y%_|h+ܿ(뮤Q'9n. (LQ RJ*kDEJ7 ALCp)2^R [Ba'曑aoq9m 9x_;{߅z{
+"˨s-}IAܩ輥nxJw0%)rWB;CٯP
+'ŠN6Fc_ɇd GXu9 RlމM,?4wz+}PTzy6vL$?ht|GH~)A2*գQpG%ů!vkz4`Ǎqtٞ6M`S#cFD[JF3Lusljgzttc|B{T
+2s tufXɤu)HE&̑SӮ*oz^mx#/MYܸ%*|ÿDw[Ϳ7őӶ
+^*>U;ˏie':Mܘ >rq
+L$tqA
+ lQ6fr8
+D"]fjF b m/kξf/vyEuyp
+_XO _3݌jbqsÅk(lLl
+EʔnyƟfuhQq$jmhԠƚ"XԱȔ1uu+ mI QAd<j ʜd.((J0Ρ[tH7iQ8lP/npPm"XW L d.1*?X.b>ס/}ބ:0P։jz7~v4'+P3;hv1-[J͒3lB2Г"60tYX阡w/d^J:hX;:K׹*gt UeyJf25RJ nYU/~,݉OW>Ueeoڒʟ6}
+?
+OԩTu!ȽgC,Oc/ۭ/3%U{[Bn0?GO=s<EgSUα=T`EZЇg%/M%֪$a jzU*UIꃾ2lEYCrȿ|8q7{G?tXS!~+\ CiSOeHYCt:k
+4z2|dKS=m!q!I1!i.4]?K9߂L3!
+; [IlN'lVesa#Ð~h``*\9*%h\ QNG(0qa\L+L>̥?%ߐZ2Z1[/k"/f,Cm%~Imak1 Fy&KK;ɇpиU̹X+ۡР5  0_|6 +pΪiiXu[`;'+#]]|4COͶVFkG`Ӟւ
+{;=I'wK.E
+{i`qM|h]IZJ #aINS%LPN5Se"Y\^C(Ö @r0Ye5 oNm
+/OՌZiq<maś &N`=(MC<Ue.X,qGtH@cu t(q.A
+]E#Hˉ hAhGKqig%eft3Y^N/w=n9Y< ㎧_&Ӂ3żF*s d dk}j:QQM>P{9MGA{>0Ú+¨DCPSn8hryyʗ.#ˡq͏Y7~ښ̱64cNx%]Ei_C{$!G\K!ySzIࣄro>)Pbhs1<?W
+F{}k~i]}~SMwv:vqvW
+bdךfgvmf34tvitsԸIlPPR1 W}L; ̼g>3zq=|9qWVŋ۲63*ϢE3K+s.E2 .jK}Ec3ɞ7%燓 fp*ԇ$X _5S>Z=#=0;58^P?0CB'` OE?ox!l^NT3[_n5$
+|p *ER.Cg%];UvmuQF0Rr$c)h}k%~b>:K Dt%ΕO~橆
+m\d|M)ViHrޔzc!EGE9Ӹc<0㑂nis^@U*sFenmV>}# $-oh}Bff_nS\7`Yp_%$ O`gAN~gss, 2zK_]q˫:zfC þE7R:JxỄsGYW4r[Eˁ?PEt#tSStFD
+I5""GMt2&i`YJ]>!W. cx
+W'|Q:%"W3
+i C~0yU T4!60l֨6Jr(lG3G
+SenG}`i:kkF]}l<c񢡙hri􇼳֜3mY'fɠ(,}` C;䈁-rnYV`Noe_y, )Sҏ(K@mXbtgM:2S S 7S)+hȚ;|d+~;ܲG #6b""a=Xs-)Ʊ r.kEoG~ZrL@N+D'j^B&M,aytn4;Lt[&d_GWIG[޷%ԇⷚPr` ,oH ~ɛ{tf-9l#dF
+x"k @)/10
++}MDc%!geY<1;0ր'M .Mjђx1gNvxo6Χuzɹ[>to}ooS%Ճ20z dƢ/K{8s1ߤ}PiuJOT SD A@PSSԬvۻ-kۻjﮭv6tSLR DO?@EL˶Mfg랙<<3ϼ1@EOyQNp [Wėï |OC ] pw?}~Qrߚ:WQtXnB@6\{`.Q3z0j,TW/CU WʱպRl
+84h1߯q jMtR(
+rW_Ɵ\#^Uha4\Bwplo9h%zVLGDb!}.'}hOxpTw7l ;轃ES EV,wYiJo׺r<g&d?䟿x[΋m;R[56~ϿR<0-t=Ks¤ޯ,aT??u)ϝ>{y;Gt [[Xxu aM r$a ] Ο=d!5"C$d"}:.pt*
+b Bz(fL %t1ے;P3:0nhn,B]࠙YWP-0jbB
+#[ESᕶl Lݚ:<]åtҙ D,@
+`ghmX:ˎ3o_<Ӡa,jSc]@)TQ{
+)%CLuS]8i3Q;tX ӓ;i *R6IF&xCЫpK4JtI&Pid8̊XPg c2, chCgp֐a0: vfڂ2,Ws
+#Vq8&˴sm!?DuH)=ĮdIOZTFIt3%=]!AYm'>@]JXނ]pG nYxFntl t,n [̍CC&"ǭ_IBYy-I}Җ$9%
+$rzBU3 ǥiv~yZ`ffOc+C|1m*L˦+6eg/:X):ٸg'Ĭ{-ЬodY!YpWI h]Uh|j
+`""[pL(-I-֐Mޡݦe2 [oOY6$;1h_cu{O}J_Zu7Y{:P hoTB0yJhhb`@F lC%wsC"h<A\NӢ?9^y{#y!)Г.,V&s4q=f0 >H
+ XFjJdEY`n? yېl*#l!!w0TkWn <wLK!=ޜG]])qkP`{]y{W7cH{P3AIsm|H89~OrlIUrtIYqG_? AX~vizYZUC"X9z5,qLW1
+~xg|JT26\M8*j4yKZܢFZ5EuX-!J(A_bD)J31qZt >Lb _n
+zb|hR/hEW#5 ~a|ë <\ĿC>O|'G]^~غG0qba,C/ we%ʼnG* נRydTM}bT-m8EUOS3+ҵLsO9&"["URΜ}<#˹|E)>^x}F@ t ]>HP>@'L *J
+N;`؍7?oWh@' ,/wp-">#m3*7ƏسGIGV}v{7]u+p+Z)"U6y (ӰFVhm!+0}٦9 J[u4o(?@30lj1$vEf#V4ק<
+yWD@_Powp+9L O g)+;_Xcc_4%|E  #;ȗš
+<HCi!a3!mw&bxn» mݥA}?c˞!@0 `v ƿi.W_'oOGv*d3|CDfF`I#'=
+(TF"&W:G]`#/ 2 j*K0QH H [ B
+h
+$d"%IwVe=ܪέ:U竺;<ϝGIExe w*dP`KqT/
+}w#alj9̳ka'GsC+CG0Kcnq_$ahgAoM
+ 4H ?NccNHNe]ki*eB6cZwϧE]򽣅ܮZ@\7ݷu]ͱ[Ļu
+D՝Q6- ]L" J|~yy'|ŏ??wեeܞ:i>w&;<9O P(,u#AÓώ\2ou iwgͨPX*时k{uش)7suMfcA?p؁#ri|y}SX^W
+,[Òlϣ.n4+X(Osو~ |6W; /]:d{%]=V՟EН&>ˍy'3RD_@BW2T|"9A?AC$j`^LgLYA5 lr}o=͟
+a)^,qGd2}p ]XJ8+&>jS.jRjK {BM@SB)]V E`ՇҊкB}Rt*8_, OWF*)B yU RRNLJ)1}M'XJZUDTH#n'(h^YhZ+iYjzv f':iD 5Izb`ؑܖ[nöp:^:k1ʿi/Ө,E%$
+Y!,!a HYiձ=:Nv:ks:a:*@6 @Bl@H =$ ǯy9~s7\K%_[ZǺ[Otב|q3/Z}gI7io$b4X괲lM`2k^>~"&Rw6<ʨׇ[zl'؉Ha@½D&#)Eyqk\@}x*.>".yXQ2 PE*Dzr?穵Y$UG*TĻoB\.Z'IQZR3fZuiwB]maKa~6' :?X.S`ߟh@UM:{ n{j' ۠1IMQ,UPX2(Ny9V~TqCaʛ%e꧸y+e䊟0;Hủ{<T\4*[CMJ3ZaϢGX,&гzT `2'Flb(JK*lA # ><Be#Q1SȉFO|zzf[)\| J'3cy!_rĢ!{F*7JW:l!k)fQ$*7G~H]g?q v"4kAw%tW^xs"Ge0D1% ͓ [.X}c g9#M-3_wd}/~V?xZ<@QCiOPq(h8NmWNM`6;u٧9=լfa{}h \::{lM c '$ 2FpTKQ 
+M' ݸ,K_c^^2 jO)dv8Z4GkXcw+huvN \e
+ ՛Wi;P+W>7wd)='(X-9zkU
+eQ4Ј=}q'45:̇9BS Wێ)͛3WC)N[pJAk|kڌyuāpCV}-!7IH8 $B#B"ڃ[\@D0@ @>
+ "ڇ+d@k[FYTsw[ ͖*يY6Y^OS OTӕ,P
+qU_a 8PM#i
+=BDGzց"K;Ty+"Z(``jERU& E,MÄ0TIp,o-VscM,Ak\ b@%W_'_i~9{wwEsM//dFP9cƴn-ݙCLተjmk0Vnޗ{ho^x S0䙇OY|Y5[d3y*&ps2N\9\ٟSݗ[՗Rޑ|YMxM4C k1P5j>>I}L0 &VaŪ#N9u~;x{MI=hʎѿ
+8&ܰjhvjۜ.csf>,K=BUICP%~Vf`׻W\>zl52hkyPEy/51>L}INFR6#cerW{p$F2tҝ,CϿJt,}IӖk<kcb=O>H:`qWWÊAqO GI1Ϊp)ffGXEbOjBY#?-~Yv&ܞbG܄x0:7oMNs)jLFWqP&!}=L7O
+OGJ6rmGaSųA>6"& w; V Ā|=̡g)U#c&N.<?q?/\#i4Cu,PSђFeqV@$ )Ria}Y6b8>g?w\W{/׵ҏ0[+qEBVC;CҶAL IvIZ8QgTc?'',r͉N1ls,TϒwZfyol_0y7a9&6
+G ;HQFB(խC/aO<3Ar'
+emH}N xz<hd ҃bAF'eIp*$:umI=uO
+z55(sU g<נk΃Dyj V|1HJI$fa06v?3K3F8K%zą&ADaWLVY<૧<K77
+
+x&h<N7nvnNMgl2:&xċC"r(*ry$&Xܝ}7owAubƞR
+U=KIUabNWUfR3U\u?%[+ON(T65BFf12$a#s0Yzc
+Gq_D]y[<[:1=,Pe6xYlUd+ XÜJdIeDc?6؇8Ea-V15LJ:5xqYאRtQhLT,fJ<j3;e%R5iDr^ Ch[AMZB<}5nC;dy48Йe"TH=#wfL4
+P&w@bNM&
+u͎IG6I)`*aY.T;?ً0a+,mʥU^X+ oGR|ӿڸ` ,g\A! )gH Ib ~t()`Ȇ3h/ԡaF'3"y: gJ]JLU=%+[5cR/+/) yf2sEKsBW PkQvPԶ=8kDf]^1LoW#B+Њᨩ a\MIhIB '{cOIj9㐨iTl_%O=gMى"%'4tFBխǗPr@`+-HAnq4y-џgnXCK`32qu>BSQ 3R7Yx Q8UjiEOʝ]bh+w~Vtb<
+l
+]bhwpݧe"*oy[jl͕(UuGZғjSG+OuƩ:d.\Xb@?W
+(3
+f|>$f0V qt2L34m$ZH,P
+խ"(6
+efB9@
+A0CbAB=*ljZΪT-d7yIӲ4ƿp;%uek>E/y/jW9aO]^?`) 0zɭr^R0!ZE I^*aO-/`}~>]ȧ=R~9y wx/h+z$+e?,A<f?h Oߖ{1P4ڛ;rkfoάSОyǞnr5`ԥ9f+@ɼmUlXP{fޅ g}:lDHJ{bdDjt5:2IZzhFd;LHϬ*G^F(pgϭ!b%N~vE%^=L
+c?K%ٌQ]A5pکdq'\GvLeG[1CUWYegS#JWd:-V}:(̚&Lٖ{+_߿X!}E+#^u3v~ޫ{Krc8 R]=.zEQ!3HWnkӚHת?ߕO͏ +a=TV0@Wkp ~]z7oWn}tfv]_9G*I'UkOLgX= !aTO;֎ڄaY1QTEI9P'uЅODRlpc("O3a!Y@Ta75[Ӯ[=+;ov]?PNvw]ۻ0o괵]2}XõIQN^2-V
+/^ sיu y?@+-p2#v -C0cQŏ1n'*d#}4e<M28_9dV
+Y3 ߔ^}a1(yP}/B{&v"
+"]a7.iTF
+l$q=}gͅ_;?n苽>S.XĀ(Y/VirՁs?]SPR{ukK!q`+'uB
+j.R%tuj
+L((GZ?--%.+0`U.ƨ:,u <AYIQTd<wpQ
+L ƞ<$S[U7#THE<N?A@`J .=RΖVUh>xS=*ˉONkF9T]-'jy(u @jx-y
+m
+"zq~_J-!`#A,ZA;i͈9fT
++kLI?C)PkY,'kdWRVP4]?3YJիة>NdK?1æqm*"ۮM $GB{g|PF2ڄ%eOH)R<˝lFdOE&QnGL 3q&D Hd#Jn#ŮDLS;[K:Qub tEJ2X||ZE*$T`t Lm Jg͵2p=^2)G ga'^C+lPUEp'
+e{:_082Z ]L1RW4\w+;ҁ4IdtF
+RǴ
+ru@^=;R*J썸P[ mÈGQ,_2KƇRn[ot~[P7vMSn̫xo|Ţl7
+]*TUrO;m1=eHyh/va
+Z;i 绺#̠֭i=`
+CTulTun L |1o%^xIW!~_VUem_8Dbψi$Suz:mh2rt3(x
+L.bmw̲@HS͞BqFqk&`K$%]`tz_|~zOwAG>V_\ڍwY-~Qcf韕}ՒŶՋ;nq>ƾG2sRfL[j݂Fg{?r⃯蔴^c;pڢ!-WGp6e7wЗ63*"n\RPLv`E/2*gbUU)o,PtOjh`8CHp,[G-}s^x-ze0Dy8AK|O$,mf$…n)ILnTMe|_fU๶~ˢ$2-fC2XXbVU1o?rLڕtX{SC`~ :$ 
+P6W8L-44nӋ~JLut6ha ' X
+tSr@\.hY \UZ#ZW+IBQ|I''[еjk;Nh:Ϣ$s'ڳ&O;Gh!]ؚμӎGF9钠$H^V-~GS#S$>h σò`nO nV5).M١PJI'4f.A5^JXtJ
+cVP+8<UjGV͵o3~ 齚lσM?;,EIBmnŇvHAJpbC
+Ca=coR}ڣ%J8݃dǁ
+Z_,o7\S/ Vfojbػ0NˆܠE PZsЌi?醡sQ,}}2&u}${i(gJ!2=d̼EѢ[8u!7Bf':|ȉ wƒ&醳&T9c]b[g>*#M}$IAX$TMkdYNIx;z
+מ$TJ%I7OmKkPϦ+R{(pRslӘtUk9~])Me()T[8ٽv>\cAxue8C~JiLFkzlM?T)a
+şϔN]SbL:ME+g xӠ<《Eh9 I cjG 7.Ug;;ήnGpn!
+B8D$ܿb_fyy39e ELyA-&
+I0ƻBf8Ohux0y OV#Xft>"O^,WEʫQ\S*8D0yF,p7DT ij HNLǍam> C]<E%
+fr)]9cc
+ E0\ r
+(dZ.Cdgf 0@c 6<06N M5"㢄 twQ[|{_9 lt6nZH$jIE+p{zw
+[;ejsliUOs,(vi"(1`k<(jy/1 ,` s #ps:D}km|58̣ =>jOYfQ> q#e'kV=:iijYմs8ZB(l]7k&YĉVq|9?'`$2_{_ZG m'Yi+Mr%w|j&KQY^d2'F2[X 23լG>z:vӗFQQFOicV BTKe]6fYWPajBg]AΏ_.s=ҙ&0KZ!mTAѮ_׃9\!GfZ+ke{FӐr+Qj@6:O9RCvd`6j拢[]P2-̰AoX|F!VG\y>amqaȰkij䀝^xI8Mz CqTlGFRl A\ÒFx~xr׹۾g n:r=EařJs ܈(tzB*nz
+.W7FtU&|Q̖v&.y(kCqգKlrK%^x\Yt^aɳ *m7ʻ^_p9RSYsrˑ@P/֎DKŸ8߾dݳ>Wm޿??v09rd&4"0S1pP9~<uyWeՋBXz_3
+]$D)hT @<05EW4R|fTMˍO%@g3l) }SgbDrM- H8iAyмV4܍|C>oy eB/_i"Eޢ\1Q/צ;LPW'Y^޵T[U🌊2w1؇zl\Vol8ͭlvS%2s GӧS
+?T-}]>_}f:ҫbF.0Žc"/ rXa<N \(h[]id7I
+_w
+ \uI9#(uOʫњT&0Q6=3wܑJP;z_Fq =͉#)y3,83/d[1lK[s=h
+c{RN.ִ
+X!d*E,\e1"r\!+il–sAYS
+kk=^mm@hGFߴ,F֌b~]= oБ` 'B o#pOIN;yv#.܆}rǿt3er{\.>Gתu-,P"3&rڐRClҐ<4P145M=NJpjR0253&ԤY?0
+5;>kN@YqmU8&@w ;14y59|
+I[T_&@sL] (62g#ŒB(XX."G/p9qBU_
+(nCq-6Bڣ#ZMi1vN|¿dOvqg={ɥ9\o^UJP/u5gc^ļ4GN"[&Pґ<L+Wqٱ8}j ^C폆f mkF1j"l]sD-:aU8j
+G-q |7kYrz
+OA꩘! ?"9^+ǹH6전*S<^ .ܰLс2 KaZ*o1P%&8NFHl}Ƚr6fK O V#g7 WՑv}td4ljݹ>ɩ#jt/gU˯+uk|SA?y}w6Cp^c
+("}!¾
+Z^xvr^K-H%+ % %*RPQD̙38̜yȜ×eݓiwXo7ȷޛ̟cMwm VVV 6:\{͕3_%ml "Lᖁ`oC/YpWN]?iS<ϵr:錭Ќ\io^v=Z/`*(@?TɅ! `L|lɶT{crz7ȇ < βG& yfaTMki` 2F a:)ZH;ZiD|<!2f<Ԏ⨃AA/vHmAfSgYk#2lS!,#Jq`)k,C6V+0
+FmR7b0_@6_C)\>*?q'ᅦʹXOp3fѼ~DΐBm_NMV0CT@>
+_a̮cڼ_OUIL\r0jh9ž5>~NzU)2'c]Bc993"[{u?ulny;8sA@ߥS&TDgT}5,ha~ZIq5>8جw\=G.H8/ImFˮ:M>|7e #AA|!B@+ #V(|U&.HxۺW})AS}G>pep=G"G8rF ~ /ГL[bA!XZq(C-UrG##22d823"ZJVSYqTLG[CBHx-{&΍\Oz6xBUE؉+NQ [Vgl!ⷵ[`a=
+Ul!l2ՠK)p4W>mk+V\2[AT/!5`N'5dbL#hn
+0Q0z0 c0z&`@hVMW;(ʺ }$LWۀG Â&<٬15&6, ap CiuBR.Ld&MH|S2ϸrw'\LgJ<U0#?+sJ\gE[.׵oY ڰHX3q/܉z:d`Gz#x:p& >܈N#$~)"k sɉɑ"_˶|`HrW5R}Ӈhr"7-FX};rR7'O{& RFzfXJa @WK9V)$7i8^`E4b"tQ-
+: ??>@<?>A@??=>@EI
+JGFE
+E
+EKKBEJIH@?>A?ACFC߾ H߾I!E!<1*"#&&-*/(."'%)(*-#*((&,&-$2;7.)$(*
+*6> GIܲ >վ'?Һ+BϽ0A0>2@3A0D־-@.A%; ;<C
+:6; 8 7 ;5 ?ؓ
+&
+&(92' "+'27)9 55488#8,558.?&LV_\!OGD5;6998,7!3168 8!:2G̽;GŹ;GȽ9Gɷ1Kϵ1KЭ9XΚ<um7=>+:<7-#'1Ol{Ԓ[۪QS_
+g f
+`)f%zۆb
+U FCBDIXk& o"T߮/Xϩ"Qإ WYamށ;oFt@Cҧ*bމn2JEVMe(}oSNd`!V0V-jF_Xh<)j%E4 $# 1!.%.+!*.*-,8'7VwbUUPP` wq#B;$Rձ)Qկ,MԸ(M԰,NӪ0Sӭ.^բ,`ՠ,`բ,_֣,]֦*Y٧(X٩(V۩'Rڪ)Oڰ$I׶(Gָ(MԵ-Jշ)@ռ'?&?Ѿ*>ξ2=7>4L̳9K˺8Jп2D2<,6&677=@Gٺ$Rڮ%U٪$W֦(ZԨ'Xզ.Yԥ,Zӥ0]Ӣ+^Ԣ+^ԡ-_Ԣ-\Ԣ-Zӣ+Zң)Uѩ+WЩ-_Ѡ.bН/]С6UΫ3YϨ4YϪ5Sе5UԱ.Vة)R״+Lڸ&Iݰ%J۳#Vا%Tը,Uժ-Tլ2]ؚ$hґ0qΌ9uΎ4sя1qӑ+oԖ.jؕ(k֏'qш#wc<kǰLpǺUW\ۜdя#qΈ*xІ+zє>lϯOQ*NLט2[ĎVUfNdURW'X Tٯ3Y$[YKQM,BҕvbX0D(D9@BA?C@FBKDMIKIKANMHJEEHBI@M=M=N=MAP6Q4T8T0S,N)J*H#H'B'>%4'$%8#<Ѷ(#$).5Uߦ)P8! 
+
+={s{Pֱ W?w/ЉGP޴^ $<4[ Zж?۞.|:%HeF9cTƾrQVTTp22Ofj3 *:McS, e>0C7GDŽO>z;uU %oc@a71/u [9~ :6oN%ԅDi_HvKͻ r>> D?8"{7/ 50m;0MA覨7 =$)JE^:<B*8!RِlіM:h$r` 6J񠛉tC2osp#%eBˆ GxS:\˵kOX$DȳHI\7u6Nt5L^X$fN](Mc.3cY(YD$fYR}hgS2&^퍯z*MdfFƚg=|goFdDCA7wDY Ei(&{RFq#8{[x7/R{Y]JׯPX
+žQ*YEVU@
+L">q.Op޼]VaoQM
+ YDlQcx熄9yJv)tŴc~
+
+n?z'XzYХүvZrx<ci%Uվ㚿w1'.CÀ"!I6o{/Π>SId=U%jіBF^=pYֿ׽/𭑻Ǜ;7y Q<+0! j't4L+*S}zW;$b?]> ~?iAQ`"Sr)LW?7*G]]Emãn`pA1v u`{ yX}7.B&DpvaXnmݣʯvIɯ1U6I1{Xo4+ÄE"[w0Bv;(
+hAG8c#gqڞږ9Ne:U"" (; If@A ߞ/} y (rIbF|rӇ?q^@=08s?[<(XT-3<J8il/14$44J S2=`'{
+}T_P{?GKuIt
+}qrRr]I'CZ
+E-z"$gmvδ& 6bK-ŞSc71t\mͮ5Kiʵ DЖaaGKGI(8-6곝cI BqpOWNijcҞ=F.MVޭ-9৊;gnV]?^tR(}qZr?wPk<{%ߣ>dl :~Y\];zvZqZPO,|2ߵ6XJ D74c\]jhȱqF` Pb,JiU0y9rnym_^ yDl[H=<oYX/o_0s{0>>jAjZ'*%DGTS}bE%ħxRD(UdJH =Br+_?#ݔ~DVz9Pu~8 @mCvvv<߂wA{ P_P`oٛt^c=pFg%7/ޟZ*53݃038 <D1))0MUOEfQ}BjWjC
+B EꗤUҔe%דP}W*TjVb hn89Ũ$0A0h3ʡTJs$
+TZS>ؖVBw#2 \D7mc莡M csya0q^B[eW9=L[3sǍ_\`}W|2W:<YV`<' 9 =6!>iXIEQ8cSNrc%$76]J𐼡8߽_DpP#:*v=j8z\^6yO7h.GhݑϐlM#ׅV4a-L)JHD:&*Ā]~5QbiC4cXghѷgY!."cg0Yb0HRJѼI
+Ιm Ϟnȝʛvf̊K uMI}}(`=8k;DW}'f hc2vR4BSC1>"< MĄ1.nb2!z>i M#!X,t
+etqDʹ2-7pIAE\05T 5ʲiNw;5Ѭl3kSj^,7EA@C7$CӴ4gy{~ss> MΠAyN \χ&c1#d:..dJ1@'J8^ɲ |bLeUu.y R6JzSk`lkvl h|K
+=T?P<T!2)ػ]g̓'_,5"VAWn;ԍ1|IID+a:2E{* b]2A!4͌`v_`7.ÔRK1s SȤb\}̍{gMw)$fӣ`z\
+ ""w7y#G0
+b=h@7PDV2D>q*ǢtQK|MӍ)͝Uo;QnF<P{SmhK+JkbaV2ƾ@9fkw2Gyy^_Hi$tlqn`V|s]rW>Rt+~X]hPf/@ߊ''Y>;xy9EEDʼnG'l`` \εvA&(ߒȑ*~ -\:Lx :RjyFyGn篖f2b}\N?U]&umzcQnjPc8f=@HC܉(+rAdcpŐ|N.5w7xq.x.-{m!tztq4!ɪQA6L]aڲs^aٍ(@_aŀI : >%Kj`q#XKX):KdvѣᲦ}DE aeNm;jaQ*hӯyw
+.RC
+RqA;50hx%Ӓl1#WCb$и2M(vÒD%EIgda)"Q\B}_;%K;'xP*\upQ{P Np=
+10o.+җ ̠ Ƃ$C?W@?qiiٗQS5{u&a3 Ъn]VQmۀzIK{c8M47ͺcƐ0x׸p6BaBʹCz!̃>0(\Jȝ@@_n"GGNc:;quR wBr/$} ԰}g}gy>/2Z=>|ijs.B1FEiHH`Bp7zmp1F'atQۈ.dP5-7DAQX8tS4j#@Z)xHxӀA998 0Qe%p!Ft|C $'2J2<@
+v JQ%}pS!zUQywL{.q'%(8?a$(3/fMҊ}])1!BY2{RZŰg ii&VgWyBAKFDpΘΞ%
+ [_mx
+Ņ[ֈ
+Q ;cL\1ڝY:**z!I-J-{S~cJ~(`j 7, 
+x)ϛ>P6ѓT5)H<<4u';SʧͨR+%>0='Lv'$yz=p[T(?E CL+qf縆Pa`F`PpzġtXFΨ#9/4gԗ$I`[ve.b S02yC' C=NS
+ZXϳ:ie#r-fX/'46= +kWj^uo"ϟ O{l&lkTu;*]2^gw9_BF@A43
+~>I<>99NNL$'ξ=/rv@Œ/!}z8J9'(6:@Gi]-HAiT| c0F;c P JSaI,nS)Dux}K!)3;S/0'õFggHif0IQGyF!pʳ8n1k&WꍷIgQgCK9sq˾ظ噄=3 pps}Ņ.棕lzߝ'B4x.UY͢s>QϹ6|5qks=8SzDGA֋
+`㋠Aw#DF0IR}
+CMhC;u{&<넖 `c
+ߓ@u@ڲ/ĩL,| \)Qe<ۖl݈rP,LB2Өed$QK˷XNº1o6br(=C- )ix*=_kO
+!5욡'DgX
+!Vq]fg<ns/NYPVPBz'@H$RDiA:;w~L)]|xtUאdC ?pc1z3a`z20h
+A.^҉J51Ju'7\%,هMH=E=F Ѡ nxN#tsi ܸxi[s 涺K,?Z[62qAKbsH:gy vZnnB= nN汼`Na?y|k#3ai4V4Uk*S
+TyY''?Ury.h;iT.xu̮MՄxxX#WI9t $͠DM
+$ŬAF<h@L0)DHjtGtFⴆo5󄻺
+]uEjUoU'''#_,PLmHǦ/yE Cv z6=c6'[sGH[`Mxa^hlU٫>.>]9аPK }i+0`FL/U\.N+n$Gi0`0<a@39Sg%" =c 5U*2yr1V(lB7LtX 6{T|1Я=LJ4
+m4&5jԢ&-ҥPFtNoG2Og+)YTfN0dҰ>0
+ xʬ&YȘvAh9C-܁tƐ,9*Oʵ cs>6sP= M2d[i<w#;!N
+fW.xSf}? nJYZU`jj%`5DW1XzjTd l6]R4SuJqEQ{zQ_mRur-M6Dv0%FewˮQ=oaa3`<H'C\{SpiRw\=!\d.M#Hڃ
+)7F?ԆOG<{Kd ;)B]@P&%{A4o!p#ܾV8/B{tPwr[kL<q42x8aHP?<ip0><<67 1!ܘ67jHŒw`q%l}0%oJBjT*l`4a)iy\A&
+y=7-"afNS{>ECi8HwQ>\'#s?>1s6]).&-(<qiX#BF/AAWZAT\K"nT,
+";~IH
+¦)Dǝ9s̙;s=9 ڣ~qjw赃oþԅk!70BT/*| r&S K;^ph|Ht5,HG^B)̎jNs&Ԓw
+iBh~fXۍԠAU6sao:! 'y̆Nn!B^m)9
+,H黴(G=nV:QȎZm+4YSÿ8cXesx8Bc0MT;G'91ET|Or~OEܩM?,|),;YQtd!zO90#-PsS-q v_܋WƯ~TmfBWRY1.&|wm|;n`_K5)1o׿^iqX"bK
+ҙv:["ir8-@
+&:lrOU*
+TЂ* XS)>:%l{}&w~7Qjlc1-S]hCDo|cTO.Fw-GnP>]n}>.&8} !P* urvO;teh/>TUB}|jHm@)lSK*NjsDyuLHW_fVA;}b
+ N&&j37P<j(r|j]c
+7990S<Q昙xw(1zh#2Rr
+UC{\v+.~hyfE_3˦Kkƃm&CV!.Nb?_@*Gw=s'"ӛυ nJ= + -!GKeQYEq{
+KO#)c>?l},6d$ߌ{zk>9Xw6,-w?wwWVlJh~&HxRVј?iޙW6$bמdkW{ k!,sfs)vY?wձI3^\ j8SANܬĬ㯖yPʈ~Flm ^y*bbcz
+7~
+W+Vl]Ɲn]E<̩-(ws7Zf}|ő-פOY?*dΒ:Z[ G'*℡l\tCM% *Nce:NNKK:
+o)@BQ+t _JԶ8ρĞp`f
+ &MY6B|%re`4/5i%$s=kA=Q$*mJ"Fc^N@=N6!Zk^k }2W܅g!٧jpd*
+eı&`?ZĶv )2$kPB"OMñ8*c1S2 O95 EؕXҌ"2+Պ .uFW`ڏ׽Aس7
+Xq
+?
+TM& I1ƚ$9ܜ7؄} ᨲquC|?Ym})RTbo'|y
+~Gw&_ƾ^(xԘ)0׋0:fS5fյR*~V_$^Tnڂ$Uڔ"ctY_\|)v9A{
+@vo_K~<=);[@aܣ/j<n}#dW3|Km?|pK]Wf{S%H @BFc #Xb6rtVihL=tvSXrS#'Q5J2nȉT!kX<) vE)861u̔69
+R*傶\!_)_+I*ptID<>",us8P셶GBg]Z{EåK+7_~a|bRi];T:V -l+,ګWO8pp>>X'G],hk%tXq Y jo2-&`΀Ej͸DM`!s!4p"5>L7=Dž.WS,q]=_C/?3nF]M庩5很=_M3I?Eo
+6K5o T
+I7!V
+eaP+Wq(ύDTе?4F.ad`{Iy>-8tu@|}TRD? zycEVc"txּ; j>f/QZ/>v]ȯ_'h.׫뵛޾xOnx+En}EoLu{~Lĵb#^MM{}qҟ4XEWތ(C'?8{נ>kI'O82-&PyJe~M˟/8wS"7\ˌӷN2&
+j;TIdaV
+ҳՈ\{9jjRm[WYֶXy"H!p)&lufJs3̝>NBy'pC Ҡ| Uc8 -"8M8kisPE' }3&"?\kA@[&Ƅd%}BLB0#./|!j& t 1
+KL5GrS-PB/lM7K<E;e^IŜjXɟ͚[5%aO/;sJ^zWq&dۚ@~h-_?X#  Vv7{jgDv;譒Tr: aNLkwlHG]`|J#&-!#x4ܾ&a3$f;0}8%Iגèoԡ#Ƥ*]$xk>| Dop⡚~/0G}nA$%6KTC ϴR!@&gMZU4-GTEsLkXVg9Lx(vcK<nwd
+Gi
+lA%2yj!)S
+FP+A-
+z~DC
+
+YS+8H lK6'2/3+0-'l[JM:%=(7'5"88868 : 74877 4j
+  $ 
+M9QQCT8 .E.Fи/FϹ/\Р7TϪ6Vζ+RҮ/Qӳ,Fӷ.DӾ,C,Fӧ>VӚFeϣ!`Ϥ SͰ+M̸TMܪ;QU̵#lҍ.q~DsX{;oM`_VjTv_tVvVdL[4|0n=6@LTɟ=?[ _K6m;O#OCKXL~yI[3WJ|dsmgquj~{hw8vO\ސB,+.*:-C9BMAa,sҊ~%m۝3dΡ@fâGq{3|X ބ(yئDrbloW7ɂ)wڀ!}wl^[ޥ$XܩQHJ>7!."'0F0G6:5(8&2;:N7L?O>R%r^o^
+:τg5׎HB;¦"J)N.ي?I-+s:q81j͙kuk\SϜlZLCWx%-Kb-}ΎȵwyU`nDZj"/6Z:2gkA޳A{§vҧ8;h;(GXSpga_pG@G| ,0 A iz'fTy}T2>䊘8
+B: %rkĜ
+2ѧNiΎ)3qcg6Ĝo1kt#:mc6_d9舾%W ӱ̮jMKTtU##oP]u7>Gꠌ'}6vd;9]m[P6xxcL`oRLy/V +'xc\P܊[K|2DE/m#tf42\>5!̦sh n=miFYDŽY?
+ 7 Ҧ tdh
+H'mb|pg(mdHBڍ9@#ZN#a}
+)k*7 _pg+Όε8,zMtJk-8 ;<GdiJ\w9,;@Bw1<W0PIx%w\ MCZU@#Xfwo*}>,'#|l3Q_8R[%,vk"СO5fKIS}Fx$rܞ?J)c*0n(|Bp}4}wxWwKJa\e_2b$@}lDxbƫRV= CYшqVreÙ'wVeg[O㷦ugS*&c<ǘﭞ3t6cC 6Wd?hyDѺs6K3˵y1saeDXF._5OYyu X J12LsBRW "5F|]ΫQgi0zW 5O{#-Dh{~v-/DKtS7?4O=%xLL=O-Tlee"$,K"~ۗ?V
+U6nN½09Hy'`tTZ ]ػ?Z hY/5!ٓY,ok笕s ol@1MhIcQIbD LjV#-f+iq&j$/SO~_ȻW{PZL{:F.!lWrÙ
+) ɭ5tWf.ŖYJ1PeҔkQ}SY\ gisw|yq_ނ2.lv[hK lzxA!c5BB6[~ Gָ s*Z=@@՜P穱'9n~> ψ1=_};:eDT1B(
++<@b*e/c cX@SH^7|]%B~۶^T
+iIA$"y])^GK:ғT#H
+ܛS% w ֖o>+G'*gE׏|Z_һaي6Pk.(#&ݵᾱrKJ(ee *}2swAL /j7 sº\^8WP+7gfYjM8wdWŕn>i&֥Jz1ib+ytP9x]Oh&ei B2v̓!\rwmAS{)Ahk v}`p()azxOඨ}c8f p6Xw`݆' iqqx,<yPgP97NHH \ⶻ]ŪҖ "h$$NDK П;<>;;'liOa;NV/bT AqdAPP"
+>u
+f.:H6h' u8n CYd{c%6;ܱx+<Ze.5f;φ?^/9bYЧ̮[Wm9u|/It׋Hq]Ŷ:kjk 0qχw{6S[Rܿb8hiߪƊҖ–Ŏ9C7VGVOǎYNN/ؕ#5dt( 5 QB KP7L¼#>$2)O+"SzW`ȡJb=h@g4ܘvY̩ErD^ ^@fokQ#*$q<&*1C^*
+qVVK+h?Pe(jvqmxs{m_4Vs-3a_ށ_yg=z~ s-_oܕ911I>'}·;^E>˶҈䖆mqZӝ
+zw馮 zCur]UQm @45v1n6rᘎ
+],A} =+RB BE.P(>T>[7BYz˄:ssL_t(:iUcVN#[z1J/11p7t9G~qxoe+w$>U6kzi
+A$-Lմm Rf:$i*MESTN#D`4JѲ"G 1 B炉]~;emg!}
+Be;nzЂAg~=Ȋ:>1t<6p|cDN1h3;
+G'eGԏ3U5͈hsI:P% \
+V1AvpDV=ۏ*#t }4:F:S1hݞ8qM:FDG>wn
+E<v>tȊuyȇ.7\k 6&GTK8k]7c·#4ph8h`TCpcIt [.uXJd$4! ӞOP`nhA>_אeHs
+:lrcbdr坅a㰉6򳠲pXDqlUڂ u`=Ւ *-j!py:"C=(faWz'5:(D%ä
+Ljqb=ܭLjo
+{ B@<{
+ }ҋ
+f8S{_Dyě,J?%'.~nRjz{IdhPشjc{,[`qhɭ屧*ȉm4V'3*Ji % ?G6FjK /EjAr%=$TGNOow_guW5]eѵoԠ}؟{ؓHnf3ljTk+@Q6:G`wI=6Erh)KA#cQ|6Lz?vAOJJ%!a/#]גߴN]u?a岀`Ec J[=jh!~ $p\*DLj<<Oz9::.Ou]nL|f
+_RA4 Z+¢2t6CiM zL׉=`Z P } Z>U I( /ā^LЀET#>vP0:WۛkG!/}-37I
+Lqk@;CS◩KT@Ni1
+,SS8>XKlp݉jv3
+{`k%zF*>_`()EW^,
+ᕣ+tYw|ay+|~TГT JSYퟢRU€9T)k!9~W( =3ZŚB[u5F;I-FbN6]1wQl,$.^'-裼!޽ҊɫUsI)~+a 8(E; !kKUlc
+Ȗ܉|񰺮8UvWRB+)Jq
+L”NFt<U2 A)% D2ZI;|?߽qu݌fk[Z0{;
+n-i*,sɈB@Aڵd]O,uSK0S蠉Jm$F
+a*]8GK+(v$%C&6SMIz$uߐ?>\gM5!uߊӤC͙EgLKasJGL"T<%' F! Gˇ8ͬwáro}ۈ*6c݂Z
+N9Y
+u0u0@)e>oM?H]Zp}/;(QG[S9#mH)Ka|9j6r%qkVdSxFDsqkڝ 6,Bhͫ Z8;(%}Tpq%7A01`-X#sHu7em,{RĞ'0g4IYEj/!5NROk˜aa/KVM;^3֍a%uu86f /^od.%s:;͚+h.O2sܐR2Me*Ӡ%zҒV6%O俀
+{^UP 3ͱ qF"GVϬ꺇Pl
+u*1pߩ&mDOu0e.?K`innFun7h;Kp*um_+4,Q#̐
+]̜
+
+H>H@
+e>$#k/ v_;dDWC*}:WӞoGþ{Om6-%L|&??@3"w Q-&>vV4wa};][S$JU}ב ρr~3}9#w'nO~ŸpܡsQOA"8|
+!H !Op)B=J?nwjnujnguP[C#o.BB@$H aig<wyy' fDjlj]-|8K5 S/zK
+ h#WCskێ!L>
+r6>YΟm+ت%{Xx@tm_njߪcz[k_=+9T#>QƗ_iwmt98߮F,Ot}&>+xRtUnPu XM$\U&^V&]gl?hj{1eiDV'L?{ Qw9FbyW3#
+G{r \>m2ރcꇨ}y'w)Ŋ'e3$
+ 9妻q{n|}1 kɟw\<c.+?w~ Yg%eUN¿tv ~L>-0s$4"kV1"&1J -'TB>Y>.mxA\N)Hy&rOBJb(-:G졨tx Jy]Q/ι?-xt:t~{x8ɗy_3]k)D$<}rVkm*җM8, :k6u´i-jsqʝ#I=լ䞺;~/a (j
+k#Plښ;ND1qf(9bzSd
+K7)R\*,\}Gh$hԻ2r 'mԏh;sUsuE{
+qxMBTOYUIOcό^9⸳3@nȝo{Z<]yv=/+^g }NkAG\Pz\]^pُc,t1cAyWk8d詖+%_;ʭ!'ʚ +"x!V=|CLev3D-*;
+mdut7d` c.Bw[2W`.s6h4FJӅAht}7!`:3:ڒ2V i6ڐi@;ڑD_XĂƆ
+C’4 *KC"u$ZS
+e$quqRERo;a7 mS4ʢ—,
+҂—2Ȭ[AThS-Iiu\IGı;/;s'E (ZFM(4؇"`.}re;Hz%^0T[iʞa~bsI(ı7lɟR1<yct޳mCU1=,(nYyplBpuhA5!"GcˠQ-d?)U  "|LKZgvX3 с[t@ ިgf7Bis~ P!gkx WuNIjkbZ<$j33_ Ԟ7Lpv|_Bv|[iLGi
+j%wM
+oXIF|':@iltsO2!H?ZI8*:k"ƛϷ*t}=޾=JbS`"ّO9L?308f8
+zx-+E#%) Ew,4,-ZD[8[cz歩ןZ\+w.7LPy>n݂ H]J7d[_LtѨ՟__d<U gM=yb <z`&]@8^%H1ڲi|9w{ K^HJ8$N&=gE]wMၜjh`6vhs@MK٭S3Xnykrmgct|՘V<汕]˫6kf_pĮ6|"}:vuNf 架)Ip7}'r(sa\qw!NFcDC)$҆OOi!e,)8{$$3XTVsl>Hs5ƮNU;|L`[<~p /~0P B}1HOx6ӝHg =T+Xg$u<tTP<9+.A(u NI,D mDn[<q^#:;cMׇ!hZHyDx8r 2P5oKo+<Mջe%-$cރjҧ)3M)Ӎ@ @Zjr88WkI}| tӄOH ~Ib0Y=+'NI0<-F\eB=Ҋ}yZ+`ϖt$/2\G J:]b9p#]^Ag@{e XV z`N+CCu(7Y+n9xƸő[֡jv&Ύ.埆^W\KqvK~zGqV"/@ޗo> Tyr_W#?)+9gb
+0nm?q_RW`^}au˟dr۴gmȴoݯ!5^s0"oܨ7$ }:BAdJ8Tuj (WU$Q CTU(T
+iZA%HBBHBhB
+蠲wu:ꬫ⽻E
+! %@4lowΜ3sj' b'n_ڸ.a WCd4j::Wh3a׸Q+GYc%w,ӑ6_ކcY`j_۶>K>IwEVEe-L퍚j3t4@&HKDžbhtK0=zgB:Q+2hmx y3"'Z]IoD#g?5/}-"0~Sl
+00KREGw cx <bllhg$H CV6!H"$Cv C0=`"L0q KԲh7 S)t8;Uh,7'Gu
+&0%0iLzܮa%lqqӞϾ2VcDPGP2TTEx%p|8'g];2^1 ~_7q{"GOI5Xw/"uºbl[9VZ}ƇVO7;Z5]J
+mt|_N7-9Wk/aƊXfQEe9FUuê /[_'}}Ԍ"G;m Y'oYE?ҹy3/S ow~3jҶZAV=}XRhT=M؇ef&l(:Qnv .<҇{ =< ܃giJóhʴM'3ޱs:H?<:gP-^w;~M<p<<CZ,]gwT S%.p-wFs1JJoyVIp
+UuUfὺVAwC@P+] x?m~3ڂko˻=~uy`gxKACWҖxS0H&f lŒ);a{0k(8 MY nm!EMӭtȷtNZ~9vk3L9pUْC'i?iNSҞМ\9b:J\rǾkQ%C1+Q
+Mf1}rh/ uB> oI_ 9t4ra-@eG=@BZD1 6CAm 2Mc|ېNK>mA8cD\V4nFN<2F)3 f5e"Ť!Ҍä#èҍ
+M?D4ŕ:%#*Zak$D]vf"g'sS S%Ǒ5}XۡHs'D֌$3%>'Pt?jFQ=#̈`XEAFRΪ4NZ׮=<{'s;y+m&q>o"8>î@۔Euݢטk_!"-=zTkYAtX?Z=Ͻf
+`
+ޤ@͢ oQ
++9Q5XZF}GV*#2J^M$5xU!ٴTKԅ! Ѥ)"[Ft R=P
+볧4ZS$vPlR l!N"Z?AD܄ "B ՎrP#8\3 x :# v"`"
+U<mf|kkMbߩN)l<!NCK&gR` @LDN?Sت&<G^_WM<Sxxҙ*Nk05G}+jǧHiRQ
+. 7ٸa6R
+|uiW!Y. %5eBkj['a ֦G9r
+9L^ 3Ko3\昳a[M{,_S5]EY_B2,J'/
+d,%/v9'iF?
+MhH]69842i"c
+ʦ FTqlrұ ۴o~eɟ1ϫ{S-Wv%w;{;TٙR]5o"dR:qy7n'ke{JWj7rM8 SVaִfO`]{l1|滱hv^v蕡)cg`ׂ>ܗMw?l<w۹$
+<Q߃M1$]OyPMvalFh:1nj1
+;;6rFy&ViQHKq
+v9w,Z%۩Wm<5L/ͯ?徯6`kU_˲i}﫜CxIoqF_2N7d]>=G?3儰rHxp9) ]_3'岪b,n.%J+(Q↬ڶ^nїNOb\OEStp
+%G I4LpH0;8\S%(`IZ^qeHEEpYp
+ /%M` NS,ĸw˦ltaUf 9ߣ|CxKQ韨/Fc4jU
+$ǥP e@ݐ#p%B$Hqi,gZx`JQ0%:?Ɲj;Ğq I
+XSj؇t:bWR
+@
+ۜރ_4&Zx5~/8v1kK/B^ܿ8/h@&D<{俦UUMݭ<|J+?z!V\of,xH+<]`Bwo|ŕtzFfMϹipg׵51Kcol+ 29&+dmBL.9GR.GϖXli?X}#IǩYp]_ZT`ەNT<n4ZU%倆QHsI^a$+ At4m&IfSZ5e.crm|Z8O!hj͚bPS@vqtL薕c5JqV-&Ӥ̝ ֲgeOVb!_e_"T <F 19n<ܓA'a.ϖ1=ƒ0=l 1,Ɯᚠ?<UmTnVz@y.9ChƸcu 
+OmqO]R1tQṟP E $8gS%`<شU>8m_0g P *j%
+u"C_ޠHo:w@\zYRe0V=ݘ `!
+K#Y1{`L8 bқxHO(@tH)ir+E4tB7L:hgGrѕBuu3A! N1`CZl/ooo_ۋ7><2Ώ GԎ_>6>\S{%ג?_+}P͜^NE`%>bN2fl߼?cx񸤩ހ>8UwZTSR-_7Bj[ mRՀri':D'6+/_u^|2?E<Vg궎izͥ*߯s\x<u([T0㾼Z~.&;C )
+r_! $9 !' ȥb>a?w}g}xgIbKqj!-?4> q):wT?[T8YZ0^o!vaQPė׬H uRF^\vѮD j1HHI.F@bJ 溧SD86I\(-'\>^RӮh %c9T pf! 5` %ݏzz|P()Q*$`Y
+Q
+d,9-KQR|B*O.,g>Nj+c gKt /zxP֟GƔ[K?nJn;<oUo7W@AZ0 fL sqx0m!M>NhQ&5!331C&7܇">fFߌa'`ty&ohj/f7aB |_]z(Pvܝ8ίv?῵yvklؽ0v qEBo;܁{o>4ۑBnM q%Yb֬Om+Ŵ*urM ,`v<`kgsd`B
+b$ G*1QD˺库Ո + =9g~Rdb9}1ڈ؛NqT@cٓHo v(i2P9 uṃ($3,>!3Gܱ(LtkoN9=pJ0'ȟrf
+o&s Wm'w{` j8uOboƼgRue
+TGhLGH\Wc#(uI/)][q[IΚ+cYɘBΖs 8:f[|$o,
+<*f[%g?ŜI|-?MZ@-Y3Orƛ&Dq
+cHŚeM+2VT~5Oº ѿx6@\6Akt>ƷD|{G9Yيn߈:dE9! f8ކ D|F[\|KO侯G %PӜ2TAJb(i8)6 x@(c]Ď1q
+lNl5RZkq :EDe+%{? 7[>C"x^[kFXMo 2Zs9bBbKf9 \Ak?lyPwpεVj@7H!$`UPPԺ=ZW֮=\ (*W$$@B79H,
+U۱@?vwޙgy>o!
+[sMyЬ@*Α
+mb vP'K{NC՞R
+1$eJ2s~ͬ7ߩr.sEU=RŁcwm<@xo(5_>V|͗'8'Īog}yX]llHϼ8͹|;wW㒅Cg
+ m\$bħ$̠6ԛH4إK[ZXxKTᣦXdC{B.l|yL②03^tj6E7HĐoe e62נ 2d: 4H3* lD"%C$1rk`& >_IUvk/PM,7JMu:\ZK-XTאjnd@/T 29v6_f5x3*;˞L~7S( 2Z"ԁ϶H*&V8"l9{5Nbۄ,v]7 6!)#8O#n궝Z>|YF]6|n_U:DÇ0`(z܈Gc с` 7c`ql ō0{Ik~ϫ}1; ..2+m!M+|~$(
+";8ԏxpO {(rsTu :!ӥOd A
+;([<%@Y0)) ckbz1>Ѝe:pL*9ˠT^5HSC5x2)\PZ;[9$CmbTMe[x(#皅)EV!@FȂ % a%?
+)4k|7u3r+| 3B7K`҄(  EܷEFT6!<Ǯ*<۴-w |;f44OiAl9y({J
+˞<i[=8GGžTCWO;lj007.}(`OH`1YwT4TmUELHD& 6eeX6$]!DCGuuAv *nG]R$!^2!=UO㸆_#ۮ+׀FB[?gOA
+fx~*o҇U{gվt?W3*ְ$p'p޸82g=r"5Xǚe=Sf=Q0ݹL6sZ @vcm5,C1weYPlKSaxTvy5q<ABGZBIHBHhy8:q$B P
+K݄)֤N6ƘbW\7^/:Y}zC.y+-7ʧW^U[]<56tl#'߾>4
+*Ti)a5DEds!g’8}Øtg#l}8_E~xc{wʱkH|n{t0G>[+ѧKWZ.3M {-7F+)ȝΦx2k}L_E dWߟf1&
+Dn OzwyoV5x:הyBYe䈆|s-NQ hU*#Ի& TX%dǨ .WP*i!CꨞJ2daեeTn3Chlq#rZ\ZܝkЌn?_F;F0V5хz*0D^A{yuc1ZIӺK?^v;˴h\ٸ+Y`هXu`q.;y>j:_;j:O#zb(('%^@ ӑC4Qh"p pj:RjhihQPiPAllffc31͐!b|pzkfꥋ%oc9N`)R:j\9oxKc|gۑ$q G1N.ο…ԓl˘8pMkA"?GDq=a Z@xxb3٩XiF KD64jqr 1N['bGƞ#,c(c>ބpoCNƺ 5ǜ]?`Fq^V5X P-_ Ԥτ˥/_B҇Ll7o}ZVOğE>q.49S$lvvdKeg]Ɇ\ؑ[s wWÒJF|I}B͊Yz;&N5Tڏq3C.{'V=OHRRo{a_JRtr:c7{VYKPdl)wwj'kU&#^&o][(B&9g "Z[ 6%O_ uuQ1cQ%zQ3j#Swln lqSг*^Xe ͻlɂrtp9,#q{ Iܡuo50
+4ݍ]yGޚ;)wCR]6"g§MQ=q \uoANvw{"riSؗp=[jK(yR{9@{!c
+:H" hD4MsQ&8 ~+?H%)2?b<^wV3#GE6*<pȮ4mG\hׁ iK&!dMNYHAk6r 98e;^ Xiڧܓ]9I\U̝ ?yYky/?^p$o:j:;
+ vǛdd~7o|q?u9} og+'pV{ڦb"ȵmbifk;{ Ӎ7.5_KYgo^.<r5r.^K0dCqz~çjOtT"*OWb*BwSO_y}_0?/uI^Kk.+ 6-&kz{Z<bMx˷<au=
+L*Hp=6deWXXqpǠ3^QSglPd:B!eV⏌RG GZ pF5~jM?$&e1 &\ )CUΖ >6\`qX7Z?&)WB,
+<!& UL.# (gf̬Fp؉}L Rİ\
+~NzQ6Tmqs_J?:P~t>@[}N{_ ]9zzKy۠m[:$^"g^ ? vSΠ
+fg vaMbF `z U
+IřK1V>^F`1 EۄJzɚ] |gk#}Eke;Њ xtd,ѯڝ3Śmse;#
+UTsFla/Bגy%c`sÎk;iϚ\ڶr]buKЕa܏yURv `|82;ڝh'<#|piO
+r_n)PQGw5Ϊsnl&NFQ>JK[h
+
+mxLD٧Lo=w|&etgwHmK(~_qxШ77}Rޮ
+6]&J.:SʲK/#UX*W&˛9V~~{#^P$eG:뙹-ܞ^)=tJM T 8{^7' ֥N+ꭥ|_E*ԴҲ E#_feE9FfV{ /5'Uo 81?ӖFu.G"㳁)0%
+> 1Ce+N53Md:O|CڟA-'q2sXOP[RgzN$o2V8RrV2{i@OY{'uxgQ+kҌ"$W?.h<ӻUJwn)Eג΍6pK&c8[s,0e3J7v?g޿MƋ,N|fE
+4ō5 ;$m U&҇zh]~y*{PB ):+_OMc1\F ) {ge(4c&8I6&b'R"u&"ߜA#p3 Hq*A)mh<SGX
+DF@ȑIbp2%F;NEzl_n1B߷O{v|2m/;+B-兔5g?_8];O?2ew9H-mQ~Kk\? 96{ڜ3W){d~&YKkԜƯϵVkt땼͢ %yFiuV}` /< 7lvg~%-'GniZb~=i_|tͣ{,lfq겇dž6yZ~yΥ۾aƝ /|^٥};`SKQgM3J]9ZL;a1R7<ıbLԀ*b*Fp`| 6wXF&ݨO5)Pt` i+S~VJɡ#U8ט>z'+RZRHao %W!fd噬zЧ±m&K-q~{Q2šX#ba;fyv4[ߑ$n! b|;r^Q574(t/p%Wy/qIb!YqV)iV"2 %lCբBРNӢ@2vԎI}&}JCNkb8EevjnA>`n\$"voY}鵺ǻU2>,xef/}Azy ]a*8!bt[@.[~3w-2AϘgǶ<WW`:{0@k`moQZsǯdsc} b7m~o0י}V_*)…]16KDCPgg !iK(93>٭҆86"ˮD ll{# x~ȃA\ FgC"t.Ԃ5t`Ym2Gcc-p9iƐ:Dm`0b`ƮdAIxYݠ@_d EXIeXԆ7 suqKyB:xyYyy=tšO+|K}x6 Ihxw4sBwtEf::MQS (]ϲh6eZVXgc:֐G@&c2DEf;1)?uОQ_ht>Mi3^h|H/Ծ䧽>'(Ow+wv ݛ>w`ܗ`8tS}a"j턓h
+7̔jkʴ;#WnB(3
+G̴ؑ8s&
+rqbO|8o&uiZ!T.y D0E1/q+mV
+yx0ooœTlnXʰ,3\rG̕w:
+-l1؍{8~MλM&;輍[wGF^g#[
+mDOEyWa_5}U"`s[T<8i_poNoX糓 wdGIp>  FTsLsRrxUJf^]E&,,_J0
+d)>J)!&@ndn3ȑ3 bXN*f#8\Z"6`:Zi4QSA..4l]dAMk^_=㘩䵈Sw(
+=݇D`Mu ѡfK>8~ۋJ޲7]:<d&*2ƪ=r߹og_;ُ:guys:%[ Tg?Bj_]1<l'E1iℴNq,9CGnmJJm$ۤ6Y"V)EeDӷ[fRP
+Iaī.&iM SDb;4qqÁNL3%RFԸDy;68I;!JȺp(y6h B9\!'d)T$DE1(>eЇGCP}qW
+q
+avn2v~}fX"&9(<=|sw~5WЁ2Xh9JH}<W %u7FsA
+ U2x̺L||]xIf]#}hXiMᮺڡ0_ *U0OxĶ~r@7`AjEiTAߡjU&`pOL|x7M?X_w^B:X/edzA9]`E}%@;D@Bbuؙδvv:N]z(gB1g
+Yf5⭚ ]C+sXvY.ޙϴ(s6MA1>w, ~ߙR;ٞ]=ґwԄ|Z/*\ BaN ^8t=spt¶
+耨wϦNjX@iWeCv|C<m8UJw0n
+ ބW@7I;1o; O3FzR=ȳZD/pr)lԒS
+ Ɓ.LhODTJ/eǙ (j' $(4w7
+gɘ)S"~F@{Md>Ir)3x]HH8R *;Ҫ+W&^k+ @2m6{~CuyE$}NMy!1w~8~'l-F
+")CՎKOI$mq;VVV,
+#+:pEq$֢2<@[d."AD3VԵ`&
+" nSj?
+T%=xJ6 ~š>z;$5Anr>(3tpf`ؗ?8>ٺ⸄>~(琌=xG-=(͘1
+?.1_
+͎<ڄ*3ՉOS]揱Ofhl/O,W; hI` J]?:íw0*,=^¥g>|ӫA5?V` R iކ~gFx
+pcrąobT0{RcCF-G̲#Qn YJ;:Mhh3 3FD)#oJS\^eUXlMBUǶHP^IS-pRrBH >2O䍌FV>K ~8)icQkQՀ{bHcl@'#Td8^TVwPx;z]#>Z'$zʸ `5Nuݯ4k-ZY3{VTـ%P6&@qRή8ϒt*)R9
+B&fre
+& K$VuN0@fI؄kK
+/ep" cL4UUdɳ<,s7b/Y,-7D]KS8cU}膙{GϬ/L5~5 ezfw7qYa<:QRь3lLĞ=mHDψ/^ehܧ.PRȄ>] aH&tcIӔ%TNc)2QSJPc@ v\A6/JKW;͌@[_X.󠶎;$  ؀C1-
+2@;{ov3߯SLRdv+*.CNɻ i!v<&CBj)Y^rK>~@K% j)
+>8ߘ>.{r>㷨 s'KbR?,!ӡ4_n@qSs~|տ *ܼzn].?goW4_)J>l!+HS*`Cet/&|M[^{H떋7ldXdE
+
+ wl
+*G$nɛru{JҲҟdQIz 7)=
+_ NoJoRA3Io%$g6<w2"X%ѩ4]1G/">J͟.trVGI16L^"o%0RMힼV5wȟ7}Kl=8f%2ރ`:8dpC
+-"v%2ݳ;m5(@Ir0c εJw06T; v ^s+wŶ{-
+ɤCRHҎ cօ_J؛ Н\Ldlpb\f#~_8r~}=k[fnn$*g#jg$'L8eZ6DMr_9&'hwq;oGM/y~'InXA$v{LgLF'{K| ,bLiPSY#(-mIH@V-
+*.cYm8tcu556Y
+z۽4ɷ0дs0hwcٵмD=s^WO/<;"kzH2 $Ezbz
+vK5= yf|A߽yKz)xv 7
+;h,qcF~ksfjf|:!1 #;DA 5//!u2,ĥsfxps"\J
+昲S<kj! IKI_v^9V?] rNoyz+|گ|fO)?;~OWnGӏjF'֋gGSGU!)e(rR @͵~^QccnlTE}DDg)-oOwKi]4LN(d)$ H}dJ<a
+ӖK__~&3YBgҎ|~;hVov@'޻/:X<3Ѭ/qlH}OKk~d//٢oj.P /Y@sKeN%L FN/Z|'def[ʼ_ӳ~Sz@(Y&l~O
+^턚gf]s۶e^p_@|
+M-խ~IRz@R `QI,t/<ďd[ Ea(Zq<M#FQh7 ӗJ쒧%ugx4#tt{ᳪⱺ/X3B_ڢsxM4u<覴'ە.*dQxH<o}*ɘ8q?yLEA r=[
+scƶhIAS"?< &1I2QAC9'߮n]@(j3;#M;.!0pATk]R!;VpXV2ܻe
+;aPͺ@#F
+DEijԹLҜ:^5E@@D$q%+]\PD9=y|χt"n %RX%AjE
+D0(2{JEp /*y i<-vLH<(o%^6bCc0l*,Gikr9Z>V&k>E
+"2^CԷbڸ;ȋ>S3yN".աjn6q^aOZLg1yN匟zhN]i@&e =YjD\R;yI ӦvMc/KX>ɾ>ka9!BtXM
+c !S
+.#N>,/%g+JH+?,&nSzTVH9|N̮&fq&.^,,srm.T`3Tĩ/K̩/Jzr s\wDSͭ/MV
+QVZ(#g2uL
+q[Mw8Mi*>L,|3O4G^u~W۸S*~)(9
+Q<[<Hc bk!CSOwӗ?]iy߹tnH@GN,
+9F7-E%*}mqa-3O-*yLZKU$e$SU"<VDSIz!@mW)d]SMB:QJȜҤN>Bt/ܾKP䦗VL<P6\|]3!VBwcj?~9BB
+t7/[AMVM(`B7L0Z^؛>pu[;˦ 
+}gIJ}gcǣޏ&oJ#7֜ƒ3#?y+M( _)-
+Mư! aq XZO#>EJws4G|k k:_Uyt
+>L0[ä }k[ӦlV`X۶6m̳B9{&5>x2ES<l0[X͟O@~<;( wtVH? 8sGS~! A~<Yh^Ek .%Pc{$ޒ܁!C`saOFB0v0BtU\E1<<& <{v>y\F_gJ̥^AȥrKqDfvl-^b2ke6q4}מ+ V->Q3%xVlڅ6!ZIm/"]%:3׽aϗ9}1Զb Y^,/ d r+|/M](<3<۟їglI*OƸԗ:V3?`P%O)I^*O9DբH հPmDnئ"U42nKa_WVvF'baʙ^uFy4=;EP{ƔAaU0}H捖
+}Y*:D'HG1ÍQmP,1$ c `z>96O9P9T>\>"<5\ MWrk@Se+iCkKZ8״;ʪڞjT;Q
+,
+:~M\;B3`Ό܍AΘ;Aw[s/*&ʝR{2V9DNЂg<k^Z"8{mlu 5NɳRĹ:z$cwWMϕ)Qհ*¬mZŚ[L}oIj_puX<iP^Oc_QFAuɖ7x`@;p`AY#MV;-޹_:V>HEPns3)˨6TN%vYoUt/,c9S?)$O1gZR
+]7RQMcֆvuGv^B4o yA)+Q/:E"b%jT7q~I/:I,ј!u5$quyO ٚBr6p> tR/;QK*z ^1Y%e8^T c9Jf1\C`hddH%eh I9gU--&]V?ST拊ْV,+/`dӫ)i
+.OZU[ȓ
+aI TL'YUEc+RSE$ pl i_r>GŠPGBz)'|fe-銩9'_P;7/Xv#A5Q!.f芢4T|Evm^?{}1~؍;xMD>t{-z0UeM$,f 훫X]4))rbX.󨦮4d "KšH IH bu@jǢSk{vzua㎀ %l$
+.&Y2Oa7Zۚ:#-  _;Nj"qkqd^m8$_jC^7 ݭ!^~%i ߉ ݧadHPfM``D$@-4N
+iŇ ΀-B:!n>l0ŗ`|o4[(B {P]ah@x
+ B[Ldf?t&j9O%\r_NOe釐D
+KbYAC853DweQnC@+Gg<҄%ts4]P!(9v4gجgJB\fȌ°t^ih& }uQpnO!ǡ»]w#y9rn-18EؓܲHZ'3<I` .VDMbFPyᴎ
+,9.8:iŎW0=Lr3W|)zGR^iE(ZG)M_?WsM9P"{+[Z}zqz =So#N K I#e҉<ZNjtՉLxKi8h47F1+85p
+o[-[ &5VE&2ϴaKvU昶ɼ.yFrVָLTHe8,{57o
+
+uaI]bڐWjl-Hu9d]i[m<HYj_:bZI+-V/:-O Spfi0LCDs"}z=RG<0JE J!$1PBE@,mĮ"ұR'@ бD% (#=@Ý>g}~|(_n/}*+x#tJ>cRW}a vaؐ6![-[6@4c-HO5P (u}*Y9]]9*-رz@p \ R
+$Z)
+`8V+, a J ~y;n8\OCb[t{fƅC/%FLs7?<},w\uC]y!<u>L3?t|r%mOْЙfyՌ{MUhԹfl E+`\4,e%jJht_ZIk ?+}^ZY[92>-
+h&nod|dC N`Lm^9nlt~@gMm?3|g+LN,%htSh)| n ̠5 [ fu0j 14ZEGjLӆӺZ-
+fI Pn^EMTcVN QFs: X/$b֪Q:t_[٨nӸbi"-lR<^%fo5guE ژ6SY&r1?^'ۿǽ{6=bޟ㶷;OiH${KNx3Rw=yUeKT֥KrG$_-<I+9u?3I7]K9ys<{}']JH MO&\HN#) nwMw1_ByR{xukD
+_>ڤ Z A/A(r t L >L
+] o4^B|bP=||-#Z3[=C/BЦ"rHc3Й( 4
+\܂75}BX>=p]-7 ; qUX笣=\&>H[!!SdO`/>RRpscXc6%>_(
+^&1MOċx }N̛{ͼo~%ǤO:c/V]1pEd
+ǫsA-9ғq }/s1:- εӖ%>4D)eta$C\z IM܌S`^L|!Mw;J1܅F\V5v!iX o9z2j8ړlGaY`4'C ZE8mBAhdF0$g8QP1)EFF$Qa9$Bs%&tދ3@R"e9y6Ũⶻ IN+v]ǽkwI[Կܕ`hq#ZRg
+=2/֜'kNOѵT
+8Ak_oo[p`
+FMNv1ؚ8tgQ?H\^_+|9??E OSry_|v+Rp݋]Wz*1AIs}^h0뻠}z0ZANA欝 ^3 |
+{҈F룼Ԭu +*{4r2Lߌ 26gu
+~r}i_`^kWKK(iEhxzs7ޛv1yU8;(5S[myi Cy~JPG3ǘ'VbRuY .l-):fv|NЏ3nsl+wssc9pm_iYa;ύA{/4>_c\5C3۱9˜ݖ{Q;Ɉ5]!(Bj'!T h&7QFQ08$%7`W3wq9(F` (@&UAFjI lj/ Ih-$ߢ m nFj(Aq<L};%w;LU.vJ6<PTԨ
+70k
+%Wrpi=UWߍ[m(
+Af) Iy5&?UG'K FM0>Ԫ`_bG#?_y>,T K7{(>'ƃFF*[*E>j>EOQKk?D:־pri>x[,Rf&Y ̖^oC-L蝰Ze}^5Wi3S X;^Fvs'r7nb75qMZoBܗTL0O5ADSI
+ܸ=y^k_ ܓr[ڷrOS*xӻ^~'y A.EGKߕ9K>] /+!OG-36y,T7cq҄2
+K+)#^eԉ#XA(~6d<N\T:h|0j ChN0c*x|M*'jM-'G%Ucl- J
+>&IˏOQST1HGte.#b,
+4"DݐT`B4lh!DHB ॷ
+40)M5b<Xo V!ʬ{P`:OW5 hA Ai9e{M8z'owM[ ـ6
+݇7CurwS(߼ꔬDꞫ 2Yf|kH^G:.%<hm)h޲ŵ gp̩X*nfefb{
+:۳j5xDd '+
+'OP<FFuD: P2|;u`|uX2«?LHxp^:]Њ$t]NK1^Kt[))lĚtŊ'ρƧ"9vN\ Y>[ bK"װ"RxK 8%,+5xK$ƭ<Gƾ}g##M㔣yx-ՆnG4BUhoM(&Jo}\0 qL018wqsu6]uAn.Zx-ւk>Wc-7!M;Q`Jw;Z%_1ScYm5ha&U&5
+v7X.[;yEHW\ |(?Xl(:&"ETr ր_T"}D (-BE"Å֡<a,02Z2j-*BETaK)=e*,6`5On:Ӡ3Vk
+! K X/.Mbmꃩ>-^>Euqlx(
+R&CԻUL~YX煭oqo *_<J?='1\\O]hkH텮2LDoC,gUG36*Дl) )xcWxM_m"T<#D{"F
+.SȠI"
+˭ 湐]̠?Sꮅ w嗀ߛ/^Knt>αBh]rio]^;~"DΩt[f1ܨ-rd \\|ֈZS\3[t:2@m^[O3}j>u"wU;8U=LԿtfhv;mW&a*M&g6%w7D;Կ-(tc}`օvphx7 y4zY7pk`r_u#{Qζ!w=4s1Btppr`#mM_.ߍM1^v"
+iU] wzo gfՍ
+`IZˊܪ촁؄Ғp]1>%% RR[[p8-%-ܐV\*O\Q) >”>}]d`ImQ졋bOKB;x$KA H$)~_mXP[Db~(4[`jbjLO L<7*K
+,q*L)uv?-~HLHm4k-{gdbjUrr-bnPR#rҒn)9o=|7n^JLܿw)ZxBQ& =p}E_t]gTca=Ӕ̗;D^%^gEˣON&X@zqЌ? (hCJ$"wh Nt(@JmI"hŒ2Za>g4B hvjgy5ؠFUkU~fqdN:Z,V]Hjaf)ϕ6I6c!IQX XY Xw*:"7C kPC,sۗVI*x/lj_PW8dw`@
+lݓPESU!);*`#02"DDEhu3mBcU]l68ԣBbI(ZJQ YltrR<_}?r/y܈L5/ A' (q1w!i*Z1 MQϖr3ee1dwc/c>o.n-F?7m1" 4:!
+=r$ICh5pv/'c2/CF>Q 7iJam1򝐙]k0F~&ƪe%Jl^T7n)̠-9ƨ0l)ARs:5ZnǭIvo
+@l
+q˻m
+ٴ-3t
+xDXR8.čGO#-1@ɚ0! " \xB$2NۄL
+E#Q[GTCp_7Ս!}TўMO.[Z0H-2"_OZ9yeoz8>h~xmkuu-kʸbgvؖ4;[{-Z٤7n^IQɋyw?FWT˹s.=凉h8бa{ű=Î=wqpt{1v0sacafÇֿhnikIwYO9gEK]ˀ7,gL0|@@VPٔ`@’ @!Ĩc9c3jL[O˔ڔ((A DvUYeW@EAlsC͏{ϣ74F*` [UAWFz߷Hosp}t-
+0}k-y it:Թm!ܪ
+%] =@$= @<,HP?'&/<ڕ8a02|n$yv41a<kCT|$$_V\sO~I?x×^kHFM2%7aɺɹ3VoY<KֽOwRϵ+wn|+׫~v\-uF}LAd)Tu~ qo^2P E m-i\`:[d.c۽UaIJx{wv,be㛍p7Uѵ޽6{`m3l)0c|e\ѱ=<LLw#/FO1(AE*!}\LD5?8aW$P
+AӨu
+PDCUI0)!-n}Oo~M`J^RdSY$Q&GџA)焔\|JK&BcIiy.)QZ`r,}-f=%|.qsbgLɣ.1 gE—ZoBM:h q3
+L|)ާ
+Q2TԈpОM"GҨ)| yDL")"$i\$N9چΊlI3'xѳ%qvł]qcKcʭ#?
+vDN8F\wH ߙ;\z8=93Ua=oe9iUhBY6&EZ аm׬mX@OۢܪQV1SE{K1c88h5L m)1ށ$}5nc?zwݗ{yɞ\7"ۍ`wٝy^1`<_vW|lbGb_&*s</ <9zy[sJ\|'LmĚ$Lӏ*SWF劝䯂aKUfa_E_MUf+,Cg #q
+g'Y&4O@a0RG`3ѱ?
+l.0oMZ/\~~'r~5T bdם=߁+67(]>=CSwN\?x/^5$oJ!v?}?mf"P&
+ x)i$x~B0
+FwMW_?p>a{BMqBSuE,`YlaY)_T&_Yާ(pKdbH4 xTpҸRlB
+f+7
+2Յqkֆ9}hQ娴]$rەԯdT  %sB7=hɲed~3p}%M?w[Ӄ[x|cKBVօ$}oOzBg
+BkV0GI:AW la`fo`v`#6wۼ3a (ޮl |s,dn9ڊwi*<::ݠa4Ѭn^auW`ҌR4[IT`;kRj hQH%kT1MQ&:a@N45mq0bsH>8;"vb)m-T1Y[ίeP )
+JX92YFFs[E XZ{c$SEA骏vVQuTVLRk
+5$Z-
+HtbbNs1@{!^]'I&16tJ7 G7FF< Iz
+j𧿬gcB/ԁw͉3Z&ٍFZ:Sv ~
+Be!lIzkBLVZ;0
+ ARSlc!)iBSa4,O3Q~ydj_5:$f{J-Gzea>ixI[0 E |SE$TN5"28@Y`HIӡHՁ?+s%q5,\s/]n."(`mf]Nb*
+*`Ji*.X(y<gyyf7X3݊rgأ>7l  p-1;m0u̜,-3%M2 Xzo#$wFZm YG[[HCVcx(8?W9FO,\CwAoz6sъj PU?DN9_xO jEO26%F# sGA̵ lb`|!@c|_[r/+sw/ͅGs:& in"gr7;#3XGR7+4
+t3*r\.DOܒEtg̞<´IcYsKl~ԊQ+DX:>a3]l IzK/qvQWGͯF"'#Uzv3b&dY'PVZӀ!:k2M4-fW3A\ܐՁW?so|[y_CdxSv&|`Y#?y7绯ڧ`U
+0!!0;mSJnO.mKhS< '7{|Y9bRhTs싉ݨDO[p
+0$`
+k
+^Po|B{ A١/k30z<oq] M
+%-4 Pͅ*./]ZH.obN` YQyBԩQ<89K7qP/u&c|vMl%R'ɟn=M׋U-VRK6sx;6'sOeRPNdMUQ'8vΩ:{%ԹײN8罋i HPM:[v%<z<v:jLFoľ2kGcl?Á0' Uya2:Բ
+خr0@<HJ]B^p嶵>u?+H\ۚ"+&sEʧR)lV+[o}ֿ^eq¥R+T3 Ir q:Ύnwv;n H @HZDErffw<>''L! 0B@^.\齰j@n97#MGoG 7t +U aM7v0wּmzum{=wl
+ E&eDb K5}qu9ezA~eo#HJ_mɫoDWeT8Pvy:;> :iCee<9|4?>Jz!d<yǀ }p/ؕp̛
+#vVEUcMFْw>.ѳrud5kx+{oxCZ2_BO>.~(຺"(.YkFǞO7&Jck-Sҧlur[SB!vV:#gϦjMb+\Mc@-u- ҒsҐS=QqژZ2Ց^Q἗Tl:DٮŶ%U8$V~~% d權s!EK
+x@|)NA[&`xKw
+nܘJΞ03jJw#_r w2}tfDf>>6Klߡk'Y@"Fh,us-ƋRXRQȔN%YR P(dkH)ne![^0Hs9X:
+H \* }F<H+%Д
+*CI ixOР FBԏb{iQ"lBNSSF8%j,~7읰c?DD|OXp~Π)9820N6YɃhum~&uܚ
+sL'?pPgVVC߬ xﻼⷺy"W!Ǟj*p*
+A0w$B B,"bVq<3άeTDD0!
+^Vma@j#ڠ kpVDCL  !*nq>]_<Ɖ_ܟ7{puy>ۛ{hɻuݣg>>鬶Xfǥ ) IsG N3t0LA̍_
+Q+@[8A;a;w#;]gllUrs+kX` :01
+W5)J` U`D
+IvPPc3Bl*YF>0?|?{]>xlu^|GVwW9Ss_ptq1g^xKox&AF|rv⻬ܟNevڥNr,g[ʬMqrE
+kh ൱ڙvzȃck+-ؐfہ9;Nų<=ל6pKMhZdȳb%ZbҠȓ_[{{weIM8֪2@A?/Cna,r:3qT=ɑG
+/%JilքX,$ JdJcVDifoYa 0
+Fi:0~ugXn
+I,As"PjJx7Boϐ
+⤢ rV[Ԗ䌷Q(#gIRŏY5ua#kdz}.m SZ=v
+vaҌ V1 S"
+1*h}\0.rOTL8D6؄5Y +ufu#D`ij( @%ZAjԇzT j T] 4rDW"@pD:٤4lX: V!tjd
+"җ+tEPg. Ȗ R"l=GCx+"T&2zhhT$ʼd|q IDC @k
+lo_jGEPR{Ipr{ipB{Ep\Kyh|cYxRsfT
+ZU8Fym"՜} @85t(r#T!ult nCt
+
+WHyT'0<2Y%P"JT0":ITG"0? 0*Ln Kp&Q: 4!!jĺ8i([C u!`\ƶw{^Hq/!'
+OTG̐ȱ
+v
+V
+Fy+P+SGBEZ–HQ}`
+:enAjZOIFMT;F+bA)v'zR'N(%sW
+7}EWrJ  w&F"w(Ș4&p%M]"a^b[
+Wh9:ZB)IeF@^2#U*)bKªǨ+hB8q[Ot#4( NnnXc=]eA/*pKO|nVσ3?/ә}ȌW9'9ymGҦ['/٤灯 /N^Td ~ٕ&7Rw)']{pGRs{D̸A\u>+:LX'-WоrMiK|3BmoMR>Rf8)3 ׎w7%tMck<g7eE.[_f=.Yc]{ВZ*^$&jEQD.ǟ}})\Vؐ3y_GMg]9+DLBU@nlÄ47`eXξNuy<u,c)0#ˍB~\'Ne(+e0.rKGOW+QOnw\6۳93;=o #Q󭻆 5vjsI/I$s=g;Khx@ "\ȓ&oFc?q{ׄ "G\/</N{ *)749?$UhZǫoR\$_My{>>iAN$)Om|W+]~Dpw0s
+׿
+O
+?"ۘjTd8"Ncg$VWdEfACj)eF;=k1a]haBJH&hBVH\>o5|6Q1D&,f@XXOH'3p!,DR 6f/Hk"q"DBT4:
+q|DjPb,<UB75!#Pm-Ao!=g"y=0g^='V,5w|
+BښU͚;8,NY[bvl}qzJt\֧6 6XSg8͖TF֚)i=SJՁita-@[-\iz=FOGBu6mtGc
+5AuT{Fk;&1X45X8%dj1=fořw)
+oKC:;>(|:;Ý֮Abo-
+MyB<xv^*/}}nwPp8ȝ M@@ & x:wvFN=˻5@BRH
+!%4ODE#;;;;;957}qeeC7 ߒ_w^uT$ɤ%7懥VS$=.>tg7D.B^g"<ғ{ e(th`X!(AͰ)r-ܰ=άy
+e<4hQkܥ #{ƀ=G^7NU8<? ?g=)2v8uYst\;Mqd$s }[ol9 | *G|7~GW sP- D-yL`K绑$+J<Szs<)쒆B()<jH@O:Iz7ӛ.:|uwE&g[?2#u_q/-->Xp;r->Dnȅ>P
+#}wݰқ^Z{i<69]9{6~i>H;{+KN#}IݚJamD8*@10m9.pt&]VLsw&/5KZ(ڕot6њF L5's]~x2ף/Ih<ߝS$M)
+d)z8AWC(` ;#v 4T,MS" W X1"u
+RBdQIqܫ`KZn VxrEt[ͽ؃\[y< [9Y[EuxFb;G8#q
+W= W1S$Ek1 ^j݁X>)ebQT &[Ɋ0õ"r<lь(teԆ)iE))-PmYfg˭n銇{z\]{Ќzf<5MQeΧ232m3e:<y#ql[rٶi,?*uMSNW2ecR2[ 1JY
+yO0d\eYs+cgK,' %·˳;ŐDe HgTEg 8U$+%JaJD)J>}?@R+AV`\ cJqrj$4_K`SeQ^SZ@/3+ry5q$^D BB %I R\+躺,zyg;WwE@ @!&P("P!s|ygޙwy?zruY\
+-#$н $:1KKS_2'gSKJ^&
+BTKnR[G%hǪyq
+VBL5kjCȆP
+xܕ{O"iYsوMǧ_]%wL+J_)ңݪ"~{ j9^c]^G97+";&BwhkfW5o_6Z2z4"_zL#W>?K/=軌x(Du"$Zue^l'3$/ƹCU}vIeM<~p^ZB(&巟:𗈫swMJ8A 3r.8_rW`%<eq$uȹs-=Rc]pҼ`%WΏ~?7G4
+疧>TAu;$PiںaXA*ZO7zmjKeϕ{р >ͦO)6['},".kdo6D&hea?aaI[biv ި _t-vFu΢ <By9}<]]9fo^u統Z, ʷK}_Avq[ȓe<^ɓf>{y3iD,W`7C e y%w`pvwOf@C"1=|TLWM@Rw .a&v%^Hj$/ČNU0p'z;FfU0(lIj1`wr5*;:) JBq<V(&" |<VPGi`*jbHU7UƷ:j"?L>^j_apjSԉbT*,fQ:t4A:E"<6?JlGA$VC~A A9g=ǖ hd}4X K&U7m3FL(3\<'E6lj_
+eҾd"QtwD7ࠂhy vAՋ 0Kf6{?s"9ws$9֘eeԪl5PvuUbZV;CW–ی?
+#g_`''G˝_{ yˋi韁H2'etaYl*Ȣ ` @@@ , B
+ I3>FւVZc"ԚpVKlDְNy?ȍdϰ+b`^c@BDP-h J*`j2qU2Y^R9/T,zz?ϫh2I'<Hpj|!غ -Vt زv/bE" _Y\Ql5+eel[1b)QBU vXjl>(srG;K3Ϭ߬2̱'^'Y}
+ 0ة:&&0E"]4>c0r-ᩀA"NJQJQX R(%
+.)Y$%B/ &3 Y[ ' &A~?ms,uo#HM4UY.Va9>ޓC_f(9xrVMٔlM&[%L8NEeK@ H#бˬwܺުzJoIP$H
+bywyc_GnSW~o>B|g.)N)h*/ȯ~+S;Mݶ{?\sZ椃=8ู
+#H25 Vȝ*&R`,PSTPi,ɐ6c 7IdPi `Dp}DV(I$`
+4SRcqIl7?Nd!NV5%v񘕘۬ W& +zVO)7!G ]Ю6Î`
+G.B3wO ż;eJ 7^npѶQrbq-b3)yMW ~Iٵ~]>OINA\HhQ}Xmx9:RAa
+]^L8I5itxee>GY `u'qS]_=|i:Yv:n(ܨBAM*n>S7K9E5bɉ7j[ vL 6-G>ږݵ~
+ 5:S+?t q~V1sԙV_O?79S-6?=6A]UުޓFw<2NY$m1qn7PF1=>c_O<uO4\ \Ulp&G|$W0r-qt;sD!Ν"ń>?KL9̲}K bb;F4x5J]c <4!=VXy=&v=:\Z8Dtchb3MP `i 8;6*DF?
+||oN"[*"9;*SGm*6:"x>;JP/(tҗ-MίW{{j0^-q7{Z<)d^ѿGI|
+5Z1X&kp78vU
+Eusy@MCsll5Z$uV䜤9:!EQ mBjT@TP*Hݦnҡ,O~,zUqp(8"cr.Hn<I=E|xOY4L^{}+LN/g~c92Y$+ސ 2߸ nyW9,$ik %ƲxB/&pWAIy]?9hB$@3E[-/3S3V yI^FOsyG}\j6Qq$(
+ 3|i%Ƥ1;MFYmZc(KPPqq46{=hWsO}*L)Iu-I:9Ox0뿅Y3~8}H.+ᣤH @XqsLl#E xDO
+(*B,(ZNq0A%$08$YLe*zi_h#+g
+GM "2#6HؖʖU*`SBr`$b>V3]azYOS_lE̒؊ȵ-U+U'Bnꮛ,ך
+D|LD5xA5
+X
+Rb5
+lӄBm#] جbp&B}ށӣN+v-ٸNuQ0H"Q\|CpVsQ9CTv{fe쓎~8SܗV$b*.4hwy@AJ1ߙq+%3;>۽s/m&L>n525Y52\beaGvՉ=k|KR[uHjS 1&5qRQ"&z]/ o,]ߎ;L;-N[9@nˣ3#.^6#c<FlǬ+zK1=xf:q@Lt#r/T;)s&:@g@3| `;L4hkcj{oȐ+en[1K}b>VKepcoG3'gK e6iR5gwe &=|ֆZ휵#4L{T0h׫0{Qǿ/]ǜ󓳅3e 69XMB9fY c\6ª~2 U(^:zH}D.C6 1,2E(2$ndO8Wї]ܛ~0p^O^C砿jp3k\G}˓/L٦ϕ`& 3Ct(j$x83y4_uwaN7 ۛL~N7u#uRy\z?%_QTA
+AґU$4ʒ1|movo!8K_iɜИ.ě7 &MC]oNX
+L}\i9o_(te
+ekTfU&T[<ZzN<I0MgxXݍījCI<8KKh *p+RUpJ'Ʌ4x5+ B@?Z#
+4 0] V2 j:01MH!! Hh$,6/8m̴Ng韦?t8i;^A, $$$@ b`}5c0. =ι̽|=ӑJ]&PՉAc
+߀ $[;nӢ%m"_'4 BQh:k#):Z*TQsMfYXV
+@P-
+8ҚF*iЄj$[6fd,YnkBL!M<gBɝEr
+s1;"e5'0fQNrМ(cKA4$ ʟ*1)=`ey, lkGASSC $Yu C~\uKC>qz'eٗ1YRRQl9R0^=@Tf[>p/݈Fpcꇀ++-xUUyu>[9Re`8l:p-b*d!b:k>`E$t}*lwBi*>$$F"*FtQlUg3+ C,5bN'# đڨKs5ա9a`QXtcb^W_uexwz8qY}[Ǡ)nr=wV?+UTA# 4][6>V!U-4ZJe(
+K\*?C8^+ܠƑԈޱɱ<%fMfpһ[)֖lKkm!Zj7ou<|ۑ훸_w$
+lɡ
+N%t؁8°!(? =`3!cHKxMà{Rcg^mDŖ76+k3#ƾ$
+Z@WF#FW^Fό̏D/LG[ _
+0ͮ^3;aΨ6W+; 'uɒӱRTL+#ˉ)b|*Iz%rYW#)˽"1'Xʁl0ExX8yd"8G~%bB'kC8:Yi8ERN2@Q`&np_I@@vg TyC<HF 7HyfkluP_
+џVӋ] PKe;6!#uF׀ÆKv̡VMM[~1HF~r.3 RGK :pq/0ȋzJQiHZ=$#"(I %1` t
+= xF_n)tZ(HcAzJId&˭St2ș+Ȩ5?2
+m>ŃeyuA@x %ڄ-VX=Zd~s8Cmk tP8^:Ur#!с-l
+1x!]ڮƁ_ǵ[]:_Ugꩴ|%ZH3W쪲ЮzFcX}IQv`V) ]%\=ZѰ%AbS͵(R
+H =$$B"VQeuݻqoWݵb?C @$F $"
+4xfwg2蓼CݔAMQTZ^AjՆ<hGWQLU[΂٠l{-Vf 1=b\`m>wXe14C,P82
+lSBJ?@
+ycQdmtւڼ׋ L,fLͶ[mJ>$5*!<At̐<He&)b}jWv!hh
+h['kMOӧ%*B84@壄Ħj$IDDAbL(GΖKz${v/ٕ:dz#ޏ:{}g߷/לr9t, Rqek+{bOA<eD4PCROAG:Htu]I;Y+^pГUSʯ2OsBH2^,}}`)ֳۃw!} WFK>)@rSzX.ȟDTۦ\t&M,Rg?e!,#_</jz#vV=V
+.s<|Q'$+{G,{G SBaZG]{ޖ|)vk=ot-U:<yțg9צ/ܙ:c|6͂xd+ `h6SyVGg[l,R)7#}?ϵ8mynw]?;nwwܭԿJay6S_*Ky_+tdzY^v p'y͸Ki_dBȪ2h8",Pb3? Ʉ(a͢`D,!>8u/Q]Chxc;x^._Z\S/- K҅F!@QŴ YQPr C
+:,Q^(g$ǵa1m0 +mB
+W kbU J"#'BW#J./&/w>l\ۊۨ5 Vџ[P"=d%l/>fҒ2Uf7Vl4Lߛ8P?a%^qqs<;'fo<k }UN¾HIHY
+! VӶjhZ{!+YH5Ț"Gq3sq~
+m.
+?Q.飕Yo<jk{
+X
+An_Ȏ[C/j/T^F꺎ZI犹Dp.!׃tb#8"7{+y/f>1}N]znΒ'/ff滾
+Ϸ;Z춅-"z\b zjp6:jcAؕjoTɸhZ3;Jk)CPY*L%e+! 5PYi Lj!Hmx|(Gƅ3}|}Д%ljdҺa5$rkl$=Pz[]<]x $"G#p2lR TJ\%9ej5UUY9u4&AgrDlE.BZ[ZZ%Qb%!x<-~>ui"%,Vƾqb|:Q6C:6SH x̻⦅?Pudi^𭍟+RCR2 Bsd<_D D)(@FX%4 ;5n'#J0Tq$l ЅE'pyBaR,m
+E`x0鎌 0Ov@CY-׭&7¬7B-5Cm"Tp"bQ9/JBEQҙi T訋f9|Qȹao_@s&\%@1BV@֟?X KM+ͷ{l6w\_wp}y/h}ih}X8c ]w\0imPVڕ$ ͂C$1zYO^-^>tYUP3AwxMxxN~^:WG9`t
+&r4`Pg<hؼ@oKk2B¤pAL*cgk
+! Q/ >WDc!H da!T'>JUVT}wj3xMrΧqG}*cseg's?1;ĕrpl k!EJsCtqaE A@M-$^ vDݽcGE9n-.I/ `(A+ bw}wy>->zrou!$hj:9
+bHGgnjK$$-/LVBqUwp'jdvrc|s&onh3ioUKnv+;˂ [s8%.ݔJOb]xp"7pSoOZ Gxr!NYXqOfp8' VsOA'3[ rm3mR^=WP8*?a}#bm,`\kEYZW$o6e={Ύn?cx_1s}r=1Cߙ~t4{|iKxǕO{>ΟumK`?uI56 u;L]=1}3ԁTl[L-9:(ONiH0jWC$U+"hU.IJӶDʰ5:-%ua0ˇt(`)7 hkbN2ȯtU%:U->Gkj:Ra`vw ]MzZzT` ףөzTA
+1Irn)aR
+&7QN4J=&;I
+/,ܰ^(
+}[g=
+JgTq+*k2k_W@Kò
+qs똜z>k 8FC7
+ )KAGo@`;l`E:kmHu^AA 壖 WgL@}V +& #e"XG'ް 6 siJEm$-g\Ws%ϖE {i/Sms<d%cXaR YҝўޑJy:L{N)$w`{KBqS#Fo=<,M
+3c4wJߤ{AbІDk Z_#.eISS Y3 .!<h,|V$DZoW.oaF|J 'IojGuup BC
+Ba#pš#A!|ShwNwڭ:h^~Q2*Toj}Bvuw5)C6A˃y WY9wLOr
+R'q"abV*`!Ae4Ql6<U\,-WM%~~COn/{=ӻw'g#YHHT»(ਗŐٿ%?pߠ/$43NO ]E2 3t$\y]<Xm^bb*0m]ۺ]~Z
+_$;`Z3*Ll)w
+X/XGr8(탱 s6OǏ[OQ/s%OA=S1QL>qϸ_؞ZHN#5Գ?Oޏ3`y#?< ;hD9v> .=ZƌH_oȋ+ ?LN#|V| P6w<kov
+v*g:}ؕar 'wc/t̽;D; =$a)GBnP$\-O
+ݯ- _:].WA_{1=ѝD'~fc>+yXf9ZOd3S6?dw& >e~YxOFķM~ɰh!Iv5B VOx7@'s R
+tƬю^ԋ_)1?"|aqw_x>qW϶ǮA&COfY\ߖe`V[|SZZZhdWrzFkb
+H"Y4hs wzѝQ4p u@s\܆ܝ(1pf:M0a¿lB׺t7ڴ-@TB* f|X:K, :K9/a\ǎgOم)bDn;@q'֦
+BIZ~ǺuR/-J[}hQ.Suŕ20S.XFM6F-$-6v5?Ъ]5V}S)|hQ.2W W@YiDVC Sd
+DdqO#cy*~b9`w`&X 4MDurPX*
+3 TZDMb
+vC"!)*ڣڢzsss<<s^ќj[?/Lэq4~J)Q fD eBI 8i/iY8
+}nRϻN*=~_ނ^>X%gcq1̬8ݖS:YhtmlәBqZ<Y9g#J!g9#cs2Y&UZ<N PoyTcZ=^%]^"W!ONr9Q']s8'EI٤nNsu0\S5я^{3hCL]&
+8f1FַH
+`Z>Q=D0LS-ۉցwidаXW&S'b&BaNŽbE-FKx j='2o'2itNueK;R_41<h|c[Ox4u8w0M -u͌cX`Caѽ<t]ۧ*OLVzv;(VApv YOpaYMqaK]JqӒaqUweo*sjĺSq{ad@d;.[q |5Yky]Mմu2n{Gѣy6-qUHbG)&!.+DžԒZ b8FE}٨3 3질ްNc'D5y;s-"Uy/[_de4-.((}^<yUN>_U,JjmN*T_ )
+z}B.tp lt ;Fם,nH8數(k{+.3fU&ơ"[#
+/?3b10iT/eԍ8[W(nf>ʰoN= WA'7$!+l>:ڮejS.re'|7ͯk(4Bv۠X(ѩ_iwO=@~L*
+Tw7=0TKQg~W 2}G5
+ Z2ԭƐqަd^___lD V
+pp90O/\3vcB uqC *PIjaWݕklaÔ֐DZŤAGPV$O1 2҅J60ơ$0:ԛ>C]"ZaYzp^Gƞs˲Wt%oz/sꣲǪ ƞ^.1=<k'bo%yR$
+NF-Ќ-O%OpߥrH>tN9luM䒵>GRyeތk@sjay 5y:Xβ$v:לӻpٴNm;eEK3aE@ fa
+dO;k^zY6 HiT8T }_,j`59"O>5< UZ`A#K+Fc?5=F GQ13!Bp_7a$oN6 C0y#ײwkY
+;Ohq=24uJ<:mևn|S<O- 6?+^w[~KVNTΤ Nclf+TVBQIXu?)ZE='we~U\+\uWyGvUd^3:j%5V8HpT@Wi*K'pT,NoMNi }RIщݾ;yW4m_:o88"{QEښ$<vcC/$OME/,;/م8zC=~e=
+L%P[6iK-& T<CvVuV*  J"szY$
+S8Qͷ* 5_e.:3m 1F,-]XV!̆SIOh'ҫ\id t.Pi5Բԕ$>  5BG#[xzmvXɒl@tI
+'0sBL5(4a7/voL%7k~d^P4\A0-ib͕'17F՟Oz՝ڮ+f^a
+ B+ JQ)F C ͐Tu(3 gEq!+dk$yue]7ά:s:|gl8m [֔
+"@HH H!!y>@Y<O=J ׈H B Ɲfwvfwv/\_2)*))ywcO[SÊߒK4Pup >3fk(i`9>QQ 0)Fxq!/H`<>S|]g S-Voc"@Y1(5\Wo1E*m|Z<s&uPz2]:_=Wt\iʖ2΀PEf$u>+C'vn>wE"a@A(y;n1˥>Pi8/ek1i͗ rz ]yrq,1\;+;lC=[lۭX)M-%`7~]M^As60.v b{sXبN7"
+Ht"4ka:<Gt H՝t $j|y1p:BĖs^.apTYcWOEɎC WlOx}
+&K-YUC_;n㯽ʌx}z&&우VJ@Ik_qәy;kE+켳M=_ٲNOǏ\ + B; h&/WSo'cmPN<aV.4Q/6Q}
+\sN9 $!<Ag@Hx8"w&w.CI.BrІ`w,mݳ[KsQ?3<3IuUods3ww!4_h5W1~qܓt_x6kLP"4]~~ǢŎwa :+-FUuMͻvjm},pilw٦ 0VhzL^DT0!8jDGVF 4 h0a{FVzFtW';C`㼗xKx 7 N9
+@e( Eё>ӍW-sK-t2P
+$a2#U/d!…lDqTЈsX~'ڛׅt |ow`o†],T4fmBԍ&M \`f
+K.FDf@cװ|T"0$kt;q5&r jR6M.*mZvv#8۰۽wֶoy!za*MVEAieTuk"p *Z TZFG[vαT5p@󑳕i%iҚ-|NScGs{WΎ5go>+G>6@'͈R ADP8
+u\w12vܑ,.GUZ۰F۠F  eY
+(yeLYQfmɲ2SL1g{
+ifcȁk9݈$67
+F::)U$Pn !1 q&0 YzULcb^( `>7Rj<:S3J AUiWPՍBXF8i9u.A)4Y.u$u$.Igy48S?Aw /i4M<77'q>&QX (%zBTSf޳p
+#̈2Yh?gCA4GRS@1*%:|9&m OSx R$UDC
+@ Q\5ZDN1˴$-YMZ(u´۷!%z@%61"8UR
+Сѣ {8 "e9\aC(~˾Oz\w-YIhn?b䍜麏ƒ!%7Ko'2[ 5VΘ!km۟UGgfrRh-qt j' Q~V|pU]h8.0%`ݥ%f/@k$K*}+_ i ֵUחٮVfWm\2wP$\ZP@5RӫYY9{3?go>!`|5X
+(hNs耖.KWvI QR,ˋ.l&nQ9_d:odc02e$<gd3f䮩2͈B6+b؝"L#, ^ƴ|w`osǞZF(,[3hAXhE԰gkTWPEs=zُQ s6lX@@?&DɁK*K=""y |$@4
+RfRͧsZZk8yzù }lQcg6< q۫cB3LmPk51*;Uў߻Rs_H<w;TIWȇ8}y\Rdw) c˷ۮ[{([`h9bEO{aZn)`oO
+xXɒ;?c&
+7D}.=Q KQ*s$ =S!v񙉻V) [mlEC;jjfVl61Ⱥe!m|=k<1 *jlDGg:5!o=-p5r'Vufj|B@0`
+ofyP?F=eG^YӼ/𪬟ۜoيNYtښћOW$kW-e}%(:} q_^&3KTzOfqQfwVws󴑋ꝅߘ֗qՊkїS%?80=6)>̋%Կ)_sӮıHAe??纠ee`jCOy?[x wy>0 O/L V{n֯;:\u[^Oҿݮ``EOgC'GlnL?Oq dQb֦^T\\1i̘[ gvn:uH&5dSV yl?gDg<,RqLIhec7 ONeZ]b:x(CU>Eޓ088.ѪbU]gǟ]
+]<LdG2Qbw KicHJr+c'`
+$$ 5Ҁ
+T@9W)$u7 {՛[g{{7$xt%zt%l|>~]Rš%Ҫ=+Gb&@"ϴ4S+`Z;"]~Dù:a
+a %L+H&S@1fD(
+4"2-Hc`2cB51˞z8m$/bO̓1m"_Y`AfY cHd[zG2!UQ5WB^0\E3 >;^=/= |6OW-:`(CPb-݄)1!uH]#UхjD2 u!tV
+*ù@
+
+e86>$O0t@]`Gk0cĂ0NDyN'df[1)'dS?I׍LQC㔝pt`_/+U㗨҉raCs`G{>m7COL<MVY9ZyzUsQKk&wioȑixoL$McvH3YGI݂t*zK<P
+nL8Hȅ(9_ׇW^W)ykk"c< 2qDFe
+:Ä" ˇ͆@ 6M }JRE&tDgGf"Żhn??/a1_'R_S*!Jc-QK1竹+qQ郵ǂ~).&6'S
+ +!;5Zў֢~jUFB$@0  aGUyLiei8n7N;\y?F~t2|Z9죞C7Fl=19m!lJSֳnβ8>{u]n 9_߄F\ ZCƍB/iD15M\ojKSXkQ*zb |Upu
+[5
+.zhYm\N{^7#;+qA=1}o ~瞩9~N{UVvĺ+0SQs$sC֞[u/ ՞ _F{͖;gov_8Di}+h SO;>r&co?ygvwpCi:GoZoZa.` B^+|2ykLG,Cgғz Cö7~ |v
+PiQ#q&k4 ^'Sm$GؗReXXST**Mrf_a+kWք*!=M&rhW!F',h(X֨KӥHؒ6SaIxU\Pl^ot]?*օ~PlXo^)lacC4~lh\d xkZ?C{>C5#OM6 "OlV{%nѪJ,GQK=)G|1 9_5Y>W-jNf]c
+dX'OmED]1?!Ofʿ!NiBT؋3I"HRx52fP1 jJn1Qk*JTP #y OPx} qN+ۈD" 8 |m-uTbG-uj 4EHVoGt!Nf؞i{q[Ng?v)L\ϲ }>=1=c~GzrqJ?C# ďyD8*AǵL,D%rR9I=\OVW!&Wrg7ozgOz70
+( FNIC2w'* S iڴ1)Df
+XcE6.9
+}bgK-xbw`3cHL{FQHm`u%7vW@ssg]0ݬd!Z6m`#g.,]7w6
+
+~HrK$!v;}:|Rspj$
+m9۳q62ӌܝͼ=q/+HcuFV ~0=3l浅elo4}3b0ݏtя~8]\;ۆ~Gjv%4
+xA !.@1)b1Q!$$>5xlMy4VE5#
+ᜥ3YC'++1aE:] I!.fQ5)zj}i9O`U2+Jr Z!?eaLƾ$$@
+I ;DE=:c:hjZMք
+A’
+_=w{Ϲ{D,^Wa 0
+`1!Ʋ:pTCuXdm]$}hXB Eѣ@Oڐ?V.ӚWDB[@/K"vq;کa3k<=gjOKQ>fO|_.ʂ#vg!4ž/p}3)luyv`&JI .ڎ?ޡ՘'8v ˰tAA
+oriFMڸ 8ArTjhW:N!WM:]%8ͱwPωCpf~eu_
+' 7cq}k۽Fn8+]TS#bu 72Za">Ư۝U=p:})zbf=_[p~EtSs6#A5+A&mK&m>1g.'@X5T1X~oe0 !F*zLԞ:V蘠hax|j Dz0xAw(ҋ/WgbOwbW6̮gg~:swd3s_֔C_{P 5ne-o\y9q(KZ p>~YKDdw ?Ht1[`\F{m`kqi O t`KW ^6vvrGN~x;ƕ\"[K.JHC,{n椖u6t o/-@;wm1ػOH='Gʈ+E䰓-
+M6%e^\DqcJp^ge{n?p$Ba[_~gonS~wvq|/% =cj@[}Rr;=1o/߸?zOr{ExL@[(Α; .9м$l94~%;x =hcIɒ|#fa(5C{iI?Efaϧ~wqG5H%X,*(Y IBfTOL^ }np7_}6um;ot
+5
+T (& eC\z0p2h,dzA١ݡ
+
+nZ
+EAd$ǞgХF54t`65YtP6t9Zr@
+
+?
+P^6B 9>%Fק6e爮?D^KZ- ]<4:gFFPZ$iݹ'2ϑyRN@c] 5fBxWiv.o@s|^$@hhXǯ}J^7/*Se^d}KeӾ+2>ZbL-Y;;fVoPieP
+l>V~sR;}g Se
+w%G{_#fHL
+]^)QЯxIزD|'"2!}d,2"X,b<
+*BgK<Z2%,3,039Ńa%5.ؑ*|۝WW:81@T+-ܟ2}_=K]y'i3AܖY73
+yǜY2زQÏ.fǻ-}&{M nI7MB 7Zz|}.ZUR+hOo7'OExcj<}L/bW_bwJɝtԎ€Ԗj=TJ"58TYC""YL/#IB Q!ll{kUӁѦ\~խ-ѡ p/-`3O?ǐǹ';ÿ8x}o-Yw
+~)?k+eY??zt3 g/Iڼ ;@MM?\FRrCn*HxHdWseWO5>N- # 92CC^]++6&1x8KD>/L;e'J(p[ܝ6
+ȭ°]z e0ϣ{\
+TU"i^C6ݫbxmbw`j* 7<27֊3ct
+y6EED
+v:x%i"OC'_?%>Z"W _:o:1}O#[zڭ^YȳF{ |MF1uqMQ$#IJ}z }X`@= ,EM{Iּ͞U ƥ"Sa՜˹gFer6O8ou݀uIZok6߯fL33TX &=LTsZ8s<;HHS,MhɐItdp O%(1uw\3"Mu68mBN 2Cfӌ"UCb2h-$Pv vU咇AC1٫ıdzGh 49qiKO5^%ī4 'TEG:{? ɋiXե(h[I2 B;Iw>ܰ_wM6+ppXťtq~M1f +a=%a<pW~lWݪ"qC'gp;`/1'<l`Kxr܀jM1$W@5#j +e!_Wk+ajKv}yeȊ"L  8b&hq }C8newL_&g=y^g4Gㄷ=ߙY9l,8J)M<jQLksZ5t@lV
+2}ה_7 ڿ5]0S\ݦ<7+fm"hRAX7
+: -Q9F0܊g2pZ חO?&tf?Vރ]^4wQIIňh!a7ȳ ?͑?"^S)d?n)67ZߠU-jbˆf_ ='>\U2ݷ;OXNn6&aa<Z'|-ݪ9yZ? ]ʳJ>+=G>x{Sn?3o9~隫-WCry5<
+RHB%I"% Zfݹ;o,y{z`hBB&m -T -(+p/wwoowtSUMm]qa#>!%{bX{bOcb!GNJ/ܐ<lEU~tЄ26%xh&qj`1#u 5=i݃#6 KWw[넿H¿y=8sR0u^W/X6=2/Vkc!ϸ nONCA?}25qk6‰&#$rwOmݡWMŷN&30􂫋ziYvoCM6f GK9[4ؿ7,P'E7/l"V`v_')"zCrc[qi9I MI}-#^apDq%4"I>???P^!V 2;/oy&~MvDĝC[]0Q[[ [M+escrfa??➿Ytz};fm9MYAyB8uqđcGL7w|8`7v8 0X}13LN㗜<]tIm[9g3o5tk>G }rG#]Rkȭ;ȋ%ȼ_F,BσWe,rdu熱zrI,anHqoCK̐^fg=gB~{]{pAel'1^23&~!sgȑFo?aM\| uu~@ikڄ֚{!F&Ll߯:Wg;?\!#JgE3ώP7yoJ|x}W AATP{*cGG9ѫOVeB~q]rU/ I+1"e7^LLKf(~DHu+e4
+c,<}пG,dɜ.QTUUXDC˹ Yg
+oe4OV&ʞcS</%ere>g$|ϊKsBMT2%YW“1Q+xו6YJUq)T%PLp 'W4u"#=аE#y#/XCk|zu+ek=ao:F鴈cF
+1YRVzfN`? ]3Ex 4v2z:f XYj3GڜbtΧM K-Nq+V@mu4
+`3Rwԃ)+Áa3<<U,A<HHnB%LRRסSgjZ E[U9e4}ձ9}X@k?pNl^g3R]ܒ\`ɚZ8ezWK>kmϘ-gʁyqP%EUԢzIIz4I7]^Tr1iST=g+UAPt=\ڂiM5cE1΀hQw@HoxUٸ̑2_`eHZ?7>Py2}d
+02
+x&S 9^RM&WW&$VՐDJg ^=De%io/CS>/A>ᜋpvjYU=A~ zzH3kD
+A¼;Fqanedjlϻ![nb\l!%$⪌R!.aRAhB?GƐ r
+-_%br~$?;ż#|z/;BjlG*XuDqV?W|}4>k(ΣCJ5ʳOЫ@+{1(߯_Duh\oƳi`?2^ی~ܵ
+ksh[qbT木Gr*zqK g&~w;nx g܄n)]Pw㈭Q 1 h#/f~y|s+gxrfXm7Ds\Å8Ɨ杋A۵}>Zuj\og6bk9j/am;O<Aup>_6\? w+iG`d]ƐNaq6>*Ii/7g 5j茆hvcadf':ȔȄRiI. UbX
+ yWc^#mv;b8e3;挜4H1'n5^:xǁ5]g gHk.F?|#?쬼"_US/KVAD\頺]yg\zJJgFZCA8أj]R<k'07{Aϑeq!̠ά`NGv8홸ti=qbϲDp1zp6zSԢڑT
+x|+ޮdú5{ȬɲL ڋz$mW6_ ߯B)z/_Lq/a;N݋Fv}5Y9{lƀn3k3İz`k`-bs뙱+v
+lX enY~(f0*,>l(z~T$- 0#hR
+lu1
+Xo ,kPb2U`
+`<
+!epCCvUAY<8PBO8c^g -
+#"^݇MG/Ô_%
+BT6@]&۠z)U>؍\E!()J=)Q=?eԁj+!bȖ6Ʉ=Nl%5Fۇxk=fDٌXa .e9QRL`H>ŲnAG -_NyfYsfH{g _:֐o"ji$.T=='o`54dz]1PCzr!%
+UXYXj7.rZL#Q:'wϺ#a6glΎhނDͱ8ňH"& &ɠGϤhq8ԘШYLNGLS$1Tk΀U;(fp Ns L
+qtP
+5Ȅ橢jWj_q^ qq%kPgA]+S/ώ!)6eG;{ݤlEQRUZbBTEE82~premy;@zVB@ Z7<cLذaK
+f UKC`|S(wYh )>czehBr uB=6eQ m)Y80,c@D_*`t\]36Ђ7"Yp6e
+jp:54nŘ,؟
+ dCA^Կ f]I[/K|iKn谨7_ uRm5䝘rmHb$<#
+e̵P3_ְ hyf[c+n  `LVeNcN óQʚjGReH yE(Ѣ@-2y 4 !\=/, -ߎ(BGio O?mb+~'lUՁcVL^TmKʝ&2,
+8qlVbgМ|?4 [znDMO|VY
+`O X{asZ7U0PFGcHpFHt(
+϶SEtzQY+&#35H#I1c Qc"M ԒXZD$0G%$hA>h?gDnJ(V7`9cq~*B sk#Q{zz=˱߾u`Lڐmλ_rfvrl`
+y$>jsR UYv䤮2P< 'ѥ(V/t#euE̽i`HZL\1+0ogwٷ+l܏=You/pp' >P$u!e7$Bq#4@@D2;MɄV
+Rywy2$Y5~bO/?qv~,ٟٺeUiz|/C&G7_J5 5515nfp\j1{Ӗ Yo)g!_(
+>9ƍ,
+>eJDR`!/_{U~Ň0z-L \UGr?$+ bܦΕvxz6tQYl3qTZ'/U1:]p@?mMw*aؾ@,iW aj S9#aU͜aNgk;C uvLl.TУ"okA
+~XYoX>v EM{:QKV0E1f7+Q~<ǡ%@jhi O¡1"R&̰g߻FC˝MCc-C˭W1zKaVbvF"cnA 9{%}<}bo犃yMo_5˵T8~T0cfk{l#BZL&V>⟢זOW9~鷸 %wck{|k%aW:^}3feڝg5٦g`OO=L|}d.Ċ9)w?/zg>!o订o(%ۣ<
+W:\Gޜ _ݢ'~]F_Mv642Y7vC3~+DEm\ӁЏ]K |9y!*OUle[%,R5UisVs*@nXb1,iᄦ}K/kƻ7DA} w-VmO͕)XG(1
+[3Xk5۲Ku-ν+yoSߦZK#Cw oN,ݷJY YMژϻc)1U'W޴іC1(c\CC<!>09!1d#uEd:ί$՗8QOJ%,şbҥNӥ(RTcS
+=rl2SX"gB\`ta9@.UƋݣEnQ6x1
+Eո&ItQ8d{Ս>ՂQ#5mȐw-Գ
+Zo
+<@Cq2` J4lT;P1!u L }=zBʜ|Lş
+1yoOJyjI>&I[(QNLlC` ]6K/-[ur<p u<lL;
+Rsy:Eh1̂5j*)`,r,C\=$zL
+
+
+DܲD*L :KV!C!J`x!Kpb[MIt!DjɎb.IҼ2Hռ*Kٻ(Oܶ!Oޯ$Oݱ#Oݬ"S۩%Tب&T֩)NӮ+HѲ1F͹1L̲0N˯6R˰3Xͣ1\ʠ4\ȣ6^ȟ5\ȩ6V˧7Pɰ:Lȸ9Mȹ6O̰;Tʩ:Wʣ>bȝ6aț9]ţ;]ť:\Ǥ;YƩ<Zȩ@Zʩ@XϞ@bΜ>XΤ>KƲ<Sǩ?WģCaJPT?ecDFY[ %
+6 45158Qj+.m)ila(5/"
+2//9bAy qB[hFu=oa]ѿFRSXUgLF`4wt8Wk
+T+Vզ4L̵8EȿICZ>y;ߘ@K^~ThW~!߁&~ڂ*}/t-n2g:b9f5a5^l#&$0?SO A
+;R0wЉ.vҊ(r؎"kޕe#fݚ"hޘdZW B4'@)K׵"8,(=lÔ0uЋ3
+z{?Vo
+Qk5p2} a!x  }lѦil8]vMT],Es
+,cÓdexYG
+Dk;Sg"+"Ksšh`o
+ߜ3 4I#O߁fol_v#ĺg|!xل?e zu&zx^7imcM[1.폚1ւ>^^,/eIa'@{y|P1i]EL]:!$d2:|Y/U
+jn|eZ1I4#w:뚭fB2Eni*"CQU^ *xʐ3
+,t5'~ 0PA-mh@0F4y;T~(a3+${X~qn@\OJbj?+(c9hhm$(n($VTG6kR?NᄙB_5%C;RoڴyWC6Ph1o q.FROHp"! -/ZV{V|g'>%pbDqP"TG{VFS|{lCXJoZ
+BcH-hҨ3X3zhIj岢3x1=eٜ"z,Y:-:lO;0bȏ$¦b0"NIEFI@
+mn" !F~(I?ocz;ϋ7) d@^sx п(w<Q8?Ah
+HqXhU3Wvoo|ُп@Oy9;ch9חHfZ]}FDŽ68
+0J ᨒzJ7K@%8߮
+;ҍǷoFEVGQ*cҸŴ{a" $%t2yiuQ)%q震ӥd{Kyn\{ڵܫor៷=s~7s/?%rsٗn.,|F -q]JULo nn?Qj4{=>tZ4\5ػb(sC3߲})H1+1H'B/ߌxwćԏm,DiL bMn[I)+aWgpZ gķuOwbV
+Eg"/W >Z`O~XClb][GCrĐ1Bu*;ݴ9Dbw<}ksv'7Ϧ+55x]/زm}`7|a[#/k8^ niQk"#ԏanwGV fϖ,-f]TgN Q`Pݙ7$3 =<38QdZ gA 5H
+}A\֖ nk q/T5'Xj kqM衅`r6+N =TV{ՉF"
+9Dp=yj ]# ϼ簅ׇ°Ai`{ڔ шn>(QHo c"2_UZWHY*Y*YIh%hhp3Mxw8{=8ŗ|k8~G}zm/ ӟ:~w:R #Eقgk؏"R{^93%~;⺇`lK›F{)o<#ә7[rNnDgub *hҒ͇rdiT Y6*`&܏m-A1ġI2g2oKΤ߬u*=J^>g& <W_cPE<X\.#}Q203-aq;UNfG 7n;>oL|kiS_2OS+W=) ȷ\i_Wrڋ +O=AS4PUtm$W%dv׶3=?oiESϮx/kOC~:]]v!.a/ZR5_j+oQJg;#rմVM=}QH͗a=8p&k8(uHL` ʂYMp!E+%jpӈe*0,V2*uHB1g?)ٝe+KU`NAæRac1&(ǪʀҀL]0(xXaC1MTc gc3b(ŲdXYdZPl'7MWhAYcEJFiRľckVқ:E*UfջHO;>0K*v,,4W"AUbTeG:0lD.ii;fNMQxҦ&%)|,(Ro.A
+LP^f֡2\A0Iɏk&?͘Ry7{/(ݩZ]ɋ icJ;LcCpB_>f8ѷ?ƞe/*/ۨϕ;δE+s^4#uKuK{Z
+cVOU҅: 6aIo,W_w| zy2˼3+&*BTޘ}T$fљ"X3ކc%kqDž = §*qj,O_(ЉG#rQc)6Rj3 Znu&/}
+Ej;搠&K>WCWk=2D QSK"5F.1^cjZ"ɖ,Md+f%dnEo73i鷀Y:Mδ3Mm3ʌY3%a7Coft 2-v$_-g:!vvVu"Q* Az+r:Ks
+%8_ ;.eܧ{|%:3f|;w}t+>!qɏce<H{IfŌG9W< s7(=^y.*MTCiDg݇TL\̅\iJ tqsn׏R?_J@eo_ϲV>pvf_n'kki ⶋZ[p_`/~|=GEce*[:OSui->呋;嵈”Դ[S"ҞGWАFcg~yiYfS⼮?NlMRX(-[[oo>pR5Rb/Fue?ƾjK/8"ZS\5_-Q]4w]\j$w]LjsKFxe-~]q {;\aJoU2saӠߊUgklIָҾ?uz覰DF79f^F4_:^w.A.Gw1>Tl}K'1}8%5 YdI[$c1)-[{z^7f^;O(/7Z`LUSpeYqq@c2hawuƘưuo״vJK
+ṢqȚggiE<xߚb{RYم.x`i6!ڽzWv%e7VΏMDT&sOP@ho(~};B*ۓ6W] V?aW-a
+0|$A.h9O>t!G1|.K S wO&jj?'@ɜQG<>mJf``-hF+㵃'%7zXa:_Mz o&:y,xҋG]"91ŏ\z-(;+]V
+w%GbT}'
+X?,Y
+ED<
+A7
+ZoP#`0P
+5?eqkiӂ(11% ,yf%UTxU:آ$K`pČ5N۩K,{?\빟w_O`c7Ƶ%LsCg o9+N%{78x2Vg0Rq(|,z00DoƼ(=[+m
+6㵇NBΊ15ym,|VDu&ZSqBW Ħ(ͧ^> )^h
+,R %z_cn*5JO6y\JgQN#'`E:`YIYɝq#@(8̃</8|G(B80vTZE<
+, x*bv~]"YZm)k+t(q kD(J yC+Y=usu\|%HBjEZ
+!7x_"}L ד
+}=Eb[(T腑q=HmLwD) rV
+쐸a;n
+le6A\༣#Pr\]}s{^.#ԫ#ؑfO쌇Z;vq<@s('@0`$NVFrT0\IqKo$]̸~FfZJZfz2sfzRrFV߲N5ԤKW'$߾ FrKU;_s03vŮ6c<}{`. up?-G?лaZo3dKcDwі[Io
+ZR7̜;g3ma*#i i!<Ī_s~KLIZڝD6pѮ1MHU !(ZjAj؅%Σ@R =zdl]5Yfڂڜ%mo:5WV5Ԗ/ioO:[V4tW44tԿo6%]o˛>XZXxF`b"1Yst=*Lė{.*mzVkoY }?I݌~\̔,E-\[DI֯g퍮葈Tv/czGJu6OԴsmL
+^뻫9xCzE4LV\;A0 pƢӖOsٸy<}D49${CpLЅ`ɈXB{ %XO&JЧ5^A* ciqOJP 6c1&diTF ℂUPjmIZ}B ֱ!w qȢX؍V#,˯6iii{h9]arh֬o0cO%F YfL)TƙN&N%Z`;h=y24ޢxUHM2&_ozce[?WR'~%,5
+?'0)Tr}zdbyFRxfio4nKk5A:K:8m<85M9*
+^(^yree1m١պ5feiy(G""
+͎M6a~i<|~zo \V|}/-+6t)1AꏛZφ6oOxv9b92s!o>{*T=W,[>am{6m;o\ }:zyEt%浜gJw=b3&ƶ^r=+Šu'atW`u͈7N P/6Z],|cz֬Bc]aE5%۞\,>?QQݗvs:gGL]5w4q42CƐw_AZȧu.uU:|Z'772Y3k,FH(Hy>
+w`#6$Eَ(tU 9gyP)u{n{5p,,MOD8nY
+σ{tM-b퓮Ef@5Tk5u)j$uWNW@@ t ts)LԣR,d$Ǔ t|?דz YB65yrMW>a6k?|0{PBVZ5'X=ЬND6@{dM>=D&pA=F_1xphO?%&vAc{ QKݶѦNXPŎgO}η!=8y9yři:3 W!msr\O[\s\BҒЖ`KV l[oE~ּ1gy*A 2UpwpP_Ȑ,9
+BJG.P皡EuՊue͒dj"4#P<:a!I϶Kj$ize
+<)h+3]R8Nye/yߵ)fkmG&;֙ rC C_gQ+_a[-iFz(8
+蝤nI..s|WP
+;ցRvǺwFK{C1be>q
+!$eMV?/l-@@N MJaqT°0zXc(c&0DčxVb
+8u쟝m2SK` Crcʻ%pLj)8mIFs'Ǎ qۃp"?€(8," }|"#SD"|l82LV }("7ϝk%aI*ݍ/;<\+- wAh
+-G@:+ 38Ըs+.BHB4Dq˰;`msk1CLd(icȼ2j,aMP5X^*GFr#%H.˧\ h^ & E#ӭ%0A1
+amMfl q󪁳Xh2ځȯZ #u
+#\I\ntA7 ̝6ƏWlB) h`rlhv1CM5b&Z6}տt//VUy8 d )a`Ae$)$f8<JĈ:vZq@C&,3sLӈ)9uz]q8wDH&"B Pm<B@QK%]W=Pr&W`O0l)"UmN5r`P3F~s^kz^ ֩ݩK+kUEkE BϱF`c|:§D=- 
+[8Ysc+GK=X@5/RZc(2ƴ*)GGh*?:v(M, 2P,P.˞:T\:_؅"b
+ˑ!"UH <\*/ 㷡=X?sX JiAʂ%Jp=0=m($:鸆B\lvܦ8RW.D'u~DnYa2a.m#ܪEHʆ]|>>_B#bGO tO7%
+W\}+ƝF9(
+Fp*J5hjSŕ$D+we(]\ben<(C؛-d |e Po>-0oQw38OZqyIQ{3.nĝbW>MGp--A l]Tšq'-99hc[~/dV\QB"9wzo{ūJ?vl$)#cWHYV$ Z^VlIK}ۿu69 mm@y `<gb?# H{xwyc⹠1yޛx5[FKlـB0au?XuaχcU/~C*b5'':2}*} k lO/p+mGB7bN2'p']4
+6L VsdkN2\n׺14qkЫV
+"s?~fN#vk6݊V{+؊dzd9|kIs )ƨ>^U/v0Kȥt;Sw$=v$|17#~Eh:aYK@5T#5L=MSͰ٬L?;9>S+|&S?j֥'
+6;5ej&&O>iH!M2o'*IFQq}UWiؠv-+*|<cѝxt~$,S6T-C=KFR^Y3߇ ̒K}II2"X$Cwv6wb'i6cje^$@0 `ނRSAI  [Pr
+6' 
+or|G
+MHCeffaYf/LC&
+dItAgJd
+WȐSYn3z^ =߉}1#a%f'LM(MR<rLp&Io>}{WɋE[,Ul-8L%u9*c#y÷aY\)nCۧ
+ )(m3779/]V靤d^[)z^5״+-8繖=a -;VZ ۵7m
+Ti~~ҡ0b:5 0PTy&CdI2iɲ
+Up@xUc08wH @C`Vj#YZV
+wҳ
+736M?WTGXõ֑cF !?̇EԹ{k=Gz^Ԟ/B';+YluLwa{>T@"Aܭ˒7'ϢFX |
+~(D
+#⢪HQ:^X$q"~1`H{
+7Թ+_Պm5<Ѝbf}v27~V)/tinZbRdåWלA?$n>$Cp]̽\VpoWq!;՜kNJ
+= Ɗ.ug?0C|twq3[[jI_kUe}ݵ c t?fΊ6ƖwlYm]mުeU@{ihX
+-z6.,--ꮮmY߭=7뤓e}2ZI}E\*clsje \D''7}SE68^ob#2q.4+ƈTz3~7z 3r;')Wi(kf`%q˱~֣7̭Mm
+fmBr-Q:d(4QV 6- ̴dJhE)?e;4uNǭ
+( >.}m9f!"lws${B
+4ɰBmpY`[a,(ki gZ`)Qs|ccr& K3ajg ᜱp?9P>(EG۠x4X_lį( ϻ<Z_ʢ26#2';—d(c
+4mDkgpʰ$<@g *c3e$#-6}HsFPU(ok|畇۟dFFBT^warCoIMxyJKubӴTmwR@gBίS{ 'Xʰ,&wE<i@@mO&58dA"m2ũGP&0g۱[=ŪۄB%xnJ[DS+T4 8^ITK5L:ԋ*PTm{RrRs O=9~r wlAv}'<M1*-!YKS<"Mn
+XwL#۩ӭ ҃uv4 x2W ?5
+ɟ[|{Lg4Wde=5?y5zzMb f=4H@u26Yvզr7Qgƃ;EG堨 h摃y7
+A YPczr#s\t<u>!<f4WT&۽V)8n{~-QTr'%Pnqso ScJaNo?CZK׹ϰ[|^^p|Ɋ5?NFW N=mȅ5IS bR` i|#p9f,"fkת|Iֹpa zyA-U=R>r?II7;ޫן'לS+ 4ɫըI',_tgx, ~{ YAeo)n*v,Cտ-*im|CɯoA! ȏmCIuamߞT67׷!;;`xk[Avs{xeGE"M
+cĮFEΔAa@<A1Ua+~itv( asw4/IVҋ݂]wa&/xl{dOh|~; 8QOg9X^:* 2ǣ=ënϣjl  ߸st['<^6;z]v -ZRwtu3cE.ϏrYTFQ*|<$š`P<(}WTQYWwPqQ 1UN
+- o. OK=VZ\;K{C,S5;t",c4֎Ɖrx?)ZcYG!T`ۊ ,o
+f[C}IxkiL)[SaNMMӊ^V,իVHt]!@f#~d.N>59uwO+ݼM_&īTJ5{q-v5.;e])Sx'6xjׇg;ZVMr
+m@R%&b)Q\b*+jf%/ Q@CVa#L3D<y~bB iH%z@"YD 2T~1YH3&MCtXX>~X+xXY.4'$ J:!4i4BB
+PPqm33g\*:8X(" H(!@BIHhɾp?{{yw|m
+=N*
+g ܳOaG)}Ů4sϤ2wZ/*Ojo_Myu S
+aT|S2_g"/QVd%*bmAa[T&*`zSM;'X# ȡRycRKQzf&_u&k|^z% 4Lw
+@[=@hOhr
+f/ͨiC}=eG_xeK`/i
+so~v8G{r_;MNJ(H(*9RiB"y[|_{\oKjwFUza7ZA5#݊ N՛\ dž2up`/ud2odW}
+O{AmeXv3dE9<x
+ HdHk]ǣDH8F>(""*&@cSu,
+ 
+@:vUĘf5YkQO\#Ū`xF=5:*>1U*z[qHC%)Y.%'XC0"&bP^g]Yό"p/>rMNbI0)X8W qABF"><.׌ i0K
+k֦BYFюa3M'_ AB$]KeAs(@E<ڴ
+G]C,Q$T "6N^~xZxO;U9Ýȏ"c۪nuw6dQW_AG}`YF++ j3YtahjPw}UGH <Z2[T謁 *ѧ% éݦs PPG1\_]YfY5Еeʌʒ鎿w6ی7\$IvinG<h%NS҇8}gXm_~1??}Tޫesu{+goAv`iMI)x*aA9gy.{ v$WOR( 1 <uZ! @@Z#H{;S ,
+lt[ dcp<|5avO+C};htY;ΏEp(Kޥ@ C
+u67^ujqؙ*<Ԧ{H=Xm(u4 :1ߜֳ_g:ڛu,;2]e7H`Yw'/55Yz`\؟ -=.:"re\7c;=~iݏg!UiVucw|Jer|M}ӿfǯ\)Qy[6O 9lύݷ0kwiv=?vOkFrxw/ZS0
+]eqYԕVrpH$p! Deqvqv;qkur9$CB7 $>J-[uO;<y''çy;b5Ǘ$^/ԬM,E!̠΍/wn:?I`-zP&4dVF$~'y *d ۪q7tH]nB s䏒BE>_׾}#9/>ozk
+k8{9O
+?߽7p"eH3aʶcL[|\h(u ;<OO%
+bp
+Ե-`+b Q<73ww8;#Qt6Ş@uj[g9R
+RҘ#s ˙%tW3* (`ݻk
+4!4<;4=+ ;9mS~?@6aY ^'ά[1G1-lm l߀@fYˣ3%\ĢlN nEG̙bq3jq{ϒ&\CJI}N?2; ?Zc\Sgj-K08,!~5' .ڙ֯}wp| _+_izxWόme y+ ыpTFFbdAsGa?Z**?S"hy5uA-KȺ\QM%{
+KHwf=3sϝmo͟1+JbfIkb<hySYˋzyVolj[Vij#ت1&m,]:kyZc[͘m[6XzoeɆyS+> bmɒRġBg<"R9)yUw2nqM3W}{m_yD.[d̦&̰҇~\6DRÍ̏
+ի7Pi_`E*;
+
+R&9>Jti%`=ބ}Axѹ
+:;ƷSZ@j#?8q`j{XӃG'7= Jk}t)($jS$qucD=:H$/901Y{SExܛ3J(4*q(9䋄dͧ?܆hWFF-CZP*R
+DTf3[~B2lO5p@<t-t35w?q!ݫ=s W.o
+4XKuP墿[T=EXy1z32; 0I)>ȏ]|)2%% ۝{%E^c%yH&O5Lo4V>,p&+*]:x!s U6 ^u8~f{UXC)J^-GQ12&ai2>#pYCU`|k^l?mw"pn{tUL
+3,T6&Sr=
+z
+X;C3B$SRx8h/Mי˞`Bw
+HAǪNq'Q=],@U3Y:U3}vSSiP:,Mv8'Kr\'}* pQP%0$i6VPC|C(Ȼ5gsO7gJ-"&x<HY<F\ahHHsy7s 9'*9b` E
+LY.*Oŀ$l8mbŏpiP.#t4sDXA#i""ZX' +nSHb7;mL-ȳ
+uHyZÉ*!VO᱉aܡ
+'d(( @"HDՏCJ07^)׏ubr,
+Pµ[sWH0Wlo-qCI$=ܺIXDpx4pyXPׄ}*CCh=[G^̩̉Q~$@=R[OR+&vQ|9Ñ7JXZ\ߝ6/}T T&;_cbi!1$s81ҰCcoHVh,Ѵ<5karQ8k1DH._϶7Vu,}·E寫EƶWUۗUZogu}孺_hoj.~Q4>}5yHGo|zkZ
+ϯK/@Gw<{-k۬Lx^<yg\kwd,_H1M& nQP J)O '%DE !2$
+L6Xln,ito~2.Nsy2E=y[AO
+XtZI}h`&"6a;l{a0:n竣f2gfo%mQ[44ajБԦau2t_Z؝J?dQ+@R XjG)"hh lJa](o%*A*$]V”V>DK0 rlsXVIK\ ʒ} SRd7nSQn/!ƈ{Ŷ'%z%+}$˽c\
+Llp$SYTԢ"Uʁ
+@\*  >o'p!t!| {/c!pT2.'O)͖c\[U
+DP5*9׉>~tMlE,oF
+,`=0}}_
+YD~gJmHwM|/ a3(KKKV\,s^ OWQqbi*CF {HInb!OS!H즤v)iNbZ'!tA+9X
+'oiϹSoR^cݫD])R,* J U(,1^>,F!{ x ($&)S
+2g f
+J“
+8 eUY̪԰< 7NҋRhBE`rhxU H>FƂc5R$\BA*e
+l\=|DE->LOjqQEb/IX]M,^y#eV|*у}1уCSd,`x@=lA;{bSϙW[=gմٱa3*_NTz N]qnyߋ]aէ<LOyyOxmF`<iۯ^nٶsn[ǍV:]t]ae˶sv|񑃷%ǩe)ܺstfy7o6';nupYڜlK΋.?l{uanM[>,|F/6ׯ>޴m~a˺K ؄.lkoؿ}J*}zyə2ҹn-yvg3/v~e .BFud'?N^9֒oxMO}{J]a?#s2M#:yc{k.3cp&5FסJ}|H!.LeE @i p`QHxZUi
+Y,H&d+~.*CՆ&ܕDGwU<;v~kFj*;;@6%u+_
+Fp1XUX(EO H
+7 Ɵ5Dstz'=j6ӿŵ+QqE
+ʎA"MZ1 am¤!}mLF`&A-Rt҄,p!Ov%N*wǑol XSP*܀NjL9LhnȷpBu8dpTwƜbg˃\'3n ug#yAʝD
+ȅM7A*CM"B>TlBVP\̠"0T= ]⎘`\c&k.8s75f?"&9^qӝq *wc+uIZna>~@ߕdbYӽ(@`@`vQ=a&C^`>>tq0F>r
+Q[_O\c&o+^[e2GsS]DAo!RvEwSGtHg`Y!EOAJx6#qYr 7Q5s5"%*BK7qd<&)[!E y[Cꪄ\UubR~ۦHjxґ'hd$)S^-?T3 ̽[\ lPtCP^ͫ?mD5 e>3{15Qm|NQdT'+z8H.6X
+UEYee'Em+ˊ
+;d> }1fi>MT>e$ݙ䥴h^Oe`Ӵ24f".MD8IU9 ct/C k~ GxA8A?uk'tY[aZY`
+c!#8zݔW[+Gl}(8dBI/N!GrKXX*qo-k*;\Ao'i>wA^*m!LtkoUrZs7!bdarP|B < -ʃʐ9w9mϼټxhXiPJL䶯FF}nSr̖5|ڇMpX=5X涯Xm;( `LgX!:}XXG{Nlz&oHy-[,ixq?_/KRƯ^d2vH
+חU#?\0OHB\[2r_EٷxgW7{*
+[pٳ:1Yw٧)Z'.O+i. (2~j U*D]&@ yI2
+ҡ=wQ<IŬЄ ׃m{_#׈q6xLsoí^y7%ŅBO31$̗_e((|!:;rqBET<HqAq^QN5em۞:StC`
+谁
+\H{R$e,@dQ92ph_Q5o P(4!AqarxJ3\5Tn?@&sK0~2
+,[m}jZA@LGiGĥȠzB&q&y/,6nw4iz>#""#4g2e!|QeAP_{daT;SC*!B'B' 1<31 )~ӌ3`mL:KK"hsLNQ'9M٘x^&@>p&G>4g?@f;@'
+<3 W9N';Np`!\Ǜ$IC\}hI l qk(}}9 k<
+]*|f}.3זYlsw`}zFCjgfwxt6ؐ*Jkd Pv?]o[wН7eԕAQv¢k";\JO̴Ό XKJB $,D-ll_3w}{;|HJ@l&ƁKyx@&TOƛv.Pc2oI?XSV{/!WFn*رA @jb2X|6jҩO{$׺'<LWcS+byrYmlE dr`Imuo ^6 `~ԶYLO`fao;e~ 5&G>($UuXQSM" *JhP11Mx@x)M+b<Xè%VnYאGX؎Z7gn~z;
+t~w-=].(9"N]:͓ӱR>,"!"Eeuh>CDQ@QRI( QnZBKp8wPY:`g(Ae
+xI[p@^5@
+
+Ҫ|F\"&N1!+E E{={nszjqzei۶E3N]^~v$E&~r'(ˇ)3gNSN;s,
+Tm,ٛi_7mWtƋV9}pw};@k> K%݊݊)L+l"| TC~=vgY =)?ƃ?Evu][25xijebblշZܴ1^X0`ibnL)Iҕl;PhyjSoܸaxzGްr]~)
+-~ZrvdQ..CXNswH@(6Dc3x>
+E-:N^/0̶*LjF
+WZwD,ψ,"+<o}oNokySg?_c*v(ZNlLXu5qM"VZE-B $$,HP@k۱W+KPvB deٽ
+~q3sΜ}syCx-'Ҽ7v`8Mej #rw4}_fJCX ތ:s;q܍3Г;|ò 99{J
+ߤQs
+3 wt747a5?/BD
+"
+1L
+iTa3"
+hQGoL6V`a>2a<\LzT݈ǂIED! ╝8Ro{Q>RJɕJ6H  1W$sյמ^ٖrwKڗMI6krGhҸב# O>U~ Zddb4,iƗ˹i1q|WqZonA)~0rDOݱ]noĤ*$INGPN[=,K?><j#FfY^o춿ov[~]w`rY_9h{K>oqՊ7W~%ڳ]ܰYOvRv [ԟ+Lu%###Z_+7mXZX{g{^7+v[߭{ymkolmM7K OlSlNVjŵ\s+v-w=^]w8ǽg^}?^p{yϞya8ieBYA*!aՅ
+t]9 IZ֭`mjiffz@f6
+:رmN|?No9_Ǟ[\?s̹#gDwYc# ~&G뙓Jqp)AbF(F!&)n.P`.+dR_ 璲lw9:
+l$ȺS5,b*̈#LW[\WƞC1CLdJN750vK8Oӣh(AgLn*[<[y7_;Ozigū^M
+Xѩ<2kfi,s+jՠi60 _n< 6V c0Mq3ٹ5aKutOHOu !'0i3=Is]^;[3A`%bo̘8:ҝ
+ gRȔ,hgϨ}3
+̏p
+?SϚ2[=#LICS C;-r+6s6s>)73g%:S:Q֟{aesC#簇C2JD)t-j/TA,Y Ӄ[8Mo/9`>|S_
+j0l4rW9پ=m+('̉ΰqn5Y#mq|:&RIdUxYJ#yh>g$\sML"lw&}"oPFfݖ)Gmp7{H?WIUlam["
+ɅpN0UwH ͽ]T-גıCbb
+ Uڔ]~zu}]^&uûU_?[sDy"&
+]bYLNըi,͕il]dڷrG/DǩF~Qggdס,1yI;х'7XlZx ʏUkLM-IEMi8mLl**P#6R'}H6Aļ[, ?@.!`G`ndK 8Ia )ߛ
+2Z@"⍽ƔĮihDYB@A:lpI%/oٙ8W|?A_{W\Xԅ䗚Rv_=<eq"PC$@B.H1HHg w[lmu]Q-k5(G$ D w&AE.)(y9yyc+YT-Wȋm61MqSC7פ_X.΂]ꝰI=ux $"J]1 ^#`F(Y{Ȳ݆g3@[Y/LY;뷹,9-MXl7ga93E (!S<T4ҮAeҌlY^^OoeE4zޟ
+9rÇM>ؘ-Y[-ZY.,Yo0enB1rt05k,c+on~~{KR3_ewx[5ж_
+NvLOק714񝧙VUxTC?_Gq`|go^$<#{wcej<<
+#K#wĄ
+.aQJ66k
+HC*;
+@ i^1jX癢Ա5l/K˜C5#\hPGhGpg^'
+'t7~GѲt\M!*W}{H}wXu c1M`$7G@{\q ֠dc2\T‡Rtp;][5Ul5'q7lDߛa
+P?R g>gLU-)%ҥ|述~taxh~;k 1lռ-[`O؃ߙajڔ's6zU'DӺь:$ԗ6QUOU 8>^NK̐ H. @B.FUϖ+Ou%3!dj"P*o͜dcRj,i$'Kdd:0 $` iR 80*%<bVs!?&>K]Z+Gs:1eUq\\ƍTJaR7[["QLPtφaeIfa( 6 H5-PdC?!hab>ҔEc*^ђJPqq6L|[kJjЧ+r3.~;V?V :,~pCuK7|/O^2ux!e#zf}}s9y2įPHaOGz'#Q̾)>l*0gZpYt1㞇ǁqg~K}W}&yFu\Im<Ǫe}$.v{g߸:-./̻w\徸֘Y<
+ ig||2"ADN)Ј#44jX´J%;YJi3aco;]v=./VvyE}/pF[nW[*-(/Z+xTVJ=͔unz}] W]p >ȏ%h4"ly&f$_Kw-tkWIP(@Vc| o=iDERۋbà@8ZCw4$jKB1QoJGH 0a3$S-Z 'DUTXFI(iceg<r9݉ˑUqD
+ť
+R~c%vT/~kasn}fIaecێ[om6l7l=6`۫0k띵Ƣy׭WPn@Vd5O ~d)
+=ExuU7W~:ׇ/ܱ/] 屫@6pU/&;1|?.~o!RC ^a |.K5dAOiyy+fųqAYY~QM 묠'-(::Rc1{ij n*7+-m5оɨ==cȀQ8`xAŋԀAtLxa-͗mڨ;s]mD- m& mBƚt vdY:* KE$XǨ<
+8!8&6XR& m rc17H3GOjOGO=i#Q`ӭsZ7̬jY7~^vrnR3vY[iq|o&iWNA)%HHSbKw$/uFCgyoL/s^A{`~OԑܝlGx8'w!B4:sΗ1T{9X},Ry,R(
+|:6^희&\W^'A eٙ:'v>ynY
+3=NM]ܿ{uk" єQ!Q3(
+ddhFM@aM_ .݈[yRt.(:p]~(<><w'.&^@D:&{:[ҝ6ay *tNS0L%?8Sfh&4aNǿѾ5zUjci k_IWc;V KR7[_H
+ITGdkuV`UXF_u8.1j™t`jAVUY*\f7+&Ԇ2 ` ҡҔ\]݀0Mn
+Jl
+IRA@Jt@PAA? ((rG(m7IQ;@H@Lh@V"#E*"AMAd;v }pҢpkBo~;]p8'c9lQbZ,jtPNUHO3 Ne8]]OOu,Ogsݓ<m<` myjp|l՘Z59Tz)܂g]+AVD0xԩE:-M-mn7獶6[/.Xl^Y2 ->{N2w=}O0`zGGJ3$xn-^(M6)w9 BBB{{hx2
+3=ji [m߾
+{gnau۬8׃^62T^gYf,sW,V+-VX6v/Kzqu{
+V4D mģ~VB/~8T_axfke| z#HkI|fR'r jLL` ti},UÑA Ck6 -Tlbȍdb(1%>LO (DGI@H
+^
+ܦ%qr) q-
+ ugfk0oX&q Ua|S+eS`f=k] ^a-(
+q<SbbYܳnkZї93+w}|ԓBB7%׿\n\QIyWʦhc3j^)i^RQ^ݜ<M3m̜39;nej(*J&b)"(7D/5:'kf?~y9y>7.,\w^ `|Kкz!]ӟ=?-
+,E79Q+ )*{?>?v"Jc{a}1w@כyIGuG!cr ` ,v 7 C^sB;C})pJޮlg5pJ7hOj/,]^a}`n[m)XGޔtX1 :#\&P?.؃#ci&ylI2q6"8 !DMx:T,*1
+<ŵHYVa021,
+?b/qY}Lu kه"+|+¿\ bZYOQg&~AVVn"O[~AV-ոSf@ƺ#%&9(1,oa:TG} c ^)clP.5K0,+0
+&d1ODIa8jfy?AR8c9``<90X#hJ> r:On+ 71gЕ
+`]wqeؓjo?gF<=vYaSn99V+8z)$tb|P}|},rn8o.$`ۤlp~kb840lX 6֌!8H anK$T7C<aa)}75U<KlU9:kI.^+ic0L@߅Yz U.Ԓ4%!7 Uغ}s  dwn~ўˏP^/4ntԑ
+!x:m
+U-K'14dÖct
+M xІBWG\;В0-|xKd)I5IPg&JLz9沀Α@sUdqsa{S^ekU^VWɟ_틋{=Wx ixF!sjh<5PC 'TbĀ-)Bg [
+\XQ[rtb= 1:bG9zϽ ض}G=6|Ci˖#SoC3)Ua%\AMw +"B$I$D
+r߄7.ZٺvNk
+}0$RAYssHH,(.g9_;}|ZOݜsXiamX0ZҙY߶A|jזSvj"ٚ+ 0)٦q6-,UĈHPHI&i2avBQܧ ~=2T Y63ee4mX2lw}sa{~bTO)Il`wg|f[Ж͖}K乚̷UYs?:|xq?j}=ӌ9ځzPWP|9I8<K? >y<iU
+yc`vYIb8u}0ط]}ڤ~t4AzD? ;3$Q[TIB|t1c >nr `/I곪@ˣ3JCϴgg?-gFV +H&v֝usޟ+'5
+@d}=G}{GzNچCE'a88Va"R]t1{ǚ>}sCIrSeK<@zZ/%`@_>mu&_3nk zc1Sա]G q[bIyCm䴩1to4Foȍ<6u =-BxT{/운)P?Jn_۸ch\
+s_i
+U:Rf鎬m|w9w^(W0}Yovjzkm'nYxƘѫ5_aAZ:Pl7wKTk2٪
+k~cϟؗ/gi|ܯ*V2}Uցߞs=k=YY/̟\g& E} sl7L )kƓ<I&!LEWK}㜤MT=3eeLi1 9|IyQGy(( ͐x0e
+kF\y'{+;̃V:-&kE;׏fc|$E9]xzMi*uF}dz.K}`hҴ'vI`F~WgS S|;υ
+78NyU?buOCVA>&,v2n^9, 5ˎa924lg@9P5|45ṉIi
+!e$|o\eBq}Nk]UΩjC>DW1&q1Y4 p(5i bs<ϳ#"\{ /B%2$UU>$$<<0˒CRt
+*"B@K"[%"" 3δgtGmG[@$BHd $ Ȓ
+s!5OPjw|aXFe2btyIT,(VX\}?Vi#b"*y[ܤ~C
+Gۃcs"+< zvWWϏ^eGߟџպhc3ȷȚ>%kȞgN.D/6g?o6x2+[C
+7NtogD"6Z8k}:ZهS´U>ZoKkys: |}[>@b57߉@;{BG恤L lLBЙ/p
+/›+f1ݴ
+X#et:w9%ueTvp aQEM%K a1 ;$ B’Xu)u:=
+!@EÒ K,2 (,.GE! q}{߻wAgccy/F|DŽЋRWvxLq YqkGZ1UVOf)ZHє3K2S,X[_]yw Vn:,[8~yE}/)Te9R@e,uKͅ3&j|R5@ 5\cW1_"dh)"[A
+>0>3 c5+cW oZ7 6f6vߵbbqvچ˫Xᇆ[mhoç\VlWO8qLZu|U.iЪ&<A5)8:@ FHP÷׼'zEP z4{D a`#t􂺧z-m9
+" XAh{a4Y}(DPfobJzS%5_636Dc_*Jo8ֿStDt#Ojg mUv(k.~so_}q*Sp ix(tGgb[uAsA̎' ssݶ)ہ 4f`Z<1W~]R}7m{cryG5q\t@T*54E:ҒPL!$QYtgƂsNHPHKOP owyծz }腮w_.;wa 8 DܞuQ
+]ToFny\
+hVCus
+aRabY<0E@UY@\
+RK}`j"(6&Ҳ|&qSlOt&;&ϙp!첞]>grM] RD^_ ݎN}\{U O I1M&A4 5Zz
+
+ 49P/3MTX1{Noz7jZ_qRxr⃃[?j#Z> {#bg~TskF'rXVv1xń2uv/(X2Z<r(,dK <Qk>w[^\ajdTQ)?XA
+zPS^E-@
+u2ָ#(IF@F9h/yN{oU1޲-_mwc剅{vo kv>4:6mE2lt]Qnϝo3%œTN$H#T)i?W4J CU
+vJ
+kM0Cq0
+
+]Z?YuOsq2ty1#,0T-U]b*˝81d%h-ZR-iJ1Q#<Iލ z*ai5E 8"|>ZwNPU)b<URM`{>,13}Ɠ&ikQQsEoB$Mم BGx]X;*dBhOkv:ۜB'B&[avLG8I*:IE'hNTnQ'. 3D/m֞2݄m[l]|dƒݑfmUC##uvq=G>a:&@Nqtջ_7<6 YyțxB#0ѳ"0퉞md;}frQʗX:A(Ctʄ*P1t[[.}-gc.o;w?J~N 4||#KVg+D%
+iLW 9HCP=j#jT/"7jP ڏ8{,cȋO mщ"YQ "\ZW?_c
+u=4W@I!6[&X&Sre?ae޴r[4:q eY~#Ek‹/RE-ԝˮ`P6
+ky2H$
+4t+:'^^عCQUwJuswNz=<GV?񡕷KFv/f-mV%}eɁuS5.\\vs꼍B}D XAgE-wblC龜K󣋐ӓpSr!jd=}-m=IYv>έx0 WI:;rg*A0<z5GT)g+w$}eDWmSԙBTȃ7N_%nD!z@{ZPZ㨚:g1Ŵ~h`0waB{D~uQWo$4 bma6 6,!8H[ds
+WױqdWڃK:B$-hIg'E$L:kf)଴L` 3嶴I? %UZ K45N/%ʝJe%aF1cɣ $Mp2ƄgHNh%e D8ЧR'ӥEvcnq<fƅ<t8!ƹOG h%IBi<ς8`Kf;NV;O2AFܢzTl?;q.a XiI="eԕqb=vDdQ$HBHFb@XulNLsXk= a'%
+O"
+ 8_o L`δg%A?w 6hDn 10XXYhMϷ
+lI&cBk ~Vd8.Š!-?
+%s;aguhbvteZa<c gEd*P`l e|PT
+ %Yc)O;@[~p?"T` 8&,o2p 7fnհѲ` !0!AB2L0`!|3ҍ XQ'Ո3f鈦2iCc-G㒭=AKxܸ?|~ښZᴥj/tcLWg0:M#)>L#Cel[MHqsOveenԽzm㹵=W˥~v}g@o6VԴwbJ{
+Q3E/nB\w;b ~
+[NEf[)݊T,ʜ}<8A@yekQ@=z9٢҃M}(='&ޘǾa./~T': # P2O+"樫UeynN+ЕJw CVʕKh I͔n/xe
+H@N?L XRYNvؒdSmSt!ׯQ ̀6<L/m?vؓ;=d/R>{rl`[
+0=E =ֱ^``'B^ wS\>v~'V+dEGM['/z.<q[::} Mk \<w6^X|zc{W~_rq·^8oZG2N 3; t8ˢ]}tkݱ5m 1"tH4Eܠ羆
+/uI+Ϝ4
+B-RKNjvY VXUwB1Ro
+[+g/:ץsubU N^q_<}i(o*?Bf{~t-?m>o90rO $[ɭTq/+CbfUJB
+wu敾Tho͛s vd<UA.ӹ{ sYE0HP$2cL,K(N,&#aŶ3nt,k_ĝoÐ&+>BglqWHH^E3f%&Ӫ/ b:${ِ8
+ϙlې ;iޜ{ܩ `<$%d}GA3vh,04"A,pUq/e?ա
+̰wm0]B9Zd[@P
+|\,16yl lPM4 2YfZ$L '"Ԃ̶Hò,(T2
+0
+]-QC(FT1lKq{Ј)$\ona Q't0t^TaEkqRak f@0 ~FȚys
+|<x| ^s-XM@U o?cWbJ໶2P@`kDqU4qOɱ} PCH^heT6 ŔjoaK4Uxr'xkХ\
+{\{SUtD#H롈,UThʵ7 Ś&K/0 Q dC0
+ܱƭr%iOohWۿa\ސT1jn5+IRtQJ
+SE&)LE QU J }Ƅ;Dh-nX}l(/.{d!2/< @~gt^a*g@
+r$s0 #**0__[owuWo (OP\}Qi:L{V}":%xwƢ1nc
+crmb>
+9g4#O.>yS+agUc :/iKo긃b!Y8+.<ZYC
+ҬfQ[ (IN`ؓjeEu$ʁHO]yO_|s,v%ِs^3sm^Qf?888 ^%1Lsí3#}O? AäAi6D=JVQɟ`86:22<J  {wj"ҡǵ1GT9@]>ݧ6إ|/Wwx%Ӯ7l ߾F?"}q[J={Y;mްٵilЯz}1_E당G;Wf{#B>\ȼ׋O Ooi\w"w`bGn/J{)>| oWvrŭ`>%23t7<go{_cϑ(K"U.Fdl4%Ë2&[ǭW1oP?*)Y#WeDgk{TgňptM)I ..;Ůt!~X#l
+|1Ŕt_:vqp_67{(ۿ"wl6>2jaDžJQW̷Hנ7&5w(WX%9HƓªW'V}*#H ?t RP9tQt]40IئlS#
+X
+eZ cN ܤr@S /Ppx2[nEx C/O_Ojj+q]9KSMbӵb4])keA7`42H|$2,YŜouK\hC,FtYvY8Bt7u!cz<gF['F'iEDC#x?{pj> |7la.à}zG➏2<X.7ęTV+f&!lKRv$V1<ݪsc'Wen[.v\y-"44u$*PSBM9,<u~$ m>(e9?UOMWԂ ̖WP~Tޤ N u~zr7U Wo"ge>`^,S
+ыao>'ueLcm
+lq%0 ,2Wl#*P,#w6邼KLNQKj@DPG
+a|+1Jtݙ{!T_9-ٛITKjplm}0_EMs͉H  Fhh fC9nމAǶ5EvfM8IZV -$u Y5ypwǁm</\:?}EM/gmz[=Uomy
+_c5cM$'>۟*{f͔o9VlosWYGF[9oqX7pr
+Ș1b[uܰk]]}&a.eHE'myu?.`:iہ3%&;c,Vn/9>:E3,dQ
+ȜF5IVKHz7<ױ҄O*&Dއɼ:nZ@ qZ
+ [أ ŴHZ t$l)6Pa t\G VtQpJ 9@>H~6*\m{FCw!+n[G1=V_ /_ mטi.
+<b^Ԫ{z_:P>E'sjBqZ^ш% jC!=`#qy(2yn|"~\Iq4Sg[~r-{-Y;7'%G .^=e{-ã;
+yA,:O.3tdI=rEȤTH:*T%ZZ"bLDʟdlBwCh籑#&_|K4a!:0LbwA|>n{&cx?M[UGpަ*`a / Dv\<b륜GT6h)9"$${B6 Щ Gյs
+ljۧ !!4PMjPSA,AIFurÞ钱wB 0r|[O!tDx.I5(1cqdޔwͤV=F/ wȌ +b\m]n JDϛ=oҨ$k3<zH4#0M1s_X{WdhSGEۀ1@:hVdž:By/ 1<ij䭅oA %&=UԕW_|2a6~zXg=Щ) v
+d~goBk,9v
+<.Li& .?<3 hu=FZ"rhH; 9 ! ggvt:*(rBS@ $!P EGƙ}~?@ni|[`<Ooۃ[PBbhZ檋v
+ɛ|{'CH3jXΌJ󪢘zHќY鈭
+ @
+eyqy5
+=Fsb" 0V[#ޕVV3]W`!A@WـU>}[O5./jBʟ6>n/wE~.*n`AR`D_Ŝ}|#?%JI,61<4,×XE8zS`Q6 _f%pWyEy E`;yIwNɜǰݲn\ nQ\LKlL=:ߨ˶*{Brfnh^ZPd.ʢ9 $bo' ).v .#Y(%sgbӍs*K#V`"y 㐣blLZi@4ǞO8縓P1݄
+>:(d?\7Y~\`Yz `N,.JJʠI4\FBvd tg d2-G\9GUIb(r5Ehj%V΀jo.0R?}m|š7Mu<u Xr5T2954md?t5PsFY_K{.kL93z7U0؞)з*_o
+V(⁒ ]&_LZםQqxdDZbW v↫& Ϡna9'buwYz˵?VilX
+RU
+Iiz>"]CfZT@%MuLieٛ6Y ITmF&B^{y uJ;FL ` 6fizj)F!2%J2݅O`q3RĴ
+}(S/5QUkQ:bY*@#2d4K$3< mL)eTBB0Eюc19P_C3u؜j\&x1ֈcs
+..sGXx4XYOcʲb4
+,Cf`ǪQ /(}=!|6K&"B!"k,KM a Ҁ<06HN@ (!B9$뉋'cMJ|bwgL4R1Xi4=I0(Hc]؁D@I=(3!d-qR~k.S;1Pήx]
+!mk, ~aKv+fbmko/7>X9[xHYZ4 ӿY9n\6f عlW c7ŷ-VmV_/]o{[|dZ?9w-lhL.GP44u)1 Ih""PæduV$Qj<Z#o()λr:R^L 8X^Z4_#Y$IK)b~M1{oWC2.hz-^@+$@7HJNNݶ]w* 1@p3r$Te?ޛy)'GԐ,-i1-xh1,@FZN7n%lb`
+9 acό21L&(beu[GgO<>m#Oߟ:r?֞uXyhZ:SPhv]S$DD=X} q~b#7҇@߲V7vi^IcSS;!6Q3ZW-i9or8 3IBÎRR ?|:K+dAKL]v.!VIMUA~Us97Q”LQuynXt0 Z6 j#~$=X 7 _~׾b1td~t&"J<?Qk,ڟj`}p|fT$v1dw(Q&B&%X >L$# T`.>D"8@a !?4 :l / ǩx8"_Eu'8\$Ky0:ǓBxS4,*-?/&TE*< l8?<r;]o{` OtϽO/-BPgΠEnx0&|`;&zh::X6a b0՘/A1"̎&%p#>F2$LFD$l49#14I0o{}*{s2ߟygo{K}v?d&6p'?'?z}\"b6o.Zϓg3Y?䐾攵RZ~e_?!~~Yׯ _\+Eo̧\Sf!frׯW~utétU._0B9C׷~}`2ۯoj\S}=O|vZ lxoC+'KH/&o1
+x ˉm͍kN`3S8ٙB}6-HtgIQÅ{\cEsՑ6nl>{}6bce agsxjlZsƣVsȊҨ|MU|jUp;M" p:Vه̏bACPMb
+M5 nNflVK{Ųn8ܩؼCMǚ}\ک:Xp{G^7tݨw`;e]sVs:A>ZTSW? - Ni!O Q0q" ]֍N 1yPT^TF5K\M32K\
+x,3e.-**MNYSk9>Y,]rQ'd ^6 LUߚT
+O:h%l=FfOEhvp\Q#K;,hڰ&>@s5;DC!N[MTZ/<
+/<)*JccD[A>Sp %leBBV@pXmQtA/!2R%@F\5^"Tz,B>J($&oo!zL:F𓍑a ?h1F3{g=v.y~9{̳O]^<_w߲_ ο||:w
+U.%"07DNK.C8m,
+&ga"-10+[ i
+8 踃ٛ}}f+ҪJrbx.
+s0V,gZJ4/~}m5G4J08Gȟ43t~81`#ϾoED\(<t\ fhYLA) lAhJIfBoLs)Ko'Y;!^&n/D^uZo7Q^ȒEt1Rc:sBÜ'4g^ZAh3h<,fqh{`׎UABCvľ?|=$bUЌ]~
+_K.[y}y9 *Y?F)2KL我D{hJgUbM/լH;lj}ˣ7 uVSW^H,lX9IyHeuLV]W1y.P{֍R.6F[`mqH%P{>E6tЃ PsPVl$z1q*[)+`jA=m/*547
+C $8/` M{Ås(@ KNdNa94r v4fæ͸a >> kĸƼ$y n݁/8`iG1tfxԫc1/wV~NĿ
+Y}w@E{cԧVcW6/n]'Di0i|H 8<6A1Sö<∝32APS ٰ)_6td\^L%Ylz:8\jv̔?;ȄH}6b״׿_8<{ͥ-KLZlNM-lqC6!(%b0UngOeTUAn&)i_$hxBcbΪspG/O'on|c7#Nn[Wu9D ?u akfȚ=8E0rxM؉gڟ2j8(T"!INH@r&$@éx[۝Nvv[U+
+Um#u\֌G$28Kh33JbY6GNPBW!w+2h&]XIA{:eY4@.E&QaR*U`ڔlJ&׬ȣs1Ub@1Yb\K%i q9aGO>]>| dߩwb0 gR%hڂ&4zq(#V"<b 0!E'tD|l, -MﱣFRȑÇ$<Oj\eoI0X84@_/OxL *]5GwkIxJbNBi.>SvM1_L -|#?D4uԓʰo¿>{"Gw3ȟ-W0K
+%/~5u~qzyr3u~9ר3XOd-&ɾU6 AY">ՉU;o
+MpG5 #3MmQ)nhbʶDr(xި"Yfo)6
+<Xhc`YVMf{ixs#s]R()(]b9;z=Lan 4uN)9щ̚ ?:0:) Ovt%[$!I>?\|Us`vď"Ա}YφeG~/(v;X2ws٭TSPss[8K-[?46l ,}߰Uchc!lE[' sJIr},yZbRLKQӦ~KIᨻ:@uBm3Ѐ+7"  ىzYO{9O?g=^g;0H#;(+ٓPd{19!4)#<`}t}T+G /3 |@,m+!GIKYButvFf{i(ގ>}I{wQ[A ] \>P+gńlU3l"*h|0P^˛Qr]qy
+ @_SˍTj%f`{RS%"yZA S%&qb"_@+7|Xjh2` 없:| hjE&1$6pfZ,@&,S. rdt Py7u tQ`DVV0
+ePy7}
+8PhR.fe<<7,d y2a<K3A^b9֢_Cw={ ݏǺ`><@XJ?\u~x>ҟ6M;
+aeX9/<͙ӓ=Ck|V<T Nvu[oeMO^ĕo;ۘO*fao@=l]O_?UONo: y c PQ<1h.&SDTENB%$@H ]X!z{7csm(z*HQZBBzBh* "H/y2}yF{[8v{&Npw_շ1{Qt=&"Dj vHKxa "~x`6sCQ*WqY5 cth6~bƱbUtVUT&r#[o'1<fL`sXiMIYX=_AL|~9ݒ<S ruTЊv<Tcʤ d DŽi9Ki%.h%7ŲD-q|ZKM,i1
+ jʼn)W+遐Va\}򛔴RSۚ1In/6V
+ɒ w GpjF;6ڥ:~-q#͵B ?ۊuv:c8asMK'quӣ^FAha~X?
+B.GeL"TPpLe `i&7cYCجЂ'scΎƟ~PXE g32iEi`vy]ײR9WSҀq`ˍ=@=A+Qy
+k!I[矮fjN0KE0upY &NxFYhfhj 'UU U%(ِu=,]]QWCs5,Wˁ,_JL)fD#ajMvh:<o S#@FmC@H0<O60gS_OvSfcyFpLwŘd}Gœxl#u{>6ئlmӶv|jvH^NzZ,4 e_d/<
+GC T捗A  GK
+}kK_{|urېS _$6- [/sV
+ʘ ῔Rqq#>fC5 |& ۩`Uq;aMq=\_^tߑFPT4z#0oaKgoQ5ndۻm))ͼTFC[ZJK֐ %2:'ds:$*sګ-sSV2 ,oynjj<,WUVW9z {"Y<RR_[d\WwlRgO12
+jen4}snDwIuXf]N`tpR[N Wrdgۃ.oW;8 Ὓ0ΆFHAG0 e8Jo'WGr_t,F8tJJ9cpJ%/W1b'EPzEQQ^M""Wx,xn
+꽲 ztr2lvXYrv3Y-v|藯-%TEb5nM F{eQX-LGY
+M2D
+O_zWxnIJaS˗B*jĹg"\2R+Ό͉ψm?eTaif-@6! KleOôS0]S* @ @B 7$$6EQۭiE9Ws랺u~ϒȹ랤-((mwm((g@; jpY[)z٨Jȉw[Kgo \OTr88ov^#hkXʇA_Vչ;>Y宾{ݡ{;PȎtr|=4tq8gaqVBWQq,MׇgzYz9:I3(#&Z4UOѫ(!Y0dx2:a3
+eСXaCR4ՠBS u%q9O ySRt-ʘRPuKZL@Mdqp[a_2/5
+cuDUq9:1azPHYa<KGd3cưz E]K[RPq/tlk{*
+ϛ}Q`n@
+B
+-Xi@1Z\Sn,7L2S=Ԅ)bH=?/Ap@kN歵pV!,Y%p=MZ NF$HϤAbsOJfyaH\cxQag*7J"jC/>"KC:_ۄh[93L"aPf iW¹qh|,+R^fyMw 7MgnM^6FgB]=o3mxΌ1ĥ5ь)3ELŲ&dɁxG/#bS X.V5x?\_N_҂qyv|VUm>.lIbe skg5->V
+1z"QumRG{kL@C'3+A<$<ƞ[ಥ/P @ .{[mgG
+>|m~~○|{9g4}{^ 4rzj
+_4FdZA3VG_`!/'icXں'eaBrc뀳!*eZob~Wձ|UŜ
+aƁ9
+SgMB4Ԏ>ged&%:C'dzhO_S#x
+41Cq#IC I䡡x@{DzƸLSq_c)#ˉ%,fe%ɣ\N}vx?ش@>víAP +E@aG_|C>{c:ude I*gr!ҢSTHr"Hj'(3&cpaKjԒOp;J<a';bBglQh)2ƕK=\U\QMiaX Y H
+zݰӻƂi23słztL-,.7լ}<`X7 4[lw;V- Yz{mv置!`#6v0-%^W<BK@N*A s%zpú{߯"B
+22n#Kk&`Pv0zݣz+(6fgqcpcߌkEo 9cWc+0vs7n^=/we(EtB,PH#Ne Gk
+RNMH'Z[YM Y\Óq_-YY}+\aZNsZY:ba0^]:ta5la8Vz:/2A=|F~` x2^n'_A6%N3we:̹Wx.G{}\Џ]w湡aםg{ .r_:.yl jbzE\)5u {kOʿj+o>`E~/w?
+ e[ƳY0U`7CwZwEm]m9b~7wciowa՟2߮ k@P(ӄ@5D=FGjZ0߮ߟ;|}Y˱WTe/ (N<xlX51n<V IHbyL=Eeqk6zYbB\NI {$ȑ>L8qhubQu1scg+9ZV e6x &m'QΡ/lΓ6N?H|llmԫ lEg?Y=7Q,/rNhi(æ(JlcZ/_ :
+ rGq 5p6QBZx0
+{Oi<#|J}ӄR=*ɜ<:g8ޗ֗1bhAK,^۫FWǙ!Ϧ6QZQ,#˓ȃ-JP8nσYA̘SGJ\9SnZhNp_Pj*8iRP!"EĮ˺33;G̙]qt3+(UH %jH$@ w=~{wf(;+v TzM<gU.J3V1<aHڰLQ3o&GZCa]m!a}TV3>(!ɢׄ$i &E^:*{N crPyBҦ
+e^;N^Yuҩ >é{}O[V)+v8~w71' <].?E+!O1IN&_&EeyULfxL%a@C0-u(\U}"Jui5
+w\ & Lǟ!j "D\"]ԍd@3EOi">`s@[lp=%j T+JzRP|ZPL9#~D(5?s | B<+zL$/* \$zp'5A?AC
+ {7|'#UYPYQzV|^SE\6 l][
+
+U,m#,s/{^|Z RDs$ @tI?%$J+e9J앉
+''/dQW'c܍JB|_FH~Fq$eH*#q$5 dI'&Q*$2$hG$s 0ED#DX cl"!d)jEOœ1%_P%G#Kܐ% {SrwSrw}>sc<؇elYuEi&c4֊MbYfLȋsި$1/*c?.Z8X;\󅥴{{Jj@%+--
+%+[FΣ8,ddND L[jVcLO&%'/
+(2BxP݂X%ABGڰM7=71
+,y{e=l垈'qYZ +8BQB*E07OH#Dp79y6g͈uPF?\:D#k$ywo<P|[ckn0W&ev( HW>2կWG|<Wʣ3C 5+CᖥylnXp&{Z³M+b)BOn$Dw539G9Jr9B
+ZCx{@ŧHD~}tp ]Bj0J5zRjt0:߶tݴq58w6NA WMt`o~hXt7]BEdPxH@cA<8nhԵ \BzB $j@i⨻{7yw)*A "-@QNAElZVڽ8of~f7qx=I<Ofg#Kv p<smm:m-;|p\{C7k|ujGS~q_%8g=G [n>櫶=7mG/<ß}ߵs
+YVa:/Cr l3p\<o.TΗ޶sMlD1:bS}[olF16?.H3clf# (&~M{ރ{!JβrVD(Nwr(\1+$衝LjϠi|ݷZڽ;h 
+:c6tCT q! A%EGȚAtfGRKDEPpMI5C8EcbtXv$0Z3Ktj Rwuը|]%
+˙+
+UU؂\U>G $DZ>Kglm
+fZj*۞6GbE+}3umhF'(mS
+RqFUыS}HE
+ch(1DbjD[|@ZL^PDbh$`w m*3&B궀9!8y-b_諩e{8ѠF+?vlӇ!/{a/'BG=HQ_ITDLdpTJ$K%Xcdc$@D7a@gdztƘ
+y,.?\c^~l}?.]zG`3'O'H'ؾ=s򯕟
+|{ijr\>*|K+]{sF_~rMmYAЍٛ6 @}[_P]{*Eaw5Q R=5d
+
+%d
+5ϰӕ輩rD ](˓Jw YՀ_$d+*F 1gGLΫN&w:E͔
+"ea3SpWKd e'<3rd%,yPW!"@/9 \(hWj:{vvujW:v- 2r'BBp$!D/;ߙ7o޼Q_ߊw"tj,EӁg([QY#'@bFRr_sg5U <@Kj=\G9E-3CLeOʾ z%S5P٪:R)*&L8*k$K(/2
+{V\ y\[|?'O$. nj
+!uZXI4g;gamB&VԖfZTɠN?1GrFK@3E pvP
+$ <Y3@لӶ`2$Iδb  󺐸qjjo9>>4#-S #@_Ӡj..Gܞ)j`ȄJ ӳt-m"]6ɉ,:ZGpsB):i
+Ilˏz9Q&&$rݍ;0
+YbC)RpJulT0;<w5`pdA,'D[iȵ9OػY%_T
+kTF%,yAhqVQ
+罾~swN" [tYqa֊ΪA@AgĘ %ߑ.r?쭎U
+sZj:.yTYź>:Wo
+
+jw_vpzw `})jćM%Na|z(ƅk''c6x1;9mJKr^fqs!ɢAvB1-Yg҈G> ]>1ՍǂY{y]֖/'W=
+~{mf}<# ME J{7"%6J ^*
+)'|3uZ$vo 4"{ Ym6w@DCuطs7 "SO[`)\{2j Ώ e=UKUЫK!_>iDžJ6\}[i}s݀K|n#!6 O1Նˡf.qBē_Lg_׿?޸u3zˉЦn3ŷÚѼ(Y$GkƱQ)}&${rX57%AθMU(`Tck,7X#=J²'9>ɩk+{|*W|?Q~5
+\n8l=:""Ж
+MKo"3D1Ddy~I>{UVF m`TUGHhӓn`
+[4Q ]r=8+IgbO ;toMTʧH_znFtO
+Hf![pwjbnj NJ;+
+8L4j ‘=+xQkZNh܎Ab'ƈ̭t)j⻻1…쥑ìc̾W65wr/K[v+oork?o}rF8.u3{4 LĽ-͉'f r7`2$z
+͒J2L&i!G]0˥ClutAZ<qd%>aîͬs!$%4 #D@izs6ƚOuT]P[b"jidMHnһa#e40CCHv212K!z-UH5$וS^͟F[?:'.kwWu#o!rSUDFWti*a%dV$;Rq#g)ĴwtBi{k=5M_Q'r*-@fgsRFgc\J.e(΍6ᲽX&Ւ5ee`j?ae?sePϿrep~ȫ^{12>~7fZT:
+>
+^yEkԁ7>ٳۭ;wzֶ-jw.[ԁݩhJWV3 0/3p+;^ty
+J"$@B
+)RAZ@`٢y;͝z:TA::tRt.Ҽ/ͽy&Y%L ؤw(;~.gQ ,&5P&ZWю 3VJdf簽A0z{'Fg?8>?c5qFi.RYL,7T{U,\:Qi*(@Ņ<0irCn S$bQD̛G-]m} ^$0Oxf]Y9/P~+ TX4iZ@F?6#_ur|f'-Q1hDOP',z83g |8 ֥.^}f3fO&6SOϭ f-1$+D7JJo͟\|K/n{|t\Ϭ&Bev 荑=v%vm-fGe9o<te,d|7=Zw5?˾o݁7s4z\MA"]Bl cJ,^'
+PR-!D :``Nv =6I;< `:{k\yvkMF]_^\vSgVr}wNO?so?>h-3
+[@XT *W" eei+ u$$"kǧxa>rOL |bt'$nK`vQZX=YqHXV* g*
+CKf NmzRAXJ|X40DsaO40 A !d <;72gĮ]]muM䯣- JN2wz@nXdn%zL}/Z
+TUHDY)VV[-ʓa
+`XN&xdM餤OG#GQ|zd5[V*)LrpQVE(
+xVYlNQp!tl@ `P?!B8BObE’E<Zd[TDG$
+I
+[;@N%z3d=̼g)e+yz!ވ?3z9ߴ]ɿ~5/[(yٝKVV`SF-|U(Q.!)%|ӬކR ~~0XT)7pƜwF+ &[dl}F卑9?Ģa{/;|{(rڜqm/ODMEOY5hH;!yfZ
+[H h MX54zZ
+>bCC-oQem{<<&n/0'j}/G՛nmN}GAOgtrI")If%2 Jtl*?dh<(CWN vsMMb`HM,\G'5@D2(
+`3(S~:[|P%_f` Ź eX[O2ri#O'Lm;|_zy\"&ȍϐQ#c?EJh
+!devvMV8x{3XceUwcuSʏꯈ y8~6Tyddih\>ÚԵ/Ya,%}7KuWoy'K+w+WJ}[驪
+3epNANFLAc&i& s;Ͱ,w7 ޗn{_ZURg2bcF AÎXGx2+v VjC̗!p5
+r"+֪}O=X h>}o+[nj寶W!~ߕ
+:c3fx ۱?pupd#>{rU/.$7P
+ZyC^J7F ㊆HC%ںbuC":!!BUE=x@Q/
+͞ 1\Esc(P
+]?Ɨ<?o/mA=LPSc1cB\9`!d7MʱfԩIA) <oDj/O %/ s/ QP#l34(Tcx#\}=kjB,M<[kVdM=%pͽ8ջV!GEYX?,, E\
+ ,`'m
+]-St vA:1yv :IKL Wd>mOOL*s]XpH(_myvEw|2|ẏqirZS+مgrm+JȼGPC95NIe6RbíD`eXHlk,ҩl$S??#@`n]/3mLHWO
+z%#
+7^'_2\#NFrpVPΙg'Ğ1&TP+Vdz˅Z<3fz#+h</I.<okI6r V~HkUZّ&[?#nfv)sѷMm>XF>ssR9؏<kâgңY<?-CCkiҲ )ViasVTA@aLP({Y AV@j^~X.kG |x`ְQSY2ӭKf
+ ?[=QQà"' H Q:5s9eO,V~(W_J~l\϶e??R~ᷧ6_,iWQAS aB,,Xo-HI;3
+;8Q_0ywv. #^T;{?G*8+<4I^AܲM9SFBRhVbLxA$-  #+ pO;kLX&t>273 ]t#"6"ؽp;P Ȅi],It֣ɢo?n}!ܧRUєQ%e0]ӀVjhq=YC$4Lb6
+uІYzF>Q)FHԌ1xFoS=Sd΋9U;BγfdD`ܤ#⚊[G-
+;
+)4ZO2֥=Onw_8 ž)O(Bd$?mެ.Kmd)vł&ii۪*a5'3di`Mk*61^yY7'eyRj9&ȱog^OiB׭RlH`iqJ;fJa:COh|>T`Ma =qbInKoPm.&RjiwwuGgzH3:aE! ?IM+}BLOcqo /<|oUSk?s~RiF8K~.@u9sc;_Ew̉":]y_ռ={Țx ?!+wCyY܉l n/K0wvbݦ_yXw ] nyGw"n]΃8[GgPE$DĄ
+ʴC8<83K%ҌJtpIU?j\)˫_Y 6њFZl4OǪ&rUhexq_4Oޗf/3 m7>(wn{]MTỻdMv$}p~Ý༜%m:<߭y̱n2cGc6v%zQn%{G=Q C8gA.GoEkyibj ~J31
+F|&
+K-*5Kwgu2G~7ڈW`L&3revV&5Ñu1\|D6S34^d*3U+7&OJ*z`<_zmHՋ~KڵJB.?<}W|2rDŽ<F3$I
+tC"/vz`f',!gp(D
+95>;ɛQS3mvb$stdnB26@XF#`pz4
+1h/~K*]ND /B1 \>}OW>s&k|?4&t!pt0绥
+V?~sg>zq
+OPɸj+.U4Z|E$ NG߽uڲ:;mm~XuYC!ֶv!ݬ  eVb#p]}b}鸷~juvYz.E}]FH,6:W^A(hyt~9J$t }}[:Yw癔1^X;m։"3-2Oz7WOjߤ&nI7gFOhLkIgW+Q?[:Z+Dre HGSٓ%<V@e |(V3_ġ~Q.0KdO:NTXhk|+ֽCPq O dbf}x4Л#FQ}p2t ik遴XPz82FzblFAciH
+;෷`3e;w{7޻?{}W|~x.k5Y$_B h#&zlUY6dQ{SAr}`K_\=4%Bf5$`ԨYuʳ6:gKdTa*\7Еősۘ`ec;}.qgX|ħ;KH̖)h[@A
+5Ū{bU >2T"^zL* T,U#㬺%
+'+SDT Ɯ,
+bH_͛.*xD}+K 5ג25 FJ:Dí`k
+"Su6+& &mmEMb6U~|2US?~vew kBj2G7Ɍr,)G
+`*\AK9'贩Vtd% T@U,e#3 jMWheO)g9$S?)KC
+2#bEyLwg#eonM:v'_Qpͥk?2J3; JDroEATA}0ݘi6nvNfc41kb@ADP@ DᴝfyoK(Ҕsū3EχRE\f&N$Ē(\LIet* &eBSZ0s~UĨo?VzzDnyigLt7֙R=
+q_5Ju!AL42q$Ϟc5j
+ eT.hj S8@gG Ir*b2qt KMvsԝD>@#c6єC6:yiaȇ($$"Q1|ZK?|r NEGMh6eudxޡVwNN>Qutn5xݕwc2k6Ҡ:(bD*f qV}@9?o2ίG/bk MB`$ďUD*&#9zHz̗%jEeg_><nYr`exweqESs[ʪҵ2:YuzewvA6#1dvvs{׭ճs
+kD"3Ъ#~V*&?Uޤ+J4E5l϶ߞz#ɵ{3ѡcؾq\Mn[L4'Dj1oVAX9W{= 18V]$jEG RYQG&e
+5Qx4%H#`WMoL5{:
+$1M4QGBzw|'>s#6ORG+ځ+t(bOR?eNƀi~P ]osy jbݾo@}q{3= gYkn,SK+eÇ`5&tm#.Ck5 i@3
+,&qI_w9u2<[V$3ݓE.@Ůa0
+$4hx: DyBOyKɗVG`e>`
+WldfH4L
+K?K&|tɠ WƨBTol]+ k֝
+L| }E3Rۆ.Ë]hlk[L\ 1gP!e-+OgdYu^J>. .4h[2~g /\ _a'ʅ)Vr~iQJ`2 &=D0AyA&)ĵ(I,*+Gei4|4+̷qogoECi?1gX;0KV;#
+B1
+}ƴ E^/Q/"/a⏼aTc 햆ɭL }JMT<ꌎEЌIe ?kKSe~6\IS9s(
+t8c,
+~HkxU3<7Hbr;`yþ]7(q_:s/Bp
+b#6bC#wωpk+"÷9&KNt츋\(ʕtQ5źN]#H6zuY9Q|yjw(䷫+NucvpW+$w&!\S{-B젽
+3*Ks`+-~g??h:;+|=pPy|h2?P\OQ700^ɶWC7Ԟmoyx?z?#صp':#ԔgOJr_<s9&<w/=&$ѧK&H+8 . *]meKt\&&+(7(
+FP01$13&lmmmL~ک/Lhbx7(Qi@Whtb&+ݪu; :Dž6HLnŤNvdZϮlb"0 c*'i>?~0L$ PI;~77ɶꎕ{p}sg?ῷ!`ylOE|S׋?ntz'ny'=Vܼw<
+zӄ}<V*R]i?WdhJtQ½0}Yw a-"X쥮(#L4ӊMsg;9}@߀]]@Ѽ6RM};웲?jhښqrp6uQa
+dH2w &ȉYʠn@mbKOЏZIɇjc, EɁ{D$ƛ BcXcl´ qlq\6g`dFM}yIP:|RZj*h׍L_X~+%[ʬURG h-iAN5-p
+2X7/?t竧6777\;uĵkG7Γˇ÷VmTԪ5pLCa}9>5?gd 9`R03m\:--́R:
+֑3Q28?ԙ G8qsjbh A|se/@g1O#&8'T>-zԗ5Ɣ63;Rn+SM25޶LVA?iT lQw;?[zJ%tr"-|C b?byAU'awS$}ZKdY8Æ'q)n
+
+bٲw5cv֎~<pC7a.Hźp5o#{p ϲYgym(l˼pWY\+L:%t9ij1cf8GqVqn݆Fl}L ?\ a\Ii'bƵ<V}C ,!?=PR^$_ȋ)J}Uck3I5'q Χ{Pg  |rKԤkAS^]ƴ\{Wwn9^zd+?h<b4]gF iop-vXu4 2<R X"dM &eAn Y 2'֖W<wޢ<VNտ tyCਆ) $&de/uIGPɉxPؾ։,FdzD(/K&N1RDVZg 36,v߮{4a}AC~7*,@<v`C $ W ڀ`!6c-8bD ` p_i8m7b(.phn7U3AuͺV]V`>׿f8v$ɍlʇ)??~
+8?S
+@'TCX^c.ALK$coi܃,e΃?EWRW?($^P>
+;zJ,QׅꚂr@ڋ:]>i]'V{>㬀rm
+?X
+C<9̧xJ(="ɪDo>%GZP
+U>}PQrnMǺ"k3
+#%&&9ka{X[;eB8
+!GHM`qU03@ݞP4B-R2J-L]S@f Xw0 a~s]Φ"̾^iszx3&VhKR^jj(BC'44U^y . ka1_ ^6f7s8omۆ]0H'0FG@@Pe(19@P&=n@/&ꥤ,C?NrNBR28M*)ID;;>O`+|w_<d%)kSU]Lb>Fq2_(sr%\VP!oI;yBxӚ/}H: J@D w d
+_Ii D((2e,*PV!afa z@OZd$<_T%vp8q kvx/7n&+Wh!TFOkHM\FLR@P9!`L R},ڋ#:"wXCm?B}6c@56& Mso9q^%1} 2H$D"'tp-5ϚԵ!vm 1bmJ5[}W/4?P]7;ںʥg윃Rَfv?6|ww~w+Xp O=<NO^G's۩'lyqxoy%²~}<ٳ^ [CEzt|`cN(pÑC$lCd޾Ÿ!<kVl*\| ]mtĺ#0go/`j6a7 !N7~ͳq"u8sYz>?XE|lT[CUOT1SEaQRè i_@qͺRrtS/$'v/ဂ#% aKYamm}?_o<:L]K¿f!~C+~ؔ89lM mr&?P/,Dxgue [; X<Y:w
+ _mWlaБ&`,_Q&.¢st,HE9oeɽ#YIoG3GTư"%qh߯ILWs/*1 f$tpGɈ>8%Ê
+j Usp==ռss6(gz C-P sucSl⫐rcChyu|!pKx{!ۓ'%\W7Ukj72][|+;5FdedVEunRL}>c{iUbEl%Wі4Xp/](_"U;\:TIЁWitH!0\O$?/ qωqys@vR\9.43k0F%(**Ḫvn;LG&infkgTT@1x!
+=UfyTP s "w~
+e93= i@݉%S`fD*,*aLZTX{0*g# sބqv$ψg sx;dIQD#s]``H1k
+(k]*[
+k>wN7Z}௽]ؾG-w c욑Qn֘Љe9v%*d%(Zv}lt(]呥^Lš 2*vz$PEa qZ#Qp-r5b=GV>gq 7`w4bp:n=T1{!h7L% 5m{QXj h;妎G7, Rhh#p$2>k?XA^YiGau9,bl}{-: {#kؗk!+OCH
+Ct::4Ơ1T#4N71V`U&l
+ P~E+
+{ ~jaY8eGp jCs# lJ ` i1-STI˟2fci2k⹘lޘK(OQ@Ee Jۻ*J:ť)Ao=p/"7'Pv1n6+O0$fz\`
+{O$D4nqm a3dq sڐHz*l
+61t!SB @@|LI}4tjOiCuM]q8@8$[e;5gξݷo~ːͽ507N>?_Nnl.ob6eIX -"=H¼к1m.6Iˡ2PԚ4hfv::F(ɃYI :TmH\OY o\"Ds:1 c{/|z5D>{Ճx%~ ~
+Ʊ Yޤ}ao:LjC3?.ilXJEËxE\5*Lh[G@z;u*beK!ÃB)q.YORDŽ#B=G߷WG~"ƽ̗]iޘ}oޒw70/@ށ|pw
+{#و:EQgYc.a.>h#@OQD8Icpf%j`ҭ8ehcF<2MMt㳧;FErd &s&&2_+Ig P̼QMF:p7X@ߜPe=QhOA²Vzp"9/4(E 3}8}'F;C:$xDsхK}k d
+?{oT~7w  v
+vT0v_k_/^ծřV݈(wb.qtls4݊,]E<`zG5F
+g@KU6黸K`
+81dOŖt(bNe'V*)Y"KߞT0ՕșjKd ]
+_/N~H0U;ÿN6-ӉjR>IMC%tsvڟuwMxiEXE(U˵I\˳5c6n{ =Ŝ3?
+`-+w=-MFi u)<
+(')yT02 \h-r>\D.j4$/r6^^ ]>~!oVP9wm@ovV:֚IIí\i wdD\E`kTZkz|Xgj$0H$;MOP@ώ-G
+b^b[qYlM2lJL~,=<ފ}5Je0j;Y
+
+ܼ <<B8]pp쵻z:|$x;s.[Z(S^9pp-WlN@ LNtHBm&N_P쇻Oqn  6g#ngZ FS)Y]Wqr\ "-m\jFeM!X^b{Y^Ift43~C:nD<I%P
+ۯӒsn*vu`5_/0qsq ] I֤391>M.$!FP#d!t !5G!+Tj7mكXܬPȚcs˦ߛW+ށ]6mn;m(Is$Nd4<敡aYfDLJMIHJL~F##ɗ bqb^\N闤Ӻe,R\a8"2OUo!M&c o?8;@6)|:c|.@';͂q<eEܞC ךO1wgEqǓNt۔{>/% ē*X[,Fˑ<S1&Ftˢ&ɏoȷYsZg'x M⒄qY\dYT8UJ{"ޓ$]{G.dow::bON8z:!j6ftk]b$>%1'!Zyt[Y?零9Ypuݳ:ylA\ G'N6G)r|0&7! L~'[:0:rRaDSrSB|)b j!'ĪZ5uChZi"[i
+-QׇDoDCZX=L?~ "d͔By+$2mt
+=zkZ$J49>k'\eMxtMSuCJ1>IނQubctnE[&"WI06%FeH̒2j2x r@9 I ֶS[iv`F]]]E%@BB•@
+
+\>Lw;3yy>^jNL*2< 4Va&qtkEZO#/.DB1F~@ <5*D
+i/w]߫KsN5]pywꩾ̼Z-gRjѩ/%>B[GPW Qwbtӽc^fǶhR,R6/3r-0;;
+Y@-髣+4Ť![%<Rzyw4`tZo_mNIbVW==]9#<!jbA癤48D52-H$hI
+04 _Lzz^z/<=7f@ G!4FrLAn֤%4uqpInE%m"8kb2R\^Ӊc
+8#ťtS3_sZ f:l$DVυכ}ͭt
+\zl{ص{ɐ#> #xF(k }yKo~*ӧݣkճLѬ70m[s 9 Ȱ=rWya:3(ex!E?EVAxE%l\L[:-h>SLN&Hi0VfrH ́U U6!hD-+~"+q4ɉ
+Ŀoo
+վ 
+⑘NimvۤhP@AED›#*Qh&麻}~y~h#9"d'0ή#sc9f};؞rNlvU߁o6tFArI-5b
+JŨFZƑd6:`Gj%a`Jlr,*MR<G4tԲ1ߛ[gPg+EnQ&UZyh=h,Ë.Wؒ]`l"G>WE}#H_S\*YU¨C0R<>2O\/rIqU^]Q_OGg<LY$̈́'Γ&".'
+WBWgxd3 tp^ps 8ځӲ$h; ,
+/ib}cj(e}V}2(ce $-DB k rI`~u,e|\uhgRm!w_ )RE\*<P:C/ } y8zsGy@y{
+<rXOcUXuGoBӗʿې@kϺěK8$޲<L4"Ha[jUmضf׸'&c4ԓ@6"~xγ!X֚&:}}_i&pV<ƽAZbbZo )C1<8DZ=Na}pux1>B1$5`<,*X*L(x.@Zpl})`\bAZaP $"r&cW5k'ށipt`6u} _,<Hi$
+vq.foL9@\$Fe w)WAE|s,ǝ}Aз
+tS\ XA@|{P  9щׇ'CNI!׸0ze|t3ڝS54 C&Mg'GLd@fw/,ϼ$1NGr
+퍴[CzQaf*xU6]~Xê6rʌJ=N.\<nI-L#,<&2 -qS`cۆɶ k/-,0V-<`[Y0#Ky)!nabr`oJzf )\|MYYX=6|8~c`!V4))}l[_CQ h'I*\>y>gxŮO>?>>dYƯ
+* ~zqvl#$oI$^9܏I[i8ІΩd2Ђ1Wj%H 9L)B
+/uu'1iKŶ_7w^e{``FZcpR$0zY[mD5Mb5.
+6&nmlu3:
+3p$#6}Tfwd@tdH
+nj-BU5@Jv)*66qClS:-8m2j*I8rC
+b@!fdD,ŗuxy>G&gU=dIJ$[lHUdG/4*ihԊ`)4#M-@u34G}P!rI*)]К@; 0q7F<]I#dT?W^ny ̱SP R3'dƩhqjy~Hucx`J؈ۈdBﻜ]zBIQy\y_w =w%gr(^sF(3ˠZ\Rh g-JB3݅WY,~2ɩ[ɿNA璽u%S?F^5T+w0׽/^t?~䵋^Ƕ_\6~ px~s˩|jh;1b  H'T9$"q{3e"E\WU 3/B}vCNt]} ;=jxlxzj.y{'ކex9@~JtVNhv}t?&˻w׳/YYJ.^Nn+|Z#E+5`L&yb"U6jД5hIPC2RkDCi30
+ X` (0Q
+d>*ƂτN k ƠXS2"uRDDPSq(>qr88!fbB&f 0ͯnԶ3a"`L3hq ixde'>bamv=.dB㭦(xx<~}k<D&LFMChʨ66Jd$2OO&u$֐LW+1K+d*[;9&gG5Y 1-B|Ah rɏ/:t
+| e'ǥăd2s҈."K-ըrK]tt=R)0FUQ%FD i 4bL K&
+g>' ϘfϴXE6Idc X@oVY!ԵQ];i]Cy2 j`+@,IEI`\g)"L$*A]H#2k1 A Uh@td\o{B
+scht^lv.ݢz<b]^w8ĭ vpO꛶o6-w/=Jgw%*RK7jYjD$xGs? N ״#"0 MͦϦ=^!Qj)!Iێ+T &|ff`|Ӎ>i*X·X'XS(D*&'1
+bMv#hF!,̤tÁl}<Xbr\\i%y|eUp?ـ=: -ӏ9JDl_~\]:sRv.xm P |vwO &.oOnW ,Ah+uw%[++_CJessA~??"N"ON֐ϩGim=7Uq9כ-.v{jמ
+{ikЀJ~4{G R}M!/fr'L]ƀMJSh׶
+ޫȑpy.}LɘΖU_:]o
+L&R|J !zCP1Rɱk.Paḛ:Va4+_
+ %$/HE.y?}߻wlb:p:gl.to"w藉`>Y<\EX}tzolƯ*Ŏ]-nxf`k]yrd{pI\&S؃Cej "}
+YML_}bxP5>"Yk\$"E[`nEM*,ݬ2tԍaBZ ȿ ˆZwjD'Ɛn Ͳ(.TBEYE(.+
+@n2At_l_gzٿ]evڼj}{?mF69[8Lv"w#>^ X> sNxر7igs@>YHl
+Jh LlE$ `Bmγ%$·P{*cv 4>0vkJ Ox>w e P޴Ǫy`O,{Q^ \o.MG쫮m/hUۙ˪eeF/YT%&IKv :!F 0TOCua<{9t(,KE^7RsE縉/*pP&BDž|m4go\ rQf+P<U5'ޓPE]Ty[l_TzҖTY+ݛXo4o[77x,I| j
+ bпm>8[hdHژgję;4
+m q8i_r0~|g%'Xle!k39᪕#N8 "6^B@ \-<۠1: &fW! j"ě0i)0)B&yXQ5(K";"3|[ ;) uTx1UA\[6xy:!9oT" VEÏnN ] a9⹡?zp { U..NƝ4t)rة3C3_ ?oĝ1TYed΃ZxCw\<c'boꇚ- 7]!ޭÝsyZczxRkaѡ޺}wuNk>TDrŔ>)B"~ԿmR{R„O#g=Bߎ}|ಀ5kXu_{}v~|=EStOR34Y}9(~(E<ˉZ"gLo &Cu9dDB6N \€ME &*'d92 4L0ÐDQ3⺺w;X=MԴJΨ"T
+t{>m\r0Z]j/,9j\$%wbh8̣[nK/_mS-W^m~egy/};|aeU\&@Mdie=f<P@ }
+Ez4Yަ v!GVBm6D&DFEKkoLkFS,|`8yh?؊Sj=*:c@Uz W(]zJ4jycOf
+# tU_
+xz;G6ŏI\9RaAs準3f3
+UIZkU5c;@#R!zotl"DI1cBrstSĄdٽcQ1O$(Έ̍=*s 7EwGUNx$@ǐ́&2֒:\X+ T@k@1oL
+1|S0
+FVon-?C:_*04c>>*4P3LULM[lk[O+SuKό]gh)"L:L>Ϻ>G9zXC;2pz\s|D{rL{vr d㚪CW7Nſ9E} _$a.۲ID.6sݒ':qUR_YG]`*K;ڟ>YX˅
+HJqʚ7w]̓9GgO_:;x1
+-2kPO[4hL8&bFIap"<F$:xNIᶉHQq
+X@
+ݕosEɆDPI:IFNLv_C\9&ZCͳTʗ
+ra幛f|:H9Dj"M_z蘵cb2f5яmqok<_劺(0rEO]qVO(8!ri+gQ:x T7̎I"1`xŸ
+fW}
+Voy_Z7X;Mv?_1P2B,v6ARZ5ŀ݋y_MVKJV%@ΟЧ'?N{Yc ɫ l = +6g7~z^۰KV6y/=`~N?h.K$OmWS9fueQlj\0?t|
+C-<  3Y3jK+V;_~k\6M ч{gQ9N w,BzE j7@֚d&dwϓnEh;+jGV?!THaU6^fC[BDH<ʠx@JXBnfC)v8qWHV0D21 ..8` 1 s? ?hGMtM6bB.[*>.kG\W3mDZmT,LBCSA7%8C3Al"GHy 5C>ǺиɽC<*:J !flc X#& xorwz[e<g>A)@׸sѷXW1VDn<It
+c熯B+R?!ހO`o.w'-|smgsoet
+zO 껎BcWnլ{k˺oZjw0u/WeGS[ŢvYH& BY׮J4"n:$4dW\]\R5yEB雾ܺ`ja徢G{ ~'\?_~xi|PT|Em
+]"K
+Юħ8TtG .шAO#A gMQpmD\^
+H|ֳ3ՀO'q9b[{iy@X"T0Ni83
+2 @BO JxEqnV(=<@$L$]kmws93֓fa@WKpZy5Q[Hu
+\ j|r9b~Tt'磏j|<񏸓s'5g#>=h,$$rv9>s=CAP*m_A%3T,A
+&v^b=4;k磛Uoįy <{D.TKOڭeVYPL-\2Y/3_Gk# -,w^N}u~pt;s|/q#`4ixTJ7?˽t"@<7`@3z1UBJΓ_+5Gj[b\:'\@9NMʹ
+*Y3
+ %c3$xv8POv9$lDv hv> c
+\'*
+<տ[hAnܓ]㤿
+EZV@"Fp\^:Z)1COEbO' pV&%
+&EagM~/;KOȻW@Xu׳7o{}B若č $o$XwLI!P>7OF
+RY1rI\ A&= gQ~
+݋j篞鰨-qa5%u]Bm{2P}-sf@CG~FR28/D&'z{*NS
+Wƨ-Qytl|#h Q?Ɏ4X*=i
+|ܖEeD
+. @͙kb-t
+d {ΚjeLm2;8mT߄.p6|H@ꪑz`cCdo&VhR fÄ`+όhÚ6f͘;0'Lq`Y+;AgMnJCtmuœ}UEb-uM.&YSח#c%XC
+.*Pn/i a1RdSFJѼbǘj|0RD'Qf(sUyuW9ITUC2ʅǪslc 'bˎJ.<Rnˆ_/Y+m{دe{O~p lED!dк6,F˱!%xߡz9X#g,KKeASKI!*9j1JYWU0d* P6?H&c([I{J,`GLÝ$p/sCQ+HTnkjZb S'$&*
+\<\2_Q7Z p1Cyszg[םtgwW(Wۯ\~O&^We7˯y ,kWI7`WE`╅h`{d}l*. ԰ҔBFȒ̆NfJPsE;uvZӀOM[&->?oe _JӀT?Q%':EW
+=YBg+,S77?]8幛|e–5o e~ai "~-7 Ӎ?dv5)GuUz+<bKM'Cp01E05t
+fJZ@\`}[e)FQFJ%
+󊗽 1oZt\Sgk /͊o) cv.|l
+H `f4I
+ Ka?>r9Tjn& ԓE,I+4xW<&+ @;{=-q4*<L\
+x%MoB:"bq9wm7eQ, 5Ti ixprg0o'<ͼʈ5f϶'Ws~=ma:q>Nog @,^Eə{G3ƞ(R Y~[J>-JTR5a)AHH?oYÿzo>sSN]Ӂ. ~ap 2"; 6m(@
+;B}]}85Ԑ̋88 P=e>{ (2I
+]/n}g}om!)os xN Ҥpn{CUi> 2'V#[<W]+m>7M;7X'.U],N[*9gy2TBPReAk`XE%/m'U?ޣ7jW0nK`c_1-mmB)9g,]7KWyZ$ճr8^!NrqooX?3" 5J8ǤjZSCSHJb41֣8H
+u`5|<Pai@k+@P 5iIr$t5PG t4W/@ M0C#:$WSjPp->
+%X\?J!y )`xRd
+l
+LYR\cb^WC;މ-eh@\7Cۼzv-thsjw
+ js
+<׳5*ݴ:g7,N.n = 
+v xщ zх
+4 `
+19=7hǜ3)ed}ċz(c 8FPFHc~P+Crᒴ_I Zl
+{
+ƛ#mC} -$WjX6ъ
+jEt[|ַ<Cke`r!uNQjDU
+*rBU@P2'L,B{|d*qN4/a6vb{zWCVeM*p*`wgB襖 /%5qqr ?e$jQ:DK :.BFK\Y5fO刪I@hw Ԏ^ڹΣI:#ıa!=NBKP6
+R$*n ’bZRW!KFkZ\QWAI
+j&ϧfJRNH'Ez.{D=!HTn*hǕ>3/^(wO=/̫<o f3 ^Dɑ\^^"\QoC[@wY\l::[QU3y.flJDMs:|JgQBjڳ?9j.p9zKU4(i1}ѼcV+mL?iņذ7yl}?Ϛu0q1k*mm9f ;ZT+=Agnfņ_?m飩i.&<C9:^(r@rr'M ADeQt9vjukwvwvƩZgrA[}$rs$CC^*Nξj߫ׯ|@9t}uPHTMP_AUdlHXS]2&8;!́u8ÌLXB T M6%MhCStY[ y0;C@N~ Τbl;pH04jPQ
+Z٣y`,%zF.&i#G*,T<DqMrqNXYTYpW8}2|s\Eghb 7& $Rfوܿ#1 enغymVn3&s&YT Y
+ۯKHT/VoPvjQ&R z
+VZm=z׷Cέ~P}slكYwSH񶡎/4mxՇOSpvrkנ.wUlTِ]B79n H}۝ZZkoR[(}!JcyJک_x2s/qQ4F/[ՌtU\<V^eBhB0U
+O"m )V% I*0 j-\Rt0v$#U&3p8&5'Q.VfGLuJ5YPiQCpO9 #gSPV-cQ9:
+BV˭?Z`OkqM{WsKL娻S`[ZIlTwӄJ9 sW C!M=y&ᖭzZg @73O/| •~X͙_Pܸ\pqpHLt[~&S PIm̽"=!k?v 1ݭG3ZzrU#e_qG{[oAw һ ;x3y}| !:]J]J:] !UŶvR>_;]J7|߷{*TY4IarۇÄ a?@{>쓛*]znr߅7fї^E&VZ1>LOvױ%iRQS !\q5q[>Y=Hۤ3
+2- '/گc/L\<~
+ⅉJ2
+a}(AIޫѻч<G_pJ(ŋUI!}(b+iEW)/:^g?[V4qeCSM(GH%n*WhESqґr.DɈ7צ -Xh qShBƊOn:tDwNS@y)R3VXPK,^Zj?^.y(*@-Fס RjAIR
+wX yNT2=Xm&߂`70=czN;
+:,a`P*eb
+42S
+9BF<βH F5ڮ$TYf^h#hmV R}aXb#zK3F3!l0蘡55_xiw )v&%M$`@ݴ,H @GD܀[J1x!m|f* Kgޓzyvh=a~L!?h}j?NjާWw ]^nEѳUތ(o"èUuRVؾ,k}]ִ*"c-&{MM&L~sa1yOOy`%meoӟt_s:`W)^ݽcWXC6ox 8.`xu{mKV<ڐ޲s[{4=hlHc+ZAތj (,+ƛq:~* /XS=7zE}0Ü(lxc;($i ?^\c>9]
+Bw BP{x`8Џ oύ鼗~?kQF(0u{)`9`vQ$bnb
+&<;GqsH+
+rQ6.c!d R/zO9bs\V
+ M8 ,go.aC0O@<~P}cG,D{,c^^0ihIdZYcL[ #ϲqFPP/
+*fAL2J\\̀+iZT0Ռpk;s.fzDCWhz "܂I7c"c'
+OF1_ZD[kO}Z|տ;t}_\љFwd;<27z
+`8:40|ajs0=|msx6Em gi=~VL&$}̉7x4zOWȓFG?ƅ+K'%xZ쁞:"yrz"QuP
+!)HOTPr5y }
+r#tY5%m$o%k qhu3)FDNUVRU+]OL>֔k+4n%̳qBIeO1v)+e}Nɋ)Y
+)=ӊ[sKˣ?~FpQzsk3_-"_R^%^VpAswN{_+DKP9RIc1!σ
+`NRo!yIzhZǵQYp{G&PN?tS#mfz9_zFk.TYgA.9BDTͅJp9P!.Wg^))蒞ordG|ݵ7U˞ltXp>mtvӟ
+濸.gd<wb>llr}}jծ6Y~]ja ڦ͛~7c$ OXJ? 1⇚q ?<~3!bNK<K#
+ʔwZ7;F.Y y(`
+$s!;;bm]mQujb Wpu:KH.i$o4,P$f Ŭ  !aF0A;T
+ %,("P}
+XD)H=C8Fa_c\I"e8,7R4z#]5KU:I43a Cd4X55IVG6FD iae"{{<7ۤ;3,>yj[ގNu(Vdzyr#.SQX@>MGs בIFCR
+^ ᪀Ý~
+d7
+ZR(a=Zzys %.-'χ{O]zax`
+5Ì~$RRB FB0"RPYjPi`Si8-AtOD`"Pn khHާa rx,3lDTLjG;D
+TSme~^-kg&KkYq#-l H5Աgh]
+uɷ4yru>(T]*mU.麶stCEKX׾ל ;V8 D%UbyTFd &KTaG_^ȳ+%[BӷFžiݑwǻM =?7x}]ia9V0L F{tW+Os_w}%Yaב7Mv@QSٵyC0FGhIN+QNWV;]ᔲR5mķN+޴jp\;ܭpשً溩^O%yUfj)ND3_QZA}X
+e:5!f"Й4@x9,cpooC
+!}鰾rPO?ހX:}#;۽mkї)P 6sMuflX. ,M-Y<m)6_w[כ h|yЕa
+$BǎR! !2te|@H7
+I z9No$P3-nΈྗl yyvh@|k%
+Oa$)\)Lœ0yr1Prm<-1m H~-LI&jnĩZpjBd+蹊
+@LTt1-TfKq2jxDWߧdkɠ4ـse ,B+_cIKM/V\%.QU']
+8%qJzuVzyN{z
+"Gʷ 3ڋz@J|.TȼgG24lG&}90sO UeYBf\x7~<yPŜ\1
+ "(W7ٜݝnv;\PIa *xxr
+44Ƥ/i<ͼ/Z\w|nZ !TOu҆d}q\uׯPsy)mq7["? KkCSP!y=ĵK=S eqY.Y-YbVllnics/MZb
+]H
+eB
+n* .rbG&SPCo,ێh'l,YHsc=FGOOpm7R@S8Ajj>OW!y:8ܔ70gnMs y3,07O߃?t>pZ76MVngLp<~i1!/V򗍄j
+Q f6L 1\2Z*Hu$h.6D׶X<tG юt
+ָ Y:c݀TXB+0X " ?\3IU8$:ԎMjjB32u)= ) DScrvXR#&X;~Z@?oZY[֩v:,nwIg=ioO(1M[۲oЗ-!^.ظ G z yl d)x
+A`0"o\lblJln]*f
+K~?m\Wo[ێ\mGkw >LYHB\67Lۼ6oĵ^[ZeU7X~뜽PR8_\pb1KY(NyžtpZ~ mzeXg7BGv={_gz}7m7^Ŀla%6A̵:.N-]4߄[6_^SM%||/]Ơ| xȵw
+>f^B&ܒ<Vi'cA]
+^3`%)p 5p+`$G_߷G)$hLxCw T՗_Cuؤa%1|j|><[!I)?`W\ci4+
+;(
+opqh*Mjji
+Du3)" 걌~#mqwAD%G?/v҂S[67زausC?o ? wYxƛy/W.R,|ė3) .wطroh6d<cF2 U~%|L/ҡ=/>da?M/&٘I.2S\., =Bf}E~5<Cw6ԃ+6(; y|(?\>nw0Af~'ف=a6dM]Ixd*)w/>cڱ@s?睯̝ʾebL_{ߧEG G꽶+lL۱4o{fu μ{-¬yIRcfȷ]F|cۦ]=1V6X%?8ZkYWe<6I{Y^Kx!Q^ꂭA|/su\#@f+0
+pϒW37PiLq@YMT%/IQybL̗21?<sŕ< L=MB%raq'LvVǘyS8SP"L ,v :U 8Mq!/\Y|s
+PFֆw Z.jm#kvϵDBB>8\wB\ xrjc%@`-߉o4 Oa'}޳^3YYo>ʀihgTu)%PSQ LC|V_{haG
+]=s L38FqMPu_ c(ka)zL%3UBT4"\8KP5$n@SULY$ ^e
+GTd`W
+7aM-(M=Ḿ4&N5@T4,K`BյQZs=Qӽș^W^?fعHTsJF5<G X:g8i4IRBW6hx+acDlDࠬsYuWCW݆avD-RDtć!o%*[<s")wOmǘu<8}(e+P!)z+ItCI0b6X4H {$h`A JA6EPIp=҅tI2^AQX-faZw@I8OyQ'xi;:UˊQGeB*`Jc ,>@jwO%+q)ỦJBxd14 b©"@
+[
+kw։rl9-p+6LAY샆هo7bv`{;c.C\QQ
+Ⰴɒ9M~9 ^~,(o36Y+.3
+sqQmM[T?7VKlߺsϯ@u۱Dgv-.g,P +16RnOA!̨PDq !Dd~b}n`_'tbvQbs" B >ƃHO{ϸyͪ'£v iU/7e{ KcLy B9,QA+JKI4a3`p<wLk%[0v ?|n=fF
+,b2o %5rbͤ\"}'l/j/;$s5
+rV}8MۮRœ@)^\&@Mg
+^5y])ղ:򜾌pAWM3eX[•$[{C`mF&/Xq> c1 e;Ѽ'eIt0t}9@!HXw˘~蟥o$5o Ҽ'fL(5xa|eȇaNKx=JAb46MJKic`s c(%ceԢ;T0BAKׂJT'L\'U_!xRC[eB5oo3&60fo9Pw|/xd`ۭb?ڐ FFU*CmJl\s. dd PhX!daBW3Qcb];z8`g_.`6 4FNZB:4)Q9E#)!^iaGAO1H-D%fF&=Q* tx5կ|
+ZݓVZܓW:D<}o\1_C_5Oïد|SQaچCdꢫ4ٲ~mflisюYؓW{r#y'o7~랃/",Qv:_8RZ~8ۚUN5d8ܣVιmEkaݛivR.Tv*4RJFp1 v`J _L @
+*y] 9Oʁj ٺ,] !W[?\}
+7C_
+[a3 =l.TF*RkH&R 0If)3 j^͙pX|"JmIۀ,9-<_y208"FLMi{3J)}Tg% D4}пW$}Jhh
+DYZ5 $Ii&XshR;vz/!Nζ gDz` "`Ls@tP lG~'mMn
+MK[I3XsO;ۍ]{l%'ś8ЀN7:tXV9m&ejIyRU5)e:%"$h$x4& ĆAqP+>^;)!sT!v
+j M7GGmɋ":d?puzIZ1lu
+ &FL)HLPpT?6$25rK-uDX>&1IgBA%r,(#553rPMr}!\2x8򏷻^9 `L%GI6T~ZYsFY&_<-o<-D*:I.xMSu -Dy3*^ցI>]xy+::E/@ˊ2D^Fjstu ] "G[Td2Twu كli-&Wz?_vۿ@V,TB)^{E}uQU_$/˯K.+JrKRhuDķH[s~/o6*l)ؼtc$y-%HzρChG'u'2gkfK -zl}Ե? q5a-yGڞSy
+4@<ϰ*juks&kxJ<#g"m$OmXF+s;7ʜ9clJ֊,蛭{?􂋧 sȉ0S kjϚ8-F Maf\vq[6٭ߵii'ڴ-hIsmv'AKn+svNz7N.am_u8/̙&;Gpc/Y T[e=x9٪ye\C:e?#μyTI@
+P%i7TB 'KWn~0\>voNz<8IVT]wD(i'byaeöW=}\a΍4s쫦1o{P &X֘V k֧HYmM[itY(),.q>o<8.<qu]EEyMB<,@@H R@E]vv3 o D!! Ԫɽ IHx mN=9s3;eAQLl8#[c0p1RG;{h5v"JHq錭AzhU^j sP ߍ#wJRCN%V-_oE۠
+}8@BZfM ԩ9\ʷAI?Oy9y8Xֆ!$ǯ @6,W ǒ?~9$?*"$>b C:!q۱K6}\Ŋ9 cuݘN}69 P3s9>L;4@(źXkL%K;(5XT 3
+2Cd5m,FDKF @Av-+\$[ lMqR)_Ã /wb$>#?sz:b&ipq|d|mtꓹ'|X
+ZzN
+uƧf#Fo@΢q]RMF@vP+̪do%?U0klmql+%-mi@
+Fڂ
+qω|
+ z&
+5U$!RṄI R></e%g/P&gB4 gtmCڻ4va)H3:L<ݠn UfC"[(Nr88{'羹nDS*jax:kgZNl/ЀVM|̗TTLg^~̝5/bZ<9vt jKq@NB E/dĆ7 nx:wu5jNh Śzr\J_ebk ؖEVl{7IBp Z
+tē<X"wm_.[;74m zKi8n&P
+k
+;Tb&XD6Iaœ̠/ӱ (Zp
+1? c{o݋/
+L׼NZJ< ޜH3'F2mb8s=zIezrq3mS:7+2mgJ[We.e 85/$0E-zE {Gl*(NQݮGIjL})~`k
+2Tj ; qf?ҏJhs|2$uQ *=r(ec-r]F_<1X4zׅci77$jSZx uԌ˘jgN5 |h`MMTsH.4Gcha@G[
+z205'Sz\vG=PSO Wwݯ*:91s0Vz-eT}fHz tmShCnn"iE\`l+yQsmfPRX&
+h?{ ACJhT3S>]$|+B< }
+WΜ]'=O>N1%,q+h!Ace4 j9!;;wg 6>M1 u@N'MI(@;5 ]% f܊/boGWZ~\?a i`H|Emr
+p}y։]螩st&"A_@I~s>իo|qe ;>gkvNN4VsjYZUP\CHՄkRpo]:͉Ek>~B@d =O3#ARu
+7WUZį.ȕډs2͡jM.S-v[%ʔb' zDNJC$yTSWթbaTP(B$D8g:vm %BaBA,JEQktqn߹?}{c40[JW.AUAwr,~,x+DžO71/Iw7!Hʴ!5dVq>CFBTy4Zxݼc})R >5+ /Giߪ}O{ϔ{x/TkC~"{"=5}"1!?ٶaYa7F?F+O3p~\ H69ct(@w/'G/ݪl. L/ܟ%-٥c/g./yK']Asp#.l&('P3 u`
+SUbB:i|c
+
+/(pXx!I4_'e:YF%#(#h&)0+rTUqY+LfB,` ^wnB;8ݢ-]F koSbs1GLl̇\.f/{SzmC
+LhP읡@ RjD/(ڇIS;!TN/׆TC>_LiNȂdls+Clȷ9+[JЭ
+):d<P
+Jri7)ò$Rb!,ň| X[ix|Z r5B_ Ti:.l_#+&dVf%r_'n܂k*57NZV
+x1̳Rݚw2`A+63m"5Jr K
+ga""q><pp C-+NKv[;~뎠lPM ,$FL<݉yi{nOċoSաҵiEW? p4jvhwlfWSmT:|g"މAm\PhmX| n n(ظ~@tppgJw"0!^?L_a
+Vk F"FxE:? Dg'[)2|=;|>uD2FQC*nz:F6790>00<M"Ȧ9!7LbhgY9Q-6Cc1
+ 0lG [ӺHʌ9;C2jJ)G'dyI-a KH ,a LsfԱUQlK@@A,/y/&Rs?wN=wo=:M>Ǝ[C}G؎֙t3jr_CN.ϸF>iN7U%-<{R^r-?p'ϯ.xVsL3}Pn6'[njVWJ[rBдBk`ӶμGmGRǹ$NkRoDʶԅHXq$Xvy{m9x qoȜSʏqg`CtN[d-e
++ǥu,2 ijYA
+ԫ#NKoaM
+[l<M7ຍl S
+˯"ӮɩE5.͜ȟR2$4/~9(j6!{WKW"}=صܷOPNBlu}Wu&D38=\7$!PqN")@iBq௝hlRXbTNM <*|":J?dWu ̗#ho5v{lf/__}޳7f8تBV2/uϒ+S9=xRJm F.x0}nas7gKr(VݹkoUOץ{\vHN==ydFRXA8c'w*um@MUh9FRe愁y*u!t)QC;wOy$w<T1Ύ?2oƾ=^b)`)O=g.ix7-v5
+mOP\gobDpMߝ>ݺ'?kg9Wf"V~ ?<NfkBC;?s2.PKCHEH 1AB$4TS
+j@nK
+mr4|Xw
+ 唳z&u%
+F1\M-0ԓr&(JZ|
+P1e
+Ԃ46P
+ҁI@ H?9#vґf
+:n"#,x-Q(gS^0웱 Yjfs`Ewș:n<z_1HKE#G̹njl3%Y%+fi:ɰc̍+ ^kOΒAw2rB/n" ĬߢA*IEJz^
+b1l$yTSuv
+l{b<<_ç"sN
+*g|FDZ6b34(tAu]4u_4K웥: L;@펱Ҁ3_Tq~Q ;?qa粻v+I<T!9Dbʥb2pC7S1]*+%g5d]$Y5)"ě,:`k35Yz9k$kGG^n9  G^) >IhLSb)0>;Q-O)/>>]}wA!>>A1Ҷ%W۟5Ձ&k$,m&Z7Τw 5SEmsCU伾s]ncIпu0t澏"%~a +ѕ,$d0F!Iz "&Q,h%#HPCd2 G0( l n@Zbh/S<r)TOI6 T 8Y:ڝWCqozǾt;m=KT DB QLA P)295oF(谯go1j{X<(팍&'Ʀ-kG'S;A7}0 h_H.p<E,_H\g-YyȀ-Tؠ)O0үo?9l [Hu
+Dose)ƑȗrmqN[9,Cm'YK?W1l.#&?/
+>|wJ)P{Ռ7g-@S6\8iM.f\yg׹,U^0of4J
+\RZlqZ]ڏ9skMs
+HzkFkf1:fw.Xl˵ٖ
+Bݝ[|}\{IWۘˠ~6.T|YU\4U+TLeOVcT eŖ
+H[|΃[NW^eGt> !C?Kq$hv2jk7mlhR/w,lC?܂8 هg>ҏbMEC}$}ƐtjEumݷ'.x3iupఊPG#z
+Ȁw=Lm^Ks{}/;>Pf|2cqs1)%)cBBx':^UɈ6zxΊ}^?@(,Qq}ӴmIF)Q*Q1Nퟌ9M 13("8$̌&@aH@Q Af%<L; Ѫ0hپ|yӹ.W7o\ۼRYv$em$7WSN
+ְ?}j3iq^.S,fچ ODNl5xMNabrG{K 5fPke91yȫ{f
+\Ń\+dFY{)54^}Jl`S!BX4UQ\3A{Rwq [m٫uY.M3wKpBxBkqިߞLq*iH5
+r,0
+O@RM<
+d"K’BMƶN8=iO(g*U$NQ Iаu(^=}gݦpަU@kk#ëðd<h3v(qq,P&4Z;<ZL^P9{x,zD&xT+17ͭ<K_x}§8ΑP@a,tbXO5hxp!9\U^U`/G
+bagn' !EhTP%Pg$mj&1iyPm<[NdoC@pb ڜkBXŦ|I;.Y~jMAZyJX:0BD>S#KYWVY
+E&,703gskoEo@ZeHʵgiNJfjV^VhƝޤ hO=fj
+- b6☱
+,P8T?]pxc
+}1Xh|MCȷwS%ۛ:ጥtTux-b6ج4-ub2~%^h[bSb (gՑ1W#k9ߵ;OC鶴i/{׮}_+ݟ~O>M+|.;y*2Y|M7vQmSM2zn=ޟj&~rV{EoPkڰ*3>j'C2QcPK=:[^ՓK,b VYi8X\/4,9T"rv nϡdpL$QEak5t#8"W2;ԁ >Q?wH^-Ԏӟa?xvh_zk ˂TYAp?ϞE2u#^P[@p>|7lV9f!8!BCD+,фNwPzfϠ:HRdtq2T }@jO}ʟG>nʹEr&>_MMxٶqmB<Dzb ?IN 661iS,:0
+y҃A=܃}tt= t[s1P
+mC߾G& SB ;hZ!@{>v^о=#0WErỦ(=a?[ZsCCV
+nr6EOEzq¯_Wo-_=ԺN[ OOںBm#]8DϛMV4~ $}/eTap.Fl@$7!;CMH @@vn3]eO*, [ KLf"%]::jv;'̏N:?Ω[w<$J3Lb.UOp]t\Θ&*E0'GZP}ag<GDm
+:>Y1"eÓCu7|dٟ4l^[?{aϷ?z w碪?s@1r_>*MtLj&b2ԝ4`\/:-OKWSNv 82M6E%Wyv+e]~E0J4<fV$PFM|ꨑO1' >aޟ MbB,l!`vT_s9xvF;{Ov'{O窏b_z}1\{[}*eRWy @,O +m:`Őmȿ};/}'ѢL^EOI6\m2ua. (9Ӱn_8Xs3Egݜ5?]VTWI^|gt,Ga.~]L4Mb
+
+>l8Z%&fHB
+s REoR͵ypnS@Z2
+-8qh
+ɷAȍ
+u3-i -TU8..wg:l]T[;<4z [Tb㜮UsBxN YEk9[{PyĮpQé-kC
+ 4mB>ڌ9ei P,EjjBaXi3NBD
+Hr#Oܿ➨~Q>l̬Þ8vOڬiɂ̭)-́UՑAo>3Bs$Hl~ Fbj??m?_t-lWNe^|]ulRr.Dw5FhrrΨ0^aڢD^>צd_Snw{:4^A.7 p,{~ ewn_y5"nhz޺wy_[XJFh&x\,w@- $6~}}8zn_/C^9R]&bG(2uQ\c+5D+6Jkzgn"!|{`50{D/"P) hqX ͽ0aLq_
+ݣW7]?bn oi=0^s7G%@׉I 6^VQʒ'Ec~(οd۠\s+^7bEf
+<{'cNPΝ|1329*NThRxwz'ܴȌ{.H)’&1ɪA^ݑOU<\$4Ka0QSZvI]4mĦiM,4EњYaZ=r*GR!<<X&qDyPw񚉛&MF4ވ}J<DQDEAXdi;ni6Mj#^x/^
+6drVs%6mƟ1_U97fz6>>RtT+pnKSOf>ŜhfKoYNA x
+YIjON3*nxh,xx,h6Z5VP@t@l4o
+4XA2WT~[r'uI鍄᫵fAL, -Ec{L >uTlI?06dY^WgRRIhc'٩]$\ќ% $I)]IN/^+JBֽ}GRMM ΘG(@G>mQ qHJsP"\Bgh>ԯwxx!e¿}x\knKړ^:JN9S_qH?H)CfT46F1<! =%&6`/0qGpѽ=96;DZ"c @_C֓ArPG&m+en<kmwE߷/_꫑C"9ЭxΟl^+l=|9{tyP pp(_sܤ߃ rBt nkd1PXSkohb]%x WdƈM0檀
+J)8.U]b\5P
+j%|/1˞oA/P?OHK J,n*ź*AUpI_6^bm<6aAX}+:`[cXű?7=Y9_ׁ
+ R"+3s3gϓbo`>ZL Qjd M G WE
+AoT].MW3,#3d΁];ڴ+d7dWл˝;=Gƍ6:Ғ^WD$g̈VZWs=V(Mщq|m-% #% ?v&C<Rp&`4LA7`3T} *E_䕦ajn`s47UM6ǚhtޓ>t*C}gdnbr1?+^]
+[lDM,clܺ}/um&Aeq‹+c
+Ș$E 
+oI21.ZG.$,E,YW妖oıb__
+(=A! e(O*Lb9[qi Y,}d
+
+PHI3H4]ela<c98T:Q2Ʒj2
+"TJ`
+(hâMI`*| 9fl˗⭞h+\^i%9B/Q#^6]VxwtߋG|tf bxVጝ,>B69$q]'e&:-a5z}8QhiT_;̾biy~@NO奄dy/oT{mRfVzY6nʚnϖJ6&dR4 l c4Fgz;}}
+&:<qeu([-IDpI=7L" ĂxI9GeEJҲxY93*}m0l_-M'*ӱYBm:Z%6))Ҿ D79mARtoRSp8m
+{/^mv>)̐k:#ͼֆwqO- PyQ`BLb4\(n/GAaxfDڵf9F)R7#`eCm 'h/rm/JeBkޢz^ϲh߆ 6(sJӪS D&i {X2[H]z" \AM&i
+ t?IOcOE3  X"]uP3Q
+_- &7H >eϵ2Mgx0xu ]`ʐbU8'LXIC3,uP:GH1N3٤gܞï~?+5}0Ȧea`M-cUKm7}ya\0,X>7#o?* FZ\sY`擙3QcS̅?Y曀H1lCo%\`N|4
+U TF2CĔmCo0+B#f$<="QTs
+5\=~}$}{ܑnwq)٬+K.cDMe8e
+"jX/'׋t#E=@%ADͅ|VMJR Qc]qX_}E]wܧ@Lb-|% I5K3+w/kH"dOɍ7A<5q90t`R` p'
+wVn|wl yrƒ1bd#ضތaYl"04M'1@r
+9EH@80`Qn<pmW;֙K
+Qp
+vyv g'ծ'Njy>?wxS|lcŋ'zcmaX¸Y6Ϋ;nz|ŽiMsδv[F&Jaf9]ӗ};gZ\b%Syt%#n1ŧ*ijt=p9SGMi"%6'NDrũٜywr{qDB%cA `&@Mb68*$QȈAq$AX ;ttA8)cyҍ=X]p961O܃V\m{lP4Ә_x5)O6j
+;@<V\p/-`6N}wtNIVz ;.#:a='3|v+u!*1:C v+mqS19}l~:6sE@ŃS~_NGDvbɽDNM6
+??(|i<Uac4PFȾ]xĴ>*OHL
+ )F,sT@s};Kl v+m6n)K|%o0:y?ַDZ<>Igziۼ[ãM
+CBuP]Eȇ hs5ո<7OS +pEP)!WUITRt3J\(7
+z hz Y!N }B5bL4 VKpAQ ]5F+e! JjȏSⵝ$};8+dh[p^T 7Z;Tl
+~[b<yB\?C@&}<  U9H]Kʆ`BmPed%ߏ7+>.āE;%B]Tx'qsMH#ε6!-Oyfgh"ݴdy=C54Xl .CK {W3]6__-+Cԗ!oKѷ?b%\%Wk\Vz9Vz56ܤ&oM9w7-)p4{[H[ CGB?88ޟ<Vqc)!{oN'ۚ3^k{ԢM\6z^Sv-'ƤuM2ʲܢ-әkjA$5{`Zu
+M]ퟭ%.zaKb<{MdyL֩PsK5h@MRM(pE>kCh̊kۛHO@})f8p.{-9mŸV-.s@(I}v1{1{ Szؐ)<}Sx(n3/`>eddkòFCOT=I~7Q,y=
+8+pLPmLҡ,'f(&$+ii.󠦯<cD.9 \#w+@"qkN;vlgۺrtA@ $/ rk*c_?y͛y#
++yq΅݅ܙNљՙ?1G?|Rh +SsuxsWItyIFBz9As g3-Xh6[B#5ڌX1bM]tH[,,;zw;èz))VIww'f rE# a=h HcOi3]!P܄120D
+t\!E+noS"]5@w7F,\UKv_nf@݋3wW~sͷf_ޱ!(t,ڀ12yT96aRFȭi=W" x:FxhR|y/}p7k OvWSرPϱ-|
+ar;cKp? 1
+- "$>1沐5K4 (0ԒtuDn-\[bYpN~8rkhAQ-<JrPhtEU=2ѯbo1}8N2&
+fN jkZZSgf.,ၙ֖Ak(A_Ԡch]th%.,:Vl?0_^}qRgw;T)NΒ5Ŧ <+[Y")o8"[V52M@A;k>jP?R1r *u>Ga8h0 OݦD|% &F61
+}9|;v,ݜ#Ƽ[R W{ky1zc) 20,ߴ 1i1T8 @9@bvsAjmG+cEGK=>ބQ\ukk{/#q# beWf)dbt B.(G\C_9.D~mW`!;_ur хjK#\2
+/@!grM\cEk1ځ0#:\*뀼ztDcDd
+d(+ 8bu0 zCZre?{Q\T PV
+ȲrL%<]i4p"RQKA,Jq9 ,
+NPiJ4
+D7U5<e|?e,F1=k*0a
+Hm/M?7yti}×?ڟ3CvtU;i$F@J
+6u֛>cwdocQ- Qr.q0sI`JfYR{P
+R,BWuaCWJ'z"6_D+\k-[\gc[}&j2l懈4S gRb2v]1+oJFGlC,wL4qREpg= =b;A/F;C4xhPWj/@bw2s.C$aG@d/M>k{)~)yiwػ'n[v@&NJ%crڥl~Cv$:#+.<8uyJqAW%󴲔?P.! ԕ*b m
+4qF["S^ӐzP 41X2[ƒa ~}NPlQg"&aaV=
+8m
+k 5ՁJ
+끥K|
+`;=)F>mc=oc:
+ؾqe0, aÌH}76CoXFtd3*{.`Uh
+,1WcPT?;;0ǝ4?
+J:?|/G0}?ZRjv8hh_RP} PR
+cb=Bc>Wa*qG }Wdj"ԣ,o͵P6f6>-| 2 9;Ãf:
+JlmHP2gLLʂ;\CU8_߀ b 4.V`䙛:461ƛ>bzpxpp
+,@\a7ygŻ#V{v"~Y`,ivOC~rzJ_S|Xm~#RlzXUFJ1_-!Nû3MuAFZyô YCqUN֒lgܬ
+47dJ|^}z/B(Ƅ_H6\5Y['yTq%&)z =Q{GS16 i#qj?z\qbU[ZD: o6ړ'9՞9=d>8'Ij>~O6P,f*Y%*fuPUA;WЋFinQD8
+4)Ep->@^Hȁ[ 2zvlqnywcMTmÆ+F@S/ssʂ!3>ЋI3u=Tc7&Ԏ4 LS :
+cfcD;Nf?9wΝwΙy-L&[fngib5ZZr[ I)wtKqy->ӭ%$n'ܣX{&Aŧ,qB+Zp8*79\=)y8ϯpNI጗FϋBƍHp%?_.U<QHvK'{*tlݓntV}'%k>UtC% l?[][`Ҷ@#E t=؛@, }<r&T}5/¥+L&ǩ0e. V@ 2ȡT.rXbfKLJ^9񢡉+7\04./`hMך|
+QE+G?j+uvVcݾr[gAg!i̞M)H0gcP PsQ?+[yy߱E mҢ995. Ƙ4&ϋ*oCCZBU~GWy À F,+ %.%{+a+a/^VF  P,`
+ _PbPs8yay(=4J7O1i`AI42tA`m `O3k 
+w-3a{Xͳn~ IҦ|:󹤫R:JMizen38V;"tF;$sE6E>ӓ> m !iBefaB!GL ŦQͼ$+2N3g#CPa+;/|gg"ZZn?L?wc FmVhP3Za^6'nQ-w$w)zW-
+ >D_];Z
+ FFuj
+o$>JP[Fo;_j!Ȝzg?A!b|ژ4d8&ke({ [4+~_!ޟ2MM 7fS6'#Ec٫ȜձU`kpɲ*4P<Ռ;WpTgoT9z(6zT+!@/,xPİTɐ[EzD#DItRl#T5Ý2]MUT^jdWs'Ei}SPैPNں[Ģf7i9f ocHlzG A_%:D+!שǠb
+e7ԥ.*q^5I_B/MF/rI;uX][tr+~s~q훰6D<GF%cOwŻm
+u73~AP'Ϣ(32h( (;X@ A2Q#?'Os._"mC(kzbIsi??ezUQ !'!" .d8vvwg:ZY  PA
+4ͬ:z.zHY
+rf8ÁM.t(15!zgƙ-p6a2)])nD&}<Un% `#T쓺 s5rZ'zH~|tH|b`TbTT= l""2(ItǪK'v6{Ʃbzy^LN- j5$[fltnt7/o$*8TB $-Dk NmbA# 1#py"n 1}PRhCZC5ƢMT8<B-G,-!Vܾ/vx>zQ D D!lRI7S 6ZP~|{
+&:(~}cv2eja\3)lGdQe;Gqml5of[(Buӭ!q+~Fآ|Ҡ9,7Fbڀ.s
+ "GmXRL L
+pIh]pMh\̵JBr a"4\hB&C]}g<ں
+@> ,\{[
+M]} Iq1zFow?W /].5L UW?3}8W8篷d l➷|u"ðU )@"0B| JA@T6 p*Hs. Mۈ$V1&-ݓ~~aƿ&_M[Y_Ϝ =v!?#?驨oQOƾ?KY
++NEu {PqẽJ
++F(d0`YWm櫑~HyHdRgԴ0f hҩ('GHF#
+&L裉bUiTO)bE E4o YzdE-mx
+ YS¸T`lʨ0>m^L.#`p&:?xp\y+lNf+:)gdfDQwgUݤLu/"RfFi}yRtIÔTgj QQN7b%E{i颁I)?F%%4#8%<Gi'JԑZ+!̰;4NYo]r`9+iҡ( a e]GX:oDt @f4hMRGS3UUru/#vV/ݢ\,]hÖj_讅W.rP7fT|Bpvr]s%hT͵ ڐR]DPWjuW!;ʁk]T]
+NZ^>k♛KonBX \G &
+RAw ͳ#sB晚\C3 :T14]OfÓA¤*L !Kۍ೵]\%E)"* i`.3Biobp)}<E PQO-m (H<UIN7Fp9.l.'*DJQc3@iIU*glmnoGM2!*-*l Wi#|i`X_nÕ0 ѥrM̗k˦oLW¥fLg
+Hr{Euq9+ ,$bABDGF A AAS_BYvsTޜd"Zw{{͍BF}>%nʏF<UxmmzĿf
+V?*9HJ_(K^).\,VuF|$9 ->Bf{gPOػ=s(h9(ɠIᯑUVu{/ʤH\H. srZTc ]X
+#_*GV;{󗟨'sYBj%p<td.LCpΐؖ AlC1
+mad^UmZufqђtCKV@94 %jָ8Rx]hg bn|
+s$g
+(>xlH9`.8~
+w_Bk
+/Nr6f>0o1 po2>$X@LγXB"߿GnF 's7'b?ħzK< e`.8?A˱JilRa,20 g\_N743oJOZ\n$'(bk,-xXl즋WXe:%_ܓ$]`Wd.J~< ˜{;Fj
+mJ2F1C&Id&<()4Ic!K-@M;pUoеv9.Ӡ4 m3ْ vP&4Nw;5VTMOOM6n EDV! !!IHfakQil?nsy
+N$a6óz,vԢ"uɒ{6 hfw.(㢝ǯ/>!lv =h6B$tO*G,I Ep5H#\PVJ`V7g YȧA*e]Z)TIFq5|?&<x e;۬RU#hr}锥v.PHQy@!)4m32sʚLWycc)=9/Ts^N^Pdc{Z`lD[r,.~i=hp}f[ח[|۴-Io%ux!t:ŬGG@<P} 琿O)#S-bڨ0Q`sFllCimWN*EsJFYȟ3 ㌵xJd`H@ {PUP*
+_W.竒T&HHHZxhTTZ8֡JvhS};fRH[xqMgk֊,y 7@n˩mȶtt|O.;y:;EElȤw
+SɡLJ4 e%4IN}=MtnI&ʜѲ$ " ط?Z;R(҇Mڟ՝" T@DX @N@jN:EqA
+p՛%Weüb1o@une7ۡma&mahvu05nK:OY "$! 0<tX>4yj$
+Mog$ &u?]L9B^H)8w)o%({{)P+Qr&R*A1GF??HH0%Nb
+@XBBBH vDvn358Dda'lv!+7!
+ޘ!o$5R7y&͵czr#C_H"35g+\OݲU,s|OȔ\le{3(\U{!
+|KHp)̩*Jʛ* ;Yƅgt_9CuMx$@_Q4bc k)E#$J8+E"$ސzϔUG`~ukd ]0j4_q/Gss>;1 uwg` Jt)u 50V5Ll<^|kh\]1.xMkJ4ahKD8L'6 z)K/2 {h!`c&d)?Ic~sHy$?ĿﵿbPx H
+ϙiJfUH*
+ 6I-*xYMO,4bf$c ˜æV Blf" uGž%J>ڎG(KͲE lUKMc4iu0଍F }9PgX{o0[&s~U3I;g+I -x]7&j! [7-h'8.\iEϷROt}u
+8!U]0\:! ("cZ) ou"h;}|\~A, p^F {w!knȘGACU 5=琇aU.C'sS4T7# Fɠ*I($/ CIjNʌQRS>A6^qWc@XKi THmb
+YihVS)!|m3 I>%>Rz6s䧹WE?<{L8:>pLӼ=ߵw/ɄƞxX˻Oc|x'>ɇS~i. B@X0Ŧ.JTb8].>e?uz㨟qnbV|-53|7nH1Fh M]b
+{g!6hS
+rTi|D4rR
+=bfk:#*]ze禪-斺yMQa"m[r] ȱTN/lnJXEјR[)UuAp
+`\y~tqRtPns4}lT
++Q~_ Rf10_~;>mc!DjiÊ
+z:O;|#Ch4gQ΀V>\rŇҙ{'n {z'Zq(w; { :?  mwa2Y+\hόvm;]ǒ}8#q/]z\Wh L\]=c[#9/o/襝;(+Rt&%[Crۨ͠2jpT%䵰?}z
++͕/FqxMMcxDexD-`~w#3.3.NF%_c/ċ{2%=JNTqdڍD`&@vkfp3=[X)\*]7.䜭])8 sHfr16 ɜMj1'& 䯡v@D`8`
+?o8ެ\z@V935B.r8}'Ygy7
+*8M
+-RVhm*|z skئvq}ĉPк <k6VGu9{Z||xPnzPA+6UL_ N%F-%$A2|&XIa܈iUVɶֶܙ<ۮTM`ˡ*l1B-\*Gx`
+j)%B!TC˷g[DPKp^Pt*v)p!<0Tcf5!mFZ VލNv$z~_<:9dmkNG8,,&8!S`PlWP샐^T<%xL?gM~>~9pn(`Qf̵"E@+f:%b V)x|:Av7}-~x=;YAbP(E3S=DŮ*Q
+_pޔ:j
+V^1mAWV<GށPWD*T5K
+q;1 im@6K^Ady:bU Y35_v/b-t1ޠ/(7tbs {qIZ =b4"S5c(e0x )p7Ut3`!-k{q^Kwtٚ<MDۄ.5SFUkur-߯LSO.Tϩ)yp/=WK1nb4MXLF:l[tg)]n WO401D%"ʤ$:$!+Q!dЊI7=k
+uME1}i06
+W}2;@3%eY}1f5U? *vJ\$o/ V
+kS4QE:J\훱w(t{=kۼ+%ffeqK_|ͿzYغco'Ƿ.^;rg*,{ px=HƁ`ˍ7a*yl4.f>*I݋*KiĔg+s;"g36:NMa_5_W||} yd%~iDV
+U3ni8}ɍh:y ċ?Ƿ,E*)܈/A
+Y#VuE7glב( X)&;uݴ;cb-A o:w俬c$ P=*T|R]GX܄+T`U|JlpK|bO
+V{. \[,<6yL
+SK CM0eJADž $OGMGr5q|u-x,B G I@BB\tteg[Cnp@~9 AD]Qڗߙyg}y>^  LC/;-mON2cm)E-ScԐT_h$͔{Eijv#{C vDfhFTt*`f@-HNi*2~buͧꏂ/G׸Evw3i*9FLpl!}v
+?φv҉BV^|C9p
+{- EpJ
+^i%K}*TѬ
+ 7@*T)0Ro%]j˝SjqJW V*v?+xDhP#0jt:U,ts\8W@2g1>.unI $ͳ!MnnUģ"Hm\76wQzԅd9Ѹ?o^>7cO-hႹnd 6xf7Os}謅~Tf^ClNgn5`k[ֶ>KځNxr{TDЃݥy@jhY+ jb뀚 0/؟ {pR<{(\+Zku9(HqX80#Dp
+7w5AiI\Rg 3P ]h!8U4zFx[ 9KѲ_e-<_<+k{ `<Ճ̈́D̷I<Ƴ n1 9a"&:Tc,YQ]Xt`κeJ9CG%6*_֟[o/[2Ι.YnZÐaI\5D)3 Wwی
+MA:j悆JAʒ7b8=zq/!ZC* Rk Cfmd[鲧mT X֖sǴ+P%cY-h9Ÿ/>Ξufgz+"<
+ |: Y& hx,YǾZ}uZې%hIO83Ø4(-8jhA>O3 ܍p` dffk4BWi9},,].` ]
+-d2nR$5.8tD}/OB|lR]ߧ^%|>\w̿`*sʌ`='Hc!]Ln+ɗ$`sgPtT3e4d}JJ!#z}BˢZ iQ W5$I}2P ;-v5>%`[i~<M ^]El_o?xxh*cFnu6Vzlݱocsa#3ANNْa`\TJHeY @:Gy;eϏ&$3E8}DE3AIm%wyn(m,2 5-XGcynfC'vVBvʴ~ }trV/4yPgǷi916i90>A"P#liN؝6N<@E
+E y9^.xn.[4i&ywy9Pjpw]`!aFRomXn;jWEKuHSkl [#j`ްճJM&
+\ {Ի ,}t\Nk8?ueǂ½}cD y: >7?<!xD%\黔4~<Λ;+5o9xzX뉤kLKO8h
+'kp@JЈ€(iusg3ٵS q}>%\UKܴݥ|iqބs@/]ooPkaW` _gpztŬY *j ).'7u֜9z^ն#;^WW(uPKն õe6 :R*0
+[÷Kt|@˶`eph2.wPGJ%Iٻ^.Ӭ:/]ޑ? h3ʊ N&iHvb-~6f“No  \A//=H}u5fqڥʹs5f#H/,%w1䣠4.z}=o.vs Ft.liY#iʙFpSǡLɞ2hA /sd<;< ƌQCV]<g͇tQf/[!\l!R[-?oʔ&Deh@6+it &#zb+W*,~U{anNbbgS ,$fbό
+̡!
+[\(B;${_#N[>aP౎7Zy3ܜJcgdk$MJ=$SS7\h7?Pp%)`-󏫲oe ܖ_ة>E.kP;꧖=D)`^5NmV{T(gp3¡U:
+6
+SoDV
+nŐX`U/Z#6 q/u̷||(`0)2{x'X/=@  h1 X]PϞTIGf;itC.ntG_/XFr?`7AC B hl"}˂`_k9[ l
+&=H,ānؔ$؁_*\,8q3D5hGx^mRhfl^Ze'.UCqF4;y1boУ#L*m|-+Vr<=N$.8K l#t#tY' iC͉2`Ls B
+
+\mx xg7'f{:|"a"[D,51Dp3-ngZ8nv]hic--EvvMɒ5,f5Ԃ>LGڝ4w+ tcwO|{{~9{< y~0w܇gA z \6"4me<jt6ЖLM$ &
+ \tE<XI'.]D$/~3; $LjzI'?$ H{oЃ+8bͭ١>ӑ=(oa$Xd|?>?
+~m٥|jz>=cʩ/9UbeSĽ@T0)JZ]E`Ց0b: T
+ߣɬ,:TýnT*LQ\[bmʦ"Ha%Ia,Lrm `?P !ъ8‼#s3C[_`omzyɶXw-?n9,BwOp/Uo.ߜY[Z~̝7
+7_$1*cED`0=gX3&Lu[.4Er˰^E(H#P^_֤AK%auYzQWR.i̒F҄\`i-Y~f=Qڐ=#聅P-2sWȝ;w*ٳLɆ;TI.A[u UKKlg!HC"UIo,F猥XHS”;?ݼp
+'b-(dFY9bg7Da@&BA7ZH ׭ƆxB$ǍXrQH(by,s2X }<{d=bnjÆ΀QĎ{O( r]6Nl )2D[R2D:r1@.q%*3ų\Cgtԑ8.HtDIyX2>¼@xB$ٰ}A!Pv{?f xӔ#KIGIIc\q1OH= | L\%#^( Y€]gQ6ư x,&ȸ9naq)֙jGѶ-8s_bO.?ûu(;(B4R65VC-Ւ+J
+73EH;JvR2!'
+)G+NFŅ[_~uŷ[nO?i
+1Xu%e Y'G T<#Gqԍe(^h dBS494xVX;"[*ҊɶfQm-GkH5(ފȶׅ,5?v2>p)H"
+<2<ݠ
+ yX sdCi`P :j@CBPBy(ke&@Z{NUbnb)"[*2NdM3 5.܃1u)g&AM/J'ӍF<cmIY0v^Mqt2X߆:9<C#!\H?YmYڝ:Ji0"4yP;oUWByS?+q=?~M9z{?:v=ytdL7ʵU3
+?cF/xn.mm^Gz9}xrMWb+jN[bq,PBH_,o\3Ӈ{yf@"X
+{_7^DCܱWq%E9MyMymmYfaEXTTUwZ@Y y=<UIYN3p7 E]p UᲇΆ֑[}|qy֞ުGƂ/nAFը#z4Iޒcѣ Ҩ3P6C@c$t-,l
+{Xĉ)0WKL wxr{N'j9F*hjJFz[ILDC]`jj
+_H>&; H[I,VJtO%離I%؇aB(7@1^ŘKC>+ﭖ[圄7^d,#_&CڋNE=wx
+;ҎzR~u?v_J?]Li
+0ÃSNIOOu_^LDL+&S/6RfdQ4Snz+6Ԅ*JRI?sݱ'Qc ZX}T鄄V>UC徱Xfn-E3ǫǛѴx0SLj9d yX &*I̅abt0^$Y)yW_=֑ں" 7$Aayoն:3۝Ng.+h` "yA @kkGOl9w{|m'^n[xsӀ]b-{C&0]đvQ#U0*߬O:ۃR~.b<Rb$7AF IKF*͔ <,4Ԍl/3j3hf<x0frޜǞL#GH}xbȽg#/>ċ6‰B@yO6f>h8&[ : [(>0YSyv-LstJslI*1KF2/ΌW͎*r憘G,ָ0!Zᣳ5)}.WdόW/h2]^R{bi?VRJb3\OAzDX97?(@Yi 8;h.aL3LYEV9I {ل,^bE<ҺNK|c1b7c7*HG_0>wB> ܙ˸˯yŖ&}b#[t#_G>VQ0#_pv.9~=+U"]<{%g7;
+ 6K8}k7XT,ZPf;8kJJJf p^T܇jq\x $%6:-^2p)rUN(2,7])Cl$f]AlpȉU%YXMQOTNlPM^
+Tm@ ޅnhr64 Yn(lr!U?Vj},N:$XO#΅=O? gSPW%l
+mt5C!5
+yӒ[ -yxP8dGw{n"pMlr\*݌JpVr'ٗyCouHUλ$14Bj+p€4JNwgr~/*bvd;~B$aBdh_ޞtu호HZtx<k)3̲
+&v
+QL
+]T Kf朵ΗiYYfj+xɻ 7`s4T4M9MzO~++/]ӜZ %BVߒ/ic t%0+>c@Ē bj< EtXوZuxqkwW{g<?ݏ<i{G#[{N>zs;yvm϶3`p:>ܠ Zl8"B&N*%U1=1Q$6p̶DZfPD<7Y&׉gU[$wx ҭ}6!^quy齵Ӿog0jߕ?F M^P~A|Yu|eryY21Iwj0R}#(kUR}eP>q% &\k+HE|Z@S_VVlpf^.
+<]poN42Q Ly6` > .ڸeC߄;יkwOzpl1ځgǓL_w.wS 'H0䜴7dsOrA~~9ÉoN2w0vg׸W#.1/Ɲֻ'.Py 9stѐ\H\ll,M "K uVJ{_)fޜ, x>T[ӕT" r4:|Wd.0+0N]U
+&ثIUl ϭ4a~2z)?_$ZEȢ&̵V(K'M^F
+ 5:(MSF
+>]nxw?j|2Qpɳ:2~f9wf!of1 Z&}~N<нvo~:(wtqptwt8p̐kۭTqI
+bZQ4PQ
+tm>M 쀧uWW\ 5(ODɇ[Cp3Ѷ3t 6Jnl5kdo?'pjP|C@P7r kv0
+F% |`6\{z4WSC1WAI> ؏aQnL60f
+XN~T7z&l3띲 h雾㓺㙺yuJGX{W@M+>IvcJk-#Z
+a%L8D'"q[qcY
+ۇ )=UX#twݎJw F]rtfT D[g@-
+.l?scezvGX^ Xzj" XFךcXFEaTF 5BSDdYT:>C9(?)Xw 4,`l5 s0qQt>~Z%W S'ӔHx袣p4JaE<f4NSO<fi8~w?(W=*q Ql:YK(q^ßw|6qo-'["eM"G=EqJ,WS]ws<U ڛۼT@@5 *DI{!(^oIr 4BZݤeXpgu|m~ oC}zS\ÃGZD>aSFbF2jl:"Ӫ#ѝա3#McZTܘ N `Ejqx?4ػz8he#pc!ϧ t1 TѢhl ev-sN>OPZ@4IJ՘/-WX_Y@=lCKF+k
+?p+
+k%4,ZKX 2[#Z Z+FYbh`(5t2JM5 ~kK%L~o32k_?~nYnh.dK,JХD;<p`]mP<
+:T[h5P*02*Fkhg3э1g<͘*TXmT&5p۟mu;2(BB! HU'dEf 8V0B\Q GV?);YPZ9.Ъc%zO n8qkfXiQMdfV +{˕ P$TJy<ețEW<=? RLFEKutA҈IlWbs?V~] 9auANk>~e3>"?b^Oi]2[>):QJ7` d@aSMck1 ̓X~LMtV
+6CHb"BB*jsӞδgzzαGN-lȢY{I! (3Gwy~mbp|KM2pM V
+ XŸj$^B~St_E^hbݯ|TD t.E|7DȷʰH+)$I-ʩy 䋦*bX^ZhV(6tϚl
+,4͵[дuk*zp/&]hˣN9&kcvG F$Yld/te,("K]e`.KanLBwh\&|"knH R6P9!I3?! ^ױLM"s9sڈb=b)rX Qi(rJ͔-*Dꠋh%\ \<@ȷ
+6$DLGT2HC<7ȧs J^/Z;UGwH#iZd@꣥ZlXj%UjR1\`ck*Ϝeq93MQEV!6 m-ђ6|BkD\#6wZ]l9QMT};롋u
+Z
+L3G<t"6"2HI
+]ao2Ro.1%ZH.25jclcr' yچm[\onUeYIdt*nM14#ITやDh
+fm<m OGF96CVzבy < P$k%* . 8EA41'Q4hm>COSɌ,%*ԉbp& 4nr2"'_3N.S|t(R`Q uRf[9Qsܰ0aFDI ԹGI}$[ꍼ"J"2K-2?o[H}sw{ӛ]LeHכ"R(Ă TR|WS1N1tl-?uqO~X~${2죥}o i/mx߹5H_٠#?>`tVaĢ^kcFOZNRAިZ-ca'q&:m#s1cISsqש'/{_<| g,) =!܎ C\kb*%,溮"j RM-E+(]@w{]5&ko @W Q:R;
+T,_2CM\V{Sm-UѯhnNL{K?B-u7_O͓݉۱'*c/Ms
+S6|+G$;C<$b>m‰l4T3/UǷ9+[Og=i*?+Y.&4k;*Ȣ}!IH BÜ>0˙y>3 
+'K=ͻ?-۫BW~ ;2vε@>ZLNg⬏9ɖ,&(X:4#ypzؗ .t^:ir 'CFG'77 ^80b# B" |ϟRY6߀nSnA?%t+!%*RC7*;7n8לuJt"܂n'܂MgV@ݭRr>fT8kJ jȜjz)&S"^
+=IR
+VR%Ps=bPlʼnx܁89Z0ׅz8ᴙ^R㲐2dv--p ) r_彶gcfhw k(gr4I'P֊4{~
+Wᬧ3Kk26375Zf_Wذe?=303<SŖ+fcKF5T9Ue}ۓ}7AjB8O9g9aus(`![/=
+Q}|!]t)z UQJ 9I+1 灙wVnV߻oS"S=!۩v7 J*r(
+w3]>ĕxLcutVaޕ <gva?Z foO fX`tQ礞zԭKa5҂R+`c-)MYm|BFhy59V>H(n+s*=(4x.=W`T`LceSwcH 1A9$пwRs}t4Ȅ4b nD_
+>C' _$[B6˦Sl"^X8t%ke`p'>3KmKיK>'?ceҨڞta<%%1<.Fn
+<@.vF P<b4ÖQ 5oC\УkM[-1\-P32}01uN9= N(dߩ?M&ةzEԤ[_e`Yyx L:F;2
+p'P!BygN SISQ0җ Lo Nl Jeg`7uj\0ZJiy2q Biۜ'4ORZ>Xݩ,.W {'mݷ=QDk lz/VG{}#~M0wj ]Т u4ul%"gr 75kefmՁK|>Kjfdk9ґjWfR K /J ?@
+'@~A G:#-!WU\/1;g?;Kϋͥdyw/BIX#0 >0NJFo(!K復x-=md&# dyD@ƪ)|+ybj&J8k۸bm:`1.SfFWYXS9h3)u%
+˩yy=srV&^<VӴutAʩ/ȇM ~qج ,JhLAEfVJ3ޣm*)Vj.7
+רmlDkkծMJ{M[^K=[#Du;G
+bE^ `YWz7zS֕/Viֶtv'cw!H[k/5.`1|+ ;{3Uob}@C
+< jB !f9H\]Pah&$Z(TMD, i=|^vr:K!YN0Tw22 @LI
+B
+Jxo'X`
+,;g$%B9Ǝc<uPddyFT9h'"1`z`\]%m>7ScGk?Ff&ݎ\;H$A
+Z#g!HܰSF:
+\λO'Hlݍ^}\o 7gA j]Fwgm0FDm9~y@VzEN|!$"#HzZPW)1#
+ K(1TJ Wc)^b$KbJ(I}/2bxP>o_נ[xX/^ޢqɛSצпSݧ~@/2Iab#47xƷc-m4['k'B&wa 2e0&=A犜Zyǒ߰0s_qAz|zwrWvMGhݎƒ_)NINIȟR7{Iyuxxg&z˟q˯k|t׿py$<8,0gGa*$9eKiXߘrX'ttoM( dQsQ8!wIOq~ͷJĶɌxy?ՙᱚDM(R
+-5;?cJ+f.#*
+` m$`
+潅jI.g?/GM3@+cكZDjBi:kל>
+5wx;TEn#Zҡ\z~!Aq?o
+![1rcv)
+w3U\ ]HũCxH-*uזq76ol'|6qH24U`3)`
+-LL_ϪujXc̢dُ';>GFG>S9x9rZ| h|P6]kd/9FJ"/CI tT9"P)pg,(4]|<\?!cw-y&c[7Fk4cUfHUUZznڥ `OHӥM &>?v$f;#-0p9d0<N<] LԅCILᄒ;OI'C)%{!@!SdPbØZ^hed]32 25Fm@QlKk\lg5cmp#֗e^Z2FzjOZj7EԕZ:ߗ^(뙀!6
+v&=stch.\@wbe[~)5+ܦo3P#X}?Ce#U죖 L⍁j+fVf^]hc^^lOuCQS*W-rGj|[ߑ^AU.0Or]@
+_?4@>
+dURϬ+>v)" *OfA,KfN.Op@8J*r@zh7Neg/ůl(x t4Q0" # dfba09tíhjg?qJ0TDrlz8^eh *sȭwߕImgP:a*NZbqQS"E]
+%Fo3ӭ7_<ۏ?GX>g
+!^p#Vszj'f*htUmBY'l;3!ȢB\
+\b^GmriB0o*Nr%361
+>B3eN$8ym,
+truvՁ"_ī)ùiEjr*TINKBy}-oB0ݘcGY0jz
+1ø0̉XhQ,>&}hWJk0疤μf;V~W2sNNĶ̜Eg>f^[܊ _okޥEUF`O{nI_m?,7ٝsm#7m/ݲW)9ffffZn<mMl,Ê
+I<lH_҇Hչ &u(券*w#x*xh%kñdBE(IeԫX
+>^Ūm Ъd`b\.
+%!ϔ P:,I"m"1!b7 M<I_Zu=n<o/
+zk sf|kf_#>"p/'_ :t־o^wrﳟY.8.;:NM0И
+a0{ l)"X
+
+:te .K͂sݣ2wP_A6çAy4M9*]ޡAt^dEk6dFMbb.!&k.aws\L6$h
+ 1CUd 0:R`C` R|"T/$0Iڇh!\ؚFHgAr
+[-E[F@
+_#a)!
+`p'Vue#d%2TE2dk( Nk&hkS9~qZO$қnRM(n| Æ{#J
+_p ]r Yvn<>ou}nZ9|jdp`.Ȝ9sGtdVf,+
+W,gη]i *3d.g<W
+q ~i/):}8vx=-sئ0;l[?l]˕t<.{'+JZHmxSaꌗ[ӹ]=_xvv$J = ~(bN]!5[,@ld&9p:.2321sh_9CDhtC%F8Tdf aB -8m9ͲL1dpv>˂ f.bqlVnc1 o dN*gG T6m`>!2ϊ=.@ 9c7]f${R`,o
+_szoIml}rr ${}vQ)g' 7wwۉ-zp |@TE<5a<QG&S%RW-c;n.jGjV $zu
+iv V:Ag2"fj})9@ᓦox%HEL)7XR?pU$s'uQ)ii6T2:md\4MO\%>Vcץ-чpmrN̟A;8 j.۶ɫVRW+ҷ=茶ܘcM=/k/}ֳU'؀/ݶ_;Bwn[ε|3~?QgW
+;ul XUjXwlɫh/I
+JBR_eEjwHWۈHGi?Z8VU8Z]쮦+SFS^?[5d4EOUHZ{%6W|fH^D
+|.olVxu|sGKXh UBKX;iF"c*zL6I=<Rnz~6 4NڸYTMخ3(hk >uwx&`YO8yY6R^CAJk=-DxC1[ %PCvF('[v=>2<s@BMP<m!bYv4XwmRCA? "l)"1CXԎf
+!<L0 <
+rX.rI
+0{m$X|s;Sc0U eUjuLg8u}bպ.Z֧T )%c:sQb/ fqQE=}=T 6u1`oد X6E2ZC}mq.?pWITbwVü,[ C7sDwk>32bK_F6U)sgt?sUi
+fCٵb%AN4՟ *sWbxKA4R5gZSC{{|ZW7/C0U}|YidV.8X8`pW](ˉ| Y鱆9Yx-ls=`m^-Ϯ]PC @0HY=,XV$
+WjEf|/Xt7qehRo
+""
+.
+Ř}JWj'UK3fwEDPqCWT\Qm.Ié[{|O1?[s0;ϯ}TC.B y,@:X9ꢀ'SKOH֧,uKF9 ^G'b |-eZj@ȋgcr(t@lE K?]
+`Ah}i4}e0$mu(QsEsf}6yUx\gw^YꃲB̷ړ̷S7}/{dueDgDdŲ5m0s]{ bm19ѸC4#ٟ@m ދB}thl %2dVZt
+x[b9GkR 1u^bo ͪX+ n5Re-iC'9~`OHO[8&E*t7aEflWŔKkR_8h{RVQES2Ѣ \4 <2*oV#r:s^E漐CHѤ4xV6_og{;Q@zt#ro䉥J Fkʽ hZ2%E礑pɬ,/HEҘ9/p5"eg8w eW09(Xm$0^~PnD=h77‚@}tIGѽZs\5WG4ьI5%L<%K&7 Jƛb)SIt0=!)ήd1
+ۯIfWpZG\1~,37EVEb-2Raci[9Fo
+3RwcZ-4lHML%i! kj5㓝VL˖w:1nK"kF6LC!uFL"`RqP " i#iî8Di"*`*[roV-%JUڙq{AVECfIDC"l.,"խ{NSu~0hQ:K1Bbj &F
+l
+V'Np*?XJJdBh6&f0DR&e\ ;# t*NjBXqfȈ,><Ƣ=co8:<~XץKЗ6]Ro_|_0z6}p<ѧLQ"-?&! G
+V|;ޤa_M\K)c=kfcMXtLh3"_l
+q Èf)k-1ѼF
+F1M&Ɂ*- X[_MXd@̞w~+&7ݶ-\l\Zsmz㬇>l%t{gjh-Or۱ͅU0W&D1.E' {=61zӶZmvۧow؈0xe<4c<s[\%o.wϟ{?U74r |M%WUGS9Rok~knA >P*ҔկAYH%=VC͓ $>r=_^C/B*פU{DM
+FOȔЙ ub-!>1%%OGڃR.RWhBU
+ 53 -no[SZmSV=rH
+iAMVwd(QS$7yȍc< ,-ޙ?h:ݯ)[)w)u [\b
+u
+@Y+a.*hH9'w N@+
+)]JWW@n 0(JהrUULU-xHNW<y'o#*ZE !UI⪻ 
+S;d?+3yż=^uf/;EsX<'`9; `^z;x2rm.bcؖ)enۀw_Ż!CmyCrnXRS\ySi.&<'("֍!s'o
+buR>qggޙ7|+t!ݍ) J1}Mz <v(8bkS Sz /n;+^4$ pSsنڻcĎ&tPekA|[Ihmť[NGIIV5mW'暢sjŎ\k-:!4
+O3#8gnĀ3m(Yz\]/'s5<<13E)'si}aKC#e(kU wAz0u'T+RjA8I;1z\Wd
+Bg=1Հr?DeN 
+ٻ-%?ٓr+RٌUbܰst8L',1 8~s5c4^Ej44nԏQq]?AI0LS+L.̜2M.1U2a'*@\fbБq*? $Qr'$ :@JJȧOK1&6 PsvO3}vg跫B.{Sx]Ѳ+}"]J`J㠡M."ӻ)1h&i5x¸3 {Q(<9 XwC{P9D;fGHE=Th,#zl:!Z\`Ez`XND/ƅi=aF7x68XBkP4)v4k.z*XyWꝅNzثP{nϼA%H6⚉E_Nnh4|Ў]iJ
+=Krĥ{GJ<Usgcݍg^ ]LRzU|6骥?p Gȥ&TFbK*1ş5FQ0QE+VJ uUbm D_{Yw;T[]0բEp#Q'fG1gmX֤ʰw ,^;e{e ?fY+c.8
+Eux:yVCBBf'$D8UQ@}yr9}>%n@"
+'-^rXGkWN2СRpWay)<-^Ƶ6-LOmLJfm/9>;Ga#^.0
+a]le ~^ER/AAd 0uAvnGɻ-qenKqC#̱=*>dmr/>1@M676w-Y~j^$]Rz1px1p[P--)
+7ڟko7*GWY}Xķ8i̥gz˾
+*
+`
+,T$%!=
+C X>]aʮ`NH2loiW V.K:=y@WOFխjsɡ|i¸c
+;)usFtI]F _ǜyKh],sQsc\XFi򠖠zbe`(3벱Dq̭4@jz~e6uĦ9@J$9(vpzVu%KCP“q@s]=mD#R
+wbUn24WH?Z(-^|ӬƪK{'#
+W-wVkX K/iGyrܲUg.|PU<KVpi€P$(uqs1S*0Y+1"t{ȟiOa O#|
+TZ Xl
+Ƅa$X3
+eRY/d{GTv|3lv3OA]s
++2!Q "'
+L[y08v,
+U4$&|o" fjBAc ,g^61N3K
+o{?ʷM|O)S3] &s{qص>F\$kbܮ]AMiOP.UDJ'M$=ۻٛoo涨TAPB/IPWE (~x;μ<}KVojxi=E6ntFmv6%&[kGYλJkU3pɜ{p{gsS.Y/gN/dL]OYcը,})U`sgH.<WsUu!*YQO=6RL 2JșCe7F r@P ' bFt^ C=H
+u<ˠ`DX k%釂w%?tX02[#)9"-E:2|lSSSɁsX(舣J]A`!1_U}O[Ho0+4!()%~ zg[}G7-ϲ|zf:BLsB/y6?)؏'vi}DGHWb3Xߖ"OF ?;493n7w1L|uq>3<?=4088p
+AสB@Qy{\e1!G]Ry^yP
+7TP2B<TOHx8 zaIIp4Mf<C-B25dT5h
+1>ZQHVW<3RxB@D8y m=mH@tM;x o7</E tbh6<C#BqFtbBBN)
+4]
+}vUuns~^󐕎ይava[Eδ;Gδ^58^ԝX-eH]J(
+?^HqOJ Ib9KjuvYa 7v7 6v)]&Bl={9҃D䵸8Y9F
+L|dk$#q=Q=!pv"r2H1% .qb [ρ{Pg[Bf:ltucz>"Q_d5^韸Gh%<V}
+Az$it-j =PIP!F*Av):b:VN
+f)a#-NT?ROiG=CGQ.\_
+ Nj=Rdr9r |WUOJ2>}9AwTdswtHc7˧RH/Rs0O3zu㭷t ˔EDKIe!Q_dp)ƤޤRJ^E^xeZ}ykɰ{iѲ:j
+ wFZKcFN7qa{ii}{jLI?2wx7U6d롡Ɠ[V ֐ ubSH
+`5XTIIHK(iR9E["*++sq\epK",s"<.Ĥ9slt2[oӊ2<KьUXl8xēVt(
+溂_5sKuj_ŭ؋K]Ǹ Oj"%g,KMR/uRT&X[Q; ~PR5(c.XD!"{ZdoDO5eϤ%=|7sh9Os_8kޫɚl@yJTh.K@6SRޥdFh:g5H ؅71>*
+'ZCl*,}-0yNrNNIKRrAB4P2L-6 :΢'4 2
+L+2bt/ւʙm6E_ˎ 5Q*0nXrUW
+}Js4"Bθ
+љP#
+.چI!|/<yBJ,p tˮNxSĨd:& O(6r\&$
+7T
+{fj5T
+h !vt 3 C(DDkQTfu
+qSZ0ݶD qpQ` $PzlF;
+4x`
+;g.i:)KY,grGzl}%xbWى2JeE"UtU\
+)Bvo
+9^B
+R28ʏXx͹uqb3jL ꧺ9o.ٿZ/GyqKBv
+
+
+Z?|cl#7Hu(Cܖ+8=0r{ 0vvAl}V<Wywn$W>!b LPcYI&uԚKq' ?Br@՗1'!]84&mњO~P7Czvf|gS#^Ɖ)uZ_8o2aCuM
+Q6f&権VG&j|&+ż|Ëx{6cOXsuF}G 7]CsWVcVN?[>TJJ1)/!4F1#~!qz8drdZ,ٌ 3:B;$S0o/fW f[v;úWtoI Uʣ5xehk3Ԧ$l%~Eyxqgnc69{3Ntt+R޳Flr~?ک6BT.FSlնZk7墽k[@TKFw3tA\.]v߁
+@6H-#-8#Y,̙ґ~݃EꅬAO"iN39Ϯs81>R+I5x^%*"}
+H h
+F82xtBZ7eO 㚬R[?Y
+,G(svO`OiILPዜZ5i/|`ySRsv՞I a1~! iĉ *y\2 j*0 (
+"," K "a "digkzjzE$,ad '/ JXFDAǩ[ԭ[u:FF$: O=ɐ!`zàFI'y (.YWMnΛ
+Axok_}!DTDX'D  *Ğ~2 jI#@0oXMnjSpLL<l4[ }MsTM|R0ƩkI(g Tޗ f)>N/|O-\&ZA
++q<B^}@!"y"iHװicEb8K]pfkI
+\A ]$dz@Tq!*Q\eW{{ܗn=Zb{w|j`Z\˟?c}
+%m v]DdJx),g* i`6 >8NMU Ǩ5Ѧ5+ wuQMoh'#\jW,i .CưeY9
+c47+
+62UQr12.*IZcIKq
+l*$H
+0L)Őb@Gv 2 0d<\(EEt0,@B}UYzQz G@,D)|x-e @ PV3NSMvZ}&zLM-)'C*ET<h[!`2]#"M0y&o\ "HՅ P4]0?M/S5_0r|xt#B:!ڇ@݀`rx
+Tq01Z] ht{|>
+>>[>^;o!OƔu>kF>uj sy58 xd;6q|=o}|l`?emĈav 7]AQk=_7emssqb;y}D^{;hi{օĵÔfx6\>|1d)htNC 7ݺ~LB֑O˝"&G0B!#ExX("y="/0!P*n%DHfl˹@*eTzpP@Sł0*;d#{I D@XD `3ֶ=,*
+;R<^ǟUrGJB
+$%܁Zf
+Q0)O2zer}SG;lս70nZЎPJL$.V1b#Ȟ(JEqTO R1EO2H]8`2$0e:SG3xx>RssV5{ UW+x+5i_7މcN =<$OϗO^%d2D F,V0keG6TDE~_m|n}w4AkQNo'!;)H
++_L%RWO_nd+]d
+a;M ZJN {?;ڊM> 좂|U}ȗ`Ez++=em 9wZH]k9luM|nsLnqJ8lͿ6I[w˘z3VPBӸ
+sX7V
+t@}
+Əhh : 
+ފ=|[vwF.J{>[͵n8~_vwSl(x V⯛C\B9j6GV'CO'SD/
+>-SQiINGl! e=쌖_4, c0. + f! @1!@Euf1]3?fim@!@J$,7{  #JΡV[;c3MrZ~r.}.4rUJRl5ϫ~9Ab뼝 _C]ra?jv q *D*Բܤ[*(*(R"m[JRgf)FnA"r M-D*jRE-''"-B&|VF,^&AS2`2b*+BʈK m%Z@r(VvM!:Cx{)nݎq7@y.0']7*BI\2"8;<,t(
+9E@l3P6MPlkh ॎ_zֵ>,CזXOYRL{T'TmU27QʈeDAEZ#G;} Uoa1 ќADPG4IT" CMٕ$dql0; t6rpO5.}S辁9a\C.Ŧ
+r!rkV2Jt9,}՟ I!\xV,Zh
+8sw;ic/f_곖GgT_&!L]l\dF9Slned4L)? ɳm)Tch1Q&kJbMM)ph/+ɤ%'p]gMԣ3'BƊ
+tUɶVϷoajEj|[KlJi" \K~R}6FM5jS<h>$tֆ*g+Ӧ (v'Ҁ{;gָ۸TSכ6?n7lZoE+k}Oŏ0dHv8.Mpڟ;W ,Tg̵O}Ѵ+nsk>`թC'ok ^Gu-k+g/@Pが-\G҆Qn1ukB<fH.uZ}\WSDI!MTҠ0IOm&;hɦvz
+iZʞңІ"Y9^jUGaYtp<H] %hrc:"MzZ$ p)AZKv8H10ʊc" 0 ).*F9BA7TSm
+ڔi}m}sxR`ڻvHsR`FG译dYXXM acwq"nkJj8.2)bVjJ6^96Vzr3~¾߽g^ 8?Wt~ ljcs~>oD sOs /'2j"Kp آ(6$@"KB KZ{gzC?=K%@ $1Y%Ke
+;b`#0O?瞺UuNLߨ
+vpt(~
+F` "0lRxք$QBy.iY|'κTO֣o_wnN3]F|~8s5Twc>㓻a_߿NȗKB+.snvgtfm/reN\`ؑ!wJ^}9}+i""2-9 .iZlKrìpyU <P(%, %mJg*0yS(?.66:LH.*ly\aWu؆J" .jӋ } U:-1 )s-M
+U2(pLASç e(o䂔pnzoaFZus 2Zlf櫔tqksw[2>e۷o.tlp.ʸԱ~]kٟ o^"s-rSUjZTK=!R}F:~@'9L@}0
+0
+Tf^I,5TSˡ*Z $h eP XGD/44QL.]d
+t'
+6(h|ӗ7ӉMU`f> =^7߿ѿ3"!R Am,ȞUT8ԜoNśy<0F țoΝya6], D>2|t_+jjePHn =qJ|ʜ+eN~3p\K'{ՃX[o!qNܔ<>z&ӆy 
+IS@Pݶ}7C,P@@C &jZz-qՃ$^{-|"kEL൭@/A \m_n;{v~gO>.w{5Dx`4 \:ǂ‚sBSEH
+#AM,gG 6pF:‘.#Dͬ
+/&|^Cx_y:,CN8>>C i::;Flb]eIjAM`K
+^250LKF*5Љj-tD)``҇ǹeO8`U
+!3pH\)S[rxFz L$ʛXu1?DVtt~Z:j]z>6k
+kec\
+gqSܲf36pr.Oq-zr}")ߟ;,.Kڪ}wr}QǬG.Wg 'l7ŸrkwlϢϼlUN3,4}B pC~EKWXՎK}B>+/K#h۩ 73u8:Cl%o=coy~C]"s֐1J]Jqqmd}6&l^>]նB<b = VDuZ8L~+)VpM*
+Jv
+ehu-C0\)dH5?w]Jpeu(OjF}n&̹a&X̬w{)kk1pHwpPiPrݠEbp$VE*hX. X 4
+EC&&
+(EQ錻o:oTCMh(E閔z8P 3Ν{|E4 jv>1Ptct+2d30V]O68 w4
+،Z0oʝ;,@Kn\` uS[ ycɓygfKʜM \ΎcuՑt%M&,\Wj:Q`5(/tI (D:'mYsa"zjwu?F|1\o0rր]oB<Vо'SeKdjA>]/v "k\D"'N AZ{kzfnjV7l5n:b^YOR Ԇȏȷ3{o冔=p1)eSf(fHbx<'(<S}8wn/T;9H0y#x 14?lD,! !/
+P@t}ᰮ0, ؀@(hgIig#dx.-إS
+zwJ! *B<qrVY%
+ ɚ|j:rQɥh%ܡ
+ (:zjS )Pujϥ!HvL$9ROV T
+Vڏg-N[,yb:)7< N[ L[=]X |n
+.k=5?0e;Kݱ/3ߴdYi,u !\2|Z<g"ܡ
+.w4尊,֐H)e!8 P \jp e:R(fQK<+ܠa5D`i UuRl)5FhhnhI,~?;"]l_j:!]
+qۡҙAǚSp$'w'oKGp@0>`~GN q]"3xX+.Ŵ9SyO~Yk}m^[g0f3'Fn1>A&|XG8C~7~
+if|RЂG=LN@UJG Ҧ) UӾF.pz]¤ Vَ9Au%Cs RzpHN#~-(;1Hm 1|m:|{fx|şN;4t>X9te*[ĪO \|$=?<3 Z-"#$[jτp$p;㉂r$$B$ r`V.qw ͼɓ9~'<=8H!J4r2B?F'nI(׻To-BLRFPcliegIw ̘?ղU0Ѽ+bGo*_C?Lk~ޛ@, XlZWJ+RFZ)
+&mbJf>!g
+j!cT3cpAGF:n?4Rx䣶cy91Vh$`T`SMpZZNC_"g}v2rYfe.0+YƳʑ #g# հJ%F)KljRj>"#kT cV.5MIZop&4t\wI6=2/δ/*I|e<ϿG0jH?\GUxx \.3,
+j.o Lh2{y<ݹ-YG֨t7Sq86^;=H1iaFc-P~ oKΊl] :hr Nm˖O{Zag
+zF׎lU5_ײ:
+6^#T]*[sKuKH7x$΁7ߞ<g؜
+( Q3LX
+пr|.F~8Y T,h mm#eZ!<<L5+YbDJ/4E`cUCyk$}EhT"KYs&R.Dͤ \Ϫ
+US8ؑ7}#eDr,WGrP ryq'#*cΌc:K) +@A \""GNw'C@u\c?揷Ry*|+aIl
+Q;P웩dkR0x;
+iہR38l+SWAl"(BoEoLyUC[r
+\IJdtZDX
+ R e^/ǨsTW$gE^'! 8FǛ T~{k?Z>fz g%LW=.zXS8Y.'L6F?htwHyIbBO΂,&1)AyU:FX=!n3~htp$ǝF~'믄s_(2_$2_e,*8"DG?a*IZJ%())VŠ@ L6]vDˆ SP.=˘$43urcrl'k4EZT
+Z:KM
+rIN>Q䐳)(u֠8nl3NxEii eC_!o CNVc--jWt{v$0[wwV{23PH4dp!5P4X
+
+<eS3b|
+\H h=y4?ߤ܊k$ӿ-~&vgiĎExc.I
+]TNH12rRQΐ@& $)
+ o
+TF&IWS5 %5Vs
+D!l
+JYRXmH#t-GY2%GۘZ eavZZ
+ rD4@p S
+)h߶y -KMnR3m ;}[+-DͶ5G(Ml{ ^^K=C0 ^$%btx)vHֺI֌5g. zD}ׇ<b;n}/z]wV•>U`ݴOM7R /x
+Pp!Ɏ&0e3H6> H_HC.rkp9ZUhmي)]XLl[MxQIîQܩ뤜*̇uiOt^UqoN1wA A`wwž#d0KLf`m
+b ~/K=T[UoYh"pHRc!Q>#
+< FyXc'|*]GK~b"ddx廼#ѣ( 811čX%
+GMQɖhBLGp13iƤ [Yt`L ̉ [HObd)dy=r֫I,o9.|nN[wE[ϭqu= µ*eEwJ>O'DhڽWT휆6H0}Ħ>xjO%8G\/Q\H}&D*'N;4\:t
+;:=P!=[NϜփ ~ t+)s%4L[|VKn@SHTCъ2R(FkeSANifhʌ6PPTJR^z|(B|]&r.W|kyX
+,#/X7+4Wpώ Ưq ƫy&~\,+gjW z>z~(h-g]D\s΢f΂Zl•?uHwWl[ԭ1b[I#7H<g SNSb[eT Zyhy,UQ%ZCNDg
+84ABoM 3Y35 L1ΟeT񰹲 Ↄ ` oؤ;a  vjz_잚yqU5. Kr$, -" *"dNyW}uSέs;zҵ?jԹd;8)ww] ~lCd -kΚYGbL͐[
+rܠ]B
+4<t3y$8*0>&6==ss8avl=Ѝ$BCl 5/d}s݃F3A# NҬP=Q K xfKg(,7cc,1WrSt˯;t+ 'WpwZ?2E>*e$p6IŖj*o
+Lc3u؂/}7wew#iswJg?u
+>9Y8U"
+.jYQQ)eogMaJ
+<m!8VSiW+ !~zubՏ
+KrF5e8,HRl@#-D  KHHD=sϜ?3=
+Fj}7gs 3:$9qtnH:FZgx-hVm6Zc#d+Ni?/0!>Z'zU!.i|qs5 #}7۷Bz^+BE27<(/cEg~:B%g o ؃o !!0!ӯCO`\iCS@O{+
+&)ɩc)F@S ƕnqKH@6~ As ˡTC,UR5 sQu(aD*yd1
+
+M:QɑJ|D|/<͹
+tr#ѠL0
+I$)5Z5يw]SB-Fo?K&%@Ӄb8
+-$b
+jZ
+xT)JYi(&Q
+ºOm^ :5
+\&@m\g
+,s5aH:]Db f{; BPP ԫtDw}b@!
+Wlg r,S|װLUL'UX M\E| 9߭et,|ܵ?]) Sڙ6ՉcJ^^G仍}ر3 .F*F˶:wJLdqY)5r[@;n`_.ў[ߎv
+[ֺG| }5KP7ʺW `ǧgR3^XcB|1}'"vDf?륬 E)C*pWqvs,1"G&jMZɁLpB?yQVccdZ&9qG}ȝyk&
+>w+}S?ܑ2+4nZ ulA+;=cIfG1$9#D=)zDz,<?Y!ĊBlebGtfYXQIh^z#o!$q><zj0~ޚo6Ka9朘kS#żSELUSZ><\*2BṰ x<y;4LO}~7C;ooq
+g
+@Rw[o#URLnw:t
+#i{i$I`%x4므o_8O3<;U\-51ev~Qeȫ6E+UQǧ,U˕<!wԓ%,qeeJE EZS#"%|\:Jq+%w7<mW`{]Y!"sS佊QV/\žWGy"RQ.UܥK] mAWn7X
+t y= $)K4pL$z*6nUU_&Vosεۉyb e.t~Y=]ʄOm@mm
+Z@O@/s5sg19exA*g"16
+tþ`S{cfDl-XPn؇-q6 9*nptYcQ3ʚ2ha\c[P:)?/t9۷n"k!wwj/md׶:5w9ߵ;wnms"zZtWtVZ롄 *(!_$J! 41P2 E D.>T@#PDhN5B.
+%4(p"DAޥ
+4P?T JEyGNz 2VH ^n&Eihm Uif 4d
+Դӓ20V)AHc9)i#iW:VeF:}\&X
+?*0qXwIO6Ӎ`adxp`
+M
+J
+M+
+XyB\sT/IRb|܃j1T'1zgoʈqV
+)y@@V:8@LI* lKnwj2Y90sމm;8&:sĿyHm2q&TF&@ 氇Y쾡4ڭ?DUb<Ҏ #Db$=,L'k0I ?20$VGߘ5߹d1mcTs,բ1m ?:տt0-t -hX* `YG|kg\/qpd3" t6SǍ{5tZcKS2%ƁKl[xU݋ǧ!?Ir
+B{{Ӄo5
+9h u;K AgJIiE{ %drr 9ܷY9W`
+! G
+L,#}2|h; 0BGۓ PUUp 3,%Ѥ*)U+&UbNp9;^.Ӡ&<KT\#NWH0 rhڪ/{L*"(H GH<‘tw(x\ɾ8Uu~Bsǚg:P2$녓p)ɆNo Ҡɛď| -6f{y Z3"޵enJFԹTlow/]*4vʈ:0;aw
+
+hc"VŸS TfCK'k%է18܀X#\e\nL<ӭ<Q#C8q#Ǽ;LЫxO;O6˶mlrT9 3}X6׍mGۆ30WЂoszJR
+4l~܏_sZ a\CO -<9"9ߤ*8Q#aѳɃ]wLp{4WЧIm>-klBZ0!m.+PX_oW|CQz+5cɪa^ `Dibc<B&<0&z9-&
+Cu :Z `U x!DlU*|J^TB" ͍<skXf$ ,jl:VhC +j*WuQZzl\jLshVz,gZr\X`n ,R۩,!$kqKɩD tk+ `* eVϟ=H6$gZ;Br2JENXe!V_cwJOI[2R
+#)H."{s%?FDv9Y7θnl?*w'[Jx=vw&wC;/J/BljS_.)|+#>~aGS@ϓ\WԦp`sMW^ObN˙_?xm{L/YORɬ0C~Z0f,!Oxf@5Q!FЙc9VxTذ>:&sx":|̂-@}
+OMyTe\!{?=>=dXL*nF͡H~&<X?8> $Fq1a7c&0KoJ_1Z`9vLyPSI9QgYbD% 9_ ( F9B
+]!(1.̄S"kGd.%l|:]:ڶoc8҂IՕ7 >
+![O?>\=T9t<TE U{ i-V)bTɑZ
+QԐ*QP-0ʃӔ[|:ZI+ޛ1Q5}!uclS`Fk0{cr{@ɼF:Mk|ȝ?*D7I%) J9$DDLA"&%Dd""%,ДC_UP} PՐ;d`,\MVn dX۴/(dq-Z1> A#5x\ K
+KFI (1$D@|
+Բ-}Wdty5}q<A'N73d D=h{k {#3FXBdŪCQAs_ϓF>z=w` cOƒ.AbRTwI_~A4|x l^
+k|TFoKwz)7!U/_1W&k:;'wo'X`zXGhO(ȳ{2ĵo<10Ǽ3tqwԇ98MySL42n
+'pպl݋8$DA,Zlv[\ǰ AEP/etl9`g-]$ws-.+ZR^~-2\sR^ϒ:U]B}eUԆ7 }XV}֮b776oI[nh裦:sXS˱Z8Ag*y9<K+ua3{|T=#s P>,PLҕbҴ,U>.KUD
+nDrM Gucrd*rNcy<B4|JK?;C9[v<rZQL4, *g(9ӊJ
+;婋K?x^v^-ɧ3%`k,F%hj]nih-_ALS%s^=+sΐq<Kcy3דRzrR30"pMѿhgE7U 7$SR"Oy(%+
+q)rb<4vJRsB ]>fچopȗ7I}x<SjFL'.U;4a#qs"W;F*9f'6x|qM+W_ՁgiftԴ)rZ06cXC1-x-T$@ ФR%\J?:UG'E Qeu8y->F!pUPN% &FS
+Yz><$>h
+n;I79CXSRe j`j!{@䓅졀G‡Z[>ڬX>B-Y k3]L0t
+،iPƵFik1G9#$мI/<jj{"z$-z/pĘsXdF".:,9!1U *jp Pu.UUNUc.ɪZh;]]jKJ: )u|yy{3I^G%hРvdN%i,ΔySJ4)ΧZT%1VLw}pu/GhhuḺBDu!_ ̷.}$yTSW-Z@ REBB@$SEJ8б]\
+X쇊GHUעҴ_ A`R45`Aj1\mds1)?
+*/5^ٔt۫=|½.fvHG󒏋-yd
+&piao3ݑb M6\ƒF븭Y
+]%
+'[|bl|FQa4UjJq<H*x
+nҖ!)*.ҳcsBYqK eRbw\NQWG((!;oIOC?<C/E] |'/Q^ek*Q{uU A
+! `}Lf
+:JkDw2;ܜfeRbhZ=֓ ]zf`6>:1wrcZٺ[Zv쿙4o6`acZہ=lp,q`loc>n$'>
+7NVgϽ\^>o #8 rY\ts5?Z>=hnaս,vwoMFk5f3<̘~EfH'M6cӘL왍u&C53ywWi*vxplXTl'nA/TXT
+kumgpNt &5C >h3`
+aZ u!68@h IA|`QY
+\,N m=ek;,eF r1ٍCFIKހ#sG}3;%r&<v(x!cwc~EƘE:ZKo4up7ǯ(mv>}uǙ\["D4,F4޳nS /g^{z1ͽ{"!ʁQnԣqqVz77 -#hT01
+ :aNhChz$-
+3Rn7Teq;y:-k0q3r6y<n,ߓMxckJg,-ߖ)T؅C")ų";Ȟ.%%կ{Vi=^B,ǥr 2e9T uN:a#<3p!rTyCpe 搏Hr(GBlu 5NJsYL:")
+M<&:&iۥ=.s?.@4a]A%H!P-gĢcp%MKIR2G=ғ'΋O9?xvN9n9eJo9h7ik..ӎ\qtR|$,!]~BJ$Mr9C|).i <WvQ|׸ed&Sv'YʏyYҊ;[R;$<d"T[3brg$1u9FuZ-y(um+-Q]ᜀ:ţOрB6:JSE+12 {V\e>C*8BOaJ AU
+:6&E<B Q֐",W^ ^ ާT8%pa syHEgL_v{iÕŪ,߰v.o屒)krhY*!\d02Ʀsi#[\DO9s9w`~
+'rb0@.I ߥp
+bGQ\wqcMnQZ!2jHP Q e.T)$DȺ4ZR;Gv--ds\55v
+!zRdVUᒕUml&HyOOJ4㥍DY&V-p 794jo0`4X&0}!)*E6+<n^3g{iϴwFf33`Eb? ,icMB&Mv9_voijzMi)ͨa`E܁LO#ǝ8RιX?ƀflBʉ<=p >|_⽌vb 4nI(K
+%W4P?WJ(
+ؿjVq/0@pF`CF'[Iq}F:Mڳ=ܟ ΐKiBՌ͢KSnO%
+UŸ" a!II!񬤐|^ZH,N+VB:,-#R8r.>M~s]k~>׼J< ]bi)_zT tENM5tř<e|i^)lKg8R^Xݨ5v!feE܋e, - mNqc5[C-,=ћ 
+7?
+P I$@@]Eurgqc #n%IH9@E^tFXfWIu~~X o=$5@|*P,ZCI)p8Ed$d,çK+]K\3&3 Bp8gBFL4QZfZ)P52b54> ׹Udyf|
+k[Aӳ`AEP&\Vţ"jZELFIHm z0qf2'I .
+qߴ|մ>e˦Wqt|y'&CWl_7{)eC󖍑Ϛ좞J"~>a%XO'c"@cӗ$""
+̞rd?hwkr6\xFMVP*t rW{Xcd`}c%}vs*dCsZBD@A!-ncH%3em.?VbRYw,LbYl5X0\
+DbaH \_L3`Fҩh.q@i7R̜bV2rvq' AoyTD9;uUgh0KWɖ@@RF<U$PMT-Te)Icfn|Io%˗ί\uRs Sci
+aa_@&8~.g rn3FK?@a`#C%|p_U%)id"3*|efX(2Tq䔂wP`)DH4c]+C2eP"XB0 Y2RDfIVfof\^ o&k:ɺ<9QMp)Q+ `djM1m1FȜ*Ų7#y[@
+(RVhM<ل&ꔸlEez,؊'N*b'Ye-vy9r̉z4mNwG>ǐ׽a={_.n {,zqgw;;=ki{v׈nOნ 5 כAf[dm4*}J4R2ٸ@#
+3\Tmk4ZzdG=X#ۚ(dPŔN*5֠Fs4e<uv
+Zqս#e uOfo:e1cg+^3+4tj u{uk]g7rv{ D~\ls?xdeç'_%
+BԣN ^O?FhBD\ܩ cFC4ܮHnHh_5
+9r^ѡ
+!" PA
+sx
+Z9in2b8]"h65EUSK\%Cyc[. ՌZ@YCTS10Xm1yHLHrI6 X%z%+\SKܥam 9L[E HXQtap ,aRF.YQh-e
+л<K8i@uTA |S`
+p]${
+$j1mfcT@VJĊ<vVJ_Jr
+:$-@ 2Vcn#w>ZK44 nC8@CH*Ie!*Bۢ v
+UչmWK\h||'ZoYk}>3Oq4"nnv9g9ʌI?k)]ے/ZV_tE
+zaS*]QD Ө*=qҌA9/`p|܄q ug!ӂh]74f>7,r|;8vw˟pLBz pILmn;M &VbҪj [9M 'x=M`;7>
+IDm4A `
+"دD `?^c2$F[Nڥ' #鑸M<N]eQdʳytE.+Uq MŠix15IAU$h.B
+hBUD
+HBJMiK]c %b%X}@_ꡟ \X`@ klr ot16 5Iကut\M=7]JGTbB SSRWQD 2` 7 A9c {¦!@NQ[m8_
+T5C]VvhU"[xK@ |HS>WlJQyF*(c5_I_B$0+&xe'Sb މg|h){{;nng7gr:M´ϹCS2ygB;6a!yl1i3ӤL yÿH Gݲ.I4J.=_\SE0>Y
+8MX\Sˆ]m.߹uCa۸~f#6'7[Ѳim@|`i
+WURUOL T\ ip8Q(h@RZ0Q6BCs”(W ԹqPb'KdI&+ل@
+TU^r}syQzj\CdME(|}56N_B%JWݯA *Z@6
+w@Ɲ~F]V:M,wҵϨg Ǵ룷Y[4sł&+=^ZYY]g b [?<b2b2+{b2״#iu؎;#m=Yet Vvr*&#%S`T
+2JZ
+\DLB@]E+WH  R俓-H%dE%5 =VV#!!XmVv@ RskࢵtBgZVH5N ԏGdC 1Qw>t!po:`&tΎ&kn8ќ QGU=곤3/ylyT^LSҐb,(\
+R)uNփԗS
+\Fqΐy_i5wƠ7]Czc&%>q
+I\lvϚN#{OU·cr:fmV<0^f2!͟ m2vHw = aH3+MchCL~Lm5zV`x' }O
+h Hj2(` 7rab(&䲅<O4&&(HLk2L,mǏcFk^Q&`}Ǘš.Ӱ~ 9gӉS&@<<z2},PMyܷ 桫|_f1Y0" &YEmQhlmm$h$ugfbt e94RRbAh))q~rmCnG$7Y×rλ ^p;.F˓^bc _`g]d|ux!-f E1%]Y䖮vH~]%ƧfBeZ"9't1eyz #WRqb:+guBZ̅.1.2d9UVt%IFRp91A[
+_d*_?&;K? ,|_טYuv&QJ
+5[V@͕0se9Bq&
+ '_'IΰyuOVo-6V6t= eww14bF9fѯ*zw.nxQU
+y罪2E{;ӑK\Dhk+2lcSKKBQ 3] ׺kvoaR4t@!5q Bo.| >aa:<J3
+Py x%}b ܯ%jj88T UPẽH8Xx
+B t
+rJ!@@]wf-ˣv,ٝQTC8 }$@P]<ttڙ?}U<P $-_pP
+Txglxs?ZZjjb|rw\9uyۣyS;u %?j{vys&uC?ae0 f~K6z_2IyéBS2UjÕ ;|w꼙=qSn⳧<cӋwG{^pOǪhQBta]Szեa8ItJc4d3(E#BɓĹK7~) JsB`%ե;׏O~zqq7w#+L
+ևuAʐPedMao 9v ˁұ[18zJU$#VUH=JU R8wN*bwXu ;ESL8E~ueEݎkӁ!0%BBhP7P %v ]*8
+EA{.!FV8R rHpZWYuN@9ɨ`2N"+|]r̈)f 4;A_eLANm&`
+
++Xa6@$]^s6][^nwrսy 6U{GdD)"2z
+QSR;t>j"Z)T4D)0
+*hJ4h}"oD'8p 3~7
+(xR_v
+058 ƽ>Of[mMv#;݄X_Xģ:,=vf>>>WkYR9bFj4VBL~$'
+)ֆLfo#W:00{5@JtÚ\/_?Z=6gnR.ιR,{}0l7@kOx}3vO QY9Hz|,8Jq'TMI%O vk3oBl:Pr'z
+=?eԹa@{*ZDٲ䐅
+p.0S{ 9Tcg+DD񦛾[s2GpPLSM͓4nsTTMAUP]~Ej_ʖ*$<*)Py"]3Tji݅x ^d iB4}>&ݔp#~;j:<_WM^V׭-m0ۇn{ 5{8-8t"|E$ЋgQ|8:PM֔{L@@뫈UJ
+JBA#5qh9!A [p-6`t.v9痥8D_nE:kbL|Y7\9wtg`&
+uKCN,fvټ06f[4v\;'?#Vݵvޙ+ <m"hE*쇊Q!M.RӰE=bг"fIƉIVxd@wRn!iMMvmwFCA(*_ tsb 1cD5oaԥevt55Vf nJr.
+(n@L!",yTYQm[E{B . k؉Aa%=$@AVP$ IUJBkKۭzZE9wޟS6r$E{(e18a5$PXvz 3ZhC]-^cu^F(P@ b$F@ I㝎O^e)I: ~h[>l!.ze[ʵ\ SƟPNq'"\.G.9J(SYITV3Wh9eaL>[YK'&Q] ۦ&`c]xc8h gh;Uvw){}UXo'恽![?DAC0d?ܹ7 /5~_~uY1g|YFU{g{ 3ۏ ~uo}+crXuEDp&xoWH9ch{ϡpԧ2u.8-T g{}~oߪg/,'R-LZ5FuG$6%D 3G6>Pvًdr_XN9k=p2܉#;Fۇ<l?y^п,f3J&]E>۽|ֈg_l2j+u3m}gl/+fl>O-8oV<YiRA52K|wlE}֭O0(nC_7#v tAP8i P
+8֭
+!vφ ~Qgyw߶پѲeˆGw|q[xWǗ-N/ lMf?{$o?'xѻ6XB}f=`J{+Zɶl+wJvx\ѽZXЌi.~yc,Y#񐲆Qr,e 'P Z
+y)
+;|R$N(5&4_8Ӱ 5kLODnB)H'Qޅ)w]?ڗ42
+\@0;!d0@#"VyS{^U[DЂBB
+S1Oz, Sҷ5dM fVQjC}p߲h qDO.ȅ63B~<5`%Ӄ!v[0w#CH?#V Ԋ!&R
+ :4(o%H]9sbIE91[YPh.0 IFx$ރgL 0c[g+cB-0E&rT=X7LEmH%7};c&:kF܎21됡~Ի5U'DTtQ(]jt*v؛]v~ ?m*tɜ5iqE[]>砟66vh?ΥtFޫ9먏90Z[ѷS.LDrPUK#I9 ?]x[=~_o@LD::)гO r u X(\af^CyK\Cn⣔Nܙyj7|^wmXآyަ o6H^w 8LM4!R13ɜ,](<0
+;{"gĬ=s.ʶ-$MԸgW D/fehXrHy9<6ҕ6]<SfUVc~2R!d zy
+HWyߍ?ρ W8-Z]:7_lzZ2N'Q>Or}U:(ZnTgzw`n{gW4s['Wq#0
+dKc+Һij5xr5 p4Fm׺*^_{f OrG5uX0u݂
+B !K vBAm]v9Nucd55,aAŪ佗GVRO27w-~ h{V~}sKt
+GNw),1z|^)T)Bu#CRzzV-sJ(W4Պk*g&H&^ll%As74y
+m
+KgNN_Q~vmkYC㻼Ͽ&s²lz}6Q6]sן̟&_6&W-?Oqss'\~o\/~E0e ٮbun5я2%R=BCh0uHU9l°N +XȳӮyϣ;N+f?/V{{!Ȟޮqg>gwzz #4b&έz*p՜KԥE3ū/οH;3
+.%8*](cŪ z/r+tD =QS{"%T1s+<EW  )A˩qzZ2\Ȃ"!}WypwhG 2eP\΂K89emRΜ(dd%^D;Rj(>i'CY)C*9h50~2UCI52v+'nێ;M>w[آv(~$ x'2ge$"rH6320)+ rpu$
+m= 8-I t-hC7o%;f-%K45u%IlA@O.^1Q`d
+tygEܿ 0wאE;˴Gm+_-yg]Bu?"^
+mpU°}ЛQC>p̷;F*
+CC V"Rד{RUyRs"s6,9٪"z+"(|uA.1هB耪z{54b-i`36 Yktk )PF@'Db<U3XuQ&G<.DeA)^?rV\$ةy|N}0[LJ<wGou W7Ģx}GCzQh-TzoNyP7S)a1,tAuڭL">ܿUdl?w޳u/.jLKIkH"mG j;#oG5oh"'h+aXe/}l(Y:{nᨽL+]k5hpuݡW츋}IprvoäSI.󨦲;: ,ld#$A@dDFv!t@Q{N{t`d,ƄlP! BECuM=yw{|\}#;3ԬgyWoݝP[ho?`3:u.h^]$Qђ`0:IF GC6<H00ƀ'p`P?vDӒ^R^x!}pl}u;?̎owچ?C,)]k]<^EtʜqF镭+^%>&C%ͤc7bDy6u,d4_+E܀5 nE:5%WJKV&'nvZfX ٺf2up '@2eF ť+MaijwfT%4" A)FTd* Q12[T
+$%#&2D5\I5)@JJK}\`٢r,0
+yh7m?CxGtZO
+׶õM1.aap9. *q᫘)GGȁnⳐ[LSՕQUsE"LeCX>%k1[O:
+}]i*L׎ApV pH ZrnFCd&Hd7 ̹9`
+^2;kxJ)eWeIk5Fqo!; mMIR^ݧW
+,_?piGtBNV;x92 GK|#>~y@Π*NZ%V
+G( SmiVnX\]8(zKޏ᫐c=þ}.#.kmhM<BWx,Z̴_s\̹]Ks֮[rĩm["\{`X.󠦒5:")\$+!K C:Q[;S%$ @pK@$/y99E08vj_uU{Iw'$
+ @89p~`fv
+TS-@qU%&_Sq)p5,(
+QURl:ۇD/ 2Ŏ.ǰvDPɁh
+‹e~=yuJw|7"t̵B_w/:\rksnve@h<4`@40 5SE5P5^j\ W`IK1Yʟ0w?R.~ky 9N[(Vk !|XesQilzZjg/^>:Wƙ.0Qwh5#A*
+;b(ۻ2_cm~?܀z}ŶKď>9:R0{̶1w(F&{1<İBdW"hi3?8DK|15C(T@.N8=p0А=/f[>Kv|_6?ɨ
+6Z3ؠhء 򀒆k>CZgR7N,go1 I&S`z4L4(~|6T2;m= ׭6/Om9MYl:"K7fݓ L׬6:twh;vn dUGtr#"~ʃI|Ϡ㝫!w>.g.=A0~GCJ Zzъ/1d
+}%([̃+:ttOTz;''(1I#B*T 673EVCJVx"`BtNZ
+Z6T6TCʁ* :J6HT
++kb2z l'9L&V1aw.?X*+6 +=`~.8~&MxA%mo.0?osӧ'#Sw'gH0 "pc?yJ懙Q{Դ_{C3xOhOOЩl2Ws蠉h 7v[_@(uLJ¢&fz}f{9yJMOwҙ{b'"]q=Lf[ORh(ǹ=捄3vY bEi10"2ORM\lK\)u qi=&[ WWAh ϑ5eM$B-Up!sZB[5.*QBȕeJʀy@W SI 䳋Vb&P3\
+kĒtYw1!J)>|2$ flMte, GфPCd+!ѩfljǟִNСFԇ5!c1F`A稏'@HR;k#Q➢|0I=Vt6$MGԽJxo&i{PL}/::x2 `6隨kXjGvx :`p6
+y3tz,9lv`иpVa h2&.xӠc='wƬBx:fTd 0a[<ȭ-`BQ!)RDDS:|Uql7L94~x%'7 f>f̂N x;k aLZ2G,Xo m#
+h LE31Uفg<5wN+=(U{r
+.{|ePr"DyTSWǥ3XPPle I Kط$$
+C"["uz0]'̙c2XK6?E;ע,$0
+`0yo(fu׽x~XF: i[P:u239ޮYh2 ѣJdDEHA>pP$~[pX1 ijޔ/^_ǿn|5W+Aٲ E.wmJXapdtSȂ.,~ۻ<S35y7'~X#}ڒ9_9LQqB̺O,~j/{wmhb
+SnR춦oK뜬Ⳕ<l-Ǥi`xEcW4
+$P}A?a\}~p#
+
+ j0qiTALTX4kK|mTDG&ȣ"q`$
+Pl@f[4`te.X
+hJW ^$U׉z1T]6V׊J
+CBCLs”<bf̤^2U{p΃ix0L &3&0 X=G
+8R̙M%z9v֑5Qq'p>
+o;4^P k]H{f}6Sգ7⏂_?<B]kYiY" [RHO[)6+U@n/z6<XK-e}L}v2V&{݌E3;&MCpzonxo:`Hj"<ؓ$̣80b aMH ;k\ MEV"ԕ$ad&!@!AĢr+hxw93>^]Kyճvwخy_4@Թ.muGWEU~@3jgqU>tAoEypz]ϧlup)JN'nM2ke3%2iG2]1dahͻ^7OQWvڽj^]6k{}gzpS1|lj3k5"@q<R1<\(' @p439QrjFӧZN&}:}i%CRbUb!]b8E;I{
+Ă񑔚ۨA
+b@:CvGճ]ӰYӠʻZH`"$[C3Ff(}L,
+ҡL X2Pqf= P8(FzyQ2b"k]FQ;RM`o/zxUpsqK
+ }u7D!<&Ya  Bk)Zb\ߑTlpXn"
+;:sE-גB$'mhƋjƒ4+L.;7͇|_x%xͱ_GcC "E& a"lpOZ:+e2l;-Ó ՚0&>2l0
+!5`]I̱Fsj@AeyHeH6HfQ(AyAUHťћf? G"Gb@3PѢtXoFoX&
+[\n?5ʥ{÷ȉ)\IJ]ia}}"ulOo_9c֜ɯ#l"S M
+PRI36R1lOBuN #v.~;Cٴs7N_vQvmX^'|"
+}U>[YGN[}qkvmջ=޳UXoUX+=9YϪ{(!S(85QTTh[]ZbzVq{sQ#Kt}
+ =8zRq眽>
+@
+ PY(\ J;S}cPOts,[sR{L眴(9p.& $-`Uh*m*?Ϫ~RiKKt%A0 L4a a<R0 S\HeW‡<G4U0"+CJCR}~θZXr5(2nLk~9Y4N D<4$ybmKɲddqD
+4 sSKFK5wFuӀMK3߁O7̻d!8UD_D ,mky"t7$yPV%!"KX @$$,a){;N
+xdU YH"!{$1A*RT'?9|g<Od0 A1ɧQA l'_Ǽu
+dHLACS 3$"F"(]x$Nq]q?}sS/- m6
+M`&rTAg+smՓU
+kxIзH%ZRmLhXdv;bp)ᙊ&LyAIk%zT-H.QYLSdHQiBH~A_\GKo%wʥU`"]xe //WބΔF
+~վ3ߺ?&KSk3iy\j[ط"ۘ!ۈw6!&Bl& } ;8kr `|7ԎŬe>OX|>FVUoіSC{3f!AA֐-5Ä#a[`6a`CiБhqӱiZ<md
+Y AK@#a+*XIz=cuq7S䓡hTx](KS
+q UE]o",#Yˇ&.p<5l5jFd̚z!e}٪ fB8Y6E,ÛF—F\#D1nHT>L>w!<M .<t zsyB܂M
+uY@Q
+5DF*C[;sK#s!릟_?Ӌ{ݮb`nLBP Ыk뷝Y6qOMmg%HY=-qVd܋}V䈸zλacshT"j`iAͯ};˘bgNF(u55:f<^5zFd}WoIܙ{״pHV/_ބ.ՓCeH̄O&!>/QUKd;稸6~*$ycak7=,Gi]pp"]:'n-hUuoqX'C{qX"ƟKLSOwi(X2ƚOCխ@i7'̜dɺZpMOJӭkܾx\b+ϹnA9J^4]| |xYF=MC[p(k:ô 3-Y7L
+j |v y tĒlWnkӤBXg%mL[ ig*.ԅu\l$BeWf1ӷIoR_B LLG (3<3!ӕ=jE'ͰY:Ow
+|um{T6/IL6J 
+۞Gg_M+\$4owF<͞cq ċSKɛ K
+HaseP#GRGNQkDiCtdh27~wah>W#OmL𦚗җ㒷kұŐ7}G/E|On7 6z1bh3aZCOW /oxJt5ȤV@/9'[NŬqOE7[Ĭ[VlXUE mW,כ%-֚%kk$P@e0H@ҿ*Ƨ*
+,ob/p 6ჭ:Iӈap${^w.'D' =5}+|;|9u@b . :#4zLI>?B:,\k7~O:Q/ѲL4\@O%]ZςI(EiRl) 5G
+.qɖxd`[&X4  akt>KTA//K X@11MRAL׀ldI*^ *4Y50
+E->QՆf
+|.&fJC0Rq]9NԅP$a@
+Pj
+iZE!MQc FG"z>I@gg&+@VG~F#G
+ {v`?CF(E5pt0MXU3Up>b
+M,%&q|VK̸[EǑeaiݡIq2klj–љ7sE- 2\SSGDHi((E("$~owL|}.iư'oEd
+8~(OS o}?s虡oG˂
+'JNPOfD挐
+*OHd+Ijwēe9sȼ2X|9̮4C_H ͸zOf[+V[)vuzz۞M{ļaU}9 *no?P;%+U{RCnгks.W_\XF(ż'pf;=&x'bR`!(߉Xֹ+ICZ#735a^=E1xmN+%h{҃V3߅k OD
+,O_˟;:;?=G8 
+t4D=M1# |ʔ0ٵlVwΘH7C'BÇB ŎGL\*zHn&$hDLU)%<j$4qAmxv &2U\~KV6g~;|L8 ki%"*0>`
+Y
+MzbВB׆FfU|ݡsUA3SPiQaMba^ ^M
+
+;M$=%=ɘh''C'NAy*#_~)-A,
+M@`qI44?4WZ`éBGɨMDQWk񽡋d~ }Of="9Y{˜T^!:NA%r_`
+kl*<
+ݑ?+#\}7:S[FH鼱䄆JV 6QrkmIr0h*o?挥m)tp nj5s50wKI.w31 ەӷ˸'Wo=6j Y%JSwýQ0
++qZ&si+|pha8׈{Yx
+{aSͺK'\`>B@EhcɳD~o6UkM\j<Z/jZ#{jr;P5asi#d3iZI:ף/4G!tsgkoQ.Bېf4ZUS .acՏudw
+nWS-!9m5W5Kڃ<*NϼKQ+uA۵
+uJJޫ!KEO%Ɇ'F2b/ҋ$~eh z Z>_۴+?#-57y Zͽx=Pl֩}e~%yV<L8 *Ky+9kX<&SK'9ViRD,0^Dyl a9,_l)BeĜ=YzCS#'@H L
+QX-!y3V
++ b{py<4^=(sN@cCh|k%:D &v{+h.$4ԚiZY* 
+(
+YmΜ{qϙ3ɛr-+pQAEs Y]؄2eԴۜw^>}?'_]Nr(NOkvawbx#qPX𘎄ϐ1zpoWDcQއtbxBd;DŒrXDp}8|10<d\Cd8mz]DG% 2iLG
+7Su)R*qS an,hI.z\_, 2b( 3~$ &PVX+)s^xJQ?ߚ VÚõQUQU7_Ov?9wE_j?JiM @UHPU9=U=99Dx1m@%gUwB]T)ob/OS
+J(}l+M_`x@t#*g?/}+
+@*܍<6O1 }XF!eX&ߌƀ ]}W 1׉J6Q>83w$@ ԢNN!3Օ m"L hEx#<,V~ѝD;J6h[.-iQx0IgUŴt$[:ak7,ig" Wwjd;c6](!܎0dl~FE";>0V;_qn)!ro;y'eiM} Kz!9,U߾oib ll_kp 3>m#ᑤNB'}Qrn:QO;(6I<Nv(ߤnmF; ڢ_("]G(b(t+W}e7G| ڍړl#ׇb>}/qл%vdnk~ `
+Iy@ SQWOiAgZ 1Pf=Z`iu~Z@ߚȫ ,_)[yL}W>7+ƛ'eJXqX,0#
+t++%Uyx.ks
+N~3~K8iiߩ *_Nz5MW둦9)}T1"di㧷{<L:qVjfʱӵk*Y? z=:Ͽ(u6wkot 6\E;%9iXg/Cnq޴m~5VхgF xtU]+tY9)ɩ]ޞ\QMY
+#g|Rgh虿nQBgyH  |ޚo"OH/";o㬕m_nqcޣGKƨ(+gtvKz0ᓄA~>_G
+^!&SHxKed|/DAVkL^|hvjP$"jTHKȌQ1ᤪOA}b~}Iҡm`X<$jy7f|qAZś$:e^(
+$b*S(
+n-+]&m! xE7zV3ÒqI)Ro8NˊS%d88e$CREE}w+;?,NJL"yGϡ}@C,FY=|:L(#fC1bs>?l` &`{ lUq ߫OL?Ÿe.IWYITplE5,0ӊ 'Q.f/oЀKʁ=Ӡ{HpĜVaHSSbL2TA<(A&( |h3&T! bXy'[YK1IcѪVLZluI=:O\OiZ."Y
+_lxhj mYdXZ1m>;b͚&yUK5}@O
+^m7Yi7 ~%:@ІȐ)fltm2~e.
+L
+̙B5s!Ts~JSG&T v.j\Ù>+J'|_S^t/GMUi*XchlƍbHP"q
+>W<f{)GvG-v~ Sw e64y&`t 5aMǍȐ%.6GЅ;l_Wz\Wyf2}
+Ɇ.řaMйzA6S?*7"?|uV8 ?M.eD4trs E|ŧ59?bvJ0H#Zeqg _ >Y8Z.b H;~MTSt{ B' %5D diL]1Py(Dp/mKA[rͅW\>ƈ|; 
+D'
+WI([I*{?IWuXt
+FңFnjzc*QoyY!:Vm*CWD\hJ09zbu?csb`3:ne1Ggӵ)SQIuS^&aNbH GfAa0Jb^mȘONΜ M"d6;Ow *Wej?Dk X|G~I Q=(&ɼ~$? A%%҅֊Ih?_ùAK9µ ҆r@aRX&߫ #DHc j2\6:Gyt{^s|C|GpXP
+}`.>Xߏ F ||ܗUv
+ -A8U48"?RD<GHcbKׂ9&+ahK"=|y4 jS
+@-7_W=ğw[`t_ԗg7l қ
+6_oFX%}f& Q0
+VL*YAj+8NU35&M4ٰ!l%؍6A|` >B47[v{4kz@qZNFshmлvy_窋pKC sgaBn}WZ 7!;>[M>yڤÀi`2#DeW
+}+_EřQ`rr&P7'#:$
+Jˋ'VI\k6|qe(,<M,6QN\䟌
+1} CFptm |XSgCFLrS&I QUs8@ Cl*xD:X60r`O"Ls9U qROOYg|brXq>"CRo&2Y˅<ml_wn2,q+J7
+/?<B{XgYԐʊp̿Ŀy.jn-@m:TnwnG);$| f9( _Ԩed(6f}P Sl@e:<̏N-V})O hm%aTHc9XxR G\}އDb{WPpJ܁wy)vj>m&;jk'BGmkEV9V8 u,?~6m7v>OG/if7С _-զ-Bن5yp\G|T2Sdb<9v:aFKGZ矺W#b2Vt" fh0*ډ0??G}E/G;LItz==E\ar躼P=k D,ʱ-³9Ľ=~Mn c inqf^W0Ey`v6nn
+6Tiy%z j+kwA??6V
+{ Mkd3]:wQMH.4v/LNT"*7E"(
+xor6[m3=m;mɶ5,Q(UgŬQ99ps9s {^::B[],׏cɁLlHpc,LaǸHe/aGɴ'Ti#`*| AVm"U먁MC4LO
+lzA^ɝ?PqJprBpˍ5%ѓ1|g{\bo[$Y%Ò
+(sH a:rDPw^+CB>AGAW
+=tT{yP{^ojocr\lZiTA׋A., c Vsj"E
+dvh$Ph_~GL
+akNzZ7$&,(VP}si_$,k.w_~Kא7$,\v ,f}Cc?w9~}uu-aF1yZ:-ɾIXXR~/*p ΄Mm$}C$KyڴfnH`XLU\ӽ!,g4&[e^$5Jǣqn ',&$M6y$vЬO>`}ӌB7 PBf_2Vg ,cS`AI-> )<܁u@ǁ}*ufX_)e{\ o#֜T_jؙ"iPg4瑿h.jϣќÜ뿀9
+::!=G w c#k.q˟9)WBHދO;2r3ࣆbQM䏺Ђ
+4 ^}%<o
+ks #?e.(Ѓ
+9 ^PQ@"/Ƀ68~Z1aatja,|hf.)2ƅ
+<_wm$ʶ{@{&vDu"o $}"G\rJ}Rֲ?_JYNo"ʝ6-:t=['Riқe PO+VB"> v1 MiNEؾ1vU6'|}`q]w<QUD
+Rsdդ KIDG~(I{, gwTlFOmTJuH"@
+f+]ծȰ׬Ϝ廲<WkSxNQI~?CU |[<LמE_#v
+255y35y6Z~F7 +x
+T̨ƮXP[~׏Ĕlyy osSSDKښO'=ӨOAK%7)hZE33AwD3]QMei
+X=`& XVFGwGwt]`CYij @$&APE{3{w{{߯YRG)%F<lϸ:,NvW[YtZc?VuJ`nEwŃMe_}84f@BPߗ*nGI⇀{J iG S}|y>=s+ >{nF]sT bV ˾ٽ{duguipČT$wCA^QjtԋJLI7bcJ^,Fk!=UKS,Lni!`i 0ꝥZM FXj4mZ.r+< 3ٴm{mk%khgD8T)z0zf=}4sKc3֛-13V1jDLީ6<,yc`ٍ:͞gOks&#FY*GS,rIV8DֺF;Ӗܳ<݃2ewGeGzJ21M Q.-tux*[~{Jv
+%dLy*݃JhFi;GpV`?:|LVnOQ5~*=T#AQ"IJ! GڅUrt܇/v6 &,uV]M(2=C]AiRza<_jO_xwX'/tXaUP\genߵGԇ( %#EcUNq,76/f ޝZh9(./̓3$Cz9"CguLQ~XAeg:ۢWJ <y3yn ?,?({LbY2b%dT)y(V)<Q#IVJccexY "^ZfIJW$8T3
+fIZ4\aеhع`Աd_ ^/4sdϗo]˨ hh۸oV],u.u&0
+FoD^WucȢ7PsQoBa{oAj&tؓ6B%A3cLȓv<q#8^Q}WWMvԩFlu[@3Kb21zBVSR7@ZyLJzfOj/5y}kTudu(:ц 5?u3>Dlv f#J ,GJ<]y<+S <Es_?$?]_\>/;-MȔa2.GםT_4k HEu(k  $l"EoNi˥fB HBHeĄ K( s]("ڙ3s}g/<Us{獇SEǙsm,lKW ob!+K_;ml8FP64X6= KHfl
+mfM
+\j"dt*17aVer (:oA#ތ'K-Iov$- іv0^68<Lxr{6r}qm>&/QIM+%YA,nӿglm$8B{1B<Lh Jк4|H=hDSa)2Y@s\c'W2)¥ݤ
+A ᄣ
+ߔ'/H.8E+E5w"ԃXM7f*oΨ+3E#>^b(8򪀼]8?3D~ݯ~:ErVYyd{~엀 cWqG⿑7|&x+*Y9J6[Fхߡt ׃4"ۑQ݈8CUuTiQЕX;6pG b'v̿9gbC
+Zvrgd1f.f>f}[mNhď+I $ջ +>i%WmN|gK3p .q/DO+MS1umKb{R9k̜DLqҜ8uVt4u%~$ ߅9-؛=Q=W9
+dշ`B0C)qN_,8 qN+D]*VSWc2l$(>8 Tg
+io e" 'W{ W(б
+_и )VK1܄A Zp&Ofp`{5s=S ^L-tXD- Ah4
+
+"vxI4ӌ40q;D Ѻ=[/zCT<4{>VTV:෍Bh ١Zѫ沫|ߣ}׭)z8P-I'u.qѐ4 l6~h+]M6Ưqtp+l}
+S9U0j,i
+RԈ3'*HQm>aCWEjo7/Qx k/ׇsP~@]'tʳNk}vUeӔGr/<pK7ν3L}Ut(f8r4r͒*NROp=?)NHRDtE6r*tHSƝùFy`9 Nj%_LWSg׽4t8T
+aNR!JZaTnh8c>;G2#`!_
+~>aC2f/z 9R~Զ
+?*BETceϜ_ P*W ?#
+]Oyvhz6OC | Q =̓ErFa+:XMߛf9?R
+\{XQM4h2iMZ9ĩ1sه&)k.d\ o8L_%:ď`y<s`cH1"y4l4vw2Go!q0tk,퓙t@CpıxRr%0 @)S`YGڞ?TD9<ng8~=JǐhA򌀆HzL;2[e>[ui]4+,EEdB } IH$,! ;nU\jxZkk38UdKI @,,"DH
+TQ sy/νy0$a-[G'6Kv|B:410r|r%"z5phxc.y{[ƛ}N وm:B%C9 Z(WCrjsAPǕ>Vεܣȭsor
+AQFo<-8(LlLUc5ݡI
+v$uKE0|%'<OSI֊BH:><UiLM<_Y`e(C(Pk4t窫`t5EW4 EWPLE]XAUMdEoxRêq8eD1m$U' P
+)VlC׈nB3 r h-4O_ e:X3GvЇP޶8ޕKq?_H8vD;?`m:,.[r#
+ dNvOֻ3M5~j߂A]s\Su@1rw,!6L }HDbEb ,d߽(YJtXD  _Qg9(siuneN:p uyz{ wKҢK9u^,4/p\:ENŶ/S:q$k0I]N9+~mcxB셟0EjL7 H&@f/27䘸~# ^`x}PD]
+9 .
+ A47Gȅ~1r!SbR{8)} 8Ȥ~/
+l$ BϡALoKrcB)Òmub`=?
+Bj
+g4?lgJ׽1O@F{N2"fTՒqby{ ȻOX'cЇ[!nKpOkq3 KSEoi狦ٮ5eo'fDאn );׶j/Ƴdl$']硫QS!~f0@!vo3\ފtᒸINKc'.Ig3RdӥRoHН_jr7㍹4xp\`mF;~Th5 wOW9V@uQ;1ђO d 4 ݳ(Yc`B
+ az00!oFD[dE#$o{Fʼ"xE <^G}.*I
+gʷwUa?xETd9NKQC>afM醓b8UAvO-`|`i\ؚ4Uw)fi|.Vz& Rf\_5f?EOڧh.<wIQ&(*>zmk]]yI*LuM+{QuPj1 e:QBďǽ9Ǽo8@0zw+ȸ3Ҿ;2CŽel#䞽
+a^nBABzYŽYSZ/U/OŮ-ܣԕJ˄7%'sԩ|ot X{TsTeCSiX(9 !iS 2(s̞6q}!ag!5.v *
+q?<,Ƞ*(N8r@@ !!1!*5㮺8 xB9BH:
+u:9' ;.
+J@*$e{bu緷|u߫ו`v?~̵LO4S<<91 T>^֕:$jn * ^̂򑙆k|,u1"@ &6 smY<x m 㘁K
+
+ӼKOxD`oB=fP;Lp3"X
+ ŧ#PȟEhn& :"~x&S4r%no^#q;Pw0 [yv8J mm' sDm{1=ToIh@XN[i*&FF_ `Aˀa4 0E, X)[|
+vM=58JDhT$-ʒ^%HJ0e8`9.i3u+ud!>Ő
+MUbd%,!U<Q]O~ɐ J=C'pLbSu$U{ਊAS-'R1d7Q[.ۮP)
+P
+Ua8z$S%Diqn r`KtED +O|X䖪}4K w]E_LMєXPKT8-{pXYn'<r*՛_mh\M Dw5X2+^n\+h;ķbu; xЅlg@5s}oQ 16xyQkvUeêW1gj艂򠳝ڧn%~8h#=KϿp__C].lhA֎2X
+3SYPd%בhGB]`Y b
+SɆ`
+& b UӕU)oLOl:sNp,C3,P,ySYu,Pu49χT<?ڗelEE@2Tu~&X i?RfG5#AHnF pP%O #?}1 QNcVqݸ. ^+fʨK{d-dx3H?ٷmyaooī>56˨m3oGF⏸3K ?i-q;C$qs?ЖR ac;2:4en9J=2YZ Qv)Kv4Pœpɘ-s|PMqKDsHuib#m##Ii]‹{6nw[XcfМoh\'ie^Á(q"j!K͇pKK#E>9YƼD d
+ e0}$%Y]R9}"ױ4~YՏnh.C.~|pA~q~gn#O=#/f)7)A`Nt͕9n]uOJܕbcmO,q˩ﯦˎRESCf*;} w=Lm7O] :;Sйώ̙wK| s>[ aΰids &+`j2ߌr_Ts҃9W㙢HzvxaCkmSs9ېʋ/N.F!yW>xI׾@)F S$xJC=R_G mȉOto C_-4׿7j `
+':č 9qV1P1@qC`Mj/2ER n!%!b>@k LHA)Y. o'Sx=TL,)v$)T0J) JpH {ݙYk<RMfVS?|3̓{ZYMv%w][E[[&f;\!75.]$HH$D@D~k"^DH
+$[C_:| ߅&˧IxJk.QDD"}BӈFA</BOHhFǴcM` x081顇U3+CeŝZ؏|6`dijbqk
+PT2j0Zee a !@&5j:g , a [@ KQ$/$ 2FTP27߹{/_vǣPZ`Ȫ $b% "Qy`XEphehp &oMs19HUsI8#RLlU"OU^8^(T^;)洙+)5h7Lm e(#?qKNju׷?vž!6-Ctk
+3?JzʿT{oK7>Ϻu#L%Ձ Km Mzq 1k ;&č<$<Np.$? !VNQЬkt-@ ˉ>U ch9`[ qakj_o--Ԁ+x;~3}2 n?t.+)GȌ 5&K; {cp@=7p*4WX-Ø6%,lu#<wI`X@eoKuh8UE:l@u|<h.y{p5 5 ɭc _]=˫y\j/\9H3hJ6?пgX;ĩ;WV AՀE\tX/ 4A~i_*Ԏ"CM$7] h '=v@H7GF׷<̂dя$iI&b1k@I$:"WC ,C(ʔ,oAy1d K+}P#<r
+ICD~阦m?:v4JҶ::R^t;$.O[NY&18>]Ɛa;ijyV:b6QvnSt[,%`|SK+V~赾]+=Qo_EMx3h[܃[YZ/#۰׏^ #_>9`qC_L@O ܟ~(y}BiҜ]DmS{ i.y|f7D=EтȘLV&{a1KfY.ZᡈBLj׃ָB?-9xϙ)zIIk|:oɇy2:KщJ&D&Le9_DKQ~ɻDQW~zqGدSa7Eo%4w|X'U΂ѕw]oPwi*Gl/㏊뷶殓?釹&nOA'#Rfp8 \y%PVsD
+
+hߘ񿂾UIqYۨc*$HȞ9j+M]眭O0=r,a`!z/CS#]T 52t#k9c@x:RO&vr7mQiW
+Q$%g,fEZP[nQIo?KDrW31 @fKSFR9k#W^~60\әll}2Z3xrJT<zVX `pGQѵ'C7Fwÿi.`)3(P_7b*CH#/{c@p]0}R8mS8x@գh' !:qxÑ]na"0 Xä(P;SR`( 4jPPM3]Aig WKLLMWQDAl4AD`.MfnvnٛLk " P7K$b1=|~ͯ>h6wS;ITVt)p|)PE4"L=|3m.pɛ+NÏ{i0[8ued|cu8Y-$' h@.
+XlG7Jc
+,k[
+tr8,K0$)&!:)kĴJI62I,mD :8"2*{3#Jr9ogp=ځ
+SkLk1ݏh٠??0-㨈!yCǤb2z
+##8
+<2W^a0졖&0KUUsJGGq[+CFFK9%w{˱yq w|/AȺz}.ɚ!w[;AQM-_`'!v[==@8ۮ=̉U(DA{6sb`)B2X۾D*"l[FDCcsΝ9S<+@ЗDKIgR_ڧ
+O_ʑ ><eR~<Xx֖@`k+T H2VN<ug(PeH (]-s;i۬Ѓ6'Ht
+Vy2m
+G0'6{ "y,q4
+\i+|R+{,eFL$ iE LCmKrU̗,aej8C3g9'R64^H4\7;ǭ9m#dPUQ]gM6BWB;r+f)n»NREBf<85?'^&/2:cdIkRg{y6ص6ص1PNwKU*ط
+laEv8o;/Fi{z AX՘vט4Z\\@Mek
+$He@E|'xgsΝ3"VXr3`8jFZ{,̂~o5%5I
+#^CU>pR_;
+݃Cpp\a0X
+Z\ ?(
+= @GkklmfB`C lz$v2D؂%E.CEb¡[~FI|!Fx!WP1&N%wbS3 ៨Zx׋4.
+lv'kR(CRh ͇Ie %Ic>Ӈ
+{bH ucmLYd.7ԫjh}@\H72bNݼۅL7{d?1sIT=3ӷw]NOQ|;
+-##0TG5EʄMA
+XdCDWXO+ 
+dqw$*Xj;x,ˎn e[ST1DE,YV_1?;j4R 2zK|KEJ#9;?u,4.z_>h,
+X<MBc{P,VMY[Bu᷵/-ZQ3ni%g'r2& A,rIo`2@l@δ4X e* 8+(AC=ڐVf i]$Ӊ<$qA:j:;
+ZT\FteGfXt{c0@M.6DXBE[@PP+"etbD>\J55#ڈd[:j@-$ko ٤%ú(E "*Rc)G
+P r/Cԛ9׶'uVϼ D>E!/
+@!Ec 4
+4G'MS& Ie }Z
+`z7(cYha_PUhڸz/uBOPG= fٮYJQG̗"\ 9n.ֳ_~3t*ЩoۨL_p)| wzog<`u8<T4G9s%Kg=N?>ufoK
+]b)+s7WDXD\x<蓦 q'{KU\&6o2<wz聡kE+
+JEks~Og"(.asmuno^0 a2t@CmnIOkmr ihdK
+'gg)5'I9+;øT}R%B:I|,q,|,&2 }\΂]|K&cgxSDL qB}-7= 98A_^UhƏ?nkcr3ZjQSH"Qfԩt}"(
+K P R"T
+cʰG? a5|:./2тxe!)kPn &'b-=\on[~rͲ:"޹mn*lWXWxg=O[o{rxw?'oVW;7Ivվ o|IqV V3^Z;WK4\WKGc2>n,6n˚{ez
+fO"U/K=ẽJ89uvAY! I
+ddZl_lK-'/]^SE `{՛x_Z}L.ȋB=@?v~&?m?Gh*XKD8㛪jRN\t!_|_ؾvl(= QN Ğz~ q,4Wȝɳ,3grʠ^7}\;d<
+sCo#GĊc2>%.<M#q+zVqh y)"Sꓚ
+XG$2Uu5 @" **
+\14?EYObet!.nHB"dԊAp >R
+4 3o]4lQ;D#޷}Nic.I;k
+B**Ơ 27)eznɛl $QCW[ݰ_aNk;[i )
+F6*Fbtń?=Ȟ88 sБ
+P)ځhRYHؖ_w*,ȈQ8`#1OSI*Qߡ~rYq[E%)!G- ]4T(! ,\a `.4"
+ yb St j"k Sd{&βÒDsqcp/vfz=Ǻ݀d9GlŹCk(XoZJ.݇hcX% .GZOv{Mݥܢxޑ=kw]:۰'crS³OCr&# e^boُ?/z] Uݩe>{'wGRT6&w92s4>gRDD?Vd9½@Yx) 5</NÔʶ]e/]m6yc5\\-Cܑ*Lp
+:1q cs9f췽3;Wu'nn-7 ' aN iCƈ_ilzOPXG{ޫw3rJJG¨L`x `UFVk юDž(PV⊄7{=@KMhx~u˴F2x7C:oދ)"@#2{DK5apU{Y&&w gbFF bJc.G~@*(o${iSޞ S_^l.2t}S?ϙ?ruص>BׯJKSyU)[[w<BeL#DbskxL 6Hi](ҐeGFŞls[< 갤 K=S94SL
+70$o{
+57E{6W9_vSհӚ[ȣ,04O0C* 9r5\:.QGUȘdy1ݦMUm˘IYFx-jROɼͮZ]Ú+^5<Ϗ?rJqqrn"xzyruv` t)܄
+GDǀ1K<â3ةZNXDSwɀ
+Wԙj';}U!iUO7cXHFċ%|#pB9 #Rc
+r
+PI"-( !)H5)B.$ $"OD%5
+R
+f!v_f2WIN1(jY,U#V*y'2\݃ʐ}\) :_៫zpl+$^׹|6öˉ6_uwURʱ[[ALUY%2i✃KVo l_A,z (U6ˀ +_!+/z)
+,{g6aM=r@%{GB';#Lup܄uK써*X>Ҁ5ףj'.?\D\I
+mqfT;A`b-
+"JʱtxfI
+{Bd! g\g7s,mۢsm
+n]]0/ZK R mIF_0=|<Ow?#O@0cNɜG0aF0mYB[V_W\J?*ݪܗYkI̾~_D_T/%pʢ2&eM06H{
+
+W=Hm8+~};޸_ ay(dO3`Ok/fij I*th~&}na0o7tW])/Gvكn$S̗" LJb&4OKь:^~53
+O6JR4҈)5nx>-1kG_Ȇ`KSiۺܴFzlUm[7}m =_1
+%
+9
+)
+ȝ~[;1ެGO2T,.TQ*B0Z4_W㟫ks4ոMPsNyܾovbs% Γ٢,p=;F Jubݴ{-=w>1Ӿ9,-}?,mvߙL6loA~a QW^΍ KusJ[o}=m wU!̈  {8:4N0}18_U{7Wǿ,?Z(
+F8F!if:d6fwѓ3RҔMTE%j#S3i]Ffixyc{p /RHdȫf8O0ChLZCg14+GDBH1IwGdk&pDJZhehc|y 5KQOR֒yB*$y5e/9xD q#ag~2A")hԅQ)*A^T wK %Rr4l}Bh b`?K/ Ћ2tPxF}#Py-8IchPYFSƤ`
+j+[C
+a&@MAdARR$f2,Xk5 P/0(kAHVR:̀CQZ4R Rb[^$gMuf^T3OΗ
+RGIk#[Cv;66CG(Ί LGꉽÛV#v>Dl=赥V6%@2w@Ӎs?sӁ)cmv2H]XR{Zc%qEO~R+{p«V$3Mni byy@ <8 e` k=q2{z}Z'(NLS[@%Ꜵq U3kۓa:0z}ޏ'$(s7k>r$8~cPlglߑ^TK` =q <}^1]#iNY>kFt;0̇0p0Uy'}ӓÓmlC%Q)S:|3#./A 5f7x moѨE@K@?mz8ET?l
+J5<mlh*@TAZ kETVkVNna>o>:2U7W^+_jP+ȧՠAo
+%vbϝgkO+EwpKJWLW
+?ΒccB{q3l\AMy'"U@Yr!' $\I[P(Za֝uignwjQPDB@BnB޼!*]ȱO:7>3;yτ4?s\?>G,QḠ.<űj*KQW(x6P.
+)x{#8-Lnr:[7Dt`LD_w S(9FⅾO#J"s$`κUl -@;Q'w"_Mm_~/;=۽oCGw<>DJ :}Rjrqf~BE`&v ~.M`vp=ӑt2.4@|@̜ n&=
+-L*<T|+h7'$;QOSjVMkUt&|>x̧*RؚVFFHk(NϒwdrL^ : &'7tt"(iIJc^ׁqO-^R
+W0i"_&bpyἇ)-z'MX\tB,A6`w݂jk̀k=7@_ <yLug0^oB3k3GġeWzio Ns!5R{{RdC8`mO/-\V$.fK2
+Lq*ֵNښM66p(;zh$l݄4@<PBHaU//"y8,]yrfTӰ=v}wo#hQֹzӶw[0vO(ÙC7e/y7+yuuyg{+RJ7O Vo wb -/pG3.ޅg{@J"-CqHBc#eK_>sM?b 霹PUlx%@i'hp%)4YwMT#Q@<MrVDP9\uU2x#4ǧ S;Qli#m*\nxvǡ!r:bNbC;\ nv7dGX @R5d T: {getU渂>(9嬊9 @H\Xdb8.lAjLԁK@ZL' zL\ɃP4
+a)6j͆/ N)1)rvN582.X6ELHaưIXƄ,?1
+ 5>$u' iCxSuiq茩{siUhڴ2m$
+** ,
+sN;{߹{ܿbDhߢo ;s cI\zӗd޴eȇLNz_A.v†1cSeZ [Hz-s+"X~9?sՓ,f.x@>9F?|/g^蟽앹~
+] gKn"8pi+B}e{ ؀ˋI{+f#OK3fZُ$A(v?"'âMć 7 H]
+C`?6k"@njM 9!\?g&7TEQ5 7܉<f^2v%2HElHlrk#7Q%-4EBsL@wMa 2'#sH5&a9F~$g !* w$PAx}X&`*x?t/LO^ -6^<g)ѫˈ3#?#O<9\GyX8>q3dFTz_:q2骀bBKmL1ოRqL>}r TifSm"ZF}̓x6T(mxH t
+zp`sza9B\U]=x\(#Mfݓ&z$N252} < MFQŀo O 7lVU\ٽ*N]K,W*<:G ѼztnOPwmUڛ"-$.S针><0I7 z so[wnjml;v]oSv &YKr^?*_Q:{7b֏8^"w%֭Aбqzv{Bݪ_>,W.F|PG5
+|ㆆ$Y[q=PΛk YYz^
+)m.VWhOjSrQ,z"Xʐ藢XB}mpPΌW:}%7Oej8a,|0Xf%NvJJf7
+s"){ T}]lPc]'Ki8]շ_yU!g+w%x.&C7;ic[ll~NA>0}@ynS@jt_ߟ땿|
+[w j c밽al*pl{8\=ەHaٰj57^UcJ|xNrF_?"oD540Ƅ;o6L`
+6L -0ß]h-A GzB.o
+##G3F$)J2ۨ!řtQ~\`C
+1G[\1q7قaO+pYMVm@¯:#/z\^}]D@&Q{^4Nk-U=5+BڐCɟ$9/9Ou~tovm6:'`>WcWni YOlC@CyAJwA]RxVeЊ=ub
+;mI>oOXT9 Lq@q
+́+!OƯ_)?1O,WmEհ"uES嬩4򜱄R 0 ?c) ?g hq b೏+|g+-~%b~#nӋ1>xt·h{?}1~7Gxc_X1(tn n78b՞j2XMiS$q̀@LH%TDt_{ 7\Nq=/cCJ?6}pr2QA8~_{4CLf{r%Zm\i92Vk;Zvq6ԮM_V<\
+|I1]Uu;Q7yط7oLVHx|YvGuׅۛoCGT Pkr"M^HZ/AP@je2W%@
+@tQ&EmI1=MJ4RB$g49 `
+sLfQl8w_p*$Ğ >r@~tfur.n
+=%D XM64֡:m-]iCFkӑϰsz~;
+/oFB~{1#L֢Ƅ(MW0?T6f2_@a?>]$0AIRi_&BJ_9E'3{*(
+)s_u O~.>HT%SA@Дa2FrDy]mEy.UV˕Ւe<bqÕHeo\lULnaA-x%kjɚJ\ K3Q2ږy rTzɂq9|y=\!H9>zKʱP ĪxU=5B}Zy&[
+ {Ll2|ӞۚH@[]n3NiiYо `
+L3σ%.u N%@+kp<ı8y>,~ޙ p[l87
+t/ WwQQ L7*]P#nA/_gU:,W`zjOŊ j&E79R=rȏ7dq"d{VP)4 $  , ]vnvv=,+w(B/! -T =X+%!H7z3yyg|>)agJ*dɤ^6}tI $BJ$ibi
+JtE'&2]Τִ̞6wUs&ămW-)b~?R/]oWT#nO[Z?Vo>>`IIfܺC:Y ZId@ݾl7zߣ~/m*xҎOW> u{4Ǝ'sfv<x|wy7#+ !:G @b ߟL&IH$OťĘ4ҧQHŤF)Knd\xSƢUCt((a-|I%7PՒ N-j6ǿU~>{Tܘt3 jW3w6&}7ym]"7V:TnvQ2a|Ҁ>G݁g6$ЄTV(-
+)(U$3sP];P/&CccF6O+D{-dyrsJw sZW>f2t{?PG*bkb[0\ok19[} :G54aZ!1]=FaY5'}8O d|dZ摠yLuMEQ.}a=>U"*P}hM}ydz ҾŀsELvM-{=m;_o\jrV>nD*E
+1S:ɶ 9O1[|ٯyȋϹ-[sO -I΁@S@R_ hZ険<$S(UK"A8& ˴w˷WV:5^ >>SX/[2;1@윷kX߅HÛh:aYܻ;1 \m{8S2__p^$Nl B-H7}OlfŠsGq|-+kƜ@f<<'g/|ܖ=\v]1.#
+?BKۢ̉챛lŖ㦫#@o1>cbBƁY`zQlSibH]g5órUB׷+@J8ЇYslrlࣖ:pfdzd
+GjX.*Z}Z׃ٖx v\C%\+1]5]|m~OXyX D6o96ԉ:l1lBh#z0,%(EZeڅ0%7z;?he[[",}Qd`QŐ$l),yl:} Aw(a
+S{ȼ
+
+HnR59pVGZ)s|8smo/ {ԇ:-Hvf)}B
+&Xt(>"
+iٛ8f>3jjaп}(S<R_<TZ<XqQxԷHt*`U!V"4!5"27 @f|!<gKk H=iD2a!`;
+d$,AF`iU~
+!L*`Q! !)j?"d-`̜pƻQ;wo_I],04
+N2 /WJI:A:>r9G¡OĜQd.HEeAXxf-]I
+Wܪv+]'T}&6i2Qv&ͦje63? ' jib#q&OΉG@-"_`~Xw"0\Chѥ⚴
+[v;tg|wE/k\)'
+³3;
+}
+ydvD@eH33Pwu~
+0U5Vd
+Q֢qcEyCd!"7eGx{G/Y5K^o;S<Ҥ֖`{lK|1vW x=-D|{י'?m7!ê@u'=6'ulWRbɲ!|WEN=}KZn ÖN@r\߹8moLyf.5&$jtizkϺS+ eOZ;ry"vU=ɭћ )@kE ZSƣ:hNE=k(εhw)ĞVi:aifstXs>m_ WUgGj7etvEa r'ȕ@_K{fGqigS*^(
+&`T / eEݺ3u|~oޛw|2f]F A͇ L.q3_cIǦ.
+jW aI5k<[IX+תIϵhêV}4tVoҰ g  GCKH9N<jR7Қqp^
+|ъb<]E[8`
+ /+m{m2[v'E2ցlQ9Qv)(6 ȥ$>lT⾋/wָ|؃k$ZnP-
+L
+-+"B,z4p~`^/b̟LcSYor^B+֗^QB Jlf4`nQ,"%Y
+n+U7uf|6I(z~1ρq3WsV-Y"f@Lk:$oL`-{8{"XmzKڐ>&n'TzZ&~%Qǹ`ߢq_\L<6]
+؀fLlYN -@c\)V8"
+
+
+~R\W[vbX&;=NrR<{wy.都4QĊDR
+"F7ͣƎ_ujbi_O'LfS.v<ix@VauX?ϐYծlp;$vg`GM赿ƫQ9|@*C.orPZ450~n3CHT-+$Bwd,A8x'ob""7&<.4
+ttDqwP#T<Dl|"sW,\<( ٘6&A}L\|4|
+w^y{N}x@?oQRs `p,]."@;|:Pvw5S݃d_YAҔ{܁;`H~o!2RWU8:qzDh_'V
+ h}}}<zPbX@Rrp#c2 V_%0 vNw@/? %HŌ!s? W!e$<{o˿yaS v>>K[vPD((\e')içi Ɇ6kߎ?/|Bf'?zn՝#dJHE<{M
+obuu vK8H86
+v!IGb(BJ#3 y@s fLևeZQ-u,8\h,b`
+a%isj22f3t?nÜѫVjR'k5q o3i& mi=M1G~6)3V%T2\~CPgd;cR' 3 ~ [3kO$ޜv?t`e XO*G0[:eLc&S%ڭ"&p4CVxYnhtX|*
+ąȺ6emFϠٮؿ-ZK:ͬ
+aNbFZ\ZG;/̬%Z7Yg-Pl=0F׵<\-.8|T_ _8AA+0dj^Wojn>z2kw2{So<NXpwsYJ\UKcO͒I6K!$.r߃?m=}4@=,!; 2=(ٚNB =–bs뉱Aۿ~+^iG!J{G%@QF4^=
+.kUn[9zT3_c)r:Z( -CE`=೎,k{x[d \$
+K5U ^\HQ2R^ZINVM[o 60e10xvfgpi[67oO޴]xXyDk.J׋FK1 IŃzN17%ZC^$ &!n7?F9 p:n"vXGH A6Gp݁@(`
+!ƣ72kH8B$@8"GI}r-XWvקnbe
+rr$@NpD(*dc癙7d9 i@JϾ^+>lZVD5eP<߅ :Dx&u[أWB]_ `P</Zl㟃ߕ$O\8qB'B!"h;ω]pOyZה*oCѪ
+4
+CH bĵ8`
+EL`Lq=>&PfXX27^>:k+\h2×<:-I tdF7,m'440iuj)T64':{ *j9 CNɽf;ݢfns~ :'ߥIGץiG'C.nZepPGfr*em=۳l/ߌKHLW 12Z6+32BskȃW1ةN8N6,-&IΆg [2砜Ij25ʐL;蔺&4[UzGGd re~m:kFK ;=2Ct'̼(=ŻKK
+3?y=|XF@{;M̍
+{<D q֥WˬS~q82z+De|)NjtI2!xE
+c4,Jͦлi}&E!!ςKH!\BL73 w 'Bq Yp11
+Jr BH/MSP;1 O:g'Ԯ$C4<a}78`TH0ՠ'G,6:vmv:dǚZAkVfGVt-Z 1s6կA77m ygk'k]j_m͉е^vd?Je꣠7A~{?)?fR\a ~g珌gkuMzYS@}+{%Oٯ)
+ZsN]e~@O- V-,xK[ M.135nUf@jTxZ49(}A$Xhv;]w0n
+h}$0
+i@ %J>cgvuvuYPiAj@HMH%#E@`yλw;{*g >BAַN޴;}>M]Pkݤ澻eMk
+#\"itms`^mN h4`EH1yS0nMnйJ-xG-|Xh^Umqը0޺%?E~.^E ˜N,A%!AXrLT?Z\2[Va,WxZ妯hk5jrW/2 \Z`Ƚ9.k
+כ%JN7KY( ,Dws×̯M^2z0tYZP()^6\&
+c83Tj,T!"%VQ\DYc'?Rzr3N+r->n F3[9w"S# >vGwۀ _{];hjoХ7 ?/([_O-vcw2t<l6a_lߥ۷z[okInG7U-6'U6]ଉ(Ѧq-Of*i8ϒ}ᱹKm%=KV! ^j/0zj3ULpms|Ingg6G{ӈM7u&g5&O*͘5f3ua|I
++LM2ϯdxme,զe0@wgn>/W.2*N=(i)) lC4`jǠSp3[AT b<uq式0>mU-('Z˾=xy.ӴHl
+{=L9g>`Q1tх)"lbKe*Q?&MasBr{\v6m{LWm eQl,Pldр̣ňpI&LR%l,CZ V"
+%bi,TɓtH_uY7lL<'͂JVtPA.})/
+Xr0F)klYՖr4-F K1|`Mx\CPS fg#Y $E8oq[µ#Kڐx
+? ;g?E(-6e QكpR
+naMR>[r
+><,,Y2T2.~*bmɘ4?p1  63#.s'_SfAg vsT)5mNv\7D3)$ I8GှAc5VA GMgg4>1Q{4hhp<N~&=%W9-I]Sty
+B|_2,czȈY!`1=<hct B__LoUӉꖀt]O/pTM=x!; ~(ܡfbx8y )kUř\}ҬbTh̚,5sxFWˈnoTJJҴҵMYj| #+?f3 7
+ B2NqGۺ:zl縫H!!BI(f)R?~;`$ƮͰˍ~B>&li>>Ď:Ϸ#.7Y
+ML_?B,};+sSLuOH;k827du!,iOS@"nC(oy |HL-Inځ>Z7T0XO:X_YT#⇸~Q`Z[҅1RSxi҇!zqq~ȋO=G|-C}EsJU/k؛5OQ>>)VsQz;zQi|wK|#M7k}SrSB/҄V?nd?0
+ "#AhHX}>"Du80(I~ ez~uJA{`Ԧ2|Jk>X눴~ΡBbcǵ/2ƲоpK,tNr/ۄlGlSG|vHL#~t2RWr^m[M :B5j(\:Ѥ#:cѥmL4hVzXU[,r
+ےr{?>6 =ջB>w[Vv{RomoZ駕rt9ן:\'O unQ,NYCxH#<Ա,(WC & :1'-9{W]&?|ՕA(mdWst`%" zS7
+uׄv#)- QHZ3(gsLTT)/)+=>)+92UH2כ=HU>2()c@ggJe5AL' f~^
+k
+ϒ$Y&/u</K MU"&tvK+<N) ]3 亰^@Uݵw4aF9')DѩRyAibdSQwTQ䗦xu(MP" - tCޫq[nd^^gyt6^Ε/>ABʽȬ(MC֜{#صK6F`f[&[kx6ޱalbe6g$NUq?}9&ća+g9\yd4[I.U1a٣?OrAKOzǢ.x(N0C&or|޳7r)}* A:͉yHoǵWdcÚ
+$!$$"2$Pisq2=%B HHB}z:/^<'d|_der,TΤ{i E75MCMQ%'DIj0D^o9a &ViK# ٢G22$эH8ӝa3Plwpڴ<8nJLFFa5Xd1ZLu*`k|85FI,ݤQ48 (-q:Bf_;7.oMhKL-<t1a 2|'g,&45ZkOQgFoF2z U
+
+d\U]IGy
+,u‘z1K#Z`mDlX ,5<
+b?b7yP{yI/;
+)>>OچQxSCMb`[]_QzӁVe^[XQQz?U<ULYS{񡬪})Uֵ6^ OҺ‹G|Km!0dMhx-L8Q?ƟhNC3;s @9̙PDEx'i;հ[쪋w5E7GLԆ
+G(J%>#9̞1@K PLwc'4m^
+ $h ~o#ŭOZPP畁s ,¼6(x``6 a|ޥ)ڂ?uK@LsP<4
+s:/C}5=ˡk?ϙo>lnUk5p jGp$3ΘH
+e;o#-^5_Ŝ4"2[Ee%ƿRp1FwZNLfOC*\BҴ25$}<[/#r@]ɌnNHKjux
+}5?3, Cۃ ( (HB
+ @bj(zfv= E1!(#"U@a2;?={}ñCWG3K/kU[_c~7pczIċÝ>A7@_pF Jd<u
+8y53 M8#xxҿ}Jujp'؀f}@ՏE?XO |PwH#1nCe'kS$Ĕzȝ3{ử'^eB>P9=!mՀ-D_1263 n,Y1-M萪ajlc&b+ԏÉM=~yTVsX-+dJ08U;SUOV!S%" yq.пyvƟ ]wP~yʴ-VNwSpUp
+D
+\2Ƌ)ceRD1髋*@"D.,KjE[
+7-IMȾwKs&.E
+]mH-#K=![̑ע1]I΄ Gչ>+ Ks.s^6:X\urx92rөa3RwЙ4=pDg_R|Իjˆ"Rk[B_ΔHp!^N=ㆤIAEDK%8Fྼఛhoay'ZȒ*;1!wggN8̎*Dz]<RWBWk mP)ӥ4~_d6b#=Ǚ?J!A
+7jLk+xh? ,* @&H=c1gm}J g < k`y{W"CULdwƦd;(R*CDX\OuӆB҇@e0HP
+8ݨsVԥrCed1PC9UhAG$SE(F?31( !M,ͤJeqaElI(TIt#OާljUD JگL, ժ F*&ѭ FsHpB
+ P;2w.TN_APQ}P~a>
+p)>ߊio.]3kەe7BZ9P+q@MȶO0ƊB]0%.M'qGAx>{9y'w"J([BwƆ3}Z'W$5/y c]A]xQE^Ph_!*(aM}Ϗ3;!YKM|GxL,xf)$ϛ}~鋢}s^5翨)+~V8ϟ ˶>1mA,?i53 +
+%T86 "0m^%-NA/6<Q[Zw̆_ո.N״ޘuq:P8q[Fܖ垤5@`.@3:Y ǀ& Hƌ01
+xNtAYsOj#-Uq,Uґژ#m@<|[c 醰隰҉G`
+sCtu`HoJjc~,<`lƖ
+=qn׾7 $oRa 3J;dqs]M_O0L_SÔMk*l~r]jigya˭\w߃ m[칯7
+֙+8ramϳ<?$XW*?A[@SeNKrF5u%
+$y*Y:h;W~Ȼ%s^7$fYϕ(ֳ*K@g1~
+ G|J{BGh{B5D\zp{G4'_osJEs SZFP8|>Goir~4?-\<lP.&۔|d.~F4_eß^RX1+m;>ְ ?' xaq/7پbMʡ^c-7EKP.m8 ybU/h 9vM/_~X;pC1]\Mp~ >.$Η
+:{5V\)'v{ =WR9}rño Еp%)(!|Q
+NSz mԆkl")2w/U+
+cG8xK?tp_#./@)~3B2"E҈wcB=(PoҮA=eË́
+i)P9o! hPSp|wpk
+J$/q뽟{jz-u^Y[X{z|5~ 66h2p*p>d:pccuƇ͌/:ѿмY>tmuc]Y{FzǦw͛C֛B7s~ky%"ecAb.5[.B!3r{θґT5<^
+nFL78J"? Ap &$!EJ\"GOd.qqW@V@ cK{mR&') <,9c19y@9!T x؋@Kge(D_% 9L&O 2{^s~Qs|]M H?؞5)ߑ4tӎ+9J$UfD;K#="zFZP˙ˮp*UҶd*G
+)<%kr"d
+.(, TKHUCY"x\)l jh9*檐
+RbH;"+p)bjR{|G#NRToy
+&H Bh `eQ8XXXAvfyf޼52vhHŐ
+g5rB"CT$$ !o
+M2C~ARLc>4o BaaS(Duvr"RV )$@ڡV.Ǯk}1F,Q&K -mM hI7%r*XBI|pq
+H5bfoѶ}}EAX?n֕?[5'rp47f5۱Mkg嶜z;|Tɺމ;$UDBKCTrk7GD芼vj
+JaAi^GC7+%pu5..G'8vosp8_$Xj‡()3| fd'R}#-p1"ÿWS[eACa-$~O%#RٶWS|ݧ6b.@e>V`:" -@ d: tC.c~` 0pJ5D\MC`A2"t:g0|hznm!K{.+ДSwql^aZ*BӋ
+ڲԜUYĒfI YIm€ Чdάwax!=ܴ;*4Z7̞1밣~谦.ȀHWۭ2 iZkqW4Hﰦ=@eIY$0Bʆ%(bkǪ(PDvB0@
+
+^}s_}s\<k+ qmOb;
+s&zlg5fM.qS\{8ˑ2$(c X.5@z[цT= ?"JG+ zw}Gƛbbx& 3<) (tK:0TB ni㏜usfPsFu1<+0sz
+hzcXNood{'A;)a|}\t <$M%m
+B >j&dn2o iZ[4|p>1d?3
+qoLdDp0u!XӌMv7RDJ2IT!'*$ZLnsyg|oAa2})1b<XH0*l,&J܊4Jp(&H -p23gU4wG] S59<L&ߔs^iݏSʃT;ʃ;B)CRTpZ' ~LS6dWI`K76nܰ m&KmNbO\--w)߆X*wVyȭ-Gl}K ێ8]{T7Q-yRD:q7W %_ .Rg*tlsp*DyUlmGk/aWҨ\yyD~hNieq\PyP+yĵ$/s, kB%0V+vYd]agjS%7=mbebjgoZ3za-'4wO1Cy^վq3qCX$#ߗKT{JB7VdU&"P-NDݐ'Ms+P^8DU)MCB?9Hz$W??rw,vʛxx\~#z nM%>f.ƊuMDhgʨ.'SW̩L{ƹj}[}>a^:aG5/3bxcj!آfaȁ~m=XHpO?\^}1︲,
+EKBcI=ߤ~l=p. ;Iπ Tkal9%d 'F
+GO[צ/q㐏t{XRi3WqԔ
+
+MDVn3M춳sif,gADI ($r4/ie6]K9ss=y'6C`\[5t6e@ӭ ;p^Eg݉hE
+QtE7v㓵 [Gru}2 hSlp
+_?ۓآs9*܁n>`[SfOMMS+ϺS[i9*_` C[jIeW'@AZA J#J#j?nvlfaЃ
+~t6s F3
+ >I!=)cO2G9#pԏ:Eog #Ea,;yGڠ
+ÎXF7Qd,鿈>s;_?h.\ \I9#,
+8vl`qskfk!ڛL_x%^C4ƳTb<GORT2@z]&9Ɨgj5ڼ~.B_2sB=!hPJlw[0
+0b 8Jv=`-l"61!2 |نFCیah=L5A3w2f ў`:`SA-]xJ. N
+^:bq$uI.4"P) m!@4B B/J"Reޜs
+ = _."AD?3oyyV-C^T;'))>R钢:R@@K*a1Kt
+(łR??EԂIJ$%I)eJwpN nv"iwkc j-P= .]p{FޯP')1O!iKW,P cRO9`ʼm9 ݻ^X/=6N!Pt)tXiL|`-iw(fr/ eYRyqE=K{YlY_JU:(\fn5"; }>8xuH.#fÁl>ޠ;usgnt ,gUTCܛBS7]9K2GrG=4l?AUy7.P]9ZEѾwΏFqwn po]+r՞3DvoY<Fy1^$A@_MT QL<6?ܱ2dg-?3Unh΀7YiP{x~(Ewz`MO"kW&m6396e8tXw5::ce3?of`j8렖|t= u9
+9B-dv7.1P{=Jfd,棲̘~C3:8y`;P/!ha_b+4'WT}6
+T[Ns.
+1y̕g˟!3OO`Ǩ,3MOTCeeg5*)/˟e.Ti"Y\~FRI+4ErLV~)I) x"[%LYG*PJנ-ERJָQ5
+N.( dw?J פ7/+~_{\?F
+\=2'$hMCQ ffF[m(Tv sqt똕ڏ1LB֘&u&q<dx2H m&hU]b4j4zd\yecm´ -wz-Xe ʀ\S;9fs1!l!M!f1~c?5[{m {W?c^]?tnPkTd]DS^''Z#;CUm'߀2NkGf0l5XsHM OVRGOOt8jV$*l3T$μ
+G
+p#8
+\@J27ո,]-!SWGhEqzjAN>-k
+5ebHHYHtbdAw =|>O;,sbwpLlnM+Ut P-V
+ uXnm@d{27v!2\tCFgS
+.xvm+:ӝUwΊZr"@HH $ D ttw~>{{>} mh
+5OtmU^͍vb}
+4_P!0*%
+30OVc*y,N݇OvHain((J3A&Hp}${:<HgEP`
+hXs($F7mjd9H8/!̉iqU4/0~UAXފ܈KwlьYA
+ `Uv
+V}FrP)rXY2RU`rQn4H$syP7iL<T;bE1{
+yvHDIDl\]ڿ/ 6< 1~pDLkP > !##2$KG5b3_{~j,Hw?D4}%./+G.7Biᒺ"|/hܔ0a՝i.P=ݪt %<-l3^^9a;
+X
+R6bhr%bJ.@ G'/ MY9] $~8o!]7N|q]!unNp݈sߌw{k^PugPvKهE{E
+~dZ#wpv
+y}ז?eԕpSĂ("I!!d! [X!$,q{<Lgqzutz(X$$4}{d1Qѹqy{w{wq
+?wY[<vݷ[|~YN0_D|?PLwIvai׫K?;γK<>1dR$,TM&@(wUGp՝A]. 9'OO;i{bo" w"zS# ߬I·kI!rU$FaiR{@bFKmۺ#3Vd+q[~^<E}׿/^JX^Z@:8@D`?%r 2N*;#‰ul`4 YoM QF1R 4Q<q/
+A *,^EfzPϖy,Ȑh._mtްlްqlO׏Q=g4_apT˵suXz@=d(+r&qDD~oܔd1㷘}};1aF u>95=c:_hK`6+!|m6ᔦtJ}+pJJH|ſ&"e\.(j&)H9ZaM + >E8/!򍥸-| tfQ=bn0T&@lS5р|S)6Ptsxg|\`
+ȶce9= 9r\gh
+J1 Z4(pɆvW L@nhkv[9 J pQZ ..UчhI%xVMӚH4Dim(Yo 5뱑o"#"}ٖ2L^pa~? g>}<&|<ls0}3{gFfl_z95ީ}AޮX:R'mW#8(։5x;+DG[U?·nMNsPRo;To4v
+-7OYBA a`s 6k!8uÑ@ #L@|s o, 3\1"@fVB\S@}j|=xğo˷^捗fk; [v {Xksf.wr۴a-e`<T.'z؟=Yi"j"HYBFctʻ|C3ь tnQS=LkLU:sN.x{UuFHљ}mM&:):Y&KjoOhiIdK% fHZ;T`xPĘ7Rwnw˨D|w-Ɣ] hܡ66*d$ 4M/*H/oqz?]񐜪h ꉼF
+G-"B ,DB8oa'TKc`Ԍ‪[@Yu)>ZIB 0R`6
+;:?-J ϊJ>坁KM!G\H.Ӡ, C# ,=!D$,a585NS:R(lBHl 77ilDǩխsymޑ3s׊/]ߴ_[/ťrePZ){qF @`C4`B щ .?ids,&(:0?P>O8ߺ(z? e4 yh`fVVO?FN0j/0"i
+
+7vD״<{GU-aWkBx,"8VL笮_ry8IE[&~Ph'ywTGO&P#@x4_n D&/5`!Y-AYLQLETg3QmTCl4G}9>4Y4ILi+.RQCLN+rIȧP'k1jb^ UVݴRdMK:|y}>VR͡vx$k)l6<O;zX'HɦYa]ePԭ5m]%I;z?wJ;KDa#cåyNP*Yq%K &$KjIn)Xuc<jT khg,[r7{޻w/vvuN>5QlϷO#aG'5ET
+.ABd4e !SUL7Xp3
+;:eԦ8=<jiC~%cW^83{gGrV.=Ao}:T]˯׀Ec;7| T{k9N[J+s8Wueʹ`)HUM\ A,29а;b8dt4¾~"܁?d<4<4\'mTFMlDeq<y=\=EVs/8TPsN5mof5#Q }|$8[OcSdU[xNywFKo@M\@cRBT EN\J4xb4ň$@'0Ipٟٚ*d@ݑz|`
+j5)wIД S\L:*NTՑcOqY59A {=A4(GB#ԏ,)*sԺD9yG,
+,x27C
+Ev dE줒.u=y=Hno1$};qq=ۙ>rcn3'ɺB,ᄍϨ~ce0"L 6,$CQ.
+LSþS|M@
+뤑"tC4 o
+hFYPȵ%~!ZY7HclĻ'KSuI:_ЗIۛ,4E` /{BrzI5A1s"s}mToA\#/
+LBХ&3B%}MUSiOS9@'qr;
+r
+Qgg<tz_"9|gs}2
+F&>4IY)ufa7MW~ܛ<J
+\,d ,C > kH2wg__p93RRe A? :FjókC Gg&ԷQR Jic;9&JB
+ p)=,i
+r$6(*#DCu4p 9aȁUQKFLDGB9 â HIDk& ،]1\O2fk%}u_ϙ@i@+V`
+wEӽzO;jxAqS_
+Щyp2PbDj"768F5!) wRxv2qp1X@>%QR9&9E4Fϩ1צvw:*% m%:qE9afbnt:=iqN^V
+|ҭ2Z-6x []l(`2.'<iuI)?IXt{~Xf#g;ҷt[Go~35/3 mc.zK{?A뮃WLO['4H]RɌ[<xlUz%~ޱ=(rSm^yhmI,-ɳSV77MmMJ&ǪjE Ic&@cDrtWh ISr
+j$@*q~*8',ߤ8=. H f
+~f?ӊbE
+L|sU`:(\霾rCe#Uo4;v;Ȏhj7lOm7k>-f|*o5 ;(lS{.|3|C`Y_u?%bLJ:{';;?;y$bTJ t:xt6!.1]Y.eޯƫ#[zOvczh0Iُ!ϗk{I;:ɽln,ZOQqUC&=,/G]͡aT ]MhHg5lVHPj  NAK@H*"D*+(iPU ɨXJ1W캙*(oۋ u$ BNUJbk\c)GwYPOuй}1qv< ,ˊ(-D+S_mq|q4҅{7oJyٿs߽&&E8k&SWŦQ҇R1|1۩/OV)YZ!HDS*Q¬fPIB'5
+Z[C}1=fm$PYQoĐ Ќ;Q|Y4TFGE32|#3?Jg͕QYpE?eDp<p@[.Ar;$D@@\ᆀ
+n;[[SΖ^#r) &@PtS 
+
+:/ǫ~~SӵO`eYT@Or>׆n?K@@aP`15o;_Z}Y~妤5v~Dg%{Rvn]7,<lROn-$ ;-- /uaƍIT;̖:s&P >s1.s-ťHkMȔ#<L1R5,əh
+,8N?j!ym9ElMC+y Oy.&O:]TU8Gle1>WYrI9jW :Ǹ7uq ֌[
+ϑWe^[s"en :*$CUxI.ʊ FdU丑z;U%ΛGMly9!CKr`2l @y^GE7#&OL35%1[̩V$S݆eZp,$L?/o0Gr AWBD`~aJlė2 w
+j2IV\  㝸pU!Bَ:)lÛ=&DOؐ]VL&!,pb-70N'nݾほw숎mXG[]X?u_9jy1ZcZ=c[Ʀ*bٚر6-l4|es,xűs(1&9D
+@4
+O$,#ה-,?9sxwM1“(m:y^C,K%9oѰc[` sx]bCa@]?LhjOIb8)CÇ #sȻu_ޠv6X;r+{uțݎgZC w^[z|eO2æGB,},o IQ=<BF KQYguX cS4<da&%zd5Yc6͕>+HL!AہwЌBu0V(<!'"h
+
+WPa _>Qpȥ_{|sjFx
+w-C+ڙ5 /|ߟ1JyLf<3bo+ *R4\+) E9`rt"&✪i;}X{zȾ-Nk;џbm}dxU)^ u/u[v^v+u9mӴGG2&8,c),] ,] 4GXi: 6HA25LPg.tBI{G t֬UO'w 6kd}-#n6u#cL
+ ݩTŢ*_Y; 3b0.B-CYLRp؛6[,0ȠayTh vUtksfSf
+wA_X\P 8mރ??5/)'6Tgdоirn{Hƅp/=ew =ߡc`=Y구USnExTCie"Y"+g>罦X\
+\I#^~?+15 zX>eesej~%D=߲:O N ]D
+7;8;ls_t<X,cdav,:n@]FV.Um~1 h bԿܵ(wbab^mHgTh~/]ĝN{NS}}1nq$L؉$@}2x8ϟ9ϴ4\4 ӫ\CUP M74!f8( L<( #ŰT44" Kd A4) JLNM3Qf,s\IP$nye^IoH)󢋴fGfO
+{gWIg[m. 2yY\/oB7sik76[
+6;e<WinI~Wqzt+O <
+=`T܁`kuM]3|2^"ڜ̗Wnx%q#eQy'Gˡ%簯C-͑.Hª(s%YsC Acu~c} 2Z
+@P0Ql
+!Tn
+p&f
+}WsGWy[4ꮮuWsa7 Q0`
+V` nyV 3{G#lmKic[@"':wP[z Mq
+Di~|}}}mq5IG0xk_qN|% *UԵa+ڛ.ܹ ڇJY=}í{9â d/FVͥa*nX6(و}o}%bRtrJƒIQ\T8t3$/aq|x,N8N9Q`4ZIN j
+z\5jl k!#D>?WrXV%]8
+ jh`!24,m*[SԽA7J@SV<ޜz
+vM3 3 U9P]# ՠ%6cO\}8wLK\]$/*rdeK\DCp $m$a쉎TY;!U֊R4(ːE`쩪Ly 2M&(k 6??9a.v
+m)QGV_F̉AH yD2NLQŦ(F",dsg/d+ 2f>~Ӛw{]bQ[CN@m÷qmnegloVVAt-(B)r$m`;^w%,6Zf[ڼXsMt`}e GS查,L?3&;aה e3d{Eƨ1EG&-]}#peV~1DNgƈ}_.T]C U|ųcG 0'i}X͞)+-.V&U6{@:Xd(~
+/ԕ8UBCy`&iħHZOh~(I%D=Xe,wXSYWg-(""kMM#! Ђ!XgtƲά:3 EP D !DR2
+"]?~ww:<;mZH
+(
+XJ%dDB:Th,F4e3jيW
+^{vvN+oMP]Q!M(6=-
+'+[Vk 5VSW&hB]@JoUWSko Ehx~jےZ9fu0G/7_6@6/Vj"}Q>/ty02V5t۟ \c!,WSܭCivi nYM
+c bރgA:\7\Kݗ|bѻ̵hEƆŔ^2>neOv J/.q!y!JLQWB@Sf*l/Ӷ%^]\u !o%<e*EWW`r\6g(ǰ@`,}j*X
+4U"hpz>6XP `?|M&ZOȒqn2]
+ SvK⍴; ]NA/ȟߤ
+] Dwg@c@@_TS55dc="
+p
+4j] 0j`"Z-$n4n ]gy4ג?#-qBnNd27#NXFnDz"2|iy 2CYc&b?CCbZnci;Ķ b9 U:Jh9W?r<<qdAQVl
+[H]@qZbB,ʙW ZK&HY<)GRz h%)5XS j$B_6JX+3H(AĆ-I`?@
+.+-XΚ!R};lYre0e 6,@W>bJ_? ^ғ]MPB5Wх8H1Y8:!)Hj~(~
+:{쒡*tcfbi&^݄ ksd!c
+7m(4J/<ID؍
+5挑\`<M%Xj@CK>6]x}h" U55q7Λ&@VpPa
+mE^Q^ ,܊8Ĝ`.ʪز#tSjjE<27N?k@0ā@&jaņ0_5^(T KK]eͭ2kW9Ny{UG_4w05uY ]Նup؃^~X:
+X7[UU5@V;ވ+{/okʼnb?ȗ=4݊cڱVȑr혳U *KԷ0%poa,Ss(ʜl̜Ȝ
+a<1L<XI3P'?3mމ \‚ȋZ,`dhpQHY"$ht[k34r <CXWck*Jl!iCtX'.SŧDl^#w#հՐoN\_9Ԭdw ]1{@'z`&|7/H) '6NnrD:>]k.Mba\xN.ONov 3y=m{RW 5Ѥm!!=_G?$bG^O,SKc31mle5666@ p h}p%D 05G{b^KǿI^L}!5ƘAt||fc`@0$8N^'aƐkso8}n'YH;HEv ["-!.8L?%<眼͵K}햾sbaCWɾ=`o{_E6 v}v{{?Pl}oGz>ѧ~$p~){r]SNA^{R6( N
+MU-T|ܵj̙ {=Rܨz<^t`Lwѭ!5Qe뫂/j~UEd)P jf }7BQD\xy%{؍*r% S!-DSuLC+2
+_Ѻvw_ڙ﷢\=%6RCx#;X=99pBɚ&8xtT:Ғh%;Eu<ІMC{bY ?L[]}RhXFR㍰ F^U'Do ,k 4 ݌奔)~\ ո-?=td ؝{s*\ 9= +2s 9)1%-1V?'ORY@tF!KbP80.q|S|6b}zy^{uf1hT$z @lBR mp:0
+=3ϼ<~ߌjNԙl;pjl df83܄}B)vPƃ+.E/vDi[%8Eި5" L<vOӐCznZr)se7c e Ym]TgEl՟`.70>6/2BFV.+qHTŨh U!,ppQi
+$36=l'--G/ /5nj~7᫕q?Xeey3;ׇ
+ѩo<w<$?<o}?<,ueE/pބ82l>ukXi.Sn4Zm͘ҍNOwW_®Js7_?EeJqJ|3e tKVܨqt7l{?\(R6_hzWfƳL 7` =w`Y~I=;.W{%:
+Ցt`>8BtFI eNQ 6{G澣T:U7u=ӈ>K.0s~<0{%s~^jY,Ůa,؆5jgE(`&U  q 7``Ee<,0O! ]C`
+1ENx0f9b$_=\zbX=kW;~n*̆5j˝û=
+S籓v\\,ZhP#1P!$CE2\DcM`lcE`Ci|ӨP-8NKɪRth5<z:|Ch^9vһ?f\zv:w_xr.Et"k^UU ]؞ZrDi.DV$mDAles
+b2/7e9T8ЫWRw>7R
+J\-wO)sTː^幥KGr1|ؾ2L"B50p-bØoa9C2UPGX1CXImt5y @ "i͈K<K04E+U
+]c5.
+t9* Sy؄|\TWx4yFK!O-#O+֐g䛎KSsv?LFlNu;J'O#&+vs66vs0K&z]wCA7hG >QK+0Y>WmձWk==h9l% mf@syPZDză65~: lmu@|sduЪ%b >|6X1X,#T #i?؈hÍv M ߜ 8C]і>:rs1zTջx'H5ҀbLk>Vak#4b CV_4 ;4-{Bqvt l
+ I;<G;xecl h;It_:M"5~ #:H a/rѤk4jDoGK:6 >}kL_RV&e2˼5!}Iprl  y7dqy\@MȀUq8`oD3h8öfL1'mc,бj28UD(--0*Сea
+L@56BV})Dq(E_cJ gAo@h6&I
+6(:8@,0AoyPlgM([,fG4Fq@/Е < S.
+9\1tT#e 8 71$ ,nK@uևFD!Qa<M4f[3 Pyx$.Ju cJ4I0%%$*
+ѶmzFd&c.@mv쯭_כu[bWq[76El[ӭ;?Y·HVό+&zMkAȝs~ Y+8|{ړ}S
+7n)T4%$NB!!c2141
+ؑG"w:Tړ11^\`"ƻۋR%ӊU#cuQ
+q<Y?TTFWCN`Tc*t/ix<|C#
+g&Ad&<Dt';hS5$v%!8/v
+Ҧ%9";J0*[J FU'-؈]S' 2 .,U<KXCCa*3^q¨z8^-Bi7dL6dsBolu^I+cLI™ChNOjYsP5Üy9 JGȟߨrD+ޔMRkoRv,S;:w:vlK[2 ºԖ L&m
+!Vm Ld``-S;,P
+
+gO4ߟ:f91j`
+akC34fe$iTVOeT#R^(Z_쁝:WNv7һ@DdNGEQ4r$dOіhK S2;⍚:\Wz]pK}:\җni BG`IJhGf8q:6J@/Q%34ێS!7uȭ>3ՑîcCPMgX|`Jz<5mڲ ć̉G_zhj*']_L>$ ឣsnݮ$烜B]o<@[#W5]Ձ{ߒ/~2:!9sLjs(> ^U D~9P~G /jʢ ,3%'Pŗ ;PuY JWO:"KՈLy>O rU53*Y@^/T
+eU?A:e6Ut&xE>--Cڹ)=8FM"( DŁ;<(t=OJ5,Ңj9a9b޷ ^If#+'Vyzz+ǥoxw7~H-j.=TS*Qv.6<^̪tb[!?K~
+N51Gg
+xL x!1TBZH5/siSkw3U<tw;rK`J4NJjk`TB4M)X
+@^NUP
+p ڻtE7>0ţ?OߺriC#uBIH)Bۏqۇoݿ~S*[;54Bəo'6DmuȲ&wU$j"&ءPI$01%:"(g7<@z t]d`g, zn`Y4 :94>bPFVtbtD@و ,"V\=o/yZ </}~[8楫ϭ_nC Q8J7,AxHSu}arE]f;y!25%
+ȜmϜiFd̴'EX|FE%I&HTHDҘ:dbE;9e^H̛!!*5GLU@5rP(26
+U.}U-Ke-PՈ/
+eMEx ՑRT4u;>WD8Ղ6%T ]\"]cp57!wNL,ߎ4SxpkWj;wo^:
+e ){9'`d<c*ԇdŨ(QI(*91J) X';)*w6rh.&4(gpFÑ I %"dݙdgjwjvACpHH @ D}
+)vt_U_UUo?O6C@ D GHv?oްíCGo|]O,Gz*tRAzsTu=W?Q;ƂV>UjzҨuɴG֎8 K1ËЁ"w.Xɒ~:p bQdq_/g< FKH^>1BK"za}C~qx( %(">>rp$Q7#wG<P!D*qK_\OjO #++^: s%$IyH#6Y@{Ж
+':>6OksLu{<0q!2<X|IE$U5͸嚫ܚ>W6 C
+Wh;Ye{wɛsU_WVB34
+7]CD:Q5\"hR0 b$v|T@Z2<#/<>S f܃$.΁\| qf@gv߮7n9Xp>_vP'Ao /6v4 x:/f [ƪTCD G3AfMr!)4m9B'}cǁWFR$UZ`0R1 bISS'lEo@di*azPdץ͞ɇTm$]SP]赉;02URMa/&mʔcLqţs'MQ듢ˠle!qUY
+V"ň/(LP̓\ȕ!sdyL>@@E]U
+dbH!,UQMPAF(C ׵/>o0t'?mك>jIlvgLzGv'OyN CBt8N-A+qQ$A= QnUŃūZPI;JQV!PFWdhY: FD`srvRyy;[-%lWmZBd ܌Y ["rx#@%yo˖mi4dqd;álf-8B"$c5 v
+}Dx-8E;Gr=h313ԗsW³>dV7;}}&rÍ%D-{%jk%h4 -aMkkhXBv@՝X]`
+` F)*!@5bv9&r.>k ڡ!b С-76dț6|U]Ě4iPSYEdQ U[-%$!@H 2ե=VLMW*(,aBH@HIؤQhdUUԫ޽=}F׮;"j66 ܞPHoCн&nMj
+3B;pֺ^-NMBq5z'H]"7ڍ1|pc7]S2L]ѿ:z?|LgS^(}'ev}ZOadW
+l%N CEldw<~,а=RQiY[ϐW`*uI SAqLqM
+3[/0Qgay gJ1]^<[VY'/̋L|gYa6
+DRC y{1./ 0׏% [ 55,\\<>XSpMS\̡d[oG|w'CZb;+ZD@X 'mq hű#:]Kjcc{Ml~.&8i'zݴ ;:yqͭZ:sntX?AW_Dk#p4¾SmnCD)|z)6ɍ (P᳎M66PCD)vO,杽1RƎ7<*nbRdR?ZDii"[؀9`@dǗ!
+,_/6!w h׺+Tҗ|_5[v4{d .H>eMl ]m4
+fm!Um~:譂f#l^9\Ue9g ?Gt>1mYbR|b=;z$i%6gry8iRMX.2/&-JY|kxe嵙:1{*y14y|/3MX/OX)į=S_?BOY_2d2YuO{u3|cI^n0½^ [яbM&h\,T9ӝ1v k<C^fPꠑsL؏Y?PyZ~FcĿx=1_`zCreL7CNE]./$5N% #&ޡ ?g^yaxsLCWΤ(Ɋ74y_UNG$)޸&
+\bUXYk4[ȫ}a UKvM~-n9}SzSMad S#XCWDB׋`Uݑu"/ҽB g)6
+@aJ2T "je;x+B_:Dބ ջP
+#q=;g<g?ٝ]ٱ
+HK 7 APET?<t{?_3'H"%-Z/;URwi뢴'CxIQR.i.iPܱr8g0sI&
+@LL7\13Tőӆťl0`k\5Cw<+b+a' %x7?*WL#l" rᗕiBW] KԔ#%DU&AY
+1:q>2J}-<^[
+1l
+i!ZmC6۱ϰf>|5Y wjyJ|#g.N2Ow z:žu>7Z#3V[Aj+"r @Sc@x6Ԁ pmBEiu#&R (TӁk{#yB J]}}|{,{]"#NJkBn
+SS=ϩ@=JޫvfMF=g(A=3E\6\LL.=爫|R Uua. Mу d
+}x>C#"kMɝܩ
+mx:6]߄e=2,m%I.D)K%^y-kL̘hqB͜nǧ1L].)¥PпX)'XA
+ 
+ XB3!uJA;
+x
+оL`ȡl[,m>|3ңSo\<6xym o|>K?IӷAEr+AC6Gm? zclJkQ2 ]g:<[]M1% - 5`rk泖g󿐜c=sBc\KKQt)E+pE8BLTnJ(>QS}p+\9JQOU2 UbI:"#7 O׍8sց P4Ի|TpI5]1=&\SNɋmNŻ~Xmm[J;yl=x5?3$#}Ap[ [Jdkܲ%շ=8^֯HQ㗩FJ֋P8ZR7aB<G<R,/ m򍙕@KJ7+Y.&4GAA91 g  !@ 򘚭Yvk]jwv]u3$p W3; (**x~q_u~_wsɑ=!=
+
+L\MK7"}!.o\R/i P׀FR
+4"@- RrJB [CQ_*.o]mꊌ25WܱO=p\77nFmd-wxkZIM__,@0X:XeX֦@ 9uiǠn)RV͉iayPSG>g
+1^lv{+Q@Օ?+"^SՎ o[O&W|@
+g2a5P3n;,_dDwGۃL~y֙/b.yJVKܲV+\2T=Xߨ=~?waMFFW<#
+M% u3& 7_n@!91aB9qL24Cti(ň$#d~ F@.8Dooo w~MQڍd;O
+ۨϝzmb>thٝKmr9[|h5) V+܄Sًe9 wNt73eleU﷚Bܴ|Dz)QI37SpP) ^)jOk<]5%-ݹ@T4V2PD=&TMoXg3)g| J`o
+ Lu 1˱\ E9Oܵ#&OZ'2zp= 3`azϴ~ݸ@tnt#WȻߍx9?xۑBYU)s\L'uZkj,@aeӁ`#D]Ǿ=DL]Op,!d|3T dzz-Z ROL]䯕3! RJArJh(9];GcWAv2TD"|2GSFKSh \rGLJ6Q5 HU7E9Gw=v"7|' lpI|4XqFq2鲈聢tby>-S։ؠX_p!gf}Q?"x^¼mQ"}c@H?hn=7SO U'Ʀ&F{g#p,GaRU>rE<\9ag..+ T 3t'f\KPxe88by#_l:Py4nވ³f՝x 7
+^#
+ 1gOsPoj
+Q7.OB)i.4s5({-45 | JYR7Ů^O؏*~r_nd/ e;8yN4/:" ֐̩Fщ4N "ӦiAmVF1˃6Gc{řF CC8vА؃a5$2bs`Q!> Ω;?G& c=&
+rX I~-;ve`nԷB+z<(߇ \K 
+V3B3m)3m~n?JljUO f̥앱{Go#D~Vt=t`u\PM|5԰,M]L>9b%S4`ery +ת_k(A¨ =<Q2(
+*Uq*Ե_W5w4+>Q}D٧"
+.dTBUNTVRg:R 4QgRG[IONXzH1z(S<r
+*ː=|
+#'.Vm׆WeV=s^q?>bh C_xXu_O>nũjXh2O
+a89v
+eM4rmcThʚn1ɝ]YI Hq~8)gB3[³K-̷M̵V5MoU$zm6r[aᾏ8 oh&@r>:vY|_Y|(y[ȓ)M`{K_ ;$m 7p=i#'NclxY{
+<'q%MKű:t .,6pQhQ0F0 yV*誦^_O 1s wBOC\Ѷ⊔-, 'iF]P HմGq e') )NDU Jg) e:7'+n1r*o;yeX*ځB2WPcXS ďjکH <H7j"c
+D˜,iPiǹu@eSN 9 p9ښu̗ݚAE.q@Xp‘B8s ȝAA`TP!7z;]ow=zc]1eNC"aE,c€4ϗp\9ݩJBͰ]$bLK}fW>o_@J I! $K;Xu;j}sQ1tvf UMBSޏcyXy7.IJȒVP?J=~8'\e#H{SUBIi%2_zE[pt &CZGȘne5O$${#m_$9/4CB,PU-
+mCV/>`}0d ʞAlG0fGz3vZ ȅcmЇA u>y=
+ +
+!cz&P?+՜<3ZX[y62<kVgA'.]oJ+ӡ0YYV&XM,L' kwޔQ6{=e8;ZO>8~޷t$k2'fSy#q&iIoQwI)/f1EQ4Pa:sb0>)
+e8!
+vAGifXd9Nq\fAMei
+_EG~]S3!+8O"{xW?K/Em ߨ;I>2j<2\`ϑ9Y<Z,mh҇ayX7GTG~`G}N/
+Nj;u5}`yZZ)Bli!F'cZ@ 91Ҍ;i,av7HG\c:X
+Mz|]xb)y ,
+V4|qnBm+(忲ʌ\Q6X"hJl6td%+NŵJiL:&)LTB(|XD۩(\MGtj0
+"O 'Nmg'|?Oit@"a55h>yňG: `IZ3oZ9Yo9
+S<nUEaRy DK/F}s]f1
+\Őߦdfku٧RfY]-P0 '"Z⎼HHF j
+P$=R%0+u?t7XWu/!ЗvQ_(D+
+ѻr/ˡ-D^f*``
+ߠ kW6۫wJZ
+
+Ol%i%~#M S@;ˡxP10wa'F{i?#+1.uƙځr໪VxحnG7pM&\X.|K88ݾ7S_d?Q`DKHڄ48m=,C{`E`E)XQǮ)_UbU;yK=?%pr7л;gj/вn:NvƿS 'A+ڦq=rP
+65rrLjvIOkܒk3BN%GbL,FFv]4Y*5˼6(rT<ʿ%5%.tf>C]>wϜm,oPiXEXh
+%gYs%Ɵ+ӄ T2)lRɑJF& S#:$X%HG '#zzT21ڂË`9Ȱ>B=ֹc{ |3e͍??$ wF
+Yg
+uxIfˑ9mol,:^:}<??.ńkFӂZDC1HOcZčXw#)o䧴w&vhSNtŧ;I]d]0@Kxbwb+$zcoG h' H%b莾boVn_]vx~w#5컐/Vtg6H wQkl|0,)ƚ2Uɤ_h#Y37dJ"3SVnfgO6Ou%BQ;oi}2a
+!L$Z\Gϵ432m 4ٮ#'u'̵)
+(@]Jj^A՜,7rD-aja
+l 7r"]ܓ&-' c5TS;GlfMD'n;T0D//o$ fS2t[6u+ĐN]gMA*X28Ʌ52`gp9
+"5,vs
+`d۵֒AQ
+,jFUEXj)XjV@V@
+is@c9w ԇk 'ۂP5o`-Y
+V9Lg×gPe@se&( lP2%|{$Ł s7&YAcQ( 0D;+ZT`*0&nr`eUi* J᛬f
+HVJ-`lJJQ|rR-AjP%xUдaP!Z*
+9hT ! /066f!)=NJ?ImNwj6ZHp1ؘ$ǯ^;|ϋPJY۫`;Pk8_gn9L!K}@T0=L QPC/ǡ){r}(@d X\}.su4vT@]U>AuhxBjdѩ!(uPS>L'yMz;PAݞm(*BY'ΦMvTgIežTÒ!j'9 g8 J˩}dA W٦'nN=T8q*g20!1Ku3y
+l)c)?!#gXWf1qĄt8 98q;H
+x<R 9 Ƈ1ζ|pMr&`xƻЌ =\;#80+;r46'8e秂-EXx.kĔB#GjEgblřt'7׏P<`$hXʊ<8b"<uEq!gy(itR?Z`XYց+ ;aOR{Yk|Ct|;c _Z[//
+b/3I#ZNL6J,vfŠƜiN(U0AŁ
+s9!@>{}4
+vC][.?.,бw0rnv3)r$cic#ZZSfe*WT4.b{hӽԜraI,
+*weuvs*1d}켑T >>f60Hgj] 38ABޤ"7o(pKs_pS/6JOʑqc2<|Ӯ9~H]Ohj)5:cR=L>pX,@SK~XKj^lkGؚQM M18Bĵj]W@5Ÿ64ľ
+X܉|y铥Q! 7G.ߋ9y*pq`ފx`u_2m`L[ӆ ):eOrli aNJ(,N%iBfm*0]z^F.2ŗqy@NLaqGq_D֓ϲFe?y#Xh)ٚѥͨy7֣oƊ:POān -
+pOLILn.v^,mplcK,)>sȼ}[,Ȑ+ vu3@}>XP|t0 ug.pPaʉ=i>!2WBOgY^vt!ų-L++, 
+=Uk#pW1Ui4㮛E)5TբEzlWe#eFR}h(7$TŤ}Ж%
+C '.4iZ>|ϛQҁ{CW<U11sBuHS'POQX*4, AvP6(
+:mfefik3>uY=:7s5Lz9#I}|2"M&0![n,++i5Qb$hͿ { L$Hw5|izV R.XZB-~O(|瓣(_SWr>:RJ-UӋ|W|ٽY91$0rC~RU@*Pz%sU|k3 L7Oq_,?r9\&zױY`#U"H3hXD,xmMُԯdM(7Kh0)%!e@|$S g=*z`Up Y=A 8G>j87RR[NAH9H51G{
+)`Ϲz]VPF*BsH[XCɫYl/h1/@\'g 4|/5S[pf\xWxwNSJ,e9>MJT=ƟWb<ξ^Ѧ̛93rBJG}MёGtDkdizuz)Ϸ=N z>{E 0Y_~nY,FbJgM{lpnq.H} 0<xneػm Ft,t`c۝8s.zׅ gn Ph{Rs0bxa9[tF#Snr;ifeӳ{8Mz:h=L&uC#2azmcNb4Zn^lz k$08l
+ȡh U>IFBO&R㝢>lkEw^B&<$Wb\Tox;K{N򊙨wMzDsm?|9S~mmjM$M=.MS/k!**
+Fh 劤.0]!3RkJ
+H:
+8У/l G
+$$6 ,ʢt鮙_35U3?fqDVA`H#ʪl!77aܺ[U/X3?N֭s=9>\zlFtzKV81묝_k)3`t"ۀƩGuRgX 6@s X$|% /Wͻx{AO#}HDSP/#\h %~w'1
+;!ab%qf_=A!`x"IT%+edb%<i!ұMo3Y)jl`}nV&jeh&V"Jj~@@@H_Q%
+a^1 !BV2Rΐ@Rnq%#\>Pr!#36~5#ýOGr<y
+d6 e/g}&jFj0QUY4v3:x + 33> F d a7P`t sWhQo":2p9 
+g΁=delV UXܖ9B) bX#F5C*-jr,IQkjΏ7\;l v38EF'bq?tY='xh
+tMٱɊ3^
+Zzh33^-fƪ) j1%N ECNєR!i
+4+fȪ"Y;[ZUMXiﺤITg %bw_w|C3T&R
+uu:.Njihj7z;n=ȌEqzdhIH"жX@qwce~}{m6O"~HaL'O
+L
+=~Ia  VvPO~b,YQLbAM~+D091=`;^?R6Q4KDBұh5&5)H=UYHRTs8uxۋϮX֤& k!ildY&, /1^JPY9=s
+r-aphnSgd% ~K:ZNCм$YilWgfY2wN})
+ H7~ VO!뻏FpgשLjHA9@4u)5I15݀58$]Ruduen iZ,0M]sX♥,b)"%8uO r Q1%Bd%1ydpM!$ѿ59 m+}w lwmlb4Z{߷ AKM|Cm Q1
+Ng7r6;}7F>ƹ'p=Au%~Qbަ& v :mj-y[[U:dP8Ύ)@B*D"_o z"|] U1R(R\F  )WY'Bۍqp#)a&dna
+@[M)Y[ K܀ _>Xhq߳Fzbm.P@}>v
+
+=&'@*=&x?A'e4oIy $C\xO<]_WTk+JSRZ_M:"䵔TY%.CV ]g_Ŕkb%gi5%
+<gH
+2hއt{ '2h+M~7
+f| rPDg', `%_$Թ'$3e E#F!*.NN̂R.- ,Kf"T? fŤ=R&<x sKV`@3 j
+D.C,RSt-(IWB7R _
+:EՉ̉#G/DP-0r;L1$mq_xvf*|s3]ͮ(]+S}9&ӵ3:ЖY %rۅ0Zl8^W8F,UYl.*F[y:RLA*z}ceNQ1zd"kƺ,<_l<M"5ֆDzp t ~)u~<]%*KSU* ;R1ED*Ii:? uZr@8i'j;pf]_54A`eoGߦXjwF/ޛ ,UE1$l ;@I{"gϟÅ(C8)W)^ H pUdU j(Az{2dDkv?!Z_` 5f殄,wPSk %4"A rN0"M^O8ξqwݷ>4 JB i7! A
+ "]?o&_9P]5y'c VnqDIg%T߁<eXFb(@.<R
+=dրp1h5q#˧fF1y 8Q5+NR'/g1UEJpA+#yDJTH)rb1% y#EVFOUJxnp!'E6 `ܡ^. ~
+4HE6## rp~DWf'3HB ο{9?DWg^tw׵^%&lÛ鳧t$L :>h?5jm59{+s ܙ!<BHw5sYG}\ z 1X=/ 8H4 ZG^w+Ch##]8,_
+uOM_}]xyMz6=b_sz˭=ֿzhi3kuu;r>u61mw
+ r}~;΂֬]+O"^ԟk *LdN +y ݏ9}(eptps3]܄"fg,@Xu񔤒X:xqc_ޫк2Qm>1r~40k}CGTtq< f,dCC``C]`0{/ - l7nne^rjwRr<%t%@Q Np#JWdAibJc|PɲrZSNғ-y&
+iqS?@ /|^,uP::::(wԖOqecV^woί\@ܽ,Ӟ%\_M{H銈bd҇&
+]޳{½ZPCMDzM`J&ADYsޙ9s>glB'+ԓ[qt>lqLGab;qt;idSԿ}N^ϑݖq]qkNN%ϷJVI!K@3;\@|& 3W0s:jT骫p* ԥ\pR+D<5RV@VBMYKn1SUM5Ƞl=SM3
+K+Ǿ-͋ 79'>9u(?rY[%~>;BjxzMl 19m<w=9oN: ׻w&gɩE(
+HgMò&)9*ʊA[#zeve2<V],!wY`ܘ(*()zyp^7!)rG !~^c!pRΔ RZR g!ul+Aj` Yj m# 7t/t\S26gRտ JiNS߈Ϻy5r\@BDg޾11oX)LycjB@ICS rGi-rd͇_!)h3' g#dH({#;Y*-槽?=/~^noKHT~ C3@f.|,_b_^2fa:;|f X08C^vXPmʖ†7m}֊rwܨ ko4++>p#~1'm
+^2VQ>_Tf6L!jN!Z L)TJEXyh![^WW0Z8W-s \@9#P--[
+2vR-p.VH-MB1s4>m+5i9Ygn
+2X],66QF-֔RKǚ2F*V?ann( yE4QӴmhTSs)$!BY
+5zh&'C~n%E3݁GDFqN3ᘀXK|ga7x:2ay+YϰfL/i%$@g^͟ ]x罸5n0I.'V|V|-x.. 85
+h>pTBbˁC~!{ ؤMO:䆯S۰=Ͷž0_i bɱ,9G/\GՖ޹+# ۋE
+[tʲ'eS]ZEcCᰵ[n wwop6|uZ8.~?nKfn
+@ʶIYf
+x.?v  )lx'63~}{uU#Ņ'Mxrk=gT<DW]7a0t|o>/ֲ;b܋nG>ꘗ}D?ƺfotS.p5P:P,B2M-DKGvzST'܄ K$Kot|T*"*H*Bgc@l4;\A#*
+4OҶn34daN&]
+}(ht݁S]~}"؜Ξ_y}eَwݶ/Lz}uשlZxRDJ StW
+0.01 񰊙g( W2
+UpT
+Xl%H5,5ib[99r !3P
+
+C+p
+b擫Q%A[:>5G;=u7\65HK+vmWVQ 7cx@r
+O'ҧҗ۠K2tʍ(qj\\Oj g@L7c(ڜ=v&/CFz4UUP3Rb . xMy!&W\W_f_퍕׷^m9{km͝5"HLU,^pKoƄ~ Mp],>n zY|}f
+[;d߂4܇J,s֊SVj h\hZYVq)ңH_ݟz}!?!.N@_
+=E^A**y3^鮃fP֗(f$wq{Cjo6 ;u33)iQjk`vD/*_:M݂Dnv0ȅlA5d DqX6\C#KD pOx& 5FQ _,3?j}_=E>'
+"<( ~n GqG>wB[RjʕUbcuk: 9F<E{\e
+RK  *>Í@7<l<GZAL
+șR9 (CZIKfȪSa$Mb?( ԣX4[SN~_Ѽ ʟ:pKp
+=* iog
+3- $LU-jd1W z@h|I[JaHc %" @SF5p-&S2?78f|9[<-r-KVʗSD)+H` 8?O%N4bRf1 B|
+rW ) C:@f JZʱyZ;} }`3tfAD}6gj}3pi::$A Ud
+uă6NEOMb<&_ ^KHċ% Hϥ9Kԑu[cda!yĊ BlŲYvI-vf-R%н2k}/c9G9V]'eG@"mސC6;o[;l  3B9zzp*0'NkOb_w~}/ $wte J1wGUЇ}mö11d!~>^c/=#Wz2 #6oօG#:.7y,<:4|,y3k1KHL9&r&ĸ?dxܩ~h!LȒZSLrgm z7y7__jpYd@@k$Zq 6bw
+j vBP%NNSPUxUvJm:ȱ];.Z׎ׂfTՁTNFUL*6@SNӚ |NӄOvBRi5KDKo$̶R^n+ܕYR h3k?2
+\A E7ܯ,p]/9Yy(ct˻fض}˾YqxgÏgڄ $YzącC' a9=eN`:09+4v3<l Umxi#V3:#D{"GY.i#RψTӢӲ~:WC ψ?Z_)i7_lYfMZܴnխ{>XkL
+"%噭 m!7ZJj M5sKk$̋rA`H5;ST+OTIjMo/dǂJ Si*)Q9S3O\C@N43O4'CVyj)GUI0VM 5*}9fpZ2RΒT1SzD͸}qϚctzes,iPiAaU$bÑ;x1p
+fx,zMU㚷S{&wـݬQk].{˖+=r=sVMV$gʹHYh^ ƫ\#DUH!\.@+`-4#C- fbUk`d"6JOF"#(V3Q[qѤz&bF 9EUsJf>R!e!@JH)
+3wȉ3I3ϦkH9jznUKgb_t(^t0>jp R?_9&WOBy*Mw\gj\<(=…މ e K,Pups4J:V:\uI-s꾠;j)}Rw5GY 7ˆa*<L0"ȄS`fD),LCcD\:$a6H N8[KE𮙺IsmW$X:L X/-z/litt@j_oURvyَ
+sPd-H]ƹ k \ *{^ז3z.0V!D[.ClU jX:]ۮ=d 6k˸Ep)@[E/Bم!p끽Z:I)&@&wcQʐ4GuL
+\(mjHΔ ?#` @pV
+r698k~%wfcZ"ya3CX^/y,zy,<-kf$/:ۼ2fQi緰
+"lH)1 *"ze&GML ƪG 'Q=TS8J#'ZiR
+WMPNڒJnݳÏP-69 3_IZ I$ \;--ZaMt
+a,,Rmmm|r~Ӈ/n:sÆ]gWF^~P=MξGv5$*
+>*gn))z;2On?l_[ݼm/^FD\߰aCo֔SC+2Id+ۘՠ?7)Vj?X7Va:X_8(7\mڭAN-]˞v?۝`:: 72Fo|Oη^ݗqgܯHnJ0!33~X )^LP7|;CS 1d!;2 R2
+M!# x]v>`) / LF4eo 0 @{<<gbpD?C[,GiYI(3hGyqgOWe]gH8B>+$G ]|g`ޚT>k+s)R; y/jo nod=ɫ5N/]v^DHMt$VcUw:6pN Ep] g>GN?u>=z[EjA s[2MP`l@XE]\̮k}q@'ͬ: 2U_"fT" Ϊ)g aA "x~e)gЋ3%DA;\8*_']썗Kepۯ|?\o`xصv>g@@0=KxYJ ,q)^EzH!:XU!3ClX: axWC2kp`Oe
+*|l,l
+˰e
+{ka-ku+~eYiWIl[6C<P^5j2
+ϴGWpb#fDMntoQO1X/Uױ7ΊHgva7ɼ0Y7K++KK> .,\z9t5n nZKfp~-n
+tQNb|'b#\qT'VlxG2ni#Un%3a
+-<mŕ\Sgk{F[֛6gN/v~4:}) 2%'e~ T҅/X]Qa CQGcddtJW$p/QLPbL>gK,yg\X!yy|ZWB
+Ly*hOYmq@2mL0
+\BuѝA7?OnLky%C5!>p.
+g
+S!$bf"?;5'
+dgM1&'xH ͜lA1
+X#*[xuQR}?H0=WYd{X;k]vG{Ɛk%"bN^z'.3 ˣ$8h]&-ȋ28mYlG\s}P\- s-FMM}tzbFL 7MaBcJ P5Py:[ jQDiqp ^e'EQ<#Tq$GQ/QTE(I qQ~{!=6zb"—IBD[H<sJRmp|iXPV=:׊y*Ўl@яE0&zu߅ D(Ԑn<&%D3\Y:@ș"jhbr@`H_8VW
+<9 w8~+~I)4,q\A@8wm PVׄU|P
+U@5D)
+Ft`nn=?9^?F&؉G9Ja*TLIɵtHGM4ԄulbG<
+w5i\P>), %Oh[|"4xx0^|(!j' hcmP,֮!=5G#Y`p` ׽GBvƤC6 lEh0
+}` j@D]
+6<4j5EBS Bik
+ UbxAt2ף\5`ǔ]Ujѕ&> eXX=Kah1r?-3Ş
+'m؉r
+X]L!ac؋i79nPsxwe$:::6] rׁ|'ow&bۊ-ԍE\x37o<u̗3f%|
+Hz;x$/x+u|mMXKys8{?&XdŒ:
+ƭj>v7 N҆Ɲ,i {
+ BkslU}*Fo=فO7q,(cDƱ\0c%BBNEIʘ'BW
+?KCv ]S'* Gx,9VƸ?~7 k6򽆧顪$aF89O3Y?u$T
+q5dU/9w+!I%Ogzq#O;Zsfzx':Gﳳ={n:WG)_(kkO(D_ hHD*p| '
+&$$lB!
+UAcDvp?3?XN1WcR U Sy PKU2Ubj&LU5W[FDk [DTFNW3u>
+?_-ﺿ4&^TSCmU ?{ao6^ۓ̿2NDMo>#6o%}2qX#>7olhg&r"h?ceԅZj= KdR[̜+rǃ=v"rA3|Z9.==7\[\錩r(+0YJ<XAZKdlZQP$%52\M-9C[]mf+~ ,/կtЎ]qbE24yh+\ UZJFsN‡מ m68vZ6/oeaM=Qሶ{Mqw^<iy"~Qhes"emV#dߒƼ('fACp=
+Jp<H *T<P
+Ll\h6vED0#LM9CgQ#Qn(`bd,ƍo\~86 邼~AFI3IU|
+k2 qvՑ3&? Ƴwx=93~/{IU< I-#(Ji*NT.9Zb6OZIֆ0ʛH؃ U)~[-$rzK8JX
+!#W)
+Txr`n_)U]OCb |(8OC?RݣTݣ6G0J!=W)ާ@RnT\UB%?@740.05M9Ӳp)9W[>.k,&`fwSsvK *$[L}1>+K@xA L
+Wk2l&87|%8PDAB5⒍OW͏qjlbLDg3!LL H4`bԷp9*TM~JNT?d%TMdx{; }гI;^ F+$$Hv[ V(Hh$_fxzNf'f^~n hi_1owS'Pݰ &~dG f^4PC(ϑi&'|'G}Fc]`N x5wǜ2s89:I<[~Xm׵nݵj'&9Bû#g.\g<&-69vk?Q[ao#?1~lk3+#O\{0/a ?7~%lgSV^9Dv3e <Ot.c êOho)h;}v
+b
+\mX RR
+gEyn^^ꟳS=ek9ϻ]]n I[n N}?7H0q#w~>qKACy`C_VnP,MtF'Op>Fy0pQ08>1r
+[웳e˪֕ccK`")̉qN+4  p!kLtp<x'i̙XNR--kPC.I/i긩 u[qR;\X+Pw+\g pIRcS2ZϕdMl"7b`2" } +nލNM ,Qjh5>Ԓ 'Nr90sy ZS<aL^AN44zqSU`
+_<a @4)(f \ErS$zD:ZI"g'Iґ@WS}A_i/ū,?Pg+&jZvѴY8S’&-v Sfld:XYHh"˜Z|Ǥ8m8gtglg_ˑЋ-9ۏ} ;~? K{?_2me]Kys
+QVN5kjQKwH9z|"rxHͳC
+RD7̹;|y ;F4Wh`IXu
+2J*ǩ*UF!% M`4 LphY,vwBbchA!rOshA!A# W$9oAiyr摕Ú1㋱aKܐggWNgN/1C ';z/1x3$s!:@XKGJV<xlV3zo雄a &{09†ǣ\,:5G̡#=4s$_`cJBeٍd$?9D\y`|GN] <}c? <+ 3߾M1m~};=īL9a2͵ c+늱uu%hH2S}dF 5J4Jq8
+WvͮP$k2,ZZG5Q9ZVΌ-55:`+F/kUUr
+?{ ˰bbW2+4 4(?kLR|;^ɞנ2t|4WW❨Bgk+sM]=^}6>:$'LoqAt€4{lt*u;CW~/%6[YSWV
+mj qE UEOϟ<PSW}.IUknx|7=_ p}|܂vؠY4Pm+zĺj60n+WrDZEQ Zn$ٍԛ~//^@9Nb`S,|_Zq[iwc.t_aj~wFp3mmfON М&Y<ڼ7<GvlX<)>"9l\.5?@nW_OVcm؉šd4ǝ*,iRԊn[!(
++z*è9hWl#=~I8|f&1Fu[ڬAM.@n 180$HĖ~Ѓ`t qG=6g}ѧG}Qnd6HʭAG 2[ԎveT3L< 2;6.OZ{Ծ787D6KB7֬VM_Q Q\ 5ېs섌< CdC
+h|.?\0u[:?GׂXSjo<}w>7Yc\D nT}1 uhP[ S`NUbj"$CЌ1>!G]P]X
+Aux!R+"@܀1< TwUh ,&6WE܆J1o&1 D@8 ( ͷI -b@jq#օ,fQ"&AoAwx$ |rwR.|h5bXV {k("XJɇ\K.aOc3mlk3XBHM[p<kkx$3Ջ:hu_k=Nh!l-CHm ͜n
+MVKr`bPRc5 G(1KH%f-kd/xeZ7׬3=Ƕi*`J7k@;fBMc8>$BЙ/рNۗQSKA; |$0p~l+ِy.=g?e}w,`Xxo Ujb/kOˠ3ctۤG6'teIh 0D2q>`Iӻ/0t~nҙg/Lzh7"Taط}>/ΥvKqMY;i?YH;gi lr\\1T^mtyB:˱:6ڱAt@W\,=%Ι5y<~esʦ+(EKsG9kGucmnۦxV j4x5
+N' m nsGƼWp
+Irt%C81%ޤaD8 Ro"$E6\O\+$$c=SbSoAbm4D&@$x #k0=TU?u/H.i3*c֍_H_h9\w.W}hpmq<r3
+Ũg'z),`5 h,u0%?9|-=h 5EH?;tL4+o*Z
+2X`B64mK!4UzVՑh3 Ԕ? !V1þ?EƸ["|(4kH5~9335M<c!3!;i gu^GǘE͏x2 yE=u7*%bD
+$[ п-<M%.\by
+H7aMH7 aP‡1ۃ>t:GNh?wẽ|Nm;ƀ&Ii׻\#kcJ连3!% `B
+=@HϦ}^x쿮4QG X</<Jn.;JS4W9j2K-i-tOPTuTn5 M 95!<TBԏu'*I|!wWIՄfĠkB<8ʟB/)UU5t[+(@`.!x`%8@AbMJ@'^H~K,V/hPyjq0_S,T5Sd(
+2p h( 7 źi9oC<ؿF|ڤǵrm  ؄QBZ8I
+bb1֒s8
+W).}o +[Gh_b %יA.WnfvPn92jJ8"ъ(r$HːpXutvםitu]A@pBH9 9 wSi=(* ;77o~Tm% ZϤ)k
+@i`$x0>(?*`b`x_
+S#|:KO/PM
+_)Thf4GkZ)MJ? 7&K%i۵47F5jQ1'ńO
+{|~x%iq\khj ƸR{[<ܒTha^D]˙`YEk1Es']_%S%Wg:t>B^.k&4KUxWaDԄ,1@9S=
+9aWЩ`{5apKr޼i|Fߟ7eOI OF?$P'~\݌h@Za<kCT%
+sr#mZDs jx /5Cv>hٮ<k6]M"FhQnmk
+7;aV43 br a: Wa.hk)?+"KMDN%5x8=ӻW'"#'}KT*ǚ/诣2\/f\m#=ތ`
+!r CTժ]kܩukkݩuDn$!g 
+X ܔ ړX3tujvlkc|[k@s `4a5/:̋;QN7TTCꞃ,\=NY= `CDP1jJ즱UB\WPr5lM
+1齙}{
+$1n̻nu-?0ou &޿?j+#F{ } zDI#!A/;BmA1 $`
+>5UHJY@;YJrH0MSK/GB} |q%o:cWh!v8+ .+ΐ2xIImE܁- 4 mAS
+BRCB D險1gkA(! $!{ H7"qaˏ[WuO{ΩJ2蛺ڵ7ee %;$}AL7_,ws7w<(X;{GŶ`o5!r;,D>8^W<dÕ|Smj#dTE'˨9wC+sUJijى:mJʐ:P6Q2hZźh3=(/}h%C1d>'Φ ֺ}ߨ=zד=6S6ωѬp(%jJj~ 0X7ws==ycFVyZ"
+5 rrQQ:vgUX+0r ]zc؟627?Z(WUx@^.rW
+Q$:@ʶ7Ez^ɷBs9[2XI#,ģ/־c=eޮ|Oof=G0'0C-^[_cCs%"`d/o=}~lfds`
+!u<6ızIG ?i >ὠxx7;;Ʒq[q;[=UZ
+AYh@dqNI3 gf Y霑A&<̙ϜۻH-M×Y_|g[*V{*OvN%I% ι/~Lx5\MxʬObρt|G!f"3&15if[2qb:LIwtRI7vfF)1 ]Y`QQ%B%إS bRlQRE
+ƿ7` @ [Pa
+Ħ *v̇&v$ W )W*Zh4ϯm|H:5u`"E HX<] imgM3\@RX6B؇(LPO.Rvlء$؎N"ת&3')f=el$yBO00RiC'_ +%{y19$> "p6")ãv2>H̵)\eё3%0&Id4EL\>C<X
+7O8yg3Ia%拤;鸀?L'ɠb2j$Ԋ*"ytyvDHnEInŔPe6BRhV:ɹtqZlS
+{=vzr!jJP5#UYhzJM_5R]Bn@*s+0Rc
+4 Uf p#N7c*K*@ԕ΋*h-̡"
+m(O31\=@{d
+lx I+L0R%P_(Uƈ-hi >UЯĉH6`=?5 =r .] &`[Uu>5? .|Ab~]ƽM=R=ǻo28 =B̆)n= |O')/oS ,Z+PR[QaE^ 0
+'.I VA Am7(qf sgL`~ kƻdɃq8L]\JWE{XgKyP'XՅ-OS2#byLNH40n'Mt{DXH Hl3YD|]D^}m3OI'
+ BB _$ <\Ǐp
+\ //_GLħ(㉦^8ءpxݰBLv0;cXRfZ5΄+M$f$PϘh40
+`D^x$rc >#}>ߕ^I=gnU^
+Us:g XkuU=3Rq]ш(ÍW1+M_\QܺnqZl -cJFr<IFppA~Ɇ*]=\{']]M _韤H\3jO0=HpG#WG|~p+G}ďFgY.,Vzso*
+
+4StC@ƛAҹc-ʉVl1zQaE Q6X Y%]al}s2W׌,K d ?Cr'kPUdQr X,YPSieц("D֐l
+vzTODRISI4C`
+tAhc
+%ۣŔ?)  *|e99_ɥ$婹[\|<%V|ШoXP:EA0yP9
+ 7
+PrOR3N_ۀV0rFl2^L4>gAl6
+P9="P7E
+\ bt˜o'7-d ,
+d e @ƃ*q=]%.W
+IlX!^nl C=-JkmC9Lg.s%?pB@BMD3GT#SB%g1Lc7O\kpJYia õw"0ɧ@+Ů`
+-R`Qf.; <'b/lGǀ9cO`EԶ
+8%br
+컒PxmΘkL{i!l U4%
+VuؚN|  F:(lq'=ϏjXz"֤IƷ$8Vf-HlbHbSTnC^Ό`ċb=J FnaM?-1[H'$@w|C?b]UO2-߂}pϤicݟ3^6B! D+a#
+J\HA
+* 1hNE"'|YB>>_P'ΗQghB2R6ͮM }{kA钸>+*LT־dkork+g^߮z$^
+]}“xubhxhr1dNpG̙\Jrb$7P
+Ҵwkyy=OsIlC 咱(6*8ߊKY|+Z-r[o=!h }cH@ߜۜm5TM+ʩb> bQsESY)ckj" RV&VELRK
+*`
+(j
+TCc(K+h .C/g QE h5ai dY*7*IHZ`c1)ux쑺s싩} KAebcxn8&UG-wgOgOIrgr*=3[:pc o_du0SgP)%D2`x`DLpR oG-җ ,RhO,֗Q$2b!z= }e迈\FhǶMr;]
+kwzr=h%5>4ЛwCͳ `+_DyWޚUV:<>?2&[)>te<ԟ888*rw)v_8_dl2حIAisMOSfv'lu{]zw|?ODSq%2pev魳<ae2NԬDlIQ~歩\d ]~q?ऱΰWa)c/I] }z_vqQ0p"2-0#ै@)hd` ~c ō-[;v) gY{ "yW~f+4:0@!Ls,OϹKcN"| o]6]k ; n#!NV_|?Lowf#a).ܒ=5r! rl;kCFK=~Xç>q+ =^} @[N J{bpoһƃ Y搴\_QMy
+b
+}w<)CLpv C@*["9rI4{AwUqWI=IԞUGigu]_TC z|i=L^׹E~MX%N Y$Ԅb($`3{#cѨY:bh1.@a"*""4cD
+ĄkU!
+UG{m0k^guda
+׎ wqtb}l\6<˶嚪|S o޼1'qDՐFI]>PCE\k}glnOEh0P &(
+
+o%@夳 d!|BC%>,D
+L%(]96霮W/ҕǔ\PtBiݣ?-0N5+QU'KyS T*2JA%^5!fP 2DΘ`D.0+pQˈLcN8VhZEPD/vԶnIbw4i35jϊ(
+x
+MML쳸;f_aյ*u
+_PؿQ82z1~;Kv1J3:`ۊ ^^GL+K(81GfN?O
+~m[=ikg
+-I]uUXc`ܫb"2Q<L&K]ȖDͰڵJ*d-|Li}M*"fɹ\@yAem.7~S?ӆoщϙ1(`Sf\ݘ
+>PmG"o%]?ANEljtX+bX'OþI' GRqd$SbhXFAR- # Qxg<b?.%fO8K-QPu i& Ɉì)cm5"DTI v|LDoT:Ǭ[";D0됏CW>zhB6C,fUْC1c1|xwJDۘ[!\)1|ʹS +'H/1Pk}s Rdt-<ns-8pes
+@)fBM<c-6\I343ul]u8PZyVr$Q=
+ut^Db=s#Wڟ/C|B)% })#j|u-TJ, Jhu92x&_QZ uDXhcƀU
+_` L"S9$Dѕ!!rWŮ9Uܝ[$>v}+qykzl%{)vJ *iLBLshfx+Ch"WJO:!._'$hˉEP.j܆$TuH
+n'ɩ+|%:s5u#n1;d ]Fw('
+24x*}41m^2Y)WK4W
+Ef* frzbXzOm⼍V` 7uxvd[aO
+<fݣ)#zcOv?rl}k F6Xn
+<MF4뀲7I.m\,ǑO,G^ȳGC`큣C8(#F}
+)Vi 5șmG& XwFaK^<޶&Z$~IcA@XFj$=%Ȝ˜I^J]uJiq~9G
+ȘnKIN6#f}>>ՆʚhNT-M{[;2f%Y35ײ[B2wcA&WWì=9Kr/β?vg7@piacƺW-wzXV-Z\렴S&iLM}ؓ54Ih8dfPgxB@tl_gtՊz*BrIGJ<0\AMe{Y&T !Б) nWyoF<gvZ0 Є~H];sΝ3w97TuBW R0=&81pc!K>Ԕnnva 䊌ZLÈnV1k&l<T\׉$`vΌmҲn$, 巘?Wϼ SqwY )WD/1&V[ak{.34{cѻ5ٮ4 xZ*Ɨז< 3$9T'xDJ0$XFec5Up<R 1uǰKz uEn[F]GY,}4Z2]4uX?bil숅ûa1eSQ ai5x%!\[w ӈyq&xHspS4ۧ[dLTN*`ʃi*ҵ
++Z!>YT"Ї=ɥS5:X(ReB2]G(u3>a:шrmrb~:;N^g'7/Z,ٲ衷;MêuPUao8f;=9e^3#?7:Qcπ=d oZNX:"ӮAM쵧m6\7 \m<8l\!_^~i6n6
+ws;Zlu<<D}{}qƫ~3 :vǑ6cFqt# ef + <GXs3'H9%Ք8KhI+#BDcHZB,y$jU쬦wW/us{Jzwv9^X'{$'[;^_|jOCP Xk=H?B^iqZ 4V[E*I<D0qaqek
+\ֵ%yD@߈pPk!1C*#c^㥜 f>莎6ϛ"_ɯL-h/O`V&Txúf+pwMѬg(ovqtY8NNR=Ou71~h&"#w+f)yp p(Sz)K?&el?X*.&)_?Vj_e7IXe>^kzi^`W8d8_y#*rsYlP>&uOJQ=TUU'Db
+PDdi㮨cde@WU+\9,y 5U&0 @<2[-,*H<Rd֖@l
+",[ T[NZ`("l(rI(D35zxMu?mSOXs+˕N9鰉NL@)\vAAE`@=h5P`A٪\0
+Y WHfu\V!sd>l=: af|责ؤ8Z7 E!]~瞷@Pubmσtޯ îmQ'h4;4*GB@EEnP!FTPčlMtζN'61YB "(7
+5Ĉbоi}gyw=:^
+Hicv@
+Μ˱wCQeERB1" IKd V cN"X8E˲Lbx5UoD_>b}Si}[6#ZE;m^{]S@#ri50hz$~~RMqIIN(@va&p'nt00BmPRiZS(w-mk/Gן{PŎwQo;b
+g? %FH^<U]x.i6w.$_{ 4
+K2a̅uɜP'1̯ (2i0ޫΜ S/MKBlVa]y},'K\7fd@<@
+.,nmeޢ6qAVo_N3#Kf u3aeU aMja01 )Mp&3o?E~s݃WNolÖgb4+1oA2JXʴ,nA08g̸AB 5x5$>B?BT+x024R M+M1XU)D }) S",Aҁa$ W;F3+9HmE>El{|f2%r̵>'ô#dU`:32]-f= 󋑡ogC+#mM)r*ر\/XS.1H܆-M85j%YH):ƺMB I~c΍y8İeD͒0ʼ8(@]{y*c?g\pvtc}g\yRe}gƾ؝q \2Zh=:rs >
+_'G:t]T_kz1=d~_[ZjrM2tT S9_hk׵FWU׷ (%$@ʀ
+P7
+PFa(RD!2G՞JJR:9P2LVg$
+tXP(%ޖHc+>KżlNT \S
+G._X)U`5biTw"[$WWL]xE0઴̿DVɗT}?]<D(<S)jUՠjG^%?Un9ծ&+Tb/
+L~|CU7b2-& u[[(~}"п/M\+U/@01z@'C$J{dT k H$F?xԫh+k!"w P&Zm7悜]D tȍEKaXXtլxg+%4\⭄z,T S\aW͚v~Z8#gf^H
+6 AO2m>S TwT&D o#:2dh?lM^dd/ĂCm`@ѝ@(w Ub,%۠ t36єpG2={H6#jhT~'?O} '@XȀ3T&k;ȌK4{
+WBalVR7 @0@;8h"w3ӾuksN G9'Eg{^M,c%?Hvf-N؉Cw[s&֡Fy8twg4(+s?Lm fm%w;[Wl *aP
+-!9v|,7m\}%e7v9V_I\XgSYL#U3FSGB4<4iIӋu 0 ZBn!le!%,IljFc2 [ٖ6Q61ӽ1S} "U]#*h eh
+4nJZ:<}<v7퐨N{@lVBτi K ,vb*FS{c5 EkܭXU9S K\JYg'V,k?d>B-Ye3iq }Q~(̀K={3c-unYcAn5[ۅ~NJSOBvT'lO.n[mxLCLxb}nq~8;쓬C(eWD #fltxNRGZs܄5 &Et&( l%Jl>_:?Nl&4̌cf1^g\}~ޮY>hst QYaӰC!Fσɟ>HO?rN?m#V!,o0ީcZcB[!so% /-Ϲ]]mƷywjoޭYK7yw7~kr~6󟬛?|ZJSMFz#BN%+aл]ܾFggw6'=oNJmc$w_ZSY]mI}mT+4IԉKqW0ygÚ)i̡&T?NLùaQ}/Ȣ!;c[cbA]6P>9ISzLUޑATԐGЃ&Ig*[N7[k槱5T!D\AMdi
+=ll:;#r((*\}Eqի{U4|F%ܯFk5B^%>ƢqDgz"d7G߇S&8=nWδ% ?@K1}bg~;22@별_|5ZqZ-AjVN2i)z`_ :upw0;al2;[q}:eqc#~43G By~Pe#O|M W,}_|Z^bZ1M32^F͵:\thiʃo"?jEk8jǘ5Zo>K+k;d/:IXxlքն-G>9ů8%qK:{ٗ{6;e4QO[ΏU@ͥ3d0M"EFiDetJ)TwHR͒M;"S"j\ rn뺺TCcKM8m9TE8󆇟
+9ZArk J Y2(cdXiz`hфdL&/QF8Wy+ǪuMHU|TwOJnEɐ[BS̍laI& EH1WǑ5X} _yʓS!{t]T)QkND(>z' mf
+ -'qs
+^.Q&9hL+' v&6-}oCݱ򎆽G: {*4Y^?{(6aqzTӉ}!+Yvz4z~^ѾtMOnVnk|) Ln/i1/S .ߢB+ eQF 8v'6Ǎ&}CjOV4]Zhic7FJ~v~砒N^
+.UO^2)8E&\bH X\oSDҠ2,cjVno%dTL\\hX (_%*h 6Pibec7Dc ϴ(9,Ոl0lӵ,s-CoR5&FWγs
+LUIc^O`p.Vgyt7 ~|9UrQ$N5<`O3*g2(!JYd)w{WU!EeG'TV`,g2\bK
+1sڎCkWa7mB'[cgw`X>9nDL9^n&e&ֺΞq~nMcZj\SǬfnfNin2p
+"J|".&T@9ƚ\c3PKBSzﳎ 8[\`da=0`H//!@HB=$쮮3g;g?ή{twP:
+:"}@T,#8~{{wy }wV-B~M%ELH{Va[S6m 3fE^,YG{S KڗU8s)yQPVTZV\\!oƆŶInOh>g_ 0At('6>#9p>d٧&\mw{.T/ئn47[2ߴfA&t.g}:oњ혹CZC^ėnީoLCڋVIΥ6зLyHu#)Hp
+aߵ3Z6&c31 X^BhB<bAiPy']jAPZat(Xqaiӥ6 gԌ N8D̉pX;9g#*Yw MidFLG7yfto eU{xk'<=I4jy x#L`<豐cǁ߆MQG Eq5#~[_<Ӥh&ӑy8XHhoN^Ϲ:ߍfjےuߕ\\b?2SՂʦm^Ym,.;7W=bGf8ԬZ@sl֓ǜ (iܮԄ־Y_젗HDAohK
+w k;wM?κW28NGwSi>jh+!˜볉QY"8٘]mrVV$0<R &C!, B7z>,Rpߙ? r.;GX݄"4HEh0n< _8p&C'x96
+R@!/c
+.UՄ<aSHd9d .f*zY3U @Yz[,eHj$y/.Yb!eɻ U72O],TVdtI#.S- q SngCğ Hqӭ~96}43USLQHQlx *!UC8t
+!RypT@N"i-2K֊,
+P 4.<u͗>ɜb|
+u5buEeA
+\Q$B@.dUbgL͚A$ނ-Qbtu~B5615lg~М` -ۗԚ
+!N
+! $RERDQPP >ݽ{mc媬rC!$ZhWߜ3; :yD)S<-Њ2f,kfs @CLq^R(Yz}%*\sYRE/k%FPwcÕrge>]&zL+ʥj袬b璬:\ \V ,Nd$#r6<\Mu8)|/"KV1B/ŜwUm#/"OjZy Z29 C%YeU]t w(ŠhN("}DMsq裊>r)eo(YjÿƂ1#aZ`(DĪgCF\ ? f3Qc8Zc U0@@M 7:0SCkgq=0?@;:='L O@ D`5R[8_Jt
+`OFE
+SFFRSZHHB(Zg&`&C03h #+6PY*x+T
+y-xǘmkKd=kvߥYے \M t9 92v
+ x>DWT:P<
+ST|FRIccMriMiwdjEMe)LPsa*wZ4F~߈|Upٽ'%h;ךtpsU«15ʅg}Z6C
+2v/{ۉm.]26y}\9.͞з!'Ҷ)r[U'%jst#6rJǏ˃$5aG#u(V׍<^v-v3[\jvѵ^U4SVLBPyͭ ٧ϛ5m\w>:ْ鎦
+*)mGao\bg`at=\A5yp=9W;s;>`,
+y$)MLܘKL1~ 73v{fvA/{-ZX|6Q$푚}xN&^K ?ǭ<0A
+Wb}EA)d3"UVHPIaq
+^:+
+~֠ˣ:Xi'X+.m孴tE 5u3u<@LRΊBF("O}ph'P<L #A` F;hO"ǣLP
+;_ #ūm ^Fxj`ܫ[1a>!46BUa:|%E{򸫍fu+BQ.> =wDpb{W:޺آK1ϕȰWW^gpY@IA#%P!G5mMOpTh=WR 1hppqFG>Ϙ>J,,)IdEwR4gW#oh.RV3
+ "i/CM䲺4
+|#e=E}zO% JKiX H\JϑT28j:(_8b
+m` Q#Er@|8*Z)fkIy%C^G͐R9ҥMT7
+F*@RTV*ʿao*gHϧKQ |}
+R
+JVQ݇{5.8.VX%|8^ *X{f%ʖUrkQB*32ob?
+{p t,.`;hIvr(ncbY%PF9-OZJWr$%B+@:z/jF-P4s^r1#$(q -Rڇ\
+yvcuh`~:7:58!Ջd+a"E{b`Ñ]]\KF
+H
+
+K{~}}}M~$ߖ#oNr4%$B!yb-
+q ^kv O=w.øCĚ~_=>lC8o`4b?XV;+{A\33&Zl|ĊmN| ~6BeǮ|$lg&H tFG䌸1Y o54}%"s9MnL:f:-20=ljIoKڶڶ^kkZD\%uv&& ދHtr 7o}qcaśmn%[y^)U#!$?ؽ7jQ/b{G~랥Nӓ~ &xdJr$6:L HLt44y H@%0aB4 $b'؃*>D5ȢnB<V\PT@faI1x¤㛵_~⼹[_M6=Znx[7wͬy7=!=M,
+uDnC2R k̳!‰[Jv;&Q3" 1*gɃ3':NV*|@_~Bs7j!BϠqu;l b91=NJͅ)L&8o68wD!n
+SH9|s',ge(9<c6Cq\Ɂą{i#f 1 UWS "0y&f asCzZLB$bcL^jUs;y=sq^Ѿȣ#0pHW)νyi>-A"4}X?ne)%(zÒFBRF?>2ædSI
+vxg]j="C!e59P-fbZ!t (VW`]S: HyI xD$ ar~k%ibpp}i'g-7B}=T[f!NlS#9H蟘m-:_TpBD\E*)g
+5Ui T]jإ*j)|(CD2K5Ӻ*bvuU-JZY@#J|C}@Q7t@&P(R
+UXM`:hT. 'Dxm`'$k\* lBQa_A?]}gYByF]
+Օ2XEXSi*g1*&`gAA*E)૴4:_)ee)3'ZX8'M;䚚&Y
+7I%ZAa=IB*Q W79BdHGn^hXkpjӨQqF4jlw2VIt(X˘,cv0:>Q9/]\-8 aٲDp5.\ d7b䬿ecv}jٔߜolvYzzM>|:_<(8"xGEAAOxkƚ4f3&i:ivw&1Mh&V4 oϼ3;VMxMHWeh-Mh #V!a*X oMsźp t0iSQB=C Ezl9ih=~p'ަwygͰCmcHZ׈T:;MqJU(V *#x*tAqURK"܅+Q1X
+(p(YX ei%{GI1s1{X;Tky]#suq}庸^,mc?or5
+_9nt-4`݄BXb\ "mm򑻄}7u?~ۍ՟=ohsMW~eW78\yhu#p}nCN)윹w`{nnlgacٛlMtڅb.1):NPKRI-dC\$+6JulD\ζKnƥCA쳡B\*cr]#旽4X+OpLEBr=[ۘ *ǀ:|Q_I?v^Kx~>9-uJfKsfRcS~ ^Y3ríoпWk#b9JD%+NՆMж#m.'׻ }g>zkOݕ $Ր{Cd2iY 4Hf5|3FKfz],ݽFHcAeL؛ɳ#QS-SYOҬ̄wݹjKz;N >QO r3Y̬ G*
+
+_,\wi•q{+/_c %%b F#KdŊ:3̈́$ɇda1K%j
+D\AMei (
+
+Q7bV)c[x{?clK4ℍsfГZĞ#'G %yU2tDp@
+~ ` +{~}#}'6XCͬ ~5#[
+Z jS2[UOm &5RFa\=u}HH$]
+3NM&SQmFٕQwE8`'i3BYnϡ[]Vێ?C_4fzOzRoTy$%/(PwB{&4@a!^@Jj)V^bݒ\YLe6K]\} |3{n^{dۥ>KYtK}ʞ{N^wJY,OT!uM[⬄ɑ{ TM;?/ZcἍ2_/~Es ͯJͳ eyŖ6eovN酽:{0wi5O0>!A܉мr]JxvRx'%rk35b+ZA*t#cdKW`((^a\P RwZXGkQ/mWV,-6 w ϓ3GڸMgvE2\ (S gwCr]jH"),V͵aN.ٳVxh@# m Jlk32,8M@Hv;?ȭ<?Kw -uI`LExcv941v81wld<}1Z߶EZcy??#4m{PQQ1m^{<<9:NbGsTB[KLsDuGD=}#B_Vbe;:lXvZ#%h
+
+/Rٙݝ;/sB[El9mW ^zhL
+A#M>]H/NTƐ1-Xm'oN;];Ѡˑ3=9!nIWQRL6#.OWo3T1_;XΚ<}h?V3?>eWutPc a?:ׂ64־#6>k#>k--<,ǗڍlvK Pppo$jd` =EqK}fAZFz@i,͇8݇ӑ=6av[ 8 zBt]'tGbC]S.,5{c]Vю ~A֒ hّ`+Vrc_oX ֮c, C߽&wOn9Y?2ci;5`g\<d\;l^<4`=d5qD!+GU䗧xH)+*U+=O۽a4 +P &Lx]?[_4 Vx.z~Tr{B[\w;w1?/ h*i
+AymhR +$.•VВ<
+f0[L7AWPUGUK4AgtЊh(wT˅ 9
+ T~H
+ˎ%WW}:Ro[DLkeIkp4a_1@wV
+:+y#X@w
+'Gbܾ2^r$3҄ULaUXDa -*J*摓eUב9&F73peZ,Qzh/k(qʗQ?`nj`oic8|ӁӔ4U%$ixA
+ oP
+T3UluI@wK[`>=|Cop!=XL:i j\}Nh x%(E)%ST0
+W\qA)"~GPeHʨ4<j"\GICtU#+^="Osr(W^L^CߐPiyZ\GJyr(S*DWCHסq*,'C]LQ
+zQa>-M
+)Z(M@MWՑp ZD]5>\_៮.f)^A%ݐ=+I %gJ$גUXe1FUC>'o"_TS oi7yi'tu(wxPht@9O'_!봃I56d0|<W1b\qκ)f礟Ơ c
+SU T SON L
+T VTWSSRQS'U@QA9 3Gޤ\Ԟbדmۑ!oޏqm
+g eh
+kmopogffaccbb[WQ
+mrq pqRaӺMFB 2
+&>lr c[IC3 % )19CIG@$3)4)6-;&|6B!CP?\* (
+1
+, *)
+Vבgσ+o͎+{ц.ф2|ы4uЍ;s͗7iϤ4\Ԯ-Rײ,Nڶ(J޹"G޻E߽Cݾ!Bܾ BܺFٳ$Mׯ%Q׮%Rة%W٥#[ڞbd cdgktx}{{!z/p֛9cҦ;Zӣ2Xӥ2[ӡ+_љ-YΩ/Zͣ0Yͣ5Yʧ7Y˨3Z̭3Yΰ1\Ѫ)]ӥ1[ԭ2S״0Lݷ&IWؑiΉ2^ɤ=_ȡ8_ȟ9[ȟ7UŪ6Vƪ:Xƨ:Uǯ=Zǩ;VȨ7Rư9Lȷ7Pɲ9Tɥ3ZȠ4[ș3UǛ1Oʯ.MѬ5O˶8T:Qɿ:H;C<A9Gұ1Xϡ-^̑2^Ś;g’>k4j8lĎ?jFiJiLdG^B^ŵDa̬:bգ'_֥#YԦ(GӸ,Bһ)Nѭ/Qϰ.Lе-JѴ.NѬ._Ϝ0fϖ2f͒1d̗2Z˛0Ṭ5Uʥ6Wʨ7Wɪ6Wʩ6Wʩ.Rѧ*Oհ,JԷ*Nִ)Qׯ&Lٲ%H۵#Fݹ!E߻*Cֽ0Fк;RDZ@Z±:Qƶ:Nǹ6Mˮ3Hˮ2G̸4J̽7Rʱ:\ɦ4^̟/QΫ-FҸ6H˰6Jɮ5Pʪ3KͿG;xfO1Q'[u?J4\Ɯ6[ƙ4_ʡ;dơ>eě7`Ȣ3[̢4Z̠0Zϡ0\Ш0[Х+Xԡ&Zګ/]ү6b˦6\̪3Yͤ1[Ψ1YϬ4WͲ9V̯8Uʱ7S̶2Rϸ3UѰ1VҪ-]ѥ-aҜ*dҖ(jӒ,nԔ+kԕ,jԙ0gҙ.fҞ2cҠ9bѡ5_ӟ3aԠ,iPSYd $0 a !$2n(*˩qz첻l[TZhEd5`! d%lvb2'x[u=C.e5dՄGaE WHɀWW6@T]zr~2|
+_*~v͉oldD[_2 ?\occ?"N^EK %uQE_)%⑚W9ïbr8 sܚ:Z!.pEt)6}VR$xA)B)" KUr>JO)FJUrA :oG%/#OUW
+;ztF48>PVV,*$*)b^-lY]6RG*
+/CdeOl\>$
+c[gwۘt/wW?9]خBJ%#Kr r.Vny +
+
+ r
+@ɯ$0t~#!WT.i z`qtlWھb;SpDi|⇛7F>=2 vɗ2WR^z% UbxPO4?f/ AP 
+y,RP9)u,0(
+1?<2 +tWInF䙧!/% >%SzM$JZ.sT .D:č#{#E-!qj«q*5@`/ F|< I>\؁?ĄKGe`vL_O]~ᰠ ' BѼV@UmAw_p߱V(ۄ4 pA6Brm~ј)M@?jMGXv)fxb@4~gfKrKln)*ea)6\}LV7
+Jq U>:VbB&.&$ EH欃KXH=:IфNoqnrNKcL
+L90,Q8ĭ%8d *H9B`RGڝ.c%< n-kAtқ ȨSl3T.8Oa.ޑG ?y7ƒ5ޘ]| k$!_,GavdivNL{-X3{Ȓ
++.=vCUCcdi1n=n|ZQ5c2?e뢚wQN8ML{؏ ٍ͹\r81j3n|mf]7娃ZfrhgOL#VηX5u:^
+ EA`QE{s?<_yfyo+p; _}L_{i f+4y_3Jj_ѹB]v}41b?:u$F;6Xv5\jdhS*%tGG\L eV#tCgGN7؄͵/6#b˂ b#d
+dM~8@]+eo&6DJhkLK3\~n>]i*3%-MQk*Gʛ稨7T?YR+v~#x]Q'e,=0N^~a?M@5$,,=0?7%8.E E&a`+ȿCHR
+A NFS nfb=l>9윜q75쀞Vcif\D߂N]"==f[˺r:~˩pgXKLuzok#YkkݿW}~A]U>]5Si*czqz&kȄd!rEʫ9# 3?YvE5jQn/oa+c=|O_>/,Zcc)Nj6jSů)a2(sܨpnwsb#p
+>w% 6?$D;A+t l :8D 5:G#V;Pvl)B6OݎHx]8Zz=R~]7i?wqÕ,tP>5YSBh
+I<$ElclBwIB yR<SV͑=Y(;))J3eC my{47]$eYI 
+lqJ[7Cߤ,EI-o|Ozw_`X(&Cu SZSOzHMs;'K#R[η熞EH|m(>^YV =4"LF
+o
+qA)s"JO13p:Gą˽r왬.%i=jxhɈB&6+!'))bU FV<RUyԹSEfBٸSPb
+CIBIH#$I( bBw{ڈG։@z,Ftjzl4D+u/k
+Fif8ޠFTVLA(zl<_9VðZ|Jd(Vq] Z h+[f1w3w \nؿ԰73oޫp]46x>.OR4sՑ,EPZ  'LE`h6G) >s>9![1G.R&x/X"
+כ*"c#a#`>_mAku8 Pj 7"cC>y[C 6<s8iIkc_.])&׆WU&${u]w~WUG>LM9;-f'v۞n$$Z=fO^vz~wؿAKh1M܄Fa^|,0O ?`W^Yդ e)~}rĀL˩؈votv3ѲajZHKͦv/ёV1+p5'x-j}Б眻 )Kz}{sHSpI$DgHG_S N -^ o%&O%$hAy^#qI꟪2TA~zD9,%38]u:dڷllכNz^y&B@}l!HX*zwB49jWOΈK%oH%zQibeHEPs\
+׃w\ 9ՙdg>XǭУڻP)ĊXB,-]]LMф۔#|j8zrByeI$ '0Ws'Ww=wuߍ)wc~r3N%?rf6k]\EM}\MV&O>J~u`O`M?ȉ$m)# +SPKNUS0%+ M
+BR%=:(eeɋ_'A(Z*vZPT7Ih$DLe!3MQQA_H #KUHN
+ uY]6vHLTT@H# 1@_Ҳר{ -Vf[!SVʊBY1./ґ2`w(GQoU14 r r:&uJ ̝,g)Z@KCn!7(hՈ1꺐uEkhK_Zώճ"Ӱ}۶icӺ۷6yİVӭ%E5@ [7࿾{$`]h[f/d  ĵM(cގg8"tW
+yWQL1ʧk-HxdW@ bTo,
+\<ĕi%넸tPl."\N?rQD4
+t| Fv$ 8mb;NpkwmvjtsJ$S")}t`\B3w(aC.ed H|6#QfE?q^2R_Ȅe%\{\Vh~?G^F?AYb+4ՇlbD1z+žT}/WZ(iLi Jn IGt:B#{;OqZ&.{)/{i)Vz_M@NoI@NOy?^?_
+*|ԟ-wd(P΂x
+r"WUI;c5 "Br;(+hDy=M)2˨@5)5LC<@E]JB.r[a ]y66 5
+ݒ ؖmU#+5K`b --%LL5ߓ4c:Dk"]7hнf#hO;/>K>v\QMy3 RB  Deu-xl2;*ΰJH\I dAYeT\\s{g)z>r5I`IZ0to6v]66]ڗ.n7w 47/9j)juC|#VY?Iq Va&XLooj¬(u z-kێ(dtFkʧnpMHV)vEΎHU:Ӧn ;“:z$58{sUs>;f}ε זt-yUe)_ayۀ
+4 `+6c')#zF5+s@ {mBV 0+5'/H쨋b\+/n~#(%UGo'RI:h?VhN
+|z߇nMo Ҵ` r],(E3>STE;ZͩH|RdWpO EE2B`H` @4D(D"R!1?\ۃD x* i!Cx0_" 7
+- YHp R` 25 aR]% Dѽ쳾8/9MM%U-d[8}Ծj ;O]G8GQ/]oݩP<Kwr}}vI,YwlTGg ?&MGS;5.SdmbXCjIc"4V3D '. sVGmpz``Qs*ǣe 3|d#䝲Q|{׳h3y've s}<}#nƂAcgv0bFv̨A7btdFTDw/&ӆn#DΒayļde쥆~ &{_+JBi4bT|RJV LSbRej$[Wc #,ݾC-~ 螺f4 /}g[؃MZX:CbBЍ^?,
+~E~#%C28S)ly 鄪fxWxe0uP:C<OעMm"wyF Y@$sw7kC^Y.><r{K<>9:rB߳C);Ml]!투vR G$Jǡbq0
+qy9ᨲ|F_?gsqz_̗n`ʩ).:AՊQ7DW\GMPjIjJt~'t1'vV-P< k<z˔Se%TQy([\OTE5lf&-0Ŕ (Qr!*VNLR6a5sq)|dJ1GeLe "W{<[*WW<+
+Kֆi8{\ll@ǫvk ۭo'+ 4i#-m#H @'2.#hCjy}FACjKd۰{U8]#)cʶ).x>+k}_B
+
+ׇ%x]z4
+O}so;^)P`v/^|Y.󨦲; @;a K@"@Fq\Q\Ş8cg\F==,T뮭A
+C仚\ %,c] NO )Rx[mk@grDys5Updg@<hAِ!xGji=Rͳ9'dVX:@vJwz+ ҂݈z7fy Q!#jP ąl@d+`.%@ ؑhf
+-Sf-5Ł91`&dE`}o7/r^C\u@\v^󹺼E_yuuu+kWם=on.\B%`]OaG\C
+
+_qeWd?P?@1%+Q/
+LHbrF)5Bc%"@S^(%Pda]蝖(9*ݪrGUY( +c&H\aMi
+" JH4 ) 5S|\s׽XWV]EJi"AB BYI><3߼ͼ~\l PrQ{7ʼnm'E׾v>`</>1OʥD
+& \ws"o3)ywBWƫ{nYC>\|:~Mx5XvXSNTU}sx[` e3}mw(tbq<=o]yag3/~F2zsp)bR8JN4}ry%Uc2L']QR<ՓtO*1'HY:B!iĆfRSî8n fC۹! bAhݵ}\
+LSx5~G5dA)鄰"(ƃqC\MY&}VbUXY'-ǬG>Wij|,HI=z`>N\
+//Wr6A^汈|RP̯!QSbICލò?MR6Em_!c_kD@)>1τ
+$b%>ʪݴJr1E]UXX/VYCL)M{D^4i)A\K=.
+Cܕ)bh
+w1ﻧIzeyghCf2z1"IU!,RUy mu \6*K?#>-Ou˅KFZeŅ
+e%.y,:%W(]
+1<踔 %*0"<UT=,"% _SI1!Mĥʙ(,NU#Uw[[q樸KirMPZ8Jq3Tj'
+Z1C(gP4B:R=,`{zi .=@UM|c4s%migAi-
+7!8#An޽3Si}}}S.߻lv|issbdfc/6Dϼ@O ڹ nujS;+!#yXh1uȑwmc-acl?6Gg9jɶg[mud ^[F]G\޼v10ܢ~ Y%g>ФsBHdD+$J4MMQ, $k^o<dԡ 4j}fm]{fnʇr"g6iZ<qc`'"nnOw-u8kkFk
+#=>2ߐI .O$Fd$IC\±r̯J_oRJ\?=q{zd_tVϝ|rtsh9od kM1-<|/'Z>6](s@s͕{/\u-Zz~o?N53R5-LyF$Wm- RbptPF)ЗOo-fe7:a@M%p!D KR^L xᣃ!E?GjP62u5Lm-jF$=9:t7*E"퉊beI#m,h3S^M&qXzf-zX`+_QTM 55pRA9ܤ)ubJJ5Fj=I
+pJc$ib5}/RZVLPw4h% ):Ӕ- l 54:P"PS6i?شM(Y.,d4ÊCjqR]g`zNU6ɪ&8QJ!!pvTnI)J9nR oS cZ(AFh{4{Lho#0E
+kY˱
+h< Rp`F>cڪ2F&T`, רg+gt3bZ|-b_]tr7k
+
+f+W\521P>.c!BpB]]gJ(KUgH3[SݺOo:J],2^'JKt!EU,e@n ʹm'9 $KJ0I>Qk6nmOm^%m?=WNtG5En~S?E_
+sa:jY
+{h{
+Z%EAk`nB HDWZ]aFفR8{yx~!(XvO`).p&PbK%V@C%]cFHWKC\zTl]س{
+FT,zc<=UKW芉Gq)駇['u7<{B4Y%tڬ<1)I(viG0v(3Nʛ@DHW~k`k=`dM_J  Yht\7?4 |̀] }1~_E~὆8syM_y yUOǭ>|||}3KߣA#+`AvGj`p
+ $k %oi"}A]5&t_~оU#0մc6]'t? @8^*Ln9#6
+mC)J4H*$L}qUڴw#ټ<'@<ݪ+8/$G񐝀58H䋍\ꀒGRa>e9W)%k
+`t:
+AɋR/3dT\^P08=LIԊ !+$
+ҋMs_6&Н
+ kTy.TcF9i!gHDCZM+[AS>}Cls\];g&2?tX-Y ?\-Kpw,m&_p&Sc})
+goz;<L%Nڻ;L܍؏|exuϿ-_ǿcl#0͝FsS3FiӃFKG/,g`,!E*,Ye6aޗð
+4BFBD+SAJ9QxZ MOA.5G+VToi/7j5b^+y̩vrM.^Y|JfQJkTt:yAxO#Wߗa} >lִ &pQ׌oWZhz/
+&9B\ /Uq-9^ZOU/0O|@d>| {*0;rɃ.*pb/)U 7MoÞ? LW>=sї$kWvm-eMow~gkoïh]dtEw ρ}1mïwra|DVE+g>v9v#f#zw'齅={O+ :]
+Bz.!=WUk*A;nS.n.#.#G=Ɔ\]?t8|ujy|ad75ߒ1ǵaL`O8O9NY<GZyل`Zb7Yѷ&dȔf,4u9|dáGƼ8(g9HM2oS:HV%,RZw왁lE@LuY*m3Q6{SnA/455Fa;a;,e*_ Edpd!]![ MI6ݘɂ46m0yۢgZL]+ ]1M"b옦j_d)!f[ T:X皰Սድӵ֑coDqJQJ sɝd^㚲CxAnn=g~}5iN6Èz À4 $~̀
+d%Y A!D: k s0SƂu!OOD )|=ӒM{I6+H
+P.2MBI0t\0]<b ޓ
+c9fEfmr.@ Bey;7wR=n=\, ?Z<#^'
+A7|.ēxwI2 a2% CeҴr@$uuܐـBRixkx[LcW1s͎%=fQōhӦby6s,<yLi9A@iEhQ>hBK-8 8:d:Lj TD9A}# ͛7< +tRAB%22>
+0_Dv?0
+o[ l'DX9#j\Bk +'7!v-W0Mo{ªļ沼XpX;i;BV?;)q>Ӡ]1z_Ŏ' k?*P
+a0*
+vEGAC,dJbe]DU 4UU~JTcڗHF$ˑõz&?[LhsSB#M fJHvXÝA #4Pmw:_g򢲻#Wòꩉ#XQ.NR%&I^8\ȑ &״3 |D˟f
+?P? TRR .r@"d} U
+b+;n)yt`خpݭGv?l?]lsgau{7??϶MKj;gtL'gՇ3T0ҀRBrUU*'}zNUW`s4`(7E_헦+UOp'f#f#L.P<C_VWdhy>YB5ٽko+_́@ zHSp]2CģdFZ
+sYV,{OdxAe\i962uity-.SQKWxlE撼6u.YlQ#-j _W.W$OqR7e30vDӗk?VkM15MM& 9
+,AOͷa]nS[N_-Cm|;^5ʒd'=ȶpϩ35[4UBvHunP%װUD>eß/  r}fMݦSġnk~ Ӳӆayیc l: PNHV(΢TGp=Vna݉ƢZ
+E 볉ih;n.KEKơCtK@_s'uԇǘwu'8jX3[_kd雈 .
+k\^mq_o?q웵^\QMi
+Mr/4&:41k7a#]xlD?u+"vfWPF whnW:
+%O&>v)x}ݿ̐6o3DcuQi$7Ί@dJJ)BA.Q
+)THa~, Tr׉}&Bj޴Rct|)/?y9B{
+J
+*Ua]Q]{):j@!FҀ?JZ(IZR2X`\ElD B
+zPtM
+C7D!ZJ UP_)zY%>UQCN7bġjB4)lAThn8Zrp|*g$ [?.JjHiFb,#;
+ [^B(+!_R']egʋItY1(r|?CUO'(S6ᓇjQ\M3>ESMqԏI@(&|GLP HUCB+ǕB/^smGg
+0u?`?~B=s[PQC_;Xt.m;u#m=u=m:]y*uS#W~~zuGv]-Q`{}?V_,olzՕ{⓹ 3fڼOx '>H
+q-ÓQiQ <eR2T_|{KuC}?(Ao%2EMu;5;A읠s
+ ")7UXxS|P4u˺j{C}A-Q+QdP3o!e_~ O
+
+-4[gK1ߥ$H9NJD:5`251;v.bj\hXLqWq .Fbek nrFJ>;4 NՓ
+<J7X[%;w9N@6( ݵڳv&p0mNo&H7ydΣT,gS@k8;l蜝z1Ft):lDPY.@{@{'谥o7D UEs׍`D7=k9Ak?Df6
+9͸\NOnwvGث`5r>* :C`m[DL\lHؓ:r'!K@0(% EIAQR /%w9Q|Ydu.7t/]=rDsO?rԣ7/7.~)ڪۉ+Mԭߔ.lf/)Ivr,%iplvZ/Ѣʠ:̹֠QmoDK X&>O3{Y)I<oUޑa9rD̋㐞t;R=Inc&VelP>Oԃڣf
+;
+VO
+ +-GgwRcFQM¨QpbRH޺o4Z5x%PR];ZOψH cMVB,42.W*Ie~%oU"Zq??>NR(Y7jsYV84 ֖ ݭ)6^F;[ qer
+HYCSN8\? &zQWol5uGZrG;b3:S[3@AsмpDgdXw\;>k2F頦jbƖ84eR:9iAY.V6[#+-U|SgPSq.H ,= z@( +۷ot"H@R$ RBIInBQ`Q@Qwpܹs=3J4SYH<IX3,z凰>F χ1\y%h
+.馬{bUU-&y {a;z\
+ORq<dՈrQ#_k{/2DTHqR_ LsTyqGCv~ƈ0VGMxNGEXFG 5K#{ AP50/I''IIypy&AS=hhG[1a@3
+!<އEPVE7O!'g-s=uZӵ+s{$M\YSϝ!:d/Zb,9S%g/??}y`q}叟YRb[.kcZsL3&/C;"$pBAll5.CC(J'hN|c$TBCE@Q䓯,C]S32\Mk} , WTň<埾yQ)C1'0>PO
+;~DܧwA} 4}oa׷͇s  5G[ᑥ}9V¤ mרknЍvНNkݎ1ؕW'/t:r:p=*9t@^f:N{ǰb]̑Dy$@I!Ⱦ@utT:D! ե ]85k6o;og[n=8q_nP?}Ґ`Ug(z$zK`
+l
+-C?ZC}*h˒YhAp~23Q=qoK]^q&#VwxEuh#C^T;x7|=y &o#߁踿nv :i{ÁdlԿIuWw<hCdp\šKlL'Nc
+GM rU?TUR[)M+54!  ׌Œ#dۦ/퇧h4{O?EGa?:??
+zV>-(U A
+]cd?쇂?Bf߇YDֻIڃBeێ t_>k>2kCL>r 'B\?>ھ}7Sc~.OCBH`TǏibΠQb"8Dr՛'RSwo$<ZMyg%psq͔?RF1>dixD1SԦɎT +GC{z{bF|bIew#Ip%֟jE"]lҰZ 'B0b'Fle&q:L
+p^bG#y:_L {+7ȪX*sΨ9۞^4BMs<PI uR';XNN`!*Z PKN=%X'1KػǴtk9 UAI.-> %IbLGAϵGKS^t.tN
+KрDnQ蚠Ţ#6BlW1-TΨA1=!\W'8V;97EMK2s ڛJ|G2݃Lw/$r 8֩ơ:ت!"xgY;Efo?ql&1%GsF< 98
+Kzm ΞmΛ_wZ6W\
+N.Sn(g_WF^W\)mnhd\+߼=eUlc}qZZ0jrĒڹ^D点tSsF f Fn8Bם?@-ʯl7ް|
+rPsF /z[pRũ'P[O󨈉蜻ig{pu!.-6.V؍e?^}UxMe`űҗO˂=m ͜m'L-9N%)uQZ c͸G 1UO9"Jh嚽z^Ab//']F #D9
+
+
+tHˡ?A=nUZuoy J Zx*(% \AiA<D<PQ9En K5nvf=nNgv36k&//NV%
+*QQ<P<>iy<Lnz^&&Ƶ[Q%!$`#zD8*M
+x׿
+DQƒ@X@ea@zd6F4Q<Ir˔߭݌?
+
+5Q kLRǩzUx(V:.kL}}&uC*'HoJ~y޸#Aϊ0}%:7gpm9uV>?珹wQ{H/MRH.Zu3K`hL<fTW?AEh1`u,H_i1+ì0mxCVrZTC+75^k4,>:< (=~;dCkPoX<wF}oV%|x*c:S>EV!Űgz仞Ͻ<#nd"C bعk.`=Ċi3_(ќ#UHPZv<ٶG9 ( 5+A#L>6R,^=8ӋCpSLۄ8d_"O4
+&E\`Fĕ]^ҬIkeb> ,0yxB DFi{HBc_ Fz@3\gn#sr
+,=A; m@%Xj,m|xLZ8ӛ]7ߚsbWyIYTzm&pm$UMJՖR(Sqwܲ沺^r퐂.2șhNɡ&BпiM+xR)+r*j[QhQ2G*@y]I( m'x6W+1x#K#Hsd'
+ّ[7ւyg% 0ޘsn싳sN-zTtC7h|4|'n~:rrzm:X%_?&pA⫶;-
+ELrOSRR[y):^&ft7p2{d
+F h'qN=EJKQ%mrf7)F˺&['DRdtTCI Xr%V1@WR5/Lu%]U3e itI=弤>2WT>*0 ?k)mDޛ CZ`(JZ௠
+eirPPuxP 6s5T>d)ÀJ7З4Š󆫠ByDS&Ksy3tzj#45/<PՃ5=KHλNtUoDKW(ne
+_
+n><OF7 *qtsag!#Nӵ<2bHD_0sc퀄5b.6r!o ><:>l}p#4䫜!y rYNw
+&#cS@to {#q/uPڇ}VC7!v\PgY3=8EGo{"8*Q-";L ec!fB{|XV;<qéw4aO,Qq׮wј91ucF
+J ZE+63
+P@&Ēa J24j[4s |~ AZX%{.qg@ƒ{׬3ڀXNW75͂ɮna৩)p;J5u@s %n=).`ǫZBb'ZãG/vG\ꎊN| N輒1vQ]>ɋW l&);)vfEآ1V0##vFG!Z##5H\F1X-D49juJ53m$
+25wՍȄYrNt@60swhBYn\&U)ȚdMEyjäբwBoV<GpxipD)PQ
+r4m`Tdhe&#TzVk*aTP)Hd+CSʩh5Th'IB^WNӗ1:VB I5.;yJMt)D5#g
+YW(5
+βN<q:oK~]<o~Q: f`
+ۥ'nB++ʃ5Up|?T/W5
+R)
+10LQLOɧ9!Uژ &Z>t9H0bVXۂŋЎ,cħ=22y+g>G>|3zbp`'ԿQ޵_rb֧JeH
+1['}t^J⌀8E3 BGHv
+@@3h&-!yX'8b
+5߶H
+y 1 !ujYLֱcow::\8rI_İISHԒau6'+8JZ*!,wġfGEΘcMHtSf`)O >%
+
+ǟN7NN=*`t I',SZZm-Lpk W4ڄ=7(^s~Vt>2u\Y/-youdM<i[J{f=)W!d(t!T9V\^66rtm\]#9K">{)`' 2rNJK*&`
+e r؏2wZ?gju@!9l䃭~lUQ*t52Gr~IWKbPZK?ʇj$^TU3/+o+79U۬+I?q~`~!qU3R^ͼgW6Y.Vo`21Y#D&ZU*}BQ2TQ gYs3Pjn;o0z/SM|\PMTn/ j28R( D $!RAEQYaYxz;7{/fn^8X * K$( !!o3O~E2EMe$HPĂyVcV԰Ne1ǁQg5|m呋g{JF\{N)Խ ׿"3TsA{J{(>iKԥ}fQT5@UVыU(RW@"i&^ !Eu9P{UzYUFy¼~V[N/0Tru䬑ưc!'9B/~!}ø {/=.i*kW4O#uO)EۤB nQtaRMe) XWFF7:<𜜯Eh(7V~{g7<=rR[ETS/~ < dPӃ#W#oDqs.>Zy@)i@ H/)ɗ o4)W&!#Ļ<4WO-Pto2(eW(UZBI7r0J3Sg@-l cO-.:7֍@pP\PT2gX&GgCGO|3 0;<G,ё-@)H*sף=ktb-oh>_;me|#iMaiT>YSޙXCpXጉCˢ]ڈBׁjWi>e:VDSϓsYBq*,8I^eWR{Ӝk;u\<uۇX޵8DrVMt?mr__?T_+zx vGH`%c]T9ݹ&@0 1Fj"%88i$:Z"xʦ5ټ'VtN <
+gMY#,F$lÓ"$[S9D (zgI9}j/ot]HX@Y5]9@uBKo;488یKǗ^߰6Ehi]7b673.T4xpkn䭁k2A&5{kwf2\\ae#$m*+cX#{h Z{=
+U+9#֠V|L_㘹wbÕJ1e_[OGxf4+x=Z>Q)@xBXT:k恚lՋ+۸"ϰ:7#M!Y#Q
+8Z)7]ŕhEF9e= sQ_-5
+< Ѝ7 9dGuaaArVԌz)14˵Dpl<TȷE6~$փd, <amo )6,Mڰ
+|Xk.Py>@Z#MQ6_C]6b5*3uX)1`vY}D׆/w<9Plʳ ,鏇=f-ՇMB5G`iXH 1݀[07e*ULXeb/؀hny'
+"Ʊ&Љu" c9^o-3ՅVk/ګU3f"Ն_݈Z*-et 40"p^jv#e~{ArZ}\'Z%@ϾPaدݫcr (&{ bõ<:yx"W*q΁޴amG<{?y؁Go-9Bݥ;t]#~|o{7 ޷k\!:_S%nɎQҖE2f/f> a/e=ߏ8e^ ;dW>G>o^A`]F/|p)p2{2jWHM|IޔAhndp&J\$Qh焝8 ߔX2Kd"ϴoj%w#05`
+(eS `Jݔ\JwKNp.#&71 P7dDNqsrX҆
+؁+uMma]/~zva?Tzp|-".A!
+Μ>OX<T\Ulg|T=dk, ԝ_;U/;~5>GؗBydvO1n1ͱG=X/vĽ0U
+|mzmy~( K.|4g!ߺ~9sOv/<
+YX
+0`;> ߒ3f ~Mla<pofFx~XsPϝvᗯ|,mٵlʺhkDU #cl͒wGG( j%N;HLT?KNxjqd2CnhGMmd} =1%?h
+8B7wZ[1%k(gmFf[1ɆxGtU{T)F(:VVX'C* KR#l(6gBTIir EfDh5@u^j#ZS4ޤΝsTRc2
+K;NJJI:)ou"bVDJSQ\ |BC+HJ*7K /!i
+忣O/P\fV(k&zay]|rIYU { By{tuWd厶cƻY'z^FFDx.#Gb+5|ÃF\h<2LCDQL
+ !Qd>.jc DsRNM5>ik&bB~
+_+!f$PBʇĘ [/2}ZKFe8zRbds87̙g Le4JG,ըJӿP*pV u\[c0Uaǡj%'s+"5\P 
+>bQLJ)~Ի7%Zt9t [jn 𾀃V U>biR:
+U'L͗J ZËm'|> -dlWhl";݂ʅ:s+mRS#|1:Pn>P=漊q
+}v4yP+Q$DP5dlg٦;;6f96ͽ]MO bDD<j<Fͪ(n;μ
+Y&@C-uH k`rW8o#L[܂rz3xwU;I OV^vۏURCN.'FOYEJ V7rDVk:!EA7sWqJπ eTbA{9\>=J^ Y,a7>`@#v0%;ta[f|(ߤ>l 8@[6w8REjU w0^rU÷Bۅorl؏i!
+ =O>+nAh ?qj5]bp`=Ƿ6E.DY{n.T{b0eh%TMKw)@ʯb)엎{_yn~ ] W6|䔧TP? P~/y
+LMa:;R6AuoRW B?%'bEΰҵf 
+{g}Wܨ̍W_trŽL1\ IS*U:EGYJyeDEh4FWTD(&Ur<#ao) d kB-vĞ\k,k)mDϿD]l+
+?^w՟TQ92T#|͟L,ZŲDMq0sK0Ab٢Km@-TJPZ#MRf%5ʰD@|ѬHw"7Xs roM gz(!h
+.4FQ&+!lb> hERBe1)zn11ڲFPQ IQeTB¡#ixřdYVߜuI~>9ݼ&iVLk:0fuC<f~E.iR].=v\&*Ef#Z`?,tl9@ qs{
+c
+%pgBcu [0y`
+S}-jSjhǖK/Lϒ%ztn>b6j s^wu6泩Iuw~}C%cJ1F С9ZxI=F}t^< +90
+[G #'$ !Qp93]wgv:nZ
+r
+KЗZo>nUSw]jU\z/’!%bN|6JӌVOu||OTS+Ʃ yG`,H%;ꛘ単:ŷ)lqRK)bg<r>W}%eG),i|L1_#醱EznDa8*02 a h40,(+grL=%:@Ϛﰟ)˔r`pe 6EUAssI{xWぱ4]1EZ.[Wȥ>bgi8pLvX:C/+U<x6o?e,o0 uIӈkZ5E]sL _m&^}(z.:q0
+v7E
+N 0>`8=QG Ǧli+>f>aKAN6|΄=>J 3ctcӀ':
+)p @`b[G;-آhgA" {-i 0]lv!a&;Z1p-:$>!tV
+;-Z#a(> Zfv;go +XfAst=L~9/'~i%91'i
+&e|曏*|pF"YhXJ)$51ֻV>臝þjy}1/
+ *YPSYQёE
+V @nB BnBHDyyypjl@YaAB$ bA+srTs~#\tFɎQQ!Av!iD 7M"4ZJddSY@jd
+.F-9춹!C;h%cW~}eXɼ~Ȣ3#YߧW%+OsNK~:S,cS4
+yRj\0N dsݸ&WD_p&܌q/cކmxon;;k5Gg^NPvԵuL&Yҙ6&mÄ%z<A|9 p8!h4*YiIVf
+rNT/+w1'KrME|7ۇ͙}2qu 0
+rUM
+ؚ)VB 't;qoYI2%JyR[ Qfn'Hm81 nD֎@BĞ| wy5cFn(6?"vH(;^ƈȶ ̝z͙~|mj85yZgW*ڳectً6LƐ7͍ KtHYj c LHkYҙD=D`
+u+S4rXD/UYnf!UlKi㔪< '_G 0W4!J
+|a,O*KvW07-F}
+f"hFBU{T$25C|PBPfib<DrG]O:M.>b^Ë́r/mΡ!lpt{("h(/g/=
+{#oM
+&'ėqRS3trx$^7n I`Hs}|W_L'Ջ)뎽~ԗ&lr_ enYe$ 5#ĕ[[rpV#]m>E
+ХVF(CR{^\hl;'P}}ҰO6 X_9?,d_WGSOig.މr|=8{V60w_:X> @?`_\\r\ta7blo
+kହì V^[a]۔MSp; )ݎDlEzvpa#ي8 ڌw!d?a
+a,Iߖ1>Ili2 2t[ HĠ"zAeX5k{
+;{x,q%!cաcfhck|a* pKǔzl5
+7hՋ)n1^"= -1c \߽_ꜙ/̤뼱+e?}9$+TLs۝9~=sn×9-f̵xsfZ<|%{燕⁘@ {i> NG$0U}P )EV
+K11CZ"mx#]}tk
+0P))פa'20)9O-$gʟgK+h9'%'bߥh_?!qմtY}hh g=#gpĴz|wM[tUS* ]UKS.sQB_zE_y}췝`M\/)8%|ORHPy]%̜N Im8OVK͐S䵔43R).MYMUOs5q<ڠ&$DD9n붎;nwm;jwZ+"r(@8 ys@p/;?fy=HvRR,>wj7:M==;%~ɔ JV)prdk#k"*e[QEwc.r/VBƛ'?|I]DAD4KRy5LQK;x@>LS`傍93jDRL> rf2"*HQEɗ=dݏ(
+Tv ߐw,ͳ"xvbWK]Or]"yCe&Vtnvb`CVY`eVb3vTo!Fz@E0)ZClj;U͡1*i#^%xks^% dS+A? Y$,8n8k6B]ҡmr0*[fyJ"\e6v|%d%3VY``W{ܒ{};N̿M뗸9;b6EFWp#kpS+?9ORQOnd@9o@nr0=ƌa$I]׮qop];|R:SA)4]wp#n4
+㍖13 R<?;c?qn N٬Nڜ#,VƮ;gT<BqA Ԩ 15L6D c3~ >^C%{ Nlt''ԅJǧjI >J$CrZ0*0Qi7ԭ=UO̝QeԜzr9$Nuc5B,!$H *19AMuBWr>keEt@S*6CHȄZBbOa+E\%|ubSoUIM̝*ۆ&!~K{dlLx 뼹ZSw~s &s fMtP' Hg☪2m5 f M'̹Vt7{Z* ƕWjr!Pza #*p2GDZ˃0P6j$Z b}VROdO59*>Xt"oeN5sa#mɣaɣY#(D]0Y2c$M9#HTΝ*|u&_Mዴ0EǨǘrZӐGҊw2iTZZ6wZ&`ܛ~4\٣',TVAaO
+2ך_C OP50*`gB|d;J=⟔y DQRW r *хz;Y<NXl_nհ:qQ*֭aիD{寁6aCCNp5^CENma416}Ug?0#4Y7|v-욝uR~Bֽ?u]]8[wϕ<g//_.<O^t|UGöҸ4~=e@ϼG1-`g( :bx7|o9l\tZtZ><X{0G1פgC%a1$hjNݴKxIqX6)7>vy I]'60 PP䰈!dZcB‹>3ԉ5Dś9mrןN#bpd'9a'ىBFD8 ol2Nl Gl N؉c
+@##A}de(GB{? @ meW.w};8 ؕp vKxm88e[C<s+mp,s6r',4;/^
+,])yTq(I-2\p3sIR^
+M5 E(d
+@
+%ki
++6T(ÅB̹mR
+ub4`cs5a'WOi/7ߪCWgJ7>(qkg@- seC6@Md:&
+驊Nj\e; ]>UIHHdU%uT ;졦)EPJDQъM2 ImTS*DsX nGp`sL-R(n\%mud1K/= 2*gO 2g>s)!!
+}esHLދz^]YQ31ZpUtw]P>QWoM:e'W?Vc'.R~1U
+xQ#f5"0L
+'ɍ8\H#@ =wbB뇭zO16 w֘[מ)Xv}fBm}W`JdΪm_EzI⸹~겯Ҳϛ`YM zQ^>8 2MGY+mG8d X'9LcЬ)S\wNYԯL璬tf쌢ƜlG4WGF 6HФ(Y<Suִm؊܋'-r2W_gѹz}ߖqE0# AdVS甲qM~7yˇ#<c nNB.C=:ۣPҁiɁ% Smv}idTc&jp8K7Ȏ-
+ST$܍4u[f{,iH`-%Ǻʴ1.`؈t̀>8Js{C6yVM?J7#M̓d:%,Άgl.-c*jr7;Nh3ZKٹ]w͹pŭ`-wխ`:*j]?j|n|ʟjtrޗv뿲e7x|v'_?#M l3c[yg
+h_ }dA0 a$%,bM
+xtF/*sw+_~ЎP\TLc˧#˕e&0"OBM\6(k_“EV`|cPɛojq+oѿоw_K_xD,^6䍘29 w^QQ) ;/V!{+%TʟRȳSvT{f xO|`GO"qG2kYbP-s'&'ˆ‰h BMJˀwpwసl&yE<39AgtA=]
+@6tԆfCT؍ͼ'Ie<E[TU s3Ion0;,|W4݊/k) ̙c橚BK̈́ekTlWXfgFMKiL^ z4qc̛-͊%cC4 L:*Ǐ|.&izLڧ﫱2*،(h
+dv%mV1.CVhCg3
+@0#YdDV>kAjP{sJuvw:7G&d,6@VF'͢Elos僬gb'|DinL H$- 3^s#T6ًOdO /&b\(䈆ɒ1j+j! bKE<WO/VpRIba PMwĽL05GIwƤIzYָ|~ϢXb~CT!Pڄ+6GZbJ%͔J93bP&]\3~/K^UC%ӘK?J~?p42ZID]! :vΙv̙ٝ=;gjf^24, WE.[G2E׳sxwfgy~ x$掠S&!YL3w OYNSA(gnC1f
+y
+ hSlxZsQܰG0C '9,c $@|<B,T#D`BK _>Q^6~UVblUct/9F(Wb?!ѥ5qgé#<2SK*Ɨi8&4{z UygPBmzlp75ʹeSnK";oܨ?8iAq0f>K<c>)<WEX{.nsAHoڱo^/?r
+cڊY=#og 8j AVX10Ikr[X#ZIn$HVFsZ{h?e@iK~)k}^)?K=m#QvGv CL(nHvy̩}QUHhTAe
+-u|y$mIk+eˋΙx' L@ZЩ4S*yr
+4{F-$oB(h}
+ 1:A.>a@#;Dg<(_!8T
+4Csn
+@cL\Di0eJdR[$(8uȜjYZX3<HT> WƲL j*ҶDu͘"}+=A E wSOP朱4h`lG؀3<{Zta o' 4i8=
+x6Mٙ_6$D1x!"oTܠQUcsxD&1>w?{X< kS~6ɪ HQK7FL"B]׃,y4.07XƇ؇bZ
+m}qs~m eLe4?EO~=;j܃Yy;y,oxY=ʮmuo/|r:9!ɐo)1""P] M7"M߆Lga@t@ $&Qxj>N#Q1:)&^CW
+kk%b8VG|/꒲ Pu*` j1>lf"RB@`egUG1TH@Ƒt(<05B< 0T,m#{^lqpRSTUG0ڶHW5S?h5w2A}3쀄l {OX:%
+Si5) Ӽ)@}cYH)m !8\L6
+k᥺zD5ⲡÙ|)1rae{opDkjѩbcآKs˥H$\(}Fr 2.DVK<9# #JFj(C C;o$u饽J -ƻc:>3j%Z[Jů_07c*H;q+#w*uɪHWG#_"eטU?*EjBX=yҿݏ-5D5Qt(*MG*~lF֊l-_
+*ʑS^׿+TCr,YSU^T{¦}ݒ؍6f{ևZǤi7}\7jkC
+|d-߈>"JAo&gI4cv0&řE Uבcv:fpU'\bbb6_MZmg
+RZ%vKATbs,Ƣcěm[ 6zkj={]tK|"aUl\'l)+ N}~2k3s#{w1=nߺ|?l޴~ֿ;ȿ/~L$k/Ngܨ邙i~jǚ$qv86x_,.št4U@7$w٨5'+
+@#frpI itRL5"^CW&Ƞ!֐AՆ2vWi)=@]*@XOZdr]9%D6x]ː\Y tjgMhT
+X$L'K~ə"G[^p @cv]( `rr>}cF$ <@‘p }Ƅ?<4'(<WmaP
+1 aXw8WfلXT"mM펷VC5"T
+lNcG lmuKvkn+ގvӛǖVl?:-oXY7NOcMLj'X 懞S!ERxh^m} 5؂c 6cC!1Z`WXl'1Oi'&IBmxjKBZQTG>Om`Q*eψJrx^QKNGM$QXp1N#&2`jT/䜒gkB9*"[#h`)DR#/ⅲwਫ1Jy](^Ԗ\(%)Y:JXG!
+Q
+~ąq\AMwÒ.@BŽaI(u.3tNg۩ӢV+l!I "@ Kz?<{>y^܉Y[b)lYBɷ6n=Yu7e?\;A
+[g{sKzxYL
+آJ H3,ȸ2ҖQ1ޔT6"l!t1=O,&f:EohO yڟ=䛱;M9F)~+SLgc cQXHRcj7S-Q`ge3yo=n_ᅳ}v }$x)-D/KncXoh2B˨`
+:иz>P3# 1}f؈Iq;HuOtggڑ8: 3ŮwWRN*6Bu+QgtQ7`[\ublh8,$;M2LD4R Q1E$O$&(5dʼx+>f~FdZz]: Wfn^3Mp%: seL "ζw!r0&ù
+ۙ8։ȶ3y掠>o[miA826Bn, ߓei]S
+,:Up^JvYapH
+b~@
+$ CPlRxN=Э&}[C'@
+Fq19 aB,e7>;=;Y(^O0nt:7M`O_/yr/*'_6]6 nm-<KNwBܥ?{j)\+Ul
+(, IIHBVYА%{zuc^nl
+ z3%"׸5NO-AgWW=փ >xu4|z;jrF:X.{a?]83rwiúUu^s\\\7;_obLPHL5PYZRLZ,gXaP,6`hp'>eXE3c
+O$
+ ' ms&`@!ضȌddikfN&a,e|h≥ƧRcuT
+-BK Rbz.4@0#ٶFڈ(0 =Ո"SXx3Z+ܡ
+J:2E5p*+9|Em"_.)˔h@V_M V%ҋ;/`^x*) hSoc={KzkJ~#>{ʻ7U[_75屷P~yDA[N(zW?/+%bU1o 5㙺^J5Ym!&, ι@85ӊz,H  ЄTo
+ |[5|+c?F"5bC P6rQ<0:hIHS8C2j HȹR/"uÞcF:HnB//AmAs鸝#F^SyaWuPo g!3 )$4($;iSXހԵ${'ʅsGLGA1> s#N#_ca 4-zRe
+۶n݆`] kl lRuc:;iK7^ĭ>D{{-n#;# ujl;0xB3 o,˘cMܮjC16Mh ӸHtqz
+NڒLW8$}?皼͇"_;0Nx>u[`49%:qrXBY,2?5sWraowgtd<<rL92_Q7z䪶Sɿҝt'.ah/?*
+%
+̝PYe-0oYk[e)y Gv;t\{s3*}Cɚ@xfoN'T,~a
+z$a͑ւmc]3Iou'(åww|3cP*|S.EOAMGyzwL7Gܶn]G.D*W'ӿTd~ez%?qT;kFrD@BBs?=
+_
+/N/'/A_A
+x'W"Wg|W0OGX(/97~s!A
+cDB W/kjzQsc9V4*XH.bֈKX(nQaJl0?I2)8$ iEG[G
+PבD$
+{uwx]WpL(UU'I܁:WٜWEBљC
+
+K+1 q,pv#λi㺘dd7`mFLUesBk-kJBZ']1 WF$E6Rhk|I dzƀ
+@998.=r6G0&/L+;/~-Ǚ>mcfI/@(r:#3ѥU1e@ Y
+@ΟpDyϚd?f腦<W=Agd2F&;U
+S/zemGHB?,~87#Sp9 ;{O{̓.H: b
+L~eؒf0"}fMpϥU⺧q tkjG:-o8.1}X,j84|*|)@kD!PU(iـd "*U"'c
+k{\%LVmEj~WSK]x/%
+-UW͵fLwdvdDƒd0gzi~NTjZڙ_3ٕ[='WϴgV<M)kϨ̩M>ɫ<ɭܝhϭg5̴d7̶瞤5w$W)T:jMFLGT1y{ekRSIcjx8V2dBQJJEgVX'X~4хFn@:w?!ä́o~ |0pgH5t;35@bLb"M.RTId@.PB4mq c dmPb20E&x-Ng,NF|^NWuVbXvЋYơ#5ƞ7eAhhIwRBy#7O~7K>_0yJz+ݙE~%;+DLvtkmՖrK c`fCׂap@-YyC*pY`,LN5KT0C
+Kf<Ql41`%]nrGr*-Zc MOawċ
+p9eLD] u_~_&OogSֻk{۔ k(xtsB^ĒR8~xy
+oY Yő8P24iK]mʂq4qp<
+=JdGCYNrO.m1; 4B_/ǜxv Oz?Vv
+oUqk
+jC,[!bNbV~l|I~K=j|E a7'PFLZTVTǷփڎ
+X&3}!&xgWO֣-oGx<& 8u<heD_#|oP/O>Dwv<{LFk%TT+Ci&db"0 ˦9t(8H30ͣ;;@ýp/!ZHz/xQQB9:%[?DLՃt@r}]3l>Jv`oRڶDFL%MI9BuLdbX R Jzq3 MRsFh+BIB̴RKtmJ!Ҵ2EZz (etqriVdTR$jm'}"g#,cAJ}O/ `
+C< :߭BGr܊PmI<gm!U9 %`Q]]
+ zTHg
+94aZ~Bϵx yFIlj!ט\3
+by⚆ A*LrH<IŖ=ZOX]$Dܱ%2qP~5l;nBWWB'mKK(*a@1s+S\Amg
+ab#}s?+[ R ?Һ 'v@Lz-\Fk/Y̟Y:y/^x͘j{Z`$V&63۾V"=şLBweVQauY%kJ9trcJwmvXmី3H=﷉]T+}|EYwh:z?#[<>9G
+__sN1t f8`6l=)|o݉vndž%mn_5]+Uxh_#ҭU?_Xldw[io6:093,n7CZ=h8 jo:pB5=I:w[&n;$99ܕ
+J\ Ys-کejlh^ؽ^~x9}{BkRG雭tC-o<lJ>^J耤9&igmf4>KI;g]OŃ g㎯S./=<zE6&
+]9 쎤
+d
+>9_GLiCVbh[ A+a{$h"Ӆ5pA_/ $|&"![G9X]<LJ5GJpzlW_eXPI}Ea }wrw<k :I
+Ry7Rљ\lLW4ꕍ*5vrL|X!p_+@Ճe){IʘL)*mry70+C$>&Vjzq01Ջ*K#;V?lIflOOokJͪTxib 1_39).K!xgq (P3aFQlA/UW\4S_&$P
+5fT"I37 l-d=LJ:(8鎑 ܏a[c<0u<l]JrrVĈ<k?؇WNb\8aJ(u_ʋ(4r ͱd 1uc cVal
+B\$}T?CUe {QOndyO֮ p?`_py\)N#b7ڗ~oGQWlWpVhFf |1 #Y[{=-&Xq&w):J4Lv\^L N_O?ye슂Y[</ðsëV#Q,p,gg ߗy$=b콡?B |,{Va_`F0bO'Rvsԉv.r;o`FkXz_'iyҟNҫeTbJ-$Qĉ)E5G$(I"6/Mdh%Z WinFԘ"\C} 6|)ᩦDׂ7P6xg0,@Eݗ^P~X]^
+Z߾ HǓeN_, NNTI9 kƅ-|̃p:;w\}W9\5 ~ {nC]  pn2
+e5,bX>A]ڜ8(ncד|(jgw LQe/J+U,oU-X)7s`>c+WAECQi"\I= "=-g g&P-;xqy5\nA*"PBIh1!4uuOwu~vuv]Z-DOPK@Yѽއ;<~{?ڗ?۷snS+鲞/70Հ`ω y6tgvZj:Z8(<wO4wxKw|3: "M Gg+/'pqz%EbM*\"0LMv5$ȕU⊥ww/I'^JԕѺҖrrmnw
+S X^v{|b||6Z\ 9½_8[8qd畇_ p} : uC:Vu#ȹ㉚j)P>BTklX 5TD-;. eBļx&& Y%MI̒Ʊ-|U+>_ESs4 m'.sRe( AB}jSa!hM)!t1d!'O  %ڸb3%z>H[4YFlJ/PIER!;.LJR*w'xV>!LM! pL$g?]L> -  "*1љV*Rj1<s94f
+?4b\h`ηȟiBa 
+"6
+CeYahD|P腘"C+gG*Lu2OU.TU8jhHEY3%k#+ZHY]O)ztS*CϔuдLeCS]O8ė$~;̅᪔2I1#i@g>fvdTBY 圢\KURe5U_(M 7Sٲ2WрeEvRRb6lJ R6$d ZJ  I%\ 6XsD16SuHT
+Z;t\(J=R~
+%HQonfggnogvQWD!Ђ Л4Qoxxxyyy%zB8>˖/e6=>b?ȁ5䘸6#b6ϰY/
+؁ sIHΚ7MqNqʖJrlHZ--t{0k>9;]hOc)66 dH׌6}{,וFi?3Qs% /|+'FyicB2U6;БIjn k
+_ H}%5"<8GMX"y{+e?"tCyL>OwdNOdZx]\SGE'͈"#lM_AGӽ8]p7&ӸtW-I$BSl>v}=u/;Wc*Mu2 T Ssgò{ͷ0fKVɴz'9oI7*ڑguD ha8`Ab(zA叙3a88+,E;LH!]|hY Kk. NNT}mաG/J9IWk:;Fp``*2W?n`~T_<|-_}h?w= '|'!U)/*k+[ȫ[UU 񪮙RBWүyNWg_?.Νyb5:==|{n{i>cv9uq 꼲~ije~ymsuckcm}u 궴㵸
+T*k~꾰*a>b jތv@8{d .0@dzyNLJ-qVA*He{ ߎ$]ƕ
+}P-ף1d `lRrPf<S( L
+._لϕ ̈́"q#L@,b)[@5:0Ų\T)tV1~'J_DB^ TJO_I:rG>N,pr
+3;E7gذ4y;&U 4L},$gTY)RB&R!B``EFq;gϜ9qUW#
+"!I Ho~{P5Y%$&ڰL;4[><<G9x~.1CF%)$Gtԁ=8߄*߇f)*Q9ʐk@e@*ϔw|;uv{#e˓626څHjA߃_
+(? . .Κ,sa/TP44ز9>ג}Pom2ڜKm0vpmL_59 uv̭Z] y2eE$pOS~YOhL}#&W_՗gU,m *OYE
+0~CӨ`ܰ?~]HW[OT6gC(pbFB}p?< 7ߟ.bΕaD[6Vm!mݑɘI!`BR5=e"mJ٥اh_[ae3ssLIcgwm"p~`-irOeks^\Tb(s =,rQ ]FGB눳8Vc^e&|tp9}\jw_N9$vGwFvDtP6͕{fWͰiOމi:09._;fMt22Vj]kq["}uqy1y6q25Wq}R±? +Bsӝ>F'f=}.uٚfhVЫ.Ys=s]sp\8\{цvjlll7N9欍::NύO8tAS\J :Q)ƅ$#Da r.YF+T04EK]@ಕ5UXpIr.)]ZG`KXTV|e]X&ᑴ.lJ#Pˤ~  {V`v#!hbp^ijvs $8GƞJMOf }i {,1A)A P|3Dn?T_W"Ljey"Pj{gEL:$ m{@ @cz "';eǛ2In"Ow u1&Z<?8Ϗ> 6QFx~1Qsahڀ] JXZ bzPA Cԍﵥ|U 꺶uS[yyZ~Q@s[uCr4ըlMmhj,} 1܆O
+P[QMQN!lZZkw(-ػ-o,?ȱ'FAɣ문UbAM̡؜t$M]aIX9Ł=?DXK6íubx(Xq 51p&urD>P z8Cρ?!su̡B<k1pl5c>uk5L/ (Y߀r̒lVGɧ]i+ۻrLKl3꼯^aOs2k}ٳ>%sB7^? 5RIJ-HZJ(P UT*T!1(k|+"PTqg4M6%&>ro}'zY[B.q닔GŽeE iC lQ=?
+!! IwN(Yُ T09~ c"KXVGހ}$忠/BToE&Oi˟a ӌ=ۂ6UJuPHI<f7}~g
+[ޅKycXCi!2}נ@
+Z K
+Rml=׏=˘{ś=cW$
+אJU5A%ڗEZ\
+W#L9߶gc;EGǵJg-m]mк 6*}zM
+
+x7?)@d\(CWpźr|pY_M(h
+y/kLw(oq'`/Ǧ>\;3m]Bxe1
+m[]]}CyrzCs!e~:zec~?y鵺7!+iv*܀8Y|;|,J0[Csft1
+1i@(P/j1R5]5@NЈI 1la0NtlދP ʁt )Ym"UQE1%7bKe0k?אm+)_[Ook _ M
+|*XI(2VE&CVtO`iG&;5 X@_uB&
+.>Uu?򬦏w3 D> 1Vrl_Rߌ$M. Gkd|?0.ʓS
+_y|Aihr380,N/B釰̉t<03jF 4x85
+03L/S l. !2\,(ðLbS]t TCp.X + φL7Ղp.x;9Sx?,$6y0kF
+O3}3
+@0ySj,C\W T@}
+6V/;{]
+<  '@(HxG}V.sRX
+K5?K4䢡HEPWI1RI{@7c8'x, =d=<rcFRw-K~7X!L+AP+:-!3c(/> ޟuu>6s~챡M:ICwNa'zjgt0 oGWj; b@QC 2 9z$lt{;6<b6{[J+Ho[;)3a;*'VO#Id`8(Ȼ. ,6A0L:420E?Jx#"$8K>hw9;8g;
+3W}ꊡDT}襏A}6&uׁ5܅:d|թlK=jB )9,BE|VfKr/g|?qs1F&_\R rKO
+WCQq@S˚jP&TՐ. 6S.ZHG OW7Pό|QHT/κ.{*)Q=1D6yv]lb8mu;z
+5O4M#|fP.:I)̉Igە-s!C9~(w:l0<
++ u7a_jFO?|OZ/2W۪2Z\271-1>LSccaS8q`pdvc`;4ڿKD5e1i#M7o!rpv(b_
+E|X:_ 9bGEX {8[9E!,b&fgpg8%[Ҧ)PhɆ6loŃ=z*}1X !MΟY-C9B6!d؉:CXH3[zY]7ӶZm>$Pc/*丈6{-ikK .,4W2V T3͉W嵜Uv]SKgP9!Wv.Sy#y+$d`Y aqc+CV"e(ǬqŒ/$`ʗ1EG" 䇬kK
+Ri\wKw7deUgwҿ~o}?|Hy Ef+"ҟnĕXnp)}E}z[$=</c xB F?4GĿt&`?B
+K8)+i8i;gŠ ,j7eBL! Svَf'
+cnȟZK|II7TIrmh
+͝i!fnR(8suYkEpMXt6"/քP-A- yp<k Rzi^X[!=iBLU>d+Dp!]
+4љS!%2beDTX 9il&CQO4ylEZ{pp6n& <p/íq(
+d7L/R.6(5> o URz C/*e߉rbTTM(6
+-
+yЋp=v.{='6]bnG`?^&{9d:@:.-8mͻٗMȝd7{_ ցX4ǡݨQ@C\{?1φ/KP4ӉKF,M\l#t_X:SH52ag}'jMz \f=mZ8'* ,@|%*Is`JeS+]~]_&J.<‰!yӲPl_oK0)6&&4wp'6s-\Yi xvJ*XO}韼.2cAQH#pMx%yP?yB_ 2wx6Ey_x|RHZ8?2
+z@/Ky=t*vg!".fW
+[7zYg+}}WmOr= [X<qf vni1{Zԡy0;4:P! w%nWL@{<57(i81gΞ#y_?:{'f0|NA
+τyCv~[Ty~0~e<
+f/8K <(GFw}Jz"a]ף6 Eb2 )l+ O娄YklYſϗ"K]\h+G^7>oߵ?g_74ii~NU)lZi#J֡‰2qQ&iq\AMi A.
+r\&4IsN0RͰᩦ{$eSrN*2O"/4G)Z9yjumM$
+njg Q)\TV
+N泊3yJآޒ*V7X)Pv';d}#c>5p| josO>?>9 ,5YAA{8PBs!wr4s:wd{k!KG&
+ e<">C+FC<g_Dع/zcOJ7ƀ[zw]YkwU^n],`
+@lmGIFt+u%@p|3Oǫc) 2m!vrUt4֎u&Z^dEl1>XyX*"4B߀~
+w;츮
+"UzIHBBB
+H=gw9s̙b9Pnػ][ S9u~aQqumI*3 JdΖF Z('<p؆5DX͏gӍXaF5 Dg9~s?Ewclyl@Vۡk=߯d}y{zȽ̥hr4s;ڇ0tKX*sV`)`4FoSu7DdOPd5So ]з= MgBxWCن4Π.j' r)|;eԊl;f=854}ӿgeRe|?q$P!3ă(x8$$ZL
+'H": 09ϝh?j ~CMwGe:2@e*{9ʶ|y#-ŵRY ObC@o_/p -9vG#]s֤K㊿a?IhA YҹDc635 E!Yx!Y_-04ie/K8!NĶJ0zg)73{Ǒxq.Qxp)8ۉRG܍D!9^h6}a(4.JGVA;e{1_-QQ?²;¢8;7LFHq 6 +m̙t*ǨJ/J%S+%Ojl w8
+&ߒXh:kͳQ'tc3i
+zI.Z¿?~?K^X>"LS_}.Q*?Gߑ`oZJuHxlURB[|)t x7inkCYڠgM5GIq'= ^8Z;/
+kPlQkKJd:$ofm \kѾxozḐ8ZvDߟ@*X5"=ۉ a#sj;g}n5"x_/#]U[H{1^{;0nn8{Bw=6?@WB]\UHH-V:ͬzϬ,,_紴hq'Zlʟ1< 5- R@R1@C)C0yn8I=Wp39֔V,jN+cHje&KpC*$f%hz
+'`F" N't1EH&t2tuO&>E^cbe DYr_[}+ GҐ’'Ṫ<UG*Sޅ-wCј)Is9.*[H=҆#nNP/'VZ,c_t7n~{TW$ Tcjb["
+[#A*n uvsl.3YnN0 &\[dMS]-S}{
+NS td)?RW%)1yKҀ.b)YvI܇I(l8-[OfdLSwWՉS+ZƔ\YJPq qO*Sڑ'}/m&G[E *j%פrJbw?ǞaK9mDr(_ae+TH.;sp9 "'@$ UPnOtNg׺nu*@r}ł B$w磺G:x\|LP>UIkYWF1ܤߐ^=ڐR!k51ʚSxRAjO+TV@*6Qρ<LR~'ri~ukC7gUg\lȨFZQ~jLvUU_Z4G'+bm\ŕ
+DI/U0 cO%'8F@㪛Hǔ*>BH}!+V86D*(Lk| ?XCd1ؔT1ސt&̠--bs kh(!˶t%䚞
+L] p-|$u}\%HWl?RuEJB(:R6s$
+0NOF35 ǻ %V >khqvtQ.3`M$}҈B
+'れa3#_Y
+^Cٖ6׺峰{ n3of;v)>mn~{;+$2+96i?onGڱl7>H,83'KێB;uv,EB]
+gQ\Tfc&:QgIQLDKRل tJ !o')#.o vlZ$
+Ѓfk: iaJBBPIT @cgS9i4 $U"r݃BXSxcsǤ ZEe=㒲^)
+p,xkohohoicVO S6qЩpԛaz;fY>%"̶$˧$ɵd2@2e6Ud/p#ecGz( ;\Gӷe! Ƞ!$(<0g#g"_,GL,e?o<95~5>PJlR4;n7,9cZȚwv !siHڧT#t3D؂E6Ah9./!8/r"g,g
+TӃ l%ާAd?o*xj,xlem|
+C<8T=q3.@0eIT3d>KOdk&h&
+OH?//J~JX.Ϩ&4eTP+J&$)#H/ $*Hٝuwa "RDH$4 D@IސBR d`eA2{9g?|y=#IKiBb}\{UWNΝ$䩪ŪJ|"N=,L[a GmП[l\tls/w&*C E7G~
++QTPEdTD;-]&
+Oz/t#4O fϻ="ie5bn/ߤ8N:v}aӧ^pj᥿a v~UO3n/^;;,|K. ˨/݅#(';[{qzsRp:y0 k̯l7"{l4樫Q,#JHh.@Njd-NC8ه "%}Ph+`fNt2ز^( QQt8qO12${ivpڼ^" ARj9
+*HlU#"*JI7[J%k m8
+ \ IK7
+T2ž-
+ڛ$i%T,ǥH6 @LwHy|XJ it+ FOТ%B('T /1#n.iL4sǚ
+UW1 k7$VF6\̑51YN@mtGbIWdP|UVI!?\T;g8MLq  D;@b<ZΖ0zzy}*HTQ,, )Gz#j~=Lw!\S) S2i 6^'J, 'Pz䟦jL
+)NbpEHHVUAB8a\(%Z/"z, _s|G\g'2t%zQ &A@>,p7H g.X
+bm%@
+| D
+> FR(%KP=Sz.`_` ɺ.ʙBaӹÈ=$^Ȁ^d@BL(1bvic~mdeơSz1)v^u<<r8>+<}xGFxoCu9a]^q̈5`g?`^2mMؘ)6$n RS wp;!~[aDؒl"䶡Bz@uXm\5wl
+Xxj_L@ ;}3]]쑅2Ub3Í|:')PN똉:z\CM4r2M+Bumuk|bh!![UNJQ2`Dċ*`D*pDrT^UtծQGG%|'V>8<)a=~VTPp!-sϜ+=~r+EܬbV`!~`"\w]Vrs!0[͒Zwnnar .-z @/ux&dl1Jvr+'NӋֳlØösNs(@ͻkvKNv/fS'-h3㤓Ć_hٺ[rL"WkX|x˚<("E!UHQO,RKGIzr-~ ϑy!O60"EMq++i -kg+ziQ|d=6VSJĉr|Pds% -rBKp(
+JjV&\BKG  q1+jOԱrEKH%GZ
+)rq =Z=+jc
+F.3DXQ Vf8+Ƌ+91
+^#ETH|'`Y)RVX!(d _/'iQpZW%/S |#f9hBrE*ȧ&, =\K0#NP]HY3ZVG.
+(*J뙯3s:sZu)
+"2,BB7y&FHk9s~9i oF=c~?̟!1@8c@"kutJIcRj g)Iy@!%窫9b֐UP*whRu/+۴)nP~HҊŲby|H"kkنȌwO?AkeVT2
+b咢^(**iǐT
+Tebf7FY#fV<BU9P;
+v2u8D. RA ӤpX҃?Uvh3yк7rhd8@4ۣy2BEA*׹N"+.4ÄcDM؉C΢md @gqpaSLsn9vH*[cKTwҷq굲]~lI8ՇM
+ς3O<2"4{ّ̱ꎜ5@{qj>2Mۈ;ǧ) Zf9P;3X702ohVj|w sbJ :bOjuIw׮I}& y|$Nk#RUqUtU=.C&k&[n6_ƏsLUXP&fk^@Ct@ 'W\8-n` pO 53Hk(U<Y59[@S+F ]*hrNW2x}y{ER϶|ekGp-rvvڏd[%Δ ^E\4M=C^&쉚0!
+e~ֲX9lb:6W{.U^.']dOV *f}
+sihzޱzih`WB! ;82W~4N4
+`"h|f6j12T$ uFna9~p&]dúɟ^bRq8k:F(cn#[cъS 6y/4uڻLmRICWC xR(L8/|~c%h|N2;c?Dǀ&"#P1dۍf=
+^Q$
+oCa+
+P~?*K ILjfg0*$ѹI #K_.cTJor
+! ^Lͧڏ[("(G 
+9:$i@㌫"
+M*Bk+3X4ƨpݢr6j PzVcƪ633m"D.t$.QqeH_jn:RZ(3UH;
+Pt6\l8
+>ȼzԩWKRO,vK<=d{(@Lo5_:Ch% $GM.y4 mb@lޯO<H<7N;.'Z̀\pq3qL(2O<Nnf^Vei6p"Q ɬ|.h9f%WbTz% ,&pGT:#(1uWS$A)0
+ZD:<~ޛow@Q+{^~SֿcL8L)$GJs 6džp }1rF>(USe a=LE)^A&v~ ?XYK0E<#יּRX`*l7h3\V-JTεT7'V;%buogSFUMp_
+| SfWV.rWmke^@XѾo5!|~-!mQv
+q68#ySäc/b/'^<Ȯ#+m.@j ևC'Ms)bݗ f|Q/_Rɖ:JLj%~`woB1OgwAziyqkTh9%.3kxe-O23u/+k}⍁
+&vljԮm- 錒+iW[
+ N-r_49~-!c{ "跅ʹ}4>^S(wL dl:M yqb#7OC#'2xp{?[v CLbw*4m},ݒѧN;B=tp)nH!w3!wxuNz6Bm6#&`̕:@ѢODhxyj'.+N WgTSi׆sD84u SE)B
+ゼ/{/¶B
+vت}nc.0]cg`Z쎡M@KRIoT_OLP{ܯ@ϱBKH-G/D?G<}A 6/P/͋$y3<2}ϲFFXI#0
+{?9:g
+V~7ޕEW WAB@fCNͅM/N'ZyaB6L+dtTg1*ҺLe\gC`=߼;~I︳U三*37 r$
+M$UF.|[;-.'gۤlc)SrpPOULs=EٕBVDhXo
+RX蔡.!#;k;Z@f
+z A3dr;PY~FUK>>;>ugzeO\W'&Ջpybu?@zG}FP`Hvf齃NWF {(W+Q`ov;5DN(<wSqWe7#A2z)|#>@n\n}VQ*r"trX{d}wTIHQbNhf{61-GFφ<<XW] Rv'G1j I$GdIG
+'ʸČ{ən'q5$hz.ZVotulF*W׳*55 1FvUejXں3 H硿Mu w'F:Cm)%*Ij`cJ.Y0 ;E߯8^/;^V6z$;9Y
+MR
+ mB& -X`C%<X`vAh`JbLWeD8 Bw^t3q3\[TqMdm"[ZKgݖB׈Z@ ]p+Mv8>zlz𫔙dڳѨԉdcTGuiCXʘCrZ@Jbڵx38lƶȉ4{7gUV% .ImIk/5J6R 
+MN ï~;WTGsY+ݾ3tCoxuaƮ$u!IƋKT=Ÿ.edK%NBiw
+s[#9{|]!#GP>/i-8aA<s5mIZý1?|2t{={Nm?>irș},LpeIܒǮ$o3:  _<kQ.7>4A3]C49via"Km1,n-,Fy7cPUŠťe,ڸR<+t˨JrWF#&=eaƁj"XI?VG&InD ߚ.|8r5
+?
+B/|6
+U= {}m-RHYo*ԃN`-BC>oMTܹ!ySZLid@q9Vu+ y75O(T[hERx@J(RJnrOjFy3}8r칎ɶ=("=xd@ 6e̚zohZ njT;6醨Rct sk)x)d)lCPiD1ILJIJ3%XB˕dd1Qчe^GxQr~]zOq5qQ6 w @"Ј P鶫jfjaem$"B$@VrodQ@@s|UrO=ǹ@t`@
+V2ZO*XUzZR"M'3^CESl+n(UmBE{5yGFcAIFPѓRa]T}]E.5H(:T0:zTK"j
+ZJ tSo{@g@G(U%7 jŽ ᐄ/֧d <x9S,H/wqj\;$dSs>%O ӯvZ.46bAp"c RGз,^ޏ,o.@ĊPQ&hN'jۛ
+S3zr 25f܀Tan&-_ еGԙُѾ8qE}pIC{:1gteTJtw|_:/xOoȗ.s.(H}N̞#VNGguф=~` %&
+${ ǛbsmPO(LL!44':OIyZ\
+m<SF^eY$ x¡iiCۓ]IW?Φ]R\4,W(<
+XF?Su #ȝqci\}!h]sO//xNn?6m MGGLotO#H^YRN:oF}?f~m?!r>MoYO z!`
+%b'о2USM5tU4*9C3tG*@(rw͜T2{
+PS,1_e;f#I0_#BdS7&ML1\?lM/tJP
+)C
+H*OL:R3 Uj
+S=@9t\↪ŦJ04/aEJ",cd*ct] ZeD+'ysurpMR »' nsC= @.n^\z|k')ِȳtNC s?5 u-
+r䫵UdkHR[56-vFHjE"o;B4Y<]E# Bo<.WBH/Tq|k#Ǫl : +WfJX^?p/1E0~O,p M#L*1%.Т&;[c #+`QS3_ZU G_i
+r<t,hsZVfn 叵Scd!IfnňAMx@lehLjƯ"p%~/.M-4QI*ۨ|HF6i"HA[edM (oH)yVUdQmh 0+c}خwO v9RaG4.DM??+b:ɹz܎eMzSMaYB, ;-ȃO#C!?&
+TOA7(IM΁sCa'뚽짚}qAšCwp4ǒgGM7r5CQ TN@9 !$䀈"7
+$0?[Lmy;!cI9IB5r@FqmG}_ϓ9
+n@&!QɵXC?<IJDJR4/=']|MvNsK4q#i ZA# Y`J,WYOExp"5Ҏ0iLK"ijEu
+ӎ s i҅< U\{x@8AfvNp?K\{CG{z= •y8zKr>>n劧y61sW;f|m=RWwp~ןŨ{?.u;;~UFmj<pZè@m iOA8M8C<C(?4K1̊ 2ő/CŎ
+JS%4eg{#
+ZdVby^2~
+!WÇt+Bfi E-&C&&gR2b
+]L`*كuq!!j⋕B?X^N(T \y%- @RZCє
+edD@,+4P2u2'$47v -QU4qlM] K_[+th X?Gt輡rcĔUP8J*SROaI)
+S*N;] bmP9
+H_&0eUTHɓwd-ykb@;)WIfZLuilG6D_¹
+W048]bx~$Rk~q=ãQ\fQM&V@v¾&|Y Q 2t9=gN;VEe5B,)}0%{JFv[PjZ."_J_q5K4[?쯄?HO(>J(rFYUUbbOJRItC}/&M E9IiMS~,g1d)X9<
+la4c{ׅ<{ךέ7YvI=<N>J9t۰L 쥆
+*le<Wތϒwq3וzۑ֑";Y^V+p_yS8RsUS_T)7'}*v<ɆUoL?*7ϛ{<ҎSl hpn'D0l'E< ZIG"kрmջC x¨#ʾY'Sve ršut 3:
+z/-t8-{ LQoi~wEaR.~ސ'#8-*;ھ
+0I
+XX\hyZZz8Y{xO]dfUa,RvǽL+6t,9i>NULOa]}ⷊqA,V%
+%5P>#kb3 SFyKTE-}f%9t[~G]hk͚<&ÿ8S> ~#tWVAxH }zRzF^5Dpg ΤFg<H>|/*1WޜҾi7{Xe:V/jZ.oj1:g 5u0`;3IMpm<4O"6%aTWpM|WЈqS,B7i ]r qyܽ\[]fAMeiW[meWTBBVI!($,! LTT<Lڶh
+ Qf
+P tJ+i2'+,C3:CZ7>Ϛsa0p#X|s܄.mnaZI 5rG'P` 0ބ
+Wۘk'
+[ ifY.D?:&G؛L@EU#,8YLn%U)ndҥ73rM.O)酒s.v\=ijUX*ͷqjw\83!Y&܀
+c
+R|I6n~t={a#}ms"}f_yz̳Ճ$ \Y=l
+}6rvaمU kn+̻D~vq~m0_x7^5K lb?fC5GEz| [;t`
+磾ڀUhr?yxp0mi PpꋾԭMWa?҂":u1ԍ5rrleyαtml@dR~u_$8I2 t2B>лG|, f{™+␜ey@boP“ Ax3:؃øL=ox}щ' mv{Q6NQ}g%WuQa<CB.T6&*:i%cL.h4{/<!CmM؃+17`LP)a ЃL˰$`bB*k0ҡc^i҇4LpvaK-ЂIQ
+] 1V g#C{^wmٕc]˧_
+> `ew7&{} W/iM ;>
+J>}?~L8xJ =9a%$7<2}8|z)<ÐGÖ"fQݫ@_Mi[Ʒoa?pԛm^|2@A=/f JKaם<1J dtY
+Y0(2ȷ<: ?Du?;3^u9a߀#coΛso/u<ݔO5؟iRwY7v{QۼkʭW,4/1ג$TMF]eUhe5c,PfI(U*bgNQv$w
+@]cMR@lej\\ar9XG-@)5݌-2ʘ%F:|^ Uρ᧽3s0BS mSfU<wL}iMI䍴uy6Fϵ.5et#/Ff,?zwSc4J
+ma
+z+]*4n`o;~t'L @<Hwg=m@ZBW%Ӂ`2]QYxGg[0_5Y+׀4
+ ",:]sdgU 6=t^1v$sGL#hf\m+;PXf
+ B]+w!x_k$\^/U2͉5dp;')14XӜ$VrC`2VF$(D-M4$?!s$M` xUx-UQq#|]GЙ 2hjJxD_M/Ճ hyc|*<-ԴZE87Ws25SGӍC4S1#auNmhtި3J C괏gQ&T,dWBe1&ރ:;g#ȥ %"H/cKm0PIPMru\c#QlKuhC\)y8N{т.oʣh'vvxK#Z|ur!%1 2` ̭EIɳ7v5٦:R/4ב
+o]܌6^Q
+n JZZI欄ܧ<N2ysMV۪Z. eE}ߙ_rrrrINN~/D{Q{-~+AH?:Ѝ7$|g\ ZAxw`lvXPu&zG2)&'n[ۙ YYHVItrY ½40NpA^\٤O٤98QxlG1ۅm?4sK fzvZ<J6[y<H!-h=f n`ˠ5+ĵ
+{8HSz}ڎPKxb W0 =moj;gQx 8P.t^ 0{ט9$yg+ktoX 8-_;yj
+X
+X|^]N3GISg[<LkEuX8陷ͅe] .g1[{gVLk:$yQdBK!B<'!e#"@֮uyh>@z&ͺ~ɱɱw$Nǻ )mֲTyto3s@@Z D6LuŻ,xX7Sk%?a~ݟ}4sOi +ҟ&ߐ~!z@;0*eiCÙڈji ?Yy)oIOEu gk_`_"߅^B2%ŘGdNd+kO*i64eIe)\L}Q/\s{lDb*oWؽn9Br94 ,`[ў؄nxȤH7^
+{si]t[,XBt;
+njW`+r3DZ|
+e-~wJ/
+?GXzB,V
+Tj!@jxVLшpAb&K1Jbn:jqb `'k&'^0,E0I+QR "
+؃6ZEvP +z >kh' X1A$㹺x#khy{%uDZٻ3'٦~BQH7
+|sK<w5blNDnĄI!RUa*!5o&cgߌ[cK
+8 RS1~4~
+WiŖZQEF w 7
+uFrBh³W]PJ5rb\G{&II`n܈*67(TmDTM
+Y"c=Xw1]n`Ccʧ>˵OyMB{5b'd/r2#BR"}|/Q&BRxn
+M֩o^\d涩ųN ڀbțEfjZpΤ|3{rgeG{6áa_J\ӗWo9T
+v\OJi#b:EMp*[Pu:w=<[6asJjDPvSҥdH/֋Y~Sڗ–t8.v32GRs޸7х5> ޞгJM%ʑ
+DWzh$E&+]z0 =?\ǤxZ}@rpN. x2Ձ Y=0Fa>m;vB,C{ k5Q1]uÐ%kQaLľ{dr=xqZ;Zo<ysxwg u>: E;=` ʪ?q}؛ܝq0N;zv<<1AA
+`,S?[_X@`'$<!*,pZYBE&IۉE21P!MUtM;Rw:a槡Թްߺn.u}'(g_Ɉc٩?oD-n{^N~&oS\${$WNfsP0/x|>k׼(Gm:[J껾KIC>+Ce4:NJԚSRHc+1S0vkaƏn`]?B<-kݤsG0@atЋ04 M@`x  h˳tpmCp
+qa<k)>"Lbu3:x؟54R]i=~=y-AtKd*Z" ,y9K81fFMPp\f8;N~FV<% 5T<D.':
+a@<XAV<UZ1L+țI(k.k [aLK3`XpR{P{gj\_I@*ԃj;
+ҚZzJUK[|\0|BV5~ˇ󻡎ƃP[k1d2m=7.M;zC6xYݮvnG9iQ#~dv\C3l`ݕ3;v{7l^G}$Q7_^;m<|AcAs3ݮY=/%mqݖ%쏺md6v(+bau@p"Y~]LFp}k/.oy̜߆Gj'WFm=F#&];
+WK֐+y}ғ,<xUd
+*;ytWwuWuψ72BozƯ]
+ñF-*zL"i it-l]sT kdGqU$DHgIkKmLt2{RC"2~QD]QIܙo^7o.'t:8D0<~z/M_泣ɛb(k;M}?~Nz"<<I#"d@N3!)ywBDLTc;,0*>
+&$'k~4K4<Y+}ge UB2 PggAP
+ Iց`$uA ;7fCYَAJ0I
+u117 .wؗD•˱er5Cg
+uVARy*4{gHƜ"
+A=] };%kLHT7!p=ܱxx7(曅DEَ戬iљ왶
+_ǘRݨ[Wc_<^Gj|
+Ο(md iP%f 9E0{s@YlmDVk5چ*L1vz}S8B}JJвY
+ ^{cSAbmn_J#8Nz^?>ܦ%oKv0W`Yi4uT2e@$EA76??'5N2ǚ2K3 s {s rr8t29Q^I{ Lӷ9-,`/cy0$w Y愞[J?AN7x.w[yV,PD efZ))|V<K) Q]ċ͸y >_T(&ߩ}aKç3XdOOt\uDM(=F]д@Nx{rJg<9=ܗX@f 3wh87wiιg=i޳ܤ$>AN"ETLMgh֢Rj3/yɩS)7sU FX4NV9d'ZxH T I6}2xJL[)#3[/(G>Qy` ~gpYN=2jTOP>ȁ^mo.w.qf5gwȃ3wepٗcԀ\៤3n]1ì|jo }Q'$JڔSm $:L?-ck'}c{!Y }K_f8>ɦSh8,yq24ei0(iL}% 'F B(uAt1DX~~`P#s"D9׏*ѱ錥(i"0ysܗ~ ͙A+D_
+ЭV|uP0%SHjРՐWAVV!+1GcBx{^DdILYV3eO8B5sic'RC韸މ<0S)ZH~`;I5r&^-ũ$(JDYTCv 5&JM,}<a~`Wnɿ4ktqARJR65{%{C`gO:;2y+ 9"9.;wә#-lAD{I^0U\}d7X̟*o$rM6}DcSHU`_%,Q6VmhDV)o"Jݎ̫ԍqWu4܉ v]{~MV,V561W3pN=i r\gQMi
+[ щ Ad!/ѧ%"tsb_l_uK`lc8USe ?Y'WDI<USb5D#M>FpnjGM-xŰ X^DJݯlKs)*dR c(~sI;g
+S,M'TB*Ѵ9\ݐW Rr!pSyFJJBdkIlM#;q/P"@Re[2
+muMnſ h\
+G% WoQ[ޡ\76B2vZZ1<(
+a9%1`|vxPv|.ހDpTs<E9B{Pы L;1p5ۥ1f(V.,lt4gh9lsH ?ߜ
+P뛎дPfcyfxr2IP%
+a6`Mr$ oE:1mp"M/l
+G3<l07Ӵ
+j4bTqisKKcai+'={p<kU
+^ |% [.><2:uֻ+k'.@׆_T|79(A(h"ԫKw>Jɟ
+'%&Kۖе'(Zi6̙ϒgΐ!4CE75.F.}L0(ųhU-06R5C$rs\AMyAEW)ꉜ4@H
+H]P?@ʊ+.専w_|_yf<ľ -]GG &_MH0bOBRI2eHa44L#r3r^ҩlX5󳠰®0aOaG8BmP}"HlO"[[
+}k=χ<EE7nN 2|H1O(7"
+,rUٚJx Ӕ،LbJ>PHgcM!lq'=NC:xE7сKo :-U;ԵY3-TswEg_ )t?"r
+h2!'Nts]N5 FL$c'2l2=lh@tž `ϕCXf(\鑩/nj~ 532OYpyʊu'mʻ<E)񦼘X( ҇ I%#0dy9EJbk82>'}H5!c<a3HutƑ<"sWVF̔S2ŵ,Y)KD牫eLуPpUxP3=kOUxC[\E`KEмѲ룥r2W Qp&P|(5\9;LVb@+G4t]4EWJ>F 6m-q$xCY,tD1++G1x&PKf T&% Z GTFTV_ca+4gti%-° cYͤT?%is:*ϳ@D lı&(ɲ6SBIR#(UNNUȩ.h1_i DL 䚦2eiC gG+
+dttmNvڝ4v2;siԨQQ(r)!(FE<b/߿?y}|/S/O5!(wKg3(; ޤKWw[78ϼ:G=okR
+"Gd2 9b'Zn8}:r
+#;tVQ!| ,r"N(ݩga(9d{Sh$/^v|<=Z?7ߛ\榖(
+rïC4`k1u2+:X彼>/)( bL|?&EUqD<ϒ<0ds0l?/˗\M *zYjjG&W+
+'/Fl~s~@[|GՁRBdqcU#)Eռn+^~ZZ.-3+L6z y]\)"3 .饔I#DJkC5aS'άSKˮ
+AmѻƃcuӔr6y.fJC0m"0 w,
+0ũt9 IN9
+C
+:?WvVt0CT(&+c%Hy ~E"ѠH&TܙdܫH c"&[T"%W?V2OΎa(C3T̬%? ƒ
+Lr(#PCqquڧќ|t$*PSkL@+V͈e\EF1pnͫP-%lz%·|v v}7k/#S"QA )qc,
+̢8e~ &)}W暓fQxHHVg 7sojFgxf[HM0t[yO|?zQa9B(>^p4Z@d"G8o^f7&'~tV6륏?=|ۡ0a
+%ݑ+/ߞ{K
+=rBs/"%IfA@Z)crAB@em[ZHB\j(aNz)ƨPk )}jtL8J'ԁM䋦
+n@J(0h|.cRFt#L*4J¼:IW-5ZVh(cKݒ2O =TsծGg#ՊͶ\ZE{=ֆxW帏*@ Y U 6JRr$?$e
+ Jz9J T/Sm̈́bE]8C+/vP?L7 yf(BJ'Yd좖(BP`L2G3+93rǦ2ggK<_KWNhm—O#WM5'VL52*
+9? is3,X#.)eSH}8^<Z>qv<_ x<~;z8U_N2\v$ &Z 3դgXDYC,p l298\sZNmM$)Pt4pzJ(>xڮ$T_RWwx }!v|,5S`Y\哴9zcP3rrqҏ3R& Zs ѡ>Ey=rxZ!R\tku[s7 [mN1``F?! #M~>p=ܴCg;gC |O?6~7_r<HdE)B!kvrm:$?NIwX7Jg>lL6GtyE5\GgXE"*RB"B
+ ZBDeԝq>̞3(*+0 H B*iJ(Aݿ{ý|' Upߎ
+]ܫ.>wyr'=ɫS~4 1<
+)|{/3 m
+ qh^L0jCF14'Ba(ƭȼŸӬ}ˣO¯IW(9>!an n r$˼㵸vxa t1Fu5y ~ƵGHO
+Qۘwvl>p>:8u}=GQ7Ox'؝o 3>hGiD >ד C,cn
+8Rdek<-|!X7zAG = Y ,u7 -53<C${NfNo
+#hEhT݃#/h}zP"O7OSCx086g+có\X*g|`=:hQnVA+א+^TU#SW܀Wh"Ϋ~EW*+ge9
+ Ttc]fɸ  .`JME|E=*gF$DGȕDHg7:|5EZ:qUD
+ÚFх\mr :SGbLuYFb'j&21 !7(;ҥZIDAو2-^
+7jYU5s03,M
+aZx9v=elm0M?a.ͥ\*R4c&GM53+'#ש>j^#uYyɣ 6J*A,UsPl'$@|z}6t}`FB L=жaHl<M#jГ*UՋJQN ]!;)&c+dH1. t ,_ى`ކC Y|t
+xr(6TZmMS۴?LTvTce'"
+(xfgzy}_z7#lcn`AUV'5d`o
+K(27#/|E>T;&; Ź)kh.itסxG@nO>-;h''8wo ~!N B:Q`6,9f8w\$[8vSQ{}.7Һؗ.(m#lm3qEqcRy!M&kC!q؞)
+!.H yY0" -! iKF{Ծ>t;- !ԡ8f?7ӌbKk1ŝ㋅3
+5B[&U\[ؐj3
+9.~6CN̒HmiEzT.D]lN(6`Ey-&o֊}nvFHR=T[8_Z4_}4{}Hڈ(6MٙB73D̼>%Re#SW(ߢ8Rmu)m#oӱSC(s>)ݧ5`6qsح\/.ob۬b&:[@e .%-9O2L*sh|: r
+KL:( Y;)odM&<MЎ% D$:mTt{~˽!yuLq* E_ v8:hpAj
+Bڡ3-P /1+˜\ nE7A3,
+Z4@æ&GV 0LlC WMC4/$Hkme7ye ɞܹſVmSe-ceO'15]rb:t1'эb8i'
+gdZ_y}|qub!ċmi ]netg:\ܙJo'u#:vݎ}m
+~Tuze9SEؕ ~SSʘwQ^4(!qy, BG D3i\ 'KDpMl(Qo'O4F6" ho^!뢋fVCtWʳo3KѯFmfK8`7EM,a4ʣ5e9 AИ9m緼`-ڎ/#hN-Ig?`ڍ
+#Fƫ_n!9GW8?3*\AMgkH ^BE HoZH$@Ewwױ.RB JbBU)D]QT0ܿs?fNpy9ZOYvh}UOφ/J ۰(2EUA0:DƲ ,]- X{SD
+wJQC͗WJ?J (ˈjjV3TE*L苦1?EЍȋrD<@kG܇< <f+i#JR`6K^*x bDzjψ6$.O@h!,[-@rЙC|dL# љz>>SNPwPҔ"G#$p5M<<QisyLB*G!rUB2K5@eI (4?NjBZ<% KobJ$rYnJxr
+P uf8ΠA 4hB!Mf$bDR'TPҜ*
++P^.
+/_s~WǝzRu,GӳH 2:
+lfHIS5LA(
+wQ%MJD "dm45, !t;I6CW#op36y%Or|
+X
+ cM4{'?iqK7|GHxkHޒu~nzhrfzr2 ۩eۙ%w[K˙׎Ϸ{w`]{^r2頵C߯]ZsXxaodtq%磳/\ξt>:
+ cc%mXqSď\te: ij5U㓡Ҁ)U"B}zBEy$OU `2T縺N¥#h':){ mW733ށiB{ aӍg& ruWхr4u#&J7R95t%]^92h'_U+R"U"UTc25lTp*E)+J6&UDHQS
+h70畷`2Tdk*IZdumHa;)"#%ȧUӂjz@=mCN~LpqQLb
+e
+c%w2iC&{@bc #J8NMduES17HRO/ɚrOi*^pO̞!^f':$l8oRW2^pa M9difMWk#Ϗpi֨a=AVwT?ɥB5CnŎLmx %qL nl.OIK$&$ق(=4QtIHt@ '6YRrWWjZ7?)ߕߝ*K
+"%]NҹRx#6j(EL "Qg[#QԞqWn
+I
+WFy0獂0fpݶ3N1ۓ.ћcQ"瘭A(cc!um}mhiwL~
+N>6KܕlJ` XxJ>.ak!g֖9vkĨ+cCΰbt,ϛR#&_
+KؐUgȦ9lCntdS&|ncf ã? ?>OpRo$Ox'_4V}Mfwo˒e xeBp`l3{~[Y[8d'jOhqО7z6;ÇxeN_D3?7䚂Wn@n@ m6j\Svw@8:W;AA#V{Z|σRM\Oڄe8{T^b$X<u'wC|
+d/>CztZ#,{W>PY|i!Bq_LW0-KJڟqU? ﲛeYދc"eѦjR (F1fE@Zkgt@n=@W)
+u\\׃kC {I
+5"fFDuQ^)@)MM7̫̕;7+RZ 1{jfe٠Y$!ax!eM*T9+5Fqw}#'0o<(BP=_oE@h*Xv:?zݵe^*}Oyݗ?#TRI,ߎc3;َ4qRϙ(KAEmp.4eZ>s*mJ}=%eQn$wPs4'kF,܉K6wi,!q{0,x[j}Pf}.>DY* WIJk0*GrpSfsY,
+C%j\đ23i>1#arIlY3ExZ`kH,1/20ZJlU@vFq6x\Kp\;;Q@7{~qJxFઉU}s\8<hPk QWd1H\f+<Y-b_;;G)Z<!P7R} S0$D 5 ׆*rI߃+
+vNۋ, Ŏ,~8'G&DpRĊTVoOKLU'Z&W"lq[Ŏ&nN{=+jkx:%]u<i#[)q5mu-P)/d:E;"M' Jb]!kF/F?ej2/
+x}[IwGY<0] &;MiH{wan];jW؝MUDrk{H.ʽ<XW<$*F928Kut۽^u3<{^8#8e ,ɤY9g In伫;(e-7~+X+ДUӥcs&_ڊΗ@z5~-,iY ΜמfLN1LQ>, qh6ahx,>إ'Hk2/Mc [_ޝ}1(JqhQ -c
+ z=sfj:0|M@lp蹐iDmk8>>wrr,|r&"2KPn|lHwe;~%/Rd ,$Xu!! An =n@Z6A)+uJ|^B8 W=(ڟ˛=QZ|.}B-44]l ev8݇>vyW;8Dz]M9Ïs_6aNt:R?Ɗ=ch6x e^xEg6!2m-(smZkPW,O1UkOOr5qQWGAPH !g>
+k*u]6is\yRfXRIbmFBLȱ3-mVtl&ؙ#1O=czFLG}.lU[d89#JdF!Gq9*.Ǥpc0K4bGI zQ4A 7(nЌ#Fȱ&z<LշidC9F| kGBU~`=Y[l{2"@SΑjbSt'd5d( WM2\S9! eT)\EoSN%ƛL.te2Lud)\H
+
+LptVh(>YFʁLigA\6%PL?/os
+J2 p kl&hBsTωH pC78IMR$ZXC(Jऱ ȃKpQ:rgMSNASˠ~оEgEsk`;Wq~k뚟Ⱥ{J{G e̶Q=2j"2mzgBj/n p+QM zM&bvM.k7Dgx
+1u;k}7]W9Wo9h>ya =bC|pG'6{Gh3Wp%YVbi3waJ/b5szivrN svv8>nK nm7oM_UV,tz<"D:G~Hȓ>aewPU =28IIU$FIUrT" }=AQʮ0e RP T(jE@R]C Qtd;%G.ʄyRR.%y.6y <z8e`{S-ԉ*lx9^j/M4혘6Di!eURU$ESp\AMeiFih]Dk0!+ְ7K;aAŶgc=ʴ@!}da(N|uﭺuo `NoLoM4jtCջR#5`FWEI >s4.y_tDWODX@X`h
+( j>aoڱ]8_ViP^0q^DSl)y8
+Κo6 caam#m:^B
+kwt3&synr?G-Fq9UiI>CI7A̋ Q1
+[\͜r+iiWw$@,;/_B(~įt7C A1;jO%-p~MVaJh&*`3yO%r$%\Yf0ꖴ{GR)gy5"m͑vYk^kS7',58%w>:zBW-W_ڱX<lYYZ[mmY;߁0CN`Mw
+T{l9l1,O"_PlxCPLTj|IH0*|sCVϘP6:,6T1xl "R@H`ip O3`d͗CUeKa9sO2e$q2QXK3qrt[ rY2bg^?xߞ,"fu\q'BO_1BA:WP#|!OPGܔ<DbreԙZbT6m6YFL֐9M \Od=a& <&8Hpzm+w 1ĘB 1dzv0HwsZqĄOt+g,|L7>N؆W_5 cE ( 'ĉX#Ճ?'ҥl|3b<̙k ӕ:ey%Lyxa<G &E$1$FҤ%YGD%gK 8tfhqP/^O(ngUu\fQMgNL 6Y BȞIX
+ jsZ{V=ӛ93tj;c]$eB$!
+;gZ&}+į\CIJW8ºxx+^vvAyw\_ϸrr-[k*,asD"tC_UɤI)9f &; L1)҂bd t{#I}y Ns McZDΞUg8Il
+9ЃD)z $eن&W/tR:OI5>Ԇ 4.
+MT%Y%¶Y;ry-ټ^{w._,nmȲn[o.M֗RY ?,Y5ǜR3ZQI-<L%rMlZD>|RoZ>Xx=dI>`Y56L^šޗ M ȌE]i^5!xDo0!-r$m 4zQl2]`gӷ~dkGq!*]{sg7|doڱ"P#QǬU4sDބ$8]_bQw] `
+f)fmvd~RT+)QGfp"DL"3Ш97,da6*l|6q`
+Я0<6pГ{`̢ )rŻ m]ٿL亮n_:c9خ^\ʻCE9c23QK31oLtG<
+ =B ޶~qI_&|O‰ob*nNu>ZS bBQ _UfSX' 'T\@x+❹Q@(diL+ͷSHWc+c+O0gL5)'O0'm0~BWn P}b`O&?]q|6lQ)د,ߣ.c.%\}G "룳p[>bOYSRư&5֜Zbn[u1OJϛn. ^4
+G
+[rMgm,?GU Of-21 [ sņ
+^D<@t
+`/v^ugD've8b&Ht`Q UM*4h$څHȴȴBMlS/*"]u"2FDq ,iJ?/_=|Ӻĝe{]]Uc-.Ge;#ycmG 9'gYX` ym
+Mr<NQb)s?롻/oaf+H*Ick|6*]L
+_CJ'*2 ĥ:, >,$L@EF 0!LcgFCç4
+#.:x;&kj1<k׏1~ë1?-װ
+ʪGEHO!!ySH
+ -±s7&/ ͛;8XANwفaRM4cqA䛐 mRLt~iFFYqWϹ'NE4;fg.;L/*Dя8wD+
+zd`-^KVqfR=Dg89p+ëC =4Pg](1a (@:1d
+s紱J$-[F,#!Zf~b_X>F~Kνam"Er3 'BO4ӳTl|Bфf}Ϝ:s)SYR,#T!.TS!oMHb% i (Q*4h@e{\SluuzL<1]|@y&P#p]/\]9Ap
+d#"DMH+tčcU<0Eg #넖G=6QQI _+#?y]"\ށ.=OqeܱG Idيg4UG
+kX햤FSͨn$z|Rj9ZrZ2W36E;#k& kǬ޽s24bEngclNl^q3[/;Yp+0u'+ͪdHk2Jl9CM/L'V]O|6ڿfl54%Q{tgkMf;&|ˌkݿamN7I$o}{1s(SF';Ö_qS qjmuzne3uM61l31D-s'xo(Doq~4}X(~M
+
+Xjq֕TEdJ`WH)K\O4N88uE*MVJ*]Z͕b
+$@X >ORIȋϏ܁;\J xN,xvai@2ڙrZSJH)ly:G-ɖ?ƜW3 U5*i89q5ES Kd{sS 2tE{
+qZVNWԸ*)YROhqŷ WD? <
+\
+o}_"U="b?J<9P3d:xa1_١bjP=e'MUUy|VSlߓhsr(&3^`:C9qo_Nv 0}|
+l4, 6zhA- 6VopҙnrCNUY{nd~o›Z@ :|.&R"(Ids\NjLn?N-n!
+Lak;&v\ 4ơ|
+~/B_v%w[0ulc :{MQQm)/+U3.~=[kw2ߥ9XzrMk~\2RD4T8ɫ @%{M$1P/z!".ḨCB GdEVD Isū]<43܄LDB\|rWL#q+kEua@W\
+ &.
+(0 20,))* (&&06
+2)
+wj_SND57HCPR=;14; 75)& # '%(*06833*./48ADCCDG?ΎNQ
+,&$4 B?/ "##)&&+.*-C
+ER]֓)^Ρ0\ͯ9aө5\iP9#8&oIBC
+uL;mux!p  (V#@_?g3K.[/th*+~_kK:4H詠v;6"n#pD41U&H+f|ȴ5m4D~<x@f<*-{+ɭw^;nbwUv݃,^if#2*jOSF*p}W} ~qxz,h>o2b1}Sv6Aw`G9nkFt5}%TD@M@KhETN?L><mӇq§
+Zz[s- Oc+g'N5'Lj9A4ޒR5.N92ќ^oά\oJ\ƞpj@㟸g?Z6_$6Z ,z,d
+JyRdQ)8~EUuV@A()LB3Y4H^BS幛"޵ڒkPA[W7b -k.|7۴x:xRAENq y΁Z_cgXR8ꮭR7E/ \bC"o?tcg$[4ܗSHu=#$_\6a6)a`v%e@Sj$ѥE`<8}Oapn7
+tq3z]ЧK=:TW/q!Dcm2st,C WboGrbM
+;L%HPB-#!P+Mve@&Z:/\뻝Yu^Ȩ4ݡVI":He`߱[_\蝮ؽE`=j]RL`|QяS" d56yЮ;6V< ڻgl7;|IDԶȴ_Dw*
+9Q5Tw))bf%>?1;!mApa8  6Ќom&6GaB nLU_xʧN|ɵF#kA7o?>=~3JDϺ3dƔ6>KΙI/lArE|i X4/3QԴ16ccPs1yi4gN~qg<u\`:n|X#Ec1K6RVjsrԪlDiY (idF9!*GBO` dV74hQ*eTKՎPM`YP-& nD,Z$0iTl
+}cP@YK V>(K<rOL(Z$1U}vFP{nR)[r+LZ_ KrvWI9\
+~=@{kEnu]js8wu(cEp>|n nm:s"%~EEW( rՁbN@~fi+NjrF*\ t.$ doBQ?M!1y#0=rtUbuX"yu65\1=m:ʹ=\$e!WWQBJy2R!)`Rd\D)gH!hSRd3|=z#fk@(p&[SUK|YR%=ܷT!i+|rAw1
+\E!_VO>~䝭Μjrbn;Poى:5Z)KBcė>3a$cB: BY|<i5|-͂5l~>zEV3+氵eszyM7%ɿR_|
+vEwԿ,dhrӡr˔[n**s|*'isY#cc2U{<fC+$ܓj`pjM%"M$u 2^Y
+uä] J1NS藧lAe:P
+(<</|@˗WUyJT,~mxUG(F] 2c1ɜL80f'̃kĘo<{lϜ=2tfwNwIweN"Gݘcu`x{p{I},|_ %7}' ܏W0w|)WwQw/
+%<@q?"Hz}.|CUa
+]6KvLS<Ert=E4RwF
+д€6\NSVz%+Xi'X=h%"U+.Ijĩp*w&Ɯj$khFQ[(
+l拭mM0Sgkmˍw&>^_<ucKk1;亩;!Hojs\AM V
+H@3@r'$\U;ttv*ળ*Dp3!BHpAHhޛ
+vf䴴s܇PFG{j 'uL&
+]BA_Flk\H'ɔ!>p.8;$vIu,O^dIьF"n6)M`vSjfwQL2+JOMKϤa&SJK⚙S,WH{]Lj((
+AnLİnIC1]=!}TBP\<C
+#W?9k
+rG xaք^U[b+cޣ`55׊9<o
+}j6߭"c+1{wCe_  #̷g[CV{y7\z[֧i=N`NSV\rf/[1WAUv{]Kui%ႴwZN-R=!\TTcUr#5757nnc)*b^|~Wj-6= `'\S P5d]=\b' äRWgkM׳?4y_|zƧ||Iw/\yZ&B_V&WpeYL}SPՏ2@H#qtYG wfbL#/ 熞&^|)-\|W2,zX 8klyCd⁝˚ E0e}3(2.1]yqM7m7kO J=(:
+?=+7AJ Br!;I
+=8ȉ{Q3QSwcO=<Z<Qi>>sY:Yl6p-s tu?Vwp&_|㼎q-:+u9ǿp_:ool
+P*= 5)BM'@-I+Pq6v@'@+c u=)%`M/6?"Zz
+MR܀.2I!0RE7гMJhK@#DCJ6uƴY+=?
+ny퀯CoTA"Tq
+~qʩ*ݜ/?]JJH+%
+,E0a .Nt˶*qd \xu&8`6 yĈb ò,|ʷ˒ѐTbk
+v\U{B&ք*tv$wEVt]8GU#I'GI声юDcұfLxSBD]|/ ]W?D3,2PL>/'x'|0kҶT)h&u/!<ϣæOO^x#~ k;ASQs[ksA_7OVޘ@DN]n|Q??hv<wở
+Zx Z~ :})&q?0;{l#|>Me@r'uӸ7E1 ׎Qwp#d 2_ByF# H#ISX1%MXִlH[Sמ;x6&&n|ܵWWHGw/}{_ yc,˂4:dFݚOhrP.Y
+`Ա
+g#}ؚpEl}y[=\_ŜR+w1tSkaKSJbVR%iN^<U
+w!>nMYZ5
+ɂ#MXiSSY~NRIUԃU
+D&!tZ &@bXFwfwQ$!
+(ws۷}K+o,<S#9@ojftgܩb7ѧ|/oдԼ}NpG J-ע-'w] WUSoNy +B)KB;V\¥K[Q+je/4@RBQK%4|g[?jJRR@[o/~\Oz ݸ .E}}R]m|]".]].,wVe$EoN5256F<n-(δ6<@
+'MG-%,K>oG77# ;g *AM=/*N߃s-x9UBnu=qfuplGw+fw{_{:.z횜5nv^m~q9m/6Cˡ{Թm1bgkџPa =0_[ۧ</^qy&_^@9;=qo,$^c ݹl<^{ć3]:S?UkBS|Sl}GDw'cJ7Yؕ9xŝ-#* :*O=*w8nREKk BDsA3
+p`'MylSꤹȏoTHL9qROh'w'sX Hƞ{Lq&+F;bE1Ş2Org7q
+
+]q]~nkqaoY~iӋMkוi[,HiZ3ml^vw]8gBZ|C7~D\o1! (d޼ׂ?l.p18a [G:Ēu=oJ~wDL,*$IDzz=*RW[[|#pK{ O?dZ5h {K^?EExmhG=B ɨvyYPYŃ֠4( ! Y IHIŽȢHf .XN<LiMwkӶ PD$@d!QEDq<:u}}u~WۣOG޷ebz,^k:q@f(trNUhJ HjRTZ&U=LcR*
+(OS C:
+An*􉱊Q*Y Xb+$f0,8kyzt٠#&nqQLUty"]no15mÚ{`'kIGGZ["E#/o䩺NZ-[Aϕ` Ҳd] E'-UGe3X^.["JIج_ţ>{
+I
+$S5lƠS$(Dll<$IŴt
+{DNIq%8ɔ\C^W nM;&+zX^Zcat+Q
+ B`<4{|!`!iD,~wN2*вey?G
+ZIK5x@…J}uܷ70U W{C5
+D
+EF̹:r_ÕL^t^A~笋,} ϵ9= wКGǩe??*kXEMIz@z'Lc`Z`Ni8gJʜVS4apT?, pYvQdSz0hAjNXjK- qEֻ 7"uQŶxY6Q/^GVUn]nJ>g|hF;롥+Ӷ㗠'5}6V`]a懑
+'Ҡ}70
+#R&DnXEzjQ!HN i|˜MJt@aeD 1HILDTHhǙ1ևϟF9iZC"A̶%BЇɵv#A?@-QI^8C3M}dűH\68F%aRc% `4$Cl?.(#Aqb &vSPiŤ\],0#lM1?# l'&nGꐥFTw6G|g=T`oDMQGkt6Xfpoj#ǮŜ\\TY~?ݟgK*%U8DŽ*3H@5
+l
+GFH:Ϥ{X\~-UENҲ<y1MǕUR2N$hիx@{0x@vvr.5PSMV,|ݱ`A.37_{7|nߝ;5;> /"?p=k]MR~kcoU$8ߥ:o :Zi_GҍWX(5R|\ 9؂M5FC )N
+A5.fhMx.
+LΨCjniEUGj\s32،"2LU ]=mJ׵߂)7`.EzT!H|K5֮"T`
+*KHڨ$DIyFVpn5`
+1Ŋ*\-k$kH|IÙ\Y39SF)dE71UN(Z nb7&A'T_#azl,oҦ: I^~)2bi"E,O I,T@%pH=JԴDdib>3&QJ!ǑJR̀V!)BiGkMJL2]%G3 ?H9ܵkQxu`6Di_ol-v?c$,+I:mogBU8~wo?=o\>#KMk[_8fVAXV(^aC^.jGgǛ"cx[(řbOcOvP~>dIB MH܄NBaGQX
+x_ƥXW
+H/:0c{f_m':$H#$ R I@fh]W9׬&[9c<,{FF^R>XSg
+lD]T]P3keѿ1\
+'3>^htq sԄ/ԣ,آJ<9K
+{ kB s6<o9xs/e>/IYKUGr5q\aqAjG%I $ 7T% AN;k.*p@@@!IǛCE]e]i<;>|$¸BE =O( } X4r
+~"rG!9?c\Ca؀G% Yx軲;3~| M)kyl WMa&sၜ3f6¹+Վծz>|o+SKjvehDU:ʝA73 M %me#M)evOMժL$9>r#Rp(A(*l I6$UZ1VdIqb@'(qF1!Dٌe9PXK4d`ԝ"G3&މOIp >x+,ލ8!,Du2*K 4IK5q1X(Hӏ JbnH3jQIH_daH1tiZ =G;#wGZI6!"POS, vbɔQ:}^VD]eV:g
+Q2Մ.gٻQev!BLPH!eN,w󸅼d
+{! .}WL'UX$52$HJA ->CvN 8=ݓ'=\zV_W?k}aWPN:c 5~Q[/qo rDa6W*b}yJN/x.^X,T&Dk/:ʽDy syqTD5cBԎGj~0HɆ8I!
+0MqdKMbZB]FHcs@:Ϸ=9! f\7VGShXZr]DPl*bTǵ30<=h%$XGkK-Ҁ/vPB*&p-]BK Ҍ/DBU1DfɆA0ÿ@^BzZo
+^oz9ju_5WNn>?{a%?gv=znlz1kPﹷ-']A퇨=;y~ҋ^ݱ{v~zk}ࡕ PfOʏcQ곴`,h
+Y xhKG
+\vWv^Ҽs8a>EMkOkyOk{,>?=q@$*Y1u"YfdVi@gP:@C|Q$NFaDVG8Pb
+SdJQnbe‰LɒҔ\QMi
+u7)
+*~0
+GΡ/ea]!<џX^"l+}%zxAܭ{u=CM̑wl*Bq[uk3UW/.#=AjwrhqshvL_w[^ 4Ђqv,&&I3$E{^>X|՞]U;l m!X/]x֛>٦h瘪e$XL>gL9
+v*մ Zj.kR@cb&TU`L?x ]|$kz:cI)*&kI1`k 7b %h` ^
+WrNohznj}㍷xhbGK =ׇx{>M
+A c$8T;!v\HetY*]!@g* R<:/뼬
+666 hf$CZb
+ &l"
+8DA7#zw 8R+7<ʈhhژױLkf<%*ίƥ)gԾ24S_:R6zE+ E2|aʚЉjT
+J=*Y^`ULy:VVJ/m$5$/&^"<>[D_d
+]{cߵS@}z{ob$XJ<6CйJӄOMG?d>4{n?aYE@:P;[FܥXǍ~]{vf_@`x1 hQ*:35GUIbʗ'u8Uѳ`+1vm1<1)nd> XQ!aA,C
+<A9Gj>]a3GiOMO+rMhra1#݌Dm<BжtA@^WɁc8R+'nv뢷t1ۃѫk+}2ېiXF?F6L5^X-)݇<k;12ώb5@X'\l&ݿ
+吭\\Re)ڂG*'Cݎ Mv:Lzعg͘c `Vử;,5F[*2',y!<|\N]ҷһa @ďYGį{ټċy~1!GPJȑ|(n[$ X&kʜG[tBg9/uuS{S9re뷥&KlXGvN%XI-Ycb![=')fKJ2tf9>STNWaS$\x;R%tisc;r]Cw{ÆڡpBU\`5-r+NUNU<dK~%wI%`/oJ.bOHbW`1&k2T<:Pc{BB4CϓGE'~"0߈ewC=]^m ٔU!fjfBRr|f~fbjf)xowcHyXPP
+H}H@$ w=VٮV+ rcW/!$xWR˕dL}}y|4oܝ^>qqf7! f֓S$}6Pk|St**_Q
+oBUWʟeyLu;!5s3x{`&2|BmA{A{5B^%
+<M! (X:8 0pAE8?DS!*>F~*5 ' $Z hIݳGeCrFn#s4EtM.Ghkѱ&tCO AM`H;Li.BF0A -P"!J"ZR5#Qb *B? `y9XA u  zZ=%UPU1I`="ESTUsT%<M1"W]QRQM :W *Ḻ+|e.Oy/+U$dɪRIYd&xp,%h!?*SAelh@Eї!+| U{^5-lx S9 Zy6ǕE\U)0X4y߇gTic{3Gb́TVgqUtP +$JoRR5LaeQQfIQ!ߤcKc7nfi`28W/2,WU)F&DP5Dp5)]Xí p2zo2<[AV4D̿3l
+
+@XO7kՒR$fu ˟ؾr||=)IVkѾזD5\w_<XL?Wg ݁B?sAWBO#lb=պ+zkwߙ2)sM om2^ŸD5
+88)KEΐUe C*K hs1RH=͓ɕ5~cNOHo6ҋ8TkxO T(.F̣f&Q;= fR|n@RfL><YWhN2ԻO6~5ows=vÃ= FW3rHxG3hM5!CݨH
+bY/zC~F my6ktNb+^n^lF[/^f+[F 7aX njN7?J<%:`QNXV`76VZ`)
+(` 9rD8:ZLLY8FNAK
+
+$$# "(8(l?z{YNq^2>]1{oa7f؃{3`G sg҂1V?Lܿsf؜`nI,8[vS-gOhFcیm)Ҍ1zFTXwdXCfD[[)KN:aV9N-;_r~=5H<_R6~#YQ-Url5F=Yg>֮Y}elF؍/3r& w(ڨ8{o_?Qמq/4^R|lbYg_s Z|z0CćyK,|v\E*a>j%F
+u4?Q E*5
+_'!q
+<
+N+'܋~PW:2uCcX^$JN֍3l`Nm2Lƾ^0z?e2w#{sGV~q1K?OK^Nד'f.~dV
+&W?@CO.bd:a7[I~VjpM*G}C
+wY˚blb侭F'cF|TEN"jT`j
+` Y
+XFhQVz֓3u"`D7bu D}%9 )͋qgڛGߺO~F\w p~q
+2F$8cJ#ⴝ mD.k&g=d*sT\];&Њ7mMm 8m=4e\ϝ$MDI3Q`tG@ʬ((s=884o!,w*{T44.DqG!q)w4#݉n=6kjԼ# 8K@T-S?V鮽i.*Ttjd3]9K5x"Nx6Di>w-uM䚲Rf۟f+/_NȳƂI` 
+gn 6.nD^}U ,#-~Pko =qVwsku"})$ ;R-²G'AK->V'2<
+u
+ُ2L`O5ELTziZؓ"u+oso]\X:[ǭѽ'ӿL:-|3Y%뤼*:/h'7V&l
+|~@lum$-NI//8st-gOID!aDi`է@w/8x{P1Y -^w߆#- 33S~/^xOc8jʙnbeD(ӄ5T;zn9&we^<Ds|L/ 5?E,͆{0{ sho\|RO7fb }4RuWvN3=hW)%P1K%uW'Y5DX="|+%$GpLC7&5 8CW˱8~P!K4"riT`.Y׃gB㙺
+G#U
+S%'ƪx vtO"ꉇtģ29"o]Y#AfCַFe81&E)%E%+TB@J\J( e>VbC*$0KUha
+u^1&]sZZ:(q9єEp@2]yAdy^d_db/s2Ys,P|"sw͞[7~% x[v 8O֞Im.
+6%1_FƷօګAGT eV˃&2+C!i[g0|vC|#yq̴D512Xs0RwlI:YOCOTbޏ)'5~BgX6秤ma&p-9W󩗫
+hsّIS.=p%'^͏ QsTҥ!t7賕5Ҡ{w7Novmg)qo#_5Žn %1ѬfbTgK`P'+c/}ù`2Bo},A1󈄁*r:2\2,v;dgDgy0'Ѡ |G/}J y${$Jj@'_⒅~
+oMN~Ǧ1Yާ'{0T^Qn?C+Ÿ{KQ2a_#Y@Qy(*?-Sz 5w6EMHГh=VEz^_0NcT0C\W/;T#{=
+Y|Imkejՙ-uu=`DEa袓lAkbCmH\Cg^@]>۹kI31kI%|Teg|wVH~J(<0R胷%[ P$o}2V y\ oMoj]7뭯AACLЂsP{ݨQR|ԏ&-[p_:%\7go[@+5X@ tZ
+bt zmc,0+p0!# xcw8ko;SPj8IUq!){CGlx+"BFۜ'^) puϜri-|pt34@x8ck/(Ksٟ4] 4AW 9XoڡaNðy\c׶ ^U߀SMC@ 0
+ ,E^SZHW9XDzЗ6ϯauGLӅN3P5z$~ \/[/`J@;4@ǂ62v%i0_ o;ncȂ5B>F +< Լ1
+Yf,rM$u +]{o{˔,?7fiv2ۊ'T#[kp
+e+GƐjMh
+k!(
+q)b<'/
+YmcܻS)e&ы">5`倕Y@:UxUz(j]qܵ]_QMy
+PgJ< %3%e`T[PJu9Xk- O{Rx/TCw0F,YR SuB?b7gKo*^wԿ]t\vw<2c}㞩׸UGEȞoZl ,` I\(ˡEg..6#s0k|50<-AGUXcR4w
+<!Y^).QVHHs n/Ϳp8ATLT $*bz$1-/'(d#Cm.{aK y5$^J!`#-h453@GEЌa*kLh„(x*۱5Ǵ!(] ?j'ijQa/`j+!d|"m&iWDJ;T#J?q1P" ӥ
+x[G$00^u" ݈^OTK@H FGa{쨣ۅ^hiheqpUku{@NG ;[~6 QqlpmY ըʌ{~)s){ׅ +q۱I𨛻A1Q,B *kY#Mvsw/u?boտ}626Z_fhu'P@Foos^y幥oMuW;.;6AVEc]_5ٽiǶ
+y - ж>A뛀6>'qdd:in\QX>toEno=>ؒ< N˳[, cb r>Eg8{bYR,,3M'⦋#8`(Y'BP50F
+XHȐQFRYp3a
+%yyF]%*8L& B\"HF=iĔ3d\ Q|neI$lGyF|"Z6T;RԊ
+3&;(.UPXsD}x˥ԩǔqNF]Ы7EWnWylIuI.PWE/SE SO":"EXL{ KQbaɢbbt@)b&/֟ʮP9"b$7UgSK [WGHa5yFW
+N\\mҕgbӟ85ޜP"S[lbRWu/[,ӧ'~{WLky
+8NtwM.TFe%KBb–FNh@=$ujǩs[nww7eP\tcwlzkrBW[X<ALt&q ?7FDOb
+Xfal]%cNP3-Lj,EDZHWEqhI dVch{h ZB>h5l>)Ԉ{b 1
+l ?
+QR{4Í4F B^!<A!Jx>w., ދ.-NgEUE5%j-c5N%9T_Y)#Vb+}s*Ҙ5]%o~^5Wn$cX wdl;BևN|_,3d ۈ9i9ĈAI7QpgŲ%s'ew Eix@ pA&]T\ͮ|1٥ 3vskS pM:n+]gfQPrpiH̼p>}l>ID!QTQrA{9VSJqSr~OUuFEx%*FcLe$pH ؜VˢwcH.&4e6@\&  
+0֎S;[3;l
+#r# !@rtӑQ&˭?꽯"[O#Ⱥ(']AQxDKmZHcBTKԴ6\LJ&.Ic4qTm\6Q㛡}Jv=$F GqOHH;5M0(U^GKQ%-$62RAp+LuuMP\]?.tbF7qZN?C!l%OZPoȓғMTY--q-^Nd&(
+VrπS#:'+@M6l20UWz@۰qZv$:ls4*.ONizr2%)m}TsWws]iA:guٗ3|ySt>GaVصL߅\&?ɷ_>UxK%/֦'5GE6uO\Ʊ<|X!'3ԣ^G~+L< ¹0K#P@G,brQ>Nœ
+qnvWaj2gR=Sj3:j-T^Ux-oPޫ23vU'߷;V}Fa@x)^O᫻NR-(}'2K>3|=Xeg9J$F+xU+5U]GIR%k(I#uV_ ~i߄P-51jM_=\2g|HZ9Q)0 ½p
+X3m0L.K.ȕm'7P6~sE͘Pc&Iɻ*8i[iMEmުC~5NːNAG F)qX3<A=&|WO^Z
+oʲ̍BJ]~Bc-1׆0vkk}{kԖ"yIrS,R]/ev?5(5 YǣcRLR / Eͭmvfw63[gp:[EP!4TDn"A"oeѣM-_y}o<~bn@z =uoŽ^v\'ٍ|)ߝ;c3b-ߡ&R>Rh9Ů6M=f]=jY@|hqp͏d'\
+ BJXrgnu3v;2މv%61/џ{b6{_;h7օMua쩚ࢩBSm`"S s=]kp˙[-}HԎ:rWH:;lKZGD}QD<I_6G]M*Qp VΤ/@*&䉚ōqŵļΚFzo
+ij#E אyq5VSinDP51_~?2W&
+$0u=M l樜fj`G4S.;K8uub#d2
+'aPʂ7MWo|wp1nH=Ikm˭n=ҖeG9 |K/y5TE%s%C?7˃/OV .M#/<QzDU*lC]g*HU9J\_$]UWW+FL6oFQ\f%L_,\T.7 Ă*j
+9r%h$9ކΚh ͚硳 |y!ӠlƧSHlgR{6wh
+D M@'5[ %;W{% %Eeoա/_a
+ UED-Zhik[/`M7׾{ߗ|>oaNM jAPuѹG>g{eѲ
+ eRw6 ua۫.8: 
+ܰ+4[?$ "rl\)oEV?4<L/KYEX LqF8qөx.4B -,0AA@ Db %$-fEN[p~_.7Շk
+A*@VkCh9hѷ\ \C5k󵬠SSRwM5e*
+(>$Ʒ
+9}lӪ'ic:s)tP%x=~]YU=y5J>+
+
+ɗfɻ1. @Hb $!%T0>U&{s坉 yHU 麶ȒTU>w'|^p / W:skʇ}If̕n7#}Slh@}+zOѹ]11Ly >KubZceOd=16]NdJ[gk$ Nډ GSйzndB?睷H}\j. ůlŏޱ;56Ui %JWO\CתתFysO
+<$a{QS1~}v]ĚFٱ [ Ỿ
+duHWqTGt<*漬]WX,=|bůY=Q)eaoCrdHiyܚ3ݏGrog~~#
+̄ OKIdOUC"8yK IRj|ы*\! MSm!M܁sU<^;9ʓ*Ȃ%ֱէGGZoZ%3ێ/ c3"NNIfb
+tE-XutY.[QS6s34uy5s5Q9jVPh An!wm/#af8mAF^f_ RPR
+ UQcC>3^ Z}3y113]V m=g}e&hi-9^I3b~g7=ՠ@eh_"Fd2\T$~7aoZ4?׿^&C~-_8{w lk-PZK̎Gc3qb=4,WjXaqqOpPyw_
+_7
+/ulwBOfg|l
+z2|㌖87҇qGʼ?s"QC'sy}dY埣5P$7bAhO}#v [HlIKaKqt; i| KX+(OHu۝6AzOxQŧ(: bo#r$]sEnԕ8;A{݅ _:;E#p⺇빮YuNBuyR'{݈27,({;JCkk_?%|Dxs4ąʚh+5eϚ"
+_2 9-n겸[. |tB1ÂJ
+pwFo <Ҡ@Dm 1ͦ1n,le[Ŭ H *WlS/ "_KOGߨ0/N`mB~%lII^sBE5 ho%vwRkЖj[G#?٫Hbbj%XZI߃տ蠝(GCwp!.ޥXJ7)mYB8 $@
+Ed FkS4606 6&&!#0>ab.|hoD4yu +,&$[^ ]`_cT %/
+ O87[2[boynHNas)o?ߌī jəR~ 7GkONzZ\&,8Kka=xGz+kv&fNgviXjjբEN9DAJU{u֮ߝq6l矗&]O..R2x}DPHth{ r^A Xc !>pj#Ŝ `y<<kq2.ބּۛV\./.ݜ<-,y;W5_{Ko^N+.f܊u`sȹ>fęK|sx1ErZ*ꩡr&z@}l!!*_!$$)Bl\c|Sj]V\m*iF\m:K{Jӵⴝԑf`o[0WF^)`Ml vy}2yɘ%uCO;=:ݞy0KȘIViF ] ?8($EJDQd8<8HH$BFS*^H+4Q8<y%0q:9n Lns,S%eG0ZW\z%N^w*
+ʕEIZM}ID0ڊcTf5MVg5!,c *Dd_҇i˛A 5ˆjDZ<U}X-pmV - mY2j߂,]C`iD
+Y \W17k⟸ߤoS([o0j(z =  BP674xfv/g +Xr0MHS<¥$qi6 }BO6 U⊨JrQ҄ R5/k~.)X@ȟj
+ZOZ/[s='do"n渵KŒBqzN@My+dmyㅍƢgg\׎;o/[9o7x6?78 j\fq&)6݃I 1 AB V%b`1$Km]XL~8 w-} c% }[:G;#6--yS`C YeGޏl@[
+M~O{ynQW3G+jV# ?-PI^1s|O2^9<4
+?&3_3u_X-q[ʦƎgKڔ%t#.K|%3yY XǽL\^êdgPH
+"AJ
+, /1:< FH
+NNQT I
+D ==>E1\T@:729!? ?AA=?=<
+==
+2*.3@<048?IHEA@<
+H J N\ף*^ע,\٤&Tٯ'Lڴ(Lڱ'Q٭"Pխ)Xӥ+UЧ,R̦0Xȩ7_ɧ4\̨1Uͨ2Tʫ8Z̫1\͝2\ʕ(Uɬ4Uʳ>Zɡ@_ƣEaǤB_ʲ;Sس/N߻$EGK QWVߣ"[٥$]ץ'_נ&c֛+b՚)\Ӡ/YЦ4XШ4]Ӫ,d٠'e۞#cڛ%eڔ&lՏ-qӍ,qД.nӖ+gԙ*eӗ+_ќ/Zͣ3Z˦6`̠3c̜1n͋7kȎ;lĐ?rCvŒ>sČ<o“@tċ9i—8jÜ?oǕ7lʛ8jΝ2fҜ*dӝ.dӞ,fԘ,hӔ)jϒ/d͗-_ʚ1Xǣ6[Š?]å;[â9[ģ:YŠ7aÕ?ir,klh(Zؾ;KX?bCcPaVSCI4N/P/b,p1^CLSLaP^LNNUBMķ>Xɨ7Xɡ<[Ü=b6u|/~>p6s?tHqAm@m>n9p4e6`0[3n;xCyNLyǏ@vό8uӍ3nי.^!M>3',7 DE NKG$D/=3==:Iŵ8VǨ<\Ƥ;WŢ6PƯ;Sū>Yë<ZĦ>^Š>_AbD`C\B[CXAT?QĻAQȴ6`̝)`˜,]͟,]Ϡ'\֟#[ܠ"Xݣ!UߥUWT
+LCB
+D BKLH%Iܿ,E0B7Cξ9G>Sͼ5QӰ0Kӵ4Tղ.W٨'V٫-Iݴ)D"NݫNլ)Lҭ(H˴3H+/"
+*("j4F&vg;vSg:t63;1ḱ^rx"SQTP#o=<|g>|v!uC,Zw̻IO=*#
+L8ĭae/hHkzr#!nޤþ˔?A@A |2
+5SgjKd:14? 1d XL(wHrC0}w KCuL:'?Z
+4'P{cJke@5 ڕiH8}e4:ca
+Im:&(.O~UmO&}RI&jpu5AjS.ɷMBqNN^1ɼZ[ijB2 (&dJ 0l3]Oo3=cs$lyu?#*sg5),YsQo[27٫gi#)pƛ
+u7}#R(%{xx Ʊ ag
+?;\ 4zGurTxR041rONHr1ǺQbDq>^XNWlCw#|YA$*Je6<QUh?PlM/KS3揲 `@lڴ%xQRQR˶&Lwx=WA}e~Q@4+D4 Ǚ6ąB^psB_p-#9va<@U~xB a#[ Z C O
+eao2:
+"&Tvcv_O2<a?rmG^|ƒ{nɸyZ+/%Rv.=фڰ"~ :z#:4^_wG@C;:ӠכT
+7Z_2Yyq5punl+vYb9W#\YlI|f5ی;.43f*w|xd*׷[X&
+ވ'*QQ&lҤئ;;Ns5DŃ(
+⅄CNibҝ}g>=<;oX"!!EPM㘽S 2%u:l9.]#{:FbeyTgV D#ߋ4E"t}PKHA IXIT] JUI\rf'/='LM17bfo®2iCq)|= yExhYX=4kn aL~O96M:Hs\b*Yü(!@UV74`癡'2':0il 4uĸbmie< { }1nAl7Afa_}> [/Dž^3&_G /W.._LNs+PpKQͺidlf/7Z<z?WF*j+Z)K7Ѥv\ C@Tܐm 1QrSW.Tz+|J$]]PQNP?aB$Pt0n
+e-_,TAfMyxtw}A eyHh9g"j$W!Ǎ?0;;yrZ} ~Jq'`!*O^諊fWՄXz5_=w{Vz $O=7Ir\pAdq߭nGGV=8rBsqR}+y!e(@9 a#\ ڨ<Y18Wǜ6/ڬ w+xY{bzOil<SW9wQI,lIEΆ3%ǝbVG?
+v]ZrS~!d/~][ *
+( Fqyq"U7%"@4|sN(e
+`,TV(\g gG0]u~pvOeM& dӎ#
+)2~~.YʋQC!NVqNW~O* 12.>]҂ϒ<5Fg"S34,EQm!O* O)n04e`Թ&PhçIo%o$-I;5i[?7_͑/"՞q_IXRFD<D݁=?:TAYj:R.FY꟨{j ?XZ@?@Cw,PZ. -4 `3' Fk;n
+=8rv%$٘bm}cܑXYj1a (pOXt%u%t'Lx'[}R'ZS'!7]WMp|']PN{& Ct$8 Y Nzw'V1P< < m)`6sJmF]F>{hEPhƚ]göydsӂaq?߂ib<.<85NӖGc (x(!8Zn;L5z);RD¼ Q.Q42c&}z|̏M[Zr&6{5_x)zס`R[n:jr=nwC"!ЇU` 2p?O@(f$ "
+0 %
+zᜳ1ֹpWpZY*N.ei%?yՁ&Q@QgawYKM$3'_+^mq[[Cl[}mm>ω1r|G ڃ7o5[S<Y-%}s@ZGK`v6=?(ZaCx:9yq½;:?G~qҭu~N硇7v>w?@r/>o{K;6sϯ9G/a~47ՈEks70?Lc+AΔ#fK|
+fnBї*(};[ꞯw~G
+ (q{\\Ǐ Tg (aH#՟DJbvM2jO=z#|$^
+OE 'OHi9ہOSpjbzD4vfG*G ƨ0:{:7(,-!/,PVxj\<$SVIN
+˜¨>QdDΐ' %JK$`%dL4 tjtAezU8r0TggQc!$!_wlBX;;=rvx_݀qnkzfafg×Nn_7G-OMvUﰶSoчg^;=:XC6}GeĜnk4sH&o ? ɥaqt 1χsM ^ܹ&(g2sfjنj(oޗ7ȚiGrL '>wBOn(u 2׺gVx @3y*t ?(F$/R _H/ǿ_<:d\nd58⍝V:1
+E3HQ BU(bz"0ƨ)t( O#bfOͅ´
+,kPk*ߍR=$\˜r-5'<rY5"hfQgҊ܍2t< %ehC,N2ي͘l@N#r&5~i2SVGNc (7؎4P
+[jڝtN;VA;-
+A+" ;PQA&;s{{99ES{/T`2U M[`Cm9gOR@A)H $&&Zw Ǐn< FTܴJ#UrUizw mE"-<LՈ'a43
+040ܮ9L(=Qai7=B SshFO<PFU3(_N=.}ΗKB s09k˷;sb/vкs]y.d"f(:mBTNwmr67.٫.yM.xTjWUzU|^\Á91}
+N1_5-.FWJK֪Ѕc_UgW7Zƃ[Am@Zx.eZ_)Ӓ+52]O>B{̷oܾ[jKK"r3ϯt7GF%HʌA~1OqZmGNn:
+4==~k< Au];Ǭ/lR7^xcaoGB?(#G>AW:ߍ'ma+tܐ/qQFXz^ѯ>eGAvVšԙ:r2f}X[CĪaAv>| >9羭HțӪƂ;|$[J OqOD=A6[Svw"̕VlKs}//iLj7וQފ?LӀ. pEK;'W`V"WbƀkZ#hXm޴ 36;zahN@,&I.ej y `5Οs-V^B^3U^0`ƞ Cw™@֔
+)IJZl0\6 f8_ƌkp%uUeU%Xl.7/kIm[%x>$ɤ4 hs:P j=5)$v/'rAeYvf.OW*` Ť
+t-RՙwrC3(Lp:ey::nQYK ׬̯wywϗsns KV'¦|"8EX)'W|N-. ,^',+'&vfZAO/ ,_qB Y}S]V*g=j`kc@Hd gvZAGM&N
+layF!fn 0O)QSc!83N bx?:|4=xU8Q݋MU 声~T=6UK cƇx >^2ؕϏ+~͖qYc"C݁e2}j*KpD=l’@
+TxeT
+ي#3eF1P'
+rcGPܒNz
+7Y.P[=Uk ; CJ,H|\ĩ\YYHet/&t2q]e^rl\16iĂIM(-|3SN(A0 ȋ6(ؤ)rcY҄& :<'q<ƅ5_gX.*0^gP v 7ŵUU? ب$Z@4Hզۃj{- q3/ݰ7^0/Dž(!o2EU*k *tj%v|(=D
+@+Z^tx|!.O^Rh.eexz&DB_XWw:?15H]
+Vlԡ6
+?N _]}g[l ɀ<<7{ӳ[tk1v
+4L+^C4_yYwK_fС2/D
+!*EY},L^kN
+„@A~ #h .rO=_q>Ta8Y"E0:]x,Kt>o_ilq5y4:D)iM*Xo5JTu hQ'n~Cp
+C!hCPh
+!' 0環$z}~7c|d,<:Q#c!#wi%F t0ZBPkij 4Qk½Q-וay}~_:|jYiɿU9Bxo=mfazuܖ@F/udm?+q!
+~g z⠉*G ֯-}A/t]r|arro[i[?:H0ỿk!ڳlTj8x׶mҌ,6=㔥VTEEi/yz,Ag&~dkt5ػWw~4cٸx!AVb,0sWx<CJ
+S TQM4<ThWXSƣO:/m`Pj-넵g Ee)Zf4"$qΑtC )!`S $e&3ڂD~AF\Ro:ImLD6dQ%οN
+)4X +Eċ
+"R:hm<A$I G I@%%e\Y" X}׃_3xUg3zXn>IhL(L;G$Kp 1^w~cx $εZSwLHLIrHܼ2 jH6PtFh7E+KV. UEivW`t歽¯V,,ۚ/ٚ\sxn]|[,qҭX,ٞԬ6ѺR+J_q(J6Eguׅe
++9~ ̗?F]Q{\f:j)3luc#Y螦d9+3<SLߌz4YцLiM58S^9tuT]u"ώn&aBԃSTL4eG+uI66U(|ЪaV3p&D &{< 3a>>pBم'6Q? V!va&,dFFyn / 㣆:)F8MZOi'
+a*B+Jl|IX>t&{]#9LY92KZ%AI|/
+ #:§W JPl@]5ܑ2;}+?e'^>}U9*`f91u7KOw %%͏^_qǽ+m%t\
+._w7?F η zx(7 _&PW 9TB9swGAre9v`ls؉1Q!)LT!9Xb($nF'Y KV`AA6*eygOVjBg:=P 0W=]陥M&x$Io`xfx+kEF
+c^/~}џJۨ6K_ggQ٫^_?z՟mYm]3zq&wl׏Zk9
+x6&oA4CH*> !.Ys׍0'p3-Q*8ZBRĪ98Ms
+NLKOV
+7<> D GKP LQ-K*;׹2151.+.1ACR>:63239:;65225@޸H7>*:;31HNFEG Q^ږiы*t˄0xȏ8v˗6jϟ4aӣ-]֮'Rد"Q׬ Tՠ`֗"iؒ'nَ2rҙDgМHd۟(`ݛfׇm{kѤ9ṣIlϝ8c՚/fӘ$hЛ-eѣ5]֫5U߲*NNR OK
+($%)%!#/7GΝ0XVdN_E[H\Fbŧ;dΣ2dӢ&[լ'Vة#]զ#Xԭ.\צ)Zة&Z٤\Ԡ_Қ&fҜ.cӨ9WӰ;Nس3Mޯ&T!X"WNKJH߸JݯIد%KӮ&KѮ+Kж3Hл4Iн6C3<.?վ/Hյ*LӶ+PԱ-M԰.GԺ3Hػ.D߻'DF߲I+Mڵ(8۽$2,;dz9HANGWO\ONPKMEPCGLµFXĬ;\Ǩ8_˱-`Ԥ)aգ+bן+d۔)k֍'jД.jΏ+cɖ5\Ģ@dĕ;l@r:mĒ8fĘ8dę=aà@^¢>Z¨BU¯ASų<SDZ7Uʫ3Uɪ5Tɧ6Tư9UDZ:\̧4`̞1`̚-Yɝ1Rȩ9PŦ9Yå:VŦ5Xə*YңTS#H;C==ͼ@5DAAPȱ?V˱5[ѯ-Oս)A+DL۱Q֬)Tդ,Tѥ/Vέ7Sϰ4RҬ6QԵ,Rٱ'Tڪ&Q٭)Oٲ(Oگ(X٥ ]Ԝ,cА/bǔ9aCeBj?eH^P]KSKWK]E_@]=];X@[B[C[C^?^<eß6nǓ2rˍ4tˌ0~~+~с4p͖;h˞?fǜ>]Ƞ:gƓ:oŐ2eƘ:eƖ@i“Aq:u@zÑ<{Ɠ7x̏8r͒8n͈7x}4o(\$yՃ%uڏ)t׍0xѕ>qǡHsĚC{Ʌ7|}6u?tIDuΓ?kه8us,d-kFoGuH\REĂ@z/e/PFEKZHjJlGo?z9xƟ@n͜;iИ8hԝS偊Gfg"
+x( "iX~ښ~;}۝n-PQ1RK<
+
+C.I# ZEG0A9=fNр BD)`[ 6%UCD|-US+ZzG7?^qyưQnuMiq8=p(dyWTJR / gyM_JO~+{Qo,*j
+{F36ÒVm Ѱs/¸w|#-6IR?:*Αՠ2/<8+o’ {=^u:DOO0]
+6d7#5.; F&D H~B6LȖ4SHfHm)ʄ"jNMyjVuYa1X
+cc:*Am cO|$`SL4uɛ*M-KcbR% ~$I+I6t+(Fĩ5IÄ N/4Gg9μ~e0F XDMu&[O-3}'#uYiAA
+D 3B:9Z|$r`;h`EG'zs'Rtf (Q-%.!--UH:.Q FS``>Jlc\W1x7> ,'<%W-.܅|J8d8tw:G?\.N;68wїෘ&yQG Yd`iK,c׫=_gәWl2z.8|Mg Nև:<wu;AwC4]jN xY!'8՚THQ 9v)XQ1<zYd^Xa׸7i֗Ywg{X$G&_%ɂG$^$/' Fij*A=ԙ},=>@-eP3q>_;n>C5h7jS F;.nd5;93h7֛ԏ[y_T0Y7WX@%^j2 cU |}ic"q> V'^`,d Uk[+$h,\
+hlUp}\tc
+~@.m{7
+o%>. T/6Hku۽Q !^R ;h{i/+ce)l!cF6a
+NK;n=$)MBFG8fd~z%,VLA腍<&. $Ӕswo 0r`fkŠ%kdS(A3OXkv9"00y+0N!?ѳ#pᒿ _Sc.꣖0k`W@SO3Xh Sn
+g%#9
+ztXG;\npSՒg^aN<slRn#/޶
+RKE HJPVۦZף)]֣-]ם&cҖ#jР)`Ҳ/N1@/69GܸH.?#9!"%&ȷ)04<G=[4^-]1S3R>SLQTP\QePeV`Xd\c[`Z`Z\YXYVUSQU*S]N^LbJcJ^K]J]L`TVYSWS[P^TXS\XTVA].ZDZ$Qү*KԼ"G۽&D۽%Aۼ*C1Hս,DԻ-@ӻ)=*7/608/=Ҹ2Eϡ9Qƣ@YCZ¯=QƵ<UȲ;X̧>i͘4lϖ/iΘ0aΡ0`ϝ0gΔ3k̊=lƍ=i”?aAa?Z=PEIHJ?QAX¯:Uư5Sȴ;U̯8VΧ-Rͥ5XȠC]ěC\B]DU;V,`̬dЛ%hԨ3Zմ2L׵9Kܶ#Jܸ+G1>!),:: ABܴ"Gմ/Lֺ4M'ED@;9
+!!"%#!$ %<۪$ZĞ<]IeGfĤ6c˦-Vз+Sش!T٪ZԨ+Zխ,Xث)Vڮ)Oݶ$NNLԧPӧ']ӡ/_Ө8Uѳ:LӺ7W٩-Xܣ%Zڣ)\٩'V۵%OHG߯@ּ%Aӽ-AӺ2@,A/FӺ-JӴ/N԰-Rө/WҦ-UЪ,RϪ1H˷4D6G:MԻ1Nߴ$MMެ+L߶$89ٵ$N͡-T>WE\PcSaS_NUMKPHSPG\>eǢ8j˘7lΐ3p̈2lƐ7mÎ=n?j@hAfBhIr>r:m8e>`¢Acä<aš@dę>g˜A_C\B[C_à:cé8^ɦ8dʞ5h̜4c͝6`Μ,R˥.JȰ2Iɯ8Tǫ:OƷ6Iȩ+JϡIRQM.CJCźCMö@N»@Hȿ=J˾3D.>0Aպ'DӶ-Jв0KϹ3QѰ/Qҫ1SЫ3Vѩ5Qѯ1SѬ1TӲ,^֤,_ٝ(_֛,bә2gҜ(hБ-eʕ5cƝ:cƘ7e•7aCb=_C]I^E^BZ:Uï9WŪ8TƩ7Ræ?W?X;^ĥ?aĠ>bĤ<bǥ4fʠ/k͐,ṗ,n͉.wπ+wҁ0sА5s̓AqƑ?lĈ9o=mÕBp‘=s‰>sC|ByDx?|AŃ:}{2Z#c*v.n6v6xˍ:{ɏA|ǃ?|:t6sA{FĊBv̑<o}/S+mHxFr@u<ĈGX|`hUVFYCM@O6[0v-Ӓ;ʏCɐ@p͝9cԦ2Zۥ*[ޟ)aݞ bە kӇ)v̆1xȅ9yDž3wň2yDž1lɐ0k˓1c΢1\ϧ3b͟3f͜3eΓ0fϏ1Z̛3Z˞5X˩4Ẓ/`Д%iڊqw r uvpa!V߻+O־1Pѹ3VШ2Pβ7N̴=IȰ4Mɱ8Qȱ>Nƴ?F8GȺ9Hȷ4Jȴ,L̰*Oҫ#Nۨ PߨPKHE@? ;#;)<095;<=6Fι6Jͷ;I̶<G̾7Hѯ+S̒.Q?LDO´>XĴ6\ʮ5^Ϭ-X6CJٵ(Mٯ-E*? 0&*+ #/D.DRQ#aݟ&kڕ#gݙ$gܙ b c#fݚ#iݗ!jߖgedffb OEINI=2/F=(F
+L(
+䰴-Ћ*̢2b}!n/$9U*_=~KIF[惃]ӷeny͞\sN7ds<]`%`@
+WCgqOşVT"b4`FvN#wΨ'Τc9
+&yQlݠҙj_b=E'׵
+U]І!i΢Uܩ^7}ty>P|y*GT'-Xvl=\
+N2[ш.L_%䎊єI9\_xxM| : !w"QyצsX=-L~'8}moWk4+?6'Zkwx_M@*ύǮ|s=a_5 a1exy r/r]ʎ(tA
+;+EI Z3X{{TMUˀb5TW1YuՅuuy r͵ V+8tQXTY('海@%D/`|!0m"zQHmѩ<J-kE+:Cc@?t~q(a',}J̲4,<e';.nj+X&gn 8Y_OCIj:SG7%Fh6e6s l\yx+&KMthd˛E8R<_#&0UmM+"_ۊѦl] Ve"i#a>n\ِ0b?i2!BR&űYSȬ) SDzl_ ZF_ cQo`z')s ܔ, 7:.( >I_vN|@t nj;>'V^lzuۈ9aww}%GpEe 5r/43ɏȝf%]U+nJF0ͼ(Y
+%{Ays/,
+\4 8e8
+ ͡{da}bmX $Ҿty}geN2'zA8#wO3=.wuLe'!%;?b{ Rκg2/p/~~1O< 
+vRքЅZ&}smE6b4"Vs֣T6|܌ܼ5SvBn<}Cfg:RvتPYey}PXK[Ik:qxv;S{&_ZAKd["7TJhRFJfn=MrSզ- Ј6z36#nSm
+oyөK} 8bŠ,uk޸7U,ttw[FA }nXpP_{w#^b,#»QN6' FƗ= ǖGƕ> 1FSp({E Q y[G 6)OKC(u0rHRe9{Z:TV L\^/O~Ʋ Z,my-Q 7;H /I A#6xi-Nqw U!I"dotw! TɃURǃ"xYm#k0*zfCߵ//4+ YX".j% !!d#)NQDtX:Q贈$@Bv
+"j{~sϽ<=tOVO
+6C%u*jB
+Pg3W^CS$r'N8b&d.~qM9 #C;PlC}r} iz,?3:x-H1y`tS`1"YUܝ-^_9;R965h{=EZR'p[ӓmzt JT})z3jwo4Gށ[Ӂj\U)+&F[JbOh l,`OX5"r=IӾb'P;KQ]R/*8.'V7~90HGL+,pHVwD~.DL>¿pwQIktЯ?/*!CLII)!%%I IkIZJ?I^OVa
+?5g+Uuoj RB'E0=IåɆ[[ӴlIďw21r.CQ%) dɮN+NP.fr?PsYݙ#eG1y \,ןuA{>wF ퟲfgy) Tx,>[~sVզ7F]2+9; <˽Ϥ "Jd1^ehg'Q?-;=y|ovc%Rz#9nYjZqy񊼰WXټ ̮|aM1eE12^W3ЈhWc
+l.ޱ?4_lۮ.rd2hm1
+* 7Cd΄( nFp^!VOBtDz#=@A7=]> /"ҕd;Hڊ#tW)8M+j klq GOI#|\
+,00DNfh%Hud7zk޳'P3 a#gk7&Ζ8,[wxՑW+GVuXdZ? P'\C!k-̞֙ahCּu5sQ7_r_bW<:/OCPVǽؘ6{ۗ/ol8GJSX1
+l]\ۗQO*1j6Phg΋_6fXGḃ|m\@BhA
+BF
+= !d#,%@Ʀnvp:ڣȤ?ys=1V~քN< /p~c9YpÑВܹ;,O= ʟTΐپ)=$={䁘s rߖW7nxͥم|&ڞP4yvI4+w00iOAd7xg o6;*q̰߃~ >4! y]
+L|S mjE]>s<\=瘻PtrE ';[[;&o> O%nmGoԟ++kXO;QYIdiI2Pn&)גZI_U~J]U'/KSӟ kkL`u?a_S9ehSԧ;im{r=;乎Eɶ}6ގ4.tez}ǩM![3!ArVOUiǻoSoSK]y %;39mu9{9G[й\A2$,i{[&Hc4jI)C)J ')b;y9)젳-lv8.i*MlA2I⧆&^QҼW ^ 3sAHqavxbG$:F.9ӂ0OQ}^Df=85 tvFe:l;J+ D
+Dqb ]mQ4woyZ<s葄'OȣS
+vsZțoϘk<s,x,!}+Je Hדޯ$e aA\Hm 긮}F_?g\~;=t)Tgר}u>!1CDgcC \}|mBXNB`ix^2Hy&kmF"& g\쬎.v,0!r<]GfQMc Vד>moۍ\A{q& 6<
+X[iݭ-Rn|~ PY>..];'&c2SƜ1\FUb1msI'z<$)L4<Z) <1u%u%mi Iǵ筕JsEl'5y
+e15+aFw |R]3V^aGTyC+Lqߍz\f.0i[ИyN\]kƖj Ս\ eg[0/fW¨V"ʏ%[>za^HMEwv,Zo>/{W}Նo>Ԯ/(RFSUXތ<&@#lf8;`v!* SbǦ6:&uEp@w
+tB]8H$v"'2dϽFNcN *-=E.WmV QD4!<Oq qʲC7* v[F->_ٗ=Ur=8Cمmߵ2{zu-
+j(_2!Xv)kO &E9wZ%}v ױ@5sF`hza=msWMs\Zgqy9]+yfڹwyZ[/3ޜom9}lo rϊ"~umm;uzmA[^
+\[ H;-~'8T
+mn6Zɐ##f0z h 7
+M27 VZ*.ju0Rsv#m^ncH%KZNk&t}r0흄~"9֤fg@ߝNK00t⠥Ұa! Ng7Xah6? 3/ {]_u0&$LCitrMY,<leqRn=* ~ZӢ̲tFibrT2d
+YZ$-,1<"UOoxl 5{G)XhEN`y"|OLU|OKP  TܫFt),c$ԹPj&kɓ1 1uvQLhKƓ"zGIe$)3F\*V's4^5.EPIyU(f'$ 39]yq.s_q}/|O M6[R G&W_ (#hnm'i}kO<Ä1̪gkT
+V+.YA)GpW`VCSk8u[%/{&N q[GfUFAhS4ΉK"liY@pe!zَ4aGEXbd6hKG,𐇌lDK-L/UH"/D O8AVXq;y<XuzW~2VPg!Rh:/?8WE.
+齏Qt@yɣsCҕZX~
+֊5wB$"zq:2*Uz<<1wʽq6廆<
+]x3ϙs3sUfx
+ixFip*"78组5清7H(umtUvV8` 򳬢z2"{XG -8l"f.adP~H^_OU=˔WW:a$K7=8wdu=Yfˑb,:ʽއSucW\N$
+4*r]Jy9yyFF < eSalLRdKS R|G2X{&@k{Dc1Z!G=
+L}[FVYЏg Ns%r [(QI4njz#NZ`'wIdu>G@ ;SrsgZ}T@z{5J_f\yf-VijOX?LI'_g_d'OsnٟNFF%rR 48Lpy#7,.t?H"^\(8GH_]c_F]\M@_bFO6_񊪽P齐`Jqa(._>8/>\o$i7" r-a;w 钠Il> 7v'
+êFv?3m;4Q63@=~.4;sG'|_mvu5H,pa5U
+>SX8?v9%ѧnXR"0~AAUxgeW\UX^:T8O~lHFQdq$Aۈ"Xm8/AMMxgIj v "ӴÐYcRaD:HUtjM߬{7{Yf*.KHy/P.Cˇh{B67ڀnrcLOiC*%]XdF5]N?2XR+@U)\/V3wj]sfor:}93np
+A(!a2ކ$|JOcL`5kOiMOLHJ'NUč :G9|Fix+gwutI5)\SXeWY#_1|U;
+D(
+
+ϤpZl`iIzO6+Ko<8
+ 5B,Xm&s:"(A)EށKdE} 98?r<kUtȻ`X{ S\܄>2c
+kV9ztA;ޢP_ +a::*9DC݁' P'la*[xGM4`$q%2ARX@ ⨬,7")w絡PaW([B@}^: *1.L~@'q*] s wRXeǘ!:JX5A4:Fb`'HnzuVL*j
+)æR1 *l,L"B&Q<vfoX1鯖WH/fs[0)ם[.{hۙUجgyy Wtf0.D޻9702Cr-wU?ks/c7P?'͐VYOU[R*,'nȔ_fG]>=MH<IϰӼLk-E U!5bDݾƼ|̗AzUy ,/-~-/7q$/n \ > 4@BOCf1wMSfR^UL4P&x9qDV ϐ;ˡ1#UzL YH}6FV(+KXSdvFM~ HBH[Qdq,D4`yMx7G:r<\.ga彎)WlD?C}_rLCƘW\W"'vt?`>%aNY0&4㟚>Ԑk^ih@[o5Y[_if{OmTJ*_&F
+fQ@Z h,Ae~,
+523% 
+Ӷ7MZk3iӱ=`Ѧ:^ԺAF:8 77:;98<ۿ#A.<+@$@+=#?8 (.<!9B֜-aɕ6nĐ7sƉ;lÖ<gę?i×@^àBe›>g™>f<câ@\Ŭ<\ɥ:\ˢ<^ˮ6[ӭ4Uۢ2Vګ%\߰W OXӜh؍b j%tܕ2kԭDS==Aڍ3تK?I[F?BHC@ 6
++
+ H U$dB"H(O4)o{ݝ7߳]Y`KP$
+AHSBZCTA0S"
+ XO ;l[s#,PwA5ݕ/uY2y}E2=9#-2\?e?\|) FWVnaIo^[aʷf/g=u+{7-0p
+ )`+buxwLH h{đ`D@(`k
+4[JMG_cC*lC+ !@{[R3}7.;c%.MxM|b9}#SR6g8Yh9U!w>?\?TvJXCV?_Xb~?t_֛͐Q7Q~a3W=F|~@]7CPZT 
+iTZ*{9,B|Z5f_0}C-f++fh_$g;7T
+= yA\ 3L!Q)* +&Fv1\@;;;:%
+
+]I=yd~6&t ҩ BTW pyɽŻM7k6ܻ䃭T:ҍPZ{?x}a\Jju<b8G~ѬvAp|c'aMĐ#1uEny5F71b>-<WUo:硒E7PD9vI\(mlD/"z*P
+M >$#ݧ6P94Fwn `;r-'* odң٥EE[siIm`Sqi1wh '4toRQɯr?B+6Z}G~tUvqDM)Iə7iZ?T˖e.km}n t?p+w:%; &b0(gG(0)L\d.S y.;dz~]r=/p/6=YK\ l0wsQ'%WѩzE™l2`3=kwp~w
+C U9\!FċD12)1DR|H\*.DDpmǪ̏ XFH!%#RMУCm}$VG/A
+PA
+B0;,'TF[&kivt+ݤn3n=-]mgܻou_m<z4L7&p'
+ RT5
+
+{|V_.cW:mBzlN\)7Z5"-4D-4i%Ҏ&L^mC87F/wI7bLD4k #V]_$[O9l2hk<1Y5ZM,A ӛ}kj>m1z
+SJսvJuf&K[KlC&ب̪ӲQj)t@wzj:KWY:{2f^X&!WoCsWsrn$uc155be}\Te]RtEmR\e 9q}Jd#)(
+JY)ZM[^{6\cGi1~ń$L;NTW VG³fЉ&{ॅ&<fYhgx劥ekg}Rk3v{p [v}kzEh)ղO.[M/ee2=cpSxGBKԦDPCg1|)[{{IGcC&˝o{pujhY1ˎyGch/d-H_yK(kv6D#$ #a5Nт
+x?5_NTL$
+$Y
+(t̔ޅuN!ω
+Pg%d#G>Dz_?w!<ʨ΄:z[Hݜb7'!{
+YhOAQ u1=^';+Z~a=!=MF@D7=8^{PvӽT%<HbT$0BZi~v/PA]@u
+,W|QxoE7p? oy@
+?
+:_uI2/ ֿ{c삌9LÐ&N4i
+I+J)<9 /YȟؿCO{y RM. =  Ӷ?;j4D(U.TB4_,_l-%v]OЀqKk_ {;+Gq]@ap:<\Ҏ:!`yٞa&2v֑$W:EhzxÑ mKx9ݚ00;9A&BF(9!t8'cnn~(e$0Q[gz=:2? ~k:S{1DDM6jch&GDY0]nsC;W Uݝ_S䩢-MκF+@J-սT
+[ Z{
+X5ЌZ*M-|g`.Քuɻ3zߟWn8PJA?΂d.g(]; mIR mdtGC_^6wŽ2s\Ҫ?<*5 i[$
+ iu{Ϲs]w)-+7\P74APp#4L-7f=sy{~>C-t
+X/LCƔz[Xt/mxF핣+K0l\3A-1
+[mwL
+gZu;zz| 403'Vv1/mP9ދN:Z#HRau>at{xKq)RLz3\.q@vǓo
+(z}[+6凶+TR1u0i"cnH\?e˔NIOvI+EKis)Jdi &i _l;K
+pI?\o8\k9Ro:hOHFE#It a{-A|wbz x%Ik<RE9__ڳN.
+WԘ+r׸' G;Q@c"&7 c}4yAgZG.@y"
+
+#oue,Q{P)"ML&We
+^,r߆&a,a@!V=/u †Hv{"DO_;DB7#0*̮aPu2D0£9 ԨjjS
+{ yUS3h)tzlrNJ`W%6)x&;>?lyPRPIӴk*h
+
+'m3/wʸ>Nm_(0?%YS$#ủW.k"&Y QikjA}ղa%~h  xߨRk(?áyj Cs4kՂFJ X9Geh5
+
+-PBIv1-_E.A AXa0pc[n7/}r%rS!J!Q);lz]WZ.
+я3mƵ
+j~.vߚϰMg͂6t[>Lw{kLf6=6v:b"s$~w
+,`Of
+sD`DلmD52|\eYFIkqsBE%ZcG^kQ{z
+F_4#YQ%%Ii /*^&~UO"'2_۪]5~q7n!zP DŽ2) aQ`ibE1VXj)QG! ; ֢ "k-@r
+5aq]aIfk
+;>69ѦGQn i;[R4)m;Լflf'_{=yֹi_]/6>NY>:Sww 7#,w;S/n"B "›j2%/`vˈy
+sr^e6{&`dW뺵ZWS@^"ABf9X3Լsp *;*HCY1Yr;,MT.
+zp]Fħ4a$MLiypr[f{F~e4` Eg <KS59QDRV`%*JfO-=[A2e w](^$^NJYϻN)FvWe*H{D0{z/br%WccߢIa&R"<_@1eh<h<hp_w[\ +btRPzsnoӕ^<!3
+&J7^d>,rLt |C9Ⱞlձw?OEyғ '&`m9u`{knʭklQ(.  \ dʮs~w%{TWs9-M]v۞Z,YlQ}?Ec~(p#ܾٲ_p.$_p/I b;p"S{ډ>nhЃ>OAr"cE6Ñvf
+b@p=ai#m%yNC&TA#>FP 8$EED D+81Z2Qo9Һn@'+k:Dy2F=Sj7f+RkU51Q{~4%7(Fhݖl `$ z h(ۂ+a?UG1񶄿{gNy9}(@xIz-Ћ Xz]Aa'ahzg u 7kJ{J{r˴ p r|
+_)O[HlP[":0 xY@JZ}
+5I`dC,PO8ti5W_jK&{ wi b缏a%6}$mXL 0E n9hz$i@\ڑP#"t<DNhOҋ$2Rx^EU!F%<0>fd=|q6X'`Ěk0df4X55&5
+3}ͻX. n҃e]Zz_J> WPZp.MVF WZ2
+GU) R8N,Z
+'eK慎3\>pSw!n[Hnnp9n
+
+OcIw&Y>w@E3\K37W9 7 &57v%Iy, \QC;
+EB%@613 06!)Թ@Ϊ*VbO <5
+< 63@IО%\Š4cǖ<gđ@iElEaFaJdLkEnFlMnHzƔ>uӫ2WAKYVWaޝb֞fѣ!`Қbӛ!gי,h֬8U;@(9!;#AB;4.())%##"##  (68=GJJB60 --'     )EN۬Tױ%Oײ+Nצ,ZՎ:px@b?`D^K^T_]d^hbiSpe]]`Z]W\TXXR[QaBYð7O˹9E2Jھ&F$@#=9 ELW WZTثUԦZآMܰ#Nݰ$Nܱ)Hٺ,A.=-;+?Ծ.@1?.QԱ5SԱ5Sת&V՗gч)uЊ7t̝EkЦ@Yݯ'MKFF:7H YҦ&jΞk͌a͎^ݘ^ ZNE<974.--( %#(0 3;=
+=*>AOԬ"[ӣ&\֬4Xե*\Ԛ+dӴKO?> &#! ': 8 . !%8 78<
+Ur
+;"Ysw"1ѝ8 n[iq }?LJ
+`
+= ^x2XKjXngLw00=S" un9ɳഹׁ9s](~M̛66$y}&5LXS'b)7hCONIf_mW^ T>CH):ҙi)_\9XX2#)|K(4ИZZ`}b.&4wnAnA9 ‘ 3DCvug]rvfggJיR
+
+yrFu VWŨ q|_xR_v&Gxm2m<}nq~&g9Ωs<60 0Q6z«g}_V22(rfnLmW&ENhȜ j$ ܄Oh
+jp3
+H7Tm&<0Ⱦt v`:~{6_: (1N@*]A}mvH5ފ>5C7fa<h ,,"dC 0+ l1IkX-Qs!cC%acdTS͎4Dmk[%LT%˪G$q(jvŋ"Z4+u">w5hH!.$i+}2R`/}d8Q(nN3qTieޙ29z%m5wq.ݐ}ZcuvQjcAѧPumKŚ1 |xj9"ۿ^7lΗX {(P;5 Z@C@)'n>
+1_qyzF. gq s8|/GAim=?#)
+F1x AA],g7;O]2+Y?Ϛqʞvbn5spߣPƣH3يgXBIWMLgW Muߛj|8gcg?ck4mqrᝩջYwv>v5q<ái8 ! ! TڝݙuqEF!b@
+H!G r r ~U]u>;k2]ߕ#kV"vm = MFƓ6G+0uzC-=֚'GR4 r߃ۘ =?$0:fX2EH)gE<JF 8:CI* %VTAVSu%,$-rc9O"hs0|),QUaMZ.9JV1 2w3zd=Tu>1K^7,', ̈K '4%pxu?9ʅ8$@ɫcƸI6OYi/}R aA!ܬ)|U`{>qET$ Ӛ2<\nn 1;
+qNG)62";`[Ro:EZBB{^b!zcrP,{If3+;7*
+(> n%f=̍5?j,+:MH)H)sIpNg;PƞSl۴i"eHg8Gȸ~41'0h- fY6 Lmff4᳛pE_|՝J)u%bCq"/tHNEe8j{ &Oogc"Qa9>%<oIzܔ<rvg sG+O63B(E 0ˑ!L 2dd0dz
+9'Z!Ƹaqr#,AUe8Ƿ$͕ۓ&KPQ mU='ϛ( $3Z 7&(VD*1U)\!R^NUq#5T!P mj#KgFd=rA[X0/*2Z]M.MRg_ܓDOݩ$II A+ENjONq&m2\ U2A@A)BPHum$m;~nai=o+}LT_"_$/i J׌Bx0zVhrVa9<U7$Kg}e5#liw_y~rzx\齇֔Gy4R[()U!!!on
+kyv&H7#VZI/CQS1],2tl 45/ 5l$Lk7ƫ]j iGju> A!4W)m
+dP. }m6D?aw,})I]n?awҊ0[y<jFCk vX15wyL׼1
+phroNmGե-1ZʱA1uX7bL1-sr4:q#&C܇&5ǦC^ھ۝:ح.}n;,Jv}cșn#wbs `
+MB
+2 )5 DN
+bniWG GZ
++' +AQ \iUҷ/^]J<D?=ܸ H؟a֝1_ӡ*?Դ/ؾ0:AC A'G?SRP.@> ? 7 <S|d8i>m•Cl@dà@_©C^Ĩ>\Ŧ=_Ɯ;aÙ:`Ö>^E[McXX > <
+BMSۢfю2j˒0`Ǧ+]ɩ*dͣ jԔ$cؤ#eܨ/[ׯ9Qֻ@E4B=3,.$(--#" " !!  %%9Bα1OOUݽ.JA
+"EWԛ#cД1gΌ6YȞ6VƤ<Xġ>XETFUFXG\oTgBcž>a<_ ;`ž<a=dĤ9aǦ8fʦ8iΗ2iΓ.h͔._̙+TΤ-UШ)Rՠ [ߟYXX W
+ZXWWVSR S OPVTUX U'Uڬ,Uե&U١SV[!Z1Sӿ=UѲ9Vң)WП*aϗ%UҜ"YٚXUL@3.. ""#$-
+1 3 241-. ..,+* 83(#%:Ӗ%LӐR:HFB<A4@2!! ! $+.8= ;:8
+4@KSXX&]ܣ'_ڤ)`ٖ+[՗*TԜ2SΞ8Vǟ=[ÞH`IZN]R^WWVQRUSSR[L^D`>Y9Mŭ:NųAZ=cÒCeBbEeCeEcFdGdIaNaRbQfMhLe@b0Yǩ2Oʧ/Nˡ+Qҥ'Rت(Wة"\ަ$_ܫ%b۱.e՛"d܃ pp
+I @LB0|߼}>q9] ]IYvz@5mm7&U:Z0'Z$3{^&ft?f5RF`|\@\ܫ(P;6Kg 2KFkҙb3B3lM*[
+_u.ZuMn?wAkhNMI`ZH^-xǃt#hAAx{>
+QaU
+G+kJsᾋt^+\ u{9WP@YDGrĺ
+!
+$s>_r ܉ެkKk9eNҴpM|A,vE뵮91ҁa[eRXl.ӯZ]]L2!:;( X"y2/<o/ JDLB
+ G2ёOméB|<\ؖBBL[Sbo2)%3ُPg89Y`pbO&bX8]bz CdZEslhYvI]-3qld<'4uCD @V@SPw} F%^5L7d$ ZTkc#8na?XRFx( b4B$GKe3^k?Z %AK Qc;(\%>DFp`"Y";2#H'}k( z^\]VSXk*1*K?f*p}LelWƱ DŽR&XOcۊ mOc= ]\"(5־*bSbS_^_(@Bo7Xou[
+d
+BcKс ?1Ds~E84W
++ 
+vW|ic&M: ZkF_
+M VṀ'N+ Ʉ   @J,%6]'ߕ^]~mGiU3
+?zgGzapAj~[zbzbVl֥FS ջ7C7_iޚOg~м9eu=R
+;isߏd!Èw >|:dg)v_ZYiP"9`s^{]#f>G-aS/%
+ڠAo1X 0w7"O>0K̥ ,u~\iL%ɺ.#kn9;XSEZZ} >M ZJXy,c͐mʢB/(UA3,׹ȍȷ 'Rx]zT5 BfG
+߮?9xfVS"
+mL%?D
+;ީk;JӲiwJ=?~;(&MD6ކC5qNmDnEnVgU/l Dئޞ4ir -*C$)I*u%UDc(%vrlhw:8D7ZKf@y=_ĩ,xn$p%I"*
+9\qgv\ueTH\׈(wGBABgK9 ]uUW?_&<iUR4yf |?a**sIV)Bnjw.G$IO-8ֆ>(,%w4B󔄭7=M4x|_]H>E K6čYM̆ǭM
+cBbuP 4Bۂ Qj&DAP#(
+5m4L[ZA6n[$54|I
+ja{.6@с%+8Qu@7f3l"] HVZwY4/4ƒvރRÇ!460Sl*gLmB-ÌKZ-UCi4`h'؆U|xEܨSA6C'2YoG,9(q MD#ޜd?m;MZX/1tٛP9}yt1(]
+"{ըoðY J/'2D89i2*XH +RBiynGelRFڱr><nHLx.tM,(r}@'l> xJ:6|y럾9x~ǽNu;)N9q:[Wj҉:I%IR -qhȔڒԚGqY¨*ߞP_~QP+?+/4;7 '?[P%~&yOwW {xe$^!_>m>A$Pk%5)&gv=g%Ω"b#[|`i`F21Q{>C r?DH~xL-ȵ_UN=GU
+Bԉ^^9bDm#_G% {
+$m#VÅ8Rw\{nt󧱋vɏ=,?!@JEyt
+2448@cy'qynq*DQ1PmTI.1My?x˿(n;6wzWI@r+3$~55=W/H16{_9~#yȯK39ggί#ȫ+ټَs'__N=I/L9VAO<Z$.ٞݖu}tur=WyAtmߓ|6YFdޱ9!JCcG+&+LGy g|,͎!z*$jy/)?(z쒠?ǯ}K삸=
+IbzxƊz3]':"fztև_,H"$as$g^BSN~ةIZĴu:ȐoAvIEiT2J.c#,zPI( Ct{RDpTq:/)l 5ώzGX8I .F @[8PVV/Jṕ}ף#tAB?ÒwB{u:\B;r4e]i\qrb[xrnY+AGgF^c,] _r 
+UqtpzܪY`亸o z@0sl(lw igqGvjCU&"}nGnw~a_[ixbk1qeyq[T::f
+L4Ȑn 6Bp<c@zu<Ka
+hiM9uL֚Įڠr~qŤsw築?)ܕ xbԽE5l8}x gWErL=^\3Z'~;/
+U]~R!o{HM?!|hlph1FR!e (',I:0=뀚ۡg?8/ʑShi7[٤d= j43]i0˂a"ԭF 0<zCC1,c$DXEc&pi[јZm &G l{4
+w (Ć;c|!|Ǒn2k)J`f۪ -0}fOOWmAAׅj>l[k
+ 02 @oNFSz;pf`ahfm(4fV J[G'6,ŸG댔* .@wZpX@#d+ÓK(䜛b[т>׌
+S {
+{Lλsc7yStwC#w/Kezf_y{
+S/}Eġ2r"8,t2(6lf]~tNM>/Og7tZB(>S,d Ӿ'-C%I+2x V/ qqBXN95djg1-x b_E
+1RӅO\ytkd, +6T[=.7bHQO
+-,SZtIǥN9혳tS??2}'Z?kEe}(
+Ok,= $R7T^w#Y\<^.s6˔>"|p? T_ S)8-a-UU>czrW5Zo5$ 4JŁ{\Fݔ޲ye{;?r-se>flxY_v:eTNït~x<+g麅ιGdW{.
+/2jI!@B5l¢a)\TcuSjGkkt;.m
+.,
+!@b Y ɝyy߻ϣ1?6~$-}7
+m0:&gμDgTUy-KڐzF.L*=H.xB1 ' 2E Yf\[_Fl
+F;χHST犛E݂,PSl/jrrS0…(|T(~&}8i7y&ˢ22҄U\Jk|-59@ j@:TZ"^lY0¤.!)0 5p! "ދڪpULʇ͠
+]S1m+4Dd:RcǙM%370{7˻nw/uD<S-A0! FC\ 88(xc ȍ"0ȑH 73r'N֭`xzu 'w9^գVzk_Fk_֩oOoԝ֨MS5~O"0A5 ab8bM=8}#GiÙ6iCYR2
+aB+hN,r6U /Gҋ\I᭥auĚ5%J#뫼+"ލHzC+w($!%SaSUgа2
+KJ0V?&!VGӊbSeA\aUZGsJaJJ8[`{i3v[b«5]}qEwweﴃ' BeQbHv~;wE!gwH;@GLa7xX㶛IVf@VuP%,:7G;i.W+q% >~zarOL{z{.ZW:7PbIdʌBgI3Y ?A'2a 
+lq
+@6x4{5W{uT5v+ofߙU|XoA:`zŞ&?՟B;D>Пg{s 22/T2C~sx4A!FSn ?/7o)o{79j75b1XV 2[}iru*0qWH;XL#DvC.']ݜ:;m$fzM6@9 f*U~e (j >ɏ҂iskuoCЧqh ;x?׊kDc|{P޽-X^2ދىu9OsTR'X/덚[JkO-^h:uߍ&5/Y-/Vѽ6L4t;@
+w&m֍G#* .ͼ31 e5CuبZD$7ɷ!_K&Vl:t}H
+K^FVp$9_FXh_,Nq*c`q
+}?/GWUSDb5e
+{*['=l̂O>TEbK&s-lD; 9СJ0ь>K?(c~<&IP >E9z<>C\O
+*C#VjHKO0nTy灁l!C~CטP-evm? }6m*#"9gP
+)0{g Ljs) .i[G ; r Ӥrs RҔc{0]I~i98Jp"nlHzQF#.?M, wژ®<XP7]ۤ4GLT^)lI7>_jKWŊɻUi a]I'۹R-𝺯НvK_R[K4)V+B!b/yo=HA= !U @ 2cĩ,9DCH W}!
+""(JͰ;:NΌ;,r_rW I
+pc N^! tg?N;ӌ7^
+(ԮUVV
+cӷrc<r^nn!}dum}kZܧ=
+: 6lރm^2AF~*&
+<hIwfVH,pp}\ae8`rnԺ:FOf/YП
+S'^X~AxI+¤p=&>rgBLaO2|32deV.>q:+& JRGO ]2x=ΌJpOHnXQ#&ARM#35 T^qi;qRT˜uN %*y{IL)˓6>!|k$p܎ U8g : "g?!{Ζ#fewsE yߐrynsw=wڥ Ki2 q1ꌬsN|}Nz{0ZzD8}5x{YO'C_:|2\Kiyc[=g"ʈa
+F%%/%4H l#ܾ;__ɾf&w6ϲ{9FǥcyͷsiX7.3y,Wll%x:gj&3@G̿rn]_7)bS+,ծGz% >f'76ޢ~pQikda2M.xʬ Q^MM*:lq# T^=k;Fc<8Df(FRlD1¹trh>XL U[iRe0q(^Q ]=pd,z bY'm_fN3cEm.pro_kyUWw˸oDWrg~@KlOLT$%& Rص~'Ce'ծeGfoOȹ8\+f$:Bİ;>U?^=Vj|5!y
+
+tuxYNas"DRf1ז Q!
+ki
+FQ
+; >:BKTIJCA 9>7<BIRRҲ6_دXڮR׸H1?59!;7:2'
+52-%#$"&%% %.7ԯ=ի:ݬGNV7XQcѵFQH; 6 IߊEӓHEDCC$@ݾ&8#'% -6=:^DEHG
+ 
+ 
+
+ 
+
+
+
+
+    
+   
+ 6E
+IE
+* -8 >BIQܲ'L-?6,.34? Mfv'bFQUNUURVHRFFAI-D߹>ػ8̽8ȸ'<ͳ@<1 2
+.,./.17 @GKR%Yܲ.b՝1eћ3dϔ<bȡ1aˢ/cН-aњ,aӝ-`ӟ+d՛0gњ3fϚ?^ǛC\N_N]M^LcLcL[GVE]Bg@hŞ<kɚ9k͝;i֜/`ܟ%]ۢV׬!QҬ&TЫ-Y΢.[̚/[ƥ9_ơ:aƠ9dǞ<dǞ;fȜ9hɠ8jΚ4kќ,eҞ/b՝-bԝ+bӛ,eӖ0bѓ2Zˣ:Vȩ7Vȭ6R˴=QϷ6Vس&Yޯ XPMVڠ$^֚(hя c͕V՟J< 78;;>"<1@ֿ/DԺ-GԮ8Nϻ0TѬ*ZҤ*bӒ*p҆({ӈ$yڋuqjg$jކ*kׂ-iӉ1fΏ1fΖ.dѢ)`ץ"aݢ`abae`bd%d۞0kє3i͔9\Ǣ:[ƥ@ZF_KbMfAaģ:Uħ0HƯ5EƱ9Dŵ=Oï@TEQNQGRB]Ʃ7dȧ0pΌ0r̍3ř4n˗6n͏*rЈ.tϏ;v̇;~}AwP…CyǍ7yˁ,}Dž6}ǐ5rΚ4gӚ3gՆsB
+@&L~:(w:}2O§'zNw֡w[dGiQRǵYe2wW β.)2)t턍Sa{UmkF>,RS*{'Zriꁘ]Ʒ!NX2ǒS0}V:\dt*$N>K6g*372ܰҩ{t)P *]ǝ8j}zeHC5jGMotHJx>TrkVeߝ߈n3܋cי5w\c֨:6
+ɱo
+C*/* h|A:R@<N{H8A<ڑ
+8r>V*:F]":J0a,[Uz;~D>sM=?"z
+/,.E30($v?̏vaE Lå[ 6}kSG1
+GiI-oi5=4*0!Y l匧7auJbXK%)xIb?vJs<v?˽#BHu=+ȱ;#Ad~E^bgxļputAasy%'5VYAK$a"}R!n*~{e(n7S]aghѧܓV|yɦ8_Q 8T;\
+ip‰:lS."L\f%,Eq#Ѵ"tI/D1 N5ʃ XRO8q(On 崢qF
+3v>,TZcn
+
+Pao
+1Bֽc @a^
+{rw=Y\]k,U6~jk_ ]|nm
+}#^Nj#.+$NxE{3R=˕ꤵF U:rME4].2E9OSqmnDwZ^oGMҶ 8OtČ-#fޣ-ƸI:`
+ɕN~
+*v}CasD/#eCRN*juWp>nxiB-Dz@egGYRZ^P-g*|,tZG.6-VP|NSYMz
+>M겈Q n 3܈ِ?4LrfLz] n:i*Uo^im%^Rc=Vk N"aڬ1r`s>s -KDhӂv5s <rS$SYn7
+Ё
+Œ-RJdplk!maNC(*Xa
+_4p
+h W̶+dzz9e$Q@p7lubz4UYxz㆛lMAL4`i8Dy
+2eaE.qs:{H3nI 꽈d=8G1@M^5XaKYcGBAHS4s\,Q&C91ero]HA՞(ƫhjucNd%UdPTf f/[#~}mp[`6b2lQ
+ͰJz%0R wo~m  bzm9[J}_U 0px}?
+&Gj];0I~jB6/'3@ )&
+¯ŧõ>׶(K׺/D-?#821>CI\ԀRΌV
+VL ?5/0+ )
+*.27?H'G0>*5շ"6ګ3.*4#8޾#>!; ;=?%@,Eָ'A٭@ F aVdmdg
+[X+Q$=ܬ9 BLV^ m1nּYF):0Lbӏ(m̘1fΦ8`Ԩ.[ٚ+bԊ-aʍ6bB^K_JgQlXkؿ1A&$!%(-04; EMS׬*\س*X"K:8.+3?D HJHK_Ӏc݅a"c8hҳKPܽ=C9-".+&!!+47տ!/(389B Q\!^^\PA62
+- *$ #'+025430%+ : EE+  #!!       
+,/*&%)//04?IQ(Uڪ2[ҫ9aϝ6^͖/`˘+dϗ(jՎ$mډ%q۔pn*gؚ4dΒ>dēI_Ua]gUbRTSWP[M^P^VR`KUGPHCF9Kų6Oĵ5SDz5Oɱ4Mɷ6X̩5\̤4\̧7_Ϊ4`Ӧ,^֢*^֟'aԠ)bӜ+_Ҥ0_ӡ*`ӝ)_љ0^ϙ6[̟:Xȫ=^˩4_Ψ3Wө4PӴ3Rڹ'WVXXQ߰QީMӜF˧Eײ?1+08;>.=8H/Kֺ/Jد+Qנ/`ӑ.iΏ0eʔ2]Ȝ0]ɟ0cͥ,jћ'pיsߒnon~i"fߖ,hԒ,kԑ(jؐ!aޛ\[]_^#\ި%[۪2\Ф<ZȫD\ħ?]Ħ>Tı?Pƹ<Iɾ8Qα8Xа*Lҥ'?ʺ97?3@A=Më<S8S°9Sũ:ZƟ7fƏ4jȣ7xˏ:{:p8s=zAw<m6a?bDf@a8k>pMuFÃD}Ǐ6qΕ,kϔ,lϓ1mϒ-e͛4[ͪ9Zе<Z۩2WVW Xe{$`;f@dF_JaPeJ`«BXɲBUԮ8Vڪ)Y"NӶ#Jѷ'TЭ(UϪ,SΩ*Hɷ0Hȳ3LƤ(Hɴ2G̷2Fκ1A6==8ǤiPwuK! @ @677vNLzyqz2NOәN'qڎq#
+$ @$!.@еuOw{gwoG;:-=z8p\]<ѓS8ޛQ8іZ<[6MjaE_G i[QT|jUprfD$!]#Zo^0OErUhGdc{Ũs˖F<?S"i}sDc93fid³';RqyǑ*YKIW=ӒV3sf%VSk;r>Hy3aOhRhiSKy.v |羋=,B3D)5#`yPAm\2):^ߠ|wIu?={wti 돩o(f >Ρo ~_<$@?
+
+K|#d^JyKllzO-espt+ڒ"pr?,`0g4
+}OLf<pJ#ofhiY9Gl;S3N2hlz86O-)^l-Uw]Aʝo1\_!yw߁_q𽽫{Iʗ*usлw?GjFk$ͥ?8\Ze_n/2Cť;L`
+8
+Y
+K=耄
+uM[YD7|r54dLt%+quCV1DY'M8isZ(F=+.8Rus q鲍D^ t67y*1'cd[i9luJa FyzΧq
+6'd&Lpy\H?ݞ%[(\1΅1רlcPҒgp@01u& lS
+;K$c(9:|l74jv.3:>4 tss{g$YQ%yX҆`Szy85q< =O:@
+
+V9ha\Mg刦Rx0jM;>nK4wް/ӋszhXmY0^Uّ
+(vҪ3 AE@BA
+j7kl
+vSNt 'ACV;k_ĮX乇B;x~qQ
+>ߑsks = 9]7cvH-tNyj֭9ZMo uG|kQO,:ؘTZn’ :oÜ(`FQz-ly
+v
+f0'ͪۮi+bRBhQ7Ӯ%e1x>57Zm=r6`vN0ЉF74qk\mb|BlAFʎuEf
+Bゞ:x;NFe_K5Yw[u"!܍pP;$fzgC0CE\}\6ww5@ٻIwYr׽M9nۊ `6c/=#;=
+´ԁW;@#C([ԍw}@
+Jqx,A-=K\CKKe(Uzfʽ2,eK^g)2ش2BCIާ K؂ʠ,auPHod$ST, 򇋰'TFg}Ι9. IaG-=ԏ VӔ^'% 'xi+BΪmq^O+oώ?"su7g7Vc+KYRBfLy%!SVGdI9c
+!O+1[ZM0S5=} !):J8:XMlJ$ UzEEP-Xcq16ڇ!!?/}Jޛ+goN3ٛQIx]%`{Js٨}u]c_ O/xf^np5\-=}5;쯫~Iþm.곮G|䤎Дő1eG;";K#r:ʙY+al~-픨zZR]C>  V"TNIiA4A/+`{Aeȯ%QpfW'3ϭcs2:R:RCc*FVVyNWzejO\s"O_Dl.;nU% #֚`7o>0\zb/1s
+ڀ`@
+"*eP.u:W؝GϣTYS7w|~ ^7Nz^=_/gO@+m}?63mAl0̿9@][K jk8#Kky\wێXmܖ -Mj\Aii
+R%롦)EwWmW65F\\Zu=yoh.L1
+@tl%e)7WsꉬVtGţv'qO4%ۍg E.ʚ>%wa`ȳdw9t8ϰ1h Yq;Pxoq=18|g^21HϖVR?1WSj'5Bۮ '}K cN ;ܥB/ߑI?Ѳc3:̌ܖE 9{nOr"SHh*oN凝 c`r>5!Wf՝ZDO2Αg
+S,)N @IBO,V
+*bY !68W^/ ) 戫B&l6P2Ǜ2&b#sdU/Ǵ? -)z/#^kAt i5#酐0s2$A35RB|̚ꢦME\Q4+$CrY# npSCy-$HT.?A~5W=ŕ([_)A=hxKZEɛxK)jQ0Z72rE f\\M%d򔵾ٳo)ɲ%Y[`6co^m އe "#L8}I6$*4@ H"ED`3q;(2PZ("%@H$ (=e\^{ys~l+yN7&'7r'YK#~(fqiYNai)ۙgu+ە~{? ht VrLUyJol2h|lL06wȘ;f3mmU*RVO1Qp& agdnց\'%`OS*GN#q=\*åET:'4[n0ާ95f*]~Y~I-'~+9pt+*>yҏ-)ߞʭp4%6=>5mM|V۫Ixm-"l$
+uQanWVg<nN8ߟ>Jx9[ҊOo:/%\V$/] ;?
+Aq K`Qֺ=&̕_h v!+$A`h./x08F2dPE;};!98;D܀ 1y8҈Ї<Ov
+Q1B0U׶1kΞv-k& ᒅGk.~qMr[ +(΃w˔pF2噎?+O.͔$o:nOJɋC15Ez$nMLdn[i抈b$_   B& 1! SR'_PɯOvIX}cDDt[5&7rbjѻADž呙m,ϰVpXˆPkfŞZp?{e x
+Km V+GTbb/sWn_zHӔ笖QwN쌞ȵ
+DEH1`_1-w!%ElRꪄ:VzV?BbߧaDz;K~N1}l:դj!i*7d<].quB0,Slj5kfi\4y%B۬X]W<㟳;~"s؅.e}=S蛂W~ >,xFN7ҭX H#zHS
+ F
+BT;}_*&~e1L黶'Gئ=|EҷA5
+|\$pjhna+B +OcqqQJ\,CDrqgggQYܿd5_ Q(,YD\-1!Vˈi
+MdU2dDS0L()*uRaJAR-{\=.|z"ď;W=\n=RdwPVO V 2]cb+`ZF8Xi 1#9%duv+S׬gX>Ny6v1SvdOIPy#.OC<fs]Bk
+TOXL@#HXaʛAOWx^eA-{n3 p<0nbYEwJ
+00\/Nv:[]Ip'u׻--t_&F%Ro'ntSb1qG'Fd<VJ Kq3s<IS}׬{[yܽ ;dU 3A<#tN+8fFg:+<"$.4KU_BTĔ1Н
+]_]%bܩ.gע4^ԧ=Yը;X۱2OE@< !-՛O_a2V1KԦ>ڲ< IU `hKbO@>
+.+""$"+.28A S[Q0''!$+5?D JGBLߙ
+gxqvc SLOZ_jt t#x݋/u՚AgѲKN5=2 .4+ 6ѷCשF91*,$
+4 :AE(><>Զ%1Ӻ!2,<.A-@Ӻ0Fҳ.FѺ/F7Iͽ?G<NиB\ذ/V!TZZ ][[_ؠbҩ-W֭*S٭&S׮%R׳/M۸-H&D@?8 ,*+ !*( !$   ''"&+ ,
+, 5 ;=IDѱ&K˻4UΩ*^Λ.c͡2jϢ;fС9_Ԥ3\ت.V߬'T!SOHEDFJMKIGA5*! ! &).448233% % (36>; .+(!  $
+D_~ 
+V &o[^^/~bEA~at<oYan)p½bI1Dt cD֚RLR w`0if颖AŘ;dmDkYgT }:rm?R2wY4eq(|QՂi
+P Lv@ldNȇVG=hl<|6by!|^^uy{&!<.đ 8!H؏tM&bzݨ3B>}cRй"܍9"LSL;"]+>aq&~t)DŽooq~+=xsk1ȝύ~+~
+>7B}L}z wF⧿'5jA~꼪Vpʝ-^^t}盉bb8([>9`Q!2%5(2d%W)"Imb9}6OM ?ԅu1ە9 ʈѷ+;w[b#(Ju +Z9_tȎJ,;
+e$;.
+5M/4H %̎ HA2LUs@Ce"խpv
+T Q*U!
+逞<Fq #Uri~9>SP{wf<QO4|f& TW $u||(:>6YEOcNNo8|b&&9#vDI" %t?_2ګO$mHhJjo>fƦu4GdVS3jӆ*R_:fs8ERZhT HIH)־-Zu̝έN3tq/ZtEĮ.r%̓{y?/7s9r~.c~zA$vVc^n9TPRkL:qW)ibtRۋ=ԞVMet=5. *j8|t1A@qk-i5y㨠
+^>ۛPv&KbU:~Th>Y2>r'~2my῜s7Q}w#~`RmQѪj;ڡڷᑵԘDV5A[e1_l'Kå<<)(r9%*pHwJIrgR'
+jqinB
+<Al0F#:5B3dOPUb*zVËļc`?'m:|GďʼKpi 
+GW&7Ur-FSFÞ+=_;fTw2`J>zb5#0O%Ljjr[Vy՛&J;-~zBMŇ9+E0rH[5=zJIрy`TSș:Fxz<X ŁA}/P֫rp  Vl2u*PbU b'8ݲ#PҊfnH>w#s,+<wjҤZ5H<^(E98TCAPAz
+Zj
+vՌ1. HWނǯvo3 ?<Cu@6ZQf;GGG^
+Eg2`mYUnsXq&;~
+nze \dJ1="{c8a8y,mtZ㼶soMO< 3|4In╃1<
+av(˷DG}r󅵪0N ~{E>lҌh\c*NTaud }LbΕyZ ̻
+%%ζ"bte=4iYgі M\k
+eTm  [ٖ7?[^5p_5='5s͟'5ysGˠ:Tyu3m]$^ ~YƐ\K^(PMx_;,E Hh!BPBHh6Euvǝv= :*"X'@HCbQ@ IeΜ={{s|Tl {U
+Wh|nr< pA J>h~ޟ@bzl 6 Xvc4C;oE]jpnWwïgcrݡj(9]Ө%kWo}S",+Ibqj&4s!@Bel} I%:I\ݢin+lŕI{"`:S/xiawh*[lwݺ8H *iBq#h
+IԣS|k" s(kCиQj)|9J@U.|x7ԱJ檰O=&A?ڰQo]m@ڮэ"([t:&Qydf9=;4u;=em158 CG/xC!Xa%Vr7mMFWͦ[Hm-_M,DfY7cڐio2a:qx<솜5=Unhm[M-]]銹p i$X41;#O{r6 іmV #:2,U7]аv#fJ5`~MԒ -?2Y#ORqR*h
+I=T>G?BM~OJr~U·gO7ZeG͏IR{hjȕj
+fACP?_dBw:}
+QNB<:81155 5 51564
+E@ DJS2]a@=
+;9-Г=E?BD CK O
+M P
+V VU$Y9XL=(4ٯD&F;D78&#(ػ1CC,AH=Q=3/$ !!! !#-.$$%',.,0HW@$*(%!1:?C
+FA?ho n u {sl l uqnzd^fgh
+ms)oؾBlϬKYܜ NӭIϱ%>п 7׿::
+A ><:7+
+B2-
+AOܜNЯ)Fн(>ҿ$;յ?߱FLSU'Uں2Oж4Lϴ.Fв2Iδ9Jɯ6Jȱ?Lð<M°;Nİ6Oɲ8Oȷ9O@Oſ?Oȴ=KȶBHǶ@Iƪ6G8DEL?H;KĴ@O=O@JDKDN:SDz;RǴ5O˳2Pͭ.SΧ/Uϩ4Vͩ6U˫<Vǭ>VƣCUFYDZEYLZV\]gel`pZlJ`.RħF >3/++/7 <<G D$Fݾ*Lص-Jչ-IԮ1Nҥ3V͠:Rǩ>TĨ>WŸC[>YC\<_ƭ0hϣ l۞!pޓmo!r߄'zx2{~:oCt{GrNoLpLlRhTfNhG`KbJdKfFfï;eΩ-`Ҫ&Zԧ)Wԣ)Wң.[ѝ1[Θ4`ʐ)Yɘ(bҗ"n܉{tz
+ųUfvEnR+Pܠ$܄#I ܐ
+QgV~E΍s,7dCfm M@1*4RM]c;
+m.p 7`k@aJPgaZ.,!6 BH_7AR$I/oG}=$~i':ZyF6Çz^op;65EUɆBBEʨ ju}l8(7}}35~%\3Z7MVEH&M,3L |.O$cmzt-S_`g _NLr'r[!R9yMafdɨ
+5PJg|pqb&`ڧ#zjG`v"n '̈́;"[HjE.]J;oL% }:]ݪ@dlus|>~f!\Au$GT,4Z!NЉfV6k2@'-F4Hk 6/e@z8]˵׵*Mݠa B[b
+$h%ÁB<0J5q|UN\&qnSJO8a0h
+k|REo:KCxU#\#7PUA$6 O4(\i'9Ġv!! [|oxgW
+/*E'ux%
+LXWopgW0ҟRE mnhFƵB$oxķ< Lf1Rì°jR:&bsIKk<p=-hwY4qxcEޞ}X'Ǧwm5aC&q,q,7HkP
+}Je>7.6 j)Xh`q%Z ݴ"x ~ʒv;{I6~؏prB"+#ssnsoNxwVt{mswk7<3y Q5'Є\A[Te""r$}x_6RdObYD}*7)7}k'kI}XKۀE,E-#ˍAk:~[Z. Pa-v^zAj~o$ >L7A@.U@V4kփ5~.gľl~϶?zRcW{Y4cܔZ z&fV6O]!?œ=l6E4 +Z;~P`b@vҬ-T;>@G1R rZ4[L
+ux9md߆X>}jՆ(
+J!Rd/;0r5\*9KÔۡ%]Z3\lGXӈ:W{$ckEhgA5~*ӊ~KT>
+/ .% " )### %++*)+.9B.(((*6;@B
+GJKd|lmaWvn cbXE3%"<8-/>'Iٴ#Nخ(Q֩-FԪ,7θ)2.2!46510+) &),)
+<0/58I=;6368?QZ%]ݩ2nї;t͐8n̖2f͘7c̙=\ɭ<`΢8_ϩ2eԜ3e؜/dܝ&bޚ#fۜ"dۚ"dڙ#g՗ kЙ hУ#]Ԩ"Xآ^ޕks s tkh `'Sݵ0Kٻ3Eڵ*Kح&Rթ.OӴ1Jն)Pճ*Nֱ(Jִ*GԷ*FԱ)Dһ0A<Iծ#HяC֤F<856<CF!J߽(F(Iڽ+J׻+I׻.Hպ-Nԫ)UՐSWOGB=!BG"G%E1I9NԿ5Jؼ1Gܿ+@%:9 G M RTMB/!(3 ::7 /%%+) !+44,!'*&  ',2 75 4 2 5 42.*+0 41<=ұ Aϸ*BϽ,=*7'6,38?HG)Hٿ-Jո,Z֧1^ӧ1\Ѫ8\Ҧ6Zҡ0[Ѡ(XΡ0[ͣ1T̬5[ͪ3^Ρ4[͞9Tɧ5GȨ2AĨ8?@<<<<;9798>4D5A;:<8>3CͿ1Hϼ/Mѷ.Sү1Sϭ1UЬ3Qά:UɧBS¦BVEZM]Q_P_VhXi[oZnJ_4S%Kֲ@2.,()/<G <=?C$Gݿ*Hַ0Lӱ2SТ<ZȪ<Vǥ;RƧAWDOAY<dħ4lʜ(rА)qӕ'kؘiߖjtz|u(yy2mς9eƐE`F^F]GZDWFWOXNXQ]QcCd?_Ů8Z̯-Sϭ3ZΥ0]Ϙ8[ʘ>aĝEdĝ9aŤ0uǀsp xyv
+; bX'`6^:iA=
+B
+@;7b%H<;625:48??kPZAAQ ((%&xYclbͦL;:6M7Qj4Y#ޢ\ *o(jȭ4/=3=g9sy~v?ӊ/u~AzB|=p9xTb&/<1T6*IM+I~rז ]^0(HP'P<;@?e0
+Hぼ#["TjOXJ߱aRVJH 4@LN
+ RKiKJelAZCK@]'qIavwV¹.h6XYn]9Q_{W\eBXAb"?oSW˳S,[<.=Fm0CH{{:U~*du(w]+,fԏhD%*Cfa({e86^8SR2G+OL& EflwY>0cP*UvB  e}X9{\=;eDk0"_DB&6d `j\-GOm"fp<;513t<8"&Hr3-|7i@\"bs-&FHr,\DN!kr༠tS'/5_5ks_cLg$.`at+I9݉d$99Zr4e 3REM('(uCZx
+ It
+\n&W -
+u#xD;#D̔<Odv0#=iԴ-qRD
+.]Ϡ Og%i#LhORkZ'@Zrh-2sVӴ2QsZ)lcѹ@]OiyPvݏS. >%ڣ3M@f-`Jr@@nåqLd26Gy,󛨜A\L`RqF-{Q!~U*l]6^yrSrZZ/΃
+>^73y4"6p˓wa1mM3^:V_,(! d1 }=ʘ?۫`T[`Q+]
+iCssoΈȫ2$>+ErH]ՔT^5@=LI{OxK{;W! 3VOgI ecrR6Fбֻcj㎷=LCdpi5'qZCyܐ lKCcuxuA-N#Fu@Kc|h
+;uI]B'Z0 e9!aMYkW
+[aFmB@ ֳ`qf}<Ii<Ukج5fl>Zya,JjW! -Y@뾅+ [DmY|36^ؙRYwH%AW|<4&2q"(!;{Oliɡ^j&:mƙ1_1SeA*yQ<<2#Y݌L]`.+1?)菨ԗP?^yMU LS5VnVvKRd*i숫-=Zv4pN.+sVؗjϞs==\R>*Sao8X'-YĬbX;%+cݾg-də?N,LDD>h @7|` tXo2E3k "-tj 0K3ǽ QTx[*OK,ĎaP\ ZS@ Տ0ӭAL @O `zvS
+*B׆t$X?Я#kՔK6ɣ&?3 CBpd0NhN^XWĖRsU.!nkiCk?@ b7b
+<UmLNum<9lb&PExwK-'O8s&1~jwa/i nT!*GC%I6E\$~:(r {ebuȒ=tx)=n5b$Vռ?JوS<t?~%oS7I<O\f ׇN}.1ub 8bP>ph7=~BZQ>1ӄZqSpA`Ų^~d>SՃՏZ%/sOX>Z-B3q#t7KƊ?b̽AEo3
+_k !kosioL~IUn#]A>_\&EKYޱ:t:EtO?ϐSP<׃M.Ѳn/{N{*gA,5H9797HkuwO9L#&c Ƚc}cc ^]lF߻-aUr2>rU+ݑQo'$Q<3)CA<wp*^9 h'9 ͟"M[>›_k=G%UY^'D9_=U${!dLFw{v%-m}4DmZ FzK⩝팓u#N-:v}GojBhAaT B1Ah
+`uoM6ޘm̉#-H vc @,X˄; C'm`*c{Sf^OlZVtj?p+,#*r$i9.WQΑ7?{TYETQe|E!k|;i㬚mumvݚfNSYffiӘg $J[
+>؟gsϽw={|;#W,/} ;&zx
+%]z|bk3T/Pt%5DD]GSY7I(ހpY:tX" s Íޤ
+Ms4w* [;f'mVz~ @]ͅU]~I eNӏK_lI]mv663
+tԪꢝҼ,0_9<A[ap^e٪"Fm(k`+Ovඪ%l!F25g~5!H\RO\S x*Xࡀ gJVKaoU}A4Y.@F*8]3tY2C^!G;4eoX'"V U7NT6$6xō4xZ"1c^aB6`@ (~BeQĈsDԂLnMVz'nITd*NՅ B$Yl&X]';*
+oӾl[ZYĬ&}BkE^Z/
+*6<6Fٱ E]`HO2Pchf/fR"$ĉ8i;*AڀL>E% m:L?g<[|}BX ="gqO>!_Vٍ$6#Opq4)OBu.ic}e>VMOSGMhѓmD-hbc|cj]Zm=66DX`*cӶڌ I/7kiD]Sg[޸'Xg
+7|yN=P;̫ԋ+oW(Xߑer} _}x=?Os~"fqF룓-14dUC‘[~Ŋ[Ŋk%C
+h_!JuD}H :Z,4{ptM291wP7 tBHmYGAbjr\/4 \.CBr$\ "(㪌ۭmwt:ٮVY!
+Fg \$p@8DP@;;ϼѱij!h!`t<3z%S0l`b3!su 2_/.KV ,2Ͷm8Mw]!!܄-9~@Qf1i<qj<[ս3؅^;³z\: ^kgK!?XFՌ #ξ}{dw oo̎\!"ev(<`lZc;A4yfʖtmr˸^rh/"7Qt:2 ' T9j Z2Өěe0;o|)4
+/cqyIŲJIcUIH N!}ʩ$ԌI%Q@"~;J=ԯp!|9NNē)gڱ9X v1-<v}[Ե)"mi
+P/c!p?/
+O$>0eQK\1*5%4#9UPk
+/aT 2-K5YٛV5&Yś:<G2eq&.ii@ZB4J#Ui|KWWj˴YBbmߍ6-SeMSעZ:7nz`%
+^PŖW%z5&D(B7N*4e@lCn:Jy_] sΚo9.!N_SV_q]z2G%82C\!5FAQIy:q2؝2
+L1A.D_:a׵L/: _B)aTt`
+T }} W?lضYn Uʔ9WU'@'={Qc)Gwqd*^W$kk* O YGėg#+3i[
+9GJ=LiAqbVIet3|nvja}*t‹=6+lCXT ejnEmxYf \t@/;]Z xr _X$aQ mi [l05rC%P\YG*wxist:H MW
+ٓ Ȓ06mK.34Sg;]I(96fhEch&8KVrB'mc-oȀPH$)Be֭9!3SI9Bn*6:"BS!V[DeB/
+e 
+twh_-eYj>f͜D
+O.< \.= -*agAKat%s3?;\A)u)$amŝmg0[$5tQm8];=[SsrqxxYs sŦn΂
+p"WĘ'|U9]b:"Jq:)tngX
+&1k|-_2xCXpc}VšL>+<3P%:T|(&KZD)X4*cZd n9ٯ ~CweOP,ӳf< ],pkSөwF{Ǔ/9BxD>D=eٯ~~?_u;wŽl`鋇Ϡg#4.oXQ!g,̈́y횉uZ孓 CM_">iF@)8H0aɈwۦhn- TxD{dG4*<;N/gY G#c}vodj
+x0nˀCXЈEc9Ğ}soۑBwym]jcQd?0n+t_"@p@9cP UG }7
+׶x2pPn9c1l:rc)=!aIp&BՓ> $=yF׶yҴ,0D"g.lڣ!ۂc5$bوjh%0 P C ŧu2ۄyu0cy7d
+O0:-LUMXG
++0a*oxgȫ/(n ^#'j$"Z蟠z1_mf
+]6C&KGպ oLz0
+:#dxd CX%:}Li¤+Ly5>XEh O 1t&gTU3~ϱLe!V085'c=qmO\Fmt'$($GZ$Y &YH&ǾcVD2L`%ЇNRI~j,(=3x-sͨ# 0xuzI`
+T53̉kL Y_lvo 񈨊[aSa᳸QAAmF.v:>bτsʧ!
+_Xc+^vOVŦRpm{lCrRES'XDW
+
+qyu ncb˯O*xX{w0y\n aN-;8c˘14U~̑!,EYaSqi9)*Oy7mCq4iCbO"u a^fw-)#'3Ȍ&
+|H^QU`#3uoੋ^Czg; y5yvy5vYl3F6g;|h]k<Yp۫Xw=Db w5j~
+WXR0
+ 0T!8/B'!4
+[ezz/=IY42 Kk3=Q@oAQute9Ot P,&S q 2Fe6x#J6:ê:NbN/FhZ(jU]UjOa 66\\m!w
+^V}\2*UK,XǸ{aCwK(tX.!^Ъ49+?.bkQ5=.zɈЛMɡsoґrkrƚBI֓C[(Uvq!)Bc5\n. y{P^b m4Dž [Ģ 6,hYp!˛xL@,$4 Lјq!K`£tVRo7V.-?+7#h7AG
+$>Jͅh")&5*O$K 9!}N,`DUj2
+zl,3G*Ngȕ\$p~$؃)6*R.Hk䝔.iyGeJMPr)̒Q
+|
+[:B-s%#$T(K<"uO* s 9z$Za輵1 Dz /Y৖νVKċz+e~,# _tH/z/uO xf0ƾ;)E9b` b% -qpums~:koDPo},sc`qפ3?<eԭO#`+ny^jj^eK̋&fL{Zqje#npSU~3AogePOmP=JiP?JzK\Vau6ܠ(jGhjýZ?Gx}5'p
+ *ZVֲEaޑҐ$@0H's|yo~3uN"4 X+ !mmOB3 = %(XGihjO)c7T=gptI6rƜ*EO9IBDaB\8 s5fw.T}7CuJzoOJk̾{2
+IU}CRN"B|lAYEb{CEQ6"d \lKJ9mn6S4z1K*Ҿ>G1;=Gzd1Ƴsɗn=bOs}>̗|#Wct#s<
+L{qudbuITbmiLRC9-}#5߸pmK<g^:__y{=}|&d=U6VG {p?hG&vq<,Ҟp*~B37ܹslcx}dN͢pjYy\CQ55qo][f/Iy3 6W{ q?q;.3'tGLe<=}:I,!>d8uѽ>l9Ϧk:ȱe<̢IJA˃aݪ@ jZCUpZ
+@s5`?⃩^bQr,X9 T-SdiAX$$3,]"oFO@WnekF%X-?:) ΋n^ruw_o_/&9h1XfεYL³>5z0B1ޘE)WF0w1\ k\0X X%k˒Z\p<;`ɞsɞuŲ%:x|}UWPyy2WG?;ML؈>Y: 1.l Y.c≯MaزjX(ÐM+EI_`F~˼?ϼ`5Vb1n :dEq(u_i;ɐv5&u݊
+;P`<l'֍ߍgcڇu8S[=#x~/{0Z
+.`\HRȰ"e
+Am2u-Á2l]2t^p.R4yz3:q; {Y|={t9'ڬFklaht:y?Ω
++Ʃ )Fc3Ywܮ-O}pYG8y9\Ÿ,LD?<;]i<p=-&dpz?IsNlxP_DIkzM|}Y{< c @C+*9aW] 7ӯ-?
+T&R\cNmO0"[WBVJ4I:Pvkl;ϳg|qOj/ƶ:+H=A$a/lO;G/1iGmTkSn3 [ZQ[q:Q[5߅+jaTe {jZqPR猎Ùmw3!g瓯4ܜ?? 6e&b&_pȃlc^@B-Lr|[dg׸ܛ
+U!++ON;GFP<J}5hp, v b\VQ+T*oT>ˡP$yL)P<ToY8
+@v'@aD'
+ݘJͰA;zkM
+͠U>S=|vL^
+2.3<??E R2X|}ee^yMxБ7^߭0'7% 
+] ZZVTPW"[߼:YվNC0; 4--(*21/))& %#"-+& &%!'*05 41-##$ $ ##% *7=D E F@ I
+> : AANٗa҇$Pӣ%Iٲ@8540!-)'& )
+( &'# !&
+;/+3
+6+!!"!&),1@LNݳ/O@>7 0( !(&(((!1 ( ' 53 ,
+.=IIϟDӫ AݵB<5 /
+0 01---&$"'!&*.)1'5(6&-)0+42(<1=/D+@&C׼"Hյ+Kխ,Qԧ*Pҫ&NҴ)M԰1MѮ/KЫ+Fϼ4B7<Ϳ4;3>6=ε)<δ#Aط&Dڸ)B׶#;ܿ 631%"!)//%0+32>5E3JϷ.Nѯ.RѬ-WҦ&b؞XQ? 7
+1+37
+MJJIFGHb^ۜd͕,nĉ:qDhHeGeOcKeJiMjGpØ<z͑2q؛,^LIKبWʜ/Y<MCMCWFWIXFV¯CZǫ=iΗ7xЊ/x҇/{҉+w҉*wЉ-wτ,|ˀ){4}>Ć=tɌ>dȞ=^<yP_T "'*"(x$Fcb4NI;nin6ݦMI<GxFx[EA@eQ?gg|+S޵OIX=3i&
+<ԕljd~974k";m*7O4$fVË7VSnT-ӕ=3z0~|SҟWOoGo?umpO< R_"McíGƛzŠnmVXBFx<}ڣ
+;?
+WBbk[vv풣Ur\ /w;(o[Υ^:Go_j.k*Wʃ~ yz]('VCXؖ@6wy/&ND ~
+{} W_?w_
+5@V"m2ʁSEGZfsPxF=N9~x}hv(Ӌ)}+EY@=u;9?7ZK}`gzMYo<{)<{wEHߋ/o{sz\sxdu!s;Ө8T/7!KU VSvLrvk,uly]D*LZ/fjCyz҂IJlM؇`ݣnIA\D0: aHѦ_ %}Q̏? *uF$KA)TQc9x]Rmv<$1B,05#e@n3<O-KP< 6(lu\+_.;ߢnVyد.{ue}UqXd*ٯ\ڭC>GZ܋QE Vm~MsҹFJ|a;-\іunAI)HJI1DRf1&Eat=PajmH@^M^PCt'/$J,af=Z")MtH h
+IoW=DGv{O;V~#gҫ|ĻyKQ\:yfjH]$-+(F))ne5ؙel/Dpay\ynpuPn
+-`]gP} ,9CR@óhhݒ)Gc{RBܺOMa'6ĐeKdc9wr+50pS˜㶽Śea/"/OW2=lLl͙m WvEgωb /_RʺH*'c5<&tB-P :ŀꇀE
+-\[yG x^C`L $:I
+ Ҽ1fETe8 EGSMԧKe 좹Ş3&I06=`br/31Cax8
+V'H=M8@h<ScǥGqI@1{rm%>zCXP#:si1$BdM a5,<5d''KTpWӠNpl$y8[[sDbcP5VFLE[A?Z5\5T~nJ(jjU\ELI,11I?g=>}:{ѴVqBKj(@zP FAkA8P#J=Z n>N56usw%#fb?J?pF VǤ5WP8gLNhNMZP)G?;I(׮sO&#yz DA7NufVA5&8K@Y oQ6)@(6 dvڀbBX Q.&K1қdG~ng cWgq|7^7=v(J=XIzs<<a }7*Cpk!5ݣW?=r:u2,.vY^{iޛy8ڕR%rB,3I,x+K :o"DCXC:%*fэ7IGEtdFfEd:]h'<7<Tt3!5* *`VVaǹ7%ZVZ#i`pӚ% bGe酓MZR^ksCߺ-v"a~T ڜk:p#W+x.S3p'L UZ qT(]xm {W5u.]RS R:ּ-Ż9^ZRVF('G~nqk[M`dE23
+d|>< N6siph숫/v>d Am]fWMSO 㩩zqd$pFo7MBW:"9<[M6g6+/ x_-IG?J<d:n\3&S.yBr! ^McG=Z|ogq󩪗f+XG/t?íyU,8V/"W=hw3l^iF! Vӄ= 1jn2XO/^%JEbA;$OsECm\*U̟(E1pZE8B}h#GC ?c$@
+ Ma+$5:i_S)HDBρN׌|q}ͅ
+ɋWT2g*1q*%s>
+!8n
+ҏop/x@i`oZ-LoW#OJ9_ˍVwd΄8p*KHZq@hhMeD
+h0}NG$D<M
+QB*B{7THF((݉`\]g
+jMATQ.!zaJ۝8v`!qr9Bm(Wn/;Y_T$pHNhg1߭BaݏBDK
+ C 1#!'c/1B8 1ΜN<hKYPHA/Z֝J;3)֮2ƉOx{>Fcwp"8~c,2}^MmZV5 M%&ji4aW5Z?lY˜ڌ1J4n簰n
+ޛG)vU3F&UσF>
+](k[͊.r0W2
+0ϛ,eOv]  `m!ZBc &]K<
+i0Bzyz.KϲLG_5Kb<KP2 ]t+?}'-/($8h|[ݹiLnj}\d9$S'Qr[܅<t`<(@ rqۥq*Y'гwΓ =~$$vg$ eZ\`g
+rQEc+;߄A@l|CtеaT2x<ưj* } &s4J_g<$ p $$H
+츣eMX:5 X#rABB9nc^W?- p9Ͼ2.ף /湮E yK\"-=
+a-u1}em[(;z%0
+i)] y#rZDmٟ{W1k[]ZlȚu˚v6ׂwYasC%Io׀S|x/>KM;$oNj'>cc`(&%r\
+6H {}ik//)K/Ȫ8emTu+> Pne56G^▥c q`7/a90.Z[`iѧzm7;6k>@*`
+R6Z^]+޻WtEbS%AZC./|ݞ|#?jOn๡boyvɲ
+|b &l(x4sY䗷谥]A+zA+M`y :KA8iITYc )%mYЉ/T'VE׾9XX*.yZqh6#+9{%E6ą&0^FLUm ֓c}^-LtwW|_0)cv<ҿeqpslFnSʕC ==rSzw:a:QCZQ*$yI3w1?Lܘ9cy[vҋbỸt#yi"t_?e[MUVxz~[^d и m}¨'aLxV9<gV:S]jtV_O(+u7ktWJQI"T2ii4VIDTSD [=2' rHc
+ (+XFtP4 `Hq{ ~p:
+ J%WjȬ\)
+lk)Ȝ3^-`^ʹo17'lcs}Kޮ3녰du!=b`@P BaP=ڝ@Q;- ;c
+' ā
+J*$#{Sy,5ffN4{s5,5|+3G2DQ0TPírys=㙟onS I"{w9bN`ubT [&Ȣ0Z32͢M~3x]3፛Ccz</q(؀Hgp 2(
+,0 ͡,n
+m.#F(Q7ێpaP?ڜ3`n昛9F}6~,:2ۭ &+
+Γ`WgșSgdNfSZ=j ­T-@;?{ָ e:K:E ZZ"xl ҷ`Z3{xog"|Xk8O [?9 Hn:)<l.w*T(Wv~Ҁ͋Mb
+ˆۀ
+&n̒"iL"z.=G%Nt='/lO'/<l0qz6.V yi}S\M̥{k'&wn#/޶ºFKAIPй Ϩ\DM\%.}tkL[*1!!r!r<%>>#ёazf|5߁y<(U%IUOq2mb-bX)ؾy~2"P7b<K+\2gŅHsG?<]lM\ޓB: wwA|y5oAGP/>|u.ix~Ux-a_9dy}qMILNoHw?I-$|<:;S\1_v`Dc*a^ ]jA!ǹ9goζ*-s?\pq澀lcE=~(+>ZVTZ\?# !H8ME\gN1{n} B~@1eۅR4CuY-NyORtxhCT<ŮXwЗ̮$/7\%&#'6:e dM79@)j aٚQZW߄^K;ԩXozcS'53'#wD<Ӻ-!KXݱLZ#J̐۳AUػF[\xB^mcAVb
+mP{ɔoF=HRZB}j\5+{|50G>arQyN-?nmԿ,HnmJ,Du}zoP_p <6>4L=@%|{u[$+ے_O:z߰ko&o^A3O81F`7i'~gwtz|YS:Jd e"ޤZjy4JgwYsۨ10[o^c\u& E-k9(gQZLCy`缓YCI!9`"HT>0cL&G%Edb
+Ӣ<!Mh&wj M`F5EVyup~ X`wc;VP®
+mRMr*dH[
+k%;j@N)T`
+"3uh8PD! a (U9U,r㎖,e1! 0ᠿn%oֲPzg_M0Թ6lf1|ʖ<BJZNf"{E4 [j0_hn5pLh4Wnji6߱аqrkg g4X߉ QUn|a(r uͫY֝ [ M0cc8FO}5>1
+_ _Q$b j$hyTюDG3ˀFZ4bRGpSS>]/8>z]Ӽ]t.dC)NV(gpW#4]%zGYMcRX}x\ TJUTQ# !U+"|ey^Q=}Bbݴ^}3sF1@_fuz|+=mmg_kiK2SG*f$B*pxrK|%{yM)SpLy1$f%kQĜwX(Qr^BB`xfQ Q٬`}*7n'AxŇ:||D]sS 3Mm"X΅} K݁t
+?V`YU5| 6_6
+K>@eLY;KI(ZHej{5X9~s{K~F'j #S88Q=
+15FytB!3Id&9^)gʚA&b)v)+ѪBܞ|EՖb#tvmS8d:Sk9ӵ`8Xr;Sϕ(! S죫wL4[qf;wc9Z1j^`Z 2 \Z<^=JĩI,Q]dz Ӈ$?Y_D-Y V\DQRX> ;S.gBb=$s<,op|
+m[C% τnX z4f<K+d9|y}@PDmߴÃ9T`>%Z\F+.z2iI5YsZhgg<+9tD3z#Kc3{}3oߴ\d-JjJvB_)=]Y IKG fK߼,&k)<"YO#Y؟GO;0u~ִv-dD1.ISH
+}SDyCWR
+k-']#`DKXEG7r=_YI U4դ:9K޳Rd.>[>MWBRjo :T94!wᆜ Wx?.)NP{N§cݎZklUl Ț7Sgɛx+C+R9=:Q ~|3pOխ}'ԔK#»тJ-;r۞lcп<2嗈G!`LKte.1Uz!MŴdI@5ɝB%b&⒮f3Cl#`."3OXN`ωҘ'[3c-&+Խ
+GA X|#IZ OF1Bx v5/!ކNNtwY8rt|;moA!^z s sk R?*E:e@:m٤|濑O7_'bxzd?C>g>KjIn!|j?MW߭&]"TԯQ4Or}?J>ck¼;5dO1/zs29qn:4,4 bn(~9 f[db2($+C2 \n
+R0֪5OȚM(3N (n.;
+>[; F\uFdzQKàd`VsexƊXXiU ?=PrLZ&Z
+ӠLS14 f0Lݛ^Ѐ-1JLF[ UPYT.usf1 S z5B5MLU& bZF%,Ml%< xb s fF/ʖJ
+2._=%}_
+n fuTA̬W<E{M8~hJ;`W7q]9(|QHW("
+=ބ !1R% 8G uL"\$kaf.&=^CN0J!ALu (UTAE**HYJPBhRDBRw{{{ν3s~>M/H!Wa-Y-/l[r?>>Nrޠڲ0ǪSmO!w9Вfߖ?땦;nM\4?h0
+o{v612}= >PN7HӜX%͟lA騘x͋#`4`
+%غp(\쟈
+
+:'[Tfr?yz>G##u2wgjޞX)h߳ #pCD
+۝"BuZy4k~aG? z|8W?<Q*
+0u"v-_Dڙ,
+6K=)-QitUua^y2yA<CW#Oi'Z'`S-CzΗ*,A59=2ʕ]5Bc<eDݝOGQxkNUg[qu
+K H5 +hB΂f0f
+=ٵsؑ_hd;- t<iۧ{22믩zp$|Ay}1`kc>$hLtIlxLjCRޫL;IUYTTyNQuFS!րq{7Ikqݿj%8:Uy۟ZTk?nǁ~ WrPa,[k5͈95~e04hh84k82>znMFq-9coZиj-uoqKpų:JT&KS7r5bIvX(CGÛ%^9sCrxf-eHFnw}A?rɵu)~7}[כ[`UduԌԕ
+, ܙ$JMѯA[FA4i:\pmH%dXm9Hh+g+]bW;͖+`(0KaQ3G ;* (Z&b$Ca㶚$6`Z ^YNY)zЍA g~%tPX8
+" Hh|gZWgxRM{?L{PYox!T@AE." ^lVj7+nki:kt{U+m-S5u)
+
+ihi֪)6w<s3{8Cw)_|,!t380]aaˌkx@
+h`;Aem%5
+ah:&N8mL # ] R[vhQ"$AG{:P'T)h×chvLGS "l_ KU0T0
+j:lGzpH^)k:i.!WLN>eK45J,.F fI
+HBIULZǍ4/dn)e3/ZlX<.-/#NjۻR:Bo@,.μt;QYoE\69s-O,Z/;0S?^&y7Q]I&yL>-akQx0`\2mPvP(|UAuu
+q cq<M7'f>q^^=ߨG;|#"}#PÝ-c2E = i_!củWMHa8R~g,ƹ.^T݋IgaKC%kKCUk+ҪOqIVDInSU>
+df;
+o1>u48 Ndtз#7ֻ&(ad9.$5cjJKɎ("Y[hXmM3vtk8M'RsK4IEKq˲4s|>13B 48&.US5rSS#x@ L=h$\%cߵC U_:~r[6bIن 4ēe^~<sT#;^̅K|ا/^QS}Kvg?|OoJ_q@Cx~XxdGg5ߣ$IV1m[Ӟ_{XSL+ZĞ}5ΰ4yę=S:훽/v.ބpjrhT{L`Zq\̰L[%ZCv%@ۧ(N+Y1MpiùwX ݖWQ2YevYA7BvLR\St' s-sp(b94-Eo}vNnW jBn|]x1C՚] kg O'{ By>ݶ]k[|kuaoL|ga۴!;TTctϑm]I"A6>-NڄHbȇ4ҶhU:g4-A:ohj}tf$
+
+gjXZ;p4T {Z0FlZh[r !l}"Dko٪,N:/lDGbDh*-*R024y96]Q*d#`dV!3z醧td4(x'~3gr-C=s*VpE66oSl+b^Vh:3r{%L/=%샲;=^y =N~y1su+"*[t?WGZGgթ3/yǴ#ADv\s~ZI%΋ <i!uyG[)=VKb19^VGMm!tR3U`yړxs?Y e.
+e/7:90v͏pzߐ㐫6_/v8ޙr@Fp^2XVU&cUTDAI HNAEd)otfw;)hCo3Q fϸM  _ľ
+X,
+>UuJn3b5ߌ?$tz©B12THm
+3v NGwkߎş`<Ձ{2?յzITyY$=͚w36x %M]Xǜ&Zqkj *5R El'1 6"qiC m\Y#qư)}զ?m!,C9+!|H#
+jwqz3!hY?`Zg4'FAdBŨ30j #ӕxn))ob6M5: S2"ԁ\gw12O/}oxeX!yӂ\[{$cBcV~t 353Zq@2*}<a@#IdHU%э]dޭ
+gӍ3G3 |:ݿgmCB)؈+0 k X mԠ`3Pr8ZFs-7dpY)Y)drD9%Y)3e0S>U1hdt\
+va4Q
+J]/1ߞ=E\ly?'{nEߥզP|uT:R_j
+rTJ Z\\7ACY=&l'` yY7Q) 5K &D5 -ٰۊ&Yl q.D֘:}`+5s69%T(劎}:ڳсm/M|#i&PF~\B?mX]5)8? p;݀tuᴭ^Y:s|t}:t/0^i^r\+*p(wSoO.d1+z
+v%N%n/:{&/;ghyGhk3L_ m K:dw<\# W8QwUsV~rYK'x٦fa-aO%醌&}:ˢhëۯ4ǠmE~cƇO(ѻ0W;7X7\%`<]c5 ymw4‡ÆŁ?#cN$*{OdJ%0v EE i񒤤P*L(1 nP 0#@Rzm5)
+_&_GyP鿟Tn 믁~myŹirb zG{^a㌮MoCG}itOt&̃H?w#L^2m0z"
+3m-
+?.{x{aO(S=<ןwzj5~S-F K\ Va!dp?1I
+Y"Y*YB}^2ۙO@I7Q37P+AJXrƍ Eo6_b@o|ܶMjJ%"v 'g>&o1+P ͰX-B-h
+v`op=ܞjtȅpV- c3xgki όR'|-EG`yBlB)qQbBR ъ0BtHB`ĵ
+৚B"1v]i\^F>ѝQBrSKm_me9gfհ۬gzuw~gk r0#-Q n'ȿ.󨦮<'aETP Il5ZĭPq:U@qAXG2e
+,ikSl'
+]<tdo#${d IhCB$yHET!)7kPt#7I4)I#5:8*ƶ N_! y*8}?0>W ]gyꆉ dG ƗǏ^BU~R<`7h=w@ x$$VeE*a U+bBz@5ו2"څ!
+Qk -5}Mڥ&8"uHVK4M.#ńuqa]mXl3:E )0Xfw3+ C;^Qj#UcpDABj$*ɡ6
+]E 2HҮL7Q"dpLSKj
+.j<T82DLˑw.G;zSgmrO2aEV.]w+e'|rWYPY^Kkoe3Ē(b1E ”6Y:C(a1D"F #V-S1]:K\.8_0' cX˲fwNw v 1Q4JB1/+w֕kh&W0/Ҡ}]wSv>nBm@oՕ!Hc[+o~kY|¯|"K
+E5ZV6~ݳ [jlۣ겤ϊ7d4d
+e(ї^-%åi<,L` =|TNC. W6"BߤòQ5[#W}҇z_;wr`K<l8-DϠf Y| 1| #5޴2q=xGHǩYyȃC7ܿ1tK{UqxCnWlP9mCXX-,&ӂ5b-T6/rab`1YZ)0]=h!_|\t9ӄ\m%AqRtEyBc'y,e
+äkPiktz0*?BcAtzߵe ?:rPOj1*PE5q?c<μ>C2\j~_he0
+bd8Z/a}
+'7%OU-g/~%I T-P}Nf@ РU;(3,?[#wS8S^6Ů+bŞYeQPny=ޗ9]J6[ }.,:ƳbFGf{՛z7^?[YxlW908̱?:lm9Ǟ@9amU
+ZC=(Wg[0nO5wF0'A yt992#MӅSʤ<<y
+
+ɿ]Ѷ(l :b
+ e,oXӄg` 1Z;P:|N]u~7
+Թ BLoAewKh_$mco? BՑ?h<3- wΜRRf4>,qJEEi%1Y,@Y۽nn];Yn<h|и161:12f<>608O 2 ",4R"&я@1Qxʐ&dRp,kDKi i(g@@q&Ut4bZb# A\_p$<wJQ0% ϟϞd3Pת7ˉL2n(,4+1
+O(51DZ$UeBXCϳcve06 j&"ǧX4 $!&*'"Jf^E9h F~J6(,DdtTAȠ~0 q4K_< %qL=dqeUBu̓PmYq͡{~:*R]  Ϛ/Xc8~:9^9Yvb)talp[tXs\pmTXmŇ6 RzPQ;K=@ w{S KGM-w\B,47O>+{dǃç:kNڔS--I?^;`zf$.J֍U[u '/_1JLq: YFf L;xJ=zF-ѶZ_*̿O"IgL W̿ݿM~W}׍/\m\|mW/,ՅO8h$3>
+p[2z6TSX]S)Ųȧ?
+O(jJ_=}SaʌM@>f>j}|=SgxR:4w/}q!Bo"zA Q<?k ?'+d!! pϞ
+_ҢA7FZw8gŦ-+ X/nq: *<G3@>HAeI2Q19E+gUmlMc|nhh9[C͜սm:rayڿfO aM♺2=7'i 0*LXCm.<G7H`ɰWF74˜
+;Abhǣ#mX`$E/Wm[wMtM
+i枰]"w^~HUu2w+LCUw.&^(QtIHD}'>I/$r01&ҴVCLM_\RLVT"e3a..K@LSuQ
+114ĥiDhI/h(= l)3̾mB(L%O7խWI"e)icf}C0-K};y9B[V<ՎB18pTmmvx aX^̕BdP:EǴ<#6UDЪH=P0
+)ĜfARY9fC%OIe(\y"͕?~_1i5O½-f VE6#9ezWg*uEz,>cc=&@|> Oj,PV'lD{Q>Ho~#+Fh;vvd4ǍuaSb.> 1GRswۢS}Ox6=s:{9џo?
+AEџa#㢘
+ZJ]#=>$}ϓm\~9e墓@R
+ ExQqX_R-kɱgnrC/qNL':RkVy{:5u7A 5nK͛kt9
+쩬__&*Y66p)[cQ
+0Ѽn]|>ίBIGVqGУ<a=" ·Ksd3b?ِ8cLaĢ87ݛk` FI
+s^Պzsf JPsx8-xNu;ewŦ5wuOeO%w=*Caq>U _-WY N.hZJ+d}K &Q^j(vauH>~};eVʝ*a!kH@>}(MyFEfܣ8>`Ira0f13 f̐TH"IjlM%<v)e`.~10B"Q|9yzxs~^/_*O8Iđ4"r d E} 6!)ݍd5٢-QBS?=KqF0]@1KPШ`h[UoB>;a
+3r30knC?jcF LjҺ#4ƁkŰnY݇Ig9*F8R0CMoݭƂCg:7'Hà%>0X)N/"
+ƀm(E6u a_^/w<DI4i="\k3A}æk"Gt-nA+8M-/|b{z B2Efů<E}pwr 9EZbu/\O TT'jj j&:q"u(cbXB{h#v()
+3<,QIIaUD2"<v܁i+7W,ᔆ|%)
+Ȓ]C\9-9xZt1t%Ṛ ܁'WNh  _urtWץvuwl3:w_}NtNt.CW]jۧ.Nj*ɿ{rsl)^/0KLC =kf8@,-
+/IN+ܜ \%II8Y'_g%]It=Gs2r)F/0b 쐶3D:@.}6o凡o<y%b{Z 1,.)#B؊6ŰKq>4\
+( ) ++//)"$%,,(.2-4'/-/Gհ%Mӫ'XӬ/Zӧ'T֡"O٣Tݡ \c`^]^\SU؞[҈ GIJH@5
+I1HԢ.#')!
+B_Ծi9? 9:<5124;961010-)4BA = >=<9:;9; A J_ӂiӛ4iϲ?^ҹ>HGܯQط;I+HJHDEFF BB= ?XԀ[^VQSR O LO!T1SӰDPˮKQ̰E^ӡ9jע$eWKG۴Jد"Pձ$R֥+Zլ,Uղ.M֫,SԔ/\Ϝ=cʞ@g˜5X̞+Fǫ"9;#:ھA @(Aٻ%@ڬ@@ ?70**)Z399,/<
+1
++ &#!)
+( " % /+&"D Q
+& ".346 100.$ "$ծ 574/,
+1232:7::;;<<9<?<9766==<:7#3!/0+DC,"2 + 1 .76Ӫ?ҞIG@88 =@A<5"1(+)''/0'&?'Q0<D
+GIF<*&+/./5HSѠKӫ"KڭHRPRM J
+E ??
+=97<)A?<G/1' !&$4&=%9$4=BGH J%Jܽ)K-J4B7<21..#8&8ջ%5)3,*,*2-350>ұ#>ѵ*Bи+Eӷ-D2=,8%2&1,2116023-4,3./3+2-0016.125.718&?%DC߹DܶIأ&NѠ3Xˣ2`ʤ2h̞.jЙ)bҜ,]ӥ)Zծ)Xק%W٧(Wة(Sخ(Zا#aܢ'c۞-a֛*e֒-fӍ)`әZަME>:
+pe mA#%\{Β:s(y$QGns.xHp^i`5~} A+:`3\Y:44.u3z`E)xN_T8F.؆(;
+8hmBgSf2
+Z 6 X$@,pLv`fCqZ> (J_[ D)ikKRQ› `{@wIyO"dV"߈=wMEL>!]vcdE9rh%baVɓ̓ggAĪj,UxHibƛ}7L7MȰjk0h  H >hPv8fn%$@$ tHh$@ۭlӎ_0+2Oξ2DVmxuof:_JgB#-Es&8 ݐ>Tʒ 丹,@ϻ%Ε^Es$7#_v_ĜCGN̝4p<ba(-Y3TSCcNPl:4Im*О 8)@ڷP&#;Nݣ8
+us@]az3<j@m տs`]OUf \8 vZ*PGaLfwZ: FP#2Pm A
+܂F5e9w&ų`
+!eMwM{Ҁ(n:@ap6.r2}GԧQ2NgV
+[ʑ '(x #+TN."Nd @'v,YXLcZ%PD }(]ᨄJS8`qʂ()7@,y5XO'.j"k6Ayh%ARnm\FFBI[.wL^^@q&w/ʼnou.ѭx v";^|,(sibb-R;ce-+F~_cbW'zgG2& \K4vew҇+z#:9c69
+b##H;ƭ+X/0z}P_Ģ7yO(ЉlbO*;P
+Pw G8`b쐈j|`Ј<\R*']Ͷ:SAh15iH*@5+n1h0!7=u}:@! Oc4'PbJ6v+Ёtt L Xah_3ml6p(@hkX}(.^@7wjr5cml% l\&ΕC8X{~9v`owƫs譾@#̳دAi`"?qG6
+I D!rGBمc\6$O' є<$S@LLLlFҡo?yUʌ_Y了~A:G{,/œėB=
+*n
+m#{1.nC Sߩr`8bzsgڮ49!7@)kbkFC:|$ aݛ=&n )P/{<ة\ݸqa8[?y6jn*^XN/+OY%f̭fo).qff\[s#UM#ǖc*TT#+r#-,|Y",08F>PWۯͳөjc:Kl\[jv18aQ[_8J<7RzU*3 oWI_ L)CJ(#Fx?s-ɩ[ *]{6 hͻqmۋp|JE >er
+9"PCUX=ho?Ŀ#9-ܻؓlr ϱoᓹ=D}x`ɑLX8E7A-q?KU\WZʅC^WXدT )8
+xGa3c&@e⤁fa(^"!p͍@f NXetB S )xdۢfi)濋.],]eu-P
+D,5Z6;_ж+z1yaԔ0?a2-O
+SMXuFbKmg]'K`$*)~rʂ05wa1ߥC
+d#ds/҅MJ~NۭiAZI!e[A霾gZRsJwdC,~)b<e2sU"Ld6h>L@RE7"QFRgcޖ1,S|eCm3-qn q{騍͘rZbj3/.0HD&hwX|WpZapTɇ Z*URztdORQg bX`IRH将\ȉêAtjAAlČmY.ٙ 9H񋖈 /ܰ7\1-.ϛ|j1\X_GFĩZ f#FG'`{meօ]fp]S+{>.}h^ wE
+!9߀6dHXM}qⴁGwVaݖDNXiI+N-'Mx6}n1*[_a8dMs"'ܝ)U !ӄ|aK `+*s
+&npv]>Cx6VB!L:Sf)*̣zt: :*Z"HeNf#^p޽:V03}zXOSw rd%&馄Q @yh~]MAZ 6bPGȵ-V0.L
+:nKKĊ;ӟMz1$wJ84]l,LYa&QI̪AV9}#vIUB67oK\g`@4a]%R<'7LBn z
+p `7`.tQ?.͎>.U!Q=>@yd2 Q((z
+u{x4oq3C*nuju$1MdOؑRTA r7
+Q5!AX"|CH;ɩraK"Ts;" ؝N,D)kA@`
+ݗ^x-xA#Ϣx7yJ_he߻
+?wU5A5èo=h{=kNsB?.z}GrBJ~8yg+D豷9aIeB6jn|G.]Y)LT-LیΫ)w2٥t&Ldy=% AL)n
+a_cq}k
+u L?@lf QįvK\5QK\Jtxվ;ڮ+ҡ=r[QKݭT9/6XGHH:-6H|8,7
+&' fr?jizNY_Y^2)K{儏Ip鄜ն-
+iM~SjjQ6^"qs3 #"`ܚ/ r?[9rhf:_b_g3r7s qPR}p:[=z>_%|Ib6"$J+e:$y@5(M:u D¿E`o5-
+ Y޸Qc/=O-2yiT<UcE2^zyDd0;ORc1yŮX`9
+
+A3 i[Z3eOF!KDxH/R~|B+&lpvږ Ώ1Ov;s
+ #}Ԫ}j^ ^Z10)1ݗ4#&r4kDK0FCps(ګ15yQ1eQ sS'5<=JjPq*=:H]mJ[{p\*ڇ[cOvh}4ׁ_"_8_b*-uX'Ǒs^fnh=20A
+1)cIѰ
+ȗjCZM6 WIL; FVUF(鸺6l?kŞbOI{DqvYX#u-LՖ=6l=bOf| f!D,»"O6GFsq"`{À!Pv0e1αJp33,C[+W(:1~瘕[ZẻUT sCwu|4BrФN GqR޻mW$Tg|0vȯԤ@Ws]9$mF+cBӟlyPY;!rY1$B@+庳⌫
+F( $@8"W8Dt¡A@9Dt-kշuQ%p};:t(kU?,%;:Z5݄m.4j`9Z$cn k_ s$0hik5t;8 53YPN {yv~ʕc}AQ~ l0Q ĞEV'ߢ0ڕk v:l> a1v{öM4 3Az4!=40BIPbt
+gv2+_eHUyU(m
+2*<6 '400S+d$SX 
+?@KrMLL DWdF!\D7?4F5bCςU fu7Cpcr8v<mƺױq?9O "YD)l;cq GPKo
+{
+ xإwE@#ƿ5
+IDlT-7ԠHv,&eA9t4U@~wM!<(bie>
+8PWď&WY{ѓn1biQvc置9x$*RӴU7^<xEx(`&ٟ
+WF[:~pۺz`Zw胕$ E7ZϒzF璽vVѺ6Ⱦ9[d{&[,ޱ޹rSmc.{.$..H$Y43Kkh:ufk%?[d;G=1|wXb,Q(5|Ӽܲ쳇ܺeDN
+N?!V܅ŀaA+:S,o0U‚8(iԈ{;׬:@XXZJ?uJxmơ晥e}̂% gi_,rn@wfXwrTozDonJot\WaiZGmƪ7q3SpȁQ`MzU
+xnߜtnS6+ ڧl/[%!ްHƆӊEwp[}j0v g?6֞]!^tRm<ah%rc oe50%NV#O2K\*JXQOC\*QڬҦ6x,/4kV5 m=?t{nvx PGD6G֨Хi nbE+h}ᢩĒ,@ q p]~}
+CJAI~^?XekDYx 1#-A[
+vdM|;) ({:N-ZDMt{
+x&d
+.a 3zmUZFaMoYC^γ k7&v8xz]D6XѐFUn,m]C_`^ Mr/x h/>Νm Qq{o v:z g'a8Wa S fVS^#]f}IuⒸ'*$
+KP18AM&x֢}h
+rf["V~wu\0( asו-j>\b=/ˁ
+$_@@"
+|Jc[ʽy^1JB\k!:0"8]Ed3CYZM-c4,Guhqlhc8W@澦ֵ3;8mޜd|hk(pʯʸ諥ٱ7^<eT<HKNb#Y5T׏RRLC^`*aY*33*Ĥ<OH*.M.ˍL-ϋJxR]xFNg>!әn%<('=_))Ɗ0W 0'\+/S#Ũ(qmH:i겴Ⲵ,m&܍l<#F"EV(WQU{'>ke_ de0Jk|wFKOo_fOt˸;EY6 #ea_ b; $wH?
+
+zMA9{s}|1w\ <K`L=Ndmwd-ҩEӕnEJ<M5&o:@Ċ1j7Px Y_W
+VSyQqZIc7z1$Ȝd9l+ٌ-t.#e 9k1YqzM{Ow%v17
+S.x})@܍H1 hkglb?`?yqV dp׋TX}e8:QxJvP1]lk KSZcrP&t4/~l^]:hvL\cb<rcRiy
+U\PW᛹M:L'1%e(^!ogC^ ۳>dȎܜƂ5
+]˾xϪhߪWq:Bړu '*(e)YyI%gJ))1ʊ5Gkkcꫢk˾J-M|AK,O:]\t$jI\rEi\JMy>8Z[x$ILzSJj}iTZ{yXJ_Y0ef#(6Ukl=6JM/t>:•¨rH|l2Yl~7]j8$q$iBi^ў:ǪI *!Q:QzD$+&Kk$+T _aCh
+Z¶D>~[;t}3<^HaPCuNw{ #mϣ~c.G
+橨#vtVfL'b xg̟ċ0 A1Y
+E:@S }YM9ך'Td8YkG;uQ7Q~;K}.N&9'#^Unx$cd〣sM蟉&y 0g`
+g #ɶNCkd{'썚WG[{dLߦ͂7X =q=kި&^0F< w~1Tde=vݚ`9 ~-|Hgc
+D
+2tı,wbz-!Ry.z19fÍ&@@$}H$ X@_8 pI y^"#h;/:&iX"D ѸqOܰb[԰K'>SXbYLmd}(t+A[FT )M`.˝@9>a V8D}MG2- R7@Za q[9r]P~iwa mgSqDr[2i-ađbww|U||h; ‹
+hQDB3єaHneZ-aAAB
+ي 3Œ;l1d<̶yp)G.{ 2]K}7wh-xvyxdǚ2RG
+ t~VRˮcc%O-Яn? t?=sw~wMW3W/WnX<]s݉ڧ_40:.Jf_W~s7#<bpi8Me 6ͷb8-̙v._1e<lu5M^N[{:ㅻvZ=\o`?X}7[*Uހ$ckwe.>!ۄlű!LynIcv@0Bm
+ }y6Ϯ~0q
+l߳ϟ =ROOgB_YHM~ }10ZpD^M5JEiE_3u4pC4$w=^<_ -SC JHh k_Bpm>6r6L}L<<'B 4篺[ZHVܬxRW@VEWiƕ{!dGA>eV/
+gPܾݙ?ww| ,4<s6):d{kƮD]|KYR<即Ȕ53ucR2%rw-"I6]
+t.gb3 S%:c}
+,Q*y:L)&VlUAHI89c7S:K!v#Ij`u\kk&s;#>7fSvjM,Vƛr 1l[<9}rH ֿ˜CtC˫?Y_\Tfᅣi#A5 Yc.,EYV 6S>*mÆoCXA
+_=;WDק<a zY^.Vp)/&7! Q
+5O-<_-7Wj|S-YkTV=x
+6 bcicYтႱ{m8~gjUCL1
+6z{ew_(ߩ&O{/
+J#pM~[r.Tzqߞy"i-i
+"-j':W.+jL '{Ý(,0SGI왶P2xK]-WY*r'c96Xm)u(wJ]/ArAqm(]+,hC-rC6o\ص^t%~о PSzx*ht9c rH-$n˕Ù&w/VHOd<B́p%܁DOHjO/&!4X5h
+TeϜnFǯJ죶{j~Fz歧 `\m:Jj71?*/*/
+@w{ $Ggw&M }4t?ù’ێ+m"@6x"E|YS^b;怫Vz(Ђ>KY_-Zղq/0
+B>nm퍉y@n*&tuDΝkLtR@۷8pL].^4x{p uR]E>sYv^/G[᩶@bN#smr8$gٺlԞ L# n%oYMcW|ilMGIdMX2تU1-A  vhz,Fe I:1GJdXٝ5bY"Y ٤U 7ڕ.^fvҽurlATΔ55 }n ؝v\8״ˇ xցtPTʅ*XnƥJ
+ t<}<O_1$ E_ 8S;I3-CAaӌY !o.HuX
+jiGu)x]7)REidM/i
+ W"B#}}>H
+V#404ݑ,Īu -Dg+tr;ǤF&' Hx UeM<FY
+.;|쐵Yȿr;A0HMtaO jᏵ ߗ4s^*|z=LUGJU5 [!]ڗժHjѥ2d}<VɗS;H<KO]KUW V1 6]h Ɔ 96̈́i ')1J?Փ
+⊡" J -X<\ ;[XT,Z =tQ)Cm!@@@Hn|ٙ9o=̙}> pǨUj*k*F&֗o`Dוт[Xh_ >HIJ9x.O_;Om#rqO$bH`ۅAxp$c3(Lv 3P͉W%*e %tFůOI:Y&.5Tųߗ?Ox|E7o1bc**چꈤƒДE旴ԶW!)ea FRlMao|x(z̩~A,(YSKRwj"@'6LS-SM:
+0F߸|:c 苋
+7Yr-,dg
+2ywݮQ7tx(L[\S~rug꬚J8.~%P@@08oM9(g]=4G_
+&yպu֠$k)w]so6?[K%:c%lMt:37ok4xΜ{~~`?}N]m30::uFF>bBlj*t ˕xi]/?vi,^#~g$} g*ݚ+2-_
+0A"n33t^yhqd4Fsf\!2P*71JPfYk
+D4iʁqo0^V:ZMn`<|l bbfAl٣Ď6SKgR"N4l?9b;!v;
+жY**sU-M-*by|"LV 7yo|KQ Jp
+A]dg {dQAQG9|8wn=ZtB46|ԩmV_o
+?HQEorTP$Rߔ-pׇ5k"5F/0~5G 2Oz0>hwsB00l3`8[k0l(3}t A!szo CZӍS6I"cv<1!9Tvq]p b{%i3Ċꭑ<1ڂ72;p$V(qp M"+cB)-8z6;"Fmmi͵y-4
+xe;Rm՛̃-%tQ܉ 6CLQ9&TT$03\PvO\ "`QP\XY#­Zq0&//;e8MQCS9eH )3Γ'29aZ.(A4=|
+bTPâ bЪR?"/كta/L
+0
+1&ݚ6+Q zIoK 瘦M[RsmKώ0:y$SwKg%)y)YɓyGior Rf {WqG
+zsԷ}5jt 58Dr-ȀzۈBcĉ+t
+\
+y4w,RBn( Tyie˭1y
+!2)Bk($LRh,zxlj_~h=!mfvao$5
+E;*M46IvٶvlgݙMb̮5FAQDD x_(F7/K}gΜ93s·syKʄzo
+ 9:wZɮ <|h25~`NܒNZ{Vt"ϊY[`YV),ת>XPnh5)q\ƫ}K:Թpgu<ew"޳,,ܽw-JrY"[P]V)烗UʪkJ
+kx_ЦL#u(]= D( il&*vu)N(*3 .ۢ=񧆖>ń \2^wΛ
+Gg Gb.hƗ VTtՑ.X'Y\ cҼ:8vf4#ЯgTZz3%`liG\w'H%m|Ͷ@3>3se
+[
+93mMF 's~Й| <8?ibfx{}n@ӏ&D`w˴
+.mm2άNDF HTb6EڑI^ 4X!cK314M 7$pO|#@xfKҶWҾuBS^AS}lw @܉+uw:&:1v%Ni=.=ǨdbW\[҇l2&Poʙ|,>"1wX9$T^[)sD҆ 5Hjg-
+
+JZ HcimhNgÁp(&Z&kQ$m/aFFcuT8kFfOBA HmI32 TSڂh`X+2hBQNRH %R2f|sUuai-όesώyX)@C۝?;w !`93qu2.a?nw~Z/YϪii*igse9Y"YjJ@Q' Q.R@3pG,])jy8u xd| ?T@!x
+YNvïMϫ{II !*[G#ȴTZ@RՃ8rUU9&PbZ9KPmK`!͋iq5RB*b67E9>.PWV̭X%jvYS/ >SQc酟r^T\a ^Ԗ5vV$<O)Q*2ybm`)0܈^krgQO0dvu{-߻|lwco#
++]8 )Av>]9C.OƷß[Y@_dC\)|o wU?/~gt>J˟P]fn`r; !s$M8Fr]cTg8E8Izt/Mtǖ6&y:BwX. z0SipS];Ȏ482fQlA`y{/A~6}b,3?挢uPZˍṈc/:$׮V&f9O 1\2gnq/ s7SVeܵi'=/:e֫]Ra-V%d1xAVh`dz(ߎ$! GN/4Qh!2ǹFN$/I }W,dj%v
+@Cf?&~]ȇ Q8R"EI3ẏ]6j Yb,³s(Asxn.pѰ0T]
+5"
+ԏ07P~]>>c`Чs
+ 2Pj*Nx3} ր$c/{9pTNdHn)2$M)vj).U[BiGubdtWg(] O R U;pe{&e 6EhE9.&MW$jl; ې4m=zCO kw5U0L){K*-MȐd(˰!+I%
+=R^;X^P  иzۈ%MIJ!lA1e*On2oNʮ.
+/0Nr~J=V8oj2R޷dkHJmLh3Ir&Oli<*[TCIrșt 7*MQ4, d l
+4$hB@H `@- nи4mL*J+((K0A Ad%! %(6ɜ5?jn[Ts[=ҜeHRsRNOY8C j5f.m56Q >Kl=/;ƲvrMtv5]OobQZ=Z*}<4TQ8 j.հhrro+iXTڷ5u@r6ݿ
+*#4:0{H_BU x86ngr{+·ۂ! [0rhZcWhJ&=f7~׬VhQ% e#HM^ vVȡ7<cg1CLF@dUa@Teʼи
+r£^}͌
+*b* ,V
+Ԑ›ˉ!J 1-':x8c|^6ږ6RgEv|)e@ŷ?]^ť{pq^ن q q-Osr];Ҝ._q1*l]Suq瞇Ut񟺶>
+=`
+ǝry6((P9UFV
+EᛇfngNΤW2K1{>AfWW|mE0U(+R>2Jt%-_F,s)[
+17^L=~QZbxa өVmlOc߁pNێqg>L"ƥp8!)l@58eDLC68 p!40$x m,g42>@2fe*EMdS0dt4`g 62vwa Qe*eqDi(Q[!";ZUmgmsezjovFվ!D"G6mQER>O0?yy|}@6#Bv?;qҲYcQ]؎
+iy* κS a
+Np VA3\)mȔ2`4~Վv6iC0!M88v'0
+=+4YYlL
+Sqs<Lmqp[+ۇ;afG_CNDTL 8}?wXMU>
+,$P%*?7T?% fIKb]*$8%ob7&c,t`8!.kCzv 0'ߊpT|K7fC*DhBl:!g3 (nmˈ>UG&WQ`Q4; x[Ǥ8.v!]1/i-{I-f ݼf-8 =8l(Y>vK:$?Mh(M*o_~ZzgE>)~~E쒶&5<2>w.Xeax;1YE:#
+)w$-EE^Ǹ\rUbR8b[޸@ ]K GvF9m:m{..]2ݡZs-4qI/u9i{z"X0T屸6M#fV5
+V<fឳ poe8ln X
+w_D¦pgxάQPݺulf ӭ!u ~///@6vP8i0ѝfYǠ41Ppeb=t5_<4;A&HCz/
+#jʸ,4)A3g~9qIJ^hs!O6-AUYl3čM>|4}搲Y Z-$P%zG)M=N\MQh7@6<tj0ngqޠhDi6'4)ItaFt2!L>*b!8e`MⰄQ!73Sdyjه_ǔW"hZ(ewķR{ /m@ƏNSpr nKZvDvm9. v
+b`J+ұ,K'gfwulrll/ͲE3qEMWQA=yyu΋|XԅzMƞT
+|Yl3Bmt? /l <lkXhg"UL]<{civDͩwW{E <# tn'v@w =6X~=^z{?X BN*yTpD}䭼Vr./aŭS/B߿6\yc
+w]P7M?9=PP,iڽqbADhGp0Ԩ`Me P}%3`_X\[ȶ+I1/}Ǩd%H=g8!9<L5i)FІ1t VǼk"L5Kg|:~F"LH^jG[v.P]D2
+Me{Pǻ7yH }|bt=&jgٳHD8fdV ǡ
+iP0Xa@sݙߝ/ݣӱ 谺<raԐ}XޔFջǗ&UDz{Fs^{yY.$md\m o9I;piCX
+  ׁ;
+**aD,P]) /&7f2!UaE̠2VUT]MCmMCǶ@E Y:I6;(@h7Sw(~!UoƷ{X$v޲/x:+)}mOGifg:_:žp:+L?y--R
+m@ W'ߓ.^TN5R@5q&M'Zuzz҉ bw5S?LsW
+;ٝݛ6lĹWg%gf3ug b$2DH򌂦J3;w)m@a0-{2@! v/?
+_ G
+VP}t^hBVXnv~gmU6~I8-8~~Ok4IdśG-C?DxU'z#y3xH>$@rQ4>*Ww
+z-ݧA
+!!YG:wn& )ED:Gf
+XRYߥ*@:4pvegMcSDŦo]_>,<~Hׂ4D]U_`w v\y|ˎrIU]+JΪ+!߮
+37 mBk4EKNKjm_@1k\^c̔I1֗h8x u/?JyWBKg@Vl$~+6=ԛW>ִ@/:t6BsywF5ua
+@
+G\ {dS@F
+g!LLA ? `T\w˦=|,߹T147~פmoFk^bB: afO-c5}Y=W-6c
+ҨUlԾ/ٳ3=wWz}MEj/##tspIZwbJq~W~J0zl|gvX{ }ӲGaO4|!0 tC{Nh]F!qIڼ.؆$
+ n[C|jDtK-z*8x3r)RBF8Yfq*60q&]C~iUzq3R Ǝ J`hr4f#NR+]Xq2B愘m BOZƌ@@3Ə:ƌ[PJa t>Qo܉2iX۰7t*,*|Β0V7Y?<VvX_=>~8g`GGFDMć6C3)rQ'˭fnͿt}GLc 鏞z)cEdrp&NZHF׵c1W(O E$ሾN_9^\C3#%#|눗7@ cN1'.q}[Rn7_Er"UX&%A%CQ>D<\fbQj)VS0/J7fȔY JGS:_"{mS25OIiԺ
+QGkYxV 9]MnYxf`<Z8M*VX(5< }1nqPK*h3QFl6&-$!kC{#u3Kb
+O@64qJ|fͽ䃴[ J&fxEUyrzm!YIH<Ʀ7>@ǤV<
+HO/Sh/S_V֒_D|r?N>&ɢ'TSc_4&k̖~;6\ =ܷ >#9Š[~o9QL-_s:.϶ܶ[G[oGfsbRX4Y%3$F5Ĩ!,q Q.9rq|K
+I IHE FEE@07C,A-*1 73#ŚFBI
+ t*ؑFo͎.r|t.QQ
+86866538 9DI 9 85 * ? ^llK~;uͬ,Tۻ0E&D
+Qݠ`Ӓ&nό*tό&tӃ,}҃8}ΙBgаFP.MMIG E=77=Cdr#iFe^egflhlfkaekZbBN#@ :
+< >:= = <<= DMQJ Lڠ!KȬ3B½7A·>?G7B9;<2I%Hݻ#E޻Eڨ+Oժ%QӔ*XʝDcQ`/<
+(#&1.}32*'%%( 6 CG0&& %&  !!&&&!!!!!!#=Q_ԗ!dЖ/dͬ;Zӻ7F+7(
+.6 329 603..+('Ѻ4Ѽ49522112950-1 4 1 / 5 2 18:<<>8;98 9;I%QBSֽJC"E JGFOՄ/RNZPhQrJxDAt<o=t|>q|;qÄ<pċ:mƐ;kř<gģ:eƨ=dêC_>[°4R˵*HֹA??@AA%Hܷ0UӤ@cȎNdXi[yep^lTa>b¤-eŜ-iƝ4pȘ5p͢3bұ:O':7<
+endstream endobj 78 0 obj <</Intent/RelativeColorimetric/Subtype/Image/Length 887631/Filter/FlateDecode/Name/X/BitsPerComponent 8/ColorSpace/DeviceCMYK/Width 644/DecodeParms<</Columns 644/Predictor 15/BitsPerComponent 4/Colors 4>>/Height 426/Type/XObject>>stream
+H\VgXH%J T)IQl]zՋ. 4"\T+ WPYXW]&))"pn'ˏoy{ΙD$Ι/++ 1srs sEnM 06:9BOw\UnyENE}JUF|D?8!+8”5 2w|.GDGF#;zyVs̔h_2 YaMn *Zbq;G50|U<WmUrSKi\..Pר}a_
+L,9 qJK{gL~ aI2<p*y+j;3F'y+َ-<w``ĪjSJ3"ÖaameٺW~!\Ac /{,pUHߝPL]cY 3^jY =Y;8\rNG6&.Q{$T~<1S{$2/c"9,'UurݝO<)ay䨒`T[cXl/O\UzSbTw4l][pyz\7ınj/Z)SD{~?w~"6ukh/4yq 씜Ѐ4̟h–QPO۪nG&^Š==KŲtu Ds8`TY"]Æ.13=o{wzlvB҆ʹ.M=Fz]*Wl
+JNES`F}pRu[sÌvL>2AQS(t smt<=8QUUJpW"1AibCkhZKˏ
+zvņ‘?D͉Ҟ竒0EĪynnO+]Z]&,qhzBҰ< +f7Ok⑵X-6v}6S㞺\Ւ
+CF%}!ϋB=o;eu ‚~}qƕcNxpBv^jBke6YsfXB/N{n
+"
+ǝs5HUKE=N˯jL|lE5;\#%󗮇9m*G 7b/h
+_+:J[TXNeۉ !0$$ Rڑs#3R9~ֆ82fNmS33z#Wa?m60ySabY}`p<c M>2g\3iQWPq(-أC.mUv$ ؃kTHx0W`h^g"gqNG=?;$
+7[ AQQh"F78AB
+DՇ
+/ NAɑ TnppI+]`rW86E pa+,XAcAeՇna;nLCO
+zmגu>l &uRh41]rۨаJyOE6Yb/FE/טqf$;Lx.ڈyʘ[x 97+TܼET ]FRG;Od)WLgHJBM[rOfZ1N ;~=;E\˳:?4GBClmC2ExiF4F΅*?M鲥6-)FzjlAw2STf
+JD;E8$ >Zlx`0@~X\x`UH
+)`a/2ɨXF3h?bz_@+/hPrDU
+1zzBQqxA!*<RaUONEMCN`@XJ.LtU5qCTg KCrM]
+|Nw,Ȉ6d') >NLs2BXq9~KP@P0=3jd}$W=ž>vvL"EdCЈCB[k;{E͸j3i`H6vvhu}:qu2}Fwc&J5Ms e|9q?> Ά:iEdݏ<sl+^=]aPQ䵴AD3nd~缿˪Xdnv4kU0՟e,q~ΓZ(5H-L:hQS&-AgƅMS7ZGg{w1;nؚp-lg܅]$Y_{F<zBMn y>@Λ6HhtѵDZV6Zeh!O'GgN7\Kŋ >j)3%]c/?w,<bӚΟKt{6ӢM읧˳Wb'e]4X}x'^,qNf?{;0߄H|%25ϨG Jw\RN; ?YUz=}#*5JNzz^MNtYFj6+;
+h:e+vf.2󨦮<
++%
+B@B
+_VǺjԴ# a܋ S:v_N%[sų_/[ `[y/7m.FwU{n׊5Oxm.m.ힾRߒ־e%(ν}+UU6(Y(+ZбmU&,>t`ՍE/z!Z[XRVޢos*6|36jR`3#Ac<
+<W$t"q(:z6îj#>r<5vEbÑ W?/<%G.,Lq#^-9^4j2^[ 樖 i'G(bW{
+Zyc~챺_C7E4V1?TRRV_'z%ߌ:;U&V?nt{ :<'vy{Zx 핚Fx+\ʻ;?zd#|Nnsv7UWxZjHab6օxCpq׮RRbH;XΒ/UK$Bؚm9PY?ܯyw_;V= _"{=LGIÚ^g73 ɭ1$Lk9F(v}g]mP/N*A݅Jvpox@\<`3Bd3' 0` DA" (0H
+$}@o)=Dpf@*Dޅ"CD G@E"IN
+
+N"Q $<#C',.4o:m
+ [z8N>u&qLae?0lg=5oF9O)M]Ӷo5 ڈAՌZ1ƕF&jnEfRe$eo+~)Xl[kҥ'`V/nvPgG9"YD0N45tSc8H45%Rhvcti[s[;!5øbIeGU&WY 畜~XӜ˱wqkFgٱs?el`rb*lnfg;v[< r>7^J:MLgT3Nf
+2#3#6P1X4p&v%ygA(P '$'Eoɾz-K>\lT:k
+{.߉%U:dr[kQ%/Wר='ʊ#mI>*/
+u9%žKo|v(+*?YH|sMOk4)|` pUK+Z{+]0{ae0HNddYϻ-ErScX$u> En2_kcUxIg~J9_Rɵga=EɃ^Wr rD`_I=_h/tܣ.f>qy"k+Il|2mm7J;vu72?GRx%+Rˡ|_lמ+lWna x
+BM `"a$y49(
+a_ŤFHC\Øj.Q>N"='['珅q6 HPAI#<x<18b\Pޣ=`;S;NHG.p#G:!jPYSN ܌fB[@>@ P~ Ă ~
+ip^ꚢbd4ETi
+q>QNQ @@{8xoentQR󧞉Q 3L#^ z>HygmM; )>6[) ͌e<-|C5m6}t^tAS|:h:njtfbymJF*8h
+;&:8LڄFco`B05ad6A`e̅ @IPFdMZղ &*
+{jܕƠ׈SMw}1IV/b:Ӕ݂RDTZz5@?|UMgPRxCs/yGVy*$N}JcgèSaK4~f^&>±9& :֊f1IVFCNM<rYϪBryevmέoR'֍ɏ%skq/gtA'Cʆ93MLRTcŐd׬a(Q7I|0GAkd@QӦkӥ?ҾKMO;ᑞqt3JfӞ~#09 b_6;[og~XCګuK<-zP`W|cw6|m. RANчW
+^_Ȼ{慷K[nŊ9anre-AU
+^yB5s$5P; j ˥%WjNW-V%wݧ/yyץ^ZpŽKn ٜKݰإU_<=t`ܱ#RKOm(ȋ]T;2)s^7X8M4>ET#__I޴ 7nv剸S7J:Ngob|T? žz*.e=ꝏs7$+ޑu7:oۄu\Q`j<S]b`˿;wϹ3 laP'P`0G BB$ }{,p3H MpD_ǒ&r
+`G
+BL<@x>"t<D?YK$`(B(|A@=@=(6T~ئҷꃺBiMSlȒ
+m{!),;t2G&
+ >@|?P(JT0X]< =zC72GЧ'(@x_p2AbÂ/TĂrS)ᢄmʃu T %_L͈Q7Ma
+pmH^sӅvʰ~y#Dņ
+f ݾ-Q(QlADƜ˄h4D6])yY<Qjˠ5J5byet7wJdZj]h]J]w5S5ho֥q6QԽ֦nF/fᕅ1G~8SŕE;&>SFa)o>Q)47f~r~ލ3T[c֜gbicS{(ZQ|ly\SG
+GB e>R=a6RaΘ04 ƁEQhvg]oomE )1YM@TzUp|r|j處+C3l5f+G'ĽA@g,j\V }{uGR[n<KF[$)ei@|n^W-O*T.u.*_Hyvg^.<xu\k+q/nky\x#ooȇxlq%BES].=^LN+UDANrbJy
+%}֏{w}s*ԦE* b>G +pnFTO.Ju;oQ\٥K=beHKY>ͅ1n5ycͿ 4<dׁ7l
+Ě#ao~422
+!"JI9PP軖Qs]/$V<Xؤ\ HXx<@!A0!h"ꙥ.ެ e
+fK:<eJ B]߹j}\U.Y_jk]$ZK.o;HrV=x2Jừ3oܘQcݩ֞ϗ?~aڙM͹;9'k?Χg.eY%bfEXײLܛvc
+ڃ"B ub}J̀氌q҉zOx`{HwiIRrCϡ;(%5IK?G:剔H% #e
+x6D jD%͸kƝMf,yq'Σ:
+
+
+ZQX@H
+U,o(dZ6K-Ml|
+DA>`OQ>/gO~={._ް2+?ٵ{_nps%vrⱟ7,>FL|DvU[h?DJ/Ʃ~JveWpwgЅKwZ;''iqi/rdy]9D߷J_MMwB D>-.m42)*\s[7^+|M0*4 ^o :@=B ->cdՅwXPX"ӭh7 4}`
+?6lAƵMq='d) Hǰ7l/@S@a s L=0}ddFTc/$Dm &5HA0(T4l̉~/czAI0w9K R gT$#ҌC9 gw\E pGZ4anb",lE6:vY5k=ë9Y2)@LqS= xzXVI#z%hv*w⠈/&H%t?{v;מ!y(x.YǎH|Ur,'雼EC*rwxg" TSf'pnu)۶0;AVz[j$[ N5BlR
+^Z36fhT;zGf:M\Ed+KD$2_)gOPY Z>m,S9O 2f0R#!Ճ@ T`k2QoV˜*K7,UՍJ{:gSD鷵 rך'{t:FlZ2KO+g^UDFTNUDku# \ۚ
+5qY@}ZȭR/FQ{ S[>u{}ipY#iV'YmNAPrL.G{ֽسV=ãiX8)oIXan',=٭ WIH7wo(II43B&Qǘ-wu7EEz;g-X5ϥwa/jW½jjC c(?q_fNVºśqO)=a޷X}ԃ[{|}hNMvүg.qKhF} kjkF/+|9( NURiLI}{oؓ/L-/97|w3'r8#}߉3l_y{5%>/r&.| GzkϞ폂^g߮n^bBfj25
+DOBXaD!뢲2*A zmx{ 8=СAѢj
+>:ƁaD_,PbLڰ5jQ\Eh<j@ÂE1YUMQT@J@7p>k)܇+)փ T`㚸
+(mgZkZjz*@$H Λ7!>ɼyy}"\ ;
+`u֯2ܞQT}͚Go\Ȭ[}| bگmWx/muO>3A~t Yh 7dq>!t gtyDE qV;j>(D/Gb<D=_䣉
+өA7w!"gXeFP?6y$hX?T(:"p"}p,5QP* U/^(dF#Ap6DEUE 4hۘ45,/r?#F <"r&8
+u2儩.? (Q:zc)Q0l Gqs#:@%) d@/ Gg]j"ycz(J&lDexߐ *!<aa%"٘Q!( DC⠘pFǏ(E>(B\@!B j m@TW=(;>}=>APyxL~v@sRE`Ek:J Dڏ5p=a '۠sg[Ua_ GdT,"0T+z[
+}hv5!uƅg v5L/cpt*Cv>FF ҩQ*G>fxH\t>L%<,33JQպ,՛IqW8ԤX"_Ϥvzs3o?cPee{5FkZɱ6Kf6QT'gFsezn`%.2__WZ"W{.OYfPؓ|3a'[;%$xx,S<E#<JpQr2c SdL [CuVtߤ[HS77QdQwBx")LdTH63f_x~ʵW68wnW7_Ss+8pڇKR3f&S+jI\ah%TkNm~SI8 2ОlyCbv[[|\*䔺)IwyH=z5+ٛ9*-z^bC_oK焟:'ڴ)z5t)wS+_|v6֜(,Xyto)x3?O(|ٌ<9!8mz^ڞS_=+
+"D0߂k(]tlOzP aj3Pv-8ҫ!ѩZCE
+#ETY{"EvrNQ+u4@Y
+Ar䋏%tDP@k>=(jzlE
+4Kb$$ϔr<?zҡ
+OfHbCk2*IKbp~<Nl]@?<yX5 ;1MBe0)#I|-𶠞()Q _}HMbBU(DۑE$ j u *#wVuo_[Xz`͉FfKOtᲱ:#F]Q<3T<mb'z"02th'2 s9݊wp}wcdY mm[|W|9/ZUכm)!ZጎC&L޸I%9ّA6n:Xm)H1r]2ccM0 6/գ'cpMIf䜟͜p\0$r2g,49Ka6_vj4i*!dL O}4[KwI^d++H= 䆴M K6OIJ^}tD$eDقc|c"!?Nu;='bY=oH!L:{ːޑ֡*^Q/-XjcR=ҙv+ (/nKa L$Gyicl1Bݨ i`hW1fB$Rn\Kl*c:O{ih޹ÿ|聬7O*͎ꏎs2TZRm_}KvaT\8o*U6d<Ʀw{ʋ,ilK4<RwSs-}20n[^S_\+]>޹k0a܆e ũŏwtk~+6w36Y_}taʪwvꃳ8pƽ?*^}mVlU<x{|ڙU݉' ,1\z}\7?>}p󟪪bK媽GXzÿÊ붼SsR =~#ٗ*ʔUwgՕaB%#@ 1#
+4#InFdb%Ia=,>0P,fJ6yBB3F!H"Eq0"]@H*B( tt'G% %1EnkG G#M8 /7P}zU l QZݏ;^OHMBb1I$cmHYpr*[ PT\\2(Ї s\9
+<G%(E1&%#TDxjGG3TH"' PqgV-TQَ 苈js>18ು h SpL\i@PlXk'W yDj$FA*"19'j !.BB܈yzl
+N{퍘]|_9abM<72 '"iH%lIvvr1fUEt /NjdH3A`%3x=Fv9Gr%+-a2δX?}㚢ڋoi_4binen΋wA4%Mˣ9V{añ"z23!cYg9I clZȵ3}9ew-3 gh<\`pY1oD;I3)Sj]R=/i]^ry%G3B3ć|R#r=a-Fj;E U8&R)?rx͚b:'X,KKLIZK#iY OE}p/ٶN-?֊T_-1z™jY{2g&'h(]zwj.w`EC?Z/%qmSEvkRվ<|yPW
+rBH"WB. !Bµ~H}^ybAUu$EJZޙ.^ٲw+/ϨvS[+;\gx>cxw;wN/4)_S<-q|}Z2S DZܣG?[Bcץ -k{9XwqO*ryzy#?,]y}nNuo\Z*Rt?ueKjF_k$@b3A|{zP
+hbB&W[$A 
+)T!6()l;J?@@@;<g.C9!1"=BA!QQA#
+^/ڃ5ô46 p}
+ݵ]>R)j<`U%`
+qL[lC=N]J⑽vb V]͏#edE<?HEyN~aªNn-[Ww+F\KL:_ogvp/ԕmږu"O쪹muQO1j;~
+X?\.MWJKnG֓C袀'/9qBIꍜɝ (Hp1Z#;W}|=5t
+5*$hl0IPz>$,.O}YPoҀ$Ò/L$(-0,BXY^n瑪 ZH)A;6HH_UAE4qO+tNFzHt(D;qп/wA -*I=<3O>ʝ1HQ
+
+N?AA@(=Q9
+jc@2H
+T6 nP'IUx>'
+YrooAsF¾@F+U+Cd_Ou_nƿF;a_̺YryArͦeWFݜrܾ/rLO,(
+ٱw֭:}RgoIp鳧6m/+ژUVRS,Y(]S+3ݏHlyE6-OY5%uW'H;Z\>aחNp.a]ɟ+eqmD_‚w;'<_4껆5Nt<x<)W/9g{
+r7,*yѡߋ>ϋ [./ίhY /[>3E~CNM! 9E
+ Sp@A!dF"=I
+(:NZtp-h(Ha뷂iaC2 6^Zt$%fċ9}Jt v-R!!ɥ
+;Q:bZ'!tDTб1J,"ݡ}J{98<t )2ZzVB0(Hp-=@hQYc.Z(Fa2'7`f uOߩA!paÌ*Y^
+GEL! nC*ƍɉDLĒ\T$sZ Y҃{"E dHMp]h2?zbdHlZAmJHK
+jEUTD*ŵ
+G?IUz.ȥDE@ IA$ྙ}>̼y͛s*}WJsUczQ;) zMksϊͬh7+\Ur&(= }hcT6o#O=OaٛtQ8O?oRTuե}ʎݘtw5cUc.v4{=n5bl<:IאO1Sn*/o(TJrgCߵ_j7FcW|jVzs;1 .V/׿=Lך#J`զ [6 ݖcO,r>..xU~\yX8WxMaPlɃeK>{0?xN,ts5r=$4KU-ӡ?v>um`Qfԡ{>/eXycgxRS]ᒮ9ݵ]%D_
+wYa}=qWӿFJ2!mEцqH\cSb&5k;TM7ʛ܈{!i׎3vl3)i~nG.-#k$]=&6*((tf׬yYWs/'V%f~9bqU:.1O۩O9+9.ьI
+;f7@ eDAA@A“RB L"D2.9b <iI%<ASLIpp| ..1vxEpAɝjG\:T ovxY DDJ M# A1%|Y(3m}n(v h$ya6׺A;-@<qB/38Fjeۘmf {E*#!Qգ@Ђ LkF~kf3 3եf>\ *V }b \I3T t/>X/˔UTLtC"s"5$6LJ! zB'|STU.P(',RfP{h ڡsݓ"QrI
+oê1Yֶzi}F':mj/i'S3Qk>>@zþyEG] $jo$[]n>tZ╭ku.2qE 5*|5Lx7(g5(7[]QOHÂ/t5ؓ#ʂ\SSCZÓzmތ^_Kُr/ AycKZXv'tg]n<17vN~ʹV6G`r,AŦeɲ;e$bwʜ9~˺;.1m6qofIx _hZx6jR)FKII򺼫Ek]*\Ȯ( 
+9l%=Ff>\*dL[>J\|zzTDͰ?*p_A*1un޼iOzk&k+4E`-#I`ȍr]u}
+` w$(G
+!l^՝\]eOS* \Z^tb֗<8/f7alɦώEn}<w["(Yۣ׉k4*-ߦ_k r0yi&-<_N4:#~bZni[gd
+Gvl͹Xܽ.Iȫ"uűoW%es<G/tnɧwwxmU)r)-~CG;GW?52CAaTיX
+ xn>d R
+2DdӐSzvQRђ녜G^'7@w<z|-)7Z]_I }ZJ5@ߏHC.IJ@yAiP'$T!"3{09st䎈Hj>C E~ՄRk Π8EĨjAS<7"Ip^(Nd,9 "J<pעQ6aMRׄ F}xh D|A [%RҢak!"^4F5X9'/
+Z\J<K|r6J/a umdIf#oh%r;]qGRo+L3ugIR# 䴱8vjR__f\Mֶ4Xݢ1hVW8M隱ϓpb9A_nY||gl-СLbI.mqĔĐyng0=qܿs*saNyir& j?X402yX>W>ɍdLbMˏx_xz;="03gϾ"*Y{]$ݤC]uR/ V/JA
+\iM qc?*V$;հNxuW=4
+ӂxxhoc,o.n(vnXR^AcUXiZʽB\+<'k}ee :'s`ExW)T-ʆ[^|x}Tgz}w@J$z|CmD!U^7۴5Z]5.%}˿>̎'>!/PP|է^tzv<9U{09&׬hmUߎ=㿯9|FBB@UvNn9>c!竏>S(pF_=Ae2F'H(;*A /1,:0 #SQ~&w@
+=Ko4G}D^JWDH"]LaTO 5 C!Ag؇5SiSqJp@Dh6©]ۨȀЀuԕ
+,h$BP;@ 07s{n%t٩XERuD+w( %h%G@5*!'cX[
+[ځF/\LAA=]~dpɡ C (%4&(ghE.JX I m` ̂ MW'%?$34.(dkސ'EAuPHHHx$./R%80QFʍ\sC$ن R4TA^DR_JwކԌlX֠ 0TNk}\Ϛ7gb@!mmZu0Zuk-;N{EVlj_ټseg?Ezƹbs,MFn7eqZ5uİUR;5jlvĄ57kmߛj͠zHxdha1{=`c3s5z1iܭsحP\̻\/,圐پuP^N{7WlUoY җsvfsmjw8/ O Yf#~a6:zG,ٸ77u4ؾFͫX&Bز5ֲp[IȽDÓl>]sw~'X5 X{%mwwz{ dw:l;umRHje+<cߊPexM?et5Wkf<Z]z>gGUUa5ּSRǐwAz6*o?s6žOe?Z{h[ִW{vaAwSDx7Xs:Jwt>IT{E)ۚiiUI7KDe)I孑
+\/9$7{?_C}g K-|=#!hyNTI%2)S֐0"7$$A ߈qMĨgh\$EƇ>7wqEkxX}-sD%4>"唫T@OPI/Hps臈w,G kW9í=C]IA2x}dKA7ht0gP !BR0^BYy‚2N\O$yjQIiRG$4T'_{=^x;tQJ{l;YCC't6q9# #"#<`! fё,#\%5Y">$N\H @hc!G)Jh;Eˏ! H W!*>pTڣCݓ^o(- h Q@YH1$k -$ mϨqCÓ> ( %/9VL&C* <➮ t-?Jz'MhGoA(AL*P蝁!`34h*nx+e&Okv8i;athg;qFCjJ˷Ԍ8r&Wa3;;a5{T;PFV9OeTݕN<|iIe(ھn5oȂ3cNz'fjBLfic=tt5X51pW1v`ޏ-ge3.6Te^wb)BR/0TXS+f/Qޭw2QN/7 94mL0gƓݜ
+":pߙ7F\cT+m3<1}dcAm /cK֝o#ojSt|߸eT>\6ݨ[ Rn nHq5y0a=N؟&"~`)wkw~']t{6h,[a%RѺ] 99{ŅT6mX'عw#ZΓҼt׈jŹ[W(з<|S+i5dzjW#3ȩʌR*)=xCZWghÉg1yߞϽ&mɊ"S+6&4)6
+ox׉k\n\<uf䨂ݪ W5rK{i7ě/tK:yNQdhD$/N8^0`}8)T)0%hE)wG5
+(*&daI ,!@w}y}ݛ}뽱Vd=1i\԰RYy+Ow7O3X%)|g{ASJWqIy\JkMJmMlK| @{稟q߇r'qõÞۘ '\*11%Hc5HdhE1E#DO@,-jL-U&c^gjGN'\`K ("S
+(iyŠZ(;撊_A GXzIޣWR苩;">8ZY>()13M'msLYHr?P,aA8TDRz̐ V\ V,VFDfLib._uIB_N"L,G$$ "$2 뙨c}WDlDp?lJ c)0_x)R*y&֛%,ԏ$x6lHN6Z@&BD֥4ø:s5y2H8Ԏ~h/viuBtCLw}ju^Y5ί&-f}3 QQy}˲lݵdcLYQEbM6ylFe'9 Uʆh3i[eq-  |nc3-g9F%*kd
+a%qサźy7V?/R4X%Y)K5jf8k;:8\N( v;'E:W_~-=l]hg ԬcâѰnתe4iy;_&Vvji׶nb 
+T/A0ZB6D0nhJkY"8I
+XmldH>؆JK%jF!=j@.%;A{P/+ɐd0V,]5G,MyvOf/ H#9GO4U-"a/!(a݁%*,LY E,7G-Kty[蓴'xBXOH[H:`2$LiDC ٚ,IKUe$0f{:ƈ0IÂԄ@d"NZ{N(tMD<QIذO߂,Z:$2$,fI;2"HL4'HK
+2&" ckSZN$c@$NMn!vTx
+xXS(脎~XlL$9 FtBnLayquMKue[lΚ7)L^]=g^[=꽨Sy9N)l^O)U6̀L531b.wK ,„LHḌY7VkTny~B[X! %V99\gt螕i٬8R^|hdQB8Vpdɿl4?{=&Gjmĺ7{1Ӳ]ͻYYOy5o:kZ&rk߲y_In@Zȯ  Uh#킚]aQY
+*|nؼ֭/Brl3Z\rߕk=SD>_;p/ixogfEf\ղA9u :%<g=R}Hyֳ#*Gځ 頫vj{㷶FU>MKlUR綩5N'o|EerCHǭ 5 mgI
+P :b#e"?>j{B~D F?2AImGpɠHfL@XDХ>/u,-JgD6S DHf놺FUh:~J0ȈC.K!yR1iS2% >P+T]}<$)TZULN+ ;-4ڇmyb@vQy@d!@}H3 CC[9\WV-oya7šcvɻ X]]\mFfGy`rz" 'YKQsPRٸ6c`xCMQ͍m8_6c9ءjr
+}>w/SZ*~nSl?{ńTY[}վ)޵ {yZ J:V׈|RMon+Nh'Ou;ebSfjmsEw d+L"7V:ٓ*5-en
+׋Kn W1ݩxdҒuUUiTt8/s*W[9S10r^z܁IErt~QV'1;[^~}"Lӟ^<59W;Q?&_b*SQŸ&qŶ?:u.o~<7çl&ԕF9q1!V^RvXW.H+΋q6ޣ>P|dcxֆZ55(㷇RNg%[o~&%18SPɼqYt9+ʹOG9y(:+3??_i[ܰSp5dgNBf[\ϟEz.Iu?xݽڔ>ZEriKy W}^dnS!ו'+2md)iUutKe܅sX˞4n*pS-_({#T;m4iv箴8WeXb"#ć6vH!d&fRg(hu{fH6,,z.CJLF*7MXc/tџ5dԈ4F^tr!~'BPmI-TȾZl@-xa"ɼ[!
+@߹n{w}'s~oƛX:ߖY\3[NmTh Znah>gf55HikC F]L[0L`*^k7XZ-{>ٌwh3|77I:h?QgҦb\Ӷ=vSuZ[EVTo'w"Thd:3?,Y^׻U塂{-Nov#:N#uz͟t *zNk.ܵG<{`kQc%kfԄ3kO%o+r, X%~l",J۽͞r3jp0y*f5'd1
+E~E{m /ݒMuqCQx?5R>s1b,XbsaόR~xi0jKZcqI[#ѣG䟪vnźW ~43wKp-1gE?M9*HG8`/ KyB/~N\@į 9b7dKB%xW
+_NAhqNrogcB3WLmTۺ!6F>UcXfք# u
+Wʚ^Nڲߤ5f=7IzJ){y}_aGKuc15..]Bd?; +!YQ' ErHLdbiLU@ykq"Uz "ʓ,TR9FyzJR3\? ZC4P ͔hΠAh<ۤhXiC` $/
+fu
+D$2!B, BY
+?Gy16&VZ#$h-#b
+# { X3%L(~rmJs0\
+;q@n,dvٌ<D:WyNkuaG?i3fkOyPḸŗݬmaV؄&i1z>Nڀ3A[Dϧ=Ox۷2Nܚ}R7l!s6[Ѵiէ|Ŷ=6h K'hնז ٌcAA!BY3g(dC-L[eUv}~Dr6Sx+Vxe_ry'AWZ۸G}^: .ghm1rnQIRwE67#IRR)]/*XCGJݵJ"TC+m (d(M*-e D.`IKQyIIY{>!/ WKIHJag}.϶Lڴֽ'>[*"w-Zpi 7]Y琻G )v%7'Nqjp}O&f|ځ/nT_K唰r}C׃>S%վy"ʈ"8gԾs~;zYt_s#<sW/O{5sâKk$d*-prQ9+ 3Kf_8kڵ͛bW-l~Nf<HG>5w9+-MUd2mG|JߞHU*)k郜U\ǚ,UݟEoHP\S"k&YDӈ,L,#\|'R\ @AC̓Z*òH 7',3Dᶉ-(4;RTM0kbiC|:&>7jĔIQ܄V,@hM
+B 9w Ju֏B`gUۋ~p#nKzW@jw|è1iAl@IcPM{%VØ]=EF1^P j, ifk^i_
+]oK68hRVPQSLr?{g* t#a 9"+R Y9q|Wń8Q°V=]UO[~XK姬̏qu ֌ x|am>ٍuvV DUB훞!~{kdU 's<,i)&Evߧ' ԈL|8c1]eW߼io}XyTʤje.w\ʫzUoWG_8 :w•v9ibGh?4ecZjoˮfi[\j?Cy~"'$z\ r?vֵ?\ y{}i:#͜\ )Q*:WϥŸyoNu{ͦ8)Gnr u3?xhY3xQe 3XW=(053'ҡɉG]8ԒEd\_jk4$n3'RH}!!'ps2lm^TYm||M+ޗBK>dH,,vo)Ѳ|#a0Jd%߫WV2\"%}Jfy;?=\Z]& }wV,֊l9'o,ەe?bRԽwA
+Xa"C !|0pGE#PMD],-Jm$'{JxqگD̃i 9N-")irb@up2P^HaK ;j.u\|)hՉ%qCN͔fk&7C
+(v2
+HBIdf .DH thDB"ꃺPD7BʊYefkG78jN!%?sn<b0gx=:=Hd.Ƚ~C GHf^^NJ!gDdge@߭ BKEhtx=,>B"m!>&r{FnQ! -./(7 })z^Im
+% ;׀ Do&-"P.B/h#%R
+M({ןֆ&>M)+!=p.|DEp>O@C 2]t=6Re8uPu M~AP=꺠JBtC1QUBκ1u+yAL=V%%´R1Y2#,.\IeѺ1q"%.+'`MGj%_-`6wɩ uOgvMVԛgnW 3nC5
+ˆLujG(w?hמ?R<ز2<vDN'wP 7Oy9>Ug z$5U5(* ̗ieϬ'TT83ah/KPaX8̖fK}`7d7kHI&=YU^=P5X8{%cu {A\o"}Tl_kC qYQsm3=L{Z,,3p0 秹fGF`Hϕ'|ý;.I-eɷ7ͬt4N}ly}_~ -_ݗ y`ϦW;֤yas?X{}3:$9
+?_W-$5(ef!Y&̖箇zFGi s>t3n뵨?]o],+;cƓ##RLzdm8oρvFǤ\;ÉrvŜN>qt8=sneƽn_5KUl13{wOTnH3wCny8+]欚|3Ț03Z%ra")sR
+~[,,peL=
+n;eߞ쐑w0߿lƓ%ؼPʚI,XpY\S\#-.~أp=˫-abNo(SAf /R*K)4߭׫1oHNeR^xADc7*٦ʎ 7`RTiy21ۃM~0@T^\!Li
+mgU4I FK^DHF2 <Z,aNXHPr>~KZT܈򬌈@U0+,C+Rpl&2Q
+ũ*QZJ* m*
+ 1 Ts%1=%/Oee *TʐQQgI m㘰?ڳCɻ*MxuIFM|DŽSݯ;Hx|[GUpkm)s4UQ_1:^D=En'vi660(nbZhݗ{<|ޛ^9~6XHaN}w8noSh_٩se=:)+z+ *nbS=EicҮ06h
+c}cܮM:j!1}Z59Cޢ֝agٻ*F^1`Uع>JiA,{ftMT}˃NXG,H+x17|ͳݻS?ۘk~>wzAaAk#nqaBDŽKq<FooHKEmؘ37iVkǝ><̹G9}B#8ypoE^eH9@5>ǽRLs+L23 mqQ;׏\yyrgs٠sӴVLM6)QaIkf?qr,)n7s" RiOS}q#eVdCăZ62|+Ynޙi#e"nQ݄sVfMަ cYsl9:ݹFK'XwdoWi+gWuwwd[ekĭ+4fR<KMVN{"Ivb<5x =QxBΤdTp`G`#yG}#{E|0Qx#64js)mܨiB]7IB?D'%: m@J3V:
+' H4#cC4ՉQB Q_R,Jx!<f ?PEHRV=Bl9 f"ag)\ ?=e-5JoYƿv}90/R ([erMB3y0fwQD̜=)R5@!X'UYb# DDL)C3ȑzQGdj=dDvhMnDی 6ujGU}#\GK
+Ul3B` Y싹Gk9"DUiq<DO0_)CvI%uDW0#BV@3( fVJ]`?S'O^i҂6iTc`86T >T0.@FtJա&H ǪmM;cEYż"dm)%
+m19R櫆ZyxVIljM1!s͚>s>sͲ!ffPqxQK_K8M]AǢZC~fV+^+mVA _ŀtLCEx!x7*ORoQ3=lͅSޗlIڱwM2&Z(1땛6w "mi[=I󸪁Ic,,9j6efC[~=#FA\64hy:rC#wjS_OS8d=TJggN[1yogĔ N,. t87bI}PoQ˱ݳqt_k;vnd%7[Z n O~
+U'.IN E
+WfƩ<ף>y08N=Ǐx?>| އjLVr8%z z lzt * Rz?н\9y32 βMg껷fOkvm>ᙔT
+xDw3uߛZh6Q1StQDwkƊ:
+r|zyznOJ¯ke:jŷyFҍ~kEtNt  "Q鉪ʡ['enkr%% FMbXRhhϲ{t )/-- =&eI}f-*98A@XZ>39| !$[3kײN7.W͔. 0X3U
+Azp4[R9j%LhlD8+ZʔKjGe JWԎAyiW~%EV :ڦ6
+2o
+R~*k|/ܹ]_)-~;,=.!=1oE '?.x"'૱zj#K:9me$G'
+'*IL4rfxDѼOF}2M*?ؕ:۬yGl8hpW+/VA@B*V /oEdϦUGo
+u8t.k NF9AAS])=Û<wʪS7o&p+L,+uCI~A.=qy<Vڽ?d#B E/};<zs;l‰MޫN_d{8[<޺5vs2\+-x
+LwGgs=|Ӳݝ:$Wۯ?vz5,S |j/nu5L,uO.ṱ5*.][`Pj,r.jpLۻ}gw~gkveMis\]ł]YFe:ve<3lQP+a {TKTsw~Z>x Zgl3䛻q\ ־Cso(f'F<a0d'Q=x(Ptbd'lz )3rу(@R|hQ=H $Bu"_#A mT&#P"R<@
+#rBs1UށV
+=U ?*T+V @F|cz!!Zʗ
+uD^
+u1932&Ug&EHncD'RE`E"eQ
+CA&
+c[َU
+t
+&f#ZHV๱f, q_}_XqXBuN*^Pp}x>2 j&/A𞐌kA^RXWڲ3dF;TG8ܦ,A޼MV9k4o0\twTI
+ JTEqPǺAa *i%%PuZ{5]]UU߯ڗJ[/U G(}%EE* *HtIwȉtMIUY>yҟ3"c_cbKTM^uֳ {Rl
+goN\:p4<#>(`f~QE
+]Y-c:Rh}JM_ԄZfE{ĤڦE'%&(2C#+ԧ?k
+Th@b2Ҳ#ҴQxP2Z_ ~nvI㨾x!A,kI5L݈OHPm0[apeoV-΃Z*׉
+<hZh%\3 @ϑHa:zȔG.GjR'*BsP1P..,B(?8!П,Н3%AttQo4*۝T[EqnĵO,>ҋK/*׀ J;5wқWJ)UE
+s@kJb̩ps Kxpm\3YeXf͓P#RrTk@J=O8Xpx|wz4}7 Ko²:/ٜ4H(#QԎF"s@%4(y J̿!YwW=̵Yx~H VYE Ydi25"PrFЗQ;PV$:0U&zVwT@d|@vmG  ZUYź_}j/Z,6uÌ4>
+ag߭|H08W?kK-U\_US:% E1UՅ]i*=^xtB33ɕ?ghTN o9}{@#Mbky"j<OM ԗՎj4NZjVp;sV'ߏE={SAx}B^NX^[FA'6{}Vqj nW;J8o{-p&4 w=wP;NTm=i駂.aX0zRoCɯ[1ٔbFySKj߽wazZ[>7X.v~_vؙ:Q];J+QkZp
+_OI>Q<˛ðruxa2  f;rUkd+"+L=IO]9Dsl,Rcmm0gklmFw]L3CVIdu.]
+9~oFigwK2;?U`oݦj+Yg|=͛ڜ MA lxamS7mY'Y`lCl8( k$R䤃'!Nhs I,TIxhy
+tUeDmy( }"P@x
+3*@\E|
+!25LH6MF6mz `K] e:-2u>Fm XƊ䀃T)
+,<RzXILm]a
+œZ G)g_='JsX(:⾑Thٞ7csDf6B.ƥұXcHJ)[<N\#RXH0~OUd]>Xd)@GW\>KcKt"z__)zηrXˁP]Y>lN2baBQyq>k~{=
+[V]\;};'d}PuRx>ȄKlߗ:bݙߴW39+\륒%g/g-yUv +cr. μXX(ZWaәK{];lp&*&4&[sXeo4m'2N'.ȶ<$)̫enWyzW{--.X|.aoY3ryN[O
+9\XusRڿ@  qۊo+YJ#%^Zk ΗzD]2g҂_`_ЇZ8dҁ}`Ee-KR%G|>C1*p{HZH5BvjAhxXp1䬢D^‡O>nʨ
+|cR!955Hi-URTQ_ A
+pױi1Rn/<t/|9QmB<)0Pғ)mKAylOZ>:j6*m%-.}>$ǁF-J a[svq
+^ aqCF%
+9goeTIE#Շ' 8aAą+ba>Emc<@#e ^eP4E#)O9J tWMsVz ZsV*7>!Q=B ;e82A~ʹ o$bnAFAd 7 FWOD;]kOF'\^[*:'SfX{28F*$%&%k&؈:o-*&
+lJ r'6ɇAӆA#mqWL~ W(i
+ *t$2ň$eBJɎAJ]~M9 ᮝNڐ}䭚Ka"HAɋRuHi1r
+q ̹ڎ)~{WuPjseT_o_#4+bsN]xp\18,9:od%_i,[.B/Nk>Uy5ѾqyfW1Df>,},>%wW`b^lmη=MEait
+-]W8<74RQ'#52?%C3C/4NHRkߦ1
+>AaZ&<VfaU 6KDu[@<2Ds ~ib.,D%#5*F#$!t O+ 8WtX[)A7vV PcN4Rd~q-:"Z}~>[丱ʠ59wf?7+m5*wؒZl5%!f&ه]#'}N M :kvLuOJqKrJL:s7:9)!69Fք_.\q94K]
+9ub3,*Ǿp#?ד8=R="9"H_ȶu)bxr>[ު"ҿ +υ--=N)t[[p43V%W/yq0+9Q>Gtu{؇[]cvcl^zsCޮz+x)Zxˈh1:$',
+d
+)Z4Ն5GEB=<E!<\RVCYHY4EQ#qR"$
+e9|Kb8PP#Hv-bD W` Xhׄ{ǸI>!5+N|.D\N!!Bq B| !ӈ놶X hMz}*5?˘JVͶPzVi|>װKR^Pu
++NvdF['[֩-pk-cᶱW㭙!ZoS|$KfSje#1G=nABiuUmu'F5҈n#{wzQ'3~)]?'"IQ#3E /&q2EG^YN$dg^bfCS3%;&ēt҆Ѕ>*zH` W|\Ξ~+r_=wHchϙ7.z\% $'=Aqwz8DOXS\]]a|B|/EL;Djh$[TݽhqQ$]9+I݊-?o@9̈́TmTDwJp(LUVq-2V}Z'C+E3曤B>wA?E[\o`l؝n/2,=_##Vm:FPzr¾Y|R9=yp'lV6oA&ĚshÆt A2NJmdӻI$ܡ AⴑK_U|VR!C&!kAك愜>Нl 3cPo*!ӞAcBaTA?<܃/cB[ }à1
+| HkVm2M]k2LڳL̔ql+[L˸㉘Nmf3LM$3 80Ϟ**NﵕH/8hhUQ+
+YbyqaH
+e|tĪ ./}UKHN(VW~/҅{X*OIlX+
+BCR´Ǣt"-ֱ:0&R6-ybj+C:6GO"d0jWJc/Fr[;vLgY<)@)=$a$C:Jl+`ڰWz 3&\ 3 "o*j!v2Z, T.Xp٧<~[$;}R!9?X/Q·~"[ے[NaGi}I1%yi3O8h0n3Ƽ(;cT\lbAL{Ar4𷙍?4ew
+)}Qu,Is O ϩq6,,''E,9Fm߹ggpS\ctM4Z6N HExԾ6s(:xߙ:\HR޳`+Ӛr,mYȶԷFD MJqMMZ|ZFu͈ư}^n:iͮc__9pqko lN
+
+,T2!<LF.wzCZ*E+DX>.=L'_^D[ zwJD4A
+dPoSs)y#W9e37 4o䮲p|<S=96IN띠~ỎieZ$6iuҚ~THNUY838#B[!;ڪؖo}[Zu$3L?1PS`hl.61cT|r=Ɍ-u&[D}4yqKPAUh$(3DW|_ם\ƛ(꼲&m2G b>j2:uФ^M+ s%u$ )YKb9ƁRwv͹ǁ{z~;O(\EQc|bQQFNT %Qm{֘rk~4oE:/Èz "`zzG;,ܵ.
+=~a'O}nzX10{X;^O9F^y*`bkļw8vW NL5rp ;ǰgዿtt2!(NHX/l7 d]y--ЈhQ~!,~>i`H,^XU{_> jl[r긾˾*ݱ,*o/*
+s);i-DL
+{1/1YШHc%f ۩k&oa/:$HDQ9<H
+Dy;7x҃ Wvi`Nl+҇4~p bhY#jϺՓ:Ay i={TR7Hb{n.=A&
+@~[ٽm׽
+B鐵Rq?D^篗/Yӊ@D
+|ӘV3@,  C,hMc2CI/sP&p؟F;3سY"ѬQ
+%̋Kl
+n̓Oއ}r$%riuFzB#cp>`Ao˨WC\(_@Pc4hu?;ui=)i51%^AsDoK8?5*(9z- K7Yf[Rjb.E<þd]? w<gi*'ʼnAX ׻h=i?iq!g{~(n7m:3RVxfeaLG󵻚SSjMgl*M6s Mބ}:+'2tQH ;=OAC#Z1iNX\ <<Q{HB g$iRAd@Cix,%#mH$wA*Cr T"bTsoC!/R%AY]2_)k!%兔KR>7R#~ԺH$Up=@o䱑C}"64N|<B"!A> 2BU WgtO mSQTe463{r&4 &YZ[/_VBxFJcp1o}fRgŸ-yrQuN1+9k݅hrU
+EtE[f4sKlǙ2C :]Pm{
+uUhIٖ& τ񰑥p`+,68%ߚRKoua\tXkwud ;X|ׇu$]~a pٔkցЗ
+qse& *MO\?tn[O_FDݞsAGY,ynX/`杦̤8@_$wIx_R$w]P} С뺄8b\'kN[R*٬̉C~>W}Nņz?,ϩs珹99^Ȍwa]qz#RLs&
+
+vvy7:JNnPې[jQ`y6gӣ"<bOeP٩:鬗Pp,oWAe=-Xò&Ridٴt1;"[Yf!%׈愲!Z砚)*,nT?PND~kȇh> 'z *
+<&jǴWjyBmzDW@7TƁW|}E!Vv)?
+fKXc!ZCEǣ%u&f-J<+R2L\SO[Zu_uɺ)5lg?W53kdK-3I烴td!G6ne+j{U L靳" )~SuG R+)ŷo>,)rQ#-+?m[TNŰnn9)Uw<wmP?Z>-o%[V~51SH3)<7Z-Uʏ?%1:T
+]Y%y@ ?P|£Pѝ9oBF)}'*#DVc; Ot־Ee`hEۄ"yG|zAܼ0/]gr󀖃6  :gy]DEPG N %*D-2h^}h7=D`qj*1t^|-P`T[0qD=p RDW?[KQ CPT m
+Ɓ@A@2o78KM?Utfcg❓1y&eeS|Ie:v#dpK.1 yu/_zb{܍kE;,6]y {NΒuSlSB"nw!x ;Eo+Ȇ"0:3<|Ԓ*S<r"7Y/r L*~]|>S^rš~iuJ‚)#),>pl =*B >x/?`c2S@UAB%+AJVJN'43G4
+7 Z#2
+ .!7M jK\K:j"I
+ρP průcuEb]U4Fa c[g=Է;|fe2kz[@TM@ZG( P>pa6rXrkxLJ9쫗o㧗g"|p3Y $9zjeLF'kuᨩFǤ]8aLʙbJ/s|ye~n6٦yդv V@VP ENSR-mu__kGL 6 H 08_Dʭפ;>z0s\EW/.,hUyވWV9ʲ<TG>e16kƳ>3=,-Eit~=͹8ul;N̍' anl^JaVSp7Cn>N~;-"[{:R(O"
+{F<`OT9tΖQ놝 )j:I9mڎTʓג9_ze1h~ #=z)ƀ!S*u LZ ^d9ۦnf_q8>G]~ ۻb
+7mf| _<P!qvAno%z~*~WvEDTtdǪMYћG,i-pՏ.Ս:ЪFAY 6P)ωQ1Ī A;A[xKć]_ĬB2֬!˅-ѻQ= x<l@0B} ,Рv%Zh dEd`%3_JFj/7{lU)]?}_i㖉SyVR̕y5=W(~pV8=ydO1+~;VStO߮ݵoj'J`69V+wӐEF#3T8YT6_cg["ѧa
+hWe-Pv{N
+vi)rʍERm#5͊26i?knknf` *+<m;ei?r(C(hU unp-ݹ9b] 䮴+G-vh#y3F\̫:+zx39kZ3Ve{<XY}<<^yԉ+HHJT G@dDuL ;aZ=mNp+? QD,4ENӸ.4!B#h(P$=xq*d~ S!*~RlMnOqڈ?1$&T/{b i) Q))E9,? uB!({eB2UU
+BsE,C!:b`sXP"Pc@*T|bqe)􇤆ڈB{,GBZ[ųHj~X?"DDEmF#.Dp*Ĉ[wb Bl7;IYgy&M<FDEef,һ8v1G[c.igK59Sd}DLCQo}i:ct}I/!nu
+]YubR^[DyDTad4fdξa=F'9¥9>=*NѵٝD\Y (X{x}M[s" 9v%"^h[7|X*1o=h&bK@!m:ICQiiwϨ
+]Wο'O֪'b?ٶE;dH_uMrH9R:7X١ 6b6w6a>@D'lN꧵
+ ܃iiԴ>ͧ.:]g
+4S2!4TGq)761} &.B Q.?oxQ .qG -J(j-D  چq@_ ꟆTB P+!!i&0߃.ʯQz=屓[zwZk_' d˿[mK{WۗKhP,|ZLШ\n5T,]*(8FfтVsQ\bj-ZbA0'5-3>#0'we+ Nɘ S0,Wթ5.}'iBڨnxxYo3VE^ہX(U+o5T]:KmIg4—_l1 a'vr'EiItdJd%*dW9ʌo]ٚu~fVdlY>U:c\2VQkD/NU|XT㍎:Kʲ6`Op'ϕoxzn؆
+/p& Bb/(kW8W_{${:>qN 9p-vuxVVfrHHHZ 6Px6?P 0 ҮK)2y}T*)+ u'SO$Fa>t/̃9<߈P4y!_bF2SC.H"A'@ULxs*>>E!Z)^o&?|h>
+s<a+ 㽎=xaខNA.D?msT ;lYwA=|LHJA>IoX:QF,og^B5i"A&"r~ko]w75*ȡWO\xŐS7qGB[1E_pKԌ)c77e7 )y[Lm*i5e,sy9#hc}s?Oq"GX**Ym8z!vwy]aHI\;&!!;|pqKmف@zH{
+cftv0^pwҟw93PNGF6Wk=^AAZA7R )<\X@ <zNzAZJNm/_<{
+ GpZ~wXf|緻k緥@mR C^:o[9kW=˲vԶ2Dw|Y706O58!@ehIg6Th[$3DLH5ΤyL^5ۤ_@s ":Cg#1:CTBns@~Y/by1h׼zϲj2$H0Ъ|"ȦDlU<bb
+6yP!zC%ur|$-`"96:MT:BQ":'ԝ[{ >K|+./'oե+?Fpۣ8ߒs'zv&x%O 2DQ}rȩ_%:C>4A{{)ZQ=E.=/GO:>uI09L}Ѥ+(d"1eaG2Aϸ?e%E:fOGHf,!k R¢)H!| OK!g{V1@{9mX݋Q(T
+aP%"j Dʀ
+mAʀ&w۔)ƽkwZMxZ7@|j"=IeܯuDT戨cڣ<k$J\עk
+U#Ȑa)iP{-}!}h!S"f2Nmi0mY߼r< H!`@L-#+Bœbg3[a{{'KDJ!Yy,>iZdN]1ʪSζxsy,SqbWM ͽ,Iŝ_-t&X`Z4A~a:æ9qX)m<٭["svw
+wHۼ8^4P;gh$j)f˚eAŶQ!7 m赮x閭
+g3 9=PfrO%8skEՄB_
+W!uju}5D׆>ZR
+#RrerlcLK/$at0zsg9j ƯGiCшJr?>V. #L3FcR11Ԏ8 İD__6 ߙ+68.]_dfdvc^bQ{uA1uI`v1Pᄶ5 Oڄm(u^X[vp"ܬH
+1A;x 2suG5u
+Tm
+E- $Awr9w߻K޽߅j "cCa 1㘫Z};n`#{Jp3lz6-Z\C5T}Q!Je҇*(rFT+ԙEfpS*+@86=̆n`5T膎| #
+D?%՞EXAFyf#YYu4(\]!C0,< A`@W_V=zrx\ǧ
+by([٩{ocJrԁ?%pܱ\M]᝗ɧ ?xWRvϼw*-)tO97||Bjo
+/͜TOxwcSO-͝|wwKd#]^|Ϗ[
+T? Q+_kvvm.]O9[]t
+AC
+fq#W%i})?-8˅87/k:d
+\iBoen!x>Vet
+<JU1X~TS9T-H[$6+<3؞7@)Fv@&@6( &pA@h MnoX#Zڭc"SQVrx԰YY#) m=F:f$jq҂\݈ WkTvӣVSD}wsQ#jpSú|,6ǷM-$F8FZD'VqyzR'Z08}::QjT8jJcdt"bi3dfPnTMѮTԈ=n"E]pMq:I򮢩 4V\I %&/zGU}˽I޾s_=so&ئ|OXtb}R^)n DZHaV-t)t^Yꑓb7g>:,%2.+nEbNLT^89KĠvJ2Q rPn9P"(G י/7\)r0U?>>8mC.%˫ybo>ĄHuG5qf
+P0 GBB
+?E^?\b/^vi '_3t9:te<8#>?mV!MUӪ`:Jghj$RuM.D STtB :f2)TEr%ժՃ,ycD\ӻHR)%mA/{"Ez)רўӘBnK9, }L3<-47S-@Ak=db Wɷ^\qomB{Jp~߭pB6G[ 0I̧Xo:<v2_y`nj6";F)hj|$tox5>2ja(br=h(qe ?xkI_fĭ 42oTޞN]$On,fɊWm^;ZY8vd2s<EeRY6`גCn5[s9ǽw3?J|UZR~%j[\iQcSr[Z['%۝TyxթµmȽfVibsB?4~OlS@ʀ'=
+i i=b7Fl)XR^`~\SACRDL н7cD胵}Sq܏2ݔQ?ǡMPZ״PE(+ǵLw
+ijHbDԇ :΍19"N;-kCxx;HI08m$E4s/! ?%\:pjwBE^BYB,m QUNIIn *AϘ5`cgc
+N,Օ84 B !j2}W؛&w޻!{0HK*jtvcbv[|A6ŝ3pݢ)47nvNGL ]䬱yR#_XfU;5Ɲl#2f4)74ɋkOP9Cbb}V*Qt/<OVV_}TC`ߺz,
+2: 'l;}iر%K3nCndip]~t rZx]HR HuHH9UHf ofD J&yH®*EݻدU'>ݓy&ksZy5OziI_93>?wb}뒳ʺMٍ;/3W\phşvqaB-3sȘVH[Jki­Uknx]j,|@69yV $;@rHJN"ѿ+}ϴYg=c2nrn[b
+hqJTV9,/Z3YN
+ep_. omjՌe{غwo%_ɜo̾EAڒGROG3iب*Y\K[|jYBnG<'jWʌK[8:vnn
+Iն]ϲ$M!Д񩡎HGywUQqR%{%4UI]9-AQJmh`儵5i{֝\~$ 9@
+ zAJC~N$rX
+ƸGp/$t 2{+v?|!ee ']ŏ k~x&"_w_xO׼)|Gs9_l/? ·#~|PfWq`uD]cj6Q5i8M@X]"*bgA0%H&~bXBQ%E:!Dt9yv`&ɈYQ`HF}f7cFN[/Q|awพN tUMR6GCJ6>U )*{{mM
+
+t7hR;R?cB-jo]@2g&Ccu]
+voK-$/;ÿ?u!9>١sM=g6K,/$R$P|9K>?)/e8W kqAٹ  ~ć#= U"t=+J'^L@;#nʳbeV:y:믹):{_?>?s??cޥ*s7.X{jVvյoOjcIުŗpM[|7Vo09S^<R4UӖCh=G+\]ETRX kؕ4nE? DPԟ+9P`Uzd
+rs-6/o1|Bbut&41i1KP*a
+C+*0&)Sa)G>1"P
+4 \bx~K='T e'*%Xֱ8?%AC@`00C)c2
+)Þ\f}hȗ
+Vb}>߱ &ib#'gTTUc
+ۻ)'cbF;fG(Z'oD=^NjnN>3*iQ~FviMhggqjpj.IwϜy4گֲ0pjW^r0|CN\`D[E_=;7̉r*N|8̿ ?&:#6[bӫ-q cz8*ИGC_ mu8{9Oݺs克՞՞,RRV4Txk߱ʂJP%_IKN)%DmSqZzy5`1%W  ^sxc -0vdZ?9Q6 Qx?oRksRؾK0pwn&\AJFe+{ qD6c.)74szkڛ{>#}\kE|EqHe(յߵ~Չ
+(JWY|싸,=P Pb('><"w]BV8c[ȑ5HU O#0{|gk fRdR.DA&"ȉ~8f`
+p8I|G }p3 R9{$I1-*Lw|Z̔Zz(Rډls~ ]Td{|yTSWpYL$lIH a_
+*um/߈m|v?*I-"Ҕ ߙީ]U%rqeÑNCJe<^
+!F0D;oVhu!NC f rj`x}ۨ@@F2
+kzQ
+uބI/h4GBq8x4!A'昶2 Dwr= 70CݨcUuuAL0&  е"k$hZXֻRj8R7
+#+%.1
+5Q3M!dm-q⡛[.5x?C!p DJyjlJPθI-}Df2@kq oE+[dPRmJRe-ZSV4xKY²Ƃda26Z2ne9<nnaQn޷Ԧ洩}ެ -ù5"8:X 0jnKmG -37ۻXK$%\6U)oUʻ)(\끝_}1NO <I֙O< ;ޏڧbzם,z.+Qu~Ƥ "cKs#QPT-?=<WwCCmdCHՕzv<37%d~ L ,rOTSæҔyY = %I_v[ BC/wA
+9S\~Nb mXOHXX? X.%łx TH c(vur]Qsj`cr7zAHa ;g륍7j+
+9#au#pZhdSVj
+.U>؇c)UT1H-Mo88<b O[oۦkkDz5b2ƀzT 'r}ԇ,$y$8حb-hN8Z4 r Di ~tµD$gqj43 D~t  *ж[  kACn~_j@8pQ!rz6TS\~˥x0֥h0ֹHC544
+*<QD5iMԨtۤ9nͶMmfdwO֨1Gc1I߉@(
+
+ (9gj?sg|1p=
+j [ s9ashȨ. \Ifuڜ9>LmBfjJC̯ uNE1zʕ1-x!O(ӅtjŚ{IQ[YrJL1f} 999PN]ӑ) @$Ót'G2{F&^S[da9Y~7ڰ9{ʄ7f>fH_UNj|ö%y%.#W2c]W-o턘sZ˟ <t2Ve 3h!cmԔZMg/?vc]^sa3DR5]:;c7NC6zIgc]lB^ F-mz\|3)',O'Ibu>lh ou&*ukphnI(]+GWGAzBԅ$!RZ.'6s^вB*EaX%k g _Lˆh ֖jwr^Q5x kDׇ5 !-S+Z@j|;b/䇜 Х9#/DFW- BUrE
+oC}b_R7 GLP_р{ioN=[tAQD=<B"6у+݅N -DcĶA"}-1H z% Vҷ=XOuȋgWG9HHx[ς':țy^Po$<N[А&V=)P7F11x7'[/'yI)~H:R־;O䰕fÍ飢\¢|NLPB0&?nѷv9u8Fu-}7?jxmʞ'v;r/~/gZsX^;5ʢG>.w'Yۿ;gsɜҋOwCU%aՀs@>Hs\3nP׃ AV`AhjtX|ry>b0s]V]b|~<p W{O Œ8~޷_NMwꕯՕyškEG*Jr_ *sOU~;nyҎڇӢ}6L#& ۭ.`׌oId[׎ղv ]7{
+Q4h Əـ
+ ng,l ~'|Νj$4IB$h*CdИ8LЮQAXMo(`Z4T´]OŽ73n65B6&9|Ԗ
+3j5>25Yс'L<m=&}tmR(rUVL~
+i@ maĎ-nu{?cq׻1V?ҩ2[nFg޿}[?4w݅&ncY+N͔q9#
+?]NLtn5j
+?<?>+R`L ajrܮ?;iuqfRbh ~bڤw鹓c_f~,z*cd~&Pݎ)2zl|%qq}M{\r~%|(}YdADb)8
+kǒ*Jrop+}ԈH:oV󨦮4
+6H= 2G@Xi'ZCH;WCF{1vb;y6n#^5P|+vthP(5P..e,jfH$Aݒ vb:BV5G$iFՍe[kT+kڊ򂲯ݔ!O/xY%jM8<do~uhs|1 CJ~֞C[wjS;6oiѥ?}קNo
+Q2t!?A0<A;11mA볁r
++2pMaFTǨpg Jhsuni+EZ+
+yBՅK7]/e˹:̄x~[$NT!m-J(3h /׬V=vEާn:B"iorSxT.6vM[懩])F&J(n1LAi[ŴQ{HH԰֔`%akh8eгω3M^I@ $TG<:6<ꨙF0h
+ H8B !$
+]¼D"OF `?H>_k 7Û[ .B;E&Rgt~ղw$pvʣnQ+u|֜<"LɧzRfbePMXWmgT5Qf:Ͱ3^N6-48Q;E]ی'-tStXʑI(VgI#XmUv;}Hx=ܩVą)FMau$Cjga&MfVp[XBMѹOBk#̇,WML9wxx:#iY;$!{V[[5nxxx?t$Tw?w뙰sW)^*0omͱZTl['A|@Vpg+{khkjoƍ=rM/s/N]UNH[ σA$4
+b09Jf <GhnvѰo#Q^5If;5E y̙rŜajĚ=OSk&ܤQ1ճehPKbk5<JsϦ5]xYcobJs?;9uUIۿ|Fe|#ٻSߏ;}¾ӓ\lߧd6YG>}SNfQ'Sq<
+S
+ :R/8LP 3I<P3ėJ볋] K``FwpdGy(,oJw8=Rlc)EwҼs:T5<~ˍP)±܌wo&=x03}CF?.8{LwN<qohQGr/mHv{O0_Tq%BKf[GNy/s,z=^Td7UGPWĞ(i7C~1bJJA<)oFMcPBVQjTQ{Ƌ ҡ*#~QTVڷi0 6%6<(!0&"D@I~ @L>I:7Bg׫G^&8c+`'m0J$ȰҳWD\DĮqt<Ak@k/ޡ~Z3*6;>UB"a?mcJHTgA 8W@\
+JG?<k|9X88e6f+^\|%`?Vm5jn*ȼQ5Mp+$%vg5Ifn
+9xyyP+NNk&Mf I呆!SSzCxtXK&|a!et_m_= X x \n3GTNLxIvLPG ' '5%
+U*AJ#RF $! zޓ:h)6AA)3Yф~EYϝLEYaq">gdqNGo
+҇A47-Ӂ lE*|a[ѓʯm%M+04fqKCaAYefޭʢ{'3/,hvQ)lɲnh{#Jk5Zԥ^kS]Uz(QKW%dww%~x^Au$rTysxW.L৸r?XL3r> #d6_ ٵfqa*Mb#.V L3h#\FF\8Џ4 9X?b<2LK@=__| z %5?&Mg4k\W_*;|?8ǣ@ oVw`޸r<6lO]Dhɠ,d /Y)( =0ߣ$ߓܝf"83XbCI2fi,^i'AC0ć녬^gGnazd1 ;( zE>`yɔ~b9B
+)[APL@/#KTDє<nRBďPW$tq>ff!\XEklț_4%ա*K0,tpz}tj{*nM}aF*{ow᫂̚sRTKt`λ%+7.شUTN~''󟍧6/ݛ~ɱ.:KǮ[= ^0ŕȁ@0DŽ'""bD
+$!pF(:L[U>60 (AiïAcKn|>ȭ_beNjU?߼#w.:8v˲K~kY}y--0qƴG;
+nW\ǥw\g:Ӻ[GV~w55ѭwWguזe5֝;WW> \j|FZ}H_b[<}_/+c@a@] 23HbhVbX,U(1 δzKd /9JL@?6$O`=\}:%,UPEtX4*:Lh,;_8U;\(va0 :bD_0d$a^!mHi͐l\n2d2dVqj5lY  W X;ZـL >l.tܪQPHiEX1z4׬[4cxטުٟ*Yj6{iAMC5޵"<k`$!d7oMcv!:>BwֹNr"ta4UBRĐjV Hf J5"e8daZfqv  pMNѿnO4f{iqVҬ]Ȩn(=0籐&Z&sȴ&7Ǘu'{ij-NR;&vrԗ!(JXeT_EJ,{Tjdz M,$=xۧc'jcw\Y x"` MI=p@3Kvx)͑×[qƬlq@z:utNEEHDoN?yrҙ Ji|l7^xCK ]qہ|s /ZZYVRVO{[]<e;G$5+=f`AOj)4S]T_\WS`<ҷ&OlyPW
+..|~EvP0t$sO5x@qQ_QE3GtnjD$H!xH]6fl5V[rTKMR^W0GS 76`i9##"96mFTW&WP~%eX׆dMXIz)a/ʘ&Kxdb2z\Ft>GUmwMsaX MpLL4EGX%4҇rsca1]"搟K1Y1zL% aNW&rD`@p,!/:ys3c \I v^~7*_Sկ\5t8+-eeYMJϝ[Zx~_3=?_T^VWģC_K8UVg?9N4+x8Gͽ6K^*%-;@qܒ}Gb.\u߰I|$ @T\Xo^hȶ^h-4XATʅ zIcsYfeUfe5vhw;Yj:|7sV6=)yGU}s g7Fv{-[߹|NYME7>=vt~ɹ֕ͯ }bwY{??ӟ8Xّo|7--owW XպQsŸzN.+-:U\}>݈+li6 jì
+C;!$6m;AnFn! U4Q%Io l/4#":](:@0./rkSň:Vl36q[^voƃÓz ftXr{UBAnKL]01 *Epаj. ތL3akdL!և8
+ nK(P1!no\snAeSɋgB`UޔԾ8mVIxnCtȎt,sƇ8gz_o0^_dgMYYtiůwmFq F]$-hnMUH_TyA{)tejki#8gZD!\lEɪ[
+]a6g| =0u
+ָ
+r^JlKe՘upv?a$̍Ă3=Sы_p޼R;7D0^k.牻<ӵ<ghT'xI(iǯvDJ51ᕘ\bH k5svʫ?l1?H۠n1u7O8k/aઘB2ғ*Gѽp
+v/eK83R'\9 &<ݜqgffkl9V=}O `Q5>'j H~%e05Gz|>g&<&pNSN1-"\j,D}3V4KWYXϔ<6M$lØFtTCPN\c,ʊ4UrT+ժK'_EXNF\yTSWp5% ȾEEVKmǵֱtl{:3sW2,,=kHBܛrL?~F{_\3S~feƭK''{dO7=U 74_pF,XOG>r~*Ib&mgJ K`IAwpƹe BY.rT1A52[kC۩/X5HjO4ԡ fVKᖎWˣ#k%:)$JJc//޶)1eK|Leۭzp?G_g֜>Z*/yʿ̘SsSw]Y{̺;^;s/vfv(?Ljcζ,IC5oe)-~
+-d/pMAā|ڂI[jp$jy'ALsPzL^.zbGhՁxd
+m״CJQ#0$Sh :dog]FJ ׌jx ڣX)֊ٷ|A*^9OA3-].\C&ԤƄNzpӀA`(JwP0TDTԠc$|B.&26^!G(/ˍ*6@r*"T;6N5Sd
+]h
+ IgI\꯷!MHUxXo2yq9i\rA/[O;ľlQoPߑwXtZ$6du/ڢ$4YoV6Y̘GZU6ƭoma|()(y.ϾP|Mݵ7|=jr ˺,BVN:9!%% r Z1I~U]?NE2a0W*f Um,k8@ym:B4EiYFvK/+)?ܿa /zX}M-@k܊9~zD'1W]cV>sUGG$m MN늈ҍͽROvˈSD)D[tzCW
+fbuR>I,mJordcqcMjfjp57qFys0+z[=uzZc3FBaPgv*<T5e-ACb-(0cM[Lj 6?&<!̏ Úؠ|&wB(s/0LW0N6ǜ:hr?*?fYgy wMpjZ\5<0XiyAYTx
+Q-~;Dơs(18߱ i uе@k"E`\J LO\WASgw =r1Qۭ6xF`+=/LZqn<iqqiX·-X4-VM&\ygs"Ǭmelm&mUȘ^-M6 :j, eˬXL긖VXWG;i?4fճ1_bYx,7vcݕt'K8\Oã?6z,6`9et&A^pSg0Z3kGmg얧W%#;$5៶/ sC9mB(+M=ɪِ%o *M{q8/.,I N-!l _/jJqf|KRuهx J'ߑmR6R .Q&[2P,Z-$TMBnP* 4( jc)-
+{n}q;W?,sFV>hBF߽/ΧË&8qڱo.n.|wn3W<.h_r?|~erw^HLۛ<=t<rh5AwXZL.n-4]]
+> i=AskP!ԃP!m~vzP&?Н/]jؤ $6kA^]P @ AL *@$]Am\I:8l؎=z|LiN'SO>8MR9qll2 l@ H]@! Ȟ~}޾7z5xPO R;uɐ5Pq%*
+\@x RRDU4%<`>#4b9񙿎P<|7y{nqͳ\aS/3Dd91]Z1C?u\n(CN˲BN2tATbt1a.LSr`GHsL&[v)TʱQh|4O*:ɾr1֬ 6]S'zaeekë8eN=eszŃ2<d|_;QkR& YA֔=Ghq13rXІe(8O5h3o6cך~4SN~c_ c 3(d¡$Z$i)X Z"tkBÖ.f#~W-ud 3wFz
+0[F#9s-)_5_3` Mq\y>[5 5Ҷo >UQ<;+ECH q2O?iZz;қmGY_YOΆF^H]=sskjC@/+ V$BDl H/ 'V{G_Ŋˆ3@s|7Ǝ( /25TMDCx6+bGynjyE4̑^j  Ķ(Q%qMߐ}uzSgyX!g^P "SkS «S;S3FA.e-wu> ॱtj<opl-r'Y"/V3Q%2&"%8fcjlX`Q\v&WQ 0'a!$TurV0I,?ǖI_e,KI)A<~a xqT O
+cI~i/LuaaTb$gQhcmE634z'9~vϟgiIt8IZFLiՖI q
++ iy)m TWHuQ\KBppѕp^DSp]H"@@!3p=˂vd7؝
+ˎMadxfa{=kIS+ '8rH/ #S\$<@v@R c!uh2BgS~M `:dؗ8   :83y>검q% ^ȳ V<@@j@դ^Zs;!BXw}.Ph 0 8PXGKSB
+پoTXټ$HP6ŋ"̓!EBJ|qEdO py
+KuQ+ۊv3$39~^Oe'-hu{<{yYv&OɆe`e&,p*YC
+H(%ϵun^BSSVTR59ŴqcR=~ge㲟KsQqao0-NA߹kǩoVM*v5u
+e(3KeTdLK5{]_<b>p3g.]>? rK7S0eJ7gK2ۙw0wDR"?\P+^~@@!Jt04@DP XIk2뭰PVPc: <z6*kܺz6'& --dʌJΙy ]?T([\TcJFL\șdc>@-p66a`?>Ydz9BC$6/6?Fp I=ڃ'W
+Q!ʮc?!h}u>. 5i<(MF*ݿpyU⴬()o~ITq2/_L?,>Lmki8GX`ω%!mm<S  Ɋ93E'I48޺eJ
+8KH8[BSHB0q55 HKȖ%)d9A&h|(y"LS  ,I^!alE­YyTk ЖB~zfVFIYA?p?2 sTsG-.>׸{޸ǁk?Ij=\Z/6W4vp%S|r:U2DCۥ,^ݡ?>^y÷??wb゙ͩ#KqYoMxk5U]FkPu0hC#}@$@'78Nrnvnsy
+9tZ':Y[u޹\^=Z
+DUwكbiO'o^P<Rr{@@@Q@Nяݒ2~WbwKgo]]ܵY֦8i?u?!By+W}7_~^{_k|x?дo'Oc[3D% pnP1%\ p~
+}7OIZDR'ZIgaP6^Wr,V&mxIMzb-M_%quf}kL#[S +$N&ɫ>2 ~#sZ|!{@<y;ۧ1&B}&K 33 K~rT` |gɽg˗zh^ޚj-3'EI'2iC~'[D<^Һ ̛(T3quJ[q8Nh!.Ω]WQ\qƮ>Vk laʮm->qOG寸z&eIbWT3. Nk:$Z؟%*':e5t xYn.{˫2aaUNU_^|QB;pLD@g .$ ZP3 rњ+^O4ӯ/ܿT7ncNNusf͇ mv~#qţ?$n`ej iqTL5YP*,SRT]1 m4!*FAʌj 4(?TWT`Fh]xH?jׂ]A UU7F=CbV'7n(<
+vLrP[QAbՎɬ+?-*E cT|P8&1Z;g4}(}GΑ.Q7ƱsxjB@gCZ9apD8hC4*$[}Jʧ$R.h"/h835@WG9Ivi\JxEKMR ]?Tv
+ĩ{g?QۆGw$ز5?}0_=Q朸Ymsٌ%!i@d˜֗jS:Tմե ~\U A-; hli.#DCUS'Q5qypK  cڑESLt UVTa *:(92t3 <r>gb Zƛz.NPx~tZe~
+͕ &-g.J%<8y@+3u7ʯ.Vv=9:қ~^ѩ/ER?Ͼzx>j:}ץq\q__ .?7}w>rP@9Q
+gM咠\u.Q^Q7g|$ 8z4-7Ѵ ޙƘsF70 / ć&/9%N|ɓLY3(zh ?-!T\L4WX+Gz\q#w` X!G"Zf1Uv?F8abLEC(@sss $(H#P: HW{WnW;M.<dgiGIE}TǸR+*~JcF>^t-QOw|U7J$K}{RU3YEN2c>6a+әJON$sˢA|>e#ڼ<ʚ=gv0ŴeUgIՖb,FZXlTbԑa"d3խg
+fK8-"Ȟb*[OYi@SM#"@l-mIFAL?ZflcjN DWx5#B0
+XK۾JP[\NNRR*JYϘZgz}hk/iXЩiSO
+^1q0v?ryWAܫя-1FYP8?};D3Y>8}PI~㱃ު{ E1ȮMxrL
+ZW0߇MU<GF&b+Jew?Խ2fT#G⃲w&Z%}_x~Zّ~ɯ6ģ[ɃHs5iMs8@ F=(
+VԬuV˱!It'| чt&ɸYv/\tЇE|\I êX;77g`>wN7>1
+c6DG̅9ptQ{NT%*%|^XP&a~Im!k#$:$Vy#gG"JDk\‚1d5/ >dz%Kq9ҙ/:3 FJ[(gM ?3|J~T&'宫ڴ=NFJcL=ir$6y~YR9[7 #\ (b#b../`Ey{&Kn%!+UI_HdB^5AMԬy
+hY.%]9Iٔs"<Ş=()o~ӳgʗmN YNg|;Ir!RٺYz{3ǰ
+m 5}lRrďzUOٳX>bqBu*T&*.7s_T%cc[{pDdgmbuؐ:C")qQR@}PA_N2Pu~Qu/.Tg Wn TeqlТxvg!A\ })NAJ6׸:>&l?ږ"3f"ANP b2H4HR%_Hshݷ?S[[N^I'zTVduJѼ2ªޅjQ;wkU'ቷozAvkY]Nw
+Awȥ$|> ~?I>o4 lip
+,iP&R57SE Pe=G=P
+ p^[lȼU0G\w1B}ܵgkl%UCRJ'lVd5lsUr)]f& Z
+3ئ<pw
+7Vc&%0 -V 54|yBb
+'Gű2qwQI] Z]fC}IGe0cA" YDzxV3A=V uS <a4{A71gۺg'Z5k={ܻ>Qy2x9x(U&Jf.T%_53Ng
+uU,l֯ i9x__5Mޮ;4ymkH{py7I? A
+z$X8uJnސWv+"1T7%>Q?]tNX݀63`/t
+FS+<~neoK32^8 _B~s412y5}Y^.F+x
+ SB^ jwZkYZBԨV]jbCanVaÎk%QWRy1 q?l1/>kcjZl>TL镛,zޔr瓏"|Ǵ`>yW^_YӖϏ<h0u;{+݆]#*`FkLm>ZO&偅SW}ag삍kʧ}Z|w$vABV\I_&*(Bq`:*;Y஦kHN)!$W;C.<OصHMjA"Iwr FKZ%4d!vv$ssV\ 6#eW$#TEO{eO=c=Tr/^{9mܧحpm0l}kǎ~vgb(2G~|Wo:x?zy ć67~yIlfUFJRGj2gRB(s*"u=Jmz`Njxޔʠ@F`:jNhK7q
++ _fǟ NUKѝbXeсhM<n!,Z+(> a=Ȁ 'G-=c@R דUp}iy)@r<_.P!7?p ׍kB܃1"5Hd?8Eu(\j멝=u8?8?ɹ:dnl}}Kr̳"
+wY%c[ϸ
+K)M٢ 5оG"1*+ O3y^+fiUvcKYOZbMi(L_9ųPilCxN !ԩyFa2Yq_C!d8槇2\/ѽfԜ.nWz
+n*+E_HSX .=ńM4d5#Qst!ep$Y TZCSڸ)ΎC+NbοSݣ!ܺU}"lGsکؾf*₱kq8/uy
+"T]q~ؠ@b_(=rRTǞjB%OBvp kb,fXH!n~|r#CB7yݝ2iR-HцڣƉ}:s冈^]A?S 8Gf wF]5ǔ$in&d(MkY_
+zJ=&[X5zԡ!h3UPQЂ
+Ih^E5J ىX5(n^msΦFSyhBڇ wr$6[V;ͽ##owznӑ#_J h{#í&6 |vcqܰfnF<]K>|7./>.3?uOZ,_d#w7*=^S|KjVbP@}X
+^`)g5!@ q:/
+c}؋鏨B\@`^P(<L}e
+jAN=<
+ցj5=f,!(W󿧱
+Gg^oYڍVWr>lݍ{&N`mAmiw >3)8\ ŊtZ͑_I(
+q\fؚ˘uI.%=&`ST' SVs\o,A"64S={ɀ#&U=f.vH*`xR2#.ʌ.m5֠^Z%#yXUbsD4tY]Tl휶:AJ- x")Z "~4N4&(rUu!(%7EbV|*R-Z9-.W̉=^?1CsNruifsC˄WfyIP5)^pvZes3NLSgH0БDP8!rBXӥ\*%٢K!ug6R ֙67d2h8H|2u=9̝j+QJ۽^w\s>5K皯GFIޕtG|cs>yhMg.""
+"銐B_(I.ҪDqō눨Qzl=-Rk !(W_yno!WWpyW
+%y)5泵xa:@+NFIAds[6oWU3-IJԼc#<oLZ+rffn2ēF7h/q4 4:n
+r˃WknE$& (Fp78+Z@. wF4LV)ot=Hh1]3D!&?DxnW.A< A]>t_Ձ\LۍNtCI}NF@=K%4_;&nxsCk=9rf_ycΘAT0ݎ*j0oP b'|idKqw*q3
+jbB-IVt%`0aҼ)l#՟#,I%T%(ar31;y {H+K#5UT]N`\󍟘 .kFg~7rK?'kr Ǯy?צYufC}In7XGkE+ ՗k]o'F$-(x=Bn.vZDm
+0Sd>F ߩ9k="piqqz%ju ^WavWedMHՙPi.N ˘h'Os|ۙƑQf^f3[5,e"ނ,fm-* iG<r-%LIZa.mA)bZfzT9H]KfT%42b&3l
+!/HN; ސY%jclfX‘3~,ygI6򬳠 ۹jWH4C|7:_+i7Zw->=fT^g=Houω.]}IYY^ y|̢Q~=3G#3Y+A
+* *\s
+FFoOPja^[l2҄!yGBٙ!vRP/+Xs}ooO߽ȑ;׺k%ez#U_(pQGGI=LKݢ\PyTsQ/LM%9a:`?O){0 ]_?:+K ѕWy+%[m<.~i*k(K-wU$mҸ!.o.'p~
+*sV96FIxPuoq`mɬ$Il>p?.)J󔟩$>]{Y013&ɒ g5#aƯ/<Pfj5MTQ#s1J $6r2sZQ\eܘ~Ӻ
+%mP+ATLZiq&>0dd"7V r
+U$;Y75QE -dclRL&c[xWD)@
+S&SؔjBnt7$d jW^]tdؙ8b5YU^DeR$wܸu;il"EeEDCXHBXt[BH~fk l:J?'i=Ʉfޔ?ձs/M\9rbl2o&+c| 3&ء%l ThaT%0pZ
+S\KJJ;x=dZav!uGKa3D[ koH.x> 50)L;ē;=\O6c烲эAwTNCLY/O>ya24C5w{B@ Hġ,o\&w(ܯO~r;1'?}x/+ jG^R$- m_)B 0QCi>=rH<ZtK BA(Bxy8  (y9]gMwWiʒlI%Y> 9cCJЄ6t3LId4΄<%)m$ @. 06eddl]u_ֱLoW~vm@uFǠL:AbTXQT A#X[변ϹF-kl~4uS_B^j1`%Cjm,e,//,>Ԡj286GoFFoE|/oG~q;ٿ=.;TL͵QlZv8߿j9U zkjQo߷*iS0ܼ8
+;n;k!s>gXq =
+K"#e*$0Jμ겆F^[@4cϪkY.NF08dy n/u
+b) /ɼU$/ "7_X EYBc]~6`V]LMf5 mbo2֦d õ~߽s➃KznS)dYPu:P+GS91:m?)z&*//pbk[s٪3\-χT *nׄٔaS#T*xRiuiU'.bT !TM1HUhDP[k2>š4Z3\k%ު'dG\X\dܔZoU~y4*M\MON}猓'QCk4\(FԩLK+ةSq7>-MF/)šwBtzfؽ&ɵTGG2(Ǟ VHr$A.pr Q`^V!Ɔ\HdjAqA24=Ud64;
+/^4eg#H0ʼnp<n$V3FeT SFJ^0%jʺ(; U~oYyڢ^:2ӡW7/@;#q!
+EXL% UI ꈓc2e^[=J
+]q$-d6畃\>V"StJAX<B"Uz*4
+ #<ztMԞ
+nCee>}r7N{ڇ}3?b&so7/e%1CĞklA 4!hLEN6ĜT*PD^‰ tE(
+ :LЙo\5EXPsP~p|Koje}Ȝ/&#6BtލÌEGsQ\A݌Mȧ{7B;^ 5,ZP =9Ru^AAû/|v Ž3&ūf1\K@1PWd:M:ƹ~׏~??75G(M)9"E hjJG@OW07ӳ.3Wj!D5(gJ2(ABzp6kPB}ABmx,!Gj DU
+86
+'KB|P TR%"}BϴP䵰@g|_pn7EzrP
+Q(֌uC]RU cκyk`2V%/eoV\N(]{DkR?RJFAQ2y2ŖБn^m4R1-P>n,-u0rJ<dpoS[]&żysjzR@(X@9Q0y$MUJghΚKhHS2J{2Q )αؕ$pԯGzojx.cj]ϸavLŮЄ2Y4ټjO #j߾-f#[t?euu
+j[[fJkN6Tj$=^n;?x W+-HW|7N:|qbBRz1͢%&.>w-=CCQX8u?n^8v?W{ycrޕE^Ll?Q^
+kee*qDrU:r.$RD q;{m225um's|Z$mǨ꒬5l1tF+.؊7
+}Io`Rzq[fbUgP`r!c~}]|ޝed%ݧ5˝&C
+N0eef|4Sp4@9K,$C4;2
+vi;w gSݒ'=hh"W<+
+Vp_RKxq̶eԾy̩a
+ĝn҄x@xj'f)GxE ) H !.\g@[ >TUU<F
+0Ҙ>aU"wbW͟$L :ă*UuP3RbEPB
+(E
+EDy&{>z%"/dLu¢%ML3T[Y[ sy!6YTDԉYPnr,~qdu7>n6cEhX["މF]L{_pzՂU
+ƥf}4lg],3KSFtSQxzjwgGéFS-zwݏu94Xw:(N#A[Knĥٮ}wqzܥQLXE[oY o,NUK8\_Q"Jf#Wo޾?|d`.[GNyЁ_Bq::rSIU]5U%P7P59iB)6 Px/ZMQ$ Źa* j{A0 A@nf~n Qp9Yjψ:oGsMh$k>[
+\ %|PTW]  @~B95-BVEXfU~Pm 8ykkY[IR""<'mi5zX\ImKƧ7^֑O=8nߚx3WSgV2,7% | gرf3ѭ%=`(٨[ʖL傉e^"5%[T7x ICI 8[*8E%3X4ЭkzVq梞^3Q혉mƴL=kT\P\T.+7Uuu:,iWuڲll •PH)m $әN Liggtt6Ӥ%)؁G)L| ؒ,ɒeYeiwu}V2?x~ow5zMme_I-*"ekhMϏ"_لt冰b61e)&0̸cech/޺=4sͥ?Oԝ#^ܵH(Lt(]>zZ^!"*hoE8JifF)/,8ٸĤ{o~h~~mc AUJRA$Qex)&j$ h`98Hm#<A*]ȂXAC`4Տ BjT&l2;1@M!A[3ߩ.G LF5ݪ$HZ<1wif;UI̽WYV@9j|qjz=~yC3 2JGD)F}(ZCMT(ZAq@X =F4ލXH!elI.H(*Q#F u@^h{cP_2y'
+;
+ UN;٭/'3o\s7}4ցsكB%{/9?=(#m:.WIRMHAˬw05꒹%<Q1Hb]Nã'JqC4R駳FEnӤ z2VϑrMN"躨JQzYX$i9}e̔vz-_zmfsf7\%ϵŚb*8dg]-RrZUTՐ/' ΨTLy@]ytɂ+-m>Ϝ|y[F'9Fq}SuksֹСA27:~inO ?vG"WW1r6= V UX&Ǖ(cgQ9ۗ<';W;|r(0^OvɆ6Y\bjV0wVrF
+mTNY*y3{3oBl@2\^6/ϒR G5}+8xvU\tmѮ#?!]*fsێ~K?x{o_x^/&GG|^‘'{.Ow^ ê|{w:==@uҌoj
+=PYSf-k!(ӕ
+HPA h&rm(֏:P:31 k8DCiiԟJV^M!5U<# ^c6#Je$ $+dt%ۏd488˽7
+nW~.<f$Xh P$cP ;#ak| bpAD*8g:˵nl|qʺ[RwLG]NECB%E2R BZMHFg
+aD'u3qDn8WH]V((Q#5'E?
+tUۡЩ>UE,{"@ɟ.K%$# x<,:bOYImEBPXJfB/Hʐ$4GIԁ@ BܟHJIHJ ,jHVE= !%
+#%IUI`r<B@TA*2bGΉ)kG*(}:=6Z
+D K6fq>2f[Vnr:\CӅ][U+qGA=4jSm@eh03]Ӳ1=d0]U:F/u}
+xǞ+Ξ.L@%߃׆RT/CР0+}Pz|U~C9>A=?aBkxC~ʎ Hͅց,_?9:* !X
+ amoP0j<[GIZ? H{
+Q oH}eۥ= gI[tlD&2騫 &H9i&SͤѰ^*o:JhsTfMg?6;˔\7H#-߭h?ɖ
+A63A/D5'u5&D+"j;pKXjO2Y`('K,L:;>Aƚ\GLU=oN?dƴ|e'GӥtW޷vM~s7_ޞ;;k}1s3a-}W:l#-de kNJ=JɣXB_&M4bIxX6{F%^LbW4"df Dbm:9gHmku{?Ә͍E?ɔ:]!OaEjtSI] òjLT
+Tk 5QpbcCT}ZU;w,$BT%
+|@zHo!"m,փiPx 9
+F1~]t)9&p M
+A &0&`@kja &#ܘ
+,Wj)YjN%U$LE:cBt
+rтY1 1.f,.05cQMg
+&zP3ix *@ybBbUͶD{dIqf"7 ~xCrCwćm/?}0 wzX{^Kܔdi[bůœ7#:Vl!/mڴfrk}ȓUc~g*u$`D\IxH5gS$fRU3emV32h TD :Mʗ NF+IG[E{TX `Q>kOu^:{dny($o17i%Nh`S!MhVqA#!ڐ7&5) [ZΙNB[g7?k q6<LL%)ƇbajXf=[&[ b&6$fjisVO ϒEIT/oW~4um]$VVy}hLĭZv<#ҌL64mVpiHpE5zA򶲂!aΊZ1Ō^2қ5
+,St Pp+JJbBk`*AP^_j˯\ SE
+ט~`BBߧ@8$SRrzQx_02DY)BG0$al|07!T( [ rby՝\`mXKejCu&loh^9hX' FO +X%ݞia,"uYE7_JyE
+b23X#."
+ Qb=x"ɳF7gY_ c6_R4]xDO$7rܥ#"_nzgwלn"* s:%bw@)4<gPr$՞P|jf]s:KLE#o|e6]d"D
+cC?5Ə̊o/|b6;m{0P8Vo阣XC=NYβ(L;S:?U{梦>Ȫ}̼3!7uy>_cls'r$B i햴RM[7MvH;X7MɴNժ[jRԔ&#HB3_`}eoyy}>{|"pXp3
+dqfrՃ6WL»[NgE5A{:e_%#њcKWbD5nU#=H烰6gD *Z+z:  ;EB];Pҭq:ˆdCaOruX1DH1R (U4+|i͐}@ ?akP>S*NalNd: J5bcCOX@Kr$
+o-)P)AⓣPڂA
+%۝uH^ro]oȊYI
+QD AYF!wj B-Ac">C)" @jrG|,D(D@Bn5D!S2
+^R jR`yR
+{rOKχ_&S;k=aըm(Ae{:Spʑ
+Q F .
+<3
+lLGjG:DC%w]pl{H:KpJǑW7}rbNFt=zvVqC屙s빓#}AOb\|`g]< ҂eE9kq؝fbE̽5 `
+ 2UI+BEжL =Mj#f3[L/ lsN0T8idl?.@~\Ef2͜4
+. mش_?~陳N40a}M:^(Ʌ
++ rM'oc{:S/^vg2S3d{¡-H)ЄBa2IiBa[J?'(Sx;%AK=֮Z4ԬYaem"US5|Qg߱- $E'R-40^[i9NS% L"7E+=z!ҵJm=_踳x<9vhrX46ӹwUW}?^յeWVϟxwoo?w
+Zx뼱Fm=xL5Y tr뮬ih,)f fF0cnú-fم]޳"Uy<r^EP ie>KEVXXd+1gjpEx,ҽ%) 9O4T=xjVi]<HMF{oۮg\3Ʊ}˓M^مch'/1H"5Mh+1IJM2h{!JF} ?!>尫S}oJJܐw䣞һ~h=# Re+>k&ðW#.,EcHh!;?Hբ0ft
+7s
+@z̚DΫt#zRT(Bח y9޴) ɨzwZ%0 'c+NK@{(y^4qO.KJ(Hs@{Tc7p= .\'v@B[u;QUI W w)U zܯ
+-R9vH} >-R@@a[Wa9@z |^D!M4 vb,Lk閎A=A %9 D_O\_:{ҏn;iͺk' t?UvM j|Dkd.*dy?^?|\/ff3?eLwv4L': n
+@$P2ttʇC_B:!IsL P)34@`lc_uZWj͇'oGŝX ՙ݃BFKn[ hfo4ߌn1kXKHpYpPUK詚le/?1u2d\OP3̦,U A yfB؊TۘrH+̄lӘ 6H K j AC>Sg?>'<}>{_݆9_>N0=&۞42Y*LN33%;aWty4(PxjAn(1d\J E19^SbRn4_J?( |Pq$S,i8IĿS3nN0*6I%}x kRXgz7(%ke)$ꋳK22pYGhsua1Xn2[uOtFͣ]&pr?VV>ӦG/!^;qAT"=~gNzYTM-.y5F3*BՃ@=\ڿ{p pgW>J</rbyjJ$'J`Ջ$~gx ƉZW( "\9LǞQ]Mp*\)3\_ƈsWDB0mD-'LxcN\eKirbUO8z^z+tty✗@:Z洧dJ2P|3k+5s]&R̷d:քNyBG|{[ 84 h
+|녷 voUhoZ.StRO-BbCz|77HǑRpE5˝ff“ƽ^R}2[f$"c)$,\7󡄑;obMSTIN$J:>0ᄬ p9i84HhSѠ%Vti1RKStbӠ*V
+!X}n>EaT2 U14RAfYx{N|)sc];mdgysgw:{|SEQ&LF{׳]ЂXOqݷF ŞVL~fp#1i*
+m?\
+_MϘ4מȃ2Bh`FT,_Vg5,(G 8δ&Ztx}(?ѓx-xcAfplQ_|~-l>xя.?km9|/~w?y/Ib˝g&zwȆW)̄ÂŊՑp>n'n/t0n̥"u$IJWj5VyAxi8gISҘ\Nmrc7i@r"eQxh"{[G񐕥 K7Eخ΅ _:}˹]1Q0]m|4_m@u Nj7L]IWTmGWV UKBti2Fdt!(O??=s}3Y43mMn V
+b)5:yELK+PcϚ^xٳ@ Fc\@ij9[H I^sL,8][FJa-oO_(.cHF)'˦2+leM#2&T8}fTdnXK2߬j}#J%S,B.=(JwYzڸPLWۓuc |?Ʊcs\aзN?i?ijdH1Dw^׵쩌 <E/i{<5נ~) Z\?@0VdW U3 kE aAԄKԹ:Vkq񷝯ȏ0 1yp
+I
+fZf;Rҳs.6h8fuxQjmN G[pTBםU_}oGoOƻt
+f2G "cvމ _g;dn`uaJ&G@ACƎ[Y1)loKՠ (^+}_N%MP\M5V.|m)Z֖k"nTZIɌBq"VF
+
+4@FRhS=kf
+nv6i9^J솒g^B!aU0jU:d#\B ^;dLJò/Yvɳo98n#8>j9E.&D33-\uwؕ]?8;əZޡ|푌_X{7С|=T_a~`vP-A ;>WpG:ډNĘ4.(<J*ҥp'w}6*Lѹ F J2;$u~ІmyR mMJ[rBjORПuEU)Fjq8EcYT[UGJDby\
+܆Im=+08
+Wr:r=@d>zq0pTTl3Ra |iiE+ک 79GVUk`ɀ0AȂIS5Sɭ8ܳ @gG>}<z^>P$-"Tװ3qџ;|F[a}gLܺ|Su/bvOsZybV\LCC|=嬋\I$gfycrě3WRŹ脿49_`B-ug;dغY .H"8*UVV@ԹZVM,dZ`nc2:cm),"h)|m9Y
+Pd0a)4Uؐ VՆt@%
+)FҼ,֊]xoi:z|"Lo?[6OG}Rg\d!/5MΒ]od;,"ߔs<IDOKj1$<ͭߴ?~֎7p3'YRs}8辂X3 V,q}7ҼVآtpjC8]O|<wӓn|hKת25٬)
+He'>c%<5-?Ztp}"?{kepO]3#-[ܓH<(o ^vXǎ<^ғ =R J4 #-J1aVIsw yJ!CjUl?2mJR&FE:vFf0/u9h!º051uUR>^[J2ZX+zm7A973_hW52ʣ|^꽀>t&?w@{Adpzv:4Lː
+r̆<p92ʤG_1VD~ 9pM„ZhR"l<b:Y?Ţ[7/7| Kq04"ZZQY3!I5`vt>ŃS~-^[iB?ͧ,CHpp%=ଣ~=^zwnlIǚQšH ޔEb'DILFngHn\͌5ǧprNJ~[')UDDG|XW*c-E\Z\hbnI?3zj\! H\, Sb3{FԘw(K
+asټ@Hɂ(ŅJj>V-u|wZər3{Tϲ,OB[u]y|o?|du|Sެ)wCx7qq
+_j<2U8ie?v5O^ðJ_6Q[5"ŨiF >) \TH'X
+xfL%a/GP j0(
+T 9<1P PAj6Ao 5a
+c
+'ćYa_Ck#8  TmL
+YeLphRJŹ@B˜Vu 0*#,%8;wEER7wST`ht\4vm2oYhm7mߩKҏҽ}u-g&;W}$z
+!S kD߂: !9*ʅk*q0]j~H>U2A*$<TX\=UIT&UH> W6O\a#ԀAw>\Ź1p689NkbaiL˛k"3ť3"Z*cTUX 2L6sjBU)FnKpnJ_;~xsCmƻMzu¸f_>qΑĻ,~wվ)}tz6 y5CYѪWɳ?AӜ/7l纔 ԐRY9ATUa+hQa>[fyм5QO*|T^.]͛5iQ.@8#bJ<fXy<Oyzﭹ*Rd=yefR2e
+-&$tOV<DbB~ ƫ.х(E+IΌJG]$+k
+;i'9,ߕi!m=+K$c#>遼>ysƱ_rܯ߹}͏gU|c%Vt%ru>pJk/}͑ΏDwDw-p˿s\~~Lk1vG}[QQrۅɷ_↠|>W:3;cQBP >yLh̿M#ah3w>cZ-c9[Pe~=2RC[J VslATL; cs'Ĩ^ \0Bd#AAJЅ'JYj> BZx(D޳p>KO*Ϋ,*, Bݟ2}?\0r_˱PQS2OJB&%?54rco"h \co; b)HAx]_pn)# ]A A/nGn[wyq=5>ۿ6itGirz֩:tf[i3!Nei_,n4\DIJn_Ka1yK }Ob0c$IJJƼByrB4a=,3&g!7SgO Ev'\WnrzOĕ<o wHx$
+XUU[ln_{֭Vmك/,])|DB $dΐ@Hin@{Ν;əձȽcWk^IGY$ѝhzRVl41bS3C. Jx ueYc?tګ TJZ|FǶƩ8,a"Z{b*c/ zȼ,32xQxQy"^A,be+;2B)y"-bk~p7<uTu?o:[]kX轗1,[9;%X1l̢yдʛUxP}Md; OB@LD%,XlRJόY٨)tk,JƲ͏
+@ʾg+nޤ e2q9`Ұ쎾ry7XVx+?P%jd4N*.ۗ$!` .O,Ph`pa!
+(N’<HQ}yW׊q
+Xyja`^" "ʼp9$qkBm׫< 39pOCsߑC7j?RWvkvx3k֯ך\O;rmaL`Wb̥"K-Ѳ#1\G ێLy"7Oࠪc&4hG^b4l)rM0~}rn|(ER4Q[;+C9<ȓh0Wjۨ phMUvaKLJET?#썩<F'QaE eF,P" 3怜3=@,'My8bo/ò9뭪r~cu멽f]])9=Mg^h~hwϴ*}{j>l?G.񫺿=wE6tҍ8'*޵G{y߻>i֥.zR<# 2]Vmn/R~rW^G}g#qz%vodܱdnd'c? LLu,83@z`A@|鰜㘑!\.lwDGUHh~! &i`{ZV*kGIV(Е2%
+bcMVv}~{uoo9zS'>n6Z%p e@:$ȩA& P:N4UXp(rgEIʦXy
+trI1+U=7_^][gpmh0]p7]1!l8G)<=#RM71+ܙ0LY /
+x#'Z/i"اPH,SQ)t~<S9RjN@=X&sK慠{uǷ{
+x j֙ū[v>CEvUռ+ . z>E@hbGuyɺ;@E.:q<M~+jA_>+snPqѾ~
+h
+W Ͼd}:0L+փcT
+qe<Y$+,╒%qDGh_)@0?\rƗiɄj$
+'uhI/ ַL:N J O#?IacMփ
+ϏC%[:i
+rˎ,[e+\@K6 kɝCxT;{-e']bd Dzzdp8$/9aоt@1Ho͡9QW8sD]@`4 !5
+L +::($0,ZY b`R3¦(v8(!Vʥ(f1\.I'Y=<IJBi=,Lnh31+ߦ:[ŏfyjmWOk`gW{m猓R(@?03B`?h= ÃRe/zUrGFɣ ڞOʼe_cIo!9SaoBI^9]| %_Wt?wUнOtT)R>ͫ>6įlB@~D6S@}NΥM~D~ZI뾸
+n-  5FκZbRp1NR;
+OË.iKJ4@0 X,WL^&-xCQl%SίEsK'u!G)j *ģйmgu㗍7_0J(0C) ǦX9h~pΑqX*⷗e\k=rʱ\moetr4m<W3m)YI,gv"D0WST,rh\-+c~c:jFSGW㛝]/Mʸy^Na+[oLs X.KGaB?F^)(oIa@7y6 f:
+&] nmq 8&iqk!NTla |ryxF[,єr'e~']aྮ+q  :ƕǿn~;^Br)ї|64'!ܒ$&m:J(V|Z O\ "=IڦʟI\kK6%g5u{R69&0sA:NtTg\ y%q '!҄knMI $TgcedM22y<EmLHV%,BD5*(X(9U7Mb|(;jQU$@GP3p#Bk=P@!Zm::'dNvhZ*5xy>u,x)v)sO;fΝKndэ9\IWs9*Hl`ѝKڅc#rD5gC9GDY_gu,@8!vJ0\!6<ytD1x0!Sp@Vt2P0m&>_ /E ]6n^vfSUm+¦~kۑ7$ ) Lp,S36(.dg
+Cf;ltYMiT?DQSzg$쉩FqaMX!7C#Uo(GYruOͯ5R$uj8ْ겒  7 9i߇7f?}ٳw[+T4Ѧ%ٍڼ,lmj8E<_=8!yɋ$7/H>WwuE-WW;nkݝq;]wnt:ujӺjAXE_"0Bnȃw=ws3m|wι{M2\e߫۵Gu`:jj<:r]z赩VNC3镡yQd!m6$DUR P d^N(MIe' h$_ DH D 4OzPkpB, re&\,^Y.A`3G#9c@@0,سǃ
+f aCےd_A ɳ|9
+ Jɋ%)BK1Goegr=[~r<UGu@ ^\Xx}sn<|߹;W .(6Ac&pKe??ww]JV/^mNU5o/Ny{cG j_]!RQ=LwP4^$9U"e$]Ov[O6*-!pz\F2
+<,g( dk:uoD/UVU׷|ى;|=uk|6K18h$G%zF*P tELGPS+:Ba|ܧLJ s*eQY*|e|= 8%Yu5ڻMJbYT*]תDe{OMzki=˟T[Gn~uxϥ?]xysם{4i/lV,amZ?-0Empodi 69:)#4.t}Ou6oՈ].E qBN9!sáqEu-99p,g >$[$"YҌDf,HdŬLe&1gP ht: B,J'VUImN=^M}ЭnmKc*48M:y$))Ld?<`~I-+Ndc` \EiEv6)ҤSk$:o1)H/8
+$\CIy 4K1]A):%;,sC+&]]KMC-e%yl,MΒoMOAywo )%uDzъ3)$\Q 4&tEjK1YS:LS`j^ZRDPqь}C\ȸ$%iS2%^]{Qu<9UǑIaY<b2﷑1::)Hr<8\RW(҆a ,0^~ܚ#!Y̐""g "dMdr:Rhɗg
+$H1<PLz9ֹSʝvr>$e mN 41mV\(\g.s* ZԄƩJ`a BE= N^̤;7r,l#95aMiS}R! j GaTIԍ4I,w2/zl&[h;,R,NJddb$NǗ4+:"4,#|{Gmt8W$4Q@9rgJDCF!|zɃ&dKӈ2=dRjUeyFDF[䚡ngh7sa.5˥uU{;PY&|^@? ~wo_*Ư-̖5ηONަnoʟXZE[ᗞ5
+&Wty94g@@}hpr0P rprd%B*O {"{QvSr[&B)e˅\顧&BPq q%CDs0MR"0|Eو∠0T61 fb4@-(d H*Oeh(hQad1t+b[rF=+#
+\yΰ{5g4$Xze=$2羧ڒs Է=Ww";7gqo";$mxH[vnqLѦwNRmUGߪ(A֣e_w߹SpzpNJW\;=VD_09ԥ`awqEJv##7!<86{x7Ʈ]-޼;"fi;! dm`IPD9a
+͛ rhY)K)hE_:j2
+}F l!~Lqڝ/L ؀ T5ZmSRГ&:x
+\NY~x׭^ Az@w: M\,s+_\{
+ϗK*2'bWvP_ SkH?srzBc`Pަq9Y 7rB=f٬ A"ꆶ7 1'(UPsE|xMfIJV`oP5CWP7Veq}JЫq1Q-?s28 UE"DU7%B,V5pif-V?uYF Wb<;jfU%hCZ{&JzK}4C\u3R'j}2!bxQA_<ĥ=f ϿcwFGC3L@Sa4+cp#F\a҄µBG$;>j<Y%-FWc%1#\ӡPL^Ɣ㠒vWqU֥6a^<'c"$mO
+uY^s=N6X200G.^;qA/f,| B7 jv-^Ww^_#;{X!R-M#s،u˝?Hmmأh>>.Ut涨=vt6S4bm)5}Y]TaWsVS[Fc -8jwL].z4[c1ecaHXw
+
+/':*U
+>!:R~qPnT@~$L0 _bp|#:a6iku6+p)6Ix@@#-
+Ds.OLxCJIr:PAQմg*s/(j3-m :j
+
+BLgdpFIgdehu<WD%qk6Dqu|3 ;?Yg_zI$D- 9uhX*vQItYq0^[]9j9]PӼ1͕ӝarć_ Dk/>i?հ
+\fԊ$,eBƃ}F]G&zDuE4a)n,A6o?0(L|FKؔ4(BsbR$Pͦ7>) ZfkfqhKjf#jq^zo&[:<v$W~dn "w Hwq+I.ݯ=yn- 'rC!Mn#RC#;m>w.?쟾Xt_X7ODCuI15w1 F4c)'DN\v"&A%SYted@BgDH(4kP؃H} FAXW-~ ux%T#) Z\~@HOHY=Ñ2l Ӛֱ,+Z3Mi-j7OMd3l}kG_7B|[/@@Y=M<%t )x% Ԏ/ xߕ z Q]:}G|GķnzKnw[?<qũ/^oOܭ/Ϝ}}ST$!P`tmvsLϖe8#
+^%,]%t#˸_|ۺ3s 5t=%P1MKj˩"&/8H(F|yOZ!sVTa#yޔ\w ϐ]p|/2yb2p(sym 9 zaņGd媛*-xhꬋS rjb~ڨK6-LCl+23f/ɺGpg}p}~<vxc|w Ͳ)wܒU3i"DR
+O:4dp60yXC!wVj5\WsQ&?[@RK zCΜ֚R񄿳z,А;12Ww#yH2:ׄcb~8V\F9ģ[9J+6O%]7rbxuu1Sx\;@8KP4(K0Wf=*\/g75|ltnn6afJ#|/ h~9ݶurA b=,<DLܖ Ä*p6-\D+J솷RP3PP
+#)ZJd]Yc!ٮ&llIdI8 vbLB64C?d|!|t6mN3H(Nj؀l0ƷN$Yں[v-ZL>g}۷3%Dҫ:5K&inzѤHQE*4#,Ӭ61۰qcI; e$*@ "BT3ⶴG<zşWՍ{G~.:VZGޞgWf {BT}aי+#p=sZ3`3:rkLOZӼD?:S]r'ƺYx fy8=OGkhZJ`D49;L*3E7SKe%PG*"-s B3Z|n&PH!? .ՇG)-ʔWVI柈p9>;S,g8M5K/J>JRF9'DT^IxA‹bnDsr^Ppùj(+P-ȃ<؂ 7n3Fĕ6 )p!eA[!"JHb;h+ MPߋ 6x]r/.'#Y->h}Tec@7ÝΚC䰺;Ts#dة(-<|L}Qw!Zh͕UFmg /zC7ꧧ޽vc^KWrU`w;D9'bg>/rZZ`Ĝ9]kվY-$]4sa[Zs4"8^v붵`pFMJ'ȷ #v2%X^ℂHʪF
+M2[ַ֧3-<Rkۊ&\KPrjn@y_^blbYQ<[Y؆53 }bY!B˱_j8Ⱦ|P;[ӳm1oE NeP7T!ceEL.4TJ1H]DDw6:m65g歬ƒsXj(ڑ7MĈ:5JO|4S*cqfl6f r3p%1 *"(RFNnoQ_9OU˒>D!Zl.XD%' 5~yI!`}JZ9YkskzNf76YV&c[ 1929'kGbG#w`чi{g7)
+F%RhQ$˴"Pw"KJ["
+;~l`9 #w%R:xz,Xs \{ɝ+hp gyYƂ[-sŹWx(np3싘5٠p*o(ӻXeM jϽV׳grVB@,ZY\&॔VMOH.\-~F~]X탥qLJ!Z'":,
+)RB<] N%ĸj9zO=+8̋,h_V\r[LH%dQ&pl븇=[%S[agSR :"?=Ko?IR bnp~4yte}wcE͚Oဦ8e{s-u"q56 ;鋴o6PLzTsEґ? (=)jM ,"+ҟ1{9s8/ު/ju=xM)I61I=*`{yދoDޤTԓԜH4X^.dX~|*Lt%E>G$B~iW&"2B8I>z$pR8ɡ('b<>2P\/aL΃ڸ8KA4؆m{\vZ{ILӴiI2fO$qvjlLm0 .qHJB쮄E};ZFI?}ۧvF65Xó`<347LXp_/4A)k͢]YvK='^pLE:TXm=Dڥ(H|Hug򞇐 ~$x@qoSyChy/ BjT#^q-ܔ>vLփDNɻ`p|R9)F o6uG5/?w^KW7.}{_д5+f 6e/6:(pf Ƿ S:|5=xcC˝fuquDU+gSʄ?!bSt{RG,.v -IPH 6ȖxNDŅ:gZda"6ڳDE-JBRPB
+فu h 332}p К*4nMXA`q=Y><3O]ӲbCKS,(n[ZO(B[hM
+pab*
+#) : |3Tb%olA<z=2wF&YkN> ,(eY5/% PZ(_h([lJx usfb
+cݖ9,Ma2&+#Iwk\_gv4ָgʲijʪvP6W;#+ÐvQŦn˭W넨T_!D 4Bz9
+MN1M!~@RnNbd'ȜU\]jI
+}x={Ϟ377 +Bt/]`d%oj1:
+?-q:%2WPqS"_[cbDez%M/bR yRJ9EE p@ 1}9f$рl^Pwr'beQ\N1z;HvW4z4uWͯ~y샑^v򳣿k;kPHQrMixVݜHznLL{NVnپF+ᄏtQt^+<PuCpW9H22w@{cJ=te)-g<Bb A:n[|gvMϫN޽/`Rt Ikx@G̉0_lVxSyxÄ/oKC
+/.B`莏TNa(Ŧ<#I#ѱ$%鋋iN|dūM+WY 8
+F w~_E3"zhjgĚ`px, 4G bLkQ?p.H
+M%P+4Zwou}|w׷M06gCe(AҔ&TP*%@ l ^>gfܶ ]nkks4$)-qBZ9m*/|{ʁC;{?^-^{8ld62k֋,R Vd<x n=▒IÖBKs9TAIW[x>*uY)(mQJ?.0M.e %R*Bbx",V;^Jv*ciTl23z
+vZxLޜLbsgǿy7חz.74zpo+bi!N&Y># h<۽[@)3Ž;_t*4]4ͥhH+agdbq"N9-T2)-/T7eCJ0)qjWi
+$j1z DV9S$WMa7~</>,rٹ/z6p7r?ɾK^>_}?ɏ>2e>9p։w4-tmML.;
+䵶Nl%
++lO<H][?S 5c„v-ۭK_y@Fơ8gOEێg/:^9b7yr*Z5s>ceɼr䣉-3 <m';-Q0Rxk"[!b}њFqpŭɎjpɽ\E͗O (1a{V\KT9hXX
+91 )GGĬHNX
+?` SP3<H3Å虎m϶<KgNm/$7%7 D31g@w@}@r[񧂊o3Aj>V6ԃqp1"ߍnMJC!ZԸ&Ax2
+T!ׄ!Pv5Q{T߯) *.׃c*\||jluS'7a
+kB3[ߞ8߾:~轑s|q5yNkKK9erDR!
+Tszl*zh@<B)tl%#M Zh盋4 H۪v[6@u5D ejbK!O$;%o'V漫!Jg.U;snGД);9㡨3))7;WUZv.Dd1ɴa&I)!\p)F=,9[o|l:e>`ז7~9~v?>?-;^z>N+wLq=0+2B  N4Wٲxʏ'B6R5aerV*[KC [Pʬ0PVjFQ,"·#"8mbjͦeӔj(UG.l '{9ҳlI!!`kG%Iz*!"|V>%*`JBU`|sA
+
+#SG$;NW#&*;MWgHIc:VͶBRb*%3^Vf<e^K6cSX^%oMLݩߝ>+srVKWz?"/ dتr`"\]r9Ÿ ھٶ]CgFKr)YNDY2't5輙MrG^` ˬTl n`~.6:z~wcݸJ 2.7[p~c]^kcC^xG~?yKYSz<-g<l[<#̢qc\p]L<q vCċЭs o<S4E\ z>]ȵ9s ag'=z~~@ޞ'}MnkO
+=:d~aY:2u֏GUZOld@|P%DFYOJ8xD! "[N_Ė/b8c<TGh:}n̥#U^P+ z@@BDU@(PF
+yH1
+(#XGKh9w
+Ҡӡ*ԢZDF0Dc狫ă>a zW /KGQ8
+K"Vli6gBN<,Eg~P Hs: bcb? |Bl\z?5>tϜ[T4Ydu}7kMXcmDȶYgP5>'laY,kW̲(y>1X --?M3b|#cfR̥`ՄG$kz'V֏E.!&8R14(mH63 TOa 2@_U0TyfC4pzmbױCm8v  (x<s@@` 5(t5xU`c\ 7'B(e
+է*Nٿl蕢=ŗ6HG UHΑ2}G
+q.8yZs:@1Ua<[u@QwHQR,F2rk|zlUY;,@|tI% 1SuZW^>yX5zd b/q8ɤ=+zQDb_Z>o:f[:&㕉D@F (Q,d$4Ș߃JSq,MfY3MeY*ef6$x
+9Vɴkٖ@5hU,^HT5/]罟ng6>f<κ1z_I? E鑕띥&*OyIꃓwO׷:n
+N%4[ȣKp8'IQ#BbN
+\L Q A&S V>&,L"7"f\DƴE򙖈1U3!)l Ye a +(-eO@|7Q!Jb9&F5[,4YF@MIJk“@1d o4I jEj e {}@u^oAȽ] z.zIF] b"
+@Aks@EC;6k/|Ӈ._8Rp ^atqv ì<GbO_KGQYťg"~qoz®l^24(⓫ECjPYֳ':Jj ttu.D̬V-hPSKRFwߵmdjN?ZY1JUTy))dJ@L; R$칼U{!K\NY6DTi'OojSmg[:y/^Y+mٶھ|KJ IjiJGJuRb߼%q5_17 1'):3P!4Kb*@9D!!˅܁,AN'<j*bV(3h
+p) u"Qֻʲ xM Bbɗ2h^zh4qH`q3ΊisMQ[\ȍ:ٹp6ݑP8 <! φ|I`H'$8XF9⹁@;{UY1s
+,>~.O0ڊX?&?ܚkR6ue7m@Wj$v^AK(!JޞWE@jGzEZWAH%c(QEK!bBh)sU
+!r+x1o!P6jH-tR)^@Jix\kP`Lbb@3!80>Que_nxشdP(n1,Q1B+7+P9Xt)KPxoxT│}[?qҐZ[g. 3)8yK.ZI) p B  _淊^}nӣ|+b48ma.E(05Nag!M H4芖Mkֽ;ռ/=gRmm<Pۨ(O;и_;ʟm>09'UnsET77?/QX]}u ηn>
+؈FIԖdDJ{oo<Ϙ=[q_C*?y篟鼹ͧFaUZ޴\K:z^{K܄\kh{C[F>3(-CK9NOj&3=Y" MѨN5:վRtm0cނڸ8#I+! \$1g'vgq>SKd:m<Ԯ69$]VB!s,x~۳ٟ*[Ȏ8;ڣ4-!s
+U n
+K9 ݶI_VLKaW;<lγ0::;;K}m/[a5nغ ΑG]ky3ڶ,Em&$Z'<cl~&aGA lj$eDxܥ+TOH9
+6;b(s$;ZFpyK'1ę,q? 9tK9P;BժU\n* x5A*-DQX/*֑j"^c4ae^j2YMHYnD&310,Z=y\ oFqր|1O)d[6b6Fo&tCjrЉ7cSL]|>p4M_m_ RxWqE釔A gfGJUH
+T%=0 ڣDX~WTvx8/KYfI5Q,U.(RqJ숗eMzznWz߁`=\)F()(%ِ#"Y j߈ %#2j~"{_v E/<5Խ
+2Ie}n"27ymz͘5*g92zd95 )1[&bP;7ɗ_<.HA$Wu쓵J^bm#W?5s`nL{z=>s̲eU ޞXOVR7kZCjl),7T9꼃.$e^*`U#E
+{ KńR ozDAR$3fIܜPydgWp̵C5GNA{ ӮR-LͅJRҩI9q&
+ٵݔEuXeFCٛ{,<xJִBHG7[߬䙄Pb+CaZ_J2ӪMy(j}}V@k%M%Pdi\.QY#hb!LMTNےZcJEγVm(f.ǥjHV]S'R& c)-nf\@ױzI\"Lh'rFYP̫Qdg6{Z 6ONvzJUįj#9emUM_iz&+%fK#kkޘV[E8>>?m5
+^`m N0sٜg
+" @=BI*<fN(1̏>"ǟ7?_^+C>Y7K~G=kvYv41):a;#G3CF,Q҇^֍?f"o# }R_%`.0>w;W^zXCoсn+k]2ݞxulm{Cݳ:O<3%Pk#'EdyRg^aҸJ$j>D!)XJ
+bq {nZh%Φpm.RH>Ql:s}rFhL$bhG+8ՁmUMdZZI:a] c\\O%yuu
+LDp .OR0 _5t#8iGT0G:T(\aki>|b̾S9VQz1zak=)"DbE̹d[dl}t@Ň-!}~aWG7_<mui S+!(D ^R@ }˫ʣUBA@PYi{h„uZznWTZhs*Gj  C Q)*iY,aIӇC-U(|FARA!B
+z#TJ&*q m_>z|л?8u /
+q2"צrk@t>3jdO蓳P໓nԝFn-`txT?1ﱚ<n>,QR5='\(ZZ~bjK|1^{~e,G%_>:kک+;^Kbq5l 8wmN;5|;Ծud8%rR(8(3 < $4 N"dؠdxZ!2~$ R /EA`ߥ",jQ
+u( c2Q+LQDYIZD ĕ4)-$/R ^LUJQKvPbԀ5h46U@ts(r2 0W-Tp20?¢ը? IS_a! K@°5E4m j"lM+&ql,Ң[Ua6#|avln7K{H@{w;H~PPyPH|C fō@H:Jˑ>P_9~sRuWo`mfܗc>aJ.7Gl 'QCA5$1rWi;6(u'^JoT6DaؘSu/M8sp`~pq[=(ԧ.9__xʬ}׾ohr(`ۿљ޽ZPclMc͕
+(tkSaMnNP25kX9VH$Br]/8k3lk~:ܠMؔ%Vq9+]0yK_RRr=S;e7; U[wj^ǙlWp*ԊTMb1TCPJ)Jd2ʬ3y6[k$:u M%j2pزכ0b _\e2_V
+z.Η$p\2*s;o>YS\v:Ğ{izLl&I88&Wcf dB*ve1*֬r:5/<M:",'"U*Gd8F=\-II(1iRwmMswCmLٶf:b,beBOBaY9HxdwxRoս5gyk}Mo?#?9W%'6;=?6(<}ʯ- HRP(V5GGqӬ@u
++lU0G V'-UǧsW/
+T0YY뛕70}^8'
+iTt Hh j١Hn_JX*KEHב@Po(`U6;Zi%t@ 85(v}v֮wq:ft2;NLIA;ul0N1.Ga9š}Ε@mXyh޼qה-;"]yFmw~kscH)ZE jZ]Yʎ*Bd5&l(c1bFȜ3BK
+x-gc#ZƟKU2g2ȆІ7T"
+q e^2 kRZI0%Л݆(i^IxF̉RCwV"x5b%4M`\Tj6->m<c[LJXV- u}(cz_-ٍtO??؝3\:x!Ϭ`L0X6RӬbd>QYM3-=RJaDy Z)n`NI]XT~!tgyZ`4LRIq%
+p^EǏh\f5U_E}!%e,SJ߭:;ϯk}E'vqye5}AZ.n.^kWbN*[H?{~Lw߂}䝱WfÇ,mϮ_66e.P˭g,
++itl!4v w<BU&dE hj̈́e؊1LG@<8&Cjxhˉ'9p2NAXN m}IȷudeepVdQ+p:@p8-XGC̀jo
+gF3bF8'~w)@d ~A5.T ?- 'e,ãǕH B5V5ǁkDhp|Ghh AHOOHAHS|IhwJ!e @0(u]9~׃?_}ώ95st4s3?LABxjfY:.9rOwy.(|Wj>fBXg /tSfVJFT ,mcp B#;H0bu盦|"kwGO
+߁|^h*mHUY`gEqsQ,K[Y+Ot\dUsSp/n VAܨsl}~}?2Od|[JZpef{﹣jqnҍ}zgbYu FAqlivCo
+a$IM!K`x$9 WN%Ka-s{,SV(-e`-fc蒎.WEsSg։:ˠl71:qJR(}0-$
+W7)蒰`.r. '[:BlE$Tm. (~8懥)D E Q<
+'b4^&I6X"6;.|0?~[Nd
+j "#X9=$GOKj<k;Ozr zp5Z1ktO}o=;\rZ|L|_?_6\n[;$}曗>ntZ8>ВkmKl'4DA!Zc56d'>B{{no6R`s"$wF؀x}pO!m_[ff{|BuH'ǿ@MR̄ZUHHH;߂iR!4 :k!Km\:
+$G>unw
+XKrH|:(Txe(Q-,\OM4~= .B+b̷˸K bRʛ hӜ)/T' }W~?4BR<~<cЋQ@ !6#%lc3PVs*8Jb
+Ș>dɶdɶ]YL[Bow[9 q-?ymݻL7`\A(F?L$$l!`AUQߛފ^ZnQ#ZL"lXåEFQY5^ ~$-s xrV4fwhgXq!2D}E]ѱO}3k}..9l:5=%54|[Q9F]lzMYu ϭ'5v&EQ 90q!С0ӛ͝Z,Ocjd.X_00MEP8 g|!JP߈
+T#rpaS
+F *Qd;L E`}l_T TW+5Ƭ~(@R`_0HIDDX
+U5͌)VIИY1BTJ1B8 xq٥ñ*$:YN(Mu16Ҹw~Lb܇KFƃ'=E;ЯĨ:}R!D4;^7 ښgg~sm2<u٫T9YXakTa,p:նQe88LC*s۳d~T ӎ`# [VJP.q1o
+Sme3u"8f93\\m72EnC[3 ذ~?&,F4SKCD&7ג YfZRi<69&lcEJ8OhMh96ҋ
+/.9)*DAb<YI$<B"I) V}t%-\iEu2LsVhYjda=}C=*,<ϪBY\/znov2 {u?ԁK?yFs\kTpֶ+}G_l/Ssy@+}C9Qj!e(C*MlPh yEd;Q:`0PY-՗>!͑0O[SHݥfJPrLɐ!Pu@S ( 7G
+;&|SzduG\ VZ\r,KI ʋ")0(B՗[W`J|:鲄8(1R~?RvP)6*[Pzpහ祵eZqWj/{%Y>hΧE-2dD2GuPbsbҥeF:dBϜ0Z<d\rlk#|drlbnիLKEX
+M2DXϚ'rw^XA
+CD?b-S :;ĖN ^;077܎l?ꇽ$LOu6̨YnGKQc'7@EX˿^Yno ogkg[[-<}وC2wϙ;ͭ>kzᏓq{|%6<wNo&Y> 7L(⣒
+ MZu|u~Cʚ(iW MxWl̝w퓯>ysqMd-ck;^($ `紨7BBxS瘃1l3ڢ>lkӽV6~G0x a'|_}zȤ葞w8xgFLzfcx5U{>HgDd8 eA5Abq!A$ VWNnuŻQitL|B?(34>4CJO ֥@wb;$ʋ剑)y{qhO@ ` ;B'u0-
+|F2ME*a! UZ/uu\ֺe:,u@JCaHS:MWLL?:=&LK `sec[-nY}Z'{oh+!F4(ecUhEŪAeHg*A+*`-g:R2G0 pC`;$ķN?,lzEn w ;w|@XyC|(@n0W &E0+: Ph_osN}߾s golӷaukΞ=}.
+|7GT{OS!ֶɾ~|[Veۛ@s0,-@XVLvV"\a!XX<WQq~L+cRda׼Bصa_vA_BK
+ƄˆeE3ZTfA8V-jBXÚmIRLj KSF)E|"
+_XX4@@vJp9E~p
+tGӘ뙈ƔlP&^Y0ghfY/,[Cup`76xIfH/|DnJ
+X#/!yg󪮍eKe:^٤,T7#C+Q1'0<rSOǵ&qt>,mduN&qBaD</Ӹ%ۘG)/fwi[Wi5xqùҎ.y폠.u„ 9P~0 cz- 9Aehj!G,7E.1Z۸gzMx.!{̃]HמK8;
+uP{@SsPz0oT sjخFAhw>! Lb-=S" 0 %B8\xL+%7v_7EL/Ė@0/-ZqA
+j|q)TCAjMظ>]&!4qʪVE,Uꣲ~dEU)++&EfD#"_e\~-[2bcIH'jS#dU:Uդ՘:YX` Y3 URs}ߨ=2)ˋ5\E#OgEVU
+aV45"TEcΧ*p,6Xұ'kgNaij̍Ňk{P7hz?Gg:qѼӴ8r?ο?+~:plو;pT3+ p6uaǻ{%,5Yҳ') }kg!~%yGhX!<Xs%fc/O~L#jNg}bTFH,_"Xtl`Ʒ>O9l
+tœ^wAA*3 /SiVޭ@5KK/V,(C
+qAh<*hm &ChƷBK
+?M@:B!tE8+iDhƣP+*;
+{KMT8@zsjO~H#1r%c[RvyyQM]SW7uS]72CƫC 8!^}lN(FX
+a8/Fa!U~%!;_[?}W|>\zۦ'vN}~zhN!'<x_s(=jq{q=0˵BWژ|2.W\pgwN NGU$G\5hP⑹ަl@_ɏnp;w]xA*b3Rt=ҡG`\@9P Μ߂c4SJB*;"M0r!/+C
+%鯆 G;G5|BӲR,is%ulq^y[CS[pb֞X+,pquGn)C'TLەJDK>[
+tgGKeKEJH4()^#M4K s+ r*,uhV GկMj-wC$NQDo$5O1|^ &t.$ 񜞈12F-X'Ik]xnIЏ%QUF&\TVxd&WV1X{oiR̉Ǔ*QI|y1EVfQ\?*d\(73?OOvnMYO仛;sWߠRپ,\'i(?tipSp[}[$[6)$!0:f#4|&3t:I?LLSr]03$ɶ$Y}Rwzi>g}ٷ=i
+WtX~ O<0p5'+[*ЏKȍ<\
+mjPS}<؞D yMۺo .P
+HFGE#QB؈>=" tuM"PJ$Xzk  Nʫ pMBulGoSU!,Uw\v5xB>ެ<Br$8 ))K<Da4 YjpA67d[M_JnZOv6\^20 ]bgdR'yl
+O&Wŕ]EU[fRjFoͨpۖ#&ߨQ0n\IueNWe2mmg5Oɴ?}js<M~bf8m]힥:^%cT>8%%e3[RQfk2kvVuEfBid Vb,{f.g)=?e\I-_աyr}ٱ|t٨w2[֟ƽ"g`HȋDm՘@rinQ:Dl*#Zgs?3~Qckc`aۻ:=ψd
+N{y;{oE"JhsŞ|&`uQU$al2Mݷ4_xxEDƃ-U<OO8&8.Bp9& G+LK.^L
+7&!~|[8<
+>%Ov/ņHX`_qAm EG5Yb@)v
+knz?w~Ƈ'WMt=|Mǹw3޻W/8df:obBEsB2ea*Kb&lRѕ=9#3$l=;\D*hګ=E8&~JOwRva8V$Qdaxw9e[׿f3n_ϩA2r7Um\}\vۜ: |}Jz?Jl%;j Pde(GSպ[͔^
+t<<YS.$j$9]定I%#Bo5lE?MWq ɘ1jj#N4Y@EF1(B^LEDXFK^ce=kHVxI?̄XL@ F. MhYV^:0b!j sڢ >b+2>2kW|lg&I|6'eCoUHM5[15 L(`IJs~6d.T-UQ]*jhUYKX+bDB%fUK\.~m͇ܛ"+ ͵|4'Z%3&>_ݪ {wK;t?Qf 33<f;o):#7bPGFB A
+ (V.Ap9H$!$ysB7a5/5>7 (T])nKv?0_97kH{nRTm'L]N5>5Z_?l >s oX>' xsGOO[ԥ+;4s/5mtג~ױoZM$eѩ3"{8:\Z[u?y6SR/—㵁䁱
+PTj!+z6`qv Yn6ڇ5v[,o6^cԿ'ciDlDaLrwhν[{ƒ`KWmj".":Iѓ!\5xgz5г]U➙n4?+쌕27O
+/dDHA(B ͌3 T9#2*vhHtH
+ƹ3
+M䙖1HB `5o\]
+.OU; uUw5 Whzm;04j& 5^lBISxdB,$ngȑTQ3Uԑr5$Kyibݷ嚦~}oB5y"=,Qd. j#2.%8,OCI1vtW䘒%ira!PlL+q<fF=冩mb!Qda6XwB(r ]dY>WR / 'UJ() h<OS<o:jf;-&X*5K\>kBU<<׆& $l͕&))ECLA#[? +OK8Ded gl(D9xJβXwfNB388Ȓ"+YXC|x>Iǹ YE
+88GB*Jv<ߏs_!5KI~ "R}saq57Ihv jI~b<,74ZϴfnGpE\M <Ԑ,`"ɂCgv`?.4@+_*b`Cy!*3DU-7l<z/#BTYH '3V^,Xg<dq/Y{{N3{&$@ W}!*Vl^@*:d02kcR̾8>THlas6A.m@Ui$F0[]4)ltc}.L+zk}ѕ)@.0NuQk \컾 x Eu2"1VN6<OxU㜂f%DC,OZB4Xv7*adlSꝖu/IN~gX;f5{"Xpx<S**'|*٧ʂ)XѓCe i[M}_73cԙѣ; q9gIlvhΝCsLC~jJ^0v]߽p"_ rGY\EDѱX1k"\WTy̤ɫfF89~FyÖ?坳;pkݫڧy"cx*vER 8>{edܳѷ[]zp@>=C~8pņU;z_ 7|f ]X6p9n
+$xkgk8ssEA7 XxʊGrH1[ilk^vȢ,ԫZ=xju,
+1<"#rRz|hn^"yjZ|HXJ|`ߣKA 37j:{8A_^o8O`~7ϻY{~^H@Բse
+m($0ʹdh;eH)ii"
+D&y%@R;&#PrBl'j+9ӑB٣!R,
+`J"P3.? >wVK:=k%=uvyNJouC5rzqe7}(2$G8Z8'!B3Ks@f* (NBº]WP}Ҵ-ٻEx'[{?<[/jg_y5+.6=ro.oFO||ɋ쎎GG  K=zUFl WS>le-}LïP ]HP$ ,S 3*EvΧ>uw{Qg%g\P;Ax 9hK1]bEritI1A3uIYC@E@\R'/ց,M$֧8'?j RJ+
+IKH_
+cUARQ'd!m,LdT)IJ)]aMtUH@w1P2J@.&Ycz`[FYK獛Se Vq|Aɍ;I,hD\zrik={gloCkTΒ$7L!d8| 3ESфdi83W@$v|!MLt432| 
+X\-\.vN £cq>'1*2Kg1| ax"B.ccbEIY`E4Q&]Y$xEWTS3]!dt*7s{Ɨ*:C=CTWN3mij_گmmӖ oKB-\8kXaEHfXh0ز _@cB#$6M<\Pʻ Gm
+E CHBUsd.+|bHU2+SBTT}N 3NY ^J\/BBzJ$P䗝 WaV0#2_x` @A!w)NT4:a }%r1:wį}TY*Lu6b u"!Q= UП `{.zNLK飓5kQKnb>mFCVQs
+̝pk$|•@7\7&}wvvG,b-39 RI|,|4aCQq>㱕 [Y9IIR+Ij*'Τ<B$X8h-#AKʆ|<WR蛦4cs'/t}\y|,&'gzsGkD[ ?CtIIypVMSO"Rx|Ёޏ 7h.*6#M46nu;|n%o*Ʈj0*3ȱPJ$vP4gTDv\^io@O2'qSSHtGP9Ҙ. V?k<ԟۮֿ@f%1*Ӌ͕Bo"kٔ=5,~[6?<t/2v9#Wc;ÿ~&]8}zn \-tp.p8
+͞J^Ajt֨{5 U<n~^ry!3Hd]ƜYI,K޺}uu
+
+1|k|a{g{ow}3Y-7Ǜ4[zLJȡ!Bp|*_?_漳~T]1cH,RLF;m/Ts3s H:@/iW!xdP   A^ X@LkMs\f^>É)q%%_ o qqAy Cܱ#!lR Pm-6BzDDbL]}ıPy@s
+"*O7s9ӮiT34RD:.dL q5~gvJg2_ˆ +=,i\ɜ)1/%Lzsx6,G<eԫ^-*E$ Qc}lv(L#PR$nԴM"^?.=,"$#ۮE÷_`4+""2Fh
+sYp΄eɦ2妈6r5U;9q6pCy{`މm+S?XVcat㮏1wd/="͈T?sW[&l,ҼTlo5ڎےCi{{o#db*(`Ot7KޛqnM$QɾIVy@*[X)FWZB5Y?\^=_+kuw;7m.z[<H,\!g1|6Jeɻ,٭lS?.ߡ|־N[MyWreؤ>xUwL{N],g3{Jz&Ͼ;2wo;ni:0}U5ULL m!
+W){³5]~to>sU: z zvEOjď1AɏvA(A\e@ZRA%o/\;#
+!E5c]?gf$9]L_ 1dz.2fOM) u0IO*)+54fҤH=MjDQETMd-)9&Щ*-0lqNɲ1 >8c I 9L!&`yBӕdmRsV5k㻖Suן6osSQYN./yɘǙgH_l[KVyl.O9)^!PN2jKJ1l>zb4R@JVm[z6QG eA=-e'^6fr+)L%y'ؽSJ.QE.' 7W*q-4ɒY3dP`QWDw|7vs9 PDa, ,#Q|>#̥x|KKcuo׷9XP֪IM93]PB>+p16XăZ^ = WvSM?lm+l+zy~=V<e>G%B2 !u%(qaC/%RV\xo(- Λڋ
+ czۛ?_f|6vLt={L(H{Pe kv:(cՆd%-v"}f~0Qh<_+T^h, !I/1h ^i&.O|-xl; :ٷL`M؆ɐg)gtb&TH R5B>˜qpuXhJ Ky  URD,VUN V<yGʑ*VY.ER.-ú2,&K5YS
+jPƝr0 ^2ˮhƻjǣ4[%r]AQ_{ eee@A+m4f4W0N9T&mM'tt̴M31u&5 (8!aQbc/Qyk{aRl<1A"gpj
+n;_|G*s1:5
+bYSs՗XYB"\/,:GfiN4f#za
+^9<'@] 馘 `='@`UP+g
+rP 4X@Es.kpw4\i  =
+3&(k2sDdg%>D>9\]aU@CNZ-p_k]73y mɆn%T,GKأWwZSU^^pE)(-@x鮘/$L!L
+d5Tޚȝm{o߿I]C$^IC!oIf}^۹O?hUcmʘ4ţy"PuRhYDOP^Oo1+s$#"  ?iKZЌ*dc-8sQ5gdg&D "[)i(r*零!F:@c$lf
+< !a1iÏ\D̎0!CihH"T,\tze-|8MhN\;7گ [3FE+v_hkIm6Ͼ>>u7_KCME%F'R[@O.ņ,lA`AoYpa[ٶRc@^ܲ/,F cWơ\)BpCtJ%bb
+4P!%*.Ȼb=}+kYS#*BGHO~`,xP&>l.T|e} ]NTH*G~s0 s r"ĉ꯲ ?]_w,{}& K âvG '4.dj IH
+r-ckòbcPuL]HB
+x&,+҇ cRB7&4gi༽T?iqزّ3gUϺ`UP^^aZkx 8dxW yܔwϩN<m14uWH5bGΖ!ǹ'%xMR\drh &M4\s%ў/&D -#%+z<VC0tJ%).dy|Mz>2D
+.&EI>2ߜ-hsQ ]DQhVOv9ipXݹv ۗ8\r}kJvs$Rxu/8w/PqfuPӨ^^,Cl"c% bsvDnrS־v~mJnnX}Ό]=b!D|7}3mkviG9k6hĥb'}#gLCXfy$16Lt7F_\aU;typp,ymd ,{ M +B I)t2thi4)LS2nLc#l`KZɲ%a[~vmZltbv嘁Mv>ioxݪg k=ih41FϽ^V X$nzÐ`1  ? 5/ Ic,TLL/[VʉȐ`}.c>P
+ ÉiNjOʰag"@@$y0 H![LB/IT sX4l&cCUQ <o?l,l)lv5Jp+jåzyT~x<#8LK?.}^SfN@(1N(L^<^eAݩ- ]uUcvӉuVV i̝6LZ%Sq<\MOW1P J+絜/kE+܁:h`;P1%"$#"LFoȮ5Y0LXʰ<@p^uHj.!2
+/qrevQгʽԊPEM ET)#uEʒzByVOXAgϒ$65BȔ~Ɓp5I"!2 D9[[x J{֥ckXU1ڶ@fl>gWI5U[xF?\7} ux-G E;#W2P~_}~z~7e @/ E
+6i\V
+!3+"8c%Ed:70)s$ˆ
+v9A/%(,VNia<jbMЕAkՏtUQ7S)Iڙ.Ȃ8xڨҸ(MyfDH ϻȷiJG89't77}tlFaB$<<>6|;X6WuG -7}̇^O>5_{o\[!iOpY*?O&<paugMT`_9aׁ?'#hq*5#'Zk,k$*mP=znzEKKN@6`+lsqLuf! 7h9LK'n ZXbǎZLh-oN)ى퍊P+W 8a
+i!.H&'@0#:"lrq*£EW@hIHo ZeyFW)liW[5cK"T 3RI$%sdLA]3bEqƆɆ_؛)3M]4K*ēvhn_8Rl3b e 0fDLѫ!}QmȣdKTAJɩ<3EG v<@4̲xSA)s8, VfFU13&2}F1C~UtNL&Q)1)L'a#!"{R2%q(>g9 C3}!8$>DWӦvJ!CɈ=)y`XucCē4GXewc4un{I0L nnlu><3Kt(T4^8KMOO TLf*ꀞQ'H9C⿊FT2h>wqhK<eV1C_="Dc䳓|X];5N̶'R g:OLuvr(RS>'sJ TBf̡~lZv{N4TPx CZ3ȵA-펺ʧ/l[Np)%i5E "$GS44 A0$RtpfN!B&Tz<h6]"T
+rv$E),(%Qn]>"S\)a 𵩘Z-rg"{N.
+\XjLU Ok1 TTYDohUQ)6ˆR(Q+pEQzUAŰL}Ki Zw?3^Q+\j|Aj 9yk#w?l}O5;'޸tW.\~vSW$Bc^W܉BْE됸9pH&b#ոHn)lyBo[" p"F?+&5Fz;"k;3;KŶ!FI|_A1[%!@p:<-'d%BPvXg6ڄ $>ȁ6!:\~` 2@n$49T! )BBxI'ȭ:!F\@}@gUkohhhs@@@gꮯQ_59駭o#.+,SMB+g)k2@ȃПՉC1<xh-oe!h!-:'OC]Z%N\ApT[m A5V k,.xKNf}5e5=VoN H͋: •Wa#{5E# .6meUHf"H[/i%ꂚKo|oVTi+r"aeJv(#srnh( 0NB 6m{q?| BqoweJ_;zo| Bwyw6p.HW`еj^h4N"ǂ< y"])=Z[\Ϩ9qBC<KUF5.^qr"l餪biûu>|77liNn|yEp)_?bZg;MjwH+el?zh[4\d0C˿oםM_L9ksG#.O1%"\BV(UeJ@~FJBd2d1nI0s%J T*Iqʁp!{RÏ(%;*x1)<ч@jPĶ<^ۇ<hC_ތC KτKq@i+"vZ x ([`.[4/tK&=g>٣ò>\R[_a6cq2JG ņKb4FM0uB: ԎhLۢ˲8Cb@4ӥKG/+|jc׹_WSϽ羷Oݩ?ڑvj- {1xkK K~|x#ARPlC`G^⧙Mꋿ &
+Lc*Bu17kd}$04WE+p'"P 0+\lۜnΔ(.*"0Tv@J릫j*(Zjрy&^*T+d: ;dq6tңq_0٢D;6@]}矼{&ULa%%MdXk1 PodhZ*HY&>?ϯ;Nĉ<h@PT薱u[QjMU1!MhUtckIBB4ڄB;~?cl>~?7Q~?Ο7jB‚&6NbLTBx_F:kN~[]GJR3JpܠZ%jO پG#¯sUkm9a"TLZcݼ=]y)dW&qM>$]y Ȏ
+2:
+ⅮW~ͫ<Pe.)e2&֕A*.Se*bBER!*P֫GʼnJWgB e612>Da$<&;R׷>3~ }7.u'[zʚʱ]㉿=]oL wt]"7$.etH}!EeB7^1ʃPclaR]JlPaLjcC`lC`#Qu0eC)52YmU]H}` slPߺ 7`0:? T`Cl@^?TfC !u)~Py ɭ Ϥ!O C( sȆ5Ʊ,_~?ǰƽ\0z*|P{eӯ{/N_E]ؕ~Ǚ>$`iH=zr}yf'4DbyH+6 SVYnaTRʆ+nvS)[!T[H[wn򞑞.H$X:lR/m?nxja#fJѝ:%SyEԚsdHk.d֑k \s.dr.JҊ.^ބ5ٽ;"ZWgK$s55jBw], <E 7T
+ʴL<_ 0P%X{lU>ek9ѪO䡌VK$kUZ]Dz̿.f'n-<$&zd2gᅅM c'oӴ[$]"r2[5Y!{·إY#dA-IVqnh@¤N)eysl5q6kq}{_|i-ۏ:6;M9^p7sZ[O5H}+kz+gwyz3÷O]626clM촹<i(/ gRJ/='~&]K; \G#as#5V-WG9<AB%ȈP"Š/SG)(U
+Mp@ ̠ X; _;vʖNrCxV<^NrKn̑킁Ö;^ŝT|!=MA Hg3[YXnϤOM;U_&ů'`'4u_Dwk (D(BF~ })U|װ滪}[91id$ِ%q:{9wPL|K0@϶^yvMx/??s~ϟ螸v % \ffle2a:]>Ms[u;_qwk``SY휹wl
+HZrDsy2o+[y{iGJ㯽6?ěX6L`ɤt;nĜmUږ`!^[ѱf<DX[ t eQsН((iLNG\u@4XMĹz1"s6 h-ŦhܚQo}ĸcirrhhν/$(8 ~E͂3/F<L%TUR%I$FɅiJ
+ճ]tH쮚([*dxQ)'%xP R)Q
+4F\cMW(Ae
+֣"麀Z.4Xnf!804[!e
+OM<G&C՞8b-oz-lyPptH+ !1 w܌q&δө&NILc=qgҩLJ[vm|b|ל$N@B}]U;ofW%uѮu( "憵+O4tn'_{/8w̓'{tW"/AWB( B|ABj
+/a$PGR(:P D<+A7P'5Oy< H=[Gi\%5}HDQ qDgOBVO:9j-Js@jTA_0GR^փz KK $T}ು߾yнrO#qхn^z›=aڣ Z1穚W?CLtIhZxVgI fZ#\rXmܣ)qOF"҉eiB_WBУ;~7oU mGF
+h:{E%X"e<<#6G`H5a>5&rlnPGw17!aVRӌ wЧ*L >emyUVdi:̞ 0=4WZZ=,l k1[C_5)bmhV'%PQ:b< 8M GH+, =d,kaXh:dhOk]m޽w@2V]fVʔ&p=ٺ̭-jYKhP$
+a VE-$YT*_s|ZY{\h%_w/*Oٖ.'Q/jlɅVAA[絤vbc2 "AEu{K߿?uRm_y!x4vʅ4>npDh{
+?8D4HhPj!K 1 ? B ѓXp:`*AWZx[>Bl?l@áһٝ@J"ܦ١B@P#DŽq@OgK0J;CA"@Fyۿ<@ e7VvɯOxw :? wFv _WÏmZxh,zsS:L:X߭S,v-q=׎긞&WCkjnM9젏1;Cqs
+VZ+I6rn::mt;[| "|A43% 7Tz ʮD%P֤=BM6|]- We30bߨۜy[X
+Q@qRIbNfFc2m얂E4[X\}U>-tS֭k;*'Í{{FӧQ/E
+\_gV+5
+`Dd,/W\Yx.TU-hXm\sH[hgyi4/GDyʴYT=khœ9uх67Y2_# ktsi W\Vǝ9 ә3\ eTC.sz8efD34!D2S]$t[Min͙ƄoƸ\]܍#"i
+(B|>r=R#jUK[jk2{V>J*..:'.oR% ֕W6OI̓c<K{W~΁-:#tG*؃ޗ.yqHI}*zTY髇:ˣ?`肺XQ`tEm@:ZFLa.+Zi漁aDNjէ
+ Fj_lܺп߹3KO|r-c81=cHBJq$(RUҤ
+RF64&-QZJԸ@H!1^|Y}ή;oA|5y3+ID~-δMOziܗ6KWR&i(kzI$eJp1VS͍pAvBZf$6ұ}bh,-
+ӜEZ ՖAu wmjoOy1Z(lCJZVdadFLZ8:jkŌ.X6Biԍ8vMVMa֗vp)Ʈ?sߝaw^D{.Wj5HpF<9<$U`ŢF+;Ib=%f
+"a.[ׄr-$u((Tytg C-bITX/MkZ[0UabUa
+)ݗ. uZfḰwB_isZԫ\bD{3zȮi(3u-^1BNr@_g忘D-*12Se 7S;S/isGTUmH!k.)A#kT:JI:
+$Ȏ55Zx 8R3B*f~k1sCUg"Ƭ.𖶐:/"w)^o̗NP 㒩n,Ȱd&K6yBr;7",|K|-GTdG:9zL<NH'@݈oAorܐ%~lW) >٧*FpjpjBCjHWy>?{Fʉ}|ꝿ~#7];Vj֪ZpAe2?ioy ϛ|Ij,ʅ(l|-;>`p"%Jz46I4ŭ2 \y'-?PHJ(_Lb8_KM0Vգ
+:Qt4H𲔙 qq{8lk"fծ V6['+Qvo^a>hXXh:Y"mOi4ɖZeabkyZV(Qp#m5\s=%r s!xўk|~p:阹 5]aoizak#
+[6CAwɴiG y5rќnRn ;:^h+4lk[`. `zee@}
+"yݔN- GM,7g[ʻ|!RZ!%R"*`x>3珟FG2f,Kf:'Τ앹\}lp08;0c 8kI֤I쮙,YYv:mjѦmN4mu5{Q%Z8V/]=`7Il>1jq?='myp%O)E2J'IX3AR#aRfX>ںJ|EK`0,B55TTdF!&ep>o'V
+5`^ؾе(3n7ntw?=99քwak:/n\<!*KUtVﴸF7Ɨ+-Nj o~S¹u8t݇S-uK{,.j[{̓/J%n%$"JO9ز
+T<I0CVi,!Q4 $h@tl9k} PP\XXy*wexۜt> ? ?u6
+C1[ J,w$'BEuOR#O5Ǧ)-#D8٩m$ DnrpA9nF6E} ځ? *A@ߎ٨!Ԟ[07.9V7Q]
+}^\bAF" `Q_z1~`{:qbbܞn[h@7ȗ
+M0}*/r,wR۾aneٮlU8]TVCQ
+:Zs$#r2hH{eDmI#/u`#=:^!QkfU
+B \
+dkp(
+j\%
++HS& 3d&zd@T,Xgb.Zm-9
+ѯ}|A-C]t ,5EBޖ+1L^ܶwzyD<Au`~Ȑ /MƢ (`%]CÈ"%xA$5a I R(/1[WM\[W[Ϲwܱe;oucމ>yG/srNەW.X*n8T
+9YU鋕 7j<tj4WۯWc篎 'BjTAp`.x}E7dstw
+eQ}
+_!AëdU(>6
+y_#tXw!4dxxzQ/Sw :|:]7oM>j]CtNOWf,0`' /X$DM)[ k[Y3jWYԾX^=}OIO}!_>oŅ5&ZM4֤ F55K1K=U?ޢq
+w~
+YN#}K3|n{HjV!SISyxuA^k=e0ʪ%i
+WR8P4M+|(t`Nu9,Av)Gam.*צð>FIxR0@Y4͂PJ'KZQv 2C1&ӂ х[g&{ngw~2w %G<e <|سyfNj߿xr[W>ݾwޜ;Cu/?ڹ{ᶦ;="qu0qI;8! ?:;hq(UDtQζeR:EiF^ 3xЍ`?Tylgp_c;vĉGҤfZXK$ZJbLnR4$44Ц!@mhͦM5W;W}M'ۉo;7yd^B ^3lL,dX⃶y A73Ϸ%}6h@~@!*32 v3ݲtb&)JBXQ<Mt*A(pb"q@5 #y=TN:ȍx|q#2!0vπ?AZl=F6Gbc CP+AFUeв}kFPWs!gP39^[=~Kߺ1xC3l@I FۏyɗQdOoc\H._ת:o~;F/U^7H6I&W]^w-ӊpO`|".
+2ZaGBXE _REVZ9.ܚQVlI`_d}C6$җo/Do.ŚJx"%ueHVi\?ֈyrU3]wJ_󚬹JWbHܨ4˼yhI`"SiG,%I>=ue'+{kv;ժpgwktQ G(*O-7OQ{ēnd|m~$u?$\Sʗ
+Ɉޕr=ftf;"%& 9)عHnA>O%b7-[)H.\ykcwr ~ O VB $kJKT#AY}7h@$elRO_SRMEL_\%}!\b))٢־pJ_X2H}i4S邤\\Q$ftP󮖞)ɱs;wv?6w~/wo}޾}oOM|SXj0uN1"i#n工5JʶaƆ!A{?ǐ)66Ҙ:ՃLA[ ɡ̊5کmn rr)?էhIuvN%ϖێةCV{
+mY" :Xmɐ ٱܩBD
+5aׁ
+瘅Ȯض;ࢨe>$[dqA6M4hnYeVdKð  5n
+lCӦIcI[iVqؖDEɇ,YuP'I4>4/H>>~4u>Xޡò0Kjǜp0ph.`%!-d2Rgg͎~ըd -L\6D
+;[QՏ #Ef`h+*TXȅ`'*呢U([ hkX/W<AN9&6"#ZQ-AF?@sC4ޫK̚h]@|oڻxw`%]oAaߞU[fv4}|s@{+Oa
+E0zAj @fsan-3x@#
+ *qWQ^"q;{_l͈֊
+{>2,&Cr{!pU(_k_}̑?q~shѴUe EUVFŚrM*3QaKqXǐ>:!(eF2'/eĪDW\;DWEJTV+pQiB,-h[b~W&Er a%/9l-۽M&E6_Uwh? 7_qq[9[h
+ h(oKw n !${GC<}̎ j}Ky]"Rα[uLNkqc;}wDuTA,Yeqt]ssǍD
+ȩ PzG{[zme9Mr{aG?_r~$Q?7~hqt% x}uyO|ɟ'ͭN/xxT'7*+bTSGBʨh
+bXw"f3`C"arX ea#zD)[+G:|6R˛zC`Tj&'?H콱ч<ٱ'9{+׏1&2Sٲ4nV6m`ѫDVelQFpQB1Fɧ(ڶ(c ?&4RAIr ;Ty+K:*eBp16a#b+nxvjIUڢع1Z빬}:*AjHk`"lF2Ы
+U/ {!L`'#"%4t+䱷z>4w/"!dvOL
+XR_Ģ.ѵRFdBZk8e@6D$LRgM߯pʨ,Rѐ3ͤn`X|i ZD6$*ddH`̢Z!XRC˔NCr~Rh5׎{ݻgf__kKxŗ^fK<p`scs}=Ig>bLgB{݅<|?^|{}'.7z}JZq_N/8zq*-qj-QsRTHJiT"ZV":]ԀHpJ'͑@{=lŠ*=Hgt<#Atz}zI٘"IS-9J7>6@@fF"СMB/C)V Zs!52TUqS?(ri @
+V4 big_WSXpuA- C F @'5wt3n
+¼~Phgmk#)1V0ZNk!g~a\hBmOۈlHHbi|
+[AA*""+=𯮨_{z쥥zm;]wnyşCc#a̦N`ƞ|QOl57H5i'Ƙ 6ggf=rf%[UX*/V Q(,qO|}~|כd*o17d7Ḹ@fR"s/νٮ6:}~qtmPkdTZhBMLBh`JV)JJҖk6iN$~w>ܙV={~9rΟgb+3(MH"<̍X
+qT .0Bp \U0.^C9m0t@"){_ƛž޹K#A33C@m_x10ܟnd%*RuB9RcTh!-'Esa=rd"V]'tOjv5UC`4;"UJ{|%oёU|QT =ֹGR;OmL^W[dבj]:$aWOۃSs:4^ǧkkoAd@YzLt#,3S5".'&bǴS=F#㟏mk7ξ](]m%!^)L@ؾg/f@O<m@ !%D/avnd^HZv2)lF>O4H(*hdzĥ]ޛZ3J=gU6y<knbzܠR,hΨ"N an^|Դp".a@'k }hZq
+rd"dje17=/6pv_{BObɆz_#~^8Z.R?u;?L8klW3v||$ql5D2kaC4P^f+yX%imo4 զ PWq] ]o_o<p>w?m>9 {<ɆU'6X.s} 9TX jU*r`ɀ/V/-boM%A*=|`@dIlX(Lۏy5+0y-lA.j=ɦeHVjRaKf='HgK&͚,$+q`ݱo~qx{>w M{؎6g?p' JOd>}:solS_x\p8`z%t~f5 sM0X'E`qMBЁyeB
+p1\(5(FKP-uGOAy(!6[2*rT3Q 5Z:fMoVi 2%H^*t#5"tjU{˴i=X3zh&[q)OAmGC;JS]D%8$[BiQv t(uĦ{Lh5nf;se>[N農n|iDq3Og͡]qRawޕ}k(<3ţK֏4==73}[y'O]#zR1KXw%fff`-r,uHdwRDAQ |5;
+0iPj !m1b_ [}u) /ypcna*jREu9PP<(UR
+ԳVN0HRota<‡
+KwAt쪢Vjտ*+Խh94P% |GǎΌ<Q@Wo;f8]MSQߌiqMˈT-4W0WSA]OdߦQ^c>-G5Pk~@zP~9<(^P^8:~ Qi Rg2-|/]Q`=*z :|Fk`0-6J@aUHys:uD9@(A5au"kbcP~놫aJ \#K`JjJݟ?Xv~w;o~vo;^,ӥQ^ԓ9,Q&ɤTL e>k@cY>kjyv3ۊ&&ʓDkoŻzod[8|p롾=y!~G7w.fe0nR/m
+"O Ш X( .\Z-[@*9R+tY$`{b~'8r+g}Rę)mN7 'So/;vDzV@<bk֣7UUj&⸅jq|'@ZF'Uـ̒j4A
+(\q$^Rs #T
+C.9BJ:n$*eG
+)
+ HjhYpbH4bЀ<!ؤW+DJl*fK
+NIDX)֤hQ_ȌIt쏲U(!Dfq3ήV >#U܊-qFN<qh ٕH W>:2~|~d ??' ~N}(v>]~M ZX*V3y)RJ~nc d3(КW!q1?K`٢D.HH9*p\&,u dȁ@
+BhP-Jx^#ah~ ЪI,BR2"2"KfsvPn]<=(7n?Yk<3ia*@C]=M\iBivcc(8J~ؽ*ۣIjiQ.˾(}&{k{#]"쑎fa-l~z C+q} HIa7^s/vߙ῝</r@_f^^9_uMw_꜊v)|&hYE8a,&LY >ф^܂-8F҈_Dΰ׺-X5K%0P݀+6s.[jތU2̖m ]71cMӸ'̵XM^VH,oEY֒-OV b!HԅĀ6ďB\Havߛy=cv1S(^Zw#NC040XD. ؑAXMUNHAM7v/iKz6x!Lx@y!PՀi\!L04͔VS/ xDGjºahuD\L}Ëtv+b%:pSy);eKȴ%iϱ~n(lPڔ]w!d4Y*(nfyHukɏ8OE$zׂJv3aN:܁m6[i6fmGUmGNc+
+wU;j,7Y(f"HdpssOLФ%<8pZT2MdN>{KN#~rnaҷ_+w?  7J@%A %*@Jh5E)
+C*EGυz5PUȠ
+%2h`*p8-߀a0 a>tigcʋIZo.G^|!x|qt5h}{׌(tL9Vk;0r.{ַʋy\}lp/BBCFV
+AhiJIMӤl4IӶ"1
+ijE,Pbe7$HaIoDq)4G-3glKQZik-7?D;j|M7h;Aw}\/'%X(;'B\odo, #ϊ>~&Jd"\w3·u[nabs,p즺uxҎڤ,dCܩlU,H/"WҋU Ȯ.9nh+̩`T551l,ź~jʸ\[5&!1M(duP#%BFqSPohԯ#;uQꓤfX@I.*nZ'6QykJaRyHǏrMTnnŸotZy0WFʼnnÖ}+!fa RF ⃷?< L/|k7u6!Ko>47G:s*MeDvo5S#K㥫sDJ'qGBnA=M8ײ%0@2*'{"C<B D|KdjP!*@*a--B0˨PCS+Jzqj:fZ= IVL5СVh*Kӊč@ىEN4d㒅K.4\fB_Sz~NVh(vq1HVP>L(z<"@AqX6_BHy@ bC°r>#5ܯm~$~|}gտxu@+~ߝΙ_gn/i9LvLа#]8nRjj
+.4AyɊCi"ô"k{KJFGB7Ľ|aeP߅^n쑄*8{Ѧ Y,U?r&hA2Q=xG x-UvbJ_W*5LxaʩJ>⺖1y@~{BzW-TP$ɴf`t"Ke5.Q⃜t`WHzmcns.M] FyiTWNM+h-ڸ@lS YcTaa
+#"9'Ò[{i-7wcll@: h`D`*f8nO Al,
+nG`g $ԯ5IH$.42\e@ȌᇽZRRŹ q78Ѷ]YQ.4ʙns9fMw/g] [19VžՌd/LMCM>|ًf-02Lmm#6?ZH]tLz:~\u3wH=ň(VTWs Rd=uf_Xni]ȓ{`\o+HSm)e姽wVl@Y6^_g*p{uȑd;SJ}p#Qs *'\KLG}p>Rߵ{EzzBq5ŵ3;uto#,Fw63s=+(nͷK̯.ϘW6{<ef6tRr1~u8aĒFCEWRKDKeXt#Ud{ťN.='U{te|8@64YV,Zr˂e;}N6j)Z6ܢ懛&Er jq+ ,UA !
+ >`a 5&;}߶eYنp+Bi;-tRN2?04IaZ&Si 5$  )vl HZY,YV>޾c;FUfh`J%6s\
+n;Ӕ|p,tTxm!Թ Ǥa{&trVLK]y
+2 J#X6 8TlGp,2*Kfbx`C9,&FR Uu&P
+'y˖uE!$łGR!̄tI9D0/}TPXwZ%L+/A|'"%Naqn}"X\NEx^$5(,"1+ki"098 &b^?k8i;͍9d=زQum|}~CU;\7pvmqCʽYK=kU`OvG+.DVJMBMm6M̱A*5R<9 @!B>FLIEAn%xN- iʰ(!"(eB*:lr:,H
+KR߱TE)ē܇.1e=#TUUCe%dP#/!xIuW+ih]&73E&,؄ ⑬<4afv:noDLVΫ D&xXrDvv=5MmZ<8dtm0ܹίctцsd9d&+B."L32e {>1P\\9Cx=/Zr,F-[s/tYA4 \93rRgں=Vk,6p3ŵ7U݈dX
+8+.DD%X&98ߐY҈߮1pmWH b(JqH H"ct.BQ*"!DWYK"5PL&$FV!2/#؎HyM\vݧ.lюlnuf9d^Pi:Xa90n oteM7@;@FT dI_ȧ&j Fˍ@zM<*kg<$}PWMg@]!H^D:ZnG+&<jiY:𬴞V,jWIˎO@+cjhgMh':֮QuboOHMx<]P
+pJ ZkJ9g{N:}W8p֏he@/N=/_:{/ۿy-]׵ѯ.^TMsdCpA%j'i36N7&kJW$z .MxSlшuznL>J?]х?k|4 UheOzR-7cP2|шSosi36pI
+N1A)tM,\dgT/B kl8sVt6 ZX/P*gSS(2ĂeB\Yta DlN0i+X,z
+\ߖÑʿV +ŪR'sDz <$/e<b*Y4#hˤ2%(sqh֗"lǺ~Uk
+3*t9K)hE /VԐKO28WJ0,NCj\ylSpv;>"P8
+ڦND'QؐN+*: mh+t HXJF\|>~/W;sV+$Gv((*ȪBJODѡPUNu`\Kd,-)T% $r&“b/{xlGl/`zB:;%%Dbv$*,|/`<EwyV;wAR^:Qs^s {գb閞}:찟z=E67<^'mgbG\'% fEv8}ij'Ty*)I$iSciGU *X1 ,!- (+C+QgAec%k9fS*'+&Y-*H-Bǎnno86&[d+Ϝ
+;xnLpqr=If_O|;}Ns.<=#'xwu}?9}Ccg}<|wWթ7rF)c؊oGnLG'b^mډM䣈3!DL !
+{:;_)+uʩ-4,)dL[Ω聪GtqJC%HUɊr0%%|r'g- |g2ml aɆ8T,m8`p`JJ`^ '''gR`Aqb饶Q۵}hwͭ/v=Z+ [JB ,IL, gB,q2+c!K.Co:W\vv]蕶[>W?w=xLRn5 l];֜. ˎ&/,5$+M3U3n H5"&b+b4dmC%M)D# qtŚiш!u8'j,O?;[/=Bj"uAmO֕ʹ֜KizajZڬ%wUQFb(@ ^p1P5zljDCV:sqKFPWVmƻ]a]u>ӂ*pkt;>\?zRj "W_芨^Ł0aW;ΪvLY@`Mb >VDZW }賀= &U@v5Z@~+"}^hԅ JPƃ`js20FdנeC^S\]z:V$'sWtYފѹ@[m^FL@4Z6Wo(vȾ0KGo/wxoΞo?;=}cD_mz^̅#6]D>lx).:e6};Î-G+*E?~'h x`D K;XYQGtB'ya5͔,r%p|1= 7 |/C#;=#]rdKZ
+rwȱ& Lsb-()˨}H3]hB&&/Ҵ)3Q$tUoe)^@C4T ĵ)|gu!ÙpI5ێDBdP4aR+ Q ϒē $,jfw.8 k{>.j{.S~!n`[vӴyՀXi-Wi e6':
+J<T!,B˔IaPk2TAUtWqiDJ pt#b*3/TZ(6B?KitGJ*d*Ml1gU7ύ9C6Me86!MfT2,f6D1Neq&;5hD>ϡ,lT{n C*;%"Dmћ%P-2<C K<3 ?{Ӹ<{Z^P<uK>}V;濉l5Eo~[m?=pvqs׽8]Mgֵ-ɖ%˒%26`äNBc LM6|HI۴cLI-%Ӥ3Ę11ta[{wZI}ߍt?Y4~ω]9Nt<9HOe!hYzi(iTD2A9BA E0[>pu]XS]`Thj-נI6P XQ' va [&91°R-=(f<Bp1A
+J "[\g+{- &n]o0bazsjdmFm*tjρG@*Y`gs5CĽ=BAB-)we;w3c\r:-lnWv9+;?;?Ow4֡Cޡ7x#_}{y6ha"YEM:Dl7檴Ah :m5V1e#'#4 @̏5Bfq8\8 ~=i%Nʫ:E%+|=ꣃt jMHɋ8(/+Ld[aGm;yOJ#NU+mZ/~XT
+WyqʀiG&6&gZI2jք&4H 1N eAnlǒoƖ{ԓ-ꉼ]4iDOWK:eT=M =/70үxpqx}gv>ir33}]|xo<yr^OnD{qƋgv4$rQ $^OSxN-mO "l`]5\snt픟wcG#uÙ멇wQs̻(,Ϝ~푥e.
+:-n'|+/~)`T^p[E;qOٔ͋_]˙>}$ݢNǕ
+ϡaXr59@SP2j}p5 ԮltMs
+)A+LVz&8; +3Nk}=N}30<~l Dž;4Ȋ `}ϖ~w_;wxaKAGruq ۦ\&%} m/_L8R=懞x%WY6'BrC$7-TN +Md`dRJ] 7Yܩ%UBY%H
+S=E00a~~E8pMSS c+iDJrg b/ʉ26y &RVtE :_l6m\EA,eZ m`K!0WƦg,)^W̚[6%IɻX9^"^M;yi.`QxWȻ厬W֑gԴRʪ-93i5W9TMKdU⊑:e 3|D5dBٜ_LĜ˜b-DD`F"2eBä +.*P
+M2R`@dܞIIiy>_+OLjMMeF O}>=;uYO.!.Mֈ[w ɖ}ZkԹ:jڃhrJ<0o:aiS"S
+^JQUłHAq<OdQC2µgrIH.Y'liv=:.cm?;"zgꎶuInO1=W;^vMuv^}mF<Ҟ1B^a'|dus+^B[bS~_ѫ^<K(քJf0tiq1,V%R<H HF"(0(ᰯE5ʱ)*2T UXM=+UJ%N]^=F4N5`1R/:6QJ#'#PZ 5cI>U :}uM'p^Dk.Pft`s$ԞJkA̛c#/uu:VʻV%K$K-K61`re
+kBH´4tڴ4tZhe24fBt!)6 |Hֱ]򪻊&;}I|3Jo϶Bv;il<um.-Y(ލXc] ;tk7o}k;{odo7pO_[?sa9N?n 1-MhނN5KI*0 bnEE N4WITtEEjQ3|B}Z"qob2b8g ]
+Q2.$QDB>.9ؤᒂVpFU޲JUQL!H&QUBhOI4rVJoY[Ii+z/a_F %!) @+
+eyJ
+.ER_1R$}r>=/>JԹhIT-ҍy()QR~UDj}MpM~P|0L:EI+S-"Qrkl54im\VzHe7Q**7 _}5}O_Nm?"IDS߬նpef}dqv6̎u=) r*(: jQwp[)!1ƽe7Z?BD&9+a%Μ (!ou;,
+=_<1vUڻॳQ9+VV09%t4eBlgQ 5W52EFXv9f^0D=aʉdgaK2W-.kY K@a-Ee&
+j3)@Gi#VY0
+qpqY+,PQaY
+thЪ폲?*Mk;ǴVV6MH@@a(YFbu>^yGQy<!`Z.gz-I{v)i%JFl{Z3B+StІ뷄a'7ABʍ b4g0h9aq$@.)=>WtD#_Lױ8T [ HU*
+b|`AfLi;iOѵD9]C^SݓRF[[=yOC*렐=z(Q|!:^X 76v&70Cr7Mbwq3;?{||9:qG8|kMGi;8QUӗf?;ʳQi
+K #ñ>rm5Xt7m\y};S(1<~IGF ۸~i c6-V3*t^;O(׎89R|TUp*vN4[C9-5+1rdSVc,i<?ab;BS:{=KnSV^rmZ\w/[+ J<ϫS*lf\>Ldfzֺ7n*oRZzZJ4)8(HjfI{]ilTkwHHf]AtkBFFJT]ە(uON}HyQBkuڮwԗTS2ƁAy'(֞xJTvU&oeRkkAWLaSL.o.̾ӹL]xjqAj\0m› +ã춅{6dYѭF0VsS%=-ֱ xbFv7:ԫBkE|;sg
+MgJS#Ji6hn L</4cCMgv̯馆W-dРfYvӈ%k<GReHf&V|ek.lg+EZS+˥%tp!i7J UI,Ʉ 7q#m fM֟gZtx!)$(D
+Z0MMzysmd;0h qAxv]4Aj?ztfItK!;)DVX<kqY'0.іwLND7RXLf Mqw-/BM&P3y jy<vk`Eg ,[2uXg\e\U];z9$N?Ü'_D{4c<tjW{vEϳc[Qo_){^}" zBcɏe(p]Q&A& oNNI-kϩPRfUZ1V!`$I1R:P"5r3U98su #범4
+@`=)JP'(QE
+PG*O ;빑* # B4#YHyJ/9u Xg*@ݘu%Z>OP. BwV= 4H#ǀk2O?ߙþW>sϽ<{շ.ؿ6|qvǥ'1Rنx$hq@ۑ
+jq
+'?!*&;7(Yy+=):8c-̣͉jP<{#E#?ØI&24iSf9/RIВՍH(F&p($f0wBmy먠PUFwLճ?ywȕ0i, v6u
+QujEijuSiڧ PI>l:M:T2īgBbg\?c3ڇ9?kYW_+UK3 K^ ]VG B1}9L!tir<,d.<}ewЍ;l{ڋX^uQ;,x?ǜhlo\en-9$H^0z4[cVp4ʁfy *A0ӄۘ]Y+ǘ2ۋNVk6U`~.Rv2OX[sPOJU|!e/N-IG[;Jz5&drdDn5R͵r0MQ gaMd+lW: 4;ۗ+tci=pqk*hP"25)؝ykΑ.~ߺ(Hcc;;@ 7݋UTUMM@p
+wW_WW֨E~Zk
+Ii ȗ* hnNOA&{Kk2(&
+ŷ_8˰xrHU<88KMGew`oPSkʬkM@<S6ɰ&> cȝ
+YR3PpU֑v #?,s/egBẅPPBR'XTcS[L=DױxY(dt)4c%p%%Fp"I(!Z/GSRoinOu?W1*?rW篍:'&h>,,kt"h PUTOiH"1HJ[>(3:Xv.,vF3x*mt]xq^<Ү ѠY?8C׻.a&׭_ev{mB~ -GӑD߇kO$[wk댁i В%=/xmDڨK0)@ )@"܋1ƚa ? @f*"T'B
+HGA (*h>$BzT("EX""V,+f2bv4SkI*buU54^@
+4 ^1Y$JR@o+@*Eh540֒*
+c')P!s^>g攁69Ҭ3.ۛA|5/EP/;]‰ O{A˧4cƢE ;rohPT@}T=Mp+]m4bhC[6Z'ƎtUDechjlCƩhbة_<6}ߗ=
+#5,PCshɆ&SRd R}DmΣB
+o n蒼'&E8-G@*>Bz=R|`܆,Ԉ%H0On'k"8wSx}?PRȐ1)г;vć8|d|̮(-+\MBohTKc(̵-c+DRyyZ
+oWݴ&3DZ-+-v<LU6[SD['7ŧTrl@>rbI 8^O]Y.Y\ #HL_zm@
+S, "*\&C{_O*8e+E\30Sm#i8\oPG)xGY
+J2UX˿f;؍GC;vZPm[hO6+7Trvr
+wFAj;0fE/; i< Fe"İtW3$i \,ӴߒO sQzѶײ-Dlm-Rr]3IXI:ڑHXnhTyؚTfHPߴ1C|c iQi !ni J [0A gKa+iǞA-̕/^Ljv d+aa n͝,ُO{ s &晲NSbC%<VL*_kVF`5xAˬ,ŤښIL^ |΃M|N*
+B91ٵ-֩sGT^h7C8<{I25^8ʼn;;B$kU>'4uqT*OeN {Лug*/fߙb 6?ic q0=B= "+ ɆǨpMI1>H# Q"S P":^ -'gH!)Bw: up1I=/ujDh\gh,kf1\>УPeTl X-.b
+3tlw .yO'_zoMC?w,rw<6W݄vf;8DsU7Zj.^Qi
+ګxҎlZ?#!Nb} Ut-HVˈLgTlŏlQSNc$>efXֵu#pff01y
+:E 8)EtD*vf,*Ǯyٚ-9iBٙs~rzNOV. Pޢ?˾pOc}:|qz!}I;+ҍ?{{نdE:NaDVDnN&8=@cnu~9P3}W&w8s/?}>po|g5S&_}LȺqL1*~f?W9قE} V!4uOoobBO}'G8zl"V{G;&6 8CڵGwefBu+(L@ _O4渪D΢fr^'%-FXZ5ΪE2c.ԴvԲ[3{V*b;Xn':c&\O/-޽)(Rl.)RD6IQCԎ"cBKk*`75IQHUdTÄʖ!Ud!4G PP!BR}=g}@x Z#kY% J#5|2 `PP@9R T!U_.<86>؆
+`D_Xʅ (Vii,T*vI` MC<[sYMլ`v^2x_L;ELUY lOHD$%, K%Z7M%Hh>_#@M'~?aKBѸdGK1Xz[jN1 J BY4<󶪷[1:R7P0>df0G%.@W!9գkkrNxm@FXHѳhꆏT%}45EbEDyp¸cf+waWH3 K_U"B.!~Ҍ ab%=n:"am@Mbq4FӤ8/ygu95Qa%咈XƈLwiH;ux5g$g.!|E؆$!"~$ֿ-?q h8mJ(z`]Jck kS0jGF-k>cWޙ`!" \3:4#||&'HxCL'DhbWuBʧiVdrF$5h2$<o,_Fzq̫c՚ $`1nzGqu/n-n= W7{sS|n*o;s_wُ9컿gtg
+шqը#ЉnИT  >X}+0l,Q '^A $%P0@D8$\0&¡<qZ>t>,Agq,6NNn\[XA@w q$3JQV~ +VꍂRaPp&{q% {
+Z}9XKADisxo׃=ot/?Сٹ=֚+?>|lba_̚$6MǙ,ʼn?4;lv/󉢯",eLuz{`Yh0֠?T_?yx̢SELgB~F(VUu.zĐC7T7j^UTSߨ:"?ghLEs~>EC+MٹݻNMțח2M$,R"iBVY+Wj%jJؐQVvՐ W ј= yg f/I)܍dU\vx^E'>6ŵzw{IgWf;w@..RsUj>,Kz;ޚꑝQyrePb{]鵫 C6"HXM
+t]R%ۗϾ;nO7%#Egq5tRs'
+젍y
+) PYA9u`>/4P%E1 B)[ lS(c$Ws2;J li-˝ 䘛om&݀s
+ܞ9 ‚;`sy}e9rY j9 ︁Oou'2{~y?sIҨ/߹7Q⋂:<X|J5?a2R
+D[?cדGqn?uu\BZ
+ BQ6Mlvē:N2Ɍ[Ӵ4Iu&vC&{mp}HЉ$tKֲu(;oIh?;2wLK:L {2Iu *L{=l+
+MKZguguecogؒJ ï
+29y;Gꨓ֑[dhs&.;oάB܁.#6RQM^"j sT=גXE]<f
+asqf#mLqZK*Yd;cX48
+.\sT>q?R'pc]AdOQNBZ TǛ0hJrU"8%ҚS)*6BJNʡ:԰i7;W r%
+ˬz:Ժ`իLzZc][PYj{}cBG\YSL ÞUF_#jmKt#k,v>XQܝ8qdr}O -2f>łO۶h;3L5zqB LsV2g:u4
+gzCOW)‰,vk_~&j5b^=|ܟ-Sɫ}~UﻒAg9UΛW]>6Pt SZ7D=
+]tE 5SU}!o!҉p/LkI \(Env}wtlQC_:9;(tXnMR0%z|4K?MMD!@.!D>G&a'Y *OIDžB
+GTc8NqOx& ' ~N0|/|?RDRK _pGUeU((/)׭a
+!B\.P 3*S},\w;ɲ^l<KQbu ;{@UFHqR6[Y;#.D S`Yi_Qp q\ۑ 
+Y5@ɚx
+Zn@>$ fkyT}~q}[0Րqj,aYr?>qݑ6{n'cwsPD++PS.\%մs|Q0" ,wFȉ\ORɶL/"gxRup0,z"wXV}ќhdB;KZ=Lsm6R9*i*#ZFETC].h z N5c4E#{l.YIMUN[P,Ԏ֒mIB3V׊r"rؑTu7qq
+ =gIt24e` L &>:,Y-ɺlZ+{zގvJHp
+םtùF EkSE &Z9=Z)j;Q3]näTHRZ4xQZb+]:(%! I!Zjt,gy"q, r#i!4=q}d2L<I].RQ#e+mf71X#J8ʚ7n#
+` ^JOu\ռ;߸;}Wvime`=-CY$;z:Gv&p;JVWmtٯ~ٲ- Wkڤ8>q}>,gij<4A1i><c p֠v:P}K$^Ra<_ uYTf/JE2b _%YK⤠T
+$U2(> | r`
+sA1#.%.ҽK'Cp w>)(M<wBu%MT
+
+ Ăv)(B6J7k`La܋f8 P [*ҥ\"\[A$E|# T~y^\ㅆ"EzP{]vsn<<۬ZUþXΠ[T!L^m%ׂP0P0/D`
+KkP|p΂ RYB5nt){5gw>ѡ5?&{׾aYmsj0&1>>ֱC Q~ylDSIⱈ
+spSFg$USlE1Z0ג/6͸%R/|F4ܘ3 8G EMLCxyv[3׍BE<iN=Ǜ`Yg'zFmY:Z+-vtAM"D3PZĄʲ^I;CdXN=ـ 
+3[IKr*aY2FUKV`R*DbnTď*;*-(P\* `$
+qB߮z0a$7D3fi ]+l&l|>o:3kL>E7?ƍbL9 ;h1WIEcں8﵍c1$+UR6$iK.MhHմEi:mS5[^K,ȣђBH?Ək׾;E􏯎d}\V,WJhëh-ˁsؒBTbOd[,ba1H&@pK
+DoU7-ugo>{x5v3]3#'Nr[vŊSMoՎ{,F)_vldž_|G9.
+k4 XA&z8@PC< 2!("R@41%
+"$/2f" 2.T`A\ PnA{΋ %uG"f0qA{'a#& XQU; )=8Wx)) HT NRBBuB$ eogTcs18(},
+Q C͜eo5);M6~K?ߪ{l\xE29IgZ>Y2‡wZnl{M?N+mVSDg:i_gvx34Q{fYQ̥,g02Fd <_:!T iD#`LH<j#ViE8ňrqeUpn>~?bliaecDp+tu ,ԫMz]xRJInd.GT餦xxxqoF/spX4T77XW~X/xUȵE,ޖ}oOt]CW6Lm5R{嗬M˾}C3c?Yitwo|޸[6V }kȍ|\wb~v6e::g}gfW\| 1etwѭG˝BZV=5S6:XPi:8  Zz̩_wvW]k8,J `,<
+kJ*~$_eWcYJI$Ho])^NdiVACxfxHi,2խE.a&Y*盩woƺnxj.w n@"E^Iy]Hwp^z@wECA(moP -Pz1?J,H Hɐ#GHAߙTzU>.ɝ
+5.˸+9οg (_)w]8NgOu#?zo4èrdHJ$4W-Br"_pY5-SrLx*\qKRV)L4HCcb-('{OzvûnɌo/6w_bOҒcQ3R6'c|E-9?t.:IDuvn6=o޺}R2go6Y!A ~A;kY">XsPԟJ@@A$R¸ 0Ta!P\Q-:=]Mwx_q8w|'pP(hZiCe6XiM۴J[QAlBR GJ_16J?zy_KI>#z=U$dE?wCEW ֕
+`Xxv6T/;TIz@".9 <Th{uj"FZ'!ǽ)%^#a=H-ײ%M>,_$L ZE(Pw[!ɣ+ϕOCOd54>wPwss9jX7b8b6o|=xiۋnΫL1;s7 ̯dBEY Aъ*\Q \꣡,lV:g'(=HNeE{g
+Uo4%S.3F }amgWp'y㝽YT3ŵRcX+6&Uv=T\? b)}tάZ=cN
+1yB]M" c)ba "iwH\oW~vI'9<dq^g3{1(J dJ,gFxfdVd<)GJ=
+˽+J쭬{W+pP>"]ʒYIVW+"4g+{+W(ÊAK`J%@$IJ2ܫS\/Ov_+Ht>X+)|Q{_Ӎ߽cxOnݹt3_oN;vOX]n8$_H2dL
+XBW}+
+//.Wxk_2«IYn]t>P?>@ rZ<sgfƙL+TcHm>ӌjk;ʴŕ ی||/a
+G򧯾o]uB{B/gPa&Po%\=8 9-
+r1*qp˔nǦsdYsZ@hpKkʨQCN0dmq-m4 BMKs*hNs6o#Ӹ:5Dx$)rxG Hh#QCF˘-4QMƂN$3&2u<uEprQW)!ZcAo"Hőo挑Qm5eY]`@.&Օz%&V,wdLg)y8KQȮA#:&"́4VAgFD)b(QDTts>?aG|#קYe`1AP_0vj^[_WoN8-$]=~R_*HPgEbMճD 0 1'\&֔5uނU􈭪@\((bMOm",^hEngU0golBFǘ61A|_;IQnka [O.taLz;-fsݳ\lbl ۟TlͭVK̯)+
+OP^dBI! ֆ` 
+Mgt1ܳːH8 8!H j'R<0^pjQVjL K.L b%PP/,InY0\f<GW [! R)){)):+
+XK@%23BXEpH?:,:o. O8򀷭-lXwI `Vt}2y`SHp[5'}I%#)/pyW/_?{pu_5;zCAjnn+1,DVЕ- nO]9{'Ύwű__<w nGo~cKϪsF 6eŚ݆=ft?ޏ})Yz ,]]4]ɁjKN:lT',
+}تە(fU}5Aga $Ir+VS&_/:XKMj
+<%عGwUQ無 ux}"LE2}p^JPYJ`<,зߪ^OoGk_8vKϹ&東ǧփ,$VӞC7 %"+S"?ZFG[OK(w=!zzYedW7)bEa[lGtaV6̃J,ůɹd9O\[@<y%b畸ТV ;żN?Y7/Be\{ D_cDNqW 2?AJɛTle'hnM ;,{v:Vsk./Hϯre~rgMXs"U׾JvLZt"RC>Rŀ8M(b\י #ݹ5\(MzĽV򦕴HtϗPvV(,PBW쨊X Ŀ0tșPmCJQ@v6- l{Qn$MvA0RH>m7'e*yDH:N1( :b
+E1w:"ud3MY3޹xοﮄc`i1l#C[O~ϵYZl*Ԓ/4g4=iD2#fJU|x[[5J̙S1 ەRbt܎TUjkJ\ɤi{[ 1lfVVʞ,i'<+Y ( 9T#&m;č&P%*ݷ*JRY M#,O]'#oRN4ͬ.PfI!Uhƶ5
+
+b]Am\w
+KY dG3ty%)0cc_w|P~xڐWbk[F3Qov~k+\9 'SքNUdnW:zG+(=JԪX+<X*Njs~5(ՒjʖR'<R@QAɈ
+*ޗGF0
+ <V)RAj*4Rl@0^!((? #k
+4^_V
+>ˆzKr,Z&&i{ ;ay/wCzRbL9R7P<Ik؁># Cye]6Ƴ C%}yՅG aM TU
+=nt浅 03bCnYUbrʡL%NTҴ٬{%%
+ (YhT*XUmVJ|}:S7u{ks9omy,R\{F?GԮZ']Z[tQhCi ΘyZdaz',!F##[ W&n8<ӡ\ޱ6h}#ei9Yd3Mj’8T4&l򧙽m9ts#O'#ŒEj9‰X`ٌ=~'vE+ˁ&h "{Fz4;O]lgeC4s #C7+6fJ&֌Puv8s巨1Q.ytqKqa^o9r["] ӔO(xQr=+SF{\LLث6Y{lqi Ovr=,L~w; _6'RrPb5rzE]UժN!̡jQraZRA*HJ*p k: y/T j?ދS%G_J-S:[y'cM}R9<(;r>^КȀ`z{SeR)CAk}u% (HR <C֢zʔo{Q\~F'Op!P?x߶_uz|μ7}umdzďz?[ܙ_"{^t=m{ܤn}Ծ6ó
+wY_~kf #ܕU
+dЉGJ$p֖! hJ@LrΦ8M9ZTblj)MU}Y[2"eꮃ(X3:`d.p-iYe.*6TEb$E
+ǡ(c:TmgLo<@+?=z?_J+qmSm=+1~xoN9vm~d /W/,GPFlQ?4 @X@T?-pF"J$IDR A֖5oY
+堮(H₂*#Gʉ^xUw[PiPZT"-J?"`}$">,5Y(XrN@B_N~},[xuhjpkXW-inkSb'uH *WS$sj^kkΕ6z~dHJH{mMPAŵXkMM}iu=whg~5ҘK琂ۿ=}_.%s5ڑ?^c,82xs_-K}o/SCތ&&ΤC?OX+ْW<N{CwކH!ZL^pi(+ M ẅ́.x$Cj@.X[]7|@s'nS'"E *7c-W u;jBi齈Qe @ `MC_|%;399WtHpI4
+& DvWDa&J~DQJ\j(nVUQ1T]: n:
+d9m0ƷeK%[e뾏]I+ѸvO2icM4.Pt)g) D8IQXqzt]1H6zDH'Ygn=x Hs'ܗ6Ypg`ޥZM {·=nz2DM+|-_EܔKjX10dFt:$0 5;9DrKz)HPQͥnČgϨMBO['}ы7c gΘ^]Yذ0#ҮPP@JPi|n3! aUê$@*\'A6R`g UW9DR~'f HL%z+bXџ
+S5ԔK(/j~ %/bTEPlP{"F~
+%"ƥO)nqՄ^5ct72X؝9DYn8I2*{"mdϡy5h5S 6d3DKzٍ+{LLEk~ۊWFﴷ<E?G7P1?]HVDrR%~~&-;YH}inhkwJG-쩈=MsDzT4Jh_zYԊ<Q(
+,䰧M;-[/=Pa7)F=Pk%AmnFa0mo
+DMuE0,y.%Tqhr} lͷ54;W=,f[$dR:vpbGk.n{SVH5ƀKҘ`@C͒kt$46,jI'K:'Sx:%KR XSX!*Vֆ#4'_$Q6ۂٚ735H΄Y\ĝe7sI# d`•bޒuSԁ ƈCc;,Fidx2.TY(FpRS͟yT^ 4Kn8.ЊBů,l:]HS$WLxЙ=>ZI)a0tZTɗS4>DhTg\b rq?E1wHv33;Q\z7_qwgn!~~alu;IBAv|ۡO7|_ݚ@\kʫԫ) ~&by T(:~9*_5. h LL$b4'"\ F2^$^Q\W, D rH1"̐PPn?<
+aDYAB !I ?A+uV
+0;E˧2̛LPp88ŋp$^\;9N6va}vcWU嵎@e޸Ǭ͆ YcƗ;SFx |h0ŹX1N`Ԑ@2b@lq{w' b*$Z"G07gݩ|"#J3-6') 2ȬSs5Tc)Z9eVB.%5!o!4#)Ӳjѽo΂fVh=t[rw>U"3=Zl4g.[\A4¡338rWw /ֿտҷv_CR.m>[W8F]\W6jFCkI:ـ!=RjYե3(Fua?[ۨ~9(4(?Ab:[|05AV[a[`Z+KL PKuYP^5&R\3}vZxmi/da`?s a @x_&' }XC xqa@}.an'uɿKi1Z
+Z^1q6i:|MT
+90k Zk3ܭ { p /m;B;|`ԞëG-1T3V|Ezt{ v,1"Yhvl2*W ںkpf_!&)uKnF[wodo{Wc[^v$Q"պſrlvB1U9@8kl>WI8`1W-bjIYS5 B>t S FR)9Ř tΘ#lҖ(EgzјN4+iyd\<wy\eTN%c_і{Ikm_2{t#oPJէoҵ~p9A3?Dj>٫ݾ)R^m`\Uf5W##*6b!?ZTGGV'JE{L.[L8!tLX>mcew]4:+W/*hk'}\ySi $Q('w!I_4L>5ZӬefí;ӋQ ~ \V[8-Gi?ix-84t젥iƨ{xm"SEkbqoi^P<LبvITKb3X.ԩ
+#lHA}*ڷG7>15}d/pwi{5{Nmk&BX"B=9(>CDe*hR`9)!Nr(@_"H\ ˬ
+J(`<QMר@2E<C$Q
+6>3Wf~u^2{CB* Œ(SMY|1 V/[ %>G<NyCǟ9:obqgg_:z1gCpQ< F(ba(<H H!TX3AdP~h`d/%X)$-T
+%3juɬz&Θd
+ @*Á
++oxA
+Labmi$*p/E{a:ۀ/ODElFUp@Q0'Fcf.F+FqԴt5o<x^r@p.ޠ*jUvtlguGk׺ZֵJUă"d)H
+fcIX71""Ȟ pg3'o"#bY@R1 %dD}(odFBӥᨀJ =A7s֐<m!ѬLWSu>}ק=\Owwկ4ljgH2GGSH0}\UB3Js'\{N0kn fi،<8䉲V4G?6\wI=ZuZoKfmX[93.5İ'{،큼أPAidPNՋL+8bQ^R9+ÿoj|~ZIzdQ;MOK{h%n\ y|VC|N#? 
+u/12'wjI2Ĵ7_@`D5
+A
+BB JK`:*DD*Y[92*L#8L8<3I1a
+"ڠY9뫇.t+VnsٚbN@tD5WS"'ǩ}
+03CtaJ́t"(z2^꠯ڦ
+Eƞb',uTtCV݊ʇ;j"^[*Я]mՋ~qg[{xѿL6gP&&R6iiAeI((Nj{
+UrXՙE1Sz/D
+[9=ez-ٜ0) `ʛ/9T`FtL Z%_1\nbzWs^ 4H:OLu i4E;$kcCN_POc2\;4AדP[Uiup\kvn>r}4Bl44 O35q>'[X>Sʄ%vԙ
+_6?+d-{ qjk=7 =rw^򫽍٥.lg6cptowۿ:r\yjl
+q i@ &`c[-Y}VRߪu{OOyYѻ Ӌa[@̖j+[rS(EJ@ܸSšhS%Raˆ;C8TgoR sO>_9=>tEA8bx0 fHzY!%ɄZD,gjc]BS曁fiHTդURux U 8$pjCxtjȸBg/ 3,{!QF>R]s*U^e)E4*%f3~I(0ݽ㦦cbd"4^zP["y)d8Qi\Wo9ٞފ T2| DV [ŨNX.65.]c.,GE) ߼IWIWV4 gʤ3S7{JP CǙL*{:&`:R5!c2UAUU1xn$1KI6<aHV?N+zL9SbȞ&mdns&( $Gjdy:vXD7NmŖ'gtm펵?jhulpU}
+!YAU
+L7ʆI6hf,jgR9BG k/bMPaWnכb3"eYRx:^bt܎ew|G|O%ͬCW aWb$1+Tx.N
+R2˼!dQGAX(B,v,@1G(ɜВ$
+iR P|9# $!AjOeRT9Otv=X":8l~۽qWYugIcPȌE¤j2$FLR8?
+aCR,k
+
+]ʩnto?{m[qw'|[k,$ėM uӞ AJ6~+ +A{kʂ[zx` ˾1-^4r̈́<-@3b6 攖5䲆s#D$3'+6,$^f?Yz؟/9>OF}@D~w=חeBB>5
+6\Z}n>Q7r$s3cP\->c_߹Qeߦh^r`x{[-G׶B):7y ý˿ʽ{JGF{3>scߛ?xÓr+ez{Zbvz-OrE jftcݿZKv||/:ް{/~o2E;'̋j Sup9>&lT1"ߖmuhk#o0*+JVqe )_!S7Cg(vKjf *wzï_YUj3
+${TT)^K$T ML|)`OPp%>!h\A&*a}\<SAZjy ijLET j ̙ɋHʰaMF"m4FZ4"r2'ӂ2^Xw遫tX/<;8^nrA H :*RPkGkvuG;ڱݝv]gu9-]Q,r&'^ wȝ雷C/{DK>M5ϋ㑌|γڿ6WlU
+F=wGNdEx]KSoJ75J~ŮmT̸Э>%CcDkatV& (&GDIPI9氢LshjfKzvi @<#Ys`7T$C<G% @TWF 0ТH܌@fOnãY]ٙ@i7Gh el⹬tG+
+?pqV? -tW9{<~ɇGz\l[-17nV9qaN^̀~:aBf2:s+Y`@ ; DK>~v:YAJȺ0<lkHD; u}k]ORӱ^EK@'~:R+*PYCu5˟03rCS/57U0妛wgڡrCôзq|rڂ Dp@&_QJ|VJ5d\?,@(G4S*Ĕ@d* S@DoDXJNUdSZ"*a(a
+I 0"7D{H QUBH"Us᪬sݶ*}̸T%fxkm燅g{~zO'vݸiY]s[cA.fv*ſzˋMM_7<:Sww}yp_[wZ<^bKs׿u_yeA]RcXծ
+
+}#ܜ{͟՟O׭/c(
+: AXEu^ԡBh"RSGo8TRD0Ar:\I mH
+ir:*'(2**Y`10J3::
+F")虘F'ƫ.ye %2BSLݙO3r ,zܮSl9<%kYh)3l˳y9s4FLDf؆g,X1.r೉\k\Ș31T#j$inx©1Qΰs,g _-tXl/^1N+Ma'A)|q^L)<Edk2$Bkh.M1ه5r(o2ΛG3p9D[<gv>е%&ĚBBg`sΓE³=z!VTJΊym1uف{.5 lؠ Ok/$|4m[)O]M_w
+M&Їۈ-/B{D5֑94 PA&7x#ud% !Yd9 $qa_02|2% H >VWJ^@Z,bz+ ءPj_8Ch
+p xEC-=0)GIëœ׌8b\z)N$le4#,1JĀ6Ip8 }(:$+Y(YB78#`EW~ }FGj%5sٵ+i׫,fLL<M^`-Ice.RFNJq]aq.PP*St)9(eb˂6T:pq
+˹BU]0{XO1VGZZtdK2ꈍ1JU:CjѰ9#jJbJ QZv) l[JxݶSڼbryc|Q罽'^yW:jݙ So}: WZz*Qed!ho 9m6ac
+"O4F:>SHIӺ$RB䙝+$
+Ѭ;gNZDRԙvĄ`L\9,> a%9&J)
+p4IRa)j+k~Ĭa.SЅrюͬP{8,.
+,r
+&:f$%:n
+D Exh@8d"@$3KH03IߤŒFY2KոIM1Guw汮o5֏N 3**TZU3gbE,D擊|P2üx!׎3 Ԅ 6ZLv^.Fe oZU/D
+Z!CL2NhMZDu&'1㗅{_o{i
+9oyl)4 5JF%d-{}M&ܵȄуZu^ywݻ6/~/G9ЧzOﯿk)
+9\#?3;˥"? 6F`xa~ueյeX1JiQ#LL0mJd.1ERQ%XmwL:+f׋lTx.S_Zl=s`Ƨ4(߮p)`Ͷ?ç9}to}lѱg/}P~+^ vjY|^?o_;sŖ΋GZ/}Z[?nvu;o]ٹs>uywGT=d*[?ԳijHk 9C#5C:̀
+h*t\0*x$YIꠡX5w"^JHBPL>*}jM!D<(<6+Vq$^OJ`!;l`q*J 4)^U|*^
+L' k؎Ɉ?&)
+`֢CQWNih7' 飸1Ip,,NB\/YȀA24#!<y}tw2Q
+ PqȇgL#38cFjƔWHLޑdW^jwhsېdvS_>aT cn LRA@h!2bYD~xq1YLv| ~sč;?iz{|OEЦGOְMZGQ?ș\yJA=[#fq%-\ lxi]*zrcU~ߕV=F} !cRit6]E,N Rmױep>K4eDI--AJ. B,DR-q y:.J!Ğ0Rd*3sn[KY*Wf0sv=]x0؆ۃo=# _
+vnn|ͻE(cB,:ьL5eejFKY ٤(B˅J˺'/ix֩?y2]7( hGnϞbUȏ/LIg^HA*ʁ$:n3bi6$6rV0qJɲi&`5S˒S S5|:i>
+7׼CO)CO/wF)l Zwq^W_?}oNqe擧\G^;K\pG~dG}wm'y?}|'߽n-ӯ'N5vMW?;ҾMM}]o ˭ReচV<ؠqd@j5z=Bp
+O<mF*G&b4#DtI?bF!1h7BYV@Q)yi*HFJ>΂HkXV4ki$ P~Vw8DŚY9&K OJƸ-_ KߓEu+k~킿V*LaUdXnt'Bw׾Hmqs#e'3 SIR DEh.LjZlJMck8kgJeQjO[2tDh&] KY'nR-Tru,D^!!UK "Y2)Ră)/fLy}O"3a}Fah{6ڶ8_O)q,f{0J<^mAdh;KSUhAgN>BlF'vz7s6|!\]$߭7L+ 3wqg G\(m +ݷ˶$26FQ&IISN/L*_ ~[#6),M d_Ɯy>v_878΋$8zZ[Nv`$pBW\?J1XG`o2W, ZV@v+Uxsj+T\}0}~_8P##p Y
+A2P@ +w7=ORESBKH~,{lOfA>P)wacRY>a,'Lx=T dX,rR^hJ.
+ I%РGjtn̻vߚ) {]]k޵(c
+@jU\&A1?By>p
+[fxluTOE
+5<$rE)_CX$N&cVtN&Q'av~S84 &[`{ 1@u[p
+ذdl[dATXz}AVq/EW.<i;w.KՏW]qw_I;K}‰ҩܳWn C_|YD_Яr (9=f7̼HWD(`Ö0RW[U"e IEUH
+s\87Ϧ-ԠaL#kxQ\YnukjZH7e\ ,@/6ePGzzj}.V@ǩJuPPs$9Z Z Bix"SO!G ŋJ8NV# LDlJ$N(yqL%41H\rʡa Y%0שrPhE@(bF88
+fo@L*I4TE@bd Vs,ĨV1%¨bR&n⪩0FA
+tRi…^Ayi##8
+ Hьb=oxm@i:lsLwicMƛTE;i׻jϜII[9ؙ_"_Ze϶ݸ:8
+qR fmR- ʌ;w ɀH qbn[|;Z@{??\{TW$L4 @ ("QUnV۪gеt_vY϶niUTyY**XByHIH2yN&;n&9
+YHBr+UUk/ʦ'jK'ϧe[buYn̆gys.onin>tMj׮k>M|j?ݲZiᚍp>}{]tvdw;#[{X÷*uGw~t~Ʀ8˥=2Zۼ+?=0
+㥼[ub%&xa$f qF% E-@kW\6?í;zpGƦM*ޯ>}_w[_^~Vv=U>]R?ƙ[]jsAGz~դK}^w~tۏݳp?ۼn,IfG|&Տ+KwȲ6?Ӵ8_8/m|-Zr2I<G#Fn6EgcZV HcT#D"\}HLYo@$0JV@pmͪ;R4 .9zT#CňEjo*ݟZYxan#MDSH裦8ms@j= *CڀR>Dk1)= D1||Z&xf(Q5m&wQ* `&gؙ}]F>,%f,<0@#!)Ä9D}}3d2MhG'CAwכC2P:]!?m ^V`$hCX%N8WlM7wMs3nX#fԣ\:o@b@víy[]2B0?efKtu( d3i Nc14b琌đso2%ٯA) 0$fSZ~4[vfqT>U'MaI#-d(vX(Ά> vxYp*C}Hw 'ZIѿ|.3*3%&7.̊qr遡wz]m67I5Ƃr-R"#7[ܾi495ՠtYR&L2dH5ZSS~m2M<G'_(gk\걪̦\KWǟj,Cׅ.|oUI Y
+$GN%q1i$ t%SXRd4LCDR+d=
+RTHCP;[>:_$0,Ix#9u\vkk=__4X^-,l>yO%5F"AcF(Lf۳车C|Cwz+{cU- /p'}}3r{J֠6CvĿBc<,t.N5VMe|{w]x3֯ PwlFB^"#E|pTͨWk{3jT۹UzRm*ypXEBBI`CBv7vk2?dhTfV,o 8):Z%nu[4Qƪ09bM4I)k"<+_+:Beňq3)Ω8vؾywF$"ΨD=_T;/uKk#"<K\\r̛pG>?_PVn|`WSKUvQ~3+֞=3JVi>έRVRfq{ >wlTl-O+]^8dS&ȅI)@X>.s7VM˜mi6f(Bgd':q7i-b ʡI<OȜi)w,L1ZR8Sa}nݎ-/Uw2Z]%}i؄0njB/iڀ2H&x׎\m[ۘ Ğ}]\çtd@%GH*+
+t}:iZ l
+}czt"#dәTN|J YHR@:|Bfŕ3p!2aIt,5JJv8liSFf A=}pZ &2d&.I1'#:^õeI̸FYZ0kV~lѮNJ`Y]BYÈ@.,$o?k!'M
+n!ˋ ^7ChifDM IJ20pĭm!qh (?XO}KfC0d.jcܣL@P-q&Hǝ bGEH )4Hd쩩88 CkPCK6Bx6.7sՐuDךm`t\}(Ν`˰.JKWXz \u?E:3L6 1G?ͥo_w;sZղ9}N dcWc qt+2X>й5pJ_8lf[)q
+%Snisl>Jf<.qk!jr56Pr&dLABGgx2b4\p1QAiNPQўiu ⊜@Bu |d0 .91259Fn?'_H^Lѵ|, kۻ^~|ʻV>R%୧ݢbtanmr `l)eoX
+B 0C!B/8?2'͈#ڜ#PD@djѐ$ @3F1{i!<B ENq4?da%tPP dZ`fNfKU=Kc=tVLf{q6cGV^/"30>Ԍ$1HYo0[5xM>JVbzr3Uc&aFJF!)aP3
+!B+);{d\x񥊛*C1E rZ|d+jEo
+[f# ELcע-:'F#kbIr钨=c~ޢ*.8%&WT)H1OQg ?PW{%Q7ͯw.;pϲW(?Px{](>{=mZeWΟ޾tnK*&jfA%IZ*pє I*1r?~Ptmnenws֎'O,qlu񾂎L/FɔOX^/@Qon;;8E|di&FcXӴԤ3Mmئ6&f:iL&bh>Ѓ㎃8vo_=@c;}|f~ 2,kvAIx%Sކ;+*mqa Ȧ`17`!G~(p`! /0aXwByswˎν᯶_T :Va FƬHy~
+-w
+~cicq);Q'8p1BVX]FNJUl;mGsj=nUbJ< lUf 0j
+iv: ]f'զBC6Zmx)˗'jdGD(e:y(_eb3
++^*RDBy1J(&Q kW@lg-dEZ_
+G
+N,Ircd t]k6/6D6GȷD(EZe["eۧGZ ^Lr%$Ppdq*q9 J gpZI)PA+i r7ZYu&ꑨaT{YRS1Ðc:T Ji(4F]#f
+DLӺ#!;IC``># (S @ XEU xR  f9bW0;
+fU/acTc n`l Ń
+)pe 'b}%2abƉW=ʧ?m)yk_ 6zՑ:֪g-&-Uߖu_[{:ym}e|xe$ϯsq/uyծmԗŰ/Ք̚(Ѣ)Oڝ\'FIҊɎ;"G-WV߉mE8595ΊI[+'"\h-`N_sOVz=:/\?ǵ<NNs"afyGN2lS>Ιco`zC?OmYv Y|dZ~j߳Olho ֶ_6i(Va>:Vz5QԖx5߹h}oxu,XX廎+o_{#/p7o?:C y|d*+rP\+q9f?{ϗ3jvwM W31(~bQ`:hq:(ƧtyQ|&)wۗ[<4Tg;v߼sp϶cM=KN\xhH&#A{K}E [e3M*Z3dy-Z
+g"z#n &J|F8fum
+rfn\ի0\h(L(Pna6GH#Ub"rM&,N
+iF3U#QiNVOiK*Igh0VUQ"AkX*M$
+Ha"̋YZ{o|
+%Dt\g_zl_D 'F+G3 uO> ];ё`9vlFN &CnI3q/oe#!d0Y0l*.RTHh$]w;U)m̊ DXl̺] u\([_.^?w݇6<Vfydټ)Uķ,4f/U ~U˺
+3Ju<WL-hÜT-u1c
+K` ^\8^Zfg@&!5H+'r8 U@ty"K]cMW2lV)N>oۆ]|뱾_omUCOxY# K(:9\d3
+=uwÉ#,~f!qs2OSU$<)80_Y#Mn
+{͊]m2UyRm+݊+wv߹zK5G6G5Κē5rGycow^}3T}oeѮv<vedc.wNj ?YU
+dʡ7ˇrݪRG~"[Uߪ+k׳_?UMq5y uUFzcZۦ\Y"
+ׯ_+}(ǯrp5W䅸x!:x{|?׾{Gucc:]oo5
+ux~};:uɵ=r zsۮxgn|'vp//lyxFk rǻ;'ZUw3ê)ED拺,FAs2a\EUj4YqŲ) c%PGi\b T.XRNv8̙Ć9G'ˤ|bIl
+ldQW7*b󸵕jFܴE23'4,k4\%9[-Y(c[+;STЃ9 F[ wPi
+
+I#@ FEAbe6UijL=_P@ՠXS%$YDyHIU9%/>5= MB.:xY?t{:G:7w<>=0ʱpG^]}@6f2e:% uksX4" 8hf.zihN.se뱴_f
+u_
+ C=3B.ln~;32.s2'< 9ha9HYR"E=ysŷ*^Wj?`xu~œs J c^gyK
+IYV0_xޑ7:v`=E&QCTt˿<|~\7}g,>?\+YK3Ҳ4-/ G.+ܮBiı[d*0.kɹ?)`A@,yĚwˁڄ6օ];D@rpB'#ͬ`5H/K{C΂z
+&x6I`V
+
+gRYL$D|5 S0)
+:UTt
+ nӲTG*6U3@Uܢ@:c BAN0ZYpD&l@XOz,
+U>:EY./yLglTM"gW ;/~ns?u^,sO_~u%~5vvoΜ}SA|GL?Ag/j8efV[1jvf"($dl(\nƔB!*)N*qƝv=VD23߽r3|6=xy?ԛXcXB/OZ!svoStToKi-s<e_#cǤ}aTs<&1S[=- $ʝ?ζCXv.+z4R2˜͝Qd;
+ѓM?XaXHb@j ARIRGSR^D\Zr*moy9%P *FqFf5](D'b&hdmS0BsAͼ$gF/Y^Z/M ψKa@Ԣ~ 
+%`Cv
+K]'HW ty㵺h̻hՎVWމ;np Hll3+z5NήfƓkݔU;}zeoNwV}_X8[T#ٕVsJ>tiî>ߺC<&plpsl99ޓ2|M 2]8l94/|nK??;zͷ?8O߻5GxoHy{:VwZy}jڥq>nPu>J“'mķ,tLꗎIUR[5YR&Vأ:|TŀRU$GE)$W<G<9$ʇbƗt)E.Shb5^_~k=+wfo3'ō/%o*ht&5  qge'LehS3brF:ͮ{5Cczwl
+>L9`H>@rN A?H{gP+KI(38v Uѱӑ}sc?kt<fPq^毚- x}ٷ&jk}:=,kqy7.X!'9iϫaDu) Ćx+2-x7q
+H !ƔP4p14# Łܺ u&( -zaVM|مV:v$ *
+3f( X?;K6`a/ޟ-\~22CH,Śp͗i0 ﲎIQRϢ\F^~Ppx.1Q{L==w'O~w7_9uw_q_?wl0zϾq©n9Y)mnxk8nzv8ƆbbXJʹC:PWק]5^XסAanZ0ߩTbO=I`j=]7EV=ZV5BZ޺,7XS]/V+T_X+O^|u[>϶=~7/W~{~wx[K̨ͼqaӹtkT[?SjX4,.G&J?6cz%7/z뛽|ʿ請ЄONJoVt0c5![3FT^l]]ܳ#yz3aobf׷.&*GFFĨ4TBr}FVQ L5THݜNuRdT n HY<.Ka -U`d%boxHn̋lVܺ5ȪS0x˲@"\b˨SJ,s+2c }lyX<hYoO 6e +lcCl~ qIljܩT:Ծ6|ať8⧺d(;yh+HWuflPԎ\Pa#Bh'1(rϒ8yb62H?c K< AF=t2%jbE]Y-T*K%1R u(Y7lmʼngt|Kt{mC<H".3v,l29-ǁ]"azNߜm%M[ΫVu0mS.SQ: *G&R'rʬU&bEgZ ̗  Jayfmh/)+M头Q42-pP&#ӤY
+Gi3%+Z 5BƤRĦzpxLRi|tWwI`,HYhD#1h)J__v \:'硍Tܟ`W))xly-ˡl%~O7*;z4B4)$ʛsv6.i+P5*r2Ӛ;3N[d1\X7[ˇ ߄gC/I`\X57Nv3!lugy2
+e y/oP'IQ sw$o:3]g,.OZ ];Z*} ?A\T[זSs=}!bQ?L"J
+p , .pOߝD ubr-2wɮ-gxNK,hA~"qm
+g
+wZOZ T߽O9JWYwv}k*(_ӱ#ҩȠiNN{«cݗ01q }왓WnksD|ٿ\;=t+Wz[wL7-% %.՜q_|ⅹEOִlj>\މ\4یMGb>['Ȯ_3S^AP~ipO)o7/{іr znI"9nfP7/= |]a 5c;`n')P8N_)R83-Qʞ~/7{`;Ə~O?x8ɯiL0 Ǻ̾pOgl]l/<.' .VΪ n<[z$е/Ev.9m<N-i‘YU=G2HkSIvlty\a>g"Mlac}ѐVags辥}^jo?J4O8\~e@>
+LdĮ3? \ZRO%jaRfsDJV.Q#T8HW3@KJY&`#c4Fqt('[CsQ
+4 #[<XXBs. P(t 'UӑRZh QH٘;^W1=;\V;i0UPA} GOG?~%g\tG{]HM ݀A'gz6Ÿ́䅆PTZ,Q/)oOOz-gC Gl G4cos77Wk}՜P@,ޢ=U~JD_{>Y+,!}2Ȏ?=x鷾_YbtDzxMy.5Krبq86jx1Wf~pr1QV
+ZLB0
+L\*1 WD.OmWדJAz!3̌_l&h:8DE J+ΐZIgK@q48QeGrmZ))(5$
+r CS|5Hd'6B14H#t TIXڈFq2/iT—*4Ç--I#w JV[lXA 09=Pb7y#{ImyTǎ$AmRt
+i *
+ʑ*#5F'  O:!°@ypW3
+E!"W@[hI˓_+$CD1Thf2R3k<!@NKiD9V猍AʚM)$V <B53G ӄMjlQO.P8Roo1p/VTfy~C~7qwwg}
+m?t(Gu#ڑhqѮ{}C}ϩ~#ߟ< ^?{ʷ_fKt|(u .EЧu/?W:zzϖw|c`d$ Ap ZT^y3 [RJ.pVEhb>4Zύ,@|9ԺW tu2A|}s j|@A0@~?p3݁}v?>9x'>>'wաk]ͭFHg8R;lvGZZs-uk&Z7Om[zC%YppN(lYaإv"N &vvi,ptM@+:J`T" 2| a
+S}6?վoc=Fmyؿ1RkuvUng.6ϙea֫ZĘ!R/EBZDSkk8$MismLHOcԬY(UTH $
+
+^dMHyOJ1')v憙lv)&tneDzfAXlC
+cW7u(ل*JUtq&KV\:VДnOjarfL_X瀜5Hӭ =^]:8}1.gý:Չ$D:%1MYڋ͔
+eΌ$8;bX6%V($ hޕZ0ws&dĉDQ6*c$5Z)Dp1 wo7\vvXvkUGۧrў_ y"lTS* QkL[Ը (Xm:L~f"rϞFiPlo*ԼΖ#9z%a>%bn̰69ݛd/֏k]lmk|jM,r5E(>SY ,Єգ/ru݊"_s> a)$ŀzAm8E
+uvd<V}<NsrQ@ę#/^)]L]V 4y01 IZH.Ǫ$/jBLLЮL4*,3M DmZIAT?WUq%D˰-:$'1BiĄ&EVq"H! NqrAͣnhs!A&x4[-Հj.ebSFV<F؀L8,LS*9a%];0gG"p1 (rHu$J q@aRZ8cFK X[70(D#dȀɱ`,!WX0"ʄL&k/0@bL%p+@nQaa\
+˪Q{O^ݺ'#:|:vphq7<{o=8~s]v@t~Lwe]/K8;f{uNZcE7̭hdaL1'@?N^9m-n֋Q:"mԭgs"{׉ۚ8Mrn'ȯDH_kqffMTo\k{ѣ7|<fЦWw{0eiGW>o=ODWpy1I[ tЇ=bLrѓUǓ*QT%t<wWv3)Ze~d:q1%+N#uBLp\:SY9;eƶc[.m5an{A_dP}J#'Bu/;I%%m><e.to~ZV}4n|Hw= \Q~-\YI;A̖7o;&r-m nnLJFyY$ w2)1O,m4%h[ǼM+iBLeqҶXKB%[zKNB)*Oڬf-H" hB!j&]yf28ʗBDNNd#|Lj*hJ-(uٕ:ޫhM(uc!#\SZQSSĔu/ejI۰L(B\ӳ)jc!.}2k1(g j2C/I5옗`>^,X3mbTe͆6Y`Y)h-O)6m5%\uAI*Ty%[*uIBe8ID IֶŴE)"V
+7DS)OtiGPoD/R VbJ3UĤq-fl*W na!D[积N_cv6}.q'SvS \~5[-z{浓QLehDP e9|{-諐(}pM(Q_`eO.v:Ry$9ݼ2/&GÙgK=fgnA昧'-g9v<ud KxÞlM k%!.䀺\E{B}E|\!o]5ip
+f7|I[q{گ|JrOtR_[9;:fdO"rjo
+x[ן і>:b B!V%qB*Ų٘Y·f"1!܌{l5n /}<-0q >Av?O!p
+|<%,OdXdQ ҭ@%@ZA.a0:80:6lN:eT&*=bjQa!b@VN`#|<dFz&&&
+I&MQ
+ VMXQ{`'ۯWC8{ޢMH| B͎pzX|  "6k@axӼSO,5:<IKyK)8sצGUkuWFy&3໫,ɇd[e˲el$- !! iIRfJZ0e4Ҕ Ig65 `ĀG[W-[{u:VX T3yo}ZIxZ5ŏ_K1TVLLF83R+r)!#H殸I}HE.E \7G
+&h 6/VaE0ZZya2-܁H^ɋp5Z$/̼s$ă>RO.;[^9z`w֡ŦG7W9xm:ngk'z~"JB7۱2}^pM5cR|nnTnt%,(d>H:|] :ֶ|$#1K fU,"\ 2T˨43ZWGihd̗ū-Uus3U2&PthicXQAA!,fxT;#iwneF7?;8Plzvk6}O=il+Ǵ'B:>]WEJ\~ymƩ{ۣ:{ -eklRYY1^/"-Ev#X75 \˚k0"2;c Չ&:!u 4R]d*61˖,,Oʦʰј4%eOjfoԅUsg2YRp}[#*6
+3.(0 rq{(kJ u>KRR;vg\.`5Nk2q,'p1]H~lO&Ҕs|/m|YJ,'xx!(ġ%0<פYS8yTGX9W ڝw1Vp
+AL[#+GZ77kD[&]sM͍ẚ>ʺrkq#Ւ`ϝ=IF"!%$bx萚W=,̃{Py%w{nH!EHD0ExX@i(/Х#Kq)9G;= 'c'O=<&;?g눫;>K!¸C˓!)Oj"Ŧ)Uh\f*`TFmJ<AM"
+L
+BbLd-,%MAY*%L(Aݚ`O0D aB8BsA0P&"CYa&H"AH`!̈arЦĈAc>!l0C av6s 3y3ټɀ::;+&=m<<uv'а=W 쪒޺eԳB=/%&JdV2JxZѦ,,ulHzk~#Ȓ6{oqߩLFmuC}=ZwN< ǧb/^VU]jh:sYSqTQtwz?}s;^~Gw_<Ѿ R4B134AN6 HŬ
+C`H ~Mb@Z?XWc!0 ARPkY$o%
+O~AlwՂSe
+}dKD|mG^SRm{7z~?^޽u}{:_3r~/ִ \>Xu:wmlwb9QR2VPD$2L<7)]M\g
+6Phmˀ-u_{o刈?y~v[;ޡZaGʻ%Ϣyl,#Q(FFS ~ 9UkD\@9LA* pH(&(79Hù¸4F2:X̦ *[&=abu_l]pZT3:8#0 mɏhy9 Zߜd;͓6K)M[Ы:oZ_:c[/u=r݁}g|kt|,%N(؋WԄ0T*bYRpMZ(
+]Ts,qCͦt"O iMѩ\p2׊:Vtv"oF,nMZSrJ|[h'☋*hfPKf?IѯNStN\Xﭗ#OJonE36K)Zv)#6X7j#w~?6d>P.њWO²gţ[s.Ox}LLR[Y%3V4#Fxdd.5Pi"!L+Q_PpM9@#XO EجkXKLԋ|)S0
+޲ l BF;qy+yR SFøZL)x<cr
+ՔOX 2V#a6sq<u⭸]ܼt[aLldiG
+Vnl?4s=-N|⹩#8wș'kY3KgQ]G:؎=Ɛkv&]' 9T`p$y\(!=)9 k%KC~ǡr7Fٌ#D|69͈3i9dI|Q:Q.Fxg\Ssܢ528,w\F| 6crO;gg.[&Sx-vv!: $0"(X@7܊SЫjբ{kՊ| +}J? AF* ~jޯAdvYk  5xo BltGW;qFT.ބIO*w*>W8CwOTiV .3_]Xoո j^g{k QԐtE>CMy\XBK p3Pe<%"#'cx=oYzq
+h*b
+qyR"a0 #*,F`#HQJФ3O+,duB7dM* M[d1 :<-\t-qOR3{fa"xfh;Ҟm8pu{58'j&쌿 E?n1^Mwbv&8NBAx)PX)# Ԗ)BkAU"jViUM]uQP @
+J hIHgWw;w(BCI_=<'둞ϳbޑQ,%ltYKc"Rv ܩ*SR7IPqkPꉴY46it3\ ~6h!JĊVµf nx MBk9J- 7B3eeIBIJ /i
+IWr0}ޯ]h6u}vUQBbm|+O A% @VY4\ V_;@x>߈~mg<R}Ωڔ2&0Ab=7T4hYΣM}|A^`Ȣ>78 \\;)<(yF-҈xHQH(6D}8O 9oYpgI5,q@eKPT˝-V@Q ꅡF$h^Yv1T ""F$?% zgOţ:4!Fs*$|fR5ƺk? :N$*q?v>:e#ئHMI
+A
+JvRD;m,kiSK"~P. K3 : H9 Q%:Q*VAX57$,J35fCmSSc?~v6`"ly Jed_}
+j(WՂPN,Z <hZ:R4Ρ^
++LGǜ n)!#@COj
+TTe^
+۹Ŏsq5h8:e(%Qfztgn -x `vjriFjDX|,dc1[d ~d^دD4=y%r2pzܪD*+W 3fUh_*DFձꐩ-T]7-VȨ't~zZU VXC>g}G[ܿC_G~w7_?zu[^T`)p<!`L
+#Vv޳W<Wzz/nl4R48wYңwo*װYq[+mdN ϥR,WaX͉$Q"9YmܔeC6VoHi" rbEI
+ y?:p`h^ 3"hL PFm4rztb}?V^f{b&w>+vĉ8oq~ J6(L6P6mmݤ m[uCEtjGJ r~`'vI8yg}{*tմ?z޻{ϧN:rm߉unj|ME&|06OO~禃 :U~0]oNSP3U,]
+ v^¸ ҔD OV=Ǧgۨr6J2[Q/W&xbCcaZ2}QNce+TW8eښ47gP&!lYEuYp(Kt>Dg@Ɗ
+[CTSZ1$Ր dXLLy@PB/x(/ p*2@ P^$AYBC@ .ba3 
+(J܆xpVSBNH[rZ~
+I0%QGJ.(x!4*EeD)@ШD(x{ <P%Du|;2mУ(|NA@΀qQh?YR~E|@GqS,b4@x53^ʶGϷ|6\awy+bap;lx}۷^~^zah|'T{rG?[ݯ￿uwˇomxyzdeUi]~[kxWN. Wu >ގo ҝ Y܋"]Oa:㣣>#oΊwbv ھxjR.5?ڢ-ˎM#{RI;J)GZG<:ϕRrϭUQRYK%HJ]*S_%•\tON}+5(ݗcer*̉ᅣD]T.ub_ߍHfvz:S7~ 8{G'Ns{g;t[z[HPZɅ"3 < D"dV O7q'όnUw9E\u۰y@ eU4Ϙ I3 !aMxXKD<! Q
+iH/ӧCN!LV@\x8UL5I92
+B1l!<Rl)dJTA‚Q$cA]Rܠu.'<&̧nD<b)3IQ9~oͷW8bFo\yz~oPxMCzA0rCe)'TŞPU7ژ"jTNJ7AUk*kYu]i;9>JOdar8ji-)ֆ
+ė&f :lL\;բ3[VOhaSQpjL嗹zoo;0xyI#)ώz +GL6?a-.`\Xp=xokL~M8G86&"*7e #+HUgݞO;X;ӝ[G߄}l;ߝ_ر$FH yQ6ni+cmMhUh/ҘRUM .S%72'v^Hl}=
+MZ's??d͒ɳ?ؘXL$)NYLc)퇝xG{>s{y)"V^z>C!Lϩͬ!F{DJ&s={\Vwͩ!.MPpPy1CƧґ˸zD_g%/v*o&GeGb%*tբyjTm/Kg=ï8yMQY"'T^EgJĹr<# %$<5%2W'W#8@e(GEIB%U>ηrZX MSLF;an&"](JکYCK"ϟ/ CG(iӷ]K]deP܋62V4ɥPE:,13
+HP,*q$Q
+I*Kb 8Q0AU 3f֡\+٘l[>釷 }V])7, "!AH/$of,Hspͨk
+!TaMKC<2JoӔBJYZ*u2VF㸒2Sn̖vkՋJW*UYh"m ]* Z7" C8)3~  d̝^Bp =eeyZ&Nt#y]6 \wz宱B ax3a&VH6^i[RZQ B-qqb)Y*u&jl-D8zLVL7`1?W$xe孈?
+ kB鋯UNM|&^\L^e1l/a%7ĭ{g.z7F?+W+rKExNo%&>,ۂ2UPQBlL_`k,^=OM=93ֿJ,<Vڕ:@$$Nnq39O;''Mv:'i6nbc 06 @]=Է4tw~펴$2?~y/mTP̣QOWOV|2aEVaMC
+io|&rjyKW|if&q
+AǓX(Gr3H3=)y*E+_voj}߹oyv\J ll%H %ˡ@Zt3:€S᢫20/Z
+mA/IK&[FI[t={L+վ
+BRٗ.N֕ٓND
+pԢt+K!.Ifwk;zEGkPtP՝dO)N'^ @R1^-+!NV
+CЦdsrc~ddX#یҕxErb@ܐ*1 Ď`@0Fj>P`[b -"%
+R**O!`,AL#1332K|ZeDMbBM+@`sp
+ā6) ORg$Xq(YRA0$. _f% ie߼SUUxXb6[Ꜫɶזw 4lqǃ9+1<RSuozՑ5
+ݥrzZl4yOճY12_pV=]Anߟ}tng0W mdIb"V$w \~%(CC1V+FP{oM__P侴z ;ζgNݾ1e}L1FmRD+֊Nʪ[H㓱RDDE;V(s3E
+Ut5%*gTL9>
+ %uHёAM:Iܔ0RrFMŲ)MjF)6•+bx/ ʠ)!dJ u2%LP9ՌXǻww4,[θM!c||6!5cM2
+VFE޾ak+KB7-Č՚B\rFLy 4u͛1X|f)+:j
+O+H!PT%#Wjy_=T>6=-ui?GSxJ c- +qP, FE86SjAK.7xTpm9[0VO~8ufGT+f'{B^60(jWF'0͈Tظ8.5 ^0ЏO>X"}lAy4ZY2yϾ{mx_ܚ}7p6 *8:Qs+W`(I[%WE\r I_0kTVykϵBܚo=U Hx&Р2AD JЂ@=:u3e>Muy9ɁyUd8 m]aOάut!^UgZTR
+޵0')* 
+0Np}F#zP $6Ñ:hF2Ζ,YdĭYn0`|cUB@%xx<Y#E@ |Mr\ "!@83bI1 WR2T'
+
+U$/h2eEjchUb73VƭJ
+!& s"rnZ*@.i3D2i}V%'Eu
+zqt|8%)'RL@i)PfZaLd#1mR7|p'hėʁ}oܽf_n^ygko nj7]%O^qkSYŮ/[cvX/NY-خ/J4«@q̓mega/hY^gw,բIzT˖(W Pe^Щ:M $d$xDO JdAJeXqu& ˳"~Mv2IhS ϊjui<dFF.=:ڥ* R$(5!KULۤ .%R=0{ReݿF׶_|3;׶6u/|DvԧE5>ڀͲyS.Mǣ P癰Qi+U6 998=9 YƄͰ%7R:13!۾lR :'/"1ṢC(]%Ka7S. +1c,tJ+W.D ňDlypp=$.[dm\p8|J 4mHӖ0Mm:0m'IO'm2̤4sPi1@ߗK.[lj[$?޾c>1J`/f+l92`+ͣ',ʘe܌tG3A05ץzޱ#978n;w/4=HsSjm;0c'b %t/'; tSO)"lbV//
+_0, }I[`S5lo^W%R)N]b]IE?nƄ0QT !6/W<q΀Q(Ur:E6dh2Onid9{Z]&ERNE "|IsoD^Skh Ǔ6ϊ<E@@<Q=sluj12`5-ABB)
+/K#D5bj]^(7*[)[ ]%"~keVT|Hy9% ՚1j^LUR+aί)qZ 4C:^x>T]=dsՂހN$(Vr236&zMn-%9r]p,Y)G9RX~$H7$&CUǯC7^=dUlZ^ >7_3wſΝgO2`/3z>{iGȴNd._S/.X}@~ܦH(H1e:N:id3̫GĠl&&-P܌%cǮf>&{c u=q\ߑ#DnweaÂh3vP_p3xK݋MVZ+-7Hg A@zFIxl H9具FBdN0;e|+9Bod^
+ʫ5e.El4P
+@YA_k)ksH5=M5y|_F9Xv&ń 480x؈U@yaER&~_:pmxbI F}]`]xژS0K< lP8]J ALguc9=mt!s=gSO}~x|7v||`mĽ`ƉW>}~OO>;uZeѨx>aeT۲Z-,t&Ms AYJ6[<zR#+vwBlIߓU )5LHWjГ($U JrS%`kՄ+]n='D5NdkNlR^lK,J1Z%rD%3ϥV0TC U)1QcjHˣ5W|t'FnEk_J'5dZ6* ?nk;/|'/>o#r>ozϝb)5xmZ粜;DQy1,K6VjwF̺PA&-BNPe<\>*%"t~p[9T*JL#پJip
+v7v4+wz掊={LR ~o0h&l%̹TQ#RIzci+1+&a)-IX0Fofe
+ӄ GDe8u6^iP_zO~IBDo*2Yr@x_&80UZڤeݼ+̤ )mfW5[@ 1:
+lti̔dp*TbAh(kP'6&Cwqq
+=?@g#6X;[-J۟7 ORSn
+'7Zort;E]8ΗM%\^#S'LܑTBsqDA`%@_q `8 n4F +;:?g!M ;ِ=΅Ih>61ը<_UN@ȍɸG [_RkC3;K-E]./[İ$"'<é[o5iO~r+}:5@-s#u){[N 3Wk]=mf0gu)}e6·wVl,ٜ1hJê2%͒A7J! 3*RD$6zw䵲[[u[<7785-sgi
+jÁZ~QG矩WTa2"o>3!jptY[*/ g6,_Y'Eh,98u8TtuFt<rQڰ
+7
+/ n|MNojn@;νN~w!uo?pm=o~EM&`7,]W3a
+O*}B~O>XkQz^vU vIbh?ٻxM~rI/]tN4nCw["T€SͧM`v*+6*)X`EeE<+1NHJrʤV ]@ԈI
+FgTcZD
+`bQ` ĴyXK/=y:::ǛR!c27IC!'l`v6
+:,9q[Xΰ2ebRvRS%ݟ_U'?Jֹu-n{k[zRa!h8عWznw+bEo+Pڜ O* )1.NFOs9/
+݂fƣf3.QP[t;޼I;xU/?yl`ϫw)ԍEHRX<J#ZL'UYp>\l$c
+q bT3*cOD*%ɕZz]"o"V"i%\!Ŵө`JB.&uZk"~
+F|_ӟο o__88vuݱuOukuor?vwɑr]V+BC
+p b\|X|ps+uTbDr}
+3CZTve |~$/I9ұėD4GIWD[s gVR#fbQh'5OE1I!gJPS( ٸ9(tyP^vu)@
+pW(u8e/-.ij&"|-EP"Aؔ2\dsP$Ok˔^P%  +O9FǟrE k]KcWO7 ^r?ې5n,KHH )e:WTLߛ 8fVŚ_ ^;~<WIW" PrO@\b+DMYZF j#A
+iFCq$"$<-ă:T\,٘P:@C2ʐ&O.*c^JL#H)0VV̢67۽œb٫T8굛KznUvX)I+/Ӆpܘ
+xXkԲzҲ6_SǞ gB_ >EP:o\r< tG{Ѐ%[yr=SIM$ļoH
+VLM% !ꂾ!Y
+AAm"x cĥ_;:
+z¶/!?^f^..%?"-D/ uIa"~o_W"]`#6ҕ)cwO}
+ͤa[JW W!D-l,[,:.?
+@1H$~tGykKJ?*)\ۖgճL#EA/]dQӡ
+!ES+u!&nN>O﮴e)+WFۣ&֣$_z̲wn;|ϪUͶѪ* 4flڋgx<.HJe4,eH@
+R7Youw6?O{:Lgڑ ,B4l_p3 U;!>VQz/39b7cYj'ob˱4X ]1
+*,ċ,_(sD
+RhNӂKd^`*q+Ub P⋶|:~Zum\uqOW$]%7Z-d9^ YNʬ^>[>nhz#.>r띟v]{ŭnɭ=g:5dY>7$@`u+\8E (@TYDBK*R"e*j/+j86Y3Y ;BUOk 5QˑPw*v5{q㜳$w[k}ZυJH,5Rɠߋ=2]жx4@ab*ey`tyPco
+FY
+R 7-VD0A+H_91uۛ 0$p68~M-gS 7HE&7Ζݣ|NE&oay/>;^'U5j>*3;CJYy׍欆<Є7H[}3]ko%3*Zz>:6گ&wuo;5sŅ{Nmhl%:F^eNu/0C '$f]%2\7j %Qu/~P#kMkϙ+o[?;e sISt#yR>~q)rFI44\VrM뽦5PҀ9p0& -Y5c90/hv6'v&`xY65
+CpRsp|-2'h_48 8 dE q* qqu׼6kf,H9a%aiO2bü()А;ޓ گ{X[Kzn<ӯպygC
+ԯM\3uq_CN3z: +|l6B@ :FIh e^oF極."eec5v.Fhߏ[zK ĤhCL ^rF5g[)[Z>+q-zU,0$0fkЍg1QA>LP0ucqo6yp戥;:|z?蕣<6S9'<(9;VEwƴq
+Ł$L*H.WJQ&s(7 įwY6#v1hkr,N(V:BbQ 16Q.27A.QF/U >eDbB(qxï-ڡg_1st!o37x#h%ǘFpPNߥFL 0TAAxt[n"DY0=5_J_mɶ5X&co]R+hwgfe>3ۉ m"t4O<婖W2ӜSfc0" (&WS&njٖ8Ks S1G) u>wlSi%&X[hOQ -<.GrIJt:Fwfۊ/]T>er7r]_/WKRd+/|UTK
+sV.=eVI:5x1
+b'>)#u>ֿ.ƃ,
+h
+  EJ
+ѩc P2 >aRꂚ#~cp$Y朤9ѕƜ<?4). ߉{1''cl%&m `&EK" b]na] o7t3}rYŞ)wFsZwʪx/2=`]
+aUYn~-XXG2AN5e
+b^rKN%[?c%> PuHGsnZcz[7%=!nu(i'hֆ:B:葸:HքȡE|U ?i1rsC ]aeXf
+9D-1$ʭhgkHm@cY1{
+um#v!rK{,&o&Awx5IuƢ[b33ESJTϊqQ|5ӲD
+3Qǁrl}v횳KF; "IX@Am/JK_a;.x 6LBe(pX 0GɀrMo'uRIAq흵g186( )ڹKXzpPg
+ËK_GlX
+Ùy E^ӲP/&#` oO,td!`;t
+>uP|+hx
+#n22 &L@:Lp2R Z?^a
+Uv~axu)7E&G|B!Oc]HbՎtWlwIkykb6n t,jrmWw4!"X
+v,Z,W:ɬbOr4~Dq:n7)gve]ɻѴY?Mײ-|Pb79(Sr97 gڟx=$rhviTڒ1hH:~^d
+w6 5n Ect!榆r@C#OBP_"qFF"3ݰ3MY)j|<cyK[$ݡJؒ Yl5"V살0U3\!9? 3(.D€M N8LuYVZis]\ t.1pħ| ƹ,'; Cۏt|{Mr!$ *Q[ow_n WN:9r&8-tV6<q}>ifBWƙÇ×w~|9R@?۳xcD;f^|nMوQ_82Q?({:9oAd}U~N5a*<L#97sMZmɷ9 M7Ỷ3Q"Ă0͌D  `p bDJ~ RsSB "+`
+̡zJcG`;{{NM I/Xlot=VV:$';lCx"f-#nn:+FRj!0Rtx1\7$cB`FBq'R-bcy'i:)y-&
+q+B=`+{3Q +~RP)1H93fWV⽴Rx*c,6 J[t֠*r^:SUC:.B<aWS`U2hntYT15"uf-i/e9T^H0+%"RvFoRj[~Al'v ؅
+|݁ۼf-ȩo w%X mmahڬ<'1Q̐PIHƋYC2
+F,a:戛/ cA(9a*\a/NR6:lU L9|~H9FI!\"% WB zy2F@
+˖qcfcڸ8>>f @#!bn4nVQTi#EUmK"VJ\@ 46>fl=v G|7g"4zMNH,4)nوM-z6-n2/
+299TyMWzX-]( #l JEugSꇲz9v!Wq
+7-ƖBHw WPX@ȄGO b,UDHE)c3
+1.1 D/̢#k"/ز>)Dt{[|oozie@nV@ހuNٞ_t7i{膠|}`Ҁ|ڵon^c*bB֑mGL6e޲@(e.CR7!<%ng-ݵhb%/$UIu
+g}UYKڬ u@eQ(\0*R?MDV99彅O#TS\
+
+vi񥚼1Ӯ33^V͓
+dzWU۔A7۔Q Pg[P?7t]v;NE! -5'fgQ,d aY .0dӽB@ !j/ZYux/<"zr܆li
+4qhY%;n}1z?02v2:Nrθ8!ga[ "N*'`g;Ĕ}Iq
+:M\(2șqgT4Q=d`1S$-l<u.`(,1azRˑ)1X2,qLQmX&n'1;\ۃi<
+i~8<̣I vgYp81Hn A7{km#HW zu}kRv y6D~)YuxQHѕ^PUf6Q뽣_e=0qbijrvfvX5RW8[R))-{\f玙Of~
+
+OR Cۨ6*yR-ajM3| ]|'vLޚooI[I~Xbk{ܼښsJoZw"seu_㴹/r Euw`0^qqbxd+B$]TI#~ɀ〠OW-3#\G;uNj
+բx{=Sr_WY&2*\RqQi* <TM2 ,Khd%8f l'8 Nw*leAjO.Gvin=d|~Qwg%hEb/iQNU@U!Zo}
+St:!#~Ԙ*Hc D?)
+Y=y5V";Ƭ]H7nl ևݐ&* qgl ("KIKCj+]Hy{Sr^d\E "9kٰcO(ÌJgBb)%CKūB>:] 3\
+ݪ҇yfvI]稸;U}5Ma>i ^
+v&3=2gذAe<A0<=ֽrkfOD4 W+d¬00)%dMS]էfblo|ylUSMi#7S#~88{ڱ'{1ד+C=5P#Pۜ]Hɜ.$+
+`Mϑcp)\
+xT, ՀpVrj} r}}+-U8ZZeJs i}uh5"X0þg3T R% %|VLb-B|Jx- "čh'Ԝ|`u!K-)ZY -.n. B%l:h߶w5>qrRq& 9 iՐо{u<zQ4'ٚx32;( ;'bWC`xkGxGЫ_ůfhkv%9.ܜ`LcII%5DbC!ڰsK. /]TCɘ 㘀BUGfIo')LdRXdd$`2`
+
+B_}9/:So!ꥸƴ]0 Vl w7G&}Iـ̗jq>?5eud+:. *B
+H]z
+48[Rüs63$؝[g,$mMi&
+d&))^G,l
+Ei)S7?\"`W=Vd4k.r#9"oq`4sL4G荞T_ Tm=vA3~Ζde˚&mGVE{ϗm >a3 R0q11Iʘfcb1bLk tb Bq
+@Xtxa'as,/na%a} cgH8Uڃ`װ52O?G }^EAz
+
+^m/2Fg ǵkW3 92!7} -
+Md? 0cwLJ%ZK~\m,2 =`
+\⃀ܛŶ:,9Yh:۶LpjIcu\q~*8aVK9rxTvYYM^p8:-6+/ݧMd@%bbӼ,Mg^D̲n8ylIґ!SMv w9-t?vv_|6~GԢ'BɗI4 2]zezAU.̚թ t-)bҝ'|dq
+XOKndEkȤZ"3d.q?
+S]!1׶_U7*yfÿfLyܠJ S)dXf_u7uolu$F7!{xnַQS(ȼ-If6jCq2<F>Jk~/SKƒ8"z=~YRaj660Ұ dbQ) &,ٕa bcڣ`XFC 4zlyL[p0>lp csmZ骉QUZTTm#F[A@8
+_7L}[ j7?d;פ:>w_~}woꞿw>:?pcWV0CL TlL+mrKo;Z t1;Ôvx|
+>Ïm{GT}D!Mz<꣜ /3^yCIlKbseN O- ŸFdK<$vC⣤TI=&5iV[lHv-ڽ7iM-WPr9]/%13SbTprx#G({pX(=w{D7T^Uoy&;e,hMB88b~O6%4@9ތ$[RʪPҊr&קe32j(愼-ϢYIh5na";<c㠴ԯjUƱ5ޘ3vߘ2%70%+rB7Qv12 =*sr.ڠϴTP)֍RBi6`v `".PQ hKAu%\%`c)**8*;:ƥ{C'FBGuCX'`巧O
+*=i
+`GNexYIT۞\,xt'K zaI0SiAeVbdz[|FN=\Zw8@) S)nе
+88&Lgr?\yn;Wmg
+&z&p}Ce >um\ S<})ctn >WW=3 FTec]oEH_+FH#ƎV ,W+̳#pso|a-YȡȠMB]WJ|bfngz7\y ֐< a=.8ǫ-j}ꤡKؼ4W{QU֡Brbihluzoa~P\[6 Ӵ'\\*2ڤ,uF>7&d+ 椢YK-}c$(uY%hjVqU_NH_q-zY'g3\uQ(5e {K- kH!e8ZK{Yudgy>C̾p떶ldl|0Nn;,s7ЫeB<1 @f"pT$ !? qvXl!*!g$GI_D v֢UL)d 7,;/FjH=1)D$Ko4
+@x<f3LO|y'-.7lr-ʂόF0e?\<Tw/>xSk ,m+7ǽRፏ>Xa\V69)v91Mݤ`e
+~.
+=UDcEf?ӖܺUFm}&x84UOg{bcAW1j;6o,W;fTe<z,HZO׉3]<YSVB
+zeEQ`AXEy:h> VT8#ZhA;j+Kcj҅*L I(CbUU*)X̭S=#:OYdw^1YN96+ K&
+١ 1G_cj/ 9A|^Skl[,p %Ru$V0k1>࠼5@aKteÏ ۣh43S(cL)L1pW1ѾDgű2*&l5GL⺠ ,L;뗶!%(">.n[LJaVōx8:Eh[{}=WNfYR8'zr?/GzW_}x+3yg7s-p#fqXETC(z`ߝw7˿QwCqxl_ :}T?6lħKo pF^tބO%#%[V>jؙ`VD!6j;~:ȮOO$O Cccy*n|3FLd6 +OnGsX:-}-ʀ7-`v:bG3nLAQ&2+!i?JLy|ZXxb+q+/7ZW5;j]#FQߺ:{ܱZqL¡:)e%V~c[+0d\=$~`N X0Vfv̡GذRSf
+=<xWڈΰ
+PLd(O|Fs8of.?"A_ J)Jxۉ] 2!<dIĿɕsfnU3iݜ(sc6@J-r j՜j*iy-t1
+ 4vc"_.4Vu@O0Ɨ6>>84 -)i346fNC?$H0/۲,ٖ-Z+k5mg2|{3~zn8g_Ll Q>ߛ,vUgf/Me]L_m,(jUK-yQRwޑգ#2&)crignMwQCx`;GBx$yZ~%C΅gY~bg-5=P:#8P1|GgMsCW7/f5#@s%Ӫb4owSSB` ĈOfzԈOr؃D1gW@r =<Ji>c8I,mU7Gr:+$"8L}Eau]k9Jh9=W0(D'L Rʜ"vməVfܱ߬64rKFK'/&/Ϳ<sڿ[MULKz UNܤ%tggZGԛj:u漱0ɢ: Ibxh_O#?.^H{ 'T>]:J8nDlPn^b5nO~Fm ~ ZPk>n'5#_&㓣P#
+Lr-A`FpcCjftZTyIjSHkO=molv&m_Vb+6
+Wꤽe_X'br^o, 2K#]7@z}`/<3"W=.yWvhU|EyGn0@PI<Vf>'aXg>]y% ׿Ws{?qͫM]>k~ua}_^.)Jj R~aK5JOyb^ס*瘷ۀI\èr걻`#j :77['ܷD~&ɮw ~NͶd8nH.k*аzG+!X0bkTeDYFj*HWDrx}͆*$kTs1=d)6·=PM[:QuـVD9#x~1}(\Nt"}rAg썱s]}NՌQ[stc59-{`G [)e<-Z
+D-_o?V˰={U<_`/C#&E 闁0϶,9{/>x黿,6'+BAa,`~FkɁFuS)%B홡l,VSb3 DQ#-m%ѩA_f\NVSuDS" i$R;Nd'H*bD. /01 Gh<D "^cW/ksc[N af$ TlMt6
+i3gSsWX4;r" x`DQ#lMlwIni7mN3i36\ͭ"g@TPQTT^vo~3|^4&i86f""4lޘ;6e)J-d9#,^/PNe/J}4C 2
+izFC.O٧\m-4 81kF $%*)Y<Ȝgdsc5JHƾx.I9wڝj!?W#$}C-+MdU^%iNAEX_ʚK5&i.q aORPDSyS!N݌q9ٝ<C:}f>M;f3cfoDq)/F h91V'4|_oLi,.M޽Yp r/gY 6Ro(?ZϒO~xAx2E?JUu;$t< 6"B/`uğe
+1>`OPV=H`Q$L@ɴXi?F{Io&apYy.d+iTƜ.H K6.M.m-zF
+C@9HP}Ig8p̄{`ɣg;SH0Gؑ%(N]8
+%(ֶUC”~D5лSnb]@^RZ_PORل
+
+݋FOlU`]qW
+q`(
+a
+lw˷ϲHf3/vf< #lwfP33[޸.!4wr~^
+PDⲛK\1 %ėRoFe)[:l֔b]d) uwȇ ej/C!TH7o\͞p j(vfjY҇YC7axEr9x<qHl\rsÊFBSޙт2yK݄ۼ!wIØW!>6OIiA&*p
+g u%g]Ǭc t˔˻U٥G>W5g~hlշ0Q.d~vJP)tO
+*4jpF)j0z˶rFMK3Lӳ2]4ٞj}=ֶ8i$,v'xwZ])҃IdS"vWf0O%z>PaH"~$(0nA CM@(N3;8CzBp
+04q؍ ,lǂpp
+oUH!8P,?8"*0߬ ?p85=B*
+"|93DM".AMѳ
+ M#R / ;S~[
+ï9О(rg("ыz Yx(ORb\*>Bn =a{{ bOCAZa)2Ef9GYkDZ|Jt+-=b022Z 7Y'JqF[W]ݯ# wW76^tϿNT'[W^xO>vl;GZ}1J5VJU5A)C3ۂ=!^vCzGm ʹ6xUk8i|>bMwt6c?+*_?V׸ьS2gisL47M1GZ$W|HK?!Jϰ|bG/n#k+& q03dAQH\h جӘ3
+9O(#{Jc=Q:,
+Z#U6.\P?r{AG>If?zɑVQpcC_鄚Tq~ 1vt}+n:ry"ђK9;+Lp c{ ]6qZaB"YS&|QB%`Mx~Ȉ*;H33#=?ysާ(M/͍5ֿ2 >AUo(HfM2
+ X. W/]yNwfmqJ[RhQ=
+[Lqf OVHe;3~co]
+#K0U-b*-Elm
+HLde
+ IK\VAR^+L~U~)^a*ZԠ\)9o=Jh&~k# o5PBDܫ]rm͖'yAGɒwcDr]a1}ѐCDL<=#Wlmzt}g 8FV@}۠VPuKZ!cyUv#<o
+#V}amNdْu4q|ǭ}/n؟杵wN{%'r/S
+þh-zYdlp# w `eŀEU ~K* V fs(hAE糢eX[B%2p_"66OΏrDX{Lje@ b":D½ifJ{G}ɜhj^F%%d :L; w:T5>c%%d+u`mWBZQ 5ghSڂ űHow'D=vnp(Z}pg;yp8]d91o:6ȍǴqB -͌B 亠T^ ɃJ"6KN33P27t7RoQ>Ʉqk?p)`B
+
+:jN
+`U]Yv:[kgn[GGqmuc X )rr Ǜ$Nű>]`Rڰ-jg7tر<@,s m`7r{+v]H߽Ԓ\ ;b \ }A̘m)qg|n|gwoU|pK?էooU>}xOnw;Wo{Scj9!kˆG BhMyxWnrQOQO>vb}Rq٤^r#16YnFmv4I^`R&C.QNSIX:+S?C8ihw@5cm>{n`"&ޡwsQ=jQ 14+.eA1
+nL3ϐtƨ(A,Sa==t?K͔N`7c׃k%FwM$ms;}B`0%BO_?Osœ7򜉩ޞ曗%,<1P1WW
+NZЋԑz-Zۻyb
+YО2$+
+
+KlV7ow<>CB:kCԟ<DlA,,.r:XB@ -D-T:y*7i2o3'
+$VufNW[Rj'Ѐ4g,e±-R
+D_B{-aL[Fلh6JT{MZq>jrZ[欝gf*&(Cg$<D$&'}r cYNT4Q]<"j\fZXlX->o4?vϟS,'t`C&P~>|
+/M$UJYk&<^oa<-(vTQUF XEܴZH4L9H"s"FL5fB^PQ+OI27R5#j2^' aVk!MTȆO/a}t&y)&vO2xb8,!@kƕi.ZkL 'V7 N>-;r4` vǒp(v坎vQ-)hveW)DG/iϪZdeCdx
+D$t
+Ŗ;|83K&?'祘69\t<N!LPa? .U1St̙V۲\ u"mYtZh1G{
+v4Z)'e2v}oS㓣: bno\cYL g#ҳzYR-4B_(*_N6,`l9QKu[.Ɣ!0N!coSs=.s%gҁ?Z{aWs9nǰ>!=[v(4
+楝-|J? VKw"ImH1V8!E!͑  / }Q$5 R>RW@C@wpPɀ B((c#PN(CTHh
+T/Dy<
+S %0s>HT?DGYhUrjy[JAZQC_%S)PImn}ſFl3d5}|s;:؃,ۄ{e 92YSj;JwtMo᫓ OcdVW27s/]ΞbWN*^ֲWʎB$F>
+ E䶫I+ݚ
+w5۳OyG߿4<ۭ)xlpSc.eMΜ=5Z~MS|>ZX;xpcɱJ@<.ȇV9F{ŀD-F݊S?<~Z:3^c#̦X{|hRM$QL 61:ߥ{pɶhlL8
+oR^+!FJ@[h:AOzieI~M t֖kҲ+$*zOp\f\Vt5(ԘURj~#7Ex.bJ@
+5]T5L321;+7ꆉG^ws X>ɿq,P0!11$B+
+샹s/3CR{a`RZ̜N.VT[ʕ=IL!pCSDf~&8 zˑkwz%ϻ/gڏ`uZ]ӳ-19͹|ְٓҕyM=)[T[7_$y~vJ<8/q+ )NeCe
+
+/߾RR3!":BtO :PZľ يU.o:|D;ϳ(C4xj']L:Mm24149b+3rߦe+ԅ*C۽ AydE,md"t=-e?5t:i#=
+ـ^#37ux;@P@ڨ S"Q"B
+-`~Dt/{aнGBِ33ss^ _7IMƿW~I4"4R2MD.$[ iFf.s,Z񖱻mٽ0\Qs ;hs6[hT-T+j_V>֟{\D q!_7HXE=-*+y"Uuk--oa{(N2Yv42DDSˮO*= ZbB= 8I̅B
+b
+QglL_)#ԱNLi PT춊u4DJ;UIͳ\}Px}Ǫc
+>sZϭu -dNɕ{F_sF˷W_.箤|i8<YM
+/M5:= atR̈B>xGg{fvhi,v d
+(lϳxPO\B
+;w[)LuDv
+:߾|.0vBۦ֧ dƗ@ZWRdvB䘥:<U9F# _~Y|U|٩1mhg +1e q@ȩ*뛖Ӧ\nÅܚaOA1rAO\tדV+2XL<DeIaw+̐#X|Kd|TѥʭBr!e_*[4yj7_ڴ/:vC*L Q;/h>>
+bft
+
+5P}C51}[A6Bnwю;9 /#wog~)=ֈZݖlj?UZ'?Qn=8&=9A/7Yw?qϑ}Q-dm ңfXš$dA F4iNrp&tEx&l,1"R'y9 "YYŕ8ƄAZR^ɃƌPXijBGBbPP';B9 8 c`^.&
+e@_E跊rf$h H.Q&jϜ0/rEZ9-$Ε.ԨYYT(p[(_]ҳwPsLcں8g? Ƙf'!6= ҩ:J)v2fIF3F4UU5eiTpZ
+>I+a||wi =p8i+1^!h:AGP`KaW 2bK^av\[wɗmAcm++ڮQN?xaeS$^s(;QeEz3ar@0,TPy;3qFT01gQ[Z5չBrjMD[2^~plIT7]a5T9RЀ,L57"qV(YNs:\߹l}7?t7\55l|♮-t@v7s*Lq+ϳKիnRHJG6H?'4);HΪZ-8ϰaؑK3a|<AkKhF;RsC(pw<Y<nIoTۯ6Ȝa Kv?h<窗[[vJ>]N6,Ad- pc_^xdk%kƛWVrԈ%D
+4I=WAV`3-+k\Z.Ξػ*UVAziWa|Ե^r=Nx%W#t˦3o':}6q]uTިV|rkE]Y< 甝dFS]~mggEEk6Êg aΠ#a|"QQ[w϶dWׯ=4
+(׬oOd<M'  #*"hF( @?T 3AJ A B)(NSޑ%0NzLVlj`&1 B'
+;)EC(ND,
+}*vY jIJ87ꞛDFT:V!PUg&e1QtN{z`x9g*1NgӐ8\SЍ7c ao|-(LkI[/هaJw0eDU YkzQ%0(XX]
+bXߝ{~-h綩0-zwn[;W&Dվ\d K٨Y&k-P_s&&ۄ.$W"ŗɶ0k!'zA߄H6$Ce{^;Da0)G#8B^v|E!2 Q0 '*RhoSge[#~ARlj*}Jy-*QW37\R[]}W0U$U'*w%4鸩l{P
+%s ;uDRqK%tǂ kP8-r;[htq3B:9oAM_0/ʐC,m9r;_ဥa$҅@nŭ",Q88W% ٲXdՋe(T
+Xː $%8zl91=_a fg|pq%}>LIHN2@6HQ ωbXL$eH0N]?46vwhҕsA*g9NRu}>lo?:ukY<^T ƍyVߪb "*N
+s,32dM-o:
+J=SZ|]0Qa2t,:1HRJ5ނW˧z_#K!dnHzm wzK<wU+.,ӉdwY:>Yb7~K)LiyaH]n\|TSϭ~aQ sS"qA(zg_eVM]g ~e-j5KWvhVߏovhCX\|$Cb?K6mKf&rVi<N]burˋ#Cu@_
+3=bhS` .4D)ʭu$rYZ|;s?5z4owiG_Q+zi|4aeP1IO
+jc5: P U^N -9'd3MG1w&!Yuv:;c=θYٻ@AҶDn[e \d_Rή^q#nZ+
+W,*/yJt6?e-7}9#َv49-} $b;]H+8uЛ-hv ዾz{5q|6+w쫳F/:tǴu
+:p8$`D\
+^hv8f\=U0l:N1\L]'ţJvH
+~R싔ʰ_AUH*z/EaP{0{0Qlab<G j:OciuVaB]FBn
+(asZU=JN#WtצSzSNؘtKި[Pro7?p~|7ʨMM[G}wä/:N3R󋲊*&cDzFtRc&Nco~ CR_&]A]wv$W=3C#c(X$1|FaA\LJXItA4r-*+ߧ#\%HŠlt 3yּM @,]N &GWQ\ꏋ'@yЂ)ɧ
+{tv;7&rxI_O@oo~ <4# XB=U?O~EdKkOFӑ}~uP ssP|EQ HJED9~ͻ-c[;mFˮs/H7anph{KxXCƢY3(tk߬>6/o?m_/dfazW~-=in<å15:r—vmU]1߷ܸL뾍꼸pߟLx O\{OtbZXl=ajQ7ţ
+CQ la2
+5]nm9:MB)&F1\ ܸk {~T
+ItH%|K!:-)v"Isy%PYXg[w2}#}?0#mܖ.&+ S~tszJ'1+hMLK32o] E 8yyAn)mί v}jB<+V]nY;X}$<և!ɾx.נ3{rN Q \\Rzz]uig؎~iw;ۺ;TWD, E4"$!rONz/<3e3\V3-=iLPgqzmx A t$~%9Eg]̃jmH7I~NkrB=hK*HC|#&]<GO<%M`9aqsyh_N HɻI5*+CfH15R~- woKa;ٗ"Ot$kF ,='3^r9WlkjRO|o
++; t>vnp5#.if_;
+>wj\C]v#`?1I|a7;˾n
+#Y/MKD^bUbZ`C;e%`5<}"ktdڹTk 1JJa8_,ȟT Wjh9hN7xs/1Q_3cms
+[{sݘ Y{CϔS豠]鹰RG-S;^YeDIm*R>#9؍$ O3b
+&?1Z
+끂*^taG
+in̄B<,F-
+i G{W_vTD$H9 ӾvzֵoDwbʐERI]4l$m0|F\QL kee^`K!I
+NW WE1p%65-(/| J**(v-E|YL1s4͏:՞Cy
+g8bZJzw0C?,*-EEq^c)=µ@u {pQW-wmEH.p2'oNj pDS}m%x~
+rnc)o͛Ԉ7_9 mAScy.-Qz7::@Kk9ym6ˀ= `3DZ yp _]Puo9b={\ͯS 4_CҽjxbD3"#>Z=Y9&̒qAj(T)hV?h]+*d{Sqd̡Y9wec}iԨ`)N_]BwJhpqڻckw&MI~iC=ey2X<OSH4 S!΄.E$HXBlY(
+ICrȂD?h 8s57eO>)*wEGQl!ra8Wuy
+
+'LB&y2E(T%0LCa\ %ʠd0*1Wӧa#Np%>FtT[]^a^,IړРm3i牢;-1!l<fv} y{B1ٔ24' "5Y`dI_Ug5džm9Y/vznhmhNR7/83E7l %{﹋b;;؄(fV&)!ӯ: J#q(o[;g){ cDhB= 4h=x8\N[!/l%{!`+0X X. b+w`9d]#rW9=BD9^K\5K ]_Iv]]ڞ _6M% vwh\ڧ7:Htcf/OAzw^eP{ҷO܄rYpr6tO/X__`ܫ#ɓ1'U}ۺww[CC-Fcif>>x)ގtφv$;3 o;>v{HI9<>oF%lmj{Qhq Q2$~E+`b2`~@ mɉ]ϢoQ~03kE  !E|9l!Vd<<'!B%Ҥ%)=<iA,)\w q)98pZ6k"oPVgaq\7VŶja;δzl]xu+v=o4ڴ*c|qr%جըjDŬ\V3g m^1=׉GsUG\y]͏CfU UE*Jf8Tz цޙum֧lKaIǾtv)6ef~ͺNN~U[^)cQS9m0WТy/Jq&F!!Ђp9vLV/,P :ٌ=Nct|:{nut Dkmau_:lg,$C#Q N|.
+}f^˙u$V7^uhe!Om-/,}22#ª )Z[v4N[zZ-6U⹐gKIL>o[1k\ r*8=I7 0:VDM$bG(YJ~ȷF'ăzm
+ΠPoZ}WXaYn?+LWG+z-×Y$ą5`Iyڪraݫ**p
+)`1e7.$#')B1)RFՅ}ZL̥4CLDb{J; 1UP5Q MjU2:k_V˜a17pcU:ڪX2)ũ y0a6@~T3x#oqvFdj5wmh=C'wUvmn +{mk~-j,NGT)Jh N }.
+ozְx9킴b 9*{V0H#H
+
+{(+lk {
+< ST֙Rڭݡ3V 2iOOgx ,TU)H <%1pUֆ4n" E? ӧhm,ё!Ɔh 3Z?||
+];; 1(`I/Xv~,רzW<@M;q5
+ q#Sة1O7wQuqI ngDմC<i8?e" zAbotčIN۩"X[ජ~SΥd^.oh[# E9}Q5z2BN/\p|vcxё$4
+"[}kDُ6#`~tp DΚB3XadɍB$aK'w'Z+9_$tv#v* (3O0X b!F\9|tR[X<g9ELd )o/| )g Ӂ
+]gPsѳ%4."ͱۙ9JTArak>7Pb쒙7Ĝ-k틳Dnؤ1MX(%=Z 
+%!`Y=k?׷:~/|~
+[ i` RfDB_LhJQ_c%TO7yx0ϥgx]Bdf<Y`V{=<"eęqg33r88A8qBRH܄l[(jWb ]UljgZe[u?,{t Q4
+9L紝=>xv~J<z
+.9y%&TٵrVڔތ<wK &8SR`6iV)[Hx=[].{~
+V|휲kI鶅^HEp`a7i̹5k}>|w^g%_K3tc_5P
+W@0^&*Sz<oSO>gN%7q)DW7%*jF8~ԹӉIىHnP
+ VĔp۳j5 WUn͢,
+ N]8@N- @vV3I*3fg>
+
+GIΧ>|/)I`RE">B}(uP B7!JzXy wQULHxׅ
+r\<Sqb!gAf!IQ:?|-!a5H,wSne؇|Oq&
+(7)Qel" H Pfqqńbw+6OnQ&Vj!(Gy{uƩ/&9
+eL 8pTE\2.Ai[*1ş\1 ezQo)%uEy[Y
+M55&f^O#bʀI$pUmaٱ"zqmB˭F*)[,ݰQC,WZ` 1~{Lվbr/_FVi=eҷ+Dq`_;Eha+ɂp!ěyW&=#@u|J$jarp8z\R$xo/i. wEG*E$.<
+n¾FlNT.a"|1Xb+*y=`p 5}jt9>ĸW勉(
+%e|q! P9*B=
+}jɟϷOlZOW0;1il[o^CEPfq g٢
+jK-ܪxd 'v9ƬBWTHNF];S7nf·Tq@9%[&[+
+@OHOPKYcp0Դ6WѴqрѦֽTU/o̫symMƎO]ʗw $Zkh|P2[ZM蹫c ۯavq۝cF׬ \X`XeWR.Re yJ'YdXE6E&T{+&ꨞ]SgE"ɚV|IK-lHRt:.c!Q.tUlbjk/M%qfft ;n˜ ڸVdC騯)heP[:xbgW@ϼ?\}Upe/:![UzPA$>#-*w^s[e7E8ֹ${ن #K h ʩ;/*8'ake& pEz3ӳP uhh>!@CKG8Z"m#ӝjh}RJAbҒ=k='tI<`36h<4ka,]>lD?I*Q(~ȧoY=_HGhzK)~V\Jő|\GKn0#18ӺB#> #\v3Fnx8@Cx74Lf|IRR`8{nqQٽP/eVzq~cc ̒
+$>5P7| 6UgD]d)sH0Q*'
+|:3w_B6|fxGr 龭_|pw_9~Ay}qu7k}'ULU/ S<
+WHʇFe&!ԆejW)jP)U7"BQ4i ͧc n4*%]KH3~H5͠VB 7)Q07y-j`ZL@y#.{%*+*zTP8eIɖZa+C%Vm":kK֘ū`0JW !P7q<3,f%ݯ;2QyV~ְB_Lm*KQ)*ͥDb7W!T#taZD($
+d#a"J$H2~7MBs
++9GUSf |Ͳ{rpt#jf:S3Wݱ!oџ&FH~0xM4佮
+,bL!R3HO ܝ93D!Cj n
+E-)f7Ve#uQgh^[Ǟ-0Ćjs۲K<څ̥xfa(pfgwSwp35]l|(AP |"9C$@AQ Xq8e-K1%
+~TvșSx<5
+LӼi <JBcy##2@ uu!&pMߐvԘtuV޴i,H#4LS ,f-` nC/.:vZq.8BvF&R'!(1Pk"/w˻p^:P4CG#AMx$OQV ]r]q5"-&%b%_P|4jmԑ剬$.Ŀ__ O?Qx;1XJK@Q8Ah8HD.
+D\bS4(@Dp]\Nedx6$E>'6IZD{x@< %6t?_{u[($8:C0BXb녝 daIɬcwK.ghC@RQ&@40P3z5~`~sK}ŎK+l46Nj~g@*|QXs7+6lUF”IV!ʐZȍBAќ%׿*Z}bۙ2Ǜ&nNEp;ȂP|%NX*˫w"(EdC{4S \Kmp^Uj[k$B% ULR1S`2ŞK]rIo \nKh$NB#2_" 'RURsV'&6 !lmEp|'E\ |EÆ̵$*u5
+SvdgI+xv*mky~:c'.);v-RE,UqDO͕w f5#vJ`ᷧ԰EYM!uo6lp%
+žT1H>R!ƣe"P7#ZT?!JV.W =TWY}dUА2uMP&gU嶍:+yuZ[Ej
+ISΜ:׾W)bݎEM ڊ&d3"$9;*j'm5<U<Xoܵ5oOv.{YP+]Va[hg VKw#?_YtkkoAQ\[w*Yŏa@:]1^H/4%Ey:B<+t5Mn≬ʍdHT{XݥBg@^+#u8ex6:~K̓Mgrےz|O^4$V^0qew7"Sg+R=sҜ7Yv ݑjVתq[cs%"Dp:=ڤxݨbwH,b2e<j T8H~~vCgG?Mkα4e/ nǪõO=?kN |R{{i6++h4i/:Li:fӇ$y9Y4P3GHXV/m{UW;$czzi{sb+o+ssmuf\oMW
+1J$-WH'dU> 6Ӈ#3owuO_ ?|X[^<[^!ǝ3ׂdX5WO-Q8$>AI2wDzP'us=
+e2T
+''>WtNG@maM1k'21&gg'f
+>d pvT|0? d&%30VjB#vbD}<=,?N #G䘂 䤊; NPs7SSN}ҽbQZCW$p 9b-%1D
+W"QB:-[M[?p-n{9CM[6 nK*۩4;+tw$0}L|jd;UIx洖=UtvSDN Τe~,٧d(:(t>u펻NϩAOFэw"Coʇ.6#Blo%3kοLt_f|^\xz>b?aRxh "ke1C +IP͋T@<
+47=Y؄Jc~f$0#L ,&1DGXB#F&aJ
+lV+
+bq[쾼o (ƨ"45^N*tZI:&ܹLKSE70</F[/xW-/Uc!J'
+YatRZGYtDx_ on&`+d\*DLq"9%J9JT֬A??|w=z7}S5EnZ*\I5hX\cCH aտ)"W
+'zpre8d5y k}BztrwQ^g5w:3kQܤHRJ5f1lz[߉)%Մ`i KCn*-aL2kͭ($DJˈI@8oUpb & 46wގȬИUA9WQ)Vl]lZP],L$h6lvvbq@@H>eǵ5go\H]bŤUMi/߹-r2KU&(MiGckA[FkxjGV̠m lYmhnxW &JrBP.l앫sQrPeIh_襁8 `;;*[>UO/ŏ&iTQ{ ۵7m ([;6ڐX2O".ϛf<2DIxzn[m
+8~%vƈSƻ)TU`Ax?9_ykK ED>pp@o'&7w jOnh*:8֔P;4|UAfs<{to3;b&|6Y;őgi#oͭh_8iz; yhGFǑigᳶqd
+p\)U !"
+UP6b'RJ_LL& b$,sǴq
+{.FuQ8_ʪ1YsrNkҤX&^7wڴبX8U(=gRs.JNT'tgK8'lf{ړB+vPvW:HLb$vZF]:otY6 '
+q2'I(PI!U 96]> rB^8pU9Y~ɟqk$C\j*|d[$Pw[`oHYJ\jQW Lڕk~YG>^:wWe^nۙ؄#L&*wWF:Awo6^)t޿zk/%]p q<i<bmUtk.@RaBcFW}9,EJk;K;Kζ/i :~ֽ^9(XIYPv R9:I4PQL[e\%w@~I+NWjz'*2~M~江 Z?/oh^WfWf!8\yP5pwk|~._XA|q@f
+>2yAt./%7aD&3*,}DEEr*
++ࠇvU!%i<ZjyV!^~ߙ.7cԌ}^MM ٵԸt_MAWxp<K_
+~&9 *31X#HN0BbBi2 N1D"r@FaNoᯡϋ_ݵ'Lcl-&ZPrY<
+Z) EQ<F*U *qTF8Ssk0TȒrLAf=%*Ay#rR3mrR#,%*ֹl;ߩRӼq[;V1?ML Y-,P$OMdpCl=/G_AۑlP%sbHZFذfX _aalDAwK˪6hק>H钚p.3{}m_x7q!$VѨVjf:R筝VTKJm&fVCBH`\O}9OF6s[zٹ]eQv{Lb+Ş/` (Erþ%̓֟@w ' 4iDJI"tR2CCPSI4FwO6:sIq$?!k6_'-+(z'pNuhV*=;
+GdgH8~U]z~i,)
+sU.΢U)/s}&7$.Q34G+5m nL8Jn̥2%Z2K@ʱG*NXu"= X
+%]I>M+hC 8?>r(nfdZI r_ڃO.9d5;=MU+OPU֕ҕpTIX˰#LCxd8/8: %fR}'&Cz/6;ԞuoiTMVuǻ63BGq|9q!3M
+aDxZ)x)N~֗xUvҥ.,b\uvFUeWㅭf̩׺!N'i`$pow^Cʿt}]xn׿ .|./X CJPr@=Vxٰ/%/OySzI̓ .' j|HO
+bVT BTtQ`];ʴ| WC~E{ -eپܣ<^>[y(]R RQPT!ahۍ]ɯ8ŧ-64I-,ay"/\e>.YpCR`CeASSRPS{6j붏K̓/68rё '3槏\p!Qx^⋬ [+oVEYmkorkb e <~ŭkUYܸ[}ÓO~OWDgG`~9,rBJr9A͛Ug=ߏݵ2#/Ϙtwղ翝p]?l)YO_' %mPe4),̻OuW6 \ibsw556c aȑR1ڨBvmg~q#?}>{4o{mt֮]iإbN#}^߬`jqB0T*r¬S1;,I""h+1Q6ӡd6F"3Ps)2=Q
+H 5Y!Z,Cd@1 w8ILCΓps+& _$sI29!
+ Yܟ[쇇K샅YƯ8Kv#B8&"/-K%CBDp6 -O %AђEiuT.y5p%eAvah"&anX6 Cm_Q-mOiwv6Vv٤Ul)k.cDz,V`!'&8`͗ŚyMBDPSHPb".<Wsbl'b}or0;CzB3n _rm-u=A6nc@ů(C o}7΄rSH<F%L&k_o?;>$_M'㗝wuc)IؗBZ^`W7䒰# I"[tZi6611 9 U1˜)ýWqe_ RR3bRu58")IJ?(Qj#jyquM8F2oL+줂zN*Ey$ѠX*j\%݊CU<)=DVI>6(EJ
+UH؎ SĽݡU8.IFErʶ见jz-]V3L̈`=I~-7TT(۱ei4td=O*Oo1z뇢ӂnv!,Z&)[)d@TwTbd7,θM\)}>ʎ4S'~5]MVe3k5 2(},w( 1K}Sx(0l?5V Z=[&Uդ:aa'{3gYlQf
+^g Խ;-^{v]37"•]1<n_s-K5_R
+صsM-Ib{WgJ+A4"yCHabRi|,k?qA4 } RDBϮMm/<?@. >Vo'Gc/ZO_K_gCY~D-CgJ4iSQƄ,<OÝ=M>woc,@XYʜVwTš.Vu.1n>4X7#Y7#WmO{wc=>|ֽ
+Fcz'UB鏭*# xCʱ0ޙ9tnzktC'l0eG^FNubDJP(4: 'G**wO
+k2HՑR%U)/U8ױ¤,5s4WO(B ʤ8.b5dFkd PJVK"U6?]bh^`n_xu/j +B 25 'TXOI
+#Cśz?S
+sYei+[e^kZ7{xݛ>MvWmhuzJ_Ǭt|!2t,<s̅?L38NE5pk*(Ix։yUŖ[.dT%Ia =&N`!ڎ_LvPޤ]e ;t78עgr4Z"kӔV`xeu\+P6`<4Whz-zh~%}`<
+#Ѫ~ӈt4"귎
+c~8k;yxbľ8p2׋ҿf v`'tO{^
+'PZt.0UC3_.vSURv8'cxnƍϡʒ ʂXtU({y>($Tۥb C^j+6:k,";Mf;RG JSXi33;9^[l_~ FG?iˈ]X~OfePN DHȒ# F\1p IuvV;
+-~@py%0șq9ϯvXYԀolCmV e[a<YrxH|ucMk3L h9{O11/hX8qbv$ yJa?\@#3L{Jڜ 8LiLz,TXyҬEY@I
+66l(<۵'l KAߨXq$P8༉Yln!c% *U$Jf XDt
+Va" 0԰{tO=X?{Wt~WO 2U|Z#5W:ѸQ<61 H* 80\rAEh'[ȴ)O3̹ c]/]*'IITRE+2,JЊwѸ@%aN<i>|)9t8`Օ*ȕΨi
+~J'꒴}jDʮs:h`
+mŎ-U#.*+Ɲf=aGY-_5('ٲTl2'ŞEHoJAC[8C
+8a2u掰̴:<m
+L0d;gWY>lhlu8ǜT屫ƽ8Ͱq3Ldw- X]ֹ=zozC_j]jBi8);`'uݽSKz=OSeבKn:[>Æom*n~F`6#ֲɨ[򖀏 ([/h{ZcW>7/SnƵݎɅÊƝ:D\c>lXWj:] ;޹
+mbuPlmCԿL/Emծ^$ZFF/yjA^^^,g<{
+/ȉBu<.
+)O>9!V`9EUbӈ Uh{xlcVuq;{pDObb.$/4|٩uaVEMgf<(2N>Of$EiC4`'g0&IJ{}NĈt.;&^/?og@{ ]ɺZ{Ke]1vD^k;;ˡ]%l_K-4:h3~Tk8 8hCr?qTr4wa[%#jk:o>8[ + ‰nA2]JEp])</ߒ}#]Fċ
+KHzQ1v>,,)SK1ߜ}37筓YHtA:_TƗkWV%t(9\$6cY'Bs lF;H)?=WqvN0)ώ*#ȸr|v16Ըj^ Y|# xq GQ̉zHOÙNŒ-q5bYiZL۩cQ#ǐr,hdE+G-Q:8C?4BrXA/cy i{H졛.E܈o I:%NOȩ{7Z'E39 qBkt\NfTLB-1 u,.H(T)X^ `!iLPφRt|BD?5ۚ\=Ķ]u\hcpI}Wlpws\w{wwZpR-ڮ-W{Q\yqPMc/˥rP
+*QdMY˕qi$
+%СI$i" IZ
+61ZTf:yGkO18w K <-SFA nI>Ԭ7ϊ׋>r[/|:@O.Yk꫊9]|~TX1 O;R|[5\fV+%n _UOڑ=,sF[oYd t4eMz F7G:ѵ/O ":9i
+Lq!_r]WRwJѿfqM!m7`7o|3SzE.8p ֦^\fAmw_HZ%sV1 0ؙ&u6NfzL2yCg>L~H-c1Ӝ։бhujx܇f^f_J4Ќi:)3+6·d`Eej-}#ռ
+D|'a0# +* CiZBh$9]%njYeATn8Y Ipv \p1^ {*imP]+XfJg^lT/bapGGoIY^ >% V96D5+5ٺmغ}5&DMUCa/ePX^tO<)_HKc@P
+"Ɏ ]@2!
+nh #O,*AE4Wv1]זO mH(pfT:%/"{B`3s;783Vwn
+Bvpc\m@٘qEg,'?}gx{˿-J;܊ 仑ۙiAv34FJGJG-􉜎>FXm2MH2=X78GH;m2Mo[BkUUۚ8ԍ˪UuYvմ?,7m[.zgZ뎬ʶ_RmۓW8e.)KqXXv䕶E +¨@<p/Gڄؖ|%fxڰdv'wRz4 -le&AgnjatF&X] .?מgSE] fr^H`BqHu;WK9-׺v4A;xo߹غ>Ub;2
+Y=B]d/1LO Q>@q:HÉ.8-Cxڦ:*{IO3=.>LMZ>y !YQ쳒XN*"(̐S2sa.CPgŶ͢Km666$i؈DKm\lf(MZzє\"5Ɩ #ˌ M@~V,mrTJ-y!% b!>$D'EvҤ1I \( t{IO4f B"+ a"+ED*1UI<Bum%ls+k+zVUũV]dvVk<sMd_\m]VnTN UͲ;+GF.
+x&xTWq f-IG!8f
+%_CgI5)^k3^q?A<o5r$ `F(eiXg0QDr?9R??꿺hxpp/|ApU|++ xSF
+O8˔PKr]8y)3<aqe#K{$gIaVξs"o՛X+PzYfr]-<1*Ib́ɉ_)͢C)Jmz.aJRW
+҄qM1;v`S}TUOhK5kJ6m79AN6g;.0+Ojs>L(E/q{-m#5V
+>Pq^2,JMQ7܍n{hgKv&eV `+FBOQڹTH= M"[|N;rHp;Q(V?1H_䧊.lz#Wg_fSڭ\t*\Â $21ט
+]Wߍ
+IbWM2A
+K1t9R%8@^td:D^,ty83G\]$D!$/C7]F ~ʧY.bB7,ʇ ~: < "t8
+'ahr
+^. !! $)b"C2a8S`*:Vc:'f$LKsi2IAF7 z]@,Y^4}
+M6Xu'-e0?DSXr">F*Kt\lJuV.\@/;h\ҚDhb05c'NTTLW?LW0O3U5K'nD%1(Q岊\`~ֽֽ[Ѐ3Ltыg?~Ei+kВ[N{^ m'Ԃ=LakT=>K9gPŘ3/EtS<Gl&]WE
+)詪~eI)P Ͻs>Igm|R9Eab2NO$X
+P/kXhYZw2:ҥ۹ '-e˵ҕv鵊gMTΪE7XM+;M͛5K۷F[Uu`cS=L]@
+țMj'겚Е7<*y%|C }3>:WyhSUjV*^+wIBEB)ϭ<8xF{R.ۦ?SE,hW.!36Ѭ
+o1ϝ,Ct\Cxiq՟(V i*o^Ο270t>Gx8?QʋְRfzm=T#;`9Âv[7 *~+i.NCwR3
+t8'QR)P꫔H5鉥Ubq؈Yܷ
+xYs -v' /u[FZ˸9&
+{Oz"xAOl ΎC=`#zi#.XH[0Ӱ@eA;Sn-kNd34Q'vMftI<s68íVLb(Sx-l*Rb$k؜2ǁk_TړV @]\P{o
+r}Ŷu^q
+j2SV}l^jA@jKTe-hBvb&tB%-1m.?>ؘݘ9^\(II
+EӅ&
+aЁE>t!{j%. 5#
+"jЋ=DD,"Bz,iy"rE".rk*4f#pGD--MPMq3cB9-dUi0
+֡S BofT,{Vtd;Y̷+숋[JY+,xpm冯!? SJA.f(6
+vD& @Gc_a"7,
+gP|1F?ٌd7}?k"spڪY٭aMek#sc > m%݋#|pB48)x&khjRD~ƗDh2PkJ
+VX똳i"1F=^қ2 |ބsܶȈ-9ºf]/ꦘ=~JO/
+ND$AI2$ B^{,VX)h^}S:PAXZ'6Kϡ/C;n9Sn ~6]nKv\Оe}naUCe5ȼ`vAj7n=N~D>ᯢ[O-@奔6m'+#+ftEMI3>u-ἣ >uhmiһ"htU{GkcUa;iVQjVHohVru^q
+1d
+2\*,d/PCEp WM4_TR33MKO;y"zןdi.p ֏z~jW?3m|y_|dJ6b7QP9|\>]Z]4Zϫt9ɸgVVd#aס@Gf qՑfK5ɢkPgTѫ\8c6gql!<Gh
+ @.ph*$P% !)TE5X'N
+H-ppMJ+r+;2?,g9$Q1)U<[X⤟' BOPų@3Q@@zMjAKVmyFbO1a_4J@*U\g'J=aϙДY`'HB<>XW9Uxk7$l N}pR\pwk:M&mvBWk֫nǕZ-kY&[)t9Ѓ|_t]|-&L=c~̹}<mLwNcͯdF)nWl糖V=|Ε kRx<؉{vz٢9#<ofv0K$1p±_X/m]Z'R@ '
+/Rw3n'P/rz%uWJi3-"V9Cp}I0̿5a{ra"wgWc9G=Z;-W3Iq!F@F_#DD{"nƞe7K)wq<cS]H^eQJ|Vdx;;Ur7[=I:< 5'~RH'{? \.Pg tهG<}tVYBS ofʽQ P<K1eIK K7!1EA/CzYZJ>E>=|@Vp
+(
+/U굵7ixLM'l2&{Ivlv_Mo6
+R[֡VZ/TU (9΋oyHFRo~fB7j@{4zʐU&*0OOOg.
+71wx\+srks*&41#*&HYGjiVaF6h%BY%໕;_sKSAX was`j
+JY7R8:F/S_fI#Qy_<LXZlڇP!ф>È>z1-d |B(Ø|3; IN&3c.Xѯ
+Mۇk{Tr` zBoy|Ӥ[ĸp%YK
+| σɥ.bV!߷*)N
+< %²Fze נ}wIfY=k{_um^{=74 8qQ;#o{Ɗ
+Q"#yBI.Q.rLz"Nx1YGQX6H`'ͼB.:D(ԏf8G,nFu$zcMPjmqt3E"]]{6=<=S>}wN R[Ob{eqHl0>G7Mn9x[t艕1N"gS&տ;Ug)l˾ǫr5 2biHrӐXO׾:?ph N*8|
+NPsȸޠXsVx<b[P! U-!A?Hdp)ݸ]sL lSU"l%QB+jK^~aPVdIˡm@wy *!*cʤræ-%yEP4#ݱ
+'ZwIYX1ӟ0p ~b
+Q "<j-^ ђA+|ޭc>FTzf0H A)r4ޅ:ܯvcmklndû?)=bޙLyrrhřAKWyR~.'hGW )Y$ABI!$3'V IIY ן\_W5v*:b Eүvb3' {xՑm/ѥZY5HWEX5m<k'܀ $
+fM>]7)Pla53|%fSg
+7lAϡS(SpeC6N
+N{ހsd Y}q-?%!*u I5*29FZqwUQL)MZ S5ԓ%: 5xޢKbT8ʼ6sG'A'9lrd`JYBi7K%5M)ۆֶ^yv~ފnSF:>ɒP E*XZʅHlXqMa(I;}
+Iyq| x\.
+i8&qDO@"5bc1:#fOHHDC<bQ1*5" Syl<͆=(Q/KnfXBK/MmJ3,%b2}7 @-T'ɚktK37IlwXXNv.0k w"vڿʭ\1keH,
+tVI 
+x':fYr" &2pݱ31ZaE, L}d t2|tTmW*^jXM]dϥEu{;˅ŝB_ʷ.v$)e<K OBӯZKvGڂ/R"I9G~wlhv<!V,Oت묛Օjn4*( ]l19v-m+H1W7ETu
+P:wˏo HG
+8t v683#ա%Z}H5@MYD-Ȧ! rFt91I5Gqh SSIRU(
+n%G)B~߃~)9>q?'fTR-gW
+{f
+S*|WVY*ky眄?Ӽ>l((%F%_x0BUXֹC=-dpc;
+Bkc6t ˄wr"EVF̑1^w(b,Yr!ctY&Һc™dDp\М` !`"RmnUs23LxzcO1O<cV1B9w|Rjwh
+בE`ħz"ԊQx훠ʩtjI6&izRRo$u%;9\SCi]wQI8Ф8l<#]& WgwжQhN.n0g#z&tCDgKCy'{\Ĭ^CA "%6O?8l +uBSDD DbCM9t# "D> 7碈
+]][p<+#DϡdLdC8B zےRQrH(GKOe꓆"Qys&VABTD]|o
+XowN-3KNq@C̹?:ei*RVv^vkk샠py;ϧH\$Ji
+
+X]S3tU̼04LMW !A "Kwm>}Su>ݺ{~NN5,vaGxLAIDBr[Uß ~lx7^ {2><=@J &.PtYi2}ƾbAETe{<bpUIѾn]B^q9yCj.ZyyCcᰌnbᰏ/aw<7q.d~saũ7IWjL7._SA'PD
+r, ^H0U
+ދgSAeE(}
+!-<٪CѫW_4*p!XsH t̿EPY05n3_ +:N hGRpfGpvoV~~7lZŲS2kؐO
+|HxRINj̀; lzŰx vxx[P!vkyݥ͂;k.7yfUG7B!{ p@> $=튃)i|ŮCc>4*"p1j"oO:1fŵuuz"P֞28N
+X6 qOE׶&%6y^EΖyݧcػ瓓OsLYPgLBVN1H3.nap_8sЦ'>-")
+-m
+-g1 )Icz^ $KgWgug4&tcלxu|fF9,ԠnFb<+jY"o) @q?X ^ܸrcGd D;_&FL?rHi4Tة`:Fw@cm7(&6U_tmI>8$F*rWA⽰|45$*C͚*\pQYz#fS*lo=*)FOf ՓC2LR_f/05.Ad
+<7W>?eu&_qmU|5\
+(ɪ β^|| W77 3+tЖ ho 6eo+evVG4>[vdGDP@WS}E ]W%Xx8lvܖՋ21szUheP:JZY(V%9u{ri{T5zY 94(4T{4Tno`{Ro}J4.LrZ_po9=QZwBضD=|*9[|NǧIĥ?s?%}>p:9=69&g^-eG2g֬Iwj!Z.!6(x=Z("w)YIȍY9+7D1C#-L.Fl_2;t
+zZ?e΍qת&ѷ3sB{PMhLb;"jt[l)=C
+L͆HsaH&Ӛ"$lItnZO7f P.}w,2! 5(ENm.iVp0s0Uz8/jr띋jr;O~w!!I6o~^WKV!΍TI~ֱ2ZxmIJyß~I]k9ߪ6>P~ɀnFU^뱆ߢ
+ *:}4Kh?dv(5+GiV60$ūOZ(ZOJ/LڹjWUhLfO&)5ОP:p)jP*}/@uenZ%-e9͹˶>j,\(D#(.3d~%$$aHcz,xAxvj:}h;3vi{C>=G="(ްTA \Cn$~$;Y[?JjymYE~e$BMumq"I$>!AL6iCW|N],.dN^~ƈP#r|X/?ՕOoh@qn2N:\ĵƍEωh?g7NqnHU:GŵƷoу
+ [y* %R`0S8(`qӋDr4BD"KlZ0$fr:
+t7ͷ9GZζZGeMIYɱ/'RaJKFYBDq@m" gcPK)0@<[\)۱HV#63> $5F|x?RvO٘ z請]%ƩI-Y9>lW0ˋRn/T9b#d.* XT^\Umv_I_.]I|rDVӕy&m
+m}~ $IA% VfAAbbMp3_XQRF[O2Qp\)(}Pgqp<ţ;"@nn>zqϘ,yjۺ|Y>hEd0Kp8ULH X(!gFb7Luh|sC-04;FtfQ}bo҇:TVAa0䭤7U/PnlTObڿ\-XkV -Ǟo.ob W#!d ǞVѸ;oHXQo%GDxv b qxML~Rױ5jd[Rwd^Hܑ76dGm#6X!;lQi#(ba
+pTǐ &F"s!#7}=_^ 3OSg?cX?(KY "끻EW_ߍky0Mǿ[eӿ4c JWG1KD[f!kq">A^tgmD$ Lu><9i(<<rT^ vGqEEG%]3Y'f
+%V9,T*k%';S; kwJoۼU)\`nl^{[ڶ9ܳp :© D%x8$Y:F
+#7@^xD#@2ͥ5"QzZS8O]%gW*7JmUW;bb5F5"9`'d\.l}qSjܷtPK䵓iEiEBV=(VX4=fCYO= Fv q>I?cy"kNJܓ)ߗP^ T1HC{7rzjwڞ%Nf'"`}K5d5x]ܛoaƲQ$,e9!
+ ߃dA&\ۃ%Kᕋ?w];v5e1YP
+Bf)"DH,n(ȓNSe:̕XR¶Sݷ8t:/2Kj- ^vvHɂt}QXvdf*Y6k=}S<6!ს Ja1UœY2&exR,ŇQ&=B%hKdi/-1 1F&TEٸ
+?qAgrSE4*
+;6sũ|5"K$YQ6$Kpp VK槂TJ $N$Eqh\NuED^MgzCB HX t^ʹ h;Θ(ׯ2+:
+R!,HoIrs$ Bko(,3Xkʽ HdxBP76
+jarw[| ISzPM>E73w)ڹ7SК{)`jlzCMaNɹ_zCE~oE|D>>Ǟō(y*ѫj䐭lLsAdBES7nvr[u_^4Vx=^=TslޣRT@KTyLpO0` p4$B @+l6魕h_ch+UUZZvH$003}R;WiF3f~7<D Zu 9L%c`^*bl" @7P E^.q\i ty눺kckkH}<,f<9/m,@uoJ x{ڗo^] m=/:k0mte-__uԧlG.c\j zz^g
+gL+l󍲚}mNޑ{nwmxԜjCsIз`tV<FX@ܐ-OVDWK
+|E(N{w
+ַ,#XDM(Fj\aMC"B-6
+kN9jzJFwDDL[Zu0[<ߍ' bMMIR]qN}tczxhV؊7y URoqKñeJwU~4‡Y g3jf#Rʈ˘*aa ?$ejV\EyB"9iB@/ݥjh,FTo);53,.]RTx&99i>=#6VЊ=ZRWT,%%Je`gjiTW+'Pr _]b2{jɼ#B}
+ލE_v8R|!/3w>yv@
+\,FVA`^?yޤiuu1b0By!?1pS,ߴb=7Fz2'6|#4]w=K
+VZ,.@F;<V rpy |@7I5b8TvEG _7CC%ߥY4 }hb8o C.;@LoŔ}:pRШ֙fbɏGM#(ݡe]3a-* Ћh}UtQ3SҨ6gտ\]YڱW:lpkۍ_Z.oX^^oc&bH8/WԠ^.MP> 语7HJ
+nCjLZnPKzcZoU2Cv
+u7 yF8R@
+ R$AQIQ??d>]*2{]96õG
+6`uF_Ij Q\Gj݆G<m U.5e:tI 4)P׃
+Rg@kE(SaLg0y#\#,`YB,
+$$~@܍K=<vfNԬc2O,%'偩<rçx#$ "Ql EQbDŠm )GȗL@f8jIKD"$T<iN}`ށDU)@F&+*r-1Cy=|{*%m81m#'&IbHC 221MzB}n&kfrLeZ`>
+RBЋ!
+39c sҎܰ.y,%h)v6l>A CRHl1vabYh-`iqnj,#F$r7 ]dw Hfv [g.Xeb[:uYoYXEO,^d,2nˍG%etBuV+%#<2j2xNHBH$@@r(rQ ]ζ3vztvnWk@$
+!J W.rw:ygg<Ϗ2%;dXKKt}%z
+D`4V͙g.`qdxC^?eFv'0AⲊ}IL[wIoO&{s5ˬBLD:$%(%/09A<oj;mt7}HWsGl۞)__:;*,f# yrBL B~8S[W/״poXP&2OUF^ :Ki0o?H_EI Ҽ9) /CBN3n(@gqrfey ɀ9G `M"á>SZfXԼbD(v-A!Zp܂ta_YyQ'%֜-!J?Qm!ƮVSg{(frROo!Axr
+8Zah앧ARB#Q' ln@;Տ$o>&]7-u6cIXд<a˺k]xq"!_n=ޖwpwqZ=M{&0H^azi+j!F#5jͺgF]\Ai1w請ti|?c -y6Cc/" NnV wHiuܔw$]WvP4CpTKvZ$#p^6$;aI"f@ >Bc_VJ?(nHվPrS{w*1, J> 9+I/ƈ% Ky$8^
+n۝-<;;o*v I Ҋ+d;YV9To),3
+3IE8__B[v5v?ոtO "+C2$c^<y/0ʃ\_u[]l$uZa=PӄUscfrBކrk̰eY<G*#4AȀTH塇p6?)Ů]RMmA:wĦY\m[zVu֑MLL Ձ=PJ8c?RzlOOm1;^.b@k^%'DDl¦3Cw}͞/z/gm h׎ `CPf:ˬl$vH\
+kY8(a?XξVQ̝Ý/G$2!^c}8d(}]b$1]^AmfWק.! TA$z/f c fzqw8Nf7$L^2yX;yL`{7iƦ7ӋB$*z )w!9{sa+hA|B
+c,Cicj\5 QD-C -m ق1
+qqjф"MGVI]0X8ںO9QdUHDQQѾ'G
+DZ2.Hܕjsf
+xC>O4#Dm]u2 )LD^2B`~ZXzj zc3
+
+$T +ƗAunZPn
+[ ϹͺCgmmg-mY)5wX}sV98C.OǕXGc\ք闍p_=kT"~WOh
+
+ˀS
+j!iP=$!yj+B5ie`
+;Ht 985qhFI9=}$=y5JwU!_QL\hSrNE\#"D8 /kp:a .z˞LJ zɗ_}U{a$I Zw k9GgO@*vÝB܄Gr}q
+LPkl
+?;E|<TDTY|1oհ!<WHKfX(kP><@+Υ/я$)  S2 !\% ("O񾤀`G$8AA2̠?-m;0G"|њ
+FJf+vd)Y`cD7XL ӬH1 dF*m_F|TOluw%0P@.1<B
+{LPȩ)+wpߟqCb#An}26SJ (&Z-`mgɬ9YFAwXX;QR4fR!- %j'=gCҳ" AA?|ۤHnbёkp#A:=Jh;M#3pF|U拗߳4JFDd
+K2}$B+)%~eh*L?Fyx+ԃg߂ FC}= xBkAzKq]C=wY,΅oznIn{zwܽ{nԙ@(>,Ԓ
+ ie2ʑRVu}
+Ӳ1ePU[J#x2z .7
+/x(qHH13`SmRqRP9>j*.gH
+`SśyeA~N w5C-OIWzG;L/X\ha=r(d5z5M&@u}8
+>[~\𺽏W_tIZ\O40u] IS/Xglv%cPwdڳ;w۶vMG8Dc!6;(*]S/г5?T|`^1ݥ7h(3a4&( \ WaU6 #h]rͨZ?»LP}=~!>z#Z|=-Q$XwR,
+\fmVvN=yi}6>/vLK0 Joɱ
+\և,Rrf}(,_{/h1>RSrL?/WOO?9-<Yt,iLg /n#$$ ZS@ClUVUC[UjڕCWݮv#G\!IB0ko=?+z}G5i馢2|>{]ӧ~?g~>|=?wS?}ۋًGZ_ oBw}q>؞-zOꦭGw ۬[ΓdiNilSJRCU;zOn'pLJqe}THN_lٛeFnCMu]q_?vv=MMz/6O${ٌٟ3^="K|@
+@+f0\aW^/3XAAܬɏ1ݹH>kt앃.2TJ[CroI"zT6@u*zyD'|чCKKhIȘf#T4kJ ҥ
++p%dKFC9xJ4PCL6E2!x覎j$ƙ݉ V{mxuuD#k@tfĖ\k.ZG9)cFC7k3pIĔg@yeF
+ћt)exTB]5e=kW^9w+,ry{"9FRHQ+v )LX$l*2`1ܷ)EM!:U"7_h?I)5lcB0ȴWPI;R&5T
+%NZ8]h1`Hq|.nHaq 3mNrg/{RuGpRp$ELˆJO`g@6"FҦW)|]/7EUjs!z̉9O那dyi/C*:)&3u 0t/78s;G5Bcm',ͥ/Ҽ5)\c^UBZT*Pi*Hmrڐy[X7I%X^N[!b]?/FeTK,>qkCpa7v:>E]/|XLtrìCa24Oԫ6JLr*x&V.[ddBcǰg'#*˿A'_]1p%
+mn][=q`}'?uFf6XӴ36Zv
++xm!datD=c9Н<6]^ʪ
+/ DE9Ueof#H.c h{k4f D@)î7c{K^ 6CaӫJ5yKlq eFӒ+ f=w<lyqFw/ORk4R1$)yGkMCOrŴqz7ƱMa1e
+TN}9pV+o8ө@@C8UfV@24',7(yQ~!D +.ȊmIŻ*^Q%(6}?Ps_SA W o_V+oOJ\FE#<$n4ѯ(;(T/OzHOm ˧j/?y^rKSQ*p,%Wf@rReݔ0$&4#;Sˆ) F5㤤8.U*Gv<ZԻFf3fsp8Lo #F`4tz>rx=rА<|993LSp
+bq@0@''CR!/O5dZȵ(dN?3qY%T
+"KU_ͧ
+&Rk?^^`uHYq_V} uX rk!0,ˁ hǪCDu
+F(a`eض8"MbNZ҉/b
+Ve =sivC"}'b#D7/ߩjf%%PGX۾DhζzK?4'y\󾐽龐ˆBoص#WHF)t b~!Jn!M{AZ<9QX
+O0g//7T#3h_$" ŘQ]H(! ʆ;9!{ 9V"EXCP
+) Ŵ;
+I^޲їݱڛyg3z{Ip"AP.X(
+tܭㆍ)'D(* 7, Gِ_V3pdEC G4rcyo5(v˾:
+2# nQڙ)N Fאd? m^9y$Bغlt6 z8__a5@)uՃ*";Ckd,2AIr%oJLSrwg0mwmMquqߦG745ofQ`5j}?<j\C"4>W]t㬞(qfOlwJoٞZ >w/܏< nqs~>` BM;~~GadkG[qLh(]QrwTSеw5nVzmw}mv'5'vˮ1amLa|a&q%bRh/(
+pi0/T(oFf$d^%BInOptNxGa~GpcwZVop{0Bj=8m0ˢqog<V8h- e'!4) b74oM\O
+H1"%!R1%!"{b?? Ke'-J@0Qj<R{A0*{60dIIRI܁u1(Mha%v3' +mΈy-)k䵴X[-:q< 8+儍xQ []a_rRP_~??O. \In۝9ɼwrgSS:n VZ,fޝrnĆ׃OKqEߋmz+FD]_ŜO>8VVM
+g-gK+g-x90
+e [=HRO$#%DF_gi/*HHg%xϮg 覰a%"9a˝.ЇN W7¬Ov P`GUmn>fs4}돴}CYvLs@β\ P±휄fX],\!YQ%m7'j]ZU LCr{@@XP1ґ4o= ]ZFk"K( k(PME E=Q^hؖ2+,[
+9--;0=WaWZɜf"#I
+ S|'&FИ7%yvK|ώ:<f~kg2Ub XE֚|8JcF~wɣ NJ9^4u>8-+^4RopUiYw&u[]Y>VWc$n] MmQ,6 ]RgKK 7^Nx cD Hզ2fIWBX`_ E-,Ccޗm q%|].lvZD/+7g*7k sJLi{]t7F2xjz:|K7;v*4iԂo2Z"[ (rqņmMH,s5khh^?4^ߏ?hcէI!$x|ȃB.O9dχc\AMew
+3~i;m;ԏS]@P@ pC1"7IO:ߜǽ;???G֧稲kezˀ|c
+<E7I[a{%/]s03ɳ~׻on`{[:z{TcwF2,ݶ{mak>?d\w qnZ o[7e}~-/v;nY۶{EUFCfE݅eQ/S
+Pvzc3_5,Οl\~_۰<_P/-՟X^;Q,Qڰ98 ?iXyʾPzC<])R<aW&Qƈ<afM CRn$'IKEا/b 6a.kO^2.y8=8ܓ2+N9lzSr`2`MJ`UeZ Ӳi8Uf]0MV}ex.(_^6L(:Od.˨0ИJq5]?Zt+6L@ꉏУLq<u8A8B])xeafp5yS O1'#w5oa
+U5Z}pv`S~}r Mĥ
+ƿ{[`t<1K9 E+P◺C%³8bYA]֒6"p]o*CL,
+b*!@Ԅ>*ʦ%ExY z6"ꞋQm~m $.:`y릳bFϡy Snc WR-> 馰P=aԋ1u#Ug
+Iyuwc󞑿 tsv[|=\R(
+pvʝ>^=,|bO3؈+I
+!# kM o*PQ
+`a`B IH!f KqO@B)""|E~kI <aa&*ne)
+2 J{;8ʦl+@$&&Ո$&޹/7:_L;vڙ3:FもfO̦pĨ&Y4-3Ϝ?s̜}"Lzov6Oxpuz82cCR Q@ˣΣ̈8m$2:jQ~b0vDb4$Ȱn~yL{RLVYyu )7218_(6ۿع3ĊKO4sA}e?:scm/ވG}OE+j߭Ϯ7iNKLGۏ1+ga{hbyGoMժoEm?{B4 p)D_~PxN AAkybh
+# *:kNi⋾4JA8bAW<aoPԒ 9T
+⻭ݶ>ukoAu
+z-<j,kXo5bAAO
+şFf
+bd[xDG9ߚ2Zc0YhNl(lb.!m eul Q`}4WpˣcB\&\*F%BY=wyy/OZcW矔5<i?^({~ >9?~-N{^{~dE7'+XT$/QO
+\"'2dUhVWfYt]^8!<
+2 S#8
+\[8jy1oQ嵋eEiEbV9YpQ5Qа*aPED 2@yV^ҳ˪ōϋ]\]t$ecݢc %im;& 1BJ􈰝>'´B`K三jS[扣6lImFp-ޱ5ᘫbkePh;3AU,MkڅҭT|i6X41`,"*vml1òj-Q
+-j>ۡI
+X[eo<PYl&%ݴGcԴTƎ1f0'$vL)5ȬYZaDLL^$s+u evt<Ժ;watB484Kfy]B){~NbDEstIO4  (~c/+_(}߿_y+ WIkb&[(֨#be7O&i?!Cod%2 &hLNٴLJ0rYT@@1jPQ'1nh$ڝt'tUjgjjjḟzz&FjT EʢA" 0/j͇rSw`qLb%*\²YtE<nnx7J2i 7 #,k*gc x' K@##/1I6yz+3Ȓ[9|+8cSuePf*5vIL%]ѱhZ=n.FT |*+0Į-0Df8t,&.(*/ f5:XvZz1;̚KNiͱs薦]'uys4xު!7i̭L|tƦ*tV~LZxDل{I=tZ^`Q&ug 51)SYEu+WGӊWfN"v */]÷2WdB[ehMC;X抄TE {"*~X#L!-v|C7x*1(I G asDa'ۡ"lhׁ a4
+CNh"Y O gkCex4xڗ;
+.꽏[F3lȍԼAu I7]1-X$4pI~*8yMnMSi!T1ZإAL11:"P{tC
+7:`7t(훠z}O
+/z\FMȓ X<m
+
+ZyEgYz3$$@H ' <8H
+WE &VkFUZ1[AaTGXMeRɶYz*W+ƒRlLJO_XK1D.I)ޜJ)ٔmN$ b44P9EL7yF_d.2M+ޟ* c
+z5X3BЍѯh^2vq)> ²ىK Ҳ) ݢYI~ٛ<@koG
+-WKFJkgVͿ_=UA՜(~v0n~@N[<Y<..4l]fuw'JgQ c#kaK4vÅ^ g/!9 ԙ{5 b2;k
+?[y.os1⎌09_E=0YloVvz+xwÜntk5xѢ {ELr"m$Ne/aJl"by,[0#XoTI-"Ӈu`T5q/ZaD|ij=A ݇؟p޺ky8qRkVU+^.]Disloo^:9wKGo8~o0.;}> ( 0I`
+3[)L.=D$ \}xTeG:C Xēv.v~?\ɡDcާҶ)mQJsbOS*Neж1]gAie \vT/bc"n-.؝KѤ;Lzkjjiy~JK"b$إQ[Ը, <_pOqυUy6g2 Y(g'&'0nvs]a &>sYy6G49gqk"'n2Y"=3Ghq6DLi;MBUjx%;e#t{L]3#lS;DvqLq
+BA/,@wNJ#}݉SmFn}zU9M 4kVJ[p7R✫tͫ8{Y'^yQb=T|qm3>b 2v>MT_OsںķF ?a%}%ޘƬa ˍW5'w
+ڌVj{Om4N񮘧 T:s̺dkSPam<ɳq/ߴR;~|.P c** ?ο, 6۾{__ny pڣ9 c1 daAfǭ<8q {tHIpp(3ăLI.dF1*$$`-=6@33ͽ+'{2#rޭ;ÇpvHNifMɕ[rKS_^q{HnɻnU %_j{wl));\ҽ~f޴K'п4zh%!ڶQ*w]釺خUbZ1L;N+#` i*Y,|2Zw<`+͡%:^؁QZ3o's=&xmPh"DNΤ%/^1!ɨp̓ۤB9$g䬀 h~/5͠tJ($0<~1vt ubEZ3򠟲1wߛP@suиpŋKqOtA (FҍmDƥE 0؋8vc?g]숃
+űcVL{#'AݠK}U_->;c-_խGeK+ZU ~i£/Vom Ho>tmuݚ͠}ߙ4X)EK#H꿋,Pl>lHN$k3jz2gk]9
+p
+@ Z҇8OѡS (2B>LW=I Lf$P:8ى`$JT w
+K]$_ˬ), Y+E-ԾC.и (* >D~0O3-";B b
+"ȾTEBEm9Ɉ/27392!eJB|^(_yfiwӥ믲mދ*sRt[DA}?K MAsf{B+fY}LSPF1Dd]":Iތ
+#cj֧H[E\m0),RZQfDq6'ȫa&E->
+;ǭq ,:x_Gw],]K`,ٝq+O.{%m;圝P>e5)a?3h{e ABЄ e=`&sXR';^5Ok Aȕt)Z7iqb7QdGfPEwe
+ tn)2^jFiEl;*-b*94|GV4[#P
+E&4}5pK.io@ _߈ѷg鳾J/Z2a2Xтuo@ژ
+w4Ce +Kj}Ӓ7I5s+"#hY &c8;)**rAk5hqTq2sӘ+\6dE о->^ j[W|oxdIV·oVgˮ5π In8ݶ ;s%w "dx:)`3ûTšG!sNt-3hn3/,:\yt;7L@ &rcA(I>q@`Ľ08qr 8Bn7cN%%@
++SDCb8p1x8p 'SI(IP 8QYD4%B6LΎb]*+a Xj?co(Qp֊G 3!
+MεZUzAoFP>|ma{郡B {lzbDQ-a.=2#E4{,S5
+Prgܗo_fy3rҿI4A%¢ @s'Ba&`}x )#
+H!; P0&Uܯg}SŞ{T/>9sӓ?|W OK:>?-v`Qʳ{O;?w,qaW٦ynz㪿ᇱmohۇ[]ֹzwoZ+>%ŲiE/ΚK {i>*rs?)8@mSZ}poZsAps3׻9 !uKkΕ״$W횄.ogikdW.7S-Є>{3xz/F=
+`p(  &(x(ƀ8:0AI0pA0$ʂ ?^`N!@@'g@-P Qdj;TTiL
+iʰ؅f>/tJ o43DќE;& W&O_x}xASW o.]_xYzcsfߜ
+Z hGH
+Hc`ؐ
+/zJ㗈6_YɶWV+4ZN ^I}[)d\gc=JަX8ؒm&25:CyK]~5lw }kݟ/Ѧ,BIy{!+r3.bR#b.8`q."g8r=ZzW~^tf .gn%$KZE-60ʐ]A΢r#YB',
+X|1&d&邔O(l 8v,ٛ
+x+t%,mۥv_ y[Zs5Pߺ{"OY Ȕ-\9 Wk
+z@G{}znݲgZS\7uijK9\Y\o} Jz Rg 1vɸkw$;C\w1t,Iz_2''U`n16\V^M
+H]`N渆n:V̈bI挆hʨc9~\ArkF5PTHS;3I$^Cp"h19aumn~|ړ+N~9nN> 5t/8q |1tr\ט+䩽&h.lۨM ʰq( 4%h¤s0ePa q:h])"Ž4qMY怡}opolM8Leb>峧q<8
+f]_I~dGM@SÖo4[|x'K ,=l7;_u?j;e݅G쏕w>yo] j/Qϭ__yp駋_b3f|9ǝ۫/siF EDHO7&3"]dOp;‹D~$i 'ICޢуE#],Ae4a(4;`M蠛>4PA6cݔda5G1}lOfח$&&##O qh'(I#vt[
+)>%)}k..IIGPYx
+h]DZ fqbr<&uac؅@UZ"B\v<*du{k'{k=L.^4?uM?ꭺ2GUݳ=W!^<(v+S3n? G#~u's^g/"<^pvī̋4.DeUl
+AJ9!o'k~VweÔxB_c"'BN($|f$zL@@"YUf,\:ViR3*ݤԮ$~t%r
+Bk'"AYQ:bH0PobbER^ԝG% UJ"fBy~wm*5,
+hN@ҍM.P8WR-W2GU
+VE9N4W̓BcE
+$1?GtI]
+Qф
+(Źp !%kqM0glE}'`v2L#I À$ɉ 2J@dla<3->dL
+3XCxT='oJݔD?`-Vx(L~l
+&v}Wd~\dyͱ-sʬ31YFA+0y"HYk f<HpG جػ DjG%/|.f)b4= ϰFٖtF<w_ e35tĊf2'sjz:sf.Kod d(Eo]^!? ,ށfYL?JK3 QF&ʹ%k<X/ A򎊞g4v6˴yI$-$|>:j\19cз<ΥjB-B,H3}p<JD#!J\ؕ
+  ;v.i- k #&L*6huf
+wsrkT5"3! -WQ},*7lLzG?Z4dʖZ jjQ3b2Xn3uf^06
+)s,60opNE6?miM/]dW(D eʉBr፲Pb ᥸Y[}쐽&'7JzV?[W/^|s \qYHUWm9jWz7wzm[=܋'4$X]%<Ҳ7/ðEY r/9\rj`vͿOrk}y|kYm?nW'J$gvV݀0[@_:Fby3Ϣrh'\KFyD:q=q
+D1
+c}-)ôڞjyñ8ψWn5cͮ\_|\;O~Ǒ/Utw~]}of;?cU36]Զ*ilO$WB
+Rw_D؉HiW ' G
+) "Do
+
+>7"9wp(HLHV@a$"+k>F4<ᥛ)\Q)wz7y@m-%Z/s.m20F '1r1 M
+!weMUWV+ygA ?X_r
+a
+)ETc) "\/Q+3 y
+rB+@Ra2zAR'VKsAR/Ԏ/IdK"LtrD9592Cw5y2=O/>a|Q\#Jjj$<2x&T[6J'ȗ;أv3#x)7
+YrJ)HNUJh'CR al;dveǺ2{3zOc]ȡdr8.E;#.pFo,u.:ӝxJ?# pO+= NgtG=!t_䇬y,'BO񽡧 cg$}gyct{d '0?{RB8 b|O( d*v i~`=ׇ/8_;?ahR^
+H X&,C\ 6$"fU.{f"?n<2ƷY_$׺4e@ԚEZƱHv.18uJ&vKHUA]@R~490$=iCJk6$2Q@LB6&SYw2pM6vڼʰRX`qL7T6=gPV=l:υa42C(~1ռzʜC dkVtСgZ.\RNzܴb+WV`74}XSo
+7bsӋI@fq&UĠo`W!W1mRH߰iw65
+ )Y&T*!J nJ3;-;.4XX/[u
+4Z6mo Vh
+3p6H|bӆ8
+SDž9u{gѓ6tlBjەaDKl:5
+rRmy~eѳwA o5_{yowt՗_:y/n|z#.S_{p,~U1g>TD׉SgpD.9EEPmnLxmvidfg;;ml&1riLiLzn^e>%Nqe6Ƙ#@:JDdH;gu@u~s!\S% -XJhKh gµ mnheWR~g'o>Ͻ#
+I/fư}ќ;Uf-mH
+Zt~b~+bY=b^A8 4(cũ3:c&{ކ.VΦέ`& ȏS!kRd`z;zDL>R0Y}lƪ0"iJ58SF5YFs. ᬹ "m"K@AP2\L t/2eTE!xHpƕ݇oE6.@;"W(_7w?٫/Oݚǿ8;om7n>:o>hh_5zP*R^p;\sYӪ]I[\UM.o}4MͱoZn57 ?|_qrWk_45}ݲU~Q\r.@'ړ E>ĺJgShM4U\Q?Ys6!-\ vDfi!RzqC&wYa0Z?=Qr:15QWgu ΀#rxf ˉCޜakHqƬ%D$UT뾎kJjqQhpbiK 0WH`cR''TSjH R Q
+'t4ղఖ G82
+9,g["RaS>D[np*Lx=  )Yv< ֧ѭ ѫ4mk@ 1kN9D $39uUyyS% Բ5f j6/+@fD+3vyyI\抦+v:PJGB:lE
+EeȼyUuFi:g!UuF=2#R7N` f]wN){F/|:%o8SUn*怊iFuTa8D3Z!<I R:! cMỷt+,D KPE5Ip2IJC2F"ܺCĈGKQ"-/$$|_B::R#Bq!fS?atPXTeԘ&_~˗oX E|^"(CĦd~MJ1<bJ1, β,|
+.Vb* \yvoh4 )fBE|r@X.MaEXNfsՊZdqgb!#S%%ZGhgGYch<L6->_w՟MZzn?r.ŖUv}pU?)C,o Tv\K<+֔m쵰/*juHkr+b3R:@\@|Aq**cqu BG
+*/p{+Q<G8{<\ew 
+et[9wnչ|.~>:Sn,+ֺ+MJF:ߠ]iVN.]wBm˶!2$qo7ȇl YCnaATu-֚ m-BZ[d;~9-A=o 8lm
+ZXNOaI&5I!vƪRp>390cד8q'Ycw:MFᗔgj$yԱe,k_?WsOgϹc8c44zx99XגdHxh0DLv&i}o/ߚZ!<Z!t6MڜؤTIi?\Q 8pqzBXM?$[)=,DD ;$P˽*ϮP+ݩn
+2[v"Q g#wU|tRŚJ<!0O NuI2IygrON<'k6Ǩ&3=?|Ayv"o8IOGJf
+EF'Кk􏱴F&QZE&KFh0iѺ,j)`F# ꐻ ,*! Fek鮵8եa5X]FK_ !fLǴLCbj+}ALt>bMt(AtjtX25LCx5|\4s2T:}Ut̞(8
+_cS.=hQ5>68 5ssjE) ,@ܞ5e|֪h0m*dsM)6:U&dSglM e܆hhr= &sOf_ۛ7ۤ /ښkN)"( LӮcy!
+#!TDaA2 I90~JFN ∟QӋc~S:7zF\w!.$F2ϸ*Gx%S/hr
+Dg;IBhB`򏵯MAe/Bl3! E9k
+PpxP% n͹!, ي[umv]dyxGh{U\Tvl_ɇAǥWra]m2:#{㘀ÁR/\B]R1uP9*s~'$(p`%…|>_QbJ.$3!({
+Q1ْgmTq{)aT
+UL/ّ|pqIɂ%Z7Qte&K:~2rD]} ^ u4O?SFo8M8i=pd*(HZ:{az%P >d w}$ eT&fmSٺZ{j넵xO^('^~Hj;=5מDz؎m?&\wfS*NZC<hk@:vVKݪk(?@*6.uO(= n'] b\>k`ڮj {e
+Lһy>\w4~D9dKvK 96Ow"]}MQx] 툆Ex-8`/֤)ʝkWrrGH%uEOX){]Xo7õ
+PGjDp*'z
+3渒*бS1%(e.Z]=dfqk]o[=deu_Nuj~<Pi^64Yxve27C83䟮=V^TPƲsqebÏݼoB\!W@ydB2 @V"XYF|{<qv~k@<Dl 4nUtȵd@;~JܾU1zŊxxץѢv^2GBw8 L%uzz{]seDI%>tk-;vxr*G C%vش0V 2P P6c&sDih:KEb*^2V̤V_^ K6x \xoTB|M iuY.KBCɌ$l-80?n4`&*NgCAɼl:L'8Vde ܼ3n<} BfT
+Y"kji-ڬ+ryֈQ<@fHPsK9 났kX*@8 Da+͸
+W.jB_WP7FdX$C8L% 58Z0N-tJW=%ߛSHuI|b* "*-8c?mu C/7_c>#| ;! ~6SvT:&6ծIszG1#k/k
+)h]]-{96%%ȧs<*P#u?Ǣx'PP㇝#F[&r9mvC%=z$`;K99DemAG~KNZLYuFŐMT(pȇSh%֎(JkK
+&k)'㰐YPE^X*ql@񸙴)o9[j_WQ:\.;J0OcuNR@|&ǩkR)^ތ?Ƚa?~˸wɾW}~w~uh{}mPY)cz/i_$R rMM[:7ú3*urTc8Je\幭" csWg@n߱ߏ_kw3.ϸ~K|!֬)?gGTb,ؼ?VtWNGf8_23wD5ݛyӯtcΨNꎪDTJ$Kr@#vGbOD-AmX1M
+Gr^zWq WQCto^J*V +g2Jn %JN(%ɸ?I0⣒L).ƨجpM0d}2>1x`t<ꕪ.=JS$|D@,A"h"!׃z}'R$ʔHD?I@<掺r;۹k팑kO39=˙ 
+vSWԋQ+8Bz˯pzwN8:TOxzǩԸ=ǭUϥZD){(TʀWrO@@޾fhHMCbI< ^TmUco=\O9OSwagf ݴf
+G.o"6w.ޡ]ع[w}?7;K n'yh ;qB @RBHŸ29x1/I>+2Y9є̎B ?PpBt1BDqt/ VBFuȞӿo2y Vlޣ~M*w_wT V\y(B/QPJk,SnaέMi.r7h!+_ψy sjT?-JOh抅P^̕_j/0 5"yP~AsqBXE |~tJ==~Q̧VbE ۇKU
+q)|B!J8|O뭃*nn6}Y1&Pfӊ77V@`^nM>l=.-^ eoubڷY_ZKͧ_Aap/X{9K IV|{ ^3`Lߕ gE
+A@U`\b&[@} TqA#]`&@RU{ 6*o,WX9 y{h;mmERTlm']_]mdw
+qƨnjwP%rLC372ju:
+jR$EsiI`hdL b1ҭn_|`Uq_}!FUN1{:GY*de:GWw7EfNjywigiE'³gaމʗ oI7_x g5̪WYAaq3sҧ?1%OSɼRTA"Q!sb~*,zTcQn
+y-o3-^g>׏^$ʾΖ>lZ77ضc}Eh/-9c=/uûJm|v65 uC{ٽfqU[;Ft7ZMEU*)z4"ʌ{֯KT==sS‚nKfzYKv f^Dj d
+ ^գ+f~3D)SE ZbZU)+M֔&jOi3Xs{ 궃
+ZrY@QcݷVv
+U&T 9nA]Y, ?7kG<i3* Z GiTD285B9 xjKR[rD;AL -SR)UC~\ ~.0o*3kb;n<Fx-/3l`ᴋtR/^D|M@?|ʴgzqi뱣<kGAڟ Q6HĦ'jJO:r Oj¯5cl9M"I@ʡl$#Mz|MԗV $$HQ
+ %l* [x87!:ƥc@# /'>g-M0z<~(o]L.'@e' m8 ۄ#`lqp{X3wWg\뺇7s˛L_pp7@}{ ۊ³n؅"XSPR/VAp[
+~+ s<q
+Zj[FBVY, ckm%8E+$h 攋lJvk*J;$jv &įZ[HY8`؋8keYZ-w:^lR_SEwAdKчQME_I8w۟O?p{K$ƪ<9|Z+S2RK0@рtyEG7 TxS9DmtȊ^*رS
+;DAP! )PU}Y
+򖎓qVXE/
+1w\'rhNʔ@k#1&*}/ʝԗ3;,`q̴F@UAUM0Wv{x'J/΋Jy邚)xጁ\b~huLI*SwQ.pJq$_IEP^p/'y+QT)Z(!?Ĕ
+<y3hP˴lr4m5tMD6>rLT\D)>ȰuѺ2/xgg$95*TR=j~HXNjWMcZAuZE[;he47(xX(
+iȪu"U}CX#WX󧄻U[ݐ`SjQ!|'oIOJpLaŶ9C3ϝ+ 'm)w-Q ͤ6
+ϙ.߃N]o4pr`xCzy V'kdTaf+gf.aVcqÂU}#<Id.";NO8.ڸr&y # L
+ar6^YˬLF;ڹ>-;HYU޸QBr_`z@T+%/m|I"aDJNZ velN9d;+tg+v>W0V'V_UV7KDj}6Y]f9
+tLd~ɼ[fO`UTuFX'5뤷ͶbnbCtd?/MkCv+b6z[:F܋6
+m}6eȼ-{}lspT%~aM^@**b9ˌIpO^_nW`nį\ U&+ͩk4>SgBolj] F@! FQzH1[!V 7@MuDz!Nh^| ? 7OA3}E0.Rk`#W` {":-a
+ yK;A/yfy b:8Ѐ Q"VSgVoIU$A)CaA;fZ
+GlBȘpɍW Jo
+
+EdrL:vbpv``^e^ifμNhҝE nUP\tso^/B? F)>M
+dm*n)o8S#`Plg±1EJĹ LX Sr1NPoI1GEb'[Z&B ] =PoSU~I7[U$|4h@V:¦ZçƢ#} =NQ L'C8= 49ZԱ7{-=#r\jurokd'N{~ӜGLݚ Yc
+mG'&XV ?Νh?5}B_=ZjaDVd#k0p=ܕ
+hCZ($v] }.n>(iDFFHpS)12&
+
+U8(ṮҐ@%hm̃
+b ϫY;цkntx+i?=tk`:r|YhQv..-{= +y[hZ[MMmFSzKᶹ. L{̶o_VڭNealWn^"KZG雒}Mzk:m҈Q tk
+uI]
+.n!~[bLckKRTib!NN[Nv PgԨ8
+I'Gwi9( K!G)#מi:@b6=ε̬| k`-~uVORN35|Kۈ[$#
+:/]%Y/F O+X&Vpo-GJg~2 +vBVt3~W]k /o4̞#]GȮi?r% Fg /y x (!g&   s!rN6F.%\D<Ql+-3yo4:0>&D"җ[%};ڷwǹwk2
+?(Q j
+pr8:',BN0VCnԚZ*DN)d!Fԡ4{g[ 2jsЦۛ6x_kٙUQuhA
+WpԍDZl<V=z5gU@JP1`ט1 C1!ц?J$@Cŏk](MDUb
+du:]4r0'6%\)` f4l1
+MqoY%>[^ ,ƺ.s\!%OSuy͜,kʺlS.P؅O {<;M+LS'
+VxjILFcӒ'Լ7-Oq͙߭SӪMg\ut[>YgWm78X>Ls,αr||R"gW
+T.s KhDZvŞC 
+C@Pǝ]
+hD -d暈Jd5 e.MpI% "H\&Ar_2u]X.k#ta$%0J؛rv"'`|iJ ;6Q#*pXDZ*k=Cׄ ^g wgGX|T=1h:\%x쑆NJ~"u`Anmc|Ss;{r:
+WK9 ˗q T?DPɪ_Lok07rrF(#2iXZQv0R1W{1?{='lQSpVmOhhUy)=7Ii_u@kGz' (
+-uy=-zu2`NͨMis_n ӇJ1fbςW'(8}P\mz]UWJ⼋v7kvi,{ȋʗ(U$I[uKEA '2Fx/$|q|۔8U4XdoO)E}:*-rzڅ|ٻEy]Y=ȿߋ=mm}w&ul~oDh
+YVd3nۺv?n{޵{Z{OH+>;ϗτە;ދ%[ӷE8[+wk=MծZ;e=__@M
+qil+A>R|y hYhJ dT Be6LL>EYڽ,dEOVV,E΀A&>⧢4vwlqJ)'črY=y-@w7Jb'~ډ}`7juJ(p_["|_x|~M.{/XI7o$ǟs`o%e 5]1DsIrH.5{ hR͏p =,PMmX_r@W+낭D`'.GPT-IA5 9v1D 1
+:x|_9&eNl&=
+[[UE1$B@W7PĘcTrDyY4I","q\
+TLqy@@=UvϮ|D+lOEyJ_{t_[v ;7!ʚO ;ӒO ]ظTcLI]T?Ԓ8_u$/kM ۫NU)Aj170#ٗ pfk#hq7wێD4F2zNn[u_ylqW)ΤHRI9őn;
+rPI0$ {њt6JNP<RY8G#:*E $DS뭅+{URbK5lw9v^_(tCt
+hNp0`uraIby@Ymr'`.jO*Cg3( 9&Nyڃ4U`X/<hO[fZ&Ww+,u1]Aڸip@ZE+ Շל-u!Ξ
+ម%Y\b&y~`jyꚞVAGF3D1dE@]Cy.}soP:D{L/'&&e~ 0}"m$nj~/z^%«5C[a(}O胷7^(GK!d"`%yG"?'/taj[tcf'Fw˿V QKR?^~hp4v6 cf8y]Z=A*b=̉%
+&#zBOR_ڰ
+ :耮INm35O꛵FҢ:yj?vr@.^1P(źQ;occl<16cGF"=47T.9S7mmO*kgr|T*ǁ|AGGqA_hVjSX*1U
+5M"uENPc_P&٨Ҩ;+7OE0 Ү"FIEff=a(z"ͷvs ?$@m(mT)
+UE !\CWhf^k #FW2V!=u7i s hu΄A6e`3f6e" 3f ^ O@.eL\s$M@-lLzdf?% mFf'#E(fJU]=͙Q #{[l/uܱ(?vmn\ۿf絝{@ܹmmW~W\g˖
+Y(S#QbBX!(D]`Yh57ƲSPĄb հs,;!!2"@LyQ{dCZ)iǿUp/k]Zw{VF9[@T.TНz- :! HH@ќ@sR#Bh
+u
+ ۞h
+9ũ2KiSOWM V5N7#ܒV}wnf1g<dH ^vOEVqś)K)Λӂ1>/l#rCrϾTT
+B}W!<H_qK#5f[@߂ %k~Vr8
+a ql؏Ap̨r]t+\Oъ@
+ߣkUC?;@K6C3qV3gP96Oz͠PΪL[,i4ek}׍zg@RS
+`;dFC!bQ@ڠ?Zk%)~ߍiȂ.eU훕} P 4-O3bc&(n^2Gbp, Z9ڣ0`vٚr5 =w~kF0ӠbUktC<]Pc~צ1ڮNfت4+L-* ^D՟ J}{%~q5^Ia=@}xp5zkh=ոոVcՓ;UzS8{S?'>ʓڥ
+&3Oß%ińwF6v0#wOv6O՟vh{
+"d-b!M-ɪ
+asy"H *Ěr1cVDN (R(ܳE c*0$C^"Drɣ|]9W/e_o+[=YKIف1͗3q $_Pո
+bP[ʑheb% ?YE 'rQ<{}aBP+sN)8_q_gi-bOlY((k?qqK0)t
+A~.NZly}A>II%9]nS;!1
+r>ID#N; /o_R\qFYKi|kNP
+UӂѤ]1)7/I >THZ Q _,nQp<!Ȼ{U_Ϫ{V5^^`ӿ"<z F[ysͳ-Jgj֙ޮݪ̿ F6 6dy9#Mmͽ1|=%t cYCe&
+P'!?gҧ4YF:TPa2
+w#001T>#_71AXA Sv6u=Wn Zr#
+Sqf 2No=|I?~LQͤ\<M`ޥWVNS,G%,מ8kkt<q[nGn)4ptS|[kiV*z,"E'ZXz}㵧OV-{bvXu 'x&Wd^ȡ+;%p@,E/c 
+e״k}%knN +{}k
+P>unrb ].!W25JI6LՎ߱32
+TjQԶ3*hNrFhA( ĺ4'ߍ%W/fWU+Kgؼ1H @B"h1$\=~ˬ<zIi户oU TUb<c)HwQu}ŝ1<Nl9024{F*8 N0A͎a|ORNJ?׽?.xчg/=-^zNܛpz8BQ#C4:UU½m=k3Aza?-<Li9%9m1W^J >q`Fr A}4HW9wnl9I4!~w7;6m35L[U7nAFYMg ci #>$#C6xF H凹vf@>PXC`3@}D>KFz]a^ bvyzv:jODOy%iBzXSsq!H eLKW62\>ڎ+e^nw8 | DנȁVR"͆~L}1Y-<pz ކRs_lxRFb£n-q"HS&Cuٓ$mʛ6^gjZlު9ތJV+ݪJHgmi}yiײ{cy9+7ey~k_Rp|9oXMT| ՘K֠Lʤzf4 !@lNbQ2iPLb[ePLU|,SDxuؐ=ўD$ml;h#K^^)e?5o" !=-ws<*Le"F?
+dR\)+T)b#lnȃby<w~{O{-;?ه(*$'GxxXi=%.3χHE6Ԛ# n1^^!{RTWDmor<{ǵ (+ͩcA|9>mnt9WҸ7t~r,YɶaLFXv*Qٛ}jQ9i-,$Di1qƾymAIR sc_̰_o_pb8e_\ۗ1@Cy% ٮ]_`=|6f R@90rpnkg_rzx}1eYDszur@~Oǽ/b=lKz?(EGˆ, (EpKT^U'gbś>"61G-P3ڸp3sm^D@-]ԧ pk<&Ing^p0ͨҔ¦Yp?] X-'L!\W\JFiP8(e,R ePk(y483hJ*AMX
+KP:8
+0qږ;e<3i"$y+.~L;͸^(m7bgԟyA'tq|=_),
+(ޭw]yu5F_Gs$U`~FvȾ\}KZ"ηD -[L9վw:|޳Gu ȕĊ{l
+jXyF.iIKp+9a+)ϲD$TWr{
+n.)H>Ixiοr1W$"!&23%+7oeد{حd)(Fm%}UL؎C|F'?a)BvnDX"*A|F6QŨoe1i7,;|BLrS~r-RVdr68bCПQg3V\[*"kZv0mOծIN+*xd䶀[Ī
+dOI|mmyF!a7 C|u ymαBu2ZiNL{#^N6`嵻ר@\z`Dmk@ݖa)(OڿJ|ZcXdTli:qD3Xg*Iz,-7"{aY^HZg^0֋/n֔EhvA"m,_Qs"3lPvkXmk bNB(jvJ۔H;gymSnV{YgV7X m,+RuG
+5k;z}d w?DL*ɲjF":}Z,FL<>@hϒ"3YmѷY³)t?PE=g/GrS|w.xzu C!1|4]~=D':C <Qy 4(UFS@T$SAV t>]un`BUx0\7^??xUһd`絬<(v )6}<;:OdU|AX܎ Sgwy;]*P
+jqv:`L.U
+˞+p8{ +WrrbiIfsiϊ{Ew4_ZwY@wJҬ5cM wws|q\E(`qYΐ8d;Q
+\"rZj.?p \G޹aF645[ـ}O׫RG 7T>ZL$i?Cqr~YME|<s[Mdud.QZA Lɺl?4SZY
+cҚ*>s<r ĊGijpƛ+':UkgT n)
+-"{i
+{ۖt-(zVM% ij9݈#݈];^M:O_BSĮ=ժmh⫒&`ޠ# <0X]+G7+j>@;}Y&MZ|=kʲ6\;%K\,:+͔O0}bTݷ?
+T ڬ
+*d>8Y]nD X l8j;&8uuKUH+FՆN2
+^#_cjhۆ ژ#כ(V&MxhRuLONK?/Vf& @HQŌe'5. 'qI,8&'K>==^{0/hy:XK;Rޢ2o}~ɛw7;2ޛ7_1f2:l ʸ.ضɷ̹kճ.غŝjllޠ8Gyx͜9U9spku:|kf&н(K7;Bܿ1Sgx9`љ͢<T4*  V9:L
+΢Q|3ʶF9zmT"-k6ćrY$ZFYaZ<RwcLb䌉?-h줛$N w Tpޠ
+G1w^{خOj:]Ǵfͤ<Ӏh}'$p|ܞD^;O&jDIuj[!!2@nEI㬡d q
+Ell7 @!? gqPDZ<10"ؑS89~Jfvc_!iTY#yuj}Sd 1:W
+F!j┵&q
+E[MGew(vBr/:(Au?ө i\=1q3NZFWKKQ
++zlOG!
+.+#GSF
+CtEȀ-#JV!5HEl ./һo{ȝdc6•M9xi6yfq `Q#::?z u 4@qjt Xـ.ΐjzluP*k(\[ ˰ջ}f' MHl3
+&2v/c5_it[:CyJ`A_ȏTq(@];?
+`IH422<7rOw{szzsMN
+˛L !W]ķS Sy8L[( H<vO'iM[Fc-}dlOQZ=?߱jLqLIh|>jp2+ s^9A
+ ]KMcH`,lp+WM?ӕbG&.1="tDNiL2e_ 泿
+3P`=Ns)&jpmDM)Ե$Y"5~fRDsg|bYqRBՓf.d4t^qڜGu#”WBָ%iQ%bh3' lq%mnB #CLPDI[mmL
+F\”u=еIK;6;"Wv3~8ltݞ??uV
+j~;y#d
+r%N#̅LX2f:`Mn3O'/IwaRSf#!-/k^ERǮb9T-2^Gop둟bb{HŹ^PUKxV e!#FLP$d6A JW(JٮK aTTr4SYN: ֝sh/,AҒUgvf%_W;mϹNڍ
+^AEj1v};;tCv z|GiN_>Ur_4HM ۱;E-f*ɷV|+I^'471w ٜj+)rG*1SFG F s
+h,\e^g/̎rsr֡rf.9E:y&yj~&~d|&hlH|0Vh\6l1Xo;OvԻ5u32~F
+ߤ%j A &'+jhR:l[&;kGƪU?2LHG'мJ㕿<9r0ZLY^ ^u^"idQ}h7˜h:+wjJUzT=k.?r,Ea㕠Ǽd$l/t8^q۽9|oFwX'ދon =V;"GD^4@MQ11(N4z>V%18E|flېw! 5|Kttb]uU >_Va7 uoxPs֖q,cvgfGS'+SVM7VE;9+tg5~G2vK18{$Ůsё] gs@(` iAgٗ^,#q&P!dSM!Q(>]ٯi+ΕaL3B8.9k9P.MS#~ktї?^u\ 5I%F c8&'a~EhojI+꧳ڊxr2ގ^`r"M𗹇s+-;ENT ]nLeH3m]7
+^&ӗ
+\pb
+3\j
+V"56݅BgR<|0=S؟+)`|OI``O4c;tMTgS9
+@p
+ΐ&9O*Ӈ|3l}:jFt2xxJ:b>6JԧS^\ң)QgJǂtX`<3ax{Җy*lOҮc~NiEfWPKt=q
+nO%7ȀA׹{u}OŐs` FQ'}Ą,&N;20a\ǒ@}<WὰR
+~Bms%Ul.^ۼ*YK8NDr𨶊th(=hB*C@ndd̽˭>S\zX@j@a=g#v=ycFc ] ݀hLv*K>mfJi\I?%`%c0
+';Qd R^P "<zB7nS/QL!s1W!+2dh.g4U) )3V@}
+ WvX5ː6%qtz@0yVu_2]FHwhߊƧuQ*5fOp:ʌ8Z)IC5dP>S TɬIof`THҶjP֩\.~}sIOl^RF%h 3Uև\vuyr-{:G*
+{KfoiMR.KjkpupE܀.Ԡ%茴4D" 64fMiC
+_
+&ʪ`S"Gtz-nbۓ"gZ _Z> N1srL0ALN/1`20(!`P$ED>T<J)EH($`\!L?HYCKYh1n<D(@J1E9UFrJ-IbL8Eqo^Yl!*|EnRߡ1ײoYMrAja~utZٶk^ TKxg >,fex
+!H<ˢL2S?JBK\WK|Ն/KO mc VOnQ'_Il%)֚{H 1>mt 5qSI=ʲ
+!ĨŹ$J'E9AIS<AaSyqhx*R.e4n&JRq=0 Rv2 Zq.&J} qR"N2C¸P`H>%E#9dsqI͘w$ILfLҟ2~OrM,FD"Q*$DE~
+ 4<beHR23C>yH$4
+>M`dFI6;v`QW3Dr G91{AK_fn/;LO"ЙԼRcțc@}cƩyl:uڹ#ldlLv4yl%hbB<֩S -SeBdSaq<"esv\F!h9Z4OG 3"[`sNͻ_t!
+H.f5X%\haUhϻSH.H8P)(4eTrY=q<RRM&jOlrE>/+f(`zVV*~־6 ?^gyC_h]4G {rhkmy ܱ3^%pOc |yX,X2
+E`"LPZ^n} 3W3ÔP[xJ@( gpV/dXh@B  ÚWÂ/DKӊ14'1rU+[E\Cܑn 0 P…,
+£nIqrI#J(@{uYPZ&iiXd?Qse*ʩ()XtwHqJf֚Ben4٬Z#ff.qH$`I3 e8T8^q2%J[6^PF
+0k~p8RBBHIdXD^eHV$DY\;b$&!\#xWk2W\ BʀEʳ _+y㊀y9V.ʱR^%ʫ!%kZ.яAˇ] F_<_/͉o3JonO>7yGP /G pJ&̷X+P6mJ_ˀijiB
+U# V#MTR"DsUtt/ OX~֞~qgmsк/7ॆW 7c~T:?hOa=yA*{ITu+U~.3]R<) ˖c%v"yeΠgmsg;׺n?_q>\=; Wu˙@xy]ajW_kp N){'sx<$'M# }jiϻ;_ryC;y||BDž͹[V =Hh5^v} ]^ݙ۝빷9pۓ;S;3cyװowgn͜9}O7*䖰[">3Ŧ'S~xz/1mM[GA72{4cdo RN/`:
+b,0}wk#lǝ؂)Xpk"0mt@HaQq<+YD/_/C,(+-M߀q#ahBcyxTMpQ6 }5ixHO3egެ|u4)Sd}B\y Ք <TRDYg*cRf(g$dIҏ=\ Ά& }@@dyuiaKY@k@ҡۨ6v2*]ߋ~h(1]aڄ:q?PV0%M_‚tB ~?a$;M Bbڍ@HCj ]@.]]@~04 Hg|Hdٕm@&$'02ݚ8Y&|<qrNΣTÃK$fdPM@ ouyFfl=&K:.2AX~̖ *.|(彥wMY ԿIwRU`}EoϾ5{T6W2&=U{p|*[!9A1W!<{cQGhDKAAwz%V-S/+k:<Ȯf]%}qFts`]XS?j=]qsn-2|bOg.v&='tVk@d;K!l}uw~z:No9Nwݧ3>Y r
+s'K.Y-?*[Ηu*Ư 6cL(ƙŇ-UtiV+2\8ڰBQ
+al@bN7,pa&93
+sm2+ׁ ʌSޠExrF(9U ~XO*82_R@Ú3U :aAʆF tL x434͎
+x~~^\7BT$_ZOTjRpJ MVZ>44Q <fPCH4i+Ȭ`0. ۘa#"MK546Ѳ^tb4i2cV]8aP"ZO?=W5cwl숆̶NKk(nN
+h`J9^D^)q &Nw#W1]KʴSוdBZWRpCʼDz;\#G?d۔y (OoפҟeO ɏ#{G~%= _\-ec@H/_Kr `` J>
+TO+Xi14 adb#4Fj$&yX4U\IJ9|FHg`$ʈĕ2GX!|I
+91?PEyQj1G_(O/Čl43_ǿ6s䯀La^ H00ƄPY3!l8`1PI6LU2a5 …WDRC*Ңf!d(HCt楚R`L T'~5~sUϑ3Kؔz49cOΪXy':%Ldup4i4fĕB}Cwٟ):">_a^FLov--׻}WFz]xtzw賥/9m β yd,lj4ΨƇ5gs8gyYp>ʽW=O/Pfaw|ޝLlOwl,<g ϶x[S FMu}X_[{@9;鸲>=MOw ^]m{u߽8=q+33.ȵ;'~З9=yDA LDD7O9
+<s\x2ƝO4gysd7<Zќ: @",\
+.jO`HZCjS<lcu#%Urb_YQZ%
+fY*fd<q&HXnSmd{d ;pҬ(mmeuNjyJ' G`gKe:TCXup:j:c f۴A̦:ͬ]?c&e"  JT3FvYMhGTs2j\~.VV6Z"y,m̮Z >Qi)r#ZUT {=6Y!̪bn0?Bʹ^?~>L"O˃‘ucEY]w<G'PXKkJub!솭 _:XUVFN4{|Z=Wʒ̞]s(lE-趔$xrϸ>)z?)=W^u|ù纓AWfm@rZֻkf{PP1HO=0ܦ:+l@v!Vk1T'c0#KkQDD$ΤOJ:wN
+z-\ji 'ZO,d4HAC[1 AA
+VfЂYK Qܢ# [D m`_maQ:B$j~Z%~x2*ęF ]
+$xxm{<svtݤy
+LjNYNKT,b6K4lX.e--ڱ\ũX3E@+»
+.5k
+
+k5Nj@EV lQCQoPJkB:5Wi7j(MaCIyH0&
++tbs]kuPa:6X(mRƀEKfHD](-2
+: Th;Q/m8T rZ>eV `.@>
+,f[ٖ]ޮp.uǸ.ŘڐՀ!rC;-dQ? eg
+%r͖'=dٙI::L &MJF=r`L:1[w:Ll+ i6٠5vRݮ}{tKzgq؎ 9n$w6>P[-.L1~~ [@`wJ=@c;@a@w͂ߺ}(.-
+DQ7<q`d%.Cm
+ n0}Ha5DX1Az{dݱvӮJAHО۞ }탠%E[~)8&jԃE
+`sw+v+@= {\N0<N6k1˃aĈVWol4:)Яf
+!h٠*}¿XsUTsH^Cns Z3S
+@N@zV
+#Eʭ4&[]xڗB佊XS `>m1k݆j@VEF>ġ!mI 2NQKG)O (7uH @ x>W­IDzE@,!x\o3)<qeǕ}T*b5FcڸdpYPGz[hu5TJ-L0C $jf8 \<H֩2n]vpIȃzP $ *kY_ h EL5& auRmmUC)|hZ%!
+)FTmA&UP-5L[`q ҌI1PǠbͭUz({Q}ҘWjA]4g KUj繹_XZ(NnxH--\ QX ZlE+ }={GY73#l}sXk_'Ƅ/ h wL$mOUe+ʲjzH,tqļ3wrng@t?]L,t^K-']+J׵ XID`Pppbc^(@7A2u1;>7
+_'=eOU_mۀab\A~vQM2^jW&6y[
+t
+vKW``iTUO}PO}TRݪleRΐI_ߎ{|LĻ_g7VRg.l˛rc%3i\Koli,LewIL֜*XoC,! ;
+k%
+4ݓwiZy4 ᯙ6r$(ˈFV Lm\/q=$i q\zF,PnVf]Z|#@',̛(})*A il3chIcvr"}֟Y0W@ɴ3c$
+<w} b22A$Vs*Tr9fhZ# #H\y %rݪR!e,YRfj4^`ݢOE(LS^ &Q| PH$u0"(r.3Bi2V)iTVtF(!@4e !V*Q@n%IF"A>
+rR"+e8JAiT+LFrP' !B<d TA T`bMā6EV%hRc)6蔆ߟ"Qi_Q@4G 54@FT.E(P]A
+E{55OD=k[ <5K5W#RC6,n B30r!-ܰ!#&vwSuw!-VdA=j9ݪW;=gѓg-/6rÖyEO
+ honF+
+֎nj$:57O]%E25=a$ìXCs^"I
+Dz9,jdXz ciWCǹj[ 4^`CuPمHt5_YNbJ
+IySI:haCIPa4=8ZLƬwO
+ 9A}s͑k(fHJ<)T "J %_ASby$P4B5AX,-ՈD4wŮ R seN 2<[妤}9Pd0=
+M9l]V
+lW,!jgX=B%LP&HrK~̥#Lzwngx}5v{W>X#IՃYiŗY󕟤}Yˈ{:iϘ./2K̟'qgXGHqi^MKC&s'7uҭNǻKΉΉN]ˠw]CYFׄ}dcӱ52䝱 }ޙ )3\뼰Ĉl{tm51lڄ:{ho:9XX=N_Ls͉<3b9rvץcGݟ:v^vM\\T:9:jYpt,rXsѥ=c?yrԵ'7N\on\{ϓWy
+(x@>|tQ &%K{3>rRr>$9]od|➦/ '9P~xsW/#lYIޗc |Fm9^Š !lcn$VX dT݀1V,%K)&DX&nXl%Fc(l{A@lI.3zsmoPSA{.d+cUūVdIМX#άJYAv;a6]ftlSmԵrC{)c{fy0iD@~xو32cȈU<7!aޝ`
+68#n=n2}آs[08>F׿Wֽcn&q/HRč
+w ukw׽gV6Gs\'oӓGh ؋5"n)c15Gkgy֪E>FHBb%bK| [r 36S",䓴bjN5 ܬfKJu __YMy#[&;,}>F(D|x,=S~:m8
+AԐ L@pdIţqTCV8 ;
+X()I5%GkhIp,IIuiՅ Q2@H ?D<<޼&$Lq, 툿A(PyKtU&mՇs>aSV/{[Wb]EHq8eE)#̘464XhymhS~ |l8lS}פrjhM0WqI)6 F YF#M-
+,.N
+H5ȤP%R8.fB|+i%Nu_Jʝ -&.95o9t{Bag銭_ow>zywT}hSmn6"(?i\ZdPYa-BJHg0bEe"a, j2`$FqЅ'gw5-zA<^-k'V "Ә/uW`
+R,p5kV2R b0GT\TZ_1Df4XwKǟ>z'^k{S;7l7:vouټ5h,S/4g(4f t<B-SʱвyO>xzeڧ=<[z/mzks/^;w] ϒcʳh.%Y^pN9fW]C3 @@ϯZY<>u욫 8-z̪/>}j/`6]jݸ?~{wT S{(]IR:ܱKWf@okfmS+C͝|g/iܱٝOwaW~s3uӞ֝586Mm9;i\nﴍﴎo߰L_J?yp坏n?+\OR*Vd[:@TVQ(bc\nL=mi+,,,#,$W;DAҌ(\Lt O|loEe3!sd }ݖ ï$8
+iK;pbmM| l>,,0`¢ohˮ_HKMXtlܓPzZ=l!Nn®/Ѫ $:ZDΓ
+tl۹NNSUHh%9`JSp )@OCyuҡڤ{ū0ZDKub[Le5 ;ʰ&a- }|w?on w}8(ɜEf^=&-xJ+G*1akPl2]OMY
+jh _{n7S!窔xfnӭ]KIAa(3h #i)73E&:hI14&lɎ UOz>U(ceH4T+ɵ:/^5t ۪ZTTThIDL /.X:YdZaSu$@mJU2b$C ռ68v5iW`uXX˰Θ!twpo@yFl DXT"ɜ O[X: jnRIT#Ip*-x "ӱIt|(堰 I.hWd>4c0  ZnJF !Ašy&i3RL@}$&(gT0 Z4Jh5J]q@!%Bm#H\ǁP_
+ ±2T/sN"2AbsRK9$ \AlPZT$(|=֤6]*Sd6W"c A̖(Q ihZnOaE"L5Y""/
+8?nzOen` >prhDy: ¦7SǾ{+19Nz,ܶw.}[%\ s NK$J9IقLZx?QwVRfAUMhllPD #@ (0k̂y0)-6T(_t2=K]%gV)O_CnZ3Ypxwm53mSǫMdp=W^-^K~=YDIb2!+3q%L#*/d.Gd9".b&|+":1I Vl~>w<Ӈdz B[g<@$<?,lԦLbPؙh*`X>Y>'2KIuNdHPZFs'[ꞽ5{ʟI~êÆ)-dH.S<~~TY.=]>S9z/~yOCC -ޟJwQ{|rf[fV7,P.Z/o Zy`֩5=O=n::t/ i9=C_^~/!h'?up~oHw#<w7(&/K]MkN^n<;pwmo'o0ڽh.w<]/yמk/o߭7[. w\}s|n(dOԮ0ֵh׾OǺ. |k< +9ܿTN=8:\AKK;`}bnթiޚon}{OQAv"4B_/UGc#֍ uֈD5Ff~[Mq<W* 'jϥgԍ4!d7vb5(Q%&/1Vj$fӫ⸴2E˘g ]t}w}{m[+4%CȠ-}D?ʹ*ujܖeYg[9\ml,PWanTZgrnzx"_eMgoh~&ZENAP ^QK`i52{zC7V .RuHMRi&;
+XoVٔꂤM Hm;ᵜd3Z" }8m,C-dWN3t2\) 7Q[ҴADƀ"\N4 ެA2U pֆ"s% Nf1$PXL k"@Ckoe/iIIT+l
+]ePI[x$ADldۈЖU<ҬS6-ڗp2*n o.
+e2)3J(KVR6FMVP&&&Б["܊umx`+o+(XeV_qk;â]KYUw '9 'S0E9]h4P@zBQ.AiΠ2VE
+5+Ìllw@~(D (Đ DcUhQ`ٴV%:P1r&g@K,D1>UqX D81U(FB":( H
+k8l̔dIjU`R$X9IIhQdӈ -\`q.0Oi')#X 0er@( Ԝ݀-<KJ$Ҥ̒ܒΘOU'&#$D
+Kt[p6Áu{J@:Ir>G2On)K:<z<J o1D#;5LRp&ǥoHhl@־rҾr볶{ol4 S?ª4/FXZaeB5q΀ċBd2jY<)T.  &o"MMYmCD@!(KD*#.D:.H
+ FI"MC.D!V̊0>
+nPf^,je<}|Nu>Y`X#ϑc@Ol8õμ48{ٟn:0r.fRk[4"QTc4r)`yFe9X@,I$%Tjzy,j?wǹ[MIOjyi?B^+  ^*)٬fju$X.fH#9.,x/׎MS3ȷ_M'â;O쟄&͡gD#(DԜZ4?!c RMyrW/6M d aE= gnfu%g;$d*~]ᢽ"Q1mmeM,,7*LLHmOUҬfy&g ZWmJy墧=?Sm~za97j:4ɾgǮ֮W;=W<Wk>Z5=y=t׳=;?=?ҳg_
+%(bBNˮDvLc%;?g> rl@6S
+bjN%T278mYEa^œj/O-TnP/+ 4e[ 5Py!Tf륓L\\gmg
+mkJҭ}U,ut)_QHFR64TD_B=⒮=1 8uQqKD~|bͼSݨ!ʕ_חp.vW&N[*3ntoMԗ:^|GȷmDKvG#-؝c̬p$> b
+&6H ՛pLϩF\r]a% _U5[{"P8gВ.Vi\6Q2A
+$SS]b&(gQrZ3 dku2W`=MHƠbf5'ZdE-'I*eYxVYWl7- dYJ Y+@"*{@Y<#f +Yf'Kj*U4˗Q]Q`6BX% KPM. > TYJBlTjK%˃-4iuT%xs6IMŐ/,ÝfIP;J߽ Y5o
+$d9fs<3A3i3nΦƉՃ#?\oY M8B._Yz=XnXT\l.Q@ExŬ72e,pN"DHFbdQgfLjZFas^Q,J9hA
+RSmz
+`8 QB`|D; akoholhxW{\3Y>IW^p龙ǃ3婣/
+uLknL3'<;;RpdHP '<n."vi;8rn1͹Tт%B8i QެM"u& BHFXן>rE ^"
+(a9jZܓ!Xh
+@]\r,UQքo(hm{Ӷzc~^_yh;Y9EnNz^HPd@Zu/LAIuhl7 En_oǁ&{b~Q[3x괎ҚH4I4:2
+ VœhhɦQPHA4dhO|
+qAŨ
+mJO\`
+H39b V3.;aRtI7~[:Z\Z寡%U~Kl[|sE&fz\?Jfn̋cr{;OMR2Ng iG!3ƌq;kxC5b}wڷ,q?vxݴ(\?HS`^ ygAF~Ht>Ժe{_eyq0Nvs$ː"x[HP0;imDVw쁉DY$_c,1^\&
+qdL5r^n?JPcH.4)kuW
+OD^zZs"txyhsY4E.rZnPvX @U@t@B_"ibd %gA& E
+6A:~2b+\YGdJKAB,%šk*^ŜQĬ~H+#
+<Ml_V0БUI}Y" ږk HWHEtXEތ|<C0M twu4CE isy%fgk#=w f+gF; -t]ׂb_Ujt6[S}*K(r3[Z9!׻zL7C@b4#!!Rr E
+eU>!>>J״AYi\`Mdk}ZH빜蚛2)}z8\+jcN\kA^3YTẆebBl K_,M]/ƾ#.OFW2ZAqCDX
+
+e(>ݮJ^i7rZ eTv/JSАT}]JQD!^
+k% j0SY"-*U-NK,8
+ZBkH%c9e /ҟ%.M];4_~Z,u~w5s"}ln9p»_"{[fVoEy0ᙛ/Vg+>Ikh7U0T0PyK.úlѷ*Н 8[Љ2|> g#N}3V+6Hu2dl*fՎF1ȪAVF}+@Lbmm,>1&>}ݍ7'~]0ǻWc=f.7y1_hJS1,@ך+IoEű3g"_MyƓOGB]DX%\[9]VTC0kjufE$H:%e+n-{Ls Zt{E[=bq2X!B"(sϔv
+&džީB/$V8L?;k+-a 勞OȓUX:vx\ȩܕk۫ᓱgtŶm
+;X-tpg_IBjR+FD>ԼueDcr:,4-:o/AE8gMHfDeRsR 0;~V'*9 硠 |\/;bU
+38kֺ2%M-%%4;$lRIJ 5d&QrP):FmG2dIV=t ewɡa?͏yVń|IJsfrÀ]=ʣؚ@N[@kX!87DѵclGMcm2n"שM㉘-S#ۏ<ByMa>I zz:yz۫ qF;9E SIo+O~36`Oim̱o<lGI,ӎ#4~lpɾ\gPw8Ne%"+-s\Sb]&,;%˨eǛ%.Jo-#q-q~%xMN=Yr&?vZ]4(߃NI7ss̽h:g7c=*n[CQ1X" od qm+/Qfo%02 mƙФV6,ŏ5sȃJLL8,$ΏJEA4ڪu2%{=_*ZDj>wT}-Y OYwf}|?$+;r@_P.BۡwAg^ Z0Q2gJؚU I]a]}TWjz,a}z<`tteHrX{.0((T.*|$a|Fbw`~ƀ.X&aND:PYIx # ]=}FzC·G٪ME~GQh=4s囤SP]P\I+'ػF1LG*^ u]SJT9/U*~7ad"IN{Ut;(%Qg!LˆkDت9P_7'ƃ&]=Qoge!k+`ҫ*x^rD2k<<@ ΍{
+-NY>θnTϺJ߰]Z?zKXWtw/"0ݝٙv]ak*S֫h#idU\k뀺W2fJ~Á!@fU ~t[Uu9PkU -m:\u
+d21g<]l>?}_1wGl{Ozufd|q۟vrĝ-x0U @m{zlqّΎ-nc/ Hh'Bi65gY2ntpKyo-C]o"|y8I;D\ym7wVIY5 aRAQZ&͚†0!?hAe㻏_z2br{x|jK52O ~62V!g3tnevےj%}wk">_?1oVpGEZQK6!mkՎKMk~WNU`@g|2vFBa,CN4~S0<)ڀ(ajŌtjT-S
+VJH2o'ET(oOkQ 8m ;u̧X*In6g9gi'&-\!rvʼJ}L&0X}ILNCGt=m
+:2ڻAjwk2볧2qw+^')$r%"ʘmFHnhqj3cZ%T'1 ]Zf';En0Nl5bKUCNŏ8 ]M:HZtЙFەq29ʴ!&NcTU&UECyZS)Ɓ| z_::|Bj=gkj7z*8R ;T`gkV.lb3WX${{"gho)3K^tm[wC7_;V.U-Ym<I.:dw?zҝo?ҝ(dR@l8!n 'q<^f/)1G{RTI t!ݦ傏*hB>~8?^V4<_`f6f Uq0ۊg{.xwLkh{CKt85s[٣5L!?Ɖ1ĝ!1;OJuR?HSQ1tj$E kss6$SC6;GY(Ȓ^cXuPS5DGya9 }>ey T}PVQC i &P^^"9 Hwzlڸ54[5m":%nVAG)9uWrj̩VĔXq# 7# r ~TyE",Ri9EtXIp#XՀ:l͆h26TCUPhܰۙvn߇xgc6f<4@UхV[ȶ86wWDZ-5LcVr(: T#8@<p h4-Ÿ1]_
+ q 4XCurh0M2qzU8g,a. %$*ϓ*93fRnFbwqhӤ8hY/5Uq1Z2fqOE 37#[*2`d'\U
+&Ej/bA P}ӰK͋bS)살*F"4\fk[Ww]I?g;&\s2D;Vl;PZZrkStpI
+'TU;
+'xo]镒GL^&Nr)HyW]F! !{tiUGI|U(s_ [ۄ fVikH3u}PUۃXk
+#eLx$H@\r_@ ͞:ZahM@uIJ
+,Pߖ* eFejbVS!Ahi2dl&Nrd(R}6u
+#ٮ ~B+PsFjN،j*tM B>Ff&k_O {%,S<[( TVaX ᕚ寡k5Auf4jE#=B<Aj:q5}"xd>4w^w +g Is:+SEv]%(t
+Q]@ζ]ʌM5H*YȦ(]BTbJۢZA c;у2]7Jj4w߯! tnD:=7<ى¼0q|rt}”
+}s#}hV'-h7>ys&={k¾/ -c #]2G.O<CpX\p#S\(]%ڦOeM.|Qps6:D8|ji#.ɖ2jpE4&hZЌ)M5I%KmģT-vʦ<{G.6!%z
+:=Z==EznHB!Si!BƼ,L5S+̙O|'Wf?Y^?w_tg6 G*EWQ^DMj'lG2Lu5ׁNz n:
+zc>_v?I+!AĖ fDL&5[ ʘT%|ݩoXTBYoy&-n0
+a[|ز͇/qBsn_d0DQӿYQ^ݑ4~k/sH_=nG]bsvέ XJ"/C>)D=&=T0mBDzs.wvuf_U1iP>T}m^O2,)iE룎GAjdLuW3TO8fMy=i|_{,jGj0" iwA+8T4{-72~ڕKkY'.1ͻPޑB(ҡ*.X7S 4v`sBRmՀ6zOpaPI58YHf\D joD2%:{P/VA*(6Q9ȽhO_j{(a-"72uzO c3]FS@mnK@'m
+I2G{Xc@-9mU|@>8%t{- ]- d]hqbo04+:}dV&BJ~K`
+@g1CM:Ǚ[
+Uso=uEEen:m2Q -0tFiΖ&lExC a:*2E3
+vzGxi!PX* Bnj@ߎFsC\"
+- +IHC%ǘBk9dQp^3`?r ;fɵUZ+eQ6J 7P)9fn6x e;ְA&
+c8~p*:z8><2zdž3ڨnv Ɏݙ:/2w/7.e6ARdD[tXcZW }r9o"S[~~_MOn<˄pu
+Ҡ|M֩eu"bӦf^@5{J6PN6c'1f/߂?>IMOK[~nwqDJ
+")o/7uOWtm
++u!zDоlq+u? tH4p :I@m$Pivɧ`RaZH=G6mF}({a~X>._~(=&fkפ|?:Vz<> 4<[L-eHg!5dJSم>Hmî4U xSY[!Vg]nvhamxkcۚ^u4\3HCCT{D[2ډ-;޶ ]S=b
+1f5[T-N%#dv%K
+SD:Fo6h` aZW[SJ
+MҽO [GV81*IHʸo7 ә^Mg5lM۟)Qu%^lMWĨg[H+mp#eK_L;P0؝R6
+ kTBXF!:#[z;}i-u;H+Y1] sߜ/s:3\|+b .z]+J
+.C|#}U0'Na$A1L)}U6Г]I. Q swUo=ZAzm.|;Z"@swE'r?dĬrƲiٯ}Itٗ:ޤm?-b#Wn%s3ӵxlh+7Z]`1feQKQpoR ٚTQfGEZe3ȺVUT҆-98?xs_g fފLhv0TT֒ GMC}@[qqrQg}5cPYX
+ -ƖWȆn
+p@Rq&蟑®tsԕi&=d3
+ 12c Ueݡv-ʓ<.
+4! VCߵc ^0e VUB<kb9ƗL-Jg,PA##.pnpL{kUwv]^'pP׎jh(i֠RDԔ1Z}0>5S7f(qCo{;`n1Z9O춑Q*@~@|CCtww@|^iG
+^sR2kwoU&\D-CgMv/ -ྦྷC}%qV8X_]fp)<2
+~[IA% *muLeF@Dȷ K1_PV*o Q&EoQ6EjADDUQPt 8j\
+v|\bO
+U~nc'7 -)g9 aL'Nl$'"O\{ɣ73'w6Oomυnh4:uVH-9Tn E-]Ε?yw߉kbbWzo_Z,ٌXڊPQ{Y¶\gmw
+| p]HbWE߂@<v&iÎ㣖d]$Eڋ]?JE΍o,=5<nlĤcDΦn4R"Jy"[/~O|?"/6V(r|$m06
+_g//nL.|6wy+]\_[8cip%_wpP
+hDnng,ehtYۣ"!:Bd`a ]~lF^ ;(FځD0m21%J&*5Lk̨bEC*p!t
+Ʋ(HGhP|-=.D-^"-{m\FTf\+OlA.X biXST6yk8lp3 !mmY Koh昃'ʜ2oeMs|2؍u$V#X>:9*嬊'pu-nx-+lDPEf$lIGV#1 STHj9Vo%+eiSNf?ni6˸f(!XY`= j3 ku.Sg\PΌm:(y1(c˽=bt_%el֚2 surM=5EYOg;F~fb5wQ*YeC[PzHzIѵNFQ 9ağ54t\ b/;L[&jdu39UWz ZoA݊ˍie5/t,nb ꔴH5c#6_A/*\_~+]y=7l(gn]bsr$XyIWrP)i&ǜDŽҩ&R=ޮ'֞ڬp~(:Y/TθI^x?6'Ƕ&-T]p:t4u瀩f
+v{
+:kC6h9=$^
+ ZOȩ~0-\>)'
+$h2|8؈all}x~W0<6-qAmk
+PRsp<ǾĮ/Rx_&&ЖI/;viI%HH)!p>Ȏ44cWɟHHb(]ت>l?ۂO&4X̄~1F7`_{xeyfg|T׳JNO; &U3MoY6L*!#vJ*nD] rݙh>8@T@X;fVykCMőA
+Xj,mesy0lY"o' 7#z4ѫS
+llX
+N$11ZCuT ,@BA
+u&):d\dld\4)]-]G$ "Cukt=
+$cZ3.Ս0P=RcK;茗2*l'l<WImVI{+Vd/QiXn<H|s7`LG}hW?wws]En􋉏pfhGw;uq}mڟ~[?IëBdHs)qH**!́j !Pwq)mP޻
+c iP>uJmuCjuQ%"CEp~{5&qGJ#PІz-p|%`.jFQrvb}~yͥ˯]I}ֿ||L}LFs8Ohg>W[sM?xD
+bg/~Owk<
+tt-lt>2 lk3lA3LAK=翬l~f}|PDx絏nDJ5Gcx'iQ= ~޿ټpʍʧ7v̼Ӽ˻u>;zrr7T[7ܾSeSrщ Gp$<Ӑwh, 4B iH0mJ015Q[#!
+Az4bDT %2;XNqNԽHhb2C 08895șP{E!M@xSj@P6P$/QQJI\<~*X^T#5STKnZkyIhA*ᘢx'g%He
+q猦;cyם:d<Ec[<uE== Ts7amQ{ vLw~
+r] n1hP4h 2N;h>W(3}F&cza#A.`ԸЁ/?F"8Ӹ=TV@nU/ܾZ~?M#_+YUliڛD֌53gQ\J
+6%:,B[ָE>\ԇXeTO#a1ixwʋA8Kfдt|oH=so>M(8)jŢ1s[ʳTJBtxp*Czt3u.cR%莔OQaϧgaaL*'f2\*=Th*x5'-q;o:^ua8s$/\#~OJ7^6[~ty͙k`K/;d@Өtd,TX}~֎B6m ӁLI؉Zxhd՝uߺuߥ'Wӫξ%`p.tv[BM{8X,&[@Ikg:`d9Yc4c<ΞL ٌOGdhV+--/3/VD^ 9I\k^ݲD)<6/:{J?3-'Xw @@;Nz坴l+i=J䞨ρ $ܴH[K-5w:ԣ8GZh"
+tPJD,<yNuc -%tXCvUdg;3s Av2v^Z_ڛWϴ + nr'2ZK]iW#a2T'^>lok Z)k3DZ/fP¼sux{p/8;
+3R: bxB GYhCW
+bVrhMG!S5pwTUg^i[F c8hm p2pOHM k"CU: ;n2P@!lѾJs_tF.Ӎ?/iSG|`Iw $4+6w"x]ALctd_}?4FLuԵ^aDجIEJԵ.u1LILnXC,߄
+ֲPH\]5<h^KQa%-
+-h"dFnj4{ ֢]Im2^ZqfYN 92m]صfxnI(I{,]BzK%nOCS0=yܷA8yW.oLJIIdܾҸ?Q cdn[nh&BgXrYe둁r%sfؒ+cOG]q |L[!!9f. I1rYhGc$Xur_X0I
+mQL5 ^f
+E5L ȯ1;T7\2nVMm/WS$.'Ym*УX\fckf.XG;ŚեH#h e?Ls
+(.`I{Mҧ
+(  uXfb>A7? NmA+ߌolOD.)=h^$/+[7 \! ~D: ax== 6 p~gtҍέRө+勏v{KWgH)4'ӂCMJ{GjQĻC@nSQVD ADIMd ji:FB.ZoEL!N:<'Y>KAa`L1lc6]Th|
+hRzAZ#l_>=Uz8];6G#f7=e_Sa.2tU E
+4]>Ta`NdSw; S`i64X8(pLf\+b8ķEhj[ĘhsOQ}}PyؙW_Y&ˇ"em~<Ԩs!4If7y
+/iW~vς:(S.;<65l{(bޡrG-( $1Yjb
+^\ {׫/W* %`){8΢`OJ@@.F=`U-/=3OÏ'ch~]SS{8?7O/b sycgOг#u<M^oSמ[i{~xbS*Mz8 (|9jLMtUp D(`bb~AAÕ)ZoEQC|)ǵ _w9鏉I*eB|&[usbFedF ΓpҾɀ.PCy:'b|UmQs1; u^}Ny&ջecR癰EeY)đhePS
+:p@)!A먿&cS=jSl. -Z
+PH1d@\YkuŚ5Ω&27W7;eՍ'wqЯm+*5hW;oJoF!O2S8=N3L@ӥ8Έش~( ^5(fqPIĴ ԮC[~ Rvy-LU/i7k'k_k/^5D4k6MǰFe!Ȁp[h KOUרNue;4NQ~}d3gTAߟn<w*Yo%3g i[Jo]b\C_MjhVXncd2Xo|6^S#iEB%S WA
+-alAb(en4_
+3.d1c΁ Qx`r`dRc)iFW1V E64lie9NpR .=IMq(7hun7kmb1Z4D9<2
+xe[^ famv5KwvBB&+YsP\T6C'WBQuvkm^v:lް.^DztoHњHjE_RJ{NЮFz/Nt(^g{lljhk}\fGXcc;R;RHz_Q]UcܒMi mTdX [Z{Se
+P
+D.kMZl,]Wd\`$Y]*D"8!d; Sm.DlOt+=YW^>D2gqi<$&ڏZ =>Dۗ*/nXBCb dlRM8&7+q{'aĽw2/"<<|w{sՅWk/i]">\_v(ݐ(*E1B|ӧ.rQj *#<,<Gl}8?묹m
+e=ǞȺBE[g\Y9Ʒ19jMyZSZo.u\ǟQ>{]d>+*}46 qR3$IԚ/*60MpnC5ux,HX׏EorW!n4( WLYa٩0JZDu3t8м8y-HG}!ߖ3oCCC_"б}\ƞ@7)Ng~d~]_]t/q\z02Dx{~o=<8?zσ8Dۀ/P
+<ꃁm9:Pj!L/rS{űh ~]c7n'$/^)=H^{煿}+pñܿ,ۿBWb.%+"\V3W=/=U?&+Kԟh҃ fj96( 4 D4<N^z$|ӹ
+Hj:[SB遮tn6>V̵wN^߽;sGn,n&&+ϓBu<:N牀CM!iYкm=A DE`Y+
+0̡%(SGqS%<Y%>hCc0Dё^ L:05PTq."\A2%4!NC݄#A"&BmCQ4VK\ǡ~ 2
+DԼ~uqbߎJ6{ юyAxO"cZmRh92x*' oLj`M
+ h:aA܅g?XU.Y_)烕}m3p
+4]'4
+*VFaF}wǼ91))_Ix|{*mG"w+kˇ"ks@e82ѷ K P ']pW<8;@N䨑uiX&x 6ԮƒJ<RaSa Of['@<&?}`v WIfv¤?LʭT6P:<t Ǐ9_2dt&gNyv}#N"GMǘUs
+6#)+Q26KN3OTe-[ӎ,@5m(nd*:K1>KN[;@߻mjUJ;Ttp J !/Xqvh‰#I;N&rFX.Ѧ-{՜shZvP6u~iM`ix;< *䂶v3ꭱzkuRf+h -,ĥ YZA>@t1u5geDشm<ߩ?+}<dNLn x8QyB'Q8 =Ǡ1)kbG*?{Jv ׆1̦۪* +кLF8ɋr.W ,h84TT"e bL,Ѣ.6UHє)/a1"*+n1RCr
+GcK/
+D&C >f7p/Ճܤ~|m&+7].~v23H/:d]mEV(Q6r)oz
+#<BerPlVڭE_{Wȫqa
+@̂&U7}U1 %:jh((@%$5 ^\@>[{&Z!d&bg"D5zo[5;z/ rK/T 6O݉O-U+:}$BCdĹ Wz:.lnys t6C`IL9O%
+b0%6O 9Ӟs !Î ӆJ )O3fY)]r/HTRG%OwokG9wΑ/b/oV_F>s&Ѓ4 ~5nnV-53]T[|6-ł)9F
+'f{ ;M\[X^F
+<e%"㎒W^`&rgbY<Fo-RqG~*=,ݍ}YgKV#d;nLը`+-F%[*CSͫ۶XߜLGP 1o
+%Kt=7q
+eoe@dǷtyAsڭQi0
+(ƢWkNV3Yf]1&1ϳ纃[/F|&^:) * mmwF3в2D<5HNYWKЩl<<\"sbns@Eb5۽^
+\ \v
+q1{<;GgOR&ݎj$S_}=n.I'#dV9" #-}@W!iyOرCeJ(j0
+dk2iUVi ?o8~.1!3ƥ=t}h@cA\l%qci3Dm 5CSt3ZHz›M4!~S*|bi<Te/?.u6̍onDZY}N:ckxk"No I{+{SMSx㏤.*7Crezd;i+7l$sy9/]kϧ%MXé6esLzZ'ػqvJnJ>Q}kDȼ)+V,@ RF":
+4 HRkw-LL.^_}ZѩŎIJнKգey<VM?"CKbPKa%N۶8\ )ZH%Yl'c.ٲ&dz!C{'3m,My즭c[HED" $@\>J?y[
+nh^ (X)Me=|=^&#!"Z2>]\pL)EKy5 Z *!yؔ(Xgvap~A_7聬h)@Ų^g<uJ]n@u:b@z=hXkhS
+j8PV*
+D(DHKP[!ϡv5!zk6&`Nt*eUzfv/L1Wvb A8~-S>_?(,cE-ڰg!kj:o@o<EdXxABI: #32gW CPF+.>CN͐B6X&L ^.M.[
+oulc3( ]i0SbV%=S~`(G/ws9MiXy?m}׮[/Iv!:?$>qa5LuL*T6e% 6IMkFDzE#o()+)4NQkl4/@HcENjИ;Xe-fN076' ¢(Ғ ?Mc3KӭΜ-hH@]ΫgyJ]k֌jQ/B{<,6+wҰGU5ZZDnR -@vAB`3yS(n2<"4;L@u[(m+Ovo}֛@KKǕʂ3y $iK%-YM!6=b g92r5܄MK͂4Z5%}Z&}Jn?RJ!Bfe\u1<Ωt.Щ׍k:503/tlS %>~
+ek;i--I&udI$$RDR$p~4"&`b5 R '$+Mv6m4#ZbLv[efrs(ީ(H`PCujՁNUԨdFUc @M`MnHB]^s.9!-mbTTaX QZcX77?@,]wo>'UH};YsҰa;.|Hx3zk;f򈯞Fí)ژV vx[|,2xX*>Y"HV.  sRAN@g-u an*OW"6߱
+[X뷧cmqܼXӮ=#anu3߹D[V7_#˄` zB-Ռ^uT2x
+ b6Xw@#+q`^=I~?O%wxBqо nT[+@P NsaJo1h|{a0VZWG+qV
+~Z4~G v㕗h7IVyL[eVFDg v21qhjC5}>YrjzCizifvT`:L7Ci]4>K_R"9͏N0pѾʘDg1o=klF_֯LA|B3+Q5k;E<*Ni_~P}An>uzm Dkd'~8`&[wl5M
+x( FzgCLrwuF+%~GCΔt=='<%rϚЮ2Ҡ!p8J
+[s&k1|[%QrH~{x.pPFQ 18\G<#b6#{|J # 6l06 6"4瞐\xޏA"]>c?cjZzxM6<O_3596%>%O7ʏ{ˏܧˏ)95=MDY?h?cmIɏsX'qusS'?_$cW6o%fC{fNK,~<|æ=p"d@\ >6QOʴSP-\ґNlŁ5yÄVC1 &btT) JӅ
+u)I"XbsʇB]5 DGkDKZʹ8a9Tד4|5Ye> f3 }WB;y}9 3zΖp ]?{c ,H,o0.Xh`J %_bG1Us
+ɴ("*@Rr^Ph(KD~F|xt<W^$T`3%쒴_הyC{h}aQi~6wnWOVE)ޣƫ؛?_'בU;ZyZy QPN*ѶBe6QDLYctH.3AL
+J
+ vnI '<{B`R{}i҉ru|AZʷY6{\^n3?~ȯ9hQ3-t6n -voZBt/Bw[e(<kZR/Ë6c^VgKeQ{t{ek17tY`D
+zJ=&/HWO˂P;:[5z1$.oq+YI4u\Rd,϶<&qNӮ==^h.d.?(W>/C'. gT\.[nCnC$66+1jAzSXH\C"i E<@:O|MKTLT$:ViI]' %qviSH׆q
+k,fTUN. ٹ,4ܑX9Ȉt2a~mw=JͭiUۂdº)7!.
+ CgM|!Bd))CEcj#?GXyA HR<֩sX! _sۯf8 ~`Y1s~ΠOgUPLk+ ,nEwrb3]2 9#V]
+lA;u 9r-*CpG/B,}!Vpb%.Z5nHK
+6FVQ#t|eivHŎAinBwq& eE_ СM 7$LRMݰC;Ԁb*5;%JΞ(ێ!Aң>`o
+w;;Dp^, jesjRECyX,v?*ܵU$7 \+d[BC#.BtP$$7JSXYS:u0HPMbTM6]d{u?Ce{k[{txw3w_>c+'WӏVNvթS`rcޒ-UMyv0hm \VxJ^ uK|NLUKͺh4e%K`,FKZ J;;QzQzgN$]ozyQ5HMxc_W!ȃ^_LΆǯ',] -z?<^ .τf+eĒr M$CDVms
+ʶ>BC#qh~뫾+g[Ν]ޛ[KԤlPy)=a::LJJny,:F:UufHSVϧ3ӲwPmB~|$fXG5M-0A4x/(gdg)hrj\;3e2}BymEJ}Jtq1$|ROWϋ76B'+B[|
+jpuS@3H$WhT(húj)BRc
+Zu*QLuTޤItLdKJ(J 7<f_ dp\CP W1S&ˈ"",Iك!ɊD*"vZ ˌ Z HR3?;19{}`ǡ[+_vr'6s "M϶gFf\ 7ȯ%Wm}M7`/\o Z$]eSۈʙ1%v_N/2S-WIsaL +s:iji) k`p#qOgN4rA>-s|M9So>)F.-P7GC[E\pD
+xI+Mf\HU5="q1;嫌yBMW?PV)t̀ [PmSmՁG8dpmm =
+@ߨmT:߮/KdrA}%Qp7:}S{ۭ/> [<=tTVa'7".\C.SpV^IMDOy+,z2ݭ#婥SK[: Gc/%׏Dͻ ޔNf*T 9>-[S]pJ(4u\fq<+
+٥ iFCMCXE;A߷Bv$,8E|٭<HaNkցVn)BU@1"X":q9luY]_b@e|f]!T/T|tԏw( Ir9@Z_zu%f8 -Cַ$msXm*VTlGvU$d84nU qVQDԄ vc,n'ue{s}97/%E'VԭO- _V!У=̖; 1^`?|gmj?~
+p4Sm`nvEh܃
+֒ҁhOsBuTD@%يRT
+ͯiT,+*(%j;ྃƌUdc#؈Zbtzd}]Ҵg)ӯTy缬"hex!O!
+S3fQ,
+ɂ b ]i+it&b%p<9ocmN++홍~g=T?~55~ɑ?8TbpO,\AB[4ϣ'oי\uf`-%B_zbAo)DE(HX8I=#h/Gu"#KH'5T;~젼GĿI ϩM&nDO2)YԞUfPҌjST^.exTJ5UH[\/yP/H,+2T^H ,]Q*`
+)FiJSω%>/S4*ZTVQD8kCJR$[ Vd!Svx6{z)xC:ySfљZVYM;HNUv8<i=旺{Mȝ#37N>kyevg/N=:W{~xrsQǥ'u^P獱/z xtMt~0ty:}kjR #(ք-2@Ys-l*㢘(ʄHWJp2#Y1
+Ȕ۔7 $Kf>FYB(cU,=*y9X tfn.S_Du|m5"5Oz7b7Qͪ
+Uz
+ub'yƝ5_~ƻI;2LT8رi} LaJwb[ 
+6cmКf!o}-W&)ظvt1wX02GV'ހBؕwMD]s6FᙼV@ïlw9y}{qlwZw"ll^ V6)nۢ;t7KylVdϯlvj ;gS֫q鷣?6OUkW2H]^u\kf;3hˬ\uΉNd=UcUuA+MQOLKlBTWZΣgc̓>]N䜈&H[^Qv7
+^F2Ցڡm=6&Pi5m90I`sb{;v {;q $5J$0Xǟj~
+4CeLQVtK-`:HHu|:v:NxZ9<iFh*U Fy}[䐼^Wpը4 >H]՞Jx}=
+! b "@Kap*#F
+ R@
+,'*YX) :,̛Av\_+髎cc>D`u\t47#2p 1"?$T-թrp<għmO8(5APe &C^6CrH9]X{W6g_zܗ_ہs޿{؅?p^7.wg޹ǓgG|w~6湹'eвYlrъ(O(T-^Uf2șCғ^PI]Y-66'R
+i,ϣ9Jw1=¤n
+hJĤ l @xpxq: #P wzz,LI94@b \?eǀ0;|(ͷ!9Ի.N\Rs͊p֬XYU]F/[ g{6փ
+bX$0i(lG é%湀.r*
+mR?mRڟkE%hm+-rdbcC
+/*O¢f3n7+kk;iUiKSixd
++RD7/!.pxhSi}i~ ^s o`A7(7^S3]%4[Nqaux~ %.y%J&l!َhL[l
+8ȃd㓓Of^@ 5K"(UR )%IH˒
+- h׏\UGsg*Zyd2e}qd8Z"7&"Ś*gФ:S6nq+/6s 76W%xr_TeaOݯt>(7Z:&gS2m3#Ya<>F^δ8x)ʻq v@
+`&u@
+[1<c5I9ADmn1۲2viBhJfc0 ĥ68!FK ݤĥ !r], G9xB;S:k/1>syErB5B| ds}'ጂ4YAvBӯ}l~Q5J{Y[5q{v3oFI27b2 L*4`,
+v9!2BJ%XZۈԖHMG@c
+GkV#_'v>!z^q25IMF7gşhc]~4}iF>=}>~k\a`xjӧ&'O9>`w^LTթscy:k?rt ;Awhp|xl@RIsN>d/q9OlsP)%ͫ}p /{^ImRDʑ#m(j;`ѭ0A^rNM8GR)CuIZ[ 5> [Ce +Aid$cu4~ʭBZ D:vr+MgPсm
+hUċV4 ~a3Gp)oZɐ޺h '0N<|
+(=@]>o!Gר}
+K r&i%rXx)}rQؑgO__x:pVlDn0rEȁjViO@!ʭ`ƥ g7c,-1L+5pE*J\h.-;
+ .^ơ:mۺ
+R@CuN*5'~Z/;BAEEcpD_T")w#I^6ę%LQ>&ع꯴W5S;C{Azs\'ﰓ :`Nӣ-zʑ"ۗ%ϛG{=ڞD33v}:7snW)i缾߹RG~EyY6dH,Ic@OxD-2)Gq+Ҫؼߎ\y;. 㖑Z
+ &ɀĶ~Ҵ Iӂ&Tk͓#HۋS?]^f%'P @w_? hAuZ7k06s0']YShӢ@ RMfA P2Y
+%Ydϥ$Z&muWg,
+
+GwExTvhvS̽/Cp} hW2u/DR55ZpY(P2'^)xח˸<YbؖH64Wbrr)x+ Հ xe[._'^+޲]p:C^ΰ <&q{?9M<>[](5)7)ݵ->hA6g? z@l8Uy _l2Ve阀iC)&^w.vd*F=`HApųג89SX'M|{[yNy_,u/woM]gהxq b% %z 8f˷E9rNjo5V,Hgg?[3XR,^. *i8L[AvJut ,;X|9 oV=gU8eTkY%i
+a)醑PA&{-h9 D8.Uw:'w;1aeEwoOr&DBa!@:Yq㮘,@: tumy_f;F /}8|S )ntXn꣣OlyܥVVPih@ZYC@F]H)6ժnOkmT C;Z+ JRoH%ATPDNԉ4 HUA^oTDՅDz{VGUc.jCAr5rtTxpXHvXHvI'wm xXX}oZ5j{R9b"0ܦ^.
+ZPv}OFs >\M\v۹?~>(ԭBݨj˚Vz"M(F{)E
+Sw<v|ekD!<???2|_&o_ Z*h(`8Vt+hjT(RR%PTrOձv: F5 U:dTw*m@7%z#4).hxo-|ҽjyT˭, Vƪ 6kKڔ@Hf2$zE-UEtwf>Ȧ;ad;da,J"F+k~6'*ocWeͱ2|l"P)ͮ OH|y->t>-?6Q~ IAyF8G!8(>j%Ѭݶ&
+4J%UM g~Udи )o.KXpŧm5iί̀ЌUX7k7FnN:yeS# &iȷ} 8ތO[10AO& C}v ٪-3F eFgOE{2ĘoUDȽ `VDAFc-j -@1 ݌a@†M~:f Y#URh^fdF轕O~r\ 7Җ4T:c}fPbL56F#R*{\HL~kځ2pNO)nzɤ.PM<@V `߬0+Vbf2mho
+M:zBs9q{ IIq6l__e]b zixRg%>[rF-mOC2~νkUrJ[*nSD
+g x"?Ҟ{hR:erz7_"
+ZLP"oWBo3ʋܴj"DTn?1u5col_K'?]\fW7~ُwV~櫕Y2tnM@BUZk";\epGRBLݮAp1)ʄ
+ 5p ܒ!A@ઠCx*kuve71PDwlt(ܱOf˅oS%j2I͙&y㤸cEe~8!.j
+qjv9֊yI/cgQ'*9*<@)׏{ܼ@Y/H659JR""avRfI+VS9wHΪ\<ֲZ, (pH:D
+&sd$N
+4xgrabޔEQKiaU{vdF%;w/SsFIr~]GkYn# qXd)4=ZS^*wgJЃ@h@H=)ZJ!7lO k>M`KAk +Z
+Y6^LYl
+ρ5
+T|# C6բ\+mFGi=*oh;SX7rw09Gs70Sã@nDeиLТX\
+Kbphj[Lnr'gWlU[
+% Q>|"rO~Ž$0DD@-ؔ4/k^}I쥑S:)͉}62òCr^r̕,ٶYjh7<ɂrc1g΅l-`)0A.!czW: ;hWJ1ڠն&J@u1 WL5rê+10kYUSR[FEe˦bjd.+U3P{%hHXKik
+;m%8Nb4HmCE{hs-PA{*ںmي&08-Ԏl+-&9\Dre.G@@`8f}?fd8m.V+Pf8H)yΔT<&
+eke?N#ߘu͠F)zzYΔ3SSlC8Zdmm
+í~k#Nlϊy\P*<~|a @3\QLs
+ܓ8| ܠ O 1pmM0'#3 dYŀKb`_u(_ߙ`&ϙq
+<Wmzi$1 mfsG":`tocq>gT#c~FL¾r1hAW#vUDX Kx(UgPz xMt )ȶfOG;6Z
+mE<rSfU #{cVBFVvxuAx*5R;_3Jh{VBpF 4 dC8 S% C@qj%3ӎj~xҸ!.R#HK.O-|;q-BNxe|sžGP ӳQ$UvZ V::[VJvec'{`>FLSRKktd3lG1 aPUH׋+ܙ9m.즾2Ih{mto)H,vXq<`/|Pv.w[˦LJ߮eUov6CMB:S?I^MQi ɦred`DFpRt3N% vg;7Tnލ[@a@3L"^ 4|6&Xq3'ub%'4WdDa*rcj@$AMkXn+Fs072b3WeUN ,QbRӏYbRW_yW(cYzT7lzT6DעQK[2X?Nv2gK(&5=>9XBDFjDk5aa8,4* 8&>X5bt!pr4a˄^ /4 <=m/$7!(F >b'j$uUr,O|#
+EKo{ȹʪRŠRe.y/@҈3mRBze[8Ċ6U{ 7?s/$eux?S1fIJ`ռ7\Ka&K&&G[q֮<0CB]DlQ01ILE&
+Ї⥏+ +:RIgH)DAT,u{.NO"#!֬CpMw.ۖԵȕ P(R)?^.ǀ }L+@KDj{КV3G[i)5{]~_$/Pݾ07?ޏ\G\"0qM;+F:İl%liDAWM:œ&Sb]2aLɅiw$iĩ<N4Sqr %GɪM~jY*9ւSFNSv2![61"$D7Ozu_\/bzk*
+s^@8ȼN@k@Im$N~Ė @c8S}IpS$@[M$<̩݁As6g>găI}<gbXcH)`
+;2Z"
+I.t m0L8<I7|gwoGG~NscpY)4a(
+% J3DD|hLԠc[=K[u%*)2I(hRLa7y+.n}ǘۓOs<bT0gË$b剞WRsIPBd]y_e b;^ oe!8NWc`HMm16)mJ7*~\-#y RlҠ)J$hʪbY3Д
+@VA<уsT{ʤ͕˹;ECDJeE6]~q_nQYxrI<\7+vyݙKx&r5O}'Ʈb|ſJ^C!Bc܅$֗g/a ]ha&f=4Zu{}hc5Yb,V쏩 ab x Ń σ> VPjad96r4 (Lp<-llAgA94 ;1;=oTUԜ,ҿ }òX]}5!-:})99W:^\TWkou5ĉF7{swU6ŕKۼ4ޤO3vCgM@Fݱ}&PvQ-8(@mŋǼ {r`=xrɢ, dTgRi]^\";])_ٯzd( 3t',}{ѷW~˪|ZYa:L?[t[QI |8@1RRvziһ"KHiĐJk5Y*/,<e0PD]i!tJM|mY8afg4xWӢ=}' ϒչV^X*,k kQ7ۧVcn8F#( ?uq
+(vNUmيhHQ4u(p{`w~ٗA-֭p竧fvVmk3nrcXKH| ru&jí[§Ĕ<7vbI1Ӳ8<sGN:C1iDEKwFo:R j%Ij&fVE\jK-| F.p:fHd
+f%ŠAB R%Z66r1]Cv,N6cfAWLQIq2ts{kw#N _ ^L/E&.: Ic=} ǤZH$ _Vӵjf94G+_4AO"*j6KuHz6ˊ;XIJS$gfX;^2uBŭIU6>CrE$XsHQ,Gc8irj1RAפhTdMoL!bnǾk¼Gzbq Ϻ錽?u
+ hKt1 D\u$
+n2Zj?lWoD'Y纚x>,uQk^Y)٪_/hsA_zk$5Dؠ>E~T4EQu"`~C ѢO j`·m C康'$TS)ZuqDeE
+Ԟ_Z c=+]vU|Vt>vɀu]3NʢJ*r?T7,~F2~ yOjмw89F>Fj<>9^rU2E%퍚_x~"
+Ȓ@EbJ=O ^F|Xyد^-QޞJ_}r-
+hR*մΛʖIkavؔ\CO;7S6rQ)c?17p mЩQ5֯Iph"EBS#)P1%2 f[}bL=|rGKGVrfraLCtȉLeJt,?{Q?a:b+Pu\`4a6>}k JP]$/!+i ij[A9A'3 {Rsdd։2-"5Y#<3#9
+3|}dnu AxW@kH̤")|صnEgjL0ѯt`2SY5 m2#6GKSnӷO8vDcx1,$ٞ.H mFe:W4ԮJ(E[0PBa'FgTU"TՆ21eVVULD3$l+nAv~ EvŬ&VyS# M?>fŤz) IYHRud9 EP66f? ^Mi_KMMڊY:ѧӊwU$KJ; DŪ&
+ @ydWz@F* (`B#8g H@u!mEmVёbqZv$n͚>G@!ft!f.eN͕de|tQd3܌9)Κ/q_T!unFr*?8ka{$ZɲEbY-._NOQ;$}v^@LQ{@Ւra]bL6P-$DDn@#z"xҀ7
+Wj/zS7m{Q/g=g9,c+~/g"ba̗ަZi ?"\
+1h99g9;c}3~NˣJSV+'y Wih2
+qSɹ$d*a+U kbwhu-˴]^&JWP.Bd[;E
+ ~^*G9A<jvUK&]WVd3Up\ȩg[KJ Vg1>>iOiӚ|P'Q!yқ"ي:| u_:k%4P4Xc_tPYcME;Xt72ZWvfFst+fPkUɮW{Ă`jUHYFxx_&r8v\sɣ+ONQz5<ecƠ2) kun6b}=k>4AsBaE~}c<o@oEql;\}7g>sFR!݊i|R#&L1I Rk82.KnX: ܮ\<;R3 g&t+zCBdK Y5"T6Eu%N(nܢtwicJΐd=HStn]r`[Fk3Wcj+P<3?Agު[.$IrEAi\4r`R:D ckGwҐA}u[VѲ-+X;žm$ZuU0^J4PB]'$ -HV&uɺei|q,A،[;?[?ٸB`7 |ʂf;N9lx*I3/ٝxdo1Oࢯ/
+sOtHf8毥P?*a-$B EAHSe$be7(Zr6;(mf"1En*Svr8YcLۼm{(:إJ^Rhju2]gmg
+~2a 0Ɂ"<dKz",0fSAL 1h5 L0jm|.dJ<`.OR>,Ayާ-Yt[J԰|uvc^}qCuqMuv~IyJXg}Ru)pPeVQm2ZBnYXT D>Ú$Gj יk'~^14qr*91+F5Ps7#E^!UȺVfysM=[L6@-G:ӥC3U X0qe4Үs.MGK?7?;`% %O^l?-4,mHhVYToP  -j 
+oY.VUk5k7כüBU!Lpemk_G%D,j%%yy)qȏV-~U)o!L77ٶFŵr )բR&B!*tݎR[J @XF[lpzk墠RK
+j4::eK4`Sֶ±mk7p^(:$,g=[w~}o!w|WɴDX  {!3Pwv>$n9ߊ]?'}7s8 Ѭ߳Pc6N1B뎱}8o#7daO㷎~7c-p)"6\dZe Ma˚]އʛBm[ S.: vfJKQRپzfϧerR5UG!r|O/ce6mKgpfzYΪWeEtwIjǛc{p]_)ܶ]W͜y|f q̝-޾-;}-o8Йu2fz;ЈӠ%;'.|io
+X+O=bE3!#-A)
+$j0 .'hu)RPۑ<WፚߔT$AbV= fe
+5zNĸB(+QzOJItDFE!AUn0Zafzшtϸ\dʍ=X2h#7N]Mz@:fn,6֘ڴ֥
+-"}-֠
+]AHveH
+Ui
+EE$Ђ8VC
+?bb9NF\gmg
+4)ТvXRA|ɇN^+R<vI%ǒHv0 `[y1F(J|I~i©#O<y$/4/A$4%1$4!NaTq}m3Kԥts7c_s6 2|HJJ\*gab쵃rd-@d[*D
+-0(Ƃ)1M  %bɎܔ-L PeJ΍ϸ{P`*-
+yRHX׬i邥6@$=a'ya{_nsN|c
+eZLc\6H-ܰ>T%AK!- #z)>,T5jc@t1ZsXlSV J>,l*2zbʈ!RkG5B#`}Xhk~қ1/íXW1@R9H0{Z.V%~B$*>bK[k(^ ) iMf9KCpa$I2,Z׏'a o:}']L_~Cݴ]h A'W1۟9~_}w`@Map*zO.Πo/N)i'd.1Ү 6)&7iv->xAvZ&E
+" r
+)"+?Q!;?E^]fg/߳t?$
+-<|2/ 24冰pe]-6U_Ih?kv䓵G FgmRNGD^k*_]<{<~D / $i j@QZi~H^ "%^c6
+s/ ql+]䠖pk,6{o<OcaT6k8R+' Emó̘1E0Q@AM2鸛yrx#=4wd*Y$Sc*< A$ ?eҫdV%"zH칍XS-:Nc65M 4 HC W_yjޠ͙i}a:V}{$=._}wPpbG'L*ݟ饡dOV\]7LYh;02I[/T@*q_C|%ѩ?rQ?" IoL$sE mNMƳºPupVٮwò^z]xzeb Ę7Yc$d"E7K6&C%-FocM+(6ۊ}4<k8'o'
+W#?*N&BO}ORzL 3!͉SkYrVr:.F$Ët8'p0b}f[.GªVe5"H B4,i"oG`~J_NnT"&ׅ[EhZ}@cr?{&N얋@-HkD /7] lg3L">(Es+w++/0X cLv2@SI4X*cCKHSS ͔p=Q-_jNƵ&VJq|oP?W0U&'O^ `7zx?ygۻOU]U׵=ֻ'+v{:Sĸa
+U5x~ᗰh`+GwH!ٝߖnL FFu6@S?qpva|)
+%n=yo^_gJPY4ZH!KQqjdd.VKV=U']GCRϬSzzڃtz7vHeuNT[iDܔa[tF'r-$m =gAv>fN>h2
+
+;h^$BS;{UV{7qOn+^rV,}v'9o[\m2oq8+_5]}Me];لu,b. X~b7ԒuHZ
+E4:O#;О%c뗦/[^d^ʺonZᕁYyS{nލ#6#Eqe[^t.l%iGi%z~;ga[jFTy $h@ (@Pq.T:͞|gy^qVK.BAclpH˛=jS9h1H5=\}:Fr7 R%C'KasD,K\k:]þrz`jf>V;dL 'X2i:iL+d;!wy&s\
+~|U4V Չ
+Ͳ?QAS<UҨiuU?ͽViR4;XK0[ԩÈ";v}RnHyU (A"HE ֺȠ4zjpwLTPH(&E2`0Âga+9StmuIb~ܜ2=j:_D.B.g0FL6Z,7?U8Yr4IZ2KI Asxs] GRB% (^q*Xqc$+n(%&K
+f-%hj9H덼+3iNXp/IkI"GU!{эB=lkpm]kwߝ^|̜M|0=^P
+ g7' g{p+zb5[r'֚џ4s' /SP:
+yV +]Ppp$% TY2"&bzgTrg(ϒ~ERΡ)\q9O9UNbGʧ ˳c+ V0&'~aCI}z菂Iˈ]jv
+ $@lE=y:֮7qmZvfSJ};ώ|V&ʹC|%)@9STu qLVESY5||@>׸Ľ=ꨡ!l
+6c63!-a6"kGkuAP}V޸Gt8 1ֻxGNj^}Ҍg;ȺF~z;'&3mOÎjEE3L6e@A7w۝SCQtI֜pԐ9jTdSP]lUUWM^ utymqe[n(n%~5%#Kx30B2cdb3"%,)}\}vKFCo6isī`ARҲobk"9;zzKoϽV ºUBF]Tx&i+^x6drʵWKH m 6w`SӀtVCw%PXܠBP{V"#?qa¶n3Py4i"k"Vh8aq$$,yV3Sz"*!ߦ
+wu
+}B$$R(P'їbm
+x@/HH<`a^AI4M|v|{D ?a^3! _8>z4?|ڊ?!yCAގHX2EMn=3퇒cc݇ZLQ>؀\.w˦Z3i|؏.fb|2*?7ŗ4$ul=ʒF_Cmb^mn>PО4T0^mµaFsX|S<|[ X$aWumxSoA"v@Dg݃0סLfxi0*Je[W%#`yI_{bAdphދXW%&֣<7{1F"<5'z]O>L f~&]װT,ګ } S>M%a@tQ'U-[TN fQ3Xqi95!cbW-󸶳&M@O 1c~X[ i|ƚk$.U=A>h^:n$׆!m֯I}|ݡR_wXdg }OԴy*ݑX G ̨+YV Y/OtΧ<#!UAP#ۄ mے!N+Rj#4uhq`om-N*bACѐE4Z/*+cE671 _ <&ba4e'ARR7N EaN6RSkj- eo5^D|!v~k=S|3{#%UXqyV\NgVcfPrqbʰ8M就yXHpZX(`#"K˂
++e JFw_Fl*0\)heJF !v
+r*XZLbncjM9ټ,hPM
+-؜7uWLլ)1zUѩF/i^ VIZXeCry1p[ɼA5n&.؎tGm ݒ̕>pQ>\>$|1lOnU$WS jU̖JrGD(*́ur_UObm" Iq {C^q裙tG 'PU*8f6TŔrS8JO"A12nf(W:Qr˃ِZ|R.SlqdV
+䃸w|O^\7,RBbpͶ(C$}n:J?!R<= zuk:se'ڷyb]
+jX:kWFŵ|I
+_sCK4ݪO}׹?> lm,im 7˄RQuN-UJ@iSMՔ[] E,xf[
+{M@!f|c
+
+ے1b<IGS$1/nsKYY'ta\HE3vRyF#yO<nVj&[(yV(E F,
+U0m? O]|UW/5&|$>xz¥S9¥&>*uF߬LCO'?]Tmӑ r}/W?z2Q
+^M!N
+w,|0Zbܸ8~dtQ5) @4HTB)BմݴIeKͮ׻k{=3u<F}4:HsZt5@ ʑrPcd,jx$I}OHVހ$^S70N]{;%d Nꅍ}ՅGa/7%ʷM oXP=Tŀb8Ci{[}{.~{>m!NHjL@5:%͒QLkևK8x廏IO|ssIviHidӱ}9=ni=j$Y-3+QU>.bƐ idb_AÉJݗ4RoXPUc+7+E/^'lF-vܑ-x%vS\S^IWBu[%CfraL]YHz3~\E7~[z3# =*'L
+{NkjmH
+iZKcn;
+OI0Ra034#
+sF?@6gKkt'% }"5UL&? gnl%kYj[!Zs|o?NǗ 3Un[~ (_,ȧd́" QLctE6 Pf‚>ѝQ\#M2b
+r
+?+%G;/xL:,X;&|/O (}oTL]8~P.K
+n'l8J|ƱvEmbʐ<rh.=34znbQSRN61mRSNtVWJX32г|Ҹ($ |-^?6H_ێ-*NEvLaW-n)+NJRGp; nϻY붴 ma 'ͭv![H7r մ[M J S:2Tx!N0:5nb:AIƉ5
+:rbZkg{;#庍M
+v)I0:{y/?_p?~JL9Dץ*9Y1ْo4yh_Thx?fnܘҴ0ȪllS&+MP
+XOÿGn/?1[2":,*c*d&0VHUڠZUfe`SZ\PmdXB %j]*T, d(;p,z2 n`vm2zUk\8נa\4wYIrc.k6:% g6cyI\ët/'W'+uWO?oOz0GN
+OW;l_̊W 녇؅r`I09&;Ud-|mN<睋s))50Q$ZWjVЄFޚjN" {<`V+l_1.cr[[vQVoIC̲YV*kg5EihW5NJgE٠IŠRY*j3M.դžj1h0G7QF2D9q|r ?YwQt.b-%?n?n4.{]q:޲k
+=?Sӻa[(iMD{ f舦{Ϝz
+kxd}XxhǚKPKKـmƑm4;r
+eRocI ˗]1K1gq L5VֱZ󘮄XyoL&+C9p4cDWSm}5
+
+m2m#x'>k<vbhM[v[BUˢEZx"/ *$&mM[mRФόmǎm;o! (qF:|<3;4tyw7ƇqIej3䥞׊HcE
+ ȗbK<;R_MZDLq~8_:Hj'BmRм&慺ZRIzb ]1XRP9J FA}jc9 NC0@NE\17NJ7E+7ǘBS]bAj-G?u6"IRR Vexw52 @9E] |LVU{~ VYx1K^ΟQ1.I-Ѓ@Ek2dXIZ8 h؆R~VPύޓk|vwmn"pOr۪wס/z٦7U3Љ q/ %bh4 /FT'&]$(vJ?)OnG%fY"2<J_-tvHx60ƧCTo ߨ}~}qtbm'Wqп9rIFKMkwBZ-Ngԙ}v8w e35,EMiQ(8
+Rgz$iBsb q+r~p]wk l9D)2}=4ǝ$
+ۮv4f)*]o\?>8ՓG:xաHE[ RɌݖ6hRk Uŝ{~:{W<rX@A
+"@@ZQ/ )1E
+L Ȕ BiQ#![i9wC9,}"I}zysds~DBpG{+e a!1(qʷӗKփ{I`hWFv4~)zdx^nUiP@*pU?o[zRQTZr~2)'b}uxwO*Ҵ ~8Y
+RC BѢ[5@=y[ ^lu򎥗hi%\sHo-tTeJC5+17I-U-cۍ
+L`tH|93tRMu&kuȣf}
+mo eé3BDȋpCEI>|ĵgw]ڢK2.ޢy A3S6xqAƦXeUCl[ceNc
+KwV#ȷCuKy]S?]imK:K%Ig/`&WTNf襟k Fxq4YNƠ3
+ RJ<(EuqZJ0R0'B@Om!Ԥ$ ݬOp=A1<aE10 $)N87w
+GaRxAXVVϵ'_osfkkKRAU< )YЦc2Z|K3EcZ6u>E\B/ &]@@^@8i҂\19n&YH7m-S5ޱ$=s"Bu鵤)??"BSRL>*JR
+ar$vRu1'`l
+c{* oWok76mAT益ѳW﹆'F}S^=Ve"Dm4wy,7*=Jp6s?:'1P"T6tjq>z1z{˽\vupG+%)-LJ+
+R+r̉<J|0g"+ك,}jǸѮaqz^bZg6hߕIvV [ /^>sҥw޽:=A5e4(iDbMZ +I{d<tG7M2\$(dUiAXXeL,4#qǩ8S[o81'2,Vŏ=UTcx=V|eFDĔzEEac[Uj0QDJ~,)T2͈5%V$YA5I#) ƨ-`btxò4"pt`.ϜV>= qGvB_mm900GM3Cѻq 77}:x^ʧρvsǯ9;G'ÝlE78*zC'AۊbuO׿
+-_'NO_'.K^>FZ\fO´-U Xyb.ڌMNO@#Oݳ CũH}m?&BVpŸkj~BW&
+Y ]kL<Ju^
+U^'o,ր '.|!):UV8UQ)0h9 Bzu""
+xOǢ# a'z#Wr2TUXD݌aXmkm4ηs!. o$;Y'-P)cE- XRɂ
+'d &k3 +M;.W'3azaZ,h2YgOgBS#'!]'1.? ,XmLt~>:L;a\eaUTZm_ǥsQέ$^
+Kݺv7EfێNP>'dVµ7ˍ}g ޑC5&,Vٖ,3?jݓB5N<@ƨ+ՑޥY-dHP el:3_{zAn? SHq` sNs/xG%Qpܹ߿ض:.mBcG 3|2'/r{7^4>31LkM0zY1
+(_ $:P"eԕ@7~?{[w iGGY(ϵ:UJq
+7'_>7ƪ.*ϷM"
+v
+-;E&z‚+Ox3 FBjC$iFlLV'o=zȺ享}=r?QK`NyDYfI*㓴h[n[+477=\W}E4/ΔBUֶRz|]3),W%'_?́áI˾)Θ{|P@wڜ姙m;5ƻm
+Z)(>"@ Ŏ*:N,90%{q8zn7>ch~w:h>U=ٽEZq~w~d8S~/#U 2WSV}OXIٗk1xP`Wt`@xٱJ md= m4bk(,T2^ߐK&9 qr-1n ¸k\-q] +L=! Y1>\pڣo [n d9^W{ ax^[t-YX5g;)VqbP VffҏɆ
+A3Xj?+[$fԒs&7}X/3‹d t[@gI9`r-J 5rSEVWO!]FC,-ִSU>52ږ458d&&]ΤS GΆ_MjAFmdcѮQi8fVӅ8SXnWAuXUKĥ LG3چTrwS`ͷ3yTxP N<pա#' XiXg`Ҕ]jp[̭ , OuƋNrVP=) qEJxAqvohO%lkF3L lՠݚH!w $y0۪9q6%6ڬB?M3jur;P3ԃ
+H \u uJ=Ky\?UポPBcuyKW.BDe_\9=jzjNiWMf60Gtv`QҤ(|+>VD` Y7*f5&M$ƈGգ"NS_6
+5;*gys-]n͔I_}4wK^nD.)q{/DʏTЖ1P_( h,<hw4(?CQ=Ml`R6KOMߏkPn j}`fVu<܂#b ^7:o]k>E=G\⟮,FN4u%
+~c7&z9I~uˣEh*Ͽ SEoHNE[RܢtӧZQn#
+#zy<K3m?=R(-q
+#zߙ1;A^!.RIzwp5-%@a|O拇9
+D!18,ϻs~Ȃ[!RR\Z+nkr0iYO:WSC;ѡ 'ÇvVk'ywkzt)YRr~/>e]g'\={!c
+_yDz-?VqX±^1X!VpO=9q |]4ԲY}E;Ի%!%tƬ}%L Y5+]{ ƫU
+\{7X9[Yn7GyM#/6鮥h%Ak:޶HqhΕtm3Z"g;ͳr
+a[\ޫ_^za:xBOkUdj]m)\cUlHH- L(V
+n`q">(K3*Kty6~֖L=J'#@u\Qw M0TJo J$8=٦TAҸtiD'vi_S(uらʆD_KJ AZ/RVYXS&[pm rrc͡`rtΒxZ⩏jcEBFV ɨ
+,xNv uO?ԦH
++HOQpl)躜O@x-o:y+`mp<5D20ɢu<ڡ<Мu0q Gq*2kpj%`L͏w>nerE= sǻۮtxfR ˵1m)-97G<3
+2 etUt= X'S) FDTM%,jQb
+Q$OSCXOӝH݆O%Rsw_:/Fo}5+}`2UrN~S%晽">H+PEZޥz"iDk\_҇T(i2!j0;P,MTtt &|G|suWO
+̤M&Xf"U0@)\i"ԁR _0O!7
+釅FpކI_f>]vqɈ (VA&PDF$+z^- DzS5dOuP1s{k~i~?r/6 ]Z1:a,H= 9
+|ט|=[]U"((Lmp㑷㤦Ds `q
+zsBmU]=FVkys5,%@
+ \B XGNl=q:98
+OƮ0g;["
+SɌm4-ixv.Q3^/Q/VC(_m΢B#M4jHi6(<EѲryaaHG0 }(SuApq<j0b늲G$vp.{?{:Ѹ/#m!LKeE,N[Ԡr3"t>O+8ľYjZkeѮ
+wkwsYC<rMܬCqiQE`-e?^_;aFvʷHET^_ºDBb.';ع->^@en:aQJV!Y0\̳v yY^z$z?p8Gt
+6y$E[ɕvieSmW sɗ~^picFZm[v6#(šP]57ķ-
+8:䌄MB#.'r
+/qB1)9D_}
+n@pABnut7ZٺUsۍO?ƿ8TU48f ^e(w2BB,
+.Xk:".A:Nd֠!(D^h=hj)?]I\zv| %Τ>'́5ձb%DQ3- ɳ]۫
+K Eaw3;mLZl l؇>]gM1ݣ{C6i@Vn%#F.JyѭUp^}b# 4NW YX KSF\0G\ė_O-8Np'
+J
+6Z"RHd
+gZq~6L2PȾwu w26$@kYU:ڋnTr1Tg=՝/C~P|->M.κ<n|mL~*఑ xaprS0m
+U
+r
+ͫ뗾wOp_;LN; ׍D[
+.ĔAo j E ~]|&"~A$0Q)@ #E@[*^#<rf jSl$w @M'֏Kw|/8o,HxJ,GKqtNx}*Y>IJ@t6ȫTq5t~D)j9 `,}G-p_O|ۅKjjkH^aޟ
+@lxHRX puIT7&RSzSҝtAel|x6vֶzz4b5g aoS<u]er:.^77L^#%{%RϪxpND0)X~ʿXZc)*[[r nt>lCyxsw
+Xq0~|kKԴ^ ! vTK;Y,\3JiB\7jR
+-.D(@|2Z6FU@3yW?hTNXT[#ė8[醜Log(*DrlxgΌ|`I T2_LWbF2~ܵqa~˦9}7,NSZuH||*T0贚|M;({<Gsc+Ǐ./^y>qneM~Kd$8n+a6b ItI+xb@$bP -Ϩ˂k%g+ ~['WW}53r-)۴hhe# HpkHC˷"3\E2Աvb!ܡC3SȌl9
+8& @X7
+|?LΎa 
++ RgG ] YEK#e̖<syI/rx$N?"#,`pxf{Pc4ro mP\S^V:L\ȞO 34dl`Tu79yLfϯm?jW37^_j"fp3%n ,)=k6jtN=3D KȻ',:J-P]s)&-ޒ_|<v潩ӗ|0smO f-郌
+
+aX%C
+DetU朲wp<^6 gSn`y8ҟOqj B$VZhmIѰ("|CVMA& 6rfF0ZxJ{[U0be3FlLrVfVi:1;r:JqjZdo7VpZkw얜sp%nLdHEĀlzf U'_b*DT7.H^gڶǽRt VKsFpC,*/)"fY8Ңu0W2&ŵ}ݘ&7jFN\#qcRs`CɃxNXPj^x
+E83%@:Ș0}Ml@`A"Bq
+!zHz}Gy@ǒ֑c?~W* .*P_
+QTB|C_TBV(ݤ
+hIQ7 ?JJ8WqXC_{G7oOznF]4yojc|I!{ 9+}S1CՑb<Re򅺽mM^$AwC$q^5RCiB<$b$K"ė({(H9 D
+}SGfm[by>9#um.:ƶM,@-x]!) `(8^ kuݕ4rύo;/F(ܜ&sCU"Z$ a}T E]82׳MX
+ae|,
+Ni >e"V#R(2CN
+.SVG'}٣u}3C}%@KL!+0H島\& ?,*g۟ݼxƽA߯l72hW!RJ8</9T]OtUʊ6f۾ܺawUQRaLɂ
+j\$k ,AU@̭,,qp rl|2Q9
+WP'HH#/NX>a J&&1 !]]jLoM(#5ֆ\J[+imn霿#?o8:N$NUN>^vo 1e k!\MI4gXZӄ$+lT!m(%𡻙PmLKaA?U>0꛶V3+s#WG{6>dYv q"GWAI $vͬ|;ӝsppSS=Dž6Lp[r%
+V6Q652˭|#1J-sYX F WU@`@JN(zx4Z6êں0tѾ#!!86q7dL&z䤙LtIڙ6d$^Z'6@ؒXڮ^WەK7sOw~N-ɩ
+T PBJ/W{lI Wb+Je:hdMU##PHj55C^O\vPӰQK26Pk$kJ'tr%ߞֲ6wŴf]1m6`fG x;[şhEy+9>\X`+cg;!\mw:=<[.&vbK'Xƺ9p0hF*3M ! +R-.bz W5ˊF_ML[9'[,Q=r)jov%T{2' ,An繓"ĕ,Kb c+Cy~[{ϽQZ^kG4UƔ-e10Y @aw# =-b+-~e`6߻ٷ92:>h[mYzz`?Mİ Tބ%ِr
+0siEq"LGxd
+4(? -_
+wྠ~qiOv
+s9GvńQ&;͏Z([D?,ԽU.$!^r_xsw#x/}UsqdDM3 G4.P YX\&ȳI:$OndƊw{KO6[Ɖ0 fJs=/BDb&na$ [cLonb׆8Ͻ!%dXlʉH6V1`ˁb)9Mg%6JIC
+-erA|X5=~~z8wr4w|n@CFlR"?4uQ t'񑉙zs#\ɳ Cf+'S0e >kgu&@kM68"4G qt)V{Tk^݆Epqsy2ާX kVmZُ!΃Lї9X@))
+o|-D{&w<}Tgބ A(wȊz/וD7,|pizgLNEIZdTR 4n3d<X sפJ׬?<{X;x,sqz{2N
+
+Er%+tf< @I6 p/Pl$5 H
+%
+Vm"RX=Tx>BkcԭD^ȊX9mT@UZnq@Dc &;(|+dg ef%ʙē3'X`8HB3Us}i$;}ٙe$o'^R=$e 2weP19FC#j<wZJvJ؎f;JnXQ"
+rdџmL
+6 V0ׇc&Gv2O ;1p`Av,Ln6՝]-`W 9R;u;%O5Ȍ5taV/;
+C"z bfI`D =[X: gʓ-)$6
+C݂Q,@ò]j.@s
+m=jWi*
+b`+ʍ}Xg2c}bl +gѬCrqL1!
+F4>;# 3 $/ΛV
+]l
+I!v"CSȋ$"U)㇗j/Cz'$kg~G?,5Av
+)\IV
+u>)` T?MNԩW#E AK["{{~JhlbB:Fṕ{W#gahLN80)R Wr =Xw#|ErG ?׌oR+ٿ66jihUٌ WŸhGQ9/u hdyZϼWi/sālh(ʧ]|o|~7E{n
+^L>nq{y/sߎܽ֍oB};!ߢ|>Z6v2:Z`%r/jzO4Eð0U+J1@_YhtN[`-]美-rVƉ1rGQ/]ڿq<cn>Tw<\FrI:`pAFᡘH;EZ:X&/cl~R]Alҩ^_fdG{]QVg[v
+: R&l^GMm ӄףh铻Y3tQV^Ii(JF/FU|̙Oo}'fk*F%?ZQ}uͮ6zMbTRw/磏Ώ?~ehK8ƪD*3"]w] BF%Xr[f'XYahyEtռH[* Ŝ@,ﻯ񾃍mf4m6QNGm:U+uJmէy*Q2f
+q%$6cY.G39y\FE(.!a Gz]5Do`fZ}oN+>>cvO9WV^4AUNq-G&u[ O,;w,-8U{g.2鞴x]ZOLtv;/F Ezy1GWƿٙ;ON "NʪfrT#!"Ay>pֹQ<@,%3)#>UP y;B
+'
+ Ųj+2y doX5:Z{MkrZGF{u2Uw,b26(iCio ؙ&l >J-)7|;d(f37ي Z7rtڸv'ad쉌)qO2AKhL}5,4ll>̼7^w-̭CyX'EnN<JxD (dI&̕ð\rr[h..p,KpJXKedED)rF/؆u7ȱ .ճY-Ǐ6*FSr˜+DsOB.Bs%0a+VWih h˺вe{S\
+$QwlW8-y;R]fdyH\,іeSjJfhbۊfב+s'AN=DԬqVIH|Vց {yA:gbSn T'iCu2oL_ؤ2s֔eԽgd= Vy:8;V-Uq+*i̚n0v -l [Pd,]r2LnR*@B)d*e;w[yƮOTPFv :RMQI7ܙ6Z,a5eSZۀUW`ЦvpH d ,OBFUW
+ωۡ*x_hYڽֆh~edza$r6<zC?}*:}r-mȂVTp;pD ҕP'"}Uf4۶*pg\?eBa&R8P J`-wA)ZO[%!o3
+"SGŞ{fmmSsC77}hy4y@@pG6^ZFm3ao-j֍ N@i^h%:~$PNCRJHHR$Dq Bo%x V& XF5u* B=PS#Ԫq2%)
+ yXw_|5^U
+ɼ[bw\RdN Mƫ$ӄ\
+NM
+L%15Q3QqQў 'B1*@1/v$ )7ɹ1H Cv2r0T)l8S
+)B@*'DqH
+0JBf$%J!,$a!=UqЭl9g)Ēx*T.T{}dϝ?|iI=Z"]<z BCra >iQk`\L l\
+
+hLC=I"X'08A K{=ёW$عRW rzD#(d/S$0xrY
+ ha 6D _yg[#/$xr2!0 iq.;%<^'{&8=d
+)$ h5e="ֹ)-񶷅otjV]bW֟\<K\y >tRmYjs1  gINq!Lx~w?ӏ.9~lmVtn{!Ӹꛞ)'q͜J?B_$;swiScՖDH.#`H]aO恸qMpnAhؔX' p W4cp62S+K c;g-뵽:DۆRm{-4~ܥ3=םGlo46j0@%|"G)
+)e2T ^@ 3栦!5h?@IisW ʭxgUP`&AN#8 :ʤ)Z9DMoXQJ EHJ
+f3(:c$[Xr<WH(֨w1RIVl(Dd$gLFrDTn4=rטwyV"B|~VL|AhN'pa5MNN8J3;-H+I+:yHh1*c+I1Qj"1csal}v.n`4[ڢ+`Y0^QuuڌH.t}
+׎lhJgj<- g: +g6YrŴ
+E0lYݐy]a/"'/gt.R>ܲhX ZmF}_|8wiglY֭ +Qp)xt>̙G^ E1/8> z)釁>sRK 1IxQ,"a2-҆(ဠP5l?aysz=YFd۰iT ) o[i'23RX&B /aGr*=TvlgR{u_{vkyl;uq&)BTġP/4ܔw$H4ϯ*\`,XKW( I5qIi59,1_oD(&D
+,Pͯ;l\|HŘJ*8@V '| )rt_YC @2V RCN\|=HAy@ <'Jˑz d0>gm0b`m.ހ^1,;mK9czѿratVmuԖj?ƥi,"~9 ,,΢DjΎr7icM|@q9&
+8RIeAFE8[.ԎYJh̖N^‡/`c-dpfRK{qGͫn~ih~㖣վݪ^e=UCe%RÏ+܊w3_>;48RTם[Fdmu@pEp8),/o}GQ-¡e+"b( 3>8]tZ~z\FxndnFݰѵQf2L!R-G ozm;<mYI'<ALYE[GGҾ^o
+;3Aqk TRG!(]dAJ.H$CR߃5|!MBRz0Cb4$t:M/&>e,3vM[_
+U
+
+zćTvQ!-H^6?T&Ҏ4Ȭ N k~`<NVtz*Pk'N[ĝ
+;!e=|N;>{-嵓Skƃ #^n:Zn٣cտ27o?֏
+Qmxd%xvdJy\RsSQ8%1Pk$Z=QnޓC9H l6(D5pbOHH
+T-ʐ>/$uC{,}GkEe#՟հ}Y Ӎi̎(nDGf}
+3V"PvHMrno6i0iRVҊgtCE/r_;Ln(LOP"(ʘXAv5<$Gnnbꦶ@ 8% <H8(d@HRDQ@ J5|$g{烷]1T,b
+i+TƲᒦ
+].'HsX!!IEq\!O`RU>mAՕ(@mSxɵz>cS:pk'uy$s-g@񑠷~mx,=Sk3>b~dܽߋ>Q^ӻa
+L=S1vʞ|aZg
+%TX$CZ7k㮗:>S%)osrZߌD4j: evVTiOiz~l%C?>zٵ?ҷ86M֏б;.;CCKˮᡍN<]K+x^ ,(5=W B 5_w\u.)PMI%`!|BrX[ߓF@{JyV-B#x䡔2QB%4CSۆ6&]9OdϻM^҂bf*LqwZO'T^f,/JBzm_EI? "TZux#ތ
+.'P2U= {
+$9B.,Nbi4(5
+|ԡa
+\nAWА(i骬|Oϼv l:C3mm??|K~ (Zr kF\ aR>L'`.]hw:=,,:Ҿ2mOZkܑn<zº286NT{vp>]3ϓG-v4@އu.vu˵ўKG0q;}iP9OL7"lM*l 7Y .RY p\/I2,GEbZb-o\[rgMQ=EO
+_-HZ]Wd!60`cLiRwqҩN;KO;)}ȥub'ۘ.BtJZiWR}3;s;.g nLߨ
+D"sI:4(fe\cV
+!lu1dEL7+֓f|!+PcC6PJY2CٕLը}Ir/Kh^UlkUDƏ;\Dv}g8up7 GBؤشք̾fylbB 3 YT!Nx֬e2*!Nmֶ BN k1(z#b<@V`X
+\ :#!%#1BXЅKnp OVvD]Q_~?-|{Kn;b;"L*4$P?YSV,"NJU!"0I*MdԦ$cOLu 64K*>YrlݴuÅ>h+Ƴӯ7ȝhũjd+aGjPd.qY0#W>ݼ`!fqNIr_/"_9.n8G}Poo|f<E}Ӄk//mO&$v) 6B6aedYz}uy`~ޅ]K):;H#/ oKo+~=p lg'/7]ŠXR7eْ^&4R', ٬R08O3t1"]#3.|0uf3!ٽfP :FFx[6BX *
+qɣ75Ezci¡=.l5x\Uv}4O]l{~/72DjA]T)?LkuCTDY)I0oZ1YE1s bP B^Xs)LLVd
+<Dܿx"2gPM_,}=o
+W9!DdӤM6O[RڕT}ld+ew!M @6@4$+>|̌g9|v R~K3K~~MjG$wD
+5#Dz,FzQ j2_(*a$j I3w jҪyT-ګQnvo^!sfd&~Y$LS?mUXl
+2UWjGX@ ITDbV9{
+M;
+%3FJ%,mFްUT*]
+sf,D2g[kP+^׎/6^"ߐ,9Ryf`F[AaNu<|O%' ʘS5b&;973EW,2z6D^(k2 +
+rQ{hJ(LMKB!SphFXV|"K&E A\< єKĥtVYedTQ* K
++Wܫ:cV&=3s;aVd e״E_: C/\uL4tfN%S UPـl^gEa<ٰE޽fk:_زGy 2GFti<-k7FJYvߖy%IJ9#ܭf#eOO~,s!4fiȼ+&VF+{#g܋}͹!18 1NJՆB֠]w#jeuYQL
+R)8aL1UJ(|A'ExP L(>Rڅ4a210TV2L5RR+IJ-'hH d9n9YiGM7/Oߝ=}۵‹ymbs*1ʹB? $DM%D(*+ۼotڣ ߯0T0և5T( fo E%6 S
+U91JA6r؍Za\!U[*I5NB`8:_C #??ݘ{( +D+XvO?T
+$̅ҸN2U(Ir
+䴶cFRcx>{kXypuE1%&/iIH_,[nt񦈣yΏ^I8;#ˆ2"7^ GZtoKl'U+_\3?Y[M?wn)kgVOowh߄Sݹg3E17UPMtOuB >Mh˜e=^J s#;zc"VyY6Q]_S
+滬TyٛQ6{Q7X2eDZ.%,DHBP: j
+u-{ /5tT2fQ<RtZ4JGp<ʆpL:`3l| P6?Q:9t#lr0zS\0}yO
+,ɲ̼i 6E^&q<)dʑ} xAUY+%E^wh+eR Uu#3%ᨑ9-%h8!(Hg7emż\{¹S,?hOqi~4o؇?5 :Wgw]:SœRP˕d[<ktJ["@ʹ骼judDź;E-wLU89,>"Ux6ƣ(
+ |8de|1я#%I\inIPDs(`ͩ(i~*X@A7oZjۢT0FkoDͦ`;wkola<s}֯'pۻzr㩻w\lRmy:o`?[O;e$? (zؿ\32$|꯻M_}t;UWV4~8wɛ]=/p>:U1@k\z=VȺ&'J7'4ZR.ʩMQRrevF"Ϛ  e 1Ïp0r3HḞ/߬*OOQ|o>L%5+ny5<WRT`d񡰒i )8搦p+YNIT`UXP
+nXŰ809Xa;vjn@I7)\։NtNk>v蚩_ B$l[@ (&4 +$h*HpꈁT!K
+cT{ZV40 xȏ8WB|-B` la#elXhpPvZeӎ tQ0I'"JP : `
+o/ &خI
+A#\,/]lw͐SI)ָbJ68]]*,a[#,>cF;:^ph"qhTXIy$ \i[lwG(FXYkTsWݙ 9bS*}j=ؒ?[n!b`8Z +>3
+\֩F/0M>\ȍg©CHq1 8,$ W_~?Wy[؞g'_FH0¢zC0era$';@{L6Dg,y鳾.s;=EaWZᬑ*EsWjo-vV`/ vd=XFUzt-VTaC9>#
+Pgoy_|07 科?-Lˊ__T(~9S ͗:Ր_Ue&ɥ`;Rry s*bQ[[?%aG||aY(HgB _( "D@A$tLIxC>ea;da ^1!:@Mɖtzl7glD8.i S!(OO*Y@zA*!x1xY֖<\O%xg&\mYm~SW0d GT8 XX܈TfߕsvĽpNsЎ|;eJ)RG7YɖP,}Qd 6'ʑiS3"f|8G=*kF:
+.Swu`6Ŵġc\{N:WtT{ٵckRIylmFTw&pp`ɔmR>[R2VEhbeZlp5T dŦ,nc#l q]NaJ =ifr& IY
+@Af2m—+tO_h5_&TkE~A3$]hDXS ҷ {k&Wܢ}8GqRpZzJ)!X"LI)hl밿/4L
+~ u5і{IhJsʰ}=کiGuz |MQ<*t}}'+hƉ?IUKKO?Z\<?QlkixYs_Of- O͌ =:gf{[:'֧Gv|'/rvW7&`ޔ]N?cRA}vkݝJmU9^y90q$N?~ s~)H%
+\D(Frlt(E$%\Hr?E*FªŚ8s\N1enzztxU3x3!ާmONg>J4d:{$=
+NZN|j1٦^BI}ctnn5pՑ^&ZPeFwf#({ya΢D-[5cY_cޯm)rWU]nLбj|:VLj9<͉wk<]El=z'Ҕ]˶'BS1 5se熾?$ 0G$ŝWIDRnKkK$ j7hC
+rKHnQȲȒm%Dm$ErCr
+~;}ݗ:(F>ȁy70j{ e EϠB X[ ւ,y,|tk
+(P 8NX^x\$8TҮp[O?j=vzy^{Ko^]=tm" U-=Q3}:3Jg0sɓY,,#BZXqBjrW(<OhLe fR{f"TE!M
+L/2A駴'0C4qf!J!C,QqO3ۄrͰ/ܨEm=}!q=e'÷׉'Yg|3ldI S|6}hrW}yŻfo NdX%Q%RyaFbw`S<םBu'#C&hF7nubk+_|Nw1P$t0ʬ!\_6F~2!B `^NN r_<_.O&Z TG#2Q
+see%W~b9Jq3stP'~nȧ]_~߷NoOw5g+v;x*^OèOV遏j?.؟ڳ.T
+gDZh ;j{.  2p&9տ9}ۈQE02F|+vD+Sȶ ^fK|klv,otww-{6#6 ]s!s9#Dۆ5d,[/kL>a) u.usīiB _cŷתیw֫ggF؇5˿": $ (M<Z, :tKA>'?8q$<r䃣9[k2
+*rHAc1j.ˮ99c cL)껽Nsl;j[_+z[4) *H!J*ɬHXy%Rq% VEMUaRخmH(gi'aN XI-&ǒsȺtiZ
+1(sjY#[RUY^)*Ϡr>7JA/NazVS8#'_v<FPk,RQNe17RZRJ6^ o߸?]t;u1<f|'_(cc3N_ެٍXuEd*uIa.t'P0x"&T<*Vd{&# Cn
+XH><l{B]96ܻZA{yp}I<?Ù^;fL8S9i߷qx}Hh6-X;|Y]s]rݕA^Og/#Q^bBFUWe2$T62el<o8R_,.Zdw0!>>JYHacIP;44.T
+M'Mŕʨ:+ElfTdB-Fib v.¢LA(uV2pp !EIYĻhoV9dd'es0nWctx<a {3F[X3{@}"@HA#p\@Z%r$a(E)q3 OEHV#P:R6Ԡe_Wq
+IRisU9h")Y>*Lp91M8 e!TZ@-hOu~aʣ, r~apW V*>8+ݱذ>!R s ix
+ @WE(a6+<~*cǭCid X; ܊G.׹%D%w^AN7ƑB!0
+;&e3fhWZʔ1rֳۈ%ICHD Q˕.EuN&0c Y|{4kuMk#5{Ge*q8*{Ur-NCbtvl|-u| e됰8ΫOޝ{mfdU[ uYtWa(d}T~S96D,G r{kLLwddG\XE}ba+K͘2IAce NKk]e<~ j㽣 4XNkR(e|SmmaujJtݻ2ʛ5jnX8!EėED 8-q@fSXh7 #c 7%2QVs)F$kJ7%F
+X )99>޳|lE1Hf4|1uAOP* F-b="Tg/$"&Spn)y׫^~Z)j j9Y6r@[\Q
+ +ɬ/pteoUS D^˂$QC18
+q 9f@Z +dKSeUMziڂKܔET =gd:u[˝wTu;7Z/r~_ ouzv9&'ϡ3[7=#s;-iX۱=<h6۝鼘9{Q2l6͚QmcgԄ5h@?/$VVy \HB7mW6 [A u&9[ٚYMFK -mx,b?*|< W7ۏXZ}v$8pev?$B(IQde !%A D"g4|BtbP"B0j~^KDqPnw u!($F"71?D
+ᜂR4J?5>|ҝo->f{[Wn\^?ܝ,۠;kܣ`bGQCٙIQM<åe"ۥuw=Ӥv)K j92={C$r@oM1P=1`*/#N X@1(^>8 +u"t.j/&QՇ꤯_!,a.3!Bh-cC?7?sD"<AxɐAa1( \>Dy=5iP;nrXKbh.8
+~T.Nj6KΙ@? |^b+یƪ't,RKTPy˹U@ۭa*TJpey=Klr<Otni*sq?xQRKmvm.J%Aݳ F@f",{K so6Q5E5:oj7*mksT+W)J(_d'Yc(Qk@8,"zMېJf*㒁bk&Yk49Xj;JiS4<툮2-Sr;3e0:m8
+7SZH֨Q8@X$ˊ,r}I>t%>kIn<
+B+{u٪ܬJ}0FH'cYfnqDDPZBdQborr@fЁL,x+v/1ˎ]Yi>[[K+ KZvHӟ5+;ĠblHq,௙ck
+$ ƘY_\.+{,| ?hzhDD"*)J!0F܍h@D# +*|>Ə /WH@)pF
+jy~R=nSsPK}U޶VYbM mE4H*\@^d`A(E"z-@,SZQbqCX|i OHJ)*K
+ DB"ϰ͂}`i80-X6f 9'Ǔ@%eh!R- ,D@PIɊP7h`Jkٔ" JRß/碄DJr!B]w9JۡWTF((pc:5𭞙 o?_S˵k3O<m[9[~p@#}jBϻ[BMw4"N éЍdM^òz3^f|Ԍ-)qR )wr^C<~-#ht&&M
+A{"o:IOBꍱŌq>xv]6/OO"&qn*^3ʷf#ƅ3Ɏ;Gvk Wjl JnAElC9&VM]GO%(HI$`E0$GLR^51& n}!c5:/p=%5TQW
+єUeTZ v'%l
+>uȡӯE_{?;?y}/n |@6!-iD
+. ةXWmq52/R؇gMrvuuUIvf0E(E8Aȗ~,qIR!%25NB*:(wGL❄YD h~ƼТ;yݝ+?iTD!Ra6wP[>so\*işElHqh_ 0&=pkNP}Ƭ~Ͷ+s7?jԜU C@BA2w
+pZ!BDms{X+s,[-= 6b7&eIsdUN!ضrq~o!EY]P mJPv0|Av;wIaM϶jM"-ǻq'ձ<
+TE4w:Ǯ3m9-fNE}`ӠcfrE ȆQs:ȉXKfrHi\߰g|y{bh dH4N]R!/*l0q"D#"F$‡ Qwj׎Nc
+U0Ѹw &$d@$89\g"R%R [ЊENڈ];IE z@(CC6vo%۲e˕آ,Z %Qpro"wzRc,_ȘpX73[|όn|~مo}kΎmQ#C!
+#vfl9's ͏C%@==u*S&U
+3[*< LJ2%(4]A1Qlmj%ۢXI
+q7r=wҌnp At"RuX\8ڤ)P~qx
+jM#/Q0)1;-3'Kh70%\b,ؔ4ΠEʤ|3C E 'rAA>Q4yų
+6/WK G/{0ɾ
+l #ҙf j}kYElȦ8ͻS_>+N >
+:@EH@*hpA
+d
+J
+?*% &$)D0R%$)TƏ4ά /u`,$qKR6T04.==b[|a;oO/ _X:zy{17gw7[\a NK){#k)kd[UiH%k?Y}nuZ@ҕ[tjW`}FZ'߭4Qb
+Vzs\Er9dM<9ooϹ'9].хz$ WմmgwM޷A׳Ag^PxoP%z]&nAk.Kf̣F_,G}=7nTE΂K
+Vg=?(bI؋6 ]vUx t7p9$P"F/ qQ;Lh=;BO(" j+GC93c:ox1e=8p{_M?Gߌ莁%Q3{6VObS=eT$ŧe
+Lj西^T.&=(zͶrvSJ>!AA($-!|3H-B jѰPɵA AziX jMVg0@Uu ۅՙHoÑSrQ/곭ÿ޸s/#R" "*A."Gt-G7#c[Ϟ}ç_|[+iC-|?[if*i$$^OwRäd[Ql>։;Q5-
+6+ d句Wq,4EI(ɲ,[Ȼ8uz!-SQ(PHm(
+E$hrlY%Z(.ÙHp_J#>P7O2sb-gz;CKd $Zd^3|iVegYE33)z<^T9ݘMHɍ*
+J|nM߂( 6]a}&1Z#瑣wBID ʯ5n5ŝ#oEA_i}}ʭ|}79#ATZUP-UE[w6 Neǖ}(8ǽavz:7;KA߼;z.{OhHGS-Ȧ\H 
+ЀTezPW@]O_ow*%3.3+%Q:;-"}{|U6rLEk~˩Ȭ|lpr{"'Ꮉ&l' s^>WfN 2c+":+jhOg9jSYgSȫa2SsAhǜ 5hFi)=5ygn殛H᳊r.qB1VFDi! J+
+Hc`@ ۄB2P)bo4}W,.2eEgSȪ<ؙ M{Lt|wѷ~ Xt{lԏ3ٝiǕo5ݳqw5Q 51)Z{U#HJ0L"zU×l<_8 PmhxPJ&b`kZZjzh6r hE3<Rb>g~-~}3X˷wuL9dP<teTjogWhuVͷWEFջg\Yw-ϕWi_}^U^Sc(E}ψ4,D<j oX!֘Czx%KcN6Q=1K4]9\ה*QD^[㟙=_zh \e=V2*]nذ*,H}/xTY aNi઀flKX /ѻؿa{i懿ρ?Xa\,*_bĬDR|@w;Jl8I
+6>kth+}j`ZD/FK"Z\l,i
+liJB(x
+oDؐS M5FQ1Lm4DrYW J
+>5dADC(
+!?Pve>|SFb7D
+C)HͧƣF ':D '.⸻ʩp"tɦy|ώJ N`Lv?`{y6>[x^+՞m6G+\կ/[k~BLj(N~֨#h 9f`/<C _LP2 B0`&spi|x/2 3M<"'xBU_k^߯ܽY=dwѴ$گklժ`{[gߞwc/U7N)Q߮!@xM19$09c#6`$M_%}psAX@pG͟ D|a&<t;>w>YvUp9XGhDB9x&Wl֨Ou_p(Yw*wO f"*;+z{rLc e5w3k.YH3#H-u=g)e@t83
+X,J\HCι<EcfΨx'`rR9b.PSTz:Mː+a3}Dp|X㪞$؏=0jo==mL=mmT6n.UխN%)FFmۼXS+M6?kұC-b+®%
+ea9Es@`@4(TS1N`+V,>4Ka>ҁo]46tD}G8
+ɗ{2~pf3zΎٖ6Vڮfj[lkK=BpF^ G6౲uR$$ɅI#M g+ Det.꦳ Z`фEYSH$MƂ˅e(
+1?\ 7?
+~% :Lo!M$ w|<v~`IswPu7Jv97ˆ:휹t1vmM",GtaKd޺qpm3Tq!ϛQDZ^~5{]ʠ0O
+GW>>'^QCс'k:*su` *oAfvcmc2upVNx.&ͯ |rzq[CBY|ihCÔAԝ,bƫ#Z1 :׀I6oo׆ 9þ)s%穁uAp $״Nq78}2\ώ - ni_)HhD;Eqh!S4lc r>Q4uLC:C{jnceB`\ÀkENɕBaϖνuj|ɫ/˹ހ{TAvDdr<"]CpA4lxB^
+PD3N*3㾓60S|9SɉfiwudwZrޡRdR'I Έ$IP/V a}5`;tzhCN=&Mg2'N\l ۬
+ݘnV9
+NǵB7hJ_V頿H= / 7
+m38vuϖ.BC:> :pI+r.xy໢3u>O7K<ك%N@\W\`P`
+@@+D{r(XYyE֑&])_'M qʐ
+_1uB̋Khsޜ.)W+@y:ND A*e\0dLtuTbVI2I"<Żn9>9A܋~g
+C7fI7q"kÕG
+Xq-,(*iܝ}1{mGHXі*Օ<h誣ҸК U _zઝCde<wz
+s>Lz*WUV4\5T$K^OLY/\wDi(l>ér5q<w I
+!7p  "rSQAWvnwng/>tۇ;uwgZ]w[PAEpIb I=BIWpwy9|>\1b
+
+A
+U*灛>C1묨Ū6I2<W
+߯s6V
+ a˙CbT?bV;}#5]Բ%f,$言
+{ ^{Yǥb V)|S;.<ke [Fwh$K:C96ʜ;.S^w#Ap˻C(7
+\9.N?bϊ; `<R5Bؗ_EF>#]Nr$8k\H(d NHed^ &%*i'B>z;!o+xkRt^pnl!>e+ eP@xtK|P\ŅƷiOpݟWԒSl$ˀcs
+OܭÎ30~DNx @l.->+ (i\N%P,tTZyU|%'9
+p`^#;v^7򠈱t>@hi􉦙<l,4w@DA#b{c 0&Fi}ymOoEE,k'P͈dw.;_U zȳ@bh=tv;1٠^9 9E'#3¸/ot.W_yIS
+hC[$hAԒ-[a[eڛ"%KzˏK>\\{9>KOX:zݕO/:o'GCc{~tiBG9&!WF;?ƌbjV|{60wKuv꽥h#?=o7S??{|_5E 5ȁμGbV
+(
+AYZHbDGD`T舫awILi`(DO(CFQ2MKgZ^y`@cr2!м>~z kNݖ_'+~V"v
+F8XB~ >FnR=BAb϶-mڑ
+t"GH'ugoKlJ5Xɳ$`+sN`ja"VWuAv2'pnh= +"5J~T򧤰?*CpTKXqwp,j*lTܠ
+a+S^ =GR4U . vrWPg[Xcy*Y@ my}`UՕ2[Lmv&]m^Y@u$zwRfC1w?-#))H HQq%`-$*~Z2o'$Z!$MUQ;<}+|˅>˘m}JӲciy]_3́4ݳйjMhg s ˼ee`J֗U&砨}e9Wip[k[4_QZ9j
+QP'Jhtܫr)1̡;4>xh1s#x1ƺDtGk?J}n3QZSTY5Fd: ޶Z,9^q$UwT4'Pwud/Ӂ /Υ7o\㷬L]kΕŶXн4wsG$gS';tiAY
+UT<D ;+MC^"EW&GGD ;17A=Xˆ)q3Iw iEA3Oovy2~zfݹ;G޵LF#ZҭNM_7^+kNGslclal8XJcv7_x]o~yz #2?*憣|A0#O (LQ(C(QH>qu~\UIaNX6[PCt.VmLڙZԑq b sHXHDt<"M<+}+eF
+?_$r! l/LiwgǼ-=lݬ8G7\ëH #k^Bk ,V |><c~07Pw(<<0 YZȔb@lD6}П~Zdyޑ]̍2/k]\w/fj.fE] t3z: A>DZ61ٖa~ÁQ i
+'˟QP굕X,.xmmU9FklWFْl&^jDKzB\D1g3Y=9'\5g5<iLm|m0
+`i Xh@B֮kmIlZu6iUaST4Ws4$$@s$@ccNmڇW?yT}j
+PlH]yn\[U8i
+Ǟy}@ob(縎Ԍ;W
+jeδG>%pQ#o6,
+'v[}uXO׳<{z-fj]=^֤֯*NjTЫ.kj- [ԒE#wu&;m,4e|e[ w6GY32c-dEyJ,~I|-t4, 6]SpuLK+춥C{W??qaU/՝D™IVZ@G\8WSJSz(rrhe$_!L;q/q?QDs8X=x,V$iZq:EB@7FF< ?*5dTWzI6D_NcIFx61
+S]VĖ
+N’xLẃqQI .M%жt?.ϓ~=<H8DA649;gϜM5@dMZqpۇu&'3k瀕Ֆu 'w1lC
+?B2 I1EheX
+ N`ā)dSx
+ =?te)tiO+^hGz`I\ðRa;DOn!ߤ#u))>:IiLEM478&6qdv݉`F B‰ \i-vi3u.VTedw:`yL^4^POK}@-ƍj+O^h::>\ *D?}n(Nv.M55<=c>!w?eu݉ ɨ,GX}Ԯg+NI%8xda+5\3^R
+r-QRVc40x^k>> {r⫮ƾyƓ@-ano 6"S|"q-BG"tF<`NWaG5Jf[Їy(c302kiF;9U_# {ҾEf%JKfKnLd:AJ{2YڴI>G>2d6~#)i_wo~$wF1JOơ+(tć̉FX
+NM5d2
+w.~ޏ?qAg9^ݰ̫2NʃE}]Y~O^PzTjiT>*Qw{]wj@z5ܤu+~l^~/n"\VUk돬&u) F*; -ꉪnݒC&N?HgO{l+,ѬV";,3Yguckh!RgnNRol/]Eߗ4/ͶK&񁥙ʹZޏsɍvn3ii
+KDL>LaM>$i M)w#s7㞮w,ҳQڳ)s]-iށM=o<җElH *-؆~V{! ƈZʠ0 kQ7>f!I6Ė(DwH.m 3x p)h5y~ЇBفDDiaEޣ|E;[ GTDt01_PG1~\ɞ!*!CUDҴ9Kkw"D^[+BXԔ
+awA-'*BBb]D%m.
+6;hU]ZJYȕWav'9 qf
+!P'_qU ~vQY3<fN-+64]œ4OZKGՎ<:rrۓo=zp,C7O'}|'޻u=}]>Koxܻ|חz?~탱ڮ]9}.i?xw(&B Hۡl'LuW'@W
+jSZl쐍Z V ~vvq\C>΅|K5yh)D& L$X Y~76dOy0XO6`12L#MHD04?>YIXogjfJ| EN~&7v!0a|N ;,>
+w}/x$ hp]92o؟mJA|$3̄Lhz
+Z6%4OU[d6 V׸&Ch[jŝ~D9į^,jU/k -Jd&X?jWjRvHv~BP3[TVuF5G_T)Ս͆ID#/oO,mIqRP IP @2x[F"۵VH)$^Lt <M% ʀ3) AIE'x2 @$ʦAY3b 7 #Y^N>lc̟N (Q.%7
+[IV#I3٤no;әtOt:vcc4""(r߇?xoޛ7d :E"z.=i[iG}!AmDT(R=(l7T U74w-0z]Nf[V*^QJ+Z;"(g[з-mw_)|G':ox6CjHeFF6!E¾G㺍dTT0qrYL<v=d!l!*zgzzYޖw(^5 ^Z2>ؿ9Zw[/>+~Aׄ@ߎ%XL FB#Dy
+.\Uf{:r, I¶p/γ+܂Y `h*AE 붂6EAjmJV_=.) kt歍eSG^ݦJRW XkRϫ
+w5 S3WLTśN9"d; %3:*"|ޠ1a8[~?F\sx[FRsW}wbʫ[aHX5{Qyw!gDg
+IML}}`_T͵ʇ, jVkω'EU}$V[f*۳쐫:zT6aBl'bMQyAcnu ގU?2Қ, PlG֗'{sm7w*W?؞i<VR*לε+Mkkԭ˾f0mPIwl`|Hx!-ƻ)"1ڢUE8 5ٿZ2JeeW[{H~rTy7Ts踭-=}x$ё;!+Ֆuuxvdl'7⭙hT(-*aw(3!+-p5nn_`-ɸ'u݂O>ʼDQ9o 9?.8[J)(0KX w!5$n''n/Qql+Cjĉop{..d?v"Ch ԙ?=)}<s"8߻M`
+Sr$ӥ \UK
+RY` ZZDJ4#
+ rk!Lc
+|$==˗,mYuF,hh~8+o^o-56ȔǪBdM|[-jR
+(B/24wu7dc'wJy)JΠ"+k|VrRwv`"|x_澬-\^k߲+727ũ1]t9ICq9@+OD.piUud %sy"IMHSת|^ڮzת/:w*sTs훃-1'$O %9^zzD*^*7Kfsit[LZ`mN#%Rl =T5]DyPmp?1E,B|k7 6]~nopKQ XyU1{B>sI`[$qF}2%'|!̄yJS{y"dݟHa耟'.l8.ء.
+dN9a]Zֶ9#}~kfhtRnHwc%lb*8L%xXnr('ќEa(Mb~.Rip6E7VpBUo|KNʄ,4.2skrzi´㩺)<[t7nhő)oIIX2P g펄"T9낤8MI4##dt E"I$tAɑp ^ Z%G
+: lrn .U ѯw̜9.`IAPxȋ >
+x?l+{kC31|(}T!
+޸'%y]XO5* qS:YvhK_৭-g tlSX eBu9F5yo'>tlo֯vތtqk@Qx87d1<ێXފQS ]`
+h0.S5LfsN-Lvs$kc)7cXlPG]>> Thsxff޼7A`E~`
+`gCG.JY)U86ޟ ~op%ZiE
+_Q b ("D \`^kp46>_"#<~ |ORp*7/ھr-{y{q"|7NΘBX5zZ^vbJL hє1q&Z ä&3d C븈T@2% eդAf]|7I1]{4С5c/}{-سoG-+SSG[vvFJS?%2ruOmg] Ǣ?{f@z;x ڒ[Ȗ]$f6N'A0
+ 2f`,ڥ([Ou uqo]SS?z /%e)67/+Ƕa7'|=a_O;)4Wj6ޖ1,j7"z\`1grg t5-O7 񇼉zעC0tġ'Rj0⦢lZ!gcdnjz%l4y٧_ޘofߙ3W9{ѷ}u[D/jO6 =<Xn@2 Z= 1J-jo@uw 6;䳶M``UJ?cr_
+9x$`9 5r~y4e4vbQ/p00ɖ崩B/_B-~]$ p̕JdH|
+ŬE/ͺlvhoze{i5.gt6޳& ZZz08iIO%tL娸 LCB@ CLD-UOzcnMY,8[Sv
+drtXSa#JxpD&"=xE_4ݩ&JPtd/a0KǕ. o;FJԶ̱6iOҜ-tgH*܈ifoF4{DeQئqZzU#5me9!/rJ xUXN:ilD!j pvWr|S|YϺB;/_fm^z@qvK9mdnJ}vsrk}2rGt1,>X*f/PO]3h/Y駝YmQ5ZMr J38+WAMDhfI}>}ig3}LivcbS{LT UDn
+^>3gvΙoG'
+vxd[هȶRjYmQZ6mKk4 ڤzCGaa-q&h9^7-L-RյYg"Wmk֗1Dwe7-2?*cJrzHj nfkY4߰߱IڲfMMUlZ'[q߮^
+}F͕OFGпjdF/
+ȡ`SQX ;}xŹB?.u\DH4Gj9`#Jʏg
+[
+(p@;.kG4
+s`uDN氙uv,vߝjٍ#?ͯ5/DJyTNl͋ _06ؗ#=R &ap焈;F2/\An"f e% Y aV샥H?Ą@ p3<7D3HYn
+(^D671nﶳvZT> ""y^?ߙ<?u@&@Bxw\B\B"4_E-mI'-?j~ ߩ?5hkn6fD=H{L@0  ݀NNo p ޢa <93ϾWȆH:OLe+XY
+T+-MfDYH*.1Mfip>=>0T{M9/ՏfW*tUeaV&J:i{Oq/;~뀴3~|ӌz=/@kh@sX@TuFjȖ H,A}Y|X!+5ue֨M\<}+#%OY3zܪq4]B*a9r ֐'fTPb 'e܋_>.{%̚|*@fjK\=,`(mlR#,Q>'nO8*wcz5lӟ:q@L km™na-Q9^+,6}7 q\}쇯v<]Bw4tpb1tKHqؑDbS-~~K]>2j: stۺb"̆YH
+s]g!#xe"4JG!v¥h'ێH]TVӻ(pQx[]\SX t)y9{-IX-A(՞4N3vG)];o)]i;;*Q-Btbw2ڍS'=B1 \SnqsIsfxHdDݲ@dM9==c5R@9Iҽ;uՌˀbA\Z^{|##uy/?=6~@_FCC>TW] YPH}i$JbYQT,1y!unI`QЀ庌$J_ T.⥻C)r$:cP簿+ xCp9r#0
+QUcԥ;ƹ?YK-W m7us!Wx~t#\zve`E>Byr ϢeJ+,jm _VO=22
+ cL"m+õ5NUcC|~\Wb\=
+U4򎃞a)ӇD'nRnSN*0PNYo|BZ3u}7I7jX)Zg =6[~)I$?˸OJgK^>d7L%Bg*k f綛`v|(W78fLӺTx2`V5'X
+Ms\Oi'f
+rSD h&I<lئtLھ_Йi3n7IMD񌊠 "rr_e}yn@A;xܔOrB D x=iR,@) \
+WoG~37OácrAMj_
+|rdN3L
+(hw85,3(xN]Q?Be!җ$C
+(q ʃR\c|hrv{~t;.ߺ*7]dÆuϹjlv;sk7OvK57/#1aj0<p2A7(iOW^\SGNy*4i?l7~dÐww޴C'ky)js/GRm`xX?.я_jaOEi>O ?QMԵtlBԬev/UueeSQ߾5S۵cyko~a[uk˦~V*u2aJ^˜?f*7@®^Tݥl^|;][_UU-x!g=M ԵcQ⠵r]P.sbo7POagSVB%J^OФ;3Bץҋ*Cdsn;O;Q-OκJm{YjHZ}FT.+|`b^PYW EVhqq5ʾIN=Ⱦ2_J^0j*0kP¹tiF`fΟ kR'a/1+l4]RI<[9q[b[mC\Tg}~U\'v
+j?/ay3v$D |erͯN>G#N+nErf$ʌbDSDر 볓xW!-BࡧY0068;aϖ#&hԛ!Շ'pR$$#17҉- Eb?#Ody@)x*HR@<(q`܃*GKI89JH%*NΩ  sBKЧa
+ В,;iioM:ʠbwAm@D6]&"UTn-)YZΦ"M\urnЌ^ژ>Lcm[We&ro4
+f+y`
+UfIٻ&>$g)?(D'8zI*63*+ٿӴ1b˽=<b0,6&C,fY,1L`=tV3@B|g{Ӳƾ\ :ηFN 9Wuxn\-S|Žq+ɧo>RL?ipC).43
+{ӟʄh2?hw)ZC6Y-w2,?T1. v&;POp*TE,'ABv Dn=j3RpF\XDRӆǫRHqHn.z
+E3tWCۤ{I<C:RrvČ-ʭUOHQTb,h}wy&Z[/_ݻAIӓe_n5e` xW%;=a_Uu"
+%G4,] ꨤ:$1cI8 f/bs2XvcugD?eu|m<bVe>T:)8 `"lII1>O 9^f7 QQiE5zyTaZ4&gUwlyGf
+->||PHŤ$ݚmYvZ5I*̭ 6E(}FݖuqOB0D8XcC4x$GXx[wl !ں'7lqC ^B2t^*-Ekg3 ]L4yBo1I
+>Gg: pZ;AN-(&},)%i?.!- F/ gܔR|R@G?u>|\!8 Kn!xG)T
+4SVw}cT"}as2@ԕ+ vg+ag]Szj`)R!z:-+FYR\$ iu36W_M
+ yo-F<}h J x^q3(
+^
+Q\S5tfꪩIgڙI';h QEPVYdDExթ:y^fOu'Pe@  L.J*+bA Pa  W ,&rUyL|`}qg%`L (xR$L$DbԒFs*+s<.䐝a,D=%Ps㸗'H֍(ZXe! -(0*
+w0
+k(ד*#bO/;%^ $z"fka{_!T[%kfK3Z$Tm||j\%&h}iI+V^{7{GvLgCIV֢o2*Ub I ["as<S=l ݭ?;~'xz<z_u0[?`X.v
+Al6>9^Y#{ΈK]
+|D=cQh?y
+q dPZt-zR/B;yS07t皉8$-*.xQ?KN('ʕBϣxb A%qxr׹‚ EARY 
+& ܭʝNNt}h!^VPw
+7(>rі+AvZ5w`cV {˨ s(P9rǛb|e#n+QWl+ZOKћˈP۩byy/*5z0&J>čPu-,ZIc4n6'K{\r a%qBIZɋN\)Nw!እb WL/+mUSgX:h?a&6JC0xp2V'27}S7
+LFzʖ|Luv*n4uoTCtr!j.( 3J@m?H Of2#<7c(*9qtk E~( !"X|*m'Jqb`I#_^}yPZ#WٌՍ^Sdl&v+=k n[h,whw5=ӘpF<5{[5uaɝ@Eɐ3Iˆ໣_دLo?&평7)(쇞OSiµ&TƧ1[t/S :gu'!%f+ OUqԀs7}WpN+[E5dVM5-N,Wv8q# haT( jeO~&_z&~Q"̛9L&UWuM_;EY}?H+ kc06`aI&!M !%IڇJZUCէvj4(3L$LeBeX `}6}~tswV*7^_^< ]䗈%nm0xa0/oTY)ʼnn9erer>CQ!Pn˴`>?n*k2X.l3o\S*gw:JurJ e2~
+9mʵsğqí v
+hd7Omj7e"T1MZ 7.LBAr*-S֋NُKIJߍN<u%.
+bCm w8sǒ̿. R`/>aoV}>Ae:(ޙWdl<a)̺kWݭhMBFL|g}2Ӡ˒L+8ғ
+#ZԷ y(>vJ brzLN$</-1ebɖg:iuV?yol7w=1<
+pי#Y.=f{ .
+{q!0b0炦.&W.3l'a=Noߓ>3Xl %G [n
+@mHJڋt}3[52FAhTJ!#06T7
+J4'
+qtHyZ,;lZP9Ѐl"xl .gq#f0ll̜'Im#RDV5H%Z#UaQ儵j-Q%#l; Ќ f=!>mA!RAa?`.+ l$I]ZrhIƸ{l" #vrlD=RNԕ<<&ᰩ#4s`
+MRI*'qP$
+խDw7{Z4MR;h#OTmi9!eݽLTRe
+924N
+v'ǝWUT9鳷<w)vjPp ]~|(uu+E 2Eߒpf|4K::M<4hUΖnL'#1;c'#mANm`.XS
+JNzP+js%;0 /9CjAS.e)8h0Fs|hxhxbNj]E&2N=QDJgUKJY*+KhlN-Idl
+Vl V)"폜3~~~ r
+S(=ħ9^-'Ynͪt^SGaS㱛A9=nRl3n:Ex vt{";H1PGVozd1IS|1*=٬F"Ց"ւTGf w!8UC(q([yLVk5Jr~a\u6MW8d ݰEVlA
+`Q:3b Dn4
+fW]hRfn't>0"&<kRtI#y14=D%<NBMn:t"C&x@fxl(w
+`9{]vװ_W+s"YS׻;lɜL^ * rNkMrHxcḺĔ|Vۗ|~NVPZj*~yz犸gqn0K?Jo^TF~FqJ8_Kղ?;77_˿ym?.s?+jx;ѫ_\U-"Wi\$FyNm%\V"ZY- V=U9vrYrE^"ǡC);d&F,bC'!PJ+D<X/z`ZD2br$ af`Qr!2&bՃP/'FAHPAeL{@zשIʹuM!}^/vVC,YOh 7L O8P3@#(
+`&ä{8<“T؏08)\ƘJ]76\ِJZ ;6]hFA&vQLbxLa@LIL-A:yW6N>B?evbq ?JxcĠDD4lM:tm}hg:ӝl;l6$C`>b<
+nlk$:$ǵj)[
+ZsjLhchd8 ¨LyXarhc -r(tj(lZGnQzNy1#,-3A<HJ(Qv%61
+m^)uZ*\T*3R媬bI^\ Tǩ.$b<ɪ
+yV]gi_mC0NC&f!ʧ,FWr/7'zU=M^e`F4Z(Fs^ F0;.o^)V:QR沼ZZ%mT,z)r(HԖMCKOǂ)#~U'=PEbqij|J-p`8fjہ|f7=Z R (͕_=nPY6쏢y¯w;#y_7˯җ\0 tOho6"whP >. ~qe/\Pk1|f0"Υ)eUgJS۸6'{=eAGynDH%0͒AW;;Zg~#I:In>z
+0 _e\
+X3io(ޛ )DK?peIyCGcGUm#.+cj'жyUAfnn )bIwx.r{ [2;1[fތ#cDp!8 c
+Hm^n=E`=w`Ru"&vg`YX9TDmXbgxs=kxz%dB4Ď
+fyh
+8NA.#8cAtIUwTHB8+A{
+؜H;hCҖ uK`~~O«Eliwv]NBG^WTKOd)(WJK%e7L:_*QTRǕ(yD@V1Ɵ*- Y
+G.QMi Jȵ e|5(W'ԨRCiO k͇b1R!F*`LR[GfUb洌9HL9ċF£ s˹ׅlDsvD
+i9T@X*K̔TZ.4G,Xg 䟙ٗԖ# |RS]%eg?,wP
+&
+P,
+1!hi"QǑ%FW3jI 5
+B(C|71ص}h]_|NķLįJ,kt!5*O~r2-tq+@OQ/ Gqd8L./8' ؞os3+1zNA~XT2C?ա~͛XZvIyVh:f;JؓT+z"<^{B2+]۸fޗ.ǿoK(zӼF|?\srV8#}(U"CAgL>iq:;*% 3EG<sYGc(РML^/i8(4|W:3vn0^}e̍𖩹fQwM>Kkڛĥ8FNHŸ=äέ{ƔoHh`]Hi\{^BjB?NR\YEkMxk/~s-J-Juo:Edz߲/.6r[OU,<e?DT'5F
+wrr$rH|z_Xd//~",؄˅ E%AB0dQh2Ԉ;9˓ ;x<7Vrga`O CH%89赲WS֦"3^d.J2Oq%;IJavV.zP8R[v0@<{A7#*7o+q9 u;{9C5 #Qk}0ZjI *D(D5x
+N Pf`@T|q2= q`#(:eP/U`7`F"J+!TМ[@U [vqj9ۉDd &WMqn|(r;KS &WNR(*uy9@s"Iq
+>5a9"]ښIVzL /8Z"ƪ,'^% 34
+Qp:| R "eYBFYD<^D3\غ@ĉqI AnRg XL
+ccX5 ӎL,:ȱَ1x:dҞxρ<@AJe'"K?P쇞q#I.0h+-E[ r\ 뷖:{AyvN
+gDl/S/&ڍx:%ѓ?KvL۶mN%8!`lԆ؅Dm{)fgND_\?K܁M,Aйilȝӗmel!RaOijQLe.mzOZ+>@x#ZZ{7!y!$g
+󧞹&لPq4ᄼ;,(V`9GTXܽIh :Y4ZǝVb<SO}gPn Qt xX'1ا@m+;bNZ5'AFqW19-Ty+:IKHOFN𰑾lC2A[ڟg箙Nڏt$14n
+˦]|*,݅}$*"&2%*ÿ*xD좬We}Jc߳v23/)UOF(1F,1gg~ǞW+o7߰/oq+/&>i-wmoB~!A,=EoI+as;]]fa宆׿^'IE옼||;FW}E0N>vDȌwZptg!Fht;,ioe;wM@U`/t^
+
+j[rǸe *ƕ Bä 
+kl ]EzVu|ܨ2Mzݽ!2 _u ,E
+!fix~#UGVP:`|j4G#o[sAcF.Hj7JgNSeI1(a|66J (liRK3JNeJB`4҈(8fH*Y;IEe^:i.|Oi. E*y O7*1
+m@Փ.ϨP˞K~G, Θs::"`GtZVcMS&jfڏ 睜|:3;m||LZ 򔭘RuHX$dS(=M<xp,W*ȠMAr䭸)+LӀgN= ?9}7(O%30D P<ۼ5;W‰-< e(Q%LP
+^%wzA{6
+7
+}qTn:/*cw6cϊɬWWʮ1> pmN49{R>/l\v+jGx$,s.)Wc $m<Gւ>'eFK rnlopRmł*肦3#3WǀrmHKӪδ*cH{i3]hN3<dVP͔Ϩn ys?򶊏h- nd:M1tYnH曗WD\4fN5"BJ\[2Tmb]"k?:[#H>YM2$?y1F>fn"ox \w3muDhzỻG<́P}<|l*YY,-pl
+\rmy~.34߇:L
+^4 y(zMJxy? <.-qzr<6X@GNʬCCؼޑ&@aPxdGkҭ[ge%07=̭༃N9v0w+嵙ڦv@n@.62
+
+ 
+
+!
+"1
+3:8BԼ)@л6>>[OҬ;Qӧ,RĮB]ɪ/M;;>!0$+)
+)2=DNުJKE$#)
+7@9 4
+3$0 0
+" )*--1 -- /
+..3 ,./1/// + /0$,)0 85& /
+.) )$-(!,(&0-9
+2-+/21*")'' 12/0/-+,$'.0:6BL
+">7A>SXާ#Zި#V Y߭&Uܲ*Qٸ)G80' !    
+#'*'
+ D'WIyyN4Dφ2 %al ގcJ²bfn!<|I;E}^`rߒ}>JX<#G6fG/3æ kĵ^p}PhH*K$<CE,JP SsQj#7< 8tHW/!ĭ_ug"/M7tQ 6X*Dl:bDA0%
+JOWC ՙفk\xt %U:X>䗧/v|yޥW^7khxHl6om~h|\kze|5>8.7K]6Xͥgg5jQk/OV.s<+gz[= .*t:-v
+(EtcaAt
+PfGZ`2x7ws:xԩ Uf?g{MykS^wيu؊!j耙\cy6lތ-靛ז kF`@]^Sυ$hA+T.^:Mϒ$g
+oSss4`8XН~C8[=ˣ__ZJЫ15Um?aܥ*7H>Hw5LWq^/<>cHӪ 92N H;2@o!t&}GܝX;GAs9Ų}ZQڛ\tf$fl d"^Z"tfXrςXG aw((lOvjzml84Gځc%U.)_O/Rc~Ys+zQy qʥK~@jm/:{KL߭+{d_$kF#rz ,@Vo 50Ơ
+O I,yOx~P=p9`KNG!+ Nw}&1}*rWu§w=آ[nXGEZbgLaMw;{i^i&ݔu&WrQU{7ڲ0mh'|v4nF 7j/>e2񵊙;Nzfo_}1SX?~Rl1/joG~ڊֈľ?6=cL/'zAɒ^%aSݣw_~"MsS{'bL1~{ wH@ >D
+wcd&*j^<FK΢%H DCD`c]e;(Bx(eɡDQ?UP˧! d A}λD }r w[ l-@J{Usf "hv Z9W )6p]~ّa{!x> ˷¼:
+J~cB{-K<{d_BRutlxpz4,W;!$.c¨"M?S5Naq9~91OTdؚ 3!WZP֍lTBCWKR(f=l[JƆ$OyyIٛǩ^|Q1BLk-8[OwS\bD44,^7xI2zpuPmay mU^a{@&+Za\ӤiǗ SbArPtl0E
+74A?Fݨ;LN5/,&< ^m҄qȕ4mɩPb۠*`sє;lixJsEkaa.qzM
+>9
+I_spvŕKw=d4|R]?pYJȎ:pՌ)cК6xy|‚9sIn'`X{u"s;u†-kġ?vǏByt.möTnҚ*a՗)EΚ1`=ң2bLH2L.IYת%Y؞`Ѣ4Zү>Rܶ1OC#0$$N:,-<#JCM;ظ8<Kڹ17*82
+
+$&
+)1
+,,'!#  !
+J R QJ
+C
+B =>6D92;
+9GIGH GEJON J IKNHL
+HJ MMB<
+=A 
+;
+G& $"-#= 3&( !(*%$&'.)
+0,+,yPǹoD#x"H++ޢɶdt&tݝtmgvN\#I%B8D<:)\8Uy_Rjx {Kߗ]IXJHv9 2kG2]J|.FMÒVUrmJ5(Үs9|#f[nNLMG[M45b
+a-Ƹhfy}7dڋ;uXâlg0rŃ,IZ\=.lZ:$G CAoOk{0/ I.50 aRp&Nu[ecAvs=uT;)?DW e1\s|1ol)#s6R8kUrIJ 3QXYV%-! dqUHY"=͘ۮ*R*FJ][d̈+نŔuc|,1+劒urimFOL^"35X{iMkC ^jֹɊT_S.*'Eś{.«oh+y?UKmWkYbI@5ȵ<:@ZV,~Q@ь8k/s>ja{l{RnxAH?')KkV9f=uRVئPY)hInw?f{9ɛ*ߜ7wYwi>u7N~{ уkŚQ:WlY%f*|8`q4B**hF
+oX~=s{g^%+u?^|d~vrw3~#Kܜwkקo|v_}:u;Swmğ7=E<YC)gErʠrz%ĔjjA]ӸC%P>lUi+ˏ9T ()gK.ͱVDIZevz7*wnRy>=M!f\){B؝@$)?~X:?_QT9 "&YkOi,<;˒]-M\S[;U/M|Ɉ[;gVLI:ʰ@2#MS%
+71$(`8LZgfx
+ѼOٞ9dpV? A(M0 D#Inr}jXOYt8:lIZTΟ
+<NtP1[1[6qTjb5DM+r
+r(
+L./<ԕ`)Eo:F<cier1a`a Բ3- 2|[A*l<D; HG
+aI2홇>ܷ3T-A1iT4G,ߙ]Ke&o8. J?2 (.Q+eObʔ5!%'DMqS˿Q:ܐH)VHH,qX,Lt/tY|9^9bqYΜri#T<qu|98[Ӆ*o+۰c@_S^46ohムT CܖJCf#ͽ
+v&o犇 4'&s+b~|Gb)DrZ]) [{}#}Oό\ 0C2Ͽ-y眳z,;ɹTrWݗJNY~oltur6㚯?>m6\`B74ѬͦY{|6e:}y:(/"DHwgyx DHx Qo$d*& N$vP`~"t~h'hQlz6Y $ҥJѢ@bHiA"x IX6m&xu9G,zo.0 眂D:(jz q** Үy4k#na0mX
+Wc\ _\ɿ{EQ Th*`)nzX,SŞ|{NCiH,f'>Up-\q +,糒o/]a#SΗYv՝?Բ=ubvcŕswUd<ʬn(~T$hLb{0/5ѝL6 w0KV,XS9MEݻS<vXpV#`|Q8<#w[j+B@D2 D<gğG%F Y7:<2;OX)R\Xm5bZ -Ov*)@f s$~ee-:a!1k1\į5&b)+_eRZ}X΍Vڦӣ Hw:B=ghε<F.X7~3׼- ᧵K744wީ!M86 %q{٤WȥL :@AFoĖ mp,xunBW쾀7ڃ7.:¥G{\*G[nS?&Wf腹ETЬ!4P6
+[ (`f<\i!@qP=
+Y&
+Gct=wCV2l`-w`5ş0wҡ]yh>D1b!Zͅ}ol<v9<n=p4G#cP ][@9xiT8^`|;`j/7>@26Q'tuatu"-wy6#- P_ptyT8
+y;?=χ{}I8io݈9ak\hE~׆>n7x {ZP6B`A6v_-:H]#o-AQ.QLt
+xɬPj$ta@6OٯJF9hTEVE^Z)5 ۲wxnjzsQвMnН#YaD>Dab5 )(9l%%YLDV̂N
+C>U;H$AMu'5p"‡y.+0%ۮmCj*SP]\Z1SԒ韀\ 4lw`3 bKrg0<XoJª? -6vWLYUƶ]jyG~3=J
+m})|uL[$JխrqJ])z.SK5=LjuΑIF-&uI2ϊ>4+GޔU{s&~ p8JmN#dO3V|Fzo&7&*jdJkzON92-r5J9f _p2]H1n-:)5Ϙ?߫,jλ$|QtsFy(|Tua<7Ϙg~4w~iÏ;/\}P(xL*|}p vC5-6\x٫}ߞDȬghFGyȁ407ƽqF Q懐|hz|--T. \cUTFF 
+Y@m鼬` (E+~qHG#:LQK+.O\0E9aeJ:est0U5l(/EB N !|"@nz4yMLtꛀ7&Ԁ
+p 4eC jSSetu
+a
+&q8rIVy@{+yD~;+1yOQyKqyWiP?BKK|
+dG wEwN MOKxW;dWV8sFV
+ynRd̴<̛<tb3cTeE,Dz ]T@+WsXiq%Vg# 51#SV1PyO wr$DpC՗ e]6R/?pYqqYyy6"5oAp}yѵW {۳HsG??ȕᚐߜg;?yK_5ѿW}"`@ދ?JA?'uBzś;-.H>T`eKᱭs5O]ܩMx`۷ZKxq8i)%/"!/S!
+$0C40"~ZjtKePʮFi.B^IM&ҎFv3ëļ
+/Lh:'Q{rrͦc^RC|Q|Y~үϫ/1EAc ײRtme*8|̹G Nݕo=KܔP``ǖSOC݆ TY}z${m_=JVjZ
+f)NEXaPfI5͙凬C+wxzPLSŇ'l^'t{k$sNDH$[͟ έ2*ub!&
+ {Kg;+qFA+"|B>$K߳ j>]4_T`nj-o ` sMmAVc~^TU+W[liw+{oz7/Ńꡪ^V_-FIيPZd6)z6n.v~Ӷ0Ԡڧw,Nu+̭;օ1X>swjb5Lnj[Ny[OEgg>7ks?+-Jշwt{Ou04*[[qXJ< =9rl;q씸Rfh3 מ}1$|yBt$O1<sF>/$ۣBiFfotN
+7&t |-RH^cGEbvl<C&2X k ~QZ p ;lim3󚑷Jl4ޮ# )ܨRsTI)ڱ "N";fc$F0
+pb_}Ӊ0 9o_s$zq#یe
+d|{ՔSW/)?0?rR~_}!k+L9F*`48B>g/8اֶ24JF. r e4xlpĄ ު.3oiY&r  'by\Q[ 6es^XeU^/S5g r;FEd/~ vaz륙T]6}WSՂw~#cpޝiQSO Q,yL[
+4 $l̿0O1c&vGvT4NsNi ^u)ڠsv'n.XasdwR,.*uDqLp*Mϥ?o^B_I|JYe{qd
+"rq(14GBr"t)..fv:ռmYm{a/5?J ӉO2S>}~Oz8 i-Vˎpzؤ91A7YAv$ 䍧zd@$8PuD' ͡,yXT'Š;= g0p,PuHL2B-gގdLrSj5U]eSTPxWÏ*
+=>|eP.+}n|*po@'RHX"T!ED ʠ6l!6{%\ w
+ƈ41eLJ]$9ֿyȷy(a$"Xr3ע/ѢQ\1mV`9lc @
+-&I112188WI Јa
+ OsG:hŕ% nx_#jUpA yOXm8%#Bٕ٥aAQg]0F:GS̪ZULOu~mVOYqՑy?L'Y,m6hUغ^ S=lV0qSC&7 ݰEuk,`N9
+r6qsT(ςԩ`3 @UP䭳:%Tc#:SMtPNs74ƶx ?
+ +[=Plep6NV55hAT6X^UsωEw)cwH釘c\)z!]\me mCNIʢd ԍUZ#  [KXǑN `t|
+3  z6H%"]^-{}oV֏M:ud̫1mG/fo6ZGM[?}xzI\nܭ,nryp_^X4#!R.B{Eowv@jvs`chn·mȎ]ќw1ť:l']Yw3{}JyѓZ3Y~Qd{Sr`E@
+~`&"VKҺl>ד{t>d·{3qqy R%1wNjgLqBqN2 An i ]Q)u|(m1oԴߵUt%!+Hqa=<Nz8HOP,j^I~~tYD}i9ZFdΝSlN-&-WѶ4} t~fGoH|7KK/ ʰ(Q*ikRUQ9.y^h4. `.o[W䗽}oVc|kfӫ,
+۬1 f5L fYM&jC:UJmQժtN 쁄0b0x_+^q>]O眇o}TamP=NVNW}|VDp5c~lT7Ko\$ D膨,H,-<XP{؋R/x_~rx~z$OOQS|LyWx%g3^㮕g
+Fi S w&p} ĸp =SPzTK A};e33tQziJc'ԙ;8=f
+,}I 'Z8lsh)cb$dN BYN[Q@7yp.
+y80 A[4!7~7)hQ&UM'؈˥ )q?Cg(• YxAy
+{Ϗve2}[<|-HL1n"&sf$VӠL RU>S$1ar>h*L;`Ob!;mn|9h ;u[Spw},LLntj^%i*z6'sT uٲXJH`v: dvZKMUtGm~iQlTW[~p;StOtoAy"Q|堜\mX-+DXU%9l6y ,ɓN#ʝУF>﵅s正R 64eGp>03@*cGz\Ɍ4 HyxSഡ 2I KLb؆(:0%JR_KXm]BŞ`N b*ϣwoAK^ nO-\'8),orᕜΘ֚zv#.ew|nw!ϻ
+V=nJ }O,fgl8PPYV#У,Ndƙ*9fOd1U :K2 f4<!{v꒯zm :@(Voga8x4|~MG'C3!atAdj4m4
+ &y8PedPkfU ǢbLz#,~,B<3*XOgT6uZ Uڴ/[i8X@uKiK챃oX޾{|0woT5c]gQRTv0\kQ*Zۿ`ji
+A+(!&qcCL>agtNgL;ivsyE7cG""r)rr%
+(hoo =\M`@q
+?v6j!r
+mOi۳Aǚ)4qpbX=ֳՠҵSּ[&eЕAqIRTL%=k=aܦJ~P/n{ cR Ór_YNh% ? XuUSi}ow5&sP֞ץ(ɥq>TZ }׿$ɋÿV>_.~3G7t[^geÍßbRf 9j@˹a"uA
+w""qlI$i) HS
+Y
+^9,% cĈ=C'aHOCVluHmݠ.u/pPAyP@?㋜ɺBmȉFھ0hn"ĥʈ
+w%ȟ,F 00
+vm.Z| dD'N0W. Qx^#=a ԗL 6`3TA<+#g`,sLj
+?'q&? օm;&y` "UVu.w$6
+"3rppqT+逽CڰL^y^co,?]D^.T\\| ltD̟4qYIm#}RȂjdeX4bbQ̨:3?ːY%Q^k+eD` -'ZuI-hSn9QC9G:\SQ_d͵lFeZmZ-jvC;n-;J~nFto%oPO^nlӮֵWx8_g_Ƙ q)ӿh=asnqXA/4[CIgGgZ#u͟u@ML2,.ƮS|axtS Z[F#y-ZVиN=ީ(Zπ4
+ߙ>/XANusB\k;Svd%Osx?JFAIN
+NRXgAi f#xà"F@7* }ҧ<ti촳n7Mjc"x_ʍr@T4X7="O ҉Z|p$|\#1E{s}1ػ
+*yun|T84tT08Ç| sNS9|0.9
+rKKrv&y۞26 iDu@9P#')tsefwG.'+]մ4F5VzebA՟rm[Z-ZvW͇1oWjeӅBpY>bM_"!װko"`{XKbGxGsz=8tILxȰN:.48_"[UCWLʥ%Df~(YS4XR:7Ekz>+ZRA%)-YV̊4Um{O9J %uH/YI
+W kL![at)K}unňS9\ةfhķϐLZ&WQohjq*yy[jX%YY_h@MFqR^5H
+Y 6QsHFm8:D˚"fnp7>r,ѼO@$;@o̲ou}ϴeq_+Ynnڲ7dOHea ޮyAjV?FV-zc$>hK8S
+ڶ]Gבhj%ضpq&o:2;rt kN
+RS۹@`/=vΡDPfPFq϶K5BInvzK[2>OŰmK]dzV% F+'ځsw C Վc- JvYYv߁'QiP$.<;7<Y]wÚ5?w~&p²ՙ4#6E\D[!$2eu}s]ś&dgԩ( ."^L}fK\zסPC)FJnkV
+xgj۽mBrqt'1zT~q
+ir{y<d޻FOe'%Sb(_ {ԡ'JLڤd}NTNak2Yr \_SWs(U,\ovĠ E6AvrDPinǾ33t7j+
+Q}=V\ .DlI|fZx W8)[1Ԓ|DXs y f; >dRħ=]܂aߵfZvM;}k!>)?/_Od7ħ_Κ dR.-D1P S50}/
+s,t>'<VZ8$pLS6뜭, z<bue.?1P!s{*dPb
+ٛ6s><;Ε;ލwz'ގgvWt c{M'2UI-MzϘҖSmcad\0"7=DyTWٲyв񂠈Q 
+/D!#I$^//pК(ݚ)8k(+|!X(To/dg3YSsvޓCs/~a\]%}}Ofmʈm& Ԕ6z*_+xyr jWp=ZM>hL$^glN@8#6DZjsB3Vܵ;PԵއfQ=<-
+B5
+$>++Wcbʎg][dqDQH"1U&'ә`*[3[JӷG7d
+)Q[@!1}Y~e:%{-طOy7;qGk[ r!킰,"% oלÍ.8!C%Ls^qP^'|vÊT~VCʫؿnK|f6c"6|Z^͇~rK`MB\+*ҀdEgiv;nUWfzOZS#E- ce"xePM٫xZ Ѓ*;qU
+خ\X6'p@wLQ,3>wB eR@!rm$,LN<_[^<+K5z_;wg'/$>
+yNW\ゔʣ0&wuU֦5
+kk92v&)PDՕҕY,_бN#8J0+
+c; +欙 U[m0Fr.#M[bBEV7('3!bB^#M-QlrZb#oV"ŗJcyiʥ;ҦI,?'Is 9c3C4ˋb} *P-!e^lf5ؒ*ȡr#‡3e-C5
+CdVc !#!AlW
+,:Phq&jkԀhqFě7ABQ6EDl2V9.;ǩ8Ib`@t"
+
+ehvݓg]ͩS[tZ/ÚpQN.\wa~LNԉ ٺrcy_X觙cܚô#ѯ)eYZYbbLq?K3fj#^J):'*'fp96k%Z XN'wP
+dFtQPP-x >V 1@>i& 1PYz`F|K&J ZBMUAEиbuR s'_S}2__pqUs*ܤJ7{OP0)Q, TKjhfqZ,_",/]~"0/- Le,4_T NY
++\HWg酡I ( K r4RRhM:W"$3fǶn۰> )n
+w
+WB14&n>4!\/01aE;eJh(5Q:"ՑQzzxBR{&lD"}/C *!PJDC#rpgDд@ a$^f֢UH WET$Wz)HIaj 6`} =6!"sPׄŽd$/_C ?_]U+ngϫ+|;%O'G+[9?=OxwuzeXZNZϤtyOf<HIl|8V4]uSWˏ;mL縊}@gB.A.Nx-%0rg&xg> Eds4 ՛Uk<u|VK%:2ʹŻUĊH(
+(U488('eD 2x_N4B6\lx>0R& 5qۏJᨦ4楲eM3gqS> ÇKFS莊Im0F48&,Jtg^Hyvjn?i~[Bgߏ};y^wsZ{O1=_9װ%bj̼)qIO~DǾwf¥LqIy+,]~z@ydY`S"]s
+b/~~B9H=x۵g_GNQެd8Iybrm8+P
+ z-r|%J DD]]HJ u^ZBO=QuoBN' }HLk|R
+DwwJ^TC*0nꊟb^<l*oh ɕ
+wҚ0G& qyp_whf7 _@ud5KI8ȹQՑh]ƥ[!m'Fѳcxwd4l!vYҸ)L 3Gf;s8doq:zݝq-vaj 9]i>-4?/NI#`rm<cfV4nbֈP,o5spF7 ei/S-<Ƨ q_gE|_5ٲ}m޼{[YrߩtvmʂVk_ ꇞQ{%߯[wە\mmvcm׏m75V8"_|pns4ڶ& 2.B< Ύ!Y­H'䶑\r;TG@)C]10XIY|͂qV27Os
+3kfCvD2k@+
+kX $nSCQ&"\
+gqvub]5:[l*8/!
+* AP ~ `6 [4ĸ4[ƛcc.1/WB\p5z?KcQ.GDbeKxsxO|<؛PBH$
+pCIK5'_z¿/^#{;/bO~ׇϺU}ퟩw_irϻ/>Q;i^Gyzȥt^ ^0
+ TNL
+e"be)X:m8
+#8:(JE"W=U1Ʊ ݢž33O}z-%{5f<Щ?yAy<'O?zNY6;{:rٳrZ&&&;Nݕ^+m엿&e'"i'ؿ9rbz31æ3-2yĥ>j;"ȹ;4S^6m?>ypxjޗI+7`RD~?xϙ/Ou1}?r;NY>_]7£-ξw!;ӣpSg\-}k 1V;V.ܓV'gc_&?jtpfk;K_+O^{0\.βl6R6ѥRa\PT1ѭ Xj=$_1
+J
+y(ke=uZBQ6)~sfMe"\{=xci!\~iQC$n^uqA-CRPRq&"JYV}Mv];^+Y_mHNeC
+j-* Qo\W'y"5]jj%Bɔw 6$nha>Gn N2DXVƌ׵qJLX|"T2_@xӰŠ:.thA
+8%c %I)YUF&%Ռ^ iɣi|<Sbֵ#L$"QGАDl䨨*iIZj `H4az؆:@#F=/ox`8I Qj= ;z'3y"]cL#<m<
+P:G>g:4uC/?;q6{#6aS,4W}_БE`;mbhhWV^_gw)ogq U a1-0۰]g`0EG%cٳEdt~ ي!ĖP#Lӕ`rx)k=rO8JAPHLaŔ!ywaݚ`s]K0vmn \믚a6v:PpED;&_&{dZd+4xllTJxFuskOv
+;_2f7,Q
+7?m82kMӡuHıIE]m)Nd۫؛{٢[59|Ju$sͱIn-b B
+\`]{u̹{3Y{mGϜd@+gb/\'ߙ~|E}T^^7sۏĿj{\OKL֧jq}eSӨ#:Q{nų rK]겕hoS 􊓻_'ퟵe=owwy;G_[~{?=U&Zy#'6_{& U>yyeŗw?Xy1ǯzp䟷N#!{ZĕGzk]?3XEVhSw2PCF[苡%j=vI/>0o}o|8dk X&MG߅bpW+GKYcf{⺐VC|'TYs\нy@Y 縚2NsĘ@¢ӷaFw k4-&ZFErD]'[aLڬeնɾbӆ<Z9֪iweR Q^ݧ*Du*JIMgtxѣiL1B{ U5|x~8帬mbR3)fDaKmcTiGwRY"2e۸r0,61bTqm1m^%bT_@ۖ1m2,í%ђWm(;֯^ kD?>w#|Q9늢 w@Nj0yrR!.yeP5J(9x
+j *y"wM!tF!pj)<s
+#m =h) ȇLޤcGʐRF4I Ƈ 0w9G{ <FYtӋƀɪeW }W)N7,E' XTc9&z`xa K9۱xy䒛JlH4+x
+[:Cbs'HvA]g:Xt5-Ji`=̡}[ĉ5'("a%v ˰>%Wnh%WD[o)O>px/R\T5tw{PACZi˰ NO{P~#= Nlxhy6字]\6ky.;qΉW[MDf< >$2JtBLS7
+NDC{.̲Ւ-7J%,48(H>B!
+r-Be.j7&Yk=QŻSf{9ۘӂz#m3_vǫK<=AV} ?6Xb>QIٻ{P9 
+A I43
+s%zL~νM*Emm
+ڨ2
+ɠSj[|ґ/achJ)8NkllR
+iJY+*
+G0/80CfSQy@/CNA1dLy3`OF)Ua*-#7A8 t?.\AV&XTANhI' !wI5C.T'z@1+;0$4MSAG:r==,YŎɆU*Y0rL"IM]/0,cw.Pi jMS|NJ0~QUYwORdeAنaL2<h:!\vBP6m ZDX؄9U 5(;bbV]
+-]\CkF3W8!\ ;* ́A ]pBu@P0,TY 4Gsj+4((С97%3UҰt_1Ni_6 @IAX a@xJ&CB tΤ.U1ؔi]:rpH*JޭkC"WOcl*yzAB uA 7ݩ3(_dG ~~v&PbF
+ o_osg
+ɨ1֪anpy||k'bVm5~! W:3ޓyV& ;g\opq}*gW*n$'c\8c4(z_q!m
+EOG&UI=3vTvxf&}%5~V?U
+Ƴ`x*Oݚ7/=Q?ž-_ϧq 6P;8i>c gghEWhG*OMV8ΥqF;jԨ@+׶~A/90 ltՅ4fљ5<1}9D+oDǴ5+G"5-q5Q{){b?[԰"Pxؤm
+̛ef׼ucylpL?#Tq9΃-[3/f,m/Έc|."sh}
+̿ψEpyF%ghQ[yҙG
+ÙN
+;n !)ƽ^J>˵?—O/׏8KjŹ0c.pđ}J]9@m\:.H+ܶ]\[].Y9r
+Rr䗗Tjr\/-Nc\\Iu^V]]S/4ŜuE
+k);o}| ){"@Rm6:]ZY^5wnOe*$AԮ}Gy^-{}OB+EVi=JLu:AVB׏Y-뙍[:iWqApu[w.nx4$ݖW i#nVAp޲ZTש~p=BZըߴn-('+kt*EQzpo"or+fu u1A$Q,o$@Q \<ۄ []
+d7x!IB,IXI,4wW`!vЄ?hk3m#Ϧ`3)3&G&0نon1QDmRxWZ<; J-kWX-dbTa=q\Re!O\|t(@;tA~*$3@#S:䇉\1l&nC*n:hkh|8搒!6%m"`@2jZ]gh.F
+ cLX0~/}k$\g=dW[tF]kR^R^04;==Q|H44`067 \fV{JX.{NrHh(p1~kwTV}d uDX].:Qd"q`!&̬224զ+Q P_]B>kO,x*seYQAbFȃĈE`3Hجv/.!ȳXj1d<#nKEyI^Ux
+ǜ߲6TTTQ~H;"REgɃXV+Hj"-?%Îy,m:t[r-MHk)(4(U^ #%Դ._uMnU*TEm&Ԭ+~A_C 7c_%~xk}&ٿow^tY-:s'ޚ>LU4LA*F#_AXE局5qem
+~##ŀ_CJz'<a=>iu-wtaDgɒDf.Y \fq,܅D!-yxFHYgAӲJJ|ˇ
+a}Κ'*w˾ nC{{<BE
+-ߖs5|e"D{<\ސG/koSB໓ o?v;׺kt!}jnS{Εo۽{6 :Q1DY1ܶstnYv{͛@Ѕ?1Yqs:rہv(X 5DVFDr+s#"F0osƔ)=L#fj;εf_ÜVq _BA0^,4$6cJ9끕h6{(c9Ծ}M5떪X`|)sQ]"SvY+$[kfJn=Lȯ@`%}Ht e{@f/X0"DzF7jѬ5;.KFWq(@Z{`6C"daLc ґ8HXq9^cI}
+O|QeS=6$EBbmod'>o \)<8BGJTܙc0n>҂5v+tTס6 Qj˜@Rdky8Mf(|1%i !M"w2QxӼoZ|+g ܲ[퍄9gK/9텮CQ[HK S4;ф3&aN ̉3h7&.IƱ+ ed@NDJ$Y&jgW>f%Y5Ytwz,6@UP|yy9`Cd%g.w9KijZIWxN?Zt;м:x0)BE
+4* )}X$>r#QiC4E FQ CPDIg&5VljǠؘN%~r2&مrȆ\EGSÎhKeǰYa3.p#I(ڐL@jMe@@qDFK9b6*ЀWh]`KAiu$7ZXJP2(Hٌ>^6b"6Oly;#A&"eOX ((٬ڧR8U1?1UE^Zר^ع$.6m񿵿}k9pa<Iob'F~F^KzK}yjf/ UTi竨wn
+KXA-cĬEs
+ѵp֘9ԉf 5L&d q^$
+2Zs }FhAƆH R FH25QD-H1AE󑮠:UM6ؽJeǗ[О6!UPiA A4tʘI4F`%%ڡ%? *CtK|Dc 8}I$ьN9Ǡi E v(EǓZg%gM'_)F ~TʺhSDa;drZhs)u>-HOh) C=tP1Ȍ MklЈNxB݀R'4^6t"hbXecàJV#F]Jޮ%Y@pP qS,:`<b)g1V d2hDfAh`%!7Gtź9s+@s+vKob[
+vK3E6AMӜ95)Z*"h|k&mAn],NvF-*; ݻ0\\@lc#=g~)JmuHZ'ۃhҜ|tc а>ߍ0Jk&tErz0QU^PiFa `/ =Kneڲ~'Dz`wȢ& D{2M:Aтfl #VI9bePoh4 RrQŃ+Hloؔ=šcIsSلF4tVdDĤ) ˤ7o(ٝhVn%ewMzÒEb H=Np7Q# 5"`A8(Hy
+㭝jsp=5)S$rsLRGDA @WS,;Od캱%k!wbuYvq fJq"^|.Z,g=.rb$$-'#ގ$Bˌ$UoJb-XVd 1-yT?L?[<D]co!!Lْ k9L۽YH 6T)KF
+ UFuRx%+[pfJbUg5as\$YgU | qJɝEl=>tmS8=,έ
+ڽ;;ȕ#`dkO=̵[lo$ɾHXsF27ÛZFA3*Δ|Ҫ9d{ 6/ N9EȰP4"XFK fUc#q]Qn))16]
+[$W|aScv>Ūr՘cW^B2ƴy%I3%MAX%mHXZ+-Ħ>ȷ\Cc^q]}P蚿[Xlkw6t 3%#jզPnOA٧ u\eZ΀n9=m=X7ThX厐9-/t2liBѾz$lFKase}t$_g(0fP򈔭 /˼l@p5Κ*ڜ/kBXec
+#SZvy޲PE^upP;oy] *w)l-&X+'/mY[~xS%_T{<I*imT) AW?ԩo
+UyV}QPAi>k\;[mk̢[`ja}[#cޱP;"fliwPQ5]uL eS(Aa#F#B }U^%?3|U k]f$wuVqLgR]+;65%yHޒPDwV44qT _z<Β9 T%%(F&F=Uī3ɟW@{Nxq!$z&
+C=SxP V' %\xx\ &?cj}EJьTo^7 (~_%1SOgK|o8>>ŗ7~{]^C"ݨ~A>t;:?ns {Hˇﺟ/6}ͷhƵ'Y0̿Yp{vUEt8>~02uOGoqMv;nW gL{g)EZ<OCV?n{~܍W9xF~$ Y ,&,t+#Nk"c3!{\{I{]k*َ{v4O?/x@!j<Mcn!fgOϢP8 ꓧ\z_<ht{C-W>|v8 .Fsg&K`QusGvZa@" Sqw-`>uBĦ4<͡
+gKh - So˔ o5Ƞ|\#=.:׌V] \=x}ٙeI5P; u3(N'(3lT,x瞫ڷop<WEj *4/8SWM`UoMR䯠IS5"~}bi_'a4AZ%F(ᜬGd-j8I*^?QQ8=pQtx=aë$
+AK4i. Id:mAw:,NߤHL_Ro (x[WϚ}!,oBpv/df]3+v^
+րFIነiBAR\#A/qnM Hޒ,"KF;
+66l0&1t𾾭#ӛC.RFڻ)Vz₰.gOp<VBԊPJa*Y}([-ğ>C5V;x0)c+(<Uz,i#F2IQ3?τJw:GBT`zaHD$I(V\j.rnЩ$%.;9L^Z
+'21#REvMR]H.Lhg6<#C.}VU V{Ny~maO(W'VَxyK'&iH˅[RЁ e9,ŔNNZM!QR\r-KU7is&(LK@G%q~%=⚪nƹ>P)ta&l)qiWRY]ҌCR\rRR[9Xg)y^p&b#˫)+gBjew\v+ZX6XCՐH펐W+):b BF(lېm]&~4RW ^RW T s)uWT^ʲ͌lNH[{3USNkXm/z6Z+hd~;:N,Qc͘`ZqW:ța,鬶i_PvgۉXľ1șء_W 햮kC bK /lXdx̤D P7Q6Ù'DAm0ECR3ށ&lXr5B#҂n 3#
+ͽ
+SApg(˘>xwWoQB'
+rsAA,Tl3 wH휸7Aj$Wܾ[W̙}8tdĪ#Qs: |~9<?'ړHΚAȚ߉T.Q+C|Svo#HB3nɬ >*߅~"l3~9t䵨S:޿=ةd~=5sHý D쁭7%>`rػW{*r@ rhNxś3*zFfE\Qgϟй{*t|]>c~mC˷%|ݓ'?_?s/uCVSrԾ WPȬC\m޻9rK.UÒDdmGUHfwbv+z /:X{ީ@U})[]l3}RFqg u_y{{l/c+>r;;2?7s"zl_Љ+V'$ 9,ZOl=)6=B!QxdoPB/1UelCsQW]޷qt[#GU$gΙfa4o"O\|K<AocC#E<k5>u.ç ǫ6 7=G\aD+VcmX ѰN$o=1Ad])S`uy{øf!]q:TnGKݞb-x|:'|1Nz4&4JѢ /}"~ dɚ%*P-.!I65^uk.8g B07t(68 -*1f1\5.:H)k(ܚ ,F5"di <ī`6 XXDFb!<)/H
+9cgm}Y06Ղ̘0)MU cpy5ƴ>vXVgJZ$rkijj K7B B ŲM*71L,[K $/$D]}K{$&ơMls*Yu.gݧuL2|Q~qNrxsmTe$ \qnS;Zv{ikdg$?]m1/Z=J1W&\,䭱<'2nQѱ(|
+8xWTɽ*oRguk"3bދ"sxw;3Yjp/wPMW&.I\vDɩpܥ
+m\uDŽj!U{})uCw@oĩnQ n
+昵zg,gIU Ki޵8
+XH~bHK1.OBMInԃ
+QIى ۷nЗKw%<1E]bGO=k_UFCQuȐHZuɩAXIЫ2m3nڨ
+
+.buҲ [}n*({EᑒaIQh"&Ci5 %k>e
+`f$sCZۤA]8WH\e SKy(k4-{JJP]p)o*@ф#W›f{N,y n
+[vwIo&@X
+ke4Hw3v^BuYr74?H EQ 5Lj+NT "03] q/i7.id9%P%xo03H0~?zV+EbLΘȞw$tϓfS_E/Ax}{Kx F1NwB&~[_N[ ' 1KW9a!^$ԘKp3i|mvY~
+. +9AxcLMJx7I^ >' һ_']USn!v@m?LnA/볋׼;n7XN|p˽Oq$M;wԆ{Lo
+sXs]0Zٜ^\b.nkސ,w'+9QqΓ%6S6:^cAS䧝g+T; c^'] /EǬ\
+vG=$'AJLٽNqNRe(t3 0SFZKNؚn"v2bЍ^\n7Kr<Ehs3!{b{` ŒMBԪS'ּ4C<Iyo*A M2v:. {{8nr,mxU$F~߿y+<(Vq̪?-l5ZwΉ}E-iŮK`#lٻNR\GM1uȖ:!p훈Z<vi
+ZZTmāx5l_]uP-ػDdlQYw6UoS;at ٟ"
+@.Avr
+^Ootz=ak
+p%i aHպ|`(\$Rٯ1Ͻ_mrҦ@{HkE]+ysV͓Ql6 c6It}$ҪO<pI(C1l$a/;ĉ'y"F>ьi\:6M@+NM?wk{Lξ@MN`z'c)$gjR af4̴'g1*~Wӱ$5@# !FNGqm܍*7 Ÿ͔!~uAI"5~>e2i$DՉKNڌ1fL]Iiz;$q2GAqfƙc3!4Z/'MF\|v/&Π^465Tm,4S)݈L(Ϧ<HRzOGnX"=)\Yrǧh@5܈'Us;Q(B` _ZPiP9+ 6y"JU42WK$pLلhs%2"Y %5*)rϥ
+Cd <rAr!apu@{ۧ 1;<=Wu.,&Vs-:]t-)*K}=4][_oCСu&tNxW~kٻ+l =w/"<^E SE}';tf!:C:Em>]}6mpz
+ K)7ocuR~;8{Rud*^-u&^0 :5n gh~#YXu~9 [a=ev4ZtzWԆd9aÚjO_Md׸U jtn9g{RРA5c㬾n&5']Zcyb-RJXwiPchG2+| M^[h|9}7;[q\=0TzfLܼ^IyLb~/'0'rҼ&th ń %Su}7fWlz6MfMWS]'L0:Zhi C&0
+2 Vu}g겔AP@e&ΠVU׹R#+dd'{Y/uGNHj١3>zlJt$
+eQt#rZOl@XR4f6 ?ZroLiu,-c Γ[PT5@ZH=wNt347tdJն%8xi1{$#/! Ź#BR‹J,sݾ랯f!-ܼpOr1= ~\ E O1] tX"(
+
+67+Ǥ#)_Y=0fK`WSgVqu01orFTDش }@)e1N8vc3z ]9Ϩ8S!eJyz^zҌ*:ɠvF+c Ҟ:d߯,,,A.0upVy[Z"Yq56gBBhN9J2ɡ9WhT@m66pf`6+\>nCT[û痧O8}}_>a :f[ͼO*HW.F&"NheC]OB;0*vhԀNq l\]urf3.76ʨO婾o\ůו6wO Kn}o
+>_.—6o++ Q\dNpf2ĸcXKŔ!vk~1zt̲]JH+#STO]j*';~sB(Tz hRFU{5_ѿ%PK^PNWYo{zͺ? &V28~5yjPlT7*PcW{@zIRiE#&sQ *@g
+ᡓB 4rug24'K瓍ZV5#]eZu|ER
++?܂!]1KC[=R:]J$
+cwj<?
+tL]`F!4:dӿ7WL]<</)=RCwVo2ɦ. *b#z
+} D\Fd)XUZG.fᵗqM1LL{!0~
+\ G6`<QmȱpHyf~͌_q,9U󄵎=i"C70}}|M !Y
+侇d'N$=HS46/XJYﹸbr<JN$=h蝪@eʈR&BXkAj=$H&H`
+<G3ph2 Fi'J<dEwXŧw=#%++.12v07'7&5W6x@oQH p7G g.2k&"ObhFR<.= ʩ#!?W (Ki%
+4?Q1m*<_ =15mh|
+n>ٵmﭏK1[6Il9Rux J8w@d:[Π;תu5 rνfߦѵ3x(6whd SG8qaoJ|Ɋ*h'v2.a g /z$!F]6UWΔ>ޖPby=qU_~* OUqutTl[)7}PThu3oMt捦S[ W4`茂u8e-@awBR
+Q[-X_ѭ{ A_9RK;i4_ubh`p҃T_)E}Pt͠kb]oKetL 5ݠWspf+@)dSjXgaf#LƲ0\/f6$!XmqGa?8^ټ оʼnS5e5T@{ut{H?_6l_2τ&V[7O}t~D)0SI
+詇ǴbX
+azv<iO(hLh!$cjC|#$s;-Aoap\^@s5a|ޟJ,i]:b< _gSHjb/&Z [3d,#k;AðQ_X;DLVӞez)@=(B
+2$z7S2(<} IC, 4+KtPP9"2`4.a OJL)fbl1:[U4*Y0,4ɕ1>.! Jr@
+BcRc*vȐ"qCd)ĩ21%]2n1 3aP!!?&hEhEaKwXxIU0r:"*[[_?Z{Nk>ZțUt˼TX\):'/͗WpxX't[J^>|yHI/n5|R3qoM(k86>0Et*ۿPOY4jVa&ZNq +ߎREK/l}So \O=@#@``=o`?;ցlѯc#Lߪ KSx8~o0w'uB]D:tmW|ۧW~~B:哻d:/i[(җz|Ѭ Eȳmb;z}?miPıexj6cϖdfǮL HJxֺ7l_`4GƸ'CǦQu獊-m)j'hQo0֬hM'hlv[{?
+cp׍+$7+4*Pʾ
+/{!uov f)N3sͨr[r/)5Y9
+aCD)A &AZ@ Ԧz]Y~j ϪUdCsJӽf<9 T3o<,9{9
+-|\|ްXޛuoxx|& 6?E
+.((;YrQB(Ly,hguD)*wl\kԫ܂qd"v>K+$LV4RZ9E"p[B7xf0+k|5ڥb{ί@3[f
+Mi 3ժ0! DhDuF^l1>N|)M._Z7K>4Ȍø6m\v*ܚ^ !ժ*Γk)3Ҟ&^20ꅛ P%S hן5%esK> Ѯ h9k΄`f}vԱaڶ߹ ߯1· :Q\Ldf˽׿dN nNFiۓ2{-xdI⊐Dm+W l)zhk}!XR m2G5,L, 6O/@X`#zњ%W4>w$ѭiIYIK.Kv^%p&o9|k8Q+Wo'1LEǷ.E(ثk?qA{z\^7t;_\Arg&`Ixg9onS j 7SϞPGcd_utJ[N0i@H9nvf݆[n+V[򷇁~/<ZuTↈsuTA 0Pd:$"*ž 0"ڂ
+xLo2?!Kgz d)Z<TPFtp9nzBMz oB&P{oJ*v5s}K6 ƎM*H;#w$I/'?y 0]#Ei ? l?cLK}&'{g~!+ EV.?apqف;j|6FzRb3芞u#%wLOPuQM3#㊘ӊ$atx՞Wv%q0}uԎ) |b~us0c8NeMsϺb
+1b׎oͽ7w;}8@y</ kHgHCŠv@$)RuH͝7.$e#:\0KSq
+SP;)H;Ɖkk=iV
+o߾/[=;ַ.5zg}]Y%sB~!Mz uTi%q̯E!HLk.|{;5"h~-sۚ~&x?[z(n;7 f92-l+=w9sR
+1׊%z)y)jY ϒ~,'lAg ў<LUDڤێ|JܙH+W<sk%OτyZ3oLfpśUn 4%~[ Ės@$HK*O+[1 <^WN/KZi1n=It'Ui]9 11|R=O+r[J$KpCLDLDTȳ$3
+IDQ~yiKJ-Q,TPD -̄<gbU"za.f1}d-ĥvn*m8CooѰqKa2k ՚z˾7lP
+]I׮,63$M{f>׺L\YEC3^[Ϩ2Q.0@WS("$ 2
+b\ި&WE ;/V{{6XTi.!Y?=i'ww\;y0THd\s<$GJ9ľ?> %Ů;#]x&+-pEF=.2raH |2 k'_T:KGX
+%(eң+,?w$x&=3 Vn9$[~A KW Cn^-uAAFa/f)SRǖ~-m8GM:qNJvłĨm??kK;J O{a|Jsndn:[CXZ&HrǬPlk'_f=M(ƍ|@߾8t0qe<TCROEPB8#y^֡cyozwOΕl%aG{7WPZrZ'f[ezg(tbV-|6c^.'u:]ҫF xzr{<|m:7L8g6̏ 36Hl9ʠUW^ @:KFűR*FQi$= J*
+jӿxd1#SgKS2z5Ȗھ
+S%Ϟ٢_hO١W<;7H.D3TXdMmL/NN \(_ ӝ|\e梮*}6ebrB}G\)RRt{j Ԭ-J[CU[N.q>zTΨMSa;ͪ@`inNgTӅ SI>:njK{PD%|,@d5\,'c‘9$QĜ/ޫeKp?rY!xi+0t^[ו H_?K%rCb^iXbwQ w0d|;Ğ:F/+x湑7B=Vl'/6}J4!5Lq&d\I䪺37Wɺ%N8&207P&(5]JRN?N"*jy&)uee7;ڱ
+EQ3@
+r HXD:孙8;K]ӂ}%(64>u[/܃3he7P
+= S}@XsO=ht}Cd~?$jMb /~O%kbʉ6"PQiL,=/i#h
+}cJFcP&Y
+_& htop)A`t-I6tB\ii;y3oȐ5ѽ='dZiWO6IO7*Eth@kȈpa ]3|f4PYGEв8,_f6uqtu 8gac0۵.Ƕa^f+xi9LQA[ψYᛎWky)囦3ĵeK tpޅ3<ĺg1V%ɲ]2idĠ ?ù HKpu"e69׷S*ž8BÞ+0<%CKw-P2Î8l<G3/q7;]{BBkCRf1 -'\`Aks8FvL2 P;!GψVQi`a#ɅqO mY 9odV3yk>؉lGWW8<ڬ26p O<6+".v̕vp0? k|[륓}ߒsܭޑnT]^y.͍7_HFgٴ#]y 5lEy[A-jY:$2r+[X4*F3!\WnEW=Â+WN*r(԰C LYuW@KщIaQj%t-<צWkɧnymfMR@#|
+ԐSuv4?ZoYzIH
+OpyY#^ūnG}=,9m@~="֫ j~\4LH}SBAk ˇ|Ϊ54-s5t`^oϐ D+7YD߁p$BJm*! go@c\χ EeWԘ]xHw_!C@VA):ΐF@#) V*ˍ~ͨGp#2Z @|61QK& #+Dv&H[y6oNv1m$26>6ggnXz͍ mMu} g_Lշ1 3TssPbj׵1.'r|z~y+UU-YjH:ΩEc
+b*#Vq2Bם$#my7ZжLkʩ+2?C`gRQ0 6F,"apy6pm<|1z<U Q3
+qxBY
+}q~7{ZzD++>jNAԲ̟~rnkSUܵemsWd4%:`Qa{(K
+G$Ý:9Mk?wF\\qO$H@Jb+_VII@jpǕS,|2,q 9' M>~ K;$sez\7YRxj^tIV<5ahr ]<D\,
+ ߡhHs4/䈣)Y0Vѣ!EnH;;2! z}j:л^ l n蚿Jw^w{{gH>3еyI[}?r{Fn/{Ik:8+8C1^7_r
+LGћƠrG8Y!
+D/s;31eu "+]Ԫ2Uefy=ϱ=
+% {fthIO%w&Uf#ʁ>"KeYNV{+kJ*Ӛmy26t1t͈UyØ4t.IGPCSV3Q69(UP,DLlZ)V4@]Zrh<f5(|)Ѯ~eTĠ(5todHi6#팩HY~SD87EcrI~~ĽiP  Ɣc,VQIX'O%ʓQE<$qr.d:|(i: ɪRΪ TYXL8g2<H_669ið*T`藗5&;2NE\4
+]̰/%c\ޞ7$^a Kz2 
+D^7Kd]Ӊ+u* S35~˗7@Y75Wgb߱-
+ǦrH*\Y~.ʪ[
+$TWǍRY=.UȀt5DT_yu˷,?1u*THۚאҴ
+ؿ#"
+ձ8l(j!v%t&1VG} ?.ASb K.ÇQnLnGp]ʀghߒXf1G?? ,|ZQǔ &T rCnaRnYz* ? w2 ߘK;N9D.zH79 ΀Ҝ]fCbMN1impYb JW ^vYyos%9
+= |yjܼu^qq}+;|
+K'8sW#)w~$S|50ߘh9DT+_j|e҇ڮwc]K ޣѕ֪>a 9fdpmz?KAnHxR}+ox25~<pfL_8ʉtcj%zs^tE9>CKiPq:A<+/w1<80- D'<:!ãܑe\ rj o>mG:3>ϵa԰S+4XIBƸ5<<fcعޙݞ`gײ{`;Y#zwD{_}tޡamCz ~u|wg&n"#6lAsuf!܉9>!{"EE3FNp`ih/H18焭{o{sgepK1E7vիi0uT7i}u㷏N+]h΂wۥmKn]Lc[t#:N+2dB,2mJ$p̏艙GeM2IET@PdpAaڊܕ}qJR${QC9| ^>/4%\R~:HX)hC׼:1sL>E"^(.+UYTa`K?}U1y]%ᘞi2#msY@C>׭ f)T!t+x|=}録8 < ?ui%Gf 2{;[dLKT{C⥤MBs>~+h/UeZßT)lN:u/eMuWſUM)%:rƔ\"2DPI zV6D"em64)qJΠp̈́:1qΰrT =KDWȄ22P 8Rj`Mp{lȤRKFA~ 0=8uNytbv:[3yįnlmoi7
+ͬ=oŇT,uy hB.
+@|PG@`El2aJdߡ=Q$&o?LYP=j|H7
+J[h]mw5{di].9}";Ӭm{eb7@wPҐb ϨT6<NޡzY
+tɀft1YjPCaBkGDD81=ɗ9|e,O1hYj2
+$z_+GD WaУ7(/$AJ`Qr*EfS~yP  +sPӿby"
+ H4NuNH :'|B/aKuߕ%$ԁ` -49sV16;t`PU$7:~2pe#&H4PBWnj}) ^ H-_<F땯s~ZlP.su`5c]4O).MIĔ"&y &]7W"ź!׈i.S]Pn!T'CRK%/4Ym HgT@h]ױ 0H"jQ859)'rQPF
+
+X5tS'^:*ѱF
+K*8 BlQqʰ\"g_? tgK\c+ǽ±&,Ay} >ZAON(bKSKoo+<q}>Hz6\e]䡤|.+dmCC=uMz/Z{E h c8:hB}3Cj'tZ>08S:TNe4G>ЯYҶ/pxh7r!' O*Ţo~zoo0a2Y +Mοy`o2~f0$ q]CSY]R+NG"b EPnː 1o *St\ƅq0obrۺ$B&-_?)~`ߑ%b٤-<B/p"!Oeu r+E[L &:}}DԥU:Υ6UzjZ@ SCs3;kݧb:6n74s3U{H4>T fG04X#)mfA}:YVFo+S.F:B_!O<x~pB{=#MEH:4F2s|_ܝ6q|)U)){5/ex瞗2ȥy.k\6 o qE(*sdJZu&W~fnS)  CZsۦWee IW|ž! R$<շ8kXs|qcwVSqu^Y?7!{ |9jw=ɟZ2kW57sl "g}5 wi?w%~;<
+ﻲ-˼^[Ϋ<}r
+Uz˸{J<7Gks. ;O֙^}tNs-Ҁ8kP&erA tGf3> \~tOKd<]{4zT\mڄh%a[oEyG&߁ϨWD"8ܚFpKyЃmR"`n=<)pRiokd'Z;l큗(exv$ҽm2c=0~rO
+3zy۝~iNwYTn}KZәUHBByR8glO|rd23ȏ2-~*hگswQeAђc14P;Й=>rh8nj K.l0_7%x^+F͞^
+*Ch5?q|Hp 6_$w4OKjog$JVqĤOtA1Ҵ{tțF-IE Ȍ*y|.K<md{@m
+9~W%|dK*XQ/LfPM1QYsZHN*uCrASI|V'p&6^^~z{H(~@zЅo$ðAT>-|NE ZbN6ufΡ7/2ʉޱnX.Bۆu$j[)d]֏*ڒ
+J $*'ԆeA+WܒV5*_rq }N JRaH*x8-/<Tu攲#$$,3h`]DD\6YMLPelQ4 {'hDR:vƥ$P'a錜|r- r`[{A_߽jQN AA"a%Vw,
+.7Ӌr1NFS*T,Qk$S)頠Oz
+HWT@jyr]`3լAY ,9\sʍ3M.ʦ|*
+ [ܬi>LXkp둬vz1P/rE
+6r&N
+tjl%ʭ7_X`EWmmJ +<l-b ZZI'k}A5&+f,~A{l=F6MM'<])~6(eRD7cqDE wD>eR w;)KSP\^5ǤK_R; rV\.
+ RuSN؈R%fP+84=p#5ɠdgWH5l-tn|r t>S{yC%NNg:$G>-?p~튝8:gf]O9D 5 0 6@RcOr45a8#tO#R*6ZЂ}C4nLhE b{7H%3X{<uQe>o?2ֵ!qG./U9y9]>Y\J. ~2|`&/pQCډo:C`&HS3뤜u^8N >gRvo[}`̞rPG!%[h9Ή/ ^r'`^88N ]&Ft
+pvPm% Y0щއ.^[DF= G>v sfI>ԅIOg}D Mcl}p`tKvA;`LdY îΑ41k:4ZKvØ72wc#s u5iKs0s߬VX8Gg
+jFEeg_k/露e>թ;o٧͗`dlϤV)..<%0PnoElN\AZ̲\8d`L^*[<irEU`m@"qyҵ-Tקri)ˤrK]kEi[yx#uxM*I}sMi7Z~?S"UCI.}Sm:r]!X{s[橥
+ɝi05GDCS%}CK+Je&@"QҤdT7uaGPۘf6#X'QT650f2Öd*tqJOӮ*P6{>S
+MA5K|@=0ÿPl+<G_Ɩ%拓`C8l4.],?)39[e")SͤP mLe*6X\k39B*"gϰ&h2
+nXV~\
+
+/yerXXtwܤBȖU*`:`mM
+PesOeUVـ
+vh[
+|K<ՔKOֻy+CԼ6u*,LʈҢjݤwNv>BںyX${xMEe^ྙm-rk!h=|srmf5{O<Hs\hY >wҶ2!4 b0#41Yr>x嚒/lQUy.+Oe*7:2{Sf`A͸ yS3ԗL1/rxn^|jYܥCK%T;FC=kB*bC̊-{f $03:g$9H۷kж,WA ϻ4DqriamP(i4KHMh[ծIEŚkZ(vI<0/%c~RKh_8<Q*V 5K"]T!B7H=]e*%3rb>z$@"+Spe-ϔ7&A0͉9~0TFNö~[nK+ȕJȑD/ k
+PqoAJt6e^~)
+GCP&koyc1me\Uco~Ħ9i_/UkYwLkUȿlN7"ʵ R
+4ķ?` ؑ}$ZPvAzxE?%c‘!DL5(UHXUw&rZN>!It" D!= US1R]JTtPg*1TW͋ܵ&~3 jK?mN[nO- ;9RrԧQ{!@,RĂ2Sb F}HMGdxOp=°*
+\f)ϒ(zec"XU&Cc7ͱAמȖWGR4.4WޔX{#ĩ!3QUIqG7 u _?E?sum(~6| *A/dG>F ׵.w9luiK:,[ YQ@ƿש\fiWy[,eH5 M 7K7 |LbkUl$D ɚT&T(hs~'KZ0C(Ѕ©
+X'fhWdlmmί"`Oԇپ9*y[5]D,-\kZg@;#ѕ-5qޘ'o~k 2]5DG?P&9͖w\~uKC)bfndqFo uB rWVРLc_O Ͽ񰷶fN]n ڱA7OX|DBMv?-h~c%* a,
+:F7e;׻KSGzg!:f('Qw fy<CΙM/D0=f%z]Ó,NHfQbtb ӁfP1lD-A8Utap
+׶tС=HrRԥ@'@OHop:bzܩ)Ɲ1d7{44ῂ^3Ti]G>,ǥ6F
+KP]\G1iN0u/o;ob dO`y ];6oǠem>USYie\*I{H-̀'o6|/ 10۱&Ė1P
+&t`C!pIP+>u&'-U/<TQLjX9dZv/~kmss%`oa0+"}[X"s
+` _]hWB_ vp-_iK|(ϥ7i"䬮K<3ˀ
+ԁ-@ԸI>|/TQyK=o\ܮ.iXM
+xfP.f]ԵC=ڷ[cX/1'{gd;Jh1z4>fhd8]1 sՊ?oOuӅt}Ȇ91.-7:5˂S\IQ>@mNfd
+F&oM. :$=:RPK׶$ȗ3Yl-ZYNMIHs=S*#|U]*AmP)oKd/h0`1+pr<.lUc.ipc -J6ZjY|4jۍM׽P㥟 Ate L:Jpþ~W$õ$O$Y~_/@G\LYj?4` {e 1
+$uѐITǒD 'w.^uCXsyh~.K˒HMk
+DU/3P HN
+ ֖1==Q"~tjd-1m@wa5$o5|&h v u[̝9Z0X먣T$cL6/TYM|IzX3)(gG+"%Ņ:
+jB
+͎l84;U^8]5۳2.3?Z-@|RQAI^S&,rjf [7:m|sY845i|Aɨ) =SHf)61ߤ-s6b^[jRkpTS|0%?N-~a݃.U.~p7un
+C, QmS
+\虘jˍ}dd!YԨEs113]]=l
+ h!d"1c^g. "#{9iHb0>_su"<jH|S5\@wm+|Zfx)K?}eP_GU tOL%zw4:o1mLm&]Ɓ  .٘}||qnrSUq|9[;=*В:\k k{ot<v$ncEߙM=7Ci<Qt]G#%Qg*c1n~6Bck*AהIq?3zj+<`8v)\cnqUHLNSq|VXLMd1ƕ$a ]J;vGۻEMn{1X>Ҭ}i7UHړneЎ0Jd~b>کsL t6_cN~ ,1 /*V|u04YsBisQgyN>HDv>UN>%
+WEk ~#c| k@MY_,Q1Eujk]H:SI`.t&qy+F_̹)=}*dI`Ԙ-
+{@gs$ @ra24Kpz$'@ +"@qIW,>ḷ>2س.f';$`xJ) !&SR~SP"3י9E 0EInܤw$iO1Ul%I+} ^ 5m¢A<ss9\M ='EqrZk3PצB_+fQDZ~R,'r*J"̾ 0$QMNs1$ج*#ݹ$Wd&GKi>>- ӂ`}TWMsK@lwis W ;޼V,$Z2EauoQԬ?0; O!9/MT3,}sue|\⧸O407>
+?z%tv[arF}~zpnrxjfnOj=\[2%,Eʒ<>tsW*/ӄoH lo ZFnaPhus G`XKB\Y uCyS[y{&$غ$r8ybH4bUqV
+iT3\^
+l Q!U{N?e>pяԆؚ Zg<hY:%ia!vn`cU/!1-G!偶
+"3hW@elKM$;oz20P(/JrYQ*[G^TcZr|_`n>ZgOaMId\WBM⢮NN`lOM)>sPU+w- ԁ5Yu2`&# @/a*2k/d
+]u
+-D%"X2x5vp6m]\6>xOaܢr$ק KN5ARb5vd8],|t
+:s^glvR`X7$>DO+
+߃Ђ\b/@iqIJ`u6YThkSe?'21uOlb47
+ڞ<p4?YVj"FedޫĸFcY$9f`QyHS]v9K-fhqfh קiqʌ%FMkv>Xge!/JB¥*uʫy`@-4F GZil^
+ `֕Mĸ> dDFS=ZbY<*@-%?r+<W4- 264䒰 c}kZ5u*J w΍Y./V4釵. Eꒃlr# 7%) *3+?b|ǭ5_[R@Y&O 5*)l1nGCBxKD{bJ ޟۙ$g?ZC "D\h ߈c{&T4װfAi "3(*4ZHhT%F5]Flwʉܑ1w~H$#<_|@a[%ͲXDoQd)עl
+2H1(Ƙ/nwEQ Sh̺K%8uwlT$__ycnnN4dJy"&mLC"4.+W2*%%f#1pLc03<L#Ԣ>yS%sn}H@@q>G44Mr'[π݅Vy%Wcy1ik*-$"m뿟<to`@8Z,bF;[`kGۏJ?/\+^ *f+[4|[/J=R3`w:1ȗzYeV*d
+wrwFy;֥IHP!
+EXP5oB5kX IW')y!S.
+Dk L7"ц*(j' 32JCCMm׌)Xl%, FDM,fWէz는a`ѮdiQ6Np.”y)Y\4I7gr/G_'_f|u8p]7&:#T2 AY_@5=cP_awn>0#K2>W4@tYH3931hϴȗT@d3@FpIySbwW0_&@`G0.nP .Ī,ُ~tFc4?kKk…M/Lu X!%|)7E (:h[m=s+PfbviQ
+4jf nH7>AF*WmrpCLbdW&FhK4Lw4S֕!g B^AH̃\JDZ Jw8C0B_tIAv6Hլs y|7n_XtA‘/4>k[tlpa=P}ʎ>M-<aΛ2s+;kNřʵlV3:59/զZ?fZ@i¥yqyD/NDO.LfZc2jlTiM-DӨpiԔft>S6䔉~FT>Sᇢ,5;m2!eUxdf,;:pd`=FN [G*@m>EFb ⊑ןZtQ0Tֲg+RwJF*BRU4X5
+)_S,ӤiMݪ#CÜ>Ġ '="4ڒH㺺*LndFZʏãP22,ʣ@^NηYxpI8r Ll?aH\1HLJIei Ҭmݏsm+da﷟$~V4H2ۜH2PQK eװ~SqE|?XC#ὁ?^Ik?tc׽ߞi2rgSo'<;W]>]A{t
+ifCI\@)T2 ^$
+:7%6%dȄk
+*٩P&4Ipg:iԸC m?vi[O(<|YF-,QU,VE.mvEy<:6:ڢw;:V _
+2t93•?JؖMi1hE@C5 Ď%!@ .$ۖm zlJ/T}]vs\2s+GUcZ-<De=*fQKK]OB-Le;--vh f[l`E?w\qRRxZlhT!<QT҇#"(\P H76R9R'}UT$j8`,[ߚ ߜO[Yy{
+`T{-bNkP")5,R/5</c_⡦K<TK꾠I;0p'`wJzZ(IK0-cLpժ.yD'Ĩ'Lӄc|A;[Hk׺HI K *Y\έp?w5
+}!ѱR3aԶ,
+[o#g3<Qb>NF}S?#',4lTj` 0sP
+˴,a1D=G^1JDNʛs
+<!J,Τj8-T2o%;Pz_GgK[\*sB?Z|Ҥ+!61阠>$j>sj@<6.% _N@nnnRhcq K $8y?v-?kJ %D<k)頄>ԿT^?}s6O;nmZ7c"~gP;ژPG;sÈ>
+ :敻#ǫ͒s} wvx(NA~&&&v,!/-/yژ Ա0Z[
+ &c'.
+,$̡|XG2C̖Ra1.wODiVQc|Jg|d Bp$D
+]sk]9MShɐŀQۑTfFٵlwb
+R $!ч5ʣ=P}[K~B; 3uZ
+ }ByJH2RH' 
+.\3[Zib'4;<bR[FP2?x"
+M/#3lZcjs:6.rϡT+OJ`&-]zr_ʢ7VF(☸hZYqEA@0:NkJxB90%)'m[奼oό pg:5 *frJ#꫹f>@U(A
+mOP@6@ A
+hn}԰]Y=g_Ӄ*DnTF_E7
+rbӒfITzjj(&ilHM<RPnmG;d6sQC9u2&,WI]st5U W;6$j
+??2- 4繷}ǚw5!毽>&jPRht` ]Nz $(DFyr|*N&ƟZ$ȸ؆GJh@ |f8@:!B[:@a
+`Ob[ϝܤrˡAIPTT pĪ_;[JY R8V2s
+v}U~]na(<5M #rKW$G/
+3N\ngj-DgŞyXWZgz)Bg$qh]:Mn@
+Eoh1V!ƅL\33~hMN\ۅuRaAך-48ݪoPm
+{*B bhWB +pMf9)cTV\/aHPa9R<Tj\?Ȗ`*"lM8{%#.{
+
+>OfdT@TmH4YzerFG内j43'9wv؀w"/I`69:z4BS .7P_σXSArꉏZ bX.|@qݳsGHv-\2OE.5zyC9"N[?:8] ~6*:h`d jJi&u
+$ĵ3eRI\("b yuXu,;Aig3
+>5*kT%piSԾ}/N ZX0WLMcwbg:üeko}Siz*g+ 缉椆B7LLL^1py}7t_ҋ? fQXZt6,IKXZDl@+7%bɹ6:,@A]}즮]jd֍~rd[jT7q˰4' މol‰cAׯfo].^~p/=+Pk#ODhӌrRue ;љmGo*QEbn$PGΘTFx6p@cŖ$*| ;QHqU!Q(M1ηh5|b FjkvʼyF_JW? _k\,ˆ{Uh~Vy>3ҹ~^h_ ێNH((n# m]=yXv3uqHp'6?93X_[~|t.0 v]љݴFqٿ$e+Gθ߯[ȷ LTnhb`GMst|h ޴' P}VW*{#1)\q5q2TdXzgXCJ2J#M09s;NbWPD(̜?4sr:N\dSu4oG^SARNv+d[3\DY"[m@82BR;yX=ݚ.(NV*Oq%h-Ꮷ"PWpQ5hϭ/g!t>jJBq%7"*(oX}J*!>5Y7$wL( ^
+S,tJPb gƒߜ7Ghfa0O0pE&ėcsM#}&Pq9L}sd i HIbJƦ=44P -%{e2nr(h\;Gn/ȥV
+8.*<qHE92*dvi74WE1U16KJᯖ@xi.Ύ Dkxjt "w=M*K-;Ŗ=Rr>ӸjHEv{O`ܖ=~M_Oh;#Qt/>
+ct{`Z݋}+\|KZvi`fW% scX>?qXPۢ7MOm #%l[^+vAs'3 pa &(T՞Ω΍ݸx]^rձYʶȋ;|Ƣpn7
+X YE*|WUEoKJSF:YH:E
+Rqdv΍ %~*>AT}`s7f۹":o.'g4ConYnh_hHEBT6hg+3h7gG;w$]*Evʅ14_L_1.kN2ɛ7_K: T|lFn0
+
+iPP]MIc(
+{aB(愷,r,3UK;T+ ү)3 )tP)֥YF|k 
+^X$Sǧ/tN uYn#*&. (Q **! rE9i;3}p>&54X$WxWՔC\;5w#<xyRRSۖx_$ܤ7;KRņ#. #Ů3<.`jc +G ){w,:qfuSL:$Bͻ:
+ Ta7G$G5SᙊgT
+Cgr\Rrb)Wtn ;'h^gM[(kLM͙*Z֨R#;)_w2:ƾ3;jbRJss1ub$ޔB‘*N\<mat`Ŀ x?#U}1/;8;$a7!fv!=-U p3+&_vmIYl ),1 }LԤ[ڹC&ㅌՂ)TaO iL0(Oq k :Sb Z%~ fez%$V
+tU6QnFږf@_ؙF{
+dgRhWErm{.ȃ6X(Y quAm"
+Ia:) pl&A]}GPbNI\Vp;P Bd$ ӫ]UMhO]+t~@ NQD xkS|GuK+c\N6x=AX髜jcJ]2o_CB^Ԝ׆# wOgae 33
+UegwΝڢr]CM:Z:H*FO
+sf~4l[B= > smGџ_:ީ u36lؓ zk/pAM젠 poȖf]}
+ -@/p/VCd1iV_\K'Y %J5sj\'';ꌔo %<57v4_W(QJy&!дߘMTh1B`h(f.68-bb>[1҈%h4
+B{oYνUn&QLZF?#)b1?rᕖ;p@h 0tJm}/qW
+B, >t-_\,-e?nLQð2Xz%Hά>ľƷ{wwZ_ݣ r*`Œti0|UQt8v=PYgB_S
+`:N+ 㚚RvYd+5;>&N/087I<LЛf(+(Ceo<fMqS%pcR'hh@J j>U~w!p0iN1a6q#…=7 5O))?
+a'-V'Qg@~2%nSbɔ: =PB2_Nƻ‘KdϊGR\ݵ"gػw@ LX5 1!F*QF(qt᡾O:w2p?>1fpњ_@Н+'1!6 j[bJwyhQUsS1ҟ6{MaȑLfo` 5𛀰 pNFX&nIVxjTvW85pjfXd! !?dZ0>=%#ʶ,
+n X
+/h̋ Z׀q>gǻcqU͕IߟN۶ڲѺ)ٲ4ǘΉϫΌo02A}xD(-V{ۗW7SUiapPs**&2BJŢWHj.
+@kkkW٧S| Rlc\D~"+IKs ukKb]ỎnH o!R_HKDL)H$5c#4M \gz^.m~|OrMa 1+9Bb]MLv8R`}SvOk7k</r%>"Q=%(h%j%hױ
+F84cp6f]ׁ֛C궩 | 0ԤڿQwMUiLT``BtN^%li__pEURڄ47)_h=[ZBsT([@to=ś˿]
+߁V##7 LGӇ fc n,r=[@PlTQaߒX1%e;{Seſ ZYaϞT^G!nШȀpb5}l(WMN˟U 1m16DL1qCE٬gy>FUsL<sU~ݑY5!x7xy"
+ue87Ei :/.[*<hv7m^OG s"͝L<߻R SW'3muZ/&h
+x9xFyq?O䪘3E ntHJ}W ҁ{lK{D=гW_c#"<Y%Zjʛၸ-uH_\N"ٲpb 56,>#$n,s’sAH`T+)˯[ζ%ܺTޚ‰=(iIM/KS~6
+1:_!aQ"KM<צ5+t{[pر'##=WE`>U',޵׍pO' Gr5Q.KURGV6 %iFkbnR3c hv! z#}Tw%袊yE}4JfƼ/4EӮ*ˮ$
+bcc!n=t|+5ć]bzL/#O+jC|?9(0<S"T0E_?ݭN{1*'PV2$Ϭz4Qx* vιѨ1RBaY!͟<ߍ!!Ѡ hCG0D`sSKdwH\'#V`@OyWщkݖ&Nep,tky9kz]tLC *%*_ʏ60(:#I@8\P/VuamU2*`6}_+(iÂFy%ƖEitEy|gEN$x 02-AnBq$.l¼k[xnK,ϚeVb@ @7DX=&<bu~|$5FPm)<8qGQs8MC3kC͏˜\4s(kk}@+G*[=ͬW6JLŚfleWr- 0
+ZY'Or~[T
+U> vO\%u9E=1a3о9&vRRKgdA~=~\!vxF9@X0Xܤ&fŶC!f&Nd{E /iKS!@kzU&9RNVyƸ~^
+K.61D0E;jC4;gPY,$Vj*sF7Z×*#PD9-t6ʸ>r>?_
+_DsjU Af&v| 1UKN㒙QZ,O.mġE',Ni}R?:=8;LzkLRĴބTzN\ k`566+`؂΄;) uHw\HIWsTfFc`~Kh]9~Y^rFW. U'O ҩm_~mۑ&Xbs^tS=51i C{`X֥1i0o= *ޅ@#l^tA )(,>~tB]qZo7O֤KrIzg]~0-פih1_WYO=J|@K9nV|f/eFvF<%IMy BHj-Xll mRwkAƞa ]hG3v{8'?tJҽXZ mhJ$2ŘX\9ť0pd vNi`| u8f|޶)twf[ԑ8-W ;
+Hwk$5A>eAK+2s1-l`ssfS˼t%{>ͅOsBwU2\1 +L˲c~d1LE:Y[9 2eX)8P2579cŽ܋S0/| 4ɍ~
+sQ]kKqTه&7lHi=%<&BBp3 !\87rQGJ:{dx\.qfbM 4o
+=/`8ךn2 q9= )S\BIޙwu+&…w?:߼^Q⑑ׯMCpSc8~&,5@%уF)L37@TBHNEmXclڹ
+hHwAʁnS׽Ӆ
+eF Uvn@kL(vC5܁E傍Ƿx5OŅ$<;Qeaq0(3 't
+G31qk,6{gX*( ]:U (TY0I;*/wzVE*FY #.^J~33ژTr`@]ènr"J7F')>u3e}}pB@@
+b\|yRw'nnYeljm;,mN'[hso)N{ibau8NP6v̯9<(GȩWzB\A)#nz*ƨ)9ۂ
+]UūX)NNKWK!?ѻNuOKq$+Ae2x[T{ܿ>(5,ۇJYeZ.3Nwң)j\a.3Pzuvlw@zB(BgzuK/$hhUҨ정7 .934*,匑^^GGMmwWگ/M:
+@icL,XI9!8 d" $7EVQJ@hBFMh'ˍR 榩|i{]zLf5AVM:2J+m-''(icz)  ¥1mBAECL:0n.& LA*TI@^CTΩbYCmj߯N#-q{ b(黽`j TQ(.u!^g/]1poBe;.FRN@pP۸鸔u'B L@3KBU|@$9,4ٳ9yw.0W5Bpn9C "CXxP ߇'Mirj^F3\?,NOׁ]s-S:q(==IYCx`T9\F7*wR.Ԝ]oOYbvsgnX"|t
+ RU+6Ơ\rFF3iZd[Yªxi e ~ 
+gP.i#5( {DLlPG9nlZ:jc©y-g>_MLkc
+A֎Íp{C?ΐMn'Lߏnruvq`! KN c/+a#^CǩX{+^8V9Jhy\ ֶܬq/]pz 8__ ]~UOƂyIDG&F~w̋OӞzcf)mθ%-+b|N:|uƹ- E=3{{z.|h)O #,!P &
+p+mѬ$u~!mٌa`O# Ҍ;mrɗ O8rB
+uKڇ]ƨ`i% rhYuKNbxsmYljPԤ!C'Ce ZB©;Ԫ/}eZ zi/A(y3b.i}?ScRr@M)y-V
+]BuIO M }˖hƨ
+eg
+F7u9|*^">t(JJU{6sūwKK_9_Mͳ Olv7^ ~[UR_Uh ~GNL3ĵc}kfW+;clbʷ a5P`Pd9}-r2;[WSd4:
+n^agmRgԸL{1Aj]8d}*H,#ԑ%<Z/f!t1`/Ԯ;'ߨ j8$SܔIA sryx?rv_O4nZs{J׉W(}W
+B
+!N(y
+uӪ3oK
+XUIa(2i6}/
+@ݼ:(BY9ES4a7L C
+;^*-U25h5 7%%#p'fRe(
+*F'Lژ u}t͸΀2EW]}ABY 1uZs;秢,T}=~J~ĺ~SvS*=6`݃<L
+hdqv[hy5d/4X6:E}& al(c3}dp@aKtlxP*di)a'tT(lSbAiyDHXGMDn1+ԕ=$Pz2]֣񀸫9 ؕI:C^hUxhUR}lO:sjI9 (ٺ^u>B ۅpP$5NX^|L<>=f\穅mWM֛9?}nrC;.BIYTxcBU~+Qre#*LdMܑ!kP[usO- >ƨA7a9]B4y8:=8wS4E׵~ z~6jZXSE }\}~Ogr8rߑok<`3hG2})tq=wJCF"lʌ3U[st* wSo
+(-XZU86t ܔ供ګ(" oG#} }s+ pGQ*C@&#@lݪ `0 ozm6McA9j`AKK&&!mm<"&Uy>BYE-KFMq
+u[@+]7M H5G7mv
+lնL^"Fڔ.{/̧Q6erEc@Bтsͳ͛xF <XB_ɛ\k_]\wmY溩2kjLpe.jfb$ЮZ@0&nuk*wNe $!!!0vbp%R vn7i⫒ԭ}yh2~kU o%кz*V^VȒ}ІR6ލnŽ ÌR$nqf{[hڠnNš^Yq30ҮᎧD\;vz4%vԌBmLRҞ~u:ʖ+7(.kZ$w:iZ=ʐ2$@ޜ.0+|]"OǢkÇߦ|jN 4.H|8yHI;yow tB9vQi= NZ3RB}6|{6ŊX>zeK
+4ւ'͚̋qC}7A@4*` ςte_vWgb˭eQ$$[{B~Q1퍭5kbj~&)n5[{s{<+_Yf߬¥}uBo"ZySL=&ATXp8S(SIȹhM"=؝Y :G>ձe)bg;ZTCׇ*;>?Zr k#kH *4a '`ԉ}:Y###fhH(?Šv?ñQ26 [JzigZ]trH:Vʎ&dM5'TOBn NqT5):dTOÁ&\ wkfH!ׄ[="hsJK_~\ԄfOsA+Ycs% ӤPٕ-n;q; f&!m}NgQ$W~k3a߹%m[rƑԨv_A83R@ۺ K!P玵?_CQ@$SQs=GqВց=pz#I9Oj֠ȪT58PjTPpqF(h:; j>RF*/W\ Cs=0b;Ts6ZI[1'D
+ U=!@g|ч}rُk\ `$) u
+:P#yajm1-9)#H.Ɨ2&ATgaQ!8{O܊paG-٫EӇA\Iy߾%?Qli 5Φc"b/y"{l] lƾ\ Jŕ#1%WQvfub8ݺn4|3~lbO}$wX/+;[Ҟ
+)73rj՝~BK3tfӧƥmҎ)ƗZg©)]8qJZ+]+O 1ǻWqG otZ
+F 83(8_FT")9ӎ-ঔ9܆t+PlD!jATD5N?@\%F\ap3r 'EZr΄q`9 w+mYe&$ЖswG#푎dq(E;CAf(&{_'C@Σ3v&IJD 3gsVZ Iy"&#B#섐6H&(&Wf
+b$Ȓ 䢅kĆ=`&cҡ%.佈k _aJH;S⎁pp8[_@xN&4f"sJټƄcYu"{ c\q
+QJ➈]gKziLp$EJ7ǥ}7CueG maM~d4)'M|蟙/I5k?e}tN:6 v0BtVDC}I|`8tHBp\]qtG~y> i9{0loYnvlINbT+-#@0Q.g'I5J_54bw+6RTsR<\"e7V@bB7SU6e)#&bWGbSV;N@B C\1݌cB7W3+'Qq`!UXc@@_)Y>sy X- /yw75 +AUwFٓq[%#EPjkE6o#XbZ1/7ľ"jPr}](0QͨS Q9O.HXH=>ϖOTjNM76F}:Sf[RyY K:c: =˜pu]e-ur ]&'ןբѤI>)'ٌf 31aPĜj)vW:[<1-[ۧof>o;ͯ3Jg [g/w)96}5Ş-c|XIk9XW.]( 5Dw4$ԶVt6BGˏ,v2]$T+#s `pf?ښ2k0fkO#Xo.WU8 ]KJ^lD#%$ :衝ցhc2Bj%)!ppT m/I 1dFOm]׬bXN]9z°vL_YܝdAEB*{JW
+0Jq)(WhC~?L~fw_a+!OKePOhee^booH\=B$Fܗr"$5T':k\#$Y*1K_6B">n(6}Qm`KɕbĸKqX~[8KowVc8ϔl jBSh5n% k.f}zݭ+夞GUPV|DG_>#>R-< +=u}f]̈b`I
+K b5;H}JP8 e{)X0 c]̆Rdc9`#d4WͬrQ- Զ(.4f;?4Xłz,d58߉ )2oMZRBV
+JN
+cx\K*/)簀Ȁ TGێֶL^5| `\
+lbk)D522G;/tt7`~ROɖ'ҦiFIbgq~;sb&) 7.RL:dJ>quJU3Jw5[h%.bc(li;b`T?Kۆ5v G-@Kt`
+&FCW* `}R5E7S!eL4h]M*tfl %>bo IҎhXczo}SFV$(qKbgu}iT܆r$X|rRM0kXzAmkcq }y͘_ X WfÇ> BGA56f
+CRvyЉ {;^Ĵ.:I=X*|^x)W.UPVY+Q-3aryC` K!aS5YN<B`?4gU6ob[%c66%y":@7w\X(ǡ 6k;p=+Tw؂ʝ( C(_Mo'r#j/f4&@q-Q(ړ\mg3$XbA%z6K QFQ!Q.>ʼn!XHYTBGK,؆-X*})d.}_y{B D&"w~1*׌Qdy@_MDcR]RL+î.28?+T
+c!5a0]qeKJ U
+Bk#
+CWfi{}F`jG#  a?jK!
+Ѿ4qcl:C7a"")7B᎜<[J(sՋlN)]?pe-]DdkM;To
+
+{nus'VO<IK[*7s4z/sh٬©/+4t
+1)KdK65vlFaf6&=?Ts=tcPY{ll4YߙscCthY,_'CJpb$HRj? u bi 3 6yP1kX_T{i6mb[#Qvבa͜5U#/\y;U*@a#o&G˃ez @d qf%{aO4Qbq>~)Ԯ=kCOś02B\T
+8SpAiS:vqિ09wn)
+p IJ_/ 0ROkϘ"lGY}J8).MAqSd3S [ ╰k\AIݒ5T'3zh!e9 X0*k]P?sw~+
+@RA@ dQfAa#_glIv }9c*VBBm/A^^2㮋ֱJ ;bvom^9=b-;viܽiQq[D[j/2p{Kv-1iC%9sXTrz,l$W0
+4my̦LAh7ᕇ^ CbCOY{RXdLʼn!1Y)Fڴ sTW@Q
+@Um, ~n0$a
+Pe;B1;7SX덅ZE.yHo_=x̼u>?eyFaڦI[SSY>3p(qES-Y(M$YAkKZgd{,.PZI Sj?J)5&CkþA)+ UUF.>#4bo)y[{9/Mb#Daܥ wM[vuTxN#ȟJDcoNR %w Ζb#=jÌ*f),<YS{`Xؓ)R;jחB%5T]\rw] n ZnN qׁ^aK
+&Dk!ZVsjM%uɫ#vB-M}8K=@c k̀4w/+W~--rߍ{) R|с5u3vА9uk0iB;K^.$a퐀p**4eےdobz_8~.jEco_/㳑GØ"Ћ'.IG-rҪޜBNfe7}rOHVHա%}U8w3I ybԵ.:%|WyofXp~)n;ÖSn~7`$.)Ό@o)5FP:eu29plȼCs4@hwj6uPȱz@uϨMyw?MP(RB>8
+OḭC5p|ʗP+5oQ+VBlzAaTc~{fS|Ȟ`)@-%'yтRtn wPeˁ ҺsnJk][Ҩj͖@F8(;u2ꮙyvQrT`RkmrzB2Δq.cu2b#*>zϛd
+$ƕ1G…1êЁ8t-t 0y-VO) 4Fn96(U)9a`<_n9lU8Q AYFE9ߑI-G4rޜj 18]L'gE NM{Ba7VabG BO[xV˹͕n%Zc"w$ϱPRzE릜:Heϖs)bO'`q<=Jk, Au~_g(`zNjIm#H.63=yeDY` LɢMio9ĎBTAbed'"`+
+EKdC΅;w@q/#ul`vqb:.RCm2,Cm:- XDԈ/8fb>'Kd>!C=z$r2ъFܳrgKKzjtKk=\"
+
+V4DO}~`KmS;X. 8&IG.G!9`PA<tpTx`m[t( r߫:W \ 4CPLR¦u
+nl E{X(־#o͒+-O؂ KG}}3doey4l $-'QFiO҄>(;?;g^mӧ>Ժdp{"ZqpdcWWӆ'$9W$[I9"**e+ @PC!t>9;%D13"e-11ophuIE:ނ!
+>PL~KMfu]V7W؂1Ub1k (*TPyzt$*=:W3!||ܭkwVf<dmQb4.z>䚽߯kF h XCF5މUgX[B@.X7unˑ`g˹ՉgnٕVw~(Y4s⧟u{_\ӷS BO#)SBwz;]H,ÔJ#g- Df.O
+0~1+d{ߖr1ܿua[kEF3 gCi:Ţ˜kL}ʇDx"_ogrcqqWs*RbӎT3`Qw6Lp:*јS\HdL
+I#׊JUשWۅAoh
+q:ژBV*U԰k1-2Ҵ
+] !Ƶ tK )Tc(
+6LLxf(:?WС6Yao7;
+fo
+gdPxkUܼmX/]p>FA茸\@T(>~ɀL(˽Pil֙G"}DdZ6,xXjJ*2|lsb*P@DDE3QD
+/5=0(YsL47zL+^.#g ~S? GX8!&l>ǔ=hmQ7oŊ9 Q3<rz`k>\ӲCaa[¾NvaV "F)\L>!U ZQ i#!aC?e~sHn((&TE}
+ t~4g.>M=6z'士21 $ph&ѭv]t&ɸseqd Al礚)\{=Xkͭ4Y}g=_GnU\?jO}O} u*;{êI=*- 2OtBp%x#չ<b%DJPAm<PQ,D4 RDWUo]pQ\C.Bdէ6mXVr\^F_$cE{/] qM˙Cy~N]yfF?G<nYo/ ^xƾi{rP1ػo'S숧~r 
+Okܡ,HgI&9f@RLa,▷Y'wHEpmVM\Ri[fDdvJPY-
+_ wb6.gC,"LȈǙFDb>T,dfXUnEHCri#aHK8ϼ")MAH%kmOƁqYzF'L .11 !&eqq~b!JDXer }v!}Dΐ 2RC%a%LB,h\WںA}0':"RgMtf>$-$e8We`iUsm'L᧛ZHHjH@$ v蠏"ݹ6f Q"^Ir qLJ S)dx:=TE>"yR:L%O7ʽ֫`~kŬ]. :,t~ =fRV RƁj@8=*j]"EC6ξ)]|!!}Sv_I-{iY@<ac]&=_"nv'ͩ<Փv&ۃi`. ׷QMD?3 ҇
+_&U;H553Zp7P Kzp"T԰ۊ>o&::!2_ nG
+7]icٴ%cV/#Pbb=*nᒊ sd19)|HGs{ݣhlLvY3KgfmܝMYx/UaOViHJHc ՜5}La3~d^+C茿YYA$ЯUfqMy۪Of=td&;[9ي1g݃yYs\ׯ&[E@b8k=<u JB7~m].c9]ЬyY#X~͞~hLmy֑h؄!V:qGOx r&p|/_1l5f<ݍ9{vEB
+uwtƌE29P$2\Ju. W6Zp>nm=?tePV80~I~|5H&!ԱST:e5q0hk9EDȧw
+K(\>>4Fx)7!*{3N!n*grS0-*gRPpi}.(}B#\JhgaB QDK%s:ݦ
+0OEU\IEr #GPϭU.uoȅёL=UsZc)[]݌ |PN쵲Xy9,bs0K&#tf&V,v$)֯N{GtL /ws~|W`$Ǔ^Y8ǼI.צ6;Of*i I.`Biu[I0vNJA_dvl@8+rخ'-H]I+v)zBYi9s~GR*Of/xwTĢ9/ smh~Bu2XV:Y^1Ŗѥ߮͟6/lrJhj"AL+i"ZI*GPME@JZw#?*FJ:޿Ubb'Y`v_+2_ȫ繊.W8[)@n&3^ss P2B!(!1o:'Sۘ#ӷYgDW,[JjݨS?+oVFce2)LXkFki;w]P0lv䠫?C>Mb,| mXX0X-}{B [0#լ\Yfz;0-T+0EaA E/(GcšYWϧ38Q[k6tt1WIkt2\AZ (qw>P-tZ{2j;%pd j,k+Đ"?BՓe4=`״2(*Ű
+ZP2>fbg
+1f^wGfX0iKS@$ͦl3@ fL
+` &0OrFwW+$(SkCOB†b2p59fSR5?n|TM.׷h v6Z+MD9$С]͛짿z4ư \Xd^z%Vwg 4t r‹rwC0: pQ+A=Tρe0 úkŠe %$tx _AHW]ݜ'e&\I%zϛg$IҔ9)jJ<إ※y417 .P@fFs3t(bZ{u믟ޭ7 `+
+`"9!]
+I.q 9.e~XXTDO{WKÜ/
+Q%U~q<3Om`w v}-Iٛ[>'sj_x_鳑D/߄I5Hə޴B$Ĕ^ic#&4NqWGI>Xw_ R!;кFq0<De7j+#aaX` b" ŽOz 2P#X+&r:h|BfbwM><DꭘV"Ij@In~K oKXo&l‘!4y00
+~X6#ՓApeyMs[(|j뭗_%-ouVƿASWvޠCu ='F&AK ̈́bM;n̄?:}h 6Fw'\J+>Ic}5<wR;W?eƕFa2c־!c!^@ Vk_K25[U& HhG+qTe\ջ$&\%
+U~;w;[s@8h""}i&("y}\Fhxrٻ*񬟗
+ְjtSF1r-^u
+Ę q&DDXBCɏ"qB[0:3yǽE:CX'CJTY}:xV
+ ]_ۦ8WZH_Ze:;'WzckUZ@JWA *"_@mpLSw:'K4ߜP7PH赱46bH͊g`Q, ⡕crQ :>m#AMk:F-Afhqz4K\bIc)0AhEhR$L8{`p8@*h@}uA~OyF;!^ui hU33¬wˑۖ`IcX.Y0P!@'D]>|Wq嚕VACj~"%ĺ
+. L`_ 8!I k{s[Y%sܾ*K9(0 5)ثB4!rTJ!6Ѹc
+'eB!ÕŢ#&=5DLkp^
+ K*ҰK/9wKXw
+ Z%kHwYA l")nS_}GEOJ3;K—W1Bud`T!bOTD~uQ=ښbq6V\2rD( B;uy:X<'BjԪxHzrFV |OEgLR)8I*.biU4jԃ)Hmֶ#1d@+fVWAj? {hzE {pPo[&Es$r
++؞[U|O5́>zqODn`D@`֘Tē ںm=ާW7V>YW4:l^s:T܁V/_$.zB!J) V@i] VV_cz+!mbR
+@#)e)Nne{ nantJnYR#|S #?J[Ki>7wLS6C-cd@c(Wb0 .Hv2ݜ+)V<tB_$.fM9P8
+~P/sogVm~e
+VTcyk/;œNgq;^ :_kiBE` ?h%'17A }U19'{G[Sajz[h|R!̩.GEOI20kHX}W(9˫L2J\DɢDD')$$zHJd&%!u&Ƃ
+ .lYU4ˡjUDt],H Rbk(L>UͶ.S$ wfW33SjgUfB݂ :\u|Bx
+U')!q HgbarPk",]JjBܞ~ޟd>~:97 /8nu&$
+ٽ3/[0<B'7=݁(
+
+1PP)Z\~!e5@#eH0f˧ߦC
+(  T.=p"B
+>tr<Mk+:w 5z$2lq9vsEJ21F ES` Eo0PWmt Ɏ\=mwHUJS3iBXlclc!I'@ x7Q?̼TiQ;QL},Ҥ-{}fthc}9wb+8CH,Ԗm:[ CKzBħ$m3)[ׯVbw"o%f1$RMHG}}l[?/I
+G7g 6yxCԄ=5ZVv
+II
+r$9b9RCm&$@ oη]m.?jS_XW^=_X~zX$܄OɎ7(O'?;}uⳣe$dIfo>*Ec[ )]]EͱmM"B6J4GbꤸcHrڠjV(il*޼_$if-~hUfVK@"AK ]~y{ǞQbZCERPjg9\7nǸ%-sݴ[$wDm-Oټ`&Afq*@HѼ[mB(xUf!4̀Fգ6=džۓŷvc}@p#+dq0<2fZAH6/ZVcR1@}UhzOh6mY Tf(i[ pQMUrř+#w!B>b
+e>9Wojy;y-2o916! "?|`>kߣ$2Ǡ{r-]
+JY]
+ίQD엯9 &==FGN>Z$'A2U
+ )>yՊ.(#՚5V&:GKeًR;@w"f=OV-NaM!kQRP Z gऔU]hDx0Nc 7EɌxXeEH[y
+_1Zbg&97NɻC fj.W/AoW.7ne$@h %aEʖϮ\x-9)<r}, ZWT
+AMܶ;ɋpFN8}y^O<g,^ܲ>S6tτq]4~ 5>='Xc7W73)ZF0a*XWM dlg#<hLÅ+ 5'VU
+#O?//b\kf}IH(NzaWGq S-݁QR]LvXl=%66MDd„Z2Bbq+h-/`[¬JXY!A2\SSh{u'a5;m"
+ISRF6I
+tΥ9MD24ji@fwH--^k_<j1ÔQTXvǧ8; ܩ
+|$f/=ҬԂ1.JBAm^4i
+"mّp!ɎF +{9Bj!@PLpXسކ@8Ux=3evq9ܓ-X91^Vogu@D#mqmY4ԴlB́:ҰUuU$^.Ap)4 HX,O#`Gp',o oCe4ܭJ A
+hO!ԍn]u1s~i{UF<ڈ>p g VZ1Qr B8Onw&օmcaSc^w)/ΓaTNE_^[e4~NhtmС|`sv_{9q|N] yCefsM\o5<?[ )CH ̱d3yUe2lmJ Pb3ǹ4BfɂPI!.8.A):8Ϗ4_5+_W.j7WV+{탋+n|ǥly.=6h !z9BijFO_S EUn)/+W]ʡiu8BtmvTrzGa f`ImA*
+IKN, +}8~757 Q@cQB.(GXXDu-a8#^x.`UR;H
+%P|h\$.Y$wyg}@Tp9<6uH
+Q2B6S$f A[djh5n?4og`MJ%'
+K)Ɛ"pgٵx .qټF)-ۖjA!DSktQ^@Ru98#D^ k7>K  $Y*N<.4 3g\ˊ0{ʎ?)EBfU'c20]EKegB:bd4!:(NjX
+'A#,E\™srѿN&\@#2fR׷9LcZ3A2yTwb1瀰%mn߽͕<1g{&nxia-#9;12 |7,W-1qWBS`6^H8cwd-rkqkAAz}Q09H Y iΛk 12WH++JB+Ã|
+4>|yT4-D4@bv/*Sq!ŽjD5]K7*1.9<0B
+=dygJ 'Dbm/ ƪ&#*-1DV#6%_8ܴUגB۶ֱ/ HHG5)D(.Z_'z/ܱ-?Z )ى~^H%@.kI/2~</&|Օ[k  es@%9{ϿB٘X[aM|acFU" _B)J/|~D71ίoxVTۛɳ14ѐDs|:A`-Z>++q{g=Ooz״: Ԣ 5YJ!21\TD1 G8!ډ?"֧[t"9X?m 'v[$
+l5$ W1!
+ץlYNֿNy֪H NPt,I9N_d@aB~U zTzwksal >X>e1$SX#<DܳL52=b
+T*C/O._55<5lz
+OBj&,[' =oQrăX@}\}3%"} (b(Ҟ&Iqc3Pbqe!BS<zy8
+"Թüӎpuh-G9(bas b4)Wctzʳ_#PQ6 n4硌ꌥ,I@Pxy/L|'[19t VEqvFLH}/v(ݢ-V`Pa^un
+{:cm=(9{`xaPG> xz?I)0>B?3A:SМOɌǹO.29;4
+qߖ(8(# / #)'ߴx&O,=IBP=i=%XĨ#W%o0UV'G)5n~I[)>[{
+%!HU3Eh6kPUHGU"U{D
+SSud'mpdam d8%Ҿ8KRN㼄)&=bz<TC.r<v<
+Ǻ_ΨH%M0^%;{L o }`_Dۍ qMZ=f)ZL"b"_ɀRjӞ[\ ((WF4 y?io@? /ӉMe"/B|Ɗ]h[n $F 8 d&j|bپ]bN":K8o4
+E~W!)3fK !1?x?܏C)KiMo_5n~+'gt!63{R6.lV#mXEO25JkQ!{˖vK=WOQ=٘
+1GXkߋ2oMXUv?M?GCBё ^LGs6uQ|27Mڸm($ 6q"t aLJ?A}a;$W@/L&+UWN:~RGtAKc?ia\_m~WtrPE В`4@jBӥQ%)D0qkh*cdi PD(Be4tN>?bhv<a@M;]g֦߈%X{ud w00kˆ{;y#)<ݭO}\uUJVo'6mB5L6;Kaܕ4!RKz͌4ӁHO3M[^c9c^Ξu1h9( 26 K,͜&Ħ%,K%
+ڔw>X̝`r4B/N2`tbn
+H]
+A4/%=l'4WQUZ)sR(ȘQ ×A9xܯhʊbI+墊']ҔGFLe( Ka!o .rڛ۝
+Y Hc'NXBZv:i F(iǃnȔB1ҹpNyc ZߛɕniŇ]͗~:\ܾU':F`JNeu
+
+H=$ay0L)f~mL4;r3/qAi:=~jd_%gWI82QrCv.ì+
+iDI24`ɩu^Z^9+o &#o p/k{9yy--=D2j5oBKa-53
+xBJBi&͡&(SV̙BImYTQqgtKfʠnBD|8Oݚ`vV=Ol+%-a1n6[0_Uܶ܈,fj:~J{tx+X襟Lۨz䰧{cF
+5' #*2f9y ۝ J)sXz>reOvFowcG@(psӴT];MG1'Q^ύ$" K@]_8?7ON닫?jK5\ec=IO=9Iά֓3aJ2@ Z!3 aA&JI!JcD3O #90=|$} (,߽{s){6tWx4scfv4+AP\@yvw7-,aR yY'
+4̚DL S)zԬ*:=n2fe E!&mX+֋O#" tw>>\r@;Ϋd.g5WTT9QoN:$ѭBbjbE]k#< E~vo _le>,aW)?˴ C5J I ,xI&CflcfK2'PUiG& a1`mI$l>&꨿
+Tg&E$¹Dlv$,m⇾=1ŝy"riEYd\BD_S gUĽj紂kݞxEU*Q ˌ V Y{zZ6 HBJ]{[ь)IW-;
+ `ȷ{ՁJnjLh/'s.:}
+(bPR+[zrO*zЅI@Ip5qR
+)Cy:DnvamiMNV{Ն>@(q_;+oD8
+iSv:$5,<ێiۦ)6gsAxQ+ Ձɋ1~7ToQR7b.#XELHxNV?i=+ .R
+KjcskwLmٹmr/t{taE=2TȮ²4hUhD?<O+a@ f -bO@)5Ӂ5.;&caYrɈ AX9fc
+4Ρvw CQ9՝`wE3nkbJ'mݳ%(-T" [`.3Ë̺yͼ\9vMu/@<j Cj~Ly@zgI#\NK.9l K(5A~)]SHiK;M :G*0} weRaRF^#Mp_uGkݾ&([(+M0Ɂf1ǹ'Zg9#\
+#G"9$aag)kl@JDyazPiV$#JoshRcW"s"nB(cY-E:z [j_i[UD0%R&ؓ5R66zA>PjFO{觌z̃-&ݫzuZrD^pw@J(4Β1i<uFZt3Qݣ$eonPB9%-R𾃍'^|uW lo?r_dF m)pkB5돨@CF`+p&fŔmbJf߳ERrgbAr]+2DTv5asm'|~sg~+awN@IhpG039(ϯ<LW_@i~|61ĮTaჭڂ>ǒ
+`f;^(ZdHܚa^ Y=f2,RNʷk-{^tE)ش9Ǯo-<lXMMqzoBKй;1q~[=e]~.a; E\mɷZOSS{=RGh /-2ietY7-k} &pi?+&T4
+*Pd$
+]%gua*Y0[KO*10:J-}૽3}>mYg%:؂@*
+1FZt`rA}H042戸ѝ`Ju(YPyS@Xgٶ0(8o
+/x>5MIU a5W昣;Sϻ_k_jǾ?1*
+=іbˡڋXD%xB[#"|5_OZj[z4-KVq9
+Qm]+Xs6%3rt673+u4?<ϔ>'S!ݶwbB@L,0
+;Qr~x&kgHHXa#l13ܐ_ [sKLXք+c1FBJ ! &5n(Isu7E߇`prNJ-@&jy+q|48o/`Ƅfgz6_Ӷ ;? -gvɄ_<<w?\y`HoOwOb5,>0S{f6nÏ.'ń+Hj󝎐3Hk<mˋϿQz=Qjjǣb#<WCs \?VMbas}ZUa@\6d](}RϫJtw{>9}CݟQ4M3cA) Q \Xpwx zs!t˧{bѠ}ʤ3zl+{]T'G6{b/J= Ҳl>0~}jJD#T1.nqkv6ưh
+Fxn"%JDRV@/SFR=$ؤ9袐j0VZ_&I4P2Xh)"dle=nJ~b(M3g5/n֖Og[|M1+$|_+#wM ۠L>
+vrd\/Z)3 ,:,p uMڄ9(wKJ|nS9ҦaM\M<3(t0Scۄ;ڰ-+(rý-k ̚.j,VV*x_3\[u͗X`;)KϠ5ZCE6=\`/LE=(-]So ɮ#\z3F!JLU!atd(Duq#j[jp0D|"u#eć;K
+i-ν:[Gto!'VSLGηxU8!(/H'xO=fܪȶy< ;b +`p. (vT(ІaCJr0Vغmu+ p$\&ɏ
+>zGIƄMD|C$" 2T#@RH YDh ) !Yg@Y05 "0ҡcTA}s9WQPB7@aWAC1.I&\ Vw̤d
+_)}z+ҾI/^~qc^
+ s]@ݪ&*fuᕗcJ~vR\A@mp
+*Ho1 W8:1e4[ M!p!W4AL7!TA{`ۉ<=
+TEskeW'?`ռ[E6De̷QRH0.׏s$܎1fc"
+P-Xp[u#t;w9z G%!$5Tsg{ǜ4sDu$a@,7`Ri#(9@zopIHo?[`Mbvپ =zDu X}2UR'k 2_`vl:!ïږy\m8~NoYpNezm6/[6jٙaX1!XNn%ܹko!;޿$@)GkZBrҎ>܂.;!ptI _p|ʦT{[iQ?rW"- t.f ̝e/{[.o{o$E'(<>GEf5BwrUs<PldY:(q?E!lC37 F7]/lA.o q!w-gveǀ#gǴȔ %GF0SWڛIP[Υï}Á'}KsDD{W5SZH6SN+#`'L39[\
+iMPL݋\
+9AHyp[F2JkDvc%хa
+Oϻt b6գ)&mY`J0Ml,"nB!JbM:゠j,s$ 泶Uz{nsuW N\>_6HDGNS R7 b0-_+ ܯ>0r٣N𑯉sU&ĂΩL_Hz%Lj/W8t QUzsx=c#&w륵?]v yQ7{pv~Լ ʫrASLWxmStblҾ
+s3#0Ws'ܜg^:}8F
+d.9 UrV\K8>pg*jY%/\s|4cNWLy'#b72/ pN얁b~6oH=e"-3Ilmd"[$~iv^y $`2BO[5@=Ô%z<Ɗ
+FfQ)~SbH*Bjj2g~owUHJ*\e4̫so1Ch >EЌP\,ֶlA:mThM'cwc*&W,}Cly~ڌy|nn=^G.轭` cy',y%L-I#w*d!~]Kk);I]3'Z~Ғb%%"mn+xIBecYNvGr4a\$6#& JW3;?#"Ӷ $!'ؖ;J<l"lyA t={bvL.4v1XKkĺUH"V0`TO)=L~F^)K43>1V:*i֩՟\)s =|ygÏP;ߛݸM{»EZǷ7-9Fz+nܾMsTȘRs}^Nz| ;-.''\2C!1ce,Fm< HIJ(_D$5uxdJ94Μe/ H7*.Z8
+7KT07d`<wR$4TB;)R3%ER[}IH $:u6/2);m
+
+
+X>uw
+@1I\%5fV@ɚ}5o͸K@%5Eb<qT~̆Th4Fj>gYi}Ë3%b{SM7v5os6V~RǚOrŝ%
+Q;9k`~T`*iYl-Epw+[1A׹%bGzj_.oߍۖ mBuS#G0層0αh4qmIyzj哻xwNhX<.9 Iɞ Ri{HزCYQi2q X]3/B^3³xBuݼ(ABxܼ>.V#D[D$<-h?΀Bd^ݢ
+'WQ%I0bbrɊ6r) l\
+@)#> iuw-ro\ U_cZ{ܚ ١NsHuk0">yÐ8X:m#h1g+Z/{0W:gp_[ szR #yeB8+P_.$!ojy5(f??3! Aj
+6Hjn@pgBoV׮ycnO~>]~uma>>2EQ955dNU&oDŽ}z?fϾTl6 Peh5Ksm^E WJFgݳՂӬ+X%w;,d, ͯU]Y7S26%nEk~FIt}-u^;]\eW#Va rBCH(Hkݎ\r@J#|nȫ_k͠ǻe1!%j;,aqU;8aw G^B"D<mm@MUu
+)[]>3BY|VNٷGo]ENaH
+CUJag&f
+.w !&%Ma晸%ZI[]Z2O*EXAB[q}Iݙ2VIu| ۶@i:꧹MJJz7i[Ld^9x5i$Xifgd_[@K8]{|Q~3"D@H_f}_$n/1y6>*lQp/v9 iPt OÏؿau%6U\%=6?T1Vݴ%6W=2xbbC $0F`I;+}tIFB:@;=LZ+>Wt|EI]|碸kM{a/ Krp
+=X Dͳ-|`!*A;!;!~ʹpU j4eXʠ6f^s$(%Ӹ#ުy}m*vGfT:q Jc{ j =s
+p}OFX۸O^Gr`ouiW짩p[vdZK
+%SpamMxoֳnFYDȒ; \~P1+ ,b /4ra>UJxb*'BTs9cIA(zѓ҃WLHSJ?D(_Dx< ,> [G,\GukE4Op%WH,X'J&, "L-YLW\E<E6!
+5lMӼ¦!ZDۦ8Wt`"ou+w UW LGFH$vT \.L
+0 Fm#" <0]pu3s\7K4p_9iXN-gZ$iOձu;ʖ1b-O# -zVᏜ v$Ts=4Ulꦀ1@t, iͰf,+LzlęQv?=t{+, 1/{ sDI̖5t~O׷C Sv{{Ѽ#Ԇ\h lg|p:s3+—F
+/gew 1c¦)4.$վ$sp7$ja FH=wH pֱ~v{AA#B~4*R ;}I 9-y3` lo!FY+#&uE2( ޳~?VqqSzcI 4S݋XN\ @d"
+4UaBʔl$H=+mo =~#Hm2xرÀƣJUV;@ywAߎ}p\>8CB38_t<-iGۨSNwl65(
+jOD2ACT[Nt*fh:QPqy[ <3LQ!\`w\Km+:m<mjD6\5{d!O-wV
+*3 ꣍`-.\3tm7|li`1VL}˾`6PPZ
+" Ip1=3^Lͽ=lg^M$7F%g@DDL#kX8H$O[;H}dB،`cvY& ƻ`RG*FIX 6NLѴI&\_^/!Ry@ $̽99dD="4
+șи3"}ԝ6!B_U.:FRf 21]#̐jF;\V/څ!
+>LaX4B{d3i"E?Cc^i¯Ō!k|o4K BܛT w_DTm/*Cؕٯ5xҿ*{ehC:2i3¨bz1Gaq;:w}'Nٴ}ynw?ܧ.ʮ!gj~$fGbGXX2Ib0<Tn[7ZYgϘlk΀l1 γsͯC߻pH$*IԱ~^D5 ǴZEGH:gxGJ*CҳUE"QI
+vИ?v~(ٿ '>RHPCfJds0ua'e,&=?/ߎXEm
+zy?%d1v\X$mOI@|! G`7}=CLT̙)!mI8*.cFd&\y0fԘ_@CD9镐bŁ q$ϣRa, J{(_`3A% Gs3OlIATEI(aN_oj= *' >6|/kzwfpw#sqetAHfd >
+3>Ї( Bz{(]
+RAT z w@hUʚ)nϚb2v<ìGryN[ؚ|{r/ԭOTɏk{s!Wn6&llVvHIJf=TX bi4|qy6k ./l.0‚ u6BTtE>R룮y}}΍'dsNJsi(z;F1))b<tˇȾlRvjD3"t#~x`>,>]g8?\LYx4 sEl;\i. Pwcjc\'>P2Wy4>nϒb!4O+/E7nB"i
+Aþ 1̈y%@ϖ χ^*ap6[ݽؘZ-~uyp%,Ly
+&Q sCtF)Ά%K*\ `2ta4>:tqJ0+lXSR]
+ZbԋOH's,H`/T0#a#d^&aO}'Ցef!tܩnk<7,AĎFy+m Ԑ3o/LKg&!J$?P,
+fHfcg|Uw9JG Rw/Y\NM)
+E B%kN4jsqZLj #> ~=N 5N1HON"Tm6gL=yKyGIL*z2-v@$$_ǔ5%b4eR*IC@KʄM%Dk,Cq4 զkM:;-/ umo̩7Ki20<iZy
+8={Y5
+ÂBp%>h@Rҝ㱰j4W<3T2[L%Ų3%PcXl1
+Tsŕ+ܩ@ X}󀑪LshaBԺb2[ ix(t23u/K='eU]PC8Le
+ [Ҏ%ǝ+w9.?3'Nn򵙔Ts!
+.L>=!xz@1F  ȍ٠fY) @d )b ;QPbpg=l_{%"LpYPϰRBfj ]΀ 3%[p{]@NŜJ'A:J4_OFBzx4ٕ:֝NP
+) 7G#=4=ht7>$D]c[XaVu9 hJdCZɲ=tNklk7q8@0D;$8(J~x4%@"G >s!H`Gn;
+vj=gZ(Rra2C3Ayb
+|H@q %
+Ь3ꀾu7o DI)KGjbD"TM9v C(:7z 55,¶?{{o? [0ֵ;yzw^ji|,MeP@h 5G&<>o')x> $WI(9ٮn߷ IU}Uy!yI`!}"Z&_I#:^:-VIAat."|mg$VJ}6~y?|p믮AhS{\_L.ݶ]Ad2ԫZ}\^7[`('+Ϯ7Y-MLI DA$!s0uZ>snD5s>+<Ý>[>5!`vTΕ.K;sxTb8iΈyE>5 f:sy}mMXDR6]BדP"5+]_Ldw9#zLXChMh5-8{{ypUja`%xJ˲965אTڇ7g(!HAIoG>z
+'BP7qZiQ]e5{,*7 %|pl
+,D\fMmg3L Zل&@ɯE.J\x< XhŒ,xIMRɌmu7u7*6PvK_yyVGtLc=!dLXUgqFTs͍Er+Ȁn,XpFd_Jp?:_ bR
+k*N)ng")&ը$lz`jYˡ|a4ba ;I_ WzjI? zls& k#m\zׯ-Q Jָ,ks0τ#G#r@6Drn$FĭPFC§Pp0j+QDŽgCQ\#Ru*2tT%t
+:MFօn{bK941cK6Ҏ5t-(e+Z-,?p/NCR%9Wu8u
+Zi~-µDtdYl֫=#ꑸ1_g/UN('ֹBưmg#>J4F j_mR00 :tzTA f+SMccץU.&43j$M<j/;]@
+ [3,% Qo ³}ſzz3:<DIm'96,9id20 9LD"-v<4,i0!mJFlJ8Bz8_GIKZLL|~S"ɑQ:PYܦ+h*mf$kח z*9#Z+"a 5ͩƎ+zldߧDōT2zSC
+zJrc5UdH/n9R\7\3ͧ kW`N
+{3O3:~k^!x2s}L<=(!O| $$ٴ'ِ6&;,-k jr _ﹼ*A_Cۛ]`2#Rn;=U Bj3|3)dF+(9*QnFc˻Aא %,-EP=7b ԘsdGm鐒5Ťo iOoM ?˥7.f3i860nmq`.8xFUR.*U4$cblLI::p7O;@8/{ئP%]*ƨ*TYL8qϖJ/fi%Z Wp$EV8eD
+臺?Ϊb eD6Oxaʎx@ ~Y{9 PPm[,S׶o>@~f&B媗ѷ ; "iR,̲|^JIM_@}+]xz0I/RU$e6n$]q4pQ$a#D\s>lZb $`\$UЎ|#pc'c׎%BC>DbYe\#T&orRk2>D^0%9Ra*fS'FIo+64dL@Q`(:F'|9hx>@
+iFj0NiocQb%/F:D,e(/ԯ1l ݠ3n[6x(?zXZ00HəHe'D̶{YPSDKn"GRH(inRd6@y 4ap1^(L"&t/spjr}ؙ7i^R+΃~kj@c\6mET
+"l+c%4 J~VGm(0jcdBڈ
+HAoLR7E玘w"D* _C ioI,L
+bQPj$Jb؅svox1/䝍$+a*H?mv7f/.G\/;|ћ !?5o
+iı*Dc&v.(ƶ4i("E rwR`蹣0>dpIzH/@&}2PaߒyX2 dFƊH BuwѸֈ+Ҕc Co+1>\+rو d#2ұ4:0h:VnDBۊv4Httg2Ġ3-_] 5A
+Ǝ=NTi Nŭe㈗hLVoi4_M# E&9XL+{M:@Sv'քI1b^Iu xIjE{Kй "G.feD I!سp4(`H#{o] ̟݇ ,:hM|ޅwAX %Dx>KFc(LҷI:Vp
+m Vp:E0D iE< ;'_P8#a W56GCƛԕOezV99y?2
+}UQ{FOf94J݅ގGhWp2|xKHls 0܋t Z؜y8`VP*@r=!H
+ΨadDG ED
+ MfLHժ3E4)va&ߩBa@DzՉLvA4U ߸)/oźt\>z_}NN(_rSO;m9!3o҉aayk?[% ,ݟP#utl G'?[<_hi R҈
+.P&R?<_|+S͛2Z% (%4^_O<_}.N&sR[Ii{)<j$Wڱ.}yeχsIe:GsORS"vܪyu$eQ$V<'|rYONFg3y )(IgVAIA=v3
+YѓAK
+[u&<\ WXGP1pҦ1'ZVwLjDHN%?'@* cХ!T >-JM)3feGVڙX>"}1HKOq7KK=%X fT "B&ͱ DJo^(RtZz5jȈ0:Nˉ.HMJ9qr?TJ!"
+y7b2P>|DqF;
+,'^㋰5XP8^'ZqzM.0yXXV!f k'Ph(TFh`$
+10FW67RSP/"KIXFIU\tGXXad?iM'p\|͝}SiC8XśfT1?JћVތcP*ĊA@ z Ơ0Z{aLZҖ CC꣱{# F4:LuFCL|`բ.2?"JBjN'iK.6gc-8NfE :ۃ wRhdjseb09FgQ0UFR]Cd ɸk<1 P{޺ށ1&?I!xZ3-kxؿp~4t͟E3ձ*D@NE@9U5te#6,8H$U?yH R$_-~w~&ɳlgɕ@,p"#'#SZ7I`aBbe
+5Ljzq5!#d0.2f`U+HߚΈ;]Pt!gANwh4a D]ȳۻi% \bjJT2ALvמ3֝RrD
+ra1cPQJfd JAPAТyfuo@(l*VPsgyV@g"Q$Iq_ޗo8Ȑ$I\2BN Qv&$$yg1)HϚ0X'݉N(HԬ5_:B0
+pD&
+aaϞRS >5s@BeJLJ c @'Ճ-X*E[HZs?׋}! f8FK*K\O D!N% ޅa"B.Rc D,f<Ҷ(\+TG`P]+j;JUP4Jr,Jr28s̷ f8kQ8W.4&~ۢs`N=s׸tA rRqmpZNS梡&6`pTE[d0'*LLYm
+ j!BFoQ¨<7BBmCJytI?E]t:Ag箹>CvQ)3(zL95J}޵^y`*n*6)<6$qF7aD): qb]TK}A^RQKOwCRu,t
+:K aȠ9F&ؒybY4sŏ7WPʠdL(H &ˆtNUS;MOcn<!x
+#1:RGP!RɡeAh6?3:[|Þ=gbD "7kZI<㧳1@VF G:4Xp Tu/ k &s4h,&N.0zPDZc4s?򾑖w}On5۽T/KGBV>$C@0N;"|U5Ato?\OFD
+6'(Q
+;I835*r
+A$w4P.<EUV4[D.޸p9fx ߳"d'\ଞX[\MЄrlCIr8BwX
+=οtFꥩ(b xUXmXMr{kҶu; M]\a,"TF*ޓ UEP=ig6әza`10.@gL:ߎEuMw 9Fט7̦e&m"DHYſZFyo`]Kڹ{.q9 Àٕ~fTw:]4(a&*$&
+=
+)s+}#g
+J$GS++aQ Q%8ZHI&#bn0""jv
+@h5ԝHjPI`hJG]n:і#AIDԲGsd\)DρԒ-H"Oz &̿ql[nЮ{V.a>mYVtεG]8 ~`XhHJƇDN^uj]K: à+v(ZBoIpdN8Yh5-BUQ2cv+6!0W%+ Zoi*J3Vj8S!u4
+ޭz~:,Q=re+ߧ:c\e֧e:|fK
+}葒$VZV
+!kб#H- {0*I\Dv*eSClؒHd\~<,;+z~ o;clz4&b%V`RpG+m~hZR]AdwJ'C56
+kb/,GDH8! E*Χ:
+Ԇ20up8V+3¾=\i,,m
+s~<ꕳ:3n5
+ۣUPdAGˊsq-Tn:|cWw.\u/{g~,lL|'{3gUe0 曮X"yfH&Q؎ Ma2]; tvxP90@L<L@8p->ʱmSퟻz~-\{g,A:V<jmzq^k((CZŁиƞkEA*/rAQPB@k Gg^I,I`t<#WOf[dž9gri(|K<}޹bQZ(Jw 29mBAKk&hALM*[$>B T)a̓ш=2B{t{ [B̑Sd%~(WEO@{"ZfShC89)9]CUVf! G!rL,ʉh
+(>/igB<LfC&7/y|kdn۟N{ieR";_hTx@wy_):^AW X /Ks
+'R!n
+VxT;lL#%
+9y_  B$TI}|ڂZ]UsܯQ.7Ծ8)PO_A2P
+dnJƗ^ȁꄠQδ1s7}
+Q:ҳd^r,a.3pʡ1 cw͞ǵn#:iu9+N$o`csn&%lD902|0* hլ1DFJhŰVv8p*77,k:VcۍYrC!B9w7( Moje<c!/^
+v>ƒ`2
+ `lMp8 UVA,fL~<
+VK" j39>,5cfF) l-Сiu.fooϾ_@3ǹMz}G= WzXwgAm1DT{ܓ
+iCT)nSiAGs@NܦI}*aSX%z۸() Žv4%Q II8v\KFvHT @AXDRK%qҢc=Dr;;y' 5!z1 g6(\EnbI}1a
+vK0B79!%b3'@b?p9kشk[u2$@"
+p3fMarfՊķ-,wy8VqBmoN1(0yF?L^.$ Q>2 [lSW]
+ՇsSF. b0 u͸ PgP҈0Oj_dnTv#qOQp4HBa9+KWq|9#$XDKW꬞k (4ʤ+<!ٷg巿f][/Y|*h
+؄AN-3ZHɎH5EzcQ"Ri_Jq[޵u[YɛbW?ݭ=cTG;[_ilՋ#r㓃q~w`M9cn?7j϶٠G6n''W8gkߴ#|4
+XGȪEyاEZ<̡Uw>WBx0OE0D|<:.w3ēI!"ڑFHj*=U>P@"/`=Ji3cp+]Fa g3[x8Ƽ_ghn|@vɠ@~n֠iZeqqZac1vg(H9Lu" 䆃 ?Wp jyN} 0(|ЌU/꽨Mͽ8s`A{=罛^)e¼kj8LD_
+ H};kٲ)c 9WK]I-y;&b+lIi-tQtm>aӼ,樝d;+m*cvFB3^K2Lj,f4Q=&6tX=g\ z(( D#20v3gˑz
+vE@DNڢLMuGyy<|JBmf읰Q͎޾x/.<R(#a.?`Q?6϶Pûl>3O_,޽~ɭ'-ЊB M
+2>_ZfUz/įIQ WSZ,ǀG2z4r~tkyS}"R6;יu V؞\?F* ϲU@Fv*,#_XW2> Kq&cGs2Č%Gl A,d?qTWKc>"CR@DJE&EUfo0 V^eK> DyTk?|qVp Qq+`x`}f'Q|e%5mJh;\~,fTAg+d|`[s80qlkx:=4y-z?wٯL/V~5ѹm`ﺿI"@D:ZcZeY@swfrvIIY[Fڞ7\ϙm "8`24YemL~@
+d kQqML~H~5촖hGfb&"LdQ)14Sҝno'S
+ߪveVD#(%(g4z572|6{0(c)F/cKVwsWO߶^{lX+`"V;̒$S;`: RvlPս)txMSAh" W~r8PD*QJhAPN 75vD0_\5k7U'd"b~ίtq$G#FJ @ČҶex;G#dAqo<΅9ڳ!dǝ~;%;TW{ 9P[QWIՙ5=g Nd?>B`lF;P{* M~fAeu=*I'"L=~Y{PcN4#s $nPbscҢi xxCs*d1М7y?7mHEPөg2L]M[VX 'mV?]( 5_Oq!95Oz*"~tǎ0 O2B4R=Q(p$ %\?=aOu`Qo=Qi3~]L8:BTIDbӮey>x=vë7=.|
+[9orDHBBLBN-B޳Dj q. 4"2Q/s|8ӣT`rn- JBdi 7 EL
+34ֺx[ʇVDi6-]OtA
+WCKGiD՜5 tm"n(ӂ雟Pz)cu2U0T!&D?V"*
+D%Bjr0}ս8w0lOm[9h&}mعäLa&#P-=@T>a
+Fu)um&A[|
+4`Ff(t/Oj.;Ǩߟ ~с <m a se5D:c^`^-ԏzx0)8XPj GQC uL8E
+WǶzEGaY2Hxi:(lgS4Ucx޵]+: |TZ^FM$TOF<jv+YaZfR@U, Ӊ-:SMӒ]^ɖo[iUGf \}0tz<"oWt , i[h5k[QrgBPC$b1AP^hǖx:R 0~|y&iPBjUZص%Q+LyV$"<W-k&Ҽ`~RиrWZ"&}ﺢ_I ;q]]\p'
+(6=kۢ;d3TQ̄TP0Nz1+v}A#H$)8e֢[ܫAOJYC|3WAzߧ$@As kdHMmx6G?xӧ4Brm#ҳthųSq0EA] 񈐙eĒc0WABn& F7 Wˬ Ujo*ef&$1modV
+
+㣠V˽af.@"
+ΘNY[NC\hs& UL%
+({z„@#EAtݛ|(@m8= /g!2}0$x؞"HYB(4BCP;kt`qh]µoUAX4G >&J@}
+R
+37WUWb:_pav5k Af~Z|i|lNѢdFP
+Lw)ݍs%g߲&%OϏƹ/?FIf{jڔFLn%7M"(5c6;ш 7Lfnަ6c!^Pdkjk_l&M_+3S_aӾ,<g{$)lA;qvׁAH%<mZTs1q fm! ÝU0XI2\NMqsGZ$ӧsDN67/޽I\3G=ST9@aV'}LR7&\(P-g]TP,(XRu4Pgp+
+qt&vbȆ@
+`^rgYpXK,J50Y> ʈ xXCUx´h-
+aUg&b*֙f{h ;Ctx 9<5bGXuA|f
+I{ⴀ<$j2_17!EL],.Rtw@snLHR1s%eD0Z`L  s[15cgH@6zW39'kox}Ղ}):BLa2!,u^9}/a& Cd *ޛΞvL IĄ0^}qa4@#7
+߂kHj cՏKu͠6n'! Y8#YB=J&lQK"{#D Csd g+y5OJmDd sAԦd;˧:$'Q"њ
+ĹY3"l¡).eF 8Qs@C amD&wS)BD[NPp_?]/ϯۧ~<-j67bnPLiÚd(;N,>
+n[&A}90`&ǂVYxyMJz10yt2k!Q \ĕ(F->e. }
+9!b6DP
+LjHV
+xCCĴP@>YÔKٟ3 \ߞ&#gcP!92rk6hᝐ gAiOp! 2D\ǽx6a}֬/$[Ӗ2!!φ/]^,_O? 3"R^x\i|U6lqhD,u<ONt68U,3Dr g+aHCn@;~0o8~dYhQlD`R b&PC3hbgyUjm@ؤ$w00D̃oF"kdeqY_ P whG b44%{|b_GT_L]VOs=]a&q&^E; {֖@20vC_OkRJRNhAB`<2 ZRݒ,<$Uy[T}g9mtIo6Њ|>:sԧ`e4< ~G hw\|‘-T+/0'z^<ep6<wm^t❲kVdP7^{
+.PRjgq[NM$\~7W
+.u1:n݈[hv_@Dj8ǓPM=@DHܳԊO7'2"#s@{)x}LQ+tGHu& Ji|q{:SlxЅchDZỶTcH95듒
+Qz64<7ΐv`K>7wT\^ ג*{A61|;X\(_/19{"{1
+ b65'|>1ʥUthgĸ1ZI(2} 1LjY=7FOz>ZNcToPC6 d2NXoc]f`a"N ՃΰnG D!W8܏hEg-u=akw>7
+lze}3Z۰_m~yz<Zoeyc+P:Q4&1Ū_w1H\;Zr/2rK*:P-׶^%&V+#!|m;s+"=q}=VMD҃kxWV@WR=W4NcCs)'F,&uHJ|
+C(04AdWIS4.ӷ%%a־`3SA_P| eܷIqEW^*MH(
+YO<rFNt ԟ26-oY&+|O>43|Vܵ~
+= Dϗu,]=5<U*"O=kIpn0@bޔC#{eao@Z{p^1G+=sM. xxErܓjg^0a6Kh(d2 3&
+RO残+<'ca%GsP,\I+U( w%]"=>;1% јDSCq[#H|8GDB?K[zO]*%Eܲ\Ok:;C4Dն*_[=6ͰQDT0o c|erqk<Cpp|n_
+ZW{t)0lBX]e˘=Y1jbc)D8ym-%2%   ~B_6&࠸I)o | }<߃5E-}=B ~Wion栵iĩGzրt{h1$͐!P%BsPJDSb,%騚Ճ[nGǃik&EM'+q&?Jav_m6ԍqG]^SQۦgg
+IԆMcin[0$+o P!
+ t߳07P
+
+j0e [*hLiSHWݮ'-H\z:I<H>&
+X>2Ϝ<dG9LS?1N^F"I$dZ0swV 3U<Cig>e`92f?;AYhYY`&Sa^vxvai+X*NNvmB)1wl7#EyOZo1"3gDP'NimɧZͶ\a@(F=P8˦7P@ݹ ^nWMws^˼bօ ѰUE\4eBS rS@H6C&?Q].Z}/X޶:A4c^%q{M#JS05Wz{hBvM#0;+gm^3-šaI/ɖ=V<-}oy~:YY}}=rƣHX|a3 kIRC'g?b^:˝K(ҋo%>)8"M_)2euYZ"DOCIkKZ#܆-ʭGsxE6GmZd7a~旍LzIi. Tg1>otUs L&~/AF3{q#%{tz$y
+)!ѺݛDu̵
+_`ba`Nvn-pU)dw)?|L>.o;.r__LD81T;[sD Jn^ 5
+2_4ƘsOCroaLXNTtFtv La,mA) Dm#%.lYz GzA&ť@0< -tP!aR}$\~Uj10~}ץ⪠52zwJ 5i
+s DҔ"`ԎnEf2[aV D>79
+
+$b\v~_zaDX9\Q\om-N;"O.:g?d>( 2 f /D_fU~TFm)\% b5#,j&B~G9puA'r`uX"ڱvFPv_FMB$<QŻﰬF 3>sYUW>2r;*,[#h13 K%^NTU%gm]1Kc1*8cɣ8SH)T$mv=./bÀt`sW:/s7Pnl+eȨZcv<ԲDUyqty;S^
+B|?&0I|{|
+&sXms['XQAXM))<ڮ',hVv|H'Y {yG^
+@Dy'+} V3 .O&MP\kUu}4wlbvHIYC*ґ zR
+Q uvlH40TʟOשu݂D 2a>_0dMנЎzuv3:=*ڀ~ݢ os)gL(^]5gf"K DAXb1* "Y왪Ꙅ+mg*as3PD9s%9#CϚ"Ҏ1 F ƾm8VwB|5f:ܶs˾x(ϯN۟tmjG2vupTkC@tE Byے
+MԶṮN!@;+*{Q|*ZH5#Q贓 0z\B0%:4)QAQ+p4|I|̼v-2'νyqyѳZM>Ze afpȐyYa6jۃ i )T9_.T7PIz%r}_dL
+4qozb>5ʃJEP ɮڻg| 3*A!i8|uG
+Sĵ$3.嚣Ĕ\ (?<#wUC 瓊0)%$Q ĭ3 P P
+Ӵn´O#wT"=,& 1"_䬠F~*ART
+~&!i
+V~׉U;O #8W~Qu<q
+7^ aF滂r;3mڗXol9,D4
+(I874"BKġLKD@H0Ua=/|e$TJΨ=yQ6;`=g Ջ5
+R`"^ijq5fa|۰0[Cs-*9sX8S}1E[kY[DFs }ӭ[GL#fЎ
+mwJAaC)a퉰%7; 9&IDg#o\p9w;+0
+ 0cE fq+QP"bh0Ìy"ig%0enaYd8IpR)huY'~ڎE=sD"Pv ,psG$< .߀hԏכ6k9_sv۱
+^,DZFQMACɨ{s9x.  W֙Մ`1jCHpa]@@~'!b҈B bQ "A DcKBB+ p4 GRðe+O9Q$w/}%_>ME*WSxPp
+a^
+#A HŹ$h51 =sѧfϻK}
+&aaJFBYE4_p;Uǩnd
+p!;$=ՏÄ2{6Sz[8HR4p@a6=>n/5(KTBeD@-55A(_˷W۹!th (eOח5&"~Ot,qF$D2 !QbI5^-G{4-8Ş~EAbhbьX|]mh"L*EU+B4JG3*
+hΪa@BV>]ﮪO;M!2NFX&(ũ1
+a r$0U31g56'X$>e)k9Aȸ}P 9eWfjP\!:WnOJ@ S3ϔN#ıuNC~Oh 
+)}Dh MCe!M<3lL%V@iܸ>ZQH)Bx9= AP[zneK x)0o2/@
+
+`0{mҢ +(2[TDOXB@".a6i`q811hzѓa" .aޮlTsQa-.10仺)ڂ"О5mRc1F873A,R[dL@HBHcP$@!qr ybdT@G93E@e"b3ܜ6ؘ_YPtļ <w)*M?<s9x+;+lHzE2@?ʥ Hq]pj_+&`er[mzj Qh~Éx]K@T#%ehpꉁMǃ| 7^>A<HE ibr8j0) Eh a9NRGNF5Ds@akb{%kԸleOL3 K8Eʼ
+wH11m 8E9gR*&1$"\GDɉT $;@V|?K,An
+@G;zU
+dڻNf
+?jqh qQŪǭ
+ !\KYMp4W( ż}^9M[愳)%E{&KAD^==:<<hT-^D-(
+x70p@s0Y  la~\mfu kr.ͱz)voNMwXgƩMWo -XD,xρLj{votDgu}U
+YKEH<N7;$D L&őȽS:+e X/mVr0`uۧP˻/mvLZ@+6BUӑi"*?
+1I'!
+$F;[uma+iKZ~OHH˟L/rSk~F!eO1|S!qSd_tZAr2
+K'b@8S̯Yt-&p`(HÁFe(!]wK"L͌z]1
+80 PQkD*-ӌH"QWEB@҉yF\¾y u*0 HQ
+= IVOEͱs++H!r2g+ʦ}rsdb˹q?|(o9ޔ |k \@Y҇H%$ƤCKXa0/1B##ˢ6;ߔs/=(-nX uJT\ k{ݔ{2xh
+~'pkb[Q`*˓aD3`zSILDkI{4lT2|| !F&bܦAK@hmV0Q@MD-uUػQyKu|TJዃrfbEJV9 j%c#Y"[V/~0$,f
+ֲK*P LWѭTAByj,F{ ][=քHE3 ᾕڎ#RHˠkY%,uA,j4jh"T/ĦZn⑂{fô,?SD#?$t NAHD r8 g<ſI7R<wtNH"PXQ~
+tF&jn`UXK}&]-F9jxDW~+BĄib0LۥG"]ty)X$Hna`>ώ:L/^Cds_:_YYCsu6ȣ@$T"٭{
+UpD#!` AGlk5!t7p- =1ms=$a<!%ꧡ׵{pCQF%2(!  $* 9G"JBX+)riø6Mm16`s1b0`|`H0i`06Ɨ4IӔ>ssuojɋ#>ILD͙Ttl4엨\hɺ%BD"]6GtjDu7]j: SD)!:DDNrt[Jd.dPt-
+ xiW . D\ؖK7LoA  I`NѶBDh&_^\{vJ=n{54N]XPqSP&mWuNT3^`PL4ZRK1}ڪ.-{AB
+&'Mq0T` S%Џ#lWz>-
+ v.鉽ʖ5I`bf(b$8:gL gJ6Լ9
+; ΰQnܔ :|7v
+zSa
+ya^]_uP
+FV[/F.pC-OKB4N!
+G&"?Akg71^L
+4, 2|BvWBiʭbjܼМw$Ldz7ؼiS#%3BzІe
+3L_ fo[0+QH " fᗿժO<
+P|-`雾Oy~u_x~*UPQ,nV_+OBT"+ 5h@~AЫC
+sC,qkgHډul_#P
+ҥ ;tKs5N;w@QgR·/=˙9ϗ\}sKYPqR=,5~o *iDzu%$nu!QaRƠaZb|0f։Z0!Pw"<!]0
+jJ'v͙a_%j^pWD\˵Liקzd@"}CH@I[6uK؂ ~&("T?{<Vs$
+CU(B38}>d1?ƣ*^_mZi~!0ZR,W QH'kǷO^]YAsK̊S0ހѵļ[97\}, G(zz($hx܎ԳT" ٿ/N]n_mE2A»e|0P8}ba~uiAq{ pT|jc<(lDXMďE2-M֬DPj[`%~-{Ȍx
+@ !$~FšɤkUA]^.puxpeSV/Syyvg!:YaOQ36;Y"{Bz$,^f1/ryuCu덈g976uB1چqk j+lV:C+&m
+Gh:ǐE*ODpxG抦*<%
+AƠ~6OC6͋ªyKQ|
+C D0H0*7 #6b2Rz>hQ2耪NDf/> XAQAd_6γǜ|j>5oN6o3{C7B/$n>quwyį$Mr5$q6ܱ k@ Ti>6S>1v Q)]W'mΛ!72U 3W?xPAB$A<޽{j VURa4MDoJU@LMɯ I
+|vshg&w:d"' @$f.FBBM;^A*ۆe6l! (uOǯΌcuY^4ӌN>7`%{߭7խĚ ?vi2O201
+'0R7Enͼ\\3ED\N#MqV6ů=}a4,nwp&^QA${/
+ N OxU?3žŧb8ݦ@)f KE [YkX' Λ}<RHBJQH؊.nUmZDǦ$!yc+ UItpD ٧t?xQ 3UG]6u3*"ڽ\ v5,t(l / ;HGX(ݷeA %̫50ka)30[}ggK{>V*Vwy!4欣fufOF3(dTNOT»h!6ļ1X롗%v`h#rv?q|D^gWqx:u+]Y}-D Y2o-”.}@(=#a*A%|߽\^vKXwoxbű|YHy~g3G=RHqKXh[d) $"BZt
+қ{y.3x<k{":j@ q/
+ jӾ^6DN.$^t؎3O<q&9<−
+R-ADmGYH8>!%./\FI<Hr1ltUkswT˵LPbs2MY1TGTDSƨ^sJe%f,CF2DYKe`T\=t΋/&}juC*%b慜}ғ@}~@'?ln
+@!;O7kl j)`bG2oM:5<yKyGPᖕʦ(;oTÁ3 bp
+2ď"Uw\v:k\ٯQIp73Oj"n<+ Qr ]ߡD<X̦ǁhZBLT*~77N. 
+Mݵ]\׉"v`e` 3V˴DV$X |VQm;4b}}B͙\|K&5/wy)(B %[_ (&
+QkOs_A:ͷkyx5g@m4_?S<Ty
+>>52d'7Kla|X颇: ~[[Ƭ*0#avN'}~X?t~4|0ZIV[ٌ^ ;F=VA5$*G]!!PCta"LK`
+{12BX,~>ck0h'؃vz}@)LS4 |rg
+>4ǠAh.-n #b.W@'G6D쳄 R1¬ iE$<yJzkGj:lG>t@#Ѱoe9_7){&[C8CƿFs ݂dfx<%mY{G֑KOD-*DC*+mDa#εF
+[ 2(vc&fswVԶնu7m
+˯…W'[B̞s2u}ˣx(6zJQ!jm 0,U"99{yeCKSAz$ M#sILdF 3 hc\luS?&}^a@{ H^4@K6xÁ
+^n-?+9*tD- X G”(>Svp'cVB[݀ &Zfi%ej1ϷƋIGtWu1kuDD%9zF6 bl^#[z܂ԑ`S]Qv3\s<gOv$LUN(OE7~`rw&oC,ͭڇ*)"ȍ+1zgDC9oѲMz e<
+G {=*Y
+O4bh)( ,Z@ 6DuoyY
+[Q"X@ cy4F -&Kr)[
+ZI'8\pO\ʖEF1ٔDSQF5xKA
+/X
+TuKvA*\sg?-Kō^/Aj
+̗c na>-g]I_= H,T*{st8=x#Qm[yCE٥= ,}*tM^bO&U O@x%PɁn~G̘5)=5]
+IOAD 0pC
+rAw RZf@vg?j 7b5
+!"]k݋$jRĴG,(LZ!siDLu" kXV'֊44.K)ScjC![X*l D$?e}G}i:, $@HM Y$I! t&$jc8I_ܞtu~s>G<["'\);mV?oF?׽FEO0b
+2f!G=Ƚhb%I⽈tZ!/8 #1x,;dsA8>o}r-iUuCDFxӟs#d0 DO@Xݶ*̄$RI>RJQJ&]#~tÁ8ALv! 8c\ϯ*yg+@$[.rHs^A-|5k.b [@/\-/
+?rw7Zm=/^P2(Evz|tR( z0XXIBL׻WSN?
+8f prqw$H`aׄ`o\*m ZUl``&df< u>8,?d_1??1:ofnM~)T0D<eGJ(|X\{+']HP=QSlt`r'iM=p
+9V^{ĥwiկ֮bϖ8%
+?Z)lW /vWaWKWokgaJeJ%"$ba!,diC>3D+ot.HPIr0F:B]]_5}yy3 Eg}GG!vuWrDAlT2lx^-ğHO,{zxqq%ezm5J}7Cׁ;4DMÜ약Etixh@ S:'V'F^yӼ3!,Hu 0_Cϩu?_*mcƖxahj?
+vH{]†j5R/c
+7>õ䔟>F~be.nn o>iW16c,FEAOuKf}%I
+a|=ϩ䘧Tya"DC@:]GMTfw<zԸcq2mjd4NxAX k6fo ڙNRވY" v}]UWNq63}/=~qjA`jkd!S]d10$2KwXTCɘ`R$8B}^T {!Uԓ#qC$UR
+1#
+#@@@yoms/B #đv L]$e [B.IB喖~`51"Q5A(ޤZBTgwlxfMNk&y46.a!/}\K_G"<nXUWIa}@V7j4el+V]͇gN-\3!if2
+qw{A#F @ªDhsߩg
+^wE~6(!f.;5"!܆LD5a[Lwb[df7a%q&&@4 As4g
+*] N1  _h
+{elqKBJD40~/ѽfF/+>/Rwl ԁnܒv6c!>b1 /H[) *}k?Z4抡Ω \o?;fV,G;\~Rβ qfpU[ςE)?)bή av+/_)D{SrLid$yL`tBwZO\T?Gܪe6byO ++צI)BH3U޶:kF@ 5لQy[o!Bь01c{Bh`j*Jv=`ЗXJLJ#?FZ+GIAdL8Y#"`yu3QA(,`j2=|d)0Sݢ;M VDwD xAX,&,n2zxPurkE4pHŹm?ʀ<!>@ް[1ei56uLj5"eLB) ZhqW}A&|3<kZȿ/r|Rku*$}prcCc#¹KЄyBFQE '@{W0/T>ve ltB{ox!1_3Gf
+1Lĩ !^i`)+?=fbb~ytw…5"D\:Ѡoo ]ζ<-#bfӸDWu r LjR5 ׶4c{+Ƒ}лc2_y&(iE&2t1WLIaq"ҽ#m(sWڲi"Fw9Ӆ=gU
+(`"D°#=gTOMLV@,RG!M~߯O&$ P;LB\D}$$Jy!z>ROx;Y8=&&F
+d+uDހ GYc\X<_ΟfĦS rɍXx 9H,jJGpEWV~*u3QMi\֠\ 㦛={H4@ҎK!wiۖ;Gj(-C$sfM@g>RճR,(IhmR0&a:{3<r!&\67o,1{+2Np`|mCzn.3m: ~ʝ;G7ԷB^IgkgL0~N?SS^fVxN: Yf"yUCQA.7Ab!,6"]}OQHTT(ĵ+$~L>:|TRQ'T;I;ssU2g1wV]bԋLRg|xNrK[* SZ+o\_,<)?Лky2q^YWJBFy,<SRI J?.QB)1aqV\ZE
+ B?PKV^9m 1߾Ia= *a
+ 2ow !F\̘<c|ShGnKgZې:3ۓ~&s^K1Wے.6FȤӫ`OPM-д*hA bxΌ;& -O9ؗ2ȟG0);Tzp6Lx*P"N\BkoGϵҽ[ [[;츏]!ư]O9@˛K̵wFTPº qA$ FlYp*=;ɛl* )m~HץKN65i%Շ ߕyH-c !!m*ɂ߼cnTVC;c_0aGeED@RTSwlX([eG`/DT>dR:$rֹ~+8<
+A,HjCfeg #;{5>dX#ug}]d~nS/d5XS3[
+RT C9̕V1֡||w?gBƌ>SY 90; ʨy޸pb5 jDcQ/վs*v*p:
+7XZսQWmC%+r!<ڽ(ŦlV!nײG_!C;7h<M `GajY] D}8ʒFa_
+'3jTܘ4JW@N8G; ' M0B-|n]*N{j!?CԁA%<t'LDT8̹,is+ Jl6U"BWRrVe4t\<\ľuV 1ROK0Esu辁]ES
+Xn h ĤՒ2Wu{ϭ+#KuKD\Ēs89#b 7H=ۡ#=ہTnCb"31 !%I=^
+q a3 @e >!X"{;hdٷez%4F85SV\|T1f>>L&@ j 9k{O%3e:KhS45cE@0r
+Lq3{z40JI-Prq(&4c$}q̗|2{ v^fL@$U=ZZjrjc(*`6X+ cLhhZ<ˋa\"K TSCںXA0LW龧rsaUU.px~`nO!JR'њ;~gHS.”ҲVC.*u/Ź؈TvR=
+䲚:jO=7llIg[6*R{߽"t6HOeM*'[@y]zP\Migmg;M$,<F7$ n~~ɾL'MMIA"n_+p8(hٯL2Ϲ}]QAh6?}hm/HSy#SB޻_f[.nϱoҾT1U
+l7ӝ:Rbqts&r[V^aH߰I;Nb#%aQĵ[\4l|B) O-T]\-mp3crlG6խ%BLHL#xBn3k(m.^t6+ǥD4ˉ1%>@hXR ل3"ū$Anï08/35 /*2
+roJF43Ξ )Ca6{t~f鵞D '1N'' ȉҩ)A%Ԡha@Z_2|r^B' Br,VP YF^6`|8s(}]|/+孱UПJG)|ŸY*L2_|g^-o=)>)?)oaCѻDТE~Srz
+npV +ݯ@:ec%Ջ<iphr<i>kc2qEN&;fozOt{UqZbz<,RY3E} Bԉ.قGT?Qm%P$#!kи&05;lE(\vB w,Eãn&nwEnIn *i4E {i.*7vS7D cTY1/\q 3K2!r
+B\JN/QّS)*,QincB
+.`EDP )f f궽PA/9$w% .赘#OC{"a!`o|ͼ^cw= j"Fv!460<#L2
+B5Ejq,x+hݙ%IH/oWh`Danr
+/aM(9嬴}[ٻ+@ԁ2ZG-ۓ>B^D&\LTbj[IW%c8| o9yZ.tn2Py,.Sx4y$#S_9E^lq$!œ[ߎ9#KG~63H*!"fw`jIjA;sE
+d$ZN;{>/A!G5TA~ &xjVe!KN;TM#BY>.f#n*7G&kI7k. *1JETc.> 2Q6
+06)mEk84RZNe>ZK#==~<@_%ڄ$qZAT3leI)l[SJ(]gsjĴ) f'b>BJgImQ:ɾNi>?E
+C]..SX"חâJaRk֐N8d!}Az)l ZJ %=bHaK\Ho=8EjF{b[@(2X0bZ:] I#0xV`9>dF1Q\ԫRpӦ˜xR<X(~w^>d#]䈓)LΟ m I]sԐd9L-_dnX[v,YU;WУ˷vF)~qCmw}l|B>϶:x<R=^H5d
+Cƕ_qMe-z,ҽr+s2iԹniAI'Lں0tiں;H@I!о/NO3Mg2MM !@$I$ݫޫ Nۙ~i=F9ϣJvyxm} 4Ƃ^*1Onv\|KD1k*uP ^^GGS!aKPNH-n#.RS& H{ x (%7S{y66_3UJ4nzAy.
+ZN
+ ͜ܜ6XCr'?
+v2PBgӍ"rD)TU&y*eݬE*>5*"\V[U,t"g>? :@[]%.z m)gy`dWSY6Z70ȃ84|DP>z~wyԳD:L QD^9X)ʱ̞΃92|]>::4z 0 cIㆹ"CHʇ
+ ewUv"AيhWlj$.;.7Mu/A“ҡ$;7\D?
+wV(@`yUjf9(
+~&A0\RsP h}NmfB02D%&|G/ΘvB.LD`7AًbnW~zC^Zrv>=ll
+*>f.RVbD{5fAR@D3I+B4GMk-.^".|x^\IZH\)K~A,otH-W3۠/ln 3\ _
+?\<:-5Ŀvu;\ qk#c znsԴ?vRzLHA@L}}2
+ GEpCHXN{bB*@Wm4gZg.gK0QT8sXīG%c
+/s{B0sjiw9frzd,ubŧw^4L^
+w/^\7d(g΁$0HqiSf<LtFᨩitdฌMADk\TRoSzs~Gm~ӒNƗRL:_ ! i jq)K#An Xd uC8 ۾>:=|AtVNOS\k*lhjbKMP/ǹb8h=tO&`.juWsKˡ|rVP L%,%B BF?S;n7Yd\*.B]KiB*U
+*:ts /ܞR|+n $6Oɛg k
+2(]V
+P["ԆSz\W%>yCg@%t[gOv"NVg%HMO9_v=^JtUBԇ9x/[Ѕ%:57
+~ U#E71V!cr)+M>f\r\A/lvիŭ
+ nvg?|Ϭl ߆<>1I΀xAZ/,vFBFPrWټPmd,Ze_P.(''>RHRM3*ncy67 Neաn9Q12yą%ZN&-N&g .ԺNRs*eݦnkU좴a ºor+ e,73Bj{
+xQ'3fW{ B:"T%Q5uW7B17w%?3 9I-_{}j ${ztqUJj|ra_˫
+f$|zjŤ*x"Jf
+D<jcp? +{fR .7:&v'0,r-Y2RdQNŽOαGo4'8kK&@(ܫѱݺ
+ Jy>Ĭ{y<cWL'=lj+ T5=@qK 13$z縨jň*z
++su2xeobOS7C<.!n 8/=2kJx;әN3uh\"BF3hre3H3m'MAи4 \p<iasxi /1
+?~Zh
+De#+W # ]<7bDzq> j(kN5Aܠ|{Ar5!A2b>~ʥoz @bxrO^O4ɐel"M(H@_>scR5)1CM~2-18R c( UN7Sn?kdBe0w¦BH[)ҖZNԻqG#A$m1yhԧ:8?^
+g6F2!/sR4`ILvBAw?d$ьA[<~˸M[Gs᠐v\2^N8. ۃLJ H橺"eM5S9+#PAͤL깬6An&K=aa5JNHH4B# tj7y~SaQ3c!C܂)l$;Б_FŻG%$P9fQJ]uo贔9no 6=1,D(faL疇̫!Vn⪾lL#f&tl9-l^KIP3w9 >u_1D*5vզ)>E,"Ivi=U\Lҷ
+D>cT"MA6y˩bY5K| w#'?otwRVy6!%-bSu}samcl׺WuYKO9JF -H +.nlSPWEL5qn@臈Z%
+endstream endobj 265 0 obj [/Indexed/DeviceRGB 255 266 0 R] endobj 266 0 obj <</Length 428/Filter[/ASCII85Decode/FlateDecode]>>stream
+8;X]O>EqN@%''O_@%e@?J;%+8(9e>X=MR6S?i^YgA3=].HDXF.R$lIL@"pJ+EP(%0
+b]6ajmNZn*!='OQZeQ^Y*,=]?C.B+\Ulg9dhD*"iC[;*=3`oP1[!S^)?1)IZ4dup`
+E1r!/,*0[*9.aFIR2&b-C#s<Xl5FH@[<=!#6V)uDBXnIr.F>oRZ7Dl%MLY\.?d>Mn
+6%Q2oYfNRF$$+ON<+]RUJmC0I<jlL.oXisZ;SYU[/7#<&37rclQKqeJe#,UF7Rgb1
+VNWFKf>nDZ4OTs0S!saG>GGKUlQ*Q?45:CI&4J'_2j<etJICj7e7nPMb=O6S7UOH<
+PO7r\I.Hu&e0d&E<.')fERr/l+*W,)q^D*ai5<uuLX.7g/>$XKrcYp0n+Xl_nU*O(
+l[$6Nn+Z_Nq0]s7hs]`XX1nZ8&94a\~>
+endstream endobj 6 0 obj <</Private 7 0 R/LastModified(D:20170201092100-07'00')>> endobj 7 0 obj <</AIPDFPrivateData50 58 0 R/AIPDFPrivateData51 59 0 R/AIPDFPrivateData52 60 0 R/AIPDFPrivateData53 61 0 R/AIPDFPrivateData54 62 0 R/AIPDFPrivateData55 63 0 R/AIPDFPrivateData56 64 0 R/AIPDFPrivateData57 65 0 R/AIPDFPrivateData58 66 0 R/AIPDFPrivateData59 67 0 R/RoundtripVersion 13/ContainerVersion 11/CreatorVersion 13/AIPDFPrivateData60 68 0 R/AIMetaData 8 0 R/AIPDFPrivateData10 18 0 R/AIPDFPrivateData11 19 0 R/AIPDFPrivateData12 20 0 R/AIPDFPrivateData13 21 0 R/AIPDFPrivateData1 9 0 R/AIPDFPrivateData14 22 0 R/AIPDFPrivateData2 10 0 R/AIPDFPrivateData15 23 0 R/AIPDFPrivateData3 11 0 R/AIPDFPrivateData16 24 0 R/AIPDFPrivateData4 12 0 R/AIPDFPrivateData17 25 0 R/AIPDFPrivateData5 13 0 R/AIPDFPrivateData18 26 0 R/AIPDFPrivateData6 14 0 R/AIPDFPrivateData19 27 0 R/AIPDFPrivateData7 15 0 R/AIPDFPrivateData8 16 0 R/AIPDFPrivateData9 17 0 R/AIPDFPrivateData20 28 0 R/AIPDFPrivateData21 29 0 R/AIPDFPrivateData22 30 0 R/AIPDFPrivateData23 31 0 R/AIPDFPrivateData24 32 0 R/AIPDFPrivateData25 33 0 R/AIPDFPrivateData26 34 0 R/AIPDFPrivateData27 35 0 R/AIPDFPrivateData28 36 0 R/AIPDFPrivateData29 37 0 R/AIPDFPrivateData30 38 0 R/AIPDFPrivateData31 39 0 R/AIPDFPrivateData32 40 0 R/AIPDFPrivateData33 41 0 R/AIPDFPrivateData34 42 0 R/AIPDFPrivateData35 43 0 R/AIPDFPrivateData36 44 0 R/AIPDFPrivateData37 45 0 R/AIPDFPrivateData38 46 0 R/AIPDFPrivateData39 47 0 R/AIPDFPrivateData40 48 0 R/AIPDFPrivateData41 49 0 R/AIPDFPrivateData42 50 0 R/AIPDFPrivateData43 51 0 R/NumBlock 60/AIPDFPrivateData44 52 0 R/AIPDFPrivateData45 53 0 R/AIPDFPrivateData46 54 0 R/AIPDFPrivateData47 55 0 R/AIPDFPrivateData48 56 0 R/AIPDFPrivateData49 57 0 R>> endobj 58 0 obj <</Length 5997/Filter[/FlateDecode]>>stream
+H{pTƟ HpK@@ `
+E$
+!!J H[FtZX R=Fp(r.)ZGtƶМΗ8&s.|g7~HDGF]quth)1ݓ:k~&}v{"gDPS8y!P>Q6‘ B=>vB!2 3|8ŏp \x)\H/\xCWv^x{g]7.THF#x!oʝej?\?S%s5fP}?J|OVs]^9fY59 F]^}N|x׼|g\ب o}*R*/¡u̇<YSxm|PL58_[$vϟŠE>n"P.ӟ^I@Q>U(|P\Xj^XooT tr3>6}g@'pa~?L\Yg*um%QQ¶,W.oB'ǡ}}yaG<|?
+%/Q]X"Xk^[{g67G] m ]&K 6?4?|S"xsCc<Unʋ DNH&u5=kCm'恷:|N=,58.|ϷEٶ\q8| V$cX:ok+ϼ_RK\-| >~wRdƜRFA|6W຦er帝\v{`@Ţ2ɴ7|\ gjמOު\#/<kpY3n.:D1΍#Tnוk13Ч}:gKMJl_
+z|FT'|r|l*yQx/z\xMr,0IM5uMp"'}%iu{gRO{5~u\Hˈij x{,'兿yγ)?w tv_E^׵\m^x &/Ji$?|Vm2ܐ"9b'TO
+$hZD[M*pWF\h<a;i==E/_kr'ޠp!:/Oe~C{,mb4
+gOh;"FV!Z=YC Q~u{ڸV:W6̀|5. }ze}Ы[ VjhMCbl%7d-0<n-&fT% ԏ1}yi.3F\|ث!i 7u/Q/ϡ~}bb
+䜒L6?VyѠ5AV)99-wcMt'3>2=/Ag\8O!l@cy$ @,b,)B,XPcca<
+ @:CCmgTH b먝ؖZn޻;;o{ݜp,_VE˓t'ko_n4$$GQcfCL$hgc3;;,u-4M-MeOOěm>7{g_xNy鵟o0.Ý 6 6-9$Jԥ s뉅IDasNncŸ.asΡ]Qfv 64te2|^ɘ r9GgfW, .TSKN͹<u&-xZ޿9Nu6jQE#шF4hD#шF4 GZ}i}0f~ղaz]R/}z\?Yg #\YHF.x;x3 #}b˩p~#*6 =cb]pHvG<3q3X xD C$fQ80{&?wy<Dσ^>"QBGssۉG3!ү"Qf<>#B>Qx?"UQf<JLFᏅgK˟. dHX#Y<xQ4/D)<0v \_S|9x]<'BXDR!?l}V o^F.I(#R"qgPi)]Mp s9胙X".F}X(YE_u( uau8lZ䌰%EhK>iSR{88yH]¿~z M净
+M0ÿo/Th/B}]վX9%rQXzEm͇>hg +k}~dRtl}tVgNh{9dju< T<~! }EKVEk?NBsD. ~]ǀg./57W#XV颵xπݎX\:_<-B).nkUN2\""}pCpx,,hm|T,E;
+XI,Pe]3UtAswn'OéxzTXB=A<ⰢRsy/
+`=@:צ mn+uT*E`Y3>|[mo+.&NuqyclP-d<@έ<8Ϩ(9g>e'Mjdm[&U j:_Yq>߲K]\: z.?{,iJ/RfٗWo_Ӆ>Ϯ<VjQ}??zzS:#zwkwQ-i)7`5c:}0 +~ Ѭ:x{%-XWP ;"gND@O7g"3c&| r@\esS؀xTOTZΚ| &
+Px][/5o۟cr;pTB_f~HS
+b+c9+Dg߱*C{ɡljWQ= fUʅ~37]ox8^ԻT̢Ԭ{|Wpf)HqԐK(xQAb-5hFR_cZ1ԱUo+JQᨂv*HJNڇ0r٫iŨb|9z7]p CcQﺾc1$׉{
+)0^Aϔ2(v5 "}ԝa 3&O-[%hԓ18po]VcQG4mlr<Jy4`W]w8O/Sfj
+J(QyO=SY)xEEN.~_;sá2.8GHM$]̣:6Q<yGS}tLcWuā|Aϩ'+O/T!9]
+D%㇌ _xBEd?bf=pOPi8%qv#&ij90k.}cG
+endstream endobj 59 0 obj <</Length 18095/Filter[/FlateDecode]>>stream
+HW;\gd`H$Ŋql!+XfJfW( !$
+
+KPhhSRQ&E<|wf=-{fvo|q֚#k<cg?0}sx|x:yxգWwҼ3nC'/խqsqч5ck͸9 y c!\ȟ!G̓zҽϞRnJ<Fǟ5!cÇr H5nV(oC~'{f#Oѵqx~wy3/!.[C}S\{W~N)t fYq`'\D>K=UC͏!/C.XӉx\-q++=l_xn3,tNw'ɕ_^~w8 UNjl-mrs+/>ʙgI6o=u~rW Zg}g=T}|%̋yJ^x.c^,7~|X&E2gL^ɇ b>O/C^^7;gn\_,s@_T^VF>8."/5}eʋys}y3̋;/%Լ؏_8͇̇Eۍ߲"z yQcl`rx.K^K_87~_t^ȋEN}Ys's I]ʳCΟc#N՜<3XʡʡKN8Ko^?=8y$z56 gZh86a6ؙf [`{8pyd3Yx9n4|6s*IjI~6Hqx"
+bH/_lcdg덵*9<]r)5ZpDYeѩM)N&V٠I 33n}fY.hзNNBj6I$6UքY-ɹ,e!$X/M<pWTևHT:G"!9jv
+B\kHF•,э=E'!Kj$%!:2 †`hvR KQѹdzG^BCYiQ֤qO;SHM|PxX(zI@ 6GзâZmP%>bl,M%apɋXh_]T L,z"HVK&jpcފC3K):Ѳh|ISmH;T)q͒:VUF#1mİ+pt4:ʕs
+=R\S󈷍5XsGIz-Z#*Jܕ@䌭v{ S@.>VpT17mp,'Nh&eJn 怒:#D!1QThShbXT$Y*
+† V
+ +:ɨTL0a*R!29b6Tcm"WTQlbro4wXpY(x'm+&FeYP\uh3^<KI#VFWUkPTjdeYX+H`טp&%<8;PXM5h%*ƙ-3P eL*-,T\AJCp%)JyFV&v@A*/sوZQck)F7] r=8 .,ӠNn\s熥D_G* bHj11= Ue:k??0Q2Aͱc7ILlʹZթpو^Ns5seְ}+N#Ů`ઉRn0!fAq^02ȓH@< C%bx^+/sW]eqDy)/H4N"(D/HI
+BvLr]:rzT*Og)TAʇLEjj=3e㳳Ul_d3|aHWCMx.OX*hV; $ꂑ/Mq?=O\~ǎ!
+ծy!.W)~-27%״dk1^j#r2A9X ˀeP c6`r6$F^*iN$
+A }u$d6xˏ >tta hH9LFs@7A0v]LY<ÙlTJR Yʵj tV`K,ZBdϾ
+JSefJ 
+LIn(gQZ~Y]D B r
+CR6 \eGͱz`_.}^ʌJ&T8 Za #]L Wз"WkHL
+;5ȜJV`wm~$* jĸ Nԛ!I"!t?̑sI0eKSS_j}q_ǸE HV;Eйd}<g\t2lj둇 09R
+e}J%
+}{6u 'lg6,I:k/MnnbljX5$_Joٞ"-15']FidS_%?׈λrŗ,#g;Zgs -p7=":VJY[WЄaBJuQ+U6-6Bm .)YI}gd/ ovFh$Ѿᓏ<sDvI|@5VLƜ}CFӃdbDbHiMBcDϲ
+ԒP{D_ND-ȐomJjW7Au<&,+ӁLgAFI1D'Vt@cFV⚻T(dxbX,%:qd!*VviA6*) ]<(]&Pt:B"c:櫺I۴h! l.C"tEnL(,5 G<I[ا*)2> qЄR|*BRw
+w kYa_D֐:}HFZdM.A6T2Om@>9F̶!Oύ; ٷ8^BM&Cq^ؖ;'ޞCb=hAg^rdet⁹O'9SMFTwV|`wR?f3VO-~@ӵ.:SČ,-L:h$R,#1 r7U'Y\ k #CTȞl H(IFw-Z87q<Y?Z~57C: cy bg
+
+-Iaq $=
+5וo$y2}מO5қԘRb Kf~\AP»&_ }<L vf}a2J0)^6TS
+Eų.(%ƿ:u.Rfjv٠ΣImBti1TKb"ܘ)K[n6)aBxFeOvf#rd8c/;g+C^cQ b5GɾI"3, >$7b$e=g s="g}ŵ#+HB7gおPefx} /c,#]<q?ǝ[8x?Ei"݋dz 5[e:gѶ#e@EX3nɖ_HCkQj<`n!-N~A$4w|!waS t)-֕UþstSdO
+q>37<
+eE1&{cwh?0Bw<TV<{D/X's2b<31)7qV;g ec 3h &j~*Ŷ(eL##;i+AgI;ʆ Fs0c:[#
+n -SlK;ĸt+k\X2}.4d؞ُ.jUW &\iZUr~]]|0Ka
+:z"GGf7u?WL"AɱEr, ?k\jD7j,󿂷9;-zMJ 9w!k^粇kJ.Q3 Y'HE\R ]Ŋ$`$3p/D98vO>/ae5ײy
+-Eg)zug`Bw~o%q(ũ:в{/: ƷzTT8jRO(JH"X"1QDn/D$p
+\'j}9<Y@"KDžp%h $RxiQ"
+=(K7Sf!bѱ(4+wzӓC
+ha&IB; ~w_'IY;(l! s3h<? 5SUj R{!28۱SиL# Ny.
+&Y6D"i|O?N'EcClms] `°~mXwOY>i(^
+!-*3ֳ\bS R[r3"Rz4`>SQ
+~Hym_N G5= 18cf##R:U:~5Wƒ:BY<tYDaxcF[UXuy [w GeЬq] SYy H[a48齬>aƴM PVd.4 Gm-G} qk\ bl76`,y݈ שF̑նkw gh$gax}(-OROԲ;([cs>T|
+x%7GAz]:ƙKua+_?34e)c*ٱUc0mBb){))4is3+bL‰qvuDj. w(  ?)a>V+MhoP@Zϙ
+?UH_@RUSV^+4"3ٍ}k] Zuջ^][oizi2ᆡQ|E-%Վ&_xY~,ScOmJ0+j%#&Bw+mէA׮:Y0DR=JIV9+7"{wrNR`OY)t'TY gV;y3Zde ߓ.y!:x+BU{Rp鋪ikd{)iqO"y:D MRUD.Fhc)fnUQ!JNQjLtEHI2M1@Bi.PnRy
+v9*Ia_ڨS7H̚D`,
+
+HkHՐƹ'2L^bjg6A2vɗ֙pp}cģ]@fe"vxzH#9m'{X>ߵ޷
+Za#]䋙 AQL_Vԃ2껮ȑ >idB}Ylpaӌ3]W{ eoSSsPزܨ=B2K wЊ|fJL^ ޞaT@kvZ'id#({KB̫tTл(3͏Dg.9RdQ6((9@$F$Kc>SQ_W曥WM VU1eN^8"F nFpTI% o.xn
+yf q#$u٣;K؛JMOE煤Ưǎڧ2X2'UX2I<`yT^Yj#+=FЫтD43Nە{0eZh(Qz xllfaI=\
+R%xjkgMt`Fk$.nM$iriղ3MEuMu2.F ֒ǀ4&B jɺ*x2R&nS;~/!E7hC̊r8_Є u;fa
+s}b y#mo3T֑@VU~t{KE5HTJ H_/[oJt3a?e1֩,Zgnf@ I޹D:f:ғu}H\~vUݎ4Esy=ZXXm_Zy?F3{TӀsENfU73|!pI!-P[5{$E;[xaVː|@KFJ*\baSH`(VH܍UMoC-u'2SB
+/Nؠ> 49FQASIX74ҏǿE[-@@Ӽp0k 'P{15I7W:oV |0Oh%{n
+<Ͱ;,9c.M(N * - bNܤ#`[96#HQl"Аʋah6cј<7s;ziAEbavϹHN!T
+a/Zdkhg̺k_ѾEmbzG1Fo`4Fn<&3@Ggうwg0<s~S mY$s '98JUk$n,LEQ+.ePX(VbwZJFPIޭqiUe&' >t{؉hB0ӫrĒگسya{;pΐ]ܺgU=I/g~..d;
+`ߘ.:] yx?W9gg$D"3#2Ik#{=-־e@r7)rі*L"#׾7r
+ǟo䇼o.p,xfAPJn=nƜ-h+w DC
+Wvς/OP0b䮛%?
+wR~l),=QUj{3e
+n8L=y9a!p1+LJtR G֭dLW6L}eVjR_f*Aƒ ~@<?K Y
+zz;R?<&.+L<f' (Hj9.sCu7"(P쿈3LăS"|oe|qZ܋C>, rӊ',,Wt9Q6XSH8t{ڗBe 2#u厊l?pda Dӥ+7ca%e#6x).h2٫ Plk :;"[7ZzyX!ҘײIJ$7Z
+l{neE6kbzEAnc%Vv" #H:D9[Pe(<J)=I&[. < V䲾aMc\o޿ -w8ukyAJ
+$i<tҺt` 9Q#h㚹
+%p>JUR_sJOjTQBQсr_[z_b0yŸo+Q{cM^c/͌8@%NX+f q1`r
+ev; >1.Yg*299Qgt CI$űГ܈UV% chD`Э?y{.l=!loXl~|.~E7*yDI. ͱos=Z'@R s#{#AѿAT' vU[m_s ROw$r@t+=GBLIPTz'(bseFS&7cuB96H0,\+C>׌Y|'>o*B 2jjYfr
+E)nrݜ9I7L9=zYx`` 6-FިAXA| l1M9:yNER+OtO(~aȢ$XJWUF&t6v5l +͌}\TVڙZZ5 ds3 ᓏy!%&Ț8˕>G[ ^lbqXU%ǣbl-Zx2-]/5`.Dɛ-)~?c#:󒠽hy 뇻kڀ֚]mdf95m YQoi$-j`a#_:TqI9Bqd'f /!wO^n ]= [9ד#DtHp4}z݆=·۟[3K0Ȑi,y!Љٜt+&Ir->+eENc~ fO> hjN|=wWo+9ՌMa<xg.1Ȇ*Kn)s/ xCD6 x _npC!$KqKeXm/<ny ?V֭;𕢿 Ox8ebt9Q skT 8B6!,'1ӧ86TOF鬄/Cʮ`&u86$u7dBDžuWk>x"{p(6Lx;p+~
+Q fh߲U aC8KRkHBmB
+2T e6ңsae?T+"XvƆ(>6Huٟhe{ ߔ D:_
+ЉhS,d6+ ,Hl֓2w/(Jϼ,'hڑhk/tYBXE*ZqQ{Kh$*ŦJ,lwA(}q5?L%&!5!Zٚ
++^j!s eʇP!V⚺{$ jVb
+0
+endstream endobj 60 0 obj <</Length 16561/Filter[/FlateDecode]>>stream
+H;r- EsWy"{
+^zTѺ6>=?!4^y~ _%6] n^K>b!,f'^{.euRz:d_J$<ՓY1!Lk.cG͗M8Y8 6MJ"춷T0|.-B2&9/cٽ?1p\V$;vHwz^;Y[1$|c(RYL[;;it29A3P*qU%d*Olcq;?Adu|/؆- D?+Hg}zLO@ b s- XIkt hÆ )!:JBSNǬ\#âz[`{^ XȕVCB.߹h=Z]cyB!<f!(5WcjiȑOu٫rAE2UZ6moJYumn?}x~)gwBwgj NRQZ]N:cWJ){%] HPHE
+_y+2ltQSeF2-D>xVH(E!ScU1Cr&.+VK2O/I~1*S}}OZB=hnIAg]UnӉA|M@|pэ+
+MT'̬G)P?ɻo7p."O:.-F][wDW=`N3jt/ȶb!$IϜs-3W 0H9 6gC\rt*;YڼXt-y {@s#bxȓDޗ]1:fEqCYag8zF2B\ΣՇ .h=H]Ys̚=dY>c4b9d2LG;gx5[X0l;v]P4$)p\б8fZ_?73t'Pw|В@U9?.ϪЧh=h@(J,'av4<^FjF0O,VUH t):{muBv14dG/.{֣R& H\H/{,smݝ ӎ1ZFy+hzQAjx=d5AFѫn@;e
+H,| [IqKDfXi8_ 2F>]!#~4u.SeV@>ݓH70G 8yu9S,S|Rз?V=VڦW; RbY(8j), [`'q
+2u_JH&s6F~&imE>D#"g="r%$GѿVÁ@)$5Xv
+OV}4ē=B< ĨC<f
+r&DZF%]%ɵ0*9AJM\!PW~FIj
+,a3oDdvs=$rjV\P1_ΣϚ(;f$*J͘zЎ7.
+H_T5?ށ'6
+h޻95ZXFJאxWx'Z˲`鮊OIQ1=tc_ò=z#্lP!Cl%U"8<(
+kYjXlﱝYI=
+M`.Hgсm:S re0<j95\q1u3OR5ٸd.!m\@9x@f42 bB$-"ㄌVx biTV^N @'"A=I;U?/0̪A~3$[#ǧ+
+*aȊAEs@ IK̄=
+qd.ogGVRŦ
+ӕuC27%SNT> , =,ɱg!32cYc_(GKLC'loVu$y:^GV&X\jl۵ّR# V0d*="%sYLMsdP3# 6u2gze>iE{]/y*EUy/K@#8WWJ
+ ײ{O *&gH6eED4ͽMj1aF4 lQ N:mFħ {ʉKTA*|PMn SPDf|?2PCwj$zbJ{_oNAH#{f>udw8]aI5bk"L-.p(lgĦNw^ȣT~@oz$4pNq* 밪o 4OyTsXIs
+w+"gYe[3sƳwW}DټI\F_ݙj@Lž7S/)?G݈;x{ ^
+]3+J }lB4W'){{ Ks,%! B e[g^W)sGxc?QH;|1e`~6<Ё?_l ڻ};ںi+GeW3x:䴏 ;C6۠X$e: 7D"/_R'p~}wnqkL.- Soh/Ҷ6b {9׶=]~oݡԭ\xdn@jԴП`~ۯ 6SW 'Ĝiͱ7g\1"`#Ώe``~,D;e5D <E,)Lc㖏oCMUF8!BQlh!\:/5 p8D
+ծ>)'ȋf kov"SFt[w da\ $rrgWzޔxK:H;/XmREuTB=$Fz0geanj04߀Re05\FѮ5rʙ0X#<dbrx"Gs@ %e'e<GhJ"JcnN=W!e__-(,FHSX^L6Z"tRvѮIJ-2n3Ƹ:}gCmKHk'f')} Z<WD :89,$ǔF4D66fa2Ae_T=nKLtWgz
+TUg(wBkkc!oE }}pپ{=+??sQ_cZaQF ^a.tQ
+%#
+XT{VZ \z@X O"f7
+#Bi$
+]>a'@4.WY{N
+/
+>aFV9wW?]H׌+R 8mLD0W J~E/}wD~
+`|(m}UbsX
+MlAL8>*K(K#B!>p2@Z"/u/mFP[ZV" Zy\0u{Dk,m
+ţ`TA~1‡+EUqksd
+LZW 3^
+[Iw
+ ı<BrmWY
+y.HT,LQ䜖
+[fڸh8ywV1+z#keȟًOgmq7[?vջ";u1ΆB_ f5L"V-\ʲ+5ӐuTz`HU9]AflLuө l œX2$}SUSAQ֤E @|eH QhO+F
+*q}c&mIn~g^!- Ӟu QHPn)
+2S.Hpf9}Lr~ nhIYd ͠ &U)G-*Y@HV+F9_f+-s+y $^m/d!5 D٘>r p1r#RlRoPBv9qXiۊMB+#6 ٝ\@jusYԿIo G˪tTf0n19O.ILj݀h^cm6J3X`o#m]5~Ѿ R؇Yb]A:`DQ Ԡ$N0C5e2M<{EPcv~b 8Kx
+9TcĜLϽ6e77 .HLPb )}A} '$uQn[merJm3: =0 \ Ȅ?$ |{B*A>g^߈tvT#|wH<y =cŘŦZ5ʩ;H]ʢ%2FaH؟l J{FF|э!cʮ 5u(EPFAYmI$6r6{ E1K ~b=SL (Hͽ`J^f噎>c6վ452WCyA
+d(&0+,m>vꍼmzM2 <
+FOYĤcS-&#"6bUǪ\ۋ.Ԣc@qOY3Ϧ_-oC|S:D6 `NpLٶeuRCLqas<^ik ~fa]ܖz.Zz8 XlIWyQ#l~*= h@ZVm݂4!ZW>n!Ir( .VulVO%<
++.7@l;ǐa85ѽÁ>ĺe.w
+
+>WsEtRyk>zyR2X@v
+r{;З;D<o]]g JN/DQA3
+`w:tI -:5uNn!D!cWpb]J
+ssv\q.)1ih #ƭFzH (0VFt`+i-LJDdp3A
+3f[ze^ZU[{)-ܓM єIKz%Cqm).ҋٯ]9*Z&J.CU]% ! X'q$ xxFB< (" "( 1/a}Ǘ3=3zf{mg`Q|eFJP~WpM){`D
+I ڱ6I>N >&Lm3 CR\X4Jy!JRh,*IzCHX*QyRE666Qւńew\s *9-f<?Dbz`*y~!+ȉ^GJ
+da
+m $$F$I49T
+렿Rr!vZlD% #$}UA)kЂW~j^Tm*@ <`EL'оѰPmTB!25OQ!r
+hA4X{0mIn"er<MT  #"о"Ry
+>H
+˽RHۨ
+-Q]g@"s,쀴 DY[QXo>'
+ i8[A/eeSKgv~^%Z_*m
+<%T5SH$,de*AJ2?%&21eܐ"רD`W]BRk!ZkHFWbRȵ!u)H~ diLvв!
+  oB)Te=r@KmݱQ@j#Y(y9,~)M].83(K;NіR0L9| ԣ-
+PS{9y>Tk5FAK [ͯ(v%)
+x~o { 7[H6FsG/.tjn+'08ѷYj"7R|& m]3΂6&q9a u){ڦ%xI)Ӭ%x36}|Q S;o:D\{.>{wgwFzl{} _=5>ŝ1u4.GYq4GƘqIQ<O}P/8i3}炶sϝGh3:݇ڮڮڮڮڮڮڮ{:| ;GG~G:pݻ]M/ǎ</\X \׍ub|<\ynׁu Od^uh.r>u
+2V]…agB3 p|lƇ$p导t|lBw&N`C5_ ;.r~ڹWM"tc>ԫM墯y|>VMv.*cSua\u1^ Ǧs1O}>*E\Bs-E΁)42/w=uϢ}OgeEo}Ucu
+v?C57 bV^_?U`WdcSŭ`/qbfy.+?WC\lB|>̏-U>79 |Fet1tv?s G~nߗŭ 9~Թ\q:2w/E e.=96q
+.&X?xϾn/߲tq~ulK7X/*8h~~A:xyVv;bbbX_T>|ѹ7UA-^镗?wոXvXO{so_>¾c 7w?wk=ߩ]^"x_;whu1D9;'?Q_,1 6q/~ǭ1.v~νg툋Q_*T_&>S/ ~sǜ_5p|MxS~N=a}u
+endstream endobj 61 0 obj <</Length 5874/Filter[/FlateDecode]>>stream
+H pT KGaydf)<BJ@D!
+ǴԱ:HU"
+ϨH >ꨝZݛn.;̟sf~wѡ];wˆfefd=_ RPpu+TOڴ:H [ 4 T NPUq4k*ƌE15jE[juw [:!C\?"8
+?#~+GzzShlH5k5ˠw c5>{Ͻޯ޳xi9Ӵkuoy,+Ey{Sroo
+ңr/ă>9-|a̋XE,I3By"PAhpl#{2;Zڷ9A:""XS,{=K?;(8pN{zRy1xx߰WE㏝.9~4zЈ8c+煷o/մ-GޓT>4HO<$ޝˉI 2Un6F!O^ta7_kEAAK- IqPy|TdqdF[ƒs_/CXꎙ#G;x_`ؗtO쒞OߟT^,Y,2ƣW!'}ђxmhڏ"zoTr8)pHxYtMy=WIZBZfȍ'=V Fڏ4a?/832W0X# IlaQS5Q=o9Vi\YjVJc8E%[Q[>QsMNR|eiuԎ).]`LU5C僕"{ldijE_$hXHqM/ܟxJyq%V +x++wZ;rB^Xp{Թ9&ojlHo%_ijV\q"|afOf?$з|Z ;+BH!|aZ?$:/y}}Ⱦo_(V˃x*O|ZVE*/"틔Xmxb`No{*1۽r_F{
+‚W5<%&GO)O\ܟxH)RrsKk|r˙;ʢy4S1V/s9r9]N0[P.P-))t/ y |.gOs~ՋCE[rt9k\Ω.=dr&/W侉-zĭ?"^Fa~[zfCP*^ӱ8?^Gv\鼘\*NqqHy<k`jrt|m7zܔYJ^E.xd|޼|AN͗-pqׂHJYJ^ w t<Nt&5)RJ)RJ)RJ)YCMԽsF%ga`Non{s? *ѽm DGk]Uݳa.voG+KyxؕaxڎY9)Ώ<;\c\xNDk$F}}Rdaxgsf7x$ CI̢zty$C^z&?wդ&bsW깘Gdcad|a3C[eJVf_aɘ̾*?\Uu  j JKA
+bM5QHK(؀ePU E at
+cU԰M\CڢE0k @◢{:'2+Ѐ2<fu+,",˦c1wMi|q
+*?n'={tn.͋GqUWMd2C2 >'*XRuKi)m\E0a(sC:~&}<Lm~!CA fjFf@<=/X; 4sC4H ΰCR˃CqSsZQ(ǏwI7k=1%s'd*1..'^7ů+y3}4hgg{*#S'|&dج7 3+{`O[SUk}7}僛"9.YvT7rd?BpD^8?_7C0ݐnv7p6c}uC^7h .&.uV/̃\B"ɃzE47pClqX΋Xߍ\8nBy<St w7"i.n\8#U\JO$^/??/
+endstream endobj 62 0 obj <</Length 10542/Filter[/FlateDecode]>>stream
+H pU߄
+to‚?{U%%1Ij<Cy^qeIop 5B0s<;]!#Y9sc|n^UP \#F\׺Py%9?…!ϙ`#XHr&1)GI;p gs~Nȯ!*{U,*ϕL<DBC˼
+Wf_X̾#X#\}!Y}aCW,|a,!?< S@`Oy,֓g`
+F?#9_yJ1k|n~>_U}0P,IR3,U f#?(r?<]We"3;5/|7Zߺ ϥrPL".f?Yl0* >c܃EO`* oP`x-yX3 }r.&`To5/oOTrp,{0|aҊ́+kbM}u兿bk%iQK `Y#X||" YZ"^_8UWIvE0{N<;>d^\*漐笑ڹQ@ESݿϗ$W> <煬 H/ێ _\+\8%zn y^A,=:׋_yM 8>#ϗΈs[:ex>ճM׹,1/}CNS%U#\/wWl?589u._hF]^Gx
+(:F?bl``3x8>^"Xnr>]!OHy?|Vs,X|o~^L)[Һ ̂yc?e VAa(_l8ؿ 6֤,KEZ`E`%qXC<P@qU7Jj?%P_Op`bMQ苆Ɯr` XNef̂TF~]|C9qbD"u茷ZZMp͋4 ˄?^>/xpn9~FnQ-MוI_;5<a+qr%`aǯ 6L8xսA]HvI^̋0z=L:TT7E=k)%/n9qlTK'`\7uHm/ôU.TTdfY?8y-}qpnfL~P+}LMVr.߾T N-<Qqz><~Cc8vhtv/SZ#c߀ׅ*j0 +7N
+UPF'` 1^ŨF[K60RR2B1Ub3Fs[SVJiBܮhdVF7*"hrg9A9 G3X1lit`:o ddIWrSrWAmF; |Ns H 9mT@ѓ#B7@0rSzV35(Ē,A-K"h{js 63ȁXz@0xԃ
+q,Oyb
+)X Fͧ6{EN$Je:hW4".TׇSh^C?'wj铗Wm7@^?q=0?MIH+$$!z=!dY`ˡkf!y{,Y
+AX;-:~FcbkR;R] D֐ۏ(Emq饛m F8虥|8wz$^C;HO@lDmxĽ!hbbdC}pRH$g4nkȔGR(v?e6Z$Vb˸ JGI^@b醕RhFX+rp(3󢕴>̓#|T7Z'b6VUogOKyeq^h,n,MF w\ AP(@P&`̰_L<r$4v)&Q5:V䘺!]
+TK z↨:G{q1/`%LwQ'Qd`)KEo*Q ,_ٕ)H󬻜hoA*wmA5W0q$sz`DZ}3LW ɈhpQ9j0 PWaJ޽{]3FES_RQS`$1ێ89ㄸY7v3r܋ r,;bvi|0'}t
+Gb1^ki*]·A,or663} +>\ `Uu =1\6Xyd|+A~B~+0Ow?y)҄$*/,跙B& g!Rv{l<痎Ë܃&Sry!b#ō`{c&kG58S[=zosէ_GUHӹ4;k$ʲFB@l9QZAlot⃩}%c Tm=Y4Ɏʱ`|hd#5aYQ"
+2pk3BG#+fk2~R LA26}ۛ)O![eޤ%XБl}peQ"#} #% 좩[-cPȣIP5{_
+6%)ۼ9a#p>iؘ0ܐ )[0٬h*@"R,(mAT/)T׳y-L,9n|ǑHx}Hk;ˍj[}ƚR(hZg+Fel dj%F'ӯ;(q(\*6[{Ô]r*۲_z5!fLӪ!. i[+t
+Cn
+jw׬b dyWgy=<!烃5+ʜTۤ腂wo\fez,<"0"D~%+䄣5I2}xsS Ѓ=͑M eq3WEJ@0d& J Kr伷x
+(FXCn:}"> ,>0,GLw_BC -'Z ,wd`u<
+3TUhU<~!"HՅ[p몤Ra0(~Yik#B\trTl-icHːBg8 O
+TP?cqM!pDR1dz 9,0jJOMFcuZd(]|~wțeg%0$b[^6a;2ܗfVGtڢ0էDe](t\α7z)Bӳd`Vi@W"DSHӾ yŔIDFP溔t'/, Q*M$^=󈸳;=K
+4;=fDKR 3Y,
+
+VҼ8zi`
+૲APb*yU_Yl
+)~1L#Ф7&NIXӒ{ُ8RM_uv$>7jV 92{6O`eݷAv 1N*]%3%kM9< E5F>ƅD
+^x' 5kV"P kBŴQ IFɦ5B& l
+Am=JA:QP|/]Ss:)2:0v_iih_*lcH¬0{ovͲz37"@Y2\s|N25/lIDҴgOgad0G쩋$) ́`p8Rǔ.ͯ˚?K$L<8t~Z6_ݣLk"{`$KBa,׵ W ,HԱvCw?l/:]W:
+(%jf_BGj. WЌp$|L=-tӭ ,@<aH:~.}ZO-5#o)'OIpXtʹ k? AšV`frm4[ s."HC/|YzV[9 +-g'rz#jdnW MxoD
+YٝX)>|y0ud
+-ZMQ</[=jΊwmzSTGG8{t>7 9TR*mң,o(x5(E2# A]#gڳa>i.pd G-
+* n] ygڕi榛dHљٿ@V*CkehIN`Tm7_4eD'ݑ%)?JUҚ3FQ 1yԒ+YW/V *8\@`r[?G&(92J[
+endstream endobj 63 0 obj <</Length 21808/Filter[/FlateDecode]>>stream
+H|WInl7 |@Vᵿ.zY,/skҜK>>1D)nl
+2+pXnu&7h]+
+@,tlCH^vGsvАAw5ēLo<oSs߫O!4x爮:R)WD^9AVc*H((U w!X1Q9Ɛ -
+kyk->F0f
+R:'zy TDRl<`(!դ
+~S쁈䣖bcź.ii%$Ly7V)xLm96&:F7H}zBl<>Xh HM|4Ӛy6X[58ǥW9 T8hm=lĤ\ކfit7)=<ΦbS-0.MCP [ʈ5#16bȺwʞ`oqp>o{Aon%VEp,
+l#K@|<uܒ{%o,^WK*i#r,m
+1Lv>1YF^:uXD3{T{q
+_l1؆9i!% 9Js+g;>]PN+GdaT2Ǫ6\"+5cj7D78P hC 1o: eZPfx kY2chv-ó6ͬ˳3\m.BQȻ`Q\+C$!4YLoΣ%
+ߩiLMyz(/g"+I
+2[̎DΨ!R@\t;34;_V
+m4'ݘ®tŃ&@ #'"i.+"ze>i~ɄZBIy۞m܎8K$|Ga#
+6\f~MK$9oF _oOO ﻄP4ix, p
+N2B䉐6\ҳ)Ōp4T>Dkߍ݈׸wϔsRi 0qޘ`zaS W]xL $"P*<Up+]FE;/D.ݵXΎdqd%]0!@90Å !1"1B"r,XZ N.氳@Z<v8期t#Uvͫ-y]uz὇ePw>"f,c$
+#%T)d FjWΌH9쾜~%
+ojjDbLc`R,x0]Qaudj 4 Z 4ױ.%f(/eJ_(ܳcAޑtL6~" э dRXx="8 g
+ m.H/FhRynb &"B')X-RZX=
+ 3T0
+ ђ@dG85X
+ձUV@}:ujBBJ;su,W.$w9QG?{5l*DsȢxљ.gnU[֎龐i 1_Oc,.>]r>['^MGp
+
+#n؛s,wM
+FPb3<ԽO9v߸/ĘMB[gF-
+FA|;5/Dh1QS H@2զ5x*^sBL6j=OL!{<<H;Z
+!lm/V4蹎_+YhQ&\ehRWMD?SU1N5xSs kLC=!=,3ɰɆ[:Xױm*ftA]O3'!ɯ,igQoKIETV/ʤ O@cL4Z4) Q3)-O-y:6A( xsHxSJHӖW~5@GZI=%3}"m|1q҃\>Չ`SG,ȑO\\Frk4dnnjXlN3c"yQ8;o%XsSG+G^P n fWo AXqeCJ2"L?nj`V
+*[ӚOh> ubE f<6t9tへ7Me2 4(5[)\0RY$1 wZhVa`5R=AZoTO Y,Y`YU,`6–oYÂVdx C\SJqWEt5Mys Uju .{ܐo ݼdr(*X v/4
+nCʱ-vOJ%O)6<_w$גx텃Sr8O^/}dZD8dbx>?!}s_,?S`ȳж){ӵdx
+S).Q2Stb
+ʜ?{|TEz`D`z(9jP' ,cBr e$\iI5čL3oi/7VloDݱKAGpCSŵUQA)挡7,= C';t2iW1<gmEMrGR7釈}O XVY‡oۣ8$@HCcۗϳ$R
+{lUMĊXm\LDkk(M2qqHG nY\g1mYg:t^Uxȅ00[N^@N,Ž(ϼMQn'K<sщ-J[BX,Gêe7#k vDf~"2@`r%RBR{هHa"N㍍Lx,2?} > ]K +x X<\]jdd.i{Jr_e`R[kqS|LL-߇*A^ y?W 1tߕO6'MO1;mLs3d>C*j .oeO3:HDF~cw])qi+.0l]>R6`hlQixF+x,8xh&cKm3: z){! -\tyqƦPtw)ֿw6AlMx +ϷG,
+yp4;ȗ s sŕ3`IhLIt~Q疽MIՁ: `; 9*5u]5l C ש=ԫ[.[`s3uzf?ϫg.:u#xzf]9Ͽ<#FLG}Q?Gߢ
+qMnbb"F%ܵFtw{Q?o ;N46ә Y̷UUT+y5eDA4QgXǗ-ÌSfp~[qRP?D:uOƗz"#v
+nvߝ
+'k
+
+hZq[GӀ5E.A>FV(0|zyeV0쫡n];eë4d(??4"57`3UZh+"6?%X~[~iZM#rQV\ɚߟH0qY`4d`VQBy(T:P;GW^bȳ</C].$RsK-s.m7}rC /M2茽M)i&$2sﮬ5Ȣ۰LMmd%"r@**ܩ]8ڦ iN18qE('.* 3Aj\x[~
+ȂXjPCDRj/" { `RK؃ lY%[<szP8L5nP*yH[h 8Qgihlƍ.c,6oc>1R{ȚA)M>F+ߏa%g:9O3`9\F$];HK[H]@6>]Ux
+t)GLQs hx"Z7Җ? GygDn[B0séoQ"\Ez:Ig <ܵ¨\!7*Z 50V*K=:HTncu8n{
+lpj -Rh)m= }x2X!(BR1DHD<^LFһs62EI%>^F,3}7X j~U%TM厠03I7w'[6}*^diQ?dDJBr IB@01/a۝z[gb+}hIQ&!5<6b\QC ;{=d>io羇p!޷]`ˋ6@#T-&Ix+ΐ#>?Yrqa\9M#g0CN{&v0ca@SȜ5 qJ,ziV uoO,"w3/P9j3HCv&rm6rkw=,dT`cT<?dmIx_e٫%yׂ{`ꇊfbI 9p=q@Jŷ:ܠfr#jō7,19DN4 A]Wد9xϱ+>V!ǹnvJe@,ge>ylS?#R3|DԷzĩy#Q t84@,hKΘ}2xcם޹N~OxӗF=D[w 8KtnX>|vz؍
+҈@!\4Nz V~r. n[5ş5YjNXj|8
+͸2jcu?
+jq+E͉!Hĩ+?@L | FBhe*;`36drdpel:[$LGHd\;s-Yה]_c::,Zdҟ>$YqyxxNU5-ƭb|-
+x L=s\p7?V#lkKc:JI eNXD"zʾ1a15k9\K{TN%cJݑIv?S9S'-X8`K/l X{95eGVfpҶDطOmF/"rS9eim!SΎ9wMkzӽ4@f
+@R'aGtvgGogNJD8mYq{ctn<[{~nwq
+>@S$1'qlՌq2LrD8y1G{77lj;F2$Io'; \`'];l3Wc- ,<'#ˏu]:2Hi@[=3pm̞YC4}?qVQV8":A<^cnj] UWtQV۞l#Zy^ ܰyXuPx
+Ɇڳkʛn|!B_`m7=->
+αFƨ#ћ~"$$-${5iuNv$1:Yh72
+j8xp:xv9}D0te*%Z>_?,$LYA:ot,| `9!'q:=zd K
+V|
+ ojZ 3c9mZ XWx< 6}DqOwdY_ 4koɲ*uN]%$#rpOU2\NaaIp83CzPiRHgZy:_έBxP)L~B!"h*z9(QG%HIS
+wQV4UM}`)-LAEmhg!Pl 0wBD
+9^LD Ü<1 釶B8ir
+= qKGclV͍:>|PϏ{~W/0q_Ƹm<Hfq|/3Q?fa}1=EG!$'3gsK+[@!-^@>a\^N$S>zEUZ| h֫|AiS<Y8/xt{M8&f` ,hz[|La_y 0V+EKRD/`c§T>U b[=Ʈ#i?ȕ fK [mvT{.!nYXMa\17Esz9`_D,Za}^#bXQyF B[om5zA7?ss_<jS2%pͼFy*WzuI$8V 3$c1Ty#Ate
+n  ]w]IӁ`(j?E58 XJGpMؾ
+uW:A'ܗ` +NYZ #p%5{.]˶ cwTbB ;5]QsC+{&bI69'T$~pg/qSB0-1̴}[blP_N1Q@̂:[olKiG,Ur+ 1X
+
+otWM9> T05??=ny%<53z9ù ]%R"P2Z7nSْ̉z0Pr7
+#]=ޟOQv+y~"G3!=\ئs?!2$hw}/*y H
+FS{B) ~ȗVLDlYǯÙd`87f U{ņlc<XróbnvK<hy@ fTG0U<9CQƽ.͈1>w^b 9Vdo $R:]KR+txAx/fhjÞH8Y$j|Xt;YN&X_S E=&De8w:Hm-wG;[#9\rdu덀Ku!xu?.s[/K%a
+#RhenňGwd*CO0;+B̬*nc !kAԟHn1wPbcL$k6:S
+>
+s2=ѽmI5.^c K+(9g+/1( "c<X1/ &MP5Uݩ*fOaWZiޢm6@e? #$VikqrG[e>*t%oTTQ P8"qɵ=F^e:Ʉ!M֥Uv0:fWRy
+~UG,ChΆ,RJ&K@jf,Os oD}Y\VywPvw5zDKJah X6F3H@&o{b*/=nz'qVOE@ƴ@BDm2P9+
+D (!CMhg(r dծeAXV
+3iHM5Ms\#0jm4/[/ګ,$bOC~eL"-`,0Y- ][q
+PE H?#%F 8,;b+ f3RFUݴyq z!l۠sgC3L.jpoxOkGvKxLBאF +xQC=A7IqL\* p#/)8R@Tu*\izL''G:ԧHӑ~Z.g aȲi)Fi2 5D*f[{F5rW݅U5Q/˩Jug^e4SE(.r_<ޖA )g $MPlD`³ވ ҾAbt^)t^02s_^I*md
+u827FP|i I0&#=Esb!eif]ԡ[Ǭ<i}|ޘW].(О5և&Vͽ;櫢_Q8<d/T@??@
+|(QWBm=
+VȍX_mQVeFbfrO_ yT{|1Ծ1@)pdBΌz@e8".\OAM照uPzo痧upec 2,pٸHIoINF8{ߠuE$BW@qT38
+ Ul Vn)m-,w q Žwei/r S
+amH"PԮ}IJГ΁h K$7ps%V|,ދ--s݈z6cYjdqݳ^k#!#1<$T '!R!2& *:CχF g2<X%%@5Ӝ)}xqWgٕ1} $̭Ri+ǨlY%&ӅU΄x|hiɋ_?aP/ }
+hጀ }:RI Syn]_d|HdPH9OVk9ԓ{hDPL R.k]_;}79x'YGܮ:GD6+,b> ϻOZe[ z[VYW6
+8B^mIO7kβgbL/Kx`[>q/{8NpGW=FN8*땇Ч0I\e nȼƍMTe9jtL$ߝ,Dɴ2勜k3seLHO\fFU?=l$ .'*,LyPek)O?8pSDJStG^ bچVߦyEzȷ^ 0$`XqQna0oW|%H;.
+8/@+˗"]y#e?$4^q'>Y14lԴHqu,nsbhS$GJsQgAtAKHU'
+H[G:*soTrGMHC
+endstream endobj 64 0 obj <</Length 7460/Filter[/FlateDecode]>>stream
+H99E6;<B
+s2kZ$G"D|hո)YbD
+8T2IAf^snjd2R+8]} g:ue$mo~TĿh 0͖i
+h6{y 5"8IlDĻs$VAᇜ u9F| Fun*"k_w*?khêZI(nW)_Zco(C7`^V=q0w
+
+>LڹVHRX#Ἷ>f
+ȳZ:jow鳷~Lr#$+r|%31{?[q;$<]C"q !9=J `pV[@vGm<G7ý{ف'`*6Bﯱ# w݆L)_,#x9i\Y"ZkT4l̋Ƣ̴{2R o_la Ez"|@8Q+c")}ƝWYb܇Hz[rXyQ{Vxq,&~|Xn'irOƟ!}Z|W_?{;F~y|
+q{n';<tbsyxٞ?Ewl`+ɪc~*najݘ3:؂Ϫl,3u%
+0:]ﵯf~񈟍vhǎV|`XD; rQ GY]u!Jn@ :|p؈؉e .kY N*וx'*fEW/$$|sŗSQ2?HWՀz ?gk' k {8Ë+iQ6%g:&X
+^cL<HϽt~ oBM슇D( ȃn@&>ģQdDN07C*3 ]|c>xʢʲ58=Ra.~~xt"Vzivb-xØ{;;?^m7hf?%=1*x_Q\;rj/'|̓3M_-QWB 1h@{oF(Aզ
+0Me`sX*M,ŠblZi.#+[˰%&<a'r1O&a92hF<8: FP GtKԔ+1ZD#|&S%ŋ嫍!چnDs!N."Wؤ* #p =S\DQ] F,[1]l
+[dU_3Mކ6%m˟~:NH:rSOE 1hb44P&$>hacASaGH ;RD*;2^TSEC[ M+B %\`C #8Qfi.#\
+)IZDce
+Ĝ:(^ή00bxEa\iuUUPgJBsn򖷼-oy[򖷼-oy+7_[Uˮpc0FeVA3X^Gg.˰el?KAF,<l#[xqxL#)ҏNULl u~\(50\(&}ke;/T<}xA&qt~
+'?iq0<r IE%yx^$qAתZ.B ^9W;5,TL$/Ԙy)*W"G.ܗU^H,Hگ#ױH ?E&G2,2vu_xb @r$(<r]/_̖ΫMFLޑ8?/jjR)ԧf8U~njbҫϪ %S ~^E l{Aa! ,I:#W"$Eθx_}8FE.+!tb)|pP񐜠kqN$/?|jB0xx}H=Oe9@a3
+Ny<`xz~+
+as+ԍ=x"^/؃x=/f]?j=*yљp|uԵ
+
+$VgT[^`Ex̨yE[\n/?Ȯ 8u.~̰CUpϛkgm =|
+M۸E9ڈ[37[nR?<,|r?y=B/CHƧT_ڿyVz n1~F9|aÎ~pdhLQ $BE|ώrSê&XZZP!W?|~~LWLbZ??X_[l:( Gh Ãj ;(<UҳzWG:7jk,-pr>*m+ʉp<R\cxʋry ֻ_*ӺyʕੵEu/FNbr~[K'_9<c _YT'}yH?i{n\<Y~/x\pr^Ȃ<SV<yfZ< Ӿ _87bjEksz]hQg#noa^-,@pM^А/Rzz—/_R[[:?;}z:(fb[`lNq:Űɨ$G䐒$`$cr2$+l>`ddPx4('2p /?/IdrPL09}d(P<Q[ID|Poo'J3\ۏ()J"h2Xլ)⾹\'=ɽ:Gd#R?(>ݛ;;J YY p#Ir%R4%)9"%iRJH8I9YI!=6II!cdz&ۦ+,NI Ai˗/_|˗/>tc޾U}VNrhmn;\/x=rznka}zآ_Zv7\ߍ,
+ZzZp+ a<x[ ?Rz}# aZ`yxWX |& 0p/@XEnX
+endstream endobj 65 0 obj <</Length 6168/Filter[/FlateDecode]>>stream
+H p7/…kx&`#`D&E"HC| DIm㣭:uZJ@@atڀFЀhZb=gK6{o 7{C9vo=;o#p^ƍټ*Z;5|='7ׁcȀx=&9cS1*qeǨŹta>V<G{\]wu0kb]g<)<{6z(&xZD؊gP\=z#
+W
+M5ہO
+kS>(`-xN)o\p4l>?ӍQu~Q
+ 鰒@|cbV_iBZ $
+c^C0c`{3ʉ\td8  e}zlj݊ :wx3qC>{
+Doju㱺
+7.ڋ+ XŃK{fB|R:(P\*ZZ˽U0zp~yok/w5{_y0%mGO>ָR~{b75RyO碽H״zo-[?:<L=!:ƒ/ؿͥXJQjdl
+'p\hWt0Ŵz}A)dw UZtGwtGwX%\xB{4;yU LŸ[\q_qgeg&egeMp2={|Zvnzf;++/-=k|=K0%i.-'iIw?LOngΤgMHK+g 6˼6;=[ O8C=A|O3yˤS\R< !@
+R֠al!
+3 Աj(ȾPQ!!,uNglK
+/'ܛs?y9=xH֬ي5uWĴ=e4YCGOJOH+ 3q&$9N퓐+񑾽z{MIЯ_Bľ#PP )t-n&8nyR'$&т},nVXaVXaVXa կ[=TeU9to>ݺ9zPV߿Q{WUUXyKFyŕ5x+ Et<>8?F_#B+!&M uN/X*,L 3BP3YdR>q:P w|<L<+}Y/t>jI<BDBC;e^* /Pp
+P \V_xU_(V_+;y: w`NO,0?\|3Ps{<bP fg<){rf-/c7SyX}a;U*<X#7%%W/E(ICz&X>SlbA(u]V.I #TFET+Zw"t,BUbڏS]qy(O18/? K?b/jOxIR.дQmto=/oOٔ~ u;>oXNjJ g O0nF(_xˋ@Utcs.1_Oe߿|p/T}z}3@^__;Q
+O d rNiyqȉCkcWl}u}N5v]GYEeOs
+i>xs+,>uMf~O夼5y6} pp/M#Jh'>׏F6P,B?G)˝/o:/}Q916ɲO?~\MFDaDruxA0}n&_f]/)1ϹM8=E<pWkx#ӥƫ4eP8ƿ#LCmšm @.yudlcnM.\wbp %k\Uf^@b)% qPud[;3_#3S2?0\Vp+p@g 4oE9r.b.|k2~6_:n.hҹckᘁs dylc8r5
+xBy nS]^SGi7IH<"|*.
+,c.K-7pߝ }Li6Q9x;%sS{.0X12*9ύOD
+_yo^'}/ZG2\8#'& ?{L}do,%."ev~m;zrc8P.pz/P9XRy< i,H::vr^mQy~Pz8-wJ'&K80ΐr|rW" +Xgr.[
+ 8P9%Y,,Ƚ?<!8wwh_ :=د~}}Ry{d1GˍU_番jx_T$^ Aoݥ}W5c̢KB]JhD\|-7ޓZ l#›t6{Cnk~8$9AaCLP /g2 x|HHPOʚ6Ԕ%K>q%MuS\3Sg s\s^(ٳ3]9OǤkΨʿY61"ѩ닇?[䜪:7GQu.<ՉV_濿#/5?x|1Ça0#%?P_ N?.b۴C9L4=(TUF"?А0
+endstream endobj 66 0 obj <</Length 19264/Filter[/FlateDecode]>>stream
+HW݋eG_B|1uAU]]]ݾH$BTP̋d]AsνYdwf2BKUwu}?߹m{ӏ~.{77Y~l}XY }5m~LqK>śc෷Ym^|ŷ1B]X<㪋_{^<{uq~}Wb̓\CR?xxQo#oُ?sw._~SNbaδ?>.0ԬɧeX<]?>~ŋg{"O+B\R{ `ت|iGu_W_?O8U¡L -v־5, w7%.w{ȼryul#Lo
+GN2J8.BEZO{PZffKJfJdne
+ސVc(܃#ҙ@j2n"(-zNXڻ#zؠUbzd" l2g$؍C;R{fMmu'ٖr
+؋ibUŜk[ WjFdeq:=oT(8Hn5FSk*F5Mt;4o_hk$n;l2ħMO!+5ZDbv"z j]LiBkQF[)J{h9%[["}Tސ 4tlt'(-FS&%)ƈzGH5kg,!5BmU-0ݳ6(\,FJx-2hȃ:\K`$Yqc2KLy~07eQd/ Q
+KTmfnsZ\((Gp2@n&Xzx a
+GQƣYR[ɒwbeN U@rfmS-;2T\3˳z!tZ0|@lF: Zv+h(gb>} bT'A}xΌaB0 1>
+f8NѨcv Ws&W9Ǎp!`kz=IoؘdhZE4\=(F+ֲWO hhU9 IBk
+b#gQOF$;x Իլ88\(Z!F]=0 c桾t~LgYϕR$c3aQm, 'cc&*TwDC/NilH)yUQ)Vcȼ}ѡC噦pnz%<Q";D_M
+Y&#.˦=eq)grǴCNv0Nep^X:GR1&2Z"bS
+y1~MRѸ6@hi zOw YM֡l`Z# j)Je*O 1KG̤g!yʴ|fnէPR]:ً5W= _LO}jޡ2}@F])Q=2[3 q+2&lulMj.YLԭ$7z
+HdQiNj"C*d0QhKKa}PQ1hHZ|vanMϱ,/ȓzWT-d: $^Bw:0p @Q]SkP"MW2Ȓe0 !|r|#
+v0 iY6Z3(66W `Ya$4z 4R/ȰAV]w|&:Ȗ:)1.00D²U$_,CC㧍|ź@Y@a 
+Ř < 8_Re)nu_ژPf*aZ}VUߢO3\Ԅ<y}jJOy(\+d:dվ%E+™{Ytǥi]}ʠqd6V+/Xft K190͢e]iZDHľΕ-UK+wq9:Q 5!,lf_D^DE\KD`Q,QAEbr1BhtmIrNݚ; T7K(6), q¾tujB"FξьE/r@AD"WϘGQta@v#6jc$
+!?z3lI|Y*'.k!א: aS~*U@)xtIE9wkL\6w$ ӝ(ZV{uhC_@TվStlcdYH[]MQFMcZ1#$d'
+*]^Ts5@(=JC !^[!;|f 7KOf:3=͉\a{Z>lMV4| 4*IfWXFyrlU|=D"QQ]d2Բ:!rX+bt )HƣLCh5QbbNeaW_Jx[2kI
+7~/G3ej.Kvn!ÞUpn1%x'1
+b|ȿQFЧ1WtHgx֘:βˏ4-F}+gѝ`5zH#q_?e4 vx0ȣuZLB~ƶ{Y
+1`1?tQhYrLppHf{IR=ayx9A8J'zܐ8]*2ME楛1n`'(^9F֥C9NE
+uHeF
+K9qQl5 e;ehGyD_}TьD;Z4L4
+̵ک8`b |l~XIʃϦՙ
+L s%( fv& ;iP-}ul\bqz={2:ʾ줦tHgY6/\B
+3w9 eߙ;UQyC8$c%=9
+4|"u_2V6>Z=zi.]Ei6I@g1xȣ_
+tH,c-9ub4}?Ὄ4 ;!#;^XnVnc8<YѶ*
+j'2_@3}=!f+V]݋- ] Z.+ԚrMꏰ7V emFނ8&ikyZ1!NՃލ]NWFGɃQ.;5r ¶_lt>9s XdA&H٥\p A6cρ
+`WYлݚ E}϶
+7Jˍf; 10(e`C6'Oo~(`ê}j
+"уtg8[`VNRv?_n6 Z iʣPՑJu؛A@@7ɍ ^|cqUvƑ 9 &Yv&4Gls} 7b)ųLIdO3@fKp:6[) 1SHX7sgl<g-攀H]!WtH\RAh# $,iٟ<I2Ly}Q>=X^\EkU+ +#q,fѵrcC?I20+pJϔZ?`ǾΉ'kya!%Eӓr1$P2RJd]^^1
+fYP'W.t`MT2$6BE#s62Zj }N4d ^Bit* ek$#u6Eo]-<L Agc9VcS1lԚ~q4exbI@&ʋ2XB)`LҌ1"cL+0\.b@y/؏b3Bo(5Yo(JcF mc~p)lcch Gݚυ(<$<[$
+}3RZFt>n#Jy_`eL +Y7wRS,qR|ӞwJmh+zY՞a-%GBMZVR{u[zȘrHy<ƍW3{TګM6VPcCU:tz!ĩsPH˔{~avo&v6>ҥ lRһOM +b|?(Ekv&uRƩ r{ $<,6h'uUK|F.â-k7,~CSjΩf3{cښQ29P6&=`̍ #X[RUnĉ/FM2@c݃vi+_R\$Lkw@[_oTH.5z|Qm[X^5jYh5;C8Q }݋!^nI1/Ӧa6`g
+5(7e u?J{yB`fݭ! TS)$3[5eTOcƐNSO0?疉Uo
+Q Cn}̍MFcrccb.Z3ρI>P+:eдδq,F(AdװmGP@_ЃF*% -mhAqJL@Ӫ8i F + N NFS>TycaXdZvqn*jFTվ"(yJ6MHȡ@u[y&wF] F`$#m赵v-(M^&~=H!ݨF8bz^jjia
+1K
+\>/e#|(70@v]$J=ެ֒i#VLSژ(l1Lkj3|r?Vr{yS!M KN1icQY8`rع[dACI^X |ԞX GJp pj 0,|]h<NO3wAdW7V dsM9_&V};Jid}?0zR , @1TKO=Wݿ~j?hi PBq>@bc&RH?~L8{!8fd@0fjz@:;,b?!<uLcO?M+=?hf'+OxH9MM= ?N|&
+j)j WO <D0eIR|@SXնZ&ԋ2#ng|gP߀օM~uh/L~d H*cY!F`w{VRD'qIՌwF`o9v 
+IJ:ƒcci$r)7vX,y-"|QgDgzVt{ii#eod/n]5C}rIB,_e:@4^0DǑ+J@y u=^0}-CBgBbq 3<Dwc"BK񁬑 ^*l-:εOl0y$aHDZA
+/v}°$b<k@2k8 8Z9D^ۉTxDA+R uZ8qnm2F]NJڤ=U,hytؗ7@v7Xꅢ[)硘q'L*9kX(k0Q]{HlPÏAzxa Xuo8XOg;.&x49!"NZNpaa k|/q>V򹚇Y܈]E +1V+dw{H aRc׎T4!발'[f^dlԮ49N7pEٖ 6wϰO3+F05_!pZԃv р68>Sl" DU%:֮ϱ$BIÕV |`,eCdn`f3ʮXWؐU#{ T Ó};bJW!IፔE qF hd<)ҌV3)%DOD/ޖY4 %e1]KnU(4>4׷~
+\W>Z\.gȬCL]3X{V*~(-$G^_BfH&+vM qVBw ?,HnQKb:{BqXL2"o@E9!Fvw@f N]C#n!҆s5nZ8׬Hօ<qc#r״˯ J\yrTP@}\]Z,[i ?3m-X?+7LSJqZݮf$DٞwZXZh]k;Fu i~/Vbkyfڧ]LhY_|l L`Ѡk$QJxKRٯoM|'SVHwއzA3m>kx?G35GC&*oek;HŘhCשʃDAo}ɏRq
+Űs6_sRc9# 2: "EnQ&cfm,(`p<Jj}ԏ'<D_mRo+yvr\JZg`fȦa41
+YfFm C4q͐ZJMvs˨{OI=_[ѶrH&~x;Xư=lG=k՜dβc3,ٹjh2sNe(a~Hʓe񳱃
+diO "һkT"q0e+}
+Cv3.$!of]=<dx ںBrMgnr8mԙUA<K,,hTUR }ol &
+em@mR/ 87M {䏑↜yuIȓ6E^\Wg J^g<Z2-ݵq5VlHSrA4 ZbږlgҼ2R
+VP-2uS )[.oUg&1 hV
+nW>9KVߛH#=6
+n Dd`R->@ )Vt߃Kķ(q,ߦu  /yَ~k
+?l*s\5;|ig(<<Ө>Ƿ +qR[ČF
+d0+de}}4c^m*p&\؃z Zi?zjJ H4\F;epZD8&X :Qq?0W=]Jn{{;
+Ϻ\*g=,
+fjQm^5
+ַIQ]y4 zd]mnvO05N T0li{$M\%?eFE@T;IL dž0O`[a ۫3tfwp`!
+g XَkM Ω8ѤFJGh;@v_
+$][
+~o?@gSMbDH c{%7c)o84,MF!~ʼn'5 9#%b(ĝN|=JddNBh:DْL:bᏠ4$͉/=x!<C4u!`W6S$ fፌnrdR*YEl,Ưb/ =Aݞ k,m\]BF&G=\Ya,v |#;m? ˧x1Ldl{CRaiOVAm U)k|ʾdܸ,If̨/fTK=RеHe0Fb*Ž|pc dAݍ~@ɀ {Y^y,*nY6U5~? -F!,[NhVH4sGkyE-,pyvS l:@cEJP77-1|p۩װeE'hng0STZQQ2Dd5PtxZ.!3LK2AԋgV?#'4HY4LVUFةyȷ2˶i\fIKfKgZIhm\A tl ߡO-"K$S Y[=8\QhZ 
+O8Ў?I l' H?e
+ZAUg^;,=NT.a Kٙ볯 Q.e)[*NTm/db]`(YjinF/`yS?I<DmJ5_J/{nq/[N1kQYp*f0UMJ s0>GM]ą؊6fODhuk>yAToy4x-Km?Bi_
+>W8#H띄C6]gѾEC&rx|Woʯ1eCL3FWcn/R{;'h[]ItSkLuX?Ů޻_jTE<Jgt{Vwz8Ã=!/J8/Jn
+"SsyP:1 2a/IX` eޫB>?d
+X܄<]ʄ?L(`
+R,g㨂0yײ~Gڲ5aBKNPq ) mra(B_$\B뉲2\(OЗ:\(j5 9ev9t  .ٶcc_zBo(
+|R&\A=mPu\f.^zðJs|}S:( I3Tt PRvFpf(Q/}0<FU9>;^1{? #`̓RH>Ƿhl ?Fyl6>(
+endstream endobj 67 0 obj <</Length 21987/Filter[/FlateDecode]>>stream
+H;n;Ef^ACg'^d?ˏ /O*"/ɏO~1iA̦$-)Kks- 5<j_%1uMGO~-u% 'Ŝ~|_k%[;;|Ƿwק&&ĭX:
+`NN2t֮}Qu|K+"x/aAP>Ъ`Iv}Ίmr/P;Z'ݤ }/4;g88a%/!kfx98ǚ|qBf}JYJCxxDKcw2E;V&<P6:Z>jUb[x OuslZƃbɽ /؆__01v#%X^3#?ٜ
+7J9Ђg~%ueZֻM_K[$l9|x/~"Gf?b]Α^'TS:OR^A2)~',V#ۥ vi4.Q!;I.n[UV=Eػ ^:%oe]fZe'5g@ ԕIy_oC}L>%w$ z}ޫouUeAeԠ,sz
+؛h}v]NCE#|^kJ)89\ydSܠT4 &:;N37E"n&;AtE'eS!PQ1%j=9g53P["G'FZe'۱Ӵzdnxr'Ef^p-Vb.IE3R_
+Qէ:˪" vuoXO RG!S0 c/ˮ4k;ZzTJ;B ;5"yw-۪pg[3f+ӘW/ Hy?W=b(frO? jSE)GTFG.(4[~AH^1ϛtcp5Fײ- s4nnxL#ALb*[vL2JO2NA!z3\<Ebu)ZdiSnk3HzIU[(\$!M@h\vmI%foTAt"+̎9V#@ 2ήrU%V~]"vdY.{-]yosd63Ak3-݋6v)<W id00IoZ\u.4Z1
+!zgTY(s4A`LmvX'=.i\ʻYmsN5bsRgT<uߏ&r]Bv]Dq=U1ϊ*~<k }Loњ_)_*SG԰7v~W f<TGTie QjO
+E̡klt٣kDk.H q<y E*c</0Cq_̨ƼФ/x.Iy1 ,C?Gǯ?%$SP%R{tw2Piud^˺:yEE&SBzUF=J"4}26ns|lԲ}T84aoxjU/|i❋Ax0&Q*,q M
+^8馩oj^MG)a잮.׾bJOG)=lj 챟o f
+;`kM @.$,+
+ˉ!Ρ)+]4GUKmr{ظe{1i>G "[r
+y<R K"0J˖|R\GD
+72A4eѸJ<ۚ9|Tݥ69mIdd衁銊Ex)^k<3}'C5OHލF rE<޻rS+.Q:e3t:Nm}:~!!R3$E71miaUSd-"iXu hw1L;Vu('UUsO{?6K=\ Y[i]Q%ct-'tȍ料b dNGE??U1WΝډ^BICN,Nztv"=sҤHmziCS"hg[X6ꨯb )k]s@rr eû| ]9Zgql-QS@LC#ɷ($q"&]t5&Յi! ( cY"eI 6F&#۝|R6wo WɴճkcŇU<>q͌DVgwj9SPa J<0gqQ9ނ@ 
+g_țt:uסyWxQxn;RY3rac>r~w|"N/CL#K)NL b"~|R=3T5g<Ku:=SKL2
+C$thwld.=X%,C"$=w?Hn,g:G I\o%VZBg
+~CD*W^Z'm067XP nO\lsĚ]+OnTV
+f~D4;Z7uՠxCM `xHhI,hC>Jgc@B/(EOzȩ!_ %vcz:S~I=-M}XMV218H"h1k>N8FQcW"29:)VQe'ErV=׊ ~D}z"LInmVl} cQۦߘLf\`.٭m{ej=2^RR<|PEbpee:]-_U
+_xf_W%ODd$ITMnNq /@C 
+V#Eߧ +zzP. FڦP[,ϡz8e1S-ZE>n5z\ѬuXVE.W~$7
+s3+y^Kf Uhu޳Lh}_-x{NcU-akS}#X||vJYK)[" ho dVύ0.)G ?bb|n ξ/J]ǯQnA/ ̳bpe-ZKN
+f4Nru?U,KîOЁ &ѫz߶l̬7,K$x- s`O0ة=y&j9wHg8\VuTؒqٹB
+]0nм`bpȲ߳PV#ϡ W7u
+$D[[Oy*DoBq.p)8ivsY(mZ5,hz[.)n12>).$Fh?&b`jsOj<'
+pEG"ٍ9e֎!&EOxvr0 o^OdVQ;O^,&*&VCL1&ł7z,.9 U [+/%[\b[?fH 6/:>7C% B>WPg3C
+_c< 517UBBɩbnFs!x@OrTåIW27-\0=tfgrpTXWˆ/\yY NIA<15D0œ?X5,6)
+V*rC?L|̌k*NDqv9JJSZ5hGL#Qb\TgD21:?olb*$U/OmvUSs%w'/Ij7=A2w곩u쪏#rIʣOʓk ]젼@qȔp;1% X.g^(8%1n_}m7.B&Z1v$y"8N_)/%qE |6M ViZA]"}r-)/AYL+FLL
+Sdv^b_vn $7C'BW6ׅ dكjS[ 63pF,4 qn*?G6Kְ9]Eޥi-[ X|5GƖWcK7jn]2wAv.+֍ sJ.'HX !٥ZOE)k>/JhԽQdVaPD$ m 'Doڅߑ]e-tZ
+<<6m͎$}l
+),<r Ah7Nۈ`$vOaJ%rsE h50T m|vO1>OVod\3=[1$[b )Lex[="s ǰ jfox"װAk..[} ԣa<^qpÚÎ\
+c#6 D;=s:\#ߊxi6CM\\B@|K(iA4hgjF,=kR}, H@'d?Vk_ Qml:[Rڙ΍=)liptZƱ2"
+,E cʑ$ɑWZayA-3":K,?q AH*]Hƺq#X<4A[P*УXɰ?
+M'-eo9Cj|\?Wk[4CJ
+(fIcŊ0wpϟD3N##Yn?.|GC!bE GQ Ꙓ|h .bԲB_L2`RCduqo0m
+@Ҽ> ,oƋۣ.Ju(R&KrK_v?Ϟ(w*ӜzSM|G51^9 : ¼ Z Ԇ&0q: xEo!7}|0h?X@f3?XB_.}>B)2@bzohn<Ţ%(ՈθJě:LFdW#y 3W9׏<ű_9ATk儈P5swǵz(WW.Mbke3Y YǔDR0U
+>dFž3Βw}xOC-"pw$ 1`Snh+Y0#X7Q=d|7rq..~}j@%Ȃр.[Iu)%,cƔr*zM6Z:v
+D)C Mx# dJxca2
+LWr4E1a9v9)^L 2"<EsE$DZTRGX}CŮIkD:9H"#2^+\. -I"n@ $/ԤtQ%%vi>=
+ܨ G'٤(]5]*붝i*Z7"f7P -?u|~{q*^u6׈)}^%bL/oH.L3|bHޭL2-JkJDvvJ̻-;
+~!ĘsC9St>#(K22kzXAe@(FiǥHsuc;lKY
+*"frZQ+GŌme/vm 7B1orp% \UIHӎ>LIK< <Ow*o
+'Y-
+f~[ѹSGsQ[̏o xg9GJDT*77 ;B0\mE=MLtQ8޲G"NөZˬZ z{\x!_7V5V9Ԍ
+=7 &^UR.m@ {12{[߈X/c أ
+X֪ ì#X-5T*q$Z^;/ Aԛ >P6Ǻy,߫,V
+guw'S%D[ұUtrFk{kzsX\ A>uF=d|H& DR?<Np#^;duqo+7
+=A]_*;Joj.mIk[ήHGdRo$=eYzTab4SZ K;?qԳaL~`ӏ-k!',c4t#>W`*@8 ݧ6TϟC-EਛbL/ pϗx&!C:ձ]8JJ!G0s
+sϘY:=v .։cr*Z3I>:{HcF?SwTuoػep<?ı)|Sey#\sTLfu-$[?Y˪h"=
+chΖmd$ nw0pWVmscdY bQk֫VZm54vj\ߑr5Зae5r$lKU~S~=QQP(SwսΌqr@k #qv)"#v %JtMk7 ==Jτ?;7O||5 uKL$j'$G2^BP( ,1i^WYW@<zt>nc䈟M
+%tH?lPuJ$iD.rn!DV 4ވ. cͭH DZN~jspbY8 L|;#20JZ72èZuKk+xMfi5RDs6n쌥㋃orU@AQX뎖Js60)g)ٳ QL‚8V=Ɉh3U2Hzg52kX|sc=9hza|~jnW !HCV]~J-*dLy?j+JĒL.D1).ERhocr'bAs?4*G^Wk9^9"?+f0[=HiY7q1@OT[\ZSv6S!A-,YMObs蓃T/v;͒){MiDe?R;qgUHge-*d@LK0g4ĨˤķB:`V}{Xuդ_gdNg@I;/Z\Z}HD3b
+7y," ]EvtűuEw0ŰRcr[94)y rpZEnT)p/m={dobvU2R0{<V\sG|}"WW_À<A68"#
+ΦoHWp#U<PRLNmDj2Bzt5DƐڍDHguv|h*fDj}R^-BO f&!ɋsJHX;CUIb+p8Ci% fO
+J'tJS%eѽ0 nC@ aY JdvA|o >VbAA3Ȟ_H"!h܎,F`#D^Z.op7p
+LVa:tw+e/*D$eÔC^z -,Hrː=Ns>kd=D+WLRF?w&s*"}T 0{67BOqgY]1hBYr(95P׿`$`d4EؗO?Վ$[}"Cg `"YIxěiT2MO@) tfǏ@@/X4e9ߞP',)'WȥMEe5/y>uvnaȳ}*.8yl3o\|g笷< un֧<ˎ!ϸu3
+3ToyFΝUny|IZSҬu-OifisYx-9|f!5[{
+tI9DH3`qK3ibC}-!͸%
+i4X@ dG+ĮO.O_h^=
+ 6=fwHCtlHrm=84.$B`gF4RjM6Ӗei@knLc~?@p}g
+TBQb|&k
+6l ZW(S7\@`IM8*iQe]ޑI翗M:;~)#襕Y|<tTyo".4q:ƩZ֭'6Z{a痕PTІ_BUq$R5jK̬2&rD7ĜepՃONpml;(eAg#_EV ح%"/O5,rx<4WaN=LPw d
+o֎&ﯻ=6!?gB_]?1h:⥧
+S(Đ9W`uڐLk߈WV:9s^#?_i%9e[!Gc^A5Ѥ"}fk^Fh zf@+[f
+aUS"Iͦ 9)OJ=`T",<1}ThR>RaS;j#&ٸN!PID<ɞZ0RzHzJ%RםR V 3RsT4~YKI<?c^܀Tu.<YE-bF),^T?g7xИ#rb*_25O$bTv@
+U7Il`{T!6j91 WLSy2#∩vɒ_;2=|YR3D6,S \mL5iKIczS LDWTm<]kޓs*cT_:X<A6/ s<n/U\׮ö򖠎j??
+ʫ"_˧%IT6cI'\󋴫^SY*;2R +Dg_5媉6+u%//KgjY" NVgF9>12Ez;r8AV7+PW>mĶ(/
+S&[$M
+E66aTm:.X r&AȞ Jig΅>eI߳y6qe8xz+h!%߿c1]sܒVj
+.N@rpPwR*K*:>@瀔Vk{u"#
+&QXV5g2L(NcB6xW_J"K@R['ԭ؜a)lBDz] '-),\sBt3C֦ CW}{!QtU0LD^ʿ[M|<&H0~>@FɒkȭhRfj݁B5!f7T ^ #]aR0ł39DaLf"\׶-A- ZM~5);e-Sd49JO)aFzR"3h {)L/Rb6'}&oCqR{z!˚s-t){WdBzM^֧/rVru\=Z/]b(y'*-
+-%C
+Y ܯ^TC?G?u,sq˅l"~qڪ1e ]r!d]g=+df[G4GVko  vZ?y:F
+H-/,/|ֺSN/j@[94LSkZg#J[)ҼSl <GrTV'4XQ Oeu#;=4GI_@g[[mYuʖ^U5ܢzq$/
+mȱ.GeԘIsصA7%4G2#3Tv\QhdlmOȲ_Q:`Wh>K}~^mNM 3)F2&yS莿Zv^־F-C3<QKP/OCƘA"VQjf+A:
+dFgrĂ F}]$LY)l, UoߴB5b+l(Ͼ {yzJH\aV^ZZHvT
+2A+I9quL.<c{2׻ s If oZܠ#1h Cdb#ۯߊ *?Sy**a} IS}x\ ă1eY$i{\F*/qe.w=@4H2l Id#T S$7B [`k5nfš iW~ =ڑ]q`*L3z9<4>*֜
+Ke~Mu݉EDΓNW\|Vmē [c:k%՚=nY
+wΫڟ*Lp&ΐdDA\ pm7X<}SlRn5ֿd X#S'\upP7vX>1
+at[_[g sKD6I刻jگʾ[!EL Ž^^*O;X3>8R5iq{Pץl=q\1
+"q=&?@Ep 8G?m*0^5NjZ>l?4R9 6b
+oC`d&SAL[QDRU'HZT; [3|*fN-2363[lnطgj;Mܗ$MsMlc"'vꉐ4Өdʍ䶋ԑ,.GB-ۤOi-9bBcg1=<(*
+"_h D{o?LH"F"۴,oy| V6ѪS 4‰29y-~ kl
+4UNp6h-" j@ C;H')ʉי ?>~b~]Fa:88ݗii3#n։KNYe@q1EdRGqzHgE1bz ^D=Zwk(/]7E}=;7x7yXy}x[O:|tF ^Dg83nF~>P'C~iP@S)A[Ac
+#ip"Z,%aXJ:'K~*kkӅp?p,r?VXVc<2mC3??^Dxa^>QCm()*
+9[q =8vHsW=bF1süu/4kcknsrFkD_YS>O)8MLʼHJb0Ln[rc Yه> Mkѻk>A uF c)/kHdvA~JG
+,Zjm'e-ɺHt&#CıJKB5q;'k(Gmt:1$&Uk4
+iA6h4.gm`_#URcޓ
+Ny'd
+s[.K޷+6kBf<zC$'>@ ~R}^s3s{:fFrRImKuAʐIozO@^D.,^X_tsYn?.{[s6v|BK6xY7anf];Ei-ZNo ƞ1:DqZ-$}~Vjj&YИ"{U볨o~
+¥W--|0bɫ*4
+endstream endobj 68 0 obj <</Length 17561/Filter[/FlateDecode]>>stream
+HWe $N wBH<za 03.)Q|T.B>`fHBH=Ft=!V%1-GfwĀH݊ V9Ll|
+Z[e8x)8ͣ XQMŹE!zkCVL柠Kr@4-FeY9\BL2udᙥv-ɤb6w1*$&֩L?B,*Ve}$=y 2ׅ F2`ϔ■@YqkZf`c!fͧX!?RHڐ8@6
+obrM[/ RTDRe 4?  k.37rWDBWK^""̴D1| 6B!R<\-Q`sp !66Tjѭ
+-CFJp] iLq
+AFZ!f}.LEzd_L~zbrT^q^kD\<?b,,~(_>Whp<,"专 @2'\8R+LbΝ-kTt\b5ڼ]NЖH] m,mFel 3jYBdFs(׼ޱ+ "C3ןVZ8&lVW z q Q%+U߂}6TCGiW( $>O3joֿJ<ژ4m7
+#ۂ&f ,7<vmbrSnI Xpu%% z#v
+6I_yl8 ywTnAqyĝ7#X!=ێSxGLaM3y;̙cآiS
+H@VIS2BkA߂ZoyDo)omȦ:.dA7 <PpDϼ{#e|q三|qsu\^Uz@"wyMTWޤ~*/9D}y;^cECӱGz@s{})r=k[l}$0"rMo~*77:Z8tMׄ O G\>c5[tњ #\ݿ(\Ǜkɿ7֎:m}v> ½C=3ZnWXX ҁ>芭h$lX%r^@2އ׻߁U<9lOZgSH5|
+_ %xG*ckF朒F< @,S}ofOD!w +"B% ,KO+zcV^w/R@Dfa^f*&gNA. [M⩽#ó|?1 >!I'ƷV|"Aa6_qSCp>!KQ')|^{>GC[m/aH0D$"WNN`y҄+^1zLeshisV\ Z2ĂhViȸqՃ BiUG>`
+OEr'N2QNd}BPwᚒaT#2.rtm"Q7TVv"m&rRc6 f{i5U FzRs)VR!|n-ef_ZGeR;_eB
+)x1dA}RSj!6=A--ˣ a_/"0vJ77B`4 C@a~#m8 Nr9X^[s>nD>A>`F4F/c?ߗH%pݑʓק*HLD`PAiLRY[@:r;}$$LJ.âTjB
+F<Gז; zٯ 3ݲ~n쮻w(m8Wu,ִ,m\T hBĈhI:.4d7\ߖ5#6exCIykW"z2g;tS}}!c!#lSA<k_/wn+ݴUv[>eg:b,3ۊ.B5L/𣕝ǵP-H&A}/i=oG0120Zgy>Kn lxj
+4cxpITz
+<k+?zX0p9ڇD<ssE$
+5{4ȷ8TK[ I"}X(JI+:F8}=n1o<--DpR)oT>o-J,ʹۇܻ8֛=ya8
+nAA2sIpb+ m\7m>qxd|i![bs3{Sn&Ht6 ӌb{)Al.BzX$x ~P-')ٸ)\ŲQ$d_6}ZO~HvW>Di. lnS@l#1Li!<6c"lyb#I@l똠s5 #.`Y;GX\4~6-:vm'.k`Gh0 >$V{B9$ -^k 1PDY\TY9
+3S<N
+T<jɍRmNe~[B"_LZk<Of
+$R3HOi̍Fv gq~ 1i`
+e}`*j=D
+ h_+KV3u%doɓ.d⤽9EFpӑTcflH&ցbqSahU1@DžFX&R\:}U1tΨU ;;YQ><ksGd2Al
+45(eb{&Ee Z3D=A"ڍF!Q2zd\a+B[ydBTMj&'6~
+G,Y,BG$<*H>xҮe+K_V6c8AvhSd`$<Gת'3_W DjK珽.*_ ){A^$kק )O1XT1(yH%= a5e޼QDҏ>8HюeY#4"\q,$D y}^WM. U9l,D@jo: G{|pږGPļE'u~WF"a:4I~{hKw$W㰫 :4yrL)]`I)q
+ MRkrZ2
+ĉd.¨ -%,Cu'gD@JWOnrJ^2-Zx$U ǂ5ݒ7qP[TjZL
+[^xn y5{- Bbm\UVoL`=4][uzCrys_ȾgCL[͑TC˖N^y9ߢ! nh]Bg^;d;4Gܜ.>ruSxUDY=&l-f;H|W G_v"^."rd;A.ySAxTA^@eT%3hoَ@ïKٍS']lgvo=H1 k9n+ẝ/GMu_2d@V팳{DWDv"t)_Z`.Mۭ5a\em
+ nɏW,WjPV$P9&C3Rs]vC.G)&W/^v%Kh7\bx3LASn,+,[:Y娜uMl.
+A Mˏ,q
+l8a.J.eee)VIōJY
+S+ qZᅀx= IIa-{cMex#3 ?U[* [!4b5t%=M@z w+;N_^{$f
+h)u3F:ηIZrAYYj jL8A&Nr9 F\bQkIFތFa;7Ci[pBM@9ʑO}棻(i&o^ jڱ+"W~BqY`o8FKUT54;HdCOmMû'[>lɞ@l#z dv=jU1ik)RK9~GQÑ:q$+jI0T2"Պ28f<³
+cH%#"L_%5tdjkL.sf[\!%/Mȱ+x~ saAs7\bXَh+,Y^1B
+{BQfF !.k \GޫFlsfCmŮ\Ѓ-ꇭ60RMe(]uodB;coZU-#d%ms>NZUך-w(C_~m)o꫗,? EK8rE$r
+G18g[UPr
+k|cO]UT#\cHZ\?{{@$dyג(VM,ߚ[2], { 7s>p/"N@ʠ Zx 2Qb]jK6I+2k׊ϛkT":۪ƾS_U#aw\S`@|uϧyVm^tS@G{mO
+>d=z
+yo
+vhNNDlM ) "YFb?ʽ 8%@X/G?-j_H"7|t-3{6<#& saZfkp $>nGT&7쁺GFا0:Mjy)0"v(**07|I2dx!:lK55*!h_ynV AWjQ}ĐV~]+[ho$ vrq
+Zr+2wx7N_Ses*A]48K c ./,U3y֪
+Noռ`*ێ g#fJ,cjD#dϬ:Yt8W8qo`!<"bY
+f,!<- <(ХS@79&5'Wn(=pc(g W0#Qb(DZ/yu_`L
+()\[7}ݠ3)sDp4)g!쏞mu"
+]5;nE5Wg>P
+ڃR[@DY
+Ȕ!V{جTOk'<b6{ёK\W%ml=c;w`壗E~P6R=FRԝZ=@l=^eG2 WxP֘a rV,s<#Ms85*ճ=x.OuH^t
+b2YN@ۼ^<~u <CqtIgY'xuB.>L
+oXu.vȔ2ۃHh9OFBY%^| F+(`M3s#ABD4D4=\Cdd ~#̫Bfܣ$ `~mc}X!RfdQs0lL3S2cHD/z,3R[^c_ck80p(e6|'KoovspQ ' e.a`i
+ 6Ͻ
+i)ˋ$e_Ƕg /v.-Gw$W㰫}r
+m7DQ?̴$Hl
+u7gѫ1o2v7;≝ wي'C歑2n^%@8& >v .;m XҸJ_eJ^
+I?^k ;H[Iڦ@y dYҼR(.@O=$nj˹:$1[Ks|wP'$< Qq]m.G>cHl lKi6=ʵ"1 *b o:Xx
+.A62|[4e5&A; kX|\I_z25Ftܦr4wTTW"w/h:}9|9%7$
+ oSxJ$t</צ
+ntw*-u$)iF;5z1n!?a{&U2znBB,uoP(t*Bmcc!$}F6#Uo<)C^ x7J `
+vK!Yp1݀ <@[{e^k>.1()nۂ\` 8>"cP\NCYoY+
+H@7s5zwvPu:Pܷ@_sW.`ǥ M.Fu
+=M9?Ml7L'YV}kѮ.s|LØ}]c"ǘc2I^c
+0151EsB84ǘ?_
+D|xm)*[
+dyl[$+'V~R&oS
+%3aJYaJYEm1
+Wz]).L)˕J:*|)eD)m!Ó0F,Gz0<F
+Cz;1
+8Yp2>ǐL&RNC3AhHWժI~;6I̒庇doG}I7 9)}OSu֚[&3 [hf-) $ +SŀdC 7Zl͵.kF!@6gULe8iff8jm/* qLG`fu^Ԏ>,uf&,ADfsjeb9VoYK߶K_QD*e!4&"3b^OP"eGF5YlI現u~O]PZ}Dz>w.nm T6
+ݽJ̺c)Dҽ<Zt}=Au$z4GU2$Ӹ nE!¢|M-C5}6tEѤ,I&X/2D G,Ku79ҏџˡ@>,Hƺ{j!ibf`J>*{#=sZ?W!KzMֲխ{
+Fa¥Tr|TDY8TF3kY$=2Gw
+,$Wn3 @_R#1Jl9jKBdV<p.ɴʬ*}\ #SxެGCRLGt7hTȬ}|+/56g#l)Ҝ5?%Ls
+JѶ\ƙ'&)Ȣq4XKTWR8U4vԥu5 ^4mS:}مpORA%w~qDd*?F Ra{?OWMĆfxr\wZ
+,Hx
+T*Dv4XEs`4<<
+?1LQ"x+1ڠrxAW!gؙ1^/FӜQMZDVJZ ˑ22Q2϶ߨ֙!0d xLϢZ*mKW W"</2 re5]Lbf'Q.{84a*> x1c?ʉ
+*1VE|+ee0u4[ oĭ Y 0ܸ#4;^:ߪ$v7XKxeE],n $i|,#0
+xiI
+ҀA%248QR@NNd >Cm*c{Z~!g+!P\ٿ!ȵ[\a;D$
+;,SxHSU nτ:\c;\mYOã6֭/ ef{yẉ=ζÝY,|!X-%Bj{IZQqV$]fNA"4; VA&$>$Ȣ@La4 G(쥪.\ h<VbQ848G, 6W1_ZME{kpb
+
+U (X&HAFπZ%C;2^]rik%1Ƿ>/Y
+4dĸ p0(:\,
+u}x
+ ]R훖?
+ &O"Avgm.hٞd6QqmH%]_`G@0ߖH]Řk-_v,ՒȊ ֓_#d H^ 0Uxdatfm*qT++j,$0>XjF`PF d[C[+\V 'BHKfS!aG
+3=XVn6P]5%_<J㻫j
+0:/69Ā QSGjm]S,vOcx-V+ܘX
+%[^^ o%DQ(*oJ`WXfE %0JxS6 In7`mg0(R.0񙸑HrptX=uq>JirQDb#"!q[VC)BRuL1t2cXLg\3;|i$6$'ki#
+} aozϞ*Z;Y6bVֵIZ-Q|ٜ3!i!"42i+#]b?iɀ*l\!E=L|F+f)H"E1qQXG!k[!;_mb8o*e3ms*`K
+3NZ{)n\p<Fs9ժ -]igJ*z+G5jIvUL20~^NK1$mCAD
+4X$Z $EAI>
+UqltD"@LDգ>lgc<;-19}\)utT9u#,9^8+:PX Q` D=9@B9ǢP^A%B0=-jĢOGC#ui++}sOCZ/x>.
+endstream endobj 8 0 obj <</Length 915>>stream
+%!PS-Adobe-3.0
+%%Creator: Adobe Illustrator(R) 13.0
+%%AI8_CreatorVersion: 13.0.0
+%%For: (Michael Vrhel) ()
+%%Title: (Object_Color.ai)
+%%CreationDate: 2/1/2017 9:21 AM
+%%BoundingBox: -66 121 676 670
+%%HiResBoundingBox: -66 121.7139 675.8633 670
+%%DocumentProcessColors: Cyan Magenta Yellow Black
+%AI5_FileFormat 9.0
+%AI12_BuildNumber: 406
+%AI3_ColorUsage: Color
+%AI7_ImageSettings: 0
+%%CMYKProcessColor: 1 1 1 1 ([Registration])
+%AI3_TemplateBox: 306.5 395.5 306.5 395.5
+%AI3_TileBox: 18 12 594 780
+%AI3_DocumentPreview: None
+%AI5_ArtSize: 792 612
+%AI5_RulerUnits: 2
+%AI9_ColorModel: 2
+%AI5_ArtFlags: 0 0 0 1 0 0 1 0 0
+%AI5_TargetResolution: 800
+%AI5_NumLayers: 1
+%AI9_OpenToView: -585 837 1 1815 938 26 0 0 93 90 0 0 1 1 1 0 1
+%AI5_OpenViewLayers: 7
+%%PageOrigin:-108 -102
+%AI7_GridSettings: 72 8 72 8 1 0 0.8 0.8 0.8 0.9 0.9 0.9
+%AI9_Flatten: 1
+%AI12_CMSettings: 00.MS
+%%EndComments
+
+endstream endobj 18 0 obj <</Length 60839/Filter[/FlateDecode]>>stream
+HyP
+X'+!g%:! ⮯*|Ek؀forY*<Pa8J
+[ɛW"
+hN%U&նk`JvuνEd.)R=_R͚p/xeW/5E]A_Vݚb˝P
+vWBl]k 13K^b,lÀu:5#`ڋ
+W~<ʸmw5jxT\ c ,򒱤Yڔ:U<7R8[ɜVJv8sϺ^uTi<`C D[p 7<uL;;ci mx/lsUINMˉ"iX(YZ
+k2cA@ !tZ)B@D R %TET<謳qqdǜ3s&}JFH)@SKLg)'$
+S~`qKC$8vVnZ
+8 1
+p[ <PN
+j0D`~uW 7Az0(V8.~]q+/6@[8^lM2 +l&Mzݠߪ `RG# :`޺g-:e־
+1Mn0GnOm?3]c< bfT_6bķ3oGf[(-o<so{22MaOZW?,5Z+uS|uEev?onvc*͕vs[*89 @K9oTOw#`Ȱ*hȼ.wZ9St^3:xF3ƾ1'7V G}_411ndl՘+/6ǼT@WjBӆ?5/^(X O^d 3Ta^2b+.q!
+Cnn߻]-SuY|Z~|I碸g̪YgB=+ cF"%_<b^edVD,*%͌#73QrAQ
+voB--z[~w {O;myܧ($pC \p#K O/AM`
+W9.۹5== & : lfԷ.2!$CqN8@r'b}ˌ!~rVg<OrZ.S\?>V9Ja6Vb}<˼ nگo,T ph+h-?NhОMAupn'6G7GLjUryv]܋{6pޟsioUѤ_ZO&>?3X2ya'ڥvk
+
+hĢaN 2AB !2$( c@B ԩ2 (*O_}J;7Ƿ͹瞓}]}Mz"
+pp
+l*?V#o,] I6O=y}E[Ϛ^,UlB2U YZ+K+ Wcq UOY&̊cf|瑻 Ri}=|] ں>_kAy1ҋ_R'p8}},7AֹK ڰ57_?"AN"@v,9zuY8ECX)[M^$]nzӘúdO&q;{'-yQscöőwmK;FJlJVe6
+Ա2AFNIN.Ӛ" ;'T -|sJIԄ=9e<|cx6ea9b- _j
+L tAԸle$qh=~]JϩU^vV>SE;XZ,'b|p2ޑZONje%2o%̷>b[e)owϭI%uҬwn/:'A v5EԈGnƪ{b9 I(QPCX[|X{(1Is`j/  }3Ԏ]jGi&JhTv(j&V@U[7sgSfR-OrT%ԙN)V^LN{}!>nW,P1w&ܦ̇21d]h(P\N^:(uJ+y٬xU4^/=sgĉӉb"C:~xAGfI{^uqvLwE9}~$~ $mT. <Q.٬v^ȓgsܹ.ܹׅox/IӕWeirYBS3&*C={/gN%sE
+8Q& g-Jr'Ry3#Rԇ$rqno Q3R/l@Й1Rٙd)ي
+qk_.cj(jKyxNS RGy¤Ʉq(vD[P&)rµ|o]9;ݯptz9B<#Mw"ۡ{Dw @D|1%)|u_}\5OAOAnú@Qi6BȟG @pܩ[T[0vB*EB Nj_
+C X-l3t߸.
+?Vv'4xLCl,"˺`^^uj [!_U`_O[b_qz}U֧t 򻞽śTe.3o`O `_fl
+uz+TnTZw ߅x1`o+6Ȧ h¨ yB Fx hbE ?n$H cG,V1ac"SM2&IMi tXO<Ͼ-woް鿆e9+O˜(%{ !Q;Iuxouho%u8}}h>s>\˚@)-)ma*w)Y±̶>ɁZi:IyFrv9C~Kj+4!;x9q%FǾbjϮtҽug L'lY VY̅Y,eFگx).RnBs1rܰG>)*Wh:;! 8AϜ']?}=K:VM֩Dy `Rҥ: M9yz R
+=D#Q(JR9{Z__>Ӗgm8s)㋬9ތerݡz!ifIQGV/vPi!nr7sۇ ]xe.rzJ]~Hnk0-RN&b6`+SWNmpev nc<"u']
+I[
+I2)cהqQxޭQwx8~|ጝ`~aPʴJ+ՀTeJ`WKhP
+Qs
+p"b^$-`RdԂvM+HZ.=?PZ_!N2bs- {1_)trȾkdjDU?O4
+Ė~ F_g wKS>+=iov^{ u|2n{=en{+=?0&]g؉X34W3Z
+}_ۈv" o"`OҪ֗ ir\%tnJGcKÆLv\מmhw~"φLoUyg.A,_:" 'l#I=ituXZMh c(l6T<͖,d_Pb|¹_BbR|ָĈEq=fͤYc m'}B﯏|\;ZDMr_εԁ|QP8y8y 1a,I,~8[ylq-QKn9VvVG sjcƢYI'_J=KIO\.i~)z(Q5#A#
+IFp~o5.eb]!>]Η& q8/ӂ>8Ӌc^&/@0/KؿpNaҳ3g?ϗżiLi,D?'=>vJ9I"Ip$eH1seIz%IV_}.ז,+nG w»ᏸҨȺ<HICy'"a@4}_6S__,I/ 2Kk3OYĞDA<6' %<<s8Vq<uZf:Uu iV^#JpU @DWG2X :kٽ`@mI@PB=E]8"Cˁګ@Fڭ dԓZ00*w3[HTvm
+H('P_@`[`
+Ű~&T.W$gB\+B" eKG>e!&9G,[Jϴa qT$.RXi[kl#ίYrxl5`W;WzT:N[x6/wR\j\ueZv]BwdM!cM{R=$)4ѽZ:CA
+yш{)CJ= T}ؽ
+k*"#ANhWFi̦`ψm iȶ$hBB9ꢰiR{ה8~_+U{Y)zUzw
+ JS_ 9ʧQ$ w,'. [Y2<n_M)֌]<̮6/<ؗCنaVmV: O2#[<۱)<g3h{މ}sr <~=Lm.Ⅴ!o&K0R]b؆K҈?6;+yS8V)8~4~bz~J:;5)ndSrGFwR+15XWPAZ]V[7$;cK1ZZ|E3Q$
+iGZN).^/tar8F<I<B:M܉F'
+6|ϧGw/L,3sisD2L23 s0V-A
+ˀy{vtA֬arc~N<#;F (hbq~ic`Z:KI$׼fS/
+U𪧍9+ckÆѵJ(]ԑwjycD=bOp$xֿ9rWG5PLjhh%W!kI%ZTV,Jٔ_sזw1_;D&Ws*j,'Ok3sFj><X=֧ОxRpgU\ՁWG3suokSe>$a]u]w9z.*ւؿg$飌Dwk#>,g ݸ9քftҌ[ G-kuԖVĽ́\!C:'_c8~~qjƬH3mOҒxs&:&*#D3X/zUu^M LC&OUsú&cmOviOrsxEs4qYGLm|.S=-7mc-Iq–lOgr/:&Jk`GtyG5QK!T8*Ht:*RBo!A`
+^#=F-
+0S餯 ?Ir O
+8E Z
+v
+&WG-40Wg
+{Q`tI Ekpf8XdN+TE ^n[$бCJ:T{/o#dWo"JL 7U1SKnU^Ucա\jf+B9U3ySV5s&ug&~fuYiz}α1m; "+8x=32'v*v|+f-n*c~#=wkenb7繎1~,rgL0\n.uZ&*b,1
+}' }]LWrgXĞ]1-yfE 6Y/g]>5=zFIX@sj*#{vxXNN?ÎE,~ٛ qZ$w<3\L?l{&b >s?Ds,_[0`;AԾvp--^rw#݅G>y:@NSq#ud~wLq fщQI1)}'ΌN':
+n2Cs{sCJ}B"jѕ"ԶԳ%ySq2`]UvEsɺ
+V$M
+H ףkbޥ Kx sCoo۩-tAD0ܑM]~=^GI?*#=F
+2(ص3i-z7<n
+Xk)|i%_^]|eY0oYPgKiEٴ@`lm+MWZyXchgT(L
+l@k|db${D`/
+$*Q*=I6742X:\F7zMWq^h/8}䶇/𯅼rk
+|k_`]hZGymTjWS9B"Sg#䥔!տ Qr2,CΧ|F"R(T i@'9&Pxќ,ͣ>Uҏ)AAjelޜofG e"Z!j|< T="<JKWzլ=n׽+>[0gYɟ)X(>p7'-!OwƆ?Qr7Y_sOtG5ugqZAj-Sţ22*"B [1쒰IJSE\Pّ5@BɢAD")̙?nɽϟ7&wWL;Wq],pPC YO1,~}D.:aHaܳt
+&~"tf [6w+e"χ)a*dL}=Ci'd+LMҢKi&T{E*;+ \`g~ ^g*^f6
+G4E qx7"4V{^keķDr[A=dԞ$" ͼԦ' ꨑ̒G.aX6d*g4p9gGQO~j kN4GoPR# aJS0Y(yO!F=-&kGeӊggFZ^].C?o4'xl*y7N֧!gH: mquXQ݈;a"^1+\M|N_  @2t>e8[:Cb_2%JzBib{]ere4,AV]Z9qJ)ɱI|_\5anҤtqFvrSƔd5VU 5]U,083 ^ ~՞`{w)w
+*ꠦ{9`9]k  '_7 g*QՃ?K
+`%t= ޱga2b ѯD`^ %`QX!-BܥZ` ̋y
+pSH_RnK2]ۋ\*C)4B7f>F`O1, veM`+Zցt/=YK%2eG%aJQJC9=[7n_˜6/^wԶã+q.U;T3&jcYLH^vKǟ<^nqb׆'L)7cPnP@]WDXL}Аq}stsi#ޭ/7j745ɡϡm(\H7)ٔG}at9쁱e9r|obeo?Gj'y8 f
+V@ζ AomRlM5yGOJ˳JJ3JD#O)3i2i^F nuF\ho]f/ a=k]p>./?f;3.~Ix@v/'>폋|e0m4Oz/s̙Nwηd=%4'z!ܭp ,nVY!ʡ%Dj.^-%{<G60!׀C_LM6u߻Vׄ7m`oցУ
+ zxM:]Gϧw6HoJI:/MrѢ[Ҭb
+;,<^813f<-/f DZJޮ=y{$<> 97Kw2{D}?ړ˾x*Z\QuA@"neo
+tr=zp]rI\ugX A=X~|*9E׽cUF9V;
+m/̗Vܠ7!Cޚ<<⇼b6 p_Zq6ƨjkCBedqϘ4z}#iwtYqu)!!ܸ&)qߢ"oAKV
+]Yس|KJ|:;ӹ(ץeJ}_rby^
+\?L?nؠmdVdznCss2jN
+ri*Xoq (!$0 &1H((X@Af@B&P􊴂q@Eh#
+NKwu/{u~<WpNx/0 <m!*zG.yN-ѳjCj+Aں \%9Z'ˊϗq$vq
+ ~Rb"v!c{g[sQ˵69eX ^Sߴ%'Άp0k8a'RއWί:
+X6臕]p.jbjvFZzʩbO<;R1rDVe}j1y#ZD,߫ )Ey7)_ڴ!ĵhy!#_B5c`Ÿc
+$Ht/.o/LtWZ(-vh3UzQ)U{
+ qlNrѢu`_|8Wmrv9YvP-~Ńх-ɎZC* qBKQU&GfՌ -Au=%"g 9,m0-tr+smszmx"tx^G| EЯ9E:?s ژq@\@\z"' ۰04QlSs9p,Rߐ!]ub`qq Z.rP'xS܊~"Ba2={^ Ѳ#feCغ#~sضۖm݄EruI:ЗvMӤSѯE>żcv:<mTtϓ8yLxWPy߁0(/r
+íQSNuRKDl Tm3qis#<
+
+H 
+= 2;'97wrϗ]x!<1ؑV~N)("a}1=\b6O@u
+|1SX x-%y#gu,j?i?{̫4gkI3sZ\MNJvDz}Q2YNҩOyyyMQy}2h?PØ/ϳ=yO42i2gPͤ )S3=ۙECRɥ v{4*R:vT28%rF"/B2cW'dj]6X
+ B_pbG rnvK1ds ΖYn͎æ0 NKx9_IvF|yQߘǾ}Yʬ0 O-3/]:tEBx(D)rl~YL<:Eb0(~hm[vؒJĵzH^ױR|웥9m7F xz0Zֺ (]ȇC8Q"ikuP~`?<FveICmxџco1߷*cBX(T^ʣ2؅=ߍ ÇÇxHxb':w!Ay3mCGq%&z~
+@}bkO7qӻ()qmƗN:RZxRɿjNV?,7{3xwJO"т
+[GdmŋO3<9GSz[Gΰi2=B^ngКþ{B5,6*G- \wߧOUg-8(Kx.~ ^VÄ k|I t
+7+x\=X[_?
+uqYG#^]GάۭoE Vte5ݯn;Rwqы|tCW*,?~_n
+njaӸOێ=8`!#֧lAg AHBg>@f/9`A
+X=$!@-( C,_K1Z۶Tt{%1\
+NȈɗ%ϟos
+YrcLSAY[~$EFj,؞鶺 'O1wBDp }_:ƢLj<6Zt"Qy/SF=ڕvL@nʄX7KZ64JZR=3i,3 i
+r#ڢg?_O\%~%槾,^)|,vUȻ;
+MxvT vH'z4J3((Ngt(|Х,ʙ+(gcwc/&s;. UٞYEs?^ ?5evʝX'%/Ln̯mqhA$QBVGb_v{ʳy]1S¸ S/YBAh>@)rnNfOIν_"NpđMC q#n?\`cVԻ?Y:n)e?3| Ek/ &|0s:0*DZ`WoX
+>9}2pG|SO~֋zYR\No
+\Zp]du\R0$px
+wqG9ߺœaKEQ3EsԲE3_I.ir셷FI¯| )xY0eq]Cq"Q$J<^ z y3b϶sJlq+[w.5"|{/
+R?wy2;L H܃xv'(|'P'3'I16%zO=0'z}XK7 hI!<߅;Ld'A"(RtƲJtM$1E&E^PPC @ ɛgPDfv*:do~ڜ?ͽ}sEݎ7`A-41.no(Fփ[Ĉԇe=M u
++<FBR=QD J O E4z@FCTdv8[*#NxNxQIᇽkiTM
+|oC).F(0J)绕ݣs$N_6% m?ژ4Ԙ4T0FWɗ99w}=
+káAں#w xC;\>fӲi椻⌢NtCIN8J+6* Ai88ں6x5GTC_nRUp=`)T
+4;N8opdnU'=Puu1eAՁ3)A)S{ K΂W˜w
+"ƭR{W=(q;b_F9<_3#Ϭ7(=@ __UTU*
+ԁf.݌QbW&*c .X}])"8Pd`ڑu$<8_b|g]qN-٫E3nt%Ƶ,vׅYR,){yǧlj1QǺ h69++}5%;/o0Wzň$iEk(9YFD}$uG~"
+OzwDD|䅯'NQ,*j9qG=Y߂jɋl;!_!)wVVE!#fyFl?W)~]~Z~
+BLJh\ p',Q$+QXd<a>>'>BRt^Tv/!_㣖g }yҳo bWh*b52vRNH#b`)
+7FɊ(\!wɝTk5{Y,W o@,g g?{L;QatnwLAdVwӼެ<QT,kF֋9!bK[LIO$/'HXԇ@YG_ dنOy4cz{f+0qBkɵ}^aV|;]-ߨ~IaY%
+z\ܤ&5pwok1ZW|v6-J_x~7Nə7Q%= =)CZ,{őN6av`u*_\~6YppRҌl5KR_P1Ēf gJsZ(yZڟ=Uҗ=U(}Vܓ3]ؗT C"z_,z[,Y*UD_bsn7ay}=;9D(s&'UvW2Hk|bSl\[>k&^
+2FNWqDXzy>1Y_(9.8a .ݏE?A#C?օC}D?A&?ք'p r1uG@
+P/ x
+59Q64=o\[} *_
+Wr?#4)3RF<SFGcݵmpq}i B{kN 4 ֯7k4 v*;: W7&م\ Ǔb ž860 W^
+],C}_X)WR(V!ovW j"o8A* $&@p4 EB !" % M8 v@ΆJ9 yv|2Lvfgb#M^uζ٘Q˲W`$*쟫團Tɳ*oguOVE_A*&|+wÏ떓 sz<TO#Wsus;2:i{[ 횉_7ST.t'ֽjY>+طjY1իqkyEiB1"dcZ.fXcF1D ¯XT<8bm d=@=$/2VӘ+&)5@z,ptZep0tfEv 0[
+J.Nny7 NSD<{Dvb-QYɜ5Xs=(SHJ|Oסb< 6҆ݿ N+;Q]ꭤs*
+,ǠJ"Qo.բe{_ vl<:`
+8:`S థ
+ O`y,<V7w 0H&ٿ~nj E(7<`֙Ȥ_M1- xiUy!ٛ
+)mjv4>,p|]":m'l#=-8m%+;XҨ <>PQy *?\=s\p`轈y/[RĴ}WjiKvU+xs<YsϼyגYYj| =U>l.qQ^<8_zz`o9y Sr =a&Y h<ڲUiϘ1$S.CI5AUܚϓls5gPHd\0x3h]<[.aUF~Dg݌}^|!qRCÊ̮K/.!OhdK"nM0B}k&= n.ڋK6lVȱԭ7O$!5쀦rǼ;qsrc~n !ƼKlID/Njv-f"DzkX\3s=Ȯ=?Ī>?(
+m n$#L5'Lj\Ÿ_7_1bPɰR}rt*@5J\
+E :dr?6nUy\^S }iwQMb_t )Y8--C6ɍScS%II8z2E;&OdF"o8'J.'Eߔ۔ԓ/J~(>_.æaS^oșŀۡ~%wUhwsU`q0_L N¿
+5_Ƌugɀ3L8OHE  @HXCX@hARe" [T@kBVV) VrO/}g~}̜<D@5RԀB<
+!0Qy/́4f k|e
+qSLi:| >P85 -uCz"ޗN&{
+뱄ݍZx8*
+B3B ~Y(Hqc̥¢UD3PSZєݚw=}#uh;@`vk'.̏^J 6vo%rb{[Tߚ`6ZZe5Z#1i``SbnW4G]nuݎG#ځʵP
+9zJ -A ?lo
+ݦVUsQuZ=qjic ys&q{s3BƢ(pɸ6grL6mDK>6>5y-}̼Դ9@NNpNnȠۺCrϧJ8o^O4KkGUj}Ŕ9]eJWD]Ы.UHUMTE@ƞ;H
+OꅗqVWa/9gX
+xF5 7"TNz󻑖 q7&q~ʡA*if'v;;GUaτ1nK; G9cf똳ji2=I)UIcpO6b1w1ތ/^L ~Ƴj^
+].es/Hxt6f̥<e\7'{c!ߎ
+)yGiUYY@߬=T |yBQP0(Y
+qk>W}C3,NxbvԅP'] VbMNy(xIM,2
+iWTR"/BY]A["V"KZKzֈ}=͜iެ@.#=O^=|'VF뎑t'Eѧ!jX_t^ s?;7p8I",ٶe/6-asMaֵao-D!k'Da qc#{α3ܐ0E%LyO% HQ﷝b?3f6<YθDHlzǢZ=7+M^dyۺwD 4c2Q,#:#3NuWސ+xR+_/|}TβL!a<C!MXDѮ$.3!qKsCqZ4dPk4b{馐\*j̈g>=y4[*(b3n2u~yJ0^}H`,i vLVuLUuU]𪖝7]͝9+L?NugϗQi3BeNw9y{5W"O^dNX} }#C[Y!#>X Zn X0niFU2ʴ[TZgZ,TJܵ"V;549\!aYj/ͮuY`|n{( nZ`
+NR@rRľ$NrbZҝĿ[a=On
+n['J+=-{I79nܣ/ٌg]]#]i)3y9ܧB/d=ce>zz[(ًeOt͟ɟA{V·u.w_d*9ǞdceLr1Ik?L{7.|ޗ|Z[RÅnp-eTM1'&+uxb6czD l@\%Ľ8uN: Wlo!O~gMpx)B:BOI8D0!BC1CA<iG x!o7y^^4u⬦ `>a
+ 9Dޫq
+P@ zH(ŏ$[ n廷Q d(aH}.r,oJPBe2k!5k3>Q+\J? vec΄UMx˂
+ S0_HM
+@
+Qe R;?`<wF>tjpBU<ZBB{e88` k@o[ɠQ h`~wUoX(-u𽧋مyG5##c̙@os3|F=Իv< @OҕwZ`hmx 0 AÙiF)h4|+%f{
+q1ةV6؉&m5+$\Y[3|'eNd=d-eV*>W(1W(|Cc"#R2^U1z@%~HgTO
+¬UeȬ D
+15KƨYy۱ g))$H>up][ w({m)}k>{Kb3(
+(x#;[JZ; 08pOH2<γ\hw}=d)T aȣnV4j׻Tt\5gH2`g%7~p-3~6`ܨ̛:U Hp,?!Ao01wKMi Nʥ+5%MΫk%`ۤ 2K߮M`º:()G&8|?c<>~́z_aɹ7O.7_bvpsUY;yQ5J[.ZQMn0^
+E6[J^4FsyU1:-kP eZyZ;^㴠QBـUӬshԸNqoT<jh]r}-J6\\AB&7_5{Pj)P*~~a[2t˨:7n.]8rzej4p馂/CF"|$6YdF% [<@4j>P@O8'ڑ ȅl2/%=qn
+0Go\  nE +7jϮV0R0|*:Gj{iZ?{8ig(-vƾE8a`00dD*EHJ90aU
+S[mݬF!rf뽮纞y8| -,ʤ!'ߠQѠ!([d
+\nħ='ҫꭍL{ȸ d]'Hi14uR2d&AsN̯pDc
+ƥ`/
+{eKˆik_~S/G
+XWc:wxJ6;.Yvɣyv4W o/y+}JgY&Rwyk"ҠF1uh1UWIPj7M[<(7S&MdQUhRC]2(w[Yrʲ^)mY-#-#-r]Ѫv^dۯ?Z0q^C>T2QQ4]AWz
+N4f&5S(aw~ojI|aA;!Ī U9θ1Ysjį6f8+&u
+;v\4(֧ &51?&s#CW_l*=GٴQj㻌7xN wŹOP+$4z aj٫->doelk<=n*uθWYo/5M5ōe;[V[Dx[OߚS=cі 2kζ&8QO>u\ht\h[WepMHu HӜ̡OZ_sB|+ᮻBF87{kȊ7/d-l%wr-9R Xj;d>'hٷ'hջ+pݓFi :
+'3OH}v ]ՇDGE/,_@݇.6H.Pi=;|2{j(nd@CN\ͬ3-Qэ1P|HkdW3\gt.޾{ŭyԝD օѫ}ޙxm;j=K5hRfQ+] ^ OQK}
+9Yv5۩ n*vYZ1doo1`##̻$5jݻu] ;Cw~""HI
+
+'`g=9
+>-ƏgM&9„Y e :Цj93lFy.8ǿ(/{;F'˥i.1|_*%l(m*#OZ`("*I.,$vIZY{v˩dibw& qȊD0Y=cƟEa{4ֈ {
+m?ہ=Fam O
+Jt5Hq[xS~>2;ֻFK߹1-urF
+D]tQ?>#]s)T&wKY?Ռ{ }¦2pFZ@}kq1`T9@Y$dwW"_VQż#dC]j5
+{YfR¦6p- A
+{9c}־6k_0k+I\v wLjGЗ86J?Ǜp:9:}Eq2,%yZV[Ά;vG}F}W|ecG5ر0A]ĺk}G^n<g^ˑǟ71^;"#?( ~lϾ(eS?OqWfpu!sa_c8BlC׹OS0t&r.`ܩ % 嵧_ؿ9SNYIN+YY!A8t
+2b}Dk \ˊ?/:kBWDW䃬BB,,ĥۢfe =5z:%f"B$ͱSw"&sN<Fo p?i<Q}U03ivpPkS:?iMhJj 5&& nDDFF\˽?R&jj*]{jEJ $IH@DQl (*HqBo EaPE\肮
+KΝwyo̜9 Ly Z
+[v?mNJ\j|JGfsKٵc/K;3J;JZ?;ߜrx^C];~^N6EOy5DJv[^?=i_X\2OMmu{j>8g]"YJn׈eRp[ {"xă-yAW?I=1a5# U)G Jא8?T0g 3F@ /4'~?exfΜ_:4c&T6v#@.pU;QM2pQ<7pDKE .]@ﻫOeh%;d>4CXݢm/L3Q}51t.ŇŊSF=v?n*SD%G3OWEuVmxK^_A2Ьrb'p/@Y٢y柢b|e;
+Ӌr"Ƭ?%Ph&~#Vr-j_m/|tht%#nl+a]{O<kmI.g85k0ry$!F%m6EHΪO~E2P9bP̜0*e7AmX0(R$~'jQUҚJ׵܏V,+ S߇Y󞚟 zmRD1G|{B'wR[B ʟ)_KܿiT,閳Ly_U l}źX1x-mbum`&+fqCpDܒ٭K
+Kn-Qm˜]O o)w V
+m*Լ. v"hHk 02/ Wh@\RFߞ2L`]$ GWZy
+ɥ)j`Ϋ_#´J߸d*0XVaJJRo<PP*by UT
+!ϰS t'cuѡ\p?smSK=Z@yoT@5g[
+uf<=v:Ls,ڤQ.eިrbQ{f^6Wtߍ\B,Et#HH&^I}q<H^GƸ7;2kÛALR\Q0C9x@3e̺ͥ: tt!' \>_"K\.L\2YIEr/a2VI4^`-knƺ'd˥-.; ROZb 0~'dC
+0!
+uT FGH-.J;!.iIAܣ/lr/|y/j+\~O >{=Dϐ{W{8A{ro a۸oyM?Ͱo!BfDW\t/{YK'}֙1ne~TRwltOLDOŞab&C o#qpc]̖JcKJ15%A\t9Jn_U룷;"K&M|72ޡ{$2-#3(&NGuHcz9&Ei2EeЂmsi]ˌ:gfMؙ+էk)6,Ԁqa`ޣA`ޯ,jp/@߇Y
+t; _Nf0eCN܆~~#z =IIcIq+)asIa akḬp{d
+%e
+W 1VYT
+gJ!P᳡Y9VswGeІ1i 4Cfx=yݢ<pʹ_E#WvFNo^wMs:uSU}D?"7Z~Ӛ9~jy*M)U-T{n߀Ro^wUW_4M-ƍic߫{M55THs2ܲ[ͲsN
+]wa m*&wZUdXׯo ̙̊zZA[B]e`A6!ug@7ۺ)_QF~瀑d蕨]8-`}$wͱ
+^ϥ<c:߱6Rs3nOeyc!2ʶYe EdQ 8KOC`O3
+/CFpxk}> pof>-u/K
+g 6/MOh# ]qMei~EGQ@X@"PFBBB
+PC@@8
+ʂ ] R&$ * XAGI~͹sorr<;&X Tnj= i` b}Sp"ϮAC {vXۈsQ$1?P 3sr"J®7?<,Ȝە\(zP3#l7ʯ^w1z'`Z8nxKtjĐN- c{gc7Щ/)u/
+mȣL<G֒ս˨*޷*{-[~(-g{v3[koھ(tʹҵ<tڭ4z|&7,Jǭ WCw\Rj8Tr
+he4l<k#:Bn(!;@skdF*^2)ddwo̤Zӥy¯O'~jAq,0ٳ C4mÿmu^jjv_nie-1ٿ¬1l^MVV1+b>3+eMm/e f/:ճ΍l)A/FּSc1oW~2oƥXϙ#Y_9KXhl$/5/[MRJC<!_m"r7rgBk|m$Mgl
+ON
+xv
+' &:B>.-xT/G-0sa B$1sAm1o:bFv Ə'??zٱքF82|SpGv-|:So+ZiN37qYYVj4?eSZJ]B!yRΔsR&Ɏ3imGg$^~&Z쌠W0WtG4%lޣ=K/skxo]dTw3[)R@#gS:?I;-Ky}\wԱWjN|fMTy3U&`IRjk+~#Nk^Yع|HK<)r9<a$%/Z:Kdÿ""(r`\R)t
+
+3pIX$q8a(\x_@Иtkn=ΨT& 07q͇fN5{+I}.O/pX$~2>M2gK<YǛeɜ:ÙŐΒAsA2/?8YYG?VfHX4۶`ѱ[wkw9*u%ˁxUzT*u@
+T
+0Xr
+#sCE|ۧ*]v$?:my.>;x[Y)|¨c'<Rr'B
+4 7 aMt^`Y$G?Sb4hLO.Q PQB8ZT9
+:jVVΫJKdn|y=<Ͻ}|L*!WMe]M\m*)KGh#ŔYbʜeiQf\/Z'eD3eT3slw>ﵒ0yٸA\=+~OL
+C\B狀|1jy]>FrgàcE}QWZ50,WKca]^;sb_%Oҝ4O9L@mfwWk#YWRɳG* fUi*yyJԱc9~S&(+׭RX+)?EH,$Q{H5QuCXÈ Ji+MZhZ Np{q
+` 
+:{]!5cQ VxVJ5yo\ HX|X/;Cs+M{(=,N:&H+Žw _cs9;%NZA^E۬a/w}6{vT|QʨF'E6o WX9CYj܊J\;~ ¿HJwLa3 Ay|OA G?"̀;C `=oN3<6G mC`Q 'M^5aN۩\v/]i@ m o@K=۽Z [1uV>QDWR9  K1Pz:v) -
+ډ1Bֲc~ClBg u#=^y߄z+t*qLqtū)XR{Z`|ɿߴ?k|jZ7oV@,[]c<Vx},)88'.Nh`Uҭl3Wb
++#J@;S
+<ԱcuI{!}QHp[,֐XW,KH
+CɃƙdžt21OtxG< i2a(vHzёd>⻂P
+\q.e^%9G9:?b'Ґd9kڹ<pDYck΅Q *] o^d c$la|%8)Ng}+sܯf<[̙ o6=[E1WGOڟL7Ȧ PL i-J}g!eҼu5uʉjc
+GKd/J{09u=Mg}A 蟏ؿ$?b(s<Kl^<+$l kJ:Bk]łZQV
+(nYA8N]RzTъVm 9ܼ{y|(\@ܥ6Gη-ɟiXG_r)}䦯S&3ħ>/"3hVem ih8``K5Z
+6ezhӮlSzx0E^I:.T 쁍as#fJ_SD=ׅ8҃SÓquSN;=MR4Ӏ,MV&JBa uj &ՆR
+
+:A5٨GICj?;X4eq&#Aw
+6^p e+v19#)qJ9X=826ƸD`[Z-mԆZneӪ | H5[Ψ7ښ?ڐVtZM_|h_}&2:>C&AR{GOn&ڷ^=ݮVWK踤CmX3q}Xi=I#㓅jZnڟ8+.1TE_ܤѿ:+69br3DŽ"yY|SSE_=_&q[kܧ.fj4cW۶w-ͬ?-;Bfm+!+rSEjS{g'$J"%7e~|i u/-a1,ky؟*u;"me7nMѿy(_Qv%:N
+Qvw^9_j'!i9Zo
+zk#}R'j$:2?)ιe䤚J:Wb3=֣؆Xg~yJWI2+~XquWrcT,{`#7`n.c #
+G5ec~١*QK˪1h"1~5 eĞt[':&Mh\^jެFU"(?r
+D@nyʣ!깳;cܟ
+S)wLn,`3g21(7<?&xm'i@? bsk
+.
+ĆeEM^B>>7GK˥~O8#V"G,+9cea∡ya5-]ß^'Rm(^]c8솑}Ӭ{XxF[ph9Hl‡Y;wJ}n% k?4 Wb&8~uQRAQ@ B fa!lUja@BBB ,ުPT***Q+Ca{~ssfFk t+#583NœK^E\C[KM, 4ynMB4q!̓D)KMTI|1" s]n0'Q",VB_fj ^^fMʸ!<uT]<W4<=<~KȬM{HQƼ6qTa00Z>
+u)!<x8^9uL
+}Y5ԺKA\ z`Ƨ~$R^]B^ Z֕dq1i񘜸l%'-Y 6i3x5k\Мۜԩ*H\ 褩jBOĢoozB^!'욈V~-~_TO\8@]rm{^v-~JMՕ<w'y|wRfwt%9  ( 0 j'v!Zg[N-c9-VC21^i0ch-EjSCid/ױ*@OIFFGis@KkD;cA_$vD-7c#
+/aNᄜ1X@5o%Zv+m!J=O-[#cdǞҘD)w_ӮJ}3->Ig*ϼ~ŗ<R*<tS;XXeѬƄ71dEJ2yH|'Z'V0@VP'Ifе Ms89Mg(m8Z[5(T)g`y k
+c+aW`/̙Mz`ױ
+_HaA{
+0#k(z1\0CuQ>fmVZ}pzavۻk1p {*!n
+Y/\(RXɸ~j ){E1nVmN|1p4/쏒˽p/DN:Ay3Uf%/M6)&|6.-z5^0$,f
+2XU }V%>}E܌azrGw[]>nwTms_ W\^ov<{beD:)/?Y3b1QФUyUP5bdCl ;> q΀s PY
+@/d'@{s\MvY9aD+MzH>r)l]͞Z!>^^㔐5P_q'iboNJ'KӧgK-Wm}3t| ڶ|.8 l^ |m5]nܿ^V7™᫴k
+~nN;7=n]Ș) 6&>5FmHE j|5>m~%(8O6;dG^!T|az)l/Xbl ,X`l QkvK6y o7Ux_n;o*Cc R%\8X  yk.(rx;Mk䩈bINлzWxiB'a|4~5qoyؘ,s "/,ř;KH}G}&G}fMP[bIlݥ;-w9URI !`9u'4wNF1 t,H:B/= peӽe
+QzBTR\o@
+_,aUJy.&fR@|h44Ԭb+?`x(C5[焚ȗ7q4pQTu
+#E/ <2Q4%PQY4$7q񁏆ŮrؙUE
+p <&?ޯM_*0U49.U*܎KԯiS|' ?x֮g)-T6\./?[Er\'B{Nh(DȕAC Y;^^Dnw@䬢#&%<guJ:bo&i>;VfEIʈԿ8)т45_C/
+oD6=(I>+T)+i/'%:{aԃstink:xdw
+@@ iK˻}̀؟hH[MJ5"I78Ix'L'v(Ci]ƵE߂DK j-g'}EnDLc2dQ$џ+A<1-wyGn1I$zwXFx䄿.a
+U>{xgs~`a6mE@8Ea&F4z ; >[h- {V 7dw
+=%!K^!7 _L4iS+י72=Vwһ__~7
+GRoa OYcg
+fԁZ'lC}s|Om:{Aدܤ'Ұ_q!(bХď&\Njc%'6r{sDa\Pq\)TS)T2Ŕj/303D튊đ\d30cK-Z9)m)rIVGiya9y>~];=PD?燦шYCU7_Uge)iM'-'  ;*TpH嬗VլAR-gR:6t%c~"߳Z? FuıIC1ڔxMh&URu˔ꬁGժcGUi+zlj0(3 4@Ӳ2p6RKhnvjs5are9o=e%۫O"p_!`1k=@qhQ^Ј~Јak!6oq"0Gm ߷gdx9x=^ ^=k%x?
+ O6}'}t부JO1rKO %Pau, yevxz !^Ay+Ov]9_#ũ쒄. {bQYA%c+C,vYf͎HMÒ򅆁%4PWl(9l$ܷ-nUo C;yPaJ0J88U;׈f\jӮ_ii5O44xUYﵫFƥV8FU+ur QJԢO,QJBm+S{=h5Ea#'W%LlM7 fCp'-r
+endstream endobj 19 0 obj <</Length 60063/Filter[/FlateDecode]>>stream
+HTT'A(+ A,(EjBBZO "!eE""OHJ/ﱺ.(UE q{93ܹ̝3gP~dp%dt.p!,^zܗtz|6:x|Yp# ya>a`
+ e`հ<-$v<Yb[cO@`*e0zKWY#6>x{z+-|n]֮^{jqˏ8຦ʢ.lv}՗B>:#jWW݆uC'.^ti@! L(=fw us|G8=Qٟ *r؄U .̺
+`+ wjfzQk # zNC9&20. ?THJI0?Wo:T7` :+;1p!w50X
+C1ͥ]5 <٭)בmU/ch9( 
+h } {F;B!yrS"L}l]l@6R q/aQ%ӪJ&ۖ'w_M6I2U%ԫMQ"*] w*Ьkښ#AhܞԤj^ݡw_E^Izރoz==ǁڰJоDռHV<'ߵ'eT;66W|<CFdX񸀾`!<=~D>sT| >1kÖYΒи/u*e/g^^YˤbƼUoMqg W)|i &r>=OKZȬ:7q6yggRx gk fEsq1|UJ52qzr&ߺJ#+{HqrTN%ܞ/K-ѡs9JE]΃>Ӿ~n۴ ڄ#{F-ҸFz!q۶srZ'5'^8s?n41z4V9( q>s\qۊIؼY's)E]lyԚg u?hx?sP g%#n sZa1ÃHq|sjxcJRrcRrSrbc\bc{_4EG,qj#sn
+)h^gKV|2/g3mK}5c/b95V=[HߪKQ//YVx?Z@ K%cFS*}~(bW0+e>a,d?+=$<Ɨo3{O1L }n?.c?#Մi8Ә8~!u~}|QڋK仡 YB9}̤A볽v9<WEQ/"iVLV;T>e,<5kS7CȝeoA2f4&M(/]HUlxUhLyԑsf=IFWEEo4-)8•sDg:#%I(}-`*`l 3\ 2n0Jmp"T
+WrN>+ q UŴeSײgٲ{isEߠ1, #׻eOL:w,Άuv؆͕phᯐKiX&ǡ<*mh_7<#WYRn <gXC
+Yvb) ]srfy+9;ut LeoaԚ&1ApScҮ<4e7ayU%{ڀЯ<HVQ\=y
+Hu
+ZD-&DZV#jTUWIwE wJDQ)bvq~>OM[}žS-3a+5ȭǑ~;}p(Ã0 ; j8lc
+gMaq%Ap
+"JNColLYyeT@.4AD.K^dLR
+K)ݩG%u@-Zzi@+X+\7c@rD/G@\
+8/yݥRJ(;KHoQ<|9y]I \L.艛OZ<vv1=||f$`ݮn
+{~[me919 ^:q ^µWpB r ~D@,3[JwFDg܎˃qk`_` ?J]Do"V\\E!"(D ! m RT׆%$$&(.MܧGXP,Ǽ;ow=s}Y2JȽuwW҇-Ib%MD%|M-3[HKZ}Y>l_"l T
+P;3|Q4w)絇chܡքDdCms;I_5߫cqWaZMĐSUCD Α"7iM*uA4z];_{Tti'</:/aƝo'5B)1(ggtR&:1VWNK b؉>kHP:!CҘ-nڼ7(*r*DZV%$KzHR΁=z@1š2[|״165/V-m;C b>0csks{agfۘ9F}h/ P.bvΈ wjd!$2>
+mF?3&b
++vq bm5j zّ"B?(06`iZsysrCSa3svNO1{$o3Hj%JcUe\\t=@o-CRԞUyqobҠMCXv_EdЫ1e`vTl2ѷ2@;8YëX{G^*aE'6)XLibQ0[3+R0tlJX91C#Ukŋܢ5V`O
+ϔ쿍~cWrǗ|f|?]%ff/e<ZP2ߧU"ܵH0ez(7-i?BX$VI~ot*8V&OD^t.gUVGY8\3k }|5M%'䦼wO&ɓI铈?T|Me|;qeb1/^/ՁͪկigP<fxL hZQfgtx]LYԿ
+ T  @sG}(}QeDǠr(r3 x9BH"}pa"ע-
+npA@WEYǷ~Uݯ~?_
+jLAYɁ]؃$O ;v{6|g G)V(1b>~T(g+ áK.*|
+W/JZt5O+JY-Gg_~aW]#5K ܐ)8<D'5? jl"je( -*;2B!iQ@@H2,*Ev  aqTZ?GB9=&߄[rSmpBr Qv}lgC`qg00ڻHr^t-8pϷ=ɱɰ"LadLߓod.k*m T567ni@:~%wTPup8RmQ(w;9M5$l~rŴ?iz:otB{hNǩF * Vb"S:*Z8*_i)9Y_NLiÇ7o݄eϾ<mJOS
+N&M#Z%݂E~<C7$yo)Χ"\ч] zvxy2?Ik4N}d֯/G(,U$7)7vhqD&2ui#U1ʱ2XANj5Jj=[e%tݽv p;(齚SB^pNxƀz:7O+09S,gV f*`.T~90ƒ3Y
+`ЅJ@y@u3bn
+Q<*مڷ`H0KHq?,TMJsڤY e[_:6piTHw)9SV%;dq2UR,<|H6],@U>DSOߘIۘۯwgkAAmKu <oi 摮Bf44iHg:hϷ`*MWz[N~SB)%Oj]&OjWPߊDy3(佛 OwLJQo)qiЩ_}]0_spU L {Fʫ2vZq`~9yY}d"n]lɧE>yTߙ{^3Rה5V=1^c0XWB[a/yAjƲiEW)Ѿ&X2q~jo\Ur09}K|kPvw؎(GםqP=>~mٸ2w/<B
+۽ѥu]y US0`ѺsWܞyǞHE0/H8z97zջOguGI{$Wc$ KqW2/e!g1/t/_Mp Е(,j9hw xqrd{-v95nB(^ l\bF-1e%/~gSWR+Sƒ,{gc߬U c\`X2k]QwE EI!6<qGKؙ~~žt޻43g^o‹΋yh䧾MjmN綤kOM?z>7J=^o*u}w:WCɬ1轭0[KgJ{ĿE,alTKl0y0K0K|3Sȟiw1d˭1c4w&6jA4j+Zu
+`_ hvlLC{Bl*iOz`
+5+9z9
+ىJzl(8 ~pS2j^_AT0gF[~:{=k]_޶KKɁi`٦8
+I3I#yuq&UF5~̫O͛Wg !1`{&9&-Ap0/6]2Y1$-w=;g\Tzf3EPeIDf.kL}k]vB5k)R^c 2GQdy젓<z
+^v`
+l*ǗPK06L
+ٞ/
+r6rTfy:}[{RW*{xg*~Ƈy:u:[7ePJ4VA/ּ6ukC!jJiJg%Z ~~O=ҳ}⒑LM^/u*T㗵od^K]EC}Y^7zү~2aj֩)fуڒ>-#=C/aBNj
+%BhH@P"+ k: ".J\V*Uwm
+/8s͙993{'VW}G.3+>*2SЅeBO{bHgoy ]r b)^jӁfw m~z/%?-?!1SCc#q߮1}kĴswޘ1|3 O>W>y |;c% L|ON^KxO_laۂ/
+Mbbr%+rP)Rt V0r|jéXuCdr ezcwLRb[B/.7CJb"{څI!CNАI=iCȔE cʺ61yߵ>.)qvp@;k. 9iZ[ғӚX9
+5Ĝ#0>8ssC[qӦu3+fJUÎ`eG]Nx&^x|MCSC7 E Z#F"'pq6~%SmJ@[J[LY2o!1y-x}V_,w_R,;~U.sXV*s\V.u[R.^+Z.\Z_լӬXи:Z4T`HwR*g!Lۻ\(8^t0#Jx<+A?%G:iչ 7%eUoME~<%5j_m=N"H.2+ ^ٕ{QńUh>Zc U|C(R^L^Jn_u×\k)>n4w;
+-_ʑ .>ہM: 7YawJ5vJE7IPio9r'mnpe]ܺ޲s'4n84補<(:а,`F\GڬQqȬi%OJ껝Y*˝bm80g\=kw>O3Ei /N'gOS>|tdK._,4WP{7nE CBbxg$\:,cf\'T)~6 pA9Tv0@߅$ZTYl)#g"sD-OX3mo9ߥ'>ÊzIT ֛d#܃!
+h@͉ep
+ &ΡD8c.X!!H
+ۑ8ԑ=y65e!-uBg!ǙjK˘ڙT~KՖk=vEXlj: 6
+!Kz}\·E3 06*VBR5SױB+;xfFFVJ& e{Q) ,'3p0>pI79D D"&i,"-X^F 3$'2 +~3.TЖ +F7}VjEƵވ gD)E 7'Lr?bYc~5ωK%A:?ĺ.
+VPBa%lBB !@PQ٣@ÊlH+ m:z[GU$=&99_C};؆;7e
+v,zr;lShC<m
+*~tWW|&ѫT=J &SoHLb\1*/#=+}nXDy,ٶ
+gm\xC&q:-;C l3K,,K(8zIcŽhɨjb2M zQEGi,T
+k^Y؍ KT{U`]. "խ:ؚS)8FxəZO̟5|ns7p!tɭQ; rʁ zP tI }F_tRE**MC3*[j\|F]S4iiL&\eop8u2Y8v|!up/pc~w rI[.8 <BpW D`߬ `w3L';a xD#OSܧ@?87QZ4.ðtO7fnB5~{a\9wmM~FkbSiDK)T@儝6Ɉ hG׷.C)F.P
+`So\t(fh PZ-hi q!rl7 Ќ@ah#BS;DF)f"
+=`D7yZBV4(D[l<NM('gۡKQ>ö}%F(/BcBJy8jh}
+ϙoJ<fud9xM30t]5ibMnB-eJ<QӨB)wYWdE%vD)
+6?yS+-+7ߵawf?8XR׹:tԚw#jq.d֘w{;gڊg:';xi~wέ Qb5F&?:_
+]rl; "2
+l!5@NпkJ,/?;Pkqj \"&Ni@
+/ *|rZzh@~A/߇aB} ~sDŀ[go 7?'0 -Zsٓ[9Qv}*Uƍ˦!B3n줥ϛ3~1g{`<imY;8FȊW=z ɣˆU.都<߄" g mdhb%CB ]"#E@BA.g2}(y{ٳgw|&
+RF9
+% _*AC?4dzUgi~R?`I2dI v(J uIj4EZz W^(M[^ư–uPGj6m ȷ,QBsUNzdΓjf1IQú95%뺨e|RW=oڜ>0I5vlJؖ%7AM)'y+͜{^fIYhx_s7rœȤ\͘llݐL:vX6\.nD!8شzVNjiF[Oj!b<bieYпjfnTѠYc]+L<nB6^|z1J2ªJaMF^I^"'j9vӻNZޔJ2FQQ"A.~NQ~8pgcN37]fl%#|.bip%}m͠wհոqw ji?bRhgR6NlGn[Tŋ8g'v.H&lY)k /El/o46ސW[2)`_#SMxP
+T\l,~A4\ZQ{U;(JhAYU%w_57u {D NauY\|Aaj(Un*|k, -c%`bSZYF~F%f%A3`s:O¸uOkZm9] s߅č+n;kg8-8(n#Zŋ^JxKBcAp#ѡ BNdףW̪N+Fu  l[mY!#Zl۲%ة?Ů`iTwϯQfHuJ~5Ā,.e :i@0qV&]?z ?afb"`8QQеw
+\iR *?e<d
+t
+yġI?'ãV1٪EQ
+-?vڟ4_oB 4tJzrGKEZ# }2~sLsT(Q*ܡY*̶nwmՂf[+ "4]C=:RFѬRgc|b\iyUR8)=T(..+Orgr3{Sf4
+iu10+y`Qqߦ2!T}>/y}FM\<2>M%BӺ҇m3žʉksW{Tud>JiIo~Ong}&vlD!b|W%vgmo@ ~7q=C2`+I[
+@X'נ|$uvߴ8(Plq|ۦ+F }M;-?eן͹D݌C"nJ>Lh$p'šw[Qcq[1oD"a 7H]I8=ɟW6} ~f5-Ł$x0Q;4o"(+EE m dh 5@(!X@zґ.!H"g8sdwfY*
+PafxwAG QzB7|8nԇ؏|
+ar`}K--N˪F *[^.~-Wb-b-W{9w{.kt/kW'z[gޫ_n^_E%zr{LSVnu$/vTp7u!rڂo5M7e>mI]h٘r7ڳ18sPG;.@qQE `</B`:%@X-Ȁ~t K`07F|?zP] 8I pH`]g\
+,&`q XP$6@DsB7IQGSTEc 0ď^mv
+pY3@,qxt]<`h+=xWVzq+_yߌ)VS}nSA+ol
+}i퀤9B@ڴ_ޜQ`O֤[[= >f9rτAm[NϘfi[Cٝ,\#ū~?r[GmR)f`(
+@R`Wk.[ɑ"IrS̡*?>U>^1Y껠S\m2vȢMMĔcCoSDK1q3e/5w|M ^86˸uEnx)ipԁ qahH=Qn+h_$pP,dT"|\2j\*fV6<P\LeQBeEZÇUoPQ*x,WP 3|{|u|W|5-ubU
+ |磕_nX !şlbV|!ʕT!dX%{?!d0>Ebڪg\zR:%ڦMRqv&cC3wGm{8N>+|P-p[W*}2eK)M)y[VᛔuۼONIr}6 ~!ViTT[h ~w%ª[>|>R"4
+j= 3:0c8~XLcEO6\LаZd:';J
+,Qλ%Q-Ǩ8̼+lL8EdT *rip^ h3RWF
+ 4hq'(8?8<~e_u)4w<–t:FK79j
+fUظU2jls\.75K=~)1nT0GL;siYԂe1i1iiGkNS3KJ[LU*g
+nάWcUש~KJGK7.}Ŧ^̻)k>;G9K _a"$93ij'qEDtA^=4^w!&ވQnѭ>D
+ [nqy]EpWZ_yroi9Hק%C!7xtĎOC<n;;>㍃ 7# }c;_ʪy[6ez#RwZ`*m n6,Ȓd$7I;Bκ
+ޅhCaԣ1kQkI&8N!qY9?FFP%Q޸H/&cւ59$XpM, %I?$q2H ΋KH sI(Hb;
+<&TT ge4
+氐 \F
+Ǎܸ-G5`7 l;!`I7
+U
+wh8h7,lTTME*D!m8 (NOǻ؉wdNf6Τ>WS^8F,s[XvcvcRgz%ޏ,qQS;CVveӖc\!g=. H Ft^rV'OLx&gVD-%7jf/TMl\J:4]\ z@h
+RQ";(K1@5D RR&;"d1}-Pi~78y37%s&?ۈbHû]-]%䷤|9oQq} 3$O'6̲*e릂M'j2.>9V>GG/|WL}rajD(辗%QY?'q?!v 4{s޲0Mt}a~DhӺ
+^x
+X ªq"OŚloϐg̰kРг_>wq@'Z{'ޯzszsuru&t=os}&&PHhwQz{'I 䮼i<<ܞDICo574<rxN~ݕIErWۃRֲ4t}o`8D"޽}\$
+vhXtA~Z<KNm 55M}wc8$PU YG~ݱSioT$O3>aA' 6
+}HVp ~w1D<GV{yL˾Lc,{q`n!4hhIBxcIH,jv4`8ICo!.#lwx20qCs?n/Ru@ꊠ_%T EA_o<=g G—<ѼN[
+D̮PW,:Cbۡ U ghz
+&$#;(Kf_s:ǦU?Q2-?Qy9_VO훢{~[-gPf.YOrU^kJPPP<P$?TD4q,q<Ai.tyTr5w;wT|ճq*'[z=Z Oi}@=zWO
+'V[UHW!>A@np EP)Z!R.]v(3gKƅzydf]욢aҗmW)d9Cۻ̀-Sp`/# 2Em=lG,kr|lv;ovpoul
+a UnΕL^v^j]lm$k]-p3$:)N1I}q}XjY9e+*i̻M::ncLk2fjcǼ6Da+Sf}xqs^ {O}=^?pEpa̩y@̬y-|DX43ñW84QKd͝!HL*.^b\
++\ ґěX
+5 Gcф! '5F,Z?q?m` AL?d z-}@Qu;& nrYWbk/rC1=rcԟ.h.v i8F?f.?F/ksC[P@y
+G\U|GSb\D|#t*#)g%KX U4k#.!JzW&7.iW8=*=Y6U@rkB\kLpt
+p}L<8‘mTı%\r
+SKW;?ضiȜ8N꼓$|E* [tS]h^WۧJ4B}a$D$j(M::>0b~D"^Oݨ@dш ~ɓ2SҖX4%GqtH[,'|eיrꊫ(HC#y#$|lHd}4i*w+X9S}l'e XKIY!"|,"Ǵ>X_X6Z Iok_`NO3*ž&~QZ͚͖^;8D?Sӝ7SڝBqkUUOSj%Okļ''zF^ZElMCb#` {Ј. /eF' );QD
+H,*UvbX$".aQv0(;*K
+qZGjw xWB'!8/>r>~CFfwѯx=TdpK\:*=Ve3{Uh5]p]jwpCyupCw&7d5#^1x.;v}e`_C{ۇ>XDuJklfeE$
+1ws wG d𻀬= dHe2Z <tIUG4yMhdx_PM.֌r7b a] \.pL`mkW|I)) "jbk$JRk<q>y=<͒dZ͚//JEåiҴ%Ag缾oWg;۽e%ʀBkҤ 0i49ޱ<AD w3FHC#G=GNM-/_ƾo(,P+hb7F/4
+Zb{;j P+z;J~A#Ka0sz|Wo~Cޞ1ry/o
+C
+Fߌ;6eGU罈C "
+sQS4NQ! ׼I-Om11t!zFi@z*p
+!ϙT淊fUa[CnJCs[JL  f,WE-ӫT<W~ِ1Ӓ>Ng 2RC.##|5^z<Nyȯadܱǂ!]>H3:~0s%qPHPF*;x?m~g)?Sf<Rd<P`+:Q-7^?3< oHeDDAǂ("B B Л iQ` GAd8k3؎+0i?<[ι7~?S*ZɶUvNMzE Vobw+8Hj.t/tsmA RFyCyCgqbd%/] _?.G/ ,FaE'Id+}ߙ0m}oݓAlma-_[4(?H/r}ڠfS >ljs'/b7a&eh)_!_G8"-922~d9e,a9F1ME x<+3217џ?{Rߓ:I;kaGa5*Weu.8Xw[Pl*F
+&h\9DXICRjl.QY|2;+9wC^Zҵ;#g(m)ۜo{2^e</|qv 9IsY3 zKK1%yʤ/,/~)Л|[\YOP4mH
+Q`LmeYvw)2?2/2͏d! 9^Þa`?(s;r`ZN2RI5⌱FT:T3Vx-%?Lcd}
+"/ Y..JX
+km2 VYEWJZs
+۝KrK˹˞ |D٢Y0V]w77j,BS_k vA6H1.6#ͅrTjr5|VۤN1Ncrm-L[A8I2]ƨ}~3^G
+ׅc5n~-.\_z\y|z5Lbp.+,pȆtNJĺt;_}4+i,
+#yCScU@X'Ubn@(iCsvU9zWhY [Υ.c:L<Gu0񻔮tjy1 Հ!1C)ia|Rάc˻^6#m:c1뫁&)pHAFG^2Bn2=|r & To~պ+"{!}' ɞ$XO-jZb'N=hw$t<29W}QrZ\_S$<ZTWsEށ"<rW^DKElD/*sԉ!O_&Y5aH|`Ցb>
+o*&Lr07Q)",8:u.UqŠ.Yd( -scRNS`$>)u%ϣE9O>v~;BGnFmC}"O/.0_R cLO'8Z߻.xO>gb3o
+
+ 0E.΋qMvF'#Xw50bMoN39yz"'Өl^ .4fxI?Nn[t>Tfd]+P VdmkƸhMcx2Dk8G@Q{nsĽrD?uF=qE ~& }dPS/Z8o?PrR=*?fƦXSDV.,*"B!,@[B$,j3ZBAY H 
+6N%^3${>A'@SSgЈH'O5uu奫
+gQk qJAh[ &HFKgw7)NG@RGla@S:VоDv5Pbt8Ns],ЭmX"WFݱiY*,OFD\Y&hrMhii[εi. )f]Ol{|Wd Of}@/mO̼#Ňݼ72u*s'pOm>erWދν/r8{2L:$W"X5 jaѮp)-W}[w۴~F]r{_/:™a5~e"_#d=m/f
+%GH%zڍ9XߗAFd}ss"Ŷ9 ?SRnK厈^y $ӕ/WY7[YpmG?-e?Zvo|m~|㬙4h֬tY+K5K>},>qKsciϦTϔNvx#y2Q" SvU\I~rue=E]M'.d{GG=fǍe [ءJQeәpXLT=1/WKB_ ֤*߇e~ *8 ^.=9o+ ]"t^k I
+69jw݆tp`{+ |rzjmoH
+@]%{z^wd[ctyI6[C 58t0@|D j3WU2]H8@Qz#zft=G90Li' 2nw6^JӮxu
+gMYW][U1aZ6fD h1~4XBpeӳ=gu?^6n\ f?A-|5S!iޔDl~o"xiO$RFNZڐ!PƟ͚*u`d9ӄ6 ܪ M !ǻ'cd]b{icXkӁ%C5%,̯:Hd,
+ >a㞤@(Dh<,UypP{s͠Ӂ;}ROxEtAB%~ޙ
+dq(+9<zH#BpA;<銮Gx!p䴃1pj
+k*K@eȢ ҫC -dT,kŲ(M#`@.EY`lXPQu]`Fȝs|yNsy-1MH]vR%8A"At ;<'v 2ݍ2#ӭЁCJ{zJsO.J=?K*+oYw.!'Ђtmv7-CD/" bpjBqQ6^@OF,E 
+py&k Pm:('12)2n$.OFLD
+x
+eMaY@Iz
+Wɱ}ȴȶQʲm=iqaQzZㅕ޿ְ #2KIV&=CXDvRdQyRӮ7c}ke* | V~Rjbǿ_{r:I8p^⌯( ~"Ŭ{:"GLǯ:.ϑǵN<<4^tMJm<QFu\,ln1=U94.ZAK6]N|]"BfMu>_Fwnػe6'~!ua+FB!1="7>4G.R
+X"kbnr.G|e׀ud
+`L025!"7+AwCSUvQccaIkJ!,إRn+b-v!5
+3أW û_ <[hܦ!hNqZ]
+ ˾L&/,3vF
+~U`wmV"-XP˅Q'G'Vq^1TV'
+lFe5@
+i _QB,(&rd}\ m:@*|pH#S!W _Mj*m
+6:)//*O*eO<ʣVD8Wo{ĩ cmX*ݛUb;CT.ګ|v &
+VSeMj{,O2<6-)99j,YFY1t# GdžcY>̳Fago|ģ ٣Gif9AON<[Y4$3~g=_-_>1y5܏ΓK95.L(MIgwM* )_,ݮ8`biyۨQl'3s6k=k󌙿%=/OsV?<f?YYڜ!5^ĒsJœX,$,<Q>
+B {ʰOuj a "حQoG,K.G;n*J !\F|ӉNIn#X$wPsYD -!o
+i%$SYʀ6Uޯr{4;|v77 18b?"~T]7^+Afڈ)nd]J].ߠ؆3 *[{C̻`e F{d~ z}J_ڿH80q7oI5z~u1UFCʓLeʽtdԆÍjǏk@w"gk oQ`2y8p!ݧ
+vKѵAz`:kPvx- 4T>t8*@@_qEG؉|lC>f @E_ЩӞQ)8p}͠
+Zf~dsuj==u?V^{<BQZ}:L2t
+CY t,$](&1T A j3q> FjuN,>45[9ó[!:e'vmik`ɰ0nbuLT\&
+#):h\1V
+
+0䦂(0g$0!𰀒z5-|{}GJWdˡ
+:9zr2č&<pflezj̘g%N򵒚+<
+2$3n<|)#|'aex}Ir]vRcD޷$".R zG!jDbDĘ.z-iB iCبDh=\$ (4!Ǎ }
+>8zqߏkݡC-"G1! B;
+sUi9w0:A>_{
+e]{*<~vhs{n۰~%E{f6Z٥6Ct7++k~âEV&fU5z fů*E_eԾ[_E4?BMr ֲeID@|g'͹fD[ FaMH;#8Ef,gd6LnIOjg>Ö|{xܑݯ,W\*=@25uP }\]KAع\p0 b9iS:7 `&H+vYj`!bdjR`e'ٟm\Xת @?x
+a77./Vo85+AIp
+WDG^79NLQLkh<msuaXGan.1-;3QJٰ6KS VeȞt?_v[}MqNdUaTcJްdV,kSc3. q_MGGfI,L*;O/IO
+],OMտѻ)L{53oTc 5N@Џ4
+
+?(gEG!B%` {Me0l7JQf#lZ
+<d_)7,صP0[F?.T;/.89rrpϹy:d_/*w/qw~(mܠkrytccwoV?dCfwC7Aa9%9ns\rO~]U7urF)vSNE./ se~sK#^**z(~/O]ITyQ~3NYvs͓f׽a2jJ(¨PETDAdB
+@PvdB (qYZ=Zlg:3jG[ o}yO//ҫL>ݻwlje"t6i& YNڈ4r'(tDhҷ/ Z ']{Ð%Ȯ]O?Zɾ؇/~?izePzkY{\;aX%zp5T`L}o5/fse&Q rYrrIz{Y=)@.m۔\ TmMU9 RՋ4QdP<;/q97a)7a97v9{$KiAm #eL.A^CǿdeoYy$1yyf}7f3Oɧf쟤"
+I٘1_W$#e. (֟Ǭְy{AX ,amqۓ/<1QS8u>]9WŬ6 -70SJ[s_8c>+}߉tIR>dvr=mzG|RkIMx-YM?a? ,*:, G7z+*8:.
+8M[76Zam88ICk
+^6D@Kk G.ܵĶԃ#9ɵv6C ;$B*G =SO Cߜ^uA7筄LDJFh(c*z<z<z.|fݘy~,0C5
+fK8whi{
+xIp$څ
+N]ڷ
+'QNk9 +sg-DߕK<4*2Z;+R2
+k+r?OPA|4`(J3x͙4m\f _xH1
+vRs
+,2WPAp~\]DƧ?Ϡӕy)bO{s}X_7>}ц0 s9Hm*<p[/w\pYN\9sehnk
+fP`r!4k')A݉dDGRD{R`k'n)-_};/Й&+ޞŸ# )}LJ2_IKٕ^Fq쵴=WiW7WYl!K5B(éWyYW#ɝ/ShK[3ޞHK^“[R/qmE4lN`{A='X13t-#eNTq !X^1> lXu"RvTϒ?U+kE+$`'Aq~b
+3Be&#ԚD@ e瞯A#OZQc4r[Jvϛ5bIwcI 1B,ip|e>7<J$-Äb6dA{_jYNA51dBAdxO/[{ȲU)<#{e,̟,͊MKq⠏h.oUٻ@ uPX@jF!h8I #:S)9r?L28'pԴ*6ЯA%ц(!Kۈ 5un휣X@3ĐQ`<DO0>L&Sf5pП'Afc:𚪇%p7ƞ5)FlBĴ9K#B;< Vdеh_C0Lfɶ_ O87<F_o|<}ݣ/&En{(Ͳyk,wm;&D<妆pd$$gll<5m AQo=s] s0r]iĠ1f\|dVb^)u&N~u<jb}QORGwI?yyOL)"ȷM-\wztc/j[*ZUHNjyXU3[vrp{p
+ &ݺcp<?>pp~/H?ήh|:#>GcDN4Jpӥ5ZW=5hzy~!M+^[v07n}f ^jnR l~ #
+  >w <B43ʰ)z[ /e>/f=_P~לoU=[ְ?,i]1><i#" E<<ߚ8PM&N+xQʔu1V2xN0#N(= ԼnZЕt>*!Ӧ݂)}=)3^ጠGNMN'@8'L;'|H=M2O!zҞ!U!=yS^e67HJd 2kiX`|`. =֠&:FEP'\4ЖkD7A#~ޔx^1CiXbѰOyV{ԉOAtA^oAys`}s
+2nFV
+k8t"˲:w7VV7<՜Gx@E"Rʩ)KdkԜPҌKrkReFYv{/}(O72FB$v d{;9=hy yS 4ow@8
+!6 8??`vͪv"_s :(>&
+€G.; (` c`-b]bbvg3O㴐GA> wcm*uGZZBz¿C"?X N-JvRj<j_6sg[Ȑ*uVJ\9VE = /`g`+XbYdx4G\Ns*3RݸQLU94W=ɨNm:xvrE W STyT$ aQhRZ*{Xق"ep
+,""TADPP>Ǿg['M\3̝{gcsVkOV\}.Fk_sA~`
+x`q]:M{4@ph}mZ3>PntfzLs'ܑO z\oDuEzу[*]֭ =xDuܻ M_]AnQ x_`F {|&xO3L=cKpѹ`;8ܜN׍!Xw]˗` ʵAwXb?r(U&~꺯m ̉W`[a
+ZU68]tC]Y}}AQ%V6K˛+OHdEREmiCB&-ow)d&tkCWmW~OvjC_"W\ivk>Juym%GnfZ=#sZyā3i{!yGKIK3Qrl4Ѥ -aLhwm09Ž;˂N-ASF:e5]:f&WSvk:)Xw a:D_p,BuǶQ ~^-53tC+|jVNkf%#z̨vL􈳆h҉s߂;d?3#<^÷s̲lܺki6L>Qb8!mnif<l;>x[+n}ȩ}@POT5D`k$zVqf^^k cb{: س蠦*&T,)W|֢<
+
+ %Ek1-hV
+,^'/VؕVϴJmsOOp +ͩ_v.Hi! RZJ7BIL1x2b.1w^#CUAG+D(}N{l}(vl4mݰK%>OLk<T{P<|uwz'~/s{nTQs^zX©X6Vdo>@d]뤧5ғwvR2%r=aZ.[79G~DZ*$rM}\'Em}IDS^EF~ݘtb.CHY_?_
+'UmAVRፅ/MK经乍' ~1._iHhDStm'P&"P !Pn,P0-lNoa7o;D5'MǴt$*cv(.=@L{N2DwtĒ:p$ BCWΤ mI/EI/b^F6x-jN~ׄQz%V#^ɎTIƍ\ILUI \j+²%k. }v N(|!̈:s_,ggRfz0wMn亼=rR'奎J}Үq>[b:YPI 77
+Ύ.OO&tdp# 0!8q>!7`A.0Q`l;פHH! "Q~
+JiĴ ./9b[5dSlO`]>շd>dBX^TQS%* ˟\o؅f˧7lDP,GGf=TZ8?35n,0siPQ~nՖv~
+\ VXr[2oyE!l{]<W!;RRW!x61W!p\#GFЀ|hc1eZ*꾽VwAKk/ h<,cwWgK46gF9iGz<-|csY,K1ゕXul]BSzVkUN^׍Ɛ,:p.c -tP 98]w6p:,c=C3ў!ĀarпߙTɠQ}@AjC/S=e)R'= H0
+ezkAd
+|_nE!<w?;K9O1s>6_T踤|/*9/TN=VNw^j3Lc$xJ /b{n5H0Se3lʤُ˝'a7-i=-Kzk%|7^nQZf15?vŞd-ޛ^ 瞯y|Ssri=3{(FR20nj`ok=uj>|үͰoHO7 ?ID|;G
+!D3:x-jr}zcņ ofo(eѬdiYaYvYgzk*^ʔXbҮ\/K'dgt'<g&?ɔY}Pv^N''%̻۞HC!X"T D ag@qtX(p E~$cd<EH/x@N_#\V >xmkx-VrM%/7.~^[Ez-a q'pQ]AMgɛp(뱻.XuPQA% Bpc/HEvEE!%*vu;n;Nt:DAnf=|?f8c)RJ!}BmJ6f}MMlg(ubhwᚬ'·YuâENݟ(-Yj%bjh)Q!7e)vrh3ݢ?{ŋEoRٯR7j8u&MZKZGNveJE؞WIK3qs얢b紖=5_lLm -VápPoτ:#XUCY 6k6ʨ*wp//w!YEo](*2$vq96 Ҡ6J?X
+u0{xMؠPq/c3̕uEm-F=kآnͭmKTþ֞(_+/[
+ޭԚ4qJ.UF9uJ/Iᒲ'?;+}zd_\s-ыWjd1Dlq@chwz>2>1Q
+jm>Dl]4䅽Y)x.0IH&B:.x%ҫO66ݹw|ʜ #"TNɆVLw8n#q=^bg5K?{woj&7_;X]U]q\Mں\;V6T9Ӧ9]--T*tw]oG>AyJgNeR#ᄅmѵiCmyRvEJ%oU\jR)[٥j1Brzћ[iַk[L1 h><>om_mS;j~TQ󅴬yqOϥs<3*rjLu>|TdzΟ8b5a,s &)wvOM;f\';;N=r/8˞>’-l&dR4Wp :fH2۽b{B-:J}NtI,uGsV"- -#~Yhй'ytd ͼU6Ƞm];14"kWS8'h5=v26173r2ct3oYy%=*?.}*w`Uܧov{ƺ3}݉璺w䟖~=>r8m|jð6A69-
+$I0Ik9Zm=4Q
+}
+%F~䲇/i˿&ƜL x?c
+ss_XU[zwu_;oj?-=^٤x3vTYJ2CΰeBC"ߧV?ZKX7m=I?D"bv;I9"?
+endstream endobj 20 0 obj <</Length 58398/Filter[/FlateDecode]>>stream
+H4 PO%, J*«V& DvH$OE-TDQX!
+.:Zes;z9(
+2^IR_if^z5 ]:2dKJ7 H/@™uٟ*чcVluٹ}N梔B䠟7,5fr-\KkKevx_d>!
+d` ;A&
+d
+M
+ďMa\} L!
+'|V
+ÊeQ GD'S.>;MWJL {vDfEIj.kH0Fa> AP)ؕ~,z?/Y]JBJRxрحŅe{*{.רT:{/w.+ڮmOw+*G6IV*t7;n(TBqSԴSשRjհK3Q[FM7=dLaS' I6*lvv%VPQf6lڐ4$3vR/4KlRkL8uNGCsF )Qq
+>,eӑߣ&8:ӈ ;*_s8|a^̢
+ov!3Cg$?K:7<k&67p-ԽNr7E{Kx~'Eo0}<Yk+yf`Mؠ:iLIu@_NڒaX5V swʏD+o vag}i Z3c1AYP`m g@uP
+/Czimd,r쇨laVֲaUclQnAvN.v.nE#֧Un_uR9%4.z2eƬxK)`e5]w,c~zxcM `L#؏,Z&8׌pmqFr9r9᱁g1xML0rAes0‡#AlP,ܬbSGI\zY$}Xxv
+WͶog) ^ml{J|J[e[)U Vg'-Oy.<=.,~gq(k8o~'ܬ8Y=<W7?w4K4`-y&
+AF=/KRifŬlgiX+G8ycFkx8dI 94Eio37)k3/0/tZ ZHmv=]"W,];E{.ߧq_\i_+bȂ,~Ag/WNr4=T!*;V+%oهg]K_򖍲s\{ѴWcam 5K.Sw-trNgҙl:QDQ ƣɂ֜fR K'DLk>nuͪqfod. . }Pn5GԲ+a%>ΪgT{6;ꍠ埼xΫp~;^ʗk^avbϼ Â!b Z9|M1r]9zK9vK5N|@kki>nCCuZ5C</{ ?FoohK6Dqk<B~M:M2܊EZwC5uU_GZKQV_ͭ&f㦚،+ap_Gkg0e:sy*9Nj2<JEx}"GSmS4omtHM^C4`o6ӒItz0{iV1 zS7s3mRUjPN1(_7rN㧤9sƒ~͎ڪ̫;\\[u.jEuWU ݧW7K+tc7N#&
+"hgg|Bad2kl20=&%}U\?n9o(߫(ӷCxR\vbCnӍ 3EgۈʫGjmCJ[rLWI,4!|ŏsNeҲ Yyd1 G>1aϤ.|aԶV`Np7)O"5-T!aW_v#S^A灼 = PT^؆`N^ ɛnq KГ vS B9`'+km<N+@q??6 m/2@%歘y6Ɉ ״#L㚺8|
+{|xs=7y"*D̐m#Xcvgrـ<[zҿ94YM%K2f+Bh-CXyqڢ4 ha3YiapjEHX&iVKꫪ%jyR~^3R{V;nuZ'}q(NC.gVlrNoy_NN=\&N$ktTX3}i|iGSQ_)h/v],l)Nu=k87v:ERWSuޞ.QswL#KG:z':{'kAeB(m,mS
+'CM75?— 7 ZFje-r|kL455 av|XwY$fLQ\1U):k.V7_W5v(SMV<~XQs$; ]}Xu~qF4fdUd*ƌV{5c<GT(e>M]*ooܾ89[mvE)x#9Tm
+w
+L7J],q&xغu\dn0#ZIs!hG+k౫oٌiz
+~quV)`E儾[1O*svqёS?)Ya6r2cD!ڋ1E'"4؞$;TR)S N|=I@8o=C {=E
+b͙AK2k}',ˤ)rc|7 +RYm2?kUe
+u 4GLVļk~hlϜ
+*++$7deҁⶾi}Pgg\%I{Ս@}_&W4t7thUCm;g;sRy|R|b
+yD֤XSymxTXThmj\"lS4[TM ]tڿ/OV^xP]TUt|֣kJhBp=ܣKRbK~ö+-n&'P]UrrytbYPo}kQKMaA!<Cf$3 |uߴ`)d ~{
+`N08 \RF̤< >~]w+oak~c[ٺﴢy/[s[S!5Tlr'i?1ͧv' R){">_;m 3\e U W-%KP
+l{
+EԹke(37Gg62iڤQaP
+
+FapC8Nc5Lwݮvw,oxm^/u_ϰaϨRklTbk//,o,N.f)fզם~;}o^xn~mk~=ؚ8,x"c8#1p?%{g?1q?|:4cuGbΝQkG@9Z α# wF`=Q/*>Q"#pBmtm&cCLמS6ڸ?ۓm ﹒?X]Z $a; } w5x,&Xg090Wy(;
+t9:9*EO[P[&:MO*G[(/ČADyOW;+
+d5(I7L9iRҡHk1-q/n>qzS퇐^#B8F$o[= >n/
+t&o
+N#tp&U
+ŒBqSVIsSiM"hohyzg}cqͮjY`Udfdk%cbYXcOxL<u}`GJjsWԤU&Ή+$ܩEC5uyc 5egfHHIpIOf/=~f!>z:>bRd4/#$e_]_rVד՗~'Uǣ?]߻;AO M-2L|ϛ
+Fvyp vxs9U4Yڞzu-v
+Ż}*-,DްIS!^g#<~ tyQ|08Ȟ[d9/:,<vz6f͒=Sf!{ȐVˮ8uE82uNLFvdiМݐ7+򳱱%X` WʀE
+.(!SNOG`oe=FG
+>j?nc汥 ǦU'Nbo;c;I iQ|.. %hVl|`[uE+^cKt{sGT}Nm
+ye kѶ<ޤaEO z?ԉ?Ԏy}oZﻀG?3NzmfWf$eV7F {ru7-IJf.Dƙݥ&=ʸ|Ň)[M+eEFۂ#$J>t,uq> VOח=;HƧdv.ߑ"MZLX] ^F>&$9ٓwjU0?+_BQ<eQUq " !BX P"*n(jT5,(ȪX[u<=cZ|7;='{_~o(yY_|tl>WB[Esʐ[gm[~E=]P)~t ׽a2.qy*U;
+/<͂-Sz9tr8_KYQ8Yy_0(ߌˆ)nbwGRn1S:")N| #w#7GS|ʽLJy̱+dsZ)!&[{v[UZ%sroPvMJqvNTlW+[.7CNOljkԖwMFFWD[=.{(©0j;y_bʻOBQG0^rkq<78sN!fN@A]/~^8Fd޻>R\e4#Us~}o}Kɹ/N_IMr6-y6%y6\l}‡*ٜ_w;}Ns9WEϻdإҟ<G${7꘠<1MN,w?y
+婼μӄ+[zTu^iiZ@rIx]UhR(j*F:jH*?:kFJz\HQ}䎨􍲻ۓgʟfe<9?Cg=87|`Sh;16u#mDÙv.GGα\xĥKe"쐚
+jeIfW,ʓ-D aSUJԿ:2.ZX{dE AUR~ikt|b[ช8=W0ut`^:"MJ3SἩC\WΝ/|T٣b'Z1u>jҫr1'7[&i4
+̡? 
+0[x*bN<̡tl-\iQQq}+M<% wv.)$BScʽ.zb\߸KR3g>m X=IrjJxU$KUŵ'ck" \iSFћe跇[g42</cjxFCk$LNNE{u@?7!xmS!q*Xh+G~.AR 
+Qc/O͹GJ2%(eXѸto~zIt9߳p!n?T)UG1OvO 
+#R-RZ *'#!À_yd%ߍx~;uZᯑ v'
+
+xmj(U`Or9Xǜ^~^} ?}t_toV/]˟{Gxl*:ev+ ܠ'ێTlZ)\1sG0”U< VL0jvU|fпːv$4-(p&Ĺ AA#k45}ZD<j9!Cj
+##0'`o`OQ/$Zy̬C Ɲ59<w&Bp aC#c-]b4Ixnq
+%ZotngѭSRwyx~G8Taz#.],Y*?;Ki8Is`/Rߞ/>'N'繣E*9s9`\a#*! Ma8 <Y΁/BB49(;1fr4r+XQo9$aկayE.3_^9r>Pp\>gtm6huV ^^YzAKXהy
+#K/q0s_BjI?4+A5_#cmU!֎%-
+g!+ 32Rg=d Δ#Qo,Љ0"'\O3JK82g,RÕp=LzfQL,PPDХLާDvzVtlWʹ0Zlgy'Ou
+_Go8L;F=T-$nv,[ `J8E'w?p ͳ`w/p-lv0]`! 9({9%lw Q=()ʬI.+6<}oQרAӹwFvG${ߜ Kce0>q/%ml1|,x5?GNxsxCGjŶhSY{Ꜳ8J+1nf_bь;ˆ{W$܍lޕ4t=Sƕm{ΧӲg"-mrͦ3 q&v8 C"zbHtG"EkE#~g0I$Ugo &n;eqv1O"5
+vZf ޤV 2}+j^*Ӭfjrl:LYsy*gRoLܳ/FdUh 1mCq_Z<Yuɚn/bсHCdF[(V=V3QՍY ?ׇ *3<`RkiS7mZG6"s7DE$1$rBHC
++9{
+`t{T:x!gyϕpaALNA D.d~^Uc-x C;l]
+uu15Қ.ʸ<׽  #=3A\ _C_7k tX$܏mD+С?}^vN3%| lCWiTyuKo?H3\Q^Ow?_,vߘmdѯG**eZov9~c>{(&13R*7ӊdmb}: 2)"޸ *u31:<zq={>މNЎ]2Z; p?e:}sASvgm6(K_XG(PƙB0@GOFWnmtnUٱG {cc7 sNXߩ6?`ݥ< 6l&>Ԅ auEa{,(3薭\XHeks~쉃Ҳ{=<(:`򮢃ڊN5_=VސRCx?kO]>TUsl˙ e-UGΖj(
+;NxS<ZH-?eXdWY
+Kp:#~ZMvNWN%~Q}LoSLHӬ%#V⾝+4#nG>WkgkuDibu"ۗl{#}U\eC6cE1cǶƌyX5پ;rJ1upf:_Q.LDüG$=>O
+Ӄ h77^-dڋ;qmsd+Ek{e}FO>f7T`w{ߝ:w5n0mKI>_Z-L]"V;2.2'hr3c-*LXaN}ga;xF!VK~5PYcÌQU~P)tJ"jv|QaA u@G6f?`\e&t]k@{0ojr?ٟ=`:` ÕVBR,MlT|{{%m)v&x7 PEVW^= {2әFq>}
+>G?6?[ &FUt&5)wrq1g[܃y
+Wb*r
+BbzgZgAͽ[4}ƖNiyWb|hq-jmpnw
+1mram.lp[]`M]p
+cS޲N0oG:WG L&|>2 vtеΜO{;{Wҳ푞f3i:$Ŀ!x։TDı JCc/J߻G5yZ-U!WMi'YZBGBgZ)wF>Y>;tGDz9LdꯞoRsS?Oj#!sF}_r^%Te|]A |
+m{FzGJČ}p^92cA
+uȹ#w}]4Xwl6T^C2Up?uwE2nds-Ȉ|t0dK dJ VYtObp,d& &b)| sWQ=F@T;:r?ro5X/A V"x:C֯)^aaNC>qa]Ya4@ jWU8
+"GG'%7,2M?|z_;d
+39\mLu~{}1x1x@`|0 p>xD;3!/܈Lט1!OSщ *bBpB.ީ"
+sN|FZa]ô6r_0$Pž"2Qc^;>>tq`%`)rTj>vISw]Y[sݮ^EW}ce;O{AƦV^׽zAA_ s #.>)bG3K蝺C2TTEHë i+arys} ׷]m近.)n!wYP],hb^"~Kq !VCc^ʎk@UCC_r7A<G&j&j'j&9
+X&]^:㘻ʸLǵFrsrb։nSWU]'.u2/:ƕu q}Ģ;Q Z4r@3
+ؠ.rCb8F!TD"P&pN $k$v|"qrrG>fđFgv}3O)G^Ћ֥YIZ/Y.4~C+4~E3\94G=B3a!QvfHUI7 ya 0A
+-zh{*U
+h) .)!)L5@> ѭ`0h" Y d}"Jc<ܖa=NϲٞɘvZaxPRPJ!aU>?Ei,'&3lbp
+[@mU N.jG-frԽ<wJ֜j"Uo2&v&3JqA3qa !{9 )AςԲ/\Tr(]e=V)SJ_ԫ|״4l~"~cc._lLd
+6 ¸BPEY6QE=s:δ93S^L޽wK޽8#\E85 ŸB0&?tϱ/Kk?  = F ``G= y띦9ǰSth{&Cﹴ+Gۛ+ޢvϔqٌmjrGeں} \lBppugIHjRa7 DC B C΋]x6O W ~8 p^1e8P@S1}cA<L$O"+IЂM] |l-p_Rܟ
+~yw~.4wf5!dF B4&pV5!x §tؑfn>?i( T﷠|_*^wG {ۦ|Ǻ!<7O~Sr`9ߟxβ#c/DlQc6=M_w+zjN_^}}3@˅=dCcVy5y9e7[em]^-'lkU:8{.O)g\4+g-(9^C WQ7UI HbƟZ|ZrjdV2*@kӹ[Mgjz;eWIo/9pBHOcXmn^t;_UOObD)TϑUq]2uczEX= L<AAoo?Y{ e!;wgxTŠi |mth騹xpxF4_h:kNO6MYfS?JfOs'[o<-8}QWZhI⑬u7I$ͷG&,ʄqwO0L\fy'&/&6fbOO{ȍѐ{2~y+/̖sņB}"E;PA^TQkoc+ࠌJQbpF~Au]+l 2t8y3@+$a6SB}\_h׻!/ݞiո~E^2*hvh%`HɴTd&LVкt[`tpNd.h#3Aqm5[2b7M5Cq-[]Ǎcj3~l #58 Ldg܃t=Famئs~b@:T
+nGu1Ei3&Y9wrJ3m>uJtϦ*iF͎ vgD}lRФfZ]a^ĺ0U~Y~yE^5cMf'y&UgxwDhWůI:3DD!ABµLMb DZDpg28E!VisD
+J~7$]}{?[X^eEt5-Zov\b! '7&0h<UBGR5SrO^1ܿmxg>o:vwa!,8U/[\ŠL@(a# %lB0qGK!v'"Ks5qq .VТrGDSpB@8#$rK
+F못vwk]U?%f~3yRGdchIW&yod)oy_lMթMm}$+p#Cij_RG 
+6N-(y]2T;:W\;J PXۙvmw M}j#džUϷ oC7LC5blk
+xno[uϻ=)w~:oQQ
+l֨,(y(6w)EvifCl/[/.^$ɺ1}ۥ>sO{WyceG_Ő[{|#77"u\GNꨞ ~wAo<e$/MPX|$2k 6e q e
+o1"2Y>G1d)$S6G$dx{1:kˑ;ik?FN@9_A@m8uA c@lf`QصtHqX8\E͗^|\ms*
+ery'nOαGm'rUѹEˋEkeYjT{)[ͫ+Jd`Hʆ҇&; k jY'
+݇L S!,;b&z`4. i#& ܠgPoatd~go\x׵ tIVsߘ<Vೃͱ01\t
+ƣp|z ;vZUg8Ok H_
+S,o3 2:7}74EH4.&0< ?/ifK1 vKl?h$S) ׳vP=1Lt m4;\tr'LX[K=:O\.xkɪ{c~7${*f2"m]s:Ae#
+|rI?u>U,uc_v`S
+VnGٙ 6a eHm2vG&z@&8)CGBjIGY4dڞ=~^΂U~c*\&PMY Ed"Tap0&$!@ B؂R\ZEqA!a%
+҉dS}ݛeٽUDzw:ΝFzRnW
+b)
+ Ӈ4 |ّ)F&lЂU+M&ʾ1q Nh@82MhdKe,Ţ'nCԴpM jB>8FmGa`qG(
+-n3IxL9ȺCD5χ5,h Ua2f~,A z떠haBnAb0n)DTc)"LθO||[䎁yr<K]:9 ^л5ƾ4O;A&=dH[K8E噗 +6> ׃֩ ܡx\WE֪ !72*0
+
+;E9qwCPviG|JgC^.mi+km@'_R&jÒ_m%6^͕&\Ӕ'ք~7no+Q],LQ|ݠX-޹Qq'H'X,$L"֋.Kj-΋
+ N77jjpVQuQQ-UO$/Q˅~t JdAI@W{
+D#Eʖ~鍊X_5Zݠ$wfmcYɸ)|ޝ57leC2m5wu!<;Cnݙ0v|Ї7SōהɛJҹSul8={W}_q$z'-b>eÙd ʼfSN;]S&rm99 Ƴ,GzH}T.a,Mx`c f$( sݹx;,[t3| d@P؃ɸ/v@eH\)+!|\&PMY
+]dXCowXMc ɥuR]O!YvP^ODv_}#g/<:|iK0?+>
+2Ozwu])`gnc8B6qop.G`o VY`kv`R V;}*m8
+8<X<d|C
+??E/eH!{Hdu⨔(eւ
+12hoA m, !.H6ޣI蔸?gW!ڦNbsi|MLsڔu/dI;C$Rԙ-gA*<dLɚ-.u
+;*Z ւ+.:D=\kӿ[-<X<bfс`
+cZ8nx}}gsΒRԹÑj”Q+ɩٕ3YOBҫK'_Ԫ8$ٕU/( "߻tu8S1WpNiGH\ÞV&D*90wOJ=, B2~uBz]ׁPtAp@R߭!cu'NL!3Xd4p'9:lG1x➻!t uϺ^db 9 'Dk̟ gr̜݋66ooWwS7 իmqH1F5 4]R]m[M. w]<Rxu"WD=sACgq%kw+& ';l%gd긂ujQíc%eM#5-=ϴt)T\T67_hkQ_ց<+ ' `0l6BYd $PYXaSAE
+(VED$B
+sh&8k?
+{i٦wi")Qrg:%./uJ1K)r)0(py-36܅P _ 
+i$9"T!S 8-.&݃r6,5#W1}?#7fu'/lΥ?l>և1F\)%N bۺpq E/ޝ_s'xYٸ_FNL:y7F.b#8! #wou,=$'r
+v)sCq;f Sےbܲ-"Hncf0$DBd\10$)yl=i϶th|3>KHё^5tGdpol'}dk Ĺ_ π
+8>J+pB8HGk\ wX8'5&J|}R
+WW556` uܺQ*UQRT,|ېu|G "q5$nShH[
+k#|]|ԅ~QON&S63y4t塘Gv\CZ=4d=J;8]M9?h̛ݑ4l;ї}؁)-b E֬+s 1GZo&sZ wy4&pgًg"O!aO"5r!6+I+|I8SAڜ{ޚܻ{1Tcg\UU[+9!WcVdӦ,ՐY CZ3I4
+w$y٦b/zDA$Vv R1"m
+7@ZhT@h͸
+Z۫6 Khga
+2bXx`$#:?M#U<IkITXк@w5Co CoQڵM[:OdЏ0?mIZW)AAzVmpapGЮhx z)P@o5Уi#ЗTB렾>yi)jj998ÚO .u}<P]TA4o;ȡr2Agq$ "Bhَۢd+9> Q%HDD73|P?)*'7Kp ǧ28&9ožӿ47%~5.~fz.fV~lϚݓŞ5>5Lv<#<a$AtQj -EǦ #M"[kx"f~ S)YP#x٢xbCؠ<
+?c 59I>1Sq< d-{Uҙ2"].eYӗ.;9m
+16Y
+]
+AD&8 GbPHx?68w{7
+`]/r:W |,[Ctcnpxo'Qإ=}88
+pp{O`)W/PgIȶ@9(!!Tg'ArT8zOB
+((ʢ"& "0r, F$I@ @`CqJk]gjvkjVxPSǷ~^uVXJM.!Xl=fX |{Taמ[1qrKJnȭq :Cimvj8rQېYY6IG8y(7}ჺ$d?)Xq7! 5I+4_fKF1i
+e!: >gX)LQX(zb&W svFw2b Ǟ
+{5aR/, `k#'4懚ңavv`j 
+ՍEg9zeEYUXVv]zF!!VU<Wl_6ݺǭX5Օe7v**Tݏ(kJUmՃͪ1nhec0ԪfH1Q2ѥN{^+UE*Ic)ѮH eUB4ܣeKW//)f}&s^mRՔgC㢅2?-^tuh>@8T7r3~^d’Z⢼D0/ED#O(}cwU 7<JOǼq//'Z'1,L~MU `߀܇3ʈ}v.:IO:Nt3;` [DGL۷ѐ䁣M4o&r
+| ￞=Ih=_.H] ]I9&KY`M\M4iM8%n:&XUsAݕ&?A~1B ۝ Ca$L3aAO`6a=e >댊O$!*!܏\`o=`<x33ǺWLw2j !#,T AŅ*D BŰ&$Ald!@5la5Uts;=W1Nh盙 3ߏɇ%IOSݧޓ܎9\}#vjU~weQ6,ۭ6,tI{r*tʝK4ZNMARsR<f@)ן!}?䵋 j~.u*ڦ!\1ו?Gu9+akNҠE܀REsG^o,}uȒCCYvm W)#ݸgJ bՇ[>}Ͼ(.=9
+zi h ZK8Re
+B].lR|.r e֖KXW#XӇ`9سI9
+  Z7ҫGWl9k/ ;]Q喘Fa,s?lkS׫0Lb6tvG=E!Osx#dOP7KY!GALxcE8)1~Bdy,?<|Opo'ruE~پ:m\JPUwN8C=D`
+`;C@|nrД$IΡ+Әw_%%zEi=}9ktp 9űNoO_p |Tɧ=ɞmFVs #Y9ש^'2|& z &}׻ \\6C=~]ન3.0C݃# ܇ `9} 1g6"ׂOq;}8N@@؅\q09K\\?ْ_ qކ3^%fm`VbšBb/sB_<Bޜcߔ#+$B,QRJ\]d<m9o[:șiΟWL4*kRUhQ|\?pڡu7 _R  ÍU}VP˵!ϸYQ$xd+i(SU9#%9 yQ{\$謹\Q{UQ!W^-*h^UQWW]sTv] ]mgZeiҮѫҞY}=}5M[M5 pJ~qx8Ư6AyfwTDYċwGdƽ MæOXE<Z _Q8CP,s݌13=s2k$) ڴ=wz3&;; J.J J?&yR%,5%&/E(2Oq1be>!/_K!3d ~Hr|&BxgE_y&GͱѳLi7jv6`҆~ǚDZ !`E"a%vu#8(t4뻽Y "Mxn}ܹ=vu-fdU6^cg/7~J'4oSs(Y[36JveEک[E TRK$7QbN \@+hh wr0* J􆵁1DZ!h2~X+
+Cَ {2I$%!VZ`oߜ:8!;cqb?ކyրׯ;13n dXgL>*>
+O`RW?fxъ<4)FkjE=}q` ccZgz\&}6#=H.Tp^R:m׾[Ǿmx$T3Cc DjiYno(7hUhHZeo~w:8ߛ|FTLenziu-23kYT~i.󨦮<h0cQ܇VA- ;@Qv$l!.eTPZeȾ$!B7AˠX:q3#O#{6]2 O^_]vۺ:/`(!.Jȩ{[!2'FL\;@,[n_?KR '#ǎf"#Shɠ28 #"edו_deKUZ)>曾weJE2]؟䨘9ʸҨΒ:K=IĿ7D\JG|`(O) >UN̝XNLQFM {e,lyխĨm/r?2?1Ǔ"Vr&E6ql_
+ѿ|Az~pK7apک%ۥq蝝}@ׄ'cێvk@|D 9D wV _#|sQw~T}:pa!~]tPt0|wk('w#}v^oVCCD އ )P쇷bpO⻅*[ Э=k28ط̤{1=QB%. %.%s
+ݧu\'u'}ne%ܶN(is<3(Nͦ?fqe;?XlA"]A6P}:z5q  |2M%xنZp ԃ0zۥ>RA TG@WSW
+CYy{mNfm;rai:|{ 8 3z-@=+}aG{Kob|~amO?8] ~~)+OyO/gܫ-L_Zl:'+:v[T<)R4#V4+i.<=&i_iVO6_Q|
+Yʲy>nE 3ޏwtn;igvIwJWKHO?BGL }k#Zօ1+:28JUM i*m=7 n:|Y2y r2Ey7pŖ;a(w>eQM7i6sÖV'9/hp>\#0BW=
+V2!O7oȻnbGR{M-n-S$Xf 2X\#`1@
+W;v&8m
+ |P.DEoXHAZ@>K,Z=I31hs!6+xNALe_ Y%Ixz8 ݠƾPb/$h2?Gh>f
+,Ëe'c4HD@6OO: mϘu.N'*gw>6|*az] e<bL^w -"BOܰ_Tx5v[% JEI{^m`ݠ-^'FxffK^Nm^>, pǽJWdXkpقL0^҇( # 3!JJ wokit[|u <؁
+ 3#kAWZdJxoMз35=ZF;KFKa? 52πP6D!F),DŽ ( ULFy8 m,Haqo} by;"^J: 15=xY~'2P|D؆ ";qjA"tkwXc X \dyZ_Xe ᧘~}2*rK |T~*#f=iJٿbN$c@b޾Nz҇ CWH5:Y炇 𽴟#_S@ԽF 4 |.!2 X!CE}t f g5f50+r*uw 7-x?4S,(8; ~_\'Y4[K r^O?o} ~ܿ4pjw5+}r7냞ۆ;F>m\ ={Y z)Mx%NMiLyѸ'RŇgOFv)&뉸<gd͞Ӆ*IqUWjq%uDx+ju^1JfB<xvM?DS3G=
+}z
+A{3 @Brɮ<[K`j\WDk0rHX6 ֊^7(FĪKdhrMR|SMo^6?\۵n@{D)M.čInqĥ=FC6 z F"s_m/-Ϡ{8`Lfj}J̈́:E //n4AFI,.=E2QZӾS=;ƥ쒝;쪀~4hZ2:bq*A4]'NT-
+~qcfHRS?2H]vcd=w/6B/\-1Y|!@da h"K0A FT en`ܘ/FZ@οg_ d)Ke{*zHzbIߚAccHCf$w1~r .\A.ׯP D W~_`WB0̅ǕQ8VVp{0"
+Eq7cLbft޵ܙ%@όST)ww }'38 = n<nIjpGk4א+&UO@RW#IK2jJ$ ,Tk;$,a]$(SP6,I $BbPlqk;s{sܗܛww?ĖsEIq wv?CQ2}
+gq K%
+zb|Wp}MX3o|2
+~Dۼ"f^w1zhQrPĊvЪV_ȧ!cHicU筂G|jx
+K-5ekү }QqO f_
+?YEhz$0Ìgz:9wkg,JFDpԖ(N 3βhY&q1#(t`[!:}dt&BW=ۀa
+3 "t4Q#CD@(0Q#(В!*Vvu' wd,
+kww8vA5= ~
+m6~Kcoep6AZkȱ 3<nTXg}"w)mvC O+oq`/w_Р_7|&
+iZP)qd$p\Er
+]NNcD ID>%#QY[3uO-}gV}lݤ"p͐r 02W kˆ~F5>wi5-Un r4e^.cIײE!V"9?b_;n$hJY2'(͡Haom<6;=5#Z#9`*Ll.
+ƻA<'2qTL$gOuΞ%\ CKxy8x4}S8]Ù&G*ʊ
+FKޔM(oy*>z;_Te:f gpQ&دƭ;w׌TM"y<U
+66UUiFm ˛ndNhSqDع/Ϲ kƛ
+< WVᏕl +o5KS /dO$?BTvŽHl/ {slvubrF?%57:g 5|ն:xK6':0'Rq|́Dy㥸kYOV /tsHY;#,{|*N|q?=rmYNϞ8M  }7s7r'3]AULdW 6٣ī4^sދN-e||mtmd 5ƔqjM:oNPK|1=TF^($*R'\II`S
+U
+$@41!1-݉/`o BX@(c~9F)3y
+2DIn'"xA^;_&:A](Ǽ&׃hM[pV9"~uً^ 1`n 鉓f1JGvAAZ7MXqۋ|ɩPO`H>Gs k<?tqrWҿhB|ׄmFp#(:z5  E_5uAAsT%׸7|"|ླ
+xtSk%rNX}ȾȪv&}  9,ꌬ%`#q 29׭ ȅ~=z~CV
+@6إlHA\q`Wm5􍡷`#WJ(`& 0.kOrL Lo0/d}Y<1|$zA[#5>5\P;QF1
+aD
+Sv31#[D
+k agpM9
+iCE`nF`s:<T9e`/ø\Q؛Kq 1q[~lз
+DQ
+#[ͥuƶt:T:3gΌ}0彗/15-! 2<L*Ol%z@at2D\<H0cDH~J(9$)>ArH*c`oұd+`CѠ8t?K[4PCy4 $ڻT=.0HyQsoiEs-/R#DG[ An|n#[ "-F^5%W^5$s|g[~i" iY'^Њgo|4L2<NZwccIXrܧ#}T/ڷ'<v[1HUvrk0δ#خ@멉C~zQ9c Xa l' p !hBG<@N6-K$ScAVٺ11std,#syrXu=;2E:6v?t BFDY_YIy#βʉܶ;+˯:KTI +E{m?#  ZbrѦs
+x#j kEcnn[w|k?l P'e/-r͕`BDz=/Z;@3s~m! }8f#?@Ȳ (vERA{༊x1oNG)x~&r֖3װTs
+d>Ri6UmZG/ n Wfojog.0jnjSh[gw50w=P_YT_149~SlT ]FW/u+ol+n87+Wg+~,U ٧
+jvVڥ)s>c֥ ^W߬iS>kܯj<0\;}fncհbZňRS^P^la`X!j=xWSMKe՗dž:\3teW]U_*57ݳZŌ|wqDKS%hŪ3،7;dP3kʙg̜hڊfl4;Rx=RzN&ijQ oCe d/<νLt>*vg:#϶p5%]OsJkšQ(~z}wl[ 7-߱+l՟!^ceD¬=e }#D?dB2&7~xXר/
+
+]A+ N$V@EnuamuSwVɳ7a޼G}>? >]y6|?6'6UYKa5 v5E+.lq{Ƅ9A(pŧ9jBb R5xA>5hxEN؄v+$d?8kQ ucÜ?0m4y`37jViۄq; :1zqVv뵻ꨞd}f#F|ˀn[#FA\m!!7z@7߉ ]0j90d8u_͇_5
+ж4ʶ DԄv- .oy1̈ٱkQ{؃r "X|%j CP9Ru603g45w]WK ]aC3Yt5 wQ$__<h6 =+n2W# 8<
+"Qg<pc ]IO[[3FYJw',4?:DEΜuꖈôB|;@u6TY:L[1Zkݝ4\696{f
+w~O_xqcy=l:ޮRUOt0oW7ҮRw*iP kd1_+,UI+Uˮ *}GOQ%d_pa\%zn$W2m:(m*(\Mڝ<s
+QEuJ\*k(UJ{kK5S2L(*UV#8w]q/ח4N ˊJ^]rq?RuLzE+P\+/T 1E3P9&rgo&J6cg:cṾT)VQLkwCp&6JŵȰaj8mǞxϝ,`MT=ES/jμ,+1xr.ϫe17^F9/uM"mu}u {ڻuNn~6}e1՚aA~K]A'xO["-zbag
+|XxVt
+3Ӭd@jeT.ĎgD@Ե, + Zrd6DZ 8R(]a8trP3߰O_WdY(2"_
+/[t1vyCdy]_8J_
+eF6c)PsGCۋ~?Tg|.8aȮ F0,b>BOT'@Rs^S@xHG aeN#,LAIoT#k ]TL$怌D: ^ފ9fSo`ti+t
+wf2 $hp&hG+C8 T·P4.-fRU:}ô?p/dZ'l?~ȶ|R.^k
+endstream endobj 21 0 obj <</Length 57897/Filter[/FlateDecode]>>stream
+HDUiTSI%!!HXQ#ȀA"DD(,mc&`Dv۴킶AG3ίLiw=W֭zU. :ٲU2/YM*ٟLL͕-B3CYգ/
+3FD/NJ뇢::` (
+ nHb i$ҟ8F0Lc
+]4{ 5B IHy3j#•
+yHE.z3C 0#2#=T߭!xav~R;t®Q@< )zF5XR3!H'ؐr3d 1 kDi6b@MCB25b kDz%<i KC^,,||d&kmHΘ\);N !jTɃQjRKQ}#H0h Gh9 @8A
+;tyw2{yUYOl>Z0M)|ib7}0'#ѿ"vF|P؅}̰THЅfC>1M^1D@zVe ټ buK?C-3ȦM!7D$׷<"$ 6ޏTxzgE y.(85Pp<?l8 8U
+;aw7<
+ex`*<=z0LR`8XD'|.W
+ `[H*kR(BEl! $$@YDevϨ:q3Ձs}}1ȅmf1ȁѣ>j@ޟ )XiP dz(҆5bg/*YR Ψ9Dje"dnH˪9F[:[AГ}j]cSMY!8mȶ9A lKHh@6ǽYC?xhV\@lYCs9Ü>]_ǝݫ>KxV6F&2a [;g{$ڛ QxMf^!U4nMz
+ZThMfX-T q6Ra+B!ʇ]],>|a惟 z1$W}:$f߰2Av%܋clMIlXܮ= ;c)oۻnyׅ̹-`ֹz,ԊPzz;Y; .ljz ׬R:o 
+nm XOv[e" }v6?N<]QG.9}v0 tw}p ŧb,oŃCGlq1J 9FSZ֧Rỵ:W]dHmV2xYw_~oH~(-Nlwz*†s-*4~_e7owɕqTY?a#ܲ%W!~%FIfo$B,=)Q)Rwymh`m4Fy35âWj̦,.(d81Ωbe\gV 3 «;2Y;dGFԥ"/{|mG(\6!Ds!!RgĞFH=B㘏H8k0{ _c9I3E+1
+'ܖl?FAco!(yon̯" neG땄K"ė`Pob~.bMtU577l0a>~wĻA n?íXmHbuD"6:-1z^=ki 8:2qv; i <'>FܦHǨgPkN^Q_VLJ8z#YH_J;9NVy3;ļ uy8$wWQqewhoNWz9!6/{%&Hd{Iҷ;7(בԘ|GscԌ)fFSsS#)!.j&uX>Ca;PD
+ΦZҨ&%O/%)濸Ď}7qȓ5UŽsbVb""m:O?#Iʜ/GGÁmy?6m:5kMe]6_`}*/ud#ڣC/޼zxh] ,
+}Gjg x&;sY=w\bVt{
+oQ_5<VhmocήEƮ_ۏJuEڮ–NbscC%MΜv# ފmZs[&[؈v I1ZON'Z3fWUn>G }+Y6[ݤ*;˹[ɻsxtuG[׵ϟ̽wX /$^WMK>UNq*']3&zdb7*2,5r:oi̽#1?;u 1zN%~
+&3f|W;Iɬke(i)&p:NCNH2nvH0Je`2F9&[ZZYXFp8g|O-yc3*}/̕ޥ z̰xr;N_ëZ,lP)fU[{ >)L9s׸/\b,ePtE04!)@ B Zq]D"]E(( v=u=cwl#0/sl+aO ?Qk*ɜw䄙w6vr-csG̩m
+6 ًOYF'Eg[˜dd5`s
+#* !hn&u p5w|3q#rݠFn
+ZLaFP`m W+h~$;B0Fos o\|ޕ#2!N싃q{[-
+Fr?rG~? >s{w_/h[ٶ.jzi`_/6jaNCJ6)XүJةאO% t}-n`?ñ
+CMzطr6/Þ:]t&`n{$a^+8p}TWx\6Vt`Uԡ; 'tjp 'sֵ_ux`\}JߓcSG(1:KZWES짩0jV`z Ř8DzfTxa* 3"|L2"%٘%ON)>^~8aKC;/Kߘ~(9Cp^6GeU}ؙ>J"}Yk6=^п1IhCkU}*<;W%~
+5!~@>YM{lG$>v&= `0g.}Ñ峓z1TϗHq
+E#%W58+Lc(< }fQ6R"98OoH>AIPܓ%#%!|υ"՗NL&RRaZnLb*<]b1G1?ӑ<eD)H')F
+$H4FL7F: F"Y7o2Pw c+ QأLu~teC̈́:jLeV 5gĵ!$$:p'-x;8+N g5Hc
+ mn'y$cJMNʍg^w]5- ܂}mAQB)!YO%P6Og $"'wHp@›B)ȿ"("R"pei4%e;7A77x  k|<
+bMz9r j?!td* MWD#JTDP(}xS @s*Ե j#C[3ц0䘱0M A-9.d9(\{% tEK½{!Bqa Łj)8g Y
+&?#b~/?,ƾػ={7I)i܍}د5QGKW#Ok{;a_'xiv`H2`]
+_(m]~lMֹDs{b/fDY+, -6vtmCBrFPZͰ=U<Y
+bXdk rՃϻː8B3A!P3!|iA ݊|&Љ
+A3EP0VR
+FU(H#p~LI ]V cu#$SaIWOt@5uq&B-Lq Md BHX"KHIQ RkA %,"ұcSE֙i33
+Lgrwo^޻/~i浳佽(Z
+yu)t&c!/7?J3NX/ѺA߇Qr7X'`>T7{:Rw&BgO ")o}-v<Iܡ@
+w8Z;H4zCtLhե_F!1 P!NuE*I 9E
+@'ͱꌓh^4sR:#7)1ݒoJn+I*"V?f$j|>FS<ꘔ;m{[g럚hth$˧{?<^Ѽ|dwe֭TC'w\zGX34?"ΎX4-6dD5a)/mNx*P#Ѳ\X1XaoGqрⓒnʼnE{^QgW~Q[>uꌲ҆־\ŝm
+[ړNQ5TjwOp΄l_GUw{+<'n1VSb'-gGJm59у)#&[)AlbϤO*n_\2[Aԧ|KylJќ 9ҙ=zAtɜ`Ib ;$~ X!:D7?O5 |,'{w(Nrͧ$ +Ip{+ɜ)nG"9m;˛$'BHz! 8?b{
+RZbe:~El\a?#!'x6#Dֶ&w*t7pp&#E Hkm5.'s(7н>Us)F#-9LH Bp#DCk2i}Z)2ݶ#*d?> ^YmOi9,02En d\D G0Y,pa>9+ju:]$x<n@0ָsg^\\?f30vp8Ϯ|j[e
+ױZzHkOf#?:~с=턽42nzu"s68\)>sI(&O:j.gh <hG <Z!2AlEK^o ^ձ k!W8k~1~fPztOޥ0wMsfMSs\gu1h8ܣ?9<"RZR
+m(C_-Y/MZ *a>E{=0j"Mqt0'M
+ӜܑXѫ΍e7VWB^o yUi}06o`
+%nٳYڵ>zɱ6vW"_ rh ^b60޸7Ie5IjJxӒjwS/>x^-0ωmO*N[NZIn+ X:Է*˩"::YYۭS>Hk_<+㿗UeXEj *  H!, B$,lU@PAFU@]hj[iԞN/=޹w|K?N<^ZV]>;Y~AQʫ37yse<Y]Q;O܍884Tg<OP#4FhB,?ۨ+AC[mAZ
+Є܏sALbZhtjye
+ryF=٬M
+gg"e:C ||,?_F|
+dTb42qbGʓӱio-Tܿ|~}ہV͑^](nu>~1þOzF@Ʉ[cRgfv&j^6;}㧧i1g.F#Ai= y] 젪9^@}wVTKAy.ll+(oPlנ)eZ{ؑk+Ft{;n9ɺTh/NU'O=ꮗ9Q[{5/Fسǖ_dw3CL{ݾOɔ㪢܉SEcCk+F/T ׵yX1]S0Qpzp=m>!z`=!Z8@Ј##BgW[(as[i7[F"C 3fg9 3+?ƧNR8sG/ f$wo؀ $9$1(n-xl=_/H E#sj b:kKpL
+yr>Y ,
+X.qL"̥ȥp+ >vY 3p9xhID s^-〤6k9ÄX O v횢lB_(E`n֥r}\ {l#e `_
+{̿;afp =ó`놽3OPYc8?~
+e)`>tq-OXgJؽ1rr xxRW
+)LO<7;Eo5[T|&֕T_YV,ϙ1.Ơ.CN
+=aM
+\ESr?esu[>Fg=^Tn3ycRyk<00kP Y*&5wҮK_NmckI\9];$wiwnwэk[I:6iBix6\wM@E%dЍD;$'#k)j)N& dוdʍLX_2 %H vHI?u< wI$Yد SLHA ЅQRm;VG6wQ42R<_@OgA\op|P|6p|A3Lmw[{o}ڣmLRa?i7a]*[F -?| ]Ir~6ܦuqi.,߼$lYTpAP6Y2(H[@*Ȣ,NnTQd }1E, v*"mL;33}s_O=_^w_r߯SۢUȹ$)5)>:OGz-=ȲRԙJ%xR0@Eޗ
+CMRMYAr͂M0&Z65;bDk)0䱼4n%~*&S<`Z: 26n%_V`xp7)g7ͮv3;cpHAͤKlRؒܧŏ:'g[N4nh/̙뺤*^O=<M2ѾѾS~fZ[j]1KV@^=+ ~D C-EmE:
+KUmme͚Ҷd[S15W^*z􋆾ҊzMɉۚcG5vpz[0_>Q0S5*MJL9@9\/9I6tZ)7o5W:pr屙Kj<5S1uA[SBKC,ɤXo=L!w@<7
+Շ#ZK_ѯoxt]΃^rl@:a  oDcH2 g8@<r jM1@fOsG =3dPWdIdz
+#0]y5oûo}"fqXSkX^֦2E9oJWy(}OǼw;5KJzu ۊ) OL:T؄qSaυM]
+{nq%j,lLȜqiԦЧFƅ1ESwG 䔎+C}D2*B2ώ󎜜wqﴼ' c52%YiM7(e-i{z,Xd {&g '_D
+NTIzHEɏ5P}LPC&OEj(6Q?Pmu2Xz(x~
+XX6"V2kԋyCe*R޽}e~ݿ<87"WzL1ѐ_:7 TLA2
+!
+92H i
+Yrq1Y}zLz8M~,Er8Qy$GޖC˗ɏ涵5e4*:Zו[WwZVw􍮞Ap=[֬fQʸ`HOjNJ$'~{%@E6['݅w=ozXգDQxIN$g\"ΘJMti$!/kȵ(MS)@vMm_v{Od N,Xy 6kՑ&H'yLݣf1z!x- ޿"PECC'eԕ/PAY}W;Y !$E-*jکZqC ua_:XEQĺu7igZ)p,䜛9K1e-g⾦dda)G$"r4
+b`5
+[(N/awظ"YE}w+wʹy`=jSC+~5WEN[#PG::VYlO}uu5Pg}&Q:kuô_2u3Sz58N*7CuFMkw=6?FGBkgLT+<Fq<yF4I,i64jVa6bل/MNb2$RIp1 $_"ɃY$Sn_@DDr1/bo%t+Il'r\G m$atK{{I9S o PKq\)TĴ*+NgDΞjBNBw<c`5,&U#qrN:&~w7ZrPث%[W' R2tB>|i%IhF^m."""s%P\C(Ŧ lD:%]~pQqf"
+4E9
+jS|l0sMPqD[yciωao^W
+{byBW[Y
+2<Yg_]*/AgV?y˺y%Q?s
+NŎ`#y_ڱ=Kَo<tYVb𬦡hE^JdU>4kt33VChCNO⻚m75WOtQ׺ud[-u9k%CkbGCz~3<k g/" K@@K(RD}V
+((ZEYEL@E}VjPϯS+pߙ3Νs=_鎪lٕ4A%/JaVh1̍
+
+yFܩ/ q̅JG^8@FP1O!3]p賳!-τKyү@d>2jD><F
+7s.[?7] X8VfdpFezii C08>q,Iȑs@W f|AӼ|ҏ&``l+v=1*VT|ۻ<<3|4LAqд샫ijB`ÿ WHGX
+a1 EٵGBh?ޗFBӃ-"i؆uȯ*,1hWJdl}{Tp3]8'OLyLhNz&| E@H<CDCt( eTKp ˺$L!nM|5!zĺ*Yyh`v]JQ}͗u +˻sH\wѥ _N4+4fu?FULK;IdYy2,=8]8?$fj什i 7Ѯ
++F Y=SÝ0m%w $>RXg(Bt>H&K$P%&JJH2+HL{6=IšdiH&n <P#v Ğ$K%{zB+zDO& ;!>!X D@pʳ)ijUƟZ$Xp$-V+zF`aM?92 x&dE>GEx|'uI~6*Ga7ɣN_'n_0f[j{3w޶bU`V͞Wsӟ/yQW~E_l~XҝZQf×Ed6G9o苵U75-Yq
+s D܇u͘fJ# hKO
+Y  EsG1Ձg: zi1+V Cf>CچJDV ymL dԁ%+ 8̄D}|`-PaB61P!1~2Fg-=7K'*Rcy/V&M&S0=e<Z/e̋n |d( O zWj"Xdi'PPj ^.V.M_wRx.R=8o. 6C/.(
+C088v< 37!7iWf d`
+p
+ɟ Yá&ڭvRC\"l<$opmY%U6x)eldDSFu$7?֪ӞN{ػGx87yW̛#ޕM_?NruA|FÐPpbqS):<9r s).Ea)2T?ediw-wow9]\F  9[UжPhZruөUh[9nSm<rYEcꃥJu)u˱SʣOWi)t)5E]7TGzoin^ɿݘ;Y][3֩T )/|;-^GAphF/(vicּ{-:MfɫH]_ 
+nA7;l#&Hv*JCE(&!T:$_~*kr{aCjb&qkGaQ=
+{`рS ̙@ Qm}AB pd2O~Ё_iE$k:"[{9=L aJ8HEJdǠMaRF'C*-H Q#ll%3_+o@$6gic ǩOx¹6vuܻ]H>@pL҃q?]] [MW|w3:C܀7t~߷
+I
+αñhg3=xa}f .
+ ߹5qtk*oafb*>vaNT&ݵ<o ^ث>6i86U%ow,_.xHkDn  ׊.?UI^!GlbSZKjd m(>SM|ZڽR<zVgHL۞H;aW0wβ5M/2/dr2=ZU;eu?Yh־P|mASCɓd򓦜?9NJ
+Q_t) (!w<N9M3dRQk}%<AdH_ϡs)΄"?Zp>.}X̍_1UџmyZ|FTh >p& ̡0bB@l ^A|
+jP ۢ
+kRIPmv?QÌ.7;x3Sh}K:a4| m1`ȯ? wpCYkJWat/եBne
+B*tc"Ha?:nK6I`"I<
+= 1EVmnD Owz{|= jKI<@E<f oNZ)^7|6Y}jg×C^^v <x򊐱*WROpy" tFhȫ)+O ޕ%&I8B44|WU$rt_p?D20NT.dS]"KAZ-|Ϸme5~=sq qha 6:KVΉ^_ܕ߸E#HK'q(3fZګ{^*oi=[rF{@^:pX}&I&z4rԾV~ygQjdI ydVBdx
+:mRC{6+fnkq{1s黬FYdldY빹׎U͕V]>_z%z񹺋O^(lVP(vt⦊2N7V_-/ˑןή9Y|<O*Rp#[8Q'-'U+}Voف}w/Jvo_Uɑ꺜
+iӚC-[kk{[a.ir 1a2ȳO(E?ь4؝Vok Ө# YӪsȞ<k|:_Y5$&h֔ ȿCw;5(Gim%w)|š^dwZ2@ ي LTGU~
+%';8\z$W@F)Ȗ o[
+SwcعIALAdHD,BD;c"pQB?"'U ^>{~rGmC?skZ#ur&,(kd'?)綨Ȯ\AxW #܍3>VX+WAsB~ӭxq7/:F ҩ[!<PN7 x8Q9@#Mv
+GyQ |Sϔ߂oNj˞.sfTq^rNNv:S)vaϖ8g+]9 ^{c}@35gϼ͌ĎDƟ y=oEHEělO7pg˼yc9.[/oװ* (geأ dQ}BӛAȲ9C\F"3p+^·b% H`0ѷ*VȌ_<uj|CӥnG; GO̼y?.j3;u)xoh|X霏zyw} g{[&hkm?yDBcIlJCeBbCUBbcMrZmkkKR(ϫ\ȫ/mfgJoe\W}+B Tږ#+ߗ-)S]TQ_]Pq'Z"m&qf᪤ӝ7CR4etmjwiUF_IŹ' '.Ve}L[;h)БS d`B@k+2n֌~>1-Dn%.?v3ð>]x_6ztSpYCf}X#CFӏu] MFl^:
+*}Q [irn TCn
+BXsZj4 */hZ?28>e:
+sCH׀z>pO]I`&n ӣ
+ ˷aOE0\ ̏I&A&tpآY"= p}L;GA1B5:}@ךNDtp
+@r
+CyG0l{+[ Yk
+#J!O-9Q}4{el}#?f[epgr%9ytyIJ޶PoU5 $oǏY۟ersr{3>3_fy}?
+xsa,֮Y3K>é8M> 9;ޗe=x+8x+=[0 j>owb9{Ձ+حp?[
+vG]K";"o)q'OTtaKr+*?}4I?3@c`_wދOMɼU9esw"k~y͗-υL+llYqܰqkSkGO_Zw!fz텨5s6gg,C̎1N,1euF8+ l.Yq O_<?μ<|60?y]
+ "MӀ]H2ן.THh;S5r qR]D(Hb>M.-z$q85aQ9֒1V-{>S-1Cil?o5 yrʈGңŬ#rUJ535'[*o|UYYYU~atV/n-S>W)w(Qm@qwSN[-KUWhk uU<yپI?}䗋g'4ur׺巺;v.;<S$ ;VFVލ1 
+ E>uA!Ǥ52cꐵ-.As&!EC7.'vCjwل о(|UܳA_'D:!ZbTHv@GHRx_ֽ~j%Xs 1/6"@B&x_j :=
+ܾ DkIs3E<_ I!!
+Bdd7K|-\w VE``# >
+&
+ј~,sHOد,xZp
+<&_{1*p7L)J[\#*0?u|ll/ - ۶o K;w)N ѓc&nN[0n92#{)7c~xel*1%\
+BM-p ѿ
+>pX`6~M n
+o;|>#?y9{-ˌףe4ﶎh'uv*i`pp
+e";%:?">bQBqmM00l I`p"TsprqK'pF m8MeKR'~•
+~JQD(U}-[9Z
+}I.ԴzUFVCM]>sIUmi}eYjQ6YqYkͲ
+MYYts Jۋ[JohJ;*[=Սw.wUݩT!+U }G>|0;O Lco n8\s#OjV1ۦj
+%tV!a2L~s8BXw
+o;PL
+&mrEyq|]91rn{`awq+1TQE9U0Q)^hmR5m^3<'^/cykQbWqɑ,"qNp=', φ{Ȋ>3w݄$ܱn QvE)IjD}D\\uC2{^YW}~rev!E`тܮCn&J/NBM8g`TsJ1o kPf 
+A%~%_Bj"kc-ݟ4Q9cx.n`̶Dx1ڝֽkF6U}Gli{7XKe3J
+8jKQԪO-CFHjRy9OEp?|70bh_ӘktEjw {kj_9ҡ
+j"Q5t~净 )M f{֕v Ni\C vYT|6]EC/˪l_aCT7/ͫʍ =wg>7zКM%m94m=vdDZuAEthԚ>'ӦG3 EϘ1 KS[E#xFgQaEs4hpz6%3fWs+ 6cd6QLab,%.(qYۄa!%޲wz=f,?<r[Cwp?I̚ϜU [C#DD{6Ӎ=tխtKɝ^&e$u)xҙľ<=a^ß0csVj#2˰l\uKԫZ>qR9Y<|<zvX7})cUBZLON~%t|ʫN1hn'R>Uε\|~cQbڧ1mʟڕ|u\ƽR׊ұOGKEj<2>S2xC V^^vAx/w[tn1@O]a <0Wq]8NޟDC-ΖڻcR~?WieGBv
+| Rpw:@ `{\K#$}Kdh#L,-':"Χ9DҚD}xGྏl mZ` +sł.Bx3p1Y^ӞDF+$wy$_%6Cj^$v.^8ԃu~ͽfPwm–7gJoْX0x#\C|}ڳIwp Z#{V ɽA>[6NyÑ^j`,0~<8q"qxEV8Nt~hH]"|zK8X%=>+Y&: WE}~xT<~_&yS?R:NOV<x>""i_4ڲ<y2@nVnj¥iώƦ\|Vx.Q;H3t,blC|<[\QQ{lD`yt,XVtX.55bTD4jҤ]&,ecɱ>N|<:{!읝;3wZHo䚑UUAL@z{CGeJ)kؑ*\S }!){g{÷Ru7۝7"(K۳7c"%>9펦u{W$E?
+9 >iT3(5u~ʓ
+KTԜi\[[i*Ֆh[k-Ҟn)R6P^WS9?X0pZSsRs^SwA[tfS{ΆѶsXPl6Vk?J1ǏoϾڎeK5L_nŗ#pTnL0e=ո˫9]$~DgA̹ g=s?7V磚}gI*1Y{ɔu"ޚyijn2]3lG(7k|X7a["Xy1}gvQtHJC_wSدHcÐ)^Cq({1Xp{&gf4y%o/bԱHvMAHx
+Ǫ>6=QcyQn=7^L+\Њ -.8a
+$/\`}BߦVOƄ%E'=>|V3dқUiFnzʷK$ԪWKQ~ۊ6.Q0:"2jLY4n8&j3i6(\ITMqԧ?wQۮԲÏZ{QRjZMM*kjR@ttv=x).hzu4uRP n_"]sЙD})b
+?yRW7+֭{!㕯Jƿ5/mk.2> '9ySU*XdQie]kJ͹jN.~w0ǣ٧vA?*ˢAKٰʚ_zF*Q'Z[c'WpSC0~t
+9\wlON|梨c6''N},C^ѳsNܵeLӳ&l_пi&6D@]nW
+l[ΪY׸ ĸaׄaG
+;:]хXNQtZ>
+"6Dr)kGJ1O/Ŀ]ʺ$ujt'W'XY~yi[S Yx4÷?Y{<sO}Ý޷oZ:\YI[¤6fCyfpp}W;~;ZϫmynW(zt'„G2^,)]w,nfCx8 cpYfVNeR1pP5!d`EˣC,<- ȮGx$b,z#m7;79IoBԇ
+nJ 2V ''NX&
+nLlO~ƿW66%p) *v oHx3Q9?bTDdOwoʼnfo&' v'2#1*g+a&Z1E쌙k.M U` 9HuV`
+.ec.l+Bb ;vp- 7kxg2!#VztK5؛uiI܃wڏܒdM THRc㩒Ϧ'%G N,ʘ*N/NI)j{UUƪUM5MʆKMU#WuRѨ(-ozFU}^U;P3RۤRpFeR1J9CHH Ahxz`ۍNe>u֛W+Z'NFEoV Y=:VK{;*a6F&=(83fY*XҌ 1diqQ3y
+ ë4+ I~ʌU2|vulFJ9 }WMk-w+Zd}q,-cd _)X`.2+f,b !bBj}9|7BS!CVkO܈:8ۖ"#G`^ o=swApk&̩Q0 qj,bsZ)w7; 4GOՠ!:#ZRg; n<y:=K :-֙ kk`s_Z۶ Wh kMV{N z>6GՅ@Rx?\eÆ {`]n8Qmds<;z9r9؞uВX"s8
+=6m)70O^qXXc50a}J Yƹ<ls@wrĽڊn|DVlE7_x~3-pknu__TPµgQmh:87FTM:4,1k6Mh˱m $J3M+=gR d#n?<6]vۯ:n>>D'ocƩEgzn/t grg?Ң\z/
+97`VV9_bTfVp K\^~c| Oux>/y7#qsM;#1lȆ0=bJ?X!&a)&б{4Ƒ@U C¡_%`
+ t$B-H_1 hzQqVYYV53Ai9͏i۟jDo u1jvT%d}2H&\e
+ ɥ =IUIlu*ޑO?F3'зV5~oM#+,藺-sWl "r|z)z/d/j)gh^]α$]uYKw*B0}ˢ߱pt'-ѣE\&PMYIM# *EdQA a@AbQAکu1"AŽa **U\:U;mSg7%-{U|rV~p.ӕYko$+\+<o$yHM/E{UGag$9Džml̬5]4MSq%U@S=-}6nN!/63gqXaGh o6h?1>%Y|V|Yq[ûF=ӯ7yMk 7
+|3rr2y2y8u=m&C :H۱v3 Q
+OGOb.aTOtF-{֓$y0/zy'It0Uft'+x&.Irdۭ"VXC-[0u<ۛ}DVyA9ϳ<%YՅ3< yH
+1w{`w̯2ΣEL}A6c]wrU4pµ{a,<Ow<`veUvϞ'xt` 3 3t}:C{`zxop9vROY*ŸY ͼ3F׿d0<iWgֿ1R1*\?k\Fg}1TxE WLJ?8iYfA-P*&">a
+*e+4;K|s7N?6 xjxɉf/D(s(i!:5!ׇۺpbW Z.ة} wm!=⪥W-!b>!qP%=bC\;6>Y#Vͨ \2XGeU!"7&YOkeĽYDV<r§ԑB[SH`]
+R\J%A $%Dwd~w/;}Vwoȡѿ{v'{LJĮOV|>kğ2ٜۥUp)Jr% (g\n]rczү!Vc; ^/&cu%zI}*l)^mC8סR!WG(A_V)?eԕ_vB .#"F 쫬I ,b$-.FUU@
+
+@*HD`@mю=:ڒ73]r%IV%63 I{&,%IҚFXK’Uy3nϨLS&);0HA3Y9 '%F#*uSivcs~:qyqGf4^q } 3Bvyegtm(ޗ{rWz
+T~ >_\#^$ۡ8a_ "
+N
+Ķ$=
+Qo#_y9r-jƚ[ȖȦȄvPп2e m
+ s#z
+9Lqm09ӿxֹ:8bywSh-dXGf7hbEzsp~WptA7X;G f:_0]8~zR
+tx(.*N֒CU_Q~zs?T`T,jѦXO {5`2>#|ے.6MiK޳¥y;ך%؅d]o!9%OXqoL//ƽwuqeS}²Lгѐ#bT^ӻR߮ep8y`uu˼8xL?ON"
+_WB-*Q9Yw 2ҁ**4$gDL7pIi-'+R{^H EY]Ϸ=x+M_P xZd*j|3
+[8? (лXނ;&uQ *
+U!פA`Qqޔ0D u!)\+g =Pc%ou[=Nrd>V4=2>]G wQܨѠ?Ӑ@IUf=?|!WmW!{:G!4vЧC+0ju@8>8
+ 2
+ TMqx~$I
+ %a1*! **-ڀ=9:zT%UUݜ-Ct!$9%i[M%Xׂ+]~NzgDó29INFG\hC
+B#ǣdHjh3\Ӑ@2m
+"2@;bz&tpIIIynhy4Ny=[V۲-K}W~nטvۄi)z : $3%.fp1B+{9FO3DnGMw)~lq~hp?p?~as̤i `Fvl^l&l̨b-̭T;5`mx 66`aN.
+su5;{pl[6*,d)}G?+߉ [2pxc¶I3%Yպ#?ZymÚQea_*¨5iXèq;è fUؼMГmq1@e,bjU^}@lq%[<`Z`.s5)8 +)q@.ۘgC,:$Л_Qϼ~Y;-ц7 Sؾ
+l^kv圣zo^5H"?"#'|ʙsU} fMjj [ m/ef qu!vc$ P]O;[ɞdHp[X>H~rʽ9\0kZyi3o _>zuy)8 \C8@0{܀5tx}IwQ\ܻo>>ۉb+1 *G1xP *(zQ]
+-1Z<kQ2oYmֈUpyq삳r*;UsNd "4wH7٫媠ɈpY)BFňix~1u(~9usyH96B;=uN>tOrgQ~ゝ%Q)Oxr1w=K7_ `ӇX\C
+, 99E @(!>00|?TA#E (%mWh(BFE!mGx.ixqpO!{7|WO$w,9XG&)v/TZuO ӟI:
+PGmT /`}IohQCLp
+b>v?9ɂA7{D-9@W%N:
+yh?b}r9#67I<8vnysr3IvʔHTc1O<mT <1N\HK6HI4OJ:4?#k y%563XTv2iDˮ#ϺxTnj
+L mS_xC ;OyFP_G?
+}^k~>_ѰX]ukoߑ^Q֠%.Wz7j#=UW^VݫTTO
+ #Wjd܂vcOg88
+* XAD@@@DœswYcsKNO@i=bTD9wDˠAEbHjƴioX}fvxy睙~7^6QW)=HI$xِti,
+˪w *k2K+Z֤VF2nT3i\9ixc/MYKxP^t) 5Q
+ur QN 5j
+8HCOgc6l=Gx 9$el\<,x!,a_7aQO:
+u_ (OOB{9bz$=pI $ _$nh6+J''vx17~x)nYfOq&$?Xƨ{8 C9ʻhDyk' 'aĖ]ĉ}`Q޵±$lЄ $["]p}%ֿ:Q]xo}U
+ q7%]ݓ3|n_wm%[Uli>R}"ڲ[o{Rs"$O~sޣ༱]gÚ8|AHE2"nXB"IAPQlkn.Ȓ EvN[eyvFG֖
+9|97sν7oǓ]|oO8cMO'ads۾3s:p$7đ{"eEVO=g~dM1J~U:.h/d4LL4 &_ǙѪKUc#U*j2zevCxg0ߧb'TOt Tu(7?Uf_aZI-_1)sQl]bG٥]lEYE֔U`NYF$d6SfӬ;Z]ON(/+O(.-i'[jFD
+="5$k@xהx}>W6*&q1bDBre|/KpCrQI2rUe00XQ\MXp{a DԼOcяw|Eg_"[1/|AI|pBV":oð$r=q"!-%b00Lbal uU9yˑ#fA^=9u9KkҨv`o48Ngv5$5}WflH.ڐ0R1~-q-2qgbG[1d ]$s47=ǂxo޷ۤc-0=Q>,q
+Fy/U3LȤԶ*`֮ZƦ:h^}Mƺ)Lp
+2ra)
+e؟a`}(8?T!=pn*O$m6]ʨ?Uu3_wԣʸ];-k]қwuff f ]<|gΑ3I$b 5,)x(p^4Ms(x|M4H.4/.k]D(%@dIX u.efZ#fP]$(nDmϴVOgZUТC͝A}澛{o^Jk?}>r?qxt88.W8Xրv
+ķPѷ¿g)?*b/EϮc%wk+;* ^Cw߯8/)<<QwFCwYȽQޒsFs#jmۉ7[O|1zf=ũq?uko4/{6<8K9 SIIC2yTuqL[wS_}@0meWzdݥ}E]=ŝ==%Mʺ2YuN̡U/*i'\yBU>Xlƌ6*omuTTʕF+Fi7_vcϲ6<2sy:48-uz
+51,drd-$mA s\sf(gH}ID_85%5 ^(F<Dk[)'<v$SYF`
+dzw2``
+BІ@l#tG?K|Ο [H eI;IDqs
+! i$E:N^kIGv1YJwm_]EiSefXff8ܲġ9ۦGm^3k*[nY =}}gzwcfS̓3a.Y1/ r
+/G,-)Y)Oc$q5%v{/miԡ 4㸶-j;`f7EA@, b YԄqrb(F5NJ6_5AoʄoJ-_rدr*DEv:t*v؇қJwmD4E<ZɧH{Kzlì9Yir)Mf2iv-d<J!RMVEv)q#>ʭDL$
+IzT¿hS^a o<fTzQJtώh)@X^I\*KC b+`q<6€YEĦ Dm_F z"bWJ90C^)ۓA,}n0}\'!fTB(- ] "R1+j ɋ{|28vK+^}|YAeA] "?:}L/+Nl}#}唒ڹxsg R`,U ,gay# D/|h"Sߡ ?dϹdc!&fzlgQ: i* r](AtaXهЎGr)VW%n1Hk榅g9C
+L .^<pޯ}դV0ng7>~ ׸D4`oh10`fzkDۈ4ok {PfhS-5y/&UGX"Rˍ*>Qt`Ps`~()7fk09|Rݫ#tP@Ņ6-T[Kp?kC3).x@/Y=z`FtFvs`M&%A'A }L/kI`8s8糶d ^
+CyS]d5G>qy7>
+:}ǝpy
+endstream endobj 9 0 obj <</Length 13507>>stream
+%%BoundingBox: -66 121 676 670
+%%HiResBoundingBox: -66 121.7139 675.8633 670
+%AI7_Thumbnail: 128 96 8
+%%BeginData: 13361 Hex Bytes
+%0000330000660000990000CC0033000033330033660033990033CC0033FF
+%0066000066330066660066990066CC0066FF009900009933009966009999
+%0099CC0099FF00CC0000CC3300CC6600CC9900CCCC00CCFF00FF3300FF66
+%00FF9900FFCC3300003300333300663300993300CC3300FF333300333333
+%3333663333993333CC3333FF3366003366333366663366993366CC3366FF
+%3399003399333399663399993399CC3399FF33CC0033CC3333CC6633CC99
+%33CCCC33CCFF33FF0033FF3333FF6633FF9933FFCC33FFFF660000660033
+%6600666600996600CC6600FF6633006633336633666633996633CC6633FF
+%6666006666336666666666996666CC6666FF669900669933669966669999
+%6699CC6699FF66CC0066CC3366CC6666CC9966CCCC66CCFF66FF0066FF33
+%66FF6666FF9966FFCC66FFFF9900009900339900669900999900CC9900FF
+%9933009933339933669933999933CC9933FF996600996633996666996699
+%9966CC9966FF9999009999339999669999999999CC9999FF99CC0099CC33
+%99CC6699CC9999CCCC99CCFF99FF0099FF3399FF6699FF9999FFCC99FFFF
+%CC0000CC0033CC0066CC0099CC00CCCC00FFCC3300CC3333CC3366CC3399
+%CC33CCCC33FFCC6600CC6633CC6666CC6699CC66CCCC66FFCC9900CC9933
+%CC9966CC9999CC99CCCC99FFCCCC00CCCC33CCCC66CCCC99CCCCCCCCCCFF
+%CCFF00CCFF33CCFF66CCFF99CCFFCCCCFFFFFF0033FF0066FF0099FF00CC
+%FF3300FF3333FF3366FF3399FF33CCFF33FFFF6600FF6633FF6666FF6699
+%FF66CCFF66FFFF9900FF9933FF9966FF9999FF99CCFF99FFFFCC00FFCC33
+%FFCC66FFCC99FFCCCCFFCCFFFFFF33FFFF66FFFF99FFFFCC110000001100
+%000011111111220000002200000022222222440000004400000044444444
+%550000005500000055555555770000007700000077777777880000008800
+%000088888888AA000000AA000000AAAAAAAABB000000BB000000BBBBBBBB
+%DD000000DD000000DDDDDDDDEE000000EE000000EEEEEEEE0000000000FF
+%00FF0000FFFFFF0000FF00FFFFFF00FFFFFF
+%524C45FFFF27F827047DCBCBA2FFCACBCAA2767C75A2A2CAA14C04270427
+%27A7FD65FFF8F8F852A2C4A2A2A2C49B9BA2A14B7C9B9B77A22727042704
+%0552FD1FFFA9FFA9AFA9FFA9AFA9FD09FFAFAFA9AFA9AFA9AFA9AFA9FD09
+%FF8585848B8585848B8585A9FD14FFA827F82752C4FFCA77A277A29BCBA2
+%9B9B9C9B9B772727270427047DFD1EFFAF85858B858B858B858B85AFFD07
+%FFAFA9AFA9AFAFAFA9FFAF8BFD08FFAF8BAFFFA9FFAFFFA9FFA9AFFD15FF
+%F827F852A2C477764C769B76779B7195709B707727272627F8277DFD1EFF
+%AFA9FFCAFFFFFFCAFFFFFF84FD07FF84FFFFFFCAFFA8FFFFFF85FD08FFAF
+%84FFFFFFCAFFA8FFFFFF85FD14FFA82D2727279C9B9B76A29B772D587677
+%779B779B767D7C58275127A7FD1EFFAFAFFD05FFA8A8FFAFAFFD07FFAFFD
+%06FF7DFFFF8BFD08FFAFAFFD06FF7DFFFFAFFD15FF2751272D279B9B7D76
+%A15257515176774B76757652CBA77C51517DFFA8FFFFA8A8FD18FFAFA9FF
+%A9FFFFFFA8A8CFFF85FD07FF85FFFFFFA8A9FFFFA8FF85FD08FFAF84FFFF
+%FFA8A9FFFFA8FF85FD15FF512D572D5751A8A1A171777CA1719B4B272070
+%76A79AFFA27C57A8FFA8FD047D52FD17FFA9AFFFFFFF7E7EFFFFFFAFAFFD
+%07FFAFAFFFFFA829FD04FFAFFD08FFAF8BFFFFFFA829FFFFFFA9AFFD15FF
+%2D2D57572D51517C7777777D777676702776769CA2A177CA7D577DFFA8A8
+%7DFFA8A8A8FD16FFAFA8FFFFA9295AFFFFA8FF85FD07FF85FFA8FF712F84
+%FFAEFF84FD09FF85FFA8FF712F84FFA8AF84FD15FF582D7C5758577C579B
+%A2C4769C779B764B76A29BA2CAA2CAA72DCFFFA8A8FFA8FD04FFA8A8A9A8
+%A8A8A9A8A8A8A9FD04A87DA8FD04FFAFFFFFFF9B9A35AEFFFFAFAFFD07FF
+%AFFFFF9AB57B3AA7FFFFAFFD08FFAF8BFFFFBCB57B3AA7FFAFAFFD15FF2D
+%2D2D57577C575776A24C7D9B9B767C2776719B779B9BA2515783FF7D7D52
+%7D52A9FFFFA8FFA8FFA8FFA8FFA8FFA8FFA8FFA8A87DFD04FFAFA8FFA1B5
+%C08157FFA8FF85FD07FF85FFA8C2C2AD82AEFFFF84FD09FF85FFA8C3C2AD
+%82AECBFF85FD14FFA8512D515157517C577C959B769B76825757577C7CC4
+%9B77527B57A8FD04FFA8FD14FFA8A8FFFFFFAFAFFFFFCAFFA8FFAFFFAFAF
+%FD07FFAFFD06FFCBFFFF8BAFFD07FFAF8BFD08FFAFAFFD15FF265127512D
+%5757577CA27176517C7B51265757A77777525751577DFD19FF7DFD04FFAF
+%A8FFA8FFA9FFA8FFCAFF84FD07FF84FFA8A8A8FFA8A8A8FF85FD08FFAF84
+%FFA8CAA8FFA8A8A8FF85FD15FF512D512D57575851A1779B769C9B7C2751
+%51A7C4A1769B517C57A8FD19FFA8A8FFFFFFAFAFA8A884A884A884AFA9AF
+%FD07FFAFAFA8A8A9A8A8A8AFAF8BFD08FFAF8BA9848485848484A985AFFD
+%15FF26FD042D575757589B779B719B515151575177717757575157A7FD19
+%FF7DFD05FF5A5A5A845A845A846085A9FD07FFA87E84A97EAFA98484AFA9
+%FD09FFA8A8A8FFA8FFAFA8A8FFAFFD15FF2D042D275857827C5152A27776
+%767C7C82577C7B7D7C827B5751AEFD19FFA8A8FD04FFA8597D527D52597D
+%7D7DFD09FF527D527D527D527D52A8FD0AFF527D597D7D7D527D52AFFD15
+%FF272704512657578351512D51515126515757517C7B7C517C575783FD19
+%FF7DAFFD04FFA8FFA8FFFFFFA8FFA8FD0BFFA8FFFFFFA8FFFFFFA8FD09FF
+%A8AFA8A8A8FFA8FFA8A8A8FD14FFCF2D277D767C51585782572D2D7B7C7C
+%2751577C577B51A67C7C57A8FD19FFA8A8FD06FF7D7DA8527DA8FD0DFF52
+%847D7D53FD0FFF7DA87DA87DFD18FF7CA8CAFFA75857A6572D2D51517C51
+%510457517B517B7B7C51577DFD19FF7DFD07FFA8A87DA87DA8FD0DFFA87D
+%A8A87DA8FD0DFFA8A8FD047DA8FD16FFCBCBC4CBCACB588357A751512658
+%8357572D2D7C57827B7C7B5851A7FD19FFA8A8FD18FFA8A8FFFFA8FD10FF
+%A8A8FD1BFFA2FFA1A2A1A7FD047C265151582D7C7C7C5758577C517C5175
+%7DFD19FF7DFD07FF2E535252527DFD0CFF7D7D5252527D52A8FD0EFF527D
+%52A8FD25FFA9FFA8FD24FFA8A8FD09FFA8FD11FFA8FD13FFA8FD1AFFA985
+%8585A8C4CAFFFFFFC4CBC9CFFFFFC9CF7D7DA8A87DFFFFFF7D7E7D7EA8FD
+%15FF7DFD4AFFAF1B85FF3DAF95C4FFFFC4B2CBCFFEFFFFCDCF7D52FF52A8
+%FFFFA87E7D52A8A8FD08FFA8FD0CFFA8A8FD1BFFA8FD2DFF1B60FFFFFFA9
+%C48ECBFFC48EFFFFCDC8CECFFF7D5259A8FD05FFA852FFA8A87DA8537E7D
+%A85252A8FD0BFF7DAFFD1BFFA8A8FD2CFF1BAFFD04FFCAC4C4CBC4BEFFFF
+%FFCCCEFFFFA82752FD06FF7E52FFA8527D7DFF277DFF7E7DFD0CFFA8A8FD
+%1BFFA8FD2DFF1B3DFFFFFFAFCACAB79BFF95FFFFFFC8CFFFFF7D7D5952A8
+%FD04FFA852FF527DFFA8FF5252FF7D7DFD04FF7DA87DA87DA87D7D7DFD1C
+%FFA8A8FD2CFFA91B618B61FFBDFFC3CACBB2CAFFFFCDCEFFFF7D52FF5227
+%A8FFFFFF7D52FFA8277DA87D7E527DA852FD05FFA8FFA8FFFD05A8FD1BFF
+%A8FD2EFFA98585FFA8CACAFFCACBC4CBFFFFCECFCFFF7DA8A8FF7DA8FFFF
+%FFA87DFFFFA87DFF7DFFFD05A8FD0BFF7DFD1CFFA8A8FD61FFA8A8FD1BFF
+%A8FD62FF7DFD1CFF7DA8FD32FFA8A87E84A8FFFFFFA7A8A7FD24FFA8A8FD
+%0DFFFD0EA87DFD10A8FD22FF5936141B143659A77CC8A5C8A0A7A8FD21FF
+%7DAFFD0CFFA87DFFFFA8FFA8FFA8FFA8FFA8FFA8FFA8FFA8FFA8FFA8FFA8
+%FFA8FFA8FFA8A8FD21FF5914151B1B1B15597BFD05CDA5A7FD21FFA8A8FD
+%0DFFA8FD1DFFA8FD20FF7E14141B141B14367CACA6CDC8CDCDCDA5A8FD20
+%FF7DFD0DFFA8A8FD09FFA87DA8FFFF7DFFFFFFA8FD09FFA8A8FD0EFFA8A8
+%7DFFA8FFA8A8A8FD09FF5A141B1B1B151B59ACA6FD07CDA0FFA8847DA87D
+%7DA8FD18FFA8A8FD0DFF7DFD09FF7DFFA8A87D7D7DA87DA8FD0AFFA8FD0E
+%FF847D52527D527D52A8FD09FF351B141B141B0D7CA5A69FCDC8CDC8CDC7
+%A6A8A87D527D8452A8FD18FF7DFD0DFFA8A8FD09FF7DA8A8527D527D527D
+%A8FD09FFA8A8FD0EFFA8A8A87D7DA87EA8A8FD09FF36151B1B1B2F7776FD
+%04C8FD05CDA6FFFFA8FD0CFFA8FFFFFFA8FFFFFFA8FFFFFFA8FFFFFFA8A8
+%A8FD0DFF7DFD0AFFA8FFFFA8FFA8FFA8FD0BFFA8FD20FF591B141B2F7795
+%76A5C8A0C8A0C8C8CDC7A7FFA87D7D527D527DFD04FFFD12A87D7D53FD0D
+%FFA8A8FD1CFFA8A8FD0BFFA87D7EFD04A87DFF7DA87DA87DFD07FFA8141B
+%14779B9B77A0FD05C8CDCDC8A7FFA8A8A87D7DA8A8FD18FFA8A8FD0DFF84
+%FFFFFF7DFF7DA8FD10FFA8FD05FFA8FD0BFFA8A87D7D527D527D527D5253
+%527DFD08FF7E1436709B9B9B4CA0C7C8C1C8C7A67CFD21FF7DFD0CA87D52
+%A8FFFFFF7D53FD0B7D537D52847D7D527D7DFFFFFFA87EFD06A87DA9FFFF
+%FFA8A8FFA87DA8FFFD07A8FD09FF8453FD049BBD9AA0A0C8A0A6A7FD22FF
+%A8A8FFFFFFA8FFFFFFA8FFFFFFA8A87EFFFFFFA87D7D7D527D7D7D527D52
+%FD057D527E7D7E7DA8FD04FF7DFD05A87E7DA8FFA8FD11FFA8FD07FFA194
+%BD9BBD9BBD9B9B9A9A7DFD23FF7DFD0DFFA8A8FD06FFA8A8A8A9A8FF7D52
+%A8FFA8A9A8FFA8FFA8FFA8FFFFFFA8A8FD08FF7DA8A8A87D7E7DA87D7D52
+%A87D7E7DA87DA87D7DFD07FFA89B9BBEBDBE9BBEBDBD77FD24FFA8A8FD0D
+%FF7DFD1DFFA8FD08FFA87DA87D7D527DA8A97D7D52597D7D52527D7D52FD
+%08FF779B95BD9BBD9BBD94A1FD24FF7DFD0DFFA8A8FD07FF7E7DFF7DFFFF
+%FF7DFFFF7EA8FD09FFA8A8FD0AFFA8FD09FFA8FFFFA87DFFA8FD0AFF77BD
+%BDBEBDBE9BA1FD25FFA8A8FD0DFF7DFD07FFA87D7D7D7EA87D7D7DA87DA8
+%7DFD09FFA8FD0FFFA8FD16FF7DA1779B77A8FD26FF7DFD0DFFA8A8FD07FF
+%A8527D597D527D527D527D537DA8FD07FFA8A8FD0EFF7D7D527D527D7D52
+%7DFD12FFAFFD28FFA8A8FD0DFF7EFD07FFA8FFA8FFA8FFFD05A8FFA8FD09
+%FFA8FD0EFFA87EA87D7D7DA87DA8FD3BFF7DAFFD0CFFA8A8FD1CFFA8A8FD
+%12FFA8A8FD0FFFA9FFCFFD2CFFA8A8FD0DFF7DA87DA884A87DA884A87DA8
+%84A87DA884A87DA884A87DA884A87DA884A8A8FD1CFF5227272E27522E2E
+%2E7D7E857E858485848584857E857E857E857E85A8FD19FF7DFD0FFFA8FF
+%A8FFA8FFA8FFA8FFA8FFA87DA8FFA8FFA8FFA8FFA8FFA8FFA8FFA8FD1DFF
+%7D0527275953592E7D848584A984A97D847D858485848584857E8584FD1A
+%FFA8A8FD1BFFA8FD2CFF7C27F82D59A97E7E53A9A8AFA9A92E2D2752527D
+%84857E857E857E85A8FD19FF7DFD1CFFA8A8FD2BFF7DF82D27527DAFFD04
+%FFA9AF7D2E272E52512E8584A985A984A985FD1AFFA8A8FD1BFFA8FD2CFF
+%52F8272727527DFFFFFFA8A98452F8272727F82759A984A984858485A9FD
+%19FF7DFD1CFFA8A8FD2BFF7D2727262D27527DFFAFFFA9AF2E52522E2727
+%275985A984AF85852EA8FD19FFA8A8FD1BFFA8FD2CFF52272727F8272752
+%A8FFFD04A8FFFFA852052E59AF84A97E5927277DFF7DA87D7DFD14FF7DAF
+%FD1BFFA8A8FD2BFF7C27585252277D52A7FFFFFD057DA87D52277DA9FFA8
+%52272727A8FF7D7D7D52FD14FFA8A8FD1BFFA8FD2CFF522D2D7C7D7D7D52
+%5183A8A8527D527D597D7D522752527D052727277DFFA8FD07FF7EA87DA8
+%7DA87DA87DA87DA87DA87D5352FD49FF7D265252A87C587C7D58A87D527D
+%A87D7D7DA7A8A87D7D2727F82705A8FFFD057DFD06FFA9FFFFFFA9FFFFFF
+%A9FFFFFFA8A8A8FD48FF5227045127272752272E2727275227525152527D
+%52587D52F827F8277DFF7DA87D527DFD13FF7DFD09FFFD0BA8FFFFFFFD0B
+%A8FFFFFFFD0BA8FD19FF7D04272727F8272727F827F8275227FD05522727
+%522727F827F8A7FD19FFA8A8FD09FFA8FFFFFFA9FFAFFFFFFFA8FFFFFFA8
+%FFA8FFFFFFA8FFFFFFA8FFFFA8A8FFFFFFA9FD04FFA8FD19FF522D272726
+%F8F827274B2727007D2752277D5152FD062704277DFD19FF7DFD09FFA8A9
+%A8FD04FFA8A8FFA8A9FFFFA8AFA8FFAFFFFFFF7DFFA8A8FFFFA8FFA8FD04
+%FFA8A8FFA8FD19FF7D27512727275127515151FD0527525252275127512D
+%7C52524BA8FD19FFA8A8FD09FFA8FD05FFA8A8FFFFA8FFFFFFA8FD06FFA8
+%A8FFA8FFFFA8A8FD05FFA8A8FFAFA9FD18FF5227272D275151572D575151
+%2D51515251525152FD055158517CA7FD19FF7DAFFD08FFA8FFA8FFCF7E7E
+%FFFFFFA8A8FFFFA8A8A8FFFFA953FFFFFFA8A8FFFF7DFFA8FFCF7E7EFFFF
+%FFA8FD19FFA7577C577C5758577C577C577C577C577C5758577C577C577C
+%577C57AEFD19FFA8A8FD09FFA8FFFFFF295AFD04FFA8FFFFFFA8FFFFFF77
+%30A9FFFFFFA8FFFFA8A8FFFFFF295AFD1DFF7C2D2D572D572D512D572D51
+%2D5751572D572D572D572D572D572D5183FD19FF7DFD09FFA8FFAFFF9494
+%34A8CAFFA8A8FFFFA8A8A8FFA894525FA8FFA8A9FFFF84FFAFFF949434A8
+%CAFFA8FD19FF7D2D572D512D572D572D572D572D5751572D572D572D572D
+%572D572DA8FD19FFA8A8FD09FFA8FFC9B5C0825EFFFFFFA8FFFFFFA8FFFF
+%BCB5A533ADFFFFA8FFFFA8A8FFA1B5C0825EFD1CFFA8837DA77D837DA77D
+%A77DA77DA77DA77D837DA77DA77DA77D837D83A8FD19FF7DFD09FFA8A8A8
+%CFA8FFA8FFA8FFA8A8FFFFA8A8A8FFA8FFA8CFA8FFA8A8FFFFA8FFA8FFA8
+%FFA8FFA8FFA8FD26FFCBFD28FFA8A8FD09FFA8FD09FFA8FFFFFFA8FD09FF
+%A8FFFFA8A8FD22FF9A9AA0BCCAFF8383A88382FF297E5354FFFFA87D7D52
+%7D7DFD08FFA8FD15FF7DFD09FFA8FFFD08A8FFA8FFFFA8FFAFFD05A8A1A8
+%FFA8FFFFA8FFFD07A8FFA8FD19FFC9A0FF93C9AF5EAEFD04FF54A9FF29A9
+%FD04FF52FFA8FFA8FFA8FFA8FF7D7DFD15FFA8A8FD09FFFD08A87DA8A8FF
+%FFFF7DFFFD09A8FFFFFD0BA8FD19FFA19A9AA0CAA758FFFFAE83FF2F7E53
+%53A8FFFFFF8452FFA8525252A8277DA87D52FD15FF7DAFFD07FFA8527D52
+%7D527E527D525228A8FFFFFD067D537D7D525284FFA8527D597D5384527D
+%595252A8FD18FFCA9AC29AFF835EFFFF835EFF5A7EFF2FA8FFFFFFAF52FF
+%7D7DA8A8FF5252FF7D7DFD04FFA8A8A8A9A8A8A8A9A8A8A8A9FD04A8537D
+%AFFD07FFFD07A8FFFD05A8FFFFA87DA87DA87EFFA8A87D847DFFA8A87D84
+%7DA8A8FFA8A87DA8A8FD18FFA0BCFF99A0FF5883FFA858FF29A8A82F7DFF
+%FFFF7D52FF7E27A8A8A87D527EA852FFFFFFA8FFA8FFA8FFA8FFA8FFA8FF
+%A8FFA8FFA8FF7DFD08FFA87DA87DA87DFF7EFFA8FFA8FFFD07A8FF7DFFFF
+%FFA8FFFFFFFD04A87D84A8A8A8FD1BFFC9A0FFCAC3CAFF83AE83CFA9FD04
+%7EFD04FFA87DFFFF7D52FF7DFF8484A87DA8FD14FFA8A8FD07FF7E7D52A8
+%7D7DA87D7D7D527D7DFF7D7D527E7D7DA87D5252527D527DA8A87D527DA8
+%52A8A87D527DFD4FFF7DFD09FFA8FFA8FFFFFFA8FFA8A8A8FFFFFFA8FFA8
+%FFA8FFA8FFFD05A8FFFFFFA8FFFFFFA8FFA8FFA8FD2AFFA8FD24FFA8A8FD
+%50FF7D76759A76A1A8A85858587D7DFD21FF7DFD50FF769A99BC93BC9352
+%58825E82585E58FD20FFA8A8FD09FFA8FFA8FFA8FFA8FFA8A8FD04FFA8FF
+%A8FFA8FFA8FFA8FD05FFA8FFA8FFA8FFA8FFA8A8FD1FFF7C93939A999993
+%7551585882585E585E58FD1FFF7DAFFD08FF7DA8A8FFA8FFA8FFA8FFA8FF
+%FFFFA8A8A8FFA8FFA8FFA8FFA8A8FFFFA8AFA8FFA8FFA8FFA8FF7DFD1EFF
+%A89A93BC99BC99BC517C57835E835E835E58A8FD1EFFA8A8FD08FFA8A8FD
+%05FFA8FD06FFA9A8FD05FFA8FFFFFFA8FD09FFA8FFFFA8A8FD1DFFA86F99
+%93BC99BB6F5757575883588258825883FD1EFF7DFD09FF84FFFFFFA9FFFF
+%A87DFFA8FFFFFFA8A8A8FD04FFA87DFFA8A8FFFFA8FFFFFFA9FFFFA87DFF
+%A8FD1EFFA19A99BC99BC6F4C2D58345858835E835E8283FF84FD047DFD18
+%FFA8A8FD08FFA8A8FFFFFFA8FD09FFA8FFFFFFA8FD05FFA8FFFFFFA8FFFF
+%FFA8FD04FFA8FD1EFFA86F9A99BB4B4C282E2D5834345882585E57A7FFA8
+%7DA87DA8FD18FF7DFD09FFA8FFA8FFFF5353FFFFFFA8FFFFFFA8A8A8FFAF
+%5353FFA8FFA8A8FFFFA8FFA8FFFF5353FFFFFF7DFD1FFF9A99BC6F534D53
+%2E583458345858835E7DA8FFA8FFFFFFA8FD18FFA8A8FD08FFA8A8FFFFA2
+%4D60FD08FFA8FFFFC44D36FD04FFA8FFFFFFA8FFFFC44D60FFFFFFA8FD1F
+%FF7D99934C28534C4C2D583434345858587DFFFFA852525253527DA8FFFF
+%FFA8FFA8FFA8FFA8FFA8FFA8FFA8FFA8FFA8A87DFD09FFA8FFAFCF8DBB33
+%82A8FFA8FFFFFFA8FFAFCA8DBB335EA8FFA8A8FFFFA8FFAFCA8DBB335EA8
+%FF7EFD20FF7D764C534C534C522E58343434587DFD04FFFD06A8FFFFFFFD
+%12A87DA8FD09FFA8A8FFA7C2C9AD83FFFFAFA9FFFFA8A8FFC9C2C8AD83FF
+%FFFFA8FD05FFA1C2C9AD83FFFFA8A8FD20FF7D52285328532F53282E2E2E
+%7DFD2BFF7DFFA8FFA9FFCBFFA8FFA8FFFFFFA8A8A8FFAFFFA8FFA8FFA8A8
+%FFFFA8FFA8FFA9FFCBFFA8FF84FD22FF5353535453545354535353FD2CFF
+%A8FFFFA8FFA8FFA8FD06FFAFA8FFA8FFA8FFA8FFA8FFA8FD05FFA8FFA8FF
+%A8FFFFA8A8FD21FFA828532F532F532F5328A8FD2CFFA8FFA8A87DA87DA8
+%7DA8A8FFFFFFFD04A87DA87DA87DA87DFFFFFFA8FFA8A87DA87DA87DA87E
+%FD23FF7D29532F545353287DFD2CFF7D7D7D7E7D7EFD047D527DAFFFFF7D
+%7EA87DA8A87D7DA87D7DA8FFA87D7DA87DA8A87D7D7D52A8AFFD22FFA87D
+%28532953287DA8FD2CFFA87D7D7DA87DA87D7E537D7DFFFFFFFD057DA87D
+%7D537D7D7DFFA8537D597D7DA87D7D537D52A8FD25FF7D7E7EFD30FFFD04
+%A8FFA8FFFFFFAFFD05FFA8A8A8FFA8FFFFFFA8FD05FFA8FFA8AFA8A9FD5D
+%FF287D5252A87D527D52527DFFFFA8527D537D7D7D527D527D7D7DA8FFFF
+%7D527D52A87D7D52A8FD61FFA8A8FD05FFFD04A8FFA8A97DFD04A8FFFFFF
+%A8FFA8A8FFFFA8A8A8FD99FFFF
+%%EndData
+
+endstream endobj 22 0 obj <</Length 55388/Filter[/FlateDecode]>>stream
+HtUyTW
+\;XyBym`EKɵ[gn^NT_w雺#N7vݵ5k:\k36Wj[fNgfs[B?` !l=/o`;BY$`ry$̞̦%79L3 i{A}r82NsΠhpe(ڜ@ň3A9CA(GflD Cw~'a{(G:uͨ+=A.bofKk
+; M)OGX~0@87g
+8l6,X0 04Ϣ?oeÂVn
+F{ve2Vzi?'>-k kHp"/n\R=oW xEAG z;]I3c_qޣ<pC>mJn GFg:U8'zx\2s4ӤBfS;п3Wcp**נ/ z2Qם(HETTfXQؾuԛ1c=&DŽ ؼSmeF맨؄99پ[עQɸ24Dg*2 n߅q GT'4(Q^R&!+'xE9͞;_}#%?q>_/O}I:ХBn ZTŠX}2 VmԡQ'Y6y3NVR<O5^D:
+U(:CZmD3*nVFIVԢY1Ys$ hHeذ7ɧI1.:>VJpTIۗ_F +4oE9߬21. d"ڳ1ofwm̞׹qak>Foղw O:ոFgy2qrٔ)Nsı!έthY~ҳY&1{LmFcF٦_e_g LMjc9qљXӼS86} QU4ǜ W#
+WLؕЩTn
+Tѣ"=GGEGu(oó8rPKw.¯Ydi2Cb U&9 YL
+AP+[Ui4<44Зz?c SaO:i#JꥫϦQr3;
+JQ<NaKةvq#gޛ|ysss{~|}o|߀twcNPB<r!E8א!Za`ANg!Ҵ'iܟЪ!l E5'O<znWHkK5 Zf
+ú,gF?‚h>+t1O:1 ZrDخ1:=Ȅ(bi3
+ AF97"o0HT53C~ڂ?
+J/]BOpWzx[_Xm7{}et ]w2as29<-Y"c&x;R3O? zn&P+VX~z7Z@-: AxY^n
+5XVX5 w16COe}\np̳
+4lB#jG/;'AGeXD|)$d0DgXE&4Ab 2T1FbGg$RgI^@W6\(#+rڿl ȅ".V y,EYL0ؿ l0,dR;fwfR+ͯϸ`;/0oxcf#<{2lzZ؋pJ}a1'&XHBNC595ȜUAVU[X4.C=O9\-`bw)l %k7Pjkd 0](YqjGnGG65[{j'ı-Xe_eY}jr '#+f
+P&&HG$nNNz{U{u9!n9g~ v07`!OgC(9m !<@8_XA_ &8DЊ 0]rcepn;z)AE$3*ꇡ !ȫbXHҬ
+@Uy
+or!A;
+fzWcןc<8 Fy]MGy,Wc>'P낵:@1ȡ'}2( 94D
+:#n.q/"{b{<ޭ'ƺ|XO\ơq4뫿pV] 3)5)k!ۖ?$o]}#^{4$kgu[wmvD5_8V8ie>:_5Gm s>9~s9ㆈ{b8Q *cimQV%1^k[h]n ü4ي˦+JV0^5Gjrњ tը&AfMjt*MՁە̯=q̫E&&ؾ:y03,]
+C Ϥim`{9L}"nˇ]6<a1gL>
+= 7{!/>mlPśoGe&Z?f+`BR ' ØA"h5Yyd|
+=-y9s_ ۉ{D|
+dztx G#Gy1CM8v#~8?@_{ fY
+*xkq9%
+K{5kn4^s8s'7}w)yRz=H1g䤯z1)_oGKm)FXs|7DޏŜ/sXv
+x<sg;%]:$pIJp?8O]b]#~ nڐqЁwm)/#
+6
+kf^GВ.'/c})5mEiD )BH}F:)ESTx/Н9 ^$ Zo$`%_Z)gyJ:ud;:
+zr"9dJ4.9f9m(# H10^
+c !r=ĵPLi[?-em(u\Lٔge;KsռR|݇qɯ{6WVDT;RL-߂QQ)-;kFI-&*R2 gz?z'ܟu _cޖt 30
+hɠu QU# % (ab/~H8' D&^CEaHQ(XiO-SPu{k=2~;
+ZI Ŋ)YA>ʕݠ5[><υ0GZV_ѪvEKEgyVq΂";([0X5E^/\nx;=/E_y@pPAGk=/hKm( 5E^69ΡŒThEf{C$wY`DМ<ThJ&X?"rpv T_@/y=7+Bpz=튀~s' &qg4`Kb*!EQBJ2KJhLPAϦoUA kxn*UK *'̃H #g|Th-G;D#Q $jxsB} "G[&'x}zsn収X+Ry}w' ֟}qX3CnD>;m8kP#
+>w8ϧDADx&Gq/vՖ&nSz̞"·yWHx:ޙ D4tٷ 78ANi|%6дf%M.P`%W.R\6usd7_K7فc];uE諱?8UjMNefM;5)#5 nqO)=@YSyи*0Ms>\jy3a(ԼVWۮ4}!?|n_}XpG O]v?%ᯎ<
+}yA" 7L M *
+˷"8Qpg:p
+f|͉̣)8=eSTu6d
+u.-%沴e,Jc)ee\ܑ',.3%a dE;* ;VT\P(.ӪՂ
+DM"*:"øǪ3sFtܑK<swKr~nWl >lf6 4:~gzr S4-c,J"#ԵLնe/b\wU@ظhx4tت*<& JO%r5~z>nݸ~-QO xCR:h˘o".,-t"STh{V^uwM6?r6ϩg8%W< ~`ǐx;I'òɟ{><$=8yT3Yj5c s<Cs,s>oV3W9WbNX栙͜*Q?\'07aN$ g_^4~jZrVQB3YKrWF^UZ^V=}Ȣ!jX5 Q4\Թ/D!+
+kZ*0=3?Xnd ?޿%Z8 ^'^wU8[luaF#j>lG͡L6<4P㮨{_>:jM-~W2{Wp` HJ FAeP#w19,I",84ݷױutnu=f
+b5ƤB.osՙg@%cA !+oh<g6ڝf&dW.]6k1Q rK`{?cH1k1_`j9E:Ij&3JkpS곋W&|ɪُGT Ή)*y0<Jhspk!UmW+ٴ?*Whn5nHI맟
+gic?'%|
+kƸsU=P
+ѼNMDO RecR.oS=`AYwH0Emk2RxgP_1Yӑ0}|G(퐀yQH|xxrqjD9la
+܁s)7~W?G[s7 O)"[xSJARÜzdgI޽s˜|[P7{A?RO̗zQ*#\Ri̓ll
+}ZpvNJtފˍ4‘бCw6o9h͗K?mw57ޑ]åחnۙw}zv`VskWj[.|ͦ?]_RCwS{]3 Wۚ{=qr7W+K~.~,?NY(ǰHSk [9<?~ֹ[2ȩϋR~|ZM dO>ZlP8bFӬ.}/NsbC3YXa9SwŒ"p) qٌߨKun$\t1_֨[S wRB[j+J9Jr-%~|-ѳpGC3qsq`u]&@=gU8Z T@+ E}4#
+5sw{3y`޾ZLverx/4X_|Y/_tCF%Ck9}3@>01&B3%.%XΈʎ'yr:,|XqE<}:U?R?yZYL+H.hVSz L헖N+;@VJȬ FW'p}YSP44 O::<*W%2$6Fg-x_`B٘:kG#?DŦ*ڔjo Dz.M}64{/syGEya>C!DP0R! H HUEk"#*]H@B &'QO==).wo&޹\۟8J_틕/c^aޡG>0;jߘ!1C"}I۸CIc Ͽ~nWߟM9#zv9 k`M̡|YSjY^Xς| =,,؛r{7s/\mdq,'w0+*lQ!ROs{):ׅT j84\4kYJ+FвN9,٢a+s֟YV)O{L|Ttqoilz(^-vݼK'?^xC>Qަy=~eҘSeJ7Lkxwi}n#mYݶؽqx/mBr(k3.W2K9n=Fk X_¬JBթfS>v6ٟ4sǜn$&oL`.M(9OYqgڴ\1e\IkYbҸorFuoJ`΍`v0}{,k#Kc\ԝy,g9,ߔBYX} dA5+Mi̟cm5+/ty<_ +^ٝX\?XtGx&OKejD=Wժiw=Jjڵ^9:rzjɀ7'VfTՠwYׄKW3+]֢|;J%ؿ>d#4lR=渎Gaa߸tsa'ߙ~f/>GŻܿpp|<4&(t|:('w)<@[. > '}
+(Q 2yqk"Kh^=sLNTV=з%œ h.u.H$A1p!̌xk%8NEL@^FD-U-,1`Pp`D'~CߓWS5XòݘlG'#Cޓ`{6z7GNrB?\C;y,rfg/XZ|s-ƈE]uOd){=RaNI3<Nw毕3^PQR,۱
+O]o:+͑
++mU(?qNr|f/%;g?ioojL?gGQbm7Bc )
+υ:Ĕz2`upq[wam-)/lyߔQ 1Wm>)-I5jIfk;R %)񮀒 HoG݂D3<Cᛂw]x.=CX7%#$E8w#X`B-9
+gv:rXʗwe}\<~G5&7A-*thS%+Z/]ZuzewǵziZ3:PunCtJQeôɬvY>'?yG|:_GGH6|Ĥ
+J'ݣ{/kQX
+sڂmv=.b\J [)r
+W"oE`exZ?{`g#"f:7A; ЎQc B|ygc&|_fN n>*HC8c@tUdIҊǼ˘&(9(ATA mΞ]ugu5,J̜SW^~m(q7!<[|yhUPVHW&!щ9KY[OJ#XTZp;r0yM<W2H%h}SjuJXY'1s< <qmxcw41_iء)UCSs}Ssc>8Es {e{0UǦ{g9OٳR<5<6{"_͋罵{,2&pC4sn?Mv*ldgclrjhzɊg `*ֹYR'ؿ|ߕ”$|-YLɱ?By%3Kq̳%hTOή+*>{rLWUtlaruf%S5srܟWąLݒƔZ
++)dT5`Z?}Zf.>Msk~Nǔ :RWߐ:N`Ū~:=>?ñW_O,R38)p- ~\k=%A9/܊]
+4.'; ,V?qB9`olcvtF{$<KzJs}?`zܫτG>9,/oyM2<;= [+gg +4Lw`jzd@%{$у#vWp=Vk?_pk/8_"ky1<)P
+K빨KEagmفŅ`_E Bo(cuc`~5ǻd0'?akQ 8Zć؀R>v@koN@)Pו
+}C}CwE׻m;xRgD:eZk~zHY6MO+׋)!dQ@wo dg؇mXF1Ã.X?͊"?Dba3g1v)
+m5sc(lKQ-8/xi<-FD!->oA))Kx7 7% \p![%瓶
+918'1ȏ@T'E-ARgG.@C9!fΜ'ƹc30i=k?c-&v`I\G K:fm!EV<@
+PϤ_%F]p/cs
+'-Z?Xr*(>ԳKDe?kS
+Di_"UJg;p%Xa~%J
+RPန
+%T0 J RӠ`TڗL)h%xb.-ϞҗMw޵ lO@#O`tr:n
+<ԳFb1|]CZB(OeX[zsiEz~ Ye@LL( C2l'&XszcsY߯fNcבV5c5DR_HCl17i9IvL|1u ywFGTNSj8@M]Im,PWGSphjUI-FQ(/s}
+YLݚԫYAoiQN8~v&:uF9gi?51ckFrJ_ū S~ |DR܃iTKmq4})uhLӼF(a{* jM-X'V/Jqlǽ[¶T)j<'ԹR٭*Eհ$|*Jwe[5^<\VSeeWeWvEQ+& 2zcߔ^׼ D"ޙL?7
+Uw7ujm Cu6.ȇc%<.XUQ3caO͏ 2)wxmC\8A`BВ >qM~8=MuP¶GFEߵ3 !;aZk{p<oE)!aC5' i 9')uP7譳b:LpY cZ剞0c-ȷem`?p~0EEG ;}vڍ" Cje|7*vP2^&wxu'::F.>WIUv'^dY2geEE_d^0}IakffxaR%Kl~"`yy6nk{{#nl+H4Kv{Jy>{'f;řG~ZqW]*֊"s\">!n H-N6vq8<{uc UҮi~UXd
+Z.d)ĵkuͽsrz (!)Ϭ(SB]bxJSVeŸd v/5pGy7x45g3PSuY\ˠ>c!+_ԥπg
+t\ 3A @ qPMGuLly,QGk5޳JK|f5zo<Ҭ0=m\2,Yy5A0:.-0
+f-]_@B΂x7/zAĭ u»4)>)
+ԛLv ʤR6(e բRUe5 #5g6&388/В699mһ ߨ`n\4$ ̭Ng60M0M1ckc6UQTʟ[k^8ďIIlZ E=nȜ_C;91dQ~Ǽ,txjyА":)!fK[ƌ9d*ߓfw3#lZb̵\9Z0d+wQg5MxNxu(_L9>t>dwyr\L:>dsRDo2w
+hIlN_J}ݖ«Yȣ9WGCFMD-u);X|
+ߛ'Y)xO3(ĵ =G=nw\opfJ$!J@`u;eu~h=H*]\^Jw(INM-KݔLIM7(Op2K͆nu}n׆EAMKB&$ W0&ׅ3&9kfG [☫cZά+"Uy$2p36%lKg[Uln{*)u-ez"I:ǦtboZ3QbfU0~*|²*&jҦQ洪oG>c;,X. |Y
+y3.YDwL֞ÂgS=^J?n_Զ"M҇6L|QO jS'=l~-˞\Ԙ5PjNgy3eY׌Ҭwd ySߝUȫL؃
+GݩT;ۋFr?PvA-oߺc(`2p= _~[U[2{|=?ExM Y]B
+o)ͺbFF.
+)[Cp^b >jNyѹzo!#d]I可b{T~(?js@n6u7p|&;W ]kS͛|2PThSwaE]s^%/WTumiwgz8K59+lȻѺ~`M֊Wf`Z;7^o9\ڬe䙅@¾%aE% 9Ι:EwpEhP@83usZ=.k$<_K~ws-';]uxsyOͯ~%ӳ
+ϳG::}د1/,:a72)D*!%|.`v+ҡ~2@y#‡ˈ-Тv96f/0wȇ4}C~)e zp۬iEu)߁ԇp ^#}ؙ9Qj9P?{-e?
+Q5 Σe+Wx\S|@
+DE+CR9qhs/'xr.*7ޥg;N]qwE 5 z~"W?s| |V,6/S"<{z5}:\oȑG.*$g'q8;ЅTІL|6B^Spg!x"sL+
+LoaE&{6$C BAm0?pExuj%Rʮ6zPT="nk;UkSumGBZou}edQ6SoS8>`
+F~3g0.Dk:8oO3vvdةy-mHՠ}&ozߤ{=B&Ж<ަg~Es8>uj ܷ{lNuݜxӱ!cSmɯjz6p.~0MӲ,;D[ۉ?d_Yukgy/wB[oc&kO'R=Uy>5he=,'2>Y,C,|,64G'[b{%,% .1/6Xځ,%(f!s 2^%ܺ.sȎ>|Stdpi"*^3j%^E.cTbOY=f׀5ԂϝA@YݠߋogNi+|2ﳠ
+VS|@c;Ƥ.;&]1)o=ZL;>vbmLe:Mxn2yS&7k25lj_@>n ŻKa>I̳_\{fX&i17+#VK-WOM,bݥ,~/\E,)xV{M}1EO!j55lz*s+͚i=eɶX`S j4B
+&o3Bh*h(<Sp]ojo^ Ts㵰z[m}T}I}cCk;JTX)RݒR>pN'Rܳ2:y]ܩJdE(m$VuaʹwVfzݓm? n'i nԾgk{y8a͜[vگN(Ysf+*g %-ْV
+: :gK3ꊔO;twh-!EAgIyMQFļSXȭ8恞cFx9`
+f5!_ I$
+l",⪇%9`пZ#.`k<89*-%sIu/k+,8;
+@X$
+<R 8?IhK7F|\SHуM?d(b!! f̃|F>#3MIm3[ vûn["5@K!_K q`LgFf{?ro=kkq~!9l8gW0=92O]qv}~;`wMX_:?bJP ԂXx+
+x<Hi4#0sפ+zQgAոob.kUNJUn[5>nxc9B'185QQk,u鈡8ړ@{dT"˨^NO .7xMH3ɢ;ixٍ`˟Td=ن.MZN&P(s|U̗2>#'Q;Yi_KԂC$EPB$Ӯh} G|j;D>!qO"DFZkГtOra/X< m~%E66i#O
+?ʪ,Muau4mɒG’'UL8/}\hWȨA)'q.NŅqy=r_?1- R#L>{拎GQ:ho^Lmému2ݡWJ;_VQV-]ОK#:VШc|-]ov"FkG`@gʣK{s䤆v"t)ԧJڽXR|@TTTҹ*fܱR:y£6!j35@M (Ϡ~*Pe(ULx(MxݭO{ݿHs7Ҭ11rR8sqc=;;Bǎ2r{O;ŸYxfyc¢ƈߟ8\,U\ҭT«,}̧.s"HeSMΚ
+X_5rtWi|fޢ >DKq~j ~ۖ$&\
+ GrSZԯeFw^hVx
+) Q;"7~bth-I[
+VV`> ,̫Uhg"`
+ꒀd^2#Sܟsւh׏y
+-_%_̵XZT#g⦹hudwحeaZpz nW2.c% q̥CuF[ۀ+#]izFŲN"+2Fkrٴ&+8-V{ mֲ
+^ vG8楼vS IկKF˳G&iuru3tA:QR=o;v<3 *qr+fj-ʄ-&)(GL#)L
+
+!o/9=^~|l:u#fg4Q@~
+]6eޚ5`\aZYRY)璀2.,z)sxw!;DÖ4ྴ!hA!c=@a#vK#_REkZ|F`E!|\
+סddȋ%%iCjcW-Q06eh_ԤSk΂~fZztCc ׇӘ̂Lf>p(Q;2툫%^'VƘIתh$sYsߜ/\8ƽ):x72^$0?x:AZ
+gjac60mKxqE֐f#6ܑȋC/UؐbȜ/(2錀ΉIuםb~DsE衃|PTlS`MQ
+, kBCqsg-j1jLZ/yD G͍g=.=.(=.c3=OsQ?3_
+\qM]Y? P
+Bda5 a U; ti;8AeS@AVpZEV[+ULw9{lj
+Qw
+vaO
+E;Sm-2%IxyY>̡E8Ž`F5`AXP0+`0b>7G,zӇ_uo
+'5YS_8|A|;4]?\|XM[F׎Xs6euoeX@ʵV~0T.\"Ճmw{SO[J\;=JO-[rW9Q?SZOn_hyWW=5ZU1er 9N%p
+$/.V; m|_qtהx|.Y!ߐcK`\PT;)nFlR@#&GM$Wb!{9fKQ͜N1vZϲӄ`~e%%5׍"uR$
+Fm-$ #3iEC}B^:5p>l3ZZ ݍƑx^n~[s3"WV onϱ߈o`} 8MFoE\35/&%noqߜ/a:A;2Ƿn(~[Z<s| @P >9'4?h8e%8\=PGY7bo6;u{5
+7G="{i7ң`-`Kѐ2%ݯ6$N87ȟ;l[vϢoTmM~Asvlu-[&UM*}a;%i-t@X󀜙 ;ȸlš
+ OrQJyƍxiKFj\E+LheUrS+{0j nCh
+*a5Kc5*#=g~չ>wƥJ3H2;Hߝ˔SySG
+~<h_UΤW[MƴKU{cI5lXot {
+SL9Ŕ _Lo@Jx^|vsSLܓ~^R}öpɆI:hSM1-aۆ58(dUCED^7ϐC\DŽ̘0O} 7KL"9Qώ2fOA#>
+/umc拀gDP0 ޿)-m)׆jV<^vrKj X?d `ێԇ/1$h*켐ַM_?tc~q?4o,8]0eᝪU=5Ykn7]4ܽ;}zMpޭ=_-k+7_9U4r<o59^>ra_CuڡuWlSW 5PTyI>ٌQ@azȥO"g]n4 C-% L '9w\ma.:m(S?4Ѹ@E p)AO}
+
+1C::Dm#K|3 %xO=m﷧ټU?/q+u;9 83s0hĠ,tD\V'=ĹE1ݑ|**[ߦqә3_u&fUH?GI 0ȸ4yIwfN:pQک21;o2:slQ5qB>Qz沾=
+ŔLֹ&<=az0qʰw3#Lͪb?Z7O}4m4?5vzd֭ >T-S.-`Ƅvѯ-E4-pmgq %=8ڏկ d k
+j5Y151Q./T7Ѹ*jUIIWoz5MJ:,ٞ4d_v;S߸V*߸֨=% p߄j΋g
+9T.9 _Bɍޝ.O\s٨zT|X({`!u͚>%:~ADRҕgm?{{lU HGQi9Rݷ_[xnFҚ?e9(KS>:9S>zm:<0BЄoKޅ .155 e!b:Cۖ./
+f#UTg"PR"%0F$$6dBu
+=VdGFzK:PFiGcH4\ {(!ٿIx )in K6y";
+\C{#ÑIWQ65IB^_DNofo)|g%b)_pp<,H$B>HdF׹OG }B`4f1%̰<zgzKz?u}!ug(6K[3r9'LV[5kq/9{,p~g6vLRS1dZ]y]w]͟{4ZS$Pw XGUoQ\@{'0pLE>w".0c:HlxXn˟KR/C:Nʒh)k:Lr[ Mbéq[얐ܬ<Fʋ_]؋V'k8-wYQD(SY 0X_)R
+eNSR֎:k:18û.1ٹPcwF*T$K*)W @z#M{dx+xܜ`BNƔ؇4I)<uc\Fy G,c <AQ ?2#8,ܼ?e[^#G`]L.`D#B8q %Ӊ\[n_w{}m=}> }`[ocVb/qšp]W2\d-`wd%cvvANrew)
+n~ü+A}z&D=!XK:<s9V^H*T4xg''2c3ڠFy c}`"P|{5Ý1H,I2F+.tZ6k%Zl~"ޞئRyg>橏۲jPy6~zsGs2K2ʼnl~J*He&jQǶ W.&ؔ޻H7[;[3[6uЧt!9u%Ӈ7r|Eћmi~ߔb 1O-'o*yoU: h]foG7X:sJÅBdӹMZ랄G)xUz]a^`M1uܰ"3YTEr*XζF9Wp8Cί= 8{v^퓹6}cל4esa-:.5{ArMCZ.[Z.䨆 jWq-
+ΣAʹî*y *nآfVQΈ}4ˢ8=e^/pjh7'_^/Lzhy.(,][ inhmfQY4:xԌ$q
+[b#fbl6!UX,6*]l4֯jNq?iUʠoU~2K
+{gKu=uևcķT%޻b]2 ^c%zvt9hؑjVZpԾ܊]*9|tB7f'=OZ&-NkO$&{R?c ''<y }- Ř~8֓[{ N(L3"3_O5dAf (5<ە
+t=AaRvI0^) V Bm+)1|@WH 5
+)hGr\סO,"Y;K՜&I;ҙFXj,lӣpD fJSzyq}̂WoWZ45iֻtH%Kv58_A!]Cȣvx.[hffx^4Xy<фg$pf,χ `e!ND"2bS><{2 >Y>#MA^Q`.٣\ڮe{~s|*1gT5\׺<lUM͟nh٘{1=֤wNS _|ZFn˫d/-ά>>6>+Łqb??)>䁵 s`?
+2pp7מ~юdڃm( уiS)<׳x?^I?
+cEX|@+|)_Qd7E?&Ivϋh&e)Zl"Z8w苶kIh:¢oMWƐ e4_m9<`6ɰudZ+ _n訫t޴jӟv56,4e7,ɾ|2{EӢE*+,1n_|(g/6enZIK/ʺڿtTj֯<^|p_A#ۮVrTZc,PPtpo|qb()8Bhz(e&|'18_h7eSimșHnv#M;
+ηe`e&2zR ё4HHjxD]Z:h{KT%- }_BZhQ$7S}
+ۃbO&3Qاq"TQLW@Cɟ>Tr&p'/w)۰?[FMDu#cGgEb?Qt,
+~T=TBd01 se)ʑO<:@/6ȫf`0* ,L_$0G?ߏD]cIeMN=c`_70>hGd/p/& ;)`X?
+樆c>r ‡_ygH?rz#aWEQ:9!~fWd׬ϼeSvúkK‚0MCIYw\jGo=|ۧ>ni.#{yQ7LDZ~.):Eܷ/?pآՏ~꒯=2?o
+ _ߙ>P>PfxP.hAq(}r7s|RPxWJ܋Uő:pQ${c_x3"FX`Q*vq5_Jeg\Id%SGt@EqQnf_eGְ5.l>2jLt1A Ң#4ʢ""1e"jtƨ=3Qknu;yյz^ս=8V c(ݴ>AjٜSmIgs&x['%wŸyz/FA4ZY\udfn/7׃wSa+
+\?O Нd>=z79HfeI̜i'{?Yԛ,kcطh.kf8iVe/Lh:gO# Vk*̞Q4m5Ǩ@QWQH0JE#T>Jk5Gi0-WO.SuZg} ގ/{ީWի |7~ycïoobPu 7 <PuDRm~&1Nw,͛VkX>e{I۲wܷٿ{7ec/'1񌐝wcmd,$a1,f~
+&q9ڜDŽʖ1\&-ka|X?9xT3lfg1 1,gfY4qEcisG<̶1kq"U֧0Uxw$0V`
+ cִ,1ff̥Lc/Ѿewf}NqU͍t6GLn
+)l\$|J4qY3i\&su[ᾌWJkuҴei_'=Π}lQVoɿ^9HӞ:I}PĮ4}vGʴuE4SUae濄{9N&>ݝtϺ4czEϨdp$TI?{*A|/9*|k),_zrS )CܦEy4(;Jicv;C qZ _U^q4'B-[ ?p
+ڦ6".2ns.rbMQrE:&oSsO}}6RV)e.`+Vp]W?Z6 dqh`(De %
+(G2N jPR/r
+FVd3@ C>I1qѩo@WQ-:v
+툡BJ͘K[^19#yLi'#ͦoSFhPL |#hY@e07|O
+E7 tx{<`tJ˛Pw/f聮\^_43z<=<vz)c,ac>~/~?CtzilzY*G6m+Ώ!őIJX<mA
+|p$XF([HrD7O Agt4rcC^w{=Y*`M)+Hmuͬ'6dA_Q̌MqK)ƗG[jQfs١/L~~geQS֥6%OFOZ<ȉzdy,3|$=qZYY4?zeF剴Fbȼ zz[M[C&ma6%w!< D^jש]WEg =! ,_풺Ua
+
+MEl%Aĥ{no]Q ("AA6E+ kUKuVkN =̙̙9'3{C G|={ 02'(shAChb4Qs'?'1H?_"GW+()ibK2_A+=HdV&z)sZa%X~#k[2@Z?>7 +%g xhsa?;nX}!@;uFX " _3}ѯ@<mVb %dUJx}˱_CP#{ y"9ߠ2h<c>YA=Zd#x~yk~
+D01k̃2Va;_FhFxpJ/amB>B-RW )9}uQjLY^P<Su<]u<;<;yO\nteY~7g^x<_%/R]9kYrzo؅{B.Xb,ߛ,-L iFEd3n<߇oӼ!Uc9rΟqGNڷN9q}0͎^|MϘltAd]~Xp.d^g>2 "/[Jf^dQ`fSF7E-ε#3}<†X^1~"z,Q6U!|gRk_!Tal>cϦ5jw%9@<5+7">9sZC!9׫لq5x53/똲)ϿY׫lf!=>vMz(Nq\^G:Ax4GP<Zi<me;;
+vgBtAvVe"jF':JsEz/3<1?~=-5bZ"mry.p`T 3+ f~}KyUq o
+>dvU"Έ>]F1cZQ5)~)^yhΟ<۽"ϕXu_طcS\ؤ#q̭V<+o<Y¸ P>%1ϲl~wƳE
+#_fG=1uZgE\qrm5}`ߨC75[|UTuN2߿E P2,:^L@?a7b7[%&"x'TM\,u )٘ѧgelD ng 4$4asoQOAuP>Ăi|0f_D o
+ D?+~m"T,2 eY
+D$Cݡ`a`~xĨh4|ʢ
+!-EMNwSx<@|[_ǒr0'%dB~
+8%4oF16H/% )8XFӑMko߶OY- ckRv)OǻXжfQn9K:򿺬/OWE*W|VrȺ/kT{dkSJNovTjNSKfIU]aqiCIա++JZ+j*}/jB  kAABH!uֲ:ٳP:b4abaPPWg3cEEtq|{_Yι{y{/uHwuϑZ~;%kْPፃ]ekv"s~;7;=w
+] v0B zA<, *9%yŴl\Ɗg9 ,JmvXG PGFdA`9/J,rpd:@R
+eYas>-CMNa<;ud}BM0(Da!E&֟Yb~!S
+sqN
+!#f|_+
+4S"=>щ.䋯r¯su!tCVB2d;_2`scxfkz3|֏Ë ~_]s]G&?0=" ,K"+%sx99xgEvMbo~8ˉ{xu[,1xijFEܫĥZNT*OWD/۩,LNP&{T."Ro$.
+ڈih١&B{Y5dQW* :H$9=[Ȍ:g=
+YlWHhP `N&]sG>ƼŜ~j=u[
+(ʗ1w,q9&_DvhCy\p>yW<>e+{>t `8E3Oba><n^10/ab {-<"_{j >r(MZV.;-YUz6bҍWj]R_<瓃 Wsڎ;~[RcrWWi|OĞT ]6;iMX-xJ 8:+42ۙ;4,oڟؠL^/
+{#IqEoA"lOYįszޔ`2dvaR( N?BG΋$7*2ǒٗD/iṪLuJMGOd8:6,8wwq<=Vo"wv8:.ܸ3>x{mh`eթw\Wǻ]=s=]c]=3|dOpck#_; }wiEK|2D:Yf"; =L$ZVcbHw_C&PnJ %OKe?g0?3Ie;%aV?2~h}H{j`tՇS
+
+fE} `FZkW%,ݡdadR햚Jc:%K_ 8on&R9r)_%$N3ux}A];W|ÓT-\f )%Gr`kd*+f/8gXn'1>CxCM5Y73-A2ֻyF!>%"2P"ThQx8 4 93tGA@+eHhb>C?z
+xD
+endstream endobj 10 0 obj <</Length 15506/Filter[/FlateDecode]>>stream
+HWko88Xt
+&1&.zg^x|
+o_a+Kabɇ"z 5ylA jGA"$ڠ'1ܔQwUy;]J>^М5 ?xn3dm!&tTbo$'y\.s1
+<-DP(/-x(%K]28oͳ$<FPLN^$eK
+"j ;@.1 SP;1lToo*|+1=˽PpBmϭ$ 4Vf?)Qr3FjEF;'e`FO/TZ, O]Da$
+qXSBj7Q;}6,b0ENnW*H}=_ J͞h\jjPT2}&BCqIFRRo{6QE(=r*BGCun/x,>tZ?O/pAxA, v'7f
+x$D 'Sĩp1M`* qd
+hB.Mtm x$Rd%=!\<mL: X^JN3\L<H*,oQV%~<Jm Al(be& _JxOv|?B
+'n͔àdR΄-NfЩ.KWP\SuN6@5P=L!t3 =N7+2L?T"DBY"?+B[r^pyz],g,2U{lV9xLAoFe Ry
+gDp:HAs'`ʌb:<Z2RT'BAm0^321U(}ȩld UqP(;%{vlW^PLE Jou!JF> mTZKR%W"$p^m[kfC$ԴlW"`pg=>_gýߡȸ4eu_9?04ٻ;6ozlG[^b5+@| =ɔ,2DTꚅws`|u^rn%w#͊xW]Mam_mupDrե0XQדPBm 5 ۾xt!sX& چntMo
+H#"e8Y4, VhBV9E3075VEew U=6V7E/F熪K!-4%%|߾n2p5fĺC7D2Zs NTsC"B|}wwK<pӖǰ>v%h/kҲڿBy"{MR'0 2\t#0=~$d[9Ni \#,D$aSp  Z%.±M6-nuـ;F/ŶB1-[>71jۆ:c
+ w4o:z=K0r}:&4l$zOh)X~EpǺja;Ҟ ,٫y #wMN<ڨp%^Eoiكu>ɲCS|>ʤк߲s P*:wsy/]G%:&N5MU*׸]n(8o@n>:0#@w,iC7;F;TN8Oζޏ0u
+6\̄mG7TS7%0Pb!0c "0M7qHoU+*ȼyZMػ`1YWm?u@5#Zq~<iUxp7eW $hLkyfX
+:S0P ᥚ=#W jtwTgzD(C rWa2,SlK$"JeyHLAHU)s~oĔ8 lħs_煶ϴ`_jLn;5|P2Wz}:f@Cbz?6dΜsIJ꒴̊Eq;4wTwX 8ͨb-Piqa3,NZ->5~y&A?}֜Ml=bLLIPSsUZF\dZOR Lؒ{ \G2?U` ߝ)ߔǠ>=Tjo~"l
+D-p.Zy[2q$K;, %,U4<-?Jչ0ӾVAqeI?Z2@(ᝅ%BKU3(m03j+1#G_Z37r+lf0ew@2AKq쭟 }W'h+D*ީ\#B10=Gyu54ζBasWKJoaۆ3QGP(b u,:x~7HK}BqccLL/- {cjj*z J1;TӘ1m.CVQŚ;,siMrFQkW\JB7O I.3?+6RHj1lJ&Z{!ۈIFF6߰dnTzr|og_
+,ܲEXbô?RZ܁l2b$N1SöaX\6V=kIv7Ѿ9R]Z╕y8Ҽg]~&YlM4)try6 JWEԜ|UM%1;Z˙wԬζ=LR!7 8\3(( ܃7b:\l/7a.=|!mx%1q Kmd8] c5vMI¼_"=Bk܈X̐I.܆C\m[&9M`G4I^}=*ӊl_zcKaWGRvIYA`ɗ7*ԡY~)7*rx#[N˯Z Zm~j
+c;`Fa;c&?7 3_ ^0̵GNՇ?YsLjCpDQPQq wc껚>h37)dz{N|"[wͺwI}st#L0rwHS|Dgk:\?KgCw0e
+#;So
+ Ж`Q3Z^D~Iןj UC=sEr 1΄fI>,K+p|Oĵ=H[mIݯI8Eoġ.P؟nIjN&<.Pl5-EN.C# 
+.MDt\m%w+:[Ma*-n-}i>;a iݙ`kZnEo<. v 1๊eV^; 2nnVKuУgqM骒&bjj^.,gꠃ.=2NPBh}}m .i`^X-h/ `[PC~x07iMʒ,.13\\C%xF`NKU[oOY)0 !ІoZm
+XG
+ q48ڻ˺vT2zHrRީZOFȚҴ%i>mQ(.5w)"85<EX!U@O
+S9y'z;hO7ȢT 7Dzfu.x#B ,p!ȌjDJ(婻
+173tq|L^z0uS,d
+w]Dq|y\FMg_u*jaGFb1j@*ZjPcoZ%Y{@t*a3ltn4vV9xb,MDႷq)_fg麦$^PLf=Iur6eB
+%. i^g#Ewq[+SF{k,d
+K(n|H:X@7=hy] MT{lo.$Z610݁4"1|k:Ts_MCGE}zuޏe\!Zv ں_MW}mоn
+K^ϕn X!>?/.b (\ *6BKo?xux(YF*E>6Sިe%ԟ~V,̧ KNߜ̢do1dQo`8_
+4 @6Zh'c(4'Y4 4?chN)-@:bsRUo^gCj>x+GbtHrOfZG \v H{n~aL-^s)B\^TyaHBUX^mA{aZр
+^ V4LCKYbsMM_Oe( Pmuv~eDž~K:AgN뒋Վ
+Nuر:9Tű jHk?#6qqXk&,&VIu%b[^Zƻѵ2W^dZ׼ 2I+6ozC%4iIxanU/k♇=^[tٗ/<\h|3Pҧ>{ ŠX ҃?BgGӺ05"Xgupz >Q@
+|`ej.&gZ׾ch* ]KHhyQFjj 5<RMuPIQ`#5BlU>X PGDgr4r.ʩG k|S`r9RbݷQyKPY_6FR$‡ h; MF8 yf t~)-̖6ij%ض8Gaqz`~[",
+ՑNkGkRDi%h
+ƿ
+WIJނ%"P+_<]6uH"Xp1A֞P'ؽoaM"߹q:2|aF2Oާ{{F lax3a1~~\o)16{zKvمg::^ <^
+_̦#L47ۋ:8iDlݞN_b4PeZ!p~Kk}#OEHq:B zt]ǭŽ3N~~S%jOک">+5wWʋ?M}>Xce>Rjnh5x[[zҚ:]dk#,f @oԣ@ _UeqKevt
+x*mNp9:͊Fv"T2UEE|Qc{bYqqw-^ؐH qC{A0 _mhc 5L~ /92i4TVտs_@c@> L֔rg@ؓ&#5P.[v9pdQ\8a>6}c'6t*"+ʼnǐO"
+(zoZi]<Iس?
+ah_A?2>kI,%IStG7|%iĕkw<n\B4  .(>(nxXC[f} 薸:V.W/fG"0vFs[e~'
+[ :`~,QC qOd [C\$n
+q043Ά3p#N7PW^x5('x3zE|C E\v H{Mx=znvLkjuWbHrPEOcב׺znV͠ 2^-׫#9@k&Q݌_Wf'7ۂ"arNǞYoyl0"Ie
+ZbQ@Ṛ}ڔZ|ъyؑP6WiW<- pJdDpYYK&iXx>s{(9)wJ_Ol (͑QVRa_~ U)TᬅL\`MkN4Yk4B'^ &Jƾz |uNWJl6>&=ih({(6fiqIiٗe?-mOࢹ62bbz
+)갅LM%Xg޹N:RJ & Ƭ'SY }Bg 33'ǾP(o8nhk7/`X̶E6h.m\9nO's8=r6d:y$7l `Aƭ<!{D'
+z0W,C',EC\Վh
+!Ɔ1AfzտJS~ͳ&)WD1A}+z-Y3Z5l#;>jNfI3vx5B UF )\W-?5" O>J$Mߓ)ҭkX^V[G#PTr;uQt& >=aFĖ4* VkЈ. ƃi>[<XciHX" ajDz֦47k4iP9Wƾ
+ttom(|Y鬝׾dctpɕSޛY=AO)hqP)`~a &e^v@n0уE? >Z.`Q5#P@pV]aDf2>74'ZLx֠ iF*!ZvVC@ nP}Op\%5D ˍqzUDB+n62toKRfXSH{<uB-a}ֶ~)lOS>fjʫIƝ0f8@Ϛ>DS1Oهq/B@I}w8ސ
+L]X'YÃSS`z
+!1J[?NyeϸG||eDnDV stnvNA"L9#SuP=cPkkEG
+XFnGȉc2ۭ!\s
+q7lfC nE:Gr#<!(E
+h BL3~nm ~r>J,7٧wdmXJ(sck<'+@nAi[([W/gN8\1#qzz0Go Yʉ
+a$; Ɍ9Xvuo
+X劉 5yOMn m*T7mJ?9n>1T]m3J0.2 P O7&z5]jo>sj[Tu9v#kļ j/٩\Zl|5_5V h=t>nOArvRHRȕZ|ة,ښ{8@e8%h)˲gA!hmP4F^6 @{*O´V}8k M9Ff$b%i`CpU$2XH|!eqK ,nC uȾ i d8`*ye Jκ2dɉ)[1"obʃَ8\W6\/I<t*A-QXJKĮzS|3É?óYSe {HB'U/
+endstream endobj 23 0 obj <</Length 56300/Filter[/FlateDecode]>>stream
+H$yTWǿ@
+
+$a [!aǵE=S2 (@P@-MPZOm=KcGx|]}-^ѸApT_)Q
+F9J al%opoq2=
+&9GDEwhDҪ Iɬ]VqNĿtQZxR)sTscf3<Z~<Mt6'}|a)q*UE
+|FJ
+dġPBʈVL
+}nz"qn.1o !-Aĺ-XSu$q闑]1du^J q,&H=N" Q/2<ՑWAdyUY~)^'E7F~gYIs^9##z$d+iuR⬊"5[Ao"vp½FhMM#C:IDNRN\volwMσ9Z_aXhWN/]ҋ_wp&V<v&o6vs݆T\@j@
+ jv.{;O^^{o96u{s2PMUM#y!8tZF \ ;!5[z c TFV)Yłل2żY-m-zی_>e=)ֻ2mΫ<eޣ<qamb.m'[gg"'کh7'iVTe9amK&Gi"YSD֜I rZGjق+}cq[nyaO-sďr(7N`FI{6GxWƽϓq'"YeBYXܐ9O 3wyk jm 7>bWOծo#{~}caߛ=ݹ(ivwor2y=7qeqL;L<;?\KzZs^~ W6+fcFjt~ម&N n7p\㠫WudXR4%a'LIuD|>jslj2F@%De7oDenkmr uH,l w}Jyl{JqdvJN{[a_d6|kD7^ k#h@Am tt Bh!tHh\m@z@ )vF
+ AҷQz0Bֈ^.vFЎC^ nj= 5p' zyZ;
+^.zrI hݖ~ bpFȈ v=wڛN§llkNk+ԁ΃_z }!2x7h !}`~# /`hF錍n n|v3CgCU}eKs} 5=GN7<;W_>?P՝.+Ե]Pjj/ vUtTwwWuWԨs+۔C-_N66}5дoRU_6_k0_ޗU!x .'m8E}[&\=^Wa<87D]"R2 f`a=&Qb,K"JQ=Qգ@1ztv߽w?G7](ߏ"A P,U4Uޟ.
+}b9ٰ)" b] 9fk DBUNPZO)~E9)(̈́ 7KHH;v}ͪCXZn|{J~ڥp;B&0A;mB~#dBGdlp;u$8 ؠ3 &j(~. lPJDDEM7y:~59h2ÆHh"y nIGߏI;̰1?zPΝ}G\"I\z"%ȋC4@6x[[!\\Ss{q~'9FEr@ߑD<C[qch9K(!6cD==oBiH14r_ݾd}%g\
+ɷCϥ{U/{{UCHw'ܕlfR `|I ֙/̂/θ .$.qYxU'/:y=W
+CD7+zl3}v+^%?$\srzfſ,Z'ZLޓ9%s<~`{Ҩ e^W-QEq/,8xι9<9VpnH<$q>iT1<L^k95ɫu«8Dέ |ސ94$r.|A5wo﷩8茂hŻ9:\?RM=?U>
+n6s-`V ȫ%{gw(.:zK73\A-~5V=ƩfK<˦q:|#>",txlˬxQ20QJa@Lxlh~}erϽJ1\y. 09Kx&jW-
+SB;aM6pnY3֤FT4SD=ΈB%;
+o2 >,K`3
+v]E0'&|EO7k+~Ukݖꆢ:˾=ywnSKs2ʶK3+h}+lߖUj/Z[ѳzϷVs?|Ք}3uV Un_<3N/nDv]J,L j <g'd[iYx=`Hs_ߘ#L+WVҍIy?93gRR[J%C{L/oǏ%قlHY?(YB )Zf<O. L.\QMi~%(D k ! =,8:{Z;8NuE*őM9..Q6Y\PPiVGEP2nb{ͷP"X:sN#}oiZ#(#fuӴ v4 .9 n_ MPB ^/
+>rx&A&?I7xX A1U`s"lm`i,9#XlkGw;Qd3\
+hQOia4.&LG(D&{oR\ DRpae:IF9ԳL禘2MJy^{LI}FR
+>NM܉w6!7.wwb-Nqp鸏~U`B'Y(8/<h1 yQZ
+N}?0?O<%}wp(^چ[Κu[,``6gGp=f$I(܎8Ԓ2g6yU~;wu+^3yykI\o9;iR_).P[_m&,a#p@TtS\rS\2 /* *.n=vCɎ!2/]ƷR_}6"ۖZV~Q77% w6$.{ǂ9miGk
+ûQYEF9K#-ɏ\w c8JJ~tfƧ9Qߒ:scFv,q?obyt.fnDر)Q5e2n0FƷ>.W8(e{
+i[EsӔf3^<uZxɵx>xK`l gKkW(3e bT֎ukUɔ1Q{"ؗi5zKܵS8kp
+rVUYx'(
+O%=G&'9rx(_p hYZbNƟ&^U8䏸T#Ww6%we1COC3$CKgp
+LS| *\a=ۅ-nqΊ ]-EۓEwR|Z!w
+)[@+~%Sd|n~܌s399Ws% GE8s$NətZn
+u+mGw"72rI հ%igr'^-pj 5ϭ
+D-K P$@@l"OӪV+U[7XYDUD;AYi--+*.OLwe&w=s-"
+Ru;
+ &(&(\v
+荄<$
+C"XS8
+<ˀ00F50տO>kxw/dpY3+oV| [fgnn5ÚfAfCj
+ħ7TsϫScS9Z<}jӰm)~U"JSSOy{^9|5=˒{GcǦmj9x8OgOK䷒: V%_Ec/Xn]c~<k)̮3+cbm DBF2~^"ûY~_C}x`VYU
+JF;ܪ)# (w^윔I)S[5Ll͘tՕߛ20ԡt)ҧѧ0 Dkt]գ%Ɔ((.h h
+)1C*񧄒`Ҕ3#^>:Ƙ\HsӘeRRrxLP
+FxH-veBclЁ%gJ^
+,X~u{V`ypC_6o/l 7{&Pӥq|ț0ۖxc,yЄjrbh"j8 /[$x@
+<@Зb΀#o?/x?(8M8~cP 1'#)x/} cyw|lE<]V67哵MVsB¬vY3$]` 78_S~sߟv;T=b+oE޳ȏkCm]).;օ6Ed}VEVE'{eg#.nFܶp׏8o ;ю:edKSۍ^ nZE
+er-Պ;kdfGoRmS9ߩdf#&#M~|CvC6>Ni@Sձ>s_ nR6VX:`Ml\Vsyі#W 'x@6PF]`C*`)Up
+D ;ÑX퓾}>:̩cgWE%5HBK%ҵo+>1-0|bXA EߜOOgVal9r/eԙsM-d3   !!ԺXl>m]jZe1
+SP\pEALQ (U;!s>rorw{Oh թ^CҤO;&w)S\U~wE0B]zvX<ZΥ'!A}G{cEq3^qr0'0@:=w,T̘g4zoFӦ}h*޻쓽31kCH+,z~#wXr[tZy*^3N6`;~Sn⿎90(竊ەEnC쳐nje@ <Ld$rGTA9jSXj:bYP-2gjUx5j}]&>
+b!6!,cm׆g׳j Y ( k1B3(nsـ $ Eaz"z ;<y%at'nc^݉u!(s 89iD4
+UUqFY[dW/b6ف5B" _u3
+cs1{z'R^)< dʛfp IlPvjriiڝ`qGa j.sog[H7AC?}i'DwsAO"{d /H*JQ ?I(X$?_I(餚u/LeeYa\Œ h1hdz)zIdN#0Lf|x3Jn X^5 Km}4sf_ V Hz;J4Wgfbyn9ƞozϷn5|U}qyiOPUs@kcګmmGiޯhkC/Rq*wTiW]::3hXzg{=
+k^FM.uִ%)znudAzwD0W9G'TD&C<m3,~kwIv- Xp( [,[
+ 6T';ZI^ BJฎ
+F?<zas0f/)8nȦHoNqݞQ=1ǝ!;wp~ON|a[, }l_oZ @,17Gdm?uĝ  B*(
+HDB \#ŮV[e=
+6M2)N[ےIE5fLGԪ>Tʦh.x
+8j^]<$<qgm]ǛW=p>bq"1uqw#As$"ܦ^:LX5χQ59T0Xhqli)ӔΧg(e6
+mNBiTHu:ŮHΫ(YbwZAy_FyaN޻IxV&Z*t3O#~\&~\&eJ99%^<5jbaIW7jgi{))FmkՙW_m̒L@S)O|MRw2'6yIS A9"@@n4r,
+l
+_XIG錫&rP& )3G80vkDP/+ؕĪ!3\kn&sZ/:jv-&vYmKd-y@3<[ZO4>.VM/2dLJ2P5L/&"Yɘ ydIs
+y}wl EOL/v*b~±(}AМ\--Q1VlU^[+.dR%;Y?9!j<@ވnb I  &?@tz z7 MdN~FdA
+)w\A7%uR@
+#Ӂvgw8¾e G\ =˄7qq=+id=ؤn_fU<S^;б΅ڣͧ ]vMWjmWO]Qq[CUAC͚#7kG պo{KUpCGE){ڋnV^S(z"i, l&^ D B0Ƨ &H1"ʌ?eb)wxз
+G+(T˦EVpa9
+Tys_}{}w <;
+mHThcVRqJ5Q@ UԨ lTG,1z6n@jji/- =\0+MzaO暆=1L+ϥ=g(5TS܅9e );|b'KZM`L!&<H˃{ y^>hΈ
+ϣ0q GɀaF;sJw>Ѹ[n½_F3:<Pp+I&EmUo4omhSjؖESCUӑIWB;fwH96`(zl̜vb̼@9nzo;%;Ox{Bc["kw/,sW3g 2)*7 , `]\y oWշ7jYliDKO'Ʌď6s 6G{k
+oCL ăvE$R@{o$\YڛKsID׳ĝ . !݄~oDgFv-qPܩ!.hnn
+Bu QT76hn@΀+&p#}`}$69({o_vb}"5}ɶ{JXv߯~;܇=@R Qx ]xeiEƐ}I)y@׆t-<fZ 3\8˅KlHk Cƨ S7M%*b^dB^mrkYO;X)n~H5mORÎ3C5f* 2>;bg-!% !.,
+@S *g)+fRBR"dJvĝn]nDӊ~>%Fǘ "t$q͈ϛ9]б{ @7OG0Y=D @WV ba aȓJJ޷hJ M/-=8yT-{}^%*H"%<f'{=wc#uU5}ʾ^Kt:V7|Nr{SΥSګ}}᳋]-;Tvl+///:qLU[CKƦw-ٶ]'zW΋:/@6Y&
+~XgiG2f|e/dc+H
+/[֧<C׮Io+fLq=e}%'x"qp4UeSI^Q(/{a_6eR(ŴHd^QE%!wEJovAzw7IAX#ge2Cβ2BzU>LP~qߘ%ܴD60)$UC{sKVtg}zSIPo$Cf0d l$Lz2ETCHl_}5:oS :'n}1
+mN"^C|~c j\AMY$-Duev-Ib;n[6sO\r:ܵ9{󻤼OjD9&w|u)Niz_KS./+Ks*BF_a63DYܒFXoFgc0'\KC~4.
+?D9iqQaI7%sz IIAM᷸G#ZĽq@wd$JG 5 儒8ԪSx.]|&^:ñ@˅0~ 92݋aALУ/jR(Dڲ,:lT(hbU&_ ~i'x]?wo7Ư^IE4l Wz0Ox~_vVVz˒v:ǿ%5.m^<R6u {۾i|+|k\
+5/z|{$~u-'b4p:׈xb|)qŴmYEqSҘiWv'b^;}cϬҰ)q͢a ~zѨ^l=I
+wӦ}<ue :o[p-ŹZ\!r 'ݍWsGBl,3!@Ā!(F |
+F}M؆pFC9_ы쏡> c N[Pt؀"A
+rw\'({ g)Dχf5ߵarʞf]͆yRٯsQ"q=θ{r{Ş7&ѧN|{B{/#Ӵ-;j6n~}]*說uvOGM EՍŷ-6\l>WyfUe7ʛo4JUN)i*ڱlaܺ,ݛh;R;`E7/DP??DN:z^5Y1zlNXG9rsu=⚼ <s@: Ұ9?l\lq+r."ςt<<2s+`YhO^
+jvv4ZFP ڝW?wlz1xv)_I"5yUCmFE
+>Fq/dž:'S5n%dͩ$VGO*_d[D9>!]` gߗp*Z}$+wp}[]Mܖ 3AX -S[c}8~Щ(it^g N+y.&4?_$ T&!@
+=DHFWޢxJ:a&^GWȺ6Vߒo+_}yRs;7]l:T{jSmٟv5ß. oz[?g ^
+ݾ/
+p,NC.7G
+=@x 5_ЏLc~7H_.`-Wrnw?%_]xcg->i#|7ҲUշU=ς!y
+AP'T u01Gu-DߓBMQ R c@H
+.,T`@cMd^)f2ól. !wX~ k  UU>n<&'3kMߢdx䌄3x&
+9_|+zӃa'?(_.|^.嗋F;* CqO{c~u>^C*+DfzyB7]*of-ԱSf3{}yw23Gy!I_Dbz$@""7pBؙGg{~Kg8C7ڞMBhg
+ *PE(.SGmU\|ZޜLw{yo-g23~¸dSt19_ݏ޺w>E>IENY?
+wy7;u~uaQ/m,(|=;Tʮ*ñXڹ=a{ cnԢ$f2?zF=;z<cdoA=*$:Xb~ b w{.yaG9a=21Wq^Uڣ4(Vqݳ]V[op6BC9!mA !\3j:O<Dp
+9yxnȪP>a[zo铹)/e/|W7?~˞Z.'p{ߢ~oM:!^ܚL7'Ѿ$ڧ)a|Ȩjh=3Ȭ195.eq-=ϓ
+ ^g!+.^"rA!7aͪ " 7ol+w_]FT:k6ET#@1<†!6(GHHFa0Ăa
+ ЏF@>P]e\l#,髾i.GczB외
+$ڗgMgO3_լ ~LGW9*}HMtH}&R<YAi崤i`BVN=L{W$v/QRұh ^3}1(<-NZW!R8«MԈnޱm]6F}:@~Kl">{?Ftbr_5};v'r-?uԝ$$DDQPd$@%9ZmkEt\Zb
+VEP/ (B #:cQju)=彗޹W`IEy'v&#: hH@2 ܡ%kӫ4xlQЪ4
+gjgmL'a훈kf41B_M#1C)Dr- %yi*ӓ@|ėw9x_F(>YލYiݜH d%q_O&~CHg
+Z:kd˵8f8^cFkђ
+sQ[Dg㡿͡\ŷOG~d{O{33<{62ݫ !խ
+7G߭z9iR1"bs tNAu2£@%"m=.bqkaw(!:D{!vDg)yc K,<ƾPΥHsiq+*PC"m7gp c~w#ڰؾ++6mWAop&f{6'ԏҼp-HrKv]gdrM޹}A RN/N1hS/Uq tĭIA\cȒ:9Wb.#|:Ur9YR*3:_N9I^.,gup03{laX.Xel_<n>pX炫s9ldljzN1lrH6;7h7[iJ<ȖFoŅ3DA2F )PU7h߱pJlG
+`,.,mئɥk3 |)5}.MgxP oq@Kf ^@
+#͛5K\W
+#xxO\QM][ޙ"(s cH GD*bkU*Kq@@eR AdQRb>j}Xk}}Cs͹wﬕ}x35{1Wxw1x'^_lq/
+qa~*W//ծ;Y,Yu)X_XG7;v^pp_pJ/$WFRKc3#SCO=TOWTϩPPEz:]GYC: ?ugge wٻC:q¿w:IYYyĤٹ5A| po"__O|UiS}S4%wVpRM;oLlXbW$WדA4i?BBFRI$$x+ '烔 S߃އuX|SH4QzN:8]{ Seql6\)?M$X&R{R{T^O(oB/kD/|kpQ&C>?WAQ<ߝN#l&1;Hf=2~f53=o&G7K/cV]9S=ۧS:6hMp5_CoxS&)O#^Wħ_Ogѕ@UZco@|TOjĪ"X2?fqW/θ{Wvcv83aa%ԁJe@\
++î`GzWRt%Dڟ",i'K44"֣0udwU?9W$-= Bb~x&!h> ʡ`M7G6mv?";˺kmdUd$O}_w^;teک66 jڮ0v3Nz=d~Gq1dpSŬTܪ,ŪIS:p(J=wG9(uVy^/B0$qdec4YE7Q}
+ʑ`ބ}EDG{aBLVL 3f*43C)8-JҞ_(S',{#(9;YpF8aJW.}aiWn7u C S0I8b7pNOcjPCv!DǠ7!•g
+ܗֽ^!.E[M<-
+˂0L}&DޣA8zQߡQ=ehǡ7 r<<7ƌ!cT`[kW^p֪}73hXB:xQjdNwcpVp'7@$>(ZA4GF`hِ0l
+;zf")/SU)]a ➂B~0=>
+dw$ׇ H\6dK!7-bڛb_DΗubbQ蟉uP K%<az;8< L
+g0_)}>8;uEMƜX/
+YBsX̊%ݶŬq13ZȲ.k[2Rw/b%mKXIdķElv<?u8Zxd<ZX*SImGmQܿMPE6,.~C>xPp ]/{ }ZE;HҜP[3Gx\I/q_˃F,™Y읃jژ&5ig#Xk{\Rfճ9_<&(lRJq4.I+(}<? ϣ$wswꤗuɯ&.yKn\+0?>k\pa`(<g?o]- V*-> j}5Ɇ+Qc߮av*r*
+o/|詢ud |4S{Us5|72*֥1' MC"K s;_ctDi}LVpcfLPJ**%B+.m̽d(bpUntu7`8C}-ITrHEvXRtfucqlC]4i`OJ| jy6y X 4PDc$D^c14 EmKԼ xEbV3%;yȆXS5Q C(tȊSC'7gE>GM:WP8?䄘Tbif6 ̯[uG5lρ 9^qoÖ\h?ZӸu͙+p{օԒ3w(;k'-p#,4?C#GfZnI9'Ƙ_/ssO8g4aG{1.I0!Ц9Y-.8B69t-"J:.8H|xJ }93Pwߓ҇=p;!kX˂=+>=~gIx}p*~jiϊG]1i'=6`ZTSjq`lߑ%Nɥq%-gS(וt i|p.WNE(圜/L#5 /ӞTrleS
+?D~fV<M$ ֆ`9(z#X
+ݐ`n $x0~ %<qo=sOq5o{jKgq5'h{7. o23h2Owm/>Hka95Z7MU㨿nDaYdԶ
+ ƞ#X &Pk'j6/r\Ұ>X3P#i^;UaN
+RĤLLd:'2RńS9Wbvʕ̖>g+]|Y VE2̂G~f?W
+fٿ3t [0)ghΰ`+H/ ^gXqNk3:06rMgߌ|µv%Y5yp|Ոyp9w5eP77Ӆg@XÖ♴us^ӈ\p }
+ӗĂzSYi8w[م"zRXw ߷%Z,ob'#j&'6؞ ,'mrulE'Q2wdV0̷1Q3/ԆfK07$ed&-Vq<7a3 Y ~=+Ōϴ|m?. }y,Th@数1#/,Pl%}`z6v;]6}&8*ش"_L9ϞOǍm2?(ʰm寵9mv?HQ=}~JH}/B]Ҳ&UV0|vJrf <|(C2O\8)$*^TI)^۲dDyg ?Crhݩ^t 7~_EYĽHx\ʵ4[.\;;Wσ~pޛD'y|ljV$b /ڛf!¬yu
+6O6됇ꂙYm ]όOʖO:rz=~/\*#OVZaO鶗x3nm>*>'˜<</u֎=[yﳶ(g[yuOɷkytftؿ7YmCC?Ǿ叞m{M@܎snpV
+apT(^s6kcC(+a7wKDJ[%ry!"ZrE=y:tZ:>6VcCr AxUDA9ɵGHS(
+|zGoՅ<@9& $!JJJZ|SL)7 g|>eK;w7ϼT]9T[`6E+A=
+ԯB^#Dbž5kGyl=a偩"}U@ wtI%&/>LypH=n0ƌ3)9(d~xpi.4IAþ'a
+a OAvˑS;]07ڃ"iu6gU@dD^[Ǩ!
+#[[Q}w^QwBWʖlNS0gEspt
+Ժ6:?9dH/1r
+Ul[{cqv)+D/ͮ<fں,ey;ˊiKqcfk"YU eQ)xj.?aVd,]9iPrj堧F1q7aRʴ6W:ދW XH#^YJ#~YYeESžuha+bbR<<E
+}b"p+Iu w 4|ސOxW~n2۽YʛV~$-$\Cx$X҆>By}Y?d5iS#&dZi
+4t_y+qF?v5Bk7
+>Y:覗^6^^?8oH뗩)DxQDkVz ׂ*e!2T8gv"viQoF>I]2N}4
+pmK8iܥ[4|ow](y}¹s+^DJUqٖ- zLL!bX˚+0#'ޡ
+kFf)k3
+gNBxCؽ?87@`%%`$\3}O 4[ 8m<+飈
+t?cDz)5یI_FLHr2f;YB/6Se~﾿Ѯ;Y] +4jz# ,9NW Qʜ\FIG8m_ /eN
+Ѿ̹r/KDyaJR`
+-4x6:z:
+LSӆyKY%Mu[.a-,AW]WGX ~1'onz'+UIY\Y5H٪Q Դtv;U ;o.L+/ԥ|3;kt`ꐮmUlǸS7yz걞Ouç.]3sM =6=.qo}#]D(Mp0y?B#B
+(/4~sهb>EU$E|iC3&gMʕ
+eN~(WqPY7]֢? :7L{#Q-g
+҆L:#|a "DއH(}o(
+a
+?G$"6.ƍH1|@2v(9_y\)@Mo|rCrpr3'~6'2#2c{b|pwpK\z
+
+HWu,el+˼V
+uUTPre,Sk5,vWJܺ%(RP2x~Ϸ,*b%ѝEG* Yh{Boug_bslb^lU |&G FAͩ6$94^EYԄlz'QxhM!*[AN2@)`sb|DbO(RFV**QkڻGC^E1{mily;ֺlHcM̥Ni%!‹`V^r| I=I'*]q {'#MkLº!aޮUqp>Z^7tspB}<<P?`_Wk[/ʄ*^mu+Y; 0%ص_6k| Ɂc)ӥdƭkG> j+ba-,R^5;~9Q,ςGX]åO|Y]PSףsL06YEe("fu}bR)11Tqh]XaXAew%bsbS=imKL9sߛ޽wxXʓf69\eUlEU 1KY9<!7+~iq(ZiL6~/*~#:o'-T̑{Mkj!Os ǞWW|]^qˏ*>C*P<u,{fy8eCKw4r ]BthcB;4W C]boh zo( ψDV(
+uzj @1x[23lb>GκgIΌ7E4" ~JPRd i)y"5=LkM( NR"桄rϞl·[~$ٿN\ )w֐JG|t;SzJEo5u]<'3L<GL(9. ˧^!Si%GR59~ko w9x yVl6"D@
+ƨfJCg?T<3r*hѺ1;KXjC3niAC9 I%1E5q?hOW?T`Mgow{ՁImץɞkݗ&vʹjNU>u>9jWr{-sHص;>VxwjD_iLG͉+9zk/vhj:*kjW4]8Z}aסgYS]o&ޔRZMHl-ǼH>cuw
+w~ Xn5\Su5d1GR=S褾8rg
+r!G05߆6
+^FZ;a{uzl)Ʉd&$o1-)o),I]>lt9!cNcnS+H6kFAЈ9أ?}Q"N\g-ylj|p] ysĽbs9m cD[>3$$dD (+
+ʐ("lVhf Ga81hQ"! V~Ek)ļP`wq>wi B"!9
+htC~yJhT `6@5ݠIt vPY! K؁'sCB[a5_g_Wle\cEa_GN8c|
+ [n;i1o@k\ b }[FYDaX|[|+2W=m9V|~g[3sEZ=Pg9̛3Si7sՒμ%soǴ18Ҏ-s\]2sץ07^Iy'u₤A9IfPy1\AMu+B/ :M_Ժ9鲦A?X҄m~9浣:nA?G^ NMWrI}mX`w xE%N`Yv4 ,_}-f.lHy_ҳ?fst2.72G<R7j0~D.(`,r(*mDil(^Q޼\ߧ`xu*ڶdp\ kH;aSؚ*σ(+y 3ߑ,<nfa6(xE,r7ۆ*/b9v!  4׍bW̒v3e.ٿn ʞj]i_
+}(.{$>!sND,Mxm]8mW<Ԉ\ՒV͛Y}`:U`KK]CQ泅/f{4Nd2hfY13̤2U2r)1,bx(9Eᯌ
+^I~EWZL,kQgZXhݶ:w}ls{ Jqu'?uiqU>X]qYN h#[weJ'Dsզoی: ?\p
+xF^#ِH11ŌH1)?"C}m@ʹ>&'BJh
+y^9{jr>9jR''7J\F (yMAG#ӆQ3s9G F#џrFpDkgJt{ɗ*hմ`ibvޣ -^ׯA"TR43ßYV>1 zgf /'%Q*fT λ3Կ=,;8^~Jjgugn͋ꓧ/n(iwHWETa}GVaTڧ;cnOU O|l.>pxBvd`k˝UUmgUegT-]gʛJ<)<Sx(/yPb
+w`dPcؠ#5v=hw˚"4V`;k[n1EЊrYOQZ#v.2~uyG^uP$CVmNQ1hBQQ [1 |͂j(ސB[ (D%n1>sv5쀼Kk?"Bn i7
+eXՔ|y3?295'j#gT4 ̍!uU:s3ڶYJJ;7?wyjW;G=q^c KesX(_7:!ܺs_Z6J){cvűM1:գ_:ط屰.z#lb1L>ZYx gC9,b`= ԀܟR砜Le>hZ<y̭Qx{LB70M.Pһ3@&}5c{+P/ל%1Ӻd3K;P;NNp
+- `
+-;/8`5H'4 q2L՘$K2n;y~w߽7z.'aΒGInd>s%aPq!O,ES^;%Q8}6.Z<(qxU1mPL/mb<|^ |qmujH^UAQvc[DqV(qQ Rw kdv+)7sl|g~'~š]E;"iϽgK+8su͌5W{W :4۵hd;is)_}_pWtd]Z9q}X;m̸@ NGa,|sIkN%/MͱO=s<㊬)۬& ͌} #r$#~ů^3ʒ1a_d{YLq7[6s)S\l#N5w>NQ39[4O'6f|y2_qYv_{N}Q2_zv ~ir0IzJݼO>-6J<)nK[sbZԍR
+#j{vHC@B mHt<2FG'G<tM0  E Ъp_L7f U`Հ6\FMVjK<;4ɷ[R
+wfpƑ3i,<݋.)ZYZQVy|]MS}mCS{mVeC g>.Оs޶}kv+%-c'v&ޕ<yc7GK\kP祼잆G}^^X\RpJ[ִ%:}XsXL3淥=.%o&a)]Mip!=ϐfo.9-
+cՙ|m'kv멲ѐ{%Аd
+#1*&rEn^G k]1!jd{M߼'*9 1W?5N#Bl}X %֓|RcY~: 1Iw
+{uCh "*'8`g/筀Fbv[``e|rĽˡז﹟k)-~6xXE;^|Nu4X@xh9͂saBd.#9j,܏a lw/Fp9[
+i
+P>8 /D-³wt|:<x܂mi)B\[-/4ߥ 83@t\QskrY95۹ ܲ _EXssVp\LJzY:e"'My2*[Ƚou1ֆ1363vu33*߭^^xQʣ<'
+fU~1{fZƤny5/%U/$5(z&){=Ye|
+5'˜ŹwK8RsoIb^]̣?mlV4sD7kqo}րWvpD1H{
+4(`_E1Z(v%J0& gk)tBџ5ټ5[c3boyNN͂Qu!ɭPqg C 﨟p{Y,NѲ,/d535J?y|Q#'gyCgOmDnE;\NWԲv{D]4-x*>w4_jxߴrz_J`ia#ƹaLF*L!y̩8aܾ89$+d%ܚvfF¿L6__Ǿ5ʌp[ا)a
+
+
+=K> ȑ0EL3l19w/4Es3NחLo[WͼO^LcQұ|h1Ү]>q߇ќ#?dzմ;Z6}LI~0_YH^r^ {n7џfOYnFOr,t0tdvXSzCmSDB1WZ
+.rM*UKI!/V{oݽ̌[#/jQ耚O_,y_@O!`
+7]^{
+:΢1R+eR_ƴq'^dDVLxܙiT&2C/_<x|Oɺƶz>W VWW_9S]stٺoמMlkOss dVވI=hUͻW>Ȉ4m{Vd6˾ؖy@]C=[Wt;}Cu5Zz7Ks'B+`Ѝ悷-h] Z>dN5E]}fPЭYFx;LI։_#1>Î-ܛ)_ wN%Y)Tun@kӱt%ޜF~=˱_| I٪cN=3lP|o79x o=( >!7 `~l|\ꛒwpľu| $;Ω[|yxB=?Cp
+V{Uq2k#d8gW\Q]EU}y4ع yAp[U!wwQ\#rU#֮Z\K̿{Aȯ y5ۑw1PiD
+F˄CB/
+OXN;*ͫkUb
+¦TW,K#elyRm"RΦuQl cNu<̱!Za:>&|tn]Odl׸Q9%#+WM
+dJoKdKٲI8/JeIélְ wNwM,?!iSu߯٢^h:GsFEuakhAEDQ@6dYq\@ Έ
+(֍QeԣI4'{{֭{w'*}X;@{Xz! Je~35ܡ)eN]2#G?HyusVIs9lf33)g86Mlϡ=2ͨ|oqg sW\yx= Cw݉1uP=i̿іksk)[U& ><SG]8_qiJӐ>~4EKZ7H`_+{kw@zzWVe/JMިf{~< eyNf`M>rϫeV&1 ͮzS8큠` ZiKKL){yJ7=?NrRI?K̺i
+&=:W4Rжi[޶ֶwyְ`M*}4iB9m 1,7Z* o!X?{'FA~΍:Z[HW.b٭AQ?3P27.2BΏا(K5;.=#(yS4y,D'?CM|'u}OD&٩q
+|OKt}v!ũŴ@=Nw~S P!:<,
+pצ|p:% YSu[tU?I^La6dVN
+,- \ >KyY,dsjfVGq7wT37&>:0Q/3nYJ]_Ys{*߯:xɾG(8Y7qS5uJZ׬o;+kP%o8Uv֌Ue]^~{7+]7Э޻tg3E[:{w4\\׊%U}+JU9}q-3gѕSҮ$J."ͦA8P (ϙb)Eb^9G)aM(<?ŀ)qE39⒫;o25 \7F=^E_W;(00u-~:=GZBQݓq9]5(@H`XQw"`>XΨY'P{6uX[.XKyXX8.E=wmX\K> 넢f9!H?/\}F]cmʱ&YڗKk.鉄/#=#ܰ7j}1hMZw\\B8!Gn=Ǻ7jx<Ɯm)՝S3)ş4 v0Ho1l/( P@:/GMuǵLӡ<4 w`2"$Ժ 2hmǸi)>?7 v4v0<rLou6l8(aNGsñ30'1'% u7
+*`AFZj],=- mQt6fE6&Fn^AB)-xy/41F#`l7Xyyre;(FJlۭcdb\\ƐfFxvL[O;+mdE<B>#-adVԋwJ>r,ޝr|nf1͕":{EgheV;YEU AwC8d+|ݞywA
+k7b a%>"g7
+Au /
+qa]0.o,ʣL䘅n5;fxNAҨϝ Q?ޝW*-䌾
+cZ-2E@/r Q؏*%~ǜƬ)WM/@AN3$ kxc?ZK3ݚsIfMm@ZdOJQ0{с;k>Yؠzf/ccZx2OLoć,SpzZ<kwg|Cq3gx>uUG5c9SFԢqg&89g_=_?'MAlCZ㫘:[q7Az ?Ӣ
+DmbeeK
+"2|+5F}/
+endstream endobj 11 0 obj <</Length 28000/Filter[/FlateDecode]>>stream
+HWkW~׺?WxtFTp$2##<tG˥vUj=_B7S}-&\vU|%W_H=}S:Uܴ>ZUV[z7rGuZ˿15yL){
+pS<U
+iֆ~P/<K.q"bR߳ Y{re[٠_E?+pc}P(h7QѭHiL F\na=j',jLv$J)bsr\'A{ eiI " 7a"i<TuӱvLɖHFi\ɕʊ0e&ubJ1cnx%p.Tia*Vn;P8YL#һAcdjoM@1 8l
+*ZLЍd}i;̰ j.@CH)TN[7dm05eh!:
+%!s3yFN_m_/35toLi=A ɳR~hwG'yĜ+{
+_u hY[n0R1be2
+X +
+^f{\7d$WNOL b|pr2e7tV E$ ª-&N&."B7lk&Ljc80'}</;CSx
+$(dhVDV<CnlkeL93F$ O6BS% ?F j?>Km(p@kj.2c6xd;6Tqi0uf!{"&B3Ip>jC Z+ό뽧fQ4Ϩ:Yf_d4t*j#n8yXKF!QŹ ̕{ɋ#do?yo.T?z8Ah?Z)EfG+f?sM)B7![n6i#ګ Wb5#!?Ь1M7΃t}U9mߜG@(垸)`8w?XD6|c[žx:ܙ/N-{2<|B9:X܄1YK3D\k|C=çvնrs8Ek2kFmթeaYVk;Z#J?a/0Z#9d9<k Gdh4Wi&)6)jJ3ă 4hO`M1y`wܞ9'|ۓ1`w1J1B<`BL1sGňs"GLA#炻`KZ _#@ 8k]zs7yi!1kS,dXֺ$+/)6J=s~F wE1uA;Мin#~mB9994몒omi7G{m}urۮr뵼!QOJߵsVl3v;?pܬqxryjr'd{$_O^峿o:ApǯydILhz] ^<ky[Ѽ7I,qogJKz}
+b^%)z]oyJGSүu{Rr44{Iz}^K1+@]E^1[h.oo^37&~L ϱ(MX^{+cGOf1"eߝ1iZd)5 EA ٧
+"xPw5rCd@/pC _8TrtT <h|kZN ~ i0}Ϸ.͈ ѕ[х1ʮ\r0KSǍλtCna
+hg=eф)^5t1;:#r^-@`QȷV8(h@S
+Z񠠕ܘ,S~وͷO9n+C\!cJf8OhA6PY6n oDm5X5&ֆmZ#MA5
+ D 46nΊi@'bfnrU `h<
+ˬ23?֫-y
+"ЖB7ײȎ + P$J&e3gΤiL$hD݉s g :Ϡ TQ` X#heΊA~CqQ;RksuBjliM̏~ԃ16LhL!i6
+Z\n~[6xn;j)BQOh"_΍X
+QfjBj6_~Vû}<5453.7O2l+kY>U2*?e:P
+gj5PFⰲ%/2E^@i 5s 4+ؠk[nݭcXP 9
+,FMӮY'e zč_s
+ՋHu6!C4 P]Bslf`TGr+PHlllOΩ^͹m9Ņ^(bZ̦6y5vȠ;T/0"wz _<\qbմ=[`QdZ! ZljwXHͷUxcdIP#H8kQU !C>.yz80e_IiqF(Dȹ/ݻ{V_X`Hܮjմ.hc,maW}o/;%~NJ45slnZeO"e9&\Ŗ==ͻLSɽ{SC*r*"|ϥ:!fk~JE>O"_6R|\&o >/0/to'rʳ8)Njn&,'a1S+&2H&]y KOk-ˎzh9iF9u\)y=~ڥ
+9m V6hAq!p[~n0ŃXgHhO_l.^FSp,kFx$R$X&݊B/惡o_f\ Ji0V;O6h8*Fݏoʍ*fLAoizC{|s,RR,^bqL+'}}8<
+ނ^2`$H
+A5!P<+iK!=_[͓R*
+#+hZ/}݃0x,} Fs ^oeP%2a$v֧BZP"hh4wem\QNld%2T',hڢo3`"J;)UeϪ)E])7]eހeOJ1&\j @w
+=RIhƕVFw@f$5jF[A!}"O;/\ahjޞ!x~t)D0ٙ
+`ot@ ;*;+Xc|!4
+Ė+(d32i
+ŏ"ty8ϐ25cS_eF9~WΨeaƊ1_yl
+*|ܫ눮q
+*,*@zK)Sq]vP0UOtݚDf?|2q٧B->
+ۉ-Q `
+լ?'\̠ݦ-hޖb=nţt}>*ezFG|oO47LR'Uf pp[b3Z(n aSB @mr4p\!jOk)`
+\x E",ut{=!GݭFaU~4}(rP @ 8L6( --3U
+ 9ZIZ> pK
+
+E *,1CUPf}
+}GO`ƛj{N|ddy|C6v6VQLkckRarT: Cg/@Q;}ua:gwAN ]
+|Ȃ c nܻ!u|gV:5?n%s$~ e<6GdW
+7/jخp9'ТgWlUEV7끢XJfmӷUk+pU^ùujBw)]uцR<!m[GəHI,(&~V?qUҶ1Bޤw1r:A?:nMFjE/UqUiȃv/uRe4@48ШbIu<ƓX0%RSY&`\W$ `V2,&TDtgvA@@Ezl,`ChbsvcޔID#0GNL61R #m5IaB8eB!2U%蹆wh^XbGsEqb
+K0HR@V nKFF"ЗkdPemP>EF7'=א YEPgP n(1L~m_xtnWO"2H
+<caEL'aa1BA%' L<XcFf&1ƃ=!w;P :f}}$L#|yDQbw=<9)ZGexG'=趱5m6w2ΰe#` 2hv
+zh'Dl#R)@
+?))B%S(q*pF}ZĹ?#ZNyQ9=B46fŁ.D`þ #*ATETy؍y/OJ&tOx}RߴJhbqѨfYJbO*QeWyG2Nlf4ЧZ?yk{i{[%Q,9
+R@S2ӯpۤxvl<grҢzj^J˽y>C0)?ґyȲ*Jxض $ M!7DZgߊ}>5_ށl&dd? {BWFFT/ ֪I ?d2Nm:
+<v:$ū8'] ۖicuGrDRX?Se,JiZO8E~kIkJ+ f*E"KO[. Vvi
+2JHG$7Yu__s/њRZR#+K!jH bpuکDݛ qdHo\
+*z(E*Qyv+vdO6t\67u@ab9erR韼JֶOםîֶ_5=U.O?VТ;g R?=SC 8].GlA?EN4 w\~%;wFE<T`34}kߪ)xRk(,~eeK=Q,>s¨1x.?+Q bGq+R=u;wzrȮ`uԆz^E-iOSı>ǽUQ2n
+ؽP^`bpw 6XP?R*^Awh]TmcO^ui)Ss{qRKxݖroKrY<«x?o;cwDOٚ?juL#AG4:fG&x˄};~6~9mlV;>[S
+
+{]29S =? #~/dB0(JL7{xAE_OH tE@3^IbgDpW$o! Q;1lhh08fԠ0 ߽h]QQ]w3Ì({РFDqQ\Fr{.xRs\
+"> loyimϩM\j񘓜oMOw2w}nwS,}b.qwyJ~_[nrWؼتZg15{x*KrSe5ZS/q_gBΣ`js/qT8[o/}8vYK$GqWXt<w)ݢo {by fo Z.Lmsjgwk ޮN}q^8B{1ÞtugEC7nw~^=] Zo5ypLsm/ ^d
+^dj_6~6M=_Ր/uY?k)6K^^^fޞl~toR;_=[*x"KmMrj:>mjƹ? < 9{X"1Y \spW<y;.S.uZ!OE\O9s ?j~; D</Jk˨o'q/F 1>xCCBX)Y¤]p>n$nZ fu+yVU#F{h|Ԏy 7,mY~Scsޡmn _@ޤIWߪ*jjJG]I߂vԨD`hA`n
+>V'5
+6'F1s+A4ngV]q.blMlnSI.O&
+b,b> k()< $oP"(O&W)y,`6H‘+)ZV #`}-re(r#?\4@S; Y#\,r*Rbɢb?lygKR.[X2o_=B`o&R#`$$MbSȒM09"
+֞\7\8Jڬ\)O])>%ίgS-<5GopN̶)N_Ly_yҶ˫תώ[/x/%ң҇[s L9'|њuU$z
+!VCX3a
+${p, 6xxNr*7^yMZ˒ʎL,,P6iޜ(4ӊ7f
+`8)<d>dzqqxg"b9O>};
+x!F ݑong jSK]+Q5zM3LOOO5
+z@Zw^ ^~X^bS/řb3пq)x{xq ' R9W$KDEZ F)/ম+_x.-61C5h18!%PM 5`e#$kߞK2,LMa&Ƥf2:;Jhμ{9neOF烯:=g<`c<'~hχ^nu#&GhVOG0}kDct>j.:-0֩(h*.\tmt[]v4جb
+i_G4EMZ"py
+CWA ~fUEIzU]/~5؞,|1F@轚"mi$0S
+Q_Zn:WC 4f5xe h :zLX3S]XK6&mG4ٕ%W%?_LG䰢M;%`Ihx%4G J3ߩ)uBӀC#nX$1r2`$֗ mw:͈!m"6R:2uX+Oc2uƪ[-*CN !m
+NpRs9>eA{Tjw5>cO+wNs\lWfdV+y}T$=`0b{u
+V>_]6zQʺoʴ/j?fzVJίo7[u>X<>X/5Y`xwmӽJ
+PeRVi#%Bާ:GzThME#',HUW.52=֯%qgA+ <kuqBN@L+AFmG f?0^rBO}y",?WFSVl8ROjcӫߖF_FRc?$pY\,sB:F;9АYw
+=7| e"ԅ+m@h]eX|aTs/KbIxr(|L mq}et,LTMR0t0O&X0cꠥT3^aM_g?/  AA4rh8z+oŪ:>TmR"EP"BHE:ݼmkڇ]:DplIHʧN|:zNܽ?<4j%pI-ug/Xޝ\XbiЯIX93¦lA`3P0U_ad~%RIoY=
+LaqX΁> זIBg-Sݐ?_Ԇ_.uzS1P`['9' 0I<ss &nQ#a3N1PVWklyi̛KJ_|* e11Z*d >z)45_5Zz %=y^+jKWA﮷2>WrOWy:xzfzV0 w· n:s<04J`P2X|Q ~kp|q*E5}CoD~m?r2`,֑[Xaj>o D}qC/ñx7*Sq䓥Lļw7 (`iq_)cs~CyߊK~piXGa yDg=3y~V ^(7 SeRƨ+'Vtթ|7-aQ'$ ۅ)EaLoǵFƖRk>w T7-x(kLrK&oϧwr8*ƇүR9x֎L][_׊mDVk<D@njMz
+K]αwk;NY:NYp_mP39Z9s6
+7/Ff;Lb{V]@L@`1[MbY"%t\ Ooqd'~"ݐ^|p8%
+#}3W)zk-ÜĨg#*0yN2D.WyAb
+Gp@/ RP! &ɡnˉW[z}oSg;t笵^^ϏymeW5+5Q^MA.q-i%;q3ϸ󳵖ݣE=>.2k뺊MfǖG-[mMk)]p)]:a(yw?v|W8XO~޺뻭=;K6<3=+m37=Lmt?8OpÍq.prI/8@su{s w
+c OP7k5go?;6]Ô^N5
+ޔ#) .ER6 j&0T*8ԃ8Ʀc2|qO¸^;e_ܸ?QK ֲly|jJ*Zp$%p֗g^غD_#!aA%, kO%w+|S
+S|Yb7JYrM`a˃X*{F/
+Y:R!
+Ld>J&uG\&2ui\9%w
+8m*V}ӷV
+I냘֮,1
+rX=*,`i5QA5MU'# O&QQ/]`e 첼JQORScirws?~gfwggwk`<x7u/dJ\~)*?ߵhv^߱h=@ַ4iNo5!O'|+;56 {^v6+X_
+x\N8e3snrn/7?yO%ٿS[==b]c2Ӷ]c hlUdx^Rl}}-g<=܉ku,TzcmZOt)GQ"QD+:]No~e]끁jqUwߕs}i-Ypw{vvdו-,5-U-/T-{W9.e dyJˮzZ+l-f}np?ݰt}dORn7gW6|֓j17Z+f0S|Ý\ WZ+M9-ij;/ Kd}V.PgGF9Kj,~)>=ϳ<u\ڡ֭ 5h\l%\k¼ Mn)Ow< _{4= c;zP9*{He)c<jqV[] `|2XuFlOηGchkuMZQksfD[2?UkbE7 }шh֚jzgײC:%C6d39FچcQc=Df0 aP53hXBRڐ;%| !h[EqEJٮ0aJ
+{<<ߓ L>l(=Swg]$X2CFNpʚTsWGQYn $C s*(33N) 9H oc1q\,Akg.Q8~$r߈X p lО'jJ9xЮbL,ϩbᗧXU_,dt.yG4Ѿr )b}xJg ps]!,LRSd[dU s
+!3RqD qaB|{8^mM&S<wc[ճolStj;퍎>Io1.1Z;NB&^U1_RqZ/=Cd8,O(P@S<G$VGtJa&qۤӁ:|9-GJs!>3㳈 ]Bb[HI/ }qo6߿^<ƒw36w'3׬X1l ??^\r%Ǿ,=w_yFګGSY*hAg$ {EcƅB`MgGQQ$UDc0ޞs'Þw*YnAea,Cs
+?w ug8]al\һBH\+j ӑxf#0*NC2 x{}$T|NR s
+y<<dO6dc< ÜybwhOc2jA\혃1
+}r
+qې.PQv@}(@w-;T,f!j-=dcJ?K{=L2h 5_v; NbXTγ.3ݻ/\QA1jމh1T|UgFc}' oXpY]vݽ`tq:ml;dj3$J9wWv>s=;V.A__XhsכYkP) X=5ր9@46u2ʎh6W75WmU M憺D-d&0ֶ4[+LAOVT|^雇GQajIP'aA1uPp Є,Qs:)j0* I*&~̔ ),пD&E-:jъZkEBHG-Gh_g0h̪#h:L#ApPg`ԚgR+P[_oi8kcl#06R*AkHrɿ+=1gk>4h3ĭ1NJgE)l'o C} XK1V/^IOQ8iP5IhcYތ
+n&\|dy~4 _i*T,+,[u${͉ߓYzR7lL)(wf&iY0۸o>|4k׶-;LYϓ73w;zɞb3&ݒ6ׁҗr6f߾X~՜ezG/=R?jqm҂溔yQSJ`1, X!𹘳,mZ8|3 1ȵaL[3`y}7
+CڂB}1
+| St<u
+WnjE+LX!(~5O{`gr\'WQP?J3J>?wjO
+Z#=;Ǯ7aTlfƙZYթ\Mq8b,}p- ,' D'^^{+=e,lX6T6T]y.󸨮+7ðHH(L
+U6Ȟ"$("1&EQQ(Ȏ lԥMRml짶45IyoP9svߴ0橍d3 8saϟ-\ͳYh}o{y_4 >Rdf76la\]vwA&?5 m|0Յ
+x~oyeN,:OoF;-nY_KṚ!>-,!7l,|9m?.8:+/.ɯ"wRyĄܒlfgc{1(?YhvӐ']h+(vVFk+eﻞzjZU˯lbkF*bo6GY!W
+# KM~ 2x
+mMOuچ lq9]p&#w0>I}3 k.L0fw5(i{k44
+m.F.GLF}H%d
+]pf@'_w|.:_5\}8qvR[{TP+lG4.(Xy{d(6Hp1Ya8gDFC|oN6|>-z>fnٚ)ǩSItW#i1H5Hp2pU̓0u Ϣ5ORqc q?4@j1;ӘH/K}:c"㒦I&קgyEP?/9GHhUJňvI |.yY;q: oo~ʵ3:9o{(gua*c3ӪAs_F{{J-;+zd4m:3]r^3L39#YU߬k{EM_^-˪eC{mVY=]oUϤПLwQI[cᆓl;qdUSckMScɦ:-]GT }/OfG Fq<׊8nvà$Wq/rv8$L"2P &njoFܫ9 ?[3K;{lFÔ$da1sދwg=䕎8c9-iLw3Kh
+{Ofl,`,aX0~M./ 9Ƭϰ֤{̐VHgC&B,$];%l
+8h
+XB5a!1/bGݔ/31#݄ů y`r#/#=3S|ƆM.da݂WZ w|\Di?`6 R&?d!-®,kA/v|!GTN
+ytQ&Tڞic+ f,Agali}Q~?'ׅt
+&= E}tY=aĉ-=ƱyElF9a-VpmKs}??k2.kbmش;o%_qcR6xO+v Qlkޥ#K(Q{=vE.nE߸nf? 䇰V}ȸɞ?٤9],aLnͷr*nV.7ZlCNACOyLL<
+ljr?K_0-X_~>c#<ͺZbn{t5{qc_VNk*r D7 wz9f0!Ω8VKvmXP u^s3\!\1QO\L.qƉד;=:4𙾧I j4ܯ2"}
+P(~) $8Pgd]6^i~ͦRcDc5|kfma8/f;k|gsgSs'G3f&Z?$WN/O-N~tVcRӝ?<?xsžC?s *_ =/6ܩbw]iN>y
+2&9#N
+=*"ab5<
+p`UO!B5y#Xזǀ7JVc6\X?|=V 2<]#)UE}}/tN/x5{KkT.B_ /%nF؍~U~=:V|t+zYh=Փ)A` 0
+endstream endobj 24 0 obj <</Length 57442/Filter[/FlateDecode]>>stream
+H,VwTW3 EJ@)R8"E@Cga`3C$!vH<$F
+)CvQsr]wo0s^,>[e0c #" ՒwVQw$#~5 lo+#qZGG wk)ZK$SrrRp,7lk}ϛ~vOǧtTu{76}zAvۧ|<
+u.p];Kv
+
+v
+ڴG͇fbv<+-t~Ci<gSf Tz=9 VRGEH!
+Lի]'#\;C{iwʦ/o4~t穣-Y;6v=.k/{d;G7L/}6uG#7O Tmh^[qs|7~^9!=iO5NV { jF$0b4
+2i|,GbH<.Έo^o)g滠ⶼ;b2ǵl f&02e@m~y\18K@,0Ƃ1.a<.=m;rpg5Aѱ5TQfS0%Xl^)P4 oCyQż^XGrU@M~ϵs[ Ų p3a%$<GKH g$qYb[Zp!fa3LN]6X\'ܟ5^
+,9n<7.'R7~ӼwfY#~"X/ iaz+~g$[%=x偢*ͥea'3ZZVSD5ŴUw,=K>H|AU]M^W2hIC&y֘Ac]N'w#q)Ѡ!+Z
+1.k]@};* ~9*&?e-o*ɳ9卋N_NS_Ԧǵ翚Nה%-CbWka\$:%8RPeQdQZ*[F;k(s҆ =΢oê"ST"6C!C*
+P`.i(b$۴jHK"^MIӛG]j
+b~Y؛Azȯ7Vy<+BJɧZRx:إ$%ywsK:y`m3˨QcRȅYVl|OkS[K)ivQ, TSW! $P+ oY
+"R\EQ<.gZq:c8j)Bswnޒ޽uqSh9LBG!Y򙬁lFۿQdLcLgV5FʪI;)GsT>ɄNbGƏU+OH=GEO^X,z/>8:;k(ٵڗ:6FP{ژeOw/ۜu979mʰk&헤>Ajq=%4PYʞKųost_ hݮ91`L{F$¿3-2J<HZYF)(s*iq ʂF&9bf*ܥ~ΤQͪg6 ?72iy舰 oO<k~ފ^[P(e\)ɲ67<6/ȟŵ~+ޮx-)^7*YW(*_Jvľ7*ޡ|m국.<qܦ8iB*7WV9_,FV=R>Sl*1Rp[^'1 x5zQvs-EeF;/ lNm3Samk񲶲w7/kx~s>{s9# @ȸفq!3ҲLo|L0XfE t\
+)bF}%^yw<|lr)oŕ|JfdiךFaXjnl]Sew)ju[ڑ ފ4L
+'q(Y.>łc#*0
+39`/25p9Z"<po8R10I;N1uѲ V_PTb{DNf )xHD
+!qKa,[BB!ɫC6>}-kL\ʼʡA.c5x5-kRp}ζWξ[rf->:k/.ˎF0#%v'
+9QRsi.2#L#mOM3ׁR 9.wҞM5_9iIo v Z:6
+j ' 32E`s` T6="{$^0JEP;#ăA˱}p ~+/܄z + yc/d W+\Q@lM9)޴CYv5Em6_\)Se'$>ɹusȷؔYx89-?ߌz6Sp+0-~ß3)yǸO<avcGưPNr3qu12s'>2{5 wvGwVod?ˇ
+&sD&
+:d} {#DŽF%ܳ&
+3DyTW$lB lFEDFbe$H 67d((uWp2EQۢl.( **Nǩ(GgUB9w͗/M>錞iCuC^GҌznj',YS7uܳ&5\>ZĬcIla pA7j6j_ĠC9,c2%^a)aLљ18n>Ʊ+70/39~Ib״璖ywa~9v툌_W& `G
+z,y}̿>B?w2c(MF֤S[=5oܫfGQ3_8:Uļr.z?gj၇8؟<=&+k}|9:p-޲ 5b6^4۵
+/,3
+"gm̺$(4d]>mȺ"h].c݊!qYGߜTv* .!!ܩxiS>w1'65P2buf+l\˱_6 *Md㿎28 v ]pAQYUgV٬-e4f:Q/DnP+Q'b%깐GY I`#+><<! gd5HFNf!sЃPza";ϖR|H@a?
+HgFG}KS`H0`}xHIoo
+ 1hǞuO6//_p^k%Wjst"U=wZ[R"Ӝ`D0| ]}ONxA$QRhz <̙01y0rOJK{)9Gs"ZIyn
+jE7Ϸ__7(쎄Bs䓰Cb
+i<@ʸnFs^Y`=H8Ȟ2r
+m(=;>Y/]1bvC}~,iy"^)-M̟Ǯ9K.=Hr+a"u'SL<rjGV/zݡ|lN 7i}ʃ,ܦvh=_M{gU>ߜǒ` M X\|8)g@ *H6Pj1Og~,X!ZCA
+}8i2sXdq( Z}}]olSn]s;t?fmU5U ^Y8Yw/uyW>_Q@nſ뷾O[b^m-QE)yƵfT`q=T%=s<BQ1N)mjs1) 8RH#\jKGvڅd R74kFDqmp^GJxBgp~1x?dJE=
+3(qU7{nj81p
+bAS.Zik:cG>%v#;p?D2g\
+R*ě{&>w+K=c&}hQ+skO::⒱ʯ“EQX= af g1?eԙᓐIB
+NE2BEG*< "*EZu8nQtJ-U7熙g=ߗ/n/2> ~S 2N17k9=}ea׬<b@+D<1Oer*0Up]~ 6: :6˛:z4a;޿؇2C6ʸQM)&?2_`owyg:Gyγ<q}_q=O\jj5!
+!jTWvJ:1"1Ko3
+2n
+
+"-m>d: ͵R`G7mQeU'=;ٖ@NӜJ$KtVqT[JpEWXBZT<BG%[Dw1
+aC!a$-+b:Uht.%W6ۢYGݳ.`{vB?^anBt*Aaf~5KO&N,HĴUDgwLH>N+=S>aEy {gt#bS;6["3vyt''yʗ6ϗL
+/̊D̊Y;DSHػvMTMϩϰjgB PĴ%ޝ!1S>/dooB͏9A/ [*ӝ[;iltQ7:@ӓy>P9DyOE2eaS=Sm8sb}KkiuGn,;!~
+d6N =4񞍵܀FL&mp }
+L<#3!ά xhbd}3?4ŏf A^?bA  /:_fo9MH+iw]эڋ,a
+(52
+5W`e/msIq*T9b|U^ٝ#Y-W?^rwڦ"ׄnȀzWK ϓ
+utP]C$dz)NDb}݈o7u\a:"#a}"g]@6gf#BO3L@29L@ԋױQ^g#Әkte?N+"6Xe
+(*~7@~ ><X砏=\tgA`Wi
+gӁKXBxrB8BH'?ۢ+XN\Pݰ_]!r޴>'<:<h͇SB-3sr0]QMY %`BH(
+&E@ @(IU3ʀX( *Eu\ϱ~zQA)|/|˃A>H1,㞕Pb{<:5͵@tG>up6
+KyǢGPٝIqoҲJ\E;s=eYs
+kRjU?b(_}@c
+ӜFO['|޺׫pӶ.MY]w6XS5u((Mbʪ:rbv|b+d"]V]{y oi]g; 0 y=u;kw0;^d_`sU3a^*31"O'T{.xIjWm* y/^n 읱QTҽX]26,lZ/ޯCgXڰ%*{os1ک
+Oya/f 7{>2[c}wOw_:h/⫬-twgIypsOV^L fHf Ɇ[ üB;M#-O?H?rni>/ zz)P`sw w2($bK85:Cͨ@?谔2S(禥D֝3ӝ2=/jGLoGg֏ >뜕Az$kɣulַLlj(XϾsi-)ex.yohi <>t
+k_4Qik$j6Dk_kLf7^OB?}KLtL`Zb@Oڜ̟}/> {#+_EAgASt_B {ZagLǨ\? D=3W&Q{ ^cX{XQtr=AM 6?Ƀ,mUUekc*b{و֢' y?~mO$/?#cߖ=xG]y9՟߯K: [ ńdrZqtGO͘
+qC֌(JEUنV3\A<DR!{*hADDCȨ4'  sjiS00AFΔCY+K4.z17 E79; `7 ;cZDqݱ,[׮"U$qeԕD
+`I'̵D!yQ~;lG'W2|XD$tXV>078d!+"QiZG ^bcyD
+Jo"!~}=,h%ĽY@<L=ZgqBHrֹ֢ĻEH$w ɒ[6!3N(?k,q^
+yk)F܇)Bbk)Oɚ,1x'SCSE,u:??뜋V\P1/I/e?FȰ{Y؇ ˯h̫M9kC(
+˃a1˃AK0?6jSgz.ٓL[Ok2c$ݘDE jVG!NSFp$xL,ue2U8|oqXDA]Nj'4m
+V^Nw,MM=nmB5/&&%OH.+wq28+`$*JJUL.0~:
+5AԚy6C]3.x\_bh+qTt qEM=j*b<Nw1.숢atvB'lZ2a NQ׼2WFcܪ'ԦA1asR>aY' 8!~4<Lx3EOK*#VUj޹5]EO]xRiT-zUR:8ܠֹ60ϒq)?Ir8U[Ϧyg;Rp: cc;iӹ;f.:֨F쎇wzbآh龥wyw w}69W8MկWݴl eNwZБuZG杷PYz_S*\I}O$SϊdQOB. )HehagystOק߭cIanPFO/#^Y(T3#/=` ٠SF2d j`ڟٲ2a!e^~aߠ>Sq~P6*@?,A⨂ZUU*j{$x`oc\cANAiNKa;T
+
+TcJ`OЄ鞀܀n|8/dlw{3('
+?IO1cER*):v״Զ5TxWG:FMtt${Ŕ2:[I/3tfg6R42PIj#Q~ ݋e^5^Wlwl!SVr p%vY D/@[d97uW 1/Foxq$T<0M"n$d;ˆH}== lK"!3 9@,HcA?8%`|%>7]Ҹwkj?ع&yDեiv+$~T־Y\nNNe+oolp{؍5VlWeO)L[qٝl@R{8d%>o
+|e$u;X$>C"zY$
+[`쓰N?gdpKp>Y'p 4W=doh#[yh4OвR/芚ƥt
+ Ʋ31єFS,iXaR628y
+Q1v>
+.]hU99s
+(M7k 3J1RCi̸m`S9<idc: vc`C
+'eI2ѾLl*c'*MnO-Lpt= 'GO3L5
+J³I#;qhs~ K) #Gg*vz.'[ ];B+7Jϛ
+QoF,H}zԻ\q\:_w׮\-'xg<qυT=\~ާg){rܲmk
+U\)ؿҚ:՗evO/ T,W9 ?ݕ\Vגz]neakyzS?ͽj}i2y7(ӚYX{N/pw((8G("[ oZ-&rbmD G(#1|? _?l>| 1~h5lP!i/mGu ?!(DԎΙP0,C(ugqVHaAHr3|0) |
+Pԃ;f!Ѓul|$EXͅg<h+[IF+[^˩p D
+*'汽Y#cEa %<\IyՕ"/Sh hw%Yp;XY#l)فfƒ%olHr1#2K,Gi[UœBܰw'lLt^圹tl10#CH`9_Ht([@Ys[Ğ~ϼs3i3s^%@
+ )
+5دc`Slj]
+xJf05̏
++lS\vXc%Ua%ˍo6HZEkFoeFzos5ueq ְ/,+2 cHaM eQk;
+j&"HEۡup~\G;~9oロw~+4W -_j?[dgsQQĨѶ#"5gx`޷T Z[&-
+}ȇfȧU+ߛfy?9gQ5TE8u%dac,q9M9TH_d>=s1me4VHy*"uQ:kipR͟1/ͰKX%iވw}oK}lXՙVUI3'rB[tѭZyk6yj]TG*Y$~iCѰ'fǹ섘SWFv_hF~v7:eZڕCZF-y/y=% Xl8<)l% u}ZN"$&Y<
+{#2"=#z^ "+^ّ9B?{<`51&$Na wY<?ahLA ;BCF@g՘8xT]*6b3郙 vyx!ɲ;}UVpݒ7+;<Mi}2񪎛ucb]}C;;(
+;'w~~{hl|^3;eeB1(}= {y&0g4<N yX @MAdQC}eo><GW CI8~{0^
+V3Ť PHS4s $,A9y_~RCR.yC,'P~j Y 2/TC!TK\Kv*F(>R%IVkLlW?9\8g:~ȷS)ZQ¯%sI(6g6Yfl/ m-3Y'jrˈ7"ܦx Ӆ?d6nJ?Eډ_2NmӥylV`*!o&HrKOZ;ܪZiM;'M”clʾ"N稑5T4mSӏC&[B& ˆYٛZjv72P1˩PJvYp?=@z/yZ/hsNMԃ>
+я\.0=W
+QwMbb{*fklc Ch%%>d?xAL8 rߢ p{BDp`y~6,h&~~o(j]5jVOgT<+-8pۡX~~璙, pF(f~ף>#;fc}
+m@93
+CY>
+`1 7i^W[\bz{Зڜ {Z xяʼHΟJTԚllrRY+'nR7 Ļtp$s.:S_C^T"&si ⨟?_U?@O C-}nHswU[VJyIt*!vj1T`TuO5wnuIZS
+%d{ #kGOЪ$AgSH{6###5hqi9MK0?(N]$ܮ E_֛N»//Du6̹qnk/3{֑H<6ϥwYI{7zdܫ$}4%i0I"/|@<dSε4׈gl085YN#yqN >:oFH$Wd5% VPzL"/IY׋OtΥ9rӰBg^>er ^eԵ}3&Ô
+
+$!3뀭X{@S[
+2 V"8TWpiV+(?6ý瞳Ϸ_m}wKWɬ '65mj'8jkxmNz3l{;tؽ,cc#xFJCbwC;}F}g6ۘmNf7L,x_e<?{ =əLrKjkfdAc}}޻_ =XyAe]CpoKURiWz,>Ut]nner=ſlf ltTøf1՞l6lbA{X;?6?Z'ݔo*5]JUőֆ,*^1rEdId)v%eg"I
+;EA }zY(ɝB}b3iS˅Q&?/xj_iK+^Ec d
+0&cLd޻ؐF=TQWjVj* r yYK5}^q ̋
+ |,Z1w<eIha ?b-v-cVٗZՁI=[U[5L*;xՓ
+K;?\֕q! xx?Smx^mOoΟOSkg,t: Z  XpMG$F}؂}l`hk"Ahb"Ds~EQLDITaj_*jϻI.1MRb'ݒP GJmG_(@]4ֶˋ˺5˥]e^ fߜ ̾5KjGS(xّ嶲:su˥ V|<o2 ;ذ؞A՚箛4oe51d%,? x¦yM9狺G?L[c\Ί#Ys]R8'3xL̓
+)펐ȽN^Bv4ŝNIG&r)h+맠M:< C#rԏ5Pu?gl?3K>\Ht4}fYHs!ǸŃ۸|ϋhU_ެ^&ת_.|ff;ޠ~yZ NE6{?fsYO-sX,66fAr~~ߴ'e%}oӛQwp>̙,}ZBqw^O;
+Q.1^owޛLTsn_r<2CPu;d6&ymu!yU3rC%<
+zdku\VF>vXzW\pG)rS;ahְK/P5'uiHwQ2 Q7"_|Ҵx[7xy
+ڏ(R"0<S Dlɔ+m|-I}yrÝػq"Nk03짼.'E)e[Rı!~̃(7
+O ? hHGNз" M/疭Y2xQ~06e=i]Co ]mO*Oݚeßb ;Rqk w`/"/ i,SKy`rtUH,&@ "
+QEob;Z ۏ
+·b&~ H9gïwjC*=L.rG|ڙ6Z|ZQod#wvQ;&6vS:`[}*Osy5q@i" ( -=K.Ŷa=^,K?#,,޺zk{,Xw]B {&<dfP/Ao2ضV7O\:pЪ53$U*0ei or29Uq·c:&洩0b'cJPp,{4+"K=0l[)2J} \ẜY=ęhL 
+w$`3x^[(o^ƤWo +O24֍EYߤi(ak
+׆߲dm'd{p-S]Q$ḇIC9
+,mJ~P 0*e>̗ffQ4d'F47"uEu.5S:\KKw2=odJrJBn𾥻?d+xa_iYYwrԳ( xoR͛W'- 8DŰ*0/l]mءE#:Y)(>eޛ>Z*>ەĎ9iV+l__0lu@-
+_4e'
+wfG]v+ c?c9P=P<?f^k ;D.>peCB/ F
+Oh6e5ZecVް O^ث:s(ZEZYZplNj[$cnR~ضAmñMY7~Pn06[߰^_5[5 f\L~%Rk,*QwkFi"'
+S d `pxSC%'2䅃D򨮲+C鉹H@^ XV0( }oGМ$Mb%(6I;#O.H+AOGJJ/7]Dt)LԷzmEp>>!#$}DC PU{xz5೰_p%'ВֈUBCz6飥}f= />'{E+b|NOid2 MbrrŠ7vSrHkVk[/AfIn\QM]y/"
+ "YDe $,I h帴0s4E+u+[.X:N=ʖ^b{{1==;޵ CoÿPMSXWB#?Y# DLdD> |ᙱL`F,b>=X^
+mj7?hѫURz
+mrU1Ѽk$#2dhpz y$ G6s9oǽ/7y]rp5ɉy =Dsmɸ}PvVҴW*Rc4YjReԷ,Ua_jWbt)ּu+G>$|rgO1^Ȭ`3j R*¨p$-,c録x$:
+_lHږRS4idSP;q)]t"zK5Z:P=]6ua!g3iYd3l9⌚.-j:yfsgZNp' 1*rAg5W3iWTxzN&ͨQL/lJ Leu}8BA.GC1ν.
+]ҝf}:3s{6_^IfR3ܠY1b[2hUx`RqGV576#ucuQ†E a6lVJJ_Je;nFu:dѫ Ϝm3vnG<4.렆Q7vI=21~TrOmKn,E,t _Σˮ++ߍuvR+IR2=Hے- îMsn͡.jůJO-o/'A尝>n|>,}S
+͐YL5\k3}3 ' 94?)7.itak"{Pc'9ܟVw߾P~GTvrOI;WG^2[wڻm۾ٯ:޻Pp etPX1l8$buVI %j0蘌VGQJ|?٫阚:c쯤3[TD,u2ՄH1ڗk_ήҍyTyVkuu)Խ:T0UY%JjG>-|'<ZX {iUjRaI?|pB[<rw0$LF=?U?/nH5d K KXC:LʗR?*(<GRM/#iDW¯XR<z189X`>r=)5kb|Bw Մت~<ɝyU3uxA4<`z" =\anC+)D5>jxBt` ɄOfCOBV`FrcArɪ>Y;`NV, ?ZAd\cK2^1jYV|pZV -Pڞ},|T4zwz հJ>ˤU CaYQ3j۾kYFZ^w7^w\a}wݲ]xhnyIiXlzӌz$+yj<O-Z
+]G@} %8Ih'K
+nI\=ꗍ:-jU#ù7M/OD@R.1>N[L9BVw8gI م>NGӠID@HL4N=I9w9#^Ji/'] ^Fάť<q=9mvS|+r>/V7S7 Y^3 78}OM@։\doaŰ}cBcޘq1~QӐKMh$ޟ㫨r!byMiLӛm4e57j6[6қh}b K71ĦD'TW{r-dRqz>@X/z/GOUC*ô"D Czrk=\aM]i>7!d")ȾJa7i:㨭#PP2ZHRUGj(nSqkE]&{]Jd׏Lk-V9Sx|0<HN{Nd'=I1w" uVDdM ݙ]6IALb7yu2a7i0L)˛W>l$)9$7WsD3DtE@DH\̈́
+HtÞl|jG 'ψZvN-K.uC?o˻~EE9 PoPT-263qD'a-ŝ{#p`\1guK:`L$Dss!k̯#q-`Wi+@M慡޺Nz9 a/'`Ig!ZԔl L188r<ЂKYngȂL Β:%{cc/3K0ԀPz#z5Iw@࣎Մ8/8O ,U3/(yJ‘FbbAo"S11#hI׌I2ޅnE=Q^EOJOP 8%hzt j|(83)ڙj~Z<s9ۉhzH U~ߝ]i4̬΢Xͤ~l4*ɢ>:o)Ciٔb яLօ :wOxeῙVFWXQWQ?z~9Bipܣ.{Ө>0 jPf eò>bi
+OR1SY4=9G jQfňNղٖȟM)Iq,Isٮy7J[MF{< uoH:PGC aM#45ZsiQ g <<goLsJujiOas8(/O)(Y|*d<QaHgI@3߫{4N3|a
+.0ϑ3Β}̟9#ƾ&d4
+red0VNLp "
+
+f:Ւ3Y78}*j'kzX[2<:YǗ<{]4DV:>$E.ìA Z򩰵PѶ3|]~R u)Ch</׋"P.[VOEusEcڵYEꦵƢ5J\TLn`][de]( &]w+~s2Ki:u.OeR٨^ײQ^qK풗Ŀ}ptCa~ٛ>c/4Pl(J[l;M,jFmO³S|/9J']HJ3NLvQ|ʍH;:i+|gGRn{ XRNGi78$] .9]lcKC'A!'# ؐ[&`p.Ewl'$ ,v'޹D TޡXyE]mC^T\VqN߳\ШDN;mNb.~k6$ލAX
+c@xX<.>y-[<.9
+}
+m߂sσLxD6؏u%wH'pkX9ga3\sɔxý]d|}pxx%@H?
+x&eS2z$i̡Z+\̢,yY܈yi"8Y?qf}[/ 2yu ٨c|ңD=!ޭ8ԯEs߹N˱?4IphڒR'=7T}]54k]ʣ|*X@e]yTr6s4fLVOE[zVdwsZR޸2j\֮FʺL4fU_mvdu؝]Lg X.:7Q7-~ɗ4~G545df9dLޚp]d!K}?;xXnWʐM]˄AgaqH? 4KuI1K>WY79a#FQ︇I jk>y]";*ٍjzrҢ)D
+uoR6ٸktt¡&uPڤ ?;F]Lc;sPǹTқG/uddNBOk!*}V9oxAu¨?fn 5a1:$Y~lռۜW3B"(6r+"iy5=ZKۖ)w,|,ܿA/WVm|({[;=UI2þV k>j"u2 z
+Lq(8X`0CXF8LJ#x"'!+QX0nNGo2GoIۣ8Wyi?WݚtHy0ޝy8{ϐ,yhLe Ir 8Y$HsiAyDq\M0̺hvp]42kJH R͠!,*`DBXB $d!$!l;cmjEȢX-
+")8 qmVԪSg"~7yf?~=sJw m`xk)ϰ`sbOV%7m˄ל?tz3lm2ok #v}_|9SeOa{l3t>T2u`:.Ab$wXNXk34XRFB$t
+#HBe{s$sLk z=) }58.+! h1@a=oL-~d.܇ 2\ KLGNI$]w6 $ (3$:_Y_Ph~.|t lVA(}Z|O+5-1L<nu9]}qMh@ۆьE<en|@[#}8 4%
+*uD]hjԺSue)ќɨl~$j$ $ck7N0Z7:q~+yúD횉jj@WExdvp
+߲UNzRٗg bјK[+;`[c>
+gi7󆙙wdr_= #NApyc
+9n׿`}i8Ȑmb^Dc
+"kYm{ J"ە9G?/>/X3c޵J7)ѿ YA6%fq߼<ez*GpܭN89C|JC1w+tr=:X §~
+"D|Ĵf>h["ߒNN|OcN{hdv]'hNyQGשήw0V+1+1J~qf
+qj{ma^JRyP55&)_r˟!O܊9%!m‹]e
+1 <KK6Գ@U ɞ ^:X{˽J?h^ hU-!YRDfP.N<@'-v
+}UH8d)LK<.:tF"wΕD՝5ҧVtogu& iWԙ➴i#w-}6yliů!!,tQ
+ſ <8M)JHQ@@P@0a
+ U,DEcCY5Ihtpr2}sNBF!h&^l^ʟ|2oG?oMAŠ
+3B1%""Gc aHrkKy`B^ģ<]p=S@Ͼ)$m= Se^So@YHUe vѶ'v nm:\tH-7
+-|3"ЫEqcoO+?ɭ素;wޮ +Nߗ{@Y%Ö% |bmNg^]y~u|Mb(g|SR|#"e%);ҴRFeSQOȩI`Y7e90wy>E)Rx>Ҍ=
+3^
+Ml(^W&w! :]tS\)uZ{&䱃OXC֝gOķ<y$G\*P/}v]+"lS3`<Cfbg
+NQPB]~nxmIZ'܌L%O^II}aܞ$-bLǼ)kh V3j-&v,5Z{palۦ+W'ݴܐtz]+Vt[F-oN cIrڐZ BGlL7$(hpLǨA6wB_kz5QԷ$-$c#GǨ
+rh>9#!!M5Ά7"Ɔ#q^gړwo'Sџ
+cR@Oy<*d6>KC}2$= s Ow8|FV
+\{g^p?T R
+I)sn1zs:Ɵr6gt3v)tFW)]̷̇Oԛ=LvV:rXL%qܢam,fz]zR^|Zc)T&}dW&R@q{$;"_wL|d;uIc?ldou ƯQaR`qzx
+)KSY1ذkR 5+&h_.S"ꖎDi3ԵYu#Q#EcsIՐ}rpbz&7r*E;GD|WXmQ%){En[F+ML7 0_{d&GF23zH;iP3Ob6t@wsA mpG}K4IT'4i?BvPt?!2"K 4?.we'Ix/MC{g;N f, Na8Ł#DuKb,Vd{g ocLr'cD̟$]fvhic(Iಟby=[Tmчdz> :'>l߆LJ
+=)DɄ[=*V>k3 ׈u+(,
+dJ+z(ǎׁɛ&)i`n[!M*_Jft=$Ijd85\lTEVhǦuޣP{"{OvH,).|13(yݞ2&W _|0lX2. ,4-~dZ}drxx^)iU.%HJ9P=X4h jkHȱrZf}JV;ޚ_(t{K!ǓŽD2<R3*k {fPi"RN/ hĘDE
+rtcq~
+2 b_2P<JʲJ6n}FxYhĴDѱA"?]練z k+{WΝ0,[ FǨ
+"6u`9+RbߌфGo$Z9ʄUH+am
+yڕhYOtIdFԊ]+y/#멳r۷LNi8#H$H nT6*toZö4A3ѼvT)=0nL7NjJԶjQc ëB__~3e]xu IY&GoMJ O?~թ%b\‡蕰|SlP(y*JY]ːH_fNps_7/
+zc^<P|gSR8lc:R)cmF.:$9{.>Q*9XKX/_р} a8""kp1bAT܋^Go!
+oHnDbb LMzr ]
+fT } zH"i zqK۬`{_5ݐ߽O ةί?fDo=j 1T d(cκ$({Q/31V*8( xmpn11Z.C 8 0w9r`f5\--7Q+e#w nBPH4@ڠ
+^ٿh}yaMq ;^CLp86<9>ͯ:|=ce A6/N?rI2O.um
+}{gv l27yl`ЄiA+<ApT`T7R'^oo9>~פb{4/mo?g xtqZ&_͌%WݠP~rίYɇ2 b
+/2\hNt~G8$c^ X
+^bX`4LlFa??r7Ǣ:G Fx|"^H b'xD7* ]a m3-7^Ƽ5qs#:[njyPi=]YҠ)xڤY8gц@#9?ЉGHlC]?`MfDȲgd]X %6(}P%&mboۊL(o]Щ]g]iAϯ>ʛ5mϮP\4[{ PS _q烆{jymA'F8“~0+~2GgGS)`atPjANmׯ_Z0r2'ƕgF2\֍ilCK4x7dZ -c8o7sX>/5fG|^/ѕzR7ZL%v!#{\iKVdI5as׾gMRi{
+~bKǓ†_r{o[GJ{wfx33=\V5|gwAdvdB`ʧ_Ϥ=<:oOmaw8'2 ^OzF쎞qϹvp|IG Y@.Tp>ycZĹ蒢饹O
+3_s>5ol:ʘ
+dʗ| 2^bd0P\֨ {Q-\ќ$
+:^@Xb{'9iyC\< _ _ IDC:άL?,$*:ܯ^-ۍ.
+c|O;Oܿ29siԴU}3*{׵"+!eU7$vNvcvǴv`z!q.H<ta6i]]:2حRW edDwj7 mK=w>^ݞAoĴa+HbCA]THX >GR3ĭsisa?):Sw|u w'/'n9Wa!+'3hδP8X0c\,7gXPK9/Vr)L;ݛ."tQ6fiK3]MQKe-kY٤"["IA<<E%ix
+) nkyz,yuΙ3ׯ3~o dIߢ d m e 3E*o.ݸL~D!<K\@T271)gl[lSR̭ɷf~uVe+td5\JQ,uƍR4@ G7x<
+\@= `)}" m'ZK/` <T#gJq&;!e:H.Ni6n:i=5K5-z=y]-^w57zwiX\q!2b{`Sky3O\kLmׄ@ p/2{EW`dx\ghgXf~0HDCF `k}OsH(S5lRq.,â;JS.5<7d/ 7ݳ
+<;D·88grkζJ4,f PF
+*=Ѡi(E9> ??z`d}%Lִr,)m,yئ_SIą"qx]ةR:fS!yoE&aav
+Uwٕ$vgp@[Tbۨ'WmJ+[_׽0޺"գ-E[JJ/m-hKu-%@ B.ƺ~ yk,X]ʑ'!+zIB3+:1yQ ]2tȅ8?F?Js?^'1{I$^:D<OV`JkLew`ݥ4!Iw@mk zjV<޼ܮc6KΡ۫2?m*^ɫ`wqwg}w'213cUvg*!}ߧ^aV8btSa>n~<v_'{sy+6Y)]U>Z[Hb=ڠhр+``ߢ >GZ eA d_A rx>^]5
+S.k[ttvQ_` 2I_S
+4!sJ<ӑ[ MAAH+r?![>Ya<+ې>C}ɟK i72J7v!ݨÛGBFdIƌ$ ƇViY~E9m9mIy_LZӥe.ùFOZdYR["墫husgԁw=A ?+|d7^w{L*wI%)kpDѰcl1%ЇmOcl'9^ֹ)6}t}F䵩oRƣv|I:m6Q9'>+WNE:B{ 1?:fqYN9@6ּ l[Et"O4S!c',Ukd8]X%~mt@X>ޓx"^T,RTh'nߝiy }U_?l|aa>g;ܘq;Uܐ2Ŝ>l > dՎDhp9;b€d7l;6(dș&yM=~҅wy@;p D]fQ7 )|I"Q 3 yWkĹ w~K'.댔5-νX"FKsa{UXڣtG߫o}{GoyJWۡvu<I?H L/YM38C$aunG\ooӰIBx?={ݑc{d҃W ٍT=#$&LBAH2~b*g$~QD
+*YusU'N Y/o
+4hK3Gx<^uoa_tpddߦɱh`p9D
+7Pؼ'{R|N?-+ا=/'`$Lvn> ߐa/p
+F'%a5aؚsNؾjlY=۶V1 MRlS/؜
+xl:B 2BviV`h VݩgY#+^,`lR<,OMrB>1f%ܴ?.ţ#ⷦIcsFI q))NC(<!ZZ!7+J vx/G *GDX
+&eӊ)V%xBy0h(7~V}LAAޓ%Eo r|8+כziݫnSnvr!4>k4={s#a
+e̽Uu @7up
+`r@z:= s9x'8֪'*\K~+\K4|mqqྙ>zQ -
+H[dEj;#雾wY״j*kE$ek+u\K&'O /|kx 1žQVv[֡~l^#i8/
+j.ji;9mDiI'mQ'mER7 kǃ9Zvf/mi-C&,=Hk'7Г'7W(>Q@Bס&nQ[֬'Š
+㾥qſTlH
+fř-n<YZa,622ĆX%h_(̔EFA_YOH,7P/zxeOc"ퟳ+lxWXqt`VRШNIѮ=c[&eoúy'T~[6+Ma1_b_XwWUq4a%N=5 .2A`tZO=1OI.GIͣ8)M=;
+bn. i#3w
++JG e{F+ɽK}sݼ>daA=K;s^g8SV-I#M˿EZy1-1d|bRX#&VBbV'sJ|;-ݩW5ͱW%ݣb#Oz]=٦}BdI)VnJTcqF.CҵdRfe6ɲ(Z,R}#De
+%[R⊥mQO>?G :] bbs6XA uc A|ZV JJFs)x4·S1v76'qcnu_9gاd=W;ͪέ3yt|~E¶<Da}\Jl˂Q11+A|nrOL/p_\ Vu8Z|VOLy!t]ڄg=B(aSo( U,,*$\QM\m'L%E(*,AB $-Q*BUDA!}lY8ubUĺ,V Pʢ{'w2̜2T0S81(c)az=L]=Ryv<HF RsR^=idy0(2(~'S+ӓd  >.3`})cfd =\̑p_ǘ4%.25*첹{C}6ϔt+RȲsI=k3O\)ؿԧr9jᑆEyMj5ړ+HjKrV"
++s}j+_--gNKyM8˸߉{ؚ2bJjGollAhٌ] mZ\W|&{qz< pEٔhc曋n" |*7:ཝxF0?{mPtXr6fJ>L=Bo=Zw\T8Urwy&<s3y0F 
+6θH4fX5aX=Y0hP,qx>r95VCʕˆK^)HQע^|<%e+uӣ7aB'rkJ ŽLDe<6OڔLFGKL) rBCAI<jRe)'zMhL5$5&~ h8])iexݧKkW =Ip?KѤ"`ҴU<̤,`ԤVnP̀u2uBL "ߚde syq+YIclJTQ# W($-rbFeT(Fc 1A("Dmf+kyˉ~w}kBx4/Q933fY!מf)ƷQO*q-{b¤Jɶ( L D"l38
+.|c|d|0m2?1H0d֩_njD83o}Me
+z!  ھ#2~ sU]$i]F. &VP
+!fSOyH eQ/iX=_ eB<)oQ,ӥPaG#(^'7DV_);G{dj2K
+BHG2:;κU)4ٳ<~{;!Lj|fKv=̈́\͌tׂBE]K ޯbb-k!,cz)72G%3a_)Sͻ'-S:ؤ]MZ= j s4; ~
+G'0N^ٴͼJmyuoY ar/ltDJXt76kƖ~- ok|o/f+`{<[Aء-n?}׈5kfU>ش
+PĤ"$D~BnbTob-D"k-$"WRګXNXtQr_hv;#&xq{ouč7%hH #:@msa?G&Lvh)3a%=i5-qm{qKwcWķ"xC.Yѹۓs.xAbv?.=KXuWi2r
+L_u#e!9uԅ7TEetuH3 oc^ߓЮ>2LgiJsA.\Che`d
+0kq/GtPX +̮0pC
+G,wQ,̳_^y  s{/k
+
+GtL3齧5'VF.9WxbJ?l&赈=Qo*v\K\}S"~ܾv"Abv<C/rfiŬqV);O+c/Ү0P)bepFmISa}XdčtK ֋俿N{Ą$O1>j C181a:#R\_SCdv?g\&aIv4.H>h 3u ~v#o~o4IA|Tf_e,r'n7 :52J
+
+]r<ܕ0a#7tfI4^{qk^kޕIWWZqx%2e):i9]<hLX v-U$,^98#tps > oDI}⚄Ӿ 15ws?5#wdGy/{hdBlP⹠{QϼoθrAׄnאIAZǐJ[$w)>z'Ghl4=kݹGl
+?XKC36ҰECGZDR #Q.!z0{.`mFHtw!f?mI mCޣxw,!6b-Y
+/T{IK
+dŬ􌬩ّ7-ax=_@1Rل}vG=9FVj,:R;gSUx1pD%Ah2s$3^Il+0/:(aaҰ(ph*Q%ҏe Ƭ+,f!gdd8vr!q8kB`̓3e!W(;'K']ϛT10rFzjF
+DEA&,+a*F#%#&~s<4w=RrٹWzÜ&z VM
+ f9]% ;DǪhO
+1ߣ[ewBT%x1ę3O ':pĈmi<O-gƽSǞ{#db Prr?|5;:auVն8yȸyD (Sr[}=M:0-+l$;q~Р1>Q#ʣ3#zKC_e#5%{sDXoP/߯S8OIcß]LgZ[z^_ ixky!z}A+.V;q#
+WhJa%|2p{O蕺}ȵ3δr~9fD=jKAdC$a
+`?2?Ku]h3
+bk@~V% =@||(oArm,X:Ij#/T 5XIBכf_=[ng?TaɴqEUQd.ƾBuc5"s-bL>Uxi =6o-JBʂFt
+}ֻ".[Cѷ*b#+> ⾓wBK{=3S@tZ!(;- ,|f L {s<4=#_Y<\XtUy e!HzL x<[
+DhMC~dȗ Q:tw؀͑!,4dwN[Z۹vh=aW>P@0SЧ[%6THFb)(]@fc f¤O' ~lܳ:rdq52K
+29U5D̽O{Nux.:ێO[`z, m8'Y/ X/xQE#w"
+endstream endobj 12 0 obj <</Length 46229/Filter[/FlateDecode]>>stream
+HViPTW>i@bW6Ɖ
+HdM1tMocL ?]`^OF#EEDP٬.:GEPDXK]oxaU^Ӈ^E h2O"F4z&P(hS&
+ 3)!y"
+IMMbx)D]V`&s'"Z'ȱotqԨ!נjn]:cQGN 1340ph 7C;O LWdq>_P#16b0FC~?
+.KvǖEܩWrK.Yz%'j:BEl.+JEG+\T" XR!+y*/_R9b/8++kl
+/<sPu{ T
+
+xj>S$6P h\̊ TWD7 Jd!tIQ
+\
+
+(+oZH(6\Wu5zE`ߨ!9X+z,*@P뾔1xG V
+ߵ@ (>(BjP,Jנ}k~]=p!Ȫȵrѧ~ nqNޮSnuhϹ_Q5=KXk5<9,ur?~Ӝf7٭1~|MU9rt,@~%@0`O=~S]Oo6i??]ǧ}5φ~ nx\hz3k/nq+-m)mm=6zw?OhȥR-T
+norbZ2orX/
+W3p hR^פVW7IU,Z$ܒޛN=ݦR1ϱ%;ۤX:llj5q]F\C:РNJ:b5_R;S IWt<mbemll@ 5uZdmuu^ݜ^p[R,g <o[VVln P_iW;w\*kxgSpj*4OU +#¼Yb0_.Xp9Wj}brƟo걔Tg\ꉜ/nmco2GH#w 7oISC]
+Ǩmzc>޾&&\7pwGxx0aoAqYp7>; v؆; wg$]}eM_ӶV?q# 9NK#y5lY2' EÓqwNi?9xS3l
+t  52Ǚ03U3y6}}s=#?r΃) <+Rn ӡB-B 'n#j
+ZII/S_Tk~
+N~LcMB`qXD0|\EbN,mB"?''ÏREc26cjܪ|t` XAU;ڸެc/26~Zƶ?/Hmypi@t6-c
+ʖέ<+{wFW_DM>]٩w#*ܤSgtG,ޢFņ'N]wu*v?FZ8fgbH40f(vNԠq`8%F*3.Os1bh|FeI?!汽{{6>Q1D
+㽇gL3)V܃x7g8cWbo1xtH?3"-]>4^ CϾx|
+0(SB\ \0/_O2l,DDc.bi?|>5&KL8/( ?X?: :f<=i?RKq<HKrt;HuIkՙjj멦*S Xb%
+&0ޙj[@'wԟov wsx,i7^UВYK&R+i LKEцz[?I 'smmkgQbg;14+پ&(st5v[鿱1=S`
+a6Oinŝ&^cnj|h<G= CYp??xo3O¾wjmokבpB8]?k>]
+yGǾGX^+@{ȶa~(sV!h\wzts|wivsr>ȱm[+̸O?]f\Cêi-+r~խ˹q{Y?1R[V+BK4'˴i~6벶uK]F粛k
+똈&!GR+^"t@<rh.?W#\  S~ϱbgaGl /3}Bx$FPy"*º, BdT)
+(c((Q)QͲ\( q|IRێ8c]t:Sos=~3<XAU2Nȫ˖cO3c9]YR 9*`3DnUʹU+
+jV|c:=!(TB$ee=7O~ѹk=mBҝAmnHR' = K~w?nߙ#y cxdy9YQro)b¢hX8X<'W :"%?Ǡf{(_]3j
+sqjFħհwCQ|
+ ¥\: Dֈv5`ù+Ιg-,Cr'-ο!/理|-j=:8r!IHI^h'ƇE α{HnKD`('1rf V4XFw4͏yo.B$ϬK*@%օA/BZ^\| !'b g!8w`oEwB3r|@ Fn x,sE_7S<*~x[
+w&{`ODaklF+o9أtĎA}üçV$p:L{ ^>5Q=R9\$21y9N:\ m0'kWk!?0?EB˲Eߞ_c;G]GYpNcˁ8Pad;"B;QrVDŰ8f{/QMGxĻC&yg]w]roI WɉWgOe}Hvn@Շ*6쯛KZ!-(܏TAnћuYy2{oX&9iPBWΒ(7&M)iiR_ħ{}Oi<5iw'srִr3'A
+.{FXf۶R3Gg9l*V[XF~ŞcpQhG;q,aw8$|CP߬?0VX%_ĸC"ĸ-< gwlq?ā`?}_قx 8(q#e;tNaƈ@Q"8< ^EF,^Mapzw3{ ,Ƙ}EEL8A-b4L&FM " .qJ1
+H Ec\"ЍlzDTۨ)kO0KM}::]us~MZ.u)>Fyqgr*?q%
+IeCxS]ɋ=zPHSo񨲷葊a~n5q?hB<x~ؽ<>aᮂ=t' t|qב]y?[4nnnwZG&-o ÀRN71!Uc4A}`Y6גmmzkX9{/s
+t>ŧl2Ӹ]0{IY{uI0_s?X53#&V!{$NL^iGONFߨO1gsk]S[ct?N̓8!!`VwPA[^gmi]hK蛗ys򍼛JxbQ]%34vH'No fl& @O&]V
+=ݚfi_!x_
+N:a$~
+BΙ\2y1-"|^rbpG,B4X$r xr;ȩg6wF^^/lO0ߟ:|){گ~Vpa&?(ĕȇI*5`OR19h^Oz/b/C|am8 U 18pXi/
+B
+<Z҄<(:O
+x_9V=
+>޹=sJ?nI.ܩuG7vowkْ? sAa~FƏ㶫䙦i BҜ&>63<qӂ{ѩ+brW
+rrjܙDUīzI$’}_
+^LZ +bK^\tQ
+K#8\s9; ;lB&Txİ@ s"^OB({uI sֵcX뱖H?X8pyL }Zq~>.t9
+oFr9ߕ
+.0!c&wЍR,;9I9POo7Q{:CfB<ANƜ6˳q?'cVP*\iitT5Z-Z2M+65F o@g4d^opAlQwSWwh.I
+`U]flU5Z]}/և,Dod(
+%E^(B`@?q11&1q 0Ok??1l7c>z$&ԕ(ԕo my5p2mٔ)˘k/Ni?+,j"vqꠜ2.rJoPRQWcQgbD]]ڊz Y
+&(e2BeL4(
+W 
+/n A=<9R2ro
+8u|0H~QaL'_"@ ߞ%4aPaHhe`E0h`lq0fU,~3s>'8_8rFfT0keLf r9>yoE<3WRGP<^"`v0o=9D%}:Y|v:f|9<yL<~zfXXFb~Z xM.F[~L6P|{Apf͊w#W?Lܱ["xfU) |
+Zm84gx'/Ɓ>bocD܏o+cCOc\ d6+W̞҅{j;"+_M:^6,7=^״
+*\g7j5’85NWZ֋̖3%ܘ_4z[T>['ט́/=z̋ssl=;78lu}"=n<=ߦ[V^Ԧg3d*d8pʳ"КiLbH^S)>:W Ai>Ȋ\-qa]GĿ$
+Hq0v K6,x*ODO6W0Jh9"!.PZ#pq
+۝јMZXFc5.+%bb~geUo >1v0;|5uCCO51pUJN/rv?%@F}{{~NNWU'Kz*;E0M
+F3,)ܾ8}^w.+^7{M}iּ$VIg &3m֢ 7^;޷]{l`+趎c1g/9Tzg?v=Y0Ym*}򍧾ROo'a'v+;-^g i  E> `еZG߃;q`~jӵζVG}? #$n^7
+ڡU;*b7c>3"fԲ&Iw@w;=]lk8~3@pZoлyď6)j6q.Aq.h> ?_2KfufKGKQfߩmn.#o7eyw=XAtE < "
+x+Pɤ(ȵ,{7"@Ԙ3v:fw{<>_. EWJ{ع'N5 Wk[MZuۥ3M>ʊ~b|h23p?r&AKLL<)<*d
+&uY™2 Ţrv3Jg\b, ̗\o0x4Y<p{6g'%_.|&-rWwq_ \mڛZ G*{!t7C_27:2z4=Ĥ#ErP!!r%"Ec_W : șg{G{و*&^M&+mrD;_\OѳDž *}1|]\ 'G&@SN,L0N%環V `d0D)$̟͟NOBN
+X)< z5FbҞbbs;K֥ ,Ro98|LsHg /~^,a8Iy8$~Ow>1}<"x7,d^`',
+6Fw* |wxؓʞp_p󈿠s#ב#=GvzUhBK=wK ;|tnDz}U9һn7j*U:o7|@NJ=|a
+}I`qjӾ7S8BWv{}!ǞVsAӇ_E?!<D?)~F0!<:spoi-; t:m؇CWOQ|Wn~kkܳYk|
+t` ? !#1p4HX?u(/)a*x F޽WUk.J&}0yB` DNeR޷D~JBp?y1g8t7<;'\8~*<DAM%E@qU45(#((e,<FiD35i&f$M:ɴ@$voa=ML)hP~.њt`
+%%``>nj-
+Cs{} pCw tV)[ (u UY `ƹ$iU<kYjpSwi?wc4@G$سrקRҩɳN ib ֢4i ?,?U N/`}%"8 p^[qP`AHتUlZS K|%[˫Wh_]i[,CL u* SN:<m<1kK6-5i p?-; ~qL>Kw1
+~iIK
+rFj7Tr͆]ܣC?Gl<C_Ùy#:1 )|k`cc$: 1/b
+? 7t6n)yi7s}Awܺt<BxdrV!O(Bx|/%?#&a' ;X݄olMřB,; ߇NA^q]ׁ7|*
+z<tagj YO\ln_Ju/X[c fO0;@Meh۩ ͻ9^Oa\UfzW`}bu<d-AB']@ڃqM3#fb~dQwG刵b6mvq˃5 8\ÿ~pv;`>8pxHA9%7dKGs%wrm%cyұ]ZϷZaN/-ݚkYՖc]fʱ(M0l.h{WL
+&ɘD*_0$h@2< rYyH3x\w0g0Q!C+"%{T7,'9la5Bm^:A81 sm&7DF@=ƻ/L06?_L{ \5,o=vư*2c^1`ȇM{`Z|wt:53 N5XAd?b1j;xYjV NTἝqnt܅GZU-qK'px*N.L V UzK{{G`}?p1~Nz{5n:L9W-XOd֤K9!|a
+@2pg ڐ!^En|?*@UiF\㮎
+ZU$~sE֩
+6峼7G+~eǞ-Hdb2E>
+Ԥ2~~2[z+gsy
+'Ĉ]Kϐffr[i//Tw Lu
+4HLl&
+pʵ ^8K$ Cn &b;X7q6EE84X)}sykpFa" N!S;$|LnA(.Ly2A*zS<?~(C)[µdZh td].W2>3fneKk9`K:Dй^{ :upސ71n1g~ QǓd!2Rm2tԗm]0ہ8~,^EFZGayWspHq#e83E9l
+>4%?kW3iƿI回{7#kde0/3^ý ǽEˌX=܏(&1{-kɢZ[x1Y|3;KdB+5Rv|_e_4yIEu{(4۠[SZ GJQ˷x/[ˎsmMًu,U.:|EAoרק1ߗ1kfX]_iIQ (0 a"؃5x
+', m ~u:16<>b$Đ$|O6؆{:, p/pGgzC nCL>}
+\Ȍ7c$R =h4$ܯs`D?9Ւr>VE(<PR~Y6IHuZB)`b=o5L
+k΀gW\ 8gJQ9hwk:[TQ dbaLc "SPQ7zxY vU/k|P TJy-J.J^0j^8G}ӂԜEcYXY% o`U6g4CmFͺY+dy4s=t?EY a,G 8"PY2c
+ox}nHkMLxYJIJbd!?E ( 8+< ߷Z>/!*}o"ӉRa'ZpG(#M>k?X*٢q<w@XPQfwOl.X |Wc?I_ WcJp=N_5$Ġ&c"C!Ykؗak1/y}%#3LQb;_xI4dKk4#sقYV)#qޱ,K? :<ĪI_r^$!fj?e6k? MoxDdC؞ћVEy%X@[8-|Le^d^&œYd _ KƲ\K2,`/ŲW;uuw*w^f~eٯzo!~_&7mKZzÇ93s
+ZN4?<uѡѷEf*>?+s _洍g~\3!KO~|a:vڼ'9YjߖypЌiWJMqeيUʝ5}q2ysu~/Wd^ OIځXJv!g_#vA;g2
+Z}wSJ3hkm:Lךl 74vZۍ-ƦA-}0h,D/n_Ak3 X \cO'Ey'r5MxJ Vq0y BB,BsqZWUbp9wZyjٟc|XJ'^.hg
+'Ǐڋ||G#-GfG<ûvEyad<8M\"ɮ5E{UՐQB@9x]oΑa>`E@lbMRJjj!ST_ǝ.qQ?G{
+\pðaJ|!O]%y 07 
+Dpz ځÈYe 2q<揹LC>LF>^nZ
+hSP<F6[p95 0W!'I10yS&n(&}/)g#Fu0<6~`"(E#G6 g"MFn¸.!8du'66R^'e#bGL p(__*l?c+!,L>3QinX.QFc0N }l?r~L`>#.`1 ķw -17Odء
+ur/="1Ƥ`fc BXX\ǂb>+|ox`p^GWERZJer*x3H '
+k1)ypԍD,=0Y)G$xxU8{lQS`,a{by8zםqǯ}4o"RlթlkofVs^ܶ*WۙWa;R}1+;n;nG_D|+]зB:l{sH$.e؜Kټϒ$}}F:r6k`d}ڳo7lW&[BOůڜ׵F==1M+aymeU1kT%gG}X-{f;>Cg}Y~݇/w]vˇ'>xEy/'XΆ=y?&l-zVfտWs V *ldr<S'2EBm6.}6HȬꞕ_kvե+^Ʒu,zI` T/<
+[v {T|*K3 Upzxuw%\؟K0jGWz/Jco88Y] ey:U{<1n`ȷD A U8TbLs18sW:_09"Nb^8s?eQ{ eă 8Sfb>34ojąPĈ0OiW&c,~'y 4s,4DrH
+ԁ},m&TP;ts=Z]WZg`n{ \/p6u==C
+~!V*#Bd*JpBP&<!+>Ǥ +M,/<CxeH/G~.󠨎< 0p""h4DFULQW7/rrs8 (x@Jݍq+R+?V @uuO`~}p1.r/\ vwprAT鑋"ncinB ා"'/A^X\_ƃB0_x5h?
+L-' i7
+,쾜b<%ǿk||LIs[.cE^e|s~:>sUߏ HQpmfafsO9-CµN WA`
+(VuH1ꌗq??_i׮IO_h}W>?x˯?9C߄2K:m—{lK3oW,Н7-ebA|aQkoObzbqBۻPߗ DC"? 떾D%?7_4"ɵiIβWMsozo+b]m8>)h(fgٓ*ؖ}y.W'Dy)Gn/|/i~L͸🴬3ۙs>Ugs~1'c+oo?(ꛘgE01DBvcO%2 ̷
+c&'Qby`25zp&p<?]c?b{SX1_>#,_
+wS!SLVE1^dn(4l)ޅ# z>tT˓0$pdI3pf:0{q?b/!~>Dԇer͈/9`]w };?&9%rr>aȗػpO`;bںMzz)kZ$G}guEUYb3Ved]\]jh2.IX+ՖkRltֹ4@weIm -~kKm،N_` O\uh%#n&&'#xڨ/zTO:b^!qe^di#N-p͌94jeN "igݨpQjX4&3lkChZWWC2ki}0]i贝Fzq ɇeJs\i[nw^W#h+c _bu0~,#΅bG@ѝzcfJ{КpoP_zC2:s{ ?8u̇G,}lG3&3xߤw/s[={~|5iAױa}=!ۯs'o qTFS< Ni\*y 7?"M@u6dǍ7::._;,NZw8Le=Ҏnj'@Z\GN܏w7:;i2&R.#7U7;FGi݂{e)iA0P*(^jOvu5Fc]Qo0Cn0:Pg^Z[[J Ͼ8'!W%B3!3xnjpV9Z3\I5J.sq&G~\(?b?62<L8LE0*􄒴K)trZ
+?ˠ%fa9Ya0_I?,-c"vaNX%c]Ә%Y&<LAcizk,H|.2挈Oq9rLwc? X@&u/# \Q!G8]<~漮{q5w2SDpWEEF="Uoh9 XU
+(&W"4֣]\`2AqFnTAClhBM㳱S  kQ%Iy$"_?e
+w3{؇O؊j;yNgŝаXgjfG8<Azi_^j>^乷o.(;(`jԊʡ-W #rH1
+h-)DDnQXAp]X^:8iR3MbLm(wqlͳ>|ҽw?䦖=KH|%/O? sI׿0f66-bogOt`_maɓD6^mЭytPfn+>AJo91!ZGݞ[}Ժ4K P,}g
+ϰ2'{L_%qx㓃?&wjQXOEy2Ƕ}!zO$K:]<Gt쌇! /W.n{L#bJhF4a<򣘙ƥf ^,M`; 6J\vw>;$~gȆ-6 n6J CH)8
++d3mw"&𛿐;wuch#\s9+ ~腼;r' yt,a*r3{:FnX2Ҭ .(IG1"7cSĴG2A)nik4zvZZjiL'A-;~Y&S5&yw}ږV}7pX%''m,oPrQ,o34I$zYeؕ>h*,j.V]&gzo`}~=0pAo`Y8z̭2jX
+,`~cH_j*җjɠj-9ȆrE!s8ÐeJ3gOY-)7S-Cٖܡ[;gܻe[%|u@[4xV{zyOt_Wk<{zPE} Σq?N Xq|.V3ZkmIeq:kLseqg}k;J0dmQLj
+y&U)N|gFBΫ9xI>ű/N!xΆ{G{ǚ+fw\v` 儱DsW
+9 0|r2xә#=4t:gƿ ?X}4
+},^mG&WEސFwz&vc|dƅ_3) (:&؛3ioϊys\꒱ܚ_$՞}%:wҴo"S_n8zwzo|ʸjI^ƫzjƵևW
+gV$W۬(/7z'7 c(\Z3F쮇c!bj1_šGCr]X""Bb%c(+(Iqh`Dky(va˲7Gij33ә63iL&Sݳkvg~s={|ðB!
+\-0rt0]
+r%kױ< x=kcVHмq;9qȷ?G~ՉdAI[K>n;\ID
+t@8MZF*_ 3dL<5cV#*G.J =Q62phfj^R VO& 7 4Ȩt]#3kTf.}qshd%W;z4#vANr
+'7Fh"1BAB00v-M!_Dʾ* . /0/oOĝ@-؏`R^<?E?qYiөX#:UK̏<t
+2VZZyǴ\0@-XQ'
+']@늠D ̃y &9s"}Y5OD`A,8!o S Vg}+tWi CZ oe܄{
+Mr$g5 {'K}M~<q*Kb6dLhxlƩOߞÇ]Hsw;j]&d''.>xIk~*mźʪvi\ywz?վbc>..Wܦk i }cImO9|w/<?zʓ"tfx&| .6.~p|99V+ / x;߯ $9fz";q76Z UR/tfccY~K ǁ#3"wAkrkWޫA(&@n`9Acz)&D'9b] N@L ^Bb1чweukנ?+&y͏/E{ܫ ߇p)B䵐l7im2277iN^hcmZ qv4ϖ[_rs9J.lmTO*!M% \&3 M +TiR;-ydn huT&TvQ=>2T0 ٨Ok0kf{ wuk0'܃8~X`L4"Fwc(38kmͨMAK<Evy޽<T4iL2NNLDK?39{{|ufE^=OCX@fWM?I}Qk669 cn`vZ4q_
+ۜcMwkwc.'8|DӧRprP^?ٝ?$n0N>@l>a &p}7 e3AGK;
+=|y;S(gJ/?FF#' WDg"cVɒq\ %b(To8)`6c$(Uo3v5eZӒоӑ y
+ 90x;r+ȁ^BK4
+z+}!Ifyjק kZ:MF<UNa'`_f|Y{*Vz$|J΅k%ʽg2@Rh KJ_2-%]4 mzBO^#Hub|{`Q4(jG9SB XL' \SF>p+4IZUY4skw띅!k"wԹe?'C&
+MkѷkMSMF}^'1 U25=žfA# >q9cq\&QL_CP!X%м9Eвt0mV 䘟Z=Ǚ
+&knX?
+-yտ7\87W|nm<M<'GcL>_ۀ|)y߉=U؃:%j^cnD!?'rn qflG|ߊ}=F!ӐґY`m8S%<
+X
+6^¶>VXmj%Z5qSg{[\;&^mjnKޮszW\l>GSIyuG-u0J z+Sx
+7h՚|W=]n؈󉕽V8!'F'wr9ޯu7<7j*sߴ&`E|A=}3&8
+Tv=>Omv4X3PP7jz/?Ux{l+iOm<p31Ylqջ6
+
+R9jW~cW>C}\>B\ ~S>nrģP {aJp +9
+o4OkЈ0b0|$*8;O^xNlE`Ul#_!\?,'!+ mrFM}=h;M jIBl9 -Bd@GWk; : xY3G9z> L9"5}$$
+?&ۏ4Lph:?GB{Y'H1X߹_"MGYO
+)\ Vd`29b.s!(G'Ő#99ºɰ~rsİK c1
+1Ko'#. o {gfbjK |_
+䡟`IgNNw[80) c,VXz:+aJ,ē-<ñ 1(s,z3KXz Y/`-f1˼͂])6,ҔAlk2Cc.j Otj鲩~verǁG9vƜ+y'SK'S$ESvb_=Ol.1~IJ-V>zgjr}a
+no?4{#W~d)fJ=wpϏ{sz OMeo!,'?/83b= ?S</()y[AjђOUپ8oL2^"zu" =rnT=K)</֝y\7s7s_XYXX3鈣л[,(vb}\ ؁8ۉێہ'{~eڂ:YȀVH.D^`x}+ y?$xQ.8rM-[qmb 8 ܼHVb +B g(Tb}wa pE8KbB܏}˜"*\QXdy?i2=gqCXl,,_̼L>ǾgT}31{LV ,C. u?]5Nfߧ?Z6]n@ХRz jmǨSPv<
+gHH+kmWv Uk'D'kbBA_P7viulQ@kFnOO`PWmݿ&E<;vA.Vt_Cc/7/^is.'ԽOLOl3{c}.LOC<[=C-P|+fio2#`TvUc7yLjaԴZITk68y_
+L";jkZIN̋mH<^P݇nNGs?=Tx<'5_fP/VmT8,Ǵ> (?((XG"pD"V#~<W\Qƍbco*L~8'(THdlƙ\1
+o|{ wq.ﳰg-sžDقu k7CՂQs%_/5J{j)3-zgϕ.~UsjKCw4?>
+
+ugI `a9FN>K磹9s ߅zSV阡# sݨa*Fu)sL?TԛP<
+173h)Xkxq8~9_#,`bx<u!3̄U ɖ* +Ŧ~A[SoDsy2nI
+Z bk7 vCD{w5d]n:sH7^G[zclpYW1^pݔ`Y{}}].)MaW%.%{X_$gYe}nJ <פߞVٲNHzTԑљ5/_˪}}~Gos
+ >wn>XԟWmJ26T)ũg~֕Hq.Wc%>G2Z:f%*$kɎɕdQDa/~]uw"'U4ؓWCůKI hs &o8}bp~G
+-cBY@w,7*Ia64pe&5S! WoF,<"CN; F<X{dhAICcːk.X\$CNzܳWyBnU>RPܿ{
+Z{i]'Z,`U_5qEo>'0*T_xQV$1œjSUl*%&=y%?τrq"O*y5ָ ̍X`}R_CaG9 !.<`N/ebcս[^im!ap\>)XbwOH<g`,`' cbϥ@
+X>bc@cNV~ab^}\%d;l^khsc1"j4$Xʣ2GX2vueyԮ]l _lVqtH~X(g[~Uf"x7+^,,ۿwrwsPPzSih{І]^hܯw>ZzO'#սUgk_usk v/TkZ<aW+.?]hwŹ%_ j*릣
+C[ϖ|ZCE|w_'?~-P~r'
+DY=Ih~=˝fAQ6v[+m,98UpAWw<*'ޜt-glϮۃ2.=Ы3
+endstream endobj 25 0 obj <</Length 60282/Filter[/FlateDecode]>>stream
+H,yXSgO eS.@Dv$$E֥PGVvp%
+V6Aqتcݦq\pA!{w{ucIƓQӘ)׿jXiʵ/ "T~1$LyVXFq2kTԔ6^l&5ӫ$;mS-sg%u9([![)w=(ZVҳJzWm.f-k#7˄m7m۲g3~}ۗ_*0iʼj7E&osU=m Pmevnsg3ASw !և_
+fA]f={,eAH)I.ۊ 2}!!¬:BAد6DQOXȃ"^D§^&/7=y1Hh?|4wy@zNЇdϟ>&EQZCI7L"FDV{)"x[$7
+u
+$q.#Tjt9scѮ4u)wSm<?lS,zX.~<"ƹuRtg
+UШDJN4zV<IХT0_0b, 3"KFǧ,ћK KYZMrEQza!~GǪ}EԇYe3JCG#Syߟg&C-n&yc\dCHAj!2 բ@3 9QaLg:
+Qҵ SQГWT!9Ut!/GsJ\ڡA$ Lƨ ROv {BIn F^Q! nN¥ j?.Åtxd6qASzړs!/ s9鑅ɽY2]ݚ!G UJDB8x^x:6OבR g5!=5' gAcU}M j"~%sUːu$TY!B8RkеU^:dspZN u^:ЩD%U%rn"IM2<*3oWI^;E=bL!,޵ƾcsfA͑CӶF_oѾP4x$sKS ]aǧn[nmEya=R.ѐ]cV!}?BY.tM>?=VC-wܳ|,7e/OyCm)n_MLǨE>F^FS iX8E;MnH-D H0ZḌĢS]pީXd6Go}_~rOg/Kvd싔56A$(NS>lh8`#\c& V!,-ylڤ4uf+:WL?U#άҩ<gӘ]T *^s[Ǟ\ ʖ}zw+k6njdMú5t|9e.{mCi/xq=j> : xC%,Q[y
+Ve :gLٶ^ݼM?oh[_}2G%K&ȇt2kJw --*(I !@$$u3L
+(ZSdGHźefjV@;"v满=979|v[g]A-
+k
+F
+)πf)0M,|>o`u6L-W۝Z[Q`o:wٳppB~f›?%;7?[wdwW^>_qa6%mcKs~UtغX:d]1)KmDɋS,X$p(! hYn^ٰ1˔L}mԥ_Xh.(OjU.ay2oS=.ǝ"3*S̅WOYVo*ʴ~uzV!3e
+]<Jق"됫\!9ݝAh?1ӹ~mk?wy=1X|ӀwD&|n ^/* ܟ ;DFReI8+! a_}1Cdn f%βZeN;]3x}9A}lppwOfC{rįd~c
+dgz9C41d7v>ON51l%{o'XE
+O!ҚaḮoI԰~ {bQyѲ<b}df-~JʑWu$˾3_E~mSf DN&<a\~qGFW:a͑UFOK:Nt[IұcI')ǓOl;֯)WGRNynMVV>Hg
+ZJ~
+TEϢUCcއT1om3lT>NS[ǶoQ޷H`U2H~5^{%zJy睽eu)WQ0?o Վ;7kmg9
+xX=&򮩑n4AЏsstFl 62:Am_Oq?uBh7_,ÝCEw$O }×upA+'z>g}XrQX#cF*icL}if
+iB
+p(\k/}3p0(' ㈋A9ꜫ-RM,ؑ+ɰ\߷
+Q\דH#×kƽK4#EO )ǔ *>yWptZ1eݸ:N&x'FID",-WRq+YIKJV*{5BDW/+t:ާݩ6$E$_?eԙs˦@ `la kBH! D}ʦ.$E
+*XVq+"֩(Ed
+J|?<Mny_˨~ %bH|6Fj0U7Ro> xǷKsfON?w3d2_d,pe@Pϟ2- }R/L7٥r~7fGb4?3miV4c_#~砈Y/<' . \}8n>Uu&}KMs@:DL*uI<_鄓p5
+Wxڥ8r
+*DUIJFOl޳]f7SXQ&pnQ
+4F +<\H%.äBWozw*S[3Z6{<I5 vuBܮ%7X3g6xL9s u9)?|ޢ,<!O]YX^\L=Ӽj'ƹ["N N'zGz5\ɿ ͮ߯u$rT&zg}B<iW#`_#}\0E?4^tiDŽ CD#¿قla?93?&.\IY~KGl 9r;M.L%myufm(BL;o|IZkVko)Z^q%Ӌ؃ ja]U;Ey`g}q', on
+*#nlZf3n5!ڏ s?IX\}uR]Bs!obuR6zH7phmb}.m(V]wW;*X~_)0_/!pxCv GhXHt.1 YW?wA HvPD_rC@)XWX?s1$tЎnJM< e>__Bq?Z$-"ЀGwfm-`Smf*+FFu޳n*#
+*$ZeaG*Wˆ1b+Q?aO}nK=eKZGk:Ɔ$B bp5 FX o@N_!f q;{$0g]U/qwqg' g\ 07B }(R¸0
+g{ܠyؒfμJ
+5KsKZ=S|;4a70ٝ zW+R,Fu1x.e¨ pAu=8UEmh|^:MxD0O5+r1>svah*6fC_$ն=iƭ-a̹1Ѹ1i'C~7( E7#|G:y</slmM"fAn db4sbJH"?2ĸoQ\hGk\@[|@dzEsʤQb%#\ʪ&UUT<1ogCզ!д1
+e b>"0{ S70
+r<qn!f0I KoB
+!3bss(
+mfsZ_Q
+g 6tlB-jɉ<5OybxLOѪCq7L0OHF| txK\R/Xv* Z WE xл)}ves&bcb̧6Yq3DQy_mm o [%aCX6{2<ʤKf.ۗ=e7 EمʾoaIMYj=NR3R$A
+ bm뱵"蠃uPysΛ{{<7
+F7'׀YO؂ #h*c? -L -#D --}mC~7G_h 7MlC=.2>oBM7U?h@аCb? xt <t߽!D=ig}OxS6 4SsLCU'.xkS(>uG5p?0Br0
+LrԲW{:; _\fS}8Qbüouky#Y}3e'Y*q= ĺ6,OYUڰ*<zPO#1>>ti $y)4'AD5~tppQ H"u bڸNiBEި6D,WYX3g .xbsjF{3BfS+j=רpyV8N?-Z(&z;jUnZ"br4X s)5Bn"IWI@> g>&3b3, B2$&\$z($QQ}C9edzϧ+NK-nMJT۩d뼄dȞ<#% >'[-dÍ,_p-m}1UARSe%ʐ¥!\/U}|y$ kp~[S֔
++U׋OYO2AGB(Xme7e:`6c-fA6o Q NuOO$v瓈K;4qkL+YE=ӊa~ͺGz0go&-eWN>dz!y͘h̸6ټ6Hc' kVF8lZ*N]Ĝ~3zG,1 g#Ik81j adU} z/>Ԭ 5K̪Kꇼ5~JmO#D6\C["qoL3I4з.Hg*n`jM wruSQC/{#WjƾǮ9ZM'mzk)Yz2 աr.1 Y<Y]%[Êu Kx,*#_ xQ3Q͞S$VU~ѫ"o$~$D}+_ᡂ9IUTV),V\UVrkY,wD<oMYi¬ii+VIK9dyJޜIgUy*KxcV`w0gn2KvS{R\_l=Ϭo<;@6-ɞެk&to֟<e
+[KYUpF.xm)O|e)Di'&GZlmUEξ}]zٵz b ?-ӟ&r
+iwȇ+îg^~$`. P];mskקٖp?+eQ=#[r^,D+os'͚^I_0"BiWH;kgm 䴰1s!E&W:Jdtd?ZpZRUMz0&7 Z/wAB$P-|M! 8 6N94z2_3>beJ(8(e2J"E o-oǭ27A|x/gg~56)IJ6ŧٟЇpg~m BzB=n9CȰ'BZ@Mq,<ƽ}
+,-TU\׊ϦkO!;ʉwS΋[`9בK]$o)EJyqNى΃I$w<ӶDo]5R^q87$t,ޑEYוQ}(?Qp2p\DV$ԸtaB;;$3߆c(yN;UMڕ<̽k.aɢ~Fe򀫌ea?p >]<lXnM<mSlzx<9U '9Ԛ-74_ϻc7!o$#[#첔+޸פgMe̝ iP9еN: orjsϪgMnأG@t+Cvmڠ&TTo{#0N[VDUDYV ?ӜđZ_Z\D: Zq)&6ƌÊW IO]_8TǎoKx~۲L0*4~ͤ{|?wbU!́GUV5[TN4&U!Z*T1mVN:bD7&U%"(mY$$B $@@Q,O/o-.` *`.c AUw;s&ə{K?i>?jhqS3n* 7|2&m'fKUR,g IHKu,ߒVܰ#+IBϼI_ƍ32 A#ü7L 5~p$/YD#ײY^։?}Jag޷N|;779T9]f_4p7>`Ӂ1Fŭg"7y!: фȁXF~|%{
+JBB_c缵[g蓫lԘJd",Pz>ғG>hąv ,f]J]mњP\m溈;==!!2%Dݺ 1 B_fWCEpHC<8{^ޭ
+SXo ^W G)$is:8.bW~˗%;#kPҗNv#8%OREE:%,D-½(ъa  >/A:LY9rZ=1ŜHc 1B̠Q<Y`׀/1Tָ~tQ of'#f\N؟M3e{qiWi(`v[| V_MAlILe~-/ן -MyA٠oPإ(Vw(mqUۦqU%Ɠ֟ϗM{ICqgĝ6szTX)>CǤ}IM~j.[ .29$R`/874F9Ea_ؓy8r$;@d*=A';NnnuGXnI>&{=?G[6=rzIjCtzYgV5R" 4h@vzL}
+"Oـ*, 1;";+u%eҕbʌ JsVbgL!pUϥFu^T𪥁gx@hD%2%qi+R]Zeu)xW91KSg^իwjswO:J"{rG\n/fmp Vw*,8@o{04ݶݖ|,ot;h
+ppG`jK ];`6/v9ӟځC$m^5w:uB(J)IV-3C򄓦d̘df-23VYKc2wSIԄ'xmgIl>!<\)5Pl}^쨏QcΥaSEmphI>ò'3քnq)'D3K*g+I)r=-EȹB$[bd{,ٔ#22/!Sl{Ex,}7*"cȲL0cqմ=WqQkJcB]|9/y.[6\C|C|cBR` sb5AȆt6[G#Z}}3]mv"ZKvU]M]PîCft&g"/#شo!x$m7UZ4b̸K'^W-EUQhe՚Y H|m3ZW7eԱ_laUQǞ@X !j>\}A&( x`Ѣ s̝BljL'CΕ)cq J>7 DB/!p{t ٿa=y"ZBK"f^r)p"t_-.W\#)
+}\'YX?7  1tN=(5u'nENoaCW$IJA{FC{RW>omrmpyBQNq{gL#.DpՂY܏'8Zs.<LAL%aVK|a#֕vU_VUGO;VL;'N.DO9D ZU?XHT*fdΆKg9nGF\ubUY5o~ǴNV;SϞ8E7gP'LA"r|$P%#{+`%KU t&zvUuQ{˓&fr3Hwea˲!rYh¼D0eRƛ5,+giq(cdN]XϞYx1,#7^1N#! ;Ҏ;?V;FoШ9#ݭS-ͩK%LaA^EV¤ .Y#{K/hݒQܼ3?+`@1ِ]x`0ooN aAE9a/
+çdk 3IJ5ZTIn۰,vpݨ~JJ߿WN})K X
+r RX:\Th9/!2ٟ
+WTAvkn*CB2ȚQv>׆W z"|tW#XJ~zw\A6N;PET'Q6M֞*zDL 5 $mBH^6&%1D=5B =}e=攨W`=2mӎ 8+=F zfɫK](*q>a*?9~*iW:pdmI7+A/&dd[J:
+XHooJ>^Y;f3D:@͎HӚs[+1ߓeE=?2
+p
+\2@1 a
+2LBYܗߋۇң8#bL/n
+e)MVVjUp %Brpz{7s}߷=q>q,Bi*޹G
+5Џ(ˆ%i ySiĢ|R Tlk+нN&:W !tQݲhh+@i$†) U*ފ]%[N2̪_ J<iHc"'QRoy"r[U@푺kAsG#Li۱ʂ}KgAC3a>{( >شd".C쏥morsnF]7ȃ: 0j 탱0k#tBvO*On4ڭ)|1oMדPR!M{;)d+3Œ;0NI=Я3Fq ]t:~]!7FUnt++Y e|>%= oA&_hc$-!j;ڄhm]BӃ7R{c.ӑw%CZ[ ꈇn%9
+.<3K)eC1^. }_Dfp>nX6iz=k]Qn6LU}C]и}+WPOPS9@Vfe?(tհ&7?C,yyjöO=Ql}#bv=vצˏ<Gj_Nse$q܎SSɅ?QzaNyS"0̰~V<' 銩t
+<+dFڤ rҬ0z\=I$I"IM_˔rsg7~L4( i{A*@Bv]h߰43]ϳ~4UnSx
+B)7Eb 8C5d "G3/tA$)DA{DX$@G~6/ dG}NGei%AՅ:쟾4⍳`NPUho#3u|##9I?37Ҡ:oT\e9`4hr-b~yqŀZ;T$uD߸yIݳ)ּ)#夋KtAA~~<ךǩO5s^jQ/^Y7[L;.ԖA|kJbU`a-8@jE߁/'LszMudċƝNжlҒ$6(/a]=Мtl!3SSjʒN>2X}h&.?pĽ@.6d6v'ֆVP?;, #BDBM!z\љQYWa@X("#4b/3qEUrFQ=w^޻w鵦}BofxfMο{wj[s~$W;Up^Fn:U?/mRu/H/J]y67eU2FTTHk@Z=h qAg|I|G&Ν\t:/F\P1 $\Iz H/3bl9 =8bXC:DZ#y ]e&:Z>K̜= 3s.,y`=#E޳Ԋۨ׬[g 9 3M!_plɩ cC%+hn1&޲hD0H$mQ8;.\l@n soQa ?
+;M@xOAb1ðF/Yyt
+Cm
+F& mcI>Neb?(V?R_ާAӨIkz)}PxX3tH=,{$Wu-tfrR'hGGخ :mL?(#nc?F~\:dC8l9aPu}$aS/]
++M~-}bF)xmESo9|s#?&nӚ:@q'AOE(ZW슅;}X]O~p]fY.6Bz! sa՘+bX3
+x717^8'fpC%E fAlDw~N&Vd@5Mqȑ]7CYײ8y-MykY~0Tӣkr.H~&rRj|2t4݉c3-Hl]N:zvƝ
+\9q}#vdaٗgH$0
+UZ &*lBpA`DnPZz"B™s{9sw?
+74@ y'd!#YG08 'r@'F-h
+}yet@PlR'mbs4c"!i#.0*|qOev|ئ<[{v 84cMgLe-?Zm܀H z,7tP?7j|(|HyahIÃSCf ztoEz${ߋH'(+ eor(?QtS]uUcS+ceSǏt՝Ƚ4<Dwm!c\J|\ލӛ>oWtFSdfsbۅgv-Dw;H |xzCxJC֛6q稤9m}FLkF4eD^  4x?. 6+~O+|ZU&9)vKf1vI>Hjou_܈Ձm# \NHN'̹Mt=%9uXg\L nv+WFx
+EbC# n=bsF4w
+?]ђmkWKᕗqs՞K8iD½(᭫lbɴ,y2gSv&F]cRz\)$ߥ] Ϻ$LMq9µqi
+)SkN%̸8tY <)ьIᜍ?eQW
+;׃5 %bWy{iSAjW|C~̻ˎ0'ceT2 SkGl#>
+zy{jGZ˟S 2\PM$Z
+PNS/A6ni嫆\Ѕ [{`
+sf.1}"`hsgռ Vp{Y5sl3A.KJKʐ&G9=5yM{G3JU;ϫV)ѹ/a-٣9M+FVO|N"PtG2z DH=b,*{ǪiU_\iɟF~]vѵCU/%G' (OeQ=N/ӏ/PKܙn;2J{;b-:@.xj 4 jP V[ZL"YI}oQwλÎ$oO$S[o;hA>0uKܰVک iewkyzV&e_} z.`-u1{TMZsH1P?'l@q 3Нt#lHgCl/Ǜybu >8@t]fතf[r'@xz<"j3%+5Xs/VZ}` ѵBe;Vy^gaIO1Y9 ZS<C oo!x NjIhN…
+P*2<yT3}QA5;$$aI X OZZZ[T
+.D]ܵUq|(
+n(>0==̽7spThU꘠|V\Nu{B#kL3WB]T]ȣ'jz2!BOۚJD%bQL%di3qAD7N%VKլ򪓧
+¯1EDzo2 Ԭ@)i^ň&+ 2|kAi{ xM ~GK1e -#Q{* 0A}c2) }kq0tȼ(M]QgQF9\-Qgerҷ,ˊJՄ_zq"ImVOs: hDߚg &M֫R6Z&sHGKc\KKH!Ʉ}dڡVu IM,G_#%++yn*P%<d.*jŌF1Q{Fr/*[/l]pY3/,xnW)zk_!|cW"Dgbe1Ȳ(\~`Z@4hX6)b sF̊B-
+PNI|2 4b~BYKuh-g<n{7ekny⩻ Bݝ 9%5 ;]rVec rښ%#S5o `Ijo;}ha9Cg<0l[<hӿ03AOiTR^~v\+8iczpZlS C{g0Xp!G!BАp^,C37Ye6@o \<C90NIim76[!mCBqdWQmm} 쯾|WX)}kXM_<?EՍjjߒ-ɏ$Cl¼?m]JX 'mMley
+Ny <D9f;pߨW ^  YIo\r$=սh6o=(֠@s&\GYAy^+oz&Aϻ#;=wϮg uE8r.*IFM3~kܙn=g8Q5 Ĺ>&퉣<_CQx8g3 u)"Ž
+;m!=Ӆ+uT=
+$TDEo ,X۪'`Dy>UE@D,DV;X;3d&3fBn\"W_ǚH^ƙA2aA򚍗ZtA=@~'m\2ńZu*sṔg5.cAq'skAPǽ kJ&ڔߴ8x˝_w9O&̸eJ\U3C+P}\ҹhcz|ŜmbV<g_JMa0W@}ɭIW})˜{3_qXy9[9r8nzCV ߹j=KU_L9Ϝcʉծ<@f:/GuȔ}btҦ`E`{,+HK:<O
+KD@ԏEu ǕsN' vŲ9B&:ɠmh~yLo["[+ؖ-5ˏIGmԲ HZe 08cn?xdE -T3-f<&I?#.TBKPV[{;ݳ)i09@Rvz} kI8(^9 bckJiDiB "%Bqs"3?>q#k#EwʓE]0ts&}!i4w6--)0]K`|Zb]
+u_I
+k#k锗v-:f(?OJeUlcTmsΦBT(Ir0
+l EףYyڤcHHeV%
+cHCC3ȏ""O:_Ws,ʞ[gS
+g zIM]dpExqAܗf~riRϟjGFjߧD \}7J-LY gRX;=Z)fK{&\m\s'z|ڲ 8HD GA$U (ϴ|ǘH?49+ᡪ Qs,,{%G8BGkM1g 5{
+ܱCq7
+Kz_.i}my8_9o@ ݡ!Bo
+"H(*- Cg򂧌T}7Or<|tkjYlAfEw bmSu''zɐG}bdGe#~g%O$_//W8Ďۓ<+QQQs̨y1c8!M
+x
+|EØ3x {gf<{D4pؠ4qqG#
+s!81la Oit Kg|B <h K
+_3d>ozw;UMpawi;'zr72Z%^ZU²1ZԊb m9czWnŮ~|}[솳BwAU(d/b8Wň
+fkrp%\$|q
+ⷑ@ę&E޵3]⿸Kǝjb]ԉg5β+\%S%1R$6f֑hr{<ⴈgX̓ ALcZ<`bQ gP`ŠvabqZ 0 P+LȲ5
+-kDZ&>G^SZycshrQQz)ǫ?jR&mpܺ>Jaw)JKSu$ U S^^BȐ;ҽP5+NG /. %olrDÖE1*8THgT{!B?F)Z~;H_%BĬA5"B<x"ar[|K\ހ~ӯ^-{,a%IIr\ -fsͣ+?P3QGq흛zvku>S0K|ЗsfLDI6k&l<$S??ePB5$jzQ;Q-Ň{6 bYd?9_+]lcZ3-=8K'azFu>/g!yby8qM^@%/Sؗ[M*j?.,bs x~pKy/C|IׇnTaZoU_W-|^^4>yd! #ȍ*s$"n3 i/HN?ǂH1#=o=}fȌ`0H!06 &s1frI%tJ:m<I2E!I7*R%#.mwB*ťu~kyͳֳf֬S<ddw1y"Lqw1& Ŵub.( s~SL?̙4%g#+@+r *ꁠ
+C^b܏~+(k!f
+293}7 ŭs4U Qe3ݽKr\w?ӯN>ݴm"ɄmZ1"шp6]SUqz㕭?2/or)kbKeK;kRMWeqe}s?'n$lK^Vj"qcOƻNt<*pF]R`5|Ϭ^x\VƪDRkC]l`aCnS}.*(,:V~R{U>ʿUEO=[3&V/:(-a%#Hh0Eln$EqΘ^Vb\0A.9@dY
+V8Bt~ +@IkAs-ʳu Ap.}|op2%=jgHqS^t^'I\0n
+$,A_1z^]!'uxw]wO1/,J#w%9 ,-e/˖]Sr/wy/DTeQдY!;}_zaEaˆֹ⵳_s&e&$:bFU{*ZGUooNEq_TV-Ϝ?Q1穢>/G`rnyY1iQK}?<~ɞyOh'ύJt<١OŁ"tb',&ʹfi#SXq{X}{x:ۙ]lB>3*yQ1ڑQ\}Z oSZi_5~?jL.mCoN(4cnSk'Q] xD\Gt"DֿĹ ƣڒ8~m^+qK|Y _jyT
+ܷ,m
+.<#t|ՍM77i6ZINVoG&OTSբDVMCVMkqQq?xT\֘7:hGy~c3Iy^}"λG4""C\MFGqEh<S%{ÊAU_ܪP87~P>\$ѶP~Qƕpd޺X)jc¡aV9xϪxtUaVB|)x^Yr)
+_,=%zN۟m&̉@xq?ݬG/U ۓi2[xLQ/I 0–@  aBDjբ`*LJ8j_)/RBQ- .D}+UAwy~ɇ9}_q8sh
+ZLe+xqEܮx-q%z]캪wzD-8F-> Q5!~?~(<D+N(܎&(<*x~kG_P<c}̤RxWAAV0G0N=7<6L&
+iG
+<IԾ]sT*CZciWDžc&{:_S-B)H? )z RF ED
+ ۀ b13i\^-rToDܷڳN>sP1S0D.cC1w8laظ(qA಼vyI.{:ROFEZ|6U`uډ
+p"H] ^D#zܱvL|UWg9y>1eudr
+Fuuy#oU
+lhсVM lAp[ $++92T+%lPZrݞ nǼ[8Z3@h(u
+
+">aMd&ɸGHYy)r{rѴ5cq/]67n6vAc%AkΛg]}{X/o]hT$9r4n1ռMoiΚؔ9'o̘6f#6ƋmQ.F6n\4} -F})ٴ ߃'\qYd:*D+NG.>zP:^֥(S~KE5%k+&=_!{ZzB6OUx[8~TcfJ&&y
+$4)3 h +9 j,y,g
+B#P8#f-+ a'2FN%ɨ?\L
+B"LwX_|Z 9~
+Dv.Q? D*±mpAp,F$TU4$b} )7?{(4
+D]'w"7W # φ#LAk !}N D/퉱}xh9zxb'^Xkʆ(1O:yonݱӶ-du?$KeKvW*eyR;7Ŝ)FUE/4ֳ\9cWE8Tg/}uĒcu;C9e,9K;^|#Ӳ@<l/1/1+[.{eUpȬMMȢ!f)
+u_OΣhKs5lq}qc
+
+&A\BwN&DWۅHt>E< (\HlB3QʅLzm-ZՊssZ{k5JDܢY|[9b%4F (i wWV#Պ I/1gV SNׯʫOVd/H0 8јGDN%JEoWG*јsM8<m YG1Ҵ(ܪIۣQJ{eqSN5*y7t%My wIѲWg,{?PdS ru5\@!d0>to|fY yoL*FH8d
+ē'k%SldI7hUͳ6i[.Q9
+69|x? Ϻ`]!J7SϬJwLsEޡL8P7㡘 ߢB"s91b5b |
+VkDM.1Ĉ}L4r/Gֵ8ACE>|s=dxgO 75Kx$SF/=jSjs?ΠnA]{ jb?3 kƑo~8jnٲ'stnqLO3An$蔃HU~hy?'
+xc샽ƅ>AOMD<5,Oj}NNcډ
+*sx
+>wqG:{O  8]8
+:! S mfnKvQq Zd%۷J}arȖn7hާhI5DsNkβuy.uX~OPg:9W: 54XUv3
+M^\y6
+*auj[n>わWLhi/>5_as>+֭Q(2 7n!߸~"z>k<;H>H'?'K<5.9=`OW+bRE ک`I`r`R5h~+#&T\JE ߕ0lW(q(Jq+M:⣯L:ƔI?3$*ݫȥBtM2֯k G>l 7o rsfx
+ x#%hc+360Oڸ(K t"Ch 5U΃ Bj1런:;=aG[;aત0guqXَǦy'Y6ؠ_:
+967,"ӤĖf \{~A =Ӥk:mՄػ߂?i
+\əu\)YZ\G~Z]ܶsm>}[ܸgfW_?hӦ_(oBb93#C[w2I^+^{vs)DYO{1(IF#wvASI4O}c2z&Nz2w='\D{z@~[6M:#ߓ9[݃?̸MBFO'yWHΥd|7ﺴ%Md\F2̷!ݹd-ӹy)mWIGbJq[ηؖ#[M)M_Y-T-d(yz{3 #V_V%LR2i_N>9Y]?e^ޤ(QAaS)_OR_TկȔUà8.T0n^nAi䪊)ќ9ђSc"&=[p;RЩЫ~^&-F,&#:_BD~4N|dI R~6e\k7 mL[4AMYddxC|H+b7Eϫ%+ KnE:]T 53k'Gcw\h֮VXTJ$uÆ%ﳒ3$F]F/gUg,d]}粀[y}K#^j*Խ(qS:5RyOJ%ޓ2 zׇJ;ܣ;:ӊ<W<<TL9j1G  *CRAkeD2S*a!E(H*!v؎7=!=k{ks?ݏR3~OjocK{SPH} Mh
+|N7)ߵ(gKl}6'-GwhߧK:e눪U"8Ki8 jpa%pP>W20.2*'c
+c?0s0ٜ
+2D76+LZi]!^*mim 5@vR'C̰5g05ceFDԊ7QJL{jOsSX׮$*R+s/A]kgzC< e4m" v˲6b@/n=V]=|K!@(O@H0Vf\QMd{$NQPQJ(BDCqY@UQ@P(Udذm]PTw'{&fNN˲{0q0!Km6q!i-,.aa=c1Z%rqrǼvLuʼ|e kP[#rr%]#ѧɻF4x>TMSIxf).7Hdy>(Эflxd Rt˳XaJ)c-J,j[߶NewŞ@hQ#{k* .OZO6i*nmvO4ںk֞]܆ߒ1!lQܲSS[g:gid|j,u?|g&NpG
+ Dޏ:
+QO
+CѬ DrZo[*|G`+&k
+ƬJg(eeܪ*Hf?h`ZɒHǘ/S\\F/sOOqPT%&e5-_,Λ=W h3|i
+I> "kB+~*eF %0c\/593ePL\@alj?]Q6jeB绪GE1br- FmXsCo^W:Ph0~fˤa[MsR䖂u 
+!RrsjgZG/>.n
+1?PD)?}6߲?LVfO;{瞝S;z2&wzRdTݛ!Ӆׅ܅")rAbzI !'>sL4t;+Q<g "ȼ Q )>]3
+C:5gƕo)"Vk2vփ
+P{ |:m&g"ܓL\d
+
+;
+s6lAz
+¿\9Wzg`|X^
+崣^;W^Tҡ2Mu7qRɄ ʰ;D?M<-叙01>io A Vnъ7.ܦߢ<&}mzբqZ'
+_/kӫ<,i5pP_ wQgT5ϻgV#/k1kl Z]RӚ9 ^n>[|{Ӧ]6>~jCCܳ9)+kM₎a5`9&-ڕ@wi Q $k fF̋ Z"1<NהA(3u+ dWc1cf߫%xtB
+BKzJ"S"Tj"_DvJ"w9O#4==M&BkOt@5eaV$
+B#! HHX–QPqFqAE`@Q[AYl3nc(Hjn3uK;Uɫ{N\R:]Uɯv *y%ԲJiͤTת֫__7-{jլ+TWKh\ZrZַ:lj1Io\dܪNձcGXye RcR]NyO<uM><ȗsvJ.gCIAhQάKǬʣUFٝ|a]CEa}&.dwz,Ku$1y|K/AW3- Ԓf 56r W۞P۞NWFOq*eSJKgr|Qu{t^5?ٟNCڣ)R'hR|SJ
+Gʏ)oV$=u:U߻$ħܣQnUgW+dN'd|q#r:Z\*Ծ Jͅ?Sf?1͸Z%i]R4zNBM+} .E3{0c0tu"q=vMnAwbډV"~b syDr3
+z<^FGpas5f"c#42|al@b+\%(d$1l?b,!"bb\~ zӹ̬\84flgm[z_gGc=Q'Evl o>`#U77g3alM&2\|
+y)ZBDȠ
+*(@ l8WqH
+GQeqj<{NW'pw46.+m74W$[p;#)aY -Oμ@8e
+Ҡ3_Z_Eo/t~r(X(ܥ-tR#Da7)Ò90iE(4)pp=[z%50wr1A)~yFr uo%̿F52:%u ޣzGe_ϼ=$> K]HC<RӐj]RAb01qTټT&U:'Nv]>9Bq%П,f<Cv՜IZOx+]2P5vVَokHw? %SzXe!Jy)^gh,N_R:+s=+N碠c: .Bxsu5 _ -PԾ
+䉐׎['Zgk4iAiF >^tc=B{@Fw
+cI5SǓ8fڿa ƷlI7Ra̶on+$is[S6m%|c3P%zm]QEy)Y1IQYy>8rDTKZ}Č-?gHEa[#z9Qꁕ^}YXċ%UU1ZiqAx4XNYٻ8w07払4vO oMlܐ&An*%j=k::GAB"3#l&O|p8d'ǚ)W<͸:+ΊNxK.UU_5i_C'|tL\cpܪ*򪸏1|eMpri@aS2%e)2Gy~>-T.ßg6ג3ٸd= Z|.ez*)?;+ԊM<`IĶa,49ì 2k2M Ĩ ۩ߊe\Dz b n`ڝ`~/Ϭya®2;2ulev,jxJ&"[04 ێx_-b&E%`'t2m8̮?2Zx^}A1 ))EJ)uWvf`7eC=%'; 58ݔv&6^SWOw
+ph"EAe9qS0n!v|&!CINh^>
+yB?!F|$y@Pc?4/y9`v+ g7wZb1=M3, ,ÒaCXs[$h r]>B} ^WK]1|U@
+:y@byf_jtBJ;W3SlO.6}3\/ѿq5cތh6s} 4>m4n>?-KV+!X|&"E[cуĤLD|"$|s+dT;`Tك3}1N!ϋ"F\ئˉ3 D=O
+< 4nQf2mЂrq;4
+v}fLix9G+F>P m!^ }ϤBwP;}6s0 _LS$^L]}~LwXSYCSa
+ōٸ \0㋎o^{Vc}{x̨<F~zcJ]J{Q5!K*<iz{\#?PF|[ wTs=oQQ6A-wG)tU4(yR8rRES)ҵO)%knP|Z_L}F]1#^sZ'_tO1?
+Z\yDŽOI-v|jaOGλܹ=}~G4Ylo\ԓN¹q2zPX]PU+
+ÏQ
+BiSHrV8܏෾d\p1GL>>IxKp< yGFӚGqq4iK6>jH}O%ʽjݕIa߾M
+Vk:.7|͖-vy΅ }螻sIļ[]ڪ4Ia %qqOKL+#f&jy |ms 3׺϶G^ZTqc [V2[yMeشi`֪ƪ&e5o I9Q,KOVJoVRvum̹b:pNK2"]#w#
+w;l}:fau1ukOޮEp"I[Sώ?Fo)hık{h{(N&NDzRzmu>(sQsѽʬEl*Yr_qT0_V7j,$$Cίbܧ /ܺ7aB'U佖L!llr 6vAy3ڶ(jЊ: ER[л7 ,d8k~e1m2W`v7Iװ, >,մb@ e'bJŲۃ| 
+ܯ[x@%*0 "G
+!WQ:BG)_߉0!G<ː[ڇ *hՄf9
+bQ_C ď( qDu!9A D=!3<ް1n: N$ijclv:j8~
+&,,,CH$!!lP:#(A
+""(*"h]:j
+ڑq,(U,R|?~罜rOs  1
+lFZ׫@@Jx-y s"n9w/4@Ok˱K%1(5@E8 %[{č:HF@v%=#r=AF^J ϩ&l[˱ѫA^`i"U zU ҫ5 Vx 1Q} Ұ@jF@dxH/|]lz~|r<5jA'-Eǧ5
+~D5~(t^H f?C{N-9;Ckc@&l7նods̼w'm{RW6kNqf 9Ӵ\6F@3O 7*`+*bS]2ߐ-;)S4Oj9L'K3l;y}ڻS1ͩsa~$}^ѭY<b<DE$a`oS
+(SqdSp,ųVleUDpP1(S.
+f3qQțA\ 6Zk F9ڃ S{HLl̋xfYulަ4[[#EMtv,F̡X-ڏq&HjHrbaη&q]+
++Qc#߯Γ[)E#f0xهtq:`N
+'I7*
+x2?eJ{7a}XV}cZ{Ѥ
+]_p ״*拥JҜ<-7d(7_2gZʚ6*}ZV!(X1`(gbA(2jXQgK=+5}}3~H#1EivEnl9CZ9fG3yr剦&~<My.CǧJ~r]rRCbI/5_5\v\0D9\*]Um:jQϑ%{Og!oz/Fͻ>'\JInIhOұ{~W瞙>бgv?_M2:@v wu %Qг-smb΍ZٟcDž_ [6JM+0r<d_W@iFI
+(BN?2!) CRq;&C EWZ З7uhs!z1qnu19OOO i߅%_KǾ1u+c6;K]IP?<-8a=mag\ݳY?yPp?-o\`7 Ŵ`vyf$kτͯ:aEY0󔎛_~FW=^6-ZQ&p(7*s
+ɨu5 uԚu1qOu?qbdG_?%.ėPؙx\|:1v)ti@&55̠-
+y )~΍G^sk395e+uK>ϵI,eֵ(mN](~I9q{Nѷ۶SKcpcG,z AId4ZC<$ M1 YN Y `rz$GͽO*&mmvaYntXq=j)!Hm }$C
+]SĽu|:iIunTޯtQ]:/\<<uH |HD/K`YTG+A=/<Wrb %$#ϸi7XMccCt==iaW!XL&Ff.ЌC @3@UǓj 1^!PmAh;,AE~]#HWaɗI[.+z{9.JMl!ײ'S_6NC՚]m +׹H<
+!&y&z<$FgL8l Q!XeQ[Tco?-a͏mXbK @8 cbxY^uDsz ղͯA";]6W1mhҭ`(;ce
+V>:e?vΔd=IQ?9ķ!d' bnX|^,}m\vź"a^?pDd_;V'&.ǒ]\xvkafnV^mG- .ܛ:l9(]@dS;gU]5ԡD
+@L@ZGo [F7^[p5W/gW6M-nHcr7,3&rŢ]Iir >ItǏ,̬"iI8Y)fݍm>n-IQ9/RαH[Y_Ew\7+X*cqM;;oȚpN+mF5n k UX?)ş$6,3twitڟV7mʈOQK*b歔[)%YV߲ cZ>mZ9iQ)gl]h}S㆕Ae B& ELEهBYUs#Ո9u!Kڀ̚Eڐ%S"|#-)]}*kRrV,wK;$VztZVj݌!̓^3Z
+q'";{B/]mg
+縼Ú8`(MD J ВS R]PbC`w7"*
+
+E ̨w]G\E촜=?~Isr$ ^4Bv8ЯƢl<oܵct ҋJּUKzWZKݧ4Ow{Y|^MaC2>Ve^NoKM%u:3m&k\՝s{A
+
+&#}հsژ5`̯\J8ǁGP+T{a qWQ"1% eby`zb!֤F!+!J;NjEY S.r Z.'$.D&E4Ӫq7'EI֔v{ʀ)#q5=Y8ɿWeO5.jUnfvf;}=WTSF%`
+=*Qiz 8֭EųwsK 1G`& }
+๼ Q~0=>x
+ m@xjqĀ>B-;"-\~vÉ%,NM+7ٞd <0'
+Xhi7ZZSStȔNy 2"r2)~Z^jp7FϟXYj{=VMfn/iin^/T{USTx[\Cr:RaS6˨}_ל6f|}dń91 ,qcmg}ϩ9nr<cP=P;=~vn´T6!s[R*oݮHl1pni?66~5̈<ϩ][&)}*~~ol8/ti gnED.j
+2xgp/.<~pLI@z?Xfb`?bv`ٷ!pl뇮f`_b!A`(;q1Ú2@n<6! <b y%um3x<׻33e: 3>0alvm\1c ÛP_*.xN5yhs*}]xe;=$^ˀSO5!~f>-YC|:0yc]e^k]7cWEiv%|A+ROʼnA'T] ~
+
+endstream endobj 13 0 obj <</Length 48408/Filter[/FlateDecode]>>stream
+HdV{P?j">(!GM5ƘH&F|FCD`wWay,,.|~(IdmGH;i'SKw42s9wDVB
+-NVtQgm-=lQjZV>7ۇ&nXn0Tl0fgV4$SfWzd􉵞ސ_X۠b>`:8>aG#7oߏ09zkXlVkRavm=,m]|3׻:ws5_J2 >k|\#N? &g3q!DgSa6n#/x8Qlwx.c,wcBzZ=[6ikٚ,Ls&x}dC>}C >"(!Z{oC3RQ.SRVѸTj5i4Di+dh\qY
+kH-S&KiGзx-y%YVP4ZzTofn+M\?^ZGU|4Ǩ/[,g' },%8+KЯ5/r̪w~6O[)UYDL>\nۄ17C&}ʠ**¾s5L97U
+G
+Ь(,J *Xѐq9W 6e) `(gĹ.x{緻3|.huK`5v{y2clս,>`Ż )t7[z3,gGjё:S=j{]>
+/5 ~moqˑc2aulb~/ȭ
+\v1~擇9d㿕oox:0)s V?Oƙ'# sg
+o55yx̃o!Ge!/aTcWK m>%bOE^KanMrǔ5-[9d6tx
+1!fbawcm|}ߵ ]0Aɔd܋6!ޛ1A(b kb B&z b㓘lC7 7.Nܑ;qhElc#PW`S+pPsVc7,,/!lOTی7}:>~ 1sۀpUcut.Qwb!7YVkfTFTzG S\r|l;- vs%Sp3t Uk٪ UƖTi?o6kc{+MvKު3/i%:`&%-`lֺmsoq?.i|]֛Cþj2F F :h?Zsatؔף?8kj86`S[oրUta4Y/VY:6l3l<YǴf
+ޮ^16ZI?`~zՏoV]UZk
+NV٘-5;rF,v2w}aFeϷY#b~N鞾(XߺU
+?ԏ[ <0=1??(?ء # 1nMfdݪ;IsԟKg'^7dVSSNz
+21Z*>ڂ2cP݃AD<DB]!31;q,N+zmEKCx{Y!_E$̨;pm2+BZ ^Syu`RP[2m1jJ_*ql:xe-z|z21tԏh5QK%`\\] ~fF_|,"5<fw l#D(ݼ!`9x[a].!>@GǙ'Qp<_fj7!X58
+u!;O}|/>9*dT9WlruwF:y[lL'}_TZ ?u?%~QΏz?IJ_[S3}GU<J=xIm>&}dçUJ8xko;z馣uϋgE'^>Min䫝 '%΢#?(ÿJN}5KbJXَկv~VxҲݝBinagEK*KVYl3XdvYwFٕ'{kOK'I OJaڏ \Jl H!nWòpkw`9x',yPQS
+OAnZ9+m߅-D.Kg`> t.<B?Ŝ1'X(v&13:q[
+Ah4dҴMiLgIiZ8w17sϽELG;Qy8 &2u
+(f벴,8_
+n5cN5)\uNt ,vxyor yákh,5ycVb>53Zq֍pmO0#AM7Q+i޶?xkjп mx'^`5BpgHF:fg^Ca<hn^1ҏj]aPW5U~tWwrW<צz*'{=S>G`'k:c3fxF<CKZ
+JC=N&\6p~GM؂zRjvk
+Tĵw5=&G8}^|RXٌ=vO`kZzm+*)˯S4Z9'1 =) xn,V\Q˶o~-s#/
+ ^~w'NMxfzCuoMgLoj;0Sk:|WsZD{ⳇHt&?гG8_Yz\Qپioev?m:U}SWkv?)=\ZๆŚ'G.΅\4w\šK%~(eg\q泗d|l%gJ>|8Zy5[gTV4ΊGl;1~ [΂簭d{'c^;%R|vզi=^8;87mEf¯|~)ч3 L[`E)mA ^q~sq~r 9X80 ÿ)K&vrJ:̱cP]E"W\B[ȳmJx_?(bukr`ɐ6;L시5pr E@|1OȁQм a?MF΍C\F.
+v$ 㜯>
+s{a)SQWP"[Dc ,Zb
+Msnmu܉P4œ`hpajTj<-ӈdU jb\ 5p92q-X
+T|ų%[!ְqf ܰ8@;,rv&i6P[Oۆ*rξdNZӔiz-װyԯl߱߄G,Aw ֧
+L'CS09e'q<@eb-gcN)gfsIX(EP^m>?qEo:a ۷y⮏}YʇG~Iг>|vlO#fͩ>^=%Y[ gF3!xws]qޙ5۴gw GvK+r~[qȯ1>u/μؑŬUL|>a#]%2/q:͙}/ܧ ?ޛόK Үd,2g"J=lo`-Rt_}ٟ OS>\-;kr+6}~`Š{˲1<qf ,ķ8\bP|Jb~[<8p?dD7&$}2O}9i; 49g9=Z&Z J G7q=ӌxA Q΃`~՘)?צ CC?Ɉa)bلla,
+w;R^ij B jpDExbjb!īĞq^*C֋f墹V&Wrk}%9S8.mZؙx_.q_eN|ﭰX1ɥ5spqoP&Z6.%WwU=*#CP)Jr'_'Gu=ƶs6lH<OkoNzhOoukV{V8/] ]pqk k Bp+.re\K8/$cy w nFguf-I:DmkrFO$0J>#?]kp6]4\{
+mmͭoahS&'
+sw_
+vY;0P6Gy
+A)J@RH|WJ\[
+#[eA|ā 1fI ?E2֢܅{$K֔D#v-0o&cFہMW^Pbyf|A.H`^!?r{0i=0O(`ԛ-r+
+GQcr
++_I("T
+\A6wL$~I2Ja4̵|~D;Sp>їX{
+bOIbK 0 ˹-'ybQ T-
+n?r"Yb3K܁଩',JAI_3'"Υ=RPʷyD ShJICpzFSo*y<é9]3˩ u
+yp6 -2A|!R?Q(~E 򴜂w|( 8qv<:#}8?gW!zPKM9>}w,<wNW=hUjK}%S^k2;PrqYffzgżW[,Z9WD?mkr]Uvpw\gȏVdcwԚ|/
+5Vd^gegggbt8+&f]=U2{]}wV ݧ%1C{ \Xdcn{]< #}
+m P+̺IϏ*+_^u66yx#1}_;x_>wL7|hÃ{;L| (=6iՋ<a z6$,cmztco {Z˦Ý'ny}U5 zr.cO8ӅZ;L_^ _3 aJ36 p?B8tL}'Ō 0W-?h|{{gL{9/1(צ&BpzpÝ ΅VYq#eij-3ZFqsp%BgĎS(;/J3hA,2~I D+^FT +!
+1)imNZ<V7
+ܫB  MHq`88?>x(;rwr.U
+4]A6/ʴQs*̢ܧEWwon5Yw-[um-v=sÌ:}h庮nsWM73جЦMp7ovfkaFiVQ^a.Iw4Y 0{
+G9$Dh\C> \g
+~?210|?CoN#XXJ BDP4m<0f
+s{{=J~ixO0L,l@.0D䩖{ ;J
+s(4?6*(@Rp9/K*fxR]^yUi|wމ˫ܑ++Ǭ+6ks3amQsD֥Y7Wx/6QCœ'&}%%~@IJyBBiѳ@Jߦb^c,b+U0*fr0 %-((9R=ϑMD6P
+!kZ~Xhsa1)a&zwM7G?_r^;x~i00~rM82`cӃ.Qzp}{4cfza+nT$;M4Sy>ǜ㪂?V7۴' :Hi7E ʖ()rZOOOa3~P| O՛7ve {w<ow=e\;w_3~_c[:.NZskr󽅲u#B5x4}8uZnΓ׺swuh=s hz{-\Ma#("q:s)yLK
+*WN1nXI߹ptԼyXiXw)m88FbDŚRSKb̿(O8Pc9}M?54Ogޔ]rǛ4.?7&\;In -rga-%iK''ԕ<%}߇B}huEO&/97ԏBI
+lVk]piD
+ºKJN%U <@G*߯QsǍ[ufI{:!Ը!{暔4Mi[)k$<Z}xdOces
+xjN'%W3{M{LUt]^`/ʍrcs4Xfm+p5p={^Ϝɬϭ ̓~h Vnb`/fffv e~6?L%f١gэGp;3(@߹As֖VfN!uix㔸K]&sAd
+{S˰y/<Dr_[斶ac[-:ZͶ^n鶾=.f~cA
+80
+](A8k*B< ^zoD
+~
+x20 \EmqL<' q]2q
+X0<=2L2<*X$VB)Ra GjƜ 9p,(
+,9UBhO Q&MƱ :8 )0fl)D69ƭOYߡsJ+'g|Zq) n2zGo[c6Uyg:^:j!ᩌf?
+\_JeUv-
+(. #.(AG!5jQgwV\l@~ݯwp)b dtԤG&ESs~a2F ohaK97<˄6˺aũ(Y` ln:,ux- 94R
+TKf%z5dd||g737ꡛGoؒ?~]YŁ-Q|~珦rmgPqm>"_>:w`[[\Wj{i{*(U8N>g轀Ӵ,1P~5we5M#OGK]Dl`S遽>ܴW;syipm'hˮg,r'&ロvh*5;ѽjkIʢ ~^:[)[X;OSRtcƲ;.F*)- ,^
+w) r9jĵ"ėF8[Kq橑/pUXOJ.]~%>*DPT8`OH/E= (?C)Y %?@*x=~.|\ǟ8h5[(G=G%ÝsCNy(t ux MO% $Ph5"q7C#ɘDĨQ$ŧ7"\XUo&eJf C A?QtTwTw]YCp|Om%I8wE8f=3Yfo/ ܦS@j5O?Ov&F)֚ⵖ.Wu"1Yz
+fZ0ګ=\2K
+.y^bgfE7.?>-8̭L/5;ϹgN\B+F8zTٔ]<Y`l_s jnjY\u85s$]SmnwtW5xݬJwDoFᇗY6N޹b*{X0w;X{uowZxfNQ2JWk^P}bqYh8ij.}=.f#isF#1YuxУFq%1g0]qU/siir֘ty qz\ua^26~񲾗5RJ WHfcXmVmse+>L!m---,Z},Z7ƺeni1VxY'X.EJw{ mfwpWb~!8]\NuN3A7^0{݆N+j5Yk34_EܠF;״4ZCsuj+[@]csSjFsF^kп(٦}3e4bj$N41.(!n܆ظnrYA, >.w/qPB ^KPqcw;U h=@ȅxY|2n+hcy
+*TI}A0|
+/%}BgCpv>m#zI~LqCT$$YW o$h#x l痍@9dƒ_m kIL"y/wSe,E&Pk,Ad ȯ`.}D%4s%el-/(o{Xw-dQ0b]~uIƺ&ӏ^{܊YZy9bsrS):5ժa4MtQb|Lh&-/e(aA>g2?ٸ3Ә ϩg<r
+l-Ĺ_s#K4)jW'a{.<O+~6CEnM٪?.d9k<k8gܗU|{G)?vNX>Ხ옭uj٦*Pr]= ty`G̛gp[o:bLpK F@x{>2$ֈ؄Q7$ҍb_xPؓHq?,!,➇Rԋ@J1^xʿM'ޔt>`L֖Q:bY:bz͈⼥ӱұRΩ  1;1}w݃pIBz'@L~OR<B1)J~@ ~@Ic}2I)S(B): x8 ?)pt<HqrI)q9lt$/x)Hhi\B%b~⸞jP,!vБhYPT 3{fҲ锤ժTu4z+ *%Ś2]lVSoU7-5Jh}.[mW ݝƆ=d}nem.~n֪LU^~jMjAՃ:A 󋩱G 023O2ʮh+F3Ue&>|UlW` <> Lod7U::v]{[jUJ7t3;E]'js{0Jln>S ՁMj
+J % ^4iw]#ДEuAr6^ͷL+=1}OFf? <@=Z@#ákrk\
+s#eKK ~uk8Ii=Vu?"Pği]F~&x.pr쿘~ף&Q>Z|HJ ).[D2f JY.g9ϖ\Rg( ^J"q|檈bZ
+o44tC7 4Y$ĸΠ3S5?w^c}{{=[KrNd.ye7׵6䝨s[[Ri`N<InCM;y>-8}딇|XeZJSms:Aȅl;;5%Έ>B<h)yr:%m?8?> l QHxAQԛԧԓ2A5.+#rP灱d(CLY1%w1=#Q+BPC<F\tX:SD
+r[:kdCKF^zdր#"` %k"h-k/'ZX1WҒfOmf(qca)E~)ٞ=WEm%%-]ך5eM=ŝ73{BK63˫tm̋ :XC]ܣP]b]T-CV__Wj w`Ma31S9٘[CFa(iW2
+t7
+zfZ^43W}
+ɌScם3ֲM|pv%o7
+$̥H<gf:wMmsSpc83(`v5ʞ*2VeS5G+4gƪyڂĬXqQ׬,41سagg_ ŸYya7\j՗ ,fHUmso5(4W뮨"BC}g0tX5tfn8ј^5 ZCcu3C==]o >+S JL66f9LnbwňbM>
+\/$3m>,'
+Oޑ-,$:Y[Z
+
+Dr v4=#!%4s}#b<LImo[v %-%V`I3z79x<&DIdG"9,>l?UtؓOlPSfhavId~Ҭޤ9OPr(!kJKԼ~Uۿw^}1s_Kutl"|a_Trp #5hWj%Ɗv3LFo yw(|<¾7wq?)>w|aT /.a`V]
+<gR0r7X3 e ?^_Grs
+F߳ Q Mʹ>ޣ/R9>HGخW'J?z#I㗙{>z}W;>|jݷ6FqZJpDZL%{~ۑq60EnMWu\1ҘcDhM־}C5_}nDo6|vya-''c/]'f=(sWŽmԆ cߞ[{;oղaGئO[; x;82mkYac[VJQr
+)=íf-ݭZdG*eި2Uzo~_/ME/)Ÿ3LHUR"JiL PhÅT4*RL(m*oQ;Do cayS804AH+e{? JQZJ G5<_`%3xF\.EogRK
+WkuvFi N]p09okX<8G,wXm׺솖 p=rkNa?ľn
+SMB.I$.TR4BN%q.iUkɸ_HW|(C@ɝ^ X_@rRf~Dl0W^ŏ(󗅳x$ -<o3f`B
+Yx
+UJlŋj٪xQ"T<)G*HAOPAɋaٳ$|VHM8**p0_ /% 1Tx@lp>(`^
+䙒4y,c*43IK1 eHewp* 5cL:0Ts,* hA%1llU!ml 2rydMbWjCl&폮>쏗ﻇsa~w
+驻}TwA]-U+Lm^oc5q5hz܍=]fDF\2;FM5s{Ʃx ,cCgn<R묱]ն^Zk?'YT뮕<߈|էӁo
+Kr[fkZeβo?C;*5^\e?`䱀{/ˇ},r6~Yo=d7! gboH+W2<
+7]]\aB}#߷pTJG#imth!V ϧU#)e4V|M~BrZD(R--|cZfwL$7@5_Ig Rі-ja) $VȃR  ˹ּLbE?R`'lx~ P_$F-P(KEa?Q
+A*J.loFt0BS"|*<O%o ?}
+I{J%CfrQ )HRgg_!/S̤[S)>Py9MN Ӳ_ȗו+]T2]κwf]Pس'S ?^P8dρg|Rv:튤m5lDv5 ʿ"|rҖ(Z(KHD,J[KyXo8{NJ:;178WK18wQ8#GcMcPZ32ZgK;9,p{2(܆Rq[a/ Ap4@Z?@qZ3+:_{%֥k޼8|8tᎀ]'gs/ǯ?9Ǐ<xs']:|Ѭ
+'g$ Yvۓ`Ts+=@8;/kcI~#uvɾo;S{L1\F]fQ]\Yt~|G7 =ag7?@"}׮Ú܃֜,R )b#CdJVJ섬 .>&y_J̟uL%ތ%7k(qv2v6}V?O}"Eiߝ
+\w2?\}2뻝gk'ɔe>]L-؇9
+7!67̟X{Q
+'mSON;(n7XMt4ɸV~J#y{0^gE .ԡL󩀌Sսd/r҅ Tm앧0^b:<H;Fs"RqM?B%D|fUŅ8 2r@miw
+?ˀYo %(CFMiz&쎩m>}4?ў:h;/K
+SRrooR2;j,g oH~@wRoeYhNhFy=
+rU@ r5N5fv2L;y?Gg;=eqJm|_z^bFuT//]feO <JrY^`rrؓHާa878Uz8,'r w`p7Z͖k-[%Gأp8><g7<}Wu9U떞cz+r<Z}
+d<O;j(>by<̃@6kt̻ nLk /+2
+LRiT:`כޙKYw(J7e"'@Qe2e6Φ߫)aŏ*(vDׁӑx-62c"% IA{M; %$G1'HDjU"n0QdAbl3
+ 5?yNoLE,jA!J1%\{ߡ!f.B` R80<^E#Dk\k1EJ²&QQb[8ͽ7R9JwQA#_/ºĺU< VPЏT4qHށ/I (h.
+XLTq|)3)rM4.M_"oSPe/~TH!.%>PJQSZLq.`ᑮ}t鈸 Iy 鍍Cvlyy[EoZu11‹9&EMѫȜ.nx0]dTpE*2&Py Bmws~T ob,faɊ>(?8+`h0#r=e,1O/
+|#ż+P(QLZ8@z}';~=-|OҖۭ:tf3+2,wg>>}-
+r&DHC%e^Թ_ϠX7/R
+PtX;dӦm;um8ಞxo _lihOGb7I?74*Z{Yž;yUu˵E:_ Xx1z=J}[_Iy=)|Qzx9cY84
+yٓ=^~_ڿ'+..~#~DEַor]f"/B.;a<4M˿W'Њ[
+ZU2qC@.>x
+!e^?1\0uWE]ثϓ(ۻBX8rѽ ž7UYŌ-bN aBPZɴyt2m=Iu׃(1y@f\yJkC#F"H  h<[fI<<"ei3r2Xd-X` T] 5 <J-Shέ@zC7,#w7\WVKCuQɾ*s^ijfwh%nod7M=\2X2Ikslv7]u^bhzFsKo<m1uq{ ,ͽf𽁟Yj}eޗc:/{~:m6Bz7k0z証cjU<jO'?:m
+^';θKgRgU%2_tC[6t,nzY!6|}`9wگW_fU ^a`}>OqZ{žV2d?6`+>g/:/q
+.ivg\[Y;v {f*J{p^AQ]w. "
+<$&(QԆ*mT" FEX`{D41j2ubҚδO:~3;s=s?ND/NYvq$+ƥ0 ^`W,c`a{(9
+-?d3sGϥFǥ}q;}7zk5ݥohmf-S6b
+ΈCֈgƃP[6:ġ$ܟ7 \.J¹eE=)`
+X4,&;:쨑1*oV+i(;y7,Jzr_$wKm/G)J|
+xMy4b?A1l
+܂wzP( G((m1< \Vg*)KA7o_2`(yEԉ $FQU`P70\\sL
+AjCV)oI䝋{|=~O*R]۩0ey%C9PC!gP`B%wox_vy{>c--瀗<hz<-dzg&|댠la2"ƜI4Zi X{Eۂ(j؇΢k=l;AsKA -;sΖ*/i\CygM*WuPrj94=,IEѼp_0ӢVm #eBƟ^RlH[x}荧ihz"iUGelQf*PgM($'E0|CQA-w}:[XK1' s v(G܏ғXjEOEjocaLchyLDZ"g̈́2?gRph21;G486K=\,?3Aff{aۏ{<$%PVW(s(.c軵H `$I,ҀO`7WiciEqQU26=U|o)|=~Gʾ[ԃWK}]twcQݝoĢK{M{?(q7+iߑl<@aW јcQ!+ePb[ U9?4ӂQ{!c|s,*{3f)`1}'*ZW >+V+Wb:E;@*3^zf}Cy2󩖒>ԇQ4Ҿoкo}%X1DIv m
+WSALW0j̣l$ ܟ=hIMZU<`!xfjSs)Û:h~&efSm}_nZ6by`Om}᜾v`+^wYzt[:ͺn8 ̀GmP5"Qr
+Gvt';]e79b<Î gq> \Joi fESp[ܜۜ#Wrf(o??v
+&h/̍FYoZuЦ1lF08ـLmK,  gkNvXQGuh>r8:8>;s_Ͼc"HH%;CA:7?4*̰/.l7!+MpIrܷVԜ6="n hQayňzLk9i?xڏ?}y}KsnhH,om$9H3c[[=vġ7o] .>T{+,\cYj^Mp[cnuںz[[=| MmΖf]S[uFCm}P^Ł/;Du)Tjlj /R
+Es(u*? g}BZmyIy"x0ڂ(A@19Ec`pk ש(RcdE"&;1`Y_x,w7Br6b:Júc &ܑ^`U!Fȃ`G^`PQG[kX[ dfQ܁d6cKWP^̙/X %
+Ϙ{
+8]h7s->_!0oH&h2B cKy(䙟F۬oUXA}HȏϟҲY|$p
+ E)ԯ B;%TvNYZ0Oz![
+\GFv唐b7]_M3I]2Ρ[hZq"En܃ٔ_H^oO}`Z} &O,Z%OUE/*
+^'њ T"rM9HOCC\ceE!.`820b5}엨O_؟aXKٲgS**PAQh8yX'-2ySpd(%PfA(= }p)НmM5śY_=g [/?QޟaKoqѓ?-{QŽ_F-,'ZC^ä>U~T!S(*ƣTc|7KyP)ۣw>= ם]%G׍WbS?V~tE㚣7<W9~HÖOn}}Ϟ
+2OK)ƐbUb(c3+.WP_H{
+Z1a |pK%e.d]3EcjQxg -Pi-y
+{mxӔ+_ଌWɴeISTxFBhHL%B
+ (`XD@QXAM &ViNDQP#̾0̰Ũ6kLs[cӯp}#b0D|<
+\OgaVkWҫgF[
+ v*.?4 }x `nn
+{X|_K2! {s
++*=m*صBqciч I"E!VPؑ Jlm<zG}bQOG%cȝOUTܛv< ]?K \{A?<=M(9` Z:&S"̳1s0XCX7OxR* $ QN'AayI ƾ˱ hh/>
+w0gɯ尗V4,wފ%G-{qo%o;仹"pGQ5_UM|lM!}[Z<cS~Mb?<Ca|eu;άuN3c oҦ1J:JJG(9PeSSˎ;WΑ3fzM3wښ=5kGT=Y%Kk[Kg~ރbKDQc2dz?esHs+]hμ|%k{ ; 
+MNJR^JV9̂[*(a 12_Dӆ'M+[{'SRdwa7&e=(><@=oyCၷMIni9O(,1ؤ RިIhQ4,krN#s({Ňro-~l1\?)x9e? _ֻ`xS-/13_xRCFIxV"-?w?h'e.<bZ޶Q`*SԬHx<"?Q"~tЍF"XoUMFq17
+Þ$4QFO%]l'%*#1o%?+?fT_m6\5 /0s[;']N6kႭy~oAxZgZL}j-l\-''2~shksvKt{̧̬
+Z;b̥<pmF1WOwZ1ԙXLMrSJ[e4՘+36[] 뎊[3SõM
+ n^5agXEڠ;,jp- =3>,ښj-gRvְ^Uix#g]o?7fr 2Q1igM
+s>xB6F)˜' Q.x( 0ifz :!"
+E`f'e.h0j*40k"~?87l!~'C>CxXb>0eb<fЋ/Dcg_&$/pp bh7uWnAHe1 j(ɸ)*UP3Ӆ?e͟zQڨV/Q"+-\ץ{UJ/?LiPTOM7 Y18n:8:5Fg&&Όo34("M (XQM,eh|I*_?AbW~wy{j| V1x7~\e_b]} ~3}o\t 
+9_^QÒ8#e'<)$b @tShd^J b0Tuh |(Pu_!~GD BVހ1K9D P?7o ȁAĺ`UlYSO%svRV~LKSrmLtsceNeŽjI6@!CoB~z̟sJbO[NA'S hb(4zAIzں=?iþm[4e3r~SI,>ӥh_"= Jg̟\G&4Y
+kSF<RJr",>¿";$- Agh1b: 1L΀"@Bs$QJ'΍BFr4V`UDSwb/,Gb`
+DnE*B#˽tYˎ
+#
+5'9<' 5.ce<e ڰ~3zVrvRg07i)o: )|R.@|\y\chTa6}UnZpmΪwVk3\w#3=]kd`4 \-le`zp=e]}d-*-m?ؘ}O0eO~<_ u6Z=X3F,zY]nw8P \oiw\d.+69,6GYw@Yo`%fw7Yޙ?~oa+ngҞZgY/X^;}5yދ묃lV0fނނھznmyµ#nX@P {OhtR<t#o֕{;fOoЂ=ek\_eZs7m๬#xoFkwywNpr WZn :5j~}રyw *qZewzp}fAD\p
+G'}Nw-|m39vgp]]" : L?a; تl6 nvN6x zne|bh2ӳq_{Cװ8*&
+k
+}[gfۘ1To.z/ܚ ݂h4tu]6 .XͫΎ7n6e7^moyҍs/#`@Fm*sZ- Ԡ.Qõ~h(By' }4Ujccwȏ`JI~4/\Rq,̺FG>nu)`Ũ(<DBD *lpAj\ $>?Jkf U\3)߭Fj?Yƚ+"0|XF^9E *=Ԯ:JzRi)e̗=ZCFŵyCAsZek%]ӢF>:5I؏YŢb]FY=55Z <wfA>7>IrR*w[ E-I?CLV<_M:J(v%<d%@n4?)Pg eJ\|PMޙxVY].&>Pca~ Q1Wd#E֚N MYP2]QQ]w>*(( \"(2,j44I<h-9zLAQ}\dd}g@qIˉئi={`*޻~߽y]|0^g'I3|79f蛞kd4HҲ- b@w9tf&1[@+h2r)<0tby^wGJ'~PEiU^OցhǷRpe=%t/dŔBHD$2X8Ojc#j$^,E=Ҟ-rƊomṢf*׼O< E\nG1xWj"s9.,
+㔢|S-E "%?FH>vN˺u'xW v}c!ø?')W8o!ݍ)>>_qvK{Ӻ
+KNi}k 73g/Iė򹸊6ce*a @m΅Gq{bzoE !w-?^.l 5B2SJ27֘
+s`~vՎ8*Mܽv?p[ʭ 0gxuZfVYJ\JkH+%pv#
+O0&[p7u!icd04;gL;27՛G
+/xϊT4kuaXs17/
+.Of\wNFWxe)bŗ8@qϙ
+D-PdQǫ; n) Vr/Ӣk<-zS5BO(tpci)|hRFafRz%mnS',j ~蟓;ȓߜ$W(&y,}:Vpkeu(Ǔke:%cL:0|Ȯ(DQA(8jRL>cX( ;.
+6{7,K\3NbeRN3̏yϽ޺<=R `/V}3^zn"QVVyD!^-Jc,BijsR {>|awT% $VNIHc.*8I95`ωD
+Nua?>^lkh^T;&LH~)_8Fshߞ?OOs&}\ϝ,Gk&n<\>7~Êmߞ|cjCkR8&Pitw.88q35GE;쭿O%ca|=}#'bcBؗ-Qη9$g& ʛy'*Ix\$q~1j@"Sss#wa X.FKq~NalcX_bbmXC.3g
+z5VJo _koCŴuobĔ k^Sʃ}i٫WOZ8'c>59DJw_
+$dnHZb"/LBl 7soB[{J{C[^ڤho6^חtױ̥sZlj+1@a*I\o32s,f0Y[Kk<k}]E f3Kqo+oe?
+M,"lY
+®%69vd<dXy)G#w63ˏuD6Ge[3w}Va{܃>٩l-6EcX#ϐ=^Y{|`5eg?>T;{Wtzb ~aa4XLze/02W[:/ f?Q7oe?x~jCUF*=j^eamiiZy]|zg㕦ƖuU ]_|㿒Ca`?i
+z+.Ge/=DOgzke!3xb& a7a <*K"%SM 0cf+?9EQ@S/AXCp])|[w%
+3,Ia!'Xq2:
+p\O{v 6C BpD:TDE+ew/z%ZaUelrf
+ks674ie\+DDwCrWA^`qo0\h.#`(8ľD$6'"`4q*~|UTۅirZ# <ϝ!Gi
+%
+' ́7o07 c#E 4=rIu7KXQѿËC+6.(7Z1f-joxP@DAWմH:/JnvO?mk|]gYEM闪Ҵgfm5fyET^/4#߬ %!G)vlԔ K~(`}-Ɯ%"h+-
+u, W
+A}b~LC¹-.ֽS(liw}ѯuAJS@Jȗɵ oyycE@sqR4%B(Nօ넬-ϼg=o9}rQضoo+nڭ3Jd==r}:CCS)WC+i!NdRs6UFq\9X@QK0 o FX頫"!97!8B转u+@g;-ޗv]W73_%a!!`$ďʇNosƲCuV Y޻?lxc'H\-租9z-G?MU*i=e/Nݪ8N jOR?Pw|rǜǬ=<ﯛWK]TF/`O3[pַ
+v7j?vٞhEevOj5xqh׃xzmmZJYh{550~Q<@ 9\J'ild}혮o 5eR j׷[SMPsA0A3rZf?9]oG0X@_7'6Rؿ.z%|n%WaWij ,9x@
+endstream endobj 26 0 obj <</Length 59927/Filter[/FlateDecode]>>stream
+H,wTS
+G A@R $tjb
+EtAy bY
+JWIS.ŷ[Od#J'.wΝof}N&35wW</rlrbWӖS8Ulzjn 帥D&8EEl!2%gHH5gM9Ϩf<RXGff}g K2*]wZT䲰s^FsQRpCָ尶8jt{jbkk[-F- [.F|$hۿkBȭ11 lnE9WjVjT$Y0pՠ(`I4`fЂI onb!fK$bC!1H
+oEaQ(v Okb5<E9Så7ОpD!({U|uq{x}(W; V+R9Oi K{K^Ij:ta ,q+g c(ZC
+ǝG2^2xʽS1ãc٫|3=y[F>ž+U5ޓ|*^hE>; n-*Y1Y;ׂ՝yAgsu ~_ hV9GOʪW̳kY"ǝ}UcP@c
+jڏFfb5#>o"
+cE'\:VJ,I}L}RM#9>9QN'ܥѻ `C
+x(_"=UN*) /8;1>=!ݳ cuww"G<v&`Jǔr"?[qO6
+#cU bDڄxihA)
+2~+~[eNeqVH%&Tlc98D)ejL/DPf&#Ԕ
+\ռ5[WHY[=mLRs~;]%U9TmנѼMVK:#9Jgڍ- `Kl'| ƾP<z+$<6A) ~T!8Tű·ǝS3ezcI2wy.E //nY1gS&Z+µ6ǣ%2bʹJ؄37i*p͸WyzI9zh9G"9Tc_$Ѯ,1rBޚ_.=2bm[YP
+gYɶD?!U;f&?^qEN m6t->Fc~0ZF^ۂW}k+.* D0>kH%7fżWˊZhTĞ2,b7,L
+&MJM˄V'U+*BqJ1nS[ Uf3Oer=tƨ;k /#>M{ܣ~qKڃx]?i;sd0}r J;z~9{}V}2AvK9:Bv9A;=B?3L:-z߸^ߟzGF?z]Q L )c"j]ZCn *75g}2 3̚Lp3|E_A$T2Nq=t]}KT}٪2UK2y9^F` FkҮU RKlƳ=vο3룺S݈{<*(?JCq>xqO} ٰ &ZN-%uu3 '"DE8\%js͉"otҦKC<PWzgnuF;NO<[&:/QY ?~, =\Z|D4Č|M!-BjBZWY
+y<S*_ז)й;6Jkʴq(?vj6EXD=!T
+hI"Ԗ6%͢rZiIgVEY_<Q *Ez&b+'yN3ȧ%NL2k70\$m2ms~RG\$S1dS.ղN
+y!ʣ1J_WFphiMrGTryj[[;sGg3'("R4GV9= g?=/f6<!2 V#,]ۤy)yI;,|Y/u^\`C1lyL B[ 
+
+_[:Pffn _d4`Tc\i\fPڗ(>-5K;J;9ixЇLc2|g'@^| Q+-6tJ<Jܟ\~R͠w)5 kFp=-ި/~cSq4<b#Ϊ<G=;T_\{B8cs٬5m,ҫtU7<g';~F>i
+wT 
+DK.Lvf8c"P)_
+b ;
+ӮsPA͊OT v!`3:J<aϤ-4~R/S/yJ*#z>8LM2Fr#]Gq㿤Sԗ5{L[XB_2ͥslm5PܼX\V LYb.t,I+Vd#ZHBnEpO]0_ف2zEOfts{StF Nc`٥-zҭ+Xw 7Ѱ4H:f`x} R(/`܉o@npk[h1\ܯ9 AcG7`7;
+Ѫ@jD<
+.`
+kMSF]&e) Yشl C$z5D1`Isq.tѠ^$6t:}x˩ф9)MiuEnk1R~ui!YE >`L!zcH']20JhΫF&'MY-yirYrw;ucV;% X7~ `887
+p<"X=%4yb|PG <@4HU1=!# ~B2D6:t 3qмj
+Roq1g, ]^I=1Ѡ;)k:~}=IkgSOևV7ֹd_|:NݹfrŽNq˛`&
+j.) w*H \0r!^<̔o9~e"/j؟W/q5<qV/Wc
+ͨZ"hf5q0{9n;WF-8
+j'WW'
+<IO
+ m7/5l~YqnUU4bfiyNY(Eg$Un({
+KyW.AQaapAM%b5Q<ָ 9>WZӚxN ؅z\Ir<\k< +P˹4j>қ=XD~,u~I+r:&gV\#;OP ]=njQ2L< =D>E/[X3ItYzSH=Z4<hx=n]{[X)[/9rk
+A?s>?
+{$yHO&X'v@זP:I9/rqPfZ59Ӧ/V?)E}gmW̮'@n{Bj!9Xkrьy襅TPoo,? zoh@iaMrFJ<,vm=?|m|D8qޛVKY#r״b+
+k#-/V=м 5%Y<&%d΂h
+j}mXHdZw $=
+Ky:ßqS?g/CIIs}f mL1;o-|M|>LI_^c^0GhYK*n#.̓J;ћ{6*G+
+fix/s=StYkj[Z
+bÙ(9H:;Wz%Re)ċ .34CbɊ_wy&ORf>e~-y\ِ^Å+Р^
+wa 07 KuK{"^zkV}9uj]j= Ǜ#L.)[%`X#XbrA(@dzo$2ШV|#e=^WW w
+М֨
+JM$$"ATJVeQD7t\aYUAWQe񮋢] K"9L?~Ls<ux"$
+JS/%y fu1j>
+uQ# Βa)`<9K% QkzE?j=F(/)n/ӜwD';3֎֍+;O.}Q?XД._Tɱ %\3gppiteH9mH%J ?N2^`W5%zNV-rS /+u~C)w8=}9W^0n`-4rYܯp
+EeҚ*ܩjܾ2t g֨zf˰J0q>Ѥk
+ЉـV
+fj^KqV?^i̩*/;],KzsjJZqfG$Y%4.dQ+e~2o] JXoJΦRúx*.xV
+t
+|hLiac;g"̚,DfyrG]?+8'Hm?eԕ% K
+*H"!a !HQ@J$5,
+B
+ҊPp9ZQAAlܗ6}//yyy94;8ƒ] N;)$ǒFbBeL_؟Y#o4?@ eDZg gَ{@^ЌQNФQfiΨ^{]R;t ?XczRGz w,Jj5{N8x 0͒'Zs
+:N>=r۠V Vάy[׋e!e&tpe.rLp/ FlhRZ΁fh@b%y̒smVEdOa4vdIؚG3S3V:l-e2=Ge1{tzh襜r'9{/M]ckhZ`ˀA_.b#uVMs<Q%>#:R]J2s,p:χ65ap]]$܀J
+ z>4Pd@
+ӌCmYg鼪h%z ۶`[Bjc8Wu¸Wm֚-Uq˛bJUEQvIF ֟S&b)rѸcHPޡ<r^.s(cMZ>& ~']:al
+:ѹړV({&M1 1:QoIG#q/-
+ZWǿ@V[< hC܏񐃟`xKʲ5u)GboƵqO_MZ5$rfؗZV7S`܍t=}15mzo[\)_bDyW|r.D*}i! ~a* ~z>#1a^HkR$셅4taM i4t>vMSKSգ-aZ7g(g1fuh"޷kC6E!
+U
+Ѳ%Ѫ &hŹ&tQbϘY h-(g7>'WT˧ԺgXD,qas8cA\^ ] +iE'yC/'bi!.p3 "jZ 8"O? p Ѽ |#/)U xor=Q
+h-0aK5ȥæammRATZB9#^Gv7R"diYbĈS>]Ú<
+~@??0z@ t<g^/qe|y%R͏۩2+NbHϹ+Lt 6< B+`n:0<
+揄w?8@L7\a",$BvHзt@[( ;ab$_D=Hc}x_ؿ~[=h9 |Es퉂NՃYO3[G<i/"`w'|Ne*bkA$Lrm36Y>yhfy rG +ySK{ߚ"^ZJykaz9t.S0`ܐ<]MǬ7~Q`DZx)[еV貧+w0M:ԥ`ڸ @_7b˺iN޺X1h\qXťxR]AUyQTōoEKmsA.xږ#cQk$mK$|
+=Z
+r#
+q/&R85գ+_Qw^5EuK=FU&Y_u VP˰alǖM:ScK1,hv~1$,tb; Ü|J4J<_¼04|Ԣ?fN\2-4`̤oĨ 35=gap߻ י:s{td`YGֿwqӺ?fYݤ|i{Z/Jsjsp](.a
+1'_ 3k9svJ'Ȱ&ZwmNƾm[ =xl3'o|֖ң9FSMJ=2
+Q hF#@C 3H O΀g&8
+_;Uxx8Cbiq~SKUmuܻiO[/HS(GZܼJR#1rڲ޼1ȷEUu`Vm8Zd3GgQiC׋&l"ߘ|>tmYy@bϱ"T9<&d{a~0(b 0.N*zBܻ)&jٕ方ы6a
+Мğܕu.r+ZSqRwe<EhqOT?hw
+<%>2֠W kjր+;p3-
+t Mg8zcS(2Ceh@dx0h;2gCiqv)qQ>Q^ /{Þ4,696e,
+2j<ecrsGL`KA% 2+-~PSx?ltFw+Ǭo.\ӔeohJ jV+xplgf&MQ[OGyZ#j- kxZ%.NֹUoD~G6m3'6N
++:]UԯFVdFzt\tL]2@l7 ] rp
+z7*Ich"(֯oCUd7_V<(WuTI>,QǬ<5/>4Ɏ01,GHS
+$ 9;e\`feVk֭yˮ |Ů y@[OUG|\\X)x,vJƦ@1b]y*%lz
+Y֌U64WGOYՊ>XLKryG5uqMB 3YD@)GHL (KpTKcղ!$a P*"
+zuPE
+}/ss=|ljey gDʚJ%1-c:ͣZM'aL.CT=gHi`SYwƨN+\חjG.I_Fv"vyLcTVw\TzISRR'C_b ] <*ds\g7id/0q;g@64>΂`NІ1TQM8I0i=Iw: Jӻ`0
+7滽T/,:S
+9O(efm+m1oZ1>|N޴3J-VΔĸĴ;b*7r'kfmZBmGr͉}K(rڶd)-
+K)w\ƚ?hoeJQJkk^ y/}/s|RJ$\5+P.eS2-X S1 ȟ} 3
+ib1DŽ,ۛ@E77
+3Q
+XO`ĤHS-#'y  }hCx: .PS(r@<@RBXqbyW49d2$PDI"
+v'49m@`fk1vsWByp_>ՁqUأ!dL8=lѝjB QN:)Wi*W:T㶴ƴBě5S+k_F.eLDnrE'D6*-' Y"RT/8ԺG9[nu]EZYqN}1=ɝ2.2(1*|ְڈϜ2(zSɜs3.Ws$fBE}
+J'2 E;ǜ옦q 91T}td2Jg;>FrI41+:z6qpFĬ!6g|5u ]Y
+bo\=x)WҖQ_&r9e%LcOX
+J\
+<Spֹdٓ3E1gf3ãXH<"=c^_o 8e5j7t@0wp)H$5kGCЏA%w!n&]atMz0N+QK'nѯ=fi§-J^
+]47
+ڄF:?ZU!ּ>~-6grC=#rodۍl s&8ݖ-p~J)#ےr'J1'ԡJ[gIjLٸUO8nw9w'
+5rbyYJGjw2U6ʖm{/[nE)Ok_AѮc,oC1.6nFcYm.3Ũ,[ILHF JBԄZFUiJ+DjCQ_D,vyPfcD^Rہ. gR toM)Q 3_99cLC!%9b~OP|+Cx|"9́X_;p0,Z_nmE-{[g<$_r*.nRIRgIid2>e\>n*{w^S^OKM)D@@)y w8_ApP[cacZdN.S%U
+.U,UH:oxDօ$SuCWTp
+c$@mqd1 @@Pv*
+gm**<|(!$23ss{;'Ҏ./gJ?]{J]W;V9dӢmא&S}NnUqqxxec<vk
+l|GmH:: [`J>f!c5~ c-C?{qpRoǤN'l ݃kx?_ÜQ 
+~G ㇀aܠy!&M{f~2]Ao{lcGؿK6`Bl}, JExTձ[C[Ꮍ.l{¬sQ⋮bvVبYo(` 9-5b:"Yff"G#^0D<&G2nWӱO}- Tqy[c~]ݽndܢ9:ޢl]GIj ؉حhhqL/B˩Ȟz9 ѪDBF+CYЫryeiN
+
+"8y6YK#{KRc`\$>7iyvHhu5A+/;
+.@! | Tr>gά`kϺEG4p-[w!s\DG ?V@#!a#0~B[PhWB@7kpDAO6
+i堐sIADXC4B$ɩ('#$6@>  lHr՗n
+tё{N'|[4eR73GiT=( 4!IP23&'@axuփ} Ŵ;n;-b;ǝ .%U8VHs }QfAhhۜA#—!˂aafaKWcaY^*"VD;ekG|. }D;kke ХO)(ɋ~9*uO.}GUAX"{,kT8+`EMƬRl IfOŪUB/MwsU$ձQ\8nU,AvZ=
+oe
+
+$έvv=1]ك)u%}Yq$@xKp5WֵY-v1]1Mpo>L :Q Skq!jM-R:z$l<`] 5}K <V^:x郯¿ [+ )繷,AxD"kTSY2c:L6sжoqdOAhFXJpRJtDvf,QKm5V leQ 6)YD/N/hqqz%bߴ=#~ex¢3}W^:y]^ߝ!kݽh䚱Zc qZY%aȆpc{Vqחs?.Xp>g,܎w]cf":!eM
+0cC8rDgTE\"沧Z}*<*3 MJ]Yt8dzӜ<%ȍ8H},rnC+!
+-!81
+J.2 z2AȖC)
+1oBޭss&3DO69’5<Z<^b;J8}Vg!: 3ÝZ۴}W
+!FL1X>*lҾ2dܶ<]YgRJmϳSm-s{+6nZ2g;ovQ@[<vUP?^d*(PUUSz
+'2fpR0euX~vxJ_-/ê=UI}H%ϻKmEBmܢz`l1^ߤq`$!
+G;$1j!f?q f1 1\sH‘3Z8 y`YPfi`/riG"f@V\1룎du\Ho 1S[LV_b;ƿkF~̠=%~S&~3&*  Q'3}TG2; VfdL1CFKP4Kq]ŜߟH`B`"K%gmg!O˒/NL=, Lv$Lq徝
+^GӖoKVu-(ZhOQąxEu aD)O.%p~te<4c&My&oLty4p;Nf G `݀D=QhO/OXVvn} xˬUTq6L빏LjYȬVؼ&`YĢF0b^yf\T{4?`(3f rRH:#˘ fucFj3% Vgknviu!y>̜g<zi:&q|.5g= JE%|ePAlR+jrGղ=R"suqцzo<d؂ٿmj!5G=hO EI(~ mȭTy2L]NhK]F*c6fGYV6f^4<2s7: ﶵD,:6kS2n~!w3+(V˄YŮ5iRN`NXa5f:<CM f#jd* Ȅȸ>WZ/ĺFz6b60;#Z jrZ5əlv鸵K8gŮK,mdY,##ѮuC
+oYm)V+#=#Dz8wdd=?7cz89)~z{+S?>zlL~y v}k hX鎟tÁ)Q>Uu
+ ۯ
+> <Հ3Ap11ހ3Jx}wf ާ7>
+8LFĪFI&xm <~L LpY\1p0MA>5.}~M@%(\DjY'5Ce!+b6"
+BfPPg&J/HzuIį
+sFr{;}l2|tscϣIK,Vn_̈VD-{JMJbalqu_.ϸ`hC(j,r$y"Yc& [$u)"1 [|%>_u \O\z.+= 9t1˒_Ys@5k| s|*-0K~V j I-.H#$5k{!f۲IE /*)di!).Tr5ϞR?Ǚ:9yRI+##S0E#?3;uv?I O)+MYjCwT9ΞRc}GQV=~]H̫`ϴ;i;PLm憘WfÊy1)2" EE8qvMxo͘T-Ll\3B1q?YE?XG;R$K5(gE/s{IDv=W9gTD ߂H6x"٬H4(*U! 
+z LyKjHkYB$WF`o Cj#<Sb^M"t\<r+IDn^//8,Ru}yJaD-[-~] ((
+E"3?UWZA`= fpa/3`7 # OUAߘ
+;jG ?k;}iF50͏0i\3h^w.go>)6xV21o( LI#䤽l3ٌo~%=%'%EPn-M-S.C X<`E*Λ:@Os8Ɨ;/JϜJYH97y.|5Lr'CRGgZ2^%J75бXqx?v[%%NGb&û 2 F $?y;H@d 0w#cӫd)^ZD}#A ū ;#; l~9"Rnmp+
+).Q)yK4%:%P[c?lX uM?~^57QYP9Smk[mGf~Op?k;%F^9罠<wa=(i%
+0E
+Z괪=tK۲;~T(\Kw3Wж)9ųmW|QKaC4KB4P* l.=E.EL,6d+
+6PKZ*WZ#h߂=?QNL-fdY*Z#kΪ2UE(Dar˲yKQl}i̩4J"Bf[,c[yDv \NkmZ!M#CUhp{Wdo *}(
+=~ktK9hIq34pY8cR8k"
+P0-siLӋV#rݳcibp(7([.TaNͬf$&\-ٳaB+V dx$p?F'5c?Vk_gjǷ[!բM#j]ԋ7BU-riiu{v?N:rnT+[JI1C3 1-zilN9n{+`dqu; x!cq
+`z>d~5g0y ߆N^LG83zĵ.av)-g}dj<#Nx_E"<° ;|UY z)ϕăg59}gq2a-oLngW\ d3 cJ7 c7>߇9?%Ud DSQR
+.u
+¬;%^Ȼo./s.'}n7ᓖdE$\G}-Fj_*X
+d_5E!p(j·.y
+[]ScW{,t&"~7t<<,EI<!3 {`, ƣ{q(d zbQ@n=B9Wk.Tpj}Zs *ٿ1*}_/eS=[~ɨTqG ʹoýYU\̖jiy6ݴvST>D|+ )mפ^-g֨gMېY#N~\;1!v>Z%h4
+yJPߍ"$7Uߕ1c>>Uj\@piK6/ZTX^ }mYkIvq;Gjƭeo} }k=Y~mXx^WNrӿ;LX{Q"Gvxhy9y Wy!=j6b"fȤLH_F.~5 ckYz"z7bQvw!#R. P:ܪ>hƼ=Obq/\MU8Wv۴AZ}Z r~V>d!%Ѹ "RlEwcg1P*=Ah E=9;~'#VxxIT|[ɍGҚs>eѝ)KMԓ1<6{ y.ɝsɄߥY{ڲߥ5NZQ)E"Р[&$wR*`e/\tNzBx7E\T ohC XI.571wi
+豧uRv`'Ҽ7^o3vc ]VChƑChWgJsW:KJlEn$p,/ ț<zdDGoZ^Ў\I<ޅVAƨkq *Iu) ٖn1O h(oA+RΪO3DZ^+:~yYemEyG$өͲ/GϺ\9WF8g{(pآ8Oa 6dHBi.󨦎=OH k DjeYBV;"A˳V7AHz<=W(Ƅ%$7C?瞙;w2o>~}#
+:a]CXWuYC3Zk4ؓ}o _TIJf)?="Y'?W /,
+1)8B`c>.-پ
+âE@qv(T  A`!5"ۂf/vL&|`A? :^/<Г'<4xh,ys/3<&d1IyD2g%Y2*
+CM
+v`Sy*VNF]ϛ6>+eV<0,E&[[$7;+ni29~8 L`)~= v^F!m$2F31g m{í; I3@~H~HW W%b.b
+>[wXޚ6^|0r0O-F-cWk|_0=W3;\aj\|酮(ũvטaXj?os/bV&@J'Qr)Vn%@h<܉h,o "n@\ʯ'I)&9{3F1o߾}z=qNm+7l;b;߹޶3lަA9a'c^W{-08}w^`RP4,ZTE(1_|ni:F[o
+^*yf w\?ۂGV
+&cqkdҶX4N?1n%.΂±69T GKE_l1ݥ v@s΁'T홈_]<HgVX_FOu RדP@ FD[0k-W/b"f U4S(z>m@nڸ"Fl xv.~G]"FhI>ͨ+
+ΰUmu&k5G]5:Ȋ1c^+ ˖0,Y|(L޻?l;Ǜ D^HeކTDod%{! VPN<P; _߷'j{e r=+C˚(C DWLuӆxV6'kW,М>_z-T[풠W0Y.isEz~hIc#?O
+@]1{z '؞Lq_O&u H$
+dp·Џ X>^h?c
+jw^x=5WRy+~~632];l\~ח秤짤xB~B~LZo8@\r`3r X,݂١p
+h.x
+w >U$X4b7g۠ϻ4H>:C-uB*7 -_zSa
+|t$ ߮A=AK g-CŇ6[uTK!6\ne5X
+ 6w,;,mALV3PRe6gP/Ns=6ra
+?qd9 9L/{z(GCN>pw)v
+P$db}@+ > t@`#kCP?3?EO(:c#` qlwb?uٰ'+1;=W<r?]
+!bdͰrGػv9e{޶31FX)E#BلUlln U%h
+<[KB7DVIЧ&IῳeY_K~e~-zDOK_9gxC)6u잒 ^SN 镮yO/zC/?b_ dLiPSYod $EAE@v!!aMC "؂*,ʞȢfAvtZimmPzT6$3A=-OǬm~gJOT*,S2lSvy~K
+1:})5a _ IfU'֌ ן&aBWߩ sgQLJiV4oZşc]1jy:I5<`Vf>\1c1xOZ}_dJJ# G{2i Dd ^q4!}@?-0$#}4"AHJ8{I<pH8Ba?><=|bUfw{$W/z{v%@`w"fhMdM&e Q{ґH;G]'(ָEoEgIcMCumM¶!JaW#T>m7d~ƀ4S
+EϮ%7YԌ7BF-;æ[^ 20#{@\_o ^={_x[O2{jvwTnQ`#OK]Ҫ_0˄`#bp]x~]qO&7D+5`1I8ku5TaJX] !, Vf|}3GjIKs
+ƐMY\[笚|/lSަ^<a1U9oW9MxʺFٲ&ť?oX%_ cXZ+s~~z ÂOņ!QS[A{lL\ ]pV1FI 0-A!
+]S}SzFo0`\Vu o ½2l.GCc캂 Jd z`0's0αӌ1FkO^x>\=5ôrށb՚QJ b
+A9\)"wJ2cV#*yǑdž~ʸ.k㷏L9wh&ԭTeHHVv+\Zh
+*  5Ř F:ܷ~xP'8>tRtأp5)!#t>h"(=$gg!qfy!1(1%ng,{Q(e+Q=L5`͐hh
+9,Ki.WiwŲܷEy/O-?1{3k6G!Oz`_02g#aR0;SDΨp<8g0]Ϛ9ޔ1LNKx&'2s&s;Nf7T|u"ٿ9 $_`YkĄuMrK}aCU=E0+*7ͯb-
+Z2 3-JB`C0/*+DJ "¼sy1 3
+mR^ k
+Y)Z)QKل~[kI;c6qQZa-kҹ:|nfRA`\,
+f`U4 Rn}х̡ɳ9zOM^O `}Qq֑
+1Syލ=e 1cLZq]$ n؆ Z- [_  R-Oz+d,)븘)
+2ΰҀ92y
+Y%EE]5;4+5ʷO.sԸc|ugBqZVV'ZqRǏ%N4:<W˶{D=jeJP@h^GQ̣0QvEbP6EM!j@H-dDUlֵ
+*"%Vw@X@k3cUjQhŰr|ws5{
+/f?6Z1Oi9NNa&Rv#q5=EڳvxsDMUE~=ݭA]8L
+` </CɦK↜b:@OXGL. Ĝ2iGr-rSlN͋B^qʂfO 8J_%أc2웓4Cya=?w}u=23Wc.28YͼﴋfӼWkG K־15Esh2\3=bf/|'F-FF֊Afא>
+ˤJ0aN%8\k )cggDd/5(՘y9\UQ%U\@aľ\)Ql(׊ 5hh7 BBiNpĢ!XcEy,Υ}߄=O :\'03X85I2xڒ2D}sֿ$S<O4אgϞ=2g1kv=4td$ddܦ"Gv-i$ ^٪R!c ے-INoXSy̻jU<~̭6fE!WT^9E P/iָn$>-qĻ)xm!_LQ)j/5IB$~/>'r~;s$ F]{R5ωʖ-ӂc-#ㇽF>^&}#bܵ#|d̆v ֈvϲV؜f
+A2'=t
+䯹:{WW2fK˖ ȶ^g'z7nv r⮌%n՛fWUīf\*b8VEֆM)6LTƬj*˚13%̴ިbݟF.Į[<rrpTԨ'+pmuV>TAz"QBe'A&7="fixS(QY)/" d)zS,=*"vi~izǞmB/Cq<dzcX''oȈw_$YI3@ٿG|AA/ϗ
+5r1VH}%3 ٫>Pk K/%\%QoKZ3?'x^};vB9f)@240
+!B!2t^ l ܦNzG?yεY={'_ݡJnOW%Bj" >ϣ\C * QCZ)v!rfB'?rUju<-p/bLᦕyFK%]4cs$vS^|bUVG3ySPmAu! e IЗC,!
+*XޑH9(T"nkW8=ڜ7B*H^{;{:lާƜ<uJm.Il qX3S?Y)8Vh*ձ˔2s}Ʊ2,9;/~#h{8|xPȄ>Ѹ!}B
+X!(S^.Z M M
+L8Ô0AETA@cyR3OAAfID RQ{oR*K+𪨅'"Ckus眛ϗy̳R\8PO=}
+S>Z{u>`AQcEĆJrdR?daQ)K0HapZA;wB7}SIfi'ÚywX*= 'E3,N/;.SV)V+1rדqoї%
+:1Rw$:1e\m;jLľ:R~kQV½Cbu#Fw#"¤3j%~3\ƚI?~kY~EHVaM(H<m% X3Yiiqܸ-חrgYRoFoV7Gc4u-_n( X0n/y^o5#:%/4szz3zj>rW-f7 ˨u \ X7!H[P8C`ǓuMs]v#rs.erܶx!^v*7>r:5P+q%
+c2(婀Q ,>
+m!!rp4!GǙ#ہ[ @,:j(ܛA@bnrQUWRf|AlGd9̹I-wohKlu4ۢXش<1͡2AE]]*7Ky!FJL1BѱWBјɡ&GDƇO=>q@=ZJ*kuU9I[be~o|'YT^:ÚEjbP5qPe?OTs+O=.T<P!Տx j{, ݰV0a2g"X\=&k"5
+6ߒ6۸u]崳4y#Iq#S^->az]KDLR2qoA!{ե21҈W}FY¿}HwD}Ez2Im\]>ob;S2g!j!5k"mۛΌWIO
+~9+zѺY0j$´!: ~GsAfO:g=K~.Շ5kP'}If{
+RЕFM&\ u7T&n(ɡ:j\$dҴ6hܸ:`̰Y9SNeQQ68qQHǰi1
+G]5Yhκ.rB o;Hg_7bW0dW̶*zȺ&7QQlsbY
+}QU
+;1`.\y}+2
+VQށ`~+$j5A Cj T+5 lvX݅wƝ_-&ț̿Erzs~q+{<ۜM/욋nB؞JbzZʝ#*9k*z\`N g;!;
+נ H:bv +saM^֡_ph2,L5#R;5@ۯ~2?c #O ,2jJ ABB\FqB'#
+Xd G+W(("SOKuQq8:TbH$^:|ߖ}c]=s ݵD{y?wB3ƥS>
+HЄdF[f"of1C,2|,T = a %%J5ڢ(b`
+zeHڷ Y^?enp+p6
+f'
+m̂Q \
+us{.SݶSb3fxMC+yΉa솦8ө-q]uuĉ5jvdڲLD%) xq D<$<&R3I'Y
+ԌA2xҢ$wJ)2YIYQ 0`ƴ PKWh'L NҊ*'ЋsKB0h80yf ig#EV
+5!vM]-0d<yOeqy.,IZ+pκ\6/?fe$(R?ɰ8?yMRmI:n.m@DAɇc'K;cx]oNo«KO=x{G6oOÁmص.;S05\H<%oxM;|l\l&´FOl[8pæ
+ ۂEh'0%p Y\k#%
++#tZç1%B Lv cCԗ"T-|MD Y ڞmCf`߰T7K%iMbREěa}Oz㾠ɸLJWn1.sIݿbkekwmY JqyH0NYas[ nNSʜgcʽ6yµt ?$ON x` aK[Q
+p[y$ƣiWtkuKE=*b}XbVIƭIY5)"6Dˮ'
+2աXaYUanjaK,<=ZTxލsu <|ΘI;wfu-N
+`q~/̪|Gh#nsA>b1.5w~ o=o{^XĽqEA,.9!jb*ٝǫ (!Qر 9F5`?.mx5a[b g HF4oEm
+J? +CA>W}uϊ-96n/k#OBh߯Q5)2Yk8gy?eyڂpsx(g{ j\+<F8w9x]r ;3 ~nǑ?b06~o
+x@,+U/K? IІ(ӧϦkx5TҤ[C֭qM~vRl;"B~cw޳7՗.%b6Ӗ}Z^15 i}:d# a=%W>g Cن̡3fӯ}3793֮,M\cw|r߯#ֆK7^[?=~ bv]_쟺BU+.J%lϊشZxZ(G?f~-,d :tF} ωXp= Rq`
+^MD;7O6oUoM^WvTVǸiG_|ޤIsRFŮeGV{-LoU+Dia5kr5yeaP!@B DBtY
+(K $,H*uR QFE6QĨl*RuO>SWVd;Bx߽w9resSyoNq9`ԛ1Q&J_G>G<.<7FMѣUތ؊瓲rz8v13L=@83Ls扊S/ѣ)Y<x Z@I&'$肊Q ˈS}0'vYfF_LtE-1:T(Sspp׬W`œimJ29xM!3z-q/U2ihZr{s_r-vUF*Ӱ8`Ŗ ծ]o0JE9ͼQ{Aӯ9i \z>lKYҸJ ; mYiu, ?HFl2=03ynv$]x
+TxO]0'2-
+Co
+ѵ2(,V}t-HZXz%,tq( #ZZP&I#W%^oWsޮgc_i'ǸC*g̵sQg krxi'NkՒJG.[9_7XX?'yNno=aܻr~1Ƶv<Ԫ(UE>_/4PGnlhhےhl:\Nܵ9!G17"QFd{z
+ݎ̞p!$Z;Pfu^8oY:<xڸ^gNŽYJ7OWӟ*ۍ(/OB˵ej叴|S[^+6rkI|OA3C&L^o*697A?jXZg|iy,fT׮փmocPLydͻx8wrLKf
+[g7}jc-v_C`{
+@ f~ + :%bK;%
+9gϭ 3~
+HFvUhVJy%QHɿ4}U
+_u,wo(V=>f_I |Nqy (1ʦ2rqwV 0D zx|Mf5ER#ĕj[:SKzPkx P @>)݀!{l b†ۮT-JdGza#m'_,Ȟ>~#g>+k<=qjCpbuЁ; UKN G 7 GUx?G(ldʲdM%5Q}P-X 'zt))w2rΧ$2Mfe.7.VFx%?9F>6DYl ^D+"ە.>ɢ0'Z6jsB%V9R9\%L9j.ԺfkJ-ky~R93Sx2*Y'fVwZ(FFϲv)84%LظTM+EآFmd
+r8Kj kr~2gNh[Gf-g}t+}]r%g,2;F-ZzwB=?9ra+sL?k*g iA_J
+G+N/xY}DuA]Kf_Bl\oMQ׏])WW$,sʢ ̸ ;F 8VfiնXrA%g1L)6
+S]J7k ěC`b0lCI(,( $bܒkқsf%lٮ#vؔF }u
+958XV 3# o6WL;3v jW<u¡ƚH%fY3L1R)d)[(ƒ6tHG蕺{u[-N\*eϣ{~~y߮oM
+P-BQAVq>?s}_rԟ-OYCլB 0Aֱc2󜃅b9 ć$f6gC lD5n*)R.Q+ l+ү,@s~py @rY$`*
+ÚAL'ǝoJ)vQ~!f8=UvT|v}DML(.p9z^v<Qp|X sG*iǪiҼ~V7$ct:1R>Z mA[Ms(#
+{Jwweä3Nל<T<pG1B]bⷎ(z7aquN$m?au##3xGzpg9{Z/cOT$12_=5IE[n9
+
+
+ɞUbʴB%Bef97\e|_6pv]<S~kg x] A|dR
+]@pBeIkB=GM{®>uI  fLfgf4eIO6d+.ǘqjRB+VصK<iLu
+.)1Ofjr>9d1gIO,h~ZU@HNE*sd2_:sƚ'@Ddus'g'֝q6KS4YRe- m4yTS/(Fd
+2 2%!IE NJ
+"D1AYZKP/!!~`o{VVD6-`e\}=kIɡ8 -;giœyab}Gj}ZngCmEE''NZ./+~$Z~`J&?x&CP*K_O]Zo\u֥܅􎜥ll&P&6d{d N- ̛&O0
+zp^Ul0
+zt
+ⵔ)&s#=`KZsĀ(6dxDw@QfS[g  /qE$A[Ƒ?̖
+zܙ]*w= EIQc+a
+&RN ~B/F6šM(GZTD+=`ٝNllHy$v=/<WINp,DѫwIb$Fiul~0:'@XulӸ-KjiҒ lk[Iܼ$r\^0+aϛ|VVUE*Te1 7քb,˸Oו=,*(_SzN+{lr|B D~ }oѩšLJ^ ϼ&Ra){ʮ;es:Ygqa&yߙ|o\__J"'LK'hGҭM* @OXJ2q ]F{w!#;qY<W|Ӄ3<Y@Fp>q6e /3{_A'`ہC^Šd-熶?NѮo"^[Hž"UE~=6?rrGgcKe7N@}TY|3W7~X;U6dfCW H޵C ЁT],.2?w0 x@л]{݊/6f*C3Aij?ҫS^=:۵#;u+b :H +ڏuSi꼺DKO]; =Up)U߆!,5K˾ `][9#w>Yv:k,[9|E{Id=̜z/w8MP4rKx;ܡt}7=w8uz`No4!- |${.*]_0(MٞaX!ZQ Cɕ+]~qÕO$4x
+D"i¡眤/[rj81Vg
+*g"-U8^[8t⾓'w{?|o]KX5-8vF`n~@ ɹ"3Ag1
+endstream endobj 14 0 obj <</Length 48415/Filter[/FlateDecode]>>stream
+HTV{PT{Y
+y>Qy < BӴڎLͨդ45faX䱰ϻ{޻@jLMGNvLIg<߹áf7#}/BWkU\Cܰ8;.5ObKhZn5&ۡobXQ6(297Bn4LPSh
+N+mrh:y!LKUl Z}Td_RǾViTJ/u;Jcwzo0 DyV|JW:-z|r?q*:oOYEDV]O%QtJ-U)z{9="A؂MvYkF[w1͋0sNE[u{<^snd$+ fTa+HV
+!zIS
+z鷩:!n]p9]>h-O[Ӗ~j2Y&ͦ1Ȱq8682av4O7π;
+ H`VNiSjM@[fz~
+D110 % b8& VOzHv3/
+I
+%?A/"pxph"1Z4Usinаa.b8hi:`5 u'cb9"sETr!sNʡt4EC (JD)ȝm`puQX<b $;ٽA6/1׀)GEE4_Gt$]3C.<B{K(>5DWhJPIO_Fz+茐޴STFA\xTҙRC9Y귆j3D}Nuғ\P`7 3dנI4r
+=S 2ixøZןZi%߽g<5Him)ID$}ThLF-X8N!eb ʼQةp80^:+TJXJ_"(SZ(OS
+2N@ɧ P!+x9?˳0ᙈ[hDze4xOvhV"ň>&jqQC98yw_.jṔ>~טs"Y[Y-V>YwXjcޢݎ_& 5Sqzu]?{jѸ~3^ݪY_wūo*~~ĝ>HYKsM/X/^0e]l|/
+/]ydPTt2ILgVh.j#a!c>Q*d!}[\S-T*Dƥ|4WN5.3_Jk4.#l0ء֟˼ Ylbx(~Ud?O}گcu`Qs;]@iQ@}>
+N^qԓ'G?BhAfH}p ȠN®E~:J@ӕ(j5rdi(-S蜧RO9 ?ަQ]rHd~S}vQ0h045't(q(dPNTN.<=7ar컟
+9&v':ɭM~+8u2dKZk*ꐬnhRuZ׈u{ͤBtH*<w}!2BӸ+m1_4.w$;~x=\Vc;$9UkU6&5hbӼ0 4S -A%TR2,ߘoxe?Bl JtuJ3Ve J`oBugw_/P4^&^
+
+^@3i:iɤ&N\Tr {}''Nt/y_3s{<<|уyYcuTkykm2nĪ3]]^<vQ>(_{bgT}Wqۯ17srYjNgE[.iw>4Rl_:%qz鬑\P|FÌ߁+ܙ:+<wW<k^5p_\q1Ogep@c;e On&Ĺc,7Wz:}Ua_=5_mׂZilb=h8l!o<h7}#fa w,żZ:ZۜuN/[unY?K`Mh6~gtuʻ$XogYx|fy5Rgxec =@so1 9-c~[̭lv(nÀ.?߇3͏qp5RX@}`052[<Vgf\;Gq~Slu
+x/w 78i5B#i4J*IPžl[Fr-|eIux |W_ >N%0}~@;\a
+Z>~r- 0D"![#.K#wA>ߕ=XCMGjhBZOozcʴi)ۣ `H^
+mCycn۩2<vHֶDz(~(Sa;%4d[hEu2%^KGz@ Ҿ 5ͣ#ѴϬ\٣J95Yú݋,z & ݬ-Y&`1"E/fQy<8: MBR/dǾW^>+{^)+^?8JMQ湍t0(H^@zgER!ʤ.>v<PuNXq{~;S-[]x{$-/h"*<ӱعEG&۔~MOom?vO˻s#CC`Cpt͏==擏O~xwəOCo~u:|wc_H=~㭳g6}9Ɯ$@*9O/Qȑ٠C46֮-݄߁|ZnL\Xlxt]nc YY83G_EIxymG (",va=gj*xIG~Ё1c>_L9OVӦ(힚'մūjA,[t
+?eNAZJhi=ϣ]#?R*pjOM~0%PP_B쏘E"wۋ)KKh_2*ߦX[ӮcX3ӧ)(}@Ii
+J2!hʝJzO}8&Tt@P'ȹ* 0_&nȚ?T%?S<}u#&WceS7n{S`mF W?M(eՊM8epu }{xf{fIԎuCѶ0jmΛcFpwՖV,aa4];>H,~]#03;~>#icB]q5(3%qu(=]03zG<~|6^cnqTZ̕v}׶]}W:nfɍ5lknI 4
+*>xKYAb.Xl&c'c'3MiwNι{993uOm
+WsџzGVNK;vݠPjG3<c65{E|N~03Dˆ8xnuu N03갹g| Ag~]
+nJxJϰ⾘rٹ. SPT2B3 $_ /G1
+/+%u}rՀ:WܔM9-WSVo8t=07SWPH+v
+٦fQ?RlY ZY4)Qg<Ѧ9e9n7*^qW=D1?C̥/Q|*KeTv%<:(a!}Y׃~ø*{
+C_>V\X!ÖK
+b*͔6* TR?M/ h6 ?GCTeR6JtTEF*V$ u. ̑~EFd[0.wrA0.&6%/$sžq2e?"2{~Y=={3<BNIrWL*>Y42#j0/SJ:q&lvuk^5uPT6eWW
+Uyl^Z]A{δ;h
+5ywciԷk~>w>.?t#忳~m_Լ]U=nXU;mdž~rfx˅k<O/Db11yN g|WRcf_07_FU
+/oFߗ>cW&|1߭9IXZ V L%_<GFP鴜EAh?U qJh#rM1biH,mQQ Nup^0
+!Ew
+2!"x~~7~)N}hR׆AfmFˠtlWMC8hovm2 MgF
+_`q[
+_c9nag6w !g09bʬ۩99!N9\
+>Vd{yϰ 1|P:f
+Lc]/Is(PD$9-g_
+ւ׏CwO \ G,~,?{6= ~ּ/)Y*sgpٿ)^ow"$aq_p |NR4\c9n}p83?,SiR?÷+eTlYMϣhTat?YD[F句Y(uqt0Dv<Ϣ[`3_}.[ҋ-)SDo8!ޥ1y7Q!Ut(kC%T ~X@B-X Woyp^F՘Gq0Rۅ{hxJ(XCFu-g
+(Nq.7 sQL#VsoMa&qKpqI LgL)XqF?|86ޏ>|؅m5q}J*G!9x_=1-
+0͏c쀛>{ݨ6̷MzMޥ֙u;\M*ƠU>:
+݈Z
+
+4(+[T2bE.(hnE ZqjjB3+" hn^nQ\FckXSʇ|y-|}}}w=? &PLoot cR潌jrZG@*(Lo"򈤾yOc-sn*l*iTR4T(\ g,6"Kh `U*p05h5(JI^Ig!9A Ё!Eqnkh˅ec}#YuU"/|#ly1_(zjS#R)OL98EpEc~#د00bM[NͤAyLyEPQTt.}5[}LjT`D܅)HtMflJ*ԯFϚg eSB!&!f̥5b!G⼊; *%KPRZG
+|9F,?=ǙƗ9F{Hh?W
+Kk,4F19* hDG¾HpS>\k.(AYʅBʥ<!H\U`8yp?o0vQ>si>)QxB
+%dRӶU?1??pݏiKv6|߅"o])f
+~g9AgI6nuPY[-W82
+lXnX}e%|&q. > 9wE΁i|e0g +Geԫt} a9.R0bY;e ]yX:<*hi6LpLdo{R|tJt$")&J-zܷ#`o/.ͽx>
+ktv|Qf>5PuZ*ITZm+ grka撹[ZWsr`$jY Wf-~#;C+0[onrX/qdָ{sjB26+/9Oid7On>uvHP縷Zu0:fwP}bUmye='ﷱ:}MZ;zGg0g6vުkk>Z:jjZo]u7zGUǚz5$PuSg36GàUt3K`8/YF6v5x`.pٜygfpJ~74?b}'y9u+-!=nnj/i0?ޏ~aw_3I!~bj1
+^&(l00ֲ>QQZ
+?Od6#/7(&
+zߩ`y2žM#_H
+qa8
+*u`nf
+q~HgRr/zJXZvk P
+ ܟD0^.G) i(jf HkBWbK M^qe
+V~QW`paU|#f! W(f/1^C'1gʼEew ̯rK$`p6Qv<O|e]iJIRNg/VM1pi{W]5G/s:cg~}$`}&`SdQIӐ|yoK<mzٵcf\H?ЉE2GS(i2+(Bۧ(Rm?[(u,%O'a$}*..l5uRPm1x[nxH/ilWMnd& O
+44H(uJD_c8o&Q¤7Cl0PiZԸn'Jٕa(?>܍st?Cx>֔xqYQEv@,'%$-ʴ1*6*'Y^J9.Ӹ
+tWױORXs}33+?3?o)1yNцص~fϟtx1)\^/֍^o9~S̩L%t%XqAs-av`}ڮ4'x ^QT<97NԵ7<c٫eoԵOt;Gnzɪb?^xdLFՒ4/
+Y x%g} `poXW 6kŹ8mD3?7?D5 ELK[!M%*
+{ɼw^]M 19@),C8B#nD\qy}0V.h9w"'',DiSo$B*;;Wf`&O P(j6@Q<( X P'Ҧ
+'*u* Eк ^ӧ&r5-Vx{δYM+}xq #
+^32b<Hy߹_a,4%C,5$u?a=]pŮEoieQsxڕMX{1_X?/]hW=LO)*i ݘ `g3l  ^\Oҁ?pxS JKk%zɼ"łc:O`a]&4(;e!;CASAv
+aa'7M b>z[d/mPS,<N9Bi"E|q˪MNb]#/אb\ 7-ŜrDb%']yc>BրW&y}!S)x>b~)5|{8+U(xO)D\\TKor2˧5 L8~zaiQAPAT";ȪQ%q:Qđ24BwC#.QT&ITMUj>Gy>}G[()R:r<7W^Pb =tSwx⧌ w)9wgKE)]Z:s祅_cwG;tN?d[)H2H(Ņ5'S2~L;\g*v=^]ix0QǶ .~jZ"ko3gxoCTr~3^^OA_2"iYO0y>R8,tԘ WPILZJg>`.1%Χx7cF|pvYOPO= :l':|q}}ixkg˜H@qIFNs)DQ?_=TD%p_1>{b/ =sQ3яN@]83!5
+u2Տ:gjYZ̧j(o}vL2YsoUpoYGQl;֬ٛv /\ǽΧW!TCǯЩj۵]ꮾ! 5j[J_BSoRjLQIAng&s;Mu}gXs/s
+n`q[ϻLz(|fۍ_ؿyCg/ǿ}[=~mvQ5sw8 ?Z;
+uD%-)Up~L+t0|്87bqmf3/vwM{xn\j8jrΏ%9
+O|
+)ϵ;)Oy
+S>r /rL{R)BawZ
+ڬR,rR<D 7 B.Bx8P" q'񟟣<t|
+ODtpt*FY8~,1}lp5篻ny; 7V3^^'#t*>޷wSzweQ)
+uvrEtO;˥OZ[]on¸fG1bp5zרv`ٚ_31Ʒh,.?
+0\{^
++dۍo:/ ę-?7/cL$ * AP.ӅxY=K$銠@,_FQ#(9ځo\ /*AO\;1W]p%\
+ލzn)%=SҰG0f`$p q? Kn 
+JwDyk#&1c
+(gx#k1c
+((%^9b1s,m|geB( :B)aFC2
+&c1ӑ?p%]^
+-p+R]q.;~,q}SC9騽ؗo>-YO-vOINCOBgB?B/eBW7+Mre_)ޔ+#mp 3ǮGъG/̒ڰrm&R p;@f@8櫔 ;383zy رfYvUaGC\ 67̊z@-psaQӰW+wBFٿwqxQ#pǘ_~]G?Dw¿~`mr˶H{K_}?J
+>~؅/?Oc%Ok. E.oj]ECҋhٳ/:o(^G([CW7l?hۇˣfR7\CA烪`/=
+gC:p,㞰Vz5+&:R||ƣA?DusihӜMY#8'Q3NQ >ă-F7*Aab9:\0Cg}XCi8Cp(% `lU#%V(ףth-X/.nZ2qhiUeңcDxZTk97t4,)PGDi3
+%7[r'Q1›MSs75cQ@4%<:`m 9O됄wV^Oe_M\9 ݱ7o2nW&o?y 3ړH8
+.N~ofўO/Qs|{tw cܳ.PI\ܠq-:aIQdR"s VYo5#6 &w\ۭ2lQJw+jM~tZT-V=h)~*|`:%ÉƽUf@%X|68ؖ,o;[ȫ
+<~זE
+Z~ޡ! -&#}ڙl(! KM++QrܯHBEthwtkP|u'{
+jt'|x}|$`빙kkS(1vy`ЬG\CY/EODG;q=@;?A G[ZӄC ?x}Oe~M]UQn>=
+aOѷ(~^,KރNj6aL[`\p7{!U{eUX`||a9(b1-w {&{xK3ȣL:%Γ&Z9 Q]nnAD_0#gA-ƥ#f'w'jȐ ^d o||x;xv':z푂O6$LҺveth}"Po*)6[ߣݞ4MݫnTK-=F[
+G|-vNj s ë^u}Fu)xpGP5}~foӨq$R݃!Ʈ?O\n Q=iW?7%bq sxa; G]
+CX xE@k6mQV >=
+ 烟IڦvpG=?hדx<c0zKp?{?ݲAM8;-
+mRΰU6NM1xpd fPIxyNḽ[0O7Yˬ]mG=`}SbG~rϷkGGc~mϧ`:8ؿp[ϰo>N#sSGZ ՘ﺟj.{
+vZ#g&?58ǽ#f.c:gA~yg>",шi"v+<Ƒ0L|̯ߍ9h ڍVe 0; *8;l!;v]Vhci7tZFU%?TcF-_Ua35{T0޲?(`m5hkV\^ږծ"P]FCM@ u~\m.jn,* fل;m_9;q.na * -™9%c u'ƛwߘKOЂJO 5A nY
+llPU~OEi&5h-jPQM1`x%Z
+%
+0ol? u5y0R’ ^EXDVP| ȼ=J r_"HS
+""ˡjL%Z~dMj6Y
+- 03Ls1Zf]֤|Mm>lURJ%a?dv<m='?p~u:44'_z焧|cIzE7y:#w @X_t6Lna{<~O !n6L5 ?
+2f9]O<68`8> \!uSoSgS$pcr;8d֢o`,(<S{5z!<m7 54BKm P,#dvoF^:;aUԿ
+rہnIkQ4
+<QX5-[N7GU:/LAxUJzV#Mv+Y|*xo[_##XP3]6xo7[^\l}-;b):pIq5KVY7÷B>'7!__}RcӮ(ܿce8x*z.ߣkZN%_b}wI:XՏQS|G}Jԑ ?C|3]/c[)tN|H\:HXt2Yk9Sou/w>1 ִsY&
+W+OyP}oꉫϣOb Ik4+eGr*ێ́ȟ9 JC+
+aDm;󏋘Gb'] jYOÎa "^OFK8\IG]KEB=H_LZ^Au:x
+L/Bh^Ŋu|
+(_RaGf5˙Q/Yl#rLԜ"x0 e&Ġxcøo^׽@p.G}t
+k^+?Αy1 unMJEG9F ѲBk ;*a:ObLVf>T0l|d2=|Xh 5BcPvڇI.[%e6uuY\m![f[wHwI~#η[$
+ΚH1am?"Fav_!𣏨1-/̡gCM^`Hay`2كfn$>xiUU}~n&7_W;BOFW_OYT|PzLkyS櫦Эfm`>xw7wlsbsvM]S%@"+KyaZ#$G8<pA(oGz_d!H0>ρ!H܎e?噖<S4Cx
+P[u9}R:ԃw6+IG}Ӑ!ZrҶȩK@yc#,jy>C)X5)8]S`2VwB=b߆/ zQp\6NBG yMI%FQĉ ?D,[$96_'~It<(O%rd̕~Jfw6A)?Nykhjp.YgII NОJEך+b`jă"C)yߓFU=ks+BIͧT(I yDƷ+!ncb:s3ـKsHAԘa`fיH
+Clr*$ґ1UՔJo?gUOYOFloWa_BF-e!dc6/h,ɺM
+AJu|J
+0=TyP?++/Moٷ9ytƦJh
+3 ow/quW3Ϯ: pzAhS>s
+n?Ѩ[9w;wgJP㙫3Q۷POS60ˣn'![D.u55Ȏ  ~gvXȽȥ:X) 1?a/FҁB/lhK
+>b.BD
+PPځoe̟~N;pDoC uܓ)+իZB7eUu 
+ BDdTAQDD62+U&Kd.l*!2+37#!hqYYiVLRՏW{{=sg߿nkS@H).RnJA`x0]2=>eYv *s$5Β-b^7 4( ԐD=T_F_NA$uH"0_$-Sd;pze&=O}<;4'9`ϟ,*.;*CveO/s̓"Y R(M)fh-wK)$ʾ,J\F'Rhc
+;b#ޡV"`i1ʲBIb@)~W\+xW,{rA_]]kA8 Zr7-cں$*L=f'IB[&P(1V?3#8K!ا(%-
+Z 刁d/_z` KJr|)7TŸ#q~i#WZ K(EbnA1#a3r0BB5|DToA1˿!·{;NR䭝q{;/&N[s뼃ٿҕwww;0vm;vY3xVhr/yq
+,˸q> xG_x= [ J=+cRfL[lRxXt[4J>J\aTV.ǽ2. ݡTzra7Cɠu 3ᇭVGNx_kZ%XO dz`PF0)_+2!e L+YAZ9#*iݐ6Rx0mNJh-{Vh
+S<hnDό܎k/ˡP
+jVDُ cǥ"r%SwK("JFُ87626ű1"eqEUg᠔k{A?!`*5-FKͣE >OMK_ߪi7h.3w[yG>f|t-q}xAT27U*GU\ 4Xj\zs劣4:B0jj\ih̾1^@M.-RvY5dRM ZWQ1Ym?1Yi=b$LSa>Ĵ?ysH{K[[U&jT3afwX}eh_v:k:߸Oy&1pum.zn Ljp^ T[m;Zl{2yѩw5Wu?k6@{0F}uxgg}3}:6gGưk=gXngǙ_Og:gԫ7̭]`þzO?f?;74(3o A s^;l;7׫?vUzخe\~Xڱ΍}\?pz"{款>sO>f=h.pW~={Zjh:*4߯;okwy  ukn0f󣏱{u4 y:ysu|`ŷje8`1=cv0vmlaO;N4sS
+57sbn`$ 8Db 6I,jP>8D)(2R<rfB" ~͂3q-h«v6MbZsQNk΅P:
+eAi{}!J-?Rw3kGhc^EAI0_[i$
+r I= +٤T26|&꩷_~"7ӯНw,/. yXFG TGO=I?~NySkh3q9L y ~W_ܦeO>y8?LAj*5WEaw \ Uy*ccccIiM`܎yг0x*H[1TEC:NER5cz2ihTNyGCmTa:j/ Ǝ;.z쇷op42;;"ЗWwZ{D)EBl<?>E#ịvIN5ou=Ep
+ډ߯0 AtKQs\
+\| xcz .}Txc}Q͇}-jLFo 
+jEgQR`8} 0B}&0YF{]Vׁ-C%^b\O>g{DEG15uɪV e9")ǥEȅ䁇 KYL\hIs]T'P-'Qlbh|{cQhr,U풎JsTg)+igǂ/±6HҿLWi()T"(zxB|ҧ8q '(S(q(٥gB\
+vCv06 ,[1o2h-J&
+f\~mwM} cKm`,p;l ]OikD k9BbLw<Fh .Zjg~oqy{^hq4:}צ[iufe
++]ncV (݌}n8O`s7Zgm[izZY5 Z\7{r)kp~?ϟ_</\\/-BCi5޶{[p +K";C]\fLx79n
+!nv->bm܇k N}f"ε kX=`pS~+P;o.ܛM1`'uI,;CQ8,o9>%;3K剙kY1Vegq1u`qX3]}2n\K~G֫?- ;'O^'|ccyQpA/ o>oJ|v:__ws3ce8
+UX0g._d _K,C~K q/yX܏ruuOX9
+yMs%rv}a3s6xZV(I?r&4y{=l&͂r| >c'G:8Xɦ)ejEþ~j[_kGvG@V}~8NJc}k:e\}W}u9KZQ{Æo{_]T[9'?3ۓk/j<#7<2ϭ}vX90 8&;^u᜝pvZBӝ`77|&:ecڭvD/+:[A8@
+՟ّiS9.NSXBg[":dOC -3s\ uoȽVii'yJ]!y -kc48vVFQs{?"\d)U[LuVH!S+߈W )/#j
+ߌ9 `l6i?(_\ѦJ5mEgH cqtp\CţpJB.c%^|MZT$IHG2:;첇
+BE 0&7m\$\0lݕb6!0vr d
+T10XǑeuPޅ:FrjE%$r|{R!"pHcR%/'WOpz'\<Wz^;@? KuhTg>pNq|]x.ftj\Wo ǜ'3=?sYK=ؗOT;*C'$0< } T8A)| j*qP[|r7$Wa_.~tbƸx5YNSRC3 c/zv9h7=sp0)?C}altb(>dY>OgT8hܫ
+G>RѮ%oϕz6jisH_^V)
+ڗyĜ2ͤ]ƻt |m:`mĽE!J
+s '" :Kz{a7 e)6hS5RcZu!T0@= +#y4.Gh8"CXCXJ&?s dk
+U#*y
+*TK3sd1k\0>~X Xb/ͱ -;?aJN[a5T3o (h?bhJ(JJG(A92&ѿ2_qF7Sqm,<[KES|@b?'%)XJ1R~J%?)?U ^HG"qo!+(H wr RTU[ eӯ!m4c)kdGⴽ\bYѰxiy|>a⛄>Y0w6 #Bee9u<Aok0UJՉβɫS4C{qy
+?khU~e]|(2wͯ=7^cu_/z˞?.Zv]GS-O覯?a榯_?T3~2/_M%6?Xbs8<O}*κڄYp7Tk7]*:׃mƹq<9:~ZmNnJBwjec;:+dY)1>
+8)0ǼNܷw}ŌDɍvN&llbYdtmmNaxð{fKĄpԏP𐱧ɬ7 ; ]#F]Kk\W{Ebq$\ۇ3!` cCfM Κ\94~pjx k5%|)%
+(BP*8%! ^Sq[Tm^E1XZk}^ԴZi[(7āc
+58)>`5}s=Va}= 6Bf]8>#x^1sLߥ 9!+6GM^an} <%n$g]DiNܱ/ Lv{v '5CSBSL!U#݃˹W
+cQ@a\!ux?l ]?y9%*)2 7q}V9E-iKw"X9I媳(&Zwr?v?NTt
+rNWȧmg Eok҆?3([?L\lqiC m?-8@)Y uLarzHWr g<chNRe0G˵?R[dz{-8 z;òHPZ̓50l@ҶRIk
+9,rQu%p4kPH.4XhpC7{۴{ /U{3-FC½<ʜo~XzZKi=5)a!Ga
+E`ՙ2n5W,t͟knkͷwl_{,pgkQGf5?3&k,*X\͜5`刱:".mV5%yY7doW9ϔýNS#Ss\l;hhq [m3vIٛz~goc^yK~f7߃M3F^/ͤw:&Ǧیf4.-s:\_7kF[1q\Bոw5>Ӡu[4<4, \M8^ֽy+|5>{_ 33;>7.2[QSN}e}'YYn]f6wOn׿`}C ߋzi74oh~59W h
+AXcp#Vӓq_7MG&ٌC1S;>d놔eNMF9;ޫ +'T=Xo{uק׃u[8q'ٗ,pqT3q-oPq`A[ųUd~p
+&Ľ@Qp*FQv wP;v 00$9>mg>mj38wgEƋR9C";DFZyK |W"n舍`(7CGBGDFŃ0Z;d`$Nj,BINlIΤVJ+&~&!wwJ)KB{a)A%)(-=\M];ܛ+{[O1<wɒ\Oi>$<
+1WUO'0UX⭁mӌ{Fr; L™*[e89 A֓6ym(9R9IA&7)nɵ_ki?'Zqp~s'ϰM`
+Z] L |IBm$?Q/)E\ ɶs$I8KPxi:cplIּv#x bqƂo?UQEBWA Dui8cn2tIX+;1KcDc^B
+S1lxH!TJՃtb,NLӱ'aZwmC#1<$hc6>YA*ƭB."Xq:}y@0Q` :<Eq3"@C9 3\HQaɒE!hdAS2( -N
+oWP1)AB]0]sZ(kZse.1fz1\r}G V1.H/F!DĹe
+{g2R-rA$Nh5Rhs)ݧPz֏0Jd&8$>ea٢".dSyp(˖mS3=df6l"OBK\i^)--w׻aP Y|di>o!o{,%xן'^& a[AMHRkSEsg6ڛ+JR4:iXQ?wejήwfxAb ~tix\ADr-9,zxZxCoºߍ;!xRJQ'of>ribi޵Wk‰
+h4Os]'mGǢC3 X~@+UȊwřhεKs)׹Ο3'=?NitAm>jl;eܣ8$U)Cƻ'=ԛ``,~6$*9_d"d1XBXoKzyyfI*Sg:uF(v l*\1<FsWk0%CkqlrE a<}_y9 sP8?QaD1߃eh蓂My=kc ѧp d q?}JDp=E SM:nH3|ɶlۼCf/,3%k@_
+FݬsaÏ.:D;ǜm}tf 0mzsFLJ~?ە0"`Xf|7
+|R!/{`klou`m#t[?a73z+;d#)jX\ב3Rq5]0jO
+endstream endobj 27 0 obj <</Length 58395/Filter[/FlateDecode]>>stream
+H4wTSyolDz"EEjIIH(&#2""M PR*À"QDz{Uf]QPaPH~3~{"d%,r?$d4e^5e>O*_su%}ʐtEpkGs.e96~QBsH<y޲/ݗSq=+9|ȵRe7у i)EzqF @ 9
+opoo%r]^Eh
+x\<A{ao_RP&0.Lusys9:*rz9jAoz}9I>0C*} O%Iewdiq;)TƤFFgΟ9*׭Qڷ}MsrO佪aRҟ?]5X0)ʛ:ݛ~fg
+ʔLerᅤO;.X_ѼGIŮ8U$(]>Ĺ {cgU' wҐ^74oCZ[fҐ;u2{EHGFȱ?9_@;1D͝+Zl&䡳rYҾ)Ftoۉ<;Pxئ:oE[.D"0̚yȴE1r295xJ2o EJ'V6P8bX)=E"93[b(+m<ɿ7%,O=1G-XK.-v'
+ޘ4R YX.}!|HYKR֢IhT_4.T(.K%tqQ*~Z׃u'i dK(A 5%<Y2硍zgO4Bc>%0h?&hIi)'(R)m$eiW1)rgJ#ce92l!<"{8 ~R C}e pw~]w((8ÚȮ ?ӅȬ,:8Ǻd;(@CBxIzv{ұ5ٵyvr/𐥪.!!U~!r`}\ kZ -E%z=cKCY+W9#̃H0CDE!"rc
+N 6"@8R,WxOꔱ߫W_׸SMCV.w3c])XKGƒ޻*=iB}SQ'^e0OrzW#cFY>#o[+B_41'!#1΋_qqFLɕBJY7n^D
+%,E
+lًPpE-ȯQk R {ٛlBQ-S 9J!
+Q}zȵKy "QMQA};B<QĴV #R)FR'(iS J]yF n
+99A. w6rz ssxbV=lN쳢xvP{PyF'Rn<XxFq}cX݃19/pƵgD㻸տ?gByf|bE caQiF9$u)s⚌OgH/15|4$i:D<,JXc]قPq(N[?z[5$X?庿U1|eTU0xPE3(ss@ܷ[gq 彋.+&>=X
+}zg'dGD'DIsγޝ}ez',֌bgN%=LywI
+wM
+wU#wCk~NOIAG(p+ \ڡ {j{R1cQ9}J>;59{ͨdzR\)˧:L_rښ<=6=aN>~~[6mv;yB}V+/x,(^GĵжqiKisWqdnokYSyٟJIuWH\oKԖuVSE֟iI ZO, IKc.|o 9܃b>hrZP] Te
+XU,Шż65XW/s#˃#ن?527rJw/-/
+X=X&\7 &,C9O( .ha` &8BrG7Uy.;HUzN%T^-Ì
+5 [ƍ(>Ѷa(+k'k Im$%6EǢ("a|h`V\AMem>t(]UD(&$BMhJo XĂHPAD)FqtkA,5@gͽ$=}'qRONBH3l~i\;
+ơ O@ %\!?D@c(!1pC/ԑsuD}Qzko }%{Z! NALs"Ф>}7#~8h"skU
+jE
+o=blb}4 K!.FTPܡ#QWNO~0Zvwvyܤ,@f^ʟZQ_Qݪ,lruYuya|M | pR 8 RW\9I.)#(Eޓżeer²ry"%i)wqZwnYrd^I{~G`*E%1<˙3"\OnV=7yBf?u9)1?B_$K=ޓKX_aiBn N-}N.սĆ-mج[.r?ρۭD8 "w C70KØ-Wϱ 9r8c}
+OBGW{xE ײ <U6yjcwTofwgHrEҌ̹/5~gMT=")\Mڟ17w"8p;qP%/sob
+YrU Ic'N-,@d|i n_#.paU$D"|#y_l^ ]z56/l"}ؖXKNIt+;؁kvpY#^kbj7L*qk9KNn\PjTEbL&׮†e,)CJg͓<%LiN9]נiأ#{܀.|mx}eܩjۜ]M̚ V +83&d=D
+4&٢س&3MfKÔDUW.C`[|t{s?m-d~)J(V7-_V5*"}
+DYIjGnSlkE9aT9bg.US_r^.M%Y )PK Fn5
+]W+X^):|T=eR9Ӥ#
+Z:W N5Mvz=^89؋`ă]5y5f_1}?[J
+X(AEa2xhkڦ*zY)h
+y-#I-\# r$p amAК oڣ@K[$lo&utl Wx`^K,>yH>6<E)(Тև,XUO#3ͯ_'t(`f-u
+iCu5Ri^bE lC`+aC?uXpў׳koeOz<.vW/96|shINL %'?([Z<VމOc3g'$Gs{G VD 8F=s;NANG
+/7q+w_<%?k:v8{6a$S&+=q'y.Vp,z9$@ψ_5dFOI{i%p, "@x" 3<N [篭[0+~0:~={JsV3iXb"f/4qf``t8I8~Ьv]y鱚z ǒA+WfΗ[3݋.6-1_66a2WG?H7rfbӈCA`=[%";9|mb̉ S־֏L+)(h8|7.0I/=x;pWX`$FqJWe'(uT *\n
+O0gCL粔Fur
+\ǢNL kQ9E]р;{w
+wsM|3˚P VlZBRl-$ٙy}?ߙ,Xс٠,ex8pB9_˔1D qt2T-;EM߭r0cƥ"')^%!~'nŘ фq01[21wD'}\WEW%у8~CUHP*q=SH%$dO<GKʮ'_?-*IG@،>к$MPyf] ڍsZ sz^igTkV<4%n5]|%lHlT}%x.h5]NBaH"%S=3m\"]4(R )]%1wB*„.ZgZީvM[Zg]w{=Y<ۆ;7q5 (_L Nlq~HN]aY}sx%K߻ZHk/Zs7WeQ*Vu<nOWƏ_D~,8kDIܨGa܄{~+{`1?0}F?'ҥOUCKxS- 6! Zqb",[dcd65Yd !,MǾ9_x ȳs%/W+D3Is"Bz֩"z;Egџ6^z>/wˑyc6(KقEgz?͗o{2OT wH0׮/uOr_,8ʐCi޸a
+gcAwFQV{o_.}>4by:d}V^q.O}@F(,-J.fu^9.u2p̒ksuΖMo>7"M]~(\<hs s Y>oYG^.L?JytlN1S:YT8ot3KsU7U(F6:6VyCq)&|s#{(`̷Y_9Zujd۲F.%M K{:-ET.M=3x_^Ro*^YR !|KAд ܰ4F6*C2cR(ԁECJ3^U;GC 5A4] ZR;e^6+3e`W_ي@Ʀ1Բ\7ZQ/F6"Չ`bXs?ۛpKN6Gi\?`ᰱ* %`߈=h)v9Jsc-8Lsbbk5<KCZւ :qdȕّyakl Y>&,D'D";%K#ÐQKplV#7<:AXON"o'2
+T](Zq vT{hF֢^/F_5ᙵBFUjO/BM.؎ ,50c4tg;&f-{zɥfq:N~,˘(7sXyu2EÅ~<Dޛ9ғ$(a7~x^݉} B z*dXEӳ]2&zNCܲ{3i:  @Ѝy_,};'ih7ݖZC&74k tlVmoxwbԿAD bY2BA2v?Y}|ȗ e҇vȑUҮSU@J )=dLl"[)KލՈ0~z1Xp/߇ŀz m{)`E]۸AgX gLiܳ*\Cs[_c,5&5& ˝[PT'(ҫ|2hИz]'@_XU9_w=UfYڢ?m^ǰiRP
+ץXi/\Oc??{pQcO wO_)2!XўT}%5C~8гas
+)"
+i4!aEJY[kz^s"U@@r3wn}*9j/
+ ymG}4mfXWQcg|_, Q4}rV$#/ϊ wKh.K7`M6h̛ߘf&ͷ}Ta|n#[gK{qo" ^_FW#|0*3Bo 313ӠG3(+M7ŧC="-_3=L{ٕƺj E>C7dB.[`  A aBN늆ԉ~>Ӑ?t`t|_qO oyGa{ l,?*=U:*=:Ө ٲcW&Jӥl Dӡ!6y0"/(-H8,7󚭓+IϮ ՄϬ_;ɭ>kպq\%Qw276 ˯oM
+ ?e==7A{Z̻߇:E rxϖ^GJLH 4- (^q(UIULɶ"/UvG*#MZyXm
+cA
+'U?iSqڴ[A2dH[~\*~l.QfB_92ienypiś<,4Qʜ))a%ae<vֽ?h({<k0y~ܾY9ʬ=%od..X:V5P:4Xnmmߑ}ǫ;ڕ=sp.`PG)\ծ,wNE$I[)8r]&UTa'Q=T
+%9.,&&u |N
+2ObNH;xEzT> '>5vSboRG^0 NK><G- s a0r] rNx}>9ś9\]k0&旜)Aآ*eb@N
+s+_<~ ( ЮPJ (ʲN=D}XxM'@>eH
+gqwbM -pQ wFa[$1DO,-P*aƶ)RuoM H(pqP?(d
+. N?cB{(q)b"B6o/}SԝkIWH8ev[S<eRPe b8]Czf6o=̒j+<-7a)qO87 i3^ \AVýFh-!
+#0ﷆ({ه8_V+iI*T9U i%Kz'"kcz2n~o]W[YWKM暨*"s۔p,¢Ey!}5*z2WbR7jm w΢7CxPؔE.˄e"5M&TQ i"sUn<FV#;WGaHL;X.Ǝg$zDkQŒSw$sI]R3#qϬIۤK_f
+Z`Ϟ!01ͥ?Xaޮ'{^j3Λ6-R˴EHlƝgnbK^;-j򯗼-({}zd/jdSlh+lV}rHtOSWOkfvjv DZ; {`u%Deڣ"g%/\mSŶf/LW!])zVGӜ;؜ W4J/,iUZQ[FL\;EՄxZ1eԲՔ:n}
+IO1;،6eѳpd* C#"WuV7T -Atll+>G0%q;0=0 pB7ó Mp?=o>X @B߃SBzIgzָJĘ6
+qfvWT1s-m}'h [ ؛5g
+!O|p(p!p.zbu"H4!߱enuZj 8c%*^_Z޼}`Z ةjI!һ6.Η ]5Ge]T[^
+`IԒ oh?R_V P+^}*g.d~e8|j҅ *&v. E:R*HgRtEʀFQl6q1'={ 23߻Gw{<sr9Vd
+>Z]|RRS0Zu,n+5~ͱ/k-Tj1jh0_h:?Wp|ZcgFZY:%&U-X ٦94o:FH,ne3[[݄7]_3Dz<U}l񥰮`>t
+0`ԃC_kEjvFt&6] 2I?/}}FNэN@7@aO^yN2yF_5l-x2Zu<M3L/],LH'$b!}O_ xv
+#qqpC'
+=vGAزP0]NAH"DL$c%SR{{ig2Mtz2}d:RTw=n2w,k1w|8CsSį܉_ M$hKA~'b8uqpDf6@(RRd7xE
+%GV([SjtVgAa+r AVcUiEnQjNL;9ecE
+5Afe#b&/<oJ|j~a[vbkB732䛮I_0ߔndCbV Ră/K'r;BddaoDGuBːO8dsؿy $I`  C$z:2
+W
+ _x[=`ZA*vp4~(ϥ\QrWJBW*Dv&??]!p -xfq('K3<+O/3}{005QKyʼn=MIk>KY/3k7ċY`ՄBx;U@Z.Q$RrX}Q{DXmXNVz>5}uy,iTSg
+ҿ90%<ЍNxughs1qlXX8X
+4#?Ajh
+Nbȭ!Ù\IQR3SÔ꒙cR̗_>3yr2&/>6rܗL;7uӧ^_=f] .7=~x){`"WI_ {2dN"xdMЋfYm!+O #"q|ʴ2PU2oUm zB@FQ)"4g7*ۮ#xAoYXd҅>{ϙ#S W7"v:NlÈu?}}tI' r!z t^:*d;}tL!ntWE1[ы'!vK/ΜU/}11q]""OFXCY}
+.
+;M:^3 zP\w~C_ٗC Ly8ɼZږ3,*m܏AC
+Nκ|$s†iэ,Vb,C\KhYR(MWЫ9BIދ3
+kކ7"ZdM,{aF`0:ƸqjuAʨjҬͫYpBs0i%zL8D]IY*M
+M׀f2p ̃{ o'!N"
+s vGH
+[FmoS˅SGҩ]8#|I.ҸEإ|;Lx[W ޢ
+#N{x z:795`{Wp'{(I#i~/ηB5m<zە楇Υ g)5
+?#nITƥ4SjYs$M})3?m!`>gHC@0[zت Blxx:a #qNHZ
+oτ {I?%}xDs&{,7qם0|O'FB^뽰Q^Q/9uv0ʜЭKԺ 4+zVS$תv*;1Jl_i_^+nJ'Y_u
++v׿N\_ht[p>{}؋8@G,>(;=g=8@}ポqoK? ždG!vl\80#.7+IK hKY̷1$1zѹ;]?|nGu$Gm5zxЛjlW@wȆ>t/!}WzBGj~- =-8bBOAڀzvZsHdZb%orf)TVػІl|qdkK
+#4hM0r"FFȨAAPl1#%:tw%4C>,#c/eԕla_CAQʸoH$$!!TD@ٔ%N¾ "j!jLmF:*T.̜9{yu#ޣ_$MiAL_"-_f}>
+{Ҭ]LMe[%g&y&RڿWl\H'uOz-s:6Vw=i+>'0J?h}A`WlTzy-ߟ6'U{J^[% =!1;)OWV?IyN#ٵ :G xr_y/ﺪLxEo0KbWuӑ:Fb-7bӍ
+_3Ђ?:K^P#-A wFZ9![r<1!]c^ *ᥱqo'xKu{i* _ FMrLOͤ?,rOh,N٬I3iu*p:?f)޾8p̮3k[X)iU[fLR$q3EbK8X?WFs]y(X{e$i?׃eB=n vY?mCu 4o/ii%mִ7P&iWҞGYO{sqs:OItP\Et&1ESsV^yQ87h3ٵ1z{hD$풱#O1Bwm1~67Bɋڑ?P)K}^4 y zU0yr"#n^@QcL[Phzo[5%ȱ 3K+~Rvi eF QҐI/2
+-5
+i-cʸ*B Y#s 1ה3Hszf Y!QJ`>F2*2ÜhMVr>ۗq?W;e&EFcw2qu¸>EbLWgj}fu e x{޴g OP}F>!}J~*㼴N84fիל RѸ];n]hC
+츽X/EP~Ⱦ0oFRW͒LqvW#'^jK_h)uT/ %
+h(AEYEQ<
+H$ % EDZ(QQAġH$ #8:uvvΊΎb{Q#{so {Gb#V-5Ū&RZ !T3jGtQI7*yVvrR-x9n^xOCm[k غvRB%l۴F`q;]ر'%ͻauhfAx {01 [5 Mqr'ºU9 =jf6{L8ʷҏX}XH,Fvui\\%(>vӃ6Gh>ܡ=tVpQ(TDGHf% xw@
+׺yvO5j<d!SV]q
+ݩҘm3Ly1\-zh(gIjGSlc28~f/P" ~q%l*.5'9!'@$GQB'j0?.UTD!uuUJP"
+x
+1v{=&F_D"##6w>ӪЪnMǼg9 %ce$r_v>/+ʔzpt>,M1{|Α}Y+]&9:Vu1me/t}cg^}Dҕ!K9/IoO%Hӑ2ٖ0eq
+Ǔ^J IL05˲zt}7*K=
+
+S՞
+CJjZZҳi* W"Ԣb'G`-0^T(׮`JOlXƄKAghQ4*Uuէ!ǝ5MOaJؿ '0I֌ecVr0`̳8]1lqقR%'R?45yhQ
+E skJ}_]I<8$y\e儛2Jp5֫$yv*< + po_ M7K~ (aRyN*y:yk'*߮([Y%]Y.]Z>8Σ%/T'U3
+j'`|#_:$Q2)c21ju}k|߭i{r
+gyQr<l?$E$yp<Pl?aTy`B4? gf0ܚfK(VUQ!q3 jݕ
+.B2$jyv{M겡E,ރy3g0)+u<;}nHݴK{O'MeOF/xCOM܊盛1snF|oEbpX,#݇Qw#pCطs?v تz
+w;^kܰ:qkc mԎ2=%PJX#Ky(#fotū5_#@8 3$[rUdO~E(9F\YZ4(5ph<@=f>@M64@0c=Ծs ~g<I-[+Ax[] ě+PlUwֆco4snsm6J}a&?"oYlMZ֥0lS#',x2{uܦ9]b93VtOWC5CQHL=;>ԯEi ^=B&GҰYb:u ppw5l
+ȥG;{ k0ȭ<hw m#Y''
+QMq3eU/u=F?mE17hĴ,EV,ޓ!:6X2&99KxfCY}ON?I^!|oې_ڸ?8,hezg{:s9iVx%~`ClXHv%^uFT5JFjF]'ώyt˚pe3r FoUA.R3_)}j.> (HA'wY8
+:ΟiaT]==?tǜ~PI<Vr{,p*̰s'S\4;?N<F"+s'xˌ-J`
+fNzMjyyCXVx1y801,#ψ<.f{d
+~c$;8?SOrJcgRwT>2ݰ~ryܼSC:GofQԖ>מ5T&=5Tږ-㽤&Nna8KuR\|{H^ŭO۲_Tk9:eU6d^͢؆ȆıMq/ ^M+Cح*B|6ӎ؁풄QAh":~4b`pyқ࢔
+|╿>=)Jg/D9e~s3<eYe\.a3wMjڌOid;huȷbȷA5
+"&,GjO6MZ
+^\cXrz%nZb[m;<%N2δf%J9
+@\PPqD+O[9r(( p൵;G:蔷r4Uuuu!F؟0e_
+sp*M:՞2(O%59q
+_L%cɝ# od,$v-cJ26<)l %Pדq$FYt,7G'9q ;Tw ;f6/EYĤx8ßI]1F]ݢ9vM)vY.?jni%={nlI%j0?Ub %ڍ>K]|l_o
+_~0PO%?ϋe]Ff2E#duz} ='T}%dB g
+6A9=/׈IGog כ6p-&ry Bkzb!A& \7B>ƈX w'/Z ~[ʺRm,[ԒuRg޴Łw{Z,KG5R͔U(ؤIƜ\%stƿԫQǎ+ALjUAR"HSBɝh>VHp5s5v"HzbEç~H<[0xE6|%WH]ٯgs0w6ErF"ֵsLX<:ȳOq4FC^#d{l+333`/!M{rNנ#ƒ E_oi
+>O2Ds/ ެ.xm\̤LnQk'FE>cscqlYUNt()p?սc5}ѹ׺yT2؁8EMe+sd}˯>?,}vT\2Ժ_ٴoƩ5YHږ7ޜ7ܜ7Ԝ9t.]Bžd6uƫ}qcF8_5CC8&:UPuދ!rgCS≍Ojuy.sz&V|XY:mY:[<s̉%QuʜuJWTP*.6FLSgן7 yx  @OiDmSر;jE[hf^Y*iV)wU"k|7>Bhm}(u> 9x!4sV\g&6 ϽQp`-ueC 0?͝Y*:gEX
+8~';^rPl!kۂl#d}YȪ}})m`k5OwCw4 r4q9rN"iCy]ۻ/l U89(vl}S]&PM]i Q먌ˀ(&!+D@DqEր`D.(
+-A#(g뙞qvjEqpVd; Ӟ3?>{~_[6(X}>$]6 yD. /mԝkO7} kKm(Yvqə,\gpSTI2ԢrJs\n!
+`H\A@|VC/,8@R2tQ 9̽˯ >[kk9?.jNJ#78Q<T<\ɞtQ+w;#.%gC!OK:aާ>`9/>]RZ|̳>ي%뛢 Za)#Vk['CX0^`B~
+-׀Dx%az.
+2.*  e}Ļo
+Gj
+}[x=//˙:F7kFڕ5q=}2^:ݖ8&=4l>4n!Hxu?JϤr ׳<]ўD}s{odثOuԑ4OB)^}Ŭ;wRpd{2w'b9 f;6>cnciއq(
+Q|FRɃR#gg23 >l2#F'n|]>u;򏊻9
+wfO̜#3}po􁞔$Dw߀ٗi|R|Tp#0]%z!^MػCwWbȺ7F:> ы7$xq^ ꅹ^CuEaMefmK*24<`[pK0_76om; }F,ޮ8 `du:^e ;?9G<ѰU&vaa >c&`}¦`S쏡`Vȶ
+`yq ǬJ|hJQZϜM6L ƌk;KNZ |XoZF۹(\,^MM{_GM?vFc +%Î]xm ӂhp&
+o}tAJթ/=VMl.3,-r+Y%DW{Fg}^@[5*%XfFkVC MY^*EEp|+
+ cĆZ%%Oo"1 Zv9@G!z{#s 蝐[}X[-jkU^^7^:Iɮ98)'$ '$M/v,
+.Eǘ훲pB&:pĂ`&;#NT$]-FY:7zV#Q'8;ն ncWY9 cKQDa:-j$H}G^&9Ħ`
+vC(TGC-4kC.[cZk$Y8jB.C LDh&<Ko |ojf8-M?GeS&p(>>:9Bu\EnWSAZ`}9bKӜ%WR;28^8 }F3yCRt4tȎDyb??l^zm!!A&xF'p2F]+w]|D%[xKvyr}"Mcؾ;%k}Gţ'g[K]IXS- -E/m]YTIR:8֝3+L(s # j3u)JhSZA֚3ژ;Ҙ7qTe8 n4fc3g6IgbjesyCrDWWt1w/ċ=C$e?+MmQOuPL)|^NmynUuqЄ}dۧ Ub[uV`[L PSg`EK`Q@T( ! A^. U^ >v;3uQ۪c)IΞ/;̙qޛ8@o{B +D:3qEUE常>yzO"(ЧUNsYikR`^߻N d{~ùLwRS ~yEMr5XjG+(:QyElܯ2p'KW^rQuIl8r]ipYݛF_
+suiwN%omli2`pƌgtt*Ʋ0u<n
+ l
+#X ~
+ Q2bYu)_#
+ SbP??df\OPM(;ïש+rÇmq2@KzѸSZ .`#F!)~8+FqP
+RfǛpݰWO#G_u( hWqkBtkBб|}V'$bGyOy%:A
+[];cyx=Z_+#жfڟ@5gz-xɝ2]~$ [ކ6\(YOΑ%>/x>3XT΄
+>b_$7F!J v) 5Ӿ֘H{JMF۔uRNP =z=)s3'S~c2j$ 
+y˾;9gV^5P-2VO֬}g]gV*Z GYd|`QM{8x`uwf\p8Gs`|KriC7sb-QR}Q2-7uN3l]pġMd]#@߸T\UTC<?eq _xr#w$ݴXl0lG + Z~5OBXtۂWAJ~QRPhc̳jG~LPi,0Ŝ=Rj\eGԹu %C]Ԩ•{#ZRUyG 1Gmw4ve3Ȼ ''iNJ9 U yF۩kݿw80./+ ĴyH:m IKZk6]8=cCe K_"
+jN\/Ǫ\A
+澌}^~i4Id"yO#K_FR(?$oDX|7$k߇EI|g۷V':úFGcz'92v,jAnfz
+>
+U!s >
+}88ȉNᰁ;6 acO8l t!oъnѰ'|G=[qo[]}(s +
+\
+
+검5#AkѶK[ouNFcj^M1<]J ^u*\ZMҜ?|`%ehucF[Q-2b^Z+ulr sb4ϑZ0.@ΓoCΝdy<cK6 Nnԡ8y
+x`FS,2?gP2#xbi_MkPѥmՁ.?:0HښﯳDGZE&Pi4
+2y!/͋9o/WVFǮ*cM±6J*1#J_:ٮ%YnKrɖd޷T89WIix|Z\uQR9 =r#Gd %"g? -P䫣2z{2cΎOU8闗 TYi>Y[gxd<u UI]zĿ{'
+,yX"L~YØC/ j(]s_qG ezbc*bEŮeE[tly#^wz.Z.Z?Ӧ53>CUMUFbjJyrJ f*V]6$Ñi
+κIG'?d< _ښswV|^{I{AwPC{ev:ir/?~{y痆uy75kGirE[Asv= Q 2`N`n ;]-G$L&`OEع)Dmw14mּ{,i3=wRP\tV՗UD~ +/f!xmWv.$p҄`>Ѽe#ӕE3%r5wkq`LOQnf*G3U<:CȐ,;ïg[9wOdso ^"7w>F̟QFt8^U
+2"YoQZՌ98B5_3_ԝMwgq:칗G[*cL5CN'qJ8[78{wp$ O 5
+0`.Q;0_p>k|E@"~8S=LUs }|ELN 95>N=8f.#0g( aoGGca@$I2>>X+/µ[_,vHc$쌇w',!o^bqDVk$0m>NNǶCtl^gc< s#e,1Qs$1HXe(m{c){M%ol^M㺼J
+#x%,W0qm"(X`_BH3E^7Dсhvdwc`x/ڭ!luZyCUUbU&; }S~ 6ΫCMZy"BsB_^݆$ S,
+k/qg&c=ڬ>nHS5휌OF!~6֤}^WH"&Dޔ8q$᭷4sۣ0{ 8/R,|?'T'.(2$eOŻsFܱn@9RKrUIw9@lwߤ2?Q~bs?{LVb}>-N+<' -W_hpP`Դk̜ut @ =%dImͮˎFL,t<=:cF_+
+4*?̭!dN#24݇i%3yĤ~חΏXynN>Kf7fa
+6UvU~97l[
+c3D!5!3~<"1/4QbaAv.bp.^c^eҭ~dzBڲ^ɦWi)mk]q̛Q#$ִɂP؆<C iCk
+o%D9eǟ
+RAvW:S5׹M׸@v3=3khA~kM]r[&ZƠ/MJ{Uz+I^J}r5Jٕqd`d䟑w|֙%Rdi>2)4z}MW2j*y/H@ZghQQEd@"H
+.DEDm@P6){mZ\ƭFgTBr0=L~n{sOra׫7IDq5($iD}5Ðz)SAs>CߖhM+ې[44]X{!#SFOj'DG8Zc91NjIp&C`SYg~?հ O4mG7M$-ȺRItfrM>V]+Cq_ַ':yG1i\ReڠiLyA="P*.ctz3o!ԟN6;6wD߹J:G70Tij/]qMW42&ߣ"+"֓U1d o%=!/Tĝzg87z\uXOl3b!KȜd
+
+t& A`!D䁴c|s d$!
+;*󇪺s>TDӝ;[3D~DL$Yނ}@kAҺKB1Mαml!MiDєB4DF"mH'c=郞w<A+>SUEU!U)^
+d dR2|~ Y.wM6vݶ6ޣk}Fmk|StS];je%W~#yrװ`UUaM;2x68³HcK~^z"Vv,fFG5ּ
+=oj;ũT">:$ju|)ky9L`"-]ÎX8&qRpYcbXt0 D
+50O'cvW'zYu_}4]޵)<-v~vE}W%3O/ y8ouMYǸ|&}:i<~'{X9`Y|?LrW}eXydeFkq{p cǶU>CSj8#Oq^Luxf03wHd(U<IWxr##6ŮoXNCXEnEnMK_Mz+f;VmؼlƪSk]NV"5qav+y=~ 3:X?%Бqg2nw򮴏i=C=!YWڻnCInHRFc/$IK@vEm7R6i'7^IKq#nX% D]qeD [m鿥6$mXS߰Qǩjɺpe6LJuR-\2YzvUw2E+8!(?%VJG|I5cұ5Q*GAæX>P<
+u"tsF/,21Ta%uBXJKC-(Ϫ'Ð1UQT]hpV8~StGʭU FTD#U+qJaB|=6=fṆ@tрA˩gDx?t"߆4q${/!c[_>#,cbBgcC3Zb d)I6\2o2Y;V׀Y}:H~tVcr^"uEh &D_1" N"
+B&@02( t8(?اWgq,9G\ClK@ 5M>h%`f5 7Mv=봠^딠[ 7--~?)/?oM.g:bb[\3ͶnJen5I),3jg`M~i9CvY!Ϧldsy mo泸Ӫ{҇۞7yTҜo'9TKKs4fAQ)5ozh>Ֆ}EIˮUoY嫳6gϡηf3&A֯k|S޽5U[Ƥiq]L}
+ .R=:Uq]|e*DJKvƯ^;#8mp]O{wE(q?pwT4/]ǰy%rHֺxxHasB~B_Y`ĸot L<8$pD-!
+%(\AH™`0DZvQTP\r
+!JթNgugw[jXwH}>\g}&_>p _gU4eQ(~m^8m?b7tجH0dUQG׏n#oC}fa BДMZYyK>ĕ_^Xɝz Ԡ{=*s-</</->:o17
+X
+ޫ䈏0 ͭ3ZKҥ gp?聉nezfz;?@xaR (069&?OSqMF f pUeZ;X~FZ {>η+=
+AiUǹ ЩVU8ohw0ZX,:j]-g}2hJU 4ROP#wc4նS4?MO%$bzt2I &͙IyC᳴mEרF'Ǡs
+]zgo]훇_jb;ʆ&6}܁R-?}q`hZO!1Ӽ/h c9,.pF\_QdW dB\?Ooncz/i/`"%!ܥ+!'\$^'_KOYMk"' +0Yg 3qrr];c(,Ejne1qi\4T*DDH"$
+B{w:v9u]nڑy}ZgY̼|oy?yoc&&#C9įŅ%I`Vޭuf
+f<haý"|zfl=fS~.+lPE/ӯ};1N{`@yi~QrP98ϗ}3)M?@=ʾCߪxYr͹7֞Ք9 S'yA]ֿ
+.f_ޗ{@S Ԧ?|1i0}
+a {i= 2k9{&V훌\stC 2up X 5qu/<?Jt 0=Y$)%YɏY)ɏ8 ?Ga;"ۑVOȵS̶eQ=i?Qf.˿1w<6{7n,˫ &ozMf z
+} "[\D޸$Fr75`]N4VN_<jep4 ǰՔcxQ5=8Ap#a"
+iqD-Z>> Qd wR?\N,#)ǥ~QKB3MX]S%-,bQCljmq/Ql".aDKtXgUO&^Kuֺe/j tc s6vTPa-Ecb` 2n wQB{qGo'{JwE?t*/N8`:cVA)V%5SnC{TfncB]gMH2Oz0iEG߈ ƺs*\K6 o WQ#
+"NTN
+9ox@oD{$a^?a/R?#
+L
+oMN{MLL
+ޙV Vz=70}N9w>qfۍ`Ncg~b;J +n+[d.ŒhfjWXޥkۭzYc\dwrid^B!C=Ox{fD8Q߈iQ>1 Oճ<TͰy|hoL4{L[uxK<wj\5}*3@Cof!,n i [Z'Y]Y\:O0!)f־m<r{ԸDm];dѷdq?Keq12hYOQz+R?3B߁n DtJe]҉
+k[4m=xm!պ8-X7GS0`s Py7l  ul ٿe=_
+0 ŢPeȋȎe quz{2\4܆t2|3. 1?II$|.=w%EOr-VĆ1olq_t$GCvØp
+s\'=zEp-IB_ DtFf`N?+#ML
+l*EKk֩k-&~15}n} XG\k zhdxK 'kW)]kobKxl7~OuyGEufyzGAAE ¢H 3CUP4]7EJHS (lbƲh\#(&oCsw߽8.p"yNˈ u "D JMO0sBby>c?}*Xu'C]W(Y4!%]g^jF {<Ѯzx4:-"]dv/1i 5KzZbJG.SD?XޱؾcڿU0-v! $&Ɍ
+~)@ڦAG4Aj`
+f'5"@v~hC ]
+ ʊ3oe gߓx ۖ3 zWX<wI7YqTƼAV(n[h;-պk/3:R#pS+0cITa'XaVBf#5#1a7mWy׆*jd
+0A6GFVpb?Jaw_%NlI)SB,-C ]jf@{
+{B~r}'@Q/Os! /~o +Lo8OMeitW^aT# c
+ħ<a#{htĨTbf̩ !sb.yU([ @o& nˈ5èMQ#w5<o+["IgπA)!ݢ'FeAo+D#FU&,&q1kƼB2?~
+\ώ1WdȘ(U,}r\C M L(HiYIHaғ=2qu@/twIp1џwDq
+_zΩDxڹR.a?ϩ|Z4Pm_ aK ye K %w{vܣ{[/wv|o0oqKuQ¾7+k_Vݨ^j=mM4
+endstream endobj 15 0 obj <</Length 51976/Filter[/FlateDecode]>>stream
+H4YPTgfS:aF5cT,
+b$21JRe dofmi{}.} eq\a4Tj25o2sn>|;= vUnڌ K&.Qnܮk.ك>츶t}94rw5ǁt HXQ$
+`G]<θ2.êm1`bt@UH1 cO/jy2.B
+u?̢t@Zw3^&= gucmq׍eH:i症~Y7Bpoux.9 @A
+ Z*k
+NOm S*r%̛ն[/|QJj#zI&VQ?T/@!j_PC3y6^ x`9 >1!_vARRC7RC=ocChȤYiGMbc a t# 7+)>dMR(n
+34i"h~@?'T> v\ ?l2PBG#B4N(1z[F~le┱I(^BVJyQ}ѹ
+^/Ed@!ϯCO\9"㔚R?[}ZJ
+=]uFx#jG*rnG6̧⣇,/w!_ 4ҐՕ7%d<LY*!oc2tY?}b]/L/!秭y yo '\U!VA-گ y4_RHgp<Cv
+m;P8G~T3Kf۹`&(g[<&rzn=;u ͏tYl;s+xU;oH{Em?WOT?rJ蒽NKMz ȍꨯUܔ9|lbK&4RSxFiQ3jxWnRo9c:VgtiDFa'_&p}]<m ;ٶq&fyoFޘav(B 90v
+3|dV&3N*Z[j Kj rR{{":}YqΥQbw^7tsWp{8A]C=_}9vrgUH榒p?%ת:XQڔ0k z"P}jg0oSXykpٛK'SjS>rЍK%v'z2,~<!~6-k4z՗]ʵ;}W~h"k-돚#xR8}4.4)Z ^'t)pE-ʳ:V81x*Fq<GDcAvkH9&׫*vKJ'L.)
+]&C-#ܤZC-d5v94yFVaRm~wRE"dPDۥ -n̙01Eaau?3:b[llwKn8c->׈]ZU،_2ۂLX{!nbگݻ<.J6p 8hH܈uY\1;>bqLZ6:MN Lr!~ܧI yd=:c{}ӦS]AQ]in7Mh
+*#h.^ ]i1 E;)>‡*ZZ=ȫmnh(]^ׅSn%Lw_.Ӕw6^n+3^)19)9o+oԔSo"3KHp[4J ? g*0Y@GB$"0&1fʬ64Mr{Y s5j*zI}\B<5|[ZX_XS haet|"dml=,%|rVӥ
+_kյkmMRIwߏ ,Q}[AyX`l7AЕ@А0ڳ0+e~fuHBhu<xZQ6(x?-KV6gb?ƒ"|0a%rA vQ`hҾ[ _MiW)-OI &b>{E% x(_ܩ9 Qp e)۱GTPbVKCE`m/
+cޛrxx|R E^) q6<[y1¨Z"S(bS7xCfثˏlĘb<soq>p!01}x`NC8a
+L2sp(3<3}}QPff}f_.{";"Qs?f _\iU s>|
+W<B+=7ZUߞwyz^vyaRf%2qtoJjZ<-V7>7{ۂM1SQw|۠0>6mZ5ai햀7:^6&vM&Wl 8u֤>}_H2hk7~^8uott<[<Mwa5082,\Nuu^f8d@2qc$x1Qs}X-~Cͣz:sDgOm%_ڵΞ~}@GKxB3ף\Ds?"qR9x'|yy JfjU* P+ր58@P(%|H:Eڤ[ m_3a,(cw|1 }n
+|^(m`}XV%2y TX*V 8/*ѱ-qR~)`$qs>sB:
+!|bNqw9ˣIm_d<<ZNއu^d7'I
+pHcQ%gD_uȋ4I7)eRD*Y2t'%;GwG}uZs>[Z[홑Ɇv7+njl*ޓS t}H}Ÿ1RbޑSEαބei X oۑ r{3
+e3 φrP+흖PuTl"pP?
+**Fb]kDQ&r4k)/r7{mu3Tȵ2 $? :m )k2XvjHao@l~WTbk _xmY:.am밇 p::d<@r?uI xowR9L`~ZDY/9ŜLg#|Ay-crĹ Y~;:UoWr9DNq.;cxVG~٘e+r)3G15\.<
+
+<@%K99*@B=GF\Dzǿͧ@` $GT\EQ?=(y
+9{9kM~&gL^{yImNY]c.1:汏CЬsl<~6X/]5
+\>|t88/q`~"G%p\!p0Ѣ/ţXQrU1\Lygzԓet!֕ѱ֔_+oI,=HIZz\!yJ9m8~r6P
+8=+5S[YBs>I-o卵q;]77Ukׇ/UUv.QDPet,T"AdZq$Y&qlH EW"<xcLddMʗ|0׽{;g}N쾄=m</{1.GqFnyiY@AS12X˿<Icw(x
+H^sK>C+
+ⵌ" <z17{PHQd5rEI"76Dl T8z:n_Gb3txԏTŷY%/7@юB ϡ
+[K
+G]kik,y
+
+R1Ra݆ǦoTv[z z%E-z@L͜+.8To3FmC`k vު05 %>yv5 rΤo:sNon%YLQc:oJaȁZD^d먶 W;aΠa'Ã{3/ o-QY(9,e}%O8&spY<7o-;Ɗ?S:K|t8l}֒g
+
+[Od~?[Ɋ҂.MᆢVu͝vս֫ޝ?VŽK%-E1֝D阻Ry!r xG{RMW)x.Ĝ.>yv_+=Wv! rZC?CF[apӑ}OyğA&mdY&-z8KXPF<q80/!/nbzTX<•ߤ˅3zEp u_]%Et|<yP
+r$x *h5j%J15̤AEA9>Tnvw{# ԘN&ivw{>|>kQSGe<?Mr=M2 _GwAȻH<a 0SCMn#WR=2kIrAk(qT_4}bP:2(M{Ҏ!w=ޮ`1_R
+qxL<w"p
+# 炂o6 9#9 }} nߩ,%-mry>!Q%w?7`GZR4`Lk]Իy{\vp)f\wxx7ɬ+1/9:2 r?r'\A/G ?ofYhSaUd\fxIc?Ƿr'0O)"}7T ɹ]_Q1m(/0:2e
+ʆ{`S8Y_p_Xd?f۽L8~,;)v
+)ij-]A"
+Ms]NwU{N_m4 4 vc~$zJƾ9~P>
+={wC{=wQPpoP$Ew\WmU[vA;'tۆ,mC\Jl0̽Ɍ=V7ZjztG˧,֒+_/.\ԗΕ/<4_\rQ|(؛nf#fSmv+*t+}[%G۬ vS=VjC8Vgk[ 6C}/ZS?/@d`v^bj&h:DsC4f0y9כ9Eokp:\#3G/"3scr.6 6Oc.0K6s嘗eHH3G]&q됻ݬgWa.9$R1}V@r8S`jV=ϥrS>V33{*'+'+}7 )N#g#ΛφlU7ݷT>5U.8ʾnu\Vxup _YK)VKg*Wj]W\eM ;-Ͽi^zU)~]?<?Vy]JwK7:eΟ_?Yd%GKԆX:Vlwxas=6BlrG׋u}]
+@+>]û3vYE`8C<tN΁-?3^ܷ].w#fdXM Ě@NX,$R)R D`hk>|ܫ
+ !x6fڀ}8J/P=}kbrs׳
+~M(JQ|._l *^ %G֪U&6S-5%lKpdm9MɾO|WWX뭻7^[=T.eP[js;m'RQ?beh}M={_+O;Y!>{'cG_xW
+M4mh_7x޽w߽G{)F 0'ĿTFR7v9į?Va0xW`.ѿ? kXkWcL7<ZEBA$6)/%_tqg~獝~P&U$#7w`ovaO)!:"{{Tuڨ
+tqEk+Lo#0 r>ΑgYp KMiEt<wz\N{kx;
+>.}P/X^mje)0X դ)0Y܂A'쓖f $̓@.R Zhwb41N Fܯo7|ۨbxƼay83jV+04LƎ!}m[2;:[Fm;sۘ/w[t[{:ޮ·ݝ jCcg/70|ǐ^; NXҪy<8huL3"x`F6}WGx
+#8XEC>HEnS@|ȟL؞sR0}/ω@Ƒt\a-8w7,b>
+tw]Xsל-x2 PQLRP7޹dKO,}O}~&[w6/H&>hQ1eIMKS_ޫ\OJTx:F,˺%lIlGkJM":[36)'^
+Jl͟IeG>W;A!7 V}݅z]QQ^gfaS%@P!hhu
+ʾ83,
+ϞcBN0
+_xeXQ$~d1 m)X?iaO R"s
+"}:Q8lIbς΁]`Yp]?=*Kq
+q0q#<>pR8>~,EyR9{)zqR* m+19 eϮ7R6yLg+x忍1Zpu>![=V{~>}>Q.'_G /:16y\i̞t<gϜŻN+tCM
+`xو{MbWG*޽TƱ3ՅpNr^\om9Ħ~g\3VMZ*-JQe:M[Ajme>9@fs&;FUV+pۮh o4 pwL4M6GG#q~485k?KkfkMUOOZkւV ⑩~fNd`c5F4X¹z:em[5o)-^+\REBd\~Ōp"՟2-Cnok-Yl?n3exج[1kRsnw廔nKȔoxwklywp|B2bvv-1Kۈ1hiKT2KZj뺘p|Uk2vgKU,ն>6$ʝy]ޥ].sjیVMժ5=6oI8 R7E^u*Z21g& 9
+rdXR<e?91t?JI; Vakӣݚ22Ek66G|*<} g|WBZ@=pƇ6>_ &
+y1>pGډޯBn'QwE0<ݖS
+RDhP2|^2zA0 a%AEAX N!"{e|Y>ץKcqكEy
+}1؆{h?WUkuk](/y, h Eb" ,$@ET@McifDr[@ .wV.ݳ]A1K2mbv:ә=G3?~|{\y`32yb.u7-?AHBCp&C}t/>X 3&D|ӆyoD˶4dLi15*66\.y/Fv-"'؆_p S@{8yϷNn6p]"G;p}_(c<rqȴ3B_?pofȟ_WGPVh(z)~)6Qpy|[Pp@P0&ث;[vCzb|抍x'y/kB_|Nt"GKpg#?9;N>o ̑qz//$@Fx`HlHmj#!OOܟ\լU dA/@XXDžM*- qv/ҟ̿2?셜-e9)Z]~H\AaIgIpDI!%:h t|fRp&6q޷󙪮?tuJ@ySo?ﻲB_Q DtWjU*On6HFܬmvw.CDڴcji6v>ЎܯV7jf
+[V7rxFo ;0v*[m:_InBt.(Ul7g,r8p8osېWLl
+.;=Gf%F}r
+N^kj&>a>6Fi[ݭV~bs
+R㷩w|<cm8ʲ;[ V퀻u~KB_s u9V/e2=vُ5`kr6ƅs~[1Hi lc>rYGV 9
++d_c}d>ڸԲC_B{6)AVc+t\W\t\L5wM˜8e>Es]+WEtp\e\K"Ӝg`+޷M/h݋D|w/ NLmTkeWVɟ{GZ>($8zBr̹⅃~
+m刁7!w*C djO 99'|JIS(LU_R= Lǚ qLi-@D
+Щ
+ `fd/ExC۞BL[Qk/DLxBHI4tn_4)WGu
+bz;".DgI L~A_4Gm'^p
+̟@y)ecJx҆"yp:GPq>q>sF.m'1[F!Iv/Jr.0PNRb3sZzPF@(iυQLX^aI>U(\+ea )Pfc Yll
+MSQaj\>n,le̮O12wƓFI+?-g/\_L>*cPpҹAA6s۠kgRvAߦKզIl   }VXT:U6sC]SNVvLJgYYs!-68dm0r\56)̵>fT[ :}7+m5kOR~!+qc~ޠ]A9
+w0g*2msHC:0R0˝ǥ"^a?Ec#Ec2GKap\߫Z{5MuJ03n;SiQ*lw]yY)=9 z;gwFMlFe-{icH|zm:͌ymU.>s;dshZⶱUexJ_78䳊CyϯkY^W\_d[ŗߌ\z}mK#_yF'wIwoZ ,z;gχ9;Sֻ_
+:-ͺA-
+''r %ѢrR1Q,/>é#mVSIcOC/=(K
+~D>O#;vq`sH= a(OE9`] O?IX |``ṗK;hO
+זW}7`>Wf{QD'nL$.۳JǛZR<wPq]5,]TW_*e/Ol(y3%r`xq瞙t j-wgo/NwT+#.uQlwwJNJQ8
+_LPH"X~H³If$!3ؗ_a\#p8P5b+xbĈuEyq
+H_/ɗ z8SU}Y:H]\s8@=ܴ 'FfέQƒ/p^>|}M}W8.q\*Jgp,fþp Y)/`_~!Y-N1f_{9cOB dz[|j~73J[ΎIԸLcxsk z>qScl!phSzbva[\~3% _\_S}*q1/I`+n [uS߇WqS7ni-U "]X; ԛ;7WQdtdeXYd/QŊru`ؔX: 2TKMcUW2Ҩ/h%sE2gxePVY*P-xVkr 49 l)# ̰Шv0cmS*i G;:= E `"z`-ӗZ#uŸ3D:tE xwFp R<Jcn2
+[St/xp*
+gE
+񄔮E6V8lJF;,ŮFM0К3Ubʚɡ2gs,KM`XsG"GMhmtm-NZi-2
+9*g!O3Wh~.g-
+,Y3/D2~~2 KB-U=%̷Ր,,^;d[;̍L+M[Sl.fߠZI)S
+R*SߩK6 D})GAjV5e:ٟRuoT(}TmmUgkQWz[$u6I^6PhRm9qIOOsLiұ7n-7S^n:Ϸ3*s2#ç8 Wc.06.3:9"ME/s?e`lGW$nHN*r<~0S^k
+^mP-oIzJ
+Z/_Njr/7˽-<x
+cvaNC8)x|T?Pd}tJZtt/җ;g$],zBUaWy
+(  ;BHCBHȾ@H(ժ8LgΜ3939w~w{b)|pjx]6I(A_š2,OPx"gKr-kX{-T(*|!:}N{A/a߫]r-~?ͅ=:7@FL΂2+8 Rnp0+2lrt(c5
+2xc[9&Z~@x@$\NvJ? o=vxI;8
+NLnM}&ps?JBE9w%^sx 4zIw 1Gq2z?.\s<ąT?~o9 ~J|m3sck
+w BMVgVRx]fF5[%K\uPq
+|;l߇lw(Ky`%^qIacUQu;'_ x{_?Ϳ._M<xd`wʸAɰ_~uiteGWffQKP|7[1rL|1<6x< zO zzN^X/;H/Dj(8 fz)APrQnk,[s&ׅ-P]0 <VT*W(\P+ɥ-%r(W=%zwu$>Γ<>.tUw$ʚl\ÿR\?rQ[zJYpK%ya:[%׌~- ɉ6 .A ?y:|&W1
+ST;
+]QK"'a4/qOr8 EYyf(0[ywɶ'es=sɬ<$ eC_WZ?{_Ja
+ ͐9=zr#0-
+X< gq?g7@xI*"gCn["~ˏP&{k2ϛggл؍<[C1 `vuuG@GHD6=eaȧl9z@GOQ87z/)8WΓI$iY'гI57jpl#eq9 c^: )ȴC= %>3ZY X9 ސ='p1wIXNx<ndO1"q
+p*o1ܤpMI_ '6Rf869ſr]ԩ0'L1SA0 0k!5.#Kk fy[.7,n vlĎ#OB6[3.*f+K
+[p2{^g3?A܋<`u-?(:h3OV.J{ 7*EņmQDbT6X6T5pȴG}/?8G 6U[>]rd|$x`(0\'ѕL?4椄/ejpxGAe'f*xUKaCk)J>kSL=apnh]x'0VL<1+O&lt,,3Nq;#Ï seMt\A40h n{;9H<Qad<KZRg!8KFtK@[2o2?rݜZ0]h/9KfjF W펊I5]NkCz8L3=.+wFic:5 S<딼d.Y23F\52vfN+C4.0r˧XnU<ՃUsZ{\M42 _7 IuUbgeOhV0UNQWt`hp!Rcb}Oۋ7on-:E`/ ڊ* #3=v\U2eX_aۛlFզ0H݌uf&e.]3N Vnj n[:>鹆YnPgZcaOg
+!^yZ\wO'
+|s}㽱2#O1~A0p?4#ms }N\QW|3Z9/<ڐ-CU٨ V6++.s˿uy7T|s[:{7, Jyu]6}KR,af=x|_|{l WRU 4ȇ7lR1k!83}n%)>_6$li?U?7kZO7}
+VU*oJKnxLUkIdt\_mʆ6eヶ֒F@X%T57?U?_+~Hqoqacf-0.ӯ<n6@RA" d5*t:jx*EqBXR! Ⱦ@7chQN̙W)Ϋy=Ϲ۳{ *
+=\8[ה[YdPpd dٰl `H(l
+j(
+YNb9/
+%2_
+GCxU8\n`pPwCwjwrsk `C+wL)gp֮[ EM:IeX!jl5fjSyFj65<wVz.=QrpM<4'T^i+NrWX+&$}$Pi1M?$)QNU.ULK?E?J4E*P-ix^ mm(xU\7ݘ3pnN\滿!-=Ygv@8_<b,Ujnkilu&GYGכ `ik\ 42zIr"3@֪!׈g1uuݖ:sS̜ʵO-rcMkV-e6$N4a~;askIy?u~Bgl UBɰ?zCp=yh=^G'̏Q956$HiiR޷jֵ߮=%ݽ&eY;3&zLRZm*z3{xkk
+|6g";#~`!n Dz ,CEvY>ȸld
+~d$αo.o{4*n=WKDO{KuEqeq
+%t_U;Tʛ*r]eaιoc˵6Q^>᮴CZ)yԑ.yrKܑ]٦>å Ĵvӡ'}₩))epbMw>햟Bk`86τv`EAC/m-hȷ%/|΁ԇW[ђ r` Z9ZW!|
+^? Z2/i⠴5i%a'šژ& Lmښ{4yņ/Z%AW!=~z%)y{(/ MQ[
+m
+lq`vc:b1h4!`6bѫ -{qf<Y քޱ&pwIrt6'U>N`)INF'bE0g•;$p?-^ŁC88- Z.s!ev?chE
+%-+'NN=Oo~%d pYމ'+S^fθz8/[9_za) oW~)K{8?l7@ )?ÉC!U0YApd6LbV̛ ptb$8OPG  gB3
+Hplҡ+nЙsYdއ׾݃H@wdmFgG\HMVУ}ߔY;){u# B'k"BN+/c'p~ӐkpNih-bצOҾLRv/mwT)ONclH$V>}PSdҎn_?6 Z$TUW5Z1Q_;
+$ŲvTԛ/='wé%mR
+я:){ewP.~f'-U?G6#/`82AOAZ(Dlw"7u}¦ip34hAȩALQ1:1 aF/2#?۶i+z s
+qv[dYԑ5]GYWJedzLaz.}D1fojG&M ySH]v~r"^ѫSո6t`N%fTu0=Dץ?
+E$t$DzYZ} <"&qo00xR0XCB HzA.3.#/1 mi dl'ΒE\G3pD>mcpɼ=-LlcB bfzsŲR4GDZűA+}62ng7
+:Ue\ސ<%2uL_/~Ka|}vcÏ^bfdZT4+ss#ki٫mxzx_ :\ 9"]6 >
+wJŝxRd2w%apKbxy]k*\/#BCB=鯑ÒYU:
+ rGG ,r~?8RӔ98 J'w\h/w5&&x;3qjs<y\}W,E|oB_ș/7s|*om_XQMyo B=g8Ol(_[*g ;dΚiM0)'qxrBlkvEVBgiw fsc17BC9h0~Rt
+^5@5✠[ :ҙZ)СPmfyF=d6d>5Z)AM.ԭq[{GqtIsaR;IJKiJHtx>J_gͽaSRQ:L5uKHYt}
+OiVwPo@x؟\׫
+R3"Ve#UO_נT""3
+^li D݅ Jp.4?$a+EQPTdS!.
+Xg:ǩ2
+ $ K TD@=$$ Aw0<ob[8gc_ßg'KGNoE6@O8cm4X#{b}siG#@
+qWGe>=C=r¾/b]j<hci 7BC!{R80a D j+l]8 X}鴸0c>dD} } ZZu%dg4dȞ_ʜW΀-Ȣ~N;4d}-{t[zwps
+@ RHrI!!,bQwܙv} }ͽ䶜|>SJ_>Е?QTLkqmi4 Mz=mU kDF@j20Wn[4 q
+ Rs{lւwOkμp ܷfEv$],=eW)}*Um]YegWcNsWKN-K,7vt$~CZ|,tez@v=,n@spVOܕˑ!avDNGo꿻I7SG<oσl;BiC6O,j-J{% E$"IK@rSXѣ*TV4 [-y=iCa9[ؔ.l/$55”s;az{fKpUњMq%wX7|xvdwx} x;l1@Fw 7uՖҀcַJ|agذq F8a6E܆Ksarی??^;gS<͏VqCy_їrWlߕXOنނUY/K/ۄFK\kܣ䥮Q] n][r0+gPA!7ws-vKP XV ^Of
+^@[/-}ucv?uG7j.d*;g>6)>.%a7%_|>>ׇx@e?|KA?Χ8lvX?…ckv_{ǝa߸@X =-]"DOoq
+Nx>UZ.U+4LƁjmRwK^,5N%Qʍ ,E(՚fU ݮ)7ѕ&bKF1.MŸPS6F~m6E2ytL"_r>s6> :5UBaj卹d' 0"f8p1.Ai~I~#H\%r|ŹBUߐMjs& Y Cj_2f3f5s77wيWՙnЩj7U_Wy^ql_P̟SU{Q-BC?NCQEj&teEMzC&G%ƬR&%#+FCdpTdZbk
+
+/v_3t:{_oηj
+^ /4 X?e' DQPji2
+EY+j](EЊ2jq$݈B ٲ-.eD+qNO?>}Cϙ?޼{߿ߵå5Jo^7pߔHJ $laalFO⅞s"ί?sfg/~̙Q좖3+x5?7rfMsjsFsٳ{s-ۦՅѲ-c:2o>7{5q^E{~Q##tƣZ#Y[KAu"+bR0?%G[4z7͆Qd|SՔT9;dX3U nL+տ(tJ<WJ}} Nx:mʈCa"Ҷ+X6^M8%4DJSDA#Cf5
+} ?k!;P_MG d^+U V
+rK>,n+{ryT&w%
+~HMքZ)r2r4ae2
+٘  `I
+;+eb^IW|G/
+g£:z\C{Ct.Qt he45깼;yg|;|]f
+/0_$ nO<E 6C5vIO{f8 ~86o9 ;xr/oڃߤ ݵ_#x)j x!KyOoOo < a=j8ᐸ5A\|HV@цBخ1}Na )̠^Ck f]&m%N^+`Pu,c$4؂Yu, 7Ym co`k[߬ =5|
+i }
+#FiOV?~a}27?ӖOAU1^4T D ʚ[F́ze^Sao&Rjyq\j&SE,P՚UמMU =PxpP,4o*Ϙc}ac4s.2:$^(۔,2%vf.#[.›3Aw΍ۮDwim/9]:Ȕ+A$?*g*׬wƬYK\5GQq/T?^"쯾W>VfAqe9]9F*eMGW<?3H(XmuT0BYDGQslE;L=ԣRp.("$,! !l "K3gfN_7{.N_|Ͻy<S(q fK_4Z.
+ U>-jtL?p<JES:QOʼeSMqXa@د$^Yȓ}a`1ߏv?~Jlb/ pn&8{ }\=VWΪJO[9:Hi}xBb+呵M>GZ"m7U?`b[B^[|ŮK7\/^6]'w{Q.xoxL>exZRhIGK8w|ŁBNk7l]M}}tlz0@~׹5zخ$^EIX<{IYoC?:y0dwFޚIC[T.sZ{sC8sԎk\ '5c- iGtATPhCsTZ~S߄u f]c#1̭^r$@&!L2$3ږ=@e*:vEm15vj5]JJn7
+?'viܻ]Ð!'5 Yfby,ފ ~\
+>?̪
+g{
+9Q9KaTk=Pd0J&ZZu
+m}(T˄ݝOt(ShQK:EgK\XޭzT6ҋ]OKZQolʞt!$;?Eϯ 6u\ɯU=3!SF{AH:cf8T7~]L ;aWa9I3-W #-Y 3zL|H A4zO?B :@f py6Nt@cC8q6`A NX&^R9򴄓%-ZZy;;ɈuBN킸0MA8j.䷂ 2:nne%J3K< )؍[Ā:r'M Wv moZɀpFA$loqZ8]o6@onwHA#~r-+aC!
+GGg0LHzƀQqtKڀ?o>Ʉ ;:1y9JA gcY)G^ުƵ]p!% Y1q
+􇙕tGiH>1R'Ic̢cLsERplY2QgyG):r3 kp עcw|z).+\¾E?mDyWH96SWd$̀hUakp\Zy̱oX'~?߳G^ g惁*+s:ʭ/C8g<LkXC!A ]!^bہ -g?Aȡ?&Gf
+"y"kGeoͰV5b-XLtxJ`,eőw.m',r)SE" : &\r=5Cs0Ȋ#`ЬFum?}k𧫺k):sE7G|З~Pf|@eO^f(si`2/{,E3Ԓ;Ҕ"SաwSwR~ɺէ5k2uuua,M(_>O]f*s\<uԁ`6U!KQ>f.8]Pf|LQD?-OOM%O2_&dM_P]30WEO'ϔvˆ-܉L-7֖=Y۵K6 Eϛ:]I=dO7jo=GA5}{Q}ihL&,)#V҄kaԪo3|GB'%`(PD6x}\0)0I̶pF\{]k^PXdxAV/9췩YEM/O6
+^kZ=К=ԝ5ܟ4UcCB}p1\b}Vs?]͟ :]L uY k4arC xϠX\ xF)#kUF0Q(M弅ы "GC5QZCAyw&5 JZ]0eq^QUf㵷v]|hsX<f,l1^o38"&~Bƨ&d(^tkTCG8_+KT]YO: UJș61Em+ XR'0pOdb z:)E}IyPQ(z\Ef sxl su\p<AmAvWn|k~ulm3Xvx eЏt<s@?dq[COC
+!`8b x
+}r W
+=^u۷Ի\W.wɖ3nՉAɺ=+ }T"}4M24HI&3> $%Q!Q1^1Qxu¿b?VĽ-F68<q"m,tžE0_qVU7WHIT%#zA h<cP#Upɐ7`{PO6r6rf?Ԓz}DpRH"KjS k(U
+52Q-sj*?wU 2?y
+$z9~,5-椙Y8#!Jڦ˟o#J5곟54PYt9/h^P?ɛ)nyvu|}꣨KǪ*f_:V:%H}sWs[=N\gLP
+ Oxڌtמ\y,̃&I~%UV!ɘާ42])O4bUI``T'ke2UT-%G(,ִPVRrJ?uz2Vh$_Ut_wcRBƌ~QGe-3URoItʍ+)|UIeLϓdHB<RUP H c9zU@H!K͢nyXJHI2yDԣo*DGO 璒Sem-"y@(kmnwTUNM$>7`AN氀aYl` !9/j8m
+*UR~*1W=0cf?iwRYqO)?h-rwݪYKbM8;; #hʏ}'!`0S=>fK?ض<;/`m`#2][laӈ5x;Lj=x Y ڂ ۵'V|PU@1U>&=hEH׻?o4.7g a1|p-X
+^pl^/>r1r;\ɀ-n p0vEBG L]خ}I|M@'YK‷n),a
+ٻ<).;ڙEB6[>"K@@zٰSlGfd@$6ٶ|:qA[N?11n7~P[ { B f=jsح2sA/؅AC. {̄ .} w59|Gl}߬!94d
+a>2><;7᐀(EEY]%H9z*rP Q
+wW䍥򆓤cY[$`Km9;{3bkAGUfJFPcwM)n.#V<h! P>$!Px~T0Qj$؎NBf[!N}wR2s"lAQq} mXC5J9HX{BTs\pX
+aB7>YgޒMǵZtg YΨO錗<S>&YRfHj>dK꿓̩N cc>Ѧ=M}uĘq;>{?'a)yÅ2}YZAD Ft٨P1N܏6V#7d|Tn*Y4޿/4IooK41dOň&GzIL:qjHK,'ëzCOz$"&&fn{GmVlA˚ io3/u>/?͒fN%6e>k}8awxOu^̜Hd>H5d?y'</1?+*d52f6faoI'mucҦ8jPg6bc#8wM߃}hbYjhFaU,Ҟ*\ml%=
+k~qy߉g諾-Nt~ xHk*qF0
++=.{8s
+ Iň~tE-
+tw+պWȆյ3 o`
+7sMAhj4:q?;>c?0PbcšqO8 ?x={!}\џ[Y'q`D񄈇9Q3!|a+-`_"s%7Z N
+38
+endstream endobj 16 0 obj <</Length 55499/Filter[/FlateDecode]>>stream
+H<yTWobUzkuj[ ťVE IX$@¦@dIXCBȞ˗/$@0 n3mO/}0g;wL`B;D.HD\"oٻ
+"l+ mf[ vow~Qo$҈7=?Y\ 6w]^.6%?C^/=<yzc DmSh1u5BC8>O_ر׷b\ 3 F~&Y]扞#p2 B A<98xx<Z'6ySՋkYc+md&s4Ice E/tBߺCۧ6ASlP;#&&j DI6&l*X$`e,'bb# 
+pRษ
+BUHS`7,ʻmOSfN&*26^}ls3Mߵdq)yq-z3g8]7⫹B-L/1 %™pR-KN$X0Vm̟r WYYLg!~2zHs^'Q_L:X8dF.Z.kv:o ` J vT%.QP2~1Ҭ1g$UnoZ5k.>bS{XٯXV[ǜG9 ELO~{)ycL/Ϝ>6^sz'_7*48n ,^DY׈+LC]N
+э;tȦ10DpT8b*h4k1},"s+N%N(||,Qk%C*ƀxd" fa$ʭ=`Lfݭb
+DTfh\f%YfS#zv=^BmHi-S
+ǔ1%!SY pl& &Z{yN)u6Fc܇bXF^Ē}JRzL}7 y\v{泋wNW^=Quy"F¹}/VΙ9.˘>G4W-ٷyY>qa qQ)xvOw<)/8Fye@'
+[/)1
+3A(Ր:*wkYGV4ȨV0`UZ뭞vk^FtJz۬BWH6J&sY_ܮ#*Hn ,Xoz.Z^nPuG525\8f.d=y#ϒԿrɴ7D)WiTX<sț@1j$JP5֠-.CZi(:&iQ)שZmڠtFcbhqC-Ĕ -
+Bo1K()M]zeGORZiL&ii*:%ͺwϞws
+"AT\J)?(@!+T7QҮ*~CgMQs{-KVQ-P,tuHm$RObڜnmOr}]sb[?e#acN؛K,xoa
+
+* WV< Hxs9P
+~6Y xhX Զ
+رr0;h.'_#ɜ%g˸+cc~fp .j\ Ƹ
+"Z 1Nag:Av9ža`bC 9C<9
+v ;>HE`۫xήZuî@V_øp;(1E$;}NgD *Dm7noC#+/WQ qb;t8A rI$nSO˂xG?;2;>;'] r@7 ]ԧ3IkZ*ҞkN 'i-ɲREB̆XQǷA~ b?82c &GءC/҅#aAl b)ހ{>ŷ M?w<{~.ŴgVX}DI+hY?~ipyǙQa{Hѭmy㒜8{)s˦{26*%^t\$}%}#9mJ7gˋy3eB9ZERY2ZK4%c"K8yFV{^Qd m&Y3h\<IϦtw擣j`h?Fu?$IH_t}h]2|)T&ȫK6kǴq@[?3Fa<Em3wuOҘgz! }oHW*dm?Ђ7ߓu̧O)r+ %߯)ύ%&"swY$sV j t`P2.& -m2.yv'wX0.
+aYG'
+H){(QE]''/Ԟ7SК"WWttn=͂7RZOw<S<*<,ʘ܉rCyϋYO
+z05T?\4 z*x!y͙uRIzQTR}Uc/G
+usZd.Koo'a ťHԪ5+VSGӪjF`V*Ff,nWӋץ72zߧRI!ҧKaNfԞ9Ν(Wh- ZNЯ.dƫڮ6MCUh'qNT*t.eB%7ZiF92%K!lem薤I,R4"C"wI++_=}!8 Y|1sotdy69
+(Eʒ}قdqQ{t~/=7w}y66 ^8m|/I1ny`U,auWrJ! "ZSe1Iɑ*j!!aoѿOq<YאrV߮(h֢aoЭa#6-h BX\#+kVg
+<[[B#{zI4Ygrx'x^"^ u?$wAIN3^̮mOk)/@+ŵŢU7D73oԈ*Ke73*$9]JGԮ]wVX(M.UEy{/ævu6pKO> Gdp34r->ÍTEEV{>s_js
+*ɩ$]
+X]aӡ6{F}w:05:S|bwO7d>c3vDsD\ ~  &P|0ɞ/)/ț}n x';Wk 0gh|
+
+]fͩ` Vo<؜`8Җ`=E27F8‘q>cג\}_ߠ+afȒr@:, ,JjMJYM0J8P U[[lP]4/d7E6 7U{D?D[J}5i-I~ g$ }D?ͪfev_"sTܑ6Y{.lN={+a0IK">}L؜1U <(Sd_O#Ͼw['e':mDϕ(Rf)?M7{mtiӕZZF!g3'Zg
+Ҟ*c/z=Q3w3{̳؎3(xZ ]X&5o*Kvn"_pQƾa)N~<dvDs] Z6H**R_W-Tv(eeo3tꍢzC.rZb̓We:\U-WL2sGK.wWrU(eRUCUͼ'&IPI|s^lc8>ԻN==j/1xw,Yr?CuQ?<+,T+
+**R3qVH "aEPZ$%- $Y[DD@Ԏ3=s3/wy>PG+ӗw+*kZ4&vJ6,ۅNqJQ"QW+tښ&5F&RRjLܯl6NY\H$MbYLTM_Y3~[5xn!٫I9Ld~6pl`39’@q9c)t 22V r-qžC\\܋֛d}t_Y?`f
+˕%g=7SJ6tkbt
+ɝcϴ;r38Y
+ dV8 i87. (قo4[5$2Z@/<x>
+mqb&fSm5x-
+jh:}IpW}F7yg; tfƢrH́CXB3 OÀ t_- @$AOl/8.h8 cc+]Cųfz6pp|}^~
+ޛ֛8N n90Fx^rnZ AjG8j8HvEb}l]lSCؐ5xt9֭cC 7" aEf1ϕ1+t D@YA9]@ua'~YCMY$y`RsPDi~ϺP>++M R;CSC#t-]MZ&8w=:{2<_֞G'L.@k<_RlRJ<kMRb.J9SyWY͙3iϓ,|.M>E%q:Nzid8q
+dRggk濪"~!,kwH=SRd~Ywѓf}Lt\/h$u׶L̗i^gQQL_^~2[RC'OE`B\ztt+_5qߝk:G<iTSs21ZV@ APŋvEeePV/
+"aB C$Dd-NZZ.x>''vӂ=s" 5/w8KҞ9G\8.叓Iu jחoЕkZFKؿ맞KjC;q"rynIOJ|P]A+Ћɼv Յ}]CGJQҪWzkFD;H4Wu*2 wa1gJ5QMr ѮGG>:1^1ސaowۙ{*e2Q}b<Et_1_sR{]YPv`ZM-\*mP(g55um
+2 +I͍MeM/4$͕rXZ]W*[oV4J:qpؘ{ZdgsdQKab,M3Lؙ4B :
+\uG_(V.lXur|˯D$fa,BpbՁ`mHz{Aj\@OA@.1Z`pfX}Ma%slw#^/<ѳ
+VT yLJ/q㜰6㹮 D5"! V-x\xa 7X1
+־tשd 8MǑ-r^oۂk<ڃg?ـ==x+3|޷1_qAf);a
+.a/!F+&l[*7V ~U1sjxxŶsw92x=2 +sZEt8F X\oVrVH,
+2 ͘xmCl5VS!wk`Ulpi~" -z9V9yAfЂOΗ4ְ⋫paG{|}F&G[&ߖWZs/ـs-#Zۀ5x!͂Nv5΃xIO)i?:|Zh ,ۓ,=Y(6&ڄw?F\C8'whF69eC
+7,j2R0Kܩ)/jFVț
+v!E؁}` !+lة]
+C (+jX:."@iBB$@򲂂FdSEtmvϙ97k_xKn; W6')0h:jX[Uw&XyY-~B_}~AZ8NhXIF T$>`զܱ=\. 5Ma_~Ku¾&cFru*r'3'S;R2vޥTg|<*ʙ<Sy5B]^S0Rv
+%RmѠۮ.]z}Y3-M:ٔqW>ݚ5<ZyCw v!5'jt
++;^W+tMvC4YIt9-XOo| o
+_ЗMTNG櫬Lu |8c<8q
+ WuŵDZ]GGkrxc,>"?M0i?~Oj9>i#I90,랝ߎ*[pi
+gR\Hj,)`ktDXS%ﶝ,2Eft(*{q6SQkJ]E^^Tx?]-49zxߙus7q6ޗ J=aAXR8aorD BrxBԀ+:BbhAh?j9u':dm];7Q
+n>&ATOZ$@(ɊMeĕWZ9?%'o-tSV͏l^]/ =ؾrm"zC,$Gg[YߗktZ} !Z;5HA AsgX^͇݀e/`ը%K|/4΀u s %&#ܟ ]n`r]-=۽!Ne7D@, Vv$kqב(cODA r,-dqt!A6RLXR5p
+F+xtQ T H9Cw#yIi"g+b8YL%SH _^g~l'eS9`/m_mdPo;2g3kS&~&J !ڔ0֜>'̚bӅky}x[7gɛ))8|Qg|0C C?}6Yl85Ila]Isl*u28$u4UEQG.31J:f6B2+rYa^ UX@'\.tJ4ʮRLS*kJtn++o)oh]V}CZ' S[*R7+v+h+
+ULM܃8
+nIuBVՈUbigXLڠ+t>T :Q nku4;7jD}sCd ۄ a@J[,t?,Gf2y
++m(2n`}%:9Gߌ0r>lKCg5Lj59>e/Cc,%$:,R*p<WUT]aTXcitղo$;SѺ)饀)_V=#n[>$Gۥc~qUkj]K޸s0Ʊlpqpސq^JZ2LCA_84|V ;;8X #?ۣ 3ωq0Da2py`[ÌbQaT-"0=<ënjCꍼ̖$!sdg[6~Z;I_?툔-c}+Z2
+cMa <:LC"{K'
+'ׇ=!=2]`r_y@%F;ž_x
+5U3|6"!T{ Ay[<Lpoe:qX], &ozqs <?
+[\7;>Pn Xs!HjA WV` @j.@ - `k|v;
+% gSooEyTD.:Y.}e#MiL<Qb}-pP<B0su5v6?}!v*.Y)4r0ʨ)YOֈȧՑ1ᄡTQa#pB
+'?~6~:MgO6UaQlLRo6ғK[J&N-3$j2玬#D[IZVȕY}
+*s@Ae6=!Wʤ+]ålp aG!IWzBѯ|XO<N,'㜦jˣfC#D9Pƛ;(zbZDs9TLcBΤ+:S밮ay$D.P&<YPv' HNŵ'f1rҏ&}I6TM#i#;ēŪh&x%o2Y?JHRD_}A|J!sy+(c©0ҋKc+C稨KL7}M^#uH'>U0 MZm^֩3.RVzǹDVWtޤd ;[L;<6Էת u]:TŒh
+ q[u26A&T%/MP%<O'{o:_D1xY6]L=zX~,(Q4?)b3ʙ<m=uCɔ7EJL{viI#ED]֮i-QTv}FUl!ijkV ʖ⪊j:庪xىl3.
+}>A:͛ȵ\!:]U΁A_:X#"&'^>n{edy!Zdu9x׮F\Y)¾>W` xvhpBw͘ l߅A&FgZJ"(-ϯcnc
+a"p@X}V[ٺҊHie\Er ְ)1ı:c~+bJ8s}q ;Þ~Gn4N됡A֓{䑇a}{^v7o0?
+GħfdjK*jre5ũ$EQ
+ID*-DyeiRuMEp UΞTmx]Pub|[8G p
+xKf X{ D>,5t1%2:?xYܭY]n.xk* pMe]a.`kt&dwwuA]E
+TlrVJYK@*""TE֫]{A8
+S]x.:7ײmO=:/|dL >MmB7tXk!ڰb6@'WG} p.SzD +Iwqxoc-!`#;7m@=s@]{x2w-ITL8bK_5zK6w-b\+ %j[-Y$k)ϧ0fS)[S)h顽H{eoRڋ^X5NggfKYʌJlssey칻+GGҜ|*B%ue}el2y"Wšˑeϳ7,)35|v9q!cF wgL&K27)c0ENڬ<ḵY Ɯ 9{5[g*gsybtOgJ-gRWl!KM U)7(+y-d@S4T.W ܡ&jTq-RKlCA CF5R]_5՜:-{;Lڮ/%cm2K|T.rGVEXtQĵ{ 5fM̜^|] Nf<W|{p9rUk u]|yxMQ8(_(fHoMgSzTMeYOU_g&ȝJi)˦i
+,DkTp)Jsμ!}/I|=cM2S/242tk4s4c<u[-eIᛚ2w2}*2>E7TFGk1*}2/U5rm#w_E
+uղ
+MK
+L\ S7(+ mDdNkuu*rV.o
+3l MO.cF[ m*]+Y4k& %Zc]A)ë
+rT Q)bJ &qeTeKV҉T:Fjd
+LK t eMW/t<hoh D U–JOi! l};bK`i+^Z~}3o燆LD_ucWh
+7mlv`ۏ>vցx?&9}hpGű@~6AVaO{ 1nF/z=w{$w0Z|݈ˡB/l&x{ t>n?> EEg7X{6S$v8Z:h.4A-R(<pQ)Yrfp{Ob VbEm
+1z1&ovgZNjH?
+صµG<snrћj[鍂i mwW>E g<
+41k{<`OGn%% ptr0Z$.n8?t9;8;8 q)^"Zh㽏?Ugt,a TȥϦ;rmήҴ:ɭk`O&mLh}xӝODJt=^@;svýwCiеawA܈+|a O08BnU!dhvOu_ٖ r+@La*'NK !
+Vwi?r11xA^f3Mo_|,kvL8A<84:ƑG19- Ai.@:-|gcg;'n7句MxӎD/:4}G"#s(6BPU]bz.hP6S{wQ= |Gji-[(G:j l;u1ǕrDc2aKbax4 D1&ZpG
+٣-w>ɓfS3Աd1CjNiKNjM}hO}Ô2HT!NM|ÓΒ(3YU̩L%0kp('~ aP=&+X;g"K6ŮO3 XƸHiI,`g>C0N؟p<e,p,Q4Q<RN52! X6aeSPyJPihM=%2천
+J_;diZmmhWՊez@˳~> M\5WZ}ΐY*o?akJ`u[`e+o_13qYJ'n# RaɓJET&=Z|CʧV_2և\C=[KYϜM˳'fOW8զMU&Ojg cM.f=?uy-]|$q9C"U&y:@O<~[ekUi
+%L-+Ъ;*NMQT[FӠ뾯6XNքTg@y/L2F
+R^]d:Rs,XLtW6R=w>WwWW`hЋ5
+)a9Z cJx\*'/-h$2w$ۛw ZqE@\!nyP#Twj +K¼w?C~w-j
+_[7cftFZdk0
+i3݆)[B{{6RbQ㞮KFp KbۤQ[{,nx@l׏l?樍)psy:OOBvd)?uNprN zGD9 o:Oq<)6 rm= wυ`kl7vٲ חlm/ѷ!m6ԸzOtwyݤ
+
+2"1dZh G Wy u*e2O}Cyg}XILix*XRcuWgk/{ҋ1ώ\~tJi).U^^ptH$6&Qls|i5,_-l'1nu2}\/Vo*Si±rs$)5wZؠؒog[t-2
+^;J9!iJISJExJ~@%h7i&QGᦹ^kh?)@Gi unJ?5G2V{(W {
+AlR(s6⮼QJd→
+n~H\S""O`R\8MwASlO}ʟ?S%Q퀊hي_br6駺,/hq2z\;:Ѐ89^T \=sΰt %C{88n>۽eXG_V6
+ݦ࠴XziX5lZ g^b1;bpVvZ sp¨Vr5r PDXZZp&WnĺYG8uRǹW8\`!^i[а@pcQ
+5F!ߧ)`'` x͵!¶\X[=nxT*kpw<[߶͋!H>"A/o]aG[d/Tp6uGayz6ݠr*:r 3lqf?O9yj>ȝ+pobm޵DVfҷB&@k@uFJ'gTPXxO_p՟>rօ}am>4b.4l$7{𿜍4PSniGF}Zgd;2lRz7&p‘(#=6:F{Ch?@[[pX nm[SHq *yeh7%WJܑJ zB iI N 9Rh){zdz8zԖUc293.GNl#?R"'!b 
+cp}bFo!zdahz'?`y~CG-!
+U_^Dߕ5[G?fo;^z8r\%L=xyϏ7]}{=YIlx}-W(4eNu\)Ui*J:@'axdVחK% ) U7BuVs]WoBX[j #3K5Ү}EQj8ү,+b٧Is q}ك®l}uWΓZ]@q=IaH|(+Уi*mL嫰H vd>碧H;,Euw-cA4RDE(
+XGmuuR,HG z) A :{wOz?\–GxUvJC|՜.#Ry(}ʖ^&[⾶Fe0>)9Oy&N2_P*dRYSQ}L-~Z!/%/)*m,7T䒔UgVW?|긦;=xO}(=SG `s`[QJlĆ ¹:>kot 6t ܷG`"b_kqMؾHn_6`vGX`"(`N#]ȁMX"[#30uzwvX|cG^lWu~ktKՑ6؄FdF <?c["K562
+V +Da*0sӹ^EޔeޔUcG(&Tɺ""y\j3 !L-^▨.nMW)hѓ\7'8?)$-Va]Ys4?D)QC^i}"GHEf bTQc7֞xbلPe^>OOKuq;7U#JW$VKbEuwʓD9 ro3Sp+Y.%Fo[FcT/߳zlõW-Ȇv%z: G,qu13.lg^{#;ё5~#`j)4ZCi
+Z3p6y{*8n NN38еtnun(\ߓݐ5?3FC4z>Gk] Sk
+eFYyi9xJd`lFp9; VW| ?~p̃U8*JKT\r-ESyۄdcR࣠f9qNJ7/ӹ[\H\ѹG.smˌGN4f6zwZ3!PbGj6Ad}5UbGːUGGg
+TKc7g<v=f +[R0pYsbYD1 =5$xYA&-V }V6+pl\A<"YЀ! ݾ!x4 C 7@Ց_&x-y
+Wa:xNsJJ윜)Kϑpxo%xck5j*5X +  ^}̩
+4qGI]˛y&x֎DB\[8?#{"^IW4_<^A80$֔"uHq˓%)C7qaEJgIm*Yܧʸi
+J,yR$e@2#R%)
+3Ro ܅ܙKwG.p& '8*o#%̧:j"
+ܢ5ÔUeCݚNnj.q^e}Q0HfT*L/Us%ڇR}T.䨊RmUQS2J^W]LB=z_J_Q=(
+3S?G]F%Uw%Rh1UF! BIP@fކIp[=͝|A{s=_lkq+x\~~=}.iѪ re~‚v4r'm:Ĭ/Z1zi6Mb`+gloB4*>vIG_X~Vlzc['Vm|'>ۂ'l@-o Ƶx ޸&{Ё]f{ Nf{߉"폿pߊ}[Ќy
+n [|Nvb#K[vƚ~n GQ88/h{fg;,2<uTs[8nKDF{0 ևso}Zs<X¾a{&'+ǀl)>tګCWiz7أr/l:_j1b=o`_3_ Dc]\b?lmkH8Ek;@
+b{!ahۯiGv3 ˊt8 J:04a#1 ?a?f'  n_Y:ߟg :Vp
+ pAbbFe5)l0۠$
+~$*u.]\~=Hb@+C.G>obm7])
+@rd^a}iN]O"= N@_7 Xݦ.U%VU\(nô<!P#ihST5=Է׉KuM ]EE֪AC^4b :rd
+< nfh[z,`1Jsh+ٍ?u A%'BGs{8@>,׽oa
+exv#oX"]RfB z{# CŊ*f!nYw-c~t">Εoۘ9"h d}p-n_/6W{"fat&F7;зT:gc !XזolBZ lzBN:@FMȤ.}N wXYDy eM\SxL\ֈrc_U0@.Fڛ
+ \!v2WSu,`;`{8=Cތn#\#o6So7@8zIV5l 'kcWñK ?Ȅ/ExY$~4r Ix9<av?Fdda>gOyk\4)&#=7#!cˀ3
+Y
+ö8 _;cXߩ#o2Џs`zGfn*1TNKp21Kf~xpP'Im\=,pT|i>BߣN?TPYADZ Hs}ײ*"@cYC fh! !@M>J R]+ݝgdܜ\rrMiL%MV'MND@ͧXӁpnBKۯ_)3,+KŊy
+ʼ"eZ*C*S
+մ4M֧lmp> }ȴ%ǪSdYRlj]D>X0Vibula]IW.Y2H5k }eJ GJC[i*ޕk
+ƋZQU[2,2H|eNQI[K0.zڳڜ]"C;mn.=
+e c+XMzz&^όjgf _wG<8J9N SsvD?93kI*Z[{F].8'MpǶ +-v@QOc2 ?dVCc;7SmN߆:鞯QoE'Yy}cP@+|7#D{G"C_zzv@sO5!
+܇N
+}Џs6(lq
+~ s%~ BּSKPwڇE~}FDKDtAygdN|BGǂ{
+5}\܋ww(jv;>ECDQ#"z̟(a oUiqJMn?n轉HP~/"r~"rNg}?ʏ  DN"nlIv<[SW߰ hQ[<,
+Wpŵ"E¦ A 5 [Hd!n*TT\@!TtZ}?0 :?|{Mιs9O!*_ Np#㜜;q
+C 8
+xP\GcwQ;Ҷ6$ݍ_~!sLqDžq/.υ&<Y`;=ibSnݍwCT'M쩥E̸Za$Ͷi32qOEgUӦչ$tYi̷״wʬ?fRߤץ7pDcʻdcdwr~Qf۲癯=,LjmXdI[:#G»$:d#c^M5"ss(,Q(*UKL]\uI̘IU('*R_鮼dJydN3e>igr5b]|;L0/6OpU!L?aFgW a͞y ϊucIW<~yQQzYXz5sCn<l0&fSS.# qq7Iig.eQSܒ̖vBCĘ/VOrdG⧍Zse=~58o*h
+k^U0]MhU,SN-f '"/jPN7i
+ES6{n<iS\-iq<:KB<ޘD{^Hiokimgg fϊΞI=:s^ԑ ԱK ԧWiWLi6b$oB&og~QsƠUmTXj4
+Z\!`dzTS5RO_gTZ
+}곳3ax]HyW`*K&I:8l)&Xѯ2pLݺnR_1u5fqSNC:u7v(ֳI}X>"{+tq=֣RWYEU]$a}-} kxdoJJIV6Ҏ,y1X!uwBH7[D–&_/V{et}v؄캭K\ϜĽeEY,G
+E}?1
+nEfTS35}2k0<wv/R}Rpx4bDd\gEc>[7'*Jd äM:cR[ʞ,d*lhJԶf/؝3%{381z)(>ؙ񿇺v%:m\o Or?;!I[qx=1ߵFP;1'ƇCW Z7.mܾFO/
+`3; 65;@02._[qh:~ۊ\G\!׍m 󳱙8
+R
+/#Wюw/c9گs?3}tܧ{ d{D?~S
+/Їzjo T
+8dZfæptp1H$^
+m m߈eD?ᨢ_kzǩ6J~\BNRŒހJ"榎󑧋~ojoL'khC~c)C^l :p_Ϫ~^2uI}m>rU>bfRx:NlF{`~"5o@"OD+bFSpƓڢƒt1)QA[ .GLXJRzTib*?FoY
+9"drQ+5a\ɬOjx\ ?^h$<rdo%'^f4$"巤 VRW7B}o3ySFKSͥ*N,ߜ!?- V7č q;&lN~^ؒU?$UsZ+'@!󏕨ycbK?(|[R*H.'DYw1o1ke?żZy} jB K*5]9Ti
+3Dm LOoi-*
+DIʢ6' 둹"^[)
+JSȺVجɺ+#LM|6GH]@x_TBvj_5uF+3쑷uI딓ՕY
+lmCfUZ8 [HؚU꒒5jEFWukN[-{KfSgX_uSCPؒ^${x:TBZX*n\UkYV^S]%UP+깉]o~ҷ oDe#ׯ@ i@gq
+mh`7%VV`gr^d/c}w(x1> ~eҶ[Gvѷ
+zmO 3`ow)ל=3O/w!\@]/_ _m.:Kf޽6Xwkav;n98V3LduW1Uc}Yfq#lU<^:S .uˁ##ǷzuF[[[pe
+EjINmImF],M^x+"^\XUo겚Ԃ6>;֕[|KtyEqC¬k\T *bZuNQ@@L'"00(0DI" LIdI:  €R﬽ݺzNIf0\lTcx% +;"/WM3}zC1Aw5
+Uτ=x5FUcaVٻrEȦ vo2 x(Aǐ: !:[x41/.ȀDZ&4>S
+lȀ2Σ8Oa0k$!C|IlcČ@4 $l!/`GCe]H73|itxjfu|-28:\_l%ÒN肇p sI>hLpz5ǚuPj
+[sʹg#괂cm6+ 9ectc=6,6,GX.ڳup_OyuYR'ھoїVS>Bqݛ(51hI Z3pw-uj` _{ѻ\{;Nj0m6xucN8݆_d3
+x5O7*&=j|Do/8lU?reQb<C++4},͙Ƣ"d"/id$aM0]ȗ`M0e.+@ZE׋O+WBe 4Ec Fќ!*j882V*ː%f^
+ V
+^f&\y)jDf}*|:c6sKxw\<M,ʧs>/T!W?Bօ ̋3D|&>űsc31dʸTuC2%U&DoJ# 5\P3$y*GҴ1htEbw1@0B<GOT%o"ES$܉1o";S}-sc ^F݋~]͟ߏ{Tuc,6a$T Y:~DN=zL%2g/4÷ȵV={F]%^eP>?T,O^0̈>-~uM\0?d|:yN*R ㇋tq%126:EB5.=͏ Já弡kA$Y;9$l=Nh9<癀1 9?&l^ުlhRԧ7I̮sZd)sLST+޿'6G!Wiʓhkt|N'5YZ&OkR[V#>WI7j'H+W
++'2B+"$wV;Jդ6WdꤪZZiruJXi鴶:LMr~,#VvVyh5R2."%p><9x,5ɍY`_F_f]';b&iH_C_VQZ(-ORWTS^^m2.x|pa= l;2
+jf"&cأt|؇g
+nSGٿ
+FP6lğal_5^ʢ_FS `<D5abFb;I3{9p(_<"%a1-|Pؘzp4(06IFsxFSȩqoõῇcI}/6}w;/w] }~ + y {yx~\9R'"tbٸ't NyK¦gէ
+\&;KP&ɑtdd}6/IU9%Rgt$̙v2fB{1i0(O9}DO"YcidYy쇓So3a]k i.*2/s̙6TJ#:p2uD 7%LS]{'NR?0:QZ8/"}7%RF.5 {儅5iSʨ1eZXjmhqXXAp8Qxqxdex2?@*&4'ďe2Em$2O5izV_T 2sr}FRy`Hыf
+Dsj\ 6;4}9"gT+ivLiXWO) FFQѐd4(1(:q lATUhd]fzX( -3bG'9{vUݪ{oz_zXY6U= T?OK Ԕ;wsKQ9uuE+A ¦a !3 [C
+ +kI.pڻ L<&'~m|ѹ>gkkLv>\O ,\
+U` 6Guu:
+g#w-.3p76޵|t%kHwWrjB[r4hlIE4ln̫nʯOn̿P\T\ϭ*jM)*:{!@xSR~>WKd4e3[ %hdֵG:"8܂d MbOa:'s&0}|3pk nm[j;J%:"mY CywWPW.9Wz|N E` NK n'op: sw >c:#b
+NwυSP\ly
+dSX;or>2E =e/.^sԒajd؉%=ȌXs^pdK-l^[ہ:̂=O-6Lx<<!,tV/#6GK80*}"+,OR8ڿ}o;ZIySޝS}vI!)A;\ѯ3㋩3c,b/0YAy
+1F`۽$:U~9uj<7^Ick8>s
+oLo{Mqΐ"s?h1h5>XOcN|3'弰1q~*!@ ~'N>^xo~3ߍ^5ߪ!#/Cn2?^>`^`/]+R+ "KXn0ύIiKu1xt(dtXO%ggo* ~R?:xrwÙ3UcTtj`mO*|iwۢSQ>Uu6lY'4+|{ה<v ! zwP~ Y?..I'#1/qcc_Fc^G c&d0~"5Yl;$]"C2q
+]2c<aa1脷鰙r?y0Qhd۵$g0M(W- /O/!GxDڏ,K8Q&б3Qo;
+AyS_مO^IzMyj;7{P"w>i?7!Cq:
+F %>G*qC؞<a%<u8\Us:q"S$}g9]l}.ia,-gL X(Y.Lz&$Ė|N$c#3I#JM&K%%C_~%I%I*MGkׇi +9/o~O1Iqsaz8c8
+?Pg^K_GP?s<Ui[;IӉUא9ʓ/(㼌ॽKPf<  vGKv%?)hMN딑H)Ʌ tLK2ٯC'յjfϤTՖ(HH9'O'49}R:OAB؟ι'sI > 5p@%~iT^/Wf齅ByDsFUn
+z4R8S"}TGu$jcj}Md˸EFoYc:C39Z]-&NKΑd7W3y>@S/,7~[]lky̼sZmYx r8 = s}6#2i.
+!8c`WWZhZDIu;aFd]Ug&ƤxG1_:y89Ef<`𵞡A_=ӭ ;nD-bc+*c*jKEMld~V6ZPMچ2A\eAK_ u'ug%! 7->w6<ff 8wl`)870987 h``9`->@Ncd$#щ/6ֱ"#4 wȌn +@c#[B9[kas)l+
++[.5W:
+r%eͅҒlyeM&ab~KRqR\_^ o+mr>IRTW\t.L/%[\񩳄Ms_M(2Cs
+.CD X k?G 8O1P_̏nv{( |_7pܴAy 狛>e ΅Cְܘe/ȗ8ޘ5[YE\~Ⱦ聇F
+zGSps5ɓE$Tm2xX}GLe?⥗(cbb_:/&|L%~ʐ$}JH櫸/ռ_U3M~Rы}R">)VrUOkS+Gդ 4@B<"u@o*Ӻ>CtTT&s0):GDқmdM\SeL
+SҜI4~EGʋ"a$a0)($8Q|ETRCxjW68:m n rbRqJErp@F_U_-.Q)rJJp|_!Go'![PU~ R̀) +zT}rMrяi:n/$.>~^]Ge&/OH!OʕeܹF>Ry[}(jYI\ʊ:۔y-Q#GIKa_uΰ[2S;,+ 0"&
+VT&MJ K 0@^60 0 UQ C؀(B֍~qޝ}~®,i } ;n.d]%^ЕY7+KzΫ ٟQD؟8@{u}Sksy ;鬕#oёxX=۹ѫpp0yL_kgeF[!S[`qXu%(tރ}Gd^@PY 9{;^_X# 1#+ ,vgxX
+Ư+e؃W"˃$6#k cM5e3@s"k@ގy;f-"ol:Y@߆H k6SṎOGN4d^
+t'> JܴٷorT7r@3/]~jV,$=_IZ8v-ssar=p xT~_z<[g_R\Ґ@x$SYz'szTqIsDuqZa`'ù4ű0שT]PQSx=7>+.)g7s =):3iCzrI
+jNH
+>A
+cʦB:Z:jH9 iv](>=X ;f4>[М2hzUAVA{$@s2@arm+28WCd*ՠLiup221 n¹EG`tS|vf50y̖ BV녎ptֈ+sumMYܶ󅅵A?7/62xW:[_(lM'A 7/ ?/伲rIKƙ4nЮ*G em[\E jqX h`×V:ˁ!͡v\_uN߸={S-M5c.[]Y,=)oVt"^aT It*uK:?C2I2p2d$EV5tm~\gŘE."HU]
+f%?t}
+2*^ &o*DֶL~ߠ_Yp_w5f8߄m"ww.@S}8
+߰O2phV
+rOEK5
+{6@^vN9}\k
+@W;ʠ7vM"7o-2BnZ7a`qDŽ!u`וӽ[R{6;ѤqfYMMM G>˪fI}dZtuaJg|LySV]~/:^[/ sϋFv=Ǐ ɝ:^%żD?=)W17YiԿeǜ f hgݯ%g:> y;-I' ^$fKr Sq32 cH"X\XOܙi9϶?Ze49poֲ֖NgcO8h87яo< {߻ ѵ;/:߄cccɄ鉏H'sDSYėY$ynWʣKTaad(a2?KKJ" RG ,K#{wlw"DXb0 ,aԧ(؂d>3$<qUMֈRHH_M7a:O?+L-W.Fwq޸tOd/EI K{Rf%IsEB)~|
+~
+Ct03
+xC<@?6 3|1\HE?0<QKp
+Iwʧ$³sw}HS'~> DqSAςI:^>?INI9;{v2'}@<NyJMP%'ΰ%3ס 3!¸Ywn'g YFz1뫉|82],v&H&P(w,aYg<3K>NtU&5<{Kx
+=9;=Xhe3_X?2?*)x
+~
+rq~(*j]4b"8jd6Ҋ
+endstream endobj 17 0 obj <</Length 58761/Filter[/FlateDecode]>>stream
+H<yTWǿ_6eGjEeShA+U
+UԺtlQ! [$%
+_?`^7<mР:C~o[??Z[:m_W[N&v M0ʊ.n1oU\\xV[7Sr)w'羪sWkTUhA_j]^+Fo0mՐTWJZJVKPHu
+y\jFS1V$fFeaӳV*z<MT hUaTGX[6S1*ԗ6'2ʒ:1bcGz7] WՕ
+5oW͛V򦺘S6jBS2ĔM=6K&Tυ5?& 7#̓|mbޘ)]ohQ&&iNZm4(dM-BU/04N'gq ~ i؈Cg}ވ}E;g|Ɇ$ -B-96SVs$(2؝Z |M='.1n=,D
+A`[4إf!!(fc$-)\{V12 [pʿW/=2ʾ7%$mdCwN$稤su}nűٱӒōo7&7<Ԕ}7K&"=t9YsgpzYC臘GΎ@Q~7FleN]^ d 뷓{OiX,l,|8j}fŗn
+s^Xi8dOZ"v"Ld]2r!bl-Bmpt/[T+Z]"مUxJ?WS$*. y=mҫA8'-q{jʞ()K;۲*qi@\*ܓ
+u"^Q@+ TVB1Zg\G" wtm0twiZpZ}| -v'dH\^ٍPD5]yV[PVk8IFtĵ6s yr?fK|Ivh;6bh-;WdGĈq߱6Y>k$m@!H!a1rpF!%ΈА{DlA=c[Wt29ig_Ԉ9&`u#mt^5C^fpCq*t8_x5 68:n k$LZ aKG8D-j
+d?#.Fa7$#svG#2\5劬YWd/8 r5o+dZ#sΊ<1m4263eiO"5xwQxDCgPTf*c~H _:v:u;i&ySZZGZCʼ-Rf:cZB*fI mH%$K Cw?hӅn $_#g3w)`C^q#D7( XoL+cN>q?pr v\ _=w!v3/l9zmD3wi/Pg7#z?DiTYoH@qk]nA[eT4l!B ! {N
+՜".ĽUi+7>*Y%p.KXfyODyZF/a,43^q3/8ZD&g*Odz->_LK=Wg!w6o!7;#佩O7`yop& cMD9S* :|,˜MפU)d> 9&͘fO&+ k@_(xvp
+2h!a=$[r3P,CƼA9v3$Pp9Rn=5:k5z`rsEnu:$JK'jLJX8 7&}L?:m\[{Ũð> j2
+,Fsi
+1yL}v|vNA. ulKFPEhFp5ǁ᛾8ꀳ]`N~\- ^#Ԭ]yϻn~޻yDx>=`o5aq*8_v3F~s?Aw ld#'жPoZ$3..7mȹb oۣ&L-r!Y߽<,
+envA&n@!MTCj_S[S3?Kn*ڗȻC}< Qӕ!t$"&ѺUcZ$>qrXXyM,/j9W5Ƿ)v/m)]bYAM gF9a%:DD[#rr}Yw6gwLzk w⁧R %m m~Pԝ env950j0LN=?}vė([h"{un@p'tl`E׆貾>\֑<q١z?+ݺhY}fu:ߠ-C)Dnϗ#ב%hEhepvg^JA{wg'9"dkEZ
+P_
+ED,DJǾQT\PqC!B"kXUDh,Vhwfݙwܹ}5!TX-k{.d.=٦K]RZ6틐e86 6 p5nw2 lq}pjZ$hQ[ ߽^أU<:{)xa#'dKT.x/CUи]:L
+YX?EDDbpa{,sn}Gi626&~̐3Atl6NpC$7n:,v§$r̥(FRp){9:=>)H|,Lg ]dglN~?ImL#>3ޟmLa7&O:/=
+|dFV-Sd6[-m:i_ .W`CfZNqar.)Il *E-y5A6:`>l`
+)fRgG M<}cnzkeXoWc]\K7@ AT։W7Bw77h'| n2gӏCiCCx BЏXOZk$NX2}s\=qL-~jF䄥Jz+;u.guvg5Gmʾt;qYPKZo"gANܷ+妰x XӁ-w5X UR L :obt!rWm
+YkqȦH/A*~.9epB
+>O=,(~Vhˎ7t/@_ȍ[ +X.LD6 WޒG8'*WFZ[5(۲ck*x~
+]'
+4?eCG5"wN3WK60>dv^XOX+?c-QO7jxuܜw}+[q„B%9[F>%XjecodN<d|NkPV7QKG:JARZ5#q,k&_*9Қ>%9ydKִHnֽ$~P<ː1ߝ7mcJ^˞*JsM
+zDm/T_6H&_:juJG?hU tW$1t
+(|զ(uBC UtiI[`3)FhWj $Sw)8 #Y`E|:k]
+o]8>JT68O^C@_f%ii,, "-;-aۙ~Yz=d2]j}uԘ9d`Q>Бơc{}ORt.91?.<+[OHR8\IA
+
+>Ԛd0pM`7S`3ofp3vct`+_ $$YcS8.؇cpgɟ8/'.ɔ-jL˖ƿV.$^pL~Q'OɒEBV]KoH Kihë8MgdIh y?CS A+.(.k,JsK9QFKL"\B*\+bevhrQ|hU饆aEvvӅV7cvwY5.)s5i0A6/\U L%12zAb44:։oq-+sUpRCbЉ$cT[4s[HUHV8Op<,~9nX TRGf=Ӊj
+nM]NN:3; ~yn2
+8n߹!##si_j8ϩka==\
+89`N}\ t*_gdZ
+yOctp9},IEH3zԡLs% w(1u=E$~&ӧKi3gDs!zǚ ~a/OÇ&wҦ=sS~ʨeqoC !@0->F?Kk\3F| DS6`bƼj )_Y伷*rGq7ъNix4e"yk`sz ̥+?+U/x2e*` s$loW,Mk&m,_Q2 eÅ"9gO5+hJof.Ц X)s:wZSV)T9㕪1dUHꌹ8ZկXZ8IKӧDL8_q,u,9Q[EWzobW*+kMR-G_f[;5ԇ^/-%&|MmIgä_3[X
+MƎg=j Ia~e]SAmGj|ve6&
+5*Y=?o)ečGI6}?C"Ӻ#@aMCN#?oN80RV#oO6k;hv(~sdt#t<\QǽŽF{/>>[
+yOr'q¼=gJRU#%W:.IrfsBv\T)]Rʻ9⮴2ƴ
+dMRi"$ުdUfݵTc99Nҫ!WyR\$n-')&[m֤7ǚ !Kr%rodԳZ2;e<o~\
+G߾n3iVAp k 4="׏&|R´z\~zC4@~?OEOAP*h7h 2AcHxngoQQ 8;b a}
+ESyd7%Ų,yD g,R6zB</H9i秸YØ G1/Ďļ̹ 潚3Gi'Ӓ(g15g&]7zN^0ΕLr[3強9oݜ:)g2QęBI laSԷ!M̥&JDkR֚IQb g#ܯ]i^KG/K^1G~G<z-x Tor9ryTy,U}] O?].)!)Jؿl9d||zׅ[]3]eۄʥFM|zRWj_;I:^ 5UBECET=JVnw~MS_P1Gy?}9{x.󨦮<B 2cT
+@DT"@4ʞEeEYۢ#*d%!!b.)xN;i3:{}=/Tg!9?8IN}G6f8MY
+O9Zί9éh~K֤vY_. eT}W<\5T\ESUV9J@\dƾwUO OiBosN7pNggM4g#2:엩9 Y
+>W?[{Z<{Z.W##gK&CC|u상iWՌt mjcmF&8J7^t=Nv%F]Q[ިt65!_ԫdDun 4(E
+xbad` ?7nڇ!>}##;"8`l:ı\)-x:(r
+njH5 odH\=m p!qnO|kcI7'W/,M4%OiY#4']`]:4遟6g/d\u:[I~'8L&Œm
+~,>| ̩1DdI2D+)-,,U)J;o{Jא%bER{. g<\bJn]9_i_}Qh[+_yAKBT #?!ȗ*艗kżdQd0%Kx}0/?g/>"GXw?0//[*ӷ(xΕµ쒇~J쌸kRH$5BؓN >b+C#Wcfodz ~DDDGƶ 448:H!u=4)Ǡ׽6";6xoxo?  Nq\m
+#MiÞn@0Szc}p#
+lkظ^D_ by.jBaW@swH>t=0gna qz*9sgܣ]pND[
+
+9E̺"\s|0i62ؑ4r@<X0.nƋ5s-Y^ '^7L _>;ʼn]i}ʛCˣ mOZ1SGDA_$oB=U"Ț)-Sg.S}<NJ"63.O8 $IL.N]ecs^ng79jyF?U+-jNe*X zpIۉcQG|eQT8]y(]!^ߖu+2rŌw6/Q+η"^ؗEXڗ$NvkϿZzUܛ+JƇ,9}
+%wEŃҊ^Ks* t+,vs׆8~ORNTsm@fHR%+nȄ8`+KWH9%i^q-!؟"(ˆCpAա8oOycCUDa ކ36!ݑUR!.,'kZ dx>&#"I`0o#w[L]U`^Wu7߲%–^#Ya^U7}{"&cw^0W.25B>Kˬ*fp:&}g
+u#_ M<؀(dd=
+
+L!ևoO )|v7]`zSApA
+oF tsC@j[ly7Š~<]JK}AKYuJMNKX99uR}ɟnNDfCBCT=9p}konZHm<
+O˓ IHo0_;$
+ʂd9mN|ޜt!p;|!MF 59cc8<LrMЉ;ݻQ|^ԃLY7K 8.aI|v{Bȃ͐5'*ܛ{<߽q1wTp-iN(@Zؕ)!
+ph"ud=LbgvG7= g%=Ohu)k鴨 _aR,[,rn\%a]G•{ĩF| Ke)Xm E7.͗kUxoG=7=գE(mS^ڤ/Ӳ+L j--v&;W G/rE[($j6DM0WDS6#d0
+F(<?B ?d
+T {T _">ǽ}#!qZ!3~CC˳9Yд<-E!yν1tr#}9$d SDq9G2YcQSšboB!kom̚]29\1?S6]mPmxgSӺAgz9&ADNDa_K#ɒw?^ؔWuK:ąs3qz3/dBMؘ'fuW7dةdqp4q W\(I,& ҄xIm\%gp r4 |-S%O4IhHt9!uRsl4aZĘD)*6F<{H?R <T+8Y
+<2a>x16~P3rrGrjk%wLgԎBZC$V/
+_-a>S#>3;+q?ڢ>zJDIn]Cs[l,v#zQzTB]xHY:u2o<k ;A3gS@u)cL^O52(u1T̘aT^G3nOiOhIQ>lIzVX<PH(!R8-"KH'
+O k%YZ/絋y
+8<Fts0c>W= 
+H{Eһ=r%T
+}"mQ9"_*%ĝs>nx~#pH2{*e,8mY5oyyZos\U'0ˊrSpm؉)=9IM)uI}I ~40OxFX h*ihVr\9;82K+B$!-
+Bm[ |n(Am=:j2Dg{UJ;ڗ|n7#$t0cjܶvYKX
+ya.H2hΘ0ӌ^f3cj#ujQu{܏_/iqr}p+/lU^Jyϕ'QڞFͥKrQ$=/IUhr{eNdUJ5I sB ˱$Œo;nvze3궓kMXFMH&Ƥk3d4x!Sdn "d
+kKB:`~FZ(!\N-(cy
+鼈YM>n?frFgӻ*NMtw`m4(ga%<Β$Vqd4V.yz822ҵ2p:SD67f^kkɹ!0dtoȃ^0S%׽:p12?;,_(+**A]""*  %@Hhҫ0t
+JS i!4頣agsKwϽ缯[3C5}t`JoR~3|2c;4 &k<>Յ6I/N>e2exjC'_>x%7><\K=ՏUN v `ߥ Ǒϭz0`#
+\NqqmpŬg9r*ˑ{U,&YgO7[6xb}+P F׷WUU**xITct@`6G TZ7PB:7 ! xJh3@E?97>.;|<'eR(31gǰx m
++nFCxvF'ܖȓ|
+MRH<ՠ:ݦ_ѱ{״I99wPO9\[i/al'j:pA|D?n!e+MO8wYšYC#}=rm \k:d=w n՝}ێSkGWq5M4"8=6z9@fb܄Da,ܨ!_[ÞysB=#;<{Cw">rn#J 779Aې7Hf.ϗ 2J✡¬[9nLOLIR8e=r9Be4򗈶w"[(u2|6|7u.S4%" 2ʱ-ϔK2'+,3^#k/JKEK2責sK=b^IP7n8xPGDODiORQO|fG~y&OEN1[Qܫ)Qx"1%v.gK~,gHIB?h!d]AS{>uF}`u|L`O`3p KK.ς<@Sګ|,#t,6@
+'_Ϲӟx# ޅI#EHKvtΘWC7{3F+'KKS&JdeSQK(kϼWٞ1^Y,DErQ]+IP(,׮pW=[,gsMDVkNkP~Hd@"w`aĶ@9
+/>@D\(%.*A8
+A+7 6
+
+q "VkW5Xr2T`*~n%^No1/m(5}"'^67=5+erK&-v+A Smk4n䰫E3l"G3)`[2r11dk3&}b~}Cj<-4gzJ]_h%8l۽?IW߸Fx>
+|q
+/MpqjQc,5͓C/<<DO3M=$+1q3 'ifegdƿS^e}n~[\;CX'J9$ik@w6ǐ!6 kuP6@_C8KA[H[׀.(eml7j +pXgvԦ?ԕ"x([mH+: "  P ! CCAFPAIHBHHI@
+RVRΞ3w/N=;O-A3׶zWC (?gCؒ}0VS3:-gЎ:!m7~{/B+G6[KMoDNJ\ԭ/rO<'[Tպ`Z,[k#G݀NLVrL u.L9pf}&1[Cf`1=f h'Wm]> Rq#jCp,JdIRsc}8N*FGEҹp)T9܍%b#K2+-o'Jb##;::~7N'v(U^>$ $uF-1܌x.^ّe2)]̮uPEOyL{9T}<R% á&՞duiq
+ eJ.t&Y
+(n,B3AGO"^xa_B )s6ȳP
+Nb(w}[Jc:;uI6=AO3C)1HN y\$6*pNSF.5=v0T" EL#^I""]ܟИ:M0Ys$sTSF_"q,X1+`2듟&?#bf#MeJSػ  gBD D-c_EId LIT$i4e6HaRg
+ƴEbRDJ9r
+BDwPi UDDtuui& ,@ %BM@v]%$B
+HHoRtuug~o;Oy<%<SSohy9vpI%0:_ [ 6ź
+P !icw4p=u4%;> NJp_6P3/
+E% S8(Dz=vb=>C{ɥ2^85Yp|TO\@Gry_tt*P˷
+󄙓Y-)1Y1ĭ9ƴ7 MilQB9+ZrWr
+93?i:],.'>`KoZ~~*%!.s
+c_zF+<-~p+n2v8WQ)!L%K'ڛX*Ϝ(zx`~BA|\:O/ϵ#g@x/_|nB9e$oX,W _7yG"hAmQ`#:@Apᥱ&QфXtuH**E|Y;^^0 ˟^61q[.hK$fUOQ,mJ;5v\V6-]DxF\8Tj'Usc#1Dџ]\b~5[$+]Ͳ
+➈rEļo9?ۖ۝ӑ] ,_]o[Ϳ.k!_T_$)t6
+:ʅb~]QGcU3ړNC`s8
+(@T^MXv"^@o1}v؍7
+Y6cF0Øΐ|VsFƷAƷ# < <GzvotOv@Axx`owRcmdV񭎕q
+&mB ə1Ϟɛ xa&0?#+!o)}‰Sg_u^)OSv'ӟS2l9sE~tE˕n.`4רЍzÑUa|ahtAr%hCL"3OQ(طam x|`V<k5moY[^xg5NJk#>p kNv9:M׈z揶zqa&9c
+CJO%&K ,йxj`Y>)HËPf {Wþf-#Ӆ@G7vO7@}hKV;(De.J10e{pKiN;go
+O:n`6w }=f kN źs$c 5ۗ]ͪ=%ewJTV&{T8W#Er<^T'qL?L6L{7Oߜ0'iI4PiHW6NdDi>=xz4dBپتÁ))f]oMܤ 8\ynw#iZils G)>j wZ8z$f4s~;rޱe#D>w޺5U==MIxT+ڙwgS9z隝ٴ'}rȉd}m^!FևQi#*>ug>"˻I='8 \g_ ѧ\8G0>W L `QQ\CEjKݭQ.d~58<JQ\?(e)w}!Ϋ?`N ˁ5j(B.ZЃ.sX []k
+k3l0w~'W; 2pjOoM{לqb]]Ԣ/b`Yvw]Elaar/w'h*2QI-I
+b<G|~,j!W1VdLmZ% ԥ ,c1&e/^ruU2KW/br f1Q|%JKxҲ6p`ê.@V2)S@ky|MATЀBJj/Z/g/wf
+ruJVYO*/䩯{ozA륽TRSD EJF#?_/Źwz|C=
+z>Nba1ddH(7g7_n__z5*Oq/<~k?nc 2X?(_2z*濒T2R%G[, ^rtpolc%<I@*w\U(S)E\YH '.&Ο**iEezF<.iR"TOȔ*c2E$&/mW7P >[)¶N
+n$
+9RZ+!G{E!@#*:+EeCGEţzGMV# n)rzZE8t6xPTqG
+r>
+ƕ,]߀=
+|{;gUФ`2vJ
+BGVAƈ֬<L;1lBuo[ +qc, ~
+ Z}]`] wu0r=f)x]
+ XחA@l] ^-x_]8uͿ#qCFX͞.x#8Zӎ5^  s` eS,XYVm)}qqZh؊wSD
+QNPu1~ijľ
+IžI`
+}{?WxzL\;<еkMc ߥFogy'OF*2 `'W?D:._ȭ{cuwOEMe[+xjZ1k^Ӧw?_01엌ZBi{E &˃Rp2H28 ; ~l]^3I5krgYȦrM(?1bVźoQ?:xSM;?lڍϛa 
+yd񹯙| 3R$kG~
+T:z*(~8J0Clk 'ץg rRH4ı_c)|WON
+Ÿ{KŸyKx3lyԛPUL
+y
+YbQ5a>kT_.>S&?2esx#SalUgoygI烃V-29o=B߳ഇׯ
+b`n+dz'yw 9
+ČI/.u-RMȣ%@'B BCgD|ᏼ*Bl l.MsIcp=pԺЮ4ḫAГ:cuwb[<L3_Y&G4.Ibޤc?g8a_2g0%Qvܟ 99o7r,[ o>鑟x`S$V =>;ihcՆ}um|{ׂyXׁ|R#^:hg?ܥO9м
+-pjf|ޱg97hK+@Vbn%?>TR|FodV}%f\^ ?Omxx^U_;0z(w>F۪ ר M識&]t+b-@p}@}5Q|_h0
+/Lt
+F%?ob
+ӆ//LRͥ+7$mHxyA8>UXs"tz-eh+_/Pz+-l7oqΣ. Z*(?P/zׅ]>Q6ufSw։!Lk#o\oI1O6 ɴ}C'2e gS$ iB~u*JN% )O˓;HR)}s))]Yľ epʔ,94B
+{ >U"Ydy&dz{ ?=|Sz?O:O&xV$GΎ2 $y
+iӕz<_,mȓI9 b%[F=^jEFOuk$7Iޗ:+2<R=A2:!q鿄2V].HTHO|p&R՟Q._X-)!#I*Z.,Ej5I3.]ܦu=?#o3n%=@vܳksVgUS}V+w-e8O{]V8-כ [ ʖO#36"N}~u:qY_gĿpMF ׳e&`Yn _lwW+8]ۤ૳
+{޹"ǫylg&X<s { խ^hV "Y+! $!@ zqD`ȚBkش*Y z/bQa߉w3MH?]i-R)#GF-"N]}zg/b@NqgSnl*pB(13a7u/luFGgz@  վ-ޣfܱa[ pu͘鱆4A: Fm=
+9,I"%%ż&żώsɌCN9'z%]dx8]4OI[妿]|
+e%?R D$ P쯯'!Yk5k}E^oB[Vm#c4oꗕ`قz8\j^6CWCK'(jCҺ<Q8Y{+AOVCC)]Fc
+Thf՘
+{#LIw {
+7C_#omQ3M\d^rf]i`f2S~DN0/Jáp wi0
+ϝ{ aoO*C?T-R*E Le0cR<FQr߸2gH%Y<,n7Q@N0kusl0X?ls@'9ws LX<
+6:fl
+̳,V"ꢍ4n\g:6ژe~SprK \)28g<?H*`>gg=Bc=΄ wD U5Fo_e
+#RS,l%Z
+xRA Ӂչ
+#=kĞ q|)>z.3I zI qv v8UC3 V$,_}KdOP IDwibSm5D-Kd8hVBF`yRf}œ_ckw6~
+QULUD"?⟽墷WNG䛣shs;MB|_^u
+lPjNGҞ3|}%{7.`6n!sro'^Iߛ\_p_7yvTts?z
+K[
+{Ų"`L ϚJgJ5N{$ mDkIzњ(Uh]$mƫ4ǹbx\]{FSy 7^8xN#umõZݡ ڃ &UGNDC,BS>r_MHN`z'l|=m:ěާ~`3=.jf&w*3aΏbt!h8dU͘DNo!<C{=o;ڙ8ɝ٧ONP_xos!|oSi-2X|W|XQLA/ V Q^]b(:_^S!SNH/*R4 e@%6R:)Q_#hh_xtGe:zSf,o4߯׋~rJ+*3^Yd:ё?UOTk] dҞWU5JFJUUvh5g :Y,'8^{bۑ3kăL&Q)*;EwO G{;R+"7)˻ /xrs1 Ƣo.sEG,^*8BmPA+&<pgX:I9EJX'/4*-נ7hUVOm ~Ł=
+|g^d.5%T'E^M'#9bO
+59~ªӵ.UbXoW?cښ[OF ^ysqjNcmz|_X] j&*lh
+>bXA ~ dck4!#1"# {I!cx? XGl1[؇s |`"wkA~!w"]A;r'1 8cl7OXI5$qC$5dudŊ5h5ъvw=9ȸ
+}eH-x"dy;>5XX' 3 daA?eeԕhժVTE,2" kXBdi"ʾ%S쉄-J+EGvfs&ロookw br_Q=adžu{/_#T'1>AOWC
+_kIs:ȉ؁pbށ5gc9
+ICYL^ X\O_iFDopQbB383-h ,n}rXED6eeu"ס5t05?蝭8$qQ{O'c5&Ha؋g Iv'j蔻\
+kՇ rivac !2^OZ#\a#f}Wn27׹.ˡ6˩.Hpn:3jϣk> :\6l]1`[Co8q7$hΏ]sÞ!^4A$SkSBЮeFVgղFfksP/{ edOy/Lp^t ^߄qAbUxB'<$O0I6Ν"pAb~%1b*iL*yhYܛ0i@[=ZN5ËY<_~ܿBČ4)y4a!^:xx"Kɑ 钎̙MY~T^ٟ?qMxq?YΜ.ҳpLi"S-fIix.H{*I-Y:U6M6Y}}L7SEMsl~:瓹%yRGm~#?QT&\祉܈҅v}=rP=
+߯*QvwK:9ԅ oo0d=@1gdOşb֓R<˙ŚYy_fiTYeYs;Zs 1s-˞,~`<#Gn%-m)K:ZAW O7] w5_*Z,Rd=/xQҙDz\ʞ{ȑݓ)+ne[Q-TVj:5reFQjʺDjK}M{u$r%k\9] J^Y=RDnBU4Ԫ(6ܬ,F{.jQ q,vK[pOPQfdF$,)s0GʕBҤ @/PմQ(PTT +4qMSCT7{t1"^ 8o7PR
+[
+Jp ߀:B=F B_<Br=p?;`?}?>qP? Wv">z~:
+
+[!㻀\xg'Sm }@l3[> nؚ[᜛ l8?_<7ˋ;΍E{.O{Ȣ >_Ï?͏>˜ h>1}C1_<3-2jk;n[mP
+DNQp\BHA"7!"((
+"FĐA *Gudv3|}j9UCn`&<npzԆθ+B?bnLT!Hy]>ܾUQ!TsSe녟<j5w*ޔ7+TEN<t=b̽,lt_9)ru\aR* R]<'NPaW>h{)Sa( t^ =3)f(EGSyo
+m]
+}9
+Ӷ6!&"He*O+/^ҋRxFMbLA
+P6(7|~#YxY1<IshKGzZ{pθ~ }/EU(]3Eʴv,wu-IK l$F(_vրmk@*#PN{Yo
+j֎uOj-Q3"콷,OS8f_[ES|GNx8i$25o̷DVHb`? 3,8悅.!ΑB P
+^ v.2}g
+F]9ݴChl^y%ӡ4T,uz6Qm?_=x5{2A?E" (*NdGH#|
+TY$UΝ
+P򦃕`5cE±ړxD?Mz,֥lC62.`/"ꓧs 3UIS0ϒaqN֝|Ɀ 'TwL^)$Dχjf'>kU6{kfWyfޭYXf;m_gE@8oo7yGivӇ}#911EGy-O "S1$>CgEFt|SoxF]^]=<FhGqamVO F|)cqg..nctez[2Ks.W)rR̉R PBSЬwsTMك5YMC F*tYeړh&O6SM}Mh3I4tm2U+LA5UA+t8nXZ9|꿨ͫw;ن"xH6u=ShϚjsrmIgWs3=JrrLU S1~^CD.qT=I쯨BKQԀi%jKE| ƪn[, K
+'Sq'ٿeR4cn#څy7- !&e>Ufi
+cX);a=
+ciOPLݝ3a)
+&k({-vWBJkĢ qnF
+߇V
+fq@) V^(ESa±Q
++8p_l/bO8
+xKsgS&W牚
+xWNn8 d?:e%}vLvٛpʬϻ|&<dI_H_;.ou!sR5HV*¬EUq[~5Y6  Uyv/9N
+!F
+[/y͒'FDb}c:T- Cܔ{@|b6{qY^-n⿎h}Gp^TqI5SdV񟇪/QOFhT`ޒ$)yJ}j2mUQ@b *=ee2Uki]4}=|䏨>$†pP~JVg,u5\] r]-:VΥsDը:GZ*r
+;'_v*^dץYpcQ1ݢY?\OD3Rݕ="sC]i OOMmOk;,geyϖUۻZ–.R&",$ĹκRA$^#jl(q ݔۘynIq]dxfWZ~o=mٵ<
+\tu #dpC^~t88yN
+C htҋ a?~5 
+Հ~ b-Яddd軜撩겝G<xMj>4 +!ev+5kF!l!˰NvN(!g4$~)7Z&8pX"HV!#j9uDiYNiɔ^`qkMg`]փ!["CX'-z+p~z
+dZVF޲@T?^玣LmЯ̲j]_?@8@C[?I̒8C?"^6pDuߜj#VG<uU|` {y'jfRn?U7?olYwvى?]sS(5N=uL+ K/ ȼ>*zeЪSS? >E0_⹗Ŏ$ْM5|Y
+RM0I7Tuwo# <^xeK7\,-6>t{t,L?E!cYͳu+6!oߖ]#$}d\敚`z Z$*0`Wk ]%8IzAN0apMk%OѺ5_' Z;2K};B} e"Gw)BsdCv;}SH 쳑3I`o{vYXcwccOJ؃.`F0O o/= 3~Ka]_lEuGOz r ym-i⾢7B빋-k}[rUE)y`&"!J\&@M&ib8֨5xA@9D@C $$;
+ 8Լaf^n47%mve6rsS&B<U|E1g%̧Q2t (E0v&L'cDqS49)[^H'H"bG;A,Ks  w 4.\.9`_A/ġ]//= l.}]b*o$7l֗,6BJ[8/JH u!g· iB1s,d.G;
+Ѻ* ^v^CҞVr?W{N極PP?"L~qKkuj3K^P/:]ڇإx m>UOY(i(9e-DI9M/N|ܒ<G>/O{VҚ1Sy*cD6QIW% rTXU$Mq$,u e>%M`sH9ӈgʕ
+%I"1s+w5s3U)SOnKzY27֤[u;O%/B߭.Vwj:ŝYaOMR-kւ2Vs
+7$YW4.6&I<isd5ʬ:z, mԯNI~we Ex<g$Y<[ʚأ4aSxm<sH{WZZ'/eeRL*X_Tҥ)1'whz ,VՊrܓ*$|i(,cIK荹U ]7hmƿ1}SG;qrq9< c@> g?с3ݝl:'|:n=
+_}e_בؠK\P
+#^{EZCys:y[}Բ 0cSGG~6+֕K𷯎.4)#3狘uE12Bl!ٲ*<Sy4}O#̒h-;Jz֒=8Sز|1;ar>{xF~&T2U
+oWɟ=QA`W$q36a!yo
+K-`C9
+v,ѐ{t׵Η Pxg>obiZn }K%k韷* þ,l̑*s4p=/
+ӻ6=Bz7uM;wjUz{)= Oх=#%Lױ?Ҧֳ,mx&q$V8[.!C5{ǬLDMb&DWI´OOtg3;{YD53Z)cݦ˒T`aM0%NHs(=mgUy헿_{:*6]h3o<8zLH5x,ʣ;reIcdV]UJJթzX[.l)󛯫>'wJC)w8G$.a<O 'jᓊ*#=W+ʼ_W B.gFu2#3$7.de=T)+Aa~O$P&W8|QVxD'$*02<WOO4'nV]4\i9#:^"9^s76;&;Y/f !#yExf5ڰm
+Z a;z_h6Ca#ͿA| v
+LZ#ؠvt7 ߅.ws{1&ߞ^=氻k:8u8Nจ `="
+"uL/SlsAھl<ؾ@3X9FS2 k8w0#SܣLKcs̶1T^ Caj1uBң;fhcs۸xHqBk0`e\LDwp
+-c#͌k'k
+?7^7.
+<#E)#>%
+[ b6ZJ܌~'d=>v؞")"d;[_jfa6 w
+& Z 8#h0h|`H7Wor{J=
+y#:w%sΥ>XA^"|-Z5l5tMvpզ<͙ȶ5 p.2EЕ7r]
+%KGZ~\sWb.諻35_ϒ[>ULjەEg^@- frA5@E#6F<@}Fc55kOU( @_oݙ1hSQ_QtiS4=['|åQ^BInw5A⾜+YCټj\^mNRKWNz ~&(`
+MsJ`?8,Z%&Cbް]:wd#5q?@]ůt $
+ C%6%Jj$}uIExUhU V`Z3F,<?-x”*0<E.RegY-Yͱ[ aڈP|;c)-| 73z62zØDysڣ.tƩ>2a_<n[4aS<}RJshbo|ZX5#YHW)JP5kBCG* ^\
+D涜޻C_2Eb3#WXDYΥ1u-L]ERu;!:P_;M秡|Z(:gY稅\4T[U&}E+r9αڹamK0T -$"A[ƴ|4t 2P0(~)"W .=ɹ?!kPZҍ4J+n M4 f*%yjI/ꔁd<GJ2pSG ES.kESYZѳ uo2OfR& էTvk-P4"쯺zS?vzR2d)D3i'5*i" ~
+:<__%(
+gfu A"Y棇 ɖ&-j#)"MA38j Cʲ4[E˨E;8=='ar!Jt.g;|.l žJZB 6ӑU)ReVJQ1^j.H oL'ٿ?k鶑o,Z2jhp{ Gʼ+ʑ)^`.(aO ԋj
+OvhX]|?WZUՒN -9!na+x_$꓉zPȗMz0q'Q,|BHM7]!AԀ
+9p+
+endstream endobj 28 0 obj <</Length 58036/Filter[/FlateDecode]>>stream
+H< TWo*R6i2A', "*QY"`mę2ֱufz\+Ȓaww{)z۟5wdh*=.R]S(e$Aamc4bdKlLs)m!1U%kLAI.א4Jl~r븓eMy>00$群ߤGȊrZ0NG|rZ;,;I)gvUzJ;aZMnՐq^&ziQfMbRV2mUĬWKB?3.άͲJo֖J[w6Be[ʪL=-s.&ybyֱ qO4.?SP^1>#L F`50kX@a@_It PӢ4Lh
+yyR]qN"%FstKoi i KWCPu>R4^'Yt1#y.#׆tS,e:`
+kP{oEe3?.N>%I/_
+f, ~\'R*7n#WФf~*sf|X=aIǿ0bwgd~%3]:E?oҫ٪Zk+<gtK7)p{iJ-Zul{bpSF%FU~1ٰn gH}-5#$6-;zjE.4N{M|UkVXe-%h!E A.RV!Z5j,Yۧ?zyX}/3Ro&.D*IŪcȟP`-JJnơ`,K0l8#%ߛiT3|`?=:8J)Eߞy.F#>J'h x ?ە$UXw
+%ICtjW;ג(ac*EIߝ]( #(%=Jt*IL (HVɆv|<R UzWBJ{5=8ļ4ƾ,VٜkK氷v2ʹ!
+][1.ǭ;G};ӿ}{@=hcȝc GP8n C~ : K}<Fq(?GCR7aO,D^^ò'p(䬑K 43%ӈD0 <dwq.@VZ7KжM}!hs_^}nT}mr¸,Q%ӶEzhIhkۉoC
+(DA =>ah)QD0iBeCqa("Rb}' hhO q`}aǷu> u11!
+V
+KX[5
+=1n 0½n2cnSF4r<'tKVxV;;7V'oRGYn#jcj{Vv(屺m\C~OsS{_
+^Tm$*Yʥ?L絋qT@{=sdl¡A0kq2LiqpF@X նtet\ט4ΤsD Sf7wُؕeܢ1naXcNiUly1S{/{FiK?fEmjPERfׁ J}.\U˟28"lQ'>l㡳 Yy$J09xg-߳rNQc
+qM5J
+,X#6r .a#6"n 2zEcEC.cE.J"ys\^߄Aykf*V6Ϛ4*W̛BU$k1%LN#/&} :A:U~)vRϷ{*.Sl5F>=g]l=(4*v]D~DЖ'G^:OT8Nk:^T`;"}DfѦGίtHP>W԰~ׯK5:;eD\-O5؎-i;9kz(Qk:aY?nSg[؎Ƶ} j, =Num #lq V ~ĪZ2Zl`"gR z>^M{#NW"$w>}фww'B!vn#IIP&)zTӕ;oTf f f((Ĥ'MM9JR@5+$YCC 3YJFr:'K#b8I"=Ⱦ{򭄟 9_@pړTOF~%!_d"~0H$}K.URs֦]ӢԹ)pi_m+%9ֈ-3vMD)D3"hR rቬ?$ _:I(REDaE&AHPx蹊"RD@uUЛ
+tPW+ɺ{ka)sw%̟3373$.S%qĿ-v
+ٟ>DhRδ`%ێ3XM2XNѓ'v]@2$cTZc(O$%p;IVԢģ,WƓM$/$jxL宑5e;*J%~<* &FvӄvZNңSZLC!uXΌzcP̧I_k@ߜaeQ+k;%MjhCy0Ț٠烼rĐ"aȲȲa9ȵ|恬KĽf CB8ra3*KEaW [ MBLB۲M"ZD]c+!g= si>-E4E3jI5G׆Ώx樃,"[ Ƈ6-u
+ ^1uNc?7n*򂖬[EMO]K7FZ);d۸T2[^ѬꓦsUǭ(>Z)&*eS6)S뷓5Pm#_Z;9zU{oHgUuyI#{V? H
+)H[DgCҜԧC)O$vگpNxY Ghi?† eSe8 [ "7'odqLbܪݥ߻JBU#}Y
+XMZRcKx)pÒ-\oPKuy5
+%ؔ˧lJ#'p8 աGww.8km&,nNv`e/ |!2\ pv
+6Ѥ\fSہڅ %%8ܙRڬ$OlNHݦIϜ՟5?3zHѢmtĞ$m*WH0
+t
+IpcQ^NBO!T>]$Nc*RyZ"K6\N6L䱓hkxұ=b*i|Ȣ?r$K1jnR*!y4qQ)񠘽WL{#
+] ӉH@`4 Dı;;S!ī'x0(NqJ4HȺvv
+I3/^)}p_Б;׷-݈<jA`/#-P(xoC%M<p;32ޯ+syfq 9ڭOnA]f҅>}k7"fL19ĨfAJ7Rه?~qlfx5nZAMs9B{/#9{jމkK8;i
+G*
+v9<R4n̾8h.ﰨ5.MJpҋ
+jQQ1RH.>@LFs5GFz-7k|gg=gZenc^Thtl1:0o+I Q;B pMq]@X0v%B p#t !AE^G"$&Ȑe#!jhum{Uрq"WX=3s-OH$IFpaߺ|uI`92)Ҕz0sJ
+fg%MV$5`v]} ~{v]";ZN4v:zWe^t|0L-Q&2)_0^Aoj,*ǵqg=t9Qk>{q?T+zSh+g(fre=αy)}msoV-v(;6;yʷfW;lvy|?1<sOeգǥ%%G\X~;y棬̯L]snuCΛo3epyN2*V76glg[B`p.<QAg{/_ulxΫ;KGeyUV5
+W5'vppo^g4H:7:c?ʻ#{IzwTŴKDmDEBl h߂iEGy;ryVJ؞ [ :l،\3#VE jC/5nA]4ƀ\ ł!A֔
+] {]eQ'vi ]z@K%A Gű&B|c}sa;/;qW-C،>cH r?I>
+3_qxA]ƻ O}ރy~۔?
+B !hPGh=KeDD"kV=K$w4''{{[nXlϢf%nY<vgׄՑh:cCsyX?Fvs> oPd@S1T
+Ձ `dg*.mMГ^e,-uN aM'P^<$ VNIS.l9T|Ja2\,+)ϧ|Mؿ1?e
+Ӈy {k(SN;i|6n\3[
+._(V$.Kl]9%cUcWۃ {C͍4UT ޵6j'+ʻa}{ZזR̈%Y~E 3i#?6{}uKCЭ
+)t>v{7/8Sl(h,vFmgQ0k\gvb3uy(CoYйݟ<B(gNte`.l##3W^W8zpe/x>ɕ=(E`6&f`H:GҐ7HL=LQ<<f s߾(< } A!Vcx=4E1 T# 7kSLE}M>nJ1OA ӻ[¸A;Jg:t{B ]LCTW!L}TGi+$= gr@}* qq }Oȍ>ǕF_&*їxݿy5.&|dxA#yDDyy,)P:R\t$dtW"o -MЫ]ڥì:%gmMJ*^̾h[!.FyB4+Fv?滃{<hYd E}h]3jhBt9s89jS1:Cj1s!U=Jm4m~wtyojQ9bʸ4mJ;p3nOv
+Vz&s>1yje[ȸ%h6JGP^ZJ/ov˷
+=b_b.HΰN9g1\p&<segIViIKԟ%;˝lT+9h>r\!ߕ ́1:fBմ3@!\TS]+.IJn ),TX}՞s -ae jK%'>ѓ[(:@Ƃ+M6Z3Z%% &'Q6Γ0W0VِqM/%+'7Q}
+ZT}LÚ:8<$eS@@UQdUd_!!$@P"A(HA \EE@`K
+2>;)3(abC"gkض-5%ᨚYw$^[.f&"Vec[S_Ɩ>햑<,w?;k0s-ٟy?Ǡ#;~9&`1A;bVp8'K~SH[r
++9cZJچv,S(
+cX}lRײb0Euܶ) UE@YC PJJ=+j=;
+*>La~Qs)hOBVK)dPls=h)|fuSIWQ:Iwk吶x:Q9g:B a^/N^oֶC!xzDGWnޛ1IF=޿ezo°mAI7mc[޳؝+]kW45؋u{ʶ-%o؜5'"r6G4*cU^g$2[e4 4A(s2;cS8}=y<sQCU/5{#$}au
+k' r6m-Ľ؃p~\""
+w:rS}8#Q棐u;_4.mI Kpe , 'xx1qRs*(6
+!]4 ;<zXYbKYx[%j݈wclփufk-vCŽ?xy(QSхegb_P4i9JjI5sʤ1ax>Syw:RsvVDE-o
+vdBk{mvHص/ ج<Y+o/|ȸuE=z#FӯϿq54|4ldN~jaY߄Y=b=$Yb/0~.YzoC:qwԾޤO/;Bb&ص :':4}c얭udy셝dَ[fnazM$bav1PƬcF5Fc_
+%Z?SԈ`_b(l@N w| kC@lmy]8K;RC11WؽW?H
+؟?Ye
+EC%:1CP0x
+,iÙRm6R7P!8g]&sɕj[ f%hD HNeU'U15S9%W=MNĻ(C'Bdؗ %5޸589;l?;*+o
+%C*ME)Rd((CФ5( AłQ#JQ]`PAV)vW[zbYDP@ǃ;y.@D1Ncw1i>tB9e".胴
+L2C⏞ [AZ;
+Yޥ
+:6.kSoBnF ZTo2;zw뼠'g r ¯HʫfwCw~WY֥5]$`ۛamCY•[B+4ݓal.L\:QQa;I*ޯ'> 5h' gv}8158Y3+ ]Az54 ugW/ |q k_rMs0 ohXX S= ^XQ,3R+gHq
+!t ˗Za-K̋'0Ī {@?ߨ^ӿ$߯CtMuE].;=(r~Y:]62k|F%]a^MKDždF@axL4n\ϨqQBQQ1CcV#Ú.COzeT6-G/NJÌ\r'j Uӯݟsx^(|gtR4dR34D̨nC~bәe!q`ut>$֥,KCF<u piy{ ^V^ՋY6J>.jS6O5EGѭ sJg1/aL.}$~) s?Ϯ}<^8hZ4zlXA#2AJ7բaZ_`{ឧEUD$ݩi]i#NKQzOLkI=L$gWգ5qkcVNȓId[2ILQ\LQt;DB&qKڈ_E<k%s ҖDqMtZv3}q9S&piy v0t\+owy$]J\pĝDt!iL$Jc7kH jE"&R&bZÉ=u !4`boBjFt78 d~K
+( u=#Ʋn==ETT8롼:zޛox7Q':dY p4|w(M"9)Pģ Vn&m_c'2Kw_,>_>/|(ϋ,:fͱOiezqEX}& FOxMx- hSEzދ >=,4"cGo PCbWX h\.9rh Jbdlp5yhv\_z׫
+dY\o<|_2uUTҟ?.~||>6#h@ 1tꀸM[;h_Nr@< h ޟ`IMT?\ߨ.c7$s \:Yyڡ
+r'}qDMΡ[X`S
+4$;*=^r:fڥ=q&=ev[sֻ}rYpv_rFP&쮷]_2.n=HoM3;Z?t G̩=YZv=|>m66bƶcJWi<) W?ע*؜Bb6φU& LNnx:u2*}|CĪOԆ´Y5+im}?|oc^N{Ct -%eDOdWF+taN=LCUŮ)-N/05;2gQ%V0uNLnxvFQ])QCQZ >E(8pb:90̇zTʏZ٧.
+w6C< `?u?p^}u2o``M
++Hl3lİ{&dr# ,2Z.\w!
+aj[SeOϡ.h'%$ɏ6Qmҝ1;y"7Ӯq.oOɸ}!]?YiOՑ65!Qh&8 &Άv'I6n$Is&ߙ@:ҭwF? /qDCG&bgs, Ќ/ⵝ p8kh&Xľ_N낉EC(k ΝBqo (p28.lZ*V@bT>NGSR_ "~RgL 43&1):)a13c8${9*GR*
+qVssJۺZ]0Yo݄>7+~rz)m+:vkǠxJfW^EN#KBꐔ,DA=L ! NSb2VD,݀ZDd
+gM vȎދF浿vo+lҬivc[U8у~7D>76U;y t] CթU~("wCt Gª[&xmR>qc62?= ]3~!jz j\Aq̠ZfLHNR%ֱ೗
+r
+=
+} w )1*V)lL29yj 'R>զ~L8:&e8xWǶp:}bu]mM%ҜҬ~yNvlGҬ^  <˖6
+pt‚B0Tz@7ḩ k9 @ٽ9M]pv?tR _ ~ Lûˍf`^9JUӍ6~bWc&o2A} EPtk+M-:ϬF*%nf 8 ?a}[IPe*;N^ ˃R2Xb.QM[O[Q.pZNlɉq9 2bM9#"uiG'~Vmf+˭_{sv!Hg*^QLHIn FwxEiR4"XVV7G5,gS&R_;)ht@0aDAɊQ<LAFҧ8'Xg%OiQb_2/]#Z;aVN`pq5Dn>| .qIa=R ʐ96isYjzf
+3StЮ^4hY15^95}j#7 x6:oT# |7A:iۂ;I󨦎=࿛e>ĊOEPed ᆄͰ*;UQPADDEE\X+. &H(>(պcɼ߄ǜ{o;N%IkU/ҕiӕ验 #[{3fk?^Z5ۚYv184|g=ZL{䏒ϡݫTq}+ImʕRHu<H\"W{ٽ}x"ČѕHiP$Ic24$z}m#p>ioGwE3W+ˣ;zEcpt؟ ^y"8>Q}#ȢHފf…Hz&8G1dO">Y,#6ФgdV#6ش/#q<̦Z=?S_>MbĪŏX*|E"$,)9lN\}v)vik`2:3صcA[;%I EĜڿJH& UIUBCļ^BN`;k:X"bQ+Z~v:X6` ,;1D]$Y!#n44K5*&70sog/7FSġ0̮ !3c>#{|Ʉ~d6?vw؝*y*~Byj<WUbg.Go!@/u?LM c6[W5)78bؑJ!>S⺴?e<]~8㖬&[O
+Dd|=JW'\ց^ܷ\Ԃl ib1/6ﻤ,_ԁ{%>_.Eb}u%`v2p} `:< s
+n M1xhYCfC}seʡ<|ƶ&LVmc0"btؖJ0v]7&|O8#^:z\=xY^VWb좐Mb] + CzD؁ȵ$n= Jp%\[ֳY% rT|e9W5gDŸYC īΉ4Sm;ف|^؉#X0}Cǀ+7Ac/y4^ݡxSsv${\5&br?8MؘqM&e7bzW:`X~lP6lT MOmKGaPMQĬMnh2vNy0&'`=ػvJpVKt}HӉc[jDxE76ـc;Q-tu-`]VӉza\
+0>8?ҫ?50Ba}(,Ffh=DQC(bB3D7Q؈# >  "n> ó > $P2?Eb-=Lu˪OoА[KKB.Og!TdAKN?^9wA6#@ТPn-*-d=n
+n"V
+roh!v .ûy< <y\c" S$ ?Zcc;Zxm((k)O]_
+[nZ *~:9(FrEZV?)K[hTXS=8Fצ#miF-VwB #yٸ}#Y t5q""@]4"(H $FqYEFEC x@
+!Q_L썑Wa<|ےLsIa`esv( j<\X0uŗY‹+Ko)j_il^"oK' c֑U<!A%BKaYnZ"9(i
+CKN7\/
+#}3L遴Eغ0- T"~#ܠ+q'72'_k_(__W?z
+kz83NZ;V#Z9 +MWvg.d^@ҙaZݙfJH5iIZRZ^AR: 9< Ny'5|Ae\)-m(=mN"iY!ͩ8^ ~!KJQ=_bE`ĎeX<_jR>+Xm
+o No,{,ґqlxg.*!? M%9 s^'o$,ƾ 9([js8!
+{4E64O1acL
+O(&!t
+]'6l.mtW,n-qvzK$;AVddMV(h],_/cy p\iIE/xGkW-FCJxiշo[p
+ަQ߼&܁즢mLf\͛ܪ,ʤܠ] ϳ~8Z[-J }Og䱿r<c»&Y7ya= W)rҋOt&snRԴyc<\&&v56r>lNEÊvY%wUSG3n/ij[{JKؒ
+f`{
+3P Jt%0z9|V⥽˳rSyַ62ϔB镝,ZC\5%>n=k}}"E>{Vu+lM#Rt)]"#IQ~Ic s.l2#"3"#$tPVDOB߱]R?y?U &V4"ֵN>Z%uNw;):FI
+zlR#
+\*| +7bpg׆U/d}:>yJY[3 _LJg 1ZP.2i~֬>7iVm,*
+Q(kM:4J$/*\N$=sKz٘ƖyxXOyܺ&v91Ru4U)[~CzE#!_þ7>2; FC sG׸5S*Jk[W,g֪6jޤ}
+LCØTA<== _ߖ IӜ</.!+U !k2؀}Y/Łyټ{4\kSUo]֝Ϭk~uFb
+!c[>?eĵI
+BYDJle3&,I@6+HP^eE6"XzVn>JѲȖ`?s&gfsd3KIF8 ^r/L
+: X' %sr`21> ]R
+=.4#urʰE 6TE %]M܆rp}uUU̢&DfY" F[-zDM*yYwʰNsrk23Rce3j%.j^tMjeO6Q9S™7-L(.}Zř[[ŝ3`@zϮ2x9UϞ_>V.avTaHi|;[譠?p7PP鶰"+;\QȾVgUwFӦifǃ["eYSSQc6ɷ4 Lº>XfE9Vi 1_eUMa$3TRR,7;:Qc
+c2QJjf_;n_6t{=2tCm\^}e6# G#hDR<br=Q'MR$)nPNRbh0N"¥q2@, *̓]{pƾ7N^˂z-K^"d9q4/Ѱ"G!j@t})@bApc@ /?|l[@ nnVd689t2]:
+$
+C("Uf@TX NqGFfEl"&9]gss͹wƏ:#µ#ɣG-PѯK zq裃mnɃW2x"{h̷>*J7:sA. r
+vsP/~, ~d#}Eͣﰶ2RMo1ʳR6sjj>gL9|unL|8k*c*5m^뮩dMK;_~~!w`YKP1W 9YM٣K*""_ԋ!+/D IFs<^32x+:v!mvMLRC,5S(5αPN퓏͊Oey<⣾ˊfj$uQg")SwI>!>vd\ypG;3Xegu`=Y)7uض fS glefDpa!c9A~zD$\wvQ!oR^`n2٥t+\nh #cK nſG^@S/ϳ"|&a!
+ r~c<r)R-KXxFA0 &̗逹[~A7>rVf7ITs=
+<sx^ sV
+>mkbie6 mЇ+igtJJfCC{ Œ /Ȣl-Gy~!vKDRSa9ˆYYSD/3\$H4PrJlCT0{< +<疗{rV1Vw\F;|YQI~av\3CcGx'x\:RrO]gRwŮt6O;Oi;L"Ϫ;}X|){QkC$ȯ( @3DF6фnM6MpRQ.ͩozzȶOȦTN%ǽy{gFyC.lܤ4dƤ2HUtm/1_8ot>v9)o%l.ibL13-Y,[>S>yWS6Wx/ɗ 빣1z޴eיeM5-ȞĴ)ضGkqy;$^K%\BTLj΄O]-ҔdIBzR8I
+±mbo[,=^Bn$$f, EGo"P OyQD߅.NܰxArO$I<~& Dp98ֆP9+"ա"bQKl\ %Mȥ"bK9@lC1EĤ8}2-WɌ5AR UBɆ
+?y_/=t߹1C$(mr(a`"ڃEL%%Zұ8Vݳ^m{괫rIRfx7}=z~3>7 Խmĵ#B\(-'
+~CA<z"wO ߌ"")/C!@ZJxd햜p=
+]/t`b׆<H7`ږfbC9@;zԳGdjUxO,8Y|:XZܝkeġ> &8R>T gd =՘ CB;d
+t"Għ}+n!_!uY׈O5#8ʈUt\{^JV9YQ +Y*Ԧ'6*BRژ:.s #:6lήUJљ(rT㔈b59[0I $>f58-v:kҌDz{{OUeBMaÒԆ^-Նt0 666΃ZShq=A߲A֥kl,Ȼ L 2
+kr")>눼`;4
+yY{1c]._|
+8qenbdjcMf{}K\򵜩▣O˛  ^{]r%t[pQKΛ SI|^9Azvcm󼣕O? xd XZ=b{nZ\>P9.?+cb}2GePO&צĝˀnY?C{;Ys̃QJVS}71=Vd<O/~gX{Z4crF~%5~%Ubrʢ"PmYZrN4cv֗,* ŲSv<[:.p/ˤ)f s<Ȱ60+%8bn4ҧ> 455LOG`G
+
+^
+2z9s1)s *=.@/"Sda7sG?sBf+amW#+ѝhV,Kb? )~U?ApO<6:pq/~<*d!{M 2j.
+
+p+;H İdF{[lq)(: fΰZu:S=v*ZD"o |/ng7
+<E-. dRU:kN oMeH&$o%%-^D #wK.\{dd"{t'dٖDr E%>H$OLXn!IDwhO$I$>U& *kq{M qn~GmbKD&2|m q.$e"p)Va_.R8^)*
+hsӾ%z|-S38k7Pw#]QĹ[@<VN, Go!0
+h,
+@ >(|^wV"FM=,!xF-90?[N$C֋OctDh<`j?ޫ;d[dNV+wB:F4_Ѡ9ķ9 5?I*09Yy>#k][D7™j\ دԞQ%a"gC=9P;^׃U*^Phvw\b²%ʏL}"?639oj쏬3M'fsn徸ܕ=ߙ󮀺y猟i?1u\vu2<JU.(w.8Unˉ/GJZr.+>[,Ϟ>g'd)$YLiܾ){_3@(Gs
+Cf6rg-]kDJ˜N?2}ؤ&k4&k$&E:w)5G'od̉y[n<L Wާ3F}I'=;WK+Χ6> %˚EĠht{jEM
+L/~74e^<k^̞|6|ï'93O+>ȋXؔUn+/[Iz紿p'sVdޜj[Eb?0
+8
+VDQ),*(J]}W;8:uvD(
+(?ޓr='{~+WG{qK?/{G౔zNNO7&EDBzYlS+iW綻xڪPZK RLRZ$C?"=A?q^/޵٢+?B8lrgc7$L'qfJn
+2j5dZ$3kʤ\k 4E~vs=T \ޮ;i_R/(e,(9>s1+#!B pyțr
+w _ZŝXrю*EDžQK~V|-{k,*|a^Џ2
+[u'D`7'%8xWrp\Z-u%x*e-z<nWN<Zy݆ J*0;eA!6w[a9{q>mЗPӉ߉Bwr`wu5/ky| |]
+ML'Fs2%߁G{{V8t]= ؑDFKUf:8?plX^ZqxRjek&2ڛƾpn[V>aHH i$t [셮ߒha4 >|婄
+>+u^'/Lo77E0 x,7!{țr". ~?SkM1 xrq=;o8 $PI{CգGD]4'^O3'?ٓ쎈M4XwTl>br~̱.,sCX}i_V-S#≍
+#=]_Eݵ"ҁDֿ;d!Qt/!N'"otы;kEg[ZaYds6Xm{Yxqa0pgG9hQ~ {}L9~^r;jvqƦWcQ䧶&j9mzo
+UyUޫιs1eRUHQӡuޜ_'l7Yи೩JYUYsQ2<"هU[z&XQ7_,Q>|xLۢ]teD+ ,cɌI> S}708gWÚ8|ѰTAT@A@DYd ! =H:VlV@%
+Eq>>֩3cuiRD3߉s7{owz2C`\;Zpx&q4{/~^^(yx6u:h6EOwW?<<ڿ,{ƿBvoH;$8 ٷ߀gvYik#_1~]Z7bW0P~}rٗaB9CE6NvW}l>;ǃU615*6BV:  G7t;70-jzY0|88A{/0wR6B}A-AI7E 9c ԡ Ԍ`&r
+|d#N a 6=@ֱϕEuڶ@%znj+BCm߳{07ֈ| 1C=H Pu|I9F{}BУ\ʽ\ֽ\4Q#]>#j2C곦CNCWgOLz׈ڱCpIj4_z|{=}ݹ{-.Ht-Pu\b`oBGE7gY|FD؀R7"> %O$8TR.|k@V)zk6(K.{Nk+i>~*UVqMѺ'SkINvN&9&#4k&h3佬a?YXQΘ9[^=m}}º1j]|h܈mgbe w©.qڹZKQ;wvYSO:<gy*Hmq*dAp06ۿ/F[ d Ii(e16޷y`E_JFhC~1;G#X~XWT$>s(O}UYȪ1j<ЌGG%ܵʹݡO[2pd&~0|Ҁ{D;Vܬ>xLȒOǬOE[QUg giy25_6IoJCbu䰐>.af3z21Oy8ep +m΁"펁"hPA) | BuNg|Bs
+! l&!qP;)•NB@
+&ơOc!>%?(!)fF!
+Q޵*ڳOU&'ة&;ֳ' (l(c*;~}zoG
+/s f޶DN$d8rg6<rccl_ŎE
+>I3$kcI:9h,͘ m2+d,dMXb.-u>qU%9el]G)S iHp811@ɰsXG]%]6A4iD܆sq[i8ɄRq
+ס݀@G Q#[z~T` itJ~XQOyآAsDf; W,u׶ћ-򇿯
+'YF<g)fnI
+5a= 2hs}_vnYǗWGXWDIkAIܼ$DnZ*6
+E7~3^X
+X9`MJ[(4~az0C.U=փZ X5QS*|^% m..XUiuluMڈ_{(^G N ~1Cs)-sz^k?eDHd "KAT T@ %HBB
+"xb;(rjnSr*ީwe| Tqω7ui.$9KlcĤ5a6T~%!퇊,ӧ>T2~EW]b~=Y[<&e
+܍ߡtQ.M
+ ¹ ~dc i:C\t%d:1fNʜ_ոt\F]?e?kp"#nvS<[(1
+[
+ѧVE!mQLDx_/ uJCsHj?C2'&`8TXn Sq%}]nOcc򎯷Q¾npnNpoDB};p BkCyL2]tO{N+01%  K˘+{A5o|a<֠j+<Bמ22* SuʹszXYɋGZ3sK̑^i9-y|Y$S$OVSYEwK1>2тYpƴiרQǟzy>Eo ef-֜SM9%E#g(l.mJ&-?2bÐR$!z&Z{bbIIk#S4dLF6IŌ+i1$2*.9Ã"\`j#fR BK:b[B%mۂ|b2jߴv
+5
+6l}
+w4gn</3?}x~xs0&rl{qJ|v\ukG6DF5o* (YVOԆZU[;80tм _M"2F8[){7*P Rcy~ւ_% MXYEv!ܥK;T!۩tƉnL}NDnr]q6t?U `kt]'eދF律*UĎjE-+涜BY߸ޛ0%ٟ<LU?2#^Ff/:4` wE,,9gF{BYRgRވ.9q>Ղw5j#Funzu)+l6*eҽ 6J5c}i%]i-UȰlk5C[SZFL#%YzMK|C5"%-}3Z+<VZN)̔dR1'/u 5ҝ$IW5ZVޢZm׫|R|B?|V|^i7Z0Q.ُiaNws3kF-KIMA^'Y?n>?a6^B1w#D@ABD?ɑ]$c{3SHNZH>2Sw|)ywgRzgckn'ϧp+y>=qp{!ITdKE]A69_ e5#+~ds1#&D=1DFL!$<BpH Zfۡt !\$KK(D<'GV紣tEfdF1@bocaG,yTY '*K]
+ $!*hkէEYe_(,
+Vڪ}G}7vobܹ3s>iD§ڛ;6EW?qY[o[k4Z }|uEO^@C/ŠĐ.5YVM|XX&1DHkO" Ӳ ?'DՓD.o% ԽPڸ4 QM<#KC8:
+$l*,ЩDPϨ8QBVI1w8QJՊ ~KEXy
+
+bWd:jbe3QG4Yߙ@{lBk Ȫ
+cV
+B)#,C~oKzƑ\e.PrwʘV~PtյIFYZ,jaiG
+y)
+7i5qk&dD'g-a%׋|ܸw(XzCU ӆmA Mh;捃',Wa(gT9&3ȊۦZc׽SqRke9N
+,9`çy<:D
+UR?Zt&kUȪ؇wȎyl~Ɍx>eYkqn=W\Y X#n3!k-ܿ^Կ.\tǶ*2uU?ѣWq7I{-A̍L(׏,0c ǁ/eKtvp;7 ۠w&H'>9@i̊rJMjK"J?R1\qG!b|rFS<dY.P-TLQ`_B෣Gv555ŚiJbzڴ\8T3hV&6^KBm5!m+CvellІra#EnSsgxpf9#}]+n׸>Q^7sR>`vcewFc?uQKN7хi;6c`. 3=MB*v]lEH:]sj+mԱQ6m6yz~y7rڪtV>j';ݥrEOpMOexƹW~Clm llr}̖{v+ U;6TlgNtBo\/Cwfx7<3,xaRrvy9Efe#eD?9ڤ+yi׾7?\,$k3rchNу)_2)7'f4'e4jd:]5]d$c~)i2-y"=E=elo{uK$jSIV;Sdt%}BNJM򃉤)É;?5}KKpHs_U s<񹼅;c&%aձ];'{+xwȆ *xrMDHikV_ &k4)|;sah"F5Ő
+1YZ\+ ){N%B ruPI35<H{Ŧ?\T$|={~\ޛه8C&>cG}Obt'&'FL2Ifա4fb"sTl2ɟ8*
+,m k#,:-AB@PȲ /(*]9j=5$%%|bUML=F ,k}ߴ,]0}dz<kRΨEHn#YWKj)YU!%+N }2N/sGm^;f#b)H Z5 Orؿ0;?5<"+|dQb{f 4o ,AFo4+ A49c4jSEw Ӄy4"ȲB%?Ac@h5C5d7ʬ79 5GF}N;Z @_cMȣ?CW.
+Ux~~Ls[B/k3qB9u x¾eYmron@msM̎RbKjnWcU
+T4EImyaE"%MD&}IlX*SI#gSc㚴q~}CSʠ8ֵüsHw711/aX!H^6IO@y/ v6
+pq聍g:R/7fF,׏HZ0H ^C1~np}nC8kP7ݟ> %vI;~nGM7f:i
+9mx都<7 maZA0ޒ
+_H^+RH=Et1J㘒gr}rC'Jq^C4QxjbTzsGݬy4ǻ6|JˈJ#ǙS3+OA/%rm
+?= {duw
+@™^/|48˞\[ʜ[u9jegި(|mƕRFRmFiN3&hoiĶc ,wǔÊ(RH>eJ)Rlο~LF{BNdBNYwڨk]wWRvP:+&]W<Gu=8T:突>j=ׂ^v9_Y[1ydQGɲ#fhQWhioYϫ2F//%(:ۗ8֝ܽ__HL?ؑ2'q`R,KpT6CԍC=Iz=I i{S3zRd%KINILK|{Sfzg :mDGl,f5Cؿ5zqcEZ(Kxמ`V#n-ځ Z-̯rL8skٟjrl ?Hukvs%᠛;0_ Z"{ClY!H8{\ ځp< ;R8q[$ 5oÌ3[h̔Eaf\)t" Fb̻<`~ގC:vЎ8,áݱXt+]p܃XZ+ñmE(DՆb`-۴\ R`&66MWy؂N-ؕ˫I
+yC#6nD!+b,<-xy Z?mAwHG8}-o "$,F8 SQ*?D5P0_8=
+2EĹ
+ y5PEr
+i9sh (KfH!@"v070d
+xUze_/Xu?xvMmkK3L_i"q\
+B/o8էotsZ_4<z}viQPn\  _kv9iY
+dYKK>fzi
+
+Cͳ >ݠT&d+Ɉ,%#&J48w`ѣp@:h\.Ş1.J{ mr c~`e  @2jȦK!Ux9Vp K^D7a@'<%{8E8̘j
+endstream endobj 29 0 obj <</Length 59176/Filter[/FlateDecode]>>stream
+H$wTgY,EHA.!.[,.MGQz&*XQ+uY-%{0kz7Qr5Vj-99|3;=?|WQ=<>8V=rM^Ǜ+q;4:]%v} Wb7pqޭ˽E;νNSY ӈT99qB+mH獅'~,ڢoҢ>kDյ4\!vδj̢2EcK<*zؕ\Ws]Odjz
+Ԫ7<z(߲ʁ%<Utn_TV_X^oڇKoޖteuHmMѓ<Փ2ӛ:ۛ6ߟ:]02Y04hDОyMf&H:{lw8Utxt9yd)s춘/\E܌+v&p0
+9CH R8QΛkZ[ǚef|GwҼqyZ֌e?Z 7e8zH"/E}("G>~)=;^D"
+(#xU J-ABf)2$Hk@pR9">[%s(i='l*YCȼȹPxEQ(&ŐqPN ae)/Gc HGg}( $Dtm
+A`tQkGnm~ڷѾ]jm&!nl MA$@:>ڝm
+qqO͡>y!bµ"}Uy!&Y~-j0'6)lV9ctY9s'Qb RdhT M徸,\ꇖ-gU5 -h]'Ue\W'j<מ'f]Al8U \q;4-sŅ:Y6#!jI=Dj%藁PzU3: a古/ s]Hkl=7<6Ea5
+T}kx]+{)H!lă7Bч.}* [DF hxrgR"ζ8AuԎL繦1in?0լJkRI=.߱>vR { ҋy`C^
+ 
++b#Ma6kCҕk $s:pa xl
+- ZgW>iizItVa6spQ}/.i\yqߔa֬1>Zy!5c@mXĕG&G|&1oRSr^.?(,ͭ9$.L>,lA*i63o+ޔe?؞9Mw2m"G6Lۙ@:3R﫮̷ŝM 3/l-ޭ玚g/[aʸNM0{oa>IC<r:Ɗ9Gsku#jgl\As5o-jx6hSA
+UM9糥U%Y3ↆ(hIk3%m;-OoH!鵴>]ceObdod)<G3jfjm59Ú0~" X!*0(HŽ"aK]P";"Xh@! aԩ])#Uv*]gx{s}{$e|_M KS*=#'Uq+[G<Ȋ5NJR
+Sظk W"^:Lw3#^ c삠G좀 Ҁ_.5-Lͦ>s7rNԎŗu]o]xm m t27uxX{_af,`aTNf"}{=$5Bfj4~fEVȬ:MN9lvGv);.%M+- ^U &M+̪*ypfS8vkpdOɽNJ}maǍ9?WdN d<095Ƀ}(yIW֋4YS3Ajg(;QaǻK?켐̏߻}6iڴO;.Yכ4@1s5?!"M=VFL95˟7&m'h~:N'u'fqC8fMg_i}lvC*boP܏My~M { v&Q&Qݪ1TU!sxD|j=%$Y5ҞD$fL
+I&r)/@=/D'%Fdd D9B(ֿ$ΰ=b
+YuIE֝LRŵ$j--*8&孫y*skI
+׌Q&֚}%u@N+P
+kPܰ
+$*^oUA-[{<ϙ9̜9gyI9Rni K9
+`"ay 2T+ s<o"q$$wV ;fI{)k9h{!ri8.?;z]%@)9=Qe/gO+K8b"OU+^[NY ucy rFz;\jH=ÁcO%<+pV''xAT4troJ}?Y֙p!e.Ln$dLΘ(&_'H.J3QsƝA  f=^r]5jb]Cdmq8/G2xsYe(mldž/&>x=9/bjEZUnyh<S!xkG x-sa- "?F>4ldTKQgH|~2vW(L9ܨU!VJJMR賲U>X6t,3 eֳ8yګ ek_m7ο%-0ӢLoRxP
+SEj^h\5:M$}w r#el dac+
+W ޒ{6 [8߮"PπZ齒#h:sudBYo,)ll҇j5aOPKR
+6/;ݰ. nЇ;֮QOxeX/bIw<jUOjU>QQeNI^.+Oʕ_˕0&f[[K%Y>EK'b#Igͳ(VCwVvSd~V*`d7$L|z`babaH"ym*Wt4} Zu8my.&J 7QbL B-Ho`NNh7
+|vzk
+ָ1J%NoTʶ]!}ԛ{0I2.Xco7I.`{K<m Ysh0kn }r?QH6Y$wy=wyfA$N~,NN9 [H[L0;q!^{9n1ܾ}a} A$ #ÀŜ 0`۟Q;QǜN qJ3Jc
+E*=P(ߗ-},_0F3_+7'W۹xɯ]->ɾ9zC1onfcFȱGCw#;5]aCr?-}6R/#H_$ Lzh5` GbpW.C#=@^vy/տ#%=Jg$vm ì]ئ%[tENNl. v伶ckrnue<l~Ag
+;TO )qјIs3 > h6uw>eNvc멬'I?kHol[BkTcFeC9^gԷaҗJ+RH&ZיZܡ ۯ/!"nk]yt/7-o
+{C 2%?oMU-
+ʻCsٖrsNޕ8
+<&8}?a7mi7j Za
+߸ppEP{̃~h9aH(Eg
+KCy{Tvkx.}+?y={>$xxW [\:_ ΧC=~.oP78kP'iZ,OTz˴z.!N6_([X/3:$5KWdfŤ
+eԑ<kSǼƘRa&T(ƴH4a+~g%| wLv1;w_ _=iP9c9Sx(,2}ۂƴ7GƏ&O;5RJ+ ZֆNUyv2_r1K<g 7!?\$)># wYװSoGë| *)ӧاcѯs<0W> b&brY3$T$3C_
+'3s>EeEdyLw{42#KЂx(U@Z؊Bt&#ⴾA 1!ȨhG nL',OJLB8'{
+ =r4o-Oi!4t:!4e=Z磽fA `(Xas\^YaФiHjR"6:٠{B~x 7`0zGҐ = AJM }6F;e]|ى|Gw?
+-`edElIߵm3LTS(ɟ+dw6&PرD+Of9.S\-Zf dS6{qΘV~Lpgڠҋ48IŇ\BzJ߿ O eF5/\RMzFҀ r^)HV].+ʴx:o:zu=s<NeJӸơu#ިb7<'B}f-hsb+&nL)yDQG_]i8>S9hs_1?wuDQgi׸mr&=Ѣb'ls<eel\jhѫ:ko(8 >ɟԯ,BϜUYyL+LJ>j9wSjy FN,oM^֒WY= yU뿞Ⱥ_w%ܕ۵td n?j/d<z@gPQW®\JkLz)-n2+a*+iD;%wKwJݭ{f"[Hgӹ[5}Lxvi d 8?/evi-^5\P{L!Du9(j8.IŒk$"lt\ ,]$]$%ƸuRi+sR{svZ[rp~z<~gve=-u&5s(wYiDcՂr/w*f-:DyTΔA32e;X" #?;c _M
+tFweɑ۷nv++]DжD7d%l'~q$@YJy$HPO_'#q$v}b_Jo$Dx}'IO""ҾdԝDvt&N)K׶_tf拘I/JRtc]b`b}Z4gLM;zB:B0q $]|&>h \GWʌ;W:cs\EQ.#fa,F{x|/wkɫQ]NJI%hsFz
+}׸ٛEyjΔQ)R/ZGh+;['&'y-bvF״~[L ktCة]e5 ^R\F&8Pw%D
+die}ݖ{zKo){&M_EIKoٰR@X[i\@6=C&l6W1E|1y>7p_t3.@蝅ܔ`~FbF`Ŏ,8CCu{K4 &>Bx?C*
+
+tk .0"d
+kuV'>TH>.8!8)MZXw$Uf |kӓB L p+|a- ܙg YCq/1ַqwh6iv?2dqOj#Kw ωb mGY Fuy㺥^o\Z5{LΏ%^Sʶ-J$GrCq<3I~-rg*jи!Fr%dB¢$uFۦU_W6HJ<wy<sy͙}_o5GjzRd_~[] ;=%t4ZQYH|7jsGφw0^+]_;Yk84#JW
+rƗ+8z SЗU l_m,Q.)iOUεUʴݐMW)7hf;aPolZ; Kg_U9mRufc#=X~,eKI1A:Im1E5EɲM9N3" zfO""տAy;) I+35N4W.3b,\IYeVir)JÌj!gYSBOdL0q+ъ3BQt^5{T7Fz4s|8cXt@trN0puaOVT F/_\ 2 ;P"N/K_(|ZDḕxiP5(!F\F0ɡكؿWf-Ђ`VUm3iu+[jmن2J(k=jf}·S;6E2$M,PC9+l/ᮮ`  @zGmOdt#nE1`Q,\D#Л0$- ,a$t½bw4툂Ч3u!^E10t,# 1>1
+qx?~,&a4v";9*J^pȻ:\t" $:B
+}B:Dn5Z@0VdRǍ.~og쫏Mm^|sW
+SpSZ!]J-/J*4<)pULu/9JjN
+^BU~2TU=
+쉖~) -8J̽%Bƺ\
+mۜŠtP 1I0'{!!6έo
+e [-L6XɁp@s^Lm84Ɖ^nc0>oa[cβƜe{e#&=#1!&JRJGGP k1
+_s^*o.$vɇTQ*.zAuOK_8}>Q8M•Ѭ],E?0cp*p;[_p[~kzE7-ZtYd%rօDI+Q-X+iP) D
+CJluR3Q9'*5.D}@>\Nel.η8qR.\&nq Q.]#]w8Y <'܃ߕJq8.g1!3IIůlt;dn*E_AјD/l!6>ff*v*Rh"k j;O%41vH،p*x/Ϩ#] O{t(sRR\ׇ
+9.cuU9.z{V_몞<<WWуcWą /=kc9TLoȵ]yw9ݡ{>dYBKU}{_ dgsfvLoN%LwO&L'Otu6/iv8i.~0D?QqnzL]#=e7eVZoZݷ%'z/{b2>┙cZ=*@66dfuŌ+o02+Ō7$[&uL'sZqsi |iF[#=xs8ޗ8?GBEqdl$bX򸆼ߚ@BVhk< lBG/G;I('$7Diҷ>bͳ̞3is;z z^Wf"l#Bz/;És_Gy&^pu5؜ !kkfLʃ5o"]QdCoqwo &6yC
+7_x _k*R!,ŀ(HY# fUAzA $DDzEt"H""HP ϵTPoy<VPgs7s'wLnr|bTAnSjh8kmzZ1^mB) Ě|Ia|!ƈ4r
+0ڢw|yum6/eDOdHOlpOT0eHGgso͋ |l(o0+5bc89
+\Aד:$dL&&mO\BRg uW<i@Έ +ݦJeNNSj|u_l();Ψd4#I_2;R>f̕eQy=}ߖ(\p
+ipV_r48uX<k *\&M!ш=Y=3K Uy|[p쳯 bKqq|NyfC,ֻuFgP& k6b°Km8fKObB%\l5NXk6d
+b02O
+75 _}Gm7Y\gFkGrP'__v2)x! _)VaDCVE0|'\f׽7.;
+yD0B*@fwBHa?BBBH!8Іox* {90  5BG+P~Af}rWRbzOB
+}^}pc:C2MB;VK9ʐ9ȋV ,WNd*F5+jzO6 "z==WdXL*_QO
+HU ,D Zn,qo,s>R *9Qwԋʝ5\v;#8K#EO,lK@:W^X  :ZWSě85XnQgEqq]X e` \7I9A
+6
+W%=K2/lyUŸ|͸Bgv*g?)Y|Q[~RYά;%F.TA"lkG I[ƈtRiRGda"A%ByЀ8kƳ["(bk H3uU6b*v#kW;`bO!Sv):p[1yWHk8m`LgNdV'̟ړ(kmFO7r's6gN ^t^FKi$%O%~LpFA=h(sH$a8B>$/r 1/ GJB "%#8`$@Ŏm͞~ 49I6JBml&V`2
+T}Rweci;S {caq"J85@IkL>GobudK}[c;;1(v
+.NM0{1(<u.x *EcB_i<l=}E3-l>M 63ʹ
+9?_J#sxX*~cT:N٘T
+[zޑh\s%zWy_e~}39P.<T)-s0k,*xĤďShgA.zL̏+m(ؒQW0UFc ~=A {KKoܮ^n!a)a ±oF<8{>UMK2
+Ak' ˻|Zќy)ZSr;T2&hҬ6xּ?cY1ˬ?41-]Ls¯ 'Fi/rRGxk9}-kf(jI)hI~.z!UnGI=悈}sgr m$ C-ԩ|QM/\K#O3Q86܇;ĭ#8\l,DS:3>Şz%ե)r)FF>{Z+;ǚck{LV/Gߥ
+!:1.lNKM] Ձdk?1*%KLjI0V=J5,enAgc[%}⟏=Rwd<dH}MOR`SxCkPV: !nP$p䴟xA3uF-tc2yDY^ȰU2bo*J*K>Ek0l:@lyVz&>튛kL;ͱn0* Nlbn 4<e%wIewXVJP<`ZI =&4 3mxUإf"E0kn5^뇍.E^_r#
+g _s^:rUN8-gΫ:}ZﲰЍh/><Tf%*Dr3Ѩq$d7D"3^_)UHtx84<R%;>SLy&h3$w/rv jG<),LkOc6ޖ4EI;lCYO;?&)w%6ޒ8] ׮ͪ [{^EҷIY<^Vf?VgKbXAT2珫
+&T_ >RNwRֽqmUiK;3yQ}iR5:W8sYSiR.-뗪7gƖ7QTFstZgބiA_쾄hR bSG)<Nٿc>)g5K(y+Ju
+-5SJ1.xp|C_=ME&LDu'vE4;ui~P0l[`6F۠F߻C?ſ( sK3<rK#"4WzҎhک4]&gz1>"Y^bJysrmz _q1-daҠНo#}Yuf+)9R@(
+G}rʽ>/,8aB'Ӕ!Zy.tNxJ$oDe?}Eܩ |6*ɶB!#0g'0>FƦL;},1^_TˎUɝnnu `S&0aCk78cuFN^ku8cj @3@ }j>K?P%\˒>7<ܚWbp`kwܨ=!-lzyܟPmp3 0alD?t{Yۢ_D/0<b CKj&I#lzNdyUN `k#f RoH!FAւwi6'JznIٶL<fS.jCgՋJk!dCHX%r8Ś5WETih τHr'H.xv׌wVOXߣεYY5 湿?=fT3nR7jq,RJҺRľ~G+dI71-~3(Gx~oXQh.x>f,^HQ=<I޲ Ba,ɾҥl$Jه1FtT*BStl3=<9yޯ#<͔\{Ynp,pl+g淕8,h8,LtZ9V_Mb<B W(J`JKZCk,Ч獰9p*,_n2~O=8:c F$&CRF
+ ߬=GSI-N`j/' .[A|oNȢow  ? >'Yϲ @pA`si 'ثr/OÁ8
+/ ϙY3[Mu)e:^y{;Sf#XX*OĒ&I"%4KfՋmR[j%KjKLϘוQZ9)ͪLE$FE
+8t{adN 7,{
+;C;C%9e?K]8, g >!_  o-} sX
+mYضQYԑU6dzq2g!97ۊt{Wkmo9'lM
+y#2ZѢB6Fdd mE8Օ}3N+ AÚDeV*0P
+<Cw ~`@ H#d߯Ydղ4|đ!Mx0Z#!auzij"}0#Ƚ2=U`#Ĉ |r+V%Ww»N fyj|KHys|`-w oO[hnsP!pr-YqkR'^?t!:=n*TRkDRK'4y!q5_Y)K+qń+)i/5Xr=]-6n*:c.Xc|˜fEO\>aWIӺ>N>ʢ6nq!d¦bk㪠Q2ڐYژʐQ/}]MH8͔gK1 1 N^17Hw[ F[0f~l]J<q<_f1*a5&~LB*+G]wșcClG
+altP,E:Rr9ր,.#Jr`@$|?,wXSYƿP H@zQ@*6DY"z `
+r'27y`}]g|>8mGqf)<&%xa&0B/0Gϳ@zυ^
+߫r\TGGtfwR-{$SlCUZ9./T:R<Uq},U̝f}
+1@2:1&gA DʶU(X76frAfVg:{SV~)s{u\#a8]<t} [ؓ5UtJ Ң/JoɤÃҊ2!lޣ{rYwm@懢ޔdyrk\"FfN ;i6K$^dО4y,}4"&&8Q2\h@wI,W>h&EH}XCÑĺ×8d?V[ Q=o#Wm WiNłrJyFZۧbab:L%Q)T0?De\ܦV+P*uxVL[ sAx_PW(t6H,QX={ }sitޡ}(i.%Exi<NvIIdg<2;}z~?p-^"B$$]*۝-^d"GB%]W=;I
+~1a[p׬9Or>u
+B3eu $O^SD,ѯKtjȢ;JӜzWVnkRr3Ze~VΚft!(*O%~)'9bPV? +u
+Yc
+`O ȸ1=ńcSa,Ƶ YTpDw8lP٠:lC_ NLpñ6k@ g@`fsnauإ'zӟsC;veTivxkvSU
+a?4Zս츨Qlaz[wYg#"iER@:
+e "ϷY>N/_#٥]A{%dr2)R1ұ$M$Rmƕ3N=ˎ<WѮ+4nȰC_:Aݯ@<WVu?TSd +GӝQ亦]&ԯ_Ʒrx?v#^-nnʳnȵy_KK
+kJbB|oˏ6 .jũ*T\ң!f'-e{'kQ6O,bR>,9R)R)Y,949b{t^G>2#3N1E*f (gbyN'Eg5k`5 ?<B4` >ic;XBn'Q7,YnT~hR2XؿTj:OR̤q ɰkQ^ˤ[(ڍ}T{; m-svkNߝ{O=n/v
+x}^́:~H
+?e:ϘEEߏ@/O>j;!A Yg.?a8 3t/@){"Fp_=r^/<.]#ݾc/hsmpg#nC_2Ft{/$D5 D* /~NLzA`l'm4_b)"d&d I}hP:Tei-E!+UеUU/AJȯA?q)|(;=B.!
+8\ 3~GxRcEs0À@}B:{w`hJk$on
+,FҎ5m J 6n&5B  7 ~:׀R^
+|J8ِ13q1ڶw;ڜb[l^L(y1{~y|CS|N(VmVZx)GFG0#i2ȋO/>2k}g<Z¿ l 6Χ
+uzb{%EQ7vUiM̟3npkȨ鴺"fWݐzǢF9]^Ԇg~y~7>oz^>'P_}6iV/ҩ3ORj*ѷ
+\DQYy~.:q^3eXzI\R` u] B{H= a#}C#Dh¾U&Č@޻M*C6+ɦrXKCUX8VcUϪǪ%/WsqYrrhͥ9oW%W߱2?津jKe]I[H"b\d/(1Cvu(ALJݑnGJ>#c9'<QDe<s
+h.W*H S٣5sy3 e%ı-cL)`/]  _-/~\Q*T01g&UP&S.Y7u98x% {@dX+¿XG}NJ]k  Da"G!d= lUMCKty->cqָgu%j18(Vd0aL:K3N =Ě%<NOݦԸ@)Y`6Dn d6A2k{ܶ uMměj}$S|UR*kQGFHDa
+/؎˂; OWzŐ=.g3%g?'2')%zM9Jyq ۄ_{_U}] 2/YԀCtk[ϖl%,}:dqk+mѬ5HlhH_1Ч!cFE!#hfez>QNqVH&ȧ峜(0Ƀ
+ës=WeyP/{CW~17MjC9>tdy.YJȬLibc}Mm,j3d<#Q^iǵ{g7H|9K{.Y}OCߜ"5Y6J|
+gjW>hx!m2\<5خ%T8.rw Fz-^HwI\Du.HC49.|{\^)Wtt]1::iRiF0(aB ]
+l{B."U.yNKUr*%m_Z87LRi4!b iP+&2 [S6!$o#m%duOuKo.g5$[e|ΗMߨ4:N68|Pi HO
+*kU;?+=,"?R=&֝:+MO#-%Cgswnv}U\d^,=YtWlIO^̰=q(|;|-z%%A#éL8{q,1#d PLBvv,,m-![0̫pfiy5MLL21gߣ{u~s~OH":@m"sb@^ N#a Ѿ?l>($Mo(<F</Ȧ
+gY?
+̿gXw[fӟe=xI
+_RnF݊@~X)f ;Ea8~(8ɢ$K{# ^IFSɣTIP(^?*&-=OO =~q:WI8z?Z{O0D?>zr@g
+.-)d~
+
+FJWJn1 * dZMyMY3;C/aBGkDܮ<Ȓ0A' -Lpn
+<z#Ƴ\}`UZrwtdܧ2`^<@m#Oke{dq}.#_Yp! -!%TEv)\
+Qԙ{2vZx%[c-@\*u M$9Sے%Q/Joҩ JN5fKSY☺lQlm8x6W]--Zx޴[ܔ-Iu ǑYi~dn}jInM"*d=&"EaļsK  SHtDw%(Dxd{Y4[Ṷ<*!s R^g(l<m&۪|g 惌`FpS*/FVɤ)39vrQ"ۧreT++ElF6kP%X].qb/TKceXbSAՅ+tzkp!Z5Ȇkiov"%ˎ*w{YVa v~`ZJX&
++]hK`zm>>`x1
+9k $ }$HL^L@QN&_I]*h+ v$Bh ?ߋh`#aG/z|1O]%yaAw0
+0ۏDB
+mH6'B~!78ʬV44m@7fbX.@XT-'v ˈ}3vNt>ooqd㛋 z4/p
+qnnQf|\z.[ƻW%/I|$q6,N/{h"8=K! !YKȦxo@va{2$~(F"'$H-?&O"+I0 aJ%dI=tS'z RtWg֦',ò ٓ/d=-h}Rڞۑ=uA{Sn[ gwf;yp62kڗswj+L"H΅ovsOV .CϦ
+#a+;~'Rh ㄃ݹ`}̪!4q1CNR5`S
+U#VEnQel(ۡ݋<4jPe$K}>Waa>8]N_ZOǞ}ى+c~f&M pcCY!תQM".
+X0/U,9ĞcH?0*CnjKC1*8c Ґ!F4#KkuPb>Jv'&iTm=d[+K֦J &9Owu~IKk 75:[,Hj#^MrC_蠠C7PAC_!}-4HEw`O'B?3w?9C[{B
+{6ԽQ*
+Go-ϸ-bܤzC~Tb}w5+8*gWL4B^xy()I|[
+CB([a>lwZ:-}IG<ɞQY!FIEpڲQ"=#g Q_a:1b6W ϕ2\lr0&`*6WAF * A2z-[hl
+KxMlR9\%|,XN'8?=ʠư3eX,rgRY
+yJjn-kAfN-K[#UҪUo
+}?&]幎]=:~
+;ZL9;:?V-vy^@`gMW5 |˨ H?~Ǹ55
+]9N*]dTۻv@sDcDb};t弮g}W;:*ouyŞ:{tWk
+O)?k>pL L ԽtOf'Җ
+0d[~>OxU! ƽy}!ֈp>pC8C2xUt'bMӒ;q?/>0u֢/"\M
+  _0 ,OFgVDL1 / Z\&7rexn7N.ъGqCZĤ{F{I$ΤŸ
+dX|뱽St
+UH=qUl#anjd`5_0߷D|JzP~0-SiQ7m@_oM_" ӣxūǽM횔[j:!oH/gUwy'e I{ٹNBp+rXf$&ĻV]4$Ty@&YY!双t
+Bt’
+Y q?+oKܔ;D1ry \@ t ]B^S S*J0+C7-y0R֧{wIYSr=q$+ p.\ xQ>qa1OnTU/Sr  qa,7GD:axA'-{4s5ZC;KΉEi,}{~#c wؤ?bZ>fZ.7pcL  r2<HgVžT?a^N;cԔKyo;R$_ko̿њ'ej:١G5SS?gu:BF)dvlcۑ/e NF9=@ŠȣMAwl><MkaEC8]`P.PI™>QȐkG팁
+Aw>} ӻ
+%:p+ x@!Ea3M 1 ƴ
+#ː>Y|Suҿ!a,zH<ۖʈ-Z3--֮bT~ZEq\Վ2z*8̃Dpt"M!=}4>Rt@?\L]*īd-/
+F% #!Vk9}7rE
+՝NU濤%:?gzӖ 乽96(dz10 Z ~9;O*; vaWFi')g'.9Pe!: bO ߠ-课fOr,n%pX_<2GPy<*WY.,u\pƚt],yLa%x.H&o`o}>$xh1]y#43 's!_$55 S6 QUoGcs[͑^RdZPLϊ]h|0_;=XݥP=5/ԏP=P0f)~I
+;Kdι t[1W!F
+~N· JBJ\h[c,y`"f_ ,O $v5Adam0q
+!.S{>kCq!]Q}ԇ
+H1>;.1r]'uG6)O8O,Ѕ(ؿG̨1|OJ_YzE!dJ ߯Fy~c&T-O)/iOb؍s 9Ih<En㺅 |t
+V gܤ[aQ=nyVsYI5t~j?SvӐad,i#gQ'#{4d8!F%7juͼ7{䷎ux\!ٔ$'Ni1؆ߚkmdK+rgV~eS>߲mc
+friK(qmǹ:6ML=NoI]_SZwMҒ<v72jJ@ v ⠈b  E R
+Zǥ U*("X;uQQ#ڪUT"yw=sr޼ܷw-yɼ% duf}d:rLY4?7ۙ&dP~W6޷lmf7Sб9lGIέ0BuN9G)z ܯK%t~>~?z=eNNfI#ʶ"kZ+iMaCҴl<oɬDEt1H&AI nt]q+^9o
+oZКS,#( \Ԇ_SQyơFrڢf~-tfn9ǜѯ[ ~FbGLZ'1DVD8΄8pvby{v}^=5טUWbLcNFUeGżq*Q[XRz>4\-Goyk;kuĀMqKᚰ[Κ憟5Q^*W 8%w#93okUC1fm{;X^z*t\#}UM2b׀PR6h^\XDXԜ֢IeRwF1QAȋQݘI6]oF_ sȁ
+tX2ȵ.܆@ݡ9x`(J$iYd%$6B2i!k&IsHzG<6{eǖ~Zq,]z|u Lق~xcSpmJgI;-SܜB$E9sE n|DgQ bbg6/g5xqb-nH5BoLii=LކL9uߚȎߑJ&>kl4 ģj&&I&!~z`{k|_iX*F yaQȢ$>4yYSJ3갧jYLgSxdQ\TXSm
+ܐAB7&oPޱ]'Lcez0_X@3hE>D2 9)1ig?o}p ̏5neX>s6qb-[G·
+ Nɼ{M֭unοD{JZ#և Ehj{CNlʞY
+eD|وrM^ VL1(h} Su3ar+Yt
++]6mMvX ӎa
+u ?
+<'>fryvFuw*9}P9Μ(q*6Y<zkL+};KRYqw3=]V1v_ߍIy{&rơT Z68Ŧ` * ب
+S9Q2Sz?iGJe+2++)"%0%25ĎA4MJ!ŕ4D__)L,yoz0#ޅ
+:?'b^}2c@DO
+nإx'ry׶MSm&#O8NeߧjEdDˊaznrdo!Sj?"'ճ(iCzT.[ Û%5;$V5Q)q 8AzE^KA7^QU48cjG)I%EN~&qj&t
+Gu /|mP~_}ap$?鉀iB)+K>n.uco1{KT)nepY^VgzQB~ĺ@! <TAO4
+k P9gy`M<젿CmD֪}psMj/juU[4(m2ߤE {2'VwxOh#(u[
+b@PG&(r 3*-=͈,NOo2:'-r-g.p2jJ}I
+ TA% aGnQQAmjڎˡZqJu:R=$Py/Oe^;g^0>9etk0slNZ.#Zi_d]~><sOfیoڬ*hڲ:HiE_Q^Y.E`Kax%p¦p>ReODωGc^2lDK+9d~öWB杂|*\[sI` 0<I)_)9|iTx*~C'ٓM#nkaVgqJf,̉/^o
+/a~{k
+pCaT„yOw(xϘV*D~
+JisҬUs
+^7t}usIiؿO]/nwwz}Msw yJs(;BD4k"_1#͜ɑf'u'YHV% SwJKRq1bojg(٫_<M%ML
+&I4],N?e9"K1sl@:: *ˁg{NFuC%>[&8CsUf?'.#=J%d\sMȚ˓f:Xߟ%?%;<ߟ1y\&κϟR 2qi"#̙άݙfgv58Y'`8`~q L&{ 8^
+ %SI38N%G x`N'^N"~sGi~Ü{i#I&⨎d۝cp${m.[b3:1/j$KhY0n^`u;?VSqVۥ#&./nz]!-jbʷ~HY=ίW})׺muQc;NxauW` 'lp/<gpi$S':k8q\iy.agwgߚ ݢ(Yko~NuRUi vS-WmHɐu~~׏ r_-ycx!PnްSx5Ez㸦M}rWYNՁزWy%Pj=Ivl\\R櫀(_|O"QB_
+^3s7}bVqmRs= w7oPJ?4b3Ci7`aXA_p~06'ABz;#p(ZfbXP϶ң~gw=vB>XCw60;sE$9Ķ-=])vjg2
+jkr82JQa=Lթgi ZwM7clR ̿rbAXGhR(i?`Q0}BNsJ`Q{Ёa]
+]KĄۋ\(g" ߟyYG
+֒咓c~;wXR!$_4(;VVhhJtTe9SҚ3΅~o›ƛC0oc;vס^&i
+8@.5':2l΋/a[1oNrr=R>5bzC$uS ^ /5
+hT5B^1yDՑ5Xy>yv"^*:$V?Qg,^ZuOߡX6m`XZ%?E! dV{^X_ZR
+{^6hI-c9) SQc|?.gS=s)ߧ'ڈ6>TG67(2%.!+
+}' ?)6&AA{ĺy5A
+MhôI`~:RPK|^x-sXק[e5<@Am.Co_ݱxm\D:)vC-?9kH
+=}I!q.Ϙ!`sπ"_c*lv؟M*yuWvsc=JO t܂ZjФgZA-NjddYKrJ#GZgv@>!&Ur?8D\HNKbCo5%!Ku _RkGSk%;;PW*6qv`1){ׅc0&L>6l
+j, o~Ѷw$^;7F9sbs@2K{r=EY{g%o:/h=Ժ_ظk0FпZiӕʘ"i7߲wtO ~)k*ytOsTrkq钸/bxT{H _[q&L9hqP-S-8<#mpMfxs
+8W/%={UeNPB?iV NZve
+kl TLCh^..==QAOCT#J@u[-ϟ<Ax0mzOk8YFTHZFOW +2rxyuz_ѵ+S>d\:|mϜsxwri{lZĻmcIA+
+TنP=ڤƓ!ur<RU.&5OD1!T1ED
+h]6 d3(,5,EkW$zzzl-*DEp}==ߙ|dw'ohZuC <s}ᜅ:Ŝ*bO|w
+yEA/M^/M-#Pf`N0 a ت2ئnXo
+F1;ļ/Dz5" YR%J@laH"ZK!%] / VbI*w F,_Vp??k {eb.ؐNӔ^GF=[ 0ir7 ϺU?[TxiȤh3ECua ]kKLO, !AkQ|d&D|X;]!_c Tg}{zԋ ֬x]/F>!;P5?턤
+(Y^د؎/x(VWȸ8uњV=
+
+BQ7WRnG`C $g pb廽1w7 q +=#k볹)X}GZܺiIirL3nT{dohy!pR``t3_)ǜ
++!xUyjCx6{rq~0031+k@ǰiI"C7v
+nPpyBl-Olj 
+RQ*8Y~ 3 8x
+Pռ2@NLj8LV
+^QD;{56w_58 lPuwʵs:ٮ9Ns. j 仼-v-f,2Gf[Q NS}o.}ۿF YkQдuyj-.Zl)yqi^U\QGL`tv7 qn}_"_ozso b}ێ\4-~0-`5)g黧Ym"5uG'jVkA4H.
+XB9`7P/+#--Y8t6-=2=up=qx?2pP<CG3,DC>(5/Psn  2:xNcNɆGGc$lnv˔^/l)v Q ]A-juկIl
+Xu&-6&,Q9s¦WM !
+|&$yrblBr5L
+t&aUeL!*8x9pR7IVWbs,糷'* lnظ5llTv%C.f`|'cvqB݌Fr38UXkUZwra&sYK DN"o9<?9k|>_ nrë[xU3g`z'_kUm ˾VX)O=bv[)aL)fe` pzDѵJ'6Kio-'O~&.W3%Y͒/OF
+ Z<R)WXwvۻEM3zW]fĎ ֪܂իj5@45ju6s v3tf.2_k ;7H((V
+fϔݟLm39I|5"}Dp`VtWъ]־GCځz6 : @ l\܈*
+7ͬo
+%A/9(&3! d~<eMj f0WA$G6WU!!.bml J(k'jx=ke^p{1µSpx[O?#Q-٢+~a`%2=/fQVdP
+JA"2AԢVk!x=$x`(si<YmeHd9YZ
+|fCF9nCytc[=_vbb_*et\?q Q+QTf}5xL=KlOs]C,xiF3 qd.s+\:lP:fXNx'R«q;1.\J s1xpsx~f٨L/b18W
+T hB/RGlj3'1Qx\/o^fT9&̺{FuJkvgX'm֧Y]`dTպs4ށz^K.ORT^K.{vZړZ .R.8Cɓ<)?Z^!?RE>񺄗_J:K:Jۏ*:_CZCe䛻eMqv(㩐=w5oRnl4)v_[bۇv]g7}:<(}Q| MT6<>{#q?kcʓ\?Iatxe t8 -;@י#1-F[]835kf5ZG
+P^|sދ]?unUwcF7׏^7؄=`Nqh(>/:}$m ,IEuI836 y o̳-1{`c,?dcA@:)k lA!#cHLC~-0$}> } {g
+:*yY/&3rAʹ\՚OZ Ty@Ai8斁ho YV(7],57Sg)btB#8%w3m
+gJgkbJ-<?Wגƛb
+0
+endstream endobj 30 0 obj <</Length 60139/Filter[/FlateDecode]>>stream
+H,y\SI%$ 7B8B@ePc! Td=qFE΄# ꪨ:GEAEo?^ׯ^ฉ&Pg^jЬEˆM XR?շ>7bnҨ?ΨWM7$*xoѽo8;[!@\d]uT-Fj)r"_ĈU!BR!rCC%A:/K'L
+&LMd3^g>IO)=>bsϹIUhۑ5ϝ/% ~_s2UnCD 蠁]h Niķ)IMn+/j7ycX4_xHW"8'WOrIQ9q!nMbAb lHsLX$4
+^
+DF%2 tv Į
+p i%[@~ v nNK1Bo%@ѿAx`eFjmlY(~P$bDrr#^ rTO}tk,!
+(20(Eʐ",B"EE@wBpUQ[
+"TV</w|yO\O }uZfTg8"=/n)l|V"-ojyx5`#W?
+ xE"H$y"#iw=^KPqR(i<upzkj?_@+P\^ѯ+^Y}gEM/^>lf>)?)hf]IϸaՄ/тHaq┿Dt$qf}8S) ^G8#KQ[k>҇J:;y^网c⎔y#Eq1GH!Q,=$y(3e3uhkio>쿖)CQDQ`b8i'Iːp:eI,ZC";#HGP.&&rŐT lo AŐ`4Fp{/2Z uy}5Deq #' 7bIXts=vDN;o[ao'!d$w`¶`;(d-x
+‰_s E/DߦpunYwf+Y~2P/dI-+7;۽U/ZգV[®Gzmvӛs4lr5:n4i|aRq{@^f"D:<g2fѬXDO,$ʧZl7! ?ɴOԮҪiBaB~Bv֩͠ՃVS?hB=OlG깎4-Qљe#3m6:AEǴ 'f8NhWqp_V镭Qt+eK%ټU>bh1
+ ú sC_aܧW'm!חm g܈ie,b!?z
+V2}tQ?\:`
+ՠJ>Ť=
+1֏qT3*%d ܙP =so16o.TrsݪRBmmf0-,p.5&xIbv*#c5^y[ <=f.UyMk=be` /sMl+gŹRE5vZPlgcl36_yK |Bq[Fr( jR6~sa
+=Q*`}
+
+
+@1cϘŦTL]m9ǯ>J:K' ՘$h"]dili\-WQHv/|%ڭd)_2$[,C3 7b\Ht83D4
+{}hfѺZ7nL8ڈl3`R?hV;jQƚ4s
+<y8ǟw%KH!_4c7XC8iqlCC!kfrj1.ꨫ6ysYw}y|BArF4!K:2(D2"v%re99%(lRrF{*ѫo)w\yN?b]U{(ůyj}ZƆ~F֦!1]Yޯqr>p~岿0'ǕrdeMxBP'67<m|w^ke:h<3؃3yO?}?FrٟL籾 OR'tЭ0S8WM*<'=)O? I,
+S!ɜDA7`S[u<{c:/lE.qmpU'V3٭qՌAF !䠓lFY<U^ y`cJ8؜bo%h@"="_-HN9'p&䜧]6&bbÓ&O*Y3^54O)kQb.Ŵ
+)*mM--qA=-ŶIr} ID8gr18c^CH^cpdl 7fn~VxQ}'^#z^ݚ-B#/jL)l=4e>+'@uNV,U4>ޔ_@ VҒђ_ Hƿ#?Q
+B1i'9
+5?R@CHj؅\ہ~DHQ=oA˾^ۃÛc618V :q#q$
+oޗcO79o. aC8o9צCZ^uع6 o k।\d"kb2*{4NѮs685>7w>O+xn;ls}/iq³ -ʥ֘^1+,M螳Uf\zwv0&_ŴOU2W<UN[H9ӾSOu,bw61~5>XŰiX'iL;/#92#N:'Xb6'4
+WQZR){keUJƧX[yҸ>@?}%q&]dQ͓KX8|;SM+!#k V%2՜EXM=F](J.
+ӾP]>کׅbL:$vvehqbg{WEgPf> ʿjV%@n}ڈB9w*˹[T_*mo1P{TC\`|;{w:V{v5a='q đX+,m%x*gJ{zEV .g+sEt2GT=I!n=Ɩ;Ʃ&,@h
+h6 2Uy)h&Tk5Y CBZ>@k+B
+Bm6;pNX
+! mo& cS
+蠐T^)DamVTX ݄
+Cv.}#6B?TC0P}3PX BYW  _ǔa[" ikR
+S
+HAB%Tܱ|۪m2dz[zІڭء6۟ kI '(/( XHjal1$AZEc@řS͇dO4A7oa5DK|O;xH)Zq|Qmk.Ag=dxeθio sݲ\lYR1+Z, ==\L8?@l:U\l/<>x lC<0/OqYe `ا9Av@+)[ﻉ0]Pg}τ!KJ>VlzB6ɄG.K!3ȳ.!BJF.caWmk\M7q{F<|^3z~g5só pfi?vMm%?TLVzx7g\=]]5)Q gݧGY͇FkR=ftI6#9=5. mC@rQ؆<Y|Τ9O[V
+'Vf򦾍}c=P0  Bލr0k]ڈӵ5y&|li!N=ľ9w>کGE^ZNKPAvo " :2n;a9M<[Q`&Y2wߠlc8݌D'):$56/vv*4QM:!?U7ܺok;zi;GЯeOyH=`C:zfҜ斧Ok'
+el
+W7zB6"3
+ELQTщ'
+b_刣ߟ!:]|89b8I|l6qR65.ySȫ忀>T1n)ntgÓC>HB'Bk"?U3V5|!mR]TڰW^6|_=.&cH/Ǜ̞
+}
+l| aF
+0|QʜҼh1VkWmHV̬ir][1a&6^]eU 6blLYe\>Pa4Ri:vt\x\h^â>$û'H"7*KhH)l@%|P5V)^"λegmt2XC,3iUb4K=
+-5sLlP>ny 'f\*aܰa cOB+u*t1P
+*FvzđF{ioq+(Jr7D
+n/@?C*rFUǾNwv.buӑE8\/VנܛȽE <:ȥ_\ |Ƶ3:d!I 9vqIO:VA
+כּa'mn%s.J{
+2
+|r\i".uyg*)?WZqabFms(綖B <5
+ҹzGe?,x3{/y>!nuu3rC]:5+ٵ*D0!{"Q[~_bG)5"9ڭ$D13~~w-F>/O:8"F~/!S><<k$b9Im ))Y(\,,Xj\M܆MV(+ѯ^xulTu mfw+nˠ4gmT(@
+VԟJ*ދ~"u_PPE8KJ~?%E[rwM(|ĵTIrxJcLҙ:=bpB5ʔZb27SlX>kܰ7C^Wnב5E3Kĕ*xĮ{Ae^e^<;^[5yB@>s]C⚣&5q#y!ط-&z*RnV0f"b>uvL`Clȭ:i}JNJQJJv* B'R-zs2-bL:d~!STBZA6*包l2R3 ^u
+_kiնXTWH80&us?dLe=zvlF>dطk 'Jo)'XaskXuf&
+*ES*roSGTh0?q?r}\ڗ#f=S)ϼХ!*N]\3NQM& #idOA>= x""5dףh 3JD#t~ }77K?7,m_&:MhHZyw$soF*e ṣOw.<0?XTH3%zӜ_j$;0_P;t, ]u\c`grA/cQgDvr9f]#E,;l_*%8ROsp&eb]}pM
+v{Le$s^~ƫXּ^וykrݾ*`@ACzbZ銛*ԹbCJg/˳fZY +&[WLQ9fT9rWj evFg%dM%0s|xc~< *0ؐw%D~ҮY
+
+xnVn;Uj5^j^GsffT!b?ҩ[[eM2;ZNn/
+BA43qwr,1C0~<O&mL/'mJ~[BiNKU
+b{35]u7Oo7E3*IFH8%H~S&LyS#H~[?Rzsn[tVAxF뉉춸Sc$-&n'?"1q)"YK#&9rI^H|U,H'v:'ǿ;'<9zj4 v49zʙkX-|!nT
+&HďҔWٟԾ2C٭ѣ'&33l>J} g45G4D
+rC*x[âmr>҇4K즴*u~q[2sjuI|1-̽_2mfZ(vX/(,Q3W>~{lM)WXΩs7y嘮KѢ#GX|[L-Uj 0 ʬ9V)?e뙡c,T(t:TG f"щdhsuBE/I:R 3}f{y澯%[2UͷQU%13DsE"@b#ׁ Q 5EG+{]6/Ȧ("1|qN wS.۱coO`{WlQ
+Mp@WS(u1Dk7FhXD"F_HZF$/k%tΘe |٠\ʆ2QI|`sIsqN ˜*CXGQ.5+=c^ͬsܬcbm۸iQˈQp̸P8J`ʸt
+8K\Ĕ awR/3c?vBLf;M-se~4s%$fc#kåaXox}c&wӊ7Tpt&2r*"-[ǦBo&=|;TzpGlzù/N8 2S83 lh|}f 3mKT~fE_]1Ǹ(7T=BF@O'*:p'd<MZY;FcPvӚyu
+yg :KM+\nRd\H$19nr7W1jAШ lєs,. ~!87K)A?9_߫Tm۪yO==+o>/n#+ hkϼ];߅{%1,:
+ˎd#iO'҈r"gҨaԴԓ4EnJQ<A>^S ANʬHM
+ q^[[l? | KĄ
+ŞOعjgztTwfu}YfOmz-៽k&I_5YJOif1+l'JNccQuxm9Bep=7^Vlj!: ~)X !0q;
+B:PnGJ-<P{&T.ԙ A -
+΍A5X'd#4l0:Eq07Ar
+
+ш)ǒ Kd1_ܼ(YtĪH®8WɅCyw'tzL2|f?f>04]0;p4Wւ|g2)!kIRcwW5oNmܪH8N\ ^k,Q> ;R~Ir>ulWݮɌ\@?s,qL2BG͓CZ[=vy y=J> nsv9xlnp({}{H7vǬVj1!1eC@x t'Ĩc!1^ @Fykxza{c\+?[HN?PX "Ma+m;d1jҟ]k.1HLA=kJz͆v8Th-YgtǫWkON-<#ÜsFͳcRXY@`$\߶q
+~3ڀ7KS!}BZ_[Z3_7߹;`
+`bui kQKLE
+lؙ?9⧜a'S%zf#~c+~irP0PaR"&Rq^a"'n`] 1a[11?̗9$Tpgƀ0gR~R<~ +MX2PLH7|={_G9us<0Q?{L?A@=;?<uo̖vN*uvt ) d
+RD8M*1jރF=v<BFJI]3ݽzwhyXXӮ?H Ħ؞FV
+
+$SPN md#ږ-&; 6ՇAk5:H0S_7&}Ȗ'|=ܴg,n׽OYPX}PLmPv; ҸwQҘ0Q.(1udQIM 1ߍNn#Im1dokj&1M$BN~iѾ,P6/5@q."I0Hb.I4Z?D٢5ߍ MhpLW3ڿu'BB6;?IB(5b-ğGVl!7N#s?t:-lRp7b<eDPkֶ@vߟ86l3#H,.;D_hmRn@љ˖Lb.YdߧsrM؊3ZU`
+Yp
+YRjwE)j-pUی =8LrMrpfzcLj9ȬQIQ܍:bruܔ^]񿋶(r/+ϩ(ס_7̬4xyz?kUo <7¦\rgžಝBk =a毙_5}dralWkf+ıpv715#kcSɶ~iMuP)FTRZDmD*߄T! 3 41\+1>{
+^٬ hD`pZU~KuKlnnN=$ڰQm7CKq/-ZLchSa~m*Ce*x&:)\Qb <zpNNؙpY;L%<kUc|4[c{n~]8^dF7Mulj r`q<&
+u`?O
+:đӅ7A>Z^ ]'-J9aVކ'>nx"שOQܿzͩ^pK֠+d~BM9~c|/;2T@YsgE[P6a)ŕ)6)[Pa6rR` n=f4w\GǟwBP`)%j.S5bRFꂋHHQDQN!"
+N4HoR$ P0Fw(3ϼ3#M(C#Ű8c.e_..iך0 ]= w66h,tτܷE)9τfB~B8 _Lj=3?< }4`GZo+G6={ʋpBy{?,N>5ǍiԪxTmfܦ໹I!6ŰMafص+?P2_:@ћ4g>!T[%S] ,dN"2Ǚ,PI^N^Rt XOhgXMjh3a\Fb9MN<9!Sg̶ҹfib(KzsҎε'si
+"KVhKsd[Iu3 =fQ;sGMźci>?ݳ)!SLw" Ȝ|{Z$]/&k(ۃ"]V$]T(]Lr֚7Fh+Q" VİԆ̻bBnC\Y4<'x;p¨Ӣ"ygm>fzfƆQΡ  2{zx1j:)SRc{ަ7ſMtd\[~h zhAEH^!ѢԦ>,Kϫӆ.RoL(Ysz
+{ ?6`#G)VS w }0zH=f1b!YhN&vf ׀+<-bYaEY`~ro3r-<nA~<8tˁ=u<,n
+ԗEP֕\pRm5y ޕ|qx+q]:]^ƹ^wip ];8S WBX&vDbt#7='VuGc9%,W+~: ><FtݣOܺg6@=:k1q.]`1r-Bo8VXv!#{}
+ZXNң5X"olcގ&\m,d`9pýv7^ۗ3wV`6q}:HvȀ!lV
+;}a\p ֟
+0DZX[VTE,%
+EY$ "UDTPD$$ahjq"jYECdt&<ߓyΙ/Kdʗb843`r=@ü^#~P\amUM|=jv>B{x8N^sR3#s2Ns,>ZY!{\Y,Pn]
+b;ըoa#Blͼ~s״)#i _˼񄖄)9M!p9$[tϏ9.r3S,l^Z)2ƍ=/lE}Y_"74W~Tgu_Y<pnYv_5wKNCjWhT Ɉq*c@Z%. uSNt|^\8'p~Lˠe@?Aǘq5Z(VYWq-gD
+c*N%j l$29^)7tl}Lu{gx?"wNKXW`Y hO^se{d+||[
+DB2hmW@0XiG^ A/SDb`x{"#Fb茄;p DJ΀ב{zat\^uvANO%ށ8? 2;stEt'dF!ڊp4: ;0v,7ǿE;+]
+E)szi cZոsub1irqUxQ+_ͪƌyLP
+\
+Q;N*6UڏVoҭݢ g@ˆ`1}
+=3P4a[eVN,1k{ՃIAb]jBK]x- LB1
+9)hC ?
+wbPX sp~0Xzh hPGAk  hqèGZƷ7 5  =uG
+ՂxC13*[ XƧAQ oXA~#&brimIWn x6oxR4 ɀj $=
+xv!79`|{ޤGizoTWA*LXVRߒŌ&֋j ]u VmB@,~0<яt}ߘQVg&<sk^5enK#%?ۉⰏEݛ9p(ӟɔ^J19tR_ɔp5\W͗z"rPx%z[^@WXѦ, SVeTm }| gUUY{Zϴy?+}II WH-g7( rTxhBfhsalm 9,6RY2i+l}ϸ qB1Â=xO+lāJ⚋ؚχ??vo,lZ}^MYAl;1ύ3 pz FKBĿ b|E c6F|B~}O1B" KiҾ8dl v Cަ/
+|ks2UQҶ$hξ"dɹ$Hi_Dg&ڕ/:1W7q\1ECdF*t]hlk[\?C[ R;c72 %:tm##cX<tj vh_CY!WQmk(KJ]-*t`Abzل[WOB1ٽb.޳hUGY 7R  .Pc :EG):-*tmA ;u!P€_hb_aC`VGWS-|f̊w*MpyϚʟ<-R.;/gh {9'GSRҼeRxkGDxv<i7nc-/uT<o]Fwɋ⑶%
+kPKgzp_7U&{W&U$#KAg"IއbitI_'ob0WU?[sY~7wH6K,NM!P9՝>|3e}9qujץT_^drޥ!SMH_t].^ WA 'Ԥw,t g+ˎMK
+'
+3g2{3>wf+6y7da_p:Wܖ9{
+'I7SP$BFgdw#>$>l4u4OGzidi0;rp & 374)xSq;IPG BF~'~!
+Hp% pɭXEK
+܈pUP[~EW\(TuUK^ !τyߙdww%HI2k#̸9Vd1eMȘ}-U82b(ZkVF-$nCh_CZw'ιƭ.arх::W N|6sҴE0f;k~ĩcW[~QkU爄EĥmWu˼J. *::kgnNR{ `W;U7&Pe<~o[+7f¤OVW3
+Bϙ3D˙3B+^60>j?Cz5
+K:eS|1Z+HGOatA Hֺ
+f'f=R0Qb(0"v .3b
+K& ;ς`†]5dC1^cCBu 9T"~:(h4mY 9) %.:MK[.-%RZRmě|"yց%bzy{2i7 -G~6D|1H!΃y_+#7E@s }3O4mg2 oc]r7z4
+rrPJ!u"XO+H*aTA4F[! ?ު߀e!$l6= $) ]&32뀝7!y3ImeSn\T+\0Zȳ{Kr~C+XVbWzEǠaYeȯNG֫9~fOcOnCԀA~=4Iv=Nyf؀en3" !D;aSsA-y6 dR[dt<s*K,uӑGs[U 9MhߢiRP[ފb(UO O >M+L79nʴKeCr[Y'I^_CP-H냺$밀8AS@jD6 }~b{03FNE[w6OMa -i9Yvn"!s_a52^Ɍ>u'uc
+xfxV: :(o5,Gykȴ^E<0+
+xbV4-.ٴ_g}e>{;M!6޷%󉘞DdBBqg M
+bBѻPS
+ֳ~o-|93LKv9ђyĶC|d6d B*ո<"rz:kQn\Y[itsyE 7Qq$!+WV`թyMguU7NXuzN2
+=ye]j =^ Wꗺ/uàcYְk$G8S-zb37ܐx{doeacʈEP/<U·dR<m{oиUx̒brB٦
+YyDe[KV,~+ZJl>~q5vTJkB h ӡY/wϚrO|fZK)/؜>m%CI =:@K09bj! &Z?^TZѤuO~ux@ʆ엪gWHjɩ2*zQuL|+
+jf3av -i
+"wd]/eEEBz_CǷ~U^{~OJ|u`P%ؾ6I)u/PiCM/OBݑG o:' 9/H9]~ܶѼv\ӡ캤iג%H'ձݗTxhX%L'$M&MǎuHfuv&:xbgTrgxr[Rt4C!ۖ#s#Euۼ._E
+2>Iؕo$"'/r_uq䬓Ҭ 9wjn_{6ƫ[2ے䵥kki#IHP_z{aJ!h4+ȚƓi~ \J;]2ޙLW [cU7FF`{gz"1xxSN9V0w_[l+(tGa=xTo*;Zu#|foW_>C>[r8-EpfVܨmna/rWtV=~cO(W<.)g+a&+VjyϕY6ܠgoq+6Qrj
+ *[ft/( *YN石*@?4n&'T4BH(
+Ju#FE&LKg<y4{ܤqU8nϞf9*NӬݓyG|wgevSӆEfY|bL!Ȩ^7U}xZv4%#$٢ǘ)v@>;B ԛ Qz,x0ecr&fb]B1ȴA}
+Zܿ
+ ' C{A˽\(%=
+ Va!BD3*!J2DiUAZDkAvviv 2 ^q SyLu(f^p!ߑXgX?1gCuO)i^Ἒ_SeJ"҃NN
+rEeRУmDuiay0"#{yq{mz;j~68H&kē*dUyVl(4 ftbP| {N88B|Y)t^pl{,~&{DzN↥8nrHbۿ֏P= ׽`3ygvᦥhN3nNpR Egt<sT?{ |C1#L7ր\Ϧ{)WSZ]Sm"rgƲ\Qʙ3eܼԮM
+D&d
+Qg} :*-Q:miDnm&lm502twS]fq举21v, 4 .1 hpWd?O@S@:NȧSaS
+{]֘םdV$$~wבaI@Ĝ$?;3LD-TwM! &!ҖKCݠKԎTD"a0]]JN8zT[15?y{|>bWT 67l*wKZ%aGU`
+SZIӆJKS?m}^9[8N<1sjm҇w>#Pqmx\]hLcX|[X59-S8)C8~^tƏgbgDB(ʅ-1(Lv"[arr}h72<NC]@ f
+%ߌ9|@6Z6
+6Pps$
+nB1r( ;% `|-b~}7rlGv7]5W6"q-b5o@:vȸ{7g.DY4n:#j{_ iWoDZfY68rVZVi%W%qR9o3q~JӔqKnrvgbAˠi6]kӭJqk$t6z{YR#uEN_L6nvuo>fzՌmeΓ:ېA\)Vݴfyy>0V(eb/P*nRpJy LͩUpӹE[MZ_R&(a/@@iĞSF.KQFA*C ı`>z1jݐ =Ϻ!BU.*&&xЀAW'@{ Wnx=gX96&f~]2x5;zU;F4:4q&I0j@P+am @>K K &ݛ !@pf,B:(1 <n-Ԭd*ZTa6D,KфljW1l ŒkvݙǸ.Nxp.a/N@alp~> M<!<
+R(ly?w{w~߽T|ӌFǔqnvì:<²qn'm:i2AGnIsn U cy ^d=D3)W5#.)6(X 3-@`sFDSrBS
+%n=%v#Gsj¢w?yANú$ ]EI"nЊ}fĚ5,t+r[-s]+uYq]=*ak@.]%J?9
+vO Ɉp1pB䔛hO2nj]e<S
+~O
+=^6-GF~C`9qFF"뻻ƞw4w4N"|BbD&ȌB."ebeB%rIJqB 5q ΉQr'd)u}2Xsø{5rnR)1fnV3WL+&eYSzeW_LQdMjt6}A)sH!1.Z7CP1 1_;ZhV*~䢵4^t{eN@~Eqz׭P׹[n`-`d|uj`{u
+YJm?2}O`~@fEK$-COtV@S&ɓڹ !g4!g8yNKTu.@8?L\JXIŬNjW.vƭqڸ_2ڒ zbV9=1Q4'B Q =wFݑxxO.#3<D5? `BG( ֶ+n@ A$t0؝g{Sp8
+nح0TOwEr5uq
+۟=D" ^EF3@GPȸ<|n2/_/ _q P
+D&أ~gŒR|^
+nbpϔ#j8҈XpR{e1(%K+`).YW:"<G*fb!)CBUoCZKޏ.h12[B"Z@ j R(nWB8ΨKA}$! e
+l/J7"\hlIz+Z=cyg֨LֺZZO mk}af\=+5{*Ni%S IzS-㣭?~O%F#wq[YtG?\!tF$#cbYf׌~g٬ɞ=:glpirڳQMڥ٪xM79FU~x QGo!<O6 A"fؐzo
+"6YAsWڼp=xky`ZS]ǶFMD۾P>4$Rߞ)LӪbr\ j&pi-z(Vl&~k_(c;vpϯeu{2-qA;Z-s989`#yμb^}c\]1䬚V,s_oŲgżR2e9òn^^58Y4g/O
+_
+2q-=Iٵ™qɅԭF
+fɼ%q!3q1WgNd)EĶWc[6Z$k)Ҥ̻KMܺG෈I|{<HA
+;"ytH=t5Ƹar-j:\a&Ƙ"6:hIED"gJMj.(lصRt1;qf5gvkO_ݠMݧh$Д/~hHD_NWϤ\OӦd6oԦϠ5XѸKWq{%;ftz=~Blx l~[`M ^ /E]k18Y7X(Žؾq%4h/ӲO-69Q;3`V-#1=|^ɂg̢C/ԬI /w6xܣ>̊W7+1[/wg
+QnH'|>De`)T #H[wQc
+|⾂YiB-[6FCvEEq^G @^ K=P ^$L<٦@
+>Fezߛ,%\ b}0–7Q!+B:uTyJQ3%x}X>ǖ9sB{9Y҇[=i)A%fGjNʺT,;qɤQCNرs>AJ ^B[}oj_,x֐:v̻ 'U+?'xB^Y\Ү8ܒלєUYG~y(bj1 qz vr&>G! +qzQub3!d(q2Gr\u8VG;<eS7)4/Mzn,9CWձש"]*dO
+C,(97ʩ{aY²8ή;L6yw-4P3T?kV40bSmV) |I~*B6
+4O_Z5]ֈ.믓^5װD) ePjO[}>RvDG3R-rv{v(ܳ]N(݃Zb[HW<uA=9553Ꙝ󗆫~1/%%eΖ>>OӽX:L_ڧ֍B)I=A8VBu5Abs!2P=us4)!|P.PEsiJ - / dKF 焍v5#Ȟ^9/ba/2!jwo]+<+TIL{TnyNőo4X ZSVMۓʉ+{cn?*'_0ͭcAmJXLT?ԆN۟ P]H ԺNȱ)gTxY%:Ğ'3 j3d[f<y<T{9cɚd+]Ou-i!똌K'kEA3P򸶺JhP$yJuߙg:gsי-#*_,]\V4r7i#d3^~܅[
+>^
+ƋRG
+;ùgɯ%o2S S>שc.4'g7$O'NN%4fy|F(I\{D9Go8q~ϘC(cQ((ǠC%1<gSՖ*MG/1Q GQC#ږS]p/q8:ۢv#;ΟZdZ1!l-Dooڄ4w .Wdƞ}hk/Z Q8hK7Z䅬ŞRFF?Xq^6fLG=kR5R,Jmھ[&OY7ebZwZw V:*s8R=gK+FK_ ˽LʼgLKYfe-}gVVg-*M/ #ojIl)3Yl>L5{Nd<$GD^?Qb_}x ]Ut!)n8 &rt{A E>a3o6H|GRS}Q2[5Mպ <fVj6J +ډBW]MMy~۩_?U>5`?^}ߓ]UlMVXH Jhx>j+?34nWs|˿Yt۬! JBH:Ku &
+F4peYAL:"Bh*?Oh̵dj=-y"ך^#KUhm ?!2i
+l)]@ؽd<Z._Rݫ);?!
+`)0i1]aֆ xc}nK_ID>7&?- a}zt =,ǝ`H0'Ou';m^ "g+gKYq {.pP bІ
+-rw!f%8aeJ|B8Y+":ow9,R?(sѩ{T.Y9<9uFn.3\i3Ǘ8|U,8"W~PrMo(_KkI.hM\<%8ә< [ٚ1mPTˍoZڞ3X/֭gUSo-;»7̽3½;\KmA= s+}+G u<ݹI ~8+~!3{bGtlх}cGѾ[1u#"oQ`5D\~|Igg'GQ7g
+;{Ҷ~Xag;9)„θc]DD"ӺGn?wnʚ,nD[(ƋO,9s|Kɘ ']ic̡ʖ!?S>t(H,iO\ؖ:T@u1U´A }בZksdڝ9NZcT4$.;:Uo|Q6VeB6Nۃ6Pt ES{>A`g8\3Z$$ө/NccDmn9;11(
+ÑGsV^݌ vH Rh@hY-R8 f2|,"ghc>,;SN@dL)7y [.bUGe{K%ˮ#kH7AҵsRUFd
+[ nSEy=J[8pU
+V
+5".xv2-7wqWn[xI5: @Z `
+q;VXK 8-\A;4G@JWV"HQoշq+>
+J7åљ
+T?9dP1D/H=>3|cMpcG}'ipQU
+кbՙ|' _O-a}3YJ}g^Y}c?49qRߢ z]f@xe&hV7TiC MY?4qJ=i O0oMhE~MnL4 u`_ze\|l{S~G:El?k}'V{cȧR?N9O huh+p}ث:mvM8ܻ*ߥi7)\Ac?of-)<Qcw!m`{Z@ pH`7
+h[I3p2GJp$Ձ$p#5 LO gߨ&ʴyrgY/|&oUzC\6fL*2ybq)k4`δ_qIЄYE+aZm(al8>>k?jަ.zV)9&Y_چ6D:r H▗2+X_" Iռ4"pSP_j
+J^׼WfTN .-p VWXp殂eph
+m@kJ. ~k}ܦ>j FI\_r3ӪO<qOw$)!:7@p|o1H{eڂU/ź~ ;CX6wS4PyRm~m~ eR{i>Vէ&;Q0^8^4!̘Ӗ2 EYYOUwM4t5vhl_+hOo/xWәla޻ꎼW5S5yu‚7OMN5^pN̛KwKTOس'E,u.O̥OI&qb^}F;vpGI\yVWbio
+d, +J0X1tobZ̕I.zҖ2XN%.ŋql!ꉁ]D,8c鎂8?'*$ID?PJDY eӈx3¼X:_47bl|t},ZLYOtEG(#oR7^ۗV7&]`sy3gfOʚaƕgKgvp}:}SO2`b6q54QƲX՞
+#G= "xPt y
+݈q0;7!Pj]< _ " w2uB%!@G*E/
+=M?4o-.Q+JҵPP5$"x(=0 TJٷ 3cLC*]Z9(B
+cK9{*jSW[ttI)s~}33y(Od
+, ;}JQ0YOs}N/F;(} R-M9t]D]2>hB.7:H1>yD %m?9m)UrxlK ƃ{S? 6 RlD=ҳ=Av<a>^ΒY$!, !zaoY) ɛ@xQLAp& `9!k|e[i umhv{qSPfzPf *vByhuWA`fQH¼"^rCgMA†m~kO4S \
+EC{C׶Y9 ?*(޸(K6V򨕍{T&+TS+.JvXݦGB( :Y:5)Qw1ܶfj>}khTGl
+GDH'e d5dt£AJyOL֗~w<
+R>LpWS
+1TAY/Dϲ#2;aA'>oJYX}
+띆EHv{K9Ѱ!h0=N4x(82:j
+U(uf
+3>->e*z'us_ཨ 5
+ t?oU'hGxws3LveOTs_&ߑ;V_ݿ9}wB5]Az]1U؛9/Qړ(]48I*NI$ir7Ng4#Q+Hw$)d:ei홳<ln~2>JZTqoT!̩l2ԅy|qJ#zbeѲ!G <sn3.bz&r$ Q,+k{Sywك;xɈzrƎJ2&<S|AxY[Wy#GyO{]{XѣWrߕf\Ӗ6ё2}l0m6Kۓ"#R^qV'v}ڢ%` V0蟆շfo.¶{/ !8pGpaqs r_)'EED poaxEkv$ .}K,k!BkBSlChKl +aE&Na%v':m,E7"p.¥ןO|+&fN2v :gH5ћT`"- Z9Am46|9-1Bt *G<?SV@,C|Yf+, sbO۷oiIX5X0(4_I>\J0Di sT|Rjr- Tb@n|VH[=M;bZogdxWF3;}^.oaQgyc B_彨.\>5+Zs[?+[ܣhm5/ƨԃ{#S7O
+bcRk ` !To@
+PE@@PpauRA޺l-8p@=G6"Lwwc| }Ct_}I0gH|j0^ _~w/j<
+<+Ad`=箐W-[/u '7Vު7)L
+HYqҵ![R.AB R ^t.p*`q=* WiA)ɥk@RĨt@,]
+Mk
+㮓 .+N7ϛv#~$шUGÕ0pꕺ镸OU`w< x41lZٗ8iQK&p[ZǴ]Gu
+^& HGfֲ>5̘b2osCHr РA:qc
+%\3,)o4[J66)E!wok{g|> ~p+TNίp׭s8[r*]YψXUeZQ'uI.ڶC!~Sj:{NKvC|:3yT7,9)oUC\gl[s 9@k;/
+OYoْ6-eBbtI`ԨcR"i<|a<'#^/w~o-JzIG&SP3mv[fB]r n؈z)uR0W']UXKUTlZ9iiyE? |W:C;MWEs)|lJ=,l)q
+[9_n$|89ccXi/3֊3~g< yz@S2m);%qcy4m\W4tgHy=uM{ګhڒ?Tu?rnEvQ֏\#prgtL'#h靑8,Qq//NuƍINJ:c>tDfP-nDcSI4?uuCm{Z > OpiLWIDu%zfM Mԅ(7',kKHr$[^GX=k N6$ϭOʽKڳʎG]/JҞHzs5izq_Q-[&c[bFSǾ'GM$l9tGs7ը\Z<`5,!`.
+`;<CW&Y>W9H5jݰ%74c{aԇ}`KcQnhƅȸe/s47B ]Vxkcnc^vSnzc6 hv]w{ !wIn
+@;t
+U6i܈v5Ӱ
++_ _LS3F GF_Q3HT!FW!r5('StAٕ?:KnJ"~=8| /Ed
+KrP; >adr P g>CY(G95C3&̊cJ(#rC5F#hWFInԮ'|moRf#$wd FǍ;PfeOy {q:0:$E,g߱ l3G#5ӻiU@ԥ›=vJtPX:!?f?UD}Y<Z}<!
+
+MYjab씯vK[<N;l5!p xx##iG\k^ >`5e
+{.IFiNcybH5AY|!梣Eؗ; ۦ) 0
+0F!P HоG؀+^ ##
+J QAG0C(HVJ
+ߑoKphOuV<P-s@r]爖`4uQ5iV%ro8X^وoUpv>vwYD, V@t3
+
+uK]{,UСye bzl^,x.tŪ$5ɌX6/ X b<KB檐͗pS?4/trv(f}(4)ö&Ģ}2a [e(9yO\ҽ|;wBU] Y;'2)uR:V9+&y66yveoF)qT9eT gfJƋL4O'JZo*[frU;Xז7#o潮g&ϸ ϼ8]lxURٚ1rY1R-|]ז1\F>1cٱic%Ro@/I<%IA$Mbe8iۙwKYe(e9%e9퇥<;S]?,O]($>=UŞɑz
+=?`BN&t
+= Q { cc}G((}Ы#
+;u4mqPv0ʌ$ Ɵ 0ŜL4h+{
+aSW'5 +NSƈ<G i1j*5zн{nqzbMx|'kz
+V `"׿cȹ_x
+ wvY;x@Nn"w$Z?jX.D?*q(P08e8^`8Q$p"{!tN0O1Qx>DB$p9G :zBQl:K COj3~OLs x=&Hm;t[ j Մ`>m`ߣOX:¹ $!`%IE0F vWۛd/< P
+y$vUZLzw>bKbrkBt}NG:Vۙek1_ zAdFP9}i,j o$ ]@tNXu|<LX5Lf7JZSu;ʹ5г77{psжe8SԲjG)W.ͼw
+?XdPMOVz/;
+dk75ݧ_ `Ш^`,?ÐP9N KjR~85mΚ4Hg}4`Z?԰"p
++]xVo?X3.g '*9^k]fLaq^_K98rX\+27jc<Mq׹4}7;>+S\Zɸ836=;Pw-?OM]yY1zBad{ݼկ4_dQJs}wusB"|Y<4bHDS[!MbPt;"o8Qd 2??..g2k)2R|Dž8 -#1Y)FI橑=KF;DmI5zsk"jTC˴vr4*1}ֵ}dew<~(b-aq|JǸ i>b cxACA1"rHa|@'(.lbF vdK(V\CWfr-c7Ȝ2PT
+1/I-JyRF1]ž.7e!3M 5rsx\ ;b= ;J/}b`Hmkxule-Wf]$cֲe:<:љ2FnTeVK*r_C{&}kP0q~[l\QBIi)C9/e CIkL[
+, D3삒`u gvΌyhҪ@Q,YP"YT. nW<': 3.Z16<MeL#oWn({ݻV?(?q֏9?.oƌē. 1c^^fR5K+//TSW[DI.󠦮=nBv/AXD(@
+2(@E’@,FPyRdM lje *PQY
+ƒj)m}CK
+mcTMh&Q<yW\9-k+qr\n\\jNo؉k7YqNnuN8]kBq#xP1P[~AʩC %ؿ5w5໤l|k3N~ HXap
+֍bYzԞC 8 D!,h+D.AtA(d.l|K.vZi1K)_;MhBµ 0{JnIge_[^S%jDo.Wg6: UlP&`5ؼT}BeH7=h~{_NU-òZlB}KU^&umwݵ3_3ª.evY "Pa?405Apnh%-W1sQ:tȲ U 7EA.rB* [e3z]1FN
+Lhsg 9ӾZ,|ܧc]A^--d-r_Ykv5%2MT`e%R4U#)䁛Bj(Y@J= Rx#O`/
+W!J&[߀6Mȹߴa,AMqrQ!+A(W C>8&0b1CN6DP DDoF:xr$NǪ'B~M?Ty:O;>TӭW%֥WG^Da5`ĝf8/R s8cybTo!X}ةu](9x;,1V6w8#G\ϷbB 4qbZ"~F7zE3F> /+,nrI~DMQWIsz4J8cFTx~e]2Ms`u3^Np7UpLp̮qY\ߊ-YV]ZcA̷$6Ryv4ގ{8Jm &ӦKqFJCZ5u׀y.p(wf)~DRf| 3fHur'I骖e*%Jr)m{uYJwiw=g.y9_rKO{Hb"2
+1 @2؇yh
+| p/TnF (twpqZ1_A P\BBd_*
+M_ckBzTq-96&,5bͰ+&X#߷E]g%
+5
+xQ
+539 ؕ_!T`
+Cl4ٵ GXWߓu5`٬W(]|6s{=yd<'PQ xo]eo匕22Dq`ĝ m` $qLcː3Pd!CF&G8W9qYn@
+endstream endobj 31 0 obj <</Length 61442/Filter[/FlateDecode]>>stream
+HwXW/
+SAEE CCQžZ ;;! a%RU_냌$o+("PleX@P侉|s99sހ~{[njmDlPUk UVYBJ @5mm|FM"놐T^nT[/:-5;W3=ycR}/~ztsk 5f C3 SFuO'CCP/=u>koV/mhR﵌Lb&l916o-R s d(p\#aoVޢ*lڶ6z~CE‚Ki筥Qv,tcLΞ.mkl>a@@ŗߚB&mDQ%r+FWƔ>Szj^șQ [;\9^Vaؐ_Dxj{|XթCwch;hT[ݍXޯ(/h{>F<ѥy);dB"6^A+E@VO$7JC@'\QGe;5I<ڹM#wc`~x䮙IO:t7Jct$כÀLlDZ}IO . OG~6=d9VoѱSq1b#Ts\B.IxF&{wcw?lGC*H7M7A}#k
+j^bV0/
+^,X}.__r,Sl,9ƭ8
+DʍHh_"ڔ2֧(J' s֥͊6_F)n(|=Zˑб*T+WQ\ŠkAA+)[F&T-TΫHK=ߩw Iޢ={uK<uޣojpkoqoWf@*yؚ?pMn05bH:VNJJ3k%7|+s5RMn^n_o弹.a]kh*$q8g'\dJ2Vez{$O^$&ˋZh3eʹbTZh/f chӂ{")yN #*P!#^K:r|Ys"aW"=},Zdr{tu21}jϴKRʔ@RJ(3BTOyvKՔ'6[Ymy6괰>Y-NWsjo>d_Vjw;7W 급񏨙5zcB_ߞ=Ǔ۳8Ҍ%$]՞ũsd'W=HLxpOkxȽ^+6cπ]`;H. 8hH*[a঑
+*M>֬
+Vo;2?q:29̣8~'+]AJ $$!! Th"EI PAd_ĺ Td>(
+R!&?w=w{73σ]^Vʀ/ֽ93?$H;S$qۣ^uLxvDN}싟=++ղm3Ja.n# PLX c5a.4
+%mU2LJd\kI_T4e& 4=1Ng1StOŴGOIiALA!mܨ1iVcm5{E;ErƔfхMx;ŪL!͂C:kXV
+'u٬)F?9^"g8kP,܉uB[-›?GUaa"ưii WۭO<O{w$>4%_iIk:{cc(%z?{;j6Tmg_v+U8
+N۾텍ي = ycEpM4|Xu$Qv_E#lW+G_%.ޯcU®^B<I${uxQo_6_nWE[pw<'v>'$z=׈@Äln8M}S#2\ U(ة
+Cs"\@PhcL q+w;:qMh*v(t2 K[%YԮMkY%lf {5a*P۟媬K*lxmªeK9E)k޲uuc4/`8~:ꚷs^pnv2IU^*R2s('M(|Tx~CzvISE!.nWU6H/ hsF2G 4O~M<ё0P ve 9~:g"~hxi^_̯f%"U1ka!**.<* -Y!F/C)uBOJSCquż
+ƪ%eحr*r>l{6HNNSS $<qb0VLy9ڂp]*@G9`'$rnNs<4eLߕG]Xq
+~mn%lB2c`0_Ty}ǧ
+<<S(W!vAz
+^jy de { . b@04H.AV䭣oJbfTQS
+d"jRWŏ*SqC 聨[w]Cܲ[WrݪJow+cK&ng šuuw!FF/n5.Gkh]
+D/ N"`|j1=%]UVb'U^g%n&e%7˸˲݆da
+Ѐ灅inr\ NL-pBƕ8Wv .{Wkgd8}8|j>b:jH/N4f
+y_/ݵG?ߥϠWi97m~^4:e0vR-F1[9=3ukb] .f=1z/|(\ԫ&]L>tk=9)d~i/*XM՘.^.=1?ФhψANڅ;/,)g'fFc태X^#mrzm+Ϧ&^3<Ayp-.3Ժs` ۻ Z
+\G ?:g#r@:Iζ))!k8 } }G`zkzqW"ηU\*jՙ Ue
+T1/!:OXT7=ۦIO9~'?Twa!+0_Kb[ͪث1 ~r57d 1_*Ok l "9\
+-|^#6%%r+$W5b>֜u_%mٽuN﯒ܧ7 LZ)u7zD!O͔5}~SY2-OZފFQD-iE$?LOrO[cU3G|K)Y`3Ow9YsRya䘭h YʄP:.-Yof\hfmxɐ}[S$I̒LdKS<6<SxZ㙵<=ǫ6PE{h<u$d)$K}O&*ɹ+dvҭe4S<򥏜ʼqɸ̡0"`{
+pXL
+K07
+Xld\i] Ұuá)Y>۪WXĒ;A4eH{w% ӲMUnQֹltzW&ūPMbY?ciz U1dy~8ݐr+1c gpDC=dzwbqvպ? _)=0.r$
+e%Ӕt/f0 ÐJ:S3I$j?Qz! (?ԑh ݰWM! bgv݄Hj#D%w=&1[!&1l@/Tf&5z+ ǶD<H&cⴷMW1#QEw[2JZJ="ٱ<ٱ"YP_MJwr51<՜<~y&~RB[i
+ϸgҍC/:w}g% oi^-jx~Sg}>]f?mLՐ(1;1Z鉬
+,*Ǵ?9q2-~$^)U<7cE%e
+KQIyi G(
+(xQ}(Wy_p^rE_JE<h[=y0v|*η}v^y8?@10F{u) O?c^_$[8Bl'B b5vooYuո3:l7൵C!miƃM#fr끜o٧mV{2Ϫ;Tr9T" xQ.'g2P$&3Ef
+Wp~n#pgH|~zÝX\'qP+ G5"q\XQ
+IXJY|f~ʘ%'3eIe, @a׃F<4Y*
+ۄm-/' ˸!vg{晱<iH!DҘw 1R,[b3 n=MDp0Mྦ `mÀ珶E3&P;&~牽<IOxN7|$ڷbNJ !nXKGT49Y=(KL/@~"'VxicXYSh9Yb}u"?m ,ЅS9><x{g~랗VjlR(=p`ɸ s=
+|W4㴻 L)lpeNgy}FVRI7E)T yEG"bZOACN-' VI*= ai7*<B@
+ӞĊu>k&UC Q~ ImᯏKn>J@HZ MRQ%C
+_AY"@\/8Iy :+k9`-p\0,JV
+
+(+,"
+N;{?3giOG:o_WrGOoMI=9XYp;.sɜҨ1[!))TgH~-rShG@B/8؋Ճd΁`R@.l
+
+Rt y: zN5[R=P&S9JeߊEsto6?"*J-2`5N%8<!FHRoGIny݋U}FD@QP+|>
+_aj/JiGHZȬxZX?Op!@ !Q:~>뼆BpK{1c{=v݄w -AC'G+m7%gF k߶!ƨir>)kT\}+qG~Mj}0)pؾbِPq/).q~}Wd Ytؿ}_6eTb(% KlW4.@qbkڽ_+xZ}QDDo̧_z}NWROۄ鎙96QQa"y=~;t}k ΈusNX
+/ 5P4q.XK }5Fpt0.:u]f Tbe͡D1\'p-R eP{BB
+ґ Q 
+SJ|ڜR'PG*ClhԲZƂz9}]&$yr$3]ǻ>B/qL&1"H(L+ DsNO"l( ĦަuǢaK:is]$|Sքv.{V;q\$sD:D
+fk[ٻ\$PiW>PuòJUrVװsJN:P<-_0%[l?#gdGTI6Ӣ O"͇PnbE;^AOl.`{67b{t/
+
+mV.}׬|ӬtbrNsNd_s?K RRR!uI1iQQ6|Wl֪F jղ_A9췽кnߪME}KeL%\v{fC&,-7~T᳢7R 5P:-d|?mFkrl`>L1&҆C ,`l\ a>0c B;Qp"",ϓ),֭%eJkὨH+FnXc^P)`f;ޯm>򙑢KGQhJmJoG. `/}׵5@.ʝ.oΔvpGTiw7Ytz5%i΄x.=
+Yc
+Mp&u9
+εc[hds^"/`Oh`B? |i l`6@ 6cNfuT\1 HtT6?DEa۴>O'4sL.!*H<KV0[I(2 <v ! @=Dt≛ Ō;H кa#zhHhq""&XOW@ tz!xıUj(߷+o
+VgqU{=ʜ{{ڲ
+K W'=[eC6ܕ
+ӱOQ@q+$(!DqFaqTB*~gG{m4̪-73N-u^oqp;aݤcpVf->iDxh͈m+; `~K{({#S=krYjergp.6,0{w!W'o_ = 7ox+xƝ?PٰF|߭)-FeyÆCtEDЫ(bBDLD/_[,u6HgM{iᗗXDs |=AĜnZvg=JZ<%
+ܶ%~,Giї79 ?'XI\ӑy˞5-oQNN4~$ #6N? 5~Of$_u Cz?m#IŻW.Ӱ`׬xm|تWJrÅm)R6z=̹3MJ+.XkXAGѐ-7y+Dj;)f]<eLڒ<*Iŵ$ƨ?ī%oS)*UJɨXF"%M1$>ݟO@(z 5\ЋRw_yn^*ҐjJOҤC7ry<Һ5tPI> "8Ui9
+*a@ApT$ *ʸ3t7.ݢ"Hx
+g;NUzTW6[(91f}Slkh~х;'5jluDV5rsVbT)UUskђNH qQZ[㋌I?2.XU5"IBO
+\1afE
+zY|c`F)zGB;R7y
+fBv\ 8=
+Zw<>kSopH5Gf ׽,<\nQjbq:%ο蕲~ZZY^y,3T/5aK"7v'uٿ]\8qZnZw+\V&V:}ңKdai* PA+ϰgybߋ65"?d^;鴟b_|&5>%>3 z,<_*~mXae
+Nx+֞dϮ:똅 }=Ni5(w[/ʙ#*$=V5O Z''<֜'`!vc!n̛ۍs7+洱˂ /e _Ƚzxha
+ƪ(g3x=k}-y%̭rJG#uҌ'5 `5\F*朡S'S[w>n4u6Js^doxQ۞5rDm{zI_HSkɿHO~(XBpӺ]"K\dv5}l!WI
+DaKM"K#(O
+o9Cギ㤡wDɐo*!HhCf!AȟDkt3$kxySqۀwQҤOIҤ$䶤q"N8@$JxxL,13܎+!P8bf:8ȶp"d(2,a@* 2d0AP"=>RW*"
+Jr"[=>ɓ~}Vݗrޫ}*{nWg%`iKX=ıMDAY86H&IE3V'i/o#-d T$N$?nElF5:_]Dh3h: 5(vq_yyn,u˜TqyȰPH7}"o;*N mv5 ;(0Fۄbg%3mp~u~LRJqM%1H91nNޕwlk9YՓ&hݵdU-؆ONuT|^T#s\=Q= A9-. S3թ@"yk%J^jyOyVcu}uύӚU셌"e
+ivmHY:Ug,X Ϛ<;m6@3}<
+ῥ8lPO4G  ]#b'0lA&haSFmP.1|lq<QOQܨׯ%' ]sX XяC¹
+nQ6$Cmn
+wY7cKzu^|^Rﳹm`}>qf
+',*#V j AzвH#B۟~:)p%z9󶔷<~xM{ګK;3FQ@#Mp{jQ<*w0&U,
+(4
+
+EGN@BL{mmMvƒg5)?vG
+ 44>[khp/@x
+(
+A
+(*zc&Zaqk,5
+' 9F,@!& thIC4"7H)K.pE!dEZ+!+{@ _I* # >ED/XR3OPQC"-ڵDtu0m Db
+Bp9B%=),nT 2a}tw5 G2a.r# ZK!aZ /zФ
+۩|z x˟o`—l7Sk/Vtf]yjKjۤԏYaᩔk?<q!E[!ln%ث[5 AJ [^^
+&\A9S5><!i&pz@Mw%O4Md!-} :Z_.bV..<ζUق쿥ϹߵW~[B{6]9f 4/WyW-G>́'L̢
+4"%ZDx>BNns"{I۝H[maVX9mvl 8f,Ҽaсm\}J(5i\!r4-|NV)Sw*btYB
+R+Qnt^τ+@3Иp.U\micɶEE%52z}W/t^Tߴ@L$I: *3 C#VBY7hi:1gl*O$Ň`\Q=C A&ŎyNU)ն
+U._UČOZb5/5*?ʂ?NbS0[4W^+GsAkA]{IkQj }VEQ-k^Ҁ9=q7hT o_w xSFƧ9h~0.^u~]wư0768gz 1š *WU,JV{A"֗s'еbӔBl:FlyZ
+3aɪx!P
+r G_@J+!:ҹ M0Wf}DykU~m_9Lsj 1r=|M#(`,@|\=d! bcwӸ
+#ph 8s1O< \c{q }1~90@117A19kv|8 -HgZr p| iivIц霞/23J~ЂtuZEϥOe}ۦ?ȾtְJKvWţCuUrd ?G&ypc6vtE"gl4<C 6@2{/ǵ:F55i fH5C~!
+zةq+|`G-'"Z̉Q ]FnXB°7㓉LJ_˄L^-mJrh AhfZ41iA 9{F w2y}y,2*vʛn]Rz@JbHV-+Ʈe@i+!߁L8S1.z57%^';kpd_b AX?#aȇݕs7z26 07u c;VDI"դw| 2q`#vW&Cٵ;;m,QlԴv_,(*)w0 ƉTvgIgYa[fYG ߢD0mOSQ/n#,|4'mŽ`sLUT}7n7@JlɌCd͠~Y5@nP;o1*W1
+ eQ,,;GHΑ[/RE*'&/dsjW#
+bD^ȃlX[Wmby f?ʂf?I7bI|nﱲ׌seK~6}mg7E ),s(C9[)o=W[٢Qcqؠ~bA H!i!c|dv8H޺v@8dx<jD=6ogŎ LsƌR|{h[y 26]cKrAաٵQ-D>dި Dy`ҼN޼6Εj־7prgҰO.[}3
+q6K~)sy.tJYJ;&[4\'W%v6: -dc+|w dd9*թLsLG??.dٮ茕牸ljA=3M/n.g*ۃX/6ʔ4-ݙ#8Sw[/W?N`&PTr@Oa+@E"ζH Vo(tN9e*\'
+
+
+BQԡ*xð< :@M-v:[Ĭut q<1 ޓN=]7Yǡb_#8:trNJr7_Ra^fϐl
+2[|&rk(6| (`%dsC:kҘpsGCqgh9)tQJRTF.)C%be T(I%w 3fDIoNIuC7 g߳k(vt@i'uYh 3
+~֖)M&Cӥs }{~Iaw=1%}9M5'X#N#׏sIדs=y^#. 36=7t13;ercؒS(gxL=1s-$ޯ-[{.q5yR쟖S6<2jJ9lac<CC {&X7AK/M?jDhW,sli̤>
+.E KPbXrؔ e??>6f7_/3[P<ϕ>/ _!.Rw<ɬI|P|ߝX8,n{ͻ$x^%{ ;<vEADyfѳG-Y뮉ֶJ:UٿW*Y/ʳʕO.7q_zPwVd<Вۅ{%ί?KJ荫<wUv ][B0
+_<LRYrW57j|jI07傁CJ`^sP\~|ސ)%.;-brJn̕"~iczo)E'OS+s?QΦJ5s F%*(Nj/Spp[1]1UaK5 &C%^UnuR: ety9AD9ՓAn-itbam78w
+C ֡T` ӄd\q&4DA#Fx0r{+ߛV^J1$0oCYQ
+C].<s"s-AD݂h!^yא&i7X5KV
+{ձ0_Am18%v,Aw,W;1'6(&7Q~K%}ΠFR'i-q_-OJޗt' 1OH>И2G|U i/o 4ZMh<Ԯb}TW̋hR/S( lM[j@M·.)_{}M3
+O*\9\/L&|k&8_ ק4,{:-].^N sYi
+]Rz %0Y3#( (bc[}Rw}qc+CtB"9!ĬhY:r7>39wGko]V6/.C[{)* pN9
+ ՄQU
+@+Ղi%FO_Π_XƵ>G B }vX] SbfWwMVҺBINX/[uNY5ĶX;sp?Fz<)z<kbc^At9-&X49 &prV;F%̏٘=s`6Ҍ^P'jcnSU8ƠϱK4iTYJ=(.=V l("*& [@Al>nEH$AiPQ3?:VA_4W2cPlUO篜?"X=l- XRЏO a_3~_x Hm'#nD vRj{#-CFORj0؁=K
+o./[~;Ae!w֊rQ]ZWުz*mBB<`!
+z$?bH|GME&yq|g0_8M1&Ev436\8`A%1M=΍M]]r<֮Ԉ̴,%|m_#6^HXkMvVk;i)v=4iNrmu xijܞ|ƞjfl-I=q,010qw.#6DZh\TuM?c[SaaX6,v`sVS1#:CkՔ j<~ LfU_'&j֠}U=Z]51kBGj]S^i_ª&X^D,/:B8kE>iK[^s?H~7}
++`^'0\ r@_5WN~JcڸkjQ%QִUmڐ*-YK?-. #,jw7aqқ0{N<'
+}ƍ1.4y =&J~\^<YǀAMFCAC|֘y9sҬH+q' !3~Р0`ؤi{j/+3GiB_-:r rt2f Mש;&=LOJmӁ((ak.{Q}agG!ɔܗE
+X\g9aqq\J.|Z݆@%:Rf?'2F6f=Ͼ=ȮK>՛PJKmz©=2rpZvx`׎ggH,kR5+Žʢvݦ6mBtBt^!oPHz&2"4<@-)m>'/?I\x9eJ㡷'B.bBiMxw~rۈf.}K iHj_[4O7vEA!$Ds\SrN)i⦼c$rޕKiIHM20s
+, 1SHH@n.0.j2|pŊZ4x5#%k HGC"tHs˰vD17aH^8؟CG"$[5  Fo
+OuxsjMSg)3wJd=ݩ܎i Csm)D,}p9gBER)\M+a${[E%MVuXy-SwA<pmB*6ئ#w-.DQcϺiߺ ՠuϘ?{RR>9܇))17whrk 8:
+nj8
+"vQr!MJNriSԣ?)\fdFlIQ6a&=|,H%bL$lj\l9\yj9lD"1
+nR:zVk+YEgRCkFR J_5RP
+"pu.PN7)Ŵ,% ؇S&P-x(aר̀ӤP^?GJ^iπE$`/A~ "(|++
+5Eb[LǟgdOedƤY;8JzL<o1(i!z# QbxG(?_^ևoW9
+ohM[\T^.IPXKOZ迼6p^ꏃ(F}qǽ(D]10~TG_ _ÿ+ ytSHmB}+4Úf$KsG5uq
+*{T8pDaEu/TԺ u޹=w^ι|_: rO=
+\HƮO# D8 U!| ؑv
+^T?Pkb,k1g,~A4"i>}ܢ_>ɜHj Ӑ հY
+ WA8NB-ẙ0A%ƞpAk9]p+Fc=epZ&v?%<ܻ4N,p4=v8
+p8`5N
+DP5 yLaiB]^lɴ'pp5'ثcCȌ:猈icB8"5Yi3Jظ;}}U]_g_=Y V>!BVgwMH_
+D[_9R6>#o5jp !bdHGH!tlHDNcOkpv!Bl %@ȕ<sߵU|_wr[M}e -ҒM=- Sv󵓆=e!a(ѩ➤N[0u|;!P ן}>EH@pGՔ mF- HlDևYR١I_'>Om:ԎnRs/Pr6\&R6{7a;x5׵`gz_W|U Ad6րI:} ! ©
+5Ө88%Ŭ{j=G$9~H_ݗO~'__o]ED;ehžoE U'8H۪zݑ+җ:#%;ދ 6H 1;q8cN jNj!gNg{EܥlAy.@}fbR*?UO^֨V4\W4]VԫjW4k}>px+ & a/Mon?0s)=W=.1J~,IF~Na {F0!_d\ԸRܤBQYÒzW5R8ftT).dX5-T% 右9?K8Y3kI ݂;\ޢv}LubEf+uvz+:#y|~Ȳn~ !D)gV#<KvS"m.QȮ3$DXG-*
+!궜rsKp}91q|;[BK=&J&&U_ +]U2/KN0zpX7w] \7+cAͼ54V[WZ6CTNZCڬ)J;D:r䂉RTkX,m2{{h՝emⷥRXi)âkGSIx}&뉯o&%6Eo$lM~g۲N9Y΋k jd%=2YqO+sj=%w<nͭCMdCWeYϫm"(!zt<.rfYæY ]o?<'=#ژoqCI2bi֫K'55ߚUbiL/jԦ;EMce[$)Ŕթ϶Y<yƝ)N̞ UB~,MPq㪎'bxߒy_-l >E3ErtkI([ܖ)O$%wVGܶXġF)8/堈Ic~cfHq.=:
+(
+ߌ%
+&ÛJ>q%ʸ*n+ާ2~|yiiKܥJgǟFj=&7랲LV^%+.q8*v: srѩBQQ 6?齍L7 5+
+v)lEڀ[ڳX=-8 Zv2a=<.켣]
+|΀`xWCuj Nn6viR400/c=5$]`LKlh 8֭D*ľiƱڵ):t}6w?b6i"ͳvH/p@:iڢ-ڙ[v I=38aZpm=ҩ ͽ9Ҩ\@D!.>'9Eu#i#ڔ P͂"ֈ^2O3LN{M}\Z_
+)Sg<g̘(cY*Q_دl[a+J=b!]+fna1
+Z:b:*?Uqȟ? xg]8f]0jY"rOaO^O~EqA݌^$zb^cq` `8H)[cw%oh]װn.4@@ *KmR"Aٔ"bUD&}a  Rwe !MEEV
+(wӞ3&4 =3܇̄ƖMz ktBV` [*,'ݎ΁Mum1.w]͡rR\{nw(;ɞu<}s5n%2GODqSL2 &>b6DRn#>ZR{8z \MtM>lߤsh)j};)ѱv|uuYH 7F9H1(Nz<9R!
+K\>6k^u3N9_ČY-t ǝpJ*n?ALRR67 6 s YGy , .T?H{ IP:Kh]t @` 2ɱ)\9W~w'6~4<R:eFkю%K/veKߟ*m-=E(:9/A.`a㍹uXD}CP_ќȱ[3<oS8;r~hIJ|],S,%ϭ3F},s|F[e_rqv%RރR s|,{,~oMOyMZ,\9Tm*c:"ù N=$mwCRn֪纹+FIߍ疽G>e"uP%zsp
+é Wh>[-!3[vY/̵ӢAA0EC>+
+8d(g ѱ`.rqUN#dZd3,}
+$:cnGz[٤4ZY#^p4WNA߰~=ߧALiEp%Sxj)/kj3p6-vY8
+R
+ӓUY|t|tt,^nmz.q<AwIԟc7nYt('y:jZ
+"VA]^;9IΙ{i
+^uuXu1;WNG1c{h{hs<߶jVYVa,:B܆b)ʱ].ܩKض;M&ϲm7[`!V0!b1rcmqf;N0GnFrjP7hV˄|wh"qPb=/r!GCH(Շ1ZD]@@ Ah?+4 R{FSL]xaX3oZZi[ڸ={~%^2*kľ& ʼL>4iw]wa&cȧwG߮#𻫓ߧf_ak ,M?<kSxuQs,Y1ӄCxtoEV%0{iIyA#"氡k b'{
+nz)HqBUў}jIQ4a3O3]g
+w?TOvTKqQ㹏=SvHpWA#h7p9tRܗmK#%G#d֦~ Bm˗l.iP9w_R˚eΐZ
+ , 9Pq-TsWd2EN*BT*';L%n%q},V>_Bqp\a
+?(vZR,Q.nie hT M/{տzõp/и
+OBd<:=h/4\ /살ŕxRMvVsW F sTQ==|t5{'G|>>;cXMu1{9o3>nўU?qלn]|z3{Go ?V 'Q*<F( ]+.O(:ʱvo96DU/QhnxlekT`1EjL{YŸ-j!/JkiGE?U›*jM5&IN&$dH||rኄK G$>
+JNz"զLקLgf@,>3U-Yu:<d${6gFM3R-;/dUJΎN0|ؕ'e2tQKV֛Wk|B3CU=$!
+}["O"c#% vTKmiem'[3&f<w
+E$m6Z02}6yR?5+n. ?fq?i_ⷲ!)sJKrIYd1I?*ޛŤS2'a3w1%]n-qq6JI1U/CcY pwDxpːkQ ppRrF6xCX5\n[fJ!&nֈ3ԨePfZ9 {eStDãHx.b9 ۶Pl<& >a=ju'9Š Q?{/ 9t
+c> P@)2 Poo4U0>Xݪէ1a<9`F:
+x?'wvxYk[25@Ub sNu7J7RgV-iJ6! 1o%W#!p?vcƷ+vE^?-
+@";W%m+5x-i6|]Ȁ.2o]yQ@j/H=O
+jtQ 5˽VqT1jcY0Y0x1xJ3&Zg͛\
+YBuuem[SU! sF|*$qn=2ьDְ2nLθVn3ƒS:E5OǴ~*<*8ê'8JbpVlgD>H1@\S?t7KiBDhnzNF6-!L.Ɨm=
+usfPJ ̡T o 7Mpsu5R͒T"1x 6F#?":#H?DH<e (XqM
+*b~(_*8z@:Ժ腙| MuOJNʝnPRPj  c]<{JF:\7%?ؒ=gMQO-bs|Ts0RK˴roZe^J&CvcEUDߚKU{?W)}M(ר\T/kY֮}gQCNiy|w|:ݒLƞiR8)Tž!d">!sSB,!O=Za*Qib? HtO_Ʋ;WޓT%\~]tg:ߕ-kJޞ8ؒ7rCq<KrQ}kDH}K(q#KB03k{wSt^=ysyfΙ>z='^Fv`/`N6ˤ
+/u }93ՂƞGmwǣ--F1>%vPy/7XvӾyӗ83Y3^ļql:;
+w,YB'lكb^mqV88~1i n1)zv~l pEPi+q[ɧÜ+`Νe,ʞyU֍߇y/(o\
+A7P٢mfUjEptu8DXCX (Cᚄ] V{Xlrl{ 14"oT b %z~5O(ñ¼*ˆe>ov& Dž}T *5fkyFԦD82N!/&޴}FZٟ\RwCv,C^PhA7(ϣ~wfzCz7S@9
+>HH L":)wx@ܮW]?nQh_ (M6t=NteΝe}s˼Ojn>ʛ0}'}*Ox亻@!K8 ^D:h
+yvS򹶓?X.ǻј}vHzi[~R+}e[ςV5kׁֆVЬ_}_1׀Z hTV=^'1vYEUbY[xm~7UF-FQ[4nxI"&^.ÈE X^+>:
+G!p "DK7!C ڱtof˰X,B2h}~e4Hn6^ɶBDRHrJ-$RV":$VDԐH:"k"LU-KY/*59"+ j B5jf ҬtEZ ʥ6_Km>*?^Jz: U8Mn*r_9.nO3='U(^/=VMmiOM L`X=op/Sq闌푌KpOu~aܧT =Оk{n>MCP)B˨bۀb{\K&ȋ+) Ɇzݕ -Ow[4*c'Xn.xU<Њ+G z|Ϡ=PvMdq#d|8b|0gp/ b(B%[ m6(ky[yLIO[ʜ< \ c<züdze㜟%dC&|_
+'mfs_(0áZ8qɥ"
+uNSIwDt4Bu'f07cfN-R{932t9O%T䖍awyZ̚zjᑏڈ>۽\sƹC5Î<
+vSqBAr
+QWkJ#w`O>EڇN'f'$@p\Y:fx۪gt m p=|\;R'nN3vZZ;rKrئH&9b)aHn$OϬI0yVq`qCp〽r$PSoޚo:־CR,M})#e>k^֭ҭt֯tY4`PrP7,9;*NJ7ܸ};nr_x~YL:s:EC-U4nYqz _[쾸&u\/劈4λ>Јrˢ z|,򎍚^iCYlp<m9aCjEd1eO_0ZXwԺl1æY#r|6{/𘳨ϙ{X_5mQ16aw4oT ]ä6nT_]
+mӶ[kCn|MJr-3+\4kT횜?מ8- &PX Q UF+~Q%yB!,
+{1H1Yb]Htg0=jྊg}d6> 1t;yeMĉVx
+9 i-ĹflfoN؜dcqKq22S^.?3#!/DߗNsXxOpw}U׼*uo:w}m-AoMLm|$JxA\jdTǘQF,B [9OؼCcy V@R8IH
+C?X ʄ΀ÁIP9 7$xo {@
+Sp h$$(OA
+hZ5QYA܏pA6? a`@Lk
+">"*oLAR]ΝΒ ڒ& ur:9UNOT)o(U$L܏ew0:b(GB$IʟQ9
+dTOo3S֍m4N޸ {&[8H>rQC8-ּlzpD9ОK*y
+F 1m[)_awmc
+<﯁1 =3W9/,Sp|%
+炟!ڬtwq6R#qc2DO 2q̒1pF}%QNw`q$;ɧ_n|oCyD}dK"d?D l\z>O`G:-Pv n6,YaOk(*)nNPV>TZ1Pry8&׽+p5ufKkHR+%C-B9/YTn)pcY"B
+ MH؇N!l؎w;ۋj^O̯{Li xiWܞR5YzZ=M
+9Ӕ9J;Jұ_dOP/^)D2[S
+i%3'gTkl7[#? rg
+M!D$UxP(Yd,*8.a(d>'ga˥CS}>Nkc:L?B?L ^t_lj1h|RX?@9<oGcxKzCȡ#Ίl)1.u* zS#P ^rEV"y<%P*Z)X-e}Jp/H[*N@zHmt:&DRcI)kJI~*<œT<8R<M-sY,b.*ak4nr*;.\20#y+sŮv,kV8Шa<UJblT o'&ȩF47釦$ GRtP[}sR r>/A2 zY3Ѝ:
+rk,`.*^g.%ڡz&pkٶ&F ly{^7xzg :hz;p̮E tu i
+o7 xwSgpQ^<XXOP7ܾGGqj pH~].MY-$ ړpįANq|wB>P˞+L=~G:=! /v$z3\.ySBRMҭH)G#']YNSDG,/t:'pjOW;^+caī-b%%[Fkl~3攉RkM~[Ҙ6Vє15{|=g<ۂ6s"쮰i'ŀs.Q`
+C'Mn(݀B6]~
+X,:_֪7 N4!LI|$Z!~r
+պ A!
+~tv:O$7;Zᰝ Pnf5B::J="MGJ+Έz=llrB=Y`(^!RWw W6\~tA!c^P;@8JU6qS)q^hW{!+Ȇ2N*NrўEt?TKz7cQfmۘ*9;n]
+ _kj~Z\:2- J}>rA,ű`;Hr/q꓎qz$ү2@-fv5%JYlnNhF! e6K!}U'sпQ0V!5X~h^Hf<%uQL햌~yڬp*E(Ȱ
+2( K~Z98fqXywiOGN8VvMdҧ{^'9솥JGKqe8
+C
+<Uvf8O*]\pv|J O_P!c.CR>$w,(dW'1D r0%jf!&LoC>&B.g&,Eq^gn;&n?!e7'oS?evG,%fµ8e<N32W 2 >Js |Q4ψ)&#4㷤43w2g[,E`2+.gg\\e} )5)=)bF*Lݴ|B"6EK~ϵVDQ8gYͳZͱ^_`b1){f]neM9U D&} zu D٘2a?-`?&c7Hq|&u75D6BQUѮ@'0Kg̨,b)d.jk{̬&+:?u*}T.mN r2w|"%LXad(0}CMSͧ$MޑS _QB>Sw_;I0X&"D
+7Ӛ8,[?{7y[bQ|vG—<o3]Q'oX4Y&J=+L7ȯOzX{p0rdǩPal0zL;w/Zǘ+K:yE)(V
+״=1p!s!yucHYCpqKX-hy[ʫ)1>ǜ)muCԱs G^+g9_<k$ Eĵ}"TSE(`"Y [
+Y]p]%a"m˞xجh)]>]6 /l$!}Z^GuKɓmE/;J֠ͷJ!]N^W@tcjۚ}8̔7W@SfDUJetB8SB8Iy,{3`29Wd 9zNo2d\ 5Vg=!3\t գͯ@YԨTiȆ=l}ZwLUf'kg5!w#gd~9w&=p3%s:%s*!c~!]ȒJeM ְđkA438B" abܿ I:
+dEy)Dozt-[`Z<p::ݒ
+>RYNJ-_
+_Wg?į_UKU·ҾB-mޛBT)|^{)P(T<P_I4)!DhP),9GFC5:W3buW1ur<עd-iy+AU;Ʒnv&%IX
+Ov fZcr]_Bۃt+Af|
+{V&sƂڽHA;H{>xHya>±Wpm3P#.eNXеX9`v1`i
+BF t - ~zD` nFVXXk۶ '{Rj, X˜'ɴ:4IN6Lmʆralu5ws!7^tf8K֔hOM] >ȕݐ]QI7EeN'8=/dҺ'4oS~<_%PLx3ŚY*a:?a*ds.)<N*I w'М" mP]S~\z^L3*c;zpVՂP|p7>,8{Tӳ+^H:gͅ} FH8gwp=r,4@ڶ<͹vOu/8u><7@ܪSdX]+5%\
+W}WAVt$ڢA"Jݠn8gcK:4aq޹5x Q7.\ar˨~Q/Ԥxv,
+bߊ6#r9*trAa %UEmw
+1x1ndRY.Z
+Vip@4ljsTQ߈_Рuh94OA  |ljjy˺' pןB.魿Y~dלe.T=skOM=̦<΂ 'WHB[>9G/cw(SKԼ9׆عQ7U?) y oi_"ڨ9olq߸yeMKwv¡zGʃG
+nZ
+nPs:jZhyJ<9Tnڵ89RIMU/`ȉF,;n+a[c?[vJSQG'SnѸ%kW'E2*5w|i}ɠkꂑ!vw͋vj&yLw*MX{&./e<^(c<)BB{h!Sy,>ȡHM1 E`ܢ[0~2G52yœ<L ޷K'L~ЬyWCQ]m
+\AMe{? ,m踮e& H >@A 1BHEZ(qE@R)c}sEA` $9\;̽'}>{#r}C< )LBʼߘWdUhYŪvƢzϒyƢ=f9>V1_P<GHNt{H8~ GO 4ai2Bd>#2ݞ"WӸoؼtw{',<VUb\ըiTI zzGQΤzƴ]kRw٢ei2t}%|65~m0觱XU~ؿdKֺZWB*24%^|I{#,^{LKhVU-kA;a \3n
+Í0p-bww_gXg57MQՕajƦ#R(мmi*
++ ҮjBjM -ȚMu[:'aQΦM53?V̭,=o:i8Fʀ8J90Ĝ:K*u_6DϭqkR #/HS$޸Uo3uӚ?2{X3y?
+"rR)2r'1Wqfr
+(Ҝ
+;Zٝ;R(+O=̒ц3zO(י"tQ$9F=U,|,q_\a&I>s^pwo:GgU/1}(CA{Wm{ ^7䎗0b"[B*JY:stj}D/p1[gnWO KX5`5}9B$o=S&A-ΟhDŽs`/)zssX83o7QΝ,lT,~s/Hؚb%gA0Q֩r 2wXb}-_N`̿#ޗ#VgiTe*f2z*֯tY< VP)br34l1cYo<<ߡe?z@=в
+r Hgu*p~wsr UuW,p |/Hgd7xk 8ñ*
+LSeYj(dmTw:}u!p yY4S&(9=:o`HYoyQ>Κ˘
+q%u
+K
+^ {
+^(FY?v2_e?c2cn;a[L
+CYHFtH $9Kq[nq k@b^~su}`u"w(Osy5qxRP躮
+ "KRD\PP PH XzzD)gg̙3{_ ^tO}X)
+(~-
+J?o4ƣy%>
+ =Uk_^-6ܷ` >L|T&wjrSʬ!
+G8;Zu\u-ܚ{n>(l9lض'RΗ, &I꧕]b>:Eo+&xy9[2^iIwQ4wQ4}7/]̉:SgĈGuq3IK~bzo@ʛ)O2^ѕI` q,X
+J a/ &/gv,ew,f@b*WYrLXI*$F(kO ĪNũ?莃< ~.2|ww`K`y5`-hK7%㛓Xrvg"AW4n c>k
+ g͆OȜ>3|9f1qoc 9؜{Mjb{d~L<V7@Z(%(@P8jF=Pb4'50!*T
+9BE9CbI\1"+\bV bJ`(raȁt]=ӆ}C:k
+CGP(!d f03%nx-[|0@v}S_ v
+,]䫋-ZMhƷh,ZLVhԬ`Hav&$p=)K%gs>3rWiA/k6ak| 5%rFH-Yn/{L0+ʨ~{Y.x?ᇙ1ی܎TG)VlB( [6,r[/2rr:)uqz|>?~>vQdoƭ{#Ckxf+]ێЁJjAMڠuQl#IRCP';4&0k#@؝ {) ׵v=Ŭ{[
+djˏ#"Uk*>.lvZv 3ir 'zܿ!HnidA69Zk ~?o5ݺ?18hbAooq (
+2
+?&CVz|1.L9D*tS3nK"EyEsOdͭޘXo)iUw{lw-!K_ tܿr9OGt!ާJv' aߑ ޳'kScB3B #$>kpً`u3"}[Q6Nèzv2/|g,fʸ3SfS1~I~CF ~<~|G6]Vs+uN:I.~g;f|j`OYg-$Y3j{W OD)cX= Eyg&d2M"'|I=EgM 1cGGQģAB4k qѩ0AnMpz6s
+o`UA` X{%2Xb"%a: !5q(>s<ߑr]?ZgSr6iIS;i:3muR;陮xs~%>}g`qXW1Z%lj䂟``Mߒe&sTš2f&*"3iǚ,fXk)\U",8+0XUUܕ+oޥEYk\KkE5yf9L: s s7y>b4e[>jk_D[4*q[&-../
+
++M hL5f,3EML̥4un^oM3u[ 9s>};>+-/?]5Taee?7Q7? #74&')J'Rgq}Mrl g˷49j,r-?, *UfdM/2>+y39軫VqfIX荮o?C+.i]=j`<99aL> =nn=ڑW`l3&6p)r# G_pztm-T4Mu߸=?_D_~syO{fO=k6.A5D "wp1yc#>
+$A"`@N`Ốy?7x NpOAN;@!JNp ypG6e1BsQ
+4ٌ?ڕzB˟7i ef~
+ Ül ou{T Dc35o:Yp;u{;uVƙٚP&¨Ֆco'!q:x]~ѲnBޏxM.ު$
+Gο6z4@XHmE;Բ}AVjѧc7</U=+m?/i;}*4ʂ{=@eb*UVd}(F&ɫRu/TK^!&ijF}HylC!+UHNcQp)sɝJ +1@3< |2AV. МjWk(-`7
+{BuJ}R_Y N
+C(iʦM>&b.3yF`/CHR< 3 dl}p/
+BʦgAC>ä#nᶇCɛƭo!POZ߷
+/pQ2\:q0;5H:5`pe# vKJyw|zM3}<?HH7C"7hRkpAZ׺Arhys#4YMoFՈkFWCUp%G{CEp/:.PԎ/^2g(
+"֪km
+(L @yb'Ɂ?
+endstream endobj 32 0 obj <</Length 63002/Filter[/FlateDecode]>>stream
+H,{≮E[J.U[)+)[F_3 %"6c;3-eK,%6*?23gg~_yssz^s|/z5>.;{@k[ WB 8~[]_ 'HօApSiԖ°6 \8\L:of )gc[40l¤8gu72v7-3gu..+<NǚJ/]ھwN@}Mo24`}(RpK7EH=RDK
+<){@,h y-
+}n~S|d$Sd2eg^I;/2?*Simy"i<N}LvJNƒH[s0ÚM='<umf(iYrd꜌3V*THo*+DjUY. 2|xn{"MLT[H!e§RSfa'ëS5 !2yBhIKp$%9򹰋6IP5LAKo#j
+!'YL>Gȓ>J<s*GAcjFx AojsݻLvS<G,sCX݄-xq*L%x b(yx{<JX%NHt[uIj6Co!SE$ YLФkցj䩈ԉ#W?' 4{|صF6)ik5W/|q/Vujך;*z1%lXsH0 h$x I@
+;1Ő
+] Ž"Zm o~|Q]A TMG:W TD.E;iF\W3j7CඖCp{}Ќ!Û:VnkN,b%n Vt/K>7:^jr|jTb10X; C_ {m;tW7vYuPaϿCEm@2fS~<OPsZ}PC4t?]Xל#oUc04{jAcH*S0@xD
+$9;!}ԒK3-Kq}-7[Go)~<k[DjM"Z^  /^lغ<m!CInU
+aLD2Iw 8@</ڧ뜢>>xr/#/̣XoH
+I?<!i, &\rq1Mza!tsoFR c%<׏=.Sߚ ik)oM=|J)$bg848mJ\'R,X QwfLFQ}(:NыtQRmJ{gxgmjÿ۵ t&?C=puϟZQWz<q}^]zMԞG@mm*NRVU֞4^ϰ.tAL܈aϤi˚&f⺰a4/{j¾WXW Vr5.6׭|p*YiΪYWiMUJG]Rpo0Ai:nP5>I7RO91幏`l!t˄:o7 M1]C 4~tqSFޓF܄QӛUS6
+ \#mSlPfeUJ"UWO +kbF9UOI3B't& &uv;G~rstF3" 9e+> .éu#l#2q_eK?uڶҎԿaL}QCJOa'.j;O^$NAS%z]%ͮeyy )+Hm{ʐ`pk9 OǺ%'~ =-ڢ0KZGoD}erYjwL]zW8XА4S<,Iɬ|ȨL%|6pbFF6^3F7G,Kf43gO6O5_xN3"`*΢3 XyrW.ny)25#R[×/V" 8%PL/WԄ
+C2?h5
+Ȇ|$1ei *VIL%tZ
+6kXfBS;7v2e[uK\>cj;,nNJ4W@-i=@[
+6N! %Lq%bž8Cq-q]3kc!쏰}[dt+gQ{џVFg#Zɍb#
+,Qԕ:{=l-
+ ^)Fi9j_N&dzq:1A-SX`S22 ?{¤jҁ1[<ڒnD<t˰̄f6nZ';\/.KM+hE 2ؼ jC$fO(xS4!T19+Aq21C/qx X3]Ϥl%ΈE[ΉF}2,5{~TԘP_e dnR7w[&@6R@ڝ@1Ѣ`Kn ^ȗj@ toJ`t(0a)rQ`G;7@P~9muߦ9aaV]XDxhy.hy/c?yh{hCe_ JUEޫR=L‘d"<zd.xuɆ{Ʌa(?"<?{jxV)Ā9}aoSoQIGxqiK8Z j
+SIFQ`x}R׈}R!7JѢta0MÏjӚ>siY9,Zyإmyz>KzY%  ~0SN)_BǍ+!(ˇUbw#bQ~ =hC"T\Ǩ<mB>p }Avݢ$ y5[>H{dr)#JpsNJ5ZyW2I&)Ĺ.vlϓ;M˦=~; ;4yTҁ!i)q&麮U缮Wu[ת&M4i$
+[yB
+?~R2x8fAlYoY2u;9k. *KE%_ۮht00b9/eI
+aKP-氒4mےgRI<+q6 aJisRf ٙpʜhhW57a׷cW8<u6Ms5}9m9w0x\\7irgτAs a0=8znp-;h9rwGB.K6} ޤy+LL]ӑ:]eLsZ(_2)t&ṳ#vn-7&H37{HW8tG(?_v?'0M
+ȡ@$
+}5
+^7?*]ixv謺57oy n
+gV $3Md\=wG@^$>SlZ`h0ad_{T'Kn?fӝ*ٓ5mYdGX nX8՞r%>/nCsЦ04Wӄ9Ʈ|Te;UɵJ=o{Ùʚ8ے%g-k#c-?p/pG5qۮǵx! IiGy][l>?#7j?JT}] bk e<^X%spm}" [tHD"~j]x
+.DҩGo^<\v\Z`6.|^/!kmIHY?TwQJTBX62i75BI?,0%kC6 DuhI{$2ʶ&gZ ˦Z$Y JcVcܓ=juG2:!Ȱu/׉t^&)pwH7"F~ovL9TdEPAUX _%4heF %PBb5z]T; P\-y_pArBόV@ ?v
+ڒn˂F)WEjN. ZUZBgqS^# ths~m>ox Q 9*3P\n)]ɱ7bc{
+wD |hy[YhSRߥ :/U&ײʉ T\F08<`WPѱ=IBTuԧi'OԲ/Rg5riӫϧ
+4 hE:^Q{R6溽WϭKMK>S>P)О)=ǔQ(G*E?UMWOܐ;!d ,'j.w%H!7#K:P>' ׉.pO3.lW3. Y7eu[*l{Jp]ݒJj[Yi
+N@I=8MN<Re? c̱%cWńlTو1R&ϤgdO~+4"_aB>cH21y%RHzX48-k5Mnrkmk,Y/P
+
+_+!g d&gL$F/$'%I_`g- Mr},eS5u[ѩq@"\UQ #,̗B ʒHB*U{jXI{?>99~̶:?y#c)hB2,i
+9W}*?ݮZ׈UucsU~p7z\|i<O_#s[m7$0<wbB9KGi+\/vѭ̭-l_vG)eU[
++䂧%6",%|Qp@,* ^D3ca7TW б#@k`x=SE0\MpzRs_rXدP|~AȓIS)iUqUD|5kQ}͕KG)d,n*HcOǎDEuy{<vԭ֫:sMZygf)i۞:Tf+k,9RX??i2UɚYs$c2z.zxugV͂zP>_fV +<L=KobqS,s׊cN$-IHhZJcP蚄ZTUǐ24<s)v+O7EA#4G+~8, bS B2~ݒofqecb ޟ$} H ̀XGܯ
+o`1)c<к3y{#w9>*"h!^T- kp?419wXQDB?m~Щ< M!Сw8A10F<AґScIa~:ו>=!Rq :_`Ɲq>0R(0Q>;HsRk2- 43tt9w<VOdRwQh=G1X"xqQ*,k>+d ]H, a"=sԌ>zGon.5=[).qۥ_t쿦aqR75T<ȑ֌t9JlO56֑;}ocx}E3JzַzsI$'BlAu+!Ƽ[ي ֌ Em#.lG3.lw3\Zm
+i&}C"y6 ҌI_L1gI7˥"<bGh*:M2)2)}fAddun7a{NN|?4QGC=~ zS^1 |$Z)@n/ߋ+HL.}T/}T7eBACCn:Lq=$uiRE6!K n3Ҝ!cֈG pOt7J'd{,x,w_6-X۝oYԵW̄qcy0<O'enQEЏNyq!#)3p؜0j~;p0o !\&v*ӈb%KmXsIR;Pe_]:?n+\Wn٬dլ|Y1̮C9ʡWJcvEn:a QezqE73NdI'nZgQ8ŏk
+쇑i}ZNtj&P)m^)aش، ج攲O*XO9X?6zDF^pzNܴv
+q%hR
+fM?ƷDbx>NtNp
+Kr[y)-N]B*bDp&>~6A1?6q9AfsT\+{-fq:8qqc/5%%uIGۊΌ75H껐<K{ڝ4+qA{⇂h3Hf7oD*hHF}FuqW1ȭ;~]AУ*$ ^?z![0y)x^Jo̍1ۼ_Ŭ膘?#۾ՌNdE*`qы-!;Ơ-BݍK?+-K
+CGO806*b7j92f+W*m%㶓;RaSsvvuvLn`N(XHk/ƭ&t1R.G0 q3j HnH*j3|>q<.A"&
+j*4[Yc7p͜mٶ5w8b#nbɘF-kQɑFVJC3=bJEUЗ#=ÿx< !_*6 =jo@By벳W}yo#k X/ b*`HGm5>}'`0H
+hr
+<H[ snOr?eqfi4vW+HEtd"ʖufXf6dɥJ,fƘd, qI6{Ny9yn U8iS~Jyg)'ZR0wrE퉆k/X[7)׎ROϬд ݜ|拸Xp*T|-dn@{yOJEݐε~^uTYp `Us㳊pi<-
+(d&
+'iЊ*Q.t
+ۉ /x {?$xui<n-Y/Yտ쵶wfqtkMJRЖH;ɖ &aC) jzӜ:uJ#uRU%T#P}3B%;Žք5yQ;Q+ank7Ns;
+\>v?MNK)ΓD7=?rUb4Ig^MJ>;Ux!.826|eH6¼md;dMnL2}$yh1~T:&mXlD!٦CPm0 6˪<Mò aC$[L*0'$[6CJQ,litML>~ 7CpwI^";{ c2Fo䲌Q|ڬjZi)tco.6ZF]>8#}P"m,Ai2Ppx
+ukа\yr3hrRŚuͫ_Jvv[ѻrXMaƇ88܇
+|oy+`fscm c%q䍈UЖ9XDYO%%$b..ϧ/w„%=: $a;ZKر+`O跰%Yٴ24,C\iBli\t%e5,qe1c{t)Zn$,qKe7c(1 5]u["k(?uUK6"|9{s|J\|C\rs|JKRl{{=Fob5q߹ ET\pU\Ѕ/+x_8> DΗ#D!( !6
+]%
+jP ~ e&/hmʙ brGm )mIi1`kM:?s;;Fs'n?9xgwez5p9Ү z-qwr% iD+J@Nr|LjlZ:4mQV8[dZCjoa%ka^ TτjPF%whU1'ֲF=u!CNmW-$|[uqo<{rnw
+]Ї1I/3[R_5gLoɘ(i
+h˸wፔ:[D96eP!59ż_2ά5jGnnDB7>s`ߺ3 `s~5`pЦF\A'6Ƴ{ {3rv Pl*e'ә(8 0h<a*9ԢI'>1Dn1acJAJ|>YMkynzxР 9`p oA o L{!ۻh Az}H Ϩaw#{M{}Gn&#. }\`A9lѯ`
+iuPC\EסǵPsӺP
+fsT)MbGP08!jCJ] 41n0z%qJ/{C t롆z +b կzbit ~(ZXI=*yBQBlFȡ'ả.rn/b]('L);}P;fZ%iHTƨB&J!1ec\4vJE̗
+k廿v{3Us=&^j1^#j1#*|Ǫ'Ѽ_Fk}=-vھ7c}{t0$lM/Fu=qU1lWd.4R\. m&!¸G;1/oG)(Qld3*s+ߕl?(lcUhU>\G2/6o+y+W`Z&_1Kw=$h p JpT@~\a$Eu
+>K0!]}<e~ϤS-yzCܭ$
+Gq2gL$WlӏhŻh'8~m*tsw"D(jEjNИ̘gRkflsx:ZNqWEy]_v^^\VzhrSfboη`Bw
+G6>el%]R cQ)ぷþD1WeXWEK/1Hp }$a(/Dq}T '^GF#y.:PO"M{R(I~2jSzO"X#FeJ^חC ?(cyJw^3{<5`Zisten$`@l"O%q$
+[Ajrm&5o~+lF3r:<ͯU=OJc{=^Q7c&p>IGL.}bu"7;pc.@ߣ-@;JFy[K'jHqR?KAo5 r[,n/32S˜ղӱrHFo<D++|QZ6Px#mP0R`qEEG ÔQz {%cͰ19z{z\ؼ0&BϗӿFr=f썘s"D:/
+=*tSyNsSj?Ns,k@`jH\Z׬[Hn1 ב@.Gay;7%eȓ,魕Ħ!d/b! #̿w ЊExݫ DD,i0|&Ka \4&"$ب ^*ABDi\)dہUK[jG_[c(\ZTj5o1Uw;_xڧlҢln؍ ?B/b&z ]+a|M)avm?疔+2vkmu4z`q`\Lkn
+" g[NJQjdzipF1ÆB
+Bk
+k忺_Z1jV {/i֨TZm(>iy1iD@xl5[? q%'!A(/3GN7"0-[1MNI,q\^uQr:MPGˢ5R:IU |΂`hL#I@v xB5 @Oh9'?9?aOH}q
+B1W` _pNG tT'$'Nk~mlLd5&\lNdb9"
+E~1Bs@qM=i6&-}ץz~]ot}ңڷ nS%Hs$OYg?Br:
+eʫJeқҶ/~ןA{tAk^kE>O̥g{]oNΠlxi"a|FF~_n;^]]Nsk_j)[S[},ww?g&9Zו#ͅmUɲC%jҢuj~ñv?%8=^Z}wt.dǞ;4CePETK C>qCg1ٱGqc:>廨 * (iw݆.] omZhB`:wu⢝~ӍqҍܭE&Y?y
+mrg&@BU!H%  4בQQP@"R
+B@rf>.*L`#|%86rTVQw/fP;D;rEEm ۊ+:;_]ҹh7{%ӦG5ףq\
+R`mS(Z9*?/lAlɴDw&"=8#e:.o{~lA4gw:o g L\~1>qr~G< 痏җ/[ͫh_ zaTc-;.67aMo [rÆq=BrnJU8kx{ X׀u UA;SKM+pMWIU%xG '%AFŧDzvߴ2Z͸jrQ`YuJٶ^{: d8\pu:}6DMO s;lهO ifLG#|;/`1nG̈́
+^tS}l꼿XV{?Z}끽UCI'^جGm)9R
+DͬaVkR&Q WOwEۚ<R
+@.?`-< Yuh\iv:Zj <{ μ;Pټ6dTmŗ=9r%9|ի1xݹ!
+\kYݢ}nc,yrVs·[IS͜R^Mo
+9/95)i)Sɥ)%!A̅*|`=s j<T-tQ %GROX ݋bOWF_\l
+po p*|-ʽJ)tYߛO2ò h*!_4E(} ,UtV(3oֻM;)Iլv'tL%"[Q1;eB8 El![΁(<D\a/$@P d8*q01  c!"6>,%^:k
+hRmҤm4ߎM0RI9ԫvpibвKk\sNQ'a|[t-%:Yaz @y
+߁:'Yt'j$@BvaلL]xU)fB+m`eY6)616й2ۭKk}Q.&(
+'6)J+]Ha)e\sXWctk@oY ܀*fr_ِ{
+۪G5zHMz6} ?D)# $H?2բCÓk2S-֊,tDV?0_;ܗc* }1RMlB!}~*#1NqũmT) QY~;*qs'*}sԅ
+YPh4t>t֟s{^`2 j9B %p"܎pw#0r(V;݈$PU4
+r>_W`Z}Orh`O1C1(<lxbl~?޷[=D\#M`$ǁIH)l+5(0@?ؚ |[1l9Mg(uSouRGӭfc&T<S8мLĄisA@d/ɶoץG֦P^M{7z41Qrb;IXo9,džʼ,{J{/ϫk_g>c2gQ͈a:ZJ Mὃ,?qZ?xF0)}p$U;iER5p#gP͛H/N>$o<i>gPdz8YXtmd-y7@5̝lˇ*@j#bkԅyzm_4hRBݞM{yZW<^B ^WHݫ|} {.XT3+uƗxMJ#Lϱ&_&gE~qΏ,Zd"}7_9;[/+3ILBmژauAyWدqB*þWsǔsf+Fo\LtS0z[7]ĝ*|`s&}/s'YE1AףCősjPIҿwTSo$ -*",."E,tB @Bs齆RJQ"U,DEDQy"HЧ|(ғٹ=3w{3'/tF C1f@
+ b-\.tS2!W%nq96Cw>
+܁ѥa͈
++$ ødV7b-Q|mA]ٝi&$
+[xoDnq-.6#u*z&bNh+<YO9%7mJݖJ!ͷY{ JWq+gL0K"dɐOi,;;r\eF!b\A䢩Vope[h"8rFZmZ /qMW7|tk _$F,wxͻϱڼaV]BP 웂W]IM/-ِ;.uY cYmqYطL}6% } ݉S=3y}9}Tm*Ih 'ք٬͌^ft_{Ex_̻" z}DK[gf%e̷ɂ;1s7?xѷ[\Nո(vKxA}Mk
+F
+]ټ pm~B&s H֬?[|46ν2q6<fOt+v+,aUeR}>QM_D5Vhܘ6Ƹ/,Qs e-k-,m
+]IZ*6m"5V9D~ c&'/ C=SX3K^FaPg($ GlԑV*)~ $+Qk>Qư ?\͋|{׽M#
+tu7E888 |c_ :|B-
+5/ [+7y
+.kgzl^k3zX~ڍQ
+=< c;V| p y;VK٣;,.X_
+h$q{%
+[qļ bUbͯ3Z%rc5f0EviU{!RDSAJWjwCӪjӲjâj_,,irKEn:f|J9*3TIt
+L JU@&L,{#nqZvt'\SQiyrR?l8!MڤnA{
+ ״aD.D#7Yf,f;1&Rb7ٺeϔ8SG:waxkjCZR]1kV?hS"~sfP}LǺa;4 dA9`T6;o2^5';tJ4{X0{TZpB/.uǏ^HH 繍 +Kfq-[ԅBZ"/uz8 7AR x ^{: })ߣD%.( z
+ l+
+%qHqQa 8aoE_n\SK0<~uNO<ůؗwQQle=ڤ)V}2ǒ&=GAGR41S0ZhÍh#hV :JwoĮ}Kbo#ҞzOEb$Òl[O$-+"g,}~~vF&UgJڡQ,34?(BD
+ؿH?|@\" mIBg`rmd<.y/rUm:f "Pa
+`~*(^TsT2avlT4X7'Jf1@\%FB1xVk
+[Z
+U l66Y6Uc+Z t>Gؿּ8 <k [n-4UJavf- <C
+>P ff1`| 
+N ^ ^C[sn[|v|V,}6lj6i_9Sl,Ty*s|9nʜ&g\`/yq}<|
+roQ:uBL{{%mөiL7#!~Zf?+'c.ޠ(ut;/y]I6Lk
+!lu[#E x@P2lᲡ0yJQŮr=B6@>%*8@`t s 2!"~cP0ۮB$l
+dI< o,{rE L(d P &pdbA$42F
+
+Sl{Q,$%\-˷LMx'm6!f1#a5+֔깉_^|/K}{0N?m"%-;`:cxO| G?|7
+m'pqR\GfG0Kl'SXNhf.py JX$rە(݆!2(E]lBrW6sUmݯ+d!iaĶ2aϿeX}Sr j<
+Q\0s 2^y̔031P!B d0$R]q5!=~;~|^g:뜵)~RbZjH9S[}~fQs9{dsz^
+xv|ي\hQ!wue8pաXw87Bl_k}y=P?yQH ꅊM?"#RPir$rRK!G\ Eء ."Ry%EQ_'.)&W
+_mHjJZj]<q8#æWYClz'zFB^۰k.FZKGYtƝҙ's`Ou΃)OUL[)ڥW9܇<Yvt86`gB7}qvX"2-:C}E8tGh'
+1(&q<QTҘZz.qA48=~A=nI
+^?gL:uuҢF٬˼gٰ~sDaL*~˶E ~uH:w
+ 'wB7pD¹GzUkAϦm_`\aRsH\t6yR-:ү )1H*BAhw}@x"aH6Af[7lrl%]c\t~e8N=0SP0?UB}S Å{GT#=ԣ='5S0\j'Ը.yIwFt aL!v\>bL a'pTIvWG9A(//1UǐfI wy?5w^^!|Vt>Lj=_g*')F8ac(86O9ή oөes֢ikj܌
+6/jP#E7hb&=&29'fLgbJ_z-{zdރGӭeQyk4I\~W`ZhIQ NAca2!wIol Gk3dfu_3"`L
+oPUB䅄y6rާʸE֕ŠXp9
+pb
+z|%?/e|ޕF+o\5}̢֏q,gpI<h5|zFjK| 9 ƥ&e3сwfzh& ]UlZbvӢ;?:_u8jI,)m 7a1āC3u|~9 oćlᅈ!/RP
+U( 1!{,03&d$I :! t; _r#{iAQHn "Prº-8kL cuatGp[brp[p>k8=G+^k`naR0G1R_qs6sJ]@TNu|Ƙ_w~rvAIh9'܅˲&ߥ* H2|{|ٶeBUY$z7./ٝI)hOyWʛM]H[̺u'KVG┠#i"9c tƙS*
+C:0vɖN mmtR4z4z{
+3ۑϹwHLx:CFx $H
++05c lE}3rk4Cq 8g2lceGpǣA#c}o+[~dE,`pdt v/ٍa/TB\O d0^5RY_C*.k&lϖ7 E9#U§Wo=rE$s csgPhL-jʚ E0&MAo$}4)q.1uߘ1/zQ.(9|{%Yce7Us?
+Fm 3)-X5쇖zCrֈsg-xbI5ߴhيv‰V=|֏J#ٮ#1u>sP5᫣.xJzbl;#-$=|&mL l'FX=htg۔ʸ.0RC7vKEȠNY˴zcJ1yy^ChAYǬ_#.e݊lXv6A{<BS{%PfM?G %f' כ%QOh (7lu'h~顜/;꼀QTy꣼
+6z~.Y-c-ꗳ~ X6*_܆Yd[]n}T{?WWQMz[/_gWMvhEmRFBy lZ0m% yFwR&l>ljb n3
+PJޅ>=p;|xU 6\ss\C,Ҹ )%\,y4,B륢n݋Hע%\kvcF430Xvndc֢R)K$Q$)u~w33sy>  Vbz{zq){S v D;2?
+v{)\|Wk` `P v/{%hBKUb4KaJH~-%-m-߲:Rk 
+ks쐜TR~_L[Qg[,hd[%KhW Gwkˁ1v@-K֦SS|?^bL|P%cE*SLeYnȳ^R_‧yK!Le$ajM_-}ܯ6KmpcNMϖCeN-zWZvSmڪ_qwثz+rưG%s FtwDy=I]Y»i<tv=)"ŪWyՉky}uI5vm86O}Ȭ<|޿&FMѪ#eAЭ>E8g
+s VEŘ1lyjy3 <d@)}OBӿG\O:gvfRXcd{!=˚pg~q5Qp3Zțaswdؑ
+vw[*\DUL$˟e jwgsG(8_}?Cr~^eOpGC(>?Wrnܽ1THP<c'F|&a2jHU !hΜD_J>ڈΎtyID@y`OQ6{0W9ݯ*0X-zj?%ҽMڡ|g qlω^ s 3?~0DS| 3] X4{|qʐQUTzNmM1"h
+"? MP˽
+4 s,o*2p#3y)u?`/XzdQRw`[Y3vx3SrK̛L4mOɭ9^kWnK,w9Ifq H4$ՠ/&5nvflT|w4aX->[.<e O 9өm̯vַv%{>6VfI`{9<`lF; :6ߴ۽֮vz%t }֘Z9G|3w^!&C+S`5zYm%
+lNy;'z)_0=b BȸmE$x ߈p=X)!'k;qD,kKl{*ZPؐI7eQ? 6g +$K= I@eiK:սg Z wp(\x ;SR6N^.x]"K/OCQ7ďARP~]h^ o" =c ܎lН*SĒnj4^5
+-;y+h}yA%9 ^@6Z9o8ݱ̇Qat5<#\l5)Rb폔aFRpcL%t0%ܧ?ӷ9h~ u:54t<X$<\0m]jRd&W
+hZ`Rxjܪn|Gs
+jEZL.
+mKqŀ.uxI'"w }Ƞx"-
+%Wsu ¦p 3sC'mk5pR
+<dKm{G J( tJ:J-PFEB B{6$D V{Rz)7"mIv~-Qo;εZQB?zU)ڝo
+ZhB%[JȬTC){vq;BNV=ts
+ڗDڎf+;ّc )lTAAs R m!B5"syW%̔L2ge.-uG%#t}h786'lj(i3RozB<s> #[Ho ?E>_\ܥ{7)jf r Gs]::y{87¬ p"5r?urȊ׼2A?_gde7?3jߧ FsgIFe{
+{JgJ sѵ.` BF/Ts/tlYO5Ÿƨ)a"'Sc1ЦqFCG:K%cġ{º¼IR+SծSuYzi:YR"*xѫn{ob
+J*c9.U}?Y9Og\1)7B&颐 j{w·a_n%p`_ʯ
+cVx&c͐9Ni9TGKayV9i|$M%U
+t B 9`f#1jSF6"X p
+a>R[r{l`l-7X~J73?*n+T<]ڍt|XI,q؃Ht r IZ
+9QC[¦GS#&Z-8?#ZYKvBLG4'˴]
+ V@hԓj2ځyr@z%z`yγQmtsR@_w0$5r_G}f :>cWVY+kI]h$Mt>\ ˳*.@Q*=)q݀}Gp*53?VQzYߟ~V "p?Rs`02$e7 ?K|L;߇N14}#j67pFĈxQV¤}c4a>*b7鰩I= @.YH:dOYsu${M(%ra)
+afsX?ƻ.w[Tvy]$bӫ.a9)q`7qKE~KHYGXĞĞ.h`}nۖ8VВ8g{ j3' _s [4'% x0gnKz~zӛ7Lnt9^; 9ۧT̩:v&ͲO^%Iݼ-
+AZw"b
+'XݑAIZ~`ƃLSK ]|+h 1Кiɿ ~EgD&@{`Z@Z\1P,dZA'(l#8~t8Y g 6(S+[?NgJrI]?C-~H&Yvs?dͅW %tzQZ(C
+NÏbn꽕3[.x y@{i^(۰82ԛmQ'ǞEk(<*a`4jX g| OKDxޙo; mJ@{[R:@2zO;$F,bz%[u]$aND%"Qs܇]b#,x
+w|/\R
+3,z+pԓZ<p:4MWj%8|(\Pr
+sJ)AcJF-8ZD'b]ղ|nd`1)z dRÅ݉9xG4[{Z95?e so {MZr}Ie=fIJnJ!R 5`RC,9˥z rǀa[23wz5r;o^Rq,Ͻ㿅OǩqQ5q-Ic=OLAOfEOT'Lq7I5 ywl^LtcL/?7t̋2^;˩8m\]޴o<o@`"w>}#5j;KxY9>z&1<IkxIZTy|1rfP>oP}qVWKF-erkK7Z]طyEJ"խ,pBiCyкs}խ:|9H11_*CEOKsqH"˨ m-T$X"Z E!PK,ŨN;ʴs,eT{]5L4¹s8<s,N}$N
+,L0xSr$*UQɟ=_$u2?P4Ǩ[-_hH^(P6SoMipBoҪg=b?q>xĿsټ,N~-nWJŰ9 n{Ǹ7s6V[v=wcԚ
+Bz߮Ɏ"žpgM[M,b3g2[3Gsc,.t"d/k{buZWȼwwwҋ|!S7!y
+>$U5JVyU1J$6U֠s ׾9hٱ=ೃ<SK!Δs%@̾嵸y٬& hL"P=K[\Tf.K׶I
+crƪ4v7'wS.R`oKWɅJE|Y?
+ɳu!nB-* > Z767Aaa !teh?ŞQj'SqIBa ة0Dw.ǽ 8kQз{Gn#v5DOu/6U1j>h@c;GS dR+z
+`< 'ge VD}
+ȓ&b!tbi(M/1>83$R? ѵS/ԭqּ`ת: qRB t.; b.PBF
+¹ 1t
+4@}4lo~p
+Ėہ*"h*H A{ < @-<^Z;wvy磅#U߿,z|רV_vPl=n5َ]3=󐣝w~ 90-(6.*EMT=t^. LGm- f?IukV`AL6PoEZatc8FE 8kCym2HLRpTQ d>m0<d(C:b3\ 3p^
+<_dx }q%B. S^CqK&[i.]}ܪ5'-d(-nlNϜywaO&.O3m|s.YR/84h8\!*vC6^SL:ߍuB;а$uaRi{uJ_T7#3/T `P
+Dʎθggw -BBI
+q'bOEѵD(V.kGLۨQI'3 
+NO(t{ۺWC23Zց3J&R`?GGGJpSjಯ?
+v7]+4nAFWxW ^uW7XZ\[ͪdZʾJ`Z,Y.R+Ev;eNPqAg#eWOy@agׄ^tx[߃#&<lTKxzJ<A*/BXKzl9w|ꎕF%MJr3EZO᧎d&JjlwH#:߱S9|By:vs&3ؓkFw[ F&OѦ 
+EJYŷGHNtQЯElEu3/L*I&/˝>Iꤾ_x6/۵N/η6%հ>3n!=KmdΆ6uџ sU:꒗<ۑBKp=VRH8" .L 7͋!LG"_8\eOa+bٰOԪqZgY4^`}
+}cL'r/az79 m1CRN6D/M̕frH eٯQEYuWQțn-|+s'Efmzy]yQ^diro҈al? eGUen&=$V=*|D7Ns<W'<F
+<GsOnjsS&~,aLza~-5zg;dx=`JE~ȎI![! QK.ǫMo)xx:T
+)$h.*!^`N(
+G\P
+mR̲w0jT#qL=AzcxWWts~@1N*\,mLǎA'\&7I#ԾWx0̖"/+J2eL2%#pA/?nx:a濈I&`\@\6)Ag>g;L´w5ŒZᕑFQX8}N'_ʾ!Œ7uU:Zv'i@X.#qGJaG FK(-x0oӤe#DH8 D)%n=qy0r:i$yTRy 2"QSf3m3ih
+&**((jn{iim5̴F\{9˦s)ioBKcNLⅴQүŷ{cPCLyztOJq|
+;1#mk-HyBnab?Ҕ֔k I5j^׹1,'7:. 1iD3f\; .<I/>ap6oThtvr.~6yj׍M> +<}:鶽ln۞ٿ / sٌĬo616:e$P[nuV %o:@~j^j^4Ջ@]
++Nh
+. [bT1q|U)RGV KqG)xKN+kQˑ¥hau짰ietlwAwe1>9ϡ /} z=sNNE9⚗7_
+2B<+(M|^6,fԻ?RŸ=Y,v)jb"< (+(b^dwU}UȹȾ
+Oթ%eF9_
+Gp.61f~$5]BKcf<yfzvmKgЫ0^ L.Fs\ol?3Y=ϸvo{ܑ=i]~cL%}8Xg$cK߬N/~S{/q-x #u =pq=cp+N%AR¯ ʁ
+xk
+et>M a,cLI?H$K]~O!{ϝ=y9ys| (Ab(D<
+(@|E~"q4w_6aϊ{<<ڲn6mY'ΫI'ϩgR.p:sGl^pA|4j]DZ[b:>^/%osȄ~y"}~
+[G{ӁA 쩣p!пE\y[<GjYߍ֋k11q ΃Yf
+%O7Fq'n4=+LX7Ŭ%5Gl^l
+|or`kNC0x
+c׽
+)3 f#RZ%\vC jRJ lLDTyBz
+DC~rWN
+ӽ+tE񟈢3C儏:Ť/Z}P QF ~IfAF8čpofj{pmpBgk,pR#}?Oes s
+w-`Tu'nhWp`+YEl7TW3tET&fI5
+^_Ӹa^a4+)b}kDz|"7F_~(
+
+Ξ4.[p%k"#eA*5>Sv 3aÞ^]M0n3?}s7y8^.v#MtCq1Q";-"J{WE, c5d3b0;3ÄNY52&ڻխ$QHٲssy}<=7?ʬcV?p+E%U
+ׄr7~Ut_:FhմՌYr9s*6k:*r1pLW宵5R]r].wJ}\wVTПv;Pc1
+FYD{YXmJk%PE!H~GIKX
+2r6c*:A* r, AZM)8Q0eU-arJY4o [Тl˼/~tvkzW>#j
+gwb6{ 20z<58D)m̻2+ @c(9L^uVبUuu:u ys^z" |w+d W.wXPƚ
+Ex;-
+PM(T#ޔ g & !p
+gRL B`BE0-v/NO)GY ]MMS~1Oy'n(_j$%e%
+cYrf]x|J8F 6;u't
+?w8gpw$޽,6Cg0N0|չGN0,i C= 
+
+Lԝ(^ܢ^zSdFƧڐ>[%bǵ=Y]WpS& 0uνWc}Q}F,Yu3Эiz37Ut?UhUr~c|#&fXv-K0:A@dvmCc߫)i`=ElCCd5o=7Y zNTdF=;Ą\TLAJ0o Z?0ou'эqՂmY7X|U?yV+\_XRp?}VR
+nX]Uؼ>OX۟&?v8kX7|+zsc4 G>P
+H0kq
+"4@a%Nc-S)QfK{
+92 ߏe~.{VyxL{,\ Y^GC{B6uA XV 9GAΒHXKt9ȏW@Vu5/h{7d
+,nf[P~_3ٽiͬa>Nn(ړ$6,vܰ [:|CU# M-I#Q"`B -Nf@3ĕeq%YoxYor22orH2^=gk\1<%1g*5A<v 5e$6A'a7 ͒DyRK$qQ2^W%54u%9S/|IHX})֞&-%/KFΤ@2iKL1}*.$.,nMSO'EM\9q&}5ax}¼gsJ8MٳRfpWLj,Y;,d0؊iä8!k0V3c.@~h@i\(BtrOR>+?z_!wL$$:#)O>^B:%;Ǐ.W θTg=k`F^A_O\n>Ķʹیyj s>]'f~|gϔIBmTt%}!ZC H,M۱jnsnPI:.z|m%ZYc- }n- zJ}Eolώ-Ď lKZb |m7cc{M١M- m9ݣ(;$Fȉ$${gu̦Q]z:ˠP5kA
+/V]TNm:ujNkANMeU tc1ȴFpcTѮPpX?QalFьn M:ŨжH`h
+4i1wj8r9Ic!O r_SBCuǶ,q]XQGv-e6\
+1c-U1˓fO˲f`_˅%^Gbge/UV]Iig(2"9kB9s._ƚ˿GS&CmDrrmb=\/F>
+BԶ]WD- #Fa>7Nt9w9T\atu@ ſo 8;PaR+ ^ㆈR1 .b ,yؙE;K֭yK6<ˑ+5'[(7Tn,szY^5fEk"ipDzMhEó"B !!TiB ! JRHN?y<EI( ACzv=3;ǸrӈTC=~7N>>V2$LLlv 5ޔq~ƞ(`O쵁Lϫ|7^
+~ibMg7$C|]u!ؼ/93g3Z"Z"C+h[,uigBoYGp^[hfktfK\z+k1' Gx= Mz63OhpЩvy9ar8|n:(M 3}'Ű''S8lzUR-*EtI@۰k(hB!D߈1L{Pq6eӢ<p°P\0ɒt5L5]O5X!R W)Fˈ_YB$[,(X/@N<!
+2jD5^f Yf}蹷-lt<ɠIŰQiuAX6䈱./d]Ī
+ J6np,fDaVbBj~Wp=t ]K(Hp^x0<x-#B kdbd)+>xTd9Ve|:ܮf+0+GJ˪&lSb)_!d]l@rrz|D',9zp^
+ W8PwDj0&f4"j< F]m0{{0d /$+`xJ^(Xs 3tT_
+#/a '[K:$~olAD)~fffg/(P.5[;PPBmUbv{o NcFG@
+YSO6Ÿ? Yn$<\Dպ8}RF>SL("Nk($~,s]Za^ZxQg~]ݸ/ҋٟh1ܨs|ڔcv.6m3Or͓¦i]&ʷLΡC,Ө ʤev]Fiz)~\DKol=3M UcS緃%mm݄!m)}ySV=CjBW+؟+^Rf <~̛INǢ̴~z.iׯm?|4 ?|"Tc|~\S=&/ܹ9y:э9q.clۨFYΓgRɄaD0~aPAaLI>s,kl"="$w_.m3-gڼ{`zw7T,QyU(h@
+E
+[
+΅ؘ9eCL
+ s~'}
+$(ޅ"HjI])P
+7CaPe(NYBYj@nk
+=v,q=aVОIΥ܉Eߋq;cVy 0p >gpfn|3縌6r%#n.a]5>shqhU4,nJ-dTN^hϊSarV?pnM~8Zgۃ
+QCZw$\[NÓį&H@$Jb[ Z+$. o̟k[Ih]uһfsr>LBB
+" Em"ت@jQ !hp)h?Bm٤`THZg}&D1#>c,eg<ٖlMދVlU1[lUN#_>e%80O`7b}1N/6Z #?1/te:.k,洞N,I+oMFcpM8V.ZsvtAp6KEk5qOۉ攉ԑۊs;2{k:մsۂ3cyK _K܁뿒 G
+_evƽNlcVvU1]úIίOhrz5p' <F庾0Φ'9ubBm%*GElϡy1Bi|gY\ En3en?.RU az9zi}wŒ6e8A.uHy4I}xh
+r5&IS4L>G i!cDȘX'dL${  ף=^鯰núȽǚ'0GSګD#P(8>}ܘO5N`5dE3gc C㌇:z\#(#lK<Yi/ ?֋tB6V=ijC/*&=V@|A(دD#ܡW=zm*9wRa5uOktٖklo9ٞ:s-J~k]Mk+sj=<6P$O*3*yKZU\@EP>wHȞwJo>tJ0ZV2qՠGw]W\pp]|0bS"R
+AGU G ŽY QJ oTQυuJPiel{j:Ŏ#O䒧φ%F#~#,ԒVLj`%n_p.2 \fuPq;};ʽV1lDWx
+e|1 ci_H|Wy9#-'MyR&W5Qg&PV`6^(
+CzB(Z!@H# BQ 
+JiHS~ qܒImINE%/'70BF+k>O2Ql{V&Hg\C޵>kIJAIYa!F&
+ƠOvN5gR>cXMo`&z-nV.q!nUMX
+*|—?
+х餢1zAj1g0
+_4XD'Lrɣ<ej94i8MCgPG\"?E\'_1e†pCޘrNfK\nU^1U-{[!mby3&귤تۤ\yۭ̆e_*"nE870f`{tY?fh_)@O{L^(4)5-7?d 6ezm3r"QQC׬ALJװ<\,cB=}g4d8&P D \#% 6w|ׅsƽz~J/b':M*6ɦj0+!=R aeJ+Ő\9U %h6@{9|Mtr;6(+w ׽޹ ;wxJYR7 B@~Z!^ S KL"C1PF DvwPC`{pj n {Ѝ_Xz P#
+
+ W
+%uh`%:J}d1i9An~([cbx(u Ʒ5-VAH`ĕθebG
+?KOm 'KBa4>Q+Fב%$m#fuֲU6Vbz+s>%e>a~IC
+m@-ܵO hީ!N LjAXkbQ }v"d8u\p[Ě.=efcߞѕݕ5Sb6P;"s&9-b/j㎔oNﻵ3Uyol)# r RrD<Q\r-J;S\1k8q-(LreA8uÀ*£twZ<Ԙv&zX/B֊nW"\Q_ٍMd>LCcekF=$'128K1Ke?vaJp2_ 3M8qToerjQ'yY'2̢_u.KtOTԔiLf?Nkź ! d 6P+y#*'NP/+s-+暯܁`t`9V}Tp(U¬@`
+ k0T7]zfӨjX)5p]CzTOp
+ _j-mF`.~п3"اNkUaq_!̬Z>R(Z5*ZGk'?Q{^)%2`Υ[1ʬSQ׼FB\EB%}ftSE$sc{Ӡ&0k(D\rEX# 7BH]($BHH 9Q"U.RE;:@"1!ʩx(l8γ<' `a4ml!0
+2g-Ö,|7 Ҕ3e(҂FvCH(d&;<ԣ=Q|{a~0=o`L!Ӈ}0l8Ĩaب~#=hC<N=ݑ4d'l jɜ8jxٵgEcmP!|:E>j
+tX H ܫ2ˋMiFҼ^nuSh:ǮoLv.Ѿ!ޢ6B
+"?< %o<Sg] /X1hA}h"U3"%cinInИٙi+1f Q^ARh—rgl7$hQVcɘvg|̂f<#eN }lKõ6ԩF8ʂo
+<DPhȿ0d)IP$Բ2o~Ğ2x\hCn~Ěf72XP\n#3QS;2h,WmyMqʜ6Ϋ޸z΋ ]C¾7}]yO:82A'WQ+E<3.Ȟ9Κ@f~vRI趄渏^ asG0JWS'%SV3W" J{q-}>>m>2t =2g*? @ɺXg0eH>}›GUPUi*w!Us&s,,uPAOҳ0ź'N&̸%u+Mr-&vKR!ʎq}֋Ew'TNNUQԑuckӗcҗfrF+]vcQ:JLL9uW$!/xK<%nkIܰSa=\m3a=֢'őb?
+b۳3C'v>;a0\ պbl
+omq6VIkV+N-E;>aHIʪOiߙS4uŸe-JBO+k̭OI_⺉#zcw#!G==9v'C]=-olۭ]`ѾjDnPZ `cխd߁-
+endstream endobj 33 0 obj <</Length 63188/Filter[/FlateDecode]>>stream
+H{8yn s- RC$V JM%̸̸ͤH Bov(.V܊mޗv}w9<{s!."Cld j 4kH!:
+!~/bҡ`,(d]Z?!ej]o@nHdz }H(
+EbH㻐
+Rg'˚c꘯ڒ';䝢
+D<Rsmc2>ye;fJޘE}o7m~>c[xmE7OG~=GDx(w֢֪cvʄwrVwUTlCQxOu\I+)`szV*ԔY0-
+ǧx>X |s93P|
+]L
+5ePZAsB|P̦&-: (g 譍ZwR۴x1m`}7ƥ&r?y^MϨ}dZWz.=z,z)Se+~J_eؔC[,5zFW 9suP
+uW
+N #_5o|\aMdkEXP
+\bKHo.ФRHBB/"T@,pի{9w{f͜33y_jҵ/N6Iw, t'Z,퍳WVcOb;M9.Muk!Iz!]|E+2ZXZè"!4­# 3R!73ĎU]3U.! K]u*譜F{'QzCOK~)(74M!Orj 0+$GxLe
+c(,+
+R-FY%VՄj~TMX"5)ìrJ朐T?-5*Vǽ
+Ƨ2'Z)RBk F<&""7O3}x Ǿk犝 dX|QKWO>9uc\+}(3q8d٩8r
+S9)MnPFgHH#<JOd.& Hzw8ݶk:>&!jĚ5n5aCFN#ג/%\L0z!\_O)ې<A|%{}?;O2ϙ< p+[G }KVʢWHA
+V@X& [ʾ3|3-r.5t<)djBED̗Ӊ<8]7bݚQ\0_xyH~{2dWۯ-4z[ '(ou- _',>xQe^'yeusD3KČrBV.=
+eg|@- rO\@*O r r`"Z߇,xd f~wDkkx$5rKPZ(MEnA$L
+B=(tg \ ^1>bS.shq4x7#|_M^)re
+`F e߀_`##ml17qWҪXm$>o_
+}ݼcD$[n\͑k CZK1Di^u*:.fL e2%!OS)8o", ~=\C^
+-9pwdz.tw`꾦Ⱜ U^Tau|KcʜC,^ل?%l#<ۺ_϶X7˙Y4ɚ[6ٚs6{.6}cڬ8@[%,mW,j|?5
+e@#
+h"~ ExJ+p7 >^ynGemDNeY
+.{ӿv`-)E)E_N֯ȸޫ`:r` F"3Q||~@|^
+;A1P1;*Oz@>z2؅C+qNRCq
+<67
+ݤF+s
+uR9fݷ?ĺ_){?9زo9VqqYY=+]h?ٴ!ޡC]:3 b9]\>-qTMm
+h;h>e<\ r(y>c2ۄ"d9{
+IP(rL=Lo[ηn"6 y*7Z,da/,XoZm_څ=`dyv$q(nUa°tcTC6Gooi"~t ⼣Wc,]t:}aŗ|<ulݺvG 񍌋bOL6NM<0첨}]b\[zݎ^YBWڽΤ?8 Nn)7[0FӄWϬz*=ʸ!V%8Ub+
+~b3rd2eqa<hߟtl4u'n4>}|Į+iV!dr:d@JovY۴;s3(a݋~'v8:\IB.z]VG.׆lo>[6՞_' o;wk:w.aRwYݻWp9Sf}
+h"|p|.‹y->^ P<716ƌاfӣ32(#材dELFx"a44_2x>s?N%?$Y>}zGq8gC?oK);e >nEo_
+*-=$H&҄TPB^dQw9sgμ­[a7D.
+
+ẍ́9~7uN5M# f!Bz@{`C{o!|O)b2<n0mF:w; iU}fqgGdEV}ßpoe\_˝DѯdKY8ZtiT"[_QbW;_CJ*Qg:?p
+LB9m]g!_ŞIL&ϯo.ʯ6ݮUǾƫ7r@jÉ5|rQ9e 翮}ewVױj)U7{N0fʂƱ>_l
+FAR{y'{vFKXnXn8׵AT3^d^Al~x O #O<Km!Ўz9\?AH=xO!Ǥ M8r,~:z,dvB/LaXb4x uvTڵf}!uWY֨\z\'ˇ8UmX3H\kDPoth
+0 Z|<5pƅXdi$Qnn?e-\bGLR &"¼Q9?)/pݸָBqI172+=٥g1]])U>g&TDΘ2vOlQt1]_y/xp[XWnDR"Zɹa
+F*;Tȡfy=Y$MҠYeߔ]1[#<@@6C?'I/c!aPÿeFi,$̊tD:ӖErj"98>1'lRN!J?JS:DJ69pjmzđ?~=b h6g3g3|=fa꩒ovqjhK%akW.>]pq#:4U'Ӛg Zr`N n?ϻ}7an3xK~Q̄D~M~-x/5 ?;lj@RTVXuR @
+"-B ,-"ʲ(D)"( U:R#P7qM9]7D438AKÖxSƭR},Rix~#.ߐA~C֋>Շ1H85n;fޔA]?T R+b(qVDn\j Ak~MB¾l1|>)b>DYj$\8dͿ5xٷ>Fku?1krYLMUPs
+[l|;t"Քh!.鱈R]ۢIa;<3)lM;n3(\J<:?꺂t мZzA"pwhNX{w_ ߴ9Kމ|/zNR#۸r!}CYV蟻}-K?iJۡmDb(G~v\*yz{"aTC>O][X6}Jaղ>0x5Li
+Ռ%n N]˞Ɂ,]˭?xu)ow
+~D=R@R2hYu>l[|7Eԍ䯻9#q\7}H7I}<Wi. ׆)'Qǫڕ#CC#%JN/PqoPޢ.=tMx 4<E*wX6Hl-6-
+tf$lm\ڔNmpE:Q)1*ԢLnG_$uj1o>,6hJ4N%ѦؔICҴ>4"N\kLܰZCJf9=˯%c2TGrގH?3@?tB'ʟخ@~ѮKlE!o$$?׊!F X|ʰI*db. :׹C';j\? psҭΣlR-(ŗeY&2 N&"t@&al~؟z/U8M@`M]4Z1UϬ߹3O/X#g,?a!$mMcrsg{bU#YU¦Ah\}ډ9D'"F&{\U!<@\0FD7Ȱ~z*vBJGީY_B":ҁ<DI(uЮ<FׇUNK;k5yL t턺aL0s:j&: @
+__ɓFYy"`x u2HL-aZ)sZ͜`WpFUPZibWMn7gszӘ}iLټ
+\x=m-Q w—/KC5}l ;_K.^);~|"oY~[>#~Y$D {҇/Aqr.c00'n:4қxEgρ7Z\8$:drUIU-)E("*9!J;QȰmI0!RUv`q!I3<4ДAzb"/- D/YXqL8}D]dHurNiWޝ?;
+0&418`&X$}`?l<_qe \{75 dO_NyſYJ/qMh#(q0fm"NԹvHg{B/< C"BrϐA6M'Á_sQ
+5ϭraSBXW__m!Wې-qhSnVٌ G[]1T٩w!ܭHƻH؆z${f:Bw%( E~+l,ͬ cFΰrZI*q 5)/<֚k=$ ȘSB :VLV݊'U%NdIx^_6[W'iuHߕ ϞQ˱R昰Z}Sԓ/T[JI-~z+:ߒ(xX5YۇfZ/lL){kq]T|CByn 9f sָɐ[q|
+Ƕá% 3mWӗ):鎋#uUyZūI:U^:_@y}5HU=N4z[w;>fZ ,ŗ[3cV֫_-d}. FXL
+6ϿKK3>J3)2T
+t0ͱz`3m׃եk- Zm7CcM&rR]x-OոG
+h@8ШZٿ;߱j1ݶ؞CW`_bwDpXys}F5q
+(^+=PCSJ( %Z
+ED
+ SC-sN л{bP]zޝ"=^dzeBp}F (&veIgnʭV琙s!zʜܗL!k.:aIYd>uX]CqV06,1DY
+ޛ:p.x(hi?'d63d~o6rHt('dNx5ЏF?׏B#"n#n9YDW+=nyԞ\5㺭N,J6~h߭pKzfơ.-^mёzŎ+FoLנQ nf/ sO>5<5J=JQJQ KV%SC,g>I
+n3\%4~6j̈1cC.gޙ=2,X#:ZeF-soL #@*Mr Os!ݫwU3\Z{͙3=M2cǘ 4&O x(٘9+{ozXbTVB"̼u.9;]-->w]f-`^-o@Tf\9|U5|-PfH 47[~n-K_©eoKoHר2|e$2~TY)O^M^19zQ lmJ̀_˘da3&22z%xyDr KNBSӖ?˙JtBK^V2/&h)zwSVأeqZ WRșcNh#"y0*a.>u%-K8qD\ jՈ_@7E,3ȚIʰ_BeK$Ne1de"m
+1DnDmͯ ܬx
+,u0NR *
+dQ
+Y,H\c.f nfH|KN׿F`f>T<wC)hjΑ7=Ja'{T|m|dV7ۆg!4p2D6avdS6Cl\o우-FQ0n%1O–U1YˊZycD0+ 7 𞰷?0z+fE=raۖx[PӈVeDd-|7u?a. O[ܟ>
+Rš//J aWye0g2SԹٔ.K-l e4lԧ ԰
+8[-p?at"tt:] *8^q 딏 sIپkZi(d VE50׌`)v0Czug!DϐfiH&3v4v* d5 Y6qqNU/Z-l <֭
+.[~5!+ө+N$^7z|c o )A6 M#
+uJ&D:O% ӛTro aqixh&9BZ\̧ݜs꜓/U9?=SICUb<AB̠N9v Y6n$/Y6Sku5
+qSNv"}) {}Jqsńbe}igvs;;C݈F<jx~mWp\‹ɤT"OHNs/ D/_u?pr  +ɠwT *<$G HQ:~Uv >i\f80C֊%!\u!A:u04'qXܛi%9 k C">9&QOyN: f[jq_AxA`<+ r V ֔f˜F:^W[]5Ā9=S1t,l kRq% j⦢cuުj> ۜ;13q qZ "XQV1w!$q)UŸe3AqsWe윔piD1A9;p鈒9F~-+k&p*
+#TE~lT\ s`SMKw . \qmXqg;1Urt0
+#es6"fǿÞZq,m# Gׇ1{_8l!b->#$>Ouky<N4OXrzzmLH9wy*&m$1T"~tzۻU?çAwlM{bL$?%;# O q1}ޚO}>/ywhoon
+ˡGP\+>\Š ;þ?~̙339s=7}kŜtr8:/FŧlϏ%
+b7bĉtq? ^ǬDbDQ}qx.[$/f1q7\4)
+
+_ Y !<3@o݇{İen4L*Pv|7CQFZ k,FE<k,_Q/BT"/eJ oPJ=C!U:{?R߄:ס8[ՂJ@3i@~j61yJ6|BM;
+ 
+T[D^( ݏF]PW2;PLU7ոC, XZotՇP
+<㼮_AXj
+h]7A
+);쌰Q@
+@)lMLd(OB
+q2uXN]#&*pd\=kdU9fQ1aq_`SWL/6. kwqh"9ՒUӎM<F:vѦGP:`P}Pxg>1)_rv^iQhXBh\@`TqNh7e3<YsךuȼdRB3 MS3$g,ҢVQ)' `S%{
+y!
+ R4q]ḮL :yYSB\ /#~׫" zbH7@-|U@v>aN3~OaL=zz"LyPi;3#rE9]fggTTDn>a3-1 GKYe"*B tUǯQُ?VIWe%X2'vH%fLl7n#E/jeNuڈ&u7X% gF`/a} o-e
+YK1+^&XPk",=Y̙󆙢rn&kYƃ
+#_zQ&IV!7BnE|6D|!ԓ?`IH˘eϾ5:[LUԽEq v,&t̉t-θP_GIB9=JC0iqCW}Ci!+m2'v7^u&eƦ٫շ%$;G%<2c`%`c?5N:{&tI*s(&-9-sq#c\)N#6);x
+W_n\P]]߀h. Y;Z8$5)&LxM蒽F4CqXjծ>܏ "&b'˰rvvI@X Mb7e#f"hHQៈwI_ n"sa2\7a CXu ]k ykui=͊S;E@Te^o*< md+!7tc;y9
+TAWw! ӶfIrE}@ߕBˡ0: @Q=[ OjGE鴣;P,(6C*MgbA%>@+P ?Pq(:*BJDN7k5v"ExwLA+SƜ9U$i)yBܔ4vC~Q'5mC0W'=hg=/lc&e4.1oY51Q[OZC\#4FnN|œgfNے1DP-f͈$I+ڸ[/L#}5%D~Y*a.$,etĮ%#Ӟ!3M/:͓q? o8Z"Pf,p&oFu|dDK]TitWg7d\7hlS>Y.틿bzHgӿ3ʈzRn䰪zo/?,W~ 0(qp.x38LZbW4S|RKdI#v@~粬a&7A8g>3ްW/Tbm؆#D*^3T?}[c)o1=;{.dYHw[-!Qcܰ
+fZo`,NrBCNCf>\t$e&Tw
+&G"a=k]3^ICfI+/n
+\UKb پ 2 բ˲BkAsM y(nEoV'ep>v:"ʜzSuFw ?5JpaROIۆQQvۼ8.8~w\;_W^qC9sZ=0J%u
+G!7q_?nv4Gf,
+ n *FYRF) -?5kb
+_;ybGb@{":P6<wcYuZ@r O8bv/~\)s̳$pĽ9{2FSƞ=Xf2où5QS>^^UΞxL ZV1̢y%rgǛg| |"ɈX%dG-P-QgiNQl8NPߕP-F$$>cE3O7I)=Ã/7<h^MZW\UOewkZ2* 1܋آּ\Z,>3l
+1?7HN$sDn =N1/Pn˟y~.%?l:.hF*mZyULn_@ްI#N
+/β|QǩL/.,20OaM="6bEy{-Կ#\5-'o;>5t8;>U-_[PUXr/G]z>?rРuuQ"M64Q4w>r!|QHZO2K+yňoԦk|x*G^Z<l~aJ.qjq,o4 paҠ.c'J6%_c޸%"SDգ } ^K)wOfMbO y
+B; <
+pxNd~J@W?r%yxH@%q8"JD%IW
+F=?^X//;A#C~czJm.s%{:1EQt(
+s^F?'7w?O0K.ük]ٓu u;﯋Gw*R\*Q<FAs|8*@ryMȃ6M$! &^
+DɟYE(umִ6t6TP-jg<fD5,c\NlYHe)'7܀
+Me iٲjUv5
+ptۮHrmW<T<~Q9UIuT W*cz(N;ݐ'4m;yVSا*0O#=*n#_QNJz<ەP}Q>}R|t~Y~ Ǵے Z axT5NKDw&c6Ҝ1=3\{P=:|B>gx
++F,~~Y#1⒤|I,}E70^0 4hsl E| TxCx&*wVV\ZdWM^D k
+Y1ِb(8y{B9UͿ-M:傭rɨ8ddmw(#cG 9Hix@*^5xI
+=1ՃGf&<V=W#pY:t;0St9n4\fQ wd cXz$O%©K1W4nUsZzD}b`PnogP-%RUú ܁&vŦqܗBM[&`]s%8FzfEK
+g֘2k[pmanO.mJHעc$AעI1+K+G0?3&h?BQ4c~gZ䇾ߓGYRlssșQoNȮ,JUrH~L v v\CcJC-9PB+$ٰ|5M-!-*\QMfi (=
+C U!HE@a :2(%s/ܜ|wq$kX`v39߶of0|KI6oR/=IKl@M)rou-Yȅ[Q "Q(+9&stYx9
+.oNj?v3n.f礛3i- 1Mpct
+/y,1×1/襱^bv8ΞNiFjD((ijԸMjr+3FXfd |/֫\nUΓnse~3\!96g"/;82B){+&
+MZ F]}rfwRz9:ntq^C&QRɵP/q.829} .ABvK45a6k>b+/QG|Ak|٬Ϲ)Z_5g>-o=9t=c=IiGҶcUo7ȥS :([D[LUEGɍn_-:#û:S.dLVOkI]|ל- r90 :2_I{(|Qdfj~\ZScQX \1f̬}i9E ,JE}!Fnp_F{s%
+AZghPCfv}yP|sy[t+BβA1gѰ}٤`k#ހz0w`k7ϩKُޡحOU
+j+xD¼CR8ZøvDYpp@%ޯPs$|3zT$W-Gct;)1ڔ]>U^v=$ ;w\FsǴy: 7wOܦ7&qIL餲&uRG)5SXCiÔSN9 }^Aohm RFIh1nc:Bzs*ߡi~Jy&Q2yc\qcDğ4󧷉^-e;ɰ_b?&1Ih;|B՝G(*m5t|B]@NB[by'1|c{-No(N78z9wxSh#T;cX̙3Xq
+|eVu>s{k=gvTq3s?^gRńB\y;.
+Af.fV7-s#38w>yλs~:k.O~ũY:%]2Dpy߄J-R7g &/w؝
+V.WP3KohbZg$__|uWL* +"0_RKX=,)?"</徉/yVRߡdU+a/R_2ナc)
+B$>#1IB(A&7_nq>q$<xbAgߞp;]Pi]"?wJﶊ~c)2K2_;}4hu0.%M/ 2"hIL [Zat?U:<;daeS1dGctfw.{6ר cC_f=&b-^̣НCm[эz7\{P>֭!/}grCruGL. V>;z<ݱlχ% E!܊I+%YLi𬻄0Zs!ͷpwǞ0 6}}ݣ{
+r@d>+o\*6F
+ \'@-85\/[mM&B&4>d ѶwsGCgS9]y7Ab t[g^rY'rrݙ(7صs/<Z:ޡEd
+:EHmkP~
+~YەseGג?0D>Jsטw";`&6'pG3tSr8'80cEa-[^}an Q cD?g$o
+B']-hU:u_{\)՘T]q
+ 2Gy!Z$f ݷe.)-9VDW{D=%"]SI/$äVj"V8@Y4X4+LS b(J}*IKzD*fsd~=NRÓb4h]y0!|6<j-$MYqYg#)mFTjFDn65PZ.]$Ž yR. Pt C!Ci7h uq 3>|/xq&)XFȈ9=xx{Xؐ;hd'?`Bo/h Gy'.؋bO{<g)44r^~P%|'<`2j#MXfY:O^>u)oЈF3[
+y"ڃ!ז.
+i]?eɺG]+r39@+C+p/-q:^guǯ:v&D누4ĄW(?k;)бkt_ÄwP=PrvCiaW7JtUAމE 2a/;U~DG=EG<C`az>:j8>6a dmG)-
+-3L1 ْ ه0Y'KnilE[z=-ݔ YTkI{y^9u~1Z|m B`G}K.
+rCK!+! L1v(ŮeSGJƿ!bw5*eA[Od^e ݲUo'WMwBeb?l
+= =捊1݁Lk=:<8P` p*8U_5qT |;3MS֌%1/hb~~ƚ w81owR78/^r>|hVa3k֡1nTSb~&uOl&e],/.bS^F $ Si3w'P3E<Ycobg?fWNX˷\+_upQEptaE<X`|rYneZo,/]}/[_ra@9iju"8vwe?l YCLjvC]Acdt^4/vyaW_9>;vo]n5|]GPXAqh5a`Wƹ8
+J# E`%̋͗=_!-ȟ&J
+|)CnT7m@3qP-lCMJЙUV qy1HwNtJǟc]M
+նe} pv_q)qӰ70eq5CB҈y
+I+9H3.PnI\?<Ql̤b²U%B=b¬8"w|?a-f%`qrh`t I
+
+NhLgTOSWM?7!tG _uDm"gv
+Q]l;*v\s^Nsߚ4У 7ʩU5ֹU-ѩMҪvjdtO(Q[r
+]t\h`PLo{Z}$zS0[Z@^7_P |U$C^_NOF?>]WGxvRgx=}Fg\}%x0h2F/^
+TB%{"#^¬syӜJh-p|cVgf%Wy~a!^Z]j+rh|+&
+GCgzSɓKI?
+ס4CM]íHŷ-2Z8+-г#$t$F[Sgro7#E2~nids3mb{Wr$&GBv ׼U
+jfBg [9-'CZ&!!|$$_@M_paړ&d+4xe1N
+XףG 
+X MмmN0mJ3[2>%?$~My!:/`ZgC'a]*AY
+ͭťI++{\=>ߓNtl{G9ݥmP+z..l'|jqKѹz'YߑG.ݪO;|&ΪU#غMoݮqV,`ѧ˳y/8?/zK+MaFQ%Myv*VUboAV5o8?P(Mߕ]!ET&B<BFv>DaU>,&ŌJ(1DluZN(U/3+yԊxeJI|*ar%If%uVIaHh*h
+{2G_L])d0')YXŬ)n1~g⪘=F%qz9}*V0^39| &_+J~u;QQЖXmPڂI.H奫g'Y!ݿpJKiqUޫ4m`)m8O+v d%E symqhx8Jj>yl/ 9AɌ^<V'*m> ,!eGmx& :]g6ڵF J[P0b>1O)-X HN91¨ϾeĹ+݋SńY27r
+
+<W>+9j9qfepo(ڼ
+F
+Ivs&ų i{~_Zfz<Ql 'A h,q-2Q <]"aJd~m@coU
+:'NSBC,9,MiK[|ڞoD!ko
+pzFr=aڮDGPenfp׎%̙S}{<gD& i{KV9X*fBVx~ӽaB+U?7 ͺUTfO \4]d7ܛm
+z?1%45ʑ"e2ϥE[ы|ы3<UgtiXvD!&.h rh!8vmAtm;u:+0Gż=@~w0fz3I9jqsbkGp?(r3x@@ DjȼФ?[{I#,y8Tk%K-r۾J"}GuK\kd1# ,dalR!2fip}ߋ|}*]|x=y99y.OP*5~%
+w>NS
+FT YNY72gng|Aj^s 
+,~[0w/qs?w7i' H2JE"q F!|!b^Ƽ~AErcYrǕi]if<!yV7 nKN1wgZ$L3 v.2:K8uS0BNRЩ~d*}Ё1`gL 04Buj!T|AǭBQ]BlҤcZNCilZErEy&rmͿ~ ro TmO  z $bULd8anjc LS?ӣ7|2)xOXrN":y11nšGފYΏ%XMaC: BqĠzCL߁Nps gz:
+j}b
+hWN3o)9mNx͉ {D#hH%MVLקLVԉ6H7&75w!)fZc& Iolڮ=
+$l[b [z
+ڄ?e BهBeMhQUaF1cglelmZf3f5r\[rDFH$<w~^_|s9r|
+*Éۯ y yn3y}?vt#|ىΘ=GiE`C\+8(Mݦ8 gg( +Bw*~#遫/f 9X¬)ьK?Kv(>S PΛV <W1&KG7JE𧻓[Sm!0lN4G{,fH)yA; ܀>%.@ V|w}-`SlJMm.ED}yص؜JJH[7?5frEyfLv3}fc"9)lgO1#QZe2tJ\fD{Q[ЀK#Dm c洰7&1H!!c:!mJt[+)m%Jϧ׬W9_$I3>K,rl (f!
+d6 _hEmaXԀ,l’ //˦I~l߯h^{3W<hEaDLZع>+s=1}.=x^ [&?Mc0g uy> 2|WL6̋<=xatjP2ߛ@_IϐIKl]4.;6(;(D (0s3@)Y{ù
+~:N/āx5?`gՀMX3q`r4Ϧp|]6Id廽ZѮ3`ԣmgmb]˞ܓuus6y:7rom$BOv,Im:"kL$vNw*(+NP=ի_1N2m_Dҫ7-!/#ZXrGƄG>ߣ}\߾M6?r:c)Q=tk^Ӧ>_[X84k}o:yX0c_4}~ =ASnH? %nQ=N ˓ fnM vݪ8
+[WC>TamǕǺbdBtoCAuЅMP)iLyϖd ,jJ>RݜZzݴzwTq1ꜳ"uVg; i^u2{aPzF:;Ej;,kQkm:+W%aj 0vVy˦5M)/%moy])9U\Qj-g4/Q@F%]A=!C6}f9=ƹ^/ ^F9>^0,. ss%&cm`]`]~o3k^&&x7-WM"WSjɫjB mVCfJ܀^ɘT21v%g$*i,2i27Z}
+ MdO0'81J1=7y(!W0L-J%rż>F iL b?ڍᐻy1vYW
+㻱n?*XݤNfERבXoUd7
+3;]ϒRbn{I%L   9kyl^sn>7~L?<ʵ Kb체 #RtC0eٗ8I
+ٍePHu:o$HiqaF>x^u_\}>c h6!û_)TlQ"aHFeo:EZE{r^O4LE'A/W6ɓ?0.!Գ$0K(uaV:Fn SbP)]ckCԄ~w) z|^.y$8&DD>)~Ov_m"l&lw'2çN_~gϞq.c(eMN|3 ڦIk;Q^]jLb$ "ukZp4e<[T<hʡ RݷENЎ5LRY<LYБF[g-W
+bp S¶ހtD6Kbn"P IS  =HѹEuC
+uPZsj0H1yc4?Dr?Dë,\w#,zxS!"=>k6ojuZ6飈8UC p莕u;~'J](O]q'.u$0v#s#c0c#k3Qʛ*}5cZ˅UG+;K`w&guǬ%Z`o
+
+<_km|%)_o
+3In:.c(KIP(+TTSj%UvWz9U|d<khؘ
+?A>sxa*SV@,hD*B̈́pVD.$׼7Yޑ<0$_l?ad[W@_f.+0kr8`34j`-e਌esU4p& =i]2oKnL
+F:c{&KRwrNj;W-_≘c^-z$a}s z4v^Ӣ^nNދn.x?V1:U~'Sa/g63
+)b ʂE:Km<:?7ތC4I0dciEz<TtyrGݟbԉ?KzMߙ
+e>+{=ytnƸbIs/u<Fw>("/?ۙ@/ѭ_֯rQ&8g~=c{. @7cuW`R
+
+PϻC0k8wz]Y>̲_w&usN+$ObΣH`3}Ws}W-W }%>}y|]Y.ou"0UC08*~𻜋s<ƱFɹ^农]-L=M9uH_&$Ѻu#íHMRz6V;{_9d1/mbl
+~$j//u3صP"Q+Ң겺%m\ sw3cPD{a2CRrKRJR==my~?~9#
+.uXnw^TTX>wHt2#p,7nB=5B#$NJ)#gf/M|O1|v/8;#|xvZpМm샮C
+Եެi˻)i˻QҒ{9g9M#g (7JG1Mzsڇ{NS[n3mN}ka=u*#?ʓ>(@ќ,<2"{&U̿,FRr0;Pƞ'"
+8<֐g~?)}K3o] .roƢ_ssQ0ĿX0_[ʭ.DݹhB W"XsY E٣"0X8D0, J|V/AuCߟN鵉5
+'tB +k#۴(2mN^a;2H#2)cv\^>Cυ/RSKmpX&h_ZRϞ(N>9Fk)qQ!3z1mWC6'nlc[el9qG3Ӈ'
+_y/q'vƇLEl7`נ.}H`߮I;qr.
+mVu*@\Wk
+V6J
+i?vRaXe^pwûE%WP<}ou о{՜^ܪĨ?)>9:1Q!y- ^ ܟ 7>:<^lHxc`ge{/ {B1ąC$዇~Ny/`JyoAZ!F+!Crt*оb j ]͘u'X.L6L. :zH]sXt
+Ze'V6JܠIVԜZ/hDҀe6-~po7Uw.l/#ϲ}5xxH!hgZ0LRݝWŝb{NÙte͔+Gӓ1/bqiQ8%E客y1oQzS9=T]JoɣJ9Ϩ&6C Hf"
+6,*PS)PJ $"H(+vWVE@`A",6.J73Ϝs{Ϟ=3ʠf^|14vg,d~+;%;# xۂ6½2u5L}EXZDH+ݕ%QJVw
+19 ߜ*X-XH`3g#2Cr￶(n΋edŋX-ۗW0m^skB~mr$xT~n_: ƽ`^XpCFf<=8Wmk 4^
+\1yX)ۿfLĚSf(i /Z|6~3aZl%;v Y
+? i+#da -Έ0LL
+JANh֦yOj<թ># :I=A6 тl%beօ
+H
+.{oG xm=o
+oHx7!n C. ]gs^f\L{E<K#
+-O,%#EO0@'1{":MQUr6FkK ʛ +rG댊8#M/oj[&!ަ5d~5gBcα!׳5rދ.sfx/r_ .sGxu1^{_W8$$cb԰^gHYcR(y9g8EIzxk0]|H䵡 OُWKyA|Q=ߛ]{?EYpjs8ً8iNtaoC y=depqNO0?7#\ZSf]ی[R: qݺ$TwG;۲9 ['CiM;6Fq}WQYy3ٔ.e?yҭ\@ErY
+JO Zxszhs w ԑאK
+~/MwEuf2 /SS&PQ"S&ćGֿ̝4ꔛ9:y<VJ~fG# :?BP1MJfh-ډa&ԥF35ұu%-I#uM?&wɄ{I^R].i>'z&+rdtT~ۿQ/btJ0<
+StP)m/vRz;Gz}~5"ez+}-& :SML]Hϝ꤂)[eT2X*
+@^*W>Jd܏T
+bվ:^G
+kuddExo]jTy7:'T-W!li!{7lx;z1G;n
+v•dhu:Sd9ҬRitIs1;T/Yߖ?R/-ksވro.k+~/89)_i;&/t-EuECzgtkaRt p=n߆:0 @@r@.eӈRntY_hz-
+7_=]cWf\vy"Y^c?%qKj6[ypAȂ,uV.+\;hGNeEU:ѲnՋ+ lP.}ReZ9r^P,@s@usЬA мdud}3t9N̄6gX :40ΆPJw#[m>Jӧ2I3'xҬ7WN3\q3㵰hQOxbġ]郹]YҼU5\mmH~~'i UruB $ҌΌS)KN;6' \1S괨^cNUQ궠Y蒀Y2ڬ%-?(wTTEŇ+ً{*#94TΞs?9"&ㇾ)"V|aʧ^YZl. gMEYۊy*Ƃ)1ZN[(_,DI]m"H/(5Icc&|ҐQQ!'AyPK1$A+>dDhك Qc L;R5?Xn>i94Q5"vDM戴wf-W0WK/j =k{A*E })l? 3c1Ze8Sk1Ezo+V6oWEE79߼A^A>eθ*3s3晌w&QcNY^Y.m4$=x8<=AHOK&c3abҼK\scG㘣1l"mLTȘi6kܰEo82ϥȌ2f6 }kX@]4Q¶ŁLJ2S^м'c4}M&>L$>YO6֪h;"n1IWZ MJ>^WAq+{] ɱ
+EuG9#&%eǺz7~Tat44G*)NU{U8T^
+v<AI:Da=~x
+(zE h
+1Rܔ;$Le[ٱc6qLy<2~ſ>Z{#
+е3"g
+>*pw~Tqbk+nȔ9#hԐ<G yO"z4.S ÇF "^Ȍ?Ƌ:4/ftn#S
+P*>\)Z&ZY߸9м=,qGT@N2eWlD&TI^-s՛qeD]ǿQkL1EO
+8HRFIO ~ާA=ӽbڼ[f,}r΀q uz¦+
+bޘN0'Sdd9 &W>/Q # RFeBMrE\(.Ch: @W`Orv`O}MD8!t+CT~T>(yG?D5պQ( x7A?DŪJ-Pr DQ}AWwT}KIסحuy{
+gU C
+}
+|t^Y,?2T)3?M$)'܌$sD%m{O!̱S.ȩM񆌋m5ѶY
+5-WjO:1',G>g,3"ݵϡcdH-,Gh}n,=7#ON6 i1i#V\)'׌/=2DQ:P'd2ݞr"- e'Hyc/"s9K~v!WMʊ_]WQ_jVmbW%%/Gr6nѮ<vᨈp&Y6qژOҧwQ#R]*a ?8
+댄$M{0tt
+!!a $,Ð CA!C,QDArq9~|>D(j;43<(A"(eTqܼ љMI ]U J|ܜK$LsH Lَ'*&AէO~wMǾ8F)P$]jW@=7_
+11+uJP @m1tW K@i{x9aE̓~: Eh
+:4nڞC]ÃVdЭ5}3Jjn}F/wV .x
+e%/ʯL^gLÑ=le
+4V@K 8f
+"3bΔ14oQl_G^?@6lZ Lʰ+E:^_^v9
+ԭNY\ϕ\\̿Z\%wyAaf4E
+'[]/B5.aQ/0oW⋽t_!7VMYO6nɐfj'/P̪r̬f6vJ;IEb<oP<TOJB=RK|3}ۈxN%-^6
+nvNp(N9VH
+ױF!ءQ1̩U1D7g0ԒҐj9?~`'S!G kwzS:>8rTmq9z!rZg
+l%MO!"6j]0v序b?Tcy sh`G$2:Ej̪Q v͸Q峁Mj*qUe2ȭ6,Wr&3*y/&83uyA}5/N;==,yk?lG7%=ky'\I#MFbO?usLc8礎;h̋w0M:sgTyw
+xw[ޞ3ݕ>
+qBj{|ZmƘl=_˫͟`Ns3f9'1gg
+H5F0Ib
+u&ѻ}T^~i>I/M .1ooRA~Yq8m8]s! ">u䈗& aH#Z::<G>t|r-6.=}ږ,$ N4u'z#Ϭ;K1DAԴla({5y+F"fXQP0j4Ii%C
+_A6W g<l4e@; Z^'Cf [7֍*!#G?FqUlQ|0m\
+טHM
+
+mcu)CY̜cy2 qn+enu_]Ypsm0b[(2 9t>,3"<4_%up,>\Z7A\g_Hԛ~Qo,d!jȵ'J'і]!!  ܓ.P6DA4Έt~ ow5xWhy[dz9TGC@L@H?=2C9Z,ts'0N6 pkssk˙zSu~b,^U`s֕y_VeAU<tN]~U Ў?WwCŰ+ud]gC h99k
+C#-Bj{#zFhgftGr\G"~'E',WoƬ3x"jo8P;@ hʀ' hc@&tDS/:vGzAz wUIJ痄ˮ{k_`it1[C}oP3gT_jj
+O58BB;j΀4#Aнx-k>hf.6_tzwv#iMR⼊r9kA*%򙎟e9NeH]r{:5CHVOca~a^t@ZO[U[2*[dP+4oebUuXh?<Z@Ulc˾KދzDhV$9o( <Pϫq|4Sf5Sf8o5d~1Xۏ?{E뻤㵠%^t],`/$Auy%'T SQ 0N,Q,cG߱dN $}Z&<H5y 3
+\*U@ޝ3IΜ|w~ۈ
+F
+nMER8O.JSeW>kQz(gäҌA(@(89)͞J8 e `>e- }!ܣ"{#eNoëޅ*io 8 mFO'shZW5ZR]Pgbr2aeerl))#5-řsavr:y w9#p S9q隣|z0Eٳ_Hlߕ}gxF @aذjϣ:M~.9-&ϟD_z+ssG ȯ]$_^i))Q< cۦw=%29 nKTH z˔n
+`
+8+J!7
+[]`x1}oj݊$nư` ̚g?+qy+_*Nmۊ= ir ;k%װؔ!6+b `lWQ>I"k-iT-qչ+'(
+endstream endobj 34 0 obj <</Length 62033/Filter[/FlateDecode]>>stream
+Hy4̨pKlBZ1یuΘ1#[i~Ye~E)nRF\&R|:9`TƝ.age22deR]S4dպ" 5dmԆk}Dz%35sR[jj{'n;99GoM^"$.GwP"d22oDtƀHi
+KSpj
+P~*8ʻ*]YKZI ߍ*7=A-a7ľz|W=^߆пLyaܐŃO5#~Ъ!EO[)h В V)Q\C.idxLkӚlGu&r^-9Pz<AqJu4D55JC>M%T"ѩ;"a`0SPsa}upkVI5-1_8 ~}>[:#c
+#7ю]['SN )qN?V{,,J}>,&|5tqDN4AդSJ]*7UA} IYn[0VXOv HmMr%;Cn
+۵ H)kC0 H:쎁£x.,If^eN\Aö@L0" d}(pHj@i>i=ᐶ
+q=4.mۢ(6#l[<Ph,̤Pi9gV K2m5MEfC
+y
+b;L<۞cr9Lm<뉭<ۑGG3'#9+];v]趠Y\֮AhWLU_`ـ_paU_7[3frg2}f9?7N ?;ӥ3f$2dL-szh5cI𾸞UJjbݣ&~\SЙaդ#ZR_7ҟD7_S[3W2ģrYO.m]z 5X,iN9SzIzcgW83Z8Rp圑†sEG
+g׈^eU ǹ5cK Qm8oY+K0 w
+|s< S'p%/˙/#ʸO㤂q2s$g(D|V"zL)cO(RL1KHZ
+ɋUoPg' H
+0n-fxF|fpoO~e;~ese.l5g9vHeKIc0Xܔ>GQjKf q-g!˙Gqg;=N”{'☻EQf@.usGm+"@
+j"`G#X-'-d_0t*+OˌˌW?ξɍs( ϹRg
+g'Xq  S" (1$BZplrGM-ګU%ҽQ1հǭ~ }ᎩD=JhT,Aѥ[؋jB *A; a]:^}F`dtjDQ I tGr{?+ +vؒsvĂ5nG[ 3wѽ1;ɓ! }f},m y5觭'ߎ_u)qcztS= KɷٛDHXa&&|IN\JEB飮Rwx0?
+
+SSW
+AP Lup7:Mb L @ zn] ;.XHk 0- t%˜xn"<#m+%oK|~W跈iҤS?Ʈ%]yBQZ`]|^lЩ. %~ȁ˾rbYA X.m٤&(
+Sf%AR*4+geĿ+J+jz`sz܌Ԧ TxDly4 qE Z4&뱉9.J $aTߏ?D*6-U
+O#OT;T /
+><?DWC>I﷮\'"м<Lh}%Bp.r뻦3pMS(<YkӵAX4XK}Y ܙ~/u=95c5˪ޜ^q3V9Ě)cwnתYfg k^w֛{3e=Y9=ża|0ME/u=\0m6C;0J?pQt3n31BTGk ZkhD<:@\yH'
+iOJhMHj%9=sxdp:+)Iɂ/<7n3pCk/pŰ[բ r;Z;ZDyVo:Z!p},a'>)ĿԪֺ>QS>)T/=SIXӯ:_J=>5uWaF1%jAtiЭ"3y
+ˊbŽ{*'`Rg(s:!&nV
+(A qIp,G^UH
+<VMpG$8^ȡmSo(MK
+p"1}YT]DzydvwXPAܿaސ3Ygot |a2˄IFsS'm08k@X-X9,@_,?Ηn%', !=% cBƣ
+Om.4cKť'+~l|mujdY0v jZצa=MJ.t
+_[eG7ےNJdY#_ e5ǹIu @DRVikhAJTDT#}5d e̗b $RXJH9-ٍqSG~S,km/ʼn2S~>OMpGkHU[K{QWh ZP'JCȥ T`D.GvGiBYro-[.,Y1' v<g?-yKdX#ۺOC`TC0/}_h$^ZnY5.O7n:A]_NO<b<i 3s=Dγ9vuŠMiXzMaX|g^LϻWj t\AMdy
+r8! DT@AYE_W]ys*n{A!iww@ϴX.OXyl̀w<+BAUuSe[*_u!?k``ز!>tҔ7E΍Hk*>zٶ>r[5h[6Bg¦TΜ8tu0t4'/{y?|L@[1|%S低/n~+_;G0z;3\D4sB=_H=o @D^qsX6<tĦSFuHcZljCjt*W0G/DDPԢ"=/t0q@3M&aS&m 6>My랤 kjƓT9w]ՓnF5}Ny뉼 r}8KzL:E|M5ѥG:6M+2NE?LӎM*(k Fot
+8#Lĥ5ŕpꌼ )EƔ{RuNmpѬ1ģ龷r\ƴ!a44.5q@=Ab{M%Pۦxtϥhm5&ñQMlףQn7}x [tW8Z~xV;澆s{Bi7
+9nɶxz F4Sj"ⳭEN/ķrǏg?׻]@fK&*LhCAeMKB<!zwdQfy=ˤ>Կ(<m#2uvGQg]gu]: g_)_^xQ(F)R|Y8Qؕ;.ŸQd(`ǎ_fOҚ3gO62ҕ4 4O+ݿ]4YҞ?Vμeŗs >epCKُ-'6efyw^BҹUʊ
+=iEtQx2FrW\SxV4ʩɟ䕉oC҂;ɧ&J&%Q){4OUq4~DIUdx fTO[P2@܈KhCq-(v\_Y[}SJmSRm>a ɭRӺ,%BRzޓ)W͡!kk̆9Jqy9](z3lN5;Ö9p8C3Oe92N^?H!Kt͑;gI'Qʈ;c&)a}L>x&MH!(P uthNb?C?ƼVaV] 6]aKaYDz4Kek$nܸٱ3NEp"z8)>!L߭עw^=w-ƛRˣl{)ڝ ݵME\6yTah>Rj&}fL+n۽DlI^~  ]3L9ҧavkmӣuWe* FvD*FwgƎe&޲Lm>C ' Xf^E_~`%YYyC)k'qkAĕh峜9
+M37}</>+?2_}Ѱg*&YgAV0
+=H1
+ѕ S U@fp!h'y_y'~*t8оd8IY\8k枂޼ƞG
+g.~kuJzKWsW{Uוݼ?*7 Z<H\?4 ڶ:/ w]C'
+
+P~݀lD Zܗc., ~r*Hby ؛s-zXOJya˼VAڪwm:9WH#ҐqOAqnԲ5#iv<aOɷ{=$4su#*lL>`@lx[j|[e:B'[V
+Vs
+U֋J5G)XSP*_Q-Ejqҽx
+o^Sj
+Au(z"SN>g^ YaW0aU^ڪ<hB0!f*OjiqUKJ=ftIuBcbsvG<6;b'ws`ڎ,Vuxs_WhN1zV'z܊ 
+*TY
+r"7oC޳tGC
+jJ9AU0$Fzz@- ѯ~ٮqCWZsG zaw4S|5SC)UQ1d(L2h*>7UO:U07"]q^dQ5"fR5bre2f&jsov[ڶ mBU(/0iB 
+Tmt'2/xRp*vyERhkZBƮjS!݀ݗ(҃san݀1}?ϴ@vNqKIf#1| ?f]-pZs]{VwpVTroY ZO
+sB"@̵-'"dz3u28)_r515=Qœ* SfW()"()Mxšc\L,,z/,~2%abDX1T\Y:_fMIb%{4u3:SFe01\ yed%hlZ
+Hi1Hf- r$?Y޹G<hq5џ9NO۱R3zm2HIfI$R, ;C N;I)6
+I©>{Z{FK.eŤb^,ۅau. l=Ef">WF֨3}jҨ55Azx>-,6}"eá8c,nQrT^\R/Jac>cC,3dVZ-Ȗ\Q^֕E3{~9sṁPfcti<XM>m^ۜ)Saf?al6U^Ԝ]aC~'{R[#`Cc‡aGiGЅꁔ*6%?ϫ
+tF'R
+D*Y'}/kĸAܟ$G 2LO3̸w,&\)'}ZqjH5jF
+OTO~}
+gg7FzPBp^\^T؀nTnrK#^wXɱ 'u#sӍi߸´^_:J0;Ysؒ; bĿ;`PG
+V`T`W7VESTC)Bۏ5DJQŦcpQ T3_pM&P{F (XUk/Qm!b>މ
+
+ɕ{XiQ_6C6d`\MbkRs.]5/3f.c܈%늰&B`}';;H^7WA܊kuҡOvegR~-\8#~V͝]{3y3<?Q?mɿ;Z%̅w
+TvY":-9N~5D:[`;|*fTS_UyeTؿjàRӈjˤzccO+gui"i<ǵKwՓI
+܂-{:WEfWNK>SgR9J˛|[rҜa5iި}^J2x(q\ IDZ-ylqק*Ó.SjyY"WlYG#=.5/ݰ<'S'+n\vp86KCC};/4Kl.J_#! [j,ssŦ|?Yn<+hK߀/1,\vy}$ :+%5Rº$4P$(p_% ȋbʼQ9)n.i)¬&sZCL#>!!?J%%)2#3׎iDm AWe*:<n()׷<<[}
+~鸫rޮ4Vr 7Rj
+~x[V6iB}_+<S8NZru΄\cWqc:Eq2$IJ]-]x&$ A:QYGCr9t4~=eD&
+ʡ"DpUe@$A2S" DN! !@0 G1\ B퀎Ǡ}ۙڮyBC<3wx
+tAEƷ>JN?>"7}H[3՛% Ysd:; X(L E(k~<a0n%j*ӎG`ƿ$!up
+TV?tj6 \ V_)\FC~]0J d)ߪEm~i
+@rع'uC
+a;A8 J0+!8r" aB3b t^ٝ`\1e,җtkKV`Ot9a.-թT)arȼy?Y߫bn97| "GۂKDz5F횶TBH B( ~G7j lc;@zpa5A}O6ڻY ]pF!kh UG i%>HD#Hoa<҇`9`[>SgYM0oZz/ZE[}ς0hB]. Y?Qb]]?^j]]\Zih622 xjWp .^Ày&=e΁)fI0I^k$\Kb["䍤ڇEL4kBʙfMWʳYSՊz)gVyR+gOUȳWIo<~%?lխwF^2X4\0o)K]0ߋU̯ze|U.cȗ1t5yq #A
+Ue-h9 gD> @.rTnÂ(ۮzuVQ6yfy~_oy\;z8|!?2UnP=GrnSI:+;ӕa9*?Oi2O}fM`mWKsIWKG2#}>u,3'鐢dz'3fĒYck7kݵ%Ya-D+£z\yB]B{^?W7 1;xƠ*lD[@~7?7`7l SB7_Յ%bIӝuHUGu>2"YRxpymNHSXaYև͸Ƭ鷺4VffpzG&rfs ^/ ZC n!&|o]@8k*@@rk )]!mvmKJJDg{򀄴%K txx;(Os¦k^kbkH>a"q?7~n=I8 GAi#V1*m 㷭ۖU(vÌycmXVl%1Jmn{Wҭwr1a^n7b7/7ծ\(wrԨ{f1Eqw6 4NB3LL\FWYDaJuC76d
+ t%GtױB2H'KOe풳d;;**mxY7ac
+-}U+~?2~0Qt1.?,X`wqW j%~PS0b9u&h=wcDr斱ʦkebTimd^=o7 Fr tDf>K@T̯rNa0/$Z<eHR'`a?HvY8}8|p^u\ڰK>ZSnilƥ^U8 B3P}T!jW ?%8P[^?Dd D2x [V1VQR?:}ƗW'(\ *^BWɏrvH@YLىCMiR,%@ 5T,kIْď+Sv?ĭcעȊ$]QܞFђvTPBZEKX*EDKM
+"njq#ȁ"bzɱ(Q:YrY c 2ŎQF#9Rj=SɸO.H\SEȌm]HGB{ObuW (Yɳ)2N̾r ☫LB?"3n0it4J+Xɿ|qQG._ 揔nrJ⌗eOlTNgJq ?emdL 8/=W`L:<x$_G > Oy@-V 4T% @GwܯPv| Q]Io
+Vrեu9;y;Q&/s]W2֧uq^95xy$*#fT^׷Pm[;Ck+I ?O["ɵAo+?m jsq}tzEWWuӽf,% 5) 7oH`ٳ2co{~pک}bR;͵UVdwvL۫A,=NHU6bG<6$ra;rB#D\+Xy;yXłl Q?P'caHtAPVۉYh iIz m56B5tlC~UaڒhΙ֊jk)sɶÜvnۚ'e@3t5-XcoG ƻ JX )M &r&!OL/,)IFw,?Hd5 ҏ`bti3mڡZXB/j|P'_ 4kU(jk/ivҢ\lҠz&}
+vR"
+<"-A2Nj7M
+2 `?X*3TV
+,08m@:r$t&:|>*<Y0ݘk3 a!AhVYBhberMTz^3Ctŷ<?@̙pEb;MιsOϘ.UrWzg7ݨQ*Tt1L 偂e7GS"K zKG< .l^'.lN+!d^;5lQ?3xA?` ~dp_7C`RFE)>gPn0ЃRUcU[T#m!]HD_gҒqOZB_SY56w#-26+0u}C32\Gnt]3<gv3T\tJEMg H=o e5ݟ-JNO@`#m%q"ݹVۃsXߺ@δf]E+Ը0wi}
+ kjDx J)R$8!%%7LCWKO_ ?>PxKE )_.=3͍yqLڴ˳Ķ|*ۦfWy& ޗq==wf4ɕ' qC$zI?[u[T|c=,Je|,f-2Wz3>qV9ojr#Nc/^1_ FRVك4qBk4$5m9^ ڴhnXŮ.O.1e7l'<+q˞i_!Hp_P:'Mqwhxz{CɓJt2(~o\6'7^qz"<9Pd%DZّo5+StB{<IY<qB!~jg.>=RˠJRJk^p:־25IKzueou~.G~5kCDߝIV?7) j@'T=GFwgP`: Lug8uҝeiNòt)ӏ*s4xee"e\>7hɨ0lh0pp$ߣ,`P@ \g\.B::G,xӼa* jVx,hȻ.Cܡ*
+~o S]z<舶Tn{lGzY߅'Qݨ{NYsJ5#Z&
+5,32cZM1ݴh~ܨXL1*&X.~\QZg/-1qa}əd*Pz_+S#Qfd4qIlb$63 \>`^r:*\E!9j3ƅ縓VlXiSEi*Qd6wU
+jd}逤GaE]?_84\=">QX%"n$4ep.]{F[x"Apx{B{
+B^' ;Għ L<ùDn <G∆*| }D:X@`:sHIyUkbƟTcϱo3}ar9WE˜O6Q=-\~X1y&GIZ1_`\; WaҐ)]o6&%Biԡm7~OtىM KZ]"Vǰѹݪ>WCQzϷK /~eCZǷ=XzbװaVҤi1t4z ֳ>cC.BҊy}EX(B P WkXZ!X]$B!FTCN=$6BitҾ+T{;{v*JRG}z1K߉FЈ;Y(C}_wU<vyKE!?(o]'.2Cuosu`S8]wis3Kͬo=_
+nɚ8):,G48[
+p;R균;$CPWefꩠ:(ihR{ WЌ\y
+W H<].~i٨K,5|⇬ZrC-y"2 rʺV,CU̢ӡ`Z/S6_L(k!VMrV|4 ׂdǯle}7ˡy|(C?=>dVl*M#Nh^OwMߛN^Mg;so}1`rwlSX1(Zn0 |V&-י$$\oD !~DðrbG0M T ׶> ;4
+8$ù؀ =sK1ҭM)УLqmS~Qnlg$||BN9~aƠsƠ8O~5蟭Y97ޟR]*Fz%5f9%k+j5jv9Nw, *T)D9~R}fZR+b5T1N.qGؤ}VGDg|?Q9cM_ 9#z.{UǪW YecYF9R3]팪wE& kv]O=Z`L#QuO15 HF`Z@?pW/ 2SSuqZmVBʻTӚX,/wB\.ݗDveKBvEy1^P۔ɯisk݂xB C Q~u=_^f#_ۜCP?Ce(
+@uQ0ů&O ͵G`ʊ
+-sB%fys#Ѓ BĜmG_iAE4sW+ QO `5~hR!3H5%v2 4^]g9&gp)"1\h<nj!EH<xc
+]|V#q# HMu
+d
+B!PQRT8kDcOU R=°y|+f)2ڧWmhF'E_L
+a|HQ?o
+}{?Jz/NdC: t獜!}x+K2Rٖ21}Qճܴ>֤{odp_3Ծ~^u5cBѝ6+Ș.zڒњ*uS+m3if®Yo>,zVE/m-ytGf[CĔs[bY܉i1DHU]fLp4ڀiҹ&fTkW}WrN^ڞ=b6,~M;v]RjUoVz (֔3({dbkF'Cf*ʨU5i\{ΤH?:O NEJS)Z֌2wG3X03rwM՞fn<\_ʺg+g
+2-,rڰ:hQH jxXQ֠irذyjc  YAsUGP}/v).9/;dq vJ&ܤv,생9oGS_fd>3bNٔo*s:Ο%H6mɋV&BHyCs\Q=naEjг ]dE\_xr?#=*E[#^ąW]tWg `ŽYj_X|1J:
+dX27֫Yrk#Qqg,#Lor EzvPR3o.`xfM!.MԤŤ\0ȍh4VGɱ
+| 5
+O npr^7ּN¸n^@4+ 2+ݷRVΞpPr [v-kEpJLTWUC9m8iAaϴnU2qlOu 9r]%r*)WBZF`?'zMτx5Ou2Gtw?][@4.&-dxkZ8eQFP۔2meHn|b&8ՒI[Y;bO JGuCqwf5Qm"e:$k!1q1S3̸PO/ "Bt![e=٤r3yzu~~\)ޱŒBpLAPdEoarp~4mߒ1 n5]p亲k.w q#ziDYINJY@4 jSܦ"^-' ͸KdwR&S$ElZngh»~!ml4EsmjM(y)bPh$@:(
+
+d% p#~DD>ޝ9fǦ ̡؋'ܫ?*p~r?Or} ?WOJpP9K;?r,$Y|ݚ)oSMrP>iwO1f
+{^]HII+||dEs*د+Yʯs\72&+n2Y1_j3^쟼Z%VO115Dr2k¿Vy :X؁$R06 FKk`:oغ^E΄]_Sjb`rm,LcY+#a:l_f<bOx[l\<&GWwdyj 4OdJ>d繤vZEo.u x`
+-CW_Ղ V @̌
+-;_(<*eD-7)$:)3C`s%-9#ɿ+&̈́䦍<c;vIh3O;}i O-ٔqЩ=[F'uY/جq}n#&kBt3V֐Q#@eC
+>}7FL/9x1mZpn[G/F99oM.=VE2L< Mgr7hdN50_6^М@o<$ u0o^J\w-XgY)T[a fBnO"MoKM`u؁.ЃڔܛeTZO,B~IPĦ8-o/v)C^U]ǾW5qD=oĺ"uŎOז;>^SӘaHy|ס nZEb'nT˼deN'lrIl,XZ 5J?j=19M^Z_;gg; x>M~[9}}On[?eO0x8вקarpt/s^rHӖ9BҼVD~*%}\l7-i'=HvR?o<&K\7kB+J+ 31~&i3` cWY#"E %*P[]iݶm_;S~=}|yγ^Wt|ge7GԬ\nnKF~rǟ+h9f=Fo Ah~rP=C+!>V|YwY iȇE~VъZ梥AhI -*b9c(b~5V|Yo> bd~Oez7+y 6o5I<1t(}ifdٙ33{r|;2={]UC]Ty4k'IvKI[6z.%0GK+LXA0ぜaAH]8*0X~Z ;`z)޾r-+/G  j`l2'2@/幗Nv<Hu&Y LyQ=z&U[fc#m崵i4O2XIXA ,,*hqh`y:!ω"z&*&
+
+%wr%aEpe(UO;Qn3 <ZkMMuPO\~S5qL={噮v3 <*a*<)p{vG'<.o\/n_m̾'rzh46zBeƥS~W~[vW|_r.>c(Atf[S QK~N{@:.ߚwHy{u9ٻg3Du]yé;v&aIQkGYQ҂2YGdQ^OT͗tK7
+uA{"SNIC&*#q?񍥕5IB|?ds7nW1?I!LO%hu)Fh
+C>TcNluCsmffږ#.Ƞ ߷6Gvd^~ ҭ Qh"PhC6D`=+_ |(2IG)`NB t2%Gfz#ԛ B )83GgPi< 8퓨/hփɭYG2`kP' &+';xTp
+jPepA"4,caEhVUdO'sgd0Ebug5B1F0ߢ[ޤ2n*WjbYl
+i"
+`'s8A
+ݛ{F~7\zU;Nnܖz cMeV趩{9JOC:[I)/{>Э跛s$.wu锸VlЯr0riTHA~72fRL}e2=7jYC}kQGIjyfxt,XXٮҾNN{i+=& }`!_ԳXmra~y]{Ŵ1ͺ;TD]e)aReΕeldWF*FBBH{lO'>0rB0e' .!_!I/2CO2wR RiK!cV7֍M𹡛05lڨZxm`&ɣ|v)٪va2GҰ)ǣaJ}W>H_yE+Ir)2W<^_xD5F<^;W%K ΣO26M
+j[QBN[3~ Yv'sAШWiËaV|Ēt ]][DZ; cB b*N\F<,.{
+rme;tny7"#]'phuКzڝ x]nosfAZ
+8vžc/J)Kf;|~Dp1b~'p#涧* Z-EGrU iʽ&>=$ۢove!ɬ]ɚ_F҂
+Ŵ*IPQSz\J)
+8iISH%?#;ͪPvUDF$.f9q;?9C??.LPq?Ji(h0o
+wt{oIއ4$M3NƫhY8M; 8i-&*7¦Zye뗮Б%u?Jc!FAx/ZJ`C,.KdZ\2-:lB|rmz ~6( ̯CWhX !Y^3?imޖ˚2G2_e|(nMvMH:|i#jqo
+ BAF 7` BHZxc5A"1`T@~ҁ{A؟b_36$wX$4ECTi6i.BI( i@""(zi
+fhVTVV)*pU(T+Kv33s;ԩ725&P ;!r78BK$ۀ0M- .m?l#Cp}Ƨy^ Iq<>mLPS a~/l/槃r$#)F!br~Ie_铀%S
+_
+ɝ\JC T^ X2§WAٮ
+FD+<y58#>pK/F%G-߭Q s-O[)7md
+A؟;Z!ا @}qˀ= CSnˇzGGhO##\jO{f\` 8+(G
+?xTp-ΜI]i?
+#?&%N&LR^y 8ݭOxL;W@x?!h2;a<fdVٸI
+>Р #C&oƋ2AMMkփ72Tv>*?ǻ"nD [-Ѻ-:5qڄ/څ/%ܶ_T=GխUj:zkFT,M XSot1 =Sy}kB]P81"+ўmH`lJg 6.bNk)R1*Dw";laaǧJU.qѪsPFOZE6m#}%֐ҫZ"퇦eC-<6A:h\msCTrr[+%v~Fиq|#<~B ٤uGZ=\<0F%sܶ(bv[vU UGP+ ~kUxn,$SnJ
+|99+b>Ʒ3/ bUĜ5+`1o˧l lXH1I&;~W!sP!(42
+s%YUa—\, _<⃜g݅Ы! 5{WUa+a{KCP$gɺlY w
+;%LhU͂6 h֕,hY.k$hXܚA_4bؚMMCYl&93iz 7}͠NNNYߍre?n|Law#hCZբ)7vbõY~YMl vu@M*hڥ`q>b5j
+
+)!@$VXVDRV,{Ou%悻̝3gN jNm(6e5rH)RZԔUqr֣z&/FܗYݗR K@^ԑ*?ݖX(#((jH[%E᧊ e^(Q|7YvBh(p
+ RaB.!kda{tn,ʹ0`9f X%*dr7dڍ`krKwx^sNWΉ/nfM-oO~q
+ا \5mN
+^z:9L87"BXD%,#(" B(!44]%b_)"VN8WqSsr"瞄ٙ?<Sd*AN2lVμ3 5fau >Y5Xޚ>n38/y{IUl9$ͻH s7+ʓ(<23k9zEji$\  u?>2203
+#=5-g<cGbIJ%[\_g~%(GeZT|B;:㇥p)RAGbjBH߬-SwC@98o.xzCK3J~cKxKZqqC~!/jr 0fڲ>vZi{׃_ܻSкt/PlV7 tE k񦏺nhyvl)":MB0l8
+%vHC
+E~Ѹ>Z}^k71_-
+W27䡾 虁(~}~JHڼ5US/f5*çcptL[v={p>^v/@LBKTbP9Ɠ+r{yTQ阬W:*(njSoߚn6gp-v*j(0^"P 6niB٤<Hp}J -]EwE/} ,:
+);bWg, N:UMfD%xop`aYWx' ʽ*4(P^{: j$߉+
+S :}.hs~8\mCjSb&&YBh=Co3C4XϒU72 +DUbɤ*<k2!0#&#D Qj|4BTNxݘE=IczO 2FcWȇj^w\؎>&IC<8dj<c;)$fHhK;FIy24op``sSe` lpxqsWH[ T?-HKQlex17ȽuH }1ND"C^h _dbO@C4MqJSİ"JĐ"#qwB?V~BF`Q! G _8kCI' w=נJ~M.G &moD h}5 E_A92QT1,8ZJoQDS§]>0%n~9(xuy׹T U(v`snEXBh 9ӆv%nR3c2~|`E|SfH x:}sނ,^ۗ<O@1gPx6ۍr;Tv`eS8Vv}Gr=LT.fU6HBҰ9k.S uհ΃ 2uz S R!V`jA֛ւ{+3O>mgDꥆ¢iaǩ˩:Ipgl|K;<vG A>9 T0\[ JiE I$Y/vFmZs&u5NyD9JovM:;}sj({4z 7'n̩yKQww.都?7 C@$2dԲQDj8Q @B
+A2,$$$a$BB!ZYT@D@XwUMs>}]$>πKщ֡i}F}]FsB~1`֍e`3
+ yh/ x`#%\7,ҟ6jEm:h:E<r?S±6D֟m߮PdEkQg;"m^JWr~Gdٓ
+rS(=?wf>-Td>vtF=\ҧ+"ޭbN٤ݵJaa=Fb -[ ]Љ. $r DD?D108޸J"߯G"Gc yR7d,5lTk|Y4f^H?6+"=2/
+.)M9ͻIk
+sDE?^wE9nFW)[a䰓.`n'
+mK3ˣ )7x>#.a
+[Wu*ey9WyȌ[K CIg[i|W9W69c͹#Pw- q/ 5Ұ/n\C~>3M:&Fi#Jd5vtG}r6ܵsM q
+lGb;v)\9)D$V!_E2M{Y75`1Gf*P8f 6U6W0dwCgX ]@Ø*W2PShJyʇ I gӿY1̀@B?՛@,5u JFfՀ~09gىH~yАr
+CwY`{
+ bpR?=꼁6Q+KrI a fFÌ[i1q:-q-SKjgOъswsΜ;wz@A
+Owa]Oۘ)MS4$OPRaU`?*rV/q,xUүY>)wEkZ'g\rGwW/V$YkȤt`SMb{,$>̃sn-KRоְml znB5όPEG֍C!)QOu=ڙA%؅x<'cm8bK[Wn`m{Y(k\yS{HS{{?*L!G:5-MrEDykxU2g;Y֝5[Ҟ3+o~DHte-VLV)lL\;&}5nF5K$&E(l4
+EcE$1c|S.yFHxi-M[&E7 xԐ2b 7ƿٕ>c6S-%O;b=f\L iHDb\s|Bs"&gZ?Ywzĕ8_ |AW5 LxD%Wy]FET茬^J^s)!|q>;U_vFZj'%+`#>Y#";)$R8=TMQM\u%C:H># 9w<%;kE5HL1Ctн:.N-Bp6֯Kj÷<`s,9
+p.zP0m >֠޴BE Ke=(CiWŕ⇅WO#FOc /zJfD}aB~whw
+k%̬+7=5ʺʮ+J5(
+eMҾFQU@V}^_r1*gYs~^1EOX%~f%\Un4F2L(f 滼L8N AA ( EX%CC'XAAXE3-z-ân?~Uv}oWW<f&uIL\rƸ@L+Seq-
+L^Lʧ"}-TA?C
+דXr.BbD*bP<\qrGn.փY;l6, )I{ R("@ )#ug)
+cdRjE ;X Ҽ`8
+iY]"ұd?)IˆplnSǥaIBvBj QJBfl#-[ ^(2.@;{hW/#{a#ۘc~wƢl<zBO'q:RS*D{jXU/#sǑ? ͻvh*9i&E:0ߌq;wƎGužw3n<#f;7?ص{X7Ȯ6[UB#$Q@AeH)ٍܑF- YG!߆8R.ƣkۊٿ{@K \D~ 4dX닌N SDy"ٞ GΆ"l6o9v O18~
+zŅ}beCbƯWX)02W-iW'GI:I6uU>]0G%=I1C["oJ
+{7_3ۿ! }HpP YFZ@EKvX@^[\%׼O*YxlbVYt&,Pښ9x-ִMYg[km<݌yoxe-g'"oՋ|#u\O}Qv|B7xCx~hbM(ˊב270jܷ<\ОU~]r,Z*-=w|(%<R>Bu}f}dcsD/;䭑0t4?`ڰw^ iUSZgWjj%֋".InϨnV.V>}F'{^C@R)pV-wWqUsW2р]}YY_e"Ƭ(u)癟O( @}1sϰZ=Eռ2q5Ddja"|.jǀjS4'A<g:#55 AVUv{gJ&wWN{MĪwO~]8V=S68xT`<;r\9jQy |\DtB^lIc n3u~43h/3hq|!t2|^izMqz*:L)O&vTEď1%Np.}_6gS2kU`Q,*Cюi?wG;웴-;oWl*BuY21 QD)f/fS1
+~0?nee3I ><N -h܀1E dE|?a0nPB ].gϛgLC̋YY)='Tk*w~_~>O?K1xG5uq Ѳ&ak &@M" ab,q(*
+۩eX :g1s{ι|>ޓ*Dk )m;"K'Y;`tVu{+L`{TjG4".&_?Xɹ6;s& )MxYhܔMasz<ߩ H҃Pdy#X_D"
+9..7;jQ2s^8 _V8+ʴa')V]#d4d2赔c}#EEZ>wgt<33;7|_?=?^a.kX2Ve5Y9{}Oճlf) &ca^H~蜅nPmn`6`@,+ٻ'y{TJ\%37>7d<ʺ3W쥑n ɺB!?.}PW9[J:EGfZZsRZ~XjFstzduNUSRE|4j$VZ7\]5|TpfX.ˋzJ*
+DDcjWΆWss1>Wf?1X)s(8m[dXf1 q['7ʚ'T-
+
+W|ݡ(y>$X(
+ՌJ{e\ V&*tLÒkFjF?r]/M,Wn>3 {l!eDJ$܊X L@p@Br r X@@Wv`eꮬ *,HowUuuWWuz71o%cjqbuz㴳TMK: Y{}>,iH{c\K{gXI[6~SL]Z:'Ok~^Tk.PH nLH)˔?ܺ#^80?8/9TORniz idgy\yOyn)!$
+&u. z_Ĵ5lƦprѡL'z%4%/ LN{6eۓ<ZZQ$1cgvG8ؿU1§,0|J,"M+_{S3KNsj[:rơy.6|X|e*qlLxCHzCI~I^bv&zRƮCsh`3l6a
+u(jT p5Up]YԦmEk6"ƯߛѧK K˘8xܰYi~
+w84;m3gQZz٬9<%EK'V1V?1>f|
+}ٙ9qqynj޲ lڞ ]:8PdUݸrT- lt#uA@v 4ANСskكZQډ,q<SY2Lxܿ}E-m$CBA9C$cVIPQ
+kچ&h(R+  3 e8RCJ_<}ȺŠu>l@W\^'鶮CKs/VzIB#|BAdP^lL|ɔg0
+nJ%"G crb |cB#vJ o?ȝ&.`t5[f@o} Jv<'7a=
+mUQ]FAĆetAxF={{?޷?{gu;\ jUMl|V)',F%D:bN.ke@Aw~A&"5#{9'OH&P%cna*-Ars"TU7l%I[8
+ hujQ@Q[UvVP8|`$#vj!p,G9$( #Oz`8xS<X3:ǂu
+Wme ެ(tez8knz41$8ƣi0WFE iN6ƍY&ƌmVp'?ťF-b91{UFvXpf-[tY߁UDۧqn5OU^K\=V9ۓdlyNvKԷe>+?/S{hi[Ha9G3HVhG.eW_Wve>>ya]H񄞃kd%Y}Z zRjHquvE|]{odAJȰa
+gd}u{Ҷ4 5dN5д-UTV>`HbB^:MYĝ6rڴuiȌukr'rvkҩz_Ѹ:gB_ȄNHCjYZ oYb#ä
+?ةF<ةsԫ{
+1wƀ1hV@2ͧ51΢5GLeO,eOp%W[joNvGX;ܐ0<iNυ+,ZP7nϴ[=ڽ^pB8{RAw)x59dC6m8HJycRB0,CRV?0<:Vҧ<<Hy4n(e>ݨhҽ6%.}ر)z]Tq<?Q)u:WG;s>mr^I"^d~Mٕfkx.<VPP v".mçY_XHlgݘ6iy(y2E`:U:E*7a/|b?l)gh™4`~2/
+`~W.Y_%4t2;y:ڴUi9H]q4"m l%BtM3-
+\WĂ89D/S?U,*HŽ~׌miQ-EaHTe`>GTzP'\TUރ5*tqRUms
+J؎JlJFz(ǻWMݯFfO9N8NjdxCLR/#MP<^{P60ER <T xc+F 2~ 0j@I-1?Jܣ$j밮њ:;9˓ڂ)cI[BǬ ljJIrk
+K
+YXxYv)NCRG>,=x?(7@rW'()숫5C ,iiWLjCGgCX]}A}~+==6Gڅ^S#knP n3t̊D6oK2+2:`0?oѨ9ۍ(
+m:n 0:S&6*,Yxm%)}ƹ^iJ"@V9 r
+"<gpVKKX:y)LaHu)UXۨZ4nBKB< ^ xad !̯;_3t!* R J(! $ RMR0PBW꺸",.(@{IN&3hpmEsϪZ N3 '?U<lV8aAm7EռbRNhD >w]o9"b?4,l?)eK2"/h9T*GdlCreO~>͡ u
+Mzu`
+8;*QOۨBQ!h1j
+^T&9
+2ʋrTAp}#ڱxjwZ͠PlYL
+3E!B*ޓ^juFi,T 0n8b:
+훨С):6FC&2DB0h.
+&~P''h"BD}6FKߓ%I Iߟ2 1Oo8t:m^ؒdInBJJӏ&=z0:Gr *i
+O8v#ekОA(rR` =k.Pw@{6gc>GAgL[
+VcrVd,Geq#b!4t}tUm]e1~^g;.4iw}RyI-׎%D']VO#lΠ`&=ƥNXf>BV7cʼṇH|dwߐIСG_פE]QSv
+bFLil8gﭣ-8S;[H$:-k-n5D^uZĄ/fyiMˎEgQ7&Ҫumik_:7i>6XZKҵUOWs'N=wļJoЯ #^5Wr[(t@>hӰ2bv4n^[:2r؄KoRJylv,jœ;!fNEWoq⢧#f:SW"$d͆lI)?Z)Ⱦu0=9B7]`}ƣ%?E5qX[
+<xg3^amGrI5Mx ϻɻsRѩ&O97ЧXBiA ^Ww!㋇ aE1~Ź:my;ے%eY=լE(a]ߜ
+Ho4Lkh1:]>[LF9KH&S/Jc y5R6 _*C:ҩ,ܙj;5eN6b'4:7qɞDŽ.<6ttw$ɈϧA\24,%Th~APnz# *;B]P> / L8s9Jd2_8|(a87^AQyr^Ert$$
+(*Hf!" $HvdtMxqݭ;pu>^W=]o]{+=X.;/#-7HUh"Q EXߠZRC`)b{
+{ӱS T7s!N !V2aaICi<4FuFAmߊENY~Dv_:e~AaQsw+R֋Kԙ1Ig,Y|<L)3(j`[f(g&w WSsD4KȐy
+2!M ޅHq!4 HB[.|?@("zD܃6#/$'ǐpTsxBeQyLUKh!h#!P$dKO: l6 ! #8qQ`1X(?@8Pq_QWd9ʯ jذQjyB#p!1oAt@gmѺvѓ*oqOMj&X4
+n<#E@(QoCA9
+BJ.R)aAm9M"
+t)Gx|+RE6r?ǣ3G+$&E9A&m>Ȱ:w[rrCy&Y%x]\Wrn|@M)tX ,61`r<sHtIqvdպCqMrQ<)wVcpeW`3ֿdUIr*#9{\=K^=~x?= \@!쏀]<'(8&kgGzv
+SgJugI%:Iqh? r0N"qt㤲-xSs1v?;5mO]
+x_+%2G<ԍ 59t 9#쇺16Fn*G
+pM'90(~S:m}9+bϯje^ |r`Ev^-%@RWLoģcW_W_̻[Ww9Q[_ljȝnϚȘfZԝ>N)}wyIoJ~Wϙmd?|V_q@S?(|XBݵg})/3jc'1o0ˆܒ$cAǃ42Bp#ê*ΊOVUy:yK:5֋ VH)އ4VZ_;e٪3O6g~_6z~T/r}VA*F׊Y>"+}]!].2_8cM;tLY&mZOl[_Z?R}[v Mߐ'`R+>CQ;1mP̘2, 0?pB7E_
+>?ɲ\RYϓIV=ʼ^jևLcZyʛrmIz.Ny}HC)ι&|bșuf⼲=ea wUɿTe6&xt}{K>E6{]2SV9晜Fi;)B֨40~說H c"3pW &k?Qn{7V7U "?EM[VF8ʸ4! kyeҀ:޷տSdw7 3)<eavj:hg;Jq!g͘Ǿ[~;FaWQNǝ6M=# zy|d[E8`cw"S\T Ha#IvF2BY@ۆk
+d.6o*x\[2RQ2P/JȚR(|}GØ/˧1GY1,JUNrYlNa#,ofW XDc7r Ҥ 7rDŽ)K<2>PHw
+Α)6I!"p V D8"Lfw.۔K!bE=M6CRjLff[w}
+l1&qMx6qʱ6Ñ]wEDEnI\()ӹ"Y(qdDubᐂs 5gx5U;Xy>Y-q'+˧7׿;*p, ?Ua]fޗ߶ʐ A
+G;58>eAk
+D/xB3ff!!N d]e 2OCȲle
++Dݥ "
+EHrRHQbqʅ~81FBѦ0|}rX_8#l0Fwlt3
+y#k8@9s+*z.tv٘3w/f^J_ʖν҇ҐL
+}
+;An`dV@Jֈm\sD`A5aȨ:rɬ5g`lZBYCYmzr8Faȸ>H#9 PTđi]#whLC<OX8 A=n6 f/ 9JA\՟bӏnSN *֯dDɦ5輻_Г~XXi*,`M80uc@:DQjyvsӺW2 O(y]4nOtD-p% lƪyFTڷ{6,
+RD?LGVXY l\wZ[!yc%zf+~i2j3}h.|c)ze*tg'kg mdocr_v]u[uZyV~TRPPQ!T%Y,]2`=Q"}2j
+kH sF GOT!RT TQOORN{HyOsKc=T/d6}GT!`-a/{P,
+t=l?O4V9U`3oOrUuZw]z[|StByf)nWhOiL lH nE
+nD rD
+wD wD qC i?f?b<\4[2Z/X(
+{7
+endstream endobj 35 0 obj <</Length 59966/Filter[/FlateDecode]>>stream
+Hē_SY{CAi4
+A,U "8" ]a5Є:X誫¸ qXqQWb%oy{~s=~޵
+ TWO
+b1e #70 _4QKQ!޿ C`9!nBU
+kYT+77<;ot1ob<iŏ^%ns}P,b)θ"ݓ&Ri]T@HӘcҗ^$/:I}RCWhcH]8IS $OBGq_!x'5 W#f ?"M#5x!*{DVmPjֽ#׬y-^ʭokowH%70\
+A"պ`<r "ra3$<9G$\lpk it#zcImQ[r݄r=v?2>TҋM}A6Z熴K &18: FbU V v{AvDKd U)@w79ʰDk4Bz p Jb+!Qڠ9}* 9N!dܯqPe!_"k& k9#ln<M%<EMc$gʟHO>sޅ,ETeʥ ex"}Hȫ+9vqCOlAh5;!kD1BX)jlEtw" 斸<d0~%[8JiCxhSNd)FAȴ9{8OB'd:?v ݣy?N%e  FV}Aȹ#5lAKN~MyuAfƧ s;=S9MRL6cm'" `*,^HV 3s;ERS>~QDlyPZcj~ 2>^JHtj(_P l7Cj1;
+^  yۋȿ,vrvF$x]gPYWW_+,/Il9Jc^UĎw]nŻS|^#;lB$lz%M[
+XW*x~_ s<5qsDqW⦍.dNf//q0( ]^~}qgV'f@$I\`n3v<»?3iHt6s!I!*/9WT2RwNHŭ~>'x?LO[H[zI Fw+ۼp郖s
+^ >l-mPrehLl$A`vⴹ i@~$5_)=O{l?sEm7ķ-rֈWMN4|Zh`r@³/A#Tcy|>•vCV՝li3[nܴCn~g" |e& {l%<9H]:7w
+8'̱:u&?.Mz-ȧclչ)_OMiA1 wFA r}߇I}7"}0' *
+:.Z:"ム٪6Uz޷~穉I$FVmUQ؏ʩQ?ečh%^5,\V,m^Ugٝl_]uTҝْ[UuQQ?م{ b^ż/ݠ,|^" :|Y:#g_Y}qp?703~j\GZ5!9J&Ֆr'JY?\.\ۍI5
+ySî*~ϴ=`Wѩy`eM}m{̢U%yu̚s/[E]%nWOJ@OWGgF* nMJpG?;ďQǎolJMł;ک wuDqw7i"o) B!SI^Yϙiod2yod\}^Wm,{F[
+9BbiVό\cfcfmY
+vb]η!S4,r,.#Ży擔t1~zK8kR v
+Mi_(]FD~5Fm往z'?cUf">qaWM@⯖Qmo>Z;SWtT6^/lo7U2-*+h/$ ُ|r~t8O4*? JД
+[c,T؋}4RYR-(ҸK$u9/vIa2`)%=v`sI`oCa$B0٠ @>}*5C btrTm~ qlzHt[")+jJr[ <ԇFឧۿx^юB2 1NBTP{{C;.B93Md_"r7 DJG' Os# V5 d=2lg"t
+b'y(t" 9L [s~r&
+@kDVq"_-^h\cSِEQh:]NF{_o 6\*YQY䋴^_
+R zݫ+*m{|g233y~ZidI$D#xs.HpNjg@pkG{|@q߷ =
+w10/6hW5^!WFJo9?b[sP]u#CRGqFm
+a zAi3 -Yr>mH6䰧o'7gr6'rF6
+xÚAOQ^^>J:SFX%3O;թM{H.>#}T~6e~58cG5gBM~ZKmA7w/ B CX7G ?r%uz5 6-=5C+y ke۱IsI3fO
+׶=7zFk=ўƾ鲦a8A6Wԭkԫ/3Z KWg0g۰>xTi֒i~QAlH<f@:4rv.9#r"k3gޥ%x*s*cٴwnY?]߫V;N(sWTkNR0Ʒ6և5 6cՆLM>qDĞJ+ >jུsnNcӊaCmL5Р2Ѭ+
+"-tA~Ff0ύ"򳕘ͲhUZ;
+ N=yZGLJӖ)ol޹5pfmYKQRք^y؄agpkە =T {U줳8nʵ2]PL7N;syU۪QURaC?%c݊1Gьdr"2v3Di9Bg)lkb\>ꔲ::*R&źhꨜc9-+"W躬X扨"E4dCg?OoDnzza4>ťzϣ-k,DԄJ1ioQ:1A㼓g0ސẍ́o҄Kic1F ሌ#kF^ٳ :+S5&#CL"uĹؕ K笊c笋"2Wr/TQ=8 )VcLqLQbsR!hAvm -&pVl/{KEfk{ QZ]6:j]k9u$3g;d9tED4_:Q hkDh*\%b+7J*Pe`q܌J67y=dC:1"{c|KA]
++ CYbuĮ *8P<7跔ʂhqiWjuԺnaM~g]ڽ!YA.FXc=
+' k} m,c
+ =6
+ \
+*@0KKϺ*jG\?+5-[ X/?`,[ X@,z#\ ZGL(*Ue$xN Tz $w5
+pI@؟ LA8
+ x7Zi v g,FL/rC$48|5
+{2>f}\Nf $Bv/ z_6A0Hj >P3m/P*2!{p%ZxC.Oz]%㦠!TsJeHGm 8{T@؄-ѳD>`OYTo4aF+c?N"ݬj?̨uա~J1C.
+b .F|rd'J8NpE15Wԟ?SW8}
+IudL醾^̙
+z_HM'ZrF-#ĸN%IϝOW5r:7G}o5272mۙ oЭT~ipk}'GMhk;{ýޭx'Z3ǵ&-3-Y96Es>:ymѬ6M?6gΑjIX$&kh}M+G 7Jnǹ\Ve]NehJ,٩&2MJ<_do|My̺m oN@.weNk4TEmA">i+ԓ #ۓ8P59~((lT'6I:++VQȜ/tK"~fv۰b Fz]A`Ci%oHi}=l^;őf'Y/m9K3縳[ V5ES }'"_O+y+NUk55Ӽ'W\+_%r.KͿry9Bw4='15 IbKy`$Igߝz_WLN'L<<C[^FK⹦*qjV.N8 -_y\߼jb3oG&#A{dFGy}ّ5A| jBL
+Tvސ[aZ,DQ13D?D;r? t
+TK ;ӣQ!*"1$s?UOd&("ސ/lˀП#U
+RBaC|WG61I>'`Hh G\6tnAFOs2$mݗiZ7͊ rhR1eb?a /_9f;,(1 cQ7?
+}ZOɫ~8Ю
+Lf1SJ'H $tG zw U A2]x7lgYϫ 5^2TC !䨌<]`lwA<F
+vۜiuv(& gY݄4n%;LI\c"Qro#[o$FPm6:6"tdyي'2IGwh@l~3E&"~{*_{:&2_-f,i~VM!\ږ'Ǵe+|Vyo&Bn]<q
+G7 w#zj"׹"'YhQw\iB3xO,f'Z.VrNBbRϧt&{%'?wyJn_⟍B$Y~q {H#-Hu5Mb_E6J[wa~MBjM1x:g1"Q&!zr1ô]Iy=q}61-#rM#+A{Tw(+C䉨aͬ:S@`-5"
+3+2"NHb1ǟU$]P .kri{O+{,QnrthTg5Ei^&r\9}w
+rLJ֟"o|/Jf\.k+ zgfeMnLs؝7>#om=_l/.7ӡ_7l Ϫg=Oo}u }r5Al;CW;Nm_7Xr9nb<aǮgBicD|a&b6k ~czgygU~e^|nT|Wx_!z ޢ{gm]E73;ؾ?a9#q\5͈ae6oX=3U 瞖=Yܼ֨,ՁOkK?^e0H ^b?t\-.x\WJ̩3gU|Jm#)I>)37?JZ6{F'+hVA<N55 *Y}T!-mmTY%}D)r+霁=9+j9Aw4JXz)G9k}3{Ϊ=_<(;9tC@@QdEn9dFΑn4PFAk((0%(&UFFlmV^o^ߝp߮=qޱ#Ӟ'-yٵk~ۖzcGΛ=wشEPckgYEd>Hߚ$1Oe1n)͜Vʶ[V$NW
+pd[czqޔny}Y܌QMcK4׿T.|unӔ-/!K:40$ V2L6?T͌x]C8d\G&\-|EFzNߓb_hORJw_u]ԷsъxdܘwZy&rOh~Io~"Вj%Jl),F_s0)Xze0jBqX:*D:(A
+5;j~ޢ"<-ZϣEyM1?0~T5z^ A2e } z6h &
+8 i:= ?y>"߬3?AHzRAlW-nj:7mڒpצ=.їWF]ZQƿ/O6D>1l2{cv~[]Qs=~Sq- ᜦήWK_ip7Oc?v3vi%MV̄-Ÿ$
+3bP
+2G%*' 9y
+ҰOe3{ ?[
+iCGQt\b$W <G
+d[z[LDQkv\$
+ AȍRQ"v#gȼ'|xV;9~Yjl;Y3G!x ` +!/! ?
+'֓D#feZzܟ"ք?ז=(* R RFLir,-yu;Rip\\3PEFz1!w /Ѻ<2Pſ /.>VϔV9PhoqR<N#<p B&a򽒄BGCQ<gcsF}Gj=NӋ){<F6A^aXȎo ΩI\}IT6b"^쒙h(!sZ3m%'YL?AoJJkۈfT8K2#k9S7? Y#6jܶ^! Ҙ|1:mg:fhU>~vs>o=}nwyS=3_)xF{G;S{ݸ?meGU%~\/kG}O;OoeloeS(EYQU˒qgsf<Ÿj<*KȗLXgHoXKgv:j"K
+^Ե濬;)s"{2&o5=gIqb>6^Z7r_[a{HyQ'-x_ _<4cqJcY8~BͿ7W`3O/' .gkϲgp~j'8OMq4L5LY/ꃦYǴ6h )
+בƖ5?3n}nr8S# +\
+G-&Ӯ.Y.D_].jS6avp /z) |ƴX8k{6}!挩9]"NMT v+=v[6~9sD>9@Mܯׯha쐇ӺR[*|>7=]RuV}G9ëK1׽O5<!Dg?`Rk'u7Woa+x32Y>
+YZeK=ڵaaڠIj&䩱?nR&4/_%O߳):n_ȥ2mڻ29]*Sf6J^gHb슣&t!»)QCXF0=sˀ~zhvOsGzkL#5Ϟ-=0pХYj~ϴ6|T8#LAn p"nq$nq GH"r^O(q)31s^!)Sbz}1'51Ni~mwL͘rFKeaY\lYyf/sȮLAtÚ!a+`QE1hrߔwjY;B"\Iiޟt%|dgr˪BuNOY!_uS}){<į%toc,t)q(`\ByvΚq 6>NGAm?x
+l 8:6.vTn7-[fT0@]K>b6r6-H}FեnCJAru1˲iҁf]Cs-rWJȵB5oEMbvButm/iPyZq&t[=lP]ߩJI5իU@Na_`WXIi'ӷ0ǭ$пD2+]Zw%ns{O&WĪ="8\E@
+i
+dt s&*xrX:UtZ,t~(pܨ89͚<m`#z
+XM
+M TD_oB_Eǒ.Q2ftli2'@8(? Dp,z(/ J$Sln'ҔAd,
+ {@|7ht4 G8B{EVr)REFjHNr"E~4R e9Oh4p1"=Bk1D1'f)r^"-kJFlN #
+RVvGjҪH<ܨuQlYq qL;I~mʞݖ]*o\l}o(/ cО(w=oc66aw|0ˁM`,V0x ;9$#[
+~~#Jksl1%CDAqeaU ?#LJ9U\*Zբ~+(6E
+Y>ּ.s ZU)] VSO zv)GAG[eDuЬ^-I=p%1<[Mn?]eG-**۩_s]+G7%zl \;;lV'7tA;3tVC@V
+TS`8=hfrLpR\`B]X5xM,ǭuwv{
+}G )51mVc/v'Eb򳵹aB]9
+-PaRe򔩄(k!Iǥ .M($w+R𿵾ڧ2QA* jzsysbqaG me) ޕ)};'@io[ vω}jOeꊸ#Y R#:)A];k ꢰA4`hҟj憎kFLDMZ_fN b]Ew9"> dڏ07 }7؃⺏&I}^IB^`YRq`.g
+v:~lQQ T%|e0X7/ )b)dX<lF9lP;LGu[̥~n"[-"܍BDnb
+}
+
+`tKQwS}oan`Bn spVd5dmtL:
+2|(jBjD[5!.B* 3= F
+%<@ؼĕO1yv8\טRϠbob~z1mHXwTtR˰l0ԇ--l_l?/% X1.؅Ͷʴ@BZtm;1[n<d }%~Jie3gsZbZFmFuI$ی-NY]a%eWU*~:&D53Nu $ xZ0B
+?H^
+u494r~PN#!%$
+O?|A;wW9 KȂ6g{3Т"$'Y q_ȿM8'u3?F4DM2 23.aݨq'r%Ғڧ\V<]dE-!Tz\99c\f)C?1qvH,L4౥DnMb [A
+1z*H?0JA掇RcS2 ĠXm?/ F&HU{Rss`FJGTT #zϐ\~$Uы@ 23AoWA]ǷvJ4O3jl, a2wX I""
+JV %s jmSKT86y-5(3%e MT;ܽ$/{wN=!Cn]~Ƕ#5{Ij4+ԑno:rek-Nfe:]?p ZCHc@>ohu4uz=Psy}}p
+:4$(gOULogxL*exyMH+nϨRx_4Ù0MhY̒?ֻ6.]jHPe(ȼ
+[(av ~Zףockǯ._Iv %ä(pၛ|]'Xwǽ܍ȽÅЦ5
+}`!rUp|"}W1וUe'vPwGnS+ٿ7XΛ:G:ًOE2 V32c2դZqF\>TzUJӬ??4oVr85%WY+6 OVyb1{tx#'g y'Mgr Cf3C b̰a#&qqb"_"&1V8]p:f#L%g GM9o/|k_ovj-nP nq{OJkZRqpo
+^tqic,~=mps\gUOGK]Yrnd]z#uD[—賌{0~~GߑYP3Y̟%D+xg]hVX#gYߨz=c Z^qPe9"c8d<Fr?9uhZ׮UzK?1 '
+4.7})
+r9Bbk2-`[|B)|? ŴZ5KFA !˶àscزSum!Xx[MC8ʻ֫ۄ[a=ty/tY)y QF(r0w&gD>{vso'ѧ@5ƯW)ڍguJHx@hmHCҍ94 rdX!jg{Oڧ=W5k)k5u23"XID!m"'rYNdv,pÕ|NyZB-a%ݥ_.7l[݊E^ŔGʈ؃4;Bl5aҡ0vޱ@C \&TPM̚e""9?g-O#G"&E9C!&Λ2::QlƨIKz''"FX,dx}ݕC,DY#  `o/k?vǻ>OIRP\fSWdi
+
+г+ `*{V-:]xy.!Zy'%5:0cǶhRbf`c&0P$)B}\`<\IFQ#L;K3#r}Q2)2Jsb%3"I2I12-F,Tu)1ZCxIuEFR|۲Ɏ.eJ<nw ;9V f߹Ry~ה.駍=)}쬢9$ώ<'-8ik#_C.brB
+Q!GEyl7_S+v!SW4U \I`EĭXF ߍk!BUK>x"`F
+<h5 !PxC5~1~ "">t@BAiZ7A
+5%VD.t~zEi]՞(MCM
+J|U;d%M^lNmRv-!mAN'hvsN!b`q1[R_;Z}gwLOY=<:'v+sVW'}#8jc" &oE`4N3/EPȹFyr1y*RaT^epvBTEcj;&-?n8նɺ5{C~s:?HGNW<⍭Ffcm~ЧIIOL⟰RMM3N`g=`Eݐw¥pό#
+WJ7|k6Bw ~1e7glTjw {3hڹ{ǨI΄qzI:-ޯcb2Uu>l̜,Jzѵ+&F5~ϭ }gShR俰6^ϵe~U- Z8h;[.Xy?B9j `i:xP%E94zEuGCq
+AR>Fߙr
+rǛ,c/+o z2jIf[_l3SsSų[2O6ix{CHsgZ69VTUsBq²_rJاX+dێ3h
+{uqt>[[yn
+z=
+v; wry_u
+y?q9;YŦpV18Ln Nd K!$Ҭ-sV=wm)"{AlBY RS[DQH ? yW`]Iin(s4L۽dY1Y=Y +] ʌzC}gdddVk^k>JfGtRA?YfxA]rѼT
+mؾ[|i1֫'
+Hg$kߜOZ IaxM8I`R 8B(3
+R恌W#.d1hUl{E-kl_f= ]€AFѽ2<>Ea J^G=4/Lv)nϟ͘D^5w_d+4%jxBەu^xnZjH|"
+=3VnwygS:!;cg]|!qqW>O{. I%Rmyr!;C[NqZ[~ob5,k`|[GkU3 FeKtE0AHa\FDW}jexy{[EomErVIJ2QXo}g}9sy>s93O7~ߨDU=e<=x,1=Ԁ%}SN/s59ʬ{A=>a78^i\YD:o[XW xԝ}QқBNaRc&wijdRYwu٩}emGhjv|MxXC$ yC.hoͦH5O$LMElJG@Žث֗V?d+ט_WYK0!2k95WQ/g&r8C"SXɬYAѝq3+^#K^S˜clR͓҇-sӌdk^ތwQw{@:5J%ƚ̤(ѓ+oVdfWGnWJnO|t+`ïuZ]kw.ח{(YJz3zmӺBp{ℑ Vm|?Q__0gP4gt>hv)=5pޢ=jȫ}MSe;z麷qieFN+b ]Pi{[h`Xr{߈ـaAr (!GnOSMH2IɌ7TO,ƊTg;Jǜ9YeҀ!_MNq^?4fujeT%١١ױݫz==$z>$!\6ȯҢ~j$g@-6_' 56[-"N/۶!>7PcxsTӐlKnjnSu*Zg(ؽٽ'gϓdNoY2L0pX>0Dd-C+!IZ"/{)q"px2c#G 'O<7G##F&ci ̘Q옧'FGw'L&q^%OBi&Տ=gNPSB~L fkbc,{)r5r?LS8MwN,-w) `Cp6?$qxLr Q}ޓ*vY6s21fanŅ"I.,/gba13*cbƕy}F?\Ǭ0RoL*THwXN[J8mIv(^Z'Yidy|v䁴g-IUL)Jc'`$BRQx"@
+ݧU=5<OQK}'R]N(ŖI|)"!طG<̤ $FAy_Ras4j<^j_Z] jcfc?q~+k~(WUv. AYJ9LC ozQmdF;slqEf 
+
+
+[;j
+d$?RE$+L: v
+QA8x_B$8
+T2Xգ"s27~>ep~{Cl]*^DbDЅuo8Tb}Niwyk27gew%'-d*lϚ͜H+|'ͱ;㷘1F-QV]m#bpL@Dq Gj`t p3d x#yF' nkVN+$6^jG ǒiZ*$ͷG٦Nm,հۓ؀ΡpijHY\/Em9B8YľFMh'r
+fʠ!#/c&g<òB,39-݌)&RqE)tbZg:.~D <>k3*uФtÜ9%zMLM&Reumc&oQN"h^siZqq)ǙY
+G'2F,ǞgR4?rYdp٩}?LyV*hKhsV&9]~7m^&زى髬;и
+}m[Hsl(bC4g ]4JD0+VT`]
+)'ڐ)9Ë~gժqkE?ty@5qfRhR(,)tA Ui HB(l }(BAQ,G\**Xs y|2m|N,_MȱG̳O*pxǡWAZ>wtnR[#΃ޟuO-?j,BokPF>(˭pߚDS D'ЄBBZTdU'e|W22"8ƫyRcYƬps,p3܅1?7ϪD,
+26,A# *B~Qz{%w
+w= s`
+R֓JuU8}W~)cĝ"  & H% sr @
+o&pA2{&4TpA
+o"j {s=.an>Nx߲ζU)ME X)ۖ\aR55NC}!?m..ww.%KQͨy7t$LBi,4Sʞv0hb=eP7+J}X3ySrJİ; +zp9ʘ,?Ϣ ~hOG^agj`,8k< }rzǜEݬr$Rj0+3A,QMe_Լ5h3mM sp'r۸?nGBQ[ΛC7RPY'opg؁9!~ 5%?莄Iw1oVfoTQy3Thsw4|q8vTD'f`⼉*=pK3؏6ad$C =PE 帝""vΨ)'F֒dBџqF5(^;Ӹ46abf󊔴5,wXr=ӳ.{ۚsFn5'=&ԫ&O ֚'Z#Z K׼&VZAxA}D,PR]rF͖>StYj\2cy&
+uOo\z^EPJ#kH <9#(kO:Uo3Mؤg?q<s* xo;BRƺ8.\Բ.@5QF]u<|ߤt tut T#V8茒YɕT m9ܖ7T(Zƽ\@BA&s6^DEؚ=gH;zOk.L۴%΄dķ&MGyvL-~?<fr0ʒ/κMy4$L4~wm'mx4h
+þ10'#g<'gPg ,:+d9+d8\ uX wQq=`\\Ի(3AFsc2jnREFrѵ$YMw]JC=N }Mf%c{2[5!K#z[;.NBcvwLݫLZ4v\T qk
+P"(娀:"β;Qrs_K}/Y
+UU"kw"DfBp鈾C&`d[C]"rMFq +Jb$&b&e}M2MjIp@ N@S>6-{I_geJxJxTkSprO>)5}SBeF߀b=cO%, 6C,J˄Bj4+޸1Y]G {κ5?kB+l{k]+ 'B{X5w5.{+5sRE>W>m|\A)vYg"ȅQRy8%qF(bW}GǪw6 n ;hO2c*ȷ)tl^qU.E/9O"OES(KؿdA]bB]r\2})(e݌K1ly\ڭ8\`M܅}|ig
+5!W
+MM{_U8_eunEbGo4|( HrnlS_=⥞KΖc)!Z/( m d|dk,=2nK7sD AN&}H{q@{EFB C^CB`s`|?#yӜ=qbφYOҠI-nSǚaQ/uI9ɿ屧Ӗvp>;ʑuID/1" ]Ұxն jAr u!P;JE j]l ZٱOې J_Ļ/kʾmHϖ66 i,O.ySy"^I_K3>"kFW%KW
+vʼ_
+5o"R$AqfyG\/-z/^UrקdmEҔ0li+2kD[q ^g}fU}+Ň\S?vB%8bprb
+:=UܣiJmsn
+ 8w..2~u;w=/}U2jvIYMa l&zDj% mn*7+7{8E=`δϹ_ ۢTeu.KC!ҰضI\g鸦geJ*quG5qq I[Ha_\ʢ/" ; U @ّ*qC(U[7e Xm}WQQhb)ȼy=w7{g|>/gMMm-(Κs=o^e"4a'^]Uo kF  VuA **v^]r5۶WpegJSxit}gPbdlQZAZ8]id.VRܭ$<=fѻC8ɞͿ[2ygةUeسk2#a:?ّ8ΘOZΑe烁KiO![:V Iv:*>1|b襴i ?βG +m2zg@lVBU73QֱI;ǭcſTfOڨ/Gb~ l}1R1z[2_JKGTsB9gr055jgjE~aR'/z8?~$7ٺܬg2v=LDw2YQh L~:orO=1VbQ#45OL3[<ژ1`xݮy} A Iq{{ !ia(hp~AoԈu|pm3j_.ڵ;mdԺR_yc&XQ*'!"Yt`}N}Jn]\(:Z^'Hn~fSϻrM9-.餉#)q$-{sObƉ::I~}(f`;Tbc;G-$36פs:ѭ!ӖAW2wK2'͈^3סXc Ĭ !DC ^^B{#s-no J潋2ܒ'|kx-b;\k}lAeҪ&a%<@1V17}ؤ6Xrn}A;DOKjbu9!sxg*ЧtI~YF.ZCஷ Mmf&*##4CHAv
+ ѫ(*fwȒӥ$tMJpL:\'6SJձ'uV c)UM_Mǿ86br(|̦5c+֡%tĎyFϏS={7 m~$:<Us{N~(kf'O+؏{45xެ=4bq`r"<n RS{bȾm,&`ʸ 9F&!.
+BHQ?"9ҿAp RQ+$ӰS$V;dvA͚P9ӯ^ _.XpZny3k Z\w`{l{܎ĝ}'u:R;j7D=4I;:hqּOIEaYæscK
+'vM3Jʧθ~_p_ּq:Bp%Ǟt\eN4kچʷQb 6zu` y`%kEB01=r'{z!C9J@vl!Ѷa7Q(4?TԻ,5M)&bA{t aVP"sAC'X~@%ndds%ZLȞIɜI)%HZ\IX,^u|(-7NLE_t@ڔO4#uVlz l鷰gyAv~/58{0
+g.=凬sY9IAhǝYoU8/uEϹ+ ~G,ڢ2BВ?[\`ahDxT2Q'<S
+0*35eHZ
+j,7&+"?ǝɚNzf 
+r5&gZ'm km?*)Z,Ui
+VB`$EɄ9uրcՖ
+G+"g>p e |pY
+kw$}#*#ݝΪ=&EN4J=>.[vc;UgH(l&^AVeJf׬a׼iS}ȖN:` 1^mYK|i7#eCq{q ڀ/tpH|W 1 #\cbV wzA~P}x
+P rb34o\am248(.1a`8crO4VɢX)(&C*YΟhZY] sW?Knw ^/ou;tr]jd:>&3^R-k‘=(x !F=nqRjN5WL;l#B$-zaInHg{$Ys{K`<4D[3DSԻVp?96_
+F4D5K|MNeKIS׋
+\dtq:iz99^+[nA]#F
+1Eã{́,yHzgꨴ5},%嵸Y՘8l}a5g )ҺoڲOJ{!(3 CGԉ3T/}~U#>Jя#bnj\_JKl$
+
+-A !0a!3˜(Nؖ&vʖ奎{{!ECCyE#1#OH&~KUN J]{v͊=W=͘ZGmOm~?a?B8T6Sk=ȚQ+B9P4.m-fZdUK9,{$擑=5惕VAl[N
+ug`J
+Q9 q'Aj1R/ A
+0f>>\[09Z`pw`u5VA8P 2p"'i@bԀ)U NRd-)"ˠؔ`n+ЁE)E 'PٚCdw
+[֌j#oGpf8D'[ݍ%N;XQoڬ9j~\4vZ }/-nNo]|*HXy]T`w޸ľD
+o}yO~~j3wm6vwA=^-z͖X[%jM&%7!eA*Ts?8 ߝ<+,NtD5zˠzÐrӠ2e@)JMka~xZGu/ E1$x,jI 8uIӜ2kiWR9rYRt9&mSw$\Ij$O]%ߕd~\9Z
+
+/Iz
+$Mq-:AmzĮQiwSYg޵-Hh~i%{Gģ2ч:p*5TSNKvrSzSF-l_.9 /^k1M>g7!hb،c[v1*#t3ϬqGqgL
+12eאR5 wRĤ 791 0
+ҏPC(H=q4Pj%*գUx5 B4&MhU[(Un7jUˬ攛|yxkOhHU{t=
+^o:<~*wS-FȄ̘l9L
+hj̈vJhp+*:RHy2NawRf2;I5JKWtk񮩲j<a/-!qvi!k`_rYS{8q/Q݀g'8+Bz@R
+$`-8AAgIw+S#Y)a9r=`U|{O/Ai}e;G-L*XCUg_tkt ,Nd
+x
+v3@1g5##jG i 3$ ;1};JHv"ϯuGIf hDkMYEԘEye<JQ"Y$C/%#aN<vecEzV NF0EҤ*e+tsXWq4p(f| y[#[C:;gTl_VGMn:$ͦӜauO{IZ |o~k>k;^ :%5#J)7c0>6{@2cQ
+ٕ96}ggϮ/=>;|;K*UO>|SPڡ So~F<Mտo F-P!U' `/nYtE{9k
+PSALdVwpL:@85zpuA+r*@8rQyg<DݟA   ߂@}BH
+gSG{/<1[O%/wO@ZSrHwᶒ; ʻ
+f?.Tf=WOYkpx%g4JZ2'\̜7dI.w&1׼ۊ;ɱ9F* Faѕ7^ׅhp䅮:j
+*z8Ir G_LS3͟J,@$ seoJΙ0ұ2g˾zuz\M^ȿz;{oߌ_ ĭDǮF|)n<L+Ʀ~I,n)-Z%,y˒>U|PoaAcw,s+tĚM kC=8
++|7,]/Ь+9O2 ˧r=8?s߇t)3A$+]4(y+6,&(VY{q 0dz/nD%Ft x4>
+SLeSXA4S+vPug"i tIh'y48uލDWKdo# /SAJ!ĀQf:oXJ#QR[8/f7jFzwx|)H$G\ Lwl̀o3N,o?I+z;] K aDNݘW~%}Nzz*͙;Od~.vʹ<iIP q^>(p"GzeE-jI|ŁEӺL¦tnOAwQ]{h1
+<5!0J33&~ }حN vl"%J(NZ.QAub{Ux8>$m,GF̊gŸ4aQsKs[ަ?mjo+ͫ}>aR{cRÝ7qȬp\TK/F
+vQGvn%^,,_ .݈΍}׮-++.WoeAvӲ~? Ր:@ F9: "CRȣ(PM)ddQ!jYSw9
+?\NZ缀-s`ypQv oC}0En݉ MACWBfV
+
+:: C '?
+(E
+c↯D=*}O< a^R^n;-΀Z,KPoi EnXx0?iƵXt*T?3Yϛ c4%,dIfy[)K0"w\/b1 i;R,H{ΐa77jU;r:O\-$DW=cg.zuH0z?k܍yVOBjKBx)cq_:
+`sH֫-H
+ѮD
+&([!&GX$؍ h`cE~cz"Q8ְQl3bl(|f$b,+3xrG&s5MfF2IJe6/`~"I|6'џn ܟĜ J^$&ho 3i&El%eJh^M7&xPF hs-+iТnS^4!̵Gfc (T~~jO#Yg3䏄4h{
+687KZťvUq]U
+wB??XND7PeJԣucyczwK5j|!;"d"`q G)F(nq^!Û.t^`eC͈7:2<u 0t{Aqa#Ί@daU 0R8mh'=DžiV*(Th1-1w$Yhا3?p% *;Z(I *~%@ZA
+ݯG,Q/r~eϹF̻_XvxdQxõWK$潸f hEBww<;4xw9"o1lwXB'uTP5
+J"jH(*(6@T`ubg۪0{y9g2;3}x3\S7Ea;N1'ɩ$&tY[9tI&Pg~Iw!VMLq1uW+;#EuF觠P8_E٨EB}'vؑ!PN^Q
+RpW({J9ȏ v0V05^hKqV`); ,XX``N3`eL=*ʼ mF =)
+I'>g79&8,,#$ɀu%m?݋7vkgo<i՝ۚb&b_I/K~CqknQkrGjK}׽,+ JG58|` o)olS&S C<d^(}xvqX$ESsQOЯ.Y;sd
+5slT ݦ-oӊmcׁuQ?
+x.T<.@
+!mA =Ƈ⥥+N<!_bq^a~Q^yJUUT,/Oȟ[URkӢYmuG]`K~1$X4Unүb=.cD[zߕ{TC~Wu}^Ϲgn jK:T/y^F4mA]GIsh,v45z49cL`Dܚ.=svkhf[|ٗXuw¼lܔA7`sz}.~bnkB{B}{ٮd ag!}"N
+U-luς`q%m-F}7x֍ +VƧ 랪>SN}zP!j.2L{s;(ûXܟ([x v|ۊMuhn*aX^7Kӧ'7G:!?!aq晻Z}adiN`q/'#oAjhy[-ǢOgy>1=/
+(5'%'w>c}FŞ#?R0XB Ć ²Op8F+0c**W,p$;%XXn +=O)P,k|ƒnjY;5JJXs",yS&4Ew*E73
+.[N^Rs{&㸣Qɶ
+w\]8폁C ,;
+H""Ž"B 
+H9 HQQ $T)α:0ʠ#8踛yK~?00[F3K s{|lR;ȾƗ ഡtZE!>)R]j C=bЃBTJ#aV"jZCKaRvp.l|uR6Jnq"gYvFlpNd? <ާ{q{ϲٰcE_^+`r|My&8iv&QU_SV=7{ӀϹkqOacbWŞs=&XjQ#{R-62=
+~ !,unrYQnkxon>79j[I; >:Swx޽1.#bIӳ^/zxU-R|Ej"9XL5(bJX|yruomS&fօ,hxb
+'")M'zI৒\ 8iTϙ R;,*04脙P%QgW
+b5;
+TeΧH gܶ}2r:eXf}942!H / qαBrD
+R
+F^-Y>+G
+AL 1KmY8|"ewH  \ 59wc92I
+:MuWUi*gkPl{Jlc1hrѩVm7VwFS&I/t\>FVc%Nb|seHhS_
+IID{b58R.
+Ŝz/E/G}Ĺc7m7J9"1"xsέInO5=~Nr{b<eXh̻'v!}YyMKgv0O %g\?9Vb [f.,3Ĩg7cԪt;0}̔vL֟7U0~&;q*;Y0a<7a4J0a?tjW
+3~=>pʓʱVI[oP
+iS= 3p{}dAl~wҮGc%T Jٝc _ ?$
+{p^Z_gޥ!>j!p]?j Bi_
+ejW>ڀ
+պC0Zs$h8Z[M44[UJ_WaӼ֦,di-.MB6^N!Ѧ1!쑝7أgmsD&szw،ާw:ٔfAuV˅F7{[0OYԉ򎬇3V
+oUwԣ4vg/mOԉ )DsYH6Ng ľK7e`á893 cve)WIP֑wQز/#%P![_ٷJn[?OMhBcn=u<|sysd|.ҹIQsnj. ü?rXF
+gw%gϸi~Y/ 3M,XR<Q
+({(@f,Q jpyTfgFݴ\퇅q[_,gD35c=kǨI5(;D;ɾF=7]w!7#<n1E|̊ e'|:+d 'QvQNȨ':y>O2F4}5Y4yD5uD%cT5 k{<Yv{V.t ҝ9C7 -ѷf[{0ځ
+_>p8~jaz DgPI;&mb6MAq5 77& $yl3Y7c&/jS=gǟއBW$WEGH
+YyV92g!OgDW@%$ /o߮=CO{p>,|pbWAg)S
+0p9y! JCnnfH^y6{ 7 q}ú}NyDNj4mqz;Su+M0p/-
+uVSze)FwKm^+7ؾ M[ڝN3:ݼumg]^}r0<4MI2\0e)%,) |rGp8
+ꗰLG:/Ҩ5Kl[ǘؗ-ѝO>ĝ f]Ƌۓ' '׎-`lE.dM.X+.n${H9>s cQ*`-^ K.@چ!ZŠ|EԤeXB-KW,ߑE6=d:=>o6%ar.mzĄpI*rXB*wKE}҂]v}IFx0}{\Nt΅)@\b'nwݯ/K w[Yn5F:^,#%8 ҽ3UqGڳ.Hi_ۃ} r_vMzYzg
+ל{lu'ziͼ_#xë,RQTDD""(ŀ. R"` "0#e@G:#;9{wsorS2ŀQx>6<ɢ+K~.߈G}Ox_@ I
+z\(%Nj{ՔKq׳%sĪM v0+Qd830pf5kld|0& p23`\uCdud:Xd)}\C`K셭V͐ &h0 6} an@'2FV86FؠclY[
+^ .
+ %s=Ƿ?7~P. zv#V 'u4::aISI
+i_k(ϹSQ!ީe%mϏ%jO񚅔c;ܶw;7<֜-i3ٍI y^k== mc)5߳R<)&x4.$VC \3x\!h)ZH$H2/7ٌ-svo<+Ӭ]M>į!<aDr(G8ͻDFGX{Np幥f,"}r{r]Nj"=zk$7+j,O8d+MyB+'z}xJ;*RmnZE.be%<Jă-SƵVL}_>!:<)OW{PFԪBQdK-*T
+T>gv:_ q
+`^"W}_Y-#okAOjx)F"վfKxM)nu봝el5۴Ohp%\_B
+״>HwNsLW:oR
++5kb<X
+;.+f˴YEA#C'~8`ɠgUA#<+?'KEVIi/&g'6Щ4)M:hI)5rP@DNH'!$ L_DF?[H^}j'\6:hX?WczsSC-HK@pT ]x^~"jg2f#5ބR8oF Sk$7"ǒAV9|M*|eX@6F·qY3>)q3}z>i|MhE
+qnte:
+ָ?Oh<Jj DǡxY|Z]B{E^޽K%*%>Wc dRtr<h iD:KU!& ~*|*}>ÝΧu&,0_﫢=* `RΨf7bV1GK-.HWhݩ/g̕/N{V{{P!['My] MyU P*|uD'i]WTcghSg9q+r<5uR'y6G9y=A`H4دmƅ (,|[ؙDhwxY`p``/$;y8'NU,_/5bƊpJp=wWV A>X>~wy6N
+سYYOxOBX%ެ[YYwY7ؙcuxMyhX8q–BQ[^8־g>Ls֟/Qo>7~< F\qb8I`,16)~
+2;<mTs<j]n-\ Vrĺo˽p"Z*2CuAȢ>h!FĴšQ>T}]Uh6$#hp <q{p#eG
+JŔJ[) r=D<'V|#S()퇕}1-UORg@WrCRE/)jeϟ 7 wm
+iY#|Hk̍U }
+,f`P
+Gef>`xC" H
+ا]P$
+endstream endobj 36 0 obj <</Length 59292/Filter[/FlateDecode]>>stream
+Hy<k`8Z8Z8GBdIMd_ƒ15&`ք!::QR9mfVhyUIy[Nu=~>u?k.cL:,mE~
+;aN-.`^?bfv`tR? m>Xj.,I-A"
+<ٲ8~dܸ6-UFAw'o?H3>K؟2֌@Ι))_ʞ͓f~,L >}K0T7?o*xxI0X#}Qݒ;v7vR+Ƴho3~5~&EV
+G֞x=y!9mP3G$}P7V֚9~B~SF;Y:hY6F[ISk>&"f<}I  A &p(_(z .@+/(
+=DL
+~wއri+Qo)[ܙõԯG)o'r0{ ,w9#Ǎ۟ɽOJ
+n1b:\QY_ BDjii>5
+U"SA Rʰ:<Ňyt8ɔíonL ecvcK5Ƣ H
+´6m-30RmBش#Jmlep[bn՘׿cv])'-js=բ;vQ6nV`T 6b*!w
+eqh*-95bĘC~G-+r~ѱ_i
+FC ( R 1*cۂ8= [zz08~p x=`Ԟ751R* O
+P,CbAm ([}Z}/uwحMwM亀.,+Q:ޝz{aߤ5Hl+[ʔ<CȤdH-l5NW2Ղ" !5GSc[R%T
+:3Ulef9X-x~T)KZo/l S@@A;QhmvdD1gyM0'}((R?R<ᚢ<rcQS_-~WΘ֠:4d>uAK}0EHƶf5Kޟ9#Y1i CR{^m\f]n磂.(O,k4He%qOk3 Bq굶":U s!`^9Ϳ
+ Fg&YK^--a [7msEdRB
+=K|ʃW|B8-aΩ&(vD NeQog^yv-Bgmby_QItlWXSImW)vk򒢭jΝ|Bζ+ Xn b{TSԲ|uKD=r8أ<<w&|LDG.Q!K,b<3ęiN$c# {dN$Vm#XrZ ĸƯX ,L
+w7%[\y7or bϧ:eLNj _ϱbjL
+/AA@E[Y Bj6`~b]j`
+\ ;|kCWt.qw(:(dEh*>s> CsN5
+T+ VB¨%FʞjJynI{ٞ^x9?itB+}Tsl9TEL۟ "64x&'B׍0 !ܯ?$WQ"_3wZ\zu,:iZ[CޏXE?/Z ȸY6Jma@ܳpeO,GIA`<3;45t(>hD{_Z[ -Ч KH^Uv|Y/:+Pҕh?mn?wF$ ielel }cUwڪ_B a"YqwRiB]©ioڅS\9-͕фHBzגJ%ygH.PݞF?yVR0Yו|0]`Ҍ.] 5C0d%ν.ru+_8k^=Ę\MO4dB1!طRjKAGGǂ*2^&LLSR)g+9軝 B؅2QlTz<. ݌ F~eNd &2I
+#!krwһff믊}i#9}irz{x}F̐Dh˂Q>id=qa~ld~q!23/xմɢie\8=s3.!42QXr))eD.̸ &̸),N(K[ZDH.Զ]Zkn[r3~3}>V,C7KqfGF:+E}p+N"7[ﻳ^U]I:T덕3\ tH4p7+z]וXgΟrٛ*kK@#2Qn2A
+- tpbW%sscoo(Nٵ6O5Sy-!׶?#T
+3p{wSJ-Qk>/82~;*܊,M{'~&?f!Vc]\nS{RZ`_ Ej^ڥ^EnՋ^U8w);U\DX!ҽPi][׶ 34Qlٸ=gcd"6# ?r!IjMq.rgfړ8Q2&y_DkQj{ْ 2b sl]$d
+Bsx<aQ|0g
+1B~L&mu7'wB ЊuEPt B~lS2ߋ>gk5s_Ày
+M \~Jue]@6n$A f"kR=p#Ԃ
+ V"
+TdAdhIC
+RWTVPÛ?0';߻߻ݗ{y㩅+_zK{ ^Vo qQ^o:Fg|tu3j=``VQvZ0+@ylY5W؍%MktkzlՑ(Ca 9\5nR[%!J64
+5ɤ:.OPr J@nh=
+.^ϕ`NqbBycAO<oB ?E*>_Ž7} Øs,TZd%zJ%=kP8Ȼ'Ț\uNE}o^h[,[+z /w vS*꫊RŠш9jIlL=<2$||`? =IG]%)ء) -&̔6xvYJf%eQЊjOWVJFmK6*$.4Z` <?ar@
+mu#l>sM\8,g^%dӼKf,9U z63bnNcaƓU^eٿ-\tIsMgIoKqRmka,Z#ƬˢVGNE=?B q}ξ>b^=4nbCa]ǒ o$O~x>MO+]Ӕz: ݯJe) PX=ursH{O ZW2:D7kVO:ϩ"W3<9P9]jqiH$!d9a5 bMA
+ѥXuAjW@WLZ$:v#[ztK)QjGY۞ҏd4q*n#;f必RI?PX7M󙷾e_\).h43}[^%zۘ8ube)ca/B})>:YF\O]J_/ӭ2;`t8|ƳF%CzT̏؞!%&%Wb#fl7kSҫ_zNx-ϱԹ7'2rvf
+NMv
+'%S'sޱ%1@tсEz kF+g(.OI"׻"_BK:Qk6LOȲ>ŒozƨwϬ^DORܡ [v_$Hn{r&^Í
+ˆ"@#U b 2( ?<gTSI- ͂tvE/3 2(ij Ԅ@BK"( ^pҌ@E,J:"ʐ9?:{R 6m%gT2M!Y;D2ͻ چU4E+T>V]c36wC^JW2a߀ v !u8#y-G!`jqo=2)ZE@a;*{lN:؃@U()#~[@#?E+J;?wS*+N8`DZ#^DE@5[73N\fGWJYٖ(l˻GsK  K^_yT9'o$y9EL^&O#0jg22pQ?|{lǜxt
+:5v7lQfPawk8Pe9ŢnJ1wR8N6Lc'oB(Λ7{TDy=pfOӡGk *h5/0l
++UPeh|]Rke @5MH[>t@ xbAq(Ut c`ݣ}ih22PÜ⋙*{YeW2'+sVHX+$̧e"hYgBęeTJik~/y|5HYG/k>O
+jNUe.^#odV͝J z`BO(~#vlp!E+>1ќbEMܑg=h7x1tR`MσX:@-D<Y7QN^IP`"!u fM+4i|/ߵ8N PMB9q(6zSh <%n}؏)'<R&; Eơ$!!86Zj7l?lָxe <ܹ9+E''Io/'ZSf6rO,XC>ۢ.Pf{a4xm]欟ܺ,f-ؑ6||{b_;U'|:ޘʽ/uOgqzI_QgAR1!T HzBUWӊe =Y1fV[Ü:T;-1
+*6`䚼ɦci}(|w&d
+@q5v
+)*y9Z]]Ng|eUn ?R/uMjmj^^Md{PE (D >WUwEE{ $@1!$P+(.bVE
+Ue}Wyk|f' jq ^EMȫѹGG73~UȞ? 1C@}$wgjn"kPOp?Do$
+Uf|~WM2EGcr)
+ <5jC4Q
+#ԓ8V1E-2?1gHa \t,VMAjґsX];8{Q&8-
+ONo˅EvV\9 n[DLKO[}sNY$i/"6>% \K)0 `5BIJyv_eOqN;sQys^}gҠ>;!>! z!>Gt(`n FsEG9!<֔A}W$1coD )X=|DCEui$hH{)]R)eqU3bp_c?o R2ZŠWktnO`c#Xu/* P"zV&X]NCK_L!N$adhӛ!<lR?({a5&@*c6r<Q%t2?8UBa0 r!B/uK!L u H
+nvng-Vpɏ͜96Fn'G*yrcӤFxbۓ{,"OLx mKWdodu$?+^Ik?.˨KȲ /ۍr@S *UmώEJZyC{Zc)VsXTKX`[ԸsVӮ;I}f/Z'OO=_=z.jp()5
+n2 j5
+ k6g5T1X5I E)6;QU԰ vޛywVGegl
+v_ٖxukF#Vvbuy|n};YfYmSziqxߪ2ƫM屣'c^c~F<|p5rpA~ԍ_x9R%|Ջ!tQ̼vROyvvNngݎ[гLOsz[߭qx""Z^S+ě>HXk+JͲ\̪4l,7۰蹗0沫d+-&;0iI/x6g~lb"vmzq=e4%kG>ačZ!Σ8^ʾA*
+KTQ@lQ [d
+,""XKRS }P{5 }}/7ιoÝ%;S&3+GM-bUvKbp5 ׉ۇ;G\%Gis\T>R'@䏯-r9٨θq{giY
+G7Om)?o.z. Q{쮫۶]Yb?S-sqq5g&Eyp23rAtd@
+#" `%FheaKEsP/H(-dנZ _BQ6=܍z(}e
+ti~ 20T?@SY,2S&8(\\%[倁^3>`i=L_$|Ml$#$3 κ69fcd`s5OK !z:!nU)6j&[KTrk&PV[қӝ1IGNL"fYfWtDO#wvIn`MI7vw-5<R|TtBFy6j ()gL:;8.w6%s >f2UQ˃;Oļ4-V&.#,*?vF&=ۙ);)QlZP1ct殺q璨1/{VoJ*oI}U")l̟$l&c(<L{56Wlqn`
+S/(=+ _t^sAݥY[A#[W[
+!|A$gj6l% ` X2lf`qD{GJyQLmt!^9 zcQjD/ W lIQo +6 qU L
+Pqj.D85Jk n]׾써}~kn^KH$U, ? sEror/r'ނn6a_B0_!|Z =>K_<ݙҝ!sSLA1O COkI~yJ
+24W.utpd*3R=k>;{}R8N7͍$8J+1Dd _
+; T'V7F(h߄LKWc$( T!@?|n<vݯXd'zʑTO)/6yϐkvF\o\*߭ǻm2<3n*}oe> 3?~ǜ5`^d^Z4/_0Z6Z6F@Ǥ9=>h!o8}|;r&V>9UF+bgK`%p|k܃?*o#F
+,һ?ƢLFi{R~w{Ygꕰ&ƶ_bZͪi)Vv>kPG2>\:·[0.'øL^!p07{urq\; q4Edr
+JG$ΜQ~8nUÝ4qBpZ\χ= rEz(&H;J?;?fџmE1Oqq)'wFY*CyD΋q1"vbiMt)[RBڠdL}"z!fOJe#)<jKLy1{ULb|.R߯.XrfW[")_bSr" S|qZfľqۢO'?g\H n]jϳO~<Z:qׇB_9T=<b^<bVʲ,W敁 V-q+Lc3f .z~ЯalrZpG:wTo(?5[M $ 2H#LG0DeGbiTױ
+ ؟`X4`W&%dz6>ҡ#6 7{mEc
+vbp!abɹ#; \ `%%B_Rre{}5#>PkenRu ~ KhR C:Cnrt3 qnâځ @W~  ` 08ʎk0o=p۰$AR ze+s$΀V]82B?p+> iN^F\秲>o5#: <Ǒ .\`^H>,vTwŪS+;?G7՞؞ h7qۣbA_BISYQ`&F$)YQo|ꍘ+#ބSC뒍4Y+Yɻ5,)l'+=(^tS TBz$r7r%3b][V| w.l~w2a$ލ[yuenwdEOn=}SSnOk q>+j!rgcIJxN*NVU_;3\˘+,v',v"/޽^Mo R~8rjl1Yڲl7⁝Jt=#W*Vt_3, $P)RDG@Q@HOBGA` A XqGZʲΈbpTEq,#Έwߋ_~xܛsM~_08xwaBgY>%pZ|)$g g,̟tHh%
+B(YTd ߎx ;e o8㑊G|#dzѸDIy0UЉ*}Pw
+g2n
+Ę֡0*i^b,+˦,JNN9tn%ySWt)r;<>7>58AIeo6Pɽ.qaI*h6ql𚔸aSNu)c% ゙z|J} =*!ey:m."!e^+Iv+LxX0\7*zaS=cѶomémC\@_=xm:t]Ax6{38uZ\pN:aq0!Z:Lj2?cSW@_xe.8;͆l
+K%r.
+ڐ9I<D^\D+@ Z!!gA,98p9vowdY+ע:(Qܮuq .cyV2Ǹ%8F Xa+)˰kM1k'g2Iy62LN è$2$$~7TpPPPP(QPlRHG$! %@ (EM)*At]73dso>_Rǰ [rvUFe-kxp=?0>ةP W5ՃyX\*ﰓ[Sa~9~,5Џ.g q1E>W·յ t|y)~;\%s qj:1Ht@wv3mD%.DvSl] >
+Wr׊%=x<0t#g(=ofLi)%)CiûXO YC̾.=/[kPq+ִͩS]̷ Ӌ2q_JOB?F(f#Ř% D̑,bR2w&>S9%fNJp۩t&0:bN$IdiԹ9FKy
+1Y:3F9w16-폒֌7.5ZJXh?bļv߈$=:RhcW(+#VftPH<.Dwf9=ɟtѿftѦxb'fsKawg$7-:n$eRmUҽ%kCm4юc<W\Q ` WJyc*Q,W{Uh[(W= DWam3v$ ΑՋ=5{Vu \zfKTsT12MǯkDt1f5a~m4eZpǖSmggVֲ%~2_Y¦JM^ ϻ98iT:W>b [)5*gZ~g~܄:qϚHꟚ5Nz h"t$܀ETCg JXzXـmTmeMpneθ$({coR>fӭhuW>bgIitm}tbC҉ͷ-(;zb-7g[ *ey"tωZiW)+ ) pd޶<<h\ֳaD75&̛R'vf3|I.`0nj<$Iy5`G%k9F"&n+Sqx^_]}u1Jl <49 H>dGd+d GX *6٩Z֩;Ȉp6~gvMD^TGC}#|7iZWZKbHOClauWw L6L;߱^-á{iK 1,wVfx=3i})}kA&YG2V> B+.V_V fG Boi%ёqVLiqji^i ҴIz9k*h IɓO͋h/LEN>֭&dܮ6daoeȴŰ_*~8rS'{Xz٩Ј _Հ:`9r
+6ך塟R)o3l 9IJDR]@
+( "P @j
+mmoV|_;N-wsYޙ\<b[iAM͖׶MK[wQVe4fZR7> EE
+"` 1R 9FH?ƋȂ-oOvAl|iV@NDΨF>$"Ϯ,W3D¼Kر)n 3g,Kd]d.ԡ! l;IV^f"FA~a,*^JI#Ad&rg?#OQ9ۛYnzX}漂@һEיZSDk0+ `FJ;Co玛튼c_GڴD63WV_4^QLgfhfCi)3K9F) ;i֏ig5
+tE⸠^V#$ބ9E(֝[W4RN>h+kAKR0phk<8e].[RWf!bN!Lv+]_=T\q΅دG#߹E .l([+c:=72Jảbĵ*[RPWǕ9;2:;HKJHaGsi_y%/ZԶH^j{?/Wd+m7 G%
+>%@눡v5nVD= @iz3!CogBAE\Nl2Ezi[$e;got}FI ZhI^t0B
+ao!8k=6z' %\8DU@^%Dh*NoFdu;c kdϩ#,k ќV2BEwYJBlDcm0N9Mk4d٧=vdWm )cQg#Qca1cջ|*kXl,M8#|[*A(=c~fny~1hA-Qz@_ ruB욠JJ^O|I衴=큤+yJg*q:iR_ڞ6,mKօS^;*rr|jc TpSݘH%swƏ*cZs8ߟ:m*!UΣsm]hިhU#wVQJ;ݒDxH֞U揉%E%:rWeN"SGE=4uҁ>N ɺo=IC` W{,<S~@YkäȅUde5!4E3HpN!Hw3q̄`}1
+ F d3"mmRh-/c7)gs-:ٮt{oARmKaC{I2U,?y/B>:ayeȊz5uq,쫈(;(,*.&,
+ B!%@HX"’ #)hUZg[UAQ" 3}=Ͻ7ync];'Wרv2wZs f3Doȋr(?EkP9r<5na ]J{
+ks|VӸ>d'"6D& Z"v#lܧ L%2"Q
+ydTܴ8yIج9?
+[ f~Ԃ5'f25v("}ab5
+ށd| ~/MO+gGn֫=r)gsǹ::[FC޻ܷigr'҅3c| u]pӮ֓cض5o86~"qh84\t_[c\
+tl.'6c.7:/:Ch V? :@́  p$ ZN^CO,??)KATy2
+3f3MKn:pv@_LZkXoXt
+~nkAgӖ@di=#rVPTlϬըzi]+៝{bq@$aI Q;؞>Ie`JǶɜv$Ϝ4{=Z9 &Q:ߴZ ::fwuDu{boKw]QlF*
+$y,`l$.`*;`1nBM-o1/WPBPj#TkFP~rӰQ>Ja3ivmvI.0 _'^#q77 lePªv4&-jklG+-FdroD JRFEc毰JӼV²Vz4xL7}N$P|rwu}-yF>./E/*B?U.lIt@9܍CfLC5-Veڄ"+܇>"WJ&#N|/tjs)_gZWwdN_J2Z bP|QBo#ChTceOc&9^~}
+~d{Q{Pū7E
+Qr#bw f?4Kq\"ocEc5D)[˰q!sq{TdW-xJ2%g81 7&PM/68烍[}Yl|_CO$zA2Ng?ĜYf:
+H)R#%!
+zҞHJqˡʻWWhMZލgvbjQVN[Hl\WԑL~&5oش*t9׸~]k~O4nʮU'j:B; uN>r*eǃ :0e۲#ըm6GVG1ד*!> [e#[;UEjDF/Jf X!b/3ٯ 2.{ lW\Kv mN7]\HU:UZ~ZqBeD5W_t;~7I=0M4
+V?\#w)3噝(,~16
+
+K7k$ ״ʈ;.]J{.1 61iz-,MG84tUaO,j8+"~>X7bj{IJ<y1sq{˂˒KYOG?.d _y%π4πoY6M-9t*:V횊̛N}R%H. _Ż߆W
+˞O^֯?.ICYUl ñmЏCP1l]ש6ipscܘIS6Sf}fۼ9/9 =`y`I!wX \4f
+)
+mdVXeg؇ P˝>3~ըוLKI?;OE[҆biP":JSB1Ql(aTb:K%|Vw$?kL? L&F dJf^EWXkv q@mArgQcR?
+IMlO~(Ӗ{_;LHzʾ׳s2SjʞGu4t{bo̞.9Q?c:j޻G֮{; Fh~:+P֑=#>5+_^-+j qD[(SaޠbYT7T9!HJQ@QTPTtH@PYQ@.
++vqmxU,((.zQT0N~=LIwd̀81O
+"c.5R93ޭAٜ~MZCH 64`"%-  @ 0I`X;ҀAW
+DEi_(A[qOʇ\97w {R]L,{d ҃ͼ^E|˴ڣkW`<+4&ϫTi8.jU/i# k@.'h5;-{..&̧?3G{y{]쑚 ҌS}&K~*M:љ>]qhZ!>&nM<T sF;9ݓ}6kFs4퍸[4Q M{-OHO!qA?$}ۥjRxElYcf
+FRCzkʫ>WiM/2`7<<":o{#m8JB@mު{8j;LNqk< bR$İ 6lB HYl9|G
+;@ h}ϑ(qUiR8V^,9쑭AOtcqەB]#84₝|֧,pCe8>dۍv?RY? 'UNpRRKi$Љe bF /i9;&1MB&9]#֟C~@S~T㧐 B%nYW1
+ӯ5f(*e66ɢwIv<{;IwgaQ$o΃_ 0E[,9e<?(t^E_."~dUO9c^?]r0q.{ִmW]w
+O7<rֲ7\{VTb)w.%ǂ|(hlw&oqCnU^u:Z *#¢rC eFL8Hx8yrq$S,zq8syhj_#UGZZ٫,꣋7" ܶ/V5Zw_92ת۞伴Syۺع23\C;42ޘBVO]fZKi5V
+
+BsM6dcA&
+iZ/1Q86Ux1~A
+8H;KMCm`$4#`T@AdAR *Ȍ pc {zߞRc9 `Ń)N3~hV\):Q ;Xs|bY^E+duG| wMjhP ~b'PN>HQ`ɎACQ 1
+S4G}ghwMd[1K0 U\0/8𘘫%(R.RyJ+YF {W#EݍkLxڜ4eNb&>OHzߛ2_,ufUoT2p RV WJ>\kL[ͼ[={%o./oqi _ 7 Ҿ'#vo8
+c
+%p
+0 \i*ir_#K.
+P)
+a9]mPzz0C܁O&OK3TfWQiV-LR R]7/
+@
+EG G Ld lQo
+:3^Vt缸%͜7y%ӝJOl q a5g9KI
+Wr$N?Z|A=ߎ1
+K:*snܑEX#ܥOi_/qjQs39WN[V}[c@mP*9TgCHqc-%Hَ8ȇ mu,Fovlv 'wճ-F159ȂGdjԃ+NG|
+8~앍D#C\=wavLtKW/J sl$,(6=P.r-pb;>B7"rrc[X_4g*hFڇ:Lvvl]Hgzĝ<%i>*>}Jﳭ,mzk<u.½uߵZרoծR߫SlaΈ4hc/z(k,S$YjO!
+ yGbH)PzVt/f3NĦ< Y@c'}~e FT6
+'{yLf<S$视ZޯO>&K|(%Nngԗu;EI:2u˰Aý>ߌ
+}"G DшHΜGŞF'i]"<3
+r$?
+Y3Zno"5#M g*ͩ1="옞?aa< bZmXa`Ŗ5XXKǂ&dlTς]` pƹsQ̓m ||;_Vٟqm~5|;2jXdK$AU
+4%ʥSc(E8%gO'N,.?)I~sC%)*}*}#{[.tx_ӯZqvͪJkW'
+6a_/&*.}'* ;2
+C-bTf1<-h2W,]c9 >ZC%3!g90 J].I1otgV7z2g
+ްiAːqcUl:>hk١Ο[C̯%"(EL*+vEjt]E7w32^beϿ>PjfZGިe 7)~"ޥv,xL'.WaZs՟7030^e?Dc_ʸ
+c+#NG}W~JYSX愇T:^|Pa{EF=^o >(l,C eɷz7$ʣ_'7Hӛc_&w&Dw*$U<#{DmA=/vĿeݵ=BH'=K.O̅ma/ߋW x`gUF>|dy,g#[hT*-'")a[bJG$5MhJEf^FKIץe$4f٢,[}U3kvŻv85+Ḭ+fo\Kښe6sIklX,t[UVhW*]vEUf͉1fG.L :Y#J+[sڴ|"L
+wp
+\p*0BŅr=E9FWGE5[ӯ/wSԮ#z^%[5l++uwՂ'1D 
+.wywÄ,LFkZrzǐ_XT=7?$x8ԱN KwNVKۜnV{tԊ.Y4y_]wcC+ﭪP1+p,M|\ү,c8`CY}prikZRɎMR_FV LX@¤G^Vɪqa cB,$fҠF&\`YF5iI/x7w.o391[
+]n1[mvEQ<;%浾L:Oh TԽN:" }ī koo Үn׫ A[wRz˵5 YȐ3.FF\]`U Z
+ۑKU"219RK)AP\ >7o pl% 4M`MN=0.N{^> $_:38 *h$U-' "03A{T#_?/Cр jZqCV` a@y믆k[ši#pϬIW9,lia)}쯾mB->Ty8#imG:q0G#Z ]s]nx?IԷ9_sж$*Ɛ*N>N:X~2SI'
+k~x!;]LLs詨 !J׌|T[66Lg3 |dz>2QRUL?B%*܏;ǃxp%
+!ۂ>K"rmGBބNipܴpMWYً$3wrv9G Xy|D dp8XE!P ެ q'2HN!$
+"<qrs//K
+bϊl9Ē?˪؏X.Mz!^cFc!|χo\U""<~T)|{8{Q Q!pG=hg;3̵-vwwinS#en2n2c|ʻ˴:KAVCj~r>ԡ4aԵPGx«(߁Y9=+~s"YfElN^gJKs%fN'|,K/}bR7N3*!|Ĕ~I2G+HO Jf(5ɼIԸf"v(mAQJ "x88%8}!/7Մr·tǽC?L{ӑGq=u.2멨Wd_mWQ_2"ޣ"Cڕ[".
+.<IW5apS(@<[{
+K; cZ]_4 pwZq|
+O7@(*xQk
+$a v:\)аağLNnMnWhp%Dj,A.
+?RpP[f:ѳ^f%+VC]6B%pmL;7k
+'._đ8*nxfHQB0d?g2W{O9ieU眙1uDJ-ZYDc2%|ƒIJ⋲zeI||s]u9Ϲ}?o=g&m܅ ż}ڣ3k׾xiȑ!"ut:tmzǿݼ#]gxOW컸';Lq1%LGfPA igZ9}0*/
+T8 |[{xj*ΧYCuO?n>]?Y:u&s6>ǬOuas=\R@8o+
+!c37=⭻#aJH78zdkHf ]1 
+lM
+򳿦yIziꏸwA ;xOE=]fĎxn‰YrMQc&Qެ?0bt1MF14=H8g@KMz9  G֞ \oT؏m|x.N;wn/Ekh>
+?Yi+/%=D ^kI<cC} ~
+ F@B:"fxI):oG",`ADX+iXKܣ`dy#.
+h.都-B E)CWAQTGZ$ Z ]DD,8CPEq@mp,20[u랳=߇F)ĕq[6RǭyO kO'!=-1ؑ%< :*J\?體~,
+=hX
+X3)Loq!>\؏  !@6BK`eJ)| "q tp7;B)D(Ah6H\y>897!pɞn/37w;0bpH2nD,ݴPhq\/3_VuEx VL{ ĮF62irBꗽz+H#=c7Rl|IdSFji! X J "|0@#ѢDoOW5apЉQD[A%pe&2qr 2T
+戜aG Lw|רh&g?m+>7j$S{+ "%On-J"C ;~UY:UţR
+CZ 7\ݱDp: GaF
+SZ"R&$ }/HcDi^F&7Jb;r ZI:ש5)KٟM@lkubkXk`,X=\wZ;Mд=v1  ZXtz0N/Y{PLKN|m X/9ߊNXJIߠ!?ACȟ»X9jӍΓnXSO֞gpoz~Rt-7m>FLa0]kz~D o'?͞lNYn"EYӪA~ˊ'
+s+M_TI1q0rz9xKP(}(YROƓ:Y^cMWIDP\x3eç~vs]d3,eKdo l>!{K8I,TeL|͎yJNuFۢ.qtS捌x{j|U{f;)k%ZW`E}pɄPLq!',wԡK6wRU⑭׈I[)TQb()vD6yH>尷P!<@^WSR 2(cqǃPD.Zv
+3d>9R{]\0UuPt3d0_Xt_r`$iAEޫ7:TR-w*I]ĉ{ ooΉ9;OcoI`:*2l$4o+C18:b}WzIډ>,;8zH?Ԣ=k?l8wT;e.T|xNBllת"p槺ӇKcw5!D!vqNJ]Ma t
+F.gh-7{/=4ʡozm|=x/LD9
+2urT3oVܲ1BN|93t&j<|քքtkڊ<oK); ȥ/Nݬ أ<^sO) y^ TRg}  B?o [YIԀR8 jmMX5$S&~˵WF^VqMTY*ǤNӿ@gRaE6}]Pif^0;^sTo Rd-B{}ɶ]ib@z1j VUS=8 ߐkB&c}hA7894xY/O5co-L7X 2#Y?X9`z`DG+_?[`RW)GHKTGvo
+m{ɏĹ3!𙣢C* {Idk"#Bt2fe+zib;l`E)z˙97qN"boO0!I/ z_cei1iR\J-KrcI_*,TTy]RG Wvgv7yψ6vggX;Qњ5Z~'u9s-s_Wu5c$fObѸhm&jU|5[;&]s}|dK7s;cqՇO\Ɂb( G=fl/86\eA'h6A:_!M OQa;v,d :!L!4VA8p8Aγ,U& 7VJ
+8(#/<*EViPdcW$aV7
+|j.Dăj1/ $6"_b)'dmAbYQ,!*Mglr®\L*U @=5 dx3YD~8kK7~]P
+sWߕ+Z{SxE̫\oN֚Kl:pZ s~htהbX,2.R)*T 0%ZJl}*\|qvBBAZ'p5zlGuQ"l}lyIJFa(P稁o}MOvC̑O9wj${rh`;2=Sisߢþ@a"tX;]~>)H#L~M̻J;=.<fD08^k9$ c|Y{qL`܇,N0'I}*Ny^(I,Otb0j*h%4.Y+b:[yߠ0h}N願=0|3 ʵ_̫VfZvZiŭDݑv"+;p<u!g78үb,w̦`]F(<-rg]>+B,^oMeionHWDDX@T, 8`G$D"4iB
+h`Ҭ1<l3V|y|lC^t0؆Ǣpq)OA{ `o= }̴v#8ek;h>i#8,G BJ3 Xt߲–AᏜWm/Î'98-O~ߞ9=~4Xw#ֻpL[Us·  NJs$
+e_]{vB$/#5
+;مOJ?@N$1' CxkX+]~5oX}r˷igĪӗ8Dݑ$ 3]*v ;cwvwV2^܅g)rFA#c0t|n2lDX `˅P+QV=
+?<Y,o2aU?S:t. TotZ!l%6N%Zާ˾7BbY?J &J/[;:G:D<mCM&LFC8<Z){d3q^QQdi&4JDE%*
+ (JKMKΡFAQ JVFeqL#(",9N:o:U~Uuo=σDTڗ
+G˯SÔxM2
+7 YiVSF#E̟..{$/uvjҗ+q*퐦Ikuڽ$ `*Yy[zZJ6OH8$b>o߷]]AknzsWۥ?iDu.O;){w;v4+%o0s`˼E'mxwduOtyoDMOo绳GϊԷNާQ߫a#{%ɏJ& 'D @ҋ s IӅɳE'˽>[@%%?gs/|M x^ XN}8ا^ U@f=m$(^ [B!tHLh~KC  lg)v\kM3h.wڨÓ63g~Y:<Ze\ExE+âC,ӪaZ"duom?3nU5'㌯Q &Tk6HEX 2}0~nb6@=CnlG6*o?*jHS4ۉ@S!/ \L`̄dNAD=I5^fW@Pn%=Dajy[RǴ`'mu}kgxhzMsީ;
+%6L)-yˆy@MDFl1l` ֧u6lv&};.܍wivc ?γ"P9Fd6wS_T-y:&ߘrNІ{
+=fNy}?E;w\9Tq"+&Ω5QO<PJr%ZᎩ^~pz'ڀ/V?ͮ(7*ȸ ΪE!͊B,Cyȏ*b_ SfJs^ _%9#aDt@ |Z\xtbLX*(d.OP2#,x.
+G3>G -/;֝9)MLԌydĤ 7bPċ1_pg]sQ]
+.#6 +aݥK+b!{a4+?ZȵȜ -%[qe{aTX#1Lz
+,ę?8\ [Q( Ok(# sP*\Dt8O8D5_
+ pt8!Ûy*BWùVB)袏F7X5 u:Xg5/p5phز}pd,E UmsˆM'/Mnl;̝ l{՜21UBk񍇾em]m`>NŰng>NF2\YI\d=̊
+p|,xP
+
+K
+Dd 5=vJ!*>?4m(8:i LВEe}Lim}d%N8[)8o%Ex\8b9Z՝6m[М^Pn{_\\RHɔ[i+u邰[Fc1cC¨'(v9uBv%i?<Y]k]YO{\vIO*mϕ˭hq]0L[;<e!hr}?6Xꍭ}?޸EA/룸!'yF2oK8ߕ<'Kgۂf>?=
+$//_ƠE";"eXGFa#g" Gs\Lt@aepC 8߱uH`9Lt[Xʂ7E|`
+Ӳ[JR1
+ƥE+KQܲ[(Qu
+_IafD8(`e^!}%ɚf3Ku;C syɓScǾ=juz::mI0 [OSV lW vkQ<ڡ Hkc[ ? "Sx'$mR0CI__qB%3"daFVo5I:q݂dcOGȲ
+ὠDs00h/-:6C$2kZ7
+L?1 {@BU+`
+o\9v}?Q{C=&ܟP2]T:aذuFƿk&wIG$% R2"M[+sȸY V&(vURtyͷQᬹFJ2 BNAffr?'o;,/Q:g|Rqɗ|)D
+΀7tѐiݎV#mȨn'4"K w?
+|s=%q>/2azӹ2˙`+#MYάP~N~]ia7g*5IaMz9B#,0~櫪4u$:$];{/Ne+Hr/vgV %7E!std[KG6gC.bރp׏QA4=OǼ5ϻzKڍ8tfw}. 2m"B  β DN=$ja ef aWfjДca;ql0X
+n('$ү/u3xJCs= ]5`\TAk;ipY,y<J?%xJ+$^
+?@wUU-DfH1]$6|nxQV oËޓ;v9\ p1QҨ^ioWLa k4gp]lj_ُq*;`}tJ2=?.I}ϗ[`WJ۳^V_5uszX8/EreQH o92Θ<w=lByx?WT`;
+]jtzQ<)v,py!{J"ʈr||"rH1 ;bӯc+U4/!f^6"hu
+l# qa`fSDA 8#r[1JRI*d+&f*Y~[[EzMi|hyW ]{oqnSiFjKnP>X]Ӧ?SuуP%y?++Ӓn?.MwnϏ}Ɯ{!}suClC~
+cA,<Te~B}˝Z-+WT^ (\SuW+-GJ?(Q*їˑ0 #aD^36Ón0'Wu?9ОM=D{` `'m`pD"?l<6,: J0[a>(`(=e
+m dD"!Z1܏ m/,u9|Vaop|΀E!/_+![ߏ. %<\Ti$1ߋ{KPX[#Ϲ'Z&W| ^6n8;NdXv. pim}ѧ.>/WKPz+ Ng\ƚM<N&qE+h'L+}[`$apxa|Ώ(.ϣ(A #,C>P<5PExWRXOiJ Q]=>o,;XZrm)=d\35잴kskl+?˜gc),;x)jֳ嵿U|ͩ?=ȕy|Z(kq?YIb|BhNT$C_6D
+:ء{[56YP&foWYpMȟ)L*[pB9n`wK2切B8QNM)SL5fx|A/ڼsD˥ް+IEōavx {{&jDSpNlxIv:F1ԹvckDS99߈f+[
+&lggvD#5N* S6k5IՓ*/i<m'tj=l=nxQneD?jݣQYDC3]eUOWle1<hYqp͏ֺzuv0~se&K#'G?4|yZ}ݬ4}fhWjTs=,39-QzO_.DZlcbŬtd|BKyh1lTϵLpX̾ѾK~$)[n
+z:{ǩ}L\{7pŧ(þR~[݃JTS%ZC5~3%
+iJO=T"V[Je}\c'w_e}?o&k86ɒ͢dvЅzu&9
+endstream endobj 37 0 obj <</Length 58190/Filter[/FlateDecode]>>stream
+H|UPTY=wA & "c
+7;-/)i#cRͭϭGabFE-l%֏fhm*m*^$"ctRLea#;br CȯHjM9t~qPq5a\K>9} {g~LyiaДUߔy'cPhՙ2¹ 8k3胻aL
+΢=lYrr<Gtdk7 jWhy®E5O  ) eB83u͌}T3 +ZB8WyY'=^_XZ{lIϝB~ ^UցmF5K޿hyJ|F)|ͫNia֝Zɵ5?h̢gƐ1-Q9Ɛ.v2MV‡০)CFҀAl-+d?<r%>X2W&y-yL6T^)ɬT V W +dՏaXVPsOVT}nyIŊ'c~)ov$gؒh8q) Icc:&uΌu+u+z%'c{6#n, Щӡ}J9xgzsZ>W nFɣ&]VK0K}$I0YRgDL<6J\$D~Jc%Xqî [xϡ
+n
+*S)e1'ia|6
+hhv'8QyrR8J,X,(P4- 4tnkslؤURA<K'VAn2{7/Vb+yNDD{rOJ
+ox)K OR AWyW-;bd!PI`bp AOHJDB)./ >?`7"1j!CiR~c)qk0"fKc)XZ9y-:n/T􌋈R;X?#V,*d#^8'ׁgރ()!bJM;E?3g{1VۘEǷ0fӐ2Wd24`z
+?HFlHٱpbɂ;-(a-
+gLM^5-\_M~yb;TV|9h,|a2InO|x+?[GZqYcpt?T
+9ߺѺ1<h52*5~ +`؅FN8͌KHnIr]$Z%[[Mw]Ca f0:nªD.GqiS{=:N"EM}{~!
+Kr\I}Ӑϊ"w"yT>Ҧ5ǐ9j;$NlJiLFa>䶋r,m!BM@q%0X+.Cv ;-FxZ*0[- k!Vqp&`%XWo'%܀P[]T֝ ^x.<`BA"2 L?.BJgsZGnSc-'rѠck-Ӷe *6NN9NRI2^XBҪHkI-ɍmIѺ+ۨ K<DI9T~xiTk pUj80?3 XUzvPOϋ;djp' a/-X֯MBd& z;! >]F7P2m(KoQxVDv7sV%mL헐
+BiCӒz᫋%a-DrSdhKD\GpNG3H$ZB=i>j(_b(xyġ7x휑gA[֘OqGIS[_p;auDKgXL 0urW'r:g /*ʀc4D(oUϸ=~ֻ;/ci?c|y͎1ӲmNo?nѷCg7 k:,uU4%Y۩.\{W%s}wdxGآYDMplQ8*TW(A˫A310Y7MC6z#mA!ڦr¾ʵGMFS*ٺb> b ORaOKfߝN.<oG(ҙ
+rh 2:r/02=;rRWl-EĶNJQ6AbT0(}A>2&
+IuY
+UxZ
+AD (0A,D 1v OE(TۡJNνf}>]@60׊gӬ>3gb ۱Xs\mÿu~aIBu>ewbbO F|k_[1<.E)RU7B dz"EMG'_f.xw^1Sa/]Yٯ>mK\#?d@f1~F@3?$Z e kwAԜ5D]!&!qx}yS)t̒ڎ-$"M!?t& Xh
+Pa\ӗxviUcbQΙ%M;%{HSN367U1]ĚX6"uy"wE?cz
+<6iJ#!["sݶWG3Sv$#ѕe?FxRyoy2`F
+"XW<'a?qD-xjdD ^SVr3db`DkBOF/:H_Њ̯ dW#
+-~#-/S}$NJy7l )E6hFnS6W~&IvջFW#ӈ|#g&$_)Pڋߛ/k*IuSƋ'2ԉҕe
+HwtZ!z\ӛ'cR>V9#h=*"\
+0ߕ婅O5lA4"iW'Q
+)r±EŔ72`Ja.OM$kbBL!`ٕ,?"a0288
+bL!aq!Z.')RVJnZZvm78 [noeܴsмai#wļi+ڹmXЌs{Aל#s?+8_qcw͗/|Ǯ<K}LY\;M'xp g~4x&;
+nfY^
+B.,JbT_obe9]IڣڂI/ ;iиMWB%.Q:RҎd.'cιv@8%oV­. ݮ;SE_XZe^8(`ڮoWb)[YG"o vq$ϴfciH\IKF_>ulOW&ni.稞Ni[(n7Zܫn s(w4xY>Ժ,éONgB-֨)^aSn\B>r#?{uGO|  ox? 9Ib.9mBԓUwE44K<wXoRe E#w]Q.(WK H@"MQAnu\UDņW]&s39s2's&32-VDMl,{wadB*JV0!P(K3 媛Ylr,(,$!QAaiтE/C^kcD˜}`O6®Y`|_q&
+'O:˓>,N3@%|+MWGݤawȻ97ƿ"ү,i﷜Oܤ;Q$q/KL"[rsN >'\- !}Hn) _^o~! w
+y$ۅȶE&euv7;`[^p^~DaM.5q1q-r%R23qL6V>oN51%nݴ3-0p*i1;XaFs)_91pZXZt~@u
+e:Ij Ha uRI?<u0]7<gHչ~R}y!oM q٘U
+a,e 6Ov͞S_^9Nh+V=c+,_;; F"ܪ;h! ;bBcİͲ` ͉^>˯d6_UVeED( 3ahp`OϹ M΂N-4QIЪM$8-}İ!q $o@6k=?BMjނd 5nCni= y`k4&ܗSڗv {#Ȑw%Of<SݝSj)?o@m_NQTKˇ:d# 9w;*ҟRJ{R+(M{\+ͼWO93kz<΁l<W5g^ԜN֜>MNkb/{(|mͰXOYsRߧ]+iHz{S)]|2'a*G3NO4Bxkj]YK&YvCvm(hz7Y ޼->Edt?Oo  ^Zi% 
+fvL kWc^(Gtpa# _`]|i*3P2"wizc1KF}&'vp[n/|qhrD^[SX[MӔIҠv]Ԩp IÖuդQZҴ{iݰɞE -{
+|h+l'`ZV < g=:؊~'w6]@%| 4ZTAi#i&䳯ruB49W _0+fIdqBf_ͺ_~e?#Nύ7 Y?_~Qu6=2tӰojI*S5ޱVp}Gn)/}IsLw^);EwʹHGۥ;'+}rχ%No gXisf7iϜHO!'Ӯd&P;;ygT%H;Nt^Iui6DI>'U* puAQDARH&yO%v=ҥiV.s]zXtqgU kW[ָ=>rNk۶-o紹~mr:yҬbڪXKYɋ ZiyyZ(t(`%:3>Ms5qq
+k_X-ݲ>iqK<+g֩Rg=*R)M[:8iS ޔqEjm)OH3~ i-X2G](}m" %Ha*N*U2搕W+ibѬ2n֩<杣*zQ;Z<MM#|Z^酑b/|Ic
+^NnU3<8+^ψ^Mdbk'rwo'7t۽z;ɝBјEf#')6$}F<ߑH6՗FL{.}.}et|weag E{΄DJ FYꌔ¯bΈ[$޳W
+_Ql]MΫﻴߒ/ڧ{ *Դu[Cthm@]jLy鹷V 3D&E$ "E&{vE E7$^z}W.hJX[1-/\c25rшC, l%wVサNK!Z?TV0:ovf/DWu*Z_)KQѳ+kU)SI.A}E^K)
+m;yaٴg{z?M[t'tҟ>!
+L0$fH,$XLCC룓 \'\'
+Dc?}hQH2nHY_AdXB:]?A {Ac͐9 쓐k E .PX& 1:yHeu@
+{ R 3!
+B
+4m2Ce_Z#֜'vG7?-f䭺VΠqeI-e$[05A$OPXUHւ셍  jubld#!ܱ)w4\kdR\iE_, ZLv0@ց~ <L\|j?ynxBq <)458#?
+27 GaN %컠.(܆2r `#!q`鯌usFۨf~iPO'?OoU-gꧭ. +喙G{Gsr^gʹuy6PٓSCʉVzܢlǚ8I[:<xs_bFٳo[6[x0{-힞)qE=}JQl*{ QqhD*}1rl,wj"a
+R,7!ߊA#bsr=\!K B XՁ|1SA /\5{˳[8h kR2XJ[:qdP7Ed*R̆ jqΏ)îo eGR6~3.A$/QA`6#lZ, 
+jքx,2~M&lDa׊
+|lI'oubXcL%>c
+YG꧋{}rAf]aƭFNZv=2R|0=?6-bhjn +ac=7İ'<!R`NXcV;90Ā/,CX
+.!e<\>f-zdcyF(yK^oA* '']҈WAP<3v@<"Ó 1>WH?Wj[im\VV%<$S*ӻD8]_Uk­<iҽ4ib,,ꝕ20 evYjD>d;d'*DgvG%%0MMEgtE~[IџdۧЌSebpQ%L./\ƺw@o#|C$">õ{=`mJXk(~Zo?5{G
+uEgaSMAޑp$MN6+|?֧٘5?m)D4"SHй3c<\xZxRܙ3)퐾R4e_4L$7njĻi{n.HOk+>7ih|̿|•:;WY{Oh^TZ?xPʚʚa%zv{DsJW嚧⪧Y EΉW,"Sڹ'Q'a.fԖ؟x;wwiAdwV*5ů/?o*Mp ?rwI?{IH
+r!a0eTZ<R>N&V2<"XJ"\|C*̭0m0@K</Eӵ< Mo.®s=BV- 1X~hMz 31H]\ &`sgq?Xtc `܏C^Fb`Bw16п7
+QL9p=$G3!|}4?ev$1HkdN$뎩>Ft|#augUAI\WB[qZ@i.(\p$A*{\׻!^Ӯ/SawU.1Gxn~c]M/̚}*˵RYȶH|躘y8/Mdk\tvJ%-8ޗq_-2*Q4_TFD_gJWwdh22JJ%. _0} "`#9u׭Z39M]SuIW=Hd^dyH^&_
+grX@# B](22m8Ƚ
+/P}Y v~/"8<!zA]_r-kpBы}-~:S:k[g|ۺ ЩzCzVuhp5Z3if0r #r˱MDr+%R̸f(يN%B"n]ϳJu*>ѶλxZ3g|J;{Knխ]tnX8| Ɵv>?D۪WL&xt+5 $p+sigM웼S6)3%wJiuQ1Փ>Z)aO | 3r;m uQtl)bWX/ kgpv/&"ձL 
+vCJϷڀNDž%oj$/W;wmQJ<m֦? VOs(F(BFRx{}&En,ܝr1'yA}vk<lB>n\QEO..X\9jxp_kS;]3XGf>gaU":~9ȈΈqN8^']}'
+
+*U[Zy]}/-.{!W?fdǤorևb #}1CuD7L3Ӈ]se_0JD>U&(*S|Q)O|l$[>ŒAOuЊ=9swlP߬ ,ϞآNdOiTHyW%'P8I%h㨿'PBՎo \Is^.u֖GƂsW4=w]GwaE͋| ЉhD3e-JљПP~: o~5x͹ s;
+6& 5Dž}D2!ԠBy2gk U
+0eKCĖHT,A6HxJ$K݅TAH|
+|>E{q$QOIcA|ÂCc5GR6ׂӁXDfVgj>?I>Sjl~*`/CQM*+d.`%ᭅއ{))
+[*sX!r);YR"Cy26?ƳelIU,Ҥ5O&R-zq^״[?/ w\1kFas4CquM6vO4D>GʛjʙBp3{F ==_˚eF#/r7Es|-몮VWg? nN(5oeeY\ev]sķ5WlT|Kr#=Qg,wofnT&|7;R8}Մ1\ .`WM悯o|I|BM(9
+J&bLS(kuCb:8b-0&83Q=<
+U6ԣzSބ@wTN_Ȣ:H["\ږ>_IfՆ$!8R2UbɊ}ArU _*!M4[f,A ֌1b v,N:޾YeB!$ j& M)Uc2IJ\\r{׿۝Ww:-jMP2p:42pQHMat%@W )?0F rWV0BD" bMIq}QY<HLx,44%g{Mbj"!i>M$"VDZ(9`P.G":_ a @bdòG /)enk'?Y۟"/j.7|"7hP<c.}Ƅ,dKDl?uֱ$-K@=.nK1VdBC'fLN _1d> |<nGZoUSRޫ&y(x.d[Px̩g}Ʊ^ܵHY8΃m>E>%0 IDqB _kUzKjN'3X% ny>;57 儾4Z
+VBmWl:پ9sk }j7=SPA܏lƄY\Ȉ6#hPL}UZJDmQ;u"gw|U~C/#p](xUT4*,~?`r9?#捇ys4V2=3GVnFN?Ny'Z{ܹ 8\ٹTݚI^:%o ͊r.82Wk~,_V,/7G
+#l)KN ԧ1 ܤ%A'O SpsɸGi "x #pk?< XW3I&I8@(%r
+~`"PAA ,b * ZiwZoZu~VB|{/3ͼof~Tګ u/>J)8.[Gg9^<kP<9U܇jjlr>l.0=@hx XVa`<C$ zcYO'<&E0 gM07d#CȀVx$Xw!l@
+CIࣧ"!;[#_ۯpFGr@Gw<9"c`7v3adKkt".٪`̥K-o+̣9 [gy\sg0x}Q-@͔)t7EO15ya!3bw߮kñJj2=ǃAY@ޡH֌z=
+w* ? !hb{`-uN-ġ;QeFfB
+XMZq9l4 ɩ
+}F8 =q3~KjI@xA9ŽK~7?6/ѴC'=y;F/]M.-v Q$!߷ozB@#K52Vs
+P o)̿D$saOvBE7ou(9E9NDYp]1<+϶Ȑi>̺ ۪(%4NgɃ^ׄ#]}B ]?]~0QZ\U>՞aUͿ/W91n>+͠~ۀ^O_3 wvQ?0Pz)}>TvW/M֝ID6x>5=-e.Ta rk>aW>abyv!FILj"QB.B}G(2!"2%' ٨6[vBE70+u G!Q_>
+K'U@wdQ;F|z{[}{@)P/
+ R|]'.^H r=BV^Zj g-l}BC 0ߍ<a(#v{j_ic^~]HXG[|ܭ,O{Kԙ[ƽ}=, |!]As
+}i^^(m0e-'Y e鿸+'ݕSļ/UDDz󗳳W=4L_uK(#dLo"ZT| dx>[_3VH5 ??+y/ȪN+"XD 2,"`eM t TD*v؎bݪ2.QN}ܼwoO
+LW&WLA#4 Wh~pɊ~[-v]B;in 3ݵ=[]¦6zE{65!h&æmsS~PNg<s<taUT11bE7yh4nr}vk璌%²;s*VT/SR>T,[P8(_20K+3硋Pڃ=C_{Q0zUq1&rWs>k^fIJ`t6HT.P$W@O蝯4{$K~Ķ'Y3vgL]6{4>BVgQA5_E:]L,6ɢ)xQm #vkzw`#h8{4.4]㇣зhU
+7^= tO1Goإ
+C";16H\vd BAZEWC(~n-ǫǽAUQ'S
++(2KoDFcDc yt,e9M g.̛MGp)lUI__~C)CY|_U,~Ԯ:.o=W8~RKǸR8LgZ%gӍ馫WCWW &Ϩ` \77[ӛ[qW̹#w79osՏ:?C  k)(.a+ex;ڷ/lCŽߌ;1mrndg@~vti$6(p+b&+E@0+ٙ.H:>R@B2>\Hs5>K;!fI  E[_;pMՃ#wv6K P[ RZ^z2:MѽY3=Ws*DOOI;]lPfvsJ=mgqb5Fa NtYS
+_1H3&|
+[waB4?~)!pr$`?QqN3[ :\KDޢ_,DBkdI7cz [TO_}EVƸnCĜߌ]ۜO3$Y%C*o埍׍0
+lp7R g}czL-뎛SQ&k>n"y>i@wshK*:/( yǻ(Z9͒5o%k0+m'ުvo1MW'>c-nbol"]j_M(!
+|og-:7kzh$#kS놼D{ cvEsgk;Y+{iӥeq%ewi AVAXvQ~ν=Sz% d!fOv/
+Sc_C5Cu]&bsD>mIӊRhcĸ3</j<֕eSg`Ovz6Ht2#ψt`4
+QA־ [{!T"Ͻ |˫D>*y-Fn?E^7Dq|My~?U=4Ul]XuM#+E/[ ;t-̉CQY/YϽ3 , McM$b$d>[-|\$z^,*/Q;O2ŝ*oW!䜟$[&x
+[65NumT`Rn-bW*^"L>l<U2J~K
++&
+$|rz_g=q8d_zʄnY)&w*6Q:ZDh4ڽ<FwIvЋ 10\^(Vd"K ~-z!3iL˓r?U|CFVecۈyrW|ƣ:
+
+CC3rm3@9"O2=ٳeqS2r,A
+ 2M=5]2G/.e֎p\75v4ؾG-˼㝂tKD I=5MSU”7d:8QA#V Twr' cSi'i"JfNRZ(/c[ Vʢ=2Uw3vm3>0KB%2ͪH4 "Bv?mTBDKы2As@,PP Ͼn4U2wxDP9W1%Ǚ]tboއʋ{gaShGVet|]~k΁萍Q햍>:-;.}=W=J)}5vbDlx}%]'wKIvCUWμϥStB:UH sD]ti&ϜFiS SHdB25 :AwIu6rONv4h[==<iqk|ozNMnfs+ѢZdcdaߏ[۵, *lW@H78
+#kde_qb' R}/*XV( B~a3Fxk W)mK~ ߕ_M^)i,w鴎i4GaOk4]gF v5gq
+~mqVpZ_Ĝ<C6v2DMaq1V Z0o~v8ü ߧ ʵ6kANr9q~ EEV{Q|5W(u^?Ro`.;umM,0jp,I;AæCYzdu2iW) t7=w+DCe>V=$xἰ(=}O5FA5LQm$x) %^z_Op.B-)<&)Udkt$eNd
+.
+zDQfeQCҍC6!nx4%iIk:<z},8j7gʋ&…EA<ݿ\أNY\x|r,+y/MD) ќƪƚ[A]7nytylnڬ_\qgg>oWmg[ k!BeMzk'ucSNMyUw wۥqR˄Wq%DE⩈™yr'r.*/{(MWnO/U1E\ԗ-tu@Uڣ4^=??uF~îQ Ristg| E'v=+U 
+ j4ѱh_\4 Zݧ'nE.Y٥f P
+3
+W/WVoửyD'>N%᝛h#iǣ!ŸBҞ:?KܝNw3Ctqt:`]Z h=l]"n@:돌c+h*ڼۍ6!v?|9>o}E7$'٫;}FеSevHL̨|F5@i3sp5lUNӒBzlҪQ r&pdf9[ f^@<fMo Rrg@(Ky4XYG
+u l49De'-#yd|H9#|U3,8,k8Wduh:pm\2&4+ۻv*{C
+ghA׃-obt1f|A
+rxv#hRN3ۦTݶiwB^!'Kg%쯻8
+OS!z3Roe}n;!k>)ߢ̹,',<ShiAᇪk>}Sj*HY#DW#DRj{![|]7 :N%!6>EuB2]YU66o8bܦ.ifbDc8YfGgmOU;l/P癥VCDM/YpvlR^U^cl6&UkwR؟c6:^4.|GS+rkҨYcGg3l][iLf5fabQQ˺ўL BQm-;%."ll_e1dyc 9Ug3Ag*l2˸@`ތ"wBQ A8pz]+'Ed J:G \h:DȬN8%aő%qIO,*w=,<*{!~ᑗ>0$hnY&X;ƬwoW$OIݪL-N呟sNIzJώqogxdztrNs/?\T-)EEk <V& G2=D$t'q</g =
+1ff)2pùhtns:&3BN$vxz=u@~fBz3Dh6AF#a#kb뛘b@8SATc! rİ[ QQZr*{f0L*MXTD-DBѪ,rI(3.3cĘqV7RK]>[JWƣnz*V;~syy^Uy"'.q"OAjށ]q;3~G
+4$&_C籫Z 4n߅_%Jջ
+\ó^r}M
+F%S-!:BlwlQR-PT_|Cur!xAw*f~@(\!7
+P`C[zfg)\/Krܿ$pQ2T&m ϦD^[/t`N0vETw||qSH4MlO <a$XI
+'ڵn ŏ䪛_O2jMK_sSy]n])"c*G9MΕ`;-M:2 TG5gt}lK!ӕlOFI?򻫾ev]rk{<ޞ@F&Ti"5܆\@ZlIMh0ρ VwIC2p&PgfwPޛ4?'Ú-_ .xN^2;mq}\O2HnԒy>qW_۩.X߫C Bآ269 ,Z4a/ *H3-Dc)D,΄#rz>DNN" %XcX]s9!a~-DkV@ HAO:v੖>,b"\T ,F$uMb䛍JLJ`S<Rxw[Tiu~rrƃo QSkJ1#p21a-
+Ⱥ59@R2;j2n"۶P~*ZCUbLd4k(G fŶ(9PoX@ Cڕtݟ/(tݚWHc\j3罺sS.8餤50zNRnDm_+6vCy@C4u|qcԣvV|}[l
+;Qoa'vR_[!ܹp@WmC9Tz#3j*?f/sōsG\''|MiۇV|>9(oٱ9WŒg}S
+YycY I
+^K^zO]IkҒgW9.i1WgpܬW׉,y+W"UR,9[>r8`@f@6ֺDVm*.4&}AZ䚱!ǵ^E QC+M+87ݨ=^6,V3Q*-Ϝ(Ț/76S!'Ǘ{$ZIȞtN(a&KVȚs3Ȉrryuŕ=8 =
+% "PS+(Qk`NQ9Der1*xF,5fc6FQz=V_>}ETBy$
+-K+(Iܵ/ !דa6ݏA'?FhNAZ/k*F)ӹ@Gй iZCP.mx68l&,\r>,Xl73]~.3e{r:/}@hLѶhf}?S[<7;tyuSE;/@3;*piW3Z_k~
+4yc༒:a}K.Z֬.E<n1
+: q 6_L@%6QNPR,/'[=1Z{ፓ b%S3> dM9O6we}
+7 D?mŀ܉zU:UD*Mu{@g>W(`>다<S:#)MԲޭ:UEw#J$DTzO:K)kt M_t8H!{?!HnA( -Ԍ@ʢ+aޙ¶^-}Ov??Зe]T]3k :6Iت(D(D<ڶ7Ca5Ϯqijhv%hn 1 B2fxN=I7c.n}V1a ;YlmQqG 4>M|U=kR6
+xwu#r9eDžb+)(ʳ2V=|+P~t9!hDsc5@Q|F3CBeBjxgBӞ4d\pȵ9BZ
+~(uib~lѮf|
+[nA>_Ď#䗂&SlOb6Bf^"eV΂ f"(̶,Yw*Z.꣤=m^g˪.%G5Wt)w+ƕ݊ʮ[T?7 侩|V5@ثyG٦@8@
+՚sX\"!V߷zm |&h򾧽2Sj|0$ Z@d~WlA
+vVѪcq (~7|97$ssgzp?݁x{ }Qp?{(ud\g@##u!Y-K*ʷ_g+CWZ\X 6T=LWMk] 7Ŏ[?9ȇ
+CeѲbd O܌͕l z$$] n]1]۷͍ Spbx#z[6h":uw7ę/W
+'j34_{ui,[ݒ3_,KN斞Twk*LyJ*YSJLR<C\:W"U$"$T,+MVES3vi)-3[)+5t*taZ3 mf4)
+1sbQް ',l0!!Cfk7@n=Dj)Mh6N})hN 3|m9fR,Ŷs@1<tBa!Y7Q;:Mh~ר(bU@N3$L c~}LAA !KnY6ytٸ%tgmQܠޣZ?b|1Ž-@ȭ[B|~ kXMb.J|D!xsA !{uVv\[=p6X!-ösr,i0fJ"B<`Vť[-tu8ؼ B$bۖD(drAg`dzϪa#yskP;S=pE(VS(0{0jj0]Մ_%K&WaoTWI)9hOCӯaJduoj{rT侭ݯe#y葼V9rߊN2P.˻͝ojC{ Ԗnw~˝]] JOo\aC"gԮBZ?$2u ~H @z?Նhmv$e ex>P.Y_
+EUN?3n`˽jJ0GכuCs2Ӽر<s4A$Y7UZ^F4՗Dٗ}o&5m *QbTB-Q
+kAi/؛9aJ$j@2D`[
+*DzP!P"D<⨰XPA\],Vxtf<g?~ݼr߻y >5݇ OyfTʸuw+\/jYѡWQ]2;:<oZϴiÀkz5\zԅnT#:TֶC6`ukGu=0#w.r}t\9*_\'lQ:->ap\2J+&B.HV" V0n E * f귂<MZ?X$dv} ɆGZ~} Q7MbnZa}g)?mzҠ]Z+vz?r2CO+Iݐ~IXuwvQ='ƵyG{O5}{-{*ϥÜ+=)]ba)4$龺=?D@3|
+'@}
+̙/O&OEdx~6W!"}8r"0ۊʲ0rUy8Z=}4AIfo<c|p,41[}WmAg/Uzf3>d)O[Of2wS^n}(Si39`@, ݻ4}ֶBw[؞2>U6gOnr}匩(c?pIT@7a܈kn
+rs|8wVx|8؞1X0>| 5e!γ)αl
+S/eQ+Cۣu[
+ѸG`Px ^*!Nbt*f CZQ
+Aj{[zgʀ"fZ>zHpR?ayhrH7uY^% /rːM_ѴnLM^_MI _-yoøس_Wf.0 i!(lR.8vPC2
+Sԋ;ʼRpHzCBq-[0oAf*gB{G<ӓ %A)&Eff$4o߹*72Hľof_I9$/dO v7gSʳgU$/k.徬Wf
+|`QjQ6t5xh73<Ы\=S7rsFKF8g-r m95fvF4V/%sp)K,6Vt+ť#
+6\vvl
+O4IJ0c9G5B5pJ/AQh8xKDZ q\x"t\M|ݩW^P˲>cSĠ{K԰wkԠ*sĽt}5wwS}U=FWcU&MޮJU2Uw<PF`Rп:g[h0X!cKƷf>Jq%;ħetsw\c̻^"OSy%cS{dœ{
+mVRږ42;E7$
+:B!D_d͜?tWc_ S(
+=Wuwxrp K1'+vX{
+< ϥ-Za܆t BwŜc{8W&9.P%苾^
+}?xt6BrS[vQ0Mhh7]YB5 oZ WDf#D $OcR XXC7&ѱOUާ^ncޟ[?)gﴊ~(|u<`l~gpK³̻0Npw=%%TR~.r}’Sb#%FF:ZPfT=7JIi%y 7wA-ON?h#!+^^4,ypxvE^o޲]=%7T/eJ./MZ-)*;ϫO
+X~ y.`s``-ʋ
+=" `+!BcC0dG@
+rMyثzTpXDUoz`AZTF`O!۲d6<D9"ɠ`jUkq;}O١Կn QP_v3QUAw:,@[FU`|H6šGǵi7"BV T\jcV {UB JAvE)_-&,Rߒ$+S'I=Ͻ9E+3^W>R(-
+R2{$VӸ
+E/eʬoGMR,QK͟QˌQ}]"I%3 $5 I*m(hNTn8}U=@PЇʵPr4;ލ'kwjlwBu`6j.1n]}컞CѤcY3Sޯ
+޻|tE`iT {Y+A ֝$Da7l<8tsxMc;N'!15 '<AQA߅=XjSzAdOa;Sn,1)ɶ2hxeUa t)w, s(qM> sC8L2#,A+~\5d%i#RxxgY2{=蝿oć`;65䔔4dbrmc=\>ᘖtuo+G_ ~]4GP<:W<-z;=Ę~sf 퐀:
+M q7 #7,Y*X/F'HFE!뤄u5D>{qw<2&p8 ~γ skaK1?}xULk6ļ 1o%9䔄Pc9>պ <ZҨt/1}1^:X|yAn;TF5!V~$,[9'"{B*OH}R_@z| ~"B r!TI$_d2<X.}CDDRnEg @vҭv0=G۴ӫl']]p׼N_Nfլj68Bpgá8~?̼Ȓ$RJTڤҢRfu0ff3%"U CdI*RZmӑB?\s=ܿ}5tBf0Z>ܲyL75jƨσN9-q- 1R 1?
+>)`hXNvUeqD[,xcP6s'$Ѵi.LMcD j
+g% ͼ,nHZؐ0^2pj+ob9,&o\ZOFsn
+2osn&oey?II5(uōE6H_J]垸C^|A7,gQ8[s_"9w巨?)e\O!kN$Ľ\;9ً]`o
+Fƍ{ rNŝjpkο)Mj]ǑKN^XU9Ni_7^ǰI]:CEcq1,B/@iCNW
+ ar ^/呿؈yUqUբoY:
+ХV޺mo+ϥ`íݏ-n}`pα[Nr26BY3!͸ 7"ES ,:gJHd[szWW|?Jz Oص*P>Xk[]3+Ů$( MLn",#HkR
+Y+rU
+viWɲo&6 WP;FZhFW ^q_Umoۚ}*|_OVo3׏g;*g )eB>|\d+'bbb%N*R*Dɲ$^7}JS:0F#D(V/A>rь,D=wbTBn+}8 mqgݭ࿱KNv;p %÷fyzשy)qەW{sf 9i;UepqPHSIT- KEAܯQ}DiH+ն1$8};Bgh:C@S*i:o!Ti
+ӧN 0 f/ l448D?$c?q}>7ц|C/wuˎu#9LenjXƌ\uڄ{LG[.~-Oi'?y]6>NFه*^*T\_zp  €Ei=#\s'2"~$cҌEbĢ=0dt0]s{z ꃹ.tnH **բ&6؞~S.Qndt=I?<$N0Rd,i{3RybGx Tx`y'ц~7:r
+4Q<
+?V؉_ː 1#{~;-@3VulG{L􃰚\
+ "ژѤZXJmzԸkZx$3AM_z>??v3A~
+YI$Tvz;~S?ax[ċ؛Q/[%b Tm]>?ܬ~
+܄3sy"fv#7L4j%pj@,F?fu)hb_'LLy p8.sjVڿ)d<>|ȋO o )OK<,oH}Z٘sJy*oPp~(dmwfx^FSԳG(9ٰ`s0;7<"g*ͨq7;>hYX@3Cf~vʶwQ4 ^W0.#PE̘!X B;ٝԬ&|*T57:֯2NgT9Nc\:Qf-dMZ֑ 4UVe;3׮ShΫW[rca9f"/j',8_FG+_LrЯZZzC-l42}˘eW <8l~M< ;#jWn0)%vSJmx6cRq~'sْjG,{Is1S@0|dwup4'[ ֹM!Bt+n0\607zV6yqmSsuVe;>@*(?+ { ϴfWzVN=+MX3!ؼ}Lv|vt|zuKl "uWw")Mli4@鼁
+{cR{DQ)WFu
+O9FOo^{$rv$>tn8'$ 8TNjF1M =gE?'SQ =o_lIasA~>:uptqpC|7mcD>Xq..f.6#? k“~tKK*I#ȝ@f8~oK=2_30Ufs>dTʬ}֥ϤԉLJ`U<zgђ 4p@Y9ͱ57UpVuA
+W=s
+<)Iy:y4_.n=uq1SIEq
+Fb>
+D.|J-/wS(bJ!4l:E˯'J$o]i·%mRKg.mxQٕ]ҟ;TtJ,w;J}G4Ƽ+*oO, ,Hȧ煔?zăb ?VK_8N旅&D
+~
+AM}Lia et2ۘ>1mLDvlʀqFuN6U~t~;*,Y.J89c¼xϳxWm^Y.{>;"Q4-fſͽc؜uiI
+-Y?H]ܬO/uQSYqbD_)MTM+'SZ_b/7_ I]~^PbYA!?BΩJsARد:[cFxIwr3.\]v,]zߗW4Wgp^ n&^S?^2ы
+WK*_l-[`Whw[~}La}lICK+)?*z'n̟MѼhŅ
+9jf.69GGp.s<)m Э*XdPӥgсmT#@Kٽfm7L~3خܳطXVk,q=ָZmsf89m
+4m%}v/?H~')CB1
+ /5jp
+
+`+'=3 \EDZԭ\B3DZՒIz{8vZb&4#8:HPy;h(S).Hbdc?؆
+J IMI*@9vZ '-4ADgFEy?}rcRGdF`VC |y<()Bomnാc'ُJ7:|8="㻲 Q#D<S6<Q{OĪ茍@Y90JO2K1asP$!EBI I(0!kZd.'|K7&h >3'ῖ|S53©:i_MΟ#c$~`Iu7^ޫ3ޔIӻzN$>dQ]Yu=5go 3>&#l2
+q&\(!пDi 6F}MĒ]dchϝw͈͛-6SܓV|6$:>Q [8Ԇ\H/Mzffl,Sx-k ?n-7x7Cy7T&N4mk^Ovz]kH6wRYusF^.wKϬh r(ޫ5`DokyL][lbQ.`2A/
+f:BV7Ye5 Q>8ݓÐ s`"qQ2ADICȊ%
+"bXeńaUϴ}_UwW7U_]߼O~GB6\)}!"b.Y'CK//߼}84'Yɹsd}ranYFQ=1(4m%r~tfT1vԏ~RY4X1!:or,0,}5:Ofi&dRNJMԪ*=k\KGI{{rUwd?ە5V-yoAob}@éo9<*W pى]׽<9l?@/
+QV1hlt09|!
+k]X4kF۔coW}Ҹk?H-lq͸
+&}ԜtbfJMYc\&x MTEh"<:Qwk {Bv#WfWD@
+Ng\
+EA&mHyϡ)f"Rb
+| hVe|[ښ;~g3VJ^UH^yQ!y=mEWֻrYvud}ݑV*M{-kJkGEafәZ!P~6Cəob`04PjuҾsHTdkk<`Me#e-:c(qK/;$
+@h!#MD)J E(uq*"ܻg]w]Xso?g2IfIf&Kߚ1w-}.=c>;u.+<>Ŷ{KWq [' GgH7 EXB6҄;T„:IMNݝ1Q4W8=69F4f{`|CbҴeN/bK%;$]_KrIV yK6 IvWރUY.ih1U
+QoTGD
+Ú-D|Ű$i{MZ>'Dc<HgɘP(7!zo7{og7JόtJcJn>W.>4Gn3ѵ@p伹Luŵ<BC#8fhh',-aՓ &p^jOw'W|3JЦ(1H/K5bo1b$Z9ۧأqxr|'\*LY7hq]?.lpIBȒ;) #&GE?\&\bGIK]<|k>}~N ߛ싞̎yo̖)ǤܧRrHyyiW>ɢ;S^py޼׾[1FT>PỄyWX`%Ҩ}(8)UfKkKA4dvh
+@u+>~go݂f ޗ
+ECBXa4F-17h3O<+H @vbAq)aAY )HXP"[ P" BD1*Xqapq+ijsywy@i
+_׍z\)~]ۓJGU#-#5?\Ĩc_*k5>0tIeXQ:eыz}@&"r5Gį*EdzV'8Į*w p;v$)"^Dߐc>H>YěW({%( ́+^?:Tby/VJ#Rl,4x
+oE^SQ:p@8hCaHHWY7iB|Ј͕hٰi ɼ
+J5:.z\}IB&{"#kGwO5DO c?^)1Kly舅U4Txf=`@`}d FNwCZwJ%8rV BTw?!R_ ޗ S8 ZrاW꡾T*ѐQjWB,:B)E buˀӄWb4I(JjM*( `4wE:}_ ]t\`?X L Cc2 *&5S*V6^d"훀ǖ6kR1KӸԓ^sFyf'&^ 'f'>UOlW{i3R)*ɩwN=~f׵'ިo]zo 2?x^axOD}t#6v o "l5G[;ӓ>ύ*=UgTsV%ΐEwS[ScsڙcCV P Aqڗ!hvՋ {Ou
+Ԥ.N3VJ7%ڟVYgOGfZ0MrS&mxV)#V1kkKz ?nښ
+endstream endobj 38 0 obj <</Length 47673/Filter[/FlateDecode]>>stream
+HtTyPW} 08r)
+
+dVg-Rhyڒ_o+і E+ orꊇ|(21/yǡ=?P`M{0q+ _ H
+8Oш+֞FaI
+&x
+L#=$KTsJ1š3o U1: Œ}dXyQ)oŀ/'GHJgfVIʿ&m">I9"?,}jT:ҩFOsZ9J{zFҍS$i2
+ zZHJ!+
+Q刖VbPX#BnBV4j#Dj^6V*ETG(DE%H=tM<͔M7Uޗ;k<WLMf:d6E]6mA)(G%G6Y5#M֊Dq3DG-ڇ(~D ~$!VrC6JIDM#6N"lCi}7DH!ǭ=82>`H;i{'sLϭ < .&ɺ#Kj,Z~.2#H7/ĕH\/ڸ:66[^AQײm$7-~٠6%gcYLd|z^8ٸ@vy/y#QJ8(IfrȚ̱in@sd-9#8p+zTo+;ToKMu{[MyO;5vEyYݥ.ϵ۵O.j^vk^2äqOMip=9J/f/M⯄q_I!/vcTϪ1g@ ob. 0jGLєgi*nj L:RDS:ժߢzWВMNOqwe o%\Xy-qprf/MWNW=chh>gz}r#LJ +5לoOLKy:˨wEr+nDs!}#{3kn^|IVu gtoԼ٢;<8zD8cl;e%{R Bb(C!|H6@3n:-P
+_k4"9MtjifcEWmAGqunݪ{zt;05ju̾}&`I7Pש}BsQߩzlOJ꾧qZ<bxg9˴"zzMrX'PN*DKv!J_[aj-z=G/O~;7yWrKTCU۞T(~]ؙ6υ6s>mK"Q{e@؊HSk@
+&,Bdx}!̢0B%#GƯDᢃmEoYGr9WS?-MbyrmeێΏȶ KT YN*Z!遅OMvGޗ7,xhw=;U*5K=9ߊ g^]_(T]2je@BB@BupT0
+EHeX
+{P|Ɂv$$$e
+IFR!b
+<? (ΰ B8A.>EJ`Q<|1fu9pϚ\^\ =o̹qkru|A*DhV$EA3»STN&\դ|i1R)rDyqȀ4y% `
+h}-<h"k2lfD6R}kIˉ/Kk&
+!r'icKq *TF7"Ȕ<qڰ0C;/,]gdۄehI#8W= ZH%C(EKawg" e" uޙv+H>o)LǬcǭD-Ga
+G ,i>-uʩ [iE߄֔=#W!W}++'S7vb7qɆ}R(5U/Rk^wNc凂ժ75~}cLű%ҏ{T3KMȏLpF\:ǰ$;91o dP*  FzE ,nt
+;N1ĽaHtiy!WyYc[4\MFmoD^I8/p%=rty 벧  C:j('HYG ɲ}x_@,B6,A pH$fNPM#>Zߨ}W+kZS
+,+ui7
+R-NMԭ즜X4.7ʜuԙ7 H "RETla 6  }_D#(ʾ(k[NgchΨ[\$96g>ϛޛ_*_z^1qpj2m&߫&R쮝aOhv?)w!?6][/> 5 63y<5Y0vvOgrLqnP`PrN;OibH>/߅ k?R;Y*[}_X(l9Z3uWxMϽBhfv2mWw!8?Yׄ݀Q*ҫ x\M4W]{&M!1wnG!˱ rEd[y ƉQ"Cx>/<;D٢Gd%+^0Oy]l`[\Ȱ}|~
+)#oWN)1  ξ#˜iuWUjcv=Sngⷎp{%<F=۩;|G~1:L_:+\c}*uYq|M}~{ n$ 6
+M\a^lKbuR<{RGqɽD˴1Ǣg9Xci}ĺ7~njr7hyV[+IF=AfvL1wJ[4ADc=C+(qQ_`VcwhYPqp$c}?ٞd]loHDe~ "MC(;4HN*=3[x>vwfl|H_Fϻ|w& bI/sٱ~43M\MّG,V%Mu 2׻R>X-e$aC *iH[ '=>㨄~adE$iX2, gt00,Eqw 苣8~yV@YnPy`i/74)h5d 1ti "?VzUp6;~T׈+{ nnr{M?WFI Em٫ɨxV^5Z^=]JC\FS\fSټ|d^uhh>=Jפ]&UW1l
+Z2ELF!.dZ=%-cvL#4*i0JʜT0x0wrPk͠jz(cԪ-}r󿔗iPSYK^HH$l*ĶRPQld/TD
+"a""t!`hڃt98c;ev9k8nuy}
+_7>,{RVۛaYk!C  ?2:mo.(9K;]^5+GwgRd|v գoƏ/8S]LB^7n? {xp7gj@Fv@
+fVf>5c#.+nH`]?A
+A+ډlˇR6.p^%(Gs`=
+2όMlw4^5$5^>ؗ݊[FQ3%휴 ݿ&(#d"/ʲR{|i~0h1'r#Bς-5A{`]H+d.ѭ`V=Czw)Br A+n4Mp&#1#`0G>Sjؒ3zb)$%u$6R)1eC#0'4@ˎ
+[GY@z&<vf|
+ m4[M\Ι kvk:u3{eGi:"hDvr#{xaJ @?_OКM%{g1 -2'BDVvvGv(5Tȕ^PG+8ňYL0N>#L5
+yY io_&({^pOsʚU/}P\+SVfgּR|\r]|i节7QOE}񇤚 Q_1PZ;Zh)֩ti:icNb苼y~Ȓ\l0-_`|TXzo"mJOi)8b?q
+\kl6|Qs<I!|؇ogq<
+\P <ػ Eqօpylֿ–haOF ȑ68<:O _{^ӳ0q!65b`3 ogjp1}= vɊxJ33ud>xIq;yY\xyCSFS6eiyM+&~6Y7Ewdml6jVR\s{Cqn=>5|`cyayu5Vdh\ l.)ӿڇ[5#oѸ#0ܑ4ߑ[NWLzw.i82{4gš#-LfV]OV]&*ۻS8i06ǰ$Z@ T{`%dEl:T?ܛAF~OڔBE¾E<>'qn?\wrsNw VRV2ִҗ\ԣgVe5$e`}#Q[?1);;me4?|%'C ɟjIoj<k#_Jz'һ3Vԙ9<a 9t匨4'F.vUλWە{9>EqUo$:UUߝx3%ƃ/8-]: _)
+b&!!PRٜ閃T;o9k;H5N !ѯ13)9JvWTjO=Sq?:xL\-Ib>|kuPgX u. W'b"8)ADeG)nx3*,u
+3Knz9%*NQALj:7qKTlcTUًײvUvʟVug8lpQ^S7ȇ@zpMN
+8C9pHt<-QGzZ#nT@1Ƞi\[d.?կ~6n1?KDJ[vK_ԋXua;!k,l
+;׸hr7-w,~YW=&=oƾ;k@|__ ;YϷwL~aG:E%;M]*Un-ljُ :<
+1w=$5#RZ {r'6lޤ&eq.WJƷWČ?(R_ SRߺN4q6\$dNgrTƩ>Mfz
+]mu,19Y`0I0P%nzw1y&'Hm`|E-P9|/a
+L2ß@4y<Nߧ.63Ez#wu{;%3J.YS>v>{t=ۢavV#1v:0g E[Fx@nQ`%SZ 84(Rh,i5sĭF~!m]^v@M52<ujoH-rCC[LE"TI#XGm҂VFmWKPC!噲"RQ~BQ~Hc‚7# ȞOKJW^6'eS!dŧÊf2<,r
+y 'J2l؟kߛ)@ZݏBj0\U T&{-2j}$H ؂8T[QApA9,JQYD$lT;BA6Aŀ #xXm=Ҋ#|^r{?_C60awFaeRv0N2b'Xo@>I
+BYp\<(6!QFd 
+a*Wd{f5R(5K/?RexRV
+!g䂃
+ثd@߇O4]`=3| `- 3C{ $bM]p[8<dP6 < <sp6q-)+6^8?]bB翅
+#CoKҞ^M{QWE/zEYriUC™QAlYҨœxiL}pR`BȥK!K~#vϺb3囶cME t>(f5nBB=Ew'=/Ő8XAU^ǂ*|[?!1N^3D]rvY=DrH{^TIu_%xiD6h`P> wI+u;gf]'}Α?Kg:UH[Ay
+Qd4t!wHO;˂f,fg ^*4KK3JDkA7!2eo@+xIaרJ/w:s4nF4['C$>浲ʙ`H$f_uz<o:w=h8ip@8yNKR'EҞ@?Q$ i{sS䉊DDvT8Y/z\7 *JLloz@n68AtAt.+
++B 83YG -S. @jwW=O Se^MӟTg<kKnqgUz "!+`*?`9uZA*U<s=!fx*䂻|_(XbT<kXsu`a.(vmNfA o9qBd0FKj8?D(!$up~kBD֚72ieSQ)fSBGstF;-v+o(=`5\gc7fDuϴF[vJvi;}i߬~Ӝ }nCZJu?z!?QG:\u'z~09wju'*Lʕ-0PkLn+Z&gNqy6= ôPn7M -@av'_`J +ZV.A"bRZQM:|`VĂmxkS[:N!]L{ tJNիXwӪ0vv<M+ɳ]XKZʽi} G# }yr¯`9püReܟv Һt9_F|I`PE8tsGRqV/vm#o9(h!lvJe#o1a;V{s^G{؞ǻԼy<~#Z?uԕ@6}QP,.'
+aQT:quZ;**j9o~Ilϙ߹ݼsM~N>&=9=zG,oE<{%
+5t9ھ^M?7Zn]=z1}3ƱqCqrĘKIICɼXޱɎae>ᗕ ¶ɆMMUu77qyM2* ?//5H, 'v+Gxu8o9σ$
+(^Z` mkz`Ek+*SuΣqN&g,
+~9s~f_k;b܏%8Z" T.-c_'6CNw\4i[Exz7]gcphR^{ԋqAy61!Ug߃dPiFU$QoCRZHf'^l ;"!]:OiYA[J)Bj("^@SBl<IdSH$neewC)ؿR z)VoDVH,7ӬSH~$G2!F(3Q@0BX}o^V];:w4mxWM5kX!Q+{%nׯDn:=Ѹ ;Ah{`K`U )fόD:Ja#OOBiLe{Wm;~]Xip<l~߂+-zMg35$h1av'=$D9 >?4
+V|C
+ֺ "]ڶuIWݰ*|gc7u ◍Zpcé#RVg&̙*zS:*x+Ft9e?qC09W}>m]eY R`D5Vb4YfoT(n( M"RsOb
+#;xkVH]d7%R-\~J9JˠZ.Z3kDtߝ#H~wi北҉W2]Hy%y2?oy1*H1+(]F+|YzBc˸'cy n jL)./6xl0*Ve{B֞?=U̵y,AECɕG~Uڎ t
+ <\q.$SBX-[fWb]{
+]Z-}GX .W9[$2ȫ.$=+
+A- =LbQ8;m>87q1{,9(0N:
+% g{=@:s>?v5Qm]QÕ!GϵCԪGvgC^ akk V
+:gjV\ -&Bsl|-40%H]6b9An Mފ ך.Jb Lb1O:XJrկN9R,r=ǚ~jun@hD6LhzAƺL=ɨME q@;drlU>'.vTLY]cH$$/5xV"x3R%gJ'4sPpQAGjln4.j^,hjZ'j‡ rR*
+3`V 8
+ҶtCAiAvUAvQ\BȢ,
+1ęA4.sLCb-:93s{]}ߗ9YTLHDOhGg/-{W=~xed^<^ /^h'DK'G;%ΎV<:7\9=\zG+ΒX)[F ^|yb|u\[R</r?[lː8 )3@t$am>y>&h"mxG3^ Dz_zQtK!j;vٵVwhW6]hg!M $ɟ(I%H%vdE@7 FdZ |;151̶UNCіQ@pG`rA_o.J"X^s
+ 1Jm<I\b"pYvC2^۰\d{|+Xt
+M+6jPD7}W^G!̤ݽ
+v]U.:6fP=iRquwf5߳[Eܧ6gDA*F(Z_@$`j ~U?נhf xҿ)u%I\O&KI`%vjXbͬKFLh)1(Ƹ;e?ix(֦[f½S&QcI3`B=U;5Ј0[ l?<5j?M̚0MμapQ7fK
+KHS;'{?Kٟ&1Liǽ4&e1L R X/~[T$r)z.o-oQzp]RUm!ٿ*Y*ګ<OṐҒEeAye~9\s;
+P1#'}i qc&cr}d5X!O:@R OGdbE8. US5Q\C/@ yrj0tpGH`PWi4F_ c5!
+
+XI!5w'lb`F@>TrUzack&S% \}J'jx]`}"߳
+ ss ˜dh2lrce";`5r: Zmvlղz 8nFspA'pus牕+0ٔ}s}}D?쏬oO:
+njDb'U@qMWY-kOhu:EJ"Qef!]wuEgIyz# )`6xF4mxIտ 5Z*!S2U0x6nq'SB" H=7MKHQ
+}K!
+C3.]ژТWyRm)iFWvά?Sx]0hJ
+:Z_b0^䃛p}k:k\EPF^SkJl·+7V۫ڿ^ao+[I^E˻ }ݔ8ha0_2:BF+]jS%;!G?
+j"(_%H[~+Đv^Ս3/cdm[f!7##z߉~7-a=^$t'N&v&dIqi o75']uKQ
+ YLճ|
+# iN8r2p!V,u/r@]T c @>x!wp'/BOCb5p5۰+n]hѹ?TǛIʟNog|Fa
+W B4Cl/C@ rS
+]\>X_$N?P|桾PbTCz-z(vJ?i T״:jѺ/te k`4q#qnĐ>eVqvx;:?JL8DJ[u H ]S XxuwI{6%sp{=Ǽ3W1~)xRlX%k\s XHX|5mpzC#NZNk~x78Ok:ЮsܦO[p˾_/{NպM!7ym#I\E{g^Cw
+: /
+*wRM1#tr0:'l8l$*F?:+p8CZ+ڂS2-pXrW9:VƜH>'(ajey{jx4GXP^qҠ BV<fgU[7UncCJlVrg4T5 JPŶ{vG"cA(]Q_ ۡ,Iv==>o0~VϦ11Y_x_q鏶02r?p~C.vB:L9kk1{7њVzPz&bIk>87Xj]lp4f[i`-P"lvGm琈Q]yO!%< O@D2ztzttFxxJ0y]K0DFkSik6uƵuJ^.*F,8qAJ"&c '_GhsNЫ°z|IubȞCُ]RsxK'89UrW>+Nf$KOwXߥ:1+u9G0ꕑ9ᗖ5I{hf'7ú4#1)#;eEru@z%b ܿ
+@e,F/_[6 G@F@QGQY<9?(:*П`I2)$d)QI@"Bo*H 90E(؀ PL%47P= ؞+)?kqSOY"4XwknK`Z%9an`t&#>F` D_z7Dm%_qڧqjYYX[ K쿫@W 6Mh.x>3줲X2O(KSWPHKflc_YPHMՕ,(-OvKH!t{:-s`f e'9P@LX՚>` zm~@@oukئo z'Rղ
+MKeB՟!V8ׅE3+uMXĚkݍ"Un
+`+}x"J)kf5qby2BpF2n<b!A~ AʿbTh_@Z8,_Y8<G ZGUQ܍_Z>iTjv
+óӿ0iSi/u=u>wG&sټs_[3mECGYo3?TuvN
+R0xBzsؼg{ä]k^V8Uރ0~'nZbV*Bi 6]IQʜ`eNU8v.d0< +8VlUЬ߸=]3+ݪ6+HzzOGtd39\|n)Nײ̙V֗
+Q ?~>.u1}{,:^Ynr uLu n/V>R}FÌF}]tt]ˠ{i쌷er~@MGH6*h򛳹udҢ)pҞþK:Y^ґ>^0;2񳆪y9NޫZN~_'0y29,]~L=ta9CܬJ=E(*$6kדշ,;K7Xd~~pJ|o=<֕<:|:A@H$KW:N7 )G_{*oK8]ūބիyA^UBb K_
+/ _  IJ?D N^WO<KC_ ARWs!7\r(uMd KEk^cWM<P ~+⍔;O 琢tj{q񐻱xLw ~'y ƽyGl
+C~mggN0O$9qwmjo:IAЂuE#% t =3)UlJyT|qHMuriW<17Dwخx(=ǘ\dE)ӍDReS( Chf cKeD\frFH[[iKV$]tS>:57<<?yޟ#mY'Zp
+"/d2VOx{)lMW̤aN熔"r8Us5~ f"ڻr lvGn浚ry󹑝fh!3ZSKŏSI{7RŻ k1LY bً X<XO넘._R$ 1SsSO\e}s0C\V'/)Ѥp︭yIfٱ=`sl3ϴ侍)Vo:&qoRDqLeݴ\enQJЖ Z.sWY._7 ]s1 ?`T1Fhl46
+AdwV!Xxwqc$D&6'DZ؀dCȬ[;"VΙaAZZ-zqsّT߼xh%hnEQ]p!ƴ^ZR DC ԑ|yYXBkXꕤQIKhN32Z)txtS~M\<T,8FE9i4! snx5GhKc}` ![4@#g#EmL rM±<2HI:Rᗈ^kY[ߵYjS ʮ3ژ[={V_lƕ\_s.q?ؑ4ٔeLD].PM,YJxшY6 GfVy^Ȣ3~rriiUr3iRq9,]] iem{ww^bShjt䱴5q4 5}u|Y3*AG2ΠCkߪI9w25VɃg2HYS2q{*Tȼ_J9?.ze{D5O{vP.
+GET> ~ʅ N`qQ͆j!P] ~bUhx_
+>G?Q
+R3qF $Tko0J<DA41%!1$2~wBt:h
+vGu82gШN3N/6NnIn WQ
+ XFA1REKAWIBkHB*Tܪb]VKb:ue)Vs_Nޗϗ|Y]%J7Ⱥwh8ds=9HgKd-YɼO+qK+tFq飕9`e+{'}/GO.E~
+SwRg(ӛ)|b(SN~#<涰,<ٱg_vO.
+WRE.Q1Ϭ{FZqhtܓ0rzcCz.iR!Rjx CY@ ca='JLJ#
+*PP`(vIgGHu*EDpnZ̦Z"rNy`qCM\†CLM@=fcԘ1쿛ȷ:Ueso8۷[l%b͏A!̊@_']Uęྴqit*w!V6~&ib}S/k:4ďե*=(cE}Feiq%.f% 9=˲y=.,^;,ƺ|>-=eb^:qA-Da{)w$xv*8Os$1!Υ"=!+6dCȈqIz)M|)L^us)HuE TQ*h^^k̺q_d]V  .l[S:-Rl3yW329+%+_BVQЛZgP~Z>T$R9oec/ʳTXU8X&`xXC}&I~$g1sOm-9TS;c:D&7Z&caasrnOטfee^C'SлImX,س"=.dYM]9 !ANiECk2I Y`48flC0 Lfk^㺟m<g#t5Y'z4/4F*p}^d/fs-ٖ;ؒd<tΏץ ~'v6+$u,%Mԋ+Y[ĵD’`C>/ex5Mv}F]sXmg^_3_ \x\ly ^c} {j{v$`J m[5;?sگ1?K+' hF:[2`v#&:?̊8G5=ӱA(;C+ֲr
+ئ& tz> {P0d)x(M^;zx67<YrdÃ%[zl}"{֭OZ9~&)ftoը\`h1|K!E)ЊQk4CTZ\Il?<]<u: WW 9z
+j lgux
+FF:d5w](nX)q'zDH?B1NVL%N4z)fϏwuԼ3)*YG嶋KJ$S]_C>SCTY@\1;v\q
+UZTuYT)z㭭v{X@D
+*{ē;%ܡWK~+OZȳ(;Ǽ3<a-a1;gܻC)7fIᏞ
+ݪ!W[F&Gԟ_ɜ\*///(~SwQrMeɫ]{e/>7eT{! H 0r
+ r x .A p$$!n!(80AN ȱ NJ 8L2!ڪzuw{\-~Y12W0?>!
+Q?a#xyJ"r(s'jw~t1՛S/wJ<"sYnM\a?_+n̹ޜWy</+ۙ{ B@W״1txÐQHNm${?L9ӟ?|1_< G^s[?H/x[si~gc}*)f7Do05k`bAaz D R"WeXRt
+`OAR1> 2G5%t;2
+P
+~+WSpH>9KzctQ$%}1C.f;wjC_z!R}Rk5 YR<We%`NiZF`or 7׀YA Q!RBĚSd R8 교`؉&rFw6OnK9߻rƼ.]EKI+E.ƏJQR6,hpa97ʧ:= ưCq):X0k|?n6M[PKVWXO(Ng(ϰ3xsib }xcwG)R,'A'=}tk;Mjۊ"
+:J)vӨ5Y@z5߲oѤwɼĦಃ(p.dwAe%R>RJVb)V'88)ʃ PlR-^\P@ EOBVr)V^]֗jmJBeز-,h{<sܚV ݺH]_?iZ0EՁJYjƋ-5*YO\֫ҳ;~hq85`9HJp1MZ0&:אƓ8uPX - FÒvKXKA_dv{9&T=A{F- }e%FR"k遝$z@)`JTPZlh&;c)&sj!ݵN")Ze~%)cԁi7QB|uC1ޥ`w [x~c 6cm+Z9]0WJޙ?L)<bmBXck1I浚Lajo$90.շ.$_;ݧ2F7 n(k-{8@r-I G'RY>Qde";eP7um~ ?߭퐓EX'q_`y 3F~0ΈrKUh>_=s[
+1
+Q?jC mnwZ{Z̵ZqaZ1v fX;bJĒk]
+
+؈)!v|zۛ,au-0i$I=qwS(hml#_@soJA~3;8@qm8^Cߔ#싉` :Y)E^Fkuz%UJ28U9
+\k| GQ@@DQDc6aĽ<H*bE- ;n5:"ǔ"icip3_~XE`SG1tQ[&ڬշ<_VmZf5D<b0G$puR+
+\ò)#X.>&/|M"Qx/_F.s8r#WnV&uS!jUk ƈOtŌyBB[lFpf O0X:E]?4r%!åq<3/TVPH8"v((3@ H wHH E) ppZζB(PEřwk<M@hҏ_ulgX#3qk3P>h%o,x>`,
+"+ h*GXD`/f
+4 t`X6 Q&\Ѩc@p5e,1yfs4E<^(Țh\L{_.z}u$3:$3-iM N0ϕgrio9-iyeE*5~OO[ݷN
+Qr!S,Q򡠓jc(x1:V@|{~kHCM \_(h3$S>KK2x1U:_fVliESZ
+:bc2 ؤm%F-۵{;Q;jwTezoJ^N_NZvH&U=KԙtΝ/|ߟ[jnWIǮ #U2x Sō_2ZK65a|OW0l;=T)3^T~q{AwDegˊס!*JtR=*}R%~YYd5{Ub^~%!,;y*O8'LW
+p^77U[ N2uҿ} bC1 @Mk]!bpJZ
+Y
+ϖMK;кڵQA`? C}# ]up-V22Y@
+Xx2ńae%"cJ 2?G, LŠb-x1ِ̛\>LG%0I Q1xL&!.O̲'lzc&Cp ݲʞcyNic[Uvpn-vX;mMͳ3Ն %u:f.׌[sNLuwTmIe%*cDmp q!ѨVːA qLjh[VE7Ĭv ύbl dWKnntXX\5sKUH^>D|Xc\8r+XwYD#,T.YD.煾OÃ
+P$A?
+ح1$D!D?;0)uw"''![W;`vza^,1snQAB~k
+u>} CD C|Q =h@PDsG C= y} zs}
+H!; r@sEl ~qy_A(ȈqۄyExc} )Cr;D9<{6pG'CAE{Fx 5/h\
+E
+θ"49$SkRĒR3f#)/UW+tRaQ:+\b :hXV+T,EA۞,LOˏKl1fX;mkm2hg*+_Lռ2zL(aMЋz:_w u U07\q<SbiSpz'L- uK?$RQ3Wn3ߒ\xvVۊ/DgkjփeKc
+~C)SÀĠz}T6oE|
+Ĭ`."sSx.O[)u;nB?>CND"AB]hG u6
+'x=C8.Vc`F/ 8Υ }-%|eǽߡ<$ɑ
+]#JYk/p? R#iBGkC#xCyM؁$(O*d#
+TʢXM%ESu#C}J» '/ y+B!/ZDIrp=&9*!Fi2RC(g¹ VvIDƌe쎳qd~coKCA\ZcF6h(\OF'=o'w*aexs LQCPǬfq+]jV/ W<o@Dw!>VWrk =luջ+=L×W|5T-zQUj^IaH^$ \M_"J/(RTǜH9ɥT&U S_Ej:{w[ cM?8hq=Ȫ>$!7kB,>u^PuCWi^uH+vIqPl 8̈.ƆXWWڅ7k;G{7~*[n;iuɃ4AYkj0N@fοmGwқi.!yc{,~ ~/wkf'U٢GB}njf3EwThHq1L Sω |#Qjd2񵫶[y\q(GKaZonKR]<Y٭Գ,2[-v@-u3$1MH4  +62/{:[e9Ty)r75yT]R7OW)SƪvU#M]xusk֟DДZػ#qֺ1sowqz'\mE?kF]s<rUˌJI2+0, 3q_s٪4q=-ƯUZu7eU({@:a+v3 7>LS'nOZ٘3WbK^9%\J̹kh>.MZ?\x=Bk6~׳uǀU>p l̀DK^ D·7-ٳZގ$F#`',FECث xFs;Ikhyz_0am,H9i3C2T?(h%M0'c(q,!c`<=KN`w1BN$1ֵ1 UJ_/n`0ܻLP(?Phk!!(Eہ}&]<H&?Ȥu2?ypPK!r2)pL0Ϙ,–%< Y4ao1Z]kyO^Xu1BJ؏I71 W<{&iKx2/mm>۞{YV1
+#)S=.0dil'kIzL1ҿerx4}q8ʀW1'2bU=]Sh-p-~l|ȞwpYZHDYɧ?-~zW 2[U9M8tV8@a&5~N[|sYjaYpA-* Rb*}n՛m60yVJƏ]UoD
+9=[3ZIq֊&m=kox(?`Ԥ>)DÍ<kWh,c.Xעިtyo&7/T!yuA;?be$ۍ8(,v Z Ž)t 7r2&[=/)?b>\4]Q{mE~bPplc\ Ur? AO"ȼ6ڥeysXCu¢5]>4yÆRFX˓|IGo2BC[@#cΩI+5A 66 >Ph3֠xpa
+ ãQ02EO_ B&<
+L
+>^ƨyS'qXCG䄴\܅ Z[Ǥ ~ Vh+
+myR^Q:lX_ݑYE玮ʃ{]d'WBQm2;9g_b$/!]zjl/ǍסX*C$z>=؊1ePٮB:WL鉱@-ܨg`FNQ2՜ 1(ڟb}ȠKE'\!qx/ Z܊p#!mtqc9V1Rqu$X mkz|i7 g|`31 QO7uGмu%qYwd
+<0jzDҠ@X)5raDeAuAc yQγ$D681t~ "`ղ4ʎ9~^*^JЕ}R%N>};U9WU^m] t6%Ԣ[xc7/c_o:^8YF9W|eO7_5}7GM=u##R;ƾopswܿ^K4TZCfr=Uo5 };AM[
+?TO@gn5s Qyb9Сe]Lq-XF!<E1I;t 0!3ZR㾂(S9Xa7
+˛x9r;w'LJr5dpdmɦ)c=\B˚s|kkoi[bcG{rsO5kr?AJd0tמc9P
+
+?2_5aKp*w1TIthmȿp[Ĕy#u@pmd]:%&`U y
+oZ>ʸ({6$^Cc>s |7.Cc'ׄ~ps}NX>>w+i
+wJ 2h$-q=ϚJ!OCKMY q-IMl]|_n%܃|Eu`i/uyH#S X>&h7%V0W^J0qtD† l4xg.,x0D(ό~Y+ -<_8rلȞ:bV.ܦ߃1=u8C^ݰkݦb̃ؼ1<b&ua>#pKǴYLץ-=%AuG=T)->$>t[=O+CrePXʑ CQ3B|~"1 Ϻbuxd>WxhȪu<1gX|/?;i+}_ɾx6VP~snz`CT"E$U/{n;hM;Dy0fA̯6:hނ"k٤\QZ#&9bŒ֤rz\{VzΞm/8,3,B|GFg2i*"[14.ujb s31Lsq.jHԠmeaAԆ晖[*ܛGe.jo 
+5UG[/L
+0uy ${NTh_أ 8w%lMO5twG#Kc!*PDۯ[r߹v?m)ksM_mjY3[SD\GO0fO̺A5HY~7|lM9m7VN1yHu{j/$yRk:jg59<F8K9{GiGi;_N7^Q աߦw* /h4u^&`(Ș}9[W?<9qIXك7ݭGWEW[jsv/ؾeK{{N}zew~};kO_g#m);gk',rl AiyAQ"$729.͂Լ 7a6%b=FW<` 'X 3
+S($ ALd4O5$E
+ OƩ0-0nDd 6QƊTR5@m &L`GmֱjW]2 Ƞ3y}Dv܂
+GT+Rb﹚:MUy%LQ3/GUU)ֳ,&{|=w,w[DlP+Rk CKIU)NS /4뚻c[sLIyȭ0u: j
+5=`afCڠPn/5r~P1&9Dt/-fLTfCYV9[ rf67p~)^G^P]2 ws˙ #y%<X {lwȜ![2J2D
+#}JGCoE-~a2`/m/؉% f𙦮$} 8dה(8Oȋbb-'<&BZ$7[:SK ە50!'LP=[u1]0&V&ߗG7 ycՠ1En_D7>lr1ْnNj$ʎ WV z&#z,u"׳58ϯȧ<q|wcޥ#Jꦮ6%״\lG's]7'~;׹Ҷ*q 3~;(מN(d\V Ȣ>ß焇#2k_. f5v`~2LJ )"CvkCkVV{ľf
+#j473C [VuI7 {~FM-҆;psRpգå1ŭ^F#fQpg{bm oN1 jJVmk?r͚-, $ES% 3.[э &<WmMa"fަ eöBxd /a*;Ќ>aߟ#+:=a8E/*!p2h0sRǍt܀LZAVYz{֪/kŷv|FRr~ަCŢk-CvAK n鑎(uN; <䣤r3Ʀ=f~?VH 7| vj };tHoՑe&2wxP"REay% r^H.y]]sP1w'yҎZՏǻyg*o??7|-W\?AEҭHr^l=_u)t Ҍ A&N<?@05%3c t> {.'O6{:?؁ICf
+銂Lpr-{4#X*dj&/f4VN,< YUi9HgA_p<i+* w<F<v!>ҿ9%I~^]Qwۆ9<5gra3+|x?yS/|sXk&XGJ2)_p$`]"ϔL,,V᪢~g^M" Œjq ps{INPx dED{`OF<v[qkv {K̽O; 㥝H8/Ʃ:@Y`B ȷ\!Gn0L #Ư|7J0RH ʨ޵l3I>dbʩ%$4L-U7hry絁 ԬnvĶw~BS]ݙ':'f͒‹΋"nwCsRdlz֕bNbU;\Oږΐb-ɂ4h E|_DҸ8d )Ŝ1V:cTSΞհ"5Miv4GP&*DfJ,xy̽u7SP>xX ]o9Qkj0Ϋ/\( l0ld}ry:_ԅē`w})Zr`?) (}\)R6i)QsTm%vjQz:j
+OucTu0r^Gz^m4/5!ߴO$ w)C:߀g'Sݐeˣmp ?l֎Q]dg_8gX:E16*򏃊3wN7> wv;U7DDšذ֮w*^o/za'8]q.s=p}~L$_bgnX^|n]x$ MeKUw߸xк3ꮤpmAxc&{ EE~o8aV|5Wy䐱RpPhOo[
+w'mE_莈`3j<E]&{3<gpYhloA@t>)6x1.
+P~>Y 7 )cG6$o>1iKwh<G{;k+ꟈ\h#J"SX7yy?R=6l()"$B&#b0 \ģDw:/`K/{<MD DG,#>{3BV|
+>e ۔DDoBcQ/h4tt[H0Va C&(d ͘pz[wmU~y\,v0eT'kuآk^:5dN.J8P0O'}!ƒԈͼ9cziN?خAXV|_]aȎܼ tQ{XE$pL65!|'-D G7h LӁXϜgA(,޽]E}}{n|w!dqM3mKj熿=vlK3V]W>ұI1L}Shpyҗ`h3do-ޕɱu܃U'9t.[~K{
+r|W8TFc;Yy^gU;7#9EL?(sJ5K; & uf\Y~IUӰVom۽^Æ~9s7%z\-񞁯u~UJ%;];>['U.~Ep[< v%nՆi >71r7𶿅oM_s/#7 n}ҕ4+׆u+.<>`n^2 {% t{PJhͦ,K fl7>R˦ɚTml5ҘFPp奇ʋF[߾d,wW0,c,zTS. #էl+ή7Z>0hKf[?}8;aw`/a71,$:a lU9Olϱ ԜQMi:>8,Ƌ]=;u 5/G:όH>y̓ʹ3K
+mxxØQBٓ3N^6*' W"ۃ\lFw 6Cc6$ޑT|@~
+endstream endobj 39 0 obj <</Length 33692/Filter[/FlateDecode]>>stream
+HlWsS,$d2R:4x
+K RjBi 0FIH0-odwKe%k,%if~j_/==Io;s9{@<m<
+#07|>қޑC4S9¬ܔ4)on*İg8Q7t!{"‰
+^1aLSy 2WDQA9! ۖ&E8U8?QA˛0QyVb̨%OpYiSx<yɓY5vY4)YI qC\poOqKt?4d^R+O iy͌x%tEoWĪ5IW%iI;i<˟>^D䅅vV%0Ka8nlMl 7LJxDǞ~K6 Iw[6ͼՖYrôV
+ T_BMNRVZxBوa|DW?C\DyVrRmM%VϬ"N^w3y6Z몑?Xǿ~<)kOgu TpWp?
+"tOFO!m*d~#
+u;( xV ԁعr8w>;&؂7
+5F<H`5؃i7yA=/`LW:}O{{b|3R.F3 s} c֜7r,3Az~vм޴ssYGͰ()yu;Iۺ4wlc2
+90k>*6`=#x<2=h *O]rXs<2X
+-c%04 Ȃ)09o C3 s hwO& =xfܲE#̝i>᯻@T#[jKG{=)eHnE>N]17Q{-iո0c'd3<oe9(z9%y&$Ɩqur<хi"Sƀm\xpO4I`!'aܡ9p{[>TO=QJև > \<B#<-A,95&t1gyTg[tժ 94SSŽeK644޻f*Ci\uk3ukw#cѺ'VyT=jRwhdX[oEyoPjj܂nXh|pRPN<퍣Ez"Ҕ V\J<4Q$mq5oZwk?-@fmJb*v];zLjֽR vs]>=zy[p]';uMѾj鼰fd0)'+;IRd*;gz͗I ~9$_55砨)+*`Y_D%cT6uBLxP}}> b$ŕ?ԗ~1%i:4\CYsU;$*+D8A|o#ȗ7y%C.A3;W1^6WۥjϿls':νz}U&k?7rK q(sKy:̹
+CzJ[9$pM5tjk(
+kSLioK=mpR5,
+\QT]+Ps]D1ЭN 掼1_EO Ά=+^7ߩ)ovrz4mBI
+p_fҵPvmDy|Ə%Y|i !<\n[lrR1lUvF [|+c [c3+u{
+yj
+dżH r!lS‚ boط-vy I І2WSsoO]EшU,;f ^@'gEŴ'My"jlb>CÔ`Ž~!֪UzŜ) PzapZ{pIm0[aރ'n
+Qz˵9ZW"O ̥>r_x( qʿ9Pۿ:{B575'XԸgx>*]%3#wU6޻4(BrNسn;a6ddFʀ[SF n5҄[ޤx<B}U
+c:[bc*)RmO2m쓥;tpM萍8}\''FC*!p{ =x2
+1SJ$WD%u4ȈUO#w^g.3Loa/L jkYmK.=Ʈ}A9rdRJ>dyvƧkٙrsT֣2o`hcLO;5(]XU]WWRu<&DG-1cLzw=q[cP=`uT:P]V1,8.̂IYUq-4 M]Z˱v~1&8t?<їT"'$B"/MmFO̴ޯGϾ|A4U!3!_>~mM~BYFG3gHyhsݏŌJ+6i_SWɹ69d !^gҼ҉u2/5kg4&7
+^NW47wQZv=sS 7aCplS)i%{s* ST$'\Fr]9Ky"Ӎ#p`zyy8s܅D6/Xog҃o-DJ< ,3}ase~ ei
+x6Z;1vC{LZDC2m=K]bA`$vԕ{L탄IYYUiP fb.!MGQ5̔*xgF]<V{(4] pc&P94R!s}T,#L҈){\]'݄xر6</S ᎍG9->4A
+Ha?go^pv%ڽ?\נx 6'3/;_|UD"(fDpA%b]T[a M%̾2  %3
+7ff7MZEԠhpgj
+QFX6v×h֌JP]&9~Eύ#7S_ gyS7<,.h1l^~g7ߨwV]!ɂwdn*(M~!čjV$_:\(Q*HTyIÖ|IZ7Y##jL1oZЉepWNP wujl*S/ۤ*[<7TCRխИV?oq sG!Ѝͪc(6hz7(!NzgfȱAȜR}߬R;S>M!r/5p+n}tjjtSÈ47wN4Q74B/Y7?=a(Q9~˞l2]`u7N+l/L7ofi5;bcM}ڼ`!uY˺GM[7qZWhެ{뭽?&l'K𹗃1Ca^ ]x+c0(d74uK'-Fo!GHADې#]<7 ](~HўK[WtVe+H/AКmȟOl^~i?fe 'D ;fzz_mbzG~(do\<?
+m,STR 9A6_9Q/hӡ<+<>e) _90P(ǯ_FN wD;tyDKPeYPLeeA>}cfA:
+#3لXƜ9ZLM =Y0g}wgRfc\*p7VQy'Yhp%-dҩ)g&ٱyu8WǠ:ms H1"q?7v^ž'vWE0q$2 QWz5ζ_YĪ(R7aQäw5p6 MX\}>cq.lɰnBQfca[- }A`#I_5)]܆Ͳ&s:#bSYKM
+Wqګ<ltG^:;`fmG>Æfu8
+ † 2NjۈD`pݸ(qz%¢ .M@1Rޞ{0AC ҨsFRΦJZנl ֯c說Cዚ5Ag4) 75FMO:Xrϋo.H->6d1C{xYd/=}[Q^)lIR,hCϝ"zV-"adB[ъok>̟TЃ"◠|bEoQ"+*-V* 2mXqh-%K5Su?>,V5G|NvI˥Ҫ潪c6ÃӮ-W|œ.є.Uζ{{:w5MZѕ]5#kϾuy+-+CUsꎫ
+扨_%a䧭G 6'.n)i|FߥoXف3w/Z [ i҄~fVw<TF3s½ejmzO ՜4}YHO_bFuſh:s^4֒cthq o6D?0ԘT_}ħ/43ʮҵU;HcMi9}=A9k6T u89.d&VÙπLGe⽰gS=3|rgj~|~(y6u4ak 
+ܔ8'7Zɡcw 12s=~xH'<)J`&q~l<nD:,9N$ |lSĉ$Q++kpUxgA =LSp`C΅ |_T{S){
+2o5'!Z#"
+6kQ9锲mFi;^0п8Z 6a_ +jG(:cSu޻T"F)xWt&G@fZQ܉ՀHӹE
+pQjr7""Z ii5L6/y'?$
+9bWv'*t?s^"iˇ܈C/ʍ%s!ɜ3$ bJ<fnGztxx.ƾ<#*uM[O&aն<H^,>9m'4Lg,q>y>#<[vEn9Ɣv*f鶦$܎/kU`t"`>L:) .ƭ:X]g${Zh]SG#1''dsڑSxZ΋î3ύ3q p
+@X_ՉB1"DspxjlZ3>Wf5er`*) |D_k8SwV|i[Uw zyzcŘ˃ZnVL2VW[ӕ ihϥUD΢ØvqcBж([s7J܇.ĐgGoXZ՝nkPԪ*~m~*E/lR1;`VOB#^
+J7=V5%?/<x4q1A|~|?U|q/~l\o <>UH
+`Xo7c/gh>&o_'6-?%Li=KtkCAutM_4vGs4 4+bQ*WD?mݱ9 0{#O7^HZL g[`n'A#!#-Cs=jJa,86P0%拘-1<^^'XogKxʀY716"$ `~ݚ-c&Zv?)Cs7L~AO ]c>;1.{8y6ֲ>;ZOpk1RmE1N]_vjlt2 ЉDh/te1Kb>C=4Pe3kic<y jM"m1C:e#Xˊ@6\ό/4)hDFq4ދ_>d1z4!j<}a=+3օ 6Bo8VE@57msVxn4F|!A0ᢹzf, +NPg׌NT6gj6z8:-b}o"մ
+}2׀[9b]S*ǣr+<V;)1EIxwwӿϻ,]FgW^k;CɯU/E9Ah\KnUe)z q~P}9.55ؿ~8߆s˷qyKN~FkP6G> vz=
+EmN&-Z%QЭ0|ZY]"lﺍ{VY lA\}tN*+u:U `Pkѩ΀-ЫzO4$78 >~r_qd1zjiS郄 ,cޝ=eO 5SRQZNbvL{l_k%¯xvr\g"mo=yܳ03pąyy^e1/wY!jZ<+xmf!mtd娽\g6v_m gY@U cl:ۼYc e;<?nj4b_q/mrȻAMG7-YU$+ ؒ%b]O~P1}Ώ0FUvϽx1^ߎYqWZYV~pOEdt W1 !rD&4"DD^{3GC!ȼD*f
+5\
+[*>vQ56d>+%vhNva"{g>ؙءYxA
+KP#Ix&d<%`H{5` A1X ЊЬi3#9ɶ3@?fb1>Ef$-~~Hn]Ph >ԙq= zfI<1㘘:Go
+-3NkycO+\Vo^RKw*5痬ځ9}^9<<]ޕT1
+|38tgqXn%3+\W?:,5v w
+~{8 wG{fL_nQQu^ vȽB㝧zuE\}in~7d^#gM_T~!*=7\s ]:yǣZYlL8ol5&)o$yv6 :QJU3);oLM/TJ]?ҐuV“:ùʱӲ5c暞O:u*w%qe5RɐlXn2)cu(M}rt0tIcD G2߱W8nZ5n.;f(QWo)S/uu
+-#qwl _1'8E£qأٰJ'YqpNm<9VyWcr 7mJ6Ƥt[<"_ 4HD+՟~3vڪ ~Xʳ>|>zU,j2‘>C-wQA$p
+˧GކL}ەHlJgΘʪxr5->ԯ!1o]ַW=h722">)̍tiSe 2?)gdtv(*EGҁdiI_] >Y kݗ4;=y|PcnIq(3]59u-R"vJ.ݽV_rXVPh^4shf* oU i!/poM5\Y _>ХiMmj8S$}L o Mʂe
+|c1-жk+*>ߨ;+
+/Zo :g5CDta,0Wi>#,Ԩ@ߟ) .]z$Ay$Qz-3{@ʳ&\09S BBx+i(X݄AVsNjc+j8ԍp`ikح /g$UVâ.dsCw}w
+6.:$W+%q; ~
+1' Uߡ cۦ̃ٔ('r#8oІ$Hۇ.v&,(&B,nJ]XdPބn{/xMԜfRp^$]\t(xNnŤKt럏 UeeA 1׌o^"fSkߖZ5yźV{y'ƽ, I~kD6P+&Wt2
+bd^3lW">.:6wyp`<K3fҌOɦqT%Zf̉gu00M;v.p qGze)¡=2oϚ{߾ɭ+G*Ӿ1ٙ;SH6zvмfR?DGz41jƓmXTD08zTkbdO6@ɼ>@gVDŽRlI'j\1]C-ΛOwn^RzR2ƻr=B_~p*i:l.nh<GS)k}uygv|u9ˬ݆CQG𒣵WVECsԟWϿvso-5srŇfEδ՜Xv/uvJ&yɎy>d
+&/ٚhl~1q]ǭ4<N4IU_ˊ>plk 」+uD
+g=}f+?j@+6hGtF<l;x~OӃn/:?tn5hg6ཇ{iP%?AZ(2DUpݣw į_#1 /0?"7 %P E#-K~ RƢ
+< t1GHd8_&`33%3>2#Fx&KC%tD]  =c8D{8olr}uDcK9Z~e#0SE/qzNw7!|Ά@Ĉ`{y2Y,wz#N e+?"/"A2C?3SA, P.|9!T?I)oKfA3hQ mf Nz`(}
+
+>ޗu{w!LbMH,CcA]<utGffNe>v8l]ƑqX.Lu[sv1 |:%N9LHƧǧg/x_Ӣ!<ij'Ɣgd%n(@EWK]kefEk\7VLmEm,:: ~Y/xlRѷ^Ết]X7Կih\ִ5l\{[i^/N um粢
+j9N[R)~SE< {#=]8p"i3U#}Tj}kڟ1agB6RHSB(>9GtOb%7|{09=_K-"e"29=a'{j<Oc&S3vz8A;湏=c1Ű$?0ws)=
+=Hϟr"_@&e9pv= DÜc3rھl⇬+-#2j;=h8X}
+z@wAn9(y'>h"r\
+p5G",Օg;9z\Ҭn+(r~ݶlO*ᮈ"7dWߪ|U}ɳOo{3X~}^wS{Xi5IΎg+Gz3{k[U[{-v$欹&At%jpVϣʓŏ.>?I?S{r#[/^$y}Ѯח$97GwF5
+
+c|x'ulW|#2"@F2rRVmp(S=՛dfh87j*lѯٝ-ǜ.aK]U?)tzvWS;zlUeޚk4I' !{psBV >5lyWb>.ߤ-tD;ӏ=ff,M{md_nٚ2˔S9d^O)&Ќ [2B vhgqǒ8:q*ɭcuiǃtϵ=]jHJB uhOt+G#NgzZ"/ 餝G+"RѺ+m|=([CWNl=Kʹ&mT|s+>./蛖RӝıG;e݄v_?aNvVN܈ژZ|]z1/Z ?0rm8Oz|܍s޻}L]/;HQRwPKD OBZBScޢ!(LiNKJv g1V_Vu%+rqX6'K?<$
+H2rp&$$@
+B ":Unm9VMnn;~;gt^aa"6k6X5Y{,s#D0ZVjM.︱6Xݛ 9U&HzG&\ԕ>+S~Z<>Բ1y[Mܮ5^[yBݮI.v5̲2Ns݇wgx(d S2n5 q!_Ṑ M^ڎ,a;>{/вL=;tf\G|,1g{1W_g=aNt
+_۝^vC_DB,‘./:3b`3!:5WYȐN? ;(fN4f^AFk)O;ND̅>V3ºL2PAS~xGnA
+4Fܧ`d=ngx>j^} 0 89tflH:䕮mYt_"׍ b倱Y#7֮4õ"!ީUC)?Fg3{ }.X9xZ00Ͽ}7+k|O3I'U=㤩E*f^mUpأ'G8^4֕͛*m< '-7\/ox=G"iXH举i`,&}(Rm=K=.RtR+52B|Şg-35ދ]ΨUooE5lVOu5dvCgS˼;E>y7_/d}k<YTW\_\:)6BVUPT1("=X>#qk¬A^׏#iFn&;fGh
+3?z\ߣ/O]?\ +ڑ9&ӹO{H4R]^9K=؜tkGbY;B}>\߯^=ZnGy~Cᕄ6?%NWs 9F3?,ܣ!b,o[CueH VcE~Aw~-?n}}PqсBxa9cY^e恥=},[ne5ޏj"{i+Xuv!UQ[{r鿒]y6zwuI
+җ廴T)-=qZXzYȽ bݙ|ȁQ.ݻ2q+c,1E`kp @ws{
+HX޴WAE0N DŽ;
+w/3c?#=&j\ Z0Eƅh<@ɑ)?6n;Mw4ap@҄k  ;=?-yjm `1hơ0@BC1~
+ hǘ<ih://ȱ}A;6D8ffƌC(nA{{#m@ʚ1Ae ^B+Syy(CA$7 R=t@nD }rcfg8| b^?֕kpׅhW4FK!!O2dhgk'ndD3sY刃kn 6ۍ ?gl: c2)x 3"ۡ70b]H9vsț{`,qЁ;b:_dFd+IT2@蟒ȴd zYjQ]M#B-[?:8 핷1'gn3ʵRjg@,L5h %V=W'iTܿHIh)i(w\٘俼N1Y>]2%ol7N2mtU56(놪t#Q0>ÔEc-IL?%i?h
+3ۀ GM: B<nQ>-
+fM}5iwV[.niSҹ:l?߿y?#| ? _b[yvëټGyU傢yYg癬|gŗOUq
+]
+[q%7k̀bDwnȺͷ6ŷĥ["`y.vbŏYit9d֒I iQvvI+YVZE@D,N=RM%Z@vDw'Ky?R%^>ωŞ0x1][4k
+]`Vt'
+E'E1}}N{DɫV1Tյ# wgs׎7V[<6f
+T謠O5Ѭ}I?ަ1Ccc#!pxd16 tI74Ӡ0K'
+bbQkD6xK2zW94ޓ3]b]5tO)uW){v !"4`9A nE7yscvڣ7Vq&-׹'#tE9J.-{m6?^}pU;Em#Zb^O|,{)z_lOTrp<W<Hn+YV,ӛZk5#
+ӝ=Ra2]yR\s?Pqp?R󠱈`.)/R0w\ovѶ5[\>-vaCP<.__ÿ|-ʹX_@OPT{,Ʋc?.$O97>оY_|F-nwj󈅠xu{qsad2?<_˛tIdj?K>20|q[vkCݱn}S9_c|s{vְd,AĈR޶K9zmD}L?zZpsg׍sIjG=?[@x@MYm8 #Q W!o!?=n?2M,h+ Piźq"`] k81Εls;]kb/gcCr?˰]9!`!FЕ _<ؠJJ.cCʄw}2!?݇J>Mwǣonl1p]GJ|3}ϛ}GF;Ck<Yю]JYq̽TIh3܌뱋Rq.L>5iGFۇ}?6P=xޡ+m$ޤc ޛAe3̜zݡ7ql1rFqA?~]r%
+dB 7`5 DccɈ~sN[t,5j'1DݕKϽ.+>[_X1\s\:Qk h˚Sg}v~^cꆇ7w~RXrjc^
+4~h,'yCgAd <o[U!iq~3͎{.FoDvL~ nYf! LƖ~}ҩЙ=fEn5(6H47-{]m}7Є1e9p΀mK2#zۯB--=@|/
+(d%["mEƃƖ0q
+# =yrtVa cӭD KЕ>\z^$r`
+΂+s{ۗXx.ևpR(xnX^ʖQI]C]HJYn\Yl?Εpf#;HZ;st7F?wRְ!@<Vm-2O(7^m$WPLoT3ELgk_Գ~ ڝ?JGGs 6rs#'=h:?<ʑx~}Ü>3saګ_S܈smmۑǭƣN ^SpR`Q6$fE9an泉qagڲ9ǚ:>JkHz 1mݨ\o(LCHVL΍Վ Z NWcЕ|S;pƚa*2TZoLT;eڢk;WY|dZy~br,oPIϜ8tX`yu7
+BVr~ex^1wdLWu}&=WuV':M\,f4틞-kGV~﫾 3s畺\yDR{@vVx$d$W/͒s~\G}jPXkfk ª3∴"?.${T[K$5fl [}<`9rُ1j<oz9
+ՁJ󔷽#Ȁܨn%.'׻HKVmukN̹, ''=8I z ZZ-8&`=<
+BvrD"?9L7ĉwo(¶.qh#>|7LU>܅r_  蠍<Hzхjo,3%~a=Ҽnw/cr M,ȂL-rg?̢qR}&>;fwx [KY6z( >6L9h$6'PdcuQ4Of(h°s򨯽)к^CKmfA{WLZQAډX.reo 'r·,P>:v3a 1+}]VeEVmy{nA͠MeEZaO@|BbDքaxڗ,]UamQT::sVc=O|sI[_ۼ`t)*4;eiQͭiCȷJdlXn7h |l~JW!Pf iErR;c~.+ m; vnRb(m=N H޳+jJcqh=KlZ+L#Sb:V5ӉfdDW @1
+Ի<@|! ^ AϞ~e(~.d3EyҢxSUidYM/RTǿ.*`דI// |!bg{DsQ(m>H9^:x#"Ly_SzTZ=:ʢUE!
+Y,7w&<{2W{QZ@Tsz&ecl'MT|biiL}U(-c?=]|ۼhm/RUŏhKI_y2N^UDy+~{{364o)"N)^Ց[5xh{NYOToa֮Mm.$/kVU/ߊI:>C"ǛO}m'CImLe?.c!s\ p>FĽՃsHbDN#an3yQ{IQ
+U{6+(ϝl,1Q/;쯾RJ|(ZAQoFQ@%KWDT"/n5wxb󠦒4
+.%΢R6e]$~}W}-]gQ7n.?bBGwSm}rk?{>=&y_y`<o%x!/^9K=نeg6`w Ŗ39\ ]u *f.oA7`Ap௽l$ o1SpuAu3.\>Y\uWtonP:p.7zsgނƸ} e*d Pl ҆9:qn}أ0^0؏}{-B·8ӑ20Bރac>x3}Y ƃ1T1ܰBg. G279G\ scmqγY Ga ƒc1pv$}N<=m2q㤬0u |?}.F/G"H;u(7Yl-HilzLi!؅XC}Ĺؤc~ƒH>tu_:qs~$ 6&BB}[Aǜ1VVrA;qb&z<* ؜KIXl*h3Z e=eZ/n)3ˍ5&Znƽ<;Oe`mڛKjʨ+L1y8GxR_Ԋ?=Y[o k "u%ۍ&c<h-m,M[3Ɛeԕh zU<9XYaV5#- ը *}Z,4kn
+O8T0gNWr[G|82_Z.mFe&,lfD(ܦ0w6wϮМfgsd&܈>Q1~g<I\:\tL~P JQuIY_WdļޞԽNBP/P4'NmY3̖lrִhn|OMIBYY"}e_'̎4}'ǟ5H[{yZ#WS۟N^vg%U^xP/)~?UˎtDnlˈr7)imUL&Nu*a]l)G(ҡYI˔;ټ9ٌSխ0a^dZ} 7¤d)׶]Rnr`nt
+LP#K\p6}]4e`ĹRݟ"ҲNb{93
+Bm+G}mǙ}z /}.6QAb~ƈgϜ|3aRfnx9f2{6 {=sÞ˃ B (;ɳ\as\}_yӘf0~ lys
+y?1&eyNɥ} `=fqyXߛLzͧv\1o?k'$A#m^Dے#eOg˖-%^k?&/S֔Ml^TchDQWӉQ/C1r}jO=vgY&l54Ap!֨42Ln=v:Ƃ{bAQ]ӓ _%Sv7*GnGZy]e56 MR]i
+9ʯ0_ߩ\p{ȞFkO,-:6#AsZ"C(0auC[
+n5d]Yo~pF::K':&VǰhsZ{cufM P`F"NR"o<ab*־QE`jJED]\'ing)
+endstream endobj 40 0 obj <</Length 38983/Filter[/FlateDecode]>>stream
+HtyPTǛ][^5\(x.xcƁC.E(B,@9Af8EYWJjle"~zޛǷ׿~ݯߛψ:-$@_j}["+
+Ʋ%
+ZPH" @-C8cؙ5$`S1\o thBr.Ch B;"} B۬ڲ!m^Vo%d;$-%; ~:
+w$ \O*SbGr'k)={/fM>oO "?DƸn)בۖo[.uz%xi}0GVv'6b)ܘZŬDk1N-d\}>`3 :a ePoQཇ"\NOכr$2x2 9k͔OHk?7z&<Cpg"ڧs\p![.%8ߏ36y>G8s3&g/u/n"Si6jƯ3_{U?S~3dĘN_Peu}F]U^[6i*գخ/׭͟l6͉AmXN TUtWv㵙xudpO|񯕩rLK|TAY]֫}%cơ:`5빧ӧTjt ]¨Q Яnk^e,.\Sg)/5+{k0:2:~~xqaGФ\MgeɎʎ+3?gBQ[@pp96ʅۙM0ϭ:`
+% Q_
++)k DS
+2{y''g%o/:%ÚGMr=jKz}%W=%~J {=n±絉GJory'zϫӏ<kΉ{JKnmհkQOZ2%jO yђ!jM~Nj8qd#zV"D[Pl>u?N:2Q:QEG~z[GṊ_ݔWs=i=-^*#ՓtpN \gfp&5%EU?,s/\o*=$\ZiahhV,6 +vZؑwU
+P}$wəH3_n1Ul,1ˬqTbBo_xN`h8~#xxOb1Ȗrv, 1gGQyπa@}<}_{'_YIx sf![uMCvx"⃵{)S,;]AZzaB̂`s[<ly,cyoǓA ?
+s'C]n`8{2ﺄ^5Mc셵k˫:]e. S84Ӧ&B!:uU$j>fs5 XMsSaKس>'Bk1
+<d)fSYe욏|RU* TmD>c YMxRBwRĥY(Y(WQ}w8F(Ğ[ȵUM99y6T}`oe|\Μ/,GK5ߏx ,Z/Kxe:y,$;WyԒiāk)Y\ƊpClbGI[)e`xɜ  "7p~QB< > 'fOs 6COi$rCprxb0Zis (Fƫ5PhdXm,[= <(W7yҾX;V0ΜLS* ǷKL8e躾TWliShNo辯mm3ZU޲8C]{|`G *:R 'M˴J5G;C>J5Ä vT>7GY̏;e{o<k9ާg0҅G2z;B=qlk|?6fa2 ~гzyi'ǍE*bTО3'Eٷޏ$cvLZ#"9N$L%?NۧDdI>o?GxF5u
+ "9
+ZfeUVnmeL;5ǏwMH]:\HwZ nX(Иo8}d}>_0XXytd%:c6|K׃)X:`}dVggɹ3e8l~127vFCNƍJo;FAqXaqXH3ݥA/~~]%ոvsC܂K#>6 Ր{06!bT_2f$Ag,5ݍ cK$ܟR'?O{7ҥ-_k$Rt*tZ1ۧVk{OS9խ=
+M,3S;1*/nVWJesŋ3eW,?3(niRַ΋zF"ɬKQv
+{>K0RHܛP GTU]Q9-+Ut+JMz6pW@( Գm#DHЃweUoU +`B~3
+:gc7U>~IN+xyIϳ|x)OFt3G¬Ey.ea;?ld@ǟGױgK<g"~T}? yJ
+x5O"}^Ex5?K!kgp>>Pxryg} 2:]2}1t:(3੔uBgqpC̅Y w?Jw{RnՄMyCgW_ \)Kp/toD-0~
+H'u$f?5dE{ڃ tJöG &CRi8!Nq–!jI6Rܻ2{M\'Ҽi7"^ZQ>#mX7AGHf^6T0fXꃁog"\v{(4-e=hLLj<mq;E%{ JV zJz.ɎҿlO{&z<@6ϫdq$
+obց(/P
+[M%dZEdݹXaWRhԕEN|mK#s<OS#T8M@Oo(B$v%Ngk[(ޣk6xQ^C kզa@Ϣ;:P~ùu>`D$狥>]f
+}DZ m𶱾 C[La0/c| +[BxgKt4 _ܴzсոm}!ya@[-uҾ6C༤xt.#9mD)aqt294RZ"{i$W<Q:Fw[coUNexT?J&ypj^ O)R?8şM4L*|ݸ6dβO&jZU]K] ufo[}G#<Se˘b[j7ȺUQhOUO$(GTr4VZT5OUŒeAcB +z3w?m F|`dqN7?~QP
+Z@]gQM%i
+OmRظte~txC
+*29fCЅ7gSzQld4g(oh
+cPapQ^>/ LwҌxJM<-mK!3}UMm[5Y%G@!倦`f#0U}W}wQR5&.4Ws#Tmw֬QLf$o#Zl`@5 XicK3W~qZG2cPsO}>}rEڢR5uȖ1s9~*wԞWz֒f6>}OȡVk|gKs ~5~(o;qr}l6p/kVrJ+-hKEi47*#.Qz[P.EVAu~~9UV2?.'non|w-ZLf< .1mŅg ~X𽆧ZMwޫ~JB횇֎܉֙ѥm#'Mg/ݯ82ճ|ba9SQߖrmB14PpvvgCsMK}oGfoUTO]-4vNÆtPx{rBŖ徱e{GQ.޸9dgsX[o>>?aܯ5`(xKKād2T^vO<[ex<ώFeLEH.Obk:lSLh߯>VMDJruYJ~t%X3Q=9FfS|3"Bz/>@Q$
+/3Q k" ˄Nk8+V3nEL沠Mݩ{[廮:9A뎴>ڤҝCuQIf~Mv ]JȰeDKp!1ښ3g:lHPȥ|*mQLUG9Hlއ)Ri644mHuY L3!e"׸xŖO OStkWm7\Kw5
+d=12!r ('܀P܁b'f:`Gc(NXN"oтA-g`AӜv ?{NG`yn=?x|EN,|ID;cb%8Gqyö6=0z.Ds aP)l
+v$on*kd;x:t f 79i[,KYP`a D{\x":Dm3EՅOyOGȼ'sяqwۙi))+"yp:,qmIב\cǪt%21> /3뿞b]sYkYJ:+(f8>aTqINZEuU\K,*s:qƠswFXn(U_ϨՑִ#Ԧt0SYN-LH36w ĿPlr4k*\knS\BFLhƶ D(M"\MڸCXȉ799 Xq.dWD'_ˤu0abHku5t|-G3i&EF347 0b] Mh <`cwy<[ҍ$\g%=}<@a}XGʺBY]=#y_=+ky7S܃O"ekaixI#Tu|ez|ZyM(:hɔ*BBk5rBQrW:xJL Wt_9/k[Vԯ KBMrV2/<[sZ\,Z3YPvT]Ec)ڴv\QP7ݾ"Vw K^?0HpY48NiEouߩO_:oVpq 8^hKa@We*nBj }U< ~G @
+;/3G YGpwz`eۂGRB`;]vP|<ˇ1̀81x$Y0 hx-I
+$j?it۰}Gyƒ DC+Ѱw_3vns5s&} A E>d9亰# LH_?d>1"@u`B` k
+k p\ R,ؗ*|üɧ5%:v ooKۘғ9ѓܽ'~{_mڐʥ][@8?4$
+P"{?xi`KY,OaĈzidB$铚$
+H4&yhe{rbî^_͗e6>.,Q
+ۆm[1cEC|G4!|90FN
+„Țqa۰ ~h
+*![0F r! FEE>l9֭=\{-&~jp`vG ;!`wQ:F(B`_>?Җ,cLq6)L'9GXPp$ru"ǣY ddjxCeY-x$=S5wsr.gʪQk;%s&"% gI%X*fz-KmDI4‹wimje a5x}Y]Sgz)KG\Us;`iܛś=SaLAB?[A꠩$;Wy9CpcH%n5lf%-2#
+\x wa+ [ 
+0V$D<}E~GA{YQdn ^o~ ax}SXklIrAA֨%X}@z
+( x];@;tT<M%P7b֫'t 5acW;<'LHdnaH/O؞^"zv{hƢxւ@eiKzSkuƵ숯W.4]T\~|r8uM7?WiXXRX*
+F U%?P`ȡ?}:?q|({+@]!ǸG5Xahȩ|eBXd{BD?E+C)LK N_֙Rl'Hs'eM"K]5SDEbty\ţрko(/}[qx65Ҳ+oV8v͚BO_Lo/<6<kF&LuAvIO6}ޠ~)#8h#N1s|MlP/ŁL1vt ),cm\2B#lݹЛ6ޤGܕFT۽M*"mNs.<kF.ĶyF׻;͙nGAlDJЙ0PaQ!ɽ0w=axwy`2 4kfeΆ1ؤ -{@[ۀ/ջJވ$gazxF,Q.hͩV u5M/^)k>?i:_{W׺64K>.UW&jˋ5<Xmz=k}5Kdg^%K5վZnJnhz~{ua}SuŦ6]sJCk-udseEӡ͕AbB7%]WLlOKF6&7F /eˋ
+ټ/Rղѣ^|1.Qv?N9Xm4?Ys9̔`AV~҆C !&H>ByMluL to] e5n4;s#qw`q)3~\ "0fAؖpERp''/W2AZ_1gb/|kjtTAnY)eutָ3xnś]{UB7ՒQ^ܻT{TZYȚo [d F3.$n]7Gd܊)6{[-6867:'j= \çkؔFKGm8ރT}zbbbAzG V =LyEaT^-A[& :  ?&x8sMo2w6()9s9X#up|v,sm, <j K Y0a6 c/F qv "~ ,Я8 u^f (Ӂ$ MӵMTΔ 7t0@͝?[bK1ѼxW]8uʥ;}¹6~@C܄m]ԾwG<g$s̠`޵#Je7OI[);SR٪״iVj^A6F5KHH+R;.Ow[WGz?{VELY%ue ZY[:gF4]2fYyX@Ⱥm7ȕT2Uա!>Dw=dW=Ly~H^\<<sgV$)nt0Pso2[r+Jf('&+ِcDEgH!xpIA{6w5Ƿ*&.9&5# =.EZ$!;Q*ǰfR{~Zn|nmq&i%$| Zx/܅; ;*/
+hFB#P{n9RqEu Y9l7'},qi{ ;C96<hש>2 m;FQ~s2 \TNRlېoyq>?; y>`b{6U.l<W `c҇Άq9ݹxlF=%QI7qQ
+C[K &Ӕ^jzخӠ<
+6j#mt꘥R4l$~LW8Lϲ+Te!/~mcp_n+~1۳q?Rf;A|Se'n~-#.sF;>ANΘRH':3I0}Of/t]`x<o㎋v lnxtЀq1Ԉ1w_40U?KP,y 䯂6@D6}܁#\ml:o;a~f6$
+柯ߛy*:fçݘ{+fyIfYCTX.z*b"nДK_WDmtYJL9T]ގR J4'-h(g^_#?i/LaYP6Jמi9TYtc ]|Ə[:qܖ vǬYIY~ʴLhyB4΋-s"F 8O 烹!ºʖ`q 3LQ7?]R2D;=i_xxN{,<tbg< wܣXOӏϐywZ2xw[ Hp/Ц=
+2:Al'3YXpQ^kQ]-\湷gzbA)I{K - I}sflALpc&d6K[ZfWmE7n.Xҁc"aZt"̭z;m{*lifBw1xJp>&/+e_syw"a\~{]?U/U^dU=eiEVD+2֬9uת.#OϽ#ΟgdC*ƘT*c㩺/J֎@G^nmHHgX+da\3 mLͩDŽ|ŀJj6}QhPQZeku` 2I-dʊ}zu}~Ui "b,<bRP+%K~[`|HJx+oo)gWt cdz-r{fw! 吤>ґ ja?ްT['!H_~dz)@ӤwH&Q*x&w 77M#𻸒o,>qAT-z2!i{}?wuWcjYjxJ-[bC^fN2 _Ss@>-
+m5y
+yVQ|1,V%)D1vux1.zO;>]؝2rUMdi~
+QM7vkhNKL.׎(}}BўL g{Se*)|FvQ}-c;JN9`QG']ي^N<lua lXkm4u^KqQ$Аŀ< ދt/Mbۗm{w=+x' Y0-X
+.bX}3V-6s.F`buw>2|FpŶ7S~U)vi6NF=hU/eI0͊Y¾YgH'BtʼS㼼C8ցԌ=gGNe n";<P"n="؁[nE@ø}Gֵ#O`m2=HZ>H@c`_zpΒ4p~~‰xpeKX :}n:d9/pϹm9'p|tK `8}El=1 Nyz{Gh@҃gg?{~wq(>F`s͘*p|cQBCkt"]L{NR} cy> YݛjoU_c^@w-ު[{Eܚx!nʽ'mJWGtwdr#DY}*Zo[ Y?+2`;Z3yL##[_kyZc[eQ}.6eMfD'_a.u/ѳ6xή@cHZu=eӖT8t<aT<;!N?F,Ro߶X%GW7m̯:{{!AV6{9ضV] pNa`+a2˶Yz=ҺNܝ2VϹ8cSxM %h8oR=cu'1y!p3Ϯ??ӡ(`{l;Xwb'AV7"ҫ}wRD Yu׎SFVj Q53X,pXt}2r"Ϛ`ӆSM'_PL醵Q.v8xr-ȃh>]-Z@ykqC,և9 K/z ljQ<BŊTz"Ɯnks>Aڀ]UwuNR?*.[Z?fzsfUkәtCV6(2u(OuIP!x] -hjѪ Jcl]+b=Yc΋ ՌQ4KYCw VԬU4rs\z-I> ?,QWwjy#,i cSttOvg̽z}rܨ Yb$}><SFWzpd`ʠ
+Ow?5
+ClQk ]
+gM?'Jņ<蹁ByX)3qa8g,C e0 +6_Gմ>[(Ʊ;gOvDMxzl:CHMdʼ˅B%v+r VxKvF' k%H:m62ˎ0?V ݜyVw
+Vj8맳#<؂#EׂqvAdEwb9+r>8KLd}x$iGC ܤ\QŬ$ne;$|e-h_-1Cn %mחExF2'ڐڂf$Ev#,6%dY7,]s z|; ȃ~9IuL߳ &H$TțT9٨o&ΏjCxм5zw-^hЂh*5moD[m"0 mEeLzR4p庹+ӰFSoC~ɣ-…QͮvBճ~|0-kס uӸRk84 蔚=Ӭ3]u8^1=JnX(ztAؗia|^ޛvgm4y{Iy&F%(OS;-w
+WkUJmrnxtM4/aLwƜ0w_;\e̵z9kU߮l'+7ō437Vwr+M)j?pmnUQ3X'%J[q3VgUӥWSUF=i={cѲ"}Hџ|v%v+ȦLr}_-Y=yA# tXfkC>cXO?5Mwq4Lu$iV.,͞bHg5
+Mz-RfydjfAu[ܿtk56k·V-GMbfM^\Jii=SP ԮLgBY-7F5Ukz9(Ÿ7w+joZyN0ҏmZ(5^
+D) P@9'y 3k2&2F}@ qyPW2r@]G3!\7l&mDLE栯5Iˏ궜DҹiAפs(3 u0<s!q,3R(qk ]£?ۧ%f˲gUX[whO =T9|'e.#5;[%;ɑ 2r49]-<7=r
+!UGr!@> %2c_uʆrv%r}ڱi?oxc H/x@ԿrJ  iP _ }|_sM;%p(PCD$l2#&{*1@7^
+q4GUō3]1[nWh?X.UEõھ)s-qY&ޮzoTMcgK߳oHwuMV)o뵅 _׽QsׅXǫɥ6}\#iƻf8}TO1"w9'EYG
+f+?櫫RT^0K6ur}%eUr kZ[s"|poe>\VȒ翽ޛ0+NBzRQ%sǟ^=.Qzskwz^oڌ QQ{sZqPs=ć wAQ)~ pÃA +w5,IUEUXX~ p)//>aƯgsdy=OS:zV6noySɌHn\( Iئ, UQtG/`yeS9%-^dp2\]LJmmA߻my2!-se/Ny:ioM^GC8~Dױ7!=̓ΰͺ~M}C%I!i?gΦoxfA\[I3!t~shbn>ccyj-;;R}ط=shnDC :FpZ*z$]Ak3ZM?7KuFZc\khpn$ҨLm0ֿ[>1ޏukMg^]2XLPL13-:{̀ xI Ɩy#`I hG#zJA}еx+Jf|5 YGu-xgU#/XóSnj[ؼ*4cjTϷmYNee@>2=<e6J'%D9m7X**$m(a՟!̓$0'7y|-qN8eps!+aYHx[\ArL&m"בcZlҐ67ҾMhLP{0|(ڞC0z&юJŨϨLl
+sM)
+{S1E8E1:ND y_tI !2m7aߠ?uD@mEw ֶ"@@%#`d  @VH+Qs̜9sf^mO{SU8snU)?w)5eIxОGDGmV|0jEC= 6&
+x/AHo^Asx/ }Ї}'Ap߆k^AZ}/M A^ <@{Ãۏ@ f`;<c`m2l1fq;bnK^{yܗ|(q77zcG㞧{䝮EZ0QQjWu8d[h#]R^aWS kqYFt'GS#t[P7^?,u :Rg@KLg\Wx:Y^,w\&(?]Zd*&[cq#%_~}鹶/znF`.1̾|Eqw.MX*W.oRUJ2C2f)JRdԩ9ݑ:\0a;ݛp#SuTRn!cSsg.AӸT3Y\Sd]5MC%Um-i&76tyVuzfN8)F*h}򱎩~2t5KϧJͷ4/=(efkR55ܸ۩d@͛sc ?{{u '1ndsOߜP_W*'_/,4o.4tVOJi(Yh&$ f߾&5@D-+x\XHB2s}F(pa>=sis?9li n17 7яp$7ICho GBDtPo=½%E3PV$eP v#axg>a$d8?ρmc܇ ^-h}sA~kH? @M1G3l$3SFEKJٖߴ NѢ04DEhA= <(}#Lvu9.k
+LfsHfrӬdzh뷛">!vN[.kךh]]1{<8)2Y&OSK}=++Q]hZgힴuetӣrGo$SOҕ=u=0;)հTֳ&git^tޯQ=.yrs{cw 5(>Yn$ S2 3 PR > UۻCq((I }HS̤mg^Wan}3Yl+*y(n6G؇{k:,|ey"k.414`6ϻF
+H2pŃ|>
+F =`jPA^ ݘ'$f%ybQo9 wGY?Џ F]H;8pj
+sjޛ<bi*t (g|SU n1Qc EmzBB~;7hI*5)zW0k0l-єvVk.ک{,]
+cd]bSXӠznLR7ևhHMB׀c|]7Am Hm14S-cwxGfyP5CtU[\r㰓= "1';%4.ލHq^& '7[w}>tHO'!0%n#QH"'=FXό |f鶚ˍHo߱%~߸{D.O|l2o qxn5T͵P#_o <΁G4;nÿ=Ѧp0`<w&F(T6jO-;JG馥rشj1|Qr'ȚVCuiv:}j"
+n %Jօig0ҀT1F8@ʣ(aIS,?47\Btq$`]#C5OQn=D\y7Ҷo/!eo
+$Y.NWͯK*up4|EdZṊ:SJPq9~`+~HO纭N^]z23ob`>&#9]fi>`TxdY=$opT4
+Ƕ8
+oc5ku=_/|=gguJz( <H/52/+k]kbBn5KnH24\N<fbp̔5N$i6 c]Ő5/&{[ ~;>cC;?D])L.>Tbп8@6|ܴC+L;@`a]w]xϊ|_fF 72&te9!6QX9KMy.GA5Dh[NH$-XFN΄Ʌ)pN ~R=A]+P^q.Jt+s`=z~aj~aZ14˺qSz
+$,0S</f}ߞ\
+j뎊_Ϯ?]/rݦc>{pg72Y4tL K'ÄoPж(hh>
+ lOyZ0a7B}rP Cq#uڍ؆̆<jQƤjxӕP~#hu(P`h>tv{@
+M$k
+KҎ*2'ॽybjHzّRj6v'Jxb{4RxÅΫ<O篫{ Xeƥ!ى[3kWUtt^0n6i˽EPQ8\/[e*MPy |mL>ffً}|Uji\ynW8f[ٶ7/ƪӇsQ
+WrWo}}mT}e1YVnl]j֭?2&hRK`.drWy<w^.{dJ`g^7e
+ P_:aJi!Jؚ֖,z$%h/
+D9%c6iؽԓys;79kB;
+ V< <vi`s}<K86PrtKCy
+RA귑2ٯ fx7?@{2'^[Ep7.
+OEP[AQDB}3 DI !Fn$
+Ogw߾e۷Vx}t>cM3EX/#Vp$|7(XjKy覉yL.iehXMh^2zgV##Zdn|h '7,IL,ZF 1r+.^ŌІ;)򝂣L'$%ԢG;5nBLC D/GƮys[Թm~y{f_+"75,kU;r.VB2؉ %g}{
+^PuT<[yT5 Zc> p\\(k/rnY
+!X0<{U(\ xI &K Åsos7kWˍa=pGpq7
+-KuҜY:#$g!T'_zn澬2_|4|r˜MReEŔr,7jz&|9Uɚ{$g)>e̩)mι|a \nWT!X%[Yd6PT?i3\ÝkWE]+RԌj,bY:ݓjc&`5?\83]l_/ZV[Jx_{dZyVnCn>-h-WhUTSizڏ jjǁ<([3]{ahh16z3 ḿOҩȀs 7|4ܙd2x@~u,(K< o'3}\@);زmՃӔ=;23(ٚ,f]6m$.](_{3=vhS^}Hն >V[#5햩<3dĴ|m޴is߉hmmH{0kDŽMڧk@I;2.3~'g]mlN]Z>d{PkrW^q$\~ӑ&t%JTM%<Ƹ݈Uj$z$ĆY[5~ݫ]ȻKKA
+>]{5ϸnYȄIUe( FBbP:,&hLqCÇ60n4V{ڋ>jeXGk=&{#DۦR_4JVuBTW^L0mrbF^Z*WMTh6eiސX8WK6YklMc9*h06K6]o!H[N 6k>+ "&+~i0d+Xڿ`
+
+9M7oyQ#/>?hd9?3ǾJ^OT{EMc7#hwuO
+rx-"<}#W$HBHB`Nr'PZwg}vCۧ;/3y'd2 ?y}Py®}q1 @w8x'n܎ wGXxp 쫯28 b2w}}c] )>h}pIPrCz ux7s/Ƌ<!Sp~luol Cz OD5fKf#R@1xњ/*OutRM1Q<|]QUz酵g~m`cj2E)}XfZ eM?W{EUl
+52O]2]d򑉳0K/Lҳ -G˗0u*GͰieD#ks)-V]H8R:"0čo-fpmmOe.}9AD@ΏIK?wJ'
+ע);fnV+j=;Z_2 ry(YR 6spyJ|:z"$ 꼄i
+u"4wEdU7Ujt21B3RU-h~Zi8&Ή)*\‰Bq7m$)"X+g\ϝ295{q*{*`pxy_>l<o4P.͘obS&(h!29fα3.s.Ci'G}zGe5v.c@̂LulcͰn=y`Mqwv>Kۡk֍+1ۏy7 >; q`LJ'v-kf^h8cg^0Sۯsz^PtЊ~H2|L|ؙuhKթlNvnQE o[%S*X`jcc4_ؒ,o}&k+ݜ[c/nv9^Xf֖tܿj  6Qg0| d4SImzn3~0wYfl,<<`-ZfikuQ;lذY3z7S̝C.Pt\%W))Wko4rJzyfO4K s92ccL_(b,P /yJꙟ5ԦT}IKata bm18Q($7^V:rr=G2rT:ۘQ% 7)(Bp
+P<>L"|3{qhwb;}1pHw.j#v p:`<}򎎂QwFx nÉ9 ;8<ȩ 6egݸ\bO@gTgF2a92ƺ_=
+-t6jCxAwBϯ[u,u}+|p CYnF)PcMR.`__KO||d\<Mi7Du^+|*'CTYCs|.vqH/G9(N$\ i(?C/y{p}iԉh?gג! @6جcAswB
+׹Xn9 OGo؂`_`.
+q W+m@fmgs{9ֹ"$!р{/n>=Kx]Goًⅳs[??2R~q*-Ҵ6x\c0Ou7k)SikWƀ
+*qeʇMLYЧigZdSFXΘFLP)ӓ'ɴe f
++ODս0Uܨ7HjVRrÕ $Y
+QQ8ѩ$M[RV`BQ9{&{8BMMpu4u=P'j=Y]r}lSL$kUxA9~Թ="*|^ѶHHikeB5ed5ASXj|W1G=ж;Eʆq6\`f<uHq\j=|dRuw4֊%q\ӓ9ӗ||daw6IR gDrEG
+䡜Iw^ȝ:%HR]Nv5qq
+i^4v q^<04- \Uix\ _-{
+oz.vݦ|꟏zD++Gu]W:F5U7tx{
+ݓG~#5
+M qvGXhb=SLC>,\?Oq^}ݓ:h6f]1hlY.xڤn7ƪʥuU"Iô1<]g=/zS_z.{{n lYlXd9k1T?'\cKmZ~j>WVĔfkC'JMl>CK^zR@HW~AJ#s3c})f`-QSAQ||ɿ9/i˟M+ʩEDy{_Oץ]yʖ\e
+)?i֫p~,}Z|{DmMrkNPWi6
+tULΔ{R:zFG!eZGnyXz79b
+endstream endobj 41 0 obj <</Length 40590/Filter[/FlateDecode]>>stream
+HlVWYi]E 0(-@#ࠠnQŽ
+"B/VI*Ie#h8O*U%3~{ޭ_&
+<gyhɯY?қXiC+
+{r]VZ(jVW3LmL3U5ef+m26eE^jផg19;vNvM4̅'$ߥVn/:UfL^]~Jh6P`Z$/>H~Nޮ#c%OiPP]cbj%c ,O JJ5h.l7ZDϕrW^9k!M}"S`!rh?Ev|1'bI{Ȋ="l桷D^j>1ٽ9>+Exwܬ'JU<q
+\/՝FM纥Y Fl|ı`z!_jf^ ~-kW\YOtzja@P5ϾPXc
+~D{flGB|"C% ra%=B_ϋ]hJR5]Rt0n6_Ö9Yj=E9mDVOiB rpLs9+ufu7ծCPAĔר
+5ruQ-馈hG's?E7J[
+U~3z&yr̘,35s9R,/~ܵ)NpXgssC*? ڟCG7鲜{Re"4-g1Ú")~4xA~_ _34+&:;DVqQU#+t2 \
+S`St7Վ3N%FR!eo,+~&bSy N fdYUvYm~]%P{3ҭEg0/k}-L[T9[U+jMt볂秄 ^KˍRĹa#7Ds((pPq目MgJ
+%Ny׎eq\FShVn'L,ܓnz0 @2n_lB.0yaf+t`=dDrdUW#́l\Qd-W%E?"(ɇ$ Yk^"ru޷Й8~#<}*6ǖB4V/d@{:)=In$94ųI۫&$[6혦iyAc0-+e3nPWE@aQkTQ O"-ˍ j"Oq$
+g,_D}%GqW1S>?P+Z{ :uRP-Sʴ4([^{0(5$+ |ђO>~8+}jOc;Щ \[nqFcCÊ֦;3N íeQsiL]4/^0x38;֧)%-?δu6լ9$<dg{Z1Yvn/
+6N5CQD]EܢK۫('y:@#vXR@
+x(:vA}T-fXk,QBǀhNЧnȥu2o?(P Q z[ay=l zhM2}q|7ΣRe]McnDY#ʜfGhVqmA,j$^}該h~L py~!Faa@gn +7\qGW?[Tα ȑFpR9ZN-[ː'~=F{$H{f<Sth3l~.JY/jJ$o2½O_>k*sKgߐm0؉haɔw;"#}aK_[kV.T>P>=%~ViE}+#Mh4<W3ɸIY>3l0VZBS: j"
+7⬶g7
+Q(+Kkd/$Ò\N@vUd^{Qe;$k |_M$o08|n't@`;$2#]B=G;p?burcfK#xkO'n+_]KCɘpKkeGd`?>8w+,c&(ss\0[1ifyQC֯J3?k347 $)pMH~ }9McfEozX_^9p4O /YMվ.4,kkˆڬfDlqLL)[_N=v%,<
+@gYfȓ>G^g
+W9Z_rMȘ.~a>̑ېѳ0P0{Fr7Ot|4D3Ύy;[FF]鹹QUVDZ==6HײlKLuLMeZ`de
+p6AAwQH%n<vBJU ٕ詼Z$ j0-g/b]UDY)*N(z
+-
+:3oAo'올ĽO_\OU'򓾄 WVeM|g,:@GxY9ћ7=H|
+#"*}|iPY
+֛DsE e%/S,͟ 4gt`,V^X,</x&Z[3%헓{Q'+3v޿>)fda$_jܰL𾡀wJ.Ė<e뤝9N.υ:O/lۀLt~RG4s{rcl9 :y$v/dx#1
+TjR=Qj/t +WCE ?u1GWzYפo`T5W7KTVu4O30u'%&b\|kvx,=$
+st_>T<ܜѰYHȕu&~#g(uiZnLȪOz;#5X]RΞǪ~v9ȥxn0 KnD{A֡
+y(r Iqatt4i?2_%2 cq @7a3^} p_
+)䋅#@3%ENJE`|j`1@F%^P>V^;UU+k+K=ꎅod?D5!k9a8 ܷ: `#0*>pؖ/g7^"=Dx:4;G_8wh=?qaz9:\. H遌EGHo‚G FǠ 8hlԠ]/v%
+KXl/\lЦI; k*_2*$s:uCI8e>ԹeW9r'0#Ripeo?f&K>^JbfJet]?i˙es5]xNdbmbIbH4&M&[NSeSr2K١/_a~#γMyH;`f8Qsn\S ([CMݧC|BfV N]KBU#uT⢸ٜ7UL|A̔/$}#qc'-';GNS6byEby讳&4
+!xGΙ93SܛB8߹Uս:?)rMi v]Va]~,/~b:kB8rs㙹J2b iҸJSN|UUyU"EYX,6~Tdˮ5z3wl,9(,F
+Gώg1">ɋ[`g$iY܈}n#OB Ð $"Q4Cn5?t9[Z"}m}%GmڈnQ*ToT?ݷ1[muRt+g~ m O6p"js~tkSsڗ;`{..e'[5v~n}G?MnO-7f=ui6*wK iV|; U>O*#Ӻ=ǡ8 5i* nP7 KqE5Blu8Ɯ6UD^Irʲ~#.ט
+56G9k.㮁q
+ 7HJN$7Kv!W@ ` `N;v> ,Ux,"n_
+]yO<{)/BӔv) ]N։o
+ 86r/vtwqxo@ C95<ߪЀpOs=߃~?DŽj޳A9|7EF9A-I F`o+x"HܩkyNR삺aI[&S֔<ֺ lxlw7vߢ53wi-!f*P\y\Q,i.} Y^KJ8GHŧMG.ch2ryrOxkh2wf4 YH[f.YV5{3ko$h}i[XwSU#SFԼىƩ;Fk_' WMdjź>k렮ҭsAR=ky!]gleٌ1L\Hb-Qpٯ^nHkt a0M.[{7xD{͇mja%vۛpefiJ/+X>SsLݧ;?Cg*7%?}.x4[jPU+LV\pKU%-FO>"mb-[*atđ,z*1գ, K顺H|aPqie24l.UQVEAwq'614h1W/97{ppD,o(V\{0[683oL4D<H*zkd9YG lp6em7V-lIbI=}Ge(/ x|{ZIP'` Zi[#{{2 9eˡy,`c!>h =y.=5ߏ ;df,Y><7:VyNøO00͈qNNHە2P&\$U0ټtp=F°h0Cf Hm::e3NHttnX6GaUĄuTX"tX¥]bDe{6F<Kd@:u{?ir֡M|!ǺI*4qa9,(7H#6=ɳatRϓVƍSF}4Us񋈩SJrD}'ZXgW` Dr?!h
+LhՐmc;xe!i!]OM% 遀 +1* U *
+\rB !! 9 B$NGjkkکG!0÷_~%]?n`R?r+
+0>9$.K"a<}0釀"0=L8`H́"0^.r `vf ^E<~o
+_g<`' ${<;3(A]/z۞NԊ2<I3
++6}vnXNȲZ 7Y 0l iyms\v'߼ll6ixfWVќ"ZXqp-VbB
+zjT2d5+L1f(6kMʳҤ#nƯ!Zc8l&;]ʹ-k:uݽַIqVf4I"Mlr[]RZ;`z{at,4њVz]V3H{?A7"(WG h Lb c- 4]:ؗ3@GbKǍ3s>
+bg+=t%f}x%>Lƭmu}s8 7G~ mPq/9 =`1c>n?
+~`"@U9<#A; (XX}jB|cؗp#j 3i~;D#^AF>w^z
+Q^1A RrM4T<
+ x;&wnz 9,pCB%i\{t;
+s˴LE5גּVt;[y8/SO|hMf
+ia[bf9xND@747O<13QM'6jP"ؒsnP,Jnԥ(dXNa I֩!󸞶gji{0G.G>c*ӂ{Y$p\=[8SB=g&bԺP=L24m2U㡾\jOS=|d}Jw4.IƚwLY9\g3OiF38J}Ip[L1? uGi⇋&_ҟS93k56^fvRlt]F\?X<'[Ο
+=rܟk
+Zr(Ҙܳ%/3A 30ā>D??s@'B{<~\hjk]BF>&Zq+VTpdV\:Mv4nLP/[VjV!rwʵdUl\8lnUYAVTքV?ǩP,qa62[aY~ynNЍu\tUǯK#qN5}'S6Yi;bAVޓx$ eߚ8"rRZu"mծVE$!xp@p IH@@ #>Owg#5Q#&_@#HIĺMZ.=) &GIGɠ,I }q?(V@L-SH mG24"X1' T$#=
+LG h>|Ow}tPҰw>)V|wĹ\0^M%]y=F8CmB}kͷt mSLI42r#66}Եݤ cϚVF:].+0n߅΃q1
+ݰMϠmH0)RU@nvӡM&pZYB ƘPXd6\[ߞ[ 9!؝g_##r5hv5R4 12)8]uygD5Xcȼ2<T9ܤsH<DۙA4'*)f ~'jWf5nQFΪyN-c#Zj\ۼr5(jX1K-6.L+L.9J/ΦbƖ Yݲl 퓞QeVa"j)>XNYeoL0t}oҳ4x׃9{E9yɓ5=gI^>UNnmyi=,H! mlYO{zPMHo'w<Ɋ#OO/Ϩup.<\alX҂'~
+f$Kz<
+sBscNmTJe՝=1"pO :9 lTD (}ۢi3n'߳tt##^ʑ?x 7 !<FIJ g&Y10]CnEi}R^FYxay]uʼYAP)}XJ"3X;K`Iay8lq74T Sg
+ɺ`ow>Qʹp=g΂D7lefښ%Yϫ;U?M,om|l4֘8<|#A|4<--]~0
+F^q,Ot8R_eniT98.UzM2#dS#he^f-
+e
+*JGnf94
+Ib;5 zOI/s)X8\5{AS87Xa>oޘi^K/b}O:δ4\(e
+'ԷgO]1'2+ O7ʹ/fJWV'V?'KHW4;}]OMy@bA`
+ֻ#X:-SuQ, rU!H IB'!i8lwfg~#y=}1b9>숋ڰxkj}5W3]ߛaxsVP_ܒ
+?sM ie~Ӓ؁gB ]"OoS̶ L>:{ -˥7ǁm^5x Gﴃ7BHn2Ҷc9i`WF-A, #wsby(}5l4ړsSfͧߟ@ڑCZ51]s,d4nptLQC8y?4bIjwI2̗׿Ɍ}&>0y1d3ʱzހuʂܱlyPplJn:g yܓd6*Tc ='`BvLȃ(>۸'ZE&rI$cqXͭo ߭6nPeʭW@ȓvMPnް,VD1mܳd)9a h 5Y'ql?YFKZN\71W6…_-غzַQ:-;ɾ?FqOXnqId1u\˛ {eGmr<6`U]5oOtUxɅdcw v'\j写◭%1u;x0:+1{IZh<sݣ܅:1dS #,Fy.si;p_6rtjɢKiρϢqgКN#Hk'M95փ:Sa,O `p ' ]-܃оH$FJ'F" IZk78YĠ`3ڂt`<̓;#H#>ɵa"qb#$CS>`z4nff/K$~HAmjoba
+03SiTgĐDcdмxsAR5R(d; ssNlzyu&7#eB(lDIg`^w\
+M蝜lGT^5!0w8s;:.lMK[Zc=ǖ3JGVsqXmCho*5o<\>'(\<,4djٛͦg+3{L+viF=?o , Y󳃥 59pDv?_xgr6f5BJI=ipA/&tNc:Gy^JX.Z:+zն혍:jm}TO)* 欙FmGcס2Umzo kcm7=kLrMᔦz&м.&׸>`3{k~k3j27zPmy GՏ3)XlE|ힵ]|ٵ଍9#7u
+``+PucKseo.6α++&ON^.;.y NU>lmZ0#kB[9(0AN,cv&]D?%7& Qi'IB9i(''GXz}צl^>}9kͰO
+|w3}\SLFiXaV]>2\G[ѡ@mC;rL+ЗOy "뺛#lv[[~v[x'Ԍu&oM[7 p
+^yLIO\%~bZgGLfpޢ4xFdI6PS\Z/>dmmA,0{qk;5V!oJωlO\ȋ8h$
+ҊȹR|f֮Aصb[V%Wn\n^GƅaU .s^<qNLFE 쿠ZVmR1a1[_? :9?cze8a-\E뚍wP-dJiP%od+幗 bpXb i; ꇫT~f<ueޮ֏
+]JN`YX6`@8S$t}?0g==yЂ.'aUh}6]EeA/ɤ,yrIіs>G&%4!
+j4Q#x`|G@n
+$w
+wW}1nӰRgjjvA렧udqZ\,vl̲PyFW隖/JBUuBs󛫦?~팤nʹx,f7X]~SdJuqTQmSl <Wv-r ഍m4xFO[%.ʯsk슙 ޡg k{+Rv)2.Ffg=<y:rA.
+}طs:f֪ǘJ#&yW6t^)I*9|9v/8wA;Aaۆ@;G7V
+ @+ZBgeFfU+@Q083A:U/ژccJ<c9Kξ\_TS5qU q%!AU?K2Oy{&iMM䈣ne'g2Q%WC6oLj{= p6¾L-kL 3]"ma2٫nu«]8l[(x[*kj=Lo=w| q+[`{FtG1- Tc䚦b+Eyk`2(o;7- ?Y%{ =+;^F^CZ "g#IH 8?#=
+Bԛy^v곊J dt9e{>v[g>1斑,UFx1+>73&\ﴊd V˺\4jD ?uę
+ED@@BBHI X]w[} tx>d}}L*a<hv M6%xdcPZÍ[pʶԳӌ~oyVz9m>۪{6Tf+ -f6ʆ5amVrW "|5&tMi `6Q۝$.ѩ%&Cv霢es _gl}Q91i^uL.B\wԺe皖fdsT\wK3eޒE <&^SګSc܆r2gsZ@?iWOy]{Z^]{L| Z/zS\HtH-k+<fs ;wa€-ve}7;9j;gs￙YZiM ։iO6.Vٮ/ٳ)t=%{Y̴ꯙYQ+( (nӮcc?G7c5qѻO33ycnQy|Q#kpTC߱ޑoݼ9i#yi|G'N^J:zK&
+oQ,#hDz~R/>fT ~2+P!ߥxS.b`=4Q&(͓x
+年`}ʇt+RL7A҃r-*t{O_m/N$c-%7>4ڹF|:a:vުefi} vo,|b+[XsK,iweZZxZiYZgr5mL¬9zy罟T^yt/nC u׼bӡSb޺4W.~seez]dYJ;|Iwja
+LD\<=R;#s 8nwMRـ{N;(@u']г&*sem,sިl:c uc\'M1ևwv}a\ $C5|voɷU4ߍ޳Z]Xf(ce;GRg)Zgt̿Oہ% 7/$eA<#\."]B/QDC$h 7(ÁrH ݲIoA&8L
+-LVQA3(*0bѴǥ__fG.y<u޾i#
+LWǬϊ-UonƋu6.{m[LjrPA@ z!V\d:i^gX㋣.qux'*\}:K}t_xHUpʳ}zPD(ۅ6 Ϸ7cO+M'jr.XC+ p#X
+koVWB:b%d[6+ۖp_9aL3Xiŕ]j儵+<I~7ĥ|sSsz2҆|=X9)OSF//e,\ieOO=2TsSJ9n2ŎK[\[d χm-1dn;6@pMxKO'ίyR:~vn󀻟{|ZO>!4hVad*A7ѩD\m,kU <&KbRk0L*|v֌ xLԝQQa8W w57il^5XGyh f_ Lِ ]zЫF@;Ҏ?6;t[@6ƞL.i0V߈g-vnN\a͋OaC-Ψ i%*p-v&R'wIoc$AO8113`*t=,8B>(ڠ vא= A:RG_?`hel,gpDŏ
+vjWv'V7κzU?\O;'y9 )ܜNYS``1X{M+gߊ6.~6Z_ڝ#}`p%-rx$=6<O
+D;&a9r֥%Bzp3L[ "`?s n)h k)\҉v#<j@4"9W:pi`moܰzUrt DAzp^x|#k-8c҃о uDzg~34!4m #̓ MXn wp`2W}N^k~>Oow7᾽?o
+ې42_J2f<¬ 2?:Q<# &)RJ:F9DƸadLCA>,cĵ
+|*J5s*9RPМ3\稯gej
+!H>Yf7l|򭩵9+ E1kuV O:*ω4ђ#,TNAN1+yYy}yMr̅ߥYDչ)Qsi1JzO99f$WI//[)cg'/A1x|kjW<Hqa2$#[ҘImM\&oIHkзyVLz1l𵝟|).ׯٖ%nnY'ѻ̽Ѓ>m֭s΀6
+9Cν$B(m~#w\Zͱ㴨23Oo!6h?)3xX cU Hy /ԈQ((Dsa``z9z>.ew+Uݗ[n}nh(ŷ~~7 ϧ˷OD^>}bS#ಷЄ1rDg oZK̥7 "iC3 ͦmr#W]Un]7c<2 8&Or,ͮs[]4]nO#c'͝7nJ:__ -WgQTi37 M̅>F?5uȁ M;|-ęZD+͋"qǂP(Ҵ= ˘ցGy iI{.(K[!HݭdQ|>Hž
+w{|σ Y9dN| I,{+"d¥a0V+LŽwz
+ђKMܲOK=| K!S'I瀉0t-4- 54"9TFd.+#s;%,z9Ix`>h?ߧ+1Ow#~qw !n@R"g2p a6R&/[m [%-F VFa2wSbm rthGjCSX/"$+cceNV*5{ ]~EXeg\/#4dyu|}k(,<ł#W b ;ig4ZC`&J_*^EѼ`7Fuh*͖d cQnUVMJ/&Q [E\4+QYX
+5RbR O|稇9մŪV!jSt" #,}{ 258_
+85U~OkC.=!p70HZx`x`V
+`X^F;5j\.}e[jv'9npІG׮e"!*t<wkt5ƪt^@5?ƾs+S){/ݘ͕~{|>c+sZ|#|zfŶק2]wQ0_Ejr7b$Rp=[7-bފύG[uQDu(iFrJY{x6Cb<g)Jz50į+r-MZZ-g{)!r|Ln&R|f=D}oKR)Ƭ_f-Ljnz4^uŸ}G_KG
+&F0WYv>)C81;?7z络
++3S]Wxu͢0xNǴν0[
+u`]I6}qΜh2G{g 4#C7"]e"5rXCio|Uyπ}ГS;kH1p H X?K;H]AR ?e$QN8N
+lsW"A҄kx03 Eu044fٔ}>z?4 B%|F0`
+ȹ)&)VD ᩔ;$ƞ/΁ )S|I٦[{J32hI[>b=dV%\U[?y <Onʱ3XfM̛X%x؟TKc ;xd'ILr:}3 s!ƪθ|5^΄x]&\^Șt<ɍU[S`xBFq?n 􍩃X<`q1An]0<H40u~7$?obܦ99;.݆lbhhZ? %Tl݉,ML|c9tHMxĀ$X&359H~O)U= }
+WY]n 랓'mP?f s# 3s
+/:WPoC*7zZ-x+nEtGT/O*K G#*>Q 24ҡa ʈĝoFœsʞª_OTfRzg\UQz
+1~qR)YW>
+yER{)(>LR+ΎAv,}$׃#p^)X<NJdK:XyIەddFs,8hgAp؅5&U$IVL1!G/U_lM%i> ^*ѫu$="*7(pVb+ذ闇~oPV/.:5X\y&.&sG|vq귯xfYBe00Z>Ssh0;* .Y5Qj)Ĵ桨*CնѐDk7jk;` 1-L |і="gԃXS$Bx6Ā_yxmZ冇'NH87xq</Qtaxx 0FEQ@Cn
+tIHB C-ʺOUI4WU]_,}V8Gv`<Lg v>0!Y9F5>1U4W1A<7ֹ&ݮ0#ytȥ-Wpߟ?pQTPq5jjfXGcHGX}y-XOkf8.GmF'COD!H2طs8!Cr$"G/:G˛<TBsooz}-u?|0nmxd&Rr r08dGD;_o[D}q‚
+ Il%KdA8.:`:|8~8<궵f\mKs_
+TMEq꿗˞k_j^UgTG(x+*62i*E-0,
+!S,< ,@{Ĩp%hnϺ
+w[I)zKCLU
+ALq]s6S -QOE Y8D3֦ ZG]{ӟ o>O2) 'W
+Z;\dumvK~P7)ogb)]LjAcZ(f'sr Vy֎1/lqW󹔩d:m#5Wrcd.fo6-LaS W˥ϗXYeIRsyRDޣ"SRhQAiTI^x[R *>C&iwy{Y@cZ>g Gtϗk(p-| <B;aũ{FwcZeH>>lvs7-G'bRhUn$l˖yHZ3UI0>im^&GCIy' }$^;p2!$B3N,$x.eNwjla̜[qв`c&ɋ&`/e1MPb8C'|E̺ܓgeu mL4'ĵ I\M (}.y.~]kEvIuVvƩyQ.B 8Z}.NIZdˆ\\v8rՃM&lG¡,j"
+6x$%U"iG)^uU7:rBpzc)ٸnY:4SQviO/
+Psain3sNT"#cR1' FժeGi ЇF/1HTf/Oup(4gdhR$W|PtW߼|p?B+,s Y;/5kj,Mg_yKRbdfOf]wOĢw뻊^xtt+B;y C"oo$!`?O>> dFs
+Bz3zlC_8t 5?)[QOؐ,y3X2.?$Rr<k=p_4,aV w*EiczALpM_Vy0^cM&ijx3LLD*bƒ }mg;>CVO~N`+͐H_r( (S@$h; 9@31A/bL
+!,ӨRYT$B㭰QRT:iQ#3#&A&1M9Y، R1E-6 _L_pusϧ[;N+؆[r\ᙎ= 9?zdǙs}ƇYڦD5gW55y5e<~F
+9&E`<g6:S3,Ju= aO>67dkqt-=54|eF\;%zy_r\Z:Ws9ý";UJͺ6:<s-)@Ʈ|OG?r%H"gn1 9>Hq-H
+)>.RI$owd)y^Doᦋ] ~d%R֖ZdB~÷qP5`c,Ry[p: 72*`fjxRǼcJM8~R Gw,a %B0`[QOa/p
+rг
+BA #bCb*3r+]Dʃ1Z^%%. XqO8&O=?-<={ e!z@1VLdL<?sd߾Bagf`c~P' Y_?
+9[ڶ>859vc}L8ys3=QX9 O؍]Y۬̚Ǘo
+'`;dLZ`4Yqֈ͏V _?q/ݾ<
+j(ڸԎ=&K[Ph%+j 5f]4yΔ=fAo9&\c* Sc
+(bAf3"}Q q*ہI:ԛQљ[2/*Ps%Fz#sBI(>2+ö{Ϛeg.K0w-s!Dv?)S䊉}6pjAn!@X ֳ;5GOCeN~*VE+4~mߥlT?½>&QCK.bw.v<[rv=I=uo~*˂/́lB٤Y4m/
+endstream endobj 42 0 obj <</Length 42445/Filter[/FlateDecode]>>stream
+HlWSY/
+
+*j v8N( Ҏ
+8qYvWlf'd{Y^^='.陞Ӟm~c潘Tݪ{^^2WO
+f,L }Y*CihRƦ/^V.ij{3|8 j|3>iIg0|T㓚^3&drW dM:BV`7:6EwoT klw
+-KJCҋ)Rs|:\n
+HirX |3%4azb -9֧,d%#7giYKt--+lvnτl\)B[sq?l۰`}@(@c%@kL.h=`?:jàؑlVV}0BRouY\fwWbk1'72"хXLnHW˺ıӐj0?.JEţw(ʣ?-0ݗеOT~ש[\'\s_ 韺 .jG[k-Ϝ7^(),hPV4ޓik%4n!/U
+|B<M˩yդ
+aXLv$?BBЎB% Y:sbh 7X7LΏ1XFe
+"*6=ËR'%x0G'h=KS`;_['mȰxio|A]AM$ G]UWzzꪬ"h
+ז5FA;I%[/:8qh'iٞA'® 0!s ږJעWB1SMOD5J)T <G
+jMIOR ~7(pܠEVL`9
+
+F!O*vӺ%)b2f9+ЃغU
+A ZzX>ێ;vlNwr'iJm sඃi׾ۖN)f;=]ݙH+;'vfJh:YN]; h?ugwgp} Πsys<y@"'m$ ^SΧo}Wڮ1Nۯ2'X|u58ZoD^rdbNh.h=Wy0w~z&?aNuƍ{YDJUUˏ9jVOF냓16>P$d%R4/TSDx6<=+*UOFEZncRM)ԊZ>&ʠ’i_&-!jbQ4.[i:U*ǗL2qm{)$lnzѶSG pBGz Os{نW^|v|U忿ܣ;N}jc{vEc9QV1јcr=1Y)93dEmPrFK:㹆}mTr;"t/~oy9{=^WC&Mmw <p=
+U8G,OT3SҦ2Mk)R.KNIdָI9W-ЂUgP -"L#ЉQs2]zs|9 (4+lu7tRG5/5_ȫEjw즯D)SݒYW/(:u/F='@D0l6Jp5
+Z{mUlÂ[&7}uLV'+{zk֎qgPqvxܟGƴ$_1scͳA!?ٝ56O
+\~zDI|jEI$%[p}WOxbNvR@r ZjyIFCx^9 s~^2<prPZ
+ n6BkM둇~\{AǙ5!A_{]OM% [AE ⁎(31:xራ: r*AAgr! I[[l_lw{$P?|;ݯW>8%Fot~jvdJX)VRC)9nmf|~/ 0gjTcr\ 9<mtP>ʼt'vCbFqo;9 ͺ1tcU/V
+KYb\U[A˒;86}
+X7D-wn~t6<-X5a#VEt7]8|l.>~ov YboOHk7b8p j.I+:3m50A0m\{)"Mx{Ē]f<t1't+,y0l+c
+^ m
+yF3͐fy9>qQ2^PrEBA{FZe&W:.}|?&/n}u-T߫2nj>1Mq4brA(ӨOx/\.LVk')6gmovwv2WoƹCŜ"Eyc|+[[U5o.i:OuA ӟӓ'J'z|Ra&Bj+4!Cߊ='*\L5NL?{4W<7MKR.Bxfd ;4dǐidL7w|~ꭚh{jkҤ'UM_K3nT\[dӢG
+G3F)bH.= \ޒRیh+ڶ;y߅0ʹP3jJ [Y+}<BI 헰J-?^LX\bzp̎=!:'JaQW1UptܟimG%j+kM(Ęn#$ 4W*^_a϶b]Pwv\mz. ti›uȂtNZ dAȸ9Xq:a9[LU9pIh,K.VUoҍyUa6 M XDSv
+|}F_w`=yУ,"4'[TZok/X7u}2x^v|iܪZv$^HN;27\9Ψ~F]:ΝrU|M3I {vgȫCc8~7p^OeLq
+['vg3%W'SRMu_ȼ;]%11<X_o.Q[k4Yyssݪ})ʒDy͟oU/5M~zΩwdERiy{| <h}/ +d],TNkM9/;Pk{;xr((88e~j>c[ǍkQÏےu5)W\lH)v$F ,/{uzN${Kʈq;!ۑb"Ad@܃DI  7ߒp!˅c}@\,#V/d>$Z/22d?AT_)hи
+ O)a!EIJ5
+O/#ȌyVp
+#NUVك1A\Ps^$Aoq1Gx*rčFc0S^̒M Ya;pXL#'asgWxl^;
+⾘OHj, M܈0;T@e_czs'?κ_ʌhXǢR?^
+bb/ҚjXc@\nn^:<}-g~co.1ĥsp{!x斌 Ϣ ;&>5bOAKtLym-+u)~<hhHvFr6~
+գ)u}PsSWVώ{ FCC5Po l43~_A#͗V[Z uݾ˫({9jʾXd|b&Ji)^^S
+h7.%y؋p?nzA< H3v:2}$Ⱦ-@)_kϡ.$_?\G̥mxs`a.<WLz_:ڃg)n!LHد
+^ʃI/^+)[<R9%Q=}4ʒ<*R_w|=7qӵwvsArp~Upi{їWqa}kUI+b`Mjo208-,qM2=BӂEj$
+p5:F$`0 +%i9[TL ~q0sqFfNk8nɰئH?:Mheπo<ߤK÷:N{Ni.c` ?ȃ4u y/*v@;[d`8nZ)":ߔ'd*Li-Mc܈# ~zQh?6דt-t{FSk:^SSX!Lmд ޓ}D;giUmyXtO{aRh>7Q3ς7o8>zm,̎r-V
+d2j[|Fٜdl۞/"݊&T٢-ܝܪm׷xæ' {?T5Ů2H~Wo%=R m+Z9gy5AO]A0~(w/%ٜ %e->`~轳mî UR냵+ӌ
+Π1m?b Y>eF2,ioRfeD3N[`ר`oZYО$ΐa?Y^exl_TWXP@DEQJшuc,-JSPbT€QL@
+[a8^8>Yy5l CQ&Ony.J6a-O915IPi*n-L[#CCDA)21*x|E`s;,&RݼCs3ȄЃ3>=5aeۂƧ¾]M6<)9 2d2|_;A`SUS 2(o
+ς9kb<mJAzx*2*%/JMWWGu;}BlV*F
+CtWn؄n^<^=Ce\^eh\#aK"oMՑ!#f<?OC#I y<+`.z^8v`z(Ȁ{(u~-mق#Hsnlx ^
+ǗۼD(UCy휈BiBf紒3 #72zYpJ1FvB6t,Hd<9?IeՄHBQqFIq1'M
+ظs *7GCz
+<&*@&^DLdFs9&#i H<3Hi>/髢?/ DǛYUYG]CG 7||R.Ԡ6d
+0pNwܵhms{Z xWwU\=71^G7 ~ܺ_|eg;Ǭp5
+%AK}]W?82s/(AGmkEXpvFmN[9\V! z'l>.p6O7u$)]yluω_}XW(vd%Z7r<8r=!tB^JzKLyT\Ƀ`3#'ؘWl ﶛ!';-NEۻOįLKB4d]F07;./F{+;+7w<+Ů}R|+R̕m@P3E뽶GF*Í-Uq.
+P eS299
+ǜAYVz,%ɡwÄn~/~SuI r,"V e`I* x2.W%Z<Sa̬PMPGAɒ[݃wڻ?I ._t "eVj'r5e;Lg\'0)TyH$1I
+ח5%5yۅ\*kZU/ \}^}C{sm+~Y
+7%>(zmџAڄڂ:*Sі7_R1<&*y\kIhocD`MDmq8D!ovL{Ք9/9;I-2#:6l|OOX,1^ wu#za{ץc[{7z/Mǎ}#ޫq?uN
+,3lƙl98gv}t,c9. r~}D_,>LZh{Ft<p\[Vԇ*+^K:
+VcX.rV>ZmaXpaA&d-ŤhbFjE)bA蚨f-^c\͘sىW ,^cw&{ ~֏c~GQQߡכXyLs`@. !._ھFcȾ %]}z>Pgz_^1ηNV^mW^lz2^%nt<P`\)Or\T &MJ.~ʬN[}!L`$"jYO*2)ƠFN1gIf0)9S&aNfr42"YjޮboeR/OhՙlIƜ@P-a kPª0EuVτLQ}IT:+A0p1pVOjF%050&s
+8'qRSOm ],+/lU* Twn[mma[/* -Q RlBE $!{&@
+' CМ$ Q~L,i1ܹGe}Mθu
+G:9ʼn^VyEsa-g*1^[gpwe{3
+?.>>!G}4踑y4g7A~ƾִ˧XL췇ò(e"oe\7>݁킆ٿcr]ow*Jink^ȇ{I 9z>[0Pmߤ\tRjc9
+,z)AAPH8:%엛r_3)֕A>I9GޕMXz|74) 2!&A/RM>8㾔+^\<xM{ba*WR&xIUr
+S֣x0eǫ ^OOB`_İʶ gOsvrrQ|vMel7xs}ۄM"GFhSg~>PEIJ ԩ /2LB='\6+NY< L5eFܓjk;ITZhLkFŒ|cYk7O0_6=0sGޘK-8<}ЏZ墸{
+j5jԹBVPxqRUXLeh%In]T bbuZW\.C[7'YSҗ7m4=?]!n KDoRm=LG>]kt Zݮ/##WY߰纗.؉[`O=Oj<021V&3)2L-*IM׹(X_! -1۽&R1'QIл[+?9;dhzL}!m)6{,t/l=W"7BEϑ~/&}Qq;ĞM6,)>}07?jtfx%+ g3<8}KuNjooeq)Ya3(f]ӘrB2 G-Oݡ٘AJxT}k{hѾXӨ϶fVG߁55<p%#h<uϞwve<د8my:q)Q -ygȊ;eJd8 AWІm,aѽ:/e2оu(mFډ&c\7`"eI`ebGP H}ֱ+UʳFB/ q71ISY% w7T"^ JNBB}
+i#A"Y\p`^w9>}nɵss();ʿ>}9M*2~1v_=li/ycvۭzK~kgȄ^x?%?]SwgOGwI
+z>w3sgSv|)tƬQ@Qo1Eˣ&6v^Q&/* w>cci;]<cP6)qmG>sCU[kCbrv`:!U6D?Sx r6<x'nnH}R\VVz8,wyXW7ji`G㰒4^b1aXL,y<Fx(Fx >C.I/!uMmAҊ0c\D񸻶bѸTt<Fًӣ kBϣ|D{+pX(&Ҷ΄(%ۅ>{r$QDE^Ӷ*2!tk@x=4‚m !20܂6jD+1,T~OX$ʩ͜A{D‚P.Dmy/tXĽBRe2$It#uu4!)Jv=q<cMNFuX}v-ycibwT$gi)E߿ʐ5;y!.RXjW-ELVBՊA Z5k&WJ;8pUr@ 5kf6睃ozk>XD72pIomL ߙ5Ͻ2|Ij,k6mWtZ5E2+XZйdTAT9 Z~V%*HßC69~߰jEjJRD{O`.Ϛ3<ca vO0#Þo]1f=]4}{٣̀ТnmL|s
+yJdM)qc`y`=X[r<Ͻ{KG{ uyTfI2Ή
+Dtc&}V/뻜ɯ?)r+58LXg/M )ڳi"Oc 1$֯lfY@WH] u`6̷kӄ0vɛc6!=x5GҮB ҈5QSRO@*%!UjI8pPSzJ!솏 flox0twT|F-4ed_ʦ+gM%] SZ={&5cɇD3lb+}*_YP .50b@YE|0!LUHhZmk:[Ы4F_f;87]C|p&M3"_`V:A\ΛI_g4-i<q}/@g.nyUgNҭآrkX:6n=7PQ.W|;Iw=ܹ5!vqYdP9.m>IEvN-ÖE*i;0rYɁpݬxlIŗ?_4\85v;Kh v'_0!ӊìsˏ=
+MoT:MunE)qc^{Zl_<P6O/\5*d?x8SUƺE.˭{aaV>o0a$:QEFn6&j~ל~}}s.n~s1~dz]]/YU׷Y|x)"ෝ`38҂ة(lf4yiG8~F eANXov"/" ?͝-l^hUຌ"p vLN,.~7Qƅ$k2(10|8ܫazw1 akO" R k3}`4d("PDC4¾M,x `:>}<ăP[.2b.ڻO'<Lx|/1!0?ν" HKgS@IU0zA4d^IZ?<ժ.ՍW;m|e7U3KxCf{lkʾ>a{ܴ?*>' {Gn+b{иdV|;هaٺ,4UҺZ>z8X5кsob䃋!Y`=0Ҽ\g\lKjLU +uŤf٨{X;]_Mew
+shHHIԦ%2"%otr?jګ$^B3#1R2OJW&<fxQ@HbQ\c{LQ8ή@udѺ 5MjQFi6V
+ϚY=Ć\aCTjO wO †Ϩ(h $8ޞhIwu?l
+眕O3 ޘVI L xJp@g0!pـUЛ)?+LGiNhm|$+1&:Rwwo6xoe>w=͎= LKGzm-ڣ릣[OhEW_<V\;
+WL8h|¹{w<G3>f]Q ރNQKy]w0( ,mVG-W&([[-+V +bKp\I֔^d1H:_nT-WaKAG%C?X!7Ħ'/Ŵ?`Yܳ
+(\
+9SbPBJBzTӡNѧ3Vx"vwug~<rt'w/2$\Vu~yJY<p964
+toS6ڇC_E8[kg{]Kо߆~viѕO =}c~On.D_['5?NI761x~KEhh&,Dزxрyu*,m%gЏ}Έa+Mf|"uj<!25{Nk\L\hނY -mݰ+r
+-֤fցYIM8^Q95NNMX%eG@ZpioN8qS,XD-%E:,>OtatxxA1> nFݬȄk09M 23;q5JIZ- K6ߘaIS.qn=Rk# }ih`IcWRm^vY >:=V^.X;|Fg3
+2*3Rs#NO2 Lh,tc(6X{l ԗJ}fN0(otչ;Rה+#^tZKף@馨uKzϑŅ1iڢz{9wܙu/NBAFC>=T}Stm…Hﭚ̺i;z{_07檢nc@r(^>toh12 ڄqϮaUR6~wVH"kD!_eǦHڎb) QUGI zUfɴ`p7KH^I9wT"y0Zg2LRaӴnKDNOR^FKaDJ]|sw>{:B$ZNBl[SWV`MX\N:JQq.,mH$İ$!; $dO :82˜7"9.9s`zPvnm)lXm.5QZW] xf'ݼ_cY֕Y´l|/Z^!-ޠY~ZL·1e?xOuwFfv=)~G*4_
+ CE:Y&a a򾲋lݾΙUwu K{5U aϝps(y-vFua|Ƭ(PQ7y8^1ecKnzM\$oWxC\ ژ{&9&߈pDm_?YZ5F=:ngɃK' rQǵʨEL+vAwbKwتlzk;=b'Rb1q[u?ݘ(WSMB5#3G_9>ZwQ[j!-c?mG#uRm=_^ҶG08hl9URbBIFq&>Ã=[Ю:fńLL6mC}F]q>:L "YF(5`+&}8G+q,7B 9~ˢc 3qMCowb{`[P'Rۗ Qan8$G>^KJ3< W|̶}sډTو=$TG?$+RzP@QSy2/bQIA<n.KB][ѫk[Q]~4: u|Ok䫇D7Խ_hEX5qzol%Tr lN!j JҸˋ:>/(ߙF kFb$2bԊV+ERӃ9e <Z(HRvQ49
+(r,[}Fe.3>HO$gMKHh\BbA`9Gi 3dx9I#|\{p|
+ՇtW3?tߥgM+hҾeo!~=>~
+KnG[\50) ܣnP51[*cIc{QA^:~0 )LD_#绀^{%a3o;&a}qIڨ^ yUvU #Yw+~=9Gjߊ^3E#9V-Ed 5|X5lHX'%JaWLr85Ҏ'{m||.6teY^TOWNMF +؁N@~@ҐyD}Sb.lo3vdc}qhvh쮘ņC( w/GJA(5.f}ߠ Z֣C[r+pxP>==tBIOaP aW&F1󓨖 `V 8-FB؂!ml\`a`{pn|xJ-?5<<%l#_ X$5Sx8eaОA ;dF:mnH
+mNƧ$[siFӒlɒu_> Cj+?blO~G3֘T>խwzOKO
+qO!b[ؗ Wծܵ-5ɦ7L>>v5VG:^ zE{yoj7-95Լ`}MP_yN2LbP ~3R̢׾tu.v5ڡ1Ҽ8,K^s!eڤHS,_Y |3 E5 qey2v&܇N?mR.'Q>0㼕!ϒY
+iGeEgDUBGwfh0 E}SCc̜NF `ؐiEgpL}tP1{a,{rrl!볰F6W7$cHٌ$K3#Nb!cv;HѰ=H"Ms)#sӌm \hЄ;mǟ%-nX媻|aoFl|n0,g\W} xJ yWyNK !}޶h,&%?wfnSĔM2mh7sU`꒼j$#7_-KV?U)61< U'9MòyuJJ(Q)86Ǵ޳~{.v
+c.X&KW[w_Ĭf}&>4y #D#vXIǻxK-ؐw[I>x_)x͂D?fl*ĕb;ь{K
+0s6.k& 7H6M'l\'bd#&|L('|$HKf s@Li_293qvB.%8x.^B.<8~5̳R
+VgvX_K)U?<U܃U
+y0l 2]/G?,nUź6ߩ+llڟw
+-0M _h+ҍ9s6V+CZwylo
+b{!87 鬒k|`/>Pߡkח}oDւ':B^@ *E|Rb.ѣb)J](ۘab <Xm$ʐQݛlB#A^-dA!ؿ%?Eȁ(/ѺxP+T?,N;ω{Qiwwr}r%܇~ٖE~? l͹UBl_Wúy\Vuj9yhǖ?{|nO!c44ﹲ'zX] Y3ehV=gיF3`w͢kHG^p)v79HפH3ߤb&Y=>QKը9cSv\GrW07tڨ) mf9v uvn=C]LpDig8KR1GF?bCL[ dȐ,1U<ǵN1Xw@&
+lgI>Ow?'T-.lbyVڟ+$1<`4Dܰt%:F"=;)?t+S㪈;pGTcoF)_X,ۆ&Xg=;|!-tv`1=n"UK^W.s,xG羅A1P.<{@{9`ctt`||Mw<GC׷cO=F.xjsgu?}ZrqQGNbo+?rx8+'!ʍɖ]^ZW_(8;S߮؊7LpvBoEy ՔqnN`A%T?Yߤg:jrZ-K`jּ EH.{$o;Ÿ%9#ϯ7ܓ| S4.lLǛS0%Xt `-PR7ܧ׹ f|Ź,wpٕX3?Ow5q
+4RFB,ؿ)dƃ@^N,d`B6q3(mubs"8Ug?@Sf¾ a<, f#NVasE<ݗ r!$QƋ.z?.:Ț?>tIZ u3š2 ֛v,8O&eC8.;)dm|{
+2!U.( xC< si^bFIgK蝄j9亢P~۰0lI:E(/fDx$Dzl >_Okx-ȟh o&(3Օ'w|!]Y4Ӗ,
+:ԫ8t<@EF$Vd"lI- 1'XWY'%O%D͸K%rlwV2s
+J{Bv[HrY 7NRaaIa۪BecALP'}>N"sRHyp*MQv8 4
+h
+ڌP"Djd>GdώaPcȍ]RBAK5I ^FQpf@t'O/s-jh7[\ Lb~l. kF/_9$">>uCx r>;EW?_'s4IIWO5a3!M̰Ec>".b)T}ھZq~
+ӿeMI Od|IGcʦ ;1dSQ.2WUDעUJ//ΌP{8aSE_+Qpюʄ?7d=z/MV 3z[vrc6֨>VRVą?ڃ(e,洭E_
+9:m59t͌rdVdv2_"^+ˌ|Dֈ)9:{-:T;+ʐޢG>/qy*2䙼`ztLbCdw8v,Kq[Cpt(,A%̫+0k.JȃVߜꚗY<ge9?ֽ8'G학=b[7XTQhUq/Ʀ>d>aǚ]S<|u#Jqn81w"Go`Zaɛܧ%\[Q=}rq˝#V]gy3cl=N΂ɝU۸цWc\yVo>/a]٠@Us>OwW[%Sp"fZaڝo8\r{sE@ږ>_Yx[
+NWb8,sG1hX%y<qfD:ˤY/1-KCR3[mv-: M4oxp?! %Th dtF xY~b1A|Vq,`ߥ[n%;D-M ,
+/.3 ,/9c&@,: 1-6(Ipl8&DcÊ!ʅȃ(h7L8/dZ{Bu#J2p '?:ȅhNd48fZ BLC{0lœ!I'dB@ypO2 \J YlS&xaPWAFWԵPWIKP X
+h $\\$H7~)&LJaoSƄϲg]A\٘{A^W/CnY^r6xk[%E<WzF/+S>d]FÜ 7(Zר&DՔ%+1hh
+1iTJqX!>Z3o3W38Z,$RԨ (L'#\iSi+Nz=[ Qdzʼb.l|됦KhH/XoŽY*0j )<3
+טl?DۆN>q/[xq{)΁ ~ L\sDZ /%7$[MO&9[߷07cPkmz]b)UAݖ(LOaKi[Bs>\^ç&Id}pTebmwp?i&\VW2?a30tD_}e/ӕl[֫ qRYXKƚ&>'ևBgMRi%JvZ`ݹaΧ+Nۏ!{-;v”euʔ5SN]H$Òl([j-7lNMI/^(J*N"T{ގKl$ؒF<*sЯ64ƸdЮ9ȩr*Mb̻H#:m$m=*躿Q3qNy:[I_
+&]Y;x"q=w6to4:D^àiOәAmaR&'Js m)S١ׄrݚ^GՏ9ak
+=$aܜ^ےdKXŕ'ӎp<PBM哕ɰ>~[dXy+Ҏ$'ׂ@`|p _l;JAҜF ;Avu9tS`AA}8຤*֦Wɢ+33z=ضpLփ)o.#?=4aOІ]-ػ7XIw\*Bl,b_}?]ȯ)r~Q# _ל_GqEGOA,y#Q
+=*J+X-*<#!C9iTrqqqώ I*}\
+#pO~"oh:hYZ
+T:zcݫZ=S,"RGQj\"5@'d#ٷ
+9|cM{
+sF?>E|F7!, D4RS1*h[ڵEnD{,Lr)r7}{tUQep\]nҟAId82rSЁ 9͵ԃv +# ئ0t QDo>Dk ('SXGj<1F#JLP0. ¸ؗ5W(*,tO#Qd8.0oRf痄nUwu,~޺#aP*1lI[Y4`h%L8E77K2žUi7216qbLGҺx>F\rSuNw{P~Ww$; \lhd(T_["Oo* 1poicUp !YwAӆKiiZ t!G2穿)R ?ܹeص}5n^[wF~VS?xPv]i97ֿhڌ5)ŲuG]oY&Ҳ#G^'R~hqL/"3שq#pbjpms":q߉EhE:8a#<'+4:?=
+ū[W{[fdAukOCb8V1>V46r
+׊][G/I'I ̴`+\t~c|As#*svY-IeKGza9q>+i#)9a=ZfAd69O6ܙG#%h"<SY /hIT.l[URnmLI=;'JS>Dk"חl<YSHu|)”P9rM euD}ݦ-Qd44 eٖ$ɨ zēhMuS:B48҅D:[4:4Ḅ_ 8nLp4(ygvNn>'Qn4,d؜ ^ x>jDvAHd&;ow8^^<8/Æ=p;e5g 쬈ǝn橹Uloih}})lYBw8;kh<A調<0;]ٳ:;ؘz[߭ZY82o-ڊ{/K~7LMӋN;T_u0wve^ a Go^siGSi sayj1ߵqu/C>=p.ct
+dcx\478%ACɟҹGZ[^M̖N |7Xt5쿎3wV3ay_XUtU[p qwkN6i>{߳Df;d βۊ%_ܝo?dlnB6_J0>dZWUȵy ?]1~C|A>wϼ2ge 19'F(P?2jglG%ӦDUi^ Z6uO1#@Ƌ?uڄ})!XDD}оbQbv6DmWQ_t '÷&<6:%❓ =z̊Sa^vk3Ċ.&5`yGSòˀ}qVdeEblo^O.9uUF<#7y]Ō$2.X;%ώ\:v
+8* Xp;:{ "s}c˭l BYpKmp}7<ۼ
+:f)ˆ1C>qI{
+$XЁ~yqh< ϝ<sy1 ;hAʁCs6F-|9Ac&сo
+n~ +GXj/դ͵f:w5+{cnHM5OU}|״YѿZӽYw? >`E9t tɊLF,T]KDH mM#1A3jbܯLu{|b TeFl8tZ`>KxFKUrJn\ȕ0 $@C6#]ț%W]瑒J9:5c+~ب.kZh!3Op:tʃ+H/iF3es܏d [OG88`Imb}e5އ[8?nP[yzcU}}2u>Eqq
+eKk-ju`VB0G;`<wٕv!݀T~E)o#}T_ɚP󸜟>8;ɲfW~5dz0!lN*Aʖ mCǖ4ȼ={[pPf#ѸjC ~,@Uxb#Wbo]/ۇ~)~m@;>@Wѳ`RD ŀΚ3/NZpޯ; Szܣvx}u=wn3B}ܻ92xxSx9agt{Bx6W>k߻$
+no).ܨ/N#ˤCqHPi lUE6δ
+u脑(g5bRTbݼYq8}ozSG)_7VGKg Ik2㺭=ϙ }|ԯzlww=~Y٧D[6 JD""~oenAϱw<iG/.Uy@ݠ/KԬoQwke[TLtbg12hjw4h3"g+;=v7J}MpJYο)iдO|а?~]u}V,mp1TTkWؐ)zژi.=jlDRڔL~p3|z=He~ߎ-Fdc:9!ShLO{B\'S9x{lcslN!qXExJO8)ޚrS<oS $6I$iAIѬGm}(,XKz=jD]BwqD}G$s{ l2=;Nk<J3}<l>|p[p~7a9{일0‹ &zleWtp!>*xA-`/yc&
+ߊo$I;>1cEƥƶ>l4. ZO((uͩ΄`727%Ak_6!S?eEȸ/0+}#6Et$<sF@L9`ʼnL |B76 cxRx'a琼Ac푣w $xP@ `[]=<)񉂠(X* <6Gȋ<&5y B!!@ ݽ+j﷫⺓ݽ*=3Cfڜ3yIëcKr U#_=4j
+ ~s[eZ*45PڪS+۶Nf+н`4(o[߫:igD3%CvagAWLUcL2{{{x -&<//wNi%v Y3TK4h,+
+<luVh{+UŨ4k<dYd0kCu'dΡ.bR,]<$K=!z$#ÝJq3hse2W2d{(XuKy‡i ~rݻe =>Ӱ~X!vi+l4aѽTsfܰ5oۘi)󱋣lX]q~^c9ǧ?sG'zFkzF4nOQ>S8IP ;r"~( -t2IR[ }izqH)rD&ǒ)#)p#^$8jxn0 YJ]K)kDs 8._%X")l^*c@<HZjἴ<`$F6~yFȐ]vatb^”+ Fv./iHҀk3B$=H"#J{p*8-ؿ0a`5]AeANw9⑏|ȃsyݭ-,#945_]2ʽsjwZ:l'f5W׌ֳv Qzn}Gl_zW]AsL
+CmZ3)|:"yR\5pǙNؽ|ǴKpy)eVQaۡDv׌̺蔛fef'rC`ysY¤`wrY,8a}2-pr|FhLKl)`[v2qsg xcmqmBs[rȢF?\Aߩy) fB\,5s ~{u\8Xoa0/kǵ[[˯Eԟ+jgYێ9ghr3Mn}nIJS't;k1q[fwU8ݲ FAG7St1ܽ:gWǔff #|1Kgr0u&[o9TCxɁ=ln2(ҷGm( %>P܌sxRYb,T0˟uvTߌCI
+ђ\Rպ]S tޔ~u]_M\y
+VWݞvZ[ViZl="*;d2I2 
+]Ac,`{ i؏6u{.:!8@6tutK_ ख़?[oɳA헾A>7;LFsd͟-L4E$zd=7vhO47Ht؞ASbVoޏCgse'5N3Ԛf|'J೬* 9[`ΐggxuUy:v|x=J[,?vp_k9jxyy{Ú,ɜ`_2f{aB^lಊ
+dl=w K9a`9jvs9㋊By* k
+lɕy2?odN0xFY?a$#g5JkE.bo%J޹b<!Ε`s̓fy1dq`X^z.rf>oOo;ޟc;o=:&,yGl#r!rYFwFyגe:Pg|ZX)S.<FB)o$DyOrnCQe!fc(0,DI_&1º1sg.H΀%A i<(9O<ʡlx`pCm?)0' x3!. :Qm*.#+hi.b`Eǯ]+雺S$:oy}ùLh op%*6jM<rߙ8aΩYk؞eX0odoNƞHáqOwNz*4{:o`]jQuɺވع[[|}VWvء*-nj7Qu踽77`W.;.ۃjsֆtK%m\_r}yasFd-n--p26m\5eRTDU<ח3`66Hrwܻʥv>CD[#Q>p:Ԯ{Ց" \rȏqQc4΂(G *%E}G+
+qlk^&2g6tݦ-9/VH&kzu|C΁UߋzCycBy2+pFE\ח-)/wƒ_{ w>clh4fcOr1 /صScSJӲ@>3
+ieه[DNz|LC<ld}*h4Qޙ82a1jpPǍ3VWL R &-(@ui4- ,XP¢4GǍ,p&a#8βgx&d2eЋZݽZiB]'4/5+O&eiDf v <r1ݔ'IEDI"`'D3wZaZ00%ehI΃5%YʰSCekLCm| 9f">-Zrq4pa$ѻ&S&gE8;OVvyoVqB { zwndJˎQn Ԭ9PNQ`l
+endstream endobj 43 0 obj <</Length 44667/Filter[/FlateDecode]>>stream
+HlV[SW?Hj룣i}JQqZ 8:,ʢ( ,d_nn$f# !:e>Ο2ސy瞜o+Oy5e*x|T^_y;#_5=kljMδn5;o乆X]:~Sֻe':uuZ\`U%E
+TDCc \N7KP6!@ەbbx׸Kd'Q+d/T X7!= :'Ss@]Nhz {g{[/w?B
+cȧ_^ڢҴTWpmWIg=WOVŇ9/-ql O1mUZXXoPck9{FAw^6P
+N;\`EL w.dDfؽ<oYm7 cILıwRG∺ސ[ >رdaur:+EEv_ޠ/Ppo6iZ1oAl3[.{^f[o1D /{iDqBsVw"
+( X52>Ig%Q{aٳ߾s/Z3|Px=/p:Xwt٧z]:1C"gzߔ~80̹Ìs҃v|TS%]tH9<}y|
+Ad8(hX ~%zbR ^J(EHa
+T5,QV˘pI;l'ew"Py8x
+||l.y$4hCbe[LK]g/rlE4u.Iexlì v39!vpBwM؆CΗ>cg8<08`t<u6:ug􃞻֗g9j?jSnwy-N֥
+m9▆t6w"Mub:M qBMjW5g9b:cn{k%ʤ{Tdlv-6yc~jb4P.cU5$x^&3\,m78# T'3Sx"c6k$gMC#γw$;$1V dKrObR>GW6)n3 )@ }(EuuXM#NvNN5KflB* z0*ĚGa]^)LĨ2R@rIø%80%uTz6ѩ`X#EpQgR96 "ڪUhEOXd̾]rrCYcX=U{N{Ny@{}$o>wVLyG_ȁK—hF'qqꐚ=z"3} 0cze=`E]ӢU1uJv4tB. b"7A<ᑹυ3)f < K`Lj{i`a{_m^È![l!ʼnYPm m"*rLD%i(: ?'fos;UJ;p&"̟Zr *ޚCz;ը0'jZ4"$-S-C7ڳYSdӂH^Tl&rl5rmI۸u?=exq
+ۑ(^zD.A\Z<Ucr0hRW;Isu^=%xQniJ8}O8VNGLtz7/ٍS__ui"`A;:Xv;ZsZ!xN"qkzw d ^I80iTr㴘8?c ʃ|BQIv{{)υd㤃2#S0`N~NLZ_m*aEC? lK5Ga9
+u?֨kSLx 9Lq㺄v԰q}^"DM'oԯI&H \ M٧s&C|Lz_)4 xvT]AR)d*RFOtrAZ5
+Fdu;-,<LFߔV뱍BzB6ȵK:i"3b'`e$Md铉)k+<Si2 (!6b¶әsQkC
+THI9RCE΂#`dGr9"Y6R[e7~2Pe:?DO5wY+[T2NKu@^r$ԸR؂=B lHbikdZ؁v 8Miy3*XijLQ3i]UhðOĖϘ(B$^/R2VE)~D'^8Vp`IQ9C0%"uڼBy?ՒJleҶS/kq tPRlA0a36/G^g0>]q\y;z
+\6<YnYlw{.?4{'gk4w#\ޛ({%*&x?|flvnM6|؎ȫv/$<xr+-s یt!1'麳sSL4Y*<7y~y ,gݘ/-潒x?c}SXzmц9/nv٧ױn2x]loJ祜m; R[d)͚7w)œ p4^*O1dÔɶ[JZDށy'-Od:TгnV”o:(Ns{*/Ȍ!D4hPm];-yeڹRۗ]3~ k1YOykV=5k덢B-r_61n}˟i wM`-BVI\y)xoJ{E:==apKp]D\_H@8~;UY=0qO,S i2
+I#n P9":SgClϏ:&""࿸b/'|ZUɣgg\wkP$IF4Pq~k˞YaڤT~^3mF`V
+xE1A {+5)<|ÈoE?GkF83;+v7oR<f6GQ}e3
+t}b♃'CKϘ_R-e/,3oqfApە*$|r;0?%=NB0kЗc<UE;?ecS6U\TGD"ݼ( <=s Ɋ[/w떘rAspva=,8.~c`܇ؖKyb|ﶍT$ư65xl4t
+\ޚ6<X`ބz~Z4n֮"}ENV`֛gS ݌㣭 II Y5E5@\SZ \Hk?oyCJ:B-
+U*X`}V):s7`BxW` 's<,IY5'c)GwGtgf;3$DӢi_O Y?wfoOOw {]tD%^gDZoRs 䥨מּԃ+;G1΢uJh܆_]TZr`=:|ۼM[p\[:|uk["G/$xn}ao/2\ހk'3 kx/.0bޅ =:q#7{ XfM-o\[2?= N{0o6&_cm] q6o¹~P+c-gԮ(1_e);mź֛#}7h0Xx313x2[ـ*8ˆwŴb"R'W| H"b{tdzTNJbl.SxKZo5[ƈXzn/"V[2AO<>$~O
+dL5")zz&d"$B16</ 0JC1 ѩ aBlO0L($9Xҋ%xg08mOj M vw84x']a1cwFQ:>#:`[[qX<R&11v 
+6WQ Oc־ރC&ZI#S`¤k@3dnmJnzHDbxR `Z*=FnSe\Ncau|7'$3G$n0aWs9(T\ s*6!6'XXu
+ރzɲߤ@.kQ.Tߺ35 2d¼uֈm`>ȇ+|Tۋ? Ft Vq_<X?-<j΃hഅ< r9;Ur<Tp% ~^[]WqDބk Nd9/;Qkkh{ꭵ wYvU\_9/ZF>Qiq$1j%6bbgTzYJOͻD#gODA
+WnB!`I)i[yCku3:4K6{c!^d+'i$=3
+up+Ckq-Ce*nb0ㄇN*48 J64Co0B‹3.<gWZF\ g2y4&(69F̨T9Jo|I9-91G 5k08 qb1ݷ<}uIZnp`hys9?1՜WSmZ'c׍øY~'c管F-b;Iz|d97lAT01(N1&5(s7vNuX裮OuvV > |^Wcr4l=Qy~i.\njf'vdsŦ J `1CIp&4`\`,t-[ZIl˲]V%YaMo:ӾBg>h}$o;+ kfȌ] 7c9 o?['4g~|<srJk]vsi%۞yvRޕd=W;^ވuլ+oS LPݚ+嫜99M6ޞk>*8X ^7d3aFtlb-.lF*:\ð.[ڔ?[gKj[hs|Gᶿ_1ϔʎ:7b[s9qX1nJ&qg|Z%v{KzV"8bt<B4}搥=sgs7AhܝD\\5
+2DGzbf?3&C%jZ֋h'6J;A GLM#d.F*1BJ<ʲTTHRZ* ӄ1+BtgIR 0.FO3D!pX heG3$~d%OH4 dXwnؗ8N9 :Ijiռ<mG;^;>,!ӵޒqdFeඤ$)"Z,{Lu&T>{R2S8^~ˢ֩\&
+'8C}xiCYCY1)462-
+ﹿӟ$xڂs-r?9gyг7|&*6"<0;9SWOnߌ:Un)}VjH[ȈƮ7FIE[u>쫚XWSS30]վ>ĊK~TRl\7`5 Bezo`[1Ƃ{[T&fw.noaXp'۰5?By`lcs!80:? ,fÛ#8?F'v9$퓧;u(?x1_pEY{Z0Ag)OKYX4_+g<\x4Eƅ5v;ؿO__9D߼vu)VteZe~J^L+.dIGyQ&CXw[򪙁vcAF`B;.若\L8 i
+uixc]-ǣZ\E*ȕ
+%Q>h><(m8Ę.WlXs
+@=3hp6,`0!kRP4F+a>֩q& Oi5cDg҅fe6`A>`@ۇu)zSN
+k %Q6.C;bSc5t★TnzD fc4)ifFg5G,g̦6Nm!(M]qJۙ1FWvT`֠`ٰVZ;z*'xpD#}0E)acV$$ו7LP:bZ7: 1৘&MK>07XAzs김Y'kfNZ iq
+f48a'Pm4ч#tFh<+!~{>yeڻe:q!:g]7[px3Qi
+r2aOAɨw<>_?a:_<@Fd”'%!e_sL 1Z2
+/=+C,os0dmmk6k6 -Qu0 KGÒ Wp%LGĞħ<
+| ,]g{nה?=cJw/-EQQxhydxOF8"$mՑn6& 㲀G\8lKЯp=Pn::oz~fPs)-C8ƀւR)'b9"h7 ?4NAN#tQ5JTR; iԶ];m# g.}5} {]%%HrF^_wgjpruY]^12]wa^t|'~{ꕛV%-.B A˱ϖcX5X0"\_
+.+)pI:E)pVayJbG!xmލ!D\~Μ7`m\NʃxL9f|nWb΁iVr~;ryxA 煹\>ك?w
+% kC]1O2~mXn@lr$ʹ5wV~æ1 3iWQz$XD &XOJI{;cJ
+ 8n`ŚNXL۰`]T?0Җayݾk.xyMY1RY(;. 탽ME!Z  p#o~ =ppg)V-ЃACn蟱i,V'i{EM'(e˔N-oGFb|
+Æ6aO+
+MdʗZLO=«%zL9&ߓoK亿qڿ̖nvV/UUY҃a!g%|zoNlst n[.qbީ-k+n|xs!,ʗwtՌ,`f|`3,%7[i%Akg{tXFĐړ M})iɨ0<{ ^dOj}qJDLQa^|Qa'V ^0嘟+JZBDD@t"B3a)y@Sϝ 
+H=5a_^+~dUR;)t=[o]9qռCx;_
+}D q}g
+ȭZR4WuwQ?u#C^TxRJ-3F?:?L%ļb0!W|.كRƈ,
+3Ep5=E֬""n2E.2u!?* ҙ: X.Sq*%n6\ `mZ4j939i W KzN-c@?U؜`&Gkp|T('"hA8g-2.-)lst+OK繢;A5pws|Fk*c 4z4e-G#Wd"$='jwz㚂 l4"403}Ov3Du]gȎey5l yಲt2BnEnrƽ1y`s}k-gV}_LZuF 6`54(2MȺ{ پiB}Ea~}NA:X{29.fxu}Q"Ƅj>ע\}`4f 0HqXrU/6dn^uv==ߠ1=l8·ģ-GSl˿'MŐ([mP\ aRuGe0[׃gto1f ,?PSmޞs}iKBZ+,G5LHLK(0RƂ(&%P;nnѯsȮӠ&ADNq<jYupuJݝQOqk=PA`9;Ar@Bt:9H3US[G~uk?oվw˫ԫ߃
+A(ʄ~aFgeT",$R*Bya
+ da$_= 4"t?*Ce)ZFE%~{H r:#O&8!߅̈O0_6Ƅ?ޯdT[O :J##`p-kh aNk{ac~[HJΤ|{gP4jga^穳lz?飇߈hX /y!Udٞ+[Hg)B븟g$^9zMQb$0H>#Ȏ^yb2rՕna㷻.jV偁 Mʻnoܹl v?j^0~{%7{;ƶ_?x-`߆)m)֭5key`M߶|Q]Z٪%/D
+xC}2AmkAyel<2!ne!
+ =&[Rj|IG+xHUYKB Y}3UVԂ@A,30 ~˼HڥEL4֘A6*r4u327Z:I&5 کF`P+95 zhz<"72=$vBׄpxDzDMAw@lzRG'.:]5'WsW`<ن
+-lIz}-
+p=r
+AځolDڃ zQXp;WMՕл֛ZWgpu3Ɩ׫ XBԳRKBzE0Q9铚jr1U=(I$6pwCybp?zNx <#RSm<,Ѻ7ؖ|z[<[l8<:K$`^8\6'i\- %ð
+ǥN3taD ^H\Sk#ܰx #_'|3?.X͵̏ؿ av..p`u#*\Q@dE4͆,ÁQCGtCdxn $:s}k48u:G!OL/s|Dwg޷;[cKd׮ ttR?tT>׀TmB.#}[[[aoPѽ?=|7BܽQ|dFu~`-*w7Gm+BKFJ
+An8^1u,m L ;T읠O% yghwA>(ІlN)fX >#^p>jࡽo_Ό0z iZ_'19Ζ%@-feǶ2ɶk95>x;]gz[ze>߼pN7lDbP
+m;@7o> 1֭}RU[ lnO}?9 Sb|jsjL"T
+*܇ȠpgO@PIoR+ORQhN2eX\=v;t/E
+l|פ/]DŽsrN#
+ㅑ'Rx뙶; ;]= k\{/uDPgEm爸 3:猶bc€Fm\iZl@ a IȾTJRI  j>0/07̽>|O{߽ES Vk&g/\,ѭT&[Щ,0qRVǕ1nhfGְܔ/PQfKfhscKЃ y=DA-˄Z? {]D# Mjoj"ߢ ~72e9&æV}a}d\I[s{ qTz˹_ո|w_.WgJ+A!c k/]k9R
+ܰpt=pO#)BUFi@rN%mGږ%\`x9XGC#^#ڔv[HCVLD8#9S)){%~h?r=yxpš>jBbnfVGM[(l\B
+}|tՅ@z0.IՀIrALsE͝Y-ێ#4©CGG!"> =*>-j<n\xI jЭVN{]woߜW]j;߷Gl+8J
+ƅRD"cW
+0AQC5?vlDuw_=zSngNb/*믇 Μ@xE#6u_N]:u%V5r~γ?FBU__ú+g[nRV"yp+$gdƵ΂!{C
+FHz^@4ⶍpokҒ`4aNR Ƌ8t$aI$Gh`R`] {`67X_ؕ!R
+j=Ve
+$Du3Nz/?< A[f&6<x}7zsݿ|
+zꕙ/51l|B(u/ӎ]<Զ2;؝00ZCe7'bj#5Ye.39=m2t{Q5&z{beYx"> v<0-6-EhAN'@{ݠ\luRFiZ(u/ZLPeF-q9eGkԀ&sɱZqKC{ '\@xL𤆞U{c_O Tze*hAE\;Ѕ ^ b`qMLw"n~x20ԏe܀Q] c1M+|HP+h)`߶2=n 6Gi,_& X2<?i!9NL+B^3<}v.=2de'-xrX.ږ np]~ڙ<"Y`nLtYHR UR˴$-Ӄd?)2 Hړ@GUEz<p ^D2G/HoqTb- ?\SK-iQҚJZ0"-<゚
+rçHۡlZid~䝬n+ˆ5.9MySY­ZJ/,o7\yvk5x{lSQ
+9ŶVmǭ]QP\/' r@ <ɓBϕtwl?voC|ϓysǯCmi$vKK_]g<2Xg^`jLyX_L٤c2Bybe'BFC!2<rٵev\^{mC>#Fk?e
+t LHy YhJ
+{qGҸ)R%)AXi@0z`hdó|%9@*8`>2@?̪|xGQh%9dˆNC袍Y0zduD=߯^ ccVhC}RHGIĠuBH 0<e\CKI7.-%7s40|'z~U1zcӷ$y& Ԕgp)C&:.?'["+;K Bnqp3Ԭ&
+lRZ1{:DP,9 E^Rw(LDlƻ]iXg~ 7-Oo,*paEH:8p/qi(r{u%r`zЎHk͹,EN~|7>Cw7;FO6<\V49>\"ױPNȶ=!Pټ)[U\gHHQ!~ʄ~|d݊t_Ksfܰ*K3̹qu>8??2 &CRvܲ:n)A3~T.PZqw9u]wmfG`wgܙe52&ͮ:vC3)Ac]Ź~j [vVLЂ=+
+ \SA΢*a¨%16.TEӆ¬b&9tG\/B סuhju&FՂ*3è0.0ZZB1)arڀz2JV0 QjBHЉ ԏrh<.EB5U`x!^edFHܬ`$b˅I8t}I1<MHBKRcNfm՘N7h wjRGzz"zsyHےmw
+B]BDC)\uAUV=VRO"~ T]ȯyۛynj_H4_rvq)s[=6WK1W+ʡzˍz=C.=^_7>O:ĘRKhCu\m; X鮽\`y,)RҨ{s :W:qПqeD(T<z^@fY) '-Iq,H0-e|4Hp*%iFhOhA)C\90BaMjtqvCsP`SOGa?6?Ec3/i6Rĺ23Y-Il_C|j-@}s1`3'=M۩+ sT^WZ܏^v7V?u#*˜'# Y \wo%yN:N {6UMCBv$]gQMdi/"TZPpk׃h:Ћ-"Mk#G Nd_*[UHR! =lm8Ӝ32g,$8rJ~Qx3%QD#ϣ#zf b94q]a5Ԁ223AyV KnSQk\
+ 8Dvᓶȹ['+@hy{*p>t msǭ uOthT2@^Zw|g!
+a-3م
+{|Uޕ=)`4J ̍Uf_]oRó~n_{_c-pll^Oi䣠\ *$J.[PKDa=_I
+%ڹ d7T;]ƴ+li=4jA
+Y9)ejQ{}pM)Q 2%,Vɰˠhp
+4"A@#"#n'!c#;d2[)xȥP3Ì\#F@.D=r-pa\ Ȗ"Ĝ`y6z;DrGB&4`R %d` KF\쁰D@\j.[ykձ?7>1s{sAk n}?xo]CR# #`&~rMLWLiZ9 YoI#-OƐ7sZ1E&<VX;iYTC)d9yYԤuU/ѯj$U2cy eZq<atKua3}l a#un~tSkSg&o*Ե.mXttr趶yE]iʻ;aS-Wbシmt3㐢}Goynη7ElV%HrgI.ܚpޚ $/wddK\,d}_wok]h;~bf.bŶE>&%}3X܃C?U'>4'ٓqcu؞d],Hj^:&͍o-13$05X gb
+~zvfXx82Q=!WTXN >*9{#P| T:
+دȉPvtn8̘8_ܡh=fc^#Zop 4jz\?yx.GSWӊ~+Hp^I;aI>3bAL ̠tR@ȅȃˆ]MwC0PCJhaHqr7Lhܘs_@6d-v%-cW-Hv#N_AGbvgƫϣeH1IxhI {b y'+,jd;[9NM+`eNITd #%{`>h4xJ4J`Q xRbDObw w);) P k@+<%SZX*4 -!ތ,FAxI|(1FrYި#zq%-Qc9Kig%*)+kg~1f'#_vՃO4z0fΤ3ftm!sv'4y F:q1j,F?%y7
+@7Vof mj}ާtzR"5#k,r.vъ(9oC <(CشOq[. 7Wp ߤ[HS/W|`L
+-KcK=]iN;u+rjʼWru/п5a{VqMzp gkג5_YwfӋ,Xv[^<Tۉך*[6oXȏθkUg M]gge=t=l^#rۦPw9KyBҽ?&>{WƓ[P'u;F߾qZLV7g䡷X`i
+@F-{@{5[C~QD5ܽKgM' gҦ*qLfO4g2>\φ40b&18=ϩiGA1 " aiVdU +r1Zzy~- <0/1Y\e08VfB|E8%I?#xdWyS=6zSAʐ,J3V0t6g)V20Ww<Lz7[+!VaQ)|Μ<`Kꔜ S,LiMMqI2&c!%msH,=,A9!(:1IUv)Vޚ ț ۵C׷=:7KR˷2cΌ9%/8XsvGbe}`Q\)kO|ftHj)ePW
+}jA_*]0!쫆~^75-;pS
+㫖z/!H} )᫠
+Z൝o;\.]`)]0!p {~  3UPwO*Dx<S-j=zV\q0<} Ѝe/-XO3<% -8ehNˡ*=^SvVOz*cԠ 35ʯ=Batiuߪ.u|Ip9Jc2rQjh ExWVN8ѓUk'79P֘TGq :/iQ)RV
+ŇaҸn
+&iP`$c:B9`654!&K*Π3&XzQP:pwzǠ"!<D'o towt7`foXі
+<AT&JMi' J~ ^KlVo9͟'Q%t㜉@=v+ [9p@z*3Z}O="u4g̶hyaΚь
+̛.F5o"f'i693<޿
+1̖Jճ]Ս'${AnR{Xdo`\? D \n~nq8b< 1b#t0ԩtl딦=nMsZ|G
+ "C>ChKr,Rs d @Q΃#۳ p"忭ޙ0l t]) n[F#4bx"wkr>/'iBAʇ:F+؞&m2aƃr7pd${! ݊\:8uơ';ϡ#SIٙᎤ%a~EW.ױ-HSA$j::U=Ջ; xO\|=z~mW] ಑ÍkefxTtˆHFR4NU`R%# |U@+h~Xl\Xhӌicd
+YD,,*$(Ƃ.95LX#3R
+G0x$_Km\n3;Χ08AD \@U oeN*>Jp^VBe4@Å(;'^Ihl͊;hTU=;+ $:=4r"80<4<hdkޛ}w?7Vd(,fjaB=W ".|"4ڸʄ57py ctGR9yf0qҼ2/6Xsy+
+ƨZEĖ0mK6P-%.L#2rf荞Ǐ+e8iT56~
+?ğ5,Qo?ZÞGZUXȀ 5Q^1N@Bn^.9؁M߭:{n"9
+&9OJ
+dRm<9υHT4۳ȹ`# >5٥xry֕`Q0rcUD4/#ԑ
+M8w i9:
+OQ/bЌ/)9ubtxio1̈́1' W!=10vf_'
+o4iq;h޳\j}w'W`S0xNg>=m)x|ҪK<
+$=6
+nԢz,3c5\5
+: c0 F'D֜'g24%͑Odq<Om<[ܩׇm&`6k©7$[ .s%=aҬIV$eTM5ZiA&5&k30璖rE?;lIYTcƤ
+clov6tk!'"㝿 Yd9(HM@+CRȮCch S w?ћߓ[eJ;v֭Z 2[7)m>;B.8Th/k߰=B?-OhusEd?rj.pS2
+.a &oΦQҿ83@sL6ϼYM+ϰ G(~Vo3&e^oުZ ƴά`&aJ<Z%߸cΜ寇;!B<(X`<kԈJ(1錈wnZh tnj?ǾZnGͷ//쵒Ֆ9#Vʶ#.Y~eÛ_9GKJ/Vگ=-9҂-yp;Kr\W`ٝk(BP"}e,o]2[)o#l۱{%-2_ـ'-҃XS˲QNܶrQDW
+ I.IX,ĩ}<<Osss9r|2*._fU'W'jv=ŏf\'bA@sV_C=GXPȏ[Xudu79AwfT>r*?ݼ "A>w/sBav0 g;(Auj{v;} &\G$
+:̛ =5۠wu J 1?>s$l#O EzEx%2394xǨh2k Q Qx/= : ߛckzv
+3/xKa^'}Ϫ~}-l4t.' (Nn\ec{Bjw37'i-bFj )-(*,ɸ2
+ rgY^յtbT!m2E²[3Uգbd4ԴiszMU5VkwV~KH/LLM<nAF :F{^91וghN:׋Q;mQ&|3|uĜ d>VqfvO?͇j۞C<[ 3=>ǣ=C^f㷢w1w!32c Bc5fa£;fuazYȄ]
+6O"D[V(0[vZ@F|Dp86*'[; eKU4{
+{&)kc40v.{< wIO 2횕2
+4}Y$a$ 0voq .@H[A-{x<u$?P^`SN)fnQY V٬"1 f7&ܚI׼<[Q:KNASջyEۀsח'7/&ʪ3th: 2NAdHhu_j y4%33r,Ķ-BYitTe];f'm6_qcC)ud
+'Yޒ4(VXf@kHIZ۔r &No`/N{pdE
+lt2ۤgj&T=#kMck<CP̃n[iƙN=u"R[vhVyBD0If8d~tC$Yc qY$b>f+S6l2Ll1>7nTĭN:^՟b]n'ieq]G _2wlCb\V8O}
++>vvソf.Mi^VT/D8HWSdc=cuq7%Aɯ
+>OA~]'yj?5,L{fyƗ֙`}4ys.y;͠J#北6~OglIϧ9#[~5{5}/xwDk;k -R[tsJlJM9w̎6MQŴaOJ>Ne@$Pp;e&_.ɗ+IaypK~޵ɮ&<
+
+RKI !@!LI&!B&L&$$Dzn{vgϞ=gބH=ߙ;~9jjRNQO{"hc0I[L+e* |bnO t_ WtI6I TX(A#Q{iZ;(bA3Šh;eSM*`K{FSFPoRq5}󐓻W" ͥB\2lƌ[S.!]{|
+L7).Agz|'2;Vrt<[J,ǐ upi<klMxh <~ɟesfז\͕]/-y*;/ڏGXL*^ yv}yJ s az.,-:g
+\a<ݶ:x ecs\ @j KRACNO_lw:Ԉ!+wg<n띱">bdx^͞c5DkZ3B4krJKeb]3#X;IVn!p}7ZN=n&lcQn, LYG/WSAi>;Y3w@p7ߗ|9=d߆bd֌;b+@cRD0C
+9JK@2ϥ|!J&FhD!ZY £sdXFJ5~
+tƧ)l:h'QLځ~z|.$( )1"Nᘰ3z
+*!FIQ$hyNI$oMaiR =Ns:i9Ht3NDA25d{PN.r*<[D43紺fSI2(OMJAYEDiGԉ1r"4
+*(01eDqPIf^8Tmoխd&Qv5R;/[><6â8oqL
+koGN}ZjЮH:\ʇ^4lxwcrR髿\*׽]0c +2m0.ZZ'k3x_NjVY 
+X 3|YW
+ahuq~ nCw;\7 v;'W7)@cTg(?Ŵ|2f̲J8ezLFK=ɪ^^X9@<>UqϏX'WzJ۽싫X-+.-k·![wo
+~Ȃg)Rϰij>8dif+%MHqsḏH6ӕȌgvJr N+
+iMNƀWE+tS -Ax<\a3aq; {$0YpE%R,}n7:S~|rW"ő"A>
+ /4踆Z|.p#aܨrW0L-\שpDྜྷ؁!'"MNNxA5\a~T-#ЀՉ]~[րM824-КlS,,TFh޾3ʧ'MV܅P,g+\ w5owU
+Jـ{4X76edZ,s}sZ&+f;œv@JjX)}["2&tA)>Okak@w;x\٥9&c}?;}`Ew J#
+I "lnB ;tdX OVF(KQ}H_~ H96(ffmkyEiQKﻘJ JJZ3?g7mMpcځ/bpAס>26u(;3;aCˡ~U>yzSڄ#A*:Uƫ7#7p;C6 v~8Cȃ ̤_6LszHRaF}aLL+Ǭ|K&S| cs<<V8vF=ܶCo}AIA>[rx v6fCf\χm>f81\8{?=S&Plސw$}W_;wcA_:cO6ؾ8eLgXEv㊻}`@˄O' r. gc6۬SJ-yᮽܒ^h}/T.6ECMϜҘݔkL%L|ŚT0&yGѹ-rtTqϝΙt;CLb岟 L-:"?JqWJw]]oۛ3EzQ޺$4DԬ>b}fVo\gJ%j}T3F *xU$zqJU}) ]N̵Ϻ[u·w7%\ėBO= RѓT9!sla얽k3,V뇍g5lg<}Z03u,3֚ܶ-!|X$ΎJ~=Qдв;t
+m սtM-"΃9QDyx iCڈ'ʩ~IzFn=J~~ݣ/6a_ y%i߮ٱ"S2mH8Ӄ ~)h EiVHץIϧM\̈x
+އ snC,tM{p_q2\X'j:ށy
+%1/yxO#G2,ݫ@ᜄgy3Gn7kЯ01?ґthILtU.]?4APGFku-RQ)G@9UR+!MHB!$Nrp.0hiV٪٪t:}駟tw U[FKv ;06q@k{W;*eBbGr ŵQa6Ǡ}͏-F4 ZG26Cef[ap[%S>LfZQuP`դx&1[%V󱗵by5w=/m" kjǭ1^ b1J.!)wL1l I> CQwPW<Y`[.y=;D0M{:maXΏ=ior)KzT)0$ԶʻWx\sODZ6q4|(A
+-ٷ'dO+s;:
+ˆ{ܾ]EBr
+GcĘ{ŅAx-QY2ҼjU[Vm҅md961BϵB(- [1&)-⯸uߴ~v zY·!3<nRqy051]ml90 >0.\ ٜnC"gN,zט"\I
+VRd"-M<BE2"mW/LRwlQj^n28{"ܼT
+mhj.=fB5\Rl H{H0z
+X80]5p_88Uk$&ބϺ{}nǶ|WUYTU
+ݴO p
+W~Zd<Q(="3ߜ|KP٢e:o*B,iQSz1+N+0qA_I:-;W6;QOgkyY_#6 hײ
+%+,vgZ$Uʔk,Kʒh\K& 1Z`Bcq?jO]S'gMHufxfc{#y KUʼ]kt:[Rԡy!-?Kq& 70ak+H;,j 7}ռS9D-jLz2ߋ_:nnxh玈vK\0y!'G.BK4]DZq{Mk"-E،_c1'7ii#Ҹb̆26yo?=ްf;r^1AN\Nd>p'KmK><Yv׌ =yWOm^i2nxlp) m-ڰy[)ۋup\Œ[T+27v=մ6Od"DS^'dnϻ}bv~7uq8 fFɌخ3]1NԴ?6Fmd\2EvtK<|wҲ|
+3 _" \EcqI8D0& $x&,JA} z%Џ>~\fݲ{^D7r0P*00] & chqʻ ,<P.`tDmo67RECz=ЃY8&"7"H'= K4~ɘwqe>[; H]q,G%>'/J| (9Y s'.x5b.T? _<q
+0QIRQ,*Vsʌ(1iSK /2=3GngdZ`ږ`}iDd3{uG.ztwU="nE` 68&߯{hhFoh|r7w"-G!#T^gfء3{a}{ܾș=;`=gw{-\TW ڢH|K[d-_ԢhK.z4`qrhaެ?f$WVr{^'bj~l&(@*l!l P#oY @;sl)ZʔZF^fsfPZO)IlDp3|$.X@.G܁{? e^xwp!9{~m[됪ꢵӀv뫑7Ȇjo 4UjV"TDX)9Z=Xʤ1)6BXB)VC%Ḩ =J* \Dnn68/۬3Jf{P̿JB0&""&Hdc ?913w<ƳT^$|h3WlV'ruʠyVVeq`.Vel"ySr 0ؠꆜeu^8J>ՠ¸_;i
+MJРva!6<ePV8gNr8X֜X5lߑ&-&4c"l?E6EP$:/[DAn("KR=;+ٓg9U(2n}+)\'c|4#Y? O͏T'8$إ19ߴ/Cf& q
+ѵEeNn|c:!NDA|S’^lsdN/iu( C')M |'A %qj{$Nu7^Xe*Hk/%lDa6e[1E_;<ʃZn|B8xPH0GT5QTSvT0Szl簲f
+٪MHGNuy?`. 7Pc
+J60:l>VwwO)oS`
+endstream endobj 44 0 obj <</Length 45899/Filter[/FlateDecode]>>stream
+HlS[ƏnM%KNzЉ6^&qbb0Y$u_II-{]͘7'NCN{ǚ==C Bң/Ax#*ȩ٠n輡AͶ@d''{IČ_'fǒr"
+']$y83(\~M) S?u7ט컦Rq٠5e>j9`kYu,yO-Mb6EXi&<yS3/6GPy)1)tA <-frF t4[}-.wJF^el^s[ّmEk2- n3tw{wVJ.
+rGc1C!"7Mz^Iu_ z}@{e#M<;Γ}yy ̸"7BoA  ת
+`#By}"J %٣MP_ez x_@@Naռ.avPbѹY'oVx{nxSFT9ݠQ*y2c\?((P
++H
+4{nl}_/>V_{`O:>᫱qYrdhR)<62;U_^Rڴ rPRb:/㧬͓;ݭ6譿_Zmތ9' ifCŠ#8)sPr*" w9,FmSˡdIB\Ha?P iyGDpTDiB67K)⑐2Hʒ"쏨 Q\hɕ8J.fǞy)R0(K%0$aev
+%gcWHD h.4Jh6qk}$e=#U z/
+o:`yh%:D\~7VI*\O9B%G"RDWs[Pza$/q/ozRK$!OPmR PB!B"^il2"!kTr)ix$!=F0
+2:{jhǝaszȅނ[Rk~u|h/]E)֔#s{ޏM&B5~V78f#Uǥ-A;'cӢ2H{sq;|r}B:vՅZz߷8#'%LEǕ%3*}һmAg_7~} ?UF[~xu
+TZuFϱZ:9
+Ԟ"j+ԅ- bAA@IȾ'/IPv1z3%9/y4ff\5J2ނ~d+
+N+
+$Bdb*LsgܮƢ s.%ϧ5B^Rzgs7o?njxE=` +x6zļRE>W
+<0~<|j3R)ھ Śk6 3O#yzFo}mAyg4-txemO=!Dd<iVp
+t4ͻo)8_Jت<k6s[u(QnW[2+H#PFesΓqlʲs J9Gh39+DZxWNؐw"|Vzh>t&>/*uj¾e5Te΋M~}M?ĺ.@66} ??9ݫ HcmUƷASÑ?n|{ea8G)
+;VUYYA53CsDt16?~_:2!v+΄fh?xk\6G#>J& Hp_JCn i^t wqE*IM$4U]I@a8łn# 2W§'JGhE z * \!䥐s>/3mu3Ҙ
+X^쫅
+~0y+Ԕ+5 ? 6G.#̕rM˵`7;w{ >?yb8A„ c\R^Z3! ߇LA]sU"Tӡ<$To
+Zhnzւ;+%=LK99K~795ׅ;B&D)] ktwĕ{AR{y+hjC{)6~s|'i{wRJRi@ˣV]XD=8k<WLF0gYJO-GY/;j lBBCf*
+Z
+4_ڠ0GJѥj՚FiȉI7֘^cF&UKS71$7ԛ21*org`inlXY ϚoVx[c45{`9 |]b^3eZ{S6GoNUvKi'>
+uG˹͔IVse+<?E-!LZFEnppAC[是z<<]VW+^5n-{A]bl=9wq\uwd[GZro^`i;j>Y%.>bsҪ}%K:^: V6^Ҵ&[dyaE\)s?Ҟc"ӄw``/Gr sAZPgʬe׬N9ImUKwt L.ؗO+- izЧ끋9Ur>>rO/_ ޚ4%垉HN.qgƳ[⺪_?6 9e5g-5R٩ky~9`ϙƃy`x<:ӑw
+to>8_h T9d#7GNꞲ7HJfo{K<rIO?CxЄ=<J5=Q '5ARfo, 5O E0a zb48qnK㨵 $ȡMAtڤX妤KY jSLRZ#O5OC]jզ`Vm\d6=%[&VkDi :te!SJuidYSͰ8S)#* ZR)QF:~+ xн+mQcjl9\ rNYnѾ1kh*tw
+U|k;'v-B_eh~Yp
+c+=H)姝WB[U~,nr -}V8lҶG;ME/)ʰ`Fwb K dx2b8?'}%ӆZcJ:51mk~ ǕͶ82`lISOl
+h´>,ZezkNY8ta`L+=G%G@Ax7_ŗ0Tv}Sܰ]g>h8c(=&+rw;] Ǻcd*J)?[P>m4&{^חm_DostMX;w{0k94؈0htAA a^?]+qBIR6c,dPAk
+1sRӤMH(!'bkfo'1E 936'qc~3>'0tJyhmbo?NbW s{$Sa-93Ho۾q%Rw2
+K|Zt^t߫0_T IX'(p ) AbZo3'|ڱ 46BL{&<0l#(Jֆ TzYl !|VĨyg=184(
+=
+)
+RړP:la9(:E>9Y:lmHo#V#k
+ K鯽X) ?s:mJ
+t["Zh$ĝR KJ H!!$8$v8v .UVZ~}oI&FV_;f4yj ӵnD/ 啄F@pdt6܍Hr3Xn,|O=,kz0$Ö.z͝p0w &U<0NNWR]lCKf:Sy&ev{V.U}|epUݲ_h,*;~
+\_l A]dX+݁r2}
+ 6ZCmX@G^DIO̵Z q QR| 楌+zdBs(`F ;a꼱꫘JQ"WË2ńzs/&`V)ZK_:oG$Ϡ
+
+w͝s-ޞi FP'㲾ՃQ?-ȃ܄[eA] )-2z&V@(l4n(|l7)Xy(16v\͍qU47]K3Z"J4)*AیbefAcL Zq >Ic&\ɿ*vA8aYjx/u
+Y\ UqYɚb} ~}cocqO˙b<m<2jhtsԏr6b5eéx UoTUW}{L՞ b饻a2}n&LGN18ܯ cpdy۰ڔũ0!Iq܎-pɎ AV_dM+H2'7O=Xr#p#Oy+=#
+wA.c9W,y#w(*z*~1]oSaC!9sq&X*76L-n.3 QTfaV3j MH381F(coxe@ox5*2wL2H_em;x ~l%8j!w?{wo7 r4|vWx{mw6;6c%=WZ~㙯A-O.t2gc=ozx7g>u0m3ڍ澱na̍, lNC"hfG"h-uNlZq{GИ3T+V 4vgg ې)1n4ġ@h$Dѐ$Lɰ }30lƐ8қ68t ɗ5mwjm ]T
+:z}\\~.lK05󖺳a7z_8{SjyV(`SkCJ/W6uV4vK,[_-lRny͵59: ]ӼļٚfucCkwUIi xNX~?nкF$;h >hʫidif}w_9Py]~r/Ap苝
+9oYlQyPɅɽ`SVWce+8ڽan?YV ع-oZuy4 e$+t,7'';i<%lRI6"*:kكdTZ"9hҨu<
+ ) :t?A['OMΩ |Vd=1HO kay1tdZ/`R/"g%a@&z1G~hffDE*vHaCG͈Gf6s\DUF͜VJhbY:N=
+Y1P6I1_ ըԼdvcΨ1w(} *Qc[NJ
+ C烯ƃ ώrQIA0^|nL+>Z*l? ˓p4h3BMs` <tjv ♐` ^bȸAY2^whd&ԓ~Є <0> s! ʽ
+2 roZF΃y٤*]BtpN♐w|ζܹ%hV l\7IOqggEyz׃ssinTI6^3á5: H~4tw]e죷B?H}=3;W|TVCUimP¾Tb]ڮsA地\ f[խÇI]"Mo|#?ّ%gץX& '+ *҂XvlvȜxZ IgMR6'/2T9eLNA:Qr#k;X&c[fA`,aus|y0FMHOL07ZJqrٱȵ u6>Iyᚁ#)j970/Pyp2#c^O=+fwv ԖF
+{m1i@^gjHZdm4RJhRp Sn(iWk v'ws-SWFG7J2w)7Iv})Z$EΨXkx hg)?q= }ِY/4sB|j 7LH>Q߀ # "
+ز1}<ڻuh<5>O#`:9`AlDG}Vs+F:3(_/Ԋ}h=~p,Kxj6~),Ż
+)\2ѻ9=eN.򧵋<`{x8Ǚ7ao⺋Άg\z
+EDƭK_HK?yMwǭx|+<ȯ,WBi?-kf~8A>/fv)^6qʍ9hE$Rv=C#l
+]+d-H߮emM M_=NYdyAF[?uę|7Tc]WkzWȍ!xT.EnBABH;drL2I&$p׾ݗO' A><37u=?p.AImv!*\s^ˉ`i~,d_Z$YRJMe2r
+1ӻleDԚཱྀ҈;{;s7::w8=?rޟl]ox'ouu{i2
+Goe/\[hB~
+Ǩ$F[#rޏSۑ[Dr) }1L+x'QZk]+Ly(2 ʧx ?_ղk}cހke#!ΑoHXV]A}7jvID{v^}y*Yֶf]?n\S_q%g?p4rHltԊ4N[_|Z}k;|?b8XbW\=.L|&5Lxk* MꭻV͗mlJXG`V<qxz<>1f|`^@tH?i_7=ȸWqf=xvKaAhc cqިCQc|gW>o,;~`ŧhBNKNܐO'%1 INH
+:.<Mm{Gh]X)({߳e'a B.̋]Ս -)L.1bk|МBact=<S}|?bn?:ZTﺻYrh~X@Wa:2!ߦh*%QoafQ!مT1<}س[|ӹK|]M]<IV|F۱Cȩ$5AO[3zӞ9>|qanښs#Y|M+u>u.w%"n[5GfXx>tI\`j+#8 ρ/p<8 ζ# qwqح4Ytei7c3g
+6 Wwbʊ /} "~s;7dbYSڂScf3v&sOF|tq}()LV7e5˓iaI͡ fiO隱8F6*t {D
+7Too"w4%
+^`e?<Ivq͡^KS}!iv@fQUj.:kTե=/6HvcfMkmaL†xge!c7 _|Lj
+ĔXv
+X\4NP,'lj\CC-qVv[c}bc:j"I
+H H9:@B !r#;{uc:i<g%˒qma|D^i̡uk;P;!eyg *pjj7c՛ &
+P\l)h~UQNAM^@ ̇,M<)~zƸp $CxSD0aD~
+w`|o.1v; 1#9Y;E+vLk`БbBP
+4v]*`[}Ip= '=$D*9B oJA"Q
+q?cd9*%l24'iΝ&t=
+Ch(+
+Z, n<7movOc 6+A3L}e'Wڕ zTan%3DȆȃ\T=_a_T鴋6->۵~Cc>IVL#&bƕ4~ z0ƗZU@: ]ZeŪR 1eهN+Uֻ&ZzgqApQcMR~];op@˙T(T7Q?;'_s͏j;oޫron3WM6دN^Ν<8tE0U9 92SX+MXZUSp4e(w'Yێ y'C,v2?x&ܲ`XNFX-̃yXAS"=ڶ鷭ySC$< y|:4?nR^ra ?( Qik}SW()$IY1TI[]K6(4G+߽lb)n+>@" 1Ltɜ3$T^g鵄8KJW%/i7skȆTgi 4:~Gƞ7GNe[l7x>fj,kyz鱫YkW$F,00|C95AEJNrE|/{Ķ52+s_[q@#!ݣs#:UµR:y|bY##^O5KKKhS>٬.u&C[VyWج:"}Y_5.GKaËdJd9ꞩs=1!#:u3ljےIhn5 L,}Vѻ>̨j.ܱi-&CV%w6FQ=GECF:,\·ή ~bު2Cnm&qjr˄\R߼[a'"_Oa'=^
+9՗&
+{K9rbsov;~ijdj>?^1&.JL|ne$oHMW>1YJ$YT`'5j|b5|L=?C7T5L9Q=ק-bCU6F2E kX;7p]'2eD{ӡK/1)T?GyyKVfs}^r ~}3ѫ~2w_IK:oHsO(
+ 
+qLva25؆֞Rh_-}&d-*=#}{S@Vf6h8QEBP3B:Їa1 5 2X RA 6<7Epp|Q(9 "3AfJ؀IIpDgd&GF`@cA42 iD|ȁm I6dB86"SK^Ck{͝w>7Lyt"¨T{Tw jiςZ>:{j*
+Q*\l]+۔yҷWjzpV~V}~3gèmy}zЛwkA>޵;sNAw׃x͇vٓ~#^ ۮs;}[{ g xuN.۳{$r(w+;bǪCT-)dqyO<xڳ
+ӌK9-dJ)#j8\4*KDy0ڢX5J3iA#0p4v-GcV J ɊkNTIV+̺^4.cQ E2հcu^:!YZrJ5-k3GL<]G|_u>ƾXWg}mV̛L|Ո?y fzB6)6ugWZK5ʴd.9MTF,E"qYĒ5_j(ȌN vf؂@F-c iluJĝcWKʼn[Ӓs2P_D;">r9&*,ۆZţқF83 {e`Cf28GvO&myV΂K j73mO^i)a='z QfXnd+:,$u5؈ه[0Z򀰝t.
+hh og9Wσہ0pMd>8'c:V"={zLq1{AG~_(裦`aP[m/+kn_^lW}}kpI[R p.kr`x_h. ڶ,ק^^#1c(<WD
+KwSX| '0k&\fdJ"+"dUȗ2vpq$5D&Y)G Q)f/l8WW)åw.i2hME~Z謔lj{[2B+KExё7]0hʮ-铞Ogo/(MΙGKcon(^6}T~%-|z1X'K _'T~5ߨ2WqvϖDH4gs WUY+}|Y.YL~L*g'L?fƱJ$(gK;Lف6Z:3Wخ&;"x,KNVh*.,(1L >;$
+X.Ck*:b Jûxt;/hE@-O
+>
+^fm_G֑Cx,LvY6˴UΊWxzֆZ3K413ˌ݄xY޶ oE Mh5Ny5 "˼(2lgt ۰Es"Fb,hg9`_zv9+qKjؐI 6wiPpl B|h!um"sͥ<bz,֬D:Y^ B CÜZU Ej9<3n0VH1R
+I+6m7\4>cZ FnT;ye%z6Kn )f@OvuY!;iޱ~<h. Vo"&'Y)bS4*-"gDQRJK4[FTчC@ P{{Ϙ> ]I6PxC5MuyQCvJnFwUcZziQt
+溌eZ_XZS"UAaW9~*}%1'"fn? fz F` x0`08 M1>!B} 4ߧ{Ox\
++bdl2jI$\tn3$IJl,HA۝qJl4(sϋЇ ໜ|8VjA/1JiF%qFvi+r%R&)pl> 9"gJYqH)c3Vߌl;kAn{n׍YERS" o~sVY'n>{#2/y5 )ዽ;РhM`fcx]Pt~5Zd_3μ?f*>o41LyT%oL]*`4:|)*
+aX%"Ylb5t#VV\7ώ1ٵ>> ~{=K.P/w'{-zQ>'ۻǃ]/wq߈ؽ>ك0χ5`&"@?y$F^ۄ.&des6ÄNXO77s؏v^hJe1A
+Z94"";zv+o0 "ÚT51+e6U(o<&/}n:QSE{04}cT?Gihg/s5򑷇xĉArrQX2EИgЏ* u]Rm~68jqN3mk)fAӦx=Q>f7S1ޒ4M36NtPk-}[ݝW{,7v}rSCþBf*b"|@ QHh4 r^"a%ȀĮ[bVܷ{Z;/lC
+tbaS8a3&Zx͂0Ћ[W9
+dBfAgGomǏSoNSw9]†;{psG
+
+=
+Hۖ
+v$p2gyeAGf̰svs3wfvf3C!ͅ
+#h K?Y<5`d=}9Sq5`Kb1.ݫsj84`(h<7lk2ӱfy@ `JۼZFNAY$
+z_8\f1|fq
+K32u +ISimg[y꿟*hH~g򚕕o$O;㥕öwOVDN۴n<仰" _uTwaWk^</Me=}E02w1 Ɨ6ھ5Es͙>D,Z_udC
+<!~z"tL]SUA7/02ygto'/n9{us, Kp3>2u|U"N GA(etC
+иC&T"$ĝ̱yބBؐ|<yvWGmcI6(d,A\SIi0.80ÒKjA.fb,gW<h^tl!ϸyɷ9|Wz.btE/8Z\q'XmH nA[B&7qSb.5/#﹤z?,:UIKXmxzG{
+}#t ̾k<:ؔ['\ۤzB y0܄-!\a? 20\L0GƋsb§sYAț!G5
+B>[#a]7&z>g-Fx^tȆȿJ6L3ҪT,9[(\R4 z؃yIoz'-!xb-qx3 jÒW5Aq+fȌy-svujA2gf'<ǜxymy9ΩϯQoG?U])%E'unAj牛O={0 =^K FmM*A<pQ{K혙1?TWR.A65_8aa-ê6똎ih˚/M|uU\?aK۝<sNuSz߽CeB_ս=uwzWMGDOn~-} "x̅AE6qO!E?gAҧDC5Z:1!*KTIa H ԏ9$l,g.1MxN2@wQѡa%9wHȺ/!OȾ)ེ*g1N1{dUDhxNvuq1" FooG@ 
+R
+
+fhږҰ>^[WsS^
+.ʔ@_bp]l2}>+ IЂ˶$bcqߚ0Pߟ}m)oǔA'F k8efzm 5Y9ZϦtWRK@v,jxG]/x̞w)v8~1t_Ok<y\J.l
+XA)',倥–?z€mJІ1Ȁ2ddy0d@,QQɃ+L޽aY-:n]L m3?2<jf w`e`e>XC
+>GW?Z0͌}6ҧlDUl^O0V*=:y[4dJH,{ᅩyTSW˪h
+$@H'$8NZg͜3ϽDpdzKsmZ6:ŠW{Y C\5Qg`*ή[ݕh-{[6dlS %_Z5v @ƴ#k_߳
+
+ kx $F,7wg}A/tVܛ-}Ӈlt6wu3I
+61|**" zzIm ڮK-w7اF."T3=^)iHT֣y:P_;[UZKI'3+4?ߜ?<}DjCcnPW(
+<˰ S}B6leW̟1 m
+SyXk0J/m$NuR3;ӿ
+Mw@ZGl/g ek9N+=zGտo;j+}+t6G:D;T#xNbVB'K (s4֏bpJi.摧}SW,9{wlYdwYqF[E
+m'|GuOvcmk_NѷSe|}YsOsxS*3nZ 9Ahyk9qkHKCI9$e A@s^{TTZoTг{HӬްw`Ł)Z :gT]P ] L1'0@BWEGk3}ФGxEA! r4ZFNRnl[!~̈́k[S\>FM L\]nUH
+gqJƐ
+C^Z|RuPǨ!W0.
+8X 8
+Sz/SZ kH3@Jo$II덴Wkܿ԰fv}a&>l94t&618h;NHIܤ[y*Eh&=94n'rZ_Mw bAPQ2jAeSE
+=fYYg8=}Ӿ^uonGb{0t]l;˰Fch^n6]-=F˧ &4WSfo{ {wXOOEuEI0u% nNbZ*x.r×\"=NdYC#_oe_зJ:#vCL
+0fACP_䐡YףuyU{Ex<Zͽj3"oDΚ0NWۗFȈG}IAO7g) `cL87_d Q?_~ss A}{ \_=CC($@#ߑ,pl[YweH?Ћ'ٜ,0gbi13.0!MY#H 3#@ζDlIM 2{;+S
+ @|eݑ͸mײi`w*SaK6ڴdQa6i`vMs7eï'!Vh3@Zr:&g@joa-`Z;S೥w$aPVW8QQQc *<f9+sbDSFZnibb(Vz|L=:3p^Л5P n]S&XJ, mH";ORq%;>BV32=hdp&Yj.97#\m>.Ng"lя!J.27? T|X[fiksқ9j>+w6ک i(
+o{y9{cyrA$Ns $/==M Wg'G\MQs j"o*Id|e7LKl"v.|ۙh@x0/vwWl1=b`=P%+pnnA0ԑDVx&~كEkdaBLHW9>]w9ϵ+:
+Q@&OUؠklTxTיe}v/#l*\D+f^eq=O.v8ڦ[\?j\:^7|ؗ?kܛmcJ}&4޷a[wC\
+u2vˇ>U cɵS1"B&M=%[7Feqǀ׭nyXqMY.w!&Vrv܎66ps:0 梌9n[+UH*mV| }2W|2<p); ?=ڮG]
+|^/_tqU4B'7u"^-O.:#$-R=<c~cCuDT])7O״jt!yv@Wl6\жn?_5רЛ~C)1%;m#(-GrwJGGn2WtόM?}gNGjj/sS%2)+{~V [ao7=7*#ǡ5J~Qоba$(L;V]#}!tr8]D ;p;AўAQ!!QIz0n53V[0f%8<D 7mܒx>5q
+#n!$!!wB•}$VnV/<2[ _sթ4%ݕ (4Lp<3; M 3NSoɴЈAn ,yYp\I y #en@r,,) .>IXȱIDICQI!E%~B LI'%.%Y ࠍ=%T_l2<4dHm˕۶Φ3Šo>#~!;'
+2!+wY,!ڹ
+utբi.g1"s\nG6fp<Ec5)sCCNctfS?;{6}M%Ÿrn,u< ^g
+4d{00UWu\)])¦ CI_$d7 ֜sxp1>ݹȝy>r'n,ޙX=͢;(rg pS
+UzMX=HQTu(Q?eM{γrC_kkE2wቲ|J^lmͿoqC~1<叿rPT$V-ZpϞдmhvzi?֪\4u,"7W9,Rr'VXI@S7Ze"Ӣk5>65{]&w7cqa+?uDB_.\zkEz}#L]osuY[ u\4k׺_֖w)_=k eRfR̭d诵>4f5= OІQkB<<.X<lvlv.ۆ}V:59Nr8.e|%fHhGpa>>,o0 U fA(iW.kF-YMbæysY?nd<EynG}WnehQֳFK:y3o^>Qwz 62^<j[-ۦЄzZ4Hg hNRת4snCCa \1f ݫt(y;FZ;ۤA4 at n1\2;~KO5|(hXdS ]ƀY::U
+UFm. ޼׼7|s+f8 iXKwlZ ב a=P:V:pVA/RT4˩N3ݚjum]3γzpgN|<*27zʛ?ԅ'촾*a}dՕ;Cc?+YR$0ͥQ1ʨy%z~)#倫EP߫Ajm}<_krͷws"ʞ`̽!뀯yRu!xv"Gm+:KDI=Vߕ1Ѝ~t~o1K}-j淞^w
+rL@!cK˃~I  mGKq)Xb16$DS
+"Epx? Ì܆ v,WXG4TC/CՆYupZ ^|8ƀMh`VS}eg*z\HZXxdH/"8+qDB@ֳsE]N-}uy 4)3[4AS5 ?2Xm Uw9n[~xQ@>8
+U_Lǹch̟z"f{Ч|mze7Ԭ `x,Y0Za΃L8? ( Y@QAX]TX>vݮV@@DQNEDH !vl;Ng:3N7<ț(}RW78J\ ώA ͇ tL s tޒj<|lpVՇ}؃u9DK_}ʘo5`Ě{_̉zv`]ߕz''Xn
+)Z+K'gcnBeǧL)Zե3'M=t'2ۈ衍My =/ukafXM4nF"uDCfLXW7~[;m{M ePj@Xw`[y[ڧ^Dyij,3ԃr+O&t8bw"<j曙9yuqU^Vsw8mNy1I,NΨ Y'z&Jv"N
+ߘD Аvh@?܂~F>A^"S zG>. Amjt-$و=?jB'[3 ;Hv4@vИh2 n/#ZI퓿Wjck)D97M$:lJѬ~B\a\p&ݷlL0#ՊUi&Zl=#Hc8T$ŨRr C*#K-GHV9Bҋ}^c]^^)ZJMSٯ #KR0$頸r[^.Ċ.
+0@G,[QCf&(jB!e3PIiȔ[BlmWD=9Yhm[xmmWUGJFɓbESG:D"t/RIUOXc'83C%MQ졧\8_4^|ΩBKDYK.6^]iY?r(b#:Ԅ‡ ckQK/~~=l!x !V
++2Ğs &4}B;M%v] ;|7&Y{>x|o
+g{nZl
+>&DZ02?24$EE |3ۙ2@Z.71 &z1$hm@<tj̢rqq vJEmI%!:$&]qԸLth47iHOJ 0@F~xC 3ؗ 2`;kap`Ax<3%}R'C3&o~IKT">mh͉χ3>*ϸxOcb|ٲ)>- ":,"4ktF4Bw~}\ߺemKC~(AA^]Nܷԏrㆍ :r 6L|6 `p1U쩑X*o fbp MBB<g̈8L90P=sghTayMGl̙#N}hVsIH T=X='-iV!g=ꠗKg:P|/QԾ}Sw+^K_mԚADt% }u}ȿML7x:*lo?p# Uκb[\qn㶀/Jnor3l,Y-|dˉ{pɅGuK{p|4& [*А[ߢіr4r*C'Zny#W0pN^5/re@{] Z u
+#v96,sNN>A^kz5qnLq43}5~9E4iqj39\g=pm{Pǩ%fO'
+P*fVg&L-1SUAf7Cک7ɤc[ϟ]堉o9 ׉>kcpѶo3Khv:NǮoԴnҐನ^x+J["r6#]ؠ6^QfX++cJdKE CxɺϪM︵=6Jo犨C7 ³;p:*8+z%օڵiI) 'KV 0vgomͯ/Ƿ~6\&U wsAإm @<tB\Ծ1b^\[(e`V sCԳ\z*0N_@6zMȥ+ane\uqȄzx,!G甀c&\4  +7Z0|H"hvgm.@JV @JT[rv`Ofi4YmŠ0g/(w4~Pz5S$jݹQ@X&-ە]vfCuRu^rb&LƾQav
+ ftݚR@#%gMhRHdlɌfũȅhnhIK<lXs֜)Qiۣ#mMM9idlh̨=S͙M qM4 >.~ɛ{qkb-yᚂOײA֌rukFJlgʹ._e2!' } /N^P
+ 'fZMh~L 0&:6# D"D.D7Y
+#
+$CfXqk/ZFm_}.cAo《ZTI vF$`E.6hGY7ցѫ;
+Ԉ3Xxr" l@ };!!tNB¢θ3cVM ۾nPao;_tytAoY-ۑףHC5b=u?u7N<g[+:+߾Ijtb
+!cN5 ,p'Zd3z{yiۇf'E&FsJ\\]؄gcѣ M!ۨ]>g%OR,qj6RjJI~D{1Ӊ$Fb|XBO1U1Lp)B~wSڕPnVBأ(5u[0*6Gݢ0L]aRu1f(:}:E[ʭâؘkzSj`r4ն5Տ6LR"0^3v (-몦[{s9 *oStc+뙢ڵA v9 BH~`vApAnܷ|p#x[p0
+ri|zb?x9߶6-Jؓ @ _"K$56'yDzAvjN'傜qrNrar@^j6QJ:2AFR.HOqg O͗7tcZTHI1 .>H<#DDŽ!aI  1(hdQapvuH ?&^C }~RF=DpO=Dp
+# <C@@?(A_"-.V
+7cUYYV 7|ksAmz*8hE4}쏀^~3,;KaV(ںq_%Ӿg7l[}wÈoC1f;90V;g
+~W~xO֒񃶟u[/ =XMFΒޙpkx0Ηo,X3z
+-4GiƿWӤ,Y;$r!fx5AU6{y+E
+gkc.h LfXKfV0|j :]p#6{Ti|ihqڴ*QG5F(۽`@uBI [Ufϥ&]KgO^/&^vz <ӿ*9iGs4}Tons}lэ
+ @V0lPf5t(if"6q(ÃX\dh]NX \lfyvg0Yvs."9hF4(!5 儁UӾڠhwܵ˸@a4C౫.|ɩyzkj(2'cL;#6AlDCdӃ1Lm|ۈM1,rd,#ϰ&ʫewoVۗjTGo\H,{PO {
+zE8sx+bss\Ik_ 4 >)oklw'
+";r!#!Y7Rbs 9!D@
+nL8y
+i
+<T ̀XJ:PR!r
+؇ !xym hBJLڋTRqU2_- QwRAYܚR45<9?)/L0.L)JX,7О'HER7byT2o}?s{JCm%3z'wOG?R$) ^dVͽ@VIxSДOCC,XgiI)TL_ZzsOPEuOwr$g]`_0 ~]iFO p>1?Kp͵oD=rɕMG'Ô&;OwӚyiیy
+xz-{ķxM̗?*:r;ۯ9ʩ}.6I&ݐ V{Һlh[ſsUrkEQЮoyl5A5yIj~jlB {̅};?tb1lKUT ׬b3Ut<+p&{Ŗbyh,1}%عdiJʋ3__w D&_ʎ ҺE+{>#gMSNtJ dFFA_Yk\jTnZo-E
+YE9h>q V2MQ"{Lg8riq(˘m2u$zU٘z$kRZ+S:cR[?L&? gZ &fD}sA:gǼ"ʂQ6c1YFx#7!j VZc૸ze4&QE۫b8f4fYkgQ_nStOWX
+y4(mKmJ}< ٴ{'|J~8Pޖ$t=}~1M7Xa`P4Qӟe%gٺVcXm>sL.iwzN)1t&1R+>nՉobC*HӴ^(ioLX3\c]*KTKg~<(}rncM;ꛍ~_S[?#rp4
+  qa`֋d@T!4 K(r
+JD"pRJH<PmhH2.8\,䪏F :
+endstream endobj 45 0 obj <</Length 56425/Filter[/FlateDecode]>>stream
+HSSYOv0. ("8.K봂ce4:2*B@ d_ Z.]ewuO|u/fV{ι{ջD$D*I$r2:'1&l'PH`~bdH G
+
+IG[㜜sV_g朳>677^{~ 2ފ;^זj}p~Rt;ĕ3k2H.]* b^8
+H4Jh
+w$t}GAx83 !75;=q:
+7r139K욇?ΞY~耏g9N3ܠk(}K.[h>V v?ܡtv1t̖]6u+G0<=+_ i*G*ǚf4m{p&q{JR-BI71ObzħG\GM
+zoPp=oK͐r30g { Cȃmy
+"iTX$%&Cz\){0}?*/8):
+G?/cQT
+aOna,@ϵ
+@Az>ܒ 99 akVHM$Zm=2h(hg^
+KH.\MMZ3 Ă%|lCX-J2v,THu幑Aұ^1d rEx6]ַ e<y
+sJ"2/kֿU?zY\2[t;71f~;UKn<߶ijՎP3Nν^n&,/Qߡ^Axjn4rMq$Vys^`zᰣDeq_[!e{{";o|}ZlI7ևH[YEM-3A M~[a@ZϮHA?+𕵛ںV6 raJt5Bʍia\=
+j5+VY^W-갔sFMl}Qb@i◀0k7!U"C!O
+b8$ Aar1(H`a%P_b@zy RcRa@JL"ȈMD}v7I 9"ё= ΆB#Gqtx#q(GbaN|bBAdpо/Ga}A
+6P qQi `%!+IHȾC@uکYj S55so"=S3Wsn֩{|Sѳ =!E$|QkP
+!@E3d15\~bfD︽^gkw5K)&hy`c]I&W(a?U;7boV\asN^-wJh2j?m='sO j=I{vvJ;6oLK4ww\ J?V<Y1'Qo"k$#?s{}$*w*WT|7Aԁ.GBӆCd571mEḭI<$1nC h6Q8MsM;۹ijgٔC#jc?X }14)1Z% hK,ykR:~I>_~/h# ;u-VYG4w nRV IH!T>U=,ǚjO=)0F.6Õ%Le(zh]-Z2Qt-5J!EHݻ|zrM 0iG|DmvZ]QTLO{V<ZY7O$Ӳ<1L@JQcIoL+1t1jm<*W{-Z5l4l+U?B<]޷7~Je-Yl'i*{lSY+o+W2tMٳ1gwDiCkDů'ޥ4ةFuRmH.ěȪnץ$1kď <R<z.yd0
+0{89J5i:|j]g['5:zd&C͹0xaDK{̮Sz^ ]h:!{O
+Z`jN9\ʬJfe AYVr*
+rny 輲(!9[7LM~g~Ԕ b=_7/Tښp W!+9pW4'Y/|FAaj1Ml  .%r?"AlĎYIHadrj '!#!R#!5 )ѩEcqK }֥kR3{ QwC@W vA29CmDT!@6ĕ AE4^Bֿ\j:8'Ej1.&';;̖5j*E*ӽjKw~6\řڲPГdտɚصMƓP-tg߭X4d' ` (h$+[']:̐MzY
+!rnmyP웿WꛛV퍀y.
+& 1w*CXj;sr¢x[;0_b N&,Jh0p}L:9'">e'Ã٪g}{m62>r3OG|fň5VpQ\&/S muԏ#VD>nWݚ=y1"hR~A9d
+=]#(|ZS:nԪN֩n 970Q tՄ;/w'j+}haUн@1Q$cpXˣuEQ'Y.'i|j2O&{nQ<2D=Vn%/L5)fSw,
+v JYӛf9>J4-@2"Fa g4=z#R4#G;xU/t^5 z7Glk3 ;`iY3`eٰfuH6dbiRi=bj j): %=XTqx&)7h_tdO˾ֺ/:4EJ J-AdzB3RxE!y'[k)ӀnTRdJ&iђ>V^І3LI~?K,kzRQu>"AkY.PОIiV;MHJڎ pxG8/~ord;n2^lg,v}ݿ3ah툏۹O#"#AX
+94)&>8| v`Ȇp{ =wQ
+ֱ98(' QNsqp44 x \$t 8w
+% C6LsȉAKnӤ~ߛgwjsܩQvzQ}>*  q:Kfl5vʏ FmsF8":bUvl{o^6ݸ5{lL\&jLrc9k>Vd
+9EJno|:#5qp"ׄJ閫NdeGgsvf^Z,С05hi^P~cy \!OjDn$3.hBjwoioZ4?6O|z3D[Amm73fȅI?gSmF0)ԋ̩AGD)M=y(+P
+;ʈ{)]rщ
+*@a2T
+P%IeXro”B@9 BHQ #
+\~:6Ό.
+@Ba/0N(4]؁@ ^8|ٓ!#F9~^0)fCdSO8Ȏ>#'"zq %m;m”W $iےi0_
++"9֑ t`l<5~Ơ2xu.|)i#tdCblkjum<q<KYzz+T e\e #gEz}eh>_+O׬{W^A6roYlݞg9{2O#GY;ǵFqx_`me>0 mIrϸCubA1dCd38B[4SuٰZ'4sgVY yM+7#uw7.WԒyߛ/HCBInC)U=K){YIu޲7Wǧ5n[>ȧ7=b
+殉d<̅*{ʺ,螰fNj=kQljv/g챃>V$\\en0ntf~sVaΪV4-ڝ\.mf!]n`~.X񖽰zRw^i^w+cÐ׮
+(Hp&44 R> 'CrJp%޳Ovky^bӭ-Un}XѳQEǞƒ7n(}^Isz P]pJZJ#fA=K3)N=p3wލ̻%
+ř57^Z-FEp´k]1CA]wt RP] V2PUJH9t\I %,DJ CGAW" HS{Sdptt8ƒ~L › ȱҩ<;--t6fui xw=d$\.ˀ|&z0\J̃lMLYa.b4-gRHKG|l
+H8>* gBB%<u,vqr3_P;7ad܅PHU?Q&T]<97/ es {m^#VYuǙN!Fቼ _<?VDȍW"QDm#y:d@iyI?{4ěG Bb뛖,ntgԣk v:+esTG[[3W(ksz]ϡ{Jiz$s8\9r
+:+i؉Tg`lہq1m6q"x'sR?Χ=y15Ǟyߙ
+v=IQ C?sI\IYm-uUTMMVY{qMKbε(},e9#S e2%v66oxUi}߮\cgy ui5n{}U+W||@]th@aIpv;a},Yjukw2Ce1~vn.o䋢\" d̕^~BֽAzl0K.a Zp3X*f@M7<r;/ny% sCnpxj4Xcz"Ӄ=+3gˆ:>báՇ
+4Y\oЍXA~EX[dIs[B+/J\AV
+:^טCH>:ʉ
+荔}vR FU:Y]_JňzRZ⛔&?W+אNh|UI/r |~$8/
+#Ƥ
+爪ɔ<g6q hp ]
+AVa  K8Nπr2܄uNҚ sR=*(yP1 z[dehT]7sHݳ^2(\WnqI{+rV+dtlYPSY@pnuA=,*$ Bؗd!N’$d%ެ@Q陧)ajjjqi =ݓ}wnT~<O~CF(Xӳ%GI({];GYH[6 C"3GTm\.{|$ z#/
+D~@GiMژeG} 8C1-D5G^sCh-9+B04֞4n ;9ʵJE`b(rwOHߔਭ}!w0c|zOWIg`^:& ߚ_όCf?{`א8?
+KĎSx`tY=dZ7~;:E&wFn9w+6Kxp <sD 1JUp|
+4K\6ȹx L euHvW4U>G(l*x[q Wqw?w
+`)ά+@qx /K%fm]Ȍդ\`ZbOXUڧ
+殐XEz+>0CAܩo`< QAxp.4MZ ij pE%M|C%~edhKi 5Ȉ831d%y
+׮B[fzMgs t )xOu`̇ ~0KPobc |T
+ϸvj<PAYG'd ̄4[IЎӂM)\nRsrbD zg?-d vݿ3D( [BQ#M)dJRAEd1ۻ0,Q=aK;yi\3JbM/Hi"Tf\'R(+鸙{z=LN
+fBD&Bg,ۈ*%hᒠi%k1۸$25o3MWPgeAnZ\wˈľZznh#!܄x`c޳2O ]+_$NUV[|-wDEA'AGAcQaT_oy\i+PŜsk3q= T2!ow3s`}ڏ+_3SP"Duڸ[.+<5nam*ͼU$7}k
+[ם6Gef\:óQj+,-$֎ٕ :܂LfY90R84];uַesyeؚEFcJFՋw{jG&K(0I&YU"<3qqf)ʦ@xb[nvpTsf,8|jiD*$#NL8w
+$&4.ť (<Qm׀o z|=6P5Œ)Go<mƠ`q؝@KVTcay՘ۏ+5oB}sR7|NiANNq%#WP+4VP=[UI)*G%EpdrJI Xb%*2Ũɹc *&J:bl4")'14jξ+ch L9oߗ5=џ'gƆFي1MSfr%,aPSϱZ|XGU-Џ핏t=ƅ>mGjh9HzR.mE;0u9eЗE"
+R3@bO\<O<dbT<H.mz5:Ȉ0o\ }x |HJI;M6x&A~
+>DVw_BS`OLGUޞ8.[F#3
+:>A`9w>tXȈ砽6DB6 1bGB6&ltranvGuCwotߦc@
+$.[ki~!?xAt4Thls_Ki[jwBǃ?:8o>/y% Z\KߡkH.0?U6N6χ_r'~Ԕ1VW1^Z>m#@lN &UnrComư[]kD6nq>E3~+<VNODvۄ[ K{V 8GeƯq9+}֕S5yț+2i P5eD^Uȋˊ-;Uyܖ߃;8qAgǨFk!+Y~Cn:v2Ӣ¾ r%uZ- w$Uvۥv)xM4ĹRi놑ѪpI(K\Bv֯zRӚg<l( A2 C)s"i,6ș6p&s1!6{`7GV~*kc1a^ $Ml.>̨sZ=#;Bݸ(/< b,IgKtQ%#L_XiFk]RORlO$Ga9l,\2:}zQ\rݩ[uS6d?\L)ӣ1~˜d0t/pEЪ"xBb_VmGؚ91yZpٗSl֢K'<dq(Y-e*qmSdR/p-A+_ӏJlbrWQXY؛@BI)C)Ԗo
+H!,!BHn䒛}B A6A=3zN9=3@?"vs{.:$T|"Qc,x4uZ;ʯx%~~[>^v6ԑ> -M/wJByoIf>O`h8-d\VhK 8W}.~d?xއÅђނ_B? ȌahxȦB
+]* %)?}!c9-_JWp  l9:~xյRz$EQ'@\d4HNLWJ`K^I㍌ I`AMSёk8dc#cTF:6S 1(clHGy]=ôm{Vm.DłԨT=wd 3)KRwK c/<pTH
+J
+)!t/ p\Јh2m- RU^)Vj\\%
+X!ʡp =#Z
+q~ JU 14 ):J*nUXj:.|\UKЂ$ Q", I
+0I1Q އsD\v(iBϺ
+(q I@9v=K:$cc@#d'R=^v퓊T {V."a*eKx 9Ot 3}4
+3(r̾Dk,7xgP,26+v;yز^r|>Rٸ p9@ .g Y2<
+H\
+y>c+ oH$Oש- z2>ס9ĩ!,a65q?11O½KZӢ02?4>PMeV҇EPOMzDʚeF5Z[~7_"MB8ߎwrfǛq%-ggs79AW1=͐a)# (IϮg^-x"A\GգqG1:&ms9?;\ћk?hdmi݁{_0tǀ<pl`}=Hww~[,huSvԆ(r(r܏m(I&X{
+8Fh^ƃ3Y@SWl3 $3҅TiutU0ŚaÖ꟩ik_<{8N4{~ŴabnѢk= + M{4GL<U3=__afB"6[XK6)ޱWů+ཿ-AR>-d.(LR5?ܤ:4WiLs&XkhW2;
+M0gJ_Ɵ(+xwl8`SmcB9 `lPAKNŒEyFӯ튑 |> SBfv3WKIsz؁-`D8wG6Z߀/EZn:zV[y41jbuQ&'mE%!}խ8 bL cԱ6ڗ2moFܔڌ:;8wtN=r"FKGi&M= Eg84BCN-03SKNd`Q`|yg9t>ڢOs?8hg0]5Xd!53 ܨMB*APs6|oR?6Oݼ(n냝vl#Aim RpYY!tZ8H[qJ+%X]vi9IlX,H"7|r[ k-gGw
+{bwQTR^ kbY$S!i*Lːiҝ
+P*_EHpS*}-`<9CxUU g;nf'X{:%Ο<sN&;<8},^$t'HHe ʡ.x<6b ZNBi|5 YTFdȉ h25KD&1\hF pz# EüLݡȆ5~ T&MI>t^raJ1MX@iMPV )_S,'x52z2S\5~rMAP<Y Yp3QɉUip0\ͷȃE+Rո3`-nZ9a'=j?iVOsIp~lb$$ztpz7ܘdiS̀L('ݺYX\(X1q{t=EP0Fr4A'wJgWy|Ov,vs,dwLl;AC%.*Hw= ۨ:8Pq{A;"p]_9۰(hðpe
+OkwK'<͠y\pWOR +V8vE7t-NS;?jLjk\r4U￾nh&)o+<}Oo=M_nxLֻ6
+myY6^e6zLmәcoD^Mc9廱4|hfD{>.^)+gp3d>axΡa}}rA*z>+3nO7lh,:̹_ygzzSйWngWms[zgI'2!l>tK,Nc7L6h-ic4pfz6U\_9u Z"GQy t_a1E<^""cMҽ 2Qk171}}*R|#rɪ⟉ۿ$)lNJ% ( URa2k b@ |Ʊj$B]kh=~O;Nu Vɉ=˒U2XZV..4&C;q;s桡Pͥ7.U5U}w}=o$F*D5I3mjx39-f~ R@Α(`9YTj: <JXYƽfMϭ
+lQU!"B%p`(!p|tևW僣
+r%"QAPD@BHHr4IH
+KV0V*R
+,'y,J*o9QS@AJO}8LPq/"}惁莚 dBtF:  sO·@Q={p4f(( Vs i:nZLp2F~I܉>32e{"ZQ?4(7!ȍ6G1>LL/&[i ϭ\tY'ӡ폣}B5`PՍ[uW L^8U"SW៾hFdWmk^/Tb^1G;U}X+?^MFMKs:%h)>TCG%}O
+-m{3 f̳ttijOTxXٰ䁻mӻbgykocՆX"o971PV4??`Wx;&ﮒ~lts'ooZD b `1+-yɬʰNڦ.*y1;8^Xehhڽ09ќh4n_-2y6z.p3.' M=ÜehAU.]OXYr^+\&pWǽEc\¦qpCuRc5j׸zƽ͔5 53G$޸ce`\U:ܒ)w0_-}s6KI[HP.PU8[>, ӂ#QuՔi_̴VKQ/Gg<..
+nqɫ_[:Vk9\A]B*l {@ڐs J3ðk>/nԷ
+#uM4ow`nK괹5:d6NS,TFo[I Mw× F U;u7X[VmySjr+gn|>ٷ WdpK>M'n+q}A͓4<V,afن>5sY1[\6Ĩ;9l'zϞuU*ۥ6 88K_3]0:G f4㑹B0Os}ک| Nbk]
+';2ֱ{[{_MjO듶6;eAsz}Dڶ/nYʶP.rʡ(PG{5x7l.ٽ= wG#f
+*bNru9Kp-&S%<wC "qHx<q'7rؐS 64ğ< (''+i^+𠭣6w>\${$H 8
+.1!lH08u[*G:Sߙ|vH/#} N~^ ,$Dpg<aQ/
+:H 8h+C~H o Sv9+o9Ho [DuO!lCS,I&.^q1|&KO
+1 [ټBl/TC:GU„qniLeXYWzYAudT,y.wV]T$˟kahR3͓W\"/ۈ¨G8T4
+rhlGoԿ͟lM.K2Mst(pS=Gg,ݙYyUz3EIާv2CK޲vSn/úiٮAKu]AMdyC.P@T@+Dn`%!$ӹO ! $ gTYufjښݭcf_3U[|u~{ yaǭ!?A0K+#[d NGYWh
++%]^ک~j=VwEBVd x[C=LQzngrTX˜&sQ9Zl/naC"LI׹'Yb;}wdƍE7/ ^VZ7sMs'$&,cBb 0HeI9Ғâ6W|'lEt= d@kpF}Bx^lx Ąp?Owqw_O'<>n$rȖpQ1uB:9;BÁNxHpx7xxAo<rk
+^Sp."Rr 3r.X\+/";? s =\ɪ8LZu ˀt'[qq2.oxL(CpF&n4H "EV Ja+ruB-|(TʦdtT\Be/?HrO!ߗUREMh?q5>
+Q
+%~W.dRЎ'%2*)6V8KF9".#
+ 8YrdH*<S!u6ƀ㋾BWeӫCnt+‡ U}4>ڗe@Bp0$@
+@t;TzD#lGxt
+aAWwtz
+*/ "PACJ)$@I;y޼ @A!"
+.Uwulgvwvgv:9{?gɽ~wNjNrfy,wA5qӬ\jvOUUH-L92~n  7qoe,e)4L{"֪5 kf <D]ﰴ +:J^<zuC[uV3l&ϱ݂vFJ,7M5.@
+G#Cji T{Fr4ܻ2+Ą(o7*("ҩ
+tLAn!ѩS6n+']UAcF) RKa wElM<}ӟyz}NڶyU<h-py"LTr9szh{N ǎaǡ<Z9l;.¾H${w<O&؟x
+‚ABD$ "Aĉ8 "ρS!D1< BOcAt#`^%}^g\/
+d'倬 kWbhGrIB$GXrJ,-WcZJ
+J!WȰJ&.FJ`Tumcl ( /9eK<PO.uT@ʺ*2M5PJI|R&B!P+L"u%j\PTdp ИZ#l@.TDKAZ%LgfF\@ϔYȿJ*2@RƑlE7,vTO)|P쒫;7[,fӲ 7f; ʹδ~=ynq9٣!->kA쑣 >0<
+}NޘF/|<z7S( 'U;}>.K;=N_V|2{Ώƛ"w"Ņ9nߦEnԲCe݌/$qs΃IZx;` vS=o3w; ΄`"< ě
+9
+ٶY35.gw~Sgo}S',4Zs<^oMd@W::Sk\0j>ί">Y4S@ :PU7Qi [f Cz1s|?RawE œ|ђbnmIxqԾٰBk'~GEp ʷwfo2w'W<[b_eq_6?V]Tۋ%oed;ӠSz,2sHN"+2"egٗY n1V|GC1Vnݛ.δAFy-ͺkª7=7#cGR(5t%QKQ~uD0*r̀ǂX'(r " rrIwE:$JH8B"78{Y;USlzݯ߫痿$dĕŠ:%g+7q$vsXWAoKL/=uG-LZ83ə A^v% GXXm V q9X:8٪a,mIZRǭ2 Vl)4e&kLmlۆ27/_OVo:P9㰵MeuaxrBMeUdn"svtS=9m]DsU\WK":^179-k 9 $]8t]_
+VPsr儨>jo?aqfIЎa 6BaKgOTCy>km($pznJ? S7<5XS6IQWܜNJk4OP+Dfo{w_Nr. pGdCy}q|YK- t<_ŽAAQ) j>n ^#T8-G~<Ӽב;0 EHxHy*4۝?9}})}6y!th6;G(^8ts,\Ephꑣ|"`NC <hA]Pl"ǜA p82. !! ,4 Q}`lA"fT*Q`DR-WwJt44NA1Oʕu sˬ7'BzgJj"puAiGyI.kB5|%iЁ y4`Ruǡm[Te2[03)tz}'Dդp\+p\#3! q)hJu2H4b3!B
+(?W+kȵ DUfƈr*\X*||d2~. ~z5>o8t ( &:ݥt⚧eqɥE+#eUYž{Ok!]Ә=\єu(Il?zʼu⾫82"8ir?\i6!FWqP~&ᎦTB:+1Pa_(?C2HתYh:AsP{Eͺ+"ɑJy2@*
+&$mT),zqˬլFӚQoZ73;3)β:C\ɹeKE =|6_SPzbr~(A<&!H.-kI4bL
+薙ZI&t]grUJֶ gЪ]BiS>ڷ~=%WL44q)9T6:ESSɲ4kqdsܱP8۽YavBBw%', k JER"@хLp1 iOAZ)8 u*
+4ڿv]zeϥ|,ZXYFr>6,҈[l%UW.q淟:{/x&C'CR_&^cJ8?RQ 0@`~B-m)B{ J@w1gd&;i='o=^ӃE+ǖ},] g;X#um,M̥shl!S<s6ڧ@a#OE_GrVja!ߴ~5 4r=k=MIWե<o(ps-gJk 'E<qO>t
+f?$~,N
+ ▮~1QhrsesNn!M | Hw0yMbwXqNI!ވBT6%b(v[k@p>
+u\{HJTdA5.J,`m<mEظ-{0iTbȇYڔ<LʄD`#4@\jT"]R
+?Ԅ2B,&DK"f)B)*eӒ|FJSpع*V&U
+R] WTR9
+
+cڌ p#<JS1֡3ļL' 9CҘH+@n<r SyGu8Ǚ*s]l $C
+UPkK=Sٯs
+sk`UN Mk84k3_PCTa vTRKJʹf@3k uG6kMPX&$ue;;I-{˦﨡Omg_j÷8R%w¯C<AG)TGB{vtf:: *d5#}#3$8CZÏC1āL@+;ǐB"ʒO"C̈x
+>u O|._ɉh!y^8tsn
+UsiTzx-[u$an!~,7@|k.Xr9ϛi?|g Uhيv>_oI6DW2aM/wіﳌu_!d 4YH+}Dd%}ͱN/L|c[Ϸe7F.}+*?mg|۷XC3d֋2-\uJ>Rs?2.q'AOz#12h]r e}l߂5~Nї
+-jIbc4u?%ȫZOL<Eovݩfvۍ\yhK8_pl0[1qZxY%m~.稣6 = ^y1I`%=Kiɉ= о.jP00Α~(P JUGl/C{yvJ唰<cizlZ?m.IĦWxi!TM—2T1EzHޠ7+f?)Ty5URs[V{#_b#P.
+Ɩ:OI,qBk]׬T3b^kaߩxlD؆xF4Qt#(f ̻TL<P"@n/h'hBFГ&:Bi'DF Wx\9`T ['KE r%Q!`djY5LY/oWsxSNc!&=Wb LǪre !3D%b B1Sy -,\2BaJ(>n(<nWp̪#3,g+602݁ה<^潈/>j)vᜲT݄Q@B1&3Il7YtT,2 S)I"I"s)(!u*OJ`Pl:!ǙNe f2|5wށ3p}
+mo זo<Daٴv5
+\)lqF #|L
+эU·vںjfء[ox3Wz^ϫMwZ]>_2On/&7'[99coq?` {e}}N[isYm1QpQ{m7"Օf|W1}t;ROǽ +)]woC46"yEO}j+7A|;)0qu`(_{RX2{>H:VQfkR@v tKђF\,e&XJ?k vaIܝ
+MX/kYWa'<A(P'6'E+%8ʒCUO^Ө!T,e3ItdkYlq]b.0zȲP_6[ސG;,كMsXx"^`COPci{S݂0t>eUhcļU/DS>`$]6M|ڻo;bP =^
+E
+.IgB{Z?5xHbVN|rON{|vv:Zq=!9q:b#_9
+p h8"ZIqSw/Ԩeîԉ}\cbw_}3fU&UcTZ3uGUd
+؆H.{d+[EIvny [bn8&2ivb=ƛrTwI! L="|
+BxX{. Cܞ\jAvDHC̞+r:
+X' faȢ{"ȼp".a B@~ZH$,>pex _dJ$vG̷ 'r3XoYm^ј͏ՓvX6*W//)F5vIO+T I1,9/G"NgȠlB^$*Y%P.9Y64] ZٲfgywQ8_L۸3=ψK3w@uu+Yw3ּY0bOyиߞPT.Dn)Ts
+8RˋhP\󾠝:sy@;w4f3FϾ -p-8gu!<pB=<Ks5
+g£ WM+ewKF|^i8U3ƲgvjxiCZKy
+78a~p}nb9GIEv\#kgxo޸?*O-eKzڬrciJ8gV?!*|vc6>!O,uw^|sN1PMVmpo"BI\kh||},? %99?1=?(}U7ZJ|L֓hoH16h>ݓNiqg=
+`D xDftBFpsxwA8ߩWj5K~XA眘JcrX/ײA͢
+3zNZiDqqyPx5f
+в<)n)6%t^j*H?"@b '[ER
+@*~ -n%\9Zr
+gΐ$ I$4`X \a36|`|>|_@l2U *UUm[RVJ+uvfO'<~I>rd<"@z+[aφ(:1 /% ] Miev)@?*,R|3m,
+ Wr5CV?R}%.tsJ&ͱLrx*T$.#xsO2 #@A =܀~0lAc,h{ć?28o/O>0F/
+,gЁ+UŲuEY홬W#d]k澱,uP.uT5a:/zYy/ \od հwW"()=yЁgV|Aq2 3f+NftwA#T{:LSpv+}'ӃKDl r<LuVc?g<ˣ͟20C
+cs G-.Eר]>]bGǒG(dz:YaD||ϡc9>J 3psnsuvOy
+|
+7πxP7>3\=HB|iAbt<1bS@r2d/hÓ zE[ջ <l]YWCs>sln`cEBfD4ߊ J2
+,'ΓgZU#X̭/tJ9Dwjw2` ݅ͶπVu1\?".k
+r
+p)79` !I49p
+ Pk0[ZXyY6ϰ fN SZ&78Z
+ѩӿivŴk!.\JM''-lل'ijs :;4+vH=Z%Ysͯc5qKmX4)\q3n{zҭ oFVyKu([;Z`18l;as7, uef 7 ;[mfisqVimo6; o7MjFI:ސDQW7D~?+ni0i1
+˶M=ʪIW^8_G6Uݲ-35-?!Ԍ@9U߮+|i;>'iA"*UGAyGgwŢFCÒe?h̏Z7L㠳4젙f]2Ryxu3uYUt8LC/o,~ USv$iR6-\wx( `l/){nϾ*u;k)T'd/N
+ CVEհSH~`ya0^&-%z3k[K$qڳ2ߜ"1? г-ѹ$ lq!l7hBmgHSFi>I0sD% ȑXj8E~)UD{~$Z~7Q}sWR#[ǐOi)k~JU6aUhFI.H?t /Bcz}-5`[w.9%'/vcǁAMu\LO8 2nyGvωQi\Bz<g4Axie,LC /fY.Y4QoNt'{Pt{1(4N )58EXOYk7,^sWq!h=W⵵2րڛ"aq܊#mƫ#dQ<>KE3p 0K2SdeR'Z >xCx{y^@>o0avwt=:솮96>'j]}:+u޳
+= r?g ^~(rM!P2E"^30X4[Dl1$@"v-ne<=S9(cOh:O3E.o{SNavOC3MN`dd};O[ˍ-R}*WKtHU4|=S:RV6zc<x3[ T n)~z*!GtO f=n(!e5sO~NޢZg`vMv S[̵RgRښ<?ѝXtJAYcuh(I6/LD6p8A9l̑p@t2Y"Vm)n:V:6g_,zN(_{zrStt p)1~PxZSqhMw#ps_el3{S9Dʣ;=CTG_2WؘeC_9dYdX+!i0s!֐r=>&ok3ypjN#>-wRq$y UdiPW/a9qgϠӷye̝[ʝMvsoJ_VwlJtZîX9^( 5ئ`zN}05|>ӢqFޚl1 o`^<䬫ƹ=z_%h tT]#Y6jdvwkܯSY"OڦNVuA<X_Xziد7}17U0_t}?r?d놜m/U~o0itcNPFɪSÆq4ҨҿIM LŎ4]#ͣ}ﺴi:*惞TR2Vp-cI|[vZJ/7\fUQIA{
+nN6.t
+i?" ?fi
+>.>ȃXnquod'!/
+2Zȫ}jrJ̚T]eci>lV0^L4фyP!aOv5f
+KUj)T1"ErdXRHZ9dT!E\J1 JZ!1I4\Z Q
+ú EbY Q$ii SKy1jn="꼡]hyZ瑓Ch.
+dT հXGͷX'ozK6&ìm/,[
+~sxr|raMaֹi4
+˧ehN9;\]ݵ(aDS6\c:lPc[3Ĺ:dˋ+B׬K:?M1bZ8fCۖcF̜.R]:})kb 2ᄋ0:Xs|olkS[^k0y+,L4p¶?|dޚOm̋_G[迓9_:7V;!GwӍ?[հnGߘ+O:4+I7v!)0NfeoO?\|t*"ԅ1gVkϿAg7hMt9:Y~kDi# 4EI0vG(XOz?J,nx~ۂ?)?ky;m+kwU#%*x&M+ *QB 2Ǟ-<dTRqOn<
+\<bBA+!g0R)Y/s~@vO }kEEJ
+< p}GO}Ct~
+@A^e`f^V>shЎJQ3XF,`V5թQPŘ,E.du#SF^j>/}R]yoOp
+ݡJ1f/o(0.yd
+>?d$>6eEz3@'?_p,q\ 5]BtrxzuL)/2l\1FSgZXB&;7*fh?g0R1ә ;:Ұ93o00$ֆ1hm4'EӦK;ӥMk_eXǫ ?t[:ݕ"-_E4Fqw^}=⬷irkiס]h)i,o#}YW |>k7D=x:j:
+ҚÙ&R<4m} Q&E:IH6!B *JFD4VRӪ +'@TP~-hM#N0קL NǤ/̦Y͘4Z4U a֠C&$R<GPin&$\gYH׏0*dbXU*IZ"+|@$TKuTBݠP(;lS" D
+QP%EPn:(<{ᰓd@#gP6/Y8_F9I>)& ݗ_Th:2z2;
+}T"?
+GCW.7|\eÀҌЂud|F%_w*_~/i҈1;V0cY]ɏ-=M-=mHYU8.؟ua}G}#&⹘x`)'I͖d`)L1A[%)jE ?n# 摕1{X&< :[7*R KuKǴrGSJ81|
+Ү\GqAv%`<#+CE]F ͲڄK5>e֣N5S)X3nԆxv
+|Cfӭˬr2=b쮲6ܴ `<QfTi<q߷5mx,~~F[䜹U]:Z괪EgUek )=6w-K/kLE-k8[B?&kڛc
+5vc2!f%)B[6b&\E83,`c\ߊ]5fn{#_3;f<>y» _-1<Ȧ 3qbi]14؍w+w צe˦`ٴ̬
+5&~j}LhMOzUңCobݫIv;hmtObjdsL[}AQ73ztEW%kv||~3|*XzVbݗ3m|Ӵܑlg^ژg%!Z`&5h۬iߒ:/K7gIr~s3 <7d>bL5Gh)WW}d&=19Wogwjmo&{44پϡ~5V:"gןic+&Z(ut**3cEl[#EO]ʒQW5ɧ'v2WB5x-E{FmYd|o#"qdd5ySԿ(K~J:3
+jAD&!A=,DYo%vHXʴ_^i˛7ooާs×~Ͻ93;'LmFRj7FJ>mF]՝[꾙B#cW{HQQ]3#] ң!}`hu}gh({YK?
+̾҅`S/=RNG1%ы^5ҐO9GCGp!,BQ Q
+$F\dHH@G@dP$B_Wzi/o{x|VD}ݔ{ĉ.N'CW#Gs ~NDptwyF[yҝD@$d[ 9 << ĜnJ7aW=|u+{$AN  H9CNg95wA9٠Ұ*Euc}R^6eVtL&{K:L֬Jt|U{g5=3.367d}K# )SsN9N혨H3be)_ {b9ϺBD =aXzd˸AO'KbCߠ*ҩi >7-0Q'.'qKEL-؋KQzȕ&з`" W, *}'9λES/}/;i)?'/\YzS@PGDPxp@}ߡf%TD+pT E5V'%tbKр[Sq őv5 zZyZ6geKYYѹ2{93
+L{g:XrgGoyL_|Y{T}7W4ufiZS`.bΰ1s =0(C[-ʶYe}~y6=kVV#/uy4?ioH3k4Klƿ}/3G۶<.+$-2+-q]vU
+endstream endobj 46 0 obj <</Length 61068/Filter[/FlateDecode]>>stream
+H,wLY{03a v.ac1`l`lfl3HB#iP2zR/UV?Nꏨ|}GwHϣ9Z<?:>Xupxr,><Z<=\6O%-8s^ן=鯗l.o(~MƑ+[v9Ͻ=|{g~cܛ6~55v\hRmT^g5o' _)4n|#є4Sw?=~8 }/$sPaUG^.*Guo'@{{0Oޓpԝ_*>p;gp$#$PH_x"7Ny: \:@/InxE
+ү\J<Us0SԭOLO0
++Q[[ng VdiVhpE_`,a`ǩn1rIy#yls4ƕTn\=ei2N>0Ϙ;3U\
+i& 4L\ ?OjsbNXc@"wZ-L55]tݓ#!;*,QE|s-F ֪:c{Y=!J<2 ;[H;'׍ s&3u0HvANѨ4e{FO,#)YFG9T2G-x(v3䑲 H.jmV/m?~H'2K]T-o{uV7kaۯ݆H{F{8r/Wo9qpmtf)=nj! _
+~KXd$@t@'@/ʀh$h𾱀E"X(<xBLd`D#A?#?{ccH0& $@Wx5k
+AAsU
+za0= ቐrӱs`
+)1$|4P)'ł2/Y'z Z'OC\
+|)zEkH
+0??9@ba iA C!UHUBg>8>Zߖ*uݲ]mLOڧt5Dޡ)HNMkӠ;O"ʮUGe[DN hL@BpߐKA$@܁\$$@)¶+[U;m;SgN۝iwygy>?Q-usAur5NE4wuHY.vּS5Egh[..0CSooO|~Z,S:i_ ZmTs4q1 }az7}.Hi—xbfID}caoUY٤5 )NÒuBiqGVojݷƘ֚t<^q@B^Y>RF+ # ȏ>P'"AApah?_O/H~ ~5cP|~!mTH=:`A7]Px-lMiegʊQW.>|SU=5̸fYS+jڪF3:=YCjڪbq(2z߹aCع=^/g&תf&tø.S*w=7ξ5r=->/{ 0/KWVNyd޸in3^Ovwk=LX x?Kp? ;~hmګ~YG2q1}MֻVm'%C"s{k*ھ$ѝrnMsSnq^ˬ_չkcs%迥ɦRcܜ.mBAxliII>UHzUsfW\ЗΌt*YtZ6UiuV5ea=s?eYiw0na?ao}:6杖e$?Ur69Ҥ|.ɶ=t^~ֻV=J@JEkƢfH(}T u$0=
+RNDi;HLFqNG<oiHg:F m̨l^ zSDds@LGi{v붚P0tQ#MGhژJdcG ;B_ltXY.νe5Z:*tݮZ󐵻=o[iʛ ݈<C~  ?8/4^Ozp
+k| _8ԟ SԐ8`jξ%iZFm-534 ٷ Ո C(+-oz{YxK8a=d!RײYTGW} !^]2RLWwEbZoAދK3˔eOQ:7ɢ7G??|&/|}K=[MS a 3P1-qi!7@{zH9\i+"o?ʉgAv4t0` ys B.KAL0o,/]qAQ0qM BHb
+N3SOIjTEB$%R$qEϻ^K
+(r)r
+!@@@@ĐB!'! D֭JTwn紻G0;߼}~3|l`KQM`s~-!k6a cA~j$,
+߽H[tGq6NShbmvܦvh #>ꊘe dqxr7s0;< B#G\9# &,\:9
+5ieAbtJ˒BiZLKb7t;LwΑCFepUP=}Y%m9yCW`(=iGbo3nk#M=/Zw%_ƛZU)i|%> 9=pj^KMnudiJYjE|fU
+I.`Sk l^L)w%j-O@N+%FM6Hbr0C̲Ldb6+Wj%Y`rWGQ
+%%G+G}=0ph˂E
+˛YWq8^}Q%Fa[cqx>03"йF_kl6k]Movn[bc:Fs{w);3a{Y0T3/2Fabwx]ڎͤ?1olԍ3 _Y5tIy;27}cEttxqK=>o
+ߒ'05cݘ
+8(pY5Nrh4d}9a.OD%8%#u6MLlEL>hNCdp`v(^ovОWif| `+zsv
+5--ݼ-{XaGy??Kw{g͆7}]Wwo}qJPC \nˋ1^Aݿ@0NʈR.F XǪ'A9U]88Z |).אyd''Kp
+)h| U9pd%d̄,y1 /И!;%"@zd^׮d9P䁼"p;$[ QeJ[qY
+
+2@IFC@i:F[@Un+7a@3"&&)N.E@Ta U\ÔUoゕ4V?=p1z)O+ʅb#Үa*fDHl/VjybZ _@#f08)oKs5
+I
+HBȝI$x$suRZutН-?엝ڪݪ}ϩzk_#Wg
+^-K.
+~X(g~D*.ǥkl-Upz"nW±G/ SE̤F[̎𱉾xĈ apHdt{4
+bA>M”ᆼJ3U9=ո=9}9=p(d\m@Ue\Gf5yRJj"?=v=5%i
+H5dt5isR"`YNEoɔră[3* RGQYUiukԍd5Kl{\j{ңh]Pc&$-)ؠo!FG0^O;^VJt1$ֈ $u0)44nQ⬈4eL|\MXf#I Щ tDa46p jJٔrWL[GUѬe
+?U3& A+igeJ!튂vƨ>(y EÁM#px 1( [ s?|Χš@k 'ZE6g̵4[T6Mү24%ˠ~CiunL yq6.U}P-ӯ–1[rȡo"Tj5 [knyqVm!܀M~,Nʒ[dݲo;|љ *yiл]R#dd^ fs$-ă;s A8텅-ĪŜŪ9'ktJoǚ;P\ՎGCov%£m]ɖ&K2en&/ډZiu6lОLl~7g$/sqVhumذ\F
+×'57ƢmԵR|,v7h#[M]P}-gf mtwu/:Is|;nmcTSK7[+ Mfv]EJkڲ1Pۧ.6 `=W7[[Br4G'$E Qt5ߣ9chGF;z@pUcΊ-#S@]R5!OD
+|Yy0=Y/u@7>/̿T> jwʍ`ʈswsnc/4伝.rJ(k HuCofr KhxN,/vL7?X %b)YӍO<)&;Z? BDNNL$,i3ߺ|*͋Ӄ)\Iă̔B?44C(qt]CAc p;\r&ȡA9r $Q\gg\kcfj٩O[S[ۭ᩷өS2D̄B2ƥUijeu<jf\xu'+"tEGU#U-<SsS*Pgx2ݪx%98>ei:) SAr1%r0] 7Ӂ
+K
+jhĩQ %:[&ADĉ  %!Hc`U52tLR,'b5م:
+ݭ9 H/svjNWN?h2I(TIϛTVDV.XSeO2+HKHrat7.[_XR]Wddc@Na
+n!Z^%5&r/S 7?, 2C_lv xNCdg 2\k. q r$F@jb5hv\6zSxSZegp\3~x_8gʸ$(L"#0,
+D">A{'QKHA)I B=ʃzڹk=˛{ė9 xd}8x2o$8)r8&ACoS;H< h0;:A<H
+}2p   f]] PIo?{'KY_yL5iݪ|Sji[mN,RJ=_YF_N)O4٧Zڂ:nEXM&\֮Cm1eFMZlǠ^C u zΪVyvE7m*M6iԙ2!KwW vg3K:S-qcSi\Xz.#YbEt qc'N^V׍U6F{&V_Z5[!s[_u]:k]R6x]EkݛK[ҵ/MXH6 ukU%v"5KԀR~G<t0;g4ψtkOTSəey-4L.?7ɗI7 J߭ޘX{mw 6 ??Vm\r#[h%]^<PRhKe&8/*x __lmxD[xFOOؚys+lt I+K6 `H1kɯ꿫tq{rr#4Źg4m/Ď4:5?&n5_gh&8of-M6kz/e]AsC6@+MD(3gcyRT*V߄@ ]h: K<ְδ6~_gjsoSs
+xQGa[Ǚަp@~O.eCC
+2!#jɫmΨ1(=ZK_F\fn-jEU;* y'#rnBf1
+P
+q٠n,3%sDg\,%uT\m^KKgjP%\2c
+
+N=RHy^+FS3
+hjZ!թ%t
+H chY^fquDYAdK:|>y6\ej+XV}tR R*$OV|2lIV5rkIQ+d.NʎR!m?١S8qxp68 %!sp@1>[C}0z |~샟<5E6uև6Kl{|<70)KM1iz4E4IgMReߩvB{{gshMX\$Q9a9: ٮ%Sn2h[g.5hr5u2[?ຕ5Z XQ+, ,Iɸ*0 N1TV+tS4#R64#)4:oЍ#t$1^șrzq``[nK,r92
+q6e M2IѤRH+%X 9@kb\ƥk
+c+-\俴/?S:Bԙ<ye4y7-xM 3vFd㽒5?.v
+^X?髟ZgYښ_`{scESy攣՘dL˵LK4=_yge'x{%ߑ]o۴ԯnX9ۣ `8\;a=DxdxOpG}[=۲N;;'HrV?]foozY4Zh6{c/1#DؤJDt$88
+*KQQ@EY–VZ
+kE==J?46ITrޗ=3@Sd%yG[_{<\@U_\(/É
+n3Ï&^ s/x yJ$gaFʅ-[/6-ab_-
+˧d 9Ohk(,egذTڰWYٶ|=;աIɊ bvL6
+((gyIp xpCCy ղ(WY-|hO9"DP ~ڙ3a妦EBBV;( V6G&u}FMVWaž¥B}#_[߾1X[c̼͢Z܆ j}j/<TZ͈ f;9:/سZnhfmcW=Vnb~Ո3{a9l`q$^1;6Zύml}jyt۱ZAwT5/ 7lfg'ЛƍuM+4O?hJ6{u{=ۼ~SS7z`67},.4S&?nzے-wG;.mz&{ns2཯C}7ܝi6#-r߂joKBG=D.lIV.Ge݁CASbKF LK2{ƽ&(+aGCȣ5fWչ&#],ސXo~י3]AMeYO
+⨀N((*,7i !@* K6BVolIXVٶԠzjKLUWMܗ罺WwgqJ)ԙ,CO[9o{wO\vmmzwWĻmVITkj.惟[vrtxlSF{޷3e,hɗAQ<MY8fn{Rl
+ﲏiֺP[yinZ1JR }˘EY Jz*:u]Jb]:]RGF: Be嫄;'0CL}B}V?`D8$DO;n. " ǂO!,E<^|biDdeC=,JK.;MC:)rTۗsL+UڨKP2V)ƇTU?0zZp59p"
+ `c7y4F.kQ(C fGT~>@"atw~ s h<gP<:_ߞGZ܉|g%8p
+}4VRqCu|.])+$:jV<n[O0z4S!5fTtJ++݇k'516i(nj{ijSPL΅t(LJIP
+.đQRft:d]M̨4Ȉ&CJT<$_oxّyE"FC\DĝS y
+;WNKJI
+ C Sa
+Bڕ+PL\PB/H:T|m~:E 8Z
+*
+peip'\&Ӑ ki5J|UV92 _y(գ`M}M\]V˂uyٸ,\}^~oȿEh(FH/
+jH7o2HIJ^2@K"UeXK#.uZR3ҀGDfOi2__¹`:Ap&8Cx#p~8ro
+s\ bIY*$P-2 `5y,*jY!U-Uz-yON紦9٤#mMeÜl(Y/b\GI#/ڱSu D%AIAh˻;u˃PڃoԟxENA\$JA<i  ؅NSBjud4Ut$nC;\tqj(xC_!GUu-pH5V>p=םa6uyd5a.5ncA-=vڴ!V͖\.DsNmAiמͫ1<Q+a<vƁTd@9xubݚYmzѾa~kN-1;wWY}G)eṆc߬4p@|@WCofvh_S6F_[7WG7v_WZC[֨Ud[Κqm}Ku.}Jc/q¬|{qcpנXD&b4uOR]gAMei
+qOpɥxS7mK26;"~6}3 Č6?,jym|G 37xID{#GCRl<1m4,>gڟs9AV+ycR~\c
+CedTkisj;q5K-鍖ޅ:*02{(
+|'S.t̷7u(R Ƙ7]k]o{Lo~-,<=V.ȋ/R""2/5$# Zz
+ !_A<m Do F^-B3_
+[IA8Z*IBgM#"zƒy9rG5tQѺ}&2|VӀ]֚Mn+}إuR<.pE"q]R݂h\J3Ys#$CkA
+DHSUU}Q* b[2!~#4ʉf0iN|T9?`h[vsuJ::0סKs-O2n̿_c`JO:Oh`(朗 P_`ZWEʙʹ?4)y{>R[ȇ4oK-KLהI憷᫾Mh<\^LȽa
+D' <]8࢓8w?a!űxd+lmH&Z 1a#laID#",ȇV@B!#٠& ydI"2#252ݩs`m{9?Cu
+%}sp's `k{! 4Ilٔ\MepE ׯD tV+jTfF84ELY\Z" i9A 4s;Hw
+y;v[nn57Ojg߱,<+%E"$
+PCB!!$(@ PH@nOԣ`K
+Ġ 蹴(h让=H`m{jfrWݙ6oqskjfbS<=1Lڵ1bKl_\ة4 wv{MV_}?|0kmyV:p8jx6^U$VVpxESuنL}\Ʃ'*fA9?*,Ls
+ݠJ33^kD3
+J;4HF%9zsVJ9fÅ)ØN"-[(ӤN,7i B% d= t8RI)_0ⶪm1MnTҎ)i3qۣ "iyEv)4( gKk@&#「yQh ||@'X :1ېMPvM ɦ{eKÐܯc ͵n%X6sUm(.F_ubk4._]Œ~ͮ7<߭x2';Ќӏt/P<`k7,:i#;
+<J U+i5YA˼M'eg9p5+yUp;YfI {ƀz:F\<>l>J<+,-Vr8ւ[3<2Wl3?pH0 !#
+v`Jԇ
+> <<Sl_WiDh.T-ZG£8:^B0pE.r ȭ&ȄȆ&ؑ-["#Z#BczawqqXp@pgMeZ
+
+.&ϴ.:wĒ7 Gw,H..!B;Ŵ5Qa֗{?2͹ؑnL9oRB:0NCG)|ϋŞE!OpMfZ")MS~}[<Y[GhT,PpCMg7qN`wx_[IA
+x8_=]p0
+tvaT//]D"Z@<o `D8 х\g@D< ƗE M@<ꌁ
+ i3g \SWl σ JGO Skn 4w[ sp/F= Tkd_&6LOKFьg e) $ &[,7I木J֞.O%TCAD<XQa"(/C̋+6dE&`Hd_?Xnqh@E cx@D 7I$} |~9:=@:򝷃5\w_Y?BH ܵ 3"P`<B&%c .+, K!cQL,*0Kci2s\g%bLJNJ XNct2ǎ1;:N$WEWF1p] L_FKKҘ(1Ky2BZA6
+G.p0J7b<&"Rst<ggit<;&g' znY^(l.9ؘY-zoUy.ܱ7 2c y=?<
+/B
+/!R CwD!ʇ ! ,%(KÓL4ǜd,eDFYВmd[cY̜ d ޯMVe˝+O'[h9P=_yۥ7/ekO_.^důWE: x:E!K.s0YkOV_oNS^mZΜ[W5-#O$3Mndlh;;.dqt?3)##KM},rL- }yӠ+
+LTt.'GΌSIki
+m^k઼bM,b͈EJ+=9 E>Aͧo0C}9[c臃""Ng@sz*RL7],1G\#f=iw}f79-Njr}K]̝Q^ĵ}տzcp+\"VI[}+(vcjrQ~+5+㫺@@]1zj9P\YB<Z@bS;\:</HwOj{%s*Rrt\barHbTsܾbafphw_iѧ,_l4ͱW%K:h%5ڱm5z`@VHu>ovaMJWK~1=e[B>v}]v9WO/5U 4/y/ Ohv4JzXީ{Y-׮u>AyOifsEWk")^OE8L٬Hkx)
+L+JljxC |k/<ڕzә/SJOm^yR_?tT5/x6޽YEjzfpTybEt^|wpK}uxR"y>x=R4HZH_{xoZܨl
+E;%!W~$dUS=kؗkC?ˑםUoK֚)6f(kQ@^vXn|RеRqo rCcњœp
+ .`ck>ˆ`c
+P
+܀ -agh/'fuH'8B]4(P4+@vh &ΧO(;GhNE=:jmu2,4X_i*!>*AY|fU,sG̗}`1&-2#r1<!wI$wGU}ϤeFDdqj/,4(Dsٳ'riLZש)cy&So+>Ņd/`t%Zu'>*q. 3^qa@Gf G{ć@Z,2 ۘÝd20)@ Kp0 QA`wP cs"錧7G\s"^o?Cz/ͨ?cf F Lϣpއ&ƖpZ9g`h~ ,`DX04Gah(p6(LMæ} Sc-Sⲇ|ܳU9ƅY¤;4Q5ִ!SaB鴬4n9Wn0-MkK5U&7PDVgE3ld-FH40虢:A$?_H Z
+ I]rn
+eL.|OB&8؃U \
+nnwτ%_)8sMi36>W.d~j24QEɳm ho2[Wz,Ooc8su|5$mqՑyvB︖E-mTW8?t,4tZxg;B'_T;RZ2yJI/K19k+(rJch㡞^A'glCvDL-,u,U@Wc47a J{O kӟ+> *
+ӅyS|
+}bDnfr2^PO\$ btcc*[]/[XB>۸MR>zLi_$4`#nC8> uWvSU98uhއ`|p
+Ew.]
+n30 b9H~G ${~iM'"3Eי9eM_
+2nLҽ2&hͬ"ͨjHhy&Xej1=v}7/UHڎw3Or ΃򫘩g NB'e0u+dS^%W>F,T&.ψQY~2oalqf^+JtBB#5<Z6.jD]9uɜP0ӫ-O'Wk̜|pSx&`ædΎH尨AP?a$?tM'@@Cx,BՃ8I ^q GT'9 O20.p19.&.3_|C]i10 A˂p :^CyYWVSK=JGDŘrhG}9A])i=
+9 =s6@1D{Hvwx?-PHV)](}-}|"k1kLU@6@P2uC$# |ɓRAR6^+2R-,WtN~ٚ7x=h+VnsuFcEW[jStjӛj45; w SJ֔r@Е EWt#o+t.#q2hN@fPJg72Q~ǾճsrWب==Z;C}zR!pw ^8T T_J{m¾Y'!syXgVXcӵħdž{{s5`}܀)2#b ?|ᢟ/D!{ Q>ϝ~~) N0~ B=Cw \ GgAgkN;puXgba[ <RǂՇ8km1!'bC{Gk
+ vj!>/w@
+uԕ
+R|v̺ce;
+?Jkt~0bs8/XSa5Bv/0ms؋_覲?Yڛ/c-%ohKlISG99pB/}
+ >:
+g!"v8223\[rnv
+XU\}ˏBU=Qi K]ShFHLWCo+j[?=Fj/U]zT'uM΍E0Grٽ>|v^nV
+JF*Qlav(In `f)4f'} af8oWz =,u}s_+XʼwĶY/3qٗQp*8=ۉs2t:*7PI+"TeVe 8UE.ޱ_9s3yT->űŝrx#bC tÖ'WC_vG~
+Wy&źSE,q*H
+D}ڿ>"1 2 N
+UV-Ԏ67Z?Hw؇D3
+:m wAWL3;{]3ƱUarںkXǚa}O&t5U rqtTjQ2fE=
+oG؉sͮ9Vpb}qpɹvhy6{O[\K[ѱݲiCͨq]5 uI2o-"-Ɍ6iaEz\ϰnc]ٺ﯌a-Tl}װܩ35[to,YX_aY
+ܷ"+'C\GKCjoN6Nl|0zNold^tfڅ|chv_'g^,/l?(%OX[FcmG͠ \;*T:|J$5R>j
+^_>vl-}q/)\.L}2_kC=R,+87˒JbP(T3qSU%YLqa-52]MSװ8TOK֏-vX9W)TΜx+
+E>¢_y}Q܂=x\w]3!8"Y[ՀH@όh&\pjq&B~N)"v511@NYYJ/f|h\&п$O #債vHVԗ2X!D1 ~Jނ 2Ԟ/ٚX2k@5͆euti+i v6?u(Ap_}hVd))k д
+|P<sdJ6n365n%ͅK)P[GDV(ûi#>p0/uo ۯӷ@ߣ(N6daM ㊸xyV7zu]wWy֬Y #%fm&QWUW DS?kG[I\QMw Ak:/bxC.*@r.ᒄ@1BCHC༭vLmmg[Y۳ysN}<1R<9,,CR0qAB/BB(Lb@)4d$-
+[,e
+<$?H:
+Hn I @Ōd?
+佞|j#FAUMѾ1ý<t?|
+r*2'B2ս,HDޤ@LH 4
+K ɗ$O%:Xk\'KrpyK3%O(gyƘ3wfC-Y5%^R>zcʀso`}&wo:;\ZUZCtwRe;K]M 5[][NyFI&PLv8z-]MTo/3ױe?gd
+.RAH)ȋ㲈\\:1 Ge@FTzDRQpCS -<RϤ32ϥ=J\rd]LqM22f9UjYu;[:Is%oɫ{N4!JvZ喙wUsWT9W~[z(ˀd0Bnd+jL1up4'N Y_p>o ZDqIė Aމ(*p)[.SWvQ|-܁YWV(zBۀwXP_iƅ\'@M%i
+
+%nB B }L
+N|C@Uv#plLE[ [~2g[a<[B6Jf0dDDCF2#3=~51CIЎq
+~< !
+E;da[Oclfq8L/Ϙe.3A
+m%m&0a&cxY;DTNr P w rt?\c~ǣk8>jԄq
+°Ͷr{ьQ^n²K[p/H.~;b?ɲR,ߗ.>ze-D?,o,˃ ԅЙ.MeymYmw*>T]Ny5hY|8S? qeԿ5<hy__q~s ~JWߑ(ƿ:4DZ?hΰDK_;%5FOX?f߷Ir4l},㢇ٞGcW%2fOAyo/Z*Q0KYtcuZ#a\5Xf-~I]շL1W›`΅e_Yc.;.zdehgHd~8,zW)ݘ]}>dKe0imdjbX",cԝx`r^xmK^E>7;î诨-];
+^p{T`B0Y"N
+X"(Ƒ7H!6ɘ:wZ N$(oh(h$ܛIM-sbR'cķ.kP7ǚC{ح>kzC|4r.7|$*'nK']]An<xAh@0|'.
+в*0Ԍ"<5Ű6谯
+[b+upDBG1A pe_쵫ЃW}^I:4t(
+.@/s SD;rZ&f#dBrܫaH~!&Ґb\qFI-""h$@qrq&ᏃlA4P
+lKѰ48]Եnkpˀ}G܄^oRNocᶍfkJݪrѪhI~"f?[8Z~9}d_Xx}
+>
+&\L.X |kQVTj#6v56!K @jT<e (gc"$G@YVOP,l!j0p49K zեlȉ A|NiigOŤW7kKV
+ _1<F8V4h/iMN~(nՉފo4'+L٨X;Ƒ1\cQd~WJ`PbX2;]b7ԃ|F$*Aaء|=΍p8gen)Ag)1 SUPF+`f$p[CUp}d%#WF9K܅!֘h"(=4DՖ9&~"ZΒN~W1KvE\)u:\BBu!f6, 1\]F `.@]wkI-{hR?[%\S h
+?97:I{mÒǁ#YT.*'"
+aDJh)fTU۳rH2ɵy6]&tbV}9/T:8].2ު^5&c?@gNyCPKwH[W3A|Oi9) [wgZĦB͵o0*+Iu݅v&
+u`-ƌ#&Ua)6 Vγny{57> ;^qw#O xu/u}<ࢃ!ޠ&B-ϼqu\>H4$=JRHDr)ər %v?ԏ A
+HqH@Ali܏M-GG2.Tgar#" F =`qCdƾƨ y59/\/ Qu0lO7glL5%?jBU*r\Qsk@O95!%KNHO$'E<P ߞA.V 3-+YHTfJԔ|QJ$CgH,9+_GUdӰt$CAl3"daq3{Ċ|n802\ }Ne$\ 9> w 򃻁9,,Θ}C$rJR1P?"_]YW.mNLKW֍;5aZ{0w:(y; [ z>q?-hN2~04›-1f8nc|F ,|?yTu_M7\dstapm|m٠P jFZ__V4PjPfS+SF' קgs:BLp~D4(+G*ڒbJ?bZҧ=>*BTD&ιŖcDQp!ߞ8(2OӟEiK 5?gi?[彣Z7 JVJ¨Do|dZ5+lveK-ǚg+[jƨfn°+3M -ɏ&־epۣI{uS /󛯴cٵI͍m /{Ç/ǻӫ;TWU9ťz;9^1<_yu4rCKۇ{OkL5k?Xy7󜵸'Z9|mZps¸|Io;]'g΃8?/I@EAPA@r!F@$l8b.DH8p$ p*Ukvv;vLg;;${:OL+Oz6LK뮬.o螌,ouoOd7,p~:0nmLon6W^-Z^?m~3|ձT,B|T2IVX)^#O16__(1k>ZjⶳwcղmNzB>U\_`}\X20V<Dd bB!(_Tp]O޲jgV O6gm+=ekkڹf[F_r\ޯQk:p>x۲.e?g߷Q?0|6ݹGZ(l~ cڳpJf\\4LؕCU 74[UvʃOԛ1h:S&A~<:0bޞf]Y^{nX1!ZeFHژE2cBUaT2M4.V=%|/E[-{M.HA{S!A f_@{sa|uǞ>yC$<w,u/.xJ&n m5a]gl9}^hk
+xP.5) ΫptBP0ok#ӕCGd|qXe7@MH~ zK"@m!.wjtj? 'ʹQSnCbd+KD``yܑ#>PIg XB}OOva%)E/N0 gI]\{MN
+<mcR>ZJV!I~.V~f'gaLO@Jj;|?q\6I r1c˘Tcl"'FgC?+ڙuH 97=nnA+Pcpp!ԍ8;k\ϊAHqsǹaݠ0-*2>)3J=GF%!Q!9Xo s. 1<[RrNQ䕺U!BUpM>ϣC2P*odI}[*+T5ZAtv!5 V4\Q*ic՚~eCds舚Ҳ>|1}wF]ۧ)+(%cr<nN%I`ȽH
+'@4Ȍ"BmSD)ŅC
+(T
+jhJj:&=.`ŧ5oC.e[;s99 )hɱPv'DY|"ģ!+:<~Q^!i ~Mks
+NwzkR, ZNM5;$!8 ҄a Io2a('%x2
+[`߆ ԆIP-I;]Nfdf:d?K.pH 'wL"UcӫED SuuޝK$.GbaXd[YSAT.Q6[DH<jZ7-'߂vr3C IHxzDž)hp /_/;hĢuAwvK,`Zwz&Luq85N8:g ZWXhYh^Poid |t3 EwTʚ/ywʯ .3g]SU*ѾVt#m낖:dl-K7$GAkՎЬ>2=061jƹAs2뼡&c:[PG?}clqd3&s}ṷfi:ֱ[6:mkGenF0naJF,z0Zf Vaˤ7򷄩oٓU).^izO:JL
+x
+E=ގI%/CR2ԛ6"*)ӵC7إLa5սY8* :<Rs;ĞG-rw p!swC ~vV 4`Phf
+
+G}y`wy:H
+N8b
+A(ehl@8XPqg`Y~$>SWH=SYNd;];$w7E(rG9hVJ:r'Nqu%G5CK]lhqKSm52ѫC[CσsHQ09]#蠿dH8? jSG 6;EQgp-44>#Q Vx>~1N?aW-5](9(
+KUV*ɠ
+j$u@ CY^-h&PȋFeuת rTxU4@(t_[*^rUVzW3<Xu*. V i2+R n<niySEw_J{xY{>4`;Ν[Vȩ;2$41nc@RX<]ą̄4PO =43ps.8<yop\`Kw~^ )*Q4Xʲ($J3(TqR) @bUT*6,J̃}(IȻo[` ./bœ(E\\ ((F|$xP
+|F pg@TI ςsA0` hSXbѶsal3HvUH˓ʵ鹡1ܠYvmwsS$mhW8г3i_ pjlFߦS$OP~w]y+huTvM6pC8.(`U lK,, dI", a>zL9={tδӾsoޖ# ]OC/唍;Y*4@|toIW!4_4MZI. I6ԢT74P-(Z|fnj@<.(#mC}2^i:Ŭ 7z5ZH߫6AzuX\S%DDS ʥw1 䫫5_K(O r~svm[;xScC>3oa0 d5̪ذ$-1ݲ|zy^ blsLŗOnOoljֲTUrm9?p€3X<yodg_iwfFVnJ6$9ڤڔRmMٶ5WU„ɊFms ɉmrU݁ݺl ׸oDȯ8Ox%6Ǫ-y*\ܳ>ne][YkaB׳qSj*#wВ?I8/~1}RlkO?Boנkj˫;ڕEueEl}\iZ|]? ~-1F:HnYa+Wnr!|ߣyc+#s$ kƍq QRlŻ.n8 V2;alC4C9q鼞e9SS7 AL+-s1^6~!X{Vo*UKr 4\U' 5y㲔~
+7l ~|{ Ӕͼ2=h;p.̲A
+Ya>T6L~[O9
+l0 5!a0|Ч! ՎjujnZ!>+8#ۯ:"?}))xh65{uOGjo!K0] dQ˲ϏGM%%.ݴz4nyWU:ޮ2S3Pho.PuhsnVXGuѣ{AO :k6b?|.)~48w4h!A 8s3gvY^ݔc]]G}{X@Vq+#%U(W%!%ޏE]t=
+"QJ@
+ ]xf
+,!o:!q .:4܈ Y)(2"`Q l,[85 ELơxTQB1*7
+\KBx[&*C >_oh~rl-ăeG~EQ)#mc[ƕ 5<9 T?>6i[iޖiçr\4%u|5=P~S@p` x$K(f2`vO=>ϱ
+
+ 5h38:;NVVvgfz_^ߣZw8
+n&xt^ K{p~B%b~1A> :DSu>pǜq_{p@{@/[Ğ9ͯlŐo+j2TCvuk.ˎq xK}S5$ٙ^ Nٰw/a<G>с8 b1OG
+Za (nDc4^5*9:°LLvi%"HLYXRS+úqa ZV˜fF&^nXѠ.a E<{npzrVzg,wN(A&lfy'%(DŰ~N$mWޭ&gpߙf3n2۰{]`Αjsu+ܵ5g9AEU^;
+&}B#,2fwarm{Vn.{ݼ+ nFm~Nn2Ψ67iu#j#WӿʜYj]^fLOyg-(vJ}ct;+S$Of1-yN4Oa7+nTzQoZc3FJޞ3t|jwG {-)u0nv~9}aәĆmӨ^souughг^~& >uļ=99B:@yy%p5ͽGq&7BSsfI1{_Rmgo[|o}=&l5}^ wl0_ Z45flnw[ֶR޲_#._;fM-g)-KpUn~B`U9\,uB U_oK ݝǍ6Vo=[}6/\o&7%;M#fmB +|z~&\tmOjT%KVz0;
+rtJO"hȇ逌A;l3
+r5ق ? |=m@|
+Y8DE֯J
+x9»M~ q 65` \GDHˏ]^9DlV,Fz,ԅ6f0gBbl͓rlmN==Pviv@MXH:/g.ua-WIҲhؚ '~9J=9-da3}o<b@ xB nW!1!14 ⿸iaoUZ"&921z*Pc=;O20T*^h'跲4jW <1
+3BHC4H3#ńCzH ɡx/  Ā(E(qkԍ8 !1șǚ*y)M%_3~:ԳV3Z)^=$1Kt/bElrmH6*zz\'R5,ڵcK<`EbXٞЌ[ y=$ҰN<zrenE5%$Gղ Bjϥ3Crю`MdVLnWFzC(ZD߭KW[SzqFb[;]^QL{+ GfbTS/j̣ڝѽuh{C7l;{(t `"fAKeLQjWt+:\2w BydettCfuxufxUz:CꫵyPz_-ZUr˾FAą{j[|Q=UjO,j |j]s2I7^Mncm&#<C}ݷyݯM։-Y=g6KM_4\tΐ~ؿ;e}{>]/߸O<`q֮ Ac;c?_j$<m?npOs{F7-c5cs8S:Þdk2[սW>묩p2`mD;Vk
+_ce8XUz%jϦs)%\Jb
+, 唔X$ "滈`?k>Ș =jĸ/mcj=d(%Tv{k%ܙHX`^aSWE8e3pqKX*g]~P
+2 HcI<\!/%p,L&m/w̸p D n}nP]JD k^%>¤t@s7 ΜHI"=|xу
+WWOqnCy?3) dr2l{̽E,zQ:jH pCh>l)frM%<~0+bs~]^Iչ~:?G-‘ӑ%@FDJhg)d(G⚨8l#Sp,*';_9S;3<>Ei+
+^w<!p%@0YS^ $ xCGeG@n{ D/2{'BO<<}! ʇ Q 8HBOhIL1b(1ْES L_ltߠA_$DA.c3qi8: SyV|BcXRsUP!pV
+{8}cOzD.u2a6JѸDŰ0-̨$ J_[?/Z,WtΤufū䅁bTV>6/ỦK3s2"s||722IR rb|amǠ9tGK똹0*raŬoݧ+ ƾLk<GMrܭ-c;V^҈;}lnzؽ'2
+VFA|XX4>\}6[<x*?>+N1ۭOŢXx{P:[T[ ~ƖŀgVeW;7`iѬtzprpph
+ ߶5z7D1>ݘQ.ޝ'֍W5K̏QߓY?QO*kJriߴx,1ͪdgn[ΫoVzL-z>L!3I5Ƕ^761K%L=wIzԤo]~iu7J)ꚿ8|E[S᥆}B檙?2vAmCwŪ01hne_?\e{W'M3,/E֌3l$yh9mv,j ?vnֲ>~#oMa7wCOjkĞxׯ?jf)o[MŞ`tju9P:A1:{j73#S;GKûX+n&b]JKMNQllpG?>2rj6c4575׊OcX񒋬syud7<ćz|Q7A<HȀx!>9!~#}nM?cEXB ZYUW W:EEۣqp)w[Z=SSwQe//kh}$k/oHxW 28]
+ލȢ)(Ȋ$\)ρNBr6PĴE7\Јf^
+_5.nYҡl\Mem~bFi"a掿`cB] 2 D$^o;+gT?oK/_(ؠF09 `vpqٱȵC@`K)b 7##P#鐙D;@t3e75Ȋ- Ҭgګ,KeN
+ټ| ǬhSB4gۋK7M
+rLݼ w,?`u ݾ~nQa.P{]XzoBK&*(L)$55WNQ
+M*R*LQF&&XH(&
+ӌ$G 66>rQȂȂZJO}2`֣Z(qfl䮘 / xϡ.r&buvZ:Z\+!f+kr1 ICPn-ju}|9t!HPw p Bn(@dAх?}/16̉F/FAal8bow(@Aq i8ZV
+Y0bˡ1rXuZV+I7{, },Ƶ4> Ҭ6Zc^ Vkk:cS7to؂ [w=xp`vlP]!%< !3謈1 *2B^AF`<],ǁ:@"$x 'Ab
+O |s͟I721Azr,jIͶzB߶孵mb=k׋:V[|jp㻩 @;aH ~YڡbiDr~t'JW/NRh^^q(/V>e8ڞ
+s G̑:}vv0:Ћ4*l= (:^f_IF ] 3GS ÔFܵ>6n~أ1Ocq<]=zF V5`O88_ocԱvP a{{?`ҵ:z~t`ܰs)uVw9G f詼m/%
+3z%V?.ؗ-f̽MiQP3;[Λ﹪.k)Yg}j՟W|7#m騚{jK5x59&wUchdwHhg7WjUn_q0M'f$ly2Mj-Ա{/?UN9fsSU^`{H\P+%pwFc;Zm)
+gTXI}鴄<8^([% Q4 3}[VCo_QhIyt4TTHǟ2r-,zV6+WF6RLk
+L*нh(#9٢
+Н; `tܾ
+"]mZ)`tTf[fW75֬,6Ī*-NJ e4X P48:y @C`bDF.Cǒ'qdq }ad܁XRCr}H B`HP5a}#! !!|vg 7d54*ՉEFqWUSM[S`yܹAf[̫
+ahn1eCs|j(g؍z1/=Q`<&,6#GCy|D`>IdLLTduf
+TeYЭX9lZαm72x tsz}}ޠ'׉r:7"7m9y6
+";g N]%x6fy tuv.$wh4/88CPHF:= HL}bZ
+a^T#PQ 9CRh?OIp:Wfɲ*4u%
++M`j Xf<FmKӖ !T!%YltzH[8Λі%%[ oI{slXSh6RQ eU reJ:ߦTɧVdvdڢPe˦uI7u1ߞa3.uo ~<jУ3ׇ?Mk1WNKJEG=aa|98jN.vrPyx,Y[y?qAyKNzt.m(?[4|FV=_,ʍStO s*>af̻C2(1fikDX&,']:}~f7Dk8t$cVϡ{ohpM΀D~oDgy0a1 ԙ0-ԞxYY,ڗ[O3o.|397oz׋' ;G3;}UX}F*?_|ڜ5W6wěHUc$x^ca5_Z4啶RkF߹;f/Vsft_zqbQks{_W?hGmf3mM8Vt/L 0fcLyXPl e@u)UY!f.}?^#?m>UcV>ȧʦ|{ҺxSQ#%"փz#8xSO1}U>ӛ;hv72ố-Ԣk+lj \/Y&#yEZ]kؓ%AnK)XkUO/%reD6I|]A`&CIZ:y@ @Z/nz\  Ѐp;nN'uDT#`3%7[%?;:B׾ʗWjEvEB].-dE0@J,b]P nlf$]'-p:}g[<g76ya͹:ŭ%Mr7W0{9dgc DguG'N.@r&o>e4qK;ܺy>EUyr7 "(1PElVM(`Y djPښ۝?!XZ~b]AO1
+2"
+9faà*-P:E8*-/,eE%K7]ؼ%ea랼jVbB.
++ڮud0x iihnl21086 , v#ko )bn, o=MYc`ml883D;1,!9O}>E3 =C/V>uU 7G`Zre]6%&hm^Ҕrͤp?TbrVČ" Y/³JfۃSgT4h,jl6]\c8Lcjm9\-<]y)m\-q\ Y U)1Q
+endstream endobj 47 0 obj <</Length 55798/Filter[/FlateDecode]>>stream
+H<{PW`jQqQ"OTDD|a&F E%h<$ƤiMfthggvgٽι{tWb;kʰ8aeNmN]9NXwӇWTegMZ
+d'^FZ DG˧N&@{eVPV@Jt&)f[J0zlk)+c9y\o.ыWvoeQ2P5i4MɆ*RT%xtI PNtIPq(f,
+OC
+諐 OόHEF=
+{J,A7<B%D"6r jGui4eѠ@58h. +(Ǵ1jژM&߇_+>R<pdlhkm%CxLG/6o]nar;>r4>0`
+
+ G
+IEJts˫6]DCF2PM+B vQLr~nvYΞ~TVKL#˵O52Z+Zf#>B>'S4+'Vd}lS9\om7m+8 _јFʴCf٧Ftkɢժhl)Fz6k5kt/5ݵ_/\ZݥyiAky\S9JP:lR {Gy,ycܱ֟:ͷ7vkwR.gws]vt ol7fh~)מ) v̲ӥֹr.<۳*7_LZt}+5NU!Zߩ}??u;rAӰevϳZw~vd+}iKM[HR14m{CbJm]7hVBuFg[bcB(JsvSɳ^q_\5/uo+Z&16\3ۓuʶOv?/K7!2~Ql~VDoe|GYW&U2L_y;{3}?F1,㎄zf^SO=wm|L/c69 +#
+I7R(&R,hv9Ւ9|Qe_Em7xoy˘ U?$qUgMW\8Vb@޼3JzXVvFds{xcoYHMWg\{Geލ|)Y[4v[oOfY EBxklh <ljGmUUX
+a1  . =]G9tU3TlT $ LgK\gmgռ& Oq'7w2c6_r팻=N%E$>nn>)oipj?:1fr*
+
+;Ca8('Fr"Odڍ ?͹e1hprpj3,UT=s)b8.K 4
+D]p \ ji󠴶3
+9¼|T
+ch Gg$ $ Yr.,% c /ˍKY
+<¤$⒜nYn3W0[LLË '"F.Fk 7%i"\4$).\ X\HomAD qރ}!JER_t@{T_]!A_#:8ꯛ_.+SH,'8AByyEF#\~+ YopG;}=It}Ӑq8eh`瘢XN6'2~@| !wiB MOljYy)/K&HMKO|xz2Ѿ(of#]3‰W 9Aue_{_tTݣiQmTU܅eM_F5ӣOk<&_S5l75KuڢewXͫ͝j&OΜaF;]<E6zVCscofNT>anTԛ3K]͉51! ~7?av`j~ ޘjdYK߯Y{:u~0;qKb{wp\sz4z?r硘9F6|{8q<ƝWۊ*FҶ\ ۝L;>X` Ǘ61Wj1Ûgg+ -LnmF=L}yzpiNӰ.٭?i> 5k9{kk% |uW71hfӲ{_u]; jOFW7w{kue/qjO!{5}`QRP #\RyYKw?g| ]}K[Rm))iV+Ѡwߚ5O#l6нZlצsnNsToU/4ųQO&VW6yUtgbD+?10K/ni?Og1<s*1W{;u]xI'M*ɗ1 cCSwPaH{EcP'|DO^(6[xF3qiD
+7ޞ쯁Upv n]w'G'psrWW ِ= 0m] ƃ@tDnXr \ 4+;;A
+=lIvN$P!#.W4nw],8LVD*zvʊ9`.** K{ m^H;b3U,l.xb֚'1oϕZf-|i ߬ĬPt0פ%rI󝘝yn˖p|5 Y Z0ܹ
+]AMmwlAdQEDİ};!$ IHw ʾ
+cc@G32/HOz#4z*ebZc Xptxt
+8J= D}dt 059lɡhϖ ;,twsݰBx"/8P>7蠸6]߄eoO=ٕ d2]*]è,47#0D2u S#`1ʌlۂ=6AtDv} 8vbwm [
+xMl"oP%W Cm9/ZM'f3JYbQj;^([$ǁ/]At$OSI|{|x0WQMR9Wn,6ʍrfOnX!W(U)idriB"4>TG*!FAil8PE$k!H~P OxA\dCLdl_!#nMznuw%tv7 w o{MpwpׯnW8543O:;yB7DBK yCw3 ?\CH(GGEKZЏMcbb3<E>BAp?"DDQþRQ|I$lbdҌZY:QRiXJWN{b\|2Ѥ_,NR)9 %TI|E"K˧b9pFd2
+Z7 `lDk֖DMhir"<}O6$ c&{;;LgadLY%!mT}u|xp"dR :% <G r-@uC~@e{A ]ѽCPWLԈ>h?’I>>ȩx z!A\DK ~ ⨻ AE4)7$ՕɤDT瓈._opI--%Z;s㪺ǝdU߷C-k¡fm@F9kIhߩy[Rl穛v[w{[t櫋%Z s{J۷=>Z;>ѩ`mLf{/wf'gg/^o=G&|V#̪_Q-cS!jv-O{ؕ'Nwh7R5e䏇K}4wQc/Oi'c:;ؚ8/u?` NOvFVvuswe۝ rqwgpm}om y0rR>_ZжY\P"Oo\ 6G6W4<v,mԍEuJVۺR{S8Z4>dzU QOk;|}\K,\4esrIY5.yY=esT_س)]2?N>!K<Tvt,w,<x߰뎅ը<|۲鵆m+%/\Y*p1p.헮q+-MxmW5SI]})61'ݹ]ˌ#h({}/43K߭o-G9t`ʾjj{mjketIJ;{^*a>t Smz.j\~hi+q NIzHG%?OXB)wLҀJ'#3 0 b r#TZE-Q1# QM
+FB"> 2jx<zUz>CƨJ *yέT5Z]ӐRDKͣs"ndf\>M&b4eӪrhٴ1ژ)B{`oa>;K+/V
+HzK'՚ /7q$=MK2Kssj'@8,3{h)ȟgI`abV6ADGy]LbI0ϴ$ϴGijrQ]R^η(XzbP"qUVk+EV=|vaQ'}9
+Vl,P1'S^v:>=\JתMIЪKMЪǐ#AED&&ǑjwwH茭O I$Q (OI (*hKo"'CI?
+B.Vd@n/Z8"!zҐBb %$CЙ
+I4H & :ˠ@b@8!w5S 5=6$'AbP Ġ:!G_D"݀ Ȥ@NyBQ?i׀ȧ00d@?F_AT(^v. '*djql$w( gU' miz&6Sťeu>TYgܘ'3/3guXcYd3S%WKur-@fx "ٚC5b}8X@\z.UZ/'d^9\A_G ՞dIԋx]v91 OpM ~NƐ^ `VȿX [ MuQ͇֥= PՋpՃ!#q 4nM΁3
+7b"{3H<9q(O- il…9$m P+:0 LryNAuAYcaK=Ճұ]q[G翖wqObS\)l~xhcxoNlXS.lM5)gͼ\>fwzBL)޽TLNj>(ީo^nsZI=(ӷ؂ݙɏߨԃKkȒ#KևfpoLI`j. _7^lhqf'+
+R=^Ӷ91>ras8vGOw`|0K.vzopa泃]ސjooDu3|ٽ8ZƒsG9޽Rj4ޭ_Ԭ.o9o /iv^՛;' -;3}+omt 4{4=0A12=6b;b#r{lA
+ϟKS063cS056: }01#Q
+26YΜHg@wEW݇ˣzۯ6%yƢsxϔnUOB4'WGf4QJ*%XΥ,dtY,EsK$1=K*E{-xRܬ9Z؂3!nhm6omT#!nq߃\xl\upPeq(\AQeW?4.;( (*@74BCu7 4lJ 4.;J2I%Jjj&fRI*UJrċw}s Vy=>^g>8"/pBn$<pD1"Z~l>WqӳQ\nw~h`gQLWz&+$K΍{,I}b>X! [`\mfx
+c[Y9憙141ScCdd)'ژt*7:fЉaNhӨ9mjsg]')Su:%z} >iΉ~y@%dHg~Oo>T&6XW[WOʝ7ޕ#E'oK2QWDWS(8N]=(v[X~cv^Gf{7duȕ u"[eS-)M-aR_$B[ykBn_!UuJmBn /s7>Vܑ́Ms&!V PNҨ8(ID FEAA#C0"'AC CA|}^~" 8V
+~xp9G6(bJ^
+0dKJ#CE%
+3FAY?^ƅjlsO;W8YbaNyPܲ xS@P_'ԭ
+u2 EJvyB.41MKIhU2
+T4)P-P_-)6,[kjދ]UW4# 㕜/ &{*VeGU~/) 3ڂ,-n&JKRy yhVJtVlX,  ~-}B`stܨwIt 4 )FjZ*GzdLz:'q_i/g eNȋ`grL(k
+;ƫgJQ]QM$y
+5 2dˊ .7
+3d|c2YRa1nY9i*+"[i%NP`U*d6)t JxUxNtjgmۯ}SӭS[j.mni>WueQ9"{
+]vie2MQy(9[25]*-C$6
+p1PvpZZEJ"!K"ʒSd^99=ځ+~c[{;%h3tC0e >
+!cc
+&8>[>__JMt\ tbY7 z}Mr,3Lp G&8Za!p2(">BBpe ',Ce} 9l^Cn7O@ _?p9"
+|sjfgmZxz owolfSyپr>3d?X铑Žw_/Ί~]h{򿝻zUO+,xӵ?Ϋ}e<Ѭ_|_)6kpB%y9|{% me۾Zmy=ɗھUrT-Q]7F꾗|Sb]N/S£ⷙk%.._9ko*~([|1ʳ?.MJYb)FƎp.|t,@U76Bb3cw7-DNK-foqV805x{8@'MVsws
+Vh^mMРch&h@S:MhzCǽ!zƵ\q>1w7G'[c:v#Gt=+Ģ9Ygh{K725&%:D'yIĹtB"_0T=e IUŒ%5¬
+-a%MA^YLMO$
+R&${Kf_5u]*/(KŶB`wtC;ڂ8Y١p`fL8KZ> ";%! Q0rE$(ʡF AT ;;tnw[i;[ w˻-Ń&,cύMȌ{' C073deh
+6%V&WڠHJb,aBd|jquV]]-b _,K0G$bIaC}E}U%Rʣvb.j 5=jNrs6=MU)3h.u]QV 7>,|\wrxloDQ:QhK-{upsO`2~4NSQvxddNY#*e:Y#-bdfV-af03I}UNjovUR T$=d8 (Ơ ] IN PC8
+vBj/'ž$oȎ <APp(#DC(
+*""aT$A 5I(FI h("=֞G?%٭MRH%ȅiY:ٺyze=f,ϕ?_~ו'ʻ՜wTwk*8jRSʬJ?ĨSȐUhW0k2t/ӓŴ0. dB{A1\/n&i#ic>`AVAbEROҐb<^ I(ِ҃;P ?[7vp8a<Gظ?Z l,tS<Cmxgm1FP` c 㸑p  F$|$c\#B ?vQerKRzB`@'Bى΍4_,O2| OB^ $ 1(+xH B\MCv΃CG=c/+U#ˣg&-N_yJ֤F=Y IWg'OO={p&2ƭsu=mJ*CdzcMMm!C>[xuB䠕g.=:p5!>>:wEEպ*O}>n_rM<ہ ˚!+mte|nS3~zr0(cd+C76onh=^T9ڿh}Cr L>>K%<yٙ+wW_ҌL"QsV/F%\ydrnٴ }ԩuUϹ{376._M2_d Z=CN$612_FXSP#bi[|տe˾wuBӫ?dTU0(_oߔ-UXT/F~^?-${E׭oǮtj'C3nxṓ_̷=:]Gղ?gk>|}ͿoSU}3q`)Mw/6pjU}/'8U7j_Ue/+^s$~0%W%}of7z$g7{)zu >OUԅïr>""rn=ٶ:2 s]zioS  AH1U87 !/x8xB p|]L1;zۃ=r\7mPbnLds/`Ya_tXw6ݜMm)<a^0*jS"
+)d-8 ;Al_gy7 = no;  _~R05%;빀c؃%6
+HGu
+b@R@8-&r
+pòr("XE侑
+}CWjû+]( Pkg ƹ-{>oג{ۋygKz;k2ɦ6Rb^̬8ԤbkRO+p'7V'72JjE'(r YPj/"% ļD%1GN8FȏWdi i*!3* dtB,HPǧIGIɄb Yp<IbĚbȒG
+aE ջ;9I"y[RbId0EcNcl^]w@w?@*8)
+^p\P@s|@%`0?RA HRALdʈȕ$ANX~(ljR(KW.(.]Q M\ -}2ymX?:5ܼ=1qw3SS {1SΎmߟyI:{6fohG[ky sFr{d1W[cw6VyuzSpIY+&FٟWni Wm.np{^ޜ}=/F7u.ms7JT}^4kw }׻ =k{љ 6' 3!A?]yy<ƂM~[C[ׇqcA{rDo0[/Yh:2峭櫟1ݘk gۉ8G#FbruZel[ ^ r ,||x/o~oŔ/|ႍo3X+x^Ϛ_"%EoTKu65.>ԵeF׮T^+{Z(|-{eۭQs-s?Zxr#1ˠق7s/nTXsl?9WAs/?Ы^)敿o=Q_%E=ݞG~Jw%)WV_(4Wy\nOb0M$\/Lp^!(h&6ddZL&dTd#Ш$L@c-jֆ N<p.x|ˁ ~O w)욮9[޼W$?
+1 H$L&8кffdfPd0fҀcEtc
+6T20IF130!bG} @# xc3& Z%6Q`cEA$⢑ЇB1wvdqA ?i&T8rUOf\ݪ: |W̑/)d:" WS,(4<F5y?Ι0Yl4xaonVfh-a7 8Dhnb~< q#[
+"^4xE}
+C
+ i9Xft.!37sh!EcQI*CsbR,':SDhtzdDĩ܊QIg@-ǃ_߄4z
+ԛap+294at}5 "!'b|!DyM:C TgQ [ek3p2+#p3
+ o@A?T°z .;kJ !es
+КKlfwg6^0kܐcj\b~"G-?T#fEa4[BU3P.uw79\B?Ad] OT=p=7'8~.SpbAnNFqB3[~6G0OM=7f:jfgtͅs謧 D^2D|XGgM8o>!>v^bav<@X
+_EInmӚʷ|IyfOKya>0W2ҘoQX˙?y>%ŔcY[jިk|?dODkN=^u7c}t&E@f!bJ=pU>F ܁']
+nOLܦj'/Q#KT>T;5B8tӶ|OلOTf5.yae/<b$XW1P=Og 7gd|
+<qAyloYoQx}^[4$@}zpC
+=̛ܻ\JK5b]Aj8m*XiuG8;WbUAXUP,Y%O6ebZJA s<*2+d ~$2sSȩhf7EvNu+&⸤\8qN M'A:*Qٹ8^V6В!b\ ȹ3^+ Zs,jd,eYHסbM°i|*ǧZ`g^}qYJB/c 8f .6f:93׹
+g"B!ݭHHLB8|sC! n';
+j+8@v#4|n[!YIٖ((ΌEe䦞Rl9Qp9bOc>avy =N:ڠN8g9.NVhvxA3*ڻTKk։qDU*ey$my(aP\:qa<i4qF/lHUφ&'ST\@.iD2:.\H,\TT:R}ڈh"b Tȅ].9''HKnt|=ArsS% #(;A=AݢGb幁[fCP3bt\& A뭾'jx[|
+ C]Rqo n~C{%YPMm۫U K ]Lۮʽϯtk`ݴȢR^_B! 3 r:Wz)H }$DBεH8z >lO7SW+IV`_<p%ADP׫eHX( OB.7HI
+ E`>pju)FR -!0p\ʺʺk
+(du(C%k-Ia06Ac0&I(Q9Cj
+ !\8UZ$Le׀ a@F(bcj
+x{SVaD%ڐ]ԔV^LB o[?e^pۋE0 B l`@X
+gk=щim:6;`W,:6=Ucs] mn~XsA=^\V]+/ aù0n G9 zn\W-ConO m=ϭ;ޅ%ݽ58ڄf-<~6|Ǿŵ- xmkl У>?xm1Z4l@ ˣ><00C<m=qxA75a= [}/a<ӆwн=[./<K0֣Ձ~ge蹧o}uԵFt<v?rhoNWЏ>r0VEnT-Pw f*_L߹*z]寮ʇ36ۉ}p^ݕoFпY]ڽ^.}vW0)@)?lAlA濪ް*vo,V̕\)OFoﬓKv|}?ynTdF'Po2GȿO _˖|uT?'uLS;Aۗݿ1o=$~2J{t炻+gw>3gЉF>`V5kYQh;o3 !]Sg=Z25BK*VdM׋-g Ehʴg{L[}{.*=\"HrUF9۩ǜD8%8崸ءQzdU4bC 6?S }zxU6v f@p{H<יִuBA]l"q4핍&nr$u|8gP< jI= |l`@|_ 8z"}x711]zQӴj2waMS4F)Y0jnSt[p']zPԲ[jX KQ'hIF+,jn ڤKTl]zDNmHQ-?`~knmCdU+(((9]-g=}߶Eu*"Nk(cйa c )51~9NFWT;NX[8JbuwTq:Y U$A*S72*?ԋ}zQAX ?X/ U
+\@MyHIe킮
+*i@K%H HI^AHР+{ʵٙ+3z;On'yT槭2%%(έ(LOB؝ΠܤP¡M(6|-X=7MHbJ4BIq(rVxpK7}ɰ=QWԱwkj|wYz{oz8v}NtGZ#R2~?v]isTN:|$ӬTss6TU>hŚ'Mјj}uSڂŽm2Ag7֨2+rV)OOdjJ:HUy@O$\)8tUu2!2.j UV,I34hSg^g*zI3>H]$e4#ͨYLENm\`d84!V:_ǠYϔfV1JX+K70VʫKx4p\P$kXF%ْF$!1$̒p p%, )5"Qo3lH`c
+fFa)B $#ٗDOakgJ9$B7ax~Cu1\'u,uv,ET
+ڂmNs)Ll1pY̽<wpM2-˰Y`eF- /MN͇`uN9[~]&LiP=U3U<#CΩI9@hSfk/IbG-(zu`@,?b+(
+z_@f_x{{m}w^P}}SF\x 㰗q{pq6ĹTo޾'=gG`BӁy0YםY X ̈ 3
+[r2Rљjh;vYa;,:@6uO<9aSt'Pڔ1v#Uoqh#m-TH5eU[PqخpF96iRuD5]tnX"y
+}?x+v*㜚mz70ܓrUlvh|Imepb0r}kՍ8t<f2<!6Cii6rZsiVeY:KhfS̆)^SDl4Om-Lu)R Yw:Ţd.hҎ'3[3V٣b4Z2K e#'mgm{l*)gybl%Z]m%cHqK',FE}C'.:JJIŃ3r>%:QT
+`ElCHu8(4l*ЯCUnWPN7DV#R#хť"l\+oSCڭmH=Mrf:b*+eҖcҬiҨu0{r\N 2TyP.TZ9DNQ3qY/$ETA7I80 ѝNmi؝:mwjW]<ߓyk1&"V@A`nVx*mYע_.8h&|:4s<.4xkYl˂{.^c%\x,¿V@EEt~[Tj"M.OGb<g1@#oW*ӅY#E;*m㪏W֒4OmIU*%Ŭ
+ʽԇ+`m+|~b/Z+l<nϛCcz-<2[i|
+Ê[ؠǦ>C i<C> Zx'
+hB1r|E"?
+}p̦JފX:?qRS
+AzYtfqwq薝0%+5I "#qGӑ#!;B]V>R 0a
+BBw };]$d.ߵHȞ ȇ{H Ao+X}C
+w{]{ۃ{~ Gzmn g"oǛM?柬gBnZ6hvD">99
+]HQKjt-ѕ ӓ5/'i;]9O3'xʅH Se܇ R+Y,%el4^>XTN g5tiT2\0jl*^9UJ#^ŝHTq.e:bh%{(J a)^a=^n9!/7am,ݱ6]T~StP6ܩ]YѼ_Zrze7B{J˛CoȮ)>l-ݭf4a6BYʘ-){La;g,i#xڌvEhk8!$.jz::35)Y*7,)]U}9z;`טkgJMճ%Mӈ<h>rq; Kp:E!IEmhprZcں8_0cpxEjL˶ 7iRȚ
+nz9ZT\7ĈQl Rpb}z%%Sůxj-oA/#&G .rU}b:21|z]4\(-c5lj*WAeTAz%"ǴQZ"К ЫЧ
+M ʧscZi`-JdFo"~#aЗ~m
+ \
+#b
+gրr#Sn׾ <~ ^vZYrT7][߽oe?]Bwn_x? tѥ,ޯʝR_ٟиS;k^iݑ+?E P3qAͲ<noiID;kͿ?7,pc'k%5d1sb-s?YyyHYxPH"g-?Y6pr[Wԁ` rwmJ=ʃN(тJH)plN-5}e#b9]Ǹl^/+
+CZ#
+\\M[X &V
+•*aF)֠"ۊ |[+6;X-*JN"{QpH/p{:PKl=_%RdWߡ35::Wi(uKw
+s=wTc=#R}Yj,0K;̥N;{,]t;ݽb]i֍-qGu#j2ݔNըXbڗʡMm cKeZ| t}"Owl{j[mY3?kQvPxmK.Vm,Vy9Zªn_',g]bC)L;>!%TǴsbQDyP7q-ڪݺZ;$! (!N
+vt.
+`N&I"dE)6$<D#˒EțrtU0t:"(c*KYJ"2jH`K(aL%%ΕJ-ۛ*Vw*X
+vN&ӕ¿Bk[$컩IΏ$C,-} 5s Fd-XfNL,{V,3Ml[淰og`v`M{{=9{}c{#dgdovfg`۳7cY9X&df`ȅp %JOCA7޼ۦ7u=ojԦ`P7S^rA}el:`]Ȥ2SȢU6|#9[KBd2K '|c„’`G{+ؿǮ.*/`+)Ź`%Xq~>vcإ" ǨE E{`s)Tu`av #s>G5 8'!r[ Y0{v_yk"{cɬscȍD`3 812\L ?NB+`IpVD܆f3=CKSe2ދ%8뽳]6͑p9>Z ODzb;:{p,vDe~>QYeׂ{,<Z@X}mG+Kc#S5a\564a#;(cY/Zt`Y \Ľ0>k8?}8b
+gMn)2=wh~vVGCDyz
++|w`j8TZ:U0+޼e_o]z}_t:^>xyJ;"rBI_w%#PZ`*]t+K;)^7Mɦ屎XߴH%ޯ
+8~o*Ypj塁Ki.[
+-<K-_d?i FA u"}Il΃X$Aq꿉4q~~h޷Iw&36/jyE.y|1&5lzK/6ꄖ= u #G\y`XCzA]P_s<  0X_LSsўzos]+t F ؆]hdO`XadN>X"27NY=
+{zi,8x(6$szY(EOW.= exLjo-L3R{5nm&jBU.?}R1S3+λV=[!kQ~$X:kD*\xfvìA@E9|,,kj9O" ]kA:7ɐ4u
+ Inest&YZ ( JҨ$1NRWrZxlbtr3F LהDZrN% ~l"RMPI
+yMJ?),RXK$(/-
+E'JC=@lW!r%LٌhP<Ncut[g;
+
+ ة&d
+ÉyqiAYuy%\*VD@YF
+x6+2v^Aa1ulA48SʐF@)ædEI(p&XIX% f bQ챤È°y.$K_!2Ї^- AAh2lĭ(b m@sh+7ccu sz4:z
+O=~-bp
+DpXFT m:۶D77lA6~ܴm߼[7[lGxQ&F뉋!0Qd%C{#H>:s]tz_:($:؝b^8: HIFih_F/=lw(*ƞQ}گP7ĥv4mקcqvbP3zIp`p^#HC '9]q9B[,vϢ~0l NY!z82w <z}y'w-%ZHRBAh]Ka0%_olcv#pZ6|A3}ҿ -jh/8|tgq>N|Gpt{f|elUX0)d̞UvgT7C!RP=qj2uM o7ncYX\u9'jO4yЌwW&:cU?hR}s}~|蛌fxسkWkUܵR\㭕}9Y-;2xs^xf[b[}<н2;X5^C?54U:Qqgj^Xu'zg/֭/Z4RN2!yQ9)tߥ:9sdWg_s]+_L{ >M5M&;3jCv.[JٺQׯ2!D/ѭu<0n** 'Z$gf\ڥgrW]>mfY#Y}҉,l2T?cOSmucqi<wu*qV4<X]k XZu*
+~""qhģZQz/$s2gfGwYA:+ulx._88I35OLM3Lswqu,jpޜz ӓ摁AlhXfo{""Lؼ\flY*ƆY*A}sQ:^~O#wvT/O7
+jC-z%»{I={/ĀYf!EFg᰿^GL%9F$^vPi$~N6\:aGa,Jc>"a+2؎4v
+~3/ľ:Z0q%
+P,61wZ!aQg݈θMd$]
+<:0<B,\I< qJྕb*/\BƯUU%+BM 6S<kLjpCȱEђ-rM
+!r\cl9 $`.&r@UjǤMjj:=?'ie}{y<kyeAviPLt >~E@bP\^CwP޷PH0IAvn~HA;v@)T'0?ʗ`IDٍ3z]W@?'(ۈu
+8w@fH0.X鮚VuiAL"v]+o}1 OkcY!ָ~~Ѿʶ#
+J v<Ixۅ<I\:T"$\L5I/J."/uѝ(u" MpMq}D>ߩ>u2ꛨ("!X OyPͫ0w4GiJihzx]8VWFi*^Uֈ-0:ʴ؊^Z<^Lgy#C[ ъtTz͇ucݢGDuGu_?'=ُݨR2Iz%wiCQb;~Ox
+Y7}I&ZQʷ+n6~eI|mZ!1+Wo2_v9@LJ_dA8} zp sto9k.Ey0 Xo= ;^w &4H5땶g}[DUӈ*n2QFcI9LBJ®J@BN"!&`*N&6#JO%Ʉ(5 qd+RˢTdb0 >'r2()x<v"|=/ل8 ®LMƎLkH:\N #c`䀊$<
+23$6* X2*:n.+0(/*{wa<Db'a G_6o_(K)gqs//آ V
+/K_VrvN!v|A߰_L7o(bM*+õ\}\WP\Spk{MnQ< zEnA"'ˢo\ HT.!>r
+ANvl;i鎻3mW<o`w'<y73 ș3c >X\lߴ
+@A)H`$[EBS/͈$B|C!q) w%<S
+BJFMG7"VlLێPwC~у?Av؅lٲIOOCH"Y
+p""a* %- k!9f9+%
+ƁfMin.&Z{ڪvC@:CuA4H5v C'Pٲ^> `o&C}V> _=L(f#ߋ׉>ߣDy[<qK;чԴ>Dۿ0/:gyαA0u={=bbТ;qGpMfw,jgLs=#s]s}Gdfy2뉼V -liГY__ҏЯy9 >s 'lDw@6mO†ΰdnּGj=D睼;zh ^&b tʱg{:]ݯS7cox~zq#K+eoZEwdž{nF.Lƹ:N#A㊷]?NfEG;qۺiז)ٻ!W_:GZ(^c/#5n ɞZ`&o+حyhK@{B3/ږ9Α/Gokkh~q?lSطcwQ ռ+㡱ohz*5vˤfEf2R<+E$;"w_8㓘s<Rig8ЖcO:$]-_zl|uJg\?+=JOGb.یT1-W-wFm*wǣYD{UhH iKwڭ{x/䞜ZF[:ƕUYGg=/
+aߍ1=X? Tm^:S
+_Cȷ+B.l]xrm*^Ws7+ualT4sM ;-{vC|+[SS8!Ӿt}41iHMC!+tāNP +4i@.4S2Q#b99v@u\]=F5rYzaF]Ru{ *ٮoQ,RwpZV8N{MDzY`khS \0!ueM]& F_̴e<U+Ry;|^'ȼeiguqThF-iD;07Im8ht$icjU{ >@S1
+[D-R~Ly$i;h?b׏G&Mпu.>s&sܦОr9bO<"Q0ύ>ϣW+CUw1#r}f\iG=z:VeS S-pF@A8׉s|@+`=AđcE'GUs"lXQ1GT{L'5aBVE~&Rm*VrϮ$51/8ee^+^3p
+l1"-Au,BWu$R%l4MZ*j%KZ)ْt%ZX ]^.]+D@s\jHWԧJ.ץJ֤ X$^E1-=O/g h)ƯW4\v:0Gݴ<xI!$톇@\bk=0L"#S!RM~dlݎdQw Yݲy+nz*dR-"ׯG6ۈlu!b9"NZEjx_pKA;!"ș#"
+ R<vδEg:{tf_|yNjA ba'Geá#á##/
+s&YjaDC[e,؍&w1lj9ƐTf͙
+H/rLNveKUDG}c ٌ!E˶m&t[?SȪO34; i:N^y_wes!zggN pϘ#\GTLjYW]n]frɤ%3jXv'&܄\ bnd mDPX.:-AtN+ #
+rz$TXMt^2z'Z:?ZEdv0UTmG#7u{De;}gJ]FCDf)wp:fVx@/n4F$i9dP;eT_v,ӞDu,jK1h"[g{_P?eZG<IPÌȭV;j+R"&+>`/וO;ޯ8aNƓ=&q>wG`IJEDn>
+LGLBQNx#\A-,s/TDsoF08d=v6% G^V-.s
+#hyn/c&d^+ ˋEQx-J$JUԐpsqbjiR%+`)@ބbBQH21A-ވdYp_^IQqdh&2 ??)u_\E̺ xY$SR*5+ ymŁ}\%BAnB!!Ir$׉8q6'vЃG)™8AI&N\|'~AA5y9W
+?FBFK
+mxE{4݉Qkh\D܉F;Q<2+WQT&^J
+D1r8V}2_S*uTƲ:P.±s3ê2K3@>(8
+.br08m
+_#z8 lk{cl9:Pwtf ,֞V/D;@t4Z.lM ."+K>{
+ݵhvпԋ9}xc^V|f,D]+晑ቧ7NXWЯ~?{;|0M_̅&B{nF6\cˋ)O6y
+}>}AWAhfOW{aXA'a齤,M_=iE4ϴ^ԍ1׍?w.ޫr<}4Re? S~0Y 'VM6v=s?Ko -A2i%_?ڿM+R_o4ƹj|ds].t867{qF9oF;\cpΚsS/_'߱aB$O뫓|:'uٳ?i'Ϸan{Zl=m.P,>biH?1%I2z޶Z3.md]suBH{']ۯ +
+]Bl{.[9qG<7]vZ{A#H·BqJ-"lWV{߶Dh6.ߣ_sq]{ vоވsvz:a tܠ:T%1˩%أxۇC(֡-!RP9VJ#
+|?3Om勲5#9vT,"%r%iy-R3$m; lRA'CS;3Ϻ9φes}G}0xX 9BYӸm3ȍh&Y9AP;ÄNU7CyϵS]q )lWl
+[!<ڑKЊЌvЁxZ Vҁ&yy+0J֊xEy5^^MSVaexQe, 8G.'q58.\]1\
+ æT`8$*UtaX)(Mx!/"0mPU8>0^Mnm^].-G Sc璫p2/j53 H: >gR=ɪXI3$U AUR8WTY
+KncRy̫ 
+ZC[Xj2^VNWPuE8QYi}'ttK~R[5s \m3WCw=y ͗hh;etg~'Y`d {Ĕ k64vfLcCwvG}g&<o7kizt]mWAѦhЭ8wUuWOU׶$kjP#K6S 5HNdhlN20XG vIO42FzcbyH5nKbTdd2jMHU][|ċb:O8?IH89x( JdO#` GA0'ɘ$LDL#G1Iw3R; c8_â<wJA~h.sh`h j=D{suq
+!zIIm*t  FN
+4!'}Y`~g
+b."Qw@+2V|Y;cWO,L  U3p+ƿd;X_XQ6ʚ s9VPu9j5GI:<VgCJ>[F1ej92=v*IcjJ2!j\GUD??i(<%9xTMu{HqP''a4HΓC Q׍0kCgh-c⢶{an:=Lןb`ilU쀜*ʒ:v)}rp{JGZݵ[JFST)*Ż}=d>IKJDBe/ dtyC~i`A~uC^DWvԖ_;ss`6ı< f 2+0А?+_'_zsYLᅟa
+><9w$81 2TN3[]Ѱ7i ZyayvYkN[Om jع -4y T2Ѓ`l =9kd9}_._=Z܊X7du]
+"+cf݁/SاKcgo킾ǯ{o}1K }@Z}l glǶ58 Gk{Gf,f=#a "c,}uM&/*۞s5l/aeT-^\b?[-f % >GVH0$^m&G.g)_/j^|2WcEߢ/]>zkˬwߚ*n;zwv4Y^sEdN Fýٮ`fHPǮl:%K)D^l[D7_gOv_AP6Pxm-}-Ұ:.kXOFDÇD S%]G$k#O[b-&4vJLYOЧ^ d9P/KPݒ3Ls(WHU>6EЁ.mDTzw5;)kdeBѾf¡DJRoW]rp:~K4N}9h"
+DhGXwlt/͗DsЊGCdgt6l 6漕=g3ۏ#c,䤃#? bomOCGm0u.Axi1]u>
+7l|SF`P[1Tg,|! Sp5{AwA'ILakഉvjMF?Ml`3냦dx#xf$s#53::t|
+]7{}!N\sѧ|5~+mDapcw|Bm/3ۘ{/H [@. ȇiXyiG7V^2կ51`ϸ4_ڣ( }|q2IYݲ,7Tn8UzKq{C9={/z eB`BXsH?%:8!h0W搳FpT~Q&xΒN6H8yHwKxXtw9崝4?p]P^e]6v}~y05zv^]*n'`*{pAkM+z:4xf;h<.3`eSjSkypGdt}3] Cw"]<Q7G
+M ϰՋ:x9#^jva.΃ #N|Os(x#.PxKtE$)Pz3MQW!=o_ɛ.d~cA#p?h5-ѮK~
+=AKDЧb5#̠jq"L_ԭ *.梊}u;?H:N<J맘Fͫ\E:"e? ܗc0p*b8. ;YEt2B'*|
+#OLgpedfaqaU'O!-MVEh9mElkE ZĚʹcL1p nj<mz3񠁫8Mi:>mzZa=ZFn]/Yhأb
+Rd]8EM nh=)BVJˋ0-jl٪n4*# IPW;{ܻ|y$=FOX܎{ nʜ Y\֢\h.ʠnoyBI3([aZI$3p^EUV(qp_YܱpG%
+J~ܤ,h[`Mr 90;qaЧ
+ ywl1QOSH"RPJ=[PLRR+m2v9"ݡ,nU gewk|١ vKTRd*{OEwuTeD.Uv1=1LH3ОЖڇ)2]>Дjrs8Ft0b O"}gڪ"ga$ibN**e+-}'ZmL3}xؚ_d-[dBjgz3븡=iNX3)sLs;\e8UWUS)Wk Hdiv1iD HdBBBB<D"|HD2LJ$"h!D$Dz)0, 4_5˃m( a혷9ҋ{Fg{CK+/0 t!nw& _B._oC.['<m ' φ/Og:_g,ͻVˠ~XgX/xF_.WXt_,6
+l1kau<0bpagŏߘMۿYVAeg m,C "t>qv,t\{Az(;
+⑬^ *QW*rKZ#(1s 0 = 7++UVl$hm%Uq7IV*|uuMM^\WV+ǁه
+
+wIXGϓE}9Ė *S_i ya]J\PE0R4(  [KAi,"^G7PMX#EE<fAذ O|<ǝkS;\pw%i)wT㺂a2p ("
+EˀRjD. GʃP\qr_i@)EbT#%`NcKx3b~1=,eN<jSIzb,Cn,<q
+p
+L _ȆačjeH;CrGl,^;`s `?; 099=6c781tn<<lGN:s llg6gX#܅`>O'nOC? kcqv[N@#Ō}6!#q9]<{<Q@dxX0?ys2 @ ;uIo,^O1"8 ;"<uu,TeTwdGMj¦HwoF;\n'lCAS=5)F:&Qu(>Ч#^Ch , #RHڟCΜܒEZs<;g@C%dW8#h,]?~ 0y *EO7+)t iV?Ӧ |=l
+EmPS:Eα*yY $ d<hB
+vT3pԮM{þjdwNo`):TIZ[6mBOZD91QU)EEl0h5tV5IGkۦ 7 D QOkbMJܮNkFڭfRLj
+FqzevE#=Fu`LMP浛X\XΪܟc<MُSq*T_cW_ɚ7ze,W{n25T߈l߁VpcV%AMb&k8
+QW&* PE-f$hjXxXDev&jI-:V" ٖE#[$]ݦ |nlU7MzzS>>mt:ҭmVO+yHiu2ۚ|$NY[cfjoKH'qO/D4K?j~dNv=],w7NhFS4M9!;j[jn$uyBZjnWU݌/'\.&Jg33y'9?9N9}]BTB'; ; Sv|~p+$Cs=k.(n>@s3l a5dx|;qXbdhX)]2.?+/S8O|pfO+~P͗_@UKWא5`Gܐسh)63Ї;dxL
+ǘ(Z׎"("(8؎o;>|v|N|m'8s8M4iӺMkU[i&m\~߳{+'qPօ/q35LJC߇yql}3RyRubiV[҂b[tN *7ic
+73cE%jCb{k,_L^CYV]?/, aCWدӵ+J2Q\?z~2WqW`^ nUVetq)xl>S~P}5PeE<2s,1z @Jp/U9Gܤj? _
+2+: Mi]:]R(gFʎ:DgFTs2|)_@TKi+]*&pWVK'IKf.vNӔUj2ڠ틼mu<&(=IOly}DzIx0=qav5u\֞캎Xǯ% .[%nuSJnF7Do͉{S!y<(#h`l5?0AyŲ/!Yi5дJ{fjDs2!Ē!;(in.[8{\2'*$QG@aX\jIFO%%)q D&uw2ݢL+9s"Dvx66K0vve9-.6}MeEŃ>.uGX1wMp-a~`+mm5g ځBz3p 8X1 ⶆ}!z-(
+r^[Pqq}VbZBwBB`D yurHl0E!`5Aq#g;tJ|>c2BI5ȔfF̛=Wr6ouP$O$Qđs'Ya$y,<6Fo=GF2jPFwuk UjDC}/u;k=vQorJ7]㢭^:3m:hj@ӢoJj ?ˑ,>* M;K<49^"?2=R*\0eESn` !PX -p1\pByK>1BsBx!X3-LAS,=*sA4`V1ϋ➕~/idCXߧ$XZ;/k˱edEmo1䍰yFЌzӗL0].:7* N$s!uw ':`I']IXn?lǝh(,g\Y4z59Ov'KM2Y2 h2QF5H|_; ,Sei1ͭZqP;LyܩJЅh&DlSh<.E4(
+ԠZ2DcMԇpOQ#Q k
+VpTh0]?"R1r@Oo04HH} :Ԑ5zAfcfDx2YX=nьa-&+50`,x@5(fyBa6;Xt"`>ij\vjrPIsQuNK61FӴ9誽0SfX=TG
+0}C0qa9LvB =p@I=zukuw=:J7C\nh7pu޾z_ z]ҷ9X 9yW)"Q^.ḠݤB4F,RD+ti%>횋ՙL2T8pF1T-&WK%t]yΓ2Ӛr_}LB?T`
+endstream endobj 48 0 obj <</Length 50307/Filter[/FlateDecode]>>stream
+HLilǥ51 nWd/+UaIӉ\c;#~Ƿ
+R 6쐷H6ah-j8p+xT{?oF 6 Y#oV{jA׶uBp.m"k=7<'aǗ?fT909WV <ilBi$RYE4g-m[e7qӉJ^7xH xZzk%632rʯWψY&)xr3>|W(y44 yv`(rY]pU+C)B)ŧE,m|fu
+2̯sc*G25b,ko~+^;-&?U힐z>vݯ\ M,Vjm\f,FRf#'nB&N0 "u\Ce[Hc !cD J=y#L
+$)u| 'Fb&lX S慸
+x)g}
+rd'τ"_bDY8W
+>yKT>ȧv7z(
+t8X<H"E(g0_%IFT"L'‰$KY8#(%9$D? `|
+䒱@Xԗ
+G qnUtųaY٨xze#3RxTr~L鄬x*d,
+L }_"/,ts*׷,E-AtT4!Iq :X#xԾ>:a)\:^RDT mjߥ6ʣv"Qdw(;t lv}Eyi"o;3d]NOQtSd R4we'ޫSIwE5p@I9~==gc[Fg#S F7iF-]Ш zcZ:簞6:爱s>lb:mۺ
+ˉ 86sVr98's~̑ye["`#nmph.*B a?\M,zPL7s灩6:o933뉅[¤0 91˧ϼٍBn+$䖤ɴd Ll%m*:^pIc3t]dgBBr避W/Us$ #>='螟u(p]}?lmO'b.;/qB4;/3-i^bԦ&
+5̔6~u3ŕg׾O_t1ӿo?u1]h_Χ؃
+ț9=;xwQׯ`Y'!_+AB2Z"A&PABTV8_L[ {'E0@ gh b*nlf0F)T\2 \($Ia( CqnMDcH
+ -;8MmA#/ӳ1@E,GΗk.FDP^&֥zLw:ݕ3{f+{f֜7X@$l3ݽp>:zK`\*T QDIjԛS
+ %_9 xXep
+cG"KRAN
+<G,pHD`DXYAbptcRҳ`-Mok&kM{LՖ22d;rj8=D;r|w1{N 6l8ϱ.q[8HMo|DnM-s3zxeȀ;lAϺW߲^2<݉٣`溱o+fxư˨mڿлTWӤRk*WQQb-*H\i/UF**TC;nVVUYuxru+U6ٓjuNT ~]UTTF1e[j.)Z.l՚]m)?7f{cwZkmecMme&ݞƖ m{ADaF[jm֗:/7Ba:mSs\i\w
+܊D = nGp>!
+&kX*`#^Xڠ:=iq~1rcMg{I^ؾfZ9+~c;l_ՋcHbK}1Jm ;݋"涄9tBy{#ȓc$!)g:.+ۋw_.o{sո} R^cdlI7GzJ -ŽՊž塻?
+yM?
+d)1}g@=KI8/
+KD
+Go'x"|=9<D?GpE 57 މơ .Fx  )g%7ݞs-:l1kje>0?r}oRu1lHR2T,UUw{f7EϱY[lFV1MVFl{itě-lf~=ݼ4ſ|]Pl.Q2(ʗ18R6 ,1 w9o)V_-_g|P3u^W=T0x~aᦉ J t5BU
+婩!C>W!rɚJɤ"_773Su" /`yTMdp]Wxn`p` }NJ+%FESEzʢJ{aEܼLuf匹tIQ:Kup=٭Yx^X<_/+6I
+QvX_h8Y--5*甊-g9ge}ŽruAU=mAGyVQAtI4h%uJ}`q} ľsn\7v&`u*JQG71.R˄[>* gNcJ
+]"$V h%P>5LdiE _0C; W(+:p& gj:2d4MY^')<iT.1.CO$Kɜ'Ȓ'i_`Cd@&Q0aut U#P,?c<&n>'1Kӻl7ȓ;ӮvbC6cխɭ|d)5/9rhnCʥ]|fqP5dGU}/ƈ.֦T-zbeĒ轂pksLy9'ε6yf _ͣ?,aˌ']éKRIZ)eUb*$LxBq-E.dcѤ4=2^KUR %^RWm_ܶO=wR{7n[gd$?w{{d_OGũOV_,psbO9#S6&I/xo봙TMɴg.o0w퉔^F`֌h3#Oۨk7e`L,=w%`yv-y#53gZ{$.Fc8p dסxNŐ
+`d(FPI5
+ɮN8cR1pڨ=d<{
+lVA^ww{ȏW['| KLFzfHLE`o3=欥j<
+Wgdo32C|x2cqa 9o ,!;<X6 }jK8z)TV-) ӕKn4FA8&yw
+ ~-`l,XpjeϯMGY8[duyMW4V5-F)TL&*v1\/uFv
+者x` 룊0.  Iod;~j\D,y0|8KfmJy `J`r?_pBn{+>AY6eyAބt`L{Þba: 1!ǔ}zd#";P`;ґ$x.Lam c(!/p8}x a~Cjhc#=w"?IR&<e B?]$!Xqg kM`"KHȆ c(N 󀭐x% <x3l-[{|Ȱ ޱ&+R@v׉:fI;c҄+ Nװ4Ε~kCnNwe;);왴>>v%3u2via~֠d8饘ech9cCz)Ֆ}M5_=gx,<X햟 7
+0"<3TF|TK'${נ1$c(X
+t}, tӕz칀PNkfeY>${vSlj[kvOY Rk=uڠ 8«%Ή-%9i&M
+9ÎIP6 mdw _k{е'Ѷޞa?IjɷHNN" d:PQ TB\TםM-o QITWC
+e]#_G6T(\%22V*TDcDRfVfTZOL5U7P.ȃՂ Z׷dkVN5
+m}MŝJ}jMujBZ#Z만;N\m=50yZ^1JUFɵY8xǛP\'ԋE5"c=:|<F7,U[/eE&JYRWiԋt M"sW]e$t^ht~*<ۊvAoVAߥsB K‘:y@X@.0Ajõs֘-Hθ _Xl$Mly\cS-3 VèūLo-CȅRWcs+C07Ww!K{'Rn'=qƳƌq?UiQߝn$g ys~cl*ٯ}`>dD>>m?[ 6+`C.0+Dٍ B=?OrrmA=m&qIXJ_FN?p)}v{?;/7~um!9whVz=݅3>jS]²eCKkiAak
+yș Ѓ6?z,iñ/d'Ig˩;֔5/b_d؜5lvl0V>>c,=B#a0>׏ki܊|3FCN{pc8~ )`A96V=T&hT!:GMDB$o0&D砌>{N‡'YBhʒ#|Gmހ>jpP&Rq=4
+`?q
+ &ې4Bld!TT  @$ }CPx"h^ƒހ\`+p!?=? }c/ XP
+{8|n| oF?f6 1jcEf3l,/Cy2Rē#n!Et/ V,P楈WLdk W(7ZO? 'qEǰ>joK{}-S5`ΙHFWy-=_|VHsrOT2b MRyP9x7+\p"4GtG)>ӠwL{ch
+E}e؈(_D!X x x̀KmA>Dc Y4 lm<ÎCv3n@Jv_VzR[u/}?~ vd߿{Eߍͥl
+9o/:,ϙA\Cq
+~|wgMB9(JO9ch/ C_MW'՞FɿG/Yr(dt2΀}[gռ_Yi%K6C264Hr|/Ri*x];c쫣CW.vhtws#|<dLFv.}:fs}9x2{a5Kr>`#i
+LR8 j,]1 .
+IT^Ӏn<=(Yp<s?p FD{Eg%8 lx.,\'CO Q?i NSi]s4't(`^h^@6y^*+:1M,!$4͍n0
+F!=X0;Ka<0>1:#xn!'i<7 %coR3lvEbhӏcOE4l? Mp~v7ACt0@'Q?\Cf{ '.<`̸?4f\ѷ4l 8[4ع<cPз7d<"rRF,Ce³5p<>4֢C<oxƬ=4.}6xoa}P)c%iU[͵T[ZXuЕjEǗթc"Q!JĖCY쐅6;l&vS7M2Mz63mxѴv1 074!! B8]Zi} t&Ng?߾߂ݧ]{oߓAA$=1h{  XrȀZȃ̙v뿘iiMMC.Aya+Y%d- Z%tem3M s^LtW4]ttIxND6]xMDwhJ
+r!FEsb(c"4awDHp!m}3X1~gxqer@-YOhO>#?9+Z7Yhc6SԺ[Mvc}XS+pa\/m海^ȥ-a=m^fߑ:G166NPм:Tӝh}PZ$\.n_{UUwznuTsUDcuԝ\vɉں܉jEZr࣊rPխCl\=T\=\" D_VWfnd+KgKGѹ+d\#9'ou4bh>chyRݗk۾7WW5/(_)^ST0_ۘ?[ՐQVUΝo/Q4+_64j*O'y+G|m
+ihi:elo8o)XS[oT@u!v|Vu\y8ZZjyV':*%-.\[X*+,݄eʎ̎aB]`Vm<N:<&#lSq&JϘJ5Szf@\ vxr"$h 9 jn="XY`0UW`JMz2n_nDhyv50`r5ڈlc6YN C5qYlZOR8sB]K9|.ań2o<>CIA΋()X >ȐfLs$_XwlFM&q$yI)/fL5ꊖG׳a?Ҫ?&} 攛&g:6=H`Zz7=ZN"45>wjj/i
+`n3<^qk/a'Vw-K1鋸-p[ڋ,‹ORoz.D4.z̷(</~ 3i%bVnx%>J*$"nԞ$Ip\F͹{6Jw,`
+rD`voͧ}2;Zf>69Xl ]&y_}dF}Ug{Dn
+;4%X?ە<wl%8X
+%[KL]됣5K!@Y {o
+hM#P|B(g*Y }3.] 8ipċ;
+8MTvgpJD#fqqIe0NzsdMɝq!-yLz> >vdE%.*X\gC="8 J碈 ! nCpGbsPP~" ¼QQ04X v;ҳV02Lrڬ.a ?/ǨH[塡Bɖ3ʪN ܔʋd7dQFXȒf).bp}0x-z<# acCd%`c 0Cy4 C[S{ݱѳSJEGn]j/5pͮ7&ꝑf9e` e;unV-\_~[ì1,1Qp
+^q4{Iq4u04˺0/wX0m9
+bZL.&?M@xxJYӞ7XZߐu! [y?)YvdI'`8fI6fçfRY05mhˢjEY_|ow9ZrVS;ufTYP[
+X=gPugfQ|e?~<ٜ9T&5̈́v+jf)S*(Ye]6XƇAh'p2f|rYڔ϶ICo~ `<oМrO#{z磎9Q+ŰH
+v̵g?MS;ڝ"W&zgq8^Y-(|/_4 ?$m65&#wFxѨbh,yDULpgh.!Ԧ!y_ Ms{ !=JZ$yեGAPZ?DOp򟫱+?0)&#1083}\zj
+O}'{'h(f 7B [YK'1=#}RE~BחsLjHqzeSPpR:(>1B~ۖ ?E>i\ K
+B U`8w܁oú9,rRI6йw 4ȁ`BPo`&xr{<Ixc6\:@Y=`-pX 1`;wl>v_h`"P{}ݲ ޛ5`N`Diz!N;u ;-(FƄ{#sfo81"&Tl͗`
+˸]oz!0#_Ɏ7rWzW=KaEӀq~g~9L>dWƸ/d ؗ>ɻs]oJǫk9UŜ+9Nx|m[<KkOQnKM?O;7x88rDu#Je<]jOqvc`T!2X㝟LN>:?>g&3lN'Bx;ɒL/>M2,! m#C)4BY~+x0,f03Je.>X^Z~Uɦ7oujDUʲ\A\*p'Y;uXe9}lR)/0̨ Nja ;ԧ3'Un\z[tKT>tA Ia6z\ckÔe[Ce}g'ߖ4)xcܱ\6pz787• XfmXmf
+A㦅C5!WB5$VZ߼* c06bAՓ0jI |s_R} HIYXdžJ^)]_)]OIMW]w\YYl-˗qh.[nRc+2J}%Wv'-S4Up%\Ycw2o&WZK ks²\aq5g3P*xaq []k(GXYu-WT}3ZW(*ǯ>_4m
+B.&DmJ`^J3Ϳu\/o(-_:j!GC_fkV6[9mcMzd'#坜O=bz$ŧʁS[tDbO.8/9L
++kB]tɨ0VؒM#o.
+l|O5'ӯ\]je&w²93$D^SԸ/)y%F( =Tz^VVaf%!EDTUUVq`hem]/CmTS@A0"^y׃_`~ݶu856w*䶫xPh5Պc1d4ct0R?b9j0K@(*Bfב
+6{ת9s}Z rxP_3t-ndA۝!&9%^Ŧt`ݤTNel2Oy"Qw rfA9Dic ́ې%^!GFX8*c <mئ|tнgHN7Sz>ȐhhgkA2nYL!cչt[u`4!tz-G$g:Z4$OjU]
+"Vz<`~Ո`Q2.ƣx<{v{[[gdM4Q&o,߷w{饡K T]-[GVO?İ_bj`e 7E;0t5h͂¬ 3R^
+M/Q,bJ"B xN '8@Ԥreؙb;o|ke՛_w^ÙZsk{8f}x7 [7[7(o<hoct8P4#6+3oL@OZ>G(1O
+ǤX%HoE\T<HcrX3Zg;tOk\EN`\`~)`+836'b70gߟ{w]:W̗>پ/`H9~uSfr3# t?=7Ov^1]z}g.`lXwpPwƫw idH)HFXuQa/a cѷh!r/C^| !SЏsSVEA40jQAh ,Indw?q/1ڻNwKn^&e?6%%q/FITz~TrUnўq`^YW:lFLrjԺ.[KN EP M7ň<b87{G}P;vH /t5VW詚Cj9p=m'h?~
+[:\s{'wLځ=7] .pg>@8g~wEZbw_vI~n:3C/hs,[-B&m$/`M?g+Lwd<ر6_`&+3-n.XSOQu_l,?Ŵ1%֛SۙJݖ0 f!K
+<Sz!zEy/B_dUWŖr.ezI+4'F:m:
+y[`BS/I1E'vV2yTqω_)LF:Ĵ>b''W}>S=նrQlZ=-*W2KRceQ4PLY2ł,zGU,SKXs |N?`+Dvǰ6JS
+t<bv&C6NW eUѱO0k3p r:9Q&|•:`AyA{ #BȞB0lp :0HŴYʄBuwO.Q-ك@k/"}muAOrYw<Ԏ {A٥ō|IƗœ` ?.
+(?`Ӂ`>C㝗e}ښukoÚڭeSnv3tvG;?ZwM g<lH${d{󊾾O <vF;b/@$\W'kaA8)
+w˥!z{
++e?{pd!'t乀It.k_=XR_MՖs'6w<Q:yԡ
+Gcض7Սu@SbIx\({9>X6XKme z=Wz^[J~OD<@9JIOxtGL #ccWo>-D<^Iu¬}e!=EҔCt98X;B۽1bf&9̫g\LHC=cmkChk^V6nLv{=촓}V'v}aǍ*֡ /^yڹto*WPQTGf,'ŽE{%,aNS]5O` jȴA`ozIA r#^t8@,= aD=. #{j6G4wz ga/ndߢKK:l}npE>!.jd X_p3s5muwEؑ.J#(Mfe[Q??t\qqonaEݯP<(GC*Q(S9P>vvӵsϩ><X1D ԄͤJ=3ɀ̲Ndm!3-Amhw;8Gg4_QfV78=Y i p@=3L؜Y+ANϰ4Jx3,E2E`/T 25"g1L<ڹEmI)cG$
+9j)더OȂל)!G%Hjy0YBI@Ph~kA u'@ڑp%g YLK(f+1E؝4g^6yY0.-0x~G? <lZk]ڥx{.Ͽx{Ŏ*7_=ls ~K/GFLzu≙X!RV) Z8C673Jcc1W
+p+k$c1OL$R!bA({ k_jғ՟W}/նiMRh{ȷkX=*4VGL U\m̜Y% >%,RA4ΧY¨y̮P\!սNxQJ_63
+QpMSB| H.y64Bd5!,n^i^\yжҦs+UGQs9+ؔ<2JŖ+l
+/꒐@y'}gqA5ԈQ q(TG6!D0]4f2Y=jz6$GZU3bV<hoy3=|cf@o ﮉrLƢxšg=/u #ѡ+vw`e@BL؎L<ב$ʼ9m[pGEk M!"Y:r熐az.?u7;׏!n=Dϵ?gw.+/v&w;!z.vtP9 |SK;./t^^yRspuU9P^Y&\RhZ*CQyei&!p
+
+]$Iu$)6:IJNȈ4H2agXH.Gs$|/ Xnbqlž@^O;i-a){PӄHCfOɔ
+!?I0Z@i$3 %QȂ~ArR(x jb#ء"*XRXߒ@V%Cud'#yY q35{o8l^́}5D݁7w$EԿ_C\= GW#Z7:0<*P+H2+LpxG^
+9Ho8Y{#? Pt (r*B&"uzX | x@/"e#6Eo#DNI2jDӫ&
+Y6iݠRm˳QrYLJ`:<#KP[Y6GCŲ?;o2JL`3,QZ/ r.(E/ `AϪ$trähjbu,(wQ "O&K?CWZʸݖ+-X;S۠%Zˢy^(y(RZeYƾK6?$C/ķyoYlw}MF3 3EKqRߛ'd~FIOp%;LMoWqck=7P6& _y V+cKwG!3/!ZkY)gWY1 k{@]Ocƭ9s~#qn}e99j:>6_3FNyu av *X Ӧg%b/X rz~Zw}N+XTjCWըm4yr0?<Ɍ
+q8.Z#7} c9?R[A`!:* &VM`,+,;T_~ԫM}k׸ܰ1(䍼@Ai
+ 7n b;A.dU[ _p##[2
+[$bj[pX2i:^ʱJw *c`;"Tv6U#%'NJmT<|
+6"|=VE`O r[ Q9&Am[rE/[UB`6jD1&|#ÁQuhǩY_?'Q.8Gm
+9ב
+?ʨ.UJ8F_ עب?<ʘ5 Vs<S[㯆|?^ywmzΑ+/"k&;2ɅNI^
+L)M ĀMZ1bɒ%˶|ծV+iW겒|/`6Ndt׶VVwjg9=|gJl5tlY'QfMŢ]D()A`xxGsQ2员(lBiӎqx!p
+R_$3A4YfCں|KFkuW_z2{Z}JUw[斉F^MSMDدh~SS1y@=jj}{}^ M ĈdKh8%Q,XM3 ZMwu{kk/n ׵'T#W=CB `'BD<CX3 ,(i_pV2 1}'&|xNjH_׾8YY\EY!*="4NпZ}՗u='rKU]wHyώu`8-L
+33C5ˡN-kd7a,1.B1Tċ[妌#2g-' (GeSRGOS~d"v#]\7w581_Ekq ȴb;L&<#3-G+ZыM%}5"y7> 3sF]ծt5[55Ե'TM'U?ReW'NW?9󻣪'?>j>K%-gmIkfn4@tEHXcK`
+14ƒqRMMr]tc:݁˸:(=JpBDl$<dW?C۳v>X,4{a1,M DаK9P'BOxd9O1 E<.JK<Yg-Q2x-1c-ڳ,)R!@S"&> yOr߂Yj}a6q3gRSŃHT#"+rSx>LY4O ɡ /!ĴxzV3>. E)xIY5}>!>Js\[
+*JWQtxYxENSѹOY3KmqNd,dtz=`3NlOD|kG/|?/VKL_g<xMW1 >uI+)-ތ臅t&2;=\_QزC/B D2}A'{?zԹɥ+
+ɻRsMsvIJ uG:g_3׃=KPJKi'h^>y:׻F2<x&4KTǢ8'ᛖ| Td!AD' RXN|!K,Zo -#*> >s2pXdvewJ,,K?{Ʉ`M}m0<+}%~cŁxS<
+, |Y>\S,( 0y ie.a~eSrLQ&8Is
+w.`I<T/)`OAxDb
+ƽפ!4&M
+pvE"CEy*qdLtĝ#.d@<ﱦ9 N 6k}EbjqW0?,#t
+sɠ %20 mB19@DO .΢]T+ilY5C}I2 N|^j}SwWגΨfY7Ƹ
+tg;bʙ%:'CyɇU-_#S Xr뽂S7_̏ɸZ)-zMR'.MhyYqաmE"qlV
+#߭.EP~#(GrJd!e&~nRۙ>ʼnT{ҖoyNq pseXlY7Bp6.x9P .F"aYGsC})u<u;ͭD_SUÚ!glU,3:ۘަ=lkMMW߯]c7R.f9g%jҵħ,${5uXetFW?~t1{ᓖ\ǧ-Omj?>=Uʶ;兹J.<n6g}/ͳ( <U7m }4$%gL},EZ`~)LEEd[ȿ`µ|\Ny*Jܼ4%`ibfv C[Prғ6r|ܼ5KV'TR*|1㒵p=E[g*,b3i<A"+I2X`j+22K8e:rMdQ7L6fEAٰ淇l]V[ س W v;Ϣ v`A(PdP*_
+?hXs`jܔOs_c\8]s&l| hYPDY2`AN4OjH8)5V|ZIsKY!5 שP[+
+?wVEn:F O ?v<>E_쭯z5kT)Y
+b6gی=NnIFU8.GUhiD)5n zG˂ b8~DJi[=l14N֭(X@ۊ u*oC%Dїͥt9W ^J5#딋 &Z2=3[W7KμrM%\[_Kք{(ɭ-m5l]S2KDΚX)65KfnzDog<wۏ?o,(;9ȬՄg}]qmBvT+L$g+SBXo-Eo'>-"Kř?um2P|i{8O~Q5>%_/ǧS=ckQ{n?c/'}>H'&ʆ%FNLh)Gb <؀|(pbu
+Y=EԶjT?d۵Vgt>-&njʲVhMekұ!k7Y5K'b^O = F[t0iW`UD.
+죻\kYtoeڴM Bzsp!8pfz{d@8N3ƞ 2
+݃~݆^W֡}"s|RT t`cׅOXpsw'M2E}Sr|ev tMŦ tj`P9X~
+H`
+gh`|([ot Ń \enyܵk<DNTB/d*zh>zgknPd;}(.eρk˃izOoF}Ȝ`¦{MƦaM{0~{{rp \Le7&9My*VfݯF, _ُoX:/غ/?q?q2Mw{,v~g&{o Û~bs[qK
+{|1!Z@z݃? Y9%p
+QFխ~v2wC<L#~$<.oX[/Z@ΚHΟ{Zۿ=FtLGMYzǐ Q??sc?w :_rz_ݦ; p?¿-uO/xkݡF?pw00_Zg_ lOv'aTD$E21Owu<7ao\l=8x͖[jxT3+#ҘSD'zrb'M0*/
+fD
+Q#dgx[h#L_r?;uq[}ka.g؈g!E
+L_5i 9'_4wY_o_h=8tA0k^m1^9T-k%>)򄏣%",1}~o(n9<ɺz
+I{5 H:
+g o5W9*
+^@W3Ʃꯤ;sR,eF%_N .Lz n*
+pv`b˝OF?q|nk0wrcoiQHj{
+_}swϸ>/3Ȯ6)(zK ,mKeMS;^CG]j+ixιBl~@gncio#>ݩ;r&/ U}6KZH%Aq[T;`r.^ũdAf0$*fHJ=ŦQ g-\XBs -97i׿nj<}`{mˌm0چeDQ.pv~ϡWPlM`RWpV
+R2]Fw?ˠPQ4zӌ+׊+Yv6 a9G'0
+gPZê yف+T3b: #h`mSjͪ x wMSvu@q
++%yVER6X8L+`/AJkX
+& B?DN! 9WvP7 `2n`ymqFL|詑D' K~ έy?KBA}3b xleB _v,Bnps6\keXTĄe<}'UIX6;+%9ײ}ѭ߇X
+9
+Tol$H㚗RͨjXNR%JYZڪsxm?.-*M2x37%k΢-IPPF+tD'*Vmp!r*X,}Ľ~p)JLrow񣫝9<UhZ)Io+WŦ ~Rg9g9Jɇ2GDfk"w!p:oX6uRd50#V5nTZW-0a%ϗ)b(+8²eMU ]aMdkр:ViY
+^y:2y}S:SQK|4LZs \pSwCwS@z}/^iKŽa
+YLiɚ%
+RnB-. ]y{vޏWwjض3/Q="GR*TXCDKϝ+xL 2E_m z˿:kds4/SUK@Aߤ;Wg;{A|T!sk&璚e^3 guO~{G3{^d2WQFnP' 9fGJ+䐰7mL]OL
+@0Y\^
+=ӣӔ/mwgݛ:>uxqݙ{r^.݁tQh끖_u!czgo5e|"'5G/R|#CUMb5[c<`DYۛ PRN`sd+1e*a %E43auE:~gA#/zo|ŮM^v]O|p7w1@ V_q$Hܦ73G!zoSmf[ط챽@w'Zo<|УcH~ 3X )(dDSaV7}:_ ڙ7z.|n8ԹxHdљc5!3icIϪAfifx}qaG#ٷQ0ow 47~>pP̦3(b-M';Ӈn~n놃.]8F_'> aq%H 8FT]P/SI}[, h.A9,D Bxn,F̳x"2'OEރ| P~jJ O pY#%Y42Lrŵ4ҌӘE8weS7^K峱 E=JnvÅM!Xdd2poz4R8~3$='&0ٟtDxFD8N*XB0fxBLHi1"PH乘FS.`0;G; .55&YÄ8ٌ81|-&{.c||~8|kZ+WbJJO }+/YNGiW{f;\A 6 [of Ыܹz%UDZFNrao'<Q~E=ξOm,y>Sbǃ UELʒc^l}l=TTh]`e0 xs"rgg\9vw~_޵Ҋ=3m[Tq>*=!JdaDk^`κ^f
++~B_F
+UWv&Di/Byb-OpR12_^1Mq'ŮQb91g ~JY\mO4N}YoTp݉Ϲք9^Z\{OYf
+W
+csj./BP*ܙ|X7bguB˴A]vH-bL17-+H?Q,NJPG3yBŭ<ڜh {FLe/lܲdEږڎ
+rDB[.{08z\A(ͦpa\HoYFz0i%Y&0nX(W " afe~#4?c1wBGa  W%̕'/6gM^cU+uu`*D;,m!isEfbOw#N-@cL % `6OF(|P>]~eZ&
+U[e_؈5Y.r: 0$+
+yY1RUaT9$մA  <YȀ)uF?5gooߞxo^n…뷵rk=ۇn9;p}9aq_>i=?poNO)< ,{<u%iJ,XET&7yf.A#7v;w^kfK_q^|w1{_(E:#P$V9ۆh1nBNRTQ=LL׉0ݒ z`~R*M'zm^mwe١;5pgljo2l9*cq MP~*1~03ra;WΝDv>u_ѮmI|~1u@ʐLP s'!\ 9' OKQTfp\qXtTiI,{p!" 7e2 B;s\6DPb&Y:ϤB0t$EuB!k D9=>I)~+
+=ºZZ[Vz5>!/ҍ/sMgz[f~q|~;z\GBtb
+9Y!KbAvhnr%W]e2+X5ɠU+*ԮF>Mw)[^ɳЊɼq/veJg~t%T)nRں'YY`2S nxx`2沦h+iY[9dP[\MږD[8/j50'
+ pk=7n<{zɔ#CYsY1ڷlfkB@=IeSDdOՓ;eOg1w|U|1ٗkVl¼QŖ6l@UT$;D|kW0G
+9ը*4JtB˄L.h7P c;z3Z/Y}v[ϵ?4jkjn[)#XqM_#b<<(9fԒ ۙfz/Qm׍~x)]
+ Hz>t&)z]?R۷s:>=-99. z/ĐJ
+i. E)%ǵ
+9u =MYqާqp3eԁt}.Lհ0G$K\4CfT dSӀB
+XT%\(Kw:{`JyQ۰<h`Ry m ݅Bu1"#Pbn͗%9S$u4KD7BmӺ"3rS4OcD'tB0hgqj }h]/1ME\.I$LN:P܍ck?#@|H xz86%#Ab&H#H>.;v$Mlv7f>[i֣ܝt>Q|4QZ!5F(z>~Ӑ9KZON~
+7G+8a1e2t N^kGc{ThK?
+O)̯X6Us+x<_RQbWyaƝǖ-πPuQˬY sYfў@0%5E|ȃU bv'K1;/r82S4>>=+Dʳ&}KbbavX`nI&]
++I_]tEsn^Y&7Pϯ"2᥍ 63<O'.Љd@C~7fFB#bﳶ?ىg
+۱XyL;J6n}v|Uc#bܖ[{+; dٛieFB10NQ[`GUqr~T엝͉/38!w \8\W,R!髩^ȱJ:&\DK1r {%i}9)R`7vȄ`l,;z+yp!OFٍ>`"0aNe7Qu!8) rP$Ɖ8]85r 51[M9ZjHRZOAp GޒbٯO"[ W[ 9@M[<#-?V&lsMCDc u;>y+|h$ѷMQ9s%|ǚcRqroE~Y=7s?k3TeQ:h S,KFyVȂ,`PbX0|α +ZHpQ=+8ma?"m_mPzo?m̯#XpN=)W8KuThxI$S`ol
+]8o L E<c &I\MtrI]ɋF(#mJIq~&9U^/̲J'9tTOx/6m'F['ߜny>~G=49quK /wTmk9W5#c'o>RӺJf:-[$X~sfYANIȄ2+J`)R9ˁ9~+VE>А 8KщtyPg3?p7m7vUȵnG꭭竷6ƃ]}wwkoAa7Pcop֏U8V 7?]:m` $CN:M2R%P
+6`|X>eceK˫jWZiO^I36
+=Jf J(*dxP&ҬߛAh`JȔn<b4n߁
+~OdC 
+%Cl[Hy%~
+n.OfL*$_ fdҶLƕ ] Z.e5<='/{1U
+Rdy[Qz.
+Tb9*TzATSWйW{N|1 ȑYNu
+o*28OkوAgS-MpkE&tJ̓,9nݤ@?/2e?ƪULOrlPI2 yE/dde0sR]g
+㷱c#qF_k17+&LG
+i6 >>JV@8|7ȓ }u8-zPu/꒐P&2H
+J#[cLú:x%灯RWR؎z pA>iAR,ǙH9jMx^Bcx{;8z._ۯ_X#Rx;]Rc]S3T;cۻ`\ <侜H% 3,Ωh^սKEzv>N.&yCuy3DԙCLR̫bL{"n@I<3v=/]5r߲k.{9 HW'۽GvTy%?:]xg%- {Y=1x286d1>2GE5BTB)4b`Cu߀DdD+ő`/Fj
+y03#;<Ǒe+FMe{k]XY]z􅒻U4]9_1<hz[[Z-fctl9h>dm5[Xjxs i{&Qˇ0D
+("\na40xqˑ2]mî\u{gΗ<{K7}_-:oSn/k;h{`*;Cz}PNƦO;u֡aO 7bݶ懏ԿVqHa3ȆHD]/ቸ8OB5[s<Y?
+C1cBEA~1#DÒ D\y7KR¹pd>l2^%{=rOR79g27fD?=>&C4y''ŸiBJ)6!iȓ<(WLʪtsBӞaosB5XYB1ˬw.X ZH`0GzݦV˸B$KĖ{<[C̓?Pfn4\e̗UxQ8|^YQ38+(+Τ6qJ=7`Np(sA[0>_DZ
+J*ň>
+˹ƒ-!6h[)*
+LnbJYsgTZ|8;S͕'9lpneͭTEPf_ҽ]\%:*cLȺJZWLp tj]q$ԗk#r%%.L7
+Z_7Fwˋ ?Yl± (5z\,ʫ.N.-t%b{іaLC0qT(GJMerA i*T>]Myxs{f&JOIڰ@$FўŰVeɲɥ  +6;(I7EEcYK-܈m}s [/2bՖ^zAmdIo8QN{)mKv_x ?p1_< "^4ܧ
+|$ʜLk 2%z4p 09 7{u=pAak }t(nm#E'8NWsy>O!Oy.bk(N)~M
+,Ul,<tS2,G $z>4h:L &qu! ^E{<u ;q|h>HQ̥ukF
+ r3ڃ#]
+ӲQUQ""Iİ^7.Q"
+j[TȈ[Э"4$CysbȌ@K~NBQQ/x"p6Bg,ͅ_yP;$u`9m_M1=#N&Oc9?
+_I(lF྄D6eDeS!I@D`6 d}G-kB}gŐ395] ⱜ)YF:;:=
+/21꾎3Dfbdě`B3vl^^ɬBimd$Z_rޘY[iNO+Bs3& 峢T9L s[IZ܀=HjMVm-ޯΉp" Ч4eo\h997֛϶Y*z'3CwAsT6YrvP%?\8Cvm>JW>mO)qmg/anjC;̻@4aF ?
+F{{X:A
+S2&b.Ko8LR6"5\k'.M4Ϝ U6|j|yЕsN$8,ms_>0m-w^쯺s_~މ<΁7ЕrD7i<]WM G&?zHVkk :gyBv^Ef/ld30/D0wkǸ>p5 ,ȓ `sE8w
+A0 G, 4a!|avm5QD~0:lgf `=V=(hTր9tWKhuB݄"D# *i͛bIцwoq7K'eq{bG7,,4*UH.}6,d ƺ+8qOю |!k]nY͐.uBL =L||(W8.⩀PiU~X25z60{z8siB\s|IUXo5KK9ٷRIz%HpRՀ<~j ȑ, BdM8pM;϶b &bk*GrMpl70ױZo0.@b
+endstream endobj 49 0 obj <</Length 53853/Filter[/FlateDecode]>>stream
+HDYlMaa˲,o[58u&A:uAĈWٱlŲ$[ Q)R)9 ޙp ]NY:Aӧ>cQ[1Ϝ\޳&:u)v,$No6'zj܏u5 Nڏ`=<N]] NWGwVהNwtxN]jxfqq J%@D<Wm%QQQ@' a)Z2qK1&ϛ-ǔcUT?|/ΰ2IS7X1 jV6n1thof0b1 .
+sO"&⼛
+z!Bf :MVIߋX?-$9/SCsNfYtؠ\H_t^. \E֦j [a#gp̂q 8mq~kQܜ#HLNp,ze;jdmEkZ\5ZLfzSosqpЊ,ֱ^Kxt>ٝ͢G[B
+0v=Zbmw vKvt76&͔͡yϴvIta^y@YnޓQDY80_L"x'hS{`sQf>2nPVVkj15Ϝ`&ZX0@b|1~+)c`ӾB2EDD%rK)m+QKw oh;Á,
+R矦y eԜVR^2}_2HlXayIBJD\9R` DŔ3{OmS${;]KFMDܺL:2+ Wb%J* K^(DVeqjYTLRJ1o@+pi);OóGסx7Gf)f<y%b'q҄~՟8m~Gxj
+}AqRdQ寏 0<llntS Gй,K2~-͵KI`>a`H94떃ϋcUvybƭ,<ZFGfWc@XM| < hp.& ) hD1Z.%Yߓm*^UT7`ei|
+]KK &_<7PJvE]#Nz
+AyOiBa3ϳQRZ`# ZAWDCl_ yP\rX~=K2V,V: R[gUye#B;tH[\ypp 3Ђ &d
+4mZ:ɤa6i`BOْClٖ-jW=$V}X6GL'M?2Ӓ׿:ﷲ3m[W'gwW\?`&7i%vM zc)oGzA49QJ& u~+ d*N1MGQ2YN/Ѯ,KXmq?Xj}#tmzebeR>V\?ڸiuZlNyNԌlj#uQY=K[Apa%cƙ(H|oAop یChk3
+,: Y+ vUXQqCy]ːAɃlѠh67gW͜w̽m~bhѼX>kR'bkLK[FAm|Ѝ.1YYɫ]/]8'3 w^ûx}!J \*w]G\Ðy,z\rdbI$IW j}&_;r垪g{}'ޖ{lݲ3?;%ST=;V:W:Ҡ7V?R:Y?|@}wlh]OP}8?\;wf| jP}'2bHj,805&_@a)vQ+nރyH˲F<K.w5nujsM'-;^vTVLvMu;-;Gj_.3gagdϏɫ͝Yo# " ޟoOh Þm+oPd83ÔPaG=
+;)}y sZ:Oӗ!Sv1F^YrD/|6V4kVW˟zy`W|tO|87zgZtS탕1"UI8/ӵΤLgr3Yc׹_& Lgktx4N:猳 C䴻8C=bJ/aa`b:F%N ΐ9fouL~d.Fʉr8mhpPiwWD]pĪI횙fڵ9؀ĻP-K£%|,۷H۶xk}xRҔsJ>C5Qr[ъ<lB@*Z{veI~)IE;1xO>7-ͷ-wۿ#yU:Q-ݛy; hb>%X+mT]OfNoSM7`IɌa >HY5۟m1bN=XK(
+_ 8e!J!xԢ9;Bчc3F)()5a ҋP7)Tz#Ôo#D dwRX~% al\*8Na+Hʻ f&+WОO1G0!8 (gǒݮ 2]u-ĸT1XqMXd\M!!sn\sw`;G1cğt^'L"
+ cE;HՕg~#GBm(r`gW=튗Xqx"VXkK =>| 5bعЗlNـ- ؑ) _.x,\'FcC{Լbe!< /ây2osx<=j#|!\(0
+n< nKyخ&;
+D;&j:n)k4T޾imHCVdq\uM9?;}_{l҆߮QW/6ř3ױcMeov [A^X>GQu';曮y@^s<*;;2gnAX6$Tg®VRqrB#3Zco**
+R"ҠEqwyr&`,G~%aZ|310u-!Kb/ @QԩYIxgKæK)Y'<Rnkyln/Xxkxu_|&t׃?x9L`=Aܺ^8esd"aRu>j6shN:Qճ袟W;]_c@;E^e0]mٰ<EEe˾yejnQ Ǟˎ UR>#82I'0}1yWfc!ɼ<.φb9I=F*z
+ BAM6Gt_/역dOlcKWa\g෈z>V:rЊ?' ޱrE^lw}P9ۃ_?;yȿ!J2M,A&+|д?E VoH"nJk2: ]5@s4'_$L${`Αy)X:l.)_! Y)(v!;p`?^ʠC8Lahw|%Gˀkq
+{Ed|rer+%knىwBڸY3؅8?Bdb"9u$HRl,L֘X[`IE pNa9 /C>AXs"r%2
+0qLһ<}/ΜN<aod+b̦\Nt!Eg + ( 7 7ߟpC.
+W9GbfE肵'~ 럹eݰ_5wvaj>Z$b$9K0y!KR<cg&砩O ̪ >*ټ{>ʅlOnYMu۩k m?:Z+dlݓ3xM7榔
+ǡ.5h31ԐhL&~P[7~+?ڛ2WPa&u]&J:uPuoI;/{㫚4]JqYke6oݯ%577h7h&
+Mkj ; d>+*CHgsGEe C@g-ݤsc^2[ >Aʉ5j7;'2Z;j]B{|zbjxxЎG5rCjᖶTW[)}$W-)GL>`t}/J1cމ
+xOԀ֬m־;Twn>zsk9|G۟mw_۪CWWM_,y]m;Nw}1O͓ ssgFřTX[Q<:%ÄBk\%>Le{_ޓ^r(qF';Nh%ޱχD̢:8ouCc~ gA 8+orzYiqVXF٪x)A,'$JZdjQ"-J'@<!Hr=]t0MOb*`6M`$FbCLMbNW]xvaeg nr"s</}Vc%<E(̒B^wJYcQ s {/ytwdCsX\c\ |D`Ʊ"UJ\;xS`1DZpڎZqhBL.0†d1_LGfȆa%"<zXb1ʅjI5%pom<6eT٭}?fWɛ[jNyG9տtӿr' 2Ei$9=SHbqc˵Ȃ1Y!s޳t+w: D'~i_"[QKaƻF}h[C?Sf_f
+x [q?NlZZC؃a[r9η|Wi{d
+f {hAnkXnf2
+6xRw&y[</=߂>gj={t~`HAoE۾o6k~])<Zn}F|hn9TDFZ=㗢NR kf;8<\ MtX)L<; {Q>1t',װcGƘ05 gig@mњ]y_{ۯ7_j֝1-"_U}T]gNK^E{͎\GyycAxnUƃq6/Z H`'EKhލKy,o^,j% >ȀqS,fIfnm&{HhL Wo ;zSP2W/יJb]]Xg<R6]k;ѴLߟ)[K$ܠf*'ϧtljXc[Lm4&Nj'NfjڋM9aVjٌLҨ.WY NT{<ˈIL9 oy2oDhi{ )#ؖ2N[bU$˂-5O/65%Nz07c
+?϶od#[}/5Jُ|&5 Eʽ, !;gC?v&|}/ <0aփx6|
+gcLI ^WFH:J\҂0dW|㿭]ҬBT`+b@Y90 /xa3t> 5b B Ʋ`F蝁@?}`7Lׅa^Ѿo ,<U/nzzR<;xe+
+Ge
+f)|>Es}znWYHNn]AYT"qy!8.lpHne `ʸ^цYmC\mGiڽ)`Z %f|.&p
+e%-Mڷ=mȥuC-ML\jY(aA
+y+d.)
+jj}=}}p"v+8PŔuwf:K#-`>c^M^%K;gT&*źGT(+ZqZdXoYi>" I1""Qq]hD!XzOw]-wWȃϮb_|Ц=h-O4F.R6t7x8sgL:51l)]ԇӍdhr/=v|iXa pW2[m~ qS#пn=Q5p';] TVGo h~vDGKQH2"h8-8hŚ=\,eJg'9xnF3>fyƃиhrz ZkQ]gMg
+CPf<}g߱;= 5tvWs>XkT55k ʡcpHeBN:QآWM4qAn&Z̦mnc5]l֩9PiO:4]34gӞIE(F]Q7!/`f-2/`ɐt.Ɨ 'dSl!NJP|o `$خbQy.**2-x7sƧ/`$7(h /2sfcyҠ6en4ޙ
+K0!vvy mǵ;N|qg-๐֖<J6ӷleSpTni,=ف~oB6w˰%b/Plg-䪧|5qA8r崳Ml>orO1l] <zqؼMUC9&l,n#" R6IvhƗ\OX,-ixw qwDTmWAQ}Gz`m[GW[gڹ@O,k˒Ol Ȅ9_2+c|cQDIYV3 r_9sq]{|l>N[Vr -cO 6`rvM,cҌXSjgǨ?aExFϟfac_Ő .XUL6$U|%>F~pQ3񮄵 R:
+Gnz m圄\kϑMdG헐r@݌;3KJ&ė9CO*FfX9/ww!riW"*ם
+tjz
+[^bi87„`2Mox k׋ 89"/z߳wZOZezx ؠ\i풰Dey60ȃoW+U6sc
+Ρٟ'@GUWe8ܓ|/;{>&>P<D"ڥsyQTr4˅
+h_U| wOh8tBQQ*9C8gX? ܋ ë́$xy 2=#KGq7.5jyV)t&CIeXiG,Dzt &q>p]
+EkvDٵ\/@_!`p]•X; <.{v$e俜HKbNdPS)< ~rQ^v=ogV5n'{K-ÅnF%| *<+.7b!J y<2#E}/OC 'cZ
+v=n~C`J {b6eN'&!,x86܈uF~iKMθ_2'O6ıE@4 |YEE0~q53TzS vZZL= SK3lAӵcTk=N6$sČr
+矂ò,TJȂ`Cpb{z#S:Y`m\`u @]Tb} ރfCD̑; C#5f4t砮B͠LYc^JS։l d)mmS}+~gفI6|34vD&rb9tg,i3uxG灼(x9뻕UNR -ACqu@|Pct,)$
+%Q͏g<4ZMuY\ 6 /5rWNXu{oީ:~*KH޷cOOAr0&ڻwݎv5"۩[-}__l{pEz wQꍝUaA Itᑆ\jǙ6nݯڽyfVcQ.rlhcvV37?[%Α;0(3$D0]`DMΠqD3제yCXYw1΀L@؇{HovG]KxЬ7&/r. k [ 7^olhQk6kֶTMնoҟo õϯ(N zrjNNYNx~}ƶ-MkV{_ݲN}a7Ő=
+&D&By?٬QNx`,,=l: 0֔oΡf EgX.ڄ4`jhS195 Y|z'%]dǩ~tAHYoMZºb`Xb1Mh?$ɇඊ*za78U"?M! 7@ەAm/[>~| F+Fq˰w2y-ۺqD%̦\3(;ٔ'mVڀZ}Vq#ה-gs l,\)=]ɒYJۑdod1<G8_y.
+\%$ٝ tt%p s]m~o㟮=zzq oyč=vq٘O˘XLOu7q
+Md1P9-6X˶XIZVZiWU mNgH;i?d/Lm͇7oi}s )R2W\(e'SH1MBIca»_#. fMbeldr/Sވ*
+L$3 v06nbNZBLCJ(cPl
+Ti][;+ZOT?sȃv!Vm\Aˤ,kmúh܅<r5*#`0?l3!Fq)Y , {;2 .eltb)Ķɦ*YKOU޼ԱּѡWcGUDU[*DZd~S7}Gx=
+k>]-#;SnqtI|A]5rHա7<VZg ?ؾUaGu7=I (d/ݾ4V5xg}·{spѮ;XnmV)kAYѫ\f_Z|x[)BI¼y~\ #X":ӤIB6BMǘI9k(C6Lȭm&EfRv] 1r܏
+9d!j%&qVMKfUgݖg͛lJqFp\ؼee nҹ~1wN YRI`cÔz:Mʺkj4]7%}~)i+ ױf6b)lt9K1 -mk(}Vf@d%ռ7LԞևYEncL73ɜ/
+\ *FG=J5 0ޏ*ր7ƠEf Q7 q́$]!PΥ\z̀ǰG!%(W5wBJbeA{\3j7}e`,F0FW[q/KghAcv)}82s!|õ(Hb0uͳf'C$dm&+bdDS~{ٙ\!(#Ofbw{<;RL-HT6G%$5islS&czWP]w._ؼ9 OMj..!?})ez`=/.WeDi =o>I3z>+Ҩ%T
+c"r_nKYK%
+h,\\%' e6f䜴#&.ɾ:;JW_vvN:z<6fp}祈##$C0>eÜb F}\2Xl Jfv} ;Mwɫd?7?}wn;>;tnG5y s&ՙ+:Xax#>:q?RE-qK!1f:nyq 4%mRhJRtIL %BCij1زF~ؖ,YwiW+]iwvphC:tӇvә;k+%o9#$C0[ pATgqKW{.n݁iO}P^gžeDהCщu׵{>~NWJ=MzsVļּk –&Hg6DkUO{1NIw jf:l o֡VeV[ 0Cq eYx^ "W_8֓f<0D!.W1I#
+{!%83`n{I0^SQb&[k)l
+"3y4W<1vj
+k~ך̔cYw xx2W+cpW7GǢށ`iYz0Ѻ£<}剛xCl١Ӫ'׬U;pPeܫkeYB2a D'7 @~fBچuPs0!2弙rHs(eŴ@]:<:3Xkd󗛎]uU/ڧ'תoa=ch{ۮ؉>s[ZPKagdcZI ك!pթ:~ռgVO[oAeݳonިzب#<i<WEX%VmF ߩ[}U/ګڹ ׷(<dzOU&\1&ͱ#l3)b)87U)%<$28wOZ`Y/;p`<`È"Z!6`Hnaxi6\ ۈ)P;`uE>n]3h٩=Q:Zaz]5{,~3S%C~٦i>G{kuO~ ?2%LQcINtڶ{6`u j#량8z~1vP,)}
+2h"|{34K6P"y31yG˨] >wҎ7tzo`$ҩY%j&8m53*mMxFFtJ1 HŨ3B&PS^8*+ ")} ~ _dDeM /./ .{ Z,)R8̒y9O +<WQKW|5JE .UЃϥe>D^fy=I%ă.ӲM V+ I KԬh-CeQSY,1Y#k-]'^x_GD3<.:2wƙd)Gt󔤟 >G:·@5{OMn)]
+FBKO?v>kQv,z#տbe^MjTFvK;>\WF'{⋈RTxG2yGjv=i؋+93H&ٞ]ͱ6q Z9Nw.փ(S[#"q\ì<"_H R|}b
+<|</${EruΝM7#-O,lc$~!寵+Jfϗ=G#]{O ǒX^&^Rx4o ُܿ
+~/Q$Sed TJ )܇S1!Š9
+*8I'g Q22#q/k$3c̈́hXAy~#* @ˋgh3R8\P]MW
+f=.ڽ:A9w|t<3l$^ 682 8s>+^ꄲ۠F":|#hM.fDrZD0o֟<{Nb
+Y陰\f.\2ٕI3gJN`׶fR56|ɥh9U0JBԤdhE\҄&Zq8LdNoOgXIz: Θ%,&95aiB~%mZiM8 #1<uFcޅVog8?h8ï8/m<YUp u~JֿUpDmr~j>jj{] {{0Zݚj{j3`?\ P#Nd7}]y??z,#M2T`.KKỸ<2. 'SȚc #C<KDҸ4WUkθ)_Lc~n)8EiJrdfdGm +O2M 6Ot\ۦ_bg?wBM?w$lLR|:Pï;Ii{Eh(}WC[3^/Ս>zti]_tQIuN2e+YC.$}WW <BS"%/;I-n)m*Fa_q+AIs]'HE0+tG,$'<27&Փ=x'-/<Y+ ݏcLf \|˦#5#Bú+x| ]ObZv}/m?+YhaQiNVq"?uᣬyo݂Uzq&sİ{ub 5 iپ!`&v!?Y؟5Z9ݯ~z8c)X0yogOQ"Ⲩ
+Pb+܄^ f+NB}~qcSكiN__`L`$#CP^Gk Danu$vq>.\Dh:yu QZݪOV-wrf7[ B`?AHGN8Ǒ)?iL;[ȁ)GL K{lw$-sT !TpW2<XOLu=O3$`=s|9hd3> ͚.]f(V VFΪzS}?Oap8Ǣ>J |O- Z(,,UkZ
+a,Ay!`&Ke Vh,_3:(^]W/(L2EL}l
+9=[d
+VAگn.DVމ.Kh͂Np6#M2ltqeݔ5Y$ 7%}I
+OLЧ{'S.k5G3r>K \uYǚuی >2 _gt&ps.6ol~xzƖEr9$mȞ4=a5 y:6|,tpɏb#ӭWג]oɎ
+|BtȖTO]bI=߀WMW'v"f sdQ(jGM>~47EuDK~a `fՆȃ}f&v'I븷~7N0kZs/rK+~fMOtsːp^
+c<DzVYkMʸWT'0^3y0`GqC2|آ`zZ2]K
+Aaq<1jv믺84vfOfX7g1C$ƛ';E24X^y$v0 VksPyo ` A7 fp^yxʈ!zLށC}9G\!ƃy\Cc'"!h/~%2rS1&#2"<"X^Re>j5
+IH(-`0/嗄-YzK$N-[lLMaR)3Nvi@؝s;:i޷Hzx䓎 e< +bJ!uǴ[XИd=wDg&Vl%XYXQ Io{3=oVwlj1F)/?:-% 1f,!4t~h}ñU?}=l[N􅗱lƂ[m~ t$@'>]VI+Eu٪U'v̊<XnyM|gY?#cJVuf.~Z^-#Ѭ*&-L#Zȍh͙fi+\ydÀgX#oe]?Ye:\Dr8GͬI(*sIfe,fVjC^k[{O~ALI, &fK4 #gljDs蜢Bvgϭw೔C7! I^3MឌS֣Ih1Fp$;{ȍ n{)5Lz63F(j IN5d?|wr&
+<:qdJpUY<ufCchVsɖ31{gz""XDfqj/HfMwW\Nq!}@!h=ϛSwg!e%\.%=<[o-{-t Կ;f,!`X8t!|.=)_A_8` 0.Y} q@<BLȁ9kda Y_vYZ'a %Y%ΧUgLJ%'xOyg
+[rA0(XgR79"j<%ߧA1ў=C6ۿljyLx뉦u'5Ѻ'B_]j>?GXYx^ojz$9uBR9k*un{gWx,O8+b߆gۉb>Q秲l~R̚s q2< 8/kL|Nu{O\Oᆧ=|Z{>qXmoZŎ37HJj(XEdŀ3VV11jl&<7XjµĤtjk_}@< ozRoo%Yt/;9?LxٟAoZOן9C6I?C~<i%|ϷK^&w-G\b/\QѲ*NA6 WT[\t:ilfHXh/+xFd42ʝ<H{?PjcK:yf\ +:hO3<ׇITsWc'v$SN;[Mm-&f'-k,EU5խE!K圍
+L[^Ld\^],ːAC>/gѕiG1n&ʸg8lѸx!oq6wwxb(0o E{WBJsM`L_΅5njrEkcޏgTfErKӪׁZLZ,7o|tGa z%?< 6z8j1MK 4pOv3󒑈ʂwQ?1gB y&Rqʝ7]gkAmgO܁kp).Q`,KͰD>8S4 0>ʩwvLs^75Ij_E][u!910 xPZSO;[~}x ~l͚g0ci4uKߌ !Ax~ )g=2ivك1$W&Ax7.j<XpQiS
+<y C<Gk 2bvŔ m[`˙$d|y  ESw(xpਿΊ<xn%Iʕb6/QGNEm΍ Bo U;U-^~`t^0|.]},޴70?ҩ  %FK^OΌ5lJMGbŘDiKh<cX2^ރ";L֔dGo
+E{0?2, 򚙳|Χ~JI|p|k 7Ku.hFJf{iHJ2yӜ 5 EJ+f`0]VΡQXPoՊ^e<1!ΝU뭞18ab]\Ϗ@jmTLƗ/%sX"kxn0Կ$u;cѱ4[Xnx3Dr|O ~%
+Wxyt{ruE߭bGqo.}Kwq^~q_>h4:َGﺢkM d8-fS1M_ g'"{W;M7}IK/aY:g<<5B/QJc #^g:!tjW>྄K͜ś!jfN.˩[$ͽP6pcĘK$YJBMh12㢂NzuUzbWx\$z.!y~]㿭 zfE1b%ȃq3l_P rL}A9+wӂ 
++& O|8yEDMS⨃><롃<I±|n֒2 sVK¸pϪUoܭµwBO}'њE\a7BX,̅p +0k}TMM>\b9N^YyJ3R S +{I)uh!*}b'U B C }y*y 9b*sNZsW£%xpN ̔ NXtox0TfNCu:װ&K/7wnuu hBm+:ܿsQ[3ruÕc:ȃC\An]e]#*=B^@\(*MTgy/p_2(p`0 `?y^ʃo|D3\u '߰1~k#xP<|Ě{j!zV+PYջ=-`}(1 DriJNW2!X{;:K} JdԳizqd[f_јyhLș2hB`Dx!;t5Ǜ?9n߅UjA>ǝe~ԟH2!S1]qi4Ql7&dpMgԯyooTfts6M6SͲV`0oh⚱ [iO:^~}WүT/oUլGoܢ1Ñ,{9 gBm Oizڣmܶs" MpɎ@L wД$.d8 qtԊtP?JX&]1p'3
+>-Yo.8%Ŕ,de{h'xgUoA~Ѿ ]R0Pځk2m+k)KFN >ca Ag%戹켙53g,a;S;aLN W0a6!,^JsP5ؒ<Bj@w kB#n"'R!?_zʵɲA:Øp R 2~!L-%v1Ű+䗳Xz⽲\ <8R+Ŕ}kX+.d}ʓȆ۫&|ⶲV[v̒te{|WMM~,[ QxpkP Z}&/pZ ̞{զ6aLic2:ϨuX$!b4s8qtU|nwuxS`eSV?Q럽?£KCDO[؟l{2QiWSߍiՅ3?pYk1Ѳd_*Ìg;*/-ߟ ~x2xх`'Ж|g rd.nE~iC疭-I`pFő+nɉp|ެ\ ^M܄c_q5qZLD˭_
+w/j|0Ro9&x#X7kyLƩF,^+AF҃+Eˑ|ϟ۹v xX'H#w'u\9?V xD @U߇!v{Wus%<3z& D\޾Yze7n!׉R&Ňp_b; Ge!BFQZkzոrxcl:
+Rsx^  k~uC+!bpr",ƩnQ\p!Ѥݣz*0pa 7{E
+nʶ,#@l&`\09^* NS½1-ՠznC;I><@ y#a0򅧬~Ik'ܘ0&5tvo 6/gq:b#3X$/;Xcǜ>fQ+Oi{)Ėovm|ֵ=F{Q7}$94OģI1qqZOJy퉟4Q8TQ%%S,V6jHT.a S]Llل|jDg~5n[]9Ez!IM䁵|), F2R"9ql~Jt
+^ !2SԈPM'<?S߳2mfi72ܬ:'?^)^v*†^ACG E=7Gz.{蹧:kЋjnhs߆8cZvQ朞X Wl;ڦѽ6Wdq㢓7Ӎ6vj/kٳkf!hƗ>޼af.d\pCidg UކfZ?PL5,pоʽKmdj[C΅ _2sIkkj~VK1jaэ0>#e5oHI.(B!2J2NsFb2ByE/<O
+\>_4
+9]};g.>>xz*L(ҎB1M}Dz$BO"W]؏W=G<Sw^ٱi;|k7.Q ȳδ=aͩnlH eycX0YS(%μ9׊hq*(L\`C8Lm9AjEi:6y:fiSmx=,{;wsVJFC\.ǓE? ma:-_d; E dc Ϲ`<ˮB6ZBpv!Jz<Ϭυ
+HT ]m@fvo[1kϬL~ͤ<ɂ`_+~R ޳u SC.1V7Pxolf9:XuILGSYٲ՝՘mKC%=V<HIAx=
+hxzVe+2ICB۲n$>=j8\u>K9{<WeEgWz&FȘz\ҿX`vA^gh vY;5~syI&h0Wdf mpfDY<l'ތsJZ7ӛf2՛ȐYl
+:C!@YmpL4s&"3 Y=ѐfCuOD2"z]$ ar!
+t+q
+A} p} S Ѫ,Hs _a9),r|-5(A ,9> .rԼXQcx<5 Η9z xP]zr^)\$P| ESj}2lP̧ζx}c:9;mϡWz}rD󣴉Ϙcmm?y7[w#[<<e g7t6$p&+ w%8cQ`m DR<5Q#! =~,]vdsEXe<7aYkNw`'z>hyE=ٶNd6#?xi/F>{ D*TaZ<Sî7)MeS-=v0P]I" )l X؇p quyhf}OnClYmۊI/$pψo}k\h"`;O46ꦼ~]$AJ'裖VK9P ǐ@vmCv?<B0al86[Su}2EL߁]󦫧.>rqTA޲K6?[1R+hh~ī?A+/.ǭvl@&
+a&`f mHRB.CȲ-leY箴v]ֱ:}ȶ `J34=t3L{Ui;o}}>Vbˈa8,'tJ^Bu(Y /;0KQc&@D`0EDZwKS[rTl]k{af]PB{|bV/TEhkz~s[m?>sRFDM {!IL#i:0KL l9Ĭ>ƴG6Dwc6_V5Ck.;#Sf_|SWwBi-lS}^g-]9XF4:(lJ;IkUvƩHb&!|.}Y~,wnO=)%PIIޠcn&<2ťY)=7GdQ\ ѳЃ
+lh6~N[=IrW\5atk~3>zfG;y'ǾɩimYK1C @ϛ SI*:~_#AYѱqԯ&Dox>'nq=2HLE(4/ 'iGIřx^%x>+x%U,^w75|nopZhZۡnٚpNxB&C!w'<27pfndO |_TO qطKEGX&3ڧtZ̸2%䓕KG,[(;YDQs/4T)i.__և|]R<Zk;#ޥxyk2q&Wb|HȂ.$TSϽ QY Dȕ Þ"r
+C\\'{:*5M|QQ15X-6*ﭧ'_|SVJu۔0!Ӳ3<$28WT/nTdo X)@~H (=ǐr&&XxȓdssQ NDkPPJxdеCK9I(4 q[[ #D4brFE u$Kՙ7~i'"jʹ*BDƽfmOZDev|qKzy} sAn^cxFQ`|tb:\zR!U#'<\ <e&NfnSpy8fgcZ9͸Va 7A5Ѯ)&#+ .ZEasYyv
+p>,pIg)Vg aD\?h;$[^_cnoبR^!f(3`)4e|Bf4) _*3`OyDˇec8[W y4?lSB+R@<tyo q%&0 x''.Eず2pc}f>GzHCgmAܾ8;Vdk~ؼ}֦3=w]fu/Y] Z;5='0O̔=D2Q. (J:W7oQ^΁),eouzsr筛]~or
+K?qZ.\΂3O}>ٗ<PX5JN3jq!1* i_3鸳@Ǭ
+QbuU}9Z1/f{ꙉONN: Ba žZOKi50P%M/ւo-x e5EEk䖆Fr$;
+/J˒d5a=`"RXGy0yc`GFn<x6<"-|K֤> &9<)Ό7Nu!#<5-YTogGLtR`+XLZ7/#_%o.p/L|qun{n{n)sJ"mC]ߜMuӚ~0ªuntj.:*0P< zޕ|U,\[բ]Vp
+l*V
+C7/xo%!-jU)K~{x!,eJ!c+ |#s4spv:Qgf1[ E(k s!-Nehb&2d|gb JtDdr Kty+LH&`Y' u:wc(j?MSyDFދm@xJ|DEwIاI; b ,A24jj?v+@ ((1`m`]-Fmo
+C55d?c븲1*c^+ 1Ѱ!\Gɛ!"@MwaՐj4^|Q-x,nJft'X<>RcFa{qJF `o\MY[/s氂FN29(`9wor+>Q$(!턯 P&nJXy|⫙#5޻ǺV
+XKU
+zl*g@NE 0@| /lQ$vFw.D>5ةsT2Vw^kFᱺ?b^_0󧌂~mCǮj]uqGyMhOC$_mX86)4CF_47ZV;zz6W${0"mظi{-VB \L[]6~][@/{zB\j+ )ӟymQMGzR׏x_s.#o'u۠5Mƍ CtcpiɝC{,1z\LTi$E3Y%+dg 8f`$2@ZoD6 Lc1K%7z*"ε\l
+ˏMJ{ڛDc2pC^|<F<xMy&3
+3! Pz)=0LBmClmlY%:mY:vWZiuYZݗuXvlRINHL3H>gf MeaM!PL&%M2m(*<yuG@CV&iRփϲfn16p
+SJr0i𼓊wLap⵭_@;<}뎗__2c c[fM^!
+nY(kL[wpp.psFʛ<.0(DVp4A2 ::Ht>zfiɃbw7eQ|14p,M~"&en+6 ^kgb$Lf4MfanR=&{f?Qy6g]އ'O-bL7;??PW?_?#?'CɱtzKPr@mi[tO>+%zwrW&t-}pH
+vmp 'uY_̘#)N뢡 YL˵}
+< B uQ4QbU8eZTX.2XC<gڢ߫ ix$6Jqwgb>5x_z/:|"A۳oX=2&{@3]KϮg;jΦ?L7y6)Xt uddE|Ĥ9ߛ,~Khxn(59?g#1a \s 2gQv#TbɻI{<ܕ/%H=mN(
+ gl1V=+&$-/Nk<rVňX
+ !&ɨ9Q
+O~GJ¤tK:OKfvG'wKW^ŏKcAi_BE2W,}R2$VZcSJ龕pǗMqLLBƤ2Qъ-"zd I!\ aBʅ`@z$LbEs{9]`3p!T 1a:F'm#!>`qOXFZ.Q\0YA6w }EX>pdI#wwnfsxpJ@klaw}oՙ.WRV <l#I&N]GCvVnGBVOw;/-p
+[ מ7h\\зt&vtrnr^uP#2afJc?ɵ CqD'_خX87M
+eXAҮ'mZңԛB Zg2;pIYbJa_G;|ȍܜ <KZb88~zЎk
+1[/fCpmOY/ / g,0"0 |-B"ÛߨqCX#oxc&q[G"2nܗY8sބWna+؜޴CS1Х6kVw+w [7lC*6o@<\̣V0Z]kxX qU=N'U/K&'Ϫ&Z:FgxU:K|mjr߷=]!*#@b>Ѡ-^q38ijhPov6k9]?}9Tdwv [6U [*+j(33loΥBٷ^9xfSԵ?M85NSL$o
+4LYR^zfZe(qUQ-SFΗ\~:)1QW&6sYv܍zqaLk8(ϚpaF *F/^{'ql
+KH$jZd3-x3YFŬ00;tv[z>+^r+UmW]_Г#Hys迺lSI>m~.b?d+ڿ|V} #T ]t # Yx׽7+u{l@F]6]7_/L #X\_Mgyܳb%Z˺W4sKh$Ip309ƙ(Qt<f)osefqG sL~RuU׸?np1{٤-U惏5؅ñ/sj]6ᅳiy.E/;y~rJ,YΝɹ`uVN۲& IiU7<h뉽F?t}:]coBҬʢ[
+fu1-+&r):o弉'ueZL U@2%;X9JN);6x#Y3f"JIiYA q 
+N% (U/Wχ!@؟0J&%_To3D{]k#GD&@$w#>,(SB2 qGޤf24vs,]YW&d\\H oB 6 x6ƜY4.; >:|o~qox F q!p 9j[°ߣ
+?2DCZGJńf4
+;;lp7PcQ:ssT 'JQrbmځH #6YSOo< WRFSS%I'uDnog׸~(}语C@" yod>,<7Vd|",c
+xp!D!z&Ѡw:gG ,򎛫XWb|@7`
+̵7<ͅ` |/p0ߛ?G9ots *5EDNwз_<vumOkZ~[PΟC?\=f}Ńm YTjD7SV!Q0*ZGgCnsGJ8Fl5fjyZ@^޶*C̥
+ƀqJC}AnTwN-?w/euк'WCkZ^i}00`?khmAQ:sw%6lךb6-dpѷC=:JqN⩋+\І[TA!+7P/awSf\Q uxږwm;/ ڶn x\ zsAwA~:w!Hp tl#Y5j<5J+&(*0[ͰU\'΀PF3 [\ͰN8}rAaMtM&$&[eqVFKܔjU q+Q/g@KS#Oܞjwwظ@飌>{0>rcބ$ʑ,SE+5.}r@uq04Q,ZDXUẼ8e(0$@p4MBJә0$܄6`\0}`˲$u_+y%ծ.K]]>d  Ifڴ2d4 ov~?(Ȧ԰g4ve}\oK_,
+A&vE Ik%$a U 'mLָ3k ޚ d"% ;N{#i4L"dQpy{:j裢3L1
+7e;</U}MREļ~ uOԋZ8c>td\
+xd%`5<g˜\QOex NZ{M3O
+=IXNǪ
+UrvxR3C0~W
+-N\2FØ4ǻ֒;JM}kޤK/#`uuintaf[*UesY!\S[ BE d„=9A ,5]bFfr DW^X ,(gi} ^52b9>nF@U4!o@hԄ9K"79MEQrz+!;6mA21I"l'8Wz*,C!?z#a!W_3;p=\fe
+Qy5jv ܔ;+\rԓppn,XoEzMjo];mR<*aPmTh :k`$!WcI ZU[pnLnlZ|9嵈_9aI06:>a,NDLnO,WgWUඝ=Xdg* )X$i.=F6ЮN׳8QfA"\)#+s `#x])!BdYD"z 2!A3 P6&̮ڴ+H pl? CM}e,3 UR"<\Ǽjսloě%밦5hs ОWp9mm|ӗYe<g'Բ٘+Y2ks
+>u -i.."R\@,d
+0^aȗ2<4ι3g+;v[xrўk_C֯zYj*8\%LWQYCLh=aH+݆W%}J;*Z ƑXUF_4NY/]]յcȆ["^zEC̣9jԶ'Il}αX}v![nE6܈<l H=ɭ˺ :A T=ȩwEeϛ!qj)ˣQ 7){h8{vO5i|DESTɷ(tԓpG+%Y95ha*|g|րFyhL^ ,t_ΛEU ,KQYGٸdM3@|0k| 4=!;RЁ h[SvS-A(`=)Մ*HSi&3
+O_?!#TkR^B’h;DbNIҪ 4B=9eTנv>=fuz=]h wy;LjӲ>V!}~-vq}'pjSEd7Gu5:`S#_|7 w7l|lrI7Ņ~WM4(^{)n-waKH"nANI7}F|j:z5+[QGB\&hྈ!oن W 9j- XmY[9MȎIFRN ΒHgҼfM|.H {fC>鈥Y<8,$X6;_Yg %C|T~Q?Wa8y\gRWWucSzR0I}22ßOLu<K ]LK@BÏF|+íΤ)MM5\÷թokoj5E<c;ƘۂK>_Lٸ d6VDW4W2e
+/bH1Kn!MOܳǐ4kM]E" ?HӁ}>H
+&`8b.dW$u鈗F<!0Aw6% ,~9pK`s&9q+F.qs:ЮmݸОݐAQ& )pX0&ӂ` B(̽!(wr4zzZ&eKUkmW˖YRo [\)x`^ϮVFqzC#G7 [[}}M㉺Tڿ s ;Ak
+2ZumҺ݃?.XSԾ`qE${I `UC6TȈMqh`h]j]7 Uh[!><Xpɯwh tu5k񻠭^Y`HֶPP
+%"BBIL܀!85ƀm ¶dؖlݒuXe떬C֮K򅍍I I&t:fB;_ twV;U W^YgLS
+qBȬs~mSXT=ժنW8YBwb7(K {N9n3ۉztգл͘y=w{e䖷)#gMi2e%|=򖏋W\: HPкY̸TH%6躜2uXj["զsQ 60V9O><%{<lzmch5*ٱHl8"dOl 64rq >`',Q:5wh_-KYM5DYJǧEVn/a\VX;xU|a7ք0u- 'obeJ7ւs+LBKΓbt2us[
+m{%RJy&bCD\? C|z$u6*L-J|c+ُ4x룺dzrѕ|ǣlZY kf<X|&e*)[2 a7[E3K ZwKPn1wwzmU斗TuEuxƚ:3YC>nj`
+,p73}h79`bŬ;<Ej= ʣo9)P,ɒ$vM@l%(3mOa9a7}8~ 5EZGZ1gÎR$>,pɢT&$KAWuJyϟQ)t"m*3dę(X0c`A`B` N|0Cóc
+s , BQ~;)[ǔ
+6NZi@~RǠ[p4yCB
+b9}q[(F~dm\^LQ P``ܐƦpI>2.= WaՌuL2vHf/%=:+ 0b/c>2,.WZC="Y^ 1-#iΜ\v]6-?zǴ?(4s28/Y8(Q@xJG6x*,{HQߨUg^R ܙ)Bc =(@4&Nf8Sj)ʈ@%mhdൌRv>j-TYg_pq|vi-xIOܑ<;!hm8kʠksʺBy&HRmk)W:u=\<7
+ 2nQF0
+†A]tGa]="EJXؗ3F$r"j <G> 3FuŻL8RXx
+Jt#^5202$ci';'XRb~Ьf>)35#p;䬩N/'kt-;Nnk:bz'ط[Ro]PFOlB+t)3y'ym
+Sȕ~gpF-ť?N)l) Bh)|Y/oÜug+̫I)B 040űL.WEEX\FGNTD@'iPK)LR:s[|lO7Ӳ'| uP4gҵOpu2} 3kisL)$4ɿs9|7w~"@׿g7a A>A4IyV?,#"b@P\<g5ѴgZ̴9y}>7>l.6y %iଁ*摶W՗Ѝib,'-ɴ6V,AW&{fo8Ϡ; LQM )e{HAjIyPdsq=uZϥ{h
+[Э<=paL(!Qhk|ct$7_Y&d()K/!E:-W*/<i>:f4}lOHpu, ~Ѐ0`~q+q9sy
+:l?&Tq5ذuHs0q'_Z=a6'1|y.@J![Ofws6mX
+Դ0F/CBO>nÝ"xBj]2"W%h!N!Ҡ&Jaj&gt9ѢB̥w_sc:o_oՃZi -4FFl2̌@"s]ׯͅyaQwjf<f=
+Sy{]rMNd+ƟkțȂυ$狦`-uOMONڛw}~<pc7-i3һF7)[ݛ? F$)]$%nqot_zlsm+ 'ԃBna2"Bc9⌗\~^@=V3 ^rȂ;0_"Gnv~wDy=9nLf f6G @6MŬS~ t[uGc
+Lt;P +.=1uqt&fvj:'jZd2c72,PD0Fճь^0.$X45'-+B_ZiyVm}v%sz补ϦL|-uf+Ҳ<) v1Hu
+`\R̕)g'3d^u+J·+b*+EK$J":n?IYⱔ6ՆԖFrh*##U1%;9icmyDW=KU_;d^sɏ`:ُϱO6}A Zyvy(*J'gyVW]͟tu|\<F{$<L,Ř\곀w8<@Z=_/fI O<ȹ]B7g.N{>'l4C:3Y&@΂znO일6vns;l5rZz^w  6TA 6N 5VBG0ܶڱn'{k_&lHg1=9`&&__CA3<8 ~5G%} x^A.O ػ=ȼ/0 pVލx^R7jz|[U 77텶 <MvJ:p.`d0MIKd DF0>h8S+rEtzFյ #7_Q7l"Lf
+^p
+y[knNeY7P
+endstream endobj 50 0 obj <</Length 60563/Filter[/FlateDecode]>>stream
+H4TipV:& G8`&ąNCH8/`˶,˒uٖX޻:VҮZlKH )L!Sa:G6~<~7|o@%e 6{Z{CP=CJoP]Pm"m[uS-I=gFf@qӔю5]yk|6ˎx7aZQ2#PMN?\U%Ẑmc#R7qc!cbܧeGҦrv%n=Z1G3]dN=*JC)y78a<f >W
+؆hqJ*Np~6=̵3 \%,uι-_w5?8xzhjv3.6}yD
+HԥV{j9:MC}:NK`w\PKa
+P=;Z{^߅7[%mq=K;S<"&wgmuqGPp>ayAϧB/a</b~73(ZHBʳH2i䙠}K/rI,i"aEp1A_!iO%ʣ_qؔ_H<e12HHbڽCO4F ϶g:ct&fg
++2l,3"lφX}6dfYٸ-2,&۞\w.XQcmin>ecү_D{<ֻjM%~oURۜY&W"PX"i+.6Ǻ٘NYNqQ[< ,]XHBka=iHs8j92$q =8I6g<.a-Z2ͱųI O\'=~J*xBj's*d{_QE"qcgK0ΝIG<Ҵ5dyΘD-$;J'@ ~,g0|ʬ'p?E ĉ8
+j-VFBD| `0O#8Ya,觌y S8U/ $ 1G jEi> 'b+1!"痛Nb][\;\-[[&:7>AYovnk-qK=,zg뻢m]'zeEU}!:Ɏ͖t3CE?"ň< c0DQ(A`14G1,$GHdR01/UX^@ji$
+4idp ᜐ 10l ,˶nYs]Ziu
+3f aW=GUJ&s*PZX!'3u6CN?<;Bf&:G%g^,3 KLx3@**]2?m[*s=ֻAHڈh")אՅBQ1ɦx?hI6y}wH<LpnmQ ѓO>5 K>GaU]#!-d'83ʟ,;w?8oON[ hddQ;cY:+u cz>q.y\˜6` NF#n4XaLgM,%kQ~ &k"vw=jrt? I=[o*q--ON2r|Qr%+' ŚRgt:6kc-'80ѢW?~yyWJٷr6NY@ZNYFAc¦?99rMo=;To1U إU[Иͅ "aͷ Ld0pOya” X\"4v=6;5ςo$<!)U:
+W.-gLldG#YGkrbU㔮a`M_l CC,v~s}ɂƢMᅘqm
+ƭe`y
+RJQf²dQFGsnoR;-_tyPW~k׿+I4?ߧ]?+
+Mw%>ThaJokŻ':g1J¸@$\bXc@EYzJ=!}E6}b9$h؁?lLMiItp56','= }x.a{!XE9Zn!&X+hi~ѤrW:(c<XH5;IU%d6utR;^!%v߀/<]'p 1JDbU.P"o
+C:},B:+8fp9#h?m\5Pf@mGX]cc1i[vFO(12xi6[
+z_h14݁k M Y7{0gr8"ga\qUc۬cgYKI}d~|
+\F]5jEШ0w#Ga% 36EQLY{{!½OD03^w͊/l0V8wtzt`7&(6=;a ;VO~'7X];}`:_)dqn%&*ޔUDwA:۾.;~]y"{z#(p~\cC}K@Rօ/flvwlbH%Q0cg#i s| ~Z Q{x:zQe]#GBVTFa v^y}OZ7՞:|qd_ϑ[-6#o@pX5V;uLAEEHެosN: 4Cp~кLv\
+'MNꍍ&vpMnU}< fϐ6!_ن]|ޟ S1NyZ<SgAnJs <|BH+PE`edMH-14xN{
+ɓI[]xhҊzPݩ?2xB߫W^*}$ޞȞ=H
+2]M\wL
+ipeR&! `89|߇|6ddɒ%ْ-YceK^ZݷViK6` NLif:tFY>oބ&aU K0\77/4pvƌ[3+׺mtHMrf z/{ilVqװ0*؟zںf:hm~LKs(UAŵ:2-=w` csu{<í{Nz=vJ0bTr϶2\4%PǡIAΌ{X!|\Ve$%>H0L=Q:1TJ\_< O sJeQLcmXJ
+ѐbc-].3gyuLtxQk<!-|?>S*}QD? wzA2]+轘H+2}<QX}}IW{*v!'W_l:9"oZYG[2ojv~V]
+ܱGQ, &"Խ "M[i#墌ZB(/x^- wO*S}Cw/Mgt}
+nAKp $5ɔ_*!|| 񾁽tRv3F(f!ym5kU3@&Z~,3#]9622cK(6vF(hz8^Dp9f}ŸTssv'd8k:_+|d?©L $T/!bSz}T(H$hO<=09Lx2p:ndbFOv  amVOOj\foL~Lzz><1bcɰ&2F(3iϒXt[A`˰ٻ@e1lw,Ӷuږ@^AsXD C􌍯|p9OSc.E`l-Z0\^XhHv͗qF?9Ey3, TE.?`r
+򐑲p%M`ˆd!]|A+Y U
+,6˵!E;#JMVF8!+Y]"#e=ooݛvB"$w]յ=>#/[ޣyv k{~YWsc8cTz`ywG٥-swv.GѴho!eOpWxW~R\PYJ=Wo *Hɢp@w@ҁPf{@0ZlYyaf րkPz:$STݜɚb$L$8{q0kP1db⽦ޮ66IѲny=ʢk~kU>UQ^+=sAWz0'gdCRL)n
+UGa P!:(
+`@ !BH9IHb||ٟ 4-8vu6m{?mٟ}ퟌx bvQ1ʔp}bmtѕ;7ښԦ<Q[9DB w&kC& <82lwTN)xP~Eڦ5.,!:Fxp/)HMs+B
+pr $\a0iS3J*-'ޭZ<fQӡ=dw_]l[t|11&ciK|,\BA4q,Ww䊃^ttJ/,kELcFnZX ŕ>_!sK7jD)0V]p+~-Zʮj(1bcG>ATB
+20BXokG}#")eOAlwd0ÈqDzȃo8c }IOt!Tק|v/zr?1c7X?odh?" ow?Tk~V*_Z:MaOId@Yxp݋"5og?ȯ5ȯpa۪V>[]A@6/ג+ frxl5$ WwUf-'|3ˁГnQjySjM\װEak',ltI/(\ ΧW  8;1
+X<)}H*r T\=104'gW#8f`^Vo ~cҕV(aTrD^"<(G &Ed2ICa^7]tjIH)D.M$rĸ %j`p0=0?n ͥmEuxDKcxDqx8X Fa6"`%z4cO·ϼ5 mN57dFC0B|͂Qw9L`?&ˡd1S%}TOLk&X6nHM`p1>Ym6-d'9ĹzXq=ߦ%ǚ2\@0+1;C}:GfXУqQt,=(&@ܓA{*6Π3ȀԜCY2pYm' =pq1 Xj9c#
+ZpAAf*g捚͆Ώ GzC5nJowZ&Z/`j.gCZy{Lb'L|$f0'l9S(kj|4ݛ95og},xE^=o>`},jPqg)r㔆oƘvo;d:@7dzވwyfa+\\\DTU,sdovW1߽iRiEݦ2;wN(Un8_8>RtYý f7(xOY9]f%zŲPpq^c[R|OZ/|j~CS-Q;C,Xq*M zp 187){=ጱkbF`%`-Y]ӓ11¢y>Y?47 Lmflu=`zFGئp(_y©Z_{ƊޱTyl
+[@B'ـhW .!ې%!@qN|$>v3x|߷8NLrKjQE*:_V?>[]6nZU7vKlVۂVJw{ AT~է3, ރs>p-$΢ +RWaގfM/{{u[/op:v(Tv%s^h,rJk E#yd̃db47BbQp&}+Sxz[k^$&vn\w:/w$z9<f.8gԛv#pjƷr۸inNAeWsо A&r5uwu:<ؔeŘ :ޡ"ׇ"C!rS઎(ׇ3Zi}m~~&is$O50|Ӛ:ƒcXd꛴ koG n1cȋ |mCާwde;\"”RL0>kM!ѧ֫tzuB]"b%37FYlqd4V|X΋(Eb
+wH9z?[wtOlz{PJ].R[_ǟL{>,#UWB0m`6d.AF&8L/Ns+,)z mkؗξoLUUas\0m(6 
+R$lQEADž;3AXܒS/I1q\Meq4Kcڔ;#Qc$$cζ/T 3[y#twdK.vYuAEZ7ie)/e8.(?>O+d%;w.?>y݌uݜll+xʩoC|5Hq+J}uZןX/|Wu47R*˭oEO/\qY-|Q08ONyK2v/~H?y\EGx`N
+Y>s)ZLD\3?S-PyAa;@E+,) JV*aݪIǩH죙.|o|Ss!4#X9wI{C| <oI ༰xFr]ItB=?~MP/x\)i.f43 ILX䘒<DƞKCˑ+MKx/u4`ϙ 611;iE8WH` 8`ck٬* /tteAQX
+]ݬfzNuKU1pBSH[
+<q{Gy!at{p$Y؃iT*wN0;;!׸7׃|,##RBZ)٭zF\,'7%Sa1|L#|`c@v0q@]2ίPԕ"Uz$эޭ&![A2R2V2)JE908hH?c?7Xfg>q\*a~T4 Ù๦Ō /&|PlRg-JG
+/{G$ӎыN'^Y*s__V*{OKW52Ì@` HA6bL4I
+q45*C\9#%oXxrAQb3LC^?(Op:wCuOBU\M,g'w7b)/wzMݱt=
+rS5}S=9&.E۾9QdkI}{r;gw׀ U-O-?4yp
+4fsSkR`at*C?9uof`PU/n@.B~y'yF5WVF
+ŰY?nRs2AS.^s'oYq'Tp%a.90}90avkl9%8\xmTaZQ~9V7 lAV~PQރ8&)3)5Aa`J%;dHz'A z=<ǭ.m[վf\/ uDƌR;B]`
+z }[Ⱥ5[ #V@1VшruhB}@I1dccguʶڟ7^YVz8w,VduΝWܯqu|NO3]{9{5͑ьQ/EWĥ)4qPgh*XyFחJvE"PebL!Sk2]W=3_dk5}!=~#D+v_e0`Z0vv|+[͇UH7EjHNWO#mmyD)1P֋hS&rڢWSm?;ª)]>'lnh)!.ոSoϘPK^>lXr2oڲ6 eG!`դ\όu]ZFJig)h8Eַ1 K4lBULC2s>وIx;`r*enh;̽#Qc%5&Uva\֐BR1IHBƵ$Aj ?!&n9vԄ)W D&2hT  骽Hw 9iIA&F+)͒"E&4?c8I&ё:|k6׫XV͹w жΗ{fx{2c\1 x®co
+
+b:#/[WßK=?!~XNiCUm#uҶ?V}Աfj1 i
+.G2k^޷F-}{ʋ3m)N ]eMćr&Zͨz1j΅tB2ߎɗ&먈_z/PR>m6 &ԓ^80@uݭ2a?Qrݏ\.J`n,]ʽYl:YDua#sw:N-''"xG IgݦpHHBJM*V苃X>LU=* 4^Ꟃ07 K$!H]$501G2%<vc>Gxp5uJ/vUZEۛ7ܼԲB&HhebL:OJ?iHH)WLNa`_SOHRVL֊`x_wcK]]xK'0#87@t>kqAѴƎ9IXl3C<و=4Fh9x ~Yhh
+p?I8qґc@6:}2S2f&tzF2,G0o!=$Ѓ(9 <YMkwlr/0!cwWph؊ -gp}yb؎|hڕ?^ -u9ҩ8Eߓ06p_!b |
+^| xЉd8 zy^94 2L!oʊp/UܸNP%ܷC9۠?Z -^z݃eyWv4jF+i A# =FO~%V"u*eu+7ViZ~b] n& |4b?cS}'a5n5Ş;*^ ٭.*x$Y Yڼa5诳"D2,]EgxGzh)mR}\%[)hߦ=wAK\A90I".e$iʾ]qsigy3Ջmm΁WVz S3)`?7vSlpS[~ 'v)#M
+5!Ҙi@M3pU@;o>L M?!i!2YbNzk˙Q@vz(F C 3PWERkOnؕqpGyoU4Zh@6.kݒЅw@O7=\(c=oB,Yxcey W<#_Gm|`.W08*q讧Hk@oZX@UA#q]LF&:*Ѹ:xih4bgxqr#¾xJ&x2A9^̉^-OY/b Sx=cP61Y6dD(BY$(z?V?wFQ-џS"|7[A?ol
+X鶎DN֦GaxWyU63 ]qTV丟84v-ʔٯI<|"p?n~hyP^N!t+Й*ܑjX}'*NpNrnmL
+|^jZˎ7$56iœ
+G??cGZÊQ뒠kS[};k8%Yڥ$ZSlaaqppW_)?^m<uHJ<V?|"nlZfяP&M"֑ϥHլP:]PORF
+A$` `>
+|J>MpqӚ8?:N\49w?;@1ZnYc9!J6[TM):yȀ98KOi[`;w21/=Sq
+= Ͱq?hcb H p&Qv* }CS@f}!_Xc({0BA&B{@\YQfE8;76_d
+0yZg@ឃ{؛CЃn
+R}:isҺ
+IKvlآZ뗰w[ ov=S\Z8pA|kAXp8iVBWb.\Ϛa^#7ꈦiRl>~ Ž`(iVpS@F'¦0(0`FBU:mPZd4Ѓ(]xu)5E +,8cN|m ,W}A%40O))G]۠^=HmL#mꝬ,p|_:H
+* S[zcEZyT^ް<Z7aecNTs)%2+\iOU]O^6dVd<zD*qcx/c/=B %Nwnl")ie/}>Qh8:z;Aqu-dW TWiƆ[ุl++;k#>7V̔9l3EyCvΦ:t__29}缒-
+`{kr&*h=# <VkMoapg^NGӿ%_H$^oqST?8Zs #VM~7v_Uץo,~2?zqaR`-q$YzU7wO GU׊yƧʖ"-}#+uUFz^nBN;̫٠ܽ8>_e޿:6<h~?[i&Ԡ QFG{zhhm0D ZlbvEG̣f 3zxf{Il=_
+L݋ݶU1j]eU[ZԚW{ؓ4f_u7@oAg i.% 'gi vyHORSԔH $@G_$ssiVqpt8y9^'7ل,p>1䤕y 7)9slp95=N͸NR@T[=+g#HnsV@G{~JIrIRf0Hʴ.XrYw0\27hOi6zQ\#ggG
+yK41?@9XˊУׁbSSѴƸUxJkZ
+-Z ,K. ,[d,W<:039Є(7,Ѓ2
+45B͹Yh:h@hC8 aBg:[ }1]AMy
+6z'o(8/h.^b8_fG`ф  xщ
+Ƶ\quH Nj5&+f3S,t XI̺Gο|rE3 +~LKRa]\ʂ~&NcbT>@bT"N;E"S'׍}KD WqR.V.o*a/ر~12y8ء7];ݭt=eue=8 i[ eUFY[X%s :Y[~B0v͜t~{Q͝Úc0]0Y(4@fԩsAqq22f]%wRKL<_K&chMTLH,ܤs 1pv1y:C.D݃@g ;ExbL/(XN+eĶ5mz[7XqESHk)uw>/ 5[^{paNɀvvʧC-NmOLb> ѵqO։Zq?3eE]KR_hNA@JiUSkZW[ W +޺|l-@<ek?
+T {h"̋Q!:%L_j7GllWn7mt䥢l}hOsаa'2" ޞ@ḡŖD<BPmJJ]00*jVqW/Wˉ+h^Vz( رn|{!hӥlEP6B<<Kj"[+ne٭\c^3G{!W?ˢS.tyf߮ڈuod{*ThZ ۀLWICWU,QRt ط%l2\;-F-?P *fdP20qnd\ q.t9*ׄS˼u:o) 4Q<[if7ְ WWj&n|%X]PZoZ~߂ Ӓ 5A
+"a6kp5wjh(l*vHvZǁJ)L{pB@nryzH!>q9!Y6xif;1|5ypՖWVPf3(9<K:LԆ8}31'Xё0cF椔0ƋiC'FnN Dv^Tj-Ή
+초( K0JLRD\Bj XjF_,+nޗnNvZ8Iy5E~8² tTv-: !v蹍p+oiG{w@4녥^-[<m Hny[p=s(]KNqw?h0Gvf'=yv9Wz.^:/1_`ޅEau]"E<}˃z_F^^}WrJu"=6u97b<w) _+&&DܛD{HRNGӓ㜴YGzՍf^~՟X`Fӑ4ѡ|Z3ԹyI ,y)?!v}q}p|q3S.F|uѧ>Cd͈n5I=UKr+KK ;vTE!dhۡ\_MrD'B|&dw:]>Qa/o=sv:qZ{"pXJ:Sw+(Y
+Z +!vn5кvAmRf L*AOJ~7}x=epr2H3gUSbP}\(x&#v=W|UNo'mv#@AǠ 'wĩo;7;恏#>{`;H/*V" զ /!RԘaLJx &3
+ Hhe.%d[lN˒]֭]I7ؘ!.gbz$ɴ3i> t7߮v3R6ݜ9|%7l4'_z,̸?0<8&O[\i߸~/@{~q6!F]4T,(xr6 УSV<`Expdށ&~̞
+>;lCf Me"g΀1țD-c֤U7H:մ=e-Anx*\67 :#Q0>`p4#`Ab'V)-qU_dJhޣ>!S ڢaj̕< PC{;rh<Gƕ&vV95R*j)meɦ9zJXm]A1r:R{q'fƠZǴdD& kF x.y TOHM}7Y[({x#@*׮#ɹ@y9oH޵hoPtS'< WBk@S+d/
+mGVp (U\ٷ 8&2cr#3cfnXc0<HPk/5`; $#QM9Gm(T]rCvHƫ!Zw Zs+ [
+\14 *MbcRO7˫;F}#H՗bDOykHV#H#y!S|>xR˾Wl*l !Mqg?580°7 5zQ-IEbۯKEu}<J֬
+둊Jj~&m]㑉[nq{r(ҏ=i<>mLMew$MPe.󨦲;_:θE=Ƹm*j2⊀8  [BX@BH# Ⱦ @ ZKKkǭ9mOO}3s]tvق2fBa
+IfVW*ECVJ0JȎXIhᰳw.5㲥vBB#h!$sM QZ9ȣTAA')ivF"-oxnmpr
+ՎCizĘX{z>bGΙVB[a<b~25LTs\ENi0 ҆ fwxϏy
+1~+
+zt
+BXvg x031:Pay ~Xn^#L0Cȅ B>8!:n8^37 /lFxRanlkG7 Ez[1{@IᆦCf6?]RqűU2
+ wC!'r#+}4nлdCTd%oc xM6>k O꧲ FJPG76ͭ@~p7ΟS+w/i/F2=y
+6X~x1DnQyX4վS?CQ(0
+BJ@`<%A􅖄K6 MVjy<(!I[
+[0KN^w;7e
+Yzlp>aN 8> o 1Q!2f3y}a^5DM qq2f1bZcR5^*jJlAG_x+ȶ#Wn
+|Fn[fQQ=:L7]kjcɂ;P e~Dt+ ªX\½z6׭c1)r-#SR!u[@ۚwN[>gJuSv6]
+2 }Cp{[W@B!ˌBόx3*lf#wN`D\ eHgv#^w_,(J{Lrupz O}yy{Ä{.<*ۯ*[w#^{Cbd,L!/<S5Vۧ.DE>\=Ov~wǝ9x^{ʄoq_MZ0w!_Qi8|4U͐cb [(5Vwl6ҫ?gZy&s󣈏W޳ٳ<pJrD^<8HcGu=co,lK׌Tl9/wG٭o_|Z#[/OܞN E˭U8ϱo N⪾YEwԇZԜ- mQUKqDWgPJ($59}4дEgj"
+df^3"Ip?y=DXɬ;
+<ƖG IB z؎fT‘Z"8׻}C:O4$\ջF1<1Y~h \bI .w3jdU_I˧ʪ۾-3.Ȫ_"?HkrJD#IbppIܧ U.hcgA<W?})k[,T¯ֳjW&?n??v9[PRcXIHʺҽrѕ9Q
+/X U\$ܽ<mivȽHۛ(/ZmKܼoXӷ O/fn"WYGR5?Q-+yCm'\ , 3~݅Nħ@;d!]aN1
+p\e0_S;
+['P;D2L’$h#B:ѨǁF&T{ Z؉6g2iƷݽ'je;)DVhMo/)ʁ>w}MoB֦C֧CVC#2D al«98cN<x.rm ~e񕱾sb
+ޛIV<Ͷ9p8MN!u_k:KﯻWJfק-Nڷ КCzw M{,1 3ѯK^SrO%ĊJ+8g\pe䵠v rYEr{|>kBz8XW3npN XqNDƎABUvuumh.eR+N߀ߟv
+P^*T(;Z6,܂n2
+S0VS Bn9??`=ˑ:~
+[*X]J1:³VmuJY
+%AV2
+J!))PRr2Y)˕H^[! ڑ mtY"7<Sk9[ϙdh5'@?I] %B;vn\&N nz ~- ,ຐ4w}jڏG0gC Y؞efa9DP
+<#5&|/ |=-3IW䏊X{ wu1`Fz+^M#!;g澳cLjC G~M0NL<ay0>y1-+y 5i\C{ÿ{#KNj!+%~ i E7xUMNp+DXS?Ŭ/
+x]pq/6=_?'ћKXstt --B<c\B51PÖP2tU/?igUf ,)8l!% B7'8q'GLd
+
+I@!uBa0;-ؖ|ɖd!ɧduZ%vu[eK>9 %@BL:L?G)eǛVvO l6_X_}d9s S I'롎3%->MS渢9yTֆpw]mxuõ]Sº<g&5GŠ緕׭ޔG4MyQ_k*%ofk?x"dVHz{(F!\ª F Gp,]|qn7FMR6 ) r; FLt_+Gߡ5Uڹs Q +J
+ˡĢwCMq쯊c\wqH
+F^k<&̆vā݀Cpp*j$#e{ aX \I ~4/$l[TM]*ׯZæ=PVl$sߖh-kH]'YiT|U\Jo3ui2OtFjS%%-˫c1)O )&l7?2 m-ϙ}bjZ9d>3psSWx?FP$x"yT9Kȭ*_\o;9~{.CCcCp_bsQi*O+m_GEsD^j =0`X}p4
+Nv=a*`DDp>t5E~複fptDԷCbR}y =7~\~:QhDmn 9L:𠱗^fV-e7v{Ƈޛr;VA
+.T u4j7(i=Ѭ`ҪlXeo]4)+s_
+J<aiZ~]r7**texzudx)CFkhmI:k=q]|DotgCrho{(;=]m\*9<z&*w^Ok:۶[K}[3QмS}*ݔ3>sDz:@f_{Sv@'B ހⶺa69eMl\[$2JU! "r[
+-Z9[=2ڦ87?- [2__! fQpZN/qC\P:m]LU8n28KZ@4tb;%[~iukEPYOZꝳF5?z͡YB)aP:7Fx)glq#OL|NU %!1`,6յz-Z파M*bQlR> WQ &<<D7ekQ'i-st}sOt}_<G\Ț((xnKO%hlC4<ip
+k$~m"eYyg=I x1sy2
+\Mh]B;ޓ?@E=8eSN*0m\>
+'t%YMP3;{fkv*$;}b[׋on=. s ^d!*IoTena]\?*o4ctz5Oͫe7#!{S|΅C,UnZ+Huo?9+uQ Q).ih]#a-Zl<)_Rմ1{d35CX)D/lλ޺Q$خm|įaKȩ'4Fh̿ҹ1NIQCʕKe7]>7ЉO KXbVW\\%g 8ӓ.7y[vA z?TjQ{l<9W(3Ƴ25&'Lrt{\y/:5 π=<΁Zb`BZڄ8L=`Aa 
+CUƃA}55!_[0퉬8]hp tn,C:&Favx[݆ `t(gj!s q`;``BMΛ8I|ܕwGW I0I?j6!1PqD"u%s*5
+#"}9+~tw!=XWӮHشE4.U69SБGm۰ڔO B-Ut{?u9-~-fWubB:1c-X{7 rXpXBK+s6A^pc+o|ݰA@m
+qtǺ9kY@'@8 ]˥VJ%7CWq
+bVryR짼VuϘkHmQπZb
+cFBlIDqզ4Okvp{3e&Iïܯh;faܱPyfܒ-`FRﱡ2Ć 3"3gaVd$U$b:q,FAk0491`Dzm0sQE:î!f$"xUTXj.)lK[) $T MJQ6>(/q OZW }p 1~3S6biR67.MSqNBNJ'dN B.G)UXP*< (3{P|@lE/qa;EG~Ç3=wZolmaix\<ѵP O̙; DTOf\5gicNeuZ_Gs7qa| e &@)$B( `nB9\`˷ْ%uKnYJZIս,A$u6i
+&$><;hw}S$ޢ3U]{z&\C{U!ERRM'R,!W&oIP> ճ '~R$DX/:u*\+|_Ub-`qcpOҩzjh# Jx0Dc T oeƮsx χNQ _@ܝ.z\h#1)YzG|ag`ߧ4$ SA 1q($ ZLtL|ڏ@'/~;[Em]7zW]RͲ[ƪ=;%?1/(D|WgJ3y
+[s);E7 [rZa-KOO{sw/)jU;m#1!֜$#1]:QN8 \x*!U{:pIc`-J(:עks^hS Eu#h ]IAԝC}wzz7~ÏTqWzJER=1ڙU$Sn'b
+к 6'uYIF#_
+>eO[$ `ErqUP:)EQsrwcz%Aw?,vqK)Ow(J/,UQH($Kt5Sj|]aigZ7e=W*Vqש_[]4t<`@^;Hq7<`?-^w~jX}>vmBR0LY<
+AhkBf-C#*V{ӳO}A)|,37Eq'|XzT``5:zQѦ˭ȹӱzٹKоG_|jgK"h)Fwptr}yo
+s*\
+<óH=Mאj3єh^!L%!"5ܮtÝ:p)L5~=hv
+46 2i%=Y81}EҠp|
+W.Fѕ~ ,:R8,p|(-QF ΕF7, V P
+ -U<Ԁq]OX8emK_ǻ׼HIڪpIϵEIS. ML)xQDH.RBdL؃} DD8/ptƝtb!gC,2c3jr !0FZ#ҏ3!U g]\2mw1GaWu}tv&!aĩ!FEp|y.HBiJ{ycI7#F쵹'ʡkNj!`=5uHlH?3'5dԯkS%n6T^ 'k?jAh"1q&iܽ}UgV1 3@`\k}MY/<RD_WJQQSSؖh^ ?}J4 . "F|<s_AEӧKB/87F j1Yڷ3ΤC'.PS+M?Ih9!/c /tؔ==cL!bqNŐs`bnMYeeF;>!s s"QK(u e ;a`xft!3A /΁52fڏLk!-Ma ϋ8Uuxs:Kllлo]!q'Ӄ#ãL{a"0kq=H<aG PM T[;^mxŨ|ٟS(3Džes@_&n߅-o?PJ6z{w _4{{M}5C"|[JmvQHW2<Iˣ,qR5B^:R8 \vP#jBgEQقG/A*I
+m+rJʆKugo&TeApwӁEL$0(9>MG, sF^7 r5HPgr,F9BᨍWUVq
+$hOdJ7RM\{[0UDTѮ4:EFY#r8wAn*1s̃8+;hT*x  GBB H8rrY R]k=ntL[gg;y߼}!'zn@sfG|; #fKeC
+K|0'㈝~wFzv3nGG2
+$窢ŕ[H-'TI^m-y<).ж3lT-RGXvdR(+gb31}4 4nh-W-C@ ]IlFbtDt|Y(%(m(<(1&:#(RN>PYbʳp|fT0i</D4Ev^'G7#PxD9vI.*Vk wF^D-l,D2q\zTMjwXE2…XtZpb t]i|'tAh>Ὸm|Is:.t%Fyj-Rg|i_/I4MR@壤峃KYZe<f!{uY
+]$=?I7HRz +s8hf\>#XNz: :$2[2LӮQܙ^ږЩ,eNU27e^s,6-&% 9s xJ?)ݺƽ*U`klcY|vmia{jWEU7~SM}Mǎ'޾X@6$_ZH02:,p.ĺ?bd4uw3sLsfC zQKTsL1^BvkzPOe`GޡF)ɎR
+jטYf##AÐ}:U^iæ8émvŰJ. }3-XQ`FIQ!$$w\@֙ ýp!+L5hԳa/-M{~e`˭Uʾ1>Q[ViiepcH277}f:ȥi2.x)<Jㄅ+DTiaٯI7Sgp3xk
+7w؇Y\\&u;5'UBqZ\̖(}uU蠯;)) B%YExޥ)f'${ّ+aY"R۳EnGETr!I_+0P>#ƻIζD[-zv)Ǽ½ukbyc~W4g(Ѫ[>eDV j76&2;`rB2[K۞5ha
+17ֲ YM[T`X+'5Ԉ
+wIsgSO5խf>M[[!ޚ 06~ZC>@RPlTz/;PTd4D'qΤLܺ'؋i߷w*<z] amFoX լw=ԣ+:ZР[ u9i8Mz˻~^1Q@`lBQ1P |!BMR(),9vjV
+FAxP+"*O䗡,Cl%?]q  x]O^E+M1!}{KpZ^ֆFcp3V*e#:nGt28pF~KHc):. %C%u[0m2
+8=b FvEN.
+@IB
+d
+
+>%9WYR=]&8PCEsURABVGB,/5ގU/ZvUymkK/ӱI‡PUʑ/jUf B
+en-BSP
+!@H#ٟ@ɪ *B54:A"M-Yh[ e,"ŭ (F֩JR1uhӜ>4H"UK?Xm
+n "ٌmZr8:)hD&O^?n<9[ѨD,1nnu H/+[5PƜǝ̫|<h"Ɩ]NhZ3<kp.#<8X_!&$^Ύ^Ybfз{FHe-g5=4-V٦mH׈YMND!,FlM>3 Vޤ-2}hm udп3}+ qݙ6'|wvJ}zLVeelѹ&]ډ5)'roEjW*Aw,g-._ |l ]PCԏ:?K$u /q%w"d>j]mu_4?ɒ׿![K4#Nq&P? D)/֏ >ZcWN Wtԉ$'cbާX8Dc[-ri -MH)Eݺo~AHjϫ& mHx{)_蘤qt\ks|ҍ0ζ1j[7~[ .ȯ?3ks.긼lTN PcqRb}WFϙa0Oq8}$QÊOB.}Zo??H-6ӹQânzF ғF"R?N%fjF:ifz0渹zB>b;jnm<X_!qس8@B6F
+I9y09! ([c#iW7T~)pdݴĥ{kqCAAPB 4Eן H:/]q gO)H=|Q@3z-(i}K҅Klg7՞hArP
+H}i> f`@ T:DkrgBrND{ ӺSJOp1]R TGL1Z lN/He\kQ+Bc>Z6%aS$r6yBCgwMC">çC`z;KC؄#Fp+V3;C!X˜߶mw
+NhEWD!s&lhv=d3{ª5<d4q;gѨ:"!Gjd:z|-`9n,(XY"+c ck>?/Ȍ#YAHHչ?gJ.DW>{AzB؟Xrv2͊eD#('g"PV.UgjA^N!HK{AfZȉ}An!P[J
+OÅU擛A7w 7M& $Gv2mZ7IumVy9DogH-'!wWs.f㥇XxaAkVLT<pb79 )Caq),*p :~87ЇWa6yjI:D!w}țUK:<mN!*<ׅ^.[1ڄ$~OsuX.9Ya-=\簯{źGXU6lì=j+Vua澐͵ y=1ۼ7X ^Sz>:cp|mF aK* j> ~]h٫[XhX~.jBRiQ I54l2la8F𪞍 "sV{/Ys \0G=Zg%o)~ù/ı̂c8D% yQEQHI[U~)d?L¹ʥic^G|tizo!ԓrYrmWM/诪w]<370&*B{m~tv⥆1 ظ #8wܮcCκSm
+_se7T6͌/ǏགྷGAk}F*4l^O$xZb>\~ "Ɓ`d|
+QÄl؊n6[8rb#%v2n ,+Q5 Y
+4]![i` `¬@& In-yYa;mשe/NߖG~@4Y#o-tJYtG_sZG^HoXSh_] {DNvogxNPK~0N4UI&FY NYiIů㠛7.R{aʯp牊lz-b",dw3 w rAw.In;nқF{ÿamw8ݍzr9輩;3՟M-:{,ՑL[iŌ~4>M1GԮ&:+"a;Sܶ~IزAd79)VO!adQzY20߉O瘏&ݚ̀^½/ddm1I5H?؁oǸ;^ю<w
+vl?C;ZɠZ*JՂ P3@az.(J/
+łxp"0DĀpB@hH¢A 4<?O0䛈8}
+$~
+TckZ\UzUinhM[ j]o|`U+Sw]3kƄfUU˗89NI\U1$
+ɖ8b
+'_:!*hJg:8i-oK}KR@Y^*r.2i}}a \q4LJESm/:_ݖV9x63v)rV4q[IeS/nؕvU!KctMtkJnCKfLwTSi?bDAuP pT
+HH.MZh)I !$$@MHo4egwQgtGeuvfκ9gx;;YX@ c7$~Z]$=zdZPw'ܚ)WiԆĦПۧO'  U*d Ty1򶘋y@Ipb5ϯKz. ĸͲnS+r.H>pl> 69y~XGW =c@oylr}_< rJ,_AReo{cXޅ)WSJ3q2uz_ė=w"PG'.>vCaKf+/?_vڏW&mpm{x(e}D]끢2LJC{αei2-w8#s0KI>`H-΋$42E+{f0uϊZq؎ܦ@iD-0ɦ*N[};e{@
+ `%C:@!+"9MpUp>B\
+ÔV@uM/S^#ۚGn%w9h6
+J)$eL
+|q~#7)Cl
+C]K1%qa;APR%y~#oZҴSQSX0qIرtQ\CtX1T~)2c9kǙOe(]-1. -#<JC "=.\~>ČnN/¬F['#Pܜ|a.QiWyF=`%5{4??ۓd'hj.]h> ~}R r+嫼?D"+2+ g^{YL;nw7~ʽ3Z"=aCgp )[aן2{"S!
+iZTXokGZivt,XrZ* !fΗ;dֺ
+C7eb"?Ws+)bCbx: ZHZK@k~oyu7]/"ؐմ 1]e6=cU#ԁ/-y}2i, ewM9"Ln4w{s:qk~aZ}Mt}ȭ9r[IC$79Wچy h)\%v'(8
+iW5W`VG)rfW e<56 "o BU/ܛb5Eр S%SC%aD"uu8l5{z3GKJaڌs4˲Yg-slM;b5hU,099ըb,Z%FujZ ARPk\`L'x uX 3c
+`41V _? =f]oVHmWM[=M$B-UsWRi5+MEkc\e[b&XMqֹ[Fy]n|YV<-8i$ɾɬ x?HAIۗ݅vj)Bs Y܌hF!ܢ*,9ܝTxnz|KEd*\QMi2ZQ! UD PYR!lbX! ! Bf% IXM
+q@;4BR<n8:V;$ܗk}~W47 5
+Z2;{ JaWj#hvL5SܽZlh,oŢal°Pl,$V$\48BɔeL:i+mϺ$c_E\ܣfZbrki9.{tGF2#}$#k[dY,L !ISh SXE[4@M?Imy^Km.<NXԩ1k~HFv jؼD[9ju*z=vR AzNl;Xb"UЛrZ7hM:f?ȭšN>:'hy1b9``B8(W%[ )DZ޷o^]NqvsNr;1G`
+x+
+*)"̇w ?iœo?\yGM~%@10KNw(fPN*w'susԪcabl ʬ#T22G6WWVnZ*-'ΑxZ߇P{;Z}'Zw#ʈ9e9>1՜Pxqfhq
+z\a.pN5fz]OTۈǃֳx%J 
+mQ#09bYh}C/^s@&>MZ]2ݫH#s+|Ϯn` maB,k5f*VVdJ#B-4vH74Sq[j&Lb:)Y@!ۤjDsx&pw`CnOQ1T8 ¼〿'BsA*[K;;o}>SaF0HI R67<J׆o"s9bbMhj.e'3gcAD A!>VZyIQƓ$¯dE6~P9ݧ5Rԋ 9H{1'b@(*q'BLQIFgZH-HU@JP3Xvz>'Z9t#3DlMUЗ1\*g~`gir+BfLJFx\5;[7_ȪFDklK#¢II)[DbjV
+49Iwn'[ZGƝcN4o'4;3Y?D¦oBF6hp6%0Kpri_ #~8@T6_&ein$rK~'w.QZ.[ߥ?aN[!+>O'<<02X]C_OXOEQSMՓ%PA#e uTUbewY/aՔKiKN>9K)(9wK7N2m ʼ=r\Ʋpp(C)(촸%f壸lξR/QFMJ"x7M v[};wi+|Cw9m.;;^ZqHlc ֽ.ͥp[A=RX4s$Pcu`LM%ɅN=`[kZB#p<HĘMT&0pu?]^,reg@o@ON rSWγ:ɹ=}ʞ55-kJ\ ־_[}"k/7L7U򚞯f/%B4dH 7l-
+Z,X~,-p4SЀcNXF;37jxaKĶie-%L0\
+QQ@"j$nGEDYED@dh}߻wiYdQ!נƓ'9ar3NxT[[=1ǻ>lt0Gcn>m3M]%N2ڴF\S!E,Y2;)v1C-d7.5cFTWW Fm}V
+D~M %TJ iMjR.չ5:V"5`ʂByM:kGz˹z{SfCzv
+%i$AI74l[G] rե0̱aü^pH'E>kuD
+] 6'nKEZ{0e]+ 2q´u\B3,^E ,C+a0(2((Wj0}gH Ԛ1H(1~_'@qD%QD=QB>kG{pxFgVlhNT0j6ﲪ0'b`>h?RU< >Q_PsPQ;?TzP(O[QJ 4b}-L"`Avg>bhڞt@&Ytұ(*HٺbJjf·TR&1˦L7sg_ʟ*JfD%r)gTN뒡<~>^#B=_]+U|ƿun:;Ҧ
+IӮGɏoZgȌXꍩß/L/h#C}A^̕4g(CIj3e7&x=D[U5(M״4=֛K]acВV^R0&<H4 79J a]e4X8}FC|n[+;_ǾzģuQ:O U$.I!T:TgЙ_3"v<eYMZO%#NR>"?WigU {:Tx5Fڻ\.%xSb1`0GWJp#Wk°` ߤ*
+F6b[[ƽ
+~wظ|;f][ۀa."ЀU
+ϼ '71牪}Oiq33a`X?9CI-`휳$g0g ID Hz '8*G߅ںxvwA-6E? SvKO~(<]܎a%=eZ
+z,=:_åo/#(sf`{გ‡Gǂ%s\AM%yquQnp@g(wG<fPQc "
+/l+4ȀB. 03Fm8YC>?b wvgUq]N9"+ Zʃ!9FAlE7P*i~,1/ nܸVnkg#'n]'nޠlvl;T=N>}XYptj} 7C]^VK`Y}f.`Za`\5bm.
+'jQ}$λ3g"?EX(!/p/]v/6p$^׈ފmsG;ftj&ekc>9:Z)iRO{M0L<YP{SqG94>"y윩k>-G 8=.57^s7w_gǬݯ ɮ=*̗ڟdw8,x ft!Y׃ByF(;h ݲr%aeeB6g1mr+y_uڦDz:H &.M* Z9@3;mc<.y`ǬW62t<mD|?#|l5R'\Cl4X`E ^/>ӠGӨ; #/n\\88`mso}"d7[_xSymo7 >IWٍRT~U럳Օ2ǩk~=omSbo
+mQ0|cQsLjrr՗]̾zS^!/tjFARkrzs!<@LVWuif&t$|.1 嗔42V*6
+AQEGyJݞ;¦аG!.~کwФ [lu˭av^1:#\/p;AAƧ lsA@ANێf @In_X:2'\fgw6#'/Y|Qӱ6HqH\O*)뷁R2rN);@VV! l+ n'vI:F*@'(L/;@"m~SAJb2XCN> NV^ vUkY(嫀aM8ӋGZq@Zx!JBPȸFlbH* w)TN"W"P#D;RwX$ 1U] M}P4(pEs$4rC& *qê ,3,㯺̇e3**AQGqEű MBU[Hy&oz 1@ h0Yqd| m
+$Av9|lywܬ;ișԷř8/ƽ# "7t
+ZIJFȣ
+M/Jʗ$ٺ 5 q
+qR9@7 xp{'T`FWwLZ[fK,C&i7vRiE~l5י0ƾXp$$bgs4o"t8j5ȥM,93fS/E0\ qZL"he, =6jo- uNWgH3,FvsDrsv7=UPIs"άJ#iOfo`[f?TbJDe: GEdRWՒJ_Z-u&gݴd~%aO-+$)u$g1:a z>)$M[T,KGO(^崱W6Pn'f(B}D l٨#pvP,:\kKKxX:0m*JJF+i`bs\%MM0PlI#YrGֽWg@G@Ay1}? (-~I2c"aXA6AzvI1tL ].<.˦jژUdz y<SGwEIsJ:dž/.s1ST87z@F֣=J3, IZ3]k b_z. A9|?I8q\8u)^6.i~$kCK\+;us5leU3N,n Aj CK9Y2R谏JڰRHq r0fC6}^U?Pw7sKf"(BdUhF]ӗM"m#G#=|t9@Nl߽ eC!"]}ǎy3(HywY2õa~ة7yт ϶wm_uW*kQm&|K
+Y^M=>';lR٘M\^&9\>]Fb <cÔ m}^p`h"&ZBN)FQqG,VV*`#";C]{6
+LDADl:ye Y " !! dYIȾ'@Tkuܪu˴Nmu.*0 ._s==?6TEr٬<簨Wۭ<0, cEP|QlK0gԆ[]{kC_φn ^`5^
+PhAq nrdv !2#$<{D`& [8rP$K@w Db+\eaXN` {4Z*2ſAE"j^#aB"MX-C.ki-{)z|b)KY&}xb]5–ӗõC [hY/#>C_FRMyv"#yX{@ {كW%?tً{P}6=OD%x`= i
+>ջ]7|Sf1]_<ʡbȋ`3r9MXo7"әkJ3 y
+۽Ԥޔެ0tS|:Y 8#:No%;[Nm`gr1
+dz6^]8Ncnn.g;]?e'uBiۨҦb/R\W aÜ'/"?xWDz<0Y x
+Azi
+rc
+ٕb]{) @ 8u$tW7ycԑMzzn`VDgR[gnrT3#KANuAO  |7<\bΒu]%Ay/
+4i@Ar%q<wv_oiPR;Mj_Wa[ ^2խwӳVBoM&AgSs_B
+?#.eP|hI-ydտO+KLjs?d ?&Bm5 %gNI_Jm]P}i3Hџ0]~n/{'K>T<W>SԼƧߟx۫3޴z( ꃨBD
+*%v0r))g9Yk,~BpOz(FEbUw 3hĿ+ꄫ(ަ4ggP)m 3h8k*<b+9IENTKPƭù2ly}c*U8!09^H5!遐SlFƖM<A #Mk+s?kcvOn^[ A.܉'[:^uфU
+fqIX3&瓶1Ki5
+޻6"To0eatJAI7So?y1Ou]1~^qS׽yEסoNr=o#NyŭդN3Hޣ;_Kv+ˇsn 2<Le>MBLSH+-hDz\.3e1l~T$1lhL 2
+'֎I}K:1D"WR~OEZVU-R7F<ס*lw-b[KF}RȴKn$4߀=:T:h[<eWjѴ_)YQN)GmDžKBV֥QmE![n)eiuYzHnPۦ\(޲ N݊6B;!yDHg=H2͋x*ƁdhE_e kCv 6Xduo?)z|OMڶ.ldgS0LqW9כ 1+Ӄnv}薸KtB(Rh
+k˜ /CP^ / = _O
+endstream endobj 51 0 obj <</Length 60605/Filter[/FlateDecode]>>stream
+HyTSƩ3#OZl=.Te($l@a@B$a
+.PkQkLhntV3|w{9M*E <JT=:'Rx7|/{J`mM d7(E< ՌY,X˸N] :k, I-,˖S_I+~?f=-0UYK!,JS|wZ m&P1N]{Mx)ײ@ <zYb]3pUߣ[q<g{eZ2݉QCENk3
+DSx%\&MQڵ$U,֢4F(-&-b31O|L
+#e )_(
+q^˳
+SǠ6Rh \am08kjIBv9r2b?<^Ԑæ0Iw:N^[m,= |1z]i<#OOGx&8u(1o=I4R3M."س1|j%@JA;&+-adU 2N:Zr8= FjX\Ev)8Cۜm\N/i׷|\uMZT\UH)$\I
+J4 {bCGȘigK.XG
+ 8D#8j-O|oom. hiU(J!pP)cx&'U%š!MHcрh\@x7, q]]
+)/Z*/,
+ސ/ 
+^dVZGI, g(`A0d!r )A&1mn36v*ݒvWnl]Œg'zldB[ٳqko̜ }8{M+yj8JC|<R{PΝȲ|c}Y{ߎ[FK 7XOr3RQj`E@/My/ΝS?I4,4Uڢ 8@W2G+m<|y ke'p;R[}5o[m8Vq#9C"+~Z%(2F5w ;Em1N<w&A:Nq}>?q;<:pʌG?}Ն
+tYq8;{:V5XhXRYUe724oSXjn6d֐cta2ɇQ#=vVΖ:`Ҧ>
+[aAYAU3Sc<QwvkOFv;k_ֱSiἱ[謐CecKi- ua:>/mT'PJIF!
+ ;)F ڰ_3䀛2{i7@}A*dAGX7ʋ^z=pn^wx@lG*D9ۜQ&t I2|DN'iHs zo?o7A$` @jbp
+;(Y;̝bzHpJ(0Mtnw焳~¸'1O0Y#\,d} f7Agަ c
+6S%Y_=XNM/ՖFQ2S!2?!S*{OCM[
+nNC-5=I-ɔ#OTឧمjYI/_TL(NB+g˛-?XYXy 嵭sGI7/r{Fj'BX0DoxTiɹS؊}M1aa ?Nҵi Y-Sl5_>{B)&|iu5ޠ<0:,# D| $7$KƂAc?}ti#ND8OhHƌ{!(w\ڋ|xE6h}Tь:Պ6$h[vt6x թ;^u˥CgX}Hx@m! 8@]i44zгx׀ &K/Bz7h3l&Ec{gv#&ו %6lP(
+03 +gVl!IS1WQ0,h%7S 9i̓ɿU&@9.~񍼲3k vf,ļߠ؏ƽ*dX+ʹXGx:AP<ߜsncO9?k:* (2Ͽ>-F8yce]?XHrԵmƊdKKn!JpMGdEzeɏ[̘wiΊ4OBQgBj7m|}NDgY~\IS1"7ޭsQgaQ
+"=49G[޼ ѷ+M)JaSJHEM6r/om-m̖^3+Qlm׉[j2q&#bƳfK6mQֲhV2hTYƪ/h"jp5zp6# p2) B$Dbgxʺp1FDQѴߩ5QT"i8z-єJV$GROS#hXDZt+uU+%'Zr1jW<4_-k'vKHD) &$"nQNN6TR}
+b}F*/P
+@~CI`Dl*
+`!_?١5LQEwY+hn7ðC:VY/l[: 0
+?438qFQ(eDE2JHX%@HȪl ! $7۽XB :ZE+::jYEL?{ν9y~K`\"2X
+_FM(˿FK9YMq5C$p.NuQ]zO\H*//VLERl1٭3.]|(.IP Qx[!IZB>k!Oj(X-i6V3w "yN!c?[f( q2X;wD}:= Yф_ ֧M41?U[ONȓp{;ZЙ}̥dA!^}nuaF czf7jj/7fɣ!ں6An0R71"D<Ut)-WEL߮Fߙ>a?7ui'~qk}NI.˻BUtmgO(OQO~Q?`'I?ė(y@N8LY(2n)1ncfmi o&SC+ې<?GDze 3~Cg~'G'4eX ,!ZK|ԃL»uop ;YQKߒ$xWWY1YiUpqXOv?~!.gK Ѻ4KE%ybutLyr'+Yuo_s<mWe?tNTc 7rdzĢK:Aba O?`,\݀ jj{TZf>oDM!.z{*];NRmtuיiʮw?HJuE7NbtUƜ?l._BB<1͔U^ (^.;WOFK!NoT!r,S0߬V<i,"!P*b*[VgQV-hD hd)M*S' JfVIC:j͂AdשU[
+Te}Γ/S*=Ci"UO9욌i<J|~JM|y*D?toLby
+{J/Q$lX5ꯊ^lPo]3ݓZd
+iW+ҋսd6*Df&٤A bCăҠ Ze%f݃Cx5
+@m
+!*FH4)&RlU'K-B<y%Ȁ9 H.SX0
+
+ ÿԭ{~ iTMnSr@iTLn҉2
+&&ʪX XO$
+,J sl64WX5esj39WlaNK~K}0ZJ)56kR˼DNJ};6o{c~GՒMbwRe[SUg}ƪm$Bk+!9s_T\N)!=ydwp΃SK9<!̡`E Z9+D]ں aԠzr
+QKޢ(ċ}F܃]@ж|Gr?>o9עwAYwzO"X.
+2Q˞SSaN*?˜ՃD$^onL>j fJ<.{1rw(a%
+X&ղcdM=.cua5H!mF:0dn^S3y7U<hIKEk
+.ObwC9NǛC f r;-'. J_IӗNr_އq/^E.}yvwK r̞ʈ wqtYo|$%vf, WH|WW/fFJZEzB'] s> /t hC͸Lc"JI:Q_<^=G1V="kՋh`&]\.c!B}Ϭ[ng'@~k'L)ӠNw+ fb
+-
+K%bP#H. IHBs$"]V[E.l"Y}߫gyIwAl)h68V_4l*~-=+xh8f*Hgv^[Wh$d<=a^3]ZPZumЌ6רra}Cal葙<u:B{Mp|a,Nfbn3Zm@Ǭ4BV)<TԝF*@p^EVm$~" mD%o$Ucɵ-m1RbbUu誦(D .
+SGiCFu͵MH k[a2T]AF#+p\)r C\#,Y (Z ^Q).Q@`H8l5GDckZ4>
+xe]L ecy3e3m`P-(6"uG+e
+~sA҂"m#!X8n
+JT
+v N"#m*")O#ӫyyOϼ&8>j9:<5^8>q{^ xꉫ4
+䌟8SSS'
+wwa5\P
+#_'YŌ7`f"y;\1wMy01ZwK[BG,Zmo{E6:KHh
+VSR,O+$QbIe,(fŃjT̒i$NTW;OR
+C!V3e@VJJL2,P."j 8xP%,a=7Oe@(Z
+QH&.tq2@7[`eL1OThOzMH<u&_ Ic% |iG
+);!nUN<j LXZtx8Dɨ 񗖤&/F֤8IoP@INoW*V h(@s@r'L@ЯdU
+H>\~EwXqاFž8[Ez(~K+{sY,G%s5
+9uvdє;NcY ӕ(1I}S&8B1c^ _iMJnö?4P136dBY`̸W]\HS 7#ktP
+=Qru]D|>$sBqvTN{tTgI{//Όg˯}z7c>$
+ƿr[lpOMϪK1ȱ#$(Ĉ0lۛ!"
+yU”<fTrʫ`<TGA!ZI@GUqmy~=O6b״VߕOv26]Z/I``w uҤ׾T~'BԓsVujF=@t>AϺ3SB>e^Kyw4t|yj+>Qq7/ b!dR~:7ڊf yN_k]|E}wY;_,:W(uuɎم46DBNAQ hk
+.@<p]|Nטb2mpS#̡[u-3ʽLLFUS<dr=L"nU.2rVRf:K7d[.:aɦȸZ8!m٤P.~đ}I&zF@3Т
+|^Mg^I#Ihl*ۺľ-g;W&u*[iB 'hҮ!lʁ2kJBwRfla^LNsg<L$+}tCč=ܖƛH3 H`IOHn6~:My.3Jf;c.c\|*cEjs,#<]}sm].z*nұ!uֽ>nl[mM5OK'e`{e7߷g5Ьv_=}Pfio,)_[zHɘ}l$[,Lp˟a7Uc7NPzc`]$mU3n<6M7 MDr0O'B_|Eto'QTŎ_쳔,uY^ME4T..us`NNtÆsZf`V 3aJӁͬ=tѬ4}^Gu1K~yum;.k&iOQ|ɪ[
+n`,Ǭ׆ױ:>cXBy <$ `M2NaS~=f["C9RM!@\.Мy|WgB@,iKeH%CdP@&&0E.IiaK%SJVȈT\)5()Uj)caF +) [٘2
+KCrדQ.+$K.d+ZT܎!Cżb$Dj)ȑ\SoZ7QjT\|)==GC3 q*K'k:Z^͟9_dg>hTYJJO_<E=_& WTSnӦt4P"uS ;7~"}K:N(<?u2|CoI&wqG}Qʄ1wmSwIN6Fv#vN9ה0
+%O򼼢«weSԱK#_mLBll Ӟ|6'9Cb2jfa)G-qsέ>4b%޲q'Y$k$
+Ɗ|$L{_FX8Zv jgm ߜd^?,
+( ]E<4W^<nO>W6skqs+/tI|*&*6,]V`4T?<3 %N۩+X:jKΈ QR글"BXB $@ ! K!$!!;I $a
+4V*<?~9;|w瘷K*CREW\*RXOoHG
+]-塒PۚnuӔaIzN[@5%>pf5 :zH[o6AǷ
+yLMqV%S(uet~@m;/X~5,9CnȇuƔѭuqc񓛰_wmČpFIbBDX YS6$ɓZQ伿9ѻKz crrm!I(;bdȭC^? ֗?A*<؞Yno՜{c>n}®oIWy͙C;Ν@jj5ߐiْ}
+V0.f=W@؟1AGkRl${ doMKz!,gSd4/TV3Wcr>Nv-zaޝ<~Jgk1ǞüroTVCz7txM',)H|n%Zt2O|Bsp}ؾ+˪~#WaixFR*Brg}JiMGT'_nBG-_֚Ҝpe8N+a2k0"fE6˒+@"EpmLLWsN}2G5O:̏_2 "vNτrl n:4UEMcO;`"뗽˴ν@Ԙ.#>ɥ 9\jntwm[|]k熮;bo
+ЪK"(G9bøNnYX\߈Ƭ~oQ+
+WbW%+ВpG(}tvHh釹`tĻȔra h\_d̸d?HB_,D6<
+ Ww۔N:ji?F[ AV\2g# D^?'aSh;N^BC a35M{ gn“E:vWΆk=LWz6#3W؃z v~$KEq/N [)3i `'2uSM/(oVg7 גt;X,nA-^a2pSO`M紶QӜx }nnCgtxQY iB! 4Wٽ^uu=qr76|`kܗ"L W3- :񵱋K|(G CzI:"DܴW iHO(*6lϱqTJ0Ƿ9gksw~IJ\ˊy3Uy=G5ẜ7AR#8s8ɐ
+}\ז"1-o$]4n ꭋݬ DZrmEz] Y?S֑#N<\?6>r*
+v.ا)Y_ANzV
+z֗ g|5Ep: o~3| YZwsqsa kC(;+cy&ѻu᩠K,-( ^r&kkb'&:&"̷?ިtxub Q
+tC!jYvh(B HА9FF-nh
+Oh{p
+E;қV'݊ohHb{[VR dZzb%_PԸDZ |LF>&̿)ʖ7|+Iʎ,I{~W~uxL#ɄB&=5TT~e_pF #?l| #- ֬PSd<nt6yGyKԻ=̅3cgSM@Ot2^YњVcj#έ lQM%/g mSbW8~Tf0{K?(OGs\5!=u'D_ a
+e{cVW `7#aOd2,t
+{iSm%oy7(RMF^Ң?ueiWv
+Cf<EԨ/~\3Y4oC h+(tKu`:Y10Yf&Izʄ{3p/j '_uR؀<Xq檉jcŻs/℩?{[?e~٥AS-\
+B7mZ݀CvA^Q_\ߧ^hr{}^w$1۬"6Ym]ZE3.wBi=Qdj:;uT3Uz- ӹfs`")ӉV$@fSXK4۫!z_p6=nxL+ ȷy"#yP [ųFwd(t(t.T23Pc
+;L8(tHSLQd63T*eD=TK粝DMf Ĕi=\A5lu4 X2 2:9PiI< H
+eb_"?
+8PA5|SAgxJB
+Us\Aɛ3Z jT )
+"H5c %HP܂%t͗3"V& $y
++TV>F(Ӡew*b{X<KǐA!tEK(Yއ"wCB>V\<d#4?uI
+Tn}B_0MTLz0W
+G/q!ԉ,)h? qW<9{<o_ @Ow6)u2gO#`~KBu wԬ_kNÌZCl+B_:0Q3V尙S$Q:|,+pђ
+;i۶9^,ۡs{S"y1` 'jڗ;aXٳ° /9c-OD,ݤ;Zˆw %$xY5'ُ?5 
+;#DK8{(`eae/My.;sڍ'sG9/a|GD?6l!Msܦ or0*ELGNBߙWA^fxp|xOi홮Ћ%~Cekek/ ?_O
+=Z =^P׌)axkٖH ZCn-sf&g6Aݖ Ppe:O$y24 ؿ;b_SۤGm)R7++wJwzv!2TAm*FeJWP9̖6UGkx=M^U-O*2N}xH;׬ح>ѹQ H6S4v&,[ƴǹ^&~OUY2EvUMnh6PͪU~XS`(즩r
+Luq}nsJ[dn4#&s=k룥w4G5i͙LMf]8OO%%R(Osԩ;ʌ*kR~C[(O.J!%& :6DƬ72CLLm"̦7%e3 _% ae0f[ËCA8QաZǚ./;^t'bދ
+>UbVw_?uEhؘˬ5Ǒ"HN"g?9gHԪugE | BQг+,ρd]<? cn̨
+L1kN ycj# ykW$n3b}\$y2Ћ&O&ܐb.3//
+@ƌZ}7eX<~-j1r>#^y8wxvKsj CY聒)y:<ރ5us-v΁k+2Gz:uF ]Z/D2S3zRv}n,ꢤ7j FgK]L>ZBxP凥*1
+f@$ G
+%E
+ 7%xSS^xwNx4SgNRy'(CÕYcl/3Kp=Ε,mrX-*2Fn ++~5X^҄|eLjkOg,;{lnsC%e$ -5nɸ5F֨b Mu\AR-mo5-j5QPY+UEb\&*dJ]scӠOtYQHUm6e K!U\u^fukt# hU~{[䲚b &Uҝ"i:<GO"%)u4) g&
+2N: n)MuNB5{Z`מ;Cn˚ɶ(K<>Adn&鰭SUֳY}Ejdə ;ٱM|C 48jo <\[<Ϣ7~5_rZIsl%Ǽ"fѠ#.Ї'nu b=W.cᚰ=Ek*L-w1 QOQZ{Z0+OrIyRITf6ؐ'I
+_[| d;mٮ/wAfc ,n @`?ّfD?ƣsl!hkUHz϶5yp5UQW H"3tpzMK^&2t2*&J+)ƈ8߱)rYK%(?Z%o{QT"ISE^X9(G5a+Z8[uK[gԖiՕБ*;Ew%* Ro:JI-ŤaWeZ_EPY٪2Su@QRzj2PtpHU0PU0HcBc-iOYOSGa 4Hi Unگ,7),g(dS}}Fk=uP|*cpdP-YRsN;p*)-n0P=*E<̇eR`Bqqߛ W`/gO ^xް|kK[*†
+u*@ݎU@#w
+ѻ҃oz0c,+<wA3NV/ xdGBnV(
+õ~ SZ\{~k'G[з f;8K8rЖ \U~n~ =ԇoJ,m_JkR}l/=c<9yko^>H^lN|6.I_P''Gm(qkڰ>rKw;DG^'&Y_JXIRpmV S!A-Q:uq++*JzK2!&w̖]v*@=~r 9檅rafԋKvd󏲊絕1sOi7Cęqső&e}VĪ[Zy7% 2c_ נuAg~"i3=f~lߕ{Lxwb+Hfw_̠m)_8C*My\Gk\q|\l'<״|fOa4!gNG?]((y(W קIFx󨦮<Lq3V@p*;V֎+hU
+( ;%%!$𲐄$@,,V"U@(Zʔc{;}~;oF#&ĭ\]Dfim0!'s)( d]_p)':؉?ed jbfMʹu֒Kw}JJ2tdЅFl K{ۣ@GA`0.i A04jKs˾ m6ճEǡ;tѮwc_'@wƨ1ڥn>,B`%#&yu vX֦6)@3Hv@iok[[[Uf@nBϖ* <VT+tEdNRߪk T)f*_aa $NH$Xb30 #jW
+[ H˚EzHƉ*H,+n
+UQ
+Y߃ ux:XD\[ jr%>g|[TK!"ܸBևIF*eF,_)GL0ne1*M=E4C2_fGe~ ls
+N&?&ίڒEŠg)EzoG26Z#CWlyu>km?|_Kqj{&_[X_8[侬Cs֝In+~Niu2ċMJ/k$%ӳ]~mۖ%MtBr;<u/=o^ӱDQpw P8ƭTsZ(YP^T)y(
+T2HODRhm8qBf G`
+QT7p 3B<Fla9[\j[EScn]/~>ǨS1JG CPXTM8 WM&d jn%X+ZNW6מ[@YEn^KbOmd;G63ܴN6v@8dp8=tIce 6}
+bw;]sϘhoH&rL̖
+Mu2X
+KT @M-,ѷ2kKtDV5`hG D5,S,F%)  Ԑ45` &[
+ja3K+1 |BU6&:ztb.sj]x(Ux/Vn`iPAN0!
+."0.Œ($PQF :4A].ք̠!mlҊL9"
+066FAbFdrz 29-x:"6դ,];*,UCAjLa@;jukl 6Uب ' EBg0 PH7*nik? YIU4Izg$mfU˹MIc|8T/ۮ6xzDWEHmgmUgiGK}J~ʎ67 T`?w2ދ<va)kv<uwk˞e+/k$\^~k'RΡʓm^ѱ76qOv[^o_&"6ZUvtv}MƖ W
+\ϰluc|QIL)
+lfVsN^S⩏xǣk%sZv |@9s8JM6B%Sڲ⣷qϥdNE0RKorsn
+
+f7I2v~b0\A[Ž/] tO6_JSnޥTAq"S0Sv%9uʲ fW-<pD{-w|b( 8|*y.z>pq*HkH(_tJ_WCU܂ǛO9}j{áu;BvOA;1skم B/7//V/mYznU,rutS?WP)3XBGNw\8XwƵ>";+ CQ y?}¿ @ca#pG#yDh8"FC7pÙiĹ1#0sͪ}(cR`i/zqgT \" #\Q7m1{8xaΊ~|ag44ؓ{c'<gL͏=ˆ g;#ƟV<'' ̊W3ř? |֠h؀ipZ\~n@;g}SB%ЊBR@p/sS}炴{A>ў8#;.Ğs0?'\eG/ <yPi
+(誸k7; ʢ"ܐ@
+;{>Qf'?cXIoWl
+ZaM3R3w <Mv %ي
+>ҵ('͹#3;KuiίN_J;Ig>W.On2s /±A?޻ ݼ\P~-iʉnʎ
+b4H*-I%c2q0B$"DP\$.ID$B(9
+떚L!Rx"$9$#> H$h2\ e³BWB
+='\Mp(`sC#aY) ĒaDrTr ],πl44 p).%S=r+(pSwHULgEto* Dfld`9>ד@7!$r\L'
+/}//QSJ͠08*M_ejv*̌+,xZE "oUFS!kF+QHeOHŏSsœ 8&.L~FD0!tyNO5U`bl¡6Әic7ZqyP 1#F3DeawY-{{ :a˵*C߭|'O9ؒ7l¾Aԣf֥?=N U=wuƣSM?22{XiGb_gU585~QOzUf<A}>_5<.MjiKcۋwl[P݇UFc*~T#8d<dB5ѧI2If`<@&kl3=~f|X~qt*e%=*B+vKbiTJn=u~{ #gU}ا IΏ"gBgVOqjܫx%0QK)">Ҝ*Ƿm&f/5-L#O *ފĉTe Ue}6=;_s/u !F81#~AmKerC6OX?=umO7d,ٗ.Okׂ٤Z*y_EZNF!cQ-Y5ʰ@"\z~e1vDq LW
+ bh(F} L=ApxTFfZkcD${IoLByҜL p$["pL:WQI]H+yF;3`.e,iΌG8ʲh MO}|cNa 4Mii[?gO8 وSQ[
+c 0 3%$xጝǀX\!7*dx qD
+p=Kee/>;Ƌ%kCh->ihȝ湯]̛=·=LWr~aD5=l?>;rαUKu_۞2mZ>NU|sjs_* b|6Je<*'
+ G/g+<wKH _;!Es3βaLHv
+r/(l‰?*olx^_>{a_yl~1k{ n?usHK[h-gdTj,afOj-ջ[utlw5?ӷqM_-(^T|w@ɏY_ͼu땟_YUsA^h_C?*NnBah[,EY'
+PQQx(̆v-vU-bl4c%a$51;DyHB2M?Cd<e`2%i{Bq]( SZX_2gN FV*W!q?|s)9!XVKȾo],eOUG8'⪑]Ws-iM*FƢpb$GB(mO,Fc?N  #.6FQJ(H&g0FdG ,̓4L42L8DžQ}`8am:3$tKRēBWG*`f 6eh %6:J `ʘ5(-YҜы v[ZݐhAb-N:S،1'qPMTkv&X0wpa2Ex@dSXcil3'$8j5M\ll& qtz]w!^Oȟ0 Ĭ*灸Hԩn>dȤĝs`Tu|NW`&H
+~xWv%_^VU֍b܅1]2bri.󠦮=;yo:QEDq}.v^}HZTj]P٤ !Ⱦo$$$l!BB,H-*󪸼VeA=?s;˽wPѯW'פ,j|?11"u5!(&(}{?̊V\ k:{qZj= \;f6(3$Rå25JRhu;We~JY}ic>05zc l2<2L9O!zSSw%U}OupA|z*k6hvYs)au:=AL\۫zDC;\dN6g4Fty_lgo
+,a&1F-9?1iϢep9mN#k/2^ՠ;/; ǾbMTd[Qg;!j3D^2))3|I=Q3W!-ўrU9 q-1ŋKJV6&EN|)2[ww{|+ʙY?aaʞ&4-%^#L'6sn3eҍI)6Bb_p_",}qz4jvL
+Ľ!rjmA3
+(FQ֑R)~$՟aL,=HCS)? A/J#Cp?1OP2
+kp~
+@An
+d cP`;+ۋF:t 'v,v ƂmfOead'KУHg"hǤЛH#Ulc:{QOv R-u@hXB{ZY}ӈE73朼0=!kSX 5@铼VC(R+uLI=83nf n%?{[k+Ye+:<jczrDmeXN}G
+{kш'a@j<I.8JGV m+ [~90j#LvzJe'{3/!Ogd]Li",1%~35^`Ol&SiFϱ).4\d"[IFzDk`wM.F+ڈ"\gd)Gx1) #2!6@<׷6͉xˎeD:-$L}{T=]ٹMuIs? vBɽ?
+!u̅ӕ/m`?A-Vٿ(n`0y` b5!݈t_oSf?E.efƌsJ\&p*ٓݠ>uTac
+E[IT繓!Ԣ>¨:Jr'% ✗!ՈŘFk(PgdVF~oFΤFO!܌C,#X*ԛ$Q1aAyIi֛3wz=ҝF3e畈OqlW3@BЉ!qE_2CI$l.鍭`̣}I̯jR~J 0~.bKegl,ij!OrfnWt^SmO.C坎V"uܶ
+ovx}7[/k=pSyZ QjĒ"Q믈@|ʃlo)=y׼c^M# ])}wV -@гmjZȻ]강]5v(BV|TQ- y4G_IȲ,IIī=M@m{>}-T3D ]>XٓVވ쾵h>_*/oJ.w/:ȩԕZc
+W&#1ܣ&=D3I紙9$21C2h?0+[8 g\]'mԊ:JIjDwjA_.A}P "\[ThR)SxVu q |xu#+]egkKZN9I5Eqjfxs4/EU
+]K!hHpB8j3Hmg6bn&cS0H^$⺂x
+o:6?&/`M^kGry5eaY}:,CEEyR<WtPB% & !FzhIP$Zơ D@" "<l3ߙ;s3s滿?1 j/P9u
+l*fd JmiJ=Y~w1rY7؆PҌ [reYsߜ֜- ~:3mJIJqn] Q|HM4Q !c$S.Μ R{Yy-87,jFOZ37ָ]hϗ+87";$V:F5u$HB}“HDbD.bROSkshY|y\$"*9M*Z ۰C7܈;܈O6 Kא!ds
+Ҷ_aZ~ZYc-% q<P\OlxʫGLxNY1nM>V`&1"G(z}#eLv=7o=_GE&joF~;Q2*}<sW g AƌfXP'bGAZ(~7sXEs ذl8u6v8Eo@ o0.Nږ%=Q#ImU'sKMK@ACKzeY zJRb-:aNj [0a ?ܵBUa+Wl{VA6rw
+]ozp`
+ew-Rr8 Rd&u-Rۺa_Is'*jJF1i1gY ̥Z$ʟ sjT#aE
+lHoD2nA
+0f.oZ~!^+
+ߺU_=VI?1_bWfm,֣Ee)iAO2sٍI$3>m= d-X17/Rcyú1=<hOizk
+ՁKXg͇=Z'VW+b<ŇO13Bf,]굘ao,yQ \ب-2{dC|P'ˋ{e ۭž]…w\.`I_`(LF5oPN Ÿi>b?y"=Oe-ҤE$c eB=RQy
+A3,A):`B4Kp}ܭ}ac0|4y 9CvХ-"ܛ֦8~!:w&ۏjkjPMe[-t8V~ 4bPVu\O2\WNQg'ICn5[18$?Mz0ھK+ͦ`s-,XcL#Y=ـ!mw,{4g?4kZ>WmPDm
+HA"DCHc2I&2[!2~ ¬O޳ע"`HdI|?Zuku{_pz0t#M{nw-m"M;v6OskGwn4͸| ϧ]#Il9/{Ka L֒29yZnh"\z_gO䩎Yéר)k U_v]
+p71 *Ц)OP$  vPNOBG(cq%%^%*OoODJY<C̬]#J<~!Lc+I.Z E|"$2%O>E!{y]B*˨zgmEAA
+*ẊbpU8URnhI+4Ds}ueew8ff b]A؀S׮0@Tqñj𪣃}O_4#.4AÀb6GQƋ$>Nט##ٍ%Oj776>Oc ϼ&SMQ[Ü!k:y$Aݎq$MŪ9PjA2x
+~T9{ b]@ìVV4xLF]s6yK!E>\
+]xf#`n'`߭D6eW9f44NiZ&]6bY;z"S 3_U}/1`@ذ42K%+RҀl_6wf@y^`òl%hu
+Ui&L O8_C3IIUg jR@],^֣8%*r#c {l(Mhq{2xY[[R@qzQ&Jw2ϤvP?,h
+Vlqr<%+@Qt҈7;,不˥ER䲑HunAWKPn[9CKɼ7NK|B՝Nq(t/ ^6eEK
+<.!ɗ;$ **ފ`A™;$PTXAwFD!( #8;#ٴUǫUwu{{O䫎~+|^~D~ӱE=S7t3QQX>ӅZ.`` YWyh,+>Uj٧i, ]\Y:YyL*[QL v#rbG1o|skXQ98vyﭸe❸?܋5FK}^wy^rz|4綪9 
+ dϺKYӤy:a*μfB{Y>RڔE3
+1:y9k IieQ_;r^1])kN@u')Om#b csvx ն'I:E==H:|HRh:&mCX_ |jL[1SJVV *+>?Z~p IO
+HmI߿XC`ٔFՐ:䀟^pQ!{M0e\JB&nDYK8`
+β{~MB,&><0Nˣ!
+HZAH]d{~gQlnZ׀6 |<ZZwF8PD9uڭ*ToԆ-|[\ŹC5U)5cՙKjĭ(^Y8 _H~S+izPգej?OV
+&5 RҪSMEܪmΉ}E״Sr[r.y\nal+?POFum-ibMѝAe@cw/>t3+һ3̈́ -҄6xo!Y|>`灙]FntXh'muD-??^_8-:(vp${#Mߊy 4`) yOp-;2x?^csb3SqrzrE};5
+KuyjǕ'IeNY__$W`(u;m%=c@jϬPN@|(^ڨ|n5. kĪ^쾕}w
+] _c߈p
+~l-ԇ}+Eo<*p՚uj ZWHcg5YAّz,^IGhejI~l.-<C=.j$w)Fd}
+i1ty v5 ]/e0'7XB^ic{a#
+J/\Q0b5Z愻ޅ$~2cރCp%\J5 T!^|!w*"n
+搫:0fpj"'9 c V':CLx$
+nsPT^g5iEw,.`1L8=wΫ|Y,auA@%E
+f) Uh`7I(5S1'I]0EwqzDn&!NW9֫1.хQ \YlE-G0)D4R1f I.a@
+ȾDâHeI&?}r߽={o*xĺ15oR]1]oSY&il]щد
+hRQ^"+`}1G5mbq~>)g}b@,yNGBfc9mޯA͡nT1cIˌQ;musJS%{Ѿc
+ w\JZ]A&7[uiI[R#*/)gޱH XUm`˙+؋2:A,׏b21swQ0Ov9VPO,MV &ddistfJc$^vžn\p$ DCI
+6ޅʤw%V4D/b<n~N%^ŏ9/ƖPm[_,rREK>L=C$SZ$џll3XP&s]d>Gў"R-hg̜2 ~pBLnFRl<{%7~ ӷ汀$Q8xwK4'iFgqԧے4 2m%bav7:JoC\`uR]VE`[Vg.a
+6rx%;v1Ft9&RԎ?
+ j"[0mبѯŽwDa"Z0QGZA| >:h)~boFt OۜŤVqa-b%<Ě@l?K볼%RYz[
+nMȥs/Хq|^9r&* <Ep;OTs>Y!uR2f:#65/bOr A\03K(|p*\bf^xXBŪ9j2֔m%wޡe :j
+DeKBB ! !KzP3.""&hApFuewr޻}B 3\L^S xP!4HZf BN.
+z'sO
+fy_qfhc+[Wf$fRh'n~~U4z@Iz+%}`9]=c+fC;YjO63x;[2 dzx :D%VD6{|/DYШ<h+C=e*dm\F=Rr?,1WazpK2y3뎰=ѵ;uUףCnzdh=z2O!o{+2*0*5]rrSQK4.(EKE\%&Jt]C}Omy@"DUQٔa(Po;Iٰ9mr)s)[7DmUS[ +J ݤX'ZbW4w&Xj7ǧS#VIzhc<88Zlmα L%?DtEiyX#KrSZY*0M 3,UBˌ}:ߏhc 15<n)KGLr Iv>K&< d8-k#
+QNY|Ň* G/3<dX83_<BvX2NzYA8YJ=_<EN-&iW<!ZM'}Ts"'̀r O
+vM. *S˞e_|jILIfz!ڤkLo>+@_W\pzzrMmgm]jɺ N:8*?fL+H,Jl 滸VO`.C
+̰zݎu&,'ܲ/{ wu;/g=Kn.ޖ{k_I}}jUFKeL\s
+۱ SI2k3^:9|=iJTͯI㯾0UZ=g]C\6G|53qG\ѯ\s9~\;Eo:|cjkw7Bۺj-g^a~:QOŮuą>L_]8I]>aPxY%xv_~U%:xF>p>WUŀMyV|lׄ9es|M-'޷[&B`9\%eU6·ƲZr.*X1?h: ݣn2Ѐ!6lo,Xk^PbKr5eamP$//Kўr)w$/ャ$,:]nS=.}%E-n{jƥY$e
+,VUלZTջ/ Y\q`?6?P?OOBlW6r RkT6saBI-/|`W#ǍVY5Dm"uϜJh:jx2nr8'5^G
+K"K=_ o0m\T'*޸p['cK䋛P{ôa V/k? j5칶¼k_֋^ Cst;y_s+F㘉F11 "0LXO3V=No`@-DY8K=xA.ctNī a<|yM
+Q1gmbu)I|³w dBxlʤCl'1?=
+yھر+iݺ a* UtFjЄ$8cǯ;P+UTiN+B$$q~'<7y([]Y=|' ffS}ٰ+hTMԪ*A=T$mἌٗƬ
+GP^,n c2m\"'eY
+@=^=G?w12RAe
+,ǂ}Ķݡu@ʲ1ͫ˪ ;? c-5 $a,EIr]/#E_s1wvs kd p_
+x
+ħC<!/jx:Ȃq l@/ł #X2%2CJ0 G<1(t>4` ]%X?N8QఐfL
+oc~{v.
+ ,CSJs!nnW| gAk ~unSv5ײ{Έ,3dߏZs؃<Ր X#`|8ǙGPqp$eBbg rL%p00)1v f/ZGU& V7
+ǥIYSqy(h,0~'у8 P# P>5]]ƴ
+KRMXq+%{˙[svYŌH˘nQ삹Wnn."ƫ-iʘ>uT0g$(5_}'ԾWo+,핔i!Bs/zRG\vN);qS232c =$lL䠰0n!5jYVgYEh7MsWgUc EӉ
+a?cBs{J\E΅}_kY#AW-y[y}ܳGY5]"7:ZSx~@uKh$>Sٮ7rK/׌֢HU;^|?>|v5ՙg{sx&oE8}ܟ׋Ù34~g}mm~|OPùn)ĦvסnjT{*jњ`oDXcs1f$oy QKRi+3䁣o\sk*tׯ6gqjk/5f~ΰ(qgь3wcd#Oy
+r yuۺpr7&qK*|q. er
+!<@S??XF3ONkt<j+*X3'1od?5-:ysyZàF~FZ۬2uWw8FlH&eDomi¼)k#%ؐkR ?)7xؖFv'dĖ,n\ήX=, i ӂZ/h2o)yTpzJ}JO8)k"'OI㶤ѲD}% vQCf
+3 J.G`6 0"A!:Oוp&uiIYQ'a,IӒ*H֤_M9^-
+1y:ٸ$+=4!_oM}YE½2-C=F<\1cy
+.vniLM1mںZ7p4mA>~zK]b^-Ɖ'k]mq=vl6PMjĻu ,KXoa.MU ۢ"C&>-T$g*aάL-t 󖰕uP?Ygp2+M6ɺJxn [%q9\%iUʵ@aҎ*6̪S|IEY*{<.fS$J(0j-¶9iܵD1)*mUeusYZ*/y왓%:.i4h=A ˜ndJwx2X?v0n!yF棻iCLKc 1,0aX2!~%cGt1e-iWE
+1{F>ǶnG>!oVa=A.9Ǽ+|v"Hk*AOam1G[!YnIØ9fE#ψD<3/#!ʖoAܫz1ŽQpPb~P;V
+Ie_֣7shX0E*/`G=&gآ+,_]
+!-@Y/ʢB43*;M)%A-N7߫A%c-PI:s+Jx{*nGUOH}Kz{]fis S'co}3ʔfh3v4HP;d<z̵ErqJx7 p25_1< >I$wKlP[ ߈s~D 89%VmN׷4]v]o7Mb?jF-uE7jsR-5юi⚒Lpw;_T%Csy>9[s:_/kç>*>‘ߊǒSHGlUW̉Cq1⻦ S?fHo8 H5?3oFG'}O1~Mw}{ܲ.WԻo!_Qw;V0DOՆS4iǿ%!*t {kv3ꈻ :g6׼FcVVS2 tx y4A,*<mj zGXG?Q!& Jz OI#5
+u
+s+I] ;1F_%M=5>0[J70~xe:iDc+\twu&],}
+zWfC]6R:f1eK btUBot-d}#;B.>v֙ʐ }VOn0H/L߹V
+ޙzڮj8.ϼu(ɽz;&c[?/+ oͽ7"Pt:_^[(g"_ g^jFjڧ/W^+u z{s{ a~Y=5>UuGcYfj`Cw8pÆ$kSv{}Xz >GVeCӪڋϹs
+ jY+벴yS|D1xEܻwcF-v҃η~eϦΌ^N'1;^:m~~[Sm2dve"|WVEkWtB^w:61W}Kӹð/"~p&jvw|1-#巜``/0 X_OѸsZEC;S5q=G&9#kp Eε6,T? RWtlP]mh\bakY4cy2I˦EL)K3UE{郰(zԋck(Y9_(u@ 7_ DtE˟CHS\eJP¶iX4iLm7
+1_ĀCzdWmOh=Jj?U/c7&`
+ȥioW짢 ܘuRܐոr:5k]S%n5%Ȼ7/n{fQ9'iJbvm[6<4=PIm*ܦݶ:58.+򒋍ٛcDZlH_2N<̢8_,KBߊ9qsJS0!LB{!mW-ѕEWΤ
+sDVǯ]6^[AːS%[ء^(-4lmTqv\2~6D͇S|NJ=2Ƿ%v
+vΙ2=J閸:~cr'nKZr
+d5O!N_\?-[ƅ:C?}vGot723r6͞-</h!))mK]V-}y6]ܖ1ǜ܂b >G^q)Yv ~\3rÔf??`Xσڜjx͏(a@amm9 &.4m 6(WuBNQWQP0XLY rM+p-ة@?+nO{[>]up>R'\~CF~*i_=jɸc"_k6vwM_?m[ZI+^ۨ2)uͩ",9H93:kUlxךև헿ܟwPG/P{ɞA㗧pAU
+J: ^)8?M늫Gp#P8دX|zP62O5zJX`{Th=#u"s !b ?u'CUD|cW&+M&Q7c%c`\!0?U /tܡ`A1Hu cbB-IЛ3l> Z4C
+-;'ԫe:[ȣmC_fɻLKCUy~U=W9zŭ{iCl\ܕ{Tr_ jdIGİ&ǘPۄ ”M*n q#9bi =\bjr%AC^zY&OEgKa0r
+}AXgpa hlXϾ^Oܘa 0*0P;'wrͤ>[JɎ)u˕QnI^=^1+JOe5zM3(Y!۶c*f/7a\^f`᧸eVI iؒ%ߝV{vX4%oפDsZ0ggG2a\/$њ;%aYX4KEmZ'ͫ6a0K*8f ľd>~,I>G|O挘p[Orwl[>AߐdͲpmAT>Ü`L䂯zR`U}̮\ϑk9<hQB12 mҐuJ ce4 omD20ރ#!cZc!~#{TȲz*z'H%y5&5mұR @zs*1a] }u{UQǦ.-bέ
+̟ngۙ>i|Vb=҇G:SىcNJ:RoY|֐F>R^fٖT>5ҢN,ZtN&?/rMHIBBZvڵYk$9INNNrp_qb"W. 7u]i׶E# 7 ,EwW{x><TqL VӷI'Lhc=-9oO>~[EpqCb! 5q})#???J_L7>c#twܑ}>n cxT=Bۀ- [D/&ְR|=tt?|/.YJlQi1ĥ̔qWYO)3iġE\TV 9*ι
+V8Rǜt/?*fF%W^j s󍘰Uf'I\6I>-T/0zH<aQ%틫( 7 0WmX
+_7E%LDzb<(0|E"쐴TpÃ8(I5*ʘb+\DFu9 jRՔr <么y1خI1
+f*|UF^2G&;deaPEy6~YycBKl#dH#=Rnё.wrvb0\WXH"K,b|UӋm*א0fز Kpm{"^ʝ$M7f6w) l1LRnA,]G;ey,+Hrf{X0]펢99\4s3?ҷ83q^ls7tZV~\{&1Ԫpv׵@Z=BΙ4s>֝=~Y~Am͎ 3Ǣ9yf5uYN3Or^춯ktzݕNC?w{C?:0 N!Dl8IA #wV=,d_ qi:k^[wI\cZg!K7皮n }gt{ R9e9 ]7<l1jX ށZguy~jڹ -?4 TH ^^fuph1d_dwHm=_©sk-;z/_!3wSw~s eI{b!?iu~B}N!44c9:㔴<K><~[oiJ0=Hh
+Zy\s-g5:NYa:6AMW!YoUғa*pC!7 gkFl-1zU`\!0/mR5Zw =I4A<0AY0C6L(Z;t kxCGZk M
+﫶d0B0`Bro ?K:,8oOk4gR6MNU&DGeۤ#lut *KXZg*affg>=*4 l/gL1
+ejSi2w09-GL-^k_wmZx`B=Wg*_Jar<ϫ1G`G?VnV)3wpSScNOٶɰ?Ƌx6Zb`B2!Q-YGզ[)Xh0[sBG<ad[Px$~ y5:.<#.
+/47}=ias}s1ҷ>ߎ_bocaW'w?vڮ7D7݋ف/1
+eeE)wɇ:S 0
+endstream endobj 52 0 obj <</Length 51813/Filter[/FlateDecode]>>stream
+H4US[CcZ /AݯqB66Mh1d о
+7.O"ILZ?V>RشI E =2wo1]ϯ
+kw
+Nko o:>n>^;77Xo _
+#x-syTVZc:t=>џw9Ɍ]I I>3>xm~㎢N\c*_]~;_8e*:ޒZ4:O\]q5<_YX]N_$csEL \ȨkQ'iH}JsǞV5;N[|L>1~@tJK^asO*>o@E#7lJk`i#Ch
+/yw1۪2f]nj뒸yC9)jGS̳%'I8y.̲*D*#RAӆ$jTs/J
+b6NT8a64)AlFfU!*ƹY}ؑ3 ٜ6Fϩ#<!cܲ..~wf^ iexߋCܲ>,hwXPFe4J-@ fCdw7۸a4bB aznAYI/3$hؼ)
+q+&DAӴx٘A P˼{<shY$W;XP/o/L\&BU#`>˜bR)E1zU bH!0%>d q9iKو_Px\7d rZsp%F-a(&e3L35
+y(@4
+YMΪZ-E b ]\?:y4^
+8$pD8&Eaa3T4E;)'2) +K:o4 Eieq_p6h$uUXS%~yQ4c|E( כuN/F˲H٤0ntЛ 6+)'JdmD F/ ;~fLcFiȋ}/@lV+DLJ0|f($x8cU,77$7lmEd$!lhk{FFEqDAAAiVN]uS_U}ϧxŚˡe#0@^h$p2\C3;M[ZE/"=(5^835*M9_ 循>ChBU䳎EЄ[Bгȼ݂,m+P{u9͝_no]&eZ;syӁ_ klfט+'{tgiSk:$vI8춟tT$3Pp8 ele1킽Կ rv'BOpm3l= q2:F+׷r2saلq.,zQt `F̙Aw!57졾Iuq2t,u|_hw.Ed&~Xh%t3C+$lVlJ,joH㦒qlY\jw3eY?y!?*QV`0'iR}XMf3eeQ:
+N^z%^|w!؞ёv*[Uc2|GM*qӗ17|uM j<P7[G5"`Fhd}X?@Ui}YeVUkl~id{}? `I|;Pon-p%]+2<Ux>41OuNJ *-ϔI[3?Sl,7M֕薔,mE\͖Ũ7Q&`V ~/o=f{LoeohW5=/?by93g%KIgO n0-ZVˊkӪ6Q$iֽ4VU-
+cYdzjnn7LKJpqm1k1<X_˛o770~O:T%LNOJMYg=v]aʆfFLo&Լ^BRIrذfu+/`:FY*>_Ece5;~*{pOF7/6P/e>ゼ*iVͅ{rWX?رDs=w<I}Ϗ>̪[%mZZ)1Ȼ{ǣih>9lYBMxaxyk #//'YfcE۞oB`:"y57081 IUaR
+;l\T4"*n RQ c_Ȫ_VKjE%`w08{r='eB3&(O7 Q.ΦV_WԐ >c v#io>Nfni%D Iw#~Fy=$$ — .(ҸO?*k;#<w$G/<9ƒSgvn+jv A!u!jqi׺b
+ȋT75e"ZdKyI}hzayŖ 3jo޶2,l,ӭԙ貔ƿ2j4:A  e#r<F^zWjn] 9q8З2͔0ꊿ-M 
+Ca\3NfB`A애[~t{w%8+78'7$O'h'qI}@j( ʨ
+!8ߩwSb5%PSԴjՖH_gJ7ν^j&,>O%[זvDj
+u }κw ~?~׺IQf\XIrG{CN<B!֍<\AS<@}V<Q@Nטw6
+t<xFxyD9KQ+EcdOq=Q+]R,ki{CCh}|/,GsdSQ9>n>˧zXf0PT7HI:3g2sr99~@lp8Y;
+ay} g|03ب>t9.)S/+ݻthxodSq
+̭BMT`m>S*d_ n,¼`ڶLlΓд~9g@4G2u'69<QrML"lYoF.9o:voKc*
+Pc OSTl1%2j9m]rnI9usEdKnЙ3ļT@v!+@D[9SEDA(P`UT$|/xIxrsw*;J?'LuL-Ƞ"n?xOD>uЫj~rsZ췵nH`sM#¨6hR7Ȯ%u9
+{@qXe|"2Ra|U[# Cj[dN})4ᇔ>:l׼danX+gZ![ 7F Y8
+;m%FGb#Zqs✄?p?I@Ɉ;MܴGصBLo|qh<|-3y-پNX1O8Vś'&wbbŝ nzW%up`a^n|ir Ps{: ۞wړ٭6fJ8wM6c]O'Zɿ괮k+|?AX1hzHuNݺ }ܵAyٖ՘C"
+= ]YQFUM+y}µf~$Nn#!ZMԼHX^,T]Kj[ٍ̈2b{Jk:p նmqµ=8+p\Hܺ}݄};t2Ƒz։0+,Y46b|v_fNYP1'CI̗;4 fsbGz 1Oڷ>̈&~LdfLMȪRkMiM$Lcrx0?Ϋ9*X0%l 4w0s_-JgТ<Bm3
+p8.Oz1@.Xarz y[ն2O5qKY̫NrON
+p8*j/:Os|؋qid
+~JdPQt@Xb0/+uV z£zע>/ihgWx O?k}R:U}Xն^i*[ J?H>yB
+f[KU1T횴֛~Jiޔ*Ǩ)wg w[ F
+POX?i /Ɏ\΋o%rd_qZEO<Z^pƽEz' ibq.o`
+jcy>D
+h% Lkpn
+41[G ;,hJFYQ?#_A#"Ÿ#~AYNHX&l,t7͖Yz5/*pME" }d&fT^Oo1Y}~Գ "r xb_6Լ/˫ rG ~lJ{I
+GwtY偋;+2ׅ__YN2PoבKw}wVkP&us:GXҮR' zh*]m8FAYE9ujs0헂en:v.zZia{3_s;?-r"U3CT"yFvJRi:^L?^N\MseVkʝe-:2ѻX¨y뚡lBqԻGk䪶NQW‡n紖, )yFD΀WssJdψk,>SλeC0H>G3´jEt}$o5a֘k
+DrGRUI?Lrɹ||_j}[|<k/hoy.N/U fN ݉˅-̢q.ZB.lE1tge404ll ¦^@*h%qL?/lק%IsZd֕`L0d5M&MurZb IW{}{ #°qTT8ofiySP>y7W1n$ 02#xm+^KxY9kݿ~}w1lq9-QlP]:kT\|[֙ ZcZp|8?l%wa4jA' AӜ8d^e 
+.۴
+c}ƧBvj>: L1%Hfv[
+;|nOo^
+lw7J?__l=L}Ο[GK_n9b1;bS;P|μ]r23 7<y{a3)mH:E&?y^0ʥmܤ ڪ?$7B6r}$Ka3eEMG /zb{vĜäII#A7ZI܏dC5 ۆTAV!iyHrɪ! 9!\5]ҲonWT> 94 5Aza
+8h!f @jJofՔ}m& ="EW4.YO>w,lVi}i8 2k}Mx<Ԟulnpav`^F-*xf\†q뚺þ;Q' }0<k;M'9C4lUD|0EuSQwrcFIuCiP&[a3ZY-eUqF߉j^n'ddXVT,Ui"[V1!t<hYҙ</rsaAb7w}>Xoa(lZx~72m즊8l([i #-v,̣eL
+grh¶E6nV4QZŒ"/Ƈ*ڰ}I^cൎwq^mC=5ۧTa&Xzg$=`Θu\N7?A {fZyui߲ 3_vsV۲U_+"#tt
+,7 3s_sFV[%,!$!!,T[;:cu*E@((
+s$'}}sϓv5˭gOW 2c^QTIZ3u8ߗ!'`~t^Q_Jn6<2*o3ʛ>M+Čʫ#2_e`rB%=r8IeG~ }32'eM0CX
+} .coHNzHCN!y>i0_s>4M>FڴB[J{=%+ԶhW^ VGpuOޮ<{1۲ ?Wnٜ$\tѩ850Rs=>X)AHT'̀<\N!|":O/JmHOy`_#1ΩM>8o;0FTCo*7t
+uWc
+m"{mA즾~`,p H
+1< vGҶW; 5=BrL=F+!C%JYPYXLRlgcӟ{<9rQEӛ 'T~<QR<+85X"8[^8yTIΡsņQIOJ݆IYuIΑKp5
+ gU]aŚwpt[ao"79u</'#U;_oB2HoT?Kݾkc+w.l,ѓ\gr"օ m{Lb+/eĐe$xGGbQ BvX;8cW`k{:nQ!'6s"O%nVYbMλGR@w1ϙq'/2saAMU#l3Ul,5u*
+W6Kf,eb¢kq'GSbgfk 9[/:;k<+vut i}͞g|ϋNG&wm$Lcnd4PG]ê5sl65IF֝\G*b |('w^p:3L^T^Ƚ5{ ; ߂=k{ /L'{2^7,cۨl}K4"kqT O] F,2^o6)n3~..Rs0bTYhOoq$n_=_~xzg<ۃ'"o^yxMu7]'yVSTQJkd]d%=K"Fo%hv
+z7QYDxp4HsMP\:Np|S]D}EA3v;+r;~p1eO)NB96U=>˝xxm`˸ʦODZL:qF^B"<<<U՚_$*yu5jIsqK3ߩ&wlARlWeq̧̌{$>2'KCTVt;tw)w#GriEaX KYUM֫ Al ;
+e̮ʚIeN+k3 3C|ޱM37twGw-=٧}% 5Zd`5jy:Fg ^=(nRRN+
+݊,NScX/zcݎwݺԷ֥zVX Yq bT i5DUM|4?I@.OI
+
+=X;ifB\N3, Jp>a'3|gakufnv߇=weqؿ{I4w1 SN*1Y)3.upv~LQj&<&-cel Mw6:Mcju*mV9u(6G}^=9z :伐5/!uQU92eW@IB֙u)=a+{npL%Lᡇd^I~g%=&7Z3>NwSaT#Wz8L(&a\JQlK?{Z_&\r_ Ƃae` /cr<ɚZo7u&iN Gj ϒ5θ Rn#2xMKLm5=#5UieG+m-ZtQZ
+cyv
+~nc ޼!O$0(TeD [fF =%rǤ&O`g)CxMk(?0T3}2Wj5՚.ܦnPGՄ7b;*2uЖN XՎ9 Ò*&UݔVNJ-(3\^?ߐs)FsN=2w.<CcUq5yvYr[h,`v[np_Km*bobړʙDşd+;%Ҫ;{?oe.oJKw" ڨr$!:m+*x,sŸ[rsaXGv~8iP;AZlԉW;mLxlSD7E`%0\_Jcavq[qrbqgq'&4|-,M${;i׷ ~N9MIWwV˵+m/]"'Zӝ&b$^8('t3#r*_Z/+C
+賟YaL ht
+ Qӑu8n|W`j3^O>I1̽^uzư
+ļjT50mgF_o&<Hz,4zI_ƴ bvNhv=%OrBhzTWאqF E!fD>-kpUyVá7Bܚ^KGMod-~~_k&~;ٲ{^k~v3RnQ3P
+qa~#>U1/K9| %c;¹ܛ& %p8!:ƚO=#:bx0[\LX<u~
+b1#n8_5}I<?s_1ϪZl+9 r/X6>$A?iO¿o퉔lpg~!?MjvBY%Z2P.ӈ 5枨LZx*aQ4B,A~N.
+"NJ܁x7,~ktf0]S;$sا/oV=8I\K uy)x:B/JkILb`O,Jtk޼1ApJ"`*bs-MQ,OQ+eUذ@ּ$dž[)!UWOrt9SnA׎~v<O{YG[}c_U8tp3?*:0Mx4J3r8ȯA%>?*..p&l .
+Hj)AMAӜ8tӔOʣp~] _6*H·Vs\T6N+I
+EEaആIO
+pV4kg\OQwLk(ʱ.jL e}yf'L;5Q9XXX&i&ImLT (ADADNwvf{|>뽙
+rR^QEؗ<OO*S%܅,K֋7C7,h|:yn%3f[/M*B8M }y%QoPy&ڏבs'TAx<N'a#dǵ~I'׼٠!tCH)A_$Aw1N2O^mufFqKἑ=e@@;\'Tԋ2"گfny4?#*3v[*fP^eM-UvS&3'"8;HO[\Wd{Le\3 sH6JkdU5=YE^OV]r'ۮ+vqK\tJJ6)ۤcom?
+?!,D䮣92vp$*>n7Ŀ}m]
+Eby/ywZ{Wo
+ 7a-ןV (WlDߞo?;;pm𯹝|KJ
+uE- <Uf<X&JIy꬗H-He>m~H|Ypx)q*kV94K0剜ﶟ*˽I_8.Žׄ“9;}Nr.*R}EڅcH<ϛ }ܤɻ)"VЗE)Nknn2r`5sC`e%TKrS5ͦ,0aYvȉ~㼔g+p-̾@BÖUe̲
+Qra˜ =gO
+yվ=x?lAb<gJ3ћ}o2 7 ˡ >x&+ 2"s
+A'^{l JġO~shD[%|[x⣋;T .g(Y}p%hbP}Eϳq]<w[VeVW<S G
+J܇AӸM+\=zpP6-2corS!fB枦#yquqX^wOU{I0Jz;`x$g]A].K]W2
+2Jg g#mXэ
+An"2
+q6?-8 n
+~ GOr~5atJ N 83Lۛ NO~n k3ԎPp7*E/.`se><'繟2+9g1+?۫f/b
+-x %2=Ӱ );iDPmлuqK3^eZtZu;LXQָ,'s_ԜȮ)[g,w3
+.<c.#ඌ j0ƫ3c+Xܥϭ
+;
+
+ S:]oU_Sk5lZˈ2!26z}6N$ɯ{>CYv-uq+M(0k&U{pbw}i%~jW^Կ> ~0f̭ǫS8nN,'Vr.VntWW*NӪ ?vt[/ %W>9E^e$(7[wFG6Xe.WS+rXuAR>O'+,3\b]d^J?ª^KQ/c4Ẍ4h}F֤ bLS g,,8oOAB8Ql^WD=N&h5\JP=GIuA96 qľ jxN5i~ü
+f:-ySl+:}ݦmy=p(l+b֤4~ 6l!]6!bfsAZC+Fd}g{Hb.WORc^[)'jXB5E"4.h)]Wh\5/0'Ĭvz) #{vѯzlv׳Dӆ1.fESq_oe֥xt05/餢ʎ66u$Xg> My)V#X8p=#GQLݪ{'>$ϧ}LU+f7-q Zf+ QS4_oY܇فoGZ8D=ݥ:(RH H=W<+Mߴm*BWrɲUDVn#8k+vLȝD{D^TX3y>gRp(پ
+jפ'?|<f^@}EIj39A{";`<y^x{IՙZl
+f󬴍!lγ8-Oe虈yQ!ޅ9B3IyZ1$D(Z 37gBO5uxp-f{3ȓQ_EoK4-Ye`>*nʽEwԪ7vJGV\UO!Ϻ5c\{+Y]QUx; p+75},(8J˪Px5$O 'hk4Co~w5rjwNcBpL*ʨ sT7ӫT7XUSK?+/|k;Q_K;"LdVUqi.Ӡ<WԸ,/ @
+t "'_q)@n|H(ж{RU*;BqNk}93.\ a
+<]_s)|^O=Ae#u*Qv[d]?Y7<:L
+Z,!R<c֝?C}WFB}\edx>[Qn3N8Ν[6˫>Ѣ]&/
+FCE^~7; #Q?X]$dnˀƂi ª3旉76xUb/bPsp>8}Z$95w b..jת}&d"Î^-=Z=*
+A "~uҒm9e:izDu!!CG5JyTr X͗3dԞP;!U??˫kBgf
+Zm Ƒ ew낿of_깵Ym;<#ȥ۸y j,dnw)~_dF0 5(ګm e]:,7cKݒֺ'5j"{gvlyvӕRq)}QzrmLhTPZT1.*f`bSK/U|zr>tgwgӜ -4KqlͷGS9~=QȜ2%ƶH+{rj"9}QmAH $!! ! =i+!u2vuU
+\r%.iE@Q$ߓŜd&}㸚[^xa!ӷ[N&2?Z:ӎɽrNЗ͸"YV`
+F=;%s\,2r  4H݆w9jMdZXN1f j䨫6R J6ز``MC %}zU
+0 nT#oz9}L^^
+JGU# )a.Xi_4p/eZϩ9}Yo z^SԻ{FEG1 o[{GU:\ށ5ﰭ\,yEyvr{zʸf.?Nq'Kb,!ۉ^CGI=.D;AaCz7gz,;\=Wb>Ki33J)aox+B/%k7<.=}ZyMԤ0lD
+<6 M+{qO:@s[yU ;j?Uq8/D5vor(yߛ]~| :4>< `</`Tej/\aGAWXkSl3
+PQ4G{qtAP飴Fì=̷Ԓ(j~RG;σ6x.hf:/1+Jt<˭hx~W6T|~5|ȇG OWСƒv]asyIy1 95h7 G&*?E j%9:۾o}7$5ƹYK gAP$kOz)~)+[۷;Hj!4&7X /w:ۉ8 x5,)Zuoխ$~XGL} ;
+}oӵ
+󍬓ۂZǠ  ;\'LU"KBa|WJcϧzR[Ҳbl:Vi
+{e6d(ꙫEˆxuIZwZJnJSJk+cW7*ICq'.%<mxK;jo9b||.z! )U]CߓqNp=]YvQ|t@ߞr8hm*g)',۬oVò4F&d(;8I;.> kW"Ƅ$^o@U~z[i+#; ^
+$o<I2[;9㿸}#~I>Niqv%p4hQ"\. W
+_CTzQFE~PPխi|Dnţ)Fsڴ!¶wK{i)])SIC6|K[+AꪜE^KzX[ct1 ܌&/`;;&j`}IkN ڕԬ_bg ,b`_R Ҿ,?n~#K
+!/kׅ lwٔoIJK類W$ ˭Cr#8i#n&ͥxMZK-!Ns޻yGUY&#g9qSAEaSO6O VK62j)JYK<0Y3fguYsnMԾ;K->[ǰk=4rѢů ō"ƅ{l-C9MjaM1m[_9楎* h21Ͼ$HjOqYfFOQÖ h( Lgˈ=rm璁h]_-{GX*GQog ACߡ~ö;ik(_)0JXˎ`xÈ<5!xEPnċV℔cd7z UgG#2z @VY^b#- lٵ6p~^)ˁ=g{9JMĴ#iX^=[;^3<߄m-II[ <?lYq<1N
+ClӸ p9ӲXo7?}qߋ}Ea!C~Yڧ?x;w߆󇵅"+B`_+bMS`'LeIS{
+-0h[ Ӆ1@Lڸ8&I6F
++HIJPUB>ӊgX7/,?y߽}Kt{P>:ޯ ^kOľ@7S U\]wE?Z퇷{y7"
+ļ_[roGNo=s[+z͏W^aJe>nM"ӵYTa{\y˯3aSq4w&k|) u?þ([Re ]%MXG5Cm [ <"_N34|ӧܦU)2U{`9+SMOU^ӊlH?/6d%UqI9q׼{b=jeA`g;+0<9Pupy(i7]^Dm#FIAMq!eiH/ˬ칢@D/ /<
+܃ª\:WNKu1*F| {x^~@F;r.Η5& 7πC2~6Xl
+ 8lw6ٺmMZsf\rHc5
+ܤ6Lf!L~FiMIwvNvu㩁V鷽)' ]Y,AmjTqQ^ac,2O%٭y̸,ܸS$^恜gyP;,ݖ2@gw$F+W 8V-yIe5`B4/(}e%mmmFcTE֥w-r=U[. 0YmNkURYeҐS$\qҔS%LJgb]pRIEV䭟@sJp[%zQڳz0 3l\Ey/R
+0MUxۼG* Ʋe* g:?hX/wf)ֽkŚ}i{hK_)#MsrJ&ٗ,rDc=MUD 23@
+9@j^cܞ<;&YkxΨwc` -$LUܴ0]t{ b~}h:ϡxWg@f(au?NJ+)s|ysNQ;-|>mT_xj$f%qN}%٬|-%{qvϟ!]Q0ӜC0Kށkg>7dXOK|,y9`3=!bWUnӲKo)7 ~W0j[dK'HQc09U.[
+LIҞPDMȷm^ܔ=^o »N|I IИtץ"jk%~F{zk%+<kL9Ux N$uU- c~bEm<i,U~ص] ]:0 ύi_Lo.Hy$}yD)u1]$k8OpQ<zMcR5)3o葐;))bո
+ʐmYf˿qmQUq+[ 2j:L׭ 9!"Yen99| v;?t:¬M. Bptm˂ \DY+;;;By>~V#s_jڔZƚ +%q O`MNnClJŃ94?D85k"ɹ`ؖlEW%ޙOӡ5;bd00;xNh9E( &wY>>.k,YAo"OK
+ݴЪ< ujDnj%Z5Ǧabk ߴx`ȡ~#0)^-1afgc˔^Y='nWBY`~W^.ȈJfL&EAOO>LՍ'ʞ"yWhU ~6j#+s/ޙ+)J  avjV`RqU0GT\*WKUݜe'ۤtO̫E?-`Qu9i~:YkZ=<SOxmGq6[آ{uk8_D;xwafR< “'{T@=yYdyI?%KҽeBn\PMf&k?Fϐ>ӯff,"w\8񦬙
+f"Ԥ^rK~%3m
+rv~;Ί;26,%+EaMiazEL] si~F@Oe)C0p V>
+/qeo'6:܆2
+毡}L_تڜ܍<)uHyyvQS;BqbcȬ`=x
+?jB(@5.Lʵp◧˘Xϑ^šL-!IU^df$Fjg_xz+YWp=$Ǜ;YoٿR/OBJ3^EQ8SzBʕɹ$<]cZ4%w!40
+^L뱭f<pI |&
+n AsS+{y|+*5ȿJį72FvJrN
+煸 L.*ی "F'm%^&td*+2x*L|/]-ſcѹ02*WWҀ6-_6$iI ϥKbdfҫMWK
+:X__o5n>bH
+s7#عI7J}daaDL2佖eu\2U3DMoQz-R?aWܑ}YTr_xu+"?-fpr
+qiB4a??Oe?oe
+2njM7}P귤&`KbCĿ(=t[;ݳ[+!㒼߾{;=vF
+iEtHD-홣!n7s$p9TZ'/n]UGnbhC}]m|*#=wN;_4?Uv&>:! KÎTYؾ|L?bAS۸@
+ m轸]m+c,XVf'HtÑ=o.&%o3IZʑG_>5 E3]-^q@o(lV;e69pYCh`A;;!k۬f=7vD\G?{~֯2`YaA1C>d.vF;lduMHax۶vl[5
+]5O2mp4\1ϕڵ!q0^p vX*7 $A: ѹAofF,3^iNӺcP6Br_̱{rifY;5c<8~CuQPJܮyE~=AkRAMyB 8<F*Dy^'eӴl)ܣ:%m `نgfnf0"h%1>wd}zVG.m
+yVҠNܸ )um__q7N#!z"iGI)Kt1 dif0fQX O'w }kq~Ox*2'4 su~aIkz$uU%gR̔̉uC=!8(j_AۡN湴ѐ,{g0|Ԥ}bx 7*n.󄤓TQB=#\愤U }";lrZ 3]%3f WF9yX WK OW]BdfӤɘ~E9XQ?8ӃfjLH\q\&tT>Z`~aqv2
+/Rbl%\OMi25=maK$$llC} A{kjJkTlBBVU}[P6 ;ϹUVy<IIkq\[$>fQlzF<>_jWw{0Tk>k߱5{kr=:6Qfk BA-vod}T1Lμ)rz|c
+m|GuL=F
+وUQԜ_1 4/H!KLRvf`AeV.j'Zub|'w?_|O2.[WUun.slf^F oŨ d-
+,z !N+W
+Yz1$q,yjv-c+ E/X~U5?OCW}^qua^9)8-qEEATqlUu8Ǖ,(#&3?g9-kf&j&yf4@<k!zi I;^G~>ś O'0>q%Nl9_PCnh,o^-[yT`VXU:h 9Ըz%0
+:le qy\ B-㊰eR7g–Qir_p% X_9Jـc_E1ܐ6̓$JdHDYQf;͹VG?,<R#SbPc!Cfo13cA>C}WX1tXy$/0>ݸ
+sqyex3xV{O~xO
+7[s8lHT.Rc0eX4lJ q--]݊96xun4 ֜i0"\%D.^j߬l q9IpM]xP,rPfY_cڑ a^^ŸaLxI=5/GȰ_@PS繑A­4 ~1+ga1)mr-V0W5SFߴQB̏Oίl8͡N9U?mԌ6̋;k!ÚQy.P;?f|a~S-b{Jd/7%f&oN׬grN|);F+v0ek+j1 ;u/x?nQyE4.0!hJ3U˼r~!F6sB+r 2%XO>^惙:/^fsօ|e
+B<U[g;G-2;r so#oi xRuPZ(L} Z.mO6Fl0h9-3jl>2"q_̃[^vy|Er4
+gh'#bD-cKo߱HŝcY/;o/5/Ɓ˴JZgzAfafH3A}Q>X`5Eߟ'&˸iz+j4N :&Ax7J~<Xe(zEk"eʥ¶iyS>ӊ9
+^p"Ly;}
+DasV,rÆwaKL@S;@\[?GDh t)=,I۲*mReca,doh$Du)aX&48s7?IkT?
+70SJwnyMʩtUܺ}Ѽ˼U<<CZ-~avkv%wEMjZo4 5Cje_[: n>>0W#feyz nz㢎d2Vrx|&
+\ڙ6낌y]̬Yd^j<bS{p^Ztf7 m@6?W9j^R3G?|Ϝ05tm*uez<-(g`B^z;s÷W>W@!7X>!w,剰CRh'&lGS>yoO [C roaKգ{a}(tU>˿f[gy̯hyp.'1c2;B )$+|eOFۼ8EK&:'a`2ɍdwwitcneW&lW~N8TmB.qb }R׭M)a-LzӪf_P^25ʢYɃKiY0Q}&Vh@Pw"x'8B#}q?;vxrTжC"p^;e?f>fa5F:w6EL;}>a{F:{OO֠h)~};H]Vj#3I^AیsxBB)dޅxcWxa=-
+-b<"2x N٪π“#㤶ͩ"nhIB?OsS|Ucn3dYӧKw5V]Ф[9oۢ^@Sc_mQ,ԿԜ{ߥI[7?DBh+sU0O
+yhf@5u+_f\FY!W3r>={#N4}֓fhP4}WW{h?C[?Ta,ͫ%<Jڔ){J!qoՒQ?ݖ[ 4)o}+Lצ]y]9J]HާI>/du"Ts/m[1Jx%+% S)4Tp>t/
+Z F2p?j]+04 +' d)dxovhŝyW>:k&2^h4y$HW lVtm1 Xt+_s8 Ofϒ(2RϬ|ąnf& Уܾ2}쫪7Gkґ3݊9f ry&  K]^H.e)f5wqhv*;$_fkH/|~jgD7~<xapʑڗzȩ~w.Э{-BVnүj o;敯ҞtxC1M^-tfET@nij"˫ǚa|43h2z.Y˼f?NRK=K߹'-<;ssbyAzGo,T\̚ҷ]ǰ{G9ιμ"A_Bm6 Qt^59A$uo^@NH;%B߷iGO̓yจa2j^9Ynݴ0Ug`WT|6S prݚa~n/ _O׭i¶HgsB_t4t*ۑ ߌ~KW~Hh^3i7WRG YTy{xQӥ
+ G]eIoCCk6e9sB0S)YS-{M[}5$o`} v!^P`.) v*/}/yio؋=d%Yns}{!Z^'}/V<a)y+c`;f-+ȋҧ~4{S>&=X-fe˼QrPg=n0-̖tpA`݀fOM=V^0IHr*f>!]ぅ{+eXA#(O'i_b/]t_rxF>bS^|hdK% ^]8/Ibeĭ%;poؐB”KиNURءda&y8]@<P<;վ}GyDERܩ:<ԙGLWnÚlA2y,lC[C,VwP1 i]s; 4KBhG b~w|vQ7)CmݺbqOU/
+c\z,5Nep-%J^/2mu
+CMZ9-UOqʆ"o{@fD3/tQw}ԏ^tN."DҘB ^_RGb:#ex&
+YLw/Xv/YAq=daIH~OV }YD+h 8į\凉]o8.V?KG& 'YAԛ)7h-[S[^㦴lޣAAǬ2ddnU⧺T٫Ə#{q{'q;Lɂ={32jM"GnT N̛kqXP pQ#`.! E"~[MΚn 'ŬȀ87*8,!2$dO^ŻnVWM˧8.jI,׭ns^Q|3 R^OW ><Q8rǝKϏD4" {[EL6.7t׺Wh׭]-QXܫinS[<Yfeۺ_;8Ԭ1woИv7xjXLrڪӑwk2/fC0dJ f~0dмb
+X 9&POO}/T~Wݶ3]TɅ@ATvxYB$lgoS
+*!wPXNԙov*]& KP@.rIo/d8 w~y|$aT}-OyvB
+3|u
+OuU%n,ӦP}y:5߸ ' S 'iqi۴WƨZU ^)u>m̮f >DKzIюV=K/~9LfkNhw>f q'=[]}M>rŇ[5`ad˽Cl%4]> ߻qDVм&^B'<_q@O|f$6;/ VD>-YQG'g2G=PGQ<~D
+̄vG
+ڬ/
+7*]M?sVQ̳tbķvq\`LI}Fy=(<uK%-y2m*J|}MJ-K
+(v'8â$KPԺZv=hW&@'eHmR<HSe!bivi?4m8[ t6iV{k;MPԋ`EϜa@Ym5Oǿ]^ɉݿxuHmx]PoZl\=@Ӈs`Y0!^orSͫ缍˧PCdvp۔(t̉9w5q} Nl{vê~!M#o?h<8bV]h.^ W:oL>֧䏭^}[K]^;^X+O~ LDx63(:qUEǺwzF
+' ANBklRuKʩ, VŘm&% א~R<{G>)ٷSwٰv =2ya6smx/y+|܏%`W8#Q~q2T[Q.
+:I9_$*!u^XqK;])GDvkZk"n;?v1)1Lѧ$w.'~!| =\6qvo%Nv]>QNCSK^L^tْŽn堲G&4G|`VGīt"v.QFeu^e]VC 3?,0r۫ჟڷynfgJAb!,n{>bޖʑ"T: H[riEb9cZK#! E(0F̊3 >Cyͫ2Xū]R8%vlQyU_Wv͑Vtr欧,慧v1 qLRZ1&#N؏I9AOӚEi&#}34[ʂ<5.A]^vR 7th0.xuꖅK#>fA͔:onJTc8
+ ŒF̳riaen,UuN̛EȩAb$qk[,kn*k}!GGr>uaS$Sg`@rE cN]Bžt)BBcI;]>xƝK8f3Ž\8#$=={<ՁW+urSuRp.5ڰu2dBe -}߃%qFxCq,Li|~Z4رy)T.!_'bu<`Y*Ob F"|ȼ]1lVu K2iTndߖEڟUG] ~\1j[co>;_z,3K5Od7ОQtg$V=|w_Jz8gzM%eI֭}!Y^B !^M!RȰߒk&x7|/`dވ6+ 4mC/B dXvpX2W}<h{!a=:z݈- E) +0RmKq!z
+'f 1qѾ =aP?㞖0iV#]#q г&6q !%i<fO8D jXztbGs`'թc0}
+ j`DqY1ozQ`> vl)Sa0e"- 9F瀫Pk r<=uLҜK=
+pz4x
+Ke~8]D_"C;0i5LsC h]xz&^F4gO6O5 5qX!6Oj2b싺iWE_̴S V߯\tb,߾g#q"j7T&Y7iNNoquEq5~`,O>X˧]ԯB {[W
+<&bHیg&m[,Lvk]BiLe<m|af?Z rV|Zڀmբ{-o]光g}t~BBt7=ZU˼۟͜ݭu< C LQP,2pt .΅pA)#Q :z}R!U9aB2X_)^Öo?
+8AEuA.u\s4C׈'Γ x e 5 sSiM{BnY5#&_5g-r=!]ӥ;Byyd$n+';rm5`7pH9Vύ=}
+yyc>jOs 4Js/e%5[W'oC
+X
+l6-qO{CQ_xљ/.2<v}'j{\tGX3iyĵ_q ۘa|yy s͋WC;!ZEQ7Ju,T;r5d^!G-y5B K~>_
+CƇoК.j߯7_ÀcOmyUk/^V/p
+һ<̘qE0$i1f!6}`ht[$
+uEM)OŤfQ-eܪώ“ܠ~[W%3_C.<Ҥl727*_5O/[O^HY̼rvW`qOU Md>&iF7u/Ab€%V3RO^6sΗ L5l*P!rܾ^|-mw/r_WP*}_ϖmJx|zgf2C&QGH9 Y&dO_59oв^reН~:Kd o9X%z bD>'[ {m 1㼬Q4jֽ];'A[qKU#<p9S:/1.Eq^}RvD~:ϰm
+X9EFkxZ@vW\{g]m >x .izl]Ui{nFEƧBc8T|JxYqRtC?)_H{ o~ZX>h2'r`~ZMn<(7`'柿!ixj8:)k6N;y
+{0r''8/a~Qpr+
+5L^o^0rӀ;&qˊ"a/ĝC>E>>S<Kkk྄xgkؒlqƦ CL)Iq# gykːnN5p Po -1,J*PGDs8d{U<01x\y6;ārD1-՜z'ӯ?e۶WMQ Ш114FE8ӋuӱQ㎂쫎Vt2LhEI\Qs{4Mu07|
+s:BlO4%я~}
+4i8E&<i\<]q`.f5&P- -ܑ/}-E>UnGc-_r1^U8>'"Ao1Ka{[$g",r;ud̬Np-1^ɘjK"yk]/_Zt%cj_/ƵW]"Hvi%=T=ܣ]
+JbSYgh6Q71Ude~}*@5G}lC󤣳5? R\
+pp])0O.(q{اrZgY ۩㙬eB xoLԁj1vժ\+;(E~u %CV1Ek:usH>YYηɖxVKAiٸP6[C|k~^]@V9m<:=u0GJߞo}=P-;WoLeHdW&84e8Ϯ~{٦|!խ A-|F̰ا"]/j7Dm9UPJ`ӓC]e|=Y48Mi,Cs&zʛ~K4s<3l`Ep<y 3]7J7ϳpzC^u3 /i&ϝxson'|MiCz8 )GZsFw/܍'9Şkニzei2]L1e
+endstream endobj 53 0 obj <</Length 44740/Filter[/FlateDecode]>>stream
+H4V[WY~$M¥@Jb$Ǝr**.b~2=MRP7& 2k$=1~(@՜cyثsoo"xOO5/I9!e, ck" !.&m9Cu)%LM1;EqKS꘩.b1^򲴍GR&N5edQ^Kc/bjr.?Avsc宸S.NQp΢72ę:`>eI'3yt*z=?~y۟sfNqHZ=<rN?
+J2r}?4;e;zӹ^z!J bHr P>(<x vnı*|!g#9{Y@ 0o̶/KKZm0'MXef&n<^F,E<Z18e NsīJ 77 ϴa }W)~1=y5E4VBB}t_0{jTF5qZMn)Žew>:Kzq`jK¨$b
+rj?+$)N'xU?Ghɠ"5wVXGS qq/i##iRк45dLx;U=OM+נaݰ7og;;,qN4yΨigMu=Ƌ
+eKC5K -"mHU$>*DgNuy }s}}SSyiߚNd>G '
+\/)ww_b Mx`~:C
++w(y# s՘tπ^"m9!aܣvĬJ7+ t8lsD^~Uڨjx fc|-B#_B|~5A?Gp?0&Y.\h%x2m:=o5ඐsz۷z(ܷ-hW}cz&|Mx ֻی eU1_*&z~PVSJ0*MJ))~ fnJ
+HO 2OJM"2 _2Iűlмfk 3y.H+n'н;ihKزT^A?#/?`RW{XRݰMpLZ G@^ǂ .PfC,rz}2T{+`#˂GN+FwoPA= ohUcUT7"qY ={RE2OK-!b9e[Vh~/M>(kYYghmS-?7z7([Q{IA~$'h\c6T_騇=sOjV!Ћ_/~}Hx>)?\MIݽF?_
+]
+yE:hxK9dhg
+dD?ozsw0Eqg0W/2 ΣO y}2w/7 ˠ?Aџ38ȨAۖůKQ/ۆv
+.X]:n;1x|y'X#"kbuY)p]/VP'%K\"&2TAC|Q0k]qx&BT$_/sUP+9˶nS1I`˦*'O Q꾓}Ŏ<v(gR0vv}'iK<W%`ČG+NdFoK
+AԸ$uOu`p\ucMB#$ iHv\ݣ=g&)xرv D/a(BGGg$=pq?7W7→t zE. Ǐ,1 L>ndu9ؑDfUV)z㷩V6\r"4t%n-bʫ3
+ޅVJ9X='dM$%nlHcv(.:]Y4#W۟W%̟Z8Cgn[CR>d#vo:un;^dWVQoZ{AY($@r|މx|oA4sQl98'K8i9ߒ'̎<m +ОSx(=ާ6d|iqG ^j==wG+uJ [{Srq\ңq;`Ӡu ~{?:p
+a{Q'E%ؤ4%uqW?{;󷬉{>kJ)GYȆV٘c
+,zU'?+Qf"hE2}#aClVĝfՀ1CChYu*c)jSt_w- 2dqq2Δrpmβ ^1X
+BU< \̝\ȟbӎ|-8<lmcas0NE}IkN*r}M}2HY0ׂ1M4 r0_?VcGXl}g^vJ걾Vu[7ߗ]{$fWq1qY ˘4\ _=rפ/lO8kécN ϻ>/>,ǁ}3^Æ&:h$x
+O;!뀹7ܪӖ]ܚY&N&hSFEU4V"3Ϩܸ"术ICP;U J-{4⎥2Csc֤Kz͏nCMwOk"SZoZmc2
+Ϊ"zײW.>tD&mj7P³3 ۻВaҴ
+-XgV!y a2 |*EϠAe+SL^VBɏgS13yyS^ʒkuJ0O+}}9|k+%󤍯;)[w*x%: 0o!"jYפ
+px>xjt7m?)Cw ʀ!+w
+r.
+>CJ2$#+ e}ȻVҫ]k^Tc(p)y
+ ݃v^ ?8eJպ}v6ߣJro#떱<`,fĂwlC]j.]G WnSxS0$sq4* ˗ Ws乀"Zwlm)㛖ch]#M? 9KgcWZCOIM0>Cu3
+o</
+ g#F~X׸uB,zkHrWqY`"~j/!м?zn38+;! \-lh61yr|l ||64݃siNrZH4mdX&g0x&j{u;/\uSꏮ^K~@^ Qgq
+q>&+zc2 **xقMuZ!}?C!-cz JCV ^#?@!z
+T-yӘ&q~_uO-"aUCMfj^[r;UolfĦI^o^lDgS
+{5?M56iN6@LP)–9PP_Wn|bkTq|I
+>1՛b~oN#VCB4ڥOsOU?08%ֵ*y6z ۸#*.U'QFym)m^^>亙wa,bw~' IE.'ԛc-;ԯ^mTh^+۲׈z׿e|!v7wt9щ\ǧDRtaw;k.WbB9DdFA
+9Nv;,rwvݶZZUAAA ɧsz !b38ZWoW|}
+;w!%NyU"dz^<(xQ+ <n[B3ya9H&)NQع:#T915ZV2C<C?Evݼ@߾at:|Ȗ`BI'I8vوᚇx/ŸG\{)x>x*B?5ޅ9bM-I;p$G_waSZ>"w'G-j$EcEWS=t9WlGW$ >ælޏjV!cAMyUo/y.<kи>3+G8 /y 8 qWR%b 3Dc$Xvoؒc-ɋ*F)x1ICԞgbO?/EP@"mqk7fm`0)O
+FN7ǨY+; mbm %OF9^ x.k;`ɑZ 
+nSeO 灦ya GDN˽HrPV+fcU7j5td)}OP䶼(Ho|)w;*l/^yIG,i1/+͏9)d??SwB}o'A/~Sׇ QQ׼u))j<jz%ɧP3&7l.lL}m{Y'FFr#֑=c<+ `q<`X!֡1*9ED:!_{xT)!?bQ-Pc4JDˤ<3< kvO%ճbboٸl\sQo:0ݖsE_@)EMoE,^
+KԺ k&h|:!'O<\״]ekqʀ`Z>4XKtkL2߰=WSue̜@!M]>=ٹ]k/FT7k#cjicMcgFmYd\'LȞLtdNgE}ю)0gUSV~<h/ԛ>Sd=I}:_oH+GA|{&3z:>2I+͇_Paxyۙ<`5u";DmC<!w/uxU[歂#`%0 zPO"`.:IEO
+L4E`EK- S  >[FJ\( S`۪i)/@`'AsJ1~*@T+>g4"dLts[*sY:RG̞88>Ӈ>4$\:1p
+\y$#R]s𠴷,Qצ\0ܩ]֘Ti^a߼`l&dU}
+,î30=>P|
+Ǎmwj (L6Z##fuYSTf/͜Y_r*K1Q+?j/B1z{LMd xЅ0v*;Vp;LŜG6Fdm3 A|\zK6sǸ1224.7EyP
+tj{8*Kӓ
+Id&z%7S_v̱/vZ.s#7FO[9wtdó{<kl{BRefnULz'NfeC#b(9 ӕɆPMwȃ1#}njzq|[//4LZ㱎f-X^/YȍnuY:0Æ/a]VqID`n;:^Žetp+wO)Gg'Jɠгfv\^1r^5߀ã+dѾi.^<yg{.zVy ygs[n7-ё4
+[ cYBcV%IWk.ݲ~5_%eR`u;)ՋAԑ/|/c #a-m.T IIr_8ϨOU=䍏&ԾGq) \-w:I\C^+{,=#o 47];wKcj4t'71-dl  ;΀)QkdV*5A1=u!gQm?RYsI)MQVssFpұrSfB=D6ǔ!}~+vdE{g ]FSܳ6GRznJؿs IhB]#sЕsA{&uy/PbUkwp׬+G7Y^0Q7%|.KCʵe~1;}}Ӟ%4^gOq{YONs>K}J=kqz/W4VG&%KSxP鈢_d128ڗ~O%qZ-YȗxxC5dE<N0ҫ[zn\j:>-x^K]gmrw2-634vU<z06\IeϬ|`3nY^;mshi-wFKȏh 5˷$f֛:g0/p~!7bVGEO&~wsc(
+aw=P"Ge̪.f,i@/Iz>Sh}+-꾔i,ޱt|e^SzfsGO>)xٞe7ݪ2-g䦘d nrߙ_YCuJ)*PiC6p^$KFwp|vq0˸ #E w+|,0W=0
+Vzڹ\p*F*;Ѽ@}⼨uJmk7ZЉ؉beR=' MՓ[sהUw.cǞ Քs]z4D޽.r\{aZw2U:)W'*P{^̃?dEdH^SMߺ[Qjsy#H:V }{6͜Q kB{)C=};X_ޮ$ekP~ܣZ
+
+ <`k<}"39>;(y MSɝ9oiߌg2;Tl?cڷ"ru% M}4SƧMdiS, q / _fUnt:\nFw Idw.:n NL
+wzolm {νcߐt[72OMW2ޚp>dO8+\Vhڏ{jɳ瘽fI2KMKщ|֚|O]񲖽W y^žb>hNpڂA#_,nJƒ7˦ͲyOKfWVLUOBTϝrUj=
+,F> 5_;F]Ofwz&>&RIt}Kj1Wu s]
+]+Jʳ9
+r#u:d->XXymeK+3x1(&<Ʋ&I҆S4ng$-)5nT›! #JS#զQE9Vճ
+^JyJ4`ǧi2G)ErQMn}|m }PX켱Y-_+j{292K0Erg&bP <nfv2. (3"okn<3`YfIN[r^r6(vD4'zq|RWRAygN۪nS\jF{KDvH)kܕFg>)JΊeW5Q? k⸕3\!̰ܪԿ?JrϪJ-X,YvIUݷ5Z)oxk}<7_"2SAr6,}mW[O*}
+FAgqw:ָYt(:[~*ǮJcNtiR`B
+&uMx )H|7dDpDmxxiaCr$(l~[DAd42kjm{I db b'
+\Λ wP+bVW\i9;nE&6f}Z7۽W,KMmF v- <0T8׊OR? F{<~5*ڭR#Vk>a]24{83y0R'>Իy'=gvE o_WƇzs0 #T좶-L9I޽Hr/a;;IlJb~8cytyFO?3KWa{xM MbW=9roɶ}vP}P5tL>-K]^r8ooB}8}V^cuU֦M\%:)OC{F:L/zgFV켗V[cޣen&>Yih{kώo<üצw[Oܖ>oH [
+hGM&1w|a8El9εJQKlp f514K\ä4Kq_nx8W/}%m\(=]WŌv[1+ƔǙznKc/:.d۷ w Q;|s.>iyvf כ|F 8SF36={h_ ggm\ˡq3{j(؎Кa0U=z;Ϝx?u$? q=л+y>\h{C[cCj
+}oM }SGS<>96023<tCR/olwsnQO)W0= ۚd~WLȷ|w/$.}M4/!͡ץԂ{=h
+gMWs
+~>]<2˷ݻWs~q/sC3:NX߰ K|b>^P9׽ͪvjĺ$:ouEJ2gSd9۷A"|j'ԧ5x'^_{y޶Ĥx4b泏}9+5vr>hʹ܉\f߲ Z: :r%s cbGrtn~W ]=fX*xИoHC`
+f}u`1ʮY_>}\=#[YxKG|7;u׭~o -.mOi:alYH,qͪY$z=d~VlFsv|`qt0~rx16^mKÍ
+=qz832xz66sWNTMf+##2Pv0#d"sz|ʝ<ꩾ;=}A5Reͥa PSZ3Ie.\QuB ;Fc4D{vV;R<rkT[z3\m\Ǚz֧}{9U5Gz3zNӌEiG1՝1;ȱfS|N|>"׎+v4oҧK};R|3k@Rk[&z^0(i򥼦
+6/eqs&v`ߣY;ٽ8Ocv/4Glp1~ R׳3| > ; ^8YWб7>=07Ccr~ ~Ykqmiʌ?XpC:L._#W\W\mA׌{G.Åxֺ7өܡbc5puh}CHy:}>f]B^]{L1{y4S[Tuv  ihm0yBݕ)YeNRm<f ! ;z&]rc[m9axHy_͜ 7 žoe^8* X'-קȄ٩[-PW9.{G|`ɸ+8lflfr_*.e'O"6EqC}]rur]PnfYMeٲ)^ýoKd+uU|کfmš\r]+voܖ{n|/>'#+COݩWS&mk%ȵF-4D\􋅞;_hܵ:,<؊?3[r|%t)*tIS\* g[k9+ʹhbךe[tGOKKiwuh/" rĽ:®W%Txg.9/0GXlUpf{FE$Bk"UWM-B?p-4r{9<ŝodkAx5
+k^lB
+ZNXd-=yuF5hAOWrͣ5qzLGnrMfNS/pz`ayF!<T""3b^=s޿T=td1Srʖ9wJ`zU8
+t2uİg}1bFm¿b=qLnY;yKV<NI83kyCV9 w,Wdj'5)iZslzz-ѐ6<GM%Mz@;ajQDM%lKk |c#jD}3y:w]‘- ֐5v9"#׳ɀ%2JZn {Cj<϶ؤGKcRs~e05V ;ɗk`Y҆%`-Ĉ[˳\O?]=k\`i#'FE0Moen^ sX1c/Ŝ\Iv^[Smaޞъ9^}A.#_![ȰWǽ&E <q tjrV5җӨq)t-ݔᇊuu5 c4I*&sc`*5#Gm|&%򡝜D_ms`ƈ1Z0eUa0f]ngpU|i3ag%>Kz}^r[̞m
++][cȑʍȲVGyw;HɑBgu
+_<+%ƐSle۞@XOg>ENy;Ó}qĸ[i.7ߵ}gݭ
+|RA}LВՄ\/Y_L-5*m vIԻsO}#-H?LK #VX wXd,^u#.{gc`+oqBFo伳C^fn*
+zα><zN_}[or }<~LڤQXw ࢈Ĩ I. KtĘhd_`y_4[g:i_Ni;5&ZQAp=
+`RκXO]wG+EM#[Om`N~Qӣh
+>*U3ZR6Qx}؅8hGqlxg;WW|C-C^IvmfX/jebIc
+:߹UәGVZKفs>a9ş<od9Iq.!x+uI pI\ [I<9N⍨ޕ~:oZnw*P#2ޒyـjW{Iw`ɀoIf׽[xIj"ڨB;': ;}||}|Ώv- nB79c I-ZME.;2?zF,=Vz➂-^Qף}K6x|y>.NnɭY,\O)ӵ\k̇6Y>>]<B{_20 fހf;jK a镴2}H -N3L(7z%ZNoOlfoR7$ٻ >gΕO0 cELq Oc"3Pxs4t.b='Iߓz{V~/Mn}&ƫ~JN*5\s+=FUn|Om39!
+(sl}tksS }{nL |
+J4K-KFmrT9gz?A <B'ofMzcNZBuPS6'G/w=ftҕS޷I~ߧOPx9lұrZvrwGƻntJ<jc`VlLxh&TO<KorsxZ4 &'X%4eÅrwafx{Z:$0&m:I+F E#^-u8o7b9ifZco$Lh#둖>Ώ᧟t*X8d8)NKO;K?rj/ [=Y=I]#~gt3!Ǩ)5_+Xa9Y=`(%
+R붌H7j SBLuqniRT?w7!dvZI _j<uxmGx$jsSWO$&pNݣ1[#ϩ f5Z>{rê?I@oRbb*8 cK+htaIlp7{7=uSGTJ={d/Mp¨,yZ|%[a0sh]mzCk?ZxoSb{z2Prr z&qB7KM߂z4tL~fz%ӕ4W 'fityL[PG\}܈`Y;|5cI<lV7ɼia8dq J}d~>ocx\;.vߟfKofJTF2sm"4\_o_ۃ>MfsliݗZWv]yۗVmXߍy.(;I&NB@KaIO$ža<%M̟^$.m6&(gv9ѶmzLglNӴI1+{bx}}>&gDUg[qfck;S)OŞ ϴi>OZ8?=yuF :?'XzbFsș6c]9K'^4twۢXHAs ޜ11]MqF_ S|KK[b7~hύOc.43yn+ѽh_f8.vFy?<ʼϳ6sΜ.,6ke]WJ'}acs!.&7{ogFzޣ5ie޸'ߘ:c<y7pXh̊]X3ri^%@fXµNΎWsb&xϿffO֤ϵ\'k \<TO F2\'d85mᛀgppM\ot~FMIX`+77_4sv_,+[UkwDe١4{W~n7'i.2+.nMo꧸`"E L{xyzõmd1Z'K<?R0w|Eљ=ž^ :m{ӡZ 3RWtoҥ}}=es*d|kX).e#sfr؁|]»bKzfNӋRK&XpefvġBk_i2LxV3s~2
+-ivm'Z"G|p%%gOL'B5W,Pt[ _WoX>Xy-W.(n170/+VkuЩ׏Zݿ}M3Bؓ^@k'E3ܘ:=ٓ-o`If9Goaxa5w9k3$
+\r[},Ι̉νxbVb?922+#auqux@ -?_ə?{m#n]*튲)X>ߩBYfF^`ϊ#9zJ,7OlvU.$!{3z#v
+Ĉp<] ~Wk_WNY~xξreoEy=Zҹ]ѬD6ӯE=sӔf7љEJ N.#:b75 Ńv=be[ {P5*4B~Yu۴?wO"Uճ^΄oVGWXK3~5,4(]Q'-ok ]͌%;wloԝSM sϻmh+}72#bxSv{JݍMX3*%#):̣
+~".x?ݜ kK %«my.?s_,^NcxfxL
+s;>%}הc&<,km!0X^М;JiuRm9}-؇p3rサ (cKAeQC@'З_~zUǢ#e?Lg|`:f.|ӎ
+?,3H7 U:GnuƂ_:c_eQ ]1ꎷqݻ/gq_BnᣜA1hh.6;kJKdKs4@Asr
+KB 63$!$YavWT-Ylƀ9Tn&m"m6)E׵M`cUwE[g7cR<ȜE0C/׬Z `Au=Vo蓸9#>m91} ߗ*Ao?+^p wkUJ>#tFJgrioIHY/ؚ) 6'{fr,meƁ;lZ'Ua؈<\kTKZg&3v sJ%+ZY5e\ ; 瘑5b9יd)
+{-C`)
+ơLN?Nh/zЛއ/Yn"֜yڜ*8k\g5В.q_ew|+.fAIvےXzEkpþ$,u>6`= f7?} kYiy8LB~7yA K8Rh֓~͓xNߙGϜkx%/~%]cgvk"ɳ2 ܟxzKgZf9f\֥g;xum8}Snօ90,ZG7wIgD8'7ށZi )bOz73#>LF&ҝ9A<kVz3ջSmbtoT^Ofͅ=&n2sN+EiY<NTyU`f<{v7'c3,>k~f2 ^E+>^\4pَxotg$S-dg3xU G0 vcV'a}Xm]15̡s9Qk\|t^]^ǫ}9e5,v uC,XRi ޡ^9?y^S'W i7jQygN~?6Aߛ?ӎ'7+Z&8}Rw&Sfh <#bgav#c7D.4sD:ws{tvZEky
+O^f~PgcᑱƝ<zc:[b@ /!FI;}<^ u%*m/]/z9bbMVu~HLa6yx8cUi%fx5^tqI~/gL&gra&E"T 6-ң"XOwz~^%u'5ikm9ٖ.C]6}:3z\DuGڟf5R?yyacLw"-IXk$Э|h=zwЗ(w'ռo$vêx! ̈́)lN2ẌFbqbҒEbh>՜>rJ7'TGSbW-=ේ Le<Ơ`EN%37#d"YNzfj=q!V Emc9ozo%`CϼXxE\S8h/F IoW.'ʼjOzL<:Ҵ{-7~~ot/=Yh.&h.\Moȇ{jNG2~֦CB0ث3]G};%
+y7Fn$kaHOJ꫓0ĘGlZ36]
+zl{]oI3{gbcb7 J^@فT=B.ỹkf>gxVu_Us""= ؗ|rf{iKHS'`텬U}*ԼUϼ_?L&gCUt_zF7~yx{ٔN~Gk DZta13IgnsO$>|ߴ〽4mqFkytz;0ʹإ{.<êv ??2޶ 65zD(a/ n0JߨнoG]='|r.7&Ņhߓ*g1]:-<XY&i 0=̊xE\>˙đWxvP]x̞0~L5Q@idSG 3 4b\2{RS:uTWhhvtTj*I\$eQNߡ[}KwNO,U]Cw{ѫymh{^6
+X98+-YB
+ԘZYuk`V@.j6iYf;C<q<(`W4<{+~S|'Ow*[c^u=49f o*9lX7˰8?tZ/6;Q N矶<y_CY6ؓxw*#ݛ~zgM]Vk%R2HwAMw .;zX)2<A\x>cf>ޮ-#aX!9`ւ/DULgXڠ诰/ _7+ٓMiŽ -z ,
+c}[u0˜4^kć\|S4m0_xT#GR34pܪ4*椇eL%ק5hk=fmU @NgiokGVS;qXj(ߜ6M.d1A|?CVa_ Gz5A(oBk=ōև`4c.zqE^?op!YR(cȣey:;MJO`{ZAucfe*|$zٔ ܽ{5k+Gޝ*<
+ lrH)9Th>𾪄oEhK;d5&;.';gԗE'|p3l/>=$oP[7h6caw\ٞtm̿}߷>Ksh~c )=ӛ)o%vsDG ǧ`8wHV6/!.S;-{qW18^ ³a:-ԑ)N ^>m֙}\9ҙ+{ &J,d>SO> 31ύ6KBXgj,Yh<]3”'S|g0_*VӒfV[>nZwtrӵ"ɜl5C,xf-^SzLce4PK~ id~C/!ؿy4+KSg19>*_N3N%ߩ3z f'u[s>0#<=&<b̟qz{0T}ႱR=dxEٶEjz9OQ0 ڹEldwAL1}ķ唿7qoHfXTl̓wseb^KW͙u|6u}sh#]ݞ' My_?7_ `W<`jmo&泅"o;9sϵYz>|s[YWꚹ
+ZaiT{Z"i6eH~sfj^;vz8)",n4ɱk֥up.C?n/qe|6®%SkEG Rex"~ӟhhs@P53e7 ㉻`;jaVqt8./T/whSMϡf!}59NC7s12'yԔZ1?(ǂp\vh>@Fޙ}t@ߌ '<&@<K}
+3Yl䆤mQ>W'Ӈ/4~B_̅WoUe!Kl?Mɔm\l?TGq|&/?c2x} Wun&\9M9Gј%-fӷGed<jHpԲL}z毧/=lvܩr1MWg=ށfz+ubBǬrLw+k#/?{0PBNl_ĬMBWyƜj³=i4z5UK-֟Mh1:<摽ܽa]P]s-3wA<
+ fq϶}ʛѺ]Vt[3:s̠ui.ϴϬfzʹ}>jG-qx>FUVqS*`tW n7В*Co|ӱη6ת!|ɢY}'й[L61C`W\FO'-?se U9k8IqT}yy}Vg!{bz*\NćևSOA-Qzg(Ënjh]⠳5&ֻ֬kҳηEl@G//MV-6Y?n|Vг/7@x&_E{.-!YCT׭%f)2ƄVj'u\X׌43FV̙eX<zmUmqT1 )C8ś[vpHmРPwb>* աm%@d5,\1DUD 3l#k_5txY̅Âz69^pI<79Oggt,e彎.9cڷ_[W6>FۼpWp:6ĒI/.~ވIɭB޷!z2q<4`=7`hW<>r,\K|,KY0qUexRdAdO0|>Gy疇LWĴp ͐g<T~O{"׭sqWM?~U.Hm#Wk~UtLAOا].kdv1V<w%]ΧC]Knq¯x`Obcv=^i;~)kgϪtV{j}<.=?c 6MG
+ԨZα ux4:*p/dVVd pv#Sg aLULR(/aѶE;UO{x 6./2ˌ ^3rh:Oڂ sސȒ0"γj^?Nwpvvԋೞ{.e uG$XV'n><O 4wW?x{uнl343޽xo\iIJv/hҳTƌձLNX[y!gw%v«mO`fkjR3|#dVgU& ww#$sP9炰RѠE*n^tiVzi-*YN*޲UEGDDHѶiʇg 7Yh,^M6\d r-L#宨zAП07to>r6ĿitN츷gy~QFok?qN K% yRVu?VgPѴYfx՝Ob@ua$l7%7D+zd9{kd}cg"!%W\º^3dH}\%?ܞ:i7UZSGϩjx< b0=wsh'THjg9=s:i}U$9YjXGo3{:r/-Q峪wѮ>ȸ^1h\5
+Xw1.߰0ѐOM^5*[w3鯶`:@EڤF%*z<͓Uс&ʈ7ۥvJњߟnא#S33ODJ<ᏯU=QրSxa ;]#iZXnA$0Ŭ%z ioH9dh[0]Tuqw C#T }ѯh^[֤uIy > JȊx
+
+;Ē5}>%>,=PrݴqqrL"gGM˕|Gh~yO v&2 @FeL%Qc/llS܋UHm ] 6l\/{,: x;61x y9amFd?.ik}Ӟ&|Y)waYr65#O+d*1;>qhx, ޙs? 1<yu5G2~xc5q²sjIս_]{#en ӣ 噞y3Q@E+?ek}_hy6ض{4:ߣeF `V8o~eSϬs>tO/~wݶbUO9m9ö g#7Fs4ci#̻Kr#9|fŀʼaAጒ ;2.5
+ɽ;"=6ڪEǨ9uy0 ~;J|ֵXCwRjLpU.ޅ&k_֣WΕA'SlPOCX7)kN\J;o CNxdDɖO:jQ 3^rm>ꍗ5.W3iiڐYHr6 0ǩݰ6I}Yr4n13<gԴ8pHFp}$E(kJsJ/a^j NB~-54OnLpSym~ֈ ]8s&fR/W4 [yͪ^t
+̒i'D\JnW}Gg4>Chau#oW99׭ YgYʆ Ȃ*s{MR{3s`ݲmpԮ(~Iǃ }+{}×߹0qn݋Է\su*Ecj5.pC-p<E{XdF.]¢]9cQM[IrziS8Q$MŧMG >'\$V~GsiSlj}\ǼE8stj'ONÙF7kh3̋W9kD~-wȹ>î/UlZˠ氠3^<d9c[_\ӻc-lxܮ
+0zj}yOoB=9pzoծ+u' \eN -r.NK/&M4\88"봾4LJ}e/Dƕ~K> )ӝLh/UYΜ>nMݠhg3<u\P<РfH%ϖ`?|j<{*$NJ-wك+`PqeHfE5ըdܨ[=8wa;iRt9I\͞]*
+sQ{"kriL%k{Dķ 䚁j̈́?nya$QCzjFJ}eR 9aQsoVg\M{
+ gj.+!oOG<7LLD~Ѣ<DozؠXK]<if{ԍ*@:t_*a?O'.>b|5~E~_݉/"koO.x0:9N͗}4os0}n{[:̼pPE4 nkS򩸸mZ1miKy =s'n )
+,wqZiMWq]q"`4ޞ$ѹ݂kצz:|9K^h⭎3ozS4+9T5esb3gBoJŎd٭dunj͓ I/^됽OM4c?s?VS:/C٘tfϩ<I >Tu螼V C KFU?n.@;8A?`Me=Z_rي3x;<  #
+j"O7(^@wɠ
+endstream endobj 54 0 obj <</Length 39382/Filter[/FlateDecode]>>stream
+H4WYOF%/xzchƀ fbC{7d yShd%q۬;Mf)? efx7s
+Cs9IO+Ғqdt; 倜O:PI2^@)O2ʵ "Άu=㐎KL5-8XJO-]aASq߾ cn|4EߚC̑WDџ6W={Eiٽo5{75 __xv4i*7er\P>żx7t4Пmߜ]vkXs?1_h>1ߝUG%]Y-XEsec#AD_t޹͉{3OcO+=asoTPKgͶ^H?r{ M`H\k!붆]'x]b_S$M͆u3-SES@+Zs;蝨>ވHtK'-D@Uq*d8zeB2] yKDBY9jyy\#\,Ȇdpmq&M6=l' vH8Dyo,W-Q  -=8U ,h kk|6\{_1{wjȣ2/#B1<k<҈gq~wdʿ ngr V?KeI.SzѶ(%1r^o*
+Ubl
+&\V MugL嵻ٱ]#$"6M`bfMx&:nU^󜵩aM&L|ђ52N,"Wf
+̆#W Φ^6{#]q}ǞfynLحt_iyٹ]3O_{iW&ߟWT9C%y;AZ]G<Ě?j WWn&눷 J^G Qľ|NN ik9 C.lϗb>#Wn:`<#f|ȶ[AZTYKW W C'^DjVEl;Peo+3-1t=1!ָ=[v!fyC/̋f}\,$23Zq7LZ42쌺g:I)7,A~FzWȗX7sk[|GM3NփZa^+3 ++a\V5ߢֶߢW_Q
+g^1y$
+\}<7EҮ><7ƻ0z&{G86fhPRGhߍ_lE;W!GK=
+{ՑcԄQm.4{+̝ꚗx#3\NfmSZWZohfPKwg'Յ~{.o"Ujێ2SwaWyCuMN+WnfQ3o[CBB5cEM OA$]ȋNpY#/5s^ v'jRocӽyA:cڝ{09'3$?r`|{qZDcC~.>e4N%|w;@%#>6 >~YA`7f 59i
+>u뽉g'M&v3=~t"<g~J9Qzd.骶%}f!F|CڮMV?3fS=2,w{I[ްuE~y QN~IV
+£m?2lZ};7/0Zk\Ft#6Zv /aB(2*|}\ ,`swufzߙ׍p}j7{;򟰻K8Qwf_!iԹ¨!mv#͑pn=ְ?IvzUmxM lCSNNk4r+o:^f/uƽ+f`Sxmh|,yOADU9uecK.jżӿS7?q?zbl6|͢Ϡ'Xp/ _-ߎȼң1st]󌯑moϱbo=Okmw̉Hp.gVsǤOr$cu .]G'&N
+<)u!O_2lKMKƤy/W#b 9߬Z΁YFg3W)ܐ29S^y*WfkcO HIitR>d%S;2ϣ^ӚvfQLƳ`4pD{n|32
+Sύz;\K⚟pg':ue.&U4 йxNh4beJ9'~Emɭ3_[ 9ph:n_%/:GfOb63;|b7ĺG}eXم Y:S44gx"EKJ(ٓ EVlW໼̹zTɩK)gʳx*\fTL1gȺc]w.w}l,2W닀i,wG/;Me1έ.ri4M*4!)19MB6 $v&Un
+FKH􌬻ZyZ0>p1|,8[xjGWy}gf]+ҿU~q4qOr̡M+SvN471|-?Zs܃v$}Zd#ނ 'M3rO'6KW9.Vo;ٿ%g4j]yS;X_k::/LYƊe&lѲ@a>匐i^_;kMUJy=];R'|*SzMiX[K\Ϣ>&5cvzj瘳\Z&gJĞfweBLpA~Ƈ?J>Q}?Oyc,8{|r-=a6Mdb\ɼL}\H|\&75&G4t˼2 esp #zPaR5xm?tyQϳԿ_3;8ox dhXңea>KF/bgLN+. <8v<kW)exЩO)BN֋sr \.1\ nkr/eBw&.;(3ݦ^k`^fEݹ%V1f#wxQy9
+|[<1-y&4N㡇^ےW_/bS4C[>q%/R: 3l9sɪu Dv- M8h=ߋJrZ(fMw=kr/~]_"S؂xN Ԋ:ނgXxL2'm};<tw W=/FJ}Pqh2WOD]=݄Vfkjd9L߿hWL3> -wa<~~ǬΗ,fEɞu>
+P
+Fw@p!z*C~64i0E^Ն{S%>cFijb]<y~"w|$QT1\6ϣl fez("N6:_ןvk溲. Ʈ['S D痘WX oR-ϲwaGU^>:0e/0~K_Jl5̎@/⧩]o"%gv.u=uXHtso!kk=KޜoV'p~jo/дv;L5zspպR#xB}cu{A,i?_,h֎ؗԐ'd5ӫtQ7b͊2S$Q+~_4YǷFz]i:Vv
+LW7}e/|Y;{1{n/}7)]wE7yx?> GzͰOǯt/zpfeY5ާ~LaO$2
+rv ;8es>Mzg%A/X]ۼܢod};`_rG?>^#sSKp<7Ďb*f{~.Fwap:-x&0:~\l:&x9,wFGy4}>FUୂ.ϩ|d]<o4YI9I25z|FXkĄUQ5ukzzDVQ:ҵQC{ :L>AdLl{?\p|kS]T!c< F)Ziib}Mb]-MДhɛ3ڗpGm0%ڶ -1+kr`cf[}Fˣ{}ZfmEyKNgl&{bYR=m_ 翸i_a.U[N`N߉_?)|SMmI<;)X]F7քw?L H횸f{U`O/ g"-ߖ]|m3W¼u^&1 l\ g$'0&MFC7gI
+WnXsE-I.UOUi]V/kOY')3g0Kz`?;]zrO37gmĹ=n[t>iޘ0"Z`NqYgޤo)nq6YVex9[d6ެ|OyP-dBB
+53S
+[~(Htf\(ͺ3M $sQ}PvҕnS*OڜBx
+e6_6 /…#snf3 ׺79Q4lF>ђf
+)Fn x29\ʧw W\ yϑ]PCr'wnUY#x.p.,g1Ƹs+68OA Px?O]xw&W{-5߭JAG x}?Zu32EyX|T9ffy( ~aCW;IS3/{{ z
+w_/w|n]9}j8%C5|5a_-~N~%}DOپ>9kGpIϠosDkZ-[0jV?3]y`.ŕOwJNW2~Oն6<&alǙ?nX"wlrZO;Iim6`J'\-Qt7*
+xC>dꮼ>-KܹSE=S73|PĩSφGSYKR>owzu\koaB0?KZ>o: qfqa&Qw웾7ČTw:|tn0Ulp\ZcY{ ft^$H~p_R{K\ʂ:A矞?<6Oڿ.ʇ[,s鬙#z-1*rEoŵ*!7ÚķUO;qt-lؙ"Oܫ3ȃdݦxA/K0t֔!4lO7N}S3|S>. SzwK<@*\ַ{M彘G݊']٧e1Yixfh:Yx =3}8?XghXK_)T.
+2ћ+g$"{n;h ;g0?n/x
+C7L1~5\h'fyye_^χ<t]sqKه3Cdµ~y ~fo";u1'~m_]}֘Ƚ7ײX'Y3qⷯNEr Sf_^UZN_/9[5͓/ƈ0BaOǙ̻Bnd&0'm|C5<t5:"18?xQO?pt{8}sr
+w;Rt2g^= qlWDIdG2c!fVb~T5W˺ z~BgBA)}\;4_CSf3f}ԁ m(plk*]]>;VsXAǦf
+5Dszުd~)PN
+/ʗPO|fO W6=2CyxA >h:sUz){E>ڢ+5j[k4'Zd_\轅:'ɖb藹D,ѩۀ/"ZSp`>|!_
+=|aNł#I =h0Pa%QY4mnQ 􁮌 TrCج{[[׹v>d_JڜW<|' +pOn(O&K)k0 ⷝ0=ڙ \Ds{5 g$sۿ+BG}ؿ[oS8sn\=Y.#qj˅,B4m +ê4
+SOھy=9s5x1vbO{=Zz҄4ZblᎋdĄ`~#}i-}?!l"ؖ`1ޟzƕ2ShMb̉=g5K`jX;/3M޵2Ino͟zyl|7:b-څL9 k= fy.)0;܋O[H{0yqY+ ~ʌ2>=j'{+=.l1c yOæz4&U:w,Mϯ\f{>n(!_[9Ć0(Gwh./9?א wqP>W<6>rCf.=)exb<2^ZywnI60֊,Η& }g5RXl̻[R7W0sR{ү46p=x~qi<״:YߏQs7oe'sw\WF|e SKMKX/_khVYSaۼ9mQ;Ց/9bh[kfld0_`B2zf\-hL>?x^{jm,W%
+|/&}J标7śK1Ϋx!<gDd<coQ4O{Q? IsY iVg5wMi,:VxM Qh=j+D?I&VO
+@HKBH5Usۙ@Uf(g΂00s=HhUiTMG#;>G'9>>K<
+~/ 4@a[ov:Z?WzڬVΰh<9ʻ~;<5;Vh:5e.m3gţō
+Ok(h{Б
+26I'vk8 mds:4MIÁ7}~<okTȸKlgg= C_ <>h<L&]bwR"cj~-V~K:y{f<B{lƵ1{}҄ r ^PExbCS@3SlwG[#a8/{^o^z1?/܀<JX>bpNEdNz$em34cQ.{$ؠ#ZW{gabAOTǯMcB|e=BքGzxG#+^P մ8?'X)6s+eY-մzKt]򇱋N[d8ߌdi̓o7?-+;A݅-rfoe-7e`|Wlw$=- SY+؃;ϫ~[AȻ耩  zl,9TD 8{OugzG=jvrc%0!OꞼ4{p1ovSiq;Vl{c髪p,D&{v/\uN_.vO3d
+zn 03uay>1ܣg7(9f:BC?WcxK]y̕-:1W|J7-ߪyA8Ι=O5x;x!>@IjZ,*{ -0:x╘`0<}O
+F3N~DɍWSK7-oC.xMg=ZP eK|:ɨćWMޮ4qz./ =W
+{ v6i+Z.NkVr;)x` n2]̘NaL'w*wW\+4uѠ@&<o;q|/9Kxߪ-kOZ iw: |!|,؉_$!?Wg(X>h
+Ҥ0,o?~͜f~i{◜k5ɵd+y:Me35i[<r|0hl.)?X˻:j@m'+uϦ4yEez /c'f,VpOVǝD53Q<a<xBn( l+'K<#cţ)AK+Ӌ"gT jV|B+;y~en{}t.AZYpߢMK<R¿o7C_ǧEz}V^Wp\˪-ƙ9 _ <Y
+xN9+֒y6oUGz&ߠx3@LEyqvV@-4{Ega$߃WJ;/+rVėߺ$ï|cFzμҟ<_}z2Y{/Q/>)i5Futl[rPZ uKwkN8AOTgyqFmk\g75xج_kq8,xi^rFK&#܌w+h=r5ӆ7{x8OVveֵM9&,h\PO|gr4ѭsF>5mOn옹fZ$ٟ̈Ӻg.{V fμ0Y/ b %FBpC~so[rNQ猘
+i+q_S~U˚b=J^%&N-cgs)ŏY{߽u}~suN6'~[wbIlXh sEz
+/. Wi󳪞;ruxB}bIی^.Zk@3 S#o߮ǧNMTk0٢;ɡ[sxy\6cSA=?A.ːG"zF\>4a<(TSߛ57U-c{aN5Y}r1< ${|ک}/keQԔ\lЙEos#Ci!}2dGCܰz+xqnm2oܘʓZi?<4 Ήr : ~M*KM_X͕7M
+SgK7 1[֩{bdv
+nΕ1%{](kXw<<RSˍ4ڲ5y9|*-=~TYT/3BΤfG|ϰLתּ]I= B-c#qZcSl `.{6wÀG\YYp\Y,igTm8{b6=:78+Anч5`}ΓW,O/e_^!Z/07\l,V[փ{Y5 $]޵=\Ļ?{tX6돁/*#}_My'D5EDϖʄ4Y+k(ճTۣz6ROՉr:Y^]֌l-\8^=Mml[7sv_VuZC
+%MǸ[yú+өe/d<| YE|^[7]^^xp *o9iSnVp1[COEb#Ԥg~#8uy0
+Fsi7IؕWW,hoZ^#pl:oǂu|kգ=UoGC[OP~*PtLywjВf~g+쇞Mlb0!_jӋzm+qK0ب_1ةe2f}L/J[C YZ^^ ~2y|ߠF2'+{$3 2cLszjwAC;x-Y܉Z}4_ա 0Fh;l9zu5W/-Aa}+.4a"|רȺIttRsS@0 ڮ8М{7%?3Ux ~T[*gL#րzGs,xWrb2qj>j]|} NY\ί|bLO]+mj&˲nQX:Vo n2)gԗYqbF3Cvh܏ndu]otqerDvFxFy_N{Yh==Ԗ~Ϲ,{x6Lvu| fy"6B۩2l['hB
+r^LKtM3`󳗞1ݩ̘q"e =h3t< D{^JDG'z_bCoZ3}MKX3SuW"霡@5pr]kmy¯ zt0%> ?g2qĽd،0Q; (uA}j3xfs9?Y*6F^7F|O-x1=I=a|yE~1[|wkOs#<J~x,mbYfA3˾]PFһh'3<[9yii p杆ɬ
+OCeۨ/R~#o蹙
+gzK9Y{f+~{hﯙ4+ʤp^bmA_z"\f-O7=bش,Lc~9{k K+-UvjK^3mdf->G/{m隻k<ҎK҂Ɨ fySewtZU}ɹx􈜺O,s,-5>2mY:gĝFuw<ޔ. vg\3a!w=kUkDv3-né5hJ10wkpuTg*t"HWb(4d+J/+̆.)[ɔ=m6PO>xWx/Ƃr$ZWK1<`FzJ l7x^|
+ef87J\^\ZcR.+%OEgxۘ.kh3} '^>wOkG~ɕdzAB[Ɉi;p%8-3>?&BE'46m#L_ Yɾ-w<^BXU>ͥF#ǻgLVjֲ'z6?Y/ ;"6Zaf흙9o zTpAulF;*kS6u>6ƅ2ﶮ^wh3'>ChlRշǯ
+:ymA "siMhxv^ _3nM; #hqT}-+X}/ f>;Sc')fၽ3{,Nq_8O7,OfZ6& a8ڟ:3{VJsN.tSTvOy܀ &DW+>}ň|RC|O \7zI6۝\4 ҕrE:O2'D)ͨ<Xm&kuEVE{G5<v-[rjnjg
+cc_}p_~p1:_w9g|i $oi}{=ǶTsvcE/;?+,
+(V/9ε 5T09γ練Ό|IR>S lze-X9If\ZDj-$w{LAL8۸fzLz/߽0 I=0ב%^ YnJY=3frnS8ji?șuJmT}/Gߚ󙲹tUvл
+8"LjR`eqꐙ3D/(ԫ2<E/<_`NQ7?'sQIakxpKb:h;~#&Ȥ~Q
+ ~M'{´lJ{gΦԅzΝz,LQٚ3D#<\U1eÄ
+G<) @-cjorgaZoofOĄs-HʛY ؂<FbY^wZDuI=gMi% )<'Q]'OX%@uY^]u., kfS0g$ CN{SL_}>ߙ·#__>hS=E2cк'`uuʹڹLw'>r[)=3/
+fQvoii{dsV-^kZ՜i FKCj(GRb9&wj昹|50yLAKVuU7@\Mqfva],t8g7ȑ>ZRqaC,E<bAgpd^~cţ"G-%ΰ~o1c9W-?ȗfJS4r([{YN֬RiyU` 1/HSa.zR,(ӧeOo]}xyOظ1}ت10T1ޛ=lqi#5s!=&;ԑZYOL :o`6ʜݳ-JԞzOH i7maE ڙfĩӝB<Q1!s ,w0Ի_&R3K7{e"<C{P|4E^Tk)kcA7RoQaic^ZZ?~5uq3ĨSkQ r~]},+6:S'|SԶ^%+`jc}2}|P>DBO;Om̸?˿~{\~|vi"tjkwo3c
+^ל5kJ91zZYg[-\y5Z79w>2lSH/sb2G];1]ꙙ`V[0|D<mJ9u Z^Qp<$c=KE=;tEG1(L-[O\ޔ a:;9sYgڝ͊-I}3æ}Q M{Re>?`*||{PP<g],thϲ\uF=ypZ`87UHe9
+<oinU=!|TkU[33͔sW'U*ʽ +:Iݡ-ڳ8%Z"fHSNRj ߕ
+ֶ3ݣli]ŲC3FYmPLbϵJ^S(YDm%o0(n̽nSN,d<WU9>!̰4zE@DgIvܦ(zM;Y!{#,ysͷgC>|P<0=g#[?2K 5 `3;=ϱ. #6/9bi9D<8S/̚<0|N;;`c0l-lƀ=Lۙ$v
+Oi=pܙxReRytWNqlw~sOpW_Uy>b7&6'nLԜY,,WZ)(ekK6SrO}Ȑ|-#?vcM[_CjP1J]s&9^iy?\Y8=J-;$6A1<j!~xJ{z1,;u[N1f.?<rTzij`MiKF,+ϥjs' p [0 W`j"4|r&{ڗx#6wI33WYC )[-iUJp @W.b3.,#=k3U#mq` ]+<am̜ಈr 6;\=vE4\_R6Qix;qM7_^hbN+SWw.3S'M)U@A wM<)ظ?5Yi&ln+=b+F̹, 7IVZN_Jw9:S)LBݝzL"foJ#R#Ci L=, os(zM=&4ѝ1K!i|#D9{&!nm:VUS
+ˌZëM/#mNY1iKB :J3cv-bC̸6{8ݧ _ů1xlcigߴr OeEсȌܰ-73kC \'tAI3_n.>xON=<yb af
+>j [ZkD-vQ|4|Ճ#*=h)Vk f(Z,Sww _ ኃsP,{͕֣'v^FS9k2~x1?<o:ryp*S ژэx
+>ύ/>꼂ؒk ̱ewv&ՒOr+h\|ĜK<fE4HBNr9ym/UݼxS }hNB 0cZ_07VUYa&KIJv b/E=vh:ܔU ̗xR[^_x.,8}љNǾ ) 1U',3^@ck+cGZ*ܤm`I[+E1{ǯZg{fo-ݏ9 Ρᓢ J MMDx< F@#&fTz{zfS|TƂ cjdk}F?7/<7s3R/Uz_*tNx}o<[ŞN=AkSV
+roxyAofPsv?WٶGiQJo<s(6I˩\I>Xr!1ZAω[M\O7y^2/IV`ĉw%ϵ3>-/>k/ZH Q|MVRojVSm0
+cF:hFq59fBŇ"~(,e'ubz8{'T;UF$v/[hmZIy4tXy}s7͵Zpx1)}vmUQU<.ZoeƗ~*׻'|F/C=דyByc?b> ?xs>͜o7WT0Eg{:`s:b!5Om+6|ZѨ]8 iVoѣ X~f<y^rj*=tPQ uAP9"`AdPOZv1  'djך~謩HoɦJ<sz=.y6q exڑ= +SZ[V-[h0 TVA_ȫꓚI-y0!e.u#{Xx"..>֨OwTjM;3W.Z/^t/ޚkp>
+7m9>2Mm \gr ǿM<L)̹w^T{'w
+\,\* xO,cZ6i)@ɻnj|=knOp}[՟0p)zHďx
+w4FUʥ1Y^>Н KCK4 ,ȷ ҈}[Uf;m=͉84U(Yq9qnf;y`k׳g/V6sw^ޚr#o[v5^fdnnj%µ9Uz՘5S~6r%3Se|v:Ț©t &ϩg5-H ߈ ;^Mi䲲
+&]}~r=%_z&(Y||ry>Ix}5hj(d0~-a3F/ߒ~פ~' p/M=$q/ETQ ȢIBufnԘz
+K}v(#H#8T޷usaԦr];[?z5цwCp1xz|[ts޹ŘkB7ʼn| + ҹ̤.=tᕇ^r yxJxRV5&"Cm~On.D4 {85/3aC8YVh&L̮p
+
+5޹VH/]^]xS>*;]й62,Spc <G3o't.g1zr)еQojl8F ;5u/WV3sE>4Wt0'@G+cGWJ=^uo=>SW_82Do<42˾`5!.Z_33/:*/F8~7ʰSqK|qa] Y|#Cߙ)õ>wa[9I3Ҁo/4Z;3&n'ڝ\D<r+.=:_ǺB줉Col/dڞl&t$t#7!w>6/~)53}:gw$>WZx
+巜F=
+Ŗ=UWy ^]}߈x$xLeRC
+~޸U|wtC϶buzޚ\&Mmege
++KfS@ 雊%q^Nyf>:A<&J<ع,~(1s& 9gS]K&F3}}n%̹ҙ
+4YۥJؑu^9ܢ^ԣʨ< Գo'Y5:Ȩi|9טKQ}1Y[żaPz~fFg<M\Iۓ.5}|>o'''q/P̔h&{:^SJK]za=͜QydJAWrsfgWݖqCym|3 iV1^ѵى\0o~rH/`xݞpE9VH7]/:t*ͿmbH5{Vlʵpr2%p|_G[,h',]ޜ1;E|
+1]͇`aлMM'wL~ƚz&}L Š3mOף?ҝ&bH##&U;i>8*\ xT) ̖pV
+:(?qs_ ?3͟xi8S7 Bq<7fܤp (Oͯ:D>&`9fԼ8Ǧ=8xZnzf. VcC U\lcypo[?Tl=h]<KfT͔KˌS.h)K1a^u0 %ͭɥVgu]WUsz/z 1(՜37h Os⒐9ZfG4m;9b~D>@%R07/>&s>315׭'*nE>RO7:ZދwUw˔XRA<7:;]1q#|~ꝼ$W"3߂b?;:=rP;kf3C03isFP ~ؠ&&z`M3:-ޝ0tXGz<=ywdZR>>߲s+.-Xۚja7MiͣI+ZcAbI1mFC'rT"/t
+T V݌E^{WQO<RChfwɟM>g?x?[ٮG5P߬AVy~8ӫpRg-O):_R'ĉnuj:r˻7;YtKk|(.YE٠٤K)<#\]e$娵]ŌiLJ"CgSM-.Մ8zh]9aXŲx̭OM'ZK3*DbE~LFᯅG;/Sȫ] ˧ǩ}'il2'/>C\r
+yn+-cp>:n3N^x<YƆ# 퇞`3[CUJZ%Τ) x5kfV]Ic}9 } /ZU=lu^XӞe
+ošfG3>8eIa{/[PoYmD̠Sj|{2Ojۿ`shbJ}.<<)ad>pFw绎K 1e u׸!4?-)鬘Fk.s9hʨU_OՇsF>`5:כeCb s7<n\4s%j.zƖ8N6.Ų_ܨzppX<=.{׾̬v)V[wz/Ŝeg]є♞֢PluI;5IZ/3gr N]юBzB;WC/<yX"1+X֕W~KGBs uW⋰C#wLkF^ݫTb>~G'ժW(~T+︴F`Tjg]47aEpw20͜n9 qj,g1rQ}%oS]Hl9g:.ަ GnrD7'֓ŷeǿ/}׏HS:50Rz,t8K72w2
+V'"!!\(_< jkm44辀78fCC֖fipN|{񪶞+ݲCr/f
+_~Ss\V`ƱLa>QlvzIcW0.,fsAY͹J ^e2D<ed#ʺ:7'c)6pj`E<Yd]QO^[OC fe՜逩56u˰t 8iuTqzA%ʞhf >&nwyd<@7e5%O۷4ߍlD3i_orYks=-w"zMIv/rX~a\k弄r>"-1/+VlgJ
+טC4Lx~0c|f^B~{O7eל=ƛ1sb,}/K&`^&5pDh~-߈R3cøȜ֧AߓrjT%T/1 ^Ȟ%1{XZ1U})?<[sSyVtOz٭Z}&Ԍv+1╽nsnF-ngUsjH<c٫{ QyGJ>"NRC-~6Gmb{-%O*y+U_+N>ڂg3OhgXfvax94-<]*+?jxhT[Ǩ% w-xr])xrqՆ_oUQ ,El4`cޯ2/ĆxnY'?<%d45vO_7(ex<}N}V$7aT3c[ģz0 y ^O*3u-+mmiv.Յ۟vj{e-<F5yM5f6a âF1&3{QbQ;DVNj |6lS7#xrLVݙQf0kdoXoбuh 0%꥝X]Ȼg9".踭'!72m\7Vêt\amf m蝶u_X)t؋t}9ZґәvSYs6/}~^Oŭ7=.d'YǤo|iÿO9UTr A}`D8]?eq<[j6w[{.5̈i9y/ukN/ l6hD=W>e.%zt=uN?#~WN?Z4#nɔh^<C?^mޙ{GZ^ϫcRk֯<,/ɮ5^*v-ԗ@㣹lPFoq?QL)hܲYO2ىKoFVoc"\'a.ͦte<'j-SzT!3(SL<{a[f'm)흷gs6flӹߴ(y^|W5x|i#saw=g?V4u9%NlP'?$a֥іl%O3q<s"X>(f95`Α<JWR5>G[;9<5LwTGLQ닦: -}ɜa>4G`XEYdq
+S}}A{М ́Xu.{|OZI11<W'w[uN hWl|0iޘԳ񳦎 )kÝnOq=1b\τ2c&`0[eLx@,<蓮q(]Y4)/F 3ļ״$lxVL=t
+ue'?
+endstream endobj 55 0 obj <</Length 27498/Filter[/FlateDecode]>>stream
+H4WIsY
+ ;#ے-ϊ8b͓5زņbŢYtC*Oҧy aO!MCJr:Y7w9ܫƚ\|X+|C,O[˿_?gqMj&WdƊrid$SٲvF|n{QnՃ+bog%~uhNX}ԛp.(q<O{ec JzEh7;6Ľl@8?$ggRqJO'id2@-:_,Ĕ8ܿcsJ2Zu+-e:*3\TG ?I.\ErQJ2]Ĺ2$&Y(qjH&8SKr,SLdj+C2SrꕑEx,srPLUv]:-pvMf70L*+'׎f{sk;K <<wǟl_ 4 ɰ\YR@qRn#<W|>"1סRqIߦE׺Y{}Ul]8Zaq,䯱*W-6+Gt;7=l/;Ηݷ; 4*[pqqf,$F.P϶gg+CY7S.+ם)_ @O)
+]ҳV{ҕtI/evqSNoٛ )
+"鸎gAz{vG̓'-y#0oy q|-:Dāw#iUܲ-y
+ϑK2gQ 3a <% e~pcdw.ZQrH/9/H{p:y[nyīO[qf>K텣xPF5"͡XԎٞwz- ?E{uxU]W|T~3MmۖvM:Zj^ ){'Uz[j~uMJGz*k9Hg)u؀Wwbw"*ĭ[/
+4OO%B2Ξ8[ `?^f2/mNV%w?yqi_:V-MB{BB @B8|R0i¾V֭M 0`t'6ҤMDip0gهG><~'^Vjur/&Zb ^Moʳ_4Ҕ=D[>0_6SOwϻ\O;ώ3e08c*`uz[5R[րiAF
+1#>8 p~+&9Y($~DUr2GLumx׶Y3sKv{q|k\ԊSc Fh#sw3fs_z?q;WxY5?:P+xst򃰞sgP=<W)>HlnyGhjf4k =i߹s`N#zOssqjZl̡:V7wܦ8`ce=O~ G䒞i?W. T&>5j_dǮߟ BMs,>2~s%g.%ͭlvn9iYLZA&L=sm\%?<_,?+p|@ϿkGV~6ouQ,cd!K,k=}q4KYf+ o[V1ilHߊZO.,kt_4 #w >ϡuo:#s =>-xcMqaи|~<Q0fV{'?`gSoS2nyY5Bk] n`i\5\hoY߾L;pCV)71|?"˪3>g}xX55lZӃv,.[6O͏M`E5~͟Ǧ27`ŭaMbuɹ3KKo/f-gGb@A<dM5A=51 :{Y2+=`V #O40SQq4I 1/V)3Y=,<:`:?m ܽc(ֹW&ߝmB8o]\w0]ϾCtaٛS=U+CB~6b^}`-f|{9r-ͤ57R|Fﶌ_О4\Ќ[MkN׾Y_{LLx >.VފE>V{*& xt+V?*q8tׅQkG~ģbΐLDbC<9fޜ1y}w!h9g͟Zv캸ޝ)B@gω?np"<~n^#x]ON1u2 E+XueNM7n3 dɜo4bFhs+˗.gm~7߿wZxxֱ=
+#7ywk
+M7D/y[L'!f }7ҾSdTz5ioUZO=4}v0two
+<?֔9I<X6?h8tVd`:
+.Oܒ>g,hԛX+澲9Gy%0%=9d<}?'UϹ7Z'Rwp}(+m*}Nz՞UvSb K#xBxępusQ{&/~99szOsˎ\g:3gէu=Α:
+Az3={7 󹺯@(δ<=mxޯ]jZi<ʓr`-s7t\rFwOri:f9࢘::bn _ fqo^pG>Gz:~‹'& GWA=I?ŨF=_B/tam-Χ==L[JHuh(9c
+8l~6bK24S1Txrqȴ}?研۾{0\9w;lūuT sIJ zlT;6$>p?p'a}ȴ<6c=&ʽ1N<kN:uUϿ}S ȿ`j_2{j:M7NH\c`&b;Vkƅ$NUgLe:I1fH$*leozδtҴ6u\ۀA;}~Fҧo9].@#o{|nUͿҾ:K^<ұ]̟jtŔnڿ]rB<s<zW#bPr fbmL>P.?^S^0P;!wVO_[.y 6e U聾$k6i}*NOVVsRJ0ix=կr]e1@>z%uh))%I<@{K%q-+&#ZkҹoeQ̮7AyvkQy=G,cԟ5 c<ܴI|]?ֲsb%yޏNo\fk܋MN<{ G\Z<ܲ'hDT2/3-l.غ3ʧYZ=8k9O?-Nu-(pn3.)6&Ӽ;as~PcU#Һ 9̢x,4bZn=ݾN }vB{TZkAMYUFۓ.XA`F :Mpfmvo/=̐hAPbb[>7N>&꽫{ͷ`uzvg>w`FbK7t|&agSVT;7Y%53Y415`\GLZM.Wp aꓗ*k{x/yOHYôPS!=@cOM^2n\05uݿi:xD~>hfc̛kSzc{s?1xTG{.xQ4̛lKJpnwz I4ur]6\S *望J32s!y|Z:BUmMO.wYzojh<~,cq~`V?du+ebѣ50󡏺>` K]˔ΪFGw|IA0m 5Qoޟ`V{?zplg9ZYf5d/:O%e#ӂ,>Һ 5jUƵ0zŏwӌt~xM~h_[53.Io'~|\9<طzc:\ kC4 ~Mőw>ϠG9hc & owj!O}oz8ֺu^GbQkSx4iߩ|PO̙8VUƀݽ8*p9^\޸iڧF|d~Es (OXhm߉O'qô0+{oE'ڄ&sH/ߔߓ]LcuKu`YwL}'쟚/x%d?>xֳ?gggW|myQ{b0?ڵU/^s>^ŲhTsnF<8O)3q!ƪ_CWE0q13‡&J<#% O1n4a enx+ķg %&Nc9?Ω?W~dfHq3cң1[gXAߩ7ztQV)F.Wϵkh6sC%rїÍ9~L?n{wQ;vC⩮TV>jy9ֺ/pJ>4AQ,*DBfJiMp+/۪iT'=A`A|`?<ưGp^^ 7>9..jd>~ u:3⣰4#ɛlw\%@<JdgZj%dŕUQ&Yn*4lt[ģҁh\,_FtkkUQ}ǟg4<lz
+o(;jiGGd.uy?SNS<mJFBt 63ϳZ_g[>W m<ˎ_L'U]WDuFݟCn'g:_ؗ89O v(l:lK/d}NNds!jF)+98
+S=oK;͇ (77*Ur޳$Os>E}q|&Mg6crj(@ec9v& }aL4ъ ˲,!*L3Lfc85o߯79כ^0#:j>SQĘg\& oe&t+
+?}~]Ǟw dg?}p?I~]' p28n%3 1lqn>z*R2yZs׼7.a ˭bDՙLFڶ}9z.]g^gJ \eRUC%@U_?Yr-zLߵBndߘ` hC5{F6 NF1՜VkOeִxx\}5[̞v
+nx8c'6bD%L#'}5>z3fTP˗̫~ouͰ1sR3./fni }[l7~qyŔh,%ʇGL 4N&8/IbIJ3ČQS12QE8;i4S5ײ.| Z)s¿̪< U+>Lc~>פHRr3] zuа
+SSi9{s/{,6STk˸ۼ? }[q̈)s'+nn>kAN!;{ ~f?{N4["^K_Ihxv an#kU eUϋywz}0 SM{ fɆ5|:+KOṉ)y|zB^Qw'9pញvSw]x/t>M+pm;j_;c~]0Y ~_{ydu紞i32ir_<֧!>njkywzI΂%2i8W;R̮ܨmbU3xYaACYn[*+Y3'Θq¿fĐ34.
+GuuM%4'Mc6_SME[F6}bCU\_7{&3\k2sA mR(FٟF%]=3{[v<sov)0u<kYVk@V0/\wER]3~ry \?]t5v8ǩ7~^nj|wc<Oszゞ#qH˼ֳ`YOvsg&_1(7n>lӬI  fDǬl4z6H|&-ꨉy&\jC 3ً+="lY; y6rA1oqs7\;q|xq9>LみLs%y/:jk1++)R۱uKi#HxS<Jq܍#Ay=w#h:UʛɗWyЉ[Il5v/NP~1}Ay$T s\&9$-I{&iD{;24{nT
+#8iPސf߹lj9~Swjx v!$f{ldġ=u+o~#uҥԓ_njG$*L AZR8!#Šc5lOǥI4,9@s$ p 6ĜBCNdԩ]/EIU&Ic ᔤdӴI˪UjҶ+)g ٦iBl<e͈--j6'ăhٶOGjL
+E/Mk*mT8uaq|_3%23.{>Ԥ;O5r;16^._uV8b~r\[6rD@-K4&Y3S^|FZ46ЬQ;́Ҏ2k͉b".j³bh >fR^wܶt^L8#zFŨTwx=cAzOs+~a 8.1mY<,!|k_x"Qp$?&e._~yOQym" x{>@>ԫkZ#=ouoݡX^i`+}GLg nFT?:@O(^ &C_/{f /Nu#W~]zɱf?Bt&Jn1tAI3Kf#քO!~+&Ԥ#Z7"&ߚJf4ێ_ad#)-;LLo0uFo7md74- ?iZY>42q޼zogr` 9kg*۷bk5͝5x'Vto͒1\0߸<uBTWo.V;??Qjy}fN?vD.<Q9s4ܕ_ٰ)7XUVL‹YgLpx<Ú^5m܃aNfXlCKkUυU?+hXd/5c-wWkb''zA,6~>vӑ 'l/h@K,>m>aij9D3nI>yx_)>Kh9"}Q״
+F^+<@'}2"Mlf>|6ص\Nn5#j';"@)FZ==,HxX~_ӓLzZjk-!gXF3^
+\&Q;h|9{93UmK067}w;RnvDC՚1=[g<K|n$Rk=,jۇ;)ޠo}3!~_I/NF5?kuoJFa%׷ADKMloSFܨg8Kf~ ԣ!ŏ_C4;;_TVznclI%0D<5XU9ޯX )Nxh@l~JBs'4S7pIoU̞i߿Z!Ņ gW;`jro4?˸sb-Kspg݊G/ OhNxZp_55eÛl7/,ܩGv[/gŶtH}jF5ȼ.ojO'=@6\]<ZwK5=`,Z|LY;J-7o!(-|xp&jr"C^PTg׬kyۣHI d)tv;Y/<_ٮ6.Tp1m*ЯXʍ۬[ȞBfwE{S]'sL;[Q8O͠Q=WyOhEm_V,m<*?~fa}Rzn|ΘEtI:oGhs. `$?`>5k]zBσ߫zR[sj^8n:&f/XMnec$0DsՉ]IH]=3[zRaFkM\LlQ/x`=3K#uw u%W>̘F烋ƯXT0Dϋ{Z8oҷPgx|
+>{_LGVb\<ڊ+u罄/^w_^Ih[mu/}CKyK}Q_Rϊm[y﬩C/W}mM̳OZ:㴸bhGW7rk͒H9p6G0@}\I_+u=o$ٺl}eto$[ vtJ=vWxbw$,+{y>d;d{3֦wc%Vb/^׏\NGi^VZp:=%t,fԣxQ-r<֝Ri?t9.OW_+uJ;NRg?ww$9hU{CL[i3H^M+dHzi<B?"~RLſ*~,<zVsnwUR@Zt04b+b#
+KGf
+LDdi&]XrAlWAw"+)e/$J*ݭ
+&3zXr&᷍`6oIĕqG&xBw=p|;'&.nՒ!?wI8
+fBAd5Pu*qLMS;YxѹW;TsImcF!F g91
+)kb$(>X5WN l0p$[bs2m9e1XU[)~nGaP([?u#¶lO ܴ 7 -DZ쳈OM
+3dzהuzaҌ8lyOkٮQ9 O iJ0@(R,\
+ǹX2+YEH
+I=>t4$ O#՟@YxFDX,Oar[F.B`sg
+VƑPGY*DDnF+9A?* lZu嚈ןowp
+)DP@.Cp 6mMsSH#qO+9 4;V#,uЀEؼʆa&/[ZsHoOdɸ==ZvsZe SHсJEpP,BB5!4R_
++0@#/as&4gהb}(9nsI! .CA}0'z e6&R q6Tx(ٿ)AW
+gJK)W(\9ז/?W ?M0֙__!Qԇ2`!i\tEz@׌!0SLDʘEGDEgɩvVaڿwP%%|d1TMyAtG}D\8D.gQ" $ šıi#k'V(CDXbB||B#4خN=^چċ-؇t>h Tb m,D7hh^hhFa 8@Jz_tt W⿒!DEluQY?V}k $I?#Ղ
+Ɣ66i/6 zQhaRQ#NMإfJ
+w7DVLWe,fyJԅX;SpH(IH7W}@@ܢɾ\䚳X0PhaG/5 ŵ"NܫP%P{HA
+
+nRo%)h{(ub-'q;sXtZy@ky_k
+<m(PQV;]U"eVNclp}/eVs9f|0|Cb +@dpd#܈"c)dlN},9<ݑc=lYn}u|<Y%rwIfOOOoVzDžb2B綸*\*ʍiegĠ <NqB
+KiV,v~.^;XW{A{jWdP1Hi*o+ -RXSz#+x_cq4yC6|58R*շ?yx/c(OD#b
+ 4X}uY"Fב|
+e%l*[dn -kcR
+BH`P@gYeP?~NG1<SgwEIŁL?AugK|-M'YsD>#IUAb NaM+
+Mpe4V+]J/"RqRU )-*H`kEJkbUP rGȤs@\- . 2\+-z#wߟ_l/s«UV-f? ˌr$u5sM]xQ
+V+.j$%.fUeTMR>_aKv#ķO ӟ3ʆa EYqLU`
+^^bVLՉsOA3@niቍhz8HYo
+9Z ,kL$Igc~K."|ϖa]HL`E`#BBk>xmRZ:~ڭy*:vY C=7 a~5TU 
+dz:CDx05QP1uq}?AX64C|e@П~f<D֭^W}^¢_22-pցp*08%.`"4q,sbDݣGT 1@ =
+ё`,0Qs),^"FXB ~(bgw0G @ud
+Hv9b׿cg4[Tx Bd:n Bgg#4T#Ú.gp T'6~`;@֘ĝ%WѾG+)&2XWغ.:yTB_MD#̅{WWϲ=D*`-& \h戸ҧrEc@e ^D||!{&|_7 IQit3"|D۟}((f b V,>(k^
+bkֱ b:D2>5~ ޢ l2i
+
+F7($y@Dj{2dVm:*05$U+6e: ĞHAp B,Il !
+Uv$Z/zCi6KЪF+:j3}4}膽$< hD[HLo%;B߾C4R ?J'
+$xdlR 6gXIVxKcM?Ѯ{K718钲'凡8+_%ck U/_1'-
+(zߨ)w<v8sGnfȽ0ݑ5ɍ`5mZ~Y^>{똯^Z4E1S,I VXe>q܍ax)K K;JYjkp·'w#.;ƖBSr;_9"Ŝ5H]_whDapZDG s-/߿}B 例SAe.ԉq(ȉ$vk r"GstT48
+DvOh$ GKXr+#֧\juI9ΡwO),Bt~D|hAn-MoL5z-2Fٖ0hkgGEt{W@UDNؠ[䤰!ף.7,Cv\K?wb74ZP9600bjiHbHdDB/u#jIǷ͚,Yϼښtu&xYk
+ҮoS7C61nD~RRh{vnY7̶DMۥ{\?/qi Uij5R^%?(y]lz;}g7\? l]k1]zm&W,_o{<uURP]QbQ " 1 oM۰f%v"5޽גƮxٻȮC<$c5b[3)ޚjӷ}pv"(5#NNJX ƍ"ݿtU'4`N+PݑmA܈ÈI<
+zbΪEN,<WK%J90 z5a%  jEeYQ/^=YnjVˏ_cC(`Ae>6NC1VbeYEi**S=KN|"Un `,HW;1э)|%]#+ 0U肸x,u1[EU*u#i FSp7N  .J.lASXAQO TADU]",Lӻӭa@;5 D%!GXT\.UR~c,zA@(į-sKh3+4&=2$4( @Ie
+ LC9扻vg9@OsQ ($l8N4J+"U)U[Bg]
+x#$qA4+4}X;r%*8w+Rv4m0
+ݑYk9*H~) ;RXh[x쬌t][y]54SF<J-|i@UHmEJƵP1Xcfo5e,KJt4m;ծ~̞hsMpGL7{;-svSC1uiL#MUnc+0/#F[}kcAu@ پxhBDΆa8ջ$(׺
+l-l5^s4V"ӻ !-aٵ8b!~u5H9~hINzޝQ]R5٫>}RSaW7ٍsa-ԛ~rSytg{iU$.WA6є6=R5P!w~ѯ`e@]+$¾!2uݻJM;6\چn ?&}#nl7gKK>)NpoI(v\dS_΅jι1(*{gi?Au]&jVCW(8loXvU̓DU/ڕ;PS$l $ꥒSPb&(Vu"~Gԏړ3T[HvHxP]1ļVN%<V}(cW 0АۤT4x5u<:b;
+'@@RIxBu a D}bWF
+W
+n5%C =4&5+U߂|&F[ %,[R5vZzB.Y#uSnң(Bjz}OxCTͯn.Sj@&,8@q>u-~PxkqNנ_xyYK>!$W: /[rw .}) yHA)-ѱPSԩ?'=40R,geћN0SFe+4)ۈ
+rSc0Y
++3|7X!ʝ
+Nۜm̊`r J52Y-ɭ.DruRz,֘*荟ϺǮaL]'%\2U/o2
+ezƧK`ˋ9kU1Hȡ%]桖-< "FBKe96 \10 B^3<GAd9LP*$*s |+<bsk_l<<&;K8⁔uh5vgb8ahuvsBV'z;ٸLkvj;}#I0Q@LI:_[(UJVQZhBA䤐+A0Cr`LG3>$edli*H-/ ڂ *;
+tuLbcťZS0yOL:6/ծASCPH52y'˷Ƕ)8kݕ 튝͡]qrlv2Ar44#04 n5>'/$"Ƿ2B? t'QkX
+53 P|ѐӡm<q Q=3*`~0: LQX1v*7@>(hiA~\ ਗA17pP9?|d#wG]Yٷfi7ӻcpWK-R*twQs:wŻ
+!7)l;ey'Si
+7kբ>@x1R}ހo]N ovVd] ɝzbƮ5#t*J8(I@WZ$A|S*)Ób>|kn_kI}lZ.NB1VB ҡw |(UlW2e~wީxm4*Ö[+;ޱFWy_)rlui~kQ7hɮT94A`$e>$/4m U>,thY4+)2;=_b_[`"-v&0K9#C
+_OsC
+5_f̠7җKkװ/ *Spu*0T*{#(6p:XBbY;f"05x2]%{9z.:˱lW٥ C[ 8X
+I&aR"$<ĩ% nm+rl߁G
+; fdn͇8~Ax^zb|rl6KR=^u.0֢|(\'HkݟW-C(}gM+{,R M_{ #H&*mR]o}x:'Xa"UScȱgɠIFҔ\d.Jrӟ+rxs+XڨJC201/ MD;Z;$ߎ9KWRqF3cFVX_+2ݎq7E(vD q{{:L6@Fߡ>{eM"90` 22苁P:Zi4#0zfoЙe1lM>,z?MIwcm v@ifb}ߩ| $ͷHpي qxEm吒f+Qw嗄ͤ@O0zO
+endstream endobj 56 0 obj <</Length 21501/Filter[/FlateDecode]>>stream
+HWK%9
+ܷY!.BB\y8 Oʬ1EgzF8ޏ_'Žd>aCӛ@tG4g_$:~ӵ<?(_qI?3@Ti%B~n"XIYy 9[:_̒s
+80CJǧNj{牆$~w.hM-q)3AKp,T#A Q6cu3=E=OiӲS$5R'L!J80#,\\+ I5 *Q@[ky>L Awfz 7rhwÇ2_.!.
+r۝;^7ODY-A)ax4F;.z@@ӧՔ_
+괠<tp+ԱJk+Wۨ@ԆF3czz w#Y(^^r Li
+&K (7sR{H! c9LS$Ν@,?k"FU5ҰaOw`h Ar? >h:^b<AOtF1N`UmaR yG4ȉB0!Q[ - vf9A;0Ɋq:_P뵎o ^cAE/؅hZp-
+U놄hZru pHy.+T.VocUHEJ$p33og筽i xOz_h`8ˎ25ĪZw9w5cΞ_o5*A׵RZ"q̞@ǡSըewhβ)'v;i=O
+1wAsu5pvݡ!l<
+ݶt@cځ\s! ,+% 8r7A H•''F?=GoҲ}Zv6
+jGcT]>߁Rpo0>:?<\*9 W7*t/#<7nH;'|>kv/F ֈ$I\#|R ni2:0-n)-!g[\G3uT:weA٬0 ۷-4ͻ++5BY&m!zsWl0-nMRw~]wntoϽ3{LA)6v`./[,2ObE1RM, eޮ0 O-}LꡥOu(eJҙ:nxU7Z 37*pگ?;燐>8tc_N49,Fo㦏8W5^${#[ﱴ@.ސշO\vC[jTsSEM%KEeScv딻73D">Vd
+JqG*v&4
++)xc6"9i)IzbAFs6JV !쁲@4m9$,q|!LE&Ch sl<Cq#k/ ^#D-Dzr',(Ăn 2TVnEڃ8ph?gG~{&yS#J )fKz#Y-ŗCtM2 Y$ ŏ?/X%$,(D}+ln'En5̷L?WF^PnЈ'F׍5 DP+oG?'2"? YieD o/$#b%%yq4I̳_y;,$#c+&&dFplcQvqZB0$H.73+|:܂7ꍄ3
+Xx(frM@.@_ ,Q=-=eN)E qkAwealv(&v{2񍆉s
+}Tko5!ZEXmXaH%IQ'C`#E0g)Fh5\B?
+9nT2GBG&oGcNPmתj$rzBP%IyON&ﲟ\oŵ՛5յKvO
+"ETP;4r[vDDJk拔o澸Set79[7~-(wJo|{:0RNfcrcĮo5/5::LD,ןeZ<_W/Gߔ=~ ڊ dI]]*ΐhNBV<>`n60>e2GtۉS ҥGޖZ /1Cڣ e=kAoE"5 @-[90zw7uTZw"vM事  ҵzۺ *MUF5$w羯v9:J.OLҭRZG6^ ڳKm# +b5ef#QOQSmC&S7~ՙ÷9朧OgIF~)w)föE:o<qTpET}IX̻‰@G
+^*y5 .~40y$MAb'Sʴ@DK)<Np &/?ǿgS$Vmz,4l`!i.%E0 nOim2T~ʞH]
+P@8݉<Em1-n"աܕ:=x:DrSHSC $}8j?@J?1yE =A.$飥[bh<{
+S&#I ]Ēz)ЎE0ܪ2
+Ea;Q q^  ,H
+ɮo[ KUr Jx (z3 u",q8K!; =Tք@#ׇ(a2 F["A`IUlғ'6;0O.RqiK݅ 4 hR %١PH[[)]jɲ,[> $ނW.uAʌ.HPH ܘ
+\ShIpϽ1<'#B|#ڗK͵o_|3q6լӘKE6=#<o}/T"M}a974zӪIW54![OńĐ;zʣ wAYM]٠$PRukEpx:Dx@Au87cf_ãJ,M r'6wMմ׊^Ro 'JF!i-UA/>_04SYu\x!%\t @&4z j\:@ ^@Fth0!9Bd+ ib$4xnw@DFl8vϢ3F~2^:
+GAv3Yaʭ1|ai'}v1k#?wd7bnwg*J=shQ^x ;3 ]lc)eqyyFGm'7jeUt"|j_:s{>GW}̓rj9 ]H49 ƍHޘO {]ްdN%w >aHAT. l>FF ;aQInO!?Tj@L
+ܷ&(Uk #0^QBRE.hX+!kcֻ]o$rb{-i>[*D16bd;UFqr&QOj o7W]9 h-=X7oEFoz^ & ν=@~|.Qd9
+_ʱ –Hot6.{Z6QX5rZhw<Wo&o_`ͽ% n GuiŦ˸m1[<o[1n$V/c"={y0JWlvC*valyf)ClGIԑ'b"e1;z9~J D#-gpH89]\O%+?ڴ$'-
+B*(i|Kw]z*~2)RFE _bJ̶0=OsZRFK!X@ĶLh5N7
+Y";Xu(լ|/Y_ 0;k8qFc
+{Uf ?Ѫ
+kI@ &"w6eR61#{Ups> ]I͐#RwˮF(^5d:8ڞt[Ft;frPz\sg1^L7&ˬPXx
+Ɩ dtqnrԏ擞I #Z<Hf2zj)6EQU9: +3injc+o$YϬQoJyUa1$Rڭ@@tEӕmtqYnxqxg)S12}M^
+*O&'2]|Q@v^{eU8* g^jfXGׅBN&n];h2Kn1S[v'#}Nq tr{TR}ΐSxWn#9W 8U:+YE)e9FOy$^q;MCUDU Ҍ |WAe)J{l8H #fk96^u,**ȲLCwY.@zx,SFlFde<DbV%N%:65N:NaC ʉ!
+ q^ߦ1Eh <ͧg7t]X5EzŇVdehЎ @Jo78? _[Q/1xd~ rUt:)
+SGXkɜ 5c#h \}}_SgLW7 %L 1P
+EeF70~";z-Ӵf9
+_
+v/#6a0HxHLU0HS@
+Ī]od r7Q&cgED6'XR'NJ>;<JjVj
+޹mq!5ŅX\u9X 1' nfC9h۩il
+F@
+o kc_@Ld| '-:lCjtb1x-zxZ|}W-ǫZ#m İfvݏFm.lGhb?7y'OSd.p/z7`T_k
+`
+
+^;E& . (axp'FoxCv][
+E^ן5ꩶQeQ\~r"6M,?y vy|&$oPܵP;
+R{B`Ԫ3n,ƺ|#&a
+$i^
+3sgZcl0/ _ծEtWxvT&}%Fo߅[fi C>9P~bYʀKVUґkϨ̗͘FxLf4STm Py1tcd=j{ ZYZ&s1IATBL:]oT e儠5=_1)$eW$W>~g%眤Kl<
+<tޟ^5w,Y(h~_Y(H3C2i?]RBamoӥ@Q](U < >^E$C6L%c6 Uԏ9"ؕTZ
+,N@;OrwȨߞw6p](K w3Fi->4@
+BF?`05ɉwYƸOsQSTNto4pd
+W)AS~+Tg >VMUx(ߣS)2
+KQI[mf6+I%V/ N?a#>RϜ ÂSgO ?|o5E>`u^i38Zv)0n|<;,6N~pW0GQАB .c=훾˄W4*1p3;ӞEs͔mN"Y5Ii ԇ%왯RDIxq~ z]l3_ ]2bAPfIHGGյ]Jz#vi&
+*s*0GT=p5}q.o%vIԤp%N>OI]y٭\ /{+BƆ6a|GW0i5rr # &6z6>s J馻*,kD`K=[K{c;+u !%'[A <:4F"ӗcNYo<@NQ3[ <n 62] ;Q-O1(y U HlDb> IDžY
+@,zث)<."I&j2sb edcE 3#KaO>yv( F@8̸[w9 A e7\4dޝ׻Ʈ:Z^|!#Ϸ
+8-ĀKZ ANN@,SaE@K#C(DPX-ʍFZ6
+q4(d\BLq<eu7bO$ܘ 빬]}.D'{?g6n$B} q.j}նdauJuZB`׳ !4"Ѧ:&8Sw 1AKj./mc/eMP^ŭˊT䞹و)a[k7Tp607RM<^T]u@CQ Ξ.r. 7W;D
+*-E뇱cYj%rD'Rp}VlyֈN6f "骋^lH^5`V $_(w/C MtT ߭=Kx\?VfT~u?)?a +:R`_Fsʈn
+ 'd<v!ƨBKc({/nm;mÿCu
+15
+jڂA80> }&`ZȌ§w4ȶ('" Zך#7y+.Ff:2y
+@J =0;ĮOg5/4i3 NU16IrdžE
+СAApEH-^:ebղ+𕠆FZmߴIL-D
+ fRTrZ@fV L,Ǻ:?O<zsc gD9hKaK٬hQU[h=vY?ҎKh'ѢdϗnM[b GhGw#ٱ#ɫBE+ lGq߾2QY|ND{-ĵqn
+K oj$ @Lz'57
+2j&;Ugk
+[psҟ/Dc"d&O?s3)L^ɐ@0@
+ƍP
+Ӡgt:j]1y|\Gvql~Ns<4:S1 h\dJFTQl7Lou2q-bۥDpÞ}Y( 7b 鮚8T/*5*dV:(r
+Ż#[
+ TQ]=5܀AKy= P]NsxHN6ޟ@ѻVycCO> b W y,䏠,%M4?b
+,!a{gNLA۪sA`Ͱ8hqF5δ_Akx3{b\+
+|v*VD2#|̲SKG|xx[4{Le
+kFh۳HՉ: .8|+tW;rd9 C'p$ =u;p KzH :#8܍ʘ/ ݊_lKP$> yM>Ŕ05EF5 &4-C}d}G ֮F DX dvt~I=Y5^ԬCbx0EL__ne^UԥMM3Y]LcY(CM]rW "q|C!خYnaGtg5V"/QL\`hGF[a6T
+iE)$a 
+ٌ+>> nxndG5 lh<"R@4nhhC5$ƊEw_lzza' ynxz$xRcT\},2ß@]H3I +C,G#_.@p9.7x>,1ȊZͧ$&Xsuً 'E$GA.+E)I C|Y$8Ωy&xAwFmIΥ7$s|`Ӹ/ERyh!}|H*PMh|9>=퇬<OOz#TPUG1za`@-4i $װi>46(T#n<t;28} q$ZѯTX +5eN -<%Y>j@[UEdc3st^=f 0x L2ygZlWgQGݯZFb읔}Zh )eX#a+ϑ{eӁUVn1{M^/e
+:Ϧ@=M>H59N|*^H9`Qj-9:VE$9s6i\AtCYԚ.QI3s;O|*͆ ' dydtˇI!LkhУ
+endstream endobj 57 0 obj <</Length 8938/Filter[/FlateDecode]>>stream
+Ht9r-9E=nA B@e_ d$IXK5~>\k (XA'?!YMuN֮eLIܟ^;HolH/gudwYdl]u=㵗9mKC߇$&_7y7[ß([x;Nqۗ?_K<%bQ=m K|qY`j-VV|샤1Ƃu aQMCZIO}&rIo܃03L X_56|m0B^_y dB._tڥek܋zՎ`zsA*"ISB.:67%Pi~z]P <wO ߞE;C:VƺIZMZh9t o8KV:zShr/Τt/"TҙIC]pXRd+2d=xTI*,dH3ƥhƎMV_\Z&v}
+ݿ-`(䢻p+Cy.cCTF ݯ0uֲΏ?Td~QxtQhZ YvDm?QpQ8쏗>,P dVv䵑MU(>L6٣Dv3:!i]Wm3<5j? s
+ J%#-@\5;*m!*^ю
+TK
+嚣+xgx>RuZus% eZdi0Yu4ELa.{./+愾"={V)8/*_- \ţ`
+E@*ևeuVlDNL]iIH
+iHzFX4$ :| rouZ>$R+ /R4Yi]{[q,&МP`" O
+,"^\{uSS:#F7XXlUseXPi5#fqj dDdؾlVX*b[VAnD`L4ho-mJyI!h`:<_aLm8i@Ƹdgf_XI+d4nXx zpE:t] 539g05m`_ _€ {x6-"Mbt)<Zr(| ?3:qC^QSo,V0DB\`5۳D>@Rvӓe&XUʋ̔
+f[eM.]>ESBx畉J]-k>RUݹDLƏBxmֳx-n-e~lxX'PZ[-6h^JND1 ⥤EfOQVvj'*Ys=5IGH_P-JsgӔ$z&Wj>o(a)rڰR<p!edDkb+eC(q5TۨC%33/ɫ1$s:ùIBgj_3/x o
+dG P/eKH,Fz^M!)0) Mdm6 !,78 튑¡>-?)eB ?82JDD$g"ZÌ˔HK2Bb`Ag
+%B1BcDNܤ }I~TϖMuF:ۊ)J1EEyE2_uRpG #[s+nslY4u@lSS
+{]dlpLd\R>?-Hnƫ1,L65/qcnW[_zXV#tRVY]d=SR``9O -k(4t>C8gGv]:*rc~gw{vǟ?s?^㋇?N~៟?׿oD*T7'5d*.Z8Aܴ
+_]W?)+M=?i_SV~I^~zw}ܞs{n=ܞs{n{'Xy޷?x~'?wWvlL.p}/{sA^Z>pkO<7b:/3?Msqϗ>|<ep?a^͟oy}㚧xf㫒y'@B>J\<r<!X
+..Q.=7\s{KlG^>=.B)3WɏK; *ϥ}]"KG`1hₑߞ=D_vΰ>ǝEezS~9F3rbe STYɅy1t*4|K}0Oxr|^t>կ<1pQo=+IO 6 S'.XEi|ɦ?ͱC/K9gyc-Cʍ'Ŭ⼸W>/.K~I e;5ǎ-0ifkZ
+ k 6 >S] wvqC9qhpi[ k-ٿ!\YAȇYN ?87?.SMyqq ]:/Sx4"<VҨg|68^3=W#&
+Sa9*bjy$. |h~h5*VT'|r|lyx/zlb,kaJ5\5yH<Ct)84Q{gBO{5~)u\IKhj5tU<DV,p;MJh+^WZ6P,ߐ4.>/f__xvHsrk$O
+  ΰCLɇ3CrYHcF ~|Hշ{Hsѧk7dg>>ee\ǤΕ;}XDcǖ?7 tBמItOpeJܑ?3?mbD]~>SdMUgy{'兯sUR|N~[ʎ'oɅc%Nʋ|tB^8a[/ϴ+IJxŅU<vpqxPɋpN~:qvpa"<E8-<8-/\wҋ‹ '`w^NξVw 偕S k!<cc{Vs!J?Xz d,2GȤ9$5*/U^ԨF5UJLL͞64Ŭh$O;Y?qzNhwrzNI蓜ҽwJJR,fr>ݓLJxnI7S,s&|6=!ڝйKW>/ P8*Ř"N"x!x7mfy%[_M>}2rG a2SLCem%ucAd܊H#2>8JAT~{lc-K#&fYlsߨ#Oqޠ=+E<́۝<O8"OJkk"aKn4eb Iо> lfHqE̬+|\kn˨AP(
+BP(rhכRm=~[]9lV~ulmOXu
+Z hC* x48!9)?.L6C}^xTqk:OENA]enX|
+0
+endstream endobj 264 0 obj <</CreationDate(D:20170201092101-07'00')/Creator(Adobe Illustrator CS3)/Producer(Adobe PDF library 8.00)/ModDate(D:20170201092101-08'00')/Title(Object_Color)>> endobj xref
+0 269
+0000000003 65535 f
+0000000016 00000 n
+0000029802 00000 n
+0000000004 00001 f
+0000000069 00000 f
+0000030065 00000 n
+0002763037 00000 n
+0002763109 00000 n
+0002916893 00000 n
+0003155351 00000 n
+0003224372 00000 n
+0003296326 00000 n
+0003381916 00000 n
+0003488575 00000 n
+0003597058 00000 n
+0003704016 00000 n
+0003756066 00000 n
+0003811639 00000 n
+0002917858 00000 n
+0002978771 00000 n
+0003038908 00000 n
+0003097380 00000 n
+0003168910 00000 n
+0003239952 00000 n
+0003324400 00000 n
+0003428219 00000 n
+0003537057 00000 n
+0003645547 00000 n
+0003870474 00000 n
+0003928584 00000 n
+0003987834 00000 n
+0004048047 00000 n
+0004109563 00000 n
+0004172639 00000 n
+0004235901 00000 n
+0004298008 00000 n
+0004358048 00000 n
+0004417414 00000 n
+0004475678 00000 n
+0004523425 00000 n
+0004557191 00000 n
+0004596248 00000 n
+0004636912 00000 n
+0004679431 00000 n
+0004724172 00000 n
+0004770145 00000 n
+0004826644 00000 n
+0004887786 00000 n
+0004943658 00000 n
+0004994039 00000 n
+0005047966 00000 n
+0005108603 00000 n
+0005169282 00000 n
+0005221169 00000 n
+0005265983 00000 n
+0005305439 00000 n
+0005333011 00000 n
+0005354586 00000 n
+0002764766 00000 n
+0002770836 00000 n
+0002789005 00000 n
+0002805640 00000 n
+0002811587 00000 n
+0002822203 00000 n
+0002844085 00000 n
+0002851618 00000 n
+0002857859 00000 n
+0002877197 00000 n
+0002899258 00000 n
+0000000075 00001 f
+0000030040 00000 n
+0000029853 00000 n
+0000029924 00000 n
+0000029955 00000 n
+0000166683 00000 n
+0000000077 00001 f
+0000171488 00000 n
+0000000079 00001 f
+0001874575 00000 n
+0000000080 00001 f
+0000000081 00001 f
+0000000082 00001 f
+0000000083 00001 f
+0000000084 00001 f
+0000000085 00001 f
+0000000086 00001 f
+0000000087 00001 f
+0000000088 00001 f
+0000000089 00001 f
+0000000090 00001 f
+0000000091 00001 f
+0000000092 00001 f
+0000000093 00001 f
+0000000094 00001 f
+0000000095 00001 f
+0000000096 00001 f
+0000000097 00001 f
+0000000098 00001 f
+0000000099 00001 f
+0000000100 00001 f
+0000000101 00001 f
+0000000102 00001 f
+0000000103 00001 f
+0000000104 00001 f
+0000000105 00001 f
+0000000106 00001 f
+0000000107 00001 f
+0000000108 00001 f
+0000000109 00001 f
+0000000110 00001 f
+0000000111 00001 f
+0000000112 00001 f
+0000000113 00001 f
+0000000114 00001 f
+0000000115 00001 f
+0000000116 00001 f
+0000000117 00001 f
+0000000118 00001 f
+0000000119 00001 f
+0000000120 00001 f
+0000000121 00001 f
+0000000122 00001 f
+0000000123 00001 f
+0000000124 00001 f
+0000000125 00001 f
+0000000126 00001 f
+0000000127 00001 f
+0000000128 00001 f
+0000000129 00001 f
+0000000130 00001 f
+0000000131 00001 f
+0000000132 00001 f
+0000000133 00001 f
+0000000134 00001 f
+0000000135 00001 f
+0000000136 00001 f
+0000000137 00001 f
+0000000138 00001 f
+0000000139 00001 f
+0000000140 00001 f
+0000000141 00001 f
+0000000142 00001 f
+0000000143 00001 f
+0000000144 00001 f
+0000000145 00001 f
+0000000146 00001 f
+0000000147 00001 f
+0000000148 00001 f
+0000000149 00001 f
+0000000150 00001 f
+0000000151 00001 f
+0000000152 00001 f
+0000000153 00001 f
+0000000154 00001 f
+0000000155 00001 f
+0000000156 00001 f
+0000000157 00001 f
+0000000158 00001 f
+0000000159 00001 f
+0000000160 00001 f
+0000000161 00001 f
+0000000162 00001 f
+0000000163 00001 f
+0000000164 00001 f
+0000000165 00001 f
+0000000166 00001 f
+0000000167 00001 f
+0000000168 00001 f
+0000000169 00001 f
+0000000170 00001 f
+0000000171 00001 f
+0000000172 00001 f
+0000000173 00001 f
+0000000175 00001 f
+0000166908 00000 n
+0000000176 00001 f
+0000000177 00001 f
+0000000178 00001 f
+0000000179 00001 f
+0000000180 00001 f
+0000000181 00001 f
+0000000182 00001 f
+0000000183 00001 f
+0000000184 00001 f
+0000000185 00001 f
+0000000186 00001 f
+0000000187 00001 f
+0000000188 00001 f
+0000000189 00001 f
+0000000190 00001 f
+0000000191 00001 f
+0000000192 00001 f
+0000000193 00001 f
+0000000194 00001 f
+0000000195 00001 f
+0000000196 00001 f
+0000000197 00001 f
+0000000198 00001 f
+0000000199 00001 f
+0000000200 00001 f
+0000000201 00001 f
+0000000202 00001 f
+0000000203 00001 f
+0000000204 00001 f
+0000000205 00001 f
+0000000206 00001 f
+0000000207 00001 f
+0000000208 00001 f
+0000000209 00001 f
+0000000210 00001 f
+0000000211 00001 f
+0000000212 00001 f
+0000000213 00001 f
+0000000214 00001 f
+0000000215 00001 f
+0000000216 00001 f
+0000000217 00001 f
+0000000218 00001 f
+0000000219 00001 f
+0000000220 00001 f
+0000000221 00001 f
+0000000222 00001 f
+0000000223 00001 f
+0000000224 00001 f
+0000000225 00001 f
+0000000226 00001 f
+0000000227 00001 f
+0000000228 00001 f
+0000000229 00001 f
+0000000230 00001 f
+0000000231 00001 f
+0000000232 00001 f
+0000000233 00001 f
+0000000234 00001 f
+0000000235 00001 f
+0000000236 00001 f
+0000000237 00001 f
+0000000238 00001 f
+0000000239 00001 f
+0000000240 00001 f
+0000000241 00001 f
+0000000242 00001 f
+0000000243 00001 f
+0000000244 00001 f
+0000000245 00001 f
+0000000246 00001 f
+0000000247 00001 f
+0000000248 00001 f
+0000000249 00001 f
+0000000250 00001 f
+0000000251 00001 f
+0000000252 00001 f
+0000000254 00001 f
+0000166796 00000 n
+0000000255 00001 f
+0000000256 00001 f
+0000000257 00001 f
+0000000258 00001 f
+0000000259 00001 f
+0000000260 00001 f
+0000000261 00001 f
+0000000262 00001 f
+0000000000 00001 f
+0000030576 00000 n
+0005363597 00000 n
+0002762472 00000 n
+0002762522 00000 n
+0000164414 00000 n
+0000000149 00000 n
+trailer
+<</Size 269/Root 1 0 R/Info 264 0 R/ID[<BF63AF5DF1259E47BE535151DEBBDFB8><93D0B8007939374990F08E7B49885071>]>>
+startxref
+5363774
+%%EOF
diff --git a/doc/colormanage/figures/architecture.pdf b/doc/colormanage/figures/architecture.pdf
new file mode 100644
index 00000000..7576d68d
--- /dev/null
+++ b/doc/colormanage/figures/architecture.pdf
Binary files differ
diff --git a/doc/colormanage/figures/des_profile_intent.pdf b/doc/colormanage/figures/des_profile_intent.pdf
new file mode 100644
index 00000000..b11c8053
--- /dev/null
+++ b/doc/colormanage/figures/des_profile_intent.pdf
Binary files differ
diff --git a/doc/colormanage/figures/destination_profile.pdf b/doc/colormanage/figures/destination_profile.pdf
new file mode 100644
index 00000000..a6e67870
--- /dev/null
+++ b/doc/colormanage/figures/destination_profile.pdf
Binary files differ
diff --git a/doc/colormanage/figures/ghostscriptR_stack_RGBclr_CS6.pdf b/doc/colormanage/figures/ghostscriptR_stack_RGBclr_CS6.pdf
new file mode 100644
index 00000000..ef8209b9
--- /dev/null
+++ b/doc/colormanage/figures/ghostscriptR_stack_RGBclr_CS6.pdf
@@ -0,0 +1,445 @@
+%PDF-1.5 %
+1 0 obj <</Metadata 24 0 R/Pages 2 0 R/OCProperties<</D<</RBGroups[]/ON[14 0 R]/Order 13 0 R>>/OCGs[14 0 R]>>/Type/Catalog>> endobj 24 0 obj <</Subtype/XML/Length 20182/Type/Metadata>>stream
+<?xpacket begin="" id="W5M0MpCehiHzreSzNTczkc9d"?>
+<x:xmpmeta xmlns:x="adobe:ns:meta/" x:xmptk="Adobe XMP Core 4.1-c036 46.277092, Fri Feb 23 2007 14:17:08 ">
+ <rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#">
+ <rdf:Description rdf:about=""
+ xmlns:dc="http://purl.org/dc/elements/1.1/">
+ <dc:format>application/pdf</dc:format>
+ <dc:title>
+ <rdf:Alt>
+ <rdf:li xml:lang="x-default">ghostscriptR_stack_RGBclr_CS6</rdf:li>
+ </rdf:Alt>
+ </dc:title>
+ </rdf:Description>
+ <rdf:Description rdf:about=""
+ xmlns:xap="http://ns.adobe.com/xap/1.0/"
+ xmlns:xapGImg="http://ns.adobe.com/xap/1.0/g/img/">
+ <xap:CreatorTool>Adobe Illustrator CS3</xap:CreatorTool>
+ <xap:CreateDate>2017-01-06T15:33:21-07:00</xap:CreateDate>
+ <xap:ModifyDate>2017-01-06T15:33:21-08:00</xap:ModifyDate>
+ <xap:MetadataDate>2017-01-06T15:33:21-08:00</xap:MetadataDate>
+ <xap:Thumbnails>
+ <rdf:Alt>
+ <rdf:li rdf:parseType="Resource">
+ <xapGImg:width>244</xapGImg:width>
+ <xapGImg:height>256</xapGImg:height>
+ <xapGImg:format>JPEG</xapGImg:format>
+ <xapGImg:image>/9j/4AAQSkZJRgABAgEASABIAAD/7QAsUGhvdG9zaG9wIDMuMAA4QklNA+0AAAAAABAASAAAAAEA&#xA;AQBIAAAAAQAB/+4ADkFkb2JlAGTAAAAAAf/bAIQABgQEBAUEBgUFBgkGBQYJCwgGBggLDAoKCwoK&#xA;DBAMDAwMDAwQDA4PEA8ODBMTFBQTExwbGxscHx8fHx8fHx8fHwEHBwcNDA0YEBAYGhURFRofHx8f&#xA;Hx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8fHx8f/8AAEQgBAAD0AwER&#xA;AAIRAQMRAf/EAaIAAAAHAQEBAQEAAAAAAAAAAAQFAwIGAQAHCAkKCwEAAgIDAQEBAQEAAAAAAAAA&#xA;AQACAwQFBgcICQoLEAACAQMDAgQCBgcDBAIGAnMBAgMRBAAFIRIxQVEGE2EicYEUMpGhBxWxQiPB&#xA;UtHhMxZi8CRygvElQzRTkqKyY3PCNUQnk6OzNhdUZHTD0uIIJoMJChgZhJRFRqS0VtNVKBry4/PE&#xA;1OT0ZXWFlaW1xdXl9WZ2hpamtsbW5vY3R1dnd4eXp7fH1+f3OEhYaHiImKi4yNjo+Ck5SVlpeYmZ&#xA;qbnJ2en5KjpKWmp6ipqqusra6voRAAICAQIDBQUEBQYECAMDbQEAAhEDBCESMUEFURNhIgZxgZEy&#xA;obHwFMHR4SNCFVJicvEzJDRDghaSUyWiY7LCB3PSNeJEgxdUkwgJChgZJjZFGidkdFU38qOzwygp&#xA;0+PzhJSktMTU5PRldYWVpbXF1eX1RlZmdoaWprbG1ub2R1dnd4eXp7fH1+f3OEhYaHiImKi4yNjo&#xA;+DlJWWl5iZmpucnZ6fkqOkpaanqKmqq6ytrq+v/aAAwDAQACEQMRAD8A9U4q7FXYq7FXYq7FXYq7&#xA;FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7F&#xA;XYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FX&#xA;Yq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXY&#xA;q7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq&#xA;7FXYq7FXYq7FXYq7FXYq7FXYq7FUl85avq+j+Wb/AFPSbAalfWkfqpZluAdFIMm/WqpyIA3PTFWD&#xA;afrejfnL5YV9K1a/8uarpsqyTR2kvCWGVlIUsV4mSI78SCu47Yqw2+/MT81Pyr1qDT/N5HmPQJyf&#xA;quoU4ysgO/GWn94o3KSV/wBam+KvcfLPmbRvMui2+saROJ7K4Gx6MjD7SOv7LL3GKppirsVdirsV&#xA;dirsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVdiqS6z518oaIxTVtZs7KResM08aybeE&#xA;deZ+7FWKXn/OQf5T2zFRrJncdRDb3DD/AIIxhT9+KpbL/wA5Nfliicle9kP8q29D/wAMyjFUNL/z&#xA;lJ+XCLyW21OQ/wAqwRA/8NMoxVivnD/nKa1u9KurLy5pM8VxcxvEl7eMimIOKcxFGZOTUO1XoD44&#xA;qgv+cUtF1f8AT+ra16bLpAtDaGU7K9w0scgC/wAxREavhUeOKvXPzw0S01b8sdbW4UF7KH67bSEb&#xA;pJb/AB1H+svJfkcVeIf84xeb7jTvOUnl2SQmx1mNzHGTstzAhkVh2HKNWU+Pw+GKvqrFXYq7FXYq&#xA;7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXnH5l/nh5Y8lF7FB+lNdA/3ghYKsVdwZ5K&#xA;Hh/qgFvYA1xV83+bvzo/MLzO7rdam9nZNUfUbEtBFQ9m4nm/+zY4qwcmu564q1iqrbWt1dTLDawv&#xA;PM32YolLsfkqgnFWb+XvyP8AzN1xkMOjS2UDUrcX9LZQD34yUkI/1UOKvXfJ3/OLOkWkiXPmq/Oo&#xA;yKQfqNryigqD0eQ/vHHyCYq9v07TrDTbKKx0+3jtbOBeENvCoRFA7ADFXjf/ADkd+ZunafoE/lDT&#xA;5lm1bUQq3wQ1+r29QxD0/bkpQL/LU+FVXhn5P3EVv+Zvl2WWVYYxdqGkZgoHJStCTTrWmKvt/FXY&#xA;q7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq8n/Pj82pPJ+mx6Ro8gHmDUULLJsfq0&#xA;Bqvq0/nYghK+BPbFXyVNNLNK80ztJLIxeSRyWZmY1LMTuSTiqzFU28s+V9c8zatFpWi2rXV5LuQN&#xA;lRAQC8jHZVFdycVfSHkj/nGPyvpsUdz5nlbWL6lWtkZorRD4fDxkkp4kgH+XFXrel6LoWiWhh0yy&#xA;t9OtUFWWCNIlovduIH3nEBSVDQfNfl/X/rP6HvFvBZuI7hkVwAxrShYKGBp1WozIz6XJirjFW4+D&#xA;VY8t8BukyuLi3treS4uJFht4VMksshCoiKKszMdgAMx3IfN/5n/85KXl082leSybW1BKSaww/fSD&#xA;ofQU/wB2v+Ufi8OOKvBpppp5XmmdpZpGLSSOSzMxNSWJ3JOKrMVfRn/OP/5z3FxPb+TfMUxkdh6e&#xA;j38h+IkdLeRj12/uz/sfDFX0JirsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVdir4U/M&#xA;fzJP5k876xq0jlkmuXS2B/ZgiPpwr/wCivvirGsVdir7A/5x48o2Wi/l9aakIx+kdbH1m6mI+L0w&#xA;zCFAf5QnxfMnFV/56+b9T0PRbGy02d7W41KSTncxEq6xQBSwVhQqWMi7jtm77E0kcszKQsR6e90n&#xA;berligIxNGXX3IfzZq+qSfkTbXaTPNPc2lrHeXJNXKOypIWbqeR+FvnktLiiNeRVAE0w1WWZ0AN2&#xA;SI2Wv+cdYYB5V1GYU9d74pJvvwSGMpt83bD7QE+LEdOH9JX2fA8KR68X6Ar/APOR76kv5W3v1MkR&#xA;Ge3F8VrX0C/t29ThXNC758fYq7FXYqq21xPbXEVzbuYp4HWSGVTRldDyVgfEEYq+9fKWstrflfSd&#xA;YYBX1CzguJFHQPJGGYD5MTiqbYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FX563tpN&#xA;Z3k9pOOM1vI8Uq+DIxVh94xVRxV2Kvtj8k9Vg1L8r9AkiIJt7f6rKo6q9uxjIPzCg/Tiqr+aXkNv&#xA;N+hJDbOsepWTmWzZ9lbkKPGx7BqDfxAzY9ma78vks/Sebre09D+Yx0PqHJJvyt0fzIPLd/5U82aW&#xA;0enRAx20khUh45S3OMFSa8W+JWHj7DMntPNj8SOXDL1dfg43ZmHL4UsOaPp6fFOPIP5br5NvdRa1&#xA;1KS6sL3h6drIgVoyhNGLhqMaNTZVzH13aH5iMbjUo9XJ0HZ35eUqlcZdGWajp9lqVhcWF9CtxZ3U&#xA;bRXEL/ZZHFGBzWuyfIn5tfkprHku5kv7EPfeW5G/d3QFXgqdo5wPuD9D7HbFXmWKuxV2KvvPyFpk&#xA;2l+SdB06cET2thbRzKe0giXmPoauKp7irsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVf&#xA;Jn/ORf5eXGg+a5PMNrETo+tyGQuo2iuyOUqNT/fm8i+O/hiryLFXYq9Q/JL83m8kahJp+pBpfLt+&#xA;4afiCz28tOPrIo+0CAA69aAU6UKr620zVNO1Sxhv9NuY7uynXlDcQsHRh8x+OKqt5DJPaTwRTNby&#xA;yxsiXCAFo2ZSA6hgRVeorkoEAgkWxmCQQDT5217zD+aPkHzCbW71ea8jb97A9wxngniJ6hZCxTwK&#xA;ggj7jnX4NPpdVjsRA92xDx+fUarSZKMiffuC9j/Lnz9a+cdHa5WP6vf2pWO+tgaqrMCVdD14vQ0r&#xA;7j3zne0NCdPOucTyL0fZ+uGohfKQ5hlFxbwXMElvcRrNBMpSWKRQyOrCjKymoII6g5gOe+P/AM+f&#xA;y2tPJnmaGXTBw0fV1ea0hO/pSRkCWIE9VHNSvsadq4q8yxV6P+Rv5dz+bvN8E9xETomlOtxfyEfC&#xA;7Kaxwe5cjf8Aya+2KvsnFXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FUDrmh6Vrul&#xA;XGlarbrdWN0vCaF/wIPVWU7gjcHFXyz+ZX/OPXmXy5LLf6BHJrGiVLBYxyuoV8JI13cD+ZB8wMVe&#xA;SEEEgihGxBxVrFWV+QfzK8z+SdRFxpU5a0dgbvTpSTBMPdf2W8GG/wBG2Kvs7yl5lsPM/lyw16xB&#xA;W2v4+ao1OSMpKOhptVHUr9GKsA/5yE0ee80HTLy3geeW2umiPpqWYLMnt2LRqM33YOYRySBNWPud&#xA;D2/hMscSBdH71X8iPKGq6JpN9qOpRPbS6m0QhtpAVdY4eVGZT05GTYHsPfI9t6uGSYjE3w3v72XY&#xA;eknigZSFcVbe56Vf39jp9pLeX1xHa2kCl5p5mCIqjuzNQDNG7x8gfnn+Zlr538yQDTeR0XSkeKyk&#xA;cFWleQgyy8TuobgoUHeg96Yqp/lv+SPmrzlNHcyxtpmhVBfUJ0IMi+ECGhkJ/m+z79sVfWXlTyno&#xA;nlXRYdH0aD0bSHdmNDJI5+1JI1BydvH6BQbYqnGKuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2Ku&#xA;xV2KuxV2KsV88/mb5R8lWwk1m6/0p1LQafCA9xJ8kqAo/wApiB74q8B81/8AOUHnHUHeLy/bw6Na&#xA;nZJSBcXJHiWcemK+ATbxxV5Fquranq19Lf6ncyXd5MayzysWY/ScVQ8MM00ixQo0krmixoCzE+wG&#xA;+Ksy8s/k5+YvmGeNbXRp7a3cit5eq1tCq/zVkAZh/qA4q+vfInlSHyn5S03y/FKZxYxsHmIpzkkd&#xA;pZGA7Au5oPDFU+xVI/OM3nCLSK+Ure1uNWaRV43zMsSxEHk/wlSSDSgxV5PqP5H/AJk+cLhJvPPm&#xA;5DCh5LY2SM8S+yqRbxq1P2uLH54qzLyn+RH5deW3SeOwOpXqUK3WoETEEb1WOixDfoeFffFXoQAA&#xA;oOmKuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxVhH5vfmInkfynJfwhZNVum+r6&#xA;ZC+6+oRVpGHXjGu596Dvir4w1TVNR1XUJ9R1G4e6vbli888hqzMf89h2xVC4qm/lO78v2nmOwufM&#xA;VpJfaLFJW9tYjxd0oaU3WtGoSKivSuKvrbyj+Zn5Lm2SHQ9Q07SUIA+rui2BHeh9RY1P0E4qzez1&#xA;rR76n1K+t7qvT0ZUkr/wJOKozFXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7F&#xA;XYq7FXYq7FXzn/zlt6/1jyzWv1fhecfDnWGv00pir57xV2KuxV2KuxVF2+q6pbU+r3k8NBxHpyOm&#xA;3hsRtiqNj84+bo0CR65qCIOirdTAD6A2KoyL8yvzEiYMvmfVajYBr24YfczkYqmtl+d/5q2dPS8w&#xA;zvTb9+sU/wDydR8VZRpP/OUX5hWpVb6Cx1GP9ovE0Uh+TRMqj/gMVeheXf8AnKjyleMkWuadc6U7&#xA;bGaMi6hHueIST7kOKvW9B8y+X/MFp9b0XUIL+3/aaFwxUns6/aQ+zAYqmWKuxV2KuxV2KuxV2Kux&#xA;V2KuxV2KuxV2KuxV2KuxV2KuxVhH5vfl2vnjym9hCyx6pav9Y02V9l9QAgxseyyKafOh7Yq+MdV0&#xA;nUtJ1CbTtTtpLS9t24TQSrxZT/EHqCNj2xVCYq7FXYq7FXYq7FXYq7FXYq7FUfouu6xoeoR6hpF5&#xA;LY3sX2JoWKmncHsynuDscVfT/wCTn582/mqSLQvMAS118ilvcJ8MN1QdAP2Jafs9D2p9nFXsWKux&#xA;V2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxVjvm/wDL7yj5uthDrunpcSIKQ3S/BPH/AKkq&#xA;0alf2Tt7Yq8Y8xf84nvyaTy5rY4mvC21BCCPnNCDX/kVirAdT/5x4/NWxJ4aWl7GP92W08LD/gXa&#xA;N/8AhcVY7d/lj+YtoT6/lrUqLUsyWssigDxZFYYqlkvlbzPE/CXSL2N+vFreUH7iuKoQ6bqINDaz&#xA;V/4xt/TFVCSOSNykilHHVWFCPoOKrcVdirsVdirsVVIJ5reeOeCRop4WEkUqEqyupqrKRuCD0xV9&#xA;y/ln5pfzT5G0jW5afWbiHhd0oP38LGKU0HQM6FgPA4qyfFXYq7FXYq7FXYq7FXYq7FXYq7FXYq7F&#xA;XYq7FXYq89/MT87vKPkqVrGUvqWsgVOn2xH7uoqvrSH4Ur4bt3pTFXjmp/8AOVfnWaU/o/TLCzhr&#xA;VVkEs8gHgX5xqf8AgMVUtB/Pz859Z1GOx0q2g1K7fpbR2hbbpybgy8VFdyTTFXvP5eX/AOZ93FcH&#xA;zxptjp5Cp9U+ptydjvz9UCWZR26HFWXySRxRtJK4SNAWd2ICgDqST0xVi8/5rfltBcehJ5k0/wBS&#xA;pB4zo6gjxZSVH34qm+k+Z/Lesj/cTqtpf7VItp45SB7hGJH04qmbKrKVYAqRQg7gg4qgLny/oN0K&#xA;XWm2s4pSksEb7dafEpxVIdS/KT8tNSUi58t2K8urW8QtmP8AsoPTOKvOfN//ADi15eubeSfyteS2&#xA;F4ATHaXLetbsf5edPVT5kt8sVfNN/Y3VhfXFjdxmK7tJXguIj1SSNirqaeDCmKqGKuxV9m/kDp9x&#xA;Y/lToq3ClHnE1wqkUPCWZ2Q/7JKN9OKvQ8VdirsVdirsVdirsVdirsVdirsVdirsVdirsVSDz95i&#xA;fy55M1jW46Geytne35Co9ZvgiqPDmwrir4Turq4u7mW6uZGmuJ3aSaZyWZ3c1ZmJ6kk4qpYq+xP+&#xA;cevLGnaR+XNhfQorX2rhrm7uAPiPxssaV60RQNvGuKvTMVfPX/OV2uaxD+hdGileLS7pJZ7hFJCz&#xA;SRsoVX/mCVrTxNfDFXkP5awfl3NrzJ55nuINOKfuGgB4erUf3xQNIFp/KOvU0xV9B+Xvyy/IS4vL&#xA;TUdCvIZbi1mSeL0dRLtyjPMK6Fyw6bigOKvYAQRUdMVdiqXap5k8vaSjPqmp2tiq9TcTRxf8TIxV&#xA;5f54/wCclfJ+k20sHl0nWtToRG6qyWqN4u7cWenWiDf+YYq+WNQv7rUL+5v7tzLd3crz3Ep6tJKx&#xA;d228WOKofFXoP5SflNqvnjV0klje38vWzg398QQHpuYYSftSN3/lG57AqvpfyZ5+s9c81av5d0Sy&#xA;Q6B5ehigXU43/dmYfB6MaAUKKFajBv2e4IOKs4xV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxVI&#xA;vPflw+ZPJ2r6GpCy3tu6QMdgJR8cRPtzUVxV8JXdpc2d3NaXUTQ3Nu7RTwuKMjoeLKw8QRiqjir3&#xA;v/nH/wDObTdHsl8peY5xbWauzaXfybRx+oxZoZW/ZXkSysdhU17Yq+lEdHRXRgyMAVYGoIO4IIxV&#xA;jH5h/l7ovnnQjpmpFoZY29SyvYwDJDJSlRX7Snoy9/Y0IVfLXm/8iPzD8uSyMuntqtgpPC8sAZqr&#xA;4tEP3qUHX4ae+KvP5YZYZGilRo5ENHRwVYHwIOKrorq6hUrDM8ak1IRior9BxVe1/fMpVrmVlYUZ&#xA;S7EEHsd8VQ+Komy07UL+X0rG1lupf99wRtI2/soJxVnPl/8AIb8z9aZSNIbToG6z6gwtwvzjNZvu&#xA;TFXqGjf84+eRPKVp+mfP2sR3McW/olvq1ry68a19WU+AFK+BxVK/NX5ual5slh8g/ldYNa2M/wC4&#xA;FzEvoO0Q+0I1FBBDTdmO9P5e6r2r8t/Idh5J8r2+j2xEtxX1b+6pQzTsByb/AFRTio8B44qyjFXY&#xA;q7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq8m/N/wDIqx84u+s6O6WPmPiBIXqIbkKKASUqVcAU&#xA;Dgex8Qq+X/MnlPzH5avmsdcsJbGcEhfUX4HA7xyCqOPdScVSjFWYeTvzZ89+UlWHStRZrFT/ALwX&#xA;I9aD5Krbp/sCMVet6F/zllEUVNe0Fg4+3PYSgg/KGWlP+RhxVmen/wDOSf5WXSgz3dzYk9RcW0jE&#xA;fP0PWxVG3P5rfklrKhb7U9PvF47LeW7EU8P30X4Yqk9xf/8AOMtxy9RdDXlSvpwrF08PTRafRiqE&#xA;a8/5xdtXVyulMTWgEUsw+kBXH34qs/5WX/zjZpYDWNhZSyLuGt9KIeta/blijPX3xVC3v/OU/k6y&#xA;h9HRNBuplQURJDDaR7eHAz0H+xxVgnmD/nJ7z/qAaPS4rXR4j9l409eYV8Xl5J90YxVCeXfyn/NL&#xA;8xb9NT1ua4t7N+up6mXLlOtIIWIdh4Uovvir6G8r+RfLH5b+WL2bSbVp7mC3knvLt6G4uDChfjyp&#xA;8K7fCo2+nfFWC6Z+ZvnxNbaS9nt7nT4fq0l1CiKkbR3clrHwtfhWRmT66KN6j/ZHIDmuKvb8Vdir&#xA;sVdirsVdirsVdirsVdirsVdirsVdirsVdirsVQ2paXpup2j2epWkN7aP9uC4RZUPzVgRirzPzD/z&#xA;jZ+W+qM8tnFcaRM1TW0krHU+McokAHsvHFWA6r/ziZq6EnSdft5x2S6heGngOUZmr92KsZvf+cZ/&#xA;zPt2Iiis7wV+1DcADv8A7+WI4qlE35B/m3DTloDtWtOFxav0/wBWU0+nFULL+S35pxvxby5dE/5P&#xA;puPvViMVXRfkj+asqkr5duAAafG0SH7mcYqj7b/nHr82p6FtFWFSKhpbq1HX2WRm/DFU+0//AJxZ&#xA;8/zkG8vNPs07gySyuPoWPj/w2Ksy0X/nE/Q4mV9a1y4uwDUxWsSW4+RZzOSPoGKvTfLH5VeQPLLJ&#xA;JpWjwrdJQi8mBnnBHdXlLFf9jTFWWYq4gEEEVB2IOKsYsfy08mWN/BeW9iwNpK1xZWzzTSW1vM9C&#xA;0kNu7tFG2wpxX4e1MVZPirsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVdi&#xA;rsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVeW/wDOOk0svki+aV2k&#xA;YatdgFiSaUj23xV6lirsVdirsVdirsVY15M86weZ5tcjhtjbroupT6YX5iQSmA09VaAUDeG+Kslx&#xA;V2KuxV2KuxV2KsO8w6T51uPzA8vX+mXbReW7VJRrFsJiiyMytwrF+3QkYqzHFXYqtmlSKJ5X+xGp&#xA;ZqeAFTiqQ+QvNsfm7ynY+Yo7Y2aX3q0t2cSFfSmeH7QC1r6demKsgxV2KuxV2KuxV2KuxV2KuxVh&#xA;f5seerzyh5biudNt1utX1G5jsNNhk+x60oJ5MAVqAF6V60xVIX8sfn4lkbxPOdnJfhef6L+oQCAt&#xA;Svp+vx507Vpiqj+RdzqXmT9Med9bujNrV1N+i2tEUxw2sVrR/SRKnqZeRr/E4qwv8nj+aOo6Bf6X&#xA;5VltdG0yLUbiS41y6T15HkfiPSgiYMh4KoLFh364qyt/Nf5meQ/M2k2nnS/t9e8u63OLSPU4YUt5&#xA;beZiAvNI1Rab1I32rQ7UKrI/zP8APus6HdaR5d8s2sd35n1+RktPXr6MMaU5yuBStK7fIk9KFVJb&#xA;7Rv+cgdKsW1SDzPZa3cW6mWTRmsookkC7lI5UVHY+G61xVOdO/NuwvPyqn89i2Ia1hf6xYhul0jC&#xA;P0+VD8LOykGn2TXFUk0fT/z413R7fXh5psdLkvo1ubbR1sYpIRHIvONXmZXlWoIrTlTxxVkGk6l+&#xA;YnmTybMhjXyv5qtblraaaaD1reX0TRpIFetY5OgbfvSuKvK/yf0r80r638wy6D5htLADVphfie1W&#xA;Uy3NAXkWqniD4Yq9G89+b/OOnXvlryboLW8nmvXI29fUp1pBEtvHymlWOlKtxZgKGgFKGoxVBX0X&#xA;54eVY49Wk1aHzlZRsgvdJjsktrngzBS1v6C1dhXv92Kp3+Z/5hXvlnS9Ng0iz+teY9fmW10mzm2A&#xA;duPJpACPsF1FK9T1piqSvoX/ADkFZ2n6RTzPp+pXkY9RtEezijgem5jSdVjk9hXj88VVPOv5jeYb&#xA;f8nP8XWFrLousOYA1rdxVaNmmEcg4SrurblWI3FDiqAs7/8AO3zmjeYfL2oWXl7QZWY6RY3UIklu&#xA;IAaLNOxjlZA43HH7u5VTrzT5v8w6b+anlDy7b3CjTdVima/j9NKu0asQQxBZd17HFUo86+fPzDs/&#xA;zUj8qeWIYLwXemrLBBchViilZ25XEjgcyqIn2a9fuxVZrtn+f3l/S5teXzHY6yLJGuLvR/qcUSGN&#xA;PicRyKiyPRa/tKfmcVTPW/MPmDzf+VcXmbyvqEekq9ncT6hBNEs/NYkZZoFY/ZKsjUam+KsT/JfR&#xA;fzTn8i6Hc6R5is7TQS8xSwktVklCLdyCVfUKk/EwYjwrir3jFXYq7FXYq7FXYq7FXYq7FXk//ORL&#xA;BNA0K4tZQ2s2erW9zpmnAM8t08dQyRooZiVLqT27dSMVRJ/PjSmtP3XlvXX1Ujium/Um5+rT7PIE&#xA;inLatK+2Ko/8kfKuteXvJsg1qP0dU1W9m1K5t9qxmcIoU02B4xgkdq0xVKv+cb/+UGv/APtr3f8A&#xA;xGPFUP8A85MkjybohHX9OWv/ACYuMVd5s/8AWkfJP/bOuv8Akzd4q9dxV4v+Snl7T/MP5Ta5od8C&#xA;LO+1G8hcpQMvwxlWXtVWAIxVUsrT86vy7s1s7SG386eWrMcbeNSYb+KBOiAGtaDYACT2oNsVeg+Q&#xA;/PejedNDGq6ZzjKOYbu0mFJYZlAJRqbHY1BHX51AVYL/AM46f8c7zX/23Lj/AIiuKsk/Mr8uLnzP&#xA;Lpur6NqTaR5m0VmfTr4DkhD0rHIOvHb36moIOKsb/wCVo+fvJs0EP5j6HGdLkdYR5j0xi8IJ2DSR&#xA;bnfqfsnwU4qq/mfLDcfmV+Vs0TLJDJdXkkbjdWUrbsrA/jir1jFXmf8Azkb/AOSo1P8A4zWv/J9M&#xA;VegaJbxW2jWFvCvGGG2ijjUdlRAAPuGKvLvP3/k+fIH/ABhuv+ISYq66/wDWmrP/ALYZ/wCJSYq9&#xA;U1RFfTLxHAZWgkDKehBQ1GKvIvyo/wDWdbv/AJhNV/XLirIv+cfP/JQ6B/0d/wDUbPir0TFXYq7F&#xA;XYq7FXYq7FXYq7FXkH56Ranp2u+UfMugzK/mW3upLHTdMkQyLcm5Xi21VChQSGNR9obimKpgb3/n&#xA;I8Rcxp/lktQH0w13y37by8fxxVNPy9/MLVtb1fVfLfmTTF0nzLo4SSeGKT1IZYZKFZIzU0+0vc9R&#xA;7gKoD8gdJ1XS/Jt7b6nZT2M76pdSLDcxPC5RgnFgrhTxNNjiqH/5yG0fV9V8p6RBpdjcX88Ws280&#xA;kVrE8zrGsM4LsqBiFBYb4qv/ADW8t+ZIfMvl/wA/eW7P9J32g+pFeaYv97NbSgq3pdasFkcUAJ3B&#xA;ANMVQ19+edzd2L2vl7ynrc3mGVSkNtcWnCOKXpylYM3wqd+nz44qjvJPkXzf5X/KebSNNuo7fzdc&#xA;CS79aTjNHHcyEHgSeSn4FCltxy33GKoSz/O68s7JLPzB5S1qHzFGvCW2trQyxTSqKcopOQ+Fj7H2&#xA;riqYfkv5a13TNP1rWdctvqF/5k1GXUf0d+1BHISVVvBqsduwp3qMVYb5O1vWvy01fzLouqeWdW1K&#xA;G+1CS90290y2M6SrJsoJqoGwXoSQagjFWeeeNe8+6TPpGv6Jp8mp6CqH9NaHHGPrwEgBSRKhmJj7&#xA;ov07bqqw/wA8efLz8wPLlx5R8seWtVN7qbRR3Fzf231e3tkSVZGaR+Tio4U/qdiqm/5l+RPMK6H5&#xA;T1Py2n1/WfJTxNDan4frEKpGsoAruT6C/DWtK03pirUv543dzZm10rydrb+ZHXilhPalIo5SOskt&#xA;a8B1rxH0YqhfzG0Hz1dfkbJp+reprXmiR7d7mOzh5t/vQrcFSBfi9NNmam9CcVesWCsthbKwKssS&#xA;BlOxBCjY4q8187aPq9z+dXkjUbexuJtPtIrgXV5HE7QxFlegkkAKrWvc4qxjzzqmv6X/AM5BWl9o&#xA;em/pe6g0cNNYBwkkkHKT1PTJ/bHUChr0piqceY/zj1PV9HutF8t+UtbPmC9ia3CXdp6UduZQULu3&#xA;Jvsg1FQB4kYqyryX5Bm0T8rY/KM8q/W5bO4iupVNVE13zZ6Gm4QycQadsVYR+VPnDWvKWiWXkfWf&#xA;KmstqNndSQR3NtberamOacyGRpeQ+FfUY1UEcRWuKvbcVdirsVdirsVdirsVdirsVYF+afk/zFrL&#xA;6Frflt4Trfly6a5trW5JWKdZAodCR0PwDuO+4xVBr5+/NgwiL/lXMn137JY6lbCHl05cqfZ+n6cV&#xA;Rv5e+TNfstb1jzd5pkgbzFrYjjNta1MNrbxABYlY/aPwry+XU4qzzFXYq7FXYq7FXYq7FXYq7FXY&#xA;q7FXYq7FXYq7FXnNx5S8wP8AnnbeZ1tK6HHpRtXvPUj2mq54+ny9T9ob8aYq9GxV2KuxV2KuxV2K&#xA;uxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2Ku&#xA;xV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2Kux&#xA;V2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV&#xA;2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2&#xA;KuxV2KuxV2Kv/9k=</xapGImg:image>
+ </rdf:li>
+ </rdf:Alt>
+ </xap:Thumbnails>
+ </rdf:Description>
+ <rdf:Description rdf:about=""
+ xmlns:xapMM="http://ns.adobe.com/xap/1.0/mm/"
+ xmlns:stRef="http://ns.adobe.com/xap/1.0/sType/ResourceRef#">
+ <xapMM:DocumentID>uuid:73E06A7F68D4E6119FDFE0D777902E87</xapMM:DocumentID>
+ <xapMM:InstanceID>uuid:50bcaba0-acc7-43ee-b6a9-770562ba5a29</xapMM:InstanceID>
+ <xapMM:DerivedFrom rdf:parseType="Resource">
+ <stRef:instanceID>uuid:88069d3d-2d9f-684e-9e56-5ae0529e21c4</stRef:instanceID>
+ <stRef:documentID>xmp.did:3de20d8c-84fe-4fe0-b63c-0d79939fe234</stRef:documentID>
+ <stRef:renditionClass>proof:pdf</stRef:renditionClass>
+ </xapMM:DerivedFrom>
+ </rdf:Description>
+ <rdf:Description rdf:about=""
+ xmlns:illustrator="http://ns.adobe.com/illustrator/1.0/">
+ <illustrator:StartupProfile>Print</illustrator:StartupProfile>
+ </rdf:Description>
+ <rdf:Description rdf:about=""
+ xmlns:xapTPg="http://ns.adobe.com/xap/1.0/t/pg/"
+ xmlns:stDim="http://ns.adobe.com/xap/1.0/sType/Dimensions#"
+ xmlns:xapG="http://ns.adobe.com/xap/1.0/g/">
+ <xapTPg:NPages>1</xapTPg:NPages>
+ <xapTPg:HasVisibleTransparency>False</xapTPg:HasVisibleTransparency>
+ <xapTPg:HasVisibleOverprint>False</xapTPg:HasVisibleOverprint>
+ <xapTPg:MaxPageSize rdf:parseType="Resource">
+ <stDim:w>342.000000</stDim:w>
+ <stDim:h>360.000000</stDim:h>
+ <stDim:unit>Points</stDim:unit>
+ </xapTPg:MaxPageSize>
+ <xapTPg:PlateNames>
+ <rdf:Seq>
+ <rdf:li>Cyan</rdf:li>
+ <rdf:li>Magenta</rdf:li>
+ <rdf:li>Yellow</rdf:li>
+ <rdf:li>Black</rdf:li>
+ <rdf:li>PANTONE 2195 C</rdf:li>
+ </rdf:Seq>
+ </xapTPg:PlateNames>
+ <xapTPg:SwatchGroups>
+ <rdf:Seq>
+ <rdf:li rdf:parseType="Resource">
+ <xapG:groupName>Default Swatch Group</xapG:groupName>
+ <xapG:groupType>0</xapG:groupType>
+ <xapG:Colorants>
+ <rdf:Seq>
+ <rdf:li rdf:parseType="Resource">
+ <xapG:swatchName>PANTONE 2195 C</xapG:swatchName>
+ <xapG:type>SPOT</xapG:type>
+ <xapG:tint>100.000000</xapG:tint>
+ <xapG:mode>LAB</xapG:mode>
+ <xapG:L>45.730000</xapG:L>
+ <xapG:A>-11</xapG:A>
+ <xapG:B>-58</xapG:B>
+ </rdf:li>
+ </rdf:Seq>
+ </xapG:Colorants>
+ </rdf:li>
+ </rdf:Seq>
+ </xapTPg:SwatchGroups>
+ </rdf:Description>
+ <rdf:Description rdf:about=""
+ xmlns:pdf="http://ns.adobe.com/pdf/1.3/">
+ <pdf:Producer>Adobe PDF library 8.00</pdf:Producer>
+ </rdf:Description>
+ </rdf:RDF>
+</x:xmpmeta>
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+<?xpacket end="w"?>
+endstream endobj 2 0 obj <</Count 1/Type/Pages/Kids[5 0 R]>> endobj 14 0 obj <</Intent 15 0 R/Usage 16 0 R/Name(Layer 1)/Type/OCG>> endobj 15 0 obj [/View/Design] endobj 16 0 obj <</CreatorInfo<</Subtype/Artwork/Creator(Adobe Illustrator 13.0)>>>> endobj 13 0 obj [14 0 R] endobj 5 0 obj <</Parent 2 0 R/Contents 19 0 R/BleedBox[0.0 0.0 342.0 360.0]/PieceInfo<</Illustrator 6 0 R>>/ArtBox[0.0 0.0 342.0 360.0]/MediaBox[0.0 0.0 342.0 360.0]/Thumb 23 0 R/TrimBox[0.0 0.0 342.0 360.0]/Resources<</ColorSpace<</CS0 18 0 R>>/Properties<</MC0 14 0 R>>/ExtGState<</GS0 17 0 R>>>>/Type/Page/LastModified(D:20170106153321-07'00')>> endobj 19 0 obj <</Length 3853/Filter/FlateDecode>>stream
+Ht͎$ ]׀OaìI`UH:lEuV& ɟ_~9<ґQG:~?}W:~;qBg;.(0oۣ5#y=Βgx{
+E#IQρ"mr
+À0FNb/E-`Q%
+
+D66LŰJPzGEri]6ZUT)-i 7< =^(2kuxpRkSb
+tzU$
++WKb~(K li,os5n^yríI Z'LMtA@%YSAs?c]w/l
+^4wDW-C%eLԣL.W:)z,"%⮞t6UIO5vz E.ߘtƵ|(Ybɥ
+ 744,,_QZb$ʖ
+4-&9qa 4/ĵv8ʘ퉣{$&1m{ǎ-Z _wצ7.T1T#oQ`knK(mTv|i9,Mʼ1fJ
+c96LR^3۾;{D6#j_6^5s@&i3VEXY|-Ǫ}Iy4E/B:1vQ.&b";GTٔu_PI4ѿNɬj8Ib]nlO#v#p7%!ENu^TBISӪkt` Vnw[ц{^ k-S UkZ=hza.=4cP ¯{|aAX`@HځMUsͶPKʉFEz6lSPDdDHscIݓH߈G8>Ko!>E—RF?Yj#V)nR':/ \T/L b0eq8aҵQ3AϼOw_C˶D)u&_
+D8M_h,[J:?t= ^p*ChAv@׌c%J |{Ϥ031ֈi1S
+}],Ђ̰ TNWäDb6sŽ
+endstream endobj 23 0 obj <</Length 196/Filter[/ASCII85Decode/FlateDecode]/BitsPerComponent 8/ColorSpace 21 0 R/Width 42/Height 45>>stream
+8;ZEWbmf1W#R0-$33`V`cb_^]D$qhX=-(M?R.fhVcU?<uPR%[$YpV&tN%3llc=g;/
+?ft7BBWNX.UQPpGI@hi=Uik1)RR3cSI3e+\gp&L%"[f52^]q*e^63pPOHsE0gB;mb
+/lu5&O_A2>.bl6g1[3K3K*RA]2i[u$r]%C<_U(TJrc+-A,#B8cnP@Xm!&mX0;Z~>
+endstream endobj 17 0 obj <</OPM 1/BM/Normal/CA 1.0/OP false/SMask/None/ca 1.0/AIS false/op false/Type/ExtGState/SA true>> endobj 18 0 obj [/Separation/PANTONE#202195#20C/DeviceRGB<</C0[1.0 1.0 1.0]/C1[0.0 0.462738 0.815689]/FunctionType 2/N 1.0/Domain[0 1]/Range[0.0 1.0 0.0 1.0 0.0 1.0]>>] endobj 21 0 obj [/Indexed/DeviceRGB 255 22 0 R] endobj 22 0 obj <</Length 428/Filter[/ASCII85Decode/FlateDecode]>>stream
+8;X]O>EqN@%''O_@%e@?J;%+8(9e>X=MR6S?i^YgA3=].HDXF.R$lIL@"pJ+EP(%0
+b]6ajmNZn*!='OQZeQ^Y*,=]?C.B+\Ulg9dhD*"iC[;*=3`oP1[!S^)?1)IZ4dup`
+E1r!/,*0[*9.aFIR2&b-C#s<Xl5FH@[<=!#6V)uDBXnIr.F>oRZ7Dl%MLY\.?d>Mn
+6%Q2oYfNRF$$+ON<+]RUJmC0I<jlL.oXisZ;SYU[/7#<&37rclQKqeJe#,UF7Rgb1
+VNWFKf>nDZ4OTs0S!saG>GGKUlQ*Q?45:CI&4J'_2j<etJICj7e7nPMb=O6S7UOH<
+PO7r\I.Hu&e0d&E<.')fERr/l+*W,)q^D*ai5<uuLX.7g/>$XKrcYp0n+Xl_nU*O(
+l[$6Nn+Z_Nq0]s7hs]`XX1nZ8&94a\~>
+endstream endobj 6 0 obj <</Private 7 0 R/LastModified(D:20170106153321-07'00')>> endobj 7 0 obj <</RoundtripVersion 13/ContainerVersion 11/CreatorVersion 13/AIMetaData 8 0 R/AIPDFPrivateData1 9 0 R/AIPDFPrivateData2 10 0 R/AIPDFPrivateData3 11 0 R/NumBlock 3>> endobj 8 0 obj <</Length 1014>>stream
+%!PS-Adobe-3.0
+%%Creator: Adobe Illustrator(R) 13.0
+%%AI8_CreatorVersion: 13.0.0
+%%For: (Michael Vrhel) ()
+%%Title: (ghostscriptR_stack_RGBclr_CS6.ai)
+%%CreationDate: 1/6/2017 3:33 PM
+%%BoundingBox: 0 0 342 360
+%%HiResBoundingBox: 0 0 342 360
+%%DocumentProcessColors: Cyan Magenta Yellow Black
+%AI5_FileFormat 9.0
+%AI12_BuildNumber: 406
+%AI3_ColorUsage: Color
+%AI7_ImageSettings: 0
+%%DocumentCustomColors: (PANTONE 2195 C)
+%%RGBCustomColor: 0 0.462745 0.815686 (PANTONE 2195 C)
+%%RGBProcessColor: 0 0 0 ([Registration])
+%AI3_TemplateBox: 171.5 179.5 171.5 179.5
+%AI3_TileBox: -117 -204 459 564
+%AI3_DocumentPreview: None
+%AI5_ArtSize: 342 360
+%AI5_RulerUnits: 2
+%AI9_ColorModel: 1
+%AI5_ArtFlags: 0 0 0 1 0 0 1 0 0
+%AI5_TargetResolution: 800
+%AI5_NumLayers: 1
+%AI9_OpenToView: -720 621 1 1815 938 26 0 0 69 101 0 0 1 1 1 0 1
+%AI5_OpenViewLayers: 7
+%%PageOrigin:-135 -216
+%AI7_GridSettings: 72 8 72 8 1 0 0.8 0.8 0.8 0.9 0.9 0.9
+%AI9_Flatten: 1
+%AI12_CMSettings: 00.MS
+%%EndComments
+
+endstream endobj 9 0 obj <</Length 7339>>stream
+%%BoundingBox: 0 0 342 360
+%%HiResBoundingBox: 0 0 342 360
+%AI7_Thumbnail: 124 128 8
+%%BeginData: 7211 Hex Bytes
+%0000330000660000990000CC0033000033330033660033990033CC0033FF
+%0066000066330066660066990066CC0066FF009900009933009966009999
+%0099CC0099FF00CC0000CC3300CC6600CC9900CCCC00CCFF00FF3300FF66
+%00FF9900FFCC3300003300333300663300993300CC3300FF333300333333
+%3333663333993333CC3333FF3366003366333366663366993366CC3366FF
+%3399003399333399663399993399CC3399FF33CC0033CC3333CC6633CC99
+%33CCCC33CCFF33FF0033FF3333FF6633FF9933FFCC33FFFF660000660033
+%6600666600996600CC6600FF6633006633336633666633996633CC6633FF
+%6666006666336666666666996666CC6666FF669900669933669966669999
+%6699CC6699FF66CC0066CC3366CC6666CC9966CCCC66CCFF66FF0066FF33
+%66FF6666FF9966FFCC66FFFF9900009900339900669900999900CC9900FF
+%9933009933339933669933999933CC9933FF996600996633996666996699
+%9966CC9966FF9999009999339999669999999999CC9999FF99CC0099CC33
+%99CC6699CC9999CCCC99CCFF99FF0099FF3399FF6699FF9999FFCC99FFFF
+%CC0000CC0033CC0066CC0099CC00CCCC00FFCC3300CC3333CC3366CC3399
+%CC33CCCC33FFCC6600CC6633CC6666CC6699CC66CCCC66FFCC9900CC9933
+%CC9966CC9999CC99CCCC99FFCCCC00CCCC33CCCC66CCCC99CCCCCCCCCCFF
+%CCFF00CCFF33CCFF66CCFF99CCFFCCCCFFFFFF0033FF0066FF0099FF00CC
+%FF3300FF3333FF3366FF3399FF33CCFF33FFFF6600FF6633FF6666FF6699
+%FF66CCFF66FFFF9900FF9933FF9966FF9999FF99CCFF99FFFFCC00FFCC33
+%FFCC66FFCC99FFCCCCFFCCFFFFFF33FFFF66FFFF99FFFFCC110000001100
+%000011111111220000002200000022222222440000004400000044444444
+%550000005500000055555555770000007700000077777777880000008800
+%000088888888AA000000AA000000AAAAAAAABB000000BB000000BBBBBBBB
+%DD000000DD000000DDDDDDDDEE000000EE000000EEEEEEEE0000000000FF
+%00FF0000FFFFFF0000FF00FFFFFF00FFFFFF
+%524C45FDFCFFFDFCFFFDFCFFFDFCFFFDFCFFFDFCFFFDFCFFFDFCFFFD27FF
+%7D7D7DFD76FFA8FFFFA82727277DA8FD73FF5227FFFFFFA852F852A8FD72
+%FF7D2727FFFFFFA852F8277DFD72FF27277DFFFFFFA8272752A8FD70FF52
+%27F87DFD04FF5227F87DFD63FFA8FFA8A87DA87DA8FD047DFD04277DFD04
+%FFA8272727FD5EFF7D7D5252FD0627F827F827F827F827F82752FD05FF7D
+%2727277DFD5AFF7D522727F8FD0F27F8277DFD06FF7D2727277DFD57FFA8
+%7D2727F8FD0F27F827277DA8FD07FFFD042752FD56FF5227F8FD0F27F827
+%277D7DFD09FF7DFD04277DFD54FFA8FD0E27F827F852527D7DFD0BFF52FD
+%052752FD53FFA8FD0F27527DA8FD0EFF52FD072752FD51FFA8FD0C27F827
+%52A8FD0FFF7DFD0B27FD50FFFD0C27F852A8FD0FFFA852F8FD0B2752FD4E
+%FFFD0C27F852FD08FFA83636FD05FFA827F8FD0D2752FD4CFFA8FD0C2752
+%FD05FF85A9FFFF5B0E37FD05FF52FD1027A8FD4BFF52F8FD0927F827A8FD
+%04FF610761FFAF0E0E5AFD04FFA8F8FD0F27F87DFD4BFFFD0C2752FD05FF
+%0E0E5AFF850E0E85FD04FFA8FD1227FD4AFF7D27F8FD0927F87DFD04FFA8
+%0E0E5BFFAF0E0E5AFD05FFFD1027F827A8FD49FFA8F8FD0B277DFD05FF0E
+%0E36FFFF610E37FD05FFA8F8FD1027FD4AFF7DFD0B27F87DFD05FF850E0E
+%5AFFFF5A0EAFFD05FF7DF8FD0F27A8FD49FFA8FD0C2752FD06FF850E14A9
+%FD0AFFA8FD0E2752FD4AFFA8FD0B27F852A8FD06FFAF84FD0CFFA8FD0C27
+%F87DFD4BFF52FD0C277DFD0AFF8585A9FD09FF52FD0B27A8FD4BFFA8F8FD
+%0C27A8FD08FF840E0E0E36AFFD08FFFD0A2752FD4DFF52FD0D27A8FD08FF
+%84140E0E0EAFFD07FFA8FD0927FD4EFFA827F8FD0C277DFD08FF5AFD040E
+%FD08FF52F8FD0527F8A8FD4FFFA8FD0D27F852A8FD07FF14140E15AFFD07
+%FF52FD0527F87DFD51FFA852F8FD0B27F8277DFD06FF5B0E0E0EFD07FF7D
+%FD06277DFD54FF7DFD0E27A8FD05FF5A0E0E85FD06FFA852FD0527A8FD56
+%FFA852FD0B27F852FD05FF850E85FD06FF7D27F827F8277DFD5AFF52FD0C
+%27FD0CFFA85227F82727A8FD59FF7D52FD0C27F87DFD0AFF5227F827277D
+%A8FD58FFA87DFD0C27F827277DFD0AFFA85252A8A8FD5AFF7D27F8FD0727
+%F827F827527D7DFD6AFF52FD0A27527DFD6EFFFD0A27F852FD6FFF52FD0C
+%277DFD6DFFA827F8FD0B27F827277D7DFD04A8FD65FF7DF8FD0F27F8FD04
+%27522752527D527D52FD047DFD04A8FD56FF52FD1927F827F827F827F827
+%F8FD042752527D7DFD51FF7DFD2B27527DA8FD4DFF7DFD2B27F827F8527D
+%FD4CFFFD31277DFD4AFF7DF8FD2F27F852A8FD49FF52F8FD31277DFD48FF
+%A852F8FD31277DFD49FFA8FD3227A8FD4AFF7D7D2727F8FD2B27F852FD4D
+%FFA87D5252FD0627F8FD2427A8FD4FFFA8FFA8A87D7D527DFD0452275227
+%52FD0627F827F827F8FD112752FD62FFA8FFA8A87D7D5252FD1027F87DFD
+%46FFA87D7D5252527D527D7DFD1AFFA87D52FD0E2752FD44FF52522727F8
+%272727F827277DFD1DFFA8FD0D277DFD42FFA82727F8FD0527F852A8FD07
+%FFA87D5252527D7DA8A8FD10FFA8F8FD0927F827A8FD42FFFD09277DFD08
+%FF7D272727F8FD04277DFD10FFA8FD0B2752FD42FFFD0827F852FD08FFA8
+%27F827277DA8FFA8A8A8FD0FFFA852FD0B27FFFFA8FD3FFFA8FD09277DFD
+%08FF7DFD04277DFD13FF7DFD0C27A8FF7D27FD3FFFA8F8FD0727F87DFD08
+%FF7D272727F827277D7DA8A8FFA8FFFFFFA8FFFFFFA8A87D52FD0D27A8FF
+%A8F87DFD3FFF7DFD092752FD09FF52FD0527F8FD04275252522752525227
+%52FD0E2752FFFFFF2752FD40FFA8FD0A27A8FD09FF5227F8FD0727F82727
+%27F8FD0D27F827277DA8FFFFA82727A8FD41FF52FD0A27A8FD09FF7D52FD
+%19277D7DFD04FF7DF8277DFD42FFA827F8FD0727F8277DFD0AFFA8525227
+%27F827F827F827F827F827F827F8272752527DA8FD05FF5227F8277DFD44
+%FF7DFD0B2752A8FD0CFFA8A87D7D527D525252FD047DA8A8FD07FFA87D27
+%27F8277DFD46FF7D27F8FD0927F82752A8A8FD1BFF7D7D2727F827F852A8
+%FFFFA852527DFD42FFA852F8FD0C2752527D7DA8A8FD0FFFA8A87D7D5252
+%FD0427F82727A8FD04FF527D527DA8FD43FFA82727F827F8FD0727F827F8
+%27F827275227FD0952FD0627F827F827F827F8527DFD05FFA87D527D52A8
+%FD45FFA87DFD2527527DA8FD08FF7D7D527DFD49FFA87D52272727F827F8
+%FD1327F8FD0427527DA8FD0CFFA8FD50FF7DA87D7D5252FD0F2752527D7D
+%A8A8FD66FFA8FFFD06A87DFD04A8FFA8FDFCFFFDFCFFFD4DFFA852FD39FF
+%A8A8FD3FFF7D27FD39FF2752FD3FFF7D27FD1BFF7D7DFD1CFF52A8FD0CFF
+%7D7DFD31FF7D52FD1BFF5252FD2AFF7D52FD2EFF7D7DFF7D27FD1BFF527D
+%FD2AFF527DFD28FFA8FD042752277DFF7D527D52272752FD04FFA8FD0427
+%7DFFFFFFA852272727A8FFA82727275227A8FFA827272752A8FFFFFF7D52
+%272727FFFFFF52A87D27F8A8FF527DFFA8527D52272727A8FFA827272752
+%27A8FD25FF2752A8FFA82752FFFF7DF8527DFFA85227FFFFFF2752A8FF7D
+%277DFFFF5227FFA87D27A8FFA82752A8A8A8FF2752A8FF7D27A8FFA82752
+%FFA87D27FFFF5227527DA8A8FF277DFFFF272752FFA852F8FFFFA82752A8
+%A8A8FD24FF7D27A8FFFFFF5227FFFF7D27A8FFFFFFA8277DFF5252FD04FF
+%7D27A8A827A8FFFFFF7DA8FFFF5252FFFFFF7D27FD04FF7DA8FF5252FD04
+%FF7DA8FF2727A8FFFFFFA85252FFA8277DFD04FF2752FFFF5252FD27FFA8
+%27FD04FFA827FFFF7D27FD05FF277DFF5252FD04FFA827FFFF277DFD07FF
+%277DFD04FF27A8FD06FF277DFD07FF5252FD05FF277DFFFF27A8FD04FF52
+%52FFFF277DFD27FF7D27A8FFFFFF5227FFFF7D52FD04FFA8277DFF277DFD
+%04FFA827A8FF7D2727A8A8FD04FF5252FD04FF7DF8527DFD04FF527DFD07
+%FF277DFD05FF5252FFA827A8FD04FF7D52FFFF5252FD28FF27527DA85227
+%7DFFFF7D27FD05FF277DFF5252FD04FFA827FFFFFFA87D27277DFFFFFF27
+%7DFD05FFA8522727A8FFFF27A8FD07FF527DFD05FF277DFFA827A8FD04FF
+%5252FFFF527DFD27FF7DFD05527DFFFFFF7D52FD04FFA8277DFF2752FD04
+%FFA827A8FD05FF7D277DFFFF5252FD07FFA87DF8A8FF277DFD07FF277DFD
+%05FF2752FFA8277DFD04FF7D52FFFF5252FD27FF277DFD08FF7D27FD05FF
+%27A8FF5252FD04FFA827FD07FF5252FFFF277DFD09FF527DFF277DFD07FF
+%527DFD05FF277DFFA827FD05FF5252FFFF527DFD27FF5252527D527D7DFF
+%FFFF7D52FD05FF277DFF5227A8FFFFFF5227FFA827FD04FF5252FFFF5252
+%FFFFFFA852A8FFFFFF277DFF5227FFFFFFA8527DFF277DFD05FF5252FFA8
+%277DFFFFFFA8277DFFFF5252FD28FF2752527D525227A8FF7D27FD05FF27
+%7DFFFF27277DA852277DFFFF7D277D7D5227FFFFFF7D27527DA8FF52277D
+%A85252A8FFA827277D7D2752FFFF277DFD05FF277DFFFF2727527D7D2727
+%FFFFFF7D27527DA8FD24FF7D52FD05FF5227FFA87DFD04FFA87DA8FFFFFF
+%52522752A8FD04FF7D275252A8FD04FF7D5252A8FFFF7D52277DA8FFA8FF
+%A87D27527DFFFFFF7DA8FD04FFA87D7DFFA8277D7D275252FD05FF7D5252
+%A8FD24FF5252FD05FF7D52FD40FF27A8FD31FF5227A8FFFFFF7D277DFD3F
+%FFA827A8FD32FF5227275227527DFD40FFA827A8FD33FFFD04A8FD44FFA8
+%FDFCFFFDFCFFFDFCFFFDFCFFFDFCFFFDFCFFFDFCFFFDFAFFFF
+%%EndData
+
+endstream endobj 10 0 obj <</Length 12663/Filter[/FlateDecode]>>stream
+HWko:Xt
+2?>QF2Z#{Q{`|%mRM%2Ts KTj<m`6I6~392ncmm!$YKjW
+hzmtqԔrY3/9h3ld/NLlѷ|I2HG0lˠRj1̱Dv"m+C+T+;CV5͙3Or|o.Bg0L9B'xAk($ѝy3'lFt[zNj;nHV7x
+cOn/u俄9kA7/_ԼXQbNCbb)PWcAbyj;ݦiW`t90^l
+ZF9AJK;{@f>E3h+M}DOH[::?UlBG9`u#墷)1(fIOGW1q Lu8
+qǣ}% 1* y &&W|*k3Ju!mESSvL!(+apn<\8vGGCNgt~m<>aGQs;ZNb7^\(KoϞ,cye#BwIO8dIPwE<aj.d.$]*6!E<olnٍ鲍%up~VɤIr[٣r;LyT^L}
+*qU-44i5LgGG+Ԃa$>'EPkgylpܶr,3&etV'3h?+8|zj˶;[aDmT,9p6zm :hxbB1`~]=-} ܫV,,s3T{lUwFH&pAkwߏвQ 47>oO4zM۝?vEc8
+D
+M)h߼-*4
+2j#4Yqu+<wH
+cP9ӓCq˭
+3a*| Ev~
+Wj<22)$=&bzK~OqK
+Dv+@J@N}u!$% oA2nk)IٛZս)A1Y&S_)5]<x=X꛽Հ FsO;<5mq1tNh<b45:E;<5:~!)R{nKRQYu^5*Z ; 6/:v΋ GR҆QD.*:Fz~l!zkhYBjT:PoiJ۴F=9*oZyg<YDZCI&cܴ%:=tv&3+Y0[kA
+Og$5kRbnqT!>ܸ~:ks.%&&vsF8S~5o*2]Sgk}͓I%Bh}WԦpz^*P'n
+U9iI~O'ay.KmMkEUD/Il \0I,u jQY9E:Ԝ{6z/`ƒ
+yA$y%gOm?^i:]rEJwOm`RKTQ/\'ɚe"*J˓hETiR7y;Gדqdr==\(lb
+5̺j
+7Y2bMm= gA=.IR2}MK=tuRh'r1 7&8|VvX>:kM^Cm pIkq3=duiװ/ZENx7/SY2omHWka[$:u=گ6L:|=<G~ g4EI6 g+W݊ލeieJWo k
+~*4hМŠA:ơΔ$p.6jI!^+
+PgC L]PMHjj A
+Hu詍nϜ!\},۞:%j~^\1M9rhn,+x2,jx
+ӓSʕyeYD: 6:դ)XSW'J/aӧӀIh=
+͸M"krV4!^cy%nEX0Ѵ{hhv4Kl-[u[#Sp<-$Bh]> 74o=)5ChJeU; 2[g%4טs#Q*+P\g@ƓչWZ` i1*9B(e:YaS_C:GjBIj~$AZ@$?nIӈ&*
+_̤#N46ۋPLk4Iw<nO'/j(~2͐;Bq]k}#OE=Tj踶[{JZR[qE='%9vJ#Ɔ޲ٌsweN67X0Õwn0)$ z+% -_:-̦XSiuȷ{iGjd;M%S[4h0ך՘o4٭G
+hnؐ ¸u|Y{Q a _n&_kx d.L{ɑN_LEoO롏m\;t>%K{[0DM ( ȱӄrıe.7,0> Ǧw <Ȋ}qb+$C1snxZi֒g';
+LB߰տZ{8DSVxZ{q5$ݗC6M,lr€w},~t#=oќǣ>
+
+J%j9
+}Iw.#V5hؕ&T:/}Ԅmk팴[P.^9~*hB]Q;q$k%y*YF*ES!ZҊ?ZղltoòV,̧yLߜ̢z۬V犚2OpcI+o[p{/\]GCdŠTz}C)n50kjI!^+
+Pq68܀QMswP
+\o[To$?e@}D5qKz`QU=;I*i~,Bz^
+`V뿍 2wUpt.Ư+n
+~R1?r';nUOX!堽c b54D>m}0Y>|ZnEߓ*f?Q&OkZ]ȫfSs#xp($[ީbh`4XP6Kj)k|&3'T"]!]uY+sQ̳6 :<WOR/ZgZHop
+
+F/V$
+q}V亸֔,a:?S7/X=iLt?[;rO2j
+pzwM!q2"x7aNTכ*=zPEZE!94[ps:jW{^ut"d|e
+N̫=/3R磊([KX !ҫ._6 @>Ïy]PALݺ4V~tNE-poFم-p:w8DeO$P˴Ab jm؅ OVl 0h,(hۓ0ldh`bNMV8]HbO[ف1z5jY(a u,<U8  -"7P[3ĩd bh"(;ͲLX1>8&gl=HX\J4"<X%50iț؁CPb4n&>ZW%NNp=7S-$=ϚrG!I^NuWt"&щ2ۂ]9]4bmAN‚y6XZb[
+=G+/yÓVu$/#PCR溫 ɛ4
+*ЛJמ(4
+E
+Tex9g@EP @}і)LmBٓ&{u3e wR3D|*i.-.smYS{0s1mv_ξ]@˾IIO&>NRk<%nM< l
+;3df$e̙st
+qxe1 qn{J]a$\^*ŷ>ZqQG~>%~G8|F4d6ㆉ_υM>^UXYMB|=>#-BIm5H^I ǟXi~]4m<M},Aq,(@@v"@Zpi3[^r  7!(hl!qg4V?&!zE?2~E@c#hY%0g lz$ MtfLq_*p MBՑ
+d"QR55;+;'w2wd4(I<5cY(@@c.@l$_KH]RKK1KkCűv#Ue$G?2~#y\Af@?kЏ:`#c=9H`#_+.:FX@ꗜKcPf$q0`'h74
+ѰhkZO Vt0qgD A hťwAhӰwF,EuӬ={dײ:C Ys @όO?g[m֐LھQo?ڷ?[*ʐ,`1qp?rf :Xc9]ͩ-cXCˋ=#Paj
+?^0TÞ-=/=m*=:tĈ?S$ QW\b$4"->&F\4/8xFk%`opw+ dأb1
+nPG%lGsTrF^h 0ˆ]p=- qw3e&/ƚڜ4YD.ϘT4yUapה^S)5"!b7Eݜ_IaU1M4ˡ*U(J~G jjQ?S"UyۥB~[$#Њi1nTUkj}7VD RwɃXgѨ䰚bjCXq!-r~,+Zijn2+.)rvge-HGaΚ7& +[R9>\  k3_ ֹ+ov"kI `=:{ϕkCZ"kw+Ńz5OvgG-78CsիbmU1lzw
+endstream endobj 11 0 obj <</Length 11947/Filter[/FlateDecode]>>stream
+HWgW"M
+PyD^-k?(1E%
+^z!cJSCNC8|P q4@DhRح i8<QbKM,s5|Y"k.fg^0˹7A4SB^2*I贵,ɰޛ4T yޞlQBMNk}.' FStgH3? ~*Y9p#;̋SI]\ 4b7sU85Nh8~b6xlrM򣃖@{Y4EpHAƱ^Eu 徝+WFN!+2倛cF-br2Ťf
+kn9q$1iJ[XRA*ǿhB1sV ldaҪβ;q?~4֚b. lq2٩I9d fC g㞓W~R.E9ְ4ڇ桲=-Q?LxX 1Iy~^4حV;FjǜHG Ϟ33^ST)wWUYbz9ffT,rD,e7OEխBf 8R}G^qÝBZ@S%>
+nj4W ylA{\,əĭaB'W޵\<F訂"nl^y0vomV2zYֺ}UOO=o|6N恍Ny*蒬qbac49-j44j
+ "WڢWWé
+q#yHͣS;P %mTl$=j7
+
+JUҔ)`M)v o*[.NƲ8Q"
+OGvT{2?*wI-pson'Wj^6L\ܦ_޽DuNhd2)яGK_m^
+#$>zfBlpy}lo_M4BI*d؋'}7]dl!VXY^J{!!yjGsA_~eIRz|
+ëW zvIdQn_y4_+'IfwRmO._PCK˶ݠҕs=LX84]BݾX\:n]/YH\57_MС{VMG2l4il71@Jzr62"QlxͧvXd
+Iϙ׊V6o.m:s+T3k\Ҙd~צ
+O-'n3g6~-
+ͭWDvQ>ke.Q'
+OL,.TBip2yTN܌,4d]ˀz֖f' e ybj T87/m!?l>Qq7P` ^\Wd*'C՗LvHqdh}U,rt'4iwKx
+{[e:b枷gXW-WaqOG\C?.E¥$\bl;]'ځZ:8bz-
+1`z[9#d2s-?pvG-r9׻tkՖ/ܩ?e/;-Dg+_"s`݆ ` bp%1 NFC(
+lUP4Ҡ%Z <;x y;Z<{#PFΠtΟvJ2HE@e؉ij͑EYЏp[8e" 3vĭ 'PGɎaP?At `M!uR>E{lpZJsA~N "AQ Ek,`dpp;xlu/~l#jeڠ
+Oz%B71 [;<Tp0WAL@¢_MAҸˑ0PD7/uŨ@֑^ Xzl
+*J(UuoAjS[_8jv<MQ%Tޥӛ9u2k*Z4@ӽɀLY 37mɣp0_WĎح~Xc2
+8搠ǘiu7K,!kWGíiE!{`sXo%@.VR?zuYz}eݣ2n8{z!MdQnE_4$N܌Hkg
+ݚ5j0YfVM ˊRl+ªd 4pP{XLgװ(?ChVs>n~p!}+Il[o?"?t+{{lR4
+Yi֚Ze~aC-nK *?WO4aM,cSP+F bOU9'VerUoV>Tt%Qu/8,D|vR|sH_6艹^A/)f;lmƕ KqaХh؁nXB(Kpqb^W ʷP씿AT`PY,Zhɮ&O <WWk
+@`?wyd!@ZGɂm>T-Xv7@?O`
+i \:Cvƪ*>j
+GӱaA9^A+<-GGT8hx^G^WW.¢@|!٩viY A%B]H
+Zh!M7<_H%[=Y=Gu}bFm̍['*
+zs|.5:vj/Kk+k6*nn)"ܺFVҪ#]=!wW i{Ykw&GmWm/
+Yߗ% u:%<p]<L늇؋' [@V$y8=/xhJ$!_IR'<*v'r}05v{*N:y!P `YA䄬YWS
+y+o}
+<(|" D`I'
+V{ϙ4֒fD*uo}2bd(G 45Ked@ R(p,2N%@6LֆY%`gF#,R-
+ħIH@p
+(f6Y
+a(vi +jGHl\1C& гaVE.
+<v,98.H5e8Hi!!A_FRg<$~ d4zR`pD[px:x`4Rg<7XIc|Ǝz^`aAp|15m@v
+'5DmDŲv*PAv$i{"LiT D TT!<u*Ҕuچjy[ҭs$spa2]#F=RGQ(Lڤ2E꭪2Y#rW3S!*pT9>^ ]e.)א^]\ؿ69#3iRG|ELc!W<J2"UEfP7rVSC
+DEv:%9xv+L+v"חk.8b\UJAG]ʮ5 fbC<#һcތ&w.c4\JydPZ
+l^K{Tԓt(R tvYcB"qX[),C$MO]ڍ'dQQN">Nji SHHT3XBLG*TH~;EUܢ s-?-|TT,9β gg'M8Ya3v%ePC9)`PqD %+r
+FrWdap*b{w|R ʑi7\$BLmq2Y4sΣ(LhOCeN
+?Rlp(*WRŲ% h7Լ:DrcrbSleIܕHs4YE#Lr0gt+wGZRFU!$oW`PS U1(+Z.9
+ J'/t{L&ԃ=eRqgR#^ _!Y-J*]lh/T(< B ח߳ls#U5iE$w%4s>=X0+_rtP j@ɵB). iI\g'?2=\o
+]eBPyn,F  bI=hfy Wj((:U_.Np82_.09jpD:-hjAVR LLW(T;Y%%[ [`b4wcVYa<}ca,6o.d Bi[nИڊں9K]UsP  TWsA 2
+"A쥢=jYT)K4O+F/a8`զ&楶eY` eiF綹bVՌ%%)3+vJ`fv Cp npe9"; 1]gbs&d߰}aq#Ek iȥFBrsp򗆕鼶GAզT.q1Ғ_ToI:>bj,0+yK(j\O3 snDCxk2WXg!)
+KCu Zn(-Tw+/AL]wѺ5l3(
+/hLhdndye%L; ǹfED0-nb`>jUjԢ ŤQ]R_!CxnSH m4 :(***
+ꏦ&+$ 5f*o\Zbam22c%;FmZpC4s'M҆8>z݆+T!i,#>r2IO&htH}Rů jY86LM
+;>O6~pA`di:^dYd)gv^ږ 1)
+j{Uʤ,`mǔɊ5 5U$]Xޔ$y#bڢ.eUirf"Z8<B`@J#H zчH.)VnHbKpG
+6#0f+>ẕb*NQeUVRŨvC>/\35yr{vS
+۶s QlU醾\$𹋳B\<sbnhy+Bk<`cat&iW5Ѳf}|MYDJs{HFw/N>Xႃ#96VRAАmns-H @~~mZNv.>ʥEJIλHke1-ں|nܲ^a}_?9Hϓ#𦢥V };`-cҊsde͡A!bhOp)+ZJ/?ݪm!{S1c!y-cNxi}) L#%0צQ`ycti.$OkSgu~wp
+z6mRL/n}-Es@|}m3rCO(
+_ dgLxD_Eƣ=UHW$y p0Tλr) hg )o;r^sΑVN~?c!šq877&+j+%NS5 y|"LXIΙSŮ`Cl|0)r77}i\n@c<7ݧ89֯??4Y+3wio8K h
+-;".]V
+;bZt?yfZ`9ky݄YUzYH[MalISMWNC ʽ ;['kxih1 1wѦsOaُNR)7.%M!;pRrCP\22ljX!k Kv>vo,E^*T+ Y6iK=7]a^h0dlPAW!{K)#(-2l,Pؽ1v.5Q+iicCuZd_i9K)GxM>&o31RԕǏ r54VȌ# 371xA+P!XD r sm9a)za}6rc_g<bF)&>`zyx%Z q2\y=2λY\:l)kz'Irg
+=A-|nZCo;z 9Brt̓TUؘڗ5 ?eA@wMQC‚
+‚KD6Q^ULgS2o{y)ЯečG3^n/Pne8
+,#g̯xrhP?4<C, n(Ey̢ǔQ,0OBҦ ^7BfN=0lmT H[JCpL%
+7jAV;R]*xhQ#C}>Q{)J2&\7Ce376δ-+O@GO1p#Wo"vǻi{ߌ0y~+; Ŀq9ájl-gd%혪=ljUVT ]p/P
+db2.:7 )b 9QA[ex>dLuSPEL^r
+% h ^W0yP?z+¶*֩aH$>(jx !kN8 E!=7BbZЌ%Ӱ憄Qg#dN qCK fTH+D%fH@\wfK!{vCRhB4's;H
+endstream endobj 20 0 obj <</CreationDate(D:20170106153321-07'00')/Creator(Adobe Illustrator CS3)/Producer(Adobe PDF library 8.00)/ModDate(D:20170106153321-08'00')/Title(ghostscriptR_stack_RGBclr_CS6)>> endobj xref
+0 25
+0000000003 65535 f
+0000000016 00000 n
+0000020409 00000 n
+0000000004 00001 f
+0000000012 00000 f
+0000020672 00000 n
+0000026128 00000 n
+0000026200 00000 n
+0000026380 00000 n
+0000027445 00000 n
+0000034835 00000 n
+0000047572 00000 n
+0000000000 00001 f
+0000020647 00000 n
+0000020460 00000 n
+0000020531 00000 n
+0000020562 00000 n
+0000025284 00000 n
+0000025397 00000 n
+0000021022 00000 n
+0000059593 00000 n
+0000025566 00000 n
+0000025614 00000 n
+0000024946 00000 n
+0000000148 00000 n
+trailer
+<</Size 25/Root 1 0 R/Info 20 0 R/ID[<232A3C82B5AC1C4685953FCB0F96CFFD><011FA45CAFB7614ABE20588E6D8FD46E>]>>
+startxref
+59786
+%%EOF
diff --git a/doc/colormanage/figures/proof_link.pdf b/doc/colormanage/figures/proof_link.pdf
new file mode 100644
index 00000000..623d7691
--- /dev/null
+++ b/doc/colormanage/figures/proof_link.pdf
Binary files differ
diff --git a/doc/colormanage/figures/source_intent.pdf b/doc/colormanage/figures/source_intent.pdf
new file mode 100644
index 00000000..b908d6be
--- /dev/null
+++ b/doc/colormanage/figures/source_intent.pdf
Binary files differ
diff --git a/doc/colormanage/figures/source_profile.pdf b/doc/colormanage/figures/source_profile.pdf
new file mode 100644
index 00000000..60cf9a78
--- /dev/null
+++ b/doc/colormanage/figures/source_profile.pdf
Binary files differ
diff --git a/doc/colormanage/figures/text_graph_image_cmyk_rgb.pdf b/doc/colormanage/figures/text_graph_image_cmyk_rgb.pdf
new file mode 100644
index 00000000..d8d254ef
--- /dev/null
+++ b/doc/colormanage/figures/text_graph_image_cmyk_rgb.pdf
@@ -0,0 +1,1686 @@
+%PDF-1.7 %
+1 0 obj <</ViewerPreferences<</Direction/L2R>>/Metadata 31 0 R/Pages 2 0 R/Type/Catalog>> endobj 31 0 obj <</Subtype/XML/Length 20263/Type/Metadata>>stream
+<?xpacket begin="" id="W5M0MpCehiHzreSzNTczkc9d"?>
+<x:xmpmeta xmlns:x="adobe:ns:meta/" x:xmptk="Adobe XMP Core 4.1-c037 46.282696, Mon Apr 02 2007 18:36:42 ">
+ <rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#">
+ <rdf:Description rdf:about=""
+ xmlns:xapMM="http://ns.adobe.com/xap/1.0/mm/"
+ xmlns:stMfs="http://ns.adobe.com/xap/1.0/sType/ManifestItem#"
+ xmlns:stRef="http://ns.adobe.com/xap/1.0/sType/ResourceRef#">
+ <xapMM:InstanceID>uuid:7bb34414-aa43-43e4-b5e0-bda0b2b10220</xapMM:InstanceID>
+ <xapMM:DocumentID>adobe:docid:indd:a5afd9b5-ab2e-11e0-8bdb-9544086fefb6</xapMM:DocumentID>
+ <xapMM:RenditionClass>proof:pdf</xapMM:RenditionClass>
+ <xapMM:Manifest>
+ <rdf:Bag>
+ <rdf:li rdf:parseType="Resource">
+ <stMfs:linkForm>ReferenceStream</stMfs:linkForm>
+ <xapMM:placedXResolution>180.00</xapMM:placedXResolution>
+ <xapMM:placedYResolution>180.00</xapMM:placedYResolution>
+ <xapMM:placedResolutionUnit>Inches</xapMM:placedResolutionUnit>
+ <stMfs:reference rdf:parseType="Resource">
+ <stRef:instanceID>uuid:7CECFCBEBBACE011841685AA9CCA09F5</stRef:instanceID>
+ <stRef:documentID>uuid:C377191EB9ACE011841685AA9CCA09F5</stRef:documentID>
+ </stMfs:reference>
+ </rdf:li>
+ </rdf:Bag>
+ </xapMM:Manifest>
+ </rdf:Description>
+ <rdf:Description rdf:about=""
+ xmlns:xap="http://ns.adobe.com/xap/1.0/"
+ xmlns:xapGImg="http://ns.adobe.com/xap/1.0/g/img/">
+ <xap:CreateDate>2011-07-12T12:26:34-07:00</xap:CreateDate>
+ <xap:ModifyDate>2011-07-12T12:26:34-07:00</xap:ModifyDate>
+ <xap:MetadataDate>2011-07-12T12:26:34-07:00</xap:MetadataDate>
+ <xap:CreatorTool>Adobe InDesign CS3 (5.0.4)</xap:CreatorTool>
+ <xap:Thumbnails>
+ <rdf:Alt>
+ <rdf:li rdf:parseType="Resource">
+ <xapGImg:format>JPEG</xapGImg:format>
+ <xapGImg:width>256</xapGImg:width>
+ <xapGImg:height>256</xapGImg:height>
+ <xapGImg:image>/9j/4AAQSkZJRgABAgEASABIAAD/7QAsUGhvdG9zaG9wIDMuMAA4QklNA+0AAAAAABAASAAAAAEA&#xA;AQBIAAAAAQAB/+4AE0Fkb2JlAGQAAAAAAQUAAgag/9sAhAAKBwcHBwcKBwcKDgkJCQ4RDAsLDBEU&#xA;EBAQEBAUEQ8RERERDxERFxoaGhcRHyEhISEfKy0tLSsyMjIyMjIyMjIyAQsJCQ4MDh8XFx8rIh0i&#xA;KzIrKysrMjIyMjIyMjIyMjIyMjIyMjI+Pj4+PjJAQEBAQEBAQEBAQEBAQEBAQEBAQED/wAARCAEA&#xA;AMYDAREAAhEBAxEB/8QBogAAAAcBAQEBAQAAAAAAAAAABAUDAgYBAAcICQoLAQACAgMBAQEBAQAA&#xA;AAAAAAABAAIDBAUGBwgJCgsQAAIBAwMCBAIGBwMEAgYCcwECAxEEAAUhEjFBUQYTYSJxgRQykaEH&#xA;FbFCI8FS0eEzFmLwJHKC8SVDNFOSorJjc8I1RCeTo7M2F1RkdMPS4ggmgwkKGBmElEVGpLRW01Uo&#xA;GvLj88TU5PRldYWVpbXF1eX1ZnaGlqa2xtbm9jdHV2d3h5ent8fX5/c4SFhoeIiYqLjI2Oj4KTlJ&#xA;WWl5iZmpucnZ6fkqOkpaanqKmqq6ytrq+hEAAgIBAgMFBQQFBgQIAwNtAQACEQMEIRIxQQVRE2Ei&#xA;BnGBkTKhsfAUwdHhI0IVUmJy8TMkNEOCFpJTJaJjssIHc9I14kSDF1STCAkKGBkmNkUaJ2R0VTfy&#xA;o7PDKCnT4/OElKS0xNTk9GV1hZWltcXV5fVGVmZ2hpamtsbW5vZHV2d3h5ent8fX5/c4SFhoeIiY&#xA;qLjI2Oj4OUlZaXmJmam5ydnp+So6SlpqeoqaqrrK2ur6/9oADAMBAAIRAxEAPwCbeU/KflW58q6L&#xA;cXGi6fNNNp9rJJJJaws7u0MbMzM0ZJJJ3OKpt/gzyf8A9WHTf+kOD/qnirv8GeT/APqw6b/0hwf9&#xA;U8Vd/gzyf/1YdN/6Q4P+qeKu/wAGeT/+rDpv/SHB/wBU8Vd/gzyf/wBWHTf+kOD/AKp4q7/Bnk//&#xA;AKsOm/8ASHB/1TxV3+DPJ/8A1YdN/wCkOD/qnirv8GeT/wDqw6b/ANIcH/VPFXf4M8n/APVh03/p&#xA;Dg/6p4q7/Bnk/wD6sOm/9IcH/VPFXf4M8n/9WHTf+kOD/qnirv8ABnk//qw6b/0hwf8AVPFXf4M8&#xA;n/8AVh03/pDg/wCqeKu/wZ5P/wCrDpv/AEhwf9U8Vd/gzyf/ANWHTf8ApDg/6p4q7/Bnk/8A6sOm&#xA;/wDSHB/1TxV3+DPJ/wD1YdN/6Q4P+qeKu/wZ5P8A+rDpv/SHB/1TxV3+DPJ//Vh03/pDg/6p4q7/&#xA;AAZ5P/6sOm/9IcH/AFTxV3+DPJ//AFYdN/6Q4P8Aqnirv8GeT/8Aqw6b/wBIcH/VPFXf4M8n/wDV&#xA;h03/AKQ4P+qeKpTrPlPyrFqOgJFounok+oSRyqtrCA6Cwv5OLgR7jkimh7gYqm3kz/lD9B/7Ztn/&#xA;AMmI8VTrFXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FUl13/jqeXP8A&#xA;tpSf907UsVd5M/5Q/Qf+2bZ/8mI8VTrFXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYqpzzxW0&#xA;L3E7BIolLOx6ADEolIRFl5X5r/MC7uJntrBmghGwRTxZh4yMN9/5Rl2m0ks+52i62ebJnOx4Y/ex&#xA;GPX9Qil9ZWAetarUHf8Ayga5lnszFW1sfysRuCbeheT/AD81yyWWqvyVqKsz/bQnpzPdff78wc+G&#xA;eCVHl3tuHUzxy4Z8uheiZB2DsVdiqS67/wAdTy5/20pP+6dqWKu8mf8AKH6D/wBs2z/5MR4qnWKu&#xA;xV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxVgn5la4bS2TTom3YerKPHeka/eCThx4vFyCPzcDX&#xA;TM5DGPeXkbMzsWY1ZjUk9yc3oAAoJAoNYVVLed7aZZU/ZO48R3GV5sQywMSxyQE409z8lax+ldHQ&#xA;O3OW2pGxPUoRWNj9G30ZowCLB5hu0WUzhR5jZkOFynYqkuu/8dTy5/20pP8AunalirvJn/KH6D/2&#xA;zbP/AJMR4qnWKuxV2KsS/MjzPqflPQ4NR0pYXmlu0t2E6ll4NHM5oFdN6xjFSWE+XvzS83azqUNo&#xA;8VkkJYGdwjLxjr8VGealfDJY48cqZ4cZySpnt35jvooFubeONoRIsZMlQxqDVio2AqPE5b4QBouV&#xA;HRxBole/mZ4kWBwrXrKH9KMM60I61Xl37ZE4wE/k4k3/AAqEfmDW7y1e5tIIkEK1YP8At9qqS6+B&#xA;yGWJjCwN+5hl08IJVF521swPLMLbkshQIiPVgKUZQXG3uTh0+MyFyDZj0cZHdfdefL2HT57pIo/U&#xA;t4WZuQPEycSV71AqMsniiFyaOEIk2ws/nD5uAqYbID3ik6/8jsx7ddxI3RvzY8z32q2VjPDaenc3&#xA;EULsiOCFkdUNKynffBxI4nseSZuxV2KuxV4f5+vjd65cb1USsB8o/wB0v/EczezIWZS+DrInjzTl&#xA;8GL5sm12KuxV6N+Vd8wu3tSfhkjZaf5SEOv4E5p9bDhz+8MdOeHUEd4epZQ7B2KpLrv/AB1PLn/b&#xA;Sk/7p2pYq7yZ/wAofoP/AGzbP/kxHiqdYq7FXYqwD85IWn8s2iJ1F/Gd/wDjDcd8jOQiGMjs8x8r&#xA;zQ6Pqn1m9skuYnQoAw5BD15o1TQgKd98cWaIO5bNNMRmCTTOr3WbrVLX6o7Rxxxgux4Eqqjc/CtS&#xA;ajb+mZGohxQ2dplxxEbj1Q1088V3LqP1hpjIpRZA7KKH46xpUqtVPTkcr8SINksISjAXJA22qXwh&#xA;WKaiojNxKuQF5D4vhqe3XKY6+MTyaMevs7hZJcUZQSwMgJjFOo9qeGZoyirJc45I0F8lrHdwSRkE&#xA;QyqFeZxXjQBzTqCxpt7ZTkzRnYi0amZnAxCS3flDUYbGK8MaNHPVkIZSw8QwqSMxSZAAnk6kwlVq&#xA;Xl3TZYtf00lRyW6hLKPiIAkU1PhkRlshD6JzJbHYq7FXYq+fPMjFtVlZjUmp+9mzY9mf3R97q9Py&#xA;PvKVZnNzsVdirMfy1YjXoKfzt+MUgOavtIfvItY/xiHxez5iOydiqS67/wAdTy5/20pP+6dqWKu8&#xA;mf8AKH6D/wBs2z/5MR4qnWKuxV2KsN/M9S/l+3CniReRkEEDpHN45j6s1Ae9hk5POPqHrQx3M0in&#xA;1TR0jpzJHYqD4ZgGZB2awmmj3l5p3JrYLbRSfCpdPUoPjHFC1dj3GZGHV5ICubkY88oijuFWGyWR&#xA;1iSaG3jUcSrnivJEXkRyp9tunh3zcYQBjDtYQ9HJCPOZKGLiQWP269hxIrSu2U4sMQCQN76owYog&#xA;k0k+ui7iagnZraZljjYNQJ1DDZFO/wDDK80DdsdVjI3TrT7K30+aIzzPNCpApUlT1Hev45dixgxH&#xA;Fs2Y8RMapm9vLLp3C3s2E8cwIiCjckbFVDrxp16V/Vhw4eGNS3aPBHBRHJI5bdbbzBaW/p8ZEmic&#xA;kgFgWYE1Py6ZrM0BDMAOTgZqE6HJ6dmah2KuxV2KvAPNUBg1eZD+y7pv4q7DNh2Wf3ZHm6vBsZDz&#xA;SbM9udirsVZt+WMBk1qKTshdj8hGw/W2artI3liPJrgL1MfIPYsxXZOxVJdd/wCOp5c/7aUn/dO1&#xA;LFXeTP8AlD9B/wC2bZ/8mI8VTrFXYq7FWF/mlJ6egWp8b1AK/wDGKc/wyjVRuDDILDza0uAHDc1W&#xA;eM/APs1HUEvmCY0GA2TWCcOpa5YiJBTmoJoSdjWvXrlZItNnoq1nl0yNB/cTMZoyeIdWOxHJeNeo&#xA;rm60hMcYifg7XRyAhRO/6FkKXDN6dtC0iRrypQMACKs5p271yP5mWONAE11Uanw41V+aG1N7UmBJ&#xA;DQK5ZEcA1FPiqN9q7VzWHNPJIyLgZMkpStNNPht7u4KSs6Q8KvJwP7s12BHTfpXM7TaqWQiP2uZg&#xA;1eSdAc2pby6j+FZQV4mIGlAB9nbZafdmVqtUcUbq/NyM+cYt6W2M3qazaPMxkla4hPKm2zIBv7Zq&#xA;TlOXKJF1GXKckrL17NkydirsVdiryD8zNMa31V7lV+CWkyn2YcX/AOGXMns/Jw5THvdbkHh6g/0m&#xA;DZtmx2KuxV6t+V2mNDFNfOKcUES1/mciR/uAXNHnyeJmkfgjRDjySn8HoWQc92KpLrv/AB1PLn/b&#xA;Sk/7p2pYq7yZ/wAofoP/AGzbP/kxHiqdYq7FXYqwP835Hj8tWxU9b6Pl7j0rg/wyvMLDGYsPKReF&#xA;zEgAhqByYVPXcMevbwGYcsYa6ZXpmm3L23qMkTjcCVJAyU/arxagp75jSABY3RUrWS1lPorKJDaU&#xA;Lp9n/JPp7Gq7dc2+j1Hoo/B2ek1Vx4epVpdQgjm/eyvCihYw/Jeap8Q6EjkKGmZUssI+m+jlyyRg&#xA;KJCFn0ppx9c9c3UnHgWeMqNiw4ihanXr9OaOcuF0vETumltfXkSywWr+hFcH40BBoaUCk9xQkZdp&#xA;NSMd7WHJ0+cQ5iwozRyyxjoObFRGpqqqPcmg6DHWaoSNR+llq84kaHJV0hm/SdpAyqaXEZqT0PME&#xA;n8Mx8P1hxHrubZsdirsVdiqQecNB/TemERLyuIKtGO7qR8afT298BsEEcw42swHJGx9Q5PDby0ks&#xA;5jG4PGvwk9x/XN1ptRHNGxz6uNiyiYUMubEz0LSLnVLyKOGMvyYBVH7Tf0HfMPXarw48I+otOaZP&#xA;pj9Re76Ppsek6fDYxnkYxV2/mc7s335q4ig7DBiGKAijsLY7FUl13/jqeXP+2lJ/3TtSxV3kz/lD&#xA;9B/7Ztn/AMmI8VTrFXYq7FWL+ftDvfMOl2un2LKjm7V3ZzRQoinFT9LDIyjxJEbYtY/lpE1oZUvx&#xA;LJGSrVj/AHbOOytyYinSpH0ZCel82yWLgNdUDHp0tpcJaWt2YZbdgsnp8mHCu4cbL9BzBlcSRTjZ&#xA;DvVKHme15lrWIqt5zBDqOIMG9WqKnfiKgdO+DHKt2AiQULokUFx6ywNIYo5C5TgZFK/EBV223O30&#xA;YmJO5bYEdSlhki024P1S4UwSSFZERgSKkdAre2WGJlHdiCLTpRPAfUNF9UD4n3BBoa0A965RwgWz&#xA;gKBKLhR1DLdqVKGv7tgSd+Pv4daYkgc2cQJK9obU6rZNzX1mmiYDcsaug3NAMsgLlHZhMRB2er5s&#xA;0uxV2KuxV2Ksc1/yXputlplpbzvuxChkc+LLtv7jALibiaLi5tHGZ4gaLF4/yocTVeaER12IMjH/&#xA;AIAgD8cuOr1BFW0/lM5/iDNND8t6doUf+jLzmYUaZwK08FA2UZSBvbk4NLDDy596b4W92KuxVJdd&#xA;/wCOp5c/7aUn/dO1LFXeTP8AlD9B/wC2bZ/8mI8VTrFXYq7FVG5to7pUWQAhGD0IqKgEe3jkoyMW&#xA;ePIYXSXSaJLyK2tyLaDcpCsZ4gkdT+8APxb9MlDJw9G6Oqrciz3oSTyoZAw+sxpz3bjBQs/87Uk3&#xA;OYufD4k75ONnAyTsbMf13y9orRy6ZNrkdlP8AkDxcyq8U2CmQcagDocqGjIlfFt7mJiCAhdO0XRd&#xA;KjeG08x2ojdSvB7csKFmbf8A0gVoGpkvyu/NBgCiLLynpWsWp0k6zBfmOIkCG34MDWnqt++atOQG&#xA;I0oHIo8LdNf8BJGONndpbIv2FW3BAr9qv73euD8rfVfDrq3J5GkkZnN+paQAOWgJ3pRiv78Uqd8H&#xA;5IXzZxFUowfl1FbXkF1DfFRDMkzL6VS/AqeJb1O/HwyY01EG2ziFVTNMyGDsVdirsVdirG7rytqN&#xA;xdTXCa7ewrLIzrEjsFQMSQq/vBsK0xVS/wAIan/1MV//AMG//VXFVay8saha3cNzJrl5cJEwZoZG&#xA;Yq4H7LVkOKsjxV2KuxVJdd/46nlz/tpSf907UsVd5M/5Q/Qf+2bZ/wDJiPFU6xV2KuxV2KuxV2Kp&#xA;ddaBo17O1zd2cU00lOTsKk0AUfgMVUv8LeXf+rfD/wADiqIstF0rTpTPY2sdvIylCyChKkg0+8Yq&#xA;jsVdirsVdirsVdirsVdirsVdirsVdirsVdiqS67/AMdTy5/20pP+6dqWKu8mf8ofoP8A2zbP/kxH&#xA;iqdYqtdgiM7VIUEniCx28FWpOIFqlSeaNHkErI1wwtyVmK2lyRGw3If9x8JHvl50mQVy38x+tt8C&#xA;Y/tCY2t3a30C3NnKk8L14yRkEGmx6ZVOEoGiKLXKJiaKhc6vp9rP9WkkZ5wATDBHJPIAdwWSBHYD&#xA;buMlDDOQvp57feyjjkQuttUsbt3it5ecsa8pIirLIgP88bAMp9iK4J4pRG4RKBHNCR+ZdJmklhiN&#xA;zJJAQJkW0uiyE7jmBBUV98sOkyAAmt/MfrZnBId3zCMsdSsdTjMtjMsyoeLgVDK38rq1GU+xGV5M&#xA;UsZqQYSgYndu91C1sBGbkvWZuEaxxySszULUCQo7dB4Y48cp8ljAy5IJPMukySywRm5aWCnrRraX&#xA;RaPkKrzUQVFR0rlh0mQAHbfzH62ZwTAvb5hubzJpEC27ySShbzj9XIt52DluirxiPxbfZ64x0uSV&#xA;1057hAwyN+XmFVNbsXljiIuI2lYIhltbiJSx6DnJCq/jkTp5gXt8x+tBxSA/aFCfzRottefo+aWV&#xA;bonisP1a4LMf8gCE8ht1GTjpMso8QG3vH62QwTIvp7wib/WbDTJIorxpEa4NIgkMsnJv5QYo3HLb&#xA;p1yGPBPICR08wxhjlPkpza9psEk0bmYtbgGYx208ix1USfG0cTAfC1cMdNOQB238x+tIxSI/aGoP&#xA;MOl3Jg9JpuN0QsMjW1wkblvs0keJU3+eMtNkjd1t5j9aywyH9oTPKWt2KuxV2KuxV2KuxVJdd/46&#xA;nlz/ALaUn/dO1LFXeTP+UP0H/tm2f/JiPFU6xV2KsNt9aOiza9cvaTTxC/PKVCgjQssa/vKvzA9w&#xA;hzYSweKMYsD0uScfGIi+iYaNYT+X/L95cM6TzS+tf8Id4lLJyVI/EfDlWfIM+YDptFhkmMkx8l/k&#xA;qNToEF4W9W4vS89xMd2eQuwPI+1KYNef3xHQbBdT/eEdy6LV7WXzE1gLC6jv1hpJIRDw9DkCrsyz&#xA;Goqdu+/TBLBIYeLiHDfnz+SnGRjuxSB026nt/M/mH0bOa85Pa19EwjjSI9fXmi6+1ctywEsGOyBz&#xA;7+/yDOcQccd65u8tyC48x6veTr9SuphGPqDAiRUQAeq5pxPKv7NcdUOHDADcd6MwrHEDcd7KSiMy&#xA;uQCyV4nwr1pmDbjse0X/AJS3zJ/0Zf8AJlszNR/i+P8Azvvb8v8AdQ+K3zaBbpophiL8dVgYRpxB&#xA;YkStRebKu58SMdF6uOz/AAFdPvxf1U0iv7i4u47WfT5raNlaTnOYWHKMoVC+jNLvvXfwyiWMRjYk&#xA;D7r/AEhrMABdobzRpEOp6cZS/wBXurL9/a3I+1G67023o1OmT0mY4594OxDLBkMJeRUfLN6dYV77&#xA;UBx1K0Y20tuRT6uR1op7v1J+jtktXj8I1H6TvfenNDgNDkmeqoi6XflQAXglZiO59MrU/QMpwn1x&#xA;97XD6ghfLSJJ5b0xXAYC3hah8VCsp+gjJ6o1nl7yyz/3h96b5Q1uxV2KuxV2KuxV2KpLrv8Ax1PL&#xA;n/bSk/7p2pYq7yZ/yh+g/wDbNs/+TEeKp1iq1y4RjGAzgHiGNAT2BIDU+7EKkWkaVqcE+pDU4rV7&#xA;bU5WmZY5XcryUJwKvAgYEDrUfLMrNmxkR4Sbj+O9uyTiQKvZfo+m6vpLvpzGC50gMRbl3cTxxnf0&#xA;2X0mVwOn2v6YM+XHlHFuJ9e5ck4T3/iasdI1HQjJDo7Q3FhI5kS1uWaMwlqlhHKkcvw17FfpxyZ4&#xA;Zt52Jd46rLJHJ9XNdZaTfLrk+vXphSSW3FstvCzOoAYOGMrJH4fyY5M0PCEB33aJZBwcI71CwsPM&#xA;FlqepaiYLOT9JNE3p/WZV9P0lKfa+qGta+AyWTJhnCMbPp8h+tlOeOUQLO3l+1V0/RLz9Ny+YNUe&#xA;L6w0X1eKC35FI0rWpdwpYn/VGRyZ4+EMceV3uieQcHCE8NaGm57V2zGaUg0rTdatdc1DU7qO19HU&#xA;/S5rHNIzR+ihQU5W6Bq19sy82XFLFGIu4307/i35JwMABeyp5g07VtRnsDZJb+lY3Md4TNK6M7R8&#xA;hwosEgA+LrX6MjpsuPGJXe4r8bowzhEG+opES/4huAsXpWtqjOvqypcSSuI6/GEU20Q5EdDy2yI8&#xA;GO9k/D9pY/ux3/j4rfQ1m41RHvI7X9HQktGiSyGTmK8JHBhVWp2Wu3XcgY8WKOPYni/HmtwEdrtB&#xA;X2ka0nmBdZ0YWsatGIrlJpZB64HTkqQsFK9jU5ZjzYjh4J35eX2s4ZIeHwytNdUi1C502S3tI4TP&#xA;cRtG4lkZUTmpUkMsTlqE+AynEYRnZug1wMRLdT0C0vrDS4LC/WIPaosSvA7OHCinI8446H23w6mc&#xA;J5DKPXvTllGUiQmWUtbsVdirsVdirsVdiqS67/x1PLn/AG0pP+6dqWKu8mf8ofoP/bNs/wDkxHiq&#xA;dYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FXYqkuu/8AHU8uf9tKT/un&#xA;alirvJn/ACh+g/8AbNs/+TEeKp1irsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVdiqFm1PTbd&#xA;/TuLuCF/5ZJEU/czDBYYSywidyEQkkcqh42DqejKQQfpGFkCCuxS7FXYq7FUl13/AI6nlz/tpSf9&#xA;07UsVd5M/wCUP0H/ALZtn/yYjxVOsVdirsVdirsVdirsVdirsVdirsVdirsVdirsVdirznzv55aF&#xA;n07THKopKPIho0hHUKeyjx7/ACyeDBLPKhy6l12fUSyyMYGgOZebyaneu3L1OPsAKZs4aDDEcmsa&#xA;bGOideXfN+oaTcqVkorH4lP2H/116fTmNqez+EcUPkohLCeKHyez6TqlvrFil7b7BtnQ7lHHVTmD&#xA;E2HY4M0csOII3C2OxV2KpLrv/HU8uf8AbSk/7p2pYq7yZ/yh+g/9s2z/AOTEeKp1irsVdirsVeDe&#xA;YfzI872PmHVLG11L07e2vLiGFPQt24xpK6ItWhJNAO5wWi2aeTvMnmK7sBc6zeG5ubglYIikEaIp&#xA;40eQxRBwRQ+OWCGzk49PxRsp1a+YdRjnnjvmj9K1LCRzTlQMPiAULXavQYTAVs2nTQMRXMrJPNV2&#xA;Zl+qoZopgRGWXidt+W6rWgO4rgEN0/lIgb80u1bW/NenXMFu90iiUqCwWI/Cep+wwFO9col4hlQG&#xA;3ewjjhPkFkfnDVopnW4n9VAKAoiKK/5JZOnzGZfhCnI/JwIDG/Nf5gea7HUIrXTb0wgRAyL6MLVc&#xA;s2/7yE02GUzAi4WqhGEqikQ/M7z2G31SoHUehbD/AJkZC3G4i9U/LXX9U8x6HcXurSerPHdNCrBV&#xA;X4BHC42jVR1c4xZRNsvySXYqkvmzVDpWjTSxtxlm/cxnuCwPJvoUHIyutnH1mY48Zrmdng93cNcz&#xA;tKeh2UeCjpm90+EYsYi4uLHwRpRy1m7FXof5Za48d79QlaqXA9Mg9nUFo2+ndc02tw+Fl25SYaeX&#xA;hZ66S+96rlDsnYq7FUl13/jqeXP+2lJ/3TtSxV3kz/lD9B/7Ztn/AMmI8VTrFXYq7FXYq+bvNFhM&#xA;3mbWWVA3K/uiKH4t5pD9nKjkALC92YeXfMa2enQRWdrFaTQII5mVN3p8POm+5INT+rMnEYzHN2Wk&#xA;jjywon4K0huLtLpTcCOS74MYo+SPx+NATL4cmrQBq1yuuCRvkylH1nuQU1/e2k1stsT/AKPsAXNV&#xA;3p8BLbEmtcjPUQhQY6jVRx0AL72mu5ZhxIPNKnip57V3pXxJyzT6oZG7T6kZOY3U4ZI7hTQs6sBw&#xA;478jUDpsfuy2eaAG5bPFA3ULry3Pq98gtQguHUlo3IVVEY4gMWIHI0JIzEyGUpe91eqjKWS65pBd&#xA;6Dc20xWWNUANDUgAe9RlRyVs41UXrX5SwNB5cuFYUreOw2pUenCAd/lluKVhlHkznLGTsVedfmre&#xA;lI4LRT0jZyP+MjcP1Kcs00ePPEfFwNaeLLCPxeWZvFdirsVTPy9dPaalHKnVCHUf5SEOP1Zg9pwv&#xA;FfcWjU+kCXcX0IrB1DruGAI+RzWu2bxV2KpLrv8Ax1PLn/bSk/7p2pYq7yZ/yh+g/wDbNs/+TEeK&#xA;p1irsVdirsVeJavbPP5k1ODmqxzXk5PqEcQQ703rUZr8pqRaCd0Klp6Mh9NTLOWI9RSaADqBQ7jx&#xA;yEcshuDTOE5ROxTue5uNQEf1p4g8NYouEfD0Wd1JpwHSi9PfM/SZjmnuOTsNLPxJbjkh5UFtHCWl&#xA;jle4P2UPIrxNeL0r233zJ1EI5CAR1b8uMSqwg51uZ7eUW8ohmNfSdDQmpJNfhP68ZwPIU5HhXGhs&#xA;lelWkl/c3U0szxSQN6YjDmo+0SKCg7ZRigeKvtcTDD1nbZm+gQ27RMsUlLqAmnIMS9amlVVmpRTU&#xA;ZZkxeoEFnlxkSEiEfqcs+oaeby4j5xWymjUXgW2UigAr9+V6rFEwvq4uoxxgD3pt5BAGkT8RxU3L&#xA;EClOqR/xynR/R8XFiyjMhLsVeVfmsT+kE/4xR/8AEpMyNB/f/B12o/xkf1Xnmbhk7FXYqitN/wB7&#xA;ovmf+InMbX/3EmrU/wB2X0LpxLafasdyYYyT/sRmnHJ2WP6QicLJ2KpLrv8Ax1PLn/bSk/7p2pYq&#xA;7yZ/yh+g/wDbNs/+TEeKp1irsVdirsVeFa5cU8wapXiEF7cK9RXb1XU7Zg5I+otBjuq21y6KqwuG&#xA;jqePUk12NE29qZRIJBCNic/W4IrYsLpKuQQOIZR4NUnkW8cu0YuYIb9NfGFKbkJpLnj+8PxKFpxU&#xA;k7kDeg3zZZMnKQv9bs8mQCpAkjuVlWWFVeeJomIDRlgAGG9WJ8PfMLWauZ9NU4uq1JmKApL9Pa14&#xA;zek1Q5Lcwu53NASoJ9wcqxaiWKTRg1MsRTx0FrbxTQyNFPMhWWNloV2BG5B60r1GbPBkMo2erssU&#xA;zONy+CClu55I2SST92AFZFG5Cnl0/HNfqNXKdxqnB1OqscIFM6/L8odIuClafWW67f7riyej+hxo&#xA;cmU5ksnYq8x/Ne2b14rinwtCo+lHav4OMv0UqzjzdfqhWoie8PNc3KXYq7FUbpEbSXyBRUgE0+Y4&#xA;/wAcw+0ZVgPm06o/u6730PBH6MEcP++0VfuFM1YdpEUKVMUuxVJdd/46nlz/ALaUn/dO1LFXeTP+&#xA;UP0H/tm2f/JiPFU6xV2KuxV2KvnvXbto/M+siRRJS8ud2rsBK4B+GnTMXJGy1SG6/RRcXsy+mY3b&#xA;kAYXcRk/6taV+jKcgADEik5vkTTDHNdMIAAVQLVn6gioqSBUdcGkyGMxTbp83BIL+cVrA3BqmQf3&#xA;iMChRxXwHzrXNxHLCQ4ujtoZhkHF0UXaLUla1S8eOvKN4ECyAgioCsG2H2u2YetmJUQ4etyiVU62&#xA;tW09nQKvVCknSnEk8SrfPrmv49x3uLGdFMZrm+vnWW5lDSMeJkLfEgHxHjT3zO/ORMDtRc4aiHBy&#xA;ooJllif1h05UWtB02G2a+czkO7gzmZSt6B5CIbSJmAC8rljRen2Ix3+WZ2j+j4rFk+ZLJ2KsT/ML&#xA;TPr2ji4UVNsxDeySDiT9DBcHEYSEh0cLtCB4BIfwl4o6NG7Iwoykgj3GdBGQkLDEEEW1hV2Kst/L&#xA;7SmvtYhciqI4kY/5ER5H6C1Bmr7SycUxDu3aq8TNGPduXteYbtHYq7FUl13/AI6nlz/tpSf907Us&#xA;Vd5M/wCUP0H/ALZtn/yYjxVOsVdirsVdirym78g3N7rt3f390LeK8vbgwRoA8rcpXK9WCjY1ys4b&#xA;LOOG93al5NTQONw9ykkYBBkYGM1NP2fi3/XmNmxGDGfpF01b288enzSXFwbiFGqFkRiyRU5VXkeZ&#xA;6dMx5Gy49XyYrPFDBdtM0hWGWYG0AJ+GJQ1TxUU8Dttltkikx5JjrNlbiGB55fTmLmRHmURnc1AI&#xA;Zg3YVyOMSB2bJGPeoaZNcX0UkJf1nh+F6GooKKGr/nvjkgIlj9VJkjXD0YcHWMgMK0IFK7k0/lyu&#xA;m26NIo/VwrJISopzfmSUpt0Cqa9fHGBB6JMIUzPyD6X6In9FgyfWDQj3jiJGZ2kFQ+LCLKMyEuxV&#xA;TnhjuYZLeZeUcqlHU9wwocUSiJCi8T84eWLnSb5+Kl0O6MB/eJ2Ye4/aGZeh1Qh6JfB1QvTy4Jcu&#xA;hYvm1b0RZ2c15KEjBpWhanT+3KNRqY4Y2efcwy5RAeb2zyZ5d/Qen85l43NwBVe6IPsr8+5zS2ZE&#xA;yPMuRo8Bxgyl9RZJhcp2KuxVJdd/46nlz/tpSf8AdO1LFXeTP+UP0H/tm2f/ACYjxVOsVdirsVdi&#xA;qWz6PDIHeErFcF2kSfiWZS5q1PiHjhJLcM8uR5IOXy3NPT17tZqbj1Yefx1NHq0tajbBkqcSFyZo&#xA;ziRSQ6pb6Jpl41vqWpGOcorEJbvX7QavJWPXj0zEOkNbH7HGhDhLGp9I8szXz3x108jtGpsZKIvF&#xA;k47SrX7Va5KOlqNWkQCPkk0mW4huG16NjAjR0bTpDy5Abt++7EbUw/lR3sfCTu08gadOBqtrcq0l&#xA;1FHJHM8FdyC3qcea05BumD8se9fD80SPI0oR4v0j+7YDivoUKkHkDUSivfAdHfVMYkFSm/LyO4oZ&#xA;7xTxpwCwUUUNRyBmbl0xjpOHq2QPCnflvQT5espbQ3H1r1ZjNy4cONVRONOT/wAnjl2LHwClkbKc&#xA;ZYh2KuxVA6lBpd9E1nqJiZevF2AZT4g1BBwEAsMmKOQVIMQuvy+0CaX1ItQRFrUiQI7f8EGT9WSj&#xA;kyRFCRcQ9n19MiAnWjeXfLuisssUsc0y/ZkkdKL/AKiigGRqzZ3Lbh0cMZvme8sgjlimBMTrIB1K&#xA;kGn3YXJX4q7FXYqkuu/8dTy5/wBtKT/unalirvJn/KH6D/2zbP8A5MR4qnWKuxV2KuxV2KuxVQls&#xA;bK4f1J7eKV+nJ0VjQe5GKqf6L0z/AJY4P+RSf804q79F6Z/yxwf8ik/5pxVEoixqqIoVVACqBQAD&#xA;oAMVXYq7FXYq7FXYq7FUn1Hyromq3TXl7A0kzgAsHddlFBsrAYqhf8CeWf8Allb/AJGyf814q7/A&#xA;nln/AJZW/wCRsn/NeKpnpWjafosTw6fGYklbkwLM1SBT9onFUfirsVdiqS67/wAdTy5/20pP+6dq&#xA;WKu8mf8AKH6D/wBs2z/5MR4qnWKuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2KuxV2&#xA;KuxV2KpLrv8Ax1PLn/bSk/7p2pYq7yZ/yh+g/wDbNs/+TEeKp1irsVSt9Yea8lsNLgF3LbUFxI7+&#xA;lDGx/YLhJCW9gpyfBQssuHayuXUrwXa2E9n6c8kUkscgk5QMU4/B6nAPX4t6p9+PAKu14RVqGj+Y&#xA;DqV7d6bc24tLqzJ+ESeosihijOjcI9gwp0w5MXCAQUyhQtE63qqaLp0t+0ZmZNkiBoXPWlaGlACT&#xA;7DBjhxypEI8RpCXus6vZ6WupjTY5xw9WWKO5PJEIDV3txWg6/wAclHHEyq0iMSatFQalJPo41ThC&#xA;C0RmCiYmLiN/il9IU26/DkTCpUgx3pDS6vq8GkSarcabHEYk9Vrdrk8xGAWav+j05e2SEImVWkRi&#xA;ZVa9tXvI9FGqyWsYldVeK2E7EuHAKqG9D7ZrQLx+nBwDjq0cI4qRunz31xbiW/tls5G3ESy+qQP8&#xA;o8EAPyrkZAA7FEgAdllzc6itz9XsrWOZRGHeWaZolBYsAo4wzEn4cQI1uVAHVLbXXtWvLGa/g06F&#xA;kgaRGj+tN6jGI8W4j6rTttvkzjiDV/j5szCINWrXGr6lFq6aTFZQuZo3mila4ZQUQ8TyAtmIbfpv&#xA;88AhExu0CIq7RUVzq3riK5s4URkZlkinaRea8aI/K3jpWvXfARGtiggJdB5jvv04mh31hHaPIpdJ&#xA;TcFlkUf76/cLyPsaZM4hwcQLIwHDYKMGpahJqslhb2cctvDx9W69cgJy34FPQPx034g+FSK5Dgjw&#xA;3bHhFWhdQ17VNPsTqMunxehzVFU3LCQh24ISv1YgVrX7WSjjjI1aYwBNWj4LrU/ra295ZxRROjMJ&#xA;oZ2lAZSvwMrQRUqD1yJEa2KCBSPyDF2KuxV2KpLrv/HU8uf9tKT/ALp2pYq7yZ/yh+g/9s2z/wCT&#xA;EeKp1irsVYv5CqunXkU3+9aXkv1oH7XOi7n7sv1P1Dupszc2TNw5KWpyqeFaVrQ9PoyhrYjqEclk&#xA;q+Y7YEyadfXAuFHV7aSVhIP9j1GZEDfp7w2x32ROvSJqOk6lfRsHtoLZ4rdh0dnCtJJ9Gyj/AGWR&#xA;xDhkAiG0gn9kAbG3BFQYkBB/1RlUubA82OaZZNZ67c+XlcHTIwuoxQ03Us1PSr/IH+Knt88unK4C&#xA;XXk2SNxvqnHmP/jgal/zCy/8QOV4vrDCH1BIrLUZtLltJtfirZPBCtjeJUxQ1jAKyL+y7fzfwrls&#xA;oCQPDz6szHi5MuR1dQ6EMrAFWBqCD0IOY7UuxVIfJ/8Axy5v+Yu5/wCThy3P9XwZ5Oanqa3Tea7A&#xA;WkkcUn1Sf4pYzItOSfsrJEfxwwrwzfemNcBTS0W/inlOozxSrII1hMaGJajnyXg8kpr9OVyo8mBr&#xA;ogfM2njVIoba1+HUoW9e1lBp6XE7sx32PSnc/LaeGfCd+TLHLh9y/wAsX0N5pojEfoXVsxivIWNW&#xA;WYH42au55HeuDNGpLkjRUPO3/HBf/jNB/wAnUw6f61xfUyDKmDsVdirsVdiqS67/AMdTy5/20pP+&#xA;6dqWKu8mf8ofoP8A2zbP/kxHiqdYq7FUtn0S1kvG1C2klsbtwBJLbso9QDp6iSK6NT3XJjIao7hk&#xA;JmqREdmUVi08sk7KUFw/AutR1VQgjHj9nfvgMkWoWekJaxXFvLczXkN0XMkdx6ZFZCTJT04oz8Ve&#xA;nTDKd9EmVrJ9AtZtJTRYppba0RPTYQlOTr4Mzxv1O5pTEZSJcXVRM3aMsrU2dslsZpLgRgKrzcOX&#xA;ECgH7tEG3yyMjZQTZQKaCE1RtXF/dG4dRGwPo8DGG5enx9Dp8t/fJ+L6apPHtVIrU9PGqWj2Tzyw&#xA;RSgrJ6PCrKRQqTJHJt8sjCXCbRGVG1H9Co2kPo0l1PJC6el6j+kZBGAF4D9zx6DqVr74fE9V0ni3&#xA;t2jaNHosH1WC6uJ4B9iOdkYJvX4SsaH8ccmTjN0spcSOmjeWJo0laBm6SRhSy/L1FdfvGRBpiEDp&#xA;GipoyPFBdTzxOzOY5zGQHY1ZgUiRt/nTJZMnH0ZSlxKc+g+vqI1T6/dRzorRx8PQ4ojGpUK9u341&#xA;OEZKjVKJ0KpVTSXFwtzPf3Nw8SsIhJ6IVGccfUCxwICwBNK1wGe3JeLyXadpX6Pkml+t3F21wQX+&#xA;sFGoQKChSND07dMZz4uiylaFj8txRarJrEV9dJcTkeqqmIRuo2CMnobigp4+9cJy3GqT4m1Ur6xo&#xA;0etQi2uLmeGEEMY4TGAzKeSkl4nbb2ODHk4DdIjLhRtvE8MSxyTPcMtayyhAx37+miL+GRJsoKrg&#xA;Q7FXYq7FUl13/jqeXP8AtpSf907UsVd5M/5Q/Qf+2bZ/8mI8VTrFXYq7FXYq7FXYq7FXYq7FXYq7&#xA;FXYq7FXYq7FXYq7FXYq7FXYq7FXYq7FUl13/AI6nlz/tpSf907UsVSnyn5s8q23lXRbe41rT4Zod&#xA;PtY5I5LqFXR1hjVlZWkBBBG4xVNv8Z+T/wDq/ab/ANJkH/VTFXf4z8n/APV+03/pMg/6qYq7/Gfk&#xA;/wD6v2m/9JkH/VTFXf4z8n/9X7Tf+kyD/qpirv8AGfk//q/ab/0mQf8AVTFXf4z8n/8AV+03/pMg&#xA;/wCqmKu/xn5P/wCr9pv/AEmQf9VMVd/jPyf/ANX7Tf8ApMg/6qYq7/Gfk/8A6v2m/wDSZB/1UxV3&#xA;+M/J/wD1ftN/6TIP+qmKu/xn5P8A+r9pv/SZB/1UxV3+M/J//V+03/pMg/6qYq7/ABn5P/6v2m/9&#xA;JkH/AFUxV3+M/J//AFftN/6TIP8Aqpirv8Z+T/8Aq/ab/wBJkH/VTFXf4z8n/wDV+03/AKTIP+qm&#xA;Ku/xn5P/AOr9pv8A0mQf9VMVd/jPyf8A9X7Tf+kyD/qpirv8Z+T/APq/ab/0mQf9VMVd/jPyf/1f&#xA;tN/6TIP+qmKu/wAZ+T/+r9pv/SZB/wBVMVd/jPyf/wBX7Tf+kyD/AKqYq7/Gfk//AKv2m/8ASZB/&#xA;1UxVKdZ82eVZdR0B4ta090g1CSSVluoSEQ2F/HyciTYcnUVPcjFX/9k=</xapGImg:image>
+ </rdf:li>
+ </rdf:Alt>
+ </xap:Thumbnails>
+ </rdf:Description>
+ <rdf:Description rdf:about=""
+ xmlns:dc="http://purl.org/dc/elements/1.1/">
+ <dc:format>application/pdf</dc:format>
+ </rdf:Description>
+ <rdf:Description rdf:about=""
+ xmlns:pdf="http://ns.adobe.com/pdf/1.3/">
+ <pdf:Producer>Adobe PDF Library 8.0</pdf:Producer>
+ <pdf:Trapped>False</pdf:Trapped>
+ </rdf:Description>
+ </rdf:RDF>
+</x:xmpmeta>
+<?xpacket end="r"?>
+endstream endobj 2 0 obj <</Count 1/Type/Pages/Kids[7 0 R]>> endobj 7 0 obj <</CropBox[0.0 0.0 612.0 792.0]/Parent 2 0 R/Contents 27 0 R/BleedBox[0.0 0.0 612.0 792.0]/ArtBox[0.0 0.0 612.0 792.0]/MediaBox[0.0 0.0 612.0 792.0]/TrimBox[0.0 0.0 612.0 792.0]/Resources<</XObject<</Im0 16 0 R/Im1 19 0 R>>/Font<</TT0 20 0 R>>/ProcSet[/PDF/Text/ImageC]/ExtGState<</GS0 11 0 R/GS1 22 0 R>>>>/Type/Page>> endobj 27 0 obj <</Length 1496>>stream
+q
+0 0 612 792 re
+W n
+BT
+0 0 0 1 k
+/GS0 gs
+/TT0 1 Tf
+12 0 0 12 180 515.6797 Tm
+(RGB Image)Tj
+0.083 -28.667 Td
+(CMYK Image)Tj
+ET
+1 0.9 0.1 0 k
+/GS1 gs
+q 1 0 0 1 463.1364 189.5939 cm
+0 0 m
+30.451 0 55.136 40.535 55.136 90.536 c
+55.136 140.538 30.451 181.073 0 181.073 c
+-30.451 181.073 -55.136 140.538 -55.136 90.536 c
+-55.136 40.535 -30.451 0 0 0 c
+f
+Q
+0.79 0.12 0.83 0 K
+8 w 4 M
+q 1 0 0 1 463.1364 189.5939 cm
+0 0 m
+30.451 0 55.136 40.535 55.136 90.536 c
+55.136 140.538 30.451 181.073 0 181.073 c
+-30.451 181.073 -55.136 140.538 -55.136 90.536 c
+-55.136 40.535 -30.451 0 0 0 c
+h
+S
+Q
+BT
+0 0 0 1 k
+/GS0 gs
+/TT0 1 Tf
+12 0 0 12 428 166.3464 Tm
+(CMYK Graphic)Tj
+ET
+0.145 0.251 0.561 rg
+/GS1 gs
+q 1 0 0 1 480.2273 557.8364 cm
+0 0 m
+30.451 0 55.136 40.534 55.136 90.536 c
+55.136 140.538 30.451 181.073 0 181.073 c
+-30.451 181.073 -55.136 140.538 -55.136 90.536 c
+-55.136 40.534 -30.451 0 0 0 c
+f
+Q
+0.188 0.639 0.38 RG
+q 1 0 0 1 480.2273 557.8364 cm
+0 0 m
+30.451 0 55.136 40.534 55.136 90.536 c
+55.136 140.538 30.451 181.073 0 181.073 c
+-30.451 181.073 -55.136 140.538 -55.136 90.536 c
+-55.136 40.534 -30.451 0 0 0 c
+h
+S
+Q
+BT
+0 0 0 1 k
+/GS0 gs
+/TT0 1 Tf
+12 0 0 12 449.3333 533.0131 Tm
+(RGB Graphic)Tj
+0.561 0.137 0.78 rg
+/GS1 gs
+72 0 0 72 70.6667 428.7448 Tm
+[(RGB )18(TEXT)]TJ
+0.592 0.859 0 0 k
+0.019 -5.037 Td
+[(CMYK )18(TEXT)]TJ
+ET
+Q
+q
+127 186 204.8 153.599 re
+W n
+q
+/GS1 gs
+204.8000031 0 0 153.6000061 127 185.9999695 cm
+/Im0 Do
+Q
+Q
+q
+/GS1 gs
+204.7884369 0 0 153.5913239 115 531.4086761 cm
+/Im1 Do
+Q
+
+endstream endobj 11 0 obj <</OPM 1/BM/Normal/CA 1.0/OP true/SMask/None/ca 1.0/AIS false/op true/Type/ExtGState/SA true>> endobj 22 0 obj <</OPM 1/BM/Normal/CA 1.0/OP false/SMask/None/ca 1.0/AIS false/op false/Type/ExtGState/SA true>> endobj 20 0 obj <</Subtype/TrueType/FontDescriptor 21 0 R/LastChar 114/Widths[250 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 667 667 0 611 0 722 0 333 0 722 0 889 0 0 0 0 667 0 611 0 0 0 722 722 0 0 0 0 0 0 0 444 0 444 0 444 0 500 500 278 0 0 0 778 0 0 500 0 333]/BaseFont/UESNHP+TimesNewRomanPSMT/FirstChar 32/ToUnicode 30 0 R/Encoding/WinAnsiEncoding/Type/Font>> endobj 21 0 obj <</StemV 80/FontName/UESNHP+TimesNewRomanPSMT/FontFile2 29 0 R/FontStretch/Normal/FontWeight 400/Flags 34/Descent -307/FontBBox[-568 -307 2000 1007]/Ascent 1007/FontFamily(Times New Roman)/CapHeight 662/XHeight 448/Type/FontDescriptor/ItalicAngle 0>> endobj 30 0 obj <</Length 327/Filter/FlateDecode>>stream
+H\j0 ~
+CI6N ! rR[cdfp3>>KINչr{L Slg)~MxPq=kU|Pr ';\p`1t
+Sy= P`%ƿ6=BV|7+9{47b G *ִJ(i
+Oe|7A)_^)bF@2gs.3G#YLfƚNxǼ3N:zxAxAf-::ryconν &&<f`n!Pc߹_T[
+0
+endstream endobj 29 0 obj <</Length 47999/Filter/FlateDecode/Length1 104171>>stream
+HytWǿooޛ~! " la- Eq)KZKa34XRT(-D HQMKj7>t߽ߙwgg潙
+'?~ tz(wBv8`미<</kR~RK:irf?>%­îp끧ow=;ά@;rgdVAe?V rcrF`\nVxL(g>iHC P~FM$" *D8P9p1;h4n<g HTcg]n욑cGc㨱cǏ-Nc8!=ʁY0$Yc/k^/u9M[2J {}WFYUWA?jV[[ M
+}0CF" `)^ aI YeGra߄g>nOP
+b'^|^AKx,:[.H_#3vM&#8u3Ha7d8"K FDeL$j
+RjnQtW4PR*ZZZ],= ww]u (H"n{0?C&I&7c֠ Q]؇)~qm/^1{2o bV[/^3f|Wn|:7T1n|Roeޛ]R)Ge|mK=ƗyRo/8㋽}Ɨx_7;eBd 9hf;ddX2G-c<=}Ra|hTZ"Y"', ')K%r9kD[",g",jG",˖H%rj|n\D;KK+KkKof\|nX>7-[.X"DCc(' D@DODE"JDQ^@DDvb/U\wUрDQ5}"*! jDTb@DJQun ȨzucTj`Z> -46˥ripD.DZ",H KK!imDZ"H;C%htD:["?2DX"]-nȝvtd2;nK&Òa 6'|> 44Hg^}p?2AV?ׇ*҇uG*GY5qǬ*ǽoUSO61?pqÑ>GG02pH7>Ϫu*uY2:fIѩ0aFgŒ> 3:ft.R00+aF;m6|'Ecs-M-3 yk'Isp::w;G[l;XlԎPNwX=oԾP:`;⠯'lg¨á:b,j I5-L
+?&XH E⽰Cu<T"T2TQ?|#4|>e<b98bv8lwϊyF+j_#6 *JD j2ğ&$b O6ܵ)]֋&'MlXL ^//F6D,AT,E*:bqȈ{?WyS+j` սF\QG41-VL&KK"r |^ܙg@dMQIyps{Z:OiԜZQjOIzfl-=Kh-%Him*P9m]A:JǩN"]**V.!{޲/{r̖#r(-#t9CΒsr|NNɅr|A.+*V˗r|M!wr/򘬐')yV^UZtF\j7Mtܺn=7m6s[-n[vut3ܞnonNmmmB:kDTH7u+;.z~Pՙ!=\c8˄א"jѐ4fԒZּ$uNpiMGi:͠Y4 QCs4OEz5h!-DMZL@hjJZDZEPZ$zZ_UVW' "D0Q BBC ""RJ"R
+bAE)XK,R B- P'/_f{~gu|o#)uuz#_ˣzPJ}}WߕzDH~cz\KC='$ZO)zZbFzA/yI/I\?z]K3BzCoH 7%ίүV
+]UZ#HHGCwtǑLi^%B$ _:b0K' pID>3
+Q(I(Ft$\b*J7T1 $s0GR1$ @ұ %Hc1K,R,X +Bzc%VJVajlZ\:l؈e(؊2
+d+rEWJeIhgh%KC{C{e-T SjUeU3Yiud),ʢc1ښXyٚY3Yc-bmx_X'$묋ub)2,C~i=l>G^<˓2`d !Fbml6V~emfml+/]mm5^o2}I_nmK=i;G#==J?hq 苁(@&`2I\lk5~ڇ8Ļ8p\O)Y\%|/p_|WhJ\G U+tŸzoVZ}kh=nu4a- fl)lB tZZWU*}U
+KF/UjK5ZRT^z^C/=B/եKңR}E#=F#5mi&iD4m6MifMsڦmG۴mZ66@[z=8=О@'z L$]聮@7z HR4z Ƞ=Lz'=ЋMd}lz ȥ聾 #
+JI O5Yv9,\[ϝ?dɩtկ]wHnc47׏?kv;|߱Ë4;<ϲ`n^WV **բݪn
+zy|{O~aդ_} HqsdB:3ڃʯ7tܟY,=G<X!i gH
+w^ir9QNjj05fKHxRxdtZKb}Sy? WevWY].?SWa&@_;[4x0xP*\XS?gNj?j
+ t05ĕi>V/?UtwX~/38*r?{5%Ѿ?"Wm櫈}Vkc? D(FFtӥ~3aPQ𥧹j_8ݳ=
+$v !@&"c G[(X*8,B %d oe%ce.]IJꮙ}{SR=eO;&8Ŏ;GZfjAk`Mm^۩<-V7][OֻzOOgmlt9Η8SΙrSb+j\ ?DZ8S8܈2bVFdt1z# #2r<cXkT[AqƸNsu~/iT1eβ
+x B. S}8}pA8Wm8
+GVŸ&LSu#](Qa4U0c6C&cȀOdhB3Z
++l%!5Kt8/ 閭etsm'^}D_O<Fįo@H/WībxM.7ě"U i2A&ʶ2Ie,Qvd1ELb. 1S1K٢HX) z.~>>c[ `k133 #ƙ`1l,5fMX8k"X$,5bX,kZ3ӔfQÅ,Z6,%|Nɛ-$֎gX2:ά {ue?{>6}>blՑ{g0;w-x_@]Q{Enb{&j5j5֨h,%[b/i=7<d
+Jd?EfY4?y/gy?Njy~_2_oC?OS?/d3Wo[&s y>?PrPG
+R! Ch@SejP]e@
+^
+l0c&c
+vTLtLYIUW)+HO]+v='b?p /q00p4d>Y@Ed1YB%s"_/j%_8J y$zAlߋMb3oN :Qj!]JUtjFItE҃ͣ'i>yFz^7]'}L9yA^򊔒 Bh(VN([򎔑HʩFuJ(6@848ZCdHЅ!zC `$ L0U%0<X
+jw}X7֓e 񓩛`)MoϬbN2P3̬e1뛍&f hfa1qUU~]oaA j 0ap iHixކkTowl׶7w2Q
+YQ$Ήbq^\%L Ӷi\hQC۩ǵmMVM4M5TqI I;,ډ Q.4~_6r6Q; ԥ+<6<kiK&B>V_/ї=x .)]2H֐t`"d[N&PYSp!#e-%;T&eel/dLa6{>_8,r"O
+H!9K9RLInKƊtȀLj.Ew )R='R$B{HR<8=P,a!LCh(e,egʔI4+?Ik(Mk:4F^TEb*`E}B}oo7 Tl,E+;,eFci]Z%0G]F/ǫAj[ѯ*UU;;8$fXxDdub֫۠aM6kޢemڶKl!5-=#cV]vݣg/w8hpΐr9jO>?aSN>cs~6o/YlWB[fW_~6~nm߱sݷ>=w/'O>_PxV+:W|K߮~uBM4VMC& ȥcD:Sp-I[
+{<u"jj7lV14`p@NрS偓 \<`oeOg;ۻڻ'wڏًWO%OvD9b qxGKG#1ɱ̱˱ N_g%vF:ltrq1겻B]aW/W 4XeU*[խVcYCtk5Zj}cm[1Uh]M=}9";+#eMx@Ey]q7wgތ
+2æ&iL6im&m*'1mCLZ[4&FT4↸,+Ό AP4n3@Iss;~=9zOMM@s+N(J+^"֚t%ierMKL;6Z7L3JGwo =Mq58p::?"7ԑ8hpv3DKur>J.]s} /ƿ嵒 KK{ n%\!M&d+7;kri]Fhr˳??4>)\s^[m)-o.խT
+ P `%܄a5}^7 !xA8+'8ǡŸ)(|0 -xށ._a `$އ/0>mǐcja;c
+4 C
+׸1c1>"T A<cI8 ,Óx
+v`G)
+p OS6dB4hM4fQ>l#
+i\Gi-"ZDi -eTL淩VJZEi u6FDJSN;3I.M_З}M{h/t!:LG(TjMf 4a2̆a! 6,UTF'4tS9MCJHUTM2]אj<<K ,Cd Ო2JF+C:eLP*Lʣ*WUJUK겺bevvvvvl&[(eLdGITHVT̐c89^f rDfI2[r̕Se&rgB9Y gB]J6_. e\$%r)rpLD+*Zk:^n&YnQ*JW*FŪ8PNTJRɪ:g3Q,?y
+ʯy4,RUgEuUTwC]UߨSz婜x:<gs!<څd7Cunlx o>vF?Z &a ! bWMEV`"BEvv"BD(^D+CkZ{$`O%Hɢ(:*:\[]Su^]*)z1#~%>c1Fdb/2>$&O0|s)2>ɧ4|s9JU\͗2_\>k\|op[-;|}%&AF09`MFn3"#҈,fa!bZŦ5V5j-m,m-Aӈ7\`ZTW>w9sRE]v邈􅅥,@( DAkhAP4l`\! ҋmswo{T*rT;%Yjr#^!)RSjIm㍤JKԓLɒIli %Gr4&TIsi!IKfҥ/i#J[i'tN(%[ywEJtR =R(}2G A2X_/e a 򈌔Qvdq<.Oȓ򔌗 2Q&z+zU_ P/ҋ쮸ϸ2ܭpowJi~?s<_2"ϯr1/,y%ǫx51o;y.|>Χ, /릅ϴtﹿUn.bo[N蘉kf6&7qu;t2y0l?3Sf Xtys$3<
+hH4<ƺ>ߥC;uXQKRBr&aRX.0 ]>,V+auT ׂv=}qw{>Qv%虶D5u>w[Bӹ
+{ۈRP]:rq7SWzROZ@WQyS@uTB:Q2t1CǑn3(!֥w})|ӌx#
+=&5NRC* #ś)2~|[Z7^My*Q:R\U| ?,WS)ECiV$Vp^4u&2}(Ƴ t6,F3t
+ı"#L/Ck=*_ ,K$wUqL4
+^4TFG]> &4;(iمYKkhjfY đZ[RE j>o͌[}͠y
+*m 4Wu+&<|Ǣy)q8q:q3IIPYg$1:R &sEͷ><gwフ?LyeҰ8?-BE_TPsg$4=
+B ^JSP^:jFcǠT1o lWJFe u'=JZ>}p~C-|
+.YvE/,.cI+֎N05Q|64j28M&bLNiILI5~ӽ;{=s<@ +"m:=LuҏI2DO07<kCc}k $0}Jc Xo>.w94Ji;t+AO8} 6y^a_u|-;) 1+m򝈇3-j?a?o7D?O_m]X^AaDh{+l"י߀``qJ3kmQ0K?n+<tI1 ʢf."|
+b%*<DK$<ZXW
+MD|Hx&QCdRG#Ƚ
+,4JwM1@n2-Y ݧ%bM/YIWAnԳZ趨n
+Mjiz`f׽.FNm]>ŗϏ&zLVIlI|NqU£–5EN&t4.(04r̔[$=Cn-*[ӡ}oL<r0`<sܚ'.58(kI+0tWBK26ւ[$8K3&*(eIk++/$( 4Oz0/^l='6[|MyhG(RIG}-1KHE0SLNkr;Mдff*c Wwż~E'yCqJ߲FniJH1Mۖ9ܔvFw"S
+t2^{W_؀ڌW mDCS0Ufl2L]<`/mw`
+9ܒ䭈
+)oV|TWIGv'W,y|r +`/ ْⲚEe.W]Rpd8)!%1z4oVx4n=# QrC!qz+ ia'Ն
+1V3?p
+]⌛BgVN5p"q?T l}Ͼ;Ǿ_bK|>;g;8l$.@SQP kNJG7AE-QJAeb -eCju6U"jMYbfw?=w:F8y<,#G8‡. pPQHrNU]kŒ^,-}M&?.ya8qT"Bo^'U=^
++w㊢,_wmۡl:_iPxQnjv;7?L奔wR}t} _o Ng; g-[~dL*,:8FѻݮIjwUhQ,qKfh WhBA |Iл
+#2NG--0T@!A *D׺n Uԕd
+-Lʏ eDzDzdlcIhm|n֌ێffρ)Q5< չX"P17ZMb\z>ŒE@Wzh,dSM"Z#13,@tlg(M8Bba,Ola@s۰qNwGѮ-ږhx Z^,=Jh6x2KPv`9IpʭM0cXpt xJ:t'SSnRu5r8fs} )IDTtѽt΀$ED'%".+!$d?D"^x@J({Ct`Dr|XYP 1%߲|?=]wA -|x)F*L̈́uZ`D=')Y^"xi!IQ4apũ$pk\7N!/`T5Ɗ1EZi N,'"E3}cT;.kSßLׯ? ֦fԷ zg͋e<|+[}4솂e'룋{/_}Q)o@,+/ͪͦjᬩV"TGr"C5")F ԨKjTB)nA'<#1fe{ 0!f C>\d.3$16]Lgg([-IuV% uH]*" KHA[;D^G?yxpLbNÀݏĂlCX74M?MnzB }1seh)<eUvr8
+ Vm@RVh
+*"*5P5nZGAmU!"JCC"'U^;&!*u={dy{^".-WV-V+YL|ƢN>PZ$Knn&oOu;KT~H
+qX&a G`tv.螛qfڹbbK~#y%BSO[V
+]dV=#خ<+?.4kEO.璲 ҲZ?ĪqÃ89w!i4[5o ,Q0?G[Om;#&ٵeԖ󖐖bmY "TX]$>~8G;Li/8N~]
+po>&pL~nun ~Z{K{[s򋐈FD)o :d-шfH @00BԀs#Eaq9hZ:֡cռ$IHh_6
+P
+fTe% ^g}:q:79?s9- L6?|`Y67{jF[
++g=ϪkSܫMik{;hvaȲo Әj^?G胨 igc"SOMgwHNN,~cߒ%+r;av'v a/r]xz.}<u
+~̌^|$ƗhbmImU5;X Gln1JDcb`ZTJb 6*#0S&4sEultX~8`$j}~hx
+q8}"u:_\Aij"ÈN0f:-N698MtJiAs3hf厧/id+Cp4ߪ||KJDvUR7L1;Ubx2!jqK-m$҄B,3!c RJ23ޝaty"kO2E'%%4crIoQՎ6!ƔUsWf\Ǎ߿7q?z}w @u߳YNlރJu}8oS|ud
+}qY]}D>{e&zpnckcHFx6H?(uמ|-V~E /9ֶb׽owztlgTK ^NZv^ȸ0X+U w3
+vڝK%
+B{P[{!R|C(4uldLOD}= ^J;.Kɱܸz5yU\TzN oS¿c>|f򪺄|XLkͤ,LF侩>ZfE+NzJ啑i/T)T޺
+*nP7Mƃ!t M=[[fJ{IAg <~+Bԥ.eB_HPw3[/CCoO9}$nʉ=]|7pjS6tcv}jiDևh${]
+a mC}MZ
+\%hvoC1ܙ4?T~^4RH ^}00=p;ʱAGo?-'3CU{z?څ8{bwP?Ǝ닩TLzF!yw:Ҥ*m̾bn?.[ӐEXi~/mK^MhbtW{fnE ZAkGPRcCVuGӪQt_)lpVpݑ1O8<5e%a4+?n9XYOSo΋\LHf&D'ss2.s vyyN88t 0tET*nIO0ĜI*9)2侹i NOBt ~hB=fgzL
+I#&A{*R^i5diѴB;YsZ+>T΁Ѵ;4<8p 8 yb(DG[F %rTbW
+EӺA5zVu<R$YR\P*T9:)N>Qp@(r::
+`} ?UH Jд7
+vPz:qD{mS)n/99%'ML.\UПމEӵ`-z2؈^-;}| 3./&.*zxkHObGl&Jr2Ir!\M%דcnPgPc8L~Ȉ D54ZFkH zk6|&L0/aє98S839;7}nmwfh
+bժ[{(?c1p~X4<<q tFRЈ
+nzs:ȅPeCJ-;_Ue
+Q)
+t٫Jd\
++;#[`o"DF3u
+^{ZJo
+՚f\`j z'F]:#u<D܄J*D1"2UT-S ٠O*
+"YKxAMय़Q8kWPzee8P=v@IbRbq4# 56f1wv1ў-yS:@nOqW;Da9,Y~^09i:O*pT1ZD
+5Vr.gD>7M5M5T_~͔JtB֌`8E t݀>RN_Ϋ5 DZc8N|I8sKsOL.MNhnm줥qlm:Ԗ%iAEVc! L
+,~U'S*ÏuS5+D/yvu<yy{y?C )DcP?[CMPUխ6 i4lHZJO=U`x(/ӯGd_.ك(;ckك屺U6I<NP $'o%yTu*AM͉g7JRd]QM&^X@sl=Q >m=^e@#Дz4sj}]|qKZD&ل 35,w&"ftkm2\3X״$#!`ZKOH"wFLOn K-Vd0CMeR@*̩UQ]D!JSBKN jsIjKJ\LO,*\m=SK M{R
+=sD!ЯpV}<t1e+kCep.TX'jbUƄ`EN098c{eY.b/DVaLN|Mұ!-jm}R+2N1h߶<kI+*bogT] VtlkG(gP555DP;-z9LlB$XXenܴ%A)eN/S"Lgy R)nxc-nwLd\%8rMx9'\ WFm^yd%/jPd8=::\P4RܱU75&xPJڐe\(\6֟toCu*9 Bw{4`|c_||q(uV{u@AR} u 㚏 zРt(N^o9nX-oX$'\ӫUuK`. .Pˁc`O<O(<m<J$G,^cIɮp_Pe9VWZn[Tц%lmP!4zH"pk%y{ɦU7s.wi;(T pΝQͨބT>OXh+cLTScH<<՟,[ .kt~$sr655ܟ<,߄- g\l.\e D'q!9+9 :}\ՎhV/{J%
+q*B5?\Ζ)KM9;8'9V&Ƚ7GsS" -e} QawT-r84Χ 05PYM)J%ɈMUS?*D#UaQ=LUՋQؘrs-j2KڔՃ;Ɋn%\▏'IM\8i WWorھڛ z-F[ʯYJ:+"2_##'6{a^{%fԜ'/y(lGi 2l<qJnmSXG%4 L'QamEЀ O0?6N&}3 lTa`
+H{x(@zwbdfX԰(PkjXZE1ļ^ԭ@<,h:"!Gwh(? =6|r@&>9=bg(o8P.1xtA"wm4kFBs2aU}_`v7'ҟt/"ӏt%Qw{}M\as҉g(Ml _f>:ia^&{:n2a;&d:b`73WlFG{mVc
+a4>M[a6> *ul#~F9G!7?5*H:w0ߍ7н S{ }`#^s7rn
+$ p 60xxlll?,Άl,3{ٳ@71v,(r{$hm-D]>ɦd>HU$#d$%!". d.H #DA!>)gN:;,Ś<Kʆ x- ϸ0]2Q^fq%W%a[YVث\^k TTrr$m o<R6k~D!"4jA7"5DŽW%9M`֠.eg~F{ܗkpU=s_@!\B%4(PyFD(Rg:(hTLҊ8
+cyhUZ-VVJ;tjy osN$Xwu{ݽ^km.ꥊqnb,sorGΑwEGm͵%+#{mEI{*^U;Yi246Aok]>It">cveU˸ cK2R59~ `޳~xL5\ i_ ~رLi3_lr 15-/ˏbSrniSo=1<=m<"'?P`)~8~ҜdL^j=62Qۼ;F滫>1F-3=<HdeRT>R"gP<&t״+e\) v?Y{:\;:s&'O*:`]VS)u+dҗ|kKQZ#!mv6V[iNx.RKXQBf`w|:cl~kS?:O4Op}=ސzToTU^11=/摚7>g4uau+uL2EL~>m~T.bc1| {;?a!|reOqN9ms9Ү<Ę R)p|9 CL<'i+UI;2aYK(buhM{Zꚭ؊~:k$}:
+xr2TwѶey;L%GY:aE-x)R蚯cs\ދ_kw%^]L,!|
+WwUOt.AJ>Gʐ_dt.%ݍ&_lQd?NMiI\5WN(EV""q5 qEEsdcN¢`E>s`|#65nj廑Q1a aN'GZy^TBeΈd7DGds'D+Cy8~:eC.]9њ&ɟ5lng8O$s5jk:rWōlߚ8.;\z歳ߓO={FM^sujnQL|k NLSCfh> !7)XQڋݟ9[|DRmJ</mSn/h9wtKrqۋ|o&v:--gsH=noa= ~`1/M5+^N<^R1r!J,ǹ4MmN ՞=Vsg>K)TA
+(mj]܋R9r7Vy~tuR&.ܟ=E
+֙{XUc^1y;Oćygx:ʡOl\?х|+&H S]amWU#r;̟X%ka&w3:v,RCU<ߒC0aRUw)e?sՏqJuqK-ٟٱi0kMMER]5s#YvonL1]cC=M=O.ds{^)gVjNQgdi91ғ/FmdWTG1/H
+ՊTsBz`eV3؍jd7ۮH3L|~>]?YrWֿӽsO7Nw}]HNř.F\E?_/5NǞ< J/f-? ԿKBPį$vn/]9GA~ ;%8$Ri8 ~wAM]ls,gv㼦d߄f;v1wh^~ڍw>\Fa8ԫL PrDGG[ңqxhk8Gq=qp=š~\\Uޥǐǟꌾm.|0w~KϢ?sLƙko3,p0&Z<_s=VpM;6uG|)l ֳkې*b@JACvŸp }7o$H%~a/W ߇*C}ɼ D=S}UX+ĺYj>}\.~~mtCxQB1 u_|yn/'-75Z?[߭A(mLv*K0nI"EzL^T/પ+7!!"hrA#klᑠഀ $iVcNmq
+#SP`)SvZt`qZv:18*V+99$?d~w~o*rަ佉t ?@Ohzh/@S)tuai鶵ֲ"G&
+5m2k
+#XPq ` .R:BME#!ǦG<BYw='̻r?b{NL⧠WT,ű%N_S{ǵ)DKx_͑8`1*mSvi!ا8I賤@{wZo_AUzoї=
+*WX:X圅@T9]M[IM0 ~1Yq}t<_A6\쩹[.#YtW@||u<-QveYZŠ/7
+;#X*w+v=olFR ,`~wQڇDo!9/"BeaPh
+fŸrw;1+'wpYzkh,cFó<GcWr٢È@؞S5w_ \k|SO~1\Q1ZʹaHUHW~J] #u_`*smP.q :QbF'Zs|GC,$0 u :{HX4Dn}FǨR;:
+H|yBǨǑqyСcU1Τ"{X$X$8#O(G\*q]rYYS{s/!'Nۗ&;-?2$I:7 &sᛕyX3'}_zlߍuy'pmy6@|naW#vc:c!qr66uCG{=N1]˝Tzg%
+^IaJ1\<qS4Jbj8ܐ>LgR1 `0 `0 `0 `0 `0 `0 r,](F6 i9_E*_!C~ٷHط?=}hHki~ڭRǩ5)?ZopOo+[Tྯ}b}{FxiߧhW8 s}[B4j\m Kz2ſE=Ws|5Ws|7G͡*_͡*_͡?:"ſKܷC_p$gC#WK⏐<ϋm$Oq-/~o?Qw؏GI 4%h2fdHP- APS|]&ɑě* ZQ>Ei-ZnorIM"͒ikP翝65(~E+C퍺 4xP{m ޷P#Z_UbZ}Iެ) Y4nߞ9kɻy1ՠFNlIO2,)IO/i 4co3$ߖGNQjL sMW@n)=TtٶțV6 h^jl,m7{cd  UemP5ym'zEfs&|meWsYꪽ!d鵒}KJ W!ׯڀ2YGfz訪-z> %K-$6d^@2f&
+
+ޑjCHQ:JiҕTEPo&Zs9{UoϘZUD3KV ۤ;7OfhU5Jk[ǟ`[M=wy!VX\Y&ΐ(WۃOaKsx}El#OFHh-\+yb}rX~i;,OQ)C3c㊶JVᎳ+Z]\~j:mߪRZ<V#Jٖ?Ďg%xo;Fb[; 3Ro`8m uEǾ`k.wt\Ә=K3nrhe‡Xֳw\Ul}SL_S
+;Sj>TgVz ʹL^ ry/5I;RScB1џ跜vRX;.ᕊ {'l"{ggHLEPkkbt.O'3{1T4~Q䠢AU j`:/yrF/)pJSF,Vc!)f4̹1J7" ì0I2Ká.CrJ.-y$3쫀BRXVV̜RBJJ))-eA`)/LdrwT55MwmM]M4Fdf[JZKikF͝L4=d]KzKSe_)`'.N Y$p 2Lސ7em)yWF9F8/dL2E4.3d&l#sV曻EXR@>cGɧ򙬐JVY+sBlI6#|#[dlCv.-wG>/rD19.'ὧ䴜rN숋rI.*?/f^rSnmU~;VsWܗPcy"ȄȂȆȁȅȃȇ(((( Q%Q
+QeQ(
+JAe
+jj# M-m耎D"
+] ;^GD/F8pF !.
+bcfbfcb},B,b,R|>'XOcVb9k9X 5l6l.Ʒ{ppG=NiYy\ q qW3~5\ -Ư w;xGx' ) be:gfd&fffe6fgd.fe>Y,,,¢,FY%Y=j˲YX eVe5Vg d-fe=g6d#6f)9[%[5۰-1فىd; _cw^>t/c,]c<0饏~&28¡7&sQ|r48N$NN4Nyٜcn8srs ~ȏ1?2~ϸ+k9\ϯ5n6n.{xxG=OiYy^yyW35^ -w;|G|'BAFj:M4f̚Ej6ͮ94ܚGj>ͯZDj1ВZJKk-4Xk4D+kVѪZMk ѺZOkmimʹЖJ[km4\k4B#5J;k?փ$۶m6vc۶m۶m۶m;ᄁXն:VY}k` 5&XSkfͭVX[kguNٺXWfݭ^X_gm A6؆PfmQ6XgmMI6٦TfmFlͱ6[hl-̖
+[il`mͶŶ6v) ~;`#vԎq;a'픝3vy`]+vծua7ݶ;v}{`='Ԟs{a/핽7{`}/վwa??!#
+"#b"b#"^K !!1 )!9R %R!5 -!=2 c]2# "#r"r#m&?
+
+0(xqJJ=,ʡ<*"*2*:j&j!
+
+JJʪʫ**jڪjjjjjjjjꠎꢮꡞꣾ񚠉ɚ隡ٚZZZZZZZZڠڤڢڦڡڥڣڧ::::::::󺠋˺뺡ۺzzzzzzzz<ps8]Cyha=#ydQ=Gcylq=ybOI='SyjOi= 3yfY=gsyny=^ ya/E^Kyi/e
+^+yeUW^kyzmu?@
+"PEPP%PPePPPPUPP5PPuPP M-m]=}0`8L$LL4L ,<,",,2,
+*:l&ll6l.>!1 )9\%\\5\ -=<#<<3< +;|'||7|/?`HbhaX$EgxF`DFbdFaTFct`Lbla\c|&`B&bb0 23S2S3 233233 23s2s32
+*:n&nn6n.>!1 )9^%^^5^ -=>#>>3> +;~'~~7~/?PHRhQX $WxEPDERdEQTEStPLRlQ\S|%PB%Rb(*+R*R+*+2*2+*+r*r+*
+*PTXETTT\%TRTZeTVT^TQTYUTUT]5TST[uTWT_ PXMT\-RZmV^QY]U]=S[}W_4P`8M$MM4M ,<-"--2-
+*:m&mm6m.>!1 )9]%]]5] -==#==3= +;}'}}7}/?!=0ù9.w<Gţz41<z< <'I<'Sz*Oi<3z&Y<gsz.y<^ z^ċz1/%^z9/W^ūz55^z= 7\u`["76efn-9l+CNNwŧ;vRffffffffffwwNffۛ-R$*T%
+)NLtLBfc'tczЋчb7GUX:†1a,b='b?p 80#p$88p"N843p&8< p!.Ÿ2\+p%ո:\p#n͸6܎;p'ݸ>܏ x1<'$x9<"^x57&x=!>3|/%;|#~7?'߼ /M(8 IN11y4<y<+J2«j:kZ6z>oF1o›f9o[Vip O,縕'$ޚmy;ޞw9m\<r'O<g,ټw^ޙx. ʻ%<SocMˬinVlz)e#u=ؙt&2Ӝ<
+tOV Z-E\ [ M2QlˌC͉ʫ "nH̐F茲F />K>6%fI/A'۬wK'[[sBe[=  yhU|gqC6Vb=UjU=+ +5-j^^3vJ-E#)KV ,-;^.ٶ5d~7Z^=+UW>,[C[M*%V)v k[&>,X6^ rSs ,3.V ϨqqVϦUlfsJ/;I1ئ8ӡXP,S9S9S9S9S9S9E* $w0&GFT@dnSҲ7pm]xuI[˦/vI,z"7ԜS󥕄0 "gE?/}h|,L5QEn9I_@V׶Uf=Tf޼ڶڶ).L"_JA3$=ƫbJKm6NH d )ҔGͨI+ƒi KԢfG_Ս!*+]e)eV4!gբoiŀihfY/Iճ֜UE
+f%"ץRT*]2aJ"JsRq
+
+uB{e,WET^ݓ{U*!P=^Ԏ}A+GD ANj5f6$'o!Wօ-IXyqQ^qV+OzsK!j趖hIUWVw%myPF+ k#鄣T>ByQW&;-eDzS]5QNt
+P!US:mDt^˿V,kM3Y^\=4fޑ=PlS"EcbH}?b|%ã\`al\n8F$ dߥ$J{qw<[oP$?uqqow
+`7یhWv>_??_&C=PA#Ќ#:3~o
+up\+S\up\5*\*{{{~~sJ>pJ_ |/E |/_ 7p#_p#7p#/«<o'i@р
+: ]}^q;Ýp7>o|̫1Ƽj̫16̯1ko_/ _]w <6yL\|}m肮tSTЈ&
+фfQڻ?Yz@{V+5QP\|Bz?|5܃҃JP7yԓ}V7,A^/??{e=%]6xi -ZKjzlǸ\mjWS>W)o2a|<ϧA% =p== z;9\~ԡO+k Ųz',^{ac؟>gz:D^Ϝ3/~˽_澚ݡ%ιwνss\z]ZKKwi)s靻EKh-ݢeam-y{?wR˼B | lRHMF&qN։:g(Ih{Dr-l9n϶lf˹ b˹j? WM:&9)LaLaL!p>rb99!hˣ-L{=S
+ٖg[m9-i N[?L38`aP!q|oSމޖ{[ήU*vW]bwU
+*vW]vU쮊U*؛b)b†uM%!l9o<宼~:8$"+_s7x(h$EFYQQ4RFPFPFPFPFPFPFPFP(C!e2D Q(CQQQQQQQQQQQQQQQQQQQQ; FN#QH4%FE#e8e8e8e8e8e8e8e8e8e8exeϝܩϝܩϝܩϝ?wLJ7^>
+S_;S_; O7z^NnUzI_ K۩۩۩۩۩۩۩۝x`7O<vWOOnvmvmvmvmvmvmWy2C=PA#VtD'tF ?O' ?O'3 ?ßg3 ?ßg ~7 ~7 ~7 ~7 _/ _/+
+o[ opnnPTЈ&4:<k~j 7o8`>ϟp_:Hh@ݟXF?Y+ 6u(s6(',{|~SO56^O뿷z7vo?R| ooχ}|zw^.y~<y?߿oo~9u}x<|c@<:Eǘw͛EM+)G5('e'ۗ{M5l_G}u4Ɠ60u4O$'[>ɖ$g[>ٖ7͖7[lJre{pmR L#lΖro˽-<`˃-\H-[.U-<rNWɶ<l9w޹+&9]eIPlRf<f\eIBYMuIZcZVvZVMZbj-\Yj-\YjWjzZOVzVj=Y'++]'dA֓z;u}vFmFQGkԑ{wd'G:p?eɍKQUyά }ڮSCA[Ö(~OOI]LIW4_I-M_K4kiZ&4}-M_KҤkiZ4}-M_KF٘/eclnwW2_]Fu.e2_]|ueW2|u.eTy90/;~y˻_N3b Q%(Sbb4_(Fb#_)̿R,Jn[/dq`-/'CZ,b5fob[>-O\j.5ۺ|ؼ/y>ﶱ[%$wqq6inW؎ea>g{ss;;sνwˬݙvb4pχox}}}pcccc+<Kol5xs˿/55>;i}yˇ?3z{,/k,WVnU[nE+j\W߾N{s\)wRaV؂؆؁X.=oRpooo;on o›& o›& o›&<w<g 3x<g ]<~b____錉Θ/tDLtDLtDLtDLtDLtDL;1N>;q??Nn؄b3`+a;7] c# ~' ~/??==?oVI"D&L$2222222v@a PPvDGɧ}| -[ȷga
+y*Uȫ­p+
+­p+
+­S_W~_7 ~7 ~7 ~7 ~,"(,"(,"(,">
+#( (4J#(4J#(4J#(L>#(<#(<#(<CyGPAyGPAyGPEyGPAyGPAaFglp68eû/(./(PB
+%(PB
+%(PB
+%(P?j_߂߃?|] ۃ[{}l=b{>:_ko| x-|7Bb{<xǾ+v F֣{!n#!x}y]~ ~ ~X_߂߃cg[|߂߃cwD~OGx~Gx~F=y]~ ~ ~{X_߂߃cg[|߂߃c=!v=+{2*2*2Z?] c(e2U&Se2U&Se2U&Se27M yTGyTGyTGU3*2*2*2*
+\OeTOeTOeTOeTW
+_+|3 ?3 ?3 ?3 ?gU\eU\eU\eU\eU\eU\eU\eU\eUXeNUeNPeNPeNPeNЍ6ڮ䵑F^\\\\\׽eP
+eP
+e? {sޙΜw39yg;sޙΜw3۱ ~7Cr7 >m?<O94ɧO'N>|:tɣG'>t ``$I'O$$$I~&xF<#ޮgobw"E _~d@tLtLtLtLtLtLtLtLtLtLGtLGtLGtLGtLGtLGt|ǹPn +XflVlvob vǞwp PQepS9S9enPnPnPnPnPp'ܕolۇ/O~w~z}s
+~ֿr~&`[ ۱;] c& ~' ~' ~' ~ |/ɹ/ @Ax@ %Uu
+ HHs[.wso{r|w|w|=|=|=|=|?
++WX^aT<<Oy*
+¯+߻W_)~W_)~W_)~Z|>ůRJ+ůRI'şRI'ŏ?RH#ŏ?RH#ŏ?RH#ŏ-χ)~G)~G)~G)~G)~G)~?(?(~7(~7(>Ƶ.'(~'(~'(~'(~'(~'(~'(~'hWx^W7(~7(~ex^FoQFoQFo7~_W ~7 ~7 ~7 ~7~w~vnvn;;;+pO <'8s9pw=p9Sx
+O(pQ8
+G9n;Ј&ts_K\\S[?}ϞośNQcޜCg958D9Q@uCS=zzzZЊ6:tl2C=Ј&4(RG0$!! aHCBmSцvtH0$!! aHCBoMGB8‘p$#&ބ$%!, aIKBX’$%!, aIKBX’$%!, aIKBX’$%!, aIKBX’$%!, aIKBXoMOBx“$'&ބ0%)!L aJSB”ÛÛÛÛ%-!l aK[B–%-akKs_
+:gڹo羝vaK~O|?V8Ч?{T&~sZ ת/?xٛ3C=Ј&4}n#Zl vEQQpv`yFWhU_ԀҺ6ZFWha-lܩ=.qyO딄{x_O7tO7t@7
+ng~gKtO t@WoqF-&N;_1u$Hԑ#эR</5[dsQ*Bپy8r6syطT[*ZժzޮͭS߷U}g#oU}d۝z[}_7YwYkmZ[֌lh~LQz3j3\dooۛ!d5x[l`3P}ՃU@V}sopz9FV}\ܞ;ꭚ[*Ҫ*6Wd>[yUoڱɾjXj/ү:ѯ:ӯ3:s__gu_gu_gu_gBƱ3 ? ]~_~_~_W~_W~_W~_W~_7 ~7 ~7 ~7 ~w~w~w~w~?HCm%qTG%qT$|gD_g=YOs%((vo119lzFa9[<#|lK.?}7aqn|N hDQ2] 2] 2] 2<l>2m:f @,rN99D|111q|S痾OscNQzt]фfmhGgu2d֙򾴠mS݆bI[g֙;o۾;o۾;oΓ'C!」tT\F;>gWl
+`vS߂r=^>ۏi߸.\yy}}yt9>:ǟ_/ýS^_>wܟ=z;TW/O]wO|{xy~}_j6us'΍7@HCR;JR\',qPR:
+rXbuIMQ u,`PCk`C#Mݏiۏecԍ=@+gҮ<={Fcr@tؔK0/(*R\40;E(Y/
+`!) ƁyB`:yͲYs: ,ᇈę]dH
+X؀YU\gϑ#+)2R[t9 %^y>gSwv9)a)5Nd܃EӾu3Diۺy52\%հ-ږl˶g.[mv6a9'lv5:bU]].bSI`
+Yۣ>ܿ3Fd-.WЎ גf.2]~/{ȯÜJ_}kQCjD յH
+SӖN3Y9miRMMӖ:.XW]7mQT%T+Ӗ[;,ɎTG5eP}@sFwd4I'?(: HiHs!:G:$`E9z+O?y+y dni+7 L c_BpE
+a\x˿$!Jn}qG+0XX>>iK%Mf ![D<RL/
+~KIMv~vvy#NjA`ȗ#rgDi'Z3R_?~~o=]Y*L
+nAw)oy"7*rD(f9.nA?#QDMFID}`jLm'ߦv/S;ܤSFUwjwf{Y
+ th4^%]$mw
+~nQ>#aQM3|f$f0d 2gH =H$ AϤP0tgs潢@&F>˛T%]b"+*XOT1rZLb2 uv9xWv_8uOnf*ƗTns4xUzCMU5p΁ĭpNW,D*ʜ**ՓZr^Qm*oi#H'ەmVQu UVѶ쬲*ǧR1f*ϠUL[ץ;Ma߾׾˾;^k+(v9V9Q{R"=gK!1b1)L o4X`l(f8_' G9JıAyDm_#֝8UuĩDƌqvV9T^eG [,壬8V$~"3vvǯIGTk4%F_qr4FlDmY6Ya6l@kt!ț>m܄0̏U lR%cUI܆uED AXAnYh °li5NE M:>T='<390:@Ʊˌ>;<3؆ wq@>5@Z٧}Dv&Jjd0XkĞ b֌>#jv7XW|A-\<k<Cñ_Ju ϖ+0fCx6R)<<U*{e:XHy.QI~';<<<‘N#2C;v Z 7v GK\nkRJhڤ6Y[)H2d`>`6[֨˛#a~BPK< Kϼ<f_|,5i} _Duu]%2]@6Fj
+ fF;tbЮ~HHo7r6vS@| _/ fe6b6^
+I ڌ@3
+
+endstream endobj 16 0 obj <</Intent/RelativeColorimetric/Subtype/Image/Length 237967/Filter/DCTDecode/Name/X/Metadata 17 0 R/BitsPerComponent 8/ColorSpace/DeviceCMYK/Width 512/Height 384/Type/XObject>>stream
+
+
+
+
+
+
+
+
+
+
+ 
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 
+rS&cD5Ts6'E7F򃓣dU()8GHVe*9:IJWXYZftugvwhijxyz
+()*6789:FGHIJVWXYZefghijtuvwxyz
+4
+ұ4׋ XAg
+g>uBEPb iknj'v
+ }~dkOwEqfn
+0:9(炢Uuaqb#N'ӷE}EOM{
+2^͊U+$H
+)~<5FG }Z|CC҆SY L?ڳjkMUF$$IpP68!f|$SU|yuuiCSHJgH^~~#^:;sOSp< zd!dC1@{q5`y>T(3TX0 "=Ny?%Πc\fɈh3&r{8A=^'>:٘lAsvk =N=jK?HR\O$"YY@0v-8҃ S*p`L<0#hThZ
+R(F*
+WQF>\Rv donVVqB#ҕn7Z*_C: ^7Y/ 0cTPe˪ʃ}9Y"rʻm̳ݭ*N'˦kRt|34PRaʇ4Y?z^yQ v|8Yr(HHIEJQ:0s.jY?:|o0P#ɩP@'/VPzFmS*n ,#oĿDzz/ɗeEU<˭[גK(6/3ÎƢz`{ƌ~3b
+znh(ǝW[P"
+hITBxUd1z& 5O_Su9?6 * )BZ$y8
+TV)zKՌ&;}M8_x3mm}yM|-x*bH,!2k٥XO1K:Spl+-6UIL<@4u܇TY
+>
+'ArRLME=D1b,Ҳ v
+}$v Nf-5q:';0{{{wk1.JTY-)8H#EMKYBOI<UbU]Ux0wjjY7gn㙕eAE ž+f)u{
+$A$5/ynbsIPQ2Gf^d(:<, +j^1IGI1杝05ٟۧ3՚px 1L0ڈqjjf偣y.972O`nF{ږg9Cvq$Gp\Q HRDGI{Vom6b a,p:OYh|w+Ce TFj*dVyZ4PY
+28x
+J_FǷ+rnN([8rR:[SYW<VVŦZ "SMWO1k64m"ƪvMqÍrZP5-Rj "a3 ֲMԬ jPQs_<u; ˙ ə7+$C[|Ɉk+GP[o>w-Px +T)>(
+׎YeheĤ!3'T-[U(.!6'5°o[EfAkZ'NqR1,I) k+;n-r54 OE*-Zzܥ&p~ 
+V/BJZpI{rm IӜ
+Ja4$
+ԅL8S4X}F{1Ʉ0#٭}t̩玢h p{2nU/ (db '4bPąWFooo hx]/~
+KP
+lYRZV1<6 r]'(ԏS=OS1OK
+Dq΋:ibx9bT2 #ܭjNߝc|ɡ
+P%P#dPПpPcvq &<K
+l3mSC"0t Y߇J:Q]֞Tc;%9a
+O
+x*Z8wXG"6ƜnYeubI$P)2`JcoAW5rБg 4ϭc=$=Jg,뛳
+
+
+lEi5MRG)I bK1ۃ;-\@1$mC,Y+%
+5PeZ}mٴ
+X86
+A2"uQk?L
+'Rzkb͊c86QV
+V23
+`} I8.V|WXcK$"IrZ'+=Da=ILJp嬪i<>:wBar ݦ0ӷ} F-ڙI6tmW^IQY:"@xP{ӣbF ˗ksi<ơ
+I@(J1i)HZnHJqj|nEQ<\[d:,n+if^YDj(';GEE/2YpP  OOapɖrlkC[SG-+c<5 Ocm.h.Gt;b#N)tϒ#Zz8*ʤ(!1:zV%#!wQb9>s{MҴw%Qa$m
+/ufWo:\ 0%O7]r~pȘVhҏr]!
+P+ҪHKBUxAh]V_˴ɄQ1;iPGo9Ҟ÷1rgrS<}hWWUubU5Uv!+4n$Y~"T]VG(
+(7b⿦fh30x91IQ  wZ"~WdFkp9Bw7miiV(:);kZz{IY($`DŽ=),ehGu*Q5[OKz/c4XTʒv$]P/3 v3S(
+dco }{ '_1QIeN6o=[ʒ;
+Üh0bXyeuMb,ТV;
+|1-k/4.%I0)WFgVn%Va'Y&
+#e=W_yp7-{>{jdciP[BCJ
+ni;,UPbNqb1Ve'iCʦ`t TZq}}C4`;~e$wR UD͂`*cdF%̠wgZ
+GoVuU8Qj'W7
+:$$^ݲT1<iq<y?L9mR<rJ
+M~^rJvſ5zt۹i~rHA2)7׶b*8 F t~d,Gyd\0pU 1=Ýd1[e͹<V
+!*\^doGt) b"(~4:aIX@4-1QTe+ Gy7++_6.Kד::֜&ޟ1U5Sq2vb&}Nvu7odQ@ /N BI'PpfJJ`L)C
+] * 8k0I *Nҕl3Ғ*j?wlm-dj;=A'k%Y;r"Zꪩ+
+tun/|
+˘P\63 KXiqM׳fˆ@2
+/)INJczØTQeeqS
+u.OlEY
+9C4E_SՕb4s yto6JmA\`K:ˬ2̥ %%%$lL
+(qwJΥRNMd7rwn
+֜L-e@0*\&5;ϱ˜iZKw pK &OWYKA[2jJ,]ZZ Eoṕ_&B^TCd?q7ۅ%;b#6 ۀ5YKm[( vo:ϰԒɻ.RG$\#1GoM`\IRAkqK3lZV(,}}>znJ>SJ 4PT=XBom9KaGڔH>zTc[t
+o
+PA @T?V[ú9{vYR7i&T
+ pƑf;ɝ[-Bu
+D
+*7Y'wiYB="tw/c}JAp|Y;VE5K3%*D
+3ajձ
+;q]<8
+񶽄'jT;Ey)gSk6G:
+jn
+C aXGIQj5'nز޸'Ç\w/@pf+`xmEJVaؤrIHkiU)<n9v oM)= $
+6AatήkR<`;~{ho& x\Pv{NAG{ܪ剶/qJ V]䕧+T
+C*ct
+Ă-ѯ&ażI=۵_f)EnIucÇ~|@ck_Ò1?%` 
+/}K>ug ڱ{ oE]/5{@V'l@[ea)װچ!,Qsnba6F is׮VUяHQ)
+2 {np̡`6u(šrTfh*DGhSmo<줒 {<9F1!b"5n2 O쪟iٯ;E@UFnPڵ'QL{+/]W"cyy@\1\X`LqŒAi?QyL1=bsXF-pM~:Œs j)
+ǁꦜY0O*( Z̑TORV )*4Gɘ`ñeF&yْXOv` &e)`'eO\'(ZhivKag =rPs,Œ61i&oo~eD;1r ӅV/
+sV@ Mp|u$Ϻʹ% |8w)bfuzEI1nYޤ
+^V
+LDo/ U
+UY@<OWVmk}!T@":\~ 2'T`aۍ/a Ppcl 6zI0 k*$tXR*msml%kPH$LJY<^Ngu;UC̥A>%]<*Hh/éЏGKїēLQO4-6 $84r6ߘI)iU](; r Ӕ4浑
+v׷뙽xuvSCUGZ<~uu-=\,R_RL&?Qp<0K$б
+]vbIsWêZOʠ?t
+&l: N@Y
+x|MMS'SRw!b; ymn* l
+Vڙ>c~,$Oq. ^K-iXÃ(tJXpp7pc.烁T|4k+m'ŀEgEH);N*cǭ#vKťD48n.3W"OcsBVa5dx0
+@0#pˤ9B)j&Ƽn›
+2u.34g$eHT1R=]T LA^>SVSE5|%.:z<5TEMHUbbGy}JonoڲJeC
+rDbE
+'>L3$ mwm٪lZ@PԴcaӉ̜h_\n 4$ JZI1 H' }-vwqzGdXU$4 5}N'JDǵc
+~7oss.7f
+=f[lR@1ROY&[P!YsXH#qS8>:vs>?OTpbehx+ %Usl9JﱵbN
+JJfvĪQbGAW$7$0LI}tTCIP }73[͙oe-)$u L~*Ӱ
+B%wi`m%ҙm0WWUQ)w*mn&e(v|rYH'ꮸ.a=J8`bpIPT]oUkr(P5ڗ$0plpZӾFo/"
+ĞT>QRc,&r 7tZf7>'P&g1@oUj 
+Τ?4TAd)$ [*YL~ۅ)ރcX~+h:mY⹹34an6JdfxL$lͪ*[/
+a-[ۆƢR)*A]ܫ{$)Ŧ9XPf7?&a#]G*byh*@жűmIۆ%&zt̝o՗zuܟGV{Y1S7(ZPi;"H
+A*[<8@rV0ɜdqSMԼ3I*7jɥFQ X؝
+m۬s-R˱ˆFӬe$&$f.RiYI6nw*R=-OM{#Ʉ)CGߎ4͊ώ&7W)4WUp1@C8J2En#Yk"眻==F X1ZO>$sݔx0i
+A:Þs.dz[ː!w3j^۳@6"<?
+xH׳AnrSCEp{
+*p$Ca; v3X>*ǚڻ `C]A-z#$=%$C Ld
+
+LyEu 9{ѶE2>Ԫ\KV:djHdäu|z SXn܇t.7ÅLT&leGpM[>7RXBNzz+lt#|S:Sp:Mk%:9JjjeP’-wB rt$Aܷ#cHQF*=q'ҍ{ <t5k) 8@X$6#lu(S[$nچsfh5Bt8"F3=331w{.K
+>e>NvD2T
+*juY {x!Нcp
+@g_RH3m4 ȻQi&&nK
+]4\]Hӷ87.[,%2
+bܑZDDN-#Θy**UHC}˒!t>N1 ێi1͙*NTWqI)
+;߅6SM%۲3b8RI!TEWfk~_&i.Ѣ:T}.s0Ahi_@B(ke-<o#6ې.ufIz=
+Թ˫Hpۑ’]ᵊNgK풕bf9gSe+)I;{C+COar95#ܸBgMyV`6{vkfݩ7j0:QeL{rP;v'cb{oȥ&"'+l7L7|]D ",~OwB (7E)~5| L
+QYnkPmf< 5>whjjyhI`u 4&J@ >L:x׸!Ǭ+ !2] U♚؝ 54(dL#/gw(IӁ]%do,@ *T7?n IqJ\%cXp2oD= 9W1W㒦 > |&4Ęe%M{udoZ1Z؍FNƣ {|
+Saϊ84(Ϻ}׷ TZz$$).(*q"?a̸oEqzrerE1<$PlRux?M2kgoP"p^ֳۻ$;r
+mt#-Z
+?gezo[6 c
+yš)$%^Tp3v]7
+ e#6nxT}-|nŚTZJ?}`<;0E;O[Oc* j<"
+A
+uR<RUT%] Qn7SA?U@#c5g@AF֗%bUծǰ
+;}6
+_徲X+:x|G6ݸlZTjxKg\7Q^P8 F@?9aPj igHY 6p &~._hycKDj
+huvW*VI)0 
+8 dPSrG4.11ej@m`TVK
+嫚uBYٛno<RΙ2Kx_,
+Gg0t~NbqX/j#0ARcIE%e>>vr%&QqF;cmL]RɞM;*cS|ɢTu;cdٓstC(RcEUU {&wv-T(<LԇkM!(e2׸cT->#׻ͯϠ
+s~Ҹ@Y|RW^Gt70R35^e7=ҵ0 Z
+tO:eT<C?U$|ҕ15R-U($[0T]%#o
+LRf#ڎ",IB6yv׹#.d:IOVgqZibXnBc<*|6VzLrK:
+-`jłI0*jXH+*duA%(+
+JK-(F*WA(g Y>);"FAۭ";!f<A|'h)8Ux x7OK\/Jɕ“DJ  neVm4AV La^5>ι<;9GOKJY/f~SΘVp!5<|9FpKÝߛLn-T
+|EDȂuX/8Q!Pq
+Iv9`›v]臡\`SM_[ps.%=H«Ot@
+$
+>o0R<g@Yr10)5 |O:)meo)Z-p+60RsrQ:[[Î\i{D-; Q}AA|.G5${Ȋ%7:kǒ+2v-M \f a9
+ 뛥&6% *
+F-oy#+=hlZRdžڽ墀(.D8F1vZ=omOyj6Iw4 6O@\J
+8Dk U4tFlM60P F1vs-nUԥ1 Î5F
+GTNP>yňd*^~<:OڀRMKTIoܓۘF{<O kVTh@VR(Kw_~s.юP~[BW VIVN0ҹF_ǿIfUT$8r_ qE1Ĥ,r|ڻZ`Ͳ,הXHDbN}Q!+LЛ
+$Uv98쯗M#5&<&Q%YedX)g3ZVRY^+ߊQkhd̕pQ-Sa=<H yh@U
+@x6gdy+Ʊޞ
+H"''nүɟ̲iq)m Gt+F_`cǃgY3 |3lteD8^ EO.ԿD"vlQc9Um$i$FIFɠGfvś kQ)$#5ljOÁfw+07ͪ!
+YDJ#Zk^i pJL &L*&rsdgK+
+I½[~׿Lky )$!L40*msܨcelPNkIGXաǡHX X~1O>_5иYHU6e`A<ʸoMjJȚntg$(q
+7א?i/fyM<6UQ>
+dX
+d`ڛkk"{uSʸLO$zvϕ OL++ˀff>#b7pIOӝKN"\45 6lӷbO~qHu v-CgᷢlYV,aFݖ7bŁx]Am.vX]rfIQRPX,/`$cHBmaK*w.URaJVҵO:havl?)nRRgZd:+?O(1~+EƳke
+,tFJ:;SVFLg@۷
+.tYKCτ 8Q[^sKZ8AQWP5n;mpgo@Ei:ٟrvJE|/ j@c5hH%B^܋7?,]o/l>e%f
+A20izLe J)bH葳W( D7 4" j1bg4HCk4
+4Ъn%v_C.-p0Z.ahQ:xӞzJC%#e,OQ
+Ia4sȻ?ެvڄ>}WAG
+ ^_Yem
+Jz_)j6>WrQsۉ<P4@A'E
+R:dgN`H:A=O{v޳^yOC{v
+)LC26& ֽүfݜiNjm Jު:x8D;O
+MM En6C:v[MO SAqFxˢ4mpDIMH8X}0-2al1/G"5Bymk؈۴7ᛕ5pʉmJlQ'h
+2Wx:p*:xȩP"%,'a9sgƈ-ÅyJF|i)qδxUŠյ`wng+>Em_"v+LfKTJ?SB !ņǍVZ* \VXB'
+RfEEYX\'c $aABt_ExL b{ 5<cIpԸEnNfɒ'cwnt&9ĀҀ-'P<SH)PK.(1fH`7ٽ_8H˲)RI=XhFhaUuN9"bzyHRA5@I/8czx
+:}23;i欴\RS7Zj2$~`cݠk.l Tt&MI/,(磪m#qd׈:5",'U:^ړ$um_#w,G | 5*,/WgO įF S^EWej3MIJQT,CA-۸^e &oBi d,İAI&
+S4vW<^á)"fҢvS!<o=NDEI*[r^Lf-0hd(htӃYÒ
+tK/k\omshOxcW6j
+ FZ0QBpw-a^0tp.cR@?Y,
+ƪÎSV1iWkK\[fE{/ٯ zj'4EA˘f&|-},Nq,{㈃zL-¥S.b$ nk^_9Ɛ1@iF}\0KZBua>֤F}*lZMlb<yed4$`DB͂$
+˳e*VϹ*
+\6%EMH?>GߌWMwDzSGI)їɛcH wЌz&dcĩ*3fRĩ15ê'bIRXFPMw1ކvIVWk.ط{@ZH1ptVxwwbL<dVbxu4*RSMH@
+Fp#ǐ*-͝èZTO(L'Bcqi6
+gύ{wAt!XXm.`dz5f\BD¨Ꙫ"˰EFnٰ[{pv6(CiCd%jHJQ##fA[x4X6@NE<LWl  qz9]-2R wZTљYx״.X]JTHڕFe/=͝͝ҷ$({+ qY[Uf.3f\IY¾Wxkpjym\RO
+ viJYQB½so8&hZl&UjhӺݒ MN .yQ='e<ێʘ>;Jj5tRW^]/0N8AOS1/U;S+<(i)UI#pߘE
+.4۞2x*f
+*ꑣ18鬧|k{-2+& 3(]ݠfW!(B;
+ޫG8 Kxd2T5f\6ER#4Xjvsk&+J
+
+xc(OzS[
+i,u-;+P<T+Qrxt*zιWWb+H֕U T;̅}`6~/weDFdtHTo]]-ʂVLCQ"xUf2Z%1
+ lMãu[?#IX
+Tc6ˌ,$2ȚeOAR|]{};Rb;,bτeE
+W{pŝȵvW]4
+3^\yb6IaKyFvޮ5!1 Q"b dz_탡>[7f"pQHC4BDÁVCSQ, I,щ*"LKSC;4
+=爎L76`8jx߿Kb/=nÊgRu@.A LF<*9CvDCV
+ƭ-up8c5_6q ᬭ 'G>]|
+PCGn:x ({P;ӂ ƒ1ҔP8[wX71..CHyR0R17
+hʡhpn>r V/`̙0@1=v/U<L솒u ]V 
+'RP-P6[(
+_Q 7d v@ػ8˽aEdaYۨ)կR8(;(+^2<@eFO~ږ$AHUZ͹N
+ڟ:,aj" $릀/!פ]6T}8Dij ,b=m|g^IBq-(޼0ڔiBNL (k]7i^N
+9`/:Gu.| zu(qh'dtk&
+*q::%p i[˧8Rt mԱVbJA'ٶ]{fu
+C
+Jd-n3#;X|[O^Ӝq
+I*S4o(bmD6Ƒ-s-,,l@HHcH;vյ0đĚܖv7$I>'=.MuVbP;y2J&k_]xt7/qVajAFLo P}k3bx6Pb+K/XDO-?qa 1/C(Dǝx^!LC`BxgJ(Vjrl^E&X yjApDL o@4DF1>qC^g[JPâvm$5[Cc<e2J/Bj)Z_1o癰^@S'gO^⇭r!P.I`IȖw_hb}p2kܼZ8 zl;.3+FJPQ:b5 r(?xe
+2.~!9/6gk9jxQ$W PdujbfgWJRs8n7
+LR _t{GVdZϺNxX_x6`OiMYMq\U0 K<ksjG"EQ=1Xɱٵ(D퍂 -qzyLjGٹ<t( o>.
+9|<Bv;O'RTX ΃_ |oƳA1L,F3AgqKɩOwIbTu'C$LR\K;p0zI"*A]~=a8% T/n;Ь:(2ʻ
+1KZ<;p#AZ
+@zx]f?`QS9-a$־[r%>}sE[bf:[*cCT",QG,m$UPrFon/./z鸷*A>m qDt$n:3njz|CzcW27Zy2-V5SMWmM4E=Ƅip9 ПL}<}'P),8#<xL9hf iۂ^;#.9-#B
+;@=#dc1mj;E{&_HZiF4j@,=
+ܒ”0#MEy%_vX3^7ֿZaI3KQb` UBtO;>Iq8}
+;l*L4֥l+w=Rc8[z[^sy5<v'Ph*#{Sv VӖoCN[R~SOgL׻ۄC{ǣx5:a cr,oێQJfo!!# 5 {YӚ;BUk 2t`uQSO!UC9knex
+-}>^]~U=78UK ;bcUyA4 Փe,JԎ}D&z˸^965E@Ddݶԓvk1(*
+uq&xi6W=ٝ0J;NRz
+~tXsd0,rfi$7/#$ޥPs 2|0bIMpX#/4P41 Q_%Xw<Y/#ݖvJ qd2dhq&TOwIZ޺ȹ_g)cC!l,IM+
+THaeռ+Ѣ>uH
+j!*c5˽CvXmĖţĶ\8D;ҝBz8+3aD2ӻDF^$n祅ik!D/$v"wbX |xO7Z! }Een1^ðC
+`V
+zztiINH,ě
+ :A_:N zI&_%.|*ID7 n<8xy45ۚŏ,-`O&|PK7xz$2KQ|8±[u<)r;JQQJ2lqQ$^WZW*Jnkw3
+_u?nJWi7e1]%'?G
+Hv xQO'J{}8̘gjE41IrU*#\NZQ2p$ڞ^^&d(𐯈hx16 ^rr ZxI)OE<r(J"Y
+42r޺UHKDP+
+s,KE)CRcdb}*ȢeFn 'y0ˢ8e_-eirCI,άw1
+# #hr ^?fĪX)YMNl
+=茊m ܆a8_d\4Pڴ#lGBn]-e3"v UJh0{02ag4妗宯tqU~b܇x6Y.4ؐL&(y7&ޜRB $ & oN|ҼA0jZO[ W Dhw*J}X;8U <T4z$AV3${ik'x(<&mv6GM+DZ[J %
+Fsr Aow59uI}i"Y
+>
+9zz)05 ;ɠjQ|U ?E
+ Ľi5̳{JGMCn8¬V N$STԒo~ogǝ˙ҪNQ18EМ 5
+R%3!
+5G;f69q.I; pٶ7O^z̽0Cd.c6 #a sHfyw 'ҿ97OT:fkivJ`mYSN7- ;Qhvy̢!I),X@=tqڟ`;ӗUavP $4S8zɽv62bIUSR#2m <{3ؕqu+u)HXӎdL?qzޅ#^}uW-fS?̊zJrdb$mxmk&,qb
+$@$O{6-V^קQRET3SUO"@jINԒ;ږ}k}s^0ꇡ"hNIAFnϴBd&e${l7(cx@E_WQVO 3
+Gʶ
+~6woqa8
+V7vQ4q u[-di谉iY aijH6;Mh2̔ҴBpQR i8ROyS \o#z) U*X)52f.qyFB]¢
+Ě&$J]r2ܩ1\N l&*ՂU773D{$wo38`$aRA`Թp1@ꪞzPN3,1JJW)v*r\tWz0l̓e F T^
+hGwD5)ygK
+ғ80x8ߵsvƧ1WE":!Ǡ utъ'yUX" (,kܿBZTJ·oRt{#
+Q׮~%f[~c5N'Q+)DB]vSn'{ {6Х$BIpQ1)-y# $E" Nݼkl`HN2cK!O ,5aSGLiDu8])/A:Gk;Xz`8 )ZH:Mw/y~Ă'I ;+rNޔ'T[/לN:
+gJ"
+ba#c߄oo͢$[6BzS̘2)DD܍X^700LcК/uWV>]t$)qb~דp|v6ںyzH=TJ9˫0t7f 9B u:]G9}9η8πzU
+qk9:zx9~w$4KXbzks9<7)o 5 7(Xq6?xtaGGƖ>SDdXkx7h&rdz,cnVd}<o6:)/\yOE3OzQX0R;<.!|ӑh*ZR|lvv7^@5{IQު;d):ecEQ
+Gڞ(ݼ8̎f3iESR:K@=Ф{xrV^QZ-J\$-D4gq4C-e 85Z0")/>
+:u(FqTfVpm%K_/5an~n2>ꉔO䫊h˫wԛvtG% ǿoBPW0TGWgp(ԳYM;}&Ǔ$:fB4 *.I 0,k $ PfQq,U--[Lu)}èCp PV+qSH%|5sqFVƺm^Mxg91=zk%EϕU̲@RM~OZޏe:=N3>LgLCU:UF0I_ fٟ緖NvIA<Jg S?G>m01F>j?A#a5ZdS`D)v驱DOcv;[ŏ u<ɗq&L_ȔΞtNX
+U[K}{2RZx }]f-ں/!aiY#Q-wto?}N>9'S~>PuVU3#]ʕ
+Jmcn0*±YlXz'UD1ԃh.nAGXlD8vj
+bIj|&W h<{xpvh@kM?t6e**P%D hFqȝp2eXZ-uhQI&56As6)P=T
+ 8e
+KF'% @
+oxw{2N[J(ac-hQF*iJ!0 '5*eW%
+.gÃg\*>R(3)SSC,TxR4
+Um&+@x&>wk([3t6
+T6F&1XWg`d$3F_B33)JGOCˈS.h vk["kQ0b^A7o[d^;+knRcR7}.bHiK2fSpǹtP枞'`I$c;K
+=Fٴ~۷Nft{r&z`]AJYR&AROؕTpy璘='wјe% {JON+!L/ڂPp8l=DfFZj|![a
+NbAfc`ujE0.8w{x@RL@#I3=em1 ipw Yf֔U+CRӅA+k#y3j^Jv6i5R"d˙lj-o.l}Wy|gEW:@qx׸ÅUf`0
+i`_(42}ػ*^D=ܕq8W Ǫrq|;\O˕"g@24r1aknQw}G]rv:Tqv+'qqs_]d
+`4b$8ɑ(PIAŹl.^ TʴLFN5nZhY+)M5Sm߷}xqK؄
+%T:R3!؊H,b&U۩eTtz)>m[)HĨr25qx0M.-/!f=l
+)*oJ͗퐬RP5 ǬMYSŸW88>zT Fc<1-uMNfÜ%&3
+&z4R`@?elw%y)Eѵp ՘t*=[Gx`hz7I:>9Rpʌ=ck=#QbQPYfO{vūE A3ʉZ頷?K=ҸO;K!ٷ[u\GX{xSEcʈ jM(boE;DYt
+2O]^ͅ)ԯ‚n˙U3$n_GZ2@d}\f'
+33Oo@u2""i0 t$O ԾrR=ꥍ㯴q11N8mBӧ+dN-o8vuE[-έQ֡=Ug:XaLfe?a䟠bVUIv>x;r5 'R/m.z]^.Yb2zF|9ʭѲTp[+q;6ISrp
+9?JEMUt&5F`nXe*\}mx$U͢z⟺#LTT=>]6(pHe[
+l!#@
+
+*4ebŷ}mN
+@ќ6GSptUJWY59^鄴V
+MC.f:On:&<>tsU3)Ţ )L{~)!fzY
+bgBew]y R.{/{ۃ?Hr eEt9/Q5$v;[CxI{sٷHQ
+N1eٓ0P՟V̘6/(v[9h"3CK8 5Mu 8Rt4~`pŖQRb5I
+oY{ ӷdRM,gd uk+u2|w'
+p6eVl"Zs Vrh#4qvGH,)k#y
+2޷,vgϦޒ,E }L 3_KRna4}BǨ<:Ҝ
+ ɊUeoP7
+ţeČ0SOHp*I\CO4ӣ*H rIC>v]efˤ(ێ
+I=BDf<
+z[IԪuc+׊S
+Q 72U*&(!*Y<AErk 7=RM qCoG_[y2Id=8]
+Q4<;Hu{[ .]iWr"
+f
+ڪzDžQӜJZcբ E@?j#ϩ^βܢʀ:
+%GNy\K`4mXRRG3*BsovS:w䜯0| g3+S]UYQU3Kf.THF!@-m9oՎn l V'zj)nrl
+YD@=*P$tҗSzǖNt
+Ø]vڅgrGm6<^f՗z(%#F>{h{^1S^b$U(JW`lL[(Te2ʋ>'Q ġ]QC$kr
+;}?mfns?j*ؔQ@oOQLHAp#QB|C$~
+vZY;0⍴
+936Y%,,׏xQ1l":i*]72_gE6'PtSM_#nAFO~g44Je)"pL+mOeٵ:Vž͗pgՆ#YX[TQa˾&M֘<Sf͓h2n1 #A04k}&)zϯV'O⥖7* D܉`oqn ?5S$-e]&:*F:Lh?.A\OSPfBS2fiU:ik-[\dL*Dw1H[I ''6YDq _\~/Ii‑,[LbVj@ikJeyđ_̴d'=qQθ RbG+e$k[Fd@=oNP&DIs䕍&~
+T$IM,I)Uy e[>ڊ>V1:-iҺjB LK!‚tHXsxDӖ7 qZ׷i׸zb7X
+4~ TRב:J3qm6DF&^fMǦnzy
+'T^1bFWVNq.y %<:v}(?:Gyʕػ`|omxOE.%T(釙## Q<=5/l$t̍!Ƌ.:YQ_?R)8m[Mer
+
+$
+ʯϨ!HʮV
+;2e 1(I]9g7cqL:ZjxyJjK}yiwVN6'T}`@$Kȧ09SFhT<'x#^XOi^ o0c;SLQd#b<{{Nnf+&Ӯ<]=tr^lœt{nOn-?F57ȼFui}qvG9Պ_:vrAqj>5U`XMiFrѰt6R;=d8auN3Eiz^ic[dK"JCKB(:!w.EOZ޴ªk(oA H0\F%%M­mo2E e8;F=TNs<%}TxQ6z5J|I&}`e,q)ΤukcqƩsP3u4u 5,< IIOL~ao[rvGs~2u$|Lu۹
+mŤFxyՏ~}HOʬpڌ=XEUU\
+Mȑ(ۮ8wY]:i_1JizZ$B8+o{xrRêNС8z ,VI
+Rln\0%9 frQ{Eg,h EM2[N;9Ndxa+mMY}h0$
+N$y/T k+WE1$s q?$RӤSiH62ỔI=OxӽL6y`LJx໱ [k{gk>eu@IIȲ`qzJt89 M$Y%jʟ"%YT
+-$vy2N8-"XP=puu+
+m<xL.t`R.5MpZXPmTmkGp|Ȏz)+B}
+
+aD7y(;{iM#a25 ;?|o^+u.%I!Ez7$aFׅư"E#5n $,2
+T H8NT/jܽK *^2Tjwy7'_Eɴ KO\k!p0ɺUpUp-kXfW[Y;9jJpԵ qϱE.\A蠏WOΘFrDmͅFn537uGjH@$,wډ0]CbǨ,bye%YlI̶9-$8
+LL]dtNR
+
+B0$Q{w7<*Go=y
+-wEDlxvSz1; 'zL**MI2 Uu}El}L+cJ>`Q޴͒QGV8S_~;s.j*xomA[cR@Ѝ>Ǫ4ˁtY2LpA3%8(ZFWG@4 rtwkTq-n]6uYA(h/%zl2^F}%6|<^c*L=b1xYBlv㜰 9LFaxF/>9=rISV
+A1i_^f ݩ! L;"F{&MEUG*Sr  ;t2ÛqW1Qܽ=E%P\A_ jGndjyR6^TKoSkrQ) Դ5Sim!ǃ
+˽,:)0LrLu*h#YXex=6Ӱ7eҊRDj`SL
+J`D&=Q˺}uߌc+OCQFZ77|zծO?r$PG%RrxV$A𵳕$1cO12m|xKhIBՂ2ɣAqiq]}Zi5Z"
+su5Fuj\Wr
+Yc{<Kp$B鯏 >z_BXǪ?$*̽GrCC<5A&<̩I,Aثkn/|s}q7-ww
+V1W/_WbǍbURyܭ!̪8F匰@>#S5p$Q;I&X\\]YU$4k*^E>Rmb -bH :N.Sb4'x& )}-\&7(DR\[L_ʩUJ2>v<WΥD{(FBFlj*!++6#._9~yo
+OO]%ּzdcXF=ZCxҬc1“Pm{qj1:(aV1HҘXcUحݝg}a-bR1Biwsxf.qA%`+8XUog}oeՙg2/M3 R%İ<E
+|W)4x."bi0
+]
+;. ٲʂe{$@$]ZyQ(zY=b=,ԕ34@&/+wH,As{9dUEEeQ-OAtʽv#3I⼯{3*~KjDEQBG%v[Eۄ@)845a_vNll3!T5vpš1ZdZʨ6^[i}Mͮy#P!M|Y'qSOP)(^y6%HT2.{_պ,&jt lb@gfx9Bd7d%( Pc^Rх
+o"RTXlJ A!Hטp$`uWXvIBDyLo+mAap "^we7yߵ :m"I8bHwX<V TBDD€: $fZ6@K>%O-I bAGzaњщzoh.E <sUN""UU u䟿{yke .X(i9؅ :H;nXȲ4hԔDlt4ާ,K)57D\VD%̥ErME{}Wt—)SFqwJ_`UZYrW'nwl=hU [*qXĉ|Ɋl0Lt~4 cYxabX*via`oӕc
+g=V'sv|*Mg
+ yXlfVL*ӎ4nV` ' hخsn~;U~.zRz'yf0%Zp0 L(% tS3#$#v׊,p<W"1ܽFip) BWL!H@bu&ÙaW]>߇VVЕIZ>G/3G34QRdrSL^͌Lѽn܀.:W1t{.SdBjkC"4f/{3os˥-`NS~}d;porc_F3Q#m/ {
+l~fZXY$\m( n7#ܩ7f_D$Go |4XoR$mx8~q {{5hGfgW7蔝젵p]Q8Q$T\Ulj"+*=pk ̸q@
+KǯR>zGm]Τx"dlW%?#+KnRh\
+QsՖJn6=>ɔнI<<AA^ܳzp)hB]/B}ApRWUx^i .;
+p
+}2TL϶%Wcb
+iÄFEk"s.'IlAHmߟڗYp[g//S2:8PҞbV%5Vpiq,J mpo
+[tv s8%!ul@%Q0La>)j(:}T6';o9E@F"(ntXk*e}*Av1c1Sr?e Qcİ~Z9m5b =+ٞ SCˆI GC%!b0 {nu/ߌYr=)~}Kd):^0S//Dj'b.aEhSy$+ 1br8'qJ~_UU&W 5L4h܂
+Z3
+*ܭz-ҝ=`NJ {Mvf;x2;:<;WH:5Ѱ'H'nK9b5Ixn>D`~/ez#45e6^-M+<'wTibGArt6^!KcR;&_ ,R5ĦD҈X!OLt51,t'wmG f`ͰU)p<{׹96XdN (%NJ[粢x/<i|hjht:~BwݢfW%jGʈT IYTSbRGäǶLIS絬ܒ)FĦШP 4?oJe1c]VõnJwPP=tko.-!iP!IV H4*zZrI(G"rEe%M-]㣖C+kq"<5iBfJݰ
+R}Hkٞf.
+h~N_Xqac4ַZ3N^(gsp'x"EabT . O$dJW3Z(E2!<H +nn3AMwo kTAԞ4p iDZ> q:Js2( k[OWjz\o䠮fQia*˥k~\ƎW2'<=ɺ37mڌ:AӗJ sVC~̒D@cpq6|e
+YLn<J9@Y)>(ЛnF(Ei0zh+[ sC"E驰LLYTCހ"nfrp6+tBl5볝4Au*9ҔD ־F(oi
+]o!KhWIhI
+Xkf*JhUn o^G&?־KJr~S(0ٖ4;J%<|9Wû;d'CK.)8?Āa=<lJ
+#Zz(fG*80XiՃ#mأ[3{YO# 6=_=^-ڵm„!#Y% А:;Qb5&j,$BƗeS#JJ1+\
+S] akww/-\ )JP4(^Z-R, ( I>
+Uٛ
+i90
+0BJ> %=<l@ \_^ݵܾQMh F1$`@ƀ )
+ب"HM!SMB jvp2%\T,Cwk[]7ʈzS4S+ U#̈V&p]ۮ"B]·
+*)
+ZHp0ڬ•\X\g'|w Ll3H9x&_B%
+XX{Ǒ׭F?#->)ʰ@*Dhn@:ndeHJTi3ܛ4h4HO
+p<>V!Ȏ6$]7[s@~e;F)ىnE}upV+O=tH\
+V5mQyEd^:zzE}1ޥeo(*::IĨ%)kDzD$oCk,#C[^\m`)Zv(0Rx]s6̶r@
+&p#Hutp )۷q苬:Y=Gd !2eȍ%B LjSScPKNmԶ+{/m%Am,@Qڵϔ'*9.ڠ
+?X9/9
+{==U-Mn3Eol fcH8bL@5YU _;{7L(a18>U3Cьbq]_Bep :ފ,sQ%Z\SAGQ-UBVFYXnbt}2QV[2RKeӋ(VFP=1SѻzZj:0Hl<MsR}v2"|nGtJp
+(IHAbTh
+
+l6'YF
+KbhB/bmϚYS$K)
+
+ >ޝGr
+S&1jf=d,70 T4T)k빀˛pIDh(LIJGb<G†҈R{ES+;)&+0 ^=_S»1
+Msp8.cvkX褣Bʈ;EÒlK W$ӯm+Sʷou5 C>YJ*
+UE1f-P/UY+d)p|WTIVJ n%6T NqepEW$aoX'$͸{UvJj_ǙV<Zc6:\ζAt|ZbpS#ĪY[5,5<bt3W3JHW>?GeHU,IRP6VCEQ+(yͯB<E
+;6C8S٧1ifYȔg, QvF7n,py>l&ю?y18*. P
+.X IY%-4A8^sf`d>U4.Ǘoz{3Xle$1Ģz(GgrK[_C~>Ur*cO[\RIDPwZ xPWاS(DUj#wT`|Aao/y2a<XK
+'GzDӦJ9asCW] aZK'VU!ۯ߄Rӗ*::q㙦+<e#$I3{a\w5ϐFV3;h-ao M0:$sǪeX.՚*ep6h>YXY?b4k8zzE˘jTGiA%-KX?_3-Cߗ5N OOGN۽w*ZrDf
+,/̪s$$‰=,fv ,bf
+NR1hB
+h݈oߍM*nv2Tѝ( ý;-}g0nRMx|;gc1JlfabX
+ ي~dӧ0敚mAp$
+[bom~b Gƽu&Z@VeK|PWz[hv =58ƥ xSJCF[ ٯ܎G;&ɬRGI=C79;
+S} {SCH0JØqFcZ#[~s̸ת
+4aUumE
+ӚS@DmFo{UΓqh
+""3UKOM qt߷F}9-"婵 'Q:?{&y i<$KC(02F=ӠeI,#TQ2
+' A~5[Vi[ {9KTkmNj羖"LK,>5΂v;y[nhv'F/G&ggIp")]
+ճ}ó%nO$X 'K_C(ȝ-7L_尌'˧T8DvY$-\9՝u3ڡM"
+1Uך*icJ Ă'mN㹂uA1~Xe!^2.04KsETeEo}O)VdBcvT8d(.[+"zYeN]JzZhhT췲=Q9,N!PMWͭPda,0\L:ړٰvk߉V!<-5ӆ .Mfa
+&˫9٫dF~$`ѝ:5ݯ~f↚IKo2`7y{K5
+ ?wpEVߨ.dn(UbDt)G:paM!Ia5TT&E oxiĢ0EgK@cVs8a=Wc$z,͌UK`%}|w]Bdq~[:ѭ0Lt>~kf_y;F! 91\<η`_og۽;'u'TgF%=DqQ:p6Nqk.QJ]KFܗ} %ES`8Qc^sF0Q85u4YT墧D32Nn8*t 03mQhi!LRd @><- sW!zJVP:<w-w7qJFtQuǽ(u"(qzA$QI(vP~ض;cf!a˸P)
+%4j_x =3$ [ɚ7ҖxJ:$nv.԰:N ^ؾ1[QSab$eV6Xi &CkR<'EJvBjR<cW pv<C.റPQ
+yҲ,젖VD8aQmnR쨼ذ,-s4%,1H0j
+xIlR“NRˉ #a.mľ^)A-[\PU%KUH
+Y^3d'k xrB^ț߇'%l (41+.j0 dA0chKKX3=Efqi1pJގB0y)bWUԠ =,cluVvNړq;heHr5uݭx,I{4Uy㭑ðxgݘohG-̜
+?uSUdpI 9"6G'?BogweI@CWIA<*Bުij4EjD ͤR@No6ZORXC`j{xr=9K/70@ C-Q}:՜cvDUʽw1~][,8~3
+T.mCY7dVk6[{8+{b\:f=Hn~$[p1󢿎~%85M|'XV^,.I{X߰`;O2<+ETF
+IBړyn?`Y^N̺K;IѾvokdߌ(gP9#*͝:زclCȎ_Ŋ'KvYc6y`vdH
+11JP$0qΘ~pNcv6KRVCea'$]pvє(
+A[ GQuշ)nm7(R"B:+Jgne1T(j5>X x:w0RV "vFރwcyqФ a^L=4a
+JUJxQ([Fց
+z.KJA
+Ѣucؕ/+Hd5%ZnC39hV[.&,Xjp_?hJN#I"~aMEdxn"M)Xwo~;aK`KmۈzS/l{= A@ %CBwa}G3Shm;v<}^L2QE-#i>J`ߢ
+|79a5& 5ˤS#wS/zrų[3arR!㪯iLQ.
+
+>xctijfߘOj¤1jNF:=uKC5]bgE3[NM+2X_߅6mm7r>~/,[ЕןQr04)2q*#J6^^2$px YNֹVH{y6Tv
+uy&aD mAw,5a8_Υ j(^;B w_l7L.>*D"i"2=3-~VU 'xR77w1ia}u Kj)q_#W6
+;nAK<_ߡFYB
++g=ff}YI&41߻U·;ӖL0jUf~Xk1LBZe b;pen綌û̞ r
+8Ӹ<=3b4\3]ɴ"Za*GI$'ۢ)[lY!vyl^h!
+t%DÀd9+fIصN-0]Չar[aR`ykU)f!š<;pv^E_QK) Kq)SuIفwi4nԷ t+.O֬ɋM #-mron-/YhN=UoTO2QG+XNYm7\ngiv6 ֢gaUݻ !ٔ!T}Hx<pSXked@`#]u?W
+ y\BvyKoKv=G33VR&a3XV;j Y$b ]>
+/73 {M6iIu@JR:`bO@{yom
+lᱨOKBL7-Tx{=~+L1і1wHq6CnT
+lWJ&Jq.+q8>xp=5-\o
+J QUyzyisy=D"(i'MkKnߴ\hlx{r3g._x)cP2TAɠVl^qRx6f=q^-.i'EKEYIUMRY
+K#2He7
+)%)P"'
+OVV+m9~l "22"rbUǁ9mg$#d0 Gǎ{?Ot[&[Xԃ;A?*X`SI3o2&1T"x0<K×1L*=<\ߤňG!W-ܶI ^" V`+<YF42pGV,,%,aS?M\HۅyxׯRƓ!fV;YuqO\*0zF>sYXiKnݷV'XVhf(ہq_̱"%՗Oc--iެ6p\SWΖI)+QPNWi!Š|x. ؜(似3Jg5}\xj97,Le$L7!jc:gwVĝPیqs6zF9$0Poĕ~crqo1QsZp46ޑehCT:M`Fr"kŞ
+0VZ1sf:~1}YŦ)3p{ 'Ҋ3<x.H5S9Az7'mmxCk$4}!n<G]'IVKIQ\K͎Tl5EkYcKi%<行UqmۡnY*穌rdfKq 4'g`w}>Te[.6FOq3NլuԿ ϝꬭLuqֿ s~v5_Xd] tU´Żq5'!znñ$&XnH׍X&'֌-,Vo\
+ ͘ѝ.UX%kBZ\X\ EJ5>*⤭c3;1bNkܓ`8c8.}ULRVnWQ=SgOe}NGZeK$`f)j7 $T<7}@w+r/Fb]+1d9",?7 zѬ
+K$ yO괵lvo4}ӊKRNJB4Y*mUm*Ju*Gj7Es^?>BlX`H<FxUx-N̵˂<*AKp8RcSчf`5Օ||Lu +èK%POoQv>@r˜G"~z}DɮqD@k
+OH;)㎕L>&"jyM᪔o!=w .VFInIgXr,$-rU"EE晛޸(dgCa{uX[GQATG Tofh(+ O,2dqz^MzvGgfQsk--w\i7ݨ'gP#C aKi 'Iǯp5t5g%(%TVq
+?ZISRze3V"C, + +ZjVBc8X8Gvk/om>7+uڀjN|{hhdjm3t-=W0lɈg<$V<5eTUf㦶#5y υ prL>,)V4SݢbI6Rt!iTF2W$@8Kf<_}oJێNj_L58UNfZ?lj>LBpEu]&0š?;Zz³9N9Mޱq<$ JLaԓJtU~f|b0n+Rb4xv%(D3cȘ>[Hic'E7?{"054l,z,UU0$NѬ<Lxe4%FaN!jV*fρ:_U@b7Q}W#5]n#E>ˎ+r9
+4OZc(TΟQ*tc+aX4*⠑* I9ܦ2{?`{!Ed8Km'MٟLs-NgƫበGVb,P{׏Lz*X63ܶ5>SY
+̛$܇k9 H)A8}ÇV4(RC Bo޶z|R"=o+sZ2k)-2
+?o=пs;;P]KdbR=\LE0hsM2K'/Bji>MKw |kh]].[<>R2Ly4Ͳ =Q^Y@QE06k5qG`Yw/g+a7xs?UFmoH JV Ǒlk-̞lB 5R:-=5,MC1B_hlfX!/WÇUYrZJTzYTT<ͷb!ic6Űq#RT$Odm(b"IQWOM&4CKEM mR+"=ߤa¿ 3/:m4T,5mK&
+y/ }JA#P{Z
+ܣaebF3;|PWwM2Ua],GaU$ԧbvb(,,n=3'ԍ'ι ,]HasŵZ1D eYe}ӦcBEt9+1|[|7i0x{foYs`⌡ "BBȅvën8{lcTO.u/<:S%VФLR(yR$[rR}ɳm꒧mӨ-XZF؟L)=^ej
+ 5H6pbK3zW³P+1"pGQMRd ߁>{T:ղ4)⑁NRF I  0pJ9=bWez~ (c 5PYKdb@
+T
+n6
++vt8SE ƒc,TP<8PAO60dR7 /a}f$Mvp&xOp5 I>evXmG[8lUK+%믨Y<j&$)oLp>mc-6o[HX Sg:BIQa<IH; &IQe\[lvDRxk)'4um* `c
+"ϸZ|fJ!#n C"۪c_`L eQcc8xrĤl&74y4[P)D\GhʙG2K8.P6V
+Rvǭ+vɊ+J򼡷1r}})_IOxéEՀx2㎣E6˵\dWG*[rDضe
+ꑾ er&;Аp!ݖj3ͷKķQp| Ƈʈ昱}mڽ}1
+YOxEbJ-kROO#:("1YY>e0Mk}\djZ&@'$.E_JIÎ4amun
+l{8#eMmn[qSb/
+0לoWjx{?xd]:-rztӶ4pl[hby<گkYVX i/Ff>0CێXeafmosmJș97©̨PlJ(>װ曹+6[u
++h R
+
+:ӈTl2 qJ7&Pr6c1I_Y_.XidOT7,$&][^vPFO鶜on#5<n~'9~~'^L.Ze$
+/i_8%Zjf
+l&}!i#Եn܂<]3%WO
+Pym5d `M8e<AчbIGaje
+S@|_IΫY_ó[QR5M"CTLZT׸rS~(osGpI@IZe潔"¿ciO
+L>p~wm.ob-
+I'P$
+luX5JIWQ*̆lobntHIPoյ@j`n6j*y*"H
+:d6^GnuG6a^KКjhYH J;xI+{nB=nIYp㮝 +A
+'0CFU"-ڢ{_i*ls:r8è G. :qk}i޼dۭ2`& lrMWNÈ͇ҫLkmn<JcinT\O
+(Ѵa/C$r⏳n
+QL*l&
+$mhU,v>a^ڜNM
+TE!]=hy**@5:r%MO'}rMל8xbP %8 v fey˚ZQiӎ?^0c Zq8)s]楊i eV&%Ўݪ;û^!W6%A)v LmΜcp%=0z{QYYj˽6icꙨzPVu>Gyn*+[̗Hrr*aVâŧWW>ǎò%.|;
+d41Knn{\pro^D^RNmgβaj:?v^\ r|gc%lYn|C|8BX, H,kДHR1O$ainѸ:,.[rYפ@Zb:(Rf1ĮO *K;( a0. WʍVW 5#!dŨo!IjX
+zGsQ&EFQI)U,7i$9z|E{X㑗D6u_ ?<,Yf8#HuX}G(<B\m)_+z #rVd*_K`8NSןAr707&M>$'m1Y3NfL1&Olmb{n0u>OԒel4 u
+H%fK ]o:r=nR\΢gB.
+HoYxţvSƙ2Tv
+e}FDЯM_J`nP犮>Ph xGwV=x{(0m':qRFu%8ѶӋAVaJ&Т -8KhKĠ:d$ m&8A*
+ɱHأ$q#UC&_/!pRJ-=oPm7KlrЬ
+is0cᤐ,'[vy-fAl
+l6e 󽝻=iy)fYⰒ3qq_K=|i̸H+Κ/-M< T1
+ IJ%ewTUw[h _sz>GRJPƕn^Ko
+nF*A(S=
+H:ޫǛ3ZVc1W泌'v]kۧ]SZQܬl0=({_J`ȎW&%k8iㅛ1L3ZMƮ= A_M\\)`pLi"*Ջ%ʣ<$>}HuՎ3v?=M-4GlDIf ň><oGk۰N}[D471-Jm
+ I#zSL:1Zsu?*ʅi~JHF*eMŸVvx
+{ΠRIy3}oTlg:OOUJݜoIu>ݞ?Ə'=@_*䬋>_x% OQ.@T䞬g|\i$Fً2_ǩ & Aٴ:jQ=ݹ/) ղcm\"<B:I'`un1n\_ɹǨ,Z hl*eI'ŪjZdD6ı: {,Zn_q
+v%BI=u( 3uwS\^L WA,klX~;;I%0#2h~<F)
+vyeMr~)l*b+)":3bzKl,
+>^殺ҒVNa;Iâ m{xBYA RA*Wڟ!\8c9]X ƱiQM$j7`(U`x7+ .1'N58仸K\J4j|FLc15/O~><`0<<3rZ2̦:܊*.U.BLHP>kvʵˊT'o
+
+Umtۛͻ+, lQ+©`fX$Ƒ6 #/[]<8:A
+%aHBF*yAsI nj::((: |xGs:@Q~W1рtN)lellxlESv18#0G̟͐<)}jiQ=ơڇYC <4Z\s RQG8R-@K~*1X`\Ba
+&ĤOƍn-ӨltUiCt8]/
+j)# \
+xbObTQ`-!Uic)6GaƭZ8Ӧo5TC3
+\R#j7r2Xrۮ=`AxVo|SpcqjbT頷N\1"ZyOէsƓ9S] cl
+bOms 6v*d~?O .o om0z)=Є (Ép n{p9#=5TqkĮ+З2e #o*{/$]Pc8%P ʼn<Koj[mv du$lDXwJN4&t4Qf[npZO0MDmPlO%we #P"^\ҜY۰R<O3F,0*+:<
+}asۉI3k{)p NJNaUlL|IŘہ. =F0E4 3h5<ekn0*DŽCl͋$LׅaYr(Z
+ijVGNJRs-h+p5<gl06ŽRD$ 6u DX5G'p|85tC6tk>8W0)e|ѧTG7 /r{=R%J?nZ\(HlC]Tδo*#̰SӨ7O8z5zÊRF;Sa89*1YZ^Ǔf=oEdF`qDnwh9VCi‰mG~3H)Gu:CJ09O(sLcJKCApѴQ&K X?=G7#w-Js&B
+ҁ%c'_r,CN9HQ8<ˍtPk
+,~d v
+ xIgp#ԛw@ã
+,o?=eLa pTPf<G L m]ɅaEE0hܴOlTnPzUf}NYtvP:Jڜ*A G|]8%N!T{SoRo% O$Q),%8:M{dXk`ǫlJ ScE;!|Xqf{v$J:3ۼʹKM' [Q~
+ɍb|s{l'JI0pIc2'xū0\>DRYp&
++)ć_s'S~E6ho9(B^'쏯
+]ꇬg qXqLj JJop i߹\;N1uzT@1&E$ g3>/`C|B6z/2TńH$cl]u6G :k56|N+ha}D(TI^VΫ,O9bXC`5 & HLa0 Ӆyn*D4I[ ֢FҢ`vE9#R A$# ㊖ȪELZx?d9>X4Y/ERU)ì˰FᑔR,A7fw3TH}u
+I$o hQ:f I#QQJ! Ύh$`~W]Ȼ@d7R|FY C@, ۙl6j 8qL{F$)< 7tņYt fdq
+D;o6?e^ę hT+32 cA=5f٪)
+
+UWQ[9vw
+{Y?//˵ !B<Ő`Eo״,"VZ.yԑ2S
+.\$/#*C}?>Dݨ>K1IGhf9uj`="G_⥎d|2HHtjJ%h6@6}}'X>鹼_/X.Oފ2LSaUz"CؓQK<$j$i dn.vlf#P L@#;
+n~!0]Hq_48 khZv3YL\`dgbW7hp v*:f*fJQ곕dp[+Jvryaju6Ғ֯Д@Xo,}Vht:Ml@Ia}P*Xs>EܯyvG+qVٱ ,kKf[n7>>U
+% U.ƚoU qnc881'p.*P`w;HvgƘ{+IU# XbT=u'ê6I[m`=;@/Z%qoE
+o7锦#BL*߽%OE)e3<bZJ[V>R9 @h$_%[(gZJ,iFD@X{-T W1.$%T?{ܶ).bxE750\F>}dKY3?<Nj4J4=<@
+h6j4=o5C썜 i*u9yPkf{yhG1%0
+Oظi* &oHQ_1c$ROJ1%Y\ {y'p80Ekwlt"TH\2W9]Uk
+
+UQOH1[orop |4kiK{:}"ɯ\qc_Mi|')( "T f6kGe,;#dDi
+Kbz׈gs!fmoq s~)3bL燚5Zaf
+x%l@1C 8}W0\@$"I&fw=7TL%L<0b=5\28k3.K1ʗ5&{`1Hj񜥇`=WLAT7%@??̡װWiyBٲyMJܪ]p(:|ɃI~r)Q"7}@f-s2Cr]?3SY<q\i'TOܱs<3nwzƏޠ[q
+HӧpIpF\:gӯSre<qc9FqBq̖R;gfs䔺|kGQN)kvw%m֢BTHe{癖 5Q\&o26CfpM9rwqˊ0^j4T
+h
+okk1CR&fMny ɘ1±
+lSf,G 9%ze HXGa'Q{܂~~Ӹ[Jδ%F5j0vb ۤkIL0TЗ|7\!Yq7hI))D[Ou@'>e|Os,?XJI4FKBTsn^[eE7uՎ
+VLm6vzn!JT O9u/bLz>b!KAFtPk/cɷipi>6:rI8T+1l2ykH@ R=gW[ڥO.}ۮ S
+{%z
+c_$ğoÃͻVYy vp'yŲ˺v:i՟P'Rpj٫>[bQ$ĈMy?+ٹb(Y"Jkw0*BR$pSV! )p5āeHULl؂dInOBə:,/jB#DfeTG]_{*Ë32a 嘡Ǩ#CG4/\ylϣ%Nڭ%.H?Ƒ::)e_P~K+OE[G\՚I'=nɈ|C Leo)\s)`yU\ktd!ηv7I3<`lmq7:sn+a
+KBZA5
+;@]$=&W^LC|jLbb_[svs2+vP "Rc>uYV]]#aLR Ëlz8i&
+"B RS9ujTLf>zs:DlH+Z
+^cdQty}1HޡRK MÊ׼{_K܄ :p'MIQ!`x@8Y_ccp͔›tZLZAy{b
+0^ UӳDԛ0!k\H=OV\RbSV=3O*kZ_QHx#K:V8GQ(e=9؅ WeWd.&j1`i*#$Ewn9^g_'T%pdXrXQ(ut㳦*FW |Uu0t06?O{U>jpZ܅SS3Ls,u+ dIꢾ[U1cOr{lC{(Ϯui*qZRCYR1'p:k5t8xG%P c^rȫ0hb6fVm)d.,8?tw'
+#
+끇-3Nwj=g1KF T)uM\nٶIQؔp餻_TY`cGʓI&Nd_ip<¨gXE ":}
+R5RnZÊӌG4PZbDB+@D[ Q)):M%Lmoې&E_vM=Jr4 *<??b^dRal:H؟U_b$@k| R"mG΄)𼿘I-<T;
+J:N5frNɤ?U1_nWZ\<ocX0Suǿ ȷAPw0eT]F9>iq=B
+|>oѬm8ѓ%S7<GOh&K%
+a4yBZ9|@.X_qV#<G
+(JH'|͎]*}c0<OjجRYw?Aۻf*C=S
++4>ۂ XpD.Cm{H[{;a#m,9*
+=7P'쥎/6 --*Tn=a_jMPAҜqI+>ld>
++qӯMzE3uF+,MhQJZ̄mp^ nOM?/42ZJu䙗UͶ g(,-ُ}r/,19
+gճ)B$l)mt%g]r#V~7]m<H3>?UF 3j=WKpQ~SuqabOW
+vg· zi_KK;HsL9Q<6b yqku;˖(!˸Gũ:z E!$y ee`Ex: [u?D_>i)Lݸ!E'lugɗdNF!z6=tÂ,KfW崌*!X=Fvbom89ug\ΝI<>¨NcU"<a+)Ҳ G:ؿ`[yrsotu)'`'˳KްS(RQr6klފ|2OWK:ee 5VӃ<{?JC ]J̔JqU0ьG,ѣjWW*$;Z33ooTYl B(ijӲq$Qoh?pJ8 :8M<!+U|ɑlˀjd(ՁP0S(-Ù^ZgżjN_v]xcF.-HA
+s FftV'L@aMF݉nOgw
+`.Hہlc|2q;C$e nH66MdY}\ti"upSuMf!_X08d"U%:|8bl2Y؍DN$_U$ omuf|l RcT`=h򶎕Lp\<lV 0J6"
+OKa9ka,W}t8>#ý]f" 2| <U8 bq± ~aFβzϹۢ
+>t!tާ0u>3И
+J%/х*TtYRHPP R|$^pƽŞ!ԜS͝1jrI':=Dw$3B
+LclWpNt #OgBWbHY[PUw %nߋkm-2$
+eKS
+
+3;q/N袠e@Pu$xx^)WmQīe=)FUnפ`Y/K[RKp$RN[+WHoMH>x7mk:M-zOisKJ%?h滛5 ~H1TO, q[iy; ˉҜA1sq}mKP $6q߈2Y
+BvC;ݙZT76=c*p>$FKi.Ja#70|ylnAkmtX=PdùnRAw>3"s ~όE:=%&,nE-pk?I2͘˖Ugx2Im<h!Ru
+-Fê.i "* aXhѕTDj 7K'WPM4lno)qܧS!Td
+YU
+$4ҀͭƼ廢H")#Onsy/fjm{}o~<Δz0_M %J8 ;4+#o`ݓ":©Yþ8͉fudE6W0*˻]MՇI9cě @"$ԩBtqٲy
+G;(t1Q:Ji䠭451ǀneJUTBdpȾa=HÝf.;IY9MBaRcdD5D;qxr
+'/S5˗c_ᄈ62whUffuķNP]2e~Y+bpvo;E= s'S%Zz!s׌v'2k|I}!HE֮z84+;(іh|8/,[N`UZQ5MS<#P#[ 8" XF @i
+(i $u^1tDžMWE/=2 /}?>1slf0'd𢋽-8Y)JhZE@ۉhDx!:C)y<B
+Mse/N`tjt!gYїU
+^iHfH枩U`$P,=Ddw#C^'=+q$k,߻`?o3[okt\KyZCjTyT=YIr݄PM'p5CK=@7ڣbA v hB7ݡ z-2KIfdqWkk;j6q\Uqyoq\wku
+~f ?ZLGH!qcc6d9m@:I<</vmOtcո_"p8Ī +$R
+1
+GqʕN(G0Yk2N%$İȐDib
+Ύu
+:dHUu<)%^wo:-Ke^G1t_x)ب"7J=e<e8 S_R `v#eWA] IJ8|ɬ%N=ܡ4o]6 BmRQT(hgPUZC-WIt6 ){ma$$S
+`uoقĐ
+X8m:qbiQb4G,ZI/fߠ*,N(r4EMWSJ19;vr廆Bx¦";+-CYڝ3ixnT6 ߢ# .t'}n͔bI`.JsdI"
+ZrLeMjy$p2+Yp q41 9,Mkx۷#.VV
+n1v߼{ tԟ-BBnm^S.#EZdD ! vk%4HDI
+jӊqjI2X7:5ո~iy(D=4(̓} mٛ64$qsu0||8ÚAcE
+Iu$n4?W W҆76$7';_%旀"N lL&,wOv%<G
+_ǗB&F`}K.,XO[L c77y
+c qd>ەYC|$qJ$ttºu?bH4"vva8Srmn/5xj*\E,zg`lHINRT߽uv3CuJ1=/2L L%N_9 H-? ҾهJH,^y'a}iֲVC@,ɢW.u
+a"+NnS<BjF臛M@וT\tugq m]*
+hHL3]kd-}Y۝,OJg/F@Mu{gn013q[1K *i s)wRv%QG EI@PP.n0f
+W[ K
+dÈL`vQ2G4wHb39xQrZh{}G Ψsw%;0+,; K-lV>BQ^<y/喬2V Ѐ.O 2Je( N>IO DU&3h;<S䌫q 1p; ^mPL}AٲMΏha@lK̅9=+r;sY
+
+oE9:xDVL[-w
+ @"vG]g jRY&q 5m͙& *E$Y!meEUSk~c//gt2+2R΀QTPGݔvͻW7eIPJS>pr,S030K%ɱ'Q \f'=D{ 2y . Q0
+g}3Rf4N4"t/ӞaQpeF=BW4@pQ3Im8[pGPW"ȨA$Nڑ~yJ.mB#
+q:yo=a%$t:AOPozYqg>| 6e("H(ԑA
+z֬+)~WéU)Su6f]n7`[INY-QONnfnf
+uHT:
+mneLb8!#8%cmd:RIwsN HL^1ƴ\K fjl܁oǷzme7.bGWt0K`l
+^B' x>cjpMk0
+9գ$?WMJ|`@ji$UQ{a]\t41)(
+Nծx 9}!]z?:]Ҭ
+lOxیS*TT*{^0B=qcYB ͍܅K{Gd<.?@F>BA=t
+Jdz{˚V|#}`z~ȽGJY 2bI{G~}f`|VA4־嵣Oif
+ز ;+
+>k+̝/_e@p& OPk0J&S@b t'OvlR%Pa8O$›y`НmvmݸhʛQKi=`sZ4%ItbaqFejXjO0(~6{1gfKM$%  t|k'<m2
+4M@D hm[`٧Q3'F(YJ
+ːŀvjY8
+;~aŦisqڲ )B b;V.YL1L`"bu 
++{t(A*0R
+zKPRA#NjΘ⺾j]x[bVVN=5糴FAQ"
+\4* MWUTRڪ6
+A.xrG}%k<KJ:/l1a e"g`uō4ɍ \a
+pXtq3eKII=BތYejfc
+Vɹ<e
+|rS5n3L(0:rvwi#%̃ϥ|uۥ)DJ+ԈĨtP=N|:5
+u0Hc1ȍۃCC,,tS?O`_Òeڍ
+ w*&<XP2'j8uuD-=<RO Z ,kE(&Ʊ:2$R[$RB셚vb6mJ W~3k4|Ӏ*X
+XF>?elGO(rwyhЇ o9}nzW,n  ħ<+sM{1vphht-S`N Ԭ.<v(CDF%άT$ sO x9B\R i%Y+Dj֌GFbs^-6w mNRR%'4e^䄤,%nd(OHE
+Am^^flu& QoLK&T:Ǖd[UM6<VUFCԵ2@m;8h1Nм3Ef[k, O]ڽ~7%)ROmK,w 1
+"W&Y9FPВ#`2kKRb3 ay{ZdsaO8jWY0P;bN)ll'
+IVZLDO8Pn)e:2||4<Kfμgΐa4M rcñ=\*Z,̝ xI-b#Țej2E@K0C"fBa(B3ɶ.F1}I aԕ8kGD!#m'۷2oytKM5Rafqfz OܥvyPQatKF,7ISoMV<Vx1ek;奔*3ˮYAIP8S=utSGESPaYS/`0&V54pXiKHNrb}- *vb|XB\Lh6aebpz_Lٓ4IL,c
+rR
+xҨv\ Jo@{A:]>#R@oB7(eb9@}6l<wsRb&:˴=M-$XG$/Qwqc9~0h)B{I8LSQ2=\"(ЯNJ
+qF1ɧnlPqJ\j5o~=a9d]q }/q+Ju$Uf|$г|3!UYi*"|xl+jd2N7oq I*–]I*;6Szdl&L:Jh#سRs{jßLd9|7$7
+N
+N(X魿X%'L%$) tѴoZ0OfkXDž=`AWUtY#1ui+3 C^ QDV#Pp,}Z. ӋTS)O+Z !nzH+(?.0UK2 *'&N+ektv'5+H遂)cquӨU71p AR i'XS--m&.qo\mRm;r#9b~e
+hޯ,7\pptE\pc1nX 9г ?o~j\V+
+7Ӥi{\Bx>u?H8ޫXU8zҐ|-t[Bu& 3͕hVt{q•` [K
+ST},ن3GAUJ [.;0՗R1P AQQ.A+ 7k{RL(A3^&|48qH??Ժx$)陌R/axó(pZD1
++x1 |rU/ 6L`Z٣V<ݝD]q:HbAŁR:&z
+ðuk)))K6#Xm-eCeؔ\fL;]Noĥjqj jKi2}̶^x0bpU!0k{ikxp?n?Nzƙ3|.jqz-׬h FFF_;.a;Ҧ
++ Mxq(%}捲R›"%)8N6CJۍUGGK:FU䝖8VRYAtۣ)kagfI)zIZjt Ԓoxe6cnm~sbޕ6mcJ
+β.2st:V!*8WTLqLً͇=uI!IMlms'oN?CMp Wy58T
+⅚
+ vX>i[ܖxF:4:odJ
+`jCBāݻq5>;mA62>kpuy*qRJ
+MY=LD@jא=3RY*YV0
+2K 
+>Z*3JrU [iw!XEab0\9g(mPY}˛JQE-kQYm>AQs&2`]5@xv
+nS6c!1.ϲ
+%ذW'֡+
+ cHaY454"oo
+{~3F^ͱ|N‹(Ubcӽ̂҅4}Ht??^mbtV gMO=]BRңTT0Hfc`
+j7ᅵӬ\([MFAzg*
+*
+1 Bu
+J
+dUU5$1rNtm}|>`ޢec2iǎ=`T +g:*Ȫ5rv
+_i wF nO2J@erw2n
+bsE<L껅Od`:i9 ͂RTyC#eF+}/#!1$&VC~i\xڞ)Wu'l,*bA-6x&Dz_`=k oR=5-h}طˑޠ튍_sORrĔa 6r F|3^Lj<~Oďy[- 4XtU<)~VI hlUɸJ"j3K4al) ä4ceb $pR%KfZI>o)@<tAw̤[ kn(;E9wTUW[kpnrгL:}_5fN`8\7 RFQ}M6)頢d䯘}8v;ȇbsTWK 8 Â k?#-* D1C #NeVvصa4DipjRZa ndHNc3_DpNA\+s3bU5
+Iqj)&h"VV0Øvۼ{)*x! $Ѷ73SXȁ q|`S0ҬeVy=%V!j,
+Ѯfvaٷ;0V:qD
+'[olxP>.єT
+ZO=Xjt";*La5[͔m;4]cij]fCL<8tMU YuE,=I"*5/sqnsS/ΑhR2ҥT|Pm-@`SPcO.us*$ ,ԛA<,R5]X}H=4 0·S˅u1JAO3><>]xV-h*m]G!=޾EZ'J6b~1}7xd,RIjQ;6rSbSgLf/,f ?V-_AOMxn'KRQRfŒ[_VsG!fjkY^ H1n}3v
+ej|b r(Q
+FIj4P/r
+G:}oh_Ljp,<S&cH F)Q-+u22cXU0,,DU25\СS–d%rڸlIX
+bՉ
+CWT57O~uBng:|>w-`<4z#+miJ|82rm-:=h"qb_gq$D4QU:H5e#N`<8ibjQI(ۇ-)32X0Ɣ!]gE 12neY^$jWacx^E> e R y }
+©--..]Ys\ aluBzj X##ya{wMV'Nh+EA/we靿stD̟r̭L
+JSgi59ah6ۥXB [R6GKӈ\{96VǏIZ @١8'{ʹXX_aM^-lJ{R<ȍЎ
+
+~CM't괵5QR̲Qx,/G%/Z:+%]gɘG!Igu.Lh[/ΛnOm9}x-+N Fe6ÉYV" c9F|e~2=$% ٔ:pGu`\4
+s,C ^ F {'Y.u.kO$-E%DuV[́g=wfR|BpҠ;:gvzqlF
+F7߇ 4s0k)[m%
+Q|ɈVP\LJf)rQN7/xWR
+N᝔.'`)WP43Rˡۿ~Cİhjr"a2+HC+
+I•y+裒T3T˅Gpߌ]f.,I50tq2xZD6Ie#:\b":&/k
+sD="]h;4~Y3U$+2RHMck_:7Sb5B6w9}ݒ$R9$~#UTG[Q ~x}NbT4x$yGO.#Y_-1*JXkzc qi׵+?p&~E$![(哋dkystT4 7ȨQm[1g|Q- [ǖ7jӬca?V;XeEHwqZ +mx:6$&H!FmQFc\ @Vu6NJz:@cdz.DIQ0!'
+1׶|62QB,بo@˹~
+AF jX87ub
+\zPIJUu ;C&8B[Ky}݋ gƶ$H ц^ AN-`X>5&s-E=D$$Gr؂8| (=,Ufoxj:bӤEAGOV`[̩gf[Лi]c]-[ozT?0(
+}n=Udm꼯ArQ"̵xmld
++ӷηz4u+F!q)~JvW<FV9ݧvIEe
+m00:M\:N^;2朕0b'd{XA]ʳ,XzPmuu#{4MK;5H7cJ$+[e'Xt>a獶2;>
+Kv+Ӎ~=9➣}Grq `eoI8}._Nͅ J| =t^
+!?kO\vS媱3$s'ig+x؃HU' }U {##F#.F?:^ ?
+W?* s)ږx
+^rPCC° jq "w["y )|R<0yiZҳHSTKxl #sus<~*{U-e 6Df@F3YI؇!皗AQsQOPl)pYYUte_1s6Zc|JIz_$8Uv4u ڼI$\x_YTM% i<K=j
+
+'.ȭRƕj)[̉jgͩ$l4P-![nFeܿWQ AYQ%-8ILQ
+L}:'ÊsCt  Ib$I'v6DNIi&&6gu庺LFhnہ &;
+2b%xJ EMNv[wlɅ%Z
+NDLl&ۥ3sgbQ ˮKz@#e M^N.Tvb2ISUUUʭb:ނz{͝j'갓YNb}& 4T,,Mۓ&fې2<.ZOxHħ 2vl_T"lڔ5
+ϐx{!$ Eey;5aңm/2A5 >صnZj0m:9k+t#U,A2; t;+Y,-ĨIZl>)ZP}Nj[Y=Qt
+iShQY3MU58P%`ݯ}}ߗ |1J7UPa \(N-ދ8itd1Hh6ê; ~'MTj.^Fb.;1vtSС:14)ej`#_{i|8%eܭe"j wsykB@ 0|W-ؙ
+X}ZBHǮ݋ (mQIsl}$xrL([){ܞKK՜Mg%x)˞@ F9NVЩ韡ٿ"Se
+&]Uv 8K=S kaդJjIl3y%堩q;cdbVk{x
+hJ`O6Nf:hIq,4+}B
+q~F+%(iR^2 D.-_˟ $45xǰ<qN#7+x󍑁W!T9FVAU1Ȉ.&QLO}b܁KkvB
+eU4x]<bf̶.<j#n /#MXUXf|PMFa#!:we#f̈ jucfea$g<
+l2'Y55 Nmk>HH hkm⊉)XGb[VOc܂kM!b>/8&3.O$(o.$,A,(OUE>9⴩LTJ{/0 w&k0O.-:Ro'pyi`$>NV6el×ǎ귇!漣^k"Yr;=M7\;?Za8~YVU9fqaXb
+[V)&M:ŀZ]J jJUoXe*0
+V7XQ%+)icot6ǜ劬$StpCr;ܮBԙyo- dO3tC4}UéZI~5-O~ 3Mj¦Eۥo:uF%]Tw[n$ǭIGWP&E5zb2S_&U2X%
+C -=:ff6
+\I|1f<Wd53ΪEUJ\0
+ /.,/?j\g,ZBv(tt^aZ)b
+e6*AxË7ܸ1\v+? $T+:ݘfvLڡ &Q*I7>$LPR<FR"(UloՐjfhq.|zjE#u2`
+il^O^9qH’owe8R *oVy*1LPpeeM9e!(Nd<DDje)e S D%a:lkOU:̏5ɂFyb`pmr8g&tX?n˫
+N8N0ݦ|;m6J :HQl~ 栮uTd,T{@pqx:TĚIw^Pu'c[
+$kl
+s{m
+>襗 $(S4厝5#xvL8aݻͫЈΦ܀tɴx `֖PG!n
+b( tzhVbęogi.}LOzj|a<&d.eGfX-7"%_;!N[
+Oںl)z=dh^6F6`_
+#6(9/ӦCܻsx(z
+#y  6AoX}GTʙ#+Syd?+FIĂO}{{-r2r%┺:[0 IS;؆(Y ՄSM}C h©4Io-*䈤3;6m qՏ>e? tUQUbT|_.&N^Hv,"VwABP0 D.׿|bSE2TUI[XSWY#K,n}[s&$kGVGA 4jі35ɸ
+uAݑH@SvU $3~%JTP { >.q\مEu#c{o l8Knq41m഼تLЊ"悕7۵"zDQF~J ݥ6˭à9q)'h.˹*y#>^?} 6q𷳆?إ:}
+IP`y
+n##Z 0{8|Rg MQǠP5׬:g<JYH, ܓIX#vy՗pH[zh6=]=6D_#ĬB* g൸;4*E
+>WC Tأw-TFk*ͯAB&K$%gV5;d)tx$0<H
+[}ÿz0oH=
+žA=9)0`m#Ć{]RE%ub4h55GFR 6p5tݹiI!K1L} 0h8xtLդ9{ ʿ̷T?8(- ^" 9-ԴtFD)/k7nl]h0ѥiyAVQ3 
+`1
+*2ck#[q=Q1 % Y$Z~n;%93}X
+U`bJR4gܞhկ4l@'jlOeErAzENZj%f+}|`hI-jMcub
+lǝ^|Z$w@8P
+( c2ncʒLUXZW*TUTt8g"-7+ZQ9ƽKǨiC ˻F)pH/۔-w 9tpD?m2NЭd&Rhq|K GJ ^TK,A
+,[IJ'c5.y^>,Ht &O8qԩ17O8zV?<%ρUGȿK {7l/
+X$E ߡjO&|f8Jeǫ6K)U|1ā=/atwCؠ0r %,|5ҳ-̑tM V]A=ۜ{۬iIiIV Gԙ?ĺv7bҾ8:h~)'Ѭϋ͒}R`f#M2dž ɖ9CoPw
+};¡w 6?:r@P89" '0\!y~
+1eX B*1hǷ~c`85۞ o{1HKp6b;
+HoMQ=mEB!' [(ۂ>Y)cxa^ơ eb\djBrͷmx[ljCx57W2UIZqy#i5$1tB>$s'FzI1TOzՙeQNvGNӔasbfK|u`I|úHBUCg_xW0E)q'V4ebW_]ϕYOǎ"dH~3kEJ.
+,f@Ri̷lZBc~dΙfc4NּCU%|iu܄8mk}tͽy:5C0ވeLJASQI>"ʖvmxl
+RTÁIT#
+]廼JU$րLK` :GE' m,.5=Qg]>#*F*駉,}Vnnw6&aI
+
+&Kw;=9)Uc=HPJ-VSDrydD}D$!+$"L睺nYiatuYM E2
+aMiZlfhsm:
+@QMN _h;`kI@TGQ?sL_t%0:zj!&7"6nϪQffEK-0>'\sҵ3>31-<*eFMq/:^%Nft+QCTEU@ձy=#< d9gC@i0
+oxw`^6^
+mb{ThŲNMlI, nUE<OL磙)NC_Q}\)u<s+UK׫tG/udxN孆ıMq[+`(
+hHʔ&"hjNπhv[cUj_]6~VIl:JR6SUQ!mvǏTXTTX~>8L[M d'E(}SqܨW/~]o;Wyĥ50V4Ӌ6 s #R<~@LȓHDktrsU4c[i:4b4iWDuu֎p5#.yƷ r'!I l(Tr@:x cOwt 4ÿ0~A.4B *طdž)
+L;{2P3EgjLeM50rڰ7"{xW3-jY 1pF`m>+*'pr/9zV"3Eq8
+"6gNTi,YP|̘~=dgQ1
+= SKMjȈ:4`\Zds'c6UēbGҝ뵉!Uy#.bFNgfHn%*[:u1UTB/uے婣I5doéJj\.pttl `mx5tDR3Р ֗$ieȴgme -gŐ&ԦArM^䈲f0ķԒx翞Rւt)<p RIZ)(dmHŤc`
+I2"=P'k6 \ʲFб x7 -n$i(0<7.|,1C}Ġ |8SN% xVeCqه3fc4B)ݥ> _V<+m55CkmZӷc[~ѵ
+>bTWɦu.t'[iĞPXڳOq'iϮTLy _\3b+}BUmC
+AtPu^ΞMUQI eo2xtWZ|^B<ßḛ,/%;.ww~%=i*tlO<xRL!F 젎i{s_5s,1lY8){I<HƧ
+K#v۷
+l`ebI F5w7az9CRW<b2)5B]lcs`9=9f KkPR q2=0{uy%˔$8gfp|2>?&3ޞR`SB xYu"w䅼9hbQxFٕbR ^<W0!^uzAkv)oHIm+R'4^l×6()0,a6:3ILm+0V
+Aȧ{s6ݴ]œ\IúNSLHm任p"xfH:@vtԜ-p кH7*JPW}j mx%u{W~tˑYuc?EW Sԣ)IRcu
+>aAXQO@A}iU,f ܭ\*7 KruϮ_˫ UELo m='D  !!6 _䣽;*2g=& vciqSoÇ= VoTΕ,!6
+6 yؽ^܄{}swwk4CxB
+_7pLeY+J)dthĥ2[X-Z)"AǮnPT(?O1V_$C>rIoѭD[H
+&p{_Ykzc|oN*&:ur,wװuFvnV{MFa\4Q,J'{pW=rVutd\JJUP{2CHRxc7rH:PV=&#<qSbϨQMFLP>81hêcjzi#G7!X
+ 84
+GW9zz WaP#MUPu_ËMnrE6ܡGb:GܷJNWQ鏝Ar,v0 AS ,Tn)(۹~p3;kdư,=}-&U0:\9fN({)гGfܞ
+os/?#hwF&܏,i bs^XI\
+LbLo՞Fºa/GbtVRu-!Y h6 =)<M[$R.LK H;eԖ(2Vu+MAx8YtZJ
+@_OTۤ2MnTP,d5M\P+g-m
+I
+KI<`s|=[NHQejV<hYmGėWIMAGfy׸UsFuq%ð*PUooR7g0 ^ n5L.IViBmËd1cUnbЖ?bOh{u< o6t Q>tNaU^NɔdΛa*:=S
+XtQMiCtPaaC2RSc%)Ea ߎ}tp<Z:Ypk(UAp}PIFݘP <RzQAYM_7ͫ![2isp{#ab6
+)M\f9f7
+CeF+ˣUs 1 ʵHIu\?a{<bɗJ_M*VLA*HLPZw\4xQJuVok D(ThQ~ ZOsϠO2m,bV%O1
+'JOU كWωܥ9=&hMv3
+%:y%*H=pKڗi9v2ݲH*Yؙ'Mn"ͧUrm850IP#K\6`5tsC%ee1222>nf6˩u Ju$ g%IJH8=lŧVl3CXD^MŤ4Rs1 >s;̶/%$B1x˿CZuj2}6{6Xh+c
+$6<xz)|S6/ux0QfnzZo*א($_}<`aKbL#<O
+ޝ}AO9W5DZpV˨b|$GP7s2 JҤN TzQZ7V
+&MKY=f8\~ŒqqS֚zBbBǰE
+w>Ѥ`)tdu*؊ցPUBw>^ٴ+xT0&%(Qteq%,O 7Ol "btjU`oS"*$ilZl-ޗ£NZfzr.١)WU1>
+Tj`<a{F']*wnpOIoOd/RЪ:yį"4 E:ezS7>s-<w 'fxOu<‹ujqMG=P`C`*0b\ӱصĎlj,F2aUTcm$z2Ք8\I ;)%eFp#U<aUuxCFBC#N|6WT4ݨpVhP ogM?ᰤѪJ7 ss fMRdkh@e?w7*rӭ:*zjH aL\6Tڌ$ 0/1Ti밵0,q$5ВGl9J8e8!Y(a FI6sMa8R0
+Q84p,3xq*w.Yŀ|hgCKĦϔ撰NLT x ˦}Onϻ/.t,<НPSDMʺptmJ,ωz8 vyb@\X.x΍g~Y?.)dhEPUUIO yn,;B]͋.ANN;Dbs=hmIG CLHJ<Q:ey{2[o5*h((@y]O䓹9*uP'+R a@6[N>t0u6f
+ޅตUT2CqR3
+|; Q8*jbX(\Kqx;C0tBqK3O
+» +$½tBTD۰;tqvtLi Ӌ+z30
+eeT:[^m_Tډ|
+a rTP@"Hh6,ָ
+tj"{U⟧xeZ*Dn
+>0c>qJ zQ #`]S #yi_V?
+%_ 3<$fK<hk`9&Ūdбѵsrp4旔5OTlZuSF1FYUt8 ?VMS%<;۔ޭEs-37XftN3EQ `Z:tɿ* p-oAR|Gq bVjqjIozs1%FRΖ} ٤5[)4U쵀=F!RAde# E-LkY؃@q6SYLdӏH~ž`܂3,|y»0bۖ%2
+q =t*NA; 5S30<;q
+M 'h2jōif M8`{-Y%JUZiᅙz^ ~}Ns-N"}qy1M`CS7C
+B׿!Vh*Cx\
+߿Y@|t߹*Yg™zm^uk%R<P#zRt2H
+Q8F~6抪!S䬶V3 O)Y5+Cɡ*{toVY 3;-eN3܃SqIld)XbwcO׬YnyX H 6oh=rI)Rw-)rTxp!}}Iމ`jN#I61ߵطGz:X0J06l0k~3a~ޞLD%J@u<I'vrXjO9ꩱl! bE:v-UIyyQ1^3GkW~tGxfzJɑ1e&C,LAjrÿpWEf+h)! 3#ZnԢ[8Iy6}t
+$?2,@8,C=r/o 'nLX]$UBm@6$j|xK3\3²eMu<KYOAOjKW py f']x8}g*,H*8N 
+r3d'Y1ˢ;]<5N3EY%Q=NڰPluH#8m4pO+USa!`:"Xrmo!|;Bx-ZOa8*G-ԬG}X_O8K f \kE5
+C4].W>`ܹ;3f:c5Tpb4MFOĿx+EԜ(SX66*}|J
+V24p3몟W$yN
+.`R%X~3$m1W !9\ CO}O\)˝u;)K-]R*?ӎqVa
+ $ZD{wƋ?ަ)o]a1*Tml~|VcxȽ2:Czz-,<fR-&Y~\h,'3&[[X^ 0'
+lsf3RRB @ϫ]>0ާU&,@g
+j
+pVx#@P`:jk'e
+4Mfk&!+
+Tq lUb^)k[I\⟣~0=ņf cgZhO y/Q5rX0
+6rE$i}o2JgT0QX0*yL+2՜R[ˀ@rmNo(Pt()*og] 婆>ER(>Iܯ׾CWfe^]д>-e8]Ym(H#s ~ս8C6+\pڝ681[w4$bvQ^ox)OPT"U#Tȟe䪞);
+&6~v]_ǒ
+X #qk2fD|
+S
+"}w>ߏ&aԣv-¬N8IM_uUgؠZLxRǒE@Ac3̭_mz#:M'@etNS̽;][ '¦I(
+7 ~ԧG2zqF=Y8M**Avםwl1RE*wY<qW^:o=nZ($ч R⫒sEۄÁ0@< 6e Û,/ !*#ѓwHPV~c,GUsADdDdž&I.<[&OW
+$*Uuc)a_h8w喢S4IL
+GpAk[.G󪪉說E.ix>l@R m?%KVjնc~oLhǩoHKfM~oA*RO@* ݈k,cO 8ažj,CѢnZŚ#fJc֔Z e.$+
+3NXI7#dg 75WeDux$Q`TT)oB-ΚC؛a-!*dm{}|.7z.WYO"
+^Uz۽HQ2p=†N~:Zk!|ej]{Q7~ϝpx1<jvxMX.+WbL[r>ޒ i ̍
+yI ZRQp bP`є˘;Rc20 vuǜB<|GovEfE.4J4POžeg SOa$Ab1Z28-N~s@IDzsTP3 @q+鰼xd:qqDٖJ
+♉W/ s'Oii;טF
+jj7) I <Oџae\^en4ؕ)dx[p8G
+ϧڲ2 E
+fjVlB cUڥWde$(h࿉f4xNmºLj4RbpVH]X!m:KٓYljU5L(*8B-!D#Ϫmp1Ι25aH!5FJV9hI]H[۱7ҷf|x@WLg^+?aԱAZ/(Pg:BvW`N0pi#\JoJ[
+9eL>8LPQRҤb?52xO K=瞢fǫ3'ǥa{2i$:h;twyϲwx, )G>uk[Ͳ 5HĚ
+OH&ɸ-p'i4?amE0_&~UT=HL1=^:IFO'n haDJ*GkK8EͰ
+bĐ8#z"t ϳT-Rb4*n|@C^ktZ$$ Vcz1Զ ZA ʵJxRnz>k<zj>8UTM9Wi#qi /Z=5?oT9
+RE#eHEh`#7 ;նKN[cܵ!6N$G*+\3vi@3MiYqQ|gm .6Ig@zatTXG x
+ {]<Myh˭'잯:qY#K
+J` 4"zHO(g
+<W F^J\a+t* ʷ]./ y
+}@A Rm =
+˙pF[.-O 3bÄ]-!),j_[:ˋ͙:5eI>$y.aYS
+åyHc@UYMJP#iY33LMU~ yq*
+(*e!Ì [no~(pq{~ =T͇*ᲔStfqIA/QT#Bj|A\uY‹B;{AN/ aj& +bo}:%f
+pق<.e x*@$8Nnͳ.Rzxnj5~J0F#$ܱ&.SEEdO\7eO76ijKVJJ,C8}5R5%<'Pdcͭ,0*4o/m~NZ) ʙ?"k $wK*~RtLyDZS&Wojć *<G]#SZ?iYVGT"<W<be<AMd0T?A쩤wfRY= tp,ԀN-+\i+ξI*S# I6{UvQ°1[lᖰYfBΡΘK(طծO|X.):h[<[glӰc8vHZz]\&x0F*j<b^@ME>ƬtKlЍ_adͺN͕fF ^ܽV:3
+iݬ)~y6N۰EÌfmjR
+t]#T+]2k
+؂\4؝-6GJ(Zi찭 _f
+IۏE1Jˍ#5/J3J H7"xUYed˔dbM {@$ܓ̫e:s=ؼ2V"Obg
+ºيb9R
+Jg0R71MoˑqXk1)ر>.R *g,mࡱ'8^CWGprfEh4U.Krup.=v5&k)f`ZBPZ
+\S J}
+F‚u%WWSkxn;Z"J(؍Pdž~,~3U|xl!OLvQ.rA'oUfU!"ёp@ݽknۚ=!a лsQW9
+e
+E0OΙ}}bB_Zf l>,`?>,w(JHI!@|LQ֞t]wAQ?1
+*W DHHeʥxP&xIOޛuC=KQV
+?y mHTջ"Džat.%ŠJIH򑶃vٵ:YH٨&>BHu|lε9k
+h3fauֵ\jy%}K
+
+ t>*BW>DJ\bZz3M,yQ2Ż\|ASUICYfI@CaG%<{gRUс$¹4{f`-P|Wfy(i'`уVVFr7wG#1@)Ҽvf&m^&L>F3Dam>tB
+N#&JTee;}
+;8cwvҍDƭ*jX衦AU$AKHuԝonaI[GSVKC<V
+.6VF 8
++0<m2ZaS`5nAE /(,naG ^ୢqTma.t5?j!
+W=d'*a}GVY}N(h!7.+Ӯs>p梋
+t04Ma+Dυ?\c
+E<_Jv6=8d [:tEcru^+R#p$=wCqex੤̱bI__+J@w
+e ~!_iᑤx"SU1GĊ4x]erȓ(5 ȃ`)F ZRLHC8xV\/'4!beE{w8CN4}Azi)S
+>#mM>:!Ln{h;t&iWM7Qc8NPJ_hI]t5~ap;I]յ(4/J
+Zb͌rBGRew~n댸jpF7T#
+MVf@%fUԪ\# U4#k2칲ƍ3IӗM.s޿+ɍ˩. g<N iĢi\[C
+)Mx׶h_̝"PGJv8a{NJqF+sB9Ћaۋz)}
+h.4B\Cq OR|]l41G3bu` GTiC  j]]&AJ)/akUAWQ<T|;*,2z*d5h.a=z*`ҫ ('V[bj)Րk7sθ=vM2,wR43e ^܅ Y)צ wĊT.N)*L*JUDh[@y4o -,aB2c P2Tŗ2ڛq,(:W
+R䬙K./$ci wmr7.$6VZ9B~E@0 lℏuQmcY~Kݏc5yWMFK2d :h&&_Nv5XuJC7qJYfqxIf iߏ
+njn-OG];Y!Vzk\5w #_!TDn;f uQZ.K'M?ɉJR'b=@xbAG2a9eଊIA
+F
+c TR-䝽;E1ϔ'Q3#f/
+E[
+vq5Gɔ%ewXvØrwC'= KĦqՑf4/ĉäOA-1ҟ]
+lՅ\%"!WڕivMxqumRsqh4&G΂'H&L)I?9F!r-2>bٻ̋3*#~˷YR"vD:u6 Gxd+9cT,;!vSo}NnZeCOIFbv lUt
+o.R҈OuIfP 
+6#`sQҖ E,QՉF_7V|7U631ijefP*t/Rxf˷*y #Q{*{\ =ZqEbRdL?xetY 4dIo8bf`gƱ$DGkű
+lUC6 xȾdUbOvg͙-ⲷ0_1
+ַ$akwAVJm0K%;dm ߧ.td슔Xi-ULsU0搝X1qq:)lhJ]҄pa%5?ZxzT EWoQ™h:YIՈ(yIGp
+T۽d G򢭍Fx(56 fjEYf"dʠ2+)8fzeq.Exn-KM Z HB6n2ZL0iRi)=
+wkFPKfF 4<-xPIxIcy^g;[2ԕ4~ŶT2L)&:Yѝ곶b~
+bOJ'Ǎ==(c
+`_6'A<9i|R&\݌-
++'V6;.$n&n'ݲ
+džPJ)8U>n>X #xLAPERwy$#F,ᤕ 0ͩ$
+<M-LK @ 2m|Q %CE mY"DRo.$XԉI WT>Pas)}\NxZև 7vՏ
+wxizo}
+w?p'(rS,O Z5K #LDZjy >sLqen; (@sL>eܼ鴘 5Ǵ)aIavt[wXv$\sHBXPqڇe
+ߍ{pRxw+޵\#NG=:E#RJC5|K/՚`G)i-p8yl)
+1U JEE-,R%ֺi>Xpu$e,}I=)]yqƳb;N0J~ŁR%iص$8mgnghS)$䧝gW U\__q 1iեDpȥI
+\˔ HœqPJ4 SI3^ѮAk"nokύd]qD϶@:R3:JBn[&ÀfZQ7+upiKm 
+ Aƶ&'[Q>&u[N8PbZ6cp><Me#Kijʠ 8d>V\ד2.{Ŏ{%OCEMGX7qgg4KGJ,Fm~=oM&dK*+vAT:+1vҤLW-dԤ'}9
+*DS=#Eo_]yJᬊ~kLL1q#f
+bffUGJz2
+,Xm<}m]Х)V=(C*%? t*s/L9+EyOr5
+W.a4Ԕم>d^Q[[H(Bj鿪_R}*10,F<eo GRtSޜ~sTV$BED1fӾ"BooMʔ&NJSXK@Dٯ>ziK w[/TITTΦ *y\{ pUO,ᤔbnI7kvCh=<CI N?7B.`4a"(MěMnG&Q^h<w\|;zw m
+qƯtjNƃ<%./ ʑF/$ZV,Ǵr²=<iQA ĆPH {vr]ojcUn @̘Q;c+u0bu8yx|Բ@Hu2}mU^1[\r5Jc1wݴ]3y@-ѝ'LF$ˠ/!̷iqj]DiN,yoH#^p r,tځ1 c,RH:5Ur.~ʏg3%p#sC8`+wGM~sf!6a˝XhihpxlKeXzMb bueQl75e skeoZi76Ga)󄸭 zhzN?ǧ9VPVD+=4_-ܪR': N:F)TmB׶nY/B{ p񢉕]^cubfԁ}mI\h=BOaYmYuvô
+Ǘ2"2&\ŶBŰhRe b}{YqD#aH<,>VxpxHcfcGi&WG%j8EvI6uF
+b|ʂ9{xz6՝~l^gڶ
+ۯk/Nf(zu9ټg`L@>GðBlb S$jmaƨ zث8r`gM)hV38EKC?ӎyV5%jx<'
+~-2!Ԕ@R-jT)<y ;6Y)m/gm/pmLjIFJCOb4Qy)I) iKRbvMtSajٍBAe6`E9ʂs dŤW6-+H6,< ֿA+AN: Ɯ*"AE'si;#a` ,+Zni|WYS0SD/0<s%e ]/ vyҏS`NL+M-~7+<EWsڑBRH>˲ʒ)ga3FLڦB}7sئ5b&:8@
+*ԑ%GoM4lJ /MQ<lv1Ge#7>eQj >-sXDYE!;h=oH`ʾP|-}h_Oh&3"X8R.t7{HlQj#8tY!yj7Scb0j:R7p.lořXGȭJ{z0\lA0JzT<|8UèAUD
+SJLg(C7v0V ӰO i$c i)>QX6= 5! ŭxzCXAjiS_Fe*ZcQcpwN`)atbP^͵c'`N?dl)Sw `Y=͛+.$:SX-$fJQcE
+f*IHO2$ؓa_KS]dI4R0)ZԕfXQ Y@JYJiڌ? Wȅ r b
+LS,qT`S})678ai1k>v՜wlt$2TXd|!)c@e_~8}mN.;
+困:8PW~å&mcw
+vLζZm#EN!?Pkgp -IJ8D`hVbff.mc{cm-ȌDT_geB4E=uF7 Tu*&T%fPmQ=3S)1
+w QZF[hUb8
+փ3"[Öd+
+52N]?8cH)Slɺu=ņr%V$Ot/ٱ?^+ݦI0A>)VXJ8R/=(&Fwo^ifY1J F"V /h%#qIezv_ZrOOFjD܃w %-RÉ;,ю{_#v)]qڛD!\A W[1|9Wb-qF
+fҥF?HI4=3o+r$#O"cx\{qV~w(X<|(=9(Z #)c&1*O'$pV0b,Wm_.c=?
+kj20yїZ}u:f
+AӇs؍~|cx0zl%>+Fi:"(녻N;<zxIut
+۾ڣB+u0떛0c_&z!u;;wH@QQ3b82OQQ)ZaYee$e
+I#j}nDZ;
+p.2|2ӊ7Y 'pH7b}ܩ[KOSSOT󢆐46k_^GQ>
+X[V
+n|͝
+榎<_'j i#2ฤՓqeaqqdaMc ikui'hK:U猭Ma5f+JBwkt'ñ:O?h>-K$g'%:z6~>ъi\-25WO>Z(Zw_9P
+-.AO%$2K+OmQYā;hH!b`R
+ώ+Xa*6 -ʆǶ'l;v`Q3\<wl$OۊH;6RK +bo4 ԏ
+"
+ZZvQ{ <~<ro{s Gtjr~bI77T:"N^X-.z<)1:s{yDsJ I>udjR?>F=C;k|xΞhzoVkFwn"T5=VXAMy7Kvs{ywГ<O;ٞMn**I!虜^RlJ
+]/6HB ؑruԾz%t)5[(gU4u#]8?8qΏA3AQOGf%g!+d6ofݏn\Q[+pΒP
+zV-N~BnP)$a}t%t"cYoSIPs~awkØovg|Z=^@l±|QpYLOq*z1adR"fox>PbWi^6[$ ()mGjnX:O1rI0x cϔx0@~* *~˙Hj$Y,4sBy)"U?b7xűK:ɇ+41v66e5qypTDV R.0WǤUb
+ O~7D.LjnC+V y ze\ #{>Ҩ[$
+Gf*@Nj-0eGG
+ꣿIX;}<W|#!a]r:6䮉†M/G+&/>!ӧ0ՏAP5XÂ(jIb*r$~Ēu 2Tpcm Sҙؐ<NQ}tgXDyO ^2cj!(#F>r:bt1.EFϗø M#TH3
+v)y }欏S'K0ZZ<J!pr̎k_[b%8PQW6yb/4!'
+H(xL`޳=EՍ>-+s%Ak!Χ>7s)Լ͆u#
+%Q?*f#ZZ rW}wTQ#C`߾>`^SK~vQŰz*6i2w|5*G7̬ZR |Cԍsh\)x$bG{ o=ez<b<0bq튋 C)O0bu>.2Ug ML_m\ҍVr4ޫk:< W~q! DzՂ%$EM˙/R"_7\IW"_ConY/t10s8΅ގ.-; VKܭJ> qSܶ\JdǾ<61̰*r>(&ɐ̱SԕGQv̓%t52͖H_/aMOƋQ6L]V5&d7-J6߰ƾ4u"+A yBBuK4( J#a>f
+n;jxL
+<UyhH^O7}*${
+
+i!
+ZlC\ST+N
+a/dÔ
+
+*1\5PDn8G>4(,8+NW*3ƿ>
+)Y P.%UJ~DbIȧ7
+qpO#gͲF8ǯM 7G&jI(%5]ߪ͑r<z%ԧ!&hcݱwOSFZN˸[Edk(!j*&geN$7*V,c ج~u?5t6l^<sA Xqu*Qovl}h94cP /͵XW2׷'cY.D) e![*GmKhwO=mxih 4ն>@ 1dJƫCG閝"j2@Iݸݼ$ M[w_t- &}im$՘QWbcv7[36[\p
+LSX!"A1*ja(Ic({o1`]?jM Z
+N*e(z6Am<L4Q:?Ljrk/7]iͽ
+ǰ2$ kNjɈ4tO۷6g
+Gi`XB˘nJ$,E"~<Za¶cdhYg%e~d$mquQPHTdJ%_uc۹I̙rzГw7kZpag ݵD?„ze1猥pX05U[ /~
+=4ln |M:#27 [T13n-OƑs☶UcE1 v~8$foHy?,W|1 ͋b2[mi&0}{OJ;^t; <)3
+^5W\<9Wh|2@<7fdzΕ}t$+XH@C׷:)5%Vm52bP1z~huJjGۀ5z,٦sFH|J
+XɠI]w6hw,*{-/晉Ex u@%J)f5ׅjQXl 8H5uSQ
+F YDXՏakہ4]+= j,M.=L1ge3jt,.yvޠ+l qJsy3U8%'9?SPYA
+ x[2'^UbK-%|
++(M9mL[?d^j~8uv,& <'!_%"5cME
+ "a&+{[ևx!Db3C8L,xpDG:>1<J؆3)円8]C {{DY;E An$g+oh mēzk3M}<<!bh=vr3A ǝO3n!X~#O%$E-ZM?%R!`ln8wJ@>t(lr3WL
+a%TU25U5VLC,<Cb;kq TS~ڵ[ܩP2S3œ3y ud8DDJUOYTr ڎq Fԓi74h#sv k:܃ഴ9 5dfU䠨QD{:[&u%#hj7]h6]y)UIYpJ3whB3S?8Y6=ҜJ}]ڥ,t{`~N\dbt^y**t] `:],E>ONᰴq
+
+rye?h_ jlx읕-n
+}</=1nZ.P/Hfc$S9Y#xS-ƣ|:q.4}Y\*B8)IWVs_h9G WUzoa6]óVKy1 3gaA%H ߒPk7XJx \iJ
+FQTᵒUUH7[bQƔΘ-#U8
+
+i>ãʸ4R,c췁r}Ftej9<4n-O4̘}
+&UIS`0QYEtXFkp(2W̒Gͩf$bnF߽C©űlPLF
+ 5r7/13vqLl}z^Z&|)6GSVrΨE|RjzY _Rg;n
+ ™h&ʣެb
+',gy*&) I Sۣe%X0~ev2
+|Oy5skqLA+3nof{V:ԳkіbR,-.g̛^lgjyJnO`=4o+v2g:kf"
+$T;I*6?E씘XMo(tlZA .(MTM ]xk.q2a8!ՅϛSm]Z
+ozg: q>§ѥY/G ]t.)YfXf6b,, s !;6sJ6m'NbxC<뒣z*1-۸axKGoiq*#gvڭ
+D8E- 8I_5 xk$QK)IMj Ow{~<]!$u¢'W{C{zƽ u<jƽ>uf\&cwX^8K؂s|9)?Ne)J3Kpx U:5y:TAo ׍uЫoq,*qZċh z,0=bmtt}.[=<h񊺐QO8u{mooORɓ8&"ME%
+Rd
+vb1UzDQtG&1JE_LJ`dM>4ɏ Ɋabp$ۑ^;MsE0Vx/%ȹFXrv0)m?>u1S
+V*T@;:h
+e_aFEHW4n$}DtCYx1T"Tp`׏Y9de *`aSpӴԽ-G,)vb>$*0zj<%*12&WtJrY[j Ua93EFVmPM<v4c.V=US^K-8GGF&=Pe
+Og+!42eZ|JȒc-%1R
+ Ca*mď,zoZp4$ȷ-h)MQ;z<Ipśw+RShi>gS89S4X*Zo%p
+tZΔ[(U(7ac[=/8iK",k7U-Jxtyg1[iLYqPزWHXԖmIԾE FX0RUEOFUa XÖe6VN?
+aWm*JB!CGv1pa~#ZᴳF`-kO8]pΌze#.G
+.&Z_u#v'ǃWƒ}
+_&2F
+TT0"AЎ6Wu# Nj<0T$vHom p?ذA@ =]v*9W8)jX)z6T@]Zz8bNB@Z1Cm];-Ń#8p󤉲qO̙J8h\#r $.4fVE0b8bW̑j>6(]wķ6b
+Zd~E4<$쎪JNIՔyáYdv8.W}m~V)6"h'F
+,lO7yS-;EQv<+6K\LJ`%uFve
+صa~rw՞ɕzѰ2TըgQ&
+J`qR=i˫% FO# #{E{ʽٿl-aC%M$,ՉE,a*O6Xmklsk
+3T7vYѶ6x@=[~
+
+ (:4Ru?$cGr=v;2#C?I'[qֹL_w,n<
+bfEIdUU3m׷f+0e a2rny!Vͨ-ZTNb>裗}
+uS̅NiK"}Gsa kb0[{{|6#^t[` )}S0o8GC-76̙oRW (RHaX!?_9֙]u}Ď3Cŷ{
+Zh޷_ 4ehmVQhroe=+"B'עޠeDo_j5} Bw+2]V;H> 5_R0jOU6Q$)ONGa]nlt;۶ZpQ: ]=bWm:-Iɂ\^ U45JFH; 4ض%+ĵsS#-5D2Z#kv.e%,@8j:M]<(~^2Xzz0~HiJ* Cۂ OG6UbAT*4QEl6hS>$ȅ+{)z܂ڽ6ѫ7ÚFo˙פbRaX,D/Nά^p`5 'AQŋA
+v"2מ;H'R
+Zx#m{ү"phsPFF_UPYJa#43 5(Xeŭpgk87l=tϹg2q*1BGNnVe,ҕ%ń1!uQX*pyq"ɔk0Ǯ.70 PW1j'C+S$1MEV1~qqEO b >qOhB(}݃X<
+Ge)Ri8L7 R||8σtKRH
+{÷,-2LbL[nK2NJLꎓ1Pv9.c'\c."7Zzycܮ] m; g=ݗvF*aiS -4dpcpE1JjI3+W R0;~Gƛ.
+@RAͅy/s6mRV-M[xI1,aٟEodViLL.u m.mν#DB:T*%4dLT!v1pXnpȍ1l⭙um<Rf]:.:p5hTY#&̯RK$5.I<*\s.ɉ:57eT6:$"l?~RxƈWb"c1ѷB2+ WPr/OMv27Wbؽ8YBf *r21οa4Z
+YR,CHʬU9*
+m{
+ X'
+uGZp0}Փ6Nh-w͝"c'ˆ)a/M ţQHw}X[wW}S
+N?aę
+,4-CUØq3Z,B_$SkY^()[X^(+:м_1`9)eV*1*'GoU TE>vͥœlӯmk~e⻔!$F};k͗r%nKl #G)C6V7Ը|`wO5,R6r
+O=u]d6yU۬]46lyo-Pb[JxT]́> Xz
+CTSAQMRvy,߹ ox [u)]q&
+'GC$j [&;@<`7bm?3w*©䬨)%$%,nF߷%{M,RZ`jhYeeQ8qKռVYw Ű,d S UU3"]<FUk%kf9.AJga
+#z _vwzwJӂ< R0&+*hή!o-=-6?!3'#6.w*MWߕSÆ1-|Qz1̯_ S_\K Fb1ln6+GۀOV[uYRfq*YPd5)D|ęi|mۈL8MomEa1&_S=6!o 飧y>
+܇˦VnKUU
+J'U>]4 >u5e(|,7I{64彮Zކ$2m/hY8P_r_):1:r-F?v{HZjd} G|S2G 3dmkµ26{xudӉ$׷]T@@
+U|n
+ԡ$R 2}1\^Ϟy(H hq|^0Pf/-}F'η]
+1
+3s OHx}fHåZxt<#HIe\kl^*xOKW<]\>&'p4'yn'4u=:c9D6fNhˌet,&Zkub
+&h7ڀ}{HyX5,^JX
+a00424e,58gufmدorRE2u_ /~r0Nt۶ RuTROOKd]ǷXrcS6!Ji{pp'\
+9|F_wmx|w\.*bqEK=w~.mζN%'3]rj|y:_hv|Ξds"C9 'MZ]vvyl9{PtSV!=Xڪ#7S:T*}ʌfpC{_=æk >u/+e<͘cCO=KB)!M8ɽG²d^\X1xFD6Ƴ|ݫ-
+|'6M#B',02g)Xy1UT$a<[mSNDհj1V`6bYZl8LOM3kˬ3.1kz4tOM  7 Kv;
+q_:IU7A>QVPTLM-l6iQ• X$yq4XHFQ5jb' f:
+}X:AYS`@H$8; 3 ɼJ ;:8eymP~ё:ԟ8qVp8-{C~>qdKԤ1UͅÂj<l8xO:O:,ՌbT➍ᤤr fEb-Ox-5t>'EENTH^׽˶ٖral`vt/}ƔƟ}QsJ@q
+W*]Ѯ$쭕s4
+5/)񪧒&6sD6ͷo;?9\ev* HB@LLϔtsoohrȤ$F'3RSÜvC:UAaC؝I fYI&4m߀
+}8%uooْygKTIàʼnxh_ٺF /wfDԧJe OAݠm}kxc8"_"&
+a~Hcw)N')3 U^#y ~+*_ӼbȦfЃ8bѴ<
+ Qfof͡T@5GKTU;L'ZJT1Sy$
+Ī>evӓ'm$C $0Ǯ6Td֎adD
+NcĮM3ϫv::i;jy`v+Wh|
+^*ڈ|
+MX#+5p!&-M@:e>x-.ܾ_$zA?E4/V͇U3<.Q1Sb ip8͙z.[IWiW_*ŪWiGTME9C%ޣI$xTߵdFĎUaԸZL>cu6Y8Q>U<XDysFjpIU XG*kymFkJ 05eWvۄSWOzzS6d'UqzVmc{oq#xE'FGӯ[U=qf^f2D-rJ ]hv=._0˺Vq8M<Y' 8(f_Q=eh:AUz%j*Jp*R':Ik q˩}0e|dUt>tg z:>(&CD&
+<J3L4X$ı^zT5
+E/K=1 K%YR.&٣;*Ѕ)3>tbCq8@tܫU~ bAcɉLijY sE0aFbEx^sS2fΑ
+JǦFi" 9~Soc&T{m12NFnzWo QXDTh n6<9~a8&LİQC5U%5iO
+[ I<{@FzJB%j1A|'C*IXAQTٓK=L2OQ,U4ҩi_Ptꞗf)I1,Fmdr>7KO17vr3Ey}[
+~[Zc0>5IS HVIvt!g:#$1Hc"5<vޜ:q1i2ax4m,iN÷eJ;=3"JQu:YҮb esVytx%& DF܆߱Iޘ`2]UV'.')Յp[ݿgM
+3ozOQ<[3wE#M-?K{X5#K5"I݇ǂ'IBN8DѢsv]HO@Dw"\i+sDmj&+ 7_9p<JLf1 RF憞{G
+^'i#5;t,E tY7SRDFrI:{>z8\ aa!u){ma_nnpAuVh˦Ҁ@3K }|?$b |ˈN&&H#mn{?9Gxyjq
+l,JIqY|x0ˮ[Si`I?*FݹxÏ
+^f\6Q|VSPP@^xfOH(07Z B:6e-*R: ^~gZ LRFfވuVR1w`,t:M mI]h9
+w[*k/`iBqV1h%E Hl=#@Hvl5ud:iHii>jx4TtXWᅫگXU>,85ާҙ3O :
+|V\E^+驰pi.K{;04QS]2&
+3W1JfpɚwӰ(3:M.MVjmμ0m@aѲΙ47 A8|f1|0 s0o*Y6U` UQ~V(fK?JJ;vג捀 8etCuPɮАO
+pҔ5ta[gُmv]7-H:F u^3?~+svx̴GQk58Ml3 "4X"ݕ-
+p6޲t5eS8yڎw@"ۥ: u{H3,%Ph]vo
+ѡy+P5p[Zd7vogݑe9⒢p̽`GE$f]I(=D-l3\%e(N80pF97+:Dc
+Kp#]n?Pwj
+3)BVI%J$W#jpҒ֩INhRgY**ĎU-,BȡA!@6'S
+ dvs̔uX՟<SYX kF$4+3η) ѱ_ păqc=Ѳϳ矲:+T *$qΌnRDsL)t~. YQ_%.<d uG6 [TYG+`AKI4۠v*.ԝoߐed]pޅ%P
+H<j+KKq(Z QyDZs42Uc-)FY];$8WHyՓLJ þĹW ?(u¢s~3Fpv; 7!{ ~,i^ѷ
+eJ8+3
+T]\F. p#Oއ)r)bxj_l cI%,pA]C0]N~OYw0|F堕&ZȫI"D+@T@vAf_JJ1J:>"KwuHש10?\::GUat3eIlJYFY]"+(XU$[R=Ne*n~<GPc#x嚑㐅 _NfШF͇_4USM9b;rKag櫨~"ʫx$5nM鏢4uSņI1aUK4
+NLNW֏Izs񱼷A1"լ~SJ X ;!ϮZ_RRRI
+=qjҧ`S< [[pUsuً̝;&W=Lą7T Ly
+.5${uVe yէݨ
+*>'b-WPWи*F+,y4d̬9m
+b~A5gz"0?^tpO>uKSVFkpF$xebQJQĻ֦}m̡͔)螹aD䈫x`E{S*VpBsWh`
+N-zcۊki
+Wx,WX$0 J-nHefU[0b|@VjJVH3=y䳔%!R\QR2%K@$썘喇#'qhx]n! t}a‡Oׁ\<S|\†Օ}<D]d1mA8y׳W[pl?"K`J8$8d 9-1k@[S<.yhSv>Ocmt1Z1_L?7E,t_*`uRO
+7ZOrj:|6;1F;~]Ž#קt̙sn|ylp %  Ǐn*1OE(yVhuMrԹBzx D;x:F8U-n3wvTT43+ `
+\r%1}z(_o|Ջf:J|/> %=ZFډ_/۞v'ӌdUZ90H$5^yP?Z-w 3W;问'OO[cV冲DuXyIܕ|
+1OE5<m?u1fY̨(4¡ZZvb1 To􍘱c&@}}*Uo`Ea eݶ\~G#'
+25K .J%NlI-VHJ1
+867). EQJ@PU>p0eBSta//\p< $wK3b{O
+P. H6+qu7d-#ȷ L7Z)C2x󦒝 G&U_W-RÃIЯ'ɲBаz0#m'C#В+x7c{}4l#k-R1QST6C\#{})xO/Sja HpaR5phi:\g>
+NWTc t>
+C%|I12R"i *>eVZ,$pjoF=G=d>^c`nY4S_08quy/8tma|E,?^`
+;jN0ctP[jǁ4$ӄ#֑==5X]dCްOy̓dʼHm[C~ _Q<
+HLZQ xS)$ĉ
+&v=]T+ucӾQI𷚛6Z"*$<;g
+pc`(
+TL6M7#jx~nϓ8DUWGCZ
+o"x.3Bp׸'C3Z
+R1n|nE42^
+Y>fɱD6ރ}<bẀVV ˁڊlW+GYC,o5rMnrAp 8t:5~y%21i ڱ~
+;"'7~^!}y7Oe`QZ_*"vkl
+HږoSiIQ^nն|*p'2Fq ,37ՋB*YPonc洭f-B6kD _
+d4HԾ(<HP=òAWL没@,62/'ͮFW0w[@R-Ҹ`~.'1cF|slC9ᒠF´[,tKXQ8p[KZ=lOY^:TrRl]wݖ0Ye5,DU ?ij%r\a`ӃLf jH\Dyb6tʙCum;~r9=dEM=Mعm"RT\Xk߅[mN(kG;v 7=*.cJޝl 'c\Rx^TB xe/2 B ׅ‡!u|ӼK^8djaa."7j"ٲwdWۥ%F 'c?/dZ
+#<@
+_ËSM3&
+cD_?Ghfꘘ)IEC
+ ̨asڇ Wf̃ vCmIP/ţKJƽv,9hD3 t;TҥL4*7-EYГ2M}0`Zʍ&|
+.-*Hz(:^#`%Iaz Ʀ;5:_kÌ%B>1bgPj7]A6\[^ ,[BCI̽L8$[)F8*fZx0J_%/BGc޷A2Qj F_4~ѱ))=>ҩf
+;$վa=٪j*S<G37"R~mf2<S!U8<shyJRSQSSҼ0
+ڃTWQzg| X>!<`7F ʞזϻ;o1ŚĤA;AT`UV']膧>P5yTm?;K]_*Sqd-r} z˝Ur7`*GnT+wRf!ĆԯH mN\2ضTI0Q=.uү]qld
+ƫjk<CFIYx<>e؜uUrKȖ%
+e'zEαl>|Ï*,p`HEQ<'V|Cb<'&`V;PD*+v{ck-KD-<:G}1^*5@d
+fe${ xncҺ,b0`S<GrM-߁Y~l Fكu1_A"Xaw
+֟?a,2/ÙpcSj(E[h*[íXk1HeGŴht{ѠVW
+uƺ?88)NTg0~=(zlW$&hj35Ƿi Ctu
+6PK_PT_GDSJԹ&<O0Įˏpޗ3RcrfUA,6I%kp;g )P"˙(+&105Tn` jE*@54p̶a|8~E}fu10jUDj,
+D7r5 ȏJa̩q¦\U@j E>% e`}.Xſcxq#c=T'1M]<lj8J֒8`}Z#h50fJu!56!)H%XpA92GewdGW1E
+o~x+0t n#_^%
+coO-መ&7Fx>uZs,>E5 c:Y|Y_8te)(BS
+$5xwVnݵ?ĚrjJOE̵Xo]_3T3rM=Dž:sϕ);,1*2fa#~.,+&xZqʖabT[R;E`SI )bOv_p撗IMnVPepvT8-f8&\.y]/ OҎӵEEkIB wkrj 莉+/=T(SxqcU$m{l.xcǪ[AN$aW᝞@ ztW'QQQ闬ܥd7"UTfvT Y6{;ȹeVIΤ{8$VR#`P"C%ۆ i>dxrHa22U9S1^4L22U"c
+2
+|3
+!XQǝ:nV(ɩ 7qJ9qq:qQ^|"ijMF:4'ܗswm(&D(tp'
+?]4+bQF!Tcֿngeݚ l=3۽05*A #4lp'g,+z1 gDXUY'H6IO-ܮq8$;b[[VU!:|+|p8@
+V1pjEXq̡]Ge|$eޣ"$"fDэ
+o,[Hi棂SuSk>}p 3g5=T*l5ػ+!,tkK8@$*|7k흃PD.y1M5T5pa"֒ $D {O-rаdTƒX<IOėmH.ᒛ%`nYI;諾
+l0=!
+GNͼESFn -vTXu٣qe2n-)J@
+:y'q`x rUzA15G[Qohtbu?PW`ŋ{:|xE t4
+w  .$%8UjO:㈦HQVKff-nXDuKt8(CQ%f c XsHHHQahzAފ3
+ʌ'2APƛ`=׫ ĦRfcXndI0dK}u
+o5@э
+gkY~;LdlQNt+ ZDzmw#NpdY(`ƞ _o:{l5㛩{}zR4pR=Z]Ll#ˢUYUĺEA|YQOIK4܀u:ݚz.⍄Vu  "_ˠ"@,GYբ޴~\`zjgYu8u?6J Q&3!F#~Q؏Z>I$-ةp
+1<.[ #KM)W< oKgsbP`I<1]<izEşP鶥z/)/8#cBg<9ELz-rX1 Ŏ<CDSpNwoew*̤cT“
+pIXwtM8mM;f1f#߀Z,/וzUUzԾ溜b6x&깞T;_˅DPZë_I(cƠ_ˊeDAKQ(AE&xT?,ae\Cšt GZ'Uʱ&G<d7m1|h~&zb, ͔ oHf2?S^~,Onu>U4wo"8)O/={VA#֍7wgqu)bNo_so_VanG2e* a%Ua
+B,6wU0Q}
+6\D] 3mÀVp1?:<N 7xg\n3'\Pj8}LZUMƎdumcS/f; cGI\j+|~U 4%أ{aĺϛ>'XI/5 CTAz~ʹb)й]V)vvӹ~%pHQ
+(}I-;
+endstream endobj 19 0 obj <</Intent/RelativeColorimetric/Subtype/Image/Length 35665/Filter/DCTDecode/Name/X/BitsPerComponent 8/ColorSpace/DeviceRGB/Width 205/Height 154/Type/XObject>>stream
+
+
+
+
+
+
+
+
+
+
+ 
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ 
+rS&cD5Ts6'E7F򃓣dU()8GHVe*9:IJWXYZftugvwhijxyz
+()*6789:FGHIJVWXYZefghijtuvwxyz
+Zev){.'J
+)X (Cnzl׬J<Y3J~tT4Ob#J4vS&ոCdfSJ$d
+ו\j;⤠"D#gU,'K*RYi):I=qIÆ<Ual+2Vo6W 4L:X]k/rܙ ip8>to䨷8:nbHT8l(da=d>54=GٯjLG GOUH1.H
+D|H&/^&@QYƓB1,SܑW $-vp˭mgkIZБGY>Tj1U5BDaI0úOAN׶-ɕ(h-cSI@8s=D(F| ;5[u(ಟ&ٲ^X [*)FDZz-;iO< 4qpuR5 * n 5EZj,=(a:^r*TaS&IX6/`<b(:P:ڌV ?)ib*ip$/HV፴: I?4pR@kx*uwK(͒%+v.
+}I;Na mg1#SH
+#SĊE}^8{"5HI})?n*vPL!%X)*֗Jj:oN°Oxn
+Y`©*JQHQHJ+FJ-«4{$ή
+Wt3_֍%%|X|Ը]G˵+b3M 4S^I)%ћb7:;)e@* 'e*[.%( (ဘHNB8/*/  kK$-> mPR$`7#
+Pߵٖ)&qLp6c wͶCA:
+*ʉ1%c!00p
+/u =Eβ_Qhp콏VC-?%T췔cF3}*˻NB?} 71ʭڴi(#R %cg q7Һ<R|s JX!zb *0#Eyf@Y^U{rtą-F|80N&:~0r6BHWd 61I]p:u/ESJ(*ij^(ˁ*B)m=qad$ Jўa69jx NG&y8NgjtaqQKQU
+nnQ~
++f+_xP
+$[
+]
+#r"ݾo:+HpTWxF0Hv[K^IR<[%n;֤I1yj̷b -rXTTP:XaĚ8]GnQ*ӌq] SG+804I*п^~#}v͸McrSh, pL:K!jrrŖ}ޛם ï{K쓴k]7lHV:@`q5NR5\tTU )S L~lqmdMBف"wx/I At0v :xjOߍw!)KXV*` lX-^cI\)?#"$IH`TK2Lg֖#SR:xÄTfmU6}!]uDJp'D#Z3&) j|MGbD0I SG\-Gˊ&52<YY@+vooh-+N<<QadSMݬVAzp
+|j C'oi$W Za ;<d9|Z&&`ABE:3ԛh
+O8% ; zI 5Ueb6 \XիUl&vBMVuW]S n6|E&D
+Z{HIBmyBxnDap30=8PSܓ"|_ ̥\1j:)3c]Cl6<~::yrigh~Nk^%!8ή,(Rv9y
+*8tF
+lH;q
+/BhWMuLԺcԒVLlvܣEymA^)m4qÒ5 Vf^]Mg
+mO$ հI, 9la4"b<-Qb[ =/06m6uPT1;$Ūn"VPAFS~u{0dqV706inG] WTaFmjn4#T[KS T*|
++l{[Jz hF1\Ta66,ZAWt{6++CpYE @$yh5 v}YݱD0)ԮW~:3<GPLI⊶Zrb]0ԋTueyb LDqSmk+[v#N@Q:Ǡ5@aS\|2YiU/4H&mh6`,N}Q!:V4)?w”J
+%DـEOgYJ\2%EVjOTK3M$b1!FnI%}K6Xݻ
+Cd4
+W
+9}dp`IQ1zPuw={"a
+[XvRڳ 8b3pl,2t6.&:"|i$㲃>,u6x--A*~nW~{H# 9Y3cl+>z # dpI$cSM6Cb#D-F$Ǘ\|yűޠʵ2B!jaIhdWhLn.Bd2sw::HouSWYK H L'>>T/$RGgpj\^:>j2 J)7N[ek=1"vyKB-c†e*}%LLMq(r.Oʘ}lp32CC3ܱ#
+W#[da&xD
+Gb2̙߮}n9,J qhtk(A5Tı:;j8=n5NPt qvQ܀
+̀vlglI|s@(ez:|Ņ2␕1l*u> G /-Ԃ&N4u'TÍbˉYUqV*58kk(I$F
+pc F$57㦖eFRXIIVp$Uih{6 e̷x\'֤ y..Ҵ~dp>U\CxuD5 L^#m#̅ r
+v(uIH&AQpG4WjHp O:S,nÔ6xv(wKQk. Dh>t'̿1r[lӇ.g\ YnT+EĎ-$ٯe:p=-#2$ONon ԲL
+aṟl[ۣJ1vhAinAV3JN?\׎yG-u&:JfIG,BAnn9vIA24U@۫sgj7Ũ[QUDRWf
+oKXƈQe̞6ZdQ
+ʨC:u9 7[ĔcQ[)R GΙpLO}>xu8P'f?{ߚV6-jPPS.c1^@dKғ2 *[e_"}<k(,Mf$mg(sg|zj<b*u'MhE˘'3{5&׾WpF)%XKWY+3el EWZdHK?:쭜SaG@)%1HZl$U10cumDZY<BvqvW)$SA3J|7sY5M䡧5%
+( @7JPg:
+J6,g)fzl3%`d,qeNĝn
+i 3 ZE t_5iv>;';('>fkIr)Z
+Hg z;"uNb-T.'zEidE FI_9Y!O\ ԡ*8ͳyR
+DOI>s3@4^9F$B<X} ۽}Iu%*ELƲmɹ(ϓkj0͏TU`X 4U[hZ|se-(Ax:#Žw[tr_KJ))%Q铺bX` -E }\LjFĕ<;)xn_Уp
+$6c^q
+]?+1ˇViQ,1 !a
+k*c8*aV7k-H4WP'gPiB]HL1GE'KSsvY3IuO&u =V:uN 4)m^WzG2Un1ORRbt]TR=U<ѳb
+/dmn%)RL̀rO$tϳG[7~*J9fˀfиЭ.<E#_.ǚ݌#K sMu4Uu*S !i*cc&F<:ZV޹}PduI(bs9::5
+hQp\9XbgYb$嘒I'_o&K-e( 
+G!uxa Fـ
+ T*Wcq~7:cN t>Yb$HD@θg/L=, ɘf 4[Q*:ƭّkEƣ9J 3
+6+u
+>~v;Ŵm8% S;m_]B
+†"eQ
+Aи,V\.YphUA${ n}ŭ@b@ᶌ-˟(88X6WEB2=UoN<ƫ2<V$Ge*MIf [¡dvc
+vţl $qC!YW0!|5A->abqaX2͗y"zNX
+#N =rdtQ_ĺ=zVFo6Ml!xz)p$
+I3BF"N)땃8uvXpŲQ1g9
+yF2/u<73FZJ0# ZֻA5%U^$CIQ㥤 Bb
+3"btlo9M48~XpJv"c&U!zD) |tѼ*JL1pZlzʘ1dR(0%J Xmؠ:0> 
+?lđDPYբ
+}6^pƣa٪#ΒXLӵZ)c~߳m\ FA$GP2~m8vAg
+AN!zMYq73_aUM4kMJmPxLi~j2cv9 ܔN0oV49y{u
+{,G]v[aJr`<$Fzf}Inɮ[q֊аbI"lQ6&1a2<oi%x((Q4yOo9QKinD'i8GMFylYB[O#슉c&u;M?.WƣaΌ9ibX26un~w(P 8B34% LvNt ^)ӾeʡMLrl^hdGtO'؉PY (lgQQNR
+?P=6z
+/5dM@U7y?2ˀ(n徢?ZzDjQ>l#nV11ƮstZQƋ.-P*1zjjqyZRCxI߉EʛJ̉#-\Ib'M*GXEqN]*Y2H`x `zk7Bq/T4nIw){m, -]+CPR8ԾRSfΣ,sjWbVUu
+TzR7u(cb
+QW-4sɰDZ3 ܓ½^bt&'8GR :ziǦC3R6|:"r)(q
+HjvgLLehl yem
+,aj}* vp2ɥ"c p<8F=企׎XWuKOnc'Ul` w9-Զ%A H>%*
+_tn9X5 `Jvlp6o): /rFrRj<ѓ3ds5qVHEZFp#\>gޡJJAN0c}e!hQJfAT.e2dɇSaoO
+@Zd1!.O}oX<:N)$Tjܸ zM,90L:,E}zdC%<.xj<<l6Y^i┠ZI5DZ|/_/6 @k ^-Ҙ1> O-_4r%cUJP#߰q$~RH&A$hE˻Z0l 4x§zCt<:n"V H֎:ɿtR#WA;F;(yBV 0&'nM8s5]:ԉj: j/.34I
+F'y«gGTƲ5(tL ޠsOS36Zk0QPFii𧊨X]䐒i%sam߫<ˁ :N8aYdZZ`GNINu[9uk4Éi'4
+X./%FfBܷ
+4f,",;mMk<uL\)>To/R}Cb*Xf #l&4+blb*ܶ\,+.Z|BD0լecsB59#̕8 f;JeA9kZs<^C rX6iuJ
+1HLj"U]]bުP{y$9jث
+PfBpHǦ{oyi<JL<z=pi;:r5|6͕>uG
+:Z('VGtԨ`0HR;G}H}դtjG QϼYsʶu(HLJ2AIƛ[3-%mD4qf
+CK8ekE f
++ԞdL[K`0-YS!G-t F[=pRI'JFh!gD> ᇳ|?Pz[AOݘR_6!V/n-Pˆ#笫Urxt8Dq/V*deO/Ao<emaZDABGtUom?hTuΟ%怢Wa5PHVH,onmR.JTy)2ּF .X.e w2`I@,HIb-vN >ݎ3lQ@:&8ўG7(ZPcTI#MzzWc/a/V3sIGp襅$,B9R^m \*|0m:Q;OA;([ŧ:mK?0D>gW7k&LӖQWkd*j9
+p'Y(jy%id!З[Nnz۶IgG9Նy "AAҙ#3F<h`izOIsd'ǣP5d@J﬊Tvg)֕
+P88J9it&DpH
+]ۈ褋#F*Ӟ`_B_a ӴwWW&aYK1t'STR>/y`.X(_vǃl5sp
+W`mO*)i4jQ Xn|G›24É?*fX9#6,uFk*=Kxݖ턉^am/:wFR騯Yc/ZMJ36<
+gZ5
+NH
+moS1oGF(N"g-JQOnݥo
+BN8)erKi}Z*|0 Bnv^g:^Ґ:iv^)=O$O bbUH pMeH?- P r-^#zZ^ _ͫɨ߲:x̄Y xGn2D$ @
+nf~;PE I0
+]aeiLOH0vwٕrku] ^A vm͙.ayg##|.9kX
+zѬB;{ܧ5j\YP;
+Nٜ0۲vg 76) 8C={z)OԟJG+# 8]3:ަZHbhj
+bE
+_|Npܠ ' 0O=1A=c9HqWBS (_ViFcU
+**9"E( j$DږV[*YH;| ˯CJv{It.#I $GEaм}E]|[.abԡ|M$xLɑʂubIo5d֨hCJ$v'@{˹nJ1(1zr3bi)h͞u@]6F/ Ɖ+¦Bb>#_`Z͚kjP!݈i6V-Elf`|RfJ>x)U-6S\V@4ga!(,H@{4bROM,rѥY)qPrNKkMa FW
+LVʢ~a5'0vI{wn{պu, lQkAzCxW y"&8梕iڜ7Y+E$Ns"G/-20 Dn4,_.
+U
+,O+f;6cp2=N'n ;vN\` r &[M x~Y]T$mnxkzEic=,O]Ծ0zJsQ?: a|<x]qm%R^nսF!˽gvb1h){4ThRmwҶ*OқҦ1<~= }86glOx씰ddiMQ9+
+x3Smn߆5Jp
+Jc@5oo (x)aPd3
+t8G0ndjsKlBgdo1¢r6*H9zBAF b'u :I\0]*:9'jJ2a4nk4
+]#T tp.9 -.(%1I{[嗍
+p'3я>tc}-l6*6QCXO $ƪeeA`5i麏%%$&AԜt*Y݇72Z)+ Noty6/ tX?NW9+-%|zBj0@!H G>_nCJK
+6|cGJ~7}/f_꼷pj * &8`6m
+Q[*GMȱbu *$"rX<s2Ĥ
+yȞ:rN .f2,%qL8]Ц;TX+\fGJN3#\0rشA'l ]WñLcYQAUuZ}N e4*K
+I%ۍUlbDmbw[Vu}DCҤKRL(#0+"ci ):m^ (($cS텠FѪv%g,Nr?YrSe ;8=æ*1$`*+&xJ))%C*m{ ~iM D@
+hqX]P˸˰(Jnv]u>5岧
+Ű<BW lI[ܸ#P fP zi3@ K y|]>bMp9TIu]u}b5q]ӥƖMkV
+d$kew֨$ }"D6i[ Qn3aN#^%4pc(RHXX4( QvkdMҀ>/gGQwiB~`='g1>l\δ$舕4MDPxlȫ"B%G܇o D|RG_N޺+2TPL{o%(:c8& gصTY~\q?)')ՙUGFlv8,R>#(rƩ{MUdJ3CIttm"E
+T3a" ltB{d$=T|ǜ1_e[rq#oÜ?}VUsiX!:)3R*n nrZ},菸] \P0C̠^wŞA%ĝ5S "j
+&ik)&!(2RfA {Ưr\(ґǧ]ӄ/tG9|Avv:zU%I,.Z
+5ʂ
+W@Y,bs-ԣ
+0<07)B$ Fƕ~rșOQW%=~WiUez40.vnb
+1$(p IцXLF̩O"RӊDJXo_((l(Ԩ1)՟KU)R͇YHqjYbqWBMBXCk
+"cOOfOCz.%5N9[aXҒzFVP
+pAAj8z/q:L\]d:/uǫ)iJ%Z%[1[߂]
+,7irn[r U;u n E'ޯbVuW)|%]]LTTѢL'pU&I>^k@Y 9眧|ˊ5>c`FZ:4󂪋"t#ȭe
+qVnY1 ODY
+?SGJ1Pd&|OҜAM{1W*/[ 6n#"6t~;]aIz
+i*Ү&Ze x(̬.[R1i EӜ_uN
+zhsd#=>r! Y5R3Mt}mn1u&R äQ{@:^A)8 a5XS sSr4.b>x "
+ luS}Vz
+6JIDD7&u]FR̙7hpW?iG|Mݡ*g0˷J\A
+>#ÌIN<MWx
+OBr't!`ty J
+Z,;©i`iZVew;&]Ϲf0H ٻVU ZteDD DU޸adjN,j1
+AGd2J&:E<swvl/ky RXt S~L؝D$ `'ZVocV3%=9땦d6-bwa2$c
+
+Jlz*di䨢1:,lMKqPRZ>i#gn{ne-ĒP$m pzj
+Zh^Z/O+3#5&o.Sw]~7'L@!dc׌ɸi/ ]<8 4f1L0azS)"
+0
+#JIoU36 bzO%CDjdHӕVODO>}4lv5c&&-<qŜQU w`[tnIRcKY#1=ti;vl
+u4Mė/~KjwiΊXn.\:Ie ?f,6Is5gT 2=- df%K) ٶ Iq
+J
+hi36ˆWqQή#މ23; vy+āJC xΫk/r_,Fdbk$
+ Č18a=;E Cy
+~DR  1F.;1p)t(IK ʓ?*~i0 F &***9< 1V#>Ď$|fئ@pz~?hz+՘/\pr,=E|J M$MYɲji#a#H豰v"OUan.]I$=92@b@
++~tLEuxT P
+X4XΉQrBT? +jwMDɌ18_15pKj$NqƉwG}uW7f10 ®UF 1Y6;B7n2>)( +f=M<R6GOB:DFgije|YjDb&F&Ma2X
+=tWr4mN8u~\
+WGx
+ #nuKǥKMA6W ux3hUFTj0{ӹ֛u(
+Hdt!_0\C4t"xQ6kfih ƋKN5c{\p Y5 |@a-ZDt3uiz PGOb)yhJׄQEXX܅:f9AmPv N4eupMPzF\!d69@0 -ɴZVH"vkYA@g:*P.(Hn^P c L ?SИlI0CRVB, __g)f/?;|4O
+{V^źO56*(G,M4A 1TiEk=ӏ~e
+/
+\
+3?Mq}=m
+endstream endobj 17 0 obj <</Subtype/XML/Length 3302/Type/Metadata>>stream
+<x:xmpmeta xmlns:x="adobe:ns:meta/" x:xmptk="Adobe XMP Core 4.1-c037 46.282696, Mon Apr 02 2007 18:36:42 ">
+ <rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#">
+ <rdf:Description rdf:about=""
+ xmlns:tiff="http://ns.adobe.com/tiff/1.0/"
+ xmlns:xap="http://ns.adobe.com/xap/1.0/"
+ xmlns:exif="http://ns.adobe.com/exif/1.0/"
+ xmlns:dc="http://purl.org/dc/elements/1.1/"
+ xmlns:photoshop="http://ns.adobe.com/photoshop/1.0/"
+ xmlns:xapMM="http://ns.adobe.com/xap/1.0/mm/"
+ xmlns:stRef="http://ns.adobe.com/xap/1.0/sType/ResourceRef#"
+ tiff:Orientation="1"
+ tiff:XResolution="1800000/10000"
+ tiff:YResolution="1800000/10000"
+ tiff:ResolutionUnit="2"
+ tiff:Make="Canon"
+ tiff:Model="Canon PowerShot A400"
+ tiff:NativeDigest="256,257,258,259,262,274,277,284,530,531,282,283,296,301,318,319,529,532,306,270,271,272,305,315,33432;61A673783E262E836328FE5F0E8EFA3C"
+ tiff:ImageWidth="512"
+ tiff:ImageLength="384"
+ tiff:Compression="5"
+ tiff:PhotometricInterpretation="5"
+ tiff:SamplesPerPixel="4"
+ tiff:PlanarConfiguration="1"
+ xap:ModifyDate="2011-07-12T12:21:23-07:00"
+ xap:CreateDate="2011-07-12T12:01:20-07:00"
+ xap:MetadataDate="2011-07-12T12:21:23-07:00"
+ xap:CreatorTool="Adobe Photoshop CS3 Windows"
+ exif:ExifVersion="0220"
+ exif:FlashpixVersion="0100"
+ exif:ColorSpace="-1"
+ exif:CompressedBitsPerPixel="3/1"
+ exif:PixelXDimension="512"
+ exif:PixelYDimension="384"
+ exif:DateTimeOriginal="2009-07-14T10:34:15-07:00"
+ exif:DateTimeDigitized="2009-07-14T10:34:15-07:00"
+ exif:ExposureTime="1/400"
+ exif:FNumber="38/10"
+ exif:ShutterSpeedValue="277/32"
+ exif:ApertureValue="123/32"
+ exif:ExposureBiasValue="0/3"
+ exif:MaxApertureValue="123/32"
+ exif:MeteringMode="5"
+ exif:FocalLength="422/32"
+ exif:FocalPlaneXResolution="2048000/175"
+ exif:FocalPlaneYResolution="1536000/131"
+ exif:FocalPlaneResolutionUnit="2"
+ exif:SensingMethod="2"
+ exif:FileSource="3"
+ exif:CustomRendered="0"
+ exif:ExposureMode="0"
+ exif:WhiteBalance="0"
+ exif:DigitalZoomRatio="2048/2048"
+ exif:SceneCaptureType="0"
+ exif:NativeDigest="36864,40960,40961,37121,37122,40962,40963,37510,40964,36867,36868,33434,33437,34850,34852,34855,34856,37377,37378,37379,37380,37381,37382,37383,37384,37385,37386,37396,41483,41484,41486,41487,41488,41492,41493,41495,41728,41729,41730,41985,41986,41987,41988,41989,41990,41991,41992,41993,41994,41995,41996,42016,0,2,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,20,22,23,24,25,26,27,28,30;1415DD4A18F25440072891B84A65FE3E"
+ dc:format="image/tiff"
+ photoshop:ColorMode="4"
+ photoshop:ICCProfile="U.S. Web Coated (SWOP) v2"
+ photoshop:History=""
+ xapMM:InstanceID="uuid:7CECFCBEBBACE011841685AA9CCA09F5"
+ xapMM:DocumentID="uuid:C377191EB9ACE011841685AA9CCA09F5">
+ <tiff:BitsPerSample>
+ <rdf:Seq>
+ <rdf:li>8</rdf:li>
+ <rdf:li>8</rdf:li>
+ <rdf:li>8</rdf:li>
+ <rdf:li>8</rdf:li>
+ </rdf:Seq>
+ </tiff:BitsPerSample>
+ <exif:Flash
+ exif:Fired="False"
+ exif:Return="0"
+ exif:Mode="3"
+ exif:Function="False"
+ exif:RedEyeMode="False"/>
+ <xapMM:DerivedFrom
+ stRef:instanceID="uuid:FB4D5A37F39CE011B6F8B3CF2E552537"
+ stRef:documentID="uuid:FA4D5A37F39CE011B6F8B3CF2E552537"/>
+ </rdf:Description>
+ </rdf:RDF>
+</x:xmpmeta>
+
+endstream endobj 28 0 obj <</CreationDate(D:20110712122634-07'00')/Creator(Adobe InDesign CS3 \(5.0.4\))/Producer(Adobe PDF Library 8.0)/ModDate(D:20110712122634-07'00')/Trapped/False>> endobj xref
+0 32
+0000000003 65535 f
+0000000016 00000 n
+0000020455 00000 n
+0000000004 00001 f
+0000000005 00000 f
+0000000006 00001 f
+0000000008 00001 f
+0000020506 00000 n
+0000000009 00001 f
+0000000010 00001 f
+0000000012 00001 f
+0000022389 00000 n
+0000000013 00001 f
+0000000014 00001 f
+0000000015 00001 f
+0000000018 00001 f
+0000071751 00000 n
+0000345787 00000 n
+0000000023 00001 f
+0000309929 00000 n
+0000022613 00000 n
+0000023001 00000 n
+0000022500 00000 n
+0000000024 00001 f
+0000000025 00001 f
+0000000026 00001 f
+0000000000 00001 f
+0000020841 00000 n
+0000349167 00000 n
+0000023665 00000 n
+0000023268 00000 n
+0000000113 00000 n
+trailer
+<</Size 32/Root 1 0 R/Info 28 0 R/ID[<F2C926B5EF2FA34C92886BB35B3E009B><2B6CDDA818AEA84A83B63AD5CEB212EC>]>>
+startxref
+349343
+%%EOF
diff --git a/doc/gs-vms.hlp b/doc/gs-vms.hlp
index 36eaa74e..08386531 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.54.0, 30 March 2021
+! Ghostscript version 9.55.0, 27 September 2021
Usage:
$ gs [options] [file ...]
diff --git a/doc/language-bindings/c-sharp-ghost-api.html b/doc/language-bindings/c-sharp-ghost-api.html
new file mode 100644
index 00000000..b98732af
--- /dev/null
+++ b/doc/language-bindings/c-sharp-ghost-api.html
@@ -0,0 +1,475 @@
+<html lang="en">
+ <head>
+ <title>Ghostscript language bindings</title>
+ <meta http-equiv="content-type" content="text/html; charset=utf-8">
+ <meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width">
+ <link href="https://fonts.googleapis.com/css?family=Source+Sans+Pro:200,200i,300,300i,400,400i,600,600i,700,700i,900,900i" rel="stylesheet">
+ <link rel="shortcut icon" type="image/png" href="../images/favicon.png">
+ <link href="css/default.css" rel="stylesheet" type="text/css" />
+ <script type="text/javascript" src="js/default.js"></script>
+ </head>
+
+ <body>
+
+ <header><h1></h1><div class="menu-icon" onclick="javascript:showMenu();"></div></header>
+
+ <div id="burger-menu">
+ <div class="navigation">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link selected"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+ </div>
+ <div class="main">
+
+ <div class="left">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link selected"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+
+ </div>
+
+ <div class="middle">
+
+<!-- note: don't tab indent <article> as it has <pre> code which will have its layout adversly affected -->
+<article class="markdown-body entry-content"><h1 id="ghostapi">GhostAPI</h1>
+<div class="banner">
+ <div class="c-sharp-text"></div>
+ <div class="vendor-logo c-sharp-logo"></div>
+</div>
+
+
+<h2 id="about">About</h2>
+<p><code>GhostAPI</code> is the <code>C#</code> bridge into the Ghostscript <code>C</code> library.</p>
+<p><code>GhostAPI</code> contains some essential <a href="#structs-and-enums">structs &amp; enums</a> as well as a static class for some <a href="#constants">constants</a>, finally it contains the main <a href="#gsapi">GSAPI</a> class which holds the key methods which interface with the <code>C</code> library.</p>
+<h2 id="structs-and-enums">Structs and Enums</h2>
+<h3 id="gsapi_revision_t">gsapi_revision_t</h3>
+<p>This <code>struct</code> is used to contain information pertinent to the version of Ghostscript.</p>
+<div class="tag structDefinition csharp"></div>
+
+<pre><code class="language-c">public struct gsapi_revision_t
+{
+ public IntPtr product;
+ public IntPtr copyright;
+ public int revision;
+ public int revisiondate;
+}</code></pre>
+<h3 id="gs_set_param_type">gs_set_param_type</h3>
+<div class="tag enumDefinition csharp"></div>
+
+<pre><code class="language-c">public enum gs_set_param_type
+{
+ gs_spt_invalid = -1,
+ gs_spt_null = 0, /* void * is NULL */
+ gs_spt_bool = 1, /* void * is NULL (false) or non-NULL (true) */
+ gs_spt_int = 2, /* void * is a pointer to an int */
+ gs_spt_float = 3, /* void * is a float * */
+ gs_spt_name = 4, /* void * is a char * */
+ gs_spt_string = 5, /* void * is a char * */
+ gs_spt_long = 6, /* void * is a long * */
+ gs_spt_i64 = 7, /* void * is an int64_t * */
+ gs_spt_size_t = 8, /* void * is a size_t * */
+ gs_spt_parsed = 9, /* void * is a pointer to a char * to be parsed */
+ gs_spt_more_to_come = 1 &lt;&lt; 31
+};</code></pre>
+<h3 id="gsencoding">gsEncoding</h3>
+<div class="tag enumDefinition csharp"></div>
+
+
+<pre><code class="language-c">public enum gsEncoding
+{
+ GS_ARG_ENCODING_LOCAL = 0,
+ GS_ARG_ENCODING_UTF8 = 1,
+ GS_ARG_ENCODING_UTF16LE = 2
+};</code></pre>
+<h2 id="constants">Constants</h2>
+<p>Constants are stored in the static class <code>gsConstants</code> for direct referencing.</p>
+<h3 id="gsconstants">gsConstants</h3>
+<div class="tag classDefinition csharp"></div>
+
+<pre><code class="language-c">static class gsConstants
+{
+ public const int E_QUIT = -101;
+ public const int GS_READ_BUFFER = 32768;
+ public const int DISPLAY_UNUSED_LAST = (1 &lt;&lt; 7);
+ public const int DISPLAY_COLORS_RGB = (1 &lt;&lt; 2);
+ public const int DISPLAY_DEPTH_8 = (1 &lt;&lt; 11);
+ public const int DISPLAY_LITTLEENDIAN = (1 &lt;&lt; 16);
+ public const int DISPLAY_BIGENDIAN = (0 &lt;&lt; 16);
+}</code></pre>
+<h2 id="gsapi">GSAPI</h2>
+<p>Methods contained within are explained below.</p>
+<p><code>gsapi_run_*</code> and <code>gsapi_exit</code> methods return an <code>int</code> code which can be interpreted as follows:</p>
+<table>
+<thead>
+<tr>
+<th>code</th>
+<th>status</th>
+</tr>
+</thead>
+<tbody><tr>
+<td><code>0</code></td>
+<td>no error</td>
+</tr>
+<tr>
+<td><code>gsConstants.E_QUIT</code></td>
+<td>"quit" has been executed. This is not an error. <a href="#gsapi_exit">gsapi_exit</a> must be called next</td>
+</tr>
+<tr>
+<td><code>&lt;0</code></td>
+<td>error</td>
+</tr>
+</tbody></table>
+<blockquote>
+<p><strong>NOTE</strong><br>
+For full detail on these return code please see:
+<a href="https://www.ghostscript.com/doc/current/API.htm#return_codes">https://www.ghostscript.com/doc/current/API.htm#return_codes</a></p>
+</blockquote>
+<blockquote>
+<p><strong>NOTE</strong><br>All <a href="#gsapi">GSAPI</a> methods aside from <a href="#gsapi_revision">gsapi_revision</a> and <a href="#gsapi_new_instance">gsapi_new_instance</a> should pass an instance of Ghostscript as their first parameter with <code>IntPtr instance</code></p>
+</blockquote>
+<h3 id="gsapi_revision">gsapi_revision</h3>
+<p>This method returns the revision numbers and strings of the Ghostscript interpreter library; you should call it before any other interpreter library functions to make sure that the correct version of the Ghostscript interpreter has been loaded.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_revision(ref gsapi_revision_t vers,
+ int size);</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>The method should write to a reference variable which conforms to the struct <a href="#gsapi_revision_t">gsapi_revision_t</a>.</p>
+</blockquote>
+<h3 id="gsapi_new_instance">gsapi_new_instance</h3>
+<p>Creates a new instance of Ghostscript. This instance is passed to most other <a href="#gsapi">GSAPI</a> methods. Unless Ghostscript has been compiled with the <code>GS_THREADSAFE</code> define, only one instance at a time is supported.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_new_instance(out IntPtr pinstance,
+ IntPtr caller_handle);</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>The method returns a pointer which represents your instance of Ghostscript.</p>
+</blockquote>
+<h3 id="gsapi_delete_instance">gsapi_delete_instance</h3>
+<p>Destroy an instance of Ghostscript. Before you call this, Ghostscript must have finished. If Ghostscript has been initialised, you must call <a href="#gsapi_exit">gsapi_exit</a> beforehand.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern void gsapi_delete_instance(IntPtr instance);</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">GSAPI.gsapi_delete_instance(gsInstance);
+gsInstance = IntPtr.Zero;</code></pre>
+<h3 id="gsapi_set_stdio_with_handle">gsapi_set_stdio_with_handle</h3>
+<p>Set the callback functions for <code>stdio</code>, together with the handle to use in the callback functions. The <code>stdin</code> callback function should return the number of characters read, 0 for EOF, or -1 for error. The <code>stdout</code> and <code>stderr</code> callback functions should return the number of characters written.</p>
+<blockquote>
+<p><strong>NOTE</strong><br>These callbacks do not affect output device I/O when using "%stdout" as the output file. In that case, device output will still be directed to the process "stdout" file descriptor, not to the <code>stdio</code> callback.</p>
+</blockquote>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_set_stdio_with_handle(IntPtr instance,
+ gs_stdio_handler stdin,
+ gs_stdio_handler stdout,
+ gs_stdio_handler stderr,
+ IntPtr caller_handle);</code></pre>
+<h3 id="gsapi_set_stdio">gsapi_set_stdio</h3>
+<p>Set the callback functions for <code>stdio</code>. The handle used in the callbacks will be taken from the value passed to <a href="#gsapi_new_instance">gsapi_new_instance</a>. Otherwise the behaviour of this function matches <a href="#gsapi_set_stdio_with_handle">gsapi_set_stdio_with_handle</a>.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_set_stdio_with_handle(IntPtr instance,
+ gs_stdio_handler stdin,
+ gs_stdio_handler stdout,
+ gs_stdio_handler stderr);</code></pre>
+<h3 id="gsapi_set_poll_with_handle">gsapi_set_poll_with_handle</h3>
+<p>Set the callback function for polling, together with the handle to pass to the callback function. This function will only be called if the Ghostscript interpreter was compiled with <code>CHECK_INTERRUPTS</code> as described in <code>gpcheck.h</code>.</p>
+<p>The polling function should return zero if all is well, and return negative if it wants ghostscript to abort. This is often used for checking for a user cancel. This can also be used for handling window events or cooperative multitasking.</p>
+<p>The polling function is called very frequently during interpretation and rendering so it must be fast. If the function is slow, then using a counter to <code>return 0</code> immediately some number of times can be used to reduce the performance impact.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_set_poll_with_handle(IntPtr instance,
+ gsPollHandler pollfn,
+ IntPtr caller_handle);</code></pre>
+<h3 id="gsapi_set_poll">gsapi_set_poll</h3>
+<p>Set the callback function for polling. The handle passed to the callback function will be taken from the handle passed to <a href="#gsapi_new_instance">gsapi_new_instance</a>. Otherwise the behaviour of this function matches <a href="#gsapi_set_poll_with_handle">gsapi_set_poll_with_handle</a>.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_set_poll(IntPtr instance,
+ gsPollHandler pollfn);</code></pre>
+<h3 id="gsapi_set_display_callback">gsapi_set_display_callback</h3>
+<p>This call is deprecated; please use <a href="#gsapi_register_callout">gsapi_register_callout</a> to register a <a href="#gscallout">callout handler</a> for the display device in preference.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_set_display_callback(IntPtr pinstance,
+ IntPtr caller_handle);</code></pre>
+<h3 id="gsapi_register_callout">gsapi_register_callout</h3>
+<p>This call registers a <a href="#gscallout">callout handler</a>.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_register_callout(IntPtr instance,
+ gsCallOut callout,
+ IntPtr callout_handle);</code></pre>
+<h3 id="gsapi_deregister_callout">gsapi_deregister_callout</h3>
+<p>This call deregisters a <a href="#gscallout">callout handler</a> previously registered with <a href="#gsapi_register_callout">gsapi_register_callout</a>. All three arguments must match exactly for the <a href="#gscallout">callout handler</a> to be deregistered.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_deregister_callout(IntPtr instance,
+ gsCallOut callout,
+ IntPtr callout_handle);</code></pre>
+<h3 id="gsapi_set_arg_encoding">gsapi_set_arg_encoding</h3>
+<p>Set the encoding used for the interpretation of all subsequent arguments supplied via the <code>GhostAPI</code> interface on this instance. By default we expect args to be in encoding <code>0</code> (the 'local' encoding for this OS). On Windows this means "the currently selected codepage". On Linux this typically means <code>utf8</code>. This means that omitting to call this function will leave Ghostscript running exactly as it always has. Please note that use of the 'local' encoding is now deprecated and should be avoided in new code. This must be called after <a href="#gsapi_new_instance">gsapi_new_instance</a> and before <a href="#gsapi_init_with_args">gsapi_init_with_args</a>.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_set_arg_encoding(IntPtr instance,
+ int encoding);</code></pre>
+<h3 id="gsapi_set_default_device_list">gsapi_set_default_device_list</h3>
+<p>Set the string containing the list of default device names, for example "display x11alpha x11 bbox". Allows the calling application to influence which device(s) Ghostscript will try, in order, in its selection of the default device. This must be called after <a href="#gsapi_new_instance">gsapi_new_instance</a> and before <a href="#gsapi_init_with_args">gsapi_init_with_args</a>.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_set_default_device_list(IntPtr instance,
+ IntPtr list,
+ ref int listlen);</code></pre>
+<h3 id="gsapi_get_default_device_list">gsapi_get_default_device_list</h3>
+<p>Returns a pointer to the current default device string. This must be called after <a href="#gsapi_new_instance">gsapi_new_instance</a> and before <a href="#gsapi_init_with_args">gsapi_init_with_args</a>.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_get_default_device_list(IntPtr instance,
+ ref IntPtr list,
+ ref int listlen);</code></pre>
+<h3 id="gsapi_init_with_args">gsapi_init_with_args</h3>
+<p>To initialise the interpreter, pass your <code>instance</code> of Ghostscript, your argument count, <code>argc</code>, and your argument variables, <code>argv</code>.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_init_with_args(IntPtr instance,
+ int argc,
+ IntPtr argv);</code></pre>
+<h3 id="gsapi_run_-">gsapi_run_*</h3>
+<p>If these functions return <code>&lt;= -100</code>, either quit or a fatal error has occured. You must call <a href="#gsapi_exit">gsapi_exit</a> next. The only exception is <a href="#gsapi_run_string_continue">gsapi_run_string_continue</a> which will return <code>gs_error_NeedInput</code> if all is well.</p>
+<p>There is a 64 KB length limit on any buffer submitted to a <code>gsapi_run_*</code> function for processing. If you have more than 65535 bytes of input then you must split it into smaller pieces and submit each in a separate <a href="#gsapi_run_string_continue">gsapi_run_string_continue</a> call.</p>
+<h3 id="gsapi_run_string_begin">gsapi_run_string_begin</h3>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_run_string_begin(IntPtr instance,
+ int usererr,
+ ref int exitcode);</code></pre>
+<h3 id="gsapi_run_string_continue">gsapi_run_string_continue</h3>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_run_string_continue(IntPtr instance,
+ IntPtr command,
+ int count,
+ int usererr,
+ ref int exitcode);</code></pre>
+<h3 id="gsapi_run_string_with_length">gsapi_run_string_with_length</h3>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_run_string_with_length(IntPtr instance,
+ IntPtr command,
+ uint length,
+ int usererr,
+ ref int exitcode);</code></pre>
+<h3 id="gsapi_run_string">gsapi_run_string</h3>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_run_string(IntPtr instance,
+ IntPtr command,
+ int usererr,
+ ref int exitcode);</code></pre>
+<h3 id="gsapi_run_string_end">gsapi_run_string_end</h3>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_run_string_end(IntPtr instance,
+ int usererr,
+ ref int exitcode);</code></pre>
+<h3 id="gsapi_run_file">gsapi_run_file</h3>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_run_file(IntPtr instance,
+ IntPtr filename,
+ int usererr,
+ ref int exitcode);</code></pre>
+<h3 id="gsapi_exit">gsapi_exit</h3>
+<p>Exit the interpreter. This must be called on shutdown if <a href="#gsapi_init_with_args">gsapi_init_with_args</a> has been called, and just before <a href="#gsapi_delete_instance">gsapi_delete_instance</a>.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_exit(IntPtr instance);</code></pre>
+<h3 id="gsapi_set_param">gsapi_set_param</h3>
+<p>Sets a parameter.</p>
+<p>Broadly, this is equivalent to setting a parameter using -d, -s or -p on the command line. This call cannot be made during a <a href="#gsapi_run_string">gsapi_run_string</a> operation.</p>
+<p>Parameters in this context are not the same as 'arguments' as processed by <a href="#gsapi_init_with_args">gsapi_init_with_args</a>, but often the same thing can be achieved. For example, with <a href="#gsapi_init_with_args">gsapi_init_with_args</a>, we can pass "-r200" to change the resolution. Broadly the same thing can be achieved by using <a href="#gsapi_set_param">gsapi_set_param</a> to set a parsed value of "&lt;&lt;/HWResolution [ 200.0 200.0 ]&gt;&gt;".</p>
+<p>Internally, when we set a parameter, we perform an <code>initgraphics</code> operation. This means that using <a href="#gsapi_set_param">gsapi_set_param</a> other than at the start of a page is likely to give unexpected results.</p>
+<p>Attempting to set a parameter that the device does not recognise will be silently ignored, and that parameter will not be found in subsequent <a href="#gsapi_get_param">gsapi_get_param</a> calls.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_set_param(IntPtr instance,
+ IntPtr param,
+ IntPtr value,
+ gs_set_param_type type);</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>The <code>type</code> argument, as a <a href="#gs_set_param_type">gs_set_param_type</a>, dictates the kind of object that the <code>value</code> argument points to.</p>
+</blockquote>
+<blockquote>
+<p><strong>NOTE</strong><br>For more on the C implementation of parameters see: <a href="https://www.ghostscript.com/doc/current/Use.htm#Parameters">Ghostscript parameters in C</a>.</p>
+</blockquote>
+<h3 id="gsapi_get_param">gsapi_get_param</h3>
+<p>Retrieve the current value of a parameter.</p>
+<p>If an error occurs, the return value is negative. Otherwise the return value is the number of bytes required for storage of the value. Call once with value <code>NULL</code> to get the number of bytes required, then call again with value pointing to at least the required number of bytes where the value will be copied out. Note that the caller is required to know the type of value in order to get it. For all types other than <a href="#gs_set_param_type">gs_spt_string</a>, <a href="#gs_set_param_type">gs_spt_name</a>, and <a href="#gs_set_param_type">gs_spt_parsed</a> knowing the type means you already know the size required.</p>
+<p>This call retrieves parameters/values that have made it to the device. Thus, any values set using <a href="#gs_set_param_type">gs_spt_more_to_come</a> without a following call omitting that flag will not be retrieved. Similarly, attempting to get a parameter before <a href="#gsapi_init_with_args">gsapi_init_with_args</a> has been called will not list any, even if <a href="#gsapi_set_param">gsapi_set_param</a> has been used.</p>
+<p>Attempting to read a parameter that is not set will return <code>gs_error_undefined</code> (-21). Note that calling <a href="#gsapi_set_param">gsapi_set_param</a> followed by <a href="#gsapi_get_param">gsapi_get_param</a> may not find the value, if the device did not recognise the key as being one of its configuration keys.</p>
+<p>For the C documentation please refer to <a href="https://www.ghostscript.com/doc/current/API.htm#get_param">Ghostscript get_param</a>.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_get_param(IntPtr instance,
+ IntPtr param,
+ IntPtr value,
+ gs_set_param_type type);</code></pre>
+<h3 id="gsapi_enumerate_params">gsapi_enumerate_params</h3>
+<p>Enumerate the current parameters. Call repeatedly to list out the current parameters.</p>
+<p>The first call should have <code>iter</code> = NULL. Subsequent calls should pass the same pointer in so the iterator can be updated. Negative return codes indicate error, 0 success, and 1 indicates that there are no more keys to read. On success, key will be updated to point to a null terminated string with the key name that is guaranteed to be valid until the next call to <a href="#gsapi_enumerate_params">gsapi_enumerate_params</a>. If <code>type</code> is non NULL then the pointer <code>type</code> will be updated to have the <code>type</code> of the parameter.</p>
+<blockquote>
+<p><strong>NOTE</strong><br>Only one enumeration can happen at a time. Starting a second enumeration will reset the first.</p>
+</blockquote>
+<p>The enumeration only returns parameters/values that have made it to the device. Thus, any values set using the <a href="#gs_set_param_type">gs_spt_more_to_come</a> without a following call omitting that flag will not be retrieved. Similarly, attempting to enumerate parameters before <a href="#gsapi_init_with_args">gsapi_init_with_args</a> has been called will not list any, even if <a href="#gsapi_set_param">gsapi_set_param</a> has been used.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_enumerate_params(IntPtr instance,
+ out IntPtr iter,
+ out IntPtr key,
+ IntPtr type);</code></pre>
+<h3 id="gsapi_add_control_path">gsapi_add_control_path</h3>
+<p>Add a (case sensitive) path to one of the lists of <a href="https://ghostscript.com/doc/current/Use.htm#Safer">permitted paths</a> for file access.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_add_control_path(IntPtr instance,
+ int type,
+ IntPtr path);</code></pre>
+<h3 id="gsapi_remove_control_path">gsapi_remove_control_path</h3>
+<p>Remove a (case sensitive) path from one of the lists of <a href="https://ghostscript.com/doc/current/Use.htm#Safer">permitted paths</a> for file access.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern int gsapi_remove_control_path(IntPtr instance,
+ int type,
+ IntPtr path);</code></pre>
+<h3 id="gsapi_purge_control_paths">gsapi_purge_control_paths</h3>
+<p>Clear all the paths from one of the lists of <a href="https://ghostscript.com/doc/current/Use.htm#Safer">permitted paths</a> for file access.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern void gsapi_purge_control_paths(IntPtr instance,
+ int type);</code></pre>
+<h3 id="gsapi_activate_path_control">gsapi_activate_path_control</h3>
+<p>Enable/Disable path control (i.e. whether paths are checked against <a href="https://ghostscript.com/doc/current/Use.htm#Safer">permitted paths</a> before access is granted).</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public static extern void gsapi_activate_path_control(IntPtr instance,
+ int enable);</code></pre>
+<h3 id="gsapi_is_path_control_active">gsapi_is_path_control_active</h3>
+<p>Query whether path control is activated or not.</p>
+<div class="tag methodDefinition csharp"></div>
+
+
+<pre><code class="language-c">public static extern int gsapi_is_path_control_active(IntPtr instance);</code></pre>
+<h2 id="callback-and-callout-prototypes">Callback and Callout prototypes</h2>
+<p><a href="#gsapi">GSAPI</a> also defines some prototype pointers which are defined as follows.</p>
+<h3 id="gs_stdio_handler">gs_stdio_handler</h3>
+<div class="tag callbackDefinition csharp"></div>
+
+<pre><code class="language-c">/* Callback proto for stdio */
+public delegate int gs_stdio_handler(IntPtr caller_handle,
+ IntPtr buffer,
+ int len);</code></pre>
+<h3 id="gspollhandler">gsPollHandler</h3>
+<div class="tag callbackDefinition csharp"></div>
+
+<pre><code class="language-c">/* Callback proto for poll function */
+public delegate int gsPollHandler(IntPtr caller_handle);</code></pre>
+<h3 id="gscallout">gsCallOut</h3>
+<div class="tag callbackDefinition csharp"></div>
+
+<pre><code class="language-c">/* Callout proto */
+public delegate int gsCallOut(IntPtr callout_handle,
+ IntPtr device_name,
+ int id,
+ int size,
+ IntPtr data);
+</code></pre>
+</article>
+
+ </div><!--/middle -->
+
+
+
+ <div class="right">
+
+ <div class="link"><a href="#about">About</a></div>
+ <div class="link"><a href="#structs-and-enums">Structs and Enums</a></div>
+ <div class="sub-link"><a href="#gsapi_revision_t">gsapi_revision_t</a></div>
+ <div class="sub-link"><a href="#gs_set_param_type">gs_set_param_type</a></div>
+ <div class="sub-link"><a href="#gsencoding">gsEncoding</a></div>
+ <div class="link"><a href="#constants">Constants</a></div>
+ <div class="sub-link"><a href="#gsconstants">gsConstants</a></div>
+ <div class="link"><a href="#gsapi">GSAPI</a></div>
+ <div class="sub-link"><a href="#gsapi_revision">gsapi_revision</a></div>
+ <div class="sub-link"><a href="#gsapi_new_instance">gsapi_new_instance</a></div>
+ <div class="sub-link"><a href="#gsapi_delete_instance">gsapi_delete_instance</a></div>
+ <div class="sub-link"><a href="#gsapi_set_stdio_with_handle">gsapi_set_stdio_with_handle</a></div>
+ <div class="sub-link"><a href="#gsapi_set_stdio">gsapi_set_stdio</a></div>
+ <div class="sub-link"><a href="#gsapi_set_poll_with_handle">gsapi_set_poll_with_handle</a></div>
+ <div class="sub-link"><a href="#gsapi_set_poll">gsapi_set_poll</a></div>
+ <div class="sub-link"><a href="#gsapi_set_display_callback">gsapi_set_display_callback</a></div>
+ <div class="sub-link"><a href="#gsapi_register_callout"> gsapi_register_callout</a></div>
+ <div class="sub-link"><a href="#gsapi_deregister_callout">gsapi_deregister_callout</a></div>
+ <div class="sub-link"><a href="#gsapi_set_arg_encoding">gsapi_set_arg_encoding</a></div>
+ <div class="sub-link"><a href="#gsapi_set_default_device_list">gsapi_set_default_device_list</a></div>
+ <div class="sub-link"><a href="#gsapi_get_default_device_list">gsapi_get_default_device_list</a></div>
+ <div class="sub-link"><a href="#gsapi_init_with_args">gsapi_init_with_args</a></div>
+ <div class="sub-link"><a href="#gsapi_run_-">gsapi_run_*</a></div>
+ <div class="sub-link"><a href="#gsapi_run_string_begin">gsapi_run_string_begin</a></div>
+ <div class="sub-link"><a href="#gsapi_run_string_continue">gsapi_run_string_continue</a></div>
+ <div class="sub-link"><a href="#gsapi_run_string_with_length">gsapi_run_string_with_length</a></div>
+ <div class="sub-link"><a href="#gsapi_run_string">gsapi_run_string</a></div>
+ <div class="sub-link"><a href="#gsapi_run_string_end">gsapi_run_string_end</a></div>
+ <div class="sub-link"><a href="#gsapi_run_file">gsapi_run_file</a></div>
+ <div class="sub-link"><a href="#gsapi_exit">gsapi_exit</a></div>
+ <div class="sub-link"><a href="#gsapi_set_param">gsapi_set_param</a></div>
+ <div class="sub-link"><a href="#gsapi_get_param">gsapi_get_param</a></div>
+ <div class="sub-link"><a href="#gsapi_enumerate_params">gsapi_enumerate_params</a></div>
+ <div class="sub-link"><a href="#gsapi_add_control_path">gsapi_add_control_path</a></div>
+ <div class="sub-link"><a href="#gsapi_remove_control_path">gsapi_remove_control_path</a></div>
+ <div class="sub-link"><a href="#gsapi_purge_control_paths">gsapi_purge_control_paths</a></div>
+ <div class="sub-link"><a href="#gsapi_activate_path_control">gsapi_activate_path_control</a></div>
+ <div class="sub-link"><a href="#gsapi_is_path_control_active">gsapi_is_path_control_active</a></div>
+ <div class="link"><a href="#callback-and-callout-prototypes">Callback and Callout prototypes</a></div>
+ <div class="sub-link"><a href="#gs_stdio_handler">gs_stdio_handler</a></div>
+ <div class="sub-link"><a href="#gspollhandler">gsPollHandler</a></div>
+ <div class="sub-link"><a href="#gscallout">gsCallOut</a></div>
+ </div>
+
+ </div>
+
+ <footer></footer>
+
+ </body>
+
+</html>
diff --git a/doc/language-bindings/c-sharp-ghost-mono.html b/doc/language-bindings/c-sharp-ghost-mono.html
new file mode 100644
index 00000000..33c2ef83
--- /dev/null
+++ b/doc/language-bindings/c-sharp-ghost-mono.html
@@ -0,0 +1,582 @@
+<html lang="en">
+ <head>
+ <title>Ghostscript language bindings</title>
+ <meta http-equiv="content-type" content="text/html; charset=utf-8">
+ <meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width">
+ <link href="https://fonts.googleapis.com/css?family=Source+Sans+Pro:200,200i,300,300i,400,400i,600,600i,700,700i,900,900i" rel="stylesheet">
+ <link rel="shortcut icon" type="image/png" href="../images/favicon.png">
+ <link href="css/default.css" rel="stylesheet" type="text/css" />
+ <script type="text/javascript" src="js/default.js"></script>
+ </head>
+
+ <body>
+
+ <header><h1></h1><div class="menu-icon" onclick="javascript:showMenu();"></div></header>
+
+ <div id="burger-menu">
+ <div class="navigation">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link selected"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+ </div>
+ <div class="main">
+
+ <div class="left">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link selected"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+
+ <div class="middle">
+
+<!-- note: don't tab indent <article> as it has <pre> code which will have its layout adversly affected -->
+<article class="markdown-body entry-content"><h1 id="ghostmono">GhostMono</h1>
+<div class="banner">
+ <div class="c-sharp-text"></div>
+ <div class="vendor-logo c-sharp-logo"></div>
+</div>
+
+
+<h2 id="about">About</h2>
+<p><code>GhostMono</code> is the <code>C#</code> interface into the <code>GhostAPI</code> library developed for Linux systems.</p>
+<h2 id="enums">Enums</h2>
+<h3 id="tasks">Tasks</h3>
+<p>The Ghostscript task type <code>enum</code> is used to inform <code>GhostAPI</code> of the type of operation which is being requested.</p>
+<table>
+<thead>
+<tr>
+<th>Task</th>
+<th>Description</th>
+</tr>
+</thead>
+<tbody><tr>
+<td>PS_DISTILL</td>
+<td>Task associated with converting a PostScript stream to a PDF document</td>
+</tr>
+<tr>
+<td>CREATE_XPS</td>
+<td>Task associated with outputting a copy of a document to XPS</td>
+</tr>
+<tr>
+<td>SAVE_RESULT</td>
+<td>Task associated with saving documents</td>
+</tr>
+<tr>
+<td>GET_PAGE_COUNT</td>
+<td>Task associated with getting the page count of a document</td>
+</tr>
+<tr>
+<td>GENERIC</td>
+<td>Generic task identifier</td>
+</tr>
+<tr>
+<td>DISPLAY_DEV_THUMBS</td>
+<td>Display Device task associated with rendering thumbnails</td>
+</tr>
+<tr>
+<td>DISPLAY_DEV_NON_PDF</td>
+<td>Display Device task associated with non-PDF or non-XPS rendering <sup><a href="#1-ghostscript-page-description-languages">1</a></sup></td>
+</tr>
+<tr>
+<td>DISPLAY_DEV_PDF</td>
+<td>Display Device task associated with PDF &amp; XPS rendering <sup><a href="#1-ghostscript-page-description-languages">1</a></sup></td>
+</tr>
+<tr>
+<td>DISPLAY_DEV_RUN_FILE</td>
+<td>Display Device task associated with running files</td>
+</tr>
+</tbody></table>
+<p>Task types are defined as <code>GS_Task_t</code>.</p>
+<div class="tag enumDefinition csharp"></div>
+
+<pre><code class="language-c">public enum GS_Task_t
+{
+ PS_DISTILL,
+ CREATE_XPS,
+ SAVE_RESULT,
+ GET_PAGE_COUNT,
+ GENERIC,
+ DISPLAY_DEV_THUMBS,
+ DISPLAY_DEV_NON_PDF,
+ DISPLAY_DEV_PDF,
+ DISPLAY_DEV_RUN_FILE
+}</code></pre>
+<h3 id="results">Results</h3>
+<p>Result types are defined as <code>GS_Result_t</code>.</p>
+<div class="tag enumDefinition csharp"></div>
+
+<pre><code class="language-c">public enum GS_Result_t
+{
+ gsOK,
+ gsFAILED,
+ gsCANCELLED
+}</code></pre>
+<h3 id="status">Status</h3>
+<p>Status is defined as <code>gsStatus</code>.</p>
+<div class="tag enumDefinition csharp"></div>
+
+<pre><code class="language-c">public enum gsStatus
+{
+ GS_READY,
+ GS_BUSY,
+ GS_ERROR
+};</code></pre>
+<h2 id="the-parameter-struct">The Parameter Struct</h2>
+<p>The parameter struct <code>gsParamState_t</code> allows for bundles of information to be processed by Ghostscript to complete overall requests.</p>
+<div class="tag structDefinition csharp"></div>
+
+<pre><code class="language-c">public struct gsParamState_t
+{
+ public String outputfile;
+ public String inputfile;
+ public GS_Task_t task;
+ public GS_Result_t result;
+ public int num_pages;
+ public List&lt;int&gt; pages;
+ public int firstpage;
+ public int lastpage;
+ public int currpage;
+ public List&lt;String&gt; args;
+ public int return_code;
+ public double zoom;
+};</code></pre>
+<h3 id="parameters-explained">Parameters explained</h3>
+<p>Setting up your parameters (with any dedicated bespoke method(s) which your application requires) is needed when communicating directly with <code>GhostAPI</code>.</p>
+<p>When requesting Ghostscript to process an operation an application developer should send a parameter payload which defines the details for the operation.</p>
+<p>For example in <code>GhostMono</code> we can see the public method as follows:</p>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">public gsStatus DistillPS(String fileName, int resolution)
+{
+ gsParamState_t gsparams = new gsParamState_t();
+ gsparams.args = new List&lt;string&gt;();
+
+ gsparams.inputfile = fileName;
+ gsparams.args.Add("gs");
+ gsparams.args.Add("-dNOPAUSE");
+ gsparams.args.Add("-dBATCH");
+ gsparams.args.Add("-I%rom%Resource/Init/");
+ gsparams.args.Add("-dSAFER");
+ gsparams.args.Add("-sDEVICE=pdfwrite");
+ gsparams.outputfile = Path.GetTempFileName();
+ gsparams.args.Add("-o" + gsparams.outputfile);
+ gsparams.task = GS_Task_t.PS_DISTILL;
+
+ return RunGhostscriptAsync(gsparams);
+}</code></pre>
+<p>Here we can see a parameter payload being setup before being passed on to the asynchronous method <code>RunGhostscriptAsync</code> which sets up a worker thread to run according to the task type in the payload.</p>
+<p><code>GhostMono</code> handles many common operations on an application developer's behalf, however if you require to write your own methods to interface with <code>GhostAPI</code> then referring to the public methods in <code>GhostMono</code> is a good starting point.</p>
+<p>For full documentation on parameters refer to <a href="https://www.ghostscript.com/doc/current/Use.htm#Parameters">Ghostscript parameters</a>.</p>
+<h2 id="the-event-class">The Event class</h2>
+<p><code>GhostMono</code> contains a public class <code>gsThreadCallBack</code>. This class is used to set and get callback information as they occur. <code>GhostMono</code> will create these payloads and deliver them back to the application layer's <code>ProgressCallBack</code> method <a href="#delegates">asynchronously</a>.</p>
+<div class="tag classDefinition csharp"></div>
+
+<pre><code class="language-c">public class gsThreadCallBack
+{
+ private bool m_completed;
+ private int m_progress;
+ private gsParamState_t m_param;
+ public bool Completed
+ {
+ get { return m_completed; }
+ }
+ public gsParamState_t Params
+ {
+ get { return m_param; }
+ }
+ public int Progress
+ {
+ get { return m_progress; }
+ }
+ public gsThreadCallBack(bool completed, int progress, gsParamState_t param)
+ {
+ m_completed = completed;
+ m_progress = progress;
+ m_param = param;
+ }
+}</code></pre>
+<h2 id="gsmono">GSMONO</h2>
+<p>This class should be instantiated as a member variable in your application with callback definitions setup as required.</p>
+<p>Handlers for asynchronous operations can injected by providing your own bespoke callback methods to your instance's <code>ProgressCallBack</code> function.</p>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">/* Set up ghostscript with callbacks for system updates */
+m_ghostscript = new GSMONO();
+m_ghostscript.ProgressCallBack += new GSMONO.Progress(gsProgress);
+m_ghostscript.StdIOCallBack += new GSMONO.StdIO(gsIO);
+m_ghostscript.DLLProblemCallBack += new GSMONO.DLLProblem(gsDLL);
+m_ghostscript.PageRenderedCallBack += new GSMONO.PageRendered(gsPageRendered);
+m_ghostscript.DisplayDeviceOpen();
+
+/* example callback stubs for asynchronous operations */
+private void gsProgress(gsThreadCallBack asyncInformation)
+{
+ Console.WriteLine($"gsProgress().progress:{asyncInformation.Progress}");
+
+ if (asyncInformation.Completed) // task complete
+ {
+ // what was the task?
+ switch (asyncInformation.Params.task)
+ {
+ case GS_Task_t.CREATE_XPS:
+ Console.WriteLine($"CREATE_XPS.outputfile:");
+ Console.WriteLine($"{asyncInformation.Params.result.outputfile}");
+ break;
+
+ case GS_Task_t.PS_DISTILL:
+ Console.WriteLine($"PS_DISTILL.outputfile:");
+ Console.WriteLine($"{asyncInformation.Params.result.outputfile}");
+ break;
+
+ case GS_Task_t.SAVE_RESULT:
+
+ break;
+
+ case GS_Task_t.DISPLAY_DEV_THUMBS:
+
+ break;
+
+ case GS_Task_t.DISPLAY_DEV_RUN_FILE:
+
+ break;
+
+ case GS_Task_t.DISPLAY_DEV_PDF:
+
+ break;
+
+ case GS_Task_t.DISPLAY_DEV_NON_PDF:
+
+ break;
+
+ default:
+
+ break;
+ }
+
+ // task failed
+ if (asyncInformation.Params.result == GS_Result_t.gsFAILED)
+ {
+ switch (asyncInformation.Params.task)
+ {
+ case GS_Task_t.CREATE_XPS:
+
+ break;
+
+ case GS_Task_t.PS_DISTILL:
+
+ break;
+
+ case GS_Task_t.SAVE_RESULT:
+
+ break;
+
+ default:
+
+ break;
+ }
+ return;
+ }
+
+ // task cancelled
+ if (asyncInformation.Params.result == GS_Result_t.gsCANCELLED)
+ {
+
+ }
+ }
+ else // task is still running
+ {
+ switch (asyncInformation.Params.task)
+ {
+ case GS_Task_t.CREATE_XPS:
+
+ break;
+
+ case GS_Task_t.PS_DISTILL:
+
+ break;
+
+ case GS_Task_t.SAVE_RESULT:
+
+ break;
+ }
+ }
+}
+
+private void gsIO(String message, int len)
+{
+ Console.WriteLine($"gsIO().message:{message}, length:{len}");
+}
+
+private void gsDLL(String message)
+{
+ Console.WriteLine($"gsDLL().message:{message}");
+}
+
+private void gsPageRendered(int width,
+ int height,
+ int raster,
+ IntPtr data,
+ gsParamState_t state)
+{
+
+};</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>Once a Ghostscript operation is in progress any defined callback functions will be called as the operation runs up unto completion. These callback methods are essential for your application to interpret activity events and react accordingly.</p>
+</blockquote>
+<p>An explanation of callbacks and the available public methods within <code>GSMONO</code> are explained below.</p>
+<h3 id="delegates">Delegates</h3>
+<p>To handle asynchronous events <code>GhostMONO</code> has four delegates which define callback methods that an application can assign to.</p>
+<table>
+<thead>
+<tr>
+<th>Callback</th>
+<th>Description</th>
+</tr>
+</thead>
+<tbody><tr>
+<td><code>DLLProblemCallBack</code></td>
+<td>Occurs if there is some issue with the Ghostscript Shared Object (<code>libgpdl.so</code>)</td>
+</tr>
+<tr>
+<td><code>StdIOCallBack</code></td>
+<td>Occurs if Ghostscript outputs something to <code>stderr</code> or <code>stdout</code></td>
+</tr>
+<tr>
+<td><code>ProgressCallBack</code></td>
+<td>Occurs as Ghostscript makes its way through a file</td>
+</tr>
+<tr>
+<td><code>PageRenderedCallBack</code></td>
+<td>Occurs when a page has been rendered and the data from the display device is ready</td>
+</tr>
+</tbody></table>
+<h4 id="dllproblemcallback">DLLProblemCallBack</h4>
+<div class="tag callbackDefinition csharp"></div>
+
+<pre><code class="language-c">internal delegate void DLLProblem(String mess);
+internal event DLLProblem DLLProblemCallBack;</code></pre>
+<h4 id="stdiocallback">StdIOCallBack</h4>
+<div class="tag callbackDefinition csharp"></div>
+
+<pre><code class="language-c">internal delegate void StdIO(String mess,
+ int len);
+internal event StdIO StdIOCallBack;</code></pre>
+<h4 id="progresscallback">ProgressCallBack</h4>
+<div class="tag callbackDefinition csharp"></div>
+
+<pre><code class="language-c">internal delegate void Progress(gsEventArgs info);
+internal event Progress ProgressCallBack;</code></pre>
+<h4 id="pagerenderedcallback">PageRenderedCallBack</h4>
+<div class="tag callbackDefinition csharp"></div>
+
+<pre><code class="language-c">internal delegate void PageRendered(int width,
+ int height,
+ int raster,
+ IntPtr data,
+ gsParamState_t state);
+internal event PageRendered PageRenderedCallBack;</code></pre>
+<h3 id="getversion">GetVersion</h3>
+<p>Use this method to get Ghostscript version info as a handy <code>String</code>.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public String GetVersion()</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">String gs_vers = m_ghostscript.GetVersion();</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>An exception will be thrown if there is any issue with the Ghostscript DLL.</p>
+</blockquote>
+<h3 id="displaydeviceopen">DisplayDeviceOpen</h3>
+<p>Sets up the <a href="https://ghostscript.com/doc/current/Devices.htm#Display_devices">display device</a> ahead of time.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public gsParamState_t DisplayDeviceOpen()</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">m_ghostscript.DisplayDeviceOpen();</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>Calling this method <a href="c-sharp-ghost-api.html#gsapi_new_instance">instantiates ghostscript</a> and configures the encoding and the callbacks for the display device.</p>
+</blockquote>
+<h3 id="displaydeviceclose">DisplayDeviceClose</h3>
+<p>Closes the <a href="https://ghostscript.com/doc/current/Devices.htm#Display_devices">display device</a> and deletes the instance.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public gsParamState_t DisplayDeviceClose()</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">m_ghostscript.DisplayDeviceClose();</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>Calling this method <a href="c-sharp-ghost-api.html#gsapi_delete_instance">deletes ghostscript</a>.</p>
+</blockquote>
+<h3 id="getpagecount">GetPageCount</h3>
+<p>Use this method to get the number of pages in a supplied document.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public int GetPageCount(String fileName)</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">int page_number = m_ghostscript.GetPageCount("my_document.pdf");</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>If Ghostscript is unable to determine the page count then this method will return <code>-1</code>.</p>
+</blockquote>
+<h3 id="distillps">DistillPS</h3>
+<p>Launches a thread rendering all the pages of a supplied PostScript file to a PDF.</p>
+<div class="tag methodDefinition csharp async"></div>
+
+<pre><code class="language-c">public gsStatus DistillPS(String fileName, int resolution)</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">m_ghostscript.DistillPS("my_postscript_document.ps", 300);</code></pre>
+<span class="smallText alignRight">
+
+<p><em><a href="#delegates">asynchronous</a></em></p>
+</span>
+
+
+
+<h3 id="displaydevicerenderall">DisplayDeviceRenderAll</h3>
+<p>Launches a thread rendering all the document pages with the <a href="https://ghostscript.com/doc/current/Devices.htm#Display_devices">display device</a>. For use with languages that can be indexed via pages which include PDF and XPS. <a href="#1-ghostscript-page-description-languages">1</a></p>
+<div class="tag methodDefinition csharp async"></div>
+
+<pre><code class="language-c">public gsStatus DisplayDeviceRenderAll(String fileName, double zoom, bool aa, GS_Task_t task)</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">m_ghostscript.DisplayDeviceRenderAll("my_document.pdf",
+ 0.1,
+ false,
+ GS_Task_t.DISPLAY_DEV_THUMBS_NON_PDF);</code></pre>
+<span class="smallText alignRight">
+
+<p><em><a href="#delegates">asynchronous</a></em></p>
+</span>
+
+
+<h3 id="displaydevicerenderthumbs">DisplayDeviceRenderThumbs</h3>
+<p>Launches a thread rendering all the pages with the <a href="https://ghostscript.com/doc/current/Devices.htm#Display_devices">display device</a> to collect thumbnail images.</p>
+<p>Recommended zoom level for thumbnails is between 0.05 and 0.2, additionally anti-aliasing is probably not required.</p>
+<div class="tag methodDefinition csharp async"></div>
+
+<pre><code class="language-c">public gsStatus DisplayDeviceRenderThumbs(String fileName,
+ double zoom,
+ bool aa)</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">m_ghostscript.DisplayDeviceRenderThumbs("my_document.pdf",
+ 0.1,
+ false);</code></pre>
+<span class="smallText alignRight">
+
+<p><em><a href="#delegates">asynchronous</a></em></p>
+</span>
+
+
+<h3 id="displaydevicerenderpages">DisplayDeviceRenderPages</h3>
+<p>Launches a thread rendering a set of pages with the <a href="https://ghostscript.com/doc/current/Devices.htm#Display_devices">display device</a>. For use with languages that can be indexed via pages which include PDF and XPS. <sup><a href="#1-ghostscript-page-description-languages">1</a></sup></p>
+<div class="tag methodDefinition csharp async"></div>
+
+<pre><code class="language-c">public gsStatus DisplayDeviceRenderPages(String fileName,
+ int first_page,
+ int last_page,
+ double zoom)</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">m_ghostscript.DisplayDeviceRenderPages("my_document.pdf",
+ 0,
+ 9,
+ 1.0);</code></pre>
+<span class="smallText alignRight">
+
+<p><em><a href="#delegates">asynchronous</a></em></p>
+</span>
+
+
+<h3 id="getstatus">GetStatus</h3>
+<p>Returns the current <a href="#status">status</a> of <code>Ghostscript</code>.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public gsStatus GetStatus()</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">gsStatus status = m_ghostscript.GetStatus();</code></pre>
+<h3 id="ghostscriptexception">GhostscriptException</h3>
+<p>An application developer can log any exceptions in this public class as required by editing the constructor.</p>
+<div class="tag classDefinition csharp"></div>
+
+<pre><code class="language-c">public class GhostscriptException : Exception
+{
+ public GhostscriptException(string message) : base(message)
+ {
+ // Report exceptions as required
+ }
+}</code></pre>
+<h2 id="notes">Notes</h2>
+<h4 id="1-ghostscript-page-description-languages">1: Ghostscript &amp; Page Description Languages</h4>
+<p>Ghostscript handles the following <a href="https://en.wikipedia.org/wiki/Page_description_language">PDLs</a>: <code>PCL</code> <code>PDF</code> <code>PS</code> <code>XPS</code>.</p>
+<p><code>PCL</code> and <code>PS</code> do not allow random access, meaning that, to print page 2 in a 100 page document, Ghostscript has to read the entire document stream of 100 pages.</p>
+<p>On the other hand, <code>PDF</code> and <code>XPS</code> allow for going directly to page 2 and then only dealing with that content. The tasks <code>DISPLAY_DEV_NON_PDF</code> and <code>DISPLAY_DEV_PDF</code> keep track of what sort of input Ghostscript is dealing with and enables the application to direct progress or completion callbacks accordingly.</p>
+</article>
+
+ </div><!-- / middle -->
+
+ <div class="right">
+
+ <div class="link"><a href="#about">About</a></div>
+ <div class="link"><a href="#enums">Enums</a></div>
+ <div class="sub-link"><a href="#tasks">Tasks</a></div>
+ <div class="sub-link"><a href="#results">Results</a></div>
+ <div class="sub-link"><a href="#status">Status</a></div>
+ <div class="link"><a href="#the-parameter-struct">The Parameter Struct</a></div>
+ <div class="sub-link"><a href="#parameters-explained">Parameters explained</a></div>
+ <div class="link"><a href="#the-event-class">The Event class</a></div>
+ <div class="link"><a href="#gsmono">GSMONO</a></div>
+ <div class="sub-link"><a href="#delegates">Delegates</a></div>
+ <div class="sub-link"><a href="#getversion">GetVersion</a></div>
+ <div class="sub-link"><a href="#displaydeviceopen">DisplayDeviceOpen</a></div>
+ <div class="sub-link"><a href="#displaydeviceclose">DisplayDeviceClose</a></div>
+ <div class="sub-link"><a href="#getpagecount">GetPageCount</a></div>
+ <div class="sub-link"><a href="#distillps">DistillPS</a></div>
+ <div class="sub-link"><a href="#displaydevicerenderall">DisplayDeviceRenderAll</a></div>
+ <div class="sub-link"><a href="#displaydevicerenderthumbs">DisplayDeviceRenderThumbs</a></div>
+ <div class="sub-link"><a href="#displaydevicerenderpages">DisplayDeviceRenderPages</a></div>
+ <div class="sub-link"><a href="#getstatus">GetStatus</a></div>
+ <div class="sub-link"><a href="#ghostscriptexception">GhostscriptException</a></div>
+ <div class="link"><a href="#notes">Notes</a></div>
+
+ </div>
+
+ </div>
+
+ <footer></footer>
+
+ </body>
+
+</html>
diff --git a/doc/language-bindings/c-sharp-ghost-net.html b/doc/language-bindings/c-sharp-ghost-net.html
new file mode 100644
index 00000000..1308abf6
--- /dev/null
+++ b/doc/language-bindings/c-sharp-ghost-net.html
@@ -0,0 +1,621 @@
+<html lang="en">
+ <head>
+ <title>Ghostscript language bindings</title>
+ <meta http-equiv="content-type" content="text/html; charset=utf-8">
+ <meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width">
+ <link href="https://fonts.googleapis.com/css?family=Source+Sans+Pro:200,200i,300,300i,400,400i,600,600i,700,700i,900,900i" rel="stylesheet">
+ <link rel="shortcut icon" type="image/png" href="../images/favicon.png">
+ <link href="css/default.css" rel="stylesheet" type="text/css" />
+ <script type="text/javascript" src="js/default.js"></script>
+ </head>
+
+ <body>
+
+ <header><h1></h1><div class="menu-icon" onclick="javascript:showMenu();"></div></header>
+
+ <div id="burger-menu">
+ <div class="navigation">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link selected"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+ </div>
+ <div class="main">
+
+ <div class="left">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link selected"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+
+ <div class="middle">
+
+<!-- note: don't tab indent <article> as it has <pre> code which will have its layout adversly affected -->
+<article class="markdown-body entry-content"><h1 id="ghostnet">GhostNET</h1>
+<div class="banner">
+ <div class="c-sharp-text"></div>
+ <div class="vendor-logo c-sharp-logo"></div>
+</div>
+
+
+<h2 id="about">About</h2>
+<p><code>GhostNET</code> is the <code>C#</code> interface into the <code>GhostAPI</code> library developed for Windows systems.</p>
+<h2 id="enums">Enums</h2>
+<h3 id="tasks">Tasks</h3>
+<p>The Ghostscript task type <code>enum</code> is used to inform <code>GhostAPI</code> of the type of operation which is being requested.</p>
+<table>
+<thead>
+<tr>
+<th>Task</th>
+<th>Description</th>
+</tr>
+</thead>
+<tbody><tr>
+<td>PS_DISTILL</td>
+<td>Task associated with converting a PostScript stream to a PDF document</td>
+</tr>
+<tr>
+<td>CREATE_XPS</td>
+<td>Task associated with outputting a copy of a document to XPS</td>
+</tr>
+<tr>
+<td>SAVE_RESULT</td>
+<td>Task associated with saving documents</td>
+</tr>
+<tr>
+<td>GET_PAGE_COUNT</td>
+<td>Task associated with getting the page count of a document</td>
+</tr>
+<tr>
+<td>GENERIC</td>
+<td>Generic task identifier</td>
+</tr>
+<tr>
+<td>DISPLAY_DEV_THUMBS</td>
+<td>Display Device task associated with rendering thumbnails</td>
+</tr>
+<tr>
+<td>DISPLAY_DEV_NON_PDF</td>
+<td>Display Device task associated with non-PDF or non-XPS rendering <sup><a href="#1-ghostscript-page-description-languages">1</a></sup></td>
+</tr>
+<tr>
+<td>DISPLAY_DEV_PDF</td>
+<td>Display Device task associated with PDF &amp; XPS rendering <sup><a href="#1-ghostscript-page-description-languages">1</a></sup></td>
+</tr>
+<tr>
+<td>DISPLAY_DEV_RUN_FILE</td>
+<td>Display Device task associated with running files</td>
+</tr>
+</tbody></table>
+<p>Task types are defined as <code>GS_Task_t</code>.</p>
+<div class="tag enumDefinition csharp"></div>
+
+<pre><code class="language-c">public enum GS_Task_t
+{
+ PS_DISTILL,
+ CREATE_XPS,
+ SAVE_RESULT,
+ GET_PAGE_COUNT,
+ GENERIC,
+ DISPLAY_DEV_THUMBS,
+ DISPLAY_DEV_NON_PDF,
+ DISPLAY_DEV_PDF,
+ DISPLAY_DEV_RUN_FILE
+}</code></pre>
+<h3 id="results">Results</h3>
+<p>Result types are defined as <code>GS_Result_t</code>.</p>
+<div class="tag enumDefinition csharp"></div>
+
+<pre><code class="language-c">public enum GS_Result_t
+{
+ gsOK,
+ gsFAILED,
+ gsCANCELLED
+}</code></pre>
+<h3 id="status">Status</h3>
+<p>Status is defined as <code>gsStatus</code>.</p>
+<div class="tag enumDefinition csharp"></div>
+
+<pre><code class="language-c">public enum gsStatus
+{
+ GS_READY,
+ GS_BUSY,
+ GS_ERROR
+};</code></pre>
+<h2 id="the-parameter-struct">The Parameter Struct</h2>
+<p>The parameter struct <code>gsParamState_t</code> allows for bundles of information to be processed by Ghostscript to complete overall requests.</p>
+<div class="tag structDefinition csharp"></div>
+
+<pre><code class="language-c">public struct gsParamState_t
+{
+ public String outputfile;
+ public String inputfile;
+ public GS_Task_t task;
+ public GS_Result_t result;
+ public int num_pages;
+ public List&lt;int&gt; pages;
+ public int firstpage;
+ public int lastpage;
+ public int currpage;
+ public List&lt;String&gt; args;
+ public int return_code;
+ public double zoom;
+ public bool aa;
+ public bool is_valid;
+};</code></pre>
+<h3 id="parameters-explained">Parameters explained</h3>
+<p>Setting up your parameters (with any dedicated bespoke method(s) which your application requires) is needed when communicating directly with <code>GhostAPI</code>.</p>
+<p>When requesting Ghostscript to process an operation an application developer should send a parameter payload which defines the details for the operation.</p>
+<p>For example in <code>GhostNET</code> we can see the public method as follows:</p>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">public gsStatus DistillPS(String fileName, int resolution)
+{
+ gsParamState_t gsparams = new gsParamState_t();
+ gsparams.args = new List&lt;string&gt;();
+
+ gsparams.inputfile = fileName;
+ gsparams.args.Add("gs");
+ gsparams.args.Add("-sDEVICE=pdfwrite");
+ gsparams.outputfile = Path.GetTempFileName();
+ gsparams.args.Add("-o" + gsparams.outputfile);
+ gsparams.task = GS_Task_t.PS_DISTILL;
+
+ return RunGhostscriptAsync(gsparams);
+}</code></pre>
+<p>Here we can see a parameter payload being setup before being passed on to the asynchronous method <code>RunGhostscriptAsync</code> which sets up a worker thread to run according to the task type in the payload.</p>
+<p><code>GhostNET</code> handles many common operations on an application developer's behalf, however if you require to write your own methods to interface with <code>GhostAPI</code> then referring to the public methods in <code>GhostNET</code> is a good starting point.</p>
+<p>For full documentation on parameters refer to <a href="https://www.ghostscript.com/doc/current/Use.htm#Parameters">Ghostscript parameters</a>.</p>
+<h2 id="the-event-class">The Event class</h2>
+<p><code>GhostNET</code> contains a public class <code>gsEventArgs</code> which is an extension of the C# class <a href="https://docs.microsoft.com/en-us/dotnet/api/system.eventargs?view=net-5.0">EventArgs</a>. This class is used to set and get events as they occur. <code>GhostNET</code> will create these payloads and deliver them back to the application layer's <code>ProgressCallBack</code> method <a href="#delegates">asynchronously</a>.</p>
+<div class="tag classDefinition csharp"></div>
+
+<pre><code class="language-c">public class gsEventArgs : EventArgs
+{
+ private bool m_completed;
+ private int m_progress;
+ private gsParamState_t m_param;
+ public bool Completed
+ {
+ get { return m_completed; }
+ }
+ public gsParamState_t Params
+ {
+ get { return m_param; }
+ }
+ public int Progress
+ {
+ get { return m_progress; }
+ }
+ public gsEventArgs(bool completed, int progress, gsParamState_t param)
+ {
+ m_completed = completed;
+ m_progress = progress;
+ m_param = param;
+ }
+}</code></pre>
+<h2 id="gsnet">GSNET</h2>
+<p>This class should be instantiated as a member variable in your application with callback definitions setup as required.</p>
+<p>Handlers for asynchronous operations can injected by providing your own bespoke callback methods to your instance's <code>ProgressCallBack</code> function.</p>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">/* Set up ghostscript with callbacks for system updates */
+m_ghostscript = new GSNET();
+m_ghostscript.ProgressCallBack += new GSNET.Progress(gsProgress);
+m_ghostscript.StdIOCallBack += new GSNET.StdIO(gsIO);
+m_ghostscript.DLLProblemCallBack += new GSNET.DLLProblem(gsDLL);
+m_ghostscript.PageRenderedCallBack += new GSNET.PageRendered(gsPageRendered);
+m_ghostscript.DisplayDeviceOpen();
+
+/* example callback stubs for asynchronous operations */
+private void gsProgress(gsEventArgs asyncInformation)
+{
+ Console.WriteLine($"gsProgress().progress:{asyncInformation.Progress}");
+
+ if (asyncInformation.Completed) // task complete
+ {
+ // what was the task?
+ switch (asyncInformation.Params.task)
+ {
+ case GS_Task_t.CREATE_XPS:
+ Console.WriteLine($"CREATE_XPS.outputfile:");
+ Console.WriteLine($"{asyncInformation.Params.result.outputfile}");
+ break;
+
+ case GS_Task_t.PS_DISTILL:
+ Console.WriteLine($"PS_DISTILL.outputfile:");
+ Console.WriteLine($"{asyncInformation.Params.result.outputfile}");
+ break;
+
+ case GS_Task_t.SAVE_RESULT:
+
+ break;
+
+ case GS_Task_t.DISPLAY_DEV_THUMBS:
+
+ break;
+
+ case GS_Task_t.DISPLAY_DEV_RUN_FILE:
+
+ break;
+
+ case GS_Task_t.DISPLAY_DEV_PDF:
+
+ break;
+
+ case GS_Task_t.DISPLAY_DEV_NON_PDF:
+
+ break;
+
+ default:
+
+ break;
+ }
+
+ // task failed
+ if (asyncInformation.Params.result == GS_Result_t.gsFAILED)
+ {
+ switch (asyncInformation.Params.task)
+ {
+ case GS_Task_t.CREATE_XPS:
+
+ break;
+
+ case GS_Task_t.PS_DISTILL:
+
+ break;
+
+ case GS_Task_t.SAVE_RESULT:
+
+ break;
+
+ default:
+
+ break;
+ }
+ return;
+ }
+
+ // task cancelled
+ if (asyncInformation.Params.result == GS_Result_t.gsCANCELLED)
+ {
+
+ }
+ }
+ else // task is still running
+ {
+ switch (asyncInformation.Params.task)
+ {
+ case GS_Task_t.CREATE_XPS:
+
+ break;
+
+ case GS_Task_t.PS_DISTILL:
+
+ break;
+
+ case GS_Task_t.SAVE_RESULT:
+
+ break;
+ }
+ }
+}
+
+private void gsIO(String message, int len)
+{
+ Console.WriteLine($"gsIO().message:{message}, length:{len}");
+}
+
+private void gsDLL(String message)
+{
+ Console.WriteLine($"gsDLL().message:{message}");
+}
+
+private void gsPageRendered(int width,
+ int height,
+ int raster,
+ IntPtr data,
+ gsParamState_t state)
+{
+
+};</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>Once a Ghostscript operation is in progress any defined callback functions will be called as the operation runs up unto completion. These callback methods are essential for your application to interpret activity events and react accordingly.</p>
+</blockquote>
+<p>An explanation of callbacks and the available public methods within <code>GSNET</code> are explained below.</p>
+<h3 id="delegates">Delegates</h3>
+<p>To handle asynchronous events <code>GhostNET</code> has four delegates which define callback methods that an application can assign to.</p>
+<table>
+<thead>
+<tr>
+<th>Callback</th>
+<th>Description</th>
+</tr>
+</thead>
+<tbody><tr>
+<td><code>DLLProblemCallBack</code></td>
+<td>Occurs if there is some issue with the Ghostscript DLL</td>
+</tr>
+<tr>
+<td><code>StdIOCallBack</code></td>
+<td>Occurs if Ghostscript outputs something to <code>stderr</code> or <code>stdout</code></td>
+</tr>
+<tr>
+<td><code>ProgressCallBack</code></td>
+<td>Occurs as Ghostscript makes its way through a file</td>
+</tr>
+<tr>
+<td><code>PageRenderedCallBack</code></td>
+<td>Occurs when a page has been rendered and the data from the display device is ready</td>
+</tr>
+</tbody></table>
+<h4 id="dllproblemcallback">DLLProblemCallBack</h4>
+<div class="tag callbackDefinition csharp"></div>
+
+<pre><code class="language-c">internal delegate void DLLProblem(String mess);
+internal event DLLProblem DLLProblemCallBack;</code></pre>
+<h4 id="stdiocallback">StdIOCallBack</h4>
+<div class="tag callbackDefinition csharp"></div>
+
+<pre><code class="language-c">internal delegate void StdIO(String mess,
+ int len);
+internal event StdIO StdIOCallBack;</code></pre>
+<h4 id="progresscallback">ProgressCallBack</h4>
+<div class="tag callbackDefinition csharp"></div>
+
+<pre><code class="language-c">internal delegate void Progress(gsEventArgs info);
+internal event Progress ProgressCallBack;</code></pre>
+<h4 id="pagerenderedcallback">PageRenderedCallBack</h4>
+<div class="tag callbackDefinition csharp"></div>
+
+<pre><code class="language-c">internal delegate void PageRendered(int width,
+ int height,
+ int raster,
+ IntPtr data,
+ gsParamState_t state);
+internal event PageRendered PageRenderedCallBack;</code></pre>
+<h3 id="getversion">GetVersion</h3>
+<p>Use this method to get Ghostscript version info as a handy <code>String</code>.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public String GetVersion()</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">String gs_vers = m_ghostscript.GetVersion();</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>An exception will be thrown if there is any issue with the Ghostscript DLL.</p>
+</blockquote>
+<h3 id="displaydeviceopen">DisplayDeviceOpen</h3>
+<p>Sets up the <a href="https://ghostscript.com/doc/current/Devices.htm#Display_devices">display device</a> ahead of time.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public gsParamState_t DisplayDeviceOpen()</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">m_ghostscript.DisplayDeviceOpen();</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>Calling this method <a href="c-sharp-ghost-api.html#gsapi_new_instance">instantiates ghostscript</a> and configures the encoding and the callbacks for the display device.</p>
+</blockquote>
+<h3 id="displaydeviceclose">DisplayDeviceClose</h3>
+<p>Closes the <a href="https://ghostscript.com/doc/current/Devices.htm#Display_devices">display device</a> and deletes the instance.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public gsParamState_t DisplayDeviceClose()</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">m_ghostscript.DisplayDeviceClose();</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>Calling this method <a href="c-sharp-ghost-api.html#gsapi_delete_instance">deletes ghostscript</a>.</p>
+</blockquote>
+<h3 id="getpagecount">GetPageCount</h3>
+<p>Use this method to get the number of pages in a supplied document.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public int GetPageCount(String fileName)</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">int page_number = m_ghostscript.GetPageCount("my_document.pdf");</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>If Ghostscript is unable to determine the page count then this method will return <code>-1</code>.</p>
+</blockquote>
+<h3 id="createxps">CreateXPS</h3>
+<p>Launches a thread to create an XPS document for Windows printing. This method is <a href="#delegates">asynchronous</a> and logic should be hooked into your application upon <a href="#gsnet">GSNET instantiation</a> to interpret progress.</p>
+<div class="tag methodDefinition csharp async"></div>
+
+<pre><code class="language-c">public gsStatus CreateXPS(String fileName,
+ int resolution,
+ int num_pages,
+ double width,
+ double height,
+ bool fit_page,
+ int firstpage,
+ int lastpage)</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">m_ghostscript.CreateXPS("my_document.pdf",
+ 300,
+ 10,
+ 1000,
+ 1000,
+ true,
+ 0,
+ 9);</code></pre>
+<span class="smallText alignRight">
+
+<p><em><a href="#delegates">asynchronous</a></em></p>
+</span>
+
+<h3 id="distillps">DistillPS</h3>
+<p>Launches a thread rendering all the pages of a supplied PostScript file to a PDF.</p>
+<div class="tag methodDefinition csharp async"></div>
+
+<pre><code class="language-c">public gsStatus DistillPS(String fileName, int resolution)</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">m_ghostscript.DistillPS("my_postscript_document.ps", 300);</code></pre>
+<span class="smallText alignRight">
+
+<p><em><a href="#delegates">asynchronous</a></em></p>
+</span>
+
+
+<h3 id="displaydevicerunfile">DisplayDeviceRunFile</h3>
+<p>Launches a thread to run a file with the <a href="https://ghostscript.com/doc/current/Devices.htm#Display_devices">display device</a>.</p>
+<div class="tag methodDefinition csharp async"></div>
+
+<pre><code class="language-c">public gsStatus DisplayDeviceRunFile(String fileName,
+ double zoom,
+ bool aa, // anti-aliasing value
+ int firstpage,
+ int lastpage)</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">m_ghostscript.DisplayDeviceRunFile("my_document.pdf",
+ 1.0,
+ true,
+ 0,
+ 9);</code></pre>
+<span class="smallText alignRight">
+
+<p><em><a href="#delegates">asynchronous</a></em></p>
+</span>
+
+<h3 id="displaydevicerenderthumbs">DisplayDeviceRenderThumbs</h3>
+<p>Launches a thread rendering all the pages with the <a href="https://ghostscript.com/doc/current/Devices.htm#Display_devices">display device</a> to collect thumbnail images.</p>
+<p>Recommended zoom level for thumbnails is between 0.05 and 0.2, additionally anti-aliasing is probably not required.</p>
+<div class="tag methodDefinition csharp async"></div>
+
+<pre><code class="language-c">public gsStatus DisplayDeviceRenderThumbs(String fileName,
+ double zoom,
+ bool aa)</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">m_ghostscript.DisplayDeviceRenderThumbs("my_document.pdf",
+ 0.1,
+ false);</code></pre>
+<span class="smallText alignRight">
+
+<p><em><a href="#delegates">asynchronous</a></em></p>
+</span>
+
+<h3 id="displaydevicerenderpages">DisplayDeviceRenderPages</h3>
+<p>Launches a thread rendering a set of pages with the <a href="https://ghostscript.com/doc/current/Devices.htm#Display_devices">display device</a>. For use with languages that can be indexed via pages which include PDF and XPS. <sup><a href="#1-ghostscript-page-description-languages">1</a></sup></p>
+<div class="tag methodDefinition csharp async"></div>
+
+<pre><code class="language-c">public gsStatus DisplayDeviceRenderPages(String fileName,
+ int first_page,
+ int last_page,
+ double zoom)</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">m_ghostscript.DisplayDeviceRenderPages("my_document.pdf",
+ 0,
+ 9,
+ 1.0);</code></pre>
+<span class="smallText alignRight">
+
+<p><em><a href="#delegates">asynchronous</a></em></p>
+</span>
+
+
+
+
+<h3 id="getstatus">GetStatus</h3>
+<p>Returns the current <a href="#status">status</a> of <code>Ghostscript</code>.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public gsStatus GetStatus()</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">gsStatus status = m_ghostscript.GetStatus();</code></pre>
+<h3 id="cancel">Cancel</h3>
+<p>Cancels <a href="#delegates">asynchronous</a> operations.</p>
+<div class="tag methodDefinition csharp"></div>
+
+<pre><code class="language-c">public void Cancel()</code></pre>
+<div class="tag sampleCode csharp"></div>
+
+<pre><code class="language-c">m_ghostscript.Cancel();</code></pre>
+<h3 id="ghostscriptexception">GhostscriptException</h3>
+<p>An application developer can log any exceptions in this public class as required by editing the constructor.</p>
+<div class="tag classDefinition csharp"></div>
+
+<pre><code class="language-c">public class GhostscriptException : Exception
+{
+ public GhostscriptException(string message) : base(message)
+ {
+ // Report exceptions as required
+ }
+}</code></pre>
+<h2 id="notes">Notes</h2>
+<h4 id="1-ghostscript-page-description-languages">1: Ghostscript &amp; Page Description Languages</h4>
+<p>Ghostscript handles the following <a href="https://en.wikipedia.org/wiki/Page_description_language">PDLs</a>: <code>PCL</code> <code>PDF</code> <code>PS</code> <code>XPS</code>.</p>
+<p><code>PCL</code> and <code>PS</code> do not allow random access, meaning that, to print page 2 in a 100 page document, Ghostscript has to read the entire document stream of 100 pages.</p>
+<p>On the other hand, <code>PDF</code> and <code>XPS</code> allow for going directly to page 2 and then only dealing with that content. The tasks <code>DISPLAY_DEV_NON_PDF</code> and <code>DISPLAY_DEV_PDF</code> keep track of what sort of input Ghostscript is dealing with and enables the application to direct progress or completion callbacks accordingly.</p>
+</article>
+
+ </div><!-- /middle -->
+
+ <div class="right">
+
+ <div class="link"><a href="#about">About</a></div>
+ <div class="link"><a href="#enums">Enums</a></div>
+ <div class="sub-link"><a href="#tasks">Tasks</a></div>
+ <div class="sub-link"><a href="#results">Results</a></div>
+ <div class="sub-link"><a href="#status">Status</a></div>
+ <div class="link"><a href="#the-parameter-struct">The Parameter Struct</a></div>
+ <div class="sub-link"><a href="#parameters-explained">Parameters explained</a></div>
+ <div class="link"><a href="#the-event-class">The Event class</a></div>
+ <div class="link"><a href="#gsnet">GSNET</a></div>
+ <div class="sub-link"><a href="#delegates">Delegates</a></div>
+ <div class="sub-link"><a href="#getversion">GetVersion</a></div>
+ <div class="sub-link"><a href="#displaydeviceopen">DisplayDeviceOpen</a></div>
+ <div class="sub-link"><a href="#displaydeviceclose">DisplayDeviceClose</a></div>
+ <div class="sub-link"><a href="#getpagecount">GetPageCount</a></div>
+ <div class="sub-link"><a href="#createxps">CreateXPS</a></div>
+ <div class="sub-link"><a href="#distillps">DistillPS</a></div>
+ <div class="sub-link"><a href="#displaydevicerunfile">DisplayDeviceRunFile</a></div>
+ <div class="sub-link"><a href="#displaydevicerenderthumbs">DisplayDeviceRenderThumbs</a></div>
+ <div class="sub-link"><a href="#displaydevicerenderpages">DisplayDeviceRenderPages</a></div>
+ <div class="sub-link"><a href="#getstatus">GetStatus</a></div>
+ <div class="sub-link"><a href="#cancel">Cancel</a></div>
+ <div class="sub-link"><a href="#ghostscriptexception">GhostscriptException</a></div>
+ <div class="link"><a href="#notes">Notes</a></div>
+
+ </div>
+
+ </div>
+
+ <footer></footer>
+
+ </body>
+
+</html>
diff --git a/doc/language-bindings/c-sharp-intro.html b/doc/language-bindings/c-sharp-intro.html
new file mode 100644
index 00000000..bfcbeead
--- /dev/null
+++ b/doc/language-bindings/c-sharp-intro.html
@@ -0,0 +1,218 @@
+<html lang="en">
+ <head>
+ <title>Ghostscript language bindings</title>
+ <meta http-equiv="content-type" content="text/html; charset=utf-8">
+ <meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width">
+ <link href="https://fonts.googleapis.com/css?family=Source+Sans+Pro:200,200i,300,300i,400,400i,600,600i,700,700i,900,900i" rel="stylesheet">
+ <link rel="shortcut icon" type="image/png" href="../images/favicon.png">
+ <link href="css/default.css" rel="stylesheet" type="text/css" />
+ <script type="text/javascript" src="js/default.js"></script>
+ </head>
+
+ <body>
+
+ <header><h1></h1><div class="menu-icon" onclick="javascript:showMenu();"></div></header>
+
+ <div id="burger-menu">
+ <div class="navigation">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link selected"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+ </div>
+ <div class="main">
+
+ <div class="left">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link selected"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+
+ <div class="middle">
+
+<!-- note: don't tab indent <article> as it has <pre> code which will have its layout adversly affected -->
+<article class="markdown-body entry-content"><h1 id="c-overview">C# overview</h1>
+<div class="banner">
+ <div class="c-sharp-text"></div>
+ <div class="vendor-logo c-sharp-logo"></div>
+</div>
+
+<h2 id="about">About</h2>
+<p>In the <a href="https://github.com/ArtifexSoftware/ghostpdl">GhostPDL repository</a> a sample <code>C#</code> project can be found in <code>/demos/csharp</code>.</p>
+<p>Within this project the following namespaces and corresponding <code>C#</code> files are of relevance:</p>
+<ul>
+<li><a href="#ghostapi">GhostAPI</a> <code>ghostapi.cs</code></li>
+<li><a href="#ghostnet">GhostNET</a> <code>ghostnet.cs</code></li>
+<li><a href="#ghostmono">GhostMono</a> <code>ghostmono.cs</code></li>
+</ul>
+<h2 id="platform-setup">Platform &amp; setup</h2>
+<h3 id="building-ghostscript">Building Ghostscript</h3>
+<p>Ghostscript should be built as a shared library for your platform.</p>
+<p>See <a href="index.html#building-ghostscript">Building Ghostscript</a>.</p>
+<h2 id="ghostapi">GhostAPI</h2>
+<p><code>GhostAPI</code> is the main wrapper responsible for bridging over to the <code>C</code> library and ensuring that the correct DLLs are imported.</p>
+<p><code>GhostAPI</code> contains the <code>ghostapi</code> class which <em>does not</em> need to be instantiated as it provides <code>public static</code> methods. These methods, which mirror their <code>C</code> counterparts, are as follows:</p>
+<table>
+<thead>
+<tr>
+<th>Method</th>
+<th>Description</th>
+</tr>
+</thead>
+<tbody><tr>
+<td><a href="c-sharp-ghost-api#gsapi_revision">gsapi_revision</a></td>
+<td>Returns the revision numbers and strings of the Ghostscript interpreter library</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_new_instance">gsapi_new_instance</a></td>
+<td>Create a new instance of Ghostscript</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_delete_instance">gsapi_delete_instance</a></td>
+<td>Destroy an instance of Ghostscript</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_set_stdio_with_handle">gsapi_set_stdio_with_handle</a></td>
+<td>Set the callback functions for <code>stdio</code>, together with the handle to use in the callback functions</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_set_stdio">gsapi_set_stdio</a></td>
+<td>Set the callback functions for <code>stdio</code></td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_set_poll_with_handle">gsapi_set_poll_with_handle</a></td>
+<td>Set the callback function for polling, together with the handle to pass to the callback function</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_set_poll">gsapi_set_poll</a></td>
+<td>Set the callback function for polling</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_set_display_callback">gsapi_set_display_callback</a></td>
+<td><em>deprecated</em></td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_register_callout">gsapi_register_callout</a></td>
+<td>This call registers a callout handler</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_deregister_callout">gsapi_deregister_callout</a></td>
+<td>This call deregisters a previously registered callout handler</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_set_arg_encoding">gsapi_set_arg_encoding</a></td>
+<td>Set the encoding used for the interpretation of all subsequent args supplied via the gsapi interface on this instance</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_set_default_device_list">gsapi_set_default_device_list</a></td>
+<td>Set the string containing the list of default device names</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_get_default_device_list">gsapi_get_default_device_list</a></td>
+<td>Returns a pointer to the current default device string</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_init_with_args">gsapi_init_with_args</a></td>
+<td>Initialise the interpreter</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_run_wildcard">gsapi_run_*</a></td>
+<td>Wildcard for various "run" methods</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_exit">gsapi_exit</a></td>
+<td>Exit the interpreter</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_set_param">gsapi_set_param</a></td>
+<td>Set a parameter</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_get_param">gsapi_get_param</a></td>
+<td>Get a parameter</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_enumerate_params">gsapi_enumerate_params</a></td>
+<td>Enumerate the current parameters</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_add_control_path">gsapi_add_control_path</a></td>
+<td>Add a (case sensitive) path to one of the lists of permitted paths for file access</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_remove_control_path">gsapi_remove_control_path</a></td>
+<td>Remove a (case sensitive) path from one of the lists of permitted paths for file access</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_purge_control_paths">gsapi_purge_control_paths</a></td>
+<td>Clear all the paths from one of the lists of permitted paths for file access</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_activate_path_control">gsapi_activate_path_control</a></td>
+<td>Enable/Disable path control</td>
+</tr>
+<tr>
+<td><a href="c-sharp-ghost-api#gsapi_is_path_control_active">gsapi_is_path_control_active</a></td>
+<td>Query whether path control is activated or not</td>
+</tr>
+</tbody></table>
+<h2 id="ghostnet">GhostNET</h2>
+<p><code>GhostNET</code> is the <a href="https://dotnet.microsoft.com/">.NET</a> interface into <code>GhostAPI</code>. It exemplifies how to do more complex operations involving multiple API calls and sequences.</p>
+<h3 id="ghostnet-wpf-example">GhostNET WPF example</h3>
+<p>In <code>demos/csharp/windows/ghostnet.sln</code> there is a sample C# demo project.</p>
+<p>This project can be opened in <a href="https://visualstudio.microsoft.com">Visual Studio</a> and used to test the Ghostscript API alongside a UI which handles opening PostScript and PDF files. The sample application here allows for file browsing and Ghostscript file viewing.</p>
+<p>Below is a screenshot of the sample application with a PDF open:</p>
+<p><img src="images/ghostnet-wpf-example.png" alt="ghostnet wpf example UI"></p>
+<h2 id="ghostmono">GhostMono</h2>
+<p><code>GhostMono</code> is the <a href="https://www.mono-project.com/">Mono</a> equivalent of <code>GhostNET</code> and as such has no dependancy on a Windows environment.</p>
+</article>
+
+ </div>
+
+ <div class="right">
+
+ <div class="link"><a href="#about">About</a></div>
+ <div class="link"><a href="#platform-setup">Platform & setup</a></div>
+ <div class="sub-link"><a href="#building-ghostscript">Building Ghostscript</a></div>
+ <div class="link"><a href="#ghostapi">GhostAPI</a></div>
+ <div class="link"><a href="#ghostnet">GhostNET</a></div>
+ <div class="sub-link"><a href="#ghostnet-wpf-example">GhostNET WPF example</a></div>
+ <div class="link"><a href="#ghostmono">GhostMono</a></div>
+
+ </div>
+
+ </div>
+
+ <footer></footer>
+
+ </body>
+
+</html>
diff --git a/doc/language-bindings/css/default.css b/doc/language-bindings/css/default.css
new file mode 100644
index 00000000..16297c1f
--- /dev/null
+++ b/doc/language-bindings/css/default.css
@@ -0,0 +1,735 @@
+* {
+ -webkit-tap-highlight-color: rgba(0,0,0,0);
+ -moz-box-sizing: border-box;
+ -webkit-box-sizing: border-box;
+ box-sizing: border-box;
+}
+
+html, body, div, span, applet, object, iframe,
+h1, h2, h3, h4, h5, h6, p, blockquote, pre,
+a, abbr, acronym, address, big, cite, code,
+del, dfn, em, img, ins, kbd, q, s, samp,
+small, strike, strong, sub, tt, var,
+b, u, i, center,
+dl, dt, dd, ol, ul, li,
+fieldset, form, label, legend,
+table, caption, tbody, tfoot, thead, tr, th, td,
+article, aside, canvas, details, embed,
+figure, figcaption, footer, header, hgroup,
+menu, nav, output, ruby, section, summary,
+time, mark, audio, video {
+ margin: 0;
+ padding: 0;
+ border: 0;
+ font-size: 100%;
+ font: inherit;
+ vertical-align: baseline;
+}
+
+/* HTML5 display-role reset for older browsers */
+article, aside, details, figcaption, figure,
+footer, header, hgroup, menu, nav, section {
+ display: block;
+}
+
+html, body {
+ position: relative;
+ height: 100%;
+}
+
+body {
+ -webkit-touch-callout: none; /* prevent callout to copy image, etc when tap to hold */
+ -webkit-text-size-adjust: none; /* prevent webkit from resizing text to fit */
+ -webkit-user-select: text; /* prevent copy paste, to allow, change 'none' to 'text' */
+ color:black;
+ background:#f9f9f9;
+ font-family:"Source Sans Pro", sans-serif; /* 200 = ExtraLight, 300 = Light, 400 = regular, 600 = semi-bold, 700 = bold, 900 = black */
+ font-weight:400;
+ font-size:16px;
+ margin:0px;
+ padding:0px;
+}
+
+.markdown-body, .entry-content {
+ padding: 0;
+}
+
+.markdown-body code {
+ background-color: #ddd;
+ border-radius: 3px;
+ padding: 2px 6px;
+ font-family: monospace;
+}
+
+.markdown-body pre {
+ background-color: #ddd;
+ word-wrap:normal;
+ margin-bottom:20px;
+ padding:20px;
+ overflow:auto;
+ font-size:85%;
+ line-height:1.45;
+ border-radius:3px
+}
+
+.markdown-body pre>code {
+ padding:0;
+ margin:0;
+ font-size:100%;
+ word-break:normal;
+ white-space:pre;
+ background:transparent;
+ border:0;
+}
+
+.markdown-body pre code, .markdown-body pre tt {
+ display:inline;
+ padding:0;
+ margin:0;
+ overflow:visible;
+ line-height:inherit;
+ word-wrap:normal;
+ background-color:transparent;
+ border:0
+}
+
+.markdown-body pre code::before,
+.markdown-body pre code::after,
+.markdown-body pre tt::before,
+.markdown-body pre tt::after {
+ content:normal
+}
+
+.markdown-body table {
+ color: #000;
+}
+
+.markdown-body table code {
+ color: #000;
+}
+
+.markdown-body table tr {
+ background-color: #fff;
+ border-bottom: 1px solid #c0c0c0;
+}
+
+.markdown-body table tr:nth-child(2n) {
+ background-color: #ddd;
+}
+
+header {
+ position: fixed;
+ width: 100%;
+ height:50px;
+ background: #0075cf url(../images/ghostscript.png) 10px center no-repeat;
+ background-size: 30px 30px;
+ color: #fff;
+ line-height: 50px;
+ text-indent: 50px;
+ z-index: 1;
+ display: flex;
+ justify-content: space-between;
+}
+
+header .menu-icon {
+ display: none;
+ margin-right: 10px;
+ width:50px;
+ height:50px;
+ background:transparent url(../images/icon-burger-menu.png) center center no-repeat;
+ background-size: 50px 50px;
+}
+
+header h1::after {
+ content: "Ghostscript language bindings";
+}
+
+footer::after {
+ content:"Copyright \00A9 2021 Artifex Software Inc. All rights reserved.";
+}
+
+a {
+ text-decoration: none;
+ color: #0075cf;
+}
+
+/** for in page anchor positioning - this offset is the height of the fixed header
+/** This appends a pseudo-element before every h2/h3 tag with an id.
+Adjusted height to accommodate header. **/
+h2[id]::before, h3[id]::before, h4[id]::before {
+ content: '';
+ display: block;
+ height: 50px;
+ margin: 0;
+}
+
+.main .middle h2, .main .middle h3, .main .middle h4 {
+ margin-top: -50px;
+ padding-top: 20px;
+}
+
+.main .middle h2 {
+ border-bottom: 3px solid #999;
+}
+
+.main .middle h3 {
+ border-bottom: 1px solid #999;
+}
+
+i {
+ font-style: italic;
+}
+
+p {
+ line-height: 24px;
+}
+
+header h1 {
+ font-size:24px;
+ font-weight:600;
+}
+
+h1 {
+ font-size:40px;
+ font-weight:600;
+}
+
+h2 {
+ font-weight:600;
+ font-size:26px;
+ margin-bottom: 10px;
+}
+
+h3 {
+ font-weight:600;
+ font-size:20px;
+ margin-bottom: 10px;
+}
+
+h4 {
+ font-weight:600;
+ font-size:16px;
+ margin-bottom: 10px;
+}
+
+li {
+ margin: 10px;
+}
+
+table {
+ margin: 20px 0;
+ border-collapse: collapse;
+ table-layout:fixed;
+ max-width:600px;
+ width: 100%;
+ border: 1px solid #c0c0c0;
+}
+
+th {
+ font-weight: bold;
+ background-color:#666;
+ color: #fff;
+ border-bottom: 1px solid #c0c0c0;
+ border-right: 1px solid #c0c0c0;
+}
+
+tr {
+ text-overflow:clip;
+}
+
+th, td {
+ text-align: left;
+ padding:14px;
+ word-wrap:break-word;
+}
+
+td {
+ border-right: 1px solid #c0c0c0;
+}
+
+footer {
+ position: relative;
+ left: 20%;
+ width: 60%;
+ height: 100px;
+ margin: 50px 0 0 0;
+ padding: 50px 20px;
+ background: url(../images/artifex-logo.png) 20px 0 no-repeat;
+ background-size: 200px auto;
+}
+
+
+em {
+ font-style: italic;
+}
+
+#burger-menu {
+ display: none;
+ position: fixed;
+ top: 50px;
+ right: 0;
+ text-align: right;
+ z-index: 1;
+ background-color: rgba(0,0,0,0.95);
+ padding: 20px;
+ border-radius: 20px;
+ border: 1px solid #c0c0c0;
+ bottom:0;
+ overflow-y:scroll;
+ overflow-x:hidden;
+}
+
+#burger-menu.show {
+ display: block;
+}
+
+#burger-menu .navigation .title {
+ color: #fff;
+ margin-top: 8px;
+}
+
+#burger-menu .navigation .link {
+ text-indent: 5px;
+ margin: 5px 10px 5px 0;
+}
+
+.main {
+ padding-top: 50px;
+ display: flex;
+}
+
+.main .left {
+ position: fixed;
+ margin: 0px;
+ inset: 50px auto 0 0;
+ width: 20%;
+ overflow-y:auto;
+ overflow-x:hidden;
+ padding: 20px 0 20px 20px;
+ border-right: 1px solid gainsboro;
+}
+
+.main .left div {
+ padding: 2px 0 2px 0;
+}
+
+.main .left .link {
+ padding-left: 40px;
+ text-indent: -20px;
+}
+
+.main .left .link {
+ padding-left: 40px;
+ text-indent: -20px;
+}
+
+.main .left .group {
+ padding-left: 20px;
+}
+
+.main .left .link.selected, #burger-menu .navigation .link.selected {
+ background-color: #0075cf;
+ color: #fff;
+}
+
+.main .left .link.selected a, #burger-menu .navigation .link.selected a{
+ color: #fff;
+}
+
+.main .middle {
+ position: relative;
+ left: 20%;
+ width: 60%;
+ padding: 10px 20px 20px 20px;
+}
+
+.main article {
+ margin: auto;
+}
+
+.main .middle p {
+ margin-bottom: 20px;
+}
+
+.main .middle ul {
+ margin: 0 0 20px 20px;
+}
+
+.main .middle img {
+ width: 100%;
+}
+
+blockquote {
+ background-color: #eee;
+ width: 100%;
+ height: auto;
+ padding: 20px;
+ border-radius: 10px;
+ margin: 0 0 20px 0;
+}
+
+blockquote strong {
+ font-size: 16px;
+ font-weight: bold;
+}
+
+.markdown-body blockquote code {
+ background: #bbb;
+}
+
+.main .right {
+ inset: 50px 0 0 auto;
+ width: 20%;
+ position:fixed;
+ overflow-y:auto;
+ overflow-x:hidden;
+ padding: 20px;
+ border-left: 1px solid gainsboro;
+}
+
+.main .right .link {
+ padding: 2px 0 2px 20px;
+ text-indent: -20px;
+}
+
+.main .right .sub-link {
+ padding: 1px 0 1px 40px;
+ text-indent: -20px;
+ font-size:12px;
+ word-wrap: break-word;
+}
+
+.banner {
+ margin: 20px 0;
+ display:flex;
+ justify-content: space-between;
+ width:100%;
+ height:50px;
+ line-height:50px;
+ font-weight:bold;
+}
+
+.banner.intro {
+ justify-content: flex-end;
+}
+
+.vendor-logo {
+ width:25%;
+ height:50px;
+}
+
+.gs-logo {
+ background: url(../images/ghostscript-grey.png) center center no-repeat;
+ background-size: 50px 50px;
+}
+
+.c-logo {
+ width:50px;
+ height:50px;
+ background: url(../images/icon-vendor-c.png) center center no-repeat;
+ background-size: 50px 50px;
+}
+
+.c-sharp-logo {
+ background: url(../images/icon-vendor-c-sharp.png) center center no-repeat;
+ background-size: 50px 50px;
+}
+
+.java-logo {
+ background: url(../images/icon-vendor-java.png) center center no-repeat;
+ background-size: 50px 50px;
+}
+
+.python-logo {
+ background: url(../images/icon-vendor-python.png) center center no-repeat;
+ background-size: 50px 50px;
+}
+
+.banner.intro {
+ justify-content: flex-end;
+}
+
+.banner .default-text::after {
+ content:"";
+}
+
+.banner .c-sharp-text::after {
+ content:"C# API";
+}
+
+.banner .java-text::after {
+ content:"Java API";
+}
+
+.banner .python-text::after {
+ content:"Python API";
+}
+
+.tag {
+ padding:5px 0px;
+ background-color:transparent;
+ color:#666;
+ font-size:10px;
+}
+
+.tag.shellCommand::before {
+ width:100%;
+ content:"\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0 SHELL COMMAND";
+ background: url(../images/icon-shell-command.png) left center no-repeat;
+ background-size:13px 13px;
+}
+
+.tag.sampleCode::after {
+ content:"SAMPLE CODE";
+}
+
+.tag.sampleCode.csharp::after {
+ width:100%;
+ content:"\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0 SAMPLE CODE";
+ background: url(../images/icon-vendor-c-sharp.png) left center no-repeat;
+ background-size:13px 13px;
+}
+
+.tag.sampleCode.java::after {
+ width:100%;
+ content:"\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0 SAMPLE CODE";
+ background: url(../images/icon-vendor-java.png) left center no-repeat;
+ background-size:20px 20px;
+}
+
+.tag.sampleCode.python::after {
+ width:100%;
+ content:"\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0 SAMPLE CODE";
+ background: url(../images/icon-vendor-python.png) left center no-repeat;
+ background-size:13px 13px;
+}
+
+.tag.structDefinition::after {
+ content:"STRUCT DEFINITION";
+}
+
+.tag.structDefinition.csharp::after {
+ width:100%;
+ content:"\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0 STRUCT DEFINITION";
+ background: url(../images/icon-vendor-c-sharp.png) left center no-repeat;
+ background-size:13px 13px;
+}
+
+.tag.enumDefinition::after {
+ content:"ENUM DEFINITION";
+}
+
+.tag.enumDefinition.csharp::after {
+ width:100%;
+ content:"\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0 ENUM DEFINITION";
+ background: url(../images/icon-vendor-c-sharp.png) left center no-repeat;
+ background-size:13px 13px;
+}
+
+.tag.enumDefinition.python::after {
+ width:100%;
+ content:"\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0 ENUM DEFINITION";
+ background: url(../images/icon-vendor-python.png) left center no-repeat;
+ background-size:13px 13px;
+}
+
+.tag.methodDefinition::after {
+ content:"METHOD DEFINITION";
+}
+
+.tag.methodDefinition.csharp::after {
+ width:100%;
+ content:"\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0 METHOD DEFINITION";
+ background: url(../images/icon-vendor-c-sharp.png) left center no-repeat;
+ background-size:13px 13px;
+}
+
+.tag.methodDefinition.java::after {
+ width:100%;
+ content:"\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0 METHOD DEFINITION";
+ background: url(../images/icon-vendor-java.png) left center no-repeat;
+ background-size:20px 20px;
+}
+
+.tag.methodDefinition.python::after {
+ width:100%;
+ content:"\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0 METHOD DEFINITION";
+ background: url(../images/icon-vendor-python.png) left center no-repeat;
+ background-size:13px 13px;
+}
+
+.tag.classDefinition::after {
+ content:"CLASS DEFINITION";
+}
+
+.tag.classDefinition.csharp::after {
+ width:100%;
+ content:"\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0 CLASS DEFINITION";
+ background: url(../images/icon-vendor-c-sharp.png) left center no-repeat;
+ background-size:13px 13px;
+}
+
+.tag.classDefinition.java::after {
+ width:100%;
+ content:"\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0 CLASS DEFINITION";
+ background: url(../images/icon-vendor-java.png) left center no-repeat;
+ background-size:20px 20px;
+}
+
+.tag.callbackDefinition::after {
+ content:"DELEGATE DEFINITION";
+}
+
+.tag.callbackDefinition.csharp::after {
+ width:100%;
+ content:"\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0 DELEGATE DEFINITION";
+ background: url(../images/icon-vendor-c-sharp.png) left center no-repeat;
+ background-size:13px 13px;
+}
+
+.tag.functionalInterface.java::after {
+ width:100%;
+ content:"\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0\00a0 FUNCTIONAL INTERFACE";
+ background: url(../images/icon-vendor-java.png) left center no-repeat;
+ background-size:20px 20px;
+}
+
+.smallText {
+ line-height: 12px;
+ font-size: 12px;
+}
+
+.alignRight {
+ text-align: right;
+}
+
+button.cta {
+ -webkit-appearance: none;
+ -moz-appearance: none;
+ border:0;
+ text-transform:uppercase;
+ border-radius:5px;
+ font-size:16px;
+ font-weight:500;
+ min-height:40px;
+ line-height:40px;
+ padding: 0 15px;
+ color:#fff;
+ cursor:pointer;
+}
+
+button.cta.orange {
+ width:auto;
+ background-image: linear-gradient(to right, #ea5842, #ec6343, #ed6d45, #ef7747, #f0804a);
+}
+
+button.cta.orange:hover {
+ background:#ea5842;
+}
+
+button.cta a {
+ color:#fff;
+}
+
+/* Dark mode */
+@media (prefers-color-scheme: dark) {
+
+ body {
+ background-color: #111;
+ color: white;
+ }
+
+ .markdown-body code, .markdown-body pre, code, .markdown-body blockquote code {
+ background-color: #444;
+ }
+
+ .markdown-body table {
+ color: #fff;
+ }
+
+ .markdown-body table code {
+ color: #fff;
+ }
+
+ .markdown-body table tr {
+ background-color: #000;
+ }
+
+ .markdown-body table tr:nth-child(2n) {
+ background-color: #222;
+ }
+
+ footer {
+ background: url(../images/artifex-logo-white.png) 20px 0 no-repeat;
+ background-size: 200px auto;
+ }
+
+ .main .middle .note, blockquote {
+ color: #000;
+ background-color: #fff;
+ }
+
+ .main .middle .note code, blockquote code {
+ color: #fff;
+ }
+
+ .vendor-logo, .tag {
+ -webkit-filter: invert(100%);
+ filter: invert(100%);
+ }
+}
+
+
+/* responsive sizes */
+@media only screen and (max-width: 1023px) {
+ .banner.intro {
+ justify-content: center;
+ }
+}
+
+/* < Tablet portrait */
+@media all and (max-width : 767px) {
+ header .menu-icon {
+ display: block;
+ }
+
+ footer {
+ left: 0%;
+ width: 100%;
+ }
+
+ .main .left {
+ width: 0%;
+ display: none;
+ }
+
+ .main .middle {
+ left: 0;
+ width: 100%;
+ }
+
+ .main .right {
+ width: 0;
+ display: none;
+ }
+
+ table {
+ width: 100%;
+ }
+}
+
+@media all and (max-width : 375px) {
+ header h1 {
+ font-size:20px;
+ }
+
+ table tr td {
+ font-size: 13px;
+ }
+}
+
+@media all and (max-width : 320px) {
+ header h1 {
+ font-size:16px;
+ }
+}
diff --git a/doc/language-bindings/demo-code.html b/doc/language-bindings/demo-code.html
new file mode 100644
index 00000000..876e3cb7
--- /dev/null
+++ b/doc/language-bindings/demo-code.html
@@ -0,0 +1,91 @@
+<html lang="en">
+ <head>
+ <title>Ghostscript language bindings</title>
+ <meta http-equiv="content-type" content="text/html; charset=utf-8">
+ <meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width">
+ <link href="https://fonts.googleapis.com/css?family=Source+Sans+Pro:200,200i,300,300i,400,400i,600,600i,700,700i,900,900i" rel="stylesheet">
+ <link rel="shortcut icon" type="image/png" href="../images/favicon.png">
+ <link href="css/default.css" rel="stylesheet" type="text/css" />
+ <script type="text/javascript" src="js/default.js"></script>
+ </head>
+
+ <body>
+
+ <header><h1></h1><div class="menu-icon" onclick="javascript:showMenu();"></div></header>
+
+ <div id="burger-menu">
+ <div class="navigation">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link selected"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+ </div>
+ <div class="main">
+
+ <div class="left">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link selected"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+
+ <div class="middle">
+
+<!-- note: don't tab indent <article> as it has <pre> code which will have its layout adversly affected -->
+<article class="markdown-body entry-content">
+ <h1 id="demo-code">Demo code</h1>
+<div class="banner intro">
+ <div class="default-text"></div>
+ <div class="vendor-logo gs-logo"></div>
+ <div class="vendor-logo c-sharp-logo"></div>
+ <div class="vendor-logo java-logo"></div>
+ <div class="vendor-logo python-logo"></div>
+</div>
+
+
+<h2 id="about">About</h2>
+
+<p>Please locate the <code>demos</code> folder in your <code>ghostpdl</code> source code download from the <a href="https://github.com/ArtifexSoftware/ghostpdl">GhostPDL repository</a> to find sample code demonstrating the language bindings in action.</p>
+</article>
+ </div>
+
+ <div class="right">
+
+ <div class="link"><a href="#about">About</a></div>
+
+ </div>
+
+ </div>
+
+ <footer></footer>
+
+ </body>
+
+</html>
diff --git a/doc/language-bindings/gs-language-bindings.pdf b/doc/language-bindings/gs-language-bindings.pdf
new file mode 100644
index 00000000..f01dc597
--- /dev/null
+++ b/doc/language-bindings/gs-language-bindings.pdf
Binary files differ
diff --git a/doc/language-bindings/images/artifex-logo-white.png b/doc/language-bindings/images/artifex-logo-white.png
new file mode 100644
index 00000000..112eb9bc
--- /dev/null
+++ b/doc/language-bindings/images/artifex-logo-white.png
Binary files differ
diff --git a/doc/language-bindings/images/artifex-logo.png b/doc/language-bindings/images/artifex-logo.png
new file mode 100644
index 00000000..cde238a4
--- /dev/null
+++ b/doc/language-bindings/images/artifex-logo.png
Binary files differ
diff --git a/doc/language-bindings/images/export-jar.png b/doc/language-bindings/images/export-jar.png
new file mode 100644
index 00000000..55550496
--- /dev/null
+++ b/doc/language-bindings/images/export-jar.png
Binary files differ
diff --git a/doc/language-bindings/images/ghostnet-wpf-example.png b/doc/language-bindings/images/ghostnet-wpf-example.png
new file mode 100644
index 00000000..b5b1eaa1
--- /dev/null
+++ b/doc/language-bindings/images/ghostnet-wpf-example.png
Binary files differ
diff --git a/doc/language-bindings/images/ghostscript-grey.png b/doc/language-bindings/images/ghostscript-grey.png
new file mode 100644
index 00000000..b295ad05
--- /dev/null
+++ b/doc/language-bindings/images/ghostscript-grey.png
Binary files differ
diff --git a/doc/language-bindings/images/ghostscript-plus-text-white.png b/doc/language-bindings/images/ghostscript-plus-text-white.png
new file mode 100644
index 00000000..1b3d2a4e
--- /dev/null
+++ b/doc/language-bindings/images/ghostscript-plus-text-white.png
Binary files differ
diff --git a/doc/language-bindings/images/ghostscript-plus-text.png b/doc/language-bindings/images/ghostscript-plus-text.png
new file mode 100644
index 00000000..15b17e5a
--- /dev/null
+++ b/doc/language-bindings/images/ghostscript-plus-text.png
Binary files differ
diff --git a/doc/language-bindings/images/ghostscript.png b/doc/language-bindings/images/ghostscript.png
new file mode 100644
index 00000000..3369a123
--- /dev/null
+++ b/doc/language-bindings/images/ghostscript.png
Binary files differ
diff --git a/doc/language-bindings/images/gsviewer.png b/doc/language-bindings/images/gsviewer.png
new file mode 100644
index 00000000..75c9d5af
--- /dev/null
+++ b/doc/language-bindings/images/gsviewer.png
Binary files differ
diff --git a/doc/language-bindings/images/icon-burger-menu.png b/doc/language-bindings/images/icon-burger-menu.png
new file mode 100644
index 00000000..d70fd43c
--- /dev/null
+++ b/doc/language-bindings/images/icon-burger-menu.png
Binary files differ
diff --git a/doc/language-bindings/images/icon-shell-command.png b/doc/language-bindings/images/icon-shell-command.png
new file mode 100644
index 00000000..c538bc6c
--- /dev/null
+++ b/doc/language-bindings/images/icon-shell-command.png
Binary files differ
diff --git a/doc/language-bindings/images/icon-vendor-c-sharp.png b/doc/language-bindings/images/icon-vendor-c-sharp.png
new file mode 100644
index 00000000..a4bc2c6d
--- /dev/null
+++ b/doc/language-bindings/images/icon-vendor-c-sharp.png
Binary files differ
diff --git a/doc/language-bindings/images/icon-vendor-c.png b/doc/language-bindings/images/icon-vendor-c.png
new file mode 100644
index 00000000..b259df47
--- /dev/null
+++ b/doc/language-bindings/images/icon-vendor-c.png
Binary files differ
diff --git a/doc/language-bindings/images/icon-vendor-java.png b/doc/language-bindings/images/icon-vendor-java.png
new file mode 100644
index 00000000..56f2ea7c
--- /dev/null
+++ b/doc/language-bindings/images/icon-vendor-java.png
Binary files differ
diff --git a/doc/language-bindings/images/icon-vendor-python.png b/doc/language-bindings/images/icon-vendor-python.png
new file mode 100644
index 00000000..bdbe2330
--- /dev/null
+++ b/doc/language-bindings/images/icon-vendor-python.png
Binary files differ
diff --git a/doc/language-bindings/images/linking-jar.png b/doc/language-bindings/images/linking-jar.png
new file mode 100644
index 00000000..ce64e587
--- /dev/null
+++ b/doc/language-bindings/images/linking-jar.png
Binary files differ
diff --git a/doc/language-bindings/index.html b/doc/language-bindings/index.html
new file mode 100644
index 00000000..7758abd7
--- /dev/null
+++ b/doc/language-bindings/index.html
@@ -0,0 +1,168 @@
+<html lang="en">
+ <head>
+ <title>Ghostscript language bindings</title>
+ <meta http-equiv="content-type" content="text/html; charset=utf-8">
+ <meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width">
+ <link href="https://fonts.googleapis.com/css?family=Source+Sans+Pro:200,200i,300,300i,400,400i,600,600i,700,700i,900,900i" rel="stylesheet">
+ <link rel="shortcut icon" type="image/png" href="../images/favicon.png">
+ <link href="css/default.css" rel="stylesheet" type="text/css" />
+ <script type="text/javascript" src="js/default.js"></script>
+ </head>
+
+ <body>
+
+ <header><h1></h1><div class="menu-icon" onclick="javascript:showMenu();"></div></header>
+
+ <div id="burger-menu">
+ <div class="navigation">
+ <div class="title first">Introduction</div>
+ <div class="link selected"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+ </div>
+
+ <div class="main">
+ <div class="left">
+ <div class="title first">Introduction</div>
+ <div class="link selected"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+
+ <div class="middle">
+
+
+<!-- note: don't tab indent <article> as it has <pre> code which will have its layout adversly affected -->
+<article class="markdown-body entry-content"><h1 id="introduction">Introduction</h1>
+<div class="banner intro">
+ <div class="default-text"></div>
+ <div class="vendor-logo gs-logo"></div>
+ <div class="vendor-logo c-sharp-logo"></div>
+ <div class="vendor-logo java-logo"></div>
+ <div class="vendor-logo python-logo"></div>
+</div>
+
+<h2 id="about-our-apis">About our APIs</h2>
+<p>The core of Ghostscript is written in <code>C</code>, but also supports <a href="https://en.wikipedia.org/wiki/Language_binding">language bindings</a> for the following programming languages:</p>
+<ul>
+<li><code>C#</code></li>
+<li><code>Java</code></li>
+<li><code>Python</code></li>
+</ul>
+<p>All of the above languages have equivalent methods as defined in the <a href="https://www.ghostscript.com/doc/current/API.htm">C API</a>. <code>Java</code> and <code>C#</code> provide additional helper methods to make the use of the API easier for certain applications. These languages also provide example viewers that make use of these methods.</p>
+<p>This developer documentation is organized by programming language type and includes API reference and sample code.</p>
+<h2 id="the-c-api">The C API</h2>
+<div class="vendor-logo c-logo"></div>
+<p>
+
+</p><p>Ghostscript has been in development for over thirty years and is written in <code>C</code>. The API has evolved over time and is continually being developed. The language bindings into Ghostscript will attempt to mirror this evolution and match the current <a href="https://www.ghostscript.com/doc/current/API.htm">C API</a> as much as possible.</p>
+<h2 id="licensing">Licensing</h2>
+<p>Before using Ghostscript, please make sure that you have a valid license to do so. There are two available licenses; make sure you pick the one whose terms you can comply with.</p>
+<h3 id="open-source-license">Open Source license</h3>
+<p>If your software is open source, you may use Ghostscript under the terms of the GNU Affero General Public License.</p>
+<p>This means that all of the source code for your complete app must be released under a compatible open source license!</p>
+<p>It also means that you may not use any proprietary closed source libraries or components in your app.</p>
+<p>Please read the full text of the AGPL license agreement from the <a href="https://www.gnu.org/licenses/agpl-3.0.html">FSF web site</a></p>
+<p>If you cannot or do not want to comply with these restrictions, you must acquire a commercial license instead.</p>
+<p><button class="cta orange"><a href="https://artifex.com/licensing/" target="new">FIND OUT MORE</a></button></p>
+<h3 id="commercial-license">Commercial license</h3>
+<p>If your project does not meet the requirements of the AGPL, please contact our sales team to discuss a commercial license. Each Artifex commercial license is crafted based on your individual use case.</p>
+<p><button class="cta orange"><a href="https://artifex.com/contact/" target="new">CONTACT US</a></button></p>
+<h2 id="building-ghostscript">Building Ghostscript</h2>
+<p>In order to use Ghostscript language bindings firstly Ghostscript must be built as a shared library for your platform.</p>
+<p>The following built libraries are required for these respective platforms:</p>
+<table>
+<thead>
+<tr>
+<th>Platform</th>
+<th>Ghostscript library files</th>
+</tr>
+</thead>
+<tbody><tr>
+<td>Windows 32-bit</td>
+<td><code>gpdldll32.dll</code> <code>gsdll32.dll</code></td>
+</tr>
+<tr>
+<td>Windows 64-bit</td>
+<td><code>gpdldll64.dll</code> <code>gsdll64.dll</code></td>
+</tr>
+<tr>
+<td>MacOS</td>
+<td><code>libgpdl.dylib</code> <code>libgs.dylib</code></td>
+</tr>
+<tr>
+<td>Linux / OpenBSD</td>
+<td><code>libgpdl.so</code> <code>libgs.so</code></td>
+</tr>
+</tbody></table>
+<blockquote>
+<p><strong>NOTE</strong><br>
+The actual filenames on MacOS will be appended with the version of Ghostscript with associated symlinks.</p>
+</blockquote>
+<h3 id="building-on-windows">Building on Windows</h3>
+<p>To build the required DLLs, load <code>/windows/ghostpdl.sln</code> into Visual Studio, and select the required architecture from the drop down - then right click on 'ghostpdl' in the solution explorer and choose "Build".</p>
+<h3 id="building-on-macos-or-linux-openbsd">Building on MacOS or Linux / OpenBSD</h3>
+<p>Firstly run the <code>autogen.sh</code> script from the command line to create the required configuration files followed by <code>make so</code> to build the shared libraries. The scripts also depend on having both <code>autoconf</code> and <code>automake</code> installed on your system. <sup>[1]</sup></p>
+<h4 id="autoconf-automake">autoconf &amp; automake</h4>
+<p>If this software is not already on your system (usually this can be found in the following location: <code>usr/local/bin</code>, but it could be located elsewhere depending on your setup) then it can be installed from your OS's package system.</p>
+<p>Alternatively, it can be installed from <a href="https://www.gnu.org/">GNU</a> here:</p>
+<p><a href="https://www.gnu.org/software/autoconf/">https://www.gnu.org/software/autoconf/</a></p>
+<p><a href="https://www.gnu.org/software/automake/">https://www.gnu.org/software/automake/</a></p>
+<p>Or, it can be installed via <a href="https://brew.sh/">Brew</a> by running:</p>
+<pre><code>brew install autoconf automake</code></pre><p>Once built, these libraries can be found in your <code>ghostpdl/sobin/</code> or <code>ghostpdl/sodebugbin</code> location depending on your build command.</p>
+<blockquote>
+<p><strong>NOTE</strong><br>
+For full detailed instructions on how to build your Ghostscript library see <a href="https://ghostscript.com/doc/current/Make.htm">here</a>.</p>
+</blockquote>
+</article>
+
+ </div>
+
+ <div class="right">
+
+ <div class="link"><a href="#about-our-apis">About our APIs</a></div>
+ <div class="link"><a href="#the-c-api">The C API</a></div>
+ <div class="link"><a href="#licensing">Licensing</a></div>
+ <div class="sub-link"><a href="#open-source-license">Open Source license</a></div>
+ <div class="sub-link"><a href="#commercial-license">Commercial license</a></div>
+ <div class="link"><a href="#building-ghostscript">Building Ghostscript</a></div>
+ <div class="sub-link"><a href="#building-on-windows">Building on Windows</a></div>
+ <div class="sub-link"><a href="#building-on-macos-or-linux-openbsd">Building on MacOS or Linux / OpenBSD</a></div>
+ </div>
+
+
+ </div>
+
+ <footer></footer>
+
+ </body>
+
+
+</html>
diff --git a/doc/language-bindings/java-gsjavajar.html b/doc/language-bindings/java-gsjavajar.html
new file mode 100644
index 00000000..e11337fc
--- /dev/null
+++ b/doc/language-bindings/java-gsjavajar.html
@@ -0,0 +1,783 @@
+<html lang="en">
+ <head>
+ <title>Ghostscript language bindings</title>
+ <meta http-equiv="content-type" content="text/html; charset=utf-8">
+ <meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width">
+ <link href="https://fonts.googleapis.com/css?family=Source+Sans+Pro:200,200i,300,300i,400,400i,600,600i,700,700i,900,900i" rel="stylesheet">
+ <link rel="shortcut icon" type="image/png" href="../images/favicon.png">
+ <link href="css/default.css" rel="stylesheet" type="text/css" />
+ <script type="text/javascript" src="js/default.js"></script>
+ </head>
+
+ <body>
+
+ <header><h1></h1><div class="menu-icon" onclick="javascript:showMenu();"></div></header>
+
+ <div id="burger-menu">
+ <div class="navigation">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link selected"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+ </div>
+ <div class="main">
+
+ <div class="left">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link selected"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+
+ <div class="middle">
+
+<!-- note: don't tab indent <article> as it has <pre> code which will have its layout adversly affected -->
+<article class="markdown-body entry-content"><h1 id="gsjava-jar">gsjava.jar</h1>
+<div class="banner">
+<div class="java-text"></div>
+<div class="vendor-logo java-logo"></div>
+</div>
+
+
+<h2 id="about">About</h2>
+<p><code>gsjava.jar</code> is the Java library which contains classes and interfaces which enable API calls required to use Ghostscript.</p>
+<p>Assuming that the JAR for your project has been <a href="java-intro.html#building-the-jar">built</a> and <a href="java-intro.html#linking-the-jar">properly linked</a> with your own project then the Ghostscript API should be available by importing the required classes within your project's <code>.java</code> files.</p>
+<h3 id="gsapi-gsinstance">GSAPI &amp; GSInstance</h3>
+<ul>
+<li><a href="#gsapi">GSAPI</a> is the main Ghostscript API class which bridges into the Ghostscript C library.</li>
+<li><a href="#gsinstance">GSInstance</a> is a wrapper class for <a href="#gsapi">GSAPI</a> which encapsulates an instance of Ghostscript and allows for simpler API calls.</li>
+</ul>
+<div class="tag sampleCode java"></div>
+
+
+<pre><code class="language-clike">// to use GSAPI
+import static com.artifex.gsjava.GSAPI.*;
+
+// to use GSInstance
+import com.artifex.gsjava.GSInstance;</code></pre>
+<h2 id="gsapi">GSAPI</h2>
+<h3 id="gsapi_revision">gsapi_revision</h3>
+<p>This method returns the revision numbers and strings of the Ghostscript interpreter library; you should call it before any other interpreter library functions to make sure that the correct version of the Ghostscript interpreter has been loaded.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_revision(GSAPI.Revision revision,
+ int len);</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>The method should write to a reference variable which conforms to the class <a href="#gsapi-revision">GSAPI.Revision</a>.</p>
+</blockquote>
+<h4 id="gsapi-revision">GSAPI.Revision</h4>
+<p>This class is used to store information about Ghostscript and provides handy getters for the product and the copyright information.</p>
+<div class="tag classDefinition java"></div>
+
+<pre><code class="language-clike">public static class Revision {
+ public volatile byte[] product;
+ public volatile byte[] copyright;
+ public volatile long revision;
+ public volatile long revisionDate;
+
+ public Revision() {
+ this.product = null;
+ this.copyright = null;
+ this.revision = 0L;
+ this.revisionDate = 0L;
+ }
+
+ /**
+ * Returns the product information as a String.
+ *
+ * @return The product information.
+ */
+ public String getProduct() {
+ return new String(product);
+ }
+
+ /**
+ * Returns the copyright information as a String.
+ *
+ * @return The copyright information.
+ */
+ public String getCopyright() {
+ return new String(copyright);
+ }
+}</code></pre>
+<h3 id="gsapi_new_instance">gsapi_new_instance</h3>
+<p>Creates a new instance of Ghostscript. This instance is passed to most other <a href="#gsapi">GSAPI</a> methods. Unless Ghostscript has been compiled with the <code>GS_THREADSAFE</code> define, only one instance at a time is supported.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_new_instance(Reference&lt;Long&gt; instance,
+ long callerHandle);</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>The method returns a reference which represents your instance of Ghostscript.</p>
+</blockquote>
+<h3 id="gsapi_delete_instance">gsapi_delete_instance</h3>
+<p>Destroy an instance of Ghostscript. Before you call this, Ghostscript must have finished. If Ghostscript has been initialised, you should call <a href="#gsapi_exit">gsapi_exit</a> beforehand.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native void gsapi_delete_instance(long instance);</code></pre>
+<h3 id="gsapi_set_stdio_with_handle">gsapi_set_stdio_with_handle</h3>
+<p>Set the callback functions for <code>stdio</code>, together with the handle to use in the callback functions. The <code>stdin</code> callback function should return the number of characters read, 0 for EOF, or -1 for error. The <code>stdout</code> and <code>stderr</code> callback functions should return the number of characters written.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_set_stdio_with_handle(long instance,
+ IStdInFunction stdin,
+ IStdOutFunction stdout,
+ IStdErrFunction stderr,
+ long callerHandle);</code></pre>
+<h3 id="gsapi_set_stdio">gsapi_set_stdio</h3>
+<p>Set the callback functions for <code>stdio</code>. The handle used in the callbacks will be taken from the value passed to <a href="#gsapi_new_instance">gsapi_new_instance</a>. Otherwise the behaviour of this function matches <a href="#gsapi_set_stdio_with_handle">gsapi_set_stdio_with_handle</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_set_stdio(long instance,
+ IStdInFunction stdin,
+ IStdOutFunction stdout,
+ IStdErrFunction stderr);</code></pre>
+<h3 id="gsapi_set_poll_with_handle">gsapi_set_poll_with_handle</h3>
+<p>Set the callback function for polling, together with the handle to pass to the callback function. This function will only be called if the Ghostscript interpreter was compiled with <code>CHECK_INTERRUPTS</code> as described in <code>gpcheck.h</code>.</p>
+<p>The polling function should return zero if all is well, and return negative if it wants ghostscript to abort. This is often used for checking for a user cancel. This can also be used for handling window events or cooperative multitasking.</p>
+<p>The polling function is called very frequently during interpretation and rendering so it must be fast. If the function is slow, then using a counter to <code>return 0</code> immediately some number of times can be used to reduce the performance impact.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_set_poll_with_handle(long instance,
+ IPollFunction pollfun,
+ long callerHandle);</code></pre>
+<h3 id="gsapi_set_poll">gsapi_set_poll</h3>
+<p>Set the callback function for polling. The handle passed to the callback function will be taken from the handle passed to <a href="#gsapi_new_instance">gsapi_new_instance</a>. Otherwise the behaviour of this function matches <a href="#gsapi_set_poll_with_handle">gsapi_set_poll_with_handle</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_set_poll(long instance,
+ IPollFunction pollfun);</code></pre>
+<h3 id="gsapi_set_display_callback">gsapi_set_display_callback</h3>
+<p>This call is deprecated; please use <a href="#gsapi_register_callout">gsapi_register_callout</a> to register a <a href="#callback-callout-interfaces">callout handler</a> for the display device in preference.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_set_display_callback(long instance,
+ DisplayCallback displayCallback);</code></pre>
+<h3 id="gsapi_register_callout">gsapi_register_callout</h3>
+<p>This call registers a <a href="#callback-callout-interfaces">callout handler</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_register_callout(long instance,
+ ICalloutFunction callout,
+ long calloutHandle);</code></pre>
+<h3 id="gsapi_deregister_callout">gsapi_deregister_callout</h3>
+<p>This call deregisters a <a href="#callback-callout-interfaces">callout handler</a> previously registered with <a href="#gsapi_register_callout">gsapi_register_callout</a>. All three arguments must match exactly for the <a href="#callback-callout-interfaces">callout handler</a> to be deregistered.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native void gsapi_deregister_callout(long instance,
+ ICalloutFunction callout,
+ long calloutHandle);</code></pre>
+<h3 id="gsapi_set_arg_encoding">gsapi_set_arg_encoding</h3>
+<p>Set the encoding used for the interpretation of all subsequent arguments supplied via the <code>GSAPI</code> interface on this instance. By default we expect args to be in encoding <code>0</code> (the 'local' encoding for this OS). On Windows this means "the currently selected codepage". This means that omitting to call this function will leave Ghostscript running exactly as it always has. Please note that use of the 'local' encoding is now deprecated and should be avoided in new code. This must be called after <a href="#gsapi_new_instance">gsapi_new_instance</a> and before <a href="#gsapi_init_with_args">gsapi_init_with_args</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_set_arg_encoding(long instance,
+ int encoding);</code></pre>
+<h3 id="gsapi_set_default_device_list">gsapi_set_default_device_list</h3>
+<p>Set the string containing the list of default device names, for example "display x11alpha x11 bbox". Allows the calling application to influence which device(s) Ghostscript will try, in order, in its selection of the default device. This must be called after <a href="#gsapi_new_instance">gsapi_new_instance</a> and before <a href="#gsapi_init_with_args">gsapi_init_with_args</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_set_default_device_list(long instance,
+ byte[] list,
+ int listlen);</code></pre>
+<h3 id="gsapi_get_default_device_list">gsapi_get_default_device_list</h3>
+<p>Returns a pointer to the current default device string. This must be called after <a href="#gsapi_new_instance">gsapi_new_instance</a> and before <a href="#gsapi_init_with_args">gsapi_init_with_args</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_get_default_device_list(long instance,
+ Reference&lt;byte[]&gt; list,
+ Reference&lt;Integer&gt; listlen);</code></pre>
+<h3 id="gsapi_init_with_args">gsapi_init_with_args</h3>
+<p>To initialise the interpreter, pass your <code>instance</code> of Ghostscript, your argument count: <code>argc</code>, and your argument variables: <code>argv</code>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_init_with_args(long instance,
+ int argc,
+ byte[][] argv);</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>There are also simpler utility methods which eliminates the need to send through your argument count and allows for simpler <code>String</code> passing for your argument array.</p>
+</blockquote>
+<p>Utility methods:</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static int gsapi_init_with_args(long instance,
+ String[] argv);</code></pre>
+<pre><code class="language-clike">public static int gsapi_init_with_args(long instance,
+ List&lt;String&gt; argv);</code></pre>
+<h3 id="gsapi_run_-">gsapi_run_*</h3>
+<p>If these functions return <code>&lt;= -100</code>, either quit or a fatal error has occured. You must call <a href="#gsapi_exit">gsapi_exit</a> next. The only exception is <a href="#gsapi_run_string_continue">gsapi_run_string_continue</a> which will return <code>gs_error_NeedInput</code> if all is well.</p>
+<p>There is a 64 KB length limit on any buffer submitted to a <code>gsapi_run_*</code> function for processing. If you have more than 65535 bytes of input then you must split it into smaller pieces and submit each in a separate <a href="#gsapi_run_string_continue">gsapi_run_string_continue</a> call.</p>
+<h3 id="gsapi_run_string_begin">gsapi_run_string_begin</h3>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_run_string_begin(long instance,
+ int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<h3 id="gsapi_run_string_continue">gsapi_run_string_continue</h3>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_run_string_continue(long instance,
+ byte[] str,
+ int length,
+ int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>There is a simpler utility method which allows for simpler <code>String</code> passing for the <code>str</code> argument.</p>
+</blockquote>
+<p>Utility method:</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static int gsapi_run_string_continue(long instance,
+ String str,
+ int length,
+ int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<h3 id="gsapi_run_string_with_length">gsapi_run_string_with_length</h3>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_run_string_with_length(long instance,
+ byte[] str,
+ int length,
+ int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>There is a simpler utility method which allows for simpler <code>String</code> passing for the <code>str</code> argument.</p>
+</blockquote>
+<p>Utility method:</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static int gsapi_run_string_with_length(long instance,
+ String str,
+ int length,
+ int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<h3 id="gsapi_run_string">gsapi_run_string</h3>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_run_string(long instance,
+ byte[] str,
+ int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>There is a simpler utility method which allows for simpler <code>String</code> passing for the <code>str</code> argument.</p>
+</blockquote>
+<p>Utility method:</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static int gsapi_run_string(long instance,
+ String str,
+ int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<h3 id="gsapi_run_string_end">gsapi_run_string_end</h3>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_run_string_end(long instance,
+ int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<h3 id="gsapi_run_file">gsapi_run_file</h3>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_run_file(long instance,
+ byte[] fileName,
+ int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>There is a simpler utility method which allows for simpler <code>String</code> passing for the <code>fileName</code> argument.</p>
+</blockquote>
+<p>Utility method:</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static int gsapi_run_file(long instance,
+ String fileName,
+ int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<h3 id="gsapi_exit">gsapi_exit</h3>
+<p>Exit the interpreter. This must be called on shutdown if <a href="#gsapi_init_with_args">gsapi_init_with_args</a> has been called, and just before <a href="#gsapi_delete_instance">gsapi_delete_instance</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_exit(long instance);</code></pre>
+<h3 id="gsapi_set_param">gsapi_set_param</h3>
+<p>Sets a parameter. Broadly, this is equivalent to setting a parameter using -d, -s or -p on the command line. This call cannot be made during a <a href="#gsapi_run_string">gsapi_run_string</a> operation.</p>
+<p>Parameters in this context are not the same as 'arguments' as processed by <a href="#gsapi_init_with_args">gsapi_init_with_args</a>, but often the same thing can be achieved. For example, with <a href="#gsapi_init_with_args">gsapi_init_with_args</a>, we can pass "-r200" to change the resolution. Broadly the same thing can be achieved by using <a href="#gsapi_set_param">gsapi_set_param</a> to set a parsed value of "&lt;&lt;/HWResolution [ 200.0 200.0 ]&gt;&gt;".</p>
+<p>Internally, when we set a parameter, we perform an <code>initgraphics</code> operation. This means that using <a href="#gsapi_set_param">gsapi_set_param</a> other than at the start of a page is likely to give unexpected results.</p>
+<p>Attempting to set a parameter that the device does not recognise will be silently ignored, and that parameter will not be found in subsequent <a href="#gsapi_get_param">gsapi_get_param</a> calls.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_set_param(long instance,
+ byte[] param,
+ Object value,
+ int paramType);</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>The <code>type</code> argument, as a <a href="#gs_set_param_type">gs_set_param_type</a>, dictates the kind of object that the <code>value</code> argument points to.</p>
+</blockquote>
+<blockquote>
+<p><strong>NOTE</strong><br>For more on the C implementation of parameters see: <a href="https://www.ghostscript.com/doc/current/Use.htm#Parameters">Ghostscript parameters in C</a>.</p>
+</blockquote>
+<blockquote>
+<p><strong>NOTE</strong><br>There are also simpler utility methods which allows for simpler <code>String</code> passing for your arguments.</p>
+</blockquote>
+<p>Utility methods:</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static int gsapi_set_param(long instance,
+ String param,
+ String value,
+ int paramType);</code></pre>
+<pre><code class="language-clike">public static int gsapi_set_param(long instance,
+ String param,
+ Object value,
+ int paramType);</code></pre>
+<h3 id="gsapi_get_param">gsapi_get_param</h3>
+<p>Retrieve the current value of a parameter.</p>
+<p>If an error occurs, the return value is negative. Otherwise the return value is the number of bytes required for storage of the value. Call once with value <code>NULL</code> to get the number of bytes required, then call again with value pointing to at least the required number of bytes where the value will be copied out. Note that the caller is required to know the type of value in order to get it. For all types other than <a href="#gs_set_param_type">gs_spt_string</a>, <a href="#gs_set_param_type">gs_spt_name</a>, and <a href="#gs_set_param_type">gs_spt_parsed</a> knowing the type means you already know the size required.</p>
+<p>This call retrieves parameters/values that have made it to the device. Thus, any values set using <a href="#gs_set_param_type">gs_spt_more_to_come</a> without a following call omitting that flag will not be retrieved. Similarly, attempting to get a parameter before <a href="#gsapi_init_with_args">gsapi_init_with_args</a> has been called will not list any, even if <a href="#gsapi_set_param">gsapi_set_param</a> has been used.</p>
+<p>Attempting to read a parameter that is not set will return <code>gs_error_undefined</code> (-21). Note that calling <a href="#gsapi_set_param">gsapi_set_param</a> followed by <a href="#gsapi_get_param">gsapi_get_param</a> may not find the value, if the device did not recognise the key as being one of its configuration keys.</p>
+<p>For the C documentation please refer to <a href="https://www.ghostscript.com/doc/current/API.htm#get_param">Ghostscript get_param</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_get_param(long instance,
+ byte[] param,
+ long value,
+ int paramType);</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>There is a simpler utility method which allows for simpler <code>String</code> passing for the <code>param</code> argument.</p>
+</blockquote>
+<p>Utility method:</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static int gsapi_get_param(long instance,
+ String param,
+ long value,
+ int paramType);</code></pre>
+<h3 id="gsapi_enumerate_params">gsapi_enumerate_params</h3>
+<p>Enumerate the current parameters. Call repeatedly to list out the current parameters.</p>
+<p>The first call should have <code>iter</code> = NULL. Subsequent calls should pass the same pointer in so the iterator can be updated. Negative return codes indicate error, 0 success, and 1 indicates that there are no more keys to read. On success, key will be updated to point to a null terminated string with the key name that is guaranteed to be valid until the next call to <a href="#gsapi_enumerate_params">gsapi_enumerate_params</a>. If <code>type</code> is non NULL then the pointer <code>type</code> will be updated to have the <code>type</code> of the parameter.</p>
+<blockquote>
+<p><strong>NOTE</strong><br>Only one enumeration can happen at a time. Starting a second enumeration will reset the first.</p>
+</blockquote>
+<p>The enumeration only returns parameters/values that have made it to the device. Thus, any values set using the <a href="#gs_set_param_type">gs_spt_more_to_come</a> without a following call omitting that flag will not be retrieved. Similarly, attempting to enumerate parameters before <a href="#gsapi_init_with_args">gsapi_init_with_args</a> has been called will not list any, even if <a href="#gsapi_set_param">gsapi_set_param</a> has been used.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_enumerate_params(long instance,
+ Reference&lt;Long&gt; iter,
+ Reference&lt;byte[]&gt; key,
+ Reference&lt;Integer&gt; paramType);</code></pre>
+<h3 id="gsapi_add_control_path">gsapi_add_control_path</h3>
+<p>Add a (case sensitive) path to one of the lists of <a href="https://ghostscript.com/doc/current/Use.htm#Safer">permitted paths</a> for file access.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_add_control_path(long instance,
+ int type,
+ byte[] path);</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>There is a simpler utility method which allows for simpler <code>String</code> passing for the <code>path</code> argument.</p>
+</blockquote>
+<p>Utility method:</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static int gsapi_add_control_path(long instance,
+ int type,
+ String path);</code></pre>
+<h3 id="gsapi_remove_control_path">gsapi_remove_control_path</h3>
+<p>Remove a (case sensitive) path from one of the lists of <a href="https://ghostscript.com/doc/current/Use.htm#Safer">permitted paths</a> for file access.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native int gsapi_remove_control_path(long instance,
+ int type,
+ byte[] path);</code></pre>
+<blockquote>
+<p><strong>NOTE</strong><br>There is a simpler utility method which allows for simpler <code>String</code> passing for the <code>path</code> argument.</p>
+</blockquote>
+<p>Utility method:</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static int gsapi_remove_control_path(long instance,
+ int type,
+ String path);</code></pre>
+<h3 id="gsapi_purge_control_paths">gsapi_purge_control_paths</h3>
+<p>Clear all the paths from one of the lists of <a href="https://ghostscript.com/doc/current/Use.htm#Safer">permitted paths</a> for file access.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native void gsapi_purge_control_paths(long instance,
+ int type);</code></pre>
+<h3 id="gsapi_activate_path_control">gsapi_activate_path_control</h3>
+<p>Enable/Disable path control (i.e. whether paths are checked against <a href="https://ghostscript.com/doc/current/Use.htm#Safer">permitted paths</a> before access is granted).</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public static native void gsapi_activate_path_control(long instance,
+ boolean enable);</code></pre>
+<h3 id="gsapi_is_path_control_active">gsapi_is_path_control_active</h3>
+<p>Query whether path control is activated or not.</p>
+<div class="tag methodDefinition java"></div>
+
+
+<pre><code class="language-clike">public static native boolean gsapi_is_path_control_active(long instance);</code></pre>
+<h2 id="callback-callout-interfaces">Callback &amp; Callout interfaces</h2>
+<p><code>gsjava.jar</code> also defines some functional interfaces for callbacks &amp; callouts with <code>package com.artifex.gsjava.callback</code> which are defined as follows.</p>
+<h3 id="istdinfunction">IStdInFunction</h3>
+<div class="tag functionalInterface java"></div>
+
+<pre><code class="language-clike">public interface IStdInFunction {
+ /**
+ * @param callerHandle The caller handle.
+ * @param buf A string represented by a byte array.
+ * @param len The number of bytes to read.
+ * @return The number of bytes read, must be &lt;code&gt;len&lt;/code&gt;/
+ */
+ public int onStdIn(long callerHandle,
+ byte[] buf,
+ int len);
+}</code></pre>
+<h3 id="istdoutfunction">IStdOutFunction</h3>
+<div class="tag functionalInterface java"></div>
+
+<pre><code class="language-clike">public interface IStdOutFunction {
+ /**
+ * Called when something should be written to the standard
+ * output stream.
+ *
+ * @param callerHandle The caller handle.
+ * @param str The string represented by a byte array to write.
+ * @param len The number of bytes to write.
+ * @return The number of bytes written, must be &lt;code&gt;len&lt;/code&gt;.
+ */
+ public int onStdOut(long callerHandle,
+ byte[] str,
+ int len);
+}</code></pre>
+<h3 id="istderrfunction">IStdErrFunction</h3>
+<div class="tag functionalInterface java"></div>
+
+<pre><code class="language-clike">public interface IStdErrFunction {
+ /**
+ * Called when something should be written to the standard error stream.
+ *
+ * @param callerHandle The caller handle.
+ * @param str The string represented by a byte array to write.
+ * @param len The length of bytes to be written.
+ * @return The amount of bytes written, must be &lt;code&gt;len&lt;/code&gt;.
+ */
+ public int onStdErr(long callerHandle,
+ byte[] str,
+ int len);
+}</code></pre>
+<h3 id="ipollfunction">IPollFunction</h3>
+<div class="tag functionalInterface java"></div>
+
+<pre><code class="language-clike">public interface IPollFunction {
+ public int onPoll(long callerHandle);
+}</code></pre>
+<h3 id="icalloutfunction">ICalloutFunction</h3>
+<div class="tag functionalInterface java"></div>
+
+<pre><code class="language-clike">public interface ICalloutFunction {
+ public int onCallout(long instance,
+ long calloutHandle,
+ byte[] deviceName,
+ int id,
+ int size,
+ long data);
+}</code></pre>
+<h2 id="gsinstance">GSInstance</h2>
+<p>This is a utility class which makes Ghostscript calls easier by storing a Ghostscript instance and, optionally, a caller handle. Essentially the class acts as a handy wrapper for the standard <a href="#gsapi">GSAPI</a> methods.</p>
+<h3 id="constructors">Constructors</h3>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public GSInstance() throws IllegalStateException;</code></pre>
+<pre><code class="language-clike">public GSInstance(long callerHandle) throws IllegalStateException;</code></pre>
+<h3 id="delete_instance">delete_instance</h3>
+<p>Wraps <a href="#gsapi_delete_instance">gsapi_delete_instance</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public void delete_instance();</code></pre>
+<h3 id="set_stdio">set_stdio</h3>
+<p>Wraps <a href="#gsapi_set_stdio">gsapi_set_stdio</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int set_stdio(IStdInFunction stdin,
+ IStdOutFunction stdout,
+ IStdErrFunction stderr);</code></pre>
+<h3 id="set_poll">set_poll</h3>
+<p>Wraps <a href="#gsapi_set_poll">gsapi_set_poll</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int set_poll(IPollFunction pollfun);</code></pre>
+<h3 id="set_display_callback">set_display_callback</h3>
+<p>Wraps <a href="#gsapi_set_display_callback">gsapi_set_display_callback</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int set_display_callback(DisplayCallback displaycallback);</code></pre>
+<h3 id="register_callout">register_callout</h3>
+<p>Wraps <a href="#gsapi_register_callout">gsapi_register_callout</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int register_callout(ICalloutFunction callout);</code></pre>
+<h3 id="deregister_callout">deregister_callout</h3>
+<p>Wraps <a href="#gsapi_deregister_callout">gsapi_deregister_callout</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public void deregister_callout(ICalloutFunction callout);</code></pre>
+<h3 id="set_arg_encoding">set_arg_encoding</h3>
+<p>Wraps <a href="#gsapi_set_arg_encoding">gsapi_set_arg_encoding</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int set_arg_encoding(int encoding);</code></pre>
+<h3 id="set_default_device_list">set_default_device_list</h3>
+<p>Wraps <a href="#gsapi_set_default_device_list">gsapi_set_default_device_list</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int set_default_device_list(byte[] list,
+ int listlen);</code></pre>
+<h3 id="get_default_device_list">get_default_device_list</h3>
+<p>Wraps <a href="#gsapi_get_default_device_list">gsapi_get_default_device_list</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int get_default_device_list(Reference&lt;byte[]&gt; list,
+ Reference&lt;Integer&gt; listlen);</code></pre>
+<h3 id="init_with_args">init_with_args</h3>
+<p>Wraps <a href="#gsapi_init_with_args">gsapi_init_with_args</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int init_with_args(int argc,
+ byte[][] argv);</code></pre>
+<pre><code class="language-clike">public int init_with_args(String[] argv);</code></pre>
+<pre><code class="language-clike">public int init_with_args(List&lt;String&gt; argv);</code></pre>
+<h3 id="run_string_begin">run_string_begin</h3>
+<p>Wraps <a href="#gsapi_run_string_begin">gsapi_run_string_begin</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int run_string_begin(int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<h3 id="run_string_continue">run_string_continue</h3>
+<p>Wraps <a href="#gsapi_run_string_continue">gsapi_run_string_continue</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int run_string_continue(byte[] str,
+ int length,
+ int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<pre><code class="language-clike">public int run_string_continue(String str,
+ int length,
+ int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<h3 id="run_string">run_string</h3>
+<p>Wraps <a href="#gsapi_run_string">gsapi_run_string</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int run_string(byte[] str,
+ int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<pre><code class="language-clike">public int run_string(String str,
+ int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<h3 id="run_file">run_file</h3>
+<p>Wraps <a href="#gsapi_run_file">gsapi_run_file</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int run_file(byte[] fileName,
+ int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<pre><code class="language-clike">public int run_file(String filename,
+ int userErrors,
+ Reference&lt;Integer&gt; pExitCode);</code></pre>
+<h3 id="exit">exit</h3>
+<p>Wraps <a href="#gsapi_exit">gsapi_exit</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int exit();</code></pre>
+<h3 id="set_param">set_param</h3>
+<p>Wraps <a href="#gsapi_set_param">gsapi_set_param</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int set_param(byte[] param,
+ Object value,
+ int paramType);</code></pre>
+<pre><code class="language-clike">public int set_param(String param,
+ String value,
+ int paramType);</code></pre>
+<pre><code class="language-clike">public int set_param(String param,
+ Object value,
+ int paramType);</code></pre>
+<h3 id="get_param">get_param</h3>
+<p>Wraps <a href="#gsapi_get_param">gsapi_get_param</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int get_param(byte[] param,
+ long value,
+ int paramType);</code></pre>
+<pre><code class="language-clike">public int get_param(String param,
+ long value,
+ int paramType);</code></pre>
+<h3 id="enumerate_params">enumerate_params</h3>
+<p>Wraps <a href="#gsapi_enumerate_params">gsapi_enumerate_params</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int enumerate_params(Reference&lt;Long&gt; iter,
+ Reference&lt;byte[]&gt; key,
+ Reference&lt;Integer&gt; paramType);</code></pre>
+<h3 id="add_control_path">add_control_path</h3>
+<p>Wraps <a href="#gsapi_add_control_path">gsapi_add_control_path</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int add_control_path(int type,
+ byte[] path);</code></pre>
+<pre><code class="language-clike">public int add_control_path(int type,
+ String path);</code></pre>
+<h3 id="remove_control_path">remove_control_path</h3>
+<p>Wraps <a href="#gsapi_remove_control_path">gsapi_remove_control_path</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public int remove_control_path(int type,
+ byte[] path);</code></pre>
+<pre><code class="language-clike">public int remove_control_path(int type,
+ String path);</code></pre>
+<h3 id="purge_control_paths">purge_control_paths</h3>
+<p>Wraps <a href="#gsapi_purge_control_paths">gsapi_purge_control_paths</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public void purge_control_paths(int type);</code></pre>
+<h3 id="activate_path_control">activate_path_control</h3>
+<p>Wraps <a href="#gsapi_activate_path_control">gsapi_activate_path_control</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public void activate_path_control(boolean enable);</code></pre>
+<h3 id="is_path_control_active">is_path_control_active</h3>
+<p>Wraps <a href="#gsapi_is_path_control_active">gsapi_is_path_control_active</a>.</p>
+<div class="tag methodDefinition java"></div>
+
+<pre><code class="language-clike">public boolean is_path_control_active();</code></pre>
+<h2 id="utility-classes">Utility classes</h2>
+<p>The com.artifex.gsjava.util package contains a set of classes and interfaces which are used throughout the API.</p>
+<h3 id="com-artifex-gsjava-util-reference">com.artifex.gsjava.util.Reference</h3>
+<p><code>Reference&lt;T&gt;</code> is used in many of the Ghostscript calls, it stores a reference to a generic value of type <code>T</code>. This class exists to emulate pointers being passed to a native function. Its value can be fetched with <code>getValue()</code> and set with <code>setValue(T value)</code>.</p>
+<div class="tag classDefinition java"></div>
+
+<pre><code class="language-clike">public class Reference&lt;T&gt; {
+
+ private volatile T value;
+
+ public Reference() {
+ this(null);
+ }
+
+ public Reference(T value) {
+ this.value = value;
+ }
+
+ public void setValue(T value) {
+ this.value = value;
+ }
+
+ public T getValue() {
+ return value;
+ }
+ ...
+}</code></pre>
+</article>
+
+ </div> <!-- /middle -->
+
+ <div class="right">
+
+ <div class="link"><a href="#about">About</a></div>
+ <div class="sub-link"><a href="#gsapi-gsinstance">GSAPI & GSInstance</a></div>
+ <div class="link"><a href="#gsapi">GSAPI</a></div>
+ <div class="sub-link"><a href="#gsapi_revision">gsapi_revision</a></div>
+ <div class="sub-link"><a href="#gsapi_new_instance">gsapi_new_instance</a></div>
+ <div class="sub-link"><a href="#gsapi_delete_instance">gsapi_delete_instance</a></div>
+ <div class="sub-link"><a href="#gsapi_set_stdio_with_handle">gsapi_set_stdio_with_handle</a></div>
+ <div class="sub-link"><a href="#gsapi_set_stdio">gsapi_set_stdio</a></div>
+ <div class="sub-link"><a href="#gsapi_set_poll_with_handle">gsapi_set_poll_with_handle</a></div>
+ <div class="sub-link"><a href="#gsapi_set_poll">gsapi_set_poll</a></div>
+ <div class="sub-link"><a href="#gsapi_set_display_callback">gsapi_set_display_callback</a></div>
+ <div class="sub-link"><a href="#gsapi_register_callout">gsapi_register_callout</a></div>
+ <div class="sub-link"><a href="#gsapi_deregister_callout">gsapi_deregister_callout</a></div>
+ <div class="sub-link"><a href="#gsapi_set_arg_encoding">gsapi_set_arg_encoding</a></div>
+ <div class="sub-link"><a href="#gsapi_set_default_device_list">gsapi_set_default_device_list</a></div>
+ <div class="sub-link"><a href="#gsapi_get_default_device_list">gsapi_get_default_device_list</a></div>
+ <div class="sub-link"><a href="#gsapi_init_with_args">gsapi_init_with_args</a></div>
+ <div class="sub-link"><a href="#gsapi_run_-">gsapi_run_*</a></div>
+ <div class="sub-link"><a href="#gsapi_run_string_begin">gsapi_run_string_begin</a></div>
+ <div class="sub-link"><a href="#gsapi_run_string_continue">gsapi_run_string_continue</a></div>
+ <div class="sub-link"><a href="#gsapi_run_string_with_length">gsapi_run_string_with_length</a></div>
+ <div class="sub-link"><a href="#gsapi_run_string">gsapi_run_string</a></div>
+ <div class="sub-link"><a href="#gsapi_run_string_end">gsapi_run_string_end</a></div>
+ <div class="sub-link"><a href="#gsapi_run_file">gsapi_run_file</a></div>
+ <div class="sub-link"><a href="#gsapi_exit">gsapi_exit</a></div>
+ <div class="sub-link"><a href="#gsapi_set_param">gsapi_set_param</a></div>
+ <div class="sub-link"><a href="#gsapi_get_param">gsapi_get_param</a></div>
+ <div class="sub-link"><a href="#gsapi_enumerate_params">gsapi_enumerate_params</a></div>
+ <div class="sub-link"><a href="#gsapi_add_control_path">gsapi_add_control_path</a></div>
+ <div class="sub-link"><a href="#gsapi_remove_control_path">gsapi_remove_control_path</a></div>
+ <div class="sub-link"><a href="#gsapi_purge_control_paths">gsapi_purge_control_paths</a></div>
+ <div class="sub-link"><a href="#gsapi_activate_path_control">gsapi_activate_path_control</a></div>
+ <div class="sub-link"><a href="#gsapi_is_path_control_active">gsapi_is_path_control_active</a></div>
+ <div class="link"><a href="#callback-callout-interfaces">Callback & Callout interfaces</a></div>
+ <div class="sub-link"><a href="#istdinfunction">IStdInFunction</a></div>
+ <div class="sub-link"><a href="#istdoutfunction">IStdOutFunction</a></div>
+ <div class="sub-link"><a href="#istderrfunction">IStdErrFunction</a></div>
+ <div class="sub-link"><a href="#ipollfunction">IPollFunction</a></div>
+ <div class="sub-link"><a href="#icalloutfunction">ICalloutFunction</a></div>
+ <div class="link"><a href="#gsinstance">GSInstance</a></div>
+ <div class="sub-link"><a href="#constructors">Constructors</a></div>
+ <div class="sub-link"><a href="#delete_instance">delete_instance</a></div>
+ <div class="sub-link"><a href="#set_stdio">set_stdio</a></div>
+ <div class="sub-link"><a href="#set_poll">set_poll</a></div>
+ <div class="sub-link"><a href="#set_display_callback">set_display_callback</a></div>
+ <div class="sub-link"><a href="#register_callout">register_callout</a></div>
+ <div class="sub-link"><a href="#deregister_callout">deregister_callout</a></div>
+ <div class="sub-link"><a href="#set_arg_encoding">set_arg_encoding</a></div>
+ <div class="sub-link"><a href="#set_default_device_list">set_default_device_list</a></div>
+ <div class="sub-link"><a href="#get_default_device_list">get_default_device_list</a></div>
+ <div class="sub-link"><a href="#init_with_args">init_with_args</a></div>
+ <div class="sub-link"><a href="#run_string_begin">run_string_begin</a></div>
+ <div class="sub-link"><a href="#run_string_continue">run_string_continue</a></div>
+ <div class="sub-link"><a href="#run_string">run_string</a></div>
+ <div class="sub-link"><a href="#run_file">run_file</a></div>
+ <div class="sub-link"><a href="#exit">exit</a></div>
+ <div class="sub-link"><a href="#set_param">set_param</a></div>
+ <div class="sub-link"><a href="#get_param">get_param</a></div>
+ <div class="sub-link"><a href="#enumerate_params">enumerate_params</a></div>
+ <div class="sub-link"><a href="#add_control_path">add_control_path</a></div>
+ <div class="sub-link"><a href="#remove_control_path">remove_control_path</a></div>
+ <div class="sub-link"><a href="#purge_control_paths">purge_control_paths</a></div>
+ <div class="sub-link"><a href="#activate_path_control">activate_path_control</a></div>
+ <div class="sub-link"><a href="#is_path_control_active">is_path_control_active</a></div>
+ <div class="link"><a href="#utility-classes">Utility classes</a></div>
+ <div class="sub-link"><a href="#com-artifex-gsjava-util-reference">com.artifex.gsjava.util.Reference</a></div>
+
+ </div>
+
+ </div>
+
+ <footer></footer>
+
+ </body>
+
+</html>
diff --git a/doc/language-bindings/java-intro.html b/doc/language-bindings/java-intro.html
new file mode 100644
index 00000000..21098521
--- /dev/null
+++ b/doc/language-bindings/java-intro.html
@@ -0,0 +1,260 @@
+<html lang="en">
+ <head>
+ <title>Ghostscript language bindings</title>
+ <meta http-equiv="content-type" content="text/html; charset=utf-8">
+ <meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width">
+ <link href="https://fonts.googleapis.com/css?family=Source+Sans+Pro:200,200i,300,300i,400,400i,600,600i,700,700i,900,900i" rel="stylesheet">
+ <link rel="shortcut icon" type="image/png" href="../images/favicon.png">
+ <link href="css/default.css" rel="stylesheet" type="text/css" />
+ <script type="text/javascript" src="js/default.js"></script>
+ </head>
+
+ <body>
+
+ <header><h1></h1><div class="menu-icon" onclick="javascript:showMenu();"></div></header>
+
+ <div id="burger-menu">
+ <div class="navigation">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link selected"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+ </div>
+ <div class="main">
+
+ <div class="left">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link selected"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+
+ <div class="middle">
+
+<!-- note: don't tab indent <article> as it has <pre> code which will have its layout adversly affected -->
+<article class="markdown-body entry-content"><h1 id="java-overview">Java overview</h1>
+<div class="banner">
+<div class="java-text"></div>
+<div class="vendor-logo java-logo"></div>
+</div>
+
+<h2 id="about">About</h2>
+<p>In the <a href="https://github.com/ArtifexSoftware/ghostpdl">GhostPDL repository</a> sample <code>Java</code> projects can be found in <code>/demos/java</code>.</p>
+<p>Within this location the following folders are of relevance:</p>
+<ul>
+<li><a href="#jni-building-the-java-native-interface">jni</a> <code>jni</code></li>
+<li><a href="#gsjava-building-the-jar">gsjava</a> <code>gsjava</code></li>
+<li><a href="#gstest">gstest</a> <code>gstest</code></li>
+<li><a href="#gsviewer">gsviewer</a> <code>gsviewer</code></li>
+</ul>
+<h2 id="platform-setup">Platform &amp; setup</h2>
+<h3 id="building-ghostscript">Building Ghostscript</h3>
+<p>Ghostscript should be built as a shared library for your platform.</p>
+<p>See <a href="index.html#building-ghostscript">Building Ghostscript</a>.</p>
+<h3 id="jni-building-the-java-native-interface">jni: Building the Java Native Interface</h3>
+<p>Before building the JNI ensure that Ghostscript has already been built for your platform and that you have JDK installed.</p>
+<p>The JNI is for use in the Java interface,
+this object must be placed somewhere on your Java PATH. On Windows, the DLL
+can be placed in the working directory, next to <code>gsjava.jar</code>.</p>
+<table>
+<thead>
+<tr>
+<th>Platform</th>
+<th>JNI file</th>
+</tr>
+</thead>
+<tbody><tr>
+<td>Windows</td>
+<td><code>gs_jni.dll</code></td>
+</tr>
+<tr>
+<td>MacOS</td>
+<td><code>gs_jni.dylib</code></td>
+</tr>
+<tr>
+<td>Linux / OpenBSD</td>
+<td><code>gs_jni.so</code></td>
+</tr>
+</tbody></table>
+<h4 id="preparing-your-include-folder">Preparing your include folder</h4>
+<p>The build scripts require the header <code>jni.h</code>, which defines
+all JNI functions, and <code>jni_md.h</code>, which defines all system-specific
+integer types. The build scripts expect an include folder relative to their location which contain these header files from your system.</p>
+<p>These headers are typically found in the following directories:</p>
+<table>
+<thead>
+<tr>
+<th>Platform</th>
+<th>jni.h</th>
+<th>jni_md.h</th>
+</tr>
+</thead>
+<tbody><tr>
+<td>Windows</td>
+<td><code>C:\Program Files\Java\&lt;JDK Install&gt;\include\jni.h</code></td>
+<td><code>C:\Program Files\Java\&lt;JDK Install&gt;\include\win32\jni_md.h</code></td>
+</tr>
+<tr>
+<td>MacOS</td>
+<td><code>/Library/Java/JavaVirtualMachines/&lt;JDK Install&gt;/Contents/Home/include/jni.h</code></td>
+<td><code>/Library/Java/JavaVirtualMachines/&lt;JDK Install&gt;/Contents/Home/include/darwin/jni_md.h</code></td>
+</tr>
+<tr>
+<td>Linux</td>
+<td><code>/lib/jvm/&lt;JDK Install&gt;/include/jni.h</code></td>
+<td><code>/lib/jvm/&lt;JDK Install&gt;/include/linux/jni_md.h</code></td>
+</tr>
+</tbody></table>
+<p>Once your <code>include</code> folder has been located folder you can copy it and place it in your <code>ghostpdl/demos/java/jni/gs_jni</code> folder.</p>
+<p>Your build scripts should now be ready to run as they will be able to find the required JNI header files in their own relative include folder.</p>
+<h4 id="building-on-windows">Building on Windows</h4>
+<p>The <code>jni</code> folder contains a Visual Studio Solution file <code>/jni/gs_jni/gs_jni.sln</code> which you should use to build the required JNI <code>gs_jni.dll</code> library file.</p>
+<p>With the project open in Visual Studio, select the required architecture from the drop down - then right click on 'gs_jni' in the solution explorer and choose "Build".</p>
+<h4 id="building-on-macos">Building on MacOS</h4>
+<p>On your command line, navigate to <code>ghostpdl/demos/java/jni/gs_jni</code> and ensure that the build script is executable and then run it, with:</p>
+<pre><code>chmod +x build_darwin.sh
+./build_darwin.sh</code></pre><h4 id="building-on-linux">Building on Linux</h4>
+<p>On your command line, navigate to <code>ghostpdl/demos/java/jni/gs_jni</code> and ensure that the build script is executable and then run it, with:</p>
+<pre><code>chmod +x build_linux.sh
+./build_linux.sh</code></pre><h3 id="gsjava-building-the-jar">gsjava: Building the JAR</h3>
+<h4 id="building-with-the-command-line">Building with the command line</h4>
+<p>Navigate to <code>ghostpdl/demos/java/gsjava</code> and use the following:</p>
+<table>
+<thead>
+<tr>
+<th>Platform</th>
+<th>Run file</th>
+</tr>
+</thead>
+<tbody><tr>
+<td>Windows</td>
+<td><code>build_win32.bat</code></td>
+</tr>
+<tr>
+<td>MacOS</td>
+<td><code>build_darwin.sh</code></td>
+</tr>
+<tr>
+<td>Linux</td>
+<td><code>build_linux.sh</code></td>
+</tr>
+</tbody></table>
+<blockquote>
+<p><strong>NOTE</strong><br>
+<code>gsjava</code> has a dependancy on <a href="#jni-building-the-java-native-interface">jni</a>, please ensure that <code>gs_jni</code> is able to be built beforehand.</p>
+</blockquote>
+<h4 id="building-with-eclipse">Building with Eclipse</h4>
+<p>Alternatively you can use <a href="https://www.eclipse.org/eclipseide/">Eclipse</a> to build the JAR file.</p>
+<p>Using <a href="https://www.eclipse.org/eclipseide/">Eclipse</a> import the source folder <code>gsjava</code> as a project and select <code>Export &gt; Java &gt; JAR File</code> as shown in the screenshot example below:</p>
+<p><img src="images/export-jar.png" alt="Eclipse export JAR"></p>
+<h4 id="linking-the-jar">Linking the JAR</h4>
+<p>The built JAR should be properly linked within your project Java Build Path as follows:</p>
+<p><img src="images/linking-jar.png" alt="Linking the JAR"></p>
+<h2 id="demo-projects">Demo projects</h2>
+<h3 id="gstest">gstest</h3>
+<p>This project can be opened in <a href="https://www.eclipse.org/eclipseide/">Eclipse</a> and used to test the Ghostscript API. The sample here simply sets up an instance of Ghostscript and then sets and gets some parameters accordingly.</p>
+<h3 id="gsviewer">gsviewer</h3>
+<p>This project can be used to test the Ghostscript API alongside a UI which handles opening PostScript and PDF files. The sample application here allows for file browsing and Ghostscript file viewing.</p>
+<p>Below is a screenshot of the sample application with a PDF open:</p>
+<p><img src="images/gsviewer.png" alt="gsviewer UI"></p>
+<p>To run the project navigate to the <code>demos/java/gsviewer</code> location and ensure that the required libraries are in the directory:</p>
+<table>
+<thead>
+<tr>
+<th>Platform</th>
+<th>Ghostscript library file</th>
+<th>JNI library file</th>
+</tr>
+</thead>
+<tbody><tr>
+<td>Windows</td>
+<td><code>gpdldll64.dll</code></td>
+<td><code>gs_jni.dll</code></td>
+</tr>
+<tr>
+<td>MacOS</td>
+<td><code>libgpdl.dylib</code></td>
+<td><code>gs_jni.dylib</code></td>
+</tr>
+<tr>
+<td>Linux / OpenBSD</td>
+<td><code>libgpdl.so</code> (this may have been built as <code>libgs.so</code>, so it should be copied into this directory and renamed to <code>libgpdl.so</code>)</td>
+<td><code>gs_jni.so</code></td>
+</tr>
+</tbody></table>
+<h4 id="building-on-windows">Building on Windows</h4>
+<p>Run the <code>build_win32.bat</code> script.</p>
+<h4 id="running-on-windows">Running on Windows</h4>
+<p>To run, open <code>gsviewer.jar</code> either through File Explorer or in the command line through the following command:</p>
+<pre><code>java -jar gsviewer.jar</code></pre><h4 id="building-on-macos">Building on MacOS</h4>
+<p>On your command line, navigate to <code>ghostpdl/demos/java/gsviewer</code> and ensure that the build script is executable and then run it, with:</p>
+<pre><code>chmod +x build_darwin.sh
+./build_darwin.sh</code></pre><p>This will automatically build <code>gs_jni.dylib</code> (in the <code>ghostpdl/demos/java/jni/gs_jni/</code> location) and <code>gsjava.jar</code> <code>gsviewer.jar</code> in the <code>gsviewer</code> directory.</p>
+<h4 id="running-on-macos">Running on MacOS</h4>
+<p>Ensure that the Ghostscript library exists in the <code>gsviewer</code> directory. (Copy and move the built library from <code>ghostpdl/sobin</code> as required).</p>
+<p>Ensure that the run script is executable and then run it, with:</p>
+<pre><code>chmod +x start_darwin.sh
+./start_darwin.sh</code></pre><h4 id="building-on-linux">Building on Linux</h4>
+<p>On your command line, navigate to <code>ghostpdl/demos/java/gsviewer</code> and ensure that the build script is executable and then run it, with:</p>
+<pre><code>chmod +x build_linux.sh
+./build_linux.sh</code></pre><p>This will automatically build <code>gs_jni.so</code> (in the <code>ghostpdl/demos/java/jni/gs_jni/</code> location) and <code>gsjava.jar</code> <code>gsviewer.jar</code> in the <code>gsviewer</code> directory.</p>
+<blockquote>
+<p><strong>NOTE</strong><br>
+On Linux, when using OpenJDK, the property "assistive_technologies" may
+need to be modified for the Java code to build. It can be modified by
+editing the "accessibility.properties" file. This is located at:</p>
+<p><code>/etc/java-8-openjdk/accessibility.properties</code></p>
+</blockquote>
+<h4 id="running-on-linux">Running on Linux</h4>
+<p>Ensure that the Ghostscript library exists in the <code>gsviewer</code> directory. (Copy and move the built library from <code>ghostpdl/sobin</code> as required).</p>
+<p>Ensure that the run script is executable and then run it, with:</p>
+<pre><code>chmod +x start_linux.sh
+./start_linux.sh</code></pre></article>
+
+ </div><!-- /middle -->
+
+ <div class="right">
+ <div class="link"><a href="#about">About</a></div>
+ <div class="link"><a href="#platform-setup">Platform & setup</a></div>
+ <div class="sub-link"><a href="#building-ghostscript">Building Ghostscript</a></div>
+ <div class="sub-link"><a href="#jni-building-the-java-native-interface">jni: Building the Java Native Interface</a></div>
+ <div class="sub-link"><a href="#gsjava-building-the-jar">gsjava: Building the JAR</a></div>
+ <div class="link"><a href="#demo-projects">Demo projects</a></div>
+ <div class="sub-link"><a href="#gstest">gstest</a></div>
+ <div class="sub-link"><a href="#gsviewer">gsviewer</a></div>
+ </div>
+
+ </div>
+
+ <footer></footer>
+
+ </body>
+
+</html>
diff --git a/doc/language-bindings/js/default.js b/doc/language-bindings/js/default.js
new file mode 100644
index 00000000..3ec04940
--- /dev/null
+++ b/doc/language-bindings/js/default.js
@@ -0,0 +1,53 @@
+var showingBurgerMenu = false;
+
+function showMenu() {
+ showingBurgerMenu = !showingBurgerMenu;
+
+ var mobileMenu = document.getElementById("burger-menu");
+
+ if (showingBurgerMenu) {
+ mobileMenu.classList.add("show");
+ } else {
+ mobileMenu.classList.remove("show");
+ }
+
+}
+
+function copyText(buttonDiv) {
+ for (var i=0;i<buttonDiv.parentNode.childNodes.length;i++) {
+
+ if (buttonDiv.parentNode.childNodes[i].tagName!=undefined) {
+ if (buttonDiv.parentNode.childNodes[i].tagName.toLowerCase()=="code") {
+ var codeBlock = buttonDiv.parentNode.childNodes[i];
+ var copyText = codeBlock.innerHTML;
+ const textArea = document.createElement('textarea');
+ textArea.textContent = copyText;
+ document.body.append(textArea);
+ textArea.select();
+ document.execCommand("copy");
+ }
+ }
+ }
+}
+
+function showCopyButton(preDiv) {
+ for (var i=0;i<preDiv.childNodes.length;i++) {
+
+ if (preDiv.childNodes[i].tagName!=undefined) {
+ if (preDiv.childNodes[i].tagName.toLowerCase()=="button") {
+ preDiv.childNodes[i].classList.add("show");
+ }
+ }
+ }
+}
+
+function hideCopyButton(preDiv) {
+ for (var i=0;i<preDiv.childNodes.length;i++) {
+
+ if (preDiv.childNodes[i].tagName!=undefined) {
+ if (preDiv.childNodes[i].tagName.toLowerCase()=="button") {
+ preDiv.childNodes[i].classList.remove("show");
+ }
+ }
+ }
+}
diff --git a/doc/language-bindings/md/c-sharp-ghost-api.md b/doc/language-bindings/md/c-sharp-ghost-api.md
new file mode 100644
index 00000000..e369cf3a
--- /dev/null
+++ b/doc/language-bindings/md/c-sharp-ghost-api.md
@@ -0,0 +1,603 @@
+# GhostAPI
+
+<div class="banner">
+ <div class="c-sharp-text"></div>
+ <div class="vendor-logo c-sharp-logo"></div>
+</div>
+
+
+## About
+
+`GhostAPI` is the `C#` bridge into the Ghostscript `C` library.
+
+`GhostAPI` contains some essential [structs and enums] as well as a static class for some [constants], finally it contains the main [GSAPI] class which holds the key methods which interface with the `C` library.
+
+## Structs and Enums
+
+
+### gsapi_revision_t
+
+This `struct` is used to contain information pertinent to the version of Ghostscript.
+
+<div class="tag structDefinition csharp"></div>
+
+```
+public struct gsapi_revision_t
+{
+ public IntPtr product;
+ public IntPtr copyright;
+ public int revision;
+ public int revisiondate;
+}
+```
+
+
+### gs_set_param_type
+
+
+<div class="tag enumDefinition csharp"></div>
+
+```
+public enum gs_set_param_type
+{
+ gs_spt_invalid = -1,
+ gs_spt_null = 0, /* void * is NULL */
+ gs_spt_bool = 1, /* void * is NULL (false) or non-NULL (true) */
+ gs_spt_int = 2, /* void * is a pointer to an int */
+ gs_spt_float = 3, /* void * is a float * */
+ gs_spt_name = 4, /* void * is a char * */
+ gs_spt_string = 5, /* void * is a char * */
+ gs_spt_long = 6, /* void * is a long * */
+ gs_spt_i64 = 7, /* void * is an int64_t * */
+ gs_spt_size_t = 8, /* void * is a size_t * */
+ gs_spt_parsed = 9, /* void * is a pointer to a char * to be parsed */
+ gs_spt_more_to_come = 1 << 31
+};
+```
+
+
+### gsEncoding
+
+
+<div class="tag enumDefinition csharp"></div>
+
+
+```
+public enum gsEncoding
+{
+ GS_ARG_ENCODING_LOCAL = 0,
+ GS_ARG_ENCODING_UTF8 = 1,
+ GS_ARG_ENCODING_UTF16LE = 2
+};
+```
+
+## Constants
+
+Constants are stored in the static class `gsConstants` for direct referencing.
+
+### gsConstants
+
+
+<div class="tag classDefinition csharp"></div>
+
+```
+static class gsConstants
+{
+ public const int E_QUIT = -101;
+ public const int GS_READ_BUFFER = 32768;
+ public const int DISPLAY_UNUSED_LAST = (1 << 7);
+ public const int DISPLAY_COLORS_RGB = (1 << 2);
+ public const int DISPLAY_DEPTH_8 = (1 << 11);
+ public const int DISPLAY_LITTLEENDIAN = (1 << 16);
+ public const int DISPLAY_BIGENDIAN = (0 << 16);
+}
+```
+
+## GSAPI
+
+Methods contained within are explained below.
+
+`gsapi_run_*` and `gsapi_exit` methods return an `int` code which can be interpreted as follows:
+
+| code | status |
+|---|---|
+|`0`| no error |
+|`gsConstants.E_QUIT`| "quit" has been executed. This is not an error. [gsapi_exit] must be called next |
+|`<0` | error |
+
+>**NOTE**<br>
+> For full detail on these return code please see:
+https://www.ghostscript.com/doc/current/API.htm#return_codes
+>
+
+> **NOTE**<br>
+> All [GSAPI] methods aside from [gsapi_revision] and [gsapi_new_instance] should pass an instance of Ghostscript as their first parameter with `IntPtr instance`
+>
+
+### gsapi_revision
+
+This method returns the revision numbers and strings of the Ghostscript interpreter library; you should call it before any other interpreter library functions to make sure that the correct version of the Ghostscript interpreter has been loaded.
+
+
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_revision(ref gsapi_revision_t vers,
+ int size);
+```
+
+
+> **NOTE**<br>
+> The method should write to a reference variable which conforms to the struct [gsapi_revision_t].
+>
+
+### gsapi_new_instance
+
+Creates a new instance of Ghostscript. This instance is passed to most other [GSAPI] methods. Unless Ghostscript has been compiled with the `GS_THREADSAFE` define, only one instance at a time is supported.
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_new_instance(out IntPtr pinstance,
+ IntPtr caller_handle);
+```
+
+
+> **NOTE**<br>
+> The method returns a pointer which represents your instance of Ghostscript.
+>
+
+### gsapi_delete_instance
+
+Destroy an instance of Ghostscript. Before you call this, Ghostscript must have finished. If Ghostscript has been initialised, you must call [gsapi_exit] beforehand.
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern void gsapi_delete_instance(IntPtr instance);
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+GSAPI.gsapi_delete_instance(gsInstance);
+gsInstance = IntPtr.Zero;
+```
+
+### gsapi_set_stdio_with_handle
+
+Set the callback functions for `stdio`, together with the handle to use in the callback functions. The `stdin` callback function should return the number of characters read, 0 for EOF, or -1 for error. The `stdout` and `stderr` callback functions should return the number of characters written.
+
+
+
+> **NOTE**<br>
+> These callbacks do not affect output device I/O when using "%stdout" as the output file. In that case, device output will still be directed to the process "stdout" file descriptor, not to the `stdio` callback.
+>
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_set_stdio_with_handle(IntPtr instance,
+ gs_stdio_handler stdin,
+ gs_stdio_handler stdout,
+ gs_stdio_handler stderr,
+ IntPtr caller_handle);
+```
+
+
+### gsapi_set_stdio
+
+Set the callback functions for `stdio`. The handle used in the callbacks will be taken from the value passed to [gsapi_new_instance]. Otherwise the behaviour of this function matches [gsapi_set_stdio_with_handle].
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_set_stdio_with_handle(IntPtr instance,
+ gs_stdio_handler stdin,
+ gs_stdio_handler stdout,
+ gs_stdio_handler stderr);
+```
+
+
+### gsapi_set_poll_with_handle
+
+Set the callback function for polling, together with the handle to pass to the callback function. This function will only be called if the Ghostscript interpreter was compiled with `CHECK_INTERRUPTS` as described in `gpcheck.h`.
+
+The polling function should return zero if all is well, and return negative if it wants ghostscript to abort. This is often used for checking for a user cancel. This can also be used for handling window events or cooperative multitasking.
+
+The polling function is called very frequently during interpretation and rendering so it must be fast. If the function is slow, then using a counter to `return 0` immediately some number of times can be used to reduce the performance impact.
+
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_set_poll_with_handle(IntPtr instance,
+ gsPollHandler pollfn,
+ IntPtr caller_handle);
+```
+
+### gsapi_set_poll
+
+Set the callback function for polling. The handle passed to the callback function will be taken from the handle passed to [gsapi_new_instance]. Otherwise the behaviour of this function matches [gsapi_set_poll_with_handle].
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_set_poll(IntPtr instance,
+ gsPollHandler pollfn);
+```
+
+
+### gsapi_set_display_callback
+
+This call is deprecated; please use [gsapi_register_callout] to register a [callout handler] for the display device in preference.
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_set_display_callback(IntPtr pinstance,
+ IntPtr caller_handle);
+```
+
+### gsapi_register_callout
+
+This call registers a [callout handler].
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_register_callout(IntPtr instance,
+ gsCallOut callout,
+ IntPtr callout_handle);
+```
+
+### gsapi_deregister_callout
+
+
+This call deregisters a [callout handler] previously registered with [gsapi_register_callout]. All three arguments must match exactly for the [callout handler] to be deregistered.
+
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_deregister_callout(IntPtr instance,
+ gsCallOut callout,
+ IntPtr callout_handle);
+```
+
+### gsapi_set_arg_encoding
+
+Set the encoding used for the interpretation of all subsequent arguments supplied via the `GhostAPI` interface on this instance. By default we expect args to be in encoding `0` (the 'local' encoding for this OS). On Windows this means "the currently selected codepage". On Linux this typically means `utf8`. This means that omitting to call this function will leave Ghostscript running exactly as it always has. Please note that use of the 'local' encoding is now deprecated and should be avoided in new code. This must be called after [gsapi_new_instance] and before [gsapi_init_with_args].
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_set_arg_encoding(IntPtr instance,
+ int encoding);
+```
+
+### gsapi_set_default_device_list
+
+Set the string containing the list of default device names, for example "display x11alpha x11 bbox". Allows the calling application to influence which device(s) Ghostscript will try, in order, in its selection of the default device. This must be called after [gsapi_new_instance] and before [gsapi_init_with_args].
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_set_default_device_list(IntPtr instance,
+ IntPtr list,
+ ref int listlen);
+```
+
+### gsapi_get_default_device_list
+
+Returns a pointer to the current default device string. This must be called after [gsapi_new_instance] and before [gsapi_init_with_args].
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_get_default_device_list(IntPtr instance,
+ ref IntPtr list,
+ ref int listlen);
+```
+
+### gsapi_init_with_args
+
+To initialise the interpreter, pass your `instance` of Ghostscript, your argument count, `argc`, and your argument variables, `argv`.
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_init_with_args(IntPtr instance,
+ int argc,
+ IntPtr argv);
+```
+
+### gsapi\_run\_\*
+
+If these functions return `<= -100`, either quit or a fatal error has occured. You must call [gsapi_exit] next. The only exception is [gsapi_run_string_continue] which will return `gs_error_NeedInput` if all is well.
+
+There is a 64 KB length limit on any buffer submitted to a `gsapi_run_*` function for processing. If you have more than 65535 bytes of input then you must split it into smaller pieces and submit each in a separate [gsapi_run_string_continue] call.
+
+### gsapi_run_string_begin
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_run_string_begin(IntPtr instance,
+ int usererr,
+ ref int exitcode);
+```
+
+### gsapi_run_string_continue
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_run_string_continue(IntPtr instance,
+ IntPtr command,
+ int count,
+ int usererr,
+ ref int exitcode);
+```
+
+### gsapi_run_string_with_length
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_run_string_with_length(IntPtr instance,
+ IntPtr command,
+ uint length,
+ int usererr,
+ ref int exitcode);
+```
+
+### gsapi_run_string
+
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_run_string(IntPtr instance,
+ IntPtr command,
+ int usererr,
+ ref int exitcode);
+```
+
+### gsapi_run_string_end
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_run_string_end(IntPtr instance,
+ int usererr,
+ ref int exitcode);
+```
+
+### gsapi_run_file
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_run_file(IntPtr instance,
+ IntPtr filename,
+ int usererr,
+ ref int exitcode);
+```
+
+### gsapi_exit
+
+Exit the interpreter. This must be called on shutdown if [gsapi_init_with_args] has been called, and just before [gsapi_delete_instance].
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_exit(IntPtr instance);
+```
+
+### gsapi_set_param
+
+Sets a parameter.
+
+Broadly, this is equivalent to setting a parameter using -d, -s or -p on the command line. This call cannot be made during a [gsapi_run_string] operation.
+
+Parameters in this context are not the same as 'arguments' as processed by [gsapi_init_with_args], but often the same thing can be achieved. For example, with [gsapi_init_with_args], we can pass "-r200" to change the resolution. Broadly the same thing can be achieved by using [gsapi_set_param] to set a parsed value of "<</HWResolution [ 200.0 200.0 ]>>".
+
+Internally, when we set a parameter, we perform an `initgraphics` operation. This means that using [gsapi_set_param] other than at the start of a page is likely to give unexpected results.
+
+Attempting to set a parameter that the device does not recognise will be silently ignored, and that parameter will not be found in subsequent [gsapi_get_param] calls.
+
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_set_param(IntPtr instance,
+ IntPtr param,
+ IntPtr value,
+ gs_set_param_type type);
+```
+
+
+> **NOTE**<br>
+> The `type` argument, as a [gs_set_param_type], dictates the kind of object that the `value` argument points to.
+>
+
+> **NOTE**<br>
+> For more on the C implementation of parameters see: [Ghostscript parameters in C].
+>
+
+### gsapi_get_param
+
+Retrieve the current value of a parameter.
+
+If an error occurs, the return value is negative. Otherwise the return value is the number of bytes required for storage of the value. Call once with value `NULL` to get the number of bytes required, then call again with value pointing to at least the required number of bytes where the value will be copied out. Note that the caller is required to know the type of value in order to get it. For all types other than [gs_spt_string], [gs_spt_name], and [gs_spt_parsed] knowing the type means you already know the size required.
+
+This call retrieves parameters/values that have made it to the device. Thus, any values set using [gs_spt_more_to_come] without a following call omitting that flag will not be retrieved. Similarly, attempting to get a parameter before [gsapi_init_with_args] has been called will not list any, even if [gsapi_set_param] has been used.
+
+Attempting to read a parameter that is not set will return `gs_error_undefined` (-21). Note that calling [gsapi_set_param] followed by [gsapi_get_param] may not find the value, if the device did not recognise the key as being one of its configuration keys.
+
+For the C documentation please refer to [Ghostscript get_param].
+
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_get_param(IntPtr instance,
+ IntPtr param,
+ IntPtr value,
+ gs_set_param_type type);
+```
+
+### gsapi_enumerate_params
+
+Enumerate the current parameters. Call repeatedly to list out the current parameters.
+
+The first call should have `iter` = NULL. Subsequent calls should pass the same pointer in so the iterator can be updated. Negative return codes indicate error, 0 success, and 1 indicates that there are no more keys to read. On success, key will be updated to point to a null terminated string with the key name that is guaranteed to be valid until the next call to [gsapi_enumerate_params]. If `type` is non NULL then the pointer `type` will be updated to have the `type` of the parameter.
+
+> **NOTE**<br>
+> Only one enumeration can happen at a time. Starting a second enumeration will reset the first.
+>
+
+The enumeration only returns parameters/values that have made it to the device. Thus, any values set using the [gs_spt_more_to_come] without a following call omitting that flag will not be retrieved. Similarly, attempting to enumerate parameters before [gsapi_init_with_args] has been called will not list any, even if [gsapi_set_param] has been used.
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_enumerate_params(IntPtr instance,
+ out IntPtr iter,
+ out IntPtr key,
+ IntPtr type);
+```
+
+### gsapi_add_control_path
+
+Add a (case sensitive) path to one of the lists of [permitted paths] for file access.
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_add_control_path(IntPtr instance,
+ int type,
+ IntPtr path);
+```
+
+### gsapi_remove_control_path
+
+Remove a (case sensitive) path from one of the lists of [permitted paths] for file access.
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern int gsapi_remove_control_path(IntPtr instance,
+ int type,
+ IntPtr path);
+```
+
+### gsapi_purge_control_paths
+
+Clear all the paths from one of the lists of [permitted paths] for file access.
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern void gsapi_purge_control_paths(IntPtr instance,
+ int type);
+```
+
+### gsapi_activate_path_control
+
+Enable/Disable path control (i.e. whether paths are checked against [permitted paths] before access is granted).
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public static extern void gsapi_activate_path_control(IntPtr instance,
+ int enable);
+```
+
+### gsapi_is_path_control_active
+
+
+Query whether path control is activated or not.
+
+<div class="tag methodDefinition csharp"></div>
+
+
+```
+public static extern int gsapi_is_path_control_active(IntPtr instance);
+```
+
+
+
+## Callback and Callout prototypes
+
+[GSAPI] also defines some prototype pointers which are defined as follows.
+
+### gs_stdio_handler
+
+<div class="tag callbackDefinition csharp"></div>
+
+```
+/* Callback proto for stdio */
+public delegate int gs_stdio_handler(IntPtr caller_handle,
+ IntPtr buffer,
+ int len);
+```
+
+
+### gsPollHandler
+
+<div class="tag callbackDefinition csharp"></div>
+
+```
+/* Callback proto for poll function */
+public delegate int gsPollHandler(IntPtr caller_handle);
+```
+
+
+### gsCallOut
+
+<div class="tag callbackDefinition csharp"></div>
+
+```
+/* Callout proto */
+public delegate int gsCallOut(IntPtr callout_handle,
+ IntPtr device_name,
+ int id,
+ int size,
+ IntPtr data);
+
+```
+
+
+[structs and enums]: #structs-and-enums
+[constants]: #constants
+[GSAPI]: #gsapi
+
+[Ghostscript parameters in C]: https://www.ghostscript.com/doc/current/Use.htm#Parameters
+[Ghostscript get_param]: https://www.ghostscript.com/doc/current/API.htm#get_param
+[gsapi_revision_t]: #gsapi_revision_t
+
+[gsapi_revision]: #gsapi_revision
+[gsapi_exit]: #gsapi_exit
+[gsapi_new_instance]: #gsapi_new_instance
+[gsapi_set_stdio_with_handle]: #gsapi_set_stdio_with_handle
+[gsapi_set_poll_with_handle]: #gsapi_set_poll_with_handle
+[gsapi_register_callout]: #gsapi_register_callout
+[gsapi_init_with_args]: #gsapi_init_with_args
+[gsapi_delete_instance]: #gsapi_delete_instance
+[gsapi_exit]: #gsapi_exit
+[gsapi_run_string]: #gsapi_run_string
+[gsapi_run_string_continue]: #gsapi_run_string_continue
+[gs_set_param_type]: #gs_set_param_type
+[gs_spt_more_to_come]: #gs_set_param_type
+[gs_spt_string]: #gs_set_param_type
+[gs_spt_name]: #gs_set_param_type
+[gs_spt_parsed]: #gs_set_param_type
+[gsapi_set_param]: #gsapi_set_param
+[gsapi_get_param]: #gsapi_get_param
+[gsapi_enumerate_params]: #gsapi_enumerate_params
+
+[permitted paths]: https://ghostscript.com/doc/current/Use.htm#Safer
+
+[callout handler]: #gscallout
diff --git a/doc/language-bindings/md/c-sharp-ghost-mono.md b/doc/language-bindings/md/c-sharp-ghost-mono.md
new file mode 100644
index 00000000..edc7925b
--- /dev/null
+++ b/doc/language-bindings/md/c-sharp-ghost-mono.md
@@ -0,0 +1,633 @@
+# GhostMono
+
+<div class="banner">
+ <div class="c-sharp-text"></div>
+ <div class="vendor-logo c-sharp-logo"></div>
+</div>
+
+
+## About
+
+`GhostMono` is the `C#` interface into the `GhostAPI` library developed for Linux systems.
+
+## Enums
+
+### Tasks
+
+The Ghostscript task type `enum` is used to inform `GhostAPI` of the type of operation which is being requested.
+
+
+| Task | Description |
+|---|---|
+|PS_DISTILL|Task associated with converting a PostScript stream to a PDF document|
+|CREATE_XPS|Task associated with outputting a copy of a document to XPS|
+|SAVE_RESULT|Task associated with saving documents|
+|GET_PAGE_COUNT|Task associated with getting the page count of a document|
+|GENERIC|Generic task identifier|
+|DISPLAY_DEV_THUMBS|Display Device task associated with rendering thumbnails|
+|DISPLAY_DEV_NON_PDF|Display Device task associated with non-PDF or non-XPS rendering <sup>[1]</sup>|
+|DISPLAY_DEV_PDF|Display Device task associated with PDF & XPS rendering <sup>[1]</sup>|
+|DISPLAY_DEV_RUN_FILE|Display Device task associated with running files|
+
+Task types are defined as `GS_Task_t`.
+
+<div class="tag enumDefinition csharp"></div>
+
+```
+public enum GS_Task_t
+{
+ PS_DISTILL,
+ CREATE_XPS,
+ SAVE_RESULT,
+ GET_PAGE_COUNT,
+ GENERIC,
+ DISPLAY_DEV_THUMBS,
+ DISPLAY_DEV_NON_PDF,
+ DISPLAY_DEV_PDF,
+ DISPLAY_DEV_RUN_FILE
+}
+```
+
+### Results
+
+Result types are defined as `GS_Result_t`.
+
+<div class="tag enumDefinition csharp"></div>
+
+```
+public enum GS_Result_t
+{
+ gsOK,
+ gsFAILED,
+ gsCANCELLED
+}
+```
+
+### Status
+
+Status is defined as `gsStatus`.
+
+<div class="tag enumDefinition csharp"></div>
+
+```
+public enum gsStatus
+{
+ GS_READY,
+ GS_BUSY,
+ GS_ERROR
+};
+```
+
+## The Parameter Struct
+
+The parameter struct `gsParamState_t` allows for bundles of information to be processed by Ghostscript to complete overall requests.
+
+<div class="tag structDefinition csharp"></div>
+
+```
+public struct gsParamState_t
+{
+ public String outputfile;
+ public String inputfile;
+ public GS_Task_t task;
+ public GS_Result_t result;
+ public int num_pages;
+ public List<int> pages;
+ public int firstpage;
+ public int lastpage;
+ public int currpage;
+ public List<String> args;
+ public int return_code;
+ public double zoom;
+};
+```
+
+
+### Parameters explained
+
+Setting up your parameters (with any dedicated bespoke method(s) which your application requires) is needed when communicating directly with `GhostAPI`.
+
+When requesting Ghostscript to process an operation an application developer should send a parameter payload which defines the details for the operation.
+
+For example in `GhostMono` we can see the public method as follows:
+
+<div class="tag sampleCode csharp"></div>
+
+```
+public gsStatus DistillPS(String fileName, int resolution)
+{
+ gsParamState_t gsparams = new gsParamState_t();
+ gsparams.args = new List<string>();
+
+ gsparams.inputfile = fileName;
+ gsparams.args.Add("gs");
+ gsparams.args.Add("-dNOPAUSE");
+ gsparams.args.Add("-dBATCH");
+ gsparams.args.Add("-I%rom%Resource/Init/");
+ gsparams.args.Add("-dSAFER");
+ gsparams.args.Add("-sDEVICE=pdfwrite");
+ gsparams.outputfile = Path.GetTempFileName();
+ gsparams.args.Add("-o" + gsparams.outputfile);
+ gsparams.task = GS_Task_t.PS_DISTILL;
+
+ return RunGhostscriptAsync(gsparams);
+}
+```
+
+Here we can see a parameter payload being setup before being passed on to the asynchronous method `RunGhostscriptAsync` which sets up a worker thread to run according to the task type in the payload.
+
+`GhostMono` handles many common operations on an application developer's behalf, however if you require to write your own methods to interface with `GhostAPI` then referring to the public methods in `GhostMono` is a good starting point.
+
+For full documentation on parameters refer to [Ghostscript parameters].
+
+
+## The Event class
+
+`GhostMono` contains a public class `gsThreadCallBack`. This class is used to set and get callback information as they occur. `GhostMono` will create these payloads and deliver them back to the application layer's `ProgressCallBack` method [asynchronously].
+
+
+<div class="tag classDefinition csharp"></div>
+
+```
+public class gsThreadCallBack
+{
+ private bool m_completed;
+ private int m_progress;
+ private gsParamState_t m_param;
+ public bool Completed
+ {
+ get { return m_completed; }
+ }
+ public gsParamState_t Params
+ {
+ get { return m_param; }
+ }
+ public int Progress
+ {
+ get { return m_progress; }
+ }
+ public gsThreadCallBack(bool completed, int progress, gsParamState_t param)
+ {
+ m_completed = completed;
+ m_progress = progress;
+ m_param = param;
+ }
+}
+```
+
+
+## GSMONO
+
+This class should be instantiated as a member variable in your application with callback definitions setup as required.
+
+Handlers for asynchronous operations can injected by providing your own bespoke callback methods to your instance's `ProgressCallBack` function.
+
+<div class="tag sampleCode csharp"></div>
+
+```
+/* Set up ghostscript with callbacks for system updates */
+m_ghostscript = new GSMONO();
+m_ghostscript.ProgressCallBack += new GSMONO.Progress(gsProgress);
+m_ghostscript.StdIOCallBack += new GSMONO.StdIO(gsIO);
+m_ghostscript.DLLProblemCallBack += new GSMONO.DLLProblem(gsDLL);
+m_ghostscript.PageRenderedCallBack += new GSMONO.PageRendered(gsPageRendered);
+m_ghostscript.DisplayDeviceOpen();
+
+/* example callback stubs for asynchronous operations */
+private void gsProgress(gsThreadCallBack asyncInformation)
+{
+ Console.WriteLine($"gsProgress().progress:{asyncInformation.Progress}");
+
+ if (asyncInformation.Completed) // task complete
+ {
+ // what was the task?
+ switch (asyncInformation.Params.task)
+ {
+ case GS_Task_t.CREATE_XPS:
+ Console.WriteLine($"CREATE_XPS.outputfile:");
+ Console.WriteLine($"{asyncInformation.Params.result.outputfile}");
+ break;
+
+ case GS_Task_t.PS_DISTILL:
+ Console.WriteLine($"PS_DISTILL.outputfile:");
+ Console.WriteLine($"{asyncInformation.Params.result.outputfile}");
+ break;
+
+ case GS_Task_t.SAVE_RESULT:
+
+ break;
+
+ case GS_Task_t.DISPLAY_DEV_THUMBS:
+
+ break;
+
+ case GS_Task_t.DISPLAY_DEV_RUN_FILE:
+
+ break;
+
+ case GS_Task_t.DISPLAY_DEV_PDF:
+
+ break;
+
+ case GS_Task_t.DISPLAY_DEV_NON_PDF:
+
+ break;
+
+ default:
+
+ break;
+ }
+
+ // task failed
+ if (asyncInformation.Params.result == GS_Result_t.gsFAILED)
+ {
+ switch (asyncInformation.Params.task)
+ {
+ case GS_Task_t.CREATE_XPS:
+
+ break;
+
+ case GS_Task_t.PS_DISTILL:
+
+ break;
+
+ case GS_Task_t.SAVE_RESULT:
+
+ break;
+
+ default:
+
+ break;
+ }
+ return;
+ }
+
+ // task cancelled
+ if (asyncInformation.Params.result == GS_Result_t.gsCANCELLED)
+ {
+
+ }
+ }
+ else // task is still running
+ {
+ switch (asyncInformation.Params.task)
+ {
+ case GS_Task_t.CREATE_XPS:
+
+ break;
+
+ case GS_Task_t.PS_DISTILL:
+
+ break;
+
+ case GS_Task_t.SAVE_RESULT:
+
+ break;
+ }
+ }
+}
+
+private void gsIO(String message, int len)
+{
+ Console.WriteLine($"gsIO().message:{message}, length:{len}");
+}
+
+private void gsDLL(String message)
+{
+ Console.WriteLine($"gsDLL().message:{message}");
+}
+
+private void gsPageRendered(int width,
+ int height,
+ int raster,
+ IntPtr data,
+ gsParamState_t state)
+{
+
+};
+```
+
+> **NOTE**<br>
+> Once a Ghostscript operation is in progress any defined callback functions will be called as the operation runs up unto completion. These callback methods are essential for your application to interpret activity events and react accordingly.
+>
+
+An explanation of callbacks and the available public methods within `GSMONO` are explained below.
+
+
+### Delegates
+
+To handle asynchronous events `GhostMONO` has four delegates which define callback methods that an application can assign to.
+
+
+| Callback | Description |
+|---|---|
+|`DLLProblemCallBack`|Occurs if there is some issue with the Ghostscript Shared Object (`libgpdl.so`)|
+|`StdIOCallBack`|Occurs if Ghostscript outputs something to `stderr` or `stdout`|
+|`ProgressCallBack`|Occurs as Ghostscript makes its way through a file|
+|`PageRenderedCallBack`|Occurs when a page has been rendered and the data from the display device is ready|
+
+
+#### DLLProblemCallBack
+
+<div class="tag callbackDefinition csharp"></div>
+
+```
+internal delegate void DLLProblem(String mess);
+internal event DLLProblem DLLProblemCallBack;
+```
+
+#### StdIOCallBack
+
+<div class="tag callbackDefinition csharp"></div>
+
+```
+internal delegate void StdIO(String mess,
+ int len);
+internal event StdIO StdIOCallBack;
+```
+
+#### ProgressCallBack
+
+<div class="tag callbackDefinition csharp"></div>
+
+```
+internal delegate void Progress(gsEventArgs info);
+internal event Progress ProgressCallBack;
+```
+
+#### PageRenderedCallBack
+
+<div class="tag callbackDefinition csharp"></div>
+
+```
+internal delegate void PageRendered(int width,
+ int height,
+ int raster,
+ IntPtr data,
+ gsParamState_t state);
+internal event PageRendered PageRenderedCallBack;
+```
+
+
+### GetVersion
+
+Use this method to get Ghostscript version info as a handy `String`.
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public String GetVersion()
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+String gs_vers = m_ghostscript.GetVersion();
+```
+
+> **NOTE**<br>
+> An exception will be thrown if there is any issue with the Ghostscript DLL.
+>
+
+
+### DisplayDeviceOpen
+
+Sets up the [display device] ahead of time.
+
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public gsParamState_t DisplayDeviceOpen()
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+m_ghostscript.DisplayDeviceOpen();
+```
+
+> **NOTE**<br>
+> Calling this method [instantiates ghostscript] and configures the encoding and the callbacks for the display device.
+>
+
+
+### DisplayDeviceClose
+
+Closes the [display device] and deletes the instance.
+
+
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public gsParamState_t DisplayDeviceClose()
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+m_ghostscript.DisplayDeviceClose();
+```
+
+> **NOTE**<br>
+> Calling this method [deletes ghostscript].
+>
+
+
+### GetPageCount
+
+Use this method to get the number of pages in a supplied document.
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public int GetPageCount(String fileName)
+```
+
+
+<div class="tag sampleCode csharp"></div>
+
+```
+int page_number = m_ghostscript.GetPageCount("my_document.pdf");
+```
+
+
+> **NOTE**<br>
+> If Ghostscript is unable to determine the page count then this method will return `-1`.
+>
+
+
+### DistillPS
+
+Launches a thread rendering all the pages of a supplied PostScript file to a PDF.
+
+<div class="tag methodDefinition csharp async"></div>
+
+```
+public gsStatus DistillPS(String fileName, int resolution)
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+m_ghostscript.DistillPS("my_postscript_document.ps", 300);
+```
+
+<span class="smallText alignRight">
+
+_[asynchronous]_
+
+</span>
+
+
+
+### DisplayDeviceRenderAll
+
+
+Launches a thread rendering all the document pages with the [display device]. For use with languages that can be indexed via pages which include PDF and XPS. [1]
+
+<div class="tag methodDefinition csharp async"></div>
+
+```
+public gsStatus DisplayDeviceRenderAll(String fileName, double zoom, bool aa, GS_Task_t task)
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+m_ghostscript.DisplayDeviceRenderAll("my_document.pdf",
+ 0.1,
+ false,
+ GS_Task_t.DISPLAY_DEV_THUMBS_NON_PDF);
+```
+
+<span class="smallText alignRight">
+
+_[asynchronous]_
+
+</span>
+
+
+### DisplayDeviceRenderThumbs
+
+Launches a thread rendering all the pages with the [display device] to collect thumbnail images.
+
+Recommended zoom level for thumbnails is between 0.05 and 0.2, additionally anti-aliasing is probably not required.
+
+<div class="tag methodDefinition csharp async"></div>
+
+```
+public gsStatus DisplayDeviceRenderThumbs(String fileName,
+ double zoom,
+ bool aa)
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+m_ghostscript.DisplayDeviceRenderThumbs("my_document.pdf",
+ 0.1,
+ false);
+```
+
+<span class="smallText alignRight">
+
+_[asynchronous]_
+
+</span>
+
+
+### DisplayDeviceRenderPages
+
+
+Launches a thread rendering a set of pages with the [display device]. For use with languages that can be indexed via pages which include PDF and XPS. <sup>[1]</sup>
+
+
+
+
+<div class="tag methodDefinition csharp async"></div>
+
+```
+public gsStatus DisplayDeviceRenderPages(String fileName,
+ int first_page,
+ int last_page,
+ double zoom)
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+m_ghostscript.DisplayDeviceRenderPages("my_document.pdf",
+ 0,
+ 9,
+ 1.0);
+```
+
+<span class="smallText alignRight">
+
+_[asynchronous]_
+
+</span>
+
+
+### GetStatus
+
+Returns the current [status] of `Ghostscript`.
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public gsStatus GetStatus()
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+gsStatus status = m_ghostscript.GetStatus();
+```
+
+
+### GhostscriptException
+
+An application developer can log any exceptions in this public class as required by editing the constructor.
+
+
+<div class="tag classDefinition csharp"></div>
+
+```
+public class GhostscriptException : Exception
+{
+ public GhostscriptException(string message) : base(message)
+ {
+ // Report exceptions as required
+ }
+}
+```
+
+
+## Notes
+
+#### 1: Ghostscript & Page Description Languages
+
+Ghostscript handles the following [PDLs]: `PCL` `PDF` `PS` `XPS`.
+
+`PCL` and `PS` do not allow random access, meaning that, to print page 2 in a 100 page document, Ghostscript has to read the entire document stream of 100 pages.
+
+On the other hand, `PDF` and `XPS` allow for going directly to page 2 and then only dealing with that content. The tasks `DISPLAY_DEV_NON_PDF` and `DISPLAY_DEV_PDF` keep track of what sort of input Ghostscript is dealing with and enables the application to direct progress or completion callbacks accordingly.
+
+
+[PDLs]: https://en.wikipedia.org/wiki/Page_description_language
+[GhostAPI]: c-sharp-ghost-api.html
+[gsapi_revision]: c-sharp-ghost-api.html#gsapi_revision
+[Ghostscript parameters]: https://www.ghostscript.com/doc/current/Use.htm#Parameters
+[display device]: https://ghostscript.com/doc/current/Devices.htm#Display_devices
+[instantiates ghostscript]: c-sharp-ghost-api.html#gsapi_new_instance
+[deletes ghostscript]: c-sharp-ghost-api.html#gsapi_delete_instance
+[status]: #status
+[notes]: #notes
+[1]: #1-ghostscript-page-description-languages
+
+[GSMono instantiation]: #gsmono
+[asynchronous]: #delegates
+[asynchronously]: #delegates
diff --git a/doc/language-bindings/md/c-sharp-ghost-net.md b/doc/language-bindings/md/c-sharp-ghost-net.md
new file mode 100644
index 00000000..7e2a9375
--- /dev/null
+++ b/doc/language-bindings/md/c-sharp-ghost-net.md
@@ -0,0 +1,681 @@
+# GhostNET
+
+<div class="banner">
+ <div class="c-sharp-text"></div>
+ <div class="vendor-logo c-sharp-logo"></div>
+</div>
+
+
+
+## About
+
+`GhostNET` is the `C#` interface into the `GhostAPI` library developed for Windows systems.
+
+## Enums
+
+
+### Tasks
+
+The Ghostscript task type `enum` is used to inform `GhostAPI` of the type of operation which is being requested.
+
+
+| Task | Description |
+|---|---|
+|PS_DISTILL|Task associated with converting a PostScript stream to a PDF document|
+|CREATE_XPS|Task associated with outputting a copy of a document to XPS|
+|SAVE_RESULT|Task associated with saving documents|
+|GET_PAGE_COUNT|Task associated with getting the page count of a document|
+|GENERIC|Generic task identifier|
+|DISPLAY_DEV_THUMBS|Display Device task associated with rendering thumbnails|
+|DISPLAY_DEV_NON_PDF|Display Device task associated with non-PDF or non-XPS rendering <sup>[1]</sup>|
+|DISPLAY_DEV_PDF|Display Device task associated with PDF & XPS rendering <sup>[1]</sup>|
+|DISPLAY_DEV_RUN_FILE|Display Device task associated with running files|
+
+Task types are defined as `GS_Task_t`.
+
+<div class="tag enumDefinition csharp"></div>
+
+```
+public enum GS_Task_t
+{
+ PS_DISTILL,
+ CREATE_XPS,
+ SAVE_RESULT,
+ GET_PAGE_COUNT,
+ GENERIC,
+ DISPLAY_DEV_THUMBS,
+ DISPLAY_DEV_NON_PDF,
+ DISPLAY_DEV_PDF,
+ DISPLAY_DEV_RUN_FILE
+}
+```
+
+### Results
+
+Result types are defined as `GS_Result_t`.
+
+<div class="tag enumDefinition csharp"></div>
+
+```
+public enum GS_Result_t
+{
+ gsOK,
+ gsFAILED,
+ gsCANCELLED
+}
+```
+
+### Status
+
+Status is defined as `gsStatus`.
+
+<div class="tag enumDefinition csharp"></div>
+
+```
+public enum gsStatus
+{
+ GS_READY,
+ GS_BUSY,
+ GS_ERROR
+};
+```
+
+## The Parameter Struct
+
+The parameter struct `gsParamState_t` allows for bundles of information to be processed by Ghostscript to complete overall requests.
+
+<div class="tag structDefinition csharp"></div>
+
+```
+public struct gsParamState_t
+{
+ public String outputfile;
+ public String inputfile;
+ public GS_Task_t task;
+ public GS_Result_t result;
+ public int num_pages;
+ public List<int> pages;
+ public int firstpage;
+ public int lastpage;
+ public int currpage;
+ public List<String> args;
+ public int return_code;
+ public double zoom;
+ public bool aa;
+ public bool is_valid;
+};
+```
+
+### Parameters explained
+
+Setting up your parameters (with any dedicated bespoke method(s) which your application requires) is needed when communicating directly with `GhostAPI`.
+
+When requesting Ghostscript to process an operation an application developer should send a parameter payload which defines the details for the operation.
+
+For example in `GhostNET` we can see the public method as follows:
+
+
+<div class="tag sampleCode csharp"></div>
+
+```
+public gsStatus DistillPS(String fileName, int resolution)
+{
+ gsParamState_t gsparams = new gsParamState_t();
+ gsparams.args = new List<string>();
+
+ gsparams.inputfile = fileName;
+ gsparams.args.Add("gs");
+ gsparams.args.Add("-sDEVICE=pdfwrite");
+ gsparams.outputfile = Path.GetTempFileName();
+ gsparams.args.Add("-o" + gsparams.outputfile);
+ gsparams.task = GS_Task_t.PS_DISTILL;
+
+ return RunGhostscriptAsync(gsparams);
+}
+```
+
+Here we can see a parameter payload being setup before being passed on to the asynchronous method `RunGhostscriptAsync` which sets up a worker thread to run according to the task type in the payload.
+
+`GhostNET` handles many common operations on an application developer's behalf, however if you require to write your own methods to interface with `GhostAPI` then referring to the public methods in `GhostNET` is a good starting point.
+
+For full documentation on parameters refer to [Ghostscript parameters].
+
+## The Event class
+
+`GhostNET` contains a public class `gsEventArgs` which is an extension of the C# class [EventArgs]. This class is used to set and get events as they occur. `GhostNET` will create these payloads and deliver them back to the application layer's `ProgressCallBack` method [asynchronously].
+
+<div class="tag classDefinition csharp"></div>
+
+```
+public class gsEventArgs : EventArgs
+{
+ private bool m_completed;
+ private int m_progress;
+ private gsParamState_t m_param;
+ public bool Completed
+ {
+ get { return m_completed; }
+ }
+ public gsParamState_t Params
+ {
+ get { return m_param; }
+ }
+ public int Progress
+ {
+ get { return m_progress; }
+ }
+ public gsEventArgs(bool completed, int progress, gsParamState_t param)
+ {
+ m_completed = completed;
+ m_progress = progress;
+ m_param = param;
+ }
+}
+```
+
+
+
+
+## GSNET
+
+This class should be instantiated as a member variable in your application with callback definitions setup as required.
+
+Handlers for asynchronous operations can injected by providing your own bespoke callback methods to your instance's `ProgressCallBack` function.
+
+<div class="tag sampleCode csharp"></div>
+
+```
+/* Set up ghostscript with callbacks for system updates */
+m_ghostscript = new GSNET();
+m_ghostscript.ProgressCallBack += new GSNET.Progress(gsProgress);
+m_ghostscript.StdIOCallBack += new GSNET.StdIO(gsIO);
+m_ghostscript.DLLProblemCallBack += new GSNET.DLLProblem(gsDLL);
+m_ghostscript.PageRenderedCallBack += new GSNET.PageRendered(gsPageRendered);
+m_ghostscript.DisplayDeviceOpen();
+
+/* example callback stubs for asynchronous operations */
+private void gsProgress(gsEventArgs asyncInformation)
+{
+ Console.WriteLine($"gsProgress().progress:{asyncInformation.Progress}");
+
+ if (asyncInformation.Completed) // task complete
+ {
+ // what was the task?
+ switch (asyncInformation.Params.task)
+ {
+ case GS_Task_t.CREATE_XPS:
+ Console.WriteLine($"CREATE_XPS.outputfile:");
+ Console.WriteLine($"{asyncInformation.Params.result.outputfile}");
+ break;
+
+ case GS_Task_t.PS_DISTILL:
+ Console.WriteLine($"PS_DISTILL.outputfile:");
+ Console.WriteLine($"{asyncInformation.Params.result.outputfile}");
+ break;
+
+ case GS_Task_t.SAVE_RESULT:
+
+ break;
+
+ case GS_Task_t.DISPLAY_DEV_THUMBS:
+
+ break;
+
+ case GS_Task_t.DISPLAY_DEV_RUN_FILE:
+
+ break;
+
+ case GS_Task_t.DISPLAY_DEV_PDF:
+
+ break;
+
+ case GS_Task_t.DISPLAY_DEV_NON_PDF:
+
+ break;
+
+ default:
+
+ break;
+ }
+
+ // task failed
+ if (asyncInformation.Params.result == GS_Result_t.gsFAILED)
+ {
+ switch (asyncInformation.Params.task)
+ {
+ case GS_Task_t.CREATE_XPS:
+
+ break;
+
+ case GS_Task_t.PS_DISTILL:
+
+ break;
+
+ case GS_Task_t.SAVE_RESULT:
+
+ break;
+
+ default:
+
+ break;
+ }
+ return;
+ }
+
+ // task cancelled
+ if (asyncInformation.Params.result == GS_Result_t.gsCANCELLED)
+ {
+
+ }
+ }
+ else // task is still running
+ {
+ switch (asyncInformation.Params.task)
+ {
+ case GS_Task_t.CREATE_XPS:
+
+ break;
+
+ case GS_Task_t.PS_DISTILL:
+
+ break;
+
+ case GS_Task_t.SAVE_RESULT:
+
+ break;
+ }
+ }
+}
+
+private void gsIO(String message, int len)
+{
+ Console.WriteLine($"gsIO().message:{message}, length:{len}");
+}
+
+private void gsDLL(String message)
+{
+ Console.WriteLine($"gsDLL().message:{message}");
+}
+
+private void gsPageRendered(int width,
+ int height,
+ int raster,
+ IntPtr data,
+ gsParamState_t state)
+{
+
+};
+```
+
+> **NOTE**<br>
+> Once a Ghostscript operation is in progress any defined callback functions will be called as the operation runs up unto completion. These callback methods are essential for your application to interpret activity events and react accordingly.
+>
+
+An explanation of callbacks and the available public methods within `GSNET` are explained below.
+
+
+### Delegates
+
+To handle asynchronous events `GhostNET` has four delegates which define callback methods that an application can assign to.
+
+
+| Callback | Description |
+|---|---|
+|`DLLProblemCallBack`|Occurs if there is some issue with the Ghostscript DLL|
+|`StdIOCallBack`|Occurs if Ghostscript outputs something to `stderr` or `stdout`|
+|`ProgressCallBack`|Occurs as Ghostscript makes its way through a file|
+|`PageRenderedCallBack`|Occurs when a page has been rendered and the data from the display device is ready|
+
+
+#### DLLProblemCallBack
+
+<div class="tag callbackDefinition csharp"></div>
+
+```
+internal delegate void DLLProblem(String mess);
+internal event DLLProblem DLLProblemCallBack;
+```
+
+#### StdIOCallBack
+
+<div class="tag callbackDefinition csharp"></div>
+
+```
+internal delegate void StdIO(String mess,
+ int len);
+internal event StdIO StdIOCallBack;
+```
+
+#### ProgressCallBack
+
+<div class="tag callbackDefinition csharp"></div>
+
+```
+internal delegate void Progress(gsEventArgs info);
+internal event Progress ProgressCallBack;
+```
+
+#### PageRenderedCallBack
+
+<div class="tag callbackDefinition csharp"></div>
+
+```
+internal delegate void PageRendered(int width,
+ int height,
+ int raster,
+ IntPtr data,
+ gsParamState_t state);
+internal event PageRendered PageRenderedCallBack;
+```
+
+### GetVersion
+
+Use this method to get Ghostscript version info as a handy `String`.
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public String GetVersion()
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+String gs_vers = m_ghostscript.GetVersion();
+```
+
+> **NOTE**<br>
+> An exception will be thrown if there is any issue with the Ghostscript DLL.
+>
+
+
+### DisplayDeviceOpen
+
+Sets up the [display device] ahead of time.
+
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public gsParamState_t DisplayDeviceOpen()
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+m_ghostscript.DisplayDeviceOpen();
+```
+
+> **NOTE**<br>
+> Calling this method [instantiates ghostscript] and configures the encoding and the callbacks for the display device.
+>
+
+### DisplayDeviceClose
+
+Closes the [display device] and deletes the instance.
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public gsParamState_t DisplayDeviceClose()
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+m_ghostscript.DisplayDeviceClose();
+```
+
+> **NOTE**<br>
+> Calling this method [deletes ghostscript].
+>
+
+### GetPageCount
+
+Use this method to get the number of pages in a supplied document.
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public int GetPageCount(String fileName)
+```
+
+
+<div class="tag sampleCode csharp"></div>
+
+```
+int page_number = m_ghostscript.GetPageCount("my_document.pdf");
+```
+
+> **NOTE**<br>
+> If Ghostscript is unable to determine the page count then this method will return `-1`.
+>
+
+
+### CreateXPS
+
+Launches a thread to create an XPS document for Windows printing. This method is [asynchronous] and logic should be hooked into your application upon [GSNET instantiation] to interpret progress.
+
+
+<div class="tag methodDefinition csharp async"></div>
+
+```
+public gsStatus CreateXPS(String fileName,
+ int resolution,
+ int num_pages,
+ double width,
+ double height,
+ bool fit_page,
+ int firstpage,
+ int lastpage)
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+m_ghostscript.CreateXPS("my_document.pdf",
+ 300,
+ 10,
+ 1000,
+ 1000,
+ true,
+ 0,
+ 9);
+```
+
+<span class="smallText alignRight">
+
+_[asynchronous]_
+
+</span>
+
+### DistillPS
+
+Launches a thread rendering all the pages of a supplied PostScript file to a PDF.
+
+<div class="tag methodDefinition csharp async"></div>
+
+```
+public gsStatus DistillPS(String fileName, int resolution)
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+m_ghostscript.DistillPS("my_postscript_document.ps", 300);
+```
+
+<span class="smallText alignRight">
+
+_[asynchronous]_
+
+</span>
+
+
+### DisplayDeviceRunFile
+
+Launches a thread to run a file with the [display device].
+
+
+<div class="tag methodDefinition csharp async"></div>
+
+```
+public gsStatus DisplayDeviceRunFile(String fileName,
+ double zoom,
+ bool aa, // anti-aliasing value
+ int firstpage,
+ int lastpage)
+```
+
+
+
+<div class="tag sampleCode csharp"></div>
+
+```
+m_ghostscript.DisplayDeviceRunFile("my_document.pdf",
+ 1.0,
+ true,
+ 0,
+ 9);
+```
+
+<span class="smallText alignRight">
+
+_[asynchronous]_
+
+</span>
+
+### DisplayDeviceRenderThumbs
+
+Launches a thread rendering all the pages with the [display device] to collect thumbnail images.
+
+Recommended zoom level for thumbnails is between 0.05 and 0.2, additionally anti-aliasing is probably not required.
+
+<div class="tag methodDefinition csharp async"></div>
+
+```
+public gsStatus DisplayDeviceRenderThumbs(String fileName,
+ double zoom,
+ bool aa)
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+m_ghostscript.DisplayDeviceRenderThumbs("my_document.pdf",
+ 0.1,
+ false);
+```
+
+<span class="smallText alignRight">
+
+_[asynchronous]_
+
+</span>
+
+### DisplayDeviceRenderPages
+
+Launches a thread rendering a set of pages with the [display device]. For use with languages that can be indexed via pages which include PDF and XPS. <sup>[1]</sup>
+
+<div class="tag methodDefinition csharp async"></div>
+
+```
+public gsStatus DisplayDeviceRenderPages(String fileName,
+ int first_page,
+ int last_page,
+ double zoom)
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+m_ghostscript.DisplayDeviceRenderPages("my_document.pdf",
+ 0,
+ 9,
+ 1.0);
+```
+
+<span class="smallText alignRight">
+
+_[asynchronous]_
+
+</span>
+
+
+
+
+### GetStatus
+
+Returns the current [status] of `Ghostscript`.
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public gsStatus GetStatus()
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+gsStatus status = m_ghostscript.GetStatus();
+```
+
+### Cancel
+
+Cancels [asynchronous] operations.
+
+<div class="tag methodDefinition csharp"></div>
+
+```
+public void Cancel()
+```
+
+<div class="tag sampleCode csharp"></div>
+
+```
+m_ghostscript.Cancel();
+```
+
+### GhostscriptException
+
+An application developer can log any exceptions in this public class as required by editing the constructor.
+
+
+<div class="tag classDefinition csharp"></div>
+
+```
+public class GhostscriptException : Exception
+{
+ public GhostscriptException(string message) : base(message)
+ {
+ // Report exceptions as required
+ }
+}
+```
+
+## Notes
+
+#### 1: Ghostscript & Page Description Languages
+
+Ghostscript handles the following [PDLs]: `PCL` `PDF` `PS` `XPS`.
+
+`PCL` and `PS` do not allow random access, meaning that, to print page 2 in a 100 page document, Ghostscript has to read the entire document stream of 100 pages.
+
+On the other hand, `PDF` and `XPS` allow for going directly to page 2 and then only dealing with that content. The tasks `DISPLAY_DEV_NON_PDF` and `DISPLAY_DEV_PDF` keep track of what sort of input Ghostscript is dealing with and enables the application to direct progress or completion callbacks accordingly.
+
+
+[PDLs]: https://en.wikipedia.org/wiki/Page_description_language
+[GhostAPI]: c-sharp-ghost-api.html
+[EventArgs]: https://docs.microsoft.com/en-us/dotnet/api/system.eventargs?view=net-5.0
+[gsapi_revision]: c-sharp-ghost-api.html#gsapi_revision
+[Ghostscript parameters]: https://www.ghostscript.com/doc/current/Use.htm#Parameters
+[display device]: https://ghostscript.com/doc/current/Devices.htm#Display_devices
+[instantiates ghostscript]: c-sharp-ghost-api.html#gsapi_new_instance
+[deletes ghostscript]: c-sharp-ghost-api.html#gsapi_delete_instance
+[status]: #status
+[notes]: #notes
+[1]: #1-ghostscript-page-description-languages
+
+[GSNET instantiation]: #gsnet
+[asynchronous]: #delegates
+[asynchronously]: #delegates
diff --git a/doc/language-bindings/md/c-sharp-intro.md b/doc/language-bindings/md/c-sharp-intro.md
new file mode 100644
index 00000000..87722021
--- /dev/null
+++ b/doc/language-bindings/md/c-sharp-intro.md
@@ -0,0 +1,120 @@
+# C# overview
+
+<div class="banner">
+ <div class="c-sharp-text"></div>
+ <div class="vendor-logo c-sharp-logo"></div>
+</div>
+
+## About
+
+In the [GhostPDL repository] a sample `C#` project can be found in `/demos/csharp`.
+
+Within this project the following namespaces and corresponding `C#` files are of relevance:
+
+- [GhostAPI] `ghostapi.cs`
+- [GhostNET] `ghostnet.cs`
+- [GhostMono] `ghostmono.cs`
+
+## Platform & setup
+
+### Building Ghostscript
+
+Ghostscript should be built as a shared library for your platform.
+
+See [Building Ghostscript].
+
+## GhostAPI
+
+`GhostAPI` is the main wrapper responsible for bridging over to the `C` library and ensuring that the correct DLLs are imported.
+
+`GhostAPI` contains the `ghostapi` class which _does not_ need to be instantiated as it provides `public static` methods. These methods, which mirror their `C` counterparts, are as follows:
+
+
+| Method | Description |
+|---|---|
+| [gsapi_revision] | Returns the revision numbers and strings of the Ghostscript interpreter library |
+| [gsapi_new_instance] | Create a new instance of Ghostscript |
+| [gsapi_delete_instance] | Destroy an instance of Ghostscript |
+| [gsapi_set_stdio_with_handle] | Set the callback functions for `stdio`, together with the handle to use in the callback functions |
+| [gsapi_set_stdio] | Set the callback functions for `stdio` |
+| [gsapi_set_poll_with_handle] | Set the callback function for polling, together with the handle to pass to the callback function |
+| [gsapi_set_poll] | Set the callback function for polling |
+| [gsapi_set_display_callback] | _deprecated_ |
+| [gsapi_register_callout] | This call registers a callout handler |
+| [gsapi_deregister_callout] | This call deregisters a previously registered callout handler |
+| [gsapi_set_arg_encoding] | Set the encoding used for the interpretation of all subsequent args supplied via the gsapi interface on this instance |
+| [gsapi_set_default_device_list] | Set the string containing the list of default device names |
+| [gsapi_get_default_device_list] | Returns a pointer to the current default device string |
+| [gsapi_init_with_args] | Initialise the interpreter |
+| [gsapi\_run\_\*][gsapi_run_wildcard] | Wildcard for various "run" methods |
+| [gsapi_exit] | Exit the interpreter |
+| [gsapi_set_param] | Set a parameter |
+| [gsapi_get_param] | Get a parameter |
+| [gsapi_enumerate_params] | Enumerate the current parameters |
+| [gsapi_add_control_path] | Add a (case sensitive) path to one of the lists of permitted paths for file access |
+| [gsapi_remove_control_path] | Remove a (case sensitive) path from one of the lists of permitted paths for file access |
+| [gsapi_purge_control_paths] | Clear all the paths from one of the lists of permitted paths for file access |
+| [gsapi_activate_path_control] | Enable/Disable path control |
+| [gsapi_is_path_control_active] | Query whether path control is activated or not |
+
+
+
+## GhostNET
+
+`GhostNET` is the [.NET] interface into `GhostAPI`. It exemplifies how to do more complex operations involving multiple API calls and sequences.
+
+
+### GhostNET WPF example
+
+In `demos/csharp/windows/ghostnet.sln` there is a sample C# demo project.
+
+
+This project can be opened in [Visual Studio] and used to test the Ghostscript API alongside a UI which handles opening PostScript and PDF files. The sample application here allows for file browsing and Ghostscript file viewing.
+
+Below is a screenshot of the sample application with a PDF open:
+
+![ghostnet wpf example UI](images/ghostnet-wpf-example.png)
+
+
+
+## GhostMono
+
+`GhostMono` is the [Mono] equivalent of `GhostNET` and as such has no dependancy on a Windows environment.
+
+
+[Visual Studio]: https://visualstudio.microsoft.com
+[GhostPDL repository]: https://github.com/ArtifexSoftware/ghostpdl
+[GhostAPI]: #ghostapi
+[GhostNET]: #ghostnet
+[GhostMono]: #ghostmono
+[Mono]: https://www.mono-project.com/
+[.NET]: https://dotnet.microsoft.com/
+[Building Ghostscript]: index.html#building-ghostscript
+
+[gsapi_revision]: c-sharp-ghost-api#gsapi_revision
+[gsapi_new_instance]: c-sharp-ghost-api#gsapi_new_instance
+[gsapi_delete_instance]: c-sharp-ghost-api#gsapi_delete_instance
+[gsapi_set_stdio_with_handle]: c-sharp-ghost-api#gsapi_set_stdio_with_handle
+[gsapi_set_stdio]: c-sharp-ghost-api#gsapi_set_stdio
+[gsapi_set_poll_with_handle]: c-sharp-ghost-api#gsapi_set_poll_with_handle
+[gsapi_set_poll]: c-sharp-ghost-api#gsapi_set_poll
+[gsapi_set_display_callback]: c-sharp-ghost-api#gsapi_set_display_callback
+[gsapi_register_callout]: c-sharp-ghost-api#gsapi_register_callout
+[gsapi_deregister_callout]: c-sharp-ghost-api#gsapi_deregister_callout
+[gsapi_set_arg_encoding]: c-sharp-ghost-api#gsapi_set_arg_encoding
+[gsapi_set_default_device_list]: c-sharp-ghost-api#gsapi_set_default_device_list
+[gsapi_get_default_device_list]: c-sharp-ghost-api#gsapi_get_default_device_list
+[gsapi_init_with_args]: c-sharp-ghost-api#gsapi_init_with_args
+[gsapi_run_wildcard]: c-sharp-ghost-api#gsapi_run_wildcard
+[gsapi_init_with_args]: c-sharp-ghost-api#gsapi_init_with_args
+[gsapi_exit]: c-sharp-ghost-api#gsapi_exit
+[gsapi_set_param]: c-sharp-ghost-api#gsapi_set_param
+[gsapi_get_param]: c-sharp-ghost-api#gsapi_get_param
+[gsapi_enumerate_params]: c-sharp-ghost-api#gsapi_enumerate_params
+[gsapi_add_control_path]: c-sharp-ghost-api#gsapi_add_control_path
+[gsapi_remove_control_path]: c-sharp-ghost-api#gsapi_remove_control_path
+[gsapi_purge_control_paths]: c-sharp-ghost-api#gsapi_purge_control_paths
+[gsapi_activate_path_control]: c-sharp-ghost-api#gsapi_activate_path_control
+[gsapi_is_path_control_active]: c-sharp-ghost-api#gsapi_is_path_control_active
+[gsapi_add_fs]: c-sharp-ghost-api#gsapi_add_fs
+[gsapi_remove_fs]: c-sharp-ghost-api#gsapi_remove_fs
diff --git a/doc/language-bindings/md/demo-code.md b/doc/language-bindings/md/demo-code.md
new file mode 100644
index 00000000..cb8db2a6
--- /dev/null
+++ b/doc/language-bindings/md/demo-code.md
@@ -0,0 +1,17 @@
+# Demo code
+
+<div class="banner intro">
+ <div class="default-text"></div>
+ <div class="vendor-logo gs-logo"></div>
+ <div class="vendor-logo c-sharp-logo"></div>
+ <div class="vendor-logo java-logo"></div>
+ <div class="vendor-logo python-logo"></div>
+</div>
+
+## About
+
+Please locate the `demos` folder in your `ghostpdl` source code download from the [GhostPDL repository] to find sample code demonstrating the language bindings in action.
+
+
+[Ghostscript releases]: https://ghostscript.com/download/gpdldnld.html
+[GhostPDL repository]: https://github.com/ArtifexSoftware/ghostpdl
diff --git a/doc/language-bindings/md/images/export-jar.png b/doc/language-bindings/md/images/export-jar.png
new file mode 100644
index 00000000..9922043a
--- /dev/null
+++ b/doc/language-bindings/md/images/export-jar.png
Binary files differ
diff --git a/doc/language-bindings/md/images/ghostnet-wpf-example.png b/doc/language-bindings/md/images/ghostnet-wpf-example.png
new file mode 100644
index 00000000..df94b86c
--- /dev/null
+++ b/doc/language-bindings/md/images/ghostnet-wpf-example.png
Binary files differ
diff --git a/doc/language-bindings/md/images/gsviewer.png b/doc/language-bindings/md/images/gsviewer.png
new file mode 100644
index 00000000..52e0f19a
--- /dev/null
+++ b/doc/language-bindings/md/images/gsviewer.png
Binary files differ
diff --git a/doc/language-bindings/md/images/linking-jar.png b/doc/language-bindings/md/images/linking-jar.png
new file mode 100644
index 00000000..a91da771
--- /dev/null
+++ b/doc/language-bindings/md/images/linking-jar.png
Binary files differ
diff --git a/doc/language-bindings/md/introduction.md b/doc/language-bindings/md/introduction.md
new file mode 100755
index 00000000..33b6856d
--- /dev/null
+++ b/doc/language-bindings/md/introduction.md
@@ -0,0 +1,113 @@
+# Introduction
+
+<div class="banner intro">
+ <div class="default-text"></div>
+ <div class="vendor-logo gs-logo"></div>
+ <div class="vendor-logo c-sharp-logo"></div>
+ <div class="vendor-logo java-logo"></div>
+ <div class="vendor-logo python-logo"></div>
+</div>
+
+## About our APIs
+
+The core of Ghostscript is written in `C`, but also supports [language bindings] for the following programming languages:
+
+* `C#`
+* `Java`
+* `Python`
+
+All of the above languages have equivalent methods as defined in the [C API]. `Java` and `C#` provide additional helper methods to make the use of the API easier for certain applications. These languages also provide example viewers that make use of these methods.
+
+This developer documentation is organized by programming language type and includes API reference and sample code.
+
+## The C API
+
+<div class="vendor-logo c-logo"></div>
+<p/>
+
+Ghostscript has been in development for over thirty years and is written in `C`. The API has evolved over time and is continually being developed. The language bindings into Ghostscript will attempt to mirror this evolution and match the current [C API] as much as possible.
+
+## Licensing
+
+Before using Ghostscript, please make sure that you have a valid license to do so. There are two available licenses; make sure you pick the one whose terms you can comply with.
+
+### Open Source license
+
+If your software is open source, you may use Ghostscript under the terms of the GNU Affero General Public License.
+
+This means that all of the source code for your complete app must be released under a compatible open source license!
+
+It also means that you may not use any proprietary closed source libraries or components in your app.
+
+Please read the full text of the AGPL license agreement from the [FSF web site]
+
+If you cannot or do not want to comply with these restrictions, you must acquire a commercial license instead.
+
+<button class="cta orange"><a href="https://artifex.com/licensing/" target="new">FIND OUT MORE</a></button>
+
+### Commercial license
+
+If your project does not meet the requirements of the AGPL, please contact our sales team to discuss a commercial license. Each Artifex commercial license is crafted based on your individual use case.
+
+<button class="cta orange"><a href="https://artifex.com/contact/" target="new">CONTACT US</a></button>
+
+
+## Building Ghostscript
+
+In order to use Ghostscript language bindings firstly Ghostscript must be built as a shared library for your platform.
+
+The following built libraries are required for these respective platforms:
+
+| Platform | Ghostscript library files |
+|---|---|
+|Windows 32-bit|`gpdldll32.dll` `gsdll32.dll`|
+|Windows 64-bit|`gpdldll64.dll` `gsdll64.dll`|
+|MacOS|`libgpdl.dylib` `libgs.dylib`|
+|Linux / OpenBSD|`libgpdl.so` `libgs.so`|
+
+
+> **NOTE**<br>
+> The actual filenames on MacOS will be appended with the version of Ghostscript with associated symlinks.
+
+### Building on Windows
+
+To build the required DLLs, load `/windows/ghostpdl.sln` into Visual Studio, and select the required architecture from the drop down - then right click on 'ghostpdl' in the solution explorer and choose "Build".
+
+
+### Building on MacOS or Linux / OpenBSD
+
+Firstly run the `autogen.sh` script from the command line to create the required configuration files followed by `make so` to build the shared libraries. The scripts also depend on having both `autoconf` and `automake` installed on your system. <sup>[1]</sup>
+
+#### autoconf & automake
+
+If this software is not already on your system (usually this can be found in the following location: `usr/local/bin`, but it could be located elsewhere depending on your setup) then it can be installed from your OS's package system.
+
+
+Alternatively, it can be installed from [GNU] here:
+
+https://www.gnu.org/software/autoconf/
+
+https://www.gnu.org/software/automake/
+
+Or, it can be installed via [Brew] by running:
+
+```
+brew install autoconf automake
+```
+
+Once built, these libraries can be found in your `ghostpdl/sobin/` or `ghostpdl/sodebugbin` location depending on your build command.
+
+
+
+> **NOTE**<br>
+> For full detailed instructions on how to build your Ghostscript library see [here].
+>
+
+[Python]: https://www.python.org/
+[Brew]: https://brew.sh/
+[GNU]: https://www.gnu.org/
+
+[C API]: https://www.ghostscript.com/doc/current/API.htm
+[FSF web site]: https://www.gnu.org/licenses/agpl-3.0.html
+[here]: https://ghostscript.com/doc/current/Make.htm
+[language bindings]: https://en.wikipedia.org/wiki/Language_binding
diff --git a/doc/language-bindings/md/java-gsjavajar.md b/doc/language-bindings/md/java-gsjavajar.md
new file mode 100644
index 00000000..650bb11f
--- /dev/null
+++ b/doc/language-bindings/md/java-gsjavajar.md
@@ -0,0 +1,1179 @@
+# gsjava.jar
+
+<div class="banner">
+<div class="java-text"></div>
+<div class="vendor-logo java-logo"></div>
+</div>
+
+
+## About
+
+`gsjava.jar` is the Java library which contains classes and interfaces which enable API calls required to use Ghostscript.
+
+Assuming that the JAR for your project has been [built] and [properly linked] with your own project then the Ghostscript API should be available by importing the required classes within your project's `.java` files.
+
+
+### GSAPI & GSInstance
+
+- [GSAPI] is the main Ghostscript API class which bridges into the Ghostscript C library.
+- [GSInstance] is a wrapper class for [GSAPI] which encapsulates an instance of Ghostscript and allows for simpler API calls.
+
+
+<div class="tag sampleCode java"></div>
+
+
+```
+// to use GSAPI
+import static com.artifex.gsjava.GSAPI.*;
+
+// to use GSInstance
+import com.artifex.gsjava.GSInstance;
+```
+
+
+## GSAPI
+
+
+### gsapi_revision
+
+This method returns the revision numbers and strings of the Ghostscript interpreter library; you should call it before any other interpreter library functions to make sure that the correct version of the Ghostscript interpreter has been loaded.
+
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_revision(GSAPI.Revision revision,
+ int len);
+```
+
+
+> **NOTE**<br>
+> The method should write to a reference variable which conforms to the class [GSAPI.Revision].
+>
+
+
+#### GSAPI.Revision
+
+This class is used to store information about Ghostscript and provides handy getters for the product and the copyright information.
+
+
+<div class="tag classDefinition java"></div>
+
+```
+public static class Revision {
+ public volatile byte[] product;
+ public volatile byte[] copyright;
+ public volatile long revision;
+ public volatile long revisionDate;
+
+ public Revision() {
+ this.product = null;
+ this.copyright = null;
+ this.revision = 0L;
+ this.revisionDate = 0L;
+ }
+
+ /**
+ * Returns the product information as a String.
+ *
+ * @return The product information.
+ */
+ public String getProduct() {
+ return new String(product);
+ }
+
+ /**
+ * Returns the copyright information as a String.
+ *
+ * @return The copyright information.
+ */
+ public String getCopyright() {
+ return new String(copyright);
+ }
+}
+```
+
+
+### gsapi_new_instance
+
+Creates a new instance of Ghostscript. This instance is passed to most other [GSAPI] methods. Unless Ghostscript has been compiled with the `GS_THREADSAFE` define, only one instance at a time is supported.
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_new_instance(Reference<Long> instance,
+ long callerHandle);
+```
+
+
+
+> **NOTE**<br>
+> The method returns a reference which represents your instance of Ghostscript.
+>
+
+
+### gsapi_delete_instance
+
+Destroy an instance of Ghostscript. Before you call this, Ghostscript must have finished. If Ghostscript has been initialised, you should call [gsapi_exit] beforehand.
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native void gsapi_delete_instance(long instance);
+```
+
+
+### gsapi_set_stdio_with_handle
+
+Set the callback functions for `stdio`, together with the handle to use in the callback functions. The `stdin` callback function should return the number of characters read, 0 for EOF, or -1 for error. The `stdout` and `stderr` callback functions should return the number of characters written.
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_set_stdio_with_handle(long instance,
+ IStdInFunction stdin,
+ IStdOutFunction stdout,
+ IStdErrFunction stderr,
+ long callerHandle);
+```
+
+
+### gsapi_set_stdio
+
+Set the callback functions for `stdio`. The handle used in the callbacks will be taken from the value passed to [gsapi_new_instance]. Otherwise the behaviour of this function matches [gsapi_set_stdio_with_handle].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_set_stdio(long instance,
+ IStdInFunction stdin,
+ IStdOutFunction stdout,
+ IStdErrFunction stderr);
+```
+
+
+### gsapi_set_poll_with_handle
+
+Set the callback function for polling, together with the handle to pass to the callback function. This function will only be called if the Ghostscript interpreter was compiled with `CHECK_INTERRUPTS` as described in `gpcheck.h`.
+
+The polling function should return zero if all is well, and return negative if it wants ghostscript to abort. This is often used for checking for a user cancel. This can also be used for handling window events or cooperative multitasking.
+
+The polling function is called very frequently during interpretation and rendering so it must be fast. If the function is slow, then using a counter to `return 0` immediately some number of times can be used to reduce the performance impact.
+
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_set_poll_with_handle(long instance,
+ IPollFunction pollfun,
+ long callerHandle);
+```
+
+### gsapi_set_poll
+
+Set the callback function for polling. The handle passed to the callback function will be taken from the handle passed to [gsapi_new_instance]. Otherwise the behaviour of this function matches [gsapi_set_poll_with_handle].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_set_poll(long instance,
+ IPollFunction pollfun);
+```
+
+### gsapi_set_display_callback
+
+This call is deprecated; please use [gsapi_register_callout] to register a [callout handler] for the display device in preference.
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_set_display_callback(long instance,
+ DisplayCallback displayCallback);
+```
+
+
+### gsapi_register_callout
+
+This call registers a [callout handler].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_register_callout(long instance,
+ ICalloutFunction callout,
+ long calloutHandle);
+```
+
+
+### gsapi_deregister_callout
+
+
+This call deregisters a [callout handler] previously registered with [gsapi_register_callout]. All three arguments must match exactly for the [callout handler] to be deregistered.
+
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native void gsapi_deregister_callout(long instance,
+ ICalloutFunction callout,
+ long calloutHandle);
+```
+
+### gsapi_set_arg_encoding
+
+Set the encoding used for the interpretation of all subsequent arguments supplied via the `GSAPI` interface on this instance. By default we expect args to be in encoding `0` (the 'local' encoding for this OS). On Windows this means "the currently selected codepage". This means that omitting to call this function will leave Ghostscript running exactly as it always has. Please note that use of the 'local' encoding is now deprecated and should be avoided in new code. This must be called after [gsapi_new_instance] and before [gsapi_init_with_args].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_set_arg_encoding(long instance,
+ int encoding);
+```
+
+### gsapi_set_default_device_list
+
+Set the string containing the list of default device names, for example "display x11alpha x11 bbox". Allows the calling application to influence which device(s) Ghostscript will try, in order, in its selection of the default device. This must be called after [gsapi_new_instance] and before [gsapi_init_with_args].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_set_default_device_list(long instance,
+ byte[] list,
+ int listlen);
+```
+
+### gsapi_get_default_device_list
+
+Returns a pointer to the current default device string. This must be called after [gsapi_new_instance] and before [gsapi_init_with_args].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_get_default_device_list(long instance,
+ Reference<byte[]> list,
+ Reference<Integer> listlen);
+```
+
+### gsapi_init_with_args
+
+To initialise the interpreter, pass your `instance` of Ghostscript, your argument count: `argc`, and your argument variables: `argv`.
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_init_with_args(long instance,
+ int argc,
+ byte[][] argv);
+```
+
+
+> **NOTE**<br>
+> There are also simpler utility methods which eliminates the need to send through your argument count and allows for simpler `String` passing for your argument array.
+>
+
+Utility methods:
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static int gsapi_init_with_args(long instance,
+ String[] argv);
+```
+
+```
+public static int gsapi_init_with_args(long instance,
+ List<String> argv);
+```
+
+### gsapi\_run\_\*
+
+If these functions return `<= -100`, either quit or a fatal error has occured. You must call [gsapi_exit] next. The only exception is [gsapi_run_string_continue] which will return `gs_error_NeedInput` if all is well.
+
+There is a 64 KB length limit on any buffer submitted to a `gsapi_run_*` function for processing. If you have more than 65535 bytes of input then you must split it into smaller pieces and submit each in a separate [gsapi_run_string_continue] call.
+
+### gsapi_run_string_begin
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_run_string_begin(long instance,
+ int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+
+
+### gsapi_run_string_continue
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_run_string_continue(long instance,
+ byte[] str,
+ int length,
+ int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+
+> **NOTE**<br>
+> There is a simpler utility method which allows for simpler `String` passing for the `str` argument.
+>
+
+
+Utility method:
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static int gsapi_run_string_continue(long instance,
+ String str,
+ int length,
+ int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+
+### gsapi_run_string_with_length
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_run_string_with_length(long instance,
+ byte[] str,
+ int length,
+ int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+
+> **NOTE**<br>
+> There is a simpler utility method which allows for simpler `String` passing for the `str` argument.
+>
+
+
+Utility method:
+
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static int gsapi_run_string_with_length(long instance,
+ String str,
+ int length,
+ int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+
+### gsapi_run_string
+
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_run_string(long instance,
+ byte[] str,
+ int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+
+
+
+> **NOTE**<br>
+> There is a simpler utility method which allows for simpler `String` passing for the `str` argument.
+>
+
+
+Utility method:
+
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static int gsapi_run_string(long instance,
+ String str,
+ int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+
+
+### gsapi_run_string_end
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_run_string_end(long instance,
+ int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+### gsapi_run_file
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_run_file(long instance,
+ byte[] fileName,
+ int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+
+
+> **NOTE**<br>
+> There is a simpler utility method which allows for simpler `String` passing for the `fileName` argument.
+>
+
+
+Utility method:
+
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static int gsapi_run_file(long instance,
+ String fileName,
+ int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+
+
+
+### gsapi_exit
+
+Exit the interpreter. This must be called on shutdown if [gsapi_init_with_args] has been called, and just before [gsapi_delete_instance].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_exit(long instance);
+```
+
+
+
+### gsapi_set_param
+
+Sets a parameter. Broadly, this is equivalent to setting a parameter using -d, -s or -p on the command line. This call cannot be made during a [gsapi_run_string] operation.
+
+Parameters in this context are not the same as 'arguments' as processed by [gsapi_init_with_args], but often the same thing can be achieved. For example, with [gsapi_init_with_args], we can pass "-r200" to change the resolution. Broadly the same thing can be achieved by using [gsapi_set_param] to set a parsed value of "<</HWResolution [ 200.0 200.0 ]>>".
+
+Internally, when we set a parameter, we perform an `initgraphics` operation. This means that using [gsapi_set_param] other than at the start of a page is likely to give unexpected results.
+
+Attempting to set a parameter that the device does not recognise will be silently ignored, and that parameter will not be found in subsequent [gsapi_get_param] calls.
+
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_set_param(long instance,
+ byte[] param,
+ Object value,
+ int paramType);
+```
+
+> **NOTE**<br>
+> The `type` argument, as a [gs_set_param_type], dictates the kind of object that the `value` argument points to.
+>
+
+> **NOTE**<br>
+> For more on the C implementation of parameters see: [Ghostscript parameters in C].
+>
+
+> **NOTE**<br>
+> There are also simpler utility methods which allows for simpler `String` passing for your arguments.
+>
+
+
+Utility methods:
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static int gsapi_set_param(long instance,
+ String param,
+ String value,
+ int paramType);
+```
+
+```
+public static int gsapi_set_param(long instance,
+ String param,
+ Object value,
+ int paramType);
+```
+
+
+### gsapi_get_param
+
+Retrieve the current value of a parameter.
+
+If an error occurs, the return value is negative. Otherwise the return value is the number of bytes required for storage of the value. Call once with value `NULL` to get the number of bytes required, then call again with value pointing to at least the required number of bytes where the value will be copied out. Note that the caller is required to know the type of value in order to get it. For all types other than [gs_spt_string], [gs_spt_name], and [gs_spt_parsed] knowing the type means you already know the size required.
+
+This call retrieves parameters/values that have made it to the device. Thus, any values set using [gs_spt_more_to_come] without a following call omitting that flag will not be retrieved. Similarly, attempting to get a parameter before [gsapi_init_with_args] has been called will not list any, even if [gsapi_set_param] has been used.
+
+Attempting to read a parameter that is not set will return `gs_error_undefined` (-21). Note that calling [gsapi_set_param] followed by [gsapi_get_param] may not find the value, if the device did not recognise the key as being one of its configuration keys.
+
+For the C documentation please refer to [Ghostscript get_param].
+
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_get_param(long instance,
+ byte[] param,
+ long value,
+ int paramType);
+```
+
+
+
+> **NOTE**<br>
+> There is a simpler utility method which allows for simpler `String` passing for the `param` argument.
+>
+
+
+Utility method:
+
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static int gsapi_get_param(long instance,
+ String param,
+ long value,
+ int paramType);
+```
+
+
+
+### gsapi_enumerate_params
+
+Enumerate the current parameters. Call repeatedly to list out the current parameters.
+
+The first call should have `iter` = NULL. Subsequent calls should pass the same pointer in so the iterator can be updated. Negative return codes indicate error, 0 success, and 1 indicates that there are no more keys to read. On success, key will be updated to point to a null terminated string with the key name that is guaranteed to be valid until the next call to [gsapi_enumerate_params]. If `type` is non NULL then the pointer `type` will be updated to have the `type` of the parameter.
+
+
+> **NOTE**<br>
+> Only one enumeration can happen at a time. Starting a second enumeration will reset the first.
+>
+
+The enumeration only returns parameters/values that have made it to the device. Thus, any values set using the [gs_spt_more_to_come] without a following call omitting that flag will not be retrieved. Similarly, attempting to enumerate parameters before [gsapi_init_with_args] has been called will not list any, even if [gsapi_set_param] has been used.
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_enumerate_params(long instance,
+ Reference<Long> iter,
+ Reference<byte[]> key,
+ Reference<Integer> paramType);
+```
+
+
+### gsapi_add_control_path
+
+Add a (case sensitive) path to one of the lists of [permitted paths] for file access.
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_add_control_path(long instance,
+ int type,
+ byte[] path);
+```
+
+> **NOTE**<br>
+> There is a simpler utility method which allows for simpler `String` passing for the `path` argument.
+>
+
+Utility method:
+
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static int gsapi_add_control_path(long instance,
+ int type,
+ String path);
+```
+
+### gsapi_remove_control_path
+
+Remove a (case sensitive) path from one of the lists of [permitted paths] for file access.
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native int gsapi_remove_control_path(long instance,
+ int type,
+ byte[] path);
+```
+
+> **NOTE**<br>
+> There is a simpler utility method which allows for simpler `String` passing for the `path` argument.
+>
+
+Utility method:
+
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static int gsapi_remove_control_path(long instance,
+ int type,
+ String path);
+```
+
+
+### gsapi_purge_control_paths
+
+Clear all the paths from one of the lists of [permitted paths] for file access.
+<div class="tag methodDefinition java"></div>
+
+```
+public static native void gsapi_purge_control_paths(long instance,
+ int type);
+```
+
+
+### gsapi_activate_path_control
+
+Enable/Disable path control (i.e. whether paths are checked against [permitted paths] before access is granted).
+
+<div class="tag methodDefinition java"></div>
+
+```
+public static native void gsapi_activate_path_control(long instance,
+ boolean enable);
+```
+
+
+### gsapi_is_path_control_active
+
+
+Query whether path control is activated or not.
+
+<div class="tag methodDefinition java"></div>
+
+
+```
+public static native boolean gsapi_is_path_control_active(long instance);
+```
+
+
+
+
+## Callback & Callout interfaces
+
+`gsjava.jar` also defines some functional interfaces for callbacks & callouts with `package com.artifex.gsjava.callback` which are defined as follows.
+
+### IStdInFunction
+
+<div class="tag functionalInterface java"></div>
+
+```
+public interface IStdInFunction {
+ /**
+ * @param callerHandle The caller handle.
+ * @param buf A string represented by a byte array.
+ * @param len The number of bytes to read.
+ * @return The number of bytes read, must be <code>len</code>/
+ */
+ public int onStdIn(long callerHandle,
+ byte[] buf,
+ int len);
+}
+```
+
+
+### IStdOutFunction
+
+<div class="tag functionalInterface java"></div>
+
+```
+public interface IStdOutFunction {
+ /**
+ * Called when something should be written to the standard
+ * output stream.
+ *
+ * @param callerHandle The caller handle.
+ * @param str The string represented by a byte array to write.
+ * @param len The number of bytes to write.
+ * @return The number of bytes written, must be <code>len</code>.
+ */
+ public int onStdOut(long callerHandle,
+ byte[] str,
+ int len);
+}
+```
+
+
+### IStdErrFunction
+
+<div class="tag functionalInterface java"></div>
+
+```
+public interface IStdErrFunction {
+ /**
+ * Called when something should be written to the standard error stream.
+ *
+ * @param callerHandle The caller handle.
+ * @param str The string represented by a byte array to write.
+ * @param len The length of bytes to be written.
+ * @return The amount of bytes written, must be <code>len</code>.
+ */
+ public int onStdErr(long callerHandle,
+ byte[] str,
+ int len);
+}
+```
+
+
+### IPollFunction
+
+<div class="tag functionalInterface java"></div>
+
+```
+public interface IPollFunction {
+ public int onPoll(long callerHandle);
+}
+```
+
+
+### ICalloutFunction
+
+<div class="tag functionalInterface java"></div>
+
+```
+public interface ICalloutFunction {
+ public int onCallout(long instance,
+ long calloutHandle,
+ byte[] deviceName,
+ int id,
+ int size,
+ long data);
+}
+```
+
+
+## GSInstance
+
+This is a utility class which makes Ghostscript calls easier by storing a Ghostscript instance and, optionally, a caller handle. Essentially the class acts as a handy wrapper for the standard [GSAPI] methods.
+
+
+### Constructors
+
+<div class="tag methodDefinition java"></div>
+
+```
+public GSInstance() throws IllegalStateException;
+```
+
+```
+public GSInstance(long callerHandle) throws IllegalStateException;
+```
+
+### delete_instance
+
+Wraps [gsapi_delete_instance].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public void delete_instance();
+```
+
+### set_stdio
+
+
+Wraps [gsapi_set_stdio].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int set_stdio(IStdInFunction stdin,
+ IStdOutFunction stdout,
+ IStdErrFunction stderr);
+```
+
+### set_poll
+
+Wraps [gsapi_set_poll].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int set_poll(IPollFunction pollfun);
+```
+
+### set_display_callback
+
+Wraps [gsapi_set_display_callback].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int set_display_callback(DisplayCallback displaycallback);
+```
+
+### register_callout
+
+Wraps [gsapi_register_callout].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int register_callout(ICalloutFunction callout);
+```
+
+
+### deregister_callout
+
+Wraps [gsapi_deregister_callout].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public void deregister_callout(ICalloutFunction callout);
+```
+
+
+### set_arg_encoding
+
+Wraps [gsapi_set_arg_encoding].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int set_arg_encoding(int encoding);
+```
+
+
+### set_default_device_list
+
+Wraps [gsapi_set_default_device_list].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int set_default_device_list(byte[] list,
+ int listlen);
+```
+
+### get_default_device_list
+
+Wraps [gsapi_get_default_device_list].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int get_default_device_list(Reference<byte[]> list,
+ Reference<Integer> listlen);
+```
+
+
+### init_with_args
+
+Wraps [gsapi_init_with_args].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int init_with_args(int argc,
+ byte[][] argv);
+```
+
+```
+public int init_with_args(String[] argv);
+```
+
+```
+public int init_with_args(List<String> argv);
+```
+
+
+### run_string_begin
+
+Wraps [gsapi_run_string_begin].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int run_string_begin(int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+
+### run_string_continue
+
+Wraps [gsapi_run_string_continue].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int run_string_continue(byte[] str,
+ int length,
+ int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+```
+public int run_string_continue(String str,
+ int length,
+ int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+### run_string
+
+Wraps [gsapi_run_string].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int run_string(byte[] str,
+ int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+```
+public int run_string(String str,
+ int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+
+### run_file
+
+Wraps [gsapi_run_file].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int run_file(byte[] fileName,
+ int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+```
+public int run_file(String filename,
+ int userErrors,
+ Reference<Integer> pExitCode);
+```
+
+### exit
+
+Wraps [gsapi_exit].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int exit();
+```
+
+
+### set_param
+
+Wraps [gsapi_set_param].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int set_param(byte[] param,
+ Object value,
+ int paramType);
+```
+
+```
+public int set_param(String param,
+ String value,
+ int paramType);
+```
+
+```
+public int set_param(String param,
+ Object value,
+ int paramType);
+```
+
+
+### get_param
+
+Wraps [gsapi_get_param].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int get_param(byte[] param,
+ long value,
+ int paramType);
+```
+
+```
+public int get_param(String param,
+ long value,
+ int paramType);
+```
+
+### enumerate_params
+
+Wraps [gsapi_enumerate_params].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int enumerate_params(Reference<Long> iter,
+ Reference<byte[]> key,
+ Reference<Integer> paramType);
+```
+
+
+### add_control_path
+
+Wraps [gsapi_add_control_path].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int add_control_path(int type,
+ byte[] path);
+```
+
+```
+public int add_control_path(int type,
+ String path);
+```
+
+### remove_control_path
+
+Wraps [gsapi_remove_control_path].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public int remove_control_path(int type,
+ byte[] path);
+```
+
+```
+public int remove_control_path(int type,
+ String path);
+```
+
+
+### purge_control_paths
+
+Wraps [gsapi_purge_control_paths].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public void purge_control_paths(int type);
+```
+
+
+### activate_path_control
+
+Wraps [gsapi_activate_path_control].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public void activate_path_control(boolean enable);
+```
+
+
+### is_path_control_active
+
+Wraps [gsapi_is_path_control_active].
+
+<div class="tag methodDefinition java"></div>
+
+```
+public boolean is_path_control_active();
+```
+
+## Utility classes
+
+The com.artifex.gsjava.util package contains a set of classes and interfaces which are used throughout the API.
+
+### com.artifex.gsjava.util.Reference
+
+`Reference<T>` is used in many of the Ghostscript calls, it stores a reference to a generic value of type `T`. This class exists to emulate pointers being passed to a native function. Its value can be fetched with `getValue()` and set with `setValue(T value)`.
+
+<div class="tag classDefinition java"></div>
+
+```
+public class Reference<T> {
+
+ private volatile T value;
+
+ public Reference() {
+ this(null);
+ }
+
+ public Reference(T value) {
+ this.value = value;
+ }
+
+ public void setValue(T value) {
+ this.value = value;
+ }
+
+ public T getValue() {
+ return value;
+ }
+ ...
+}
+```
+
+[Ghostscript parameters in C]: https://www.ghostscript.com/doc/current/Use.htm#Parameters
+[Ghostscript get_param]: https://www.ghostscript.com/doc/current/API.htm#get_param
+[permitted paths]: https://ghostscript.com/doc/current/Use.htm#Safer
+
+[GSAPI]: #gsapi
+[GSInstance]: #gsinstance
+[built]: java-intro.html#building-the-jar
+[properly linked]: java-intro.html#linking-the-jar
+[GSAPI.Revision]: #gsapi-revision
+
+
+[gsapi_set_stdio]: #gsapi_set_stdio
+[gsapi_set_poll]: #gsapi_set_poll
+[gsapi_set_display_callback]: #gsapi_set_display_callback
+[gsapi_deregister_callout]: #gsapi_deregister_callout
+[gsapi_run_string_begin]: #gsapi_run_string_begin
+[gsapi_run_file]: #gsapi_run_file
+[gsapi_add_control_path]: #gsapi_add_control_path
+[gsapi_remove_control_path]: #gsapi_remove_control_path
+[gsapi_purge_control_paths]: #gsapi_purge_control_paths
+[gsapi_activate_path_control]: #gsapi_activate_path_control
+[gsapi_is_path_control_active]: #gsapi_is_path_control_active
+[gsapi_revision]: #gsapi_revision
+[gsapi_exit]: #gsapi_exit
+[gsapi_new_instance]: #gsapi_new_instance
+[gsapi_set_stdio_with_handle]: #gsapi_set_stdio_with_handle
+[gsapi_set_poll_with_handle]: #gsapi_set_poll_with_handle
+[gsapi_register_callout]: #gsapi_register_callout
+[gsapi_init_with_args]: #gsapi_init_with_args
+[gsapi_delete_instance]: #gsapi_delete_instance
+[gsapi_exit]: #gsapi_exit
+[gsapi_run_string]: #gsapi_run_string
+[gsapi_run_string_continue]: #gsapi_run_string_continue
+[gs_set_param_type]: #gs_set_param_type
+[gs_spt_more_to_come]: #gs_set_param_type
+[gs_spt_string]: #gs_set_param_type
+[gs_spt_name]: #gs_set_param_type
+[gs_spt_parsed]: #gs_set_param_type
+[gsapi_set_param]: #gsapi_set_param
+[gsapi_get_param]: #gsapi_get_param
+[gsapi_enumerate_params]: #gsapi_enumerate_params
+[gsapi_set_arg_encoding]: #gsapi_set_arg_encoding
+[gsapi_set_default_device_list]: #gsapi_set_default_device_list
+[gsapi_get_default_device_list]: #gsapi_get_default_device_list
+
+
+[callout handler]: #callback-callout-interfaces
diff --git a/doc/language-bindings/md/java-intro.md b/doc/language-bindings/md/java-intro.md
new file mode 100644
index 00000000..fe6422fa
--- /dev/null
+++ b/doc/language-bindings/md/java-intro.md
@@ -0,0 +1,221 @@
+# Java overview
+
+<div class="banner">
+<div class="java-text"></div>
+<div class="vendor-logo java-logo"></div>
+</div>
+
+## About
+
+
+In the [GhostPDL repository] sample `Java` projects can be found in `/demos/java`.
+
+Within this location the following folders are of relevance:
+
+- [jni] `jni`
+- [gsjava] `gsjava`
+- [gstest] `gstest`
+- [gsviewer] `gsviewer`
+
+
+## Platform & setup
+
+
+### Building Ghostscript
+
+Ghostscript should be built as a shared library for your platform.
+
+See [Building Ghostscript].
+
+### jni: Building the Java Native Interface
+
+Before building the JNI ensure that Ghostscript has already been built for your platform and that you have JDK installed.
+
+The JNI is for use in the Java interface,
+this object must be placed somewhere on your Java PATH. On Windows, the DLL
+can be placed in the working directory, next to `gsjava.jar`.
+
+| Platform | JNI file |
+|---|---|
+|Windows|`gs_jni.dll`|
+|MacOS|`gs_jni.dylib`|
+|Linux / OpenBSD|`gs_jni.so`|
+
+
+#### Preparing your include folder
+
+The build scripts require the header `jni.h`, which defines
+all JNI functions, and `jni_md.h`, which defines all system-specific
+integer types. The build scripts expect an include folder relative to their location which contain these header files from your system.
+
+These headers are typically found in the following directories:
+
+
+| Platform | jni.h | jni_md.h |
+|---|---|---|
+|Windows|`C:\Program Files\Java\<JDK Install>\include\jni.h`|`C:\Program Files\Java\<JDK Install>\include\win32\jni_md.h`|
+|MacOS|`/Library/Java/JavaVirtualMachines/<JDK Install>/Contents/Home/include/jni.h`|`/Library/Java/JavaVirtualMachines/<JDK Install>/Contents/Home/include/darwin/jni_md.h`|
+|Linux|`/lib/jvm/<JDK Install>/include/jni.h`|`/lib/jvm/<JDK Install>/include/linux/jni_md.h`|
+
+
+Once your `include` folder has been located folder you can copy it and place it in your `ghostpdl/demos/java/jni/gs_jni` folder.
+
+Your build scripts should now be ready to run as they will be able to find the required JNI header files in their own relative include folder.
+
+
+#### Building on Windows
+
+The `jni` folder contains a Visual Studio Solution file `/jni/gs_jni/gs_jni.sln` which you should use to build the required JNI `gs_jni.dll` library file.
+
+With the project open in Visual Studio, select the required architecture from the drop down - then right click on 'gs_jni' in the solution explorer and choose "Build".
+
+#### Building on MacOS
+
+On your command line, navigate to `ghostpdl/demos/java/jni/gs_jni` and ensure that the build script is executable and then run it, with:
+
+```
+chmod +x build_darwin.sh
+./build_darwin.sh
+```
+
+#### Building on Linux
+
+On your command line, navigate to `ghostpdl/demos/java/jni/gs_jni` and ensure that the build script is executable and then run it, with:
+
+```
+chmod +x build_linux.sh
+./build_linux.sh
+```
+
+### gsjava: Building the JAR
+
+
+#### Building with the command line
+
+Navigate to `ghostpdl/demos/java/gsjava` and use the following:
+
+| Platform | Run file|
+|---|---|
+|Windows| `build_win32.bat` |
+|MacOS| `build_darwin.sh` |
+|Linux| `build_linux.sh` |
+
+> **NOTE**<br>
+> `gsjava` has a dependancy on [jni], please ensure that `gs_jni` is able to be built beforehand.
+
+#### Building with Eclipse
+
+Alternatively you can use [Eclipse] to build the JAR file.
+
+Using [Eclipse] import the source folder `gsjava` as a project and select `Export > Java > JAR File` as shown in the screenshot example below:
+
+![Eclipse export JAR](images/export-jar.png)
+
+#### Linking the JAR
+
+The built JAR should be properly linked within your project Java Build Path as follows:
+
+![Linking the JAR](images/linking-jar.png)
+
+## Demo projects
+
+### gstest
+
+This project can be opened in [Eclipse] and used to test the Ghostscript API. The sample here simply sets up an instance of Ghostscript and then sets and gets some parameters accordingly.
+
+
+### gsviewer
+
+This project can be used to test the Ghostscript API alongside a UI which handles opening PostScript and PDF files. The sample application here allows for file browsing and Ghostscript file viewing.
+
+Below is a screenshot of the sample application with a PDF open:
+
+![gsviewer UI](images/gsviewer.png)
+
+
+To run the project navigate to the `demos/java/gsviewer` location and ensure that the required libraries are in the directory:
+
+
+| Platform | Ghostscript library file | JNI library file |
+|---|---|---|
+|Windows|`gpdldll64.dll`|`gs_jni.dll`|
+|MacOS|`libgpdl.dylib`|`gs_jni.dylib`|
+|Linux / OpenBSD|`libgpdl.so` (this may have been built as `libgs.so`, so it should be copied into this directory and renamed to `libgpdl.so`) |`gs_jni.so`|
+
+
+#### Building on Windows
+
+Run the `build_win32.bat` script.
+
+#### Running on Windows
+
+To run, open `gsviewer.jar` either through File Explorer or in the command line through the following command:
+
+```
+java -jar gsviewer.jar
+```
+
+#### Building on MacOS
+
+On your command line, navigate to `ghostpdl/demos/java/gsviewer` and ensure that the build script is executable and then run it, with:
+
+```
+chmod +x build_darwin.sh
+./build_darwin.sh
+```
+
+This will automatically build `gs_jni.dylib` (in the `ghostpdl/demos/java/jni/gs_jni/` location) and `gsjava.jar` `gsviewer.jar` in the `gsviewer` directory.
+
+#### Running on MacOS
+
+Ensure that the Ghostscript library exists in the `gsviewer` directory. (Copy and move the built library from `ghostpdl/sobin` as required).
+
+Ensure that the run script is executable and then run it, with:
+
+```
+chmod +x start_darwin.sh
+./start_darwin.sh
+```
+
+#### Building on Linux
+
+On your command line, navigate to `ghostpdl/demos/java/gsviewer` and ensure that the build script is executable and then run it, with:
+
+```
+chmod +x build_linux.sh
+./build_linux.sh
+```
+
+This will automatically build `gs_jni.so` (in the `ghostpdl/demos/java/jni/gs_jni/` location) and `gsjava.jar` `gsviewer.jar` in the `gsviewer` directory.
+
+> **NOTE**<br>
+> On Linux, when using OpenJDK, the property "assistive_technologies" may
+need to be modified for the Java code to build. It can be modified by
+editing the "accessibility.properties" file. This is located at:
+>
+> `/etc/java-8-openjdk/accessibility.properties`
+>
+
+#### Running on Linux
+
+Ensure that the Ghostscript library exists in the `gsviewer` directory. (Copy and move the built library from `ghostpdl/sobin` as required).
+
+Ensure that the run script is executable and then run it, with:
+
+```
+chmod +x start_linux.sh
+./start_linux.sh
+```
+
+
+
+
+
+[jni]: #jni-building-the-java-native-interface
+[gsjava]: #gsjava-building-the-jar
+[gstest]: #gstest
+[gsviewer]: #gsviewer
+[Building Ghostscript]: index.html#building-ghostscript
+[GhostPDL repository]: https://github.com/ArtifexSoftware/ghostpdl
+
+[Eclipse]: https://www.eclipse.org/eclipseide/
diff --git a/doc/language-bindings/md/python-gsapi.md b/doc/language-bindings/md/python-gsapi.md
new file mode 100644
index 00000000..7a11da5d
--- /dev/null
+++ b/doc/language-bindings/md/python-gsapi.md
@@ -0,0 +1,813 @@
+# gsapi.py
+
+<div class="banner">
+<div class="python-text"></div>
+<div class="vendor-logo python-logo"></div>
+</div>
+
+
+## About
+
+`gsapi.py` is the `Python` binding into the Ghostscript `C` library.
+
+Assuming that the [Ghostscript library has been built] for your project then `gsapi` should be imported into your own `Python` scripts for API usage.
+
+<div class="tag sampleCode python"></div>
+
+```
+import gsapi
+```
+
+
+
+## gsapi
+
+### Overview
+
+Implemented using Python's ctypes module.
+
+All functions have the same name as the `C` function that they wrap.
+
+Functions raise a `GSError` exception if the underlying function returned a
+negative [error code].
+
+Functions that don't have out-params return `None`. Out-params are returned
+directly (using tuples if there are more than one).
+
+
+### Return codes
+
+`gsapi_run_*` and `gsapi_exit` methods return an `int` code which can be interpreted as follows:
+
+| code | status |
+|---|---|
+|`0`| no error |
+|`gsConstants.E_QUIT`| "quit" has been executed. This is not an error. [gsapi_exit] must be called next |
+|`<0` | error |
+
+>**NOTE**<br>
+> For full detail on these return code please see:
+https://www.ghostscript.com/doc/current/API.htm#return_codes
+>
+
+
+### gsapi_revision
+
+Returns a `gsapi_revision_t`.
+
+This method returns the revision numbers and strings of the Ghostscript interpreter library; you should call it before any other interpreter library functions to make sure that the correct version of the Ghostscript interpreter has been loaded.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_revision()
+```
+
+<div class="tag sampleCode python"></div>
+
+```
+version_info = gsapi.gsapi_revision()
+print (version_info)
+```
+
+### gsapi_new_instance
+
+Returns a new instance of Ghostscript to be used with other `gsapi_*()` functions.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_new_instance(caller_handle)
+```
+
+#### Parameters
+
+`caller_handle`: Typically unused, but is passed to callbacks e.g. via `gsapi_set_stdio()`. Must be convertible to a `C void*`, so `None` or an
+ integer is ok but other types such as strings will fail.
+
+
+<div class="tag sampleCode python"></div>
+
+```
+instance = gsapi.gsapi_new_instance(1)
+```
+
+
+### gsapi_delete_instance
+
+Destroy an instance of Ghostscript. Before you call this, Ghostscript should ensure to have finished any processes.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_delete_instance(instance)
+```
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+<div class="tag sampleCode python"></div>
+
+```
+gsapi.gsapi_delete_instance(instance)
+```
+
+
+
+### gsapi_set_stdio
+
+Set the callback functions for `stdio`, together with the handle to use in the callback functions.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_set_stdio(instance, stdin_fn, stdout_fn, stderr_fn)
+```
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`stdin_fn`: If not `None`, will be called with:
+- `(caller_handle, text, len_)`:
+ - `caller_handle`: As passed originally to `gsapi_new_instance()`.
+ - `text`: A `ctypes.LP_c_char` of length `len_`.
+
+`stdout_fn` and `stderr_fn`:If not `None`, called with:
+- `(caller_handle, text)`:
+ - `caller_handle`: As passed originally to `gsapi_new_instance()`.
+ - `text`: A Python bytes object.
+
+Should return the number of bytes of `text` that they handled; for convenience `None` is converted to `len(text)`.
+
+<div class="tag sampleCode python"></div>
+
+```
+def stdout_fn(caller_handle, bytes_):
+ sys.stdout.write(bytes_.decode('latin-1'))
+
+gsapi.gsapi_set_stdio(instance, None, stdout_fn, None)
+print('gsapi_set_stdio() ok.')
+```
+
+
+### gsapi_set_poll
+
+Set the callback function for polling.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_set_poll(instance, poll_fn)
+```
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`poll_fn`: Will be called with `caller_handle` as passed
+ to `gsapi_new_instance()`.
+
+<div class="tag sampleCode python"></div>
+
+```
+def poll_fn(caller_handle, bytes_):
+ sys.stdout.write(bytes_.decode('latin-1'))
+
+gsapi.gsapi_set_poll(instance, poll_fn)
+print('gsapi_set_poll() ok.')
+```
+
+### gsapi_set_display_callback
+
+Sets the [display] callback.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_set_display_callback(instance, callback)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`callback`: Must be a `display_callback` instance.
+
+<div class="tag sampleCode python"></div>
+
+```
+d = display_callback()
+gsapi.gsapi_set_display_callback(instance, d)
+print('gsapi_set_display_callback() ok.')
+```
+
+### gsapi_set_arg_encoding
+
+Set the encoding used for the interpretation of all subsequent arguments supplied via the `GhostAPI` interface on this instance. By default we expect args to be in encoding `0` (the 'local' encoding for this OS). On Windows this means "the currently selected codepage". On Linux this typically means `utf8`. This means that omitting to call this function will leave Ghostscript running exactly as it always has.
+
+This must be called after [gsapi_new_instance] and before [gsapi_init_with_args].
+
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_set_arg_encoding(instance, encoding)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`encoding`: Encoding must be one of:
+
+|Encoding enum|Value|
+|---|---|
+|`GS_ARG_ENCODING_LOCAL`|0|
+|`GS_ARG_ENCODING_UTF8`|1|
+|`GS_ARG_ENCODING_UTF16LE`|2|
+
+<div class="tag sampleCode python"></div>
+
+```
+gsapi.gsapi_set_arg_encoding(instance, gsapi.GS_ARG_ENCODING_UTF8)
+```
+
+>**NOTE**<br>
+> Please note that use of the 'local' encoding (`GS_ARG_ENCODING_LOCAL`) is now deprecated and should be avoided in new code.
+
+### gsapi_set_default_device_list
+
+Set the string containing the list of default device names, for example "display x11alpha x11 bbox". Allows the calling application to influence which device(s) Ghostscript will try, in order, in its selection of the default device. This must be called after [gsapi_new_instance] and before [gsapi_init_with_args].
+
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_set_default_device_list(instance, list_)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`list_`: A string of device names.
+
+<div class="tag sampleCode python"></div>
+
+```
+gsapi.gsapi_set_default_device_list(instance, 'bmp256 bmp32b bmpgray cdeskjet cdj1600 cdj500')
+```
+
+
+### gsapi_get_default_device_list
+
+Returns a string containing the list of default device names. This must be called after [gsapi_new_instance] and before [gsapi_init_with_args].
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_get_default_device_list(instance)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+<div class="tag sampleCode python"></div>
+
+```
+device_list = gsapi.gsapi_get_default_device_list(instance)
+print(device_list)
+```
+
+
+### gsapi_init_with_args
+
+To initialise the interpreter, pass your `instance` of Ghostscript and your argument variables with `args`.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_init_with_args(instance, args)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`args`: A list/tuple of strings.
+
+<div class="tag sampleCode python"></div>
+
+```
+in_filename = 'tiger.eps'
+out_filename = 'tiger.pdf'
+params = ['gs', '-dNOPAUSE', '-dBATCH', '-sDEVICE=pdfwrite',
+ '-o', out_filename, '-f', in_filename]
+gsapi.gsapi_init_with_args(instance, params)
+```
+
+### gsapi_run_*
+
+Returns an [exit code] or an exception on error.
+
+There is a 64 KB length limit on any buffer submitted to a `gsapi_run_*` function for processing. If you have more than 65535 bytes of input then you must split it into smaller pieces and submit each in a separate [gsapi_run_string_continue] call.
+
+> **NOTE**<br>
+> All these functions return an [exit code]
+
+### gsapi_run_string_begin
+
+Starts a `run_string_` operation.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_run_string_begin(instance, user_errors)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`user_errors`: An `int`, for more see [user errors parameter explained].
+
+
+<div class="tag sampleCode python"></div>
+
+```
+exitcode = gsapi.gsapi_run_string_begin(instance, 0)
+```
+
+### gsapi_run_string_continue
+
+Processes file byte data (`str_`) to feed as chunks into Ghostscript. This method should typically be called within a buffer context.
+
+> **NOTE**<br>
+> An exception is _not_ raised for the `gs_error_NeedInput` return code.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_run_string_continue(instance, str_, user_errors)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`str_`: Should be either a Python string or a bytes object. If the former,
+it is converted into a bytes object using `utf-8` encoding.
+
+`user_errors`: An `int`, for more see [user errors parameter explained].
+
+<div class="tag sampleCode python"></div>
+
+```
+exitcode = gsapi.gsapi_run_string_continue(instance, data, 0)
+```
+
+> **NOTE**<br>
+> For the return code, we don't raise an exception for `gs_error_NeedInput`.
+
+### gsapi_run_string_with_length
+
+Processes file byte data (`str_`) to feed into Ghostscript when the `length` is known and the file byte data is immediately available.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_run_string_with_length(instance, str_, length, user_errors)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`str_`: Should be either a Python string or a bytes object. If the former,
+it is converted into a bytes object using `utf-8` encoding.
+
+`length`: An `int` representing the length of `gsapi_run_string_with_length`.
+
+`user_errors`: An `int`, for more see [user errors parameter explained].
+
+<div class="tag sampleCode python"></div>
+
+```
+gsapi.gsapi_run_string_with_length(instance,"hello",5,0)
+```
+
+
+> **NOTE**<br>
+> If using this method then ensure that the file byte data will fit into a single (<64k) buffer.
+>
+
+
+### gsapi_run_string
+
+Processes file byte data (`str_`) to feed into Ghostscript.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_run_string(instance, str_, user_errors)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`str_`: Should be either a Python string or a bytes object. If the former,
+it is converted into a bytes object using `utf-8` encoding.
+
+`user_errors`: An `int`, for more see [user errors parameter explained].
+
+<div class="tag sampleCode python"></div>
+
+```
+gsapi.gsapi_run_string(instance,"hello",0)
+```
+
+
+> **NOTE**<br>
+> This method can only work on a standard, null terminated C string.
+>
+
+
+### gsapi_run_string_end
+
+Ends a `run_string_` operation.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_run_string_end(instance, user_errors)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`user_errors`: An `int`, for more see [user errors parameter explained].
+
+<div class="tag sampleCode python"></div>
+
+```
+exitcode = gsapi.gsapi_run_string_end(instance, 0)
+```
+
+
+
+### gsapi_run_file
+
+Runs a file through Ghostscript.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_run_file(instance, filename, user_errors)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`filename`: String representing file name.
+
+`user_errors`: An `int`, for more see [user errors parameter explained].
+
+<div class="tag sampleCode python"></div>
+
+```
+in_filename = 'tiger.eps'
+gsapi.gsapi_run_file(instance, in_filename, 0)
+```
+
+
+> **NOTE**<br>
+> This will process the supplied input file with any previously supplied [argument parameters].
+>
+
+
+### gsapi_exit
+
+Exit the interpreter. This must be called on shutdown if [gsapi_init_with_args] has been called, and just before [gsapi_delete_instance].
+
+<div class="tag methodDefinition python"></div>
+
+
+```
+def gsapi_exit(instance)
+```
+
+<div class="tag sampleCode python"></div>
+
+```
+gsapi.gsapi_exit(instance)
+```
+
+
+### gsapi_set_param
+
+Sets a parameter. Broadly, this is equivalent to setting a parameter using -d, -s or -p on the command line. This call cannot be made during a [gsapi_run_string] operation.
+
+Parameters in this context are not the same as 'arguments' as processed by [gsapi_init_with_args], but often the same thing can be achieved. For example, with [gsapi_init_with_args], we can pass "-r200" to change the resolution. Broadly the same thing can be achieved by using [gsapi_set_param] to set a parsed value of "<</HWResolution [ 200.0 200.0 ]>>".
+
+Internally, when we set a parameter, we perform an `initgraphics` operation. This means that using [gsapi_set_param] other than at the start of a page is likely to give unexpected results.
+
+Attempting to set a parameter that the device does not recognise will be silently ignored, and that parameter will not be found in subsequent [gsapi_get_param] calls.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_set_param(instance, param, value, type_=None)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`param`: Name of parameter, either a bytes or a str; if str it is encoded using latin-1.
+
+`value`: A bool, int, float, bytes or str. If str, it is encoded into a bytes using utf-8.
+
+
+`type_`: If `type_` is not `None`, `value` must be convertible to the Python type implied by `type_`:
+
+#### Parameter list
+
+| `type_` | Python type(s) |
+|---|---|
+|gs_spt_null | [Ignored] |
+|gs_spt_bool | bool |
+|gs_spt_int | int |
+|gs_spt_float | float |
+|gs_spt_name | [Error] |
+|gs_spt_string | (bytes, str) |
+|gs_spt_long | int |
+|gs_spt_i64 | int |
+|gs_spt_size_t | int |
+|gs_spt_parsed | (bytes, str) |
+|gs_spt_more_to_come | (bytes, str) |
+
+
+An exception is raised if `type_` is an integer type and `value` is outside its range.
+
+If `type_` is `None`, we choose something suitable for type of `value`:
+
+| Python type of `value` | `type_` |
+|---|---|
+| bool | gs_spt_bool |
+| int | gs_spt_i64 |
+| float | gs_spt_float |
+| bytes | gs_spt_parsed |
+| str | gs_spt_parsed (encoded with utf-8) |
+
+If `value` is `None`, we use `gs_spt_null`.
+
+Otherwise `type_` must be a `gs_spt_*` except for `gs_spt_invalid` and `gs_spt_name`.
+
+> **NOTE**<br>
+> This implementation supports automatic inference of type by looking at the type of `value`.
+>
+
+<div class="tag sampleCode python"></div>
+
+```
+set_margins = gsapi.gsapi_set_param(instance, "Margins", "[10 10]")
+```
+
+
+> **NOTE**<br>
+> For more on the `C` implementation of parameters see: [Ghostscript parameters in C].
+>
+
+
+### gsapi_get_param
+
+Retrieve the current value of a parameter.
+
+If an error occurs, the return value is negative. Otherwise the return value is the number of bytes required for storage of the value. Call once with value `NULL` to get the number of bytes required, then call again with value pointing to at least the required number of bytes where the value will be copied out. Note that the caller is required to know the type of value in order to get it. For all types other than [gs_spt_string], [gs_spt_name], and [gs_spt_parsed] knowing the type means you already know the size required.
+
+This call retrieves parameters/values that have made it to the device. Thus, any values set using [gs_spt_more_to_come] without a following call omitting that flag will not be retrieved. Similarly, attempting to get a parameter before [gsapi_init_with_args] has been called will not list any, even if [gsapi_set_param] has been used.
+
+Attempting to read a parameter that is not set will return `gs_error_undefined` (-21). Note that calling [gsapi_set_param] followed by [gsapi_get_param] may not find the value, if the device did not recognise the key as being one of its configuration keys.
+
+For the `C` documentation please refer to [Ghostscript get_param].
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_get_param(instance, param, type_=None, encoding=None)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`param`: Name of parameter, either a `bytes` or `str`; if a `str` it is encoded using `latin-1`.
+
+`type_`: A `gs_spt_*` constant or `None`. If `None` we try each `gs_spt_*` until one succeeds; if none succeeds we raise the last error.
+
+`encoding`: Only affects string values. If `None` we return a `bytes` object, otherwise it should be the encoding to use to decode into a string, e.g. 'utf-8'.
+
+<div class="tag sampleCode python"></div>
+
+```
+get_margins = gsapi.gsapi_get_param(instance, "Margins")
+```
+
+
+### gsapi_enumerate_params
+
+
+Enumerate the current parameters on the instance of Ghostscript.
+
+Returns an array of `(key, value)` for each parameter. `key` is decoded as `latin-1`.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_enumerate_params(instance)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+<div class="tag sampleCode python"></div>
+
+```
+for param, type_ in gsapi.gsapi_enumerate_params(instance):
+ val = gsapi.gsapi_get_param(instance,param, encoding='utf-8')
+ print('%-24s : %s' % (param, val))
+```
+
+
+
+
+
+### gsapi_add_control_path
+
+
+Add a (case sensitive) path to one of the lists of [permitted paths] for file access.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_add_control_path(instance, type_, path)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`type_`: An `int` which must be one of:
+
+|Enum|Value|
+|---|---|
+|GS_PERMIT_FILE_READING|0|
+|GS_PERMIT_FILE_WRITING|1|
+|GS_PERMIT_FILE_CONTROL|2|
+
+`path`: A `string` representing the file path.
+
+<div class="tag sampleCode python"></div>
+
+```
+gsapi.gsapi_add_control_path(instance, gsapi.GS_PERMIT_FILE_READING, "/docs/secure/")
+```
+
+
+
+### gsapi_remove_control_path
+
+Remove a (case sensitive) path from one of the lists of [permitted paths] for file access.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_remove_control_path(instance, type_, path)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`type_`: An `int` representing the permission type.
+
+`path`: A `string` representing the file path.
+
+<div class="tag sampleCode python"></div>
+
+```
+gsapi.gsapi_remove_control_path(instance, gsapi.GS_PERMIT_FILE_READING, "/docs/secure/")
+```
+
+
+
+
+### gsapi_purge_control_paths
+
+Clear all the paths from one of the lists of [permitted paths] for file access.
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_purge_control_paths(instance, type_)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`type_`: An `int` representing the permission type.
+
+
+<div class="tag sampleCode python"></div>
+
+```
+gsapi.gsapi_purge_control_paths(instance, gsapi.GS_PERMIT_FILE_READING)
+```
+
+
+### gsapi_activate_path_control
+
+Enable/Disable path control (i.e. whether paths are checked against [permitted paths] before access is granted).
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_activate_path_control(instance, enable)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+`enable`: `bool` to enable/disable path control.
+
+<div class="tag sampleCode python"></div>
+
+```
+gsapi.gsapi_activate_path_control(instance, true)
+```
+
+### gsapi_is_path_control_active
+
+Query whether path control is activated or not.
+
+
+<div class="tag methodDefinition python"></div>
+
+```
+def gsapi_is_path_control_active(instance)
+```
+
+#### Parameters
+
+`instance`: Your instance of Ghostscript.
+
+<div class="tag sampleCode python"></div>
+
+```
+isActive = gsapi.gsapi_is_path_control_active(instance)
+```
+
+## Notes
+
+#### 1: User errors parameter
+
+The `user_errors` argument is normally set to zero to indicate that errors should be handled through the normal mechanisms within the interpreted code. If set to a negative value, the functions will return an error code directly to the caller, bypassing the interpreted language. The interpreted language's error handler is bypassed, regardless of `user_errors` parameter, for the `gs_error_interrupt` generated when the polling callback returns a negative value. A positive `user_errors` is treated the same as zero.
+
+[Ghostscript library has been built]: python-intro.html#platform-setup
+
+[display]: https://ghostscript.com/doc/current/API.htm#display
+[Ghostscript parameters in C]: https://www.ghostscript.com/doc/current/Use.htm#Parameters
+[Ghostscript get_param]: https://www.ghostscript.com/doc/current/API.htm#get_param
+
+
+[error code]: #return-codes
+[exit code]: #return-codes
+[return code]: #return-codes
+[user errors parameter explained]: #1-user-errors-parameter
+
+[argument parameters]: #gsapi_init_with_args
+[gsapi_new_instance]: #gsapi_new_instance
+[gsapi_delete_instance]: #gsapi_delete_instance
+[gsapi_init_with_args]: #gsapi_init_with_args
+[gsapi_run_string_continue]: #gsapi_run_string_continue
+[gsapi_run_string_begin]: #gsapi_run_string_begin
+[gsapi_run_string]: #gsapi_run_string
+[gsapi_exit]: #gsapi_exit
+
+[permitted paths]: https://ghostscript.com/doc/current/Use.htm#Safer
+
+
+[gsapi_set_param]: #gsapi_set_param
+[gsapi_get_param]: #gsapi_get_param
+[gsapi_enumerate_params]: #gsapi_enumerate_params
+
+[gs_spt_string]: #parameter-list
+[gs_spt_name]: #parameter-list
+[gs_spt_parsed]: #parameter-list
+[gs_spt_more_to_come]: #parameter-list
diff --git a/doc/language-bindings/md/python-intro.md b/doc/language-bindings/md/python-intro.md
new file mode 100644
index 00000000..5ec452ff
--- /dev/null
+++ b/doc/language-bindings/md/python-intro.md
@@ -0,0 +1,76 @@
+# Python overview
+
+<div class="banner">
+<div class="python-text"></div>
+<div class="vendor-logo python-logo"></div>
+</div>
+
+## About
+
+The `Python` API is provided by the file [gsapi.py] - this is the binding to the Ghostscript `C` library.
+
+In the [GhostPDL repository] sample `Python` examples can be found in `/demos/python/examples.py`.
+
+## Platform & setup
+
+### Building Ghostscript
+
+Ghostscript should be built as a shared library for your platform.
+
+See [Building Ghostscript].
+
+## Specifying the Ghostscript shared library
+
+Two environmental variables can be used to specify where to find the Ghostscript shared library.
+
+`GSAPI_LIB` sets the exact path of the Ghostscript shared library, otherwise, `GSAPI_LIBDIR` sets the directory containing the Ghostscript shared library.
+
+If neither is defined we will use the OS's default location(s) for shared libraries.
+
+If `GSAPI_LIB` is not defined, the leafname of the shared library is inferred
+from the OS type - `libgs.so` on Unix, `libgs.dylib` on MacOS, `gsdll64.dll` on Windows 64.
+
+
+## API test
+
+The `gsapi.py` file that provides the `Python` bindings can also be used to test the bindings, by running it directly.
+
+Assuming that your Ghostscript library has successfully been created, then from the root of your `ghostpdl` checkout run:
+
+
+#### Windows
+
+<div class="tag shellCommand"> from ghostpdl</div>
+
+```
+// Run gsapi.py as a test script in a cmd.exe window:
+set GSAPI_LIBDIR=debugbin&& python ./demos/python/gsapi.py
+
+// Run gsapi.py as a test script in a PowerShell window:
+cmd /C "set GSAPI_LIBDIR=debugbin&& python ./demos/python/gsapi.py"
+```
+
+#### Linux/OpenBSD/MacOS
+
+<div class="tag shellCommand"> from ghostpdl</div>
+
+```
+// Run gsapi.py as a test script:
+GSAPI_LIBDIR=sodebugbin ./demos/python/gsapi.py
+```
+
+
+If there are no errors then this will have validated that the Ghostscript library is present & operational.
+
+
+
+
+[Python]: https://www.python.org/
+[Brew]: https://brew.sh/
+[GNU]: https://www.gnu.org/
+[gsapi.py]: python-gsapi
+[Building Ghostscript]: index.html#building-ghostscript
+[display]: https://ghostscript.com/doc/current/API.htm#display
+
+
+[GhostPDL repository]: https://github.com/ArtifexSoftware/ghostpdl
diff --git a/doc/language-bindings/python-gsapi.html b/doc/language-bindings/python-gsapi.html
new file mode 100644
index 00000000..d6d97ec3
--- /dev/null
+++ b/doc/language-bindings/python-gsapi.html
@@ -0,0 +1,598 @@
+<html lang="en">
+ <head>
+ <title>Ghostscript language bindings</title>
+ <meta http-equiv="content-type" content="text/html; charset=utf-8">
+ <meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width">
+ <link href="https://fonts.googleapis.com/css?family=Source+Sans+Pro:200,200i,300,300i,400,400i,600,600i,700,700i,900,900i" rel="stylesheet">
+ <link rel="shortcut icon" type="image/png" href="../images/favicon.png">
+ <link href="css/default.css" rel="stylesheet" type="text/css" />
+ <script type="text/javascript" src="js/default.js"></script>
+ </head>
+
+ <body>
+
+ <header><h1></h1><div class="menu-icon" onclick="javascript:showMenu();"></div></header>
+
+ <div id="burger-menu">
+ <div class="navigation">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link selected"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+ </div>
+ <div class="main">
+
+ <div class="left">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link"><a href="python-intro.html">Overview</a></div>
+ <div class="link selected"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+
+ <div class="middle">
+
+<!-- note: don't tab indent <article> as it has <pre> code which will have its layout adversly affected -->
+<article class="markdown-body entry-content"><h1 id="gsapi-py">gsapi.py</h1>
+<div class="banner">
+<div class="python-text"></div>
+<div class="vendor-logo python-logo"></div>
+</div>
+
+
+<h2 id="about">About</h2>
+<p><code>gsapi.py</code> is the <code>Python</code> binding into the Ghostscript <code>C</code> library.</p>
+<p>Assuming that the <a href="python-intro.html#platform-setup">Ghostscript library has been built</a> for your project then <code>gsapi</code> should be imported into your own <code>Python</code> scripts for API usage.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>import gsapi</code></pre><h2 id="gsapi">gsapi</h2>
+<h3 id="overview">Overview</h3>
+<p>Implemented using Python's ctypes module.</p>
+<p>All functions have the same name as the <code>C</code> function that they wrap.</p>
+<p>Functions raise a <code>GSError</code> exception if the underlying function returned a
+negative <a href="#return-codes">error code</a>.</p>
+<p>Functions that don't have out-params return <code>None</code>. Out-params are returned
+directly (using tuples if there are more than one).</p>
+<h3 id="return-codes">Return codes</h3>
+<p><code>gsapi_run_*</code> and <code>gsapi_exit</code> methods return an <code>int</code> code which can be interpreted as follows:</p>
+<table>
+<thead>
+<tr>
+<th>code</th>
+<th>status</th>
+</tr>
+</thead>
+<tbody><tr>
+<td><code>0</code></td>
+<td>no error</td>
+</tr>
+<tr>
+<td><code>gsConstants.E_QUIT</code></td>
+<td>"quit" has been executed. This is not an error. <a href="#gsapi_exit">gsapi_exit</a> must be called next</td>
+</tr>
+<tr>
+<td><code>&lt;0</code></td>
+<td>error</td>
+</tr>
+</tbody></table>
+<blockquote>
+<p><strong>NOTE</strong><br>
+For full detail on these return code please see:
+<a href="https://www.ghostscript.com/doc/current/API.htm#return_codes">https://www.ghostscript.com/doc/current/API.htm#return_codes</a></p>
+</blockquote>
+<h3 id="gsapi_revision">gsapi_revision</h3>
+<p>Returns a <code>gsapi_revision_t</code>.</p>
+<p>This method returns the revision numbers and strings of the Ghostscript interpreter library; you should call it before any other interpreter library functions to make sure that the correct version of the Ghostscript interpreter has been loaded.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_revision()</code></pre><div class="tag sampleCode python"></div>
+
+<pre><code>version_info = gsapi.gsapi_revision()
+print (version_info)</code></pre><h3 id="gsapi_new_instance">gsapi_new_instance</h3>
+<p>Returns a new instance of Ghostscript to be used with other <code>gsapi_*()</code> functions.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_new_instance(caller_handle)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>caller_handle</code>: Typically unused, but is passed to callbacks e.g. via <code>gsapi_set_stdio()</code>. Must be convertible to a <code>C void*</code>, so <code>None</code> or an
+ integer is ok but other types such as strings will fail.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>instance = gsapi.gsapi_new_instance(1)</code></pre><h3 id="gsapi_delete_instance">gsapi_delete_instance</h3>
+<p>Destroy an instance of Ghostscript. Before you call this, Ghostscript should ensure to have finished any processes.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_delete_instance(instance)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>gsapi.gsapi_delete_instance(instance)</code></pre><h3 id="gsapi_set_stdio">gsapi_set_stdio</h3>
+<p>Set the callback functions for <code>stdio</code>, together with the handle to use in the callback functions.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_set_stdio(instance, stdin_fn, stdout_fn, stderr_fn)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>stdin_fn</code>: If not <code>None</code>, will be called with:</p>
+<ul>
+<li><code>(caller_handle, text, len_)</code>:<ul>
+<li><code>caller_handle</code>: As passed originally to <code>gsapi_new_instance()</code>.</li>
+<li><code>text</code>: A <code>ctypes.LP_c_char</code> of length <code>len_</code>.</li>
+</ul>
+</li>
+</ul>
+<p><code>stdout_fn</code> and <code>stderr_fn</code>:If not <code>None</code>, called with:</p>
+<ul>
+<li><code>(caller_handle, text)</code>:<ul>
+<li><code>caller_handle</code>: As passed originally to <code>gsapi_new_instance()</code>.</li>
+<li><code>text</code>: A Python bytes object.</li>
+</ul>
+</li>
+</ul>
+<p>Should return the number of bytes of <code>text</code> that they handled; for convenience <code>None</code> is converted to <code>len(text)</code>.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>def stdout_fn(caller_handle, bytes_):
+ sys.stdout.write(bytes_.decode('latin-1'))
+
+gsapi.gsapi_set_stdio(instance, None, stdout_fn, None)
+print('gsapi_set_stdio() ok.')</code></pre><h3 id="gsapi_set_poll">gsapi_set_poll</h3>
+<p>Set the callback function for polling.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_set_poll(instance, poll_fn)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>poll_fn</code>: Will be called with <code>caller_handle</code> as passed
+ to <code>gsapi_new_instance()</code>.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>def poll_fn(caller_handle, bytes_):
+ sys.stdout.write(bytes_.decode('latin-1'))
+
+gsapi.gsapi_set_poll(instance, poll_fn)
+print('gsapi_set_poll() ok.')</code></pre><h3 id="gsapi_set_display_callback">gsapi_set_display_callback</h3>
+<p>Sets the <a href="https://ghostscript.com/doc/current/API.htm#display">display</a> callback.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_set_display_callback(instance, callback)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>callback</code>: Must be a <code>display_callback</code> instance.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>d = display_callback()
+gsapi.gsapi_set_display_callback(instance, d)
+print('gsapi_set_display_callback() ok.')</code></pre><h3 id="gsapi_set_arg_encoding">gsapi_set_arg_encoding</h3>
+<p>Set the encoding used for the interpretation of all subsequent arguments supplied via the <code>GhostAPI</code> interface on this instance. By default we expect args to be in encoding <code>0</code> (the 'local' encoding for this OS). On Windows this means "the currently selected codepage". On Linux this typically means <code>utf8</code>. This means that omitting to call this function will leave Ghostscript running exactly as it always has.</p>
+<p>This must be called after <a href="#gsapi_new_instance">gsapi_new_instance</a> and before <a href="#gsapi_init_with_args">gsapi_init_with_args</a>.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_set_arg_encoding(instance, encoding)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>encoding</code>: Encoding must be one of:</p>
+<table>
+<thead>
+<tr>
+<th>Encoding enum</th>
+<th>Value</th>
+</tr>
+</thead>
+<tbody><tr>
+<td><code>GS_ARG_ENCODING_LOCAL</code></td>
+<td>0</td>
+</tr>
+<tr>
+<td><code>GS_ARG_ENCODING_UTF8</code></td>
+<td>1</td>
+</tr>
+<tr>
+<td><code>GS_ARG_ENCODING_UTF16LE</code></td>
+<td>2</td>
+</tr>
+</tbody></table>
+<div class="tag sampleCode python"></div>
+
+<pre><code>gsapi.gsapi_set_arg_encoding(instance, gsapi.GS_ARG_ENCODING_UTF8)</code></pre><blockquote>
+<p><strong>NOTE</strong><br>
+Please note that use of the 'local' encoding (<code>GS_ARG_ENCODING_LOCAL</code>) is now deprecated and should be avoided in new code.</p>
+</blockquote>
+<h3 id="gsapi_set_default_device_list">gsapi_set_default_device_list</h3>
+<p>Set the string containing the list of default device names, for example "display x11alpha x11 bbox". Allows the calling application to influence which device(s) Ghostscript will try, in order, in its selection of the default device. This must be called after <a href="#gsapi_new_instance">gsapi_new_instance</a> and before <a href="#gsapi_init_with_args">gsapi_init_with_args</a>.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_set_default_device_list(instance, list_)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>list_</code>: A string of device names.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>gsapi.gsapi_set_default_device_list(instance, 'bmp256 bmp32b bmpgray cdeskjet cdj1600 cdj500')</code></pre><h3 id="gsapi_get_default_device_list">gsapi_get_default_device_list</h3>
+<p>Returns a string containing the list of default device names. This must be called after <a href="#gsapi_new_instance">gsapi_new_instance</a> and before <a href="#gsapi_init_with_args">gsapi_init_with_args</a>.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_get_default_device_list(instance)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>device_list = gsapi.gsapi_get_default_device_list(instance)
+print(device_list)</code></pre><h3 id="gsapi_init_with_args">gsapi_init_with_args</h3>
+<p>To initialise the interpreter, pass your <code>instance</code> of Ghostscript and your argument variables with <code>args</code>.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_init_with_args(instance, args)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>args</code>: A list/tuple of strings.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>in_filename = 'tiger.eps'
+out_filename = 'tiger.pdf'
+params = ['gs', '-dNOPAUSE', '-dBATCH', '-sDEVICE=pdfwrite',
+ '-o', out_filename, '-f', in_filename]
+gsapi.gsapi_init_with_args(instance, params)</code></pre><h3 id="gsapi_run_-">gsapi_run_*</h3>
+<p>Returns an <a href="#return-codes">exit code</a> or an exception on error.</p>
+<p>There is a 64 KB length limit on any buffer submitted to a <code>gsapi_run_*</code> function for processing. If you have more than 65535 bytes of input then you must split it into smaller pieces and submit each in a separate <a href="#gsapi_run_string_continue">gsapi_run_string_continue</a> call.</p>
+<blockquote>
+<p><strong>NOTE</strong><br>
+All these functions return an <a href="#return-codes">exit code</a></p>
+</blockquote>
+<h3 id="gsapi_run_string_begin">gsapi_run_string_begin</h3>
+<p>Starts a <code>run_string_</code> operation.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_run_string_begin(instance, user_errors)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>user_errors</code>: An <code>int</code>, for more see <a href="#1-user-errors-parameter">user errors parameter explained</a>.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>exitcode = gsapi.gsapi_run_string_begin(instance, 0)</code></pre><h3 id="gsapi_run_string_continue">gsapi_run_string_continue</h3>
+<p>Processes file byte data (<code>str_</code>) to feed as chunks into Ghostscript. This method should typically be called within a buffer context.</p>
+<blockquote>
+<p><strong>NOTE</strong><br>
+An exception is <em>not</em> raised for the <code>gs_error_NeedInput</code> return code.</p>
+</blockquote>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_run_string_continue(instance, str_, user_errors)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>str_</code>: Should be either a Python string or a bytes object. If the former,
+it is converted into a bytes object using <code>utf-8</code> encoding.</p>
+<p><code>user_errors</code>: An <code>int</code>, for more see <a href="#1-user-errors-parameter">user errors parameter explained</a>.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>exitcode = gsapi.gsapi_run_string_continue(instance, data, 0)</code></pre><blockquote>
+<p><strong>NOTE</strong><br>
+For the return code, we don't raise an exception for <code>gs_error_NeedInput</code>.</p>
+</blockquote>
+<h3 id="gsapi_run_string_with_length">gsapi_run_string_with_length</h3>
+<p>Processes file byte data (<code>str_</code>) to feed into Ghostscript when the <code>length</code> is known and the file byte data is immediately available.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_run_string_with_length(instance, str_, length, user_errors)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>str_</code>: Should be either a Python string or a bytes object. If the former,
+it is converted into a bytes object using <code>utf-8</code> encoding.</p>
+<p><code>length</code>: An <code>int</code> representing the length of <code>gsapi_run_string_with_length</code>.</p>
+<p><code>user_errors</code>: An <code>int</code>, for more see <a href="#1-user-errors-parameter">user errors parameter explained</a>.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>gsapi.gsapi_run_string_with_length(instance,"hello",5,0)</code></pre><blockquote>
+<p><strong>NOTE</strong><br>
+If using this method then ensure that the file byte data will fit into a single (&lt;64k) buffer.</p>
+</blockquote>
+<h3 id="gsapi_run_string">gsapi_run_string</h3>
+<p>Processes file byte data (<code>str_</code>) to feed into Ghostscript.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_run_string(instance, str_, user_errors)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>str_</code>: Should be either a Python string or a bytes object. If the former,
+it is converted into a bytes object using <code>utf-8</code> encoding.</p>
+<p><code>user_errors</code>: An <code>int</code>, for more see <a href="#1-user-errors-parameter">user errors parameter explained</a>.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>gsapi.gsapi_run_string(instance,"hello",0)</code></pre><blockquote>
+<p><strong>NOTE</strong><br>
+This method can only work on a standard, null terminated C string.</p>
+</blockquote>
+<h3 id="gsapi_run_string_end">gsapi_run_string_end</h3>
+<p>Ends a <code>run_string_</code> operation.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_run_string_end(instance, user_errors)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>user_errors</code>: An <code>int</code>, for more see <a href="#1-user-errors-parameter">user errors parameter explained</a>.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>exitcode = gsapi.gsapi_run_string_end(instance, 0)</code></pre><h3 id="gsapi_run_file">gsapi_run_file</h3>
+<p>Runs a file through Ghostscript.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_run_file(instance, filename, user_errors)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>filename</code>: String representing file name.</p>
+<p><code>user_errors</code>: An <code>int</code>, for more see <a href="#1-user-errors-parameter">user errors parameter explained</a>.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>in_filename = 'tiger.eps'
+gsapi.gsapi_run_file(instance, in_filename, 0)</code></pre><blockquote>
+<p><strong>NOTE</strong><br>
+This will process the supplied input file with any previously supplied <a href="#gsapi_init_with_args">argument parameters</a>.</p>
+</blockquote>
+<h3 id="gsapi_exit">gsapi_exit</h3>
+<p>Exit the interpreter. This must be called on shutdown if <a href="#gsapi_init_with_args">gsapi_init_with_args</a> has been called, and just before <a href="#gsapi_delete_instance">gsapi_delete_instance</a>.</p>
+<div class="tag methodDefinition python"></div>
+
+
+<pre><code>def gsapi_exit(instance)</code></pre><div class="tag sampleCode python"></div>
+
+<pre><code>gsapi.gsapi_exit(instance)</code></pre><h3 id="gsapi_set_param">gsapi_set_param</h3>
+<p>Sets a parameter. Broadly, this is equivalent to setting a parameter using -d, -s or -p on the command line. This call cannot be made during a <a href="#gsapi_run_string">gsapi_run_string</a> operation.</p>
+<p>Parameters in this context are not the same as 'arguments' as processed by <a href="#gsapi_init_with_args">gsapi_init_with_args</a>, but often the same thing can be achieved. For example, with <a href="#gsapi_init_with_args">gsapi_init_with_args</a>, we can pass "-r200" to change the resolution. Broadly the same thing can be achieved by using <a href="#gsapi_set_param">gsapi_set_param</a> to set a parsed value of "&lt;&lt;/HWResolution [ 200.0 200.0 ]&gt;&gt;".</p>
+<p>Internally, when we set a parameter, we perform an <code>initgraphics</code> operation. This means that using <a href="#gsapi_set_param">gsapi_set_param</a> other than at the start of a page is likely to give unexpected results.</p>
+<p>Attempting to set a parameter that the device does not recognise will be silently ignored, and that parameter will not be found in subsequent <a href="#gsapi_get_param">gsapi_get_param</a> calls.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_set_param(instance, param, value, type_=None)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>param</code>: Name of parameter, either a bytes or a str; if str it is encoded using latin-1.</p>
+<p><code>value</code>: A bool, int, float, bytes or str. If str, it is encoded into a bytes using utf-8.</p>
+<p><code>type_</code>: If <code>type_</code> is not <code>None</code>, <code>value</code> must be convertible to the Python type implied by <code>type_</code>:</p>
+<h4 id="parameter-list">Parameter list</h4>
+<table>
+<thead>
+<tr>
+<th><code>type_</code></th>
+<th>Python type(s)</th>
+</tr>
+</thead>
+<tbody><tr>
+<td>gs_spt_null</td>
+<td>[Ignored]</td>
+</tr>
+<tr>
+<td>gs_spt_bool</td>
+<td>bool</td>
+</tr>
+<tr>
+<td>gs_spt_int</td>
+<td>int</td>
+</tr>
+<tr>
+<td>gs_spt_float</td>
+<td>float</td>
+</tr>
+<tr>
+<td>gs_spt_name</td>
+<td>[Error]</td>
+</tr>
+<tr>
+<td>gs_spt_string</td>
+<td>(bytes, str)</td>
+</tr>
+<tr>
+<td>gs_spt_long</td>
+<td>int</td>
+</tr>
+<tr>
+<td>gs_spt_i64</td>
+<td>int</td>
+</tr>
+<tr>
+<td>gs_spt_size_t</td>
+<td>int</td>
+</tr>
+<tr>
+<td>gs_spt_parsed</td>
+<td>(bytes, str)</td>
+</tr>
+<tr>
+<td>gs_spt_more_to_come</td>
+<td>(bytes, str)</td>
+</tr>
+</tbody></table>
+<p>An exception is raised if <code>type_</code> is an integer type and <code>value</code> is outside its range.</p>
+<p>If <code>type_</code> is <code>None</code>, we choose something suitable for type of <code>value</code>:</p>
+<table>
+<thead>
+<tr>
+<th>Python type of <code>value</code></th>
+<th><code>type_</code></th>
+</tr>
+</thead>
+<tbody><tr>
+<td>bool</td>
+<td>gs_spt_bool</td>
+</tr>
+<tr>
+<td>int</td>
+<td>gs_spt_i64</td>
+</tr>
+<tr>
+<td>float</td>
+<td>gs_spt_float</td>
+</tr>
+<tr>
+<td>bytes</td>
+<td>gs_spt_parsed</td>
+</tr>
+<tr>
+<td>str</td>
+<td>gs_spt_parsed (encoded with utf-8)</td>
+</tr>
+</tbody></table>
+<p>If <code>value</code> is <code>None</code>, we use <code>gs_spt_null</code>.</p>
+<p>Otherwise <code>type_</code> must be a <code>gs_spt_*</code> except for <code>gs_spt_invalid</code> and <code>gs_spt_name</code>.</p>
+<blockquote>
+<p><strong>NOTE</strong><br>
+This implementation supports automatic inference of type by looking at the type of <code>value</code>.</p>
+</blockquote>
+<div class="tag sampleCode python"></div>
+
+<pre><code>set_margins = gsapi.gsapi_set_param(instance, "Margins", "[10 10]")</code></pre><blockquote>
+<p><strong>NOTE</strong><br>
+For more on the <code>C</code> implementation of parameters see: <a href="https://www.ghostscript.com/doc/current/Use.htm#Parameters">Ghostscript parameters in C</a>.</p>
+</blockquote>
+<h3 id="gsapi_get_param">gsapi_get_param</h3>
+<p>Retrieve the current value of a parameter.</p>
+<p>If an error occurs, the return value is negative. Otherwise the return value is the number of bytes required for storage of the value. Call once with value <code>NULL</code> to get the number of bytes required, then call again with value pointing to at least the required number of bytes where the value will be copied out. Note that the caller is required to know the type of value in order to get it. For all types other than <a href="#parameter-list">gs_spt_string</a>, <a href="#parameter-list">gs_spt_name</a>, and <a href="#parameter-list">gs_spt_parsed</a> knowing the type means you already know the size required.</p>
+<p>This call retrieves parameters/values that have made it to the device. Thus, any values set using <a href="#parameter-list">gs_spt_more_to_come</a> without a following call omitting that flag will not be retrieved. Similarly, attempting to get a parameter before <a href="#gsapi_init_with_args">gsapi_init_with_args</a> has been called will not list any, even if <a href="#gsapi_set_param">gsapi_set_param</a> has been used.</p>
+<p>Attempting to read a parameter that is not set will return <code>gs_error_undefined</code> (-21). Note that calling <a href="#gsapi_set_param">gsapi_set_param</a> followed by <a href="#gsapi_get_param">gsapi_get_param</a> may not find the value, if the device did not recognise the key as being one of its configuration keys.</p>
+<p>For the <code>C</code> documentation please refer to <a href="https://www.ghostscript.com/doc/current/API.htm#get_param">Ghostscript get_param</a>.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_get_param(instance, param, type_=None, encoding=None)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>param</code>: Name of parameter, either a <code>bytes</code> or <code>str</code>; if a <code>str</code> it is encoded using <code>latin-1</code>.</p>
+<p><code>type_</code>: A <code>gs_spt_*</code> constant or <code>None</code>. If <code>None</code> we try each <code>gs_spt_*</code> until one succeeds; if none succeeds we raise the last error.</p>
+<p><code>encoding</code>: Only affects string values. If <code>None</code> we return a <code>bytes</code> object, otherwise it should be the encoding to use to decode into a string, e.g. 'utf-8'.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>get_margins = gsapi.gsapi_get_param(instance, "Margins")</code></pre><h3 id="gsapi_enumerate_params">gsapi_enumerate_params</h3>
+<p>Enumerate the current parameters on the instance of Ghostscript.</p>
+<p>Returns an array of <code>(key, value)</code> for each parameter. <code>key</code> is decoded as <code>latin-1</code>.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_enumerate_params(instance)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>for param, type_ in gsapi.gsapi_enumerate_params(instance):
+ val = gsapi.gsapi_get_param(instance,param, encoding='utf-8')
+ print('%-24s : %s' % (param, val))</code></pre><h3 id="gsapi_add_control_path">gsapi_add_control_path</h3>
+<p>Add a (case sensitive) path to one of the lists of <a href="https://ghostscript.com/doc/current/Use.htm#Safer">permitted paths</a> for file access.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_add_control_path(instance, type_, path)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>type_</code>: An <code>int</code> which must be one of:</p>
+<table>
+<thead>
+<tr>
+<th>Enum</th>
+<th>Value</th>
+</tr>
+</thead>
+<tbody><tr>
+<td>GS_PERMIT_FILE_READING</td>
+<td>0</td>
+</tr>
+<tr>
+<td>GS_PERMIT_FILE_WRITING</td>
+<td>1</td>
+</tr>
+<tr>
+<td>GS_PERMIT_FILE_CONTROL</td>
+<td>2</td>
+</tr>
+</tbody></table>
+<p><code>path</code>: A <code>string</code> representing the file path.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>gsapi.gsapi_add_control_path(instance, gsapi.GS_PERMIT_FILE_READING, "/docs/secure/")</code></pre><h3 id="gsapi_remove_control_path">gsapi_remove_control_path</h3>
+<p>Remove a (case sensitive) path from one of the lists of <a href="https://ghostscript.com/doc/current/Use.htm#Safer">permitted paths</a> for file access.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_remove_control_path(instance, type_, path)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>type_</code>: An <code>int</code> representing the permission type.</p>
+<p><code>path</code>: A <code>string</code> representing the file path.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>gsapi.gsapi_remove_control_path(instance, gsapi.GS_PERMIT_FILE_READING, "/docs/secure/")</code></pre><h3 id="gsapi_purge_control_paths">gsapi_purge_control_paths</h3>
+<p>Clear all the paths from one of the lists of <a href="https://ghostscript.com/doc/current/Use.htm#Safer">permitted paths</a> for file access.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_purge_control_paths(instance, type_)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>type_</code>: An <code>int</code> representing the permission type.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>gsapi.gsapi_purge_control_paths(instance, gsapi.GS_PERMIT_FILE_READING)</code></pre><h3 id="gsapi_activate_path_control">gsapi_activate_path_control</h3>
+<p>Enable/Disable path control (i.e. whether paths are checked against <a href="https://ghostscript.com/doc/current/Use.htm#Safer">permitted paths</a> before access is granted).</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_activate_path_control(instance, enable)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<p><code>enable</code>: <code>bool</code> to enable/disable path control.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>gsapi.gsapi_activate_path_control(instance, true)</code></pre><h3 id="gsapi_is_path_control_active">gsapi_is_path_control_active</h3>
+<p>Query whether path control is activated or not.</p>
+<div class="tag methodDefinition python"></div>
+
+<pre><code>def gsapi_is_path_control_active(instance)</code></pre><h4 id="parameters">Parameters</h4>
+<p><code>instance</code>: Your instance of Ghostscript.</p>
+<div class="tag sampleCode python"></div>
+
+<pre><code>isActive = gsapi.gsapi_is_path_control_active(instance)</code></pre><h2 id="notes">Notes</h2>
+<h4 id="1-user-errors-parameter">1: User errors parameter</h4>
+<p>The <code>user_errors</code> argument is normally set to zero to indicate that errors should be handled through the normal mechanisms within the interpreted code. If set to a negative value, the functions will return an error code directly to the caller, bypassing the interpreted language. The interpreted language's error handler is bypassed, regardless of <code>user_errors</code> parameter, for the <code>gs_error_interrupt</code> generated when the polling callback returns a negative value. A positive <code>user_errors</code> is treated the same as zero.</p>
+</article>
+
+
+ </div><!-- / middle -->
+
+ <div class="right">
+
+ <div class="link"><a href="#about">About</a></div>
+ <div class="link"><a href="#gsapi">gsapi</a></div>
+ <div class="sub-link"><a href="#overview">Overview</a></div>
+ <div class="sub-link"><a href="#return-codes">Return codes</a></div>
+ <div class="sub-link"><a href="#gsapi_revision">gsapi_revision</a></div>
+ <div class="sub-link"><a href="#gsapi_new_instance">gsapi_new_instance</a></div>
+ <div class="sub-link"><a href="#gsapi_delete_instance">gsapi_delete_instance</a></div>
+ <div class="sub-link"><a href="#gsapi_set_stdio">gsapi_set_stdio</a></div>
+ <div class="sub-link"><a href="#gsapi_set_poll">gsapi_set_poll</a></div>
+ <div class="sub-link"><a href="#gsapi_set_display_callback">gsapi_set_display_callback</a></div>
+ <div class="sub-link"><a href="#gsapi_set_arg_encoding">gsapi_set_arg_encoding</a></div>
+ <div class="sub-link"><a href="#gsapi_set_default_device_list">gsapi_set_default_device_list</a></div>
+ <div class="sub-link"><a href="#gsapi_get_default_device_list">gsapi_get_default_device_list</a></div>
+ <div class="sub-link"><a href="#gsapi_init_with_args">gsapi_init_with_args</a></div>
+ <div class="sub-link"><a href="#gsapi_run_-">gsapi_run_*</a></div>
+ <div class="sub-link"><a href="#gsapi_run_string_begin">gsapi_run_string_begin</a></div>
+ <div class="sub-link"><a href="#gsapi_run_string_continue">gsapi_run_string_continue</a></div>
+ <div class="sub-link"><a href="#gsapi_run_string_with_length">gsapi_run_string_with_length</a></div>
+ <div class="sub-link"><a href="#gsapi_run_string">gsapi_run_string</a></div>
+ <div class="sub-link"><a href="#gsapi_run_string_end">gsapi_run_string_end</a></div>
+ <div class="sub-link"><a href="#gsapi_run_file">gsapi_run_file</a></div>
+ <div class="sub-link"><a href="#gsapi_exit">gsapi_exit</a></div>
+ <div class="sub-link"><a href="#gsapi_set_param">gsapi_set_param</a></div>
+ <div class="sub-link"><a href="#gsapi_get_param">gsapi_get_param</a></div>
+ <div class="sub-link"><a href="#gsapi_enumerate_params">gsapi_enumerate_params</a></div>
+ <div class="sub-link"><a href="#gsapi_add_control_path">gsapi_add_control_path</a></div>
+ <div class="sub-link"><a href="#gsapi_remove_control_path">gsapi_remove_control_path</a></div>
+ <div class="sub-link"><a href="#gsapi_purge_control_paths">gsapi_purge_control_paths</a></div>
+ <div class="sub-link"><a href="#gsapi_activate_path_control">gsapi_activate_path_control</a></div>
+ <div class="sub-link"><a href="#gsapi_is_path_control_active">gsapi_is_path_control_active</a></div>
+ <div class="link"><a href="#notes">Notes</a></div>
+ </div>
+
+ </div>
+
+ <footer></footer>
+
+ </body>
+
+</html>
diff --git a/doc/language-bindings/python-intro.html b/doc/language-bindings/python-intro.html
new file mode 100644
index 00000000..6236219b
--- /dev/null
+++ b/doc/language-bindings/python-intro.html
@@ -0,0 +1,114 @@
+<html lang="en">
+ <head>
+ <title>Ghostscript language bindings</title>
+ <meta http-equiv="content-type" content="text/html; charset=utf-8">
+ <meta name="viewport" content="user-scalable=no, initial-scale=1, maximum-scale=1, minimum-scale=1, width=device-width">
+ <link href="https://fonts.googleapis.com/css?family=Source+Sans+Pro:200,200i,300,300i,400,400i,600,600i,700,700i,900,900i" rel="stylesheet">
+ <link rel="shortcut icon" type="image/png" href="../images/favicon.png">
+ <link href="css/default.css" rel="stylesheet" type="text/css" />
+ <script type="text/javascript" src="js/default.js"></script>
+ </head>
+
+ <body>
+
+ <header><h1></h1><div class="menu-icon" onclick="javascript:showMenu();"></div></header>
+
+ <div id="burger-menu">
+ <div class="navigation">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link selected"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+ </div>
+ <div class="main">
+
+ <div class="left">
+ <div class="title first">Introduction</div>
+ <div class="link"><a href="index.html">About our APIs</a></div>
+ <div class="link"><a href="demo-code.html">Demo code</a></div>
+
+ <div class="title">C#</div>
+ <div class="link"><a href="c-sharp-intro.html">Overview</a></div>
+ <div class="link"><a href="c-sharp-ghost-api.html">GhostAPI</a></div>
+ <div class="link"><a href="c-sharp-ghost-net.html">GhostNET</a></div>
+ <div class="link"><a href="c-sharp-ghost-mono.html">GhostMono</a></div>
+
+ <div class="title">Java</div>
+ <div class="link"><a href="java-intro.html">Overview</a></div>
+ <div class="link"><a href="java-gsjavajar.html">gsjava.jar</a></div>
+
+ <div class="title">Python</div>
+ <div class="link selected"><a href="python-intro.html">Overview</a></div>
+ <div class="link"><a href="python-gsapi.html">gsapi.py</a></div>
+ </div>
+
+ <div class="middle">
+
+<!-- note: don't tab indent <article> as it has <pre> code which will have its layout adversly affected -->
+<article class="markdown-body entry-content"><h1 id="python-overview">Python overview</h1>
+<div class="banner">
+<div class="python-text"></div>
+<div class="vendor-logo python-logo"></div>
+</div>
+
+<h2 id="about">About</h2>
+<p>The <code>Python</code> API is provided by the file <a href="python-gsapi">gsapi.py</a> - this is the binding to the Ghostscript <code>C</code> library.</p>
+<p>In the <a href="https://github.com/ArtifexSoftware/ghostpdl">GhostPDL repository</a> sample <code>Python</code> examples can be found in <code>/demos/python/examples.py</code>.</p>
+<h2 id="platform-setup">Platform &amp; setup</h2>
+<h3 id="building-ghostscript">Building Ghostscript</h3>
+<p>Ghostscript should be built as a shared library for your platform.</p>
+<p>See <a href="index.html#building-ghostscript">Building Ghostscript</a>.</p>
+<h2 id="specifying-the-ghostscript-shared-library">Specifying the Ghostscript shared library</h2>
+<p>Two environmental variables can be used to specify where to find the Ghostscript shared library.</p>
+<p><code>GSAPI_LIB</code> sets the exact path of the Ghostscript shared library, otherwise, <code>GSAPI_LIBDIR</code> sets the directory containing the Ghostscript shared library.</p>
+<p>If neither is defined we will use the OS's default location(s) for shared libraries.</p>
+<p>If <code>GSAPI_LIB</code> is not defined, the leafname of the shared library is inferred
+from the OS type - <code>libgs.so</code> on Unix, <code>libgs.dylib</code> on MacOS, <code>gsdll64.dll</code> on Windows 64.</p>
+<h2 id="api-test">API test</h2>
+<p>The <code>gsapi.py</code> file that provides the <code>Python</code> bindings can also be used to test the bindings, by running it directly.</p>
+<p>Assuming that your Ghostscript library has successfully been created, then from the root of your <code>ghostpdl</code> checkout run:</p>
+<h4 id="windows">Windows</h4>
+<div class="tag shellCommand"> from ghostpdl</div>
+
+<pre><code>// Run gsapi.py as a test script in a cmd.exe window:
+set GSAPI_LIBDIR=debugbin&amp;&amp; python ./demos/python/gsapi.py
+
+// Run gsapi.py as a test script in a PowerShell window:
+cmd /C "set GSAPI_LIBDIR=debugbin&amp;&amp; python ./demos/python/gsapi.py"</code></pre><h4 id="linux-openbsd-macos">Linux/OpenBSD/MacOS</h4>
+<div class="tag shellCommand"> from ghostpdl</div>
+
+<pre><code>// Run gsapi.py as a test script:
+GSAPI_LIBDIR=sodebugbin ./demos/python/gsapi.py</code></pre><p>If there are no errors then this will have validated that the Ghostscript library is present &amp; operational.</p>
+</article>
+
+ </div> <!-- /middle -->
+
+ <div class="right">
+ <div class="link"><a href="#about">About</a></div>
+ <div class="link"><a href="#platform-setup">Platform & setup</a></div>
+ <div class="sub-link"><a href="#building-ghostscript">Building Ghostscript</a></div>
+ <div class="link"><a href="#specifying-the-ghostscript-shared-library">Specifying the Ghostscript shared library</a></div>
+ <div class="link"><a href="#api-test">API test</a></div>
+ </div>
+
+ </div>
+
+ <footer></footer>
+
+ </body>
+
+</html>
diff --git a/doc/sample_downscale_device.htm b/doc/sample_downscale_device.htm
index 31340887..1061b7c1 100644
--- a/doc/sample_downscale_device.htm
+++ b/doc/sample_downscale_device.htm
@@ -253,7 +253,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
<!--FINISH EDITING HERE-->
diff --git a/doc/subclass.htm b/doc/subclass.htm
index 09dc9403..a3f9d144 100644
--- a/doc/subclass.htm
+++ b/doc/subclass.htm
@@ -511,103 +511,41 @@ Now we've got all the garbage collector machinery out of the way we can deal wit
/* Device procedures */<br />
static dev_proc_text_begin(black_text_text_begin);
</code>
+<p>Then we define the procedure to initialize the device procs:
+</p>
+<code>
+void black_text_init_dev_procs(gx_device *dev)<br />
+{<br />
+&nbsp;&nbsp;&nbsp;&nbsp;default_subclass_initialize_device_procs(dev);<br />
+<br />
+&nbsp;&nbsp;&nbsp;&nbsp;set_dev_proc(dev, text_begin, black_text_text_begin);<br />
+}
+</code>
<p>Then we define the actual device:
</p>
<code>
const
-gx_device_black_text gs_black_text_device =
-{
-<dd> std_device_dci_type_body(gx_device_black_text, 0, "black_text", &st_black_text_device,<br />
- MAX_COORD, MAX_COORD,<br />
- MAX_RESOLUTION, MAX_RESOLUTION,<br />
- 1, 8, 255, 0, 256, 1),<br />
- {default_subclass_open_device,<br />
- default_subclass_get_initial_matrix,<br />
- default_subclass_sync_output, /* sync_output */<br />
- default_subclass_output_page,<br />
- default_subclass_close_device,<br />
- default_subclass_map_rgb_color,<br />
- default_subclass_map_color_rgb,<br />
- default_subclass_fill_rectangle,<br />
- default_subclass_tile_rectangle, /* tile_rectangle */<br />
- default_subclass_copy_mono,<br />
- default_subclass_copy_color,<br />
- default_subclass_draw_line, /* draw_line */<br />
- default_subclass_get_bits, /* get_bits */<br />
- default_subclass_get_params,<br />
- default_subclass_put_params,<br />
- default_subclass_map_cmyk_color,<br />
- default_subclass_get_xfont_procs, /* get_xfont_procs */<br />
- default_subclass_get_xfont_device, /* get_xfont_device */<br />
- default_subclass_map_rgb_alpha_color,<br />
- default_subclass_get_page_device,<br />
- default_subclass_get_alpha_bits, /* get_alpha_bits */<br />
- default_subclass_copy_alpha,<br />
- default_subclass_get_band, /* get_band */<br />
- default_subclass_copy_rop, /* copy_rop */<br />
- default_subclass_fill_path,<br />
- default_subclass_stroke_path,<br />
- default_subclass_fill_mask,<br />
- default_subclass_fill_trapezoid,<br />
- default_subclass_fill_parallelogram,<br />
- default_subclass_fill_triangle,<br />
- default_subclass_draw_thin_line,<br />
- default_subclass_begin_image,<br />
- default_subclass_image_data, /* image_data */<br />
- default_subclass_end_image, /* end_image */<br />
- default_subclass_strip_tile_rectangle,<br />
- default_subclass_strip_copy_rop,<br />
- default_subclass_get_clipping_box, /* get_clipping_box */<br />
- default_subclass_begin_typed_image,<br />
- default_subclass_get_bits_rectangle, /* get_bits_rectangle */<br />
- default_subclass_map_color_rgb_alpha,<br />
- default_subclass_create_compositor,<br />
- default_subclass_get_hardware_params, /* get_hardware_params */<br />
- black_text_text_begin,<br />
- default_subclass_finish_copydevice, /* finish_copydevice */<br />
- default_subclass_begin_transparency_group, /* begin_transparency_group */<br />
- default_subclass_end_transparency_group, /* end_transparency_group */<br />
- default_subclass_begin_transparency_mask, /* begin_transparency_mask */<br />
- default_subclass_end_transparency_mask, /* end_transparency_mask */<br />
- default_subclass_discard_transparency_layer, /* discard_transparency_layer */<br />
- default_subclass_get_color_mapping_procs, /* get_color_mapping_procs */<br />
- default_subclass_get_color_comp_index, /* get_color_comp_index */<br />
- default_subclass_encode_color, /* encode_color */<br />
- default_subclass_decode_color, /* decode_color */<br />
- default_subclass_pattern_manage, /* pattern_manage */<br />
- default_subclass_fill_rectangle_hl_color, /* fill_rectangle_hl_color */<br />
- default_subclass_include_color_space, /* include_color_space */<br />
- default_subclass_fill_linear_color_scanline, /* fill_linear_color_scanline */<br />
- default_subclass_fill_linear_color_trapezoid, /* fill_linear_color_trapezoid */<br />
- default_subclass_fill_linear_color_triangle, /* fill_linear_color_triangle */<br />
- default_subclass_update_spot_equivalent_colors, /* update_spot_equivalent_colors */<br />
- default_subclass_ret_devn_params, /* ret_devn_params */<br />
- default_subclass_fillpage, /* fillpage */<br />
- default_subclass_push_transparency_state, /* push_transparency_state */<br />
- default_subclass_pop_transparency_state, /* pop_transparency_state */<br />
- default_subclass_put_image, /* put_image */<br />
- default_subclass_dev_spec_op, /* dev_spec_op */<br />
- default_subclass_copy_planes, /* copy_planes */<br />
- default_subclass_get_profile, /* get_profile */<br />
- default_subclass_set_graphics_type_tag, /* set_graphics_type_tag */<br />
- default_subclass_strip_copy_rop2,<br />
- default_subclass_strip_tile_rect_devn,<br />
- default_subclass_copy_alpha_hl_color,<br />
- default_subclass_process_page
-</dd> }
+gx_device_black_text gs_black_text_device =<br />
+{<br />
+&nbsp;&nbsp;&nbsp;&nbsp;std_device_dci_type_body(gx_device_black_text, 0, "black_text", &st_black_text_device,<br />
+&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;MAX_COORD, MAX_COORD,<br />
+&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;MAX_RESOLUTION, MAX_RESOLUTION,<br />
+&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;1, 8, 255, 0, 256, 1),<br />
+&nbsp;&nbsp;&nbsp;&nbsp;black_text_initialize_device_procs<br />
};
</code>
-<p>Much of this is simply boilerplate, defining the device methods as being the default methods for a subclassing device. The
- exception being the text_begin method. The main body of the macro is:</p>
+<p>The call to default_subclass_initialize_device_procs assigns the
+default methods for a subclassing device. We then override the
+text_begin method to our specific one. The main body of the macro is:</p>
<code>
const
-gx_device_black_text gs_black_text_device =
-{
-<dd> std_device_dci_type_body(gx_device_black_text, 0, "black_text", &st_black_text_device,<br />
- MAX_COORD, MAX_COORD,<br />
- MAX_RESOLUTION, MAX_RESOLUTION,<br />
- 1, 8, 255, 0, 256, 1),
-</dd></code>
+gx_device_black_text gs_black_text_device =<br />
+{<br />
+&nbsp;&nbsp;&nbsp;&nbsp;std_device_dci_type_body(gx_device_black_text, 0, "black_text", &st_black_text_device,<br />
+&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;MAX_COORD, MAX_COORD,<br />
+&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;MAX_RESOLUTION, MAX_RESOLUTION,<br />
+&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;1, 8, 255, 0, 256, 1),
+</code>
<p>This simply defines an instance of the 'gx_device_black_text' structure (which is simply a gx_device_s structure) initialised
using a macro (yet another family of macros). Here we use the 'st_black_text_device' structure descriptor we created above,
and some dummy values for the resolution, colour depth etc. Since this device doesn't do rendering these values aren't useful
@@ -802,7 +740,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/doc/thirdparty.htm b/doc/thirdparty.htm
index fca4ca7d..cb4aa718 100644
--- a/doc/thirdparty.htm
+++ b/doc/thirdparty.htm
@@ -223,7 +223,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.54.0, 30 March 2021
+<small>Ghostscript version 9.55.0, 27 September 2021
<!-- [3.0 end visible trailer] ============================================= -->
diff --git a/extract/Makefile b/extract/Makefile
index a39d413a..086c09b7 100644
--- a/extract/Makefile
+++ b/extract/Makefile
@@ -72,7 +72,7 @@ endif
we_are_mupdf_thirdparty = $(findstring /mupdf/thirdparty/extract, $(abspath .))
ifneq ($(we_are_mupdf_thirdparty),)
$(warning we are mupdf thirdparty)
- mutool := ../../build/debug-extract/mutool
+ mutool := ../../build/debug/mutool
gs := ../../../ghostpdl/debug-extract-bin/gs
libbacktrace = ../../../libbacktrace/.libs
endif
@@ -133,6 +133,10 @@ ifneq ($(mutool),)
tests_mutool := \
$(patsubst %, %.mutool.docx.diff, $(pdfs_generated)) \
$(patsubst %, %.mutool-norotate.docx.diff, $(pdfs_generated)) \
+ $(patsubst %, %.mutool.odt.diff, $(pdfs_generated)) \
+
+ tests_mutool_odt := \
+ $(patsubst %, %.mutool.odt.diff, $(pdfs_generated)) \
endif
ifneq ($(gs),)
@@ -153,16 +157,22 @@ endif
test-exe: $(tests_exe)
@echo $@: passed
-# Checks output of mutool conversion from .pdf to .docx. Requires that mutool
-# was built with extract as a third-party library.
+# Checks output of mutool conversion from .pdf to .docx/.odt. Requires that
+# mutool was built with extract as a third-party library.
#
test-mutool: $(tests_mutool)
@echo $@: passed
-# Checks output of gs conversion from .pdf to .docx. Requires that mutool
-# was built with extract as a third-party library. As of 2021-02-10 this
-# requires, for example ghostpdl/extract being a link to an extract checkout
-# and configuring with --with-extract-dir=extract.
+# Checks output of mutool conversion from .pdf to .odt. Requires that mutool
+# was built with extract as a third-party library.
+#
+test-mutool-odt: $(tests_mutool_odt)
+ @echo $@: passed
+
+# Checks output of gs conversion from .pdf to .docx. Requires that gs was built
+# with extract as a third-party library. As of 2021-02-10 this requires, for
+# example ghostpdl/extract being a link to an extract checkout and configuring
+# with --with-extract-dir=extract.
#
test-gs: $(tests_gs)
@echo $@: passed
@@ -198,8 +208,13 @@ exe_src = \
src/extract.c \
src/join.c \
src/mem.c \
+ src/odt.c \
+ src/odt_template.c \
src/outf.c \
- src/xml.c src/zip.c \
+ src/sys.c \
+ src/text.c \
+ src/xml.c \
+ src/zip.c \
ifeq ($(build),memento)
exe_src += src/memento.c
@@ -225,6 +240,13 @@ ifeq ($(build),memento)
endif
endif
+ifeq ($(create_ref),yes)
+# Special rule for populating .ref directories with current output. Useful to
+# initialise references outputs for new output type.
+#
+test/%.odt.dir.ref/: test/generated/%.odt.dir/
+ rsync -ai $< $@
+endif
# Rules that make the various intermediate targets required by $(tests).
#
@@ -244,29 +266,34 @@ test/generated/%.pdf.intermediate-gs.xml: test/%.pdf $(gs)
%.extract.docx: % $(exe)
@echo
@echo == Generating docx with extract.exe
- $(run_exe) -r 0 -i $< -o $@
+ $(run_exe) -r 0 -i $< -f docx -o $@
+
+%.extract.odt: % $(exe)
+ @echo
+ @echo == Generating odt with extract.exe
+ $(run_exe) -r 0 -i $< -f odt -o $@
%.extract-rotate.docx: % $(exe) Makefile
@echo
@echo == Generating docx with rotation with extract.exe
- $(run_exe) -r 1 -s 0 -i $< -o $@
+ $(run_exe) -r 1 -s 0 -i $< -f docx -o $@
%.extract-rotate-spacing.docx: % $(exe) Makefile
@echo
@echo == Generating docx with rotation with extract.exe
- $(run_exe) -r 1 -s 1 -i $< -o $@
+ $(run_exe) -r 1 -s 1 -i $< -f docx -o $@
%.extract-autosplit.docx: % $(exe)
@echo
@echo == Generating docx with autosplit with extract.exe
- $(run_exe) -r 0 -i $< --autosplit 1 -o $@
+ $(run_exe) -r 0 -i $< -f docx --autosplit 1 -o $@
%.extract-template.docx: % $(exe)
@echo
@echo == Generating docx using src/template.docx with extract.exe
- $(run_exe) -r 0 -i $< -t src/template.docx -o $@
+ $(run_exe) -r 0 -i $< -f docx -t src/template.docx -o $@
-test/generated/%.docx.diff: test/generated/%.docx.dir/ test/%.docx.dir.ref/
+test/generated/%.diff: test/generated/%.dir/ test/%.dir.ref/
@echo
@echo == Checking $<
diff -ru $^
@@ -278,15 +305,29 @@ test/generated/%.extract-template.docx.diff: test/generated/%.extract-template.d
@echo == Checking $<
diff -ru $^
-# Unzips .docx into .docx.dir/ directory. Note that we requires a trailing '/'
-# in target.
+# Unzips .docx into .docx.dir/ directory, and prettyfies the .xml files.
+#
+# Note that we requires a trailing '/' in target.
#
-%.docx.dir/: %.docx
+%.docx.dir/: %.docx .ALWAYS
@echo
@echo == Extracting .docx into directory.
@rm -r $@ 2>/dev/null || true
unzip -q -d $@ $<
+# Unzips .odt into .odt.dir/ directory, and prettyfies the .xml files.
+#
+# Note that we requires a trailing '/' in target.
+#
+%.odt.dir/: %.odt
+ @echo
+ @echo == Extracting .odt into directory.
+ @rm -r $@ 2>/dev/null || true
+ unzip -q -d $@ $<
+
+%.xml.pretty.xml: %.xml
+ xmllint --format $< > $@
+
# Uses zip to create .docx file by zipping up a directory. Useful to recreate
# .docx from reference directory test/*.docx.dir.ref.
%.docx: %
@@ -299,7 +340,7 @@ test/generated/%.extract-template.docx.diff: test/generated/%.extract-template.d
%.docx.dir.pretty: %.docx.dir/
@rm -r $@ $@- 2>/dev/null || true
cp -pr $< $@-
- ./src/docx_template_build.py --docx-pretty $@-
+ ./src/docx_template_build.py --pretty $@-
mv $@- $@
# Converts .pdf directly to .docx using mutool.
@@ -328,6 +369,13 @@ test/generated/%.pdf.gs.docx: test/%.pdf $(gs)
@mkdir -p test/generated
$(gs) -sDEVICE=docxwrite -o $@ $<
+# Converts .pdf directly to .odt using mutool.
+test/generated/%.pdf.mutool.odt: test/%.pdf $(mutool)
+ @echo
+ @echo == Converting .pdf directly to .odt using mutool.
+ @mkdir -p test/generated
+ $(mutool) convert -O mediabox-clip=no -o $@ $<
+
# Valgrind test
#
@@ -432,7 +480,7 @@ test-src:
# Compile rule. We always include src/docx_template.c as a prerequisite in case
# code #includes docx_template.h.
#
-src/build/%.c-$(build).o: src/%.c src/docx_template.c
+src/build/%.c-$(build).o: src/%.c src/docx_template.c src/odt_template.c
@mkdir -p src/build
$(CC) -c $(flags_compile) -o $@ $<
@@ -444,7 +492,13 @@ src/build/%.c-$(build).o: src/%.c src/docx_template.c
src/docx_template.c: src/docx_template_build.py .ALWAYS
@echo
@echo == Building $@
- ./src/docx_template_build.py -i src/template.docx -o src/docx_template
+ ./src/docx_template_build.py -i src/template.docx -n docx -o src/docx_template
+
+src/odt_template.c: src/docx_template_build.py .ALWAYS
+ @echo
+ @echo == Building $@
+ ./src/docx_template_build.py -i src/template.odt -n odt -o src/odt_template
+
.ALWAYS:
.PHONY: .ALWAYS
diff --git a/extract/include/extract.h b/extract/include/extract.h
index 97f43cd6..60908c06 100644
--- a/extract/include/extract.h
+++ b/extract/include/extract.h
@@ -22,8 +22,16 @@ typedef struct extract_t extract_t;
/* State for processing a document. */
+typedef enum
+{
+ extract_format_ODT,
+ extract_format_DOCX
+} extract_format_t;
+
+
int extract_begin(
extract_alloc_t* alloc,
+ extract_format_t format,
extract_t** pextract
);
/* Creates a new extract_t* for use by other extract_*() functions. All
@@ -122,7 +130,7 @@ int extract_add_image(
double y,
double w,
double h,
- char* data,
+ void* data,
size_t data_size,
extract_image_data_free data_free,
void* data_free_handle
diff --git a/extract/src/astring.c b/extract/src/astring.c
index 1d273c9e..fd09d639 100644
--- a/extract/src/astring.c
+++ b/extract/src/astring.c
@@ -1,8 +1,12 @@
#include "../include/extract_alloc.h"
#include "astring.h"
+#include "mem.h"
#include "memento.h"
+#include <assert.h>
+#include <stdarg.h>
+#include <stdio.h>
#include <stdlib.h>
#include <string.h>
@@ -39,3 +43,96 @@ int extract_astring_cat(extract_alloc_t* alloc, extract_astring_t* string, const
return extract_astring_catl(alloc, string, s, strlen(s));
}
+int extract_astring_catf(extract_alloc_t* alloc, extract_astring_t* string, const char* format, ...)
+{
+ char* buffer = NULL;
+ int e;
+ va_list va;
+ va_start(va, format);
+ e = extract_vasprintf(alloc, &buffer, format, va);
+ va_end(va);
+ if (e < 0) return e;
+ e = extract_astring_cat(alloc, string, buffer);
+ extract_free(alloc, &buffer);
+ return e;
+}
+
+int extract_astring_truncate(extract_astring_t* content, int len)
+{
+ assert((size_t) len <= content->chars_num);
+ content->chars_num -= len;
+ content->chars[content->chars_num] = 0;
+ return 0;
+}
+
+int astring_char_truncate_if(extract_astring_t* content, char c)
+{
+ if (content->chars_num && content->chars[content->chars_num-1] == c) {
+ extract_astring_truncate(content, 1);
+ }
+ return 0;
+}
+
+int extract_astring_cat_xmlc(extract_alloc_t* alloc, extract_astring_t* string, int c)
+{
+ int ret = -1;
+
+ if (0) {}
+
+ /* Escape XML special characters. */
+ else if (c == '<') extract_astring_cat(alloc, string, "&lt;");
+ else if (c == '>') extract_astring_cat(alloc, string, "&gt;");
+ else if (c == '&') extract_astring_cat(alloc, string, "&amp;");
+ else if (c == '"') extract_astring_cat(alloc, string, "&quot;");
+ else if (c == '\'') extract_astring_cat(alloc, string, "&apos;");
+
+ /* Expand ligatures. */
+ else if (c == 0xFB00)
+ {
+ if (extract_astring_cat(alloc, string, "ff")) goto end;
+ }
+ else if (c == 0xFB01)
+ {
+ if (extract_astring_cat(alloc, string, "fi")) goto end;
+ }
+ else if (c == 0xFB02)
+ {
+ if (extract_astring_cat(alloc, string, "fl")) goto end;
+ }
+ else if (c == 0xFB03)
+ {
+ if (extract_astring_cat(alloc, string, "ffi")) goto end;
+ }
+ else if (c == 0xFB04)
+ {
+ if (extract_astring_cat(alloc, string, "ffl")) goto end;
+ }
+
+ /* Output ASCII verbatim. */
+ else if (c >= 32 && c <= 127)
+ {
+ if (extract_astring_catc(alloc, string, (char) c)) goto end;
+ }
+
+ /* Escape all other characters. */
+ else
+ {
+ char buffer[32];
+ if (c < 32
+ && (c != 0x9 && c != 0xa && c != 0xd)
+ )
+ {
+ /* Illegal xml character; see
+ https://www.w3.org/TR/xml/#charsets. We replace with
+ 0xfffd, the unicode replacement character. */
+ c = 0xfffd;
+ }
+ snprintf(buffer, sizeof(buffer), "&#x%x;", c);
+ if (extract_astring_cat(alloc, string, buffer)) goto end;
+ }
+
+ ret = 0;
+
+ end:
+ return ret;
+}
diff --git a/extract/src/astring.h b/extract/src/astring.h
index 947e6587..c2b60d25 100644
--- a/extract/src/astring.h
+++ b/extract/src/astring.h
@@ -19,5 +19,15 @@ int extract_astring_catl(extract_alloc_t* alloc, extract_astring_t* string, cons
int extract_astring_catc(extract_alloc_t* alloc, extract_astring_t* string, char c);
int extract_astring_cat(extract_alloc_t* alloc, extract_astring_t* string, const char* s);
+int extract_astring_catf(extract_alloc_t* alloc, extract_astring_t* string, const char* format, ...);
+
+int extract_astring_truncate(extract_astring_t* content, int len);
+/* Removes last <len> chars. */
+
+int astring_char_truncate_if(extract_astring_t* content, char c);
+/* Removes last char if it is <c>. */
+
+int extract_astring_cat_xmlc(extract_alloc_t* alloc, extract_astring_t* string, int c);
+/* Appends specified character using XML escapes as necessary. */
#endif
diff --git a/extract/src/document.h b/extract/src/document.h
index 7a1470e4..c59348f4 100644
--- a/extract/src/document.h
+++ b/extract/src/document.h
@@ -54,7 +54,7 @@ typedef struct
unsigned font_bold : 1;
unsigned font_italic : 1;
unsigned wmode : 1;
- };
+ } flags;
char_t* chars;
int chars_num;
@@ -97,7 +97,11 @@ typedef struct
char* type; /* jpg, png etc. */
char* name; /* Name of image file within docx. */
char* id; /* ID of image within docx. */
- char* data;
+ double x;
+ double y;
+ double w;
+ double h;
+ void* data;
size_t data_size;
extract_image_data_free data_free;
@@ -126,13 +130,14 @@ typedef struct
/* These refer to items in .lines. Initially empty, then set
by extract_join(). */
-} page_t;
-/* A page. Contains different representations of the list of spans. */
+} extract_page_t;
+/* A page. Contains different representations of the list of spans. NB not
+called page_t because this clashes with a system type on hpux. */
typedef struct
{
- page_t** pages;
- int pages_num;
+ extract_page_t** pages;
+ int pages_num;
} document_t;
/* A list of pages. */
@@ -147,4 +152,7 @@ typedef struct
int extract_document_join(extract_alloc_t* alloc, document_t* document);
+double extract_matrices_to_font_size(matrix_t* ctm, matrix_t* trm);
+
+
#endif
diff --git a/extract/src/docx.c b/extract/src/docx.c
index 238e81d4..4532cd4e 100644
--- a/extract/src/docx.c
+++ b/extract/src/docx.c
@@ -15,12 +15,13 @@ docx_paragraph_finish(). */
#include "mem.h"
#include "memento.h"
#include "outf.h"
+#include "sys.h"
+#include "text.h"
#include "zip.h"
#include <assert.h>
#include <errno.h>
#include <math.h>
-#include <stdarg.h>
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
@@ -81,30 +82,6 @@ static int extract_docx_run_finish(extract_alloc_t* alloc, extract_astring_t* co
return extract_astring_cat(alloc, content, "</w:t></w:r>");
}
-static int extract_docx_char_append_string(extract_alloc_t* alloc, extract_astring_t* content, const char* text)
-{
- return extract_astring_cat(alloc, content, text);
-}
-
-static int extract_docx_char_append_stringf(extract_alloc_t* alloc, extract_astring_t* content, const char* format, ...)
-{
- char* buffer = NULL;
- int e;
- va_list va;
- va_start(va, format);
- e = extract_vasprintf(alloc, &buffer, format, va);
- va_end(va);
- if (e < 0) return e;
- e = extract_astring_cat(alloc, content, buffer);
- extract_free(alloc, &buffer);
- return e;
-}
-
-static int extract_docx_char_append_char(extract_alloc_t* alloc, extract_astring_t* content, char c)
-{
- return extract_astring_catc(alloc, content, c);
-}
-
static int extract_docx_paragraph_empty(extract_alloc_t* alloc, extract_astring_t* content)
/* Append an empty paragraph to *content. */
{
@@ -131,34 +108,16 @@ static int extract_docx_paragraph_empty(extract_alloc_t* alloc, extract_astring_
}
-/* Removes last <len> chars. */
-static int docx_char_truncate(extract_astring_t* content, int len)
-{
- assert((size_t) len <= content->chars_num);
- content->chars_num -= len;
- content->chars[content->chars_num] = 0;
- return 0;
-}
-
static int extract_docx_char_truncate_if(extract_astring_t* content, char c)
/* Removes last char if it is <c>. */
{
if (content->chars_num && content->chars[content->chars_num-1] == c) {
- docx_char_truncate(content, 1);
+ extract_astring_truncate(content, 1);
}
return 0;
}
-static double matrices_to_font_size(matrix_t* ctm, matrix_t* trm)
-{
- double font_size = matrix_expansion(*trm)
- * matrix_expansion(*ctm);
- /* Round font_size to nearest 0.01. */
- font_size = (double) (int) (font_size * 100.0f + 0.5f) / 100.0f;
- return font_size;
-}
-
typedef struct
{
const char* font_name;
@@ -193,19 +152,19 @@ font. */
span_t* span = line->spans[s];
double font_size_new;
state->ctm_prev = &span->ctm;
- font_size_new = matrices_to_font_size(&span->ctm, &span->trm);
+ font_size_new = extract_matrices_to_font_size(&span->ctm, &span->trm);
if (!state->font_name
|| strcmp(span->font_name, state->font_name)
- || span->font_bold != state->font_bold
- || span->font_italic != state->font_italic
+ || span->flags.font_bold != state->font_bold
+ || span->flags.font_italic != state->font_italic
|| font_size_new != state->font_size
) {
if (state->font_name) {
if (extract_docx_run_finish(alloc, content)) goto end;
}
state->font_name = span->font_name;
- state->font_bold = span->font_bold;
- state->font_italic = span->font_italic;
+ state->font_bold = span->flags.font_bold;
+ state->font_italic = span->flags.font_italic;
state->font_size = font_size_new;
if (extract_docx_run_start(
alloc,
@@ -220,44 +179,7 @@ font. */
for (si=0; si<span->chars_num; ++si) {
char_t* char_ = &span->chars[si];
int c = char_->ucs;
-
- if (0) {}
-
- /* Escape XML special characters. */
- else if (c == '<') extract_docx_char_append_string(alloc, content, "&lt;");
- else if (c == '>') extract_docx_char_append_string(alloc, content, "&gt;");
- else if (c == '&') extract_docx_char_append_string(alloc, content, "&amp;");
- else if (c == '"') extract_docx_char_append_string(alloc, content, "&quot;");
- else if (c == '\'') extract_docx_char_append_string(alloc, content, "&apos;");
-
- /* Expand ligatures. */
- else if (c == 0xFB00) {
- if (extract_docx_char_append_string(alloc, content, "ff")) goto end;
- }
- else if (c == 0xFB01) {
- if (extract_docx_char_append_string(alloc, content, "fi")) goto end;
- }
- else if (c == 0xFB02) {
- if (extract_docx_char_append_string(alloc, content, "fl")) goto end;
- }
- else if (c == 0xFB03) {
- if (extract_docx_char_append_string(alloc, content, "ffi")) goto end;
- }
- else if (c == 0xFB04) {
- if (extract_docx_char_append_string(alloc, content, "ffl")) goto end;
- }
-
- /* Output ASCII verbatim. */
- else if (c >= 32 && c <= 127) {
- if (extract_docx_char_append_char(alloc, content, (char) c)) goto end;
- }
-
- /* Escape all other characters. */
- else {
- char buffer[32];
- snprintf(buffer, sizeof(buffer), "&#x%x;", c);
- if (extract_docx_char_append_string(alloc, content, buffer)) goto end;
- }
+ if (extract_astring_cat_xmlc(alloc, content, c)) goto end;
}
/* Remove any trailing '-' at end of line. */
if (extract_docx_char_truncate_if(content, '-')) goto end;
@@ -282,70 +204,70 @@ static int extract_document_append_image(
)
/* Write reference to image into docx content. */
{
- extract_docx_char_append_string(alloc, content, "\n");
- extract_docx_char_append_string(alloc, content, " <w:p>\n");
- extract_docx_char_append_string(alloc, content, " <w:r>\n");
- extract_docx_char_append_string(alloc, content, " <w:rPr>\n");
- extract_docx_char_append_string(alloc, content, " <w:noProof/>\n");
- extract_docx_char_append_string(alloc, content, " </w:rPr>\n");
- extract_docx_char_append_string(alloc, content, " <w:drawing>\n");
- extract_docx_char_append_string(alloc, content, " <wp:inline distT=\"0\" distB=\"0\" distL=\"0\" distR=\"0\" wp14:anchorId=\"7057A832\" wp14:editId=\"466EB3FB\">\n");
- extract_docx_char_append_string(alloc, content, " <wp:extent cx=\"2933700\" cy=\"2200275\"/>\n");
- extract_docx_char_append_string(alloc, content, " <wp:effectExtent l=\"0\" t=\"0\" r=\"0\" b=\"9525\"/>\n");
- extract_docx_char_append_string(alloc, content, " <wp:docPr id=\"1\" name=\"Picture 1\"/>\n");
- extract_docx_char_append_string(alloc, content, " <wp:cNvGraphicFramePr>\n");
- extract_docx_char_append_string(alloc, content, " <a:graphicFrameLocks xmlns:a=\"http://schemas.openxmlformats.org/drawingml/2006/main\" noChangeAspect=\"1\"/>\n");
- extract_docx_char_append_string(alloc, content, " </wp:cNvGraphicFramePr>\n");
- extract_docx_char_append_string(alloc, content, " <a:graphic xmlns:a=\"http://schemas.openxmlformats.org/drawingml/2006/main\">\n");
- extract_docx_char_append_string(alloc, content, " <a:graphicData uri=\"http://schemas.openxmlformats.org/drawingml/2006/picture\">\n");
- extract_docx_char_append_string(alloc, content, " <pic:pic xmlns:pic=\"http://schemas.openxmlformats.org/drawingml/2006/picture\">\n");
- extract_docx_char_append_string(alloc, content, " <pic:nvPicPr>\n");
- extract_docx_char_append_string(alloc, content, " <pic:cNvPr id=\"1\" name=\"Picture 1\"/>\n");
- extract_docx_char_append_string(alloc, content, " <pic:cNvPicPr>\n");
- extract_docx_char_append_string(alloc, content, " <a:picLocks noChangeAspect=\"1\" noChangeArrowheads=\"1\"/>\n");
- extract_docx_char_append_string(alloc, content, " </pic:cNvPicPr>\n");
- extract_docx_char_append_string(alloc, content, " </pic:nvPicPr>\n");
- extract_docx_char_append_string(alloc, content, " <pic:blipFill>\n");
- extract_docx_char_append_stringf(alloc, content," <a:blip r:embed=\"%s\">\n", image->id);
- extract_docx_char_append_string(alloc, content, " <a:extLst>\n");
- extract_docx_char_append_string(alloc, content, " <a:ext uri=\"{28A0092B-C50C-407E-A947-70E740481C1C}\">\n");
- extract_docx_char_append_string(alloc, content, " <a14:useLocalDpi xmlns:a14=\"http://schemas.microsoft.com/office/drawing/2010/main\" val=\"0\"/>\n");
- extract_docx_char_append_string(alloc, content, " </a:ext>\n");
- extract_docx_char_append_string(alloc, content, " </a:extLst>\n");
- extract_docx_char_append_string(alloc, content, " </a:blip>\n");
- //extract_docx_char_append_string(alloc, content, " <a:srcRect/>\n");
- extract_docx_char_append_string(alloc, content, " <a:stretch>\n");
- extract_docx_char_append_string(alloc, content, " <a:fillRect/>\n");
- extract_docx_char_append_string(alloc, content, " </a:stretch>\n");
- extract_docx_char_append_string(alloc, content, " </pic:blipFill>\n");
- extract_docx_char_append_string(alloc, content, " <pic:spPr bwMode=\"auto\">\n");
- extract_docx_char_append_string(alloc, content, " <a:xfrm>\n");
- extract_docx_char_append_string(alloc, content, " <a:off x=\"0\" y=\"0\"/>\n");
- extract_docx_char_append_string(alloc, content, " <a:ext cx=\"2933700\" cy=\"2200275\"/>\n");
- extract_docx_char_append_string(alloc, content, " </a:xfrm>\n");
- extract_docx_char_append_string(alloc, content, " <a:prstGeom prst=\"rect\">\n");
- extract_docx_char_append_string(alloc, content, " <a:avLst/>\n");
- extract_docx_char_append_string(alloc, content, " </a:prstGeom>\n");
- extract_docx_char_append_string(alloc, content, " <a:noFill/>\n");
- extract_docx_char_append_string(alloc, content, " <a:ln>\n");
- extract_docx_char_append_string(alloc, content, " <a:noFill/>\n");
- extract_docx_char_append_string(alloc, content, " </a:ln>\n");
- extract_docx_char_append_string(alloc, content, " </pic:spPr>\n");
- extract_docx_char_append_string(alloc, content, " </pic:pic>\n");
- extract_docx_char_append_string(alloc, content, " </a:graphicData>\n");
- extract_docx_char_append_string(alloc, content, " </a:graphic>\n");
- extract_docx_char_append_string(alloc, content, " </wp:inline>\n");
- extract_docx_char_append_string(alloc, content, " </w:drawing>\n");
- extract_docx_char_append_string(alloc, content, " </w:r>\n");
- extract_docx_char_append_string(alloc, content, " </w:p>\n");
- extract_docx_char_append_string(alloc, content, "\n");
+ extract_astring_cat(alloc, content, "\n");
+ extract_astring_cat(alloc, content, " <w:p>\n");
+ extract_astring_cat(alloc, content, " <w:r>\n");
+ extract_astring_cat(alloc, content, " <w:rPr>\n");
+ extract_astring_cat(alloc, content, " <w:noProof/>\n");
+ extract_astring_cat(alloc, content, " </w:rPr>\n");
+ extract_astring_cat(alloc, content, " <w:drawing>\n");
+ extract_astring_cat(alloc, content, " <wp:inline distT=\"0\" distB=\"0\" distL=\"0\" distR=\"0\" wp14:anchorId=\"7057A832\" wp14:editId=\"466EB3FB\">\n");
+ extract_astring_cat(alloc, content, " <wp:extent cx=\"2933700\" cy=\"2200275\"/>\n");
+ extract_astring_cat(alloc, content, " <wp:effectExtent l=\"0\" t=\"0\" r=\"0\" b=\"9525\"/>\n");
+ extract_astring_cat(alloc, content, " <wp:docPr id=\"1\" name=\"Picture 1\"/>\n");
+ extract_astring_cat(alloc, content, " <wp:cNvGraphicFramePr>\n");
+ extract_astring_cat(alloc, content, " <a:graphicFrameLocks xmlns:a=\"http://schemas.openxmlformats.org/drawingml/2006/main\" noChangeAspect=\"1\"/>\n");
+ extract_astring_cat(alloc, content, " </wp:cNvGraphicFramePr>\n");
+ extract_astring_cat(alloc, content, " <a:graphic xmlns:a=\"http://schemas.openxmlformats.org/drawingml/2006/main\">\n");
+ extract_astring_cat(alloc, content, " <a:graphicData uri=\"http://schemas.openxmlformats.org/drawingml/2006/picture\">\n");
+ extract_astring_cat(alloc, content, " <pic:pic xmlns:pic=\"http://schemas.openxmlformats.org/drawingml/2006/picture\">\n");
+ extract_astring_cat(alloc, content, " <pic:nvPicPr>\n");
+ extract_astring_cat(alloc, content, " <pic:cNvPr id=\"1\" name=\"Picture 1\"/>\n");
+ extract_astring_cat(alloc, content, " <pic:cNvPicPr>\n");
+ extract_astring_cat(alloc, content, " <a:picLocks noChangeAspect=\"1\" noChangeArrowheads=\"1\"/>\n");
+ extract_astring_cat(alloc, content, " </pic:cNvPicPr>\n");
+ extract_astring_cat(alloc, content, " </pic:nvPicPr>\n");
+ extract_astring_cat(alloc, content, " <pic:blipFill>\n");
+ extract_astring_catf(alloc, content," <a:blip r:embed=\"%s\">\n", image->id);
+ extract_astring_cat(alloc, content, " <a:extLst>\n");
+ extract_astring_cat(alloc, content, " <a:ext uri=\"{28A0092B-C50C-407E-A947-70E740481C1C}\">\n");
+ extract_astring_cat(alloc, content, " <a14:useLocalDpi xmlns:a14=\"http://schemas.microsoft.com/office/drawing/2010/main\" val=\"0\"/>\n");
+ extract_astring_cat(alloc, content, " </a:ext>\n");
+ extract_astring_cat(alloc, content, " </a:extLst>\n");
+ extract_astring_cat(alloc, content, " </a:blip>\n");
+ //extract_astring_cat(alloc, content, " <a:srcRect/>\n");
+ extract_astring_cat(alloc, content, " <a:stretch>\n");
+ extract_astring_cat(alloc, content, " <a:fillRect/>\n");
+ extract_astring_cat(alloc, content, " </a:stretch>\n");
+ extract_astring_cat(alloc, content, " </pic:blipFill>\n");
+ extract_astring_cat(alloc, content, " <pic:spPr bwMode=\"auto\">\n");
+ extract_astring_cat(alloc, content, " <a:xfrm>\n");
+ extract_astring_cat(alloc, content, " <a:off x=\"0\" y=\"0\"/>\n");
+ extract_astring_cat(alloc, content, " <a:ext cx=\"2933700\" cy=\"2200275\"/>\n");
+ extract_astring_cat(alloc, content, " </a:xfrm>\n");
+ extract_astring_cat(alloc, content, " <a:prstGeom prst=\"rect\">\n");
+ extract_astring_cat(alloc, content, " <a:avLst/>\n");
+ extract_astring_cat(alloc, content, " </a:prstGeom>\n");
+ extract_astring_cat(alloc, content, " <a:noFill/>\n");
+ extract_astring_cat(alloc, content, " <a:ln>\n");
+ extract_astring_cat(alloc, content, " <a:noFill/>\n");
+ extract_astring_cat(alloc, content, " </a:ln>\n");
+ extract_astring_cat(alloc, content, " </pic:spPr>\n");
+ extract_astring_cat(alloc, content, " </pic:pic>\n");
+ extract_astring_cat(alloc, content, " </a:graphicData>\n");
+ extract_astring_cat(alloc, content, " </a:graphic>\n");
+ extract_astring_cat(alloc, content, " </wp:inline>\n");
+ extract_astring_cat(alloc, content, " </w:drawing>\n");
+ extract_astring_cat(alloc, content, " </w:r>\n");
+ extract_astring_cat(alloc, content, " </w:p>\n");
+ extract_astring_cat(alloc, content, "\n");
return 0;
}
static int extract_document_output_rotated_paragraphs(
extract_alloc_t* alloc,
- page_t* page,
+ extract_page_t* page,
int paragraph_begin,
int paragraph_end,
int rot,
@@ -362,63 +284,63 @@ static int extract_document_output_rotated_paragraphs(
int e = 0;
int p;
outf("x,y=%ik,%ik = %i,%i", x/1000, y/1000, x, y);
- extract_docx_char_append_string(alloc, content, "\n");
- extract_docx_char_append_string(alloc, content, "\n");
- extract_docx_char_append_string(alloc, content, "<w:p>\n");
- extract_docx_char_append_string(alloc, content, " <w:r>\n");
- extract_docx_char_append_string(alloc, content, " <mc:AlternateContent>\n");
- extract_docx_char_append_string(alloc, content, " <mc:Choice Requires=\"wps\">\n");
- extract_docx_char_append_string(alloc, content, " <w:drawing>\n");
- extract_docx_char_append_string(alloc, content, " <wp:anchor distT=\"0\" distB=\"0\" distL=\"0\" distR=\"0\" simplePos=\"0\" relativeHeight=\"0\" behindDoc=\"0\" locked=\"0\" layoutInCell=\"1\" allowOverlap=\"1\" wp14:anchorId=\"53A210D1\" wp14:editId=\"2B7E8016\">\n");
- extract_docx_char_append_string(alloc, content, " <wp:simplePos x=\"0\" y=\"0\"/>\n");
- extract_docx_char_append_string(alloc, content, " <wp:positionH relativeFrom=\"page\">\n");
- extract_docx_char_append_stringf(alloc, content," <wp:posOffset>%i</wp:posOffset>\n", x);
- extract_docx_char_append_string(alloc, content, " </wp:positionH>\n");
- extract_docx_char_append_string(alloc, content, " <wp:positionV relativeFrom=\"page\">\n");
- extract_docx_char_append_stringf(alloc, content," <wp:posOffset>%i</wp:posOffset>\n", y);
- extract_docx_char_append_string(alloc, content, " </wp:positionV>\n");
- extract_docx_char_append_stringf(alloc, content," <wp:extent cx=\"%i\" cy=\"%i\"/>\n", w, h);
- extract_docx_char_append_string(alloc, content, " <wp:effectExtent l=\"381000\" t=\"723900\" r=\"371475\" b=\"723900\"/>\n");
- extract_docx_char_append_string(alloc, content, " <wp:wrapNone/>\n");
- extract_docx_char_append_stringf(alloc, content," <wp:docPr id=\"%i\" name=\"Text Box %i\"/>\n", text_box_id, text_box_id);
- extract_docx_char_append_string(alloc, content, " <wp:cNvGraphicFramePr/>\n");
- extract_docx_char_append_string(alloc, content, " <a:graphic xmlns:a=\"http://schemas.openxmlformats.org/drawingml/2006/main\">\n");
- extract_docx_char_append_string(alloc, content, " <a:graphicData uri=\"http://schemas.microsoft.com/office/word/2010/wordprocessingShape\">\n");
- extract_docx_char_append_string(alloc, content, " <wps:wsp>\n");
- extract_docx_char_append_string(alloc, content, " <wps:cNvSpPr txBox=\"1\"/>\n");
- extract_docx_char_append_string(alloc, content, " <wps:spPr>\n");
- extract_docx_char_append_stringf(alloc, content," <a:xfrm rot=\"%i\">\n", rot);
- extract_docx_char_append_string(alloc, content, " <a:off x=\"0\" y=\"0\"/>\n");
- extract_docx_char_append_string(alloc, content, " <a:ext cx=\"3228975\" cy=\"2286000\"/>\n");
- extract_docx_char_append_string(alloc, content, " </a:xfrm>\n");
- extract_docx_char_append_string(alloc, content, " <a:prstGeom prst=\"rect\">\n");
- extract_docx_char_append_string(alloc, content, " <a:avLst/>\n");
- extract_docx_char_append_string(alloc, content, " </a:prstGeom>\n");
+ extract_astring_cat(alloc, content, "\n");
+ extract_astring_cat(alloc, content, "\n");
+ extract_astring_cat(alloc, content, "<w:p>\n");
+ extract_astring_cat(alloc, content, " <w:r>\n");
+ extract_astring_cat(alloc, content, " <mc:AlternateContent>\n");
+ extract_astring_cat(alloc, content, " <mc:Choice Requires=\"wps\">\n");
+ extract_astring_cat(alloc, content, " <w:drawing>\n");
+ extract_astring_cat(alloc, content, " <wp:anchor distT=\"0\" distB=\"0\" distL=\"0\" distR=\"0\" simplePos=\"0\" relativeHeight=\"0\" behindDoc=\"0\" locked=\"0\" layoutInCell=\"1\" allowOverlap=\"1\" wp14:anchorId=\"53A210D1\" wp14:editId=\"2B7E8016\">\n");
+ extract_astring_cat(alloc, content, " <wp:simplePos x=\"0\" y=\"0\"/>\n");
+ extract_astring_cat(alloc, content, " <wp:positionH relativeFrom=\"page\">\n");
+ extract_astring_catf(alloc, content," <wp:posOffset>%i</wp:posOffset>\n", x);
+ extract_astring_cat(alloc, content, " </wp:positionH>\n");
+ extract_astring_cat(alloc, content, " <wp:positionV relativeFrom=\"page\">\n");
+ extract_astring_catf(alloc, content," <wp:posOffset>%i</wp:posOffset>\n", y);
+ extract_astring_cat(alloc, content, " </wp:positionV>\n");
+ extract_astring_catf(alloc, content," <wp:extent cx=\"%i\" cy=\"%i\"/>\n", w, h);
+ extract_astring_cat(alloc, content, " <wp:effectExtent l=\"381000\" t=\"723900\" r=\"371475\" b=\"723900\"/>\n");
+ extract_astring_cat(alloc, content, " <wp:wrapNone/>\n");
+ extract_astring_catf(alloc, content," <wp:docPr id=\"%i\" name=\"Text Box %i\"/>\n", text_box_id, text_box_id);
+ extract_astring_cat(alloc, content, " <wp:cNvGraphicFramePr/>\n");
+ extract_astring_cat(alloc, content, " <a:graphic xmlns:a=\"http://schemas.openxmlformats.org/drawingml/2006/main\">\n");
+ extract_astring_cat(alloc, content, " <a:graphicData uri=\"http://schemas.microsoft.com/office/word/2010/wordprocessingShape\">\n");
+ extract_astring_cat(alloc, content, " <wps:wsp>\n");
+ extract_astring_cat(alloc, content, " <wps:cNvSpPr txBox=\"1\"/>\n");
+ extract_astring_cat(alloc, content, " <wps:spPr>\n");
+ extract_astring_catf(alloc, content," <a:xfrm rot=\"%i\">\n", rot);
+ extract_astring_cat(alloc, content, " <a:off x=\"0\" y=\"0\"/>\n");
+ extract_astring_cat(alloc, content, " <a:ext cx=\"3228975\" cy=\"2286000\"/>\n");
+ extract_astring_cat(alloc, content, " </a:xfrm>\n");
+ extract_astring_cat(alloc, content, " <a:prstGeom prst=\"rect\">\n");
+ extract_astring_cat(alloc, content, " <a:avLst/>\n");
+ extract_astring_cat(alloc, content, " </a:prstGeom>\n");
/* Give box a solid background. */
if (0) {
- extract_docx_char_append_string(alloc, content, " <a:solidFill>\n");
- extract_docx_char_append_string(alloc, content, " <a:schemeClr val=\"lt1\"/>\n");
- extract_docx_char_append_string(alloc, content, " </a:solidFill>\n");
+ extract_astring_cat(alloc, content, " <a:solidFill>\n");
+ extract_astring_cat(alloc, content, " <a:schemeClr val=\"lt1\"/>\n");
+ extract_astring_cat(alloc, content, " </a:solidFill>\n");
}
/* Draw line around box. */
if (0) {
- extract_docx_char_append_string(alloc, content, " <a:ln w=\"175\">\n");
- extract_docx_char_append_string(alloc, content, " <a:solidFill>\n");
- extract_docx_char_append_string(alloc, content, " <a:prstClr val=\"black\"/>\n");
- extract_docx_char_append_string(alloc, content, " </a:solidFill>\n");
- extract_docx_char_append_string(alloc, content, " </a:ln>\n");
+ extract_astring_cat(alloc, content, " <a:ln w=\"175\">\n");
+ extract_astring_cat(alloc, content, " <a:solidFill>\n");
+ extract_astring_cat(alloc, content, " <a:prstClr val=\"black\"/>\n");
+ extract_astring_cat(alloc, content, " </a:solidFill>\n");
+ extract_astring_cat(alloc, content, " </a:ln>\n");
}
- extract_docx_char_append_string(alloc, content, " </wps:spPr>\n");
- extract_docx_char_append_string(alloc, content, " <wps:txbx>\n");
- extract_docx_char_append_string(alloc, content, " <w:txbxContent>");
+ extract_astring_cat(alloc, content, " </wps:spPr>\n");
+ extract_astring_cat(alloc, content, " <wps:txbx>\n");
+ extract_astring_cat(alloc, content, " <w:txbxContent>");
#if 0
if (0) {
/* Output inline text describing the rotation. */
- extract_docx_char_append_stringf(content, "<w:p>\n"
+ extract_astring_catf(content, "<w:p>\n"
"<w:r><w:rPr><w:rFonts w:ascii=\"OpenSans\" w:hAnsi=\"OpenSans\"/><w:sz w:val=\"20.000000\"/><w:szCs w:val=\"15.000000\"/></w:rPr><w:t xml:space=\"preserve\">*** rotate: %f rad, %f deg. rot=%i</w:t></w:r>\n"
"</w:p>\n",
rotate,
@@ -434,50 +356,50 @@ static int extract_document_output_rotated_paragraphs(
if (extract_document_to_docx_content_paragraph(alloc, state, paragraph, content)) goto end;
}
- extract_docx_char_append_string(alloc, content, "\n");
- extract_docx_char_append_string(alloc, content, " </w:txbxContent>\n");
- extract_docx_char_append_string(alloc, content, " </wps:txbx>\n");
- extract_docx_char_append_string(alloc, content, " <wps:bodyPr rot=\"0\" spcFirstLastPara=\"0\" vertOverflow=\"overflow\" horzOverflow=\"overflow\" vert=\"horz\" wrap=\"square\" lIns=\"91440\" tIns=\"45720\" rIns=\"91440\" bIns=\"45720\" numCol=\"1\" spcCol=\"0\" rtlCol=\"0\" fromWordArt=\"0\" anchor=\"t\" anchorCtr=\"0\" forceAA=\"0\" compatLnSpc=\"1\">\n");
- extract_docx_char_append_string(alloc, content, " <a:prstTxWarp prst=\"textNoShape\">\n");
- extract_docx_char_append_string(alloc, content, " <a:avLst/>\n");
- extract_docx_char_append_string(alloc, content, " </a:prstTxWarp>\n");
- extract_docx_char_append_string(alloc, content, " <a:noAutofit/>\n");
- extract_docx_char_append_string(alloc, content, " </wps:bodyPr>\n");
- extract_docx_char_append_string(alloc, content, " </wps:wsp>\n");
- extract_docx_char_append_string(alloc, content, " </a:graphicData>\n");
- extract_docx_char_append_string(alloc, content, " </a:graphic>\n");
- extract_docx_char_append_string(alloc, content, " </wp:anchor>\n");
- extract_docx_char_append_string(alloc, content, " </w:drawing>\n");
- extract_docx_char_append_string(alloc, content, " </mc:Choice>\n");
+ extract_astring_cat(alloc, content, "\n");
+ extract_astring_cat(alloc, content, " </w:txbxContent>\n");
+ extract_astring_cat(alloc, content, " </wps:txbx>\n");
+ extract_astring_cat(alloc, content, " <wps:bodyPr rot=\"0\" spcFirstLastPara=\"0\" vertOverflow=\"overflow\" horzOverflow=\"overflow\" vert=\"horz\" wrap=\"square\" lIns=\"91440\" tIns=\"45720\" rIns=\"91440\" bIns=\"45720\" numCol=\"1\" spcCol=\"0\" rtlCol=\"0\" fromWordArt=\"0\" anchor=\"t\" anchorCtr=\"0\" forceAA=\"0\" compatLnSpc=\"1\">\n");
+ extract_astring_cat(alloc, content, " <a:prstTxWarp prst=\"textNoShape\">\n");
+ extract_astring_cat(alloc, content, " <a:avLst/>\n");
+ extract_astring_cat(alloc, content, " </a:prstTxWarp>\n");
+ extract_astring_cat(alloc, content, " <a:noAutofit/>\n");
+ extract_astring_cat(alloc, content, " </wps:bodyPr>\n");
+ extract_astring_cat(alloc, content, " </wps:wsp>\n");
+ extract_astring_cat(alloc, content, " </a:graphicData>\n");
+ extract_astring_cat(alloc, content, " </a:graphic>\n");
+ extract_astring_cat(alloc, content, " </wp:anchor>\n");
+ extract_astring_cat(alloc, content, " </w:drawing>\n");
+ extract_astring_cat(alloc, content, " </mc:Choice>\n");
/* This fallback is copied from a real Word document. Not sure
whether it works - both Libreoffice and Word use the above
choice. */
- extract_docx_char_append_string(alloc, content, " <mc:Fallback>\n");
- extract_docx_char_append_string(alloc, content, " <w:pict>\n");
- extract_docx_char_append_string(alloc, content, " <v:shapetype w14:anchorId=\"53A210D1\" id=\"_x0000_t202\" coordsize=\"21600,21600\" o:spt=\"202\" path=\"m,l,21600r21600,l21600,xe\">\n");
- extract_docx_char_append_string(alloc, content, " <v:stroke joinstyle=\"miter\"/>\n");
- extract_docx_char_append_string(alloc, content, " <v:path gradientshapeok=\"t\" o:connecttype=\"rect\"/>\n");
- extract_docx_char_append_string(alloc, content, " </v:shapetype>\n");
- extract_docx_char_append_stringf(alloc, content," <v:shape id=\"Text Box %i\" o:spid=\"_x0000_s1026\" type=\"#_x0000_t202\" style=\"position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top\" o:gfxdata=\"UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;\" fillcolor=\"white [3201]\" strokeweight=\".5pt\">\n", text_box_id);
- extract_docx_char_append_string(alloc, content, " <v:textbox>\n");
- extract_docx_char_append_string(alloc, content, " <w:txbxContent>");
+ extract_astring_cat(alloc, content, " <mc:Fallback>\n");
+ extract_astring_cat(alloc, content, " <w:pict>\n");
+ extract_astring_cat(alloc, content, " <v:shapetype w14:anchorId=\"53A210D1\" id=\"_x0000_t202\" coordsize=\"21600,21600\" o:spt=\"202\" path=\"m,l,21600r21600,l21600,xe\">\n");
+ extract_astring_cat(alloc, content, " <v:stroke joinstyle=\"miter\"/>\n");
+ extract_astring_cat(alloc, content, " <v:path gradientshapeok=\"t\" o:connecttype=\"rect\"/>\n");
+ extract_astring_cat(alloc, content, " </v:shapetype>\n");
+ extract_astring_catf(alloc, content," <v:shape id=\"Text Box %i\" o:spid=\"_x0000_s1026\" type=\"#_x0000_t202\" style=\"position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top\" o:gfxdata=\"UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;\" fillcolor=\"white [3201]\" strokeweight=\".5pt\">\n", text_box_id);
+ extract_astring_cat(alloc, content, " <v:textbox>\n");
+ extract_astring_cat(alloc, content, " <w:txbxContent>");
for (p=paragraph_begin; p<paragraph_end; ++p) {
paragraph_t* paragraph = page->paragraphs[p];
if (extract_document_to_docx_content_paragraph(alloc, state, paragraph, content)) goto end;
}
- extract_docx_char_append_string(alloc, content, "\n");
- extract_docx_char_append_string(alloc, content, "\n");
- extract_docx_char_append_string(alloc, content, " </w:txbxContent>\n");
- extract_docx_char_append_string(alloc, content, " </v:textbox>\n");
- extract_docx_char_append_string(alloc, content, " </v:shape>\n");
- extract_docx_char_append_string(alloc, content, " </w:pict>\n");
- extract_docx_char_append_string(alloc, content, " </mc:Fallback>\n");
- extract_docx_char_append_string(alloc, content, " </mc:AlternateContent>\n");
- extract_docx_char_append_string(alloc, content, " </w:r>\n");
- extract_docx_char_append_string(alloc, content, "</w:p>");
+ extract_astring_cat(alloc, content, "\n");
+ extract_astring_cat(alloc, content, "\n");
+ extract_astring_cat(alloc, content, " </w:txbxContent>\n");
+ extract_astring_cat(alloc, content, " </v:textbox>\n");
+ extract_astring_cat(alloc, content, " </v:shape>\n");
+ extract_astring_cat(alloc, content, " </w:pict>\n");
+ extract_astring_cat(alloc, content, " </mc:Fallback>\n");
+ extract_astring_cat(alloc, content, " </mc:AlternateContent>\n");
+ extract_astring_cat(alloc, content, " </w:r>\n");
+ extract_astring_cat(alloc, content, "</w:p>");
e = 0;
end:
return e;
@@ -499,7 +421,7 @@ int extract_document_to_docx_content(
/* Write paragraphs into <content>. */
for (p=0; p<document->pages_num; ++p) {
- page_t* page = document->pages[p];
+ extract_page_t* page = document->pages[p];
int p;
content_state_t state;
state.font_name = NULL;
@@ -689,137 +611,6 @@ int extract_document_to_docx_content(
}
-
-static int systemf(extract_alloc_t* alloc, const char* format, ...)
-/* Like system() but takes printf-style format and args. Also, if we return +ve
-we set errno to EIO. */
-{
- int e;
- char* command;
- va_list va;
- va_start(va, format);
- e = extract_vasprintf(alloc, &command, format, va);
- va_end(va);
- if (e < 0) return e;
- outf("running: %s", command);
- e = system(command);
- extract_free(alloc, &command);
- if (e > 0) {
- errno = EIO;
- }
- return e;
-}
-
-static int read_all(extract_alloc_t* alloc, FILE* in, char** o_out)
-/* Reads until eof into zero-terminated malloc'd buffer. */
-{
- size_t len = 0;
- size_t delta = 128;
- for(;;) {
- size_t n;
- if (extract_realloc2(alloc, o_out, len, len + delta + 1)) {
- extract_free(alloc, o_out);
- return -1;
- }
- n = fread(*o_out + len, 1 /*size*/, delta /*nmemb*/, in);
- len += n;
- if (feof(in)) {
- (*o_out)[len] = 0;
- return 0;
- }
- if (ferror(in)) {
- /* It's weird that fread() and ferror() don't set errno. */
- errno = EIO;
- extract_free(alloc, o_out);
- return -1;
- }
- }
-}
-
-static int read_all_path(extract_alloc_t* alloc, const char* path, char** o_text)
-/* Reads entire file into zero-terminated malloc'd buffer. */
-{
- int e = -1;
- FILE* f = NULL;
- f = fopen(path, "rb");
- if (!f) goto end;
- if (read_all(alloc, f, o_text)) goto end;
- e = 0;
- end:
- if (f) fclose(f);
- if (e) extract_free(alloc, &o_text);
- return e;
-}
-
-static int write_all(const void* data, size_t data_size, const char* path)
-{
- int e = -1;
- FILE* f = fopen(path, "w");
- if (!f) goto end;
- if (fwrite(data, data_size, 1 /*nmemb*/, f) != 1) goto end;
- e = 0;
- end:
- if (f) fclose(f);
- return e;
-}
-
-static int extract_docx_content_insert(
- extract_alloc_t* alloc,
- const char* original,
- const char* mid_begin_name,
- const char* mid_end_name,
- extract_astring_t* contentss,
- int contentss_num,
- char** o_out
- )
-/* Creates a string consisting of <original> with all strings in <contentss>
-inserted into <original>'s <mid_begin_name>...<mid_end_name> region, and
-appends this string to *o_out. */
-{
- int e = -1;
- const char* mid_begin;
- const char* mid_end;
- extract_astring_t out;
- extract_astring_init(&out);
-
- mid_begin = strstr(original, mid_begin_name);
- if (!mid_begin) {
- outf("error: could not find '%s' in docx content",
- mid_begin_name);
- errno = ESRCH;
- goto end;
- }
- mid_begin += strlen(mid_begin_name);
-
- mid_end = strstr(mid_begin, mid_end_name);
- if (!mid_end) {
- outf("error: could not find '%s' in docx content",
- mid_end_name);
- errno = ESRCH;
- goto end;
- }
-
- if (extract_astring_catl(alloc, &out, original, mid_begin - original)) goto end;
- {
- int i;
- for (i=0; i<contentss_num; ++i) {
- if (extract_astring_catl(alloc, &out, contentss[i].chars, contentss[i].chars_num)) goto end;
- }
- }
- if (extract_astring_cat(alloc, &out, mid_end)) goto end;
-
- *o_out = out.chars;
- out.chars = NULL;
- e = 0;
-
- end:
- if (e) {
- extract_astring_free(alloc, &out);
- *o_out = NULL;
- }
- return e;
-}
-
static int s_find_mid(const char* text, const char* begin, const char* end, const char** o_begin, const char** o_end)
/* Sets *o_begin to end of first occurrence of <begin> in <text>, and *o_end to
beginning of first occurtence of <end> in <text>. */
@@ -906,9 +697,10 @@ int extract_docx_content_item(
}
else if (!strcmp(name, "word/document.xml")) {
/* Insert paragraphs content. */
- if (extract_docx_content_insert(
+ if (extract_content_insert(
alloc,
text,
+ NULL /*single*/,
"<w:body>",
"</w:body>",
contentss,
@@ -933,46 +725,6 @@ int extract_docx_content_item(
-static int check_path_shell_safe(const char* path)
-/* Returns -1 with errno=EINVAL if <path> contains sequences that could make it
-unsafe in shell commands. */
-{
- if (0
- || strstr(path, "..")
- || strchr(path, '\'')
- || strchr(path, '"')
- || strchr(path, ' ')
- ) {
- errno = EINVAL;
- return -1;
- }
- return 0;
-}
-
-static int remove_directory(extract_alloc_t* alloc, const char* path)
-{
- if (check_path_shell_safe(path)) {
- outf("path_out is unsafe: %s", path);
- return -1;
- }
- return systemf(alloc, "rm -r '%s'", path);
-}
-
-#ifdef _WIN32
-#include <direct.h>
-static int s_mkdir(const char* path, int mode)
-{
- (void) mode;
- return _mkdir(path);
-}
-#else
-static int s_mkdir(const char* path, int mode)
-{
- return mkdir(path, mode);
-}
-#endif
-
-
int extract_docx_write_template(
extract_alloc_t* alloc,
extract_astring_t* contentss,
@@ -994,24 +746,24 @@ int extract_docx_write_template(
assert(path_out);
assert(path_template);
- if (check_path_shell_safe(path_out)) {
+ if (extract_check_path_shell_safe(path_out)) {
outf("path_out is unsafe: %s", path_out);
goto end;
}
outf("images->images_num=%i", images->images_num);
if (extract_asprintf(alloc, &path_tempdir, "%s.dir", path_out) < 0) goto end;
- if (systemf(alloc, "rm -r '%s' 2>/dev/null", path_tempdir) < 0) goto end;
+ if (extract_systemf(alloc, "rm -r '%s' 2>/dev/null", path_tempdir) < 0) goto end;
- if (s_mkdir(path_tempdir, 0777)) {
+ if (extract_mkdir(path_tempdir, 0777)) {
outf("Failed to create directory: %s", path_tempdir);
goto end;
}
outf("Unzipping template document '%s' to tempdir: %s",
path_template, path_tempdir);
- e = systemf(alloc, "unzip -q -d '%s' '%s'", path_tempdir, path_template);
- if (e) {
+ if (extract_systemf(alloc, "unzip -q -d '%s' '%s'", path_tempdir, path_template))
+ {
outf("Failed to unzip %s into %s",
path_template, path_tempdir);
goto end;
@@ -1034,7 +786,7 @@ int extract_docx_write_template(
extract_free(alloc, &text);
extract_free(alloc, &text2);
if (extract_asprintf(alloc, &path, "%s/%s", path_tempdir, name) < 0) goto end;
- if (read_all_path(alloc, path, &text)) goto end;
+ if (extract_read_all_path(alloc, path, &text)) goto end;
if (extract_docx_content_item(
alloc,
@@ -1045,9 +797,10 @@ int extract_docx_write_template(
text,
&text2
)) goto end;
+
{
const char* text3 = (text2) ? text2 : text;
- if (write_all(text3, strlen(text3), path)) goto end;
+ if (extract_write_all(text3, strlen(text3), path)) goto end;
}
}
}
@@ -1055,21 +808,21 @@ int extract_docx_write_template(
/* Copy images into <path_tempdir>/media/. */
extract_free(alloc, &path);
if (extract_asprintf(alloc, &path, "%s/word/media", path_tempdir) < 0) goto end;
- if (s_mkdir(path, 0777)) goto end;
+ if (extract_mkdir(path, 0777)) goto end;
for (i=0; i<images->images_num; ++i) {
image_t* image = &images->images[i];
extract_free(alloc, &path);
if (extract_asprintf(alloc, &path, "%s/word/media/%s", path_tempdir, image->name) < 0) goto end;
- if (write_all(image->data, image->data_size, path)) goto end;
+ if (extract_write_all(image->data, image->data_size, path)) goto end;
}
outf("Zipping tempdir to create %s", path_out);
{
const char* path_out_leaf = strrchr(path_out, '/');
if (!path_out_leaf) path_out_leaf = path_out;
- e = systemf(alloc, "cd '%s' && zip -q -r -D '../%s' .", path_tempdir, path_out_leaf);
- if (e) {
+ if (extract_systemf(alloc, "cd '%s' && zip -q -r -D '../%s' .", path_tempdir, path_out_leaf))
+ {
outf("Zip command failed to convert '%s' directory into output file: %s",
path_tempdir, path_out);
goto end;
@@ -1077,7 +830,7 @@ int extract_docx_write_template(
}
if (!preserve_dir) {
- if (remove_directory(alloc, path_tempdir)) goto end;
+ if (extract_remove_directory(alloc, path_tempdir)) goto end;
}
e = 0;
diff --git a/extract/src/docx_template_build.py b/extract/src/docx_template_build.py
index b528bcb5..5e2f5380 100755
--- a/extract/src/docx_template_build.py
+++ b/extract/src/docx_template_build.py
@@ -1,12 +1,19 @@
#! /usr/bin/env python3
'''
-Creates C code for creating docx files using internal template docx content.
+Creates C code for creating docx/odt files using internal template docx/odt
+content.
Args:
- -i <docx-path>
- Set template docx file to extract from.
+ --pretty <directory>
+ Prettyfies all .xml files within <directory> using 'xmllint --format'.
+
+ -i <in-path>
+ Set template docx/odt file to extract from.
+
+ -n docx | odt
+ Infix to use in generated identifier names.
-o <out-path>
Set name of output files.
@@ -30,31 +37,33 @@ def system(command):
print(f'command failed: {command}')
assert 0
-def read(path):
+def read(path, encoding):
'''
- Returns contents of file. We assume it is utf-8.
+ Returns contents of file.
'''
with open(path, 'rb') as f:
raw = f.read()
- return raw.decode('utf-8')
+ if encoding:
+ return raw.decode(encoding)
+ return raw
-def write(text, path):
+def write(text, path, encoding):
'''
Writes text to file.
'''
parent = os.path.dirname(path)
if parent:
os.makedirs(parent, exist_ok=True)
- with open(path, 'w') as f:
- f.write(text)
+ with open(path, 'wb') as f:
+ f.write(text.encode(encoding))
-def write_if_diff(text, path):
- try:
- old = read(path)
- except Exception:
- old = None
- if text != old:
- write(text, path)
+def write_if_diff(text, path, encoding):
+ if os.path.isfile(path):
+ old = read(path, encoding)
+ if old == text:
+ return
+ print(f'Updating path={path} because contents have changed')
+ write(text, path, encoding)
def check_path_safe(path):
'''
@@ -88,6 +97,7 @@ def main():
path_in = None
path_out = None
+ infix = None
args = iter(sys.argv[1:])
while 1:
try: arg = next(args)
@@ -95,7 +105,7 @@ def main():
if arg == '-h' or arg == '--help':
print(__doc__)
return
- elif arg == '--docx-pretty':
+ elif arg == '--pretty':
d = next(args)
for dirpath, dirnames, filenames in os.walk(d):
for filename in filenames:
@@ -106,16 +116,20 @@ def main():
system(f'mv {path}- {path}')
elif arg == '-i':
path_in = next(args)
+ elif arg == '-n':
+ infix = next(args)
elif arg == '-o':
path_out = next(args)
else:
- assert 0
+ assert 0, f'unrecognised arg: {arg}'
if not path_in:
return
if not path_in:
- raise Exception('Need to specify -i <docx-path>')
+ raise Exception('Need to specify -i <in-path>')
+ if not infix:
+ raise Exception('Need to specify -n <name>')
if not path_out:
raise Exception('Need to specify -o <out-path>')
@@ -132,7 +146,7 @@ def main():
out_c.write(f'\n')
- out_c.write('const docx_template_item_t docx_template_items[] =\n')
+ out_c.write(f'const {infix}_template_item_t {infix}_template_items[] =\n')
out_c.write(f'{{\n')
num_items = 0
@@ -147,63 +161,79 @@ def main():
if name:
if not name.endswith('/'):
name += '/'
- out_c3.write(f' if (extract_zip_write_file(zip, NULL, 0, "{name}")) goto end;\n')
+ out_c3.write(f' if (extract_zip_write_file(zip, NULL, 0, "{infix}")) goto end;\n')
for filename in sorted(filenames):
num_items += 1
path = os.path.join(dirpath, filename)
+ print(f'looking at path={path}')
name = path[ len(path_temp)+1: ]
- text = read(os.path.join(dirpath, filename))
- #print(f'first line is: %r' % text.split("\n")[0])
- text = text.replace('"', '\\"')
-
- # Looks like template files use \r\n when we interpret them as
- # utf-8, so we preserve this in the generated strings.
- #
- text = text.replace('\r\n', '\\r\\n"\n "')
-
- # Split on '<' to avoid overly-long lines, which break windows
- # compiler.
- #
- text = re.sub('([<][^/])', '"\n "\\1', text)
-
- # Remove name of document creator.
- #
- for tag in 'dc:creator', 'cp:lastModifiedBy':
- text = re.sub(f'[<]{tag}[>][^<]*[<]/{tag}[>]', f'<{tag}></{tag}>', text)
-
out_c.write(f' {{\n')
out_c.write(f' "{name}",\n')
- out_c.write(f' "{text}"\n')
+ if filename.endswith('.xml') or filename.endswith('.rels'):
+ text = read(os.path.join(dirpath, filename), 'utf-8')
+ #print(f'first line is: %r' % text.split("\n")[0])
+ text = text.replace('"', '\\"')
+
+ # Looks like .docx template files use \r\n when we interpret them as
+ # utf-8, so we preserve this in the generated strings.
+ #
+ # .odt seems to have first line ending with '\n', not '\r\n'.
+ #
+ text = text.replace('\r', '\\r')
+ text = text.replace('\n', '\\n"\n "')
+
+ # Split on '<' to avoid overly-long lines, which break windows
+ # compiler.
+ #
+ text = re.sub('([<][^/])', '"\n "\\1', text)
+
+ # Remove name of document creator.
+ #
+ for tag in 'dc:creator', 'cp:lastModifiedBy':
+ text = re.sub(f'[<]{tag}[>][^<]*[<]/{tag}[>]', f'<{tag}></{tag}>', text)
+
+ out_c.write(f' "{text}"\n')
+ else:
+ data = read(os.path.join(dirpath, filename), encoding=None)
+ out_c.write(f' "')
+ i = 0
+ for byte in data:
+ i += 1
+ if i % 16 == 0:
+ out_c.write(f'"\n "')
+ out_c.write(f'\\x{byte:02x}')
+ out_c.write(f'"\n')
+
out_c.write(f' }},\n')
out_c.write(f' \n')
out_c.write(f'}};\n')
out_c.write(f'\n')
- out_c.write(f'int docx_template_items_num = {num_items};\n')
+ out_c.write(f'int {infix}_template_items_num = {num_items};\n')
out_c = out_c.getvalue()
- write_if_diff(out_c, f'{path_out}.c')
+ write_if_diff(out_c, f'{path_out}.c', 'utf-8')
out_h = io.StringIO()
- out_h.write(f'#ifndef EXTRACT_DOCX_TEMPLATE_H\n')
- out_h.write(f'#define EXTRACT_DOCX_TEMPLATE_H\n')
+ out_h.write(f'#ifndef EXTRACT_{infix.upper()}_TEMPLATE_H\n')
+ out_h.write(f'#define EXTRACT_{infix.upper()}_TEMPLATE_H\n')
out_h.write(f'\n')
out_h.write(f'/* THIS IS AUTO-GENERATED CODE, DO NOT EDIT. */\n')
out_h.write(f'\n')
out_h.write(f'\n')
out_h.write(f'typedef struct\n')
out_h.write(f'{{\n')
- out_h.write(f' const char* name; /* Name of item in docx archive. */\n')
- out_h.write(f' const char* text; /* Contents of item in docx archive. */\n')
- out_h.write(f'}} docx_template_item_t;\n')
+ out_h.write(f' const char* name; /* Name of item in {infix} archive. */\n')
+ out_h.write(f' const char* text; /* Contents of item in {infix} archive. */\n')
+ out_h.write(f'}} {infix}_template_item_t;\n')
out_h.write(f'\n')
- out_h.write(f'extern const docx_template_item_t docx_template_items[];\n')
- out_h.write(f'extern int docx_template_items_num;\n')
+ out_h.write(f'extern const {infix}_template_item_t {infix}_template_items[];\n')
+ out_h.write(f'extern int {infix}_template_items_num;\n')
out_h.write(f'\n')
out_h.write(f'\n')
out_h.write(f'#endif\n')
- write_if_diff(out_h.getvalue(), f'{path_out}.h')
+ write_if_diff(out_h.getvalue(), f'{path_out}.h', 'utf-8')
#os.system(f'rm -r "{path_temp}"')
if __name__ == '__main__':
diff --git a/extract/src/extract-exe.c b/extract/src/extract-exe.c
index d3ac81d0..22b520db 100644
--- a/extract/src/extract-exe.c
+++ b/extract/src/extract-exe.c
@@ -60,6 +60,7 @@ int main(int argc, char** argv)
int autosplit = 0;
int images = 1;
int alloc_stats = 0;
+ int format = -1;
int i;
extract_alloc_t* alloc = NULL;
@@ -91,6 +92,8 @@ int main(int argc, char** argv)
" --autosplit 0|1\n"
" If 1, we initially split spans when y coordinate changes. This\n"
" stresses our handling of spans when input is from mupdf.\n"
+ " -f odt | docx\n"
+ " Sets output format. Required.\n"
" -i <intermediate-path>\n"
" Path of XML file containing intermediate text spans.\n"
" -o <docx-path>\n"
@@ -110,7 +113,7 @@ int main(int argc, char** argv)
" vertical space between paragraphs that had different ctm matrices\n"
" in the original document.\n"
" -t <docx-template>\n"
- " If specified we use <docx-template> as template. Otheerwise we use"
+ " If specified we use <docx-template> as template. Otheerwise we use\n"
" an internal template.\n"
" -v <verbose>\n"
" Set verbose level.\n"
@@ -131,6 +134,18 @@ int main(int argc, char** argv)
else if (!strcmp(arg, "--autosplit")) {
if (arg_next_int(argv, argc, &i, &autosplit)) goto end;
}
+ else if (!strcmp(arg, "-f")) {
+ const char* format_name;
+ if (arg_next_string(argv, argc, &i, &format_name)) goto end;
+ if (!strcmp(format_name, "odt")) format = extract_format_ODT;
+ else if (!strcmp(format_name, "docx")) format = extract_format_DOCX;
+ else
+ {
+ printf("-f value should be 'odt' or 'docx', not '%s'.\n", format_name);
+ errno = EINVAL;
+ goto end;
+ }
+ }
else if (!strcmp(arg, "-i")) {
if (arg_next_string(argv, argc, &i, &input_path)) goto end;
}
@@ -169,6 +184,13 @@ int main(int argc, char** argv)
assert(i < argc);
}
+
+ if (format == -1)
+ {
+ printf("'-f odt | docx' must be specified\n");
+ errno = EINVAL;
+ goto end;
+ }
if (!input_path) {
printf("-i <input-path> not specified.\n");
@@ -181,8 +203,9 @@ int main(int argc, char** argv)
goto end;
}
- if (extract_begin(alloc, &extract)) goto end;
+ if (extract_begin(alloc, format, &extract)) goto end;
if (extract_read_intermediate(extract, intermediate, autosplit)) goto end;
+
if (extract_process(extract, spacing, rotation, images)) goto end;
if (content_path) {
diff --git a/extract/src/extract.c b/extract/src/extract.c
index adb3565e..9eb85d2f 100644
--- a/extract/src/extract.c
+++ b/extract/src/extract.c
@@ -7,6 +7,8 @@
#include "docx_template.h"
#include "mem.h"
#include "memento.h"
+#include "odt.h"
+#include "odt_template.h"
#include "outf.h"
#include "xml.h"
#include "zip.h"
@@ -74,7 +76,7 @@ const char* span_string(extract_alloc_t* alloc, span_t* span)
span->font_name,
span->trm.a,
span->trm.d,
- span->wmode,
+ span->flags.wmode,
span->chars_num
);
extract_astring_cat(alloc, &ret, buffer);
@@ -155,7 +157,7 @@ span_t* line_span_first(line_t* line)
return line->spans[0];
}
-static void page_free(extract_alloc_t* alloc, page_t* page)
+static void page_free(extract_alloc_t* alloc, extract_page_t* page)
{
int s;
if (!page) return;
@@ -204,9 +206,9 @@ static void page_free(extract_alloc_t* alloc, page_t* page)
extract_free(alloc, &page->images);
}
-static span_t* page_span_append(extract_alloc_t* alloc, page_t* page)
-/* Appends new empty span_ to an page_t; returns NULL with errno set on error.
-*/
+static span_t* page_span_append(extract_alloc_t* alloc, extract_page_t* page)
+/* Appends new empty span_ to an extract_page_t; returns NULL with errno set on
+error. */
{
span_t* span;
if (extract_malloc(alloc, &span, sizeof(*span))) return NULL;
@@ -257,9 +259,9 @@ On return document->page[].images* will be NULL etc.
int e = -1;
int p;
images_t images = {0};
- outf("images.images_num=%i", images.images_num);
+ outf("extract_document_images(): images.images_num=%i", images.images_num);
for (p=0; p<document->pages_num; ++p) {
- page_t* page = document->pages[p];
+ extract_page_t* page = document->pages[p];
int i;
for (i=0; i<page->images_num; ++i) {
image_t* image;
@@ -327,7 +329,7 @@ static void extract_document_free(extract_alloc_t* alloc, document_t* document)
return;
}
for (p=0; p<document->pages_num; ++p) {
- page_t* page = document->pages[p];
+ extract_page_t* page = document->pages[p];
page_free(alloc, page);
extract_free(alloc, &page);
}
@@ -396,7 +398,7 @@ static void s_document_init(document_t* document)
}
-static int page_span_end_clean(extract_alloc_t* alloc, page_t* page)
+static int page_span_end_clean(extract_alloc_t* alloc, extract_page_t* page)
/* Does preliminary processing of the end of the last span in a page; intended
to be called as we load span information.
@@ -428,7 +430,7 @@ char_t into a new span_t. */
font_size = matrix_expansion(span->trm)
* matrix_expansion(span->ctm);
- if (span->wmode) {
+ if (span->flags.wmode) {
dir.x = 0;
dir.y = 1;
}
@@ -534,18 +536,28 @@ struct extract_t
int contentss_num;
images_t images;
-};
+ extract_format_t format;
+ extract_odt_styles_t odt_styles;
+};
int extract_begin(
extract_alloc_t* alloc,
+ extract_format_t format,
extract_t** pextract
)
{
int e = -1;
extract_t* extract;
+ if (format != extract_format_ODT && format != extract_format_DOCX)
+ {
+ outf0("Invalid format=%i\n", format);
+ errno = EINVAL;
+ return -1;
+ }
+
/* Use a temporary extract_alloc_t to allocate space for the extract_t. */
if (extract_malloc(alloc, &extract, sizeof(*extract))) goto end;
@@ -557,6 +569,8 @@ int extract_begin(
*/
extract->image_n = 10;
+ extract->format = format;
+
e = 0;
end:
@@ -564,6 +578,7 @@ int extract_begin(
return e;
}
+
static void image_free_fn(void* handle, void* image_data)
{
(void) handle;
@@ -603,7 +618,7 @@ int extract_read_intermediate(extract_t* extract, extract_buffer_t* buffer, int
</page>
...
- We convert this into a list of page_t's, each containing a list of
+ We convert this into a list of extract_page_t's, each containing a list of
span_t's, each containing a list of char_t's.
While doing this, we do some within-span processing by calling
@@ -612,7 +627,7 @@ int extract_read_intermediate(extract_t* extract, extract_buffer_t* buffer, int
Split spans in two where there seem to be large gaps between glyphs.
*/
for(;;) {
- page_t* page;
+ extract_page_t* page;
int e = extract_xml_pparse_next(buffer, &tag);
if (e == 1) break; /* EOF. */
if (e) goto end;
@@ -853,7 +868,7 @@ int extract_span_begin(
)
{
int e = -1;
- page_t* page;
+ extract_page_t* page;
span_t* span;
assert(extract->document.pages_num > 0);
page = extract->document.pages[extract->document.pages_num-1];
@@ -875,9 +890,9 @@ int extract_span_begin(
const char* ff = strchr(font_name, '+');
const char* f = (ff) ? ff+1 : font_name;
if (extract_strdup(extract->alloc, f, &span->font_name)) goto end;
- span->font_bold = font_bold ? 1 : 0;
- span->font_italic = font_italic ? 1 : 0;
- span->wmode = wmode ? 1 : 0;
+ span->flags.font_bold = font_bold ? 1 : 0;
+ span->flags.font_italic = font_italic ? 1 : 0;
+ span->flags.wmode = wmode ? 1 : 0;
extract->span_offset_x = 0;
extract->span_offset_y = 0;
}
@@ -898,7 +913,7 @@ int extract_add_char(
{
int e = -1;
char_t* char_;
- page_t* page = extract->document.pages[extract->document.pages_num-1];
+ extract_page_t* page = extract->document.pages[extract->document.pages_num-1];
span_t* span = page->spans[page->spans_num - 1];
if (autosplit && y - extract->span_offset_y != 0) {
@@ -966,7 +981,7 @@ int extract_add_char(
int extract_span_end(extract_t* extract)
{
- page_t* page = extract->document.pages[extract->document.pages_num-1];
+ extract_page_t* page = extract->document.pages[extract->document.pages_num-1];
span_t* span = page->spans[page->spans_num - 1];
if (span->chars_num == 0) {
/* Calling code called extract_span_begin() then extract_span_end()
@@ -986,22 +1001,21 @@ int extract_add_image(
double y,
double w,
double h,
- char* data,
+ void* data,
size_t data_size,
extract_image_data_free data_free,
void* data_free_handle
)
{
int e = -1;
- page_t* page = extract->document.pages[extract->document.pages_num-1];
+ extract_page_t* page = extract->document.pages[extract->document.pages_num-1];
image_t image_temp = {0};
- (void) x;
- (void) y;
- (void) w;
- (void) h;
-
extract->image_n += 1;
+ image_temp.x = x;
+ image_temp.y = y;
+ image_temp.w = w;
+ image_temp.h = h;
image_temp.data = data;
image_temp.data_size = data_size;
image_temp.data_free = data_free;
@@ -1037,9 +1051,9 @@ int extract_add_image(
int extract_page_begin(extract_t* extract)
{
- /* Appends new empty page_t to an extract->document. */
- page_t* page;
- if (extract_malloc(extract->alloc, &page, sizeof(page_t))) return -1;
+ /* Appends new empty extract_page_t to an extract->document. */
+ extract_page_t* page;
+ if (extract_malloc(extract->alloc, &page, sizeof(extract_page_t))) return -1;
page->spans = NULL;
page->spans_num = 0;
page->lines = NULL;
@@ -1051,8 +1065,8 @@ int extract_page_begin(extract_t* extract)
if (extract_realloc2(
extract->alloc,
&extract->document.pages,
- sizeof(page_t*) * extract->document.pages_num + 1,
- sizeof(page_t*) * (extract->document.pages_num + 1)
+ sizeof(extract_page_t*) * extract->document.pages_num + 1,
+ sizeof(extract_page_t*) * (extract->document.pages_num + 1)
)) {
extract_free(extract->alloc, &page);
return -1;
@@ -1089,15 +1103,37 @@ int extract_process(
if (extract_document_join(extract->alloc, &extract->document)) goto end;
- if (extract_document_to_docx_content(
- extract->alloc,
- &extract->document,
- spacing,
- rotation,
- images,
- &extract->contentss[extract->contentss_num - 1]
- )) goto end;
-
+ if (extract->format == extract_format_ODT)
+ {
+ if (extract_document_to_odt_content(
+ extract->alloc,
+ &extract->document,
+ spacing,
+ rotation,
+ images,
+ &extract->contentss[extract->contentss_num - 1],
+ &extract->odt_styles
+ )) goto end;
+ }
+ else if (extract->format == extract_format_DOCX)
+ {
+ if (extract_document_to_docx_content(
+ extract->alloc,
+ &extract->document,
+ spacing,
+ rotation,
+ images,
+ &extract->contentss[extract->contentss_num - 1]
+ )) goto end;
+ }
+ else
+ {
+ outf0("Invalid format=%i", extract->format);
+ assert(0);
+ errno = EINVAL;
+ return 1;
+ }
+
if (extract_document_images(extract->alloc, &extract->document, &extract->images)) goto end;
{
@@ -1124,33 +1160,75 @@ int extract_write(extract_t* extract, extract_buffer_t* buffer)
int i;
if (extract_zip_open(buffer, &zip)) goto end;
- for (i=0; i<docx_template_items_num; ++i) {
- const docx_template_item_t* item = &docx_template_items[i];
- extract_free(extract->alloc, &text2);
- outf("i=%i item->name=%s", i, item->name);
- if (extract_docx_content_item(
- extract->alloc,
- extract->contentss,
- extract->contentss_num,
- &extract->images,
- item->name,
- item->text,
- &text2
- )) {
- goto end;
+ if (extract->format == extract_format_ODT)
+ {
+ for (i=0; i<odt_template_items_num; ++i) {
+ const odt_template_item_t* item = &odt_template_items[i];
+ extract_free(extract->alloc, &text2);
+ outf("i=%i item->name=%s", i, item->name);
+ if (extract_odt_content_item(
+ extract->alloc,
+ extract->contentss,
+ extract->contentss_num,
+ &extract->odt_styles,
+ &extract->images,
+ item->name,
+ item->text,
+ &text2
+ ))
+ {
+ goto end;
+ }
+ {
+ const char* text3 = (text2) ? text2 : item->text;
+ if (extract_zip_write_file(zip, text3, strlen(text3), item->name)) goto end;
+ }
}
-
- {
- const char* text3 = (text2) ? text2 : item->text;
- if (extract_zip_write_file(zip, text3, strlen(text3), item->name)) goto end;
+ outf0("extract->images.images_num=%i", extract->images.images_num);
+ for (i=0; i<extract->images.images_num; ++i) {
+ image_t* image = &extract->images.images[i];
+ extract_free(extract->alloc, &text2);
+ if (extract_asprintf(extract->alloc, &text2, "Pictures/%s", image->name) < 0) goto end;
+ if (extract_zip_write_file(zip, image->data, image->data_size, text2)) goto end;
}
}
-
- for (i=0; i<extract->images.images_num; ++i) {
- image_t* image = &extract->images.images[i];
- extract_free(extract->alloc, &text2);
- if (extract_asprintf(extract->alloc, &text2, "word/media/%s", image->name) < 0) goto end;
- if (extract_zip_write_file(zip, image->data, image->data_size, text2)) goto end;
+ else if (extract->format == extract_format_DOCX)
+ {
+ for (i=0; i<docx_template_items_num; ++i) {
+ const docx_template_item_t* item = &docx_template_items[i];
+ extract_free(extract->alloc, &text2);
+ outf("i=%i item->name=%s", i, item->name);
+ if (extract_docx_content_item(
+ extract->alloc,
+ extract->contentss,
+ extract->contentss_num,
+ &extract->images,
+ item->name,
+ item->text,
+ &text2
+ ))
+ {
+ goto end;
+ }
+
+ {
+ const char* text3 = (text2) ? text2 : item->text;
+ if (extract_zip_write_file(zip, text3, strlen(text3), item->name)) goto end;
+ }
+ }
+ for (i=0; i<extract->images.images_num; ++i) {
+ image_t* image = &extract->images.images[i];
+ extract_free(extract->alloc, &text2);
+ if (extract_asprintf(extract->alloc, &text2, "word/media/%s", image->name) < 0) goto end;
+ if (extract_zip_write_file(zip, image->data, image->data_size, text2)) goto end;
+ }
+ }
+ else
+ {
+ outf0("Invalid format=%i", extract->format);
+ assert(0);
+ errno = EINVAL;
+ return 1;
}
if (extract_zip_close(&zip)) goto end;
@@ -1180,6 +1258,14 @@ int extract_write_content(extract_t* extract, extract_buffer_t* buffer)
return 0;
}
+static int string_ends_with(const char* string, const char* end)
+{
+ size_t string_len = strlen(string);
+ size_t end_len = strlen(end);
+ if (end_len > string_len) return 0;
+ return memcmp(string + string_len - end_len, end, end_len) == 0;
+}
+
int extract_write_template(
extract_t* extract,
const char* path_template,
@@ -1187,15 +1273,31 @@ int extract_write_template(
int preserve_dir
)
{
- return extract_docx_write_template(
- extract->alloc,
- extract->contentss,
- extract->contentss_num,
- &extract->images,
- path_template,
- path_out,
- preserve_dir
- );
+ if (string_ends_with(path_out, ".odt"))
+ {
+ return extract_odt_write_template(
+ extract->alloc,
+ extract->contentss,
+ extract->contentss_num,
+ &extract->odt_styles,
+ &extract->images,
+ path_template,
+ path_out,
+ preserve_dir
+ );
+ }
+ else
+ {
+ return extract_docx_write_template(
+ extract->alloc,
+ extract->contentss,
+ extract->contentss_num,
+ &extract->images,
+ path_template,
+ path_out,
+ preserve_dir
+ );
+ }
}
void extract_end(extract_t** pextract)
@@ -1224,3 +1326,12 @@ void extract_exp_min(extract_t* extract, size_t size)
{
extract_alloc_exp_min(extract->alloc, size);
}
+
+double extract_matrices_to_font_size(matrix_t* ctm, matrix_t* trm)
+{
+ double font_size = matrix_expansion(*trm)
+ * matrix_expansion(*ctm);
+ /* Round font_size to nearest 0.01. */
+ font_size = (double) (int) (font_size * 100.0f + 0.5f) / 100.0f;
+ return font_size;
+}
diff --git a/extract/src/join.c b/extract/src/join.c
index bc02ea21..f12e2751 100644
--- a/extract/src/join.c
+++ b/extract/src/join.c
@@ -182,7 +182,7 @@ static int lines_are_compatible(
{
if (a == b) return 0;
if (!a->spans || !b->spans) return 0;
- if (line_span_first(a)->wmode != line_span_first(b)->wmode) {
+ if (line_span_first(a)->flags.wmode != line_span_first(b)->flags.wmode) {
return 0;
}
if (matrix_cmp4(
@@ -923,7 +923,7 @@ int extract_document_join(extract_alloc_t* alloc, document_t* document)
*/
int p;
for (p=0; p<document->pages_num; ++p) {
- page_t* page = document->pages[p];
+ extract_page_t* page = document->pages[p];
outf("processing page %i: num_spans=%i", p, page->spans_num);
if (make_lines(
diff --git a/extract/src/mem.h b/extract/src/mem.h
index 59729b1a..ffdcb049 100644
--- a/extract/src/mem.h
+++ b/extract/src/mem.h
@@ -1,6 +1,8 @@
#ifndef EXTRACT_MEM_H
#define EXTRACT_MEM_H
+#include "../include/extract_alloc.h"
+
#include <stdarg.h>
#include <string.h>
diff --git a/extract/src/odt.c b/extract/src/odt.c
new file mode 100644
index 00000000..bacb362d
--- /dev/null
+++ b/extract/src/odt.c
@@ -0,0 +1,880 @@
+/* These extract_odt_*() functions generate odt content and odt zip archive
+data.
+
+Caller must call things in a sensible order to create valid content -
+e.g. don't call odt_paragraph_start() twice without intervening call to
+odt_paragraph_finish(). */
+
+#include "../include/extract.h"
+
+#include "odt_template.h"
+
+#include "astring.h"
+#include "document.h"
+#include "odt.h"
+#include "mem.h"
+#include "memento.h"
+#include "outf.h"
+#include "sys.h"
+#include "text.h"
+#include "zip.h"
+
+#include <assert.h>
+#include <errno.h>
+#include <math.h>
+#include <stdlib.h>
+#include <stdio.h>
+#include <string.h>
+
+#include <sys/stat.h>
+
+
+static int extract_odt_paragraph_start(extract_alloc_t* alloc, extract_astring_t* content)
+{
+ return extract_astring_cat(alloc, content, "\n\n<text:p>");
+}
+
+static int extract_odt_paragraph_finish(extract_alloc_t* alloc, extract_astring_t* content)
+{
+ return extract_astring_cat(alloc, content, "</text:p>");
+}
+
+
+/* ODT doesn't seem to support ad-hoc inline font specifications; instead
+we have to define a style at the start of the content.xml file. So when
+writing content we insert a style name and add the required styles to a
+extract_odt_styles_t struct. */
+
+struct extract_odt_style_t
+{
+ int id; /* A unique id for this style. */
+ char* font_name;
+ double font_size;
+ int font_bold;
+ int font_italic;
+};
+
+struct extract_odt_styles_t
+{
+ /* Styles are stored sorted. */
+ extract_odt_style_t* styles;
+ int styles_num;
+};
+
+static int extract_odt_style_compare(extract_odt_style_t* a, extract_odt_style_t*b)
+{
+ int d;
+ double dd;
+ if ((d = strcmp(a->font_name, b->font_name))) return d;
+ if ((dd = a->font_size - b->font_size) != 0.0) return (dd > 0.0) ? 1 : -1;
+ if ((d = a->font_bold - b->font_bold)) return d;
+ if ((d = a->font_italic - b->font_italic)) return d;
+ return 0;
+}
+
+static int extract_odt_style_append_definition(extract_alloc_t* alloc, extract_odt_style_t* style, extract_astring_t* text)
+{
+ const char* font_name = style->font_name;
+ /* This improves output e.g. for zlib.3.pdf, but clearly a hack. */
+ if (0 && strstr(font_name, "Helvetica"))
+ {
+ font_name = "Liberation Sans";
+ }
+ outf("style->font_name=%s font_name=%s", style->font_name, font_name);
+ if (extract_astring_catf(alloc, text, "<style:style style:name=\"T%i\" style:family=\"text\">", style->id)) return -1;
+ if (extract_astring_catf(alloc, text, "<style:text-properties style:font-name=\"%s\"", font_name)) return -1;
+ if (extract_astring_catf(alloc, text, " fo:font-size=\"%.2fpt\"", style->font_size)) return -1;
+ if (extract_astring_catf(alloc, text, " fo:font-weight=\"%s\"", style->font_bold ? "bold" : "normal")) return -1;
+ if (extract_astring_catf(alloc, text, " fo:font-style=\"%s\"", style->font_italic ? "italic" : "normal")) return -1;
+ if (extract_astring_cat(alloc, text, " /></style:style>")) return -1;
+ return 0;
+}
+
+void extract_odt_styles_free(extract_alloc_t* alloc, extract_odt_styles_t* styles)
+{
+ extract_free(alloc, &styles->styles);
+}
+
+static int extract_odt_styles_definitions(
+ extract_alloc_t* alloc,
+ extract_odt_styles_t* styles,
+ extract_astring_t* out
+ )
+{
+ int i;
+ if (extract_astring_cat(alloc, out, "<office:automatic-styles>")) return -1;
+ for (i=0; i<styles->styles_num; ++i)
+ {
+ if (extract_odt_style_append_definition(alloc, &styles->styles[i], out)) return -1;
+ }
+ extract_astring_cat(alloc, out, "<style:style style:name=\"gr1\" style:family=\"graphic\">\n");
+ extract_astring_cat(alloc, out, "<style:graphic-properties"
+ " draw:stroke=\"none\""
+ " svg:stroke-color=\"#000000\""
+ " draw:fill=\"none\""
+ " draw:fill-color=\"#ffffff\""
+ " fo:min-height=\"1.9898in\""
+ " style:run-through=\"foreground\""
+ " style:wrap=\"run-through\""
+ " style:number-wrapped-paragraphs=\"no-limit\""
+ " style:vertical-pos=\"from-top\""
+ " style:vertical-rel=\"paragraph\""
+ " style:horizontal-pos=\"from-left\""
+ " style:horizontal-rel=\"paragraph\""
+ " />\n"
+ );
+ extract_astring_cat(alloc, out, "<style:paragraph-properties style:writing-mode=\"lr-tb\"/>\n");
+ extract_astring_cat(alloc, out, "</style:style>\n");
+
+ /* Style for images. */
+ extract_astring_cat(alloc, out, "<style:style style:name=\"fr1\" style:family=\"graphic\" style:parent-style-name=\"Graphics\">\n");
+ extract_astring_cat(alloc, out, "<style:graphic-properties"
+ " fo:margin-left=\"0in\""
+ " fo:margin-right=\"0in\""
+ " fo:margin-top=\"0in\""
+ " fo:margin-bottom=\"0in\""
+ " style:vertical-pos=\"top\""
+ " style:vertical-rel=\"baseline\""
+ " fo:background-color=\"transparent\""
+ " draw:fill=\"none\""
+ " draw:fill-color=\"#ffffff\""
+ " fo:padding=\"0in\""
+ " fo:border=\"none\""
+ " style:mirror=\"none\""
+ " fo:clip=\"rect(0in, 0in, 0in, 0in)\""
+ " draw:luminance=\"0%\""
+ " draw:contrast=\"0%\""
+ " draw:red=\"0%\""
+ " draw:green=\"0%\""
+ " draw:blue=\"0%\""
+ " draw:gamma=\"100%\""
+ " draw:color-inversion=\"false\""
+ " draw:image-opacity=\"100%\""
+ " draw:color-mode=\"standard\""
+ "/>\n");
+ extract_astring_cat(alloc, out, "</style:style>\n");
+
+
+ if (extract_astring_cat(alloc, out, "</office:automatic-styles>")) return -1;
+ return 0;
+}
+
+static int styles_add(
+ extract_alloc_t* alloc,
+ extract_odt_styles_t* styles,
+ const char* font_name,
+ double font_size,
+ int font_bold,
+ int font_italic,
+ extract_odt_style_t** o_style
+ )
+/* Adds specified style to <styles> if not already present. Sets *o_style to
+point to the style_t within <styles>. */
+{
+ extract_odt_style_t style = {0 /*id*/, (char*) font_name, font_size, font_bold, font_italic};
+ int i;
+ /* We keep styles->styles[] sorted; todo: use bsearch or similar when
+ searching. */
+ for (i=0; i<styles->styles_num; ++i)
+ {
+ int d = extract_odt_style_compare(&style, &styles->styles[i]);
+ if (d == 0)
+ {
+ *o_style = &styles->styles[i];
+ return 0;
+ }
+ if (d > 0) break;
+ }
+ /* Insert at position <i>. */
+ if (extract_realloc(alloc, &styles->styles, sizeof(styles->styles[0]) * (styles->styles_num+1))) return -1;
+ memmove(&styles->styles[i+1], &styles->styles[i], sizeof(styles->styles[0]) * (styles->styles_num - i));
+ styles->styles_num += 1;
+ styles->styles[i].id = styles->styles_num + 10; /* Leave space for template's built-in styles. */
+ if (extract_strdup(alloc, font_name, &styles->styles[i].font_name)) return -1;
+ styles->styles[i].font_size = font_size;
+ styles->styles[i].font_bold = font_bold;
+ styles->styles[i].font_italic = font_italic;
+ *o_style = &styles->styles[i];
+ return 0;
+}
+
+static int extract_odt_run_start(
+ extract_alloc_t* alloc,
+ extract_astring_t* content,
+ extract_odt_styles_t* styles,
+ const char* font_name,
+ double font_size,
+ int bold,
+ int italic
+ )
+/* Starts a new run. Caller must ensure that extract_odt_run_finish() was
+called to terminate any previous run. */
+{
+ extract_odt_style_t* style;
+ if (styles_add(alloc, styles, font_name, font_size, bold, italic, &style)) return -1;
+ if (extract_astring_catf(alloc, content, "<text:span text:style-name=\"T%i\">", style->id)) return -1;
+ return 0;
+}
+
+static int extract_odt_run_finish(extract_alloc_t* alloc, extract_astring_t* content)
+{
+ return extract_astring_cat(alloc, content, "</text:span>");
+}
+
+static int extract_odt_paragraph_empty(extract_alloc_t* alloc, extract_astring_t* content, extract_odt_styles_t* styles)
+/* Append an empty paragraph to *content. */
+{
+ int e = -1;
+ if (extract_odt_paragraph_start(alloc, content)) goto end;
+ /* [This comment is from docx, haven't checked odt.] It seems like our
+ choice of font size here doesn't make any difference to the ammount of
+ vertical space, unless we include a non-space character. Presumably
+ something to do with the styles in the template document. */
+ if (extract_odt_run_start(
+ alloc,
+ content,
+ styles,
+ "OpenSans",
+ 10 /*font_size*/,
+ 0 /*font_bold*/,
+ 0 /*font_italic*/
+ )) goto end;
+ //docx_char_append_string(content, "&#160;"); /* &#160; is non-break space. */
+ if (extract_odt_run_finish(alloc, content)) goto end;
+ if (extract_odt_paragraph_finish(alloc, content)) goto end;
+ e = 0;
+ end:
+ return e;
+}
+
+
+typedef struct
+{
+ const char* font_name;
+ double font_size;
+ int font_bold;
+ int font_italic;
+ matrix_t* ctm_prev;
+ /* todo: add extract_odt_styles_t member? */
+} content_state_t;
+/* Used to keep track of font information when writing paragraphs of odt
+content, e.g. so we know whether a font has changed so need to start a new odt
+span. */
+
+
+static int extract_document_to_odt_content_paragraph(
+ extract_alloc_t* alloc,
+ content_state_t* state,
+ paragraph_t* paragraph,
+ extract_astring_t* content,
+ extract_odt_styles_t* styles
+ )
+/* Append odt xml for <paragraph> to <content>. Updates *state if we change
+font. */
+{
+ int e = -1;
+ int l;
+
+ if (extract_odt_paragraph_start(alloc, content)) goto end;
+
+ for (l=0; l<paragraph->lines_num; ++l)
+ {
+ line_t* line = paragraph->lines[l];
+ int s;
+ for (s=0; s<line->spans_num; ++s)
+ {
+ int si;
+ span_t* span = line->spans[s];
+ double font_size_new;
+ state->ctm_prev = &span->ctm;
+ font_size_new = extract_matrices_to_font_size(&span->ctm, &span->trm);
+ if (!state->font_name
+ || strcmp(span->font_name, state->font_name)
+ || span->flags.font_bold != state->font_bold
+ || span->flags.font_italic != state->font_italic
+ || font_size_new != state->font_size
+ )
+ {
+ if (state->font_name)
+ {
+ if (extract_odt_run_finish(alloc, content)) goto end;
+ }
+ state->font_name = span->font_name;
+ state->font_bold = span->flags.font_bold;
+ state->font_italic = span->flags.font_italic;
+ state->font_size = font_size_new;
+ if (extract_odt_run_start(
+ alloc,
+ content,
+ styles,
+ state->font_name,
+ state->font_size,
+ state->font_bold,
+ state->font_italic
+ )) goto end;
+ }
+
+ for (si=0; si<span->chars_num; ++si)
+ {
+ char_t* char_ = &span->chars[si];
+ int c = char_->ucs;
+ if (extract_astring_cat_xmlc(alloc, content, c)) goto end;
+ }
+ /* Remove any trailing '-' at end of line. */
+ if (astring_char_truncate_if(content, '-')) goto end;
+ }
+ }
+ if (state->font_name)
+ {
+ if (extract_odt_run_finish(alloc, content)) goto end;
+ state->font_name = NULL;
+ }
+ if (extract_odt_paragraph_finish(alloc, content)) goto end;
+
+ e = 0;
+
+ end:
+ return e;
+}
+
+static int extract_document_append_image(
+ extract_alloc_t* alloc,
+ extract_astring_t* content,
+ image_t* image
+ )
+/* Write reference to image into odt content. */
+{
+ extract_astring_cat(alloc, content, "\n");
+ extract_astring_cat(alloc, content, "<text:p text:style-name=\"Standard\">\n");
+ extract_astring_catf(alloc, content, "<draw:frame draw:style-name=\"fr1\" draw:name=\"Picture %s\" text:anchor-type=\"as-char\" svg:width=\"%fin\" svg:height=\"%fin\" draw:z-index=\"0\">\n",
+ image->id,
+ image->w / 72.0,
+ image->h / 72.0
+ );
+ extract_astring_catf(alloc, content, "<draw:image xlink:href=\"Pictures/%s\" xlink:type=\"simple\" xlink:show=\"embed\" xlink:actuate=\"onLoad\" draw:mime-type=\"image/%s\"/>\n",
+ image->name,
+ image->type
+ );
+ extract_astring_cat(alloc, content, "</draw:frame>\n");
+ extract_astring_cat(alloc, content, "</text:p>\n");
+
+ return 0;
+}
+
+
+static int extract_document_output_rotated_paragraphs(
+ extract_alloc_t* alloc,
+ extract_page_t* page,
+ int paragraph_begin,
+ int paragraph_end,
+ double rotation_rad,
+ double x_pt,
+ double y_pt,
+ double w_pt,
+ double h_pt,
+ int text_box_id,
+ extract_astring_t* content,
+ extract_odt_styles_t* styles,
+ content_state_t* state
+ )
+/* Writes paragraph to content inside rotated text box. */
+{
+ int e = 0;
+ int p;
+ double pt_to_inch = 1/72.0;
+ outf("rotated paragraphs: rotation_rad=%f (x y)=(%i %i) (w h)=(%i %i)", rotation_rad, x_pt, y_pt, w_pt, h_pt);
+
+ // https://docs.oasis-open.org/office/OpenDocument/v1.3/cs02/part3-schema/OpenDocument-v1.3-cs02-part3-schema.html#attribute-draw_transform
+ // says rotation is in degrees, but we seem to require -radians.
+ //
+
+ if (!e) e = extract_astring_cat(alloc, content, "\n");
+
+ if (!e) e = extract_astring_cat(alloc, content, "<text:p text:style-name=\"Standard\">\n");
+ if (!e) e = extract_astring_catf(alloc, content, "<draw:frame"
+ " text:anchor-type=\"paragraph\""
+ " draw:z-index=\"5\""
+ " draw:name=\"Shape%i\""
+ " draw:style-name=\"gr1\""
+ " draw:text-style-name=\"Standard\""
+ " svg:width=\"%fin\""
+ " svg:height=\"%fin\""
+ " draw:transform=\"rotate (%f) translate (%fin %fin)\""
+ ">\n"
+ ,
+ text_box_id,
+ w_pt * pt_to_inch,
+ h_pt * pt_to_inch,
+ -rotation_rad,
+ x_pt * pt_to_inch,
+ y_pt * pt_to_inch
+ );
+ if (!e) e = extract_astring_cat(alloc, content, "<draw:text-box>\n");
+
+ for (p=paragraph_begin; p<paragraph_end; ++p)
+ {
+ paragraph_t* paragraph = page->paragraphs[p];
+ if (!e) e = extract_document_to_odt_content_paragraph(alloc, state, paragraph, content, styles);
+ }
+
+ if (!e) e = extract_astring_cat(alloc, content, "\n");
+ if (!e) e = extract_astring_cat(alloc, content, "</draw:text-box>\n");
+ if (!e) e = extract_astring_cat(alloc, content, "</draw:frame>\n");
+
+ if (!e) e = extract_astring_cat(alloc, content, "</text:p>\n");
+
+ return e;
+}
+
+
+int extract_document_to_odt_content(
+ extract_alloc_t* alloc,
+ document_t* document,
+ int spacing,
+ int rotation,
+ int images,
+ extract_astring_t* content,
+ extract_odt_styles_t* styles
+ )
+{
+ int ret = -1;
+ int text_box_id = 0;
+ int p;
+
+ /* Write paragraphs into <content>. */
+ for (p=0; p<document->pages_num; ++p)
+ {
+ extract_page_t* page = document->pages[p];
+ int p;
+ content_state_t state;
+ state.font_name = NULL;
+ state.font_size = 0;
+ state.font_bold = 0;
+ state.font_italic = 0;
+ state.ctm_prev = NULL;
+
+ for (p=0; p<page->paragraphs_num; ++p)
+ {
+ paragraph_t* paragraph = page->paragraphs[p];
+ const matrix_t* ctm = &paragraph->lines[0]->spans[0]->ctm;
+ double rotate = atan2(ctm->b, ctm->a);
+
+ if (spacing
+ && state.ctm_prev
+ && paragraph->lines_num
+ && paragraph->lines[0]->spans_num
+ && matrix_cmp4(
+ state.ctm_prev,
+ &paragraph->lines[0]->spans[0]->ctm
+ )
+ )
+ {
+ /* Extra vertical space between paragraphs that were at
+ different angles in the original document. */
+ if (extract_odt_paragraph_empty(alloc, content, styles)) goto end;
+ }
+
+ if (spacing)
+ {
+ /* Extra vertical space between paragraphs. */
+ if (extract_odt_paragraph_empty(alloc, content, styles)) goto end;
+ }
+
+ if (rotation && rotate != 0)
+ {
+ /* Find extent of paragraphs with this same rotation. extent
+ will contain max width and max height of paragraphs, in units
+ before application of ctm, i.e. before rotation. */
+ point_t extent = {0, 0};
+ int p0 = p;
+ int p1;
+
+ outf("rotate=%.2frad=%.1fdeg ctm: ef=(%f %f) abcd=(%f %f %f %f)",
+ rotate, rotate * 180 / pi,
+ ctm->e,
+ ctm->f,
+ ctm->a,
+ ctm->b,
+ ctm->c,
+ ctm->d
+ );
+
+ {
+ /* We assume that first span is at origin of text
+ block. This assumes left-to-right text. */
+ double rotate0 = rotate;
+ const matrix_t* ctm0 = ctm;
+ point_t origin =
+ {
+ paragraph->lines[0]->spans[0]->chars[0].x,
+ paragraph->lines[0]->spans[0]->chars[0].y
+ };
+ matrix_t ctm_inverse = {1, 0, 0, 1, 0, 0};
+ double ctm_det = ctm->a*ctm->d - ctm->b*ctm->c;
+ if (ctm_det != 0)
+ {
+ ctm_inverse.a = +ctm->d / ctm_det;
+ ctm_inverse.b = -ctm->b / ctm_det;
+ ctm_inverse.c = -ctm->c / ctm_det;
+ ctm_inverse.d = +ctm->a / ctm_det;
+ }
+ else
+ {
+ outf("cannot invert ctm=(%f %f %f %f)",
+ ctm->a, ctm->b, ctm->c, ctm->d);
+ }
+
+ for (p=p0; p<page->paragraphs_num; ++p)
+ {
+ paragraph = page->paragraphs[p];
+ ctm = &paragraph->lines[0]->spans[0]->ctm;
+ rotate = atan2(ctm->b, ctm->a);
+ if (rotate != rotate0)
+ {
+ break;
+ }
+
+ /* Update <extent>. */
+ {
+ int l;
+ for (l=0; l<paragraph->lines_num; ++l)
+ {
+ line_t* line = paragraph->lines[l];
+ span_t* span = line_span_last(line);
+ char_t* char_ = span_char_last(span);
+ double adv = char_->adv * matrix_expansion(span->trm);
+ double x = char_->x + adv * cos(rotate);
+ double y = char_->y + adv * sin(rotate);
+
+ double dx = x - origin.x;
+ double dy = y - origin.y;
+
+ /* Position relative to origin and before box rotation. */
+ double xx = ctm_inverse.a * dx + ctm_inverse.b * dy;
+ double yy = ctm_inverse.c * dx + ctm_inverse.d * dy;
+ yy = -yy;
+ if (xx > extent.x) extent.x = xx;
+ if (yy > extent.y) extent.y = yy;
+ if (0) outf("rotate=%f p=%i: origin=(%f %f) xy=(%f %f) dxy=(%f %f) xxyy=(%f %f) span: %s",
+ rotate, p, origin.x, origin.y, x, y, dx, dy, xx, yy, span_string(alloc, span));
+ }
+ }
+ }
+ p1 = p;
+ rotate = rotate0;
+ ctm = ctm0;
+ outf("rotate=%f p0=%i p1=%i. extent is: (%f %f)",
+ rotate, p0, p1, extent.x, extent.y);
+ }
+
+ /* Paragraphs p0..p1-1 have same rotation. We output them into
+ a single rotated text box. */
+
+ /* We need unique id for text box. */
+ text_box_id += 1;
+
+ if (extract_document_output_rotated_paragraphs(
+ alloc,
+ page,
+ p0,
+ p1,
+ rotate,
+ ctm->e,
+ ctm->f,
+ extent.x,
+ extent.y,
+ text_box_id,
+ content,
+ styles,
+ &state
+ )) goto end;
+ p = p1 - 1;
+ }
+ else
+ {
+ if (extract_document_to_odt_content_paragraph(alloc, &state, paragraph, content, styles)) goto end;
+ }
+
+ }
+
+ outf("images=%i", images);
+ if (images)
+ {
+ int i;
+ outf("page->images_num=%i", page->images_num);
+ for (i=0; i<page->images_num; ++i)
+ {
+ extract_document_append_image(alloc, content, &page->images[i]);
+ }
+ }
+ }
+ ret = 0;
+
+ end:
+
+ return ret;
+}
+
+
+#if 0
+static int s_find_mid(const char* text, const char* begin, const char* end, const char** o_begin, const char** o_end)
+/* Sets *o_begin to end of first occurrence of <begin> in <text>, and *o_end to
+beginning of first occurtence of <end> in <text>. */
+{
+ *o_begin = strstr(text, begin);
+ if (!*o_begin) goto fail;
+ *o_begin += strlen(begin);
+ *o_end = strstr(*o_begin, end);
+ if (!*o_end) goto fail;
+ return 0;
+ fail:
+ errno = ESRCH;
+ return -1;
+}
+#endif
+
+int extract_odt_content_item(
+ extract_alloc_t* alloc,
+ extract_astring_t* contentss,
+ int contentss_num,
+ extract_odt_styles_t* styles,
+ images_t* images,
+ const char* name,
+ const char* text,
+ char** text2
+ )
+{
+ int e = -1;
+ extract_astring_t temp;
+ extract_astring_init(&temp);
+ *text2 = NULL;
+
+ (void) images;
+ if (0)
+ {}
+ else if (!strcmp(name, "content.xml"))
+ {
+ /* Insert paragraphs content. */
+ char* text_intermediate = NULL;
+ extract_astring_t styles_definitions = {0};
+
+ if (extract_content_insert(
+ alloc,
+ text,
+ NULL /*single*/,
+ NULL,
+ "</office:text>",
+ contentss,
+ contentss_num,
+ &text_intermediate
+ )) goto end;
+ outf("text_intermediate: %s", text_intermediate);
+
+ if (extract_odt_styles_definitions(alloc, styles, &styles_definitions)) goto end;
+
+ e = extract_content_insert(
+ alloc,
+ text_intermediate,
+ "<office:automatic-styles/>" /*single*/,
+ NULL,
+ NULL, //"</office:automatic-styles>",
+ &styles_definitions,
+ 1,
+ text2
+ );
+ outf("e=%i errno=%i", e, errno);
+ extract_free(alloc, &text_intermediate);
+ extract_astring_free(alloc, &styles_definitions);
+ outf("e=%i errno=%i", e, errno);
+ if (e) goto end;
+ }
+ else if (!strcmp(name, "META-INF/manifest.xml"))
+ {
+ /* Add images. */
+ int e = 0;
+ int i;
+ for (i=0; i<images->images_num; ++i)
+ {
+ image_t* image = &images->images[i];
+ if (!e) e = extract_astring_catf(alloc, &temp, "<manifest:file-entry manifest:full-path=\"Pictures/%s\" manifest:media-type=\"image/%s\"/>\n",
+ image->name,
+ image->type
+ );
+ }
+ if (!e) e = extract_content_insert(
+ alloc,
+ text,
+ NULL /*single*/,
+ NULL /*mid_begin_name*/,
+ "</manifest:manifest>" /*mid_end_name*/,
+ &temp,
+ 1,
+ text2
+ );
+ if (e) goto end;
+ }
+ else
+ {
+ *text2 = NULL;
+ }
+ e = 0;
+ end:
+ outf("e=%i errno=%i text2=%s", e, errno, text2);
+ if (e)
+ {
+ /* We might have set <text2> to new content. */
+ extract_free(alloc, text2);
+ /* We might have used <temp> as a temporary buffer. */
+ extract_astring_free(alloc, &temp);
+ }
+ extract_astring_init(&temp);
+ return e;
+}
+
+
+
+int extract_odt_write_template(
+ extract_alloc_t* alloc,
+ extract_astring_t* contentss,
+ int contentss_num,
+ extract_odt_styles_t* styles,
+ images_t* images,
+ const char* path_template,
+ const char* path_out,
+ int preserve_dir
+ )
+{
+ int e = -1;
+ int i;
+ char* path_tempdir = NULL;
+ FILE* f = NULL;
+ char* path = NULL;
+ char* text = NULL;
+ char* text2 = NULL;
+
+ assert(path_out);
+ assert(path_template);
+
+ if (extract_check_path_shell_safe(path_out))
+ {
+ outf("path_out is unsafe: %s", path_out);
+ goto end;
+ }
+
+ outf("images->images_num=%i", images->images_num);
+ if (extract_asprintf(alloc, &path_tempdir, "%s.dir", path_out) < 0) goto end;
+ if (extract_systemf(alloc, "rm -r '%s' 2>/dev/null", path_tempdir) < 0) goto end;
+
+ if (extract_mkdir(path_tempdir, 0777))
+ {
+ outf("Failed to create directory: %s", path_tempdir);
+ goto end;
+ }
+
+ outf("Unzipping template document '%s' to tempdir: %s",
+ path_template, path_tempdir);
+ if (extract_systemf(alloc, "unzip -q -d '%s' '%s'", path_tempdir, path_template))
+ {
+ outf("Failed to unzip %s into %s",
+ path_template, path_tempdir);
+ goto end;
+ }
+
+ /* Might be nice to iterate through all items in path_tempdir, but for now
+ we look at just the items that we know extract_odt_content_item() will
+ modify. */
+
+ {
+ const char* names[] =
+ {
+ "content.xml",
+ "META-INF/manifest.xml",
+ };
+ int names_num = sizeof(names) / sizeof(names[0]);
+ for (i=0; i<names_num; ++i)
+ {
+ const char* name = names[i];
+ extract_free(alloc, &path);
+ extract_free(alloc, &text);
+ extract_free(alloc, &text2);
+ if (extract_asprintf(alloc, &path, "%s/%s", path_tempdir, name) < 0) goto end;
+ if (extract_read_all_path(alloc, path, &text)) goto end;
+
+ outf("before extract_odt_content_item() styles->styles_num=%i", styles->styles_num);
+ if (extract_odt_content_item(
+ alloc,
+ contentss,
+ contentss_num,
+ styles,
+ images,
+ name,
+ text,
+ &text2
+ ))
+ {
+ outf("extract_odt_content_item() failed");
+ goto end;
+ }
+
+ outf("after extract_odt_content_item styles->styles_num=%i", styles->styles_num);
+
+ {
+ const char* text3 = (text2) ? text2 : text;
+ if (extract_write_all(text3, strlen(text3), path)) goto end;
+ outf("have written to path=%s", path);
+ }
+ }
+ }
+
+ /* Copy images into <path_tempdir>/Pictures/. */
+ outf("");
+ extract_free(alloc, &path);
+ if (extract_asprintf(alloc, &path, "%s/Pictures", path_tempdir) < 0) goto end;
+ if (extract_mkdir(path, 0777))
+ {
+ outf("Failed to mkdir %s", path);
+ goto end;
+ }
+ outf("");
+ for (i=0; i<images->images_num; ++i)
+ {
+ image_t* image = &images->images[i];
+ extract_free(alloc, &path);
+ if (extract_asprintf(alloc, &path, "%s/Pictures/%s", path_tempdir, image->name) < 0) goto end;
+ if (extract_write_all(image->data, image->data_size, path)) goto end;
+ }
+
+ outf("Zipping tempdir to create %s", path_out);
+ {
+ const char* path_out_leaf = strrchr(path_out, '/');
+ if (!path_out_leaf) path_out_leaf = path_out;
+ if (extract_systemf(alloc, "cd '%s' && zip -q -r -D '../%s' .", path_tempdir, path_out_leaf))
+ {
+ outf("Zip command failed to convert '%s' directory into output file: %s",
+ path_tempdir, path_out);
+ goto end;
+ }
+ }
+
+ if (!preserve_dir)
+ {
+ if (extract_remove_directory(alloc, path_tempdir)) goto end;
+ }
+
+ e = 0;
+
+ end:
+ outf("e=%i", e);
+ extract_free(alloc, &path_tempdir);
+ extract_free(alloc, &path);
+ extract_free(alloc, &text);
+ extract_free(alloc, &text2);
+ //extract_odt_styles_free(alloc, &styles);
+ if (f) fclose(f);
+
+ if (e)
+ {
+ outf("Failed to create %s", path_out);
+ }
+ return e;
+}
diff --git a/extract/src/odt.h b/extract/src/odt.h
new file mode 100644
index 00000000..68fa0262
--- /dev/null
+++ b/extract/src/odt.h
@@ -0,0 +1,100 @@
+#ifndef ARTIFEX_EXTRACT_ODT_H
+#define ARTIFEX_EXTRACT_ODT_H
+
+/* Only for internal use by extract code. */
+
+/* Things for creating odt files. */
+
+typedef struct extract_odt_style_t extract_odt_style_t;
+
+typedef struct
+{
+ extract_odt_style_t* styles;
+ int styles_num;
+} extract_odt_styles_t;
+
+void extract_odt_styles_free(extract_alloc_t* alloc, extract_odt_styles_t* styles);
+
+int extract_document_to_odt_content(
+ extract_alloc_t* alloc,
+ document_t* document,
+ int spacing,
+ int rotation,
+ int images,
+ extract_astring_t* o_content,
+ extract_odt_styles_t* o_styles
+ );
+/* Makes *o_content point to a string containing all paragraphs in *document in
+odt XML format.
+
+Also writes style definitions to <o_styles>.
+
+<o_content> and <o_styles> can be passed to extract_odt_content_item() or
+extract_odt_write_template() to be inserted into an odt archive. */
+
+
+int extract_odt_write_template(
+ extract_alloc_t* alloc,
+ extract_astring_t* contentss,
+ int contentss_num,
+ extract_odt_styles_t* styles,
+ images_t* images,
+ const char* path_template,
+ const char* path_out,
+ int preserve_dir
+ );
+/* Creates a new odt file using a provided template document.
+
+Uses the 'zip' and 'unzip' commands internally.
+
+contents
+contentss_num
+ Content to be inserted into word/document.xml.
+document
+ .
+images
+ Information about images.
+path_template
+ Name of odt file to use as a template.
+path_out
+ Name of odt file to create. Must not contain single-quote, double quote,
+ space or ".." sequence - these will force EINVAL error because they could
+ make internal shell commands unsafe.
+preserve_dir
+ If true, we don't delete the temporary directory <path_out>.dir containing
+ unzipped odt content.
+*/
+
+
+int extract_odt_content_item(
+ extract_alloc_t* alloc,
+ extract_astring_t* contentss,
+ int contentss_num,
+ extract_odt_styles_t* styles,
+ images_t* images,
+ const char* name,
+ const char* text,
+ char** text2
+ );
+/* Determines content of <name> in odt archive.
+
+content
+content_length
+ Text to insert if <name> is word/document.xml.
+styles
+ Text containing style definitions.
+images
+ Information about images. If <name> is word/document.xml we insert
+ relationship information mapping from image ids to image names;
+ <text> should already contain reference ids for images. If <name> is
+ [Content_Types].xml we insert information about image types.
+name
+ Path within the odt zip archive.
+text
+ Content of <name> in template odt file.
+text2
+ Out-param. Set to NULL if <text> should be used unchanged. Otherwise set to
+ point to desired text, allocated with malloc() which caller should free.
+*/
+
+#endif
diff --git a/extract/src/odt_template.c b/extract/src/odt_template.c
new file mode 100644
index 00000000..5bc66b81
--- /dev/null
+++ b/extract/src/odt_template.c
@@ -0,0 +1,365 @@
+/* THIS IS AUTO-GENERATED CODE, DO NOT EDIT. */
+
+#include "odt_template.h"
+
+const odt_template_item_t odt_template_items[] =
+{
+ {
+ "content.xml",
+ ""
+ "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
+ ""
+ "<office:document-content xmlns:css3t=\"http://www.w3.org/TR/css3-text/\" xmlns:grddl=\"http://www.w3.org/2003/g/data-view#\" xmlns:xhtml=\"http://www.w3.org/1999/xhtml\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" xmlns:xsd=\"http://www.w3.org/2001/XMLSchema\" xmlns:xforms=\"http://www.w3.org/2002/xforms\" xmlns:dom=\"http://www.w3.org/2001/xml-events\" xmlns:script=\"urn:oasis:names:tc:opendocument:xmlns:script:1.0\" xmlns:form=\"urn:oasis:names:tc:opendocument:xmlns:form:1.0\" xmlns:math=\"http://www.w3.org/1998/Math/MathML\" xmlns:number=\"urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0\" xmlns:field=\"urn:openoffice:names:experimental:ooo-ms-interop:xmlns:field:1.0\" xmlns:meta=\"urn:oasis:names:tc:opendocument:xmlns:meta:1.0\" xmlns:loext=\"urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0\" xmlns:officeooo=\"http://openoffice.org/2009/office\" xmlns:table=\"urn:oasis:names:tc:opendocument:xmlns:table:1.0\" xmlns:chart=\"urn:oasis:names:tc:opendocument:xmlns:chart:1.0\" xmlns:tableooo=\"http://openoffice.org/2009/table\" xmlns:draw=\"urn:oasis:names:tc:opendocument:xmlns:drawing:1.0\" xmlns:rpt=\"http://openoffice.org/2005/report\" xmlns:dr3d=\"urn:oasis:names:tc:opendocument:xmlns:dr3d:1.0\" xmlns:of=\"urn:oasis:names:tc:opendocument:xmlns:of:1.2\" xmlns:text=\"urn:oasis:names:tc:opendocument:xmlns:text:1.0\" xmlns:style=\"urn:oasis:names:tc:opendocument:xmlns:style:1.0\" xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:calcext=\"urn:org:documentfoundation:names:experimental:calc:xmlns:calcext:1.0\" xmlns:oooc=\"http://openoffice.org/2004/calc\" xmlns:drawooo=\"http://openoffice.org/2010/draw\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" xmlns:ooo=\"http://openoffice.org/2004/office\" xmlns:ooow=\"http://openoffice.org/2004/writer\" xmlns:fo=\"urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0\" xmlns:formx=\"urn:openoffice:names:experimental:ooxml-odf-interop:xmlns:form:1.0\" xmlns:svg=\"urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0\" xmlns:office=\"urn:oasis:names:tc:opendocument:xmlns:office:1.0\" office:version=\"1.3\">"
+ "<office:scripts/>"
+ "<office:font-face-decls>"
+ "<style:font-face style:name=\"Liberation Serif\" svg:font-family=\"&apos;Liberation Serif&apos;\" style:font-family-generic=\"roman\" style:font-pitch=\"variable\"/>"
+ "<style:font-face style:name=\"Liberation Sans\" svg:font-family=\"&apos;Liberation Sans&apos;\" style:font-family-generic=\"swiss\" style:font-pitch=\"variable\"/>"
+ "<style:font-face style:name=\"Unifont\" svg:font-family=\"Unifont\" style:font-family-generic=\"system\" style:font-pitch=\"variable\"/></office:font-face-decls>"
+ "<office:automatic-styles/>"
+ "<office:body>"
+ "<office:text>"
+ "<text:sequence-decls>"
+ "<text:sequence-decl text:display-outline-level=\"0\" text:name=\"Illustration\"/>"
+ "<text:sequence-decl text:display-outline-level=\"0\" text:name=\"Table\"/>"
+ "<text:sequence-decl text:display-outline-level=\"0\" text:name=\"Text\"/>"
+ "<text:sequence-decl text:display-outline-level=\"0\" text:name=\"Drawing\"/>"
+ "<text:sequence-decl text:display-outline-level=\"0\" text:name=\"Figure\"/></text:sequence-decls>"
+ "<text:p text:style-name=\"Standard\"/></office:text></office:body></office:document-content>"
+ },
+
+ {
+ "manifest.rdf",
+ "\x3c\x3f\x78\x6d\x6c\x20\x76\x65\x72\x73\x69\x6f\x6e\x3d\x22"
+ "\x31\x2e\x30\x22\x20\x65\x6e\x63\x6f\x64\x69\x6e\x67\x3d\x22\x75"
+ "\x74\x66\x2d\x38\x22\x3f\x3e\x0a\x3c\x72\x64\x66\x3a\x52\x44\x46"
+ "\x20\x78\x6d\x6c\x6e\x73\x3a\x72\x64\x66\x3d\x22\x68\x74\x74\x70"
+ "\x3a\x2f\x2f\x77\x77\x77\x2e\x77\x33\x2e\x6f\x72\x67\x2f\x31\x39"
+ "\x39\x39\x2f\x30\x32\x2f\x32\x32\x2d\x72\x64\x66\x2d\x73\x79\x6e"
+ "\x74\x61\x78\x2d\x6e\x73\x23\x22\x3e\x0a\x20\x20\x3c\x72\x64\x66"
+ "\x3a\x44\x65\x73\x63\x72\x69\x70\x74\x69\x6f\x6e\x20\x72\x64\x66"
+ "\x3a\x61\x62\x6f\x75\x74\x3d\x22\x73\x74\x79\x6c\x65\x73\x2e\x78"
+ "\x6d\x6c\x22\x3e\x0a\x20\x20\x20\x20\x3c\x72\x64\x66\x3a\x74\x79"
+ "\x70\x65\x20\x72\x64\x66\x3a\x72\x65\x73\x6f\x75\x72\x63\x65\x3d"
+ "\x22\x68\x74\x74\x70\x3a\x2f\x2f\x64\x6f\x63\x73\x2e\x6f\x61\x73"
+ "\x69\x73\x2d\x6f\x70\x65\x6e\x2e\x6f\x72\x67\x2f\x6e\x73\x2f\x6f"
+ "\x66\x66\x69\x63\x65\x2f\x31\x2e\x32\x2f\x6d\x65\x74\x61\x2f\x6f"
+ "\x64\x66\x23\x53\x74\x79\x6c\x65\x73\x46\x69\x6c\x65\x22\x2f\x3e"
+ "\x0a\x20\x20\x3c\x2f\x72\x64\x66\x3a\x44\x65\x73\x63\x72\x69\x70"
+ "\x74\x69\x6f\x6e\x3e\x0a\x20\x20\x3c\x72\x64\x66\x3a\x44\x65\x73"
+ "\x63\x72\x69\x70\x74\x69\x6f\x6e\x20\x72\x64\x66\x3a\x61\x62\x6f"
+ "\x75\x74\x3d\x22\x22\x3e\x0a\x20\x20\x20\x20\x3c\x6e\x73\x30\x3a"
+ "\x68\x61\x73\x50\x61\x72\x74\x20\x78\x6d\x6c\x6e\x73\x3a\x6e\x73"
+ "\x30\x3d\x22\x68\x74\x74\x70\x3a\x2f\x2f\x64\x6f\x63\x73\x2e\x6f"
+ "\x61\x73\x69\x73\x2d\x6f\x70\x65\x6e\x2e\x6f\x72\x67\x2f\x6e\x73"
+ "\x2f\x6f\x66\x66\x69\x63\x65\x2f\x31\x2e\x32\x2f\x6d\x65\x74\x61"
+ "\x2f\x70\x6b\x67\x23\x22\x20\x72\x64\x66\x3a\x72\x65\x73\x6f\x75"
+ "\x72\x63\x65\x3d\x22\x73\x74\x79\x6c\x65\x73\x2e\x78\x6d\x6c\x22"
+ "\x2f\x3e\x0a\x20\x20\x3c\x2f\x72\x64\x66\x3a\x44\x65\x73\x63\x72"
+ "\x69\x70\x74\x69\x6f\x6e\x3e\x0a\x20\x20\x3c\x72\x64\x66\x3a\x44"
+ "\x65\x73\x63\x72\x69\x70\x74\x69\x6f\x6e\x20\x72\x64\x66\x3a\x61"
+ "\x62\x6f\x75\x74\x3d\x22\x63\x6f\x6e\x74\x65\x6e\x74\x2e\x78\x6d"
+ "\x6c\x22\x3e\x0a\x20\x20\x20\x20\x3c\x72\x64\x66\x3a\x74\x79\x70"
+ "\x65\x20\x72\x64\x66\x3a\x72\x65\x73\x6f\x75\x72\x63\x65\x3d\x22"
+ "\x68\x74\x74\x70\x3a\x2f\x2f\x64\x6f\x63\x73\x2e\x6f\x61\x73\x69"
+ "\x73\x2d\x6f\x70\x65\x6e\x2e\x6f\x72\x67\x2f\x6e\x73\x2f\x6f\x66"
+ "\x66\x69\x63\x65\x2f\x31\x2e\x32\x2f\x6d\x65\x74\x61\x2f\x6f\x64"
+ "\x66\x23\x43\x6f\x6e\x74\x65\x6e\x74\x46\x69\x6c\x65\x22\x2f\x3e"
+ "\x0a\x20\x20\x3c\x2f\x72\x64\x66\x3a\x44\x65\x73\x63\x72\x69\x70"
+ "\x74\x69\x6f\x6e\x3e\x0a\x20\x20\x3c\x72\x64\x66\x3a\x44\x65\x73"
+ "\x63\x72\x69\x70\x74\x69\x6f\x6e\x20\x72\x64\x66\x3a\x61\x62\x6f"
+ "\x75\x74\x3d\x22\x22\x3e\x0a\x20\x20\x20\x20\x3c\x6e\x73\x30\x3a"
+ "\x68\x61\x73\x50\x61\x72\x74\x20\x78\x6d\x6c\x6e\x73\x3a\x6e\x73"
+ "\x30\x3d\x22\x68\x74\x74\x70\x3a\x2f\x2f\x64\x6f\x63\x73\x2e\x6f"
+ "\x61\x73\x69\x73\x2d\x6f\x70\x65\x6e\x2e\x6f\x72\x67\x2f\x6e\x73"
+ "\x2f\x6f\x66\x66\x69\x63\x65\x2f\x31\x2e\x32\x2f\x6d\x65\x74\x61"
+ "\x2f\x70\x6b\x67\x23\x22\x20\x72\x64\x66\x3a\x72\x65\x73\x6f\x75"
+ "\x72\x63\x65\x3d\x22\x63\x6f\x6e\x74\x65\x6e\x74\x2e\x78\x6d\x6c"
+ "\x22\x2f\x3e\x0a\x20\x20\x3c\x2f\x72\x64\x66\x3a\x44\x65\x73\x63"
+ "\x72\x69\x70\x74\x69\x6f\x6e\x3e\x0a\x20\x20\x3c\x72\x64\x66\x3a"
+ "\x44\x65\x73\x63\x72\x69\x70\x74\x69\x6f\x6e\x20\x72\x64\x66\x3a"
+ "\x61\x62\x6f\x75\x74\x3d\x22\x22\x3e\x0a\x20\x20\x20\x20\x3c\x72"
+ "\x64\x66\x3a\x74\x79\x70\x65\x20\x72\x64\x66\x3a\x72\x65\x73\x6f"
+ "\x75\x72\x63\x65\x3d\x22\x68\x74\x74\x70\x3a\x2f\x2f\x64\x6f\x63"
+ "\x73\x2e\x6f\x61\x73\x69\x73\x2d\x6f\x70\x65\x6e\x2e\x6f\x72\x67"
+ "\x2f\x6e\x73\x2f\x6f\x66\x66\x69\x63\x65\x2f\x31\x2e\x32\x2f\x6d"
+ "\x65\x74\x61\x2f\x70\x6b\x67\x23\x44\x6f\x63\x75\x6d\x65\x6e\x74"
+ "\x22\x2f\x3e\x0a\x20\x20\x3c\x2f\x72\x64\x66\x3a\x44\x65\x73\x63"
+ "\x72\x69\x70\x74\x69\x6f\x6e\x3e\x0a\x3c\x2f\x72\x64\x66\x3a\x52"
+ "\x44\x46\x3e\x0a"
+ },
+
+ {
+ "meta.xml",
+ ""
+ "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
+ ""
+ "<office:document-meta xmlns:grddl=\"http://www.w3.org/2003/g/data-view#\" xmlns:meta=\"urn:oasis:names:tc:opendocument:xmlns:meta:1.0\" xmlns:ooo=\"http://openoffice.org/2004/office\" xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" xmlns:office=\"urn:oasis:names:tc:opendocument:xmlns:office:1.0\" office:version=\"1.3\">"
+ "<office:meta>"
+ "<meta:creation-date>2021-04-05T17:06:57.937137058</meta:creation-date>"
+ "<meta:generator>LibreOffice/7.0.1.2$OpenBSD_X86_64 LibreOffice_project/00$Build-2</meta:generator>"
+ "<dc:date>2021-04-06T17:14:51.409959656</dc:date>"
+ "<meta:editing-duration>PT20S</meta:editing-duration>"
+ "<meta:editing-cycles>1</meta:editing-cycles>"
+ "<meta:document-statistic meta:table-count=\"0\" meta:image-count=\"0\" meta:object-count=\"0\" meta:page-count=\"1\" meta:paragraph-count=\"0\" meta:word-count=\"0\" meta:character-count=\"0\" meta:non-whitespace-character-count=\"0\"/></office:meta></office:document-meta>"
+ },
+
+ {
+ "mimetype",
+ "\x61\x70\x70\x6c\x69\x63\x61\x74\x69\x6f\x6e\x2f\x76\x6e\x64"
+ "\x2e\x6f\x61\x73\x69\x73\x2e\x6f\x70\x65\x6e\x64\x6f\x63\x75\x6d"
+ "\x65\x6e\x74\x2e\x74\x65\x78\x74"
+ },
+
+ {
+ "settings.xml",
+ ""
+ "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
+ ""
+ "<office:document-settings xmlns:config=\"urn:oasis:names:tc:opendocument:xmlns:config:1.0\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" xmlns:ooo=\"http://openoffice.org/2004/office\" xmlns:office=\"urn:oasis:names:tc:opendocument:xmlns:office:1.0\" office:version=\"1.3\">"
+ "<office:settings>"
+ "<config:config-item-set config:name=\"ooo:view-settings\">"
+ "<config:config-item config:name=\"ViewAreaTop\" config:type=\"long\">0</config:config-item>"
+ "<config:config-item config:name=\"ViewAreaLeft\" config:type=\"long\">0</config:config-item>"
+ "<config:config-item config:name=\"ViewAreaWidth\" config:type=\"long\">26275</config:config-item>"
+ "<config:config-item config:name=\"ViewAreaHeight\" config:type=\"long\">19502</config:config-item>"
+ "<config:config-item config:name=\"ShowRedlineChanges\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"InBrowseMode\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item-map-indexed config:name=\"Views\">"
+ "<config:config-item-map-entry>"
+ "<config:config-item config:name=\"ViewId\" config:type=\"string\">view2</config:config-item>"
+ "<config:config-item config:name=\"ViewLeft\" config:type=\"long\">4343</config:config-item>"
+ "<config:config-item config:name=\"ViewTop\" config:type=\"long\">2501</config:config-item>"
+ "<config:config-item config:name=\"VisibleLeft\" config:type=\"long\">0</config:config-item>"
+ "<config:config-item config:name=\"VisibleTop\" config:type=\"long\">0</config:config-item>"
+ "<config:config-item config:name=\"VisibleRight\" config:type=\"long\">26273</config:config-item>"
+ "<config:config-item config:name=\"VisibleBottom\" config:type=\"long\">19500</config:config-item>"
+ "<config:config-item config:name=\"ZoomType\" config:type=\"short\">0</config:config-item>"
+ "<config:config-item config:name=\"ViewLayoutColumns\" config:type=\"short\">1</config:config-item>"
+ "<config:config-item config:name=\"ViewLayoutBookMode\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"ZoomFactor\" config:type=\"short\">100</config:config-item>"
+ "<config:config-item config:name=\"IsSelectedFrame\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"AnchoredTextOverflowLegacy\" config:type=\"boolean\">false</config:config-item></config:config-item-map-entry></config:config-item-map-indexed></config:config-item-set>"
+ "<config:config-item-set config:name=\"ooo:configuration-settings\">"
+ "<config:config-item config:name=\"PrintBlackFonts\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"PrintReversed\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"SaveThumbnail\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"EmbedFonts\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"PrintControls\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"OutlineLevelYieldsNumbering\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"PrintPageBackground\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"PrintAnnotationMode\" config:type=\"short\">0</config:config-item>"
+ "<config:config-item config:name=\"PrintGraphics\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"EmbeddedDatabaseName\" config:type=\"string\"/>"
+ "<config:config-item config:name=\"ProtectForm\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"PrintLeftPages\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"PrintProspect\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"PrintHiddenText\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"PrintRightPages\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"PrintFaxName\" config:type=\"string\"/>"
+ "<config:config-item config:name=\"PrintPaperFromSetup\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"TabsRelativeToIndent\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"RedlineProtectionKey\" config:type=\"base64Binary\"/>"
+ "<config:config-item config:name=\"PrintTextPlaceholder\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"MathBaselineAlignment\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"ProtectBookmarks\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"IgnoreTabsAndBlanksForLineCalculation\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"ContinuousEndnotes\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"FieldAutoUpdate\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"EmptyDbFieldHidesPara\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"ApplyParagraphMarkFormatToNumbering\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"PrintEmptyPages\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"TabOverMargin\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"EmbedAsianScriptFonts\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"EmbedLatinScriptFonts\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"DisableOffPagePositioning\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"EmbedOnlyUsedFonts\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"MsWordCompMinLineHeightByFly\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"SurroundTextWrapSmall\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"BackgroundParaOverDrawings\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"ClippedPictures\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"FloattableNomargins\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"UnbreakableNumberings\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"EmbedSystemFonts\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"TabOverflow\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"PrintTables\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"PrintDrawings\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"ConsiderTextWrapOnObjPos\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"PrintSingleJobs\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"SmallCapsPercentage66\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"CollapseEmptyCellPara\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"HeaderSpacingBelowLastPara\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"RsidRoot\" config:type=\"int\">2052946</config:config-item>"
+ "<config:config-item config:name=\"PrinterSetup\" config:type=\"base64Binary\"/>"
+ "<config:config-item config:name=\"CurrentDatabaseCommand\" config:type=\"string\"/>"
+ "<config:config-item config:name=\"AlignTabStopPosition\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"ClipAsCharacterAnchoredWriterFlyFrames\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"DoNotCaptureDrawObjsOnPage\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"SaveGlobalDocumentLinks\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"CurrentDatabaseCommandType\" config:type=\"int\">0</config:config-item>"
+ "<config:config-item config:name=\"LoadReadonly\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"DoNotResetParaAttrsForNumFont\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"StylesNoDefault\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"LinkUpdateMode\" config:type=\"short\">1</config:config-item>"
+ "<config:config-item config:name=\"DoNotJustifyLinesWithManualBreak\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"PropLineSpacingShrinksFirstLine\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"TabAtLeftIndentForParagraphsInList\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"ProtectFields\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"UnxForceZeroExtLeading\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"CurrentDatabaseDataSource\" config:type=\"string\"/>"
+ "<config:config-item config:name=\"UseFormerTextWrapping\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"UseFormerLineSpacing\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"AllowPrintJobCancel\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"SubtractFlysAnchoredAtFlys\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"AddParaSpacingToTableCells\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"AddExternalLeading\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"Rsid\" config:type=\"int\">2178852</config:config-item>"
+ "<config:config-item config:name=\"AddVerticalFrameOffsets\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"TreatSingleColumnBreakAsPageBreak\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"AddFrameOffsets\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"IsLabelDocument\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"MsWordCompTrailingBlanks\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"PrinterPaperFromSetup\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"IgnoreFirstLineIndentInNumbering\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"PrinterName\" config:type=\"string\"/>"
+ "<config:config-item config:name=\"IsKernAsianPunctuation\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"PrinterIndependentLayout\" config:type=\"string\">high-resolution</config:config-item>"
+ "<config:config-item config:name=\"TableRowKeep\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"UpdateFromTemplate\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"EmbedComplexScriptFonts\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"UseOldPrinterMetrics\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"InvertBorderSpacing\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"PrintProspectRTL\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"ApplyUserData\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"AddParaTableSpacingAtStart\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"SaveVersionOnClose\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"CharacterCompressionType\" config:type=\"short\">0</config:config-item>"
+ "<config:config-item config:name=\"UseOldNumbering\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"UseFormerObjectPositioning\" config:type=\"boolean\">false</config:config-item>"
+ "<config:config-item config:name=\"ChartAutoUpdate\" config:type=\"boolean\">true</config:config-item>"
+ "<config:config-item config:name=\"AddParaTableSpacing\" config:type=\"boolean\">true</config:config-item></config:config-item-set></office:settings></office:document-settings>"
+ },
+
+ {
+ "styles.xml",
+ ""
+ "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
+ ""
+ "<office:document-styles xmlns:css3t=\"http://www.w3.org/TR/css3-text/\" xmlns:grddl=\"http://www.w3.org/2003/g/data-view#\" xmlns:xhtml=\"http://www.w3.org/1999/xhtml\" xmlns:dom=\"http://www.w3.org/2001/xml-events\" xmlns:script=\"urn:oasis:names:tc:opendocument:xmlns:script:1.0\" xmlns:form=\"urn:oasis:names:tc:opendocument:xmlns:form:1.0\" xmlns:math=\"http://www.w3.org/1998/Math/MathML\" xmlns:number=\"urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0\" xmlns:field=\"urn:openoffice:names:experimental:ooo-ms-interop:xmlns:field:1.0\" xmlns:meta=\"urn:oasis:names:tc:opendocument:xmlns:meta:1.0\" xmlns:loext=\"urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0\" xmlns:officeooo=\"http://openoffice.org/2009/office\" xmlns:table=\"urn:oasis:names:tc:opendocument:xmlns:table:1.0\" xmlns:chart=\"urn:oasis:names:tc:opendocument:xmlns:chart:1.0\" xmlns:tableooo=\"http://openoffice.org/2009/table\" xmlns:draw=\"urn:oasis:names:tc:opendocument:xmlns:drawing:1.0\" xmlns:rpt=\"http://openoffice.org/2005/report\" xmlns:dr3d=\"urn:oasis:names:tc:opendocument:xmlns:dr3d:1.0\" xmlns:of=\"urn:oasis:names:tc:opendocument:xmlns:of:1.2\" xmlns:text=\"urn:oasis:names:tc:opendocument:xmlns:text:1.0\" xmlns:style=\"urn:oasis:names:tc:opendocument:xmlns:style:1.0\" xmlns:dc=\"http://purl.org/dc/elements/1.1/\" xmlns:calcext=\"urn:org:documentfoundation:names:experimental:calc:xmlns:calcext:1.0\" xmlns:oooc=\"http://openoffice.org/2004/calc\" xmlns:drawooo=\"http://openoffice.org/2010/draw\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" xmlns:ooo=\"http://openoffice.org/2004/office\" xmlns:ooow=\"http://openoffice.org/2004/writer\" xmlns:fo=\"urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0\" xmlns:svg=\"urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0\" xmlns:office=\"urn:oasis:names:tc:opendocument:xmlns:office:1.0\" office:version=\"1.3\">"
+ "<office:font-face-decls>"
+ "<style:font-face style:name=\"Liberation Serif\" svg:font-family=\"&apos;Liberation Serif&apos;\" style:font-family-generic=\"roman\" style:font-pitch=\"variable\"/>"
+ "<style:font-face style:name=\"Liberation Sans\" svg:font-family=\"&apos;Liberation Sans&apos;\" style:font-family-generic=\"swiss\" style:font-pitch=\"variable\"/>"
+ "<style:font-face style:name=\"Unifont\" svg:font-family=\"Unifont\" style:font-family-generic=\"system\" style:font-pitch=\"variable\"/></office:font-face-decls>"
+ "<office:styles>"
+ "<style:default-style style:family=\"graphic\">"
+ "<style:graphic-properties svg:stroke-color=\"#3465a4\" draw:fill-color=\"#729fcf\" fo:wrap-option=\"no-wrap\" draw:shadow-offset-x=\"0.1181in\" draw:shadow-offset-y=\"0.1181in\" draw:start-line-spacing-horizontal=\"0.1114in\" draw:start-line-spacing-vertical=\"0.1114in\" draw:end-line-spacing-horizontal=\"0.1114in\" draw:end-line-spacing-vertical=\"0.1114in\" style:flow-with-text=\"false\"/>"
+ "<style:paragraph-properties style:text-autospace=\"ideograph-alpha\" style:line-break=\"strict\" style:font-independent-line-spacing=\"false\">"
+ "<style:tab-stops/></style:paragraph-properties>"
+ "<style:text-properties style:use-window-font-color=\"true\" loext:opacity=\"0%\" style:font-name=\"Liberation Serif\" fo:font-size=\"12pt\" fo:language=\"en\" fo:country=\"US\" style:letter-kerning=\"true\" style:font-name-asian=\"Unifont\" style:font-size-asian=\"10.5pt\" style:language-asian=\"zh\" style:country-asian=\"CN\" style:font-name-complex=\"Unifont\" style:font-size-complex=\"12pt\" style:language-complex=\"hi\" style:country-complex=\"IN\"/></style:default-style>"
+ "<style:default-style style:family=\"paragraph\">"
+ "<style:paragraph-properties fo:orphans=\"2\" fo:widows=\"2\" fo:hyphenation-ladder-count=\"no-limit\" style:text-autospace=\"ideograph-alpha\" style:punctuation-wrap=\"hanging\" style:line-break=\"strict\" style:tab-stop-distance=\"0.4925in\" style:writing-mode=\"page\"/>"
+ "<style:text-properties style:use-window-font-color=\"true\" loext:opacity=\"0%\" style:font-name=\"Liberation Serif\" fo:font-size=\"12pt\" fo:language=\"en\" fo:country=\"US\" style:letter-kerning=\"true\" style:font-name-asian=\"Unifont\" style:font-size-asian=\"10.5pt\" style:language-asian=\"zh\" style:country-asian=\"CN\" style:font-name-complex=\"Unifont\" style:font-size-complex=\"12pt\" style:language-complex=\"hi\" style:country-complex=\"IN\" fo:hyphenate=\"false\" fo:hyphenation-remain-char-count=\"2\" fo:hyphenation-push-char-count=\"2\" loext:hyphenation-no-caps=\"false\"/></style:default-style>"
+ "<style:default-style style:family=\"table\">"
+ "<style:table-properties table:border-model=\"collapsing\"/></style:default-style>"
+ "<style:default-style style:family=\"table-row\">"
+ "<style:table-row-properties fo:keep-together=\"auto\"/></style:default-style>"
+ "<style:style style:name=\"Standard\" style:family=\"paragraph\" style:class=\"text\">"
+ "<style:paragraph-properties fo:margin-top=\"0in\" fo:margin-bottom=\"0.0799in\" style:contextual-spacing=\"false\"/></style:style>"
+ "<style:style style:name=\"Heading\" style:family=\"paragraph\" style:parent-style-name=\"Standard\" style:next-style-name=\"Text_20_body\" style:class=\"text\">"
+ "<style:paragraph-properties fo:margin-top=\"0.1665in\" fo:margin-bottom=\"0.0835in\" style:contextual-spacing=\"false\" fo:keep-with-next=\"always\"/>"
+ "<style:text-properties style:font-name=\"Liberation Sans\" fo:font-family=\"&apos;Liberation Sans&apos;\" style:font-family-generic=\"swiss\" style:font-pitch=\"variable\" fo:font-size=\"14pt\" style:font-name-asian=\"Unifont\" style:font-family-asian=\"Unifont\" style:font-family-generic-asian=\"system\" style:font-pitch-asian=\"variable\" style:font-size-asian=\"14pt\" style:font-name-complex=\"Unifont\" style:font-family-complex=\"Unifont\" style:font-family-generic-complex=\"system\" style:font-pitch-complex=\"variable\" style:font-size-complex=\"14pt\"/></style:style>"
+ "<style:style style:name=\"Text_20_body\" style:display-name=\"Text body\" style:family=\"paragraph\" style:parent-style-name=\"Standard\" style:class=\"text\">"
+ "<style:paragraph-properties fo:margin-top=\"0in\" fo:margin-bottom=\"0.0972in\" style:contextual-spacing=\"false\" fo:line-height=\"115%\"/></style:style>"
+ "<style:style style:name=\"List\" style:family=\"paragraph\" style:parent-style-name=\"Text_20_body\" style:class=\"list\">"
+ "<style:text-properties style:font-size-asian=\"12pt\"/></style:style>"
+ "<style:style style:name=\"Caption\" style:family=\"paragraph\" style:parent-style-name=\"Standard\" style:class=\"extra\">"
+ "<style:paragraph-properties fo:margin-top=\"0.0835in\" fo:margin-bottom=\"0.0835in\" style:contextual-spacing=\"false\" text:number-lines=\"false\" text:line-number=\"0\"/>"
+ "<style:text-properties fo:font-size=\"12pt\" fo:font-style=\"italic\" style:font-size-asian=\"12pt\" style:font-style-asian=\"italic\" style:font-size-complex=\"12pt\" style:font-style-complex=\"italic\"/></style:style>"
+ "<style:style style:name=\"Index\" style:family=\"paragraph\" style:parent-style-name=\"Standard\" style:class=\"index\">"
+ "<style:paragraph-properties text:number-lines=\"false\" text:line-number=\"0\"/>"
+ "<style:text-properties style:font-size-asian=\"12pt\"/></style:style>"
+ "<text:outline-style style:name=\"Outline\">"
+ "<text:outline-level-style text:level=\"1\" style:num-format=\"\">"
+ "<style:list-level-properties text:list-level-position-and-space-mode=\"label-alignment\">"
+ "<style:list-level-label-alignment text:label-followed-by=\"listtab\"/></style:list-level-properties></text:outline-level-style>"
+ "<text:outline-level-style text:level=\"2\" style:num-format=\"\">"
+ "<style:list-level-properties text:list-level-position-and-space-mode=\"label-alignment\">"
+ "<style:list-level-label-alignment text:label-followed-by=\"listtab\"/></style:list-level-properties></text:outline-level-style>"
+ "<text:outline-level-style text:level=\"3\" style:num-format=\"\">"
+ "<style:list-level-properties text:list-level-position-and-space-mode=\"label-alignment\">"
+ "<style:list-level-label-alignment text:label-followed-by=\"listtab\"/></style:list-level-properties></text:outline-level-style>"
+ "<text:outline-level-style text:level=\"4\" style:num-format=\"\">"
+ "<style:list-level-properties text:list-level-position-and-space-mode=\"label-alignment\">"
+ "<style:list-level-label-alignment text:label-followed-by=\"listtab\"/></style:list-level-properties></text:outline-level-style>"
+ "<text:outline-level-style text:level=\"5\" style:num-format=\"\">"
+ "<style:list-level-properties text:list-level-position-and-space-mode=\"label-alignment\">"
+ "<style:list-level-label-alignment text:label-followed-by=\"listtab\"/></style:list-level-properties></text:outline-level-style>"
+ "<text:outline-level-style text:level=\"6\" style:num-format=\"\">"
+ "<style:list-level-properties text:list-level-position-and-space-mode=\"label-alignment\">"
+ "<style:list-level-label-alignment text:label-followed-by=\"listtab\"/></style:list-level-properties></text:outline-level-style>"
+ "<text:outline-level-style text:level=\"7\" style:num-format=\"\">"
+ "<style:list-level-properties text:list-level-position-and-space-mode=\"label-alignment\">"
+ "<style:list-level-label-alignment text:label-followed-by=\"listtab\"/></style:list-level-properties></text:outline-level-style>"
+ "<text:outline-level-style text:level=\"8\" style:num-format=\"\">"
+ "<style:list-level-properties text:list-level-position-and-space-mode=\"label-alignment\">"
+ "<style:list-level-label-alignment text:label-followed-by=\"listtab\"/></style:list-level-properties></text:outline-level-style>"
+ "<text:outline-level-style text:level=\"9\" style:num-format=\"\">"
+ "<style:list-level-properties text:list-level-position-and-space-mode=\"label-alignment\">"
+ "<style:list-level-label-alignment text:label-followed-by=\"listtab\"/></style:list-level-properties></text:outline-level-style>"
+ "<text:outline-level-style text:level=\"10\" style:num-format=\"\">"
+ "<style:list-level-properties text:list-level-position-and-space-mode=\"label-alignment\">"
+ "<style:list-level-label-alignment text:label-followed-by=\"listtab\"/></style:list-level-properties></text:outline-level-style></text:outline-style>"
+ "<text:notes-configuration text:note-class=\"footnote\" style:num-format=\"1\" text:start-value=\"0\" text:footnotes-position=\"page\" text:start-numbering-at=\"document\"/>"
+ "<text:notes-configuration text:note-class=\"endnote\" style:num-format=\"i\" text:start-value=\"0\"/>"
+ "<text:linenumbering-configuration text:number-lines=\"false\" text:offset=\"0.1965in\" style:num-format=\"1\" text:number-position=\"left\" text:increment=\"5\"/></office:styles>"
+ "<office:automatic-styles>"
+ "<style:page-layout style:name=\"Mpm1\">"
+ "<style:page-layout-properties fo:page-width=\"8.5in\" fo:page-height=\"11in\" style:num-format=\"1\" style:print-orientation=\"portrait\" fo:margin-top=\"0.7874in\" fo:margin-bottom=\"0.7874in\" fo:margin-left=\"0.7874in\" fo:margin-right=\"0.7874in\" style:writing-mode=\"lr-tb\" style:layout-grid-color=\"#c0c0c0\" style:layout-grid-lines=\"20\" style:layout-grid-base-height=\"0.278in\" style:layout-grid-ruby-height=\"0.139in\" style:layout-grid-mode=\"none\" style:layout-grid-ruby-below=\"false\" style:layout-grid-print=\"false\" style:layout-grid-display=\"false\" style:footnote-max-height=\"0in\">"
+ "<style:footnote-sep style:width=\"0.0071in\" style:distance-before-sep=\"0.0398in\" style:distance-after-sep=\"0.0398in\" style:line-style=\"solid\" style:adjustment=\"left\" style:rel-width=\"25%\" style:color=\"#000000\"/></style:page-layout-properties>"
+ "<style:header-style/>"
+ "<style:footer-style/></style:page-layout></office:automatic-styles>"
+ "<office:master-styles>"
+ "<style:master-page style:name=\"Standard\" style:page-layout-name=\"Mpm1\"/></office:master-styles></office:document-styles>"
+ },
+
+ {
+ "META-INF/manifest.xml",
+ ""
+ "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
+ ""
+ "<manifest:manifest xmlns:manifest=\"urn:oasis:names:tc:opendocument:xmlns:manifest:1.0\" manifest:version=\"1.3\" xmlns:loext=\"urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0\">\n"
+ " "
+ "<manifest:file-entry manifest:full-path=\"/\" manifest:version=\"1.3\" manifest:media-type=\"application/vnd.oasis.opendocument.text\"/>\n"
+ " "
+ "<manifest:file-entry manifest:full-path=\"meta.xml\" manifest:media-type=\"text/xml\"/>\n"
+ " "
+ "<manifest:file-entry manifest:full-path=\"settings.xml\" manifest:media-type=\"text/xml\"/>\n"
+ " "
+ "<manifest:file-entry manifest:full-path=\"Configurations2/\" manifest:media-type=\"application/vnd.sun.xml.ui.configuration\"/>\n"
+ " "
+ "<manifest:file-entry manifest:full-path=\"manifest.rdf\" manifest:media-type=\"application/rdf+xml\"/>\n"
+ " "
+ "<manifest:file-entry manifest:full-path=\"styles.xml\" manifest:media-type=\"text/xml\"/>\n"
+ " "
+ "<manifest:file-entry manifest:full-path=\"content.xml\" manifest:media-type=\"text/xml\"/>\n"
+ " "
+ "<manifest:file-entry manifest:full-path=\"Thumbnails/thumbnail.png\" manifest:media-type=\"image/png\"/>\n"
+ "</manifest:manifest>"
+ },
+
+ {
+ "Thumbnails/thumbnail.png",
+ "\x89\x50\x4e\x47\x0d\x0a\x1a\x0a\x00\x00\x00\x0d\x49\x48\x44"
+ "\x52\x00\x00\x00\xc6\x00\x00\x01\x00\x08\x03\x00\x00\x00\xdf\x83"
+ "\xf9\x72\x00\x00\x00\x09\x50\x4c\x54\x45\xff\xff\xff\x00\x00\x00"
+ "\xff\xff\xff\x7e\xef\x8f\x4f\x00\x00\x00\x48\x49\x44\x41\x54\x78"
+ "\xda\xed\xc1\x31\x01\x00\x00\x00\xc2\xa0\xf5\x4f\x6d\x0c\x1f\xa0"
+ "\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"
+ "\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"
+ "\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00"
+ "\x00\x78\x18\xc7\x00\x00\x01\xf9\xd2\xb5\x9a\x00\x00\x00\x00\x49"
+ "\x45\x4e\x44\xae\x42\x60\x82"
+ },
+
+};
+
+int odt_template_items_num = 8;
diff --git a/extract/src/odt_template.h b/extract/src/odt_template.h
new file mode 100644
index 00000000..93ad972b
--- /dev/null
+++ b/extract/src/odt_template.h
@@ -0,0 +1,17 @@
+#ifndef EXTRACT_ODT_TEMPLATE_H
+#define EXTRACT_ODT_TEMPLATE_H
+
+/* THIS IS AUTO-GENERATED CODE, DO NOT EDIT. */
+
+
+typedef struct
+{
+ const char* name; /* Name of item in odt archive. */
+ const char* text; /* Contents of item in odt archive. */
+} odt_template_item_t;
+
+extern const odt_template_item_t odt_template_items[];
+extern int odt_template_items_num;
+
+
+#endif
diff --git a/extract/src/sys.c b/extract/src/sys.c
new file mode 100644
index 00000000..131f6312
--- /dev/null
+++ b/extract/src/sys.c
@@ -0,0 +1,137 @@
+#include "mem.h"
+#include "outf.h"
+#include "sys.h"
+
+#include <errno.h>
+#include <stdarg.h>
+
+#include <sys/stat.h>
+
+
+/* Define extract_APPLE_IOS if we are on iOS. */
+#undef extract_APPLE_IOS
+#ifdef __APPLE__
+ #include "TargetConditionals.h"
+ #ifdef TARGET_OS_IPHONE
+ #define extract_APPLE_IOS
+ #elif TARGET_IPHONE_SIMULATOR
+ #define extract_APPLE_IOS
+ #endif
+#endif
+
+int extract_systemf(extract_alloc_t* alloc, const char* format, ...)
+{
+ #ifdef extract_APPLE_IOS
+ /* system() not available on iOS. */
+ (void) alloc;
+ (void) format;
+ errno = ENOTSUP;
+ return -1;
+ #else
+
+ int e;
+ char* command;
+ va_list va;
+ va_start(va, format);
+ e = extract_vasprintf(alloc, &command, format, va);
+ va_end(va);
+ if (e < 0) return e;
+ outf("running: %s", command);
+ e = system(command);
+ extract_free(alloc, &command);
+ if (e > 0) {
+ errno = EIO;
+ }
+ return e;
+
+ #endif
+}
+
+int extract_read_all(extract_alloc_t* alloc, FILE* in, char** o_out)
+{
+ size_t len = 0;
+ size_t delta = 128;
+ for(;;) {
+ size_t n;
+ if (extract_realloc2(alloc, o_out, len, len + delta + 1)) {
+ extract_free(alloc, o_out);
+ return -1;
+ }
+ n = fread(*o_out + len, 1 /*size*/, delta /*nmemb*/, in);
+ len += n;
+ if (feof(in)) {
+ (*o_out)[len] = 0;
+ return 0;
+ }
+ if (ferror(in)) {
+ /* It's weird that fread() and ferror() don't set errno. */
+ errno = EIO;
+ extract_free(alloc, o_out);
+ return -1;
+ }
+ }
+}
+
+int extract_read_all_path(extract_alloc_t* alloc, const char* path, char** o_text)
+{
+ int e = -1;
+ FILE* f = NULL;
+ f = fopen(path, "rb");
+ if (!f) goto end;
+ if (extract_read_all(alloc, f, o_text)) goto end;
+ e = 0;
+ end:
+ if (f) fclose(f);
+ if (e) extract_free(alloc, &o_text);
+ return e;
+}
+
+int extract_write_all(const void* data, size_t data_size, const char* path)
+{
+ int e = -1;
+ FILE* f = fopen(path, "w");
+ if (!f) goto end;
+ if (fwrite(data, data_size, 1 /*nmemb*/, f) != 1) goto end;
+ e = 0;
+ end:
+ if (f) fclose(f);
+ return e;
+}
+
+int extract_check_path_shell_safe(const char* path)
+/* Returns -1 with errno=EINVAL if <path> contains sequences that could make it
+unsafe in shell commands. */
+{
+ if (0
+ || strstr(path, "..")
+ || strchr(path, '\'')
+ || strchr(path, '"')
+ || strchr(path, ' ')
+ ) {
+ errno = EINVAL;
+ return -1;
+ }
+ return 0;
+}
+int extract_remove_directory(extract_alloc_t* alloc, const char* path)
+{
+ if (extract_check_path_shell_safe(path)) {
+ outf("path_out is unsafe: %s", path);
+ return -1;
+ }
+ return extract_systemf(alloc, "rm -r '%s'", path);
+}
+
+#ifdef _WIN32
+#include <direct.h>
+int extract_mkdir(const char* path, int mode)
+{
+ (void) mode;
+ return _mkdir(path);
+}
+#else
+int extract_mkdir(const char* path, int mode)
+{
+ return mkdir(path, mode);
+}
+#endif
diff --git a/extract/src/sys.h b/extract/src/sys.h
new file mode 100644
index 00000000..f2b3a01f
--- /dev/null
+++ b/extract/src/sys.h
@@ -0,0 +1,35 @@
+#ifndef EXTRACT_SYS_H
+#define EXTRACT_SYS_H
+
+#include "../include/extract_alloc.h"
+
+#include <stdio.h>
+
+
+int extract_systemf(extract_alloc_t* alloc, const char* format, ...);
+/* Like system() but takes printf-style format and args. Also, if we return +ve
+we set errno to EIO.
+
+On iOS we always -1:ENOTSUP because the system() function is not available. */
+
+int extract_read_all(extract_alloc_t* alloc, FILE* in, char** o_out);
+/* Reads until eof into zero-terminated malloc'd buffer. */
+
+int extract_read_all_path(extract_alloc_t* alloc, const char* path, char** o_text);
+/* Reads entire file into zero-terminated malloc'd buffer. */
+
+int extract_write_all(const void* data, size_t data_size, const char* path);
+
+int extract_check_path_shell_safe(const char* path);
+/* Returns -1 with errno=EINVAL if <path> contains sequences that could make it
+unsafe in shell commands. */
+
+int extract_remove_directory(extract_alloc_t* alloc, const char* path);
+/* Internally calls extract_systemf(); returns error if
+extract_check_path_shell_safe(path) returns an error, but this is probably not
+to be relied on. */
+
+int extract_mkdir(const char* path, int mode);
+/* Compatibility wrapper to cope on Windows. */
+
+#endif
diff --git a/extract/src/template.odt b/extract/src/template.odt
new file mode 100644
index 00000000..92440555
--- /dev/null
+++ b/extract/src/template.odt
Binary files differ
diff --git a/extract/src/text.c b/extract/src/text.c
new file mode 100644
index 00000000..f832baa2
--- /dev/null
+++ b/extract/src/text.c
@@ -0,0 +1,108 @@
+#include "text.h"
+
+#include "astring.h"
+#include "outf.h"
+
+#include <assert.h>
+#include <errno.h>
+#include <string.h>
+
+
+int extract_content_insert(
+ extract_alloc_t* alloc,
+ const char* original,
+ const char* single_name,
+ const char* mid_begin_name,
+ const char* mid_end_name,
+ extract_astring_t* contentss,
+ int contentss_num,
+ char** o_out
+ )
+/* Creates a new string by inserting sequence of strings into a template
+string.
+
+If <single_name> is in <original>, it is replaced by <contentss>.
+
+Otherwise the text between the end of <mid_begin_name> and beginning of
+<mid_end_name> is replaced by <contentss>.
+
+If <mid_begin_name> is NULL, we insert into the zero-length region before
+<mid_end_name>.
+
+If <mid_end_name> is NULL, we insert into the zero-length region after
+<mid_begin_name>.
+
+At least one of <single_name>, <mid_begin_name> and <mid_end_name> must be
+non-NULL.
+*/
+{
+ int e = -1;
+ const char* mid_begin = NULL;
+ const char* mid_end = NULL;
+ const char* single = NULL;
+ extract_astring_t out;
+ extract_astring_init(&out);
+
+ assert(single_name || mid_begin_name || mid_end_name);
+
+ if (single_name) single = strstr(original, single_name);
+
+ if (single)
+ {
+ outf("Have found single_name='%s', using in preference to mid_begin_name=%s mid_end_name=%s",
+ single_name,
+ mid_begin_name,
+ mid_end_name
+ );
+ mid_begin = single;
+ mid_end = single + strlen(single_name);
+ }
+ else
+ {
+ if (mid_begin_name) {
+ mid_begin = strstr(original, mid_begin_name);
+ if (!mid_begin) {
+ outf("error: could not find '%s' in odt content", mid_begin_name);
+ errno = ESRCH;
+ goto end;
+ }
+ mid_begin += strlen(mid_begin_name);
+ }
+ if (mid_end_name) {
+ mid_end = strstr(mid_begin ? mid_begin : original, mid_end_name);
+ if (!mid_end) {
+ outf("error: could not find '%s' in odt content", mid_end_name);
+ e = -1;
+ errno = ESRCH;
+ goto end;
+ }
+ }
+ if (!mid_begin) {
+ mid_begin = mid_end;
+ }
+ if (!mid_end) {
+ mid_end = mid_begin;
+ }
+ }
+
+ if (extract_astring_catl(alloc, &out, original, mid_begin - original)) goto end;
+ {
+ int i;
+ for (i=0; i<contentss_num; ++i) {
+ if (extract_astring_catl(alloc, &out, contentss[i].chars, contentss[i].chars_num)) goto end;
+ }
+ }
+ if (extract_astring_cat(alloc, &out, mid_end)) goto end;
+
+ *o_out = out.chars;
+ out.chars = NULL;
+ e = 0;
+
+ end:
+ if (e) {
+ extract_astring_free(alloc, &out);
+ *o_out = NULL;
+ }
+ return e;
+}
+
diff --git a/extract/src/text.h b/extract/src/text.h
new file mode 100644
index 00000000..fe5a155b
--- /dev/null
+++ b/extract/src/text.h
@@ -0,0 +1,37 @@
+#ifndef EXTRACT_TEXT_H
+#define EXTRACT_TEXT_H
+
+#include "../include/extract_alloc.h"
+
+#include "astring.h"
+
+
+int extract_content_insert(
+ extract_alloc_t* alloc,
+ const char* original,
+ const char* single_name,
+ const char* mid_begin_name,
+ const char* mid_end_name,
+ extract_astring_t* contentss,
+ int contentss_num,
+ char** o_out
+ );
+/* Creates a new string by inserting sequence of strings into a template
+string.
+
+If <single_name> is in <original>, it is replaced by <contentss>.
+
+Otherwise the text between the end of <mid_begin_name> and beginning of
+<mid_end_name> is replaced by <contentss>.
+
+If <mid_begin_name> is NULL, we insert into the zero-length region before
+<mid_end_name>.
+
+If <mid_end_name> is NULL, we insert into the zero-length region after
+<mid_begin_name>.
+
+At least one of <single_name>, <mid_begin_name> and <mid_end_name> must be
+non-NULL.
+*/
+
+#endif
diff --git a/extract/src/zip.c b/extract/src/zip.c
index 013cd578..03bfd024 100644
--- a/extract/src/zip.c
+++ b/extract/src/zip.c
@@ -6,7 +6,6 @@
#include "zip.h"
#include <zlib.h>
-/* For crc32(). */
#include <assert.h>
#include <errno.h>
@@ -43,6 +42,8 @@ struct extract_zip_t
after every small output operation. */
int errno_;
int eof;
+ uint16_t compression_method;
+ int compress_level;
/* Defaults for various values in zip file headers etc. */
uint16_t mtime;
@@ -68,6 +69,8 @@ int extract_zip_open(extract_buffer_t* buffer, extract_zip_t** o_zip)
zip->buffer = buffer;
zip->errno_ = 0;
zip->eof = 0;
+ zip->compression_method = Z_DEFLATED;
+ zip->compress_level = Z_DEFAULT_COMPRESSION;
/* We could maybe convert current date/time to the ms-dos format required
here, but using zeros doesn't seem to make a difference to Word etc. */
@@ -115,7 +118,127 @@ static int s_native_little_endinesss(void)
abort();
}
+
+/* Allocation fns for zlib. */
+
+static void* s_zalloc(void* opaque, unsigned items, unsigned size)
+{
+ extract_zip_t* zip = opaque;
+ extract_alloc_t* alloc = extract_buffer_alloc(zip->buffer);
+ void* ptr;
+ int e = extract_malloc(alloc, &ptr, items*size);
+ if (e) return NULL;
+ return ptr;
+}
+
+static void s_zfree(void* opaque, void* ptr)
+{
+ extract_zip_t* zip = opaque;
+ extract_alloc_t* alloc = extract_buffer_alloc(zip->buffer);
+ extract_free(alloc, &ptr);
+}
+
+
+static int s_write_compressed(
+ extract_zip_t* zip,
+ const void* data,
+ size_t data_length,
+ size_t* o_compressed_length
+ )
+/* Uses zlib to write raw deflate compressed data to zip->buffer. */
+{
+ int ze;
+ z_stream zstream;
+ if (zip->errno_) return -1;
+ if (zip->eof) return +1;
+
+ zstream.zalloc = s_zalloc;
+ zstream.zfree = s_zfree;
+ zstream.opaque = zip;
+
+ /* We need to write raw deflate data, so we use deflateInit2() with -ve
+ windowBits. The values we use are deflateInit()'s defaults. */
+ ze = deflateInit2(
+ &zstream,
+ zip->compress_level,
+ Z_DEFLATED,
+ -15 /*windowBits*/,
+ 8 /*memLevel*/,
+ Z_DEFAULT_STRATEGY
+ );
+ if (ze != Z_OK)
+ {
+ errno = (ze == Z_MEM_ERROR) ? ENOMEM : EINVAL;
+ zip->errno_ = errno;
+ outf("deflateInit2() failed ze=%i", ze);
+ return -1;
+ }
+
+ /* Set zstream to read from specified data. */
+ zstream.next_in = (void*) data;
+ zstream.avail_in = (unsigned) data_length;
+
+ /* We increment *o_compressed_length gradually so that if we return an
+ error, we still indicate how many butes of compressed data have been
+ written. */
+ if (o_compressed_length)
+ {
+ *o_compressed_length = 0;
+ }
+
+ for(;;)
+ {
+ /* todo: write an extract_buffer_cache() function so we can write
+ directly into output buffer if it has a fn_cache. */
+ unsigned char buffer[1024];
+ zstream.next_out = &buffer[0];
+ zstream.avail_out = sizeof(buffer);
+ ze = deflate(&zstream, zstream.avail_in ? Z_NO_FLUSH : Z_FINISH);
+ if (ze != Z_STREAM_END && ze != Z_OK)
+ {
+ outf("deflate() failed ze=%i", ze);
+ errno = EIO;
+ zip->errno_ = errno;
+ return -1;
+ }
+ {
+ /* Send the new compressed data to buffer. */
+ size_t bytes_written;
+ int e = extract_buffer_write(zip->buffer, buffer, zstream.next_out - buffer, &bytes_written);
+ if (o_compressed_length)
+ {
+ *o_compressed_length += bytes_written;
+ }
+ if (e)
+ {
+ if (e == -1) zip->errno_ = errno;
+ if (e == +1) zip->eof = 1;
+ outf("extract_buffer_write() failed e=%i errno=%i", e, errno);
+ return e;
+ }
+ }
+ if (ze == Z_STREAM_END)
+ {
+ break;
+ }
+ }
+ ze = deflateEnd(&zstream);
+ if (ze != Z_OK)
+ {
+ outf("deflateEnd() failed ze=%i", ze);
+ errno = EIO;
+ zip->errno_ = errno;
+ return -1;
+ }
+ if (o_compressed_length)
+ {
+ assert(*o_compressed_length == (size_t) zstream.total_out);
+ }
+ return 0;
+}
+
static int s_write(extract_zip_t* zip, const void* data, size_t data_length)
+/* Writes uncompressed data to zip->buffer. */
{
size_t actual;
int e;
@@ -192,33 +315,66 @@ int extract_zip_write_file(
cd_file->mtime = zip->mtime;
cd_file->mdate = zip->mtime;
cd_file->crc_sum = (int32_t) crc32(crc32(0, NULL, 0), data, (int) data_length);
- cd_file->size_compressed = (int) data_length;
cd_file->size_uncompressed = (int) data_length;
+ if (zip->compression_method == 0)
+ {
+ cd_file->size_compressed = cd_file->size_uncompressed;
+ }
if (extract_strdup(alloc, name, &cd_file->name)) goto end;
cd_file->offset = (int) extract_buffer_pos(zip->buffer);
cd_file->attr_internal = zip->file_attr_internal;
cd_file->attr_external = zip->file_attr_external;
if (!cd_file->name) goto end;
- /* Write local file header. */
+ /* Write local file header. If we are using compression, we set bit 3 of
+ General purpose bit flag and write zeros for crc-32, compressed size and
+ uncompressed size; then we write the actual values in data descriptor after
+ the compressed data. */
{
const char extra_local[] = ""; /* Modify for testing. */
+ uint16_t general_purpose_bit_flag = zip->general_purpose_bit_flag;
+ if (zip->compression_method) general_purpose_bit_flag |= 8;
s_write_uint32(zip, 0x04034b50);
s_write_uint16(zip, zip->version_extract); /* Version needed to extract (minimum). */
- s_write_uint16(zip, zip->general_purpose_bit_flag); /* General purpose bit flag */
- s_write_uint16(zip, 0); /* Compression method */
+ s_write_uint16(zip, general_purpose_bit_flag); /* General purpose bit flag */
+ s_write_uint16(zip, zip->compression_method); /* Compression method */
s_write_uint16(zip, cd_file->mtime); /* File last modification time */
s_write_uint16(zip, cd_file->mdate); /* File last modification date */
- s_write_uint32(zip, cd_file->crc_sum); /* CRC-32 of uncompressed data */
- s_write_uint32(zip, cd_file->size_compressed); /* Compressed size */
- s_write_uint32(zip, cd_file->size_uncompressed); /* Uncompressed size */
+ if (zip->compression_method)
+ {
+ s_write_uint32(zip, 0); /* CRC-32 of uncompressed data */
+ s_write_uint32(zip, 0); /* Compressed size */
+ s_write_uint32(zip, 0); /* Uncompressed size */
+ }
+ else
+ {
+ s_write_uint32(zip, cd_file->crc_sum); /* CRC-32 of uncompressed data */
+ s_write_uint32(zip, cd_file->size_compressed); /* Compressed size */
+ s_write_uint32(zip, cd_file->size_uncompressed);/* Uncompressed size */
+ }
s_write_uint16(zip, (uint16_t) strlen(name)); /* File name length (n) */
s_write_uint16(zip, sizeof(extra_local)-1); /* Extra field length (m) */
s_write_string(zip, cd_file->name); /* File name */
s_write(zip, extra_local, sizeof(extra_local)-1); /* Extra field */
}
- /* Write the (uncompressed) data. */
- s_write(zip, data, data_length);
+
+ if (zip->compression_method)
+ {
+ /* Write compressed data. */
+ size_t data_length_compressed;
+ s_write_compressed(zip, data, data_length, &data_length_compressed);
+ cd_file->size_compressed = (int) data_length_compressed;
+
+ /* Write data descriptor. */
+ s_write_uint32(zip, 0x08074b50); /* Data descriptor signature */
+ s_write_uint32(zip, cd_file->crc_sum); /* CRC-32 of uncompressed data */
+ s_write_uint32(zip, cd_file->size_compressed); /* Compressed size */
+ s_write_uint32(zip, cd_file->size_uncompressed); /* Uncompressed size */
+ }
+ else
+ {
+ s_write(zip, data, data_length);
+ }
if (zip->errno_) e = -1;
else if (zip->eof) e = +1;
@@ -264,7 +420,7 @@ int extract_zip_close(extract_zip_t** pzip)
s_write_uint16(zip, zip->version_creator); /* Version made by, copied from command-line zip. */
s_write_uint16(zip, zip->version_extract); /* Version needed to extract (minimum). */
s_write_uint16(zip, zip->general_purpose_bit_flag); /* General purpose bit flag */
- s_write_uint16(zip, 0); /* Compression method */
+ s_write_uint16(zip, zip->compression_method); /* Compression method */
s_write_uint16(zip, cd_file->mtime); /* File last modification time */
s_write_uint16(zip, cd_file->mdate); /* File last modification date */
s_write_uint32(zip, cd_file->crc_sum); /* CRC-32 of uncompressed data */
diff --git a/extract/src/zip.h b/extract/src/zip.h
index 570f475a..da27558c 100644
--- a/extract/src/zip.h
+++ b/extract/src/zip.h
@@ -10,7 +10,7 @@
/* Support for creating zip file content.
-Content is uncompressed.
+Content is compressed using deflate.
Unless otherwise stated, all functions return 0 on success or -1 with errno
set.
@@ -23,6 +23,8 @@ typedef struct extract_zip_t extract_zip_t;
int extract_zip_open(extract_buffer_t* buffer, extract_zip_t** o_zip);
/* Creates an extract_zip_t that writes to specified buffer.
+We reuse <buffer>'s allocator for zlib's allocation needs.
+
buffer:
Destination for zip file content.
o_zip:
diff --git a/extract/test/Python2.pdf.mutool.odt.dir.ref/META-INF/manifest.xml b/extract/test/Python2.pdf.mutool.odt.dir.ref/META-INF/manifest.xml
new file mode 100644
index 00000000..ec991d79
--- /dev/null
+++ b/extract/test/Python2.pdf.mutool.odt.dir.ref/META-INF/manifest.xml
@@ -0,0 +1,11 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<manifest:manifest xmlns:manifest="urn:oasis:names:tc:opendocument:xmlns:manifest:1.0" manifest:version="1.3" xmlns:loext="urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0">
+ <manifest:file-entry manifest:full-path="/" manifest:version="1.3" manifest:media-type="application/vnd.oasis.opendocument.text"/>
+ <manifest:file-entry manifest:full-path="meta.xml" manifest:media-type="text/xml"/>
+ <manifest:file-entry manifest:full-path="settings.xml" manifest:media-type="text/xml"/>
+ <manifest:file-entry manifest:full-path="Configurations2/" manifest:media-type="application/vnd.sun.xml.ui.configuration"/>
+ <manifest:file-entry manifest:full-path="manifest.rdf" manifest:media-type="application/rdf+xml"/>
+ <manifest:file-entry manifest:full-path="styles.xml" manifest:media-type="text/xml"/>
+ <manifest:file-entry manifest:full-path="content.xml" manifest:media-type="text/xml"/>
+ <manifest:file-entry manifest:full-path="Thumbnails/thumbnail.png" manifest:media-type="image/png"/>
+</manifest:manifest> \ No newline at end of file
diff --git a/extract/test/Python2.pdf.mutool.odt.dir.ref/Thumbnails/thumbnail.png b/extract/test/Python2.pdf.mutool.odt.dir.ref/Thumbnails/thumbnail.png
new file mode 100644
index 00000000..0dd1608e
--- /dev/null
+++ b/extract/test/Python2.pdf.mutool.odt.dir.ref/Thumbnails/thumbnail.png
@@ -0,0 +1,2 @@
+PNG
+
diff --git a/extract/test/Python2.pdf.mutool.odt.dir.ref/content.xml b/extract/test/Python2.pdf.mutool.odt.dir.ref/content.xml
new file mode 100644
index 00000000..476e791f
--- /dev/null
+++ b/extract/test/Python2.pdf.mutool.odt.dir.ref/content.xml
@@ -0,0 +1,113 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<office:document-content xmlns:css3t="http://www.w3.org/TR/css3-text/" xmlns:grddl="http://www.w3.org/2003/g/data-view#" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xforms="http://www.w3.org/2002/xforms" xmlns:dom="http://www.w3.org/2001/xml-events" xmlns:script="urn:oasis:names:tc:opendocument:xmlns:script:1.0" xmlns:form="urn:oasis:names:tc:opendocument:xmlns:form:1.0" xmlns:math="http://www.w3.org/1998/Math/MathML" xmlns:number="urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0" xmlns:field="urn:openoffice:names:experimental:ooo-ms-interop:xmlns:field:1.0" xmlns:meta="urn:oasis:names:tc:opendocument:xmlns:meta:1.0" xmlns:loext="urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0" xmlns:officeooo="http://openoffice.org/2009/office" xmlns:table="urn:oasis:names:tc:opendocument:xmlns:table:1.0" xmlns:chart="urn:oasis:names:tc:opendocument:xmlns:chart:1.0" xmlns:tableooo="http://openoffice.org/2009/table" xmlns:draw="urn:oasis:names:tc:opendocument:xmlns:drawing:1.0" xmlns:rpt="http://openoffice.org/2005/report" xmlns:dr3d="urn:oasis:names:tc:opendocument:xmlns:dr3d:1.0" xmlns:of="urn:oasis:names:tc:opendocument:xmlns:of:1.2" xmlns:text="urn:oasis:names:tc:opendocument:xmlns:text:1.0" xmlns:style="urn:oasis:names:tc:opendocument:xmlns:style:1.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:calcext="urn:org:documentfoundation:names:experimental:calc:xmlns:calcext:1.0" xmlns:oooc="http://openoffice.org/2004/calc" xmlns:drawooo="http://openoffice.org/2010/draw" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:ooo="http://openoffice.org/2004/office" xmlns:ooow="http://openoffice.org/2004/writer" xmlns:fo="urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0" xmlns:formx="urn:openoffice:names:experimental:ooxml-odf-interop:xmlns:form:1.0" xmlns:svg="urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" office:version="1.3"><office:scripts/><office:font-face-decls><style:font-face style:name="Liberation Serif" svg:font-family="&apos;Liberation Serif&apos;" style:font-family-generic="roman" style:font-pitch="variable"/><style:font-face style:name="Liberation Sans" svg:font-family="&apos;Liberation Sans&apos;" style:font-family-generic="swiss" style:font-pitch="variable"/><style:font-face style:name="Unifont" svg:font-family="Unifont" style:font-family-generic="system" style:font-pitch="variable"/></office:font-face-decls><office:automatic-styles><style:style style:name="T14" style:family="text"><style:text-properties style:font-name="TimesNewRomanPSMT" fo:font-size="7.43pt" fo:font-weight="normal" fo:font-style="normal" /></style:style><style:style style:name="T16" style:family="text"><style:text-properties style:font-name="TimesNewRomanPS-ItalicMT" fo:font-size="7.43pt" fo:font-weight="normal" fo:font-style="italic" /></style:style><style:style style:name="T15" style:family="text"><style:text-properties style:font-name="TimesNewRomanPS-BoldMT" fo:font-size="7.43pt" fo:font-weight="bold" fo:font-style="normal" /></style:style><style:style style:name="T23" style:family="text"><style:text-properties style:font-name="OpenSans-Italic" fo:font-size="16.00pt" fo:font-weight="normal" fo:font-style="italic" /></style:style><style:style style:name="T18" style:family="text"><style:text-properties style:font-name="OpenSans-Italic" fo:font-size="14.00pt" fo:font-weight="normal" fo:font-style="italic" /></style:style><style:style style:name="T21" style:family="text"><style:text-properties style:font-name="OpenSans-Italic" fo:font-size="10.00pt" fo:font-weight="normal" fo:font-style="italic" /></style:style><style:style style:name="T20" style:family="text"><style:text-properties style:font-name="OpenSans-BoldItalic" fo:font-size="10.00pt" fo:font-weight="bold" fo:font-style="italic" /></style:style><style:style style:name="T22" style:family="text"><style:text-properties style:font-name="OpenSans-Bold" fo:font-size="14.00pt" fo:font-weight="bold" fo:font-style="normal" /></style:style><style:style style:name="T19" style:family="text"><style:text-properties style:font-name="OpenSans-Bold" fo:font-size="10.00pt" fo:font-weight="bold" fo:font-style="normal" /></style:style><style:style style:name="T24" style:family="text"><style:text-properties style:font-name="OpenSans" fo:font-size="14.00pt" fo:font-weight="normal" fo:font-style="normal" /></style:style><style:style style:name="T17" style:family="text"><style:text-properties style:font-name="OpenSans" fo:font-size="10.00pt" fo:font-weight="normal" fo:font-style="normal" /></style:style><style:style style:name="T11" style:family="text"><style:text-properties style:font-name="CourierNewPSMT" fo:font-size="7.43pt" fo:font-weight="normal" fo:font-style="normal" /></style:style><style:style style:name="T13" style:family="text"><style:text-properties style:font-name="CourierNewPS-ItalicMT" fo:font-size="10.00pt" fo:font-weight="normal" fo:font-style="italic" /></style:style><style:style style:name="T12" style:family="text"><style:text-properties style:font-name="CourierNewPS-BoldMT" fo:font-size="7.43pt" fo:font-weight="bold" fo:font-style="normal" /></style:style><style:style style:name="gr1" style:family="graphic">
+<style:graphic-properties draw:stroke="none" svg:stroke-color="#000000" draw:fill="none" draw:fill-color="#ffffff" fo:min-height="1.9898in" style:run-through="foreground" style:wrap="run-through" style:number-wrapped-paragraphs="no-limit" style:vertical-pos="from-top" style:vertical-rel="paragraph" style:horizontal-pos="from-left" style:horizontal-rel="paragraph" />
+<style:paragraph-properties style:writing-mode="lr-tb"/>
+</style:style>
+<style:style style:name="fr1" style:family="graphic" style:parent-style-name="Graphics">
+<style:graphic-properties fo:margin-left="0in" fo:margin-right="0in" fo:margin-top="0in" fo:margin-bottom="0in" style:vertical-pos="top" style:vertical-rel="baseline" fo:background-color="transparent" draw:fill="none" draw:fill-color="#ffffff" fo:padding="0in" fo:border="none" style:mirror="none" fo:clip="rect(0in, 0in, 0in, 0in)" draw:luminance="0%" draw:contrast="0%" draw:red="0%" draw:green="0%" draw:blue="0%" draw:gamma="100%" draw:color-inversion="false" draw:image-opacity="100%" draw:color-mode="standard"/>
+</style:style>
+</office:automatic-styles><office:body><office:text><text:sequence-decls><text:sequence-decl text:display-outline-level="0" text:name="Illustration"/><text:sequence-decl text:display-outline-level="0" text:name="Table"/><text:sequence-decl text:display-outline-level="0" text:name="Text"/><text:sequence-decl text:display-outline-level="0" text:name="Drawing"/><text:sequence-decl text:display-outline-level="0" text:name="Figure"/></text:sequence-decls><text:p text:style-name="Standard"/>
+<text:p text:style-name="Standard">
+<draw:frame text:anchor-type="paragraph" draw:z-index="5" draw:name="Shape1" draw:style-name="gr1" draw:text-style-name="Standard" svg:width="3.164382in" svg:height="1.031016in" draw:transform="rotate (-3.045849) translate (6.752333in 7.925972in)">
+<draw:text-box>
+
+
+<text:p><text:span text:style-name="T11">There was one who was famed for the number of things He </text:span><text:span text:style-name="T12">forgot </text:span><text:span text:style-name="T11">when he entered the ship: His umbrella, his watch, all his jewels and rings, And the clothes he had bought for the trip. He had </text:span><text:span text:style-name="T13">forty-two</text:span><text:span text:style-name="T11"> boxes, all carefully packed, With his name painted clearly on each: But, since he omitted to mention the fact, They were all left behind on the beach.</text:span></text:p>
+</draw:text-box>
+</draw:frame>
+</text:p>
+
+<text:p text:style-name="Standard">
+<draw:frame text:anchor-type="paragraph" draw:z-index="5" draw:name="Shape2" draw:style-name="gr1" draw:text-style-name="Standard" svg:width="2.395263in" svg:height="1.541583in" draw:transform="rotate (2.477539) translate (2.109778in 6.750042in)">
+<draw:text-box>
+
+
+<text:p><text:span text:style-name="T14">The crew was complete: it included a </text:span><text:span text:style-name="T15">Boots</text:span><text:span text:style-name="T14">&#x2014; A maker of Bonnets and Hoods&#x2014; A </text:span><text:span text:style-name="T15">Barrister</text:span><text:span text:style-name="T14">, brought to arrange their disputes&#x2014; And a </text:span><text:span text:style-name="T15">Broker</text:span><text:span text:style-name="T14">, to value their goods.</text:span></text:p>
+
+<text:p><text:span text:style-name="T14">A </text:span><text:span text:style-name="T15">Billiard-marker</text:span><text:span text:style-name="T14">, whose skill was immense, Might perhaps have won more than his share&#x2014; But a </text:span><text:span text:style-name="T15">Banker</text:span><text:span text:style-name="T14">, engaged at enormous expense, Had the whole of their </text:span><text:span text:style-name="T16">cash </text:span><text:span text:style-name="T14">in his care.</text:span></text:p>
+
+<text:p><text:span text:style-name="T14">There was also a </text:span><text:span text:style-name="T15">Beaver</text:span><text:span text:style-name="T14">, that paced on the deck, Or would sit making lace in the bow: And had often (the </text:span><text:span text:style-name="T15">Bellman </text:span><text:span text:style-name="T14">said) saved them from wreck, Though none of the sailors knew how.</text:span></text:p>
+</draw:text-box>
+</draw:frame>
+</text:p>
+
+<text:p text:style-name="Standard">
+<draw:frame text:anchor-type="paragraph" draw:z-index="5" draw:name="Shape3" draw:style-name="gr1" draw:text-style-name="Standard" svg:width="3.124056in" svg:height="2.028653in" draw:transform="rotate (-1.783173) translate (7.624278in 3.348042in)">
+<draw:text-box>
+
+
+<text:p><text:span text:style-name="T17">&quot;Just the place for a </text:span><text:span text:style-name="T18">Snark</text:span><text:span text:style-name="T17">!&quot; the </text:span><text:span text:style-name="T19">Bellman </text:span><text:span text:style-name="T17">cried,</text:span></text:p>
+
+<text:p><text:span text:style-name="T17"> As he landed his crew with care;</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">Supporting each man on the top of the tide</text:span></text:p>
+
+<text:p><text:span text:style-name="T17"> By a finger entwined in his hair.</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">&quot;Just the place for a </text:span><text:span text:style-name="T18">Snark</text:span><text:span text:style-name="T17">! I have said it twice:</text:span></text:p>
+
+<text:p><text:span text:style-name="T17"> That alone should encourage the crew.</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">Just the place for a </text:span><text:span text:style-name="T18">Snark</text:span><text:span text:style-name="T17">! I have said it thrice:</text:span></text:p>
+
+<text:p><text:span text:style-name="T17"> What I tell you </text:span><text:span text:style-name="T19">three </text:span><text:span text:style-name="T17">times is true.&quot;</text:span></text:p>
+</draw:text-box>
+</draw:frame>
+</text:p>
+
+<text:p text:style-name="Standard">
+<draw:frame text:anchor-type="paragraph" draw:z-index="5" draw:name="Shape4" draw:style-name="gr1" draw:text-style-name="Standard" svg:width="2.525194in" svg:height="1.087708in" draw:transform="rotate (-0.579428) translate (5.400722in 0.528625in)">
+<draw:text-box>
+
+
+<text:p><text:span text:style-name="T17">There was a young man of </text:span><text:span text:style-name="T20">Madras</text:span><text:span text:style-name="T17">,</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">Whose balls were </text:span><text:span text:style-name="T21">constructed </text:span><text:span text:style-name="T17">of brass,</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">When jangled together,</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">They played &#x201c;</text:span><text:span text:style-name="T22">Stormy Weather</text:span><text:span text:style-name="T17">&#x201d;,</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">And </text:span><text:span text:style-name="T23">lightning</text:span><text:span text:style-name="T21"> </text:span><text:span text:style-name="T17">shot out of his ass.</text:span></text:p>
+</draw:text-box>
+</draw:frame>
+</text:p>
+
+<text:p text:style-name="Standard">
+<draw:frame text:anchor-type="paragraph" draw:z-index="5" draw:name="Shape5" draw:style-name="gr1" draw:text-style-name="Standard" svg:width="2.285973in" svg:height="3.268209in" draw:transform="rotate (0.478675) translate (0.450069in 1.370778in)">
+<draw:text-box>
+
+
+<text:p><text:span text:style-name="T17">A Python, I should not advise,</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">For it needs a doctor for its eyes,</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">And has the Measles yearly.</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">However, if </text:span><text:span text:style-name="T24">you feel</text:span><text:span text:style-name="T17"> inclined</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">To get one (to improve your mind,</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">And not from fashion merely),</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">Allow no </text:span><text:span text:style-name="T21">music</text:span><text:span text:style-name="T17"> near its cage;</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">And when it </text:span><text:span text:style-name="T19">flies</text:span><text:span text:style-name="T17"> into a rage</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">Chastise it, most severely.</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">I had an Aunt in Yucatan</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">Who bought a Python from a man</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">And kept it for a pet.</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">She </text:span><text:span text:style-name="T20">died</text:span><text:span text:style-name="T17">, because she never knew</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">These simple little rules and few; &#x2014;</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">The snake is living yet.</text:span></text:p>
+</draw:text-box>
+</draw:frame>
+</text:p>
+</office:text></office:body></office:document-content> \ No newline at end of file
diff --git a/extract/test/Python2.pdf.mutool.odt.dir.ref/manifest.rdf b/extract/test/Python2.pdf.mutool.odt.dir.ref/manifest.rdf
new file mode 100644
index 00000000..927e206b
--- /dev/null
+++ b/extract/test/Python2.pdf.mutool.odt.dir.ref/manifest.rdf
@@ -0,0 +1,18 @@
+<?xml version="1.0" encoding="utf-8"?>
+<rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#">
+ <rdf:Description rdf:about="styles.xml">
+ <rdf:type rdf:resource="http://docs.oasis-open.org/ns/office/1.2/meta/odf#StylesFile"/>
+ </rdf:Description>
+ <rdf:Description rdf:about="">
+ <ns0:hasPart xmlns:ns0="http://docs.oasis-open.org/ns/office/1.2/meta/pkg#" rdf:resource="styles.xml"/>
+ </rdf:Description>
+ <rdf:Description rdf:about="content.xml">
+ <rdf:type rdf:resource="http://docs.oasis-open.org/ns/office/1.2/meta/odf#ContentFile"/>
+ </rdf:Description>
+ <rdf:Description rdf:about="">
+ <ns0:hasPart xmlns:ns0="http://docs.oasis-open.org/ns/office/1.2/meta/pkg#" rdf:resource="content.xml"/>
+ </rdf:Description>
+ <rdf:Description rdf:about="">
+ <rdf:type rdf:resource="http://docs.oasis-open.org/ns/office/1.2/meta/pkg#Document"/>
+ </rdf:Description>
+</rdf:RDF>
diff --git a/extract/test/Python2.pdf.mutool.odt.dir.ref/meta.xml b/extract/test/Python2.pdf.mutool.odt.dir.ref/meta.xml
new file mode 100644
index 00000000..6b42561e
--- /dev/null
+++ b/extract/test/Python2.pdf.mutool.odt.dir.ref/meta.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<office:document-meta xmlns:grddl="http://www.w3.org/2003/g/data-view#" xmlns:meta="urn:oasis:names:tc:opendocument:xmlns:meta:1.0" xmlns:ooo="http://openoffice.org/2004/office" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" office:version="1.3"><office:meta><meta:creation-date>2021-04-05T17:06:57.937137058</meta:creation-date><meta:generator>LibreOffice/7.0.1.2$OpenBSD_X86_64 LibreOffice_project/00$Build-2</meta:generator><dc:date>2021-04-06T17:14:51.409959656</dc:date><meta:editing-duration>PT20S</meta:editing-duration><meta:editing-cycles>1</meta:editing-cycles><meta:document-statistic meta:table-count="0" meta:image-count="0" meta:object-count="0" meta:page-count="1" meta:paragraph-count="0" meta:word-count="0" meta:character-count="0" meta:non-whitespace-character-count="0"/></office:meta></office:document-meta> \ No newline at end of file
diff --git a/extract/test/Python2.pdf.mutool.odt.dir.ref/mimetype b/extract/test/Python2.pdf.mutool.odt.dir.ref/mimetype
new file mode 100644
index 00000000..2e95b81c
--- /dev/null
+++ b/extract/test/Python2.pdf.mutool.odt.dir.ref/mimetype
@@ -0,0 +1 @@
+application/vnd.oasis.opendocument.text \ No newline at end of file
diff --git a/extract/test/Python2.pdf.mutool.odt.dir.ref/settings.xml b/extract/test/Python2.pdf.mutool.odt.dir.ref/settings.xml
new file mode 100644
index 00000000..35a8138f
--- /dev/null
+++ b/extract/test/Python2.pdf.mutool.odt.dir.ref/settings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<office:document-settings xmlns:config="urn:oasis:names:tc:opendocument:xmlns:config:1.0" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:ooo="http://openoffice.org/2004/office" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" office:version="1.3"><office:settings><config:config-item-set config:name="ooo:view-settings"><config:config-item config:name="ViewAreaTop" config:type="long">0</config:config-item><config:config-item config:name="ViewAreaLeft" config:type="long">0</config:config-item><config:config-item config:name="ViewAreaWidth" config:type="long">26275</config:config-item><config:config-item config:name="ViewAreaHeight" config:type="long">19502</config:config-item><config:config-item config:name="ShowRedlineChanges" config:type="boolean">true</config:config-item><config:config-item config:name="InBrowseMode" config:type="boolean">false</config:config-item><config:config-item-map-indexed config:name="Views"><config:config-item-map-entry><config:config-item config:name="ViewId" config:type="string">view2</config:config-item><config:config-item config:name="ViewLeft" config:type="long">4343</config:config-item><config:config-item config:name="ViewTop" config:type="long">2501</config:config-item><config:config-item config:name="VisibleLeft" config:type="long">0</config:config-item><config:config-item config:name="VisibleTop" config:type="long">0</config:config-item><config:config-item config:name="VisibleRight" config:type="long">26273</config:config-item><config:config-item config:name="VisibleBottom" config:type="long">19500</config:config-item><config:config-item config:name="ZoomType" config:type="short">0</config:config-item><config:config-item config:name="ViewLayoutColumns" config:type="short">1</config:config-item><config:config-item config:name="ViewLayoutBookMode" config:type="boolean">false</config:config-item><config:config-item config:name="ZoomFactor" config:type="short">100</config:config-item><config:config-item config:name="IsSelectedFrame" config:type="boolean">false</config:config-item><config:config-item config:name="AnchoredTextOverflowLegacy" config:type="boolean">false</config:config-item></config:config-item-map-entry></config:config-item-map-indexed></config:config-item-set><config:config-item-set config:name="ooo:configuration-settings"><config:config-item config:name="PrintBlackFonts" config:type="boolean">false</config:config-item><config:config-item config:name="PrintReversed" config:type="boolean">false</config:config-item><config:config-item config:name="SaveThumbnail" config:type="boolean">true</config:config-item><config:config-item config:name="EmbedFonts" config:type="boolean">false</config:config-item><config:config-item config:name="PrintControls" config:type="boolean">true</config:config-item><config:config-item config:name="OutlineLevelYieldsNumbering" config:type="boolean">false</config:config-item><config:config-item config:name="PrintPageBackground" config:type="boolean">true</config:config-item><config:config-item config:name="PrintAnnotationMode" config:type="short">0</config:config-item><config:config-item config:name="PrintGraphics" config:type="boolean">true</config:config-item><config:config-item config:name="EmbeddedDatabaseName" config:type="string"/><config:config-item config:name="ProtectForm" config:type="boolean">false</config:config-item><config:config-item config:name="PrintLeftPages" config:type="boolean">true</config:config-item><config:config-item config:name="PrintProspect" config:type="boolean">false</config:config-item><config:config-item config:name="PrintHiddenText" config:type="boolean">false</config:config-item><config:config-item config:name="PrintRightPages" config:type="boolean">true</config:config-item><config:config-item config:name="PrintFaxName" config:type="string"/><config:config-item config:name="PrintPaperFromSetup" config:type="boolean">false</config:config-item><config:config-item config:name="TabsRelativeToIndent" config:type="boolean">true</config:config-item><config:config-item config:name="RedlineProtectionKey" config:type="base64Binary"/><config:config-item config:name="PrintTextPlaceholder" config:type="boolean">false</config:config-item><config:config-item config:name="MathBaselineAlignment" config:type="boolean">true</config:config-item><config:config-item config:name="ProtectBookmarks" config:type="boolean">false</config:config-item><config:config-item config:name="IgnoreTabsAndBlanksForLineCalculation" config:type="boolean">false</config:config-item><config:config-item config:name="ContinuousEndnotes" config:type="boolean">false</config:config-item><config:config-item config:name="FieldAutoUpdate" config:type="boolean">true</config:config-item><config:config-item config:name="EmptyDbFieldHidesPara" config:type="boolean">true</config:config-item><config:config-item config:name="ApplyParagraphMarkFormatToNumbering" config:type="boolean">false</config:config-item><config:config-item config:name="PrintEmptyPages" config:type="boolean">true</config:config-item><config:config-item config:name="TabOverMargin" config:type="boolean">false</config:config-item><config:config-item config:name="EmbedAsianScriptFonts" config:type="boolean">true</config:config-item><config:config-item config:name="EmbedLatinScriptFonts" config:type="boolean">true</config:config-item><config:config-item config:name="DisableOffPagePositioning" config:type="boolean">false</config:config-item><config:config-item config:name="EmbedOnlyUsedFonts" config:type="boolean">false</config:config-item><config:config-item config:name="MsWordCompMinLineHeightByFly" config:type="boolean">false</config:config-item><config:config-item config:name="SurroundTextWrapSmall" config:type="boolean">false</config:config-item><config:config-item config:name="BackgroundParaOverDrawings" config:type="boolean">false</config:config-item><config:config-item config:name="ClippedPictures" config:type="boolean">false</config:config-item><config:config-item config:name="FloattableNomargins" config:type="boolean">false</config:config-item><config:config-item config:name="UnbreakableNumberings" config:type="boolean">false</config:config-item><config:config-item config:name="EmbedSystemFonts" config:type="boolean">false</config:config-item><config:config-item config:name="TabOverflow" config:type="boolean">true</config:config-item><config:config-item config:name="PrintTables" config:type="boolean">true</config:config-item><config:config-item config:name="PrintDrawings" config:type="boolean">true</config:config-item><config:config-item config:name="ConsiderTextWrapOnObjPos" config:type="boolean">false</config:config-item><config:config-item config:name="PrintSingleJobs" config:type="boolean">false</config:config-item><config:config-item config:name="SmallCapsPercentage66" config:type="boolean">false</config:config-item><config:config-item config:name="CollapseEmptyCellPara" config:type="boolean">true</config:config-item><config:config-item config:name="HeaderSpacingBelowLastPara" config:type="boolean">false</config:config-item><config:config-item config:name="RsidRoot" config:type="int">2052946</config:config-item><config:config-item config:name="PrinterSetup" config:type="base64Binary"/><config:config-item config:name="CurrentDatabaseCommand" config:type="string"/><config:config-item config:name="AlignTabStopPosition" config:type="boolean">true</config:config-item><config:config-item config:name="ClipAsCharacterAnchoredWriterFlyFrames" config:type="boolean">false</config:config-item><config:config-item config:name="DoNotCaptureDrawObjsOnPage" config:type="boolean">false</config:config-item><config:config-item config:name="SaveGlobalDocumentLinks" config:type="boolean">false</config:config-item><config:config-item config:name="CurrentDatabaseCommandType" config:type="int">0</config:config-item><config:config-item config:name="LoadReadonly" config:type="boolean">false</config:config-item><config:config-item config:name="DoNotResetParaAttrsForNumFont" config:type="boolean">false</config:config-item><config:config-item config:name="StylesNoDefault" config:type="boolean">false</config:config-item><config:config-item config:name="LinkUpdateMode" config:type="short">1</config:config-item><config:config-item config:name="DoNotJustifyLinesWithManualBreak" config:type="boolean">false</config:config-item><config:config-item config:name="PropLineSpacingShrinksFirstLine" config:type="boolean">true</config:config-item><config:config-item config:name="TabAtLeftIndentForParagraphsInList" config:type="boolean">false</config:config-item><config:config-item config:name="ProtectFields" config:type="boolean">false</config:config-item><config:config-item config:name="UnxForceZeroExtLeading" config:type="boolean">false</config:config-item><config:config-item config:name="CurrentDatabaseDataSource" config:type="string"/><config:config-item config:name="UseFormerTextWrapping" config:type="boolean">false</config:config-item><config:config-item config:name="UseFormerLineSpacing" config:type="boolean">false</config:config-item><config:config-item config:name="AllowPrintJobCancel" config:type="boolean">true</config:config-item><config:config-item config:name="SubtractFlysAnchoredAtFlys" config:type="boolean">false</config:config-item><config:config-item config:name="AddParaSpacingToTableCells" config:type="boolean">true</config:config-item><config:config-item config:name="AddExternalLeading" config:type="boolean">true</config:config-item><config:config-item config:name="Rsid" config:type="int">2178852</config:config-item><config:config-item config:name="AddVerticalFrameOffsets" config:type="boolean">false</config:config-item><config:config-item config:name="TreatSingleColumnBreakAsPageBreak" config:type="boolean">false</config:config-item><config:config-item config:name="AddFrameOffsets" config:type="boolean">false</config:config-item><config:config-item config:name="IsLabelDocument" config:type="boolean">false</config:config-item><config:config-item config:name="MsWordCompTrailingBlanks" config:type="boolean">false</config:config-item><config:config-item config:name="PrinterPaperFromSetup" config:type="boolean">false</config:config-item><config:config-item config:name="IgnoreFirstLineIndentInNumbering" config:type="boolean">false</config:config-item><config:config-item config:name="PrinterName" config:type="string"/><config:config-item config:name="IsKernAsianPunctuation" config:type="boolean">false</config:config-item><config:config-item config:name="PrinterIndependentLayout" config:type="string">high-resolution</config:config-item><config:config-item config:name="TableRowKeep" config:type="boolean">false</config:config-item><config:config-item config:name="UpdateFromTemplate" config:type="boolean">true</config:config-item><config:config-item config:name="EmbedComplexScriptFonts" config:type="boolean">true</config:config-item><config:config-item config:name="UseOldPrinterMetrics" config:type="boolean">false</config:config-item><config:config-item config:name="InvertBorderSpacing" config:type="boolean">false</config:config-item><config:config-item config:name="PrintProspectRTL" config:type="boolean">false</config:config-item><config:config-item config:name="ApplyUserData" config:type="boolean">true</config:config-item><config:config-item config:name="AddParaTableSpacingAtStart" config:type="boolean">true</config:config-item><config:config-item config:name="SaveVersionOnClose" config:type="boolean">false</config:config-item><config:config-item config:name="CharacterCompressionType" config:type="short">0</config:config-item><config:config-item config:name="UseOldNumbering" config:type="boolean">false</config:config-item><config:config-item config:name="UseFormerObjectPositioning" config:type="boolean">false</config:config-item><config:config-item config:name="ChartAutoUpdate" config:type="boolean">true</config:config-item><config:config-item config:name="AddParaTableSpacing" config:type="boolean">true</config:config-item></config:config-item-set></office:settings></office:document-settings> \ No newline at end of file
diff --git a/extract/test/Python2.pdf.mutool.odt.dir.ref/styles.xml b/extract/test/Python2.pdf.mutool.odt.dir.ref/styles.xml
new file mode 100644
index 00000000..91403c4e
--- /dev/null
+++ b/extract/test/Python2.pdf.mutool.odt.dir.ref/styles.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<office:document-styles xmlns:css3t="http://www.w3.org/TR/css3-text/" xmlns:grddl="http://www.w3.org/2003/g/data-view#" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:dom="http://www.w3.org/2001/xml-events" xmlns:script="urn:oasis:names:tc:opendocument:xmlns:script:1.0" xmlns:form="urn:oasis:names:tc:opendocument:xmlns:form:1.0" xmlns:math="http://www.w3.org/1998/Math/MathML" xmlns:number="urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0" xmlns:field="urn:openoffice:names:experimental:ooo-ms-interop:xmlns:field:1.0" xmlns:meta="urn:oasis:names:tc:opendocument:xmlns:meta:1.0" xmlns:loext="urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0" xmlns:officeooo="http://openoffice.org/2009/office" xmlns:table="urn:oasis:names:tc:opendocument:xmlns:table:1.0" xmlns:chart="urn:oasis:names:tc:opendocument:xmlns:chart:1.0" xmlns:tableooo="http://openoffice.org/2009/table" xmlns:draw="urn:oasis:names:tc:opendocument:xmlns:drawing:1.0" xmlns:rpt="http://openoffice.org/2005/report" xmlns:dr3d="urn:oasis:names:tc:opendocument:xmlns:dr3d:1.0" xmlns:of="urn:oasis:names:tc:opendocument:xmlns:of:1.2" xmlns:text="urn:oasis:names:tc:opendocument:xmlns:text:1.0" xmlns:style="urn:oasis:names:tc:opendocument:xmlns:style:1.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:calcext="urn:org:documentfoundation:names:experimental:calc:xmlns:calcext:1.0" xmlns:oooc="http://openoffice.org/2004/calc" xmlns:drawooo="http://openoffice.org/2010/draw" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:ooo="http://openoffice.org/2004/office" xmlns:ooow="http://openoffice.org/2004/writer" xmlns:fo="urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0" xmlns:svg="urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" office:version="1.3"><office:font-face-decls><style:font-face style:name="Liberation Serif" svg:font-family="&apos;Liberation Serif&apos;" style:font-family-generic="roman" style:font-pitch="variable"/><style:font-face style:name="Liberation Sans" svg:font-family="&apos;Liberation Sans&apos;" style:font-family-generic="swiss" style:font-pitch="variable"/><style:font-face style:name="Unifont" svg:font-family="Unifont" style:font-family-generic="system" style:font-pitch="variable"/></office:font-face-decls><office:styles><style:default-style style:family="graphic"><style:graphic-properties svg:stroke-color="#3465a4" draw:fill-color="#729fcf" fo:wrap-option="no-wrap" draw:shadow-offset-x="0.1181in" draw:shadow-offset-y="0.1181in" draw:start-line-spacing-horizontal="0.1114in" draw:start-line-spacing-vertical="0.1114in" draw:end-line-spacing-horizontal="0.1114in" draw:end-line-spacing-vertical="0.1114in" style:flow-with-text="false"/><style:paragraph-properties style:text-autospace="ideograph-alpha" style:line-break="strict" style:font-independent-line-spacing="false"><style:tab-stops/></style:paragraph-properties><style:text-properties style:use-window-font-color="true" loext:opacity="0%" style:font-name="Liberation Serif" fo:font-size="12pt" fo:language="en" fo:country="US" style:letter-kerning="true" style:font-name-asian="Unifont" style:font-size-asian="10.5pt" style:language-asian="zh" style:country-asian="CN" style:font-name-complex="Unifont" style:font-size-complex="12pt" style:language-complex="hi" style:country-complex="IN"/></style:default-style><style:default-style style:family="paragraph"><style:paragraph-properties fo:orphans="2" fo:widows="2" fo:hyphenation-ladder-count="no-limit" style:text-autospace="ideograph-alpha" style:punctuation-wrap="hanging" style:line-break="strict" style:tab-stop-distance="0.4925in" style:writing-mode="page"/><style:text-properties style:use-window-font-color="true" loext:opacity="0%" style:font-name="Liberation Serif" fo:font-size="12pt" fo:language="en" fo:country="US" style:letter-kerning="true" style:font-name-asian="Unifont" style:font-size-asian="10.5pt" style:language-asian="zh" style:country-asian="CN" style:font-name-complex="Unifont" style:font-size-complex="12pt" style:language-complex="hi" style:country-complex="IN" fo:hyphenate="false" fo:hyphenation-remain-char-count="2" fo:hyphenation-push-char-count="2" loext:hyphenation-no-caps="false"/></style:default-style><style:default-style style:family="table"><style:table-properties table:border-model="collapsing"/></style:default-style><style:default-style style:family="table-row"><style:table-row-properties fo:keep-together="auto"/></style:default-style><style:style style:name="Standard" style:family="paragraph" style:class="text"><style:paragraph-properties fo:margin-top="0in" fo:margin-bottom="0.0799in" style:contextual-spacing="false"/></style:style><style:style style:name="Heading" style:family="paragraph" style:parent-style-name="Standard" style:next-style-name="Text_20_body" style:class="text"><style:paragraph-properties fo:margin-top="0.1665in" fo:margin-bottom="0.0835in" style:contextual-spacing="false" fo:keep-with-next="always"/><style:text-properties style:font-name="Liberation Sans" fo:font-family="&apos;Liberation Sans&apos;" style:font-family-generic="swiss" style:font-pitch="variable" fo:font-size="14pt" style:font-name-asian="Unifont" style:font-family-asian="Unifont" style:font-family-generic-asian="system" style:font-pitch-asian="variable" style:font-size-asian="14pt" style:font-name-complex="Unifont" style:font-family-complex="Unifont" style:font-family-generic-complex="system" style:font-pitch-complex="variable" style:font-size-complex="14pt"/></style:style><style:style style:name="Text_20_body" style:display-name="Text body" style:family="paragraph" style:parent-style-name="Standard" style:class="text"><style:paragraph-properties fo:margin-top="0in" fo:margin-bottom="0.0972in" style:contextual-spacing="false" fo:line-height="115%"/></style:style><style:style style:name="List" style:family="paragraph" style:parent-style-name="Text_20_body" style:class="list"><style:text-properties style:font-size-asian="12pt"/></style:style><style:style style:name="Caption" style:family="paragraph" style:parent-style-name="Standard" style:class="extra"><style:paragraph-properties fo:margin-top="0.0835in" fo:margin-bottom="0.0835in" style:contextual-spacing="false" text:number-lines="false" text:line-number="0"/><style:text-properties fo:font-size="12pt" fo:font-style="italic" style:font-size-asian="12pt" style:font-style-asian="italic" style:font-size-complex="12pt" style:font-style-complex="italic"/></style:style><style:style style:name="Index" style:family="paragraph" style:parent-style-name="Standard" style:class="index"><style:paragraph-properties text:number-lines="false" text:line-number="0"/><style:text-properties style:font-size-asian="12pt"/></style:style><text:outline-style style:name="Outline"><text:outline-level-style text:level="1" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="2" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="3" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="4" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="5" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="6" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="7" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="8" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="9" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="10" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style></text:outline-style><text:notes-configuration text:note-class="footnote" style:num-format="1" text:start-value="0" text:footnotes-position="page" text:start-numbering-at="document"/><text:notes-configuration text:note-class="endnote" style:num-format="i" text:start-value="0"/><text:linenumbering-configuration text:number-lines="false" text:offset="0.1965in" style:num-format="1" text:number-position="left" text:increment="5"/></office:styles><office:automatic-styles><style:page-layout style:name="Mpm1"><style:page-layout-properties fo:page-width="8.5in" fo:page-height="11in" style:num-format="1" style:print-orientation="portrait" fo:margin-top="0.7874in" fo:margin-bottom="0.7874in" fo:margin-left="0.7874in" fo:margin-right="0.7874in" style:writing-mode="lr-tb" style:layout-grid-color="#c0c0c0" style:layout-grid-lines="20" style:layout-grid-base-height="0.278in" style:layout-grid-ruby-height="0.139in" style:layout-grid-mode="none" style:layout-grid-ruby-below="false" style:layout-grid-print="false" style:layout-grid-display="false" style:footnote-max-height="0in"><style:footnote-sep style:width="0.0071in" style:distance-before-sep="0.0398in" style:distance-after-sep="0.0398in" style:line-style="solid" style:adjustment="left" style:rel-width="25%" style:color="#000000"/></style:page-layout-properties><style:header-style/><style:footer-style/></style:page-layout></office:automatic-styles><office:master-styles><style:master-page style:name="Standard" style:page-layout-name="Mpm1"/></office:master-styles></office:document-styles> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/[Content_Types].xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/[Content_Types].xml
new file mode 100644
index 00000000..07d88cca
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/[Content_Types].xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Types xmlns="http://schemas.openxmlformats.org/package/2006/content-types"><Default Extension="rels" ContentType="application/vnd.openxmlformats-package.relationships+xml"/><Default Extension="xml" ContentType="application/xml"/><Override PartName="/word/document.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.document.main+xml"/><Override PartName="/word/styles.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.styles+xml"/><Override PartName="/word/settings.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.settings+xml"/><Override PartName="/word/webSettings.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.webSettings+xml"/><Override PartName="/word/fontTable.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.fontTable+xml"/><Override PartName="/word/theme/theme1.xml" ContentType="application/vnd.openxmlformats-officedocument.theme+xml"/><Override PartName="/docProps/core.xml" ContentType="application/vnd.openxmlformats-package.core-properties+xml"/><Override PartName="/docProps/app.xml" ContentType="application/vnd.openxmlformats-officedocument.extended-properties+xml"/></Types> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/_rels/.rels b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/_rels/.rels
new file mode 100644
index 00000000..32548d42
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/_rels/.rels
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/extended-properties" Target="docProps/app.xml"/><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/package/2006/relationships/metadata/core-properties" Target="docProps/core.xml"/><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument" Target="word/document.xml"/></Relationships> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/docProps/app.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/docProps/app.xml
new file mode 100644
index 00000000..eb8dd2e5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/docProps/app.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Properties xmlns="http://schemas.openxmlformats.org/officeDocument/2006/extended-properties" xmlns:vt="http://schemas.openxmlformats.org/officeDocument/2006/docPropsVTypes"><Template>Normal.dotm</Template><TotalTime>3</TotalTime><Pages>1</Pages><Words>2</Words><Characters>18</Characters><Application>Microsoft Office Word</Application><DocSecurity>0</DocSecurity><Lines>1</Lines><Paragraphs>1</Paragraphs><ScaleCrop>false</ScaleCrop><Company></Company><LinksUpToDate>false</LinksUpToDate><CharactersWithSpaces>19</CharactersWithSpaces><SharedDoc>false</SharedDoc><HyperlinksChanged>false</HyperlinksChanged><AppVersion>16.0000</AppVersion></Properties> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/docProps/core.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/docProps/core.xml
new file mode 100644
index 00000000..195d77a9
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/docProps/core.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<cp:coreProperties xmlns:cp="http://schemas.openxmlformats.org/package/2006/metadata/core-properties" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:dcterms="http://purl.org/dc/terms/" xmlns:dcmitype="http://purl.org/dc/dcmitype/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><dc:title></dc:title><dc:subject></dc:subject><dc:creator></dc:creator><cp:keywords></cp:keywords><dc:description></dc:description><cp:lastModifiedBy></cp:lastModifiedBy><cp:revision>1</cp:revision><dcterms:created xsi:type="dcterms:W3CDTF">2020-09-25T17:04:00Z</dcterms:created><dcterms:modified xsi:type="dcterms:W3CDTF">2020-09-25T17:07:00Z</dcterms:modified></cp:coreProperties> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/_rels/document.xml.rels b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/_rels/document.xml.rels
new file mode 100644
index 00000000..3b2b7f8c
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/_rels/document.xml.rels
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/webSettings" Target="webSettings.xml"/><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/settings" Target="settings.xml"/><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles" Target="styles.xml"/><Relationship Id="rId5" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme" Target="theme/theme1.xml"/><Relationship Id="rId4" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/fontTable" Target="fontTable.xml"/></Relationships> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/document.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/document.xml
new file mode 100644
index 00000000..32b69d9f
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/document.xml
@@ -0,0 +1,321 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:document xmlns:wpc="http://schemas.microsoft.com/office/word/2010/wordprocessingCanvas" xmlns:cx="http://schemas.microsoft.com/office/drawing/2014/chartex" xmlns:cx1="http://schemas.microsoft.com/office/drawing/2015/9/8/chartex" xmlns:cx2="http://schemas.microsoft.com/office/drawing/2015/10/21/chartex" xmlns:cx3="http://schemas.microsoft.com/office/drawing/2016/5/9/chartex" xmlns:cx4="http://schemas.microsoft.com/office/drawing/2016/5/10/chartex" xmlns:cx5="http://schemas.microsoft.com/office/drawing/2016/5/11/chartex" xmlns:cx6="http://schemas.microsoft.com/office/drawing/2016/5/12/chartex" xmlns:cx7="http://schemas.microsoft.com/office/drawing/2016/5/13/chartex" xmlns:cx8="http://schemas.microsoft.com/office/drawing/2016/5/14/chartex" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:aink="http://schemas.microsoft.com/office/drawing/2016/ink" xmlns:am3d="http://schemas.microsoft.com/office/drawing/2017/model3d" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:m="http://schemas.openxmlformats.org/officeDocument/2006/math" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:wp14="http://schemas.microsoft.com/office/word/2010/wordprocessingDrawing" xmlns:wp="http://schemas.openxmlformats.org/drawingml/2006/wordprocessingDrawing" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" xmlns:wpg="http://schemas.microsoft.com/office/word/2010/wordprocessingGroup" xmlns:wpi="http://schemas.microsoft.com/office/word/2010/wordprocessingInk" xmlns:wne="http://schemas.microsoft.com/office/word/2006/wordml" xmlns:wps="http://schemas.microsoft.com/office/word/2010/wordprocessingShape" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex wp14"><w:body>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">The crew was complete: it included a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Boots</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">&#x2014; A maker of Bonnets and Hoods&#x2014; A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Barrister</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, brought to arrange their disputes&#x2014; And a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Broker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, to value their goods.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Billiard-marker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, whose skill was immense, Might perhaps have won more than his share&#x2014; But a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Banker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, engaged at enormous expense, Had the whole of their </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-ItalicMT" w:hAnsi="TimesNewRomanPS-ItalicMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">cash </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">in his care.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was also a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Beaver</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, that paced on the deck, Or would sit making lace in the bow: And had often (the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">said) saved them from wreck, Though none of the sailors knew how.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was one who was famed for the number of things He His umbrella, his watch, all his jewels and rings, </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-BoldMT" w:hAnsi="CourierNewPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">forgot </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve"> And the clothes he had bought for the trip. when he entered the ship: He had </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-ItalicMT" w:hAnsi="CourierNewPS-ItalicMT"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">forty-two </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">With his name painted clearly on each: But, since he omitted to mention the fact, They were all left behind on the beach. boxes, all carefully packed,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">!&quot; the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">cried,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> As he landed his crew with care;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Supporting each man on the top of the tide</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> By a finger entwined in his hair.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it twice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> That alone should encourage the crew.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it thrice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> What I tell you </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">three </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">times is true.&quot;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">There was a young man of </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Madras</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Whose balls were </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">constructed </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">of brass,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">When jangled together,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">They played &#x201c;</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Stormy Weather</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&#x201d;,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="32.000000"/><w:szCs w:val="24.000000"/></w:rPr><w:t xml:space="preserve">lightning</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">shot out of his ass.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">A Python, I should not advise,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">For it needs a doctor for its eyes,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And has the Measles yearly.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">However, if </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">you feel</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> inclined</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">To get one (to improve your mind,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And not from fashion merely),</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Allow no </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">music</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> near its cage;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And when it </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">flies</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> into a rage</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Chastise it, most severely.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">I had an Aunt in Yucatan</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Who bought a Python from a man</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And kept it for a pet.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">She </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">died</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">, because she never knew</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">These simple little rules and few; &#x2014;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">The snake is living yet.</w:t></w:r>
+</w:p></w:body></w:document> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/fontTable.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/fontTable.xml
new file mode 100644
index 00000000..a39546e5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/fontTable.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:fonts xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:font w:name="Calibri"><w:panose1 w:val="020F0502020204030204"/><w:charset w:val="00"/><w:family w:val="swiss"/><w:pitch w:val="variable"/><w:sig w:usb0="E4002EFF" w:usb1="C000247B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font><w:font w:name="Times New Roman"><w:panose1 w:val="02020603050405020304"/><w:charset w:val="00"/><w:family w:val="roman"/><w:pitch w:val="variable"/><w:sig w:usb0="E0002EFF" w:usb1="C000785B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font><w:font w:name="Calibri Light"><w:panose1 w:val="020F0302020204030204"/><w:charset w:val="00"/><w:family w:val="swiss"/><w:pitch w:val="variable"/><w:sig w:usb0="E4002EFF" w:usb1="C000247B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font></w:fonts> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/settings.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/settings.xml
new file mode 100644
index 00000000..c403540d
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/settings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:settings xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:m="http://schemas.openxmlformats.org/officeDocument/2006/math" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" xmlns:sl="http://schemas.openxmlformats.org/schemaLibrary/2006/main" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:zoom w:percent="100"/><w:proofState w:spelling="clean" w:grammar="clean"/><w:defaultTabStop w:val="720"/><w:characterSpacingControl w:val="doNotCompress"/><w:compat><w:compatSetting w:name="compatibilityMode" w:uri="http://schemas.microsoft.com/office/word" w:val="15"/><w:compatSetting w:name="overrideTableStyleFontSizeAndJustification" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="enableOpenTypeFeatures" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="doNotFlipMirrorIndents" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="differentiateMultirowTableHeaders" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="useWord2013TrackBottomHyphenation" w:uri="http://schemas.microsoft.com/office/word" w:val="0"/></w:compat><w:rsids><w:rsidRoot w:val="007F4427"/><w:rsid w:val="00255448"/><w:rsid w:val="007F4427"/></w:rsids><m:mathPr><m:mathFont m:val="Cambria Math"/><m:brkBin m:val="before"/><m:brkBinSub m:val="--"/><m:smallFrac m:val="0"/><m:dispDef/><m:lMargin m:val="0"/><m:rMargin m:val="0"/><m:defJc m:val="centerGroup"/><m:wrapIndent m:val="1440"/><m:intLim m:val="subSup"/><m:naryLim m:val="undOvr"/></m:mathPr><w:themeFontLang w:val="en-GB"/><w:clrSchemeMapping w:bg1="light1" w:t1="dark1" w:bg2="light2" w:t2="dark2" w:accent1="accent1" w:accent2="accent2" w:accent3="accent3" w:accent4="accent4" w:accent5="accent5" w:accent6="accent6" w:hyperlink="hyperlink" w:followedHyperlink="followedHyperlink"/><w:shapeDefaults><o:shapedefaults v:ext="edit" spidmax="1026"/><o:shapelayout v:ext="edit"><o:idmap v:ext="edit" data="1"/></o:shapelayout></w:shapeDefaults><w:decimalSymbol w:val="."/><w:listSeparator w:val=","/><w14:docId w14:val="32E52EF8"/><w15:chartTrackingRefBased/><w15:docId w15:val="{A10F59F7-497D-44D4-A338-47719734E7A0}"/></w:settings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/styles.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/styles.xml
new file mode 100644
index 00000000..38e5e2bd
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/styles.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:styles xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:docDefaults><w:rPrDefault><w:rPr><w:rFonts w:asciiTheme="minorHAnsi" w:eastAsiaTheme="minorHAnsi" w:hAnsiTheme="minorHAnsi" w:cstheme="minorBidi"/><w:sz w:val="22"/><w:szCs w:val="22"/><w:lang w:val="en-GB" w:eastAsia="en-US" w:bidi="ar-SA"/></w:rPr></w:rPrDefault><w:pPrDefault><w:pPr><w:spacing w:after="160" w:line="259" w:lineRule="auto"/></w:pPr></w:pPrDefault></w:docDefaults><w:latentStyles w:defLockedState="0" w:defUIPriority="99" w:defSemiHidden="0" w:defUnhideWhenUsed="0" w:defQFormat="0" w:count="376"><w:lsdException w:name="Normal" w:uiPriority="0" w:qFormat="1"/><w:lsdException w:name="heading 1" w:uiPriority="9" w:qFormat="1"/><w:lsdException w:name="heading 2" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 3" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 4" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 5" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 6" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 7" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 8" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 9" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="index 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 9" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 1" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 2" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 3" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 4" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 5" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 6" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 7" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 8" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 9" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footnote text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="header" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footer" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="caption" w:semiHidden="1" w:uiPriority="35" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="table of figures" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="envelope address" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="envelope return" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footnote reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="line number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="page number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="endnote reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="endnote text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="table of authorities" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="macro" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="toa heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Title" w:uiPriority="10" w:qFormat="1"/><w:lsdException w:name="Closing" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Signature" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Default Paragraph Font" w:semiHidden="1" w:uiPriority="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Message Header" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Subtitle" w:uiPriority="11" w:qFormat="1"/><w:lsdException w:name="Salutation" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Date" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text First Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text First Indent 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Note Heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Block Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Hyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="FollowedHyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Strong" w:uiPriority="22" w:qFormat="1"/><w:lsdException w:name="Emphasis" w:uiPriority="20" w:qFormat="1"/><w:lsdException w:name="Document Map" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Plain Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="E-mail Signature" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Top of Form" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Bottom of Form" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal (Web)" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Acronym" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Address" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Cite" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Code" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Definition" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Keyboard" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Preformatted" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Sample" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Typewriter" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Variable" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal Table" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation subject" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="No List" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Contemporary" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Elegant" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Professional" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Subtle 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Subtle 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Balloon Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid" w:uiPriority="39"/><w:lsdException w:name="Table Theme" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Placeholder Text" w:semiHidden="1"/><w:lsdException w:name="No Spacing" w:uiPriority="1" w:qFormat="1"/><w:lsdException w:name="Light Shading" w:uiPriority="60"/><w:lsdException w:name="Light List" w:uiPriority="61"/><w:lsdException w:name="Light Grid" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2" w:uiPriority="64"/><w:lsdException w:name="Medium List 1" w:uiPriority="65"/><w:lsdException w:name="Medium List 2" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3" w:uiPriority="69"/><w:lsdException w:name="Dark List" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading" w:uiPriority="71"/><w:lsdException w:name="Colorful List" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 1" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 1" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 1" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 1" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 1" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 1" w:uiPriority="65"/><w:lsdException w:name="Revision" w:semiHidden="1"/><w:lsdException w:name="List Paragraph" w:uiPriority="34" w:qFormat="1"/><w:lsdException w:name="Quote" w:uiPriority="29" w:qFormat="1"/><w:lsdException w:name="Intense Quote" w:uiPriority="30" w:qFormat="1"/><w:lsdException w:name="Medium List 2 Accent 1" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 1" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 1" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 1" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 1" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 1" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 1" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 1" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 2" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 2" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 2" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 2" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 2" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 2" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 2" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 2" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 2" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 2" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 2" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 2" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 2" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 2" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 3" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 3" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 3" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 3" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 3" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 3" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 3" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 3" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 3" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 3" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 3" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 3" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 3" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 3" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 4" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 4" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 4" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 4" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 4" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 4" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 4" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 4" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 4" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 4" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 4" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 4" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 4" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 4" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 5" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 5" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 5" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 5" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 5" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 5" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 5" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 5" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 5" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 5" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 5" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 5" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 5" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 5" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 6" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 6" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 6" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 6" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 6" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 6" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 6" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 6" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 6" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 6" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 6" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 6" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 6" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 6" w:uiPriority="73"/><w:lsdException w:name="Subtle Emphasis" w:uiPriority="19" w:qFormat="1"/><w:lsdException w:name="Intense Emphasis" w:uiPriority="21" w:qFormat="1"/><w:lsdException w:name="Subtle Reference" w:uiPriority="31" w:qFormat="1"/><w:lsdException w:name="Intense Reference" w:uiPriority="32" w:qFormat="1"/><w:lsdException w:name="Book Title" w:uiPriority="33" w:qFormat="1"/><w:lsdException w:name="Bibliography" w:semiHidden="1" w:uiPriority="37" w:unhideWhenUsed="1"/><w:lsdException w:name="TOC Heading" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="Plain Table 1" w:uiPriority="41"/><w:lsdException w:name="Plain Table 2" w:uiPriority="42"/><w:lsdException w:name="Plain Table 3" w:uiPriority="43"/><w:lsdException w:name="Plain Table 4" w:uiPriority="44"/><w:lsdException w:name="Plain Table 5" w:uiPriority="45"/><w:lsdException w:name="Grid Table Light" w:uiPriority="40"/><w:lsdException w:name="Grid Table 1 Light" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 1" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 1" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 1" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 1" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 1" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 1" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 1" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 2" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 2" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 2" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 2" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 2" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 2" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 2" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 3" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 3" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 3" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 3" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 3" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 3" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 3" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 4" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 4" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 4" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 4" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 4" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 4" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 4" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 5" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 5" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 5" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 5" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 5" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 5" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 5" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 6" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 6" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 6" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 6" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 6" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 6" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 6" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light" w:uiPriority="46"/><w:lsdException w:name="List Table 2" w:uiPriority="47"/><w:lsdException w:name="List Table 3" w:uiPriority="48"/><w:lsdException w:name="List Table 4" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 1" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 1" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 1" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 1" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 1" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 1" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 1" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 2" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 2" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 2" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 2" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 2" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 2" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 2" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 3" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 3" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 3" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 3" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 3" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 3" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 3" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 4" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 4" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 4" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 4" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 4" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 4" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 4" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 5" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 5" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 5" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 5" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 5" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 5" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 5" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 6" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 6" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 6" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 6" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 6" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 6" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 6" w:uiPriority="52"/><w:lsdException w:name="Mention" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Smart Hyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Hashtag" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Unresolved Mention" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Smart Link" w:semiHidden="1" w:unhideWhenUsed="1"/></w:latentStyles><w:style w:type="paragraph" w:default="1" w:styleId="Normal"><w:name w:val="Normal"/><w:qFormat/></w:style><w:style w:type="character" w:default="1" w:styleId="DefaultParagraphFont"><w:name w:val="Default Paragraph Font"/><w:uiPriority w:val="1"/><w:semiHidden/><w:unhideWhenUsed/></w:style><w:style w:type="table" w:default="1" w:styleId="TableNormal"><w:name w:val="Normal Table"/><w:uiPriority w:val="99"/><w:semiHidden/><w:unhideWhenUsed/><w:tblPr><w:tblInd w:w="0" w:type="dxa"/><w:tblCellMar><w:top w:w="0" w:type="dxa"/><w:left w:w="108" w:type="dxa"/><w:bottom w:w="0" w:type="dxa"/><w:right w:w="108" w:type="dxa"/></w:tblCellMar></w:tblPr></w:style><w:style w:type="numbering" w:default="1" w:styleId="NoList"><w:name w:val="No List"/><w:uiPriority w:val="99"/><w:semiHidden/><w:unhideWhenUsed/></w:style></w:styles> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/theme/theme1.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/theme/theme1.xml
new file mode 100644
index 00000000..d1a502f8
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/theme/theme1.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<a:theme xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main" name="Office Theme"><a:themeElements><a:clrScheme name="Office"><a:dk1><a:sysClr val="windowText" lastClr="000000"/></a:dk1><a:lt1><a:sysClr val="window" lastClr="FFFFFF"/></a:lt1><a:dk2><a:srgbClr val="44546A"/></a:dk2><a:lt2><a:srgbClr val="E7E6E6"/></a:lt2><a:accent1><a:srgbClr val="4472C4"/></a:accent1><a:accent2><a:srgbClr val="ED7D31"/></a:accent2><a:accent3><a:srgbClr val="A5A5A5"/></a:accent3><a:accent4><a:srgbClr val="FFC000"/></a:accent4><a:accent5><a:srgbClr val="5B9BD5"/></a:accent5><a:accent6><a:srgbClr val="70AD47"/></a:accent6><a:hlink><a:srgbClr val="0563C1"/></a:hlink><a:folHlink><a:srgbClr val="954F72"/></a:folHlink></a:clrScheme><a:fontScheme name="Office"><a:majorFont><a:latin typeface="Calibri Light" panose="020F0302020204030204"/><a:ea typeface=""/><a:cs typeface=""/><a:font script="Jpan" typeface="游ゴシック Light"/><a:font script="Hang" typeface="맑은 고딕"/><a:font script="Hans" typeface="等线 Light"/><a:font script="Hant" typeface="新細明體"/><a:font script="Arab" typeface="Times New Roman"/><a:font script="Hebr" typeface="Times New Roman"/><a:font script="Thai" typeface="Angsana New"/><a:font script="Ethi" typeface="Nyala"/><a:font script="Beng" typeface="Vrinda"/><a:font script="Gujr" typeface="Shruti"/><a:font script="Khmr" typeface="MoolBoran"/><a:font script="Knda" typeface="Tunga"/><a:font script="Guru" typeface="Raavi"/><a:font script="Cans" typeface="Euphemia"/><a:font script="Cher" typeface="Plantagenet Cherokee"/><a:font script="Yiii" typeface="Microsoft Yi Baiti"/><a:font script="Tibt" typeface="Microsoft Himalaya"/><a:font script="Thaa" typeface="MV Boli"/><a:font script="Deva" typeface="Mangal"/><a:font script="Telu" typeface="Gautami"/><a:font script="Taml" typeface="Latha"/><a:font script="Syrc" typeface="Estrangelo Edessa"/><a:font script="Orya" typeface="Kalinga"/><a:font script="Mlym" typeface="Kartika"/><a:font script="Laoo" typeface="DokChampa"/><a:font script="Sinh" typeface="Iskoola Pota"/><a:font script="Mong" typeface="Mongolian Baiti"/><a:font script="Viet" typeface="Times New Roman"/><a:font script="Uigh" typeface="Microsoft Uighur"/><a:font script="Geor" typeface="Sylfaen"/><a:font script="Armn" typeface="Arial"/><a:font script="Bugi" typeface="Leelawadee UI"/><a:font script="Bopo" typeface="Microsoft JhengHei"/><a:font script="Java" typeface="Javanese Text"/><a:font script="Lisu" typeface="Segoe UI"/><a:font script="Mymr" typeface="Myanmar Text"/><a:font script="Nkoo" typeface="Ebrima"/><a:font script="Olck" typeface="Nirmala UI"/><a:font script="Osma" typeface="Ebrima"/><a:font script="Phag" typeface="Phagspa"/><a:font script="Syrn" typeface="Estrangelo Edessa"/><a:font script="Syrj" typeface="Estrangelo Edessa"/><a:font script="Syre" typeface="Estrangelo Edessa"/><a:font script="Sora" typeface="Nirmala UI"/><a:font script="Tale" typeface="Microsoft Tai Le"/><a:font script="Talu" typeface="Microsoft New Tai Lue"/><a:font script="Tfng" typeface="Ebrima"/></a:majorFont><a:minorFont><a:latin typeface="Calibri" panose="020F0502020204030204"/><a:ea typeface=""/><a:cs typeface=""/><a:font script="Jpan" typeface="游明朝"/><a:font script="Hang" typeface="맑은 고딕"/><a:font script="Hans" typeface="等线"/><a:font script="Hant" typeface="新細明體"/><a:font script="Arab" typeface="Arial"/><a:font script="Hebr" typeface="Arial"/><a:font script="Thai" typeface="Cordia New"/><a:font script="Ethi" typeface="Nyala"/><a:font script="Beng" typeface="Vrinda"/><a:font script="Gujr" typeface="Shruti"/><a:font script="Khmr" typeface="DaunPenh"/><a:font script="Knda" typeface="Tunga"/><a:font script="Guru" typeface="Raavi"/><a:font script="Cans" typeface="Euphemia"/><a:font script="Cher" typeface="Plantagenet Cherokee"/><a:font script="Yiii" typeface="Microsoft Yi Baiti"/><a:font script="Tibt" typeface="Microsoft Himalaya"/><a:font script="Thaa" typeface="MV Boli"/><a:font script="Deva" typeface="Mangal"/><a:font script="Telu" typeface="Gautami"/><a:font script="Taml" typeface="Latha"/><a:font script="Syrc" typeface="Estrangelo Edessa"/><a:font script="Orya" typeface="Kalinga"/><a:font script="Mlym" typeface="Kartika"/><a:font script="Laoo" typeface="DokChampa"/><a:font script="Sinh" typeface="Iskoola Pota"/><a:font script="Mong" typeface="Mongolian Baiti"/><a:font script="Viet" typeface="Arial"/><a:font script="Uigh" typeface="Microsoft Uighur"/><a:font script="Geor" typeface="Sylfaen"/><a:font script="Armn" typeface="Arial"/><a:font script="Bugi" typeface="Leelawadee UI"/><a:font script="Bopo" typeface="Microsoft JhengHei"/><a:font script="Java" typeface="Javanese Text"/><a:font script="Lisu" typeface="Segoe UI"/><a:font script="Mymr" typeface="Myanmar Text"/><a:font script="Nkoo" typeface="Ebrima"/><a:font script="Olck" typeface="Nirmala UI"/><a:font script="Osma" typeface="Ebrima"/><a:font script="Phag" typeface="Phagspa"/><a:font script="Syrn" typeface="Estrangelo Edessa"/><a:font script="Syrj" typeface="Estrangelo Edessa"/><a:font script="Syre" typeface="Estrangelo Edessa"/><a:font script="Sora" typeface="Nirmala UI"/><a:font script="Tale" typeface="Microsoft Tai Le"/><a:font script="Talu" typeface="Microsoft New Tai Lue"/><a:font script="Tfng" typeface="Ebrima"/></a:minorFont></a:fontScheme><a:fmtScheme name="Office"><a:fillStyleLst><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:lumMod val="110000"/><a:satMod val="105000"/><a:tint val="67000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:lumMod val="105000"/><a:satMod val="103000"/><a:tint val="73000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:lumMod val="105000"/><a:satMod val="109000"/><a:tint val="81000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:satMod val="103000"/><a:lumMod val="102000"/><a:tint val="94000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:satMod val="110000"/><a:lumMod val="100000"/><a:shade val="100000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:lumMod val="99000"/><a:satMod val="120000"/><a:shade val="78000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill></a:fillStyleLst><a:lnStyleLst><a:ln w="6350" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln><a:ln w="12700" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln><a:ln w="19050" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln></a:lnStyleLst><a:effectStyleLst><a:effectStyle><a:effectLst/></a:effectStyle><a:effectStyle><a:effectLst/></a:effectStyle><a:effectStyle><a:effectLst><a:outerShdw blurRad="57150" dist="19050" dir="5400000" algn="ctr" rotWithShape="0"><a:srgbClr val="000000"><a:alpha val="63000"/></a:srgbClr></a:outerShdw></a:effectLst></a:effectStyle></a:effectStyleLst><a:bgFillStyleLst><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:solidFill><a:schemeClr val="phClr"><a:tint val="95000"/><a:satMod val="170000"/></a:schemeClr></a:solidFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:tint val="93000"/><a:satMod val="150000"/><a:shade val="98000"/><a:lumMod val="102000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:tint val="98000"/><a:satMod val="130000"/><a:shade val="90000"/><a:lumMod val="103000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:shade val="63000"/><a:satMod val="120000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill></a:bgFillStyleLst></a:fmtScheme></a:themeElements><a:objectDefaults/><a:extraClrSchemeLst/><a:extLst><a:ext uri="{05A4C25C-085E-4340-85A3-A5531E510DB2}"><thm15:themeFamily xmlns:thm15="http://schemas.microsoft.com/office/thememl/2012/main" name="Office Theme" id="{62F939B6-93AF-4DB8-9C6B-D6C7DFDC589F}" vid="{4A3C46E8-61CC-4603-A589-7422A47A8E4A}"/></a:ext></a:extLst></a:theme> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/webSettings.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/webSettings.xml
new file mode 100644
index 00000000..629ae06a
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-autosplit.docx.dir.ref/word/webSettings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:webSettings xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:optimizeForBrowser/><w:allowPNG/></w:webSettings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/[Content_Types].xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/[Content_Types].xml
new file mode 100644
index 00000000..07d88cca
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/[Content_Types].xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Types xmlns="http://schemas.openxmlformats.org/package/2006/content-types"><Default Extension="rels" ContentType="application/vnd.openxmlformats-package.relationships+xml"/><Default Extension="xml" ContentType="application/xml"/><Override PartName="/word/document.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.document.main+xml"/><Override PartName="/word/styles.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.styles+xml"/><Override PartName="/word/settings.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.settings+xml"/><Override PartName="/word/webSettings.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.webSettings+xml"/><Override PartName="/word/fontTable.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.fontTable+xml"/><Override PartName="/word/theme/theme1.xml" ContentType="application/vnd.openxmlformats-officedocument.theme+xml"/><Override PartName="/docProps/core.xml" ContentType="application/vnd.openxmlformats-package.core-properties+xml"/><Override PartName="/docProps/app.xml" ContentType="application/vnd.openxmlformats-officedocument.extended-properties+xml"/></Types> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/_rels/.rels b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/_rels/.rels
new file mode 100644
index 00000000..32548d42
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/_rels/.rels
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/extended-properties" Target="docProps/app.xml"/><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/package/2006/relationships/metadata/core-properties" Target="docProps/core.xml"/><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument" Target="word/document.xml"/></Relationships> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/docProps/app.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/docProps/app.xml
new file mode 100644
index 00000000..eb8dd2e5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/docProps/app.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Properties xmlns="http://schemas.openxmlformats.org/officeDocument/2006/extended-properties" xmlns:vt="http://schemas.openxmlformats.org/officeDocument/2006/docPropsVTypes"><Template>Normal.dotm</Template><TotalTime>3</TotalTime><Pages>1</Pages><Words>2</Words><Characters>18</Characters><Application>Microsoft Office Word</Application><DocSecurity>0</DocSecurity><Lines>1</Lines><Paragraphs>1</Paragraphs><ScaleCrop>false</ScaleCrop><Company></Company><LinksUpToDate>false</LinksUpToDate><CharactersWithSpaces>19</CharactersWithSpaces><SharedDoc>false</SharedDoc><HyperlinksChanged>false</HyperlinksChanged><AppVersion>16.0000</AppVersion></Properties> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/docProps/core.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/docProps/core.xml
new file mode 100644
index 00000000..195d77a9
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/docProps/core.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<cp:coreProperties xmlns:cp="http://schemas.openxmlformats.org/package/2006/metadata/core-properties" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:dcterms="http://purl.org/dc/terms/" xmlns:dcmitype="http://purl.org/dc/dcmitype/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><dc:title></dc:title><dc:subject></dc:subject><dc:creator></dc:creator><cp:keywords></cp:keywords><dc:description></dc:description><cp:lastModifiedBy></cp:lastModifiedBy><cp:revision>1</cp:revision><dcterms:created xsi:type="dcterms:W3CDTF">2020-09-25T17:04:00Z</dcterms:created><dcterms:modified xsi:type="dcterms:W3CDTF">2020-09-25T17:07:00Z</dcterms:modified></cp:coreProperties> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/_rels/document.xml.rels b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/_rels/document.xml.rels
new file mode 100644
index 00000000..3b2b7f8c
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/_rels/document.xml.rels
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/webSettings" Target="webSettings.xml"/><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/settings" Target="settings.xml"/><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles" Target="styles.xml"/><Relationship Id="rId5" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme" Target="theme/theme1.xml"/><Relationship Id="rId4" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/fontTable" Target="fontTable.xml"/></Relationships> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/document.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/document.xml
new file mode 100644
index 00000000..115e84f5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/document.xml
@@ -0,0 +1,718 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:document xmlns:wpc="http://schemas.microsoft.com/office/word/2010/wordprocessingCanvas" xmlns:cx="http://schemas.microsoft.com/office/drawing/2014/chartex" xmlns:cx1="http://schemas.microsoft.com/office/drawing/2015/9/8/chartex" xmlns:cx2="http://schemas.microsoft.com/office/drawing/2015/10/21/chartex" xmlns:cx3="http://schemas.microsoft.com/office/drawing/2016/5/9/chartex" xmlns:cx4="http://schemas.microsoft.com/office/drawing/2016/5/10/chartex" xmlns:cx5="http://schemas.microsoft.com/office/drawing/2016/5/11/chartex" xmlns:cx6="http://schemas.microsoft.com/office/drawing/2016/5/12/chartex" xmlns:cx7="http://schemas.microsoft.com/office/drawing/2016/5/13/chartex" xmlns:cx8="http://schemas.microsoft.com/office/drawing/2016/5/14/chartex" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:aink="http://schemas.microsoft.com/office/drawing/2016/ink" xmlns:am3d="http://schemas.microsoft.com/office/drawing/2017/model3d" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:m="http://schemas.openxmlformats.org/officeDocument/2006/math" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:wp14="http://schemas.microsoft.com/office/word/2010/wordprocessingDrawing" xmlns:wp="http://schemas.openxmlformats.org/drawingml/2006/wordprocessingDrawing" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" xmlns:wpg="http://schemas.microsoft.com/office/word/2010/wordprocessingGroup" xmlns:wpi="http://schemas.microsoft.com/office/word/2010/wordprocessingInk" xmlns:wne="http://schemas.microsoft.com/office/word/2006/wordml" xmlns:wps="http://schemas.microsoft.com/office/word/2010/wordprocessingShape" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex wp14"><w:body>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>781084</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>2030770</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2190257" cy="2819346"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="1" name="Text Box 1"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="-8517153">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">The crew was complete: it included a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Boots</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">&#x2014; A maker of Bonnets and Hoods&#x2014; A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Barrister</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, brought to arrange their disputes&#x2014; And a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Broker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, to value their goods.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Billiard-marker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, whose skill was immense, Might perhaps have won more than his share&#x2014; But a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Banker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, engaged at enormous expense, Had the whole of their </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-ItalicMT" w:hAnsi="TimesNewRomanPS-ItalicMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">cash </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">in his care.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was also a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Beaver</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, that paced on the deck, Or would sit making lace in the bow: And had often (the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">said) saved them from wreck, Though none of the sailors knew how.</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 1" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">The crew was complete: it included a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Boots</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">&#x2014; A maker of Bonnets and Hoods&#x2014; A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Barrister</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, brought to arrange their disputes&#x2014; And a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Broker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, to value their goods.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Billiard-marker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, whose skill was immense, Might perhaps have won more than his share&#x2014; But a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Banker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, engaged at enormous expense, Had the whole of their </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-ItalicMT" w:hAnsi="TimesNewRomanPS-ItalicMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">cash </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">in his care.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was also a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Beaver</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, that paced on the deck, Or would sit making lace in the bow: And had often (the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">said) saved them from wreck, Though none of the sailors knew how.</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>1630060</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>825686</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="4204294" cy="5742838"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="2" name="Text Box 2"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="10470860">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was one who was famed for the number of things He His umbrella, his watch, all his jewels and rings, </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-BoldMT" w:hAnsi="CourierNewPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">forgot </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve"> And the clothes he had bought for the trip. when he entered the ship: He had </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-ItalicMT" w:hAnsi="CourierNewPS-ItalicMT"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">forty-two </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">With his name painted clearly on each: But, since he omitted to mention the fact, They were all left behind on the beach. boxes, all carefully packed,</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 2" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was one who was famed for the number of things He His umbrella, his watch, all his jewels and rings, </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-BoldMT" w:hAnsi="CourierNewPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">forgot </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve"> And the clothes he had bought for the trip. when he entered the ship: He had </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-ItalicMT" w:hAnsi="CourierNewPS-ItalicMT"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">forty-two </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">With his name painted clearly on each: But, since he omitted to mention the fact, They were all left behind on the beach. boxes, all carefully packed,</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>3428887</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>1311322</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2856668" cy="3710084"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="3" name="Text Box 3"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="6130097">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">!&quot; the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">cried,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> As he landed his crew with care;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Supporting each man on the top of the tide</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> By a finger entwined in his hair.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it twice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> That alone should encourage the crew.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it thrice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> What I tell you </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">three </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">times is true.&quot;</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 3" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">!&quot; the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">cried,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> As he landed his crew with care;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Supporting each man on the top of the tide</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> By a finger entwined in his hair.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it twice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> That alone should encourage the crew.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it thrice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> What I tell you </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">three </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">times is true.&quot;</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>4205387</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>52893</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2309037" cy="1989180"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="4" name="Text Box 4"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="1991925">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">There was a young man of </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Madras</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Whose balls were </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">constructed </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">of brass,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">When jangled together,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">They played &#x201c;</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Stormy Weather</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&#x201d;,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="32.000000"/><w:szCs w:val="24.000000"/></w:rPr><w:t xml:space="preserve">lightning</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">shot out of his ass.</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 4" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">There was a young man of </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Madras</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Whose balls were </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">constructed </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">of brass,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">When jangled together,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">They played &#x201c;</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Stormy Weather</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&#x201d;,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="32.000000"/><w:szCs w:val="24.000000"/></w:rPr><w:t xml:space="preserve">lightning</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">shot out of his ass.</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>1670565</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>-464151</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2090264" cy="5976830"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="5" name="Text Box 5"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="-1645561">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">A Python, I should not advise,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">For it needs a doctor for its eyes,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And has the Measles yearly.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">However, if </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">you feel</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> inclined</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">To get one (to improve your mind,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And not from fashion merely),</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Allow no </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">music</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> near its cage;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And when it </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">flies</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> into a rage</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Chastise it, most severely.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">I had an Aunt in Yucatan</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Who bought a Python from a man</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And kept it for a pet.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">She </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">died</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">, because she never knew</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">These simple little rules and few; &#x2014;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">The snake is living yet.</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 5" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">A Python, I should not advise,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">For it needs a doctor for its eyes,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And has the Measles yearly.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">However, if </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">you feel</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> inclined</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">To get one (to improve your mind,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And not from fashion merely),</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Allow no </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">music</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> near its cage;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And when it </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">flies</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> into a rage</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Chastise it, most severely.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">I had an Aunt in Yucatan</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Who bought a Python from a man</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And kept it for a pet.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">She </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">died</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">, because she never knew</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">These simple little rules and few; &#x2014;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">The snake is living yet.</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p></w:body></w:document> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/fontTable.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/fontTable.xml
new file mode 100644
index 00000000..a39546e5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/fontTable.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:fonts xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:font w:name="Calibri"><w:panose1 w:val="020F0502020204030204"/><w:charset w:val="00"/><w:family w:val="swiss"/><w:pitch w:val="variable"/><w:sig w:usb0="E4002EFF" w:usb1="C000247B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font><w:font w:name="Times New Roman"><w:panose1 w:val="02020603050405020304"/><w:charset w:val="00"/><w:family w:val="roman"/><w:pitch w:val="variable"/><w:sig w:usb0="E0002EFF" w:usb1="C000785B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font><w:font w:name="Calibri Light"><w:panose1 w:val="020F0302020204030204"/><w:charset w:val="00"/><w:family w:val="swiss"/><w:pitch w:val="variable"/><w:sig w:usb0="E4002EFF" w:usb1="C000247B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font></w:fonts> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/settings.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/settings.xml
new file mode 100644
index 00000000..c403540d
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/settings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:settings xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:m="http://schemas.openxmlformats.org/officeDocument/2006/math" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" xmlns:sl="http://schemas.openxmlformats.org/schemaLibrary/2006/main" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:zoom w:percent="100"/><w:proofState w:spelling="clean" w:grammar="clean"/><w:defaultTabStop w:val="720"/><w:characterSpacingControl w:val="doNotCompress"/><w:compat><w:compatSetting w:name="compatibilityMode" w:uri="http://schemas.microsoft.com/office/word" w:val="15"/><w:compatSetting w:name="overrideTableStyleFontSizeAndJustification" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="enableOpenTypeFeatures" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="doNotFlipMirrorIndents" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="differentiateMultirowTableHeaders" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="useWord2013TrackBottomHyphenation" w:uri="http://schemas.microsoft.com/office/word" w:val="0"/></w:compat><w:rsids><w:rsidRoot w:val="007F4427"/><w:rsid w:val="00255448"/><w:rsid w:val="007F4427"/></w:rsids><m:mathPr><m:mathFont m:val="Cambria Math"/><m:brkBin m:val="before"/><m:brkBinSub m:val="--"/><m:smallFrac m:val="0"/><m:dispDef/><m:lMargin m:val="0"/><m:rMargin m:val="0"/><m:defJc m:val="centerGroup"/><m:wrapIndent m:val="1440"/><m:intLim m:val="subSup"/><m:naryLim m:val="undOvr"/></m:mathPr><w:themeFontLang w:val="en-GB"/><w:clrSchemeMapping w:bg1="light1" w:t1="dark1" w:bg2="light2" w:t2="dark2" w:accent1="accent1" w:accent2="accent2" w:accent3="accent3" w:accent4="accent4" w:accent5="accent5" w:accent6="accent6" w:hyperlink="hyperlink" w:followedHyperlink="followedHyperlink"/><w:shapeDefaults><o:shapedefaults v:ext="edit" spidmax="1026"/><o:shapelayout v:ext="edit"><o:idmap v:ext="edit" data="1"/></o:shapelayout></w:shapeDefaults><w:decimalSymbol w:val="."/><w:listSeparator w:val=","/><w14:docId w14:val="32E52EF8"/><w15:chartTrackingRefBased/><w15:docId w15:val="{A10F59F7-497D-44D4-A338-47719734E7A0}"/></w:settings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/styles.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/styles.xml
new file mode 100644
index 00000000..38e5e2bd
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/styles.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:styles xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:docDefaults><w:rPrDefault><w:rPr><w:rFonts w:asciiTheme="minorHAnsi" w:eastAsiaTheme="minorHAnsi" w:hAnsiTheme="minorHAnsi" w:cstheme="minorBidi"/><w:sz w:val="22"/><w:szCs w:val="22"/><w:lang w:val="en-GB" w:eastAsia="en-US" w:bidi="ar-SA"/></w:rPr></w:rPrDefault><w:pPrDefault><w:pPr><w:spacing w:after="160" w:line="259" w:lineRule="auto"/></w:pPr></w:pPrDefault></w:docDefaults><w:latentStyles w:defLockedState="0" w:defUIPriority="99" w:defSemiHidden="0" w:defUnhideWhenUsed="0" w:defQFormat="0" w:count="376"><w:lsdException w:name="Normal" w:uiPriority="0" w:qFormat="1"/><w:lsdException w:name="heading 1" w:uiPriority="9" w:qFormat="1"/><w:lsdException w:name="heading 2" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 3" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 4" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 5" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 6" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 7" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 8" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 9" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="index 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 9" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 1" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 2" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 3" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 4" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 5" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 6" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 7" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 8" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 9" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footnote text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="header" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footer" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="caption" w:semiHidden="1" w:uiPriority="35" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="table of figures" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="envelope address" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="envelope return" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footnote reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="line number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="page number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="endnote reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="endnote text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="table of authorities" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="macro" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="toa heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Title" w:uiPriority="10" w:qFormat="1"/><w:lsdException w:name="Closing" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Signature" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Default Paragraph Font" w:semiHidden="1" w:uiPriority="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Message Header" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Subtitle" w:uiPriority="11" w:qFormat="1"/><w:lsdException w:name="Salutation" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Date" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text First Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text First Indent 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Note Heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Block Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Hyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="FollowedHyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Strong" w:uiPriority="22" w:qFormat="1"/><w:lsdException w:name="Emphasis" w:uiPriority="20" w:qFormat="1"/><w:lsdException w:name="Document Map" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Plain Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="E-mail Signature" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Top of Form" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Bottom of Form" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal (Web)" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Acronym" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Address" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Cite" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Code" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Definition" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Keyboard" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Preformatted" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Sample" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Typewriter" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Variable" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal Table" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation subject" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="No List" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Contemporary" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Elegant" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Professional" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Subtle 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Subtle 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Balloon Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid" w:uiPriority="39"/><w:lsdException w:name="Table Theme" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Placeholder Text" w:semiHidden="1"/><w:lsdException w:name="No Spacing" w:uiPriority="1" w:qFormat="1"/><w:lsdException w:name="Light Shading" w:uiPriority="60"/><w:lsdException w:name="Light List" w:uiPriority="61"/><w:lsdException w:name="Light Grid" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2" w:uiPriority="64"/><w:lsdException w:name="Medium List 1" w:uiPriority="65"/><w:lsdException w:name="Medium List 2" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3" w:uiPriority="69"/><w:lsdException w:name="Dark List" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading" w:uiPriority="71"/><w:lsdException w:name="Colorful List" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 1" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 1" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 1" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 1" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 1" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 1" w:uiPriority="65"/><w:lsdException w:name="Revision" w:semiHidden="1"/><w:lsdException w:name="List Paragraph" w:uiPriority="34" w:qFormat="1"/><w:lsdException w:name="Quote" w:uiPriority="29" w:qFormat="1"/><w:lsdException w:name="Intense Quote" w:uiPriority="30" w:qFormat="1"/><w:lsdException w:name="Medium List 2 Accent 1" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 1" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 1" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 1" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 1" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 1" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 1" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 1" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 2" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 2" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 2" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 2" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 2" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 2" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 2" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 2" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 2" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 2" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 2" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 2" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 2" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 2" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 3" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 3" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 3" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 3" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 3" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 3" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 3" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 3" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 3" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 3" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 3" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 3" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 3" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 3" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 4" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 4" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 4" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 4" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 4" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 4" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 4" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 4" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 4" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 4" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 4" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 4" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 4" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 4" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 5" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 5" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 5" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 5" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 5" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 5" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 5" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 5" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 5" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 5" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 5" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 5" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 5" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 5" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 6" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 6" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 6" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 6" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 6" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 6" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 6" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 6" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 6" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 6" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 6" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 6" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 6" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 6" w:uiPriority="73"/><w:lsdException w:name="Subtle Emphasis" w:uiPriority="19" w:qFormat="1"/><w:lsdException w:name="Intense Emphasis" w:uiPriority="21" w:qFormat="1"/><w:lsdException w:name="Subtle Reference" w:uiPriority="31" w:qFormat="1"/><w:lsdException w:name="Intense Reference" w:uiPriority="32" w:qFormat="1"/><w:lsdException w:name="Book Title" w:uiPriority="33" w:qFormat="1"/><w:lsdException w:name="Bibliography" w:semiHidden="1" w:uiPriority="37" w:unhideWhenUsed="1"/><w:lsdException w:name="TOC Heading" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="Plain Table 1" w:uiPriority="41"/><w:lsdException w:name="Plain Table 2" w:uiPriority="42"/><w:lsdException w:name="Plain Table 3" w:uiPriority="43"/><w:lsdException w:name="Plain Table 4" w:uiPriority="44"/><w:lsdException w:name="Plain Table 5" w:uiPriority="45"/><w:lsdException w:name="Grid Table Light" w:uiPriority="40"/><w:lsdException w:name="Grid Table 1 Light" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 1" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 1" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 1" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 1" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 1" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 1" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 1" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 2" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 2" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 2" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 2" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 2" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 2" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 2" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 3" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 3" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 3" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 3" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 3" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 3" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 3" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 4" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 4" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 4" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 4" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 4" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 4" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 4" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 5" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 5" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 5" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 5" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 5" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 5" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 5" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 6" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 6" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 6" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 6" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 6" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 6" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 6" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light" w:uiPriority="46"/><w:lsdException w:name="List Table 2" w:uiPriority="47"/><w:lsdException w:name="List Table 3" w:uiPriority="48"/><w:lsdException w:name="List Table 4" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 1" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 1" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 1" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 1" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 1" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 1" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 1" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 2" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 2" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 2" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 2" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 2" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 2" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 2" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 3" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 3" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 3" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 3" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 3" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 3" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 3" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 4" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 4" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 4" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 4" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 4" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 4" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 4" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 5" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 5" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 5" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 5" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 5" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 5" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 5" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 6" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 6" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 6" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 6" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 6" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 6" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 6" w:uiPriority="52"/><w:lsdException w:name="Mention" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Smart Hyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Hashtag" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Unresolved Mention" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Smart Link" w:semiHidden="1" w:unhideWhenUsed="1"/></w:latentStyles><w:style w:type="paragraph" w:default="1" w:styleId="Normal"><w:name w:val="Normal"/><w:qFormat/></w:style><w:style w:type="character" w:default="1" w:styleId="DefaultParagraphFont"><w:name w:val="Default Paragraph Font"/><w:uiPriority w:val="1"/><w:semiHidden/><w:unhideWhenUsed/></w:style><w:style w:type="table" w:default="1" w:styleId="TableNormal"><w:name w:val="Normal Table"/><w:uiPriority w:val="99"/><w:semiHidden/><w:unhideWhenUsed/><w:tblPr><w:tblInd w:w="0" w:type="dxa"/><w:tblCellMar><w:top w:w="0" w:type="dxa"/><w:left w:w="108" w:type="dxa"/><w:bottom w:w="0" w:type="dxa"/><w:right w:w="108" w:type="dxa"/></w:tblCellMar></w:tblPr></w:style><w:style w:type="numbering" w:default="1" w:styleId="NoList"><w:name w:val="No List"/><w:uiPriority w:val="99"/><w:semiHidden/><w:unhideWhenUsed/></w:style></w:styles> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/theme/theme1.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/theme/theme1.xml
new file mode 100644
index 00000000..d1a502f8
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/theme/theme1.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<a:theme xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main" name="Office Theme"><a:themeElements><a:clrScheme name="Office"><a:dk1><a:sysClr val="windowText" lastClr="000000"/></a:dk1><a:lt1><a:sysClr val="window" lastClr="FFFFFF"/></a:lt1><a:dk2><a:srgbClr val="44546A"/></a:dk2><a:lt2><a:srgbClr val="E7E6E6"/></a:lt2><a:accent1><a:srgbClr val="4472C4"/></a:accent1><a:accent2><a:srgbClr val="ED7D31"/></a:accent2><a:accent3><a:srgbClr val="A5A5A5"/></a:accent3><a:accent4><a:srgbClr val="FFC000"/></a:accent4><a:accent5><a:srgbClr val="5B9BD5"/></a:accent5><a:accent6><a:srgbClr val="70AD47"/></a:accent6><a:hlink><a:srgbClr val="0563C1"/></a:hlink><a:folHlink><a:srgbClr val="954F72"/></a:folHlink></a:clrScheme><a:fontScheme name="Office"><a:majorFont><a:latin typeface="Calibri Light" panose="020F0302020204030204"/><a:ea typeface=""/><a:cs typeface=""/><a:font script="Jpan" typeface="游ゴシック Light"/><a:font script="Hang" typeface="맑은 고딕"/><a:font script="Hans" typeface="等线 Light"/><a:font script="Hant" typeface="新細明體"/><a:font script="Arab" typeface="Times New Roman"/><a:font script="Hebr" typeface="Times New Roman"/><a:font script="Thai" typeface="Angsana New"/><a:font script="Ethi" typeface="Nyala"/><a:font script="Beng" typeface="Vrinda"/><a:font script="Gujr" typeface="Shruti"/><a:font script="Khmr" typeface="MoolBoran"/><a:font script="Knda" typeface="Tunga"/><a:font script="Guru" typeface="Raavi"/><a:font script="Cans" typeface="Euphemia"/><a:font script="Cher" typeface="Plantagenet Cherokee"/><a:font script="Yiii" typeface="Microsoft Yi Baiti"/><a:font script="Tibt" typeface="Microsoft Himalaya"/><a:font script="Thaa" typeface="MV Boli"/><a:font script="Deva" typeface="Mangal"/><a:font script="Telu" typeface="Gautami"/><a:font script="Taml" typeface="Latha"/><a:font script="Syrc" typeface="Estrangelo Edessa"/><a:font script="Orya" typeface="Kalinga"/><a:font script="Mlym" typeface="Kartika"/><a:font script="Laoo" typeface="DokChampa"/><a:font script="Sinh" typeface="Iskoola Pota"/><a:font script="Mong" typeface="Mongolian Baiti"/><a:font script="Viet" typeface="Times New Roman"/><a:font script="Uigh" typeface="Microsoft Uighur"/><a:font script="Geor" typeface="Sylfaen"/><a:font script="Armn" typeface="Arial"/><a:font script="Bugi" typeface="Leelawadee UI"/><a:font script="Bopo" typeface="Microsoft JhengHei"/><a:font script="Java" typeface="Javanese Text"/><a:font script="Lisu" typeface="Segoe UI"/><a:font script="Mymr" typeface="Myanmar Text"/><a:font script="Nkoo" typeface="Ebrima"/><a:font script="Olck" typeface="Nirmala UI"/><a:font script="Osma" typeface="Ebrima"/><a:font script="Phag" typeface="Phagspa"/><a:font script="Syrn" typeface="Estrangelo Edessa"/><a:font script="Syrj" typeface="Estrangelo Edessa"/><a:font script="Syre" typeface="Estrangelo Edessa"/><a:font script="Sora" typeface="Nirmala UI"/><a:font script="Tale" typeface="Microsoft Tai Le"/><a:font script="Talu" typeface="Microsoft New Tai Lue"/><a:font script="Tfng" typeface="Ebrima"/></a:majorFont><a:minorFont><a:latin typeface="Calibri" panose="020F0502020204030204"/><a:ea typeface=""/><a:cs typeface=""/><a:font script="Jpan" typeface="游明朝"/><a:font script="Hang" typeface="맑은 고딕"/><a:font script="Hans" typeface="等线"/><a:font script="Hant" typeface="新細明體"/><a:font script="Arab" typeface="Arial"/><a:font script="Hebr" typeface="Arial"/><a:font script="Thai" typeface="Cordia New"/><a:font script="Ethi" typeface="Nyala"/><a:font script="Beng" typeface="Vrinda"/><a:font script="Gujr" typeface="Shruti"/><a:font script="Khmr" typeface="DaunPenh"/><a:font script="Knda" typeface="Tunga"/><a:font script="Guru" typeface="Raavi"/><a:font script="Cans" typeface="Euphemia"/><a:font script="Cher" typeface="Plantagenet Cherokee"/><a:font script="Yiii" typeface="Microsoft Yi Baiti"/><a:font script="Tibt" typeface="Microsoft Himalaya"/><a:font script="Thaa" typeface="MV Boli"/><a:font script="Deva" typeface="Mangal"/><a:font script="Telu" typeface="Gautami"/><a:font script="Taml" typeface="Latha"/><a:font script="Syrc" typeface="Estrangelo Edessa"/><a:font script="Orya" typeface="Kalinga"/><a:font script="Mlym" typeface="Kartika"/><a:font script="Laoo" typeface="DokChampa"/><a:font script="Sinh" typeface="Iskoola Pota"/><a:font script="Mong" typeface="Mongolian Baiti"/><a:font script="Viet" typeface="Arial"/><a:font script="Uigh" typeface="Microsoft Uighur"/><a:font script="Geor" typeface="Sylfaen"/><a:font script="Armn" typeface="Arial"/><a:font script="Bugi" typeface="Leelawadee UI"/><a:font script="Bopo" typeface="Microsoft JhengHei"/><a:font script="Java" typeface="Javanese Text"/><a:font script="Lisu" typeface="Segoe UI"/><a:font script="Mymr" typeface="Myanmar Text"/><a:font script="Nkoo" typeface="Ebrima"/><a:font script="Olck" typeface="Nirmala UI"/><a:font script="Osma" typeface="Ebrima"/><a:font script="Phag" typeface="Phagspa"/><a:font script="Syrn" typeface="Estrangelo Edessa"/><a:font script="Syrj" typeface="Estrangelo Edessa"/><a:font script="Syre" typeface="Estrangelo Edessa"/><a:font script="Sora" typeface="Nirmala UI"/><a:font script="Tale" typeface="Microsoft Tai Le"/><a:font script="Talu" typeface="Microsoft New Tai Lue"/><a:font script="Tfng" typeface="Ebrima"/></a:minorFont></a:fontScheme><a:fmtScheme name="Office"><a:fillStyleLst><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:lumMod val="110000"/><a:satMod val="105000"/><a:tint val="67000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:lumMod val="105000"/><a:satMod val="103000"/><a:tint val="73000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:lumMod val="105000"/><a:satMod val="109000"/><a:tint val="81000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:satMod val="103000"/><a:lumMod val="102000"/><a:tint val="94000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:satMod val="110000"/><a:lumMod val="100000"/><a:shade val="100000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:lumMod val="99000"/><a:satMod val="120000"/><a:shade val="78000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill></a:fillStyleLst><a:lnStyleLst><a:ln w="6350" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln><a:ln w="12700" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln><a:ln w="19050" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln></a:lnStyleLst><a:effectStyleLst><a:effectStyle><a:effectLst/></a:effectStyle><a:effectStyle><a:effectLst/></a:effectStyle><a:effectStyle><a:effectLst><a:outerShdw blurRad="57150" dist="19050" dir="5400000" algn="ctr" rotWithShape="0"><a:srgbClr val="000000"><a:alpha val="63000"/></a:srgbClr></a:outerShdw></a:effectLst></a:effectStyle></a:effectStyleLst><a:bgFillStyleLst><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:solidFill><a:schemeClr val="phClr"><a:tint val="95000"/><a:satMod val="170000"/></a:schemeClr></a:solidFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:tint val="93000"/><a:satMod val="150000"/><a:shade val="98000"/><a:lumMod val="102000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:tint val="98000"/><a:satMod val="130000"/><a:shade val="90000"/><a:lumMod val="103000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:shade val="63000"/><a:satMod val="120000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill></a:bgFillStyleLst></a:fmtScheme></a:themeElements><a:objectDefaults/><a:extraClrSchemeLst/><a:extLst><a:ext uri="{05A4C25C-085E-4340-85A3-A5531E510DB2}"><thm15:themeFamily xmlns:thm15="http://schemas.microsoft.com/office/thememl/2012/main" name="Office Theme" id="{62F939B6-93AF-4DB8-9C6B-D6C7DFDC589F}" vid="{4A3C46E8-61CC-4603-A589-7422A47A8E4A}"/></a:ext></a:extLst></a:theme> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/webSettings.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/webSettings.xml
new file mode 100644
index 00000000..629ae06a
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate-spacing.docx.dir.ref/word/webSettings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:webSettings xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:optimizeForBrowser/><w:allowPNG/></w:webSettings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/[Content_Types].xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/[Content_Types].xml
new file mode 100644
index 00000000..07d88cca
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/[Content_Types].xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Types xmlns="http://schemas.openxmlformats.org/package/2006/content-types"><Default Extension="rels" ContentType="application/vnd.openxmlformats-package.relationships+xml"/><Default Extension="xml" ContentType="application/xml"/><Override PartName="/word/document.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.document.main+xml"/><Override PartName="/word/styles.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.styles+xml"/><Override PartName="/word/settings.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.settings+xml"/><Override PartName="/word/webSettings.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.webSettings+xml"/><Override PartName="/word/fontTable.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.fontTable+xml"/><Override PartName="/word/theme/theme1.xml" ContentType="application/vnd.openxmlformats-officedocument.theme+xml"/><Override PartName="/docProps/core.xml" ContentType="application/vnd.openxmlformats-package.core-properties+xml"/><Override PartName="/docProps/app.xml" ContentType="application/vnd.openxmlformats-officedocument.extended-properties+xml"/></Types> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/_rels/.rels b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/_rels/.rels
new file mode 100644
index 00000000..32548d42
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/_rels/.rels
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/extended-properties" Target="docProps/app.xml"/><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/package/2006/relationships/metadata/core-properties" Target="docProps/core.xml"/><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument" Target="word/document.xml"/></Relationships> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/docProps/app.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/docProps/app.xml
new file mode 100644
index 00000000..eb8dd2e5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/docProps/app.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Properties xmlns="http://schemas.openxmlformats.org/officeDocument/2006/extended-properties" xmlns:vt="http://schemas.openxmlformats.org/officeDocument/2006/docPropsVTypes"><Template>Normal.dotm</Template><TotalTime>3</TotalTime><Pages>1</Pages><Words>2</Words><Characters>18</Characters><Application>Microsoft Office Word</Application><DocSecurity>0</DocSecurity><Lines>1</Lines><Paragraphs>1</Paragraphs><ScaleCrop>false</ScaleCrop><Company></Company><LinksUpToDate>false</LinksUpToDate><CharactersWithSpaces>19</CharactersWithSpaces><SharedDoc>false</SharedDoc><HyperlinksChanged>false</HyperlinksChanged><AppVersion>16.0000</AppVersion></Properties> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/docProps/core.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/docProps/core.xml
new file mode 100644
index 00000000..195d77a9
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/docProps/core.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<cp:coreProperties xmlns:cp="http://schemas.openxmlformats.org/package/2006/metadata/core-properties" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:dcterms="http://purl.org/dc/terms/" xmlns:dcmitype="http://purl.org/dc/dcmitype/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><dc:title></dc:title><dc:subject></dc:subject><dc:creator></dc:creator><cp:keywords></cp:keywords><dc:description></dc:description><cp:lastModifiedBy></cp:lastModifiedBy><cp:revision>1</cp:revision><dcterms:created xsi:type="dcterms:W3CDTF">2020-09-25T17:04:00Z</dcterms:created><dcterms:modified xsi:type="dcterms:W3CDTF">2020-09-25T17:07:00Z</dcterms:modified></cp:coreProperties> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/_rels/document.xml.rels b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/_rels/document.xml.rels
new file mode 100644
index 00000000..3b2b7f8c
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/_rels/document.xml.rels
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/webSettings" Target="webSettings.xml"/><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/settings" Target="settings.xml"/><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles" Target="styles.xml"/><Relationship Id="rId5" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme" Target="theme/theme1.xml"/><Relationship Id="rId4" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/fontTable" Target="fontTable.xml"/></Relationships> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/document.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/document.xml
new file mode 100644
index 00000000..d1b2f177
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/document.xml
@@ -0,0 +1,682 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:document xmlns:wpc="http://schemas.microsoft.com/office/word/2010/wordprocessingCanvas" xmlns:cx="http://schemas.microsoft.com/office/drawing/2014/chartex" xmlns:cx1="http://schemas.microsoft.com/office/drawing/2015/9/8/chartex" xmlns:cx2="http://schemas.microsoft.com/office/drawing/2015/10/21/chartex" xmlns:cx3="http://schemas.microsoft.com/office/drawing/2016/5/9/chartex" xmlns:cx4="http://schemas.microsoft.com/office/drawing/2016/5/10/chartex" xmlns:cx5="http://schemas.microsoft.com/office/drawing/2016/5/11/chartex" xmlns:cx6="http://schemas.microsoft.com/office/drawing/2016/5/12/chartex" xmlns:cx7="http://schemas.microsoft.com/office/drawing/2016/5/13/chartex" xmlns:cx8="http://schemas.microsoft.com/office/drawing/2016/5/14/chartex" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:aink="http://schemas.microsoft.com/office/drawing/2016/ink" xmlns:am3d="http://schemas.microsoft.com/office/drawing/2017/model3d" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:m="http://schemas.openxmlformats.org/officeDocument/2006/math" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:wp14="http://schemas.microsoft.com/office/word/2010/wordprocessingDrawing" xmlns:wp="http://schemas.openxmlformats.org/drawingml/2006/wordprocessingDrawing" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" xmlns:wpg="http://schemas.microsoft.com/office/word/2010/wordprocessingGroup" xmlns:wpi="http://schemas.microsoft.com/office/word/2010/wordprocessingInk" xmlns:wne="http://schemas.microsoft.com/office/word/2006/wordml" xmlns:wps="http://schemas.microsoft.com/office/word/2010/wordprocessingShape" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex wp14"><w:body>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>781084</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>2030770</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2190257" cy="2819346"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="1" name="Text Box 1"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="-8517153">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">The crew was complete: it included a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Boots</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">&#x2014; A maker of Bonnets and Hoods&#x2014; A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Barrister</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, brought to arrange their disputes&#x2014; And a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Broker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, to value their goods.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Billiard-marker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, whose skill was immense, Might perhaps have won more than his share&#x2014; But a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Banker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, engaged at enormous expense, Had the whole of their </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-ItalicMT" w:hAnsi="TimesNewRomanPS-ItalicMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">cash </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">in his care.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was also a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Beaver</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, that paced on the deck, Or would sit making lace in the bow: And had often (the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">said) saved them from wreck, Though none of the sailors knew how.</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 1" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">The crew was complete: it included a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Boots</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">&#x2014; A maker of Bonnets and Hoods&#x2014; A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Barrister</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, brought to arrange their disputes&#x2014; And a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Broker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, to value their goods.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Billiard-marker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, whose skill was immense, Might perhaps have won more than his share&#x2014; But a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Banker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, engaged at enormous expense, Had the whole of their </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-ItalicMT" w:hAnsi="TimesNewRomanPS-ItalicMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">cash </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">in his care.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was also a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Beaver</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, that paced on the deck, Or would sit making lace in the bow: And had often (the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">said) saved them from wreck, Though none of the sailors knew how.</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>1630060</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>825686</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="4204294" cy="5742838"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="2" name="Text Box 2"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="10470860">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was one who was famed for the number of things He His umbrella, his watch, all his jewels and rings, </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-BoldMT" w:hAnsi="CourierNewPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">forgot </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve"> And the clothes he had bought for the trip. when he entered the ship: He had </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-ItalicMT" w:hAnsi="CourierNewPS-ItalicMT"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">forty-two </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">With his name painted clearly on each: But, since he omitted to mention the fact, They were all left behind on the beach. boxes, all carefully packed,</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 2" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was one who was famed for the number of things He His umbrella, his watch, all his jewels and rings, </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-BoldMT" w:hAnsi="CourierNewPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">forgot </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve"> And the clothes he had bought for the trip. when he entered the ship: He had </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-ItalicMT" w:hAnsi="CourierNewPS-ItalicMT"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">forty-two </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">With his name painted clearly on each: But, since he omitted to mention the fact, They were all left behind on the beach. boxes, all carefully packed,</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>3428887</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>1311322</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2856668" cy="3710084"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="3" name="Text Box 3"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="6130097">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">!&quot; the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">cried,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> As he landed his crew with care;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Supporting each man on the top of the tide</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> By a finger entwined in his hair.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it twice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> That alone should encourage the crew.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it thrice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> What I tell you </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">three </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">times is true.&quot;</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 3" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">!&quot; the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">cried,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> As he landed his crew with care;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Supporting each man on the top of the tide</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> By a finger entwined in his hair.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it twice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> That alone should encourage the crew.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it thrice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> What I tell you </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">three </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">times is true.&quot;</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>4205387</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>52893</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2309037" cy="1989180"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="4" name="Text Box 4"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="1991925">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">There was a young man of </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Madras</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Whose balls were </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">constructed </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">of brass,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">When jangled together,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">They played &#x201c;</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Stormy Weather</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&#x201d;,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="32.000000"/><w:szCs w:val="24.000000"/></w:rPr><w:t xml:space="preserve">lightning</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">shot out of his ass.</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 4" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">There was a young man of </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Madras</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Whose balls were </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">constructed </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">of brass,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">When jangled together,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">They played &#x201c;</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Stormy Weather</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&#x201d;,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="32.000000"/><w:szCs w:val="24.000000"/></w:rPr><w:t xml:space="preserve">lightning</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">shot out of his ass.</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>1670565</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>-464151</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2090264" cy="5976830"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="5" name="Text Box 5"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="-1645561">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">A Python, I should not advise,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">For it needs a doctor for its eyes,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And has the Measles yearly.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">However, if </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">you feel</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> inclined</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">To get one (to improve your mind,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And not from fashion merely),</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Allow no </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">music</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> near its cage;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And when it </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">flies</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> into a rage</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Chastise it, most severely.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">I had an Aunt in Yucatan</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Who bought a Python from a man</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And kept it for a pet.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">She </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">died</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">, because she never knew</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">These simple little rules and few; &#x2014;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">The snake is living yet.</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 5" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">A Python, I should not advise,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">For it needs a doctor for its eyes,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And has the Measles yearly.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">However, if </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">you feel</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> inclined</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">To get one (to improve your mind,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And not from fashion merely),</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Allow no </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">music</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> near its cage;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And when it </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">flies</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> into a rage</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Chastise it, most severely.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">I had an Aunt in Yucatan</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Who bought a Python from a man</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And kept it for a pet.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">She </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">died</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">, because she never knew</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">These simple little rules and few; &#x2014;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">The snake is living yet.</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p></w:body></w:document> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/fontTable.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/fontTable.xml
new file mode 100644
index 00000000..a39546e5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/fontTable.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:fonts xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:font w:name="Calibri"><w:panose1 w:val="020F0502020204030204"/><w:charset w:val="00"/><w:family w:val="swiss"/><w:pitch w:val="variable"/><w:sig w:usb0="E4002EFF" w:usb1="C000247B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font><w:font w:name="Times New Roman"><w:panose1 w:val="02020603050405020304"/><w:charset w:val="00"/><w:family w:val="roman"/><w:pitch w:val="variable"/><w:sig w:usb0="E0002EFF" w:usb1="C000785B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font><w:font w:name="Calibri Light"><w:panose1 w:val="020F0302020204030204"/><w:charset w:val="00"/><w:family w:val="swiss"/><w:pitch w:val="variable"/><w:sig w:usb0="E4002EFF" w:usb1="C000247B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font></w:fonts> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/settings.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/settings.xml
new file mode 100644
index 00000000..c403540d
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/settings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:settings xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:m="http://schemas.openxmlformats.org/officeDocument/2006/math" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" xmlns:sl="http://schemas.openxmlformats.org/schemaLibrary/2006/main" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:zoom w:percent="100"/><w:proofState w:spelling="clean" w:grammar="clean"/><w:defaultTabStop w:val="720"/><w:characterSpacingControl w:val="doNotCompress"/><w:compat><w:compatSetting w:name="compatibilityMode" w:uri="http://schemas.microsoft.com/office/word" w:val="15"/><w:compatSetting w:name="overrideTableStyleFontSizeAndJustification" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="enableOpenTypeFeatures" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="doNotFlipMirrorIndents" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="differentiateMultirowTableHeaders" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="useWord2013TrackBottomHyphenation" w:uri="http://schemas.microsoft.com/office/word" w:val="0"/></w:compat><w:rsids><w:rsidRoot w:val="007F4427"/><w:rsid w:val="00255448"/><w:rsid w:val="007F4427"/></w:rsids><m:mathPr><m:mathFont m:val="Cambria Math"/><m:brkBin m:val="before"/><m:brkBinSub m:val="--"/><m:smallFrac m:val="0"/><m:dispDef/><m:lMargin m:val="0"/><m:rMargin m:val="0"/><m:defJc m:val="centerGroup"/><m:wrapIndent m:val="1440"/><m:intLim m:val="subSup"/><m:naryLim m:val="undOvr"/></m:mathPr><w:themeFontLang w:val="en-GB"/><w:clrSchemeMapping w:bg1="light1" w:t1="dark1" w:bg2="light2" w:t2="dark2" w:accent1="accent1" w:accent2="accent2" w:accent3="accent3" w:accent4="accent4" w:accent5="accent5" w:accent6="accent6" w:hyperlink="hyperlink" w:followedHyperlink="followedHyperlink"/><w:shapeDefaults><o:shapedefaults v:ext="edit" spidmax="1026"/><o:shapelayout v:ext="edit"><o:idmap v:ext="edit" data="1"/></o:shapelayout></w:shapeDefaults><w:decimalSymbol w:val="."/><w:listSeparator w:val=","/><w14:docId w14:val="32E52EF8"/><w15:chartTrackingRefBased/><w15:docId w15:val="{A10F59F7-497D-44D4-A338-47719734E7A0}"/></w:settings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/styles.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/styles.xml
new file mode 100644
index 00000000..38e5e2bd
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/styles.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:styles xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:docDefaults><w:rPrDefault><w:rPr><w:rFonts w:asciiTheme="minorHAnsi" w:eastAsiaTheme="minorHAnsi" w:hAnsiTheme="minorHAnsi" w:cstheme="minorBidi"/><w:sz w:val="22"/><w:szCs w:val="22"/><w:lang w:val="en-GB" w:eastAsia="en-US" w:bidi="ar-SA"/></w:rPr></w:rPrDefault><w:pPrDefault><w:pPr><w:spacing w:after="160" w:line="259" w:lineRule="auto"/></w:pPr></w:pPrDefault></w:docDefaults><w:latentStyles w:defLockedState="0" w:defUIPriority="99" w:defSemiHidden="0" w:defUnhideWhenUsed="0" w:defQFormat="0" w:count="376"><w:lsdException w:name="Normal" w:uiPriority="0" w:qFormat="1"/><w:lsdException w:name="heading 1" w:uiPriority="9" w:qFormat="1"/><w:lsdException w:name="heading 2" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 3" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 4" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 5" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 6" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 7" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 8" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 9" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="index 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 9" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 1" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 2" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 3" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 4" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 5" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 6" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 7" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 8" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 9" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footnote text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="header" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footer" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="caption" w:semiHidden="1" w:uiPriority="35" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="table of figures" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="envelope address" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="envelope return" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footnote reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="line number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="page number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="endnote reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="endnote text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="table of authorities" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="macro" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="toa heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Title" w:uiPriority="10" w:qFormat="1"/><w:lsdException w:name="Closing" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Signature" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Default Paragraph Font" w:semiHidden="1" w:uiPriority="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Message Header" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Subtitle" w:uiPriority="11" w:qFormat="1"/><w:lsdException w:name="Salutation" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Date" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text First Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text First Indent 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Note Heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Block Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Hyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="FollowedHyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Strong" w:uiPriority="22" w:qFormat="1"/><w:lsdException w:name="Emphasis" w:uiPriority="20" w:qFormat="1"/><w:lsdException w:name="Document Map" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Plain Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="E-mail Signature" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Top of Form" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Bottom of Form" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal (Web)" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Acronym" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Address" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Cite" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Code" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Definition" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Keyboard" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Preformatted" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Sample" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Typewriter" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Variable" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal Table" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation subject" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="No List" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Contemporary" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Elegant" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Professional" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Subtle 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Subtle 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Balloon Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid" w:uiPriority="39"/><w:lsdException w:name="Table Theme" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Placeholder Text" w:semiHidden="1"/><w:lsdException w:name="No Spacing" w:uiPriority="1" w:qFormat="1"/><w:lsdException w:name="Light Shading" w:uiPriority="60"/><w:lsdException w:name="Light List" w:uiPriority="61"/><w:lsdException w:name="Light Grid" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2" w:uiPriority="64"/><w:lsdException w:name="Medium List 1" w:uiPriority="65"/><w:lsdException w:name="Medium List 2" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3" w:uiPriority="69"/><w:lsdException w:name="Dark List" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading" w:uiPriority="71"/><w:lsdException w:name="Colorful List" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 1" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 1" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 1" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 1" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 1" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 1" w:uiPriority="65"/><w:lsdException w:name="Revision" w:semiHidden="1"/><w:lsdException w:name="List Paragraph" w:uiPriority="34" w:qFormat="1"/><w:lsdException w:name="Quote" w:uiPriority="29" w:qFormat="1"/><w:lsdException w:name="Intense Quote" w:uiPriority="30" w:qFormat="1"/><w:lsdException w:name="Medium List 2 Accent 1" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 1" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 1" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 1" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 1" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 1" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 1" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 1" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 2" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 2" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 2" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 2" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 2" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 2" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 2" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 2" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 2" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 2" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 2" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 2" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 2" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 2" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 3" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 3" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 3" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 3" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 3" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 3" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 3" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 3" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 3" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 3" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 3" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 3" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 3" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 3" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 4" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 4" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 4" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 4" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 4" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 4" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 4" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 4" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 4" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 4" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 4" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 4" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 4" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 4" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 5" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 5" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 5" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 5" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 5" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 5" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 5" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 5" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 5" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 5" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 5" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 5" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 5" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 5" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 6" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 6" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 6" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 6" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 6" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 6" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 6" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 6" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 6" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 6" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 6" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 6" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 6" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 6" w:uiPriority="73"/><w:lsdException w:name="Subtle Emphasis" w:uiPriority="19" w:qFormat="1"/><w:lsdException w:name="Intense Emphasis" w:uiPriority="21" w:qFormat="1"/><w:lsdException w:name="Subtle Reference" w:uiPriority="31" w:qFormat="1"/><w:lsdException w:name="Intense Reference" w:uiPriority="32" w:qFormat="1"/><w:lsdException w:name="Book Title" w:uiPriority="33" w:qFormat="1"/><w:lsdException w:name="Bibliography" w:semiHidden="1" w:uiPriority="37" w:unhideWhenUsed="1"/><w:lsdException w:name="TOC Heading" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="Plain Table 1" w:uiPriority="41"/><w:lsdException w:name="Plain Table 2" w:uiPriority="42"/><w:lsdException w:name="Plain Table 3" w:uiPriority="43"/><w:lsdException w:name="Plain Table 4" w:uiPriority="44"/><w:lsdException w:name="Plain Table 5" w:uiPriority="45"/><w:lsdException w:name="Grid Table Light" w:uiPriority="40"/><w:lsdException w:name="Grid Table 1 Light" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 1" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 1" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 1" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 1" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 1" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 1" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 1" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 2" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 2" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 2" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 2" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 2" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 2" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 2" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 3" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 3" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 3" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 3" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 3" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 3" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 3" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 4" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 4" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 4" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 4" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 4" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 4" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 4" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 5" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 5" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 5" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 5" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 5" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 5" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 5" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 6" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 6" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 6" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 6" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 6" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 6" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 6" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light" w:uiPriority="46"/><w:lsdException w:name="List Table 2" w:uiPriority="47"/><w:lsdException w:name="List Table 3" w:uiPriority="48"/><w:lsdException w:name="List Table 4" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 1" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 1" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 1" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 1" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 1" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 1" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 1" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 2" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 2" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 2" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 2" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 2" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 2" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 2" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 3" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 3" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 3" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 3" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 3" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 3" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 3" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 4" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 4" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 4" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 4" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 4" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 4" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 4" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 5" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 5" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 5" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 5" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 5" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 5" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 5" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 6" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 6" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 6" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 6" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 6" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 6" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 6" w:uiPriority="52"/><w:lsdException w:name="Mention" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Smart Hyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Hashtag" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Unresolved Mention" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Smart Link" w:semiHidden="1" w:unhideWhenUsed="1"/></w:latentStyles><w:style w:type="paragraph" w:default="1" w:styleId="Normal"><w:name w:val="Normal"/><w:qFormat/></w:style><w:style w:type="character" w:default="1" w:styleId="DefaultParagraphFont"><w:name w:val="Default Paragraph Font"/><w:uiPriority w:val="1"/><w:semiHidden/><w:unhideWhenUsed/></w:style><w:style w:type="table" w:default="1" w:styleId="TableNormal"><w:name w:val="Normal Table"/><w:uiPriority w:val="99"/><w:semiHidden/><w:unhideWhenUsed/><w:tblPr><w:tblInd w:w="0" w:type="dxa"/><w:tblCellMar><w:top w:w="0" w:type="dxa"/><w:left w:w="108" w:type="dxa"/><w:bottom w:w="0" w:type="dxa"/><w:right w:w="108" w:type="dxa"/></w:tblCellMar></w:tblPr></w:style><w:style w:type="numbering" w:default="1" w:styleId="NoList"><w:name w:val="No List"/><w:uiPriority w:val="99"/><w:semiHidden/><w:unhideWhenUsed/></w:style></w:styles> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/theme/theme1.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/theme/theme1.xml
new file mode 100644
index 00000000..d1a502f8
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/theme/theme1.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<a:theme xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main" name="Office Theme"><a:themeElements><a:clrScheme name="Office"><a:dk1><a:sysClr val="windowText" lastClr="000000"/></a:dk1><a:lt1><a:sysClr val="window" lastClr="FFFFFF"/></a:lt1><a:dk2><a:srgbClr val="44546A"/></a:dk2><a:lt2><a:srgbClr val="E7E6E6"/></a:lt2><a:accent1><a:srgbClr val="4472C4"/></a:accent1><a:accent2><a:srgbClr val="ED7D31"/></a:accent2><a:accent3><a:srgbClr val="A5A5A5"/></a:accent3><a:accent4><a:srgbClr val="FFC000"/></a:accent4><a:accent5><a:srgbClr val="5B9BD5"/></a:accent5><a:accent6><a:srgbClr val="70AD47"/></a:accent6><a:hlink><a:srgbClr val="0563C1"/></a:hlink><a:folHlink><a:srgbClr val="954F72"/></a:folHlink></a:clrScheme><a:fontScheme name="Office"><a:majorFont><a:latin typeface="Calibri Light" panose="020F0302020204030204"/><a:ea typeface=""/><a:cs typeface=""/><a:font script="Jpan" typeface="游ゴシック Light"/><a:font script="Hang" typeface="맑은 고딕"/><a:font script="Hans" typeface="等线 Light"/><a:font script="Hant" typeface="新細明體"/><a:font script="Arab" typeface="Times New Roman"/><a:font script="Hebr" typeface="Times New Roman"/><a:font script="Thai" typeface="Angsana New"/><a:font script="Ethi" typeface="Nyala"/><a:font script="Beng" typeface="Vrinda"/><a:font script="Gujr" typeface="Shruti"/><a:font script="Khmr" typeface="MoolBoran"/><a:font script="Knda" typeface="Tunga"/><a:font script="Guru" typeface="Raavi"/><a:font script="Cans" typeface="Euphemia"/><a:font script="Cher" typeface="Plantagenet Cherokee"/><a:font script="Yiii" typeface="Microsoft Yi Baiti"/><a:font script="Tibt" typeface="Microsoft Himalaya"/><a:font script="Thaa" typeface="MV Boli"/><a:font script="Deva" typeface="Mangal"/><a:font script="Telu" typeface="Gautami"/><a:font script="Taml" typeface="Latha"/><a:font script="Syrc" typeface="Estrangelo Edessa"/><a:font script="Orya" typeface="Kalinga"/><a:font script="Mlym" typeface="Kartika"/><a:font script="Laoo" typeface="DokChampa"/><a:font script="Sinh" typeface="Iskoola Pota"/><a:font script="Mong" typeface="Mongolian Baiti"/><a:font script="Viet" typeface="Times New Roman"/><a:font script="Uigh" typeface="Microsoft Uighur"/><a:font script="Geor" typeface="Sylfaen"/><a:font script="Armn" typeface="Arial"/><a:font script="Bugi" typeface="Leelawadee UI"/><a:font script="Bopo" typeface="Microsoft JhengHei"/><a:font script="Java" typeface="Javanese Text"/><a:font script="Lisu" typeface="Segoe UI"/><a:font script="Mymr" typeface="Myanmar Text"/><a:font script="Nkoo" typeface="Ebrima"/><a:font script="Olck" typeface="Nirmala UI"/><a:font script="Osma" typeface="Ebrima"/><a:font script="Phag" typeface="Phagspa"/><a:font script="Syrn" typeface="Estrangelo Edessa"/><a:font script="Syrj" typeface="Estrangelo Edessa"/><a:font script="Syre" typeface="Estrangelo Edessa"/><a:font script="Sora" typeface="Nirmala UI"/><a:font script="Tale" typeface="Microsoft Tai Le"/><a:font script="Talu" typeface="Microsoft New Tai Lue"/><a:font script="Tfng" typeface="Ebrima"/></a:majorFont><a:minorFont><a:latin typeface="Calibri" panose="020F0502020204030204"/><a:ea typeface=""/><a:cs typeface=""/><a:font script="Jpan" typeface="游明朝"/><a:font script="Hang" typeface="맑은 고딕"/><a:font script="Hans" typeface="等线"/><a:font script="Hant" typeface="新細明體"/><a:font script="Arab" typeface="Arial"/><a:font script="Hebr" typeface="Arial"/><a:font script="Thai" typeface="Cordia New"/><a:font script="Ethi" typeface="Nyala"/><a:font script="Beng" typeface="Vrinda"/><a:font script="Gujr" typeface="Shruti"/><a:font script="Khmr" typeface="DaunPenh"/><a:font script="Knda" typeface="Tunga"/><a:font script="Guru" typeface="Raavi"/><a:font script="Cans" typeface="Euphemia"/><a:font script="Cher" typeface="Plantagenet Cherokee"/><a:font script="Yiii" typeface="Microsoft Yi Baiti"/><a:font script="Tibt" typeface="Microsoft Himalaya"/><a:font script="Thaa" typeface="MV Boli"/><a:font script="Deva" typeface="Mangal"/><a:font script="Telu" typeface="Gautami"/><a:font script="Taml" typeface="Latha"/><a:font script="Syrc" typeface="Estrangelo Edessa"/><a:font script="Orya" typeface="Kalinga"/><a:font script="Mlym" typeface="Kartika"/><a:font script="Laoo" typeface="DokChampa"/><a:font script="Sinh" typeface="Iskoola Pota"/><a:font script="Mong" typeface="Mongolian Baiti"/><a:font script="Viet" typeface="Arial"/><a:font script="Uigh" typeface="Microsoft Uighur"/><a:font script="Geor" typeface="Sylfaen"/><a:font script="Armn" typeface="Arial"/><a:font script="Bugi" typeface="Leelawadee UI"/><a:font script="Bopo" typeface="Microsoft JhengHei"/><a:font script="Java" typeface="Javanese Text"/><a:font script="Lisu" typeface="Segoe UI"/><a:font script="Mymr" typeface="Myanmar Text"/><a:font script="Nkoo" typeface="Ebrima"/><a:font script="Olck" typeface="Nirmala UI"/><a:font script="Osma" typeface="Ebrima"/><a:font script="Phag" typeface="Phagspa"/><a:font script="Syrn" typeface="Estrangelo Edessa"/><a:font script="Syrj" typeface="Estrangelo Edessa"/><a:font script="Syre" typeface="Estrangelo Edessa"/><a:font script="Sora" typeface="Nirmala UI"/><a:font script="Tale" typeface="Microsoft Tai Le"/><a:font script="Talu" typeface="Microsoft New Tai Lue"/><a:font script="Tfng" typeface="Ebrima"/></a:minorFont></a:fontScheme><a:fmtScheme name="Office"><a:fillStyleLst><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:lumMod val="110000"/><a:satMod val="105000"/><a:tint val="67000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:lumMod val="105000"/><a:satMod val="103000"/><a:tint val="73000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:lumMod val="105000"/><a:satMod val="109000"/><a:tint val="81000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:satMod val="103000"/><a:lumMod val="102000"/><a:tint val="94000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:satMod val="110000"/><a:lumMod val="100000"/><a:shade val="100000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:lumMod val="99000"/><a:satMod val="120000"/><a:shade val="78000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill></a:fillStyleLst><a:lnStyleLst><a:ln w="6350" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln><a:ln w="12700" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln><a:ln w="19050" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln></a:lnStyleLst><a:effectStyleLst><a:effectStyle><a:effectLst/></a:effectStyle><a:effectStyle><a:effectLst/></a:effectStyle><a:effectStyle><a:effectLst><a:outerShdw blurRad="57150" dist="19050" dir="5400000" algn="ctr" rotWithShape="0"><a:srgbClr val="000000"><a:alpha val="63000"/></a:srgbClr></a:outerShdw></a:effectLst></a:effectStyle></a:effectStyleLst><a:bgFillStyleLst><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:solidFill><a:schemeClr val="phClr"><a:tint val="95000"/><a:satMod val="170000"/></a:schemeClr></a:solidFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:tint val="93000"/><a:satMod val="150000"/><a:shade val="98000"/><a:lumMod val="102000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:tint val="98000"/><a:satMod val="130000"/><a:shade val="90000"/><a:lumMod val="103000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:shade val="63000"/><a:satMod val="120000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill></a:bgFillStyleLst></a:fmtScheme></a:themeElements><a:objectDefaults/><a:extraClrSchemeLst/><a:extLst><a:ext uri="{05A4C25C-085E-4340-85A3-A5531E510DB2}"><thm15:themeFamily xmlns:thm15="http://schemas.microsoft.com/office/thememl/2012/main" name="Office Theme" id="{62F939B6-93AF-4DB8-9C6B-D6C7DFDC589F}" vid="{4A3C46E8-61CC-4603-A589-7422A47A8E4A}"/></a:ext></a:extLst></a:theme> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/webSettings.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/webSettings.xml
new file mode 100644
index 00000000..629ae06a
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract-rotate.docx.dir.ref/word/webSettings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:webSettings xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:optimizeForBrowser/><w:allowPNG/></w:webSettings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/[Content_Types].xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/[Content_Types].xml
new file mode 100644
index 00000000..07d88cca
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/[Content_Types].xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Types xmlns="http://schemas.openxmlformats.org/package/2006/content-types"><Default Extension="rels" ContentType="application/vnd.openxmlformats-package.relationships+xml"/><Default Extension="xml" ContentType="application/xml"/><Override PartName="/word/document.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.document.main+xml"/><Override PartName="/word/styles.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.styles+xml"/><Override PartName="/word/settings.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.settings+xml"/><Override PartName="/word/webSettings.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.webSettings+xml"/><Override PartName="/word/fontTable.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.fontTable+xml"/><Override PartName="/word/theme/theme1.xml" ContentType="application/vnd.openxmlformats-officedocument.theme+xml"/><Override PartName="/docProps/core.xml" ContentType="application/vnd.openxmlformats-package.core-properties+xml"/><Override PartName="/docProps/app.xml" ContentType="application/vnd.openxmlformats-officedocument.extended-properties+xml"/></Types> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/_rels/.rels b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/_rels/.rels
new file mode 100644
index 00000000..32548d42
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/_rels/.rels
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/extended-properties" Target="docProps/app.xml"/><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/package/2006/relationships/metadata/core-properties" Target="docProps/core.xml"/><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument" Target="word/document.xml"/></Relationships> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/docProps/app.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/docProps/app.xml
new file mode 100644
index 00000000..eb8dd2e5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/docProps/app.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Properties xmlns="http://schemas.openxmlformats.org/officeDocument/2006/extended-properties" xmlns:vt="http://schemas.openxmlformats.org/officeDocument/2006/docPropsVTypes"><Template>Normal.dotm</Template><TotalTime>3</TotalTime><Pages>1</Pages><Words>2</Words><Characters>18</Characters><Application>Microsoft Office Word</Application><DocSecurity>0</DocSecurity><Lines>1</Lines><Paragraphs>1</Paragraphs><ScaleCrop>false</ScaleCrop><Company></Company><LinksUpToDate>false</LinksUpToDate><CharactersWithSpaces>19</CharactersWithSpaces><SharedDoc>false</SharedDoc><HyperlinksChanged>false</HyperlinksChanged><AppVersion>16.0000</AppVersion></Properties> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/docProps/core.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/docProps/core.xml
new file mode 100644
index 00000000..195d77a9
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/docProps/core.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<cp:coreProperties xmlns:cp="http://schemas.openxmlformats.org/package/2006/metadata/core-properties" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:dcterms="http://purl.org/dc/terms/" xmlns:dcmitype="http://purl.org/dc/dcmitype/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><dc:title></dc:title><dc:subject></dc:subject><dc:creator></dc:creator><cp:keywords></cp:keywords><dc:description></dc:description><cp:lastModifiedBy></cp:lastModifiedBy><cp:revision>1</cp:revision><dcterms:created xsi:type="dcterms:W3CDTF">2020-09-25T17:04:00Z</dcterms:created><dcterms:modified xsi:type="dcterms:W3CDTF">2020-09-25T17:07:00Z</dcterms:modified></cp:coreProperties> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/_rels/document.xml.rels b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/_rels/document.xml.rels
new file mode 100644
index 00000000..3b2b7f8c
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/_rels/document.xml.rels
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/webSettings" Target="webSettings.xml"/><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/settings" Target="settings.xml"/><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles" Target="styles.xml"/><Relationship Id="rId5" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme" Target="theme/theme1.xml"/><Relationship Id="rId4" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/fontTable" Target="fontTable.xml"/></Relationships> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/document.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/document.xml
new file mode 100644
index 00000000..32b69d9f
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/document.xml
@@ -0,0 +1,321 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:document xmlns:wpc="http://schemas.microsoft.com/office/word/2010/wordprocessingCanvas" xmlns:cx="http://schemas.microsoft.com/office/drawing/2014/chartex" xmlns:cx1="http://schemas.microsoft.com/office/drawing/2015/9/8/chartex" xmlns:cx2="http://schemas.microsoft.com/office/drawing/2015/10/21/chartex" xmlns:cx3="http://schemas.microsoft.com/office/drawing/2016/5/9/chartex" xmlns:cx4="http://schemas.microsoft.com/office/drawing/2016/5/10/chartex" xmlns:cx5="http://schemas.microsoft.com/office/drawing/2016/5/11/chartex" xmlns:cx6="http://schemas.microsoft.com/office/drawing/2016/5/12/chartex" xmlns:cx7="http://schemas.microsoft.com/office/drawing/2016/5/13/chartex" xmlns:cx8="http://schemas.microsoft.com/office/drawing/2016/5/14/chartex" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:aink="http://schemas.microsoft.com/office/drawing/2016/ink" xmlns:am3d="http://schemas.microsoft.com/office/drawing/2017/model3d" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:m="http://schemas.openxmlformats.org/officeDocument/2006/math" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:wp14="http://schemas.microsoft.com/office/word/2010/wordprocessingDrawing" xmlns:wp="http://schemas.openxmlformats.org/drawingml/2006/wordprocessingDrawing" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" xmlns:wpg="http://schemas.microsoft.com/office/word/2010/wordprocessingGroup" xmlns:wpi="http://schemas.microsoft.com/office/word/2010/wordprocessingInk" xmlns:wne="http://schemas.microsoft.com/office/word/2006/wordml" xmlns:wps="http://schemas.microsoft.com/office/word/2010/wordprocessingShape" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex wp14"><w:body>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">The crew was complete: it included a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Boots</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">&#x2014; A maker of Bonnets and Hoods&#x2014; A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Barrister</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, brought to arrange their disputes&#x2014; And a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Broker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, to value their goods.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Billiard-marker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, whose skill was immense, Might perhaps have won more than his share&#x2014; But a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Banker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, engaged at enormous expense, Had the whole of their </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-ItalicMT" w:hAnsi="TimesNewRomanPS-ItalicMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">cash </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">in his care.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was also a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Beaver</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, that paced on the deck, Or would sit making lace in the bow: And had often (the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">said) saved them from wreck, Though none of the sailors knew how.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was one who was famed for the number of things He His umbrella, his watch, all his jewels and rings, </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-BoldMT" w:hAnsi="CourierNewPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">forgot </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve"> And the clothes he had bought for the trip. when he entered the ship: He had </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-ItalicMT" w:hAnsi="CourierNewPS-ItalicMT"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">forty-two </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">With his name painted clearly on each: But, since he omitted to mention the fact, They were all left behind on the beach. boxes, all carefully packed,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">!&quot; the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">cried,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> As he landed his crew with care;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Supporting each man on the top of the tide</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> By a finger entwined in his hair.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it twice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> That alone should encourage the crew.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it thrice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> What I tell you </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">three </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">times is true.&quot;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">There was a young man of </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Madras</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Whose balls were </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">constructed </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">of brass,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">When jangled together,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">They played &#x201c;</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Stormy Weather</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&#x201d;,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="32.000000"/><w:szCs w:val="24.000000"/></w:rPr><w:t xml:space="preserve">lightning</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">shot out of his ass.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">A Python, I should not advise,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">For it needs a doctor for its eyes,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And has the Measles yearly.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">However, if </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">you feel</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> inclined</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">To get one (to improve your mind,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And not from fashion merely),</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Allow no </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">music</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> near its cage;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And when it </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">flies</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> into a rage</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Chastise it, most severely.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">I had an Aunt in Yucatan</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Who bought a Python from a man</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And kept it for a pet.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">She </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">died</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">, because she never knew</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">These simple little rules and few; &#x2014;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">The snake is living yet.</w:t></w:r>
+</w:p></w:body></w:document> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/fontTable.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/fontTable.xml
new file mode 100644
index 00000000..a39546e5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/fontTable.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:fonts xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:font w:name="Calibri"><w:panose1 w:val="020F0502020204030204"/><w:charset w:val="00"/><w:family w:val="swiss"/><w:pitch w:val="variable"/><w:sig w:usb0="E4002EFF" w:usb1="C000247B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font><w:font w:name="Times New Roman"><w:panose1 w:val="02020603050405020304"/><w:charset w:val="00"/><w:family w:val="roman"/><w:pitch w:val="variable"/><w:sig w:usb0="E0002EFF" w:usb1="C000785B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font><w:font w:name="Calibri Light"><w:panose1 w:val="020F0302020204030204"/><w:charset w:val="00"/><w:family w:val="swiss"/><w:pitch w:val="variable"/><w:sig w:usb0="E4002EFF" w:usb1="C000247B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font></w:fonts> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/settings.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/settings.xml
new file mode 100644
index 00000000..c403540d
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/settings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:settings xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:m="http://schemas.openxmlformats.org/officeDocument/2006/math" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" xmlns:sl="http://schemas.openxmlformats.org/schemaLibrary/2006/main" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:zoom w:percent="100"/><w:proofState w:spelling="clean" w:grammar="clean"/><w:defaultTabStop w:val="720"/><w:characterSpacingControl w:val="doNotCompress"/><w:compat><w:compatSetting w:name="compatibilityMode" w:uri="http://schemas.microsoft.com/office/word" w:val="15"/><w:compatSetting w:name="overrideTableStyleFontSizeAndJustification" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="enableOpenTypeFeatures" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="doNotFlipMirrorIndents" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="differentiateMultirowTableHeaders" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="useWord2013TrackBottomHyphenation" w:uri="http://schemas.microsoft.com/office/word" w:val="0"/></w:compat><w:rsids><w:rsidRoot w:val="007F4427"/><w:rsid w:val="00255448"/><w:rsid w:val="007F4427"/></w:rsids><m:mathPr><m:mathFont m:val="Cambria Math"/><m:brkBin m:val="before"/><m:brkBinSub m:val="--"/><m:smallFrac m:val="0"/><m:dispDef/><m:lMargin m:val="0"/><m:rMargin m:val="0"/><m:defJc m:val="centerGroup"/><m:wrapIndent m:val="1440"/><m:intLim m:val="subSup"/><m:naryLim m:val="undOvr"/></m:mathPr><w:themeFontLang w:val="en-GB"/><w:clrSchemeMapping w:bg1="light1" w:t1="dark1" w:bg2="light2" w:t2="dark2" w:accent1="accent1" w:accent2="accent2" w:accent3="accent3" w:accent4="accent4" w:accent5="accent5" w:accent6="accent6" w:hyperlink="hyperlink" w:followedHyperlink="followedHyperlink"/><w:shapeDefaults><o:shapedefaults v:ext="edit" spidmax="1026"/><o:shapelayout v:ext="edit"><o:idmap v:ext="edit" data="1"/></o:shapelayout></w:shapeDefaults><w:decimalSymbol w:val="."/><w:listSeparator w:val=","/><w14:docId w14:val="32E52EF8"/><w15:chartTrackingRefBased/><w15:docId w15:val="{A10F59F7-497D-44D4-A338-47719734E7A0}"/></w:settings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/styles.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/styles.xml
new file mode 100644
index 00000000..38e5e2bd
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/styles.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:styles xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:docDefaults><w:rPrDefault><w:rPr><w:rFonts w:asciiTheme="minorHAnsi" w:eastAsiaTheme="minorHAnsi" w:hAnsiTheme="minorHAnsi" w:cstheme="minorBidi"/><w:sz w:val="22"/><w:szCs w:val="22"/><w:lang w:val="en-GB" w:eastAsia="en-US" w:bidi="ar-SA"/></w:rPr></w:rPrDefault><w:pPrDefault><w:pPr><w:spacing w:after="160" w:line="259" w:lineRule="auto"/></w:pPr></w:pPrDefault></w:docDefaults><w:latentStyles w:defLockedState="0" w:defUIPriority="99" w:defSemiHidden="0" w:defUnhideWhenUsed="0" w:defQFormat="0" w:count="376"><w:lsdException w:name="Normal" w:uiPriority="0" w:qFormat="1"/><w:lsdException w:name="heading 1" w:uiPriority="9" w:qFormat="1"/><w:lsdException w:name="heading 2" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 3" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 4" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 5" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 6" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 7" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 8" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 9" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="index 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 9" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 1" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 2" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 3" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 4" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 5" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 6" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 7" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 8" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 9" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footnote text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="header" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footer" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="caption" w:semiHidden="1" w:uiPriority="35" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="table of figures" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="envelope address" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="envelope return" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footnote reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="line number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="page number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="endnote reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="endnote text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="table of authorities" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="macro" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="toa heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Title" w:uiPriority="10" w:qFormat="1"/><w:lsdException w:name="Closing" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Signature" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Default Paragraph Font" w:semiHidden="1" w:uiPriority="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Message Header" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Subtitle" w:uiPriority="11" w:qFormat="1"/><w:lsdException w:name="Salutation" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Date" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text First Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text First Indent 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Note Heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Block Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Hyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="FollowedHyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Strong" w:uiPriority="22" w:qFormat="1"/><w:lsdException w:name="Emphasis" w:uiPriority="20" w:qFormat="1"/><w:lsdException w:name="Document Map" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Plain Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="E-mail Signature" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Top of Form" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Bottom of Form" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal (Web)" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Acronym" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Address" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Cite" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Code" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Definition" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Keyboard" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Preformatted" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Sample" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Typewriter" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Variable" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal Table" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation subject" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="No List" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Contemporary" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Elegant" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Professional" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Subtle 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Subtle 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Balloon Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid" w:uiPriority="39"/><w:lsdException w:name="Table Theme" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Placeholder Text" w:semiHidden="1"/><w:lsdException w:name="No Spacing" w:uiPriority="1" w:qFormat="1"/><w:lsdException w:name="Light Shading" w:uiPriority="60"/><w:lsdException w:name="Light List" w:uiPriority="61"/><w:lsdException w:name="Light Grid" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2" w:uiPriority="64"/><w:lsdException w:name="Medium List 1" w:uiPriority="65"/><w:lsdException w:name="Medium List 2" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3" w:uiPriority="69"/><w:lsdException w:name="Dark List" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading" w:uiPriority="71"/><w:lsdException w:name="Colorful List" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 1" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 1" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 1" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 1" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 1" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 1" w:uiPriority="65"/><w:lsdException w:name="Revision" w:semiHidden="1"/><w:lsdException w:name="List Paragraph" w:uiPriority="34" w:qFormat="1"/><w:lsdException w:name="Quote" w:uiPriority="29" w:qFormat="1"/><w:lsdException w:name="Intense Quote" w:uiPriority="30" w:qFormat="1"/><w:lsdException w:name="Medium List 2 Accent 1" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 1" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 1" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 1" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 1" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 1" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 1" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 1" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 2" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 2" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 2" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 2" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 2" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 2" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 2" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 2" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 2" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 2" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 2" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 2" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 2" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 2" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 3" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 3" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 3" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 3" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 3" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 3" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 3" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 3" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 3" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 3" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 3" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 3" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 3" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 3" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 4" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 4" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 4" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 4" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 4" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 4" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 4" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 4" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 4" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 4" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 4" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 4" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 4" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 4" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 5" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 5" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 5" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 5" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 5" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 5" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 5" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 5" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 5" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 5" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 5" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 5" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 5" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 5" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 6" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 6" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 6" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 6" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 6" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 6" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 6" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 6" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 6" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 6" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 6" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 6" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 6" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 6" w:uiPriority="73"/><w:lsdException w:name="Subtle Emphasis" w:uiPriority="19" w:qFormat="1"/><w:lsdException w:name="Intense Emphasis" w:uiPriority="21" w:qFormat="1"/><w:lsdException w:name="Subtle Reference" w:uiPriority="31" w:qFormat="1"/><w:lsdException w:name="Intense Reference" w:uiPriority="32" w:qFormat="1"/><w:lsdException w:name="Book Title" w:uiPriority="33" w:qFormat="1"/><w:lsdException w:name="Bibliography" w:semiHidden="1" w:uiPriority="37" w:unhideWhenUsed="1"/><w:lsdException w:name="TOC Heading" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="Plain Table 1" w:uiPriority="41"/><w:lsdException w:name="Plain Table 2" w:uiPriority="42"/><w:lsdException w:name="Plain Table 3" w:uiPriority="43"/><w:lsdException w:name="Plain Table 4" w:uiPriority="44"/><w:lsdException w:name="Plain Table 5" w:uiPriority="45"/><w:lsdException w:name="Grid Table Light" w:uiPriority="40"/><w:lsdException w:name="Grid Table 1 Light" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 1" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 1" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 1" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 1" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 1" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 1" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 1" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 2" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 2" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 2" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 2" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 2" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 2" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 2" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 3" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 3" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 3" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 3" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 3" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 3" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 3" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 4" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 4" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 4" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 4" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 4" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 4" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 4" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 5" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 5" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 5" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 5" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 5" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 5" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 5" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 6" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 6" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 6" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 6" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 6" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 6" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 6" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light" w:uiPriority="46"/><w:lsdException w:name="List Table 2" w:uiPriority="47"/><w:lsdException w:name="List Table 3" w:uiPriority="48"/><w:lsdException w:name="List Table 4" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 1" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 1" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 1" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 1" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 1" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 1" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 1" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 2" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 2" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 2" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 2" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 2" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 2" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 2" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 3" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 3" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 3" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 3" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 3" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 3" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 3" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 4" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 4" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 4" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 4" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 4" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 4" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 4" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 5" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 5" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 5" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 5" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 5" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 5" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 5" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 6" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 6" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 6" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 6" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 6" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 6" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 6" w:uiPriority="52"/><w:lsdException w:name="Mention" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Smart Hyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Hashtag" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Unresolved Mention" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Smart Link" w:semiHidden="1" w:unhideWhenUsed="1"/></w:latentStyles><w:style w:type="paragraph" w:default="1" w:styleId="Normal"><w:name w:val="Normal"/><w:qFormat/></w:style><w:style w:type="character" w:default="1" w:styleId="DefaultParagraphFont"><w:name w:val="Default Paragraph Font"/><w:uiPriority w:val="1"/><w:semiHidden/><w:unhideWhenUsed/></w:style><w:style w:type="table" w:default="1" w:styleId="TableNormal"><w:name w:val="Normal Table"/><w:uiPriority w:val="99"/><w:semiHidden/><w:unhideWhenUsed/><w:tblPr><w:tblInd w:w="0" w:type="dxa"/><w:tblCellMar><w:top w:w="0" w:type="dxa"/><w:left w:w="108" w:type="dxa"/><w:bottom w:w="0" w:type="dxa"/><w:right w:w="108" w:type="dxa"/></w:tblCellMar></w:tblPr></w:style><w:style w:type="numbering" w:default="1" w:styleId="NoList"><w:name w:val="No List"/><w:uiPriority w:val="99"/><w:semiHidden/><w:unhideWhenUsed/></w:style></w:styles> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/theme/theme1.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/theme/theme1.xml
new file mode 100644
index 00000000..d1a502f8
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/theme/theme1.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<a:theme xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main" name="Office Theme"><a:themeElements><a:clrScheme name="Office"><a:dk1><a:sysClr val="windowText" lastClr="000000"/></a:dk1><a:lt1><a:sysClr val="window" lastClr="FFFFFF"/></a:lt1><a:dk2><a:srgbClr val="44546A"/></a:dk2><a:lt2><a:srgbClr val="E7E6E6"/></a:lt2><a:accent1><a:srgbClr val="4472C4"/></a:accent1><a:accent2><a:srgbClr val="ED7D31"/></a:accent2><a:accent3><a:srgbClr val="A5A5A5"/></a:accent3><a:accent4><a:srgbClr val="FFC000"/></a:accent4><a:accent5><a:srgbClr val="5B9BD5"/></a:accent5><a:accent6><a:srgbClr val="70AD47"/></a:accent6><a:hlink><a:srgbClr val="0563C1"/></a:hlink><a:folHlink><a:srgbClr val="954F72"/></a:folHlink></a:clrScheme><a:fontScheme name="Office"><a:majorFont><a:latin typeface="Calibri Light" panose="020F0302020204030204"/><a:ea typeface=""/><a:cs typeface=""/><a:font script="Jpan" typeface="游ゴシック Light"/><a:font script="Hang" typeface="맑은 고딕"/><a:font script="Hans" typeface="等线 Light"/><a:font script="Hant" typeface="新細明體"/><a:font script="Arab" typeface="Times New Roman"/><a:font script="Hebr" typeface="Times New Roman"/><a:font script="Thai" typeface="Angsana New"/><a:font script="Ethi" typeface="Nyala"/><a:font script="Beng" typeface="Vrinda"/><a:font script="Gujr" typeface="Shruti"/><a:font script="Khmr" typeface="MoolBoran"/><a:font script="Knda" typeface="Tunga"/><a:font script="Guru" typeface="Raavi"/><a:font script="Cans" typeface="Euphemia"/><a:font script="Cher" typeface="Plantagenet Cherokee"/><a:font script="Yiii" typeface="Microsoft Yi Baiti"/><a:font script="Tibt" typeface="Microsoft Himalaya"/><a:font script="Thaa" typeface="MV Boli"/><a:font script="Deva" typeface="Mangal"/><a:font script="Telu" typeface="Gautami"/><a:font script="Taml" typeface="Latha"/><a:font script="Syrc" typeface="Estrangelo Edessa"/><a:font script="Orya" typeface="Kalinga"/><a:font script="Mlym" typeface="Kartika"/><a:font script="Laoo" typeface="DokChampa"/><a:font script="Sinh" typeface="Iskoola Pota"/><a:font script="Mong" typeface="Mongolian Baiti"/><a:font script="Viet" typeface="Times New Roman"/><a:font script="Uigh" typeface="Microsoft Uighur"/><a:font script="Geor" typeface="Sylfaen"/><a:font script="Armn" typeface="Arial"/><a:font script="Bugi" typeface="Leelawadee UI"/><a:font script="Bopo" typeface="Microsoft JhengHei"/><a:font script="Java" typeface="Javanese Text"/><a:font script="Lisu" typeface="Segoe UI"/><a:font script="Mymr" typeface="Myanmar Text"/><a:font script="Nkoo" typeface="Ebrima"/><a:font script="Olck" typeface="Nirmala UI"/><a:font script="Osma" typeface="Ebrima"/><a:font script="Phag" typeface="Phagspa"/><a:font script="Syrn" typeface="Estrangelo Edessa"/><a:font script="Syrj" typeface="Estrangelo Edessa"/><a:font script="Syre" typeface="Estrangelo Edessa"/><a:font script="Sora" typeface="Nirmala UI"/><a:font script="Tale" typeface="Microsoft Tai Le"/><a:font script="Talu" typeface="Microsoft New Tai Lue"/><a:font script="Tfng" typeface="Ebrima"/></a:majorFont><a:minorFont><a:latin typeface="Calibri" panose="020F0502020204030204"/><a:ea typeface=""/><a:cs typeface=""/><a:font script="Jpan" typeface="游明朝"/><a:font script="Hang" typeface="맑은 고딕"/><a:font script="Hans" typeface="等线"/><a:font script="Hant" typeface="新細明體"/><a:font script="Arab" typeface="Arial"/><a:font script="Hebr" typeface="Arial"/><a:font script="Thai" typeface="Cordia New"/><a:font script="Ethi" typeface="Nyala"/><a:font script="Beng" typeface="Vrinda"/><a:font script="Gujr" typeface="Shruti"/><a:font script="Khmr" typeface="DaunPenh"/><a:font script="Knda" typeface="Tunga"/><a:font script="Guru" typeface="Raavi"/><a:font script="Cans" typeface="Euphemia"/><a:font script="Cher" typeface="Plantagenet Cherokee"/><a:font script="Yiii" typeface="Microsoft Yi Baiti"/><a:font script="Tibt" typeface="Microsoft Himalaya"/><a:font script="Thaa" typeface="MV Boli"/><a:font script="Deva" typeface="Mangal"/><a:font script="Telu" typeface="Gautami"/><a:font script="Taml" typeface="Latha"/><a:font script="Syrc" typeface="Estrangelo Edessa"/><a:font script="Orya" typeface="Kalinga"/><a:font script="Mlym" typeface="Kartika"/><a:font script="Laoo" typeface="DokChampa"/><a:font script="Sinh" typeface="Iskoola Pota"/><a:font script="Mong" typeface="Mongolian Baiti"/><a:font script="Viet" typeface="Arial"/><a:font script="Uigh" typeface="Microsoft Uighur"/><a:font script="Geor" typeface="Sylfaen"/><a:font script="Armn" typeface="Arial"/><a:font script="Bugi" typeface="Leelawadee UI"/><a:font script="Bopo" typeface="Microsoft JhengHei"/><a:font script="Java" typeface="Javanese Text"/><a:font script="Lisu" typeface="Segoe UI"/><a:font script="Mymr" typeface="Myanmar Text"/><a:font script="Nkoo" typeface="Ebrima"/><a:font script="Olck" typeface="Nirmala UI"/><a:font script="Osma" typeface="Ebrima"/><a:font script="Phag" typeface="Phagspa"/><a:font script="Syrn" typeface="Estrangelo Edessa"/><a:font script="Syrj" typeface="Estrangelo Edessa"/><a:font script="Syre" typeface="Estrangelo Edessa"/><a:font script="Sora" typeface="Nirmala UI"/><a:font script="Tale" typeface="Microsoft Tai Le"/><a:font script="Talu" typeface="Microsoft New Tai Lue"/><a:font script="Tfng" typeface="Ebrima"/></a:minorFont></a:fontScheme><a:fmtScheme name="Office"><a:fillStyleLst><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:lumMod val="110000"/><a:satMod val="105000"/><a:tint val="67000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:lumMod val="105000"/><a:satMod val="103000"/><a:tint val="73000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:lumMod val="105000"/><a:satMod val="109000"/><a:tint val="81000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:satMod val="103000"/><a:lumMod val="102000"/><a:tint val="94000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:satMod val="110000"/><a:lumMod val="100000"/><a:shade val="100000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:lumMod val="99000"/><a:satMod val="120000"/><a:shade val="78000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill></a:fillStyleLst><a:lnStyleLst><a:ln w="6350" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln><a:ln w="12700" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln><a:ln w="19050" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln></a:lnStyleLst><a:effectStyleLst><a:effectStyle><a:effectLst/></a:effectStyle><a:effectStyle><a:effectLst/></a:effectStyle><a:effectStyle><a:effectLst><a:outerShdw blurRad="57150" dist="19050" dir="5400000" algn="ctr" rotWithShape="0"><a:srgbClr val="000000"><a:alpha val="63000"/></a:srgbClr></a:outerShdw></a:effectLst></a:effectStyle></a:effectStyleLst><a:bgFillStyleLst><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:solidFill><a:schemeClr val="phClr"><a:tint val="95000"/><a:satMod val="170000"/></a:schemeClr></a:solidFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:tint val="93000"/><a:satMod val="150000"/><a:shade val="98000"/><a:lumMod val="102000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:tint val="98000"/><a:satMod val="130000"/><a:shade val="90000"/><a:lumMod val="103000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:shade val="63000"/><a:satMod val="120000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill></a:bgFillStyleLst></a:fmtScheme></a:themeElements><a:objectDefaults/><a:extraClrSchemeLst/><a:extLst><a:ext uri="{05A4C25C-085E-4340-85A3-A5531E510DB2}"><thm15:themeFamily xmlns:thm15="http://schemas.microsoft.com/office/thememl/2012/main" name="Office Theme" id="{62F939B6-93AF-4DB8-9C6B-D6C7DFDC589F}" vid="{4A3C46E8-61CC-4603-A589-7422A47A8E4A}"/></a:ext></a:extLst></a:theme> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/webSettings.xml b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/webSettings.xml
new file mode 100644
index 00000000..629ae06a
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-gs.xml.extract.docx.dir.ref/word/webSettings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:webSettings xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:optimizeForBrowser/><w:allowPNG/></w:webSettings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/[Content_Types].xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/[Content_Types].xml
new file mode 100644
index 00000000..07d88cca
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/[Content_Types].xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Types xmlns="http://schemas.openxmlformats.org/package/2006/content-types"><Default Extension="rels" ContentType="application/vnd.openxmlformats-package.relationships+xml"/><Default Extension="xml" ContentType="application/xml"/><Override PartName="/word/document.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.document.main+xml"/><Override PartName="/word/styles.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.styles+xml"/><Override PartName="/word/settings.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.settings+xml"/><Override PartName="/word/webSettings.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.webSettings+xml"/><Override PartName="/word/fontTable.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.fontTable+xml"/><Override PartName="/word/theme/theme1.xml" ContentType="application/vnd.openxmlformats-officedocument.theme+xml"/><Override PartName="/docProps/core.xml" ContentType="application/vnd.openxmlformats-package.core-properties+xml"/><Override PartName="/docProps/app.xml" ContentType="application/vnd.openxmlformats-officedocument.extended-properties+xml"/></Types> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/_rels/.rels b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/_rels/.rels
new file mode 100644
index 00000000..32548d42
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/_rels/.rels
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/extended-properties" Target="docProps/app.xml"/><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/package/2006/relationships/metadata/core-properties" Target="docProps/core.xml"/><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument" Target="word/document.xml"/></Relationships> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/docProps/app.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/docProps/app.xml
new file mode 100644
index 00000000..eb8dd2e5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/docProps/app.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Properties xmlns="http://schemas.openxmlformats.org/officeDocument/2006/extended-properties" xmlns:vt="http://schemas.openxmlformats.org/officeDocument/2006/docPropsVTypes"><Template>Normal.dotm</Template><TotalTime>3</TotalTime><Pages>1</Pages><Words>2</Words><Characters>18</Characters><Application>Microsoft Office Word</Application><DocSecurity>0</DocSecurity><Lines>1</Lines><Paragraphs>1</Paragraphs><ScaleCrop>false</ScaleCrop><Company></Company><LinksUpToDate>false</LinksUpToDate><CharactersWithSpaces>19</CharactersWithSpaces><SharedDoc>false</SharedDoc><HyperlinksChanged>false</HyperlinksChanged><AppVersion>16.0000</AppVersion></Properties> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/docProps/core.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/docProps/core.xml
new file mode 100644
index 00000000..195d77a9
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/docProps/core.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<cp:coreProperties xmlns:cp="http://schemas.openxmlformats.org/package/2006/metadata/core-properties" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:dcterms="http://purl.org/dc/terms/" xmlns:dcmitype="http://purl.org/dc/dcmitype/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><dc:title></dc:title><dc:subject></dc:subject><dc:creator></dc:creator><cp:keywords></cp:keywords><dc:description></dc:description><cp:lastModifiedBy></cp:lastModifiedBy><cp:revision>1</cp:revision><dcterms:created xsi:type="dcterms:W3CDTF">2020-09-25T17:04:00Z</dcterms:created><dcterms:modified xsi:type="dcterms:W3CDTF">2020-09-25T17:07:00Z</dcterms:modified></cp:coreProperties> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/_rels/document.xml.rels b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/_rels/document.xml.rels
new file mode 100644
index 00000000..3b2b7f8c
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/_rels/document.xml.rels
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/webSettings" Target="webSettings.xml"/><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/settings" Target="settings.xml"/><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles" Target="styles.xml"/><Relationship Id="rId5" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme" Target="theme/theme1.xml"/><Relationship Id="rId4" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/fontTable" Target="fontTable.xml"/></Relationships> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/document.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/document.xml
new file mode 100644
index 00000000..d18a0195
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/document.xml
@@ -0,0 +1,321 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:document xmlns:wpc="http://schemas.microsoft.com/office/word/2010/wordprocessingCanvas" xmlns:cx="http://schemas.microsoft.com/office/drawing/2014/chartex" xmlns:cx1="http://schemas.microsoft.com/office/drawing/2015/9/8/chartex" xmlns:cx2="http://schemas.microsoft.com/office/drawing/2015/10/21/chartex" xmlns:cx3="http://schemas.microsoft.com/office/drawing/2016/5/9/chartex" xmlns:cx4="http://schemas.microsoft.com/office/drawing/2016/5/10/chartex" xmlns:cx5="http://schemas.microsoft.com/office/drawing/2016/5/11/chartex" xmlns:cx6="http://schemas.microsoft.com/office/drawing/2016/5/12/chartex" xmlns:cx7="http://schemas.microsoft.com/office/drawing/2016/5/13/chartex" xmlns:cx8="http://schemas.microsoft.com/office/drawing/2016/5/14/chartex" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:aink="http://schemas.microsoft.com/office/drawing/2016/ink" xmlns:am3d="http://schemas.microsoft.com/office/drawing/2017/model3d" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:m="http://schemas.openxmlformats.org/officeDocument/2006/math" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:wp14="http://schemas.microsoft.com/office/word/2010/wordprocessingDrawing" xmlns:wp="http://schemas.openxmlformats.org/drawingml/2006/wordprocessingDrawing" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" xmlns:wpg="http://schemas.microsoft.com/office/word/2010/wordprocessingGroup" xmlns:wpi="http://schemas.microsoft.com/office/word/2010/wordprocessingInk" xmlns:wne="http://schemas.microsoft.com/office/word/2006/wordml" xmlns:wps="http://schemas.microsoft.com/office/word/2010/wordprocessingShape" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex wp14"><w:body>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was one who was famed for the number of things He </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-BoldMT" w:hAnsi="CourierNewPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">forgot </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">when he entered the ship: His umbrella, his watch, all his jewels and rings, And the clothes he had bought for the trip. He had </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-ItalicMT" w:hAnsi="CourierNewPS-ItalicMT"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">forty-two</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve"> boxes, all carefully packed, With his name painted clearly on each: But, since he omitted to mention the fact, They were all left behind on the beach.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">The crew was complete: it included a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Boots</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">&#x2014; A maker of Bonnets and Hoods&#x2014; A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Barrister</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, brought to arrange their disputes&#x2014; And a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Broker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, to value their goods.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Billiard-marker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, whose skill was immense, Might perhaps have won more than his share&#x2014; But a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Banker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, engaged at enormous expense, Had the whole of their </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-ItalicMT" w:hAnsi="TimesNewRomanPS-ItalicMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">cash </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">in his care.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was also a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Beaver</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, that paced on the deck, Or would sit making lace in the bow: And had often (the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">said) saved them from wreck, Though none of the sailors knew how.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">!&quot; the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">cried,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> As he landed his crew with care;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Supporting each man on the top of the tide</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> By a finger entwined in his hair.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it twice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> That alone should encourage the crew.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it thrice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> What I tell you </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">three </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">times is true.&quot;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">There was a young man of </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Madras</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Whose balls were </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">constructed </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">of brass,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">When jangled together,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">They played &#x201c;</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Stormy Weather</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&#x201d;,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="32.000000"/><w:szCs w:val="24.000000"/></w:rPr><w:t xml:space="preserve">lightning</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">shot out of his ass.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">A Python, I should not advise,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">For it needs a doctor for its eyes,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And has the Measles yearly.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">However, if </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">you feel</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> inclined</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">To get one (to improve your mind,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And not from fashion merely),</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Allow no </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">music</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> near its cage;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And when it </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">flies</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> into a rage</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Chastise it, most severely.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">I had an Aunt in Yucatan</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Who bought a Python from a man</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And kept it for a pet.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">She </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">died</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">, because she never knew</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">These simple little rules and few; &#x2014;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">The snake is living yet.</w:t></w:r>
+</w:p></w:body></w:document> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/fontTable.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/fontTable.xml
new file mode 100644
index 00000000..a39546e5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/fontTable.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:fonts xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:font w:name="Calibri"><w:panose1 w:val="020F0502020204030204"/><w:charset w:val="00"/><w:family w:val="swiss"/><w:pitch w:val="variable"/><w:sig w:usb0="E4002EFF" w:usb1="C000247B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font><w:font w:name="Times New Roman"><w:panose1 w:val="02020603050405020304"/><w:charset w:val="00"/><w:family w:val="roman"/><w:pitch w:val="variable"/><w:sig w:usb0="E0002EFF" w:usb1="C000785B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font><w:font w:name="Calibri Light"><w:panose1 w:val="020F0302020204030204"/><w:charset w:val="00"/><w:family w:val="swiss"/><w:pitch w:val="variable"/><w:sig w:usb0="E4002EFF" w:usb1="C000247B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font></w:fonts> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/settings.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/settings.xml
new file mode 100644
index 00000000..c403540d
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/settings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:settings xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:m="http://schemas.openxmlformats.org/officeDocument/2006/math" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" xmlns:sl="http://schemas.openxmlformats.org/schemaLibrary/2006/main" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:zoom w:percent="100"/><w:proofState w:spelling="clean" w:grammar="clean"/><w:defaultTabStop w:val="720"/><w:characterSpacingControl w:val="doNotCompress"/><w:compat><w:compatSetting w:name="compatibilityMode" w:uri="http://schemas.microsoft.com/office/word" w:val="15"/><w:compatSetting w:name="overrideTableStyleFontSizeAndJustification" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="enableOpenTypeFeatures" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="doNotFlipMirrorIndents" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="differentiateMultirowTableHeaders" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="useWord2013TrackBottomHyphenation" w:uri="http://schemas.microsoft.com/office/word" w:val="0"/></w:compat><w:rsids><w:rsidRoot w:val="007F4427"/><w:rsid w:val="00255448"/><w:rsid w:val="007F4427"/></w:rsids><m:mathPr><m:mathFont m:val="Cambria Math"/><m:brkBin m:val="before"/><m:brkBinSub m:val="--"/><m:smallFrac m:val="0"/><m:dispDef/><m:lMargin m:val="0"/><m:rMargin m:val="0"/><m:defJc m:val="centerGroup"/><m:wrapIndent m:val="1440"/><m:intLim m:val="subSup"/><m:naryLim m:val="undOvr"/></m:mathPr><w:themeFontLang w:val="en-GB"/><w:clrSchemeMapping w:bg1="light1" w:t1="dark1" w:bg2="light2" w:t2="dark2" w:accent1="accent1" w:accent2="accent2" w:accent3="accent3" w:accent4="accent4" w:accent5="accent5" w:accent6="accent6" w:hyperlink="hyperlink" w:followedHyperlink="followedHyperlink"/><w:shapeDefaults><o:shapedefaults v:ext="edit" spidmax="1026"/><o:shapelayout v:ext="edit"><o:idmap v:ext="edit" data="1"/></o:shapelayout></w:shapeDefaults><w:decimalSymbol w:val="."/><w:listSeparator w:val=","/><w14:docId w14:val="32E52EF8"/><w15:chartTrackingRefBased/><w15:docId w15:val="{A10F59F7-497D-44D4-A338-47719734E7A0}"/></w:settings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/styles.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/styles.xml
new file mode 100644
index 00000000..38e5e2bd
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/styles.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:styles xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:docDefaults><w:rPrDefault><w:rPr><w:rFonts w:asciiTheme="minorHAnsi" w:eastAsiaTheme="minorHAnsi" w:hAnsiTheme="minorHAnsi" w:cstheme="minorBidi"/><w:sz w:val="22"/><w:szCs w:val="22"/><w:lang w:val="en-GB" w:eastAsia="en-US" w:bidi="ar-SA"/></w:rPr></w:rPrDefault><w:pPrDefault><w:pPr><w:spacing w:after="160" w:line="259" w:lineRule="auto"/></w:pPr></w:pPrDefault></w:docDefaults><w:latentStyles w:defLockedState="0" w:defUIPriority="99" w:defSemiHidden="0" w:defUnhideWhenUsed="0" w:defQFormat="0" w:count="376"><w:lsdException w:name="Normal" w:uiPriority="0" w:qFormat="1"/><w:lsdException w:name="heading 1" w:uiPriority="9" w:qFormat="1"/><w:lsdException w:name="heading 2" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 3" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 4" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 5" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 6" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 7" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 8" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 9" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="index 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 9" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 1" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 2" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 3" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 4" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 5" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 6" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 7" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 8" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 9" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footnote text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="header" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footer" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="caption" w:semiHidden="1" w:uiPriority="35" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="table of figures" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="envelope address" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="envelope return" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footnote reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="line number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="page number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="endnote reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="endnote text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="table of authorities" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="macro" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="toa heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Title" w:uiPriority="10" w:qFormat="1"/><w:lsdException w:name="Closing" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Signature" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Default Paragraph Font" w:semiHidden="1" w:uiPriority="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Message Header" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Subtitle" w:uiPriority="11" w:qFormat="1"/><w:lsdException w:name="Salutation" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Date" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text First Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text First Indent 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Note Heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Block Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Hyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="FollowedHyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Strong" w:uiPriority="22" w:qFormat="1"/><w:lsdException w:name="Emphasis" w:uiPriority="20" w:qFormat="1"/><w:lsdException w:name="Document Map" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Plain Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="E-mail Signature" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Top of Form" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Bottom of Form" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal (Web)" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Acronym" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Address" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Cite" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Code" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Definition" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Keyboard" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Preformatted" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Sample" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Typewriter" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Variable" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal Table" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation subject" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="No List" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Contemporary" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Elegant" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Professional" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Subtle 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Subtle 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Balloon Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid" w:uiPriority="39"/><w:lsdException w:name="Table Theme" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Placeholder Text" w:semiHidden="1"/><w:lsdException w:name="No Spacing" w:uiPriority="1" w:qFormat="1"/><w:lsdException w:name="Light Shading" w:uiPriority="60"/><w:lsdException w:name="Light List" w:uiPriority="61"/><w:lsdException w:name="Light Grid" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2" w:uiPriority="64"/><w:lsdException w:name="Medium List 1" w:uiPriority="65"/><w:lsdException w:name="Medium List 2" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3" w:uiPriority="69"/><w:lsdException w:name="Dark List" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading" w:uiPriority="71"/><w:lsdException w:name="Colorful List" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 1" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 1" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 1" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 1" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 1" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 1" w:uiPriority="65"/><w:lsdException w:name="Revision" w:semiHidden="1"/><w:lsdException w:name="List Paragraph" w:uiPriority="34" w:qFormat="1"/><w:lsdException w:name="Quote" w:uiPriority="29" w:qFormat="1"/><w:lsdException w:name="Intense Quote" w:uiPriority="30" w:qFormat="1"/><w:lsdException w:name="Medium List 2 Accent 1" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 1" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 1" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 1" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 1" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 1" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 1" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 1" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 2" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 2" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 2" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 2" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 2" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 2" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 2" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 2" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 2" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 2" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 2" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 2" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 2" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 2" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 3" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 3" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 3" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 3" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 3" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 3" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 3" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 3" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 3" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 3" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 3" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 3" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 3" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 3" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 4" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 4" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 4" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 4" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 4" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 4" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 4" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 4" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 4" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 4" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 4" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 4" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 4" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 4" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 5" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 5" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 5" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 5" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 5" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 5" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 5" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 5" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 5" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 5" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 5" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 5" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 5" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 5" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 6" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 6" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 6" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 6" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 6" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 6" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 6" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 6" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 6" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 6" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 6" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 6" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 6" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 6" w:uiPriority="73"/><w:lsdException w:name="Subtle Emphasis" w:uiPriority="19" w:qFormat="1"/><w:lsdException w:name="Intense Emphasis" w:uiPriority="21" w:qFormat="1"/><w:lsdException w:name="Subtle Reference" w:uiPriority="31" w:qFormat="1"/><w:lsdException w:name="Intense Reference" w:uiPriority="32" w:qFormat="1"/><w:lsdException w:name="Book Title" w:uiPriority="33" w:qFormat="1"/><w:lsdException w:name="Bibliography" w:semiHidden="1" w:uiPriority="37" w:unhideWhenUsed="1"/><w:lsdException w:name="TOC Heading" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="Plain Table 1" w:uiPriority="41"/><w:lsdException w:name="Plain Table 2" w:uiPriority="42"/><w:lsdException w:name="Plain Table 3" w:uiPriority="43"/><w:lsdException w:name="Plain Table 4" w:uiPriority="44"/><w:lsdException w:name="Plain Table 5" w:uiPriority="45"/><w:lsdException w:name="Grid Table Light" w:uiPriority="40"/><w:lsdException w:name="Grid Table 1 Light" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 1" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 1" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 1" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 1" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 1" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 1" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 1" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 2" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 2" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 2" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 2" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 2" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 2" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 2" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 3" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 3" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 3" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 3" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 3" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 3" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 3" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 4" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 4" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 4" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 4" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 4" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 4" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 4" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 5" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 5" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 5" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 5" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 5" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 5" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 5" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 6" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 6" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 6" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 6" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 6" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 6" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 6" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light" w:uiPriority="46"/><w:lsdException w:name="List Table 2" w:uiPriority="47"/><w:lsdException w:name="List Table 3" w:uiPriority="48"/><w:lsdException w:name="List Table 4" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 1" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 1" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 1" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 1" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 1" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 1" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 1" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 2" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 2" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 2" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 2" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 2" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 2" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 2" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 3" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 3" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 3" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 3" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 3" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 3" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 3" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 4" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 4" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 4" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 4" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 4" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 4" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 4" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 5" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 5" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 5" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 5" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 5" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 5" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 5" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 6" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 6" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 6" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 6" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 6" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 6" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 6" w:uiPriority="52"/><w:lsdException w:name="Mention" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Smart Hyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Hashtag" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Unresolved Mention" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Smart Link" w:semiHidden="1" w:unhideWhenUsed="1"/></w:latentStyles><w:style w:type="paragraph" w:default="1" w:styleId="Normal"><w:name w:val="Normal"/><w:qFormat/></w:style><w:style w:type="character" w:default="1" w:styleId="DefaultParagraphFont"><w:name w:val="Default Paragraph Font"/><w:uiPriority w:val="1"/><w:semiHidden/><w:unhideWhenUsed/></w:style><w:style w:type="table" w:default="1" w:styleId="TableNormal"><w:name w:val="Normal Table"/><w:uiPriority w:val="99"/><w:semiHidden/><w:unhideWhenUsed/><w:tblPr><w:tblInd w:w="0" w:type="dxa"/><w:tblCellMar><w:top w:w="0" w:type="dxa"/><w:left w:w="108" w:type="dxa"/><w:bottom w:w="0" w:type="dxa"/><w:right w:w="108" w:type="dxa"/></w:tblCellMar></w:tblPr></w:style><w:style w:type="numbering" w:default="1" w:styleId="NoList"><w:name w:val="No List"/><w:uiPriority w:val="99"/><w:semiHidden/><w:unhideWhenUsed/></w:style></w:styles> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/theme/theme1.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/theme/theme1.xml
new file mode 100644
index 00000000..d1a502f8
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/theme/theme1.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<a:theme xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main" name="Office Theme"><a:themeElements><a:clrScheme name="Office"><a:dk1><a:sysClr val="windowText" lastClr="000000"/></a:dk1><a:lt1><a:sysClr val="window" lastClr="FFFFFF"/></a:lt1><a:dk2><a:srgbClr val="44546A"/></a:dk2><a:lt2><a:srgbClr val="E7E6E6"/></a:lt2><a:accent1><a:srgbClr val="4472C4"/></a:accent1><a:accent2><a:srgbClr val="ED7D31"/></a:accent2><a:accent3><a:srgbClr val="A5A5A5"/></a:accent3><a:accent4><a:srgbClr val="FFC000"/></a:accent4><a:accent5><a:srgbClr val="5B9BD5"/></a:accent5><a:accent6><a:srgbClr val="70AD47"/></a:accent6><a:hlink><a:srgbClr val="0563C1"/></a:hlink><a:folHlink><a:srgbClr val="954F72"/></a:folHlink></a:clrScheme><a:fontScheme name="Office"><a:majorFont><a:latin typeface="Calibri Light" panose="020F0302020204030204"/><a:ea typeface=""/><a:cs typeface=""/><a:font script="Jpan" typeface="游ゴシック Light"/><a:font script="Hang" typeface="맑은 고딕"/><a:font script="Hans" typeface="等线 Light"/><a:font script="Hant" typeface="新細明體"/><a:font script="Arab" typeface="Times New Roman"/><a:font script="Hebr" typeface="Times New Roman"/><a:font script="Thai" typeface="Angsana New"/><a:font script="Ethi" typeface="Nyala"/><a:font script="Beng" typeface="Vrinda"/><a:font script="Gujr" typeface="Shruti"/><a:font script="Khmr" typeface="MoolBoran"/><a:font script="Knda" typeface="Tunga"/><a:font script="Guru" typeface="Raavi"/><a:font script="Cans" typeface="Euphemia"/><a:font script="Cher" typeface="Plantagenet Cherokee"/><a:font script="Yiii" typeface="Microsoft Yi Baiti"/><a:font script="Tibt" typeface="Microsoft Himalaya"/><a:font script="Thaa" typeface="MV Boli"/><a:font script="Deva" typeface="Mangal"/><a:font script="Telu" typeface="Gautami"/><a:font script="Taml" typeface="Latha"/><a:font script="Syrc" typeface="Estrangelo Edessa"/><a:font script="Orya" typeface="Kalinga"/><a:font script="Mlym" typeface="Kartika"/><a:font script="Laoo" typeface="DokChampa"/><a:font script="Sinh" typeface="Iskoola Pota"/><a:font script="Mong" typeface="Mongolian Baiti"/><a:font script="Viet" typeface="Times New Roman"/><a:font script="Uigh" typeface="Microsoft Uighur"/><a:font script="Geor" typeface="Sylfaen"/><a:font script="Armn" typeface="Arial"/><a:font script="Bugi" typeface="Leelawadee UI"/><a:font script="Bopo" typeface="Microsoft JhengHei"/><a:font script="Java" typeface="Javanese Text"/><a:font script="Lisu" typeface="Segoe UI"/><a:font script="Mymr" typeface="Myanmar Text"/><a:font script="Nkoo" typeface="Ebrima"/><a:font script="Olck" typeface="Nirmala UI"/><a:font script="Osma" typeface="Ebrima"/><a:font script="Phag" typeface="Phagspa"/><a:font script="Syrn" typeface="Estrangelo Edessa"/><a:font script="Syrj" typeface="Estrangelo Edessa"/><a:font script="Syre" typeface="Estrangelo Edessa"/><a:font script="Sora" typeface="Nirmala UI"/><a:font script="Tale" typeface="Microsoft Tai Le"/><a:font script="Talu" typeface="Microsoft New Tai Lue"/><a:font script="Tfng" typeface="Ebrima"/></a:majorFont><a:minorFont><a:latin typeface="Calibri" panose="020F0502020204030204"/><a:ea typeface=""/><a:cs typeface=""/><a:font script="Jpan" typeface="游明朝"/><a:font script="Hang" typeface="맑은 고딕"/><a:font script="Hans" typeface="等线"/><a:font script="Hant" typeface="新細明體"/><a:font script="Arab" typeface="Arial"/><a:font script="Hebr" typeface="Arial"/><a:font script="Thai" typeface="Cordia New"/><a:font script="Ethi" typeface="Nyala"/><a:font script="Beng" typeface="Vrinda"/><a:font script="Gujr" typeface="Shruti"/><a:font script="Khmr" typeface="DaunPenh"/><a:font script="Knda" typeface="Tunga"/><a:font script="Guru" typeface="Raavi"/><a:font script="Cans" typeface="Euphemia"/><a:font script="Cher" typeface="Plantagenet Cherokee"/><a:font script="Yiii" typeface="Microsoft Yi Baiti"/><a:font script="Tibt" typeface="Microsoft Himalaya"/><a:font script="Thaa" typeface="MV Boli"/><a:font script="Deva" typeface="Mangal"/><a:font script="Telu" typeface="Gautami"/><a:font script="Taml" typeface="Latha"/><a:font script="Syrc" typeface="Estrangelo Edessa"/><a:font script="Orya" typeface="Kalinga"/><a:font script="Mlym" typeface="Kartika"/><a:font script="Laoo" typeface="DokChampa"/><a:font script="Sinh" typeface="Iskoola Pota"/><a:font script="Mong" typeface="Mongolian Baiti"/><a:font script="Viet" typeface="Arial"/><a:font script="Uigh" typeface="Microsoft Uighur"/><a:font script="Geor" typeface="Sylfaen"/><a:font script="Armn" typeface="Arial"/><a:font script="Bugi" typeface="Leelawadee UI"/><a:font script="Bopo" typeface="Microsoft JhengHei"/><a:font script="Java" typeface="Javanese Text"/><a:font script="Lisu" typeface="Segoe UI"/><a:font script="Mymr" typeface="Myanmar Text"/><a:font script="Nkoo" typeface="Ebrima"/><a:font script="Olck" typeface="Nirmala UI"/><a:font script="Osma" typeface="Ebrima"/><a:font script="Phag" typeface="Phagspa"/><a:font script="Syrn" typeface="Estrangelo Edessa"/><a:font script="Syrj" typeface="Estrangelo Edessa"/><a:font script="Syre" typeface="Estrangelo Edessa"/><a:font script="Sora" typeface="Nirmala UI"/><a:font script="Tale" typeface="Microsoft Tai Le"/><a:font script="Talu" typeface="Microsoft New Tai Lue"/><a:font script="Tfng" typeface="Ebrima"/></a:minorFont></a:fontScheme><a:fmtScheme name="Office"><a:fillStyleLst><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:lumMod val="110000"/><a:satMod val="105000"/><a:tint val="67000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:lumMod val="105000"/><a:satMod val="103000"/><a:tint val="73000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:lumMod val="105000"/><a:satMod val="109000"/><a:tint val="81000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:satMod val="103000"/><a:lumMod val="102000"/><a:tint val="94000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:satMod val="110000"/><a:lumMod val="100000"/><a:shade val="100000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:lumMod val="99000"/><a:satMod val="120000"/><a:shade val="78000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill></a:fillStyleLst><a:lnStyleLst><a:ln w="6350" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln><a:ln w="12700" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln><a:ln w="19050" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln></a:lnStyleLst><a:effectStyleLst><a:effectStyle><a:effectLst/></a:effectStyle><a:effectStyle><a:effectLst/></a:effectStyle><a:effectStyle><a:effectLst><a:outerShdw blurRad="57150" dist="19050" dir="5400000" algn="ctr" rotWithShape="0"><a:srgbClr val="000000"><a:alpha val="63000"/></a:srgbClr></a:outerShdw></a:effectLst></a:effectStyle></a:effectStyleLst><a:bgFillStyleLst><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:solidFill><a:schemeClr val="phClr"><a:tint val="95000"/><a:satMod val="170000"/></a:schemeClr></a:solidFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:tint val="93000"/><a:satMod val="150000"/><a:shade val="98000"/><a:lumMod val="102000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:tint val="98000"/><a:satMod val="130000"/><a:shade val="90000"/><a:lumMod val="103000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:shade val="63000"/><a:satMod val="120000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill></a:bgFillStyleLst></a:fmtScheme></a:themeElements><a:objectDefaults/><a:extraClrSchemeLst/><a:extLst><a:ext uri="{05A4C25C-085E-4340-85A3-A5531E510DB2}"><thm15:themeFamily xmlns:thm15="http://schemas.microsoft.com/office/thememl/2012/main" name="Office Theme" id="{62F939B6-93AF-4DB8-9C6B-D6C7DFDC589F}" vid="{4A3C46E8-61CC-4603-A589-7422A47A8E4A}"/></a:ext></a:extLst></a:theme> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/webSettings.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/webSettings.xml
new file mode 100644
index 00000000..629ae06a
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-autosplit.docx.dir.ref/word/webSettings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:webSettings xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:optimizeForBrowser/><w:allowPNG/></w:webSettings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/[Content_Types].xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/[Content_Types].xml
new file mode 100644
index 00000000..07d88cca
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/[Content_Types].xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Types xmlns="http://schemas.openxmlformats.org/package/2006/content-types"><Default Extension="rels" ContentType="application/vnd.openxmlformats-package.relationships+xml"/><Default Extension="xml" ContentType="application/xml"/><Override PartName="/word/document.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.document.main+xml"/><Override PartName="/word/styles.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.styles+xml"/><Override PartName="/word/settings.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.settings+xml"/><Override PartName="/word/webSettings.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.webSettings+xml"/><Override PartName="/word/fontTable.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.fontTable+xml"/><Override PartName="/word/theme/theme1.xml" ContentType="application/vnd.openxmlformats-officedocument.theme+xml"/><Override PartName="/docProps/core.xml" ContentType="application/vnd.openxmlformats-package.core-properties+xml"/><Override PartName="/docProps/app.xml" ContentType="application/vnd.openxmlformats-officedocument.extended-properties+xml"/></Types> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/_rels/.rels b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/_rels/.rels
new file mode 100644
index 00000000..32548d42
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/_rels/.rels
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/extended-properties" Target="docProps/app.xml"/><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/package/2006/relationships/metadata/core-properties" Target="docProps/core.xml"/><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument" Target="word/document.xml"/></Relationships> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/docProps/app.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/docProps/app.xml
new file mode 100644
index 00000000..eb8dd2e5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/docProps/app.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Properties xmlns="http://schemas.openxmlformats.org/officeDocument/2006/extended-properties" xmlns:vt="http://schemas.openxmlformats.org/officeDocument/2006/docPropsVTypes"><Template>Normal.dotm</Template><TotalTime>3</TotalTime><Pages>1</Pages><Words>2</Words><Characters>18</Characters><Application>Microsoft Office Word</Application><DocSecurity>0</DocSecurity><Lines>1</Lines><Paragraphs>1</Paragraphs><ScaleCrop>false</ScaleCrop><Company></Company><LinksUpToDate>false</LinksUpToDate><CharactersWithSpaces>19</CharactersWithSpaces><SharedDoc>false</SharedDoc><HyperlinksChanged>false</HyperlinksChanged><AppVersion>16.0000</AppVersion></Properties> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/docProps/core.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/docProps/core.xml
new file mode 100644
index 00000000..195d77a9
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/docProps/core.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<cp:coreProperties xmlns:cp="http://schemas.openxmlformats.org/package/2006/metadata/core-properties" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:dcterms="http://purl.org/dc/terms/" xmlns:dcmitype="http://purl.org/dc/dcmitype/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><dc:title></dc:title><dc:subject></dc:subject><dc:creator></dc:creator><cp:keywords></cp:keywords><dc:description></dc:description><cp:lastModifiedBy></cp:lastModifiedBy><cp:revision>1</cp:revision><dcterms:created xsi:type="dcterms:W3CDTF">2020-09-25T17:04:00Z</dcterms:created><dcterms:modified xsi:type="dcterms:W3CDTF">2020-09-25T17:07:00Z</dcterms:modified></cp:coreProperties> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/_rels/document.xml.rels b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/_rels/document.xml.rels
new file mode 100644
index 00000000..3b2b7f8c
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/_rels/document.xml.rels
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/webSettings" Target="webSettings.xml"/><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/settings" Target="settings.xml"/><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles" Target="styles.xml"/><Relationship Id="rId5" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme" Target="theme/theme1.xml"/><Relationship Id="rId4" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/fontTable" Target="fontTable.xml"/></Relationships> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/document.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/document.xml
new file mode 100644
index 00000000..495c19b0
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/document.xml
@@ -0,0 +1,718 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:document xmlns:wpc="http://schemas.microsoft.com/office/word/2010/wordprocessingCanvas" xmlns:cx="http://schemas.microsoft.com/office/drawing/2014/chartex" xmlns:cx1="http://schemas.microsoft.com/office/drawing/2015/9/8/chartex" xmlns:cx2="http://schemas.microsoft.com/office/drawing/2015/10/21/chartex" xmlns:cx3="http://schemas.microsoft.com/office/drawing/2016/5/9/chartex" xmlns:cx4="http://schemas.microsoft.com/office/drawing/2016/5/10/chartex" xmlns:cx5="http://schemas.microsoft.com/office/drawing/2016/5/11/chartex" xmlns:cx6="http://schemas.microsoft.com/office/drawing/2016/5/12/chartex" xmlns:cx7="http://schemas.microsoft.com/office/drawing/2016/5/13/chartex" xmlns:cx8="http://schemas.microsoft.com/office/drawing/2016/5/14/chartex" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:aink="http://schemas.microsoft.com/office/drawing/2016/ink" xmlns:am3d="http://schemas.microsoft.com/office/drawing/2017/model3d" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:m="http://schemas.openxmlformats.org/officeDocument/2006/math" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:wp14="http://schemas.microsoft.com/office/word/2010/wordprocessingDrawing" xmlns:wp="http://schemas.openxmlformats.org/drawingml/2006/wordprocessingDrawing" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" xmlns:wpg="http://schemas.microsoft.com/office/word/2010/wordprocessingGroup" xmlns:wpi="http://schemas.microsoft.com/office/word/2010/wordprocessingInk" xmlns:wne="http://schemas.microsoft.com/office/word/2006/wordml" xmlns:wps="http://schemas.microsoft.com/office/word/2010/wordprocessingShape" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex wp14"><w:body>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>3197324</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>4602912</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2893510" cy="1885520"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="1" name="Text Box 1"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="10470858">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was one who was famed for the number of things He </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-BoldMT" w:hAnsi="CourierNewPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">forgot </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">when he entered the ship: His umbrella, his watch, all his jewels and rings, And the clothes he had bought for the trip. He had </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-ItalicMT" w:hAnsi="CourierNewPS-ItalicMT"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">forty-two</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve"> boxes, all carefully packed, With his name painted clearly on each: But, since he omitted to mention the fact, They were all left behind on the beach.</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 1" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was one who was famed for the number of things He </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-BoldMT" w:hAnsi="CourierNewPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">forgot </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">when he entered the ship: His umbrella, his watch, all his jewels and rings, And the clothes he had bought for the trip. He had </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-ItalicMT" w:hAnsi="CourierNewPS-ItalicMT"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">forty-two</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve"> boxes, all carefully packed, With his name painted clearly on each: But, since he omitted to mention the fact, They were all left behind on the beach.</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>840434</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>2075903</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2190228" cy="2819246"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="2" name="Text Box 2"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="-8517153">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">The crew was complete: it included a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Boots</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">&#x2014; A maker of Bonnets and Hoods&#x2014; A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Barrister</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, brought to arrange their disputes&#x2014; And a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Broker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, to value their goods.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Billiard-marker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, whose skill was immense, Might perhaps have won more than his share&#x2014; But a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Banker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, engaged at enormous expense, Had the whole of their </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-ItalicMT" w:hAnsi="TimesNewRomanPS-ItalicMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">cash </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">in his care.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was also a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Beaver</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, that paced on the deck, Or would sit making lace in the bow: And had often (the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">said) saved them from wreck, Though none of the sailors knew how.</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 2" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">The crew was complete: it included a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Boots</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">&#x2014; A maker of Bonnets and Hoods&#x2014; A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Barrister</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, brought to arrange their disputes&#x2014; And a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Broker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, to value their goods.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Billiard-marker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, whose skill was immense, Might perhaps have won more than his share&#x2014; But a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Banker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, engaged at enormous expense, Had the whole of their </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-ItalicMT" w:hAnsi="TimesNewRomanPS-ItalicMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">cash </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">in his care.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was also a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Beaver</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, that paced on the deck, Or would sit making lace in the bow: And had often (the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">said) saved them from wreck, Though none of the sailors knew how.</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>3428932</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>1309973</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2856636" cy="3710000"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="3" name="Text Box 3"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="6130096">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">!&quot; the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">cried,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> As he landed his crew with care;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Supporting each man on the top of the tide</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> By a finger entwined in his hair.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it twice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> That alone should encourage the crew.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it thrice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> What I tell you </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">three </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">times is true.&quot;</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 3" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">!&quot; the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">cried,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> As he landed his crew with care;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Supporting each man on the top of the tide</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> By a finger entwined in his hair.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it twice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> That alone should encourage the crew.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it thrice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> What I tell you </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">three </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">times is true.&quot;</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>4205387</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>51483</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2309037" cy="1989200"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="4" name="Text Box 4"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="1991926">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">There was a young man of </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Madras</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Whose balls were </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">constructed </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">of brass,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">When jangled together,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">They played &#x201c;</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Stormy Weather</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&#x201d;,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="32.000000"/><w:szCs w:val="24.000000"/></w:rPr><w:t xml:space="preserve">lightning</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">shot out of his ass.</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 4" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">There was a young man of </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Madras</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Whose balls were </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">constructed </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">of brass,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">When jangled together,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">They played &#x201c;</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Stormy Weather</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&#x201d;,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="32.000000"/><w:szCs w:val="24.000000"/></w:rPr><w:t xml:space="preserve">lightning</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">shot out of his ass.</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>1670564</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>-465543</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2090293" cy="5976900"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="5" name="Text Box 5"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="-1645562">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">A Python, I should not advise,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">For it needs a doctor for its eyes,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And has the Measles yearly.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">However, if </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">you feel</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> inclined</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">To get one (to improve your mind,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And not from fashion merely),</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Allow no </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">music</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> near its cage;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And when it </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">flies</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> into a rage</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Chastise it, most severely.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">I had an Aunt in Yucatan</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Who bought a Python from a man</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And kept it for a pet.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">She </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">died</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">, because she never knew</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">These simple little rules and few; &#x2014;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">The snake is living yet.</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 5" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">A Python, I should not advise,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">For it needs a doctor for its eyes,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And has the Measles yearly.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">However, if </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">you feel</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> inclined</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">To get one (to improve your mind,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And not from fashion merely),</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Allow no </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">music</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> near its cage;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And when it </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">flies</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> into a rage</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Chastise it, most severely.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">I had an Aunt in Yucatan</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Who bought a Python from a man</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And kept it for a pet.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">She </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">died</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">, because she never knew</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">These simple little rules and few; &#x2014;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">The snake is living yet.</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p></w:body></w:document> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/fontTable.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/fontTable.xml
new file mode 100644
index 00000000..a39546e5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/fontTable.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:fonts xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:font w:name="Calibri"><w:panose1 w:val="020F0502020204030204"/><w:charset w:val="00"/><w:family w:val="swiss"/><w:pitch w:val="variable"/><w:sig w:usb0="E4002EFF" w:usb1="C000247B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font><w:font w:name="Times New Roman"><w:panose1 w:val="02020603050405020304"/><w:charset w:val="00"/><w:family w:val="roman"/><w:pitch w:val="variable"/><w:sig w:usb0="E0002EFF" w:usb1="C000785B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font><w:font w:name="Calibri Light"><w:panose1 w:val="020F0302020204030204"/><w:charset w:val="00"/><w:family w:val="swiss"/><w:pitch w:val="variable"/><w:sig w:usb0="E4002EFF" w:usb1="C000247B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font></w:fonts> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/settings.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/settings.xml
new file mode 100644
index 00000000..c403540d
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/settings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:settings xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:m="http://schemas.openxmlformats.org/officeDocument/2006/math" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" xmlns:sl="http://schemas.openxmlformats.org/schemaLibrary/2006/main" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:zoom w:percent="100"/><w:proofState w:spelling="clean" w:grammar="clean"/><w:defaultTabStop w:val="720"/><w:characterSpacingControl w:val="doNotCompress"/><w:compat><w:compatSetting w:name="compatibilityMode" w:uri="http://schemas.microsoft.com/office/word" w:val="15"/><w:compatSetting w:name="overrideTableStyleFontSizeAndJustification" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="enableOpenTypeFeatures" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="doNotFlipMirrorIndents" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="differentiateMultirowTableHeaders" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="useWord2013TrackBottomHyphenation" w:uri="http://schemas.microsoft.com/office/word" w:val="0"/></w:compat><w:rsids><w:rsidRoot w:val="007F4427"/><w:rsid w:val="00255448"/><w:rsid w:val="007F4427"/></w:rsids><m:mathPr><m:mathFont m:val="Cambria Math"/><m:brkBin m:val="before"/><m:brkBinSub m:val="--"/><m:smallFrac m:val="0"/><m:dispDef/><m:lMargin m:val="0"/><m:rMargin m:val="0"/><m:defJc m:val="centerGroup"/><m:wrapIndent m:val="1440"/><m:intLim m:val="subSup"/><m:naryLim m:val="undOvr"/></m:mathPr><w:themeFontLang w:val="en-GB"/><w:clrSchemeMapping w:bg1="light1" w:t1="dark1" w:bg2="light2" w:t2="dark2" w:accent1="accent1" w:accent2="accent2" w:accent3="accent3" w:accent4="accent4" w:accent5="accent5" w:accent6="accent6" w:hyperlink="hyperlink" w:followedHyperlink="followedHyperlink"/><w:shapeDefaults><o:shapedefaults v:ext="edit" spidmax="1026"/><o:shapelayout v:ext="edit"><o:idmap v:ext="edit" data="1"/></o:shapelayout></w:shapeDefaults><w:decimalSymbol w:val="."/><w:listSeparator w:val=","/><w14:docId w14:val="32E52EF8"/><w15:chartTrackingRefBased/><w15:docId w15:val="{A10F59F7-497D-44D4-A338-47719734E7A0}"/></w:settings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/styles.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/styles.xml
new file mode 100644
index 00000000..38e5e2bd
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/styles.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:styles xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:docDefaults><w:rPrDefault><w:rPr><w:rFonts w:asciiTheme="minorHAnsi" w:eastAsiaTheme="minorHAnsi" w:hAnsiTheme="minorHAnsi" w:cstheme="minorBidi"/><w:sz w:val="22"/><w:szCs w:val="22"/><w:lang w:val="en-GB" w:eastAsia="en-US" w:bidi="ar-SA"/></w:rPr></w:rPrDefault><w:pPrDefault><w:pPr><w:spacing w:after="160" w:line="259" w:lineRule="auto"/></w:pPr></w:pPrDefault></w:docDefaults><w:latentStyles w:defLockedState="0" w:defUIPriority="99" w:defSemiHidden="0" w:defUnhideWhenUsed="0" w:defQFormat="0" w:count="376"><w:lsdException w:name="Normal" w:uiPriority="0" w:qFormat="1"/><w:lsdException w:name="heading 1" w:uiPriority="9" w:qFormat="1"/><w:lsdException w:name="heading 2" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 3" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 4" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 5" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 6" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 7" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 8" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 9" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="index 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 9" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 1" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 2" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 3" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 4" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 5" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 6" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 7" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 8" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 9" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footnote text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="header" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footer" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="caption" w:semiHidden="1" w:uiPriority="35" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="table of figures" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="envelope address" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="envelope return" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footnote reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="line number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="page number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="endnote reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="endnote text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="table of authorities" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="macro" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="toa heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Title" w:uiPriority="10" w:qFormat="1"/><w:lsdException w:name="Closing" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Signature" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Default Paragraph Font" w:semiHidden="1" w:uiPriority="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Message Header" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Subtitle" w:uiPriority="11" w:qFormat="1"/><w:lsdException w:name="Salutation" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Date" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text First Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text First Indent 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Note Heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Block Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Hyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="FollowedHyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Strong" w:uiPriority="22" w:qFormat="1"/><w:lsdException w:name="Emphasis" w:uiPriority="20" w:qFormat="1"/><w:lsdException w:name="Document Map" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Plain Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="E-mail Signature" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Top of Form" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Bottom of Form" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal (Web)" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Acronym" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Address" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Cite" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Code" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Definition" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Keyboard" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Preformatted" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Sample" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Typewriter" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Variable" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal Table" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation subject" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="No List" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Contemporary" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Elegant" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Professional" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Subtle 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Subtle 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Balloon Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid" w:uiPriority="39"/><w:lsdException w:name="Table Theme" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Placeholder Text" w:semiHidden="1"/><w:lsdException w:name="No Spacing" w:uiPriority="1" w:qFormat="1"/><w:lsdException w:name="Light Shading" w:uiPriority="60"/><w:lsdException w:name="Light List" w:uiPriority="61"/><w:lsdException w:name="Light Grid" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2" w:uiPriority="64"/><w:lsdException w:name="Medium List 1" w:uiPriority="65"/><w:lsdException w:name="Medium List 2" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3" w:uiPriority="69"/><w:lsdException w:name="Dark List" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading" w:uiPriority="71"/><w:lsdException w:name="Colorful List" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 1" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 1" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 1" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 1" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 1" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 1" w:uiPriority="65"/><w:lsdException w:name="Revision" w:semiHidden="1"/><w:lsdException w:name="List Paragraph" w:uiPriority="34" w:qFormat="1"/><w:lsdException w:name="Quote" w:uiPriority="29" w:qFormat="1"/><w:lsdException w:name="Intense Quote" w:uiPriority="30" w:qFormat="1"/><w:lsdException w:name="Medium List 2 Accent 1" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 1" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 1" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 1" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 1" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 1" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 1" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 1" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 2" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 2" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 2" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 2" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 2" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 2" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 2" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 2" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 2" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 2" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 2" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 2" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 2" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 2" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 3" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 3" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 3" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 3" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 3" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 3" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 3" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 3" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 3" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 3" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 3" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 3" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 3" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 3" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 4" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 4" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 4" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 4" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 4" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 4" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 4" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 4" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 4" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 4" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 4" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 4" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 4" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 4" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 5" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 5" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 5" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 5" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 5" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 5" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 5" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 5" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 5" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 5" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 5" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 5" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 5" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 5" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 6" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 6" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 6" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 6" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 6" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 6" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 6" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 6" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 6" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 6" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 6" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 6" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 6" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 6" w:uiPriority="73"/><w:lsdException w:name="Subtle Emphasis" w:uiPriority="19" w:qFormat="1"/><w:lsdException w:name="Intense Emphasis" w:uiPriority="21" w:qFormat="1"/><w:lsdException w:name="Subtle Reference" w:uiPriority="31" w:qFormat="1"/><w:lsdException w:name="Intense Reference" w:uiPriority="32" w:qFormat="1"/><w:lsdException w:name="Book Title" w:uiPriority="33" w:qFormat="1"/><w:lsdException w:name="Bibliography" w:semiHidden="1" w:uiPriority="37" w:unhideWhenUsed="1"/><w:lsdException w:name="TOC Heading" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="Plain Table 1" w:uiPriority="41"/><w:lsdException w:name="Plain Table 2" w:uiPriority="42"/><w:lsdException w:name="Plain Table 3" w:uiPriority="43"/><w:lsdException w:name="Plain Table 4" w:uiPriority="44"/><w:lsdException w:name="Plain Table 5" w:uiPriority="45"/><w:lsdException w:name="Grid Table Light" w:uiPriority="40"/><w:lsdException w:name="Grid Table 1 Light" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 1" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 1" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 1" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 1" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 1" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 1" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 1" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 2" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 2" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 2" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 2" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 2" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 2" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 2" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 3" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 3" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 3" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 3" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 3" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 3" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 3" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 4" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 4" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 4" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 4" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 4" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 4" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 4" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 5" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 5" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 5" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 5" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 5" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 5" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 5" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 6" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 6" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 6" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 6" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 6" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 6" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 6" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light" w:uiPriority="46"/><w:lsdException w:name="List Table 2" w:uiPriority="47"/><w:lsdException w:name="List Table 3" w:uiPriority="48"/><w:lsdException w:name="List Table 4" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 1" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 1" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 1" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 1" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 1" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 1" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 1" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 2" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 2" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 2" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 2" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 2" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 2" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 2" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 3" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 3" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 3" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 3" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 3" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 3" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 3" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 4" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 4" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 4" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 4" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 4" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 4" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 4" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 5" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 5" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 5" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 5" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 5" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 5" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 5" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 6" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 6" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 6" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 6" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 6" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 6" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 6" w:uiPriority="52"/><w:lsdException w:name="Mention" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Smart Hyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Hashtag" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Unresolved Mention" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Smart Link" w:semiHidden="1" w:unhideWhenUsed="1"/></w:latentStyles><w:style w:type="paragraph" w:default="1" w:styleId="Normal"><w:name w:val="Normal"/><w:qFormat/></w:style><w:style w:type="character" w:default="1" w:styleId="DefaultParagraphFont"><w:name w:val="Default Paragraph Font"/><w:uiPriority w:val="1"/><w:semiHidden/><w:unhideWhenUsed/></w:style><w:style w:type="table" w:default="1" w:styleId="TableNormal"><w:name w:val="Normal Table"/><w:uiPriority w:val="99"/><w:semiHidden/><w:unhideWhenUsed/><w:tblPr><w:tblInd w:w="0" w:type="dxa"/><w:tblCellMar><w:top w:w="0" w:type="dxa"/><w:left w:w="108" w:type="dxa"/><w:bottom w:w="0" w:type="dxa"/><w:right w:w="108" w:type="dxa"/></w:tblCellMar></w:tblPr></w:style><w:style w:type="numbering" w:default="1" w:styleId="NoList"><w:name w:val="No List"/><w:uiPriority w:val="99"/><w:semiHidden/><w:unhideWhenUsed/></w:style></w:styles> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/theme/theme1.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/theme/theme1.xml
new file mode 100644
index 00000000..d1a502f8
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/theme/theme1.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<a:theme xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main" name="Office Theme"><a:themeElements><a:clrScheme name="Office"><a:dk1><a:sysClr val="windowText" lastClr="000000"/></a:dk1><a:lt1><a:sysClr val="window" lastClr="FFFFFF"/></a:lt1><a:dk2><a:srgbClr val="44546A"/></a:dk2><a:lt2><a:srgbClr val="E7E6E6"/></a:lt2><a:accent1><a:srgbClr val="4472C4"/></a:accent1><a:accent2><a:srgbClr val="ED7D31"/></a:accent2><a:accent3><a:srgbClr val="A5A5A5"/></a:accent3><a:accent4><a:srgbClr val="FFC000"/></a:accent4><a:accent5><a:srgbClr val="5B9BD5"/></a:accent5><a:accent6><a:srgbClr val="70AD47"/></a:accent6><a:hlink><a:srgbClr val="0563C1"/></a:hlink><a:folHlink><a:srgbClr val="954F72"/></a:folHlink></a:clrScheme><a:fontScheme name="Office"><a:majorFont><a:latin typeface="Calibri Light" panose="020F0302020204030204"/><a:ea typeface=""/><a:cs typeface=""/><a:font script="Jpan" typeface="游ゴシック Light"/><a:font script="Hang" typeface="맑은 고딕"/><a:font script="Hans" typeface="等线 Light"/><a:font script="Hant" typeface="新細明體"/><a:font script="Arab" typeface="Times New Roman"/><a:font script="Hebr" typeface="Times New Roman"/><a:font script="Thai" typeface="Angsana New"/><a:font script="Ethi" typeface="Nyala"/><a:font script="Beng" typeface="Vrinda"/><a:font script="Gujr" typeface="Shruti"/><a:font script="Khmr" typeface="MoolBoran"/><a:font script="Knda" typeface="Tunga"/><a:font script="Guru" typeface="Raavi"/><a:font script="Cans" typeface="Euphemia"/><a:font script="Cher" typeface="Plantagenet Cherokee"/><a:font script="Yiii" typeface="Microsoft Yi Baiti"/><a:font script="Tibt" typeface="Microsoft Himalaya"/><a:font script="Thaa" typeface="MV Boli"/><a:font script="Deva" typeface="Mangal"/><a:font script="Telu" typeface="Gautami"/><a:font script="Taml" typeface="Latha"/><a:font script="Syrc" typeface="Estrangelo Edessa"/><a:font script="Orya" typeface="Kalinga"/><a:font script="Mlym" typeface="Kartika"/><a:font script="Laoo" typeface="DokChampa"/><a:font script="Sinh" typeface="Iskoola Pota"/><a:font script="Mong" typeface="Mongolian Baiti"/><a:font script="Viet" typeface="Times New Roman"/><a:font script="Uigh" typeface="Microsoft Uighur"/><a:font script="Geor" typeface="Sylfaen"/><a:font script="Armn" typeface="Arial"/><a:font script="Bugi" typeface="Leelawadee UI"/><a:font script="Bopo" typeface="Microsoft JhengHei"/><a:font script="Java" typeface="Javanese Text"/><a:font script="Lisu" typeface="Segoe UI"/><a:font script="Mymr" typeface="Myanmar Text"/><a:font script="Nkoo" typeface="Ebrima"/><a:font script="Olck" typeface="Nirmala UI"/><a:font script="Osma" typeface="Ebrima"/><a:font script="Phag" typeface="Phagspa"/><a:font script="Syrn" typeface="Estrangelo Edessa"/><a:font script="Syrj" typeface="Estrangelo Edessa"/><a:font script="Syre" typeface="Estrangelo Edessa"/><a:font script="Sora" typeface="Nirmala UI"/><a:font script="Tale" typeface="Microsoft Tai Le"/><a:font script="Talu" typeface="Microsoft New Tai Lue"/><a:font script="Tfng" typeface="Ebrima"/></a:majorFont><a:minorFont><a:latin typeface="Calibri" panose="020F0502020204030204"/><a:ea typeface=""/><a:cs typeface=""/><a:font script="Jpan" typeface="游明朝"/><a:font script="Hang" typeface="맑은 고딕"/><a:font script="Hans" typeface="等线"/><a:font script="Hant" typeface="新細明體"/><a:font script="Arab" typeface="Arial"/><a:font script="Hebr" typeface="Arial"/><a:font script="Thai" typeface="Cordia New"/><a:font script="Ethi" typeface="Nyala"/><a:font script="Beng" typeface="Vrinda"/><a:font script="Gujr" typeface="Shruti"/><a:font script="Khmr" typeface="DaunPenh"/><a:font script="Knda" typeface="Tunga"/><a:font script="Guru" typeface="Raavi"/><a:font script="Cans" typeface="Euphemia"/><a:font script="Cher" typeface="Plantagenet Cherokee"/><a:font script="Yiii" typeface="Microsoft Yi Baiti"/><a:font script="Tibt" typeface="Microsoft Himalaya"/><a:font script="Thaa" typeface="MV Boli"/><a:font script="Deva" typeface="Mangal"/><a:font script="Telu" typeface="Gautami"/><a:font script="Taml" typeface="Latha"/><a:font script="Syrc" typeface="Estrangelo Edessa"/><a:font script="Orya" typeface="Kalinga"/><a:font script="Mlym" typeface="Kartika"/><a:font script="Laoo" typeface="DokChampa"/><a:font script="Sinh" typeface="Iskoola Pota"/><a:font script="Mong" typeface="Mongolian Baiti"/><a:font script="Viet" typeface="Arial"/><a:font script="Uigh" typeface="Microsoft Uighur"/><a:font script="Geor" typeface="Sylfaen"/><a:font script="Armn" typeface="Arial"/><a:font script="Bugi" typeface="Leelawadee UI"/><a:font script="Bopo" typeface="Microsoft JhengHei"/><a:font script="Java" typeface="Javanese Text"/><a:font script="Lisu" typeface="Segoe UI"/><a:font script="Mymr" typeface="Myanmar Text"/><a:font script="Nkoo" typeface="Ebrima"/><a:font script="Olck" typeface="Nirmala UI"/><a:font script="Osma" typeface="Ebrima"/><a:font script="Phag" typeface="Phagspa"/><a:font script="Syrn" typeface="Estrangelo Edessa"/><a:font script="Syrj" typeface="Estrangelo Edessa"/><a:font script="Syre" typeface="Estrangelo Edessa"/><a:font script="Sora" typeface="Nirmala UI"/><a:font script="Tale" typeface="Microsoft Tai Le"/><a:font script="Talu" typeface="Microsoft New Tai Lue"/><a:font script="Tfng" typeface="Ebrima"/></a:minorFont></a:fontScheme><a:fmtScheme name="Office"><a:fillStyleLst><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:lumMod val="110000"/><a:satMod val="105000"/><a:tint val="67000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:lumMod val="105000"/><a:satMod val="103000"/><a:tint val="73000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:lumMod val="105000"/><a:satMod val="109000"/><a:tint val="81000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:satMod val="103000"/><a:lumMod val="102000"/><a:tint val="94000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:satMod val="110000"/><a:lumMod val="100000"/><a:shade val="100000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:lumMod val="99000"/><a:satMod val="120000"/><a:shade val="78000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill></a:fillStyleLst><a:lnStyleLst><a:ln w="6350" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln><a:ln w="12700" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln><a:ln w="19050" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln></a:lnStyleLst><a:effectStyleLst><a:effectStyle><a:effectLst/></a:effectStyle><a:effectStyle><a:effectLst/></a:effectStyle><a:effectStyle><a:effectLst><a:outerShdw blurRad="57150" dist="19050" dir="5400000" algn="ctr" rotWithShape="0"><a:srgbClr val="000000"><a:alpha val="63000"/></a:srgbClr></a:outerShdw></a:effectLst></a:effectStyle></a:effectStyleLst><a:bgFillStyleLst><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:solidFill><a:schemeClr val="phClr"><a:tint val="95000"/><a:satMod val="170000"/></a:schemeClr></a:solidFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:tint val="93000"/><a:satMod val="150000"/><a:shade val="98000"/><a:lumMod val="102000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:tint val="98000"/><a:satMod val="130000"/><a:shade val="90000"/><a:lumMod val="103000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:shade val="63000"/><a:satMod val="120000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill></a:bgFillStyleLst></a:fmtScheme></a:themeElements><a:objectDefaults/><a:extraClrSchemeLst/><a:extLst><a:ext uri="{05A4C25C-085E-4340-85A3-A5531E510DB2}"><thm15:themeFamily xmlns:thm15="http://schemas.microsoft.com/office/thememl/2012/main" name="Office Theme" id="{62F939B6-93AF-4DB8-9C6B-D6C7DFDC589F}" vid="{4A3C46E8-61CC-4603-A589-7422A47A8E4A}"/></a:ext></a:extLst></a:theme> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/webSettings.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/webSettings.xml
new file mode 100644
index 00000000..629ae06a
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate-spacing.docx.dir.ref/word/webSettings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:webSettings xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:optimizeForBrowser/><w:allowPNG/></w:webSettings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/[Content_Types].xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/[Content_Types].xml
new file mode 100644
index 00000000..07d88cca
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/[Content_Types].xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Types xmlns="http://schemas.openxmlformats.org/package/2006/content-types"><Default Extension="rels" ContentType="application/vnd.openxmlformats-package.relationships+xml"/><Default Extension="xml" ContentType="application/xml"/><Override PartName="/word/document.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.document.main+xml"/><Override PartName="/word/styles.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.styles+xml"/><Override PartName="/word/settings.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.settings+xml"/><Override PartName="/word/webSettings.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.webSettings+xml"/><Override PartName="/word/fontTable.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.fontTable+xml"/><Override PartName="/word/theme/theme1.xml" ContentType="application/vnd.openxmlformats-officedocument.theme+xml"/><Override PartName="/docProps/core.xml" ContentType="application/vnd.openxmlformats-package.core-properties+xml"/><Override PartName="/docProps/app.xml" ContentType="application/vnd.openxmlformats-officedocument.extended-properties+xml"/></Types> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/_rels/.rels b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/_rels/.rels
new file mode 100644
index 00000000..32548d42
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/_rels/.rels
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/extended-properties" Target="docProps/app.xml"/><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/package/2006/relationships/metadata/core-properties" Target="docProps/core.xml"/><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument" Target="word/document.xml"/></Relationships> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/docProps/app.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/docProps/app.xml
new file mode 100644
index 00000000..eb8dd2e5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/docProps/app.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Properties xmlns="http://schemas.openxmlformats.org/officeDocument/2006/extended-properties" xmlns:vt="http://schemas.openxmlformats.org/officeDocument/2006/docPropsVTypes"><Template>Normal.dotm</Template><TotalTime>3</TotalTime><Pages>1</Pages><Words>2</Words><Characters>18</Characters><Application>Microsoft Office Word</Application><DocSecurity>0</DocSecurity><Lines>1</Lines><Paragraphs>1</Paragraphs><ScaleCrop>false</ScaleCrop><Company></Company><LinksUpToDate>false</LinksUpToDate><CharactersWithSpaces>19</CharactersWithSpaces><SharedDoc>false</SharedDoc><HyperlinksChanged>false</HyperlinksChanged><AppVersion>16.0000</AppVersion></Properties> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/docProps/core.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/docProps/core.xml
new file mode 100644
index 00000000..195d77a9
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/docProps/core.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<cp:coreProperties xmlns:cp="http://schemas.openxmlformats.org/package/2006/metadata/core-properties" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:dcterms="http://purl.org/dc/terms/" xmlns:dcmitype="http://purl.org/dc/dcmitype/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><dc:title></dc:title><dc:subject></dc:subject><dc:creator></dc:creator><cp:keywords></cp:keywords><dc:description></dc:description><cp:lastModifiedBy></cp:lastModifiedBy><cp:revision>1</cp:revision><dcterms:created xsi:type="dcterms:W3CDTF">2020-09-25T17:04:00Z</dcterms:created><dcterms:modified xsi:type="dcterms:W3CDTF">2020-09-25T17:07:00Z</dcterms:modified></cp:coreProperties> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/_rels/document.xml.rels b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/_rels/document.xml.rels
new file mode 100644
index 00000000..3b2b7f8c
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/_rels/document.xml.rels
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/webSettings" Target="webSettings.xml"/><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/settings" Target="settings.xml"/><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles" Target="styles.xml"/><Relationship Id="rId5" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme" Target="theme/theme1.xml"/><Relationship Id="rId4" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/fontTable" Target="fontTable.xml"/></Relationships> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/document.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/document.xml
new file mode 100644
index 00000000..a6cc3178
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/document.xml
@@ -0,0 +1,682 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:document xmlns:wpc="http://schemas.microsoft.com/office/word/2010/wordprocessingCanvas" xmlns:cx="http://schemas.microsoft.com/office/drawing/2014/chartex" xmlns:cx1="http://schemas.microsoft.com/office/drawing/2015/9/8/chartex" xmlns:cx2="http://schemas.microsoft.com/office/drawing/2015/10/21/chartex" xmlns:cx3="http://schemas.microsoft.com/office/drawing/2016/5/9/chartex" xmlns:cx4="http://schemas.microsoft.com/office/drawing/2016/5/10/chartex" xmlns:cx5="http://schemas.microsoft.com/office/drawing/2016/5/11/chartex" xmlns:cx6="http://schemas.microsoft.com/office/drawing/2016/5/12/chartex" xmlns:cx7="http://schemas.microsoft.com/office/drawing/2016/5/13/chartex" xmlns:cx8="http://schemas.microsoft.com/office/drawing/2016/5/14/chartex" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:aink="http://schemas.microsoft.com/office/drawing/2016/ink" xmlns:am3d="http://schemas.microsoft.com/office/drawing/2017/model3d" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:m="http://schemas.openxmlformats.org/officeDocument/2006/math" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:wp14="http://schemas.microsoft.com/office/word/2010/wordprocessingDrawing" xmlns:wp="http://schemas.openxmlformats.org/drawingml/2006/wordprocessingDrawing" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" xmlns:wpg="http://schemas.microsoft.com/office/word/2010/wordprocessingGroup" xmlns:wpi="http://schemas.microsoft.com/office/word/2010/wordprocessingInk" xmlns:wne="http://schemas.microsoft.com/office/word/2006/wordml" xmlns:wps="http://schemas.microsoft.com/office/word/2010/wordprocessingShape" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex wp14"><w:body>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>3197324</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>4602912</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2893510" cy="1885520"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="1" name="Text Box 1"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="10470858">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was one who was famed for the number of things He </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-BoldMT" w:hAnsi="CourierNewPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">forgot </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">when he entered the ship: His umbrella, his watch, all his jewels and rings, And the clothes he had bought for the trip. He had </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-ItalicMT" w:hAnsi="CourierNewPS-ItalicMT"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">forty-two</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve"> boxes, all carefully packed, With his name painted clearly on each: But, since he omitted to mention the fact, They were all left behind on the beach.</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 1" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was one who was famed for the number of things He </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-BoldMT" w:hAnsi="CourierNewPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">forgot </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">when he entered the ship: His umbrella, his watch, all his jewels and rings, And the clothes he had bought for the trip. He had </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-ItalicMT" w:hAnsi="CourierNewPS-ItalicMT"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">forty-two</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve"> boxes, all carefully packed, With his name painted clearly on each: But, since he omitted to mention the fact, They were all left behind on the beach.</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>840434</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>2075903</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2190228" cy="2819246"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="2" name="Text Box 2"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="-8517153">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">The crew was complete: it included a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Boots</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">&#x2014; A maker of Bonnets and Hoods&#x2014; A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Barrister</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, brought to arrange their disputes&#x2014; And a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Broker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, to value their goods.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Billiard-marker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, whose skill was immense, Might perhaps have won more than his share&#x2014; But a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Banker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, engaged at enormous expense, Had the whole of their </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-ItalicMT" w:hAnsi="TimesNewRomanPS-ItalicMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">cash </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">in his care.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was also a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Beaver</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, that paced on the deck, Or would sit making lace in the bow: And had often (the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">said) saved them from wreck, Though none of the sailors knew how.</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 2" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">The crew was complete: it included a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Boots</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">&#x2014; A maker of Bonnets and Hoods&#x2014; A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Barrister</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, brought to arrange their disputes&#x2014; And a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Broker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, to value their goods.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Billiard-marker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, whose skill was immense, Might perhaps have won more than his share&#x2014; But a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Banker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, engaged at enormous expense, Had the whole of their </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-ItalicMT" w:hAnsi="TimesNewRomanPS-ItalicMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">cash </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">in his care.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was also a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Beaver</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, that paced on the deck, Or would sit making lace in the bow: And had often (the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">said) saved them from wreck, Though none of the sailors knew how.</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>3428932</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>1309973</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2856636" cy="3710000"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="3" name="Text Box 3"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="6130096">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">!&quot; the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">cried,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> As he landed his crew with care;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Supporting each man on the top of the tide</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> By a finger entwined in his hair.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it twice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> That alone should encourage the crew.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it thrice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> What I tell you </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">three </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">times is true.&quot;</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 3" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">!&quot; the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">cried,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> As he landed his crew with care;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Supporting each man on the top of the tide</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> By a finger entwined in his hair.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it twice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> That alone should encourage the crew.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it thrice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> What I tell you </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">three </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">times is true.&quot;</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>4205387</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>51483</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2309037" cy="1989200"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="4" name="Text Box 4"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="1991926">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">There was a young man of </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Madras</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Whose balls were </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">constructed </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">of brass,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">When jangled together,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">They played &#x201c;</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Stormy Weather</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&#x201d;,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="32.000000"/><w:szCs w:val="24.000000"/></w:rPr><w:t xml:space="preserve">lightning</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">shot out of his ass.</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 4" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">There was a young man of </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Madras</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Whose balls were </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">constructed </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">of brass,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">When jangled together,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">They played &#x201c;</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Stormy Weather</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&#x201d;,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="32.000000"/><w:szCs w:val="24.000000"/></w:rPr><w:t xml:space="preserve">lightning</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">shot out of his ass.</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p>
+
+<w:p>
+ <w:r>
+ <mc:AlternateContent>
+ <mc:Choice Requires="wps">
+ <w:drawing>
+ <wp:anchor distT="0" distB="0" distL="0" distR="0" simplePos="0" relativeHeight="0" behindDoc="0" locked="0" layoutInCell="1" allowOverlap="1" wp14:anchorId="53A210D1" wp14:editId="2B7E8016">
+ <wp:simplePos x="0" y="0"/>
+ <wp:positionH relativeFrom="page">
+ <wp:posOffset>1670564</wp:posOffset>
+ </wp:positionH>
+ <wp:positionV relativeFrom="page">
+ <wp:posOffset>-465543</wp:posOffset>
+ </wp:positionV>
+ <wp:extent cx="2090293" cy="5976900"/>
+ <wp:effectExtent l="381000" t="723900" r="371475" b="723900"/>
+ <wp:wrapNone/>
+ <wp:docPr id="5" name="Text Box 5"/>
+ <wp:cNvGraphicFramePr/>
+ <a:graphic xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main">
+ <a:graphicData uri="http://schemas.microsoft.com/office/word/2010/wordprocessingShape">
+ <wps:wsp>
+ <wps:cNvSpPr txBox="1"/>
+ <wps:spPr>
+ <a:xfrm rot="-1645562">
+ <a:off x="0" y="0"/>
+ <a:ext cx="3228975" cy="2286000"/>
+ </a:xfrm>
+ <a:prstGeom prst="rect">
+ <a:avLst/>
+ </a:prstGeom>
+ </wps:spPr>
+ <wps:txbx>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">A Python, I should not advise,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">For it needs a doctor for its eyes,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And has the Measles yearly.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">However, if </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">you feel</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> inclined</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">To get one (to improve your mind,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And not from fashion merely),</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Allow no </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">music</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> near its cage;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And when it </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">flies</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> into a rage</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Chastise it, most severely.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">I had an Aunt in Yucatan</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Who bought a Python from a man</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And kept it for a pet.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">She </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">died</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">, because she never knew</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">These simple little rules and few; &#x2014;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">The snake is living yet.</w:t></w:r>
+</w:p>
+ </w:txbxContent>
+ </wps:txbx>
+ <wps:bodyPr rot="0" spcFirstLastPara="0" vertOverflow="overflow" horzOverflow="overflow" vert="horz" wrap="square" lIns="91440" tIns="45720" rIns="91440" bIns="45720" numCol="1" spcCol="0" rtlCol="0" fromWordArt="0" anchor="t" anchorCtr="0" forceAA="0" compatLnSpc="1">
+ <a:prstTxWarp prst="textNoShape">
+ <a:avLst/>
+ </a:prstTxWarp>
+ <a:noAutofit/>
+ </wps:bodyPr>
+ </wps:wsp>
+ </a:graphicData>
+ </a:graphic>
+ </wp:anchor>
+ </w:drawing>
+ </mc:Choice>
+ <mc:Fallback>
+ <w:pict>
+ <v:shapetype w14:anchorId="53A210D1" id="_x0000_t202" coordsize="21600,21600" o:spt="202" path="m,l,21600r21600,l21600,xe">
+ <v:stroke joinstyle="miter"/>
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
+ </v:shapetype>
+ <v:shape id="Text Box 5" o:spid="_x0000_s1026" type="#_x0000_t202" style="position:absolute;margin-left:71.25pt;margin-top:48.75pt;width:254.25pt;height:180pt;rotation:-2241476fd;z-index:251659264;visibility:visible;mso-wrap-style:square;mso-wrap-distance-left:9pt;mso-wrap-distance-top:0;mso-wrap-distance-right:9pt;mso-wrap-distance-bottom:0;mso-position-horizontal:absolute;mso-position-horizontal-relative:text;mso-position-vertical:absolute;mso-position-vertical-relative:text;v-text-anchor:top" o:gfxdata="UEsDBBQABgAIAAAAIQC2gziS/gAAAOEBAAATAAAAW0NvbnRlbnRfVHlwZXNdLnhtbJSRQU7DMBBF&#10;90jcwfIWJU67QAgl6YK0S0CoHGBkTxKLZGx5TGhvj5O2G0SRWNoz/78nu9wcxkFMGNg6quQqL6RA&#10;0s5Y6ir5vt9lD1JwBDIwOMJKHpHlpr69KfdHjyxSmriSfYz+USnWPY7AufNIadK6MEJMx9ApD/oD&#10;OlTrorhX2lFEilmcO2RdNtjC5xDF9pCuTyYBB5bi6bQ4syoJ3g9WQ0ymaiLzg5KdCXlKLjvcW893&#10;SUOqXwnz5DrgnHtJTxOsQfEKIT7DmDSUCaxw7Rqn8787ZsmRM9e2VmPeBN4uqYvTtW7jvijg9N/y&#10;JsXecLq0q+WD6m8AAAD//wMAUEsDBBQABgAIAAAAIQA4/SH/1gAAAJQBAAALAAAAX3JlbHMvLnJl&#10;bHOkkMFqwzAMhu+DvYPRfXGawxijTi+j0GvpHsDYimMaW0Yy2fr2M4PBMnrbUb/Q94l/f/hMi1qR&#10;JVI2sOt6UJgd+ZiDgffL8ekFlFSbvV0oo4EbChzGx4f9GRdb25HMsYhqlCwG5lrLq9biZkxWOiqY&#10;22YiTra2kYMu1l1tQD30/bPm3wwYN0x18gb45AdQl1tp5j/sFB2T0FQ7R0nTNEV3j6o9feQzro1i&#10;OWA14Fm+Q8a1a8+Bvu/d/dMb2JY5uiPbhG/ktn4cqGU/er3pcvwCAAD//wMAUEsDBBQABgAIAAAA&#10;IQDQg5pQVgIAALEEAAAOAAAAZHJzL2Uyb0RvYy54bWysVE1v2zAMvQ/YfxB0X+2k+WiDOEXWosOA&#10;oi3QDj0rstwYk0VNUmJ3v35PipMl3U7DLgJFPj+Rj6TnV12j2VY5X5Mp+OAs50wZSWVtXgv+7fn2&#10;0wVnPghTCk1GFfxNeX61+Phh3tqZGtKadKkcA4nxs9YWfB2CnWWZl2vVCH9GVhkEK3KNCLi616x0&#10;ogV7o7Nhnk+yllxpHUnlPbw3uyBfJP6qUjI8VJVXgemCI7eQTpfOVTyzxVzMXp2w61r2aYh/yKIR&#10;tcGjB6obEQTbuPoPqqaWjjxV4UxSk1FV1VKlGlDNIH9XzdNaWJVqgTjeHmTy/49W3m8fHatL9I4z&#10;Ixq06Fl1gX2mjg2iOq31M4CeLGChgzsie7+HMxbdVa5hjiDu4HI8ml5MpkkLVMcAh+xvB6kjt4Tz&#10;fDi8uJyOOZOIwZ7keWpGtmOLrNb58EVRw6JRcIdeJlqxvfMBGQC6h0S4J12Xt7XW6RLnR11rx7YC&#10;ndch5YwvTlDasLbgk/NxnohPYpH68P1KC/k9Vn3KgJs2cEaNdlpEK3SrrhdoReUbdEvSQAZv5W0N&#10;3jvhw6NwGDQ4sTzhAUelCclQb3G2Jvfzb/6IR/8R5azF4Bbc/9gIpzjTXw0m43IwGsVJT5fReDrE&#10;xR1HVscRs2muCQqh+8gumREf9N6sHDUv2LFlfBUhYSTeLnjYm9dht07YUamWywTCbFsR7syTlZF6&#10;383n7kU42/czYBTuaT/iYvaurTts/NLQchOoqlPPo8A7VXvdsRepLf0Ox8U7vifU7z/N4hcAAAD/&#10;/wMAUEsDBBQABgAIAAAAIQBh17L63wAAAAoBAAAPAAAAZHJzL2Rvd25yZXYueG1sTI9BT4NAEIXv&#10;Jv6HzZh4s0ubgpayNIboSW3Syg9Y2BGI7CyyS0v99Y4nPU3ezMub72W72fbihKPvHClYLiIQSLUz&#10;HTUKyvfnuwcQPmgyuneECi7oYZdfX2U6Ne5MBzwdQyM4hHyqFbQhDKmUvm7Rar9wAxLfPtxodWA5&#10;NtKM+szhtperKEqk1R3xh1YPWLRYfx4nq8APVfz9VQxPb+WUNC+vZbGPDhelbm/mxy2IgHP4M8Mv&#10;PqNDzkyVm8h40bNer2K2Ktjc82RDEi+5XKVgHfNG5pn8XyH/AQAA//8DAFBLAQItABQABgAIAAAA&#10;IQC2gziS/gAAAOEBAAATAAAAAAAAAAAAAAAAAAAAAABbQ29udGVudF9UeXBlc10ueG1sUEsBAi0A&#10;FAAGAAgAAAAhADj9If/WAAAAlAEAAAsAAAAAAAAAAAAAAAAALwEAAF9yZWxzLy5yZWxzUEsBAi0A&#10;FAAGAAgAAAAhANCDmlBWAgAAsQQAAA4AAAAAAAAAAAAAAAAALgIAAGRycy9lMm9Eb2MueG1sUEsB&#10;Ai0AFAAGAAgAAAAhAGHXsvrfAAAACgEAAA8AAAAAAAAAAAAAAAAAsAQAAGRycy9kb3ducmV2Lnht&#10;bFBLBQYAAAAABAAEAPMAAAC8BQAAAAA=&#10;" fillcolor="white [3201]" strokeweight=".5pt">
+ <v:textbox>
+ <w:txbxContent>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">A Python, I should not advise,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">For it needs a doctor for its eyes,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And has the Measles yearly.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">However, if </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">you feel</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> inclined</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">To get one (to improve your mind,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And not from fashion merely),</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Allow no </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">music</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> near its cage;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And when it </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">flies</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> into a rage</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Chastise it, most severely.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">I had an Aunt in Yucatan</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Who bought a Python from a man</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And kept it for a pet.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">She </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">died</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">, because she never knew</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">These simple little rules and few; &#x2014;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">The snake is living yet.</w:t></w:r>
+</w:p>
+
+ </w:txbxContent>
+ </v:textbox>
+ </v:shape>
+ </w:pict>
+ </mc:Fallback>
+ </mc:AlternateContent>
+ </w:r>
+</w:p></w:body></w:document> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/fontTable.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/fontTable.xml
new file mode 100644
index 00000000..a39546e5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/fontTable.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:fonts xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:font w:name="Calibri"><w:panose1 w:val="020F0502020204030204"/><w:charset w:val="00"/><w:family w:val="swiss"/><w:pitch w:val="variable"/><w:sig w:usb0="E4002EFF" w:usb1="C000247B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font><w:font w:name="Times New Roman"><w:panose1 w:val="02020603050405020304"/><w:charset w:val="00"/><w:family w:val="roman"/><w:pitch w:val="variable"/><w:sig w:usb0="E0002EFF" w:usb1="C000785B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font><w:font w:name="Calibri Light"><w:panose1 w:val="020F0302020204030204"/><w:charset w:val="00"/><w:family w:val="swiss"/><w:pitch w:val="variable"/><w:sig w:usb0="E4002EFF" w:usb1="C000247B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font></w:fonts> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/settings.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/settings.xml
new file mode 100644
index 00000000..c403540d
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/settings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:settings xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:m="http://schemas.openxmlformats.org/officeDocument/2006/math" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" xmlns:sl="http://schemas.openxmlformats.org/schemaLibrary/2006/main" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:zoom w:percent="100"/><w:proofState w:spelling="clean" w:grammar="clean"/><w:defaultTabStop w:val="720"/><w:characterSpacingControl w:val="doNotCompress"/><w:compat><w:compatSetting w:name="compatibilityMode" w:uri="http://schemas.microsoft.com/office/word" w:val="15"/><w:compatSetting w:name="overrideTableStyleFontSizeAndJustification" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="enableOpenTypeFeatures" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="doNotFlipMirrorIndents" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="differentiateMultirowTableHeaders" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="useWord2013TrackBottomHyphenation" w:uri="http://schemas.microsoft.com/office/word" w:val="0"/></w:compat><w:rsids><w:rsidRoot w:val="007F4427"/><w:rsid w:val="00255448"/><w:rsid w:val="007F4427"/></w:rsids><m:mathPr><m:mathFont m:val="Cambria Math"/><m:brkBin m:val="before"/><m:brkBinSub m:val="--"/><m:smallFrac m:val="0"/><m:dispDef/><m:lMargin m:val="0"/><m:rMargin m:val="0"/><m:defJc m:val="centerGroup"/><m:wrapIndent m:val="1440"/><m:intLim m:val="subSup"/><m:naryLim m:val="undOvr"/></m:mathPr><w:themeFontLang w:val="en-GB"/><w:clrSchemeMapping w:bg1="light1" w:t1="dark1" w:bg2="light2" w:t2="dark2" w:accent1="accent1" w:accent2="accent2" w:accent3="accent3" w:accent4="accent4" w:accent5="accent5" w:accent6="accent6" w:hyperlink="hyperlink" w:followedHyperlink="followedHyperlink"/><w:shapeDefaults><o:shapedefaults v:ext="edit" spidmax="1026"/><o:shapelayout v:ext="edit"><o:idmap v:ext="edit" data="1"/></o:shapelayout></w:shapeDefaults><w:decimalSymbol w:val="."/><w:listSeparator w:val=","/><w14:docId w14:val="32E52EF8"/><w15:chartTrackingRefBased/><w15:docId w15:val="{A10F59F7-497D-44D4-A338-47719734E7A0}"/></w:settings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/styles.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/styles.xml
new file mode 100644
index 00000000..38e5e2bd
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/styles.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:styles xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:docDefaults><w:rPrDefault><w:rPr><w:rFonts w:asciiTheme="minorHAnsi" w:eastAsiaTheme="minorHAnsi" w:hAnsiTheme="minorHAnsi" w:cstheme="minorBidi"/><w:sz w:val="22"/><w:szCs w:val="22"/><w:lang w:val="en-GB" w:eastAsia="en-US" w:bidi="ar-SA"/></w:rPr></w:rPrDefault><w:pPrDefault><w:pPr><w:spacing w:after="160" w:line="259" w:lineRule="auto"/></w:pPr></w:pPrDefault></w:docDefaults><w:latentStyles w:defLockedState="0" w:defUIPriority="99" w:defSemiHidden="0" w:defUnhideWhenUsed="0" w:defQFormat="0" w:count="376"><w:lsdException w:name="Normal" w:uiPriority="0" w:qFormat="1"/><w:lsdException w:name="heading 1" w:uiPriority="9" w:qFormat="1"/><w:lsdException w:name="heading 2" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 3" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 4" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 5" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 6" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 7" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 8" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 9" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="index 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 9" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 1" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 2" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 3" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 4" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 5" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 6" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 7" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 8" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 9" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footnote text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="header" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footer" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="caption" w:semiHidden="1" w:uiPriority="35" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="table of figures" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="envelope address" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="envelope return" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footnote reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="line number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="page number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="endnote reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="endnote text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="table of authorities" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="macro" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="toa heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Title" w:uiPriority="10" w:qFormat="1"/><w:lsdException w:name="Closing" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Signature" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Default Paragraph Font" w:semiHidden="1" w:uiPriority="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Message Header" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Subtitle" w:uiPriority="11" w:qFormat="1"/><w:lsdException w:name="Salutation" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Date" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text First Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text First Indent 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Note Heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Block Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Hyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="FollowedHyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Strong" w:uiPriority="22" w:qFormat="1"/><w:lsdException w:name="Emphasis" w:uiPriority="20" w:qFormat="1"/><w:lsdException w:name="Document Map" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Plain Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="E-mail Signature" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Top of Form" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Bottom of Form" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal (Web)" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Acronym" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Address" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Cite" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Code" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Definition" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Keyboard" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Preformatted" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Sample" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Typewriter" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Variable" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal Table" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation subject" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="No List" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Contemporary" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Elegant" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Professional" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Subtle 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Subtle 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Balloon Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid" w:uiPriority="39"/><w:lsdException w:name="Table Theme" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Placeholder Text" w:semiHidden="1"/><w:lsdException w:name="No Spacing" w:uiPriority="1" w:qFormat="1"/><w:lsdException w:name="Light Shading" w:uiPriority="60"/><w:lsdException w:name="Light List" w:uiPriority="61"/><w:lsdException w:name="Light Grid" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2" w:uiPriority="64"/><w:lsdException w:name="Medium List 1" w:uiPriority="65"/><w:lsdException w:name="Medium List 2" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3" w:uiPriority="69"/><w:lsdException w:name="Dark List" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading" w:uiPriority="71"/><w:lsdException w:name="Colorful List" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 1" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 1" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 1" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 1" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 1" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 1" w:uiPriority="65"/><w:lsdException w:name="Revision" w:semiHidden="1"/><w:lsdException w:name="List Paragraph" w:uiPriority="34" w:qFormat="1"/><w:lsdException w:name="Quote" w:uiPriority="29" w:qFormat="1"/><w:lsdException w:name="Intense Quote" w:uiPriority="30" w:qFormat="1"/><w:lsdException w:name="Medium List 2 Accent 1" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 1" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 1" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 1" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 1" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 1" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 1" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 1" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 2" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 2" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 2" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 2" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 2" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 2" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 2" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 2" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 2" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 2" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 2" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 2" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 2" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 2" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 3" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 3" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 3" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 3" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 3" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 3" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 3" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 3" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 3" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 3" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 3" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 3" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 3" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 3" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 4" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 4" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 4" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 4" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 4" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 4" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 4" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 4" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 4" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 4" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 4" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 4" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 4" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 4" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 5" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 5" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 5" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 5" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 5" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 5" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 5" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 5" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 5" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 5" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 5" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 5" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 5" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 5" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 6" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 6" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 6" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 6" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 6" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 6" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 6" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 6" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 6" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 6" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 6" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 6" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 6" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 6" w:uiPriority="73"/><w:lsdException w:name="Subtle Emphasis" w:uiPriority="19" w:qFormat="1"/><w:lsdException w:name="Intense Emphasis" w:uiPriority="21" w:qFormat="1"/><w:lsdException w:name="Subtle Reference" w:uiPriority="31" w:qFormat="1"/><w:lsdException w:name="Intense Reference" w:uiPriority="32" w:qFormat="1"/><w:lsdException w:name="Book Title" w:uiPriority="33" w:qFormat="1"/><w:lsdException w:name="Bibliography" w:semiHidden="1" w:uiPriority="37" w:unhideWhenUsed="1"/><w:lsdException w:name="TOC Heading" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="Plain Table 1" w:uiPriority="41"/><w:lsdException w:name="Plain Table 2" w:uiPriority="42"/><w:lsdException w:name="Plain Table 3" w:uiPriority="43"/><w:lsdException w:name="Plain Table 4" w:uiPriority="44"/><w:lsdException w:name="Plain Table 5" w:uiPriority="45"/><w:lsdException w:name="Grid Table Light" w:uiPriority="40"/><w:lsdException w:name="Grid Table 1 Light" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 1" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 1" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 1" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 1" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 1" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 1" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 1" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 2" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 2" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 2" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 2" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 2" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 2" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 2" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 3" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 3" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 3" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 3" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 3" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 3" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 3" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 4" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 4" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 4" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 4" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 4" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 4" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 4" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 5" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 5" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 5" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 5" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 5" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 5" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 5" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 6" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 6" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 6" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 6" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 6" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 6" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 6" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light" w:uiPriority="46"/><w:lsdException w:name="List Table 2" w:uiPriority="47"/><w:lsdException w:name="List Table 3" w:uiPriority="48"/><w:lsdException w:name="List Table 4" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 1" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 1" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 1" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 1" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 1" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 1" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 1" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 2" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 2" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 2" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 2" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 2" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 2" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 2" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 3" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 3" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 3" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 3" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 3" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 3" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 3" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 4" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 4" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 4" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 4" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 4" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 4" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 4" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 5" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 5" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 5" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 5" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 5" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 5" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 5" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 6" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 6" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 6" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 6" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 6" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 6" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 6" w:uiPriority="52"/><w:lsdException w:name="Mention" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Smart Hyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Hashtag" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Unresolved Mention" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Smart Link" w:semiHidden="1" w:unhideWhenUsed="1"/></w:latentStyles><w:style w:type="paragraph" w:default="1" w:styleId="Normal"><w:name w:val="Normal"/><w:qFormat/></w:style><w:style w:type="character" w:default="1" w:styleId="DefaultParagraphFont"><w:name w:val="Default Paragraph Font"/><w:uiPriority w:val="1"/><w:semiHidden/><w:unhideWhenUsed/></w:style><w:style w:type="table" w:default="1" w:styleId="TableNormal"><w:name w:val="Normal Table"/><w:uiPriority w:val="99"/><w:semiHidden/><w:unhideWhenUsed/><w:tblPr><w:tblInd w:w="0" w:type="dxa"/><w:tblCellMar><w:top w:w="0" w:type="dxa"/><w:left w:w="108" w:type="dxa"/><w:bottom w:w="0" w:type="dxa"/><w:right w:w="108" w:type="dxa"/></w:tblCellMar></w:tblPr></w:style><w:style w:type="numbering" w:default="1" w:styleId="NoList"><w:name w:val="No List"/><w:uiPriority w:val="99"/><w:semiHidden/><w:unhideWhenUsed/></w:style></w:styles> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/theme/theme1.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/theme/theme1.xml
new file mode 100644
index 00000000..d1a502f8
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/theme/theme1.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<a:theme xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main" name="Office Theme"><a:themeElements><a:clrScheme name="Office"><a:dk1><a:sysClr val="windowText" lastClr="000000"/></a:dk1><a:lt1><a:sysClr val="window" lastClr="FFFFFF"/></a:lt1><a:dk2><a:srgbClr val="44546A"/></a:dk2><a:lt2><a:srgbClr val="E7E6E6"/></a:lt2><a:accent1><a:srgbClr val="4472C4"/></a:accent1><a:accent2><a:srgbClr val="ED7D31"/></a:accent2><a:accent3><a:srgbClr val="A5A5A5"/></a:accent3><a:accent4><a:srgbClr val="FFC000"/></a:accent4><a:accent5><a:srgbClr val="5B9BD5"/></a:accent5><a:accent6><a:srgbClr val="70AD47"/></a:accent6><a:hlink><a:srgbClr val="0563C1"/></a:hlink><a:folHlink><a:srgbClr val="954F72"/></a:folHlink></a:clrScheme><a:fontScheme name="Office"><a:majorFont><a:latin typeface="Calibri Light" panose="020F0302020204030204"/><a:ea typeface=""/><a:cs typeface=""/><a:font script="Jpan" typeface="游ゴシック Light"/><a:font script="Hang" typeface="맑은 고딕"/><a:font script="Hans" typeface="等线 Light"/><a:font script="Hant" typeface="新細明體"/><a:font script="Arab" typeface="Times New Roman"/><a:font script="Hebr" typeface="Times New Roman"/><a:font script="Thai" typeface="Angsana New"/><a:font script="Ethi" typeface="Nyala"/><a:font script="Beng" typeface="Vrinda"/><a:font script="Gujr" typeface="Shruti"/><a:font script="Khmr" typeface="MoolBoran"/><a:font script="Knda" typeface="Tunga"/><a:font script="Guru" typeface="Raavi"/><a:font script="Cans" typeface="Euphemia"/><a:font script="Cher" typeface="Plantagenet Cherokee"/><a:font script="Yiii" typeface="Microsoft Yi Baiti"/><a:font script="Tibt" typeface="Microsoft Himalaya"/><a:font script="Thaa" typeface="MV Boli"/><a:font script="Deva" typeface="Mangal"/><a:font script="Telu" typeface="Gautami"/><a:font script="Taml" typeface="Latha"/><a:font script="Syrc" typeface="Estrangelo Edessa"/><a:font script="Orya" typeface="Kalinga"/><a:font script="Mlym" typeface="Kartika"/><a:font script="Laoo" typeface="DokChampa"/><a:font script="Sinh" typeface="Iskoola Pota"/><a:font script="Mong" typeface="Mongolian Baiti"/><a:font script="Viet" typeface="Times New Roman"/><a:font script="Uigh" typeface="Microsoft Uighur"/><a:font script="Geor" typeface="Sylfaen"/><a:font script="Armn" typeface="Arial"/><a:font script="Bugi" typeface="Leelawadee UI"/><a:font script="Bopo" typeface="Microsoft JhengHei"/><a:font script="Java" typeface="Javanese Text"/><a:font script="Lisu" typeface="Segoe UI"/><a:font script="Mymr" typeface="Myanmar Text"/><a:font script="Nkoo" typeface="Ebrima"/><a:font script="Olck" typeface="Nirmala UI"/><a:font script="Osma" typeface="Ebrima"/><a:font script="Phag" typeface="Phagspa"/><a:font script="Syrn" typeface="Estrangelo Edessa"/><a:font script="Syrj" typeface="Estrangelo Edessa"/><a:font script="Syre" typeface="Estrangelo Edessa"/><a:font script="Sora" typeface="Nirmala UI"/><a:font script="Tale" typeface="Microsoft Tai Le"/><a:font script="Talu" typeface="Microsoft New Tai Lue"/><a:font script="Tfng" typeface="Ebrima"/></a:majorFont><a:minorFont><a:latin typeface="Calibri" panose="020F0502020204030204"/><a:ea typeface=""/><a:cs typeface=""/><a:font script="Jpan" typeface="游明朝"/><a:font script="Hang" typeface="맑은 고딕"/><a:font script="Hans" typeface="等线"/><a:font script="Hant" typeface="新細明體"/><a:font script="Arab" typeface="Arial"/><a:font script="Hebr" typeface="Arial"/><a:font script="Thai" typeface="Cordia New"/><a:font script="Ethi" typeface="Nyala"/><a:font script="Beng" typeface="Vrinda"/><a:font script="Gujr" typeface="Shruti"/><a:font script="Khmr" typeface="DaunPenh"/><a:font script="Knda" typeface="Tunga"/><a:font script="Guru" typeface="Raavi"/><a:font script="Cans" typeface="Euphemia"/><a:font script="Cher" typeface="Plantagenet Cherokee"/><a:font script="Yiii" typeface="Microsoft Yi Baiti"/><a:font script="Tibt" typeface="Microsoft Himalaya"/><a:font script="Thaa" typeface="MV Boli"/><a:font script="Deva" typeface="Mangal"/><a:font script="Telu" typeface="Gautami"/><a:font script="Taml" typeface="Latha"/><a:font script="Syrc" typeface="Estrangelo Edessa"/><a:font script="Orya" typeface="Kalinga"/><a:font script="Mlym" typeface="Kartika"/><a:font script="Laoo" typeface="DokChampa"/><a:font script="Sinh" typeface="Iskoola Pota"/><a:font script="Mong" typeface="Mongolian Baiti"/><a:font script="Viet" typeface="Arial"/><a:font script="Uigh" typeface="Microsoft Uighur"/><a:font script="Geor" typeface="Sylfaen"/><a:font script="Armn" typeface="Arial"/><a:font script="Bugi" typeface="Leelawadee UI"/><a:font script="Bopo" typeface="Microsoft JhengHei"/><a:font script="Java" typeface="Javanese Text"/><a:font script="Lisu" typeface="Segoe UI"/><a:font script="Mymr" typeface="Myanmar Text"/><a:font script="Nkoo" typeface="Ebrima"/><a:font script="Olck" typeface="Nirmala UI"/><a:font script="Osma" typeface="Ebrima"/><a:font script="Phag" typeface="Phagspa"/><a:font script="Syrn" typeface="Estrangelo Edessa"/><a:font script="Syrj" typeface="Estrangelo Edessa"/><a:font script="Syre" typeface="Estrangelo Edessa"/><a:font script="Sora" typeface="Nirmala UI"/><a:font script="Tale" typeface="Microsoft Tai Le"/><a:font script="Talu" typeface="Microsoft New Tai Lue"/><a:font script="Tfng" typeface="Ebrima"/></a:minorFont></a:fontScheme><a:fmtScheme name="Office"><a:fillStyleLst><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:lumMod val="110000"/><a:satMod val="105000"/><a:tint val="67000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:lumMod val="105000"/><a:satMod val="103000"/><a:tint val="73000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:lumMod val="105000"/><a:satMod val="109000"/><a:tint val="81000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:satMod val="103000"/><a:lumMod val="102000"/><a:tint val="94000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:satMod val="110000"/><a:lumMod val="100000"/><a:shade val="100000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:lumMod val="99000"/><a:satMod val="120000"/><a:shade val="78000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill></a:fillStyleLst><a:lnStyleLst><a:ln w="6350" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln><a:ln w="12700" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln><a:ln w="19050" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln></a:lnStyleLst><a:effectStyleLst><a:effectStyle><a:effectLst/></a:effectStyle><a:effectStyle><a:effectLst/></a:effectStyle><a:effectStyle><a:effectLst><a:outerShdw blurRad="57150" dist="19050" dir="5400000" algn="ctr" rotWithShape="0"><a:srgbClr val="000000"><a:alpha val="63000"/></a:srgbClr></a:outerShdw></a:effectLst></a:effectStyle></a:effectStyleLst><a:bgFillStyleLst><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:solidFill><a:schemeClr val="phClr"><a:tint val="95000"/><a:satMod val="170000"/></a:schemeClr></a:solidFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:tint val="93000"/><a:satMod val="150000"/><a:shade val="98000"/><a:lumMod val="102000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:tint val="98000"/><a:satMod val="130000"/><a:shade val="90000"/><a:lumMod val="103000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:shade val="63000"/><a:satMod val="120000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill></a:bgFillStyleLst></a:fmtScheme></a:themeElements><a:objectDefaults/><a:extraClrSchemeLst/><a:extLst><a:ext uri="{05A4C25C-085E-4340-85A3-A5531E510DB2}"><thm15:themeFamily xmlns:thm15="http://schemas.microsoft.com/office/thememl/2012/main" name="Office Theme" id="{62F939B6-93AF-4DB8-9C6B-D6C7DFDC589F}" vid="{4A3C46E8-61CC-4603-A589-7422A47A8E4A}"/></a:ext></a:extLst></a:theme> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/webSettings.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/webSettings.xml
new file mode 100644
index 00000000..629ae06a
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract-rotate.docx.dir.ref/word/webSettings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:webSettings xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:optimizeForBrowser/><w:allowPNG/></w:webSettings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/[Content_Types].xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/[Content_Types].xml
new file mode 100644
index 00000000..07d88cca
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/[Content_Types].xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Types xmlns="http://schemas.openxmlformats.org/package/2006/content-types"><Default Extension="rels" ContentType="application/vnd.openxmlformats-package.relationships+xml"/><Default Extension="xml" ContentType="application/xml"/><Override PartName="/word/document.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.document.main+xml"/><Override PartName="/word/styles.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.styles+xml"/><Override PartName="/word/settings.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.settings+xml"/><Override PartName="/word/webSettings.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.webSettings+xml"/><Override PartName="/word/fontTable.xml" ContentType="application/vnd.openxmlformats-officedocument.wordprocessingml.fontTable+xml"/><Override PartName="/word/theme/theme1.xml" ContentType="application/vnd.openxmlformats-officedocument.theme+xml"/><Override PartName="/docProps/core.xml" ContentType="application/vnd.openxmlformats-package.core-properties+xml"/><Override PartName="/docProps/app.xml" ContentType="application/vnd.openxmlformats-officedocument.extended-properties+xml"/></Types> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/_rels/.rels b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/_rels/.rels
new file mode 100644
index 00000000..32548d42
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/_rels/.rels
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/extended-properties" Target="docProps/app.xml"/><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/package/2006/relationships/metadata/core-properties" Target="docProps/core.xml"/><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument" Target="word/document.xml"/></Relationships> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/docProps/app.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/docProps/app.xml
new file mode 100644
index 00000000..eb8dd2e5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/docProps/app.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Properties xmlns="http://schemas.openxmlformats.org/officeDocument/2006/extended-properties" xmlns:vt="http://schemas.openxmlformats.org/officeDocument/2006/docPropsVTypes"><Template>Normal.dotm</Template><TotalTime>3</TotalTime><Pages>1</Pages><Words>2</Words><Characters>18</Characters><Application>Microsoft Office Word</Application><DocSecurity>0</DocSecurity><Lines>1</Lines><Paragraphs>1</Paragraphs><ScaleCrop>false</ScaleCrop><Company></Company><LinksUpToDate>false</LinksUpToDate><CharactersWithSpaces>19</CharactersWithSpaces><SharedDoc>false</SharedDoc><HyperlinksChanged>false</HyperlinksChanged><AppVersion>16.0000</AppVersion></Properties> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/docProps/core.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/docProps/core.xml
new file mode 100644
index 00000000..195d77a9
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/docProps/core.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<cp:coreProperties xmlns:cp="http://schemas.openxmlformats.org/package/2006/metadata/core-properties" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:dcterms="http://purl.org/dc/terms/" xmlns:dcmitype="http://purl.org/dc/dcmitype/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"><dc:title></dc:title><dc:subject></dc:subject><dc:creator></dc:creator><cp:keywords></cp:keywords><dc:description></dc:description><cp:lastModifiedBy></cp:lastModifiedBy><cp:revision>1</cp:revision><dcterms:created xsi:type="dcterms:W3CDTF">2020-09-25T17:04:00Z</dcterms:created><dcterms:modified xsi:type="dcterms:W3CDTF">2020-09-25T17:07:00Z</dcterms:modified></cp:coreProperties> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/_rels/document.xml.rels b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/_rels/document.xml.rels
new file mode 100644
index 00000000..3b2b7f8c
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/_rels/document.xml.rels
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<Relationships xmlns="http://schemas.openxmlformats.org/package/2006/relationships"><Relationship Id="rId3" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/webSettings" Target="webSettings.xml"/><Relationship Id="rId2" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/settings" Target="settings.xml"/><Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/styles" Target="styles.xml"/><Relationship Id="rId5" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme" Target="theme/theme1.xml"/><Relationship Id="rId4" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/fontTable" Target="fontTable.xml"/></Relationships> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/document.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/document.xml
new file mode 100644
index 00000000..d18a0195
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/document.xml
@@ -0,0 +1,321 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:document xmlns:wpc="http://schemas.microsoft.com/office/word/2010/wordprocessingCanvas" xmlns:cx="http://schemas.microsoft.com/office/drawing/2014/chartex" xmlns:cx1="http://schemas.microsoft.com/office/drawing/2015/9/8/chartex" xmlns:cx2="http://schemas.microsoft.com/office/drawing/2015/10/21/chartex" xmlns:cx3="http://schemas.microsoft.com/office/drawing/2016/5/9/chartex" xmlns:cx4="http://schemas.microsoft.com/office/drawing/2016/5/10/chartex" xmlns:cx5="http://schemas.microsoft.com/office/drawing/2016/5/11/chartex" xmlns:cx6="http://schemas.microsoft.com/office/drawing/2016/5/12/chartex" xmlns:cx7="http://schemas.microsoft.com/office/drawing/2016/5/13/chartex" xmlns:cx8="http://schemas.microsoft.com/office/drawing/2016/5/14/chartex" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:aink="http://schemas.microsoft.com/office/drawing/2016/ink" xmlns:am3d="http://schemas.microsoft.com/office/drawing/2017/model3d" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:m="http://schemas.openxmlformats.org/officeDocument/2006/math" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:wp14="http://schemas.microsoft.com/office/word/2010/wordprocessingDrawing" xmlns:wp="http://schemas.openxmlformats.org/drawingml/2006/wordprocessingDrawing" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" xmlns:wpg="http://schemas.microsoft.com/office/word/2010/wordprocessingGroup" xmlns:wpi="http://schemas.microsoft.com/office/word/2010/wordprocessingInk" xmlns:wne="http://schemas.microsoft.com/office/word/2006/wordml" xmlns:wps="http://schemas.microsoft.com/office/word/2010/wordprocessingShape" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex wp14"><w:body>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was one who was famed for the number of things He </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-BoldMT" w:hAnsi="CourierNewPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">forgot </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">when he entered the ship: His umbrella, his watch, all his jewels and rings, And the clothes he had bought for the trip. He had </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPS-ItalicMT" w:hAnsi="CourierNewPS-ItalicMT"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">forty-two</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="CourierNewPSMT" w:hAnsi="CourierNewPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve"> boxes, all carefully packed, With his name painted clearly on each: But, since he omitted to mention the fact, They were all left behind on the beach.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">The crew was complete: it included a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Boots</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">&#x2014; A maker of Bonnets and Hoods&#x2014; A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Barrister</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, brought to arrange their disputes&#x2014; And a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Broker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, to value their goods.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">A </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Billiard-marker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, whose skill was immense, Might perhaps have won more than his share&#x2014; But a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Banker</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, engaged at enormous expense, Had the whole of their </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-ItalicMT" w:hAnsi="TimesNewRomanPS-ItalicMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">cash </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">in his care.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">There was also a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Beaver</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">, that paced on the deck, Or would sit making lace in the bow: And had often (the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPS-BoldMT" w:hAnsi="TimesNewRomanPS-BoldMT"/><w:b/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="TimesNewRomanPSMT" w:hAnsi="TimesNewRomanPSMT"/><w:sz w:val="14.860000"/><w:szCs w:val="11.145000"/></w:rPr><w:t xml:space="preserve">said) saved them from wreck, Though none of the sailors knew how.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">!&quot; the </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Bellman </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">cried,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> As he landed his crew with care;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Supporting each man on the top of the tide</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> By a finger entwined in his hair.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&quot;Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it twice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> That alone should encourage the crew.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Just the place for a </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Snark</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">! I have said it thrice:</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> What I tell you </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">three </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">times is true.&quot;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">There was a young man of </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Madras</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Whose balls were </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">constructed </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">of brass,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">When jangled together,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">They played &#x201c;</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">Stormy Weather</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">&#x201d;,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="32.000000"/><w:szCs w:val="24.000000"/></w:rPr><w:t xml:space="preserve">lightning</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">shot out of his ass.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">A Python, I should not advise,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">For it needs a doctor for its eyes,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And has the Measles yearly.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">However, if </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="28.000000"/><w:szCs w:val="21.000000"/></w:rPr><w:t xml:space="preserve">you feel</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> inclined</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">To get one (to improve your mind,</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And not from fashion merely),</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Allow no </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Italic" w:hAnsi="OpenSans-Italic"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">music</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> near its cage;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And when it </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-Bold" w:hAnsi="OpenSans-Bold"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">flies</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"> into a rage</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Chastise it, most severely.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">I had an Aunt in Yucatan</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">Who bought a Python from a man</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">And kept it for a pet.</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">She </w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans-BoldItalic" w:hAnsi="OpenSans-BoldItalic"/><w:b/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">died</w:t></w:r>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">, because she never knew</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">These simple little rules and few; &#x2014;</w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve"></w:t></w:r>
+</w:p>
+
+<w:p>
+<w:r><w:rPr><w:rFonts w:ascii="OpenSans" w:hAnsi="OpenSans"/><w:sz w:val="20.000000"/><w:szCs w:val="15.000000"/></w:rPr><w:t xml:space="preserve">The snake is living yet.</w:t></w:r>
+</w:p></w:body></w:document> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/fontTable.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/fontTable.xml
new file mode 100644
index 00000000..a39546e5
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/fontTable.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:fonts xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:font w:name="Calibri"><w:panose1 w:val="020F0502020204030204"/><w:charset w:val="00"/><w:family w:val="swiss"/><w:pitch w:val="variable"/><w:sig w:usb0="E4002EFF" w:usb1="C000247B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font><w:font w:name="Times New Roman"><w:panose1 w:val="02020603050405020304"/><w:charset w:val="00"/><w:family w:val="roman"/><w:pitch w:val="variable"/><w:sig w:usb0="E0002EFF" w:usb1="C000785B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font><w:font w:name="Calibri Light"><w:panose1 w:val="020F0302020204030204"/><w:charset w:val="00"/><w:family w:val="swiss"/><w:pitch w:val="variable"/><w:sig w:usb0="E4002EFF" w:usb1="C000247B" w:usb2="00000009" w:usb3="00000000" w:csb0="000001FF" w:csb1="00000000"/></w:font></w:fonts> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/settings.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/settings.xml
new file mode 100644
index 00000000..c403540d
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/settings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:settings xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:m="http://schemas.openxmlformats.org/officeDocument/2006/math" xmlns:v="urn:schemas-microsoft-com:vml" xmlns:w10="urn:schemas-microsoft-com:office:word" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" xmlns:sl="http://schemas.openxmlformats.org/schemaLibrary/2006/main" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:zoom w:percent="100"/><w:proofState w:spelling="clean" w:grammar="clean"/><w:defaultTabStop w:val="720"/><w:characterSpacingControl w:val="doNotCompress"/><w:compat><w:compatSetting w:name="compatibilityMode" w:uri="http://schemas.microsoft.com/office/word" w:val="15"/><w:compatSetting w:name="overrideTableStyleFontSizeAndJustification" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="enableOpenTypeFeatures" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="doNotFlipMirrorIndents" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="differentiateMultirowTableHeaders" w:uri="http://schemas.microsoft.com/office/word" w:val="1"/><w:compatSetting w:name="useWord2013TrackBottomHyphenation" w:uri="http://schemas.microsoft.com/office/word" w:val="0"/></w:compat><w:rsids><w:rsidRoot w:val="007F4427"/><w:rsid w:val="00255448"/><w:rsid w:val="007F4427"/></w:rsids><m:mathPr><m:mathFont m:val="Cambria Math"/><m:brkBin m:val="before"/><m:brkBinSub m:val="--"/><m:smallFrac m:val="0"/><m:dispDef/><m:lMargin m:val="0"/><m:rMargin m:val="0"/><m:defJc m:val="centerGroup"/><m:wrapIndent m:val="1440"/><m:intLim m:val="subSup"/><m:naryLim m:val="undOvr"/></m:mathPr><w:themeFontLang w:val="en-GB"/><w:clrSchemeMapping w:bg1="light1" w:t1="dark1" w:bg2="light2" w:t2="dark2" w:accent1="accent1" w:accent2="accent2" w:accent3="accent3" w:accent4="accent4" w:accent5="accent5" w:accent6="accent6" w:hyperlink="hyperlink" w:followedHyperlink="followedHyperlink"/><w:shapeDefaults><o:shapedefaults v:ext="edit" spidmax="1026"/><o:shapelayout v:ext="edit"><o:idmap v:ext="edit" data="1"/></o:shapelayout></w:shapeDefaults><w:decimalSymbol w:val="."/><w:listSeparator w:val=","/><w14:docId w14:val="32E52EF8"/><w15:chartTrackingRefBased/><w15:docId w15:val="{A10F59F7-497D-44D4-A338-47719734E7A0}"/></w:settings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/styles.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/styles.xml
new file mode 100644
index 00000000..38e5e2bd
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/styles.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:styles xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:docDefaults><w:rPrDefault><w:rPr><w:rFonts w:asciiTheme="minorHAnsi" w:eastAsiaTheme="minorHAnsi" w:hAnsiTheme="minorHAnsi" w:cstheme="minorBidi"/><w:sz w:val="22"/><w:szCs w:val="22"/><w:lang w:val="en-GB" w:eastAsia="en-US" w:bidi="ar-SA"/></w:rPr></w:rPrDefault><w:pPrDefault><w:pPr><w:spacing w:after="160" w:line="259" w:lineRule="auto"/></w:pPr></w:pPrDefault></w:docDefaults><w:latentStyles w:defLockedState="0" w:defUIPriority="99" w:defSemiHidden="0" w:defUnhideWhenUsed="0" w:defQFormat="0" w:count="376"><w:lsdException w:name="Normal" w:uiPriority="0" w:qFormat="1"/><w:lsdException w:name="heading 1" w:uiPriority="9" w:qFormat="1"/><w:lsdException w:name="heading 2" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 3" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 4" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 5" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 6" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 7" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 8" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="heading 9" w:semiHidden="1" w:uiPriority="9" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="index 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index 9" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 1" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 2" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 3" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 4" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 5" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 6" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 7" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 8" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="toc 9" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footnote text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="header" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footer" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="index heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="caption" w:semiHidden="1" w:uiPriority="35" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="table of figures" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="envelope address" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="envelope return" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="footnote reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="line number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="page number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="endnote reference" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="endnote text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="table of authorities" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="macro" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="toa heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Bullet 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Number 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Title" w:uiPriority="10" w:qFormat="1"/><w:lsdException w:name="Closing" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Signature" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Default Paragraph Font" w:semiHidden="1" w:uiPriority="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="List Continue 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Message Header" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Subtitle" w:uiPriority="11" w:qFormat="1"/><w:lsdException w:name="Salutation" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Date" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text First Indent" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text First Indent 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Note Heading" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Body Text Indent 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Block Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Hyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="FollowedHyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Strong" w:uiPriority="22" w:qFormat="1"/><w:lsdException w:name="Emphasis" w:uiPriority="20" w:qFormat="1"/><w:lsdException w:name="Document Map" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Plain Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="E-mail Signature" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Top of Form" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Bottom of Form" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal (Web)" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Acronym" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Address" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Cite" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Code" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Definition" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Keyboard" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Preformatted" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Sample" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Typewriter" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="HTML Variable" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Normal Table" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="annotation subject" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="No List" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Outline List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Simple 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Classic 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Colorful 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Columns 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 4" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 5" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 6" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 7" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table List 8" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table 3D effects 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Contemporary" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Elegant" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Professional" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Subtle 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Subtle 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 1" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 2" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Web 3" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Balloon Text" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Table Grid" w:uiPriority="39"/><w:lsdException w:name="Table Theme" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Placeholder Text" w:semiHidden="1"/><w:lsdException w:name="No Spacing" w:uiPriority="1" w:qFormat="1"/><w:lsdException w:name="Light Shading" w:uiPriority="60"/><w:lsdException w:name="Light List" w:uiPriority="61"/><w:lsdException w:name="Light Grid" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2" w:uiPriority="64"/><w:lsdException w:name="Medium List 1" w:uiPriority="65"/><w:lsdException w:name="Medium List 2" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3" w:uiPriority="69"/><w:lsdException w:name="Dark List" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading" w:uiPriority="71"/><w:lsdException w:name="Colorful List" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 1" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 1" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 1" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 1" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 1" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 1" w:uiPriority="65"/><w:lsdException w:name="Revision" w:semiHidden="1"/><w:lsdException w:name="List Paragraph" w:uiPriority="34" w:qFormat="1"/><w:lsdException w:name="Quote" w:uiPriority="29" w:qFormat="1"/><w:lsdException w:name="Intense Quote" w:uiPriority="30" w:qFormat="1"/><w:lsdException w:name="Medium List 2 Accent 1" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 1" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 1" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 1" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 1" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 1" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 1" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 1" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 2" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 2" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 2" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 2" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 2" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 2" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 2" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 2" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 2" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 2" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 2" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 2" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 2" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 2" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 3" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 3" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 3" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 3" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 3" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 3" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 3" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 3" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 3" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 3" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 3" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 3" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 3" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 3" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 4" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 4" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 4" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 4" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 4" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 4" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 4" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 4" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 4" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 4" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 4" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 4" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 4" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 4" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 5" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 5" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 5" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 5" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 5" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 5" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 5" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 5" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 5" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 5" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 5" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 5" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 5" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 5" w:uiPriority="73"/><w:lsdException w:name="Light Shading Accent 6" w:uiPriority="60"/><w:lsdException w:name="Light List Accent 6" w:uiPriority="61"/><w:lsdException w:name="Light Grid Accent 6" w:uiPriority="62"/><w:lsdException w:name="Medium Shading 1 Accent 6" w:uiPriority="63"/><w:lsdException w:name="Medium Shading 2 Accent 6" w:uiPriority="64"/><w:lsdException w:name="Medium List 1 Accent 6" w:uiPriority="65"/><w:lsdException w:name="Medium List 2 Accent 6" w:uiPriority="66"/><w:lsdException w:name="Medium Grid 1 Accent 6" w:uiPriority="67"/><w:lsdException w:name="Medium Grid 2 Accent 6" w:uiPriority="68"/><w:lsdException w:name="Medium Grid 3 Accent 6" w:uiPriority="69"/><w:lsdException w:name="Dark List Accent 6" w:uiPriority="70"/><w:lsdException w:name="Colorful Shading Accent 6" w:uiPriority="71"/><w:lsdException w:name="Colorful List Accent 6" w:uiPriority="72"/><w:lsdException w:name="Colorful Grid Accent 6" w:uiPriority="73"/><w:lsdException w:name="Subtle Emphasis" w:uiPriority="19" w:qFormat="1"/><w:lsdException w:name="Intense Emphasis" w:uiPriority="21" w:qFormat="1"/><w:lsdException w:name="Subtle Reference" w:uiPriority="31" w:qFormat="1"/><w:lsdException w:name="Intense Reference" w:uiPriority="32" w:qFormat="1"/><w:lsdException w:name="Book Title" w:uiPriority="33" w:qFormat="1"/><w:lsdException w:name="Bibliography" w:semiHidden="1" w:uiPriority="37" w:unhideWhenUsed="1"/><w:lsdException w:name="TOC Heading" w:semiHidden="1" w:uiPriority="39" w:unhideWhenUsed="1" w:qFormat="1"/><w:lsdException w:name="Plain Table 1" w:uiPriority="41"/><w:lsdException w:name="Plain Table 2" w:uiPriority="42"/><w:lsdException w:name="Plain Table 3" w:uiPriority="43"/><w:lsdException w:name="Plain Table 4" w:uiPriority="44"/><w:lsdException w:name="Plain Table 5" w:uiPriority="45"/><w:lsdException w:name="Grid Table Light" w:uiPriority="40"/><w:lsdException w:name="Grid Table 1 Light" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 1" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 1" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 1" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 1" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 1" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 1" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 1" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 2" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 2" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 2" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 2" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 2" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 2" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 2" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 3" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 3" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 3" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 3" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 3" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 3" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 3" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 4" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 4" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 4" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 4" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 4" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 4" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 4" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 5" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 5" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 5" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 5" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 5" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 5" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 5" w:uiPriority="52"/><w:lsdException w:name="Grid Table 1 Light Accent 6" w:uiPriority="46"/><w:lsdException w:name="Grid Table 2 Accent 6" w:uiPriority="47"/><w:lsdException w:name="Grid Table 3 Accent 6" w:uiPriority="48"/><w:lsdException w:name="Grid Table 4 Accent 6" w:uiPriority="49"/><w:lsdException w:name="Grid Table 5 Dark Accent 6" w:uiPriority="50"/><w:lsdException w:name="Grid Table 6 Colorful Accent 6" w:uiPriority="51"/><w:lsdException w:name="Grid Table 7 Colorful Accent 6" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light" w:uiPriority="46"/><w:lsdException w:name="List Table 2" w:uiPriority="47"/><w:lsdException w:name="List Table 3" w:uiPriority="48"/><w:lsdException w:name="List Table 4" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 1" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 1" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 1" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 1" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 1" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 1" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 1" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 2" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 2" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 2" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 2" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 2" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 2" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 2" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 3" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 3" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 3" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 3" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 3" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 3" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 3" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 4" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 4" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 4" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 4" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 4" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 4" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 4" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 5" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 5" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 5" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 5" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 5" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 5" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 5" w:uiPriority="52"/><w:lsdException w:name="List Table 1 Light Accent 6" w:uiPriority="46"/><w:lsdException w:name="List Table 2 Accent 6" w:uiPriority="47"/><w:lsdException w:name="List Table 3 Accent 6" w:uiPriority="48"/><w:lsdException w:name="List Table 4 Accent 6" w:uiPriority="49"/><w:lsdException w:name="List Table 5 Dark Accent 6" w:uiPriority="50"/><w:lsdException w:name="List Table 6 Colorful Accent 6" w:uiPriority="51"/><w:lsdException w:name="List Table 7 Colorful Accent 6" w:uiPriority="52"/><w:lsdException w:name="Mention" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Smart Hyperlink" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Hashtag" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Unresolved Mention" w:semiHidden="1" w:unhideWhenUsed="1"/><w:lsdException w:name="Smart Link" w:semiHidden="1" w:unhideWhenUsed="1"/></w:latentStyles><w:style w:type="paragraph" w:default="1" w:styleId="Normal"><w:name w:val="Normal"/><w:qFormat/></w:style><w:style w:type="character" w:default="1" w:styleId="DefaultParagraphFont"><w:name w:val="Default Paragraph Font"/><w:uiPriority w:val="1"/><w:semiHidden/><w:unhideWhenUsed/></w:style><w:style w:type="table" w:default="1" w:styleId="TableNormal"><w:name w:val="Normal Table"/><w:uiPriority w:val="99"/><w:semiHidden/><w:unhideWhenUsed/><w:tblPr><w:tblInd w:w="0" w:type="dxa"/><w:tblCellMar><w:top w:w="0" w:type="dxa"/><w:left w:w="108" w:type="dxa"/><w:bottom w:w="0" w:type="dxa"/><w:right w:w="108" w:type="dxa"/></w:tblCellMar></w:tblPr></w:style><w:style w:type="numbering" w:default="1" w:styleId="NoList"><w:name w:val="No List"/><w:uiPriority w:val="99"/><w:semiHidden/><w:unhideWhenUsed/></w:style></w:styles> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/theme/theme1.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/theme/theme1.xml
new file mode 100644
index 00000000..d1a502f8
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/theme/theme1.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<a:theme xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main" name="Office Theme"><a:themeElements><a:clrScheme name="Office"><a:dk1><a:sysClr val="windowText" lastClr="000000"/></a:dk1><a:lt1><a:sysClr val="window" lastClr="FFFFFF"/></a:lt1><a:dk2><a:srgbClr val="44546A"/></a:dk2><a:lt2><a:srgbClr val="E7E6E6"/></a:lt2><a:accent1><a:srgbClr val="4472C4"/></a:accent1><a:accent2><a:srgbClr val="ED7D31"/></a:accent2><a:accent3><a:srgbClr val="A5A5A5"/></a:accent3><a:accent4><a:srgbClr val="FFC000"/></a:accent4><a:accent5><a:srgbClr val="5B9BD5"/></a:accent5><a:accent6><a:srgbClr val="70AD47"/></a:accent6><a:hlink><a:srgbClr val="0563C1"/></a:hlink><a:folHlink><a:srgbClr val="954F72"/></a:folHlink></a:clrScheme><a:fontScheme name="Office"><a:majorFont><a:latin typeface="Calibri Light" panose="020F0302020204030204"/><a:ea typeface=""/><a:cs typeface=""/><a:font script="Jpan" typeface="游ゴシック Light"/><a:font script="Hang" typeface="맑은 고딕"/><a:font script="Hans" typeface="等线 Light"/><a:font script="Hant" typeface="新細明體"/><a:font script="Arab" typeface="Times New Roman"/><a:font script="Hebr" typeface="Times New Roman"/><a:font script="Thai" typeface="Angsana New"/><a:font script="Ethi" typeface="Nyala"/><a:font script="Beng" typeface="Vrinda"/><a:font script="Gujr" typeface="Shruti"/><a:font script="Khmr" typeface="MoolBoran"/><a:font script="Knda" typeface="Tunga"/><a:font script="Guru" typeface="Raavi"/><a:font script="Cans" typeface="Euphemia"/><a:font script="Cher" typeface="Plantagenet Cherokee"/><a:font script="Yiii" typeface="Microsoft Yi Baiti"/><a:font script="Tibt" typeface="Microsoft Himalaya"/><a:font script="Thaa" typeface="MV Boli"/><a:font script="Deva" typeface="Mangal"/><a:font script="Telu" typeface="Gautami"/><a:font script="Taml" typeface="Latha"/><a:font script="Syrc" typeface="Estrangelo Edessa"/><a:font script="Orya" typeface="Kalinga"/><a:font script="Mlym" typeface="Kartika"/><a:font script="Laoo" typeface="DokChampa"/><a:font script="Sinh" typeface="Iskoola Pota"/><a:font script="Mong" typeface="Mongolian Baiti"/><a:font script="Viet" typeface="Times New Roman"/><a:font script="Uigh" typeface="Microsoft Uighur"/><a:font script="Geor" typeface="Sylfaen"/><a:font script="Armn" typeface="Arial"/><a:font script="Bugi" typeface="Leelawadee UI"/><a:font script="Bopo" typeface="Microsoft JhengHei"/><a:font script="Java" typeface="Javanese Text"/><a:font script="Lisu" typeface="Segoe UI"/><a:font script="Mymr" typeface="Myanmar Text"/><a:font script="Nkoo" typeface="Ebrima"/><a:font script="Olck" typeface="Nirmala UI"/><a:font script="Osma" typeface="Ebrima"/><a:font script="Phag" typeface="Phagspa"/><a:font script="Syrn" typeface="Estrangelo Edessa"/><a:font script="Syrj" typeface="Estrangelo Edessa"/><a:font script="Syre" typeface="Estrangelo Edessa"/><a:font script="Sora" typeface="Nirmala UI"/><a:font script="Tale" typeface="Microsoft Tai Le"/><a:font script="Talu" typeface="Microsoft New Tai Lue"/><a:font script="Tfng" typeface="Ebrima"/></a:majorFont><a:minorFont><a:latin typeface="Calibri" panose="020F0502020204030204"/><a:ea typeface=""/><a:cs typeface=""/><a:font script="Jpan" typeface="游明朝"/><a:font script="Hang" typeface="맑은 고딕"/><a:font script="Hans" typeface="等线"/><a:font script="Hant" typeface="新細明體"/><a:font script="Arab" typeface="Arial"/><a:font script="Hebr" typeface="Arial"/><a:font script="Thai" typeface="Cordia New"/><a:font script="Ethi" typeface="Nyala"/><a:font script="Beng" typeface="Vrinda"/><a:font script="Gujr" typeface="Shruti"/><a:font script="Khmr" typeface="DaunPenh"/><a:font script="Knda" typeface="Tunga"/><a:font script="Guru" typeface="Raavi"/><a:font script="Cans" typeface="Euphemia"/><a:font script="Cher" typeface="Plantagenet Cherokee"/><a:font script="Yiii" typeface="Microsoft Yi Baiti"/><a:font script="Tibt" typeface="Microsoft Himalaya"/><a:font script="Thaa" typeface="MV Boli"/><a:font script="Deva" typeface="Mangal"/><a:font script="Telu" typeface="Gautami"/><a:font script="Taml" typeface="Latha"/><a:font script="Syrc" typeface="Estrangelo Edessa"/><a:font script="Orya" typeface="Kalinga"/><a:font script="Mlym" typeface="Kartika"/><a:font script="Laoo" typeface="DokChampa"/><a:font script="Sinh" typeface="Iskoola Pota"/><a:font script="Mong" typeface="Mongolian Baiti"/><a:font script="Viet" typeface="Arial"/><a:font script="Uigh" typeface="Microsoft Uighur"/><a:font script="Geor" typeface="Sylfaen"/><a:font script="Armn" typeface="Arial"/><a:font script="Bugi" typeface="Leelawadee UI"/><a:font script="Bopo" typeface="Microsoft JhengHei"/><a:font script="Java" typeface="Javanese Text"/><a:font script="Lisu" typeface="Segoe UI"/><a:font script="Mymr" typeface="Myanmar Text"/><a:font script="Nkoo" typeface="Ebrima"/><a:font script="Olck" typeface="Nirmala UI"/><a:font script="Osma" typeface="Ebrima"/><a:font script="Phag" typeface="Phagspa"/><a:font script="Syrn" typeface="Estrangelo Edessa"/><a:font script="Syrj" typeface="Estrangelo Edessa"/><a:font script="Syre" typeface="Estrangelo Edessa"/><a:font script="Sora" typeface="Nirmala UI"/><a:font script="Tale" typeface="Microsoft Tai Le"/><a:font script="Talu" typeface="Microsoft New Tai Lue"/><a:font script="Tfng" typeface="Ebrima"/></a:minorFont></a:fontScheme><a:fmtScheme name="Office"><a:fillStyleLst><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:lumMod val="110000"/><a:satMod val="105000"/><a:tint val="67000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:lumMod val="105000"/><a:satMod val="103000"/><a:tint val="73000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:lumMod val="105000"/><a:satMod val="109000"/><a:tint val="81000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:satMod val="103000"/><a:lumMod val="102000"/><a:tint val="94000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:satMod val="110000"/><a:lumMod val="100000"/><a:shade val="100000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:lumMod val="99000"/><a:satMod val="120000"/><a:shade val="78000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill></a:fillStyleLst><a:lnStyleLst><a:ln w="6350" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln><a:ln w="12700" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln><a:ln w="19050" cap="flat" cmpd="sng" algn="ctr"><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:prstDash val="solid"/><a:miter lim="800000"/></a:ln></a:lnStyleLst><a:effectStyleLst><a:effectStyle><a:effectLst/></a:effectStyle><a:effectStyle><a:effectLst/></a:effectStyle><a:effectStyle><a:effectLst><a:outerShdw blurRad="57150" dist="19050" dir="5400000" algn="ctr" rotWithShape="0"><a:srgbClr val="000000"><a:alpha val="63000"/></a:srgbClr></a:outerShdw></a:effectLst></a:effectStyle></a:effectStyleLst><a:bgFillStyleLst><a:solidFill><a:schemeClr val="phClr"/></a:solidFill><a:solidFill><a:schemeClr val="phClr"><a:tint val="95000"/><a:satMod val="170000"/></a:schemeClr></a:solidFill><a:gradFill rotWithShape="1"><a:gsLst><a:gs pos="0"><a:schemeClr val="phClr"><a:tint val="93000"/><a:satMod val="150000"/><a:shade val="98000"/><a:lumMod val="102000"/></a:schemeClr></a:gs><a:gs pos="50000"><a:schemeClr val="phClr"><a:tint val="98000"/><a:satMod val="130000"/><a:shade val="90000"/><a:lumMod val="103000"/></a:schemeClr></a:gs><a:gs pos="100000"><a:schemeClr val="phClr"><a:shade val="63000"/><a:satMod val="120000"/></a:schemeClr></a:gs></a:gsLst><a:lin ang="5400000" scaled="0"/></a:gradFill></a:bgFillStyleLst></a:fmtScheme></a:themeElements><a:objectDefaults/><a:extraClrSchemeLst/><a:extLst><a:ext uri="{05A4C25C-085E-4340-85A3-A5531E510DB2}"><thm15:themeFamily xmlns:thm15="http://schemas.microsoft.com/office/thememl/2012/main" name="Office Theme" id="{62F939B6-93AF-4DB8-9C6B-D6C7DFDC589F}" vid="{4A3C46E8-61CC-4603-A589-7422A47A8E4A}"/></a:ext></a:extLst></a:theme> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/webSettings.xml b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/webSettings.xml
new file mode 100644
index 00000000..629ae06a
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.intermediate-mu.xml.extract.docx.dir.ref/word/webSettings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
+<w:webSettings xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:w="http://schemas.openxmlformats.org/wordprocessingml/2006/main" xmlns:w14="http://schemas.microsoft.com/office/word/2010/wordml" xmlns:w15="http://schemas.microsoft.com/office/word/2012/wordml" xmlns:w16cex="http://schemas.microsoft.com/office/word/2018/wordml/cex" xmlns:w16cid="http://schemas.microsoft.com/office/word/2016/wordml/cid" xmlns:w16="http://schemas.microsoft.com/office/word/2018/wordml" xmlns:w16se="http://schemas.microsoft.com/office/word/2015/wordml/symex" mc:Ignorable="w14 w15 w16se w16cid w16 w16cex"><w:optimizeForBrowser/><w:allowPNG/></w:webSettings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/META-INF/manifest.xml b/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/META-INF/manifest.xml
new file mode 100644
index 00000000..ec991d79
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/META-INF/manifest.xml
@@ -0,0 +1,11 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<manifest:manifest xmlns:manifest="urn:oasis:names:tc:opendocument:xmlns:manifest:1.0" manifest:version="1.3" xmlns:loext="urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0">
+ <manifest:file-entry manifest:full-path="/" manifest:version="1.3" manifest:media-type="application/vnd.oasis.opendocument.text"/>
+ <manifest:file-entry manifest:full-path="meta.xml" manifest:media-type="text/xml"/>
+ <manifest:file-entry manifest:full-path="settings.xml" manifest:media-type="text/xml"/>
+ <manifest:file-entry manifest:full-path="Configurations2/" manifest:media-type="application/vnd.sun.xml.ui.configuration"/>
+ <manifest:file-entry manifest:full-path="manifest.rdf" manifest:media-type="application/rdf+xml"/>
+ <manifest:file-entry manifest:full-path="styles.xml" manifest:media-type="text/xml"/>
+ <manifest:file-entry manifest:full-path="content.xml" manifest:media-type="text/xml"/>
+ <manifest:file-entry manifest:full-path="Thumbnails/thumbnail.png" manifest:media-type="image/png"/>
+</manifest:manifest> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/Thumbnails/thumbnail.png b/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/Thumbnails/thumbnail.png
new file mode 100644
index 00000000..0dd1608e
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/Thumbnails/thumbnail.png
@@ -0,0 +1,2 @@
+PNG
+
diff --git a/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/content.xml b/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/content.xml
new file mode 100644
index 00000000..0db6512f
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/content.xml
@@ -0,0 +1,113 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<office:document-content xmlns:css3t="http://www.w3.org/TR/css3-text/" xmlns:grddl="http://www.w3.org/2003/g/data-view#" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xforms="http://www.w3.org/2002/xforms" xmlns:dom="http://www.w3.org/2001/xml-events" xmlns:script="urn:oasis:names:tc:opendocument:xmlns:script:1.0" xmlns:form="urn:oasis:names:tc:opendocument:xmlns:form:1.0" xmlns:math="http://www.w3.org/1998/Math/MathML" xmlns:number="urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0" xmlns:field="urn:openoffice:names:experimental:ooo-ms-interop:xmlns:field:1.0" xmlns:meta="urn:oasis:names:tc:opendocument:xmlns:meta:1.0" xmlns:loext="urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0" xmlns:officeooo="http://openoffice.org/2009/office" xmlns:table="urn:oasis:names:tc:opendocument:xmlns:table:1.0" xmlns:chart="urn:oasis:names:tc:opendocument:xmlns:chart:1.0" xmlns:tableooo="http://openoffice.org/2009/table" xmlns:draw="urn:oasis:names:tc:opendocument:xmlns:drawing:1.0" xmlns:rpt="http://openoffice.org/2005/report" xmlns:dr3d="urn:oasis:names:tc:opendocument:xmlns:dr3d:1.0" xmlns:of="urn:oasis:names:tc:opendocument:xmlns:of:1.2" xmlns:text="urn:oasis:names:tc:opendocument:xmlns:text:1.0" xmlns:style="urn:oasis:names:tc:opendocument:xmlns:style:1.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:calcext="urn:org:documentfoundation:names:experimental:calc:xmlns:calcext:1.0" xmlns:oooc="http://openoffice.org/2004/calc" xmlns:drawooo="http://openoffice.org/2010/draw" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:ooo="http://openoffice.org/2004/office" xmlns:ooow="http://openoffice.org/2004/writer" xmlns:fo="urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0" xmlns:formx="urn:openoffice:names:experimental:ooxml-odf-interop:xmlns:form:1.0" xmlns:svg="urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" office:version="1.3"><office:scripts/><office:font-face-decls><style:font-face style:name="Liberation Serif" svg:font-family="&apos;Liberation Serif&apos;" style:font-family-generic="roman" style:font-pitch="variable"/><style:font-face style:name="Liberation Sans" svg:font-family="&apos;Liberation Sans&apos;" style:font-family-generic="swiss" style:font-pitch="variable"/><style:font-face style:name="Unifont" svg:font-family="Unifont" style:font-family-generic="system" style:font-pitch="variable"/></office:font-face-decls><office:automatic-styles><style:style style:name="T14" style:family="text"><style:text-properties style:font-name="TimesNewRomanPSMT" fo:font-size="7.43pt" fo:font-weight="normal" fo:font-style="normal" /></style:style><style:style style:name="T16" style:family="text"><style:text-properties style:font-name="TimesNewRomanPS-ItalicMT" fo:font-size="7.43pt" fo:font-weight="normal" fo:font-style="italic" /></style:style><style:style style:name="T15" style:family="text"><style:text-properties style:font-name="TimesNewRomanPS-BoldMT" fo:font-size="7.43pt" fo:font-weight="bold" fo:font-style="normal" /></style:style><style:style style:name="T23" style:family="text"><style:text-properties style:font-name="OpenSans-Italic" fo:font-size="16.00pt" fo:font-weight="normal" fo:font-style="italic" /></style:style><style:style style:name="T18" style:family="text"><style:text-properties style:font-name="OpenSans-Italic" fo:font-size="14.00pt" fo:font-weight="normal" fo:font-style="italic" /></style:style><style:style style:name="T21" style:family="text"><style:text-properties style:font-name="OpenSans-Italic" fo:font-size="10.00pt" fo:font-weight="normal" fo:font-style="italic" /></style:style><style:style style:name="T20" style:family="text"><style:text-properties style:font-name="OpenSans-BoldItalic" fo:font-size="10.00pt" fo:font-weight="bold" fo:font-style="italic" /></style:style><style:style style:name="T22" style:family="text"><style:text-properties style:font-name="OpenSans-Bold" fo:font-size="14.00pt" fo:font-weight="bold" fo:font-style="normal" /></style:style><style:style style:name="T19" style:family="text"><style:text-properties style:font-name="OpenSans-Bold" fo:font-size="10.00pt" fo:font-weight="bold" fo:font-style="normal" /></style:style><style:style style:name="T24" style:family="text"><style:text-properties style:font-name="OpenSans" fo:font-size="14.00pt" fo:font-weight="normal" fo:font-style="normal" /></style:style><style:style style:name="T17" style:family="text"><style:text-properties style:font-name="OpenSans" fo:font-size="10.00pt" fo:font-weight="normal" fo:font-style="normal" /></style:style><style:style style:name="T11" style:family="text"><style:text-properties style:font-name="CourierNewPSMT" fo:font-size="7.43pt" fo:font-weight="normal" fo:font-style="normal" /></style:style><style:style style:name="T13" style:family="text"><style:text-properties style:font-name="CourierNewPS-ItalicMT" fo:font-size="10.00pt" fo:font-weight="normal" fo:font-style="italic" /></style:style><style:style style:name="T12" style:family="text"><style:text-properties style:font-name="CourierNewPS-BoldMT" fo:font-size="7.43pt" fo:font-weight="bold" fo:font-style="normal" /></style:style><style:style style:name="gr1" style:family="graphic">
+<style:graphic-properties draw:stroke="none" svg:stroke-color="#000000" draw:fill="none" draw:fill-color="#ffffff" fo:min-height="1.9898in" style:run-through="foreground" style:wrap="run-through" style:number-wrapped-paragraphs="no-limit" style:vertical-pos="from-top" style:vertical-rel="paragraph" style:horizontal-pos="from-left" style:horizontal-rel="paragraph" />
+<style:paragraph-properties style:writing-mode="lr-tb"/>
+</style:style>
+<style:style style:name="fr1" style:family="graphic" style:parent-style-name="Graphics">
+<style:graphic-properties fo:margin-left="0in" fo:margin-right="0in" fo:margin-top="0in" fo:margin-bottom="0in" style:vertical-pos="top" style:vertical-rel="baseline" fo:background-color="transparent" draw:fill="none" draw:fill-color="#ffffff" fo:padding="0in" fo:border="none" style:mirror="none" fo:clip="rect(0in, 0in, 0in, 0in)" draw:luminance="0%" draw:contrast="0%" draw:red="0%" draw:green="0%" draw:blue="0%" draw:gamma="100%" draw:color-inversion="false" draw:image-opacity="100%" draw:color-mode="standard"/>
+</style:style>
+</office:automatic-styles><office:body><office:text><text:sequence-decls><text:sequence-decl text:display-outline-level="0" text:name="Illustration"/><text:sequence-decl text:display-outline-level="0" text:name="Table"/><text:sequence-decl text:display-outline-level="0" text:name="Text"/><text:sequence-decl text:display-outline-level="0" text:name="Drawing"/><text:sequence-decl text:display-outline-level="0" text:name="Figure"/></text:sequence-decls><text:p text:style-name="Standard"/>
+<text:p text:style-name="Standard">
+<draw:frame text:anchor-type="paragraph" draw:z-index="5" draw:name="Shape1" draw:style-name="gr1" draw:text-style-name="Standard" svg:width="3.164382in" svg:height="1.031016in" draw:transform="rotate (-3.045849) translate (6.752333in 6.939861in)">
+<draw:text-box>
+
+
+<text:p><text:span text:style-name="T11">There was one who was famed for the number of things He </text:span><text:span text:style-name="T12">forgot </text:span><text:span text:style-name="T11">when he entered the ship: His umbrella, his watch, all his jewels and rings, And the clothes he had bought for the trip. He had </text:span><text:span text:style-name="T13">forty-two</text:span><text:span text:style-name="T11"> boxes, all carefully packed, With his name painted clearly on each: But, since he omitted to mention the fact, They were all left behind on the beach.</text:span></text:p>
+</draw:text-box>
+</draw:frame>
+</text:p>
+
+<text:p text:style-name="Standard">
+<draw:frame text:anchor-type="paragraph" draw:z-index="5" draw:name="Shape2" draw:style-name="gr1" draw:text-style-name="Standard" svg:width="2.395263in" svg:height="1.541583in" draw:transform="rotate (2.477539) translate (2.109778in 5.763930in)">
+<draw:text-box>
+
+
+<text:p><text:span text:style-name="T14">The crew was complete: it included a </text:span><text:span text:style-name="T15">Boots</text:span><text:span text:style-name="T14">&#x2014; A maker of Bonnets and Hoods&#x2014; A </text:span><text:span text:style-name="T15">Barrister</text:span><text:span text:style-name="T14">, brought to arrange their disputes&#x2014; And a </text:span><text:span text:style-name="T15">Broker</text:span><text:span text:style-name="T14">, to value their goods.</text:span></text:p>
+
+<text:p><text:span text:style-name="T14">A </text:span><text:span text:style-name="T15">Billiard-marker</text:span><text:span text:style-name="T14">, whose skill was immense, Might perhaps have won more than his share&#x2014; But a </text:span><text:span text:style-name="T15">Banker</text:span><text:span text:style-name="T14">, engaged at enormous expense, Had the whole of their </text:span><text:span text:style-name="T16">cash </text:span><text:span text:style-name="T14">in his care.</text:span></text:p>
+
+<text:p><text:span text:style-name="T14">There was also a </text:span><text:span text:style-name="T15">Beaver</text:span><text:span text:style-name="T14">, that paced on the deck, Or would sit making lace in the bow: And had often (the </text:span><text:span text:style-name="T15">Bellman </text:span><text:span text:style-name="T14">said) saved them from wreck, Though none of the sailors knew how.</text:span></text:p>
+</draw:text-box>
+</draw:frame>
+</text:p>
+
+<text:p text:style-name="Standard">
+<draw:frame text:anchor-type="paragraph" draw:z-index="5" draw:name="Shape3" draw:style-name="gr1" draw:text-style-name="Standard" svg:width="3.124056in" svg:height="2.028653in" draw:transform="rotate (-1.783173) translate (7.624278in 2.361931in)">
+<draw:text-box>
+
+
+<text:p><text:span text:style-name="T17">&quot;Just the place for a </text:span><text:span text:style-name="T18">Snark</text:span><text:span text:style-name="T17">!&quot; the </text:span><text:span text:style-name="T19">Bellman </text:span><text:span text:style-name="T17">cried,</text:span></text:p>
+
+<text:p><text:span text:style-name="T17"> As he landed his crew with care;</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">Supporting each man on the top of the tide</text:span></text:p>
+
+<text:p><text:span text:style-name="T17"> By a finger entwined in his hair.</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">&quot;Just the place for a </text:span><text:span text:style-name="T18">Snark</text:span><text:span text:style-name="T17">! I have said it twice:</text:span></text:p>
+
+<text:p><text:span text:style-name="T17"> That alone should encourage the crew.</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">Just the place for a </text:span><text:span text:style-name="T18">Snark</text:span><text:span text:style-name="T17">! I have said it thrice:</text:span></text:p>
+
+<text:p><text:span text:style-name="T17"> What I tell you </text:span><text:span text:style-name="T19">three </text:span><text:span text:style-name="T17">times is true.&quot;</text:span></text:p>
+</draw:text-box>
+</draw:frame>
+</text:p>
+
+<text:p text:style-name="Standard">
+<draw:frame text:anchor-type="paragraph" draw:z-index="5" draw:name="Shape4" draw:style-name="gr1" draw:text-style-name="Standard" svg:width="2.525194in" svg:height="1.087708in" draw:transform="rotate (-0.579428) translate (5.400722in -0.457486in)">
+<draw:text-box>
+
+
+<text:p><text:span text:style-name="T17">There was a young man of </text:span><text:span text:style-name="T20">Madras</text:span><text:span text:style-name="T17">,</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">Whose balls were </text:span><text:span text:style-name="T21">constructed </text:span><text:span text:style-name="T17">of brass,</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">When jangled together,</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">They played &#x201c;</text:span><text:span text:style-name="T22">Stormy Weather</text:span><text:span text:style-name="T17">&#x201d;,</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">And </text:span><text:span text:style-name="T23">lightning</text:span><text:span text:style-name="T21"> </text:span><text:span text:style-name="T17">shot out of his ass.</text:span></text:p>
+</draw:text-box>
+</draw:frame>
+</text:p>
+
+<text:p text:style-name="Standard">
+<draw:frame text:anchor-type="paragraph" draw:z-index="5" draw:name="Shape5" draw:style-name="gr1" draw:text-style-name="Standard" svg:width="2.285973in" svg:height="3.268209in" draw:transform="rotate (0.478675) translate (0.450069in 0.384666in)">
+<draw:text-box>
+
+
+<text:p><text:span text:style-name="T17">A Python, I should not advise,</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">For it needs a doctor for its eyes,</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">And has the Measles yearly.</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">However, if </text:span><text:span text:style-name="T24">you feel</text:span><text:span text:style-name="T17"> inclined</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">To get one (to improve your mind,</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">And not from fashion merely),</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">Allow no </text:span><text:span text:style-name="T21">music</text:span><text:span text:style-name="T17"> near its cage;</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">And when it </text:span><text:span text:style-name="T19">flies</text:span><text:span text:style-name="T17"> into a rage</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">Chastise it, most severely.</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">I had an Aunt in Yucatan</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">Who bought a Python from a man</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">And kept it for a pet.</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">She </text:span><text:span text:style-name="T20">died</text:span><text:span text:style-name="T17">, because she never knew</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">These simple little rules and few; &#x2014;</text:span></text:p>
+
+<text:p><text:span text:style-name="T17">The snake is living yet.</text:span></text:p>
+</draw:text-box>
+</draw:frame>
+</text:p>
+</office:text></office:body></office:document-content> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/manifest.rdf b/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/manifest.rdf
new file mode 100644
index 00000000..927e206b
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/manifest.rdf
@@ -0,0 +1,18 @@
+<?xml version="1.0" encoding="utf-8"?>
+<rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#">
+ <rdf:Description rdf:about="styles.xml">
+ <rdf:type rdf:resource="http://docs.oasis-open.org/ns/office/1.2/meta/odf#StylesFile"/>
+ </rdf:Description>
+ <rdf:Description rdf:about="">
+ <ns0:hasPart xmlns:ns0="http://docs.oasis-open.org/ns/office/1.2/meta/pkg#" rdf:resource="styles.xml"/>
+ </rdf:Description>
+ <rdf:Description rdf:about="content.xml">
+ <rdf:type rdf:resource="http://docs.oasis-open.org/ns/office/1.2/meta/odf#ContentFile"/>
+ </rdf:Description>
+ <rdf:Description rdf:about="">
+ <ns0:hasPart xmlns:ns0="http://docs.oasis-open.org/ns/office/1.2/meta/pkg#" rdf:resource="content.xml"/>
+ </rdf:Description>
+ <rdf:Description rdf:about="">
+ <rdf:type rdf:resource="http://docs.oasis-open.org/ns/office/1.2/meta/pkg#Document"/>
+ </rdf:Description>
+</rdf:RDF>
diff --git a/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/meta.xml b/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/meta.xml
new file mode 100644
index 00000000..6b42561e
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/meta.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<office:document-meta xmlns:grddl="http://www.w3.org/2003/g/data-view#" xmlns:meta="urn:oasis:names:tc:opendocument:xmlns:meta:1.0" xmlns:ooo="http://openoffice.org/2004/office" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" office:version="1.3"><office:meta><meta:creation-date>2021-04-05T17:06:57.937137058</meta:creation-date><meta:generator>LibreOffice/7.0.1.2$OpenBSD_X86_64 LibreOffice_project/00$Build-2</meta:generator><dc:date>2021-04-06T17:14:51.409959656</dc:date><meta:editing-duration>PT20S</meta:editing-duration><meta:editing-cycles>1</meta:editing-cycles><meta:document-statistic meta:table-count="0" meta:image-count="0" meta:object-count="0" meta:page-count="1" meta:paragraph-count="0" meta:word-count="0" meta:character-count="0" meta:non-whitespace-character-count="0"/></office:meta></office:document-meta> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/mimetype b/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/mimetype
new file mode 100644
index 00000000..2e95b81c
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/mimetype
@@ -0,0 +1 @@
+application/vnd.oasis.opendocument.text \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/settings.xml b/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/settings.xml
new file mode 100644
index 00000000..35a8138f
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/settings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<office:document-settings xmlns:config="urn:oasis:names:tc:opendocument:xmlns:config:1.0" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:ooo="http://openoffice.org/2004/office" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" office:version="1.3"><office:settings><config:config-item-set config:name="ooo:view-settings"><config:config-item config:name="ViewAreaTop" config:type="long">0</config:config-item><config:config-item config:name="ViewAreaLeft" config:type="long">0</config:config-item><config:config-item config:name="ViewAreaWidth" config:type="long">26275</config:config-item><config:config-item config:name="ViewAreaHeight" config:type="long">19502</config:config-item><config:config-item config:name="ShowRedlineChanges" config:type="boolean">true</config:config-item><config:config-item config:name="InBrowseMode" config:type="boolean">false</config:config-item><config:config-item-map-indexed config:name="Views"><config:config-item-map-entry><config:config-item config:name="ViewId" config:type="string">view2</config:config-item><config:config-item config:name="ViewLeft" config:type="long">4343</config:config-item><config:config-item config:name="ViewTop" config:type="long">2501</config:config-item><config:config-item config:name="VisibleLeft" config:type="long">0</config:config-item><config:config-item config:name="VisibleTop" config:type="long">0</config:config-item><config:config-item config:name="VisibleRight" config:type="long">26273</config:config-item><config:config-item config:name="VisibleBottom" config:type="long">19500</config:config-item><config:config-item config:name="ZoomType" config:type="short">0</config:config-item><config:config-item config:name="ViewLayoutColumns" config:type="short">1</config:config-item><config:config-item config:name="ViewLayoutBookMode" config:type="boolean">false</config:config-item><config:config-item config:name="ZoomFactor" config:type="short">100</config:config-item><config:config-item config:name="IsSelectedFrame" config:type="boolean">false</config:config-item><config:config-item config:name="AnchoredTextOverflowLegacy" config:type="boolean">false</config:config-item></config:config-item-map-entry></config:config-item-map-indexed></config:config-item-set><config:config-item-set config:name="ooo:configuration-settings"><config:config-item config:name="PrintBlackFonts" config:type="boolean">false</config:config-item><config:config-item config:name="PrintReversed" config:type="boolean">false</config:config-item><config:config-item config:name="SaveThumbnail" config:type="boolean">true</config:config-item><config:config-item config:name="EmbedFonts" config:type="boolean">false</config:config-item><config:config-item config:name="PrintControls" config:type="boolean">true</config:config-item><config:config-item config:name="OutlineLevelYieldsNumbering" config:type="boolean">false</config:config-item><config:config-item config:name="PrintPageBackground" config:type="boolean">true</config:config-item><config:config-item config:name="PrintAnnotationMode" config:type="short">0</config:config-item><config:config-item config:name="PrintGraphics" config:type="boolean">true</config:config-item><config:config-item config:name="EmbeddedDatabaseName" config:type="string"/><config:config-item config:name="ProtectForm" config:type="boolean">false</config:config-item><config:config-item config:name="PrintLeftPages" config:type="boolean">true</config:config-item><config:config-item config:name="PrintProspect" config:type="boolean">false</config:config-item><config:config-item config:name="PrintHiddenText" config:type="boolean">false</config:config-item><config:config-item config:name="PrintRightPages" config:type="boolean">true</config:config-item><config:config-item config:name="PrintFaxName" config:type="string"/><config:config-item config:name="PrintPaperFromSetup" config:type="boolean">false</config:config-item><config:config-item config:name="TabsRelativeToIndent" config:type="boolean">true</config:config-item><config:config-item config:name="RedlineProtectionKey" config:type="base64Binary"/><config:config-item config:name="PrintTextPlaceholder" config:type="boolean">false</config:config-item><config:config-item config:name="MathBaselineAlignment" config:type="boolean">true</config:config-item><config:config-item config:name="ProtectBookmarks" config:type="boolean">false</config:config-item><config:config-item config:name="IgnoreTabsAndBlanksForLineCalculation" config:type="boolean">false</config:config-item><config:config-item config:name="ContinuousEndnotes" config:type="boolean">false</config:config-item><config:config-item config:name="FieldAutoUpdate" config:type="boolean">true</config:config-item><config:config-item config:name="EmptyDbFieldHidesPara" config:type="boolean">true</config:config-item><config:config-item config:name="ApplyParagraphMarkFormatToNumbering" config:type="boolean">false</config:config-item><config:config-item config:name="PrintEmptyPages" config:type="boolean">true</config:config-item><config:config-item config:name="TabOverMargin" config:type="boolean">false</config:config-item><config:config-item config:name="EmbedAsianScriptFonts" config:type="boolean">true</config:config-item><config:config-item config:name="EmbedLatinScriptFonts" config:type="boolean">true</config:config-item><config:config-item config:name="DisableOffPagePositioning" config:type="boolean">false</config:config-item><config:config-item config:name="EmbedOnlyUsedFonts" config:type="boolean">false</config:config-item><config:config-item config:name="MsWordCompMinLineHeightByFly" config:type="boolean">false</config:config-item><config:config-item config:name="SurroundTextWrapSmall" config:type="boolean">false</config:config-item><config:config-item config:name="BackgroundParaOverDrawings" config:type="boolean">false</config:config-item><config:config-item config:name="ClippedPictures" config:type="boolean">false</config:config-item><config:config-item config:name="FloattableNomargins" config:type="boolean">false</config:config-item><config:config-item config:name="UnbreakableNumberings" config:type="boolean">false</config:config-item><config:config-item config:name="EmbedSystemFonts" config:type="boolean">false</config:config-item><config:config-item config:name="TabOverflow" config:type="boolean">true</config:config-item><config:config-item config:name="PrintTables" config:type="boolean">true</config:config-item><config:config-item config:name="PrintDrawings" config:type="boolean">true</config:config-item><config:config-item config:name="ConsiderTextWrapOnObjPos" config:type="boolean">false</config:config-item><config:config-item config:name="PrintSingleJobs" config:type="boolean">false</config:config-item><config:config-item config:name="SmallCapsPercentage66" config:type="boolean">false</config:config-item><config:config-item config:name="CollapseEmptyCellPara" config:type="boolean">true</config:config-item><config:config-item config:name="HeaderSpacingBelowLastPara" config:type="boolean">false</config:config-item><config:config-item config:name="RsidRoot" config:type="int">2052946</config:config-item><config:config-item config:name="PrinterSetup" config:type="base64Binary"/><config:config-item config:name="CurrentDatabaseCommand" config:type="string"/><config:config-item config:name="AlignTabStopPosition" config:type="boolean">true</config:config-item><config:config-item config:name="ClipAsCharacterAnchoredWriterFlyFrames" config:type="boolean">false</config:config-item><config:config-item config:name="DoNotCaptureDrawObjsOnPage" config:type="boolean">false</config:config-item><config:config-item config:name="SaveGlobalDocumentLinks" config:type="boolean">false</config:config-item><config:config-item config:name="CurrentDatabaseCommandType" config:type="int">0</config:config-item><config:config-item config:name="LoadReadonly" config:type="boolean">false</config:config-item><config:config-item config:name="DoNotResetParaAttrsForNumFont" config:type="boolean">false</config:config-item><config:config-item config:name="StylesNoDefault" config:type="boolean">false</config:config-item><config:config-item config:name="LinkUpdateMode" config:type="short">1</config:config-item><config:config-item config:name="DoNotJustifyLinesWithManualBreak" config:type="boolean">false</config:config-item><config:config-item config:name="PropLineSpacingShrinksFirstLine" config:type="boolean">true</config:config-item><config:config-item config:name="TabAtLeftIndentForParagraphsInList" config:type="boolean">false</config:config-item><config:config-item config:name="ProtectFields" config:type="boolean">false</config:config-item><config:config-item config:name="UnxForceZeroExtLeading" config:type="boolean">false</config:config-item><config:config-item config:name="CurrentDatabaseDataSource" config:type="string"/><config:config-item config:name="UseFormerTextWrapping" config:type="boolean">false</config:config-item><config:config-item config:name="UseFormerLineSpacing" config:type="boolean">false</config:config-item><config:config-item config:name="AllowPrintJobCancel" config:type="boolean">true</config:config-item><config:config-item config:name="SubtractFlysAnchoredAtFlys" config:type="boolean">false</config:config-item><config:config-item config:name="AddParaSpacingToTableCells" config:type="boolean">true</config:config-item><config:config-item config:name="AddExternalLeading" config:type="boolean">true</config:config-item><config:config-item config:name="Rsid" config:type="int">2178852</config:config-item><config:config-item config:name="AddVerticalFrameOffsets" config:type="boolean">false</config:config-item><config:config-item config:name="TreatSingleColumnBreakAsPageBreak" config:type="boolean">false</config:config-item><config:config-item config:name="AddFrameOffsets" config:type="boolean">false</config:config-item><config:config-item config:name="IsLabelDocument" config:type="boolean">false</config:config-item><config:config-item config:name="MsWordCompTrailingBlanks" config:type="boolean">false</config:config-item><config:config-item config:name="PrinterPaperFromSetup" config:type="boolean">false</config:config-item><config:config-item config:name="IgnoreFirstLineIndentInNumbering" config:type="boolean">false</config:config-item><config:config-item config:name="PrinterName" config:type="string"/><config:config-item config:name="IsKernAsianPunctuation" config:type="boolean">false</config:config-item><config:config-item config:name="PrinterIndependentLayout" config:type="string">high-resolution</config:config-item><config:config-item config:name="TableRowKeep" config:type="boolean">false</config:config-item><config:config-item config:name="UpdateFromTemplate" config:type="boolean">true</config:config-item><config:config-item config:name="EmbedComplexScriptFonts" config:type="boolean">true</config:config-item><config:config-item config:name="UseOldPrinterMetrics" config:type="boolean">false</config:config-item><config:config-item config:name="InvertBorderSpacing" config:type="boolean">false</config:config-item><config:config-item config:name="PrintProspectRTL" config:type="boolean">false</config:config-item><config:config-item config:name="ApplyUserData" config:type="boolean">true</config:config-item><config:config-item config:name="AddParaTableSpacingAtStart" config:type="boolean">true</config:config-item><config:config-item config:name="SaveVersionOnClose" config:type="boolean">false</config:config-item><config:config-item config:name="CharacterCompressionType" config:type="short">0</config:config-item><config:config-item config:name="UseOldNumbering" config:type="boolean">false</config:config-item><config:config-item config:name="UseFormerObjectPositioning" config:type="boolean">false</config:config-item><config:config-item config:name="ChartAutoUpdate" config:type="boolean">true</config:config-item><config:config-item config:name="AddParaTableSpacing" config:type="boolean">true</config:config-item></config:config-item-set></office:settings></office:document-settings> \ No newline at end of file
diff --git a/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/styles.xml b/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/styles.xml
new file mode 100644
index 00000000..91403c4e
--- /dev/null
+++ b/extract/test/Python2clipped.pdf.mutool.odt.dir.ref/styles.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<office:document-styles xmlns:css3t="http://www.w3.org/TR/css3-text/" xmlns:grddl="http://www.w3.org/2003/g/data-view#" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:dom="http://www.w3.org/2001/xml-events" xmlns:script="urn:oasis:names:tc:opendocument:xmlns:script:1.0" xmlns:form="urn:oasis:names:tc:opendocument:xmlns:form:1.0" xmlns:math="http://www.w3.org/1998/Math/MathML" xmlns:number="urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0" xmlns:field="urn:openoffice:names:experimental:ooo-ms-interop:xmlns:field:1.0" xmlns:meta="urn:oasis:names:tc:opendocument:xmlns:meta:1.0" xmlns:loext="urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0" xmlns:officeooo="http://openoffice.org/2009/office" xmlns:table="urn:oasis:names:tc:opendocument:xmlns:table:1.0" xmlns:chart="urn:oasis:names:tc:opendocument:xmlns:chart:1.0" xmlns:tableooo="http://openoffice.org/2009/table" xmlns:draw="urn:oasis:names:tc:opendocument:xmlns:drawing:1.0" xmlns:rpt="http://openoffice.org/2005/report" xmlns:dr3d="urn:oasis:names:tc:opendocument:xmlns:dr3d:1.0" xmlns:of="urn:oasis:names:tc:opendocument:xmlns:of:1.2" xmlns:text="urn:oasis:names:tc:opendocument:xmlns:text:1.0" xmlns:style="urn:oasis:names:tc:opendocument:xmlns:style:1.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:calcext="urn:org:documentfoundation:names:experimental:calc:xmlns:calcext:1.0" xmlns:oooc="http://openoffice.org/2004/calc" xmlns:drawooo="http://openoffice.org/2010/draw" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:ooo="http://openoffice.org/2004/office" xmlns:ooow="http://openoffice.org/2004/writer" xmlns:fo="urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0" xmlns:svg="urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" office:version="1.3"><office:font-face-decls><style:font-face style:name="Liberation Serif" svg:font-family="&apos;Liberation Serif&apos;" style:font-family-generic="roman" style:font-pitch="variable"/><style:font-face style:name="Liberation Sans" svg:font-family="&apos;Liberation Sans&apos;" style:font-family-generic="swiss" style:font-pitch="variable"/><style:font-face style:name="Unifont" svg:font-family="Unifont" style:font-family-generic="system" style:font-pitch="variable"/></office:font-face-decls><office:styles><style:default-style style:family="graphic"><style:graphic-properties svg:stroke-color="#3465a4" draw:fill-color="#729fcf" fo:wrap-option="no-wrap" draw:shadow-offset-x="0.1181in" draw:shadow-offset-y="0.1181in" draw:start-line-spacing-horizontal="0.1114in" draw:start-line-spacing-vertical="0.1114in" draw:end-line-spacing-horizontal="0.1114in" draw:end-line-spacing-vertical="0.1114in" style:flow-with-text="false"/><style:paragraph-properties style:text-autospace="ideograph-alpha" style:line-break="strict" style:font-independent-line-spacing="false"><style:tab-stops/></style:paragraph-properties><style:text-properties style:use-window-font-color="true" loext:opacity="0%" style:font-name="Liberation Serif" fo:font-size="12pt" fo:language="en" fo:country="US" style:letter-kerning="true" style:font-name-asian="Unifont" style:font-size-asian="10.5pt" style:language-asian="zh" style:country-asian="CN" style:font-name-complex="Unifont" style:font-size-complex="12pt" style:language-complex="hi" style:country-complex="IN"/></style:default-style><style:default-style style:family="paragraph"><style:paragraph-properties fo:orphans="2" fo:widows="2" fo:hyphenation-ladder-count="no-limit" style:text-autospace="ideograph-alpha" style:punctuation-wrap="hanging" style:line-break="strict" style:tab-stop-distance="0.4925in" style:writing-mode="page"/><style:text-properties style:use-window-font-color="true" loext:opacity="0%" style:font-name="Liberation Serif" fo:font-size="12pt" fo:language="en" fo:country="US" style:letter-kerning="true" style:font-name-asian="Unifont" style:font-size-asian="10.5pt" style:language-asian="zh" style:country-asian="CN" style:font-name-complex="Unifont" style:font-size-complex="12pt" style:language-complex="hi" style:country-complex="IN" fo:hyphenate="false" fo:hyphenation-remain-char-count="2" fo:hyphenation-push-char-count="2" loext:hyphenation-no-caps="false"/></style:default-style><style:default-style style:family="table"><style:table-properties table:border-model="collapsing"/></style:default-style><style:default-style style:family="table-row"><style:table-row-properties fo:keep-together="auto"/></style:default-style><style:style style:name="Standard" style:family="paragraph" style:class="text"><style:paragraph-properties fo:margin-top="0in" fo:margin-bottom="0.0799in" style:contextual-spacing="false"/></style:style><style:style style:name="Heading" style:family="paragraph" style:parent-style-name="Standard" style:next-style-name="Text_20_body" style:class="text"><style:paragraph-properties fo:margin-top="0.1665in" fo:margin-bottom="0.0835in" style:contextual-spacing="false" fo:keep-with-next="always"/><style:text-properties style:font-name="Liberation Sans" fo:font-family="&apos;Liberation Sans&apos;" style:font-family-generic="swiss" style:font-pitch="variable" fo:font-size="14pt" style:font-name-asian="Unifont" style:font-family-asian="Unifont" style:font-family-generic-asian="system" style:font-pitch-asian="variable" style:font-size-asian="14pt" style:font-name-complex="Unifont" style:font-family-complex="Unifont" style:font-family-generic-complex="system" style:font-pitch-complex="variable" style:font-size-complex="14pt"/></style:style><style:style style:name="Text_20_body" style:display-name="Text body" style:family="paragraph" style:parent-style-name="Standard" style:class="text"><style:paragraph-properties fo:margin-top="0in" fo:margin-bottom="0.0972in" style:contextual-spacing="false" fo:line-height="115%"/></style:style><style:style style:name="List" style:family="paragraph" style:parent-style-name="Text_20_body" style:class="list"><style:text-properties style:font-size-asian="12pt"/></style:style><style:style style:name="Caption" style:family="paragraph" style:parent-style-name="Standard" style:class="extra"><style:paragraph-properties fo:margin-top="0.0835in" fo:margin-bottom="0.0835in" style:contextual-spacing="false" text:number-lines="false" text:line-number="0"/><style:text-properties fo:font-size="12pt" fo:font-style="italic" style:font-size-asian="12pt" style:font-style-asian="italic" style:font-size-complex="12pt" style:font-style-complex="italic"/></style:style><style:style style:name="Index" style:family="paragraph" style:parent-style-name="Standard" style:class="index"><style:paragraph-properties text:number-lines="false" text:line-number="0"/><style:text-properties style:font-size-asian="12pt"/></style:style><text:outline-style style:name="Outline"><text:outline-level-style text:level="1" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="2" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="3" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="4" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="5" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="6" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="7" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="8" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="9" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="10" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style></text:outline-style><text:notes-configuration text:note-class="footnote" style:num-format="1" text:start-value="0" text:footnotes-position="page" text:start-numbering-at="document"/><text:notes-configuration text:note-class="endnote" style:num-format="i" text:start-value="0"/><text:linenumbering-configuration text:number-lines="false" text:offset="0.1965in" style:num-format="1" text:number-position="left" text:increment="5"/></office:styles><office:automatic-styles><style:page-layout style:name="Mpm1"><style:page-layout-properties fo:page-width="8.5in" fo:page-height="11in" style:num-format="1" style:print-orientation="portrait" fo:margin-top="0.7874in" fo:margin-bottom="0.7874in" fo:margin-left="0.7874in" fo:margin-right="0.7874in" style:writing-mode="lr-tb" style:layout-grid-color="#c0c0c0" style:layout-grid-lines="20" style:layout-grid-base-height="0.278in" style:layout-grid-ruby-height="0.139in" style:layout-grid-mode="none" style:layout-grid-ruby-below="false" style:layout-grid-print="false" style:layout-grid-display="false" style:footnote-max-height="0in"><style:footnote-sep style:width="0.0071in" style:distance-before-sep="0.0398in" style:distance-after-sep="0.0398in" style:line-style="solid" style:adjustment="left" style:rel-width="25%" style:color="#000000"/></style:page-layout-properties><style:header-style/><style:footer-style/></style:page-layout></office:automatic-styles><office:master-styles><style:master-page style:name="Standard" style:page-layout-name="Mpm1"/></office:master-styles></office:document-styles> \ No newline at end of file
diff --git a/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/META-INF/manifest.xml b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/META-INF/manifest.xml
new file mode 100644
index 00000000..a75f3862
--- /dev/null
+++ b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/META-INF/manifest.xml
@@ -0,0 +1,12 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<manifest:manifest xmlns:manifest="urn:oasis:names:tc:opendocument:xmlns:manifest:1.0" manifest:version="1.3" xmlns:loext="urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0">
+ <manifest:file-entry manifest:full-path="/" manifest:version="1.3" manifest:media-type="application/vnd.oasis.opendocument.text"/>
+ <manifest:file-entry manifest:full-path="meta.xml" manifest:media-type="text/xml"/>
+ <manifest:file-entry manifest:full-path="settings.xml" manifest:media-type="text/xml"/>
+ <manifest:file-entry manifest:full-path="Configurations2/" manifest:media-type="application/vnd.sun.xml.ui.configuration"/>
+ <manifest:file-entry manifest:full-path="manifest.rdf" manifest:media-type="application/rdf+xml"/>
+ <manifest:file-entry manifest:full-path="styles.xml" manifest:media-type="text/xml"/>
+ <manifest:file-entry manifest:full-path="content.xml" manifest:media-type="text/xml"/>
+ <manifest:file-entry manifest:full-path="Thumbnails/thumbnail.png" manifest:media-type="image/png"/>
+<manifest:file-entry manifest:full-path="Pictures/image11.jpeg" manifest:media-type="image/jpeg"/>
+</manifest:manifest> \ No newline at end of file
diff --git a/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/Pictures/image11.jpeg b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/Pictures/image11.jpeg
new file mode 100644
index 00000000..70105d1e
--- /dev/null
+++ b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/Pictures/image11.jpeg
Binary files differ
diff --git a/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/Thumbnails/thumbnail.png b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/Thumbnails/thumbnail.png
new file mode 100644
index 00000000..0dd1608e
--- /dev/null
+++ b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/Thumbnails/thumbnail.png
@@ -0,0 +1,2 @@
+PNG
+
diff --git a/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/content.xml b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/content.xml
new file mode 100644
index 00000000..233fd264
--- /dev/null
+++ b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/content.xml
@@ -0,0 +1,21 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<office:document-content xmlns:css3t="http://www.w3.org/TR/css3-text/" xmlns:grddl="http://www.w3.org/2003/g/data-view#" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xforms="http://www.w3.org/2002/xforms" xmlns:dom="http://www.w3.org/2001/xml-events" xmlns:script="urn:oasis:names:tc:opendocument:xmlns:script:1.0" xmlns:form="urn:oasis:names:tc:opendocument:xmlns:form:1.0" xmlns:math="http://www.w3.org/1998/Math/MathML" xmlns:number="urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0" xmlns:field="urn:openoffice:names:experimental:ooo-ms-interop:xmlns:field:1.0" xmlns:meta="urn:oasis:names:tc:opendocument:xmlns:meta:1.0" xmlns:loext="urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0" xmlns:officeooo="http://openoffice.org/2009/office" xmlns:table="urn:oasis:names:tc:opendocument:xmlns:table:1.0" xmlns:chart="urn:oasis:names:tc:opendocument:xmlns:chart:1.0" xmlns:tableooo="http://openoffice.org/2009/table" xmlns:draw="urn:oasis:names:tc:opendocument:xmlns:drawing:1.0" xmlns:rpt="http://openoffice.org/2005/report" xmlns:dr3d="urn:oasis:names:tc:opendocument:xmlns:dr3d:1.0" xmlns:of="urn:oasis:names:tc:opendocument:xmlns:of:1.2" xmlns:text="urn:oasis:names:tc:opendocument:xmlns:text:1.0" xmlns:style="urn:oasis:names:tc:opendocument:xmlns:style:1.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:calcext="urn:org:documentfoundation:names:experimental:calc:xmlns:calcext:1.0" xmlns:oooc="http://openoffice.org/2004/calc" xmlns:drawooo="http://openoffice.org/2010/draw" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:ooo="http://openoffice.org/2004/office" xmlns:ooow="http://openoffice.org/2004/writer" xmlns:fo="urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0" xmlns:formx="urn:openoffice:names:experimental:ooxml-odf-interop:xmlns:form:1.0" xmlns:svg="urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" office:version="1.3"><office:scripts/><office:font-face-decls><style:font-face style:name="Liberation Serif" svg:font-family="&apos;Liberation Serif&apos;" style:font-family-generic="roman" style:font-pitch="variable"/><style:font-face style:name="Liberation Sans" svg:font-family="&apos;Liberation Sans&apos;" style:font-family-generic="swiss" style:font-pitch="variable"/><style:font-face style:name="Unifont" svg:font-family="Unifont" style:font-family-generic="system" style:font-pitch="variable"/></office:font-face-decls><office:automatic-styles><style:style style:name="T11" style:family="text"><style:text-properties style:font-name="TimesNewRomanPSMT" fo:font-size="48.00pt" fo:font-weight="normal" fo:font-style="normal" /></style:style><style:style style:name="gr1" style:family="graphic">
+<style:graphic-properties draw:stroke="none" svg:stroke-color="#000000" draw:fill="none" draw:fill-color="#ffffff" fo:min-height="1.9898in" style:run-through="foreground" style:wrap="run-through" style:number-wrapped-paragraphs="no-limit" style:vertical-pos="from-top" style:vertical-rel="paragraph" style:horizontal-pos="from-left" style:horizontal-rel="paragraph" />
+<style:paragraph-properties style:writing-mode="lr-tb"/>
+</style:style>
+<style:style style:name="fr1" style:family="graphic" style:parent-style-name="Graphics">
+<style:graphic-properties fo:margin-left="0in" fo:margin-right="0in" fo:margin-top="0in" fo:margin-bottom="0in" style:vertical-pos="top" style:vertical-rel="baseline" fo:background-color="transparent" draw:fill="none" draw:fill-color="#ffffff" fo:padding="0in" fo:border="none" style:mirror="none" fo:clip="rect(0in, 0in, 0in, 0in)" draw:luminance="0%" draw:contrast="0%" draw:red="0%" draw:green="0%" draw:blue="0%" draw:gamma="100%" draw:color-inversion="false" draw:image-opacity="100%" draw:color-mode="standard"/>
+</style:style>
+</office:automatic-styles><office:body><office:text><text:sequence-decls><text:sequence-decl text:display-outline-level="0" text:name="Illustration"/><text:sequence-decl text:display-outline-level="0" text:name="Table"/><text:sequence-decl text:display-outline-level="0" text:name="Text"/><text:sequence-decl text:display-outline-level="0" text:name="Drawing"/><text:sequence-decl text:display-outline-level="0" text:name="Figure"/></text:sequence-decls><text:p text:style-name="Standard"/>
+
+<text:p><text:span text:style-name="T11">Black RGB </text:span></text:p>
+
+<text:p><text:span text:style-name="T11">Gray RGB </text:span></text:p>
+
+<text:p><text:span text:style-name="T11">NeutralCIELAB</text:span></text:p>
+<text:p text:style-name="Standard">
+<draw:frame draw:style-name="fr1" draw:name="Picture rId11" text:anchor-type="as-char" svg:width="4.277778in" svg:height="3.208333in" draw:z-index="0">
+<draw:image xlink:href="Pictures/image11.jpeg" xlink:type="simple" xlink:show="embed" xlink:actuate="onLoad" draw:mime-type="image/jpeg"/>
+</draw:frame>
+</text:p>
+</office:text></office:body></office:document-content> \ No newline at end of file
diff --git a/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/manifest.rdf b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/manifest.rdf
new file mode 100644
index 00000000..927e206b
--- /dev/null
+++ b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/manifest.rdf
@@ -0,0 +1,18 @@
+<?xml version="1.0" encoding="utf-8"?>
+<rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#">
+ <rdf:Description rdf:about="styles.xml">
+ <rdf:type rdf:resource="http://docs.oasis-open.org/ns/office/1.2/meta/odf#StylesFile"/>
+ </rdf:Description>
+ <rdf:Description rdf:about="">
+ <ns0:hasPart xmlns:ns0="http://docs.oasis-open.org/ns/office/1.2/meta/pkg#" rdf:resource="styles.xml"/>
+ </rdf:Description>
+ <rdf:Description rdf:about="content.xml">
+ <rdf:type rdf:resource="http://docs.oasis-open.org/ns/office/1.2/meta/odf#ContentFile"/>
+ </rdf:Description>
+ <rdf:Description rdf:about="">
+ <ns0:hasPart xmlns:ns0="http://docs.oasis-open.org/ns/office/1.2/meta/pkg#" rdf:resource="content.xml"/>
+ </rdf:Description>
+ <rdf:Description rdf:about="">
+ <rdf:type rdf:resource="http://docs.oasis-open.org/ns/office/1.2/meta/pkg#Document"/>
+ </rdf:Description>
+</rdf:RDF>
diff --git a/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/meta.xml b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/meta.xml
new file mode 100644
index 00000000..6b42561e
--- /dev/null
+++ b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/meta.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<office:document-meta xmlns:grddl="http://www.w3.org/2003/g/data-view#" xmlns:meta="urn:oasis:names:tc:opendocument:xmlns:meta:1.0" xmlns:ooo="http://openoffice.org/2004/office" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" office:version="1.3"><office:meta><meta:creation-date>2021-04-05T17:06:57.937137058</meta:creation-date><meta:generator>LibreOffice/7.0.1.2$OpenBSD_X86_64 LibreOffice_project/00$Build-2</meta:generator><dc:date>2021-04-06T17:14:51.409959656</dc:date><meta:editing-duration>PT20S</meta:editing-duration><meta:editing-cycles>1</meta:editing-cycles><meta:document-statistic meta:table-count="0" meta:image-count="0" meta:object-count="0" meta:page-count="1" meta:paragraph-count="0" meta:word-count="0" meta:character-count="0" meta:non-whitespace-character-count="0"/></office:meta></office:document-meta> \ No newline at end of file
diff --git a/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/mimetype b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/mimetype
new file mode 100644
index 00000000..2e95b81c
--- /dev/null
+++ b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/mimetype
@@ -0,0 +1 @@
+application/vnd.oasis.opendocument.text \ No newline at end of file
diff --git a/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/settings.xml b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/settings.xml
new file mode 100644
index 00000000..35a8138f
--- /dev/null
+++ b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/settings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<office:document-settings xmlns:config="urn:oasis:names:tc:opendocument:xmlns:config:1.0" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:ooo="http://openoffice.org/2004/office" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" office:version="1.3"><office:settings><config:config-item-set config:name="ooo:view-settings"><config:config-item config:name="ViewAreaTop" config:type="long">0</config:config-item><config:config-item config:name="ViewAreaLeft" config:type="long">0</config:config-item><config:config-item config:name="ViewAreaWidth" config:type="long">26275</config:config-item><config:config-item config:name="ViewAreaHeight" config:type="long">19502</config:config-item><config:config-item config:name="ShowRedlineChanges" config:type="boolean">true</config:config-item><config:config-item config:name="InBrowseMode" config:type="boolean">false</config:config-item><config:config-item-map-indexed config:name="Views"><config:config-item-map-entry><config:config-item config:name="ViewId" config:type="string">view2</config:config-item><config:config-item config:name="ViewLeft" config:type="long">4343</config:config-item><config:config-item config:name="ViewTop" config:type="long">2501</config:config-item><config:config-item config:name="VisibleLeft" config:type="long">0</config:config-item><config:config-item config:name="VisibleTop" config:type="long">0</config:config-item><config:config-item config:name="VisibleRight" config:type="long">26273</config:config-item><config:config-item config:name="VisibleBottom" config:type="long">19500</config:config-item><config:config-item config:name="ZoomType" config:type="short">0</config:config-item><config:config-item config:name="ViewLayoutColumns" config:type="short">1</config:config-item><config:config-item config:name="ViewLayoutBookMode" config:type="boolean">false</config:config-item><config:config-item config:name="ZoomFactor" config:type="short">100</config:config-item><config:config-item config:name="IsSelectedFrame" config:type="boolean">false</config:config-item><config:config-item config:name="AnchoredTextOverflowLegacy" config:type="boolean">false</config:config-item></config:config-item-map-entry></config:config-item-map-indexed></config:config-item-set><config:config-item-set config:name="ooo:configuration-settings"><config:config-item config:name="PrintBlackFonts" config:type="boolean">false</config:config-item><config:config-item config:name="PrintReversed" config:type="boolean">false</config:config-item><config:config-item config:name="SaveThumbnail" config:type="boolean">true</config:config-item><config:config-item config:name="EmbedFonts" config:type="boolean">false</config:config-item><config:config-item config:name="PrintControls" config:type="boolean">true</config:config-item><config:config-item config:name="OutlineLevelYieldsNumbering" config:type="boolean">false</config:config-item><config:config-item config:name="PrintPageBackground" config:type="boolean">true</config:config-item><config:config-item config:name="PrintAnnotationMode" config:type="short">0</config:config-item><config:config-item config:name="PrintGraphics" config:type="boolean">true</config:config-item><config:config-item config:name="EmbeddedDatabaseName" config:type="string"/><config:config-item config:name="ProtectForm" config:type="boolean">false</config:config-item><config:config-item config:name="PrintLeftPages" config:type="boolean">true</config:config-item><config:config-item config:name="PrintProspect" config:type="boolean">false</config:config-item><config:config-item config:name="PrintHiddenText" config:type="boolean">false</config:config-item><config:config-item config:name="PrintRightPages" config:type="boolean">true</config:config-item><config:config-item config:name="PrintFaxName" config:type="string"/><config:config-item config:name="PrintPaperFromSetup" config:type="boolean">false</config:config-item><config:config-item config:name="TabsRelativeToIndent" config:type="boolean">true</config:config-item><config:config-item config:name="RedlineProtectionKey" config:type="base64Binary"/><config:config-item config:name="PrintTextPlaceholder" config:type="boolean">false</config:config-item><config:config-item config:name="MathBaselineAlignment" config:type="boolean">true</config:config-item><config:config-item config:name="ProtectBookmarks" config:type="boolean">false</config:config-item><config:config-item config:name="IgnoreTabsAndBlanksForLineCalculation" config:type="boolean">false</config:config-item><config:config-item config:name="ContinuousEndnotes" config:type="boolean">false</config:config-item><config:config-item config:name="FieldAutoUpdate" config:type="boolean">true</config:config-item><config:config-item config:name="EmptyDbFieldHidesPara" config:type="boolean">true</config:config-item><config:config-item config:name="ApplyParagraphMarkFormatToNumbering" config:type="boolean">false</config:config-item><config:config-item config:name="PrintEmptyPages" config:type="boolean">true</config:config-item><config:config-item config:name="TabOverMargin" config:type="boolean">false</config:config-item><config:config-item config:name="EmbedAsianScriptFonts" config:type="boolean">true</config:config-item><config:config-item config:name="EmbedLatinScriptFonts" config:type="boolean">true</config:config-item><config:config-item config:name="DisableOffPagePositioning" config:type="boolean">false</config:config-item><config:config-item config:name="EmbedOnlyUsedFonts" config:type="boolean">false</config:config-item><config:config-item config:name="MsWordCompMinLineHeightByFly" config:type="boolean">false</config:config-item><config:config-item config:name="SurroundTextWrapSmall" config:type="boolean">false</config:config-item><config:config-item config:name="BackgroundParaOverDrawings" config:type="boolean">false</config:config-item><config:config-item config:name="ClippedPictures" config:type="boolean">false</config:config-item><config:config-item config:name="FloattableNomargins" config:type="boolean">false</config:config-item><config:config-item config:name="UnbreakableNumberings" config:type="boolean">false</config:config-item><config:config-item config:name="EmbedSystemFonts" config:type="boolean">false</config:config-item><config:config-item config:name="TabOverflow" config:type="boolean">true</config:config-item><config:config-item config:name="PrintTables" config:type="boolean">true</config:config-item><config:config-item config:name="PrintDrawings" config:type="boolean">true</config:config-item><config:config-item config:name="ConsiderTextWrapOnObjPos" config:type="boolean">false</config:config-item><config:config-item config:name="PrintSingleJobs" config:type="boolean">false</config:config-item><config:config-item config:name="SmallCapsPercentage66" config:type="boolean">false</config:config-item><config:config-item config:name="CollapseEmptyCellPara" config:type="boolean">true</config:config-item><config:config-item config:name="HeaderSpacingBelowLastPara" config:type="boolean">false</config:config-item><config:config-item config:name="RsidRoot" config:type="int">2052946</config:config-item><config:config-item config:name="PrinterSetup" config:type="base64Binary"/><config:config-item config:name="CurrentDatabaseCommand" config:type="string"/><config:config-item config:name="AlignTabStopPosition" config:type="boolean">true</config:config-item><config:config-item config:name="ClipAsCharacterAnchoredWriterFlyFrames" config:type="boolean">false</config:config-item><config:config-item config:name="DoNotCaptureDrawObjsOnPage" config:type="boolean">false</config:config-item><config:config-item config:name="SaveGlobalDocumentLinks" config:type="boolean">false</config:config-item><config:config-item config:name="CurrentDatabaseCommandType" config:type="int">0</config:config-item><config:config-item config:name="LoadReadonly" config:type="boolean">false</config:config-item><config:config-item config:name="DoNotResetParaAttrsForNumFont" config:type="boolean">false</config:config-item><config:config-item config:name="StylesNoDefault" config:type="boolean">false</config:config-item><config:config-item config:name="LinkUpdateMode" config:type="short">1</config:config-item><config:config-item config:name="DoNotJustifyLinesWithManualBreak" config:type="boolean">false</config:config-item><config:config-item config:name="PropLineSpacingShrinksFirstLine" config:type="boolean">true</config:config-item><config:config-item config:name="TabAtLeftIndentForParagraphsInList" config:type="boolean">false</config:config-item><config:config-item config:name="ProtectFields" config:type="boolean">false</config:config-item><config:config-item config:name="UnxForceZeroExtLeading" config:type="boolean">false</config:config-item><config:config-item config:name="CurrentDatabaseDataSource" config:type="string"/><config:config-item config:name="UseFormerTextWrapping" config:type="boolean">false</config:config-item><config:config-item config:name="UseFormerLineSpacing" config:type="boolean">false</config:config-item><config:config-item config:name="AllowPrintJobCancel" config:type="boolean">true</config:config-item><config:config-item config:name="SubtractFlysAnchoredAtFlys" config:type="boolean">false</config:config-item><config:config-item config:name="AddParaSpacingToTableCells" config:type="boolean">true</config:config-item><config:config-item config:name="AddExternalLeading" config:type="boolean">true</config:config-item><config:config-item config:name="Rsid" config:type="int">2178852</config:config-item><config:config-item config:name="AddVerticalFrameOffsets" config:type="boolean">false</config:config-item><config:config-item config:name="TreatSingleColumnBreakAsPageBreak" config:type="boolean">false</config:config-item><config:config-item config:name="AddFrameOffsets" config:type="boolean">false</config:config-item><config:config-item config:name="IsLabelDocument" config:type="boolean">false</config:config-item><config:config-item config:name="MsWordCompTrailingBlanks" config:type="boolean">false</config:config-item><config:config-item config:name="PrinterPaperFromSetup" config:type="boolean">false</config:config-item><config:config-item config:name="IgnoreFirstLineIndentInNumbering" config:type="boolean">false</config:config-item><config:config-item config:name="PrinterName" config:type="string"/><config:config-item config:name="IsKernAsianPunctuation" config:type="boolean">false</config:config-item><config:config-item config:name="PrinterIndependentLayout" config:type="string">high-resolution</config:config-item><config:config-item config:name="TableRowKeep" config:type="boolean">false</config:config-item><config:config-item config:name="UpdateFromTemplate" config:type="boolean">true</config:config-item><config:config-item config:name="EmbedComplexScriptFonts" config:type="boolean">true</config:config-item><config:config-item config:name="UseOldPrinterMetrics" config:type="boolean">false</config:config-item><config:config-item config:name="InvertBorderSpacing" config:type="boolean">false</config:config-item><config:config-item config:name="PrintProspectRTL" config:type="boolean">false</config:config-item><config:config-item config:name="ApplyUserData" config:type="boolean">true</config:config-item><config:config-item config:name="AddParaTableSpacingAtStart" config:type="boolean">true</config:config-item><config:config-item config:name="SaveVersionOnClose" config:type="boolean">false</config:config-item><config:config-item config:name="CharacterCompressionType" config:type="short">0</config:config-item><config:config-item config:name="UseOldNumbering" config:type="boolean">false</config:config-item><config:config-item config:name="UseFormerObjectPositioning" config:type="boolean">false</config:config-item><config:config-item config:name="ChartAutoUpdate" config:type="boolean">true</config:config-item><config:config-item config:name="AddParaTableSpacing" config:type="boolean">true</config:config-item></config:config-item-set></office:settings></office:document-settings> \ No newline at end of file
diff --git a/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/styles.xml b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/styles.xml
new file mode 100644
index 00000000..91403c4e
--- /dev/null
+++ b/extract/test/text_graphic_image.pdf.mutool.odt.dir.ref/styles.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<office:document-styles xmlns:css3t="http://www.w3.org/TR/css3-text/" xmlns:grddl="http://www.w3.org/2003/g/data-view#" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:dom="http://www.w3.org/2001/xml-events" xmlns:script="urn:oasis:names:tc:opendocument:xmlns:script:1.0" xmlns:form="urn:oasis:names:tc:opendocument:xmlns:form:1.0" xmlns:math="http://www.w3.org/1998/Math/MathML" xmlns:number="urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0" xmlns:field="urn:openoffice:names:experimental:ooo-ms-interop:xmlns:field:1.0" xmlns:meta="urn:oasis:names:tc:opendocument:xmlns:meta:1.0" xmlns:loext="urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0" xmlns:officeooo="http://openoffice.org/2009/office" xmlns:table="urn:oasis:names:tc:opendocument:xmlns:table:1.0" xmlns:chart="urn:oasis:names:tc:opendocument:xmlns:chart:1.0" xmlns:tableooo="http://openoffice.org/2009/table" xmlns:draw="urn:oasis:names:tc:opendocument:xmlns:drawing:1.0" xmlns:rpt="http://openoffice.org/2005/report" xmlns:dr3d="urn:oasis:names:tc:opendocument:xmlns:dr3d:1.0" xmlns:of="urn:oasis:names:tc:opendocument:xmlns:of:1.2" xmlns:text="urn:oasis:names:tc:opendocument:xmlns:text:1.0" xmlns:style="urn:oasis:names:tc:opendocument:xmlns:style:1.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:calcext="urn:org:documentfoundation:names:experimental:calc:xmlns:calcext:1.0" xmlns:oooc="http://openoffice.org/2004/calc" xmlns:drawooo="http://openoffice.org/2010/draw" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:ooo="http://openoffice.org/2004/office" xmlns:ooow="http://openoffice.org/2004/writer" xmlns:fo="urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0" xmlns:svg="urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" office:version="1.3"><office:font-face-decls><style:font-face style:name="Liberation Serif" svg:font-family="&apos;Liberation Serif&apos;" style:font-family-generic="roman" style:font-pitch="variable"/><style:font-face style:name="Liberation Sans" svg:font-family="&apos;Liberation Sans&apos;" style:font-family-generic="swiss" style:font-pitch="variable"/><style:font-face style:name="Unifont" svg:font-family="Unifont" style:font-family-generic="system" style:font-pitch="variable"/></office:font-face-decls><office:styles><style:default-style style:family="graphic"><style:graphic-properties svg:stroke-color="#3465a4" draw:fill-color="#729fcf" fo:wrap-option="no-wrap" draw:shadow-offset-x="0.1181in" draw:shadow-offset-y="0.1181in" draw:start-line-spacing-horizontal="0.1114in" draw:start-line-spacing-vertical="0.1114in" draw:end-line-spacing-horizontal="0.1114in" draw:end-line-spacing-vertical="0.1114in" style:flow-with-text="false"/><style:paragraph-properties style:text-autospace="ideograph-alpha" style:line-break="strict" style:font-independent-line-spacing="false"><style:tab-stops/></style:paragraph-properties><style:text-properties style:use-window-font-color="true" loext:opacity="0%" style:font-name="Liberation Serif" fo:font-size="12pt" fo:language="en" fo:country="US" style:letter-kerning="true" style:font-name-asian="Unifont" style:font-size-asian="10.5pt" style:language-asian="zh" style:country-asian="CN" style:font-name-complex="Unifont" style:font-size-complex="12pt" style:language-complex="hi" style:country-complex="IN"/></style:default-style><style:default-style style:family="paragraph"><style:paragraph-properties fo:orphans="2" fo:widows="2" fo:hyphenation-ladder-count="no-limit" style:text-autospace="ideograph-alpha" style:punctuation-wrap="hanging" style:line-break="strict" style:tab-stop-distance="0.4925in" style:writing-mode="page"/><style:text-properties style:use-window-font-color="true" loext:opacity="0%" style:font-name="Liberation Serif" fo:font-size="12pt" fo:language="en" fo:country="US" style:letter-kerning="true" style:font-name-asian="Unifont" style:font-size-asian="10.5pt" style:language-asian="zh" style:country-asian="CN" style:font-name-complex="Unifont" style:font-size-complex="12pt" style:language-complex="hi" style:country-complex="IN" fo:hyphenate="false" fo:hyphenation-remain-char-count="2" fo:hyphenation-push-char-count="2" loext:hyphenation-no-caps="false"/></style:default-style><style:default-style style:family="table"><style:table-properties table:border-model="collapsing"/></style:default-style><style:default-style style:family="table-row"><style:table-row-properties fo:keep-together="auto"/></style:default-style><style:style style:name="Standard" style:family="paragraph" style:class="text"><style:paragraph-properties fo:margin-top="0in" fo:margin-bottom="0.0799in" style:contextual-spacing="false"/></style:style><style:style style:name="Heading" style:family="paragraph" style:parent-style-name="Standard" style:next-style-name="Text_20_body" style:class="text"><style:paragraph-properties fo:margin-top="0.1665in" fo:margin-bottom="0.0835in" style:contextual-spacing="false" fo:keep-with-next="always"/><style:text-properties style:font-name="Liberation Sans" fo:font-family="&apos;Liberation Sans&apos;" style:font-family-generic="swiss" style:font-pitch="variable" fo:font-size="14pt" style:font-name-asian="Unifont" style:font-family-asian="Unifont" style:font-family-generic-asian="system" style:font-pitch-asian="variable" style:font-size-asian="14pt" style:font-name-complex="Unifont" style:font-family-complex="Unifont" style:font-family-generic-complex="system" style:font-pitch-complex="variable" style:font-size-complex="14pt"/></style:style><style:style style:name="Text_20_body" style:display-name="Text body" style:family="paragraph" style:parent-style-name="Standard" style:class="text"><style:paragraph-properties fo:margin-top="0in" fo:margin-bottom="0.0972in" style:contextual-spacing="false" fo:line-height="115%"/></style:style><style:style style:name="List" style:family="paragraph" style:parent-style-name="Text_20_body" style:class="list"><style:text-properties style:font-size-asian="12pt"/></style:style><style:style style:name="Caption" style:family="paragraph" style:parent-style-name="Standard" style:class="extra"><style:paragraph-properties fo:margin-top="0.0835in" fo:margin-bottom="0.0835in" style:contextual-spacing="false" text:number-lines="false" text:line-number="0"/><style:text-properties fo:font-size="12pt" fo:font-style="italic" style:font-size-asian="12pt" style:font-style-asian="italic" style:font-size-complex="12pt" style:font-style-complex="italic"/></style:style><style:style style:name="Index" style:family="paragraph" style:parent-style-name="Standard" style:class="index"><style:paragraph-properties text:number-lines="false" text:line-number="0"/><style:text-properties style:font-size-asian="12pt"/></style:style><text:outline-style style:name="Outline"><text:outline-level-style text:level="1" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="2" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="3" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="4" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="5" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="6" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="7" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="8" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="9" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="10" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style></text:outline-style><text:notes-configuration text:note-class="footnote" style:num-format="1" text:start-value="0" text:footnotes-position="page" text:start-numbering-at="document"/><text:notes-configuration text:note-class="endnote" style:num-format="i" text:start-value="0"/><text:linenumbering-configuration text:number-lines="false" text:offset="0.1965in" style:num-format="1" text:number-position="left" text:increment="5"/></office:styles><office:automatic-styles><style:page-layout style:name="Mpm1"><style:page-layout-properties fo:page-width="8.5in" fo:page-height="11in" style:num-format="1" style:print-orientation="portrait" fo:margin-top="0.7874in" fo:margin-bottom="0.7874in" fo:margin-left="0.7874in" fo:margin-right="0.7874in" style:writing-mode="lr-tb" style:layout-grid-color="#c0c0c0" style:layout-grid-lines="20" style:layout-grid-base-height="0.278in" style:layout-grid-ruby-height="0.139in" style:layout-grid-mode="none" style:layout-grid-ruby-below="false" style:layout-grid-print="false" style:layout-grid-display="false" style:footnote-max-height="0in"><style:footnote-sep style:width="0.0071in" style:distance-before-sep="0.0398in" style:distance-after-sep="0.0398in" style:line-style="solid" style:adjustment="left" style:rel-width="25%" style:color="#000000"/></style:page-layout-properties><style:header-style/><style:footer-style/></style:page-layout></office:automatic-styles><office:master-styles><style:master-page style:name="Standard" style:page-layout-name="Mpm1"/></office:master-styles></office:document-styles> \ No newline at end of file
diff --git a/extract/test/zlib.3.pdf.mutool.odt.dir.ref/META-INF/manifest.xml b/extract/test/zlib.3.pdf.mutool.odt.dir.ref/META-INF/manifest.xml
new file mode 100644
index 00000000..ec991d79
--- /dev/null
+++ b/extract/test/zlib.3.pdf.mutool.odt.dir.ref/META-INF/manifest.xml
@@ -0,0 +1,11 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<manifest:manifest xmlns:manifest="urn:oasis:names:tc:opendocument:xmlns:manifest:1.0" manifest:version="1.3" xmlns:loext="urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0">
+ <manifest:file-entry manifest:full-path="/" manifest:version="1.3" manifest:media-type="application/vnd.oasis.opendocument.text"/>
+ <manifest:file-entry manifest:full-path="meta.xml" manifest:media-type="text/xml"/>
+ <manifest:file-entry manifest:full-path="settings.xml" manifest:media-type="text/xml"/>
+ <manifest:file-entry manifest:full-path="Configurations2/" manifest:media-type="application/vnd.sun.xml.ui.configuration"/>
+ <manifest:file-entry manifest:full-path="manifest.rdf" manifest:media-type="application/rdf+xml"/>
+ <manifest:file-entry manifest:full-path="styles.xml" manifest:media-type="text/xml"/>
+ <manifest:file-entry manifest:full-path="content.xml" manifest:media-type="text/xml"/>
+ <manifest:file-entry manifest:full-path="Thumbnails/thumbnail.png" manifest:media-type="image/png"/>
+</manifest:manifest> \ No newline at end of file
diff --git a/extract/test/zlib.3.pdf.mutool.odt.dir.ref/Thumbnails/thumbnail.png b/extract/test/zlib.3.pdf.mutool.odt.dir.ref/Thumbnails/thumbnail.png
new file mode 100644
index 00000000..0dd1608e
--- /dev/null
+++ b/extract/test/zlib.3.pdf.mutool.odt.dir.ref/Thumbnails/thumbnail.png
@@ -0,0 +1,2 @@
+PNG
+
diff --git a/extract/test/zlib.3.pdf.mutool.odt.dir.ref/content.xml b/extract/test/zlib.3.pdf.mutool.odt.dir.ref/content.xml
new file mode 100644
index 00000000..d3f5f2be
--- /dev/null
+++ b/extract/test/zlib.3.pdf.mutool.odt.dir.ref/content.xml
@@ -0,0 +1,77 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<office:document-content xmlns:css3t="http://www.w3.org/TR/css3-text/" xmlns:grddl="http://www.w3.org/2003/g/data-view#" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xforms="http://www.w3.org/2002/xforms" xmlns:dom="http://www.w3.org/2001/xml-events" xmlns:script="urn:oasis:names:tc:opendocument:xmlns:script:1.0" xmlns:form="urn:oasis:names:tc:opendocument:xmlns:form:1.0" xmlns:math="http://www.w3.org/1998/Math/MathML" xmlns:number="urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0" xmlns:field="urn:openoffice:names:experimental:ooo-ms-interop:xmlns:field:1.0" xmlns:meta="urn:oasis:names:tc:opendocument:xmlns:meta:1.0" xmlns:loext="urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0" xmlns:officeooo="http://openoffice.org/2009/office" xmlns:table="urn:oasis:names:tc:opendocument:xmlns:table:1.0" xmlns:chart="urn:oasis:names:tc:opendocument:xmlns:chart:1.0" xmlns:tableooo="http://openoffice.org/2009/table" xmlns:draw="urn:oasis:names:tc:opendocument:xmlns:drawing:1.0" xmlns:rpt="http://openoffice.org/2005/report" xmlns:dr3d="urn:oasis:names:tc:opendocument:xmlns:dr3d:1.0" xmlns:of="urn:oasis:names:tc:opendocument:xmlns:of:1.2" xmlns:text="urn:oasis:names:tc:opendocument:xmlns:text:1.0" xmlns:style="urn:oasis:names:tc:opendocument:xmlns:style:1.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:calcext="urn:org:documentfoundation:names:experimental:calc:xmlns:calcext:1.0" xmlns:oooc="http://openoffice.org/2004/calc" xmlns:drawooo="http://openoffice.org/2010/draw" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:ooo="http://openoffice.org/2004/office" xmlns:ooow="http://openoffice.org/2004/writer" xmlns:fo="urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0" xmlns:formx="urn:openoffice:names:experimental:ooxml-odf-interop:xmlns:form:1.0" xmlns:svg="urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" office:version="1.3"><office:scripts/><office:font-face-decls><style:font-face style:name="Liberation Serif" svg:font-family="&apos;Liberation Serif&apos;" style:font-family-generic="roman" style:font-pitch="variable"/><style:font-face style:name="Liberation Sans" svg:font-family="&apos;Liberation Sans&apos;" style:font-family-generic="swiss" style:font-pitch="variable"/><style:font-face style:name="Unifont" svg:font-family="Unifont" style:font-family-generic="system" style:font-pitch="variable"/></office:font-face-decls><office:automatic-styles><style:style style:name="T13" style:family="text"><style:text-properties style:font-name="Helvetica-Oblique" fo:font-size="10.00pt" fo:font-weight="normal" fo:font-style="italic" /></style:style><style:style style:name="T12" style:family="text"><style:text-properties style:font-name="Helvetica-Bold" fo:font-size="10.95pt" fo:font-weight="bold" fo:font-style="normal" /></style:style><style:style style:name="T11" style:family="text"><style:text-properties style:font-name="Helvetica" fo:font-size="10.00pt" fo:font-weight="normal" fo:font-style="normal" /></style:style><style:style style:name="gr1" style:family="graphic">
+<style:graphic-properties draw:stroke="none" svg:stroke-color="#000000" draw:fill="none" draw:fill-color="#ffffff" fo:min-height="1.9898in" style:run-through="foreground" style:wrap="run-through" style:number-wrapped-paragraphs="no-limit" style:vertical-pos="from-top" style:vertical-rel="paragraph" style:horizontal-pos="from-left" style:horizontal-rel="paragraph" />
+<style:paragraph-properties style:writing-mode="lr-tb"/>
+</style:style>
+<style:style style:name="fr1" style:family="graphic" style:parent-style-name="Graphics">
+<style:graphic-properties fo:margin-left="0in" fo:margin-right="0in" fo:margin-top="0in" fo:margin-bottom="0in" style:vertical-pos="top" style:vertical-rel="baseline" fo:background-color="transparent" draw:fill="none" draw:fill-color="#ffffff" fo:padding="0in" fo:border="none" style:mirror="none" fo:clip="rect(0in, 0in, 0in, 0in)" draw:luminance="0%" draw:contrast="0%" draw:red="0%" draw:green="0%" draw:blue="0%" draw:gamma="100%" draw:color-inversion="false" draw:image-opacity="100%" draw:color-mode="standard"/>
+</style:style>
+</office:automatic-styles><office:body><office:text><text:sequence-decls><text:sequence-decl text:display-outline-level="0" text:name="Illustration"/><text:sequence-decl text:display-outline-level="0" text:name="Table"/><text:sequence-decl text:display-outline-level="0" text:name="Text"/><text:sequence-decl text:display-outline-level="0" text:name="Drawing"/><text:sequence-decl text:display-outline-level="0" text:name="Figure"/></text:sequence-decls><text:p text:style-name="Standard"/>
+
+<text:p><text:span text:style-name="T11">ZLIB(3) ZLIB(3)</text:span></text:p>
+
+<text:p><text:span text:style-name="T12">NAME </text:span><text:span text:style-name="T11">zlib &#x2212; compression/decompression library</text:span></text:p>
+
+<text:p><text:span text:style-name="T12">SYNOPSIS </text:span><text:span text:style-name="T11">[see </text:span><text:span text:style-name="T13">zlib.h </text:span><text:span text:style-name="T11">for full description]</text:span></text:p>
+
+<text:p><text:span text:style-name="T12">DESCRIPTION </text:span><text:span text:style-name="T11">The </text:span><text:span text:style-name="T13">zlib </text:span><text:span text:style-name="T11">library is a general purpose data compression library. The code is thread safe, assuming that the standard library functions used are thread safe, such as memory allocation routines. It provides in-memory compression and decompression functions, including integrity checks of the uncompressed data. This version of the library supports only one compression method (deflation) but other algorithms may be added later with the same stream interface.</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">Compression can be done in a single step if the buffers are large enough or can be done by repeated calls of the compression function. In the latter case, the application must provide more input and/or consume the output (providing more output space) before each call.</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">The library also supports reading and writing files in </text:span><text:span text:style-name="T13">gzip</text:span><text:span text:style-name="T11">(1) (.gz) format with an interface similar to that of stdio.</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">The library does not install any signal handler. The decoder checks the consistency of the compressed data, so the library should never crash even in the case of corrupted input.</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">All functions of the compression library are documented in the file </text:span><text:span text:style-name="T13">zlib.h</text:span><text:span text:style-name="T11">. The distribution source includes examples of use of the library in the files </text:span><text:span text:style-name="T13">test/example.c </text:span><text:span text:style-name="T11">and </text:span><text:span text:style-name="T13">test/minigzip.c, </text:span><text:span text:style-name="T11">as well as other examples in the </text:span><text:span text:style-name="T13">examples/ </text:span><text:span text:style-name="T11">directory.</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">Changes to this version are documented in the file </text:span><text:span text:style-name="T13">ChangeLog </text:span><text:span text:style-name="T11">that accompanies the source.</text:span></text:p>
+
+<text:p><text:span text:style-name="T13">zlib </text:span><text:span text:style-name="T11">is built in to many languages and operating systems, including but not limited to Java, Python, .NET, PHP, Perl, Ruby, Swift, and Go.</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">An experimental package to read and write files in the .zip format, written on top of </text:span><text:span text:style-name="T13">zlib </text:span><text:span text:style-name="T11">by Gilles Vollant (info@winimage.com), is available at:</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">http://www.winimage.com/zLibDll/minizip.html and also in the </text:span><text:span text:style-name="T13">contrib/minizip </text:span><text:span text:style-name="T11">directory of the main </text:span><text:span text:style-name="T13">zlib </text:span><text:span text:style-name="T11">source distribution.</text:span></text:p>
+
+<text:p><text:span text:style-name="T12">SEE ALSO </text:span><text:span text:style-name="T11">The </text:span><text:span text:style-name="T13">zlib </text:span><text:span text:style-name="T11">web site can be found at:</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">http://zlib.net/</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">The data format used by the </text:span><text:span text:style-name="T13">zlib </text:span><text:span text:style-name="T11">library is described by RFC (Request for Comments) 1950 to 1952 in the files:</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">http://tools.ietf.org/html/rfc1950 (for the zlib header and trailer format) http://tools.ietf.org/html/rfc1951 (for the deflate compressed data format) http://tools.ietf.org/html/rfc1952 (for the gzip header and trailer format)</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">Mark Nelson wrote an article about </text:span><text:span text:style-name="T13">zlib </text:span><text:span text:style-name="T11">for the Jan. 1997 issue of Dr. Dobb&#x2019;s Journal; a copy of the article is available at:</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">http://marknelson.us/1997/01/01/zlib-engine/</text:span></text:p>
+
+<text:p><text:span text:style-name="T12">REPORTING PROBLEMS </text:span><text:span text:style-name="T11">Before reporting a problem, please check the </text:span><text:span text:style-name="T13">zlib </text:span><text:span text:style-name="T11">web site to verify that you have the latest version of </text:span><text:span text:style-name="T13">zlib</text:span><text:span text:style-name="T11">; otherwise, obtain the latest version and see if the problem still exists. Please read the </text:span><text:span text:style-name="T13">zlib </text:span><text:span text:style-name="T11">FAQ at:</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">http://zlib.net/zlib_faq.html</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">before asking for help. Send questions and/or comments to zlib@gzip.org, or (for the Windows DLL version) to Gilles Vollant (info@winimage.com).</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">15 Jan 2017 1</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">ZLIB(3) ZLIB(3)</text:span></text:p>
+
+<text:p><text:span text:style-name="T12">AUTHORS AND LICENSE </text:span><text:span text:style-name="T11">Version 1.2.11</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">Copyright (C) 1995-2017 Jean-loup Gailly and Mark Adler</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">This software is provided &#x2019;as-is&#x2019;, without any express or implied warranty. In no event will the authors be held liable for any damages arising from the use of this software.</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">Permission is granted to anyone to use this software for any purpose, including commercial applications, and to alter it and redistribute it freely, subject to the following restrictions:</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">1. The origin of this software must not be misrepresented; you must not claim that you wrote the original software. If you use this software in a product, an acknowledgment in the product documentation would be appreciated but is not required.</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">2. Altered source versions must be plainly marked as such, and must not be misrepresented as being the original software.</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">3. This notice may not be removed or altered from any source distribution.</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">Jean-loup Gailly Mark Adler jloup@gzip.org madler@alumni.caltech.edu</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">The deflate format used by </text:span><text:span text:style-name="T13">zlib </text:span><text:span text:style-name="T11">was defined by Phil Katz. The deflate and </text:span><text:span text:style-name="T13">zlib </text:span><text:span text:style-name="T11">specifications were written by L. Peter Deutsch. Thanks to all the people who reported problems and suggested various improvements in </text:span><text:span text:style-name="T13">zlib</text:span><text:span text:style-name="T11">; who are too numerous to cite here.</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">UNIX manual page by R. P. C. Rodgers, U.S. National Library of Medicine (rodgers@nlm.nih.gov).</text:span></text:p>
+
+<text:p><text:span text:style-name="T11">15 Jan 2017 2</text:span></text:p></office:text></office:body></office:document-content> \ No newline at end of file
diff --git a/extract/test/zlib.3.pdf.mutool.odt.dir.ref/manifest.rdf b/extract/test/zlib.3.pdf.mutool.odt.dir.ref/manifest.rdf
new file mode 100644
index 00000000..927e206b
--- /dev/null
+++ b/extract/test/zlib.3.pdf.mutool.odt.dir.ref/manifest.rdf
@@ -0,0 +1,18 @@
+<?xml version="1.0" encoding="utf-8"?>
+<rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#">
+ <rdf:Description rdf:about="styles.xml">
+ <rdf:type rdf:resource="http://docs.oasis-open.org/ns/office/1.2/meta/odf#StylesFile"/>
+ </rdf:Description>
+ <rdf:Description rdf:about="">
+ <ns0:hasPart xmlns:ns0="http://docs.oasis-open.org/ns/office/1.2/meta/pkg#" rdf:resource="styles.xml"/>
+ </rdf:Description>
+ <rdf:Description rdf:about="content.xml">
+ <rdf:type rdf:resource="http://docs.oasis-open.org/ns/office/1.2/meta/odf#ContentFile"/>
+ </rdf:Description>
+ <rdf:Description rdf:about="">
+ <ns0:hasPart xmlns:ns0="http://docs.oasis-open.org/ns/office/1.2/meta/pkg#" rdf:resource="content.xml"/>
+ </rdf:Description>
+ <rdf:Description rdf:about="">
+ <rdf:type rdf:resource="http://docs.oasis-open.org/ns/office/1.2/meta/pkg#Document"/>
+ </rdf:Description>
+</rdf:RDF>
diff --git a/extract/test/zlib.3.pdf.mutool.odt.dir.ref/meta.xml b/extract/test/zlib.3.pdf.mutool.odt.dir.ref/meta.xml
new file mode 100644
index 00000000..6b42561e
--- /dev/null
+++ b/extract/test/zlib.3.pdf.mutool.odt.dir.ref/meta.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<office:document-meta xmlns:grddl="http://www.w3.org/2003/g/data-view#" xmlns:meta="urn:oasis:names:tc:opendocument:xmlns:meta:1.0" xmlns:ooo="http://openoffice.org/2004/office" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" office:version="1.3"><office:meta><meta:creation-date>2021-04-05T17:06:57.937137058</meta:creation-date><meta:generator>LibreOffice/7.0.1.2$OpenBSD_X86_64 LibreOffice_project/00$Build-2</meta:generator><dc:date>2021-04-06T17:14:51.409959656</dc:date><meta:editing-duration>PT20S</meta:editing-duration><meta:editing-cycles>1</meta:editing-cycles><meta:document-statistic meta:table-count="0" meta:image-count="0" meta:object-count="0" meta:page-count="1" meta:paragraph-count="0" meta:word-count="0" meta:character-count="0" meta:non-whitespace-character-count="0"/></office:meta></office:document-meta> \ No newline at end of file
diff --git a/extract/test/zlib.3.pdf.mutool.odt.dir.ref/mimetype b/extract/test/zlib.3.pdf.mutool.odt.dir.ref/mimetype
new file mode 100644
index 00000000..2e95b81c
--- /dev/null
+++ b/extract/test/zlib.3.pdf.mutool.odt.dir.ref/mimetype
@@ -0,0 +1 @@
+application/vnd.oasis.opendocument.text \ No newline at end of file
diff --git a/extract/test/zlib.3.pdf.mutool.odt.dir.ref/settings.xml b/extract/test/zlib.3.pdf.mutool.odt.dir.ref/settings.xml
new file mode 100644
index 00000000..35a8138f
--- /dev/null
+++ b/extract/test/zlib.3.pdf.mutool.odt.dir.ref/settings.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<office:document-settings xmlns:config="urn:oasis:names:tc:opendocument:xmlns:config:1.0" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:ooo="http://openoffice.org/2004/office" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" office:version="1.3"><office:settings><config:config-item-set config:name="ooo:view-settings"><config:config-item config:name="ViewAreaTop" config:type="long">0</config:config-item><config:config-item config:name="ViewAreaLeft" config:type="long">0</config:config-item><config:config-item config:name="ViewAreaWidth" config:type="long">26275</config:config-item><config:config-item config:name="ViewAreaHeight" config:type="long">19502</config:config-item><config:config-item config:name="ShowRedlineChanges" config:type="boolean">true</config:config-item><config:config-item config:name="InBrowseMode" config:type="boolean">false</config:config-item><config:config-item-map-indexed config:name="Views"><config:config-item-map-entry><config:config-item config:name="ViewId" config:type="string">view2</config:config-item><config:config-item config:name="ViewLeft" config:type="long">4343</config:config-item><config:config-item config:name="ViewTop" config:type="long">2501</config:config-item><config:config-item config:name="VisibleLeft" config:type="long">0</config:config-item><config:config-item config:name="VisibleTop" config:type="long">0</config:config-item><config:config-item config:name="VisibleRight" config:type="long">26273</config:config-item><config:config-item config:name="VisibleBottom" config:type="long">19500</config:config-item><config:config-item config:name="ZoomType" config:type="short">0</config:config-item><config:config-item config:name="ViewLayoutColumns" config:type="short">1</config:config-item><config:config-item config:name="ViewLayoutBookMode" config:type="boolean">false</config:config-item><config:config-item config:name="ZoomFactor" config:type="short">100</config:config-item><config:config-item config:name="IsSelectedFrame" config:type="boolean">false</config:config-item><config:config-item config:name="AnchoredTextOverflowLegacy" config:type="boolean">false</config:config-item></config:config-item-map-entry></config:config-item-map-indexed></config:config-item-set><config:config-item-set config:name="ooo:configuration-settings"><config:config-item config:name="PrintBlackFonts" config:type="boolean">false</config:config-item><config:config-item config:name="PrintReversed" config:type="boolean">false</config:config-item><config:config-item config:name="SaveThumbnail" config:type="boolean">true</config:config-item><config:config-item config:name="EmbedFonts" config:type="boolean">false</config:config-item><config:config-item config:name="PrintControls" config:type="boolean">true</config:config-item><config:config-item config:name="OutlineLevelYieldsNumbering" config:type="boolean">false</config:config-item><config:config-item config:name="PrintPageBackground" config:type="boolean">true</config:config-item><config:config-item config:name="PrintAnnotationMode" config:type="short">0</config:config-item><config:config-item config:name="PrintGraphics" config:type="boolean">true</config:config-item><config:config-item config:name="EmbeddedDatabaseName" config:type="string"/><config:config-item config:name="ProtectForm" config:type="boolean">false</config:config-item><config:config-item config:name="PrintLeftPages" config:type="boolean">true</config:config-item><config:config-item config:name="PrintProspect" config:type="boolean">false</config:config-item><config:config-item config:name="PrintHiddenText" config:type="boolean">false</config:config-item><config:config-item config:name="PrintRightPages" config:type="boolean">true</config:config-item><config:config-item config:name="PrintFaxName" config:type="string"/><config:config-item config:name="PrintPaperFromSetup" config:type="boolean">false</config:config-item><config:config-item config:name="TabsRelativeToIndent" config:type="boolean">true</config:config-item><config:config-item config:name="RedlineProtectionKey" config:type="base64Binary"/><config:config-item config:name="PrintTextPlaceholder" config:type="boolean">false</config:config-item><config:config-item config:name="MathBaselineAlignment" config:type="boolean">true</config:config-item><config:config-item config:name="ProtectBookmarks" config:type="boolean">false</config:config-item><config:config-item config:name="IgnoreTabsAndBlanksForLineCalculation" config:type="boolean">false</config:config-item><config:config-item config:name="ContinuousEndnotes" config:type="boolean">false</config:config-item><config:config-item config:name="FieldAutoUpdate" config:type="boolean">true</config:config-item><config:config-item config:name="EmptyDbFieldHidesPara" config:type="boolean">true</config:config-item><config:config-item config:name="ApplyParagraphMarkFormatToNumbering" config:type="boolean">false</config:config-item><config:config-item config:name="PrintEmptyPages" config:type="boolean">true</config:config-item><config:config-item config:name="TabOverMargin" config:type="boolean">false</config:config-item><config:config-item config:name="EmbedAsianScriptFonts" config:type="boolean">true</config:config-item><config:config-item config:name="EmbedLatinScriptFonts" config:type="boolean">true</config:config-item><config:config-item config:name="DisableOffPagePositioning" config:type="boolean">false</config:config-item><config:config-item config:name="EmbedOnlyUsedFonts" config:type="boolean">false</config:config-item><config:config-item config:name="MsWordCompMinLineHeightByFly" config:type="boolean">false</config:config-item><config:config-item config:name="SurroundTextWrapSmall" config:type="boolean">false</config:config-item><config:config-item config:name="BackgroundParaOverDrawings" config:type="boolean">false</config:config-item><config:config-item config:name="ClippedPictures" config:type="boolean">false</config:config-item><config:config-item config:name="FloattableNomargins" config:type="boolean">false</config:config-item><config:config-item config:name="UnbreakableNumberings" config:type="boolean">false</config:config-item><config:config-item config:name="EmbedSystemFonts" config:type="boolean">false</config:config-item><config:config-item config:name="TabOverflow" config:type="boolean">true</config:config-item><config:config-item config:name="PrintTables" config:type="boolean">true</config:config-item><config:config-item config:name="PrintDrawings" config:type="boolean">true</config:config-item><config:config-item config:name="ConsiderTextWrapOnObjPos" config:type="boolean">false</config:config-item><config:config-item config:name="PrintSingleJobs" config:type="boolean">false</config:config-item><config:config-item config:name="SmallCapsPercentage66" config:type="boolean">false</config:config-item><config:config-item config:name="CollapseEmptyCellPara" config:type="boolean">true</config:config-item><config:config-item config:name="HeaderSpacingBelowLastPara" config:type="boolean">false</config:config-item><config:config-item config:name="RsidRoot" config:type="int">2052946</config:config-item><config:config-item config:name="PrinterSetup" config:type="base64Binary"/><config:config-item config:name="CurrentDatabaseCommand" config:type="string"/><config:config-item config:name="AlignTabStopPosition" config:type="boolean">true</config:config-item><config:config-item config:name="ClipAsCharacterAnchoredWriterFlyFrames" config:type="boolean">false</config:config-item><config:config-item config:name="DoNotCaptureDrawObjsOnPage" config:type="boolean">false</config:config-item><config:config-item config:name="SaveGlobalDocumentLinks" config:type="boolean">false</config:config-item><config:config-item config:name="CurrentDatabaseCommandType" config:type="int">0</config:config-item><config:config-item config:name="LoadReadonly" config:type="boolean">false</config:config-item><config:config-item config:name="DoNotResetParaAttrsForNumFont" config:type="boolean">false</config:config-item><config:config-item config:name="StylesNoDefault" config:type="boolean">false</config:config-item><config:config-item config:name="LinkUpdateMode" config:type="short">1</config:config-item><config:config-item config:name="DoNotJustifyLinesWithManualBreak" config:type="boolean">false</config:config-item><config:config-item config:name="PropLineSpacingShrinksFirstLine" config:type="boolean">true</config:config-item><config:config-item config:name="TabAtLeftIndentForParagraphsInList" config:type="boolean">false</config:config-item><config:config-item config:name="ProtectFields" config:type="boolean">false</config:config-item><config:config-item config:name="UnxForceZeroExtLeading" config:type="boolean">false</config:config-item><config:config-item config:name="CurrentDatabaseDataSource" config:type="string"/><config:config-item config:name="UseFormerTextWrapping" config:type="boolean">false</config:config-item><config:config-item config:name="UseFormerLineSpacing" config:type="boolean">false</config:config-item><config:config-item config:name="AllowPrintJobCancel" config:type="boolean">true</config:config-item><config:config-item config:name="SubtractFlysAnchoredAtFlys" config:type="boolean">false</config:config-item><config:config-item config:name="AddParaSpacingToTableCells" config:type="boolean">true</config:config-item><config:config-item config:name="AddExternalLeading" config:type="boolean">true</config:config-item><config:config-item config:name="Rsid" config:type="int">2178852</config:config-item><config:config-item config:name="AddVerticalFrameOffsets" config:type="boolean">false</config:config-item><config:config-item config:name="TreatSingleColumnBreakAsPageBreak" config:type="boolean">false</config:config-item><config:config-item config:name="AddFrameOffsets" config:type="boolean">false</config:config-item><config:config-item config:name="IsLabelDocument" config:type="boolean">false</config:config-item><config:config-item config:name="MsWordCompTrailingBlanks" config:type="boolean">false</config:config-item><config:config-item config:name="PrinterPaperFromSetup" config:type="boolean">false</config:config-item><config:config-item config:name="IgnoreFirstLineIndentInNumbering" config:type="boolean">false</config:config-item><config:config-item config:name="PrinterName" config:type="string"/><config:config-item config:name="IsKernAsianPunctuation" config:type="boolean">false</config:config-item><config:config-item config:name="PrinterIndependentLayout" config:type="string">high-resolution</config:config-item><config:config-item config:name="TableRowKeep" config:type="boolean">false</config:config-item><config:config-item config:name="UpdateFromTemplate" config:type="boolean">true</config:config-item><config:config-item config:name="EmbedComplexScriptFonts" config:type="boolean">true</config:config-item><config:config-item config:name="UseOldPrinterMetrics" config:type="boolean">false</config:config-item><config:config-item config:name="InvertBorderSpacing" config:type="boolean">false</config:config-item><config:config-item config:name="PrintProspectRTL" config:type="boolean">false</config:config-item><config:config-item config:name="ApplyUserData" config:type="boolean">true</config:config-item><config:config-item config:name="AddParaTableSpacingAtStart" config:type="boolean">true</config:config-item><config:config-item config:name="SaveVersionOnClose" config:type="boolean">false</config:config-item><config:config-item config:name="CharacterCompressionType" config:type="short">0</config:config-item><config:config-item config:name="UseOldNumbering" config:type="boolean">false</config:config-item><config:config-item config:name="UseFormerObjectPositioning" config:type="boolean">false</config:config-item><config:config-item config:name="ChartAutoUpdate" config:type="boolean">true</config:config-item><config:config-item config:name="AddParaTableSpacing" config:type="boolean">true</config:config-item></config:config-item-set></office:settings></office:document-settings> \ No newline at end of file
diff --git a/extract/test/zlib.3.pdf.mutool.odt.dir.ref/styles.xml b/extract/test/zlib.3.pdf.mutool.odt.dir.ref/styles.xml
new file mode 100644
index 00000000..91403c4e
--- /dev/null
+++ b/extract/test/zlib.3.pdf.mutool.odt.dir.ref/styles.xml
@@ -0,0 +1,2 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<office:document-styles xmlns:css3t="http://www.w3.org/TR/css3-text/" xmlns:grddl="http://www.w3.org/2003/g/data-view#" xmlns:xhtml="http://www.w3.org/1999/xhtml" xmlns:dom="http://www.w3.org/2001/xml-events" xmlns:script="urn:oasis:names:tc:opendocument:xmlns:script:1.0" xmlns:form="urn:oasis:names:tc:opendocument:xmlns:form:1.0" xmlns:math="http://www.w3.org/1998/Math/MathML" xmlns:number="urn:oasis:names:tc:opendocument:xmlns:datastyle:1.0" xmlns:field="urn:openoffice:names:experimental:ooo-ms-interop:xmlns:field:1.0" xmlns:meta="urn:oasis:names:tc:opendocument:xmlns:meta:1.0" xmlns:loext="urn:org:documentfoundation:names:experimental:office:xmlns:loext:1.0" xmlns:officeooo="http://openoffice.org/2009/office" xmlns:table="urn:oasis:names:tc:opendocument:xmlns:table:1.0" xmlns:chart="urn:oasis:names:tc:opendocument:xmlns:chart:1.0" xmlns:tableooo="http://openoffice.org/2009/table" xmlns:draw="urn:oasis:names:tc:opendocument:xmlns:drawing:1.0" xmlns:rpt="http://openoffice.org/2005/report" xmlns:dr3d="urn:oasis:names:tc:opendocument:xmlns:dr3d:1.0" xmlns:of="urn:oasis:names:tc:opendocument:xmlns:of:1.2" xmlns:text="urn:oasis:names:tc:opendocument:xmlns:text:1.0" xmlns:style="urn:oasis:names:tc:opendocument:xmlns:style:1.0" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:calcext="urn:org:documentfoundation:names:experimental:calc:xmlns:calcext:1.0" xmlns:oooc="http://openoffice.org/2004/calc" xmlns:drawooo="http://openoffice.org/2010/draw" xmlns:xlink="http://www.w3.org/1999/xlink" xmlns:ooo="http://openoffice.org/2004/office" xmlns:ooow="http://openoffice.org/2004/writer" xmlns:fo="urn:oasis:names:tc:opendocument:xmlns:xsl-fo-compatible:1.0" xmlns:svg="urn:oasis:names:tc:opendocument:xmlns:svg-compatible:1.0" xmlns:office="urn:oasis:names:tc:opendocument:xmlns:office:1.0" office:version="1.3"><office:font-face-decls><style:font-face style:name="Liberation Serif" svg:font-family="&apos;Liberation Serif&apos;" style:font-family-generic="roman" style:font-pitch="variable"/><style:font-face style:name="Liberation Sans" svg:font-family="&apos;Liberation Sans&apos;" style:font-family-generic="swiss" style:font-pitch="variable"/><style:font-face style:name="Unifont" svg:font-family="Unifont" style:font-family-generic="system" style:font-pitch="variable"/></office:font-face-decls><office:styles><style:default-style style:family="graphic"><style:graphic-properties svg:stroke-color="#3465a4" draw:fill-color="#729fcf" fo:wrap-option="no-wrap" draw:shadow-offset-x="0.1181in" draw:shadow-offset-y="0.1181in" draw:start-line-spacing-horizontal="0.1114in" draw:start-line-spacing-vertical="0.1114in" draw:end-line-spacing-horizontal="0.1114in" draw:end-line-spacing-vertical="0.1114in" style:flow-with-text="false"/><style:paragraph-properties style:text-autospace="ideograph-alpha" style:line-break="strict" style:font-independent-line-spacing="false"><style:tab-stops/></style:paragraph-properties><style:text-properties style:use-window-font-color="true" loext:opacity="0%" style:font-name="Liberation Serif" fo:font-size="12pt" fo:language="en" fo:country="US" style:letter-kerning="true" style:font-name-asian="Unifont" style:font-size-asian="10.5pt" style:language-asian="zh" style:country-asian="CN" style:font-name-complex="Unifont" style:font-size-complex="12pt" style:language-complex="hi" style:country-complex="IN"/></style:default-style><style:default-style style:family="paragraph"><style:paragraph-properties fo:orphans="2" fo:widows="2" fo:hyphenation-ladder-count="no-limit" style:text-autospace="ideograph-alpha" style:punctuation-wrap="hanging" style:line-break="strict" style:tab-stop-distance="0.4925in" style:writing-mode="page"/><style:text-properties style:use-window-font-color="true" loext:opacity="0%" style:font-name="Liberation Serif" fo:font-size="12pt" fo:language="en" fo:country="US" style:letter-kerning="true" style:font-name-asian="Unifont" style:font-size-asian="10.5pt" style:language-asian="zh" style:country-asian="CN" style:font-name-complex="Unifont" style:font-size-complex="12pt" style:language-complex="hi" style:country-complex="IN" fo:hyphenate="false" fo:hyphenation-remain-char-count="2" fo:hyphenation-push-char-count="2" loext:hyphenation-no-caps="false"/></style:default-style><style:default-style style:family="table"><style:table-properties table:border-model="collapsing"/></style:default-style><style:default-style style:family="table-row"><style:table-row-properties fo:keep-together="auto"/></style:default-style><style:style style:name="Standard" style:family="paragraph" style:class="text"><style:paragraph-properties fo:margin-top="0in" fo:margin-bottom="0.0799in" style:contextual-spacing="false"/></style:style><style:style style:name="Heading" style:family="paragraph" style:parent-style-name="Standard" style:next-style-name="Text_20_body" style:class="text"><style:paragraph-properties fo:margin-top="0.1665in" fo:margin-bottom="0.0835in" style:contextual-spacing="false" fo:keep-with-next="always"/><style:text-properties style:font-name="Liberation Sans" fo:font-family="&apos;Liberation Sans&apos;" style:font-family-generic="swiss" style:font-pitch="variable" fo:font-size="14pt" style:font-name-asian="Unifont" style:font-family-asian="Unifont" style:font-family-generic-asian="system" style:font-pitch-asian="variable" style:font-size-asian="14pt" style:font-name-complex="Unifont" style:font-family-complex="Unifont" style:font-family-generic-complex="system" style:font-pitch-complex="variable" style:font-size-complex="14pt"/></style:style><style:style style:name="Text_20_body" style:display-name="Text body" style:family="paragraph" style:parent-style-name="Standard" style:class="text"><style:paragraph-properties fo:margin-top="0in" fo:margin-bottom="0.0972in" style:contextual-spacing="false" fo:line-height="115%"/></style:style><style:style style:name="List" style:family="paragraph" style:parent-style-name="Text_20_body" style:class="list"><style:text-properties style:font-size-asian="12pt"/></style:style><style:style style:name="Caption" style:family="paragraph" style:parent-style-name="Standard" style:class="extra"><style:paragraph-properties fo:margin-top="0.0835in" fo:margin-bottom="0.0835in" style:contextual-spacing="false" text:number-lines="false" text:line-number="0"/><style:text-properties fo:font-size="12pt" fo:font-style="italic" style:font-size-asian="12pt" style:font-style-asian="italic" style:font-size-complex="12pt" style:font-style-complex="italic"/></style:style><style:style style:name="Index" style:family="paragraph" style:parent-style-name="Standard" style:class="index"><style:paragraph-properties text:number-lines="false" text:line-number="0"/><style:text-properties style:font-size-asian="12pt"/></style:style><text:outline-style style:name="Outline"><text:outline-level-style text:level="1" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="2" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="3" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="4" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="5" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="6" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="7" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="8" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="9" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style><text:outline-level-style text:level="10" style:num-format=""><style:list-level-properties text:list-level-position-and-space-mode="label-alignment"><style:list-level-label-alignment text:label-followed-by="listtab"/></style:list-level-properties></text:outline-level-style></text:outline-style><text:notes-configuration text:note-class="footnote" style:num-format="1" text:start-value="0" text:footnotes-position="page" text:start-numbering-at="document"/><text:notes-configuration text:note-class="endnote" style:num-format="i" text:start-value="0"/><text:linenumbering-configuration text:number-lines="false" text:offset="0.1965in" style:num-format="1" text:number-position="left" text:increment="5"/></office:styles><office:automatic-styles><style:page-layout style:name="Mpm1"><style:page-layout-properties fo:page-width="8.5in" fo:page-height="11in" style:num-format="1" style:print-orientation="portrait" fo:margin-top="0.7874in" fo:margin-bottom="0.7874in" fo:margin-left="0.7874in" fo:margin-right="0.7874in" style:writing-mode="lr-tb" style:layout-grid-color="#c0c0c0" style:layout-grid-lines="20" style:layout-grid-base-height="0.278in" style:layout-grid-ruby-height="0.139in" style:layout-grid-mode="none" style:layout-grid-ruby-below="false" style:layout-grid-print="false" style:layout-grid-display="false" style:footnote-max-height="0in"><style:footnote-sep style:width="0.0071in" style:distance-before-sep="0.0398in" style:distance-after-sep="0.0398in" style:line-style="solid" style:adjustment="left" style:rel-width="25%" style:color="#000000"/></style:page-layout-properties><style:header-style/><style:footer-style/></style:page-layout></office:automatic-styles><office:master-styles><style:master-page style:name="Standard" style:page-layout-name="Mpm1"/></office:master-styles></office:document-styles> \ No newline at end of file
diff --git a/jbig2dec/README b/jbig2dec/README
index 7a0e53d2..1a739c69 100644
--- a/jbig2dec/README
+++ b/jbig2dec/README
@@ -28,5 +28,5 @@ Report bugs at https://bugs.ghostscript.com
For security issues please use the "Security - Other" product,
and for normal bugs the "jbig2dec" product.
-Contact the developers at the IRC channel #ghostscript at freenode.net
+Contact the developers on Discord or IRC at #ghostscript at libera.chat
or via the mailing list <gs-devel@ghostscript.com>.
diff --git a/jbig2dec/config_win32.h b/jbig2dec/config_win32.h
index dc807c9a..53d4e918 100644
--- a/jbig2dec/config_win32.h
+++ b/jbig2dec/config_win32.h
@@ -44,7 +44,7 @@ typedef unsigned __int64 uint64_t;
/* Previously we defined inline as nothing for 2005 and below */
# define inline
#else
-/* VS 2008 has __inline but not inline, later versiosn (unknown exactly where) define inline
+/* VS 2008 has __inline but not inline, later versions (unknown exactly where) define inline
* so cater for it being defined already.
*/
# if !(defined(inline))
diff --git a/jbig2dec/configure.ac.in b/jbig2dec/configure.ac.in
index 95dbf639..cf3022f7 100644
--- a/jbig2dec/configure.ac.in
+++ b/jbig2dec/configure.ac.in
@@ -4,6 +4,7 @@ AC_INIT([jbig2dec], [unknown-version], [gs-devel@ghostscript.com])
AC_PREREQ(2.53)
AC_CONFIG_SRCDIR([jbig2dec.c])
+AM_SILENT_RULES([yes])
AM_INIT_AUTOMAKE([-Wall])
AM_CONFIG_HEADER(config.h)
diff --git a/jbig2dec/jbig2.h b/jbig2dec/jbig2.h
index c83517e7..49fb1f02 100644
--- a/jbig2dec/jbig2.h
+++ b/jbig2dec/jbig2.h
@@ -105,11 +105,6 @@ void jbig2_release_page(Jbig2Ctx *ctx, Jbig2Image *image);
/* mark the current page as complete, simulating an end-of-page segment (for broken streams) */
int jbig2_complete_page(Jbig2Ctx *ctx);
-/* If we don't have a definition for inline, make it nothing so the code will compile */
-#ifndef inline
-#define inline
-#endif
-
#ifdef __cplusplus
}
#endif
diff --git a/jbig2dec/jbig2_priv.h b/jbig2dec/jbig2_priv.h
index ac341cdc..ed366af5 100644
--- a/jbig2dec/jbig2_priv.h
+++ b/jbig2dec/jbig2_priv.h
@@ -35,6 +35,11 @@
/* library internals */
+/* If we don't have a definition for inline, make it nothing so the code will compile */
+#ifndef inline
+#define inline
+#endif
+
typedef uint8_t byte;
#define bool int
diff --git a/jbig2dec/jbig2dec.1 b/jbig2dec/jbig2dec.1
index 70607eb8..b3a8e4be 100644
--- a/jbig2dec/jbig2dec.1
+++ b/jbig2dec/jbig2dec.1
@@ -69,7 +69,7 @@ Show usage summary.
.SH REPORTING BUGS
Report bugs at https://bugs.ghostscript.com
-Contact the developers at the IRC channel #ghostscript at freenode.net
+Contact the developers on Dicord and IRC on #ghostscript at libera.chat
or via the mailing list <gs-devel@ghostscript.com>.
.SH AUTHOR
diff --git a/jbig2dec/jbig2dec.c b/jbig2dec/jbig2dec.c
index 1a45e71d..dc1fd560 100644
--- a/jbig2dec/jbig2dec.c
+++ b/jbig2dec/jbig2dec.c
@@ -91,6 +91,47 @@ static int print_usage(void);
#define KBYTE 1024
#define MBYTE (1024 * KBYTE)
+static void *jbig2dec_reached_limit(jbig2dec_allocator_t *allocator, size_t oldsize, size_t size)
+{
+ size_t limit_mb = allocator->memory_limit / MBYTE;
+ size_t used_mb = allocator->memory_used / MBYTE;
+ size_t oldsize_mb = oldsize / MBYTE;
+ size_t size_mb = size / MBYTE;
+
+ if (oldsize == 0)
+ jbig2_error(allocator->ctx, JBIG2_SEVERITY_FATAL, -1, "memory: limit reached: limit: %zu (%zu Mbyte) used: %zu (%zu Mbyte) allocation: %zu (%zu Mbyte)",
+ allocator->memory_limit, limit_mb,
+ allocator->memory_used, used_mb,
+ size, size_mb);
+ else
+ jbig2_error(allocator->ctx, JBIG2_SEVERITY_FATAL, -1, "memory: limit reached: limit: %zu (%zu Mbyte) used: %zu (%zu Mbyte) reallocation: %zu (%zu Mbyte) -> %zu (%zu Mbyte)",
+ allocator->memory_limit, limit_mb,
+ allocator->memory_used, used_mb,
+ oldsize, oldsize_mb,
+ size, size_mb);
+
+ return NULL;
+}
+
+static void jbig2dec_peak(jbig2dec_allocator_t *allocator)
+{
+ size_t limit_mb = allocator->memory_limit / MBYTE;
+ size_t peak_mb = allocator->memory_peak / MBYTE;
+ size_t used_mb = allocator->memory_used / MBYTE;
+
+ if (allocator->ctx == NULL)
+ return;
+ if (used_mb <= peak_mb)
+ return;
+
+ allocator->memory_peak = allocator->memory_used;
+
+ jbig2_error(allocator->ctx, JBIG2_SEVERITY_DEBUG, JBIG2_UNKNOWN_SEGMENT_NUMBER, "memory: limit: %lu %sbyte used: %lu %sbyte, peak: %lu %sbyte",
+ limit_mb > 0 ? limit_mb : allocator->memory_limit, limit_mb > 0 ? "M" : "",
+ used_mb > 0 ? used_mb : allocator->memory_used, used_mb > 0 ? "M" : "",
+ peak_mb > 0 ? peak_mb : allocator->memory_peak, peak_mb > 0 ? "M" : "");
+}
+
static void *jbig2dec_alloc(Jbig2Allocator *allocator_, size_t size)
{
jbig2dec_allocator_t *allocator = (jbig2dec_allocator_t *) allocator_;
@@ -98,24 +139,19 @@ static void *jbig2dec_alloc(Jbig2Allocator *allocator_, size_t size)
if (size == 0)
return NULL;
- if (size > allocator->memory_limit - ALIGNMENT - allocator->memory_used)
+ if (size > SIZE_MAX - ALIGNMENT)
return NULL;
+ if (size + ALIGNMENT > allocator->memory_limit - allocator->memory_used)
+ return jbig2dec_reached_limit(allocator, 0, size + ALIGNMENT);
+
ptr = malloc(size + ALIGNMENT);
if (ptr == NULL)
return NULL;
memcpy(ptr, &size, sizeof(size));
allocator->memory_used += size + ALIGNMENT;
- if (allocator->memory_used > allocator->memory_peak) {
- allocator->memory_peak = allocator->memory_used;
-
- if (allocator->ctx) {
- size_t limit_mb = allocator->memory_limit / MBYTE;
- size_t peak_mb = allocator->memory_peak / MBYTE;
- jbig2_error(allocator->ctx, JBIG2_SEVERITY_DEBUG, JBIG2_UNKNOWN_SEGMENT_NUMBER, "memory: limit: %lu Mbyte peak usage: %lu Mbyte", limit_mb, peak_mb);
- }
- }
+ jbig2dec_peak(allocator);
return (unsigned char *) ptr + ALIGNMENT;
}
@@ -136,54 +172,36 @@ static void jbig2dec_free(Jbig2Allocator *allocator_, void *p)
static void *jbig2dec_realloc(Jbig2Allocator *allocator_, void *p, size_t size)
{
jbig2dec_allocator_t *allocator = (jbig2dec_allocator_t *) allocator_;
- unsigned char *oldp = p ? (unsigned char *) p - ALIGNMENT : NULL;
+ unsigned char *oldp;
+ size_t oldsize;
- if (size > SIZE_MAX - ALIGNMENT)
+ if (p == NULL)
+ return jbig2dec_alloc(allocator_, size);
+ if (p < (void *) ALIGNMENT)
return NULL;
- if (oldp == NULL)
- {
- if (size == 0)
- return NULL;
- if (size > allocator->memory_limit - ALIGNMENT - allocator->memory_used)
- return NULL;
-
- p = malloc(size + ALIGNMENT);
+ if (size == 0) {
+ jbig2dec_free(allocator_, p);
+ return NULL;
}
- else
- {
- size_t oldsize;
- memcpy(&oldsize, oldp, sizeof(oldsize));
-
- if (size == 0)
- {
- allocator->memory_used -= oldsize + ALIGNMENT;
- free(oldp);
- return NULL;
- }
+ if (size > SIZE_MAX - ALIGNMENT)
+ return NULL;
- if (size > allocator->memory_limit - allocator->memory_used + oldsize)
- return NULL;
+ oldp = (unsigned char *) p - ALIGNMENT;
+ memcpy(&oldsize, oldp, sizeof(oldsize));
- p = realloc(oldp, size + ALIGNMENT);
- if (p == NULL)
- return NULL;
+ if (size + ALIGNMENT > allocator->memory_limit - allocator->memory_used + oldsize + ALIGNMENT)
+ return jbig2dec_reached_limit(allocator, oldsize + ALIGNMENT, size + ALIGNMENT);
- allocator->memory_used -= oldsize + ALIGNMENT;
- }
+ p = realloc(oldp, size + ALIGNMENT);
+ if (p == NULL)
+ return NULL;
+ allocator->memory_used -= oldsize + ALIGNMENT;
memcpy(p, &size, sizeof(size));
allocator->memory_used += size + ALIGNMENT;
- if (allocator->memory_used > allocator->memory_peak) {
- allocator->memory_peak = allocator->memory_used;
-
- if (allocator->ctx) {
- size_t limit_mb = allocator->memory_limit / MBYTE;
- size_t peak_mb = allocator->memory_peak / MBYTE;
- jbig2_error(allocator->ctx, JBIG2_SEVERITY_DEBUG, JBIG2_UNKNOWN_SEGMENT_NUMBER, "memory: limit: %lu Mbyte peak usage: %lu Mbyte", limit_mb, peak_mb);
- }
- }
+ jbig2dec_peak(allocator);
return (unsigned char *) p + ALIGNMENT;
}
diff --git a/jpeg/Makefile.am b/jpeg/Makefile.am
index be582603..c477a445 100644
--- a/jpeg/Makefile.am
+++ b/jpeg/Makefile.am
@@ -39,9 +39,9 @@ MKFILES= configure Makefile.in makefile.ansi makefile.unix makefile.b32 \
makejmak.vc6 makecdep.vc6 makecdsp.vc6 makecmak.vc6 makeddep.vc6 \
makeddsp.vc6 makedmak.vc6 maketdep.vc6 maketdsp.vc6 maketmak.vc6 \
makerdep.vc6 makerdsp.vc6 makermak.vc6 makewdep.vc6 makewdsp.vc6 \
- makewmak.vc6 makejsln.v15 makeasln.v15 makejvcx.v15 makejfil.v15 \
- makecvcx.v15 makecfil.v15 makedvcx.v15 makedfil.v15 maketvcx.v15 \
- maketfil.v15 makervcx.v15 makerfil.v15 makewvcx.v15 makewfil.v15 \
+ makewmak.vc6 makejsln.v16 makeasln.v16 makejvcx.v16 makejfil.v16 \
+ makecvcx.v16 makecfil.v16 makedvcx.v16 makedfil.v16 maketvcx.v16 \
+ maketfil.v16 makervcx.v16 makerfil.v16 makewvcx.v16 makewfil.v16 \
makeproj.mac makcjpeg.st makdjpeg.st makljpeg.st maktjpeg.st \
makefile.manx makefile.sas makefile.mms makefile.vms makvms.opt
@@ -58,8 +58,8 @@ CONFIGUREFILES= config.guess config.sub install-sh ltmain.sh depcomp \
OTHERFILES= jconfig.txt ckconfig.c jmemdosa.asm libjpeg.map libjpeg.pc.in
# Test support files
-TESTFILES= testorig.jpg testimg.ppm testimg.bmp testimg.jpg testprog.jpg \
- testimgp.jpg
+TESTFILES= testorig.jpg testimg.ppm testimg.gif testimg.bmp testimg.jpg \
+ testprog.jpg testimgp.jpg
# libtool libraries to build
lib_LTLIBRARIES = libjpeg.la
@@ -108,8 +108,8 @@ pkgconfigdir = $(libdir)/pkgconfig
nodist_pkgconfig_DATA = libjpeg.pc
# Files to be cleaned
-CLEANFILES = testout.ppm testout.bmp testout.jpg testoutp.ppm testoutp.jpg \
- testoutt.jpg
+CLEANFILES = testout.ppm testout.gif testout.bmp testout.jpg testoutp.ppm \
+ testoutp.jpg testoutt.jpg
# Install jconfig.h
install-data-local:
@@ -124,13 +124,15 @@ uninstall-local:
test: check-local
check-local:
rm -f testout*
- ./djpeg -dct int -ppm -outfile testout.ppm $(srcdir)/testorig.jpg
- ./djpeg -dct int -bmp -colors 256 -outfile testout.bmp $(srcdir)/testorig.jpg
- ./cjpeg -dct int -outfile testout.jpg $(srcdir)/testimg.ppm
+ ./djpeg -dct int -ppm -outfile testout.ppm $(srcdir)/testorig.jpg
+ ./djpeg -dct int -gif -outfile testout.gif $(srcdir)/testorig.jpg
+ ./djpeg -dct int -bmp -colors 256 -outfile testout.bmp $(srcdir)/testorig.jpg
+ ./cjpeg -dct int -outfile testout.jpg $(srcdir)/testimg.ppm
./djpeg -dct int -ppm -outfile testoutp.ppm $(srcdir)/testprog.jpg
./cjpeg -dct int -progressive -opt -outfile testoutp.jpg $(srcdir)/testimg.ppm
./jpegtran -outfile testoutt.jpg $(srcdir)/testprog.jpg
cmp $(srcdir)/testimg.ppm testout.ppm
+ cmp $(srcdir)/testimg.gif testout.gif
cmp $(srcdir)/testimg.bmp testout.bmp
cmp $(srcdir)/testimg.jpg testout.jpg
cmp $(srcdir)/testimg.ppm testoutp.ppm
diff --git a/jpeg/Makefile.in b/jpeg/Makefile.in
index fef89e0b..79efda66 100644
--- a/jpeg/Makefile.in
+++ b/jpeg/Makefile.in
@@ -1,7 +1,7 @@
-# Makefile.in generated by automake 1.15.1 from Makefile.am.
+# Makefile.in generated by automake 1.16.1 from Makefile.am.
# @configure_input@
-# Copyright (C) 1994-2017 Free Software Foundation, Inc.
+# Copyright (C) 1994-2018 Free Software Foundation, Inc.
# This Makefile.in is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -114,6 +114,10 @@ mkinstalldirs = $(install_sh) -d
CONFIG_HEADER = jconfig.h
CONFIG_CLEAN_FILES = libjpeg.pc
CONFIG_CLEAN_VPATH_FILES =
+am__installdirs = "$(DESTDIR)$(bindir)" "$(DESTDIR)$(libdir)" \
+ "$(DESTDIR)$(man1dir)" "$(DESTDIR)$(pkgconfigdir)" \
+ "$(DESTDIR)$(includedir)"
+PROGRAMS = $(bin_PROGRAMS)
am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
am__vpath_adj = case $$p in \
$(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \
@@ -141,9 +145,6 @@ am__uninstall_files_from_dir = { \
|| { echo " ( cd '$$dir' && rm -f" $$files ")"; \
$(am__cd) "$$dir" && rm -f $$files; }; \
}
-am__installdirs = "$(DESTDIR)$(libdir)" "$(DESTDIR)$(bindir)" \
- "$(DESTDIR)$(man1dir)" "$(DESTDIR)$(pkgconfigdir)" \
- "$(DESTDIR)$(includedir)"
LTLIBRARIES = $(lib_LTLIBRARIES)
libjpeg_la_LIBADD =
am__objects_1 = jaricom.lo jcapimin.lo jcapistd.lo jcarith.lo \
@@ -165,7 +166,6 @@ am__v_lt_1 =
libjpeg_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
$(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
$(libjpeg_la_LDFLAGS) $(LDFLAGS) -o $@
-PROGRAMS = $(bin_PROGRAMS)
am_cjpeg_OBJECTS = cjpeg.$(OBJEXT) rdppm.$(OBJEXT) rdgif.$(OBJEXT) \
rdtarga.$(OBJEXT) rdrle.$(OBJEXT) rdbmp.$(OBJEXT) \
rdswitch.$(OBJEXT) cdjpeg.$(OBJEXT)
@@ -200,7 +200,40 @@ am__v_at_0 = @
am__v_at_1 =
DEFAULT_INCLUDES = -I.@am__isrc@
depcomp = $(SHELL) $(top_srcdir)/depcomp
-am__depfiles_maybe = depfiles
+am__maybe_remake_depfiles = depfiles
+am__depfiles_remade = ./$(DEPDIR)/@MEMORYMGR@.Plo \
+ ./$(DEPDIR)/cdjpeg.Po ./$(DEPDIR)/cjpeg.Po \
+ ./$(DEPDIR)/djpeg.Po ./$(DEPDIR)/jaricom.Plo \
+ ./$(DEPDIR)/jcapimin.Plo ./$(DEPDIR)/jcapistd.Plo \
+ ./$(DEPDIR)/jcarith.Plo ./$(DEPDIR)/jccoefct.Plo \
+ ./$(DEPDIR)/jccolor.Plo ./$(DEPDIR)/jcdctmgr.Plo \
+ ./$(DEPDIR)/jchuff.Plo ./$(DEPDIR)/jcinit.Plo \
+ ./$(DEPDIR)/jcmainct.Plo ./$(DEPDIR)/jcmarker.Plo \
+ ./$(DEPDIR)/jcmaster.Plo ./$(DEPDIR)/jcomapi.Plo \
+ ./$(DEPDIR)/jcparam.Plo ./$(DEPDIR)/jcprepct.Plo \
+ ./$(DEPDIR)/jcsample.Plo ./$(DEPDIR)/jctrans.Plo \
+ ./$(DEPDIR)/jdapimin.Plo ./$(DEPDIR)/jdapistd.Plo \
+ ./$(DEPDIR)/jdarith.Plo ./$(DEPDIR)/jdatadst.Plo \
+ ./$(DEPDIR)/jdatasrc.Plo ./$(DEPDIR)/jdcoefct.Plo \
+ ./$(DEPDIR)/jdcolor.Plo ./$(DEPDIR)/jddctmgr.Plo \
+ ./$(DEPDIR)/jdhuff.Plo ./$(DEPDIR)/jdinput.Plo \
+ ./$(DEPDIR)/jdmainct.Plo ./$(DEPDIR)/jdmarker.Plo \
+ ./$(DEPDIR)/jdmaster.Plo ./$(DEPDIR)/jdmerge.Plo \
+ ./$(DEPDIR)/jdpostct.Plo ./$(DEPDIR)/jdsample.Plo \
+ ./$(DEPDIR)/jdtrans.Plo ./$(DEPDIR)/jerror.Plo \
+ ./$(DEPDIR)/jfdctflt.Plo ./$(DEPDIR)/jfdctfst.Plo \
+ ./$(DEPDIR)/jfdctint.Plo ./$(DEPDIR)/jidctflt.Plo \
+ ./$(DEPDIR)/jidctfst.Plo ./$(DEPDIR)/jidctint.Plo \
+ ./$(DEPDIR)/jmemmgr.Plo ./$(DEPDIR)/jpegtran.Po \
+ ./$(DEPDIR)/jquant1.Plo ./$(DEPDIR)/jquant2.Plo \
+ ./$(DEPDIR)/jutils.Plo ./$(DEPDIR)/rdbmp.Po \
+ ./$(DEPDIR)/rdcolmap.Po ./$(DEPDIR)/rdgif.Po \
+ ./$(DEPDIR)/rdjpgcom.Po ./$(DEPDIR)/rdppm.Po \
+ ./$(DEPDIR)/rdrle.Po ./$(DEPDIR)/rdswitch.Po \
+ ./$(DEPDIR)/rdtarga.Po ./$(DEPDIR)/transupp.Po \
+ ./$(DEPDIR)/wrbmp.Po ./$(DEPDIR)/wrgif.Po \
+ ./$(DEPDIR)/wrjpgcom.Po ./$(DEPDIR)/wrppm.Po \
+ ./$(DEPDIR)/wrrle.Po ./$(DEPDIR)/wrtarga.Po
am__mv = mv -f
COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
$(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
@@ -287,6 +320,8 @@ INSTALL_PROGRAM = @INSTALL_PROGRAM@
INSTALL_SCRIPT = @INSTALL_SCRIPT@
INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
JPEG_LIB_VERSION = @JPEG_LIB_VERSION@
+JPEG_LIB_VERSION_MAJOR = @JPEG_LIB_VERSION_MAJOR@
+JPEG_LIB_VERSION_MINOR = @JPEG_LIB_VERSION_MINOR@
LD = @LD@
LDFLAGS = @LDFLAGS@
LIBOBJS = @LIBOBJS@
@@ -415,9 +450,9 @@ MKFILES = configure Makefile.in makefile.ansi makefile.unix makefile.b32 \
makejmak.vc6 makecdep.vc6 makecdsp.vc6 makecmak.vc6 makeddep.vc6 \
makeddsp.vc6 makedmak.vc6 maketdep.vc6 maketdsp.vc6 maketmak.vc6 \
makerdep.vc6 makerdsp.vc6 makermak.vc6 makewdep.vc6 makewdsp.vc6 \
- makewmak.vc6 makejsln.v15 makeasln.v15 makejvcx.v15 makejfil.v15 \
- makecvcx.v15 makecfil.v15 makedvcx.v15 makedfil.v15 maketvcx.v15 \
- maketfil.v15 makervcx.v15 makerfil.v15 makewvcx.v15 makewfil.v15 \
+ makewmak.vc6 makejsln.v16 makeasln.v16 makejvcx.v16 makejfil.v16 \
+ makecvcx.v16 makecfil.v16 makedvcx.v16 makedfil.v16 maketvcx.v16 \
+ maketfil.v16 makervcx.v16 makerfil.v16 makewvcx.v16 makewfil.v16 \
makeproj.mac makcjpeg.st makdjpeg.st makljpeg.st maktjpeg.st \
makefile.manx makefile.sas makefile.mms makefile.vms makvms.opt
@@ -437,8 +472,8 @@ CONFIGUREFILES = config.guess config.sub install-sh ltmain.sh depcomp \
OTHERFILES = jconfig.txt ckconfig.c jmemdosa.asm libjpeg.map libjpeg.pc.in
# Test support files
-TESTFILES = testorig.jpg testimg.ppm testimg.bmp testimg.jpg testprog.jpg \
- testimgp.jpg
+TESTFILES = testorig.jpg testimg.ppm testimg.gif testimg.bmp testimg.jpg \
+ testprog.jpg testimgp.jpg
# libtool libraries to build
@@ -484,8 +519,8 @@ pkgconfigdir = $(libdir)/pkgconfig
nodist_pkgconfig_DATA = libjpeg.pc
# Files to be cleaned
-CLEANFILES = testout.ppm testout.bmp testout.jpg testoutp.ppm testoutp.jpg \
- testoutt.jpg
+CLEANFILES = testout.ppm testout.gif testout.bmp testout.jpg testoutp.ppm \
+ testoutp.jpg testoutt.jpg
all: jconfig.h
$(MAKE) $(AM_MAKEFLAGS) all-am
@@ -513,8 +548,8 @@ Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
echo ' $(SHELL) ./config.status'; \
$(SHELL) ./config.status;; \
*) \
- echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe)'; \
- cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__depfiles_maybe);; \
+ echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles)'; \
+ cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles);; \
esac;
$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
@@ -542,44 +577,6 @@ distclean-hdr:
-rm -f jconfig.h stamp-h1
libjpeg.pc: $(top_builddir)/config.status $(srcdir)/libjpeg.pc.in
cd $(top_builddir) && $(SHELL) ./config.status $@
-
-install-libLTLIBRARIES: $(lib_LTLIBRARIES)
- @$(NORMAL_INSTALL)
- @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \
- list2=; for p in $$list; do \
- if test -f $$p; then \
- list2="$$list2 $$p"; \
- else :; fi; \
- done; \
- test -z "$$list2" || { \
- echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \
- $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \
- echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \
- $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \
- }
-
-uninstall-libLTLIBRARIES:
- @$(NORMAL_UNINSTALL)
- @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \
- for p in $$list; do \
- $(am__strip_dir) \
- echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \
- $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \
- done
-
-clean-libLTLIBRARIES:
- -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES)
- @list='$(lib_LTLIBRARIES)'; \
- locs=`for p in $$list; do echo $$p; done | \
- sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \
- sort -u`; \
- test -z "$$locs" || { \
- echo rm -f $${locs}; \
- rm -f $${locs}; \
- }
-
-libjpeg.la: $(libjpeg_la_OBJECTS) $(libjpeg_la_DEPENDENCIES) $(EXTRA_libjpeg_la_DEPENDENCIES)
- $(AM_V_CCLD)$(libjpeg_la_LINK) -rpath $(libdir) $(libjpeg_la_OBJECTS) $(libjpeg_la_LIBADD) $(LIBS)
install-binPROGRAMS: $(bin_PROGRAMS)
@$(NORMAL_INSTALL)
@list='$(bin_PROGRAMS)'; test -n "$(bindir)" || list=; \
@@ -630,6 +627,44 @@ clean-binPROGRAMS:
echo " rm -f" $$list; \
rm -f $$list
+install-libLTLIBRARIES: $(lib_LTLIBRARIES)
+ @$(NORMAL_INSTALL)
+ @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \
+ list2=; for p in $$list; do \
+ if test -f $$p; then \
+ list2="$$list2 $$p"; \
+ else :; fi; \
+ done; \
+ test -z "$$list2" || { \
+ echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \
+ $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \
+ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \
+ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \
+ }
+
+uninstall-libLTLIBRARIES:
+ @$(NORMAL_UNINSTALL)
+ @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \
+ for p in $$list; do \
+ $(am__strip_dir) \
+ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \
+ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \
+ done
+
+clean-libLTLIBRARIES:
+ -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES)
+ @list='$(lib_LTLIBRARIES)'; \
+ locs=`for p in $$list; do echo $$p; done | \
+ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \
+ sort -u`; \
+ test -z "$$locs" || { \
+ echo rm -f $${locs}; \
+ rm -f $${locs}; \
+ }
+
+libjpeg.la: $(libjpeg_la_OBJECTS) $(libjpeg_la_DEPENDENCIES) $(EXTRA_libjpeg_la_DEPENDENCIES)
+ $(AM_V_CCLD)$(libjpeg_la_LINK) -rpath $(libdir) $(libjpeg_la_OBJECTS) $(libjpeg_la_LIBADD) $(LIBS)
+
cjpeg$(EXEEXT): $(cjpeg_OBJECTS) $(cjpeg_DEPENDENCIES) $(EXTRA_cjpeg_DEPENDENCIES)
@rm -f cjpeg$(EXEEXT)
$(AM_V_CCLD)$(LINK) $(cjpeg_OBJECTS) $(cjpeg_LDADD) $(LIBS)
@@ -656,71 +691,77 @@ mostlyclean-compile:
distclean-compile:
-rm -f *.tab.c
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/@MEMORYMGR@.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cdjpeg.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cjpeg.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/djpeg.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jaricom.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcapimin.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcapistd.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcarith.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jccoefct.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jccolor.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcdctmgr.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jchuff.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcinit.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcmainct.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcmarker.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcmaster.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcomapi.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcparam.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcprepct.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcsample.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jctrans.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdapimin.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdapistd.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdarith.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdatadst.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdatasrc.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdcoefct.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdcolor.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jddctmgr.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdhuff.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdinput.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdmainct.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdmarker.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdmaster.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdmerge.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdpostct.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdsample.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdtrans.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jerror.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jfdctflt.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jfdctfst.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jfdctint.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jidctflt.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jidctfst.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jidctint.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jmemmgr.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jpegtran.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jquant1.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jquant2.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jutils.Plo@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rdbmp.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rdcolmap.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rdgif.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rdjpgcom.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rdppm.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rdrle.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rdswitch.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rdtarga.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/transupp.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/wrbmp.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/wrgif.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/wrjpgcom.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/wrppm.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/wrrle.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/wrtarga.Po@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/@MEMORYMGR@.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cdjpeg.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/cjpeg.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/djpeg.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jaricom.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcapimin.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcapistd.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcarith.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jccoefct.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jccolor.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcdctmgr.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jchuff.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcinit.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcmainct.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcmarker.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcmaster.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcomapi.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcparam.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcprepct.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jcsample.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jctrans.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdapimin.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdapistd.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdarith.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdatadst.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdatasrc.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdcoefct.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdcolor.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jddctmgr.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdhuff.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdinput.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdmainct.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdmarker.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdmaster.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdmerge.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdpostct.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdsample.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jdtrans.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jerror.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jfdctflt.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jfdctfst.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jfdctint.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jidctflt.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jidctfst.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jidctint.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jmemmgr.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jpegtran.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jquant1.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jquant2.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/jutils.Plo@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rdbmp.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rdcolmap.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rdgif.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rdjpgcom.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rdppm.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rdrle.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rdswitch.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/rdtarga.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/transupp.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/wrbmp.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/wrgif.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/wrjpgcom.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/wrppm.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/wrrle.Po@am__quote@ # am--include-marker
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/wrtarga.Po@am__quote@ # am--include-marker
+
+$(am__depfiles_remade):
+ @$(MKDIR_P) $(@D)
+ @echo '# dummy' >$@-t && $(am__mv) $@-t $@
+
+am--depfiles: $(am__depfiles_remade)
.c.o:
@am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $<
@@ -898,12 +939,12 @@ distclean-tags:
check-am: all-am
$(MAKE) $(AM_MAKEFLAGS) check-local
check: check-am
-all-am: Makefile $(LTLIBRARIES) $(PROGRAMS) $(MANS) $(DATA) $(HEADERS) \
+all-am: Makefile $(PROGRAMS) $(LTLIBRARIES) $(MANS) $(DATA) $(HEADERS) \
jconfig.h
install-binPROGRAMS: install-libLTLIBRARIES
installdirs:
- for dir in "$(DESTDIR)$(libdir)" "$(DESTDIR)$(bindir)" "$(DESTDIR)$(man1dir)" "$(DESTDIR)$(pkgconfigdir)" "$(DESTDIR)$(includedir)"; do \
+ for dir in "$(DESTDIR)$(bindir)" "$(DESTDIR)$(libdir)" "$(DESTDIR)$(man1dir)" "$(DESTDIR)$(pkgconfigdir)" "$(DESTDIR)$(includedir)"; do \
test -z "$$dir" || $(MKDIR_P) "$$dir"; \
done
install: install-am
@@ -944,7 +985,71 @@ clean-am: clean-binPROGRAMS clean-generic clean-libLTLIBRARIES \
distclean: distclean-am
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
- -rm -rf ./$(DEPDIR)
+ -rm -f ./$(DEPDIR)/@MEMORYMGR@.Plo
+ -rm -f ./$(DEPDIR)/cdjpeg.Po
+ -rm -f ./$(DEPDIR)/cjpeg.Po
+ -rm -f ./$(DEPDIR)/djpeg.Po
+ -rm -f ./$(DEPDIR)/jaricom.Plo
+ -rm -f ./$(DEPDIR)/jcapimin.Plo
+ -rm -f ./$(DEPDIR)/jcapistd.Plo
+ -rm -f ./$(DEPDIR)/jcarith.Plo
+ -rm -f ./$(DEPDIR)/jccoefct.Plo
+ -rm -f ./$(DEPDIR)/jccolor.Plo
+ -rm -f ./$(DEPDIR)/jcdctmgr.Plo
+ -rm -f ./$(DEPDIR)/jchuff.Plo
+ -rm -f ./$(DEPDIR)/jcinit.Plo
+ -rm -f ./$(DEPDIR)/jcmainct.Plo
+ -rm -f ./$(DEPDIR)/jcmarker.Plo
+ -rm -f ./$(DEPDIR)/jcmaster.Plo
+ -rm -f ./$(DEPDIR)/jcomapi.Plo
+ -rm -f ./$(DEPDIR)/jcparam.Plo
+ -rm -f ./$(DEPDIR)/jcprepct.Plo
+ -rm -f ./$(DEPDIR)/jcsample.Plo
+ -rm -f ./$(DEPDIR)/jctrans.Plo
+ -rm -f ./$(DEPDIR)/jdapimin.Plo
+ -rm -f ./$(DEPDIR)/jdapistd.Plo
+ -rm -f ./$(DEPDIR)/jdarith.Plo
+ -rm -f ./$(DEPDIR)/jdatadst.Plo
+ -rm -f ./$(DEPDIR)/jdatasrc.Plo
+ -rm -f ./$(DEPDIR)/jdcoefct.Plo
+ -rm -f ./$(DEPDIR)/jdcolor.Plo
+ -rm -f ./$(DEPDIR)/jddctmgr.Plo
+ -rm -f ./$(DEPDIR)/jdhuff.Plo
+ -rm -f ./$(DEPDIR)/jdinput.Plo
+ -rm -f ./$(DEPDIR)/jdmainct.Plo
+ -rm -f ./$(DEPDIR)/jdmarker.Plo
+ -rm -f ./$(DEPDIR)/jdmaster.Plo
+ -rm -f ./$(DEPDIR)/jdmerge.Plo
+ -rm -f ./$(DEPDIR)/jdpostct.Plo
+ -rm -f ./$(DEPDIR)/jdsample.Plo
+ -rm -f ./$(DEPDIR)/jdtrans.Plo
+ -rm -f ./$(DEPDIR)/jerror.Plo
+ -rm -f ./$(DEPDIR)/jfdctflt.Plo
+ -rm -f ./$(DEPDIR)/jfdctfst.Plo
+ -rm -f ./$(DEPDIR)/jfdctint.Plo
+ -rm -f ./$(DEPDIR)/jidctflt.Plo
+ -rm -f ./$(DEPDIR)/jidctfst.Plo
+ -rm -f ./$(DEPDIR)/jidctint.Plo
+ -rm -f ./$(DEPDIR)/jmemmgr.Plo
+ -rm -f ./$(DEPDIR)/jpegtran.Po
+ -rm -f ./$(DEPDIR)/jquant1.Plo
+ -rm -f ./$(DEPDIR)/jquant2.Plo
+ -rm -f ./$(DEPDIR)/jutils.Plo
+ -rm -f ./$(DEPDIR)/rdbmp.Po
+ -rm -f ./$(DEPDIR)/rdcolmap.Po
+ -rm -f ./$(DEPDIR)/rdgif.Po
+ -rm -f ./$(DEPDIR)/rdjpgcom.Po
+ -rm -f ./$(DEPDIR)/rdppm.Po
+ -rm -f ./$(DEPDIR)/rdrle.Po
+ -rm -f ./$(DEPDIR)/rdswitch.Po
+ -rm -f ./$(DEPDIR)/rdtarga.Po
+ -rm -f ./$(DEPDIR)/transupp.Po
+ -rm -f ./$(DEPDIR)/wrbmp.Po
+ -rm -f ./$(DEPDIR)/wrgif.Po
+ -rm -f ./$(DEPDIR)/wrjpgcom.Po
+ -rm -f ./$(DEPDIR)/wrppm.Po
+ -rm -f ./$(DEPDIR)/wrrle.Po
+ -rm -f ./$(DEPDIR)/wrtarga.Po
-rm -f Makefile
distclean-am: clean-am distclean-compile distclean-generic \
distclean-hdr distclean-libtool distclean-tags
@@ -993,7 +1098,71 @@ installcheck-am:
maintainer-clean: maintainer-clean-am
-rm -f $(am__CONFIG_DISTCLEAN_FILES)
-rm -rf $(top_srcdir)/autom4te.cache
- -rm -rf ./$(DEPDIR)
+ -rm -f ./$(DEPDIR)/@MEMORYMGR@.Plo
+ -rm -f ./$(DEPDIR)/cdjpeg.Po
+ -rm -f ./$(DEPDIR)/cjpeg.Po
+ -rm -f ./$(DEPDIR)/djpeg.Po
+ -rm -f ./$(DEPDIR)/jaricom.Plo
+ -rm -f ./$(DEPDIR)/jcapimin.Plo
+ -rm -f ./$(DEPDIR)/jcapistd.Plo
+ -rm -f ./$(DEPDIR)/jcarith.Plo
+ -rm -f ./$(DEPDIR)/jccoefct.Plo
+ -rm -f ./$(DEPDIR)/jccolor.Plo
+ -rm -f ./$(DEPDIR)/jcdctmgr.Plo
+ -rm -f ./$(DEPDIR)/jchuff.Plo
+ -rm -f ./$(DEPDIR)/jcinit.Plo
+ -rm -f ./$(DEPDIR)/jcmainct.Plo
+ -rm -f ./$(DEPDIR)/jcmarker.Plo
+ -rm -f ./$(DEPDIR)/jcmaster.Plo
+ -rm -f ./$(DEPDIR)/jcomapi.Plo
+ -rm -f ./$(DEPDIR)/jcparam.Plo
+ -rm -f ./$(DEPDIR)/jcprepct.Plo
+ -rm -f ./$(DEPDIR)/jcsample.Plo
+ -rm -f ./$(DEPDIR)/jctrans.Plo
+ -rm -f ./$(DEPDIR)/jdapimin.Plo
+ -rm -f ./$(DEPDIR)/jdapistd.Plo
+ -rm -f ./$(DEPDIR)/jdarith.Plo
+ -rm -f ./$(DEPDIR)/jdatadst.Plo
+ -rm -f ./$(DEPDIR)/jdatasrc.Plo
+ -rm -f ./$(DEPDIR)/jdcoefct.Plo
+ -rm -f ./$(DEPDIR)/jdcolor.Plo
+ -rm -f ./$(DEPDIR)/jddctmgr.Plo
+ -rm -f ./$(DEPDIR)/jdhuff.Plo
+ -rm -f ./$(DEPDIR)/jdinput.Plo
+ -rm -f ./$(DEPDIR)/jdmainct.Plo
+ -rm -f ./$(DEPDIR)/jdmarker.Plo
+ -rm -f ./$(DEPDIR)/jdmaster.Plo
+ -rm -f ./$(DEPDIR)/jdmerge.Plo
+ -rm -f ./$(DEPDIR)/jdpostct.Plo
+ -rm -f ./$(DEPDIR)/jdsample.Plo
+ -rm -f ./$(DEPDIR)/jdtrans.Plo
+ -rm -f ./$(DEPDIR)/jerror.Plo
+ -rm -f ./$(DEPDIR)/jfdctflt.Plo
+ -rm -f ./$(DEPDIR)/jfdctfst.Plo
+ -rm -f ./$(DEPDIR)/jfdctint.Plo
+ -rm -f ./$(DEPDIR)/jidctflt.Plo
+ -rm -f ./$(DEPDIR)/jidctfst.Plo
+ -rm -f ./$(DEPDIR)/jidctint.Plo
+ -rm -f ./$(DEPDIR)/jmemmgr.Plo
+ -rm -f ./$(DEPDIR)/jpegtran.Po
+ -rm -f ./$(DEPDIR)/jquant1.Plo
+ -rm -f ./$(DEPDIR)/jquant2.Plo
+ -rm -f ./$(DEPDIR)/jutils.Plo
+ -rm -f ./$(DEPDIR)/rdbmp.Po
+ -rm -f ./$(DEPDIR)/rdcolmap.Po
+ -rm -f ./$(DEPDIR)/rdgif.Po
+ -rm -f ./$(DEPDIR)/rdjpgcom.Po
+ -rm -f ./$(DEPDIR)/rdppm.Po
+ -rm -f ./$(DEPDIR)/rdrle.Po
+ -rm -f ./$(DEPDIR)/rdswitch.Po
+ -rm -f ./$(DEPDIR)/rdtarga.Po
+ -rm -f ./$(DEPDIR)/transupp.Po
+ -rm -f ./$(DEPDIR)/wrbmp.Po
+ -rm -f ./$(DEPDIR)/wrgif.Po
+ -rm -f ./$(DEPDIR)/wrjpgcom.Po
+ -rm -f ./$(DEPDIR)/wrppm.Po
+ -rm -f ./$(DEPDIR)/wrrle.Po
+ -rm -f ./$(DEPDIR)/wrtarga.Po
-rm -f Makefile
maintainer-clean-am: distclean-am maintainer-clean-generic
@@ -1018,19 +1187,20 @@ uninstall-man: uninstall-man1
.MAKE: all check-am install-am install-strip
-.PHONY: CTAGS GTAGS TAGS all all-am am--refresh check check-am \
- check-local clean clean-binPROGRAMS clean-cscope clean-generic \
- clean-libLTLIBRARIES clean-libtool cscope cscopelist-am ctags \
- ctags-am distclean distclean-compile distclean-generic \
- distclean-hdr distclean-libtool distclean-tags dvi dvi-am html \
- html-am info info-am install install-am install-binPROGRAMS \
- install-data install-data-am install-data-local install-dvi \
- install-dvi-am install-exec install-exec-am install-html \
- install-html-am install-includeHEADERS install-info \
- install-info-am install-libLTLIBRARIES install-man \
- install-man1 install-nodist_pkgconfigDATA install-pdf \
- install-pdf-am install-ps install-ps-am install-strip \
- installcheck installcheck-am installdirs maintainer-clean \
+.PHONY: CTAGS GTAGS TAGS all all-am am--depfiles am--refresh check \
+ check-am check-local clean clean-binPROGRAMS clean-cscope \
+ clean-generic clean-libLTLIBRARIES clean-libtool cscope \
+ cscopelist-am ctags ctags-am distclean distclean-compile \
+ distclean-generic distclean-hdr distclean-libtool \
+ distclean-tags dvi dvi-am html html-am info info-am install \
+ install-am install-binPROGRAMS install-data install-data-am \
+ install-data-local install-dvi install-dvi-am install-exec \
+ install-exec-am install-html install-html-am \
+ install-includeHEADERS install-info install-info-am \
+ install-libLTLIBRARIES install-man install-man1 \
+ install-nodist_pkgconfigDATA install-pdf install-pdf-am \
+ install-ps install-ps-am install-strip installcheck \
+ installcheck-am installdirs maintainer-clean \
maintainer-clean-generic mostlyclean mostlyclean-compile \
mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \
tags tags-am uninstall uninstall-am uninstall-binPROGRAMS \
@@ -1054,13 +1224,15 @@ uninstall-local:
test: check-local
check-local:
rm -f testout*
- ./djpeg -dct int -ppm -outfile testout.ppm $(srcdir)/testorig.jpg
- ./djpeg -dct int -bmp -colors 256 -outfile testout.bmp $(srcdir)/testorig.jpg
- ./cjpeg -dct int -outfile testout.jpg $(srcdir)/testimg.ppm
+ ./djpeg -dct int -ppm -outfile testout.ppm $(srcdir)/testorig.jpg
+ ./djpeg -dct int -gif -outfile testout.gif $(srcdir)/testorig.jpg
+ ./djpeg -dct int -bmp -colors 256 -outfile testout.bmp $(srcdir)/testorig.jpg
+ ./cjpeg -dct int -outfile testout.jpg $(srcdir)/testimg.ppm
./djpeg -dct int -ppm -outfile testoutp.ppm $(srcdir)/testprog.jpg
./cjpeg -dct int -progressive -opt -outfile testoutp.jpg $(srcdir)/testimg.ppm
./jpegtran -outfile testoutt.jpg $(srcdir)/testprog.jpg
cmp $(srcdir)/testimg.ppm testout.ppm
+ cmp $(srcdir)/testimg.gif testout.gif
cmp $(srcdir)/testimg.bmp testout.bmp
cmp $(srcdir)/testimg.jpg testout.jpg
cmp $(srcdir)/testimg.ppm testoutp.ppm
diff --git a/jpeg/README b/jpeg/README
index 56cdb600..13b245c5 100644
--- a/jpeg/README
+++ b/jpeg/README
@@ -1,7 +1,7 @@
The Independent JPEG Group's JPEG software
==========================================
-README for release 9c of 14-Jan-2018
+README for release 9d of 12-Jan-2020
====================================
This distribution contains the ninth public release of the Independent JPEG
@@ -10,8 +10,8 @@ to use it for any purpose, subject to the conditions under LEGAL ISSUES, below.
This software is the work of Tom Lane, Guido Vollbeding, Philip Gladstone,
Bill Allombert, Jim Boucher, Lee Crocker, Bob Friesenhahn, Ben Jackson,
-Julian Minguillon, Luis Ortiz, George Phillips, Davide Rossi, Ge' Weijers,
-and other members of the Independent JPEG Group.
+John Korejwa, Julian Minguillon, Luis Ortiz, George Phillips, Davide Rossi,
+Ge' Weijers, and other members of the Independent JPEG Group.
IJG is not affiliated with the ISO/IEC JTC1/SC29/WG1 standards committee
(previously known as JPEG, together with ITU-T SG16).
@@ -115,7 +115,7 @@ with respect to this software, its quality, accuracy, merchantability, or
fitness for a particular purpose. This software is provided "AS IS", and you,
its user, assume the entire risk as to its quality and accuracy.
-This software is copyright (C) 1991-2018, Thomas G. Lane, Guido Vollbeding.
+This software is copyright (C) 1991-2020, Thomas G. Lane, Guido Vollbeding.
All Rights Reserved except as specified below.
Permission is hereby granted to use, copy, modify, and distribute this
@@ -152,13 +152,6 @@ The same holds for its supporting scripts (config.guess, config.sub,
ltmain.sh). Another support script, install-sh, is copyright by X Consortium
but is also freely distributable.
-The IJG distribution formerly included code to read and write GIF files.
-To avoid entanglement with the Unisys LZW patent (now expired), GIF reading
-support has been removed altogether, and the GIF writer has been simplified
-to produce "uncompressed GIFs". This technique does not use the LZW
-algorithm; the resulting GIF files are larger than usual, but are readable
-by all standard GIF decoders.
-
REFERENCES
==========
@@ -246,8 +239,8 @@ ARCHIVE LOCATIONS
The "official" archive site for this software is www.ijg.org.
The most recent released version can always be found there in
directory "files". This particular version will be archived as
-http://www.ijg.org/files/jpegsrc.v9c.tar.gz, and in Windows-compatible
-"zip" archive format as http://www.ijg.org/files/jpegsr9c.zip.
+http://www.ijg.org/files/jpegsrc.v9d.tar.gz, and in Windows-compatible
+"zip" archive format as http://www.ijg.org/files/jpegsr9d.zip.
The JPEG FAQ (Frequently Asked Questions) article is a source of some
general information about JPEG.
diff --git a/jpeg/aclocal.m4 b/jpeg/aclocal.m4
index dde9b178..f77f2904 100644
--- a/jpeg/aclocal.m4
+++ b/jpeg/aclocal.m4
@@ -1,6 +1,6 @@
-# generated automatically by aclocal 1.15.1 -*- Autoconf -*-
+# generated automatically by aclocal 1.16.1 -*- Autoconf -*-
-# Copyright (C) 1996-2017 Free Software Foundation, Inc.
+# Copyright (C) 1996-2018 Free Software Foundation, Inc.
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -9049,7 +9049,7 @@ m4_ifndef([_LT_PROG_F77], [AC_DEFUN([_LT_PROG_F77])])
m4_ifndef([_LT_PROG_FC], [AC_DEFUN([_LT_PROG_FC])])
m4_ifndef([_LT_PROG_CXX], [AC_DEFUN([_LT_PROG_CXX])])
-# Copyright (C) 2002-2017 Free Software Foundation, Inc.
+# Copyright (C) 2002-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -9061,10 +9061,10 @@ m4_ifndef([_LT_PROG_CXX], [AC_DEFUN([_LT_PROG_CXX])])
# generated from the m4 files accompanying Automake X.Y.
# (This private macro should not be called outside this file.)
AC_DEFUN([AM_AUTOMAKE_VERSION],
-[am__api_version='1.15'
+[am__api_version='1.16'
dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to
dnl require some minimum version. Point them to the right macro.
-m4_if([$1], [1.15.1], [],
+m4_if([$1], [1.16.1], [],
[AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl
])
@@ -9080,12 +9080,12 @@ m4_define([_AM_AUTOCONF_VERSION], [])
# Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced.
# This function is AC_REQUIREd by AM_INIT_AUTOMAKE.
AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION],
-[AM_AUTOMAKE_VERSION([1.15.1])dnl
+[AM_AUTOMAKE_VERSION([1.16.1])dnl
m4_ifndef([AC_AUTOCONF_VERSION],
[m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl
_AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))])
-# Copyright (C) 2011-2017 Free Software Foundation, Inc.
+# Copyright (C) 2011-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -9147,7 +9147,7 @@ AC_SUBST([AR])dnl
# AM_AUX_DIR_EXPAND -*- Autoconf -*-
-# Copyright (C) 2001-2017 Free Software Foundation, Inc.
+# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -9199,7 +9199,7 @@ am_aux_dir=`cd "$ac_aux_dir" && pwd`
# AM_CONDITIONAL -*- Autoconf -*-
-# Copyright (C) 1997-2017 Free Software Foundation, Inc.
+# Copyright (C) 1997-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -9230,7 +9230,7 @@ AC_CONFIG_COMMANDS_PRE(
Usually this means the macro was only invoked conditionally.]])
fi])])
-# Copyright (C) 1999-2017 Free Software Foundation, Inc.
+# Copyright (C) 1999-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -9421,13 +9421,12 @@ _AM_SUBST_NOTMAKE([am__nodep])dnl
# Generate code to set up dependency tracking. -*- Autoconf -*-
-# Copyright (C) 1999-2017 Free Software Foundation, Inc.
+# Copyright (C) 1999-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
# with or without modifications, as long as this notice is preserved.
-
# _AM_OUTPUT_DEPENDENCY_COMMANDS
# ------------------------------
AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
@@ -9435,49 +9434,41 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
# Older Autoconf quotes --file arguments for eval, but not when files
# are listed without --file. Let's play safe and only enable the eval
# if we detect the quoting.
- case $CONFIG_FILES in
- *\'*) eval set x "$CONFIG_FILES" ;;
- *) set x $CONFIG_FILES ;;
- esac
+ # TODO: see whether this extra hack can be removed once we start
+ # requiring Autoconf 2.70 or later.
+ AS_CASE([$CONFIG_FILES],
+ [*\'*], [eval set x "$CONFIG_FILES"],
+ [*], [set x $CONFIG_FILES])
shift
- for mf
+ # Used to flag and report bootstrapping failures.
+ am_rc=0
+ for am_mf
do
# Strip MF so we end up with the name of the file.
- mf=`echo "$mf" | sed -e 's/:.*$//'`
- # Check whether this is an Automake generated Makefile or not.
- # We used to match only the files named 'Makefile.in', but
- # some people rename them; so instead we look at the file content.
- # Grep'ing the first line is not enough: some people post-process
- # each Makefile.in and add a new line on top of each file to say so.
- # Grep'ing the whole file is not good either: AIX grep has a line
+ am_mf=`AS_ECHO(["$am_mf"]) | sed -e 's/:.*$//'`
+ # Check whether this is an Automake generated Makefile which includes
+ # dependency-tracking related rules and includes.
+ # Grep'ing the whole file directly is not great: AIX grep has a line
# limit of 2048, but all sed's we know have understand at least 4000.
- if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then
- dirpart=`AS_DIRNAME("$mf")`
- else
- continue
- fi
- # Extract the definition of DEPDIR, am__include, and am__quote
- # from the Makefile without running 'make'.
- DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
- test -z "$DEPDIR" && continue
- am__include=`sed -n 's/^am__include = //p' < "$mf"`
- test -z "$am__include" && continue
- am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
- # Find all dependency output files, they are included files with
- # $(DEPDIR) in their names. We invoke sed twice because it is the
- # simplest approach to changing $(DEPDIR) to its actual value in the
- # expansion.
- for file in `sed -n "
- s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
- sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do
- # Make sure the directory exists.
- test -f "$dirpart/$file" && continue
- fdir=`AS_DIRNAME(["$file"])`
- AS_MKDIR_P([$dirpart/$fdir])
- # echo "creating $dirpart/$file"
- echo '# dummy' > "$dirpart/$file"
- done
+ sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \
+ || continue
+ am_dirpart=`AS_DIRNAME(["$am_mf"])`
+ am_filepart=`AS_BASENAME(["$am_mf"])`
+ AM_RUN_LOG([cd "$am_dirpart" \
+ && sed -e '/# am--include-marker/d' "$am_filepart" \
+ | $MAKE -f - am--depfiles]) || am_rc=$?
done
+ if test $am_rc -ne 0; then
+ AC_MSG_FAILURE([Something went wrong bootstrapping makefile fragments
+ for automatic dependency tracking. Try re-running configure with the
+ '--disable-dependency-tracking' option to at least be able to build
+ the package (albeit without support for automatic dependency tracking).])
+ fi
+ AS_UNSET([am_dirpart])
+ AS_UNSET([am_filepart])
+ AS_UNSET([am_mf])
+ AS_UNSET([am_rc])
+ rm -f conftest-deps.mk
}
])# _AM_OUTPUT_DEPENDENCY_COMMANDS
@@ -9486,18 +9477,17 @@ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS],
# -----------------------------
# This macro should only be invoked once -- use via AC_REQUIRE.
#
-# This code is only required when automatic dependency tracking
-# is enabled. FIXME. This creates each '.P' file that we will
-# need in order to bootstrap the dependency handling code.
+# This code is only required when automatic dependency tracking is enabled.
+# This creates each '.Po' and '.Plo' makefile fragment that we'll need in
+# order to bootstrap the dependency handling code.
AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS],
[AC_CONFIG_COMMANDS([depfiles],
[test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS],
- [AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"])
-])
+ [AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"])])
# Do all the work for Automake. -*- Autoconf -*-
-# Copyright (C) 1996-2017 Free Software Foundation, Inc.
+# Copyright (C) 1996-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -9584,8 +9574,8 @@ AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl
AC_REQUIRE([AC_PROG_MKDIR_P])dnl
# For better backward compatibility. To be removed once Automake 1.9.x
# dies out for good. For more background, see:
-# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
-# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
+# <https://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
+# <https://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
AC_SUBST([mkdir_p], ['$(MKDIR_P)'])
# We need awk for the "check" target (and possibly the TAP driver). The
# system "awk" is bad on some platforms.
@@ -9652,7 +9642,7 @@ END
Aborting the configuration process, to ensure you take notice of the issue.
You can download and install GNU coreutils to get an 'rm' implementation
-that behaves properly: <http://www.gnu.org/software/coreutils/>.
+that behaves properly: <https://www.gnu.org/software/coreutils/>.
If you want to complete the configuration process using your problematic
'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM
@@ -9694,7 +9684,7 @@ for _am_header in $config_headers :; do
done
echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count])
-# Copyright (C) 2001-2017 Free Software Foundation, Inc.
+# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -9715,7 +9705,7 @@ if test x"${install_sh+set}" != xset; then
fi
AC_SUBST([install_sh])])
-# Copyright (C) 2003-2017 Free Software Foundation, Inc.
+# Copyright (C) 2003-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -9737,7 +9727,7 @@ AC_SUBST([am__leading_dot])])
# Add --enable-maintainer-mode option to configure. -*- Autoconf -*-
# From Jim Meyering
-# Copyright (C) 1996-2017 Free Software Foundation, Inc.
+# Copyright (C) 1996-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -9772,7 +9762,7 @@ AC_MSG_CHECKING([whether to enable maintainer-specific portions of Makefiles])
# Check to see how 'make' treats includes. -*- Autoconf -*-
-# Copyright (C) 2001-2017 Free Software Foundation, Inc.
+# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -9780,49 +9770,42 @@ AC_MSG_CHECKING([whether to enable maintainer-specific portions of Makefiles])
# AM_MAKE_INCLUDE()
# -----------------
-# Check to see how make treats includes.
+# Check whether make has an 'include' directive that can support all
+# the idioms we need for our automatic dependency tracking code.
AC_DEFUN([AM_MAKE_INCLUDE],
-[am_make=${MAKE-make}
-cat > confinc << 'END'
+[AC_MSG_CHECKING([whether ${MAKE-make} supports the include directive])
+cat > confinc.mk << 'END'
am__doit:
- @echo this is the am__doit target
+ @echo this is the am__doit target >confinc.out
.PHONY: am__doit
END
-# If we don't find an include directive, just comment out the code.
-AC_MSG_CHECKING([for style of include used by $am_make])
am__include="#"
am__quote=
-_am_result=none
-# First try GNU make style include.
-echo "include confinc" > confmf
-# Ignore all kinds of additional output from 'make'.
-case `$am_make -s -f confmf 2> /dev/null` in #(
-*the\ am__doit\ target*)
- am__include=include
- am__quote=
- _am_result=GNU
- ;;
-esac
-# Now try BSD make style include.
-if test "$am__include" = "#"; then
- echo '.include "confinc"' > confmf
- case `$am_make -s -f confmf 2> /dev/null` in #(
- *the\ am__doit\ target*)
- am__include=.include
- am__quote="\""
- _am_result=BSD
- ;;
- esac
-fi
-AC_SUBST([am__include])
-AC_SUBST([am__quote])
-AC_MSG_RESULT([$_am_result])
-rm -f confinc confmf
-])
+# BSD make does it like this.
+echo '.include "confinc.mk" # ignored' > confmf.BSD
+# Other make implementations (GNU, Solaris 10, AIX) do it like this.
+echo 'include confinc.mk # ignored' > confmf.GNU
+_am_result=no
+for s in GNU BSD; do
+ AM_RUN_LOG([${MAKE-make} -f confmf.$s && cat confinc.out])
+ AS_CASE([$?:`cat confinc.out 2>/dev/null`],
+ ['0:this is the am__doit target'],
+ [AS_CASE([$s],
+ [BSD], [am__include='.include' am__quote='"'],
+ [am__include='include' am__quote=''])])
+ if test "$am__include" != "#"; then
+ _am_result="yes ($s style)"
+ break
+ fi
+done
+rm -f confinc.* confmf.*
+AC_MSG_RESULT([${_am_result}])
+AC_SUBST([am__include])])
+AC_SUBST([am__quote])])
# Fake the existence of programs that GNU maintainers use. -*- Autoconf -*-
-# Copyright (C) 1997-2017 Free Software Foundation, Inc.
+# Copyright (C) 1997-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -9861,7 +9844,7 @@ fi
# Helper functions for option handling. -*- Autoconf -*-
-# Copyright (C) 2001-2017 Free Software Foundation, Inc.
+# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -9890,7 +9873,7 @@ AC_DEFUN([_AM_SET_OPTIONS],
AC_DEFUN([_AM_IF_OPTION],
[m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])])
-# Copyright (C) 1999-2017 Free Software Foundation, Inc.
+# Copyright (C) 1999-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -9937,7 +9920,7 @@ AC_LANG_POP([C])])
# For backward compatibility.
AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])])
-# Copyright (C) 2001-2017 Free Software Foundation, Inc.
+# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -9956,7 +9939,7 @@ AC_DEFUN([AM_RUN_LOG],
# Check to make sure that the build environment is sane. -*- Autoconf -*-
-# Copyright (C) 1996-2017 Free Software Foundation, Inc.
+# Copyright (C) 1996-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -10037,7 +10020,7 @@ AC_CONFIG_COMMANDS_PRE(
rm -f conftest.file
])
-# Copyright (C) 2009-2017 Free Software Foundation, Inc.
+# Copyright (C) 2009-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -10097,7 +10080,7 @@ AC_SUBST([AM_BACKSLASH])dnl
_AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl
])
-# Copyright (C) 2001-2017 Free Software Foundation, Inc.
+# Copyright (C) 2001-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -10125,7 +10108,7 @@ fi
INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s"
AC_SUBST([INSTALL_STRIP_PROGRAM])])
-# Copyright (C) 2006-2017 Free Software Foundation, Inc.
+# Copyright (C) 2006-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
@@ -10144,7 +10127,7 @@ AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)])
# Check how to create a tarball. -*- Autoconf -*-
-# Copyright (C) 2004-2017 Free Software Foundation, Inc.
+# Copyright (C) 2004-2018 Free Software Foundation, Inc.
#
# This file is free software; the Free Software Foundation
# gives unlimited permission to copy and/or distribute it,
diff --git a/jpeg/ar-lib b/jpeg/ar-lib
index 05094d34..0baa4f60 100755
--- a/jpeg/ar-lib
+++ b/jpeg/ar-lib
@@ -4,7 +4,7 @@
me=ar-lib
scriptversion=2012-03-01.08; # UTC
-# Copyright (C) 2010-2017 Free Software Foundation, Inc.
+# Copyright (C) 2010-2018 Free Software Foundation, Inc.
# Written by Peter Rosin <peda@lysator.liu.se>.
#
# This program is free software; you can redistribute it and/or modify
@@ -18,7 +18,7 @@ scriptversion=2012-03-01.08; # UTC
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
-# along with this program. If not, see <http://www.gnu.org/licenses/>.
+# along with this program. If not, see <https://www.gnu.org/licenses/>.
# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
diff --git a/jpeg/cdjpeg.h b/jpeg/cdjpeg.h
index ed024ac3..524ab3a2 100644
--- a/jpeg/cdjpeg.h
+++ b/jpeg/cdjpeg.h
@@ -2,6 +2,7 @@
* cdjpeg.h
*
* Copyright (C) 1994-1997, Thomas G. Lane.
+ * Modified 2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -121,7 +122,8 @@ EXTERN(cjpeg_source_ptr) jinit_read_bmp JPP((j_compress_ptr cinfo));
EXTERN(djpeg_dest_ptr) jinit_write_bmp JPP((j_decompress_ptr cinfo,
boolean is_os2));
EXTERN(cjpeg_source_ptr) jinit_read_gif JPP((j_compress_ptr cinfo));
-EXTERN(djpeg_dest_ptr) jinit_write_gif JPP((j_decompress_ptr cinfo));
+EXTERN(djpeg_dest_ptr) jinit_write_gif JPP((j_decompress_ptr cinfo,
+ boolean is_lzw));
EXTERN(cjpeg_source_ptr) jinit_read_ppm JPP((j_compress_ptr cinfo));
EXTERN(djpeg_dest_ptr) jinit_write_ppm JPP((j_decompress_ptr cinfo));
EXTERN(cjpeg_source_ptr) jinit_read_rle JPP((j_compress_ptr cinfo));
diff --git a/jpeg/change.log b/jpeg/change.log
index 674a558a..ed8ec6af 100644
--- a/jpeg/change.log
+++ b/jpeg/change.log
@@ -1,6 +1,55 @@
CHANGE LOG for Independent JPEG Group's JPEG software
+Version 9d 12-Jan-2020
+-----------------------
+
+Optimize the optimal Huffman code table generation to produce
+slightly smaller files. Thank to John Korejwa for suggestion.
+Note: Requires rebuild of testimgp.jpg.
+
+Decoding Huffman: Use default tables if tables are not defined.
+Thank to Simone Azzalin for report (Motion JPEG),
+and to Martin Strunz for hint.
+
+Add sanity check in optimal Huffman code table generation.
+Thank to Adam Farley for suggestion.
+
+rdtarga.c: use read_byte(), with EOF check, instead of getc()
+in read_*_pixel().
+Thank to Chijin Zhou for cjpeg potential vulnerability report.
+
+jmemnobs.c: respect the max_memory_to_use setting in
+jpeg_mem_available() computation. Thank to Sheng Shu and
+Dongdong She for djpeg potential vulnerability report.
+
+jdarith.c, jdhuff.c: avoid left shift of negative value
+compiler warning in decode_mcu_AC_refine().
+Thank to Indu Bhagat for suggestion.
+
+Add x64 (64-bit) platform support, avoid compiler warnings.
+Thank to Jonathan Potter, Feiyun Wang, and Sheng Shu for suggestion.
+
+Adjust libjpeg version specification for pkg-config file.
+Thank to Chen Chen for suggestion.
+
+Restore GIF read and write support from libjpeg version 6a.
+Thank to Wolfgang Werner (W.W.) Heinz for suggestion.
+
+Improve consistency in raw (downsampled) image data processing mode.
+Thank to Zhongyuan Zhou for hint.
+
+Avoid out of bounds array read (AC derived table pointers)
+in start pass in jdhuff.c. Thank to Peng Li for report.
+
+Improve code sanity (jdhuff.c).
+Thank to Reza Mirzazade farkhani for reports.
+
+Add jpegtran -drop option; add options to the crop extension and wipe
+to fill the extra area with content from the source image region,
+instead of gray out.
+
+
Version 9c 14-Jan-2018
-----------------------
diff --git a/jpeg/cjpeg.1 b/jpeg/cjpeg.1
index 7d685be5..355d3405 100644
--- a/jpeg/cjpeg.1
+++ b/jpeg/cjpeg.1
@@ -1,4 +1,4 @@
-.TH CJPEG 1 "26 July 2015"
+.TH CJPEG 1 "28 April 2019"
.SH NAME
cjpeg \- compress an image file to a JPEG file
.SH SYNOPSIS
@@ -16,8 +16,9 @@ cjpeg \- compress an image file to a JPEG file
compresses the named image file, or the standard input if no file is
named, and produces a JPEG/JFIF file on the standard output.
The currently supported input file formats are: PPM (PBMPLUS color
-format), PGM (PBMPLUS grayscale format), BMP, Targa, and RLE (Utah Raster
-Toolkit format). (RLE is supported only if the URT library is available.)
+format), PGM (PBMPLUS grayscale format), BMP, GIF, Targa, and RLE (Utah Raster
+Toolkit format). (RLE is supported only if the URT library is available,
+which it isn't on most non-Unix systems.)
.SH OPTIONS
All switch names may be abbreviated; for example,
.B \-grayscale
@@ -42,10 +43,10 @@ Scale quantization tables to adjust image quality. Quality is 0 (worst) to
.TP
.B \-grayscale
Create monochrome JPEG file from color input. Be sure to use this switch when
-compressing a grayscale BMP file, because
+compressing a grayscale BMP or GIF file, because
.B cjpeg
-isn't bright enough to notice whether a BMP file uses only shades of gray.
-By saying
+isn't bright enough to notice whether a BMP or GIF file uses only shades of
+gray. By saying
.BR \-grayscale ,
you'll get a smaller JPEG file that takes less time to process.
.TP
@@ -375,10 +376,6 @@ Communications of the ACM, April 1991 (vol. 34, no. 4), pp. 30-44.
.SH AUTHOR
Independent JPEG Group
.SH BUGS
-GIF input files are no longer supported, to avoid the Unisys LZW patent
-(now expired).
-(Conversion of GIF files to JPEG is usually a bad idea anyway.)
-.PP
Not all variants of BMP and Targa file formats are supported.
.PP
The
diff --git a/jpeg/compile b/jpeg/compile
index 2ab71e4e..99e50524 100755
--- a/jpeg/compile
+++ b/jpeg/compile
@@ -1,9 +1,9 @@
#! /bin/sh
# Wrapper for compilers which do not understand '-c -o'.
-scriptversion=2016-01-11.22; # UTC
+scriptversion=2018-03-07.03; # UTC
-# Copyright (C) 1999-2017 Free Software Foundation, Inc.
+# Copyright (C) 1999-2018 Free Software Foundation, Inc.
# Written by Tom Tromey <tromey@cygnus.com>.
#
# This program is free software; you can redistribute it and/or modify
@@ -17,7 +17,7 @@ scriptversion=2016-01-11.22; # UTC
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
-# along with this program. If not, see <http://www.gnu.org/licenses/>.
+# along with this program. If not, see <https://www.gnu.org/licenses/>.
# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
@@ -340,7 +340,7 @@ exit $ret
# Local Variables:
# mode: shell-script
# sh-indentation: 2
-# eval: (add-hook 'write-file-hooks 'time-stamp)
+# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "scriptversion="
# time-stamp-format: "%:y-%02m-%02d.%02H"
# time-stamp-time-zone: "UTC0"
diff --git a/jpeg/config.guess b/jpeg/config.guess
index 2193702b..256083a7 100755
--- a/jpeg/config.guess
+++ b/jpeg/config.guess
@@ -1,8 +1,8 @@
#! /bin/sh
# Attempt to guess a canonical system name.
-# Copyright 1992-2017 Free Software Foundation, Inc.
+# Copyright 1992-2018 Free Software Foundation, Inc.
-timestamp='2017-05-27'
+timestamp='2018-03-08'
# This file is free software; you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by
@@ -15,7 +15,7 @@ timestamp='2017-05-27'
# General Public License for more details.
#
# You should have received a copy of the GNU General Public License
-# along with this program; if not, see <http://www.gnu.org/licenses/>.
+# along with this program; if not, see <https://www.gnu.org/licenses/>.
#
# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
@@ -27,7 +27,7 @@ timestamp='2017-05-27'
# Originally written by Per Bothner; maintained since 2000 by Ben Elliston.
#
# You can get the latest version of this script from:
-# http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess
+# https://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess
#
# Please send patches to <config-patches@gnu.org>.
@@ -39,7 +39,7 @@ Usage: $0 [OPTION]
Output the configuration name of the system \`$me' is run on.
-Operation modes:
+Options:
-h, --help print this help, then exit
-t, --time-stamp print date of last modification, then exit
-v, --version print version number, then exit
@@ -50,7 +50,7 @@ version="\
GNU config.guess ($timestamp)
Originally written by Per Bothner.
-Copyright 1992-2017 Free Software Foundation, Inc.
+Copyright 1992-2018 Free Software Foundation, Inc.
This is free software; see the source for copying conditions. There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
@@ -107,9 +107,9 @@ trap "rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null; exit 1" 1 2 13 15 ;
dummy=$tmp/dummy ;
tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ;
case $CC_FOR_BUILD,$HOST_CC,$CC in
- ,,) echo "int x;" > $dummy.c ;
+ ,,) echo "int x;" > "$dummy.c" ;
for c in cc gcc c89 c99 ; do
- if ($c -c -o $dummy.o $dummy.c) >/dev/null 2>&1 ; then
+ if ($c -c -o "$dummy.o" "$dummy.c") >/dev/null 2>&1 ; then
CC_FOR_BUILD="$c"; break ;
fi ;
done ;
@@ -132,14 +132,14 @@ UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown
UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown
UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown
-case "${UNAME_SYSTEM}" in
+case "$UNAME_SYSTEM" in
Linux|GNU|GNU/*)
# If the system lacks a compiler, then just pick glibc.
# We could probably try harder.
LIBC=gnu
- eval $set_cc_for_build
- cat <<-EOF > $dummy.c
+ eval "$set_cc_for_build"
+ cat <<-EOF > "$dummy.c"
#include <features.h>
#if defined(__UCLIBC__)
LIBC=uclibc
@@ -149,13 +149,20 @@ Linux|GNU|GNU/*)
LIBC=gnu
#endif
EOF
- eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^LIBC' | sed 's, ,,g'`
+ eval "`$CC_FOR_BUILD -E "$dummy.c" 2>/dev/null | grep '^LIBC' | sed 's, ,,g'`"
+
+ # If ldd exists, use it to detect musl libc.
+ if command -v ldd >/dev/null && \
+ ldd --version 2>&1 | grep -q ^musl
+ then
+ LIBC=musl
+ fi
;;
esac
# Note: order is significant - the case branches are not exclusive.
-case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
+case "$UNAME_MACHINE:$UNAME_SYSTEM:$UNAME_RELEASE:$UNAME_VERSION" in
*:NetBSD:*:*)
# NetBSD (nbsd) targets should (where applicable) match one or
# more of the tuples: *-*-netbsdelf*, *-*-netbsdaout*,
@@ -169,30 +176,30 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
# portion of the name. We always set it to "unknown".
sysctl="sysctl -n hw.machine_arch"
UNAME_MACHINE_ARCH=`(uname -p 2>/dev/null || \
- /sbin/$sysctl 2>/dev/null || \
- /usr/sbin/$sysctl 2>/dev/null || \
+ "/sbin/$sysctl" 2>/dev/null || \
+ "/usr/sbin/$sysctl" 2>/dev/null || \
echo unknown)`
- case "${UNAME_MACHINE_ARCH}" in
+ case "$UNAME_MACHINE_ARCH" in
armeb) machine=armeb-unknown ;;
arm*) machine=arm-unknown ;;
sh3el) machine=shl-unknown ;;
sh3eb) machine=sh-unknown ;;
sh5el) machine=sh5le-unknown ;;
earmv*)
- arch=`echo ${UNAME_MACHINE_ARCH} | sed -e 's,^e\(armv[0-9]\).*$,\1,'`
- endian=`echo ${UNAME_MACHINE_ARCH} | sed -ne 's,^.*\(eb\)$,\1,p'`
- machine=${arch}${endian}-unknown
+ arch=`echo "$UNAME_MACHINE_ARCH" | sed -e 's,^e\(armv[0-9]\).*$,\1,'`
+ endian=`echo "$UNAME_MACHINE_ARCH" | sed -ne 's,^.*\(eb\)$,\1,p'`
+ machine="${arch}${endian}"-unknown
;;
- *) machine=${UNAME_MACHINE_ARCH}-unknown ;;
+ *) machine="$UNAME_MACHINE_ARCH"-unknown ;;
esac
# The Operating System including object format, if it has switched
# to ELF recently (or will in the future) and ABI.
- case "${UNAME_MACHINE_ARCH}" in
+ case "$UNAME_MACHINE_ARCH" in
earm*)
os=netbsdelf
;;
arm*|i386|m68k|ns32k|sh3*|sparc|vax)
- eval $set_cc_for_build
+ eval "$set_cc_for_build"
if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \
| grep -q __ELF__
then
@@ -208,10 +215,10 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
;;
esac
# Determine ABI tags.
- case "${UNAME_MACHINE_ARCH}" in
+ case "$UNAME_MACHINE_ARCH" in
earm*)
expr='s/^earmv[0-9]/-eabi/;s/eb$//'
- abi=`echo ${UNAME_MACHINE_ARCH} | sed -e "$expr"`
+ abi=`echo "$UNAME_MACHINE_ARCH" | sed -e "$expr"`
;;
esac
# The OS release
@@ -219,46 +226,55 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
# thus, need a distinct triplet. However, they do not need
# kernel version information, so it can be replaced with a
# suitable tag, in the style of linux-gnu.
- case "${UNAME_VERSION}" in
+ case "$UNAME_VERSION" in
Debian*)
release='-gnu'
;;
*)
- release=`echo ${UNAME_RELEASE} | sed -e 's/[-_].*//' | cut -d. -f1,2`
+ release=`echo "$UNAME_RELEASE" | sed -e 's/[-_].*//' | cut -d. -f1,2`
;;
esac
# Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM:
# contains redundant information, the shorter form:
# CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used.
- echo "${machine}-${os}${release}${abi}"
+ echo "$machine-${os}${release}${abi}"
exit ;;
*:Bitrig:*:*)
UNAME_MACHINE_ARCH=`arch | sed 's/Bitrig.//'`
- echo ${UNAME_MACHINE_ARCH}-unknown-bitrig${UNAME_RELEASE}
+ echo "$UNAME_MACHINE_ARCH"-unknown-bitrig"$UNAME_RELEASE"
exit ;;
*:OpenBSD:*:*)
UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'`
- echo ${UNAME_MACHINE_ARCH}-unknown-openbsd${UNAME_RELEASE}
+ echo "$UNAME_MACHINE_ARCH"-unknown-openbsd"$UNAME_RELEASE"
exit ;;
*:LibertyBSD:*:*)
UNAME_MACHINE_ARCH=`arch | sed 's/^.*BSD\.//'`
- echo ${UNAME_MACHINE_ARCH}-unknown-libertybsd${UNAME_RELEASE}
+ echo "$UNAME_MACHINE_ARCH"-unknown-libertybsd"$UNAME_RELEASE"
+ exit ;;
+ *:MidnightBSD:*:*)
+ echo "$UNAME_MACHINE"-unknown-midnightbsd"$UNAME_RELEASE"
exit ;;
*:ekkoBSD:*:*)
- echo ${UNAME_MACHINE}-unknown-ekkobsd${UNAME_RELEASE}
+ echo "$UNAME_MACHINE"-unknown-ekkobsd"$UNAME_RELEASE"
exit ;;
*:SolidBSD:*:*)
- echo ${UNAME_MACHINE}-unknown-solidbsd${UNAME_RELEASE}
+ echo "$UNAME_MACHINE"-unknown-solidbsd"$UNAME_RELEASE"
exit ;;
macppc:MirBSD:*:*)
- echo powerpc-unknown-mirbsd${UNAME_RELEASE}
+ echo powerpc-unknown-mirbsd"$UNAME_RELEASE"
exit ;;
*:MirBSD:*:*)
- echo ${UNAME_MACHINE}-unknown-mirbsd${UNAME_RELEASE}
+ echo "$UNAME_MACHINE"-unknown-mirbsd"$UNAME_RELEASE"
exit ;;
*:Sortix:*:*)
- echo ${UNAME_MACHINE}-unknown-sortix
+ echo "$UNAME_MACHINE"-unknown-sortix
+ exit ;;
+ *:Redox:*:*)
+ echo "$UNAME_MACHINE"-unknown-redox
exit ;;
+ mips:OSF1:*.*)
+ echo mips-dec-osf1
+ exit ;;
alpha:OSF1:*:*)
case $UNAME_RELEASE in
*4.0)
@@ -310,28 +326,19 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
# A Tn.n version is a released field test version.
# A Xn.n version is an unreleased experimental baselevel.
# 1.2 uses "1.2" for uname -r.
- echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[PVTX]//' | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz`
+ echo "$UNAME_MACHINE"-dec-osf"`echo "$UNAME_RELEASE" | sed -e 's/^[PVTX]//' | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz`"
# Reset EXIT trap before exiting to avoid spurious non-zero exit code.
exitcode=$?
trap '' 0
exit $exitcode ;;
- Alpha\ *:Windows_NT*:*)
- # How do we know it's Interix rather than the generic POSIX subsystem?
- # Should we change UNAME_MACHINE based on the output of uname instead
- # of the specific Alpha model?
- echo alpha-pc-interix
- exit ;;
- 21064:Windows_NT:50:3)
- echo alpha-dec-winnt3.5
- exit ;;
Amiga*:UNIX_System_V:4.0:*)
echo m68k-unknown-sysv4
exit ;;
*:[Aa]miga[Oo][Ss]:*:*)
- echo ${UNAME_MACHINE}-unknown-amigaos
+ echo "$UNAME_MACHINE"-unknown-amigaos
exit ;;
*:[Mm]orph[Oo][Ss]:*:*)
- echo ${UNAME_MACHINE}-unknown-morphos
+ echo "$UNAME_MACHINE"-unknown-morphos
exit ;;
*:OS/390:*:*)
echo i370-ibm-openedition
@@ -343,7 +350,7 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
echo powerpc-ibm-os400
exit ;;
arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*)
- echo arm-acorn-riscix${UNAME_RELEASE}
+ echo arm-acorn-riscix"$UNAME_RELEASE"
exit ;;
arm*:riscos:*:*|arm*:RISCOS:*:*)
echo arm-unknown-riscos
@@ -370,19 +377,19 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
sparc) echo sparc-icl-nx7; exit ;;
esac ;;
s390x:SunOS:*:*)
- echo ${UNAME_MACHINE}-ibm-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+ echo "$UNAME_MACHINE"-ibm-solaris2"`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'`"
exit ;;
sun4H:SunOS:5.*:*)
- echo sparc-hal-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+ echo sparc-hal-solaris2"`echo "$UNAME_RELEASE"|sed -e 's/[^.]*//'`"
exit ;;
sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*)
- echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+ echo sparc-sun-solaris2"`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'`"
exit ;;
i86pc:AuroraUX:5.*:* | i86xen:AuroraUX:5.*:*)
- echo i386-pc-auroraux${UNAME_RELEASE}
+ echo i386-pc-auroraux"$UNAME_RELEASE"
exit ;;
i86pc:SunOS:5.*:* | i86xen:SunOS:5.*:*)
- eval $set_cc_for_build
+ eval "$set_cc_for_build"
SUN_ARCH=i386
# If there is a compiler, see if it is configured for 64-bit objects.
# Note that the Sun cc does not turn __LP64__ into 1 like gcc does.
@@ -395,13 +402,13 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
SUN_ARCH=x86_64
fi
fi
- echo ${SUN_ARCH}-pc-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+ echo "$SUN_ARCH"-pc-solaris2"`echo "$UNAME_RELEASE"|sed -e 's/[^.]*//'`"
exit ;;
sun4*:SunOS:6*:*)
# According to config.sub, this is the proper way to canonicalize
# SunOS6. Hard to guess exactly what SunOS6 will be like, but
# it's likely to be more like Solaris than SunOS4.
- echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+ echo sparc-sun-solaris3"`echo "$UNAME_RELEASE"|sed -e 's/[^.]*//'`"
exit ;;
sun4*:SunOS:*:*)
case "`/usr/bin/arch -k`" in
@@ -410,25 +417,25 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
;;
esac
# Japanese Language versions have a version number like `4.1.3-JL'.
- echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'`
+ echo sparc-sun-sunos"`echo "$UNAME_RELEASE"|sed -e 's/-/_/'`"
exit ;;
sun3*:SunOS:*:*)
- echo m68k-sun-sunos${UNAME_RELEASE}
+ echo m68k-sun-sunos"$UNAME_RELEASE"
exit ;;
sun*:*:4.2BSD:*)
UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null`
- test "x${UNAME_RELEASE}" = x && UNAME_RELEASE=3
+ test "x$UNAME_RELEASE" = x && UNAME_RELEASE=3
case "`/bin/arch`" in
sun3)
- echo m68k-sun-sunos${UNAME_RELEASE}
+ echo m68k-sun-sunos"$UNAME_RELEASE"
;;
sun4)
- echo sparc-sun-sunos${UNAME_RELEASE}
+ echo sparc-sun-sunos"$UNAME_RELEASE"
;;
esac
exit ;;
aushp:SunOS:*:*)
- echo sparc-auspex-sunos${UNAME_RELEASE}
+ echo sparc-auspex-sunos"$UNAME_RELEASE"
exit ;;
# The situation for MiNT is a little confusing. The machine name
# can be virtually everything (everything which is not
@@ -439,44 +446,44 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
# MiNT. But MiNT is downward compatible to TOS, so this should
# be no problem.
atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*)
- echo m68k-atari-mint${UNAME_RELEASE}
+ echo m68k-atari-mint"$UNAME_RELEASE"
exit ;;
atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*)
- echo m68k-atari-mint${UNAME_RELEASE}
+ echo m68k-atari-mint"$UNAME_RELEASE"
exit ;;
*falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*)
- echo m68k-atari-mint${UNAME_RELEASE}
+ echo m68k-atari-mint"$UNAME_RELEASE"
exit ;;
milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*)
- echo m68k-milan-mint${UNAME_RELEASE}
+ echo m68k-milan-mint"$UNAME_RELEASE"
exit ;;
hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*)
- echo m68k-hades-mint${UNAME_RELEASE}
+ echo m68k-hades-mint"$UNAME_RELEASE"
exit ;;
*:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*)
- echo m68k-unknown-mint${UNAME_RELEASE}
+ echo m68k-unknown-mint"$UNAME_RELEASE"
exit ;;
m68k:machten:*:*)
- echo m68k-apple-machten${UNAME_RELEASE}
+ echo m68k-apple-machten"$UNAME_RELEASE"
exit ;;
powerpc:machten:*:*)
- echo powerpc-apple-machten${UNAME_RELEASE}
+ echo powerpc-apple-machten"$UNAME_RELEASE"
exit ;;
RISC*:Mach:*:*)
echo mips-dec-mach_bsd4.3
exit ;;
RISC*:ULTRIX:*:*)
- echo mips-dec-ultrix${UNAME_RELEASE}
+ echo mips-dec-ultrix"$UNAME_RELEASE"
exit ;;
VAX*:ULTRIX*:*:*)
- echo vax-dec-ultrix${UNAME_RELEASE}
+ echo vax-dec-ultrix"$UNAME_RELEASE"
exit ;;
2020:CLIX:*:* | 2430:CLIX:*:*)
- echo clipper-intergraph-clix${UNAME_RELEASE}
+ echo clipper-intergraph-clix"$UNAME_RELEASE"
exit ;;
mips:*:*:UMIPS | mips:*:*:RISCos)
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
+ eval "$set_cc_for_build"
+ sed 's/^ //' << EOF > "$dummy.c"
#ifdef __cplusplus
#include <stdio.h> /* for printf() prototype */
int main (int argc, char *argv[]) {
@@ -485,23 +492,23 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
#endif
#if defined (host_mips) && defined (MIPSEB)
#if defined (SYSTYPE_SYSV)
- printf ("mips-mips-riscos%ssysv\n", argv[1]); exit (0);
+ printf ("mips-mips-riscos%ssysv\\n", argv[1]); exit (0);
#endif
#if defined (SYSTYPE_SVR4)
- printf ("mips-mips-riscos%ssvr4\n", argv[1]); exit (0);
+ printf ("mips-mips-riscos%ssvr4\\n", argv[1]); exit (0);
#endif
#if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD)
- printf ("mips-mips-riscos%sbsd\n", argv[1]); exit (0);
+ printf ("mips-mips-riscos%sbsd\\n", argv[1]); exit (0);
#endif
#endif
exit (-1);
}
EOF
- $CC_FOR_BUILD -o $dummy $dummy.c &&
- dummyarg=`echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` &&
- SYSTEM_NAME=`$dummy $dummyarg` &&
+ $CC_FOR_BUILD -o "$dummy" "$dummy.c" &&
+ dummyarg=`echo "$UNAME_RELEASE" | sed -n 's/\([0-9]*\).*/\1/p'` &&
+ SYSTEM_NAME=`"$dummy" "$dummyarg"` &&
{ echo "$SYSTEM_NAME"; exit; }
- echo mips-mips-riscos${UNAME_RELEASE}
+ echo mips-mips-riscos"$UNAME_RELEASE"
exit ;;
Motorola:PowerMAX_OS:*:*)
echo powerpc-motorola-powermax
@@ -527,17 +534,17 @@ EOF
AViiON:dgux:*:*)
# DG/UX returns AViiON for all architectures
UNAME_PROCESSOR=`/usr/bin/uname -p`
- if [ $UNAME_PROCESSOR = mc88100 ] || [ $UNAME_PROCESSOR = mc88110 ]
+ if [ "$UNAME_PROCESSOR" = mc88100 ] || [ "$UNAME_PROCESSOR" = mc88110 ]
then
- if [ ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx ] || \
- [ ${TARGET_BINARY_INTERFACE}x = x ]
+ if [ "$TARGET_BINARY_INTERFACE"x = m88kdguxelfx ] || \
+ [ "$TARGET_BINARY_INTERFACE"x = x ]
then
- echo m88k-dg-dgux${UNAME_RELEASE}
+ echo m88k-dg-dgux"$UNAME_RELEASE"
else
- echo m88k-dg-dguxbcs${UNAME_RELEASE}
+ echo m88k-dg-dguxbcs"$UNAME_RELEASE"
fi
else
- echo i586-dg-dgux${UNAME_RELEASE}
+ echo i586-dg-dgux"$UNAME_RELEASE"
fi
exit ;;
M88*:DolphinOS:*:*) # DolphinOS (SVR3)
@@ -554,7 +561,7 @@ EOF
echo m68k-tektronix-bsd
exit ;;
*:IRIX*:*:*)
- echo mips-sgi-irix`echo ${UNAME_RELEASE}|sed -e 's/-/_/g'`
+ echo mips-sgi-irix"`echo "$UNAME_RELEASE"|sed -e 's/-/_/g'`"
exit ;;
????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX.
echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id
@@ -566,14 +573,14 @@ EOF
if [ -x /usr/bin/oslevel ] ; then
IBM_REV=`/usr/bin/oslevel`
else
- IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
+ IBM_REV="$UNAME_VERSION.$UNAME_RELEASE"
fi
- echo ${UNAME_MACHINE}-ibm-aix${IBM_REV}
+ echo "$UNAME_MACHINE"-ibm-aix"$IBM_REV"
exit ;;
*:AIX:2:3)
if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
+ eval "$set_cc_for_build"
+ sed 's/^ //' << EOF > "$dummy.c"
#include <sys/systemcfg.h>
main()
@@ -584,7 +591,7 @@ EOF
exit(0);
}
EOF
- if $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy`
+ if $CC_FOR_BUILD -o "$dummy" "$dummy.c" && SYSTEM_NAME=`"$dummy"`
then
echo "$SYSTEM_NAME"
else
@@ -598,7 +605,7 @@ EOF
exit ;;
*:AIX:*:[4567])
IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'`
- if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then
+ if /usr/sbin/lsattr -El "$IBM_CPU_ID" | grep ' POWER' >/dev/null 2>&1; then
IBM_ARCH=rs6000
else
IBM_ARCH=powerpc
@@ -607,18 +614,18 @@ EOF
IBM_REV=`/usr/bin/lslpp -Lqc bos.rte.libc |
awk -F: '{ print $3 }' | sed s/[0-9]*$/0/`
else
- IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
+ IBM_REV="$UNAME_VERSION.$UNAME_RELEASE"
fi
- echo ${IBM_ARCH}-ibm-aix${IBM_REV}
+ echo "$IBM_ARCH"-ibm-aix"$IBM_REV"
exit ;;
*:AIX:*:*)
echo rs6000-ibm-aix
exit ;;
- ibmrt:4.4BSD:*|romp-ibm:BSD:*)
+ ibmrt:4.4BSD:*|romp-ibm:4.4BSD:*)
echo romp-ibm-bsd4.4
exit ;;
ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC BSD and
- echo romp-ibm-bsd${UNAME_RELEASE} # 4.3 with uname added to
+ echo romp-ibm-bsd"$UNAME_RELEASE" # 4.3 with uname added to
exit ;; # report: romp-ibm BSD 4.3
*:BOSX:*:*)
echo rs6000-bull-bosx
@@ -633,28 +640,28 @@ EOF
echo m68k-hp-bsd4.4
exit ;;
9000/[34678]??:HP-UX:*:*)
- HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
- case "${UNAME_MACHINE}" in
- 9000/31? ) HP_ARCH=m68000 ;;
- 9000/[34]?? ) HP_ARCH=m68k ;;
+ HPUX_REV=`echo "$UNAME_RELEASE"|sed -e 's/[^.]*.[0B]*//'`
+ case "$UNAME_MACHINE" in
+ 9000/31?) HP_ARCH=m68000 ;;
+ 9000/[34]??) HP_ARCH=m68k ;;
9000/[678][0-9][0-9])
if [ -x /usr/bin/getconf ]; then
sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null`
sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null`
- case "${sc_cpu_version}" in
+ case "$sc_cpu_version" in
523) HP_ARCH=hppa1.0 ;; # CPU_PA_RISC1_0
528) HP_ARCH=hppa1.1 ;; # CPU_PA_RISC1_1
532) # CPU_PA_RISC2_0
- case "${sc_kernel_bits}" in
+ case "$sc_kernel_bits" in
32) HP_ARCH=hppa2.0n ;;
64) HP_ARCH=hppa2.0w ;;
'') HP_ARCH=hppa2.0 ;; # HP-UX 10.20
esac ;;
esac
fi
- if [ "${HP_ARCH}" = "" ]; then
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
+ if [ "$HP_ARCH" = "" ]; then
+ eval "$set_cc_for_build"
+ sed 's/^ //' << EOF > "$dummy.c"
#define _HPUX_SOURCE
#include <stdlib.h>
@@ -687,13 +694,13 @@ EOF
exit (0);
}
EOF
- (CCOPTS="" $CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null) && HP_ARCH=`$dummy`
+ (CCOPTS="" $CC_FOR_BUILD -o "$dummy" "$dummy.c" 2>/dev/null) && HP_ARCH=`"$dummy"`
test -z "$HP_ARCH" && HP_ARCH=hppa
fi ;;
esac
- if [ ${HP_ARCH} = hppa2.0w ]
+ if [ "$HP_ARCH" = hppa2.0w ]
then
- eval $set_cc_for_build
+ eval "$set_cc_for_build"
# hppa2.0w-hp-hpux* has a 64-bit kernel and a compiler generating
# 32-bit code. hppa64-hp-hpux* has the same kernel and a compiler
@@ -712,15 +719,15 @@ EOF
HP_ARCH=hppa64
fi
fi
- echo ${HP_ARCH}-hp-hpux${HPUX_REV}
+ echo "$HP_ARCH"-hp-hpux"$HPUX_REV"
exit ;;
ia64:HP-UX:*:*)
- HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
- echo ia64-hp-hpux${HPUX_REV}
+ HPUX_REV=`echo "$UNAME_RELEASE"|sed -e 's/[^.]*.[0B]*//'`
+ echo ia64-hp-hpux"$HPUX_REV"
exit ;;
3050*:HI-UX:*:*)
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
+ eval "$set_cc_for_build"
+ sed 's/^ //' << EOF > "$dummy.c"
#include <unistd.h>
int
main ()
@@ -745,11 +752,11 @@ EOF
exit (0);
}
EOF
- $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` &&
+ $CC_FOR_BUILD -o "$dummy" "$dummy.c" && SYSTEM_NAME=`"$dummy"` &&
{ echo "$SYSTEM_NAME"; exit; }
echo unknown-hitachi-hiuxwe2
exit ;;
- 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:* )
+ 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:*)
echo hppa1.1-hp-bsd
exit ;;
9000/8??:4.3bsd:*:*)
@@ -758,7 +765,7 @@ EOF
*9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*)
echo hppa1.0-hp-mpeix
exit ;;
- hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* )
+ hp7??:OSF1:*:* | hp8?[79]:OSF1:*:*)
echo hppa1.1-hp-osf
exit ;;
hp8??:OSF1:*:*)
@@ -766,9 +773,9 @@ EOF
exit ;;
i*86:OSF1:*:*)
if [ -x /usr/sbin/sysversion ] ; then
- echo ${UNAME_MACHINE}-unknown-osf1mk
+ echo "$UNAME_MACHINE"-unknown-osf1mk
else
- echo ${UNAME_MACHINE}-unknown-osf1
+ echo "$UNAME_MACHINE"-unknown-osf1
fi
exit ;;
parisc*:Lites*:*:*)
@@ -793,128 +800,109 @@ EOF
echo c4-convex-bsd
exit ;;
CRAY*Y-MP:*:*:*)
- echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
+ echo ymp-cray-unicos"$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'
exit ;;
CRAY*[A-Z]90:*:*:*)
- echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \
+ echo "$UNAME_MACHINE"-cray-unicos"$UNAME_RELEASE" \
| sed -e 's/CRAY.*\([A-Z]90\)/\1/' \
-e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \
-e 's/\.[^.]*$/.X/'
exit ;;
CRAY*TS:*:*:*)
- echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
+ echo t90-cray-unicos"$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'
exit ;;
CRAY*T3E:*:*:*)
- echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
+ echo alphaev5-cray-unicosmk"$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'
exit ;;
CRAY*SV1:*:*:*)
- echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
+ echo sv1-cray-unicos"$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'
exit ;;
*:UNICOS/mp:*:*)
- echo craynv-cray-unicosmp${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
+ echo craynv-cray-unicosmp"$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'
exit ;;
F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*)
FUJITSU_PROC=`uname -m | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz`
FUJITSU_SYS=`uname -p | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz | sed -e 's/\///'`
- FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'`
+ FUJITSU_REL=`echo "$UNAME_RELEASE" | sed -e 's/ /_/'`
echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}"
exit ;;
5000:UNIX_System_V:4.*:*)
FUJITSU_SYS=`uname -p | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz | sed -e 's/\///'`
- FUJITSU_REL=`echo ${UNAME_RELEASE} | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz | sed -e 's/ /_/'`
+ FUJITSU_REL=`echo "$UNAME_RELEASE" | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz | sed -e 's/ /_/'`
echo "sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}"
exit ;;
i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*)
- echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE}
+ echo "$UNAME_MACHINE"-pc-bsdi"$UNAME_RELEASE"
exit ;;
sparc*:BSD/OS:*:*)
- echo sparc-unknown-bsdi${UNAME_RELEASE}
+ echo sparc-unknown-bsdi"$UNAME_RELEASE"
exit ;;
*:BSD/OS:*:*)
- echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE}
+ echo "$UNAME_MACHINE"-unknown-bsdi"$UNAME_RELEASE"
exit ;;
*:FreeBSD:*:*)
UNAME_PROCESSOR=`/usr/bin/uname -p`
- case ${UNAME_PROCESSOR} in
+ case "$UNAME_PROCESSOR" in
amd64)
UNAME_PROCESSOR=x86_64 ;;
i386)
UNAME_PROCESSOR=i586 ;;
esac
- echo ${UNAME_PROCESSOR}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`
+ echo "$UNAME_PROCESSOR"-unknown-freebsd"`echo "$UNAME_RELEASE"|sed -e 's/[-(].*//'`"
exit ;;
i*:CYGWIN*:*)
- echo ${UNAME_MACHINE}-pc-cygwin
+ echo "$UNAME_MACHINE"-pc-cygwin
exit ;;
*:MINGW64*:*)
- echo ${UNAME_MACHINE}-pc-mingw64
+ echo "$UNAME_MACHINE"-pc-mingw64
exit ;;
*:MINGW*:*)
- echo ${UNAME_MACHINE}-pc-mingw32
+ echo "$UNAME_MACHINE"-pc-mingw32
exit ;;
*:MSYS*:*)
- echo ${UNAME_MACHINE}-pc-msys
- exit ;;
- i*:windows32*:*)
- # uname -m includes "-pc" on this system.
- echo ${UNAME_MACHINE}-mingw32
+ echo "$UNAME_MACHINE"-pc-msys
exit ;;
i*:PW*:*)
- echo ${UNAME_MACHINE}-pc-pw32
+ echo "$UNAME_MACHINE"-pc-pw32
exit ;;
*:Interix*:*)
- case ${UNAME_MACHINE} in
+ case "$UNAME_MACHINE" in
x86)
- echo i586-pc-interix${UNAME_RELEASE}
+ echo i586-pc-interix"$UNAME_RELEASE"
exit ;;
authenticamd | genuineintel | EM64T)
- echo x86_64-unknown-interix${UNAME_RELEASE}
+ echo x86_64-unknown-interix"$UNAME_RELEASE"
exit ;;
IA64)
- echo ia64-unknown-interix${UNAME_RELEASE}
+ echo ia64-unknown-interix"$UNAME_RELEASE"
exit ;;
esac ;;
- [345]86:Windows_95:* | [345]86:Windows_98:* | [345]86:Windows_NT:*)
- echo i${UNAME_MACHINE}-pc-mks
- exit ;;
- 8664:Windows_NT:*)
- echo x86_64-pc-mks
- exit ;;
- i*:Windows_NT*:* | Pentium*:Windows_NT*:*)
- # How do we know it's Interix rather than the generic POSIX subsystem?
- # It also conflicts with pre-2.0 versions of AT&T UWIN. Should we
- # UNAME_MACHINE based on the output of uname instead of i386?
- echo i586-pc-interix
- exit ;;
i*:UWIN*:*)
- echo ${UNAME_MACHINE}-pc-uwin
+ echo "$UNAME_MACHINE"-pc-uwin
exit ;;
amd64:CYGWIN*:*:* | x86_64:CYGWIN*:*:*)
echo x86_64-unknown-cygwin
exit ;;
- p*:CYGWIN*:*)
- echo powerpcle-unknown-cygwin
- exit ;;
prep*:SunOS:5.*:*)
- echo powerpcle-unknown-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+ echo powerpcle-unknown-solaris2"`echo "$UNAME_RELEASE"|sed -e 's/[^.]*//'`"
exit ;;
*:GNU:*:*)
# the GNU system
- echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-${LIBC}`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'`
+ echo "`echo "$UNAME_MACHINE"|sed -e 's,[-/].*$,,'`-unknown-$LIBC`echo "$UNAME_RELEASE"|sed -e 's,/.*$,,'`"
exit ;;
*:GNU/*:*:*)
# other systems with GNU libc and userland
- echo ${UNAME_MACHINE}-unknown-`echo ${UNAME_SYSTEM} | sed 's,^[^/]*/,,' | tr "[:upper:]" "[:lower:]"``echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`-${LIBC}
+ echo "$UNAME_MACHINE-unknown-`echo "$UNAME_SYSTEM" | sed 's,^[^/]*/,,' | tr "[:upper:]" "[:lower:]"``echo "$UNAME_RELEASE"|sed -e 's/[-(].*//'`-$LIBC"
exit ;;
i*86:Minix:*:*)
- echo ${UNAME_MACHINE}-pc-minix
+ echo "$UNAME_MACHINE"-pc-minix
exit ;;
aarch64:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
aarch64_be:Linux:*:*)
UNAME_MACHINE=aarch64_be
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
alpha:Linux:*:*)
case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in
@@ -928,63 +916,63 @@ EOF
esac
objdump --private-headers /bin/sh | grep -q ld.so.1
if test "$?" = 0 ; then LIBC=gnulibc1 ; fi
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
arc:Linux:*:* | arceb:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
arm*:Linux:*:*)
- eval $set_cc_for_build
+ eval "$set_cc_for_build"
if echo __ARM_EABI__ | $CC_FOR_BUILD -E - 2>/dev/null \
| grep -q __ARM_EABI__
then
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
else
if echo __ARM_PCS_VFP | $CC_FOR_BUILD -E - 2>/dev/null \
| grep -q __ARM_PCS_VFP
then
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}eabi
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"eabi
else
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}eabihf
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"eabihf
fi
fi
exit ;;
avr32*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
cris:Linux:*:*)
- echo ${UNAME_MACHINE}-axis-linux-${LIBC}
+ echo "$UNAME_MACHINE"-axis-linux-"$LIBC"
exit ;;
crisv32:Linux:*:*)
- echo ${UNAME_MACHINE}-axis-linux-${LIBC}
+ echo "$UNAME_MACHINE"-axis-linux-"$LIBC"
exit ;;
e2k:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
frv:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
hexagon:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
i*86:Linux:*:*)
- echo ${UNAME_MACHINE}-pc-linux-${LIBC}
+ echo "$UNAME_MACHINE"-pc-linux-"$LIBC"
exit ;;
ia64:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
k1om:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
m32r*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
m68*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
mips:Linux:*:* | mips64:Linux:*:*)
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
+ eval "$set_cc_for_build"
+ sed 's/^ //' << EOF > "$dummy.c"
#undef CPU
#undef ${UNAME_MACHINE}
#undef ${UNAME_MACHINE}el
@@ -998,70 +986,70 @@ EOF
#endif
#endif
EOF
- eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^CPU'`
- test x"${CPU}" != x && { echo "${CPU}-unknown-linux-${LIBC}"; exit; }
+ eval "`$CC_FOR_BUILD -E "$dummy.c" 2>/dev/null | grep '^CPU'`"
+ test "x$CPU" != x && { echo "$CPU-unknown-linux-$LIBC"; exit; }
;;
mips64el:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
openrisc*:Linux:*:*)
- echo or1k-unknown-linux-${LIBC}
+ echo or1k-unknown-linux-"$LIBC"
exit ;;
or32:Linux:*:* | or1k*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
padre:Linux:*:*)
- echo sparc-unknown-linux-${LIBC}
+ echo sparc-unknown-linux-"$LIBC"
exit ;;
parisc64:Linux:*:* | hppa64:Linux:*:*)
- echo hppa64-unknown-linux-${LIBC}
+ echo hppa64-unknown-linux-"$LIBC"
exit ;;
parisc:Linux:*:* | hppa:Linux:*:*)
# Look for CPU level
case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in
- PA7*) echo hppa1.1-unknown-linux-${LIBC} ;;
- PA8*) echo hppa2.0-unknown-linux-${LIBC} ;;
- *) echo hppa-unknown-linux-${LIBC} ;;
+ PA7*) echo hppa1.1-unknown-linux-"$LIBC" ;;
+ PA8*) echo hppa2.0-unknown-linux-"$LIBC" ;;
+ *) echo hppa-unknown-linux-"$LIBC" ;;
esac
exit ;;
ppc64:Linux:*:*)
- echo powerpc64-unknown-linux-${LIBC}
+ echo powerpc64-unknown-linux-"$LIBC"
exit ;;
ppc:Linux:*:*)
- echo powerpc-unknown-linux-${LIBC}
+ echo powerpc-unknown-linux-"$LIBC"
exit ;;
ppc64le:Linux:*:*)
- echo powerpc64le-unknown-linux-${LIBC}
+ echo powerpc64le-unknown-linux-"$LIBC"
exit ;;
ppcle:Linux:*:*)
- echo powerpcle-unknown-linux-${LIBC}
+ echo powerpcle-unknown-linux-"$LIBC"
exit ;;
riscv32:Linux:*:* | riscv64:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
s390:Linux:*:* | s390x:Linux:*:*)
- echo ${UNAME_MACHINE}-ibm-linux-${LIBC}
+ echo "$UNAME_MACHINE"-ibm-linux-"$LIBC"
exit ;;
sh64*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
sh*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
sparc:Linux:*:* | sparc64:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
tile*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
vax:Linux:*:*)
- echo ${UNAME_MACHINE}-dec-linux-${LIBC}
+ echo "$UNAME_MACHINE"-dec-linux-"$LIBC"
exit ;;
x86_64:Linux:*:*)
- echo ${UNAME_MACHINE}-pc-linux-${LIBC}
+ echo "$UNAME_MACHINE"-pc-linux-"$LIBC"
exit ;;
xtensa*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
i*86:DYNIX/ptx:4*:*)
# ptx 4.0 does uname -s correctly, with DYNIX/ptx in there.
@@ -1075,34 +1063,34 @@ EOF
# I am not positive that other SVR4 systems won't match this,
# I just have to hope. -- rms.
# Use sysv4.2uw... so that sysv4* matches it.
- echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION}
+ echo "$UNAME_MACHINE"-pc-sysv4.2uw"$UNAME_VERSION"
exit ;;
i*86:OS/2:*:*)
# If we were able to find `uname', then EMX Unix compatibility
# is probably installed.
- echo ${UNAME_MACHINE}-pc-os2-emx
+ echo "$UNAME_MACHINE"-pc-os2-emx
exit ;;
i*86:XTS-300:*:STOP)
- echo ${UNAME_MACHINE}-unknown-stop
+ echo "$UNAME_MACHINE"-unknown-stop
exit ;;
i*86:atheos:*:*)
- echo ${UNAME_MACHINE}-unknown-atheos
+ echo "$UNAME_MACHINE"-unknown-atheos
exit ;;
i*86:syllable:*:*)
- echo ${UNAME_MACHINE}-pc-syllable
+ echo "$UNAME_MACHINE"-pc-syllable
exit ;;
i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.[02]*:*)
- echo i386-unknown-lynxos${UNAME_RELEASE}
+ echo i386-unknown-lynxos"$UNAME_RELEASE"
exit ;;
i*86:*DOS:*:*)
- echo ${UNAME_MACHINE}-pc-msdosdjgpp
+ echo "$UNAME_MACHINE"-pc-msdosdjgpp
exit ;;
- i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*)
- UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'`
+ i*86:*:4.*:*)
+ UNAME_REL=`echo "$UNAME_RELEASE" | sed 's/\/MP$//'`
if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then
- echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL}
+ echo "$UNAME_MACHINE"-univel-sysv"$UNAME_REL"
else
- echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL}
+ echo "$UNAME_MACHINE"-pc-sysv"$UNAME_REL"
fi
exit ;;
i*86:*:5:[678]*)
@@ -1112,12 +1100,12 @@ EOF
*Pentium) UNAME_MACHINE=i586 ;;
*Pent*|*Celeron) UNAME_MACHINE=i686 ;;
esac
- echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION}
+ echo "$UNAME_MACHINE-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}{$UNAME_VERSION}"
exit ;;
i*86:*:3.2:*)
if test -f /usr/options/cb.name; then
UNAME_REL=`sed -n 's/.*Version //p' </usr/options/cb.name`
- echo ${UNAME_MACHINE}-pc-isc$UNAME_REL
+ echo "$UNAME_MACHINE"-pc-isc"$UNAME_REL"
elif /bin/uname -X 2>/dev/null >/dev/null ; then
UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')`
(/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486
@@ -1127,9 +1115,9 @@ EOF
&& UNAME_MACHINE=i686
(/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \
&& UNAME_MACHINE=i686
- echo ${UNAME_MACHINE}-pc-sco$UNAME_REL
+ echo "$UNAME_MACHINE"-pc-sco"$UNAME_REL"
else
- echo ${UNAME_MACHINE}-pc-sysv32
+ echo "$UNAME_MACHINE"-pc-sysv32
fi
exit ;;
pc:*:*:*)
@@ -1149,9 +1137,9 @@ EOF
exit ;;
i860:*:4.*:*) # i860-SVR4
if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then
- echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4
+ echo i860-stardent-sysv"$UNAME_RELEASE" # Stardent Vistra i860-SVR4
else # Add other i860-SVR4 vendors below as they are discovered.
- echo i860-unknown-sysv${UNAME_RELEASE} # Unknown i860-SVR4
+ echo i860-unknown-sysv"$UNAME_RELEASE" # Unknown i860-SVR4
fi
exit ;;
mini*:CTIX:SYS*5:*)
@@ -1171,9 +1159,9 @@ EOF
test -r /etc/.relid \
&& OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid`
/bin/uname -p 2>/dev/null | grep 86 >/dev/null \
- && { echo i486-ncr-sysv4.3${OS_REL}; exit; }
+ && { echo i486-ncr-sysv4.3"$OS_REL"; exit; }
/bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \
- && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;;
+ && { echo i586-ncr-sysv4.3"$OS_REL"; exit; } ;;
3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*)
/bin/uname -p 2>/dev/null | grep 86 >/dev/null \
&& { echo i486-ncr-sysv4; exit; } ;;
@@ -1182,28 +1170,28 @@ EOF
test -r /etc/.relid \
&& OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid`
/bin/uname -p 2>/dev/null | grep 86 >/dev/null \
- && { echo i486-ncr-sysv4.3${OS_REL}; exit; }
+ && { echo i486-ncr-sysv4.3"$OS_REL"; exit; }
/bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \
- && { echo i586-ncr-sysv4.3${OS_REL}; exit; }
+ && { echo i586-ncr-sysv4.3"$OS_REL"; exit; }
/bin/uname -p 2>/dev/null | /bin/grep pteron >/dev/null \
- && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;;
+ && { echo i586-ncr-sysv4.3"$OS_REL"; exit; } ;;
m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*)
- echo m68k-unknown-lynxos${UNAME_RELEASE}
+ echo m68k-unknown-lynxos"$UNAME_RELEASE"
exit ;;
mc68030:UNIX_System_V:4.*:*)
echo m68k-atari-sysv4
exit ;;
TSUNAMI:LynxOS:2.*:*)
- echo sparc-unknown-lynxos${UNAME_RELEASE}
+ echo sparc-unknown-lynxos"$UNAME_RELEASE"
exit ;;
rs6000:LynxOS:2.*:*)
- echo rs6000-unknown-lynxos${UNAME_RELEASE}
+ echo rs6000-unknown-lynxos"$UNAME_RELEASE"
exit ;;
PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.[02]*:*)
- echo powerpc-unknown-lynxos${UNAME_RELEASE}
+ echo powerpc-unknown-lynxos"$UNAME_RELEASE"
exit ;;
SM[BE]S:UNIX_SV:*:*)
- echo mips-dde-sysv${UNAME_RELEASE}
+ echo mips-dde-sysv"$UNAME_RELEASE"
exit ;;
RM*:ReliantUNIX-*:*:*)
echo mips-sni-sysv4
@@ -1214,7 +1202,7 @@ EOF
*:SINIX-*:*:*)
if uname -p 2>/dev/null >/dev/null ; then
UNAME_MACHINE=`(uname -p) 2>/dev/null`
- echo ${UNAME_MACHINE}-sni-sysv4
+ echo "$UNAME_MACHINE"-sni-sysv4
else
echo ns32k-sni-sysv
fi
@@ -1234,23 +1222,23 @@ EOF
exit ;;
i*86:VOS:*:*)
# From Paul.Green@stratus.com.
- echo ${UNAME_MACHINE}-stratus-vos
+ echo "$UNAME_MACHINE"-stratus-vos
exit ;;
*:VOS:*:*)
# From Paul.Green@stratus.com.
echo hppa1.1-stratus-vos
exit ;;
mc68*:A/UX:*:*)
- echo m68k-apple-aux${UNAME_RELEASE}
+ echo m68k-apple-aux"$UNAME_RELEASE"
exit ;;
news*:NEWS-OS:6*:*)
echo mips-sony-newsos6
exit ;;
R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*)
if [ -d /usr/nec ]; then
- echo mips-nec-sysv${UNAME_RELEASE}
+ echo mips-nec-sysv"$UNAME_RELEASE"
else
- echo mips-unknown-sysv${UNAME_RELEASE}
+ echo mips-unknown-sysv"$UNAME_RELEASE"
fi
exit ;;
BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only.
@@ -1269,39 +1257,39 @@ EOF
echo x86_64-unknown-haiku
exit ;;
SX-4:SUPER-UX:*:*)
- echo sx4-nec-superux${UNAME_RELEASE}
+ echo sx4-nec-superux"$UNAME_RELEASE"
exit ;;
SX-5:SUPER-UX:*:*)
- echo sx5-nec-superux${UNAME_RELEASE}
+ echo sx5-nec-superux"$UNAME_RELEASE"
exit ;;
SX-6:SUPER-UX:*:*)
- echo sx6-nec-superux${UNAME_RELEASE}
+ echo sx6-nec-superux"$UNAME_RELEASE"
exit ;;
SX-7:SUPER-UX:*:*)
- echo sx7-nec-superux${UNAME_RELEASE}
+ echo sx7-nec-superux"$UNAME_RELEASE"
exit ;;
SX-8:SUPER-UX:*:*)
- echo sx8-nec-superux${UNAME_RELEASE}
+ echo sx8-nec-superux"$UNAME_RELEASE"
exit ;;
SX-8R:SUPER-UX:*:*)
- echo sx8r-nec-superux${UNAME_RELEASE}
+ echo sx8r-nec-superux"$UNAME_RELEASE"
exit ;;
SX-ACE:SUPER-UX:*:*)
- echo sxace-nec-superux${UNAME_RELEASE}
+ echo sxace-nec-superux"$UNAME_RELEASE"
exit ;;
Power*:Rhapsody:*:*)
- echo powerpc-apple-rhapsody${UNAME_RELEASE}
+ echo powerpc-apple-rhapsody"$UNAME_RELEASE"
exit ;;
*:Rhapsody:*:*)
- echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE}
+ echo "$UNAME_MACHINE"-apple-rhapsody"$UNAME_RELEASE"
exit ;;
*:Darwin:*:*)
UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown
- eval $set_cc_for_build
+ eval "$set_cc_for_build"
if test "$UNAME_PROCESSOR" = unknown ; then
UNAME_PROCESSOR=powerpc
fi
- if test `echo "$UNAME_RELEASE" | sed -e 's/\..*//'` -le 10 ; then
+ if test "`echo "$UNAME_RELEASE" | sed -e 's/\..*//'`" -le 10 ; then
if [ "$CC_FOR_BUILD" != no_compiler_found ]; then
if (echo '#ifdef __LP64__'; echo IS_64BIT_ARCH; echo '#endif') | \
(CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) | \
@@ -1329,7 +1317,7 @@ EOF
# that Apple uses in portable devices.
UNAME_PROCESSOR=x86_64
fi
- echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE}
+ echo "$UNAME_PROCESSOR"-apple-darwin"$UNAME_RELEASE"
exit ;;
*:procnto*:*:* | *:QNX:[0123456789]*:*)
UNAME_PROCESSOR=`uname -p`
@@ -1337,22 +1325,25 @@ EOF
UNAME_PROCESSOR=i386
UNAME_MACHINE=pc
fi
- echo ${UNAME_PROCESSOR}-${UNAME_MACHINE}-nto-qnx${UNAME_RELEASE}
+ echo "$UNAME_PROCESSOR"-"$UNAME_MACHINE"-nto-qnx"$UNAME_RELEASE"
exit ;;
*:QNX:*:4*)
echo i386-pc-qnx
exit ;;
NEO-*:NONSTOP_KERNEL:*:*)
- echo neo-tandem-nsk${UNAME_RELEASE}
+ echo neo-tandem-nsk"$UNAME_RELEASE"
exit ;;
NSE-*:NONSTOP_KERNEL:*:*)
- echo nse-tandem-nsk${UNAME_RELEASE}
+ echo nse-tandem-nsk"$UNAME_RELEASE"
exit ;;
NSR-*:NONSTOP_KERNEL:*:*)
- echo nsr-tandem-nsk${UNAME_RELEASE}
+ echo nsr-tandem-nsk"$UNAME_RELEASE"
+ exit ;;
+ NSV-*:NONSTOP_KERNEL:*:*)
+ echo nsv-tandem-nsk"$UNAME_RELEASE"
exit ;;
NSX-*:NONSTOP_KERNEL:*:*)
- echo nsx-tandem-nsk${UNAME_RELEASE}
+ echo nsx-tandem-nsk"$UNAME_RELEASE"
exit ;;
*:NonStop-UX:*:*)
echo mips-compaq-nonstopux
@@ -1361,7 +1352,7 @@ EOF
echo bs2000-siemens-sysv
exit ;;
DS/*:UNIX_System_V:*:*)
- echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE}
+ echo "$UNAME_MACHINE"-"$UNAME_SYSTEM"-"$UNAME_RELEASE"
exit ;;
*:Plan9:*:*)
# "uname -m" is not consistent, so use $cputype instead. 386
@@ -1372,7 +1363,7 @@ EOF
else
UNAME_MACHINE="$cputype"
fi
- echo ${UNAME_MACHINE}-unknown-plan9
+ echo "$UNAME_MACHINE"-unknown-plan9
exit ;;
*:TOPS-10:*:*)
echo pdp10-unknown-tops10
@@ -1393,14 +1384,14 @@ EOF
echo pdp10-unknown-its
exit ;;
SEI:*:*:SEIUX)
- echo mips-sei-seiux${UNAME_RELEASE}
+ echo mips-sei-seiux"$UNAME_RELEASE"
exit ;;
*:DragonFly:*:*)
- echo ${UNAME_MACHINE}-unknown-dragonfly`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`
+ echo "$UNAME_MACHINE"-unknown-dragonfly"`echo "$UNAME_RELEASE"|sed -e 's/[-(].*//'`"
exit ;;
*:*VMS:*:*)
UNAME_MACHINE=`(uname -p) 2>/dev/null`
- case "${UNAME_MACHINE}" in
+ case "$UNAME_MACHINE" in
A*) echo alpha-dec-vms ; exit ;;
I*) echo ia64-dec-vms ; exit ;;
V*) echo vax-dec-vms ; exit ;;
@@ -1409,32 +1400,44 @@ EOF
echo i386-pc-xenix
exit ;;
i*86:skyos:*:*)
- echo ${UNAME_MACHINE}-pc-skyos`echo ${UNAME_RELEASE} | sed -e 's/ .*$//'`
+ echo "$UNAME_MACHINE"-pc-skyos"`echo "$UNAME_RELEASE" | sed -e 's/ .*$//'`"
exit ;;
i*86:rdos:*:*)
- echo ${UNAME_MACHINE}-pc-rdos
+ echo "$UNAME_MACHINE"-pc-rdos
exit ;;
i*86:AROS:*:*)
- echo ${UNAME_MACHINE}-pc-aros
+ echo "$UNAME_MACHINE"-pc-aros
exit ;;
x86_64:VMkernel:*:*)
- echo ${UNAME_MACHINE}-unknown-esx
+ echo "$UNAME_MACHINE"-unknown-esx
exit ;;
amd64:Isilon\ OneFS:*:*)
echo x86_64-unknown-onefs
exit ;;
esac
+echo "$0: unable to guess system type" >&2
+
+case "$UNAME_MACHINE:$UNAME_SYSTEM" in
+ mips:Linux | mips64:Linux)
+ # If we got here on MIPS GNU/Linux, output extra information.
+ cat >&2 <<EOF
+
+NOTE: MIPS GNU/Linux systems require a C compiler to fully recognize
+the system type. Please install a C compiler and try again.
+EOF
+ ;;
+esac
+
cat >&2 <<EOF
-$0: unable to guess system type
This script (version $timestamp), has failed to recognize the
-operating system you are using. If your script is old, overwrite
-config.guess and config.sub with the latest versions from:
+operating system you are using. If your script is old, overwrite *all*
+copies of config.guess and config.sub with the latest versions from:
- http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess
+ https://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess
and
- http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub
+ https://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub
If $0 has already been updated, send the following data and any
information you think might be pertinent to config-patches@gnu.org to
@@ -1457,16 +1460,16 @@ hostinfo = `(hostinfo) 2>/dev/null`
/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null`
/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null`
-UNAME_MACHINE = ${UNAME_MACHINE}
-UNAME_RELEASE = ${UNAME_RELEASE}
-UNAME_SYSTEM = ${UNAME_SYSTEM}
-UNAME_VERSION = ${UNAME_VERSION}
+UNAME_MACHINE = "$UNAME_MACHINE"
+UNAME_RELEASE = "$UNAME_RELEASE"
+UNAME_SYSTEM = "$UNAME_SYSTEM"
+UNAME_VERSION = "$UNAME_VERSION"
EOF
exit 1
# Local variables:
-# eval: (add-hook 'write-file-hooks 'time-stamp)
+# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "timestamp='"
# time-stamp-format: "%:y-%02m-%02d"
# time-stamp-end: "'"
diff --git a/jpeg/config.sub b/jpeg/config.sub
index 40ea5dfe..9ccf09a7 100755
--- a/jpeg/config.sub
+++ b/jpeg/config.sub
@@ -1,8 +1,8 @@
#! /bin/sh
# Configuration validation subroutine script.
-# Copyright 1992-2017 Free Software Foundation, Inc.
+# Copyright 1992-2018 Free Software Foundation, Inc.
-timestamp='2017-04-02'
+timestamp='2018-03-08'
# This file is free software; you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by
@@ -15,7 +15,7 @@ timestamp='2017-04-02'
# General Public License for more details.
#
# You should have received a copy of the GNU General Public License
-# along with this program; if not, see <http://www.gnu.org/licenses/>.
+# along with this program; if not, see <https://www.gnu.org/licenses/>.
#
# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
@@ -33,7 +33,7 @@ timestamp='2017-04-02'
# Otherwise, we print the canonical config type on stdout and succeed.
# You can get the latest version of this script from:
-# http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub
+# https://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub
# This file is supposed to be the same for all GNU packages
# and recognize all the CPU types, system types and aliases
@@ -57,7 +57,7 @@ Usage: $0 [OPTION] CPU-MFR-OPSYS or ALIAS
Canonicalize a configuration name.
-Operation modes:
+Options:
-h, --help print this help, then exit
-t, --time-stamp print date of last modification, then exit
-v, --version print version number, then exit
@@ -67,7 +67,7 @@ Report bugs and patches to <config-patches@gnu.org>."
version="\
GNU config.sub ($timestamp)
-Copyright 1992-2017 Free Software Foundation, Inc.
+Copyright 1992-2018 Free Software Foundation, Inc.
This is free software; see the source for copying conditions. There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
@@ -94,7 +94,7 @@ while test $# -gt 0 ; do
*local*)
# First pass through any local machine types.
- echo $1
+ echo "$1"
exit ;;
* )
@@ -112,7 +112,7 @@ esac
# Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any).
# Here we must recognize all the valid KERNEL-OS combinations.
-maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'`
+maybe_os=`echo "$1" | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'`
case $maybe_os in
nto-qnx* | linux-gnu* | linux-android* | linux-dietlibc | linux-newlib* | \
linux-musl* | linux-uclibc* | uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | \
@@ -120,16 +120,16 @@ case $maybe_os in
kopensolaris*-gnu* | cloudabi*-eabi* | \
storm-chaos* | os2-emx* | rtmk-nova*)
os=-$maybe_os
- basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`
+ basic_machine=`echo "$1" | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`
;;
android-linux)
os=-linux-android
- basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`-unknown
+ basic_machine=`echo "$1" | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`-unknown
;;
*)
- basic_machine=`echo $1 | sed 's/-[^-]*$//'`
- if [ $basic_machine != $1 ]
- then os=`echo $1 | sed 's/.*-/-/'`
+ basic_machine=`echo "$1" | sed 's/-[^-]*$//'`
+ if [ "$basic_machine" != "$1" ]
+ then os=`echo "$1" | sed 's/.*-/-/'`
else os=; fi
;;
esac
@@ -178,44 +178,44 @@ case $os in
;;
-sco6)
os=-sco5v6
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-sco5)
os=-sco3.2v5
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-sco4)
os=-sco3.2v4
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-sco3.2.[4-9]*)
os=`echo $os | sed -e 's/sco3.2./sco3.2v/'`
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-sco3.2v[4-9]*)
# Don't forget version if it is 3.2v4 or newer.
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-sco5v6*)
# Don't forget version if it is 3.2v4 or newer.
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-sco*)
os=-sco3.2v2
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-udk*)
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-isc)
os=-isc2.2
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-clix*)
basic_machine=clipper-intergraph
;;
-isc*)
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-lynx*178)
os=-lynxos178
@@ -227,10 +227,7 @@ case $os in
os=-lynxos
;;
-ptx*)
- basic_machine=`echo $1 | sed -e 's/86-.*/86-sequent/'`
- ;;
- -windowsnt*)
- os=`echo $os | sed -e 's/windowsnt/winnt/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-sequent/'`
;;
-psos*)
os=-psos
@@ -299,7 +296,7 @@ case $basic_machine in
| nios | nios2 | nios2eb | nios2el \
| ns16k | ns32k \
| open8 | or1k | or1knd | or32 \
- | pdp10 | pdp11 | pj | pjl \
+ | pdp10 | pj | pjl \
| powerpc | powerpc64 | powerpc64le | powerpcle \
| pru \
| pyramid \
@@ -316,7 +313,6 @@ case $basic_machine in
| v850 | v850e | v850e1 | v850e2 | v850es | v850e2v3 \
| visium \
| wasm32 \
- | we32k \
| x86 | xc16x | xstormy16 | xtensa \
| z8k | z80)
basic_machine=$basic_machine-unknown
@@ -337,7 +333,7 @@ case $basic_machine in
basic_machine=$basic_machine-unknown
os=-none
;;
- m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65 | z8k)
+ m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65)
;;
ms1)
basic_machine=mt-unknown
@@ -366,7 +362,7 @@ case $basic_machine in
;;
# Object if more than one company name word.
*-*-*)
- echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2
+ echo Invalid configuration \`"$1"\': machine \`"$basic_machine"\' not recognized 1>&2
exit 1
;;
# Recognize the basic CPU types with company name.
@@ -461,7 +457,7 @@ case $basic_machine in
# Recognize the various machine names and aliases which stand
# for a CPU type and a company and sometimes even an OS.
386bsd)
- basic_machine=i386-unknown
+ basic_machine=i386-pc
os=-bsd
;;
3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc)
@@ -495,7 +491,7 @@ case $basic_machine in
basic_machine=x86_64-pc
;;
amd64-*)
- basic_machine=x86_64-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=x86_64-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
amdahl)
basic_machine=580-amdahl
@@ -540,7 +536,7 @@ case $basic_machine in
os=-linux
;;
blackfin-*)
- basic_machine=bfin-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=bfin-`echo "$basic_machine" | sed 's/^[^-]*-//'`
os=-linux
;;
bluegene*)
@@ -548,13 +544,13 @@ case $basic_machine in
os=-cnk
;;
c54x-*)
- basic_machine=tic54x-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=tic54x-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
c55x-*)
- basic_machine=tic55x-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=tic55x-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
c6x-*)
- basic_machine=tic6x-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=tic6x-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
c90)
basic_machine=c90-cray
@@ -643,7 +639,7 @@ case $basic_machine in
basic_machine=rs6000-bull
os=-bosx
;;
- dpx2* | dpx2*-bull)
+ dpx2*)
basic_machine=m68k-bull
os=-sysv3
;;
@@ -652,7 +648,7 @@ case $basic_machine in
os=$os"spe"
;;
e500v[12]-*)
- basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=powerpc-`echo "$basic_machine" | sed 's/^[^-]*-//'`
os=$os"spe"
;;
ebmon29k)
@@ -744,9 +740,6 @@ case $basic_machine in
hp9k8[0-9][0-9] | hp8[0-9][0-9])
basic_machine=hppa1.0-hp
;;
- hppa-next)
- os=-nextstep3
- ;;
hppaosf)
basic_machine=hppa1.1-hp
os=-osf
@@ -759,26 +752,26 @@ case $basic_machine in
basic_machine=i370-ibm
;;
i*86v32)
- basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86.*/86-pc/'`
os=-sysv32
;;
i*86v4*)
- basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86.*/86-pc/'`
os=-sysv4
;;
i*86v)
- basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86.*/86-pc/'`
os=-sysv
;;
i*86sol2)
- basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86.*/86-pc/'`
os=-solaris2
;;
i386mach)
basic_machine=i386-mach
os=-mach
;;
- i386-vsta | vsta)
+ vsta)
basic_machine=i386-unknown
os=-vsta
;;
@@ -797,19 +790,16 @@ case $basic_machine in
os=-sysv
;;
leon-*|leon[3-9]-*)
- basic_machine=sparc-`echo $basic_machine | sed 's/-.*//'`
+ basic_machine=sparc-`echo "$basic_machine" | sed 's/-.*//'`
;;
m68knommu)
basic_machine=m68k-unknown
os=-linux
;;
m68knommu-*)
- basic_machine=m68k-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=m68k-`echo "$basic_machine" | sed 's/^[^-]*-//'`
os=-linux
;;
- m88k-omron*)
- basic_machine=m88k-omron
- ;;
magnum | m3230)
basic_machine=mips-mips
os=-sysv
@@ -841,10 +831,10 @@ case $basic_machine in
os=-mint
;;
mips3*-*)
- basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`
+ basic_machine=`echo "$basic_machine" | sed -e 's/mips3/mips64/'`
;;
mips3*)
- basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`-unknown
+ basic_machine=`echo "$basic_machine" | sed -e 's/mips3/mips64/'`-unknown
;;
monitor)
basic_machine=m68k-rom68k
@@ -863,7 +853,7 @@ case $basic_machine in
os=-msdos
;;
ms1-*)
- basic_machine=`echo $basic_machine | sed -e 's/ms1-/mt-/'`
+ basic_machine=`echo "$basic_machine" | sed -e 's/ms1-/mt-/'`
;;
msys)
basic_machine=i686-pc
@@ -905,7 +895,7 @@ case $basic_machine in
basic_machine=v70-nec
os=-sysv
;;
- next | m*-next )
+ next | m*-next)
basic_machine=m68k-next
case $os in
-nextstep* )
@@ -950,6 +940,9 @@ case $basic_machine in
nsr-tandem)
basic_machine=nsr-tandem
;;
+ nsv-tandem)
+ basic_machine=nsv-tandem
+ ;;
nsx-tandem)
basic_machine=nsx-tandem
;;
@@ -985,7 +978,7 @@ case $basic_machine in
os=-linux
;;
parisc-*)
- basic_machine=hppa-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=hppa-`echo "$basic_machine" | sed 's/^[^-]*-//'`
os=-linux
;;
pbd)
@@ -1001,7 +994,7 @@ case $basic_machine in
basic_machine=i386-pc
;;
pc98-*)
- basic_machine=i386-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=i386-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
pentium | p5 | k5 | k6 | nexgen | viac3)
basic_machine=i586-pc
@@ -1016,16 +1009,16 @@ case $basic_machine in
basic_machine=i786-pc
;;
pentium-* | p5-* | k5-* | k6-* | nexgen-* | viac3-*)
- basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=i586-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
pentiumpro-* | p6-* | 6x86-* | athlon-*)
- basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=i686-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
pentiumii-* | pentium2-* | pentiumiii-* | pentium3-*)
- basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=i686-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
pentium4-*)
- basic_machine=i786-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=i786-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
pn)
basic_machine=pn-gould
@@ -1035,23 +1028,23 @@ case $basic_machine in
ppc | ppcbe) basic_machine=powerpc-unknown
;;
ppc-* | ppcbe-*)
- basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=powerpc-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
ppcle | powerpclittle)
basic_machine=powerpcle-unknown
;;
ppcle-* | powerpclittle-*)
- basic_machine=powerpcle-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=powerpcle-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
ppc64) basic_machine=powerpc64-unknown
;;
- ppc64-*) basic_machine=powerpc64-`echo $basic_machine | sed 's/^[^-]*-//'`
+ ppc64-*) basic_machine=powerpc64-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
ppc64le | powerpc64little)
basic_machine=powerpc64le-unknown
;;
ppc64le-* | powerpc64little-*)
- basic_machine=powerpc64le-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=powerpc64le-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
ps2)
basic_machine=i386-ibm
@@ -1105,17 +1098,10 @@ case $basic_machine in
sequent)
basic_machine=i386-sequent
;;
- sh)
- basic_machine=sh-hitachi
- os=-hms
- ;;
sh5el)
basic_machine=sh5le-unknown
;;
- sh64)
- basic_machine=sh64-unknown
- ;;
- sparclite-wrs | simso-wrs)
+ simso-wrs)
basic_machine=sparclite-wrs
os=-vxworks
;;
@@ -1134,7 +1120,7 @@ case $basic_machine in
os=-sysv4
;;
strongarm-* | thumb-*)
- basic_machine=arm-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=arm-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
sun2)
basic_machine=m68000-sun
@@ -1248,9 +1234,6 @@ case $basic_machine in
basic_machine=a29k-wrs
os=-vxworks
;;
- wasm32)
- basic_machine=wasm32-unknown
- ;;
w65*)
basic_machine=w65-wdc
os=-none
@@ -1259,6 +1242,9 @@ case $basic_machine in
basic_machine=hppa1.1-winbond
os=-proelf
;;
+ x64)
+ basic_machine=x86_64-pc
+ ;;
xbox)
basic_machine=i686-pc
os=-mingw32
@@ -1267,20 +1253,12 @@ case $basic_machine in
basic_machine=xps100-honeywell
;;
xscale-* | xscalee[bl]-*)
- basic_machine=`echo $basic_machine | sed 's/^xscale/arm/'`
+ basic_machine=`echo "$basic_machine" | sed 's/^xscale/arm/'`
;;
ymp)
basic_machine=ymp-cray
os=-unicos
;;
- z8k-*-coff)
- basic_machine=z8k-unknown
- os=-sim
- ;;
- z80-*-coff)
- basic_machine=z80-unknown
- os=-sim
- ;;
none)
basic_machine=none-none
os=-none
@@ -1309,10 +1287,6 @@ case $basic_machine in
vax)
basic_machine=vax-dec
;;
- pdp10)
- # there are many clones, so DEC is not a safe bet
- basic_machine=pdp10-unknown
- ;;
pdp11)
basic_machine=pdp11-dec
;;
@@ -1322,9 +1296,6 @@ case $basic_machine in
sh[1234] | sh[24]a | sh[24]aeb | sh[34]eb | sh[1234]le | sh[23]ele)
basic_machine=sh-unknown
;;
- sparc | sparcv8 | sparcv9 | sparcv9b | sparcv9v)
- basic_machine=sparc-sun
- ;;
cydra)
basic_machine=cydra-cydrome
;;
@@ -1344,7 +1315,7 @@ case $basic_machine in
# Make sure to match an already-canonicalized machine name.
;;
*)
- echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2
+ echo Invalid configuration \`"$1"\': machine \`"$basic_machine"\' not recognized 1>&2
exit 1
;;
esac
@@ -1352,10 +1323,10 @@ esac
# Here we canonicalize certain aliases for manufacturers.
case $basic_machine in
*-digital*)
- basic_machine=`echo $basic_machine | sed 's/digital.*/dec/'`
+ basic_machine=`echo "$basic_machine" | sed 's/digital.*/dec/'`
;;
*-commodore*)
- basic_machine=`echo $basic_machine | sed 's/commodore.*/cbm/'`
+ basic_machine=`echo "$basic_machine" | sed 's/commodore.*/cbm/'`
;;
*)
;;
@@ -1366,8 +1337,8 @@ esac
if [ x"$os" != x"" ]
then
case $os in
- # First match some system type aliases
- # that might get confused with valid system types.
+ # First match some system type aliases that might get confused
+ # with valid system types.
# -solaris* is a basic system type, with this one exception.
-auroraux)
os=-auroraux
@@ -1378,18 +1349,19 @@ case $os in
-solaris)
os=-solaris2
;;
- -svr4*)
- os=-sysv4
- ;;
-unixware*)
os=-sysv4.2uw
;;
-gnu/linux*)
os=`echo $os | sed -e 's|gnu/linux|linux-gnu|'`
;;
- # First accept the basic system types.
+ # es1800 is here to avoid being matched by es* (a different OS)
+ -es1800*)
+ os=-ose
+ ;;
+ # Now accept the basic system types.
# The portable systems comes first.
- # Each alternative MUST END IN A *, to match a version number.
+ # Each alternative MUST end in a * to match a version number.
# -sysv* is not here because it comes later, after sysvr4.
-gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \
| -*vms* | -sco* | -esix* | -isc* | -aix* | -cnk* | -sunos | -sunos[34]*\
@@ -1399,25 +1371,26 @@ case $os in
| -aos* | -aros* | -cloudabi* | -sortix* \
| -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \
| -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \
- | -hiux* | -386bsd* | -knetbsd* | -mirbsd* | -netbsd* \
+ | -hiux* | -knetbsd* | -mirbsd* | -netbsd* \
| -bitrig* | -openbsd* | -solidbsd* | -libertybsd* \
| -ekkobsd* | -kfreebsd* | -freebsd* | -riscix* | -lynxos* \
| -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \
| -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \
- | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \
+ | -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* | -hcos* \
| -chorusos* | -chorusrdb* | -cegcc* | -glidix* \
| -cygwin* | -msys* | -pe* | -psos* | -moss* | -proelf* | -rtems* \
| -midipix* | -mingw32* | -mingw64* | -linux-gnu* | -linux-android* \
| -linux-newlib* | -linux-musl* | -linux-uclibc* \
| -uxpv* | -beos* | -mpeix* | -udk* | -moxiebox* \
- | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \
+ | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* \
| -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \
| -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* \
| -os2* | -vos* | -palmos* | -uclinux* | -nucleus* \
- | -morphos* | -superux* | -rtmk* | -rtmk-nova* | -windiss* \
+ | -morphos* | -superux* | -rtmk* | -windiss* \
| -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly* \
| -skyos* | -haiku* | -rdos* | -toppers* | -drops* | -es* \
- | -onefs* | -tirtos* | -phoenix* | -fuchsia* | -redox*)
+ | -onefs* | -tirtos* | -phoenix* | -fuchsia* | -redox* | -bme* \
+ | -midnightbsd*)
# Remember, each alternative MUST END IN *, to match a version number.
;;
-qnx*)
@@ -1434,12 +1407,12 @@ case $os in
-nto*)
os=`echo $os | sed -e 's|nto|nto-qnx|'`
;;
- -sim | -es1800* | -hms* | -xray | -os68k* | -none* | -v88r* \
- | -windows* | -osx | -abug | -netware* | -os9* | -beos* | -haiku* \
+ -sim | -xray | -os68k* | -v88r* \
+ | -windows* | -osx | -abug | -netware* | -os9* \
| -macos* | -mpw* | -magic* | -mmixware* | -mon960* | -lnews*)
;;
-mac*)
- os=`echo $os | sed -e 's|mac|macos|'`
+ os=`echo "$os" | sed -e 's|mac|macos|'`
;;
-linux-dietlibc)
os=-linux-dietlibc
@@ -1448,10 +1421,10 @@ case $os in
os=`echo $os | sed -e 's|linux|linux-gnu|'`
;;
-sunos5*)
- os=`echo $os | sed -e 's|sunos5|solaris2|'`
+ os=`echo "$os" | sed -e 's|sunos5|solaris2|'`
;;
-sunos6*)
- os=`echo $os | sed -e 's|sunos6|solaris3|'`
+ os=`echo "$os" | sed -e 's|sunos6|solaris3|'`
;;
-opened*)
os=-openedition
@@ -1462,12 +1435,6 @@ case $os in
-wince*)
os=-wince
;;
- -osfrose*)
- os=-osfrose
- ;;
- -osf*)
- os=-osf
- ;;
-utek*)
os=-bsd
;;
@@ -1492,7 +1459,7 @@ case $os in
-nova*)
os=-rtmk-nova
;;
- -ns2 )
+ -ns2)
os=-nextstep2
;;
-nsk*)
@@ -1514,7 +1481,7 @@ case $os in
-oss*)
os=-sysv3
;;
- -svr4)
+ -svr4*)
os=-sysv4
;;
-svr3)
@@ -1529,24 +1496,28 @@ case $os in
-ose*)
os=-ose
;;
- -es1800*)
- os=-ose
- ;;
- -xenix)
- os=-xenix
- ;;
-*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*)
os=-mint
;;
- -aros*)
- os=-aros
- ;;
-zvmoe)
os=-zvmoe
;;
-dicos*)
os=-dicos
;;
+ -pikeos*)
+ # Until real need of OS specific support for
+ # particular features comes up, bare metal
+ # configurations are quite functional.
+ case $basic_machine in
+ arm*)
+ os=-eabi
+ ;;
+ *)
+ os=-elf
+ ;;
+ esac
+ ;;
-nacl*)
;;
-ios)
@@ -1556,7 +1527,7 @@ case $os in
*)
# Get rid of the `-' at the beginning of $os.
os=`echo $os | sed 's/[^-]*-//'`
- echo Invalid configuration \`$1\': system \`$os\' not recognized 1>&2
+ echo Invalid configuration \`"$1"\': system \`"$os"\' not recognized 1>&2
exit 1
;;
esac
@@ -1652,9 +1623,6 @@ case $basic_machine in
*-be)
os=-beos
;;
- *-haiku)
- os=-haiku
- ;;
*-ibm)
os=-aix
;;
@@ -1694,7 +1662,7 @@ case $basic_machine in
m88k-omron*)
os=-luna
;;
- *-next )
+ *-next)
os=-nextstep
;;
*-sequent)
@@ -1709,9 +1677,6 @@ case $basic_machine in
i370-*)
os=-mvs
;;
- *-next)
- os=-nextstep3
- ;;
*-gould)
os=-sysv
;;
@@ -1821,15 +1786,15 @@ case $basic_machine in
vendor=stratus
;;
esac
- basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"`
+ basic_machine=`echo "$basic_machine" | sed "s/unknown/$vendor/"`
;;
esac
-echo $basic_machine$os
+echo "$basic_machine$os"
exit
# Local variables:
-# eval: (add-hook 'write-file-hooks 'time-stamp)
+# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "timestamp='"
# time-stamp-format: "%:y-%02m-%02d"
# time-stamp-end: "'"
diff --git a/jpeg/configure b/jpeg/configure
index 9c593db4..ccd339d1 100755
--- a/jpeg/configure
+++ b/jpeg/configure
@@ -1,6 +1,6 @@
#! /bin/sh
# Guess values for system-dependent variables and create Makefiles.
-# Generated by GNU Autoconf 2.69 for libjpeg 9.3.0.
+# Generated by GNU Autoconf 2.69 for libjpeg 9.4.0.
#
#
# Copyright (C) 1992-1996, 1998-2012 Free Software Foundation, Inc.
@@ -587,8 +587,8 @@ MAKEFLAGS=
# Identity of this package.
PACKAGE_NAME='libjpeg'
PACKAGE_TARNAME='libjpeg'
-PACKAGE_VERSION='9.3.0'
-PACKAGE_STRING='libjpeg 9.3.0'
+PACKAGE_VERSION='9.4.0'
+PACKAGE_STRING='libjpeg 9.4.0'
PACKAGE_BUGREPORT=''
PACKAGE_URL=''
@@ -632,6 +632,8 @@ ac_subst_vars='am__EXEEXT_FALSE
am__EXEEXT_TRUE
LTLIBOBJS
LIBOBJS
+JPEG_LIB_VERSION_MINOR
+JPEG_LIB_VERSION_MAJOR
JPEG_LIB_VERSION
MEMORYMGR
LT_SYS_LIBRARY_PATH
@@ -667,7 +669,6 @@ am__nodep
AMDEPBACKSLASH
AMDEP_FALSE
AMDEP_TRUE
-am__quote
am__include
DEPDIR
OBJEXT
@@ -756,7 +757,8 @@ PACKAGE_VERSION
PACKAGE_TARNAME
PACKAGE_NAME
PATH_SEPARATOR
-SHELL'
+SHELL
+am__quote'
ac_subst_files=''
ac_user_opts='
enable_option_checking
@@ -1324,7 +1326,7 @@ if test "$ac_init_help" = "long"; then
# Omit some internal or obsolete options to make the list less imposing.
# This message is too long to be a string in the A/UX 3.1 sh.
cat <<_ACEOF
-\`configure' configures libjpeg 9.3.0 to adapt to many kinds of systems.
+\`configure' configures libjpeg 9.4.0 to adapt to many kinds of systems.
Usage: $0 [OPTION]... [VAR=VALUE]...
@@ -1395,7 +1397,7 @@ fi
if test -n "$ac_init_help"; then
case $ac_init_help in
- short | recursive ) echo "Configuration of libjpeg 9.3.0:";;
+ short | recursive ) echo "Configuration of libjpeg 9.4.0:";;
esac
cat <<\_ACEOF
@@ -1512,7 +1514,7 @@ fi
test -n "$ac_init_help" && exit $ac_status
if $ac_init_version; then
cat <<\_ACEOF
-libjpeg configure 9.3.0
+libjpeg configure 9.4.0
generated by GNU Autoconf 2.69
Copyright (C) 2012 Free Software Foundation, Inc.
@@ -1877,7 +1879,7 @@ cat >config.log <<_ACEOF
This file contains any messages produced by compilers while
running configure, to aid debugging if configure makes a mistake.
-It was created by libjpeg $as_me 9.3.0, which was
+It was created by libjpeg $as_me 9.4.0, which was
generated by GNU Autoconf 2.69. Invocation command line was
$ $0 $@
@@ -2378,7 +2380,7 @@ test -n "$target_alias" &&
# Initialize Automake
# Don't require all the GNU mandated files
-am__api_version='1.15'
+am__api_version='1.16'
# Find a good install program. We prefer a C program (faster),
# so one script is as good as another. But avoid the broken or
@@ -2864,7 +2866,7 @@ fi
# Define the identity of the package.
PACKAGE='libjpeg'
- VERSION='9.3.0'
+ VERSION='9.4.0'
cat >>confdefs.h <<_ACEOF
@@ -2894,8 +2896,8 @@ MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"}
# For better backward compatibility. To be removed once Automake 1.9.x
# dies out for good. For more background, see:
-# <http://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
-# <http://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
+# <https://lists.gnu.org/archive/html/automake/2012-07/msg00001.html>
+# <https://lists.gnu.org/archive/html/automake/2012-07/msg00014.html>
mkdir_p='$(MKDIR_P)'
# We need awk for the "check" target (and possibly the TAP driver). The
@@ -2946,7 +2948,7 @@ END
Aborting the configuration process, to ensure you take notice of the issue.
You can download and install GNU coreutils to get an 'rm' implementation
-that behaves properly: <http://www.gnu.org/software/coreutils/>.
+that behaves properly: <https://www.gnu.org/software/coreutils/>.
If you want to complete the configuration process using your problematic
'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM
@@ -3880,45 +3882,45 @@ DEPDIR="${am__leading_dot}deps"
ac_config_commands="$ac_config_commands depfiles"
-
-am_make=${MAKE-make}
-cat > confinc << 'END'
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} supports the include directive" >&5
+$as_echo_n "checking whether ${MAKE-make} supports the include directive... " >&6; }
+cat > confinc.mk << 'END'
am__doit:
- @echo this is the am__doit target
+ @echo this is the am__doit target >confinc.out
.PHONY: am__doit
END
-# If we don't find an include directive, just comment out the code.
-{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for style of include used by $am_make" >&5
-$as_echo_n "checking for style of include used by $am_make... " >&6; }
am__include="#"
am__quote=
-_am_result=none
-# First try GNU make style include.
-echo "include confinc" > confmf
-# Ignore all kinds of additional output from 'make'.
-case `$am_make -s -f confmf 2> /dev/null` in #(
-*the\ am__doit\ target*)
- am__include=include
- am__quote=
- _am_result=GNU
- ;;
-esac
-# Now try BSD make style include.
-if test "$am__include" = "#"; then
- echo '.include "confinc"' > confmf
- case `$am_make -s -f confmf 2> /dev/null` in #(
- *the\ am__doit\ target*)
- am__include=.include
- am__quote="\""
- _am_result=BSD
+# BSD make does it like this.
+echo '.include "confinc.mk" # ignored' > confmf.BSD
+# Other make implementations (GNU, Solaris 10, AIX) do it like this.
+echo 'include confinc.mk # ignored' > confmf.GNU
+_am_result=no
+for s in GNU BSD; do
+ { echo "$as_me:$LINENO: ${MAKE-make} -f confmf.$s && cat confinc.out" >&5
+ (${MAKE-make} -f confmf.$s && cat confinc.out) >&5 2>&5
+ ac_status=$?
+ echo "$as_me:$LINENO: \$? = $ac_status" >&5
+ (exit $ac_status); }
+ case $?:`cat confinc.out 2>/dev/null` in #(
+ '0:this is the am__doit target') :
+ case $s in #(
+ BSD) :
+ am__include='.include' am__quote='"' ;; #(
+ *) :
+ am__include='include' am__quote='' ;;
+esac ;; #(
+ *) :
;;
- esac
-fi
-
-
-{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $_am_result" >&5
-$as_echo "$_am_result" >&6; }
-rm -f confinc confmf
+esac
+ if test "$am__include" != "#"; then
+ _am_result="yes ($s style)"
+ break
+ fi
+done
+rm -f confinc.* confmf.*
+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: ${_am_result}" >&5
+$as_echo "${_am_result}" >&6; }
# Check whether --enable-dependency-tracking was given.
if test "${enable_dependency_tracking+set}" = set; then :
@@ -13576,8 +13578,12 @@ major=`sed -ne 's/^#define JPEG_LIB_VERSION_MAJOR *\([0-9][0-9]*\).*$/\1/p' $src
minor=`sed -ne 's/^#define JPEG_LIB_VERSION_MINOR *\([0-9][0-9]*\).*$/\1/p' $srcdir/jpeglib.h`
JPEG_LIB_VERSION=`expr $major + $minor`:0:$minor
-{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $JPEG_LIB_VERSION" >&5
-$as_echo "$JPEG_LIB_VERSION" >&6; }
+JPEG_LIB_VERSION_MAJOR=$major
+
+JPEG_LIB_VERSION_MINOR=$minor
+
+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $major.$minor.0" >&5
+$as_echo "$major.$minor.0" >&6; }
ac_config_files="$ac_config_files Makefile libjpeg.pc"
@@ -14119,7 +14125,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1
# report actual input values of CONFIG_FILES etc. instead of their
# values after options handling.
ac_log="
-This file was extended by libjpeg $as_me 9.3.0, which was
+This file was extended by libjpeg $as_me 9.4.0, which was
generated by GNU Autoconf 2.69. Invocation command line was
CONFIG_FILES = $CONFIG_FILES
@@ -14185,7 +14191,7 @@ _ACEOF
cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`"
ac_cs_version="\\
-libjpeg config.status 9.3.0
+libjpeg config.status 9.4.0
configured by $0, generated by GNU Autoconf 2.69,
with options \\"\$ac_cs_config\\"
@@ -14304,7 +14310,7 @@ cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
#
# INIT-COMMANDS
#
-AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"
+AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"
# The HP-UX ksh and POSIX shell print the target directory to stdout
@@ -15203,29 +15209,35 @@ $as_echo "$as_me: executing $ac_file commands" >&6;}
# Older Autoconf quotes --file arguments for eval, but not when files
# are listed without --file. Let's play safe and only enable the eval
# if we detect the quoting.
- case $CONFIG_FILES in
- *\'*) eval set x "$CONFIG_FILES" ;;
- *) set x $CONFIG_FILES ;;
- esac
+ # TODO: see whether this extra hack can be removed once we start
+ # requiring Autoconf 2.70 or later.
+ case $CONFIG_FILES in #(
+ *\'*) :
+ eval set x "$CONFIG_FILES" ;; #(
+ *) :
+ set x $CONFIG_FILES ;; #(
+ *) :
+ ;;
+esac
shift
- for mf
+ # Used to flag and report bootstrapping failures.
+ am_rc=0
+ for am_mf
do
# Strip MF so we end up with the name of the file.
- mf=`echo "$mf" | sed -e 's/:.*$//'`
- # Check whether this is an Automake generated Makefile or not.
- # We used to match only the files named 'Makefile.in', but
- # some people rename them; so instead we look at the file content.
- # Grep'ing the first line is not enough: some people post-process
- # each Makefile.in and add a new line on top of each file to say so.
- # Grep'ing the whole file is not good either: AIX grep has a line
+ am_mf=`$as_echo "$am_mf" | sed -e 's/:.*$//'`
+ # Check whether this is an Automake generated Makefile which includes
+ # dependency-tracking related rules and includes.
+ # Grep'ing the whole file directly is not great: AIX grep has a line
# limit of 2048, but all sed's we know have understand at least 4000.
- if sed -n 's,^#.*generated by automake.*,X,p' "$mf" | grep X >/dev/null 2>&1; then
- dirpart=`$as_dirname -- "$mf" ||
-$as_expr X"$mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
- X"$mf" : 'X\(//\)[^/]' \| \
- X"$mf" : 'X\(//\)$' \| \
- X"$mf" : 'X\(/\)' \| . 2>/dev/null ||
-$as_echo X"$mf" |
+ sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \
+ || continue
+ am_dirpart=`$as_dirname -- "$am_mf" ||
+$as_expr X"$am_mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
+ X"$am_mf" : 'X\(//\)[^/]' \| \
+ X"$am_mf" : 'X\(//\)$' \| \
+ X"$am_mf" : 'X\(/\)' \| . 2>/dev/null ||
+$as_echo X"$am_mf" |
sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
s//\1/
q
@@ -15243,53 +15255,48 @@ $as_echo X"$mf" |
q
}
s/.*/./; q'`
- else
- continue
- fi
- # Extract the definition of DEPDIR, am__include, and am__quote
- # from the Makefile without running 'make'.
- DEPDIR=`sed -n 's/^DEPDIR = //p' < "$mf"`
- test -z "$DEPDIR" && continue
- am__include=`sed -n 's/^am__include = //p' < "$mf"`
- test -z "$am__include" && continue
- am__quote=`sed -n 's/^am__quote = //p' < "$mf"`
- # Find all dependency output files, they are included files with
- # $(DEPDIR) in their names. We invoke sed twice because it is the
- # simplest approach to changing $(DEPDIR) to its actual value in the
- # expansion.
- for file in `sed -n "
- s/^$am__include $am__quote\(.*(DEPDIR).*\)$am__quote"'$/\1/p' <"$mf" | \
- sed -e 's/\$(DEPDIR)/'"$DEPDIR"'/g'`; do
- # Make sure the directory exists.
- test -f "$dirpart/$file" && continue
- fdir=`$as_dirname -- "$file" ||
-$as_expr X"$file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
- X"$file" : 'X\(//\)[^/]' \| \
- X"$file" : 'X\(//\)$' \| \
- X"$file" : 'X\(/\)' \| . 2>/dev/null ||
-$as_echo X"$file" |
- sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{
- s//\1/
- q
- }
- /^X\(\/\/\)[^/].*/{
+ am_filepart=`$as_basename -- "$am_mf" ||
+$as_expr X/"$am_mf" : '.*/\([^/][^/]*\)/*$' \| \
+ X"$am_mf" : 'X\(//\)$' \| \
+ X"$am_mf" : 'X\(/\)' \| . 2>/dev/null ||
+$as_echo X/"$am_mf" |
+ sed '/^.*\/\([^/][^/]*\)\/*$/{
s//\1/
q
}
- /^X\(\/\/\)$/{
+ /^X\/\(\/\/\)$/{
s//\1/
q
}
- /^X\(\/\).*/{
+ /^X\/\(\/\).*/{
s//\1/
q
}
s/.*/./; q'`
- as_dir=$dirpart/$fdir; as_fn_mkdir_p
- # echo "creating $dirpart/$file"
- echo '# dummy' > "$dirpart/$file"
- done
+ { echo "$as_me:$LINENO: cd "$am_dirpart" \
+ && sed -e '/# am--include-marker/d' "$am_filepart" \
+ | $MAKE -f - am--depfiles" >&5
+ (cd "$am_dirpart" \
+ && sed -e '/# am--include-marker/d' "$am_filepart" \
+ | $MAKE -f - am--depfiles) >&5 2>&5
+ ac_status=$?
+ echo "$as_me:$LINENO: \$? = $ac_status" >&5
+ (exit $ac_status); } || am_rc=$?
done
+ if test $am_rc -ne 0; then
+ { { $as_echo "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5
+$as_echo "$as_me: error: in \`$ac_pwd':" >&2;}
+as_fn_error $? "Something went wrong bootstrapping makefile fragments
+ for automatic dependency tracking. Try re-running configure with the
+ '--disable-dependency-tracking' option to at least be able to build
+ the package (albeit without support for automatic dependency tracking).
+See \`config.log' for more details" "$LINENO" 5; }
+ fi
+ { am_dirpart=; unset am_dirpart;}
+ { am_filepart=; unset am_filepart;}
+ { am_mf=; unset am_mf;}
+ { am_rc=; unset am_rc;}
+ rm -f conftest-deps.mk
}
;;
"libtool":C)
diff --git a/jpeg/configure.ac b/jpeg/configure.ac
index 503f7361..eb3eeede 100644
--- a/jpeg/configure.ac
+++ b/jpeg/configure.ac
@@ -5,7 +5,7 @@
# Configure script for IJG libjpeg
#
-AC_INIT([libjpeg], [9.3.0])
+AC_INIT([libjpeg], [9.4.0])
# Directory where autotools helper scripts lives.
AC_CONFIG_AUX_DIR([.])
@@ -357,9 +357,10 @@ AC_SUBST([MEMORYMGR])
AC_MSG_CHECKING([libjpeg version number])
[major=`sed -ne 's/^#define JPEG_LIB_VERSION_MAJOR *\([0-9][0-9]*\).*$/\1/p' $srcdir/jpeglib.h`
minor=`sed -ne 's/^#define JPEG_LIB_VERSION_MINOR *\([0-9][0-9]*\).*$/\1/p' $srcdir/jpeglib.h`]
-AC_SUBST([JPEG_LIB_VERSION],
- [`expr $major + $minor`:0:$minor])
-AC_MSG_RESULT([$JPEG_LIB_VERSION])
+AC_SUBST([JPEG_LIB_VERSION], [`expr $major + $minor`:0:$minor])
+AC_SUBST([JPEG_LIB_VERSION_MAJOR], [$major])
+AC_SUBST([JPEG_LIB_VERSION_MINOR], [$minor])
+AC_MSG_RESULT([$major.$minor.0])
AC_CONFIG_FILES([Makefile libjpeg.pc])
AC_OUTPUT
diff --git a/jpeg/depcomp b/jpeg/depcomp
index b39f98f9..65cbf709 100755
--- a/jpeg/depcomp
+++ b/jpeg/depcomp
@@ -1,9 +1,9 @@
#! /bin/sh
# depcomp - compile a program generating dependencies as side-effects
-scriptversion=2016-01-11.22; # UTC
+scriptversion=2018-03-07.03; # UTC
-# Copyright (C) 1999-2017 Free Software Foundation, Inc.
+# Copyright (C) 1999-2018 Free Software Foundation, Inc.
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
@@ -16,7 +16,7 @@ scriptversion=2016-01-11.22; # UTC
# GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
-# along with this program. If not, see <http://www.gnu.org/licenses/>.
+# along with this program. If not, see <https://www.gnu.org/licenses/>.
# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
@@ -783,7 +783,7 @@ exit 0
# Local Variables:
# mode: shell-script
# sh-indentation: 2
-# eval: (add-hook 'write-file-hooks 'time-stamp)
+# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "scriptversion="
# time-stamp-format: "%:y-%02m-%02d.%02H"
# time-stamp-time-zone: "UTC0"
diff --git a/jpeg/djpeg.1 b/jpeg/djpeg.1
index dfbe4f12..1cb364f2 100644
--- a/jpeg/djpeg.1
+++ b/jpeg/djpeg.1
@@ -1,4 +1,4 @@
-.TH DJPEG 1 "26 July 2015"
+.TH DJPEG 1 "28 April 2019"
.SH NAME
djpeg \- decompress a JPEG file to an image file
.SH SYNOPSIS
@@ -16,7 +16,8 @@ djpeg \- decompress a JPEG file to an image file
decompresses the named JPEG file, or the standard input if no file is named,
and produces an image file on the standard output. PBMPLUS (PPM/PGM), BMP,
GIF, Targa, or RLE (Utah Raster Toolkit) output format can be selected.
-(RLE is supported only if the URT library is available.)
+(RLE is supported only if the URT library is available, which it isn't
+on most non-Unix systems.)
.SH OPTIONS
All switch names may be abbreviated; for example,
.B \-grayscale
@@ -76,8 +77,8 @@ Scaling is handy if the image is larger than your screen; also,
runs much faster when scaling down the output.
.TP
.B \-bmp
-Select BMP output format (Windows flavor). 8-bit colormapped format is
-emitted if
+Select BMP output format (Windows flavor).
+8-bit colormapped format is emitted if
.B \-colors
or
.B \-grayscale
@@ -85,13 +86,24 @@ is specified, or if the JPEG file is grayscale; otherwise, 24-bit full-color
format is emitted.
.TP
.B \-gif
-Select GIF output format. Since GIF does not support more than 256 colors,
+Select GIF output format (LZW compressed).
+Since GIF does not support more than 256 colors,
.B \-colors 256
-is assumed (unless you specify a smaller number of colors).
+is assumed (unless you specify a smaller number of colors). If you specify
+.BR \-fast ,
+the default number of colors is 216.
+.TP
+.B \-gif0
+Select GIF output format (uncompressed).
+Since GIF does not support more than 256 colors,
+.B \-colors 256
+is assumed (unless you specify a smaller number of colors). If you specify
+.BR \-fast ,
+the default number of colors is 216.
.TP
.B \-os2
-Select BMP output format (OS/2 1.x flavor). 8-bit colormapped format is
-emitted if
+Select BMP output format (OS/2 1.x flavor).
+8-bit colormapped format is emitted if
.B \-colors
or
.B \-grayscale
@@ -250,8 +262,3 @@ Wallace, Gregory K. "The JPEG Still Picture Compression Standard",
Communications of the ACM, April 1991 (vol. 34, no. 4), pp. 30-44.
.SH AUTHOR
Independent JPEG Group
-.SH BUGS
-To avoid the Unisys LZW patent (now expired),
-.B djpeg
-produces uncompressed GIF files. These are larger than they should be, but
-are readable by standard GIF decoders.
diff --git a/jpeg/djpeg.c b/jpeg/djpeg.c
index 0c9b89bd..a01b3968 100644
--- a/jpeg/djpeg.c
+++ b/jpeg/djpeg.c
@@ -2,7 +2,7 @@
* djpeg.c
*
* Copyright (C) 1991-1997, Thomas G. Lane.
- * Modified 2009-2015 by Guido Vollbeding.
+ * Modified 2009-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -59,7 +59,8 @@ static const char * const cdjpeg_message_table[] = {
typedef enum {
FMT_BMP, /* BMP format (Windows flavor) */
- FMT_GIF, /* GIF format */
+ FMT_GIF, /* GIF format (LZW compressed) */
+ FMT_GIF0, /* GIF format (uncompressed) */
FMT_OS2, /* BMP format (OS/2 flavor) */
FMT_PPM, /* PPM/PGM (PBMPLUS formats) */
FMT_RLE, /* RLE format */
@@ -111,8 +112,10 @@ usage (void)
(DEFAULT_FMT == FMT_BMP ? " (default)" : ""));
#endif
#ifdef GIF_SUPPORTED
- fprintf(stderr, " -gif Select GIF output format%s\n",
+ fprintf(stderr, " -gif Select GIF output format (LZW compressed)%s\n",
(DEFAULT_FMT == FMT_GIF ? " (default)" : ""));
+ fprintf(stderr, " -gif0 Select GIF output format (uncompressed)%s\n",
+ (DEFAULT_FMT == FMT_GIF0 ? " (default)" : ""));
#endif
#ifdef BMP_SUPPORTED
fprintf(stderr, " -os2 Select BMP output format (OS/2 style)%s\n",
@@ -195,7 +198,7 @@ parse_switches (j_decompress_ptr cinfo, int argc, char **argv,
arg++; /* advance past switch marker character */
if (keymatch(arg, "bmp", 1)) {
- /* BMP output format. */
+ /* BMP output format (Windows flavor). */
requested_fmt = FMT_BMP;
} else if (keymatch(arg, "colors", 1) || keymatch(arg, "colours", 1) ||
@@ -258,9 +261,13 @@ parse_switches (j_decompress_ptr cinfo, int argc, char **argv,
cinfo->do_fancy_upsampling = FALSE;
} else if (keymatch(arg, "gif", 1)) {
- /* GIF output format. */
+ /* GIF output format (LZW compressed). */
requested_fmt = FMT_GIF;
+ } else if (keymatch(arg, "gif0", 4)) {
+ /* GIF output format (uncompressed). */
+ requested_fmt = FMT_GIF0;
+
} else if (keymatch(arg, "grayscale", 2) || keymatch(arg, "greyscale",2)) {
/* Force monochrome output. */
cinfo->out_color_space = JCS_GRAYSCALE;
@@ -461,7 +468,7 @@ main (int argc, char **argv)
* APP12 is used by some digital camera makers for textual info,
* so we provide the ability to display it as text.
* If you like, additional APPn marker types can be selected for display,
- * but don't try to override APP0 or APP14 this way (see libjpeg.doc).
+ * but don't try to override APP0 or APP14 this way (see libjpeg.txt).
*/
jpeg_set_marker_processor(&cinfo, JPEG_COM, print_text_marker);
jpeg_set_marker_processor(&cinfo, JPEG_APP0+12, print_text_marker);
@@ -554,7 +561,10 @@ main (int argc, char **argv)
#endif
#ifdef GIF_SUPPORTED
case FMT_GIF:
- dest_mgr = jinit_write_gif(&cinfo);
+ dest_mgr = jinit_write_gif(&cinfo, TRUE);
+ break;
+ case FMT_GIF0:
+ dest_mgr = jinit_write_gif(&cinfo, FALSE);
break;
#endif
#ifdef PPM_SUPPORTED
@@ -574,7 +584,6 @@ main (int argc, char **argv)
#endif
default:
ERREXIT(&cinfo, JERR_UNSUPPORTED_FORMAT);
- break;
}
dest_mgr->output_file = output_file;
diff --git a/jpeg/filelist.txt b/jpeg/filelist.txt
index 583859f0..86def455 100644
--- a/jpeg/filelist.txt
+++ b/jpeg/filelist.txt
@@ -1,6 +1,6 @@
IJG JPEG LIBRARY: FILE LIST
-Copyright (C) 1994-2017, Thomas G. Lane, Guido Vollbeding.
+Copyright (C) 1994-2019, Thomas G. Lane, Guido Vollbeding.
This file is part of the Independent JPEG Group's software.
For conditions of distribution and use, see the accompanying README file.
@@ -151,7 +151,7 @@ transupp.c Support code for jpegtran: lossless image manipulations.
Image file reader modules for cjpeg:
rdbmp.c BMP file input.
-rdgif.c GIF file input (now just a stub).
+rdgif.c GIF file input.
rdppm.c PPM/PGM file input.
rdrle.c Utah RLE file input.
rdtarga.c Targa file input.
@@ -159,7 +159,7 @@ rdtarga.c Targa file input.
Image file writer modules for djpeg:
wrbmp.c BMP file output.
-wrgif.c GIF file output (a mere shadow of its former self).
+wrgif.c GIF file output.
wrppm.c PPM/PGM file output.
wrrle.c Utah RLE file output.
wrtarga.c Targa file output.
diff --git a/jpeg/install-sh b/jpeg/install-sh
index 0360b79e..8175c640 100755
--- a/jpeg/install-sh
+++ b/jpeg/install-sh
@@ -1,7 +1,7 @@
#!/bin/sh
# install - install a program, script, or datafile
-scriptversion=2016-01-11.22; # UTC
+scriptversion=2018-03-11.20; # UTC
# This originates from X11R5 (mit/util/scripts/install.sh), which was
# later released in X11R6 (xc/config/util/install.sh) with the
@@ -271,15 +271,18 @@ do
fi
dst=$dst_arg
- # If destination is a directory, append the input filename; won't work
- # if double slashes aren't ignored.
+ # If destination is a directory, append the input filename.
if test -d "$dst"; then
if test "$is_target_a_directory" = never; then
echo "$0: $dst_arg: Is a directory" >&2
exit 1
fi
dstdir=$dst
- dst=$dstdir/`basename "$src"`
+ dstbase=`basename "$src"`
+ case $dst in
+ */) dst=$dst$dstbase;;
+ *) dst=$dst/$dstbase;;
+ esac
dstdir_status=0
else
dstdir=`dirname "$dst"`
@@ -288,6 +291,11 @@ do
fi
fi
+ case $dstdir in
+ */) dstdirslash=$dstdir;;
+ *) dstdirslash=$dstdir/;;
+ esac
+
obsolete_mkdir_used=false
if test $dstdir_status != 0; then
@@ -324,34 +332,43 @@ do
# is incompatible with FreeBSD 'install' when (umask & 300) != 0.
;;
*)
+ # Note that $RANDOM variable is not portable (e.g. dash); Use it
+ # here however when possible just to lower collision chance.
tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$
- trap 'ret=$?; rmdir "$tmpdir/d" "$tmpdir" 2>/dev/null; exit $ret' 0
+ trap 'ret=$?; rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" 2>/dev/null; exit $ret' 0
+
+ # Because "mkdir -p" follows existing symlinks and we likely work
+ # directly in world-writeable /tmp, make sure that the '$tmpdir'
+ # directory is successfully created first before we actually test
+ # 'mkdir -p' feature.
if (umask $mkdir_umask &&
- exec $mkdirprog $mkdir_mode -p -- "$tmpdir/d") >/dev/null 2>&1
+ $mkdirprog $mkdir_mode "$tmpdir" &&
+ exec $mkdirprog $mkdir_mode -p -- "$tmpdir/a/b") >/dev/null 2>&1
then
if test -z "$dir_arg" || {
# Check for POSIX incompatibilities with -m.
# HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or
# other-writable bit of parent directory when it shouldn't.
# FreeBSD 6.1 mkdir -m -p sets mode of existing directory.
- ls_ld_tmpdir=`ls -ld "$tmpdir"`
+ test_tmpdir="$tmpdir/a"
+ ls_ld_tmpdir=`ls -ld "$test_tmpdir"`
case $ls_ld_tmpdir in
d????-?r-*) different_mode=700;;
d????-?--*) different_mode=755;;
*) false;;
esac &&
- $mkdirprog -m$different_mode -p -- "$tmpdir" && {
- ls_ld_tmpdir_1=`ls -ld "$tmpdir"`
+ $mkdirprog -m$different_mode -p -- "$test_tmpdir" && {
+ ls_ld_tmpdir_1=`ls -ld "$test_tmpdir"`
test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1"
}
}
then posix_mkdir=:
fi
- rmdir "$tmpdir/d" "$tmpdir"
+ rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir"
else
# Remove any dirs left behind by ancient mkdir implementations.
- rmdir ./$mkdir_mode ./-p ./-- 2>/dev/null
+ rmdir ./$mkdir_mode ./-p ./-- "$tmpdir" 2>/dev/null
fi
trap '' 0;;
esac;;
@@ -427,8 +444,8 @@ do
else
# Make a couple of temp file names in the proper directory.
- dsttmp=$dstdir/_inst.$$_
- rmtmp=$dstdir/_rm.$$_
+ dsttmp=${dstdirslash}_inst.$$_
+ rmtmp=${dstdirslash}_rm.$$_
# Trap to clean up those temp files at exit.
trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0
@@ -493,7 +510,7 @@ do
done
# Local variables:
-# eval: (add-hook 'write-file-hooks 'time-stamp)
+# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "scriptversion="
# time-stamp-format: "%:y-%02m-%02d.%02H"
# time-stamp-time-zone: "UTC0"
diff --git a/jpeg/install.txt b/jpeg/install.txt
index 10600a40..107f6c1f 100644
--- a/jpeg/install.txt
+++ b/jpeg/install.txt
@@ -1,6 +1,6 @@
INSTALLATION INSTRUCTIONS for the Independent JPEG Group's JPEG software
-Copyright (C) 1991-2017, Thomas G. Lane, Guido Vollbeding.
+Copyright (C) 1991-2019, Thomas G. Lane, Guido Vollbeding.
This file is part of the Independent JPEG Group's software.
For conditions of distribution and use, see the accompanying README file.
@@ -150,8 +150,8 @@ makefile.wat jconfig.wat MS-DOS, OS/2, or Windows NT, Watcom C
makefile.vc jconfig.vc Windows, MS Visual C++
makefile.vs jconfig.vc Windows, MS Visual C++ 6 Developer Studio
make*.vc6
-makefile.vs jconfig.vc Windows, Visual Studio 2017 (v15)
-make*.v15
+makefile.vs jconfig.vc Windows, Visual Studio 2019 (v16)
+make*.v16
makefile.b32 jconfig.vc Windows, Borland C++ 32-bit (bcc32)
makefile.mms jconfig.vms Digital VMS, with MMS software
makefile.vms jconfig.vms Digital VMS, without MMS software
@@ -1029,48 +1029,66 @@ library, we recommend building the applications so that you can run the
self-test.)
To use:
-1. Open the command prompt, change to the main directory and execute the
- command line
- NMAKE /f makefile.vs setup-vc6
+1. Open the command prompt, change to the source directory and execute
+ the command line
+ NMAKE /f makefile.vs setup-vc6
+ If you get an error message saying that the "NMAKE" command could
+ not be found, execute the command
+ "%ProgramFiles%\Microsoft Visual Studio\VC98\Bin\VCVARS32"
+ to set the environment for using Microsoft Visual C++ tools,
+ and repeat the NMAKE call.
This will move jconfig.vc to jconfig.h and makefiles to project files.
(Note that the renaming is critical!)
+ Alternatively you can use
+ NMAKE /f makefile.vs setupcopy-vc6
+ This will create renamed copies of the files, which allows to repeat
+ the setup later.
2. Open the workspace file jpeg.dsw, build the library project.
(If you are using Developer Studio more recent than 6.0, you'll
probably get a message saying that the project files are being updated.)
3. Open the workspace file apps.dsw, build the application projects.
4. To perform the self-test, execute the command line
- NMAKE /f makefile.vs test-build
-5. Move the application .exe files from `app`\Release to an
+ NMAKE /f makefile.vs test-build
+5. Move the application .exe files from the Release folder to an
appropriate location on your path.
-Microsoft Windows, Visual Studio 2017 (v15):
+Microsoft Windows, Visual Studio 2019 (v16):
We include makefiles that should work as project files in Visual Studio
-2017 (v15) or later. There is a library makefile that builds the IJG
-library as a static Win32 library, and application makefiles that build
-the sample applications as Win32 console applications. (Even if you only
-want the library, we recommend building the applications so that you can
-run the self-test.)
+2019 (v16) or later. There is a library makefile that builds the IJG
+library as a static Win32/x64 library, and application makefiles that
+build the sample applications as Win32/x64 console applications. (Even
+if you only want the library, we recommend building the applications so
+that you can run the self-test.)
To use:
-1. Open the Developer Command Prompt, change to the main directory and
- execute the command line
- NMAKE /f makefile.vs setup-v15
+1. Open the Developer Command Prompt for VS 2019, change to the source
+ directory and execute the command line
+ NMAKE /f makefile.vs setup-v16
This will move jconfig.vc to jconfig.h and makefiles to project files.
(Note that the renaming is critical!)
+ Alternatively you can use
+ NMAKE /f makefile.vs setupcopy-v16
+ This will create renamed copies of the files, which allows to repeat
+ the setup later.
2. Open the solution file jpeg.sln, build the library project.
a) If you are using Visual Studio more recent than
- 2017 (v15), you'll probably get a message saying
+ 2019 (v16), you'll probably get a message saying
that the project files are being updated.
b) If necessary, open the project properties and
adapt the Windows Target Platform Version in
the Configuration Properties, General section;
we support the latest version at the time of release.
+ c) If you want to build x64 code, change the platform setting from
+ Win32 to x64. You can build Win32 and x64 versions side by side.
3. Open the solution file apps.sln, build the application projects.
4. To perform the self-test, execute the command line
- NMAKE /f makefile.vs test-build
-5. Move the application .exe files from `app`\Release to an
+ NMAKE /f makefile.vs test-32
+ for the Win32 build, or on a 64-bit system
+ NMAKE /f makefile.vs test-64
+ for the x64 build.
+5. Move the application .exe files from the Release folder to an
appropriate location on your path.
diff --git a/jpeg/jcarith.c b/jpeg/jcarith.c
index a64190e7..46ce6c6a 100644
--- a/jpeg/jcarith.c
+++ b/jpeg/jcarith.c
@@ -1,7 +1,7 @@
/*
* jcarith.c
*
- * Developed 1997-2013 by Guido Vollbeding.
+ * Developed 1997-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -181,11 +181,11 @@ finish_pass (j_compress_ptr cinfo)
if (e->zc) /* output final pending zero bytes */
do emit_byte(0x00, cinfo);
while (--e->zc);
- emit_byte((e->c >> 19) & 0xFF, cinfo);
+ emit_byte((int) ((e->c >> 19) & 0xFF), cinfo);
if (((e->c >> 19) & 0xFF) == 0xFF)
emit_byte(0x00, cinfo);
if (e->c & 0x7F800L) {
- emit_byte((e->c >> 11) & 0xFF, cinfo);
+ emit_byte((int) ((e->c >> 11) & 0xFF), cinfo);
if (((e->c >> 11) & 0xFF) == 0xFF)
emit_byte(0x00, cinfo);
}
@@ -280,7 +280,8 @@ arith_encode (j_compress_ptr cinfo, unsigned char *st, int val)
/* Note: The 3 spacer bits in the C register guarantee
* that the new buffer byte can't be 0xFF here
* (see page 160 in the P&M JPEG book). */
- e->buffer = temp & 0xFF; /* new output byte, might overflow later */
+ /* New output byte, might overflow later */
+ e->buffer = (int) (temp & 0xFF);
} else if (temp == 0xFF) {
++e->sc; /* stack 0xFF byte (which might overflow later) */
} else {
@@ -302,7 +303,8 @@ arith_encode (j_compress_ptr cinfo, unsigned char *st, int val)
emit_byte(0x00, cinfo);
} while (--e->sc);
}
- e->buffer = temp & 0xFF; /* new output byte (can still overflow) */
+ /* New output byte (can still overflow) */
+ e->buffer = (int) (temp & 0xFF);
}
e->c &= 0x7FFFFL;
e->ct += 8;
@@ -926,9 +928,8 @@ jinit_arith_encoder (j_compress_ptr cinfo)
arith_entropy_ptr entropy;
int i;
- entropy = (arith_entropy_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(arith_entropy_encoder));
+ entropy = (arith_entropy_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(arith_entropy_encoder));
cinfo->entropy = &entropy->pub;
entropy->pub.start_pass = start_pass;
entropy->pub.finish_pass = finish_pass;
diff --git a/jpeg/jccolor.c b/jpeg/jccolor.c
index f6b4a493..db2ca429 100644
--- a/jpeg/jccolor.c
+++ b/jpeg/jccolor.c
@@ -2,7 +2,7 @@
* jccolor.c
*
* Copyright (C) 1991-1996, Thomas G. Lane.
- * Modified 2011-2013 by Guido Vollbeding.
+ * Modified 2011-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -105,14 +105,14 @@ rgb_ycc_start (j_compress_ptr cinfo)
/* Allocate and fill in the conversion tables. */
cconvert->rgb_ycc_tab = rgb_ycc_tab = (INT32 *)
(*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (TABLE_SIZE * SIZEOF(INT32)));
+ TABLE_SIZE * SIZEOF(INT32));
for (i = 0; i <= MAXJSAMPLE; i++) {
rgb_ycc_tab[i+R_Y_OFF] = FIX(0.299) * i;
rgb_ycc_tab[i+G_Y_OFF] = FIX(0.587) * i;
rgb_ycc_tab[i+B_Y_OFF] = FIX(0.114) * i + ONE_HALF;
- rgb_ycc_tab[i+R_CB_OFF] = (-FIX(0.168735892)) * i;
- rgb_ycc_tab[i+G_CB_OFF] = (-FIX(0.331264108)) * i;
+ rgb_ycc_tab[i+R_CB_OFF] = (- FIX(0.168735892)) * i;
+ rgb_ycc_tab[i+G_CB_OFF] = (- FIX(0.331264108)) * i;
/* We use a rounding fudge-factor of 0.5-epsilon for Cb and Cr.
* This ensures that the maximum output will round to MAXJSAMPLE
* not MAXJSAMPLE+1, and thus that we don't have to range-limit.
@@ -121,8 +121,8 @@ rgb_ycc_start (j_compress_ptr cinfo)
/* B=>Cb and R=>Cr tables are the same
rgb_ycc_tab[i+R_CR_OFF] = FIX(0.5) * i + CBCR_OFFSET + ONE_HALF-1;
*/
- rgb_ycc_tab[i+G_CR_OFF] = (-FIX(0.418687589)) * i;
- rgb_ycc_tab[i+B_CR_OFF] = (-FIX(0.081312411)) * i;
+ rgb_ycc_tab[i+G_CR_OFF] = (- FIX(0.418687589)) * i;
+ rgb_ycc_tab[i+B_CR_OFF] = (- FIX(0.081312411)) * i;
}
}
@@ -131,12 +131,12 @@ rgb_ycc_start (j_compress_ptr cinfo)
* Convert some rows of samples to the JPEG colorspace.
*
* Note that we change from the application's interleaved-pixel format
- * to our internal noninterleaved, one-plane-per-component format.
- * The input buffer is therefore three times as wide as the output buffer.
+ * to our internal noninterleaved, one-plane-per-component format. The
+ * input buffer is therefore three times as wide as the output buffer.
*
- * A starting row offset is provided only for the output buffer. The caller
- * can easily adjust the passed input_buf value to accommodate any row
- * offset required on that side.
+ * A starting row offset is provided only for the output buffer. The
+ * caller can easily adjust the passed input_buf value to accommodate
+ * any row offset required on that side.
*/
METHODDEF(void)
@@ -145,8 +145,8 @@ rgb_ycc_convert (j_compress_ptr cinfo,
JDIMENSION output_row, int num_rows)
{
my_cconvert_ptr cconvert = (my_cconvert_ptr) cinfo->cconvert;
- register INT32 * ctab = cconvert->rgb_ycc_tab;
register int r, g, b;
+ register INT32 * ctab = cconvert->rgb_ycc_tab;
register JSAMPROW inptr;
register JSAMPROW outptr0, outptr1, outptr2;
register JDIMENSION col;
@@ -162,6 +162,7 @@ rgb_ycc_convert (j_compress_ptr cinfo,
r = GETJSAMPLE(inptr[RGB_RED]);
g = GETJSAMPLE(inptr[RGB_GREEN]);
b = GETJSAMPLE(inptr[RGB_BLUE]);
+ inptr += RGB_PIXELSIZE;
/* If the inputs are 0..MAXJSAMPLE, the outputs of these equations
* must be too; we do not need an explicit range-limiting operation.
* Hence the value being shifted is never negative, and we don't
@@ -179,7 +180,6 @@ rgb_ycc_convert (j_compress_ptr cinfo,
outptr2[col] = (JSAMPLE)
((ctab[r+R_CR_OFF] + ctab[g+G_CR_OFF] + ctab[b+B_CR_OFF])
>> SCALEBITS);
- inptr += RGB_PIXELSIZE;
}
}
}
@@ -201,8 +201,8 @@ rgb_gray_convert (j_compress_ptr cinfo,
JDIMENSION output_row, int num_rows)
{
my_cconvert_ptr cconvert = (my_cconvert_ptr) cinfo->cconvert;
- register INT32 * ctab = cconvert->rgb_ycc_tab;
register int r, g, b;
+ register INT32 * ctab = cconvert->rgb_ycc_tab;
register JSAMPROW inptr;
register JSAMPROW outptr;
register JDIMENSION col;
@@ -215,11 +215,11 @@ rgb_gray_convert (j_compress_ptr cinfo,
r = GETJSAMPLE(inptr[RGB_RED]);
g = GETJSAMPLE(inptr[RGB_GREEN]);
b = GETJSAMPLE(inptr[RGB_BLUE]);
+ inptr += RGB_PIXELSIZE;
/* Y */
outptr[col] = (JSAMPLE)
((ctab[r+R_Y_OFF] + ctab[g+G_Y_OFF] + ctab[b+B_Y_OFF])
>> SCALEBITS);
- inptr += RGB_PIXELSIZE;
}
}
}
@@ -228,8 +228,8 @@ rgb_gray_convert (j_compress_ptr cinfo,
/*
* Convert some rows of samples to the JPEG colorspace.
* This version handles Adobe-style CMYK->YCCK conversion,
- * where we convert R=1-C, G=1-M, and B=1-Y to YCbCr using the same
- * conversion as above, while passing K (black) unchanged.
+ * where we convert R=1-C, G=1-M, and B=1-Y to YCbCr using the
+ * same conversion as above, while passing K (black) unchanged.
* We assume rgb_ycc_start has been called.
*/
@@ -239,8 +239,8 @@ cmyk_ycck_convert (j_compress_ptr cinfo,
JDIMENSION output_row, int num_rows)
{
my_cconvert_ptr cconvert = (my_cconvert_ptr) cinfo->cconvert;
- register INT32 * ctab = cconvert->rgb_ycc_tab;
register int r, g, b;
+ register INT32 * ctab = cconvert->rgb_ycc_tab;
register JSAMPROW inptr;
register JSAMPROW outptr0, outptr1, outptr2, outptr3;
register JDIMENSION col;
@@ -259,6 +259,7 @@ cmyk_ycck_convert (j_compress_ptr cinfo,
b = MAXJSAMPLE - GETJSAMPLE(inptr[2]);
/* K passes through as-is */
outptr3[col] = inptr[3]; /* don't need GETJSAMPLE here */
+ inptr += 4;
/* If the inputs are 0..MAXJSAMPLE, the outputs of these equations
* must be too; we do not need an explicit range-limiting operation.
* Hence the value being shifted is never negative, and we don't
@@ -276,7 +277,6 @@ cmyk_ycck_convert (j_compress_ptr cinfo,
outptr2[col] = (JSAMPLE)
((ctab[r+R_CR_OFF] + ctab[g+G_CR_OFF] + ctab[b+B_CR_OFF])
>> SCALEBITS);
- inptr += 4;
}
}
}
@@ -312,13 +312,13 @@ rgb_rgb1_convert (j_compress_ptr cinfo,
r = GETJSAMPLE(inptr[RGB_RED]);
g = GETJSAMPLE(inptr[RGB_GREEN]);
b = GETJSAMPLE(inptr[RGB_BLUE]);
+ inptr += RGB_PIXELSIZE;
/* Assume that MAXJSAMPLE+1 is a power of 2, so that the MOD
* (modulo) operator is equivalent to the bitmask operator AND.
*/
outptr0[col] = (JSAMPLE) ((r - g + CENTERJSAMPLE) & MAXJSAMPLE);
outptr1[col] = (JSAMPLE) g;
outptr2[col] = (JSAMPLE) ((b - g + CENTERJSAMPLE) & MAXJSAMPLE);
- inptr += RGB_PIXELSIZE;
}
}
}
@@ -335,17 +335,17 @@ grayscale_convert (j_compress_ptr cinfo,
JSAMPARRAY input_buf, JSAMPIMAGE output_buf,
JDIMENSION output_row, int num_rows)
{
- int instride = cinfo->input_components;
register JSAMPROW inptr;
register JSAMPROW outptr;
- register JDIMENSION col;
+ register JDIMENSION count;
+ register int instride = cinfo->input_components;
JDIMENSION num_cols = cinfo->image_width;
while (--num_rows >= 0) {
inptr = *input_buf++;
outptr = output_buf[0][output_row++];
- for (col = 0; col < num_cols; col++) {
- outptr[col] = inptr[0]; /* don't need GETJSAMPLE() here */
+ for (count = num_cols; count > 0; count--) {
+ *outptr++ = *inptr; /* don't need GETJSAMPLE() here */
inptr += instride;
}
}
@@ -396,21 +396,21 @@ null_convert (j_compress_ptr cinfo,
JSAMPARRAY input_buf, JSAMPIMAGE output_buf,
JDIMENSION output_row, int num_rows)
{
- int ci;
- register int nc = cinfo->num_components;
register JSAMPROW inptr;
register JSAMPROW outptr;
- register JDIMENSION col;
+ register JDIMENSION count;
+ register int num_comps = cinfo->num_components;
JDIMENSION num_cols = cinfo->image_width;
+ int ci;
while (--num_rows >= 0) {
/* It seems fastest to make a separate pass for each component. */
- for (ci = 0; ci < nc; ci++) {
+ for (ci = 0; ci < num_comps; ci++) {
inptr = input_buf[0] + ci;
outptr = output_buf[ci][output_row];
- for (col = 0; col < num_cols; col++) {
+ for (count = num_cols; count > 0; count--) {
*outptr++ = *inptr; /* don't need GETJSAMPLE() here */
- inptr += nc;
+ inptr += num_comps;
}
}
input_buf++;
@@ -439,9 +439,8 @@ jinit_color_converter (j_compress_ptr cinfo)
{
my_cconvert_ptr cconvert;
- cconvert = (my_cconvert_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(my_color_converter));
+ cconvert = (my_cconvert_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(my_color_converter));
cinfo->cconvert = &cconvert->pub;
/* set start_pass to null method until we find out differently */
cconvert->pub.start_pass = null_method;
@@ -455,9 +454,11 @@ jinit_color_converter (j_compress_ptr cinfo)
case JCS_RGB:
case JCS_BG_RGB:
+#if RGB_PIXELSIZE != 3
if (cinfo->input_components != RGB_PIXELSIZE)
ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
break;
+#endif /* else share code with YCbCr */
case JCS_YCbCr:
case JCS_BG_YCC:
@@ -474,7 +475,6 @@ jinit_color_converter (j_compress_ptr cinfo)
default: /* JCS_UNKNOWN can be anything */
if (cinfo->input_components < 1)
ERREXIT(cinfo, JERR_BAD_IN_COLORSPACE);
- break;
}
/* Support color transform only for RGB colorspaces */
@@ -507,19 +507,18 @@ jinit_color_converter (j_compress_ptr cinfo)
case JCS_BG_RGB:
if (cinfo->num_components != 3)
ERREXIT(cinfo, JERR_BAD_J_COLORSPACE);
- if (cinfo->in_color_space == cinfo->jpeg_color_space) {
- switch (cinfo->color_transform) {
- case JCT_NONE:
- cconvert->pub.color_convert = rgb_convert;
- break;
- case JCT_SUBTRACT_GREEN:
- cconvert->pub.color_convert = rgb_rgb1_convert;
- break;
- default:
- ERREXIT(cinfo, JERR_CONVERSION_NOTIMPL);
- }
- } else
+ if (cinfo->in_color_space != cinfo->jpeg_color_space)
ERREXIT(cinfo, JERR_CONVERSION_NOTIMPL);
+ switch (cinfo->color_transform) {
+ case JCT_NONE:
+ cconvert->pub.color_convert = rgb_convert;
+ break;
+ case JCT_SUBTRACT_GREEN:
+ cconvert->pub.color_convert = rgb_rgb1_convert;
+ break;
+ default:
+ ERREXIT(cinfo, JERR_CONVERSION_NOTIMPL);
+ }
break;
case JCS_YCbCr:
@@ -572,10 +571,9 @@ jinit_color_converter (j_compress_ptr cinfo)
case JCS_CMYK:
if (cinfo->num_components != 4)
ERREXIT(cinfo, JERR_BAD_J_COLORSPACE);
- if (cinfo->in_color_space == JCS_CMYK)
- cconvert->pub.color_convert = null_convert;
- else
+ if (cinfo->in_color_space != JCS_CMYK)
ERREXIT(cinfo, JERR_CONVERSION_NOTIMPL);
+ cconvert->pub.color_convert = null_convert;
break;
case JCS_YCCK:
@@ -599,6 +597,5 @@ jinit_color_converter (j_compress_ptr cinfo)
cinfo->num_components != cinfo->input_components)
ERREXIT(cinfo, JERR_CONVERSION_NOTIMPL);
cconvert->pub.color_convert = null_convert;
- break;
}
}
diff --git a/jpeg/jchuff.c b/jpeg/jchuff.c
index d1313f67..02fc275b 100644
--- a/jpeg/jchuff.c
+++ b/jpeg/jchuff.c
@@ -2,7 +2,7 @@
* jchuff.c
*
* Copyright (C) 1991-1997, Thomas G. Lane.
- * Modified 2006-2013 by Guido Vollbeding.
+ * Modified 2006-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -178,13 +178,12 @@ jpeg_make_c_derived_tbl (j_compress_ptr cinfo, boolean isDC, int tblno,
htbl =
isDC ? cinfo->dc_huff_tbl_ptrs[tblno] : cinfo->ac_huff_tbl_ptrs[tblno];
if (htbl == NULL)
- ERREXIT1(cinfo, JERR_NO_HUFF_TABLE, tblno);
+ htbl = jpeg_std_huff_table((j_common_ptr) cinfo, isDC, tblno);
/* Allocate a workspace if we haven't already done so. */
if (*pdtbl == NULL)
- *pdtbl = (c_derived_tbl *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(c_derived_tbl));
+ *pdtbl = (c_derived_tbl *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(c_derived_tbl));
dtbl = *pdtbl;
/* Figure C.1: make table of Huffman code length for each symbol */
@@ -1256,22 +1255,88 @@ jpeg_gen_optimal_table (j_compress_ptr cinfo, JHUFF_TBL * htbl, long freq[])
UINT8 bits[MAX_CLEN+1]; /* bits[k] = # of symbols with code length k */
int codesize[257]; /* codesize[k] = code length of symbol k */
int others[257]; /* next symbol in current branch of tree */
- int c1, c2;
- int p, i, j;
+ int c1, c2, i, j;
+ UINT8 *p;
long v;
+ freq[256] = 1; /* make sure 256 has a nonzero count */
+ /* Including the pseudo-symbol 256 in the Huffman procedure guarantees
+ * that no real symbol is given code-value of all ones, because 256
+ * will be placed last in the largest codeword category.
+ * In the symbol list build procedure this element serves as sentinel
+ * for the zero run loop.
+ */
+
+#ifndef DONT_USE_FANCY_HUFF_OPT
+
+ /* Build list of symbols sorted in order of descending frequency */
+ /* This approach has several benefits (thank to John Korejwa for the idea):
+ * 1.
+ * If a codelength category is split during the length limiting procedure
+ * below, the feature that more frequent symbols are assigned shorter
+ * codewords remains valid for the adjusted code.
+ * 2.
+ * To reduce consecutive ones in a Huffman data stream (thus reducing the
+ * number of stuff bytes in JPEG) it is preferable to follow 0 branches
+ * (and avoid 1 branches) as much as possible. This is easily done by
+ * assigning symbols to leaves of the Huffman tree in order of decreasing
+ * frequency, with no secondary sort based on codelengths.
+ * 3.
+ * The symbol list can be built independently from the assignment of code
+ * lengths by the Huffman procedure below.
+ * Note: The symbol list build procedure must be performed first, because
+ * the Huffman procedure assigning the codelengths clobbers the frequency
+ * counts!
+ */
+
+ /* Here we use the others array as a linked list of nonzero frequencies
+ * to be sorted. Already sorted elements are removed from the list.
+ */
+
+ /* Building list */
+
+ /* This item does not correspond to a valid symbol frequency and is used
+ * as starting index.
+ */
+ j = 256;
+
+ for (i = 0;; i++) {
+ if (freq[i] == 0) /* skip zero frequencies */
+ continue;
+ if (i > 255)
+ break;
+ others[j] = i; /* this symbol value */
+ j = i; /* previous symbol value */
+ }
+ others[j] = -1; /* mark end of list */
+
+ /* Sorting list */
+
+ p = htbl->huffval;
+ while ((c1 = others[256]) >= 0) {
+ v = freq[c1];
+ i = c1; /* first symbol value */
+ j = 256; /* pseudo symbol value for starting index */
+ while ((c2 = others[c1]) >= 0) {
+ if (freq[c2] > v) {
+ v = freq[c2];
+ i = c2; /* this symbol value */
+ j = c1; /* previous symbol value */
+ }
+ c1 = c2;
+ }
+ others[j] = others[i]; /* remove this symbol i from list */
+ *p++ = (UINT8) i;
+ }
+
+#endif /* DONT_USE_FANCY_HUFF_OPT */
+
/* This algorithm is explained in section K.2 of the JPEG standard */
MEMZERO(bits, SIZEOF(bits));
MEMZERO(codesize, SIZEOF(codesize));
for (i = 0; i < 257; i++)
others[i] = -1; /* init links to empty */
-
- freq[256] = 1; /* make sure 256 has a nonzero count */
- /* Including the pseudo-symbol 256 in the Huffman procedure guarantees
- * that no real symbol is given code-value of all ones, because 256
- * will be placed last in the largest codeword category.
- */
/* Huffman's basic algorithm to assign optimal code lengths to symbols */
@@ -1301,7 +1366,7 @@ jpeg_gen_optimal_table (j_compress_ptr cinfo, JHUFF_TBL * htbl, long freq[])
/* Done if we've merged everything into one frequency */
if (c2 < 0)
break;
-
+
/* Else merge the two counts/trees */
freq[c1] += freq[c2];
freq[c2] = 0;
@@ -1312,9 +1377,9 @@ jpeg_gen_optimal_table (j_compress_ptr cinfo, JHUFF_TBL * htbl, long freq[])
c1 = others[c1];
codesize[c1]++;
}
-
+
others[c1] = c2; /* chain c2 onto c1's tree branch */
-
+
/* Increment the codesize of everything in c2's tree branch */
codesize[c2]++;
while (others[c2] >= 0) {
@@ -1329,7 +1394,7 @@ jpeg_gen_optimal_table (j_compress_ptr cinfo, JHUFF_TBL * htbl, long freq[])
/* The JPEG standard seems to think that this can't happen, */
/* but I'm paranoid... */
if (codesize[i] > MAX_CLEN)
- ERREXIT(cinfo, JERR_HUFF_CLEN_OVERFLOW);
+ ERREXIT(cinfo, JERR_HUFF_CLEN_OUTOFBOUNDS);
bits[codesize[i]]++;
}
@@ -1345,13 +1410,16 @@ jpeg_gen_optimal_table (j_compress_ptr cinfo, JHUFF_TBL * htbl, long freq[])
* shortest nonzero BITS entry is converted into a prefix for two code words
* one bit longer.
*/
-
+
for (i = MAX_CLEN; i > 16; i--) {
while (bits[i] > 0) {
j = i - 2; /* find length of new prefix to be used */
- while (bits[j] == 0)
+ while (bits[j] == 0) {
+ if (j == 0)
+ ERREXIT(cinfo, JERR_HUFF_CLEN_OUTOFBOUNDS);
j--;
-
+ }
+
bits[i] -= 2; /* remove two symbols */
bits[i-1]++; /* one goes in this length */
bits[j+1] += 2; /* two new symbols in this length */
@@ -1363,24 +1431,27 @@ jpeg_gen_optimal_table (j_compress_ptr cinfo, JHUFF_TBL * htbl, long freq[])
while (bits[i] == 0) /* find largest codelength still in use */
i--;
bits[i]--;
-
+
/* Return final symbol counts (only for lengths 0..16) */
MEMCOPY(htbl->bits, bits, SIZEOF(htbl->bits));
-
+
+#ifdef DONT_USE_FANCY_HUFF_OPT
+
/* Return a list of the symbols sorted by code length */
- /* It's not real clear to me why we don't need to consider the codelength
- * changes made above, but the JPEG spec seems to think this works.
+ /* Note: Due to the codelength changes made above, it can happen
+ * that more frequent symbols are assigned longer codewords.
*/
- p = 0;
+ p = htbl->huffval;
for (i = 1; i <= MAX_CLEN; i++) {
for (j = 0; j <= 255; j++) {
if (codesize[j] == i) {
- htbl->huffval[p] = (UINT8) j;
- p++;
+ *p++ = (UINT8) j;
}
}
}
+#endif /* DONT_USE_FANCY_HUFF_OPT */
+
/* Set sent_table FALSE so updated table will be written to JPEG file. */
htbl->sent_table = FALSE;
}
@@ -1400,13 +1471,13 @@ finish_pass_gather (j_compress_ptr cinfo)
boolean did_dc[NUM_HUFF_TBLS];
boolean did_ac[NUM_HUFF_TBLS];
- /* It's important not to apply jpeg_gen_optimal_table more than once
- * per table, because it clobbers the input frequency counts!
- */
if (cinfo->progressive_mode)
/* Flush out buffered data (all we care about is counting the EOB symbol) */
emit_eobrun(entropy);
+ /* It's important not to apply jpeg_gen_optimal_table more than once
+ * per table, because it clobbers the input frequency counts!
+ */
MEMZERO(did_dc, SIZEOF(did_dc));
MEMZERO(did_ac, SIZEOF(did_ac));
@@ -1475,9 +1546,8 @@ start_pass_huff (j_compress_ptr cinfo, boolean gather_statistics)
entropy->pub.encode_mcu = encode_mcu_AC_refine;
/* AC refinement needs a correction bit buffer */
if (entropy->bit_buffer == NULL)
- entropy->bit_buffer = (char *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- MAX_CORR_BITS * SIZEOF(char));
+ entropy->bit_buffer = (char *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, MAX_CORR_BITS * SIZEOF(char));
}
}
@@ -1505,9 +1575,8 @@ start_pass_huff (j_compress_ptr cinfo, boolean gather_statistics)
/* Allocate and zero the statistics tables */
/* Note that jpeg_gen_optimal_table expects 257 entries in each table! */
if (entropy->dc_count_ptrs[tbl] == NULL)
- entropy->dc_count_ptrs[tbl] = (long *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- 257 * SIZEOF(long));
+ entropy->dc_count_ptrs[tbl] = (long *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, 257 * SIZEOF(long));
MEMZERO(entropy->dc_count_ptrs[tbl], 257 * SIZEOF(long));
} else {
/* Compute derived values for Huffman tables */
@@ -1525,9 +1594,8 @@ start_pass_huff (j_compress_ptr cinfo, boolean gather_statistics)
if (tbl < 0 || tbl >= NUM_HUFF_TBLS)
ERREXIT1(cinfo, JERR_NO_HUFF_TABLE, tbl);
if (entropy->ac_count_ptrs[tbl] == NULL)
- entropy->ac_count_ptrs[tbl] = (long *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- 257 * SIZEOF(long));
+ entropy->ac_count_ptrs[tbl] = (long *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, 257 * SIZEOF(long));
MEMZERO(entropy->ac_count_ptrs[tbl], 257 * SIZEOF(long));
} else {
jpeg_make_c_derived_tbl(cinfo, FALSE, tbl,
@@ -1556,9 +1624,8 @@ jinit_huff_encoder (j_compress_ptr cinfo)
huff_entropy_ptr entropy;
int i;
- entropy = (huff_entropy_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(huff_entropy_encoder));
+ entropy = (huff_entropy_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(huff_entropy_encoder));
cinfo->entropy = &entropy->pub;
entropy->pub.start_pass = start_pass_huff;
diff --git a/jpeg/jcmarker.c b/jpeg/jcmarker.c
index ca2bb399..8874cd86 100644
--- a/jpeg/jcmarker.c
+++ b/jpeg/jcmarker.c
@@ -2,7 +2,7 @@
* jcmarker.c
*
* Copyright (C) 1991-1998, Thomas G. Lane.
- * Modified 2003-2013 by Guido Vollbeding.
+ * Modified 2003-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -471,7 +471,6 @@ emit_adobe_app14 (j_compress_ptr cinfo)
break;
default:
emit_byte(cinfo, 0); /* Color transform = 0 */
- break;
}
}
@@ -702,9 +701,8 @@ jinit_marker_writer (j_compress_ptr cinfo)
my_marker_ptr marker;
/* Create the subobject */
- marker = (my_marker_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(my_marker_writer));
+ marker = (my_marker_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(my_marker_writer));
cinfo->marker = &marker->pub;
/* Initialize method pointers */
marker->pub.write_file_header = write_file_header;
diff --git a/jpeg/jcmaster.c b/jpeg/jcmaster.c
index 43d49aec..89dcf78c 100644
--- a/jpeg/jcmaster.c
+++ b/jpeg/jcmaster.c
@@ -2,7 +2,7 @@
* jcmaster.c
*
* Copyright (C) 1991-1997, Thomas G. Lane.
- * Modified 2003-2017 by Guido Vollbeding.
+ * Modified 2003-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -62,7 +62,7 @@ initial_setup (j_compress_ptr cinfo)
case 5: cinfo->natural_order = jpeg_natural_order5; break;
case 6: cinfo->natural_order = jpeg_natural_order6; break;
case 7: cinfo->natural_order = jpeg_natural_order7; break;
- default: cinfo->natural_order = jpeg_natural_order; break;
+ default: cinfo->natural_order = jpeg_natural_order;
}
/* Derive lim_Se from block_size */
@@ -114,20 +114,24 @@ initial_setup (j_compress_ptr cinfo)
*/
ssize = 1;
#ifdef DCT_SCALING_SUPPORTED
- while (cinfo->min_DCT_h_scaled_size * ssize <=
- (cinfo->do_fancy_downsampling ? DCTSIZE : DCTSIZE / 2) &&
- (cinfo->max_h_samp_factor % (compptr->h_samp_factor * ssize * 2)) == 0) {
- ssize = ssize * 2;
- }
+ if (! cinfo->raw_data_in)
+ while (cinfo->min_DCT_h_scaled_size * ssize <=
+ (cinfo->do_fancy_downsampling ? DCTSIZE : DCTSIZE / 2) &&
+ (cinfo->max_h_samp_factor % (compptr->h_samp_factor * ssize * 2)) ==
+ 0) {
+ ssize = ssize * 2;
+ }
#endif
compptr->DCT_h_scaled_size = cinfo->min_DCT_h_scaled_size * ssize;
ssize = 1;
#ifdef DCT_SCALING_SUPPORTED
- while (cinfo->min_DCT_v_scaled_size * ssize <=
- (cinfo->do_fancy_downsampling ? DCTSIZE : DCTSIZE / 2) &&
- (cinfo->max_v_samp_factor % (compptr->v_samp_factor * ssize * 2)) == 0) {
- ssize = ssize * 2;
- }
+ if (! cinfo->raw_data_in)
+ while (cinfo->min_DCT_v_scaled_size * ssize <=
+ (cinfo->do_fancy_downsampling ? DCTSIZE : DCTSIZE / 2) &&
+ (cinfo->max_v_samp_factor % (compptr->v_samp_factor * ssize * 2)) ==
+ 0) {
+ ssize = ssize * 2;
+ }
#endif
compptr->DCT_v_scaled_size = cinfo->min_DCT_v_scaled_size * ssize;
@@ -620,9 +624,8 @@ jinit_c_master_control (j_compress_ptr cinfo, boolean transcode_only)
{
my_master_ptr master;
- master = (my_master_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(my_comp_master));
+ master = (my_master_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(my_comp_master));
cinfo->master = &master->pub;
master->pub.prepare_for_pass = prepare_for_pass;
master->pub.pass_startup = pass_startup;
diff --git a/jpeg/jcomapi.c b/jpeg/jcomapi.c
index 9b1fa756..678c5d12 100644
--- a/jpeg/jcomapi.c
+++ b/jpeg/jcomapi.c
@@ -2,6 +2,7 @@
* jcomapi.c
*
* Copyright (C) 1994-1997, Thomas G. Lane.
+ * Modified 2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -104,3 +105,140 @@ jpeg_alloc_huff_table (j_common_ptr cinfo)
tbl->sent_table = FALSE; /* make sure this is false in any new table */
return tbl;
}
+
+
+/*
+ * Set up the standard Huffman tables (cf. JPEG standard section K.3).
+ * IMPORTANT: these are only valid for 8-bit data precision!
+ * (Would jutils.c be a more reasonable place to put this?)
+ */
+
+GLOBAL(JHUFF_TBL *)
+jpeg_std_huff_table (j_common_ptr cinfo, boolean isDC, int tblno)
+{
+ JHUFF_TBL **htblptr, *htbl;
+ const UINT8 *bits, *val;
+ int nsymbols, len;
+
+ static const UINT8 bits_dc_luminance[17] =
+ { /* 0-base */ 0, 0, 1, 5, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0 };
+ static const UINT8 val_dc_luminance[] =
+ { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11 };
+
+ static const UINT8 bits_dc_chrominance[17] =
+ { /* 0-base */ 0, 0, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0 };
+ static const UINT8 val_dc_chrominance[] =
+ { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11 };
+
+ static const UINT8 bits_ac_luminance[17] =
+ { /* 0-base */ 0, 0, 2, 1, 3, 3, 2, 4, 3, 5, 5, 4, 4, 0, 0, 1, 0x7d };
+ static const UINT8 val_ac_luminance[] =
+ { 0x01, 0x02, 0x03, 0x00, 0x04, 0x11, 0x05, 0x12,
+ 0x21, 0x31, 0x41, 0x06, 0x13, 0x51, 0x61, 0x07,
+ 0x22, 0x71, 0x14, 0x32, 0x81, 0x91, 0xa1, 0x08,
+ 0x23, 0x42, 0xb1, 0xc1, 0x15, 0x52, 0xd1, 0xf0,
+ 0x24, 0x33, 0x62, 0x72, 0x82, 0x09, 0x0a, 0x16,
+ 0x17, 0x18, 0x19, 0x1a, 0x25, 0x26, 0x27, 0x28,
+ 0x29, 0x2a, 0x34, 0x35, 0x36, 0x37, 0x38, 0x39,
+ 0x3a, 0x43, 0x44, 0x45, 0x46, 0x47, 0x48, 0x49,
+ 0x4a, 0x53, 0x54, 0x55, 0x56, 0x57, 0x58, 0x59,
+ 0x5a, 0x63, 0x64, 0x65, 0x66, 0x67, 0x68, 0x69,
+ 0x6a, 0x73, 0x74, 0x75, 0x76, 0x77, 0x78, 0x79,
+ 0x7a, 0x83, 0x84, 0x85, 0x86, 0x87, 0x88, 0x89,
+ 0x8a, 0x92, 0x93, 0x94, 0x95, 0x96, 0x97, 0x98,
+ 0x99, 0x9a, 0xa2, 0xa3, 0xa4, 0xa5, 0xa6, 0xa7,
+ 0xa8, 0xa9, 0xaa, 0xb2, 0xb3, 0xb4, 0xb5, 0xb6,
+ 0xb7, 0xb8, 0xb9, 0xba, 0xc2, 0xc3, 0xc4, 0xc5,
+ 0xc6, 0xc7, 0xc8, 0xc9, 0xca, 0xd2, 0xd3, 0xd4,
+ 0xd5, 0xd6, 0xd7, 0xd8, 0xd9, 0xda, 0xe1, 0xe2,
+ 0xe3, 0xe4, 0xe5, 0xe6, 0xe7, 0xe8, 0xe9, 0xea,
+ 0xf1, 0xf2, 0xf3, 0xf4, 0xf5, 0xf6, 0xf7, 0xf8,
+ 0xf9, 0xfa };
+
+ static const UINT8 bits_ac_chrominance[17] =
+ { /* 0-base */ 0, 0, 2, 1, 2, 4, 4, 3, 4, 7, 5, 4, 4, 0, 1, 2, 0x77 };
+ static const UINT8 val_ac_chrominance[] =
+ { 0x00, 0x01, 0x02, 0x03, 0x11, 0x04, 0x05, 0x21,
+ 0x31, 0x06, 0x12, 0x41, 0x51, 0x07, 0x61, 0x71,
+ 0x13, 0x22, 0x32, 0x81, 0x08, 0x14, 0x42, 0x91,
+ 0xa1, 0xb1, 0xc1, 0x09, 0x23, 0x33, 0x52, 0xf0,
+ 0x15, 0x62, 0x72, 0xd1, 0x0a, 0x16, 0x24, 0x34,
+ 0xe1, 0x25, 0xf1, 0x17, 0x18, 0x19, 0x1a, 0x26,
+ 0x27, 0x28, 0x29, 0x2a, 0x35, 0x36, 0x37, 0x38,
+ 0x39, 0x3a, 0x43, 0x44, 0x45, 0x46, 0x47, 0x48,
+ 0x49, 0x4a, 0x53, 0x54, 0x55, 0x56, 0x57, 0x58,
+ 0x59, 0x5a, 0x63, 0x64, 0x65, 0x66, 0x67, 0x68,
+ 0x69, 0x6a, 0x73, 0x74, 0x75, 0x76, 0x77, 0x78,
+ 0x79, 0x7a, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87,
+ 0x88, 0x89, 0x8a, 0x92, 0x93, 0x94, 0x95, 0x96,
+ 0x97, 0x98, 0x99, 0x9a, 0xa2, 0xa3, 0xa4, 0xa5,
+ 0xa6, 0xa7, 0xa8, 0xa9, 0xaa, 0xb2, 0xb3, 0xb4,
+ 0xb5, 0xb6, 0xb7, 0xb8, 0xb9, 0xba, 0xc2, 0xc3,
+ 0xc4, 0xc5, 0xc6, 0xc7, 0xc8, 0xc9, 0xca, 0xd2,
+ 0xd3, 0xd4, 0xd5, 0xd6, 0xd7, 0xd8, 0xd9, 0xda,
+ 0xe2, 0xe3, 0xe4, 0xe5, 0xe6, 0xe7, 0xe8, 0xe9,
+ 0xea, 0xf2, 0xf3, 0xf4, 0xf5, 0xf6, 0xf7, 0xf8,
+ 0xf9, 0xfa };
+
+ if (cinfo->is_decompressor) {
+ if (isDC)
+ htblptr = ((j_decompress_ptr) cinfo)->dc_huff_tbl_ptrs;
+ else
+ htblptr = ((j_decompress_ptr) cinfo)->ac_huff_tbl_ptrs;
+ } else {
+ if (isDC)
+ htblptr = ((j_compress_ptr) cinfo)->dc_huff_tbl_ptrs;
+ else
+ htblptr = ((j_compress_ptr) cinfo)->ac_huff_tbl_ptrs;
+ }
+
+ switch (tblno) {
+ case 0:
+ if (isDC) {
+ bits = bits_dc_luminance;
+ val = val_dc_luminance;
+ } else {
+ bits = bits_ac_luminance;
+ val = val_ac_luminance;
+ }
+ break;
+ case 1:
+ if (isDC) {
+ bits = bits_dc_chrominance;
+ val = val_dc_chrominance;
+ } else {
+ bits = bits_ac_chrominance;
+ val = val_ac_chrominance;
+ }
+ break;
+ default:
+ ERREXIT1(cinfo, JERR_NO_HUFF_TABLE, tblno);
+ return NULL; /* avoid compiler warnings for uninitialized variables */
+ }
+
+ if (htblptr[tblno] == NULL)
+ htblptr[tblno] = jpeg_alloc_huff_table(cinfo);
+
+ htbl = htblptr[tblno];
+
+ /* Copy the number-of-symbols-of-each-code-length counts */
+ MEMCOPY(htbl->bits, bits, SIZEOF(htbl->bits));
+
+ /* Validate the counts. We do this here mainly so we can copy the right
+ * number of symbols from the val[] array, without risking marching off
+ * the end of memory. jxhuff.c will do a more thorough test later.
+ */
+ nsymbols = 0;
+ for (len = 1; len <= 16; len++)
+ nsymbols += bits[len];
+ if (nsymbols > 256)
+ ERREXIT(cinfo, JERR_BAD_HUFF_TABLE);
+
+ if (nsymbols > 0)
+ MEMCOPY(htbl->huffval, val, nsymbols * SIZEOF(UINT8));
+
+ /* Initialize sent_table FALSE so table will be written to JPEG file. */
+ htbl->sent_table = FALSE;
+
+ return htbl;
+}
diff --git a/jpeg/jcparam.c b/jpeg/jcparam.c
index 4b2bee24..3b7014ff 100644
--- a/jpeg/jcparam.c
+++ b/jpeg/jcparam.c
@@ -2,7 +2,7 @@
* jcparam.c
*
* Copyright (C) 1991-1998, Thomas G. Lane.
- * Modified 2003-2013 by Guido Vollbeding.
+ * Modified 2003-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -162,112 +162,23 @@ jpeg_set_quality (j_compress_ptr cinfo, int quality, boolean force_baseline)
/*
- * Huffman table setup routines
+ * Reset standard Huffman tables
*/
LOCAL(void)
-add_huff_table (j_compress_ptr cinfo,
- JHUFF_TBL **htblptr, const UINT8 *bits, const UINT8 *val)
-/* Define a Huffman table */
+std_huff_tables (j_compress_ptr cinfo)
{
- int nsymbols, len;
-
- if (*htblptr == NULL)
- *htblptr = jpeg_alloc_huff_table((j_common_ptr) cinfo);
-
- /* Copy the number-of-symbols-of-each-code-length counts */
- MEMCOPY((*htblptr)->bits, bits, SIZEOF((*htblptr)->bits));
+ if (cinfo->dc_huff_tbl_ptrs[0] != NULL)
+ (void) jpeg_std_huff_table((j_common_ptr) cinfo, TRUE, 0);
- /* Validate the counts. We do this here mainly so we can copy the right
- * number of symbols from the val[] array, without risking marching off
- * the end of memory. jchuff.c will do a more thorough test later.
- */
- nsymbols = 0;
- for (len = 1; len <= 16; len++)
- nsymbols += bits[len];
- if (nsymbols < 1 || nsymbols > 256)
- ERREXIT(cinfo, JERR_BAD_HUFF_TABLE);
+ if (cinfo->ac_huff_tbl_ptrs[0] != NULL)
+ (void) jpeg_std_huff_table((j_common_ptr) cinfo, FALSE, 0);
- MEMCOPY((*htblptr)->huffval, val, nsymbols * SIZEOF(UINT8));
+ if (cinfo->dc_huff_tbl_ptrs[1] != NULL)
+ (void) jpeg_std_huff_table((j_common_ptr) cinfo, TRUE, 1);
- /* Initialize sent_table FALSE so table will be written to JPEG file. */
- (*htblptr)->sent_table = FALSE;
-}
-
-
-LOCAL(void)
-std_huff_tables (j_compress_ptr cinfo)
-/* Set up the standard Huffman tables (cf. JPEG standard section K.3) */
-/* IMPORTANT: these are only valid for 8-bit data precision! */
-{
- static const UINT8 bits_dc_luminance[17] =
- { /* 0-base */ 0, 0, 1, 5, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0 };
- static const UINT8 val_dc_luminance[] =
- { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11 };
-
- static const UINT8 bits_dc_chrominance[17] =
- { /* 0-base */ 0, 0, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0, 0, 0, 0 };
- static const UINT8 val_dc_chrominance[] =
- { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11 };
-
- static const UINT8 bits_ac_luminance[17] =
- { /* 0-base */ 0, 0, 2, 1, 3, 3, 2, 4, 3, 5, 5, 4, 4, 0, 0, 1, 0x7d };
- static const UINT8 val_ac_luminance[] =
- { 0x01, 0x02, 0x03, 0x00, 0x04, 0x11, 0x05, 0x12,
- 0x21, 0x31, 0x41, 0x06, 0x13, 0x51, 0x61, 0x07,
- 0x22, 0x71, 0x14, 0x32, 0x81, 0x91, 0xa1, 0x08,
- 0x23, 0x42, 0xb1, 0xc1, 0x15, 0x52, 0xd1, 0xf0,
- 0x24, 0x33, 0x62, 0x72, 0x82, 0x09, 0x0a, 0x16,
- 0x17, 0x18, 0x19, 0x1a, 0x25, 0x26, 0x27, 0x28,
- 0x29, 0x2a, 0x34, 0x35, 0x36, 0x37, 0x38, 0x39,
- 0x3a, 0x43, 0x44, 0x45, 0x46, 0x47, 0x48, 0x49,
- 0x4a, 0x53, 0x54, 0x55, 0x56, 0x57, 0x58, 0x59,
- 0x5a, 0x63, 0x64, 0x65, 0x66, 0x67, 0x68, 0x69,
- 0x6a, 0x73, 0x74, 0x75, 0x76, 0x77, 0x78, 0x79,
- 0x7a, 0x83, 0x84, 0x85, 0x86, 0x87, 0x88, 0x89,
- 0x8a, 0x92, 0x93, 0x94, 0x95, 0x96, 0x97, 0x98,
- 0x99, 0x9a, 0xa2, 0xa3, 0xa4, 0xa5, 0xa6, 0xa7,
- 0xa8, 0xa9, 0xaa, 0xb2, 0xb3, 0xb4, 0xb5, 0xb6,
- 0xb7, 0xb8, 0xb9, 0xba, 0xc2, 0xc3, 0xc4, 0xc5,
- 0xc6, 0xc7, 0xc8, 0xc9, 0xca, 0xd2, 0xd3, 0xd4,
- 0xd5, 0xd6, 0xd7, 0xd8, 0xd9, 0xda, 0xe1, 0xe2,
- 0xe3, 0xe4, 0xe5, 0xe6, 0xe7, 0xe8, 0xe9, 0xea,
- 0xf1, 0xf2, 0xf3, 0xf4, 0xf5, 0xf6, 0xf7, 0xf8,
- 0xf9, 0xfa };
-
- static const UINT8 bits_ac_chrominance[17] =
- { /* 0-base */ 0, 0, 2, 1, 2, 4, 4, 3, 4, 7, 5, 4, 4, 0, 1, 2, 0x77 };
- static const UINT8 val_ac_chrominance[] =
- { 0x00, 0x01, 0x02, 0x03, 0x11, 0x04, 0x05, 0x21,
- 0x31, 0x06, 0x12, 0x41, 0x51, 0x07, 0x61, 0x71,
- 0x13, 0x22, 0x32, 0x81, 0x08, 0x14, 0x42, 0x91,
- 0xa1, 0xb1, 0xc1, 0x09, 0x23, 0x33, 0x52, 0xf0,
- 0x15, 0x62, 0x72, 0xd1, 0x0a, 0x16, 0x24, 0x34,
- 0xe1, 0x25, 0xf1, 0x17, 0x18, 0x19, 0x1a, 0x26,
- 0x27, 0x28, 0x29, 0x2a, 0x35, 0x36, 0x37, 0x38,
- 0x39, 0x3a, 0x43, 0x44, 0x45, 0x46, 0x47, 0x48,
- 0x49, 0x4a, 0x53, 0x54, 0x55, 0x56, 0x57, 0x58,
- 0x59, 0x5a, 0x63, 0x64, 0x65, 0x66, 0x67, 0x68,
- 0x69, 0x6a, 0x73, 0x74, 0x75, 0x76, 0x77, 0x78,
- 0x79, 0x7a, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87,
- 0x88, 0x89, 0x8a, 0x92, 0x93, 0x94, 0x95, 0x96,
- 0x97, 0x98, 0x99, 0x9a, 0xa2, 0xa3, 0xa4, 0xa5,
- 0xa6, 0xa7, 0xa8, 0xa9, 0xaa, 0xb2, 0xb3, 0xb4,
- 0xb5, 0xb6, 0xb7, 0xb8, 0xb9, 0xba, 0xc2, 0xc3,
- 0xc4, 0xc5, 0xc6, 0xc7, 0xc8, 0xc9, 0xca, 0xd2,
- 0xd3, 0xd4, 0xd5, 0xd6, 0xd7, 0xd8, 0xd9, 0xda,
- 0xe2, 0xe3, 0xe4, 0xe5, 0xe6, 0xe7, 0xe8, 0xe9,
- 0xea, 0xf2, 0xf3, 0xf4, 0xf5, 0xf6, 0xf7, 0xf8,
- 0xf9, 0xfa };
-
- add_huff_table(cinfo, &cinfo->dc_huff_tbl_ptrs[0],
- bits_dc_luminance, val_dc_luminance);
- add_huff_table(cinfo, &cinfo->ac_huff_tbl_ptrs[0],
- bits_ac_luminance, val_ac_luminance);
- add_huff_table(cinfo, &cinfo->dc_huff_tbl_ptrs[1],
- bits_dc_chrominance, val_dc_chrominance);
- add_huff_table(cinfo, &cinfo->ac_huff_tbl_ptrs[1],
- bits_ac_chrominance, val_ac_chrominance);
+ if (cinfo->ac_huff_tbl_ptrs[1] != NULL)
+ (void) jpeg_std_huff_table((j_common_ptr) cinfo, FALSE, 1);
}
@@ -306,7 +217,7 @@ jpeg_set_defaults (j_compress_ptr cinfo)
cinfo->data_precision = BITS_IN_JSAMPLE;
/* Set up two quantization tables using default quality of 75 */
jpeg_set_quality(cinfo, 75, TRUE);
- /* Set up two Huffman tables */
+ /* Reset standard Huffman tables */
std_huff_tables(cinfo);
/* Initialize default arithmetic coding conditioning */
diff --git a/jpeg/jdarith.c b/jpeg/jdarith.c
index 5533c073..67363eb5 100644
--- a/jpeg/jdarith.c
+++ b/jpeg/jdarith.c
@@ -1,7 +1,7 @@
/*
* jdarith.c
*
- * Developed 1997-2015 by Guido Vollbeding.
+ * Developed 1997-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -150,8 +150,8 @@ arith_decode (j_decompress_ptr cinfo, unsigned char *st)
*/
sv = *st;
qe = jpeg_aritab[sv & 0x7F]; /* => Qe_Value */
- nl = qe & 0xFF; qe >>= 8; /* Next_Index_LPS + Switch_MPS */
- nm = qe & 0xFF; qe >>= 8; /* Next_Index_MPS */
+ nl = (unsigned char) (qe & 0xFF); qe >>= 8; /* Next_Index_LPS + Switch_MPS */
+ nm = (unsigned char) (qe & 0xFF); qe >>= 8; /* Next_Index_MPS */
/* Decode & estimation procedures per sections D.2.4 & D.2.5 */
temp = e->a - qe;
@@ -280,7 +280,7 @@ decode_mcu_DC_first (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
if ((m = arith_decode(cinfo, st)) != 0) {
st = entropy->dc_stats[tbl] + 20; /* Table F.4: X1 = 20 */
while (arith_decode(cinfo, st)) {
- if ((m <<= 1) == 0x8000) {
+ if ((m <<= 1) == (int) 0x8000U) {
WARNMS(cinfo, JWRN_ARITH_BAD_CODE);
entropy->ct = -1; /* magnitude overflow */
return TRUE;
@@ -370,7 +370,7 @@ decode_mcu_AC_first (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
st = entropy->ac_stats[tbl] +
(k <= cinfo->arith_ac_K[tbl] ? 189 : 217);
while (arith_decode(cinfo, st)) {
- if ((m <<= 1) == 0x8000) {
+ if ((m <<= 1) == (int) 0x8000U) {
WARNMS(cinfo, JWRN_ARITH_BAD_CODE);
entropy->ct = -1; /* magnitude overflow */
return TRUE;
@@ -404,7 +404,8 @@ decode_mcu_DC_refine (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
{
arith_entropy_ptr entropy = (arith_entropy_ptr) cinfo->entropy;
unsigned char *st;
- int p1, blkn;
+ JCOEF p1;
+ int blkn;
/* Process restart marker if needed */
if (cinfo->restart_interval) {
@@ -440,7 +441,7 @@ decode_mcu_AC_refine (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
JCOEFPTR thiscoef;
unsigned char *st;
int tbl, k, kex;
- int p1, m1;
+ JCOEF p1, m1;
const int * natural_order;
/* Process restart marker if needed */
@@ -459,7 +460,7 @@ decode_mcu_AC_refine (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
tbl = cinfo->cur_comp_info[0]->ac_tbl_no;
p1 = 1 << cinfo->Al; /* 1 in the bit position being coded */
- m1 = (-1) << cinfo->Al; /* -1 in the bit position being coded */
+ m1 = -p1; /* -1 in the bit position being coded */
/* Establish EOBx (previous stage end-of-block) index */
kex = cinfo->Se;
@@ -555,7 +556,7 @@ decode_mcu (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
if ((m = arith_decode(cinfo, st)) != 0) {
st = entropy->dc_stats[tbl] + 20; /* Table F.4: X1 = 20 */
while (arith_decode(cinfo, st)) {
- if ((m <<= 1) == 0x8000) {
+ if ((m <<= 1) == (int) 0x8000U) {
WARNMS(cinfo, JWRN_ARITH_BAD_CODE);
entropy->ct = -1; /* magnitude overflow */
return TRUE;
@@ -612,7 +613,7 @@ decode_mcu (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
st = entropy->ac_stats[tbl] +
(k <= cinfo->arith_ac_K[tbl] ? 189 : 217);
while (arith_decode(cinfo, st)) {
- if ((m <<= 1) == 0x8000) {
+ if ((m <<= 1) == (int) 0x8000U) {
WARNMS(cinfo, JWRN_ARITH_BAD_CODE);
entropy->ct = -1; /* magnitude overflow */
return TRUE;
@@ -766,9 +767,8 @@ jinit_arith_decoder (j_decompress_ptr cinfo)
arith_entropy_ptr entropy;
int i;
- entropy = (arith_entropy_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(arith_entropy_decoder));
+ entropy = (arith_entropy_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(arith_entropy_decoder));
cinfo->entropy = &entropy->pub;
entropy->pub.start_pass = start_pass;
entropy->pub.finish_pass = finish_pass;
@@ -785,9 +785,9 @@ jinit_arith_decoder (j_decompress_ptr cinfo)
if (cinfo->progressive_mode) {
/* Create progression status table */
int *coef_bit_ptr, ci;
- cinfo->coef_bits = (int (*)[DCTSIZE2])
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- cinfo->num_components*DCTSIZE2*SIZEOF(int));
+ cinfo->coef_bits = (int (*)[DCTSIZE2]) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE,
+ cinfo->num_components * DCTSIZE2 * SIZEOF(int));
coef_bit_ptr = & cinfo->coef_bits[0][0];
for (ci = 0; ci < cinfo->num_components; ci++)
for (i = 0; i < DCTSIZE2; i++)
diff --git a/jpeg/jdatadst.c b/jpeg/jdatadst.c
index dcac2293..75ebd7c2 100644
--- a/jpeg/jdatadst.c
+++ b/jpeg/jdatadst.c
@@ -2,7 +2,7 @@
* jdatadst.c
*
* Copyright (C) 1994-1996, Thomas G. Lane.
- * Modified 2009-2017 by Guido Vollbeding.
+ * Modified 2009-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -46,7 +46,7 @@ typedef struct {
struct jpeg_destination_mgr pub; /* public fields */
unsigned char ** outbuffer; /* target buffer */
- unsigned long * outsize;
+ size_t * outsize;
unsigned char * newbuffer; /* newly allocated buffer */
JOCTET * buffer; /* start of buffer */
size_t bufsize;
@@ -66,9 +66,8 @@ init_destination (j_compress_ptr cinfo)
my_dest_ptr dest = (my_dest_ptr) cinfo->dest;
/* Allocate the output buffer --- it will be released when done with image */
- dest->buffer = (JOCTET *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- OUTPUT_BUF_SIZE * SIZEOF(JOCTET));
+ dest->buffer = (JOCTET *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, OUTPUT_BUF_SIZE * SIZEOF(JOCTET));
dest->pub.next_output_byte = dest->buffer;
dest->pub.free_in_buffer = OUTPUT_BUF_SIZE;
@@ -131,7 +130,7 @@ empty_mem_output_buffer (j_compress_ptr cinfo)
nextbuffer = (JOCTET *) malloc(nextsize);
if (nextbuffer == NULL)
- ERREXIT1(cinfo, JERR_OUT_OF_MEMORY, 10);
+ ERREXIT1(cinfo, JERR_OUT_OF_MEMORY, 11);
MEMCOPY(nextbuffer, dest->buffer, dest->bufsize);
@@ -204,9 +203,8 @@ jpeg_stdio_dest (j_compress_ptr cinfo, FILE * outfile)
* sizes may be different. Caveat programmer.
*/
if (cinfo->dest == NULL) { /* first time for this JPEG object? */
- cinfo->dest = (struct jpeg_destination_mgr *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_PERMANENT,
- SIZEOF(my_destination_mgr));
+ cinfo->dest = (struct jpeg_destination_mgr *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_PERMANENT, SIZEOF(my_destination_mgr));
}
dest = (my_dest_ptr) cinfo->dest;
@@ -233,7 +231,7 @@ jpeg_stdio_dest (j_compress_ptr cinfo, FILE * outfile)
GLOBAL(void)
jpeg_mem_dest (j_compress_ptr cinfo,
- unsigned char ** outbuffer, unsigned long * outsize)
+ unsigned char ** outbuffer, size_t * outsize)
{
my_mem_dest_ptr dest;
@@ -244,9 +242,8 @@ jpeg_mem_dest (j_compress_ptr cinfo,
* can be written to the same buffer without re-executing jpeg_mem_dest.
*/
if (cinfo->dest == NULL) { /* first time for this JPEG object? */
- cinfo->dest = (struct jpeg_destination_mgr *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_PERMANENT,
- SIZEOF(my_mem_destination_mgr));
+ cinfo->dest = (struct jpeg_destination_mgr *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_PERMANENT, SIZEOF(my_mem_destination_mgr));
}
dest = (my_mem_dest_ptr) cinfo->dest;
diff --git a/jpeg/jdatasrc.c b/jpeg/jdatasrc.c
index 2a27cfed..606ae11b 100644
--- a/jpeg/jdatasrc.c
+++ b/jpeg/jdatasrc.c
@@ -2,7 +2,7 @@
* jdatasrc.c
*
* Copyright (C) 1994-1996, Thomas G. Lane.
- * Modified 2009-2015 by Guido Vollbeding.
+ * Modified 2009-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -156,21 +156,23 @@ METHODDEF(void)
skip_input_data (j_decompress_ptr cinfo, long num_bytes)
{
struct jpeg_source_mgr * src = cinfo->src;
+ size_t nbytes;
/* Just a dumb implementation for now. Could use fseek() except
* it doesn't work on pipes. Not clear that being smart is worth
* any trouble anyway --- large skips are infrequent.
*/
if (num_bytes > 0) {
- while (num_bytes > (long) src->bytes_in_buffer) {
- num_bytes -= (long) src->bytes_in_buffer;
+ nbytes = (size_t) num_bytes;
+ while (nbytes > src->bytes_in_buffer) {
+ nbytes -= src->bytes_in_buffer;
(void) (*src->fill_input_buffer) (cinfo);
/* note we assume that fill_input_buffer will never return FALSE,
* so suspension need not be handled.
*/
}
- src->next_input_byte += (size_t) num_bytes;
- src->bytes_in_buffer -= (size_t) num_bytes;
+ src->next_input_byte += nbytes;
+ src->bytes_in_buffer -= nbytes;
}
}
@@ -219,13 +221,11 @@ jpeg_stdio_src (j_decompress_ptr cinfo, FILE * infile)
* manager serially with the same JPEG object. Caveat programmer.
*/
if (cinfo->src == NULL) { /* first time for this JPEG object? */
- cinfo->src = (struct jpeg_source_mgr *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_PERMANENT,
- SIZEOF(my_source_mgr));
+ cinfo->src = (struct jpeg_source_mgr *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_PERMANENT, SIZEOF(my_source_mgr));
src = (my_src_ptr) cinfo->src;
- src->buffer = (JOCTET *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_PERMANENT,
- INPUT_BUF_SIZE * SIZEOF(JOCTET));
+ src->buffer = (JOCTET *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_PERMANENT, INPUT_BUF_SIZE * SIZEOF(JOCTET));
}
src = (my_src_ptr) cinfo->src;
@@ -247,7 +247,7 @@ jpeg_stdio_src (j_decompress_ptr cinfo, FILE * infile)
GLOBAL(void)
jpeg_mem_src (j_decompress_ptr cinfo,
- const unsigned char * inbuffer, unsigned long insize)
+ const unsigned char * inbuffer, size_t insize)
{
struct jpeg_source_mgr * src;
@@ -259,9 +259,8 @@ jpeg_mem_src (j_decompress_ptr cinfo,
* the first one.
*/
if (cinfo->src == NULL) { /* first time for this JPEG object? */
- cinfo->src = (struct jpeg_source_mgr *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_PERMANENT,
- SIZEOF(struct jpeg_source_mgr));
+ cinfo->src = (struct jpeg_source_mgr *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_PERMANENT, SIZEOF(struct jpeg_source_mgr));
}
src = cinfo->src;
@@ -270,6 +269,6 @@ jpeg_mem_src (j_decompress_ptr cinfo,
src->skip_input_data = skip_input_data;
src->resync_to_restart = jpeg_resync_to_restart; /* use default method */
src->term_source = term_source;
- src->bytes_in_buffer = (size_t) insize;
+ src->bytes_in_buffer = insize;
src->next_input_byte = (const JOCTET *) inbuffer;
}
diff --git a/jpeg/jdcolor.c b/jpeg/jdcolor.c
index 0316354d..3746c2e9 100644
--- a/jpeg/jdcolor.c
+++ b/jpeg/jdcolor.c
@@ -2,7 +2,7 @@
* jdcolor.c
*
* Copyright (C) 1991-1997, Thomas G. Lane.
- * Modified 2011-2017 by Guido Vollbeding.
+ * Modified 2011-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -124,28 +124,22 @@ build_ycc_rgb_table (j_decompress_ptr cinfo)
INT32 x;
SHIFT_TEMPS
- cconvert->Cr_r_tab = (int *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (MAXJSAMPLE+1) * SIZEOF(int));
- cconvert->Cb_b_tab = (int *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (MAXJSAMPLE+1) * SIZEOF(int));
- cconvert->Cr_g_tab = (INT32 *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (MAXJSAMPLE+1) * SIZEOF(INT32));
- cconvert->Cb_g_tab = (INT32 *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (MAXJSAMPLE+1) * SIZEOF(INT32));
+ cconvert->Cr_r_tab = (int *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, (MAXJSAMPLE+1) * SIZEOF(int));
+ cconvert->Cb_b_tab = (int *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, (MAXJSAMPLE+1) * SIZEOF(int));
+ cconvert->Cr_g_tab = (INT32 *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, (MAXJSAMPLE+1) * SIZEOF(INT32));
+ cconvert->Cb_g_tab = (INT32 *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, (MAXJSAMPLE+1) * SIZEOF(INT32));
for (i = 0, x = -CENTERJSAMPLE; i <= MAXJSAMPLE; i++, x++) {
/* i is the actual input pixel value, in the range 0..MAXJSAMPLE */
/* The Cb or Cr value we are thinking of is x = i - CENTERJSAMPLE */
/* Cr=>R value is nearest int to 1.402 * x */
- cconvert->Cr_r_tab[i] = (int)
- RIGHT_SHIFT(FIX(1.402) * x + ONE_HALF, SCALEBITS);
+ cconvert->Cr_r_tab[i] = (int) DESCALE(FIX(1.402) * x, SCALEBITS);
/* Cb=>B value is nearest int to 1.772 * x */
- cconvert->Cb_b_tab[i] = (int)
- RIGHT_SHIFT(FIX(1.772) * x + ONE_HALF, SCALEBITS);
+ cconvert->Cb_b_tab[i] = (int) DESCALE(FIX(1.772) * x, SCALEBITS);
/* Cr=>G value is scaled-up -0.714136286 * x */
cconvert->Cr_g_tab[i] = (- FIX(0.714136286)) * x;
/* Cb=>G value is scaled-up -0.344136286 * x */
@@ -164,28 +158,22 @@ build_bg_ycc_rgb_table (j_decompress_ptr cinfo)
INT32 x;
SHIFT_TEMPS
- cconvert->Cr_r_tab = (int *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (MAXJSAMPLE+1) * SIZEOF(int));
- cconvert->Cb_b_tab = (int *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (MAXJSAMPLE+1) * SIZEOF(int));
- cconvert->Cr_g_tab = (INT32 *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (MAXJSAMPLE+1) * SIZEOF(INT32));
- cconvert->Cb_g_tab = (INT32 *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (MAXJSAMPLE+1) * SIZEOF(INT32));
+ cconvert->Cr_r_tab = (int *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, (MAXJSAMPLE+1) * SIZEOF(int));
+ cconvert->Cb_b_tab = (int *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, (MAXJSAMPLE+1) * SIZEOF(int));
+ cconvert->Cr_g_tab = (INT32 *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, (MAXJSAMPLE+1) * SIZEOF(INT32));
+ cconvert->Cb_g_tab = (INT32 *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, (MAXJSAMPLE+1) * SIZEOF(INT32));
for (i = 0, x = -CENTERJSAMPLE; i <= MAXJSAMPLE; i++, x++) {
/* i is the actual input pixel value, in the range 0..MAXJSAMPLE */
/* The Cb or Cr value we are thinking of is x = i - CENTERJSAMPLE */
/* Cr=>R value is nearest int to 2.804 * x */
- cconvert->Cr_r_tab[i] = (int)
- RIGHT_SHIFT(FIX(2.804) * x + ONE_HALF, SCALEBITS);
+ cconvert->Cr_r_tab[i] = (int) DESCALE(FIX(2.804) * x, SCALEBITS);
/* Cb=>B value is nearest int to 3.544 * x */
- cconvert->Cb_b_tab[i] = (int)
- RIGHT_SHIFT(FIX(3.544) * x + ONE_HALF, SCALEBITS);
+ cconvert->Cb_b_tab[i] = (int) DESCALE(FIX(3.544) * x, SCALEBITS);
/* Cr=>G value is scaled-up -1.428272572 * x */
cconvert->Cr_g_tab[i] = (- FIX(1.428272572)) * x;
/* Cb=>G value is scaled-up -0.688272572 * x */
@@ -201,6 +189,7 @@ build_bg_ycc_rgb_table (j_decompress_ptr cinfo)
* Note that we change from noninterleaved, one-plane-per-component format
* to interleaved-pixel format. The output buffer is therefore three times
* as wide as the input buffer.
+ *
* A starting row offset is provided only for the input buffer. The caller
* can easily adjust the passed output_buf value to accommodate any row
* offset required on that side.
@@ -264,9 +253,8 @@ build_rgb_y_table (j_decompress_ptr cinfo)
INT32 i;
/* Allocate and fill in the conversion tables. */
- cconvert->rgb_y_tab = rgb_y_tab = (INT32 *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (TABLE_SIZE * SIZEOF(INT32)));
+ cconvert->rgb_y_tab = rgb_y_tab = (INT32 *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, TABLE_SIZE * SIZEOF(INT32));
for (i = 0; i <= MAXJSAMPLE; i++) {
rgb_y_tab[i+R_Y_OFF] = FIX(0.299) * i;
@@ -286,8 +274,8 @@ rgb_gray_convert (j_decompress_ptr cinfo,
JSAMPARRAY output_buf, int num_rows)
{
my_cconvert_ptr cconvert = (my_cconvert_ptr) cinfo->cconvert;
- register INT32 * ctab = cconvert->rgb_y_tab;
register int r, g, b;
+ register INT32 * ctab = cconvert->rgb_y_tab;
register JSAMPROW outptr;
register JSAMPROW inptr0, inptr1, inptr2;
register JDIMENSION col;
@@ -313,6 +301,7 @@ rgb_gray_convert (j_decompress_ptr cinfo,
/*
+ * Convert some rows of samples to the output colorspace.
* [R-G,G,B-G] to [R,G,B] conversion with modulo calculation
* (inverse color transform).
* This can be seen as an adaption of the general YCbCr->RGB
@@ -364,8 +353,8 @@ rgb1_gray_convert (j_decompress_ptr cinfo,
JSAMPARRAY output_buf, int num_rows)
{
my_cconvert_ptr cconvert = (my_cconvert_ptr) cinfo->cconvert;
- register INT32 * ctab = cconvert->rgb_y_tab;
register int r, g, b;
+ register INT32 * ctab = cconvert->rgb_y_tab;
register JSAMPROW outptr;
register JSAMPROW inptr0, inptr1, inptr2;
register JDIMENSION col;
@@ -396,6 +385,7 @@ rgb1_gray_convert (j_decompress_ptr cinfo,
/*
+ * Convert some rows of samples to the output colorspace.
* No colorspace change, but conversion from separate-planes
* to interleaved representation.
*/
@@ -430,6 +420,7 @@ rgb_convert (j_decompress_ptr cinfo,
/*
* Color conversion for no colorspace change: just copy the data,
* converting from separate-planes to interleaved representation.
+ * We assume out_color_components == num_components.
*/
METHODDEF(void)
@@ -437,20 +428,21 @@ null_convert (j_decompress_ptr cinfo,
JSAMPIMAGE input_buf, JDIMENSION input_row,
JSAMPARRAY output_buf, int num_rows)
{
- int ci;
- register int nc = cinfo->num_components;
register JSAMPROW outptr;
register JSAMPROW inptr;
- register JDIMENSION col;
+ register JDIMENSION count;
+ register int num_comps = cinfo->num_components;
JDIMENSION num_cols = cinfo->output_width;
+ int ci;
while (--num_rows >= 0) {
- for (ci = 0; ci < nc; ci++) {
+ /* It seems fastest to make a separate pass for each component. */
+ for (ci = 0; ci < num_comps; ci++) {
inptr = input_buf[ci][input_row];
outptr = output_buf[0] + ci;
- for (col = 0; col < num_cols; col++) {
- *outptr = *inptr++; /* needn't bother with GETJSAMPLE() here */
- outptr += nc;
+ for (count = num_cols; count > 0; count--) {
+ *outptr = *inptr++; /* don't need GETJSAMPLE() here */
+ outptr += num_comps;
}
}
input_row++;
@@ -504,9 +496,10 @@ gray_rgb_convert (j_decompress_ptr cinfo,
/*
- * Adobe-style YCCK->CMYK conversion.
- * We convert YCbCr to R=1-C, G=1-M, and B=1-Y using the same
- * conversion as above, while passing K (black) unchanged.
+ * Convert some rows of samples to the output colorspace.
+ * This version handles Adobe-style YCCK->CMYK conversion,
+ * where we convert YCbCr to R=1-C, G=1-M, and B=1-Y using the
+ * same conversion as above, while passing K (black) unchanged.
* We assume build_ycc_rgb_table has been called.
*/
@@ -577,9 +570,8 @@ jinit_color_deconverter (j_decompress_ptr cinfo)
my_cconvert_ptr cconvert;
int ci;
- cconvert = (my_cconvert_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(my_color_deconverter));
+ cconvert = (my_cconvert_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(my_color_deconverter));
cinfo->cconvert = &cconvert->pub;
cconvert->pub.start_pass = start_pass_dcolor;
@@ -607,7 +599,6 @@ jinit_color_deconverter (j_decompress_ptr cinfo)
default: /* JCS_UNKNOWN can be anything */
if (cinfo->num_components < 1)
ERREXIT(cinfo, JERR_BAD_J_COLORSPACE);
- break;
}
/* Support color transform only for RGB colorspaces */
@@ -684,19 +675,18 @@ jinit_color_deconverter (j_decompress_ptr cinfo)
case JCS_BG_RGB:
cinfo->out_color_components = RGB_PIXELSIZE;
- if (cinfo->jpeg_color_space == JCS_BG_RGB) {
- switch (cinfo->color_transform) {
- case JCT_NONE:
- cconvert->pub.color_convert = rgb_convert;
- break;
- case JCT_SUBTRACT_GREEN:
- cconvert->pub.color_convert = rgb1_rgb_convert;
- break;
- default:
- ERREXIT(cinfo, JERR_CONVERSION_NOTIMPL);
- }
- } else
+ if (cinfo->jpeg_color_space != JCS_BG_RGB)
ERREXIT(cinfo, JERR_CONVERSION_NOTIMPL);
+ switch (cinfo->color_transform) {
+ case JCT_NONE:
+ cconvert->pub.color_convert = rgb_convert;
+ break;
+ case JCT_SUBTRACT_GREEN:
+ cconvert->pub.color_convert = rgb1_rgb_convert;
+ break;
+ default:
+ ERREXIT(cinfo, JERR_CONVERSION_NOTIMPL);
+ }
break;
case JCS_CMYK:
@@ -714,14 +704,12 @@ jinit_color_deconverter (j_decompress_ptr cinfo)
}
break;
- default:
- /* Permit null conversion to same output space */
- if (cinfo->out_color_space == cinfo->jpeg_color_space) {
- cinfo->out_color_components = cinfo->num_components;
- cconvert->pub.color_convert = null_convert;
- } else /* unsupported non-null conversion */
+ default: /* permit null conversion to same output space */
+ if (cinfo->out_color_space != cinfo->jpeg_color_space)
+ /* unsupported non-null conversion */
ERREXIT(cinfo, JERR_CONVERSION_NOTIMPL);
- break;
+ cinfo->out_color_components = cinfo->num_components;
+ cconvert->pub.color_convert = null_convert;
}
if (cinfo->quantize_colors)
diff --git a/jpeg/jdct.h b/jpeg/jdct.h
index bcfedfcf..c8ec6cd9 100644
--- a/jpeg/jdct.h
+++ b/jpeg/jdct.h
@@ -2,7 +2,7 @@
* jdct.h
*
* Copyright (C) 1994-1996, Thomas G. Lane.
- * Modified 2002-2017 by Guido Vollbeding.
+ * Modified 2002-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -358,13 +358,6 @@ EXTERN(void) jpeg_idct_1x2
#define FIX(x) ((INT32) ((x) * CONST_SCALE + 0.5))
-/* Descale and correctly round an INT32 value that's scaled by N bits.
- * We assume RIGHT_SHIFT rounds towards minus infinity, so adding
- * the fudge factor is correct for either sign of X.
- */
-
-#define DESCALE(x,n) RIGHT_SHIFT((x) + (ONE << ((n)-1)), n)
-
/* Multiply an INT32 variable by an INT32 constant to yield an INT32 result.
* This macro is used only when the two inputs will actually be no more than
* 16 bits wide, so that a 16x16->32 bit multiply can be used instead of a
diff --git a/jpeg/jdhuff.c b/jpeg/jdhuff.c
index 835d06ec..aea06f60 100644
--- a/jpeg/jdhuff.c
+++ b/jpeg/jdhuff.c
@@ -2,7 +2,7 @@
* jdhuff.c
*
* Copyright (C) 1991-1997, Thomas G. Lane.
- * Modified 2006-2016 by Guido Vollbeding.
+ * Modified 2006-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -341,13 +341,12 @@ jpeg_make_d_derived_tbl (j_decompress_ptr cinfo, boolean isDC, int tblno,
htbl =
isDC ? cinfo->dc_huff_tbl_ptrs[tblno] : cinfo->ac_huff_tbl_ptrs[tblno];
if (htbl == NULL)
- ERREXIT1(cinfo, JERR_NO_HUFF_TABLE, tblno);
+ htbl = jpeg_std_huff_table((j_common_ptr) cinfo, isDC, tblno);
/* Allocate a workspace if we haven't already done so. */
if (*pdtbl == NULL)
- *pdtbl = (d_derived_tbl *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(d_derived_tbl));
+ *pdtbl = (d_derived_tbl *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(d_derived_tbl));
dtbl = *pdtbl;
dtbl->pub = htbl; /* fill in back link */
@@ -706,7 +705,7 @@ process_restart (j_decompress_ptr cinfo)
METHODDEF(boolean)
decode_mcu_DC_first (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
-{
+{
huff_entropy_ptr entropy = (huff_entropy_ptr) cinfo->entropy;
int Al = cinfo->Al;
register int s, r;
@@ -730,7 +729,7 @@ decode_mcu_DC_first (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
if (! entropy->insufficient_data) {
/* Load up working state */
- BITREAD_LOAD_STATE(cinfo,entropy->bitstate);
+ BITREAD_LOAD_STATE(cinfo, entropy->bitstate);
ASSIGN_STATE(state, entropy->saved);
/* Outer loop handles each block in the MCU */
@@ -759,12 +758,13 @@ decode_mcu_DC_first (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
}
/* Completed MCU, so update state */
- BITREAD_SAVE_STATE(cinfo,entropy->bitstate);
+ BITREAD_SAVE_STATE(cinfo, entropy->bitstate);
ASSIGN_STATE(entropy->saved, state);
}
- /* Account for restart interval (no-op if not using restarts) */
- entropy->restarts_to_go--;
+ /* Account for restart interval if using restarts */
+ if (cinfo->restart_interval)
+ entropy->restarts_to_go--;
return TRUE;
}
@@ -777,7 +777,7 @@ decode_mcu_DC_first (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
METHODDEF(boolean)
decode_mcu_AC_first (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
-{
+{
huff_entropy_ptr entropy = (huff_entropy_ptr) cinfo->entropy;
register int s, k, r;
unsigned int EOBRUN;
@@ -809,7 +809,7 @@ decode_mcu_AC_first (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
if (EOBRUN) /* if it's a band of zeroes... */
EOBRUN--; /* ...process it now (we do nothing) */
else {
- BITREAD_LOAD_STATE(cinfo,entropy->bitstate);
+ BITREAD_LOAD_STATE(cinfo, entropy->bitstate);
Se = cinfo->Se;
Al = cinfo->Al;
natural_order = cinfo->natural_order;
@@ -842,15 +842,16 @@ decode_mcu_AC_first (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
}
}
- BITREAD_SAVE_STATE(cinfo,entropy->bitstate);
+ BITREAD_SAVE_STATE(cinfo, entropy->bitstate);
}
/* Completed MCU, so update state */
entropy->saved.EOBRUN = EOBRUN; /* only part of saved state we need */
}
- /* Account for restart interval (no-op if not using restarts) */
- entropy->restarts_to_go--;
+ /* Account for restart interval if using restarts */
+ if (cinfo->restart_interval)
+ entropy->restarts_to_go--;
return TRUE;
}
@@ -864,9 +865,10 @@ decode_mcu_AC_first (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
METHODDEF(boolean)
decode_mcu_DC_refine (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
-{
+{
huff_entropy_ptr entropy = (huff_entropy_ptr) cinfo->entropy;
- int p1, blkn;
+ JCOEF p1;
+ int blkn;
BITREAD_STATE_VARS;
/* Process restart marker if needed; may have to suspend */
@@ -881,7 +883,7 @@ decode_mcu_DC_refine (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
*/
/* Load up working state */
- BITREAD_LOAD_STATE(cinfo,entropy->bitstate);
+ BITREAD_LOAD_STATE(cinfo, entropy->bitstate);
p1 = 1 << cinfo->Al; /* 1 in the bit position being coded */
@@ -896,10 +898,11 @@ decode_mcu_DC_refine (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
}
/* Completed MCU, so update state */
- BITREAD_SAVE_STATE(cinfo,entropy->bitstate);
+ BITREAD_SAVE_STATE(cinfo, entropy->bitstate);
- /* Account for restart interval (no-op if not using restarts) */
- entropy->restarts_to_go--;
+ /* Account for restart interval if using restarts */
+ if (cinfo->restart_interval)
+ entropy->restarts_to_go--;
return TRUE;
}
@@ -911,11 +914,12 @@ decode_mcu_DC_refine (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
METHODDEF(boolean)
decode_mcu_AC_refine (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
-{
+{
huff_entropy_ptr entropy = (huff_entropy_ptr) cinfo->entropy;
register int s, k, r;
unsigned int EOBRUN;
- int Se, p1, m1;
+ int Se;
+ JCOEF p1, m1;
const int * natural_order;
JBLOCKROW block;
JCOEFPTR thiscoef;
@@ -937,11 +941,11 @@ decode_mcu_AC_refine (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
Se = cinfo->Se;
p1 = 1 << cinfo->Al; /* 1 in the bit position being coded */
- m1 = (-1) << cinfo->Al; /* -1 in the bit position being coded */
+ m1 = -p1; /* -1 in the bit position being coded */
natural_order = cinfo->natural_order;
/* Load up working state */
- BITREAD_LOAD_STATE(cinfo,entropy->bitstate);
+ BITREAD_LOAD_STATE(cinfo, entropy->bitstate);
EOBRUN = entropy->saved.EOBRUN; /* only part of saved state we need */
/* There is always only one block per MCU */
@@ -1043,12 +1047,13 @@ decode_mcu_AC_refine (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
}
/* Completed MCU, so update state */
- BITREAD_SAVE_STATE(cinfo,entropy->bitstate);
+ BITREAD_SAVE_STATE(cinfo, entropy->bitstate);
entropy->saved.EOBRUN = EOBRUN; /* only part of saved state we need */
}
- /* Account for restart interval (no-op if not using restarts) */
- entropy->restarts_to_go--;
+ /* Account for restart interval if using restarts */
+ if (cinfo->restart_interval)
+ entropy->restarts_to_go--;
return TRUE;
@@ -1091,7 +1096,7 @@ decode_mcu_sub (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
Se = cinfo->lim_Se;
/* Load up working state */
- BITREAD_LOAD_STATE(cinfo,entropy->bitstate);
+ BITREAD_LOAD_STATE(cinfo, entropy->bitstate);
ASSIGN_STATE(state, entropy->saved);
/* Outer loop handles each block in the MCU */
@@ -1178,12 +1183,13 @@ decode_mcu_sub (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
}
/* Completed MCU, so update state */
- BITREAD_SAVE_STATE(cinfo,entropy->bitstate);
+ BITREAD_SAVE_STATE(cinfo, entropy->bitstate);
ASSIGN_STATE(entropy->saved, state);
}
- /* Account for restart interval (no-op if not using restarts) */
- entropy->restarts_to_go--;
+ /* Account for restart interval if using restarts */
+ if (cinfo->restart_interval)
+ entropy->restarts_to_go--;
return TRUE;
}
@@ -1215,7 +1221,7 @@ decode_mcu (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
if (! entropy->insufficient_data) {
/* Load up working state */
- BITREAD_LOAD_STATE(cinfo,entropy->bitstate);
+ BITREAD_LOAD_STATE(cinfo, entropy->bitstate);
ASSIGN_STATE(state, entropy->saved);
/* Outer loop handles each block in the MCU */
@@ -1302,12 +1308,13 @@ decode_mcu (j_decompress_ptr cinfo, JBLOCKROW *MCU_data)
}
/* Completed MCU, so update state */
- BITREAD_SAVE_STATE(cinfo,entropy->bitstate);
+ BITREAD_SAVE_STATE(cinfo, entropy->bitstate);
ASSIGN_STATE(entropy->saved, state);
}
- /* Account for restart interval (no-op if not using restarts) */
- entropy->restarts_to_go--;
+ /* Account for restart interval if using restarts */
+ if (cinfo->restart_interval)
+ entropy->restarts_to_go--;
return TRUE;
}
@@ -1343,11 +1350,11 @@ start_pass_huff_decoder (j_decompress_ptr cinfo)
goto bad;
}
if (cinfo->Al > 13) { /* need not check for < 0 */
- /* Arguably the maximum Al value should be less than 13 for 8-bit precision,
- * but the spec doesn't say so, and we try to be liberal about what we
- * accept. Note: large Al values could result in out-of-range DC
- * coefficients during early scans, leading to bizarre displays due to
- * overflows in the IDCT math. But we won't crash.
+ /* Arguably the maximum Al value should be less than 13 for 8-bit
+ * precision, but the spec doesn't say so, and we try to be liberal
+ * about what we accept. Note: large Al values could result in
+ * out-of-range DC coefficients during early scans, leading to bizarre
+ * displays due to overflows in the IDCT math. But we won't crash.
*/
bad:
ERREXIT4(cinfo, JERR_BAD_PROGRESSION,
@@ -1451,7 +1458,8 @@ start_pass_huff_decoder (j_decompress_ptr cinfo)
compptr = cinfo->cur_comp_info[ci];
/* Precalculate which table to use for each block */
entropy->dc_cur_tbls[blkn] = entropy->dc_derived_tbls[compptr->dc_tbl_no];
- entropy->ac_cur_tbls[blkn] = entropy->ac_derived_tbls[compptr->ac_tbl_no];
+ entropy->ac_cur_tbls[blkn] = /* AC needs no table when not present */
+ cinfo->lim_Se ? entropy->ac_derived_tbls[compptr->ac_tbl_no] : NULL;
/* Decide whether we really care about the coefficient values */
if (compptr->component_needed) {
ci = compptr->DCT_v_scaled_size;
@@ -1494,7 +1502,6 @@ start_pass_huff_decoder (j_decompress_ptr cinfo)
if (ci <= 0 || ci > 8) ci = 8;
if (i <= 0 || i > 8) i = 8;
entropy->coef_limit[blkn] = 1 + jpeg_zigzag_order[ci - 1][i - 1];
- break;
}
} else {
entropy->coef_limit[blkn] = 0;
@@ -1522,9 +1529,8 @@ jinit_huff_decoder (j_decompress_ptr cinfo)
huff_entropy_ptr entropy;
int i;
- entropy = (huff_entropy_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(huff_entropy_decoder));
+ entropy = (huff_entropy_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(huff_entropy_decoder));
cinfo->entropy = &entropy->pub;
entropy->pub.start_pass = start_pass_huff_decoder;
entropy->pub.finish_pass = finish_pass_huff;
@@ -1532,9 +1538,9 @@ jinit_huff_decoder (j_decompress_ptr cinfo)
if (cinfo->progressive_mode) {
/* Create progression status table */
int *coef_bit_ptr, ci;
- cinfo->coef_bits = (int (*)[DCTSIZE2])
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- cinfo->num_components*DCTSIZE2*SIZEOF(int));
+ cinfo->coef_bits = (int (*)[DCTSIZE2]) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE,
+ cinfo->num_components * DCTSIZE2 * SIZEOF(int));
coef_bit_ptr = & cinfo->coef_bits[0][0];
for (ci = 0; ci < cinfo->num_components; ci++)
for (i = 0; i < DCTSIZE2; i++)
@@ -1545,7 +1551,7 @@ jinit_huff_decoder (j_decompress_ptr cinfo)
entropy->derived_tbls[i] = NULL;
}
} else {
- /* Mark tables unallocated */
+ /* Mark derived tables unallocated */
for (i = 0; i < NUM_HUFF_TBLS; i++) {
entropy->dc_derived_tbls[i] = entropy->ac_derived_tbls[i] = NULL;
}
diff --git a/jpeg/jdmarker.c b/jpeg/jdmarker.c
index 3fbe5c16..c10fde60 100644
--- a/jpeg/jdmarker.c
+++ b/jpeg/jdmarker.c
@@ -2,7 +2,7 @@
* jdmarker.c
*
* Copyright (C) 1991-1998, Thomas G. Lane.
- * Modified 2009-2013 by Guido Vollbeding.
+ * Modified 2009-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -496,8 +496,6 @@ get_dht (j_decompress_ptr cinfo)
if (count > 256 || ((INT32) count) > length)
ERREXIT(cinfo, JERR_BAD_HUFF_TABLE);
- MEMZERO(huffval, SIZEOF(huffval)); /* pre-zero array for later copy */
-
for (i = 0; i < count; i++)
INPUT_BYTE(cinfo, huffval[i], return FALSE);
@@ -517,7 +515,8 @@ get_dht (j_decompress_ptr cinfo)
*htblptr = jpeg_alloc_huff_table((j_common_ptr) cinfo);
MEMCOPY((*htblptr)->bits, bits, SIZEOF((*htblptr)->bits));
- MEMCOPY((*htblptr)->huffval, huffval, SIZEOF((*htblptr)->huffval));
+ if (count > 0)
+ MEMCOPY((*htblptr)->huffval, huffval, count * SIZEOF(UINT8));
}
if (length != 0)
@@ -577,14 +576,14 @@ get_dqt (j_decompress_ptr cinfo)
count = DCTSIZE2;
}
- switch (count) {
+ switch ((int) count) {
case (2*2): natural_order = jpeg_natural_order2; break;
case (3*3): natural_order = jpeg_natural_order3; break;
case (4*4): natural_order = jpeg_natural_order4; break;
case (5*5): natural_order = jpeg_natural_order5; break;
case (6*6): natural_order = jpeg_natural_order6; break;
case (7*7): natural_order = jpeg_natural_order7; break;
- default: natural_order = jpeg_natural_order; break;
+ default: natural_order = jpeg_natural_order;
}
for (i = 0; i < count; i++) {
@@ -784,7 +783,6 @@ examine_app0 (j_decompress_ptr cinfo, JOCTET FAR * data,
default:
TRACEMS2(cinfo, 1, JTRC_JFIF_EXTENSION,
GETJOCTET(data[5]), (int) totallen);
- break;
}
} else {
/* Start of APP0 does not match "JFIF" or "JFXX", or too short */
@@ -858,7 +856,6 @@ get_interesting_appn (j_decompress_ptr cinfo)
default:
/* can't get here unless jpeg_save_markers chooses wrong processor */
ERREXIT1(cinfo, JERR_UNKNOWN_MARKER, cinfo->unread_marker);
- break;
}
/* skip any remaining data -- could be lots */
@@ -964,7 +961,6 @@ save_marker (j_decompress_ptr cinfo)
default:
TRACEMS2(cinfo, 1, JTRC_MISC_MARKER, cinfo->unread_marker,
(int) (data_length + length));
- break;
}
/* skip any remaining data -- could be lots */
@@ -1240,7 +1236,6 @@ read_markers (j_decompress_ptr cinfo)
* ought to change!
*/
ERREXIT1(cinfo, JERR_UNKNOWN_MARKER, cinfo->unread_marker);
- break;
}
/* Successfully processed marker, so reset state variable */
cinfo->unread_marker = 0;
@@ -1416,9 +1411,8 @@ jinit_marker_reader (j_decompress_ptr cinfo)
int i;
/* Create subobject in permanent pool */
- marker = (my_marker_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_PERMANENT,
- SIZEOF(my_marker_reader));
+ marker = (my_marker_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_PERMANENT, SIZEOF(my_marker_reader));
cinfo->marker = &marker->pub;
/* Initialize public method pointers */
marker->pub.reset_marker_reader = reset_marker_reader;
diff --git a/jpeg/jdmaster.c b/jpeg/jdmaster.c
index 62c07671..c309f762 100644
--- a/jpeg/jdmaster.c
+++ b/jpeg/jdmaster.c
@@ -2,7 +2,7 @@
* jdmaster.c
*
* Copyright (C) 1991-1997, Thomas G. Lane.
- * Modified 2002-2017 by Guido Vollbeding.
+ * Modified 2002-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -104,7 +104,7 @@ jpeg_calc_output_dimensions (j_decompress_ptr cinfo)
*/
{
#ifdef IDCT_SCALING_SUPPORTED
- int ci;
+ int ci, ssize;
jpeg_component_info *compptr;
#endif
@@ -124,19 +124,23 @@ jpeg_calc_output_dimensions (j_decompress_ptr cinfo)
*/
for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
ci++, compptr++) {
- int ssize = 1;
- while (cinfo->min_DCT_h_scaled_size * ssize <=
- (cinfo->do_fancy_upsampling ? DCTSIZE : DCTSIZE / 2) &&
- (cinfo->max_h_samp_factor % (compptr->h_samp_factor * ssize * 2)) == 0) {
- ssize = ssize * 2;
- }
+ ssize = 1;
+ if (! cinfo->raw_data_out)
+ while (cinfo->min_DCT_h_scaled_size * ssize <=
+ (cinfo->do_fancy_upsampling ? DCTSIZE : DCTSIZE / 2) &&
+ (cinfo->max_h_samp_factor % (compptr->h_samp_factor * ssize * 2)) ==
+ 0) {
+ ssize = ssize * 2;
+ }
compptr->DCT_h_scaled_size = cinfo->min_DCT_h_scaled_size * ssize;
ssize = 1;
- while (cinfo->min_DCT_v_scaled_size * ssize <=
- (cinfo->do_fancy_upsampling ? DCTSIZE : DCTSIZE / 2) &&
- (cinfo->max_v_samp_factor % (compptr->v_samp_factor * ssize * 2)) == 0) {
- ssize = ssize * 2;
- }
+ if (! cinfo->raw_data_out)
+ while (cinfo->min_DCT_v_scaled_size * ssize <=
+ (cinfo->do_fancy_upsampling ? DCTSIZE : DCTSIZE / 2) &&
+ (cinfo->max_v_samp_factor % (compptr->v_samp_factor * ssize * 2)) ==
+ 0) {
+ ssize = ssize * 2;
+ }
compptr->DCT_v_scaled_size = cinfo->min_DCT_v_scaled_size * ssize;
/* We don't support IDCT ratios larger than 2. */
@@ -144,13 +148,10 @@ jpeg_calc_output_dimensions (j_decompress_ptr cinfo)
compptr->DCT_h_scaled_size = compptr->DCT_v_scaled_size * 2;
else if (compptr->DCT_v_scaled_size > compptr->DCT_h_scaled_size * 2)
compptr->DCT_v_scaled_size = compptr->DCT_h_scaled_size * 2;
- }
- /* Recompute downsampled dimensions of components;
- * application needs to know these if using raw downsampled data.
- */
- for (ci = 0, compptr = cinfo->comp_info; ci < cinfo->num_components;
- ci++, compptr++) {
+ /* Recompute downsampled dimensions of components;
+ * application needs to know these if using raw downsampled data.
+ */
/* Size in samples, after IDCT scaling */
compptr->downsampled_width = (JDIMENSION)
jdiv_round_up((long) cinfo->image_width *
@@ -172,8 +173,10 @@ jpeg_calc_output_dimensions (j_decompress_ptr cinfo)
break;
case JCS_RGB:
case JCS_BG_RGB:
+#if RGB_PIXELSIZE != 3
cinfo->out_color_components = RGB_PIXELSIZE;
break;
+#endif /* else share code with YCbCr */
case JCS_YCbCr:
case JCS_BG_YCC:
cinfo->out_color_components = 3;
@@ -184,7 +187,6 @@ jpeg_calc_output_dimensions (j_decompress_ptr cinfo)
break;
default: /* else must be same colorspace as in file */
cinfo->out_color_components = cinfo->num_components;
- break;
}
cinfo->output_components = (cinfo->quantize_colors ? 1 :
cinfo->out_color_components);
@@ -525,9 +527,8 @@ jinit_master_decompress (j_decompress_ptr cinfo)
{
my_master_ptr master;
- master = (my_master_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(my_decomp_master));
+ master = (my_master_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(my_decomp_master));
cinfo->master = &master->pub;
master->pub.prepare_for_output_pass = prepare_for_output_pass;
master->pub.finish_output_pass = finish_output_pass;
diff --git a/jpeg/jdmerge.c b/jpeg/jdmerge.c
index 866693f5..8b5c899c 100644
--- a/jpeg/jdmerge.c
+++ b/jpeg/jdmerge.c
@@ -2,7 +2,7 @@
* jdmerge.c
*
* Copyright (C) 1994-1996, Thomas G. Lane.
- * Modified 2013-2017 by Guido Vollbeding.
+ * Modified 2013-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -95,28 +95,22 @@ build_ycc_rgb_table (j_decompress_ptr cinfo)
INT32 x;
SHIFT_TEMPS
- upsample->Cr_r_tab = (int *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (MAXJSAMPLE+1) * SIZEOF(int));
- upsample->Cb_b_tab = (int *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (MAXJSAMPLE+1) * SIZEOF(int));
- upsample->Cr_g_tab = (INT32 *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (MAXJSAMPLE+1) * SIZEOF(INT32));
- upsample->Cb_g_tab = (INT32 *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (MAXJSAMPLE+1) * SIZEOF(INT32));
+ upsample->Cr_r_tab = (int *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, (MAXJSAMPLE+1) * SIZEOF(int));
+ upsample->Cb_b_tab = (int *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, (MAXJSAMPLE+1) * SIZEOF(int));
+ upsample->Cr_g_tab = (INT32 *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, (MAXJSAMPLE+1) * SIZEOF(INT32));
+ upsample->Cb_g_tab = (INT32 *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, (MAXJSAMPLE+1) * SIZEOF(INT32));
for (i = 0, x = -CENTERJSAMPLE; i <= MAXJSAMPLE; i++, x++) {
/* i is the actual input pixel value, in the range 0..MAXJSAMPLE */
/* The Cb or Cr value we are thinking of is x = i - CENTERJSAMPLE */
/* Cr=>R value is nearest int to 1.402 * x */
- upsample->Cr_r_tab[i] = (int)
- RIGHT_SHIFT(FIX(1.402) * x + ONE_HALF, SCALEBITS);
+ upsample->Cr_r_tab[i] = (int) DESCALE(FIX(1.402) * x, SCALEBITS);
/* Cb=>B value is nearest int to 1.772 * x */
- upsample->Cb_b_tab[i] = (int)
- RIGHT_SHIFT(FIX(1.772) * x + ONE_HALF, SCALEBITS);
+ upsample->Cb_b_tab[i] = (int) DESCALE(FIX(1.772) * x, SCALEBITS);
/* Cr=>G value is scaled-up -0.714136286 * x */
upsample->Cr_g_tab[i] = (- FIX(0.714136286)) * x;
/* Cb=>G value is scaled-up -0.344136286 * x */
@@ -135,28 +129,22 @@ build_bg_ycc_rgb_table (j_decompress_ptr cinfo)
INT32 x;
SHIFT_TEMPS
- upsample->Cr_r_tab = (int *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (MAXJSAMPLE+1) * SIZEOF(int));
- upsample->Cb_b_tab = (int *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (MAXJSAMPLE+1) * SIZEOF(int));
- upsample->Cr_g_tab = (INT32 *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (MAXJSAMPLE+1) * SIZEOF(INT32));
- upsample->Cb_g_tab = (INT32 *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (MAXJSAMPLE+1) * SIZEOF(INT32));
+ upsample->Cr_r_tab = (int *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, (MAXJSAMPLE+1) * SIZEOF(int));
+ upsample->Cb_b_tab = (int *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, (MAXJSAMPLE+1) * SIZEOF(int));
+ upsample->Cr_g_tab = (INT32 *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, (MAXJSAMPLE+1) * SIZEOF(INT32));
+ upsample->Cb_g_tab = (INT32 *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, (MAXJSAMPLE+1) * SIZEOF(INT32));
for (i = 0, x = -CENTERJSAMPLE; i <= MAXJSAMPLE; i++, x++) {
/* i is the actual input pixel value, in the range 0..MAXJSAMPLE */
/* The Cb or Cr value we are thinking of is x = i - CENTERJSAMPLE */
/* Cr=>R value is nearest int to 2.804 * x */
- upsample->Cr_r_tab[i] = (int)
- RIGHT_SHIFT(FIX(2.804) * x + ONE_HALF, SCALEBITS);
+ upsample->Cr_r_tab[i] = (int) DESCALE(FIX(2.804) * x, SCALEBITS);
/* Cb=>B value is nearest int to 3.544 * x */
- upsample->Cb_b_tab[i] = (int)
- RIGHT_SHIFT(FIX(3.544) * x + ONE_HALF, SCALEBITS);
+ upsample->Cb_b_tab[i] = (int) DESCALE(FIX(3.544) * x, SCALEBITS);
/* Cr=>G value is scaled-up -1.428272572 * x */
upsample->Cr_g_tab[i] = (- FIX(1.428272572)) * x;
/* Cb=>G value is scaled-up -0.688272572 * x */
@@ -419,9 +407,8 @@ jinit_merged_upsampler (j_decompress_ptr cinfo)
{
my_upsample_ptr upsample;
- upsample = (my_upsample_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(my_upsampler));
+ upsample = (my_upsample_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(my_upsampler));
cinfo->upsample = &upsample->pub;
upsample->pub.start_pass = start_pass_merged_upsample;
upsample->pub.need_context_rows = FALSE;
@@ -432,9 +419,9 @@ jinit_merged_upsampler (j_decompress_ptr cinfo)
upsample->pub.upsample = merged_2v_upsample;
upsample->upmethod = h2v2_merged_upsample;
/* Allocate a spare row buffer */
- upsample->spare_row = (JSAMPROW)
- (*cinfo->mem->alloc_large) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (size_t) (upsample->out_row_width * SIZEOF(JSAMPLE)));
+ upsample->spare_row = (JSAMPROW) (*cinfo->mem->alloc_large)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE,
+ (size_t) upsample->out_row_width * SIZEOF(JSAMPLE));
} else {
upsample->pub.upsample = merged_1v_upsample;
upsample->upmethod = h2v1_merged_upsample;
diff --git a/jpeg/jerror.h b/jpeg/jerror.h
index a4b661f7..db608b9c 100644
--- a/jpeg/jerror.h
+++ b/jpeg/jerror.h
@@ -2,7 +2,7 @@
* jerror.h
*
* Copyright (C) 1994-1997, Thomas G. Lane.
- * Modified 1997-2012 by Guido Vollbeding.
+ * Modified 1997-2018 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -84,7 +84,7 @@ JMESSAGE(JERR_EOI_EXPECTED, "Didn't expect more than one scan")
JMESSAGE(JERR_FILE_READ, "Input file read error")
JMESSAGE(JERR_FILE_WRITE, "Output file write error --- out of disk space?")
JMESSAGE(JERR_FRACT_SAMPLE_NOTIMPL, "Fractional sampling not implemented yet")
-JMESSAGE(JERR_HUFF_CLEN_OVERFLOW, "Huffman code size table overflow")
+JMESSAGE(JERR_HUFF_CLEN_OUTOFBOUNDS, "Huffman code size table out of bounds")
JMESSAGE(JERR_HUFF_MISSING_CODE, "Missing Huffman code table entry")
JMESSAGE(JERR_IMAGE_TOO_BIG, "Maximum supported image dimension is %u pixels")
JMESSAGE(JERR_INPUT_EMPTY, "Empty input file")
diff --git a/jpeg/jfdctint.c b/jpeg/jfdctint.c
index 7ed42e5d..05df4750 100644
--- a/jpeg/jfdctint.c
+++ b/jpeg/jfdctint.c
@@ -2,7 +2,7 @@
* jfdctint.c
*
* Copyright (C) 1991-1996, Thomas G. Lane.
- * Modification developed 2003-2015 by Guido Vollbeding.
+ * Modification developed 2003-2018 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -3261,78 +3261,84 @@ jpeg_fdct_6x3 (DCTELEM * data, JSAMPARRAY sample_data, JDIMENSION start_col)
GLOBAL(void)
jpeg_fdct_4x2 (DCTELEM * data, JSAMPARRAY sample_data, JDIMENSION start_col)
{
- INT32 tmp0, tmp1;
- INT32 tmp10, tmp11;
- DCTELEM *dataptr;
+ DCTELEM tmp0, tmp2, tmp10, tmp12, tmp4, tmp5;
+ INT32 tmp1, tmp3, tmp11, tmp13;
+ INT32 z1, z2, z3;
JSAMPROW elemptr;
- int ctr;
SHIFT_TEMPS
/* Pre-zero output coefficient block. */
MEMZERO(data, SIZEOF(DCTELEM) * DCTSIZE2);
/* Pass 1: process rows.
- * Note results are scaled up by sqrt(8) compared to a true DCT;
- * furthermore, we scale the results by 2**PASS1_BITS.
- * We must also scale the output by (8/4)*(8/2) = 2**3, which we add here.
+ * Note results are scaled up by sqrt(8) compared to a true DCT.
* 4-point FDCT kernel,
* cK represents sqrt(2) * cos(K*pi/16) [refers to 8-point FDCT].
*/
- dataptr = data;
- for (ctr = 0; ctr < 2; ctr++) {
- elemptr = sample_data[ctr] + start_col;
+ /* Row 0 */
+ elemptr = sample_data[0] + start_col;
- /* Even part */
+ /* Even part */
- tmp0 = GETJSAMPLE(elemptr[0]) + GETJSAMPLE(elemptr[3]);
- tmp1 = GETJSAMPLE(elemptr[1]) + GETJSAMPLE(elemptr[2]);
+ tmp4 = GETJSAMPLE(elemptr[0]) + GETJSAMPLE(elemptr[3]);
+ tmp5 = GETJSAMPLE(elemptr[1]) + GETJSAMPLE(elemptr[2]);
- tmp10 = GETJSAMPLE(elemptr[0]) - GETJSAMPLE(elemptr[3]);
- tmp11 = GETJSAMPLE(elemptr[1]) - GETJSAMPLE(elemptr[2]);
+ tmp0 = tmp4 + tmp5;
+ tmp2 = tmp4 - tmp5;
- /* Apply unsigned->signed conversion. */
- dataptr[0] = (DCTELEM)
- ((tmp0 + tmp1 - 4 * CENTERJSAMPLE) << (PASS1_BITS+3));
- dataptr[2] = (DCTELEM) ((tmp0 - tmp1) << (PASS1_BITS+3));
+ /* Odd part */
- /* Odd part */
+ z2 = GETJSAMPLE(elemptr[0]) - GETJSAMPLE(elemptr[3]);
+ z3 = GETJSAMPLE(elemptr[1]) - GETJSAMPLE(elemptr[2]);
- tmp0 = MULTIPLY(tmp10 + tmp11, FIX_0_541196100); /* c6 */
- /* Add fudge factor here for final descale. */
- tmp0 += ONE << (CONST_BITS-PASS1_BITS-4);
+ z1 = MULTIPLY(z2 + z3, FIX_0_541196100); /* c6 */
+ /* Add fudge factor here for final descale. */
+ z1 += ONE << (CONST_BITS-3-1);
+ tmp1 = z1 + MULTIPLY(z2, FIX_0_765366865); /* c2-c6 */
+ tmp3 = z1 - MULTIPLY(z3, FIX_1_847759065); /* c2+c6 */
- dataptr[1] = (DCTELEM)
- RIGHT_SHIFT(tmp0 + MULTIPLY(tmp10, FIX_0_765366865), /* c2-c6 */
- CONST_BITS-PASS1_BITS-3);
- dataptr[3] = (DCTELEM)
- RIGHT_SHIFT(tmp0 - MULTIPLY(tmp11, FIX_1_847759065), /* c2+c6 */
- CONST_BITS-PASS1_BITS-3);
+ /* Row 1 */
+ elemptr = sample_data[1] + start_col;
- dataptr += DCTSIZE; /* advance pointer to next row */
- }
+ /* Even part */
- /* Pass 2: process columns.
- * We remove the PASS1_BITS scaling, but leave the results scaled up
- * by an overall factor of 8.
- */
+ tmp4 = GETJSAMPLE(elemptr[0]) + GETJSAMPLE(elemptr[3]);
+ tmp5 = GETJSAMPLE(elemptr[1]) + GETJSAMPLE(elemptr[2]);
- dataptr = data;
- for (ctr = 0; ctr < 4; ctr++) {
- /* Even part */
+ tmp10 = tmp4 + tmp5;
+ tmp12 = tmp4 - tmp5;
- /* Add fudge factor here for final descale. */
- tmp0 = dataptr[DCTSIZE*0] + (ONE << (PASS1_BITS-1));
- tmp1 = dataptr[DCTSIZE*1];
+ /* Odd part */
- dataptr[DCTSIZE*0] = (DCTELEM) RIGHT_SHIFT(tmp0 + tmp1, PASS1_BITS);
+ z2 = GETJSAMPLE(elemptr[0]) - GETJSAMPLE(elemptr[3]);
+ z3 = GETJSAMPLE(elemptr[1]) - GETJSAMPLE(elemptr[2]);
- /* Odd part */
+ z1 = MULTIPLY(z2 + z3, FIX_0_541196100); /* c6 */
+ tmp11 = z1 + MULTIPLY(z2, FIX_0_765366865); /* c2-c6 */
+ tmp13 = z1 - MULTIPLY(z3, FIX_1_847759065); /* c2+c6 */
- dataptr[DCTSIZE*1] = (DCTELEM) RIGHT_SHIFT(tmp0 - tmp1, PASS1_BITS);
+ /* Pass 2: process columns.
+ * We leave the results scaled up by an overall factor of 8.
+ * We must also scale the output by (8/4)*(8/2) = 2**3.
+ */
- dataptr++; /* advance pointer to next column */
- }
+ /* Column 0 */
+ /* Apply unsigned->signed conversion. */
+ data[DCTSIZE*0] = (tmp0 + tmp10 - 8 * CENTERJSAMPLE) << 3;
+ data[DCTSIZE*1] = (tmp0 - tmp10) << 3;
+
+ /* Column 1 */
+ data[DCTSIZE*0+1] = (DCTELEM) RIGHT_SHIFT(tmp1 + tmp11, CONST_BITS-3);
+ data[DCTSIZE*1+1] = (DCTELEM) RIGHT_SHIFT(tmp1 - tmp11, CONST_BITS-3);
+
+ /* Column 2 */
+ data[DCTSIZE*0+2] = (tmp2 + tmp12) << 3;
+ data[DCTSIZE*1+2] = (tmp2 - tmp12) << 3;
+
+ /* Column 3 */
+ data[DCTSIZE*0+3] = (DCTELEM) RIGHT_SHIFT(tmp3 + tmp13, CONST_BITS-3);
+ data[DCTSIZE*1+3] = (DCTELEM) RIGHT_SHIFT(tmp3 - tmp13, CONST_BITS-3);
}
@@ -4312,7 +4318,6 @@ jpeg_fdct_2x4 (DCTELEM * data, JSAMPARRAY sample_data, JDIMENSION start_col)
/* Pass 1: process rows.
* Note results are scaled up by sqrt(8) compared to a true DCT.
- * We must also scale the output by (8/2)*(8/4) = 2**3, which we add here.
*/
dataptr = data;
@@ -4325,17 +4330,18 @@ jpeg_fdct_2x4 (DCTELEM * data, JSAMPARRAY sample_data, JDIMENSION start_col)
tmp1 = GETJSAMPLE(elemptr[1]);
/* Apply unsigned->signed conversion. */
- dataptr[0] = (DCTELEM) ((tmp0 + tmp1 - 2 * CENTERJSAMPLE) << 3);
+ dataptr[0] = (DCTELEM) (tmp0 + tmp1 - 2 * CENTERJSAMPLE);
/* Odd part */
- dataptr[1] = (DCTELEM) ((tmp0 - tmp1) << 3);
+ dataptr[1] = (DCTELEM) (tmp0 - tmp1);
dataptr += DCTSIZE; /* advance pointer to next row */
}
/* Pass 2: process columns.
* We leave the results scaled up by an overall factor of 8.
+ * We must also scale the output by (8/2)*(8/4) = 2**3.
* 4-point FDCT kernel,
* cK represents sqrt(2) * cos(K*pi/16) [refers to 8-point FDCT].
*/
@@ -4350,21 +4356,21 @@ jpeg_fdct_2x4 (DCTELEM * data, JSAMPARRAY sample_data, JDIMENSION start_col)
tmp10 = dataptr[DCTSIZE*0] - dataptr[DCTSIZE*3];
tmp11 = dataptr[DCTSIZE*1] - dataptr[DCTSIZE*2];
- dataptr[DCTSIZE*0] = (DCTELEM) (tmp0 + tmp1);
- dataptr[DCTSIZE*2] = (DCTELEM) (tmp0 - tmp1);
+ dataptr[DCTSIZE*0] = (DCTELEM) ((tmp0 + tmp1) << 3);
+ dataptr[DCTSIZE*2] = (DCTELEM) ((tmp0 - tmp1) << 3);
/* Odd part */
tmp0 = MULTIPLY(tmp10 + tmp11, FIX_0_541196100); /* c6 */
/* Add fudge factor here for final descale. */
- tmp0 += ONE << (CONST_BITS-1);
+ tmp0 += ONE << (CONST_BITS-3-1);
dataptr[DCTSIZE*1] = (DCTELEM)
RIGHT_SHIFT(tmp0 + MULTIPLY(tmp10, FIX_0_765366865), /* c2-c6 */
- CONST_BITS);
+ CONST_BITS-3);
dataptr[DCTSIZE*3] = (DCTELEM)
RIGHT_SHIFT(tmp0 - MULTIPLY(tmp11, FIX_1_847759065), /* c2+c6 */
- CONST_BITS);
+ CONST_BITS-3);
dataptr++; /* advance pointer to next column */
}
diff --git a/jpeg/jidctint.c b/jpeg/jidctint.c
index 8f871e81..8881a8f2 100644
--- a/jpeg/jidctint.c
+++ b/jpeg/jidctint.c
@@ -2,7 +2,7 @@
* jidctint.c
*
* Copyright (C) 1991-1998, Thomas G. Lane.
- * Modification developed 2002-2016 by Guido Vollbeding.
+ * Modification developed 2002-2018 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -1504,7 +1504,7 @@ jpeg_idct_10x10 (j_decompress_ptr cinfo, jpeg_component_info * compptr,
/*
* Perform dequantization and inverse DCT on one block of coefficients,
- * producing a 11x11 output block.
+ * producing an 11x11 output block.
*
* Optimized algorithm with 24 multiplications in the 1-D kernel.
* cK represents sqrt(2) * cos(K*pi/22).
@@ -3728,7 +3728,7 @@ jpeg_idct_10x5 (j_decompress_ptr cinfo, jpeg_component_info * compptr,
/*
* Perform dequantization and inverse DCT on one block of coefficients,
- * producing a 8x4 output block.
+ * producing an 8x4 output block.
*
* 4-point IDCT in pass 1 (columns), 8-point in pass 2 (rows).
*/
@@ -3890,7 +3890,7 @@ jpeg_idct_8x4 (j_decompress_ptr cinfo, jpeg_component_info * compptr,
/*
* Perform dequantization and inverse DCT on one block of coefficients,
- * producing a reduced-size 6x3 output block.
+ * producing a 6x3 output block.
*
* 3-point IDCT in pass 1 (columns), 6-point in pass 2 (rows).
*/
@@ -4142,7 +4142,7 @@ jpeg_idct_2x1 (j_decompress_ptr cinfo, jpeg_component_info * compptr,
/*
* Perform dequantization and inverse DCT on one block of coefficients,
- * producing a 8x16 output block.
+ * producing an 8x16 output block.
*
* 16-point IDCT in pass 1 (columns), 8-point in pass 2 (rows).
*/
@@ -4956,6 +4956,8 @@ jpeg_idct_4x8 (j_decompress_ptr cinfo, jpeg_component_info * compptr,
*/
z2 = DEQUANTIZE(inptr[DCTSIZE*0], quantptr[DCTSIZE*0]);
+ if (ctr == 4)
+ CLAMP_DC(z2);
z3 = DEQUANTIZE(inptr[DCTSIZE*4], quantptr[DCTSIZE*4]);
z2 <<= CONST_BITS;
z3 <<= CONST_BITS;
@@ -5075,7 +5077,7 @@ jpeg_idct_4x8 (j_decompress_ptr cinfo, jpeg_component_info * compptr,
/*
* Perform dequantization and inverse DCT on one block of coefficients,
- * producing a reduced-size 3x6 output block.
+ * producing a 3x6 output block.
*
* 6-point IDCT in pass 1 (columns), 3-point in pass 2 (rows).
*/
diff --git a/jpeg/jmemmgr.c b/jpeg/jmemmgr.c
index 0a137cdd..40377de4 100644
--- a/jpeg/jmemmgr.c
+++ b/jpeg/jmemmgr.c
@@ -2,7 +2,7 @@
* jmemmgr.c
*
* Copyright (C) 1991-1997, Thomas G. Lane.
- * Modified 2011-2012 by Guido Vollbeding.
+ * Modified 2011-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -130,7 +130,7 @@ typedef struct {
jvirt_barray_ptr virt_barray_list;
/* This counts total space obtained from jpeg_get_small/large */
- long total_space_allocated;
+ size_t total_space_allocated;
/* alloc_sarray and alloc_barray set this value for use by virtual
* array routines.
@@ -195,7 +195,7 @@ print_mem_stats (j_common_ptr cinfo, int pool_id)
* This is helpful because message parm array can't handle longs.
*/
fprintf(stderr, "Freeing pool %d, total space = %ld\n",
- pool_id, mem->total_space_allocated);
+ pool_id, (long) mem->total_space_allocated);
for (lhdr_ptr = mem->large_list[pool_id]; lhdr_ptr != NULL;
lhdr_ptr = lhdr_ptr->hdr.next) {
@@ -260,11 +260,11 @@ alloc_small (j_common_ptr cinfo, int pool_id, size_t sizeofobject)
{
my_mem_ptr mem = (my_mem_ptr) cinfo->mem;
small_pool_ptr hdr_ptr, prev_hdr_ptr;
- char * data_ptr;
size_t odd_bytes, min_request, slop;
+ char * data_ptr;
/* Check for unsatisfiable request (do now to ensure no overflow below) */
- if (sizeofobject > (size_t) (MAX_ALLOC_CHUNK-SIZEOF(small_pool_hdr)))
+ if (sizeofobject > (size_t) MAX_ALLOC_CHUNK - SIZEOF(small_pool_hdr))
out_of_memory(cinfo, 1); /* request exceeds malloc's ability */
/* Round up the requested size to a multiple of SIZEOF(ALIGN_TYPE) */
@@ -293,8 +293,8 @@ alloc_small (j_common_ptr cinfo, int pool_id, size_t sizeofobject)
else
slop = extra_pool_slop[pool_id];
/* Don't ask for more than MAX_ALLOC_CHUNK */
- if (slop > (size_t) (MAX_ALLOC_CHUNK-min_request))
- slop = (size_t) (MAX_ALLOC_CHUNK-min_request);
+ if (slop > (size_t) MAX_ALLOC_CHUNK - min_request)
+ slop = (size_t) MAX_ALLOC_CHUNK - min_request;
/* Try to get space, if fail reduce slop and try again */
for (;;) {
hdr_ptr = (small_pool_ptr) jpeg_get_small(cinfo, min_request + slop);
@@ -348,7 +348,7 @@ alloc_large (j_common_ptr cinfo, int pool_id, size_t sizeofobject)
size_t odd_bytes;
/* Check for unsatisfiable request (do now to ensure no overflow below) */
- if (sizeofobject > (size_t) (MAX_ALLOC_CHUNK-SIZEOF(large_pool_hdr)))
+ if (sizeofobject > (size_t) MAX_ALLOC_CHUNK - SIZEOF(large_pool_hdr))
out_of_memory(cinfo, 3); /* request exceeds malloc's ability */
/* Round up the requested size to a multiple of SIZEOF(ALIGN_TYPE) */
@@ -404,7 +404,7 @@ alloc_sarray (j_common_ptr cinfo, int pool_id,
long ltemp;
/* Calculate max # of rows allowed in one allocation chunk */
- ltemp = (MAX_ALLOC_CHUNK-SIZEOF(large_pool_hdr)) /
+ ltemp = (MAX_ALLOC_CHUNK - SIZEOF(large_pool_hdr)) /
((long) samplesperrow * SIZEOF(JSAMPLE));
if (ltemp <= 0)
ERREXIT(cinfo, JERR_WIDTH_OVERFLOW);
@@ -416,15 +416,14 @@ alloc_sarray (j_common_ptr cinfo, int pool_id,
/* Get space for row pointers (small object) */
result = (JSAMPARRAY) alloc_small(cinfo, pool_id,
- (size_t) (numrows * SIZEOF(JSAMPROW)));
+ (size_t) numrows * SIZEOF(JSAMPROW));
/* Get the rows themselves (large objects) */
currow = 0;
while (currow < numrows) {
rowsperchunk = MIN(rowsperchunk, numrows - currow);
workspace = (JSAMPROW) alloc_large(cinfo, pool_id,
- (size_t) ((size_t) rowsperchunk * (size_t) samplesperrow
- * SIZEOF(JSAMPLE)));
+ (size_t) rowsperchunk * (size_t) samplesperrow * SIZEOF(JSAMPLE));
for (i = rowsperchunk; i > 0; i--) {
result[currow++] = workspace;
workspace += samplesperrow;
@@ -452,7 +451,7 @@ alloc_barray (j_common_ptr cinfo, int pool_id,
long ltemp;
/* Calculate max # of rows allowed in one allocation chunk */
- ltemp = (MAX_ALLOC_CHUNK-SIZEOF(large_pool_hdr)) /
+ ltemp = (MAX_ALLOC_CHUNK - SIZEOF(large_pool_hdr)) /
((long) blocksperrow * SIZEOF(JBLOCK));
if (ltemp <= 0)
ERREXIT(cinfo, JERR_WIDTH_OVERFLOW);
@@ -464,15 +463,14 @@ alloc_barray (j_common_ptr cinfo, int pool_id,
/* Get space for row pointers (small object) */
result = (JBLOCKARRAY) alloc_small(cinfo, pool_id,
- (size_t) (numrows * SIZEOF(JBLOCKROW)));
+ (size_t) numrows * SIZEOF(JBLOCKROW));
/* Get the rows themselves (large objects) */
currow = 0;
while (currow < numrows) {
rowsperchunk = MIN(rowsperchunk, numrows - currow);
workspace = (JBLOCKROW) alloc_large(cinfo, pool_id,
- (size_t) ((size_t) rowsperchunk * (size_t) blocksperrow
- * SIZEOF(JBLOCK)));
+ (size_t) rowsperchunk * (size_t) blocksperrow * SIZEOF(JBLOCK));
for (i = rowsperchunk; i > 0; i--) {
result[currow++] = workspace;
workspace += blocksperrow;
@@ -585,8 +583,8 @@ realize_virt_arrays (j_common_ptr cinfo)
/* Allocate the in-memory buffers for any unrealized virtual arrays */
{
my_mem_ptr mem = (my_mem_ptr) cinfo->mem;
- long space_per_minheight, maximum_space, avail_mem;
- long minheights, max_minheights;
+ long bytesperrow, space_per_minheight, maximum_space;
+ long avail_mem, minheights, max_minheights;
jvirt_sarray_ptr sptr;
jvirt_barray_ptr bptr;
@@ -598,18 +596,16 @@ realize_virt_arrays (j_common_ptr cinfo)
maximum_space = 0;
for (sptr = mem->virt_sarray_list; sptr != NULL; sptr = sptr->next) {
if (sptr->mem_buffer == NULL) { /* if not realized yet */
- space_per_minheight += (long) sptr->maxaccess *
- (long) sptr->samplesperrow * SIZEOF(JSAMPLE);
- maximum_space += (long) sptr->rows_in_array *
- (long) sptr->samplesperrow * SIZEOF(JSAMPLE);
+ bytesperrow = (long) sptr->samplesperrow * SIZEOF(JSAMPLE);
+ space_per_minheight += (long) sptr->maxaccess * bytesperrow;
+ maximum_space += (long) sptr->rows_in_array * bytesperrow;
}
}
for (bptr = mem->virt_barray_list; bptr != NULL; bptr = bptr->next) {
if (bptr->mem_buffer == NULL) { /* if not realized yet */
- space_per_minheight += (long) bptr->maxaccess *
- (long) bptr->blocksperrow * SIZEOF(JBLOCK);
- maximum_space += (long) bptr->rows_in_array *
- (long) bptr->blocksperrow * SIZEOF(JBLOCK);
+ bytesperrow = (long) bptr->blocksperrow * SIZEOF(JBLOCK);
+ space_per_minheight += (long) bptr->maxaccess * bytesperrow;
+ maximum_space += (long) bptr->rows_in_array * bytesperrow;
}
}
@@ -618,7 +614,7 @@ realize_virt_arrays (j_common_ptr cinfo)
/* Determine amount of memory to actually use; this is system-dependent. */
avail_mem = jpeg_mem_available(cinfo, space_per_minheight, maximum_space,
- mem->total_space_allocated);
+ (long) mem->total_space_allocated);
/* If the maximum space needed is available, make all the buffers full
* height; otherwise parcel it out with the same number of minheights
@@ -694,7 +690,7 @@ do_sarray_io (j_common_ptr cinfo, jvirt_sarray_ptr ptr, boolean writing)
long bytesperrow, file_offset, byte_count, rows, thisrow, i;
bytesperrow = (long) ptr->samplesperrow * SIZEOF(JSAMPLE);
- file_offset = ptr->cur_start_row * bytesperrow;
+ file_offset = (long) ptr->cur_start_row * bytesperrow;
/* Loop to read or write each allocation chunk in mem_buffer */
for (i = 0; i < (long) ptr->rows_in_mem; i += ptr->rowsperchunk) {
/* One chunk, but check for short chunk at end of buffer */
@@ -727,7 +723,7 @@ do_barray_io (j_common_ptr cinfo, jvirt_barray_ptr ptr, boolean writing)
long bytesperrow, file_offset, byte_count, rows, thisrow, i;
bytesperrow = (long) ptr->blocksperrow * SIZEOF(JBLOCK);
- file_offset = ptr->cur_start_row * bytesperrow;
+ file_offset = (long) ptr->cur_start_row * bytesperrow;
/* Loop to read or write each allocation chunk in mem_buffer */
for (i = 0; i < (long) ptr->rows_in_mem; i += ptr->rowsperchunk) {
/* One chunk, but check for short chunk at end of buffer */
@@ -771,7 +767,7 @@ access_virt_sarray (j_common_ptr cinfo, jvirt_sarray_ptr ptr,
/* Make the desired part of the virtual array accessible */
if (start_row < ptr->cur_start_row ||
- end_row > ptr->cur_start_row+ptr->rows_in_mem) {
+ end_row > ptr->cur_start_row + ptr->rows_in_mem) {
if (! ptr->b_s_open)
ERREXIT(cinfo, JERR_VIRTUAL_BUG);
/* Flush old buffer contents if necessary */
@@ -856,7 +852,7 @@ access_virt_barray (j_common_ptr cinfo, jvirt_barray_ptr ptr,
/* Make the desired part of the virtual array accessible */
if (start_row < ptr->cur_start_row ||
- end_row > ptr->cur_start_row+ptr->rows_in_mem) {
+ end_row > ptr->cur_start_row + ptr->rows_in_mem) {
if (! ptr->b_s_open)
ERREXIT(cinfo, JERR_VIRTUAL_BUG);
/* Flush old buffer contents if necessary */
@@ -1093,7 +1089,7 @@ jinit_memory_mgr (j_common_ptr cinfo)
mem->total_space_allocated = SIZEOF(my_memory_mgr);
/* Declare ourselves open for business */
- cinfo->mem = & mem->pub;
+ cinfo->mem = &mem->pub;
/* Check for an environment variable JPEGMEM; if found, override the
* default max_memory setting from jpeg_mem_init. Note that the
diff --git a/jpeg/jmemnobs.c b/jpeg/jmemnobs.c
index eb8c3377..a364cd82 100644
--- a/jpeg/jmemnobs.c
+++ b/jpeg/jmemnobs.c
@@ -2,6 +2,7 @@
* jmemnobs.c
*
* Copyright (C) 1992-1996, Thomas G. Lane.
+ * Modified 2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -12,7 +13,7 @@
* This is very portable in the sense that it'll compile on almost anything,
* but you'd better have lots of main memory (or virtual memory) if you want
* to process big images.
- * Note that the max_memory_to_use option is ignored by this implementation.
+ * Note that the max_memory_to_use option is respected by this implementation.
*/
#define JPEG_INTERNALS
@@ -66,13 +67,16 @@ jpeg_free_large (j_common_ptr cinfo, void FAR * object, size_t sizeofobject)
/*
* This routine computes the total memory space available for allocation.
- * Here we always say, "we got all you want bud!"
*/
GLOBAL(long)
jpeg_mem_available (j_common_ptr cinfo, long min_bytes_needed,
long max_bytes_needed, long already_allocated)
{
+ if (cinfo->mem->max_memory_to_use)
+ return cinfo->mem->max_memory_to_use - already_allocated;
+
+ /* Here we say, "we got all you want bud!" */
return max_bytes_needed;
}
diff --git a/jpeg/jpegint.h b/jpeg/jpegint.h
index e312e1af..52c708d4 100644
--- a/jpeg/jpegint.h
+++ b/jpeg/jpegint.h
@@ -2,7 +2,7 @@
* jpegint.h
*
* Copyright (C) 1991-1997, Thomas G. Lane.
- * Modified 1997-2017 by Guido Vollbeding.
+ * Modified 1997-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -302,6 +302,13 @@ struct jpeg_color_quantizer {
#define RIGHT_SHIFT(x,shft) ((x) >> (shft))
#endif
+/* Descale and correctly round an INT32 value that's scaled by N bits.
+ * We assume RIGHT_SHIFT rounds towards minus infinity, so adding
+ * the fudge factor is correct for either sign of X.
+ */
+
+#define DESCALE(x,n) RIGHT_SHIFT((x) + ((INT32) 1 << ((n)-1)), n)
+
/* Short forms of external names for systems with brain-damaged linkers. */
diff --git a/jpeg/jpeglib.h b/jpeg/jpeglib.h
index 4bd98531..591a2cb6 100644
--- a/jpeg/jpeglib.h
+++ b/jpeg/jpeglib.h
@@ -2,7 +2,7 @@
* jpeglib.h
*
* Copyright (C) 1991-1998, Thomas G. Lane.
- * Modified 2002-2017 by Guido Vollbeding.
+ * Modified 2002-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -39,7 +39,7 @@ extern "C" {
#define JPEG_LIB_VERSION 90 /* Compatibility version 9.0 */
#define JPEG_LIB_VERSION_MAJOR 9
-#define JPEG_LIB_VERSION_MINOR 3
+#define JPEG_LIB_VERSION_MINOR 4
/* Various constants determining the sizes of things.
@@ -909,6 +909,7 @@ typedef JMETHOD(boolean, jpeg_marker_parser_method, (j_decompress_ptr cinfo));
#define jpeg_suppress_tables jSuppressTables
#define jpeg_alloc_quant_table jAlcQTable
#define jpeg_alloc_huff_table jAlcHTable
+#define jpeg_std_huff_table jStdHTable
#define jpeg_start_compress jStrtCompress
#define jpeg_write_scanlines jWrtScanlines
#define jpeg_finish_compress jFinCompress
@@ -977,10 +978,10 @@ EXTERN(void) jpeg_stdio_src JPP((j_decompress_ptr cinfo, FILE * infile));
/* Data source and destination managers: memory buffers. */
EXTERN(void) jpeg_mem_dest JPP((j_compress_ptr cinfo,
unsigned char ** outbuffer,
- unsigned long * outsize));
+ size_t * outsize));
EXTERN(void) jpeg_mem_src JPP((j_decompress_ptr cinfo,
const unsigned char * inbuffer,
- unsigned long insize));
+ size_t insize));
/* Default parameter setup for compression */
EXTERN(void) jpeg_set_defaults JPP((j_compress_ptr cinfo));
@@ -1005,6 +1006,8 @@ EXTERN(void) jpeg_suppress_tables JPP((j_compress_ptr cinfo,
boolean suppress));
EXTERN(JQUANT_TBL *) jpeg_alloc_quant_table JPP((j_common_ptr cinfo));
EXTERN(JHUFF_TBL *) jpeg_alloc_huff_table JPP((j_common_ptr cinfo));
+EXTERN(JHUFF_TBL *) jpeg_std_huff_table JPP((j_common_ptr cinfo,
+ boolean isDC, int tblno));
/* Main entry points for compression */
EXTERN(void) jpeg_start_compress JPP((j_compress_ptr cinfo,
diff --git a/jpeg/jpegtran.1 b/jpeg/jpegtran.1
index 4f051848..7929afdd 100644
--- a/jpeg/jpegtran.1
+++ b/jpeg/jpegtran.1
@@ -1,4 +1,4 @@
-.TH JPEGTRAN 1 "30 September 2017"
+.TH JPEGTRAN 1 "28 August 2019"
.SH NAME
jpegtran \- lossless transformation of JPEG files
.SH SYNOPSIS
@@ -169,12 +169,20 @@ region dimensions to keep the lower right crop corner unchanged. (Thus, the
output image covers at least the requested region, but may cover more.)
The adjustment of the region dimensions may be optionally disabled by
attaching an 'f' character ("force") to the width or height number.
-
+.PP
The image can be losslessly cropped by giving the switch:
.TP
.B \-crop WxH+X+Y
Crop to a rectangular subarea of width W, height H starting at point X,Y.
.PP
+Crop extension: The width or height parameters can be made larger than the
+source image. In this case the extra area is filled in with zero (neutral
+gray). A larger width parameter has two more options: Attaching an 'f'
+character ("flatten") to the width number will fill in the extra area with
+the DC of the adjacent block, instead of gray out. Attaching an 'r'
+character ("reflect") to the width number will fill in the extra area with
+repeated reflections of the source region, instead of gray out.
+.PP
A complementary lossless-wipe option is provided to discard (gray out) data
inside a given image region while losslessly preserving what is outside:
.TP
@@ -182,8 +190,22 @@ inside a given image region while losslessly preserving what is outside:
Wipe (gray out) a rectangular subarea of width W, height H starting at point
X,Y.
.PP
-Attaching an 'f' character ("flatten") to the width number will fill
-the region with the average of adjacent blocks, instead of gray out.
+Attaching an 'f' character ("flatten") to the width number will fill the
+region with the average of adjacent blocks, instead of gray out. In case
+the wipe region and outside area form two horizontally adjacent rectangles,
+attaching an 'r' character ("reflect") to the width number will fill the
+region with repeated reflections of the outside area, instead of gray out.
+.PP
+Another option is lossless-drop, which replaces data at a given image
+position by another image:
+.TP
+.B \-drop +X+Y filename
+Drop another image
+.PP
+Both source images must have the same subsampling values. It is best if
+they also have the same quantization, otherwise quantization adaption occurs.
+The trim option can be used with the drop option to requantize the drop file
+to the source file.
.PP
Other not-strictly-lossless transformation switches are:
.TP
diff --git a/jpeg/jpegtran.c b/jpeg/jpegtran.c
index 5269344e..bfaa8aca 100644
--- a/jpeg/jpegtran.c
+++ b/jpeg/jpegtran.c
@@ -1,7 +1,7 @@
/*
* jpegtran.c
*
- * Copyright (C) 1995-2013, Thomas G. Lane, Guido Vollbeding.
+ * Copyright (C) 1995-2019, Thomas G. Lane, Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -37,6 +37,7 @@
static const char * progname; /* program name for error messages */
static char * outfilename; /* for -outfile switch */
+static char * dropfilename; /* for -drop switch */
static char * scaleoption; /* -scale switch */
static JCOPY_OPTION copyoption; /* -copy switch */
static jpeg_transform_info transformoption; /* image transformation options */
@@ -66,6 +67,7 @@ usage (void)
fprintf(stderr, "Switches for modifying the image:\n");
#if TRANSFORMS_SUPPORTED
fprintf(stderr, " -crop WxH+X+Y Crop to a rectangular subarea\n");
+ fprintf(stderr, " -drop +X+Y filename Drop another image\n");
fprintf(stderr, " -flip [horizontal|vertical] Mirror image (left-right or top-bottom)\n");
fprintf(stderr, " -grayscale Reduce to grayscale (omit color data)\n");
fprintf(stderr, " -perfect Fail if there is non-transformable edge blocks\n");
@@ -76,6 +78,7 @@ usage (void)
fprintf(stderr, " -transpose Transpose image\n");
fprintf(stderr, " -transverse Transverse transpose image\n");
fprintf(stderr, " -trim Drop non-transformable edge blocks\n");
+ fprintf(stderr, " with -drop: Requantize drop file to source file\n");
fprintf(stderr, " -wipe WxH+X+Y Wipe (gray out) a rectangular subarea\n");
#endif
fprintf(stderr, "Switches for advanced users:\n");
@@ -188,7 +191,7 @@ parse_switches (j_compress_ptr cinfo, int argc, char **argv,
#if TRANSFORMS_SUPPORTED
if (++argn >= argc) /* advance to next argument */
usage();
- if (transformoption.crop /* reject multiple crop/wipe requests */ ||
+ if (transformoption.crop /* reject multiple crop/drop/wipe requests */ ||
! jtransform_parse_crop_spec(&transformoption, argv[argn])) {
fprintf(stderr, "%s: bogus -crop argument '%s'\n",
progname, argv[argn]);
@@ -198,6 +201,26 @@ parse_switches (j_compress_ptr cinfo, int argc, char **argv,
select_transform(JXFORM_NONE); /* force an error */
#endif
+ } else if (keymatch(arg, "drop", 2)) {
+#if TRANSFORMS_SUPPORTED
+ if (++argn >= argc) /* advance to next argument */
+ usage();
+ if (transformoption.crop /* reject multiple crop/drop/wipe requests */ ||
+ ! jtransform_parse_crop_spec(&transformoption, argv[argn]) ||
+ transformoption.crop_width_set != JCROP_UNSET ||
+ transformoption.crop_height_set != JCROP_UNSET) {
+ fprintf(stderr, "%s: bogus -drop argument '%s'\n",
+ progname, argv[argn]);
+ exit(EXIT_FAILURE);
+ }
+ if (++argn >= argc) /* advance to next argument */
+ usage();
+ dropfilename = argv[argn];
+ select_transform(JXFORM_DROP);
+#else
+ select_transform(JXFORM_NONE); /* force an error */
+#endif
+
} else if (keymatch(arg, "debug", 1) || keymatch(arg, "verbose", 1)) {
/* Enable debug printouts. */
/* On first -d, print version identification */
@@ -342,7 +365,7 @@ parse_switches (j_compress_ptr cinfo, int argc, char **argv,
#if TRANSFORMS_SUPPORTED
if (++argn >= argc) /* advance to next argument */
usage();
- if (transformoption.crop /* reject multiple crop/wipe requests */ ||
+ if (transformoption.crop /* reject multiple crop/drop/wipe requests */ ||
! jtransform_parse_crop_spec(&transformoption, argv[argn])) {
fprintf(stderr, "%s: bogus -wipe argument '%s'\n",
progname, argv[argn]);
@@ -386,8 +409,14 @@ int
main (int argc, char **argv)
{
struct jpeg_decompress_struct srcinfo;
+ struct jpeg_error_mgr jsrcerr;
+#if TRANSFORMS_SUPPORTED
+ struct jpeg_decompress_struct dropinfo;
+ struct jpeg_error_mgr jdroperr;
+ FILE * drop_file;
+#endif
struct jpeg_compress_struct dstinfo;
- struct jpeg_error_mgr jsrcerr, jdsterr;
+ struct jpeg_error_mgr jdsterr;
#ifdef PROGRESS_REPORT
struct cdjpeg_progress_mgr progress;
#endif
@@ -427,7 +456,7 @@ main (int argc, char **argv)
* values read here are mostly ignored; we will rescan the switches after
* opening the input file. Also note that most of the switches affect the
* destination JPEG object, so we parse into that and then copy over what
- * needs to affects the source too.
+ * needs to affect the source too.
*/
file_index = parse_switches(&dstinfo, argc, argv, 0, FALSE);
@@ -469,6 +498,21 @@ main (int argc, char **argv)
fp = read_stdin();
}
+#if TRANSFORMS_SUPPORTED
+ /* Open the drop file. */
+ if (dropfilename != NULL) {
+ if ((drop_file = fopen(dropfilename, READ_BINARY)) == NULL) {
+ fprintf(stderr, "%s: can't open %s for reading\n", progname, dropfilename);
+ exit(EXIT_FAILURE);
+ }
+ dropinfo.err = jpeg_std_error(&jdroperr);
+ jpeg_create_decompress(&dropinfo);
+ jpeg_stdio_src(&dropinfo, drop_file);
+ } else {
+ drop_file = NULL;
+ }
+#endif
+
#ifdef PROGRESS_REPORT
start_progress_monitor((j_common_ptr) &dstinfo, &progress);
#endif
@@ -488,6 +532,17 @@ main (int argc, char **argv)
&srcinfo.scale_num, &srcinfo.scale_denom) < 1)
usage();
+#if TRANSFORMS_SUPPORTED
+ if (dropfilename != NULL) {
+ (void) jpeg_read_header(&dropinfo, TRUE);
+ transformoption.crop_width = dropinfo.image_width;
+ transformoption.crop_width_set = JCROP_POS;
+ transformoption.crop_height = dropinfo.image_height;
+ transformoption.crop_height_set = JCROP_POS;
+ transformoption.drop_ptr = &dropinfo;
+ }
+#endif
+
/* Any space needed by a transform option must be requested before
* jpeg_read_coefficients so that memory allocation will be done right.
*/
@@ -503,6 +558,12 @@ main (int argc, char **argv)
/* Read source file as DCT coefficients */
src_coef_arrays = jpeg_read_coefficients(&srcinfo);
+#if TRANSFORMS_SUPPORTED
+ if (dropfilename != NULL) {
+ transformoption.drop_coef_arrays = jpeg_read_coefficients(&dropinfo);
+ }
+#endif
+
/* Initialize destination compression parameters from source values */
jpeg_copy_critical_parameters(&srcinfo, &dstinfo);
@@ -560,18 +621,34 @@ main (int argc, char **argv)
/* Finish compression and release memory */
jpeg_finish_compress(&dstinfo);
jpeg_destroy_compress(&dstinfo);
+#if TRANSFORMS_SUPPORTED
+ if (dropfilename != NULL) {
+ (void) jpeg_finish_decompress(&dropinfo);
+ jpeg_destroy_decompress(&dropinfo);
+ }
+#endif
(void) jpeg_finish_decompress(&srcinfo);
jpeg_destroy_decompress(&srcinfo);
/* Close output file, if we opened it */
if (fp != stdout)
fclose(fp);
+#if TRANSFORMS_SUPPORTED
+ if (drop_file != NULL)
+ fclose(drop_file);
+#endif
#ifdef PROGRESS_REPORT
end_progress_monitor((j_common_ptr) &dstinfo);
#endif
/* All done. */
- exit(jsrcerr.num_warnings + jdsterr.num_warnings ?EXIT_WARNING:EXIT_SUCCESS);
- return 0; /* suppress no-return-value warnings */
+#if TRANSFORMS_SUPPORTED
+ if (dropfilename != NULL)
+ exit(jsrcerr.num_warnings + jdroperr.num_warnings +
+ jdsterr.num_warnings ? EXIT_WARNING : EXIT_SUCCESS);
+#endif
+ exit(jsrcerr.num_warnings + jdsterr.num_warnings ?
+ EXIT_WARNING : EXIT_SUCCESS);
+ return 0; /* suppress no-return-value warnings */
}
diff --git a/jpeg/jutils.c b/jpeg/jutils.c
index 5b16b6d0..1e2dfb01 100644
--- a/jpeg/jutils.c
+++ b/jpeg/jutils.c
@@ -2,7 +2,7 @@
* jutils.c
*
* Copyright (C) 1991-1996, Thomas G. Lane.
- * Modified 2009-2011 by Guido Vollbeding.
+ * Modified 2009-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -185,7 +185,7 @@ jcopy_sample_rows (JSAMPARRAY input_array, int source_row,
{
register JSAMPROW inptr, outptr;
#ifdef FMEMCOPY
- register size_t count = (size_t) (num_cols * SIZEOF(JSAMPLE));
+ register size_t count = (size_t) num_cols * SIZEOF(JSAMPLE);
#else
register JDIMENSION count;
#endif
@@ -213,7 +213,7 @@ jcopy_block_row (JBLOCKROW input_row, JBLOCKROW output_row,
/* Copy a row of coefficient blocks from one place to another. */
{
#ifdef FMEMCOPY
- FMEMCOPY(output_row, input_row, num_blocks * (DCTSIZE2 * SIZEOF(JCOEF)));
+ FMEMCOPY(output_row, input_row, (size_t) num_blocks * (DCTSIZE2 * SIZEOF(JCOEF)));
#else
register JCOEFPTR inptr, outptr;
register long count;
diff --git a/jpeg/jversion.h b/jpeg/jversion.h
index d096384f..c9befacd 100644
--- a/jpeg/jversion.h
+++ b/jpeg/jversion.h
@@ -1,7 +1,7 @@
/*
* jversion.h
*
- * Copyright (C) 1991-2018, Thomas G. Lane, Guido Vollbeding.
+ * Copyright (C) 1991-2020, Thomas G. Lane, Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -9,6 +9,6 @@
*/
-#define JVERSION "9c 14-Jan-2018"
+#define JVERSION "9d 12-Jan-2020"
-#define JCOPYRIGHT "Copyright (C) 2018, Thomas G. Lane, Guido Vollbeding"
+#define JCOPYRIGHT "Copyright (C) 2020, Thomas G. Lane, Guido Vollbeding"
diff --git a/jpeg/libjpeg.pc.in b/jpeg/libjpeg.pc.in
index 271b742f..d8e738f4 100644
--- a/jpeg/libjpeg.pc.in
+++ b/jpeg/libjpeg.pc.in
@@ -5,6 +5,6 @@ includedir=@includedir@
Name: libjpeg
Description: Reads and writes JPEG files
-Version: @JPEG_LIB_VERSION@
+Version: @JPEG_LIB_VERSION_MAJOR@.@JPEG_LIB_VERSION_MINOR@.0
Libs: -L${libdir} -ljpeg
Cflags: -I${includedir}
diff --git a/jpeg/libjpeg.txt b/jpeg/libjpeg.txt
index 4243c246..546a86e2 100644
--- a/jpeg/libjpeg.txt
+++ b/jpeg/libjpeg.txt
@@ -1,6 +1,6 @@
USING THE IJG JPEG LIBRARY
-Copyright (C) 1994-2013, Thomas G. Lane, Guido Vollbeding.
+Copyright (C) 1994-2019, Thomas G. Lane, Guido Vollbeding.
This file is part of the Independent JPEG Group's software.
For conditions of distribution and use, see the accompanying README file.
@@ -2591,8 +2591,8 @@ different sizes. If the image dimensions are not a multiple of the MCU size,
you must also pad the data correctly (usually, this is done by replicating
the last column and/or row). The data must be padded to a multiple of a DCT
block in each component: that is, each downsampled row must contain a
-multiple of block_size valid samples, and there must be a multiple of
-block_size sample rows for each component. (For applications such as
+multiple of DCT_h_scaled_size valid samples, and there must be a multiple of
+DCT_v_scaled_size sample rows for each component. (For applications such as
conversion of digital TV images, the standard image size is usually a
multiple of the DCT block size, so that no padding need actually be done.)
@@ -2602,8 +2602,6 @@ jpeg_write_scanlines(). Before calling jpeg_start_compress(), you must do
the following:
* Set cinfo->raw_data_in to TRUE. (It is set FALSE by jpeg_set_defaults().)
This notifies the library that you will be supplying raw data.
- Furthermore, set cinfo->do_fancy_downsampling to FALSE if you want to use
- real downsampled data. (It is set TRUE by jpeg_set_defaults().)
* Ensure jpeg_color_space is correct --- an explicit jpeg_set_colorspace()
call is a good idea. Note that since color conversion is bypassed,
in_color_space is ignored, except that jpeg_set_defaults() uses it to
@@ -2620,23 +2618,25 @@ The scanlines count passed to and returned from jpeg_write_raw_data is
measured in terms of the component with the largest v_samp_factor.
jpeg_write_raw_data() processes one MCU row per call, which is to say
-v_samp_factor*block_size sample rows of each component. The passed num_lines
-value must be at least max_v_samp_factor*block_size, and the return value
-will be exactly that amount (or possibly some multiple of that amount, in
-future library versions). This is true even on the last call at the bottom
-of the image; don't forget to pad your data as necessary.
+v_samp_factor*min_DCT_v_scaled_size sample rows of each component. The passed
+num_lines value must be at least max_v_samp_factor*min_DCT_v_scaled_size, and
+the return value will be exactly that amount (or possibly some multiple of
+that amount, in future library versions). This is true even on the last call
+at the bottom of the image; don't forget to pad your data as necessary.
The required dimensions of the supplied data can be computed for each
component as
- cinfo->comp_info[i].width_in_blocks*block_size samples per row
- cinfo->comp_info[i].height_in_blocks*block_size rows in image
+ cinfo->comp_info[i].width_in_blocks *
+ cinfo->comp_info[i].DCT_h_scaled_size samples per row
+ cinfo->comp_info[i].height_in_blocks *
+ cinfo->comp_info[i].DCT_v_scaled_size rows in image
after jpeg_start_compress() has initialized those fields. If the valid data
is smaller than this, it must be padded appropriately. For some sampling
factors and image sizes, additional dummy DCT blocks are inserted to make
the image a multiple of the MCU dimensions. The library creates such dummy
blocks itself; it does not read them from your supplied data. Therefore you
-need never pad by more than block_size samples. An example may help here.
-Assume 2h2v downsampling of YCbCr data, that is
+need never pad by more than DCT_scaled_size samples.
+An example may help here. Assume 2h2v downsampling of YCbCr data, that is
cinfo->comp_info[0].h_samp_factor = 2 for Y
cinfo->comp_info[0].v_samp_factor = 2
cinfo->comp_info[1].h_samp_factor = 1 for Cb
@@ -2662,27 +2662,26 @@ destination module suspends, jpeg_write_raw_data() will return 0.
In this case the same data rows must be passed again on the next call.
-Decompression with raw data output implies bypassing all postprocessing.
-You must deal with the color space and sampling factors present in the
-incoming file. If your application only handles, say, 2h1v YCbCr data,
-you must check for and fail on other color spaces or other sampling factors.
+Decompression with raw data output implies bypassing all postprocessing:
+you cannot ask for color quantization, for instance. More seriously, you
+must deal with the color space and sampling factors present in the incoming
+file. If your application only handles, say, 2h1v YCbCr data, you must
+check for and fail on other color spaces or other sampling factors.
The library will not convert to a different color space for you.
To obtain raw data output, set cinfo->raw_data_out = TRUE before
jpeg_start_decompress() (it is set FALSE by jpeg_read_header()). Be sure to
verify that the color space and sampling factors are ones you can handle.
-Furthermore, set cinfo->do_fancy_upsampling = FALSE if you want to get real
-downsampled data (it is set TRUE by jpeg_read_header()).
Then call jpeg_read_raw_data() in place of jpeg_read_scanlines(). The
decompression process is otherwise the same as usual.
jpeg_read_raw_data() returns one MCU row per call, and thus you must pass a
-buffer of at least max_v_samp_factor*block_size scanlines (scanline counting
-is the same as for raw-data compression). The buffer you pass must be large
-enough to hold the actual data plus padding to DCT-block boundaries. As with
-compression, any entirely dummy DCT blocks are not processed so you need not
-allocate space for them, but the total scanline count includes them. The
-above example of computing buffer dimensions for raw-data compression is
+buffer of at least max_v_samp_factor*min_DCT_v_scaled_size scanlines (scanline
+counting is the same as for raw-data compression). The buffer you pass must
+be large enough to hold the actual data plus padding to DCT-block boundaries.
+As with compression, any entirely dummy DCT blocks are not processed so you
+need not allocate space for them, but the total scanline count includes them.
+The above example of computing buffer dimensions for raw-data compression is
equally valid for decompression.
Input suspension is supported with raw-data decompression: if the data source
diff --git a/jpeg/makeasln.v15 b/jpeg/makeasln.v16
index 617d9e94..8e69d6ff 100644
--- a/jpeg/makeasln.v15
+++ b/jpeg/makeasln.v16
@@ -1,6 +1,8 @@
-
-Microsoft Visual Studio Solution File, Format Version 11.00
-# Visual C++ Express 2010
+
+Microsoft Visual Studio Solution File, Format Version 12.00
+# Visual Studio 15
+VisualStudioVersion = 15.0.28307.329
+MinimumVisualStudioVersion = 10.0.40219.1
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "cjpeg", "cjpeg.vcxproj", "{2E7FAAD9-2F58-4BDE-81F2-1D6D3FB8BF57}"
EndProject
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "djpeg", "djpeg.vcxproj", "{11043137-B453-4DFA-9010-4D2B9DC1545C}"
@@ -14,20 +16,34 @@ EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Release|Win32 = Release|Win32
+ Release|x64 = Release|x64
EndGlobalSection
GlobalSection(ProjectConfigurationPlatforms) = postSolution
{2E7FAAD9-2F58-4BDE-81F2-1D6D3FB8BF57}.Release|Win32.ActiveCfg = Release|Win32
{2E7FAAD9-2F58-4BDE-81F2-1D6D3FB8BF57}.Release|Win32.Build.0 = Release|Win32
+ {2E7FAAD9-2F58-4BDE-81F2-1D6D3FB8BF57}.Release|x64.ActiveCfg = Release|x64
+ {2E7FAAD9-2F58-4BDE-81F2-1D6D3FB8BF57}.Release|x64.Build.0 = Release|x64
{11043137-B453-4DFA-9010-4D2B9DC1545C}.Release|Win32.ActiveCfg = Release|Win32
{11043137-B453-4DFA-9010-4D2B9DC1545C}.Release|Win32.Build.0 = Release|Win32
+ {11043137-B453-4DFA-9010-4D2B9DC1545C}.Release|x64.ActiveCfg = Release|x64
+ {11043137-B453-4DFA-9010-4D2B9DC1545C}.Release|x64.Build.0 = Release|x64
{025BAC50-51B5-4FFE-BC47-3F920BB4047E}.Release|Win32.ActiveCfg = Release|Win32
{025BAC50-51B5-4FFE-BC47-3F920BB4047E}.Release|Win32.Build.0 = Release|Win32
+ {025BAC50-51B5-4FFE-BC47-3F920BB4047E}.Release|x64.ActiveCfg = Release|x64
+ {025BAC50-51B5-4FFE-BC47-3F920BB4047E}.Release|x64.Build.0 = Release|x64
{C81513DB-78DC-46BC-BC98-82E745203976}.Release|Win32.ActiveCfg = Release|Win32
{C81513DB-78DC-46BC-BC98-82E745203976}.Release|Win32.Build.0 = Release|Win32
+ {C81513DB-78DC-46BC-BC98-82E745203976}.Release|x64.ActiveCfg = Release|x64
+ {C81513DB-78DC-46BC-BC98-82E745203976}.Release|x64.Build.0 = Release|x64
{B57065D4-DDDA-4668-BAF5-2D49270C973C}.Release|Win32.ActiveCfg = Release|Win32
{B57065D4-DDDA-4668-BAF5-2D49270C973C}.Release|Win32.Build.0 = Release|Win32
+ {B57065D4-DDDA-4668-BAF5-2D49270C973C}.Release|x64.ActiveCfg = Release|x64
+ {B57065D4-DDDA-4668-BAF5-2D49270C973C}.Release|x64.Build.0 = Release|x64
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
EndGlobalSection
+ GlobalSection(ExtensibilityGlobals) = postSolution
+ SolutionGuid = {2F6B4B1E-5D02-475F-B2FE-EA2D9E697E54}
+ EndGlobalSection
EndGlobal
diff --git a/jpeg/makecdsp.vc6 b/jpeg/makecdsp.vc6
index 3ab59651..68fea836 100644
--- a/jpeg/makecdsp.vc6
+++ b/jpeg/makecdsp.vc6
@@ -33,8 +33,8 @@ RSC=rc.exe
# PROP BASE Target_Dir ".\cjpeg"
# PROP Use_MFC 0
# PROP Use_Debug_Libraries 0
-# PROP Output_Dir ".\cjpeg\Release"
-# PROP Intermediate_Dir ".\cjpeg\Release"
+# PROP Output_Dir ".\Release"
+# PROP Intermediate_Dir ".\Release\cjpeg"
# PROP Ignore_Export_Lib 0
# PROP Target_Dir ".\cjpeg"
# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_CONSOLE" /YX /c
diff --git a/jpeg/makecfil.v15 b/jpeg/makecfil.v16
index a4f81ac3..2c002398 100644
--- a/jpeg/makecfil.v15
+++ b/jpeg/makecfil.v16
@@ -1,4 +1,4 @@
-<?xml version="1.0" encoding="utf-8"?>
+<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<Filter Include="Source Files">
diff --git a/jpeg/makecvcx.v15 b/jpeg/makecvcx.v16
index 9ca1fb3e..c67383b8 100644
--- a/jpeg/makecvcx.v15
+++ b/jpeg/makecvcx.v16
@@ -1,16 +1,20 @@
-<?xml version="1.0" encoding="utf-8"?>
+<?xml version="1.0" encoding="utf-8"?>
<Project DefaultTargets="Build" ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup Label="ProjectConfigurations">
<ProjectConfiguration Include="Release|Win32">
<Configuration>Release</Configuration>
<Platform>Win32</Platform>
</ProjectConfiguration>
+ <ProjectConfiguration Include="Release|x64">
+ <Configuration>Release</Configuration>
+ <Platform>x64</Platform>
+ </ProjectConfiguration>
</ItemGroup>
<PropertyGroup Label="Globals">
<ProjectGuid>{2E7FAAD9-2F58-4BDE-81F2-1D6D3FB8BF57}</ProjectGuid>
<Keyword>Win32Proj</Keyword>
<RootNamespace>cjpeg</RootNamespace>
- <WindowsTargetPlatformVersion>10.0.16299.0</WindowsTargetPlatformVersion>
+ <WindowsTargetPlatformVersion>10.0</WindowsTargetPlatformVersion>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">
@@ -18,7 +22,14 @@
<UseDebugLibraries>false</UseDebugLibraries>
<WholeProgramOptimization>true</WholeProgramOptimization>
<CharacterSet>Unicode</CharacterSet>
- <PlatformToolset>v141</PlatformToolset>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
+ <ConfigurationType>Application</ConfigurationType>
+ <UseDebugLibraries>false</UseDebugLibraries>
+ <WholeProgramOptimization>true</WholeProgramOptimization>
+ <CharacterSet>Unicode</CharacterSet>
+ <PlatformToolset>v142</PlatformToolset>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
<ImportGroup Label="ExtensionSettings">
@@ -26,11 +37,19 @@
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
</ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
<PropertyGroup Label="UserMacros" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<LinkIncremental>false</LinkIncremental>
- <OutDir>$(ProjectName)\$(Configuration)\</OutDir>
- <IntDir>$(ProjectName)\$(Configuration)\</IntDir>
+ <OutDir>$(Configuration)\$(Platform)\</OutDir>
+ <IntDir>$(Configuration)\$(Platform)\$(ProjectName)\</IntDir>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+ <LinkIncremental>false</LinkIncremental>
+ <OutDir>$(Configuration)\$(Platform)\</OutDir>
+ <IntDir>$(Configuration)\$(Platform)\$(ProjectName)\</IntDir>
</PropertyGroup>
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<ClCompile>
@@ -49,7 +68,27 @@
<GenerateDebugInformation>true</GenerateDebugInformation>
<EnableCOMDATFolding>true</EnableCOMDATFolding>
<OptimizeReferences>true</OptimizeReferences>
- <AdditionalDependencies>Release\jpeg.lib;kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies)</AdditionalDependencies>
+ <AdditionalDependencies>$(Configuration)\$(Platform)\jpeg.lib;kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies)</AdditionalDependencies>
+ </Link>
+ </ItemDefinitionGroup>
+ <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+ <ClCompile>
+ <WarningLevel>Level3</WarningLevel>
+ <PrecompiledHeader>NotUsing</PrecompiledHeader>
+ <Optimization>Full</Optimization>
+ <FunctionLevelLinking>true</FunctionLevelLinking>
+ <IntrinsicFunctions>false</IntrinsicFunctions>
+ <PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;_CRT_SECURE_NO_WARNINGS</PreprocessorDefinitions>
+ <OmitFramePointers>true</OmitFramePointers>
+ <EnableFiberSafeOptimizations>true</EnableFiberSafeOptimizations>
+ <DisableSpecificWarnings>4996</DisableSpecificWarnings>
+ </ClCompile>
+ <Link>
+ <SubSystem>Console</SubSystem>
+ <GenerateDebugInformation>true</GenerateDebugInformation>
+ <EnableCOMDATFolding>true</EnableCOMDATFolding>
+ <OptimizeReferences>true</OptimizeReferences>
+ <AdditionalDependencies>$(Configuration)\$(Platform)\jpeg.lib;kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies)</AdditionalDependencies>
</Link>
</ItemDefinitionGroup>
<ItemGroup>
diff --git a/jpeg/makeddsp.vc6 b/jpeg/makeddsp.vc6
index f583a0f6..5ff61ef6 100644
--- a/jpeg/makeddsp.vc6
+++ b/jpeg/makeddsp.vc6
@@ -33,8 +33,8 @@ RSC=rc.exe
# PROP BASE Target_Dir ".\djpeg"
# PROP Use_MFC 0
# PROP Use_Debug_Libraries 0
-# PROP Output_Dir ".\djpeg\Release"
-# PROP Intermediate_Dir ".\djpeg\Release"
+# PROP Output_Dir ".\Release"
+# PROP Intermediate_Dir ".\Release\djpeg"
# PROP Ignore_Export_Lib 0
# PROP Target_Dir ".\djpeg"
# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_CONSOLE" /YX /c
diff --git a/jpeg/makedfil.v15 b/jpeg/makedfil.v16
index b4a83abf..d190e154 100644
--- a/jpeg/makedfil.v15
+++ b/jpeg/makedfil.v16
@@ -1,4 +1,4 @@
-<?xml version="1.0" encoding="utf-8"?>
+<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<Filter Include="Source Files">
diff --git a/jpeg/makedvcx.v15 b/jpeg/makedvcx.v16
index a611ac58..b295719d 100644
--- a/jpeg/makedvcx.v15
+++ b/jpeg/makedvcx.v16
@@ -1,16 +1,20 @@
-<?xml version="1.0" encoding="utf-8"?>
+<?xml version="1.0" encoding="utf-8"?>
<Project DefaultTargets="Build" ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup Label="ProjectConfigurations">
<ProjectConfiguration Include="Release|Win32">
<Configuration>Release</Configuration>
<Platform>Win32</Platform>
</ProjectConfiguration>
+ <ProjectConfiguration Include="Release|x64">
+ <Configuration>Release</Configuration>
+ <Platform>x64</Platform>
+ </ProjectConfiguration>
</ItemGroup>
<PropertyGroup Label="Globals">
<ProjectGuid>{11043137-B453-4DFA-9010-4D2B9DC1545C}</ProjectGuid>
<Keyword>Win32Proj</Keyword>
<RootNamespace>djpeg</RootNamespace>
- <WindowsTargetPlatformVersion>10.0.16299.0</WindowsTargetPlatformVersion>
+ <WindowsTargetPlatformVersion>10.0</WindowsTargetPlatformVersion>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">
@@ -18,7 +22,14 @@
<UseDebugLibraries>false</UseDebugLibraries>
<WholeProgramOptimization>true</WholeProgramOptimization>
<CharacterSet>Unicode</CharacterSet>
- <PlatformToolset>v141</PlatformToolset>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
+ <ConfigurationType>Application</ConfigurationType>
+ <UseDebugLibraries>false</UseDebugLibraries>
+ <WholeProgramOptimization>true</WholeProgramOptimization>
+ <CharacterSet>Unicode</CharacterSet>
+ <PlatformToolset>v142</PlatformToolset>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
<ImportGroup Label="ExtensionSettings">
@@ -26,11 +37,19 @@
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
</ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
<PropertyGroup Label="UserMacros" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<LinkIncremental>false</LinkIncremental>
- <OutDir>$(ProjectName)\$(Configuration)\</OutDir>
- <IntDir>$(ProjectName)\$(Configuration)\</IntDir>
+ <OutDir>$(Configuration)\$(Platform)\</OutDir>
+ <IntDir>$(Configuration)\$(Platform)\$(ProjectName)\</IntDir>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+ <LinkIncremental>false</LinkIncremental>
+ <OutDir>$(Configuration)\$(Platform)\</OutDir>
+ <IntDir>$(Configuration)\$(Platform)\$(ProjectName)\</IntDir>
</PropertyGroup>
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<ClCompile>
@@ -49,7 +68,27 @@
<GenerateDebugInformation>true</GenerateDebugInformation>
<EnableCOMDATFolding>true</EnableCOMDATFolding>
<OptimizeReferences>true</OptimizeReferences>
- <AdditionalDependencies>Release\jpeg.lib;kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies)</AdditionalDependencies>
+ <AdditionalDependencies>$(Configuration)\$(Platform)\jpeg.lib;kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies)</AdditionalDependencies>
+ </Link>
+ </ItemDefinitionGroup>
+ <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+ <ClCompile>
+ <WarningLevel>Level3</WarningLevel>
+ <PrecompiledHeader>NotUsing</PrecompiledHeader>
+ <Optimization>Full</Optimization>
+ <FunctionLevelLinking>true</FunctionLevelLinking>
+ <IntrinsicFunctions>false</IntrinsicFunctions>
+ <PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;_CRT_SECURE_NO_WARNINGS</PreprocessorDefinitions>
+ <OmitFramePointers>true</OmitFramePointers>
+ <EnableFiberSafeOptimizations>true</EnableFiberSafeOptimizations>
+ <DisableSpecificWarnings>4996</DisableSpecificWarnings>
+ </ClCompile>
+ <Link>
+ <SubSystem>Console</SubSystem>
+ <GenerateDebugInformation>true</GenerateDebugInformation>
+ <EnableCOMDATFolding>true</EnableCOMDATFolding>
+ <OptimizeReferences>true</OptimizeReferences>
+ <AdditionalDependencies>$(Configuration)\$(Platform)\jpeg.lib;kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies)</AdditionalDependencies>
</Link>
</ItemDefinitionGroup>
<ItemGroup>
diff --git a/jpeg/makefile.ansi b/jpeg/makefile.ansi
index d4ca2d34..cb695c50 100644
--- a/jpeg/makefile.ansi
+++ b/jpeg/makefile.ansi
@@ -66,9 +66,9 @@ MKFILES= configure Makefile.in makefile.ansi makefile.unix makefile.b32 \
makejmak.vc6 makecdep.vc6 makecdsp.vc6 makecmak.vc6 makeddep.vc6 \
makeddsp.vc6 makedmak.vc6 maketdep.vc6 maketdsp.vc6 maketmak.vc6 \
makerdep.vc6 makerdsp.vc6 makermak.vc6 makewdep.vc6 makewdsp.vc6 \
- makewmak.vc6 makejsln.v15 makeasln.v15 makejvcx.v15 makejfil.v15 \
- makecvcx.v15 makecfil.v15 makedvcx.v15 makedfil.v15 maketvcx.v15 \
- maketfil.v15 makervcx.v15 makerfil.v15 makewvcx.v15 makewfil.v15 \
+ makewmak.vc6 makejsln.v16 makeasln.v16 makejvcx.v16 makejfil.v16 \
+ makecvcx.v16 makecfil.v16 makedvcx.v16 makedfil.v16 maketvcx.v16 \
+ maketfil.v16 makervcx.v16 makerfil.v16 makewvcx.v16 makewfil.v16 \
makeproj.mac makcjpeg.st makdjpeg.st makljpeg.st maktjpeg.st \
makefile.manx makefile.sas makefile.mms makefile.vms makvms.opt
CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
@@ -77,8 +77,8 @@ CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
CONFIGUREFILES= config.guess config.sub install-sh ltmain.sh depcomp \
missing ar-lib
OTHERFILES= jconfig.txt ckconfig.c jmemdosa.asm libjpeg.map libjpeg.pc.in
-TESTFILES= testorig.jpg testimg.ppm testimg.bmp testimg.jpg testprog.jpg \
- testimgp.jpg
+TESTFILES= testorig.jpg testimg.ppm testimg.gif testimg.bmp testimg.jpg \
+ testprog.jpg testimgp.jpg
DISTFILES= $(DOCS) $(MKFILES) $(CONFIGFILES) $(SOURCES) $(INCLUDES) \
$(CONFIGUREFILES) $(OTHERFILES) $(TESTFILES)
# library object files common to compression and decompression
@@ -136,13 +136,15 @@ clean:
test: cjpeg djpeg jpegtran
$(RM) testout*
- ./djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
- ./djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
- ./cjpeg -dct int -outfile testout.jpg testimg.ppm
+ ./djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
+ ./djpeg -dct int -gif -outfile testout.gif testorig.jpg
+ ./djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
+ ./cjpeg -dct int -outfile testout.jpg testimg.ppm
./djpeg -dct int -ppm -outfile testoutp.ppm testprog.jpg
./cjpeg -dct int -progressive -opt -outfile testoutp.jpg testimg.ppm
./jpegtran -outfile testoutt.jpg testprog.jpg
cmp testimg.ppm testout.ppm
+ cmp testimg.gif testout.gif
cmp testimg.bmp testout.bmp
cmp testimg.jpg testout.jpg
cmp testimg.ppm testoutp.ppm
diff --git a/jpeg/makefile.b32 b/jpeg/makefile.b32
index 2a7abfd5..083e56d6 100644
--- a/jpeg/makefile.b32
+++ b/jpeg/makefile.b32
@@ -62,9 +62,9 @@ MKFILES= configure Makefile.in makefile.ansi makefile.unix makefile.b32 \
makejmak.vc6 makecdep.vc6 makecdsp.vc6 makecmak.vc6 makeddep.vc6 \
makeddsp.vc6 makedmak.vc6 maketdep.vc6 maketdsp.vc6 maketmak.vc6 \
makerdep.vc6 makerdsp.vc6 makermak.vc6 makewdep.vc6 makewdsp.vc6 \
- makewmak.vc6 makejsln.v15 makeasln.v15 makejvcx.v15 makejfil.v15 \
- makecvcx.v15 makecfil.v15 makedvcx.v15 makedfil.v15 maketvcx.v15 \
- maketfil.v15 makervcx.v15 makerfil.v15 makewvcx.v15 makewfil.v15 \
+ makewmak.vc6 makejsln.v16 makeasln.v16 makejvcx.v16 makejfil.v16 \
+ makecvcx.v16 makecfil.v16 makedvcx.v16 makedfil.v16 maketvcx.v16 \
+ maketfil.v16 makervcx.v16 makerfil.v16 makewvcx.v16 makewfil.v16 \
makeproj.mac makcjpeg.st makdjpeg.st makljpeg.st maktjpeg.st \
makefile.manx makefile.sas makefile.mms makefile.vms makvms.opt
CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
@@ -73,8 +73,8 @@ CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
CONFIGUREFILES= config.guess config.sub install-sh ltmain.sh depcomp \
missing ar-lib
OTHERFILES= jconfig.txt ckconfig.c jmemdosa.asm libjpeg.map libjpeg.pc.in
-TESTFILES= testorig.jpg testimg.ppm testimg.bmp testimg.jpg testprog.jpg \
- testimgp.jpg
+TESTFILES= testorig.jpg testimg.ppm testimg.gif testimg.bmp testimg.jpg \
+ testprog.jpg testimgp.jpg
DISTFILES= $(DOCS) $(MKFILES) $(CONFIGFILES) $(SOURCES) $(INCLUDES) \
$(CONFIGUREFILES) $(OTHERFILES) $(TESTFILES)
# library object files common to compression and decompression
@@ -154,14 +154,16 @@ clean:
test: cjpeg.exe djpeg.exe jpegtran.exe
- del testout*.*
- djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
- djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
- cjpeg -dct int -outfile testout.jpg testimg.ppm
+ djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
+ djpeg -dct int -gif -outfile testout.gif testorig.jpg
+ djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
+ cjpeg -dct int -outfile testout.jpg testimg.ppm
djpeg -dct int -ppm -outfile testoutp.ppm testprog.jpg
cjpeg -dct int -progressive -opt -outfile testoutp.jpg testimg.ppm
jpegtran -outfile testoutt.jpg testprog.jpg
echo n > n.tmp
comp testimg.ppm testout.ppm < n.tmp
+ comp testimg.gif testout.gif < n.tmp
comp testimg.bmp testout.bmp < n.tmp
comp testimg.jpg testout.jpg < n.tmp
comp testimg.ppm testoutp.ppm < n.tmp
diff --git a/jpeg/makefile.bcc b/jpeg/makefile.bcc
index 13142a91..16b640ab 100644
--- a/jpeg/makefile.bcc
+++ b/jpeg/makefile.bcc
@@ -93,9 +93,9 @@ MKFILES= configure Makefile.in makefile.ansi makefile.unix makefile.b32 \
makejmak.vc6 makecdep.vc6 makecdsp.vc6 makecmak.vc6 makeddep.vc6 \
makeddsp.vc6 makedmak.vc6 maketdep.vc6 maketdsp.vc6 maketmak.vc6 \
makerdep.vc6 makerdsp.vc6 makermak.vc6 makewdep.vc6 makewdsp.vc6 \
- makewmak.vc6 makejsln.v15 makeasln.v15 makejvcx.v15 makejfil.v15 \
- makecvcx.v15 makecfil.v15 makedvcx.v15 makedfil.v15 maketvcx.v15 \
- maketfil.v15 makervcx.v15 makerfil.v15 makewvcx.v15 makewfil.v15 \
+ makewmak.vc6 makejsln.v16 makeasln.v16 makejvcx.v16 makejfil.v16 \
+ makecvcx.v16 makecfil.v16 makedvcx.v16 makedfil.v16 maketvcx.v16 \
+ maketfil.v16 makervcx.v16 makerfil.v16 makewvcx.v16 makewfil.v16 \
makeproj.mac makcjpeg.st makdjpeg.st makljpeg.st maktjpeg.st \
makefile.manx makefile.sas makefile.mms makefile.vms makvms.opt
CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
@@ -104,8 +104,8 @@ CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
CONFIGUREFILES= config.guess config.sub install-sh ltmain.sh depcomp \
missing ar-lib
OTHERFILES= jconfig.txt ckconfig.c jmemdosa.asm libjpeg.map libjpeg.pc.in
-TESTFILES= testorig.jpg testimg.ppm testimg.bmp testimg.jpg testprog.jpg \
- testimgp.jpg
+TESTFILES= testorig.jpg testimg.ppm testimg.gif testimg.bmp testimg.jpg \
+ testprog.jpg testimgp.jpg
DISTFILES= $(DOCS) $(MKFILES) $(CONFIGFILES) $(SOURCES) $(INCLUDES) \
$(CONFIGUREFILES) $(OTHERFILES) $(TESTFILES)
# library object files common to compression and decompression
@@ -194,14 +194,16 @@ clean:
test: cjpeg.exe djpeg.exe jpegtran.exe
- del testout*.*
- djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
- djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
- cjpeg -dct int -outfile testout.jpg testimg.ppm
+ djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
+ djpeg -dct int -gif -outfile testout.gif testorig.jpg
+ djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
+ cjpeg -dct int -outfile testout.jpg testimg.ppm
djpeg -dct int -ppm -outfile testoutp.ppm testprog.jpg
cjpeg -dct int -progressive -opt -outfile testoutp.jpg testimg.ppm
jpegtran -outfile testoutt.jpg testprog.jpg
!if $d(DOS)
fc /b testimg.ppm testout.ppm
+ fc /b testimg.gif testout.gif
fc /b testimg.bmp testout.bmp
fc /b testimg.jpg testout.jpg
fc /b testimg.ppm testoutp.ppm
@@ -210,6 +212,7 @@ test: cjpeg.exe djpeg.exe jpegtran.exe
!else
echo n > n.tmp
comp testimg.ppm testout.ppm < n.tmp
+ comp testimg.gif testout.gif < n.tmp
comp testimg.bmp testout.bmp < n.tmp
comp testimg.jpg testout.jpg < n.tmp
comp testimg.ppm testoutp.ppm < n.tmp
diff --git a/jpeg/makefile.dj b/jpeg/makefile.dj
index f69c1458..38724919 100644
--- a/jpeg/makefile.dj
+++ b/jpeg/makefile.dj
@@ -66,9 +66,9 @@ MKFILES= configure Makefile.in makefile.ansi makefile.unix makefile.b32 \
makejmak.vc6 makecdep.vc6 makecdsp.vc6 makecmak.vc6 makeddep.vc6 \
makeddsp.vc6 makedmak.vc6 maketdep.vc6 maketdsp.vc6 maketmak.vc6 \
makerdep.vc6 makerdsp.vc6 makermak.vc6 makewdep.vc6 makewdsp.vc6 \
- makewmak.vc6 makejsln.v15 makeasln.v15 makejvcx.v15 makejfil.v15 \
- makecvcx.v15 makecfil.v15 makedvcx.v15 makedfil.v15 maketvcx.v15 \
- maketfil.v15 makervcx.v15 makerfil.v15 makewvcx.v15 makewfil.v15 \
+ makewmak.vc6 makejsln.v16 makeasln.v16 makejvcx.v16 makejfil.v16 \
+ makecvcx.v16 makecfil.v16 makedvcx.v16 makedfil.v16 maketvcx.v16 \
+ maketfil.v16 makervcx.v16 makerfil.v16 makewvcx.v16 makewfil.v16 \
makeproj.mac makcjpeg.st makdjpeg.st makljpeg.st maktjpeg.st \
makefile.manx makefile.sas makefile.mms makefile.vms makvms.opt
CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
@@ -77,8 +77,8 @@ CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
CONFIGUREFILES= config.guess config.sub install-sh ltmain.sh depcomp \
missing ar-lib
OTHERFILES= jconfig.txt ckconfig.c jmemdosa.asm libjpeg.map libjpeg.pc.in
-TESTFILES= testorig.jpg testimg.ppm testimg.bmp testimg.jpg testprog.jpg \
- testimgp.jpg
+TESTFILES= testorig.jpg testimg.ppm testimg.gif testimg.bmp testimg.jpg \
+ testprog.jpg testimgp.jpg
DISTFILES= $(DOCS) $(MKFILES) $(CONFIGFILES) $(SOURCES) $(INCLUDES) \
$(CONFIGUREFILES) $(OTHERFILES) $(TESTFILES)
# library object files common to compression and decompression
@@ -142,13 +142,15 @@ clean:
test: cjpeg.exe djpeg.exe jpegtran.exe
$(RM) testout*.*
- ./djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
- ./djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
- ./cjpeg -dct int -outfile testout.jpg testimg.ppm
+ ./djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
+ ./djpeg -dct int -gif -outfile testout.gif testorig.jpg
+ ./djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
+ ./cjpeg -dct int -outfile testout.jpg testimg.ppm
./djpeg -dct int -ppm -outfile testoutp.ppm testprog.jpg
./cjpeg -dct int -progressive -opt -outfile testoutp.jpg testimg.ppm
./jpegtran -outfile testoutt.jpg testprog.jpg
fc /b testimg.ppm testout.ppm
+ fc /b testimg.gif testout.gif
fc /b testimg.bmp testout.bmp
fc /b testimg.jpg testout.jpg
fc /b testimg.ppm testoutp.ppm
diff --git a/jpeg/makefile.manx b/jpeg/makefile.manx
index 28eb50db..4776b637 100644
--- a/jpeg/makefile.manx
+++ b/jpeg/makefile.manx
@@ -67,9 +67,9 @@ MKFILES= configure Makefile.in makefile.ansi makefile.unix makefile.b32 \
makejmak.vc6 makecdep.vc6 makecdsp.vc6 makecmak.vc6 makeddep.vc6 \
makeddsp.vc6 makedmak.vc6 maketdep.vc6 maketdsp.vc6 maketmak.vc6 \
makerdep.vc6 makerdsp.vc6 makermak.vc6 makewdep.vc6 makewdsp.vc6 \
- makewmak.vc6 makejsln.v15 makeasln.v15 makejvcx.v15 makejfil.v15 \
- makecvcx.v15 makecfil.v15 makedvcx.v15 makedfil.v15 maketvcx.v15 \
- maketfil.v15 makervcx.v15 makerfil.v15 makewvcx.v15 makewfil.v15 \
+ makewmak.vc6 makejsln.v16 makeasln.v16 makejvcx.v16 makejfil.v16 \
+ makecvcx.v16 makecfil.v16 makedvcx.v16 makedfil.v16 maketvcx.v16 \
+ maketfil.v16 makervcx.v16 makerfil.v16 makewvcx.v16 makewfil.v16 \
makeproj.mac makcjpeg.st makdjpeg.st makljpeg.st maktjpeg.st \
makefile.manx makefile.sas makefile.mms makefile.vms makvms.opt
CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
@@ -78,8 +78,8 @@ CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
CONFIGUREFILES= config.guess config.sub install-sh ltmain.sh depcomp \
missing ar-lib
OTHERFILES= jconfig.txt ckconfig.c jmemdosa.asm libjpeg.map libjpeg.pc.in
-TESTFILES= testorig.jpg testimg.ppm testimg.bmp testimg.jpg testprog.jpg \
- testimgp.jpg
+TESTFILES= testorig.jpg testimg.ppm testimg.gif testimg.bmp testimg.jpg \
+ testprog.jpg testimgp.jpg
DISTFILES= $(DOCS) $(MKFILES) $(CONFIGFILES) $(SOURCES) $(INCLUDES) \
$(CONFIGUREFILES) $(OTHERFILES) $(TESTFILES)
# library object files common to compression and decompression
@@ -136,13 +136,15 @@ clean:
test: cjpeg djpeg jpegtran
-$(RM) testout*.*
- djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
- djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
- cjpeg -dct int -outfile testout.jpg testimg.ppm
+ djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
+ djpeg -dct int -gif -outfile testout.gif testorig.jpg
+ djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
+ cjpeg -dct int -outfile testout.jpg testimg.ppm
djpeg -dct int -ppm -outfile testoutp.ppm testprog.jpg
cjpeg -dct int -progressive -opt -outfile testoutp.jpg testimg.ppm
jpegtran -outfile testoutt.jpg testprog.jpg
cmp testimg.ppm testout.ppm
+ cmp testimg.gif testout.gif
cmp testimg.bmp testout.bmp
cmp testimg.jpg testout.jpg
cmp testimg.ppm testoutp.ppm
diff --git a/jpeg/makefile.mc6 b/jpeg/makefile.mc6
index 401af0c6..7e155f5d 100644
--- a/jpeg/makefile.mc6
+++ b/jpeg/makefile.mc6
@@ -64,9 +64,9 @@ MKFILES= configure Makefile.in makefile.ansi makefile.unix makefile.b32 \
makejmak.vc6 makecdep.vc6 makecdsp.vc6 makecmak.vc6 makeddep.vc6 \
makeddsp.vc6 makedmak.vc6 maketdep.vc6 maketdsp.vc6 maketmak.vc6 \
makerdep.vc6 makerdsp.vc6 makermak.vc6 makewdep.vc6 makewdsp.vc6 \
- makewmak.vc6 makejsln.v15 makeasln.v15 makejvcx.v15 makejfil.v15 \
- makecvcx.v15 makecfil.v15 makedvcx.v15 makedfil.v15 maketvcx.v15 \
- maketfil.v15 makervcx.v15 makerfil.v15 makewvcx.v15 makewfil.v15 \
+ makewmak.vc6 makejsln.v16 makeasln.v16 makejvcx.v16 makejfil.v16 \
+ makecvcx.v16 makecfil.v16 makedvcx.v16 makedfil.v16 maketvcx.v16 \
+ maketfil.v16 makervcx.v16 makerfil.v16 makewvcx.v16 makewfil.v16 \
makeproj.mac makcjpeg.st makdjpeg.st makljpeg.st maktjpeg.st \
makefile.manx makefile.sas makefile.mms makefile.vms makvms.opt
CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
@@ -75,8 +75,8 @@ CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
CONFIGUREFILES= config.guess config.sub install-sh ltmain.sh depcomp \
missing ar-lib
OTHERFILES= jconfig.txt ckconfig.c jmemdosa.asm libjpeg.map libjpeg.pc.in
-TESTFILES= testorig.jpg testimg.ppm testimg.bmp testimg.jpg testprog.jpg \
- testimgp.jpg
+TESTFILES= testorig.jpg testimg.ppm testimg.gif testimg.bmp testimg.jpg \
+ testprog.jpg testimgp.jpg
DISTFILES= $(DOCS) $(MKFILES) $(CONFIGFILES) $(SOURCES) $(INCLUDES) \
$(CONFIGUREFILES) $(OTHERFILES) $(TESTFILES)
# library object files common to compression and decompression
@@ -169,13 +169,15 @@ clean:
test: cjpeg.exe djpeg.exe jpegtran.exe
del testout*.*
- djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
- djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
- cjpeg -dct int -outfile testout.jpg testimg.ppm
+ djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
+ djpeg -dct int -gif -outfile testout.gif testorig.jpg
+ djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
+ cjpeg -dct int -outfile testout.jpg testimg.ppm
djpeg -dct int -ppm -outfile testoutp.ppm testprog.jpg
cjpeg -dct int -progressive -opt -outfile testoutp.jpg testimg.ppm
jpegtran -outfile testoutt.jpg testprog.jpg
fc /b testimg.ppm testout.ppm
+ fc /b testimg.gif testout.gif
fc /b testimg.bmp testout.bmp
fc /b testimg.jpg testout.jpg
fc /b testimg.ppm testoutp.ppm
diff --git a/jpeg/makefile.mms b/jpeg/makefile.mms
index e1792be4..0e616bbb 100644
--- a/jpeg/makefile.mms
+++ b/jpeg/makefile.mms
@@ -53,9 +53,9 @@ MKFILES= configure Makefile.in makefile.ansi makefile.unix makefile.b32 \
makejmak.vc6 makecdep.vc6 makecdsp.vc6 makecmak.vc6 makeddep.vc6 \
makeddsp.vc6 makedmak.vc6 maketdep.vc6 maketdsp.vc6 maketmak.vc6 \
makerdep.vc6 makerdsp.vc6 makermak.vc6 makewdep.vc6 makewdsp.vc6 \
- makewmak.vc6 makejsln.v15 makeasln.v15 makejvcx.v15 makejfil.v15 \
- makecvcx.v15 makecfil.v15 makedvcx.v15 makedfil.v15 maketvcx.v15 \
- maketfil.v15 makervcx.v15 makerfil.v15 makewvcx.v15 makewfil.v15 \
+ makewmak.vc6 makejsln.v16 makeasln.v16 makejvcx.v16 makejfil.v16 \
+ makecvcx.v16 makecfil.v16 makedvcx.v16 makedfil.v16 maketvcx.v16 \
+ maketfil.v16 makervcx.v16 makerfil.v16 makewvcx.v16 makewfil.v16 \
makeproj.mac makcjpeg.st makdjpeg.st makljpeg.st maktjpeg.st \
makefile.manx makefile.sas makefile.mms makefile.vms makvms.opt
CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
@@ -64,8 +64,8 @@ CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
CONFIGUREFILES= config.guess config.sub install-sh ltmain.sh depcomp \
missing ar-lib
OTHERFILES= jconfig.txt ckconfig.c jmemdosa.asm libjpeg.map libjpeg.pc.in
-TESTFILES= testorig.jpg testimg.ppm testimg.bmp testimg.jpg testprog.jpg \
- testimgp.jpg
+TESTFILES= testorig.jpg testimg.ppm testimg.gif testimg.bmp testimg.jpg \
+ testprog.jpg testimgp.jpg
DISTFILES= $(DOCS) $(MKFILES) $(CONFIGFILES) $(SOURCES) $(INCLUDES) \
$(CONFIGUREFILES) $(OTHERFILES) $(TESTFILES)
# library object files common to compression and decompression
@@ -141,12 +141,14 @@ clean :
test : cjpeg.exe djpeg.exe jpegtran.exe
mcr sys$disk:[]djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
+ mcr sys$disk:[]djpeg -dct int -gif -outfile testout.gif testorig.jpg
mcr sys$disk:[]djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
- mcr sys$disk:[]cjpeg -dct int -outfile testout.jpg testimg.ppm
+ mcr sys$disk:[]cjpeg -dct int -outfile testout.jpg testimg.ppm
mcr sys$disk:[]djpeg -dct int -ppm -outfile testoutp.ppm testprog.jpg
mcr sys$disk:[]cjpeg -dct int -progressive -opt -outfile testoutp.jpg testimg.ppm
mcr sys$disk:[]jpegtran -outfile testoutt.jpg testprog.jpg
- Backup /Compare/Log testimg.ppm testout.ppm
+ - Backup /Compare/Log testimg.gif testout.gif
- Backup /Compare/Log testimg.bmp testout.bmp
- Backup /Compare/Log testimg.jpg testout.jpg
- Backup /Compare/Log testimg.ppm testoutp.ppm
diff --git a/jpeg/makefile.sas b/jpeg/makefile.sas
index 90e1d9c9..f5beb1f1 100644
--- a/jpeg/makefile.sas
+++ b/jpeg/makefile.sas
@@ -75,9 +75,9 @@ MKFILES= configure Makefile.in makefile.ansi makefile.unix makefile.b32 \
makejmak.vc6 makecdep.vc6 makecdsp.vc6 makecmak.vc6 makeddep.vc6 \
makeddsp.vc6 makedmak.vc6 maketdep.vc6 maketdsp.vc6 maketmak.vc6 \
makerdep.vc6 makerdsp.vc6 makermak.vc6 makewdep.vc6 makewdsp.vc6 \
- makewmak.vc6 makejsln.v15 makeasln.v15 makejvcx.v15 makejfil.v15 \
- makecvcx.v15 makecfil.v15 makedvcx.v15 makedfil.v15 maketvcx.v15 \
- maketfil.v15 makervcx.v15 makerfil.v15 makewvcx.v15 makewfil.v15 \
+ makewmak.vc6 makejsln.v16 makeasln.v16 makejvcx.v16 makejfil.v16 \
+ makecvcx.v16 makecfil.v16 makedvcx.v16 makedfil.v16 maketvcx.v16 \
+ maketfil.v16 makervcx.v16 makerfil.v16 makewvcx.v16 makewfil.v16 \
makeproj.mac makcjpeg.st makdjpeg.st makljpeg.st maktjpeg.st \
makefile.manx makefile.sas makefile.mms makefile.vms makvms.opt
CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
@@ -86,8 +86,8 @@ CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
CONFIGUREFILES= config.guess config.sub install-sh ltmain.sh depcomp \
missing ar-lib
OTHERFILES= jconfig.txt ckconfig.c jmemdosa.asm libjpeg.map libjpeg.pc.in
-TESTFILES= testorig.jpg testimg.ppm testimg.bmp testimg.jpg testprog.jpg \
- testimgp.jpg
+TESTFILES= testorig.jpg testimg.ppm testimg.gif testimg.bmp testimg.jpg \
+ testprog.jpg testimgp.jpg
DISTFILES= $(DOCS) $(MKFILES) $(CONFIGFILES) $(SOURCES) $(INCLUDES) \
$(CONFIGUREFILES) $(OTHERFILES) $(TESTFILES)
# library object files common to compression and decompression
@@ -174,13 +174,15 @@ clean:
test: cjpeg djpeg jpegtran
-$(RM) testout*.*
- djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
- djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
- cjpeg -dct int -outfile testout.jpg testimg.ppm
+ djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
+ djpeg -dct int -gif -outfile testout.gif testorig.jpg
+ djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
+ cjpeg -dct int -outfile testout.jpg testimg.ppm
djpeg -dct int -ppm -outfile testoutp.ppm testprog.jpg
cjpeg -dct int -progressive -opt -outfile testoutp.jpg testimg.ppm
jpegtran -outfile testoutt.jpg testprog.jpg
cmp testimg.ppm testout.ppm
+ cmp testimg.gif testout.gif
cmp testimg.bmp testout.bmp
cmp testimg.jpg testout.jpg
cmp testimg.ppm testoutp.ppm
diff --git a/jpeg/makefile.unix b/jpeg/makefile.unix
index 77d38515..5887970b 100644
--- a/jpeg/makefile.unix
+++ b/jpeg/makefile.unix
@@ -70,9 +70,9 @@ MKFILES= configure Makefile.in makefile.ansi makefile.unix makefile.b32 \
makejmak.vc6 makecdep.vc6 makecdsp.vc6 makecmak.vc6 makeddep.vc6 \
makeddsp.vc6 makedmak.vc6 maketdep.vc6 maketdsp.vc6 maketmak.vc6 \
makerdep.vc6 makerdsp.vc6 makermak.vc6 makewdep.vc6 makewdsp.vc6 \
- makewmak.vc6 makejsln.v15 makeasln.v15 makejvcx.v15 makejfil.v15 \
- makecvcx.v15 makecfil.v15 makedvcx.v15 makedfil.v15 maketvcx.v15 \
- maketfil.v15 makervcx.v15 makerfil.v15 makewvcx.v15 makewfil.v15 \
+ makewmak.vc6 makejsln.v16 makeasln.v16 makejvcx.v16 makejfil.v16 \
+ makecvcx.v16 makecfil.v16 makedvcx.v16 makedfil.v16 maketvcx.v16 \
+ maketfil.v16 makervcx.v16 makerfil.v16 makewvcx.v16 makewfil.v16 \
makeproj.mac makcjpeg.st makdjpeg.st makljpeg.st maktjpeg.st \
makefile.manx makefile.sas makefile.mms makefile.vms makvms.opt
CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
@@ -81,8 +81,8 @@ CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
CONFIGUREFILES= config.guess config.sub install-sh ltmain.sh depcomp \
missing ar-lib
OTHERFILES= jconfig.txt ckconfig.c jmemdosa.asm libjpeg.map libjpeg.pc.in
-TESTFILES= testorig.jpg testimg.ppm testimg.bmp testimg.jpg testprog.jpg \
- testimgp.jpg
+TESTFILES= testorig.jpg testimg.ppm testimg.gif testimg.bmp testimg.jpg \
+ testprog.jpg testimgp.jpg
DISTFILES= $(DOCS) $(MKFILES) $(CONFIGFILES) $(SOURCES) $(INCLUDES) \
$(CONFIGUREFILES) $(OTHERFILES) $(TESTFILES)
# library object files common to compression and decompression
@@ -150,13 +150,15 @@ clean:
test: cjpeg djpeg jpegtran
$(RM) testout*
- ./djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
- ./djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
- ./cjpeg -dct int -outfile testout.jpg testimg.ppm
+ ./djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
+ ./djpeg -dct int -gif -outfile testout.gif testorig.jpg
+ ./djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
+ ./cjpeg -dct int -outfile testout.jpg testimg.ppm
./djpeg -dct int -ppm -outfile testoutp.ppm testprog.jpg
./cjpeg -dct int -progressive -opt -outfile testoutp.jpg testimg.ppm
./jpegtran -outfile testoutt.jpg testprog.jpg
cmp testimg.ppm testout.ppm
+ cmp testimg.gif testout.gif
cmp testimg.bmp testout.bmp
cmp testimg.jpg testout.jpg
cmp testimg.ppm testoutp.ppm
diff --git a/jpeg/makefile.vc b/jpeg/makefile.vc
index bb3381cc..aff85a66 100644
--- a/jpeg/makefile.vc
+++ b/jpeg/makefile.vc
@@ -63,9 +63,9 @@ MKFILES= configure Makefile.in makefile.ansi makefile.unix makefile.b32 \
makejmak.vc6 makecdep.vc6 makecdsp.vc6 makecmak.vc6 makeddep.vc6 \
makeddsp.vc6 makedmak.vc6 maketdep.vc6 maketdsp.vc6 maketmak.vc6 \
makerdep.vc6 makerdsp.vc6 makermak.vc6 makewdep.vc6 makewdsp.vc6 \
- makewmak.vc6 makejsln.v15 makeasln.v15 makejvcx.v15 makejfil.v15 \
- makecvcx.v15 makecfil.v15 makedvcx.v15 makedfil.v15 maketvcx.v15 \
- maketfil.v15 makervcx.v15 makerfil.v15 makewvcx.v15 makewfil.v15 \
+ makewmak.vc6 makejsln.v16 makeasln.v16 makejvcx.v16 makejfil.v16 \
+ makecvcx.v16 makecfil.v16 makedvcx.v16 makedfil.v16 maketvcx.v16 \
+ maketfil.v16 makervcx.v16 makerfil.v16 makewvcx.v16 makewfil.v16 \
makeproj.mac makcjpeg.st makdjpeg.st makljpeg.st maktjpeg.st \
makefile.manx makefile.sas makefile.mms makefile.vms makvms.opt
CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
@@ -74,8 +74,8 @@ CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
CONFIGUREFILES= config.guess config.sub install-sh ltmain.sh depcomp \
missing ar-lib
OTHERFILES= jconfig.txt ckconfig.c jmemdosa.asm libjpeg.map libjpeg.pc.in
-TESTFILES= testorig.jpg testimg.ppm testimg.bmp testimg.jpg testprog.jpg \
- testimgp.jpg
+TESTFILES= testorig.jpg testimg.ppm testimg.gif testimg.bmp testimg.jpg \
+ testprog.jpg testimgp.jpg
DISTFILES= $(DOCS) $(MKFILES) $(CONFIGFILES) $(SOURCES) $(INCLUDES) \
$(CONFIGUREFILES) $(OTHERFILES) $(TESTFILES)
# library object files common to compression and decompression
@@ -154,32 +154,74 @@ setup-vc6:
ren makewdep.vc6 wrjpgcom.dep
ren makewdsp.vc6 wrjpgcom.dsp
-setup-v15:
+setupcopy-vc6:
+ copy /y jconfig.vc jconfig.h
+ copy /y makejdsw.vc6 jpeg.dsw
+ copy /y makeadsw.vc6 apps.dsw
+ copy /y makejmak.vc6 jpeg.mak
+ copy /y makejdep.vc6 jpeg.dep
+ copy /y makejdsp.vc6 jpeg.dsp
+ copy /y makecmak.vc6 cjpeg.mak
+ copy /y makecdep.vc6 cjpeg.dep
+ copy /y makecdsp.vc6 cjpeg.dsp
+ copy /y makedmak.vc6 djpeg.mak
+ copy /y makeddep.vc6 djpeg.dep
+ copy /y makeddsp.vc6 djpeg.dsp
+ copy /y maketmak.vc6 jpegtran.mak
+ copy /y maketdep.vc6 jpegtran.dep
+ copy /y maketdsp.vc6 jpegtran.dsp
+ copy /y makermak.vc6 rdjpgcom.mak
+ copy /y makerdep.vc6 rdjpgcom.dep
+ copy /y makerdsp.vc6 rdjpgcom.dsp
+ copy /y makewmak.vc6 wrjpgcom.mak
+ copy /y makewdep.vc6 wrjpgcom.dep
+ copy /y makewdsp.vc6 wrjpgcom.dsp
+
+setup-v16:
ren jconfig.vc jconfig.h
- ren makejsln.v15 jpeg.sln
- ren makeasln.v15 apps.sln
- ren makejvcx.v15 jpeg.vcxproj
- ren makejfil.v15 jpeg.vcxproj.filters
- ren makecvcx.v15 cjpeg.vcxproj
- ren makecfil.v15 cjpeg.vcxproj.filters
- ren makedvcx.v15 djpeg.vcxproj
- ren makedfil.v15 djpeg.vcxproj.filters
- ren maketvcx.v15 jpegtran.vcxproj
- ren maketfil.v15 jpegtran.vcxproj.filters
- ren makervcx.v15 rdjpgcom.vcxproj
- ren makerfil.v15 rdjpgcom.vcxproj.filters
- ren makewvcx.v15 wrjpgcom.vcxproj
- ren makewfil.v15 wrjpgcom.vcxproj.filters
+ ren makejsln.v16 jpeg.sln
+ ren makeasln.v16 apps.sln
+ ren makejvcx.v16 jpeg.vcxproj
+ ren makejfil.v16 jpeg.vcxproj.filters
+ ren makecvcx.v16 cjpeg.vcxproj
+ ren makecfil.v16 cjpeg.vcxproj.filters
+ ren makedvcx.v16 djpeg.vcxproj
+ ren makedfil.v16 djpeg.vcxproj.filters
+ ren maketvcx.v16 jpegtran.vcxproj
+ ren maketfil.v16 jpegtran.vcxproj.filters
+ ren makervcx.v16 rdjpgcom.vcxproj
+ ren makerfil.v16 rdjpgcom.vcxproj.filters
+ ren makewvcx.v16 wrjpgcom.vcxproj
+ ren makewfil.v16 wrjpgcom.vcxproj.filters
+
+setupcopy-v16:
+ copy /y jconfig.vc jconfig.h
+ copy /y makejsln.v16 jpeg.sln
+ copy /y makeasln.v16 apps.sln
+ copy /y makejvcx.v16 jpeg.vcxproj
+ copy /y makejfil.v16 jpeg.vcxproj.filters
+ copy /y makecvcx.v16 cjpeg.vcxproj
+ copy /y makecfil.v16 cjpeg.vcxproj.filters
+ copy /y makedvcx.v16 djpeg.vcxproj
+ copy /y makedfil.v16 djpeg.vcxproj.filters
+ copy /y maketvcx.v16 jpegtran.vcxproj
+ copy /y maketfil.v16 jpegtran.vcxproj.filters
+ copy /y makervcx.v16 rdjpgcom.vcxproj
+ copy /y makerfil.v16 rdjpgcom.vcxproj.filters
+ copy /y makewvcx.v16 wrjpgcom.vcxproj
+ copy /y makewfil.v16 wrjpgcom.vcxproj.filters
test:
IF EXIST testout* $(RM) testout*
- .\djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
- .\djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
- .\cjpeg -dct int -outfile testout.jpg testimg.ppm
+ .\djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
+ .\djpeg -dct int -gif -outfile testout.gif testorig.jpg
+ .\djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
+ .\cjpeg -dct int -outfile testout.jpg testimg.ppm
.\djpeg -dct int -ppm -outfile testoutp.ppm testprog.jpg
.\cjpeg -dct int -progressive -opt -outfile testoutp.jpg testimg.ppm
.\jpegtran -outfile testoutt.jpg testprog.jpg
fc /b testimg.ppm testout.ppm
+ fc /b testimg.gif testout.gif
fc /b testimg.bmp testout.bmp
fc /b testimg.jpg testout.jpg
fc /b testimg.ppm testoutp.ppm
@@ -187,19 +229,55 @@ test:
fc /b testorig.jpg testoutt.jpg
test-build:
- IF EXIST testout* $(RM) testout*
- .\djpeg\Release\djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
- .\djpeg\Release\djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
- .\cjpeg\Release\cjpeg -dct int -outfile testout.jpg testimg.ppm
- .\djpeg\Release\djpeg -dct int -ppm -outfile testoutp.ppm testprog.jpg
- .\cjpeg\Release\cjpeg -dct int -progressive -opt -outfile testoutp.jpg testimg.ppm
- .\jpegtran\Release\jpegtran -outfile testoutt.jpg testprog.jpg
- fc /b testimg.ppm testout.ppm
- fc /b testimg.bmp testout.bmp
- fc /b testimg.jpg testout.jpg
- fc /b testimg.ppm testoutp.ppm
- fc /b testimgp.jpg testoutp.jpg
- fc /b testorig.jpg testoutt.jpg
+ IF EXIST .\Release\testout* $(RM) .\Release\testout*
+ .\Release\djpeg -dct int -ppm -outfile .\Release\testout.ppm testorig.jpg
+ .\Release\djpeg -dct int -gif -outfile .\Release\testout.gif testorig.jpg
+ .\Release\djpeg -dct int -bmp -colors 256 -outfile .\Release\testout.bmp testorig.jpg
+ .\Release\cjpeg -dct int -outfile .\Release\testout.jpg testimg.ppm
+ .\Release\djpeg -dct int -ppm -outfile .\Release\testoutp.ppm testprog.jpg
+ .\Release\cjpeg -dct int -progressive -opt -outfile .\Release\testoutp.jpg testimg.ppm
+ .\Release\jpegtran -outfile .\Release\testoutt.jpg testprog.jpg
+ fc /b testimg.ppm .\Release\testout.ppm
+ fc /b testimg.gif .\Release\testout.gif
+ fc /b testimg.bmp .\Release\testout.bmp
+ fc /b testimg.jpg .\Release\testout.jpg
+ fc /b testimg.ppm .\Release\testoutp.ppm
+ fc /b testimgp.jpg .\Release\testoutp.jpg
+ fc /b testorig.jpg .\Release\testoutt.jpg
+
+test-32:
+ IF EXIST .\Release\testout* $(RM) .\Release\testout*
+ .\Release\Win32\djpeg -dct int -ppm -outfile .\Release\testout.ppm testorig.jpg
+ .\Release\Win32\djpeg -dct int -gif -outfile .\Release\testout.gif testorig.jpg
+ .\Release\Win32\djpeg -dct int -bmp -colors 256 -outfile .\Release\testout.bmp testorig.jpg
+ .\Release\Win32\cjpeg -dct int -outfile .\Release\testout.jpg testimg.ppm
+ .\Release\Win32\djpeg -dct int -ppm -outfile .\Release\testoutp.ppm testprog.jpg
+ .\Release\Win32\cjpeg -dct int -progressive -opt -outfile .\Release\testoutp.jpg testimg.ppm
+ .\Release\Win32\jpegtran -outfile .\Release\testoutt.jpg testprog.jpg
+ fc /b testimg.ppm .\Release\testout.ppm
+ fc /b testimg.gif .\Release\testout.gif
+ fc /b testimg.bmp .\Release\testout.bmp
+ fc /b testimg.jpg .\Release\testout.jpg
+ fc /b testimg.ppm .\Release\testoutp.ppm
+ fc /b testimgp.jpg .\Release\testoutp.jpg
+ fc /b testorig.jpg .\Release\testoutt.jpg
+
+test-64:
+ IF EXIST .\Release\testout* $(RM) .\Release\testout*
+ .\Release\x64\djpeg -dct int -ppm -outfile .\Release\testout.ppm testorig.jpg
+ .\Release\x64\djpeg -dct int -gif -outfile .\Release\testout.gif testorig.jpg
+ .\Release\x64\djpeg -dct int -bmp -colors 256 -outfile .\Release\testout.bmp testorig.jpg
+ .\Release\x64\cjpeg -dct int -outfile .\Release\testout.jpg testimg.ppm
+ .\Release\x64\djpeg -dct int -ppm -outfile .\Release\testoutp.ppm testprog.jpg
+ .\Release\x64\cjpeg -dct int -progressive -opt -outfile .\Release\testoutp.jpg testimg.ppm
+ .\Release\x64\jpegtran -outfile .\Release\testoutt.jpg testprog.jpg
+ fc /b testimg.ppm .\Release\testout.ppm
+ fc /b testimg.gif .\Release\testout.gif
+ fc /b testimg.bmp .\Release\testout.bmp
+ fc /b testimg.jpg .\Release\testout.jpg
+ fc /b testimg.ppm .\Release\testoutp.ppm
+ fc /b testimgp.jpg .\Release\testoutp.jpg
+ fc /b testorig.jpg .\Release\testoutt.jpg
jaricom.obj: jaricom.c jinclude.h jconfig.h jpeglib.h jmorecfg.h jpegint.h jerror.h
diff --git a/jpeg/makefile.vs b/jpeg/makefile.vs
index 4fdead5f..bb10fcb6 100644
--- a/jpeg/makefile.vs
+++ b/jpeg/makefile.vs
@@ -63,9 +63,9 @@ MKFILES= configure Makefile.in makefile.ansi makefile.unix makefile.b32 \
makejmak.vc6 makecdep.vc6 makecdsp.vc6 makecmak.vc6 makeddep.vc6 \
makeddsp.vc6 makedmak.vc6 maketdep.vc6 maketdsp.vc6 maketmak.vc6 \
makerdep.vc6 makerdsp.vc6 makermak.vc6 makewdep.vc6 makewdsp.vc6 \
- makewmak.vc6 makejsln.v15 makeasln.v15 makejvcx.v15 makejfil.v15 \
- makecvcx.v15 makecfil.v15 makedvcx.v15 makedfil.v15 maketvcx.v15 \
- maketfil.v15 makervcx.v15 makerfil.v15 makewvcx.v15 makewfil.v15 \
+ makewmak.vc6 makejsln.v16 makeasln.v16 makejvcx.v16 makejfil.v16 \
+ makecvcx.v16 makecfil.v16 makedvcx.v16 makedfil.v16 maketvcx.v16 \
+ maketfil.v16 makervcx.v16 makerfil.v16 makewvcx.v16 makewfil.v16 \
makeproj.mac makcjpeg.st makdjpeg.st makljpeg.st maktjpeg.st \
makefile.manx makefile.sas makefile.mms makefile.vms makvms.opt
CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
@@ -74,8 +74,8 @@ CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat \
CONFIGUREFILES= config.guess config.sub install-sh ltmain.sh depcomp \
missing ar-lib
OTHERFILES= jconfig.txt ckconfig.c jmemdosa.asm libjpeg.map libjpeg.pc.in
-TESTFILES= testorig.jpg testimg.ppm testimg.bmp testimg.jpg testprog.jpg \
- testimgp.jpg
+TESTFILES= testorig.jpg testimg.ppm testimg.gif testimg.bmp testimg.jpg \
+ testprog.jpg testimgp.jpg
DISTFILES= $(DOCS) $(MKFILES) $(CONFIGFILES) $(SOURCES) $(INCLUDES) \
$(CONFIGUREFILES) $(OTHERFILES) $(TESTFILES)
# library object files common to compression and decompression
@@ -154,32 +154,74 @@ setup-vc6:
ren makewdep.vc6 wrjpgcom.dep
ren makewdsp.vc6 wrjpgcom.dsp
-setup-v15:
+setupcopy-vc6:
+ copy /y jconfig.vc jconfig.h
+ copy /y makejdsw.vc6 jpeg.dsw
+ copy /y makeadsw.vc6 apps.dsw
+ copy /y makejmak.vc6 jpeg.mak
+ copy /y makejdep.vc6 jpeg.dep
+ copy /y makejdsp.vc6 jpeg.dsp
+ copy /y makecmak.vc6 cjpeg.mak
+ copy /y makecdep.vc6 cjpeg.dep
+ copy /y makecdsp.vc6 cjpeg.dsp
+ copy /y makedmak.vc6 djpeg.mak
+ copy /y makeddep.vc6 djpeg.dep
+ copy /y makeddsp.vc6 djpeg.dsp
+ copy /y maketmak.vc6 jpegtran.mak
+ copy /y maketdep.vc6 jpegtran.dep
+ copy /y maketdsp.vc6 jpegtran.dsp
+ copy /y makermak.vc6 rdjpgcom.mak
+ copy /y makerdep.vc6 rdjpgcom.dep
+ copy /y makerdsp.vc6 rdjpgcom.dsp
+ copy /y makewmak.vc6 wrjpgcom.mak
+ copy /y makewdep.vc6 wrjpgcom.dep
+ copy /y makewdsp.vc6 wrjpgcom.dsp
+
+setup-v16:
ren jconfig.vc jconfig.h
- ren makejsln.v15 jpeg.sln
- ren makeasln.v15 apps.sln
- ren makejvcx.v15 jpeg.vcxproj
- ren makejfil.v15 jpeg.vcxproj.filters
- ren makecvcx.v15 cjpeg.vcxproj
- ren makecfil.v15 cjpeg.vcxproj.filters
- ren makedvcx.v15 djpeg.vcxproj
- ren makedfil.v15 djpeg.vcxproj.filters
- ren maketvcx.v15 jpegtran.vcxproj
- ren maketfil.v15 jpegtran.vcxproj.filters
- ren makervcx.v15 rdjpgcom.vcxproj
- ren makerfil.v15 rdjpgcom.vcxproj.filters
- ren makewvcx.v15 wrjpgcom.vcxproj
- ren makewfil.v15 wrjpgcom.vcxproj.filters
+ ren makejsln.v16 jpeg.sln
+ ren makeasln.v16 apps.sln
+ ren makejvcx.v16 jpeg.vcxproj
+ ren makejfil.v16 jpeg.vcxproj.filters
+ ren makecvcx.v16 cjpeg.vcxproj
+ ren makecfil.v16 cjpeg.vcxproj.filters
+ ren makedvcx.v16 djpeg.vcxproj
+ ren makedfil.v16 djpeg.vcxproj.filters
+ ren maketvcx.v16 jpegtran.vcxproj
+ ren maketfil.v16 jpegtran.vcxproj.filters
+ ren makervcx.v16 rdjpgcom.vcxproj
+ ren makerfil.v16 rdjpgcom.vcxproj.filters
+ ren makewvcx.v16 wrjpgcom.vcxproj
+ ren makewfil.v16 wrjpgcom.vcxproj.filters
+
+setupcopy-v16:
+ copy /y jconfig.vc jconfig.h
+ copy /y makejsln.v16 jpeg.sln
+ copy /y makeasln.v16 apps.sln
+ copy /y makejvcx.v16 jpeg.vcxproj
+ copy /y makejfil.v16 jpeg.vcxproj.filters
+ copy /y makecvcx.v16 cjpeg.vcxproj
+ copy /y makecfil.v16 cjpeg.vcxproj.filters
+ copy /y makedvcx.v16 djpeg.vcxproj
+ copy /y makedfil.v16 djpeg.vcxproj.filters
+ copy /y maketvcx.v16 jpegtran.vcxproj
+ copy /y maketfil.v16 jpegtran.vcxproj.filters
+ copy /y makervcx.v16 rdjpgcom.vcxproj
+ copy /y makerfil.v16 rdjpgcom.vcxproj.filters
+ copy /y makewvcx.v16 wrjpgcom.vcxproj
+ copy /y makewfil.v16 wrjpgcom.vcxproj.filters
test:
IF EXIST testout* $(RM) testout*
- .\djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
- .\djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
- .\cjpeg -dct int -outfile testout.jpg testimg.ppm
+ .\djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
+ .\djpeg -dct int -gif -outfile testout.gif testorig.jpg
+ .\djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
+ .\cjpeg -dct int -outfile testout.jpg testimg.ppm
.\djpeg -dct int -ppm -outfile testoutp.ppm testprog.jpg
.\cjpeg -dct int -progressive -opt -outfile testoutp.jpg testimg.ppm
.\jpegtran -outfile testoutt.jpg testprog.jpg
fc /b testimg.ppm testout.ppm
+ fc /b testimg.gif testout.gif
fc /b testimg.bmp testout.bmp
fc /b testimg.jpg testout.jpg
fc /b testimg.ppm testoutp.ppm
@@ -187,19 +229,55 @@ test:
fc /b testorig.jpg testoutt.jpg
test-build:
- IF EXIST testout* $(RM) testout*
- .\djpeg\Release\djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
- .\djpeg\Release\djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
- .\cjpeg\Release\cjpeg -dct int -outfile testout.jpg testimg.ppm
- .\djpeg\Release\djpeg -dct int -ppm -outfile testoutp.ppm testprog.jpg
- .\cjpeg\Release\cjpeg -dct int -progressive -opt -outfile testoutp.jpg testimg.ppm
- .\jpegtran\Release\jpegtran -outfile testoutt.jpg testprog.jpg
- fc /b testimg.ppm testout.ppm
- fc /b testimg.bmp testout.bmp
- fc /b testimg.jpg testout.jpg
- fc /b testimg.ppm testoutp.ppm
- fc /b testimgp.jpg testoutp.jpg
- fc /b testorig.jpg testoutt.jpg
+ IF EXIST .\Release\testout* $(RM) .\Release\testout*
+ .\Release\djpeg -dct int -ppm -outfile .\Release\testout.ppm testorig.jpg
+ .\Release\djpeg -dct int -gif -outfile .\Release\testout.gif testorig.jpg
+ .\Release\djpeg -dct int -bmp -colors 256 -outfile .\Release\testout.bmp testorig.jpg
+ .\Release\cjpeg -dct int -outfile .\Release\testout.jpg testimg.ppm
+ .\Release\djpeg -dct int -ppm -outfile .\Release\testoutp.ppm testprog.jpg
+ .\Release\cjpeg -dct int -progressive -opt -outfile .\Release\testoutp.jpg testimg.ppm
+ .\Release\jpegtran -outfile .\Release\testoutt.jpg testprog.jpg
+ fc /b testimg.ppm .\Release\testout.ppm
+ fc /b testimg.gif .\Release\testout.gif
+ fc /b testimg.bmp .\Release\testout.bmp
+ fc /b testimg.jpg .\Release\testout.jpg
+ fc /b testimg.ppm .\Release\testoutp.ppm
+ fc /b testimgp.jpg .\Release\testoutp.jpg
+ fc /b testorig.jpg .\Release\testoutt.jpg
+
+test-32:
+ IF EXIST .\Release\testout* $(RM) .\Release\testout*
+ .\Release\Win32\djpeg -dct int -ppm -outfile .\Release\testout.ppm testorig.jpg
+ .\Release\Win32\djpeg -dct int -gif -outfile .\Release\testout.gif testorig.jpg
+ .\Release\Win32\djpeg -dct int -bmp -colors 256 -outfile .\Release\testout.bmp testorig.jpg
+ .\Release\Win32\cjpeg -dct int -outfile .\Release\testout.jpg testimg.ppm
+ .\Release\Win32\djpeg -dct int -ppm -outfile .\Release\testoutp.ppm testprog.jpg
+ .\Release\Win32\cjpeg -dct int -progressive -opt -outfile .\Release\testoutp.jpg testimg.ppm
+ .\Release\Win32\jpegtran -outfile .\Release\testoutt.jpg testprog.jpg
+ fc /b testimg.ppm .\Release\testout.ppm
+ fc /b testimg.gif .\Release\testout.gif
+ fc /b testimg.bmp .\Release\testout.bmp
+ fc /b testimg.jpg .\Release\testout.jpg
+ fc /b testimg.ppm .\Release\testoutp.ppm
+ fc /b testimgp.jpg .\Release\testoutp.jpg
+ fc /b testorig.jpg .\Release\testoutt.jpg
+
+test-64:
+ IF EXIST .\Release\testout* $(RM) .\Release\testout*
+ .\Release\x64\djpeg -dct int -ppm -outfile .\Release\testout.ppm testorig.jpg
+ .\Release\x64\djpeg -dct int -gif -outfile .\Release\testout.gif testorig.jpg
+ .\Release\x64\djpeg -dct int -bmp -colors 256 -outfile .\Release\testout.bmp testorig.jpg
+ .\Release\x64\cjpeg -dct int -outfile .\Release\testout.jpg testimg.ppm
+ .\Release\x64\djpeg -dct int -ppm -outfile .\Release\testoutp.ppm testprog.jpg
+ .\Release\x64\cjpeg -dct int -progressive -opt -outfile .\Release\testoutp.jpg testimg.ppm
+ .\Release\x64\jpegtran -outfile .\Release\testoutt.jpg testprog.jpg
+ fc /b testimg.ppm .\Release\testout.ppm
+ fc /b testimg.gif .\Release\testout.gif
+ fc /b testimg.bmp .\Release\testout.bmp
+ fc /b testimg.jpg .\Release\testout.jpg
+ fc /b testimg.ppm .\Release\testoutp.ppm
+ fc /b testimgp.jpg .\Release\testoutp.jpg
+ fc /b testorig.jpg .\Release\testoutt.jpg
jaricom.obj: jaricom.c jinclude.h jconfig.h jpeglib.h jmorecfg.h jpegint.h jerror.h
diff --git a/jpeg/makefile.wat b/jpeg/makefile.wat
index 0dfc9780..56b2f0dd 100644
--- a/jpeg/makefile.wat
+++ b/jpeg/makefile.wat
@@ -65,9 +65,9 @@ MKFILES= configure Makefile.in makefile.ansi makefile.unix makefile.b32 &
makejmak.vc6 makecdep.vc6 makecdsp.vc6 makecmak.vc6 makeddep.vc6 &
makeddsp.vc6 makedmak.vc6 maketdep.vc6 maketdsp.vc6 maketmak.vc6 &
makerdep.vc6 makerdsp.vc6 makermak.vc6 makewdep.vc6 makewdsp.vc6 &
- makewmak.vc6 makejsln.v15 makeasln.v15 makejvcx.v15 makejfil.v15 &
- makecvcx.v15 makecfil.v15 makedvcx.v15 makedfil.v15 maketvcx.v15 &
- maketfil.v15 makervcx.v15 makerfil.v15 makewvcx.v15 makewfil.v15 &
+ makewmak.vc6 makejsln.v16 makeasln.v16 makejvcx.v16 makejfil.v16 &
+ makecvcx.v16 makecfil.v16 makedvcx.v16 makedfil.v16 maketvcx.v16 &
+ maketfil.v16 makervcx.v16 makerfil.v16 makewvcx.v16 makewfil.v16 &
makeproj.mac makcjpeg.st makdjpeg.st makljpeg.st maktjpeg.st &
makefile.manx makefile.sas makefile.mms makefile.vms makvms.opt
CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat &
@@ -76,8 +76,8 @@ CONFIGFILES= jconfig.cfg jconfig.bcc jconfig.mc6 jconfig.dj jconfig.wat &
CONFIGUREFILES= config.guess config.sub install-sh ltmain.sh depcomp &
missing ar-lib
OTHERFILES= jconfig.txt ckconfig.c jmemdosa.asm libjpeg.map libjpeg.pc.in
-TESTFILES= testorig.jpg testimg.ppm testimg.bmp testimg.jpg testprog.jpg &
- testimgp.jpg
+TESTFILES= testorig.jpg testimg.ppm testimg.gif testimg.bmp testimg.jpg &
+ testprog.jpg testimgp.jpg
DISTFILES= $(DOCS) $(MKFILES) $(CONFIGFILES) $(SOURCES) $(INCLUDES) &
$(CONFIGUREFILES) $(OTHERFILES) $(TESTFILES)
# library object files common to compression and decompression
@@ -144,14 +144,16 @@ clean: .SYMBOLIC
test: cjpeg.exe djpeg.exe jpegtran.exe .SYMBOLIC
- del testout*.*
- djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
- djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
- cjpeg -dct int -outfile testout.jpg testimg.ppm
+ djpeg -dct int -ppm -outfile testout.ppm testorig.jpg
+ djpeg -dct int -gif -outfile testout.gif testorig.jpg
+ djpeg -dct int -bmp -colors 256 -outfile testout.bmp testorig.jpg
+ cjpeg -dct int -outfile testout.jpg testimg.ppm
djpeg -dct int -ppm -outfile testoutp.ppm testprog.jpg
cjpeg -dct int -progressive -opt -outfile testoutp.jpg testimg.ppm
jpegtran -outfile testoutt.jpg testprog.jpg
!ifeq SYSTEM DOS
fc /b testimg.ppm testout.ppm
+ fc /b testimg.gif testout.gif
fc /b testimg.bmp testout.bmp
fc /b testimg.jpg testout.jpg
fc /b testimg.ppm testoutp.ppm
@@ -160,6 +162,7 @@ test: cjpeg.exe djpeg.exe jpegtran.exe .SYMBOLIC
!else
echo n > n.tmp
comp testimg.ppm testout.ppm < n.tmp
+ comp testimg.gif testout.gif < n.tmp
comp testimg.bmp testout.bmp < n.tmp
comp testimg.jpg testout.jpg < n.tmp
comp testimg.ppm testoutp.ppm < n.tmp
diff --git a/jpeg/makejdsp.vc6 b/jpeg/makejdsp.vc6
index 738f1ab4..8cd27bd6 100644
--- a/jpeg/makejdsp.vc6
+++ b/jpeg/makejdsp.vc6
@@ -34,7 +34,7 @@ RSC=rc.exe
# PROP Use_MFC 0
# PROP Use_Debug_Libraries 0
# PROP Output_Dir ".\Release"
-# PROP Intermediate_Dir ".\Release"
+# PROP Intermediate_Dir ".\Release\jpeg"
# PROP Target_Dir ""
# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /YX /c
# ADD CPP /nologo /G6 /MT /W3 /GX /Ox /Oa /Ob2 /D "WIN32" /D "NDEBUG" /D "_WINDOWS" /YX /FD /c
diff --git a/jpeg/makejfil.v15 b/jpeg/makejfil.v16
index 654bfc09..4cd1d071 100644
--- a/jpeg/makejfil.v15
+++ b/jpeg/makejfil.v16
@@ -1,4 +1,4 @@
-<?xml version="1.0" encoding="utf-8"?>
+<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<Filter Include="Source Files">
diff --git a/jpeg/makejsln.v15 b/jpeg/makejsln.v16
index 6a5befdf..11ef80f8 100644
--- a/jpeg/makejsln.v15
+++ b/jpeg/makejsln.v16
@@ -1,17 +1,25 @@
-
-Microsoft Visual Studio Solution File, Format Version 11.00
-# Visual C++ Express 2010
+
+Microsoft Visual Studio Solution File, Format Version 12.00
+# Visual Studio 15
+VisualStudioVersion = 15.0.28307.329
+MinimumVisualStudioVersion = 10.0.40219.1
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "jpeg", "jpeg.vcxproj", "{019DBD2A-273D-4BA4-BF86-B5EFE2ED76B1}"
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
Release|Win32 = Release|Win32
+ Release|x64 = Release|x64
EndGlobalSection
GlobalSection(ProjectConfigurationPlatforms) = postSolution
{019DBD2A-273D-4BA4-BF86-B5EFE2ED76B1}.Release|Win32.ActiveCfg = Release|Win32
{019DBD2A-273D-4BA4-BF86-B5EFE2ED76B1}.Release|Win32.Build.0 = Release|Win32
+ {019DBD2A-273D-4BA4-BF86-B5EFE2ED76B1}.Release|x64.ActiveCfg = Release|x64
+ {019DBD2A-273D-4BA4-BF86-B5EFE2ED76B1}.Release|x64.Build.0 = Release|x64
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
EndGlobalSection
+ GlobalSection(ExtensibilityGlobals) = postSolution
+ SolutionGuid = {F3829CB8-BF87-4A30-B5D3-E3ADB548485D}
+ EndGlobalSection
EndGlobal
diff --git a/jpeg/makejvcx.v15 b/jpeg/makejvcx.v16
index 31579e28..20ad5f7a 100644
--- a/jpeg/makejvcx.v15
+++ b/jpeg/makejvcx.v16
@@ -1,10 +1,14 @@
-<?xml version="1.0" encoding="utf-8"?>
+<?xml version="1.0" encoding="utf-8"?>
<Project DefaultTargets="Build" ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup Label="ProjectConfigurations">
<ProjectConfiguration Include="Release|Win32">
<Configuration>Release</Configuration>
<Platform>Win32</Platform>
</ProjectConfiguration>
+ <ProjectConfiguration Include="Release|x64">
+ <Configuration>Release</Configuration>
+ <Platform>x64</Platform>
+ </ProjectConfiguration>
</ItemGroup>
<ItemGroup>
<ClInclude Include="jconfig.h" />
@@ -69,7 +73,7 @@
<ProjectGuid>{019DBD2A-273D-4BA4-BF86-B5EFE2ED76B1}</ProjectGuid>
<Keyword>Win32Proj</Keyword>
<RootNamespace>jpeg</RootNamespace>
- <WindowsTargetPlatformVersion>10.0.16299.0</WindowsTargetPlatformVersion>
+ <WindowsTargetPlatformVersion>10.0</WindowsTargetPlatformVersion>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">
@@ -77,7 +81,14 @@
<UseDebugLibraries>false</UseDebugLibraries>
<WholeProgramOptimization>true</WholeProgramOptimization>
<CharacterSet>Unicode</CharacterSet>
- <PlatformToolset>v141</PlatformToolset>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
+ <ConfigurationType>StaticLibrary</ConfigurationType>
+ <UseDebugLibraries>false</UseDebugLibraries>
+ <WholeProgramOptimization>true</WholeProgramOptimization>
+ <CharacterSet>Unicode</CharacterSet>
+ <PlatformToolset>v142</PlatformToolset>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
<ImportGroup Label="ExtensionSettings">
@@ -85,8 +96,18 @@
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
</ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
<PropertyGroup Label="UserMacros" />
- <PropertyGroup />
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
+ <OutDir>$(SolutionDir)$(Configuration)\$(Platform)\</OutDir>
+ <IntDir>$(Configuration)\$(Platform)\$(ProjectName)\</IntDir>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+ <OutDir>$(SolutionDir)$(Configuration)\$(Platform)\</OutDir>
+ <IntDir>$(Configuration)\$(Platform)\$(ProjectName)\</IntDir>
+ </PropertyGroup>
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<ClCompile>
<WarningLevel>Level3</WarningLevel>
@@ -105,6 +126,24 @@
<OptimizeReferences>true</OptimizeReferences>
</Link>
</ItemDefinitionGroup>
+ <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+ <ClCompile>
+ <WarningLevel>Level3</WarningLevel>
+ <PrecompiledHeader>NotUsing</PrecompiledHeader>
+ <Optimization>Full</Optimization>
+ <FunctionLevelLinking>true</FunctionLevelLinking>
+ <IntrinsicFunctions>false</IntrinsicFunctions>
+ <PreprocessorDefinitions>NDEBUG;_LIB;_CRT_SECURE_NO_WARNINGS</PreprocessorDefinitions>
+ <OmitFramePointers>true</OmitFramePointers>
+ <EnableFiberSafeOptimizations>true</EnableFiberSafeOptimizations>
+ </ClCompile>
+ <Link>
+ <SubSystem>Windows</SubSystem>
+ <GenerateDebugInformation>true</GenerateDebugInformation>
+ <EnableCOMDATFolding>true</EnableCOMDATFolding>
+ <OptimizeReferences>true</OptimizeReferences>
+ </Link>
+ </ItemDefinitionGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
<ImportGroup Label="ExtensionTargets">
</ImportGroup>
diff --git a/jpeg/makerdsp.vc6 b/jpeg/makerdsp.vc6
index 60de09af..8eaf4467 100644
--- a/jpeg/makerdsp.vc6
+++ b/jpeg/makerdsp.vc6
@@ -33,8 +33,8 @@ RSC=rc.exe
# PROP BASE Target_Dir ".\rdjpgcom"
# PROP Use_MFC 0
# PROP Use_Debug_Libraries 0
-# PROP Output_Dir ".\rdjpgcom\Release"
-# PROP Intermediate_Dir ".\rdjpgcom\Release"
+# PROP Output_Dir ".\Release"
+# PROP Intermediate_Dir ".\Release\rdjpgcom"
# PROP Ignore_Export_Lib 0
# PROP Target_Dir ".\rdjpgcom"
# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_CONSOLE" /YX /c
diff --git a/jpeg/makerfil.v15 b/jpeg/makerfil.v16
index d14914af..be828f53 100644
--- a/jpeg/makerfil.v15
+++ b/jpeg/makerfil.v16
@@ -1,4 +1,4 @@
-<?xml version="1.0" encoding="utf-8"?>
+<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<Filter Include="Source Files">
diff --git a/jpeg/makervcx.v15 b/jpeg/makervcx.v16
index 76bb6de0..e53020ae 100644
--- a/jpeg/makervcx.v15
+++ b/jpeg/makervcx.v16
@@ -1,16 +1,20 @@
-<?xml version="1.0" encoding="utf-8"?>
+<?xml version="1.0" encoding="utf-8"?>
<Project DefaultTargets="Build" ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup Label="ProjectConfigurations">
<ProjectConfiguration Include="Release|Win32">
<Configuration>Release</Configuration>
<Platform>Win32</Platform>
</ProjectConfiguration>
+ <ProjectConfiguration Include="Release|x64">
+ <Configuration>Release</Configuration>
+ <Platform>x64</Platform>
+ </ProjectConfiguration>
</ItemGroup>
<PropertyGroup Label="Globals">
<ProjectGuid>{C81513DB-78DC-46BC-BC98-82E745203976}</ProjectGuid>
<Keyword>Win32Proj</Keyword>
<RootNamespace>rdjpgcom</RootNamespace>
- <WindowsTargetPlatformVersion>10.0.16299.0</WindowsTargetPlatformVersion>
+ <WindowsTargetPlatformVersion>10.0</WindowsTargetPlatformVersion>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">
@@ -18,7 +22,14 @@
<UseDebugLibraries>false</UseDebugLibraries>
<WholeProgramOptimization>true</WholeProgramOptimization>
<CharacterSet>Unicode</CharacterSet>
- <PlatformToolset>v141</PlatformToolset>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
+ <ConfigurationType>Application</ConfigurationType>
+ <UseDebugLibraries>false</UseDebugLibraries>
+ <WholeProgramOptimization>true</WholeProgramOptimization>
+ <CharacterSet>Unicode</CharacterSet>
+ <PlatformToolset>v142</PlatformToolset>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
<ImportGroup Label="ExtensionSettings">
@@ -26,11 +37,19 @@
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
</ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
<PropertyGroup Label="UserMacros" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<LinkIncremental>false</LinkIncremental>
- <OutDir>$(ProjectName)\$(Configuration)\</OutDir>
- <IntDir>$(ProjectName)\$(Configuration)\</IntDir>
+ <OutDir>$(Configuration)\$(Platform)\</OutDir>
+ <IntDir>$(Configuration)\$(Platform)\$(ProjectName)\</IntDir>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+ <LinkIncremental>false</LinkIncremental>
+ <OutDir>$(Configuration)\$(Platform)\</OutDir>
+ <IntDir>$(Configuration)\$(Platform)\$(ProjectName)\</IntDir>
</PropertyGroup>
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<ClCompile>
@@ -51,6 +70,25 @@
<OptimizeReferences>true</OptimizeReferences>
</Link>
</ItemDefinitionGroup>
+ <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+ <ClCompile>
+ <WarningLevel>Level3</WarningLevel>
+ <PrecompiledHeader>NotUsing</PrecompiledHeader>
+ <Optimization>Full</Optimization>
+ <FunctionLevelLinking>true</FunctionLevelLinking>
+ <IntrinsicFunctions>false</IntrinsicFunctions>
+ <PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;_CRT_SECURE_NO_WARNINGS</PreprocessorDefinitions>
+ <OmitFramePointers>true</OmitFramePointers>
+ <EnableFiberSafeOptimizations>true</EnableFiberSafeOptimizations>
+ <DisableSpecificWarnings>4996</DisableSpecificWarnings>
+ </ClCompile>
+ <Link>
+ <SubSystem>Console</SubSystem>
+ <GenerateDebugInformation>true</GenerateDebugInformation>
+ <EnableCOMDATFolding>true</EnableCOMDATFolding>
+ <OptimizeReferences>true</OptimizeReferences>
+ </Link>
+ </ItemDefinitionGroup>
<ItemGroup>
<ClInclude Include="jconfig.h" />
<ClInclude Include="jinclude.h" />
diff --git a/jpeg/maketdsp.vc6 b/jpeg/maketdsp.vc6
index fe1ae9a3..00df01af 100644
--- a/jpeg/maketdsp.vc6
+++ b/jpeg/maketdsp.vc6
@@ -33,8 +33,8 @@ RSC=rc.exe
# PROP BASE Target_Dir ".\jpegtran"
# PROP Use_MFC 0
# PROP Use_Debug_Libraries 0
-# PROP Output_Dir ".\jpegtran\Release"
-# PROP Intermediate_Dir ".\jpegtran\Release"
+# PROP Output_Dir ".\Release"
+# PROP Intermediate_Dir ".\Release\jpegtran"
# PROP Ignore_Export_Lib 0
# PROP Target_Dir ".\jpegtran"
# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_CONSOLE" /YX /c
diff --git a/jpeg/maketfil.v15 b/jpeg/maketfil.v16
index fae00941..4fcb2105 100644
--- a/jpeg/maketfil.v15
+++ b/jpeg/maketfil.v16
@@ -1,4 +1,4 @@
-<?xml version="1.0" encoding="utf-8"?>
+<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<Filter Include="Source Files">
diff --git a/jpeg/maketvcx.v15 b/jpeg/maketvcx.v16
index 2cf5eed3..1ce73bb3 100644
--- a/jpeg/maketvcx.v15
+++ b/jpeg/maketvcx.v16
@@ -1,16 +1,20 @@
-<?xml version="1.0" encoding="utf-8"?>
+<?xml version="1.0" encoding="utf-8"?>
<Project DefaultTargets="Build" ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup Label="ProjectConfigurations">
<ProjectConfiguration Include="Release|Win32">
<Configuration>Release</Configuration>
<Platform>Win32</Platform>
</ProjectConfiguration>
+ <ProjectConfiguration Include="Release|x64">
+ <Configuration>Release</Configuration>
+ <Platform>x64</Platform>
+ </ProjectConfiguration>
</ItemGroup>
<PropertyGroup Label="Globals">
<ProjectGuid>{025BAC50-51B5-4FFE-BC47-3F920BB4047E}</ProjectGuid>
<Keyword>Win32Proj</Keyword>
<RootNamespace>jpegtran</RootNamespace>
- <WindowsTargetPlatformVersion>10.0.16299.0</WindowsTargetPlatformVersion>
+ <WindowsTargetPlatformVersion>10.0</WindowsTargetPlatformVersion>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">
@@ -18,7 +22,14 @@
<UseDebugLibraries>false</UseDebugLibraries>
<WholeProgramOptimization>true</WholeProgramOptimization>
<CharacterSet>Unicode</CharacterSet>
- <PlatformToolset>v141</PlatformToolset>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
+ <ConfigurationType>Application</ConfigurationType>
+ <UseDebugLibraries>false</UseDebugLibraries>
+ <WholeProgramOptimization>true</WholeProgramOptimization>
+ <CharacterSet>Unicode</CharacterSet>
+ <PlatformToolset>v142</PlatformToolset>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
<ImportGroup Label="ExtensionSettings">
@@ -26,11 +37,19 @@
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
</ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
<PropertyGroup Label="UserMacros" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<LinkIncremental>false</LinkIncremental>
- <OutDir>$(ProjectName)\$(Configuration)\</OutDir>
- <IntDir>$(ProjectName)\$(Configuration)\</IntDir>
+ <OutDir>$(Configuration)\$(Platform)\</OutDir>
+ <IntDir>$(Configuration)\$(Platform)\$(ProjectName)\</IntDir>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+ <LinkIncremental>false</LinkIncremental>
+ <OutDir>$(Configuration)\$(Platform)\</OutDir>
+ <IntDir>$(Configuration)\$(Platform)\$(ProjectName)\</IntDir>
</PropertyGroup>
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<ClCompile>
@@ -49,7 +68,27 @@
<GenerateDebugInformation>true</GenerateDebugInformation>
<EnableCOMDATFolding>true</EnableCOMDATFolding>
<OptimizeReferences>true</OptimizeReferences>
- <AdditionalDependencies>Release\jpeg.lib;kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies)</AdditionalDependencies>
+ <AdditionalDependencies>$(Configuration)\$(Platform)\jpeg.lib;kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies)</AdditionalDependencies>
+ </Link>
+ </ItemDefinitionGroup>
+ <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+ <ClCompile>
+ <WarningLevel>Level3</WarningLevel>
+ <PrecompiledHeader>NotUsing</PrecompiledHeader>
+ <Optimization>Full</Optimization>
+ <FunctionLevelLinking>true</FunctionLevelLinking>
+ <IntrinsicFunctions>false</IntrinsicFunctions>
+ <PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;_CRT_SECURE_NO_WARNINGS</PreprocessorDefinitions>
+ <OmitFramePointers>true</OmitFramePointers>
+ <EnableFiberSafeOptimizations>true</EnableFiberSafeOptimizations>
+ <DisableSpecificWarnings>4996</DisableSpecificWarnings>
+ </ClCompile>
+ <Link>
+ <SubSystem>Console</SubSystem>
+ <GenerateDebugInformation>true</GenerateDebugInformation>
+ <EnableCOMDATFolding>true</EnableCOMDATFolding>
+ <OptimizeReferences>true</OptimizeReferences>
+ <AdditionalDependencies>$(Configuration)\$(Platform)\jpeg.lib;kernel32.lib;user32.lib;gdi32.lib;winspool.lib;comdlg32.lib;advapi32.lib;shell32.lib;ole32.lib;oleaut32.lib;uuid.lib;odbc32.lib;odbccp32.lib;%(AdditionalDependencies)</AdditionalDependencies>
</Link>
</ItemDefinitionGroup>
<ItemGroup>
diff --git a/jpeg/makewdsp.vc6 b/jpeg/makewdsp.vc6
index 2063b1a5..d2f3887c 100644
--- a/jpeg/makewdsp.vc6
+++ b/jpeg/makewdsp.vc6
@@ -33,8 +33,8 @@ RSC=rc.exe
# PROP BASE Target_Dir ".\wrjpgcom"
# PROP Use_MFC 0
# PROP Use_Debug_Libraries 0
-# PROP Output_Dir ".\wrjpgcom\Release"
-# PROP Intermediate_Dir ".\wrjpgcom\Release"
+# PROP Output_Dir ".\Release"
+# PROP Intermediate_Dir ".\Release\wrjpgcom"
# PROP Ignore_Export_Lib 0
# PROP Target_Dir ".\wrjpgcom"
# ADD BASE CPP /nologo /W3 /GX /O2 /D "WIN32" /D "NDEBUG" /D "_CONSOLE" /YX /c
diff --git a/jpeg/makewfil.v15 b/jpeg/makewfil.v16
index 72c58566..c6ea74dd 100644
--- a/jpeg/makewfil.v15
+++ b/jpeg/makewfil.v16
@@ -1,4 +1,4 @@
-<?xml version="1.0" encoding="utf-8"?>
+<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<Filter Include="Source Files">
diff --git a/jpeg/makewvcx.v15 b/jpeg/makewvcx.v16
index 5f8b8df3..4abd720c 100644
--- a/jpeg/makewvcx.v15
+++ b/jpeg/makewvcx.v16
@@ -1,16 +1,20 @@
-<?xml version="1.0" encoding="utf-8"?>
+<?xml version="1.0" encoding="utf-8"?>
<Project DefaultTargets="Build" ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup Label="ProjectConfigurations">
<ProjectConfiguration Include="Release|Win32">
<Configuration>Release</Configuration>
<Platform>Win32</Platform>
</ProjectConfiguration>
+ <ProjectConfiguration Include="Release|x64">
+ <Configuration>Release</Configuration>
+ <Platform>x64</Platform>
+ </ProjectConfiguration>
</ItemGroup>
<PropertyGroup Label="Globals">
<ProjectGuid>{B57065D4-DDDA-4668-BAF5-2D49270C973C}</ProjectGuid>
<Keyword>Win32Proj</Keyword>
<RootNamespace>wrjpgcom</RootNamespace>
- <WindowsTargetPlatformVersion>10.0.16299.0</WindowsTargetPlatformVersion>
+ <WindowsTargetPlatformVersion>10.0</WindowsTargetPlatformVersion>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">
@@ -18,7 +22,14 @@
<UseDebugLibraries>false</UseDebugLibraries>
<WholeProgramOptimization>true</WholeProgramOptimization>
<CharacterSet>Unicode</CharacterSet>
- <PlatformToolset>v141</PlatformToolset>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
+ <ConfigurationType>Application</ConfigurationType>
+ <UseDebugLibraries>false</UseDebugLibraries>
+ <WholeProgramOptimization>true</WholeProgramOptimization>
+ <CharacterSet>Unicode</CharacterSet>
+ <PlatformToolset>v142</PlatformToolset>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
<ImportGroup Label="ExtensionSettings">
@@ -26,11 +37,19 @@
<ImportGroup Label="PropertySheets" Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
</ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
<PropertyGroup Label="UserMacros" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<LinkIncremental>false</LinkIncremental>
- <OutDir>$(ProjectName)\$(Configuration)\</OutDir>
- <IntDir>$(ProjectName)\$(Configuration)\</IntDir>
+ <OutDir>$(Configuration)\$(Platform)\</OutDir>
+ <IntDir>$(Configuration)\$(Platform)\$(ProjectName)\</IntDir>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+ <LinkIncremental>false</LinkIncremental>
+ <OutDir>$(Configuration)\$(Platform)\</OutDir>
+ <IntDir>$(Configuration)\$(Platform)\$(ProjectName)\</IntDir>
</PropertyGroup>
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
<ClCompile>
@@ -51,6 +70,25 @@
<OptimizeReferences>true</OptimizeReferences>
</Link>
</ItemDefinitionGroup>
+ <ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+ <ClCompile>
+ <WarningLevel>Level3</WarningLevel>
+ <PrecompiledHeader>NotUsing</PrecompiledHeader>
+ <Optimization>Full</Optimization>
+ <FunctionLevelLinking>true</FunctionLevelLinking>
+ <IntrinsicFunctions>false</IntrinsicFunctions>
+ <PreprocessorDefinitions>WIN32;NDEBUG;_CONSOLE;_CRT_SECURE_NO_WARNINGS</PreprocessorDefinitions>
+ <OmitFramePointers>true</OmitFramePointers>
+ <EnableFiberSafeOptimizations>true</EnableFiberSafeOptimizations>
+ <DisableSpecificWarnings>4996</DisableSpecificWarnings>
+ </ClCompile>
+ <Link>
+ <SubSystem>Console</SubSystem>
+ <GenerateDebugInformation>true</GenerateDebugInformation>
+ <EnableCOMDATFolding>true</EnableCOMDATFolding>
+ <OptimizeReferences>true</OptimizeReferences>
+ </Link>
+ </ItemDefinitionGroup>
<ItemGroup>
<ClInclude Include="jconfig.h" />
<ClInclude Include="jinclude.h" />
diff --git a/jpeg/missing b/jpeg/missing
index c6e37958..625aeb11 100755
--- a/jpeg/missing
+++ b/jpeg/missing
@@ -1,9 +1,9 @@
#! /bin/sh
# Common wrapper for a few potentially missing GNU programs.
-scriptversion=2016-01-11.22; # UTC
+scriptversion=2018-03-07.03; # UTC
-# Copyright (C) 1996-2017 Free Software Foundation, Inc.
+# Copyright (C) 1996-2018 Free Software Foundation, Inc.
# Originally written by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996.
# This program is free software; you can redistribute it and/or modify
@@ -17,7 +17,7 @@ scriptversion=2016-01-11.22; # UTC
# GNU General Public License for more details.
# You should have received a copy of the GNU General Public License
-# along with this program. If not, see <http://www.gnu.org/licenses/>.
+# along with this program. If not, see <https://www.gnu.org/licenses/>.
# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
@@ -101,9 +101,9 @@ else
exit $st
fi
-perl_URL=http://www.perl.org/
-flex_URL=http://flex.sourceforge.net/
-gnu_software_URL=http://www.gnu.org/software
+perl_URL=https://www.perl.org/
+flex_URL=https://github.com/westes/flex
+gnu_software_URL=https://www.gnu.org/software
program_details ()
{
@@ -207,7 +207,7 @@ give_advice "$1" | sed -e '1s/^/WARNING: /' \
exit $st
# Local variables:
-# eval: (add-hook 'write-file-hooks 'time-stamp)
+# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "scriptversion="
# time-stamp-format: "%:y-%02m-%02d.%02H"
# time-stamp-time-zone: "UTC0"
diff --git a/jpeg/rdbmp.c b/jpeg/rdbmp.c
index 6639ad06..6749ea01 100644
--- a/jpeg/rdbmp.c
+++ b/jpeg/rdbmp.c
@@ -2,7 +2,7 @@
* rdbmp.c
*
* Copyright (C) 1994-1996, Thomas G. Lane.
- * Modified 2009-2017 by Guido Vollbeding.
+ * Modified 2009-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -33,11 +33,10 @@
typedef unsigned char U_CHAR;
#define UCH(x) ((int) (x))
#else /* !HAVE_UNSIGNED_CHAR */
-#ifdef CHAR_IS_UNSIGNED
typedef char U_CHAR;
+#ifdef CHAR_IS_UNSIGNED
#define UCH(x) ((int) (x))
#else
-typedef char U_CHAR;
#define UCH(x) ((int) (x) & 0xFF)
#endif
#endif /* HAVE_UNSIGNED_CHAR */
@@ -105,7 +104,6 @@ read_colormap (bmp_source_ptr sinfo, int cmaplen, int mapentrysize)
break;
default:
ERREXIT(sinfo->cinfo, JERR_BMP_BADCMAP);
- break;
}
}
@@ -122,7 +120,6 @@ get_8bit_row (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
/* This version is for reading 8-bit colormap indexes */
{
bmp_source_ptr source = (bmp_source_ptr) sinfo;
- JSAMPARRAY image_ptr;
register JSAMPROW inptr, outptr;
register JSAMPARRAY colormap;
register JDIMENSION col;
@@ -131,12 +128,10 @@ get_8bit_row (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
/* Fetch next row from virtual array */
source->source_row--;
- image_ptr = (*cinfo->mem->access_virt_sarray)
- ((j_common_ptr) cinfo, source->whole_image,
- source->source_row, (JDIMENSION) 1, FALSE);
+ inptr = * (*cinfo->mem->access_virt_sarray) ((j_common_ptr) cinfo,
+ source->whole_image, source->source_row, (JDIMENSION) 1, FALSE);
/* Expand the colormap indexes to real data */
- inptr = image_ptr[0];
outptr = source->pub.buffer[0];
colormap = source->colormap;
cmaplen = source->cmap_length;
@@ -152,26 +147,22 @@ get_8bit_row (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
return 1;
}
-
METHODDEF(JDIMENSION)
get_24bit_row (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
/* This version is for reading 24-bit pixels */
{
bmp_source_ptr source = (bmp_source_ptr) sinfo;
- JSAMPARRAY image_ptr;
register JSAMPROW inptr, outptr;
register JDIMENSION col;
/* Fetch next row from virtual array */
source->source_row--;
- image_ptr = (*cinfo->mem->access_virt_sarray)
- ((j_common_ptr) cinfo, source->whole_image,
- source->source_row, (JDIMENSION) 1, FALSE);
+ inptr = * (*cinfo->mem->access_virt_sarray) ((j_common_ptr) cinfo,
+ source->whole_image, source->source_row, (JDIMENSION) 1, FALSE);
/* Transfer data. Note source values are in BGR order
* (even though Microsoft's own documents say the opposite).
*/
- inptr = image_ptr[0];
outptr = source->pub.buffer[0];
for (col = cinfo->image_width; col > 0; col--) {
outptr[2] = *inptr++; /* can omit GETJSAMPLE() safely */
@@ -183,26 +174,22 @@ get_24bit_row (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
return 1;
}
-
METHODDEF(JDIMENSION)
get_32bit_row (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
/* This version is for reading 32-bit pixels */
{
bmp_source_ptr source = (bmp_source_ptr) sinfo;
- JSAMPARRAY image_ptr;
register JSAMPROW inptr, outptr;
register JDIMENSION col;
/* Fetch next row from virtual array */
source->source_row--;
- image_ptr = (*cinfo->mem->access_virt_sarray)
- ((j_common_ptr) cinfo, source->whole_image,
- source->source_row, (JDIMENSION) 1, FALSE);
+ inptr = * (*cinfo->mem->access_virt_sarray) ((j_common_ptr) cinfo,
+ source->whole_image, source->source_row, (JDIMENSION) 1, FALSE);
/* Transfer data. Note source values are in BGR order
* (even though Microsoft's own documents say the opposite).
*/
- inptr = image_ptr[0];
outptr = source->pub.buffer[0];
for (col = cinfo->image_width; col > 0; col--) {
outptr[2] = *inptr++; /* can omit GETJSAMPLE() safely */
@@ -229,7 +216,6 @@ preload_image (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
register FILE *infile = source->pub.input_file;
register int c;
register JSAMPROW out_ptr;
- JSAMPARRAY image_ptr;
JDIMENSION row, col;
cd_progress_ptr progress = (cd_progress_ptr) cinfo->progress;
@@ -240,10 +226,8 @@ preload_image (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
progress->pub.pass_limit = (long) cinfo->image_height;
(*progress->pub.progress_monitor) ((j_common_ptr) cinfo);
}
- image_ptr = (*cinfo->mem->access_virt_sarray)
- ((j_common_ptr) cinfo, source->whole_image,
- row, (JDIMENSION) 1, TRUE);
- out_ptr = image_ptr[0];
+ out_ptr = * (*cinfo->mem->access_virt_sarray) ((j_common_ptr) cinfo,
+ source->whole_image, row, (JDIMENSION) 1, TRUE);
for (col = source->row_width; col > 0; col--) {
/* inline copy of read_byte() for speed */
if ((c = getc(infile)) == EOF)
@@ -285,12 +269,12 @@ start_input_bmp (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
bmp_source_ptr source = (bmp_source_ptr) sinfo;
U_CHAR bmpfileheader[14];
U_CHAR bmpinfoheader[64];
-#define GET_2B(array,offset) ((unsigned int) UCH(array[offset]) + \
- (((unsigned int) UCH(array[offset+1])) << 8))
-#define GET_4B(array,offset) ((INT32) UCH(array[offset]) + \
- (((INT32) UCH(array[offset+1])) << 8) + \
- (((INT32) UCH(array[offset+2])) << 16) + \
- (((INT32) UCH(array[offset+3])) << 24))
+#define GET_2B(array, offset) ((unsigned int) UCH(array[offset]) + \
+ (((unsigned int) UCH(array[offset+1])) << 8))
+#define GET_4B(array, offset) ((INT32) UCH(array[offset]) + \
+ (((INT32) UCH(array[offset+1])) << 8) + \
+ (((INT32) UCH(array[offset+2])) << 16) + \
+ (((INT32) UCH(array[offset+3])) << 24))
INT32 bfOffBits;
INT32 headerSize;
INT32 biWidth;
@@ -306,9 +290,9 @@ start_input_bmp (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
/* Read and verify the bitmap file header */
if (! ReadOK(source->pub.input_file, bmpfileheader, 14))
ERREXIT(cinfo, JERR_INPUT_EOF);
- if (GET_2B(bmpfileheader,0) != 0x4D42) /* 'BM' */
+ if (GET_2B(bmpfileheader, 0) != 0x4D42) /* 'BM' */
ERREXIT(cinfo, JERR_BMP_NOT);
- bfOffBits = GET_4B(bmpfileheader,10);
+ bfOffBits = GET_4B(bmpfileheader, 10);
/* We ignore the remaining fileheader fields */
/* The infoheader might be 12 bytes (OS/2 1.x), 40 bytes (Windows),
@@ -316,19 +300,19 @@ start_input_bmp (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
*/
if (! ReadOK(source->pub.input_file, bmpinfoheader, 4))
ERREXIT(cinfo, JERR_INPUT_EOF);
- headerSize = GET_4B(bmpinfoheader,0);
+ headerSize = GET_4B(bmpinfoheader, 0);
if (headerSize < 12 || headerSize > 64)
ERREXIT(cinfo, JERR_BMP_BADHEADER);
- if (! ReadOK(source->pub.input_file, bmpinfoheader+4, headerSize-4))
+ if (! ReadOK(source->pub.input_file, bmpinfoheader + 4, headerSize - 4))
ERREXIT(cinfo, JERR_INPUT_EOF);
switch ((int) headerSize) {
case 12:
/* Decode OS/2 1.x header (Microsoft calls this a BITMAPCOREHEADER) */
- biWidth = (INT32) GET_2B(bmpinfoheader,4);
- biHeight = (INT32) GET_2B(bmpinfoheader,6);
- biPlanes = GET_2B(bmpinfoheader,8);
- source->bits_per_pixel = (int) GET_2B(bmpinfoheader,10);
+ biWidth = (INT32) GET_2B(bmpinfoheader, 4);
+ biHeight = (INT32) GET_2B(bmpinfoheader, 6);
+ biPlanes = GET_2B(bmpinfoheader, 8);
+ source->bits_per_pixel = (int) GET_2B(bmpinfoheader, 10);
switch (source->bits_per_pixel) {
case 8: /* colormapped image */
@@ -342,21 +326,20 @@ start_input_bmp (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
break;
default:
ERREXIT(cinfo, JERR_BMP_BADDEPTH);
- break;
}
break;
case 40:
case 64:
/* Decode Windows 3.x header (Microsoft calls this a BITMAPINFOHEADER) */
/* or OS/2 2.x header, which has additional fields that we ignore */
- biWidth = GET_4B(bmpinfoheader,4);
- biHeight = GET_4B(bmpinfoheader,8);
- biPlanes = GET_2B(bmpinfoheader,12);
- source->bits_per_pixel = (int) GET_2B(bmpinfoheader,14);
- biCompression = GET_4B(bmpinfoheader,16);
- biXPelsPerMeter = GET_4B(bmpinfoheader,24);
- biYPelsPerMeter = GET_4B(bmpinfoheader,28);
- biClrUsed = GET_4B(bmpinfoheader,32);
+ biWidth = GET_4B(bmpinfoheader, 4);
+ biHeight = GET_4B(bmpinfoheader, 8);
+ biPlanes = GET_2B(bmpinfoheader, 12);
+ source->bits_per_pixel = (int) GET_2B(bmpinfoheader, 14);
+ biCompression = GET_4B(bmpinfoheader, 16);
+ biXPelsPerMeter = GET_4B(bmpinfoheader, 24);
+ biYPelsPerMeter = GET_4B(bmpinfoheader, 28);
+ biClrUsed = GET_4B(bmpinfoheader, 32);
/* biSizeImage, biClrImportant fields are ignored */
switch (source->bits_per_pixel) {
@@ -371,7 +354,6 @@ start_input_bmp (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
break;
default:
ERREXIT(cinfo, JERR_BMP_BADDEPTH);
- break;
}
if (biCompression != 0)
ERREXIT(cinfo, JERR_BMP_COMPRESSED);
@@ -404,9 +386,8 @@ start_input_bmp (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
else if (biClrUsed > 256)
ERREXIT(cinfo, JERR_BMP_BADCMAP);
/* Allocate space to store the colormap */
- source->colormap = (*cinfo->mem->alloc_sarray)
- ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (JDIMENSION) biClrUsed, (JDIMENSION) 3);
+ source->colormap = (*cinfo->mem->alloc_sarray) ((j_common_ptr) cinfo,
+ JPOOL_IMAGE, (JDIMENSION) biClrUsed, (JDIMENSION) 3);
source->cmap_length = (int) biClrUsed;
/* and read it from the file */
read_colormap(source, (int) biClrUsed, mapentrysize);
@@ -442,9 +423,8 @@ start_input_bmp (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
}
/* Allocate one-row buffer for returned data */
- source->pub.buffer = (*cinfo->mem->alloc_sarray)
- ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (JDIMENSION) (biWidth * 3), (JDIMENSION) 1);
+ source->pub.buffer = (*cinfo->mem->alloc_sarray) ((j_common_ptr) cinfo,
+ JPOOL_IMAGE, (JDIMENSION) (biWidth * 3), (JDIMENSION) 1);
source->pub.buffer_height = 1;
cinfo->in_color_space = JCS_RGB;
@@ -476,9 +456,8 @@ jinit_read_bmp (j_compress_ptr cinfo)
bmp_source_ptr source;
/* Create module interface object */
- source = (bmp_source_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(bmp_source_struct));
+ source = (bmp_source_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(bmp_source_struct));
source->cinfo = cinfo; /* make back link for subroutines */
/* Fill in method ptrs, except get_pixel_rows which start_input sets */
source->pub.start_input = start_input_bmp;
diff --git a/jpeg/rdgif.c b/jpeg/rdgif.c
index b27c1675..0cbf8d13 100644
--- a/jpeg/rdgif.c
+++ b/jpeg/rdgif.c
@@ -1,28 +1,659 @@
/*
* rdgif.c
*
- * Copyright (C) 1991-1997, Thomas G. Lane.
+ * Copyright (C) 1991-1996, Thomas G. Lane.
+ * Modified 2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
* This file contains routines to read input images in GIF format.
*
- *****************************************************************************
- * NOTE: to avoid entanglements with Unisys' patent on LZW compression, *
- * the ability to read GIF files has been removed from the IJG distribution. *
- * Sorry about that. *
- *****************************************************************************
- *
- * We are required to state that
- * "The Graphics Interchange Format(c) is the Copyright property of
- * CompuServe Incorporated. GIF(sm) is a Service Mark property of
- * CompuServe Incorporated."
+ * These routines may need modification for non-Unix environments or
+ * specialized applications. As they stand, they assume input from
+ * an ordinary stdio stream. They further assume that reading begins
+ * at the start of the file; start_input may need work if the
+ * user interface has already read some data (e.g., to determine that
+ * the file is indeed GIF format).
+ */
+
+/*
+ * This code is loosely based on giftoppm from the PBMPLUS distribution
+ * of Feb. 1991. That file contains the following copyright notice:
+ * +-------------------------------------------------------------------+
+ * | Copyright 1990, David Koblas. |
+ * | Permission to use, copy, modify, and distribute this software |
+ * | and its documentation for any purpose and without fee is hereby |
+ * | granted, provided that the above copyright notice appear in all |
+ * | copies and that both that copyright notice and this permission |
+ * | notice appear in supporting documentation. This software is |
+ * | provided "as is" without express or implied warranty. |
+ * +-------------------------------------------------------------------+
*/
#include "cdjpeg.h" /* Common decls for cjpeg/djpeg applications */
#ifdef GIF_SUPPORTED
+
+/* Macros to deal with unsigned chars as efficiently as compiler allows */
+
+#ifdef HAVE_UNSIGNED_CHAR
+typedef unsigned char U_CHAR;
+#define UCH(x) ((int) (x))
+#else /* !HAVE_UNSIGNED_CHAR */
+typedef char U_CHAR;
+#ifdef CHAR_IS_UNSIGNED
+#define UCH(x) ((int) (x))
+#else
+#define UCH(x) ((int) (x) & 0xFF)
+#endif
+#endif /* HAVE_UNSIGNED_CHAR */
+
+
+#define ReadOK(file,buffer,len) (JFREAD(file,buffer,len) == ((size_t) (len)))
+
+
+#define MAXCOLORMAPSIZE 256 /* max # of colors in a GIF colormap */
+#define NUMCOLORS 3 /* # of colors */
+#define CM_RED 0 /* color component numbers */
+#define CM_GREEN 1
+#define CM_BLUE 2
+
+#define MAX_LZW_BITS 12 /* maximum LZW code size */
+#define LZW_TABLE_SIZE (1<<MAX_LZW_BITS) /* # of possible LZW symbols */
+
+/* Macros for extracting header data --- note we assume chars may be signed */
+
+#define LM_to_uint(array, offset) ((unsigned int) UCH(array[offset]) + \
+ (((unsigned int) UCH(array[offset+1])) << 8))
+
+#define BitSet(byte, bit) ((byte) & (bit))
+#define INTERLACE 0x40 /* mask for bit signifying interlaced image */
+#define COLORMAPFLAG 0x80 /* mask for bit signifying colormap presence */
+
+
+/*
+ * LZW decompression tables look like this:
+ * symbol_head[K] = prefix symbol of any LZW symbol K (0..LZW_TABLE_SIZE-1)
+ * symbol_tail[K] = suffix byte of any LZW symbol K (0..LZW_TABLE_SIZE-1)
+ * Note that entries 0..end_code of the above tables are not used,
+ * since those symbols represent raw bytes or special codes.
+ *
+ * The stack represents the not-yet-used expansion of the last LZW symbol.
+ * In the worst case, a symbol could expand to as many bytes as there are
+ * LZW symbols, so we allocate LZW_TABLE_SIZE bytes for the stack.
+ * (This is conservative since that number includes the raw-byte symbols.)
+ *
+ * The tables are allocated from FAR heap space since they would use up
+ * rather a lot of the near data space in a PC.
+ */
+
+
+/* Private version of data source object */
+
+typedef struct {
+ struct cjpeg_source_struct pub; /* public fields */
+
+ j_compress_ptr cinfo; /* back link saves passing separate parm */
+
+ JSAMPARRAY colormap; /* GIF colormap (converted to my format) */
+
+ /* State for GetCode and LZWReadByte */
+ U_CHAR code_buf[256+4]; /* current input data block */
+ int last_byte; /* # of bytes in code_buf */
+ int last_bit; /* # of bits in code_buf */
+ int cur_bit; /* next bit index to read */
+ boolean first_time; /* flags first call to GetCode */
+ boolean out_of_blocks; /* TRUE if hit terminator data block */
+
+ int input_code_size; /* codesize given in GIF file */
+ int clear_code, end_code; /* values for Clear and End codes */
+
+ int code_size; /* current actual code size */
+ int limit_code; /* 2^code_size */
+ int max_code; /* first unused code value */
+
+ /* Private state for LZWReadByte */
+ int oldcode; /* previous LZW symbol */
+ int firstcode; /* first byte of oldcode's expansion */
+
+ /* LZW symbol table and expansion stack */
+ UINT16 FAR *symbol_head; /* => table of prefix symbols */
+ UINT8 FAR *symbol_tail; /* => table of suffix bytes */
+ UINT8 FAR *symbol_stack; /* => stack for symbol expansions */
+ UINT8 FAR *sp; /* stack pointer */
+
+ /* State for interlaced image processing */
+ boolean is_interlaced; /* TRUE if have interlaced image */
+ jvirt_sarray_ptr interlaced_image; /* full image in interlaced order */
+ JDIMENSION cur_row_number; /* need to know actual row number */
+ JDIMENSION pass2_offset; /* # of pixel rows in pass 1 */
+ JDIMENSION pass3_offset; /* # of pixel rows in passes 1&2 */
+ JDIMENSION pass4_offset; /* # of pixel rows in passes 1,2,3 */
+} gif_source_struct;
+
+typedef gif_source_struct * gif_source_ptr;
+
+
+/* Forward declarations */
+METHODDEF(JDIMENSION) get_pixel_rows
+ JPP((j_compress_ptr cinfo, cjpeg_source_ptr sinfo));
+METHODDEF(JDIMENSION) load_interlaced_image
+ JPP((j_compress_ptr cinfo, cjpeg_source_ptr sinfo));
+METHODDEF(JDIMENSION) get_interlaced_row
+ JPP((j_compress_ptr cinfo, cjpeg_source_ptr sinfo));
+
+
+LOCAL(int)
+ReadByte (gif_source_ptr sinfo)
+/* Read next byte from GIF file */
+{
+ register FILE *infile = sinfo->pub.input_file;
+ register int c;
+
+ if ((c = getc(infile)) == EOF)
+ ERREXIT(sinfo->cinfo, JERR_INPUT_EOF);
+ return c;
+}
+
+
+LOCAL(int)
+GetDataBlock (gif_source_ptr sinfo, U_CHAR *buf)
+/* Read a GIF data block, which has a leading count byte */
+/* A zero-length block marks the end of a data block sequence */
+{
+ int count;
+
+ count = ReadByte(sinfo);
+ if (count > 0) {
+ if (! ReadOK(sinfo->pub.input_file, buf, count))
+ ERREXIT(sinfo->cinfo, JERR_INPUT_EOF);
+ }
+ return count;
+}
+
+
+LOCAL(void)
+SkipDataBlocks (gif_source_ptr sinfo)
+/* Skip a series of data blocks, until a block terminator is found */
+{
+ U_CHAR buf[256];
+
+ while (GetDataBlock(sinfo, buf) > 0)
+ /* skip */;
+}
+
+
+LOCAL(void)
+ReInitLZW (gif_source_ptr sinfo)
+/* (Re)initialize LZW state; shared code for startup and Clear processing */
+{
+ sinfo->code_size = sinfo->input_code_size + 1;
+ sinfo->limit_code = sinfo->clear_code << 1; /* 2^code_size */
+ sinfo->max_code = sinfo->clear_code + 2; /* first unused code value */
+ sinfo->sp = sinfo->symbol_stack; /* init stack to empty */
+}
+
+
+LOCAL(void)
+InitLZWCode (gif_source_ptr sinfo)
+/* Initialize for a series of LZWReadByte (and hence GetCode) calls */
+{
+ /* GetCode initialization */
+ sinfo->last_byte = 2; /* make safe to "recopy last two bytes" */
+ sinfo->code_buf[0] = 0;
+ sinfo->code_buf[1] = 0;
+ sinfo->last_bit = 0; /* nothing in the buffer */
+ sinfo->cur_bit = 0; /* force buffer load on first call */
+ sinfo->first_time = TRUE;
+ sinfo->out_of_blocks = FALSE;
+
+ /* LZWReadByte initialization: */
+ /* compute special code values (note that these do not change later) */
+ sinfo->clear_code = 1 << sinfo->input_code_size;
+ sinfo->end_code = sinfo->clear_code + 1;
+ ReInitLZW(sinfo);
+}
+
+
+LOCAL(int)
+GetCode (gif_source_ptr sinfo)
+/* Fetch the next code_size bits from the GIF data */
+/* We assume code_size is less than 16 */
+{
+ register INT32 accum;
+ int offs, count;
+
+ while (sinfo->cur_bit + sinfo->code_size > sinfo->last_bit) {
+ /* Time to reload the buffer */
+ /* First time, share code with Clear case */
+ if (sinfo->first_time) {
+ sinfo->first_time = FALSE;
+ return sinfo->clear_code;
+ }
+ if (sinfo->out_of_blocks) {
+ WARNMS(sinfo->cinfo, JWRN_GIF_NOMOREDATA);
+ return sinfo->end_code; /* fake something useful */
+ }
+ /* preserve last two bytes of what we have -- assume code_size <= 16 */
+ sinfo->code_buf[0] = sinfo->code_buf[sinfo->last_byte-2];
+ sinfo->code_buf[1] = sinfo->code_buf[sinfo->last_byte-1];
+ /* Load more bytes; set flag if we reach the terminator block */
+ if ((count = GetDataBlock(sinfo, &sinfo->code_buf[2])) == 0) {
+ sinfo->out_of_blocks = TRUE;
+ WARNMS(sinfo->cinfo, JWRN_GIF_NOMOREDATA);
+ return sinfo->end_code; /* fake something useful */
+ }
+ /* Reset counters */
+ sinfo->cur_bit = (sinfo->cur_bit - sinfo->last_bit) + 16;
+ sinfo->last_byte = 2 + count;
+ sinfo->last_bit = sinfo->last_byte * 8;
+ }
+
+ /* Form up next 24 bits in accum */
+ offs = sinfo->cur_bit >> 3; /* byte containing cur_bit */
+ accum = (INT32) UCH(sinfo->code_buf[offs+2]);
+ accum <<= 8;
+ accum |= (INT32) UCH(sinfo->code_buf[offs+1]);
+ accum <<= 8;
+ accum |= (INT32) UCH(sinfo->code_buf[offs]);
+
+ /* Right-align cur_bit in accum, then mask off desired number of bits */
+ accum >>= (sinfo->cur_bit & 7);
+ sinfo->cur_bit += sinfo->code_size;
+ return ((int) accum) & ((1 << sinfo->code_size) - 1);
+}
+
+
+LOCAL(int)
+LZWReadByte (gif_source_ptr sinfo)
+/* Read an LZW-compressed byte */
+{
+ register int code; /* current working code */
+ int incode; /* saves actual input code */
+
+ /* If any codes are stacked from a previously read symbol, return them */
+ if (sinfo->sp > sinfo->symbol_stack)
+ return (int) *(-- sinfo->sp);
+
+ /* Time to read a new symbol */
+ code = GetCode(sinfo);
+
+ if (code == sinfo->clear_code) {
+ /* Reinit state, swallow any extra Clear codes, and */
+ /* return next code, which is expected to be a raw byte. */
+ ReInitLZW(sinfo);
+ do {
+ code = GetCode(sinfo);
+ } while (code == sinfo->clear_code);
+ if (code > sinfo->clear_code) { /* make sure it is a raw byte */
+ WARNMS(sinfo->cinfo, JWRN_GIF_BADDATA);
+ code = 0; /* use something valid */
+ }
+ /* make firstcode, oldcode valid! */
+ sinfo->firstcode = sinfo->oldcode = code;
+ return code;
+ }
+
+ if (code == sinfo->end_code) {
+ /* Skip the rest of the image, unless GetCode already read terminator */
+ if (! sinfo->out_of_blocks) {
+ SkipDataBlocks(sinfo);
+ sinfo->out_of_blocks = TRUE;
+ }
+ /* Complain that there's not enough data */
+ WARNMS(sinfo->cinfo, JWRN_GIF_ENDCODE);
+ /* Pad data with 0's */
+ return 0; /* fake something usable */
+ }
+
+ /* Got normal raw byte or LZW symbol */
+ incode = code; /* save for a moment */
+
+ if (code >= sinfo->max_code) { /* special case for not-yet-defined symbol */
+ /* code == max_code is OK; anything bigger is bad data */
+ if (code > sinfo->max_code) {
+ WARNMS(sinfo->cinfo, JWRN_GIF_BADDATA);
+ incode = 0; /* prevent creation of loops in symbol table */
+ }
+ /* this symbol will be defined as oldcode/firstcode */
+ *(sinfo->sp++) = (UINT8) sinfo->firstcode;
+ code = sinfo->oldcode;
+ }
+
+ /* If it's a symbol, expand it into the stack */
+ while (code >= sinfo->clear_code) {
+ *(sinfo->sp++) = sinfo->symbol_tail[code]; /* tail is a byte value */
+ code = sinfo->symbol_head[code]; /* head is another LZW symbol */
+ }
+ /* At this point code just represents a raw byte */
+ sinfo->firstcode = code; /* save for possible future use */
+
+ /* If there's room in table... */
+ if ((code = sinfo->max_code) < LZW_TABLE_SIZE) {
+ /* Define a new symbol = prev sym + head of this sym's expansion */
+ sinfo->symbol_head[code] = (UINT16) sinfo->oldcode;
+ sinfo->symbol_tail[code] = (UINT8) sinfo->firstcode;
+ sinfo->max_code++;
+ /* Is it time to increase code_size? */
+ if (sinfo->max_code >= sinfo->limit_code &&
+ sinfo->code_size < MAX_LZW_BITS) {
+ sinfo->code_size++;
+ sinfo->limit_code <<= 1; /* keep equal to 2^code_size */
+ }
+ }
+
+ sinfo->oldcode = incode; /* save last input symbol for future use */
+ return sinfo->firstcode; /* return first byte of symbol's expansion */
+}
+
+
+LOCAL(void)
+ReadColorMap (gif_source_ptr sinfo, int cmaplen, JSAMPARRAY cmap)
+/* Read a GIF colormap */
+{
+ int i;
+
+ for (i = 0; i < cmaplen; i++) {
+#if BITS_IN_JSAMPLE == 8
+#define UPSCALE(x) (x)
+#else
+#define UPSCALE(x) ((x) << (BITS_IN_JSAMPLE-8))
+#endif
+ cmap[CM_RED ][i] = (JSAMPLE) UPSCALE(ReadByte(sinfo));
+ cmap[CM_GREEN][i] = (JSAMPLE) UPSCALE(ReadByte(sinfo));
+ cmap[CM_BLUE ][i] = (JSAMPLE) UPSCALE(ReadByte(sinfo));
+ }
+}
+
+
+LOCAL(void)
+DoExtension (gif_source_ptr sinfo)
+/* Process an extension block */
+/* Currently we ignore 'em all */
+{
+ int extlabel;
+
+ /* Read extension label byte */
+ extlabel = ReadByte(sinfo);
+ TRACEMS1(sinfo->cinfo, 1, JTRC_GIF_EXTENSION, extlabel);
+ /* Skip the data block(s) associated with the extension */
+ SkipDataBlocks(sinfo);
+}
+
+
+/*
+ * Read the file header; return image size and component count.
+ */
+
+METHODDEF(void)
+start_input_gif (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
+{
+ gif_source_ptr source = (gif_source_ptr) sinfo;
+ U_CHAR hdrbuf[10]; /* workspace for reading control blocks */
+ unsigned int width, height; /* image dimensions */
+ int colormaplen, aspectRatio;
+ int c;
+
+ /* Read and verify GIF Header */
+ if (! ReadOK(source->pub.input_file, hdrbuf, 6))
+ ERREXIT(cinfo, JERR_GIF_NOT);
+ if (hdrbuf[0] != 'G' || hdrbuf[1] != 'I' || hdrbuf[2] != 'F')
+ ERREXIT(cinfo, JERR_GIF_NOT);
+ /* Check for expected version numbers.
+ * If unknown version, give warning and try to process anyway;
+ * this is per recommendation in GIF89a standard.
+ */
+ if ((hdrbuf[3] != '8' || hdrbuf[4] != '7' || hdrbuf[5] != 'a') &&
+ (hdrbuf[3] != '8' || hdrbuf[4] != '9' || hdrbuf[5] != 'a'))
+ TRACEMS3(cinfo, 1, JTRC_GIF_BADVERSION, hdrbuf[3], hdrbuf[4], hdrbuf[5]);
+
+ /* Read and decipher Logical Screen Descriptor */
+ if (! ReadOK(source->pub.input_file, hdrbuf, 7))
+ ERREXIT(cinfo, JERR_INPUT_EOF);
+ width = LM_to_uint(hdrbuf, 0);
+ height = LM_to_uint(hdrbuf, 2);
+ /* we ignore the color resolution, sort flag, and background color index */
+ aspectRatio = UCH(hdrbuf[6]);
+ if (aspectRatio != 0 && aspectRatio != 49)
+ TRACEMS(cinfo, 1, JTRC_GIF_NONSQUARE);
+
+ /* Allocate space to store the colormap */
+ source->colormap = (*cinfo->mem->alloc_sarray) ((j_common_ptr) cinfo,
+ JPOOL_IMAGE, (JDIMENSION) MAXCOLORMAPSIZE, (JDIMENSION) NUMCOLORS);
+ colormaplen = 0; /* indicate initialization */
+
+ /* Read global colormap if header indicates it is present */
+ if (BitSet(hdrbuf[4], COLORMAPFLAG)) {
+ colormaplen = 2 << (hdrbuf[4] & 0x07);
+ ReadColorMap(source, colormaplen, source->colormap);
+ }
+
+ /* Scan until we reach start of desired image.
+ * We don't currently support skipping images, but could add it easily.
+ */
+ for (;;) {
+ c = ReadByte(source);
+
+ if (c == ';') /* GIF terminator?? */
+ ERREXIT(cinfo, JERR_GIF_IMAGENOTFOUND);
+
+ if (c == '!') { /* Extension */
+ DoExtension(source);
+ continue;
+ }
+
+ if (c != ',') { /* Not an image separator? */
+ WARNMS1(cinfo, JWRN_GIF_CHAR, c);
+ continue;
+ }
+
+ /* Read and decipher Local Image Descriptor */
+ if (! ReadOK(source->pub.input_file, hdrbuf, 9))
+ ERREXIT(cinfo, JERR_INPUT_EOF);
+ /* we ignore top/left position info, also sort flag */
+ width = LM_to_uint(hdrbuf, 4);
+ height = LM_to_uint(hdrbuf, 6);
+ source->is_interlaced = (BitSet(hdrbuf[8], INTERLACE) != 0);
+
+ /* Read local colormap if header indicates it is present */
+ /* Note: if we wanted to support skipping images, */
+ /* we'd need to skip rather than read colormap for ignored images */
+ if (BitSet(hdrbuf[8], COLORMAPFLAG)) {
+ colormaplen = 2 << (hdrbuf[8] & 0x07);
+ ReadColorMap(source, colormaplen, source->colormap);
+ }
+
+ source->input_code_size = ReadByte(source); /* get min-code-size byte */
+ if (source->input_code_size < 2 || source->input_code_size > 8)
+ ERREXIT1(cinfo, JERR_GIF_CODESIZE, source->input_code_size);
+
+ /* Reached desired image, so break out of loop */
+ /* If we wanted to skip this image, */
+ /* we'd call SkipDataBlocks and then continue the loop */
+ break;
+ }
+
+ /* Prepare to read selected image: first initialize LZW decompressor */
+ source->symbol_head = (UINT16 FAR *) (*cinfo->mem->alloc_large)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, LZW_TABLE_SIZE * SIZEOF(UINT16));
+ source->symbol_tail = (UINT8 FAR *) (*cinfo->mem->alloc_large)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, LZW_TABLE_SIZE * SIZEOF(UINT8));
+ source->symbol_stack = (UINT8 FAR *) (*cinfo->mem->alloc_large)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, LZW_TABLE_SIZE * SIZEOF(UINT8));
+ InitLZWCode(source);
+
+ /*
+ * If image is interlaced, we read it into a full-size sample array,
+ * decompressing as we go; then get_interlaced_row selects rows from the
+ * sample array in the proper order.
+ */
+ if (source->is_interlaced) {
+ /* We request the virtual array now, but can't access it until virtual
+ * arrays have been allocated. Hence, the actual work of reading the
+ * image is postponed until the first call to get_pixel_rows.
+ */
+ source->interlaced_image = (*cinfo->mem->request_virt_sarray)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, FALSE,
+ (JDIMENSION) width, (JDIMENSION) height, (JDIMENSION) 1);
+ if (cinfo->progress != NULL) {
+ cd_progress_ptr progress = (cd_progress_ptr) cinfo->progress;
+ progress->total_extra_passes++; /* count file input as separate pass */
+ }
+ source->pub.get_pixel_rows = load_interlaced_image;
+ } else {
+ source->pub.get_pixel_rows = get_pixel_rows;
+ }
+
+ /* Create compressor input buffer. */
+ source->pub.buffer = (*cinfo->mem->alloc_sarray) ((j_common_ptr) cinfo,
+ JPOOL_IMAGE, (JDIMENSION) width * NUMCOLORS, (JDIMENSION) 1);
+ source->pub.buffer_height = 1;
+
+ /* Pad colormap for safety. */
+ for (c = colormaplen; c < source->clear_code; c++) {
+ source->colormap[CM_RED ][c] =
+ source->colormap[CM_GREEN][c] =
+ source->colormap[CM_BLUE ][c] = CENTERJSAMPLE;
+ }
+
+ /* Return info about the image. */
+ cinfo->in_color_space = JCS_RGB;
+ cinfo->input_components = NUMCOLORS;
+ cinfo->data_precision = BITS_IN_JSAMPLE; /* we always rescale data to this */
+ cinfo->image_width = width;
+ cinfo->image_height = height;
+
+ TRACEMS3(cinfo, 1, JTRC_GIF, width, height, colormaplen);
+}
+
+
+/*
+ * Read one row of pixels.
+ * This version is used for noninterlaced GIF images:
+ * we read directly from the GIF file.
+ */
+
+METHODDEF(JDIMENSION)
+get_pixel_rows (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
+{
+ gif_source_ptr source = (gif_source_ptr) sinfo;
+ register int c;
+ register JSAMPROW ptr;
+ register JDIMENSION col;
+ register JSAMPARRAY colormap = source->colormap;
+
+ ptr = source->pub.buffer[0];
+ for (col = cinfo->image_width; col > 0; col--) {
+ c = LZWReadByte(source);
+ *ptr++ = colormap[CM_RED ][c];
+ *ptr++ = colormap[CM_GREEN][c];
+ *ptr++ = colormap[CM_BLUE ][c];
+ }
+ return 1;
+}
+
+
+/*
+ * Read one row of pixels.
+ * This version is used for the first call on get_pixel_rows when
+ * reading an interlaced GIF file: we read the whole image into memory.
+ */
+
+METHODDEF(JDIMENSION)
+load_interlaced_image (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
+{
+ gif_source_ptr source = (gif_source_ptr) sinfo;
+ register JSAMPROW sptr;
+ register JDIMENSION col;
+ JDIMENSION row;
+ cd_progress_ptr progress = (cd_progress_ptr) cinfo->progress;
+
+ /* Read the interlaced image into the virtual array we've created. */
+ for (row = 0; row < cinfo->image_height; row++) {
+ if (progress != NULL) {
+ progress->pub.pass_counter = (long) row;
+ progress->pub.pass_limit = (long) cinfo->image_height;
+ (*progress->pub.progress_monitor) ((j_common_ptr) cinfo);
+ }
+ sptr = * (*cinfo->mem->access_virt_sarray) ((j_common_ptr) cinfo,
+ source->interlaced_image, row, (JDIMENSION) 1, TRUE);
+ for (col = cinfo->image_width; col > 0; col--) {
+ *sptr++ = (JSAMPLE) LZWReadByte(source);
+ }
+ }
+ if (progress != NULL)
+ progress->completed_extra_passes++;
+
+ /* Replace method pointer so subsequent calls don't come here. */
+ source->pub.get_pixel_rows = get_interlaced_row;
+ /* Initialize for get_interlaced_row, and perform first call on it. */
+ source->cur_row_number = 0;
+ source->pass2_offset = (cinfo->image_height + 7) / 8;
+ source->pass3_offset = source->pass2_offset + (cinfo->image_height + 3) / 8;
+ source->pass4_offset = source->pass3_offset + (cinfo->image_height + 1) / 4;
+
+ return get_interlaced_row(cinfo, sinfo);
+}
+
+
+/*
+ * Read one row of pixels.
+ * This version is used for interlaced GIF images:
+ * we read from the virtual array.
+ */
+
+METHODDEF(JDIMENSION)
+get_interlaced_row (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
+{
+ gif_source_ptr source = (gif_source_ptr) sinfo;
+ register int c;
+ register JSAMPROW sptr, ptr;
+ register JDIMENSION col;
+ register JSAMPARRAY colormap = source->colormap;
+ JDIMENSION irow;
+
+ /* Figure out which row of interlaced image is needed, and access it. */
+ switch ((int) (source->cur_row_number & 7)) {
+ case 0: /* first-pass row */
+ irow = source->cur_row_number >> 3;
+ break;
+ case 4: /* second-pass row */
+ irow = (source->cur_row_number >> 3) + source->pass2_offset;
+ break;
+ case 2: /* third-pass row */
+ case 6:
+ irow = (source->cur_row_number >> 2) + source->pass3_offset;
+ break;
+ default: /* fourth-pass row */
+ irow = (source->cur_row_number >> 1) + source->pass4_offset;
+ }
+ sptr = * (*cinfo->mem->access_virt_sarray) ((j_common_ptr) cinfo,
+ source->interlaced_image, irow, (JDIMENSION) 1, FALSE);
+ /* Scan the row, expand colormap, and output */
+ ptr = source->pub.buffer[0];
+ for (col = cinfo->image_width; col > 0; col--) {
+ c = GETJSAMPLE(*sptr++);
+ *ptr++ = colormap[CM_RED ][c];
+ *ptr++ = colormap[CM_GREEN][c];
+ *ptr++ = colormap[CM_BLUE ][c];
+ }
+ source->cur_row_number++; /* for next time */
+ return 1;
+}
+
+
+/*
+ * Finish up at the end of the file.
+ */
+
+METHODDEF(void)
+finish_input_gif (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
+{
+ /* no work */
+}
+
+
/*
* The module selection routine for GIF format input.
*/
@@ -30,9 +661,17 @@
GLOBAL(cjpeg_source_ptr)
jinit_read_gif (j_compress_ptr cinfo)
{
- fprintf(stderr, "GIF input is unsupported for legal reasons. Sorry.\n");
- exit(EXIT_FAILURE);
- return NULL; /* keep compiler happy */
+ gif_source_ptr source;
+
+ /* Create module interface object */
+ source = (gif_source_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(gif_source_struct));
+ source->cinfo = cinfo; /* make back link for subroutines */
+ /* Fill in method ptrs, except get_pixel_rows which start_input sets */
+ source->pub.start_input = start_input_gif;
+ source->pub.finish_input = finish_input_gif;
+
+ return &source->pub;
}
#endif /* GIF_SUPPORTED */
diff --git a/jpeg/rdppm.c b/jpeg/rdppm.c
index 357ce9e3..33e469ac 100644
--- a/jpeg/rdppm.c
+++ b/jpeg/rdppm.c
@@ -2,7 +2,7 @@
* rdppm.c
*
* Copyright (C) 1991-1997, Thomas G. Lane.
- * Modified 2009-2017 by Bill Allombert, Guido Vollbeding.
+ * Modified 2009-2019 by Bill Allombert, Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -19,11 +19,6 @@
* the file is indeed PPM format).
*/
-#include "cdjpeg.h" /* Common decls for cjpeg/djpeg applications */
-
-#ifdef PPM_SUPPORTED
-
-
/* Portions of this code are based on the PBMPLUS library, which is:
**
** Copyright (C) 1988 by Jef Poskanzer.
@@ -36,6 +31,10 @@
** implied warranty.
*/
+#include "cdjpeg.h" /* Common decls for cjpeg/djpeg applications */
+
+#ifdef PPM_SUPPORTED
+
/* Macros to deal with unsigned chars as efficiently as compiler allows */
@@ -43,11 +42,10 @@
typedef unsigned char U_CHAR;
#define UCH(x) ((int) (x))
#else /* !HAVE_UNSIGNED_CHAR */
-#ifdef CHAR_IS_UNSIGNED
typedef char U_CHAR;
+#ifdef CHAR_IS_UNSIGNED
#define UCH(x) ((int) (x))
#else
-typedef char U_CHAR;
#define UCH(x) ((int) (x) & 0xFF)
#endif
#endif /* HAVE_UNSIGNED_CHAR */
@@ -358,7 +356,6 @@ start_input_ppm (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
break;
default:
ERREXIT(cinfo, JERR_PPM_NOT);
- break;
}
/* fetch the remaining header info */
@@ -449,9 +446,8 @@ start_input_ppm (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
source->pub.buffer_height = 1;
} else {
/* Need to translate anyway, so make a separate sample buffer. */
- source->pub.buffer = (*cinfo->mem->alloc_sarray)
- ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (JDIMENSION) w * cinfo->input_components, (JDIMENSION) 1);
+ source->pub.buffer = (*cinfo->mem->alloc_sarray) ((j_common_ptr) cinfo,
+ JPOOL_IMAGE, (JDIMENSION) w * cinfo->input_components, (JDIMENSION) 1);
source->pub.buffer_height = 1;
}
@@ -461,7 +457,7 @@ start_input_ppm (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
/* On 16-bit-int machines we have to be careful of maxval = 65535 */
source->rescale = (JSAMPLE *) (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo,
- JPOOL_IMAGE, (size_t) (((long) maxval + 1L) * SIZEOF(JSAMPLE)));
+ JPOOL_IMAGE, ((size_t) maxval + (size_t) 1) * SIZEOF(JSAMPLE));
half_maxval = maxval / 2;
for (val = 0; val <= (INT32) maxval; val++) {
/* The multiplication here must be done in 32 bits to avoid overflow */
@@ -492,9 +488,8 @@ jinit_read_ppm (j_compress_ptr cinfo)
ppm_source_ptr source;
/* Create module interface object */
- source = (ppm_source_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(ppm_source_struct));
+ source = (ppm_source_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(ppm_source_struct));
/* Fill in method ptrs, except get_pixel_rows which start_input sets */
source->pub.start_input = start_input_ppm;
source->pub.finish_input = finish_input_ppm;
diff --git a/jpeg/rdrle.c b/jpeg/rdrle.c
index 542bc374..06f2e8aa 100644
--- a/jpeg/rdrle.c
+++ b/jpeg/rdrle.c
@@ -2,6 +2,7 @@
* rdrle.c
*
* Copyright (C) 1991-1996, Thomas G. Lane.
+ * Modified 2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -68,7 +69,7 @@ typedef struct _rle_source_struct {
jvirt_sarray_ptr image; /* virtual array to hold the image */
JDIMENSION row; /* current row # in the virtual array */
rle_hdr header; /* Input file information */
- rle_pixel** rle_row; /* holds a row returned by rle_getrow() */
+ rle_pixel **rle_row; /* holds a row returned by rle_getrow() */
} rle_source_struct;
@@ -95,19 +96,14 @@ start_input_rle (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
break;
case RLE_NOT_RLE:
ERREXIT(cinfo, JERR_RLE_NOT);
- break;
case RLE_NO_SPACE:
ERREXIT(cinfo, JERR_RLE_MEM);
- break;
case RLE_EMPTY:
ERREXIT(cinfo, JERR_RLE_EMPTY);
- break;
case RLE_EOF:
ERREXIT(cinfo, JERR_RLE_EOF);
- break;
default:
ERREXIT(cinfo, JERR_RLE_BADERROR);
- break;
}
/* Figure out what we have, set private vars and return values accordingly */
@@ -155,16 +151,15 @@ start_input_rle (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
* (GRAYSCALE scanlines don't need converting)
*/
if (source->visual != GRAYSCALE) {
- source->rle_row = (rle_pixel**) (*cinfo->mem->alloc_sarray)
+ source->rle_row = (rle_pixel **) (*cinfo->mem->alloc_sarray)
((j_common_ptr) cinfo, JPOOL_IMAGE,
- (JDIMENSION) width, (JDIMENSION) cinfo->input_components);
+ width, (JDIMENSION) cinfo->input_components);
}
/* request a virtual array to hold the image */
source->image = (*cinfo->mem->request_virt_sarray)
((j_common_ptr) cinfo, JPOOL_IMAGE, FALSE,
- (JDIMENSION) (width * source->header.ncolors),
- (JDIMENSION) height, (JDIMENSION) 1);
+ width * (JDIMENSION) source->header.ncolors, height, (JDIMENSION) 1);
#ifdef PROGRESS_REPORT
if (progress != NULL) {
@@ -242,7 +237,7 @@ load_image (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
{
rle_source_ptr source = (rle_source_ptr) sinfo;
JDIMENSION row, col;
- JSAMPROW scanline, red_ptr, green_ptr, blue_ptr;
+ JSAMPROW scanline, red_ptr, green_ptr, blue_ptr;
rle_pixel **rle_row;
rle_map *colormap;
char channel;
@@ -250,9 +245,6 @@ load_image (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
cd_progress_ptr progress = (cd_progress_ptr) cinfo->progress;
#endif
- colormap = source->header.cmap;
- rle_row = source->rle_row;
-
/* Read the RLE data into our virtual array.
* We assume here that (a) rle_pixel is represented the same as JSAMPLE,
* and (b) we are not on a machine where FAR pointers differ from regular.
@@ -273,12 +265,12 @@ load_image (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
case PSEUDOCOLOR:
for (row = 0; row < cinfo->image_height; row++) {
rle_row = (rle_pixel **) (*cinfo->mem->access_virt_sarray)
- ((j_common_ptr) cinfo, source->image, row, (JDIMENSION) 1, TRUE);
+ ((j_common_ptr) cinfo, source->image, row, (JDIMENSION) 1, TRUE);
rle_getrow(&source->header, rle_row);
#ifdef PROGRESS_REPORT
if (progress != NULL) {
- progress->pub.pass_counter++;
- (*progress->pub.progress_monitor) ((j_common_ptr) cinfo);
+ progress->pub.pass_counter++;
+ (*progress->pub.progress_monitor) ((j_common_ptr) cinfo);
}
#endif
}
@@ -286,48 +278,50 @@ load_image (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
case MAPPEDGRAY:
case TRUECOLOR:
+ rle_row = source->rle_row;
+ colormap = source->header.cmap;
for (row = 0; row < cinfo->image_height; row++) {
- scanline = * (*cinfo->mem->access_virt_sarray)
- ((j_common_ptr) cinfo, source->image, row, (JDIMENSION) 1, TRUE);
- rle_row = source->rle_row;
rle_getrow(&source->header, rle_row);
+ scanline = * (*cinfo->mem->access_virt_sarray)
+ ((j_common_ptr) cinfo, source->image, row, (JDIMENSION) 1, TRUE);
for (col = 0; col < cinfo->image_width; col++) {
- for (channel = 0; channel < source->header.ncolors; channel++) {
- *scanline++ = (JSAMPLE)
- (colormap[GETJSAMPLE(rle_row[channel][col]) + 256 * channel] >> 8);
- }
+ for (channel = 0; channel < source->header.ncolors; channel++) {
+ *scanline++ = (JSAMPLE)
+ (colormap[GETJSAMPLE(rle_row[channel][col]) + 256 * channel] >> 8);
+ }
}
#ifdef PROGRESS_REPORT
if (progress != NULL) {
- progress->pub.pass_counter++;
- (*progress->pub.progress_monitor) ((j_common_ptr) cinfo);
+ progress->pub.pass_counter++;
+ (*progress->pub.progress_monitor) ((j_common_ptr) cinfo);
}
#endif
}
break;
case DIRECTCOLOR:
+ rle_row = source->rle_row;
for (row = 0; row < cinfo->image_height; row++) {
- scanline = * (*cinfo->mem->access_virt_sarray)
- ((j_common_ptr) cinfo, source->image, row, (JDIMENSION) 1, TRUE);
rle_getrow(&source->header, rle_row);
+ scanline = * (*cinfo->mem->access_virt_sarray)
+ ((j_common_ptr) cinfo, source->image, row, (JDIMENSION) 1, TRUE);
red_ptr = rle_row[0];
green_ptr = rle_row[1];
blue_ptr = rle_row[2];
for (col = cinfo->image_width; col > 0; col--) {
- *scanline++ = *red_ptr++;
- *scanline++ = *green_ptr++;
- *scanline++ = *blue_ptr++;
+ *scanline++ = *red_ptr++;
+ *scanline++ = *green_ptr++;
+ *scanline++ = *blue_ptr++;
}
#ifdef PROGRESS_REPORT
if (progress != NULL) {
- progress->pub.pass_counter++;
- (*progress->pub.progress_monitor) ((j_common_ptr) cinfo);
+ progress->pub.pass_counter++;
+ (*progress->pub.progress_monitor) ((j_common_ptr) cinfo);
}
#endif
}
@@ -373,15 +367,14 @@ jinit_read_rle (j_compress_ptr cinfo)
rle_source_ptr source;
/* Create module interface object */
- source = (rle_source_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(rle_source_struct));
+ source = (rle_source_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(rle_source_struct));
/* Fill in method ptrs */
source->pub.start_input = start_input_rle;
source->pub.finish_input = finish_input_rle;
source->pub.get_pixel_rows = load_image;
- return (cjpeg_source_ptr) source;
+ return &source->pub;
}
#endif /* RLE_SUPPORTED */
diff --git a/jpeg/rdswitch.c b/jpeg/rdswitch.c
index b5aba83c..c0f7fed8 100644
--- a/jpeg/rdswitch.c
+++ b/jpeg/rdswitch.c
@@ -2,7 +2,7 @@
* rdswitch.c
*
* Copyright (C) 1991-1996, Thomas G. Lane.
- * Modified 2003-2015 by Guido Vollbeding.
+ * Modified 2003-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -249,9 +249,8 @@ bogus:
* NOTE: for cjpeg's use, JPOOL_IMAGE is the right lifetime for this data,
* but if you want to compress multiple images you'd want JPOOL_PERMANENT.
*/
- scanptr = (jpeg_scan_info *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- scanno * SIZEOF(jpeg_scan_info));
+ scanptr = (jpeg_scan_info *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, scanno * SIZEOF(jpeg_scan_info));
MEMCOPY(scanptr, scans, scanno * SIZEOF(jpeg_scan_info));
cinfo->scan_info = scanptr;
cinfo->num_scans = scanno;
diff --git a/jpeg/rdtarga.c b/jpeg/rdtarga.c
index b3a7251c..c72ad73f 100644
--- a/jpeg/rdtarga.c
+++ b/jpeg/rdtarga.c
@@ -2,7 +2,7 @@
* rdtarga.c
*
* Copyright (C) 1991-1996, Thomas G. Lane.
- * Modified 2017 by Guido Vollbeding.
+ * Modified 2017-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -29,11 +29,10 @@
typedef unsigned char U_CHAR;
#define UCH(x) ((int) (x))
#else /* !HAVE_UNSIGNED_CHAR */
-#ifdef CHAR_IS_UNSIGNED
typedef char U_CHAR;
+#ifdef CHAR_IS_UNSIGNED
#define UCH(x) ((int) (x))
#else
-typedef char U_CHAR;
#define UCH(x) ((int) (x) & 0xFF)
#endif
#endif /* HAVE_UNSIGNED_CHAR */
@@ -125,20 +124,17 @@ METHODDEF(void)
read_non_rle_pixel (tga_source_ptr sinfo)
/* Read one Targa pixel from the input file; no RLE expansion */
{
- register FILE *infile = sinfo->pub.input_file;
register int i;
for (i = 0; i < sinfo->pixel_size; i++) {
- sinfo->tga_pixel[i] = (U_CHAR) getc(infile);
+ sinfo->tga_pixel[i] = (U_CHAR) read_byte(sinfo);
}
}
-
METHODDEF(void)
read_rle_pixel (tga_source_ptr sinfo)
/* Read one Targa pixel from the input file, expanding RLE data as needed */
{
- register FILE *infile = sinfo->pub.input_file;
register int i;
/* Duplicate previously read pixel? */
@@ -160,7 +156,7 @@ read_rle_pixel (tga_source_ptr sinfo)
/* Read next pixel */
for (i = 0; i < sinfo->pixel_size; i++) {
- sinfo->tga_pixel[i] = (U_CHAR) getc(infile);
+ sinfo->tga_pixel[i] = (U_CHAR) read_byte(sinfo);
}
}
@@ -171,7 +167,6 @@ read_rle_pixel (tga_source_ptr sinfo)
* We provide several different versions depending on input file format.
*/
-
METHODDEF(JDIMENSION)
get_8bit_gray_row (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
/* This version is for reading 8-bit grayscale pixels */
@@ -288,9 +283,8 @@ get_memory_row (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
source_row = cinfo->image_height - source->current_row - 1;
/* Fetch that row from virtual array */
- source->pub.buffer = (*cinfo->mem->access_virt_sarray)
- ((j_common_ptr) cinfo, source->whole_image,
- source_row, (JDIMENSION) 1, FALSE);
+ source->pub.buffer = (*cinfo->mem->access_virt_sarray) ((j_common_ptr) cinfo,
+ source->whole_image, source_row, (JDIMENSION) 1, FALSE);
source->current_row++;
return 1;
@@ -409,7 +403,6 @@ start_input_tga (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
break;
default:
ERREXIT(cinfo, JERR_TGA_BADPARMS);
- break;
}
TRACEMS2(cinfo, 1, JTRC_TGA, width, height);
break;
@@ -424,7 +417,6 @@ start_input_tga (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
break;
default:
ERREXIT(cinfo, JERR_TGA_BADPARMS);
- break;
}
if (is_bottom_up) {
@@ -442,9 +434,8 @@ start_input_tga (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
} else {
/* Don't need a virtual array, but do need a one-row input buffer. */
source->whole_image = NULL;
- source->pub.buffer = (*cinfo->mem->alloc_sarray)
- ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (JDIMENSION) width * components, (JDIMENSION) 1);
+ source->pub.buffer = (*cinfo->mem->alloc_sarray) ((j_common_ptr) cinfo,
+ JPOOL_IMAGE, (JDIMENSION) width * components, (JDIMENSION) 1);
source->pub.buffer_height = 1;
source->pub.get_pixel_rows = source->get_pixel_rows;
}
@@ -456,8 +447,8 @@ start_input_tga (j_compress_ptr cinfo, cjpeg_source_ptr sinfo)
if (maplen > 256 || GET_2B(3) != 0)
ERREXIT(cinfo, JERR_TGA_BADCMAP);
/* Allocate space to store the colormap */
- source->colormap = (*cinfo->mem->alloc_sarray)
- ((j_common_ptr) cinfo, JPOOL_IMAGE, (JDIMENSION) maplen, (JDIMENSION) 3);
+ source->colormap = (*cinfo->mem->alloc_sarray) ((j_common_ptr) cinfo,
+ JPOOL_IMAGE, (JDIMENSION) maplen, (JDIMENSION) 3);
source->cmap_length = (int) maplen;
/* and read it from the file */
read_colormap(source, (int) maplen, UCH(targaheader[7]));
@@ -496,9 +487,8 @@ jinit_read_targa (j_compress_ptr cinfo)
tga_source_ptr source;
/* Create module interface object */
- source = (tga_source_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(tga_source_struct));
+ source = (tga_source_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(tga_source_struct));
source->cinfo = cinfo; /* make back link for subroutines */
/* Fill in method ptrs, except get_pixel_rows which start_input sets */
source->pub.start_input = start_input_tga;
diff --git a/jpeg/testimg.gif b/jpeg/testimg.gif
new file mode 100644
index 00000000..f4dcf923
--- /dev/null
+++ b/jpeg/testimg.gif
Binary files differ
diff --git a/jpeg/testimgp.jpg b/jpeg/testimgp.jpg
index ca6acad1..7dc62509 100644
--- a/jpeg/testimgp.jpg
+++ b/jpeg/testimgp.jpg
Binary files differ
diff --git a/jpeg/transupp.c b/jpeg/transupp.c
index d10f57b4..7ee74ef4 100644
--- a/jpeg/transupp.c
+++ b/jpeg/transupp.c
@@ -1,7 +1,7 @@
/*
* transupp.c
*
- * Copyright (C) 1997-2017, Thomas G. Lane, Guido Vollbeding.
+ * Copyright (C) 1997-2019, Thomas G. Lane, Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -14,6 +14,8 @@
/* Although this file really shouldn't have access to the library internals,
* it's helpful to let it call jround_up() and jcopy_block_row().
+ * Also, the (switchable) virtual memory adaptation code for
+ * the drop feature has dependencies on library internals.
*/
#define JPEG_INTERNALS
@@ -75,6 +77,274 @@
*/
+/* Drop code may be used with or without virtual memory adaptation code.
+ * This code has some dependencies on internal library behavior, so you
+ * may choose to disable it. For example, it doesn't make a difference
+ * if you only use jmemnobs anyway.
+ */
+#ifndef DROP_REQUEST_FROM_SRC
+#define DROP_REQUEST_FROM_SRC 1 /* 0 disables adaptation */
+#endif
+
+
+#if DROP_REQUEST_FROM_SRC
+/* Force jpeg_read_coefficients to request
+ * the virtual coefficient arrays from
+ * the source decompression object.
+ */
+METHODDEF(jvirt_barray_ptr)
+drop_request_virt_barray (j_common_ptr cinfo, int pool_id, boolean pre_zero,
+ JDIMENSION blocksperrow, JDIMENSION numrows,
+ JDIMENSION maxaccess)
+{
+ j_common_ptr srcinfo = (j_common_ptr) cinfo->client_data;
+
+ return (*srcinfo->mem->request_virt_barray)
+ (srcinfo, pool_id, pre_zero,
+ blocksperrow, numrows, maxaccess);
+}
+
+
+/* Force jpeg_read_coefficients to return
+ * after requesting and before accessing
+ * the virtual coefficient arrays.
+ */
+METHODDEF(int)
+drop_consume_input (j_decompress_ptr cinfo)
+{
+ return JPEG_SUSPENDED;
+}
+
+
+METHODDEF(void)
+drop_start_input_pass (j_decompress_ptr cinfo)
+{
+ cinfo->inputctl->consume_input = drop_consume_input;
+}
+
+
+LOCAL(void)
+drop_request_from_src (j_decompress_ptr dropinfo, j_decompress_ptr srcinfo)
+{
+ void *save_client_data;
+ JMETHOD(jvirt_barray_ptr, save_request_virt_barray,
+ (j_common_ptr cinfo, int pool_id, boolean pre_zero,
+ JDIMENSION blocksperrow, JDIMENSION numrows, JDIMENSION maxaccess));
+ JMETHOD(void, save_start_input_pass, (j_decompress_ptr cinfo));
+
+ /* Set custom method pointers, save original pointers */
+ save_client_data = dropinfo->client_data;
+ dropinfo->client_data = (void *) srcinfo;
+ save_request_virt_barray = dropinfo->mem->request_virt_barray;
+ dropinfo->mem->request_virt_barray = drop_request_virt_barray;
+ save_start_input_pass = dropinfo->inputctl->start_input_pass;
+ dropinfo->inputctl->start_input_pass = drop_start_input_pass;
+
+ /* Execute only initialization part.
+ * Requested coefficient arrays will be realized later by the srcinfo object.
+ * Next call to the same function will then do the actual data reading.
+ * NB: since we request the coefficient arrays from another object,
+ * the inherent realization call is effectively a no-op.
+ */
+ (void) jpeg_read_coefficients(dropinfo);
+
+ /* Reset method pointers */
+ dropinfo->client_data = save_client_data;
+ dropinfo->mem->request_virt_barray = save_request_virt_barray;
+ dropinfo->inputctl->start_input_pass = save_start_input_pass;
+ /* Do input initialization for first scan now,
+ * which also resets the consume_input method.
+ */
+ (*save_start_input_pass)(dropinfo);
+}
+#endif /* DROP_REQUEST_FROM_SRC */
+
+
+LOCAL(void)
+dequant_comp (j_decompress_ptr cinfo, jpeg_component_info *compptr,
+ jvirt_barray_ptr coef_array, JQUANT_TBL *qtblptr1)
+{
+ JDIMENSION blk_x, blk_y;
+ int offset_y, k;
+ JQUANT_TBL *qtblptr;
+ JBLOCKARRAY buffer;
+ JBLOCKROW block;
+ JCOEFPTR ptr;
+
+ qtblptr = compptr->quant_table;
+ for (blk_y = 0; blk_y < compptr->height_in_blocks;
+ blk_y += compptr->v_samp_factor) {
+ buffer = (*cinfo->mem->access_virt_barray)
+ ((j_common_ptr) cinfo, coef_array, blk_y,
+ (JDIMENSION) compptr->v_samp_factor, TRUE);
+ for (offset_y = 0; offset_y < compptr->v_samp_factor; offset_y++) {
+ block = buffer[offset_y];
+ for (blk_x = 0; blk_x < compptr->width_in_blocks; blk_x++) {
+ ptr = block[blk_x];
+ for (k = 0; k < DCTSIZE2; k++)
+ if (qtblptr->quantval[k] != qtblptr1->quantval[k])
+ ptr[k] *= qtblptr->quantval[k] / qtblptr1->quantval[k];
+ }
+ }
+ }
+}
+
+
+LOCAL(void)
+requant_comp (j_decompress_ptr cinfo, jpeg_component_info *compptr,
+ jvirt_barray_ptr coef_array, JQUANT_TBL *qtblptr1)
+{
+ JDIMENSION blk_x, blk_y;
+ int offset_y, k;
+ JQUANT_TBL *qtblptr;
+ JBLOCKARRAY buffer;
+ JBLOCKROW block;
+ JCOEFPTR ptr;
+ JCOEF temp, qval;
+
+ qtblptr = compptr->quant_table;
+ for (blk_y = 0; blk_y < compptr->height_in_blocks;
+ blk_y += compptr->v_samp_factor) {
+ buffer = (*cinfo->mem->access_virt_barray)
+ ((j_common_ptr) cinfo, coef_array, blk_y,
+ (JDIMENSION) compptr->v_samp_factor, TRUE);
+ for (offset_y = 0; offset_y < compptr->v_samp_factor; offset_y++) {
+ block = buffer[offset_y];
+ for (blk_x = 0; blk_x < compptr->width_in_blocks; blk_x++) {
+ ptr = block[blk_x];
+ for (k = 0; k < DCTSIZE2; k++) {
+ temp = qtblptr->quantval[k];
+ qval = qtblptr1->quantval[k];
+ if (temp != qval) {
+ temp *= ptr[k];
+ /* The following quantization code is a copy from jcdctmgr.c */
+#ifdef FAST_DIVIDE
+#define DIVIDE_BY(a,b) a /= b
+#else
+#define DIVIDE_BY(a,b) if (a >= b) a /= b; else a = 0
+#endif
+ if (temp < 0) {
+ temp = -temp;
+ temp += qval>>1; /* for rounding */
+ DIVIDE_BY(temp, qval);
+ temp = -temp;
+ } else {
+ temp += qval>>1; /* for rounding */
+ DIVIDE_BY(temp, qval);
+ }
+ ptr[k] = temp;
+ }
+ }
+ }
+ }
+ }
+}
+
+
+/* Calculate largest common denominator with Euclid's algorithm.
+ */
+LOCAL(JCOEF)
+largest_common_denominator(JCOEF a, JCOEF b)
+{
+ JCOEF c;
+
+ do {
+ c = a % b;
+ a = b;
+ b = c;
+ } while (c);
+
+ return a;
+}
+
+
+LOCAL(void)
+adjust_quant(j_decompress_ptr srcinfo, jvirt_barray_ptr *src_coef_arrays,
+ j_decompress_ptr dropinfo, jvirt_barray_ptr *drop_coef_arrays,
+ boolean trim, j_compress_ptr dstinfo)
+{
+ jpeg_component_info *compptr1, *compptr2;
+ JQUANT_TBL *qtblptr1, *qtblptr2, *qtblptr3;
+ int ci, k;
+
+ for (ci = 0; ci < dstinfo->num_components &&
+ ci < dropinfo->num_components; ci++) {
+ compptr1 = srcinfo->comp_info + ci;
+ compptr2 = dropinfo->comp_info + ci;
+ qtblptr1 = compptr1->quant_table;
+ qtblptr2 = compptr2->quant_table;
+ for (k = 0; k < DCTSIZE2; k++) {
+ if (qtblptr1->quantval[k] != qtblptr2->quantval[k]) {
+ if (trim)
+ requant_comp(dropinfo, compptr2, drop_coef_arrays[ci], qtblptr1);
+ else {
+ qtblptr3 = dstinfo->quant_tbl_ptrs[compptr1->quant_tbl_no];
+ for (k = 0; k < DCTSIZE2; k++)
+ if (qtblptr1->quantval[k] != qtblptr2->quantval[k])
+ qtblptr3->quantval[k] = largest_common_denominator
+ (qtblptr1->quantval[k], qtblptr2->quantval[k]);
+ dequant_comp(srcinfo, compptr1, src_coef_arrays[ci], qtblptr3);
+ dequant_comp(dropinfo, compptr2, drop_coef_arrays[ci], qtblptr3);
+ }
+ break;
+ }
+ }
+ }
+}
+
+
+LOCAL(void)
+do_drop (j_decompress_ptr srcinfo, j_compress_ptr dstinfo,
+ JDIMENSION x_crop_offset, JDIMENSION y_crop_offset,
+ jvirt_barray_ptr *src_coef_arrays,
+ j_decompress_ptr dropinfo, jvirt_barray_ptr *drop_coef_arrays,
+ JDIMENSION drop_width, JDIMENSION drop_height)
+/* Drop. If the dropinfo component number is smaller than the destination's,
+ * we fill in the remaining components with zero. This provides the feature
+ * of dropping grayscale into (arbitrarily sampled) color images.
+ */
+{
+ JDIMENSION comp_width, comp_height;
+ JDIMENSION blk_y, x_drop_blocks, y_drop_blocks;
+ int ci, offset_y;
+ JBLOCKARRAY src_buffer, dst_buffer;
+ jpeg_component_info *compptr;
+
+ for (ci = 0; ci < dstinfo->num_components; ci++) {
+ compptr = dstinfo->comp_info + ci;
+ comp_width = drop_width * compptr->h_samp_factor;
+ comp_height = drop_height * compptr->v_samp_factor;
+ x_drop_blocks = x_crop_offset * compptr->h_samp_factor;
+ y_drop_blocks = y_crop_offset * compptr->v_samp_factor;
+ for (blk_y = 0; blk_y < comp_height; blk_y += compptr->v_samp_factor) {
+ dst_buffer = (*srcinfo->mem->access_virt_barray)
+ ((j_common_ptr) srcinfo, src_coef_arrays[ci], blk_y + y_drop_blocks,
+ (JDIMENSION) compptr->v_samp_factor, TRUE);
+ if (ci < dropinfo->num_components) {
+#if DROP_REQUEST_FROM_SRC
+ src_buffer = (*srcinfo->mem->access_virt_barray)
+ ((j_common_ptr) srcinfo, drop_coef_arrays[ci], blk_y,
+#else
+ src_buffer = (*dropinfo->mem->access_virt_barray)
+ ((j_common_ptr) dropinfo, drop_coef_arrays[ci], blk_y,
+#endif
+ (JDIMENSION) compptr->v_samp_factor, FALSE);
+ for (offset_y = 0; offset_y < compptr->v_samp_factor; offset_y++) {
+ jcopy_block_row(src_buffer[offset_y],
+ dst_buffer[offset_y] + x_drop_blocks,
+ comp_width);
+ }
+ } else {
+ for (offset_y = 0; offset_y < compptr->v_samp_factor; offset_y++) {
+ FMEMZERO(dst_buffer[offset_y] + x_drop_blocks,
+ comp_width * SIZEOF(JBLOCK));
+ }
+ }
+ }
+ }
+}
+
+
LOCAL(void)
do_crop (j_decompress_ptr srcinfo, j_compress_ptr dstinfo,
JDIMENSION x_crop_offset, JDIMENSION y_crop_offset,
@@ -114,10 +384,10 @@ do_crop (j_decompress_ptr srcinfo, j_compress_ptr dstinfo,
LOCAL(void)
-do_crop_ext (j_decompress_ptr srcinfo, j_compress_ptr dstinfo,
- JDIMENSION x_crop_offset, JDIMENSION y_crop_offset,
- jvirt_barray_ptr *src_coef_arrays,
- jvirt_barray_ptr *dst_coef_arrays)
+do_crop_ext_zero (j_decompress_ptr srcinfo, j_compress_ptr dstinfo,
+ JDIMENSION x_crop_offset, JDIMENSION y_crop_offset,
+ jvirt_barray_ptr *src_coef_arrays,
+ jvirt_barray_ptr *dst_coef_arrays)
/* Crop. This is only used when no rotate/flip is requested with the crop.
* Extension: If the destination size is larger than the source, we fill in
* the extra area with zero (neutral gray). Note we also have to zero partial
@@ -148,7 +418,7 @@ do_crop_ext (j_decompress_ptr srcinfo, j_compress_ptr dstinfo,
(JDIMENSION) compptr->v_samp_factor, TRUE);
if (dstinfo->jpeg_height > srcinfo->output_height) {
if (dst_blk_y < y_crop_blocks ||
- dst_blk_y >= comp_height + y_crop_blocks) {
+ dst_blk_y >= y_crop_blocks + comp_height) {
for (offset_y = 0; offset_y < compptr->v_samp_factor; offset_y++) {
FMEMZERO(dst_buffer[offset_y],
compptr->width_in_blocks * SIZEOF(JBLOCK));
@@ -174,11 +444,11 @@ do_crop_ext (j_decompress_ptr srcinfo, j_compress_ptr dstinfo,
jcopy_block_row(src_buffer[offset_y],
dst_buffer[offset_y] + x_crop_blocks,
comp_width);
- if (compptr->width_in_blocks > comp_width + x_crop_blocks) {
+ if (compptr->width_in_blocks > x_crop_blocks + comp_width) {
FMEMZERO(dst_buffer[offset_y] +
- comp_width + x_crop_blocks,
+ x_crop_blocks + comp_width,
(compptr->width_in_blocks -
- comp_width - x_crop_blocks) * SIZEOF(JBLOCK));
+ x_crop_blocks - comp_width) * SIZEOF(JBLOCK));
}
} else {
jcopy_block_row(src_buffer[offset_y] + x_crop_blocks,
@@ -192,6 +462,190 @@ do_crop_ext (j_decompress_ptr srcinfo, j_compress_ptr dstinfo,
LOCAL(void)
+do_crop_ext_flat (j_decompress_ptr srcinfo, j_compress_ptr dstinfo,
+ JDIMENSION x_crop_offset, JDIMENSION y_crop_offset,
+ jvirt_barray_ptr *src_coef_arrays,
+ jvirt_barray_ptr *dst_coef_arrays)
+/* Crop. This is only used when no rotate/flip is requested with the crop.
+ * Extension: The destination width is larger than the source and we fill in
+ * the extra area with the DC of the adjacent block. Note we also have to
+ * fill partial iMCUs at the right and bottom edge of the source image area
+ * in this case.
+ */
+{
+ JDIMENSION MCU_cols, MCU_rows, comp_width, comp_height;
+ JDIMENSION dst_blk_x, dst_blk_y, x_crop_blocks, y_crop_blocks;
+ int ci, offset_y;
+ JCOEF dc;
+ JBLOCKARRAY src_buffer, dst_buffer;
+ jpeg_component_info *compptr;
+
+ MCU_cols = srcinfo->output_width /
+ (dstinfo->max_h_samp_factor * dstinfo->min_DCT_h_scaled_size);
+ MCU_rows = srcinfo->output_height /
+ (dstinfo->max_v_samp_factor * dstinfo->min_DCT_v_scaled_size);
+
+ for (ci = 0; ci < dstinfo->num_components; ci++) {
+ compptr = dstinfo->comp_info + ci;
+ comp_width = MCU_cols * compptr->h_samp_factor;
+ comp_height = MCU_rows * compptr->v_samp_factor;
+ x_crop_blocks = x_crop_offset * compptr->h_samp_factor;
+ y_crop_blocks = y_crop_offset * compptr->v_samp_factor;
+ for (dst_blk_y = 0; dst_blk_y < compptr->height_in_blocks;
+ dst_blk_y += compptr->v_samp_factor) {
+ dst_buffer = (*srcinfo->mem->access_virt_barray)
+ ((j_common_ptr) srcinfo, dst_coef_arrays[ci], dst_blk_y,
+ (JDIMENSION) compptr->v_samp_factor, TRUE);
+ if (dstinfo->jpeg_height > srcinfo->output_height) {
+ if (dst_blk_y < y_crop_blocks ||
+ dst_blk_y >= y_crop_blocks + comp_height) {
+ for (offset_y = 0; offset_y < compptr->v_samp_factor; offset_y++) {
+ FMEMZERO(dst_buffer[offset_y],
+ compptr->width_in_blocks * SIZEOF(JBLOCK));
+ }
+ continue;
+ }
+ src_buffer = (*srcinfo->mem->access_virt_barray)
+ ((j_common_ptr) srcinfo, src_coef_arrays[ci],
+ dst_blk_y - y_crop_blocks,
+ (JDIMENSION) compptr->v_samp_factor, FALSE);
+ } else {
+ src_buffer = (*srcinfo->mem->access_virt_barray)
+ ((j_common_ptr) srcinfo, src_coef_arrays[ci],
+ dst_blk_y + y_crop_blocks,
+ (JDIMENSION) compptr->v_samp_factor, FALSE);
+ }
+ for (offset_y = 0; offset_y < compptr->v_samp_factor; offset_y++) {
+ if (x_crop_blocks > 0) {
+ FMEMZERO(dst_buffer[offset_y],
+ x_crop_blocks * SIZEOF(JBLOCK));
+ dc = src_buffer[offset_y][0][0];
+ for (dst_blk_x = 0; dst_blk_x < x_crop_blocks; dst_blk_x++) {
+ dst_buffer[offset_y][dst_blk_x][0] = dc;
+ }
+ }
+ jcopy_block_row(src_buffer[offset_y],
+ dst_buffer[offset_y] + x_crop_blocks,
+ comp_width);
+ if (compptr->width_in_blocks > x_crop_blocks + comp_width) {
+ FMEMZERO(dst_buffer[offset_y] +
+ x_crop_blocks + comp_width,
+ (compptr->width_in_blocks -
+ x_crop_blocks - comp_width) * SIZEOF(JBLOCK));
+ dc = src_buffer[offset_y][comp_width - 1][0];
+ for (dst_blk_x = x_crop_blocks + comp_width;
+ dst_blk_x < compptr->width_in_blocks; dst_blk_x++) {
+ dst_buffer[offset_y][dst_blk_x][0] = dc;
+ }
+ }
+ }
+ }
+ }
+}
+
+
+LOCAL(void)
+do_crop_ext_reflect (j_decompress_ptr srcinfo, j_compress_ptr dstinfo,
+ JDIMENSION x_crop_offset, JDIMENSION y_crop_offset,
+ jvirt_barray_ptr *src_coef_arrays,
+ jvirt_barray_ptr *dst_coef_arrays)
+/* Crop. This is only used when no rotate/flip is requested with the crop.
+ * Extension: The destination width is larger than the source and we fill in
+ * the extra area with repeated reflections of the source region. Note we
+ * also have to fill partial iMCUs at the right and bottom edge of the source
+ * image area in this case.
+ */
+{
+ JDIMENSION MCU_cols, MCU_rows, comp_width, comp_height, src_blk_x;
+ JDIMENSION dst_blk_x, dst_blk_y, x_crop_blocks, y_crop_blocks;
+ int ci, k, offset_y;
+ JBLOCKARRAY src_buffer, dst_buffer;
+ JBLOCKROW src_row_ptr, dst_row_ptr;
+ JCOEFPTR src_ptr, dst_ptr;
+ jpeg_component_info *compptr;
+
+ MCU_cols = srcinfo->output_width /
+ (dstinfo->max_h_samp_factor * dstinfo->min_DCT_h_scaled_size);
+ MCU_rows = srcinfo->output_height /
+ (dstinfo->max_v_samp_factor * dstinfo->min_DCT_v_scaled_size);
+
+ for (ci = 0; ci < dstinfo->num_components; ci++) {
+ compptr = dstinfo->comp_info + ci;
+ comp_width = MCU_cols * compptr->h_samp_factor;
+ comp_height = MCU_rows * compptr->v_samp_factor;
+ x_crop_blocks = x_crop_offset * compptr->h_samp_factor;
+ y_crop_blocks = y_crop_offset * compptr->v_samp_factor;
+ for (dst_blk_y = 0; dst_blk_y < compptr->height_in_blocks;
+ dst_blk_y += compptr->v_samp_factor) {
+ dst_buffer = (*srcinfo->mem->access_virt_barray)
+ ((j_common_ptr) srcinfo, dst_coef_arrays[ci], dst_blk_y,
+ (JDIMENSION) compptr->v_samp_factor, TRUE);
+ if (dstinfo->jpeg_height > srcinfo->output_height) {
+ if (dst_blk_y < y_crop_blocks ||
+ dst_blk_y >= y_crop_blocks + comp_height) {
+ for (offset_y = 0; offset_y < compptr->v_samp_factor; offset_y++) {
+ FMEMZERO(dst_buffer[offset_y],
+ compptr->width_in_blocks * SIZEOF(JBLOCK));
+ }
+ continue;
+ }
+ src_buffer = (*srcinfo->mem->access_virt_barray)
+ ((j_common_ptr) srcinfo, src_coef_arrays[ci],
+ dst_blk_y - y_crop_blocks,
+ (JDIMENSION) compptr->v_samp_factor, FALSE);
+ } else {
+ src_buffer = (*srcinfo->mem->access_virt_barray)
+ ((j_common_ptr) srcinfo, src_coef_arrays[ci],
+ dst_blk_y + y_crop_blocks,
+ (JDIMENSION) compptr->v_samp_factor, FALSE);
+ }
+ for (offset_y = 0; offset_y < compptr->v_samp_factor; offset_y++) {
+ /* Copy source region */
+ jcopy_block_row(src_buffer[offset_y],
+ dst_buffer[offset_y] + x_crop_blocks,
+ comp_width);
+ if (x_crop_blocks > 0) {
+ /* Reflect to left */
+ dst_row_ptr = dst_buffer[offset_y] + x_crop_blocks;
+ for (dst_blk_x = x_crop_blocks; dst_blk_x > 0;) {
+ src_row_ptr = dst_row_ptr; /* (re)set axis of reflection */
+ for (src_blk_x = comp_width; src_blk_x > 0 && dst_blk_x > 0;
+ src_blk_x--, dst_blk_x--) {
+ dst_ptr = *--dst_row_ptr; /* destination goes left */
+ src_ptr = *src_row_ptr++; /* source goes right */
+ /* this unrolled loop doesn't need to know which row it's on... */
+ for (k = 0; k < DCTSIZE2; k += 2) {
+ *dst_ptr++ = *src_ptr++; /* copy even column */
+ *dst_ptr++ = - *src_ptr++; /* copy odd column with sign change */
+ }
+ }
+ }
+ }
+ if (compptr->width_in_blocks > x_crop_blocks + comp_width) {
+ /* Reflect to right */
+ dst_row_ptr = dst_buffer[offset_y] + x_crop_blocks + comp_width;
+ for (dst_blk_x = compptr->width_in_blocks - x_crop_blocks - comp_width;
+ dst_blk_x > 0;) {
+ src_row_ptr = dst_row_ptr; /* (re)set axis of reflection */
+ for (src_blk_x = comp_width; src_blk_x > 0 && dst_blk_x > 0;
+ src_blk_x--, dst_blk_x--) {
+ dst_ptr = *dst_row_ptr++; /* destination goes right */
+ src_ptr = *--src_row_ptr; /* source goes left */
+ /* this unrolled loop doesn't need to know which row it's on... */
+ for (k = 0; k < DCTSIZE2; k += 2) {
+ *dst_ptr++ = *src_ptr++; /* copy even column */
+ *dst_ptr++ = - *src_ptr++; /* copy odd column with sign change */
+ }
+ }
+ }
+ }
+ }
+ }
+ }
+}
+
+
+LOCAL(void)
do_wipe (j_decompress_ptr srcinfo, j_compress_ptr dstinfo,
JDIMENSION x_crop_offset, JDIMENSION y_crop_offset,
jvirt_barray_ptr *src_coef_arrays,
@@ -275,6 +729,78 @@ do_flatten (j_decompress_ptr srcinfo, j_compress_ptr dstinfo,
LOCAL(void)
+do_reflect (j_decompress_ptr srcinfo, j_compress_ptr dstinfo,
+ JDIMENSION x_crop_offset,
+ jvirt_barray_ptr *src_coef_arrays,
+ JDIMENSION drop_width, JDIMENSION drop_height)
+/* Reflect - drop content of specified area, similar to wipe, but
+ * fill with repeated reflections of the outside area, instead of zero.
+ * NB: y_crop_offset is assumed to be zero.
+ */
+{
+ JDIMENSION x_wipe_blocks, wipe_width;
+ JDIMENSION y_wipe_blocks, wipe_bottom;
+ JDIMENSION src_blk_x, dst_blk_x;
+ int ci, k, offset_y;
+ JBLOCKARRAY buffer;
+ JBLOCKROW src_row_ptr, dst_row_ptr;
+ JCOEFPTR src_ptr, dst_ptr;
+ jpeg_component_info *compptr;
+
+ for (ci = 0; ci < dstinfo->num_components; ci++) {
+ compptr = dstinfo->comp_info + ci;
+ x_wipe_blocks = x_crop_offset * compptr->h_samp_factor;
+ wipe_width = drop_width * compptr->h_samp_factor;
+ wipe_bottom = drop_height * compptr->v_samp_factor;
+ for (y_wipe_blocks = 0; y_wipe_blocks < wipe_bottom;
+ y_wipe_blocks += compptr->v_samp_factor) {
+ buffer = (*srcinfo->mem->access_virt_barray)
+ ((j_common_ptr) srcinfo, src_coef_arrays[ci], y_wipe_blocks,
+ (JDIMENSION) compptr->v_samp_factor, TRUE);
+ for (offset_y = 0; offset_y < compptr->v_samp_factor; offset_y++) {
+ if (x_wipe_blocks > 0) {
+ /* Reflect from left */
+ dst_row_ptr = buffer[offset_y] + x_wipe_blocks;
+ for (dst_blk_x = wipe_width; dst_blk_x > 0;) {
+ src_row_ptr = dst_row_ptr; /* (re)set axis of reflection */
+ for (src_blk_x = x_wipe_blocks;
+ src_blk_x > 0 && dst_blk_x > 0; src_blk_x--, dst_blk_x--) {
+ dst_ptr = *dst_row_ptr++; /* destination goes right */
+ src_ptr = *--src_row_ptr; /* source goes left */
+ /* this unrolled loop doesn't need to know which row it's on... */
+ for (k = 0; k < DCTSIZE2; k += 2) {
+ *dst_ptr++ = *src_ptr++; /* copy even column */
+ *dst_ptr++ = - *src_ptr++; /* copy odd column with sign change */
+ }
+ }
+ }
+ } else if (compptr->width_in_blocks > x_wipe_blocks + wipe_width) {
+ /* Reflect from right */
+ dst_row_ptr = buffer[offset_y] + x_wipe_blocks + wipe_width;
+ for (dst_blk_x = wipe_width; dst_blk_x > 0;) {
+ src_row_ptr = dst_row_ptr; /* (re)set axis of reflection */
+ src_blk_x = compptr->width_in_blocks - x_wipe_blocks - wipe_width;
+ for (; src_blk_x > 0 && dst_blk_x > 0; src_blk_x--, dst_blk_x--) {
+ dst_ptr = *--dst_row_ptr; /* destination goes left */
+ src_ptr = *src_row_ptr++; /* source goes right */
+ /* this unrolled loop doesn't need to know which row it's on... */
+ for (k = 0; k < DCTSIZE2; k += 2) {
+ *dst_ptr++ = *src_ptr++; /* copy even column */
+ *dst_ptr++ = - *src_ptr++; /* copy odd column with sign change */
+ }
+ }
+ }
+ } else {
+ FMEMZERO(buffer[offset_y] + x_wipe_blocks,
+ wipe_width * SIZEOF(JBLOCK));
+ }
+ }
+ }
+ }
+}
+
+
+LOCAL(void)
do_flip_h_no_crop (j_decompress_ptr srcinfo, j_compress_ptr dstinfo,
JDIMENSION x_crop_offset,
jvirt_barray_ptr *src_coef_arrays)
@@ -932,7 +1458,7 @@ jt_read_integer (const char ** strptr, JDIMENSION * result)
* The routine returns TRUE if the spec string is valid, FALSE if not.
*
* The crop spec string should have the format
- * <width>[f]x<height>[f]{+-}<xoffset>{+-}<yoffset>
+ * <width>[{fr}]x<height>[{fr}]{+-}<xoffset>{+-}<yoffset>
* where width, height, xoffset, and yoffset are unsigned integers.
* Each of the elements can be omitted to indicate a default value.
* (A weakness of this style is that it is not possible to omit xoffset
@@ -957,6 +1483,9 @@ jtransform_parse_crop_spec (jpeg_transform_info *info, const char *spec)
if (*spec == 'f' || *spec == 'F') {
spec++;
info->crop_width_set = JCROP_FORCE;
+ } else if (*spec == 'r' || *spec == 'R') {
+ spec++;
+ info->crop_width_set = JCROP_REFLECT;
} else
info->crop_width_set = JCROP_POS;
}
@@ -968,6 +1497,9 @@ jtransform_parse_crop_spec (jpeg_transform_info *info, const char *spec)
if (*spec == 'f' || *spec == 'F') {
spec++;
info->crop_height_set = JCROP_FORCE;
+ } else if (*spec == 'r' || *spec == 'R') {
+ spec++;
+ info->crop_height_set = JCROP_REFLECT;
} else
info->crop_height_set = JCROP_POS;
}
@@ -1042,10 +1574,10 @@ jtransform_request_workspace (j_decompress_ptr srcinfo,
jvirt_barray_ptr *coef_arrays;
boolean need_workspace, transpose_it;
jpeg_component_info *compptr;
- JDIMENSION xoffset, yoffset;
+ JDIMENSION xoffset, yoffset, dtemp;
JDIMENSION width_in_iMCUs, height_in_iMCUs;
JDIMENSION width_in_blocks, height_in_blocks;
- int ci, h_samp_factor, v_samp_factor;
+ int itemp, ci, h_samp_factor, v_samp_factor;
/* Determine number of components in output image */
if (info->force_grayscale &&
@@ -1115,7 +1647,6 @@ jtransform_request_workspace (j_decompress_ptr srcinfo,
info->iMCU_sample_height =
srcinfo->max_v_samp_factor * srcinfo->min_DCT_v_scaled_size;
}
- break;
}
/* If cropping has been requested, compute the crop area's position and
@@ -1179,7 +1710,54 @@ jtransform_request_workspace (j_decompress_ptr srcinfo,
else
yoffset = info->output_height - info->crop_height - info->crop_yoffset;
/* Now adjust so that upper left corner falls at an iMCU boundary */
- if (info->transform == JXFORM_WIPE) {
+ switch (info->transform) {
+ case JXFORM_DROP:
+ /* Ensure the effective drop region will not exceed the requested */
+ itemp = info->iMCU_sample_width;
+ dtemp = itemp - 1 - ((xoffset + itemp - 1) % itemp);
+ xoffset += dtemp;
+ if (info->crop_width <= dtemp)
+ info->drop_width = 0;
+ else if (xoffset + info->crop_width - dtemp == info->output_width)
+ /* Matching right edge: include partial iMCU */
+ info->drop_width = (info->crop_width - dtemp + itemp - 1) / itemp;
+ else
+ info->drop_width = (info->crop_width - dtemp) / itemp;
+ itemp = info->iMCU_sample_height;
+ dtemp = itemp - 1 - ((yoffset + itemp - 1) % itemp);
+ yoffset += dtemp;
+ if (info->crop_height <= dtemp)
+ info->drop_height = 0;
+ else if (yoffset + info->crop_height - dtemp == info->output_height)
+ /* Matching bottom edge: include partial iMCU */
+ info->drop_height = (info->crop_height - dtemp + itemp - 1) / itemp;
+ else
+ info->drop_height = (info->crop_height - dtemp) / itemp;
+ /* Check if sampling factors match for dropping */
+ if (info->drop_width != 0 && info->drop_height != 0)
+ for (ci = 0; ci < info->num_components &&
+ ci < info->drop_ptr->num_components; ci++) {
+ if (info->drop_ptr->comp_info[ci].h_samp_factor *
+ srcinfo->max_h_samp_factor !=
+ srcinfo->comp_info[ci].h_samp_factor *
+ info->drop_ptr->max_h_samp_factor)
+ ERREXIT6(srcinfo, JERR_BAD_DROP_SAMPLING, ci,
+ info->drop_ptr->comp_info[ci].h_samp_factor,
+ info->drop_ptr->max_h_samp_factor,
+ srcinfo->comp_info[ci].h_samp_factor,
+ srcinfo->max_h_samp_factor, 'h');
+ if (info->drop_ptr->comp_info[ci].v_samp_factor *
+ srcinfo->max_v_samp_factor !=
+ srcinfo->comp_info[ci].v_samp_factor *
+ info->drop_ptr->max_v_samp_factor)
+ ERREXIT6(srcinfo, JERR_BAD_DROP_SAMPLING, ci,
+ info->drop_ptr->comp_info[ci].v_samp_factor,
+ info->drop_ptr->max_v_samp_factor,
+ srcinfo->comp_info[ci].v_samp_factor,
+ srcinfo->max_v_samp_factor, 'v');
+ }
+ break;
+ case JXFORM_WIPE:
/* Ensure the effective wipe region will cover the requested */
info->drop_width = (JDIMENSION) jdiv_round_up
((long) (info->crop_width + (xoffset % info->iMCU_sample_width)),
@@ -1187,7 +1765,8 @@ jtransform_request_workspace (j_decompress_ptr srcinfo,
info->drop_height = (JDIMENSION) jdiv_round_up
((long) (info->crop_height + (yoffset % info->iMCU_sample_height)),
(long) info->iMCU_sample_height);
- } else {
+ break;
+ default:
/* Ensure the effective crop region will cover the requested */
if (info->crop_width_set == JCROP_FORCE ||
info->crop_width > info->output_width)
@@ -1275,6 +1854,11 @@ jtransform_request_workspace (j_decompress_ptr srcinfo,
break;
case JXFORM_WIPE:
break;
+ case JXFORM_DROP:
+#if DROP_REQUEST_FROM_SRC
+ drop_request_from_src(info->drop_ptr, srcinfo);
+#endif
+ break;
}
/* Allocate workspace if needed.
@@ -1282,15 +1866,13 @@ jtransform_request_workspace (j_decompress_ptr srcinfo,
* so that transform routines need not worry about missing edge blocks.
*/
if (need_workspace) {
- coef_arrays = (jvirt_barray_ptr *)
- (*srcinfo->mem->alloc_small) ((j_common_ptr) srcinfo, JPOOL_IMAGE,
- SIZEOF(jvirt_barray_ptr) * info->num_components);
- width_in_iMCUs = (JDIMENSION)
- jdiv_round_up((long) info->output_width,
- (long) info->iMCU_sample_width);
- height_in_iMCUs = (JDIMENSION)
- jdiv_round_up((long) info->output_height,
- (long) info->iMCU_sample_height);
+ coef_arrays = (jvirt_barray_ptr *) (*srcinfo->mem->alloc_small)
+ ((j_common_ptr) srcinfo, JPOOL_IMAGE,
+ SIZEOF(jvirt_barray_ptr) * info->num_components);
+ width_in_iMCUs = (JDIMENSION) jdiv_round_up
+ ((long) info->output_width, (long) info->iMCU_sample_width);
+ height_in_iMCUs = (JDIMENSION) jdiv_round_up
+ ((long) info->output_height, (long) info->iMCU_sample_height);
for (ci = 0; ci < info->num_components; ci++) {
compptr = srcinfo->comp_info + ci;
if (info->num_components == 1) {
@@ -1574,7 +2156,7 @@ jtransform_adjust_parameters (j_decompress_ptr srcinfo,
dstinfo->jpeg_width = info->output_width;
dstinfo->jpeg_height = info->output_height;
- /* Transpose destination image parameters */
+ /* Transpose destination image parameters, adjust quantization */
switch (info->transform) {
case JXFORM_TRANSPOSE:
case JXFORM_TRANSVERSE:
@@ -1582,6 +2164,12 @@ jtransform_adjust_parameters (j_decompress_ptr srcinfo,
case JXFORM_ROT_270:
transpose_critical_parameters(dstinfo);
break;
+ case JXFORM_DROP:
+ if (info->drop_width != 0 && info->drop_height != 0)
+ adjust_quant(srcinfo, src_coef_arrays,
+ info->drop_ptr, info->drop_coef_arrays,
+ info->trim, dstinfo);
+ break;
default:
break;
}
@@ -1637,10 +2225,22 @@ jtransform_execute_transform (j_decompress_ptr srcinfo,
switch (info->transform) {
case JXFORM_NONE:
if (info->output_width > srcinfo->output_width ||
- info->output_height > srcinfo->output_height)
- do_crop_ext(srcinfo, dstinfo, info->x_crop_offset, info->y_crop_offset,
- src_coef_arrays, dst_coef_arrays);
- else if (info->x_crop_offset != 0 || info->y_crop_offset != 0)
+ info->output_height > srcinfo->output_height) {
+ if (info->output_width > srcinfo->output_width &&
+ info->crop_width_set == JCROP_REFLECT)
+ do_crop_ext_reflect(srcinfo, dstinfo,
+ info->x_crop_offset, info->y_crop_offset,
+ src_coef_arrays, dst_coef_arrays);
+ else if (info->output_width > srcinfo->output_width &&
+ info->crop_width_set == JCROP_FORCE)
+ do_crop_ext_flat(srcinfo, dstinfo,
+ info->x_crop_offset, info->y_crop_offset,
+ src_coef_arrays, dst_coef_arrays);
+ else
+ do_crop_ext_zero(srcinfo, dstinfo,
+ info->x_crop_offset, info->y_crop_offset,
+ src_coef_arrays, dst_coef_arrays);
+ } else if (info->x_crop_offset != 0 || info->y_crop_offset != 0)
do_crop(srcinfo, dstinfo, info->x_crop_offset, info->y_crop_offset,
src_coef_arrays, dst_coef_arrays);
break;
@@ -1677,12 +2277,28 @@ jtransform_execute_transform (j_decompress_ptr srcinfo,
src_coef_arrays, dst_coef_arrays);
break;
case JXFORM_WIPE:
- if (info->crop_width_set != JCROP_FORCE)
- do_wipe(srcinfo, dstinfo, info->x_crop_offset, info->y_crop_offset,
- src_coef_arrays, info->drop_width, info->drop_height);
- else
+ if (info->crop_width_set == JCROP_REFLECT &&
+ info->y_crop_offset == 0 && info->drop_height ==
+ (JDIMENSION) jdiv_round_up
+ ((long) info->output_height, (long) info->iMCU_sample_height) &&
+ (info->x_crop_offset == 0 ||
+ info->x_crop_offset + info->drop_width ==
+ (JDIMENSION) jdiv_round_up
+ ((long) info->output_width, (long) info->iMCU_sample_width)))
+ do_reflect(srcinfo, dstinfo, info->x_crop_offset,
+ src_coef_arrays, info->drop_width, info->drop_height);
+ else if (info->crop_width_set == JCROP_FORCE)
do_flatten(srcinfo, dstinfo, info->x_crop_offset, info->y_crop_offset,
src_coef_arrays, info->drop_width, info->drop_height);
+ else
+ do_wipe(srcinfo, dstinfo, info->x_crop_offset, info->y_crop_offset,
+ src_coef_arrays, info->drop_width, info->drop_height);
+ break;
+ case JXFORM_DROP:
+ if (info->drop_width != 0 && info->drop_height != 0)
+ do_drop(srcinfo, dstinfo, info->x_crop_offset, info->y_crop_offset,
+ src_coef_arrays, info->drop_ptr, info->drop_coef_arrays,
+ info->drop_width, info->drop_height);
break;
}
}
diff --git a/jpeg/transupp.h b/jpeg/transupp.h
index eee69314..a8ba16ad 100644
--- a/jpeg/transupp.h
+++ b/jpeg/transupp.h
@@ -1,7 +1,7 @@
/*
* transupp.h
*
- * Copyright (C) 1997-2013, Thomas G. Lane, Guido Vollbeding.
+ * Copyright (C) 1997-2019, Thomas G. Lane, Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -61,6 +61,11 @@
*
* A complementary lossless-wipe option is provided to discard (gray out) data
* inside a given image region while losslessly preserving what is outside.
+ * Another option is lossless-drop, which replaces data at a given image
+ * position by another image. Both source images must have the same
+ * subsampling values. It is best if they also have the same quantization,
+ * otherwise quantization adaption occurs. The trim option can be used with
+ * the drop option to requantize the drop file to the source file.
*
* We also provide a lossless-resize option, which is kind of a lossless-crop
* operation in the DCT coefficient block domain - it discards higher-order
@@ -106,20 +111,22 @@ typedef enum {
JXFORM_ROT_90, /* 90-degree clockwise rotation */
JXFORM_ROT_180, /* 180-degree rotation */
JXFORM_ROT_270, /* 270-degree clockwise (or 90 ccw) */
- JXFORM_WIPE /* wipe */
+ JXFORM_WIPE, /* wipe */
+ JXFORM_DROP /* drop */
} JXFORM_CODE;
/*
* Codes for crop parameters, which can individually be unspecified,
* positive or negative for xoffset or yoffset,
- * positive or forced for width or height.
+ * positive or force or reflect for width or height.
*/
typedef enum {
- JCROP_UNSET,
- JCROP_POS,
- JCROP_NEG,
- JCROP_FORCE
+ JCROP_UNSET,
+ JCROP_POS,
+ JCROP_NEG,
+ JCROP_FORCE,
+ JCROP_REFLECT
} JCROP_CODE;
/*
@@ -134,20 +141,24 @@ typedef struct {
boolean perfect; /* if TRUE, fail if partial MCUs are requested */
boolean trim; /* if TRUE, trim partial MCUs as needed */
boolean force_grayscale; /* if TRUE, convert color image to grayscale */
- boolean crop; /* if TRUE, crop or wipe source image */
+ boolean crop; /* if TRUE, crop or wipe source image, or drop */
/* Crop parameters: application need not set these unless crop is TRUE.
* These can be filled in by jtransform_parse_crop_spec().
*/
JDIMENSION crop_width; /* Width of selected region */
- JCROP_CODE crop_width_set; /* (forced disables adjustment) */
+ JCROP_CODE crop_width_set; /* (force disables adjustment) */
JDIMENSION crop_height; /* Height of selected region */
- JCROP_CODE crop_height_set; /* (forced disables adjustment) */
+ JCROP_CODE crop_height_set; /* (force disables adjustment) */
JDIMENSION crop_xoffset; /* X offset of selected region */
JCROP_CODE crop_xoffset_set; /* (negative measures from right edge) */
JDIMENSION crop_yoffset; /* Y offset of selected region */
JCROP_CODE crop_yoffset_set; /* (negative measures from bottom edge) */
+ /* Drop parameters: set by caller for drop request */
+ j_decompress_ptr drop_ptr;
+ jvirt_barray_ptr * drop_coef_arrays;
+
/* Internal workspace: caller should not touch these */
int num_components; /* # of components in workspace */
jvirt_barray_ptr * workspace_coef_arrays; /* workspace for transformations */
diff --git a/jpeg/usage.txt b/jpeg/usage.txt
index d06e3fc2..b20484bb 100644
--- a/jpeg/usage.txt
+++ b/jpeg/usage.txt
@@ -47,7 +47,7 @@ or
This syntax works on all systems, so it is useful for scripts.
The currently supported image file formats are: PPM (PBMPLUS color format),
-PGM (PBMPLUS grayscale format), BMP, Targa, and RLE (Utah Raster Toolkit
+PGM (PBMPLUS grayscale format), BMP, GIF, Targa, and RLE (Utah Raster Toolkit
format). (RLE is supported only if the URT library is available, which it
isn't on most non-Unix systems.) cjpeg recognizes the input image format
automatically, with the exception of some Targa-format files. You have to
@@ -73,10 +73,10 @@ The basic command line switches for cjpeg are:
-grayscale Create monochrome JPEG file from color input.
Be sure to use this switch when compressing a grayscale
- BMP file, because cjpeg isn't bright enough to notice
- whether a BMP file uses only shades of gray. By
- saying -grayscale, you'll get a smaller JPEG file that
- takes less time to process.
+ BMP or GIF file, because cjpeg isn't bright enough to
+ notice whether a BMP or GIF file uses only shades of
+ gray. By saying -grayscale, you'll get a smaller
+ JPEG file that takes less time to process.
-rgb Create RGB JPEG file.
Using this switch suppresses the conversion from RGB
@@ -317,10 +317,17 @@ The basic command line switches for djpeg are:
is specified, or if the JPEG file is grayscale;
otherwise, 24-bit full-color format is emitted.
- -gif Select GIF output format. Since GIF does not support
- more than 256 colors, -colors 256 is assumed (unless
- you specify a smaller number of colors). If you
- specify -fast, the default number of colors is 216.
+ -gif Select GIF output format (LZW compressed).
+ Since GIF does not support more than 256 colors,
+ -colors 256 is assumed (unless you specify a smaller
+ number of colors). If you specify -fast, the default
+ number of colors is 216.
+
+ -gif0 Select GIF output format (uncompressed).
+ Since GIF does not support more than 256 colors,
+ -colors 256 is assumed (unless you specify a smaller
+ number of colors). If you specify -fast, the default
+ number of colors is 216.
-os2 Select BMP output format (OS/2 1.x flavor). 8-bit
colormapped format is emitted if -colors or -grayscale
@@ -411,10 +418,6 @@ quality settings to make very small JPEG files; the percentage improvement
is often a lot more than it is on larger files. (At present, -optimize
mode is always selected when generating progressive JPEG files.)
-GIF input files are no longer supported, to avoid the Unisys LZW patent
-(now expired).
-(Conversion of GIF files to JPEG is usually a bad idea anyway.)
-
HINTS FOR DJPEG
@@ -440,10 +443,6 @@ it may run out of memory even with -maxmemory 0. In that case you can still
decompress, with some loss of image quality, by specifying -onepass for
one-pass quantization.
-To avoid the Unisys LZW patent (now expired), djpeg produces uncompressed GIF
-files. These are larger than they should be, but are readable by standard GIF
-decoders.
-
HINTS FOR BOTH PROGRAMS
@@ -571,13 +570,33 @@ The image can be losslessly cropped by giving the switch:
-crop WxH+X+Y Crop to a rectangular subarea of width W, height H
starting at point X,Y.
+Crop extension: The width or height parameters can be made larger than the
+source image. In this case the extra area is filled in with zero (neutral
+gray). A larger width parameter has two more options: Attaching an 'f'
+character ("flatten") to the width number will fill in the extra area with
+the DC of the adjacent block, instead of gray out. Attaching an 'r'
+character ("reflect") to the width number will fill in the extra area with
+repeated reflections of the source region, instead of gray out.
+
A complementary lossless-wipe option is provided to discard (gray out) data
inside a given image region while losslessly preserving what is outside:
-wipe WxH+X+Y Wipe (gray out) a rectangular subarea of
width W, height H starting at point X,Y.
-Attaching an 'f' character ("flatten") to the width number will fill
-the region with the average of adjacent blocks, instead of gray out.
+Attaching an 'f' character ("flatten") to the width number will fill the
+region with the average of adjacent blocks, instead of gray out. In case
+the wipe region and outside area form two horizontally adjacent rectangles,
+attaching an 'r' character ("reflect") to the width number will fill the
+region with repeated reflections of the outside area, instead of gray out.
+
+Another option is lossless-drop, which replaces data at a given image
+position by another image:
+ -drop +X+Y filename Drop another image
+
+Both source images must have the same subsampling values. It is best if
+they also have the same quantization, otherwise quantization adaption occurs.
+The trim option can be used with the drop option to requantize the drop file
+to the source file.
Other not-strictly-lossless transformation switches are:
diff --git a/jpeg/wrbmp.c b/jpeg/wrbmp.c
index 28148644..a9a7f53e 100644
--- a/jpeg/wrbmp.c
+++ b/jpeg/wrbmp.c
@@ -2,7 +2,7 @@
* wrbmp.c
*
* Copyright (C) 1994-1996, Thomas G. Lane.
- * Modified 2017 by Guido Vollbeding.
+ * Modified 2017-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -74,22 +74,19 @@ put_pixel_rows (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo,
/* This version is for writing 24-bit pixels */
{
bmp_dest_ptr dest = (bmp_dest_ptr) dinfo;
- JSAMPARRAY image_ptr;
register JSAMPROW inptr, outptr;
register JDIMENSION col;
int pad;
/* Access next row in virtual array */
- image_ptr = (*cinfo->mem->access_virt_sarray)
- ((j_common_ptr) cinfo, dest->whole_image,
- dest->cur_output_row, (JDIMENSION) 1, TRUE);
+ outptr = * (*cinfo->mem->access_virt_sarray) ((j_common_ptr) cinfo,
+ dest->whole_image, dest->cur_output_row, (JDIMENSION) 1, TRUE);
dest->cur_output_row++;
/* Transfer data. Note destination values must be in BGR order
* (even though Microsoft's own documents say the opposite).
*/
inptr = dest->pub.buffer[0];
- outptr = image_ptr[0];
for (col = cinfo->output_width; col > 0; col--) {
outptr[2] = *inptr++; /* can omit GETJSAMPLE() safely */
outptr[1] = *inptr++;
@@ -109,20 +106,17 @@ put_gray_rows (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo,
/* This version is for grayscale OR quantized color output */
{
bmp_dest_ptr dest = (bmp_dest_ptr) dinfo;
- JSAMPARRAY image_ptr;
register JSAMPROW inptr, outptr;
register JDIMENSION col;
int pad;
/* Access next row in virtual array */
- image_ptr = (*cinfo->mem->access_virt_sarray)
- ((j_common_ptr) cinfo, dest->whole_image,
- dest->cur_output_row, (JDIMENSION) 1, TRUE);
+ outptr = * (*cinfo->mem->access_virt_sarray) ((j_common_ptr) cinfo,
+ dest->whole_image, dest->cur_output_row, (JDIMENSION) 1, TRUE);
dest->cur_output_row++;
/* Transfer data. */
inptr = dest->pub.buffer[0];
- outptr = image_ptr[0];
for (col = cinfo->output_width; col > 0; col--) {
*outptr++ = *inptr++; /* can omit GETJSAMPLE() safely */
}
@@ -160,10 +154,10 @@ write_bmp_header (j_decompress_ptr cinfo, bmp_dest_ptr dest)
{
char bmpfileheader[14];
char bmpinfoheader[40];
-#define PUT_2B(array,offset,value) \
+#define PUT_2B(array, offset, value) \
(array[offset] = (char) ((value) & 0xFF), \
array[offset+1] = (char) (((value) >> 8) & 0xFF))
-#define PUT_4B(array,offset,value) \
+#define PUT_4B(array, offset, value) \
(array[offset] = (char) ((value) & 0xFF), \
array[offset+1] = (char) (((value) >> 8) & 0xFF), \
array[offset+2] = (char) (((value) >> 16) & 0xFF), \
@@ -328,13 +322,13 @@ write_colormap (j_decompress_ptr cinfo, bmp_dest_ptr dest,
putc(0, outfile);
}
}
- /* Pad colormap with zeros to ensure specified number of colormap entries */
+ /* Pad colormap to ensure specified number of colormap entries */
if (i > map_colors)
ERREXIT1(cinfo, JERR_TOO_MANY_COLORS, i);
for (; i < map_colors; i++) {
- putc(0, outfile);
- putc(0, outfile);
- putc(0, outfile);
+ putc(CENTERJSAMPLE, outfile);
+ putc(CENTERJSAMPLE, outfile);
+ putc(CENTERJSAMPLE, outfile);
if (map_entry_size == 4)
putc(0, outfile);
}
@@ -346,7 +340,6 @@ finish_output_bmp (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo)
{
bmp_dest_ptr dest = (bmp_dest_ptr) dinfo;
register FILE * outfile = dest->pub.output_file;
- JSAMPARRAY image_ptr;
register JSAMPROW data_ptr;
JDIMENSION row;
register JDIMENSION col;
@@ -365,9 +358,8 @@ finish_output_bmp (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo)
progress->pub.pass_limit = (long) cinfo->output_height;
(*progress->pub.progress_monitor) ((j_common_ptr) cinfo);
}
- image_ptr = (*cinfo->mem->access_virt_sarray)
- ((j_common_ptr) cinfo, dest->whole_image, row-1, (JDIMENSION) 1, FALSE);
- data_ptr = image_ptr[0];
+ data_ptr = * (*cinfo->mem->access_virt_sarray) ((j_common_ptr) cinfo,
+ dest->whole_image, row - 1, (JDIMENSION) 1, FALSE);
for (col = dest->row_width; col > 0; col--) {
putc(GETJSAMPLE(*data_ptr), outfile);
data_ptr++;
@@ -394,21 +386,23 @@ jinit_write_bmp (j_decompress_ptr cinfo, boolean is_os2)
JDIMENSION row_width;
/* Create module interface object, fill in method pointers */
- dest = (bmp_dest_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(bmp_dest_struct));
+ dest = (bmp_dest_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(bmp_dest_struct));
dest->pub.start_output = start_output_bmp;
dest->pub.finish_output = finish_output_bmp;
dest->is_os2 = is_os2;
- if (cinfo->out_color_space == JCS_GRAYSCALE) {
+ switch (cinfo->out_color_space) {
+ case JCS_GRAYSCALE:
dest->pub.put_pixel_rows = put_gray_rows;
- } else if (cinfo->out_color_space == JCS_RGB) {
+ break;
+ case JCS_RGB:
if (cinfo->quantize_colors)
dest->pub.put_pixel_rows = put_gray_rows;
else
dest->pub.put_pixel_rows = put_pixel_rows;
- } else {
+ break;
+ default:
ERREXIT(cinfo, JERR_BMP_COLORSPACE);
}
diff --git a/jpeg/wrgif.c b/jpeg/wrgif.c
index 843a1036..9d472de1 100644
--- a/jpeg/wrgif.c
+++ b/jpeg/wrgif.c
@@ -1,19 +1,13 @@
/*
* wrgif.c
*
- * Copyright (C) 1991-1997, Thomas G. Lane.
- * Modified 2015-2017 by Guido Vollbeding.
+ * Copyright (C) 1991-1996, Thomas G. Lane.
+ * Modified 2015-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
* This file contains routines to write output images in GIF format.
*
- **************************************************************************
- * NOTE: to avoid entanglements with Unisys' patent on LZW compression, *
- * this code has been modified to output "uncompressed GIF" files. *
- * There is no trace of the LZW algorithm in this file. *
- **************************************************************************
- *
* These routines may need modification for non-Unix environments or
* specialized applications. As they stand, they assume output to
* an ordinary stdio stream.
@@ -31,11 +25,6 @@
* copyright notice and this permission notice appear in supporting
* documentation. This software is provided "as is" without express or
* implied warranty.
- *
- * We are also required to state that
- * "The Graphics Interchange Format(c) is the Copyright property of
- * CompuServe Incorporated. GIF(sm) is a Service Mark property of
- * CompuServe Incorporated."
*/
#include "cdjpeg.h" /* Common decls for cjpeg/djpeg applications */
@@ -43,6 +32,40 @@
#ifdef GIF_SUPPORTED
+#define MAX_LZW_BITS 12 /* maximum LZW code size (4096 symbols) */
+
+typedef INT16 code_int; /* must hold -1 .. 2**MAX_LZW_BITS */
+
+#define LZW_TABLE_SIZE ((code_int) 1 << MAX_LZW_BITS)
+
+#define HSIZE 5003 /* hash table size for 80% occupancy */
+
+typedef int hash_int; /* must hold -2*HSIZE..2*HSIZE */
+
+#define MAXCODE(n_bits) (((code_int) 1 << (n_bits)) - 1)
+
+
+/*
+ * The LZW hash table consists of two parallel arrays:
+ * hash_code[i] code of symbol in slot i, or 0 if empty slot
+ * hash_value[i] symbol's value; undefined if empty slot
+ * where slot values (i) range from 0 to HSIZE-1. The symbol value is
+ * its prefix symbol's code concatenated with its suffix character.
+ *
+ * Algorithm: use open addressing double hashing (no chaining) on the
+ * prefix code / suffix character combination. We do a variant of Knuth's
+ * algorithm D (vol. 3, sec. 6.4) along with G. Knott's relatively-prime
+ * secondary probe.
+ *
+ * The hash_value[] table is allocated from FAR heap space since it would
+ * use up rather a lot of the near data space in a PC.
+ */
+
+typedef INT32 hash_entry; /* must hold (code_int<<8) | byte */
+
+#define HASH_ENTRY(prefix, suffix) ((((hash_entry) (prefix)) << 8) | (suffix))
+
+
/* Private version of data destination object */
typedef struct {
@@ -52,14 +75,24 @@ typedef struct {
/* State for packing variable-width codes into a bitstream */
int n_bits; /* current number of bits/code */
- int maxcode; /* maximum code, given n_bits */
+ code_int maxcode; /* maximum code, given n_bits */
+ int init_bits; /* initial n_bits ... restored after clear */
INT32 cur_accum; /* holds bits not yet output */
int cur_bits; /* # of bits in cur_accum */
+ /* LZW string construction */
+ code_int waiting_code; /* symbol not yet output; may be extendable */
+ boolean first_byte; /* if TRUE, waiting_code is not valid */
+
/* State for GIF code assignment */
- int ClearCode; /* clear code (doesn't change) */
- int EOFCode; /* EOF code (ditto) */
- int code_counter; /* counts output symbols */
+ code_int ClearCode; /* clear code (doesn't change) */
+ code_int EOFCode; /* EOF code (ditto) */
+ code_int free_code; /* LZW: first not-yet-used symbol code */
+ code_int code_counter; /* not LZW: counts output symbols */
+
+ /* LZW hash table */
+ code_int *hash_code; /* => hash table of symbol codes */
+ hash_entry FAR *hash_value; /* => hash table of symbol values */
/* GIF data packet construction buffer */
int bytesinpkt; /* # of bytes in current packet */
@@ -69,9 +102,6 @@ typedef struct {
typedef gif_dest_struct * gif_dest_ptr;
-/* Largest value that will fit in N bits */
-#define MAXCODE(n_bits) ((1 << (n_bits)) - 1)
-
/*
* Routines to package finished data bytes into GIF data blocks.
@@ -93,7 +123,7 @@ flush_packet (gif_dest_ptr dinfo)
/* Add a character to current packet; flush to disk if necessary */
-#define CHAR_OUT(dinfo,c) \
+#define CHAR_OUT(dinfo, c) \
{ (dinfo)->packetbuf[++(dinfo)->bytesinpkt] = (char) (c); \
if ((dinfo)->bytesinpkt >= 255) \
flush_packet(dinfo); \
@@ -103,7 +133,7 @@ flush_packet (gif_dest_ptr dinfo)
/* Routine to convert variable-width codes into a byte stream */
LOCAL(void)
-output (gif_dest_ptr dinfo, int code)
+output (gif_dest_ptr dinfo, code_int code)
/* Emit a code of n_bits bits */
/* Uses cur_accum and cur_bits to reblock into 8-bit bytes */
{
@@ -115,74 +145,76 @@ output (gif_dest_ptr dinfo, int code)
dinfo->cur_accum >>= 8;
dinfo->cur_bits -= 8;
}
+
+ /*
+ * If the next entry is going to be too big for the code size,
+ * then increase it, if possible. We do this here to ensure
+ * that it's done in sync with the decoder's codesize increases.
+ */
+ if (dinfo->free_code > dinfo->maxcode) {
+ dinfo->n_bits++;
+ if (dinfo->n_bits == MAX_LZW_BITS)
+ dinfo->maxcode = LZW_TABLE_SIZE; /* free_code will never exceed this */
+ else
+ dinfo->maxcode = MAXCODE(dinfo->n_bits);
+ }
}
-/* The pseudo-compression algorithm.
- *
- * In this module we simply output each pixel value as a separate symbol;
- * thus, no compression occurs. In fact, there is expansion of one bit per
- * pixel, because we use a symbol width one bit wider than the pixel width.
- *
- * GIF ordinarily uses variable-width symbols, and the decoder will expect
- * to ratchet up the symbol width after a fixed number of symbols.
- * To simplify the logic and keep the expansion penalty down, we emit a
- * GIF Clear code to reset the decoder just before the width would ratchet up.
- * Thus, all the symbols in the output file will have the same bit width.
- * Note that emitting the Clear codes at the right times is a mere matter of
- * counting output symbols and is in no way dependent on the LZW patent.
- *
- * With a small basic pixel width (low color count), Clear codes will be
- * needed very frequently, causing the file to expand even more. So this
- * simplistic approach wouldn't work too well on bilevel images, for example.
- * But for output of JPEG conversions the pixel width will usually be 8 bits
- * (129 to 256 colors), so the overhead added by Clear symbols is only about
- * one symbol in every 256.
- */
+/* Compression initialization & termination */
+
+
+LOCAL(void)
+clear_hash (gif_dest_ptr dinfo)
+/* Fill the hash table with empty entries */
+{
+ /* It's sufficient to zero hash_code[] */
+ MEMZERO(dinfo->hash_code, HSIZE * SIZEOF(code_int));
+}
+
+
+LOCAL(void)
+clear_block (gif_dest_ptr dinfo)
+/* Reset compressor and issue a Clear code */
+{
+ clear_hash(dinfo); /* delete all the symbols */
+ dinfo->free_code = dinfo->ClearCode + 2;
+ output(dinfo, dinfo->ClearCode); /* inform decoder */
+ dinfo->n_bits = dinfo->init_bits; /* reset code size */
+ dinfo->maxcode = MAXCODE(dinfo->n_bits);
+}
+
LOCAL(void)
compress_init (gif_dest_ptr dinfo, int i_bits)
-/* Initialize pseudo-compressor */
+/* Initialize compressor */
{
/* init all the state variables */
- dinfo->n_bits = i_bits;
+ dinfo->n_bits = dinfo->init_bits = i_bits;
dinfo->maxcode = MAXCODE(dinfo->n_bits);
- dinfo->ClearCode = (1 << (i_bits - 1));
+ dinfo->ClearCode = ((code_int) 1 << (i_bits - 1));
dinfo->EOFCode = dinfo->ClearCode + 1;
- dinfo->code_counter = dinfo->ClearCode + 2;
+ dinfo->code_counter = dinfo->free_code = dinfo->ClearCode + 2;
+ dinfo->first_byte = TRUE; /* no waiting symbol yet */
/* init output buffering vars */
dinfo->bytesinpkt = 0;
dinfo->cur_accum = 0;
dinfo->cur_bits = 0;
+ /* clear hash table */
+ if (dinfo->hash_code != NULL)
+ clear_hash(dinfo);
/* GIF specifies an initial Clear code */
output(dinfo, dinfo->ClearCode);
}
LOCAL(void)
-compress_pixel (gif_dest_ptr dinfo, int c)
-/* Accept and "compress" one pixel value.
- * The given value must be less than n_bits wide.
- */
-{
- /* Output the given pixel value as a symbol. */
- output(dinfo, c);
- /* Issue Clear codes often enough to keep the reader from ratcheting up
- * its symbol size.
- */
- if (dinfo->code_counter < dinfo->maxcode) {
- dinfo->code_counter++;
- } else {
- output(dinfo, dinfo->ClearCode);
- dinfo->code_counter = dinfo->ClearCode + 2; /* reset the counter */
- }
-}
-
-
-LOCAL(void)
compress_term (gif_dest_ptr dinfo)
/* Clean up at end */
{
+ /* Flush out the buffered LZW code */
+ if (! dinfo->first_byte)
+ output(dinfo, dinfo->waiting_code);
/* Send an EOF code */
output(dinfo, dinfo->EOFCode);
/* Flush the bit-packing buffer */
@@ -219,7 +251,7 @@ put_3bytes (gif_dest_ptr dinfo, int val)
LOCAL(void)
emit_header (gif_dest_ptr dinfo, int num_colors, JSAMPARRAY colormap)
/* Output the GIF file header, including color map */
-/* If colormap==NULL, synthesize a grayscale colormap */
+/* If colormap == NULL, synthesize a grayscale colormap */
{
int BitsPerPixel, ColorMapSize, InitCodeSize, FlagByte;
int cshift = dinfo->cinfo->data_precision - 8;
@@ -250,15 +282,15 @@ emit_header (gif_dest_ptr dinfo, int num_colors, JSAMPARRAY colormap)
put_word(dinfo, (unsigned int) dinfo->cinfo->output_width);
put_word(dinfo, (unsigned int) dinfo->cinfo->output_height);
FlagByte = 0x80; /* Yes, there is a global color table */
- FlagByte |= (BitsPerPixel-1) << 4; /* color resolution */
- FlagByte |= (BitsPerPixel-1); /* size of global color table */
+ FlagByte |= (BitsPerPixel - 1) << 4; /* color resolution */
+ FlagByte |= (BitsPerPixel - 1); /* size of global color table */
putc(FlagByte, dinfo->pub.output_file);
putc(0, dinfo->pub.output_file); /* Background color index */
putc(0, dinfo->pub.output_file); /* Reserved (aspect ratio in GIF89) */
/* Write the Global Color Map */
/* If the color map is more than 8 bits precision, */
/* we reduce it to 8 bits by shifting */
- for (i=0; i < ColorMapSize; i++) {
+ for (i = 0; i < ColorMapSize; i++) {
if (i < num_colors) {
if (colormap != NULL) {
if (dinfo->cinfo->out_color_space == JCS_RGB) {
@@ -272,11 +304,11 @@ emit_header (gif_dest_ptr dinfo, int num_colors, JSAMPARRAY colormap)
}
} else {
/* Create a grayscale map of num_colors values, range 0..255 */
- put_3bytes(dinfo, (i * 255 + (num_colors-1)/2) / (num_colors-1));
+ put_3bytes(dinfo, (i * 255 + (num_colors - 1) / 2) / (num_colors - 1));
}
} else {
/* fill out the map to a power of 2 */
- put_3bytes(dinfo, 0);
+ put_3bytes(dinfo, CENTERJSAMPLE >> cshift);
}
}
/* Write image separator and Image Descriptor */
@@ -290,8 +322,8 @@ emit_header (gif_dest_ptr dinfo, int num_colors, JSAMPARRAY colormap)
/* Write Initial Code Size byte */
putc(InitCodeSize, dinfo->pub.output_file);
- /* Initialize for "compression" of image data */
- compress_init(dinfo, InitCodeSize+1);
+ /* Initialize for compression of image data */
+ compress_init(dinfo, InitCodeSize + 1);
}
@@ -316,17 +348,139 @@ start_output_gif (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo)
* In this module rows_supplied will always be 1.
*/
+
+/*
+ * The LZW algorithm proper
+ */
+
+METHODDEF(void)
+put_LZW_pixel_rows (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo,
+ JDIMENSION rows_supplied)
+{
+ gif_dest_ptr dest = (gif_dest_ptr) dinfo;
+ register JSAMPROW ptr;
+ register JDIMENSION col;
+ code_int c;
+ register hash_int i;
+ register hash_int disp;
+ register hash_entry probe_value;
+
+ ptr = dest->pub.buffer[0];
+ for (col = cinfo->output_width; col > 0; col--) {
+ /* Accept and compress one 8-bit byte */
+ c = (code_int) GETJSAMPLE(*ptr++);
+
+ if (dest->first_byte) { /* need to initialize waiting_code */
+ dest->waiting_code = c;
+ dest->first_byte = FALSE;
+ continue;
+ }
+
+ /* Probe hash table to see if a symbol exists for
+ * waiting_code followed by c.
+ * If so, replace waiting_code by that symbol and continue.
+ */
+ i = ((hash_int) c << (MAX_LZW_BITS-8)) + dest->waiting_code;
+ /* i is less than twice 2**MAX_LZW_BITS, therefore less than twice HSIZE */
+ if (i >= HSIZE)
+ i -= HSIZE;
+
+ probe_value = HASH_ENTRY(dest->waiting_code, c);
+
+ if (dest->hash_code[i] == 0) {
+ /* hit empty slot; desired symbol not in table */
+ output(dest, dest->waiting_code);
+ if (dest->free_code < LZW_TABLE_SIZE) {
+ dest->hash_code[i] = dest->free_code++; /* add symbol to hashtable */
+ dest->hash_value[i] = probe_value;
+ } else
+ clear_block(dest);
+ dest->waiting_code = c;
+ continue;
+ }
+ if (dest->hash_value[i] == probe_value) {
+ dest->waiting_code = dest->hash_code[i];
+ continue;
+ }
+
+ if (i == 0) /* secondary hash (after G. Knott) */
+ disp = 1;
+ else
+ disp = HSIZE - i;
+ for (;;) {
+ i -= disp;
+ if (i < 0)
+ i += HSIZE;
+ if (dest->hash_code[i] == 0) {
+ /* hit empty slot; desired symbol not in table */
+ output(dest, dest->waiting_code);
+ if (dest->free_code < LZW_TABLE_SIZE) {
+ dest->hash_code[i] = dest->free_code++; /* add symbol to hashtable */
+ dest->hash_value[i] = probe_value;
+ } else
+ clear_block(dest);
+ dest->waiting_code = c;
+ break;
+ }
+ if (dest->hash_value[i] == probe_value) {
+ dest->waiting_code = dest->hash_code[i];
+ break;
+ }
+ }
+ }
+}
+
+
+/*
+ * The pseudo-compression algorithm.
+ *
+ * In this version we simply output each pixel value as a separate symbol;
+ * thus, no compression occurs. In fact, there is expansion of one bit per
+ * pixel, because we use a symbol width one bit wider than the pixel width.
+ *
+ * GIF ordinarily uses variable-width symbols, and the decoder will expect
+ * to ratchet up the symbol width after a fixed number of symbols.
+ * To simplify the logic and keep the expansion penalty down, we emit a
+ * GIF Clear code to reset the decoder just before the width would ratchet up.
+ * Thus, all the symbols in the output file will have the same bit width.
+ * Note that emitting the Clear codes at the right times is a mere matter of
+ * counting output symbols and is in no way dependent on the LZW algorithm.
+ *
+ * With a small basic pixel width (low color count), Clear codes will be
+ * needed very frequently, causing the file to expand even more. So this
+ * simplistic approach wouldn't work too well on bilevel images, for example.
+ * But for output of JPEG conversions the pixel width will usually be 8 bits
+ * (129 to 256 colors), so the overhead added by Clear symbols is only about
+ * one symbol in every 256.
+ */
+
METHODDEF(void)
-put_pixel_rows (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo,
- JDIMENSION rows_supplied)
+put_raw_pixel_rows (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo,
+ JDIMENSION rows_supplied)
{
gif_dest_ptr dest = (gif_dest_ptr) dinfo;
register JSAMPROW ptr;
register JDIMENSION col;
+ code_int c;
ptr = dest->pub.buffer[0];
for (col = cinfo->output_width; col > 0; col--) {
- compress_pixel(dest, GETJSAMPLE(*ptr++));
+ c = (code_int) GETJSAMPLE(*ptr++);
+ /* Accept and output one pixel value.
+ * The given value must be less than n_bits wide.
+ */
+
+ /* Output the given pixel value as a symbol. */
+ output(dest, c);
+ /* Issue Clear codes often enough to keep the reader from ratcheting up
+ * its symbol size.
+ */
+ if (dest->code_counter < dest->maxcode) {
+ dest->code_counter++;
+ } else {
+ output(dest, dest->ClearCode);
+ dest->code_counter = dest->ClearCode + 2; /* reset the counter */
+ }
}
}
@@ -340,7 +494,7 @@ finish_output_gif (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo)
{
gif_dest_ptr dest = (gif_dest_ptr) dinfo;
- /* Flush "compression" mechanism */
+ /* Flush compression mechanism */
compress_term(dest);
/* Write a zero-length data block to end the series */
putc(0, dest->pub.output_file);
@@ -358,17 +512,15 @@ finish_output_gif (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo)
*/
GLOBAL(djpeg_dest_ptr)
-jinit_write_gif (j_decompress_ptr cinfo)
+jinit_write_gif (j_decompress_ptr cinfo, boolean is_lzw)
{
gif_dest_ptr dest;
/* Create module interface object, fill in method pointers */
- dest = (gif_dest_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(gif_dest_struct));
+ dest = (gif_dest_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(gif_dest_struct));
dest->cinfo = cinfo; /* make back link for subroutines */
dest->pub.start_output = start_output_gif;
- dest->pub.put_pixel_rows = put_pixel_rows;
dest->pub.finish_output = finish_output_gif;
if (cinfo->out_color_space != JCS_GRAYSCALE &&
@@ -394,6 +546,20 @@ jinit_write_gif (j_decompress_ptr cinfo)
((j_common_ptr) cinfo, JPOOL_IMAGE, cinfo->output_width, (JDIMENSION) 1);
dest->pub.buffer_height = 1;
+ if (is_lzw) {
+ dest->pub.put_pixel_rows = put_LZW_pixel_rows;
+ /* Allocate space for hash table */
+ dest->hash_code = (code_int *) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, HSIZE * SIZEOF(code_int));
+ dest->hash_value = (hash_entry FAR *) (*cinfo->mem->alloc_large)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, HSIZE * SIZEOF(hash_entry));
+ } else {
+ dest->pub.put_pixel_rows = put_raw_pixel_rows;
+ /* Mark tables unused */
+ dest->hash_code = NULL;
+ dest->hash_value = NULL;
+ }
+
return &dest->pub;
}
diff --git a/jpeg/wrppm.c b/jpeg/wrppm.c
index e2f27cf2..eb8bdf40 100644
--- a/jpeg/wrppm.c
+++ b/jpeg/wrppm.c
@@ -2,7 +2,7 @@
* wrppm.c
*
* Copyright (C) 1991-1996, Thomas G. Lane.
- * Modified 2009-2017 by Guido Vollbeding.
+ * Modified 2009-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -149,7 +149,6 @@ put_demapped_rgb (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo,
(void) JFWRITE(dest->pub.output_file, dest->iobuffer, dest->buffer_width);
}
-
METHODDEF(void)
put_demapped_gray (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo,
JDIMENSION rows_supplied)
@@ -157,13 +156,13 @@ put_demapped_gray (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo,
ppm_dest_ptr dest = (ppm_dest_ptr) dinfo;
register char * bufferptr;
register JSAMPROW ptr;
- register JSAMPROW color_map = cinfo->colormap[0];
+ register JSAMPROW color_map0 = cinfo->colormap[0];
register JDIMENSION col;
ptr = dest->pub.buffer[0];
bufferptr = dest->iobuffer;
for (col = cinfo->output_width; col > 0; col--) {
- PUTPPMSAMPLE(bufferptr, GETJSAMPLE(color_map[GETJSAMPLE(*ptr++)]));
+ PUTPPMSAMPLE(bufferptr, GETJSAMPLE(color_map0[GETJSAMPLE(*ptr++)]));
}
(void) JFWRITE(dest->pub.output_file, dest->iobuffer, dest->buffer_width);
}
@@ -176,19 +175,17 @@ put_demapped_gray (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo,
METHODDEF(void)
start_output_ppm (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo)
{
- ppm_dest_ptr dest = (ppm_dest_ptr) dinfo;
-
/* Emit file header */
switch (cinfo->out_color_space) {
case JCS_GRAYSCALE:
/* emit header for raw PGM format */
- fprintf(dest->pub.output_file, "P5\n%ld %ld\n%d\n",
+ fprintf(dinfo->output_file, "P5\n%ld %ld\n%d\n",
(long) cinfo->output_width, (long) cinfo->output_height,
PPM_MAXVAL);
break;
case JCS_RGB:
/* emit header for raw PPM format */
- fprintf(dest->pub.output_file, "P6\n%ld %ld\n%d\n",
+ fprintf(dinfo->output_file, "P6\n%ld %ld\n%d\n",
(long) cinfo->output_width, (long) cinfo->output_height,
PPM_MAXVAL);
break;
@@ -222,9 +219,8 @@ jinit_write_ppm (j_decompress_ptr cinfo)
ppm_dest_ptr dest;
/* Create module interface object, fill in method pointers */
- dest = (ppm_dest_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(ppm_dest_struct));
+ dest = (ppm_dest_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(ppm_dest_struct));
dest->pub.start_output = start_output_ppm;
dest->pub.finish_output = finish_output_ppm;
diff --git a/jpeg/wrrle.c b/jpeg/wrrle.c
index 403e2606..dc2fadb8 100644
--- a/jpeg/wrrle.c
+++ b/jpeg/wrrle.c
@@ -2,7 +2,7 @@
* wrrle.c
*
* Copyright (C) 1991-1996, Thomas G. Lane.
- * Modified 2017 by Guido Vollbeding.
+ * Modified 2017-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -62,6 +62,7 @@ typedef struct {
typedef rle_dest_struct * rle_dest_ptr;
+
/* Forward declarations */
METHODDEF(void) rle_put_pixel_rows
JPP((j_decompress_ptr cinfo, djpeg_dest_ptr dinfo,
@@ -79,7 +80,7 @@ start_output_rle (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo)
{
rle_dest_ptr dest = (rle_dest_ptr) dinfo;
size_t cmapsize;
- int i, ci;
+ int ci, i;
#ifdef PROGRESS_REPORT
cd_progress_ptr progress = (cd_progress_ptr) cinfo->progress;
#endif
@@ -123,8 +124,8 @@ start_output_rle (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo)
/* Shifting would need adjustment for JSAMPLEs wider than 8 bits. */
for (ci = 0; ci < cinfo->out_color_components; ci++) {
for (i = 0; i < cinfo->actual_number_of_colors; i++) {
- dest->colormap[ci * CMAPLENGTH + i] =
- GETJSAMPLE(cinfo->colormap[ci][i]) << 8;
+ dest->colormap[ci * CMAPLENGTH + i] =
+ GETJSAMPLE(cinfo->colormap[ci][i]) << 8;
}
}
}
@@ -163,6 +164,7 @@ rle_put_pixel_rows (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo,
}
}
+
/*
* Finish up at the end of the file.
*
@@ -174,7 +176,7 @@ finish_output_rle (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo)
{
rle_dest_ptr dest = (rle_dest_ptr) dinfo;
rle_hdr header; /* Output file information */
- rle_pixel **rle_row, *red, *green, *blue;
+ rle_pixel **rle_row, *red_ptr, *green_ptr, *blue_ptr;
JSAMPROW output_row;
char cmapcomment[80];
int row, col;
@@ -221,37 +223,37 @@ finish_output_rle (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo)
#endif
if (cinfo->output_components == 1) {
- for (row = cinfo->output_height-1; row >= 0; row--) {
+ for (row = cinfo->output_height - 1; row >= 0; row--) {
rle_row = (rle_pixel **) (*cinfo->mem->access_virt_sarray)
- ((j_common_ptr) cinfo, dest->image,
+ ((j_common_ptr) cinfo, dest->image,
(JDIMENSION) row, (JDIMENSION) 1, FALSE);
rle_putrow(rle_row, (int) cinfo->output_width, &header);
#ifdef PROGRESS_REPORT
if (progress != NULL) {
- progress->pub.pass_counter++;
- (*progress->pub.progress_monitor) ((j_common_ptr) cinfo);
+ progress->pub.pass_counter++;
+ (*progress->pub.progress_monitor) ((j_common_ptr) cinfo);
}
#endif
}
} else {
- for (row = cinfo->output_height-1; row >= 0; row--) {
- rle_row = (rle_pixel **) dest->rle_row;
+ for (row = cinfo->output_height - 1; row >= 0; row--) {
output_row = * (*cinfo->mem->access_virt_sarray)
- ((j_common_ptr) cinfo, dest->image,
+ ((j_common_ptr) cinfo, dest->image,
(JDIMENSION) row, (JDIMENSION) 1, FALSE);
- red = rle_row[0];
- green = rle_row[1];
- blue = rle_row[2];
+ rle_row = dest->rle_row;
+ red_ptr = rle_row[0];
+ green_ptr = rle_row[1];
+ blue_ptr = rle_row[2];
for (col = cinfo->output_width; col > 0; col--) {
- *red++ = GETJSAMPLE(*output_row++);
- *green++ = GETJSAMPLE(*output_row++);
- *blue++ = GETJSAMPLE(*output_row++);
+ *red_ptr++ = GETJSAMPLE(*output_row++);
+ *green_ptr++ = GETJSAMPLE(*output_row++);
+ *blue_ptr++ = GETJSAMPLE(*output_row++);
}
rle_putrow(rle_row, (int) cinfo->output_width, &header);
#ifdef PROGRESS_REPORT
if (progress != NULL) {
- progress->pub.pass_counter++;
- (*progress->pub.progress_monitor) ((j_common_ptr) cinfo);
+ progress->pub.pass_counter++;
+ (*progress->pub.progress_monitor) ((j_common_ptr) cinfo);
}
#endif
}
@@ -280,9 +282,8 @@ jinit_write_rle (j_decompress_ptr cinfo)
rle_dest_ptr dest;
/* Create module interface object, fill in method pointers */
- dest = (rle_dest_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(rle_dest_struct));
+ dest = (rle_dest_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(rle_dest_struct));
dest->pub.start_output = start_output_rle;
dest->pub.finish_output = finish_output_rle;
@@ -290,14 +291,13 @@ jinit_write_rle (j_decompress_ptr cinfo)
jpeg_calc_output_dimensions(cinfo);
/* Allocate a work array for output to the RLE library. */
- dest->rle_row = (*cinfo->mem->alloc_sarray)
- ((j_common_ptr) cinfo, JPOOL_IMAGE,
- cinfo->output_width, (JDIMENSION) cinfo->output_components);
+ dest->rle_row = (*cinfo->mem->alloc_sarray) ((j_common_ptr) cinfo,
+ JPOOL_IMAGE, cinfo->output_width, (JDIMENSION) cinfo->output_components);
/* Allocate a virtual array to hold the image. */
dest->image = (*cinfo->mem->request_virt_sarray)
((j_common_ptr) cinfo, JPOOL_IMAGE, FALSE,
- (JDIMENSION) (cinfo->output_width * cinfo->output_components),
+ cinfo->output_width * (JDIMENSION) cinfo->output_components,
cinfo->output_height, (JDIMENSION) 1);
return &dest->pub;
diff --git a/jpeg/wrtarga.c b/jpeg/wrtarga.c
index 276a42ce..8ded5183 100644
--- a/jpeg/wrtarga.c
+++ b/jpeg/wrtarga.c
@@ -2,7 +2,7 @@
* wrtarga.c
*
* Copyright (C) 1991-1996, Thomas G. Lane.
- * Modified 2015-2017 by Guido Vollbeding.
+ * Modified 2015-2019 by Guido Vollbeding.
* This file is part of the Independent JPEG Group's software.
* For conditions of distribution and use, see the accompanying README file.
*
@@ -167,19 +167,20 @@ put_demapped_gray (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo,
METHODDEF(void)
start_output_tga (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo)
{
- tga_dest_ptr dest = (tga_dest_ptr) dinfo;
int num_colors, i;
FILE *outfile;
- if (cinfo->out_color_space == JCS_GRAYSCALE) {
+ switch (cinfo->out_color_space) {
+ case JCS_GRAYSCALE:
/* Targa doesn't have a mapped grayscale format, so we will */
/* demap quantized gray output. Never emit a colormap. */
write_header(cinfo, dinfo, 0);
if (cinfo->quantize_colors)
- dest->pub.put_pixel_rows = put_demapped_gray;
+ dinfo->put_pixel_rows = put_demapped_gray;
else
- dest->pub.put_pixel_rows = put_gray_rows;
- } else if (cinfo->out_color_space == JCS_RGB) {
+ dinfo->put_pixel_rows = put_gray_rows;
+ break;
+ case JCS_RGB:
if (cinfo->quantize_colors) {
/* We only support 8-bit colormap indexes, so only 256 colors */
num_colors = cinfo->actual_number_of_colors;
@@ -187,18 +188,19 @@ start_output_tga (j_decompress_ptr cinfo, djpeg_dest_ptr dinfo)
ERREXIT1(cinfo, JERR_TOO_MANY_COLORS, num_colors);
write_header(cinfo, dinfo, num_colors);
/* Write the colormap. Note Targa uses BGR byte order */
- outfile = dest->pub.output_file;
+ outfile = dinfo->output_file;
for (i = 0; i < num_colors; i++) {
putc(GETJSAMPLE(cinfo->colormap[2][i]), outfile);
putc(GETJSAMPLE(cinfo->colormap[1][i]), outfile);
putc(GETJSAMPLE(cinfo->colormap[0][i]), outfile);
}
- dest->pub.put_pixel_rows = put_gray_rows;
+ dinfo->put_pixel_rows = put_gray_rows;
} else {
write_header(cinfo, dinfo, 0);
- dest->pub.put_pixel_rows = put_pixel_rows;
+ dinfo->put_pixel_rows = put_pixel_rows;
}
- } else {
+ break;
+ default:
ERREXIT(cinfo, JERR_TGA_COLORSPACE);
}
}
@@ -228,9 +230,8 @@ jinit_write_targa (j_decompress_ptr cinfo)
tga_dest_ptr dest;
/* Create module interface object, fill in method pointers */
- dest = (tga_dest_ptr)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- SIZEOF(tga_dest_struct));
+ dest = (tga_dest_ptr) (*cinfo->mem->alloc_small)
+ ((j_common_ptr) cinfo, JPOOL_IMAGE, SIZEOF(tga_dest_struct));
dest->pub.start_output = start_output_tga;
dest->pub.finish_output = finish_output_tga;
@@ -239,13 +240,12 @@ jinit_write_targa (j_decompress_ptr cinfo)
/* Create I/O buffer. Note we make this near on a PC. */
dest->buffer_width = cinfo->output_width * cinfo->output_components;
- dest->iobuffer = (char *)
- (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo, JPOOL_IMAGE,
- (size_t) (dest->buffer_width * SIZEOF(char)));
+ dest->iobuffer = (char *) (*cinfo->mem->alloc_small) ((j_common_ptr) cinfo,
+ JPOOL_IMAGE, (size_t) dest->buffer_width * SIZEOF(char));
/* Create decompressor output buffer. */
- dest->pub.buffer = (*cinfo->mem->alloc_sarray)
- ((j_common_ptr) cinfo, JPOOL_IMAGE, dest->buffer_width, (JDIMENSION) 1);
+ dest->pub.buffer = (*cinfo->mem->alloc_sarray) ((j_common_ptr) cinfo,
+ JPOOL_IMAGE, dest->buffer_width, (JDIMENSION) 1);
dest->pub.buffer_height = 1;
return &dest->pub;
diff --git a/lcms2mt/Makefile.in b/lcms2mt/Makefile.in
index fa2b6908..94f3f411 100644
--- a/lcms2mt/Makefile.in
+++ b/lcms2mt/Makefile.in
@@ -119,11 +119,11 @@ am__v_P_1 = :
AM_V_GEN = $(am__v_GEN_@AM_V@)
am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@)
am__v_GEN_0 = @echo " GEN " $@;
-am__v_GEN_1 =
+am__v_GEN_1 =
AM_V_at = $(am__v_at_@AM_V@)
am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
am__v_at_0 = @
-am__v_at_1 =
+am__v_at_1 =
SOURCES =
DIST_SOURCES =
RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \
@@ -200,7 +200,7 @@ DIST_SUBDIRS = src include utils/tificc utils/transicc utils/linkicc \
utils/jpgicc utils/psicc testbed plugins
am__DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/lcms2mt.pc.in \
AUTHORS COPYING ChangeLog INSTALL compile config.guess \
- config.sub depcomp install-sh ltmain.sh missing
+ config.sub install-sh ltmain.sh missing
DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
distdir = $(PACKAGE)-$(VERSION)
top_distdir = $(distdir)
@@ -299,6 +299,7 @@ LIB_ZLIB = @LIB_ZLIB@
LIPO = @LIPO@
LN_S = @LN_S@
LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
MAINT = @MAINT@
MAKEINFO = @MAKEINFO@
MANIFEST_TOOL = @MANIFEST_TOOL@
diff --git a/lcms2mt/Projects/VC2015/lcms2mt.rc b/lcms2mt/Projects/VC2015/lcms2mt.rc
index b7ca5856..c381a4b5 100644
--- a/lcms2mt/Projects/VC2015/lcms2mt.rc
+++ b/lcms2mt/Projects/VC2015/lcms2mt.rc
@@ -27,8 +27,8 @@ LANGUAGE LANG_SPANISH, SUBLANG_SPANISH_MODERN
//
1 VERSIONINFO
- FILEVERSION 2,12,0,0
- PRODUCTVERSION 2,12,0,0
+ FILEVERSION 2,13,0,0
+ PRODUCTVERSION 2,13,0,0
FILEFLAGSMASK 0x0L
#ifdef _DEBUG
FILEFLAGS 0x1L
@@ -45,12 +45,12 @@ BEGIN
BEGIN
VALUE "CompanyName", "Marti Maria"
VALUE "FileDescription", "lcms color engine"
- VALUE "FileVersion", "2.12.0.0"
+ VALUE "FileVersion", "2.13.0.0"
VALUE "InternalName", "lcms"
VALUE "LegalCopyright", "Copyright � Marti Maria 2021"
VALUE "OriginalFilename", "lcms2.dll"
VALUE "ProductName", "LittleCMS color engine"
- VALUE "ProductVersion", "2.12.0.0"
+ VALUE "ProductVersion", "2.13.0.0"
END
END
BLOCK "VarFileInfo"
diff --git a/lcms2mt/Projects/VC2017/lcms2mt.rc b/lcms2mt/Projects/VC2017/lcms2mt.rc
index b7ca5856..c381a4b5 100644
--- a/lcms2mt/Projects/VC2017/lcms2mt.rc
+++ b/lcms2mt/Projects/VC2017/lcms2mt.rc
@@ -27,8 +27,8 @@ LANGUAGE LANG_SPANISH, SUBLANG_SPANISH_MODERN
//
1 VERSIONINFO
- FILEVERSION 2,12,0,0
- PRODUCTVERSION 2,12,0,0
+ FILEVERSION 2,13,0,0
+ PRODUCTVERSION 2,13,0,0
FILEFLAGSMASK 0x0L
#ifdef _DEBUG
FILEFLAGS 0x1L
@@ -45,12 +45,12 @@ BEGIN
BEGIN
VALUE "CompanyName", "Marti Maria"
VALUE "FileDescription", "lcms color engine"
- VALUE "FileVersion", "2.12.0.0"
+ VALUE "FileVersion", "2.13.0.0"
VALUE "InternalName", "lcms"
VALUE "LegalCopyright", "Copyright � Marti Maria 2021"
VALUE "OriginalFilename", "lcms2.dll"
VALUE "ProductName", "LittleCMS color engine"
- VALUE "ProductVersion", "2.12.0.0"
+ VALUE "ProductVersion", "2.13.0.0"
END
END
BLOCK "VarFileInfo"
diff --git a/lcms2mt/Projects/VC2019/lcms2mt.rc b/lcms2mt/Projects/VC2019/lcms2mt.rc
index b7ca5856..c381a4b5 100644
--- a/lcms2mt/Projects/VC2019/lcms2mt.rc
+++ b/lcms2mt/Projects/VC2019/lcms2mt.rc
@@ -27,8 +27,8 @@ LANGUAGE LANG_SPANISH, SUBLANG_SPANISH_MODERN
//
1 VERSIONINFO
- FILEVERSION 2,12,0,0
- PRODUCTVERSION 2,12,0,0
+ FILEVERSION 2,13,0,0
+ PRODUCTVERSION 2,13,0,0
FILEFLAGSMASK 0x0L
#ifdef _DEBUG
FILEFLAGS 0x1L
@@ -45,12 +45,12 @@ BEGIN
BEGIN
VALUE "CompanyName", "Marti Maria"
VALUE "FileDescription", "lcms color engine"
- VALUE "FileVersion", "2.12.0.0"
+ VALUE "FileVersion", "2.13.0.0"
VALUE "InternalName", "lcms"
VALUE "LegalCopyright", "Copyright � Marti Maria 2021"
VALUE "OriginalFilename", "lcms2.dll"
VALUE "ProductName", "LittleCMS color engine"
- VALUE "ProductVersion", "2.12.0.0"
+ VALUE "ProductVersion", "2.13.0.0"
END
END
BLOCK "VarFileInfo"
diff --git a/lcms2mt/Projects/Xcode_12/lcms2/lcms2.xcodeproj/project.pbxproj b/lcms2mt/Projects/Xcode_12/lcms2/lcms2.xcodeproj/project.pbxproj
new file mode 100644
index 00000000..9f61a884
--- /dev/null
+++ b/lcms2mt/Projects/Xcode_12/lcms2/lcms2.xcodeproj/project.pbxproj
@@ -0,0 +1,1387 @@
+// !$*UTF8*$!
+{
+ archiveVersion = 1;
+ classes = {
+ };
+ objectVersion = 54;
+ objects = {
+
+/* Begin PBXBuildFile section */
+ 4123B46925518DB1005F0287 /* linkicc.c in Sources */ = {isa = PBXBuildFile; fileRef = 4123B46825518DB1005F0287 /* linkicc.c */; };
+ 4123B4A425518FFB005F0287 /* xgetopt.c in Sources */ = {isa = PBXBuildFile; fileRef = 4123B4A325518FFB005F0287 /* xgetopt.c */; };
+ 4123B4B82551903B005F0287 /* tificc.c in Sources */ = {isa = PBXBuildFile; fileRef = 4123B4B72551903B005F0287 /* tificc.c */; };
+ 4123B5042551A1C8005F0287 /* libfast_float_plugin.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 418B0A8F24C5E35200DF2C21 /* libfast_float_plugin.a */; };
+ 418B0A5224C5E1C900DF2C21 /* cmsgamma.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A3824C5E1C700DF2C21 /* cmsgamma.c */; };
+ 418B0A5324C5E1C900DF2C21 /* cmsintrp.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A3924C5E1C700DF2C21 /* cmsintrp.c */; };
+ 418B0A5424C5E1C900DF2C21 /* cmsgmt.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A3A24C5E1C700DF2C21 /* cmsgmt.c */; };
+ 418B0A5524C5E1C900DF2C21 /* cmscnvrt.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A3B24C5E1C700DF2C21 /* cmscnvrt.c */; };
+ 418B0A5624C5E1C900DF2C21 /* cmsmd5.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A3C24C5E1C700DF2C21 /* cmsmd5.c */; };
+ 418B0A5724C5E1C900DF2C21 /* cmssm.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A3D24C5E1C700DF2C21 /* cmssm.c */; };
+ 418B0A5824C5E1C900DF2C21 /* cmsopt.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A3E24C5E1C700DF2C21 /* cmsopt.c */; };
+ 418B0A5924C5E1C900DF2C21 /* cmscgats.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A3F24C5E1C700DF2C21 /* cmscgats.c */; };
+ 418B0A5A24C5E1C900DF2C21 /* cmsalpha.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A4024C5E1C800DF2C21 /* cmsalpha.c */; };
+ 418B0A5B24C5E1C900DF2C21 /* cmstypes.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A4124C5E1C800DF2C21 /* cmstypes.c */; };
+ 418B0A5C24C5E1C900DF2C21 /* cmsio1.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A4224C5E1C800DF2C21 /* cmsio1.c */; };
+ 418B0A5D24C5E1C900DF2C21 /* cmspack.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A4324C5E1C800DF2C21 /* cmspack.c */; };
+ 418B0A5E24C5E1C900DF2C21 /* cmsxform.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A4424C5E1C800DF2C21 /* cmsxform.c */; };
+ 418B0A5F24C5E1C900DF2C21 /* cmswtpnt.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A4524C5E1C800DF2C21 /* cmswtpnt.c */; };
+ 418B0A6024C5E1C900DF2C21 /* cmsmtrx.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A4624C5E1C800DF2C21 /* cmsmtrx.c */; };
+ 418B0A6124C5E1C900DF2C21 /* cmspcs.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A4724C5E1C800DF2C21 /* cmspcs.c */; };
+ 418B0A6224C5E1C900DF2C21 /* cmsps2.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A4824C5E1C800DF2C21 /* cmsps2.c */; };
+ 418B0A6324C5E1C900DF2C21 /* cmsnamed.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A4924C5E1C800DF2C21 /* cmsnamed.c */; };
+ 418B0A6424C5E1C900DF2C21 /* cmserr.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A4A24C5E1C800DF2C21 /* cmserr.c */; };
+ 418B0A6524C5E1C900DF2C21 /* cmslut.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A4B24C5E1C800DF2C21 /* cmslut.c */; };
+ 418B0A6624C5E1C900DF2C21 /* cmsvirt.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A4C24C5E1C800DF2C21 /* cmsvirt.c */; };
+ 418B0A6724C5E1C900DF2C21 /* cmsplugin.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A4D24C5E1C800DF2C21 /* cmsplugin.c */; };
+ 418B0A6824C5E1C900DF2C21 /* cmshalf.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A4E24C5E1C800DF2C21 /* cmshalf.c */; };
+ 418B0A6924C5E1C900DF2C21 /* cmsio0.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A4F24C5E1C900DF2C21 /* cmsio0.c */; };
+ 418B0A6A24C5E1C900DF2C21 /* cmscam02.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A5024C5E1C900DF2C21 /* cmscam02.c */; };
+ 418B0A6B24C5E1C900DF2C21 /* cmssamp.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A5124C5E1C900DF2C21 /* cmssamp.c */; };
+ 418B0A6F24C5E1E800DF2C21 /* lcms2.h in Headers */ = {isa = PBXBuildFile; fileRef = 418B0A6D24C5E1E800DF2C21 /* lcms2.h */; settings = {ATTRIBUTES = (Public, ); }; };
+ 418B0A7024C5E1E800DF2C21 /* lcms2_plugin.h in Headers */ = {isa = PBXBuildFile; fileRef = 418B0A6E24C5E1E800DF2C21 /* lcms2_plugin.h */; settings = {ATTRIBUTES = (Public, ); }; };
+ 418B0A7224C5E1F400DF2C21 /* lcms2_internal.h in Headers */ = {isa = PBXBuildFile; fileRef = 418B0A7124C5E1F400DF2C21 /* lcms2_internal.h */; settings = {ATTRIBUTES = (Private, ); }; };
+ 418B0A8A24C5E30000DF2C21 /* liblcms2.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 418B0A3124C5E19500DF2C21 /* liblcms2.a */; };
+ 418B0AA124C5E37800DF2C21 /* fast_float_curves.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A9324C5E37600DF2C21 /* fast_float_curves.c */; };
+ 418B0AA224C5E37800DF2C21 /* fast_float_15mats.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A9424C5E37600DF2C21 /* fast_float_15mats.c */; };
+ 418B0AA324C5E37800DF2C21 /* fast_float_tethra.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A9524C5E37600DF2C21 /* fast_float_tethra.c */; };
+ 418B0AA424C5E37800DF2C21 /* fast_float_cmyk.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A9624C5E37700DF2C21 /* fast_float_cmyk.c */; };
+ 418B0AA524C5E37800DF2C21 /* fast_16_tethra.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A9724C5E37700DF2C21 /* fast_16_tethra.c */; };
+ 418B0AA624C5E37800DF2C21 /* fast_float_internal.h in Headers */ = {isa = PBXBuildFile; fileRef = 418B0A9824C5E37700DF2C21 /* fast_float_internal.h */; settings = {ATTRIBUTES = (Private, ); }; };
+ 418B0AA724C5E37800DF2C21 /* fast_8_matsh.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A9924C5E37700DF2C21 /* fast_8_matsh.c */; };
+ 418B0AA824C5E37800DF2C21 /* fast_float_separate.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A9A24C5E37700DF2C21 /* fast_float_separate.c */; };
+ 418B0AA924C5E37800DF2C21 /* fast_8_matsh_sse.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A9B24C5E37700DF2C21 /* fast_8_matsh_sse.c */; };
+ 418B0AAA24C5E37800DF2C21 /* fast_8_tethra.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A9C24C5E37700DF2C21 /* fast_8_tethra.c */; };
+ 418B0AAB24C5E37800DF2C21 /* fast_float_sup.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A9D24C5E37700DF2C21 /* fast_float_sup.c */; };
+ 418B0AAC24C5E37800DF2C21 /* fast_float_15bits.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A9E24C5E37700DF2C21 /* fast_float_15bits.c */; };
+ 418B0AAD24C5E37800DF2C21 /* fast_8_curves.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0A9F24C5E37700DF2C21 /* fast_8_curves.c */; };
+ 418B0AAE24C5E37800DF2C21 /* fast_float_matsh.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0AA024C5E37800DF2C21 /* fast_float_matsh.c */; };
+ 418B0AB024C5E38C00DF2C21 /* lcms2_fast_float.h in Headers */ = {isa = PBXBuildFile; fileRef = 418B0AAF24C5E38C00DF2C21 /* lcms2_fast_float.h */; settings = {ATTRIBUTES = (Public, ); }; };
+ 418B0AC224C5E47C00DF2C21 /* liblcms2.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 418B0A3124C5E19500DF2C21 /* liblcms2.a */; };
+ 418B0ADA24C5E58A00DF2C21 /* liblcms2.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 418B0A3124C5E19500DF2C21 /* liblcms2.a */; };
+ 418B0AEA24C5E5CF00DF2C21 /* liblcms2.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 418B0A3124C5E19500DF2C21 /* liblcms2.a */; };
+ 418B0AF224C5E6B000DF2C21 /* fast_float_testbed.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0AF124C5E6B000DF2C21 /* fast_float_testbed.c */; };
+ 418B0AF624C5E6C800DF2C21 /* xgetopt.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0AF324C5E6C700DF2C21 /* xgetopt.c */; };
+ 418B0AF724C5E6C800DF2C21 /* vprf.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0AF424C5E6C700DF2C21 /* vprf.c */; };
+ 418B0AF924C5E6D200DF2C21 /* transicc.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0AF824C5E6D200DF2C21 /* transicc.c */; };
+ 418B0AFF24C5E73100DF2C21 /* xgetopt.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0AFD24C5E73100DF2C21 /* xgetopt.c */; };
+ 418B0B0024C5E73100DF2C21 /* vprf.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0AFE24C5E73100DF2C21 /* vprf.c */; };
+ 418B0B0F24C5E79200DF2C21 /* utils.h in Sources */ = {isa = PBXBuildFile; fileRef = 418B0B0E24C5E79200DF2C21 /* utils.h */; };
+ 418B0B1424C5E7BB00DF2C21 /* vprf.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0B1224C5E7BB00DF2C21 /* vprf.c */; };
+ 418B0B1524C5E7CF00DF2C21 /* liblcms2.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 418B0A3124C5E19500DF2C21 /* liblcms2.a */; };
+ 418B0B2124C5E8FA00DF2C21 /* liblcms2.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 418B0A3124C5E19500DF2C21 /* liblcms2.a */; };
+ 418B0B2524C5E92100DF2C21 /* tifdiff.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0B2424C5E92100DF2C21 /* tifdiff.c */; };
+ 418B0B2924C5E92B00DF2C21 /* vprf.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0B2724C5E92B00DF2C21 /* vprf.c */; };
+ 418B0B2A24C5E92B00DF2C21 /* xgetopt.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0B2824C5E92B00DF2C21 /* xgetopt.c */; };
+ 418B0B3824C5E98E00DF2C21 /* iccjpeg.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0B3624C5E98E00DF2C21 /* iccjpeg.c */; };
+ 418B0B3A24C5E99600DF2C21 /* jpgicc.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0B3924C5E99600DF2C21 /* jpgicc.c */; };
+ 418B0B3D24C5E9A200DF2C21 /* liblcms2.a in Frameworks */ = {isa = PBXBuildFile; fileRef = 418B0A3124C5E19500DF2C21 /* liblcms2.a */; };
+ 418B0B4124C5E9F700DF2C21 /* vprf.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0B3E24C5E9F700DF2C21 /* vprf.c */; };
+ 418B0B4224C5E9F700DF2C21 /* xgetopt.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0B3F24C5E9F700DF2C21 /* xgetopt.c */; };
+ 418B0B4624C5EC1D00DF2C21 /* testcms2.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0B4324C5EC1D00DF2C21 /* testcms2.c */; };
+ 418B0B4724C5EC1D00DF2C21 /* testplugin.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0B4524C5EC1D00DF2C21 /* testplugin.c */; };
+ 418B0B4924C5EC2A00DF2C21 /* zoo_icc.c in Sources */ = {isa = PBXBuildFile; fileRef = 418B0B4824C5EC2A00DF2C21 /* zoo_icc.c */; };
+/* End PBXBuildFile section */
+
+/* Begin PBXContainerItemProxy section */
+ 418B0A8524C5E29800DF2C21 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 418B0A2924C5E19500DF2C21 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 418B0A3024C5E19500DF2C21;
+ remoteInfo = lcms2;
+ };
+ 418B0AB224C5E3D400DF2C21 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 418B0A2924C5E19500DF2C21 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 418B0A3024C5E19500DF2C21;
+ remoteInfo = lcms2;
+ };
+ 418B0AC324C5E48100DF2C21 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 418B0A2924C5E19500DF2C21 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 418B0A8E24C5E35200DF2C21;
+ remoteInfo = fast_float_plugin;
+ };
+ 418B0AC524C5E48600DF2C21 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 418B0A2924C5E19500DF2C21 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 418B0A3024C5E19500DF2C21;
+ remoteInfo = lcms2;
+ };
+ 418B0ADB24C5E58F00DF2C21 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 418B0A2924C5E19500DF2C21 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 418B0A3024C5E19500DF2C21;
+ remoteInfo = lcms2;
+ };
+ 418B0AE824C5E5CA00DF2C21 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 418B0A2924C5E19500DF2C21 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 418B0A3024C5E19500DF2C21;
+ remoteInfo = lcms2;
+ };
+ 418B0B0C24C5E77500DF2C21 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 418B0A2924C5E19500DF2C21 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 418B0A3024C5E19500DF2C21;
+ remoteInfo = lcms2;
+ };
+ 418B0B2224C5E8FA00DF2C21 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 418B0A2924C5E19500DF2C21 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 418B0A3024C5E19500DF2C21;
+ remoteInfo = lcms2;
+ };
+ 418B0B3B24C5E99E00DF2C21 /* PBXContainerItemProxy */ = {
+ isa = PBXContainerItemProxy;
+ containerPortal = 418B0A2924C5E19500DF2C21 /* Project object */;
+ proxyType = 1;
+ remoteGlobalIDString = 418B0A3024C5E19500DF2C21;
+ remoteInfo = lcms2;
+ };
+/* End PBXContainerItemProxy section */
+
+/* Begin PBXCopyFilesBuildPhase section */
+ 418B0A7624C5E25200DF2C21 /* CopyFiles */ = {
+ isa = PBXCopyFilesBuildPhase;
+ buildActionMask = 2147483647;
+ dstPath = /usr/share/man/man1;
+ dstSubfolderSpec = 0;
+ files = (
+ );
+ runOnlyForDeploymentPostprocessing = 1;
+ };
+ 418B0AB624C5E42900DF2C21 /* CopyFiles */ = {
+ isa = PBXCopyFilesBuildPhase;
+ buildActionMask = 2147483647;
+ dstPath = /usr/share/man/man1;
+ dstSubfolderSpec = 0;
+ files = (
+ );
+ runOnlyForDeploymentPostprocessing = 1;
+ };
+ 418B0AC924C5E4EA00DF2C21 /* CopyFiles */ = {
+ isa = PBXCopyFilesBuildPhase;
+ buildActionMask = 2147483647;
+ dstPath = /usr/share/man/man1/;
+ dstSubfolderSpec = 0;
+ files = (
+ );
+ runOnlyForDeploymentPostprocessing = 1;
+ };
+ 418B0ADF24C5E5C300DF2C21 /* CopyFiles */ = {
+ isa = PBXCopyFilesBuildPhase;
+ buildActionMask = 2147483647;
+ dstPath = /usr/share/man/man1/;
+ dstSubfolderSpec = 0;
+ files = (
+ );
+ runOnlyForDeploymentPostprocessing = 1;
+ };
+ 418B0B0324C5E76100DF2C21 /* CopyFiles */ = {
+ isa = PBXCopyFilesBuildPhase;
+ buildActionMask = 2147483647;
+ dstPath = /usr/share/man/man1/;
+ dstSubfolderSpec = 0;
+ files = (
+ );
+ runOnlyForDeploymentPostprocessing = 1;
+ };
+ 418B0B1824C5E85600DF2C21 /* CopyFiles */ = {
+ isa = PBXCopyFilesBuildPhase;
+ buildActionMask = 2147483647;
+ dstPath = /usr/share/man/man1/;
+ dstSubfolderSpec = 0;
+ files = (
+ );
+ runOnlyForDeploymentPostprocessing = 1;
+ };
+ 418B0B2D24C5E95D00DF2C21 /* CopyFiles */ = {
+ isa = PBXCopyFilesBuildPhase;
+ buildActionMask = 2147483647;
+ dstPath = /usr/share/man/man1/;
+ dstSubfolderSpec = 0;
+ files = (
+ );
+ runOnlyForDeploymentPostprocessing = 1;
+ };
+/* End PBXCopyFilesBuildPhase section */
+
+/* Begin PBXFileReference section */
+ 4123B46825518DB1005F0287 /* linkicc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = linkicc.c; sourceTree = "<group>"; };
+ 4123B4A325518FFB005F0287 /* xgetopt.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = xgetopt.c; path = ../common/xgetopt.c; sourceTree = "<group>"; };
+ 4123B4B72551903B005F0287 /* tificc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = tificc.c; sourceTree = "<group>"; };
+ 4123B4C2255190FE005F0287 /* tifdiff.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = tifdiff.c; sourceTree = "<group>"; };
+ 418B0A3124C5E19500DF2C21 /* liblcms2.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = liblcms2.a; sourceTree = BUILT_PRODUCTS_DIR; };
+ 418B0A3824C5E1C700DF2C21 /* cmsgamma.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmsgamma.c; path = ../../../src/cmsgamma.c; sourceTree = "<group>"; };
+ 418B0A3924C5E1C700DF2C21 /* cmsintrp.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmsintrp.c; path = ../../../src/cmsintrp.c; sourceTree = "<group>"; };
+ 418B0A3A24C5E1C700DF2C21 /* cmsgmt.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmsgmt.c; path = ../../../src/cmsgmt.c; sourceTree = "<group>"; };
+ 418B0A3B24C5E1C700DF2C21 /* cmscnvrt.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmscnvrt.c; path = ../../../src/cmscnvrt.c; sourceTree = "<group>"; };
+ 418B0A3C24C5E1C700DF2C21 /* cmsmd5.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmsmd5.c; path = ../../../src/cmsmd5.c; sourceTree = "<group>"; };
+ 418B0A3D24C5E1C700DF2C21 /* cmssm.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmssm.c; path = ../../../src/cmssm.c; sourceTree = "<group>"; };
+ 418B0A3E24C5E1C700DF2C21 /* cmsopt.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmsopt.c; path = ../../../src/cmsopt.c; sourceTree = "<group>"; };
+ 418B0A3F24C5E1C700DF2C21 /* cmscgats.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmscgats.c; path = ../../../src/cmscgats.c; sourceTree = "<group>"; };
+ 418B0A4024C5E1C800DF2C21 /* cmsalpha.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmsalpha.c; path = ../../../src/cmsalpha.c; sourceTree = "<group>"; };
+ 418B0A4124C5E1C800DF2C21 /* cmstypes.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmstypes.c; path = ../../../src/cmstypes.c; sourceTree = "<group>"; };
+ 418B0A4224C5E1C800DF2C21 /* cmsio1.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmsio1.c; path = ../../../src/cmsio1.c; sourceTree = "<group>"; };
+ 418B0A4324C5E1C800DF2C21 /* cmspack.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmspack.c; path = ../../../src/cmspack.c; sourceTree = "<group>"; };
+ 418B0A4424C5E1C800DF2C21 /* cmsxform.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmsxform.c; path = ../../../src/cmsxform.c; sourceTree = "<group>"; };
+ 418B0A4524C5E1C800DF2C21 /* cmswtpnt.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmswtpnt.c; path = ../../../src/cmswtpnt.c; sourceTree = "<group>"; };
+ 418B0A4624C5E1C800DF2C21 /* cmsmtrx.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmsmtrx.c; path = ../../../src/cmsmtrx.c; sourceTree = "<group>"; };
+ 418B0A4724C5E1C800DF2C21 /* cmspcs.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmspcs.c; path = ../../../src/cmspcs.c; sourceTree = "<group>"; };
+ 418B0A4824C5E1C800DF2C21 /* cmsps2.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmsps2.c; path = ../../../src/cmsps2.c; sourceTree = "<group>"; };
+ 418B0A4924C5E1C800DF2C21 /* cmsnamed.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmsnamed.c; path = ../../../src/cmsnamed.c; sourceTree = "<group>"; };
+ 418B0A4A24C5E1C800DF2C21 /* cmserr.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmserr.c; path = ../../../src/cmserr.c; sourceTree = "<group>"; };
+ 418B0A4B24C5E1C800DF2C21 /* cmslut.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmslut.c; path = ../../../src/cmslut.c; sourceTree = "<group>"; };
+ 418B0A4C24C5E1C800DF2C21 /* cmsvirt.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmsvirt.c; path = ../../../src/cmsvirt.c; sourceTree = "<group>"; };
+ 418B0A4D24C5E1C800DF2C21 /* cmsplugin.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmsplugin.c; path = ../../../src/cmsplugin.c; sourceTree = "<group>"; };
+ 418B0A4E24C5E1C800DF2C21 /* cmshalf.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmshalf.c; path = ../../../src/cmshalf.c; sourceTree = "<group>"; };
+ 418B0A4F24C5E1C900DF2C21 /* cmsio0.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmsio0.c; path = ../../../src/cmsio0.c; sourceTree = "<group>"; };
+ 418B0A5024C5E1C900DF2C21 /* cmscam02.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmscam02.c; path = ../../../src/cmscam02.c; sourceTree = "<group>"; };
+ 418B0A5124C5E1C900DF2C21 /* cmssamp.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = cmssamp.c; path = ../../../src/cmssamp.c; sourceTree = "<group>"; };
+ 418B0A6D24C5E1E800DF2C21 /* lcms2.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = lcms2.h; path = ../../../include/lcms2.h; sourceTree = "<group>"; };
+ 418B0A6E24C5E1E800DF2C21 /* lcms2_plugin.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = lcms2_plugin.h; path = ../../../include/lcms2_plugin.h; sourceTree = "<group>"; };
+ 418B0A7124C5E1F400DF2C21 /* lcms2_internal.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = lcms2_internal.h; path = ../../../src/lcms2_internal.h; sourceTree = "<group>"; };
+ 418B0A7824C5E25200DF2C21 /* testbed */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = testbed; sourceTree = BUILT_PRODUCTS_DIR; };
+ 418B0A8F24C5E35200DF2C21 /* libfast_float_plugin.a */ = {isa = PBXFileReference; explicitFileType = archive.ar; includeInIndex = 0; path = libfast_float_plugin.a; sourceTree = BUILT_PRODUCTS_DIR; };
+ 418B0A9324C5E37600DF2C21 /* fast_float_curves.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = fast_float_curves.c; path = ../../../plugins/fast_float/src/fast_float_curves.c; sourceTree = "<group>"; };
+ 418B0A9424C5E37600DF2C21 /* fast_float_15mats.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = fast_float_15mats.c; path = ../../../plugins/fast_float/src/fast_float_15mats.c; sourceTree = "<group>"; };
+ 418B0A9524C5E37600DF2C21 /* fast_float_tethra.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = fast_float_tethra.c; path = ../../../plugins/fast_float/src/fast_float_tethra.c; sourceTree = "<group>"; };
+ 418B0A9624C5E37700DF2C21 /* fast_float_cmyk.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = fast_float_cmyk.c; path = ../../../plugins/fast_float/src/fast_float_cmyk.c; sourceTree = "<group>"; };
+ 418B0A9724C5E37700DF2C21 /* fast_16_tethra.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = fast_16_tethra.c; path = ../../../plugins/fast_float/src/fast_16_tethra.c; sourceTree = "<group>"; };
+ 418B0A9824C5E37700DF2C21 /* fast_float_internal.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = fast_float_internal.h; path = ../../../plugins/fast_float/src/fast_float_internal.h; sourceTree = "<group>"; };
+ 418B0A9924C5E37700DF2C21 /* fast_8_matsh.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = fast_8_matsh.c; path = ../../../plugins/fast_float/src/fast_8_matsh.c; sourceTree = "<group>"; };
+ 418B0A9A24C5E37700DF2C21 /* fast_float_separate.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = fast_float_separate.c; path = ../../../plugins/fast_float/src/fast_float_separate.c; sourceTree = "<group>"; };
+ 418B0A9B24C5E37700DF2C21 /* fast_8_matsh_sse.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = fast_8_matsh_sse.c; path = ../../../plugins/fast_float/src/fast_8_matsh_sse.c; sourceTree = "<group>"; };
+ 418B0A9C24C5E37700DF2C21 /* fast_8_tethra.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = fast_8_tethra.c; path = ../../../plugins/fast_float/src/fast_8_tethra.c; sourceTree = "<group>"; };
+ 418B0A9D24C5E37700DF2C21 /* fast_float_sup.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = fast_float_sup.c; path = ../../../plugins/fast_float/src/fast_float_sup.c; sourceTree = "<group>"; };
+ 418B0A9E24C5E37700DF2C21 /* fast_float_15bits.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = fast_float_15bits.c; path = ../../../plugins/fast_float/src/fast_float_15bits.c; sourceTree = "<group>"; };
+ 418B0A9F24C5E37700DF2C21 /* fast_8_curves.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = fast_8_curves.c; path = ../../../plugins/fast_float/src/fast_8_curves.c; sourceTree = "<group>"; };
+ 418B0AA024C5E37800DF2C21 /* fast_float_matsh.c */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.c; name = fast_float_matsh.c; path = ../../../plugins/fast_float/src/fast_float_matsh.c; sourceTree = "<group>"; };
+ 418B0AAF24C5E38C00DF2C21 /* lcms2_fast_float.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; name = lcms2_fast_float.h; path = ../../../plugins/fast_float/include/lcms2_fast_float.h; sourceTree = "<group>"; };
+ 418B0AB824C5E42900DF2C21 /* testbed */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; name = testbed; path = fast_float_testbed; sourceTree = BUILT_PRODUCTS_DIR; };
+ 418B0ACB24C5E4EA00DF2C21 /* transicc */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = transicc; sourceTree = BUILT_PRODUCTS_DIR; };
+ 418B0AE124C5E5C300DF2C21 /* linkicc */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = linkicc; sourceTree = BUILT_PRODUCTS_DIR; };
+ 418B0AF124C5E6B000DF2C21 /* fast_float_testbed.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = fast_float_testbed.c; path = ../../../plugins/fast_float/testbed/fast_float_testbed.c; sourceTree = SOURCE_ROOT; };
+ 418B0AF324C5E6C700DF2C21 /* xgetopt.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = xgetopt.c; path = ../../../utils/common/xgetopt.c; sourceTree = SOURCE_ROOT; };
+ 418B0AF424C5E6C700DF2C21 /* vprf.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = vprf.c; path = ../../../utils/common/vprf.c; sourceTree = SOURCE_ROOT; };
+ 418B0AF524C5E6C800DF2C21 /* utils.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = utils.h; path = ../../../utils/common/utils.h; sourceTree = SOURCE_ROOT; };
+ 418B0AF824C5E6D200DF2C21 /* transicc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = transicc.c; path = ../../../utils/transicc/transicc.c; sourceTree = SOURCE_ROOT; };
+ 418B0AFC24C5E73100DF2C21 /* utils.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = utils.h; path = ../../../utils/common/utils.h; sourceTree = SOURCE_ROOT; };
+ 418B0AFD24C5E73100DF2C21 /* xgetopt.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = xgetopt.c; path = ../../../utils/common/xgetopt.c; sourceTree = SOURCE_ROOT; };
+ 418B0AFE24C5E73100DF2C21 /* vprf.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = vprf.c; path = ../../../utils/common/vprf.c; sourceTree = SOURCE_ROOT; };
+ 418B0B0524C5E76100DF2C21 /* tificc */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = tificc; sourceTree = BUILT_PRODUCTS_DIR; };
+ 418B0B0E24C5E79200DF2C21 /* utils.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = utils.h; path = ../../../utils/common/utils.h; sourceTree = SOURCE_ROOT; };
+ 418B0B1224C5E7BB00DF2C21 /* vprf.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = vprf.c; path = ../../../utils/common/vprf.c; sourceTree = SOURCE_ROOT; };
+ 418B0B1A24C5E85600DF2C21 /* tifdiff */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = tifdiff; sourceTree = BUILT_PRODUCTS_DIR; };
+ 418B0B2424C5E92100DF2C21 /* tifdiff.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = tifdiff.c; path = ../../../utils/tificc/tifdiff.c; sourceTree = SOURCE_ROOT; };
+ 418B0B2724C5E92B00DF2C21 /* vprf.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = vprf.c; path = ../common/vprf.c; sourceTree = "<group>"; };
+ 418B0B2824C5E92B00DF2C21 /* xgetopt.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = xgetopt.c; path = ../common/xgetopt.c; sourceTree = "<group>"; };
+ 418B0B2F24C5E95D00DF2C21 /* jpegicc */ = {isa = PBXFileReference; explicitFileType = "compiled.mach-o.executable"; includeInIndex = 0; path = jpegicc; sourceTree = BUILT_PRODUCTS_DIR; };
+ 418B0B3624C5E98E00DF2C21 /* iccjpeg.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = iccjpeg.c; path = ../../../utils/jpgicc/iccjpeg.c; sourceTree = SOURCE_ROOT; };
+ 418B0B3724C5E98E00DF2C21 /* iccjpeg.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = iccjpeg.h; path = ../../../utils/jpgicc/iccjpeg.h; sourceTree = SOURCE_ROOT; };
+ 418B0B3924C5E99600DF2C21 /* jpgicc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; path = jpgicc.c; sourceTree = "<group>"; };
+ 418B0B3E24C5E9F700DF2C21 /* vprf.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = vprf.c; path = ../../../utils/common/vprf.c; sourceTree = SOURCE_ROOT; };
+ 418B0B3F24C5E9F700DF2C21 /* xgetopt.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = xgetopt.c; path = ../../../utils/common/xgetopt.c; sourceTree = SOURCE_ROOT; };
+ 418B0B4024C5E9F700DF2C21 /* utils.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = utils.h; path = ../../../utils/common/utils.h; sourceTree = SOURCE_ROOT; };
+ 418B0B4324C5EC1D00DF2C21 /* testcms2.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = testcms2.c; path = ../../../testbed/testcms2.c; sourceTree = SOURCE_ROOT; };
+ 418B0B4424C5EC1D00DF2C21 /* testcms2.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = testcms2.h; path = ../../../testbed/testcms2.h; sourceTree = SOURCE_ROOT; };
+ 418B0B4524C5EC1D00DF2C21 /* testplugin.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = testplugin.c; path = ../../../testbed/testplugin.c; sourceTree = "<group>"; };
+ 418B0B4824C5EC2A00DF2C21 /* zoo_icc.c */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.c; name = zoo_icc.c; path = ../../../testbed/zoo_icc.c; sourceTree = SOURCE_ROOT; };
+/* End PBXFileReference section */
+
+/* Begin PBXFrameworksBuildPhase section */
+ 418B0A2F24C5E19500DF2C21 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0A7524C5E25200DF2C21 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0A8A24C5E30000DF2C21 /* liblcms2.a in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0A8D24C5E35200DF2C21 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0AB524C5E42900DF2C21 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0AC224C5E47C00DF2C21 /* liblcms2.a in Frameworks */,
+ 4123B5042551A1C8005F0287 /* libfast_float_plugin.a in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0AC824C5E4EA00DF2C21 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0ADA24C5E58A00DF2C21 /* liblcms2.a in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0ADE24C5E5C300DF2C21 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0AEA24C5E5CF00DF2C21 /* liblcms2.a in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0B0224C5E76100DF2C21 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0B1524C5E7CF00DF2C21 /* liblcms2.a in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0B1724C5E85600DF2C21 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0B2124C5E8FA00DF2C21 /* liblcms2.a in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0B2C24C5E95D00DF2C21 /* Frameworks */ = {
+ isa = PBXFrameworksBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0B3D24C5E9A200DF2C21 /* liblcms2.a in Frameworks */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+/* End PBXFrameworksBuildPhase section */
+
+/* Begin PBXGroup section */
+ 418B0A2824C5E19500DF2C21 = {
+ isa = PBXGroup;
+ children = (
+ 418B0AB124C5E39A00DF2C21 /* fast_float_plugin */,
+ 418B0A7324C5E1FE00DF2C21 /* include */,
+ 418B0A6C24C5E1CE00DF2C21 /* src */,
+ 418B0A7924C5E25200DF2C21 /* testbed */,
+ 418B0AB924C5E42900DF2C21 /* fast_float_testbed */,
+ 418B0ACC24C5E4EA00DF2C21 /* transicc */,
+ 418B0AE224C5E5C300DF2C21 /* linkicc */,
+ 418B0B0624C5E76100DF2C21 /* tificc */,
+ 418B0B1B24C5E85600DF2C21 /* tifdiff */,
+ 418B0B3024C5E95D00DF2C21 /* jpegicc */,
+ 418B0A3224C5E19500DF2C21 /* Products */,
+ 418B0A8924C5E30000DF2C21 /* Frameworks */,
+ );
+ sourceTree = "<group>";
+ };
+ 418B0A3224C5E19500DF2C21 /* Products */ = {
+ isa = PBXGroup;
+ children = (
+ 418B0A3124C5E19500DF2C21 /* liblcms2.a */,
+ 418B0A7824C5E25200DF2C21 /* testbed */,
+ 418B0A8F24C5E35200DF2C21 /* libfast_float_plugin.a */,
+ 418B0AB824C5E42900DF2C21 /* testbed */,
+ 418B0ACB24C5E4EA00DF2C21 /* transicc */,
+ 418B0AE124C5E5C300DF2C21 /* linkicc */,
+ 418B0B0524C5E76100DF2C21 /* tificc */,
+ 418B0B1A24C5E85600DF2C21 /* tifdiff */,
+ 418B0B2F24C5E95D00DF2C21 /* jpegicc */,
+ );
+ name = Products;
+ sourceTree = "<group>";
+ };
+ 418B0A6C24C5E1CE00DF2C21 /* src */ = {
+ isa = PBXGroup;
+ children = (
+ 418B0A7124C5E1F400DF2C21 /* lcms2_internal.h */,
+ 418B0A4024C5E1C800DF2C21 /* cmsalpha.c */,
+ 418B0A5024C5E1C900DF2C21 /* cmscam02.c */,
+ 418B0A3F24C5E1C700DF2C21 /* cmscgats.c */,
+ 418B0A3B24C5E1C700DF2C21 /* cmscnvrt.c */,
+ 418B0A4A24C5E1C800DF2C21 /* cmserr.c */,
+ 418B0A3824C5E1C700DF2C21 /* cmsgamma.c */,
+ 418B0A3A24C5E1C700DF2C21 /* cmsgmt.c */,
+ 418B0A4E24C5E1C800DF2C21 /* cmshalf.c */,
+ 418B0A3924C5E1C700DF2C21 /* cmsintrp.c */,
+ 418B0A4F24C5E1C900DF2C21 /* cmsio0.c */,
+ 418B0A4224C5E1C800DF2C21 /* cmsio1.c */,
+ 418B0A4B24C5E1C800DF2C21 /* cmslut.c */,
+ 418B0A3C24C5E1C700DF2C21 /* cmsmd5.c */,
+ 418B0A4624C5E1C800DF2C21 /* cmsmtrx.c */,
+ 418B0A4924C5E1C800DF2C21 /* cmsnamed.c */,
+ 418B0A3E24C5E1C700DF2C21 /* cmsopt.c */,
+ 418B0A4324C5E1C800DF2C21 /* cmspack.c */,
+ 418B0A4724C5E1C800DF2C21 /* cmspcs.c */,
+ 418B0A4D24C5E1C800DF2C21 /* cmsplugin.c */,
+ 418B0A4824C5E1C800DF2C21 /* cmsps2.c */,
+ 418B0A5124C5E1C900DF2C21 /* cmssamp.c */,
+ 418B0A3D24C5E1C700DF2C21 /* cmssm.c */,
+ 418B0A4124C5E1C800DF2C21 /* cmstypes.c */,
+ 418B0A4C24C5E1C800DF2C21 /* cmsvirt.c */,
+ 418B0A4524C5E1C800DF2C21 /* cmswtpnt.c */,
+ 418B0A4424C5E1C800DF2C21 /* cmsxform.c */,
+ );
+ name = src;
+ sourceTree = "<group>";
+ };
+ 418B0A7324C5E1FE00DF2C21 /* include */ = {
+ isa = PBXGroup;
+ children = (
+ 418B0A6E24C5E1E800DF2C21 /* lcms2_plugin.h */,
+ 418B0A6D24C5E1E800DF2C21 /* lcms2.h */,
+ );
+ name = include;
+ sourceTree = "<group>";
+ };
+ 418B0A7924C5E25200DF2C21 /* testbed */ = {
+ isa = PBXGroup;
+ children = (
+ 418B0B4824C5EC2A00DF2C21 /* zoo_icc.c */,
+ 418B0B4324C5EC1D00DF2C21 /* testcms2.c */,
+ 418B0B4424C5EC1D00DF2C21 /* testcms2.h */,
+ 418B0B4524C5EC1D00DF2C21 /* testplugin.c */,
+ );
+ name = testbed;
+ sourceTree = SOURCE_ROOT;
+ };
+ 418B0A8924C5E30000DF2C21 /* Frameworks */ = {
+ isa = PBXGroup;
+ children = (
+ );
+ name = Frameworks;
+ sourceTree = "<group>";
+ };
+ 418B0AB124C5E39A00DF2C21 /* fast_float_plugin */ = {
+ isa = PBXGroup;
+ children = (
+ 418B0AAF24C5E38C00DF2C21 /* lcms2_fast_float.h */,
+ 418B0A9F24C5E37700DF2C21 /* fast_8_curves.c */,
+ 418B0A9B24C5E37700DF2C21 /* fast_8_matsh_sse.c */,
+ 418B0A9924C5E37700DF2C21 /* fast_8_matsh.c */,
+ 418B0A9C24C5E37700DF2C21 /* fast_8_tethra.c */,
+ 418B0A9724C5E37700DF2C21 /* fast_16_tethra.c */,
+ 418B0A9E24C5E37700DF2C21 /* fast_float_15bits.c */,
+ 418B0A9424C5E37600DF2C21 /* fast_float_15mats.c */,
+ 418B0A9624C5E37700DF2C21 /* fast_float_cmyk.c */,
+ 418B0A9324C5E37600DF2C21 /* fast_float_curves.c */,
+ 418B0A9824C5E37700DF2C21 /* fast_float_internal.h */,
+ 418B0AA024C5E37800DF2C21 /* fast_float_matsh.c */,
+ 418B0A9A24C5E37700DF2C21 /* fast_float_separate.c */,
+ 418B0A9D24C5E37700DF2C21 /* fast_float_sup.c */,
+ 418B0A9524C5E37600DF2C21 /* fast_float_tethra.c */,
+ );
+ name = fast_float_plugin;
+ sourceTree = "<group>";
+ };
+ 418B0AB924C5E42900DF2C21 /* fast_float_testbed */ = {
+ isa = PBXGroup;
+ children = (
+ 418B0AF124C5E6B000DF2C21 /* fast_float_testbed.c */,
+ );
+ name = fast_float_testbed;
+ path = ../../../plugins/fast_float/testbed;
+ sourceTree = "<group>";
+ };
+ 418B0ACC24C5E4EA00DF2C21 /* transicc */ = {
+ isa = PBXGroup;
+ children = (
+ 418B0AF824C5E6D200DF2C21 /* transicc.c */,
+ 418B0AF524C5E6C800DF2C21 /* utils.h */,
+ 418B0AF424C5E6C700DF2C21 /* vprf.c */,
+ 418B0AF324C5E6C700DF2C21 /* xgetopt.c */,
+ );
+ name = transicc;
+ sourceTree = SOURCE_ROOT;
+ };
+ 418B0AE224C5E5C300DF2C21 /* linkicc */ = {
+ isa = PBXGroup;
+ children = (
+ 4123B46825518DB1005F0287 /* linkicc.c */,
+ 418B0AFC24C5E73100DF2C21 /* utils.h */,
+ 418B0AFE24C5E73100DF2C21 /* vprf.c */,
+ 418B0AFD24C5E73100DF2C21 /* xgetopt.c */,
+ );
+ name = linkicc;
+ path = ../../../utils/linkicc;
+ sourceTree = SOURCE_ROOT;
+ };
+ 418B0B0624C5E76100DF2C21 /* tificc */ = {
+ isa = PBXGroup;
+ children = (
+ 4123B4B72551903B005F0287 /* tificc.c */,
+ 4123B4A325518FFB005F0287 /* xgetopt.c */,
+ 418B0B1224C5E7BB00DF2C21 /* vprf.c */,
+ 418B0B0E24C5E79200DF2C21 /* utils.h */,
+ );
+ name = tificc;
+ path = ../../../utils/tificc;
+ sourceTree = SOURCE_ROOT;
+ };
+ 418B0B1B24C5E85600DF2C21 /* tifdiff */ = {
+ isa = PBXGroup;
+ children = (
+ 4123B4C2255190FE005F0287 /* tifdiff.c */,
+ 418B0B2724C5E92B00DF2C21 /* vprf.c */,
+ 418B0B2824C5E92B00DF2C21 /* xgetopt.c */,
+ 418B0B2424C5E92100DF2C21 /* tifdiff.c */,
+ );
+ name = tifdiff;
+ path = ../../../utils/tificc;
+ sourceTree = SOURCE_ROOT;
+ };
+ 418B0B3024C5E95D00DF2C21 /* jpegicc */ = {
+ isa = PBXGroup;
+ children = (
+ 418B0B4024C5E9F700DF2C21 /* utils.h */,
+ 418B0B3E24C5E9F700DF2C21 /* vprf.c */,
+ 418B0B3F24C5E9F700DF2C21 /* xgetopt.c */,
+ 418B0B3924C5E99600DF2C21 /* jpgicc.c */,
+ 418B0B3624C5E98E00DF2C21 /* iccjpeg.c */,
+ 418B0B3724C5E98E00DF2C21 /* iccjpeg.h */,
+ );
+ name = jpegicc;
+ path = ../../../utils/jpgicc;
+ sourceTree = "<group>";
+ };
+/* End PBXGroup section */
+
+/* Begin PBXHeadersBuildPhase section */
+ 418B0A2D24C5E19500DF2C21 /* Headers */ = {
+ isa = PBXHeadersBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0A6F24C5E1E800DF2C21 /* lcms2.h in Headers */,
+ 418B0A7024C5E1E800DF2C21 /* lcms2_plugin.h in Headers */,
+ 418B0A7224C5E1F400DF2C21 /* lcms2_internal.h in Headers */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0A8B24C5E35200DF2C21 /* Headers */ = {
+ isa = PBXHeadersBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0AB024C5E38C00DF2C21 /* lcms2_fast_float.h in Headers */,
+ 418B0AA624C5E37800DF2C21 /* fast_float_internal.h in Headers */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+/* End PBXHeadersBuildPhase section */
+
+/* Begin PBXNativeTarget section */
+ 418B0A3024C5E19500DF2C21 /* lcms2 */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 418B0A3524C5E19500DF2C21 /* Build configuration list for PBXNativeTarget "lcms2" */;
+ buildPhases = (
+ 418B0A2D24C5E19500DF2C21 /* Headers */,
+ 418B0A2E24C5E19500DF2C21 /* Sources */,
+ 418B0A2F24C5E19500DF2C21 /* Frameworks */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ );
+ name = lcms2;
+ productName = lcms2;
+ productReference = 418B0A3124C5E19500DF2C21 /* liblcms2.a */;
+ productType = "com.apple.product-type.library.static";
+ };
+ 418B0A7724C5E25200DF2C21 /* testbed */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 418B0A7C24C5E25200DF2C21 /* Build configuration list for PBXNativeTarget "testbed" */;
+ buildPhases = (
+ 418B0A7424C5E25200DF2C21 /* Sources */,
+ 418B0A7524C5E25200DF2C21 /* Frameworks */,
+ 418B0A7624C5E25200DF2C21 /* CopyFiles */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 418B0A8624C5E29800DF2C21 /* PBXTargetDependency */,
+ );
+ name = testbed;
+ productName = testbed;
+ productReference = 418B0A7824C5E25200DF2C21 /* testbed */;
+ productType = "com.apple.product-type.tool";
+ };
+ 418B0A8E24C5E35200DF2C21 /* fast_float_plugin */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 418B0A9024C5E35200DF2C21 /* Build configuration list for PBXNativeTarget "fast_float_plugin" */;
+ buildPhases = (
+ 418B0A8B24C5E35200DF2C21 /* Headers */,
+ 418B0A8C24C5E35200DF2C21 /* Sources */,
+ 418B0A8D24C5E35200DF2C21 /* Frameworks */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 418B0AB324C5E3D400DF2C21 /* PBXTargetDependency */,
+ );
+ name = fast_float_plugin;
+ productName = fast_float_plugin;
+ productReference = 418B0A8F24C5E35200DF2C21 /* libfast_float_plugin.a */;
+ productType = "com.apple.product-type.library.static";
+ };
+ 418B0AB724C5E42900DF2C21 /* fast_float_testbed */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 418B0ABC24C5E42900DF2C21 /* Build configuration list for PBXNativeTarget "fast_float_testbed" */;
+ buildPhases = (
+ 418B0AB424C5E42900DF2C21 /* Sources */,
+ 418B0AB524C5E42900DF2C21 /* Frameworks */,
+ 418B0AB624C5E42900DF2C21 /* CopyFiles */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 418B0AC624C5E48600DF2C21 /* PBXTargetDependency */,
+ 418B0AC424C5E48100DF2C21 /* PBXTargetDependency */,
+ );
+ name = fast_float_testbed;
+ productName = fast_float_testbed;
+ productReference = 418B0AB824C5E42900DF2C21 /* testbed */;
+ productType = "com.apple.product-type.tool";
+ };
+ 418B0ACA24C5E4EA00DF2C21 /* transicc */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 418B0ACF24C5E4EA00DF2C21 /* Build configuration list for PBXNativeTarget "transicc" */;
+ buildPhases = (
+ 418B0AC724C5E4EA00DF2C21 /* Sources */,
+ 418B0AC824C5E4EA00DF2C21 /* Frameworks */,
+ 418B0AC924C5E4EA00DF2C21 /* CopyFiles */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 418B0ADC24C5E58F00DF2C21 /* PBXTargetDependency */,
+ );
+ name = transicc;
+ productName = transicc;
+ productReference = 418B0ACB24C5E4EA00DF2C21 /* transicc */;
+ productType = "com.apple.product-type.tool";
+ };
+ 418B0AE024C5E5C300DF2C21 /* linkicc */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 418B0AE524C5E5C300DF2C21 /* Build configuration list for PBXNativeTarget "linkicc" */;
+ buildPhases = (
+ 418B0ADD24C5E5C300DF2C21 /* Sources */,
+ 418B0ADE24C5E5C300DF2C21 /* Frameworks */,
+ 418B0ADF24C5E5C300DF2C21 /* CopyFiles */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 418B0AE924C5E5CA00DF2C21 /* PBXTargetDependency */,
+ );
+ name = linkicc;
+ productName = linkicc;
+ productReference = 418B0AE124C5E5C300DF2C21 /* linkicc */;
+ productType = "com.apple.product-type.tool";
+ };
+ 418B0B0424C5E76100DF2C21 /* tificc */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 418B0B0924C5E76100DF2C21 /* Build configuration list for PBXNativeTarget "tificc" */;
+ buildPhases = (
+ 418B0B0124C5E76100DF2C21 /* Sources */,
+ 418B0B0224C5E76100DF2C21 /* Frameworks */,
+ 418B0B0324C5E76100DF2C21 /* CopyFiles */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 418B0B0D24C5E77500DF2C21 /* PBXTargetDependency */,
+ );
+ name = tificc;
+ productName = tificc;
+ productReference = 418B0B0524C5E76100DF2C21 /* tificc */;
+ productType = "com.apple.product-type.tool";
+ };
+ 418B0B1924C5E85600DF2C21 /* tifdiff */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 418B0B1E24C5E85600DF2C21 /* Build configuration list for PBXNativeTarget "tifdiff" */;
+ buildPhases = (
+ 418B0B1624C5E85600DF2C21 /* Sources */,
+ 418B0B1724C5E85600DF2C21 /* Frameworks */,
+ 418B0B1824C5E85600DF2C21 /* CopyFiles */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 418B0B2324C5E8FA00DF2C21 /* PBXTargetDependency */,
+ );
+ name = tifdiff;
+ productName = tifdiff;
+ productReference = 418B0B1A24C5E85600DF2C21 /* tifdiff */;
+ productType = "com.apple.product-type.tool";
+ };
+ 418B0B2E24C5E95D00DF2C21 /* jpegicc */ = {
+ isa = PBXNativeTarget;
+ buildConfigurationList = 418B0B3324C5E95D00DF2C21 /* Build configuration list for PBXNativeTarget "jpegicc" */;
+ buildPhases = (
+ 418B0B2B24C5E95D00DF2C21 /* Sources */,
+ 418B0B2C24C5E95D00DF2C21 /* Frameworks */,
+ 418B0B2D24C5E95D00DF2C21 /* CopyFiles */,
+ );
+ buildRules = (
+ );
+ dependencies = (
+ 418B0B3C24C5E99E00DF2C21 /* PBXTargetDependency */,
+ );
+ name = jpegicc;
+ productName = jpegicc;
+ productReference = 418B0B2F24C5E95D00DF2C21 /* jpegicc */;
+ productType = "com.apple.product-type.tool";
+ };
+/* End PBXNativeTarget section */
+
+/* Begin PBXProject section */
+ 418B0A2924C5E19500DF2C21 /* Project object */ = {
+ isa = PBXProject;
+ attributes = {
+ LastUpgradeCheck = 1210;
+ ORGANIZATIONNAME = littlecms;
+ TargetAttributes = {
+ 418B0A3024C5E19500DF2C21 = {
+ CreatedOnToolsVersion = 11.6;
+ };
+ 418B0A7724C5E25200DF2C21 = {
+ CreatedOnToolsVersion = 11.6;
+ };
+ 418B0A8E24C5E35200DF2C21 = {
+ CreatedOnToolsVersion = 11.6;
+ };
+ 418B0AB724C5E42900DF2C21 = {
+ CreatedOnToolsVersion = 11.6;
+ };
+ 418B0ACA24C5E4EA00DF2C21 = {
+ CreatedOnToolsVersion = 11.6;
+ };
+ 418B0AE024C5E5C300DF2C21 = {
+ CreatedOnToolsVersion = 11.6;
+ };
+ 418B0B0424C5E76100DF2C21 = {
+ CreatedOnToolsVersion = 11.6;
+ };
+ 418B0B1924C5E85600DF2C21 = {
+ CreatedOnToolsVersion = 11.6;
+ };
+ 418B0B2E24C5E95D00DF2C21 = {
+ CreatedOnToolsVersion = 11.6;
+ };
+ };
+ };
+ buildConfigurationList = 418B0A2C24C5E19500DF2C21 /* Build configuration list for PBXProject "lcms2" */;
+ compatibilityVersion = "Xcode 12.0";
+ developmentRegion = en;
+ hasScannedForEncodings = 0;
+ knownRegions = (
+ en,
+ Base,
+ );
+ mainGroup = 418B0A2824C5E19500DF2C21;
+ productRefGroup = 418B0A3224C5E19500DF2C21 /* Products */;
+ projectDirPath = "";
+ projectRoot = "";
+ targets = (
+ 418B0A3024C5E19500DF2C21 /* lcms2 */,
+ 418B0A7724C5E25200DF2C21 /* testbed */,
+ 418B0A8E24C5E35200DF2C21 /* fast_float_plugin */,
+ 418B0AB724C5E42900DF2C21 /* fast_float_testbed */,
+ 418B0ACA24C5E4EA00DF2C21 /* transicc */,
+ 418B0AE024C5E5C300DF2C21 /* linkicc */,
+ 418B0B0424C5E76100DF2C21 /* tificc */,
+ 418B0B1924C5E85600DF2C21 /* tifdiff */,
+ 418B0B2E24C5E95D00DF2C21 /* jpegicc */,
+ );
+ };
+/* End PBXProject section */
+
+/* Begin PBXSourcesBuildPhase section */
+ 418B0A2E24C5E19500DF2C21 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0A5224C5E1C900DF2C21 /* cmsgamma.c in Sources */,
+ 418B0A5324C5E1C900DF2C21 /* cmsintrp.c in Sources */,
+ 418B0A5424C5E1C900DF2C21 /* cmsgmt.c in Sources */,
+ 418B0A5524C5E1C900DF2C21 /* cmscnvrt.c in Sources */,
+ 418B0A5624C5E1C900DF2C21 /* cmsmd5.c in Sources */,
+ 418B0A5724C5E1C900DF2C21 /* cmssm.c in Sources */,
+ 418B0A5824C5E1C900DF2C21 /* cmsopt.c in Sources */,
+ 418B0A5924C5E1C900DF2C21 /* cmscgats.c in Sources */,
+ 418B0A5A24C5E1C900DF2C21 /* cmsalpha.c in Sources */,
+ 418B0A5B24C5E1C900DF2C21 /* cmstypes.c in Sources */,
+ 418B0A5C24C5E1C900DF2C21 /* cmsio1.c in Sources */,
+ 418B0A5D24C5E1C900DF2C21 /* cmspack.c in Sources */,
+ 418B0A5E24C5E1C900DF2C21 /* cmsxform.c in Sources */,
+ 418B0A5F24C5E1C900DF2C21 /* cmswtpnt.c in Sources */,
+ 418B0A6024C5E1C900DF2C21 /* cmsmtrx.c in Sources */,
+ 418B0A6124C5E1C900DF2C21 /* cmspcs.c in Sources */,
+ 418B0A6224C5E1C900DF2C21 /* cmsps2.c in Sources */,
+ 418B0A6324C5E1C900DF2C21 /* cmsnamed.c in Sources */,
+ 418B0A6424C5E1C900DF2C21 /* cmserr.c in Sources */,
+ 418B0A6524C5E1C900DF2C21 /* cmslut.c in Sources */,
+ 418B0A6624C5E1C900DF2C21 /* cmsvirt.c in Sources */,
+ 418B0A6724C5E1C900DF2C21 /* cmsplugin.c in Sources */,
+ 418B0A6824C5E1C900DF2C21 /* cmshalf.c in Sources */,
+ 418B0A6924C5E1C900DF2C21 /* cmsio0.c in Sources */,
+ 418B0A6A24C5E1C900DF2C21 /* cmscam02.c in Sources */,
+ 418B0A6B24C5E1C900DF2C21 /* cmssamp.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0A7424C5E25200DF2C21 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0B4724C5EC1D00DF2C21 /* testplugin.c in Sources */,
+ 418B0B4924C5EC2A00DF2C21 /* zoo_icc.c in Sources */,
+ 418B0B4624C5EC1D00DF2C21 /* testcms2.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0A8C24C5E35200DF2C21 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0AA124C5E37800DF2C21 /* fast_float_curves.c in Sources */,
+ 418B0AA224C5E37800DF2C21 /* fast_float_15mats.c in Sources */,
+ 418B0AA324C5E37800DF2C21 /* fast_float_tethra.c in Sources */,
+ 418B0AA424C5E37800DF2C21 /* fast_float_cmyk.c in Sources */,
+ 418B0AA524C5E37800DF2C21 /* fast_16_tethra.c in Sources */,
+ 418B0AA724C5E37800DF2C21 /* fast_8_matsh.c in Sources */,
+ 418B0AA824C5E37800DF2C21 /* fast_float_separate.c in Sources */,
+ 418B0AA924C5E37800DF2C21 /* fast_8_matsh_sse.c in Sources */,
+ 418B0AAA24C5E37800DF2C21 /* fast_8_tethra.c in Sources */,
+ 418B0AAB24C5E37800DF2C21 /* fast_float_sup.c in Sources */,
+ 418B0AAC24C5E37800DF2C21 /* fast_float_15bits.c in Sources */,
+ 418B0AAD24C5E37800DF2C21 /* fast_8_curves.c in Sources */,
+ 418B0AAE24C5E37800DF2C21 /* fast_float_matsh.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0AB424C5E42900DF2C21 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0AF224C5E6B000DF2C21 /* fast_float_testbed.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0AC724C5E4EA00DF2C21 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0AF724C5E6C800DF2C21 /* vprf.c in Sources */,
+ 418B0AF924C5E6D200DF2C21 /* transicc.c in Sources */,
+ 418B0AF624C5E6C800DF2C21 /* xgetopt.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0ADD24C5E5C300DF2C21 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0B0024C5E73100DF2C21 /* vprf.c in Sources */,
+ 418B0AFF24C5E73100DF2C21 /* xgetopt.c in Sources */,
+ 4123B46925518DB1005F0287 /* linkicc.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0B0124C5E76100DF2C21 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 4123B4A425518FFB005F0287 /* xgetopt.c in Sources */,
+ 418B0B0F24C5E79200DF2C21 /* utils.h in Sources */,
+ 418B0B1424C5E7BB00DF2C21 /* vprf.c in Sources */,
+ 4123B4B82551903B005F0287 /* tificc.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0B1624C5E85600DF2C21 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0B2524C5E92100DF2C21 /* tifdiff.c in Sources */,
+ 418B0B2924C5E92B00DF2C21 /* vprf.c in Sources */,
+ 418B0B2A24C5E92B00DF2C21 /* xgetopt.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+ 418B0B2B24C5E95D00DF2C21 /* Sources */ = {
+ isa = PBXSourcesBuildPhase;
+ buildActionMask = 2147483647;
+ files = (
+ 418B0B3824C5E98E00DF2C21 /* iccjpeg.c in Sources */,
+ 418B0B4224C5E9F700DF2C21 /* xgetopt.c in Sources */,
+ 418B0B4124C5E9F700DF2C21 /* vprf.c in Sources */,
+ 418B0B3A24C5E99600DF2C21 /* jpgicc.c in Sources */,
+ );
+ runOnlyForDeploymentPostprocessing = 0;
+ };
+/* End PBXSourcesBuildPhase section */
+
+/* Begin PBXTargetDependency section */
+ 418B0A8624C5E29800DF2C21 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 418B0A3024C5E19500DF2C21 /* lcms2 */;
+ targetProxy = 418B0A8524C5E29800DF2C21 /* PBXContainerItemProxy */;
+ };
+ 418B0AB324C5E3D400DF2C21 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 418B0A3024C5E19500DF2C21 /* lcms2 */;
+ targetProxy = 418B0AB224C5E3D400DF2C21 /* PBXContainerItemProxy */;
+ };
+ 418B0AC424C5E48100DF2C21 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 418B0A8E24C5E35200DF2C21 /* fast_float_plugin */;
+ targetProxy = 418B0AC324C5E48100DF2C21 /* PBXContainerItemProxy */;
+ };
+ 418B0AC624C5E48600DF2C21 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 418B0A3024C5E19500DF2C21 /* lcms2 */;
+ targetProxy = 418B0AC524C5E48600DF2C21 /* PBXContainerItemProxy */;
+ };
+ 418B0ADC24C5E58F00DF2C21 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 418B0A3024C5E19500DF2C21 /* lcms2 */;
+ targetProxy = 418B0ADB24C5E58F00DF2C21 /* PBXContainerItemProxy */;
+ };
+ 418B0AE924C5E5CA00DF2C21 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 418B0A3024C5E19500DF2C21 /* lcms2 */;
+ targetProxy = 418B0AE824C5E5CA00DF2C21 /* PBXContainerItemProxy */;
+ };
+ 418B0B0D24C5E77500DF2C21 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 418B0A3024C5E19500DF2C21 /* lcms2 */;
+ targetProxy = 418B0B0C24C5E77500DF2C21 /* PBXContainerItemProxy */;
+ };
+ 418B0B2324C5E8FA00DF2C21 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 418B0A3024C5E19500DF2C21 /* lcms2 */;
+ targetProxy = 418B0B2224C5E8FA00DF2C21 /* PBXContainerItemProxy */;
+ };
+ 418B0B3C24C5E99E00DF2C21 /* PBXTargetDependency */ = {
+ isa = PBXTargetDependency;
+ target = 418B0A3024C5E19500DF2C21 /* lcms2 */;
+ targetProxy = 418B0B3B24C5E99E00DF2C21 /* PBXContainerItemProxy */;
+ };
+/* End PBXTargetDependency section */
+
+/* Begin XCBuildConfiguration section */
+ 418B0A3324C5E19500DF2C21 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ ALWAYS_SEARCH_USER_PATHS = NO;
+ CLANG_ANALYZER_NONNULL = YES;
+ CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
+ CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
+ CLANG_CXX_LIBRARY = "libc++";
+ CLANG_ENABLE_MODULES = YES;
+ CLANG_ENABLE_OBJC_ARC = YES;
+ CLANG_ENABLE_OBJC_WEAK = YES;
+ CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
+ CLANG_WARN_BOOL_CONVERSION = YES;
+ CLANG_WARN_COMMA = YES;
+ CLANG_WARN_CONSTANT_CONVERSION = YES;
+ CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
+ CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
+ CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
+ CLANG_WARN_EMPTY_BODY = YES;
+ CLANG_WARN_ENUM_CONVERSION = YES;
+ CLANG_WARN_INFINITE_RECURSION = YES;
+ CLANG_WARN_INT_CONVERSION = YES;
+ CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
+ CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
+ CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
+ CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
+ CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES;
+ CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
+ CLANG_WARN_STRICT_PROTOTYPES = YES;
+ CLANG_WARN_SUSPICIOUS_MOVE = YES;
+ CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;
+ CLANG_WARN_UNREACHABLE_CODE = YES;
+ CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
+ COPY_PHASE_STRIP = NO;
+ DEBUG_INFORMATION_FORMAT = dwarf;
+ ENABLE_STRICT_OBJC_MSGSEND = YES;
+ ENABLE_TESTABILITY = YES;
+ GCC_C_LANGUAGE_STANDARD = gnu11;
+ GCC_DYNAMIC_NO_PIC = NO;
+ GCC_NO_COMMON_BLOCKS = YES;
+ GCC_OPTIMIZATION_LEVEL = 0;
+ GCC_PREPROCESSOR_DEFINITIONS = (
+ "DEBUG=1",
+ "$(inherited)",
+ );
+ GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
+ GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
+ GCC_WARN_UNDECLARED_SELECTOR = YES;
+ GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
+ GCC_WARN_UNUSED_FUNCTION = YES;
+ GCC_WARN_UNUSED_VARIABLE = YES;
+ MACOSX_DEPLOYMENT_TARGET = 10.15;
+ MTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE;
+ MTL_FAST_MATH = YES;
+ ONLY_ACTIVE_ARCH = YES;
+ SDKROOT = macosx;
+ };
+ name = Debug;
+ };
+ 418B0A3424C5E19500DF2C21 /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ ALWAYS_SEARCH_USER_PATHS = NO;
+ CLANG_ANALYZER_NONNULL = YES;
+ CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE;
+ CLANG_CXX_LANGUAGE_STANDARD = "gnu++14";
+ CLANG_CXX_LIBRARY = "libc++";
+ CLANG_ENABLE_MODULES = YES;
+ CLANG_ENABLE_OBJC_ARC = YES;
+ CLANG_ENABLE_OBJC_WEAK = YES;
+ CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES;
+ CLANG_WARN_BOOL_CONVERSION = YES;
+ CLANG_WARN_COMMA = YES;
+ CLANG_WARN_CONSTANT_CONVERSION = YES;
+ CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES;
+ CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR;
+ CLANG_WARN_DOCUMENTATION_COMMENTS = YES;
+ CLANG_WARN_EMPTY_BODY = YES;
+ CLANG_WARN_ENUM_CONVERSION = YES;
+ CLANG_WARN_INFINITE_RECURSION = YES;
+ CLANG_WARN_INT_CONVERSION = YES;
+ CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES;
+ CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES;
+ CLANG_WARN_OBJC_LITERAL_CONVERSION = YES;
+ CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR;
+ CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES;
+ CLANG_WARN_RANGE_LOOP_ANALYSIS = YES;
+ CLANG_WARN_STRICT_PROTOTYPES = YES;
+ CLANG_WARN_SUSPICIOUS_MOVE = YES;
+ CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE;
+ CLANG_WARN_UNREACHABLE_CODE = YES;
+ CLANG_WARN__DUPLICATE_METHOD_MATCH = YES;
+ COPY_PHASE_STRIP = NO;
+ DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym";
+ ENABLE_NS_ASSERTIONS = NO;
+ ENABLE_STRICT_OBJC_MSGSEND = YES;
+ GCC_C_LANGUAGE_STANDARD = gnu11;
+ GCC_NO_COMMON_BLOCKS = YES;
+ GCC_WARN_64_TO_32_BIT_CONVERSION = YES;
+ GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR;
+ GCC_WARN_UNDECLARED_SELECTOR = YES;
+ GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE;
+ GCC_WARN_UNUSED_FUNCTION = YES;
+ GCC_WARN_UNUSED_VARIABLE = YES;
+ MACOSX_DEPLOYMENT_TARGET = 10.15;
+ MTL_ENABLE_DEBUG_INFO = NO;
+ MTL_FAST_MATH = YES;
+ ONLY_ACTIVE_ARCH = YES;
+ SDKROOT = macosx;
+ };
+ name = Release;
+ };
+ 418B0A3624C5E19500DF2C21 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ EXECUTABLE_PREFIX = lib;
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ SKIP_INSTALL = YES;
+ };
+ name = Debug;
+ };
+ 418B0A3724C5E19500DF2C21 /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ EXECUTABLE_PREFIX = lib;
+ ONLY_ACTIVE_ARCH = YES;
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ SKIP_INSTALL = YES;
+ };
+ name = Release;
+ };
+ 418B0A7D24C5E25200DF2C21 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Debug;
+ };
+ 418B0A7E24C5E25200DF2C21 /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Release;
+ };
+ 418B0A9124C5E35200DF2C21 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ EXECUTABLE_PREFIX = lib;
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ SKIP_INSTALL = YES;
+ };
+ name = Debug;
+ };
+ 418B0A9224C5E35200DF2C21 /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ EXECUTABLE_PREFIX = lib;
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ SKIP_INSTALL = YES;
+ };
+ name = Release;
+ };
+ 418B0ABD24C5E42900DF2C21 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Debug;
+ };
+ 418B0ABE24C5E42900DF2C21 /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Release;
+ };
+ 418B0AD024C5E4EA00DF2C21 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Debug;
+ };
+ 418B0AD124C5E4EA00DF2C21 /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Release;
+ };
+ 418B0AE624C5E5C300DF2C21 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Debug;
+ };
+ 418B0AE724C5E5C300DF2C21 /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Release;
+ };
+ 418B0B0A24C5E76100DF2C21 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ HEADER_SEARCH_PATHS = /usr/local/include;
+ MACOSX_DEPLOYMENT_TARGET = 10.15;
+ OTHER_LDFLAGS = (
+ "-L",
+ /usr/local/lib,
+ "-ltiff",
+ );
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Debug;
+ };
+ 418B0B0B24C5E76100DF2C21 /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ HEADER_SEARCH_PATHS = /usr/local/include;
+ MACOSX_DEPLOYMENT_TARGET = 10.15;
+ OTHER_LDFLAGS = (
+ "-L",
+ /usr/local/lib,
+ "-ltiff",
+ );
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Release;
+ };
+ 418B0B1F24C5E85600DF2C21 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ HEADER_SEARCH_PATHS = /usr/local/include;
+ OTHER_LDFLAGS = (
+ "-L",
+ /usr/local/lib,
+ "-ltiff",
+ );
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Debug;
+ };
+ 418B0B2024C5E85600DF2C21 /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ HEADER_SEARCH_PATHS = /usr/local/include;
+ OTHER_LDFLAGS = (
+ "-L",
+ /usr/local/lib,
+ "-ltiff",
+ );
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Release;
+ };
+ 418B0B3424C5E95D00DF2C21 /* Debug */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ HEADER_SEARCH_PATHS = /usr/local/include;
+ OTHER_LDFLAGS = (
+ "-L",
+ /usr/local/lib,
+ "-ljpeg",
+ );
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Debug;
+ };
+ 418B0B3524C5E95D00DF2C21 /* Release */ = {
+ isa = XCBuildConfiguration;
+ buildSettings = {
+ CODE_SIGN_STYLE = Automatic;
+ HEADER_SEARCH_PATHS = /usr/local/include;
+ OTHER_LDFLAGS = (
+ "-L",
+ /usr/local/lib,
+ "-ljpeg",
+ );
+ PRODUCT_NAME = "$(TARGET_NAME)";
+ };
+ name = Release;
+ };
+/* End XCBuildConfiguration section */
+
+/* Begin XCConfigurationList section */
+ 418B0A2C24C5E19500DF2C21 /* Build configuration list for PBXProject "lcms2" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 418B0A3324C5E19500DF2C21 /* Debug */,
+ 418B0A3424C5E19500DF2C21 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 418B0A3524C5E19500DF2C21 /* Build configuration list for PBXNativeTarget "lcms2" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 418B0A3624C5E19500DF2C21 /* Debug */,
+ 418B0A3724C5E19500DF2C21 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 418B0A7C24C5E25200DF2C21 /* Build configuration list for PBXNativeTarget "testbed" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 418B0A7D24C5E25200DF2C21 /* Debug */,
+ 418B0A7E24C5E25200DF2C21 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 418B0A9024C5E35200DF2C21 /* Build configuration list for PBXNativeTarget "fast_float_plugin" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 418B0A9124C5E35200DF2C21 /* Debug */,
+ 418B0A9224C5E35200DF2C21 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 418B0ABC24C5E42900DF2C21 /* Build configuration list for PBXNativeTarget "fast_float_testbed" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 418B0ABD24C5E42900DF2C21 /* Debug */,
+ 418B0ABE24C5E42900DF2C21 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 418B0ACF24C5E4EA00DF2C21 /* Build configuration list for PBXNativeTarget "transicc" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 418B0AD024C5E4EA00DF2C21 /* Debug */,
+ 418B0AD124C5E4EA00DF2C21 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 418B0AE524C5E5C300DF2C21 /* Build configuration list for PBXNativeTarget "linkicc" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 418B0AE624C5E5C300DF2C21 /* Debug */,
+ 418B0AE724C5E5C300DF2C21 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 418B0B0924C5E76100DF2C21 /* Build configuration list for PBXNativeTarget "tificc" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 418B0B0A24C5E76100DF2C21 /* Debug */,
+ 418B0B0B24C5E76100DF2C21 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 418B0B1E24C5E85600DF2C21 /* Build configuration list for PBXNativeTarget "tifdiff" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 418B0B1F24C5E85600DF2C21 /* Debug */,
+ 418B0B2024C5E85600DF2C21 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+ 418B0B3324C5E95D00DF2C21 /* Build configuration list for PBXNativeTarget "jpegicc" */ = {
+ isa = XCConfigurationList;
+ buildConfigurations = (
+ 418B0B3424C5E95D00DF2C21 /* Debug */,
+ 418B0B3524C5E95D00DF2C21 /* Release */,
+ );
+ defaultConfigurationIsVisible = 0;
+ defaultConfigurationName = Release;
+ };
+/* End XCConfigurationList section */
+ };
+ rootObject = 418B0A2924C5E19500DF2C21 /* Project object */;
+}
diff --git a/lcms2mt/Projects/Xcode_12/lcms2/lcms2.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/lcms2mt/Projects/Xcode_12/lcms2/lcms2.xcodeproj/project.xcworkspace/contents.xcworkspacedata
new file mode 100644
index 00000000..ebae7845
--- /dev/null
+++ b/lcms2mt/Projects/Xcode_12/lcms2/lcms2.xcodeproj/project.xcworkspace/contents.xcworkspacedata
@@ -0,0 +1,7 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<Workspace
+ version = "1.0">
+ <FileRef
+ location = "self:lcms2.xcodeproj">
+ </FileRef>
+</Workspace>
diff --git a/lcms2mt/Projects/Xcode_12/lcms2/lcms2.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/lcms2mt/Projects/Xcode_12/lcms2/lcms2.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist
new file mode 100644
index 00000000..18d98100
--- /dev/null
+++ b/lcms2mt/Projects/Xcode_12/lcms2/lcms2.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist
@@ -0,0 +1,8 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
+<plist version="1.0">
+<dict>
+ <key>IDEDidComputeMac32BitWarning</key>
+ <true/>
+</dict>
+</plist>
diff --git a/lcms2mt/Projects/Xcode_12/lcms2/lcms2.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings b/lcms2mt/Projects/Xcode_12/lcms2/lcms2.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings
new file mode 100644
index 00000000..f9b0d7c5
--- /dev/null
+++ b/lcms2mt/Projects/Xcode_12/lcms2/lcms2.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings
@@ -0,0 +1,8 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
+<plist version="1.0">
+<dict>
+ <key>PreviewsEnabled</key>
+ <false/>
+</dict>
+</plist>
diff --git a/lcms2mt/autogen.sh b/lcms2mt/autogen.sh
index 0b8b74f0..a14ba21c 100755
--- a/lcms2mt/autogen.sh
+++ b/lcms2mt/autogen.sh
@@ -7,6 +7,16 @@ test -z "$srcdir" && srcdir=.
DIE=0
ACLOCAL_FLAGS="-I m4"
+if [ "$1" = "--distclean" ];
+then
+ make distclean
+ rm configure config.guess config.sub depcomp install-sh missing
+ rm aclocal.m4 compile ltmain.sh m4/libtool.m4 m4/ltoptions.m4
+ rm m4/ltsugar.m4 m4/lt~obsolete.m4 m4/ltversion.m4
+ echo done cleaning!
+ exit 0
+fi
+
(test -f $srcdir/configure.ac) || {
echo -n "**Error**: Directory $srcdir does not look like the"
echo " top-level package directory"
@@ -22,7 +32,7 @@ ACLOCAL_FLAGS="-I m4"
}
(grep "^LT_INIT" $srcdir/configure.ac >/dev/null) && {
- (libtool --version) < /dev/null > /dev/null 2>&1 || {
+ (libtoolize --version) < /dev/null > /dev/null 2>&1 || {
echo
echo "**Error**: You must have libtool installed."
echo "You can get it from: ftp://ftp.gnu.org/pub/gnu/"
diff --git a/lcms2mt/compile b/lcms2mt/compile
index 531136b0..a85b723c 100755
--- a/lcms2mt/compile
+++ b/lcms2mt/compile
@@ -3,7 +3,7 @@
scriptversion=2012-10-14.11; # UTC
-# Copyright (C) 1999-2013 Free Software Foundation, Inc.
+# Copyright (C) 1999-2014 Free Software Foundation, Inc.
# Written by Tom Tromey <tromey@cygnus.com>.
#
# This program is free software; you can redistribute it and/or modify
diff --git a/lcms2mt/config.guess b/lcms2mt/config.guess
index e7464614..f50dcdb6 100755
--- a/lcms2mt/config.guess
+++ b/lcms2mt/config.guess
@@ -1,8 +1,8 @@
#! /bin/sh
# Attempt to guess a canonical system name.
-# Copyright 1992-2014 Free Software Foundation, Inc.
+# Copyright 1992-2018 Free Software Foundation, Inc.
-timestamp='2014-11-04'
+timestamp='2018-02-24'
# This file is free software; you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by
@@ -15,7 +15,7 @@ timestamp='2014-11-04'
# General Public License for more details.
#
# You should have received a copy of the GNU General Public License
-# along with this program; if not, see <http://www.gnu.org/licenses/>.
+# along with this program; if not, see <https://www.gnu.org/licenses/>.
#
# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
@@ -27,7 +27,7 @@ timestamp='2014-11-04'
# Originally written by Per Bothner; maintained since 2000 by Ben Elliston.
#
# You can get the latest version of this script from:
-# http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess;hb=HEAD
+# https://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess
#
# Please send patches to <config-patches@gnu.org>.
@@ -39,7 +39,7 @@ Usage: $0 [OPTION]
Output the configuration name of the system \`$me' is run on.
-Operation modes:
+Options:
-h, --help print this help, then exit
-t, --time-stamp print date of last modification, then exit
-v, --version print version number, then exit
@@ -50,7 +50,7 @@ version="\
GNU config.guess ($timestamp)
Originally written by Per Bothner.
-Copyright 1992-2014 Free Software Foundation, Inc.
+Copyright 1992-2018 Free Software Foundation, Inc.
This is free software; see the source for copying conditions. There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
@@ -107,9 +107,9 @@ trap "rm -f \$tmpfiles 2>/dev/null; rmdir \$tmp 2>/dev/null; exit 1" 1 2 13 15 ;
dummy=$tmp/dummy ;
tmpfiles="$dummy.c $dummy.o $dummy.rel $dummy" ;
case $CC_FOR_BUILD,$HOST_CC,$CC in
- ,,) echo "int x;" > $dummy.c ;
+ ,,) echo "int x;" > "$dummy.c" ;
for c in cc gcc c89 c99 ; do
- if ($c -c -o $dummy.o $dummy.c) >/dev/null 2>&1 ; then
+ if ($c -c -o "$dummy.o" "$dummy.c") >/dev/null 2>&1 ; then
CC_FOR_BUILD="$c"; break ;
fi ;
done ;
@@ -132,14 +132,14 @@ UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown
UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown
UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown
-case "${UNAME_SYSTEM}" in
+case "$UNAME_SYSTEM" in
Linux|GNU|GNU/*)
# If the system lacks a compiler, then just pick glibc.
# We could probably try harder.
LIBC=gnu
- eval $set_cc_for_build
- cat <<-EOF > $dummy.c
+ eval "$set_cc_for_build"
+ cat <<-EOF > "$dummy.c"
#include <features.h>
#if defined(__UCLIBC__)
LIBC=uclibc
@@ -149,13 +149,20 @@ Linux|GNU|GNU/*)
LIBC=gnu
#endif
EOF
- eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^LIBC' | sed 's, ,,g'`
+ eval "`$CC_FOR_BUILD -E "$dummy.c" 2>/dev/null | grep '^LIBC' | sed 's, ,,g'`"
+
+ # If ldd exists, use it to detect musl libc.
+ if command -v ldd >/dev/null && \
+ ldd --version 2>&1 | grep -q ^musl
+ then
+ LIBC=musl
+ fi
;;
esac
# Note: order is significant - the case branches are not exclusive.
-case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
+case "$UNAME_MACHINE:$UNAME_SYSTEM:$UNAME_RELEASE:$UNAME_VERSION" in
*:NetBSD:*:*)
# NetBSD (nbsd) targets should (where applicable) match one or
# more of the tuples: *-*-netbsdelf*, *-*-netbsdaout*,
@@ -168,21 +175,31 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
# Note: NetBSD doesn't particularly care about the vendor
# portion of the name. We always set it to "unknown".
sysctl="sysctl -n hw.machine_arch"
- UNAME_MACHINE_ARCH=`(/sbin/$sysctl 2>/dev/null || \
- /usr/sbin/$sysctl 2>/dev/null || echo unknown)`
- case "${UNAME_MACHINE_ARCH}" in
+ UNAME_MACHINE_ARCH=`(uname -p 2>/dev/null || \
+ "/sbin/$sysctl" 2>/dev/null || \
+ "/usr/sbin/$sysctl" 2>/dev/null || \
+ echo unknown)`
+ case "$UNAME_MACHINE_ARCH" in
armeb) machine=armeb-unknown ;;
arm*) machine=arm-unknown ;;
sh3el) machine=shl-unknown ;;
sh3eb) machine=sh-unknown ;;
sh5el) machine=sh5le-unknown ;;
- *) machine=${UNAME_MACHINE_ARCH}-unknown ;;
+ earmv*)
+ arch=`echo "$UNAME_MACHINE_ARCH" | sed -e 's,^e\(armv[0-9]\).*$,\1,'`
+ endian=`echo "$UNAME_MACHINE_ARCH" | sed -ne 's,^.*\(eb\)$,\1,p'`
+ machine="${arch}${endian}"-unknown
+ ;;
+ *) machine="$UNAME_MACHINE_ARCH"-unknown ;;
esac
# The Operating System including object format, if it has switched
- # to ELF recently, or will in the future.
- case "${UNAME_MACHINE_ARCH}" in
+ # to ELF recently (or will in the future) and ABI.
+ case "$UNAME_MACHINE_ARCH" in
+ earm*)
+ os=netbsdelf
+ ;;
arm*|i386|m68k|ns32k|sh3*|sparc|vax)
- eval $set_cc_for_build
+ eval "$set_cc_for_build"
if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \
| grep -q __ELF__
then
@@ -197,44 +214,67 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
os=netbsd
;;
esac
+ # Determine ABI tags.
+ case "$UNAME_MACHINE_ARCH" in
+ earm*)
+ expr='s/^earmv[0-9]/-eabi/;s/eb$//'
+ abi=`echo "$UNAME_MACHINE_ARCH" | sed -e "$expr"`
+ ;;
+ esac
# The OS release
# Debian GNU/NetBSD machines have a different userland, and
# thus, need a distinct triplet. However, they do not need
# kernel version information, so it can be replaced with a
# suitable tag, in the style of linux-gnu.
- case "${UNAME_VERSION}" in
+ case "$UNAME_VERSION" in
Debian*)
release='-gnu'
;;
*)
- release=`echo ${UNAME_RELEASE}|sed -e 's/[-_].*/\./'`
+ release=`echo "$UNAME_RELEASE" | sed -e 's/[-_].*//' | cut -d. -f1,2`
;;
esac
# Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM:
# contains redundant information, the shorter form:
# CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used.
- echo "${machine}-${os}${release}"
+ echo "$machine-${os}${release}${abi}"
exit ;;
*:Bitrig:*:*)
UNAME_MACHINE_ARCH=`arch | sed 's/Bitrig.//'`
- echo ${UNAME_MACHINE_ARCH}-unknown-bitrig${UNAME_RELEASE}
+ echo "$UNAME_MACHINE_ARCH"-unknown-bitrig"$UNAME_RELEASE"
exit ;;
*:OpenBSD:*:*)
UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'`
- echo ${UNAME_MACHINE_ARCH}-unknown-openbsd${UNAME_RELEASE}
+ echo "$UNAME_MACHINE_ARCH"-unknown-openbsd"$UNAME_RELEASE"
+ exit ;;
+ *:LibertyBSD:*:*)
+ UNAME_MACHINE_ARCH=`arch | sed 's/^.*BSD\.//'`
+ echo "$UNAME_MACHINE_ARCH"-unknown-libertybsd"$UNAME_RELEASE"
+ exit ;;
+ *:MidnightBSD:*:*)
+ echo "$UNAME_MACHINE"-unknown-midnightbsd"$UNAME_RELEASE"
exit ;;
*:ekkoBSD:*:*)
- echo ${UNAME_MACHINE}-unknown-ekkobsd${UNAME_RELEASE}
+ echo "$UNAME_MACHINE"-unknown-ekkobsd"$UNAME_RELEASE"
exit ;;
*:SolidBSD:*:*)
- echo ${UNAME_MACHINE}-unknown-solidbsd${UNAME_RELEASE}
+ echo "$UNAME_MACHINE"-unknown-solidbsd"$UNAME_RELEASE"
exit ;;
macppc:MirBSD:*:*)
- echo powerpc-unknown-mirbsd${UNAME_RELEASE}
+ echo powerpc-unknown-mirbsd"$UNAME_RELEASE"
exit ;;
*:MirBSD:*:*)
- echo ${UNAME_MACHINE}-unknown-mirbsd${UNAME_RELEASE}
+ echo "$UNAME_MACHINE"-unknown-mirbsd"$UNAME_RELEASE"
+ exit ;;
+ *:Sortix:*:*)
+ echo "$UNAME_MACHINE"-unknown-sortix
exit ;;
+ *:Redox:*:*)
+ echo "$UNAME_MACHINE"-unknown-redox
+ exit ;;
+ mips:OSF1:*.*)
+ echo mips-dec-osf1
+ exit ;;
alpha:OSF1:*:*)
case $UNAME_RELEASE in
*4.0)
@@ -251,63 +291,54 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^ The alpha \(.*\) processor.*$/\1/p' | head -n 1`
case "$ALPHA_CPU_TYPE" in
"EV4 (21064)")
- UNAME_MACHINE="alpha" ;;
+ UNAME_MACHINE=alpha ;;
"EV4.5 (21064)")
- UNAME_MACHINE="alpha" ;;
+ UNAME_MACHINE=alpha ;;
"LCA4 (21066/21068)")
- UNAME_MACHINE="alpha" ;;
+ UNAME_MACHINE=alpha ;;
"EV5 (21164)")
- UNAME_MACHINE="alphaev5" ;;
+ UNAME_MACHINE=alphaev5 ;;
"EV5.6 (21164A)")
- UNAME_MACHINE="alphaev56" ;;
+ UNAME_MACHINE=alphaev56 ;;
"EV5.6 (21164PC)")
- UNAME_MACHINE="alphapca56" ;;
+ UNAME_MACHINE=alphapca56 ;;
"EV5.7 (21164PC)")
- UNAME_MACHINE="alphapca57" ;;
+ UNAME_MACHINE=alphapca57 ;;
"EV6 (21264)")
- UNAME_MACHINE="alphaev6" ;;
+ UNAME_MACHINE=alphaev6 ;;
"EV6.7 (21264A)")
- UNAME_MACHINE="alphaev67" ;;
+ UNAME_MACHINE=alphaev67 ;;
"EV6.8CB (21264C)")
- UNAME_MACHINE="alphaev68" ;;
+ UNAME_MACHINE=alphaev68 ;;
"EV6.8AL (21264B)")
- UNAME_MACHINE="alphaev68" ;;
+ UNAME_MACHINE=alphaev68 ;;
"EV6.8CX (21264D)")
- UNAME_MACHINE="alphaev68" ;;
+ UNAME_MACHINE=alphaev68 ;;
"EV6.9A (21264/EV69A)")
- UNAME_MACHINE="alphaev69" ;;
+ UNAME_MACHINE=alphaev69 ;;
"EV7 (21364)")
- UNAME_MACHINE="alphaev7" ;;
+ UNAME_MACHINE=alphaev7 ;;
"EV7.9 (21364A)")
- UNAME_MACHINE="alphaev79" ;;
+ UNAME_MACHINE=alphaev79 ;;
esac
# A Pn.n version is a patched version.
# A Vn.n version is a released version.
# A Tn.n version is a released field test version.
# A Xn.n version is an unreleased experimental baselevel.
# 1.2 uses "1.2" for uname -r.
- echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[PVTX]//' | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
+ echo "$UNAME_MACHINE"-dec-osf"`echo "$UNAME_RELEASE" | sed -e 's/^[PVTX]//' | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz`"
# Reset EXIT trap before exiting to avoid spurious non-zero exit code.
exitcode=$?
trap '' 0
exit $exitcode ;;
- Alpha\ *:Windows_NT*:*)
- # How do we know it's Interix rather than the generic POSIX subsystem?
- # Should we change UNAME_MACHINE based on the output of uname instead
- # of the specific Alpha model?
- echo alpha-pc-interix
- exit ;;
- 21064:Windows_NT:50:3)
- echo alpha-dec-winnt3.5
- exit ;;
Amiga*:UNIX_System_V:4.0:*)
echo m68k-unknown-sysv4
exit ;;
*:[Aa]miga[Oo][Ss]:*:*)
- echo ${UNAME_MACHINE}-unknown-amigaos
+ echo "$UNAME_MACHINE"-unknown-amigaos
exit ;;
*:[Mm]orph[Oo][Ss]:*:*)
- echo ${UNAME_MACHINE}-unknown-morphos
+ echo "$UNAME_MACHINE"-unknown-morphos
exit ;;
*:OS/390:*:*)
echo i370-ibm-openedition
@@ -319,7 +350,7 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
echo powerpc-ibm-os400
exit ;;
arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*)
- echo arm-acorn-riscix${UNAME_RELEASE}
+ echo arm-acorn-riscix"$UNAME_RELEASE"
exit ;;
arm*:riscos:*:*|arm*:RISCOS:*:*)
echo arm-unknown-riscos
@@ -346,38 +377,38 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
sparc) echo sparc-icl-nx7; exit ;;
esac ;;
s390x:SunOS:*:*)
- echo ${UNAME_MACHINE}-ibm-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+ echo "$UNAME_MACHINE"-ibm-solaris2"`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'`"
exit ;;
sun4H:SunOS:5.*:*)
- echo sparc-hal-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+ echo sparc-hal-solaris2"`echo "$UNAME_RELEASE"|sed -e 's/[^.]*//'`"
exit ;;
sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*)
- echo sparc-sun-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+ echo sparc-sun-solaris2"`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'`"
exit ;;
i86pc:AuroraUX:5.*:* | i86xen:AuroraUX:5.*:*)
- echo i386-pc-auroraux${UNAME_RELEASE}
+ echo i386-pc-auroraux"$UNAME_RELEASE"
exit ;;
i86pc:SunOS:5.*:* | i86xen:SunOS:5.*:*)
- eval $set_cc_for_build
- SUN_ARCH="i386"
+ eval "$set_cc_for_build"
+ SUN_ARCH=i386
# If there is a compiler, see if it is configured for 64-bit objects.
# Note that the Sun cc does not turn __LP64__ into 1 like gcc does.
# This test works for both compilers.
- if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then
+ if [ "$CC_FOR_BUILD" != no_compiler_found ]; then
if (echo '#ifdef __amd64'; echo IS_64BIT_ARCH; echo '#endif') | \
- (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \
+ (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) | \
grep IS_64BIT_ARCH >/dev/null
then
- SUN_ARCH="x86_64"
+ SUN_ARCH=x86_64
fi
fi
- echo ${SUN_ARCH}-pc-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+ echo "$SUN_ARCH"-pc-solaris2"`echo "$UNAME_RELEASE"|sed -e 's/[^.]*//'`"
exit ;;
sun4*:SunOS:6*:*)
# According to config.sub, this is the proper way to canonicalize
# SunOS6. Hard to guess exactly what SunOS6 will be like, but
# it's likely to be more like Solaris than SunOS4.
- echo sparc-sun-solaris3`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+ echo sparc-sun-solaris3"`echo "$UNAME_RELEASE"|sed -e 's/[^.]*//'`"
exit ;;
sun4*:SunOS:*:*)
case "`/usr/bin/arch -k`" in
@@ -386,25 +417,25 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
;;
esac
# Japanese Language versions have a version number like `4.1.3-JL'.
- echo sparc-sun-sunos`echo ${UNAME_RELEASE}|sed -e 's/-/_/'`
+ echo sparc-sun-sunos"`echo "$UNAME_RELEASE"|sed -e 's/-/_/'`"
exit ;;
sun3*:SunOS:*:*)
- echo m68k-sun-sunos${UNAME_RELEASE}
+ echo m68k-sun-sunos"$UNAME_RELEASE"
exit ;;
sun*:*:4.2BSD:*)
UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null`
- test "x${UNAME_RELEASE}" = "x" && UNAME_RELEASE=3
+ test "x$UNAME_RELEASE" = x && UNAME_RELEASE=3
case "`/bin/arch`" in
sun3)
- echo m68k-sun-sunos${UNAME_RELEASE}
+ echo m68k-sun-sunos"$UNAME_RELEASE"
;;
sun4)
- echo sparc-sun-sunos${UNAME_RELEASE}
+ echo sparc-sun-sunos"$UNAME_RELEASE"
;;
esac
exit ;;
aushp:SunOS:*:*)
- echo sparc-auspex-sunos${UNAME_RELEASE}
+ echo sparc-auspex-sunos"$UNAME_RELEASE"
exit ;;
# The situation for MiNT is a little confusing. The machine name
# can be virtually everything (everything which is not
@@ -415,44 +446,44 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
# MiNT. But MiNT is downward compatible to TOS, so this should
# be no problem.
atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*)
- echo m68k-atari-mint${UNAME_RELEASE}
+ echo m68k-atari-mint"$UNAME_RELEASE"
exit ;;
atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*)
- echo m68k-atari-mint${UNAME_RELEASE}
+ echo m68k-atari-mint"$UNAME_RELEASE"
exit ;;
*falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*)
- echo m68k-atari-mint${UNAME_RELEASE}
+ echo m68k-atari-mint"$UNAME_RELEASE"
exit ;;
milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*)
- echo m68k-milan-mint${UNAME_RELEASE}
+ echo m68k-milan-mint"$UNAME_RELEASE"
exit ;;
hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*)
- echo m68k-hades-mint${UNAME_RELEASE}
+ echo m68k-hades-mint"$UNAME_RELEASE"
exit ;;
*:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*)
- echo m68k-unknown-mint${UNAME_RELEASE}
+ echo m68k-unknown-mint"$UNAME_RELEASE"
exit ;;
m68k:machten:*:*)
- echo m68k-apple-machten${UNAME_RELEASE}
+ echo m68k-apple-machten"$UNAME_RELEASE"
exit ;;
powerpc:machten:*:*)
- echo powerpc-apple-machten${UNAME_RELEASE}
+ echo powerpc-apple-machten"$UNAME_RELEASE"
exit ;;
RISC*:Mach:*:*)
echo mips-dec-mach_bsd4.3
exit ;;
RISC*:ULTRIX:*:*)
- echo mips-dec-ultrix${UNAME_RELEASE}
+ echo mips-dec-ultrix"$UNAME_RELEASE"
exit ;;
VAX*:ULTRIX*:*:*)
- echo vax-dec-ultrix${UNAME_RELEASE}
+ echo vax-dec-ultrix"$UNAME_RELEASE"
exit ;;
2020:CLIX:*:* | 2430:CLIX:*:*)
- echo clipper-intergraph-clix${UNAME_RELEASE}
+ echo clipper-intergraph-clix"$UNAME_RELEASE"
exit ;;
mips:*:*:UMIPS | mips:*:*:RISCos)
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
+ eval "$set_cc_for_build"
+ sed 's/^ //' << EOF > "$dummy.c"
#ifdef __cplusplus
#include <stdio.h> /* for printf() prototype */
int main (int argc, char *argv[]) {
@@ -461,23 +492,23 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
#endif
#if defined (host_mips) && defined (MIPSEB)
#if defined (SYSTYPE_SYSV)
- printf ("mips-mips-riscos%ssysv\n", argv[1]); exit (0);
+ printf ("mips-mips-riscos%ssysv\\n", argv[1]); exit (0);
#endif
#if defined (SYSTYPE_SVR4)
- printf ("mips-mips-riscos%ssvr4\n", argv[1]); exit (0);
+ printf ("mips-mips-riscos%ssvr4\\n", argv[1]); exit (0);
#endif
#if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD)
- printf ("mips-mips-riscos%sbsd\n", argv[1]); exit (0);
+ printf ("mips-mips-riscos%sbsd\\n", argv[1]); exit (0);
#endif
#endif
exit (-1);
}
EOF
- $CC_FOR_BUILD -o $dummy $dummy.c &&
- dummyarg=`echo "${UNAME_RELEASE}" | sed -n 's/\([0-9]*\).*/\1/p'` &&
- SYSTEM_NAME=`$dummy $dummyarg` &&
+ $CC_FOR_BUILD -o "$dummy" "$dummy.c" &&
+ dummyarg=`echo "$UNAME_RELEASE" | sed -n 's/\([0-9]*\).*/\1/p'` &&
+ SYSTEM_NAME=`"$dummy" "$dummyarg"` &&
{ echo "$SYSTEM_NAME"; exit; }
- echo mips-mips-riscos${UNAME_RELEASE}
+ echo mips-mips-riscos"$UNAME_RELEASE"
exit ;;
Motorola:PowerMAX_OS:*:*)
echo powerpc-motorola-powermax
@@ -503,17 +534,17 @@ EOF
AViiON:dgux:*:*)
# DG/UX returns AViiON for all architectures
UNAME_PROCESSOR=`/usr/bin/uname -p`
- if [ $UNAME_PROCESSOR = mc88100 ] || [ $UNAME_PROCESSOR = mc88110 ]
+ if [ "$UNAME_PROCESSOR" = mc88100 ] || [ "$UNAME_PROCESSOR" = mc88110 ]
then
- if [ ${TARGET_BINARY_INTERFACE}x = m88kdguxelfx ] || \
- [ ${TARGET_BINARY_INTERFACE}x = x ]
+ if [ "$TARGET_BINARY_INTERFACE"x = m88kdguxelfx ] || \
+ [ "$TARGET_BINARY_INTERFACE"x = x ]
then
- echo m88k-dg-dgux${UNAME_RELEASE}
+ echo m88k-dg-dgux"$UNAME_RELEASE"
else
- echo m88k-dg-dguxbcs${UNAME_RELEASE}
+ echo m88k-dg-dguxbcs"$UNAME_RELEASE"
fi
else
- echo i586-dg-dgux${UNAME_RELEASE}
+ echo i586-dg-dgux"$UNAME_RELEASE"
fi
exit ;;
M88*:DolphinOS:*:*) # DolphinOS (SVR3)
@@ -530,7 +561,7 @@ EOF
echo m68k-tektronix-bsd
exit ;;
*:IRIX*:*:*)
- echo mips-sgi-irix`echo ${UNAME_RELEASE}|sed -e 's/-/_/g'`
+ echo mips-sgi-irix"`echo "$UNAME_RELEASE"|sed -e 's/-/_/g'`"
exit ;;
????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX.
echo romp-ibm-aix # uname -m gives an 8 hex-code CPU id
@@ -542,14 +573,14 @@ EOF
if [ -x /usr/bin/oslevel ] ; then
IBM_REV=`/usr/bin/oslevel`
else
- IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
+ IBM_REV="$UNAME_VERSION.$UNAME_RELEASE"
fi
- echo ${UNAME_MACHINE}-ibm-aix${IBM_REV}
+ echo "$UNAME_MACHINE"-ibm-aix"$IBM_REV"
exit ;;
*:AIX:2:3)
if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
+ eval "$set_cc_for_build"
+ sed 's/^ //' << EOF > "$dummy.c"
#include <sys/systemcfg.h>
main()
@@ -560,7 +591,7 @@ EOF
exit(0);
}
EOF
- if $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy`
+ if $CC_FOR_BUILD -o "$dummy" "$dummy.c" && SYSTEM_NAME=`"$dummy"`
then
echo "$SYSTEM_NAME"
else
@@ -574,7 +605,7 @@ EOF
exit ;;
*:AIX:*:[4567])
IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'`
- if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then
+ if /usr/sbin/lsattr -El "$IBM_CPU_ID" | grep ' POWER' >/dev/null 2>&1; then
IBM_ARCH=rs6000
else
IBM_ARCH=powerpc
@@ -583,18 +614,18 @@ EOF
IBM_REV=`/usr/bin/lslpp -Lqc bos.rte.libc |
awk -F: '{ print $3 }' | sed s/[0-9]*$/0/`
else
- IBM_REV=${UNAME_VERSION}.${UNAME_RELEASE}
+ IBM_REV="$UNAME_VERSION.$UNAME_RELEASE"
fi
- echo ${IBM_ARCH}-ibm-aix${IBM_REV}
+ echo "$IBM_ARCH"-ibm-aix"$IBM_REV"
exit ;;
*:AIX:*:*)
echo rs6000-ibm-aix
exit ;;
- ibmrt:4.4BSD:*|romp-ibm:BSD:*)
+ ibmrt:4.4BSD:*|romp-ibm:4.4BSD:*)
echo romp-ibm-bsd4.4
exit ;;
ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC BSD and
- echo romp-ibm-bsd${UNAME_RELEASE} # 4.3 with uname added to
+ echo romp-ibm-bsd"$UNAME_RELEASE" # 4.3 with uname added to
exit ;; # report: romp-ibm BSD 4.3
*:BOSX:*:*)
echo rs6000-bull-bosx
@@ -609,28 +640,28 @@ EOF
echo m68k-hp-bsd4.4
exit ;;
9000/[34678]??:HP-UX:*:*)
- HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
- case "${UNAME_MACHINE}" in
- 9000/31? ) HP_ARCH=m68000 ;;
- 9000/[34]?? ) HP_ARCH=m68k ;;
+ HPUX_REV=`echo "$UNAME_RELEASE"|sed -e 's/[^.]*.[0B]*//'`
+ case "$UNAME_MACHINE" in
+ 9000/31?) HP_ARCH=m68000 ;;
+ 9000/[34]??) HP_ARCH=m68k ;;
9000/[678][0-9][0-9])
if [ -x /usr/bin/getconf ]; then
sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null`
sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null`
- case "${sc_cpu_version}" in
- 523) HP_ARCH="hppa1.0" ;; # CPU_PA_RISC1_0
- 528) HP_ARCH="hppa1.1" ;; # CPU_PA_RISC1_1
+ case "$sc_cpu_version" in
+ 523) HP_ARCH=hppa1.0 ;; # CPU_PA_RISC1_0
+ 528) HP_ARCH=hppa1.1 ;; # CPU_PA_RISC1_1
532) # CPU_PA_RISC2_0
- case "${sc_kernel_bits}" in
- 32) HP_ARCH="hppa2.0n" ;;
- 64) HP_ARCH="hppa2.0w" ;;
- '') HP_ARCH="hppa2.0" ;; # HP-UX 10.20
+ case "$sc_kernel_bits" in
+ 32) HP_ARCH=hppa2.0n ;;
+ 64) HP_ARCH=hppa2.0w ;;
+ '') HP_ARCH=hppa2.0 ;; # HP-UX 10.20
esac ;;
esac
fi
- if [ "${HP_ARCH}" = "" ]; then
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
+ if [ "$HP_ARCH" = "" ]; then
+ eval "$set_cc_for_build"
+ sed 's/^ //' << EOF > "$dummy.c"
#define _HPUX_SOURCE
#include <stdlib.h>
@@ -663,13 +694,13 @@ EOF
exit (0);
}
EOF
- (CCOPTS= $CC_FOR_BUILD -o $dummy $dummy.c 2>/dev/null) && HP_ARCH=`$dummy`
+ (CCOPTS="" $CC_FOR_BUILD -o "$dummy" "$dummy.c" 2>/dev/null) && HP_ARCH=`"$dummy"`
test -z "$HP_ARCH" && HP_ARCH=hppa
fi ;;
esac
- if [ ${HP_ARCH} = "hppa2.0w" ]
+ if [ "$HP_ARCH" = hppa2.0w ]
then
- eval $set_cc_for_build
+ eval "$set_cc_for_build"
# hppa2.0w-hp-hpux* has a 64-bit kernel and a compiler generating
# 32-bit code. hppa64-hp-hpux* has the same kernel and a compiler
@@ -680,23 +711,23 @@ EOF
# $ CC_FOR_BUILD="cc +DA2.0w" ./config.guess
# => hppa64-hp-hpux11.23
- if echo __LP64__ | (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) |
+ if echo __LP64__ | (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) |
grep -q __LP64__
then
- HP_ARCH="hppa2.0w"
+ HP_ARCH=hppa2.0w
else
- HP_ARCH="hppa64"
+ HP_ARCH=hppa64
fi
fi
- echo ${HP_ARCH}-hp-hpux${HPUX_REV}
+ echo "$HP_ARCH"-hp-hpux"$HPUX_REV"
exit ;;
ia64:HP-UX:*:*)
- HPUX_REV=`echo ${UNAME_RELEASE}|sed -e 's/[^.]*.[0B]*//'`
- echo ia64-hp-hpux${HPUX_REV}
+ HPUX_REV=`echo "$UNAME_RELEASE"|sed -e 's/[^.]*.[0B]*//'`
+ echo ia64-hp-hpux"$HPUX_REV"
exit ;;
3050*:HI-UX:*:*)
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
+ eval "$set_cc_for_build"
+ sed 's/^ //' << EOF > "$dummy.c"
#include <unistd.h>
int
main ()
@@ -721,11 +752,11 @@ EOF
exit (0);
}
EOF
- $CC_FOR_BUILD -o $dummy $dummy.c && SYSTEM_NAME=`$dummy` &&
+ $CC_FOR_BUILD -o "$dummy" "$dummy.c" && SYSTEM_NAME=`"$dummy"` &&
{ echo "$SYSTEM_NAME"; exit; }
echo unknown-hitachi-hiuxwe2
exit ;;
- 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:* )
+ 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:*)
echo hppa1.1-hp-bsd
exit ;;
9000/8??:4.3bsd:*:*)
@@ -734,7 +765,7 @@ EOF
*9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*)
echo hppa1.0-hp-mpeix
exit ;;
- hp7??:OSF1:*:* | hp8?[79]:OSF1:*:* )
+ hp7??:OSF1:*:* | hp8?[79]:OSF1:*:*)
echo hppa1.1-hp-osf
exit ;;
hp8??:OSF1:*:*)
@@ -742,9 +773,9 @@ EOF
exit ;;
i*86:OSF1:*:*)
if [ -x /usr/sbin/sysversion ] ; then
- echo ${UNAME_MACHINE}-unknown-osf1mk
+ echo "$UNAME_MACHINE"-unknown-osf1mk
else
- echo ${UNAME_MACHINE}-unknown-osf1
+ echo "$UNAME_MACHINE"-unknown-osf1
fi
exit ;;
parisc*:Lites*:*:*)
@@ -769,127 +800,109 @@ EOF
echo c4-convex-bsd
exit ;;
CRAY*Y-MP:*:*:*)
- echo ymp-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
+ echo ymp-cray-unicos"$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'
exit ;;
CRAY*[A-Z]90:*:*:*)
- echo ${UNAME_MACHINE}-cray-unicos${UNAME_RELEASE} \
+ echo "$UNAME_MACHINE"-cray-unicos"$UNAME_RELEASE" \
| sed -e 's/CRAY.*\([A-Z]90\)/\1/' \
-e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \
-e 's/\.[^.]*$/.X/'
exit ;;
CRAY*TS:*:*:*)
- echo t90-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
+ echo t90-cray-unicos"$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'
exit ;;
CRAY*T3E:*:*:*)
- echo alphaev5-cray-unicosmk${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
+ echo alphaev5-cray-unicosmk"$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'
exit ;;
CRAY*SV1:*:*:*)
- echo sv1-cray-unicos${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
+ echo sv1-cray-unicos"$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'
exit ;;
*:UNICOS/mp:*:*)
- echo craynv-cray-unicosmp${UNAME_RELEASE} | sed -e 's/\.[^.]*$/.X/'
+ echo craynv-cray-unicosmp"$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'
exit ;;
F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*)
- FUJITSU_PROC=`uname -m | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
- FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'`
- FUJITSU_REL=`echo ${UNAME_RELEASE} | sed -e 's/ /_/'`
+ FUJITSU_PROC=`uname -m | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz`
+ FUJITSU_SYS=`uname -p | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz | sed -e 's/\///'`
+ FUJITSU_REL=`echo "$UNAME_RELEASE" | sed -e 's/ /_/'`
echo "${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}"
exit ;;
5000:UNIX_System_V:4.*:*)
- FUJITSU_SYS=`uname -p | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/\///'`
- FUJITSU_REL=`echo ${UNAME_RELEASE} | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz' | sed -e 's/ /_/'`
+ FUJITSU_SYS=`uname -p | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz | sed -e 's/\///'`
+ FUJITSU_REL=`echo "$UNAME_RELEASE" | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz | sed -e 's/ /_/'`
echo "sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL}"
exit ;;
i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*)
- echo ${UNAME_MACHINE}-pc-bsdi${UNAME_RELEASE}
+ echo "$UNAME_MACHINE"-pc-bsdi"$UNAME_RELEASE"
exit ;;
sparc*:BSD/OS:*:*)
- echo sparc-unknown-bsdi${UNAME_RELEASE}
+ echo sparc-unknown-bsdi"$UNAME_RELEASE"
exit ;;
*:BSD/OS:*:*)
- echo ${UNAME_MACHINE}-unknown-bsdi${UNAME_RELEASE}
+ echo "$UNAME_MACHINE"-unknown-bsdi"$UNAME_RELEASE"
exit ;;
*:FreeBSD:*:*)
UNAME_PROCESSOR=`/usr/bin/uname -p`
- case ${UNAME_PROCESSOR} in
+ case "$UNAME_PROCESSOR" in
amd64)
- echo x86_64-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;;
- *)
- echo ${UNAME_PROCESSOR}-unknown-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;;
+ UNAME_PROCESSOR=x86_64 ;;
+ i386)
+ UNAME_PROCESSOR=i586 ;;
esac
+ echo "$UNAME_PROCESSOR"-unknown-freebsd"`echo "$UNAME_RELEASE"|sed -e 's/[-(].*//'`"
exit ;;
i*:CYGWIN*:*)
- echo ${UNAME_MACHINE}-pc-cygwin
+ echo "$UNAME_MACHINE"-pc-cygwin
exit ;;
*:MINGW64*:*)
- echo ${UNAME_MACHINE}-pc-mingw64
+ echo "$UNAME_MACHINE"-pc-mingw64
exit ;;
*:MINGW*:*)
- echo ${UNAME_MACHINE}-pc-mingw32
+ echo "$UNAME_MACHINE"-pc-mingw32
exit ;;
*:MSYS*:*)
- echo ${UNAME_MACHINE}-pc-msys
- exit ;;
- i*:windows32*:*)
- # uname -m includes "-pc" on this system.
- echo ${UNAME_MACHINE}-mingw32
+ echo "$UNAME_MACHINE"-pc-msys
exit ;;
i*:PW*:*)
- echo ${UNAME_MACHINE}-pc-pw32
+ echo "$UNAME_MACHINE"-pc-pw32
exit ;;
*:Interix*:*)
- case ${UNAME_MACHINE} in
+ case "$UNAME_MACHINE" in
x86)
- echo i586-pc-interix${UNAME_RELEASE}
+ echo i586-pc-interix"$UNAME_RELEASE"
exit ;;
authenticamd | genuineintel | EM64T)
- echo x86_64-unknown-interix${UNAME_RELEASE}
+ echo x86_64-unknown-interix"$UNAME_RELEASE"
exit ;;
IA64)
- echo ia64-unknown-interix${UNAME_RELEASE}
+ echo ia64-unknown-interix"$UNAME_RELEASE"
exit ;;
esac ;;
- [345]86:Windows_95:* | [345]86:Windows_98:* | [345]86:Windows_NT:*)
- echo i${UNAME_MACHINE}-pc-mks
- exit ;;
- 8664:Windows_NT:*)
- echo x86_64-pc-mks
- exit ;;
- i*:Windows_NT*:* | Pentium*:Windows_NT*:*)
- # How do we know it's Interix rather than the generic POSIX subsystem?
- # It also conflicts with pre-2.0 versions of AT&T UWIN. Should we
- # UNAME_MACHINE based on the output of uname instead of i386?
- echo i586-pc-interix
- exit ;;
i*:UWIN*:*)
- echo ${UNAME_MACHINE}-pc-uwin
+ echo "$UNAME_MACHINE"-pc-uwin
exit ;;
amd64:CYGWIN*:*:* | x86_64:CYGWIN*:*:*)
echo x86_64-unknown-cygwin
exit ;;
- p*:CYGWIN*:*)
- echo powerpcle-unknown-cygwin
- exit ;;
prep*:SunOS:5.*:*)
- echo powerpcle-unknown-solaris2`echo ${UNAME_RELEASE}|sed -e 's/[^.]*//'`
+ echo powerpcle-unknown-solaris2"`echo "$UNAME_RELEASE"|sed -e 's/[^.]*//'`"
exit ;;
*:GNU:*:*)
# the GNU system
- echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-unknown-${LIBC}`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'`
+ echo "`echo "$UNAME_MACHINE"|sed -e 's,[-/].*$,,'`-unknown-$LIBC`echo "$UNAME_RELEASE"|sed -e 's,/.*$,,'`"
exit ;;
*:GNU/*:*:*)
# other systems with GNU libc and userland
- echo ${UNAME_MACHINE}-unknown-`echo ${UNAME_SYSTEM} | sed 's,^[^/]*/,,' | tr '[A-Z]' '[a-z]'``echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`-${LIBC}
+ echo "$UNAME_MACHINE-unknown-`echo "$UNAME_SYSTEM" | sed 's,^[^/]*/,,' | tr "[:upper:]" "[:lower:]"``echo "$UNAME_RELEASE"|sed -e 's/[-(].*//'`-$LIBC"
exit ;;
i*86:Minix:*:*)
- echo ${UNAME_MACHINE}-pc-minix
+ echo "$UNAME_MACHINE"-pc-minix
exit ;;
aarch64:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
aarch64_be:Linux:*:*)
UNAME_MACHINE=aarch64_be
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
alpha:Linux:*:*)
case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in
@@ -902,58 +915,64 @@ EOF
EV68*) UNAME_MACHINE=alphaev68 ;;
esac
objdump --private-headers /bin/sh | grep -q ld.so.1
- if test "$?" = 0 ; then LIBC="gnulibc1" ; fi
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ if test "$?" = 0 ; then LIBC=gnulibc1 ; fi
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
arc:Linux:*:* | arceb:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
arm*:Linux:*:*)
- eval $set_cc_for_build
+ eval "$set_cc_for_build"
if echo __ARM_EABI__ | $CC_FOR_BUILD -E - 2>/dev/null \
| grep -q __ARM_EABI__
then
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
else
if echo __ARM_PCS_VFP | $CC_FOR_BUILD -E - 2>/dev/null \
| grep -q __ARM_PCS_VFP
then
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}eabi
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"eabi
else
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}eabihf
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"eabihf
fi
fi
exit ;;
avr32*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
cris:Linux:*:*)
- echo ${UNAME_MACHINE}-axis-linux-${LIBC}
+ echo "$UNAME_MACHINE"-axis-linux-"$LIBC"
exit ;;
crisv32:Linux:*:*)
- echo ${UNAME_MACHINE}-axis-linux-${LIBC}
+ echo "$UNAME_MACHINE"-axis-linux-"$LIBC"
+ exit ;;
+ e2k:Linux:*:*)
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
frv:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
hexagon:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
i*86:Linux:*:*)
- echo ${UNAME_MACHINE}-pc-linux-${LIBC}
+ echo "$UNAME_MACHINE"-pc-linux-"$LIBC"
exit ;;
ia64:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
+ exit ;;
+ k1om:Linux:*:*)
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
m32r*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
m68*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
mips:Linux:*:* | mips64:Linux:*:*)
- eval $set_cc_for_build
- sed 's/^ //' << EOF >$dummy.c
+ eval "$set_cc_for_build"
+ sed 's/^ //' << EOF > "$dummy.c"
#undef CPU
#undef ${UNAME_MACHINE}
#undef ${UNAME_MACHINE}el
@@ -967,64 +986,74 @@ EOF
#endif
#endif
EOF
- eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^CPU'`
- test x"${CPU}" != x && { echo "${CPU}-unknown-linux-${LIBC}"; exit; }
+ eval "`$CC_FOR_BUILD -E "$dummy.c" 2>/dev/null | grep '^CPU'`"
+ test "x$CPU" != x && { echo "$CPU-unknown-linux-$LIBC"; exit; }
;;
+ mips64el:Linux:*:*)
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
+ exit ;;
openrisc*:Linux:*:*)
- echo or1k-unknown-linux-${LIBC}
+ echo or1k-unknown-linux-"$LIBC"
exit ;;
or32:Linux:*:* | or1k*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
padre:Linux:*:*)
- echo sparc-unknown-linux-${LIBC}
+ echo sparc-unknown-linux-"$LIBC"
exit ;;
parisc64:Linux:*:* | hppa64:Linux:*:*)
- echo hppa64-unknown-linux-${LIBC}
+ echo hppa64-unknown-linux-"$LIBC"
exit ;;
parisc:Linux:*:* | hppa:Linux:*:*)
# Look for CPU level
case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in
- PA7*) echo hppa1.1-unknown-linux-${LIBC} ;;
- PA8*) echo hppa2.0-unknown-linux-${LIBC} ;;
- *) echo hppa-unknown-linux-${LIBC} ;;
+ PA7*) echo hppa1.1-unknown-linux-"$LIBC" ;;
+ PA8*) echo hppa2.0-unknown-linux-"$LIBC" ;;
+ *) echo hppa-unknown-linux-"$LIBC" ;;
esac
exit ;;
ppc64:Linux:*:*)
- echo powerpc64-unknown-linux-${LIBC}
+ echo powerpc64-unknown-linux-"$LIBC"
exit ;;
ppc:Linux:*:*)
- echo powerpc-unknown-linux-${LIBC}
+ echo powerpc-unknown-linux-"$LIBC"
exit ;;
ppc64le:Linux:*:*)
- echo powerpc64le-unknown-linux-${LIBC}
+ echo powerpc64le-unknown-linux-"$LIBC"
exit ;;
ppcle:Linux:*:*)
- echo powerpcle-unknown-linux-${LIBC}
+ echo powerpcle-unknown-linux-"$LIBC"
+ exit ;;
+ riscv32:Linux:*:* | riscv64:Linux:*:*)
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
s390:Linux:*:* | s390x:Linux:*:*)
- echo ${UNAME_MACHINE}-ibm-linux-${LIBC}
+ echo "$UNAME_MACHINE"-ibm-linux-"$LIBC"
exit ;;
sh64*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
sh*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
sparc:Linux:*:* | sparc64:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
tile*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
vax:Linux:*:*)
- echo ${UNAME_MACHINE}-dec-linux-${LIBC}
+ echo "$UNAME_MACHINE"-dec-linux-"$LIBC"
exit ;;
x86_64:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ if objdump -f /bin/sh | grep -q elf32-x86-64; then
+ echo "$UNAME_MACHINE"-pc-linux-"$LIBC"x32
+ else
+ echo "$UNAME_MACHINE"-pc-linux-"$LIBC"
+ fi
exit ;;
xtensa*:Linux:*:*)
- echo ${UNAME_MACHINE}-unknown-linux-${LIBC}
+ echo "$UNAME_MACHINE"-unknown-linux-"$LIBC"
exit ;;
i*86:DYNIX/ptx:4*:*)
# ptx 4.0 does uname -s correctly, with DYNIX/ptx in there.
@@ -1038,34 +1067,34 @@ EOF
# I am not positive that other SVR4 systems won't match this,
# I just have to hope. -- rms.
# Use sysv4.2uw... so that sysv4* matches it.
- echo ${UNAME_MACHINE}-pc-sysv4.2uw${UNAME_VERSION}
+ echo "$UNAME_MACHINE"-pc-sysv4.2uw"$UNAME_VERSION"
exit ;;
i*86:OS/2:*:*)
# If we were able to find `uname', then EMX Unix compatibility
# is probably installed.
- echo ${UNAME_MACHINE}-pc-os2-emx
+ echo "$UNAME_MACHINE"-pc-os2-emx
exit ;;
i*86:XTS-300:*:STOP)
- echo ${UNAME_MACHINE}-unknown-stop
+ echo "$UNAME_MACHINE"-unknown-stop
exit ;;
i*86:atheos:*:*)
- echo ${UNAME_MACHINE}-unknown-atheos
+ echo "$UNAME_MACHINE"-unknown-atheos
exit ;;
i*86:syllable:*:*)
- echo ${UNAME_MACHINE}-pc-syllable
+ echo "$UNAME_MACHINE"-pc-syllable
exit ;;
i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.[02]*:*)
- echo i386-unknown-lynxos${UNAME_RELEASE}
+ echo i386-unknown-lynxos"$UNAME_RELEASE"
exit ;;
i*86:*DOS:*:*)
- echo ${UNAME_MACHINE}-pc-msdosdjgpp
+ echo "$UNAME_MACHINE"-pc-msdosdjgpp
exit ;;
- i*86:*:4.*:* | i*86:SYSTEM_V:4.*:*)
- UNAME_REL=`echo ${UNAME_RELEASE} | sed 's/\/MP$//'`
+ i*86:*:4.*:*)
+ UNAME_REL=`echo "$UNAME_RELEASE" | sed 's/\/MP$//'`
if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then
- echo ${UNAME_MACHINE}-univel-sysv${UNAME_REL}
+ echo "$UNAME_MACHINE"-univel-sysv"$UNAME_REL"
else
- echo ${UNAME_MACHINE}-pc-sysv${UNAME_REL}
+ echo "$UNAME_MACHINE"-pc-sysv"$UNAME_REL"
fi
exit ;;
i*86:*:5:[678]*)
@@ -1075,12 +1104,12 @@ EOF
*Pentium) UNAME_MACHINE=i586 ;;
*Pent*|*Celeron) UNAME_MACHINE=i686 ;;
esac
- echo ${UNAME_MACHINE}-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION}
+ echo "$UNAME_MACHINE-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}{$UNAME_VERSION}"
exit ;;
i*86:*:3.2:*)
if test -f /usr/options/cb.name; then
UNAME_REL=`sed -n 's/.*Version //p' </usr/options/cb.name`
- echo ${UNAME_MACHINE}-pc-isc$UNAME_REL
+ echo "$UNAME_MACHINE"-pc-isc"$UNAME_REL"
elif /bin/uname -X 2>/dev/null >/dev/null ; then
UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')`
(/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486
@@ -1090,9 +1119,9 @@ EOF
&& UNAME_MACHINE=i686
(/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \
&& UNAME_MACHINE=i686
- echo ${UNAME_MACHINE}-pc-sco$UNAME_REL
+ echo "$UNAME_MACHINE"-pc-sco"$UNAME_REL"
else
- echo ${UNAME_MACHINE}-pc-sysv32
+ echo "$UNAME_MACHINE"-pc-sysv32
fi
exit ;;
pc:*:*:*)
@@ -1100,7 +1129,7 @@ EOF
# uname -m prints for DJGPP always 'pc', but it prints nothing about
# the processor, so we play safe by assuming i586.
# Note: whatever this is, it MUST be the same as what config.sub
- # prints for the "djgpp" host, or else GDB configuration will decide that
+ # prints for the "djgpp" host, or else GDB configure will decide that
# this is a cross-build.
echo i586-pc-msdosdjgpp
exit ;;
@@ -1112,9 +1141,9 @@ EOF
exit ;;
i860:*:4.*:*) # i860-SVR4
if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then
- echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4
+ echo i860-stardent-sysv"$UNAME_RELEASE" # Stardent Vistra i860-SVR4
else # Add other i860-SVR4 vendors below as they are discovered.
- echo i860-unknown-sysv${UNAME_RELEASE} # Unknown i860-SVR4
+ echo i860-unknown-sysv"$UNAME_RELEASE" # Unknown i860-SVR4
fi
exit ;;
mini*:CTIX:SYS*5:*)
@@ -1134,9 +1163,9 @@ EOF
test -r /etc/.relid \
&& OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid`
/bin/uname -p 2>/dev/null | grep 86 >/dev/null \
- && { echo i486-ncr-sysv4.3${OS_REL}; exit; }
+ && { echo i486-ncr-sysv4.3"$OS_REL"; exit; }
/bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \
- && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;;
+ && { echo i586-ncr-sysv4.3"$OS_REL"; exit; } ;;
3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*)
/bin/uname -p 2>/dev/null | grep 86 >/dev/null \
&& { echo i486-ncr-sysv4; exit; } ;;
@@ -1145,28 +1174,28 @@ EOF
test -r /etc/.relid \
&& OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid`
/bin/uname -p 2>/dev/null | grep 86 >/dev/null \
- && { echo i486-ncr-sysv4.3${OS_REL}; exit; }
+ && { echo i486-ncr-sysv4.3"$OS_REL"; exit; }
/bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \
- && { echo i586-ncr-sysv4.3${OS_REL}; exit; }
+ && { echo i586-ncr-sysv4.3"$OS_REL"; exit; }
/bin/uname -p 2>/dev/null | /bin/grep pteron >/dev/null \
- && { echo i586-ncr-sysv4.3${OS_REL}; exit; } ;;
+ && { echo i586-ncr-sysv4.3"$OS_REL"; exit; } ;;
m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*)
- echo m68k-unknown-lynxos${UNAME_RELEASE}
+ echo m68k-unknown-lynxos"$UNAME_RELEASE"
exit ;;
mc68030:UNIX_System_V:4.*:*)
echo m68k-atari-sysv4
exit ;;
TSUNAMI:LynxOS:2.*:*)
- echo sparc-unknown-lynxos${UNAME_RELEASE}
+ echo sparc-unknown-lynxos"$UNAME_RELEASE"
exit ;;
rs6000:LynxOS:2.*:*)
- echo rs6000-unknown-lynxos${UNAME_RELEASE}
+ echo rs6000-unknown-lynxos"$UNAME_RELEASE"
exit ;;
PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.[02]*:*)
- echo powerpc-unknown-lynxos${UNAME_RELEASE}
+ echo powerpc-unknown-lynxos"$UNAME_RELEASE"
exit ;;
SM[BE]S:UNIX_SV:*:*)
- echo mips-dde-sysv${UNAME_RELEASE}
+ echo mips-dde-sysv"$UNAME_RELEASE"
exit ;;
RM*:ReliantUNIX-*:*:*)
echo mips-sni-sysv4
@@ -1177,7 +1206,7 @@ EOF
*:SINIX-*:*:*)
if uname -p 2>/dev/null >/dev/null ; then
UNAME_MACHINE=`(uname -p) 2>/dev/null`
- echo ${UNAME_MACHINE}-sni-sysv4
+ echo "$UNAME_MACHINE"-sni-sysv4
else
echo ns32k-sni-sysv
fi
@@ -1197,23 +1226,23 @@ EOF
exit ;;
i*86:VOS:*:*)
# From Paul.Green@stratus.com.
- echo ${UNAME_MACHINE}-stratus-vos
+ echo "$UNAME_MACHINE"-stratus-vos
exit ;;
*:VOS:*:*)
# From Paul.Green@stratus.com.
echo hppa1.1-stratus-vos
exit ;;
mc68*:A/UX:*:*)
- echo m68k-apple-aux${UNAME_RELEASE}
+ echo m68k-apple-aux"$UNAME_RELEASE"
exit ;;
news*:NEWS-OS:6*:*)
echo mips-sony-newsos6
exit ;;
R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*)
if [ -d /usr/nec ]; then
- echo mips-nec-sysv${UNAME_RELEASE}
+ echo mips-nec-sysv"$UNAME_RELEASE"
else
- echo mips-unknown-sysv${UNAME_RELEASE}
+ echo mips-unknown-sysv"$UNAME_RELEASE"
fi
exit ;;
BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only.
@@ -1232,46 +1261,56 @@ EOF
echo x86_64-unknown-haiku
exit ;;
SX-4:SUPER-UX:*:*)
- echo sx4-nec-superux${UNAME_RELEASE}
+ echo sx4-nec-superux"$UNAME_RELEASE"
exit ;;
SX-5:SUPER-UX:*:*)
- echo sx5-nec-superux${UNAME_RELEASE}
+ echo sx5-nec-superux"$UNAME_RELEASE"
exit ;;
SX-6:SUPER-UX:*:*)
- echo sx6-nec-superux${UNAME_RELEASE}
+ echo sx6-nec-superux"$UNAME_RELEASE"
exit ;;
SX-7:SUPER-UX:*:*)
- echo sx7-nec-superux${UNAME_RELEASE}
+ echo sx7-nec-superux"$UNAME_RELEASE"
exit ;;
SX-8:SUPER-UX:*:*)
- echo sx8-nec-superux${UNAME_RELEASE}
+ echo sx8-nec-superux"$UNAME_RELEASE"
exit ;;
SX-8R:SUPER-UX:*:*)
- echo sx8r-nec-superux${UNAME_RELEASE}
+ echo sx8r-nec-superux"$UNAME_RELEASE"
+ exit ;;
+ SX-ACE:SUPER-UX:*:*)
+ echo sxace-nec-superux"$UNAME_RELEASE"
exit ;;
Power*:Rhapsody:*:*)
- echo powerpc-apple-rhapsody${UNAME_RELEASE}
+ echo powerpc-apple-rhapsody"$UNAME_RELEASE"
exit ;;
*:Rhapsody:*:*)
- echo ${UNAME_MACHINE}-apple-rhapsody${UNAME_RELEASE}
+ echo "$UNAME_MACHINE"-apple-rhapsody"$UNAME_RELEASE"
exit ;;
*:Darwin:*:*)
UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown
- eval $set_cc_for_build
+ eval "$set_cc_for_build"
if test "$UNAME_PROCESSOR" = unknown ; then
UNAME_PROCESSOR=powerpc
fi
- if test `echo "$UNAME_RELEASE" | sed -e 's/\..*//'` -le 10 ; then
- if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then
+ if test "`echo "$UNAME_RELEASE" | sed -e 's/\..*//'`" -le 10 ; then
+ if [ "$CC_FOR_BUILD" != no_compiler_found ]; then
if (echo '#ifdef __LP64__'; echo IS_64BIT_ARCH; echo '#endif') | \
- (CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \
- grep IS_64BIT_ARCH >/dev/null
+ (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) | \
+ grep IS_64BIT_ARCH >/dev/null
then
case $UNAME_PROCESSOR in
i386) UNAME_PROCESSOR=x86_64 ;;
powerpc) UNAME_PROCESSOR=powerpc64 ;;
esac
fi
+ # On 10.4-10.6 one might compile for PowerPC via gcc -arch ppc
+ if (echo '#ifdef __POWERPC__'; echo IS_PPC; echo '#endif') | \
+ (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) | \
+ grep IS_PPC >/dev/null
+ then
+ UNAME_PROCESSOR=powerpc
+ fi
fi
elif test "$UNAME_PROCESSOR" = i386 ; then
# Avoid executing cc on OS X 10.9, as it ships with a stub
@@ -1282,27 +1321,33 @@ EOF
# that Apple uses in portable devices.
UNAME_PROCESSOR=x86_64
fi
- echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE}
+ echo "$UNAME_PROCESSOR"-apple-darwin"$UNAME_RELEASE"
exit ;;
*:procnto*:*:* | *:QNX:[0123456789]*:*)
UNAME_PROCESSOR=`uname -p`
- if test "$UNAME_PROCESSOR" = "x86"; then
+ if test "$UNAME_PROCESSOR" = x86; then
UNAME_PROCESSOR=i386
UNAME_MACHINE=pc
fi
- echo ${UNAME_PROCESSOR}-${UNAME_MACHINE}-nto-qnx${UNAME_RELEASE}
+ echo "$UNAME_PROCESSOR"-"$UNAME_MACHINE"-nto-qnx"$UNAME_RELEASE"
exit ;;
*:QNX:*:4*)
echo i386-pc-qnx
exit ;;
- NEO-?:NONSTOP_KERNEL:*:*)
- echo neo-tandem-nsk${UNAME_RELEASE}
+ NEO-*:NONSTOP_KERNEL:*:*)
+ echo neo-tandem-nsk"$UNAME_RELEASE"
exit ;;
NSE-*:NONSTOP_KERNEL:*:*)
- echo nse-tandem-nsk${UNAME_RELEASE}
+ echo nse-tandem-nsk"$UNAME_RELEASE"
exit ;;
- NSR-?:NONSTOP_KERNEL:*:*)
- echo nsr-tandem-nsk${UNAME_RELEASE}
+ NSR-*:NONSTOP_KERNEL:*:*)
+ echo nsr-tandem-nsk"$UNAME_RELEASE"
+ exit ;;
+ NSV-*:NONSTOP_KERNEL:*:*)
+ echo nsv-tandem-nsk"$UNAME_RELEASE"
+ exit ;;
+ NSX-*:NONSTOP_KERNEL:*:*)
+ echo nsx-tandem-nsk"$UNAME_RELEASE"
exit ;;
*:NonStop-UX:*:*)
echo mips-compaq-nonstopux
@@ -1311,18 +1356,18 @@ EOF
echo bs2000-siemens-sysv
exit ;;
DS/*:UNIX_System_V:*:*)
- echo ${UNAME_MACHINE}-${UNAME_SYSTEM}-${UNAME_RELEASE}
+ echo "$UNAME_MACHINE"-"$UNAME_SYSTEM"-"$UNAME_RELEASE"
exit ;;
*:Plan9:*:*)
# "uname -m" is not consistent, so use $cputype instead. 386
# is converted to i386 for consistency with other x86
# operating systems.
- if test "$cputype" = "386"; then
+ if test "$cputype" = 386; then
UNAME_MACHINE=i386
else
UNAME_MACHINE="$cputype"
fi
- echo ${UNAME_MACHINE}-unknown-plan9
+ echo "$UNAME_MACHINE"-unknown-plan9
exit ;;
*:TOPS-10:*:*)
echo pdp10-unknown-tops10
@@ -1343,14 +1388,14 @@ EOF
echo pdp10-unknown-its
exit ;;
SEI:*:*:SEIUX)
- echo mips-sei-seiux${UNAME_RELEASE}
+ echo mips-sei-seiux"$UNAME_RELEASE"
exit ;;
*:DragonFly:*:*)
- echo ${UNAME_MACHINE}-unknown-dragonfly`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`
+ echo "$UNAME_MACHINE"-unknown-dragonfly"`echo "$UNAME_RELEASE"|sed -e 's/[-(].*//'`"
exit ;;
*:*VMS:*:*)
UNAME_MACHINE=`(uname -p) 2>/dev/null`
- case "${UNAME_MACHINE}" in
+ case "$UNAME_MACHINE" in
A*) echo alpha-dec-vms ; exit ;;
I*) echo ia64-dec-vms ; exit ;;
V*) echo vax-dec-vms ; exit ;;
@@ -1359,34 +1404,48 @@ EOF
echo i386-pc-xenix
exit ;;
i*86:skyos:*:*)
- echo ${UNAME_MACHINE}-pc-skyos`echo ${UNAME_RELEASE}` | sed -e 's/ .*$//'
+ echo "$UNAME_MACHINE"-pc-skyos"`echo "$UNAME_RELEASE" | sed -e 's/ .*$//'`"
exit ;;
i*86:rdos:*:*)
- echo ${UNAME_MACHINE}-pc-rdos
+ echo "$UNAME_MACHINE"-pc-rdos
exit ;;
i*86:AROS:*:*)
- echo ${UNAME_MACHINE}-pc-aros
+ echo "$UNAME_MACHINE"-pc-aros
exit ;;
x86_64:VMkernel:*:*)
- echo ${UNAME_MACHINE}-unknown-esx
+ echo "$UNAME_MACHINE"-unknown-esx
+ exit ;;
+ amd64:Isilon\ OneFS:*:*)
+ echo x86_64-unknown-onefs
exit ;;
esac
+echo "$0: unable to guess system type" >&2
+
+case "$UNAME_MACHINE:$UNAME_SYSTEM" in
+ mips:Linux | mips64:Linux)
+ # If we got here on MIPS GNU/Linux, output extra information.
+ cat >&2 <<EOF
+
+NOTE: MIPS GNU/Linux systems require a C compiler to fully recognize
+the system type. Please install a C compiler and try again.
+EOF
+ ;;
+esac
+
cat >&2 <<EOF
-$0: unable to guess system type
-This script, last modified $timestamp, has failed to recognize
-the operating system you are using. It is advised that you
-download the most up to date version of the config scripts from
+This script (version $timestamp), has failed to recognize the
+operating system you are using. If your script is old, overwrite *all*
+copies of config.guess and config.sub with the latest versions from:
- http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess;hb=HEAD
+ https://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess
and
- http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub;hb=HEAD
+ https://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub
-If the version you run ($0) is already up to date, please
-send the following data and any information you think might be
-pertinent to <config-patches@gnu.org> in order to provide the needed
-information to handle your system.
+If $0 has already been updated, send the following data and any
+information you think might be pertinent to config-patches@gnu.org to
+provide the necessary information to handle your system.
config.guess timestamp = $timestamp
@@ -1405,16 +1464,16 @@ hostinfo = `(hostinfo) 2>/dev/null`
/usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null`
/usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null`
-UNAME_MACHINE = ${UNAME_MACHINE}
-UNAME_RELEASE = ${UNAME_RELEASE}
-UNAME_SYSTEM = ${UNAME_SYSTEM}
-UNAME_VERSION = ${UNAME_VERSION}
+UNAME_MACHINE = "$UNAME_MACHINE"
+UNAME_RELEASE = "$UNAME_RELEASE"
+UNAME_SYSTEM = "$UNAME_SYSTEM"
+UNAME_VERSION = "$UNAME_VERSION"
EOF
exit 1
# Local variables:
-# eval: (add-hook 'write-file-hooks 'time-stamp)
+# eval: (add-hook 'write-file-functions 'time-stamp)
# time-stamp-start: "timestamp='"
# time-stamp-format: "%:y-%02m-%02d"
# time-stamp-end: "'"
diff --git a/lcms2mt/config.sub b/lcms2mt/config.sub
index 7ffe3737..1d8e98bc 100755
--- a/lcms2mt/config.sub
+++ b/lcms2mt/config.sub
@@ -1,8 +1,8 @@
#! /bin/sh
# Configuration validation subroutine script.
-# Copyright 1992-2014 Free Software Foundation, Inc.
+# Copyright 1992-2018 Free Software Foundation, Inc.
-timestamp='2014-12-03'
+timestamp='2018-02-22'
# This file is free software; you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by
@@ -15,7 +15,7 @@ timestamp='2014-12-03'
# General Public License for more details.
#
# You should have received a copy of the GNU General Public License
-# along with this program; if not, see <http://www.gnu.org/licenses/>.
+# along with this program; if not, see <https://www.gnu.org/licenses/>.
#
# As a special exception to the GNU General Public License, if you
# distribute this file as part of a program that contains a
@@ -33,7 +33,7 @@ timestamp='2014-12-03'
# Otherwise, we print the canonical config type on stdout and succeed.
# You can get the latest version of this script from:
-# http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub;hb=HEAD
+# https://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.sub
# This file is supposed to be the same for all GNU packages
# and recognize all the CPU types, system types and aliases
@@ -53,12 +53,11 @@ timestamp='2014-12-03'
me=`echo "$0" | sed -e 's,.*/,,'`
usage="\
-Usage: $0 [OPTION] CPU-MFR-OPSYS
- $0 [OPTION] ALIAS
+Usage: $0 [OPTION] CPU-MFR-OPSYS or ALIAS
Canonicalize a configuration name.
-Operation modes:
+Options:
-h, --help print this help, then exit
-t, --time-stamp print date of last modification, then exit
-v, --version print version number, then exit
@@ -68,7 +67,7 @@ Report bugs and patches to <config-patches@gnu.org>."
version="\
GNU config.sub ($timestamp)
-Copyright 1992-2014 Free Software Foundation, Inc.
+Copyright 1992-2018 Free Software Foundation, Inc.
This is free software; see the source for copying conditions. There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
@@ -95,7 +94,7 @@ while test $# -gt 0 ; do
*local*)
# First pass through any local machine types.
- echo $1
+ echo "$1"
exit ;;
* )
@@ -113,24 +112,24 @@ esac
# Separate what the user gave into CPU-COMPANY and OS or KERNEL-OS (if any).
# Here we must recognize all the valid KERNEL-OS combinations.
-maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'`
+maybe_os=`echo "$1" | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'`
case $maybe_os in
nto-qnx* | linux-gnu* | linux-android* | linux-dietlibc | linux-newlib* | \
linux-musl* | linux-uclibc* | uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | \
- knetbsd*-gnu* | netbsd*-gnu* | \
- kopensolaris*-gnu* | \
+ knetbsd*-gnu* | netbsd*-gnu* | netbsd*-eabi* | \
+ kopensolaris*-gnu* | cloudabi*-eabi* | \
storm-chaos* | os2-emx* | rtmk-nova*)
os=-$maybe_os
- basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`
+ basic_machine=`echo "$1" | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`
;;
android-linux)
os=-linux-android
- basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`-unknown
+ basic_machine=`echo "$1" | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`-unknown
;;
*)
- basic_machine=`echo $1 | sed 's/-[^-]*$//'`
- if [ $basic_machine != $1 ]
- then os=`echo $1 | sed 's/.*-/-/'`
+ basic_machine=`echo "$1" | sed 's/-[^-]*$//'`
+ if [ "$basic_machine" != "$1" ]
+ then os=`echo "$1" | sed 's/.*-/-/'`
else os=; fi
;;
esac
@@ -179,44 +178,44 @@ case $os in
;;
-sco6)
os=-sco5v6
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-sco5)
os=-sco3.2v5
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-sco4)
os=-sco3.2v4
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-sco3.2.[4-9]*)
os=`echo $os | sed -e 's/sco3.2./sco3.2v/'`
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-sco3.2v[4-9]*)
# Don't forget version if it is 3.2v4 or newer.
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-sco5v6*)
# Don't forget version if it is 3.2v4 or newer.
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-sco*)
os=-sco3.2v2
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-udk*)
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-isc)
os=-isc2.2
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-clix*)
basic_machine=clipper-intergraph
;;
-isc*)
- basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-pc/'`
;;
-lynx*178)
os=-lynxos178
@@ -228,10 +227,7 @@ case $os in
os=-lynxos
;;
-ptx*)
- basic_machine=`echo $1 | sed -e 's/86-.*/86-sequent/'`
- ;;
- -windowsnt*)
- os=`echo $os | sed -e 's/windowsnt/winnt/'`
+ basic_machine=`echo "$1" | sed -e 's/86-.*/86-sequent/'`
;;
-psos*)
os=-psos
@@ -255,15 +251,16 @@ case $basic_machine in
| arc | arceb \
| arm | arm[bl]e | arme[lb] | armv[2-8] | armv[3-8][lb] | armv7[arm] \
| avr | avr32 \
+ | ba \
| be32 | be64 \
| bfin \
| c4x | c8051 | clipper \
| d10v | d30v | dlx | dsp16xx \
- | epiphany \
- | fido | fr30 | frv \
+ | e2k | epiphany \
+ | fido | fr30 | frv | ft32 \
| h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \
| hexagon \
- | i370 | i860 | i960 | ia64 \
+ | i370 | i860 | i960 | ia16 | ia64 \
| ip2k | iq2000 \
| k1om \
| le32 | le64 \
@@ -299,13 +296,14 @@ case $basic_machine in
| nios | nios2 | nios2eb | nios2el \
| ns16k | ns32k \
| open8 | or1k | or1knd | or32 \
- | pdp10 | pdp11 | pj | pjl \
+ | pdp10 | pj | pjl \
| powerpc | powerpc64 | powerpc64le | powerpcle \
+ | pru \
| pyramid \
| riscv32 | riscv64 \
| rl78 | rx \
| score \
- | sh | sh[1234] | sh[24]a | sh[24]aeb | sh[23]e | sh[34]eb | sheb | shbe | shle | sh[1234]le | sh3ele \
+ | sh | sh[1234] | sh[24]a | sh[24]aeb | sh[23]e | sh[234]eb | sheb | shbe | shle | sh[1234]le | sh3ele \
| sh64 | sh64le \
| sparc | sparc64 | sparc64b | sparc64v | sparc86x | sparclet | sparclite \
| sparcv8 | sparcv9 | sparcv9b | sparcv9v \
@@ -314,7 +312,7 @@ case $basic_machine in
| ubicom32 \
| v850 | v850e | v850e1 | v850e2 | v850es | v850e2v3 \
| visium \
- | we32k \
+ | wasm32 \
| x86 | xc16x | xstormy16 | xtensa \
| z8k | z80)
basic_machine=$basic_machine-unknown
@@ -335,7 +333,7 @@ case $basic_machine in
basic_machine=$basic_machine-unknown
os=-none
;;
- m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65 | z8k)
+ m88110 | m680[12346]0 | m683?2 | m68360 | m5200 | v70 | w65)
;;
ms1)
basic_machine=mt-unknown
@@ -364,7 +362,7 @@ case $basic_machine in
;;
# Object if more than one company name word.
*-*-*)
- echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2
+ echo Invalid configuration \`"$1"\': machine \`"$basic_machine"\' not recognized 1>&2
exit 1
;;
# Recognize the basic CPU types with company name.
@@ -376,17 +374,18 @@ case $basic_machine in
| alphapca5[67]-* | alpha64pca5[67]-* | arc-* | arceb-* \
| arm-* | armbe-* | armle-* | armeb-* | armv*-* \
| avr-* | avr32-* \
+ | ba-* \
| be32-* | be64-* \
| bfin-* | bs2000-* \
| c[123]* | c30-* | [cjt]90-* | c4x-* \
| c8051-* | clipper-* | craynv-* | cydra-* \
| d10v-* | d30v-* | dlx-* \
- | elxsi-* \
+ | e2k-* | elxsi-* \
| f30[01]-* | f700-* | fido-* | fr30-* | frv-* | fx80-* \
| h8300-* | h8500-* \
| hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \
| hexagon-* \
- | i*86-* | i860-* | i960-* | ia64-* \
+ | i*86-* | i860-* | i960-* | ia16-* | ia64-* \
| ip2k-* | iq2000-* \
| k1om-* \
| le32-* | le64-* \
@@ -427,13 +426,15 @@ case $basic_machine in
| orion-* \
| pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \
| powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* \
+ | pru-* \
| pyramid-* \
+ | riscv32-* | riscv64-* \
| rl78-* | romp-* | rs6000-* | rx-* \
| sh-* | sh[1234]-* | sh[24]a-* | sh[24]aeb-* | sh[23]e-* | sh[34]eb-* | sheb-* | shbe-* \
| shle-* | sh[1234]le-* | sh3ele-* | sh64-* | sh64le-* \
| sparc-* | sparc64-* | sparc64b-* | sparc64v-* | sparc86x-* | sparclet-* \
| sparclite-* \
- | sparcv8-* | sparcv9-* | sparcv9b-* | sparcv9v-* | sv1-* | sx?-* \
+ | sparcv8-* | sparcv9-* | sparcv9b-* | sparcv9v-* | sv1-* | sx*-* \
| tahoe-* \
| tic30-* | tic4x-* | tic54x-* | tic55x-* | tic6x-* | tic80-* \
| tile*-* \
@@ -442,6 +443,7 @@ case $basic_machine in
| v850-* | v850e-* | v850e1-* | v850es-* | v850e2-* | v850e2v3-* \
| vax-* \
| visium-* \
+ | wasm32-* \
| we32k-* \
| x86-* | x86_64-* | xc16x-* | xps100-* \
| xstormy16-* | xtensa*-* \
@@ -455,7 +457,7 @@ case $basic_machine in
# Recognize the various machine names and aliases which stand
# for a CPU type and a company and sometimes even an OS.
386bsd)
- basic_machine=i386-unknown
+ basic_machine=i386-pc
os=-bsd
;;
3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc)
@@ -489,7 +491,7 @@ case $basic_machine in
basic_machine=x86_64-pc
;;
amd64-*)
- basic_machine=x86_64-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=x86_64-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
amdahl)
basic_machine=580-amdahl
@@ -518,6 +520,9 @@ case $basic_machine in
basic_machine=i386-pc
os=-aros
;;
+ asmjs)
+ basic_machine=asmjs-unknown
+ ;;
aux)
basic_machine=m68k-apple
os=-aux
@@ -531,7 +536,7 @@ case $basic_machine in
os=-linux
;;
blackfin-*)
- basic_machine=bfin-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=bfin-`echo "$basic_machine" | sed 's/^[^-]*-//'`
os=-linux
;;
bluegene*)
@@ -539,13 +544,13 @@ case $basic_machine in
os=-cnk
;;
c54x-*)
- basic_machine=tic54x-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=tic54x-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
c55x-*)
- basic_machine=tic55x-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=tic55x-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
c6x-*)
- basic_machine=tic6x-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=tic6x-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
c90)
basic_machine=c90-cray
@@ -634,10 +639,18 @@ case $basic_machine in
basic_machine=rs6000-bull
os=-bosx
;;
- dpx2* | dpx2*-bull)
+ dpx2*)
basic_machine=m68k-bull
os=-sysv3
;;
+ e500v[12])
+ basic_machine=powerpc-unknown
+ os=$os"spe"
+ ;;
+ e500v[12]-*)
+ basic_machine=powerpc-`echo "$basic_machine" | sed 's/^[^-]*-//'`
+ os=$os"spe"
+ ;;
ebmon29k)
basic_machine=a29k-amd
os=-ebmon
@@ -727,9 +740,6 @@ case $basic_machine in
hp9k8[0-9][0-9] | hp8[0-9][0-9])
basic_machine=hppa1.0-hp
;;
- hppa-next)
- os=-nextstep3
- ;;
hppaosf)
basic_machine=hppa1.1-hp
os=-osf
@@ -742,26 +752,26 @@ case $basic_machine in
basic_machine=i370-ibm
;;
i*86v32)
- basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86.*/86-pc/'`
os=-sysv32
;;
i*86v4*)
- basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86.*/86-pc/'`
os=-sysv4
;;
i*86v)
- basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86.*/86-pc/'`
os=-sysv
;;
i*86sol2)
- basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
+ basic_machine=`echo "$1" | sed -e 's/86.*/86-pc/'`
os=-solaris2
;;
i386mach)
basic_machine=i386-mach
os=-mach
;;
- i386-vsta | vsta)
+ vsta)
basic_machine=i386-unknown
os=-vsta
;;
@@ -780,19 +790,16 @@ case $basic_machine in
os=-sysv
;;
leon-*|leon[3-9]-*)
- basic_machine=sparc-`echo $basic_machine | sed 's/-.*//'`
+ basic_machine=sparc-`echo "$basic_machine" | sed 's/-.*//'`
;;
m68knommu)
basic_machine=m68k-unknown
os=-linux
;;
m68knommu-*)
- basic_machine=m68k-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=m68k-`echo "$basic_machine" | sed 's/^[^-]*-//'`
os=-linux
;;
- m88k-omron*)
- basic_machine=m88k-omron
- ;;
magnum | m3230)
basic_machine=mips-mips
os=-sysv
@@ -824,10 +831,10 @@ case $basic_machine in
os=-mint
;;
mips3*-*)
- basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`
+ basic_machine=`echo "$basic_machine" | sed -e 's/mips3/mips64/'`
;;
mips3*)
- basic_machine=`echo $basic_machine | sed -e 's/mips3/mips64/'`-unknown
+ basic_machine=`echo "$basic_machine" | sed -e 's/mips3/mips64/'`-unknown
;;
monitor)
basic_machine=m68k-rom68k
@@ -846,7 +853,7 @@ case $basic_machine in
os=-msdos
;;
ms1-*)
- basic_machine=`echo $basic_machine | sed -e 's/ms1-/mt-/'`
+ basic_machine=`echo "$basic_machine" | sed -e 's/ms1-/mt-/'`
;;
msys)
basic_machine=i686-pc
@@ -888,7 +895,7 @@ case $basic_machine in
basic_machine=v70-nec
os=-sysv
;;
- next | m*-next )
+ next | m*-next)
basic_machine=m68k-next
case $os in
-nextstep* )
@@ -933,6 +940,12 @@ case $basic_machine in
nsr-tandem)
basic_machine=nsr-tandem
;;
+ nsv-tandem)
+ basic_machine=nsv-tandem
+ ;;
+ nsx-tandem)
+ basic_machine=nsx-tandem
+ ;;
op50n-* | op60c-*)
basic_machine=hppa1.1-oki
os=-proelf
@@ -965,7 +978,7 @@ case $basic_machine in
os=-linux
;;
parisc-*)
- basic_machine=hppa-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=hppa-`echo "$basic_machine" | sed 's/^[^-]*-//'`
os=-linux
;;
pbd)
@@ -981,7 +994,7 @@ case $basic_machine in
basic_machine=i386-pc
;;
pc98-*)
- basic_machine=i386-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=i386-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
pentium | p5 | k5 | k6 | nexgen | viac3)
basic_machine=i586-pc
@@ -996,16 +1009,16 @@ case $basic_machine in
basic_machine=i786-pc
;;
pentium-* | p5-* | k5-* | k6-* | nexgen-* | viac3-*)
- basic_machine=i586-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=i586-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
pentiumpro-* | p6-* | 6x86-* | athlon-*)
- basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=i686-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
pentiumii-* | pentium2-* | pentiumiii-* | pentium3-*)
- basic_machine=i686-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=i686-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
pentium4-*)
- basic_machine=i786-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=i786-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
pn)
basic_machine=pn-gould
@@ -1015,23 +1028,23 @@ case $basic_machine in
ppc | ppcbe) basic_machine=powerpc-unknown
;;
ppc-* | ppcbe-*)
- basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=powerpc-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
- ppcle | powerpclittle | ppc-le | powerpc-little)
+ ppcle | powerpclittle)
basic_machine=powerpcle-unknown
;;
ppcle-* | powerpclittle-*)
- basic_machine=powerpcle-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=powerpcle-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
ppc64) basic_machine=powerpc64-unknown
;;
- ppc64-*) basic_machine=powerpc64-`echo $basic_machine | sed 's/^[^-]*-//'`
+ ppc64-*) basic_machine=powerpc64-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
- ppc64le | powerpc64little | ppc64-le | powerpc64-little)
+ ppc64le | powerpc64little)
basic_machine=powerpc64le-unknown
;;
ppc64le-* | powerpc64little-*)
- basic_machine=powerpc64le-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=powerpc64le-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
ps2)
basic_machine=i386-ibm
@@ -1085,17 +1098,10 @@ case $basic_machine in
sequent)
basic_machine=i386-sequent
;;
- sh)
- basic_machine=sh-hitachi
- os=-hms
- ;;
sh5el)
basic_machine=sh5le-unknown
;;
- sh64)
- basic_machine=sh64-unknown
- ;;
- sparclite-wrs | simso-wrs)
+ simso-wrs)
basic_machine=sparclite-wrs
os=-vxworks
;;
@@ -1114,7 +1120,7 @@ case $basic_machine in
os=-sysv4
;;
strongarm-* | thumb-*)
- basic_machine=arm-`echo $basic_machine | sed 's/^[^-]*-//'`
+ basic_machine=arm-`echo "$basic_machine" | sed 's/^[^-]*-//'`
;;
sun2)
basic_machine=m68000-sun
@@ -1236,6 +1242,9 @@ case $basic_machine in
basic_machine=hppa1.1-winbond
os=-proelf
;;
+ x64)
+ basic_machine=x86_64-pc
+ ;;
xbox)
basic_machine=i686-pc
os=-mingw32
@@ -1244,20 +1253,12 @@ case $basic_machine in
basic_machine=xps100-honeywell
;;
xscale-* | xscalee[bl]-*)
- basic_machine=`echo $basic_machine | sed 's/^xscale/arm/'`
+ basic_machine=`echo "$basic_machine" | sed 's/^xscale/arm/'`
;;
ymp)
basic_machine=ymp-cray
os=-unicos
;;
- z8k-*-coff)
- basic_machine=z8k-unknown
- os=-sim
- ;;
- z80-*-coff)
- basic_machine=z80-unknown
- os=-sim
- ;;
none)
basic_machine=none-none
os=-none
@@ -1286,10 +1287,6 @@ case $basic_machine in
vax)
basic_machine=vax-dec
;;
- pdp10)
- # there are many clones, so DEC is not a safe bet
- basic_machine=pdp10-unknown
- ;;
pdp11)
basic_machine=pdp11-dec
;;
@@ -1299,9 +1296,6 @@ case $basic_machine in
sh[1234] | sh[24]a | sh[24]aeb | sh[34]eb | sh[1234]le | sh[23]ele)
basic_machine=sh-unknown
;;
- sparc | sparcv8 | sparcv9 | sparcv9b | sparcv9v)
- basic_machine=sparc-sun
- ;;
cydra)
basic_machine=cydra-cydrome
;;
@@ -1321,7 +1315,7 @@ case $basic_machine in
# Make sure to match an already-canonicalized machine name.
;;
*)
- echo Invalid configuration \`$1\': machine \`$basic_machine\' not recognized 1>&2
+ echo Invalid configuration \`"$1"\': machine \`"$basic_machine"\' not recognized 1>&2
exit 1
;;
esac
@@ -1329,10 +1323,10 @@ esac
# Here we canonicalize certain aliases for manufacturers.
case $basic_machine in
*-digital*)
- basic_machine=`echo $basic_machine | sed 's/digital.*/dec/'`
+ basic_machine=`echo "$basic_machine" | sed 's/digital.*/dec/'`
;;
*-commodore*)
- basic_machine=`echo $basic_machine | sed 's/commodore.*/cbm/'`
+ basic_machine=`echo "$basic_machine" | sed 's/commodore.*/cbm/'`
;;
*)
;;
@@ -1343,8 +1337,8 @@ esac
if [ x"$os" != x"" ]
then
case $os in
- # First match some system type aliases
- # that might get confused with valid system types.
+ # First match some system type aliases that might get confused
+ # with valid system types.
# -solaris* is a basic system type, with this one exception.
-auroraux)
os=-auroraux
@@ -1355,45 +1349,48 @@ case $os in
-solaris)
os=-solaris2
;;
- -svr4*)
- os=-sysv4
- ;;
-unixware*)
os=-sysv4.2uw
;;
-gnu/linux*)
os=`echo $os | sed -e 's|gnu/linux|linux-gnu|'`
;;
- # First accept the basic system types.
+ # es1800 is here to avoid being matched by es* (a different OS)
+ -es1800*)
+ os=-ose
+ ;;
+ # Now accept the basic system types.
# The portable systems comes first.
- # Each alternative MUST END IN A *, to match a version number.
+ # Each alternative MUST end in a * to match a version number.
# -sysv* is not here because it comes later, after sysvr4.
-gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \
| -*vms* | -sco* | -esix* | -isc* | -aix* | -cnk* | -sunos | -sunos[34]*\
| -hpux* | -unos* | -osf* | -luna* | -dgux* | -auroraux* | -solaris* \
| -sym* | -kopensolaris* | -plan9* \
| -amigaos* | -amigados* | -msdos* | -newsos* | -unicos* | -aof* \
- | -aos* | -aros* \
+ | -aos* | -aros* | -cloudabi* | -sortix* \
| -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \
| -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \
- | -hiux* | -386bsd* | -knetbsd* | -mirbsd* | -netbsd* \
- | -bitrig* | -openbsd* | -solidbsd* \
+ | -hiux* | -knetbsd* | -mirbsd* | -netbsd* \
+ | -bitrig* | -openbsd* | -solidbsd* | -libertybsd* \
| -ekkobsd* | -kfreebsd* | -freebsd* | -riscix* | -lynxos* \
| -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \
| -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \
| -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \
- | -chorusos* | -chorusrdb* | -cegcc* \
+ | -chorusos* | -chorusrdb* | -cegcc* | -glidix* \
| -cygwin* | -msys* | -pe* | -psos* | -moss* | -proelf* | -rtems* \
- | -mingw32* | -mingw64* | -linux-gnu* | -linux-android* \
+ | -midipix* | -mingw32* | -mingw64* | -linux-gnu* | -linux-android* \
| -linux-newlib* | -linux-musl* | -linux-uclibc* \
| -uxpv* | -beos* | -mpeix* | -udk* | -moxiebox* \
- | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \
+ | -interix* | -uwin* | -mks* | -rhapsody* | -darwin* \
| -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \
| -storm-chaos* | -tops10* | -tenex* | -tops20* | -its* \
| -os2* | -vos* | -palmos* | -uclinux* | -nucleus* \
- | -morphos* | -superux* | -rtmk* | -rtmk-nova* | -windiss* \
+ | -morphos* | -superux* | -rtmk* | -windiss* \
| -powermax* | -dnix* | -nx6 | -nx7 | -sei* | -dragonfly* \
- | -skyos* | -haiku* | -rdos* | -toppers* | -drops* | -es* | -tirtos*)
+ | -skyos* | -haiku* | -rdos* | -toppers* | -drops* | -es* \
+ | -onefs* | -tirtos* | -phoenix* | -fuchsia* | -redox* | -bme* \
+ | -midnightbsd*)
# Remember, each alternative MUST END IN *, to match a version number.
;;
-qnx*)
@@ -1410,12 +1407,12 @@ case $os in
-nto*)
os=`echo $os | sed -e 's|nto|nto-qnx|'`
;;
- -sim | -es1800* | -hms* | -xray | -os68k* | -none* | -v88r* \
- | -windows* | -osx | -abug | -netware* | -os9* | -beos* | -haiku* \
+ -sim | -xray | -os68k* | -v88r* \
+ | -windows* | -osx | -abug | -netware* | -os9* \
| -macos* | -mpw* | -magic* | -mmixware* | -mon960* | -lnews*)
;;
-mac*)
- os=`echo $os | sed -e 's|mac|macos|'`
+ os=`echo "$os" | sed -e 's|mac|macos|'`
;;
-linux-dietlibc)
os=-linux-dietlibc
@@ -1424,10 +1421,10 @@ case $os in
os=`echo $os | sed -e 's|linux|linux-gnu|'`
;;
-sunos5*)
- os=`echo $os | sed -e 's|sunos5|solaris2|'`
+ os=`echo "$os" | sed -e 's|sunos5|solaris2|'`
;;
-sunos6*)
- os=`echo $os | sed -e 's|sunos6|solaris3|'`
+ os=`echo "$os" | sed -e 's|sunos6|solaris3|'`
;;
-opened*)
os=-openedition
@@ -1438,12 +1435,6 @@ case $os in
-wince*)
os=-wince
;;
- -osfrose*)
- os=-osfrose
- ;;
- -osf*)
- os=-osf
- ;;
-utek*)
os=-bsd
;;
@@ -1468,7 +1459,7 @@ case $os in
-nova*)
os=-rtmk-nova
;;
- -ns2 )
+ -ns2)
os=-nextstep2
;;
-nsk*)
@@ -1490,7 +1481,7 @@ case $os in
-oss*)
os=-sysv3
;;
- -svr4)
+ -svr4*)
os=-sysv4
;;
-svr3)
@@ -1505,32 +1496,38 @@ case $os in
-ose*)
os=-ose
;;
- -es1800*)
- os=-ose
- ;;
- -xenix)
- os=-xenix
- ;;
-*mint | -mint[0-9]* | -*MiNT | -MiNT[0-9]*)
os=-mint
;;
- -aros*)
- os=-aros
- ;;
-zvmoe)
os=-zvmoe
;;
-dicos*)
os=-dicos
;;
+ -pikeos*)
+ # Until real need of OS specific support for
+ # particular features comes up, bare metal
+ # configurations are quite functional.
+ case $basic_machine in
+ arm*)
+ os=-eabi
+ ;;
+ *)
+ os=-elf
+ ;;
+ esac
+ ;;
-nacl*)
;;
+ -ios)
+ ;;
-none)
;;
*)
# Get rid of the `-' at the beginning of $os.
os=`echo $os | sed 's/[^-]*-//'`
- echo Invalid configuration \`$1\': system \`$os\' not recognized 1>&2
+ echo Invalid configuration \`"$1"\': system \`"$os"\' not recognized 1>&2
exit 1
;;
esac
@@ -1620,12 +1617,12 @@ case $basic_machine in
sparc-* | *-sun)
os=-sunos4.1.1
;;
+ pru-*)
+ os=-elf
+ ;;
*-be)
os=-beos
;;
- *-haiku)
- os=-haiku
- ;;
*-ibm)
os=-aix
;;
@@ -1665,7 +1662,7 @@ case $basic_machine in
m88k-omron*)
os=-luna
;;
- *-next )
+ *-next)
os=-nextstep
;;
*-sequent)
@@ -1680,9 +1677,6 @@ case $basic_machine in
i370-*)
os=-mvs
;;
- *-next)
- os=-nextstep3
- ;;
*-gould)
os=-sysv
;;
@@ -1792,15 +1786,15 @@ case $basic_machine in
vendor=stratus
;;
esac
- basic_machine=`echo $basic_machine | sed "s/unknown/$vendor/"`
+ basic_machine=`echo "$basic_machine" | sed "s/unknown/$vendor/"`
;;
esac
-echo $basic_machine$os
+echo "$basic_machine$os"
exit
# Local variables:
-# eval: (add-hook 'write-file-hooks 'time-stamp)
+# eval: (add-hook 'write-file-functions 'time-stamp)
# time-stamp-start: "timestamp='"
# time-stamp-format: "%:y-%02m-%02d"
# time-stamp-end: "'"
diff --git a/lcms2mt/configure b/lcms2mt/configure
index 2a650128..ab555c17 100644
--- a/lcms2mt/configure
+++ b/lcms2mt/configure
@@ -659,7 +659,9 @@ MAINT
MAINTAINER_MODE_FALSE
MAINTAINER_MODE_TRUE
LIBTOOL_DEPS
+AS
CXXCPP
+LT_SYS_LIBRARY_PATH
OTOOL64
OTOOL
LIPO
@@ -669,6 +671,8 @@ MANIFEST_TOOL
RANLIB
ac_ct_AR
AR
+DLLTOOL
+OBJDUMP
LN_S
NM
ac_ct_DUMPBIN
@@ -679,9 +683,6 @@ EGREP
GREP
SED
LIBTOOL
-OBJDUMP
-DLLTOOL
-AS
am__fastdepCXX_FALSE
am__fastdepCXX_TRUE
CXXDEPMODE
@@ -792,6 +793,7 @@ enable_shared
enable_static
with_pic
enable_fast_install
+with_aix_soname
with_gnu_ld
with_sysroot
enable_libtool_lock
@@ -814,6 +816,7 @@ CPP
CXX
CXXFLAGS
CCC
+LT_SYS_LIBRARY_PATH
CXXCPP'
@@ -1464,9 +1467,12 @@ Optional Packages:
--without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no)
--with-pic[=PKGS] try to use only PIC/non-PIC objects [default=use
both]
+ --with-aix-soname=aix|svr4|both
+ shared library versioning (aka "SONAME") variant to
+ provide on AIX, [default=aix].
--with-gnu-ld assume the C compiler uses GNU ld [default=no]
- --with-sysroot=DIR Search for dependent libraries within DIR
- (or the compiler's sysroot if not specified).
+ --with-sysroot[=DIR] Search for dependent libraries within DIR (or the
+ compiler's sysroot if not specified).
--with-jpeg=DIR use jpeg installed in DIR
--with-tiff=DIR use tiff installed in DIR
--without-zlib disable ZLIB support
@@ -1485,6 +1491,8 @@ Some influential environment variables:
CPP C preprocessor
CXX C++ compiler command
CXXFLAGS C++ compiler flags
+ LT_SYS_LIBRARY_PATH
+ User-defined run-time library search path.
CXXCPP C++ preprocessor
Use these variables to override the choices made by `configure' or to help
@@ -5043,386 +5051,6 @@ else
fi
-
-#AM_PROG_LD
-#AC_SUBST(LD)
-#AC_PROG_INSTALL
-#AC_PROG_MAKE_SET
-#AC_PROG_LN_S
-
-#
-# Tests for Windows
-#
-
-
-
-# Configure libtool
-# Check whether --enable-shared was given.
-if test "${enable_shared+set}" = set; then :
- enableval=$enable_shared; p=${PACKAGE-default}
- case $enableval in
- yes) enable_shared=yes ;;
- no) enable_shared=no ;;
- *)
- enable_shared=no
- # Look at the argument we got. We use all the common list separators.
- lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
- for pkg in $enableval; do
- IFS="$lt_save_ifs"
- if test "X$pkg" = "X$p"; then
- enable_shared=yes
- fi
- done
- IFS="$lt_save_ifs"
- ;;
- esac
-else
- enable_shared=yes
-fi
-
-
-
-
-
-
-
-
-
-# Check whether --enable-static was given.
-if test "${enable_static+set}" = set; then :
- enableval=$enable_static; p=${PACKAGE-default}
- case $enableval in
- yes) enable_static=yes ;;
- no) enable_static=no ;;
- *)
- enable_static=no
- # Look at the argument we got. We use all the common list separators.
- lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
- for pkg in $enableval; do
- IFS="$lt_save_ifs"
- if test "X$pkg" = "X$p"; then
- enable_static=yes
- fi
- done
- IFS="$lt_save_ifs"
- ;;
- esac
-else
- enable_static=yes
-fi
-
-
-
-
-
-
-
-
-
-enable_win32_dll=yes
-
-case $host in
-*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-cegcc*)
- if test -n "$ac_tool_prefix"; then
- # Extract the first word of "${ac_tool_prefix}as", so it can be a program name with args.
-set dummy ${ac_tool_prefix}as; ac_word=$2
-{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
-$as_echo_n "checking for $ac_word... " >&6; }
-if ${ac_cv_prog_AS+:} false; then :
- $as_echo_n "(cached) " >&6
-else
- if test -n "$AS"; then
- ac_cv_prog_AS="$AS" # Let the user override the test.
-else
-as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
-for as_dir in $PATH
-do
- IFS=$as_save_IFS
- test -z "$as_dir" && as_dir=.
- for ac_exec_ext in '' $ac_executable_extensions; do
- if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
- ac_cv_prog_AS="${ac_tool_prefix}as"
- $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5
- break 2
- fi
-done
- done
-IFS=$as_save_IFS
-
-fi
-fi
-AS=$ac_cv_prog_AS
-if test -n "$AS"; then
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: $AS" >&5
-$as_echo "$AS" >&6; }
-else
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
-$as_echo "no" >&6; }
-fi
-
-
-fi
-if test -z "$ac_cv_prog_AS"; then
- ac_ct_AS=$AS
- # Extract the first word of "as", so it can be a program name with args.
-set dummy as; ac_word=$2
-{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
-$as_echo_n "checking for $ac_word... " >&6; }
-if ${ac_cv_prog_ac_ct_AS+:} false; then :
- $as_echo_n "(cached) " >&6
-else
- if test -n "$ac_ct_AS"; then
- ac_cv_prog_ac_ct_AS="$ac_ct_AS" # Let the user override the test.
-else
-as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
-for as_dir in $PATH
-do
- IFS=$as_save_IFS
- test -z "$as_dir" && as_dir=.
- for ac_exec_ext in '' $ac_executable_extensions; do
- if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
- ac_cv_prog_ac_ct_AS="as"
- $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5
- break 2
- fi
-done
- done
-IFS=$as_save_IFS
-
-fi
-fi
-ac_ct_AS=$ac_cv_prog_ac_ct_AS
-if test -n "$ac_ct_AS"; then
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_AS" >&5
-$as_echo "$ac_ct_AS" >&6; }
-else
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
-$as_echo "no" >&6; }
-fi
-
- if test "x$ac_ct_AS" = x; then
- AS="false"
- else
- case $cross_compiling:$ac_tool_warned in
-yes:)
-{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5
-$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
-ac_tool_warned=yes ;;
-esac
- AS=$ac_ct_AS
- fi
-else
- AS="$ac_cv_prog_AS"
-fi
-
- if test -n "$ac_tool_prefix"; then
- # Extract the first word of "${ac_tool_prefix}dlltool", so it can be a program name with args.
-set dummy ${ac_tool_prefix}dlltool; ac_word=$2
-{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
-$as_echo_n "checking for $ac_word... " >&6; }
-if ${ac_cv_prog_DLLTOOL+:} false; then :
- $as_echo_n "(cached) " >&6
-else
- if test -n "$DLLTOOL"; then
- ac_cv_prog_DLLTOOL="$DLLTOOL" # Let the user override the test.
-else
-as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
-for as_dir in $PATH
-do
- IFS=$as_save_IFS
- test -z "$as_dir" && as_dir=.
- for ac_exec_ext in '' $ac_executable_extensions; do
- if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
- ac_cv_prog_DLLTOOL="${ac_tool_prefix}dlltool"
- $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5
- break 2
- fi
-done
- done
-IFS=$as_save_IFS
-
-fi
-fi
-DLLTOOL=$ac_cv_prog_DLLTOOL
-if test -n "$DLLTOOL"; then
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DLLTOOL" >&5
-$as_echo "$DLLTOOL" >&6; }
-else
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
-$as_echo "no" >&6; }
-fi
-
-
-fi
-if test -z "$ac_cv_prog_DLLTOOL"; then
- ac_ct_DLLTOOL=$DLLTOOL
- # Extract the first word of "dlltool", so it can be a program name with args.
-set dummy dlltool; ac_word=$2
-{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
-$as_echo_n "checking for $ac_word... " >&6; }
-if ${ac_cv_prog_ac_ct_DLLTOOL+:} false; then :
- $as_echo_n "(cached) " >&6
-else
- if test -n "$ac_ct_DLLTOOL"; then
- ac_cv_prog_ac_ct_DLLTOOL="$ac_ct_DLLTOOL" # Let the user override the test.
-else
-as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
-for as_dir in $PATH
-do
- IFS=$as_save_IFS
- test -z "$as_dir" && as_dir=.
- for ac_exec_ext in '' $ac_executable_extensions; do
- if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
- ac_cv_prog_ac_ct_DLLTOOL="dlltool"
- $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5
- break 2
- fi
-done
- done
-IFS=$as_save_IFS
-
-fi
-fi
-ac_ct_DLLTOOL=$ac_cv_prog_ac_ct_DLLTOOL
-if test -n "$ac_ct_DLLTOOL"; then
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DLLTOOL" >&5
-$as_echo "$ac_ct_DLLTOOL" >&6; }
-else
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
-$as_echo "no" >&6; }
-fi
-
- if test "x$ac_ct_DLLTOOL" = x; then
- DLLTOOL="false"
- else
- case $cross_compiling:$ac_tool_warned in
-yes:)
-{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5
-$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
-ac_tool_warned=yes ;;
-esac
- DLLTOOL=$ac_ct_DLLTOOL
- fi
-else
- DLLTOOL="$ac_cv_prog_DLLTOOL"
-fi
-
- if test -n "$ac_tool_prefix"; then
- # Extract the first word of "${ac_tool_prefix}objdump", so it can be a program name with args.
-set dummy ${ac_tool_prefix}objdump; ac_word=$2
-{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
-$as_echo_n "checking for $ac_word... " >&6; }
-if ${ac_cv_prog_OBJDUMP+:} false; then :
- $as_echo_n "(cached) " >&6
-else
- if test -n "$OBJDUMP"; then
- ac_cv_prog_OBJDUMP="$OBJDUMP" # Let the user override the test.
-else
-as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
-for as_dir in $PATH
-do
- IFS=$as_save_IFS
- test -z "$as_dir" && as_dir=.
- for ac_exec_ext in '' $ac_executable_extensions; do
- if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
- ac_cv_prog_OBJDUMP="${ac_tool_prefix}objdump"
- $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5
- break 2
- fi
-done
- done
-IFS=$as_save_IFS
-
-fi
-fi
-OBJDUMP=$ac_cv_prog_OBJDUMP
-if test -n "$OBJDUMP"; then
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OBJDUMP" >&5
-$as_echo "$OBJDUMP" >&6; }
-else
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
-$as_echo "no" >&6; }
-fi
-
-
-fi
-if test -z "$ac_cv_prog_OBJDUMP"; then
- ac_ct_OBJDUMP=$OBJDUMP
- # Extract the first word of "objdump", so it can be a program name with args.
-set dummy objdump; ac_word=$2
-{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
-$as_echo_n "checking for $ac_word... " >&6; }
-if ${ac_cv_prog_ac_ct_OBJDUMP+:} false; then :
- $as_echo_n "(cached) " >&6
-else
- if test -n "$ac_ct_OBJDUMP"; then
- ac_cv_prog_ac_ct_OBJDUMP="$ac_ct_OBJDUMP" # Let the user override the test.
-else
-as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
-for as_dir in $PATH
-do
- IFS=$as_save_IFS
- test -z "$as_dir" && as_dir=.
- for ac_exec_ext in '' $ac_executable_extensions; do
- if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
- ac_cv_prog_ac_ct_OBJDUMP="objdump"
- $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5
- break 2
- fi
-done
- done
-IFS=$as_save_IFS
-
-fi
-fi
-ac_ct_OBJDUMP=$ac_cv_prog_ac_ct_OBJDUMP
-if test -n "$ac_ct_OBJDUMP"; then
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OBJDUMP" >&5
-$as_echo "$ac_ct_OBJDUMP" >&6; }
-else
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
-$as_echo "no" >&6; }
-fi
-
- if test "x$ac_ct_OBJDUMP" = x; then
- OBJDUMP="false"
- else
- case $cross_compiling:$ac_tool_warned in
-yes:)
-{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5
-$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
-ac_tool_warned=yes ;;
-esac
- OBJDUMP=$ac_ct_OBJDUMP
- fi
-else
- OBJDUMP="$ac_cv_prog_OBJDUMP"
-fi
-
- ;;
-esac
-
-test -z "$AS" && AS=as
-
-
-
-
-
-test -z "$DLLTOOL" && DLLTOOL=dlltool
-
-
-
-
-
-test -z "$OBJDUMP" && OBJDUMP=objdump
-
-
-
-
-
-
-
-
case `pwd` in
*\ * | *\ *)
{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&5
@@ -5431,8 +5059,8 @@ esac
-macro_version='2.4.2'
-macro_revision='1.3337'
+macro_version='2.4.6'
+macro_revision='2.4.6'
@@ -5446,7 +5074,7 @@ macro_revision='1.3337'
-ltmain="$ac_aux_dir/ltmain.sh"
+ltmain=$ac_aux_dir/ltmain.sh
# Backslashify metacharacters that are still active within
# double-quoted strings.
@@ -5495,7 +5123,7 @@ func_echo_all ()
$ECHO ""
}
-case "$ECHO" in
+case $ECHO in
printf*) { $as_echo "$as_me:${as_lineno-$LINENO}: result: printf" >&5
$as_echo "printf" >&6; } ;;
print*) { $as_echo "$as_me:${as_lineno-$LINENO}: result: print -r" >&5
@@ -5818,19 +5446,19 @@ test -z "$GREP" && GREP=grep
# Check whether --with-gnu-ld was given.
if test "${with_gnu_ld+set}" = set; then :
- withval=$with_gnu_ld; test "$withval" = no || with_gnu_ld=yes
+ withval=$with_gnu_ld; test no = "$withval" || with_gnu_ld=yes
else
with_gnu_ld=no
fi
ac_prog=ld
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
# Check if gcc -print-prog-name=ld gives a path.
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for ld used by $CC" >&5
$as_echo_n "checking for ld used by $CC... " >&6; }
case $host in
*-*-mingw*)
- # gcc leaves a trailing carriage return which upsets mingw
+ # gcc leaves a trailing carriage return, which upsets mingw
ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;;
*)
ac_prog=`($CC -print-prog-name=ld) 2>&5` ;;
@@ -5844,7 +5472,7 @@ $as_echo_n "checking for ld used by $CC... " >&6; }
while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do
ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"`
done
- test -z "$LD" && LD="$ac_prog"
+ test -z "$LD" && LD=$ac_prog
;;
"")
# If it fails, then pretend we aren't using GCC.
@@ -5855,7 +5483,7 @@ $as_echo_n "checking for ld used by $CC... " >&6; }
with_gnu_ld=unknown
;;
esac
-elif test "$with_gnu_ld" = yes; then
+elif test yes = "$with_gnu_ld"; then
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for GNU ld" >&5
$as_echo_n "checking for GNU ld... " >&6; }
else
@@ -5866,32 +5494,32 @@ if ${lt_cv_path_LD+:} false; then :
$as_echo_n "(cached) " >&6
else
if test -z "$LD"; then
- lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+ lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR
for ac_dir in $PATH; do
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
test -z "$ac_dir" && ac_dir=.
if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then
- lt_cv_path_LD="$ac_dir/$ac_prog"
+ lt_cv_path_LD=$ac_dir/$ac_prog
# Check to see if the program is GNU ld. I'd rather use --version,
# but apparently some variants of GNU ld only accept -v.
# Break only if it was the GNU/non-GNU ld that we prefer.
case `"$lt_cv_path_LD" -v 2>&1 </dev/null` in
*GNU* | *'with BFD'*)
- test "$with_gnu_ld" != no && break
+ test no != "$with_gnu_ld" && break
;;
*)
- test "$with_gnu_ld" != yes && break
+ test yes != "$with_gnu_ld" && break
;;
esac
fi
done
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
else
- lt_cv_path_LD="$LD" # Let the user override the test with a path.
+ lt_cv_path_LD=$LD # Let the user override the test with a path.
fi
fi
-LD="$lt_cv_path_LD"
+LD=$lt_cv_path_LD
if test -n "$LD"; then
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $LD" >&5
$as_echo "$LD" >&6; }
@@ -5934,33 +5562,38 @@ if ${lt_cv_path_NM+:} false; then :
else
if test -n "$NM"; then
# Let the user override the test.
- lt_cv_path_NM="$NM"
+ lt_cv_path_NM=$NM
else
- lt_nm_to_check="${ac_tool_prefix}nm"
+ lt_nm_to_check=${ac_tool_prefix}nm
if test -n "$ac_tool_prefix" && test "$build" = "$host"; then
lt_nm_to_check="$lt_nm_to_check nm"
fi
for lt_tmp_nm in $lt_nm_to_check; do
- lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+ lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR
for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
test -z "$ac_dir" && ac_dir=.
- tmp_nm="$ac_dir/$lt_tmp_nm"
- if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext" ; then
+ tmp_nm=$ac_dir/$lt_tmp_nm
+ if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext"; then
# Check to see if the nm accepts a BSD-compat flag.
- # Adding the `sed 1q' prevents false positives on HP-UX, which says:
+ # Adding the 'sed 1q' prevents false positives on HP-UX, which says:
# nm: unknown option "B" ignored
# Tru64's nm complains that /dev/null is an invalid object file
- case `"$tmp_nm" -B /dev/null 2>&1 | sed '1q'` in
- */dev/null* | *'Invalid file or object type'*)
+ # MSYS converts /dev/null to NUL, MinGW nm treats NUL as empty
+ case $build_os in
+ mingw*) lt_bad_file=conftest.nm/nofile ;;
+ *) lt_bad_file=/dev/null ;;
+ esac
+ case `"$tmp_nm" -B $lt_bad_file 2>&1 | sed '1q'` in
+ *$lt_bad_file* | *'Invalid file or object type'*)
lt_cv_path_NM="$tmp_nm -B"
- break
+ break 2
;;
*)
case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in
*/dev/null*)
lt_cv_path_NM="$tmp_nm -p"
- break
+ break 2
;;
*)
lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but
@@ -5971,15 +5604,15 @@ else
esac
fi
done
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
done
: ${lt_cv_path_NM=no}
fi
fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_path_NM" >&5
$as_echo "$lt_cv_path_NM" >&6; }
-if test "$lt_cv_path_NM" != "no"; then
- NM="$lt_cv_path_NM"
+if test no != "$lt_cv_path_NM"; then
+ NM=$lt_cv_path_NM
else
# Didn't find any BSD compatible name lister, look for dumpbin.
if test -n "$DUMPBIN"; then :
@@ -6085,9 +5718,9 @@ esac
fi
fi
- case `$DUMPBIN -symbols /dev/null 2>&1 | sed '1q'` in
+ case `$DUMPBIN -symbols -headers /dev/null 2>&1 | sed '1q'` in
*COFF*)
- DUMPBIN="$DUMPBIN -symbols"
+ DUMPBIN="$DUMPBIN -symbols -headers"
;;
*)
DUMPBIN=:
@@ -6095,8 +5728,8 @@ fi
esac
fi
- if test "$DUMPBIN" != ":"; then
- NM="$DUMPBIN"
+ if test : != "$DUMPBIN"; then
+ NM=$DUMPBIN
fi
fi
test -z "$NM" && NM=nm
@@ -6147,7 +5780,7 @@ if ${lt_cv_sys_max_cmd_len+:} false; then :
$as_echo_n "(cached) " >&6
else
i=0
- teststring="ABCD"
+ teststring=ABCD
case $build_os in
msdosdjgpp*)
@@ -6187,7 +5820,7 @@ else
lt_cv_sys_max_cmd_len=8192;
;;
- netbsd* | freebsd* | openbsd* | darwin* | dragonfly*)
+ bitrig* | darwin* | dragonfly* | freebsd* | netbsd* | openbsd*)
# This has been around since 386BSD, at least. Likely further.
if test -x /sbin/sysctl; then
lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax`
@@ -6237,22 +5870,23 @@ else
;;
*)
lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null`
- if test -n "$lt_cv_sys_max_cmd_len"; then
+ if test -n "$lt_cv_sys_max_cmd_len" && \
+ test undefined != "$lt_cv_sys_max_cmd_len"; then
lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4`
lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3`
else
# Make teststring a little bigger before we do anything with it.
# a 1K string should be a reasonable start.
- for i in 1 2 3 4 5 6 7 8 ; do
+ for i in 1 2 3 4 5 6 7 8; do
teststring=$teststring$teststring
done
SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}}
# If test is not a shell built-in, we'll probably end up computing a
# maximum length that is only half of the actual maximum length, but
# we can't tell.
- while { test "X"`env echo "$teststring$teststring" 2>/dev/null` \
+ while { test X`env echo "$teststring$teststring" 2>/dev/null` \
= "X$teststring$teststring"; } >/dev/null 2>&1 &&
- test $i != 17 # 1/2 MB should be enough
+ test 17 != "$i" # 1/2 MB should be enough
do
i=`expr $i + 1`
teststring=$teststring$teststring
@@ -6270,7 +5904,7 @@ else
fi
-if test -n $lt_cv_sys_max_cmd_len ; then
+if test -n "$lt_cv_sys_max_cmd_len"; then
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_sys_max_cmd_len" >&5
$as_echo "$lt_cv_sys_max_cmd_len" >&6; }
else
@@ -6288,30 +5922,6 @@ max_cmd_len=$lt_cv_sys_max_cmd_len
: ${MV="mv -f"}
: ${RM="rm -f"}
-{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the shell understands some XSI constructs" >&5
-$as_echo_n "checking whether the shell understands some XSI constructs... " >&6; }
-# Try some XSI features
-xsi_shell=no
-( _lt_dummy="a/b/c"
- test "${_lt_dummy##*/},${_lt_dummy%/*},${_lt_dummy#??}"${_lt_dummy%"$_lt_dummy"}, \
- = c,a/b,b/c, \
- && eval 'test $(( 1 + 1 )) -eq 2 \
- && test "${#_lt_dummy}" -eq 5' ) >/dev/null 2>&1 \
- && xsi_shell=yes
-{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $xsi_shell" >&5
-$as_echo "$xsi_shell" >&6; }
-
-
-{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the shell understands \"+=\"" >&5
-$as_echo_n "checking whether the shell understands \"+=\"... " >&6; }
-lt_shell_append=no
-( foo=bar; set foo baz; eval "$1+=\$2" && test "$foo" = barbaz ) \
- >/dev/null 2>&1 \
- && lt_shell_append=yes
-{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_shell_append" >&5
-$as_echo "$lt_shell_append" >&6; }
-
-
if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then
lt_unset=unset
else
@@ -6434,13 +6044,13 @@ esac
reload_cmds='$LD$reload_flag -o $output$reload_objs'
case $host_os in
cygwin* | mingw* | pw32* | cegcc*)
- if test "$GCC" != yes; then
+ if test yes != "$GCC"; then
reload_cmds=false
fi
;;
darwin*)
- if test "$GCC" = yes; then
- reload_cmds='$LTCC $LTCFLAGS -nostdlib ${wl}-r -o $output$reload_objs'
+ if test yes = "$GCC"; then
+ reload_cmds='$LTCC $LTCFLAGS -nostdlib $wl-r -o $output$reload_objs'
else
reload_cmds='$LD$reload_flag -o $output$reload_objs'
fi
@@ -6554,6 +6164,9 @@ test -z "$OBJDUMP" && OBJDUMP=objdump
+
+
+
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking how to recognize dependent libraries" >&5
$as_echo_n "checking how to recognize dependent libraries... " >&6; }
if ${lt_cv_deplibs_check_method+:} false; then :
@@ -6565,13 +6178,13 @@ lt_cv_deplibs_check_method='unknown'
# Need to set the preceding variable on all platforms that support
# interlibrary dependencies.
# 'none' -- dependencies not supported.
-# `unknown' -- same as none, but documents that we really don't know.
+# 'unknown' -- same as none, but documents that we really don't know.
# 'pass_all' -- all dependencies passed with no checks.
# 'test_compile' -- check by making test program.
# 'file_magic [[regex]]' -- check by looking for files in library path
-# which responds to the $file_magic_cmd with a given extended regex.
-# If you have `file' or equivalent on your system and you're not sure
-# whether `pass_all' will *always* work, you probably want this one.
+# that responds to the $file_magic_cmd with a given extended regex.
+# If you have 'file' or equivalent on your system and you're not sure
+# whether 'pass_all' will *always* work, you probably want this one.
case $host_os in
aix[4-9]*)
@@ -6598,8 +6211,7 @@ mingw* | pw32*)
# Base MSYS/MinGW do not provide the 'file' command needed by
# func_win32_libid shell function, so use a weaker test based on 'objdump',
# unless we find 'file', for example because we are cross-compiling.
- # func_win32_libid assumes BSD nm, so disallow it if using MS dumpbin.
- if ( test "$lt_cv_nm_interface" = "BSD nm" && file / ) >/dev/null 2>&1; then
+ if ( file / ) >/dev/null 2>&1; then
lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL'
lt_cv_file_magic_cmd='func_win32_libid'
else
@@ -6635,10 +6247,6 @@ freebsd* | dragonfly*)
fi
;;
-gnu*)
- lt_cv_deplibs_check_method=pass_all
- ;;
-
haiku*)
lt_cv_deplibs_check_method=pass_all
;;
@@ -6677,11 +6285,11 @@ irix5* | irix6* | nonstopux*)
;;
# This must be glibc/ELF.
-linux* | k*bsd*-gnu | kopensolaris*-gnu)
+linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
lt_cv_deplibs_check_method=pass_all
;;
-netbsd*)
+netbsd* | netbsdelf*-gnu)
if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then
lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$'
else
@@ -6699,8 +6307,8 @@ newos6*)
lt_cv_deplibs_check_method=pass_all
;;
-openbsd*)
- if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
+openbsd* | bitrig*)
+ if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then
lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|\.so|_pic\.a)$'
else
lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$'
@@ -6753,6 +6361,9 @@ sysv4 | sysv4.3*)
tpf*)
lt_cv_deplibs_check_method=pass_all
;;
+os2*)
+ lt_cv_deplibs_check_method=pass_all
+ ;;
esac
fi
@@ -6898,6 +6509,9 @@ test -z "$DLLTOOL" && DLLTOOL=dlltool
+
+
+
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking how to associate runtime and link libraries" >&5
$as_echo_n "checking how to associate runtime and link libraries... " >&6; }
if ${lt_cv_sharedlib_from_linklib_cmd+:} false; then :
@@ -6907,8 +6521,8 @@ else
case $host_os in
cygwin* | mingw* | pw32* | cegcc*)
- # two different shell functions defined in ltmain.sh
- # decide which to use based on capabilities of $DLLTOOL
+ # two different shell functions defined in ltmain.sh;
+ # decide which one to use based on capabilities of $DLLTOOL
case `$DLLTOOL --help 2>&1` in
*--identify-strict*)
lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib
@@ -6920,7 +6534,7 @@ cygwin* | mingw* | pw32* | cegcc*)
;;
*)
# fallback: assume linklib IS sharedlib
- lt_cv_sharedlib_from_linklib_cmd="$ECHO"
+ lt_cv_sharedlib_from_linklib_cmd=$ECHO
;;
esac
@@ -7075,7 +6689,7 @@ if ac_fn_c_try_compile "$LINENO"; then :
ac_status=$?
$as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
test $ac_status = 0; }
- if test "$ac_status" -eq 0; then
+ if test 0 -eq "$ac_status"; then
# Ensure the archiver fails upon bogus file names.
rm -f conftest.$ac_objext libconftest.a
{ { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$lt_ar_try\""; } >&5
@@ -7083,7 +6697,7 @@ if ac_fn_c_try_compile "$LINENO"; then :
ac_status=$?
$as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
test $ac_status = 0; }
- if test "$ac_status" -ne 0; then
+ if test 0 -ne "$ac_status"; then
lt_cv_ar_at_file=@
fi
fi
@@ -7096,7 +6710,7 @@ fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ar_at_file" >&5
$as_echo "$lt_cv_ar_at_file" >&6; }
-if test "x$lt_cv_ar_at_file" = xno; then
+if test no = "$lt_cv_ar_at_file"; then
archiver_list_spec=
else
archiver_list_spec=$lt_cv_ar_at_file
@@ -7313,7 +6927,7 @@ old_postuninstall_cmds=
if test -n "$RANLIB"; then
case $host_os in
- openbsd*)
+ bitrig* | openbsd*)
old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$tool_oldlib"
;;
*)
@@ -7403,7 +7017,7 @@ cygwin* | mingw* | pw32* | cegcc*)
symcode='[ABCDGISTW]'
;;
hpux*)
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
symcode='[ABCDEGRST]'
fi
;;
@@ -7436,14 +7050,44 @@ case `$NM -V 2>&1` in
symcode='[ABCDGIRSTW]' ;;
esac
+if test "$lt_cv_nm_interface" = "MS dumpbin"; then
+ # Gets list of data symbols to import.
+ lt_cv_sys_global_symbol_to_import="sed -n -e 's/^I .* \(.*\)$/\1/p'"
+ # Adjust the below global symbol transforms to fixup imported variables.
+ lt_cdecl_hook=" -e 's/^I .* \(.*\)$/extern __declspec(dllimport) char \1;/p'"
+ lt_c_name_hook=" -e 's/^I .* \(.*\)$/ {\"\1\", (void *) 0},/p'"
+ lt_c_name_lib_hook="\
+ -e 's/^I .* \(lib.*\)$/ {\"\1\", (void *) 0},/p'\
+ -e 's/^I .* \(.*\)$/ {\"lib\1\", (void *) 0},/p'"
+else
+ # Disable hooks by default.
+ lt_cv_sys_global_symbol_to_import=
+ lt_cdecl_hook=
+ lt_c_name_hook=
+ lt_c_name_lib_hook=
+fi
+
# Transform an extracted symbol line into a proper C declaration.
# Some systems (esp. on ia64) link data and code symbols differently,
# so use this general approach.
-lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern int \1();/p' -e 's/^$symcode* .* \(.*\)$/extern char \1;/p'"
+lt_cv_sys_global_symbol_to_cdecl="sed -n"\
+$lt_cdecl_hook\
+" -e 's/^T .* \(.*\)$/extern int \1();/p'"\
+" -e 's/^$symcode$symcode* .* \(.*\)$/extern char \1;/p'"
# Transform an extracted symbol line into symbol name and symbol address
-lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([^ ]*\)[ ]*$/ {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([^ ]*\) \([^ ]*\)$/ {\"\2\", (void *) \&\2},/p'"
-lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n -e 's/^: \([^ ]*\)[ ]*$/ {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([^ ]*\) \(lib[^ ]*\)$/ {\"\2\", (void *) \&\2},/p' -e 's/^$symcode* \([^ ]*\) \([^ ]*\)$/ {\"lib\2\", (void *) \&\2},/p'"
+lt_cv_sys_global_symbol_to_c_name_address="sed -n"\
+$lt_c_name_hook\
+" -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\
+" -e 's/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/p'"
+
+# Transform an extracted symbol line into symbol name with lib prefix and
+# symbol address.
+lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n"\
+$lt_c_name_lib_hook\
+" -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\
+" -e 's/^$symcode$symcode* .* \(lib.*\)$/ {\"\1\", (void *) \&\1},/p'"\
+" -e 's/^$symcode$symcode* .* \(.*\)$/ {\"lib\1\", (void *) \&\1},/p'"
# Handle CRLF in mingw tool chain
opt_cr=
@@ -7461,21 +7105,24 @@ for ac_symprfx in "" "_"; do
# Write the raw and C identifiers.
if test "$lt_cv_nm_interface" = "MS dumpbin"; then
- # Fake it for dumpbin and say T for any non-static function
- # and D for any global variable.
+ # Fake it for dumpbin and say T for any non-static function,
+ # D for any global variable and I for any imported variable.
# Also find C++ and __fastcall symbols from MSVC++,
# which start with @ or ?.
lt_cv_sys_global_symbol_pipe="$AWK '"\
" {last_section=section; section=\$ 3};"\
" /^COFF SYMBOL TABLE/{for(i in hide) delete hide[i]};"\
" /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\
+" /^ *Symbol name *: /{split(\$ 0,sn,\":\"); si=substr(sn[2],2)};"\
+" /^ *Type *: code/{print \"T\",si,substr(si,length(prfx))};"\
+" /^ *Type *: data/{print \"I\",si,substr(si,length(prfx))};"\
" \$ 0!~/External *\|/{next};"\
" / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\
" {if(hide[section]) next};"\
-" {f=0}; \$ 0~/\(\).*\|/{f=1}; {printf f ? \"T \" : \"D \"};"\
-" {split(\$ 0, a, /\||\r/); split(a[2], s)};"\
-" s[1]~/^[@?]/{print s[1], s[1]; next};"\
-" s[1]~prfx {split(s[1],t,\"@\"); print t[1], substr(t[1],length(prfx))}"\
+" {f=\"D\"}; \$ 0~/\(\).*\|/{f=\"T\"};"\
+" {split(\$ 0,a,/\||\r/); split(a[2],s)};"\
+" s[1]~/^[@?]/{print f,s[1],s[1]; next};"\
+" s[1]~prfx {split(s[1],t,\"@\"); print f,t[1],substr(t[1],length(prfx))}"\
" ' prfx=^$ac_symprfx"
else
lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[ ]\($symcode$symcode*\)[ ][ ]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'"
@@ -7523,11 +7170,11 @@ _LT_EOF
if $GREP ' nm_test_func$' "$nlist" >/dev/null; then
cat <<_LT_EOF > conftest.$ac_ext
/* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */
-#if defined(_WIN32) || defined(__CYGWIN__) || defined(_WIN32_WCE)
-/* DATA imports from DLLs on WIN32 con't be const, because runtime
+#if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE
+/* DATA imports from DLLs on WIN32 can't be const, because runtime
relocations are performed -- see ld's documentation on pseudo-relocs. */
# define LT_DLSYM_CONST
-#elif defined(__osf__)
+#elif defined __osf__
/* This system does not cope well with relocations in const data. */
# define LT_DLSYM_CONST
#else
@@ -7553,7 +7200,7 @@ lt__PROGRAM__LTX_preloaded_symbols[] =
{
{ "@PROGRAM@", (void *) 0 },
_LT_EOF
- $SED "s/^$symcode$symcode* \(.*\) \(.*\)$/ {\"\2\", (void *) \&\2},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext
+ $SED "s/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext
cat <<\_LT_EOF >> conftest.$ac_ext
{0, (void *) 0}
};
@@ -7573,13 +7220,13 @@ _LT_EOF
mv conftest.$ac_objext conftstm.$ac_objext
lt_globsym_save_LIBS=$LIBS
lt_globsym_save_CFLAGS=$CFLAGS
- LIBS="conftstm.$ac_objext"
+ LIBS=conftstm.$ac_objext
CFLAGS="$CFLAGS$lt_prog_compiler_no_builtin_flag"
if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5
(eval $ac_link) 2>&5
ac_status=$?
$as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
- test $ac_status = 0; } && test -s conftest${ac_exeext}; then
+ test $ac_status = 0; } && test -s conftest$ac_exeext; then
pipe_works=yes
fi
LIBS=$lt_globsym_save_LIBS
@@ -7600,7 +7247,7 @@ _LT_EOF
rm -rf conftest* conftst*
# Do not use the global_symbol_pipe unless it works.
- if test "$pipe_works" = yes; then
+ if test yes = "$pipe_works"; then
break
else
lt_cv_sys_global_symbol_pipe=
@@ -7653,6 +7300,16 @@ fi
+
+
+
+
+
+
+
+
+
+
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for sysroot" >&5
$as_echo_n "checking for sysroot... " >&6; }
@@ -7665,9 +7322,9 @@ fi
lt_sysroot=
-case ${with_sysroot} in #(
+case $with_sysroot in #(
yes)
- if test "$GCC" = yes; then
+ if test yes = "$GCC"; then
lt_sysroot=`$CC --print-sysroot 2>/dev/null`
fi
;; #(
@@ -7677,8 +7334,8 @@ case ${with_sysroot} in #(
no|'')
;; #(
*)
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: ${with_sysroot}" >&5
-$as_echo "${with_sysroot}" >&6; }
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: $with_sysroot" >&5
+$as_echo "$with_sysroot" >&6; }
as_fn_error $? "The sysroot must be an absolute path." "$LINENO" 5
;;
esac
@@ -7690,18 +7347,99 @@ $as_echo "${lt_sysroot:-no}" >&6; }
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for a working dd" >&5
+$as_echo_n "checking for a working dd... " >&6; }
+if ${ac_cv_path_lt_DD+:} false; then :
+ $as_echo_n "(cached) " >&6
+else
+ printf 0123456789abcdef0123456789abcdef >conftest.i
+cat conftest.i conftest.i >conftest2.i
+: ${lt_DD:=$DD}
+if test -z "$lt_DD"; then
+ ac_path_lt_DD_found=false
+ # Loop through the user's path and test for each of PROGNAME-LIST
+ as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+ IFS=$as_save_IFS
+ test -z "$as_dir" && as_dir=.
+ for ac_prog in dd; do
+ for ac_exec_ext in '' $ac_executable_extensions; do
+ ac_path_lt_DD="$as_dir/$ac_prog$ac_exec_ext"
+ as_fn_executable_p "$ac_path_lt_DD" || continue
+if "$ac_path_lt_DD" bs=32 count=1 <conftest2.i >conftest.out 2>/dev/null; then
+ cmp -s conftest.i conftest.out \
+ && ac_cv_path_lt_DD="$ac_path_lt_DD" ac_path_lt_DD_found=:
+fi
+ $ac_path_lt_DD_found && break 3
+ done
+ done
+ done
+IFS=$as_save_IFS
+ if test -z "$ac_cv_path_lt_DD"; then
+ :
+ fi
+else
+ ac_cv_path_lt_DD=$lt_DD
+fi
+
+rm -f conftest.i conftest2.i conftest.out
+fi
+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_lt_DD" >&5
+$as_echo "$ac_cv_path_lt_DD" >&6; }
+
+
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking how to truncate binary pipes" >&5
+$as_echo_n "checking how to truncate binary pipes... " >&6; }
+if ${lt_cv_truncate_bin+:} false; then :
+ $as_echo_n "(cached) " >&6
+else
+ printf 0123456789abcdef0123456789abcdef >conftest.i
+cat conftest.i conftest.i >conftest2.i
+lt_cv_truncate_bin=
+if "$ac_cv_path_lt_DD" bs=32 count=1 <conftest2.i >conftest.out 2>/dev/null; then
+ cmp -s conftest.i conftest.out \
+ && lt_cv_truncate_bin="$ac_cv_path_lt_DD bs=4096 count=1"
+fi
+rm -f conftest.i conftest2.i conftest.out
+test -z "$lt_cv_truncate_bin" && lt_cv_truncate_bin="$SED -e 4q"
+fi
+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_truncate_bin" >&5
+$as_echo "$lt_cv_truncate_bin" >&6; }
+
+
+
+
+
+
+
+# Calculate cc_basename. Skip known compiler wrappers and cross-prefix.
+func_cc_basename ()
+{
+ for cc_temp in $*""; do
+ case $cc_temp in
+ compile | *[\\/]compile | ccache | *[\\/]ccache ) ;;
+ distcc | *[\\/]distcc | purify | *[\\/]purify ) ;;
+ \-*) ;;
+ *) break;;
+ esac
+ done
+ func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"`
+}
+
# Check whether --enable-libtool-lock was given.
if test "${enable_libtool_lock+set}" = set; then :
enableval=$enable_libtool_lock;
fi
-test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes
+test no = "$enable_libtool_lock" || enable_libtool_lock=yes
# Some flags need to be propagated to the compiler or linker for good
# libtool support.
case $host in
ia64-*-hpux*)
- # Find out which ABI we are using.
+ # Find out what ABI is being produced by ac_compile, and set mode
+ # options accordingly.
echo 'int i;' > conftest.$ac_ext
if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5
(eval $ac_compile) 2>&5
@@ -7710,24 +7448,25 @@ ia64-*-hpux*)
test $ac_status = 0; }; then
case `/usr/bin/file conftest.$ac_objext` in
*ELF-32*)
- HPUX_IA64_MODE="32"
+ HPUX_IA64_MODE=32
;;
*ELF-64*)
- HPUX_IA64_MODE="64"
+ HPUX_IA64_MODE=64
;;
esac
fi
rm -rf conftest*
;;
*-*-irix6*)
- # Find out which ABI we are using.
+ # Find out what ABI is being produced by ac_compile, and set linker
+ # options accordingly.
echo '#line '$LINENO' "configure"' > conftest.$ac_ext
if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5
(eval $ac_compile) 2>&5
ac_status=$?
$as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
test $ac_status = 0; }; then
- if test "$lt_cv_prog_gnu_ld" = yes; then
+ if test yes = "$lt_cv_prog_gnu_ld"; then
case `/usr/bin/file conftest.$ac_objext` in
*32-bit*)
LD="${LD-ld} -melf32bsmip"
@@ -7756,9 +7495,50 @@ ia64-*-hpux*)
rm -rf conftest*
;;
-x86_64-*kfreebsd*-gnu|x86_64-*linux*|ppc*-*linux*|powerpc*-*linux*| \
+mips64*-*linux*)
+ # Find out what ABI is being produced by ac_compile, and set linker
+ # options accordingly.
+ echo '#line '$LINENO' "configure"' > conftest.$ac_ext
+ if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5
+ (eval $ac_compile) 2>&5
+ ac_status=$?
+ $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
+ test $ac_status = 0; }; then
+ emul=elf
+ case `/usr/bin/file conftest.$ac_objext` in
+ *32-bit*)
+ emul="${emul}32"
+ ;;
+ *64-bit*)
+ emul="${emul}64"
+ ;;
+ esac
+ case `/usr/bin/file conftest.$ac_objext` in
+ *MSB*)
+ emul="${emul}btsmip"
+ ;;
+ *LSB*)
+ emul="${emul}ltsmip"
+ ;;
+ esac
+ case `/usr/bin/file conftest.$ac_objext` in
+ *N32*)
+ emul="${emul}n32"
+ ;;
+ esac
+ LD="${LD-ld} -m $emul"
+ fi
+ rm -rf conftest*
+ ;;
+
+x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \
s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
- # Find out which ABI we are using.
+ # Find out what ABI is being produced by ac_compile, and set linker
+ # options accordingly. Note that the listed cases only cover the
+ # situations where additional linker options are needed (such as when
+ # doing 32-bit compilation for a host where ld defaults to 64-bit, or
+ # vice versa); the common cases where no linker options are needed do
+ # not appear in the list.
echo 'int i;' > conftest.$ac_ext
if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5
(eval $ac_compile) 2>&5
@@ -7772,9 +7552,19 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
LD="${LD-ld} -m elf_i386_fbsd"
;;
x86_64-*linux*)
- LD="${LD-ld} -m elf_i386"
+ case `/usr/bin/file conftest.o` in
+ *x86-64*)
+ LD="${LD-ld} -m elf32_x86_64"
+ ;;
+ *)
+ LD="${LD-ld} -m elf_i386"
+ ;;
+ esac
;;
- ppc64-*linux*|powerpc64-*linux*)
+ powerpc64le-*linux*)
+ LD="${LD-ld} -m elf32lppclinux"
+ ;;
+ powerpc64-*linux*)
LD="${LD-ld} -m elf32ppclinux"
;;
s390x-*linux*)
@@ -7793,7 +7583,10 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
x86_64-*linux*)
LD="${LD-ld} -m elf_x86_64"
;;
- ppc*-*linux*|powerpc*-*linux*)
+ powerpcle-*linux*)
+ LD="${LD-ld} -m elf64lppc"
+ ;;
+ powerpc-*linux*)
LD="${LD-ld} -m elf64ppc"
;;
s390*-*linux*|s390*-*tpf*)
@@ -7811,7 +7604,7 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
*-*-sco3.2v5*)
# On SCO OpenServer 5, we need -belf to get full-featured binaries.
- SAVE_CFLAGS="$CFLAGS"
+ SAVE_CFLAGS=$CFLAGS
CFLAGS="$CFLAGS -belf"
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether the C compiler needs -belf" >&5
$as_echo_n "checking whether the C compiler needs -belf... " >&6; }
@@ -7851,13 +7644,14 @@ ac_compiler_gnu=$ac_cv_c_compiler_gnu
fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_cc_needs_belf" >&5
$as_echo "$lt_cv_cc_needs_belf" >&6; }
- if test x"$lt_cv_cc_needs_belf" != x"yes"; then
+ if test yes != "$lt_cv_cc_needs_belf"; then
# this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf
- CFLAGS="$SAVE_CFLAGS"
+ CFLAGS=$SAVE_CFLAGS
fi
;;
*-*solaris*)
- # Find out which ABI we are using.
+ # Find out what ABI is being produced by ac_compile, and set linker
+ # options accordingly.
echo 'int i;' > conftest.$ac_ext
if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5
(eval $ac_compile) 2>&5
@@ -7869,7 +7663,7 @@ $as_echo "$lt_cv_cc_needs_belf" >&6; }
case $lt_cv_prog_gnu_ld in
yes*)
case $host in
- i?86-*-solaris*)
+ i?86-*-solaris*|x86_64-*-solaris*)
LD="${LD-ld} -m elf_x86_64"
;;
sparc*-*-solaris*)
@@ -7878,7 +7672,7 @@ $as_echo "$lt_cv_cc_needs_belf" >&6; }
esac
# GNU ld 2.21 introduced _sol2 emulations. Use them if available.
if ${LD-ld} -V | grep _sol2 >/dev/null 2>&1; then
- LD="${LD-ld}_sol2"
+ LD=${LD-ld}_sol2
fi
;;
*)
@@ -7894,7 +7688,7 @@ $as_echo "$lt_cv_cc_needs_belf" >&6; }
;;
esac
-need_locks="$enable_libtool_lock"
+need_locks=$enable_libtool_lock
if test -n "$ac_tool_prefix"; then
# Extract the first word of "${ac_tool_prefix}mt", so it can be a program name with args.
@@ -8005,7 +7799,7 @@ else
fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_path_mainfest_tool" >&5
$as_echo "$lt_cv_path_mainfest_tool" >&6; }
-if test "x$lt_cv_path_mainfest_tool" != xyes; then
+if test yes != "$lt_cv_path_mainfest_tool"; then
MANIFEST_TOOL=:
fi
@@ -8508,7 +8302,7 @@ if ${lt_cv_apple_cc_single_mod+:} false; then :
$as_echo_n "(cached) " >&6
else
lt_cv_apple_cc_single_mod=no
- if test -z "${LT_MULTI_MODULE}"; then
+ if test -z "$LT_MULTI_MODULE"; then
# By default we will add the -single_module flag. You can override
# by either setting the environment variable LT_MULTI_MODULE
# non-empty at configure time, or by adding -multi_module to the
@@ -8526,7 +8320,7 @@ else
cat conftest.err >&5
# Otherwise, if the output was created with a 0 exit code from
# the compiler, it worked.
- elif test -f libconftest.dylib && test $_lt_result -eq 0; then
+ elif test -f libconftest.dylib && test 0 = "$_lt_result"; then
lt_cv_apple_cc_single_mod=yes
else
cat conftest.err >&5
@@ -8565,7 +8359,7 @@ else
fi
rm -f core conftest.err conftest.$ac_objext \
conftest$ac_exeext conftest.$ac_ext
- LDFLAGS="$save_LDFLAGS"
+ LDFLAGS=$save_LDFLAGS
fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_exported_symbols_list" >&5
@@ -8594,7 +8388,7 @@ _LT_EOF
_lt_result=$?
if test -s conftest.err && $GREP force_load conftest.err; then
cat conftest.err >&5
- elif test -f conftest && test $_lt_result -eq 0 && $GREP forced_load conftest >/dev/null 2>&1 ; then
+ elif test -f conftest && test 0 = "$_lt_result" && $GREP forced_load conftest >/dev/null 2>&1; then
lt_cv_ld_force_load=yes
else
cat conftest.err >&5
@@ -8607,32 +8401,32 @@ fi
$as_echo "$lt_cv_ld_force_load" >&6; }
case $host_os in
rhapsody* | darwin1.[012])
- _lt_dar_allow_undefined='${wl}-undefined ${wl}suppress' ;;
+ _lt_dar_allow_undefined='$wl-undefined ${wl}suppress' ;;
darwin1.*)
- _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;;
+ _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;;
darwin*) # darwin 5.x on
# if running on 10.5 or later, the deployment target defaults
# to the OS version, if on x86, and 10.4, the deployment
# target defaults to 10.4. Don't you love it?
case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in
10.0,*86*-darwin8*|10.0,*-darwin[91]*)
- _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;;
- 10.[012]*)
- _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;;
+ _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;;
+ 10.[012][,.]*)
+ _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;;
10.*)
- _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;;
+ _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;;
esac
;;
esac
- if test "$lt_cv_apple_cc_single_mod" = "yes"; then
+ if test yes = "$lt_cv_apple_cc_single_mod"; then
_lt_dar_single_mod='$single_module'
fi
- if test "$lt_cv_ld_exported_symbols_list" = "yes"; then
- _lt_dar_export_syms=' ${wl}-exported_symbols_list,$output_objdir/${libname}-symbols.expsym'
+ if test yes = "$lt_cv_ld_exported_symbols_list"; then
+ _lt_dar_export_syms=' $wl-exported_symbols_list,$output_objdir/$libname-symbols.expsym'
else
- _lt_dar_export_syms='~$NMEDIT -s $output_objdir/${libname}-symbols.expsym ${lib}'
+ _lt_dar_export_syms='~$NMEDIT -s $output_objdir/$libname-symbols.expsym $lib'
fi
- if test "$DSYMUTIL" != ":" && test "$lt_cv_ld_force_load" = "no"; then
+ if test : != "$DSYMUTIL" && test no = "$lt_cv_ld_force_load"; then
_lt_dsymutil='~$DSYMUTIL $lib || :'
else
_lt_dsymutil=
@@ -8640,6 +8434,41 @@ $as_echo "$lt_cv_ld_force_load" >&6; }
;;
esac
+# func_munge_path_list VARIABLE PATH
+# -----------------------------------
+# VARIABLE is name of variable containing _space_ separated list of
+# directories to be munged by the contents of PATH, which is string
+# having a format:
+# "DIR[:DIR]:"
+# string "DIR[ DIR]" will be prepended to VARIABLE
+# ":DIR[:DIR]"
+# string "DIR[ DIR]" will be appended to VARIABLE
+# "DIRP[:DIRP]::[DIRA:]DIRA"
+# string "DIRP[ DIRP]" will be prepended to VARIABLE and string
+# "DIRA[ DIRA]" will be appended to VARIABLE
+# "DIR[:DIR]"
+# VARIABLE will be replaced by "DIR[ DIR]"
+func_munge_path_list ()
+{
+ case x$2 in
+ x)
+ ;;
+ *:)
+ eval $1=\"`$ECHO $2 | $SED 's/:/ /g'` \$$1\"
+ ;;
+ x:*)
+ eval $1=\"\$$1 `$ECHO $2 | $SED 's/:/ /g'`\"
+ ;;
+ *::*)
+ eval $1=\"\$$1\ `$ECHO $2 | $SED -e 's/.*:://' -e 's/:/ /g'`\"
+ eval $1=\"`$ECHO $2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \$$1\"
+ ;;
+ *)
+ eval $1=\"`$ECHO $2 | $SED 's/:/ /g'`\"
+ ;;
+ esac
+}
+
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for ANSI C header files" >&5
$as_echo_n "checking for ANSI C header files... " >&6; }
@@ -8788,9 +8617,9 @@ done
func_stripname_cnf ()
{
- case ${2} in
- .*) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%\\\\${2}\$%%"`;;
- *) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%${2}\$%%"`;;
+ case $2 in
+ .*) func_stripname_result=`$ECHO "$3" | $SED "s%^$1%%; s%\\\\$2\$%%"`;;
+ *) func_stripname_result=`$ECHO "$3" | $SED "s%^$1%%; s%$2\$%%"`;;
esac
} # func_stripname_cnf
@@ -8805,6 +8634,68 @@ func_stripname_cnf ()
enable_dlopen=no
+ enable_win32_dll=no
+
+
+ # Check whether --enable-shared was given.
+if test "${enable_shared+set}" = set; then :
+ enableval=$enable_shared; p=${PACKAGE-default}
+ case $enableval in
+ yes) enable_shared=yes ;;
+ no) enable_shared=no ;;
+ *)
+ enable_shared=no
+ # Look at the argument we got. We use all the common list separators.
+ lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
+ for pkg in $enableval; do
+ IFS=$lt_save_ifs
+ if test "X$pkg" = "X$p"; then
+ enable_shared=yes
+ fi
+ done
+ IFS=$lt_save_ifs
+ ;;
+ esac
+else
+ enable_shared=yes
+fi
+
+
+
+
+
+
+
+
+
+ # Check whether --enable-static was given.
+if test "${enable_static+set}" = set; then :
+ enableval=$enable_static; p=${PACKAGE-default}
+ case $enableval in
+ yes) enable_static=yes ;;
+ no) enable_static=no ;;
+ *)
+ enable_static=no
+ # Look at the argument we got. We use all the common list separators.
+ lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
+ for pkg in $enableval; do
+ IFS=$lt_save_ifs
+ if test "X$pkg" = "X$p"; then
+ enable_static=yes
+ fi
+ done
+ IFS=$lt_save_ifs
+ ;;
+ esac
+else
+ enable_static=yes
+fi
+
+
+
+
+
+
@@ -8817,14 +8708,14 @@ if test "${with_pic+set}" = set; then :
*)
pic_mode=default
# Look at the argument we got. We use all the common list separators.
- lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+ lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
for lt_pkg in $withval; do
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
if test "X$lt_pkg" = "X$lt_p"; then
pic_mode=yes
fi
done
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
;;
esac
else
@@ -8832,8 +8723,6 @@ else
fi
-test -z "$pic_mode" && pic_mode=default
-
@@ -8849,14 +8738,14 @@ if test "${enable_fast_install+set}" = set; then :
*)
enable_fast_install=no
# Look at the argument we got. We use all the common list separators.
- lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+ lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
for pkg in $enableval; do
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
if test "X$pkg" = "X$p"; then
enable_fast_install=yes
fi
done
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
;;
esac
else
@@ -8870,11 +8759,63 @@ fi
+ shared_archive_member_spec=
+case $host,$enable_shared in
+power*-*-aix[5-9]*,yes)
+ { $as_echo "$as_me:${as_lineno-$LINENO}: checking which variant of shared library versioning to provide" >&5
+$as_echo_n "checking which variant of shared library versioning to provide... " >&6; }
+
+# Check whether --with-aix-soname was given.
+if test "${with_aix_soname+set}" = set; then :
+ withval=$with_aix_soname; case $withval in
+ aix|svr4|both)
+ ;;
+ *)
+ as_fn_error $? "Unknown argument to --with-aix-soname" "$LINENO" 5
+ ;;
+ esac
+ lt_cv_with_aix_soname=$with_aix_soname
+else
+ if ${lt_cv_with_aix_soname+:} false; then :
+ $as_echo_n "(cached) " >&6
+else
+ lt_cv_with_aix_soname=aix
+fi
+
+ with_aix_soname=$lt_cv_with_aix_soname
+fi
+
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: $with_aix_soname" >&5
+$as_echo "$with_aix_soname" >&6; }
+ if test aix != "$with_aix_soname"; then
+ # For the AIX way of multilib, we name the shared archive member
+ # based on the bitwidth used, traditionally 'shr.o' or 'shr_64.o',
+ # and 'shr.imp' or 'shr_64.imp', respectively, for the Import File.
+ # Even when GNU compilers ignore OBJECT_MODE but need '-maix64' flag,
+ # the AIX toolchain works better with OBJECT_MODE set (default 32).
+ if test 64 = "${OBJECT_MODE-32}"; then
+ shared_archive_member_spec=shr_64
+ else
+ shared_archive_member_spec=shr
+ fi
+ fi
+ ;;
+*)
+ with_aix_soname=aix
+ ;;
+esac
+
+
+
+
+
+
+
# This can be used to rebuild libtool when needed
-LIBTOOL_DEPS="$ltmain"
+LIBTOOL_DEPS=$ltmain
# Always use our own libtool.
LIBTOOL='$(SHELL) $(top_builddir)/libtool'
@@ -8923,7 +8864,7 @@ test -z "$LN_S" && LN_S="ln -s"
-if test -n "${ZSH_VERSION+set}" ; then
+if test -n "${ZSH_VERSION+set}"; then
setopt NO_GLOB_SUBST
fi
@@ -8962,7 +8903,7 @@ aix3*)
# AIX sometimes has problems with the GCC collect2 program. For some
# reason, if we set the COLLECT_NAMES environment variable, the problems
# vanish in a puff of smoke.
- if test "X${COLLECT_NAMES+set}" != Xset; then
+ if test set != "${COLLECT_NAMES+set}"; then
COLLECT_NAMES=
export COLLECT_NAMES
fi
@@ -8973,14 +8914,14 @@ esac
ofile=libtool
can_build_shared=yes
-# All known linkers require a `.a' archive for static linking (except MSVC,
+# All known linkers require a '.a' archive for static linking (except MSVC,
# which needs '.lib').
libext=a
-with_gnu_ld="$lt_cv_prog_gnu_ld"
+with_gnu_ld=$lt_cv_prog_gnu_ld
-old_CC="$CC"
-old_CFLAGS="$CFLAGS"
+old_CC=$CC
+old_CFLAGS=$CFLAGS
# Set sane defaults for various variables
test -z "$CC" && CC=cc
@@ -8989,15 +8930,8 @@ test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS
test -z "$LD" && LD=ld
test -z "$ac_objext" && ac_objext=o
-for cc_temp in $compiler""; do
- case $cc_temp in
- compile | *[\\/]compile | ccache | *[\\/]ccache ) ;;
- distcc | *[\\/]distcc | purify | *[\\/]purify ) ;;
- \-*) ;;
- *) break;;
- esac
-done
-cc_basename=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"`
+func_cc_basename $compiler
+cc_basename=$func_cc_basename_result
# Only perform the check for file, if the check method requires it
@@ -9012,22 +8946,22 @@ if ${lt_cv_path_MAGIC_CMD+:} false; then :
else
case $MAGIC_CMD in
[\\/*] | ?:[\\/]*)
- lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path.
+ lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path.
;;
*)
- lt_save_MAGIC_CMD="$MAGIC_CMD"
- lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+ lt_save_MAGIC_CMD=$MAGIC_CMD
+ lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR
ac_dummy="/usr/bin$PATH_SEPARATOR$PATH"
for ac_dir in $ac_dummy; do
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
test -z "$ac_dir" && ac_dir=.
- if test -f $ac_dir/${ac_tool_prefix}file; then
- lt_cv_path_MAGIC_CMD="$ac_dir/${ac_tool_prefix}file"
+ if test -f "$ac_dir/${ac_tool_prefix}file"; then
+ lt_cv_path_MAGIC_CMD=$ac_dir/"${ac_tool_prefix}file"
if test -n "$file_magic_test_file"; then
case $deplibs_check_method in
"file_magic "*)
file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"`
- MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
+ MAGIC_CMD=$lt_cv_path_MAGIC_CMD
if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null |
$EGREP "$file_magic_regex" > /dev/null; then
:
@@ -9050,13 +8984,13 @@ _LT_EOF
break
fi
done
- IFS="$lt_save_ifs"
- MAGIC_CMD="$lt_save_MAGIC_CMD"
+ IFS=$lt_save_ifs
+ MAGIC_CMD=$lt_save_MAGIC_CMD
;;
esac
fi
-MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
+MAGIC_CMD=$lt_cv_path_MAGIC_CMD
if test -n "$MAGIC_CMD"; then
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $MAGIC_CMD" >&5
$as_echo "$MAGIC_CMD" >&6; }
@@ -9078,22 +9012,22 @@ if ${lt_cv_path_MAGIC_CMD+:} false; then :
else
case $MAGIC_CMD in
[\\/*] | ?:[\\/]*)
- lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path.
+ lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path.
;;
*)
- lt_save_MAGIC_CMD="$MAGIC_CMD"
- lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+ lt_save_MAGIC_CMD=$MAGIC_CMD
+ lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR
ac_dummy="/usr/bin$PATH_SEPARATOR$PATH"
for ac_dir in $ac_dummy; do
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
test -z "$ac_dir" && ac_dir=.
- if test -f $ac_dir/file; then
- lt_cv_path_MAGIC_CMD="$ac_dir/file"
+ if test -f "$ac_dir/file"; then
+ lt_cv_path_MAGIC_CMD=$ac_dir/"file"
if test -n "$file_magic_test_file"; then
case $deplibs_check_method in
"file_magic "*)
file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"`
- MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
+ MAGIC_CMD=$lt_cv_path_MAGIC_CMD
if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null |
$EGREP "$file_magic_regex" > /dev/null; then
:
@@ -9116,13 +9050,13 @@ _LT_EOF
break
fi
done
- IFS="$lt_save_ifs"
- MAGIC_CMD="$lt_save_MAGIC_CMD"
+ IFS=$lt_save_ifs
+ MAGIC_CMD=$lt_save_MAGIC_CMD
;;
esac
fi
-MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
+MAGIC_CMD=$lt_cv_path_MAGIC_CMD
if test -n "$MAGIC_CMD"; then
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $MAGIC_CMD" >&5
$as_echo "$MAGIC_CMD" >&6; }
@@ -9143,7 +9077,7 @@ esac
# Use C for the default configuration in the libtool script
-lt_save_CC="$CC"
+lt_save_CC=$CC
ac_ext=c
ac_cpp='$CPP $CPPFLAGS'
ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
@@ -9205,7 +9139,7 @@ if test -n "$compiler"; then
lt_prog_compiler_no_builtin_flag=
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
case $cc_basename in
nvcc*)
lt_prog_compiler_no_builtin_flag=' -Xcompiler -fno-builtin' ;;
@@ -9221,7 +9155,7 @@ else
lt_cv_prog_compiler_rtti_exceptions=no
ac_outfile=conftest.$ac_objext
echo "$lt_simple_compile_test_code" > conftest.$ac_ext
- lt_compiler_flag="-fno-rtti -fno-exceptions"
+ lt_compiler_flag="-fno-rtti -fno-exceptions" ## exclude from sc_useless_quotes_in_assignment
# Insert the option either (1) after the last *FLAGS variable, or
# (2) before a word containing "conftest.", or (3) at the end.
# Note that $ac_compile itself does not contain backslashes and begins
@@ -9251,7 +9185,7 @@ fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_rtti_exceptions" >&5
$as_echo "$lt_cv_prog_compiler_rtti_exceptions" >&6; }
-if test x"$lt_cv_prog_compiler_rtti_exceptions" = xyes; then
+if test yes = "$lt_cv_prog_compiler_rtti_exceptions"; then
lt_prog_compiler_no_builtin_flag="$lt_prog_compiler_no_builtin_flag -fno-rtti -fno-exceptions"
else
:
@@ -9269,17 +9203,18 @@ lt_prog_compiler_pic=
lt_prog_compiler_static=
- if test "$GCC" = yes; then
+ if test yes = "$GCC"; then
lt_prog_compiler_wl='-Wl,'
lt_prog_compiler_static='-static'
case $host_os in
aix*)
# All AIX code is PIC.
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# AIX 5 now supports IA64 processor
lt_prog_compiler_static='-Bstatic'
fi
+ lt_prog_compiler_pic='-fPIC'
;;
amigaos*)
@@ -9290,8 +9225,8 @@ lt_prog_compiler_static=
;;
m68k)
# FIXME: we need at least 68020 code to build shared libraries, but
- # adding the `-m68020' flag to GCC prevents building anything better,
- # like `-m68040'.
+ # adding the '-m68020' flag to GCC prevents building anything better,
+ # like '-m68040'.
lt_prog_compiler_pic='-m68020 -resident32 -malways-restore-a4'
;;
esac
@@ -9307,6 +9242,11 @@ lt_prog_compiler_static=
# Although the cygwin gcc ignores -fPIC, still need this for old-style
# (--disable-auto-import) libraries
lt_prog_compiler_pic='-DDLL_EXPORT'
+ case $host_os in
+ os2*)
+ lt_prog_compiler_static='$wl-static'
+ ;;
+ esac
;;
darwin* | rhapsody*)
@@ -9377,7 +9317,7 @@ lt_prog_compiler_static=
case $host_os in
aix*)
lt_prog_compiler_wl='-Wl,'
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# AIX 5 now supports IA64 processor
lt_prog_compiler_static='-Bstatic'
else
@@ -9385,10 +9325,29 @@ lt_prog_compiler_static=
fi
;;
+ darwin* | rhapsody*)
+ # PIC is the default on this platform
+ # Common symbols not allowed in MH_DYLIB files
+ lt_prog_compiler_pic='-fno-common'
+ case $cc_basename in
+ nagfor*)
+ # NAG Fortran compiler
+ lt_prog_compiler_wl='-Wl,-Wl,,'
+ lt_prog_compiler_pic='-PIC'
+ lt_prog_compiler_static='-Bstatic'
+ ;;
+ esac
+ ;;
+
mingw* | cygwin* | pw32* | os2* | cegcc*)
# This hack is so that the source file can tell whether it is being
# built for inclusion in a dll (and should export symbols for example).
lt_prog_compiler_pic='-DDLL_EXPORT'
+ case $host_os in
+ os2*)
+ lt_prog_compiler_static='$wl-static'
+ ;;
+ esac
;;
hpux9* | hpux10* | hpux11*)
@@ -9404,7 +9363,7 @@ lt_prog_compiler_static=
;;
esac
# Is there a better lt_prog_compiler_static that works with the bundled CC?
- lt_prog_compiler_static='${wl}-a ${wl}archive'
+ lt_prog_compiler_static='$wl-a ${wl}archive'
;;
irix5* | irix6* | nonstopux*)
@@ -9413,9 +9372,9 @@ lt_prog_compiler_static=
lt_prog_compiler_static='-non_shared'
;;
- linux* | k*bsd*-gnu | kopensolaris*-gnu)
+ linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
case $cc_basename in
- # old Intel for x86_64 which still supported -KPIC.
+ # old Intel for x86_64, which still supported -KPIC.
ecc*)
lt_prog_compiler_wl='-Wl,'
lt_prog_compiler_pic='-KPIC'
@@ -9440,6 +9399,12 @@ lt_prog_compiler_static=
lt_prog_compiler_pic='-PIC'
lt_prog_compiler_static='-Bstatic'
;;
+ tcc*)
+ # Fabrice Bellard et al's Tiny C Compiler
+ lt_prog_compiler_wl='-Wl,'
+ lt_prog_compiler_pic='-fPIC'
+ lt_prog_compiler_static='-static'
+ ;;
pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*)
# Portland Group compilers (*not* the Pentium gcc compiler,
# which looks to be a dead project)
@@ -9537,7 +9502,7 @@ lt_prog_compiler_static=
;;
sysv4*MP*)
- if test -d /usr/nec ;then
+ if test -d /usr/nec; then
lt_prog_compiler_pic='-Kconform_pic'
lt_prog_compiler_static='-Bstatic'
fi
@@ -9566,7 +9531,7 @@ lt_prog_compiler_static=
fi
case $host_os in
- # For platforms which do not support PIC, -DPIC is meaningless:
+ # For platforms that do not support PIC, -DPIC is meaningless:
*djgpp*)
lt_prog_compiler_pic=
;;
@@ -9598,7 +9563,7 @@ else
lt_cv_prog_compiler_pic_works=no
ac_outfile=conftest.$ac_objext
echo "$lt_simple_compile_test_code" > conftest.$ac_ext
- lt_compiler_flag="$lt_prog_compiler_pic -DPIC"
+ lt_compiler_flag="$lt_prog_compiler_pic -DPIC" ## exclude from sc_useless_quotes_in_assignment
# Insert the option either (1) after the last *FLAGS variable, or
# (2) before a word containing "conftest.", or (3) at the end.
# Note that $ac_compile itself does not contain backslashes and begins
@@ -9628,7 +9593,7 @@ fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_works" >&5
$as_echo "$lt_cv_prog_compiler_pic_works" >&6; }
-if test x"$lt_cv_prog_compiler_pic_works" = xyes; then
+if test yes = "$lt_cv_prog_compiler_pic_works"; then
case $lt_prog_compiler_pic in
"" | " "*) ;;
*) lt_prog_compiler_pic=" $lt_prog_compiler_pic" ;;
@@ -9660,7 +9625,7 @@ if ${lt_cv_prog_compiler_static_works+:} false; then :
$as_echo_n "(cached) " >&6
else
lt_cv_prog_compiler_static_works=no
- save_LDFLAGS="$LDFLAGS"
+ save_LDFLAGS=$LDFLAGS
LDFLAGS="$LDFLAGS $lt_tmp_static_flag"
echo "$lt_simple_link_test_code" > conftest.$ac_ext
if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then
@@ -9679,13 +9644,13 @@ else
fi
fi
$RM -r conftest*
- LDFLAGS="$save_LDFLAGS"
+ LDFLAGS=$save_LDFLAGS
fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_static_works" >&5
$as_echo "$lt_cv_prog_compiler_static_works" >&6; }
-if test x"$lt_cv_prog_compiler_static_works" = xyes; then
+if test yes = "$lt_cv_prog_compiler_static_works"; then
:
else
lt_prog_compiler_static=
@@ -9805,8 +9770,8 @@ $as_echo "$lt_cv_prog_compiler_c_o" >&6; }
-hard_links="nottested"
-if test "$lt_cv_prog_compiler_c_o" = no && test "$need_locks" != no; then
+hard_links=nottested
+if test no = "$lt_cv_prog_compiler_c_o" && test no != "$need_locks"; then
# do not overwrite the value of need_locks provided by the user
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if we can lock with hard links" >&5
$as_echo_n "checking if we can lock with hard links... " >&6; }
@@ -9818,9 +9783,9 @@ $as_echo_n "checking if we can lock with hard links... " >&6; }
ln conftest.a conftest.b 2>/dev/null && hard_links=no
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $hard_links" >&5
$as_echo "$hard_links" >&6; }
- if test "$hard_links" = no; then
- { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5
-$as_echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;}
+ if test no = "$hard_links"; then
+ { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&5
+$as_echo "$as_me: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&2;}
need_locks=warn
fi
else
@@ -9863,9 +9828,9 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
# included in the symbol list
include_expsyms=
# exclude_expsyms can be an extended regexp of symbols to exclude
- # it will be wrapped by ` (' and `)$', so one must not match beginning or
- # end of line. Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc',
- # as well as any symbol that contains `d'.
+ # it will be wrapped by ' (' and ')$', so one must not match beginning or
+ # end of line. Example: 'a|bc|.*d.*' will exclude the symbols 'a' and 'bc',
+ # as well as any symbol that contains 'd'.
exclude_expsyms='_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*'
# Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out
# platforms (ab)use it in PIC code, but their linkers get confused if
@@ -9880,7 +9845,7 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
# FIXME: the MSVC++ port hasn't been tested in a loooong time
# When not using gcc, we currently assume that we are using
# Microsoft Visual C++.
- if test "$GCC" != yes; then
+ if test yes != "$GCC"; then
with_gnu_ld=no
fi
;;
@@ -9888,9 +9853,12 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
# we just hope/assume this is gcc and not c89 (= MSVC++)
with_gnu_ld=yes
;;
- openbsd*)
+ openbsd* | bitrig*)
with_gnu_ld=no
;;
+ linux* | k*bsd*-gnu | gnu*)
+ link_all_deplibs=no
+ ;;
esac
ld_shlibs=yes
@@ -9898,7 +9866,7 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
# On some targets, GNU ld is compatible enough with the native linker
# that we're better off using the native interface for both.
lt_use_gnu_ld_interface=no
- if test "$with_gnu_ld" = yes; then
+ if test yes = "$with_gnu_ld"; then
case $host_os in
aix*)
# The AIX port of GNU ld has always aspired to compatibility
@@ -9920,24 +9888,24 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
esac
fi
- if test "$lt_use_gnu_ld_interface" = yes; then
+ if test yes = "$lt_use_gnu_ld_interface"; then
# If archive_cmds runs LD, not CC, wlarc should be empty
- wlarc='${wl}'
+ wlarc='$wl'
# Set some defaults for GNU ld with shared library support. These
# are reset later if shared libraries are not supported. Putting them
# here allows them to be overridden if necessary.
runpath_var=LD_RUN_PATH
- hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
- export_dynamic_flag_spec='${wl}--export-dynamic'
+ hardcode_libdir_flag_spec='$wl-rpath $wl$libdir'
+ export_dynamic_flag_spec='$wl--export-dynamic'
# ancient GNU ld didn't support --whole-archive et. al.
if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then
- whole_archive_flag_spec="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive'
+ whole_archive_flag_spec=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive'
else
whole_archive_flag_spec=
fi
supports_anon_versioning=no
- case `$LD -v 2>&1` in
+ case `$LD -v | $SED -e 's/(^)\+)\s\+//' 2>&1` in
*GNU\ gold*) supports_anon_versioning=yes ;;
*\ [01].* | *\ 2.[0-9].* | *\ 2.10.*) ;; # catch versions < 2.11
*\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ...
@@ -9950,7 +9918,7 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
case $host_os in
aix[3-9]*)
# On AIX/PPC, the GNU linker is very broken
- if test "$host_cpu" != ia64; then
+ if test ia64 != "$host_cpu"; then
ld_shlibs=no
cat <<_LT_EOF 1>&2
@@ -9969,7 +9937,7 @@ _LT_EOF
case $host_cpu in
powerpc)
# see comment about AmigaOS4 .so support
- archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+ archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
archive_expsym_cmds=''
;;
m68k)
@@ -9985,7 +9953,7 @@ _LT_EOF
allow_undefined_flag=unsupported
# Joseph Beckenbach <jrb3@best.com> says some releases of gcc
# support --undefined. This deserves some investigation. FIXME
- archive_cmds='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+ archive_cmds='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
else
ld_shlibs=no
fi
@@ -9995,7 +9963,7 @@ _LT_EOF
# _LT_TAGVAR(hardcode_libdir_flag_spec, ) is actually meaningless,
# as there is no search path for DLLs.
hardcode_libdir_flag_spec='-L$libdir'
- export_dynamic_flag_spec='${wl}--export-all-symbols'
+ export_dynamic_flag_spec='$wl--export-all-symbols'
allow_undefined_flag=unsupported
always_export_symbols=no
enable_shared_with_static_runtimes=yes
@@ -10003,61 +9971,89 @@ _LT_EOF
exclude_expsyms='[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname'
if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then
- archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
- # If the export-symbols file already is a .def file (1st line
- # is EXPORTS), use it as is; otherwise, prepend...
- archive_expsym_cmds='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then
- cp $export_symbols $output_objdir/$soname.def;
- else
- echo EXPORTS > $output_objdir/$soname.def;
- cat $export_symbols >> $output_objdir/$soname.def;
- fi~
- $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+ archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+ # If the export-symbols file already is a .def file, use it as
+ # is; otherwise, prepend EXPORTS...
+ archive_expsym_cmds='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then
+ cp $export_symbols $output_objdir/$soname.def;
+ else
+ echo EXPORTS > $output_objdir/$soname.def;
+ cat $export_symbols >> $output_objdir/$soname.def;
+ fi~
+ $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
else
ld_shlibs=no
fi
;;
haiku*)
- archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+ archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
link_all_deplibs=yes
;;
+ os2*)
+ hardcode_libdir_flag_spec='-L$libdir'
+ hardcode_minus_L=yes
+ allow_undefined_flag=unsupported
+ shrext_cmds=.dll
+ archive_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+ $ECHO EXPORTS >> $output_objdir/$libname.def~
+ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~
+ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+ emximp -o $lib $output_objdir/$libname.def'
+ archive_expsym_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+ $ECHO EXPORTS >> $output_objdir/$libname.def~
+ prefix_cmds="$SED"~
+ if test EXPORTS = "`$SED 1q $export_symbols`"; then
+ prefix_cmds="$prefix_cmds -e 1d";
+ fi~
+ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~
+ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~
+ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+ emximp -o $lib $output_objdir/$libname.def'
+ old_archive_From_new_cmds='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def'
+ enable_shared_with_static_runtimes=yes
+ ;;
+
interix[3-9]*)
hardcode_direct=no
hardcode_shlibpath_var=no
- hardcode_libdir_flag_spec='${wl}-rpath,$libdir'
- export_dynamic_flag_spec='${wl}-E'
+ hardcode_libdir_flag_spec='$wl-rpath,$libdir'
+ export_dynamic_flag_spec='$wl-E'
# Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc.
# Instead, shared libraries are loaded at an image base (0x10000000 by
# default) and relocated if they conflict, which is a slow very memory
# consuming and fragmenting process. To avoid this, we pick a random,
# 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link
# time. Moving up from 0x10000000 also allows more sbrk(2) space.
- archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
- archive_expsym_cmds='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+ archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+ archive_expsym_cmds='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
;;
gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu)
tmp_diet=no
- if test "$host_os" = linux-dietlibc; then
+ if test linux-dietlibc = "$host_os"; then
case $cc_basename in
diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn)
esac
fi
if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \
- && test "$tmp_diet" = no
+ && test no = "$tmp_diet"
then
tmp_addflag=' $pic_flag'
tmp_sharedflag='-shared'
case $cc_basename,$host_cpu in
pgcc*) # Portland Group C compiler
- whole_archive_flag_spec='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+ whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
tmp_addflag=' $pic_flag'
;;
pgf77* | pgf90* | pgf95* | pgfortran*)
# Portland Group f77 and f90 compilers
- whole_archive_flag_spec='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+ whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
tmp_addflag=' $pic_flag -Mnomain' ;;
ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64
tmp_addflag=' -i_dynamic' ;;
@@ -10068,42 +10064,47 @@ _LT_EOF
lf95*) # Lahey Fortran 8.1
whole_archive_flag_spec=
tmp_sharedflag='--shared' ;;
+ nagfor*) # NAGFOR 5.3
+ tmp_sharedflag='-Wl,-shared' ;;
xl[cC]* | bgxl[cC]* | mpixl[cC]*) # IBM XL C 8.0 on PPC (deal with xlf below)
tmp_sharedflag='-qmkshrobj'
tmp_addflag= ;;
nvcc*) # Cuda Compiler Driver 2.2
- whole_archive_flag_spec='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+ whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
compiler_needs_object=yes
;;
esac
case `$CC -V 2>&1 | sed 5q` in
*Sun\ C*) # Sun C 5.9
- whole_archive_flag_spec='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+ whole_archive_flag_spec='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
compiler_needs_object=yes
tmp_sharedflag='-G' ;;
*Sun\ F*) # Sun Fortran 8.3
tmp_sharedflag='-G' ;;
esac
- archive_cmds='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+ archive_cmds='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
- if test "x$supports_anon_versioning" = xyes; then
+ if test yes = "$supports_anon_versioning"; then
archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~
- cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
- echo "local: *; };" >> $output_objdir/$libname.ver~
- $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib'
+ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
+ echo "local: *; };" >> $output_objdir/$libname.ver~
+ $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib'
fi
case $cc_basename in
+ tcc*)
+ export_dynamic_flag_spec='-rdynamic'
+ ;;
xlf* | bgf* | bgxlf* | mpixlf*)
# IBM XL Fortran 10.1 on PPC cannot create shared libs itself
whole_archive_flag_spec='--whole-archive$convenience --no-whole-archive'
- hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+ hardcode_libdir_flag_spec='$wl-rpath $wl$libdir'
archive_cmds='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib'
- if test "x$supports_anon_versioning" = xyes; then
+ if test yes = "$supports_anon_versioning"; then
archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~
- cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
- echo "local: *; };" >> $output_objdir/$libname.ver~
- $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib'
+ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
+ echo "local: *; };" >> $output_objdir/$libname.ver~
+ $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib'
fi
;;
esac
@@ -10112,13 +10113,13 @@ _LT_EOF
fi
;;
- netbsd*)
+ netbsd* | netbsdelf*-gnu)
if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then
archive_cmds='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib'
wlarc=
else
- archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
- archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+ archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+ archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
fi
;;
@@ -10136,8 +10137,8 @@ _LT_EOF
_LT_EOF
elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
- archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
- archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+ archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+ archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
else
ld_shlibs=no
fi
@@ -10149,7 +10150,7 @@ _LT_EOF
ld_shlibs=no
cat <<_LT_EOF 1>&2
-*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 can not
+*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 cannot
*** reliably create shared libraries on SCO systems. Therefore, libtool
*** is disabling shared libraries support. We urge you to upgrade GNU
*** binutils to release 2.16.91.0.3 or newer. Another option is to modify
@@ -10164,9 +10165,9 @@ _LT_EOF
# DT_RUNPATH tag from executables and libraries. But doing so
# requires that you compile everything twice, which is a pain.
if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
- hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
- archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
- archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+ hardcode_libdir_flag_spec='$wl-rpath $wl$libdir'
+ archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+ archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
else
ld_shlibs=no
fi
@@ -10183,15 +10184,15 @@ _LT_EOF
*)
if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
- archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
- archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+ archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+ archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
else
ld_shlibs=no
fi
;;
esac
- if test "$ld_shlibs" = no; then
+ if test no = "$ld_shlibs"; then
runpath_var=
hardcode_libdir_flag_spec=
export_dynamic_flag_spec=
@@ -10207,7 +10208,7 @@ _LT_EOF
# Note: this linker hardcodes the directories in LIBPATH if there
# are no directories specified by -L.
hardcode_minus_L=yes
- if test "$GCC" = yes && test -z "$lt_prog_compiler_static"; then
+ if test yes = "$GCC" && test -z "$lt_prog_compiler_static"; then
# Neither direct hardcoding nor static linking is supported with a
# broken collect2.
hardcode_direct=unsupported
@@ -10215,34 +10216,57 @@ _LT_EOF
;;
aix[4-9]*)
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# On IA64, the linker does run time linking by default, so we don't
# have to do anything special.
aix_use_runtimelinking=no
exp_sym_flag='-Bexport'
- no_entry_flag=""
+ no_entry_flag=
else
# If we're using GNU nm, then we don't want the "-C" option.
- # -C means demangle to AIX nm, but means don't demangle with GNU nm
- # Also, AIX nm treats weak defined symbols like other global
- # defined symbols, whereas GNU nm marks them as "W".
+ # -C means demangle to GNU nm, but means don't demangle to AIX nm.
+ # Without the "-l" option, or with the "-B" option, AIX nm treats
+ # weak defined symbols like other global defined symbols, whereas
+ # GNU nm marks them as "W".
+ # While the 'weak' keyword is ignored in the Export File, we need
+ # it in the Import File for the 'aix-soname' feature, so we have
+ # to replace the "-B" option with "-P" for AIX nm.
if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then
- export_symbols_cmds='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+ export_symbols_cmds='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && (substr(\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols'
else
- export_symbols_cmds='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+ export_symbols_cmds='`func_echo_all $NM | $SED -e '\''s/B\([^B]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && (substr(\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols'
fi
aix_use_runtimelinking=no
# Test if we are trying to use run time linking or normal
# AIX style linking. If -brtl is somewhere in LDFLAGS, we
- # need to do runtime linking.
+ # have runtime linking enabled, and use it for executables.
+ # For shared libraries, we enable/disable runtime linking
+ # depending on the kind of the shared library created -
+ # when "with_aix_soname,aix_use_runtimelinking" is:
+ # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables
+ # "aix,yes" lib.so shared, rtl:yes, for executables
+ # lib.a static archive
+ # "both,no" lib.so.V(shr.o) shared, rtl:yes
+ # lib.a(lib.so.V) shared, rtl:no, for executables
+ # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables
+ # lib.a(lib.so.V) shared, rtl:no
+ # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables
+ # lib.a static archive
case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*)
for ld_flag in $LDFLAGS; do
- if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then
+ if (test x-brtl = "x$ld_flag" || test x-Wl,-brtl = "x$ld_flag"); then
aix_use_runtimelinking=yes
break
fi
done
+ if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then
+ # With aix-soname=svr4, we create the lib.so.V shared archives only,
+ # so we don't have lib.a shared libs to link our executables.
+ # We have to force runtime linking in this case.
+ aix_use_runtimelinking=yes
+ LDFLAGS="$LDFLAGS -Wl,-brtl"
+ fi
;;
esac
@@ -10261,13 +10285,21 @@ _LT_EOF
hardcode_direct_absolute=yes
hardcode_libdir_separator=':'
link_all_deplibs=yes
- file_list_spec='${wl}-f,'
+ file_list_spec='$wl-f,'
+ case $with_aix_soname,$aix_use_runtimelinking in
+ aix,*) ;; # traditional, no import file
+ svr4,* | *,yes) # use import file
+ # The Import File defines what to hardcode.
+ hardcode_direct=no
+ hardcode_direct_absolute=no
+ ;;
+ esac
- if test "$GCC" = yes; then
+ if test yes = "$GCC"; then
case $host_os in aix4.[012]|aix4.[012].*)
# We only want to do this on AIX 4.2 and lower, the check
# below for broken collect2 doesn't work under 4.3+
- collect2name=`${CC} -print-prog-name=collect2`
+ collect2name=`$CC -print-prog-name=collect2`
if test -f "$collect2name" &&
strings "$collect2name" | $GREP resolve_lib_name >/dev/null
then
@@ -10286,35 +10318,42 @@ _LT_EOF
;;
esac
shared_flag='-shared'
- if test "$aix_use_runtimelinking" = yes; then
- shared_flag="$shared_flag "'${wl}-G'
+ if test yes = "$aix_use_runtimelinking"; then
+ shared_flag="$shared_flag "'$wl-G'
fi
+ # Need to ensure runtime linking is disabled for the traditional
+ # shared library, or the linker may eventually find shared libraries
+ # /with/ Import File - we do not want to mix them.
+ shared_flag_aix='-shared'
+ shared_flag_svr4='-shared $wl-G'
else
# not using gcc
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release
# chokes on -Wl,-G. The following line is correct:
shared_flag='-G'
else
- if test "$aix_use_runtimelinking" = yes; then
- shared_flag='${wl}-G'
+ if test yes = "$aix_use_runtimelinking"; then
+ shared_flag='$wl-G'
else
- shared_flag='${wl}-bM:SRE'
+ shared_flag='$wl-bM:SRE'
fi
+ shared_flag_aix='$wl-bM:SRE'
+ shared_flag_svr4='$wl-G'
fi
fi
- export_dynamic_flag_spec='${wl}-bexpall'
+ export_dynamic_flag_spec='$wl-bexpall'
# It seems that -bexpall does not export symbols beginning with
# underscore (_), so it is better to generate a list of symbols to export.
always_export_symbols=yes
- if test "$aix_use_runtimelinking" = yes; then
+ if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then
# Warning - without using the other runtime loading flags (-brtl),
# -berok will link without error, but may produce a broken library.
allow_undefined_flag='-berok'
# Determine the default libpath from the value encoded in an
# empty executable.
- if test "${lt_cv_aix_libpath+set}" = set; then
+ if test set = "${lt_cv_aix_libpath+set}"; then
aix_libpath=$lt_cv_aix_libpath
else
if ${lt_cv_aix_libpath_+:} false; then :
@@ -10349,7 +10388,7 @@ fi
rm -f core conftest.err conftest.$ac_objext \
conftest$ac_exeext conftest.$ac_ext
if test -z "$lt_cv_aix_libpath_"; then
- lt_cv_aix_libpath_="/usr/lib:/lib"
+ lt_cv_aix_libpath_=/usr/lib:/lib
fi
fi
@@ -10357,17 +10396,17 @@ fi
aix_libpath=$lt_cv_aix_libpath_
fi
- hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath"
- archive_expsym_cmds='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then func_echo_all "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag"
+ hardcode_libdir_flag_spec='$wl-blibpath:$libdir:'"$aix_libpath"
+ archive_expsym_cmds='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag
else
- if test "$host_cpu" = ia64; then
- hardcode_libdir_flag_spec='${wl}-R $libdir:/usr/lib:/lib'
+ if test ia64 = "$host_cpu"; then
+ hardcode_libdir_flag_spec='$wl-R $libdir:/usr/lib:/lib'
allow_undefined_flag="-z nodefs"
- archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols"
+ archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols"
else
# Determine the default libpath from the value encoded in an
# empty executable.
- if test "${lt_cv_aix_libpath+set}" = set; then
+ if test set = "${lt_cv_aix_libpath+set}"; then
aix_libpath=$lt_cv_aix_libpath
else
if ${lt_cv_aix_libpath_+:} false; then :
@@ -10402,7 +10441,7 @@ fi
rm -f core conftest.err conftest.$ac_objext \
conftest$ac_exeext conftest.$ac_ext
if test -z "$lt_cv_aix_libpath_"; then
- lt_cv_aix_libpath_="/usr/lib:/lib"
+ lt_cv_aix_libpath_=/usr/lib:/lib
fi
fi
@@ -10410,21 +10449,33 @@ fi
aix_libpath=$lt_cv_aix_libpath_
fi
- hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath"
+ hardcode_libdir_flag_spec='$wl-blibpath:$libdir:'"$aix_libpath"
# Warning - without using the other run time loading flags,
# -berok will link without error, but may produce a broken library.
- no_undefined_flag=' ${wl}-bernotok'
- allow_undefined_flag=' ${wl}-berok'
- if test "$with_gnu_ld" = yes; then
+ no_undefined_flag=' $wl-bernotok'
+ allow_undefined_flag=' $wl-berok'
+ if test yes = "$with_gnu_ld"; then
# We only use this code for GNU lds that support --whole-archive.
- whole_archive_flag_spec='${wl}--whole-archive$convenience ${wl}--no-whole-archive'
+ whole_archive_flag_spec='$wl--whole-archive$convenience $wl--no-whole-archive'
else
# Exported symbols can be pulled into shared objects from archives
whole_archive_flag_spec='$convenience'
fi
archive_cmds_need_lc=yes
- # This is similar to how AIX traditionally builds its shared libraries.
- archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname'
+ archive_expsym_cmds='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d'
+ # -brtl affects multiple linker settings, -berok does not and is overridden later
+ compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([, ]\\)%-berok\\1%g"`'
+ if test svr4 != "$with_aix_soname"; then
+ # This is similar to how AIX traditionally builds its shared libraries.
+ archive_expsym_cmds="$archive_expsym_cmds"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname'
+ fi
+ if test aix != "$with_aix_soname"; then
+ archive_expsym_cmds="$archive_expsym_cmds"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp'
+ else
+ # used by -dlpreopen to get the symbols
+ archive_expsym_cmds="$archive_expsym_cmds"'~$MV $output_objdir/$realname.d/$soname $output_objdir'
+ fi
+ archive_expsym_cmds="$archive_expsym_cmds"'~$RM -r $output_objdir/$realname.d'
fi
fi
;;
@@ -10433,7 +10484,7 @@ fi
case $host_cpu in
powerpc)
# see comment about AmigaOS4 .so support
- archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+ archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
archive_expsym_cmds=''
;;
m68k)
@@ -10463,16 +10514,17 @@ fi
# Tell ltmain to make .lib files, not .a files.
libext=lib
# Tell ltmain to make .dll files, not .so files.
- shrext_cmds=".dll"
+ shrext_cmds=.dll
# FIXME: Setting linknames here is a bad hack.
- archive_cmds='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-dll~linknames='
- archive_expsym_cmds='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then
- sed -n -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' -e '1\\\!p' < $export_symbols > $output_objdir/$soname.exp;
- else
- sed -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' < $export_symbols > $output_objdir/$soname.exp;
- fi~
- $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~
- linknames='
+ archive_cmds='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames='
+ archive_expsym_cmds='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then
+ cp "$export_symbols" "$output_objdir/$soname.def";
+ echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp";
+ else
+ $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp;
+ fi~
+ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~
+ linknames='
# The linker will not automatically build a static lib if we build a DLL.
# _LT_TAGVAR(old_archive_from_new_cmds, )='true'
enable_shared_with_static_runtimes=yes
@@ -10481,18 +10533,18 @@ fi
# Don't use ranlib
old_postinstall_cmds='chmod 644 $oldlib'
postlink_cmds='lt_outputfile="@OUTPUT@"~
- lt_tool_outputfile="@TOOL_OUTPUT@"~
- case $lt_outputfile in
- *.exe|*.EXE) ;;
- *)
- lt_outputfile="$lt_outputfile.exe"
- lt_tool_outputfile="$lt_tool_outputfile.exe"
- ;;
- esac~
- if test "$MANIFEST_TOOL" != ":" && test -f "$lt_outputfile.manifest"; then
- $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1;
- $RM "$lt_outputfile.manifest";
- fi'
+ lt_tool_outputfile="@TOOL_OUTPUT@"~
+ case $lt_outputfile in
+ *.exe|*.EXE) ;;
+ *)
+ lt_outputfile=$lt_outputfile.exe
+ lt_tool_outputfile=$lt_tool_outputfile.exe
+ ;;
+ esac~
+ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then
+ $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1;
+ $RM "$lt_outputfile.manifest";
+ fi'
;;
*)
# Assume MSVC wrapper
@@ -10501,7 +10553,7 @@ fi
# Tell ltmain to make .lib files, not .a files.
libext=lib
# Tell ltmain to make .dll files, not .so files.
- shrext_cmds=".dll"
+ shrext_cmds=.dll
# FIXME: Setting linknames here is a bad hack.
archive_cmds='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames='
# The linker will automatically build a .lib file if we build a DLL.
@@ -10520,24 +10572,24 @@ fi
hardcode_direct=no
hardcode_automatic=yes
hardcode_shlibpath_var=unsupported
- if test "$lt_cv_ld_force_load" = "yes"; then
- whole_archive_flag_spec='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience ${wl}-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`'
+ if test yes = "$lt_cv_ld_force_load"; then
+ whole_archive_flag_spec='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`'
else
whole_archive_flag_spec=''
fi
link_all_deplibs=yes
- allow_undefined_flag="$_lt_dar_allow_undefined"
+ allow_undefined_flag=$_lt_dar_allow_undefined
case $cc_basename in
- ifort*) _lt_dar_can_shared=yes ;;
+ ifort*|nagfor*) _lt_dar_can_shared=yes ;;
*) _lt_dar_can_shared=$GCC ;;
esac
- if test "$_lt_dar_can_shared" = "yes"; then
+ if test yes = "$_lt_dar_can_shared"; then
output_verbose_link_cmd=func_echo_all
- archive_cmds="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}"
- module_cmds="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}"
- archive_expsym_cmds="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}"
- module_expsym_cmds="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}"
+ archive_cmds="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil"
+ module_cmds="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil"
+ archive_expsym_cmds="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil"
+ module_expsym_cmds="sed -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil"
else
ld_shlibs=no
@@ -10579,33 +10631,33 @@ fi
;;
hpux9*)
- if test "$GCC" = yes; then
- archive_cmds='$RM $output_objdir/$soname~$CC -shared $pic_flag ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
+ if test yes = "$GCC"; then
+ archive_cmds='$RM $output_objdir/$soname~$CC -shared $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib'
else
- archive_cmds='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
+ archive_cmds='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib'
fi
- hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir'
+ hardcode_libdir_flag_spec='$wl+b $wl$libdir'
hardcode_libdir_separator=:
hardcode_direct=yes
# hardcode_minus_L: Not really in the search PATH,
# but as the default location of the library.
hardcode_minus_L=yes
- export_dynamic_flag_spec='${wl}-E'
+ export_dynamic_flag_spec='$wl-E'
;;
hpux10*)
- if test "$GCC" = yes && test "$with_gnu_ld" = no; then
- archive_cmds='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
+ if test yes,no = "$GCC,$with_gnu_ld"; then
+ archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
else
archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'
fi
- if test "$with_gnu_ld" = no; then
- hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir'
+ if test no = "$with_gnu_ld"; then
+ hardcode_libdir_flag_spec='$wl+b $wl$libdir'
hardcode_libdir_separator=:
hardcode_direct=yes
hardcode_direct_absolute=yes
- export_dynamic_flag_spec='${wl}-E'
+ export_dynamic_flag_spec='$wl-E'
# hardcode_minus_L: Not really in the search PATH,
# but as the default location of the library.
hardcode_minus_L=yes
@@ -10613,25 +10665,25 @@ fi
;;
hpux11*)
- if test "$GCC" = yes && test "$with_gnu_ld" = no; then
+ if test yes,no = "$GCC,$with_gnu_ld"; then
case $host_cpu in
hppa*64*)
- archive_cmds='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_cmds='$CC -shared $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags'
;;
ia64*)
- archive_cmds='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
+ archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
;;
*)
- archive_cmds='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
+ archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
;;
esac
else
case $host_cpu in
hppa*64*)
- archive_cmds='$CC -b ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_cmds='$CC -b $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags'
;;
ia64*)
- archive_cmds='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
+ archive_cmds='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
;;
*)
@@ -10643,7 +10695,7 @@ if ${lt_cv_prog_compiler__b+:} false; then :
$as_echo_n "(cached) " >&6
else
lt_cv_prog_compiler__b=no
- save_LDFLAGS="$LDFLAGS"
+ save_LDFLAGS=$LDFLAGS
LDFLAGS="$LDFLAGS -b"
echo "$lt_simple_link_test_code" > conftest.$ac_ext
if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then
@@ -10662,14 +10714,14 @@ else
fi
fi
$RM -r conftest*
- LDFLAGS="$save_LDFLAGS"
+ LDFLAGS=$save_LDFLAGS
fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler__b" >&5
$as_echo "$lt_cv_prog_compiler__b" >&6; }
-if test x"$lt_cv_prog_compiler__b" = xyes; then
- archive_cmds='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
+if test yes = "$lt_cv_prog_compiler__b"; then
+ archive_cmds='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
else
archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'
fi
@@ -10677,8 +10729,8 @@ fi
;;
esac
fi
- if test "$with_gnu_ld" = no; then
- hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir'
+ if test no = "$with_gnu_ld"; then
+ hardcode_libdir_flag_spec='$wl+b $wl$libdir'
hardcode_libdir_separator=:
case $host_cpu in
@@ -10689,7 +10741,7 @@ fi
*)
hardcode_direct=yes
hardcode_direct_absolute=yes
- export_dynamic_flag_spec='${wl}-E'
+ export_dynamic_flag_spec='$wl-E'
# hardcode_minus_L: Not really in the search PATH,
# but as the default location of the library.
@@ -10700,8 +10752,8 @@ fi
;;
irix5* | irix6* | nonstopux*)
- if test "$GCC" = yes; then
- archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+ if test yes = "$GCC"; then
+ archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
# Try to use the -exported_symbol ld option, if it does not
# work, assume that -exports_file does not work either and
# implicitly export all symbols.
@@ -10711,8 +10763,8 @@ $as_echo_n "checking whether the $host_os linker accepts -exported_symbol... " >
if ${lt_cv_irix_exported_symbol+:} false; then :
$as_echo_n "(cached) " >&6
else
- save_LDFLAGS="$LDFLAGS"
- LDFLAGS="$LDFLAGS -shared ${wl}-exported_symbol ${wl}foo ${wl}-update_registry ${wl}/dev/null"
+ save_LDFLAGS=$LDFLAGS
+ LDFLAGS="$LDFLAGS -shared $wl-exported_symbol ${wl}foo $wl-update_registry $wl/dev/null"
cat confdefs.h - <<_ACEOF >conftest.$ac_ext
/* end confdefs.h. */
int foo (void) { return 0; }
@@ -10724,25 +10776,36 @@ else
fi
rm -f core conftest.err conftest.$ac_objext \
conftest$ac_exeext conftest.$ac_ext
- LDFLAGS="$save_LDFLAGS"
+ LDFLAGS=$save_LDFLAGS
fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_irix_exported_symbol" >&5
$as_echo "$lt_cv_irix_exported_symbol" >&6; }
- if test "$lt_cv_irix_exported_symbol" = yes; then
- archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations ${wl}-exports_file ${wl}$export_symbols -o $lib'
+ if test yes = "$lt_cv_irix_exported_symbol"; then
+ archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations $wl-exports_file $wl$export_symbols -o $lib'
fi
+ link_all_deplibs=no
else
- archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
- archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -exports_file $export_symbols -o $lib'
+ archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
+ archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -exports_file $export_symbols -o $lib'
fi
archive_cmds_need_lc='no'
- hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+ hardcode_libdir_flag_spec='$wl-rpath $wl$libdir'
hardcode_libdir_separator=:
inherit_rpath=yes
link_all_deplibs=yes
;;
- netbsd*)
+ linux*)
+ case $cc_basename in
+ tcc*)
+ # Fabrice Bellard et al's Tiny C Compiler
+ ld_shlibs=yes
+ archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
+ ;;
+ esac
+ ;;
+
+ netbsd* | netbsdelf*-gnu)
if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then
archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out
else
@@ -10756,7 +10819,7 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
newsos6)
archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
hardcode_direct=yes
- hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+ hardcode_libdir_flag_spec='$wl-rpath $wl$libdir'
hardcode_libdir_separator=:
hardcode_shlibpath_var=no
;;
@@ -10764,27 +10827,19 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
*nto* | *qnx*)
;;
- openbsd*)
+ openbsd* | bitrig*)
if test -f /usr/libexec/ld.so; then
hardcode_direct=yes
hardcode_shlibpath_var=no
hardcode_direct_absolute=yes
- if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
+ if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then
archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
- archive_expsym_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols'
- hardcode_libdir_flag_spec='${wl}-rpath,$libdir'
- export_dynamic_flag_spec='${wl}-E'
+ archive_expsym_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags $wl-retain-symbols-file,$export_symbols'
+ hardcode_libdir_flag_spec='$wl-rpath,$libdir'
+ export_dynamic_flag_spec='$wl-E'
else
- case $host_os in
- openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*)
- archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags'
- hardcode_libdir_flag_spec='-R$libdir'
- ;;
- *)
- archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
- hardcode_libdir_flag_spec='${wl}-rpath,$libdir'
- ;;
- esac
+ archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
+ hardcode_libdir_flag_spec='$wl-rpath,$libdir'
fi
else
ld_shlibs=no
@@ -10795,33 +10850,53 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
hardcode_libdir_flag_spec='-L$libdir'
hardcode_minus_L=yes
allow_undefined_flag=unsupported
- archive_cmds='$ECHO "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~echo DATA >> $output_objdir/$libname.def~echo " SINGLE NONSHARED" >> $output_objdir/$libname.def~echo EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def'
- old_archive_from_new_cmds='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def'
+ shrext_cmds=.dll
+ archive_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+ $ECHO EXPORTS >> $output_objdir/$libname.def~
+ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~
+ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+ emximp -o $lib $output_objdir/$libname.def'
+ archive_expsym_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+ $ECHO EXPORTS >> $output_objdir/$libname.def~
+ prefix_cmds="$SED"~
+ if test EXPORTS = "`$SED 1q $export_symbols`"; then
+ prefix_cmds="$prefix_cmds -e 1d";
+ fi~
+ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~
+ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~
+ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+ emximp -o $lib $output_objdir/$libname.def'
+ old_archive_From_new_cmds='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def'
+ enable_shared_with_static_runtimes=yes
;;
osf3*)
- if test "$GCC" = yes; then
- allow_undefined_flag=' ${wl}-expect_unresolved ${wl}\*'
- archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+ if test yes = "$GCC"; then
+ allow_undefined_flag=' $wl-expect_unresolved $wl\*'
+ archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
else
allow_undefined_flag=' -expect_unresolved \*'
- archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
+ archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
fi
archive_cmds_need_lc='no'
- hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+ hardcode_libdir_flag_spec='$wl-rpath $wl$libdir'
hardcode_libdir_separator=:
;;
osf4* | osf5*) # as osf3* with the addition of -msym flag
- if test "$GCC" = yes; then
- allow_undefined_flag=' ${wl}-expect_unresolved ${wl}\*'
- archive_cmds='$CC -shared${allow_undefined_flag} $pic_flag $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
- hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir'
+ if test yes = "$GCC"; then
+ allow_undefined_flag=' $wl-expect_unresolved $wl\*'
+ archive_cmds='$CC -shared$allow_undefined_flag $pic_flag $libobjs $deplibs $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
+ hardcode_libdir_flag_spec='$wl-rpath $wl$libdir'
else
allow_undefined_flag=' -expect_unresolved \*'
- archive_cmds='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
+ archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
archive_expsym_cmds='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~
- $CC -shared${allow_undefined_flag} ${wl}-input ${wl}$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib~$RM $lib.exp'
+ $CC -shared$allow_undefined_flag $wl-input $wl$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~$RM $lib.exp'
# Both c and cxx compiler support -rpath directly
hardcode_libdir_flag_spec='-rpath $libdir'
@@ -10832,24 +10907,24 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
solaris*)
no_undefined_flag=' -z defs'
- if test "$GCC" = yes; then
- wlarc='${wl}'
- archive_cmds='$CC -shared $pic_flag ${wl}-z ${wl}text ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+ if test yes = "$GCC"; then
+ wlarc='$wl'
+ archive_cmds='$CC -shared $pic_flag $wl-z ${wl}text $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags'
archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
- $CC -shared $pic_flag ${wl}-z ${wl}text ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
+ $CC -shared $pic_flag $wl-z ${wl}text $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
else
case `$CC -V 2>&1` in
*"Compilers 5.0"*)
wlarc=''
- archive_cmds='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags'
+ archive_cmds='$LD -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $linker_flags'
archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
- $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp'
+ $LD -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp'
;;
*)
- wlarc='${wl}'
- archive_cmds='$CC -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $compiler_flags'
+ wlarc='$wl'
+ archive_cmds='$CC -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $compiler_flags'
archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
- $CC -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
+ $CC -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
;;
esac
fi
@@ -10859,11 +10934,11 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
solaris2.[0-5] | solaris2.[0-5].*) ;;
*)
# The compiler driver will combine and reorder linker options,
- # but understands `-z linker_flag'. GCC discards it without `$wl',
+ # but understands '-z linker_flag'. GCC discards it without '$wl',
# but is careful enough not to reorder.
# Supported since Solaris 2.6 (maybe 2.5.1?)
- if test "$GCC" = yes; then
- whole_archive_flag_spec='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract'
+ if test yes = "$GCC"; then
+ whole_archive_flag_spec='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract'
else
whole_archive_flag_spec='-z allextract$convenience -z defaultextract'
fi
@@ -10873,10 +10948,10 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
;;
sunos4*)
- if test "x$host_vendor" = xsequent; then
+ if test sequent = "$host_vendor"; then
# Use $CC to link under sequent, because it throws in some extra .o
# files that make .init and .fini sections work.
- archive_cmds='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_cmds='$CC -G $wl-h $soname -o $lib $libobjs $deplibs $compiler_flags'
else
archive_cmds='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags'
fi
@@ -10925,43 +11000,43 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
;;
sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*)
- no_undefined_flag='${wl}-z,text'
+ no_undefined_flag='$wl-z,text'
archive_cmds_need_lc=no
hardcode_shlibpath_var=no
runpath_var='LD_RUN_PATH'
- if test "$GCC" = yes; then
- archive_cmds='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
- archive_expsym_cmds='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ if test yes = "$GCC"; then
+ archive_cmds='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_expsym_cmds='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
else
- archive_cmds='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
- archive_expsym_cmds='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_cmds='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_expsym_cmds='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
fi
;;
sysv5* | sco3.2v5* | sco5v6*)
- # Note: We can NOT use -z defs as we might desire, because we do not
+ # Note: We CANNOT use -z defs as we might desire, because we do not
# link with -lc, and that would cause any symbols used from libc to
# always be unresolved, which means just about no library would
# ever link correctly. If we're not using GNU ld we use -z text
# though, which does catch some bad symbols but isn't as heavy-handed
# as -z defs.
- no_undefined_flag='${wl}-z,text'
- allow_undefined_flag='${wl}-z,nodefs'
+ no_undefined_flag='$wl-z,text'
+ allow_undefined_flag='$wl-z,nodefs'
archive_cmds_need_lc=no
hardcode_shlibpath_var=no
- hardcode_libdir_flag_spec='${wl}-R,$libdir'
+ hardcode_libdir_flag_spec='$wl-R,$libdir'
hardcode_libdir_separator=':'
link_all_deplibs=yes
- export_dynamic_flag_spec='${wl}-Bexport'
+ export_dynamic_flag_spec='$wl-Bexport'
runpath_var='LD_RUN_PATH'
- if test "$GCC" = yes; then
- archive_cmds='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
- archive_expsym_cmds='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ if test yes = "$GCC"; then
+ archive_cmds='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_expsym_cmds='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
else
- archive_cmds='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
- archive_expsym_cmds='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_cmds='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_expsym_cmds='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
fi
;;
@@ -10976,10 +11051,10 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
;;
esac
- if test x$host_vendor = xsni; then
+ if test sni = "$host_vendor"; then
case $host in
sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*)
- export_dynamic_flag_spec='${wl}-Blargedynsym'
+ export_dynamic_flag_spec='$wl-Blargedynsym'
;;
esac
fi
@@ -10987,7 +11062,7 @@ $as_echo "$lt_cv_irix_exported_symbol" >&6; }
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs" >&5
$as_echo "$ld_shlibs" >&6; }
-test "$ld_shlibs" = no && can_build_shared=no
+test no = "$ld_shlibs" && can_build_shared=no
with_gnu_ld=$with_gnu_ld
@@ -11013,7 +11088,7 @@ x|xyes)
# Assume -lc should be added
archive_cmds_need_lc=yes
- if test "$enable_shared" = yes && test "$GCC" = yes; then
+ if test yes,yes = "$GCC,$enable_shared"; then
case $archive_cmds in
*'~'*)
# FIXME: we may have to deal with multi-command sequences.
@@ -11228,14 +11303,14 @@ esac
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking dynamic linker characteristics" >&5
$as_echo_n "checking dynamic linker characteristics... " >&6; }
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
case $host_os in
- darwin*) lt_awk_arg="/^libraries:/,/LR/" ;;
- *) lt_awk_arg="/^libraries:/" ;;
+ darwin*) lt_awk_arg='/^libraries:/,/LR/' ;;
+ *) lt_awk_arg='/^libraries:/' ;;
esac
case $host_os in
- mingw* | cegcc*) lt_sed_strip_eq="s,=\([A-Za-z]:\),\1,g" ;;
- *) lt_sed_strip_eq="s,=/,/,g" ;;
+ mingw* | cegcc*) lt_sed_strip_eq='s|=\([A-Za-z]:\)|\1|g' ;;
+ *) lt_sed_strip_eq='s|=/|/|g' ;;
esac
lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e $lt_sed_strip_eq`
case $lt_search_path_spec in
@@ -11251,28 +11326,35 @@ if test "$GCC" = yes; then
;;
esac
# Ok, now we have the path, separated by spaces, we can step through it
- # and add multilib dir if necessary.
+ # and add multilib dir if necessary...
lt_tmp_lt_search_path_spec=
- lt_multi_os_dir=`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null`
+ lt_multi_os_dir=/`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null`
+ # ...but if some path component already ends with the multilib dir we assume
+ # that all is fine and trust -print-search-dirs as is (GCC 4.2? or newer).
+ case "$lt_multi_os_dir; $lt_search_path_spec " in
+ "/; "* | "/.; "* | "/./; "* | *"$lt_multi_os_dir "* | *"$lt_multi_os_dir/ "*)
+ lt_multi_os_dir=
+ ;;
+ esac
for lt_sys_path in $lt_search_path_spec; do
- if test -d "$lt_sys_path/$lt_multi_os_dir"; then
- lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path/$lt_multi_os_dir"
- else
+ if test -d "$lt_sys_path$lt_multi_os_dir"; then
+ lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path$lt_multi_os_dir"
+ elif test -n "$lt_multi_os_dir"; then
test -d "$lt_sys_path" && \
lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path"
fi
done
lt_search_path_spec=`$ECHO "$lt_tmp_lt_search_path_spec" | awk '
-BEGIN {RS=" "; FS="/|\n";} {
- lt_foo="";
- lt_count=0;
+BEGIN {RS = " "; FS = "/|\n";} {
+ lt_foo = "";
+ lt_count = 0;
for (lt_i = NF; lt_i > 0; lt_i--) {
if ($lt_i != "" && $lt_i != ".") {
if ($lt_i == "..") {
lt_count++;
} else {
if (lt_count == 0) {
- lt_foo="/" $lt_i lt_foo;
+ lt_foo = "/" $lt_i lt_foo;
} else {
lt_count--;
}
@@ -11286,7 +11368,7 @@ BEGIN {RS=" "; FS="/|\n";} {
# for these hosts.
case $host_os in
mingw* | cegcc*) lt_search_path_spec=`$ECHO "$lt_search_path_spec" |\
- $SED 's,/\([A-Za-z]:\),\1,g'` ;;
+ $SED 's|/\([A-Za-z]:\)|\1|g'` ;;
esac
sys_lib_search_path_spec=`$ECHO "$lt_search_path_spec" | $lt_NL2SP`
else
@@ -11295,7 +11377,7 @@ fi
library_names_spec=
libname_spec='lib$name'
soname_spec=
-shrext_cmds=".so"
+shrext_cmds=.so
postinstall_cmds=
postuninstall_cmds=
finish_cmds=
@@ -11312,14 +11394,16 @@ hardcode_into_libs=no
# flags to be left without arguments
need_version=unknown
+
+
case $host_os in
aix3*)
version_type=linux # correct to gnu/linux during the next big refactor
- library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname.a'
shlibpath_var=LIBPATH
# AIX 3 has no versioning support, so we append a major version to the name.
- soname_spec='${libname}${release}${shared_ext}$major'
+ soname_spec='$libname$release$shared_ext$major'
;;
aix[4-9]*)
@@ -11327,41 +11411,91 @@ aix[4-9]*)
need_lib_prefix=no
need_version=no
hardcode_into_libs=yes
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# AIX 5 supports IA64
- library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}'
+ library_names_spec='$libname$release$shared_ext$major $libname$release$shared_ext$versuffix $libname$shared_ext'
shlibpath_var=LD_LIBRARY_PATH
else
# With GCC up to 2.95.x, collect2 would create an import file
# for dependence libraries. The import file would start with
- # the line `#! .'. This would cause the generated library to
- # depend on `.', always an invalid library. This was fixed in
+ # the line '#! .'. This would cause the generated library to
+ # depend on '.', always an invalid library. This was fixed in
# development snapshots of GCC prior to 3.0.
case $host_os in
aix4 | aix4.[01] | aix4.[01].*)
if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)'
echo ' yes '
- echo '#endif'; } | ${CC} -E - | $GREP yes > /dev/null; then
+ echo '#endif'; } | $CC -E - | $GREP yes > /dev/null; then
:
else
can_build_shared=no
fi
;;
esac
- # AIX (on Power*) has no versioning support, so currently we can not hardcode correct
+ # Using Import Files as archive members, it is possible to support
+ # filename-based versioning of shared library archives on AIX. While
+ # this would work for both with and without runtime linking, it will
+ # prevent static linking of such archives. So we do filename-based
+ # shared library versioning with .so extension only, which is used
+ # when both runtime linking and shared linking is enabled.
+ # Unfortunately, runtime linking may impact performance, so we do
+ # not want this to be the default eventually. Also, we use the
+ # versioned .so libs for executables only if there is the -brtl
+ # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only.
+ # To allow for filename-based versioning support, we need to create
+ # libNAME.so.V as an archive file, containing:
+ # *) an Import File, referring to the versioned filename of the
+ # archive as well as the shared archive member, telling the
+ # bitwidth (32 or 64) of that shared object, and providing the
+ # list of exported symbols of that shared object, eventually
+ # decorated with the 'weak' keyword
+ # *) the shared object with the F_LOADONLY flag set, to really avoid
+ # it being seen by the linker.
+ # At run time we better use the real file rather than another symlink,
+ # but for link time we create the symlink libNAME.so -> libNAME.so.V
+
+ case $with_aix_soname,$aix_use_runtimelinking in
+ # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct
# soname into executable. Probably we can add versioning support to
# collect2, so additional links can be useful in future.
- if test "$aix_use_runtimelinking" = yes; then
+ aix,yes) # traditional libtool
+ dynamic_linker='AIX unversionable lib.so'
# If using run time linking (on AIX 4.2 or later) use lib<name>.so
# instead of lib<name>.a to let people know that these are not
# typical AIX shared libraries.
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- else
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ ;;
+ aix,no) # traditional AIX only
+ dynamic_linker='AIX lib.a(lib.so.V)'
# We preserve .a as extension for shared libraries through AIX4.2
# and later when we are not doing run time linking.
- library_names_spec='${libname}${release}.a $libname.a'
- soname_spec='${libname}${release}${shared_ext}$major'
- fi
+ library_names_spec='$libname$release.a $libname.a'
+ soname_spec='$libname$release$shared_ext$major'
+ ;;
+ svr4,*) # full svr4 only
+ dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o)"
+ library_names_spec='$libname$release$shared_ext$major $libname$shared_ext'
+ # We do not specify a path in Import Files, so LIBPATH fires.
+ shlibpath_overrides_runpath=yes
+ ;;
+ *,yes) # both, prefer svr4
+ dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o), lib.a(lib.so.V)"
+ library_names_spec='$libname$release$shared_ext$major $libname$shared_ext'
+ # unpreferred sharedlib libNAME.a needs extra handling
+ postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"'
+ postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"'
+ # We do not specify a path in Import Files, so LIBPATH fires.
+ shlibpath_overrides_runpath=yes
+ ;;
+ *,no) # both, prefer aix
+ dynamic_linker="AIX lib.a(lib.so.V), lib.so.V($shared_archive_member_spec.o)"
+ library_names_spec='$libname$release.a $libname.a'
+ soname_spec='$libname$release$shared_ext$major'
+ # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling
+ postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)'
+ postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"'
+ ;;
+ esac
shlibpath_var=LIBPATH
fi
;;
@@ -11371,18 +11505,18 @@ amigaos*)
powerpc)
# Since July 2007 AmigaOS4 officially supports .so libraries.
# When compiling the executable, add -use-dynld -Lsobjs: to the compileline.
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
;;
m68k)
library_names_spec='$libname.ixlibrary $libname.a'
# Create ${libname}_ixlibrary.a entries in /sys/libs.
- finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; test $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done'
+ finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done'
;;
esac
;;
beos*)
- library_names_spec='${libname}${shared_ext}'
+ library_names_spec='$libname$shared_ext'
dynamic_linker="$host_os ld.so"
shlibpath_var=LIBRARY_PATH
;;
@@ -11390,8 +11524,8 @@ beos*)
bsdi[45]*)
version_type=linux # correct to gnu/linux during the next big refactor
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir'
shlibpath_var=LD_LIBRARY_PATH
sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib"
@@ -11403,7 +11537,7 @@ bsdi[45]*)
cygwin* | mingw* | pw32* | cegcc*)
version_type=windows
- shrext_cmds=".dll"
+ shrext_cmds=.dll
need_version=no
need_lib_prefix=no
@@ -11412,8 +11546,8 @@ cygwin* | mingw* | pw32* | cegcc*)
# gcc
library_names_spec='$libname.dll.a'
# DLL is installed to $(libdir)/../bin by postinstall_cmds
- postinstall_cmds='base_file=`basename \${file}`~
- dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~
+ postinstall_cmds='base_file=`basename \$file`~
+ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~
dldir=$destdir/`dirname \$dlpath`~
test -d \$dldir || mkdir -p \$dldir~
$install_prog $dir/$dlname \$dldir/$dlname~
@@ -11429,17 +11563,17 @@ cygwin* | mingw* | pw32* | cegcc*)
case $host_os in
cygwin*)
# Cygwin DLLs use 'cyg' prefix rather than 'lib'
- soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}'
+ soname_spec='`echo $libname | sed -e 's/^lib/cyg/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext'
sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/lib/w32api"
;;
mingw* | cegcc*)
# MinGW DLLs use traditional 'lib' prefix
- soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}'
+ soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext'
;;
pw32*)
# pw32 DLLs use 'pw' prefix rather than 'lib'
- library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}'
+ library_names_spec='`echo $libname | sed -e 's/^lib/pw/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext'
;;
esac
dynamic_linker='Win32 ld.exe'
@@ -11448,8 +11582,8 @@ cygwin* | mingw* | pw32* | cegcc*)
*,cl*)
# Native MSVC
libname_spec='$name'
- soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}'
- library_names_spec='${libname}.dll.lib'
+ soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext'
+ library_names_spec='$libname.dll.lib'
case $build_os in
mingw*)
@@ -11476,7 +11610,7 @@ cygwin* | mingw* | pw32* | cegcc*)
sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"`
;;
*)
- sys_lib_search_path_spec="$LIB"
+ sys_lib_search_path_spec=$LIB
if $ECHO "$sys_lib_search_path_spec" | $GREP ';[c-zC-Z]:/' >/dev/null; then
# It is most probably a Windows format PATH.
sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'`
@@ -11489,8 +11623,8 @@ cygwin* | mingw* | pw32* | cegcc*)
esac
# DLL is installed to $(libdir)/../bin by postinstall_cmds
- postinstall_cmds='base_file=`basename \${file}`~
- dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~
+ postinstall_cmds='base_file=`basename \$file`~
+ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~
dldir=$destdir/`dirname \$dlpath`~
test -d \$dldir || mkdir -p \$dldir~
$install_prog $dir/$dlname \$dldir/$dlname'
@@ -11503,7 +11637,7 @@ cygwin* | mingw* | pw32* | cegcc*)
*)
# Assume MSVC wrapper
- library_names_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext} $libname.lib'
+ library_names_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext $libname.lib'
dynamic_linker='Win32 ld.exe'
;;
esac
@@ -11516,8 +11650,8 @@ darwin* | rhapsody*)
version_type=darwin
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${major}$shared_ext ${libname}$shared_ext'
- soname_spec='${libname}${release}${major}$shared_ext'
+ library_names_spec='$libname$release$major$shared_ext $libname$shared_ext'
+ soname_spec='$libname$release$major$shared_ext'
shlibpath_overrides_runpath=yes
shlibpath_var=DYLD_LIBRARY_PATH
shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`'
@@ -11530,8 +11664,8 @@ dgux*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
;;
@@ -11549,12 +11683,13 @@ freebsd* | dragonfly*)
version_type=freebsd-$objformat
case $version_type in
freebsd-elf*)
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
need_version=no
need_lib_prefix=no
;;
freebsd-*)
- library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix'
need_version=yes
;;
esac
@@ -11579,26 +11714,15 @@ freebsd* | dragonfly*)
esac
;;
-gnu*)
- version_type=linux # correct to gnu/linux during the next big refactor
- need_lib_prefix=no
- need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
- shlibpath_var=LD_LIBRARY_PATH
- shlibpath_overrides_runpath=no
- hardcode_into_libs=yes
- ;;
-
haiku*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
dynamic_linker="$host_os runtime_loader"
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LIBRARY_PATH
- shlibpath_overrides_runpath=yes
+ shlibpath_overrides_runpath=no
sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib'
hardcode_into_libs=yes
;;
@@ -11616,14 +11740,15 @@ hpux9* | hpux10* | hpux11*)
dynamic_linker="$host_os dld.so"
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=yes # Unless +noenvvar is specified.
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
- if test "X$HPUX_IA64_MODE" = X32; then
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
+ if test 32 = "$HPUX_IA64_MODE"; then
sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib"
+ sys_lib_dlsearch_path_spec=/usr/lib/hpux32
else
sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64"
+ sys_lib_dlsearch_path_spec=/usr/lib/hpux64
fi
- sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
;;
hppa*64*)
shrext_cmds='.sl'
@@ -11631,8 +11756,8 @@ hpux9* | hpux10* | hpux11*)
dynamic_linker="$host_os dld.sl"
shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH
shlibpath_overrides_runpath=yes # Unless +noenvvar is specified.
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64"
sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
;;
@@ -11641,8 +11766,8 @@ hpux9* | hpux10* | hpux11*)
dynamic_linker="$host_os dld.sl"
shlibpath_var=SHLIB_PATH
shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
;;
esac
# HP-UX runs *really* slowly unless shared libraries are mode 555, ...
@@ -11655,8 +11780,8 @@ interix[3-9]*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=no
@@ -11667,7 +11792,7 @@ irix5* | irix6* | nonstopux*)
case $host_os in
nonstopux*) version_type=nonstopux ;;
*)
- if test "$lt_cv_prog_gnu_ld" = yes; then
+ if test yes = "$lt_cv_prog_gnu_ld"; then
version_type=linux # correct to gnu/linux during the next big refactor
else
version_type=irix
@@ -11675,8 +11800,8 @@ irix5* | irix6* | nonstopux*)
esac
need_lib_prefix=no
need_version=no
- soname_spec='${libname}${release}${shared_ext}$major'
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}'
+ soname_spec='$libname$release$shared_ext$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$release$shared_ext $libname$shared_ext'
case $host_os in
irix5* | nonstopux*)
libsuff= shlibsuff=
@@ -11695,8 +11820,8 @@ irix5* | irix6* | nonstopux*)
esac
shlibpath_var=LD_LIBRARY${shlibsuff}_PATH
shlibpath_overrides_runpath=no
- sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}"
- sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}"
+ sys_lib_search_path_spec="/usr/lib$libsuff /lib$libsuff /usr/local/lib$libsuff"
+ sys_lib_dlsearch_path_spec="/usr/lib$libsuff /lib$libsuff"
hardcode_into_libs=yes
;;
@@ -11705,13 +11830,33 @@ linux*oldld* | linux*aout* | linux*coff*)
dynamic_linker=no
;;
+linux*android*)
+ version_type=none # Android doesn't support versioned libraries.
+ need_lib_prefix=no
+ need_version=no
+ library_names_spec='$libname$release$shared_ext'
+ soname_spec='$libname$release$shared_ext'
+ finish_cmds=
+ shlibpath_var=LD_LIBRARY_PATH
+ shlibpath_overrides_runpath=yes
+
+ # This implies no fast_install, which is unacceptable.
+ # Some rework will be needed to allow for fast_install
+ # before this can be enabled.
+ hardcode_into_libs=yes
+
+ dynamic_linker='Android linker'
+ # Don't embed -rpath directories since the linker doesn't support them.
+ hardcode_libdir_flag_spec='-L$libdir'
+ ;;
+
# This must be glibc/ELF.
-linux* | k*bsd*-gnu | kopensolaris*-gnu)
+linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=no
@@ -11755,7 +11900,12 @@ fi
# before this can be enabled.
hardcode_into_libs=yes
- # Append ld.so.conf contents to the search path
+ # Ideally, we could use ldconfig to report *all* directores which are
+ # searched for libraries, however this is still not possible. Aside from not
+ # being certain /sbin/ldconfig is available, command
+ # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64,
+ # even though it is searched at run-time. Try to do the best guess by
+ # appending ld.so.conf contents (and includes) to the search path.
if test -f /etc/ld.so.conf; then
lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '`
sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra"
@@ -11770,17 +11920,29 @@ fi
dynamic_linker='GNU/Linux ld.so'
;;
+netbsdelf*-gnu)
+ version_type=linux
+ need_lib_prefix=no
+ need_version=no
+ library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}'
+ soname_spec='${libname}${release}${shared_ext}$major'
+ shlibpath_var=LD_LIBRARY_PATH
+ shlibpath_overrides_runpath=no
+ hardcode_into_libs=yes
+ dynamic_linker='NetBSD ld.elf_so'
+ ;;
+
netbsd*)
version_type=sunos
need_lib_prefix=no
need_version=no
if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix'
finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir'
dynamic_linker='NetBSD (a.out) ld.so'
else
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
dynamic_linker='NetBSD ld.elf_so'
fi
shlibpath_var=LD_LIBRARY_PATH
@@ -11790,7 +11952,7 @@ netbsd*)
newsos6)
version_type=linux # correct to gnu/linux during the next big refactor
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=yes
;;
@@ -11799,58 +11961,68 @@ newsos6)
version_type=qnx
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=no
hardcode_into_libs=yes
dynamic_linker='ldqnx.so'
;;
-openbsd*)
+openbsd* | bitrig*)
version_type=sunos
- sys_lib_dlsearch_path_spec="/usr/lib"
+ sys_lib_dlsearch_path_spec=/usr/lib
need_lib_prefix=no
- # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs.
- case $host_os in
- openbsd3.3 | openbsd3.3.*) need_version=yes ;;
- *) need_version=no ;;
- esac
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
- finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir'
- shlibpath_var=LD_LIBRARY_PATH
- if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
- case $host_os in
- openbsd2.[89] | openbsd2.[89].*)
- shlibpath_overrides_runpath=no
- ;;
- *)
- shlibpath_overrides_runpath=yes
- ;;
- esac
+ if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then
+ need_version=no
else
- shlibpath_overrides_runpath=yes
+ need_version=yes
fi
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix'
+ finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir'
+ shlibpath_var=LD_LIBRARY_PATH
+ shlibpath_overrides_runpath=yes
;;
os2*)
libname_spec='$name'
- shrext_cmds=".dll"
+ version_type=windows
+ shrext_cmds=.dll
+ need_version=no
need_lib_prefix=no
- library_names_spec='$libname${shared_ext} $libname.a'
+ # OS/2 can only load a DLL with a base name of 8 characters or less.
+ soname_spec='`test -n "$os2dllname" && libname="$os2dllname";
+ v=$($ECHO $release$versuffix | tr -d .-);
+ n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _);
+ $ECHO $n$v`$shared_ext'
+ library_names_spec='${libname}_dll.$libext'
dynamic_linker='OS/2 ld.exe'
- shlibpath_var=LIBPATH
+ shlibpath_var=BEGINLIBPATH
+ sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib"
+ sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
+ postinstall_cmds='base_file=`basename \$file`~
+ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; $ECHO \$dlname'\''`~
+ dldir=$destdir/`dirname \$dlpath`~
+ test -d \$dldir || mkdir -p \$dldir~
+ $install_prog $dir/$dlname \$dldir/$dlname~
+ chmod a+x \$dldir/$dlname~
+ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then
+ eval '\''$striplib \$dldir/$dlname'\'' || exit \$?;
+ fi'
+ postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~
+ dlpath=$dir/\$dldll~
+ $RM \$dlpath'
;;
osf3* | osf4* | osf5*)
version_type=osf
need_lib_prefix=no
need_version=no
- soname_spec='${libname}${release}${shared_ext}$major'
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+ soname_spec='$libname$release$shared_ext$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
shlibpath_var=LD_LIBRARY_PATH
sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib"
- sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec"
+ sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
;;
rdos*)
@@ -11861,8 +12033,8 @@ solaris*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=yes
hardcode_into_libs=yes
@@ -11872,11 +12044,11 @@ solaris*)
sunos4*)
version_type=sunos
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix'
finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=yes
- if test "$with_gnu_ld" = yes; then
+ if test yes = "$with_gnu_ld"; then
need_lib_prefix=no
fi
need_version=yes
@@ -11884,8 +12056,8 @@ sunos4*)
sysv4 | sysv4.3*)
version_type=linux # correct to gnu/linux during the next big refactor
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
case $host_vendor in
sni)
@@ -11906,24 +12078,24 @@ sysv4 | sysv4.3*)
;;
sysv4*MP*)
- if test -d /usr/nec ;then
+ if test -d /usr/nec; then
version_type=linux # correct to gnu/linux during the next big refactor
- library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}'
- soname_spec='$libname${shared_ext}.$major'
+ library_names_spec='$libname$shared_ext.$versuffix $libname$shared_ext.$major $libname$shared_ext'
+ soname_spec='$libname$shared_ext.$major'
shlibpath_var=LD_LIBRARY_PATH
fi
;;
sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*)
- version_type=freebsd-elf
+ version_type=sco
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=yes
hardcode_into_libs=yes
- if test "$with_gnu_ld" = yes; then
+ if test yes = "$with_gnu_ld"; then
sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib'
else
sys_lib_search_path_spec='/usr/ccs/lib /usr/lib'
@@ -11941,7 +12113,7 @@ tpf*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=no
hardcode_into_libs=yes
@@ -11949,8 +12121,8 @@ tpf*)
uts4*)
version_type=linux # correct to gnu/linux during the next big refactor
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
;;
@@ -11960,20 +12132,35 @@ uts4*)
esac
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $dynamic_linker" >&5
$as_echo "$dynamic_linker" >&6; }
-test "$dynamic_linker" = no && can_build_shared=no
+test no = "$dynamic_linker" && can_build_shared=no
variables_saved_for_relink="PATH $shlibpath_var $runpath_var"
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH"
fi
-if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then
- sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec"
+if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then
+ sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec
fi
-if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then
- sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec"
+
+if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then
+ sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec
fi
+# remember unaugmented sys_lib_dlsearch_path content for libtool script decls...
+configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec
+
+# ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code
+func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH"
+
+# to be used as default LT_SYS_LIBRARY_PATH value in generated libtool
+configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH
+
+
+
+
+
+
@@ -12070,15 +12257,15 @@ $as_echo_n "checking how to hardcode library paths into programs... " >&6; }
hardcode_action=
if test -n "$hardcode_libdir_flag_spec" ||
test -n "$runpath_var" ||
- test "X$hardcode_automatic" = "Xyes" ; then
+ test yes = "$hardcode_automatic"; then
# We can hardcode non-existent directories.
- if test "$hardcode_direct" != no &&
+ if test no != "$hardcode_direct" &&
# If the only mechanism to avoid hardcoding is shlibpath_var, we
# have to relink, otherwise we might link with an installed library
# when we should be linking with a yet-to-be-installed one
- ## test "$_LT_TAGVAR(hardcode_shlibpath_var, )" != no &&
- test "$hardcode_minus_L" != no; then
+ ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, )" &&
+ test no != "$hardcode_minus_L"; then
# Linking always hardcodes the temporary library directory.
hardcode_action=relink
else
@@ -12093,12 +12280,12 @@ fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $hardcode_action" >&5
$as_echo "$hardcode_action" >&6; }
-if test "$hardcode_action" = relink ||
- test "$inherit_rpath" = yes; then
+if test relink = "$hardcode_action" ||
+ test yes = "$inherit_rpath"; then
# Fast installation is not supported
enable_fast_install=no
-elif test "$shlibpath_overrides_runpath" = yes ||
- test "$enable_shared" = no; then
+elif test yes = "$shlibpath_overrides_runpath" ||
+ test no = "$enable_shared"; then
# Fast installation is not necessary
enable_fast_install=needless
fi
@@ -12108,7 +12295,7 @@ fi
- if test "x$enable_dlopen" != xyes; then
+ if test yes != "$enable_dlopen"; then
enable_dlopen=unknown
enable_dlopen_self=unknown
enable_dlopen_self_static=unknown
@@ -12118,23 +12305,23 @@ else
case $host_os in
beos*)
- lt_cv_dlopen="load_add_on"
+ lt_cv_dlopen=load_add_on
lt_cv_dlopen_libs=
lt_cv_dlopen_self=yes
;;
mingw* | pw32* | cegcc*)
- lt_cv_dlopen="LoadLibrary"
+ lt_cv_dlopen=LoadLibrary
lt_cv_dlopen_libs=
;;
cygwin*)
- lt_cv_dlopen="dlopen"
+ lt_cv_dlopen=dlopen
lt_cv_dlopen_libs=
;;
darwin*)
- # if libdl is installed we need to link against it
+ # if libdl is installed we need to link against it
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5
$as_echo_n "checking for dlopen in -ldl... " >&6; }
if ${ac_cv_lib_dl_dlopen+:} false; then :
@@ -12172,10 +12359,10 @@ fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5
$as_echo "$ac_cv_lib_dl_dlopen" >&6; }
if test "x$ac_cv_lib_dl_dlopen" = xyes; then :
- lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"
+ lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl
else
- lt_cv_dlopen="dyld"
+ lt_cv_dlopen=dyld
lt_cv_dlopen_libs=
lt_cv_dlopen_self=yes
@@ -12183,10 +12370,18 @@ fi
;;
+ tpf*)
+ # Don't try to run any link tests for TPF. We know it's impossible
+ # because TPF is a cross-compiler, and we know how we open DSOs.
+ lt_cv_dlopen=dlopen
+ lt_cv_dlopen_libs=
+ lt_cv_dlopen_self=no
+ ;;
+
*)
ac_fn_c_check_func "$LINENO" "shl_load" "ac_cv_func_shl_load"
if test "x$ac_cv_func_shl_load" = xyes; then :
- lt_cv_dlopen="shl_load"
+ lt_cv_dlopen=shl_load
else
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for shl_load in -ldld" >&5
$as_echo_n "checking for shl_load in -ldld... " >&6; }
@@ -12225,11 +12420,11 @@ fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dld_shl_load" >&5
$as_echo "$ac_cv_lib_dld_shl_load" >&6; }
if test "x$ac_cv_lib_dld_shl_load" = xyes; then :
- lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-ldld"
+ lt_cv_dlopen=shl_load lt_cv_dlopen_libs=-ldld
else
ac_fn_c_check_func "$LINENO" "dlopen" "ac_cv_func_dlopen"
if test "x$ac_cv_func_dlopen" = xyes; then :
- lt_cv_dlopen="dlopen"
+ lt_cv_dlopen=dlopen
else
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5
$as_echo_n "checking for dlopen in -ldl... " >&6; }
@@ -12268,7 +12463,7 @@ fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5
$as_echo "$ac_cv_lib_dl_dlopen" >&6; }
if test "x$ac_cv_lib_dl_dlopen" = xyes; then :
- lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"
+ lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl
else
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for dlopen in -lsvld" >&5
$as_echo_n "checking for dlopen in -lsvld... " >&6; }
@@ -12307,7 +12502,7 @@ fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_svld_dlopen" >&5
$as_echo "$ac_cv_lib_svld_dlopen" >&6; }
if test "x$ac_cv_lib_svld_dlopen" = xyes; then :
- lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld"
+ lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-lsvld
else
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for dld_link in -ldld" >&5
$as_echo_n "checking for dld_link in -ldld... " >&6; }
@@ -12346,7 +12541,7 @@ fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dld_dld_link" >&5
$as_echo "$ac_cv_lib_dld_dld_link" >&6; }
if test "x$ac_cv_lib_dld_dld_link" = xyes; then :
- lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-ldld"
+ lt_cv_dlopen=dld_link lt_cv_dlopen_libs=-ldld
fi
@@ -12367,21 +12562,21 @@ fi
;;
esac
- if test "x$lt_cv_dlopen" != xno; then
- enable_dlopen=yes
- else
+ if test no = "$lt_cv_dlopen"; then
enable_dlopen=no
+ else
+ enable_dlopen=yes
fi
case $lt_cv_dlopen in
dlopen)
- save_CPPFLAGS="$CPPFLAGS"
- test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H"
+ save_CPPFLAGS=$CPPFLAGS
+ test yes = "$ac_cv_header_dlfcn_h" && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H"
- save_LDFLAGS="$LDFLAGS"
+ save_LDFLAGS=$LDFLAGS
wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\"
- save_LIBS="$LIBS"
+ save_LIBS=$LIBS
LIBS="$lt_cv_dlopen_libs $LIBS"
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether a program can dlopen itself" >&5
@@ -12389,7 +12584,7 @@ $as_echo_n "checking whether a program can dlopen itself... " >&6; }
if ${lt_cv_dlopen_self+:} false; then :
$as_echo_n "(cached) " >&6
else
- if test "$cross_compiling" = yes; then :
+ if test yes = "$cross_compiling"; then :
lt_cv_dlopen_self=cross
else
lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
@@ -12436,9 +12631,9 @@ else
# endif
#endif
-/* When -fvisbility=hidden is used, assume the code has been annotated
+/* When -fvisibility=hidden is used, assume the code has been annotated
correspondingly for the symbols needed. */
-#if defined(__GNUC__) && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3))
+#if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3))
int fnord () __attribute__((visibility("default")));
#endif
@@ -12468,7 +12663,7 @@ _LT_EOF
(eval $ac_link) 2>&5
ac_status=$?
$as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
- test $ac_status = 0; } && test -s conftest${ac_exeext} 2>/dev/null; then
+ test $ac_status = 0; } && test -s "conftest$ac_exeext" 2>/dev/null; then
(./conftest; exit; ) >&5 2>/dev/null
lt_status=$?
case x$lt_status in
@@ -12488,14 +12683,14 @@ fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_dlopen_self" >&5
$as_echo "$lt_cv_dlopen_self" >&6; }
- if test "x$lt_cv_dlopen_self" = xyes; then
+ if test yes = "$lt_cv_dlopen_self"; then
wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\"
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether a statically linked program can dlopen itself" >&5
$as_echo_n "checking whether a statically linked program can dlopen itself... " >&6; }
if ${lt_cv_dlopen_self_static+:} false; then :
$as_echo_n "(cached) " >&6
else
- if test "$cross_compiling" = yes; then :
+ if test yes = "$cross_compiling"; then :
lt_cv_dlopen_self_static=cross
else
lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
@@ -12542,9 +12737,9 @@ else
# endif
#endif
-/* When -fvisbility=hidden is used, assume the code has been annotated
+/* When -fvisibility=hidden is used, assume the code has been annotated
correspondingly for the symbols needed. */
-#if defined(__GNUC__) && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3))
+#if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3))
int fnord () __attribute__((visibility("default")));
#endif
@@ -12574,7 +12769,7 @@ _LT_EOF
(eval $ac_link) 2>&5
ac_status=$?
$as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
- test $ac_status = 0; } && test -s conftest${ac_exeext} 2>/dev/null; then
+ test $ac_status = 0; } && test -s "conftest$ac_exeext" 2>/dev/null; then
(./conftest; exit; ) >&5 2>/dev/null
lt_status=$?
case x$lt_status in
@@ -12595,9 +12790,9 @@ fi
$as_echo "$lt_cv_dlopen_self_static" >&6; }
fi
- CPPFLAGS="$save_CPPFLAGS"
- LDFLAGS="$save_LDFLAGS"
- LIBS="$save_LIBS"
+ CPPFLAGS=$save_CPPFLAGS
+ LDFLAGS=$save_LDFLAGS
+ LIBS=$save_LIBS
;;
esac
@@ -12641,7 +12836,7 @@ else
# FIXME - insert some real tests, host_os isn't really good enough
case $host_os in
darwin*)
- if test -n "$STRIP" ; then
+ if test -n "$STRIP"; then
striplib="$STRIP -x"
old_striplib="$STRIP -S"
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
@@ -12669,7 +12864,7 @@ fi
- # Report which library types will actually be built
+ # Report what library types will actually be built
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if libtool supports shared libraries" >&5
$as_echo_n "checking if libtool supports shared libraries... " >&6; }
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $can_build_shared" >&5
@@ -12677,13 +12872,13 @@ $as_echo "$can_build_shared" >&6; }
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build shared libraries" >&5
$as_echo_n "checking whether to build shared libraries... " >&6; }
- test "$can_build_shared" = "no" && enable_shared=no
+ test no = "$can_build_shared" && enable_shared=no
# On AIX, shared libraries and static libraries use the same namespace, and
# are all built from PIC.
case $host_os in
aix3*)
- test "$enable_shared" = yes && enable_static=no
+ test yes = "$enable_shared" && enable_static=no
if test -n "$RANLIB"; then
archive_cmds="$archive_cmds~\$RANLIB \$lib"
postinstall_cmds='$RANLIB $lib'
@@ -12691,8 +12886,12 @@ $as_echo_n "checking whether to build shared libraries... " >&6; }
;;
aix[4-9]*)
- if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then
- test "$enable_shared" = yes && enable_static=no
+ if test ia64 != "$host_cpu"; then
+ case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in
+ yes,aix,yes) ;; # shared object as lib.so file only
+ yes,svr4,*) ;; # shared object as lib.so archive member only
+ yes,*) enable_static=no ;; # shared object in lib.a archive as well
+ esac
fi
;;
esac
@@ -12702,7 +12901,7 @@ $as_echo "$enable_shared" >&6; }
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether to build static libraries" >&5
$as_echo_n "checking whether to build static libraries... " >&6; }
# Make sure either enable_shared or enable_static is yes.
- test "$enable_shared" = yes || enable_static=yes
+ test yes = "$enable_shared" || enable_static=yes
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $enable_static" >&5
$as_echo "$enable_static" >&6; }
@@ -12716,11 +12915,11 @@ ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'
ac_compiler_gnu=$ac_cv_c_compiler_gnu
-CC="$lt_save_CC"
+CC=$lt_save_CC
- if test -n "$CXX" && ( test "X$CXX" != "Xno" &&
- ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) ||
- (test "X$CXX" != "Xg++"))) ; then
+ if test -n "$CXX" && ( test no != "$CXX" &&
+ ( (test g++ = "$CXX" && `g++ -v >/dev/null 2>&1` ) ||
+ (test g++ != "$CXX"))); then
ac_ext=cpp
ac_cpp='$CXXCPP $CPPFLAGS'
ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5'
@@ -12899,7 +13098,7 @@ objext_CXX=$objext
# the CXX compiler isn't working. Some variables (like enable_shared)
# are currently assumed to apply to all compilers on this platform,
# and will be corrupted by setting them based on a non-working compiler.
-if test "$_lt_caught_CXX_error" != yes; then
+if test yes != "$_lt_caught_CXX_error"; then
# Code to be used in simple compile tests
lt_simple_compile_test_code="int some_variable = 0;"
@@ -12960,46 +13159,39 @@ $RM -r conftest*
CFLAGS=$CXXFLAGS
compiler=$CC
compiler_CXX=$CC
- for cc_temp in $compiler""; do
- case $cc_temp in
- compile | *[\\/]compile | ccache | *[\\/]ccache ) ;;
- distcc | *[\\/]distcc | purify | *[\\/]purify ) ;;
- \-*) ;;
- *) break;;
- esac
-done
-cc_basename=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"`
+ func_cc_basename $compiler
+cc_basename=$func_cc_basename_result
if test -n "$compiler"; then
# We don't want -fno-exception when compiling C++ code, so set the
# no_builtin_flag separately
- if test "$GXX" = yes; then
+ if test yes = "$GXX"; then
lt_prog_compiler_no_builtin_flag_CXX=' -fno-builtin'
else
lt_prog_compiler_no_builtin_flag_CXX=
fi
- if test "$GXX" = yes; then
+ if test yes = "$GXX"; then
# Set up default GNU C++ configuration
# Check whether --with-gnu-ld was given.
if test "${with_gnu_ld+set}" = set; then :
- withval=$with_gnu_ld; test "$withval" = no || with_gnu_ld=yes
+ withval=$with_gnu_ld; test no = "$withval" || with_gnu_ld=yes
else
with_gnu_ld=no
fi
ac_prog=ld
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
# Check if gcc -print-prog-name=ld gives a path.
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for ld used by $CC" >&5
$as_echo_n "checking for ld used by $CC... " >&6; }
case $host in
*-*-mingw*)
- # gcc leaves a trailing carriage return which upsets mingw
+ # gcc leaves a trailing carriage return, which upsets mingw
ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;;
*)
ac_prog=`($CC -print-prog-name=ld) 2>&5` ;;
@@ -13013,7 +13205,7 @@ $as_echo_n "checking for ld used by $CC... " >&6; }
while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do
ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"`
done
- test -z "$LD" && LD="$ac_prog"
+ test -z "$LD" && LD=$ac_prog
;;
"")
# If it fails, then pretend we aren't using GCC.
@@ -13024,7 +13216,7 @@ $as_echo_n "checking for ld used by $CC... " >&6; }
with_gnu_ld=unknown
;;
esac
-elif test "$with_gnu_ld" = yes; then
+elif test yes = "$with_gnu_ld"; then
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for GNU ld" >&5
$as_echo_n "checking for GNU ld... " >&6; }
else
@@ -13035,32 +13227,32 @@ if ${lt_cv_path_LD+:} false; then :
$as_echo_n "(cached) " >&6
else
if test -z "$LD"; then
- lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+ lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR
for ac_dir in $PATH; do
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
test -z "$ac_dir" && ac_dir=.
if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then
- lt_cv_path_LD="$ac_dir/$ac_prog"
+ lt_cv_path_LD=$ac_dir/$ac_prog
# Check to see if the program is GNU ld. I'd rather use --version,
# but apparently some variants of GNU ld only accept -v.
# Break only if it was the GNU/non-GNU ld that we prefer.
case `"$lt_cv_path_LD" -v 2>&1 </dev/null` in
*GNU* | *'with BFD'*)
- test "$with_gnu_ld" != no && break
+ test no != "$with_gnu_ld" && break
;;
*)
- test "$with_gnu_ld" != yes && break
+ test yes != "$with_gnu_ld" && break
;;
esac
fi
done
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
else
- lt_cv_path_LD="$LD" # Let the user override the test with a path.
+ lt_cv_path_LD=$LD # Let the user override the test with a path.
fi
fi
-LD="$lt_cv_path_LD"
+LD=$lt_cv_path_LD
if test -n "$LD"; then
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $LD" >&5
$as_echo "$LD" >&6; }
@@ -13096,22 +13288,22 @@ with_gnu_ld=$lt_cv_prog_gnu_ld
# Check if GNU C++ uses GNU ld as the underlying linker, since the
# archiving commands below assume that GNU ld is being used.
- if test "$with_gnu_ld" = yes; then
- archive_cmds_CXX='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib'
- archive_expsym_cmds_CXX='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+ if test yes = "$with_gnu_ld"; then
+ archive_cmds_CXX='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib'
+ archive_expsym_cmds_CXX='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
- hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir'
- export_dynamic_flag_spec_CXX='${wl}--export-dynamic'
+ hardcode_libdir_flag_spec_CXX='$wl-rpath $wl$libdir'
+ export_dynamic_flag_spec_CXX='$wl--export-dynamic'
# If archive_cmds runs LD, not CC, wlarc should be empty
# XXX I think wlarc can be eliminated in ltcf-cxx, but I need to
# investigate it a little bit more. (MM)
- wlarc='${wl}'
+ wlarc='$wl'
# ancient GNU ld didn't support --whole-archive et. al.
if eval "`$CC -print-prog-name=ld` --help 2>&1" |
$GREP 'no-whole-archive' > /dev/null; then
- whole_archive_flag_spec_CXX="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive'
+ whole_archive_flag_spec_CXX=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive'
else
whole_archive_flag_spec_CXX=
fi
@@ -13148,18 +13340,30 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
ld_shlibs_CXX=no
;;
aix[4-9]*)
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# On IA64, the linker does run time linking by default, so we don't
# have to do anything special.
aix_use_runtimelinking=no
exp_sym_flag='-Bexport'
- no_entry_flag=""
+ no_entry_flag=
else
aix_use_runtimelinking=no
# Test if we are trying to use run time linking or normal
# AIX style linking. If -brtl is somewhere in LDFLAGS, we
- # need to do runtime linking.
+ # have runtime linking enabled, and use it for executables.
+ # For shared libraries, we enable/disable runtime linking
+ # depending on the kind of the shared library created -
+ # when "with_aix_soname,aix_use_runtimelinking" is:
+ # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables
+ # "aix,yes" lib.so shared, rtl:yes, for executables
+ # lib.a static archive
+ # "both,no" lib.so.V(shr.o) shared, rtl:yes
+ # lib.a(lib.so.V) shared, rtl:no, for executables
+ # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables
+ # lib.a(lib.so.V) shared, rtl:no
+ # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables
+ # lib.a static archive
case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*)
for ld_flag in $LDFLAGS; do
case $ld_flag in
@@ -13169,6 +13373,13 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
;;
esac
done
+ if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then
+ # With aix-soname=svr4, we create the lib.so.V shared archives only,
+ # so we don't have lib.a shared libs to link our executables.
+ # We have to force runtime linking in this case.
+ aix_use_runtimelinking=yes
+ LDFLAGS="$LDFLAGS -Wl,-brtl"
+ fi
;;
esac
@@ -13187,13 +13398,21 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
hardcode_direct_absolute_CXX=yes
hardcode_libdir_separator_CXX=':'
link_all_deplibs_CXX=yes
- file_list_spec_CXX='${wl}-f,'
+ file_list_spec_CXX='$wl-f,'
+ case $with_aix_soname,$aix_use_runtimelinking in
+ aix,*) ;; # no import file
+ svr4,* | *,yes) # use import file
+ # The Import File defines what to hardcode.
+ hardcode_direct_CXX=no
+ hardcode_direct_absolute_CXX=no
+ ;;
+ esac
- if test "$GXX" = yes; then
+ if test yes = "$GXX"; then
case $host_os in aix4.[012]|aix4.[012].*)
# We only want to do this on AIX 4.2 and lower, the check
# below for broken collect2 doesn't work under 4.3+
- collect2name=`${CC} -print-prog-name=collect2`
+ collect2name=`$CC -print-prog-name=collect2`
if test -f "$collect2name" &&
strings "$collect2name" | $GREP resolve_lib_name >/dev/null
then
@@ -13211,36 +13430,44 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
fi
esac
shared_flag='-shared'
- if test "$aix_use_runtimelinking" = yes; then
- shared_flag="$shared_flag "'${wl}-G'
+ if test yes = "$aix_use_runtimelinking"; then
+ shared_flag=$shared_flag' $wl-G'
fi
+ # Need to ensure runtime linking is disabled for the traditional
+ # shared library, or the linker may eventually find shared libraries
+ # /with/ Import File - we do not want to mix them.
+ shared_flag_aix='-shared'
+ shared_flag_svr4='-shared $wl-G'
else
# not using gcc
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release
# chokes on -Wl,-G. The following line is correct:
shared_flag='-G'
else
- if test "$aix_use_runtimelinking" = yes; then
- shared_flag='${wl}-G'
+ if test yes = "$aix_use_runtimelinking"; then
+ shared_flag='$wl-G'
else
- shared_flag='${wl}-bM:SRE'
+ shared_flag='$wl-bM:SRE'
fi
+ shared_flag_aix='$wl-bM:SRE'
+ shared_flag_svr4='$wl-G'
fi
fi
- export_dynamic_flag_spec_CXX='${wl}-bexpall'
+ export_dynamic_flag_spec_CXX='$wl-bexpall'
# It seems that -bexpall does not export symbols beginning with
# underscore (_), so it is better to generate a list of symbols to
# export.
always_export_symbols_CXX=yes
- if test "$aix_use_runtimelinking" = yes; then
+ if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then
# Warning - without using the other runtime loading flags (-brtl),
# -berok will link without error, but may produce a broken library.
- allow_undefined_flag_CXX='-berok'
+ # The "-G" linker flag allows undefined symbols.
+ no_undefined_flag_CXX='-bernotok'
# Determine the default libpath from the value encoded in an empty
# executable.
- if test "${lt_cv_aix_libpath+set}" = set; then
+ if test set = "${lt_cv_aix_libpath+set}"; then
aix_libpath=$lt_cv_aix_libpath
else
if ${lt_cv_aix_libpath__CXX+:} false; then :
@@ -13275,7 +13502,7 @@ fi
rm -f core conftest.err conftest.$ac_objext \
conftest$ac_exeext conftest.$ac_ext
if test -z "$lt_cv_aix_libpath__CXX"; then
- lt_cv_aix_libpath__CXX="/usr/lib:/lib"
+ lt_cv_aix_libpath__CXX=/usr/lib:/lib
fi
fi
@@ -13283,18 +13510,18 @@ fi
aix_libpath=$lt_cv_aix_libpath__CXX
fi
- hardcode_libdir_flag_spec_CXX='${wl}-blibpath:$libdir:'"$aix_libpath"
+ hardcode_libdir_flag_spec_CXX='$wl-blibpath:$libdir:'"$aix_libpath"
- archive_expsym_cmds_CXX='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then func_echo_all "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag"
+ archive_expsym_cmds_CXX='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag
else
- if test "$host_cpu" = ia64; then
- hardcode_libdir_flag_spec_CXX='${wl}-R $libdir:/usr/lib:/lib'
+ if test ia64 = "$host_cpu"; then
+ hardcode_libdir_flag_spec_CXX='$wl-R $libdir:/usr/lib:/lib'
allow_undefined_flag_CXX="-z nodefs"
- archive_expsym_cmds_CXX="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols"
+ archive_expsym_cmds_CXX="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols"
else
# Determine the default libpath from the value encoded in an
# empty executable.
- if test "${lt_cv_aix_libpath+set}" = set; then
+ if test set = "${lt_cv_aix_libpath+set}"; then
aix_libpath=$lt_cv_aix_libpath
else
if ${lt_cv_aix_libpath__CXX+:} false; then :
@@ -13329,7 +13556,7 @@ fi
rm -f core conftest.err conftest.$ac_objext \
conftest$ac_exeext conftest.$ac_ext
if test -z "$lt_cv_aix_libpath__CXX"; then
- lt_cv_aix_libpath__CXX="/usr/lib:/lib"
+ lt_cv_aix_libpath__CXX=/usr/lib:/lib
fi
fi
@@ -13337,22 +13564,34 @@ fi
aix_libpath=$lt_cv_aix_libpath__CXX
fi
- hardcode_libdir_flag_spec_CXX='${wl}-blibpath:$libdir:'"$aix_libpath"
+ hardcode_libdir_flag_spec_CXX='$wl-blibpath:$libdir:'"$aix_libpath"
# Warning - without using the other run time loading flags,
# -berok will link without error, but may produce a broken library.
- no_undefined_flag_CXX=' ${wl}-bernotok'
- allow_undefined_flag_CXX=' ${wl}-berok'
- if test "$with_gnu_ld" = yes; then
+ no_undefined_flag_CXX=' $wl-bernotok'
+ allow_undefined_flag_CXX=' $wl-berok'
+ if test yes = "$with_gnu_ld"; then
# We only use this code for GNU lds that support --whole-archive.
- whole_archive_flag_spec_CXX='${wl}--whole-archive$convenience ${wl}--no-whole-archive'
+ whole_archive_flag_spec_CXX='$wl--whole-archive$convenience $wl--no-whole-archive'
else
# Exported symbols can be pulled into shared objects from archives
whole_archive_flag_spec_CXX='$convenience'
fi
archive_cmds_need_lc_CXX=yes
- # This is similar to how AIX traditionally builds its shared
- # libraries.
- archive_expsym_cmds_CXX="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname'
+ archive_expsym_cmds_CXX='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d'
+ # -brtl affects multiple linker settings, -berok does not and is overridden later
+ compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([, ]\\)%-berok\\1%g"`'
+ if test svr4 != "$with_aix_soname"; then
+ # This is similar to how AIX traditionally builds its shared
+ # libraries. Need -bnortl late, we may have -brtl in LDFLAGS.
+ archive_expsym_cmds_CXX="$archive_expsym_cmds_CXX"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname'
+ fi
+ if test aix != "$with_aix_soname"; then
+ archive_expsym_cmds_CXX="$archive_expsym_cmds_CXX"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp'
+ else
+ # used by -dlpreopen to get the symbols
+ archive_expsym_cmds_CXX="$archive_expsym_cmds_CXX"'~$MV $output_objdir/$realname.d/$soname $output_objdir'
+ fi
+ archive_expsym_cmds_CXX="$archive_expsym_cmds_CXX"'~$RM -r $output_objdir/$realname.d'
fi
fi
;;
@@ -13362,7 +13601,7 @@ fi
allow_undefined_flag_CXX=unsupported
# Joseph Beckenbach <jrb3@best.com> says some releases of gcc
# support --undefined. This deserves some investigation. FIXME
- archive_cmds_CXX='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+ archive_cmds_CXX='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
else
ld_shlibs_CXX=no
fi
@@ -13390,57 +13629,58 @@ fi
# Tell ltmain to make .lib files, not .a files.
libext=lib
# Tell ltmain to make .dll files, not .so files.
- shrext_cmds=".dll"
+ shrext_cmds=.dll
# FIXME: Setting linknames here is a bad hack.
- archive_cmds_CXX='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-dll~linknames='
- archive_expsym_cmds_CXX='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then
- $SED -n -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' -e '1\\\!p' < $export_symbols > $output_objdir/$soname.exp;
- else
- $SED -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' < $export_symbols > $output_objdir/$soname.exp;
- fi~
- $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~
- linknames='
+ archive_cmds_CXX='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames='
+ archive_expsym_cmds_CXX='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then
+ cp "$export_symbols" "$output_objdir/$soname.def";
+ echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp";
+ else
+ $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp;
+ fi~
+ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~
+ linknames='
# The linker will not automatically build a static lib if we build a DLL.
# _LT_TAGVAR(old_archive_from_new_cmds, CXX)='true'
enable_shared_with_static_runtimes_CXX=yes
# Don't use ranlib
old_postinstall_cmds_CXX='chmod 644 $oldlib'
postlink_cmds_CXX='lt_outputfile="@OUTPUT@"~
- lt_tool_outputfile="@TOOL_OUTPUT@"~
- case $lt_outputfile in
- *.exe|*.EXE) ;;
- *)
- lt_outputfile="$lt_outputfile.exe"
- lt_tool_outputfile="$lt_tool_outputfile.exe"
- ;;
- esac~
- func_to_tool_file "$lt_outputfile"~
- if test "$MANIFEST_TOOL" != ":" && test -f "$lt_outputfile.manifest"; then
- $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1;
- $RM "$lt_outputfile.manifest";
- fi'
+ lt_tool_outputfile="@TOOL_OUTPUT@"~
+ case $lt_outputfile in
+ *.exe|*.EXE) ;;
+ *)
+ lt_outputfile=$lt_outputfile.exe
+ lt_tool_outputfile=$lt_tool_outputfile.exe
+ ;;
+ esac~
+ func_to_tool_file "$lt_outputfile"~
+ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then
+ $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1;
+ $RM "$lt_outputfile.manifest";
+ fi'
;;
*)
# g++
# _LT_TAGVAR(hardcode_libdir_flag_spec, CXX) is actually meaningless,
# as there is no search path for DLLs.
hardcode_libdir_flag_spec_CXX='-L$libdir'
- export_dynamic_flag_spec_CXX='${wl}--export-all-symbols'
+ export_dynamic_flag_spec_CXX='$wl--export-all-symbols'
allow_undefined_flag_CXX=unsupported
always_export_symbols_CXX=no
enable_shared_with_static_runtimes_CXX=yes
if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then
- archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
- # If the export-symbols file already is a .def file (1st line
- # is EXPORTS), use it as is; otherwise, prepend...
- archive_expsym_cmds_CXX='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then
- cp $export_symbols $output_objdir/$soname.def;
- else
- echo EXPORTS > $output_objdir/$soname.def;
- cat $export_symbols >> $output_objdir/$soname.def;
- fi~
- $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+ archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+ # If the export-symbols file already is a .def file, use it as
+ # is; otherwise, prepend EXPORTS...
+ archive_expsym_cmds_CXX='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then
+ cp $export_symbols $output_objdir/$soname.def;
+ else
+ echo EXPORTS > $output_objdir/$soname.def;
+ cat $export_symbols >> $output_objdir/$soname.def;
+ fi~
+ $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
else
ld_shlibs_CXX=no
fi
@@ -13454,27 +13694,27 @@ fi
hardcode_direct_CXX=no
hardcode_automatic_CXX=yes
hardcode_shlibpath_var_CXX=unsupported
- if test "$lt_cv_ld_force_load" = "yes"; then
- whole_archive_flag_spec_CXX='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience ${wl}-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`'
+ if test yes = "$lt_cv_ld_force_load"; then
+ whole_archive_flag_spec_CXX='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`'
else
whole_archive_flag_spec_CXX=''
fi
link_all_deplibs_CXX=yes
- allow_undefined_flag_CXX="$_lt_dar_allow_undefined"
+ allow_undefined_flag_CXX=$_lt_dar_allow_undefined
case $cc_basename in
- ifort*) _lt_dar_can_shared=yes ;;
+ ifort*|nagfor*) _lt_dar_can_shared=yes ;;
*) _lt_dar_can_shared=$GCC ;;
esac
- if test "$_lt_dar_can_shared" = "yes"; then
+ if test yes = "$_lt_dar_can_shared"; then
output_verbose_link_cmd=func_echo_all
- archive_cmds_CXX="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}"
- module_cmds_CXX="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}"
- archive_expsym_cmds_CXX="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}"
- module_expsym_cmds_CXX="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}"
- if test "$lt_cv_apple_cc_single_mod" != "yes"; then
- archive_cmds_CXX="\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dsymutil}"
- archive_expsym_cmds_CXX="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dar_export_syms}${_lt_dsymutil}"
+ archive_cmds_CXX="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil"
+ module_cmds_CXX="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil"
+ archive_expsym_cmds_CXX="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil"
+ module_expsym_cmds_CXX="sed -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil"
+ if test yes != "$lt_cv_apple_cc_single_mod"; then
+ archive_cmds_CXX="\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dsymutil"
+ archive_expsym_cmds_CXX="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dar_export_syms$_lt_dsymutil"
fi
else
@@ -13483,6 +13723,34 @@ fi
;;
+ os2*)
+ hardcode_libdir_flag_spec_CXX='-L$libdir'
+ hardcode_minus_L_CXX=yes
+ allow_undefined_flag_CXX=unsupported
+ shrext_cmds=.dll
+ archive_cmds_CXX='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+ $ECHO EXPORTS >> $output_objdir/$libname.def~
+ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~
+ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+ emximp -o $lib $output_objdir/$libname.def'
+ archive_expsym_cmds_CXX='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+ $ECHO EXPORTS >> $output_objdir/$libname.def~
+ prefix_cmds="$SED"~
+ if test EXPORTS = "`$SED 1q $export_symbols`"; then
+ prefix_cmds="$prefix_cmds -e 1d";
+ fi~
+ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~
+ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~
+ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+ emximp -o $lib $output_objdir/$libname.def'
+ old_archive_From_new_cmds_CXX='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def'
+ enable_shared_with_static_runtimes_CXX=yes
+ ;;
+
dgux*)
case $cc_basename in
ec++*)
@@ -13517,18 +13785,15 @@ fi
ld_shlibs_CXX=yes
;;
- gnu*)
- ;;
-
haiku*)
- archive_cmds_CXX='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+ archive_cmds_CXX='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
link_all_deplibs_CXX=yes
;;
hpux9*)
- hardcode_libdir_flag_spec_CXX='${wl}+b ${wl}$libdir'
+ hardcode_libdir_flag_spec_CXX='$wl+b $wl$libdir'
hardcode_libdir_separator_CXX=:
- export_dynamic_flag_spec_CXX='${wl}-E'
+ export_dynamic_flag_spec_CXX='$wl-E'
hardcode_direct_CXX=yes
hardcode_minus_L_CXX=yes # Not in the search PATH,
# but as the default
@@ -13540,7 +13805,7 @@ fi
ld_shlibs_CXX=no
;;
aCC*)
- archive_cmds_CXX='$RM $output_objdir/$soname~$CC -b ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
+ archive_cmds_CXX='$RM $output_objdir/$soname~$CC -b $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib'
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
@@ -13549,11 +13814,11 @@ fi
# explicitly linking system object files so we need to strip them
# from the output so that they don't get included in the library
# dependencies.
- output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
+ output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
;;
*)
- if test "$GXX" = yes; then
- archive_cmds_CXX='$RM $output_objdir/$soname~$CC -shared -nostdlib $pic_flag ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
+ if test yes = "$GXX"; then
+ archive_cmds_CXX='$RM $output_objdir/$soname~$CC -shared -nostdlib $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib'
else
# FIXME: insert proper C++ library support
ld_shlibs_CXX=no
@@ -13563,15 +13828,15 @@ fi
;;
hpux10*|hpux11*)
- if test $with_gnu_ld = no; then
- hardcode_libdir_flag_spec_CXX='${wl}+b ${wl}$libdir'
+ if test no = "$with_gnu_ld"; then
+ hardcode_libdir_flag_spec_CXX='$wl+b $wl$libdir'
hardcode_libdir_separator_CXX=:
case $host_cpu in
hppa*64*|ia64*)
;;
*)
- export_dynamic_flag_spec_CXX='${wl}-E'
+ export_dynamic_flag_spec_CXX='$wl-E'
;;
esac
fi
@@ -13597,13 +13862,13 @@ fi
aCC*)
case $host_cpu in
hppa*64*)
- archive_cmds_CXX='$CC -b ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+ archive_cmds_CXX='$CC -b $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
;;
ia64*)
- archive_cmds_CXX='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+ archive_cmds_CXX='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
;;
*)
- archive_cmds_CXX='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+ archive_cmds_CXX='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
;;
esac
# Commands to make compiler produce verbose output that lists
@@ -13614,20 +13879,20 @@ fi
# explicitly linking system object files so we need to strip them
# from the output so that they don't get included in the library
# dependencies.
- output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
+ output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
;;
*)
- if test "$GXX" = yes; then
- if test $with_gnu_ld = no; then
+ if test yes = "$GXX"; then
+ if test no = "$with_gnu_ld"; then
case $host_cpu in
hppa*64*)
- archive_cmds_CXX='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+ archive_cmds_CXX='$CC -shared -nostdlib -fPIC $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
;;
ia64*)
- archive_cmds_CXX='$CC -shared -nostdlib $pic_flag ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+ archive_cmds_CXX='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
;;
*)
- archive_cmds_CXX='$CC -shared -nostdlib $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+ archive_cmds_CXX='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
;;
esac
fi
@@ -13642,22 +13907,22 @@ fi
interix[3-9]*)
hardcode_direct_CXX=no
hardcode_shlibpath_var_CXX=no
- hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir'
- export_dynamic_flag_spec_CXX='${wl}-E'
+ hardcode_libdir_flag_spec_CXX='$wl-rpath,$libdir'
+ export_dynamic_flag_spec_CXX='$wl-E'
# Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc.
# Instead, shared libraries are loaded at an image base (0x10000000 by
# default) and relocated if they conflict, which is a slow very memory
# consuming and fragmenting process. To avoid this, we pick a random,
# 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link
# time. Moving up from 0x10000000 also allows more sbrk(2) space.
- archive_cmds_CXX='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
- archive_expsym_cmds_CXX='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+ archive_cmds_CXX='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+ archive_expsym_cmds_CXX='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
;;
irix5* | irix6*)
case $cc_basename in
CC*)
# SGI C++
- archive_cmds_CXX='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
+ archive_cmds_CXX='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
# Archives containing C++ object files must be created using
# "CC -ar", where "CC" is the IRIX C++ compiler. This is
@@ -13666,22 +13931,22 @@ fi
old_archive_cmds_CXX='$CC -ar -WR,-u -o $oldlib $oldobjs'
;;
*)
- if test "$GXX" = yes; then
- if test "$with_gnu_ld" = no; then
- archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+ if test yes = "$GXX"; then
+ if test no = "$with_gnu_ld"; then
+ archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
else
- archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` -o $lib'
+ archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` -o $lib'
fi
fi
link_all_deplibs_CXX=yes
;;
esac
- hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir'
+ hardcode_libdir_flag_spec_CXX='$wl-rpath $wl$libdir'
hardcode_libdir_separator_CXX=:
inherit_rpath_CXX=yes
;;
- linux* | k*bsd*-gnu | kopensolaris*-gnu)
+ linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
case $cc_basename in
KCC*)
# Kuck and Associates, Inc. (KAI) C++ Compiler
@@ -13689,8 +13954,8 @@ fi
# KCC will only create a shared library if the output file
# ends with ".so" (or ".sl" for HP-UX), so rename the library
# to its proper name (with version) after linking.
- archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib'
- archive_expsym_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib ${wl}-retain-symbols-file,$export_symbols; mv \$templib $lib'
+ archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib'
+ archive_expsym_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib $wl-retain-symbols-file,$export_symbols; mv \$templib $lib'
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
@@ -13699,10 +13964,10 @@ fi
# explicitly linking system object files so we need to strip them
# from the output so that they don't get included in the library
# dependencies.
- output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | $GREP "ld"`; rm -f libconftest$shared_ext; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
+ output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | $GREP "ld"`; rm -f libconftest$shared_ext; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
- hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir'
- export_dynamic_flag_spec_CXX='${wl}--export-dynamic'
+ hardcode_libdir_flag_spec_CXX='$wl-rpath,$libdir'
+ export_dynamic_flag_spec_CXX='$wl--export-dynamic'
# Archives containing C++ object files must be created using
# "CC -Bstatic", where "CC" is the KAI C++ compiler.
@@ -13716,59 +13981,59 @@ fi
# earlier do not add the objects themselves.
case `$CC -V 2>&1` in
*"Version 7."*)
- archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib'
- archive_expsym_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+ archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib'
+ archive_expsym_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
;;
*) # Version 8.0 or newer
tmp_idyn=
case $host_cpu in
ia64*) tmp_idyn=' -i_dynamic';;
esac
- archive_cmds_CXX='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
- archive_expsym_cmds_CXX='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+ archive_cmds_CXX='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+ archive_expsym_cmds_CXX='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
;;
esac
archive_cmds_need_lc_CXX=no
- hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir'
- export_dynamic_flag_spec_CXX='${wl}--export-dynamic'
- whole_archive_flag_spec_CXX='${wl}--whole-archive$convenience ${wl}--no-whole-archive'
+ hardcode_libdir_flag_spec_CXX='$wl-rpath,$libdir'
+ export_dynamic_flag_spec_CXX='$wl--export-dynamic'
+ whole_archive_flag_spec_CXX='$wl--whole-archive$convenience $wl--no-whole-archive'
;;
pgCC* | pgcpp*)
# Portland Group C++ compiler
case `$CC -V` in
*pgCC\ [1-5].* | *pgcpp\ [1-5].*)
prelink_cmds_CXX='tpldir=Template.dir~
- rm -rf $tpldir~
- $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~
- compile_command="$compile_command `find $tpldir -name \*.o | sort | $NL2SP`"'
+ rm -rf $tpldir~
+ $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~
+ compile_command="$compile_command `find $tpldir -name \*.o | sort | $NL2SP`"'
old_archive_cmds_CXX='tpldir=Template.dir~
- rm -rf $tpldir~
- $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~
- $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | sort | $NL2SP`~
- $RANLIB $oldlib'
+ rm -rf $tpldir~
+ $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~
+ $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | sort | $NL2SP`~
+ $RANLIB $oldlib'
archive_cmds_CXX='tpldir=Template.dir~
- rm -rf $tpldir~
- $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~
- $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib'
+ rm -rf $tpldir~
+ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~
+ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib'
archive_expsym_cmds_CXX='tpldir=Template.dir~
- rm -rf $tpldir~
- $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~
- $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib'
+ rm -rf $tpldir~
+ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~
+ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
;;
*) # Version 6 and above use weak symbols
- archive_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib'
- archive_expsym_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib'
+ archive_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib'
+ archive_expsym_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
;;
esac
- hardcode_libdir_flag_spec_CXX='${wl}--rpath ${wl}$libdir'
- export_dynamic_flag_spec_CXX='${wl}--export-dynamic'
- whole_archive_flag_spec_CXX='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+ hardcode_libdir_flag_spec_CXX='$wl--rpath $wl$libdir'
+ export_dynamic_flag_spec_CXX='$wl--export-dynamic'
+ whole_archive_flag_spec_CXX='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
;;
cxx*)
# Compaq C++
- archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib'
- archive_expsym_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib ${wl}-retain-symbols-file $wl$export_symbols'
+ archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib'
+ archive_expsym_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib $wl-retain-symbols-file $wl$export_symbols'
runpath_var=LD_RUN_PATH
hardcode_libdir_flag_spec_CXX='-rpath $libdir'
@@ -13782,18 +14047,18 @@ fi
# explicitly linking system object files so we need to strip them
# from the output so that they don't get included in the library
# dependencies.
- output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "X$list" | $Xsed'
+ output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "X$list" | $Xsed'
;;
xl* | mpixl* | bgxl*)
# IBM XL 8.0 on PPC, with GNU ld
- hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir'
- export_dynamic_flag_spec_CXX='${wl}--export-dynamic'
- archive_cmds_CXX='$CC -qmkshrobj $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
- if test "x$supports_anon_versioning" = xyes; then
+ hardcode_libdir_flag_spec_CXX='$wl-rpath $wl$libdir'
+ export_dynamic_flag_spec_CXX='$wl--export-dynamic'
+ archive_cmds_CXX='$CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+ if test yes = "$supports_anon_versioning"; then
archive_expsym_cmds_CXX='echo "{ global:" > $output_objdir/$libname.ver~
- cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
- echo "local: *; };" >> $output_objdir/$libname.ver~
- $CC -qmkshrobj $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib'
+ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
+ echo "local: *; };" >> $output_objdir/$libname.ver~
+ $CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib'
fi
;;
*)
@@ -13801,10 +14066,10 @@ fi
*Sun\ C*)
# Sun C++ 5.9
no_undefined_flag_CXX=' -zdefs'
- archive_cmds_CXX='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
- archive_expsym_cmds_CXX='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file ${wl}$export_symbols'
+ archive_cmds_CXX='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+ archive_expsym_cmds_CXX='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file $wl$export_symbols'
hardcode_libdir_flag_spec_CXX='-R$libdir'
- whole_archive_flag_spec_CXX='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+ whole_archive_flag_spec_CXX='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
compiler_needs_object_CXX=yes
# Not sure whether something based on
@@ -13862,22 +14127,17 @@ fi
ld_shlibs_CXX=yes
;;
- openbsd2*)
- # C++ shared libraries are fairly broken
- ld_shlibs_CXX=no
- ;;
-
- openbsd*)
+ openbsd* | bitrig*)
if test -f /usr/libexec/ld.so; then
hardcode_direct_CXX=yes
hardcode_shlibpath_var_CXX=no
hardcode_direct_absolute_CXX=yes
archive_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib'
- hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir'
- if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
- archive_expsym_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file,$export_symbols -o $lib'
- export_dynamic_flag_spec_CXX='${wl}-E'
- whole_archive_flag_spec_CXX="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive'
+ hardcode_libdir_flag_spec_CXX='$wl-rpath,$libdir'
+ if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`"; then
+ archive_expsym_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file,$export_symbols -o $lib'
+ export_dynamic_flag_spec_CXX='$wl-E'
+ whole_archive_flag_spec_CXX=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive'
fi
output_verbose_link_cmd=func_echo_all
else
@@ -13893,9 +14153,9 @@ fi
# KCC will only create a shared library if the output file
# ends with ".so" (or ".sl" for HP-UX), so rename the library
# to its proper name (with version) after linking.
- archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo "$lib" | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib'
+ archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo "$lib" | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib'
- hardcode_libdir_flag_spec_CXX='${wl}-rpath,$libdir'
+ hardcode_libdir_flag_spec_CXX='$wl-rpath,$libdir'
hardcode_libdir_separator_CXX=:
# Archives containing C++ object files must be created using
@@ -13913,17 +14173,17 @@ fi
cxx*)
case $host in
osf3*)
- allow_undefined_flag_CXX=' ${wl}-expect_unresolved ${wl}\*'
- archive_cmds_CXX='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $soname `test -n "$verstring" && func_echo_all "${wl}-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
- hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir'
+ allow_undefined_flag_CXX=' $wl-expect_unresolved $wl\*'
+ archive_cmds_CXX='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $soname `test -n "$verstring" && func_echo_all "$wl-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
+ hardcode_libdir_flag_spec_CXX='$wl-rpath $wl$libdir'
;;
*)
allow_undefined_flag_CXX=' -expect_unresolved \*'
- archive_cmds_CXX='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
+ archive_cmds_CXX='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
archive_expsym_cmds_CXX='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~
- echo "-hidden">> $lib.exp~
- $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname ${wl}-input ${wl}$lib.exp `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib~
- $RM $lib.exp'
+ echo "-hidden">> $lib.exp~
+ $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname $wl-input $wl$lib.exp `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~
+ $RM $lib.exp'
hardcode_libdir_flag_spec_CXX='-rpath $libdir'
;;
esac
@@ -13938,21 +14198,21 @@ fi
# explicitly linking system object files so we need to strip them
# from the output so that they don't get included in the library
# dependencies.
- output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
+ output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
;;
*)
- if test "$GXX" = yes && test "$with_gnu_ld" = no; then
- allow_undefined_flag_CXX=' ${wl}-expect_unresolved ${wl}\*'
+ if test yes,no = "$GXX,$with_gnu_ld"; then
+ allow_undefined_flag_CXX=' $wl-expect_unresolved $wl\*'
case $host in
osf3*)
- archive_cmds_CXX='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+ archive_cmds_CXX='$CC -shared -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
;;
*)
- archive_cmds_CXX='$CC -shared $pic_flag -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+ archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
;;
esac
- hardcode_libdir_flag_spec_CXX='${wl}-rpath ${wl}$libdir'
+ hardcode_libdir_flag_spec_CXX='$wl-rpath $wl$libdir'
hardcode_libdir_separator_CXX=:
# Commands to make compiler produce verbose output that lists
@@ -13998,9 +14258,9 @@ fi
# Sun C++ 4.2, 5.x and Centerline C++
archive_cmds_need_lc_CXX=yes
no_undefined_flag_CXX=' -zdefs'
- archive_cmds_CXX='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+ archive_cmds_CXX='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
archive_expsym_cmds_CXX='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
- $CC -G${allow_undefined_flag} ${wl}-M ${wl}$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp'
+ $CC -G$allow_undefined_flag $wl-M $wl$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp'
hardcode_libdir_flag_spec_CXX='-R$libdir'
hardcode_shlibpath_var_CXX=no
@@ -14008,7 +14268,7 @@ fi
solaris2.[0-5] | solaris2.[0-5].*) ;;
*)
# The compiler driver will combine and reorder linker options,
- # but understands `-z linker_flag'.
+ # but understands '-z linker_flag'.
# Supported since Solaris 2.6 (maybe 2.5.1?)
whole_archive_flag_spec_CXX='-z allextract$convenience -z defaultextract'
;;
@@ -14025,30 +14285,30 @@ fi
;;
gcx*)
# Green Hills C++ Compiler
- archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib'
+ archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib'
# The C++ compiler must be used to create the archive.
old_archive_cmds_CXX='$CC $LDFLAGS -archive -o $oldlib $oldobjs'
;;
*)
# GNU C++ compiler with Solaris linker
- if test "$GXX" = yes && test "$with_gnu_ld" = no; then
- no_undefined_flag_CXX=' ${wl}-z ${wl}defs'
+ if test yes,no = "$GXX,$with_gnu_ld"; then
+ no_undefined_flag_CXX=' $wl-z ${wl}defs'
if $CC --version | $GREP -v '^2\.7' > /dev/null; then
- archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib'
+ archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib'
archive_expsym_cmds_CXX='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
- $CC -shared $pic_flag -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp'
+ $CC -shared $pic_flag -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp'
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
else
- # g++ 2.7 appears to require `-G' NOT `-shared' on this
+ # g++ 2.7 appears to require '-G' NOT '-shared' on this
# platform.
- archive_cmds_CXX='$CC -G -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib'
+ archive_cmds_CXX='$CC -G -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib'
archive_expsym_cmds_CXX='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
- $CC -G -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp'
+ $CC -G -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp'
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
@@ -14056,11 +14316,11 @@ fi
output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
fi
- hardcode_libdir_flag_spec_CXX='${wl}-R $wl$libdir'
+ hardcode_libdir_flag_spec_CXX='$wl-R $wl$libdir'
case $host_os in
solaris2.[0-5] | solaris2.[0-5].*) ;;
*)
- whole_archive_flag_spec_CXX='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract'
+ whole_archive_flag_spec_CXX='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract'
;;
esac
fi
@@ -14069,52 +14329,52 @@ fi
;;
sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*)
- no_undefined_flag_CXX='${wl}-z,text'
+ no_undefined_flag_CXX='$wl-z,text'
archive_cmds_need_lc_CXX=no
hardcode_shlibpath_var_CXX=no
runpath_var='LD_RUN_PATH'
case $cc_basename in
CC*)
- archive_cmds_CXX='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
- archive_expsym_cmds_CXX='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_cmds_CXX='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_expsym_cmds_CXX='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
;;
*)
- archive_cmds_CXX='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
- archive_expsym_cmds_CXX='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_cmds_CXX='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_expsym_cmds_CXX='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
;;
esac
;;
sysv5* | sco3.2v5* | sco5v6*)
- # Note: We can NOT use -z defs as we might desire, because we do not
+ # Note: We CANNOT use -z defs as we might desire, because we do not
# link with -lc, and that would cause any symbols used from libc to
# always be unresolved, which means just about no library would
# ever link correctly. If we're not using GNU ld we use -z text
# though, which does catch some bad symbols but isn't as heavy-handed
# as -z defs.
- no_undefined_flag_CXX='${wl}-z,text'
- allow_undefined_flag_CXX='${wl}-z,nodefs'
+ no_undefined_flag_CXX='$wl-z,text'
+ allow_undefined_flag_CXX='$wl-z,nodefs'
archive_cmds_need_lc_CXX=no
hardcode_shlibpath_var_CXX=no
- hardcode_libdir_flag_spec_CXX='${wl}-R,$libdir'
+ hardcode_libdir_flag_spec_CXX='$wl-R,$libdir'
hardcode_libdir_separator_CXX=':'
link_all_deplibs_CXX=yes
- export_dynamic_flag_spec_CXX='${wl}-Bexport'
+ export_dynamic_flag_spec_CXX='$wl-Bexport'
runpath_var='LD_RUN_PATH'
case $cc_basename in
CC*)
- archive_cmds_CXX='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
- archive_expsym_cmds_CXX='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_cmds_CXX='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_expsym_cmds_CXX='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
old_archive_cmds_CXX='$CC -Tprelink_objects $oldobjs~
- '"$old_archive_cmds_CXX"
+ '"$old_archive_cmds_CXX"
reload_cmds_CXX='$CC -Tprelink_objects $reload_objs~
- '"$reload_cmds_CXX"
+ '"$reload_cmds_CXX"
;;
*)
- archive_cmds_CXX='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
- archive_expsym_cmds_CXX='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_cmds_CXX='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ archive_expsym_cmds_CXX='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
;;
esac
;;
@@ -14146,10 +14406,10 @@ fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs_CXX" >&5
$as_echo "$ld_shlibs_CXX" >&6; }
- test "$ld_shlibs_CXX" = no && can_build_shared=no
+ test no = "$ld_shlibs_CXX" && can_build_shared=no
- GCC_CXX="$GXX"
- LD_CXX="$LD"
+ GCC_CXX=$GXX
+ LD_CXX=$LD
## CAVEAT EMPTOR:
## There is no encapsulation within the following macros, do not change
@@ -14193,13 +14453,13 @@ if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5
pre_test_object_deps_done=no
for p in `eval "$output_verbose_link_cmd"`; do
- case ${prev}${p} in
+ case $prev$p in
-L* | -R* | -l*)
# Some compilers place space between "-{L,R}" and the path.
# Remove the space.
- if test $p = "-L" ||
- test $p = "-R"; then
+ if test x-L = "$p" ||
+ test x-R = "$p"; then
prev=$p
continue
fi
@@ -14215,16 +14475,16 @@ if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5
case $p in
=*) func_stripname_cnf '=' '' "$p"; p=$lt_sysroot$func_stripname_result ;;
esac
- if test "$pre_test_object_deps_done" = no; then
- case ${prev} in
+ if test no = "$pre_test_object_deps_done"; then
+ case $prev in
-L | -R)
# Internal compiler library paths should come after those
# provided the user. The postdeps already come after the
# user supplied libs so there is no need to process them.
if test -z "$compiler_lib_search_path_CXX"; then
- compiler_lib_search_path_CXX="${prev}${p}"
+ compiler_lib_search_path_CXX=$prev$p
else
- compiler_lib_search_path_CXX="${compiler_lib_search_path_CXX} ${prev}${p}"
+ compiler_lib_search_path_CXX="${compiler_lib_search_path_CXX} $prev$p"
fi
;;
# The "-l" case would never come before the object being
@@ -14232,9 +14492,9 @@ if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5
esac
else
if test -z "$postdeps_CXX"; then
- postdeps_CXX="${prev}${p}"
+ postdeps_CXX=$prev$p
else
- postdeps_CXX="${postdeps_CXX} ${prev}${p}"
+ postdeps_CXX="${postdeps_CXX} $prev$p"
fi
fi
prev=
@@ -14249,15 +14509,15 @@ if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5
continue
fi
- if test "$pre_test_object_deps_done" = no; then
+ if test no = "$pre_test_object_deps_done"; then
if test -z "$predep_objects_CXX"; then
- predep_objects_CXX="$p"
+ predep_objects_CXX=$p
else
predep_objects_CXX="$predep_objects_CXX $p"
fi
else
if test -z "$postdep_objects_CXX"; then
- postdep_objects_CXX="$p"
+ postdep_objects_CXX=$p
else
postdep_objects_CXX="$postdep_objects_CXX $p"
fi
@@ -14287,51 +14547,6 @@ interix[3-9]*)
postdep_objects_CXX=
postdeps_CXX=
;;
-
-linux*)
- case `$CC -V 2>&1 | sed 5q` in
- *Sun\ C*)
- # Sun C++ 5.9
-
- # The more standards-conforming stlport4 library is
- # incompatible with the Cstd library. Avoid specifying
- # it if it's in CXXFLAGS. Ignore libCrun as
- # -library=stlport4 depends on it.
- case " $CXX $CXXFLAGS " in
- *" -library=stlport4 "*)
- solaris_use_stlport4=yes
- ;;
- esac
-
- if test "$solaris_use_stlport4" != yes; then
- postdeps_CXX='-library=Cstd -library=Crun'
- fi
- ;;
- esac
- ;;
-
-solaris*)
- case $cc_basename in
- CC* | sunCC*)
- # The more standards-conforming stlport4 library is
- # incompatible with the Cstd library. Avoid specifying
- # it if it's in CXXFLAGS. Ignore libCrun as
- # -library=stlport4 depends on it.
- case " $CXX $CXXFLAGS " in
- *" -library=stlport4 "*)
- solaris_use_stlport4=yes
- ;;
- esac
-
- # Adding this requires a known-good setup of shared libraries for
- # Sun compiler versions before 5.6, else PIC objects from an old
- # archive will be linked into the output, leading to subtle bugs.
- if test "$solaris_use_stlport4" != yes; then
- postdeps_CXX='-library=Cstd -library=Crun'
- fi
- ;;
- esac
- ;;
esac
@@ -14340,7 +14555,7 @@ case " $postdeps_CXX " in
esac
compiler_lib_search_dirs_CXX=
if test -n "${compiler_lib_search_path_CXX}"; then
- compiler_lib_search_dirs_CXX=`echo " ${compiler_lib_search_path_CXX}" | ${SED} -e 's! -L! !g' -e 's!^ !!'`
+ compiler_lib_search_dirs_CXX=`echo " ${compiler_lib_search_path_CXX}" | $SED -e 's! -L! !g' -e 's!^ !!'`
fi
@@ -14379,17 +14594,18 @@ lt_prog_compiler_static_CXX=
# C++ specific cases for pic, static, wl, etc.
- if test "$GXX" = yes; then
+ if test yes = "$GXX"; then
lt_prog_compiler_wl_CXX='-Wl,'
lt_prog_compiler_static_CXX='-static'
case $host_os in
aix*)
# All AIX code is PIC.
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# AIX 5 now supports IA64 processor
lt_prog_compiler_static_CXX='-Bstatic'
fi
+ lt_prog_compiler_pic_CXX='-fPIC'
;;
amigaos*)
@@ -14400,8 +14616,8 @@ lt_prog_compiler_static_CXX=
;;
m68k)
# FIXME: we need at least 68020 code to build shared libraries, but
- # adding the `-m68020' flag to GCC prevents building anything better,
- # like `-m68040'.
+ # adding the '-m68020' flag to GCC prevents building anything better,
+ # like '-m68040'.
lt_prog_compiler_pic_CXX='-m68020 -resident32 -malways-restore-a4'
;;
esac
@@ -14416,6 +14632,11 @@ lt_prog_compiler_static_CXX=
# Although the cygwin gcc ignores -fPIC, still need this for old-style
# (--disable-auto-import) libraries
lt_prog_compiler_pic_CXX='-DDLL_EXPORT'
+ case $host_os in
+ os2*)
+ lt_prog_compiler_static_CXX='$wl-static'
+ ;;
+ esac
;;
darwin* | rhapsody*)
# PIC is the default on this platform
@@ -14465,7 +14686,7 @@ lt_prog_compiler_static_CXX=
case $host_os in
aix[4-9]*)
# All AIX code is PIC.
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# AIX 5 now supports IA64 processor
lt_prog_compiler_static_CXX='-Bstatic'
else
@@ -14505,14 +14726,14 @@ lt_prog_compiler_static_CXX=
case $cc_basename in
CC*)
lt_prog_compiler_wl_CXX='-Wl,'
- lt_prog_compiler_static_CXX='${wl}-a ${wl}archive'
- if test "$host_cpu" != ia64; then
+ lt_prog_compiler_static_CXX='$wl-a ${wl}archive'
+ if test ia64 != "$host_cpu"; then
lt_prog_compiler_pic_CXX='+Z'
fi
;;
aCC*)
lt_prog_compiler_wl_CXX='-Wl,'
- lt_prog_compiler_static_CXX='${wl}-a ${wl}archive'
+ lt_prog_compiler_static_CXX='$wl-a ${wl}archive'
case $host_cpu in
hppa*64*|ia64*)
# +Z the default
@@ -14541,7 +14762,7 @@ lt_prog_compiler_static_CXX=
;;
esac
;;
- linux* | k*bsd*-gnu | kopensolaris*-gnu)
+ linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
case $cc_basename in
KCC*)
# KAI C++ Compiler
@@ -14549,7 +14770,7 @@ lt_prog_compiler_static_CXX=
lt_prog_compiler_pic_CXX='-fPIC'
;;
ecpc* )
- # old Intel C++ for x86_64 which still supported -KPIC.
+ # old Intel C++ for x86_64, which still supported -KPIC.
lt_prog_compiler_wl_CXX='-Wl,'
lt_prog_compiler_pic_CXX='-KPIC'
lt_prog_compiler_static_CXX='-static'
@@ -14605,7 +14826,7 @@ lt_prog_compiler_static_CXX=
;;
esac
;;
- netbsd*)
+ netbsd* | netbsdelf*-gnu)
;;
*qnx* | *nto*)
# QNX uses GNU C++, but need to define -shared option too, otherwise
@@ -14694,7 +14915,7 @@ lt_prog_compiler_static_CXX=
fi
case $host_os in
- # For platforms which do not support PIC, -DPIC is meaningless:
+ # For platforms that do not support PIC, -DPIC is meaningless:
*djgpp*)
lt_prog_compiler_pic_CXX=
;;
@@ -14726,7 +14947,7 @@ else
lt_cv_prog_compiler_pic_works_CXX=no
ac_outfile=conftest.$ac_objext
echo "$lt_simple_compile_test_code" > conftest.$ac_ext
- lt_compiler_flag="$lt_prog_compiler_pic_CXX -DPIC"
+ lt_compiler_flag="$lt_prog_compiler_pic_CXX -DPIC" ## exclude from sc_useless_quotes_in_assignment
# Insert the option either (1) after the last *FLAGS variable, or
# (2) before a word containing "conftest.", or (3) at the end.
# Note that $ac_compile itself does not contain backslashes and begins
@@ -14756,7 +14977,7 @@ fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_works_CXX" >&5
$as_echo "$lt_cv_prog_compiler_pic_works_CXX" >&6; }
-if test x"$lt_cv_prog_compiler_pic_works_CXX" = xyes; then
+if test yes = "$lt_cv_prog_compiler_pic_works_CXX"; then
case $lt_prog_compiler_pic_CXX in
"" | " "*) ;;
*) lt_prog_compiler_pic_CXX=" $lt_prog_compiler_pic_CXX" ;;
@@ -14782,7 +15003,7 @@ if ${lt_cv_prog_compiler_static_works_CXX+:} false; then :
$as_echo_n "(cached) " >&6
else
lt_cv_prog_compiler_static_works_CXX=no
- save_LDFLAGS="$LDFLAGS"
+ save_LDFLAGS=$LDFLAGS
LDFLAGS="$LDFLAGS $lt_tmp_static_flag"
echo "$lt_simple_link_test_code" > conftest.$ac_ext
if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then
@@ -14801,13 +15022,13 @@ else
fi
fi
$RM -r conftest*
- LDFLAGS="$save_LDFLAGS"
+ LDFLAGS=$save_LDFLAGS
fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_static_works_CXX" >&5
$as_echo "$lt_cv_prog_compiler_static_works_CXX" >&6; }
-if test x"$lt_cv_prog_compiler_static_works_CXX" = xyes; then
+if test yes = "$lt_cv_prog_compiler_static_works_CXX"; then
:
else
lt_prog_compiler_static_CXX=
@@ -14921,8 +15142,8 @@ $as_echo "$lt_cv_prog_compiler_c_o_CXX" >&6; }
-hard_links="nottested"
-if test "$lt_cv_prog_compiler_c_o_CXX" = no && test "$need_locks" != no; then
+hard_links=nottested
+if test no = "$lt_cv_prog_compiler_c_o_CXX" && test no != "$need_locks"; then
# do not overwrite the value of need_locks provided by the user
{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if we can lock with hard links" >&5
$as_echo_n "checking if we can lock with hard links... " >&6; }
@@ -14934,9 +15155,9 @@ $as_echo_n "checking if we can lock with hard links... " >&6; }
ln conftest.a conftest.b 2>/dev/null && hard_links=no
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $hard_links" >&5
$as_echo "$hard_links" >&6; }
- if test "$hard_links" = no; then
- { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&5
-$as_echo "$as_me: WARNING: \`$CC' does not support \`-c -o', so \`make -j' may be unsafe" >&2;}
+ if test no = "$hard_links"; then
+ { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&5
+$as_echo "$as_me: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&2;}
need_locks=warn
fi
else
@@ -14953,17 +15174,21 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
case $host_os in
aix[4-9]*)
# If we're using GNU nm, then we don't want the "-C" option.
- # -C means demangle to AIX nm, but means don't demangle with GNU nm
- # Also, AIX nm treats weak defined symbols like other global defined
- # symbols, whereas GNU nm marks them as "W".
+ # -C means demangle to GNU nm, but means don't demangle to AIX nm.
+ # Without the "-l" option, or with the "-B" option, AIX nm treats
+ # weak defined symbols like other global defined symbols, whereas
+ # GNU nm marks them as "W".
+ # While the 'weak' keyword is ignored in the Export File, we need
+ # it in the Import File for the 'aix-soname' feature, so we have
+ # to replace the "-B" option with "-P" for AIX nm.
if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then
- export_symbols_cmds_CXX='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+ export_symbols_cmds_CXX='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && (substr(\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols'
else
- export_symbols_cmds_CXX='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && (substr(\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+ export_symbols_cmds_CXX='`func_echo_all $NM | $SED -e '\''s/B\([^B]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && (substr(\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols'
fi
;;
pw32*)
- export_symbols_cmds_CXX="$ltdll_cmds"
+ export_symbols_cmds_CXX=$ltdll_cmds
;;
cygwin* | mingw* | cegcc*)
case $cc_basename in
@@ -14976,6 +15201,9 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
;;
esac
;;
+ linux* | k*bsd*-gnu | gnu*)
+ link_all_deplibs_CXX=no
+ ;;
*)
export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols'
;;
@@ -14983,7 +15211,7 @@ $as_echo_n "checking whether the $compiler linker ($LD) supports shared librarie
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs_CXX" >&5
$as_echo "$ld_shlibs_CXX" >&6; }
-test "$ld_shlibs_CXX" = no && can_build_shared=no
+test no = "$ld_shlibs_CXX" && can_build_shared=no
with_gnu_ld_CXX=$with_gnu_ld
@@ -15000,7 +15228,7 @@ x|xyes)
# Assume -lc should be added
archive_cmds_need_lc_CXX=yes
- if test "$enable_shared" = yes && test "$GCC" = yes; then
+ if test yes,yes = "$GCC,$enable_shared"; then
case $archive_cmds_CXX in
*'~'*)
# FIXME: we may have to deal with multi-command sequences.
@@ -15128,7 +15356,7 @@ $as_echo_n "checking dynamic linker characteristics... " >&6; }
library_names_spec=
libname_spec='lib$name'
soname_spec=
-shrext_cmds=".so"
+shrext_cmds=.so
postinstall_cmds=
postuninstall_cmds=
finish_cmds=
@@ -15145,14 +15373,16 @@ hardcode_into_libs=no
# flags to be left without arguments
need_version=unknown
+
+
case $host_os in
aix3*)
version_type=linux # correct to gnu/linux during the next big refactor
- library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname.a'
shlibpath_var=LIBPATH
# AIX 3 has no versioning support, so we append a major version to the name.
- soname_spec='${libname}${release}${shared_ext}$major'
+ soname_spec='$libname$release$shared_ext$major'
;;
aix[4-9]*)
@@ -15160,41 +15390,91 @@ aix[4-9]*)
need_lib_prefix=no
need_version=no
hardcode_into_libs=yes
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# AIX 5 supports IA64
- library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}'
+ library_names_spec='$libname$release$shared_ext$major $libname$release$shared_ext$versuffix $libname$shared_ext'
shlibpath_var=LD_LIBRARY_PATH
else
# With GCC up to 2.95.x, collect2 would create an import file
# for dependence libraries. The import file would start with
- # the line `#! .'. This would cause the generated library to
- # depend on `.', always an invalid library. This was fixed in
+ # the line '#! .'. This would cause the generated library to
+ # depend on '.', always an invalid library. This was fixed in
# development snapshots of GCC prior to 3.0.
case $host_os in
aix4 | aix4.[01] | aix4.[01].*)
if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)'
echo ' yes '
- echo '#endif'; } | ${CC} -E - | $GREP yes > /dev/null; then
+ echo '#endif'; } | $CC -E - | $GREP yes > /dev/null; then
:
else
can_build_shared=no
fi
;;
esac
- # AIX (on Power*) has no versioning support, so currently we can not hardcode correct
+ # Using Import Files as archive members, it is possible to support
+ # filename-based versioning of shared library archives on AIX. While
+ # this would work for both with and without runtime linking, it will
+ # prevent static linking of such archives. So we do filename-based
+ # shared library versioning with .so extension only, which is used
+ # when both runtime linking and shared linking is enabled.
+ # Unfortunately, runtime linking may impact performance, so we do
+ # not want this to be the default eventually. Also, we use the
+ # versioned .so libs for executables only if there is the -brtl
+ # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only.
+ # To allow for filename-based versioning support, we need to create
+ # libNAME.so.V as an archive file, containing:
+ # *) an Import File, referring to the versioned filename of the
+ # archive as well as the shared archive member, telling the
+ # bitwidth (32 or 64) of that shared object, and providing the
+ # list of exported symbols of that shared object, eventually
+ # decorated with the 'weak' keyword
+ # *) the shared object with the F_LOADONLY flag set, to really avoid
+ # it being seen by the linker.
+ # At run time we better use the real file rather than another symlink,
+ # but for link time we create the symlink libNAME.so -> libNAME.so.V
+
+ case $with_aix_soname,$aix_use_runtimelinking in
+ # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct
# soname into executable. Probably we can add versioning support to
# collect2, so additional links can be useful in future.
- if test "$aix_use_runtimelinking" = yes; then
+ aix,yes) # traditional libtool
+ dynamic_linker='AIX unversionable lib.so'
# If using run time linking (on AIX 4.2 or later) use lib<name>.so
# instead of lib<name>.a to let people know that these are not
# typical AIX shared libraries.
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- else
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ ;;
+ aix,no) # traditional AIX only
+ dynamic_linker='AIX lib.a(lib.so.V)'
# We preserve .a as extension for shared libraries through AIX4.2
# and later when we are not doing run time linking.
- library_names_spec='${libname}${release}.a $libname.a'
- soname_spec='${libname}${release}${shared_ext}$major'
- fi
+ library_names_spec='$libname$release.a $libname.a'
+ soname_spec='$libname$release$shared_ext$major'
+ ;;
+ svr4,*) # full svr4 only
+ dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o)"
+ library_names_spec='$libname$release$shared_ext$major $libname$shared_ext'
+ # We do not specify a path in Import Files, so LIBPATH fires.
+ shlibpath_overrides_runpath=yes
+ ;;
+ *,yes) # both, prefer svr4
+ dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o), lib.a(lib.so.V)"
+ library_names_spec='$libname$release$shared_ext$major $libname$shared_ext'
+ # unpreferred sharedlib libNAME.a needs extra handling
+ postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"'
+ postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"'
+ # We do not specify a path in Import Files, so LIBPATH fires.
+ shlibpath_overrides_runpath=yes
+ ;;
+ *,no) # both, prefer aix
+ dynamic_linker="AIX lib.a(lib.so.V), lib.so.V($shared_archive_member_spec.o)"
+ library_names_spec='$libname$release.a $libname.a'
+ soname_spec='$libname$release$shared_ext$major'
+ # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling
+ postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)'
+ postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"'
+ ;;
+ esac
shlibpath_var=LIBPATH
fi
;;
@@ -15204,18 +15484,18 @@ amigaos*)
powerpc)
# Since July 2007 AmigaOS4 officially supports .so libraries.
# When compiling the executable, add -use-dynld -Lsobjs: to the compileline.
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
;;
m68k)
library_names_spec='$libname.ixlibrary $libname.a'
# Create ${libname}_ixlibrary.a entries in /sys/libs.
- finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; test $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done'
+ finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done'
;;
esac
;;
beos*)
- library_names_spec='${libname}${shared_ext}'
+ library_names_spec='$libname$shared_ext'
dynamic_linker="$host_os ld.so"
shlibpath_var=LIBRARY_PATH
;;
@@ -15223,8 +15503,8 @@ beos*)
bsdi[45]*)
version_type=linux # correct to gnu/linux during the next big refactor
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir'
shlibpath_var=LD_LIBRARY_PATH
sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib"
@@ -15236,7 +15516,7 @@ bsdi[45]*)
cygwin* | mingw* | pw32* | cegcc*)
version_type=windows
- shrext_cmds=".dll"
+ shrext_cmds=.dll
need_version=no
need_lib_prefix=no
@@ -15245,8 +15525,8 @@ cygwin* | mingw* | pw32* | cegcc*)
# gcc
library_names_spec='$libname.dll.a'
# DLL is installed to $(libdir)/../bin by postinstall_cmds
- postinstall_cmds='base_file=`basename \${file}`~
- dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~
+ postinstall_cmds='base_file=`basename \$file`~
+ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~
dldir=$destdir/`dirname \$dlpath`~
test -d \$dldir || mkdir -p \$dldir~
$install_prog $dir/$dlname \$dldir/$dlname~
@@ -15262,16 +15542,16 @@ cygwin* | mingw* | pw32* | cegcc*)
case $host_os in
cygwin*)
# Cygwin DLLs use 'cyg' prefix rather than 'lib'
- soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}'
+ soname_spec='`echo $libname | sed -e 's/^lib/cyg/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext'
;;
mingw* | cegcc*)
# MinGW DLLs use traditional 'lib' prefix
- soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}'
+ soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext'
;;
pw32*)
# pw32 DLLs use 'pw' prefix rather than 'lib'
- library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}'
+ library_names_spec='`echo $libname | sed -e 's/^lib/pw/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext'
;;
esac
dynamic_linker='Win32 ld.exe'
@@ -15280,8 +15560,8 @@ cygwin* | mingw* | pw32* | cegcc*)
*,cl*)
# Native MSVC
libname_spec='$name'
- soname_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext}'
- library_names_spec='${libname}.dll.lib'
+ soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext'
+ library_names_spec='$libname.dll.lib'
case $build_os in
mingw*)
@@ -15308,7 +15588,7 @@ cygwin* | mingw* | pw32* | cegcc*)
sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"`
;;
*)
- sys_lib_search_path_spec="$LIB"
+ sys_lib_search_path_spec=$LIB
if $ECHO "$sys_lib_search_path_spec" | $GREP ';[c-zC-Z]:/' >/dev/null; then
# It is most probably a Windows format PATH.
sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'`
@@ -15321,8 +15601,8 @@ cygwin* | mingw* | pw32* | cegcc*)
esac
# DLL is installed to $(libdir)/../bin by postinstall_cmds
- postinstall_cmds='base_file=`basename \${file}`~
- dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~
+ postinstall_cmds='base_file=`basename \$file`~
+ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~
dldir=$destdir/`dirname \$dlpath`~
test -d \$dldir || mkdir -p \$dldir~
$install_prog $dir/$dlname \$dldir/$dlname'
@@ -15335,7 +15615,7 @@ cygwin* | mingw* | pw32* | cegcc*)
*)
# Assume MSVC wrapper
- library_names_spec='${libname}`echo ${release} | $SED -e 's/[.]/-/g'`${versuffix}${shared_ext} $libname.lib'
+ library_names_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext $libname.lib'
dynamic_linker='Win32 ld.exe'
;;
esac
@@ -15348,8 +15628,8 @@ darwin* | rhapsody*)
version_type=darwin
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${major}$shared_ext ${libname}$shared_ext'
- soname_spec='${libname}${release}${major}$shared_ext'
+ library_names_spec='$libname$release$major$shared_ext $libname$shared_ext'
+ soname_spec='$libname$release$major$shared_ext'
shlibpath_overrides_runpath=yes
shlibpath_var=DYLD_LIBRARY_PATH
shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`'
@@ -15361,8 +15641,8 @@ dgux*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
;;
@@ -15380,12 +15660,13 @@ freebsd* | dragonfly*)
version_type=freebsd-$objformat
case $version_type in
freebsd-elf*)
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
need_version=no
need_lib_prefix=no
;;
freebsd-*)
- library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix'
need_version=yes
;;
esac
@@ -15410,26 +15691,15 @@ freebsd* | dragonfly*)
esac
;;
-gnu*)
- version_type=linux # correct to gnu/linux during the next big refactor
- need_lib_prefix=no
- need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
- shlibpath_var=LD_LIBRARY_PATH
- shlibpath_overrides_runpath=no
- hardcode_into_libs=yes
- ;;
-
haiku*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
dynamic_linker="$host_os runtime_loader"
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LIBRARY_PATH
- shlibpath_overrides_runpath=yes
+ shlibpath_overrides_runpath=no
sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib'
hardcode_into_libs=yes
;;
@@ -15447,14 +15717,15 @@ hpux9* | hpux10* | hpux11*)
dynamic_linker="$host_os dld.so"
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=yes # Unless +noenvvar is specified.
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
- if test "X$HPUX_IA64_MODE" = X32; then
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
+ if test 32 = "$HPUX_IA64_MODE"; then
sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib"
+ sys_lib_dlsearch_path_spec=/usr/lib/hpux32
else
sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64"
+ sys_lib_dlsearch_path_spec=/usr/lib/hpux64
fi
- sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
;;
hppa*64*)
shrext_cmds='.sl'
@@ -15462,8 +15733,8 @@ hpux9* | hpux10* | hpux11*)
dynamic_linker="$host_os dld.sl"
shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH
shlibpath_overrides_runpath=yes # Unless +noenvvar is specified.
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64"
sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
;;
@@ -15472,8 +15743,8 @@ hpux9* | hpux10* | hpux11*)
dynamic_linker="$host_os dld.sl"
shlibpath_var=SHLIB_PATH
shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
;;
esac
# HP-UX runs *really* slowly unless shared libraries are mode 555, ...
@@ -15486,8 +15757,8 @@ interix[3-9]*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=no
@@ -15498,7 +15769,7 @@ irix5* | irix6* | nonstopux*)
case $host_os in
nonstopux*) version_type=nonstopux ;;
*)
- if test "$lt_cv_prog_gnu_ld" = yes; then
+ if test yes = "$lt_cv_prog_gnu_ld"; then
version_type=linux # correct to gnu/linux during the next big refactor
else
version_type=irix
@@ -15506,8 +15777,8 @@ irix5* | irix6* | nonstopux*)
esac
need_lib_prefix=no
need_version=no
- soname_spec='${libname}${release}${shared_ext}$major'
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}'
+ soname_spec='$libname$release$shared_ext$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$release$shared_ext $libname$shared_ext'
case $host_os in
irix5* | nonstopux*)
libsuff= shlibsuff=
@@ -15526,8 +15797,8 @@ irix5* | irix6* | nonstopux*)
esac
shlibpath_var=LD_LIBRARY${shlibsuff}_PATH
shlibpath_overrides_runpath=no
- sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}"
- sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}"
+ sys_lib_search_path_spec="/usr/lib$libsuff /lib$libsuff /usr/local/lib$libsuff"
+ sys_lib_dlsearch_path_spec="/usr/lib$libsuff /lib$libsuff"
hardcode_into_libs=yes
;;
@@ -15536,13 +15807,33 @@ linux*oldld* | linux*aout* | linux*coff*)
dynamic_linker=no
;;
+linux*android*)
+ version_type=none # Android doesn't support versioned libraries.
+ need_lib_prefix=no
+ need_version=no
+ library_names_spec='$libname$release$shared_ext'
+ soname_spec='$libname$release$shared_ext'
+ finish_cmds=
+ shlibpath_var=LD_LIBRARY_PATH
+ shlibpath_overrides_runpath=yes
+
+ # This implies no fast_install, which is unacceptable.
+ # Some rework will be needed to allow for fast_install
+ # before this can be enabled.
+ hardcode_into_libs=yes
+
+ dynamic_linker='Android linker'
+ # Don't embed -rpath directories since the linker doesn't support them.
+ hardcode_libdir_flag_spec_CXX='-L$libdir'
+ ;;
+
# This must be glibc/ELF.
-linux* | k*bsd*-gnu | kopensolaris*-gnu)
+linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=no
@@ -15586,7 +15877,12 @@ fi
# before this can be enabled.
hardcode_into_libs=yes
- # Append ld.so.conf contents to the search path
+ # Ideally, we could use ldconfig to report *all* directores which are
+ # searched for libraries, however this is still not possible. Aside from not
+ # being certain /sbin/ldconfig is available, command
+ # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64,
+ # even though it is searched at run-time. Try to do the best guess by
+ # appending ld.so.conf contents (and includes) to the search path.
if test -f /etc/ld.so.conf; then
lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '`
sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra"
@@ -15601,17 +15897,29 @@ fi
dynamic_linker='GNU/Linux ld.so'
;;
+netbsdelf*-gnu)
+ version_type=linux
+ need_lib_prefix=no
+ need_version=no
+ library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}'
+ soname_spec='${libname}${release}${shared_ext}$major'
+ shlibpath_var=LD_LIBRARY_PATH
+ shlibpath_overrides_runpath=no
+ hardcode_into_libs=yes
+ dynamic_linker='NetBSD ld.elf_so'
+ ;;
+
netbsd*)
version_type=sunos
need_lib_prefix=no
need_version=no
if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix'
finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir'
dynamic_linker='NetBSD (a.out) ld.so'
else
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
dynamic_linker='NetBSD ld.elf_so'
fi
shlibpath_var=LD_LIBRARY_PATH
@@ -15621,7 +15929,7 @@ netbsd*)
newsos6)
version_type=linux # correct to gnu/linux during the next big refactor
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=yes
;;
@@ -15630,58 +15938,68 @@ newsos6)
version_type=qnx
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=no
hardcode_into_libs=yes
dynamic_linker='ldqnx.so'
;;
-openbsd*)
+openbsd* | bitrig*)
version_type=sunos
- sys_lib_dlsearch_path_spec="/usr/lib"
+ sys_lib_dlsearch_path_spec=/usr/lib
need_lib_prefix=no
- # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs.
- case $host_os in
- openbsd3.3 | openbsd3.3.*) need_version=yes ;;
- *) need_version=no ;;
- esac
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
- finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir'
- shlibpath_var=LD_LIBRARY_PATH
- if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
- case $host_os in
- openbsd2.[89] | openbsd2.[89].*)
- shlibpath_overrides_runpath=no
- ;;
- *)
- shlibpath_overrides_runpath=yes
- ;;
- esac
+ if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then
+ need_version=no
else
- shlibpath_overrides_runpath=yes
+ need_version=yes
fi
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix'
+ finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir'
+ shlibpath_var=LD_LIBRARY_PATH
+ shlibpath_overrides_runpath=yes
;;
os2*)
libname_spec='$name'
- shrext_cmds=".dll"
+ version_type=windows
+ shrext_cmds=.dll
+ need_version=no
need_lib_prefix=no
- library_names_spec='$libname${shared_ext} $libname.a'
+ # OS/2 can only load a DLL with a base name of 8 characters or less.
+ soname_spec='`test -n "$os2dllname" && libname="$os2dllname";
+ v=$($ECHO $release$versuffix | tr -d .-);
+ n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _);
+ $ECHO $n$v`$shared_ext'
+ library_names_spec='${libname}_dll.$libext'
dynamic_linker='OS/2 ld.exe'
- shlibpath_var=LIBPATH
+ shlibpath_var=BEGINLIBPATH
+ sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib"
+ sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
+ postinstall_cmds='base_file=`basename \$file`~
+ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; $ECHO \$dlname'\''`~
+ dldir=$destdir/`dirname \$dlpath`~
+ test -d \$dldir || mkdir -p \$dldir~
+ $install_prog $dir/$dlname \$dldir/$dlname~
+ chmod a+x \$dldir/$dlname~
+ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then
+ eval '\''$striplib \$dldir/$dlname'\'' || exit \$?;
+ fi'
+ postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~
+ dlpath=$dir/\$dldll~
+ $RM \$dlpath'
;;
osf3* | osf4* | osf5*)
version_type=osf
need_lib_prefix=no
need_version=no
- soname_spec='${libname}${release}${shared_ext}$major'
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+ soname_spec='$libname$release$shared_ext$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
shlibpath_var=LD_LIBRARY_PATH
sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib"
- sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec"
+ sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
;;
rdos*)
@@ -15692,8 +16010,8 @@ solaris*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=yes
hardcode_into_libs=yes
@@ -15703,11 +16021,11 @@ solaris*)
sunos4*)
version_type=sunos
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix'
finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=yes
- if test "$with_gnu_ld" = yes; then
+ if test yes = "$with_gnu_ld"; then
need_lib_prefix=no
fi
need_version=yes
@@ -15715,8 +16033,8 @@ sunos4*)
sysv4 | sysv4.3*)
version_type=linux # correct to gnu/linux during the next big refactor
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
case $host_vendor in
sni)
@@ -15737,24 +16055,24 @@ sysv4 | sysv4.3*)
;;
sysv4*MP*)
- if test -d /usr/nec ;then
+ if test -d /usr/nec; then
version_type=linux # correct to gnu/linux during the next big refactor
- library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}'
- soname_spec='$libname${shared_ext}.$major'
+ library_names_spec='$libname$shared_ext.$versuffix $libname$shared_ext.$major $libname$shared_ext'
+ soname_spec='$libname$shared_ext.$major'
shlibpath_var=LD_LIBRARY_PATH
fi
;;
sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*)
- version_type=freebsd-elf
+ version_type=sco
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=yes
hardcode_into_libs=yes
- if test "$with_gnu_ld" = yes; then
+ if test yes = "$with_gnu_ld"; then
sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib'
else
sys_lib_search_path_spec='/usr/ccs/lib /usr/lib'
@@ -15772,7 +16090,7 @@ tpf*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=no
hardcode_into_libs=yes
@@ -15780,8 +16098,8 @@ tpf*)
uts4*)
version_type=linux # correct to gnu/linux during the next big refactor
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
;;
@@ -15791,20 +16109,32 @@ uts4*)
esac
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $dynamic_linker" >&5
$as_echo "$dynamic_linker" >&6; }
-test "$dynamic_linker" = no && can_build_shared=no
+test no = "$dynamic_linker" && can_build_shared=no
variables_saved_for_relink="PATH $shlibpath_var $runpath_var"
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH"
fi
-if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then
- sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec"
+if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then
+ sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec
fi
-if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then
- sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec"
+
+if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then
+ sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec
fi
+# remember unaugmented sys_lib_dlsearch_path content for libtool script decls...
+configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec
+
+# ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code
+func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH"
+
+# to be used as default LT_SYS_LIBRARY_PATH value in generated libtool
+configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH
+
+
+
@@ -15847,15 +16177,15 @@ $as_echo_n "checking how to hardcode library paths into programs... " >&6; }
hardcode_action_CXX=
if test -n "$hardcode_libdir_flag_spec_CXX" ||
test -n "$runpath_var_CXX" ||
- test "X$hardcode_automatic_CXX" = "Xyes" ; then
+ test yes = "$hardcode_automatic_CXX"; then
# We can hardcode non-existent directories.
- if test "$hardcode_direct_CXX" != no &&
+ if test no != "$hardcode_direct_CXX" &&
# If the only mechanism to avoid hardcoding is shlibpath_var, we
# have to relink, otherwise we might link with an installed library
# when we should be linking with a yet-to-be-installed one
- ## test "$_LT_TAGVAR(hardcode_shlibpath_var, CXX)" != no &&
- test "$hardcode_minus_L_CXX" != no; then
+ ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, CXX)" &&
+ test no != "$hardcode_minus_L_CXX"; then
# Linking always hardcodes the temporary library directory.
hardcode_action_CXX=relink
else
@@ -15870,12 +16200,12 @@ fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $hardcode_action_CXX" >&5
$as_echo "$hardcode_action_CXX" >&6; }
-if test "$hardcode_action_CXX" = relink ||
- test "$inherit_rpath_CXX" = yes; then
+if test relink = "$hardcode_action_CXX" ||
+ test yes = "$inherit_rpath_CXX"; then
# Fast installation is not supported
enable_fast_install=no
-elif test "$shlibpath_overrides_runpath" = yes ||
- test "$enable_shared" = no; then
+elif test yes = "$shlibpath_overrides_runpath" ||
+ test no = "$enable_shared"; then
# Fast installation is not necessary
enable_fast_install=needless
fi
@@ -15898,7 +16228,7 @@ fi
lt_cv_path_LD=$lt_save_path_LD
lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld
lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld
-fi # test "$_lt_caught_CXX_error" != yes
+fi # test yes != "$_lt_caught_CXX_error"
ac_ext=c
ac_cpp='$CPP $CPPFLAGS'
@@ -15929,6 +16259,375 @@ ac_compiler_gnu=$ac_cv_c_compiler_gnu
+#AM_PROG_LD
+#AC_SUBST(LD)
+#AC_PROG_INSTALL
+#AC_PROG_MAKE_SET
+#AC_PROG_LN_S
+
+#
+# Tests for Windows
+#
+
+
+
+# Configure libtool
+# Check whether --enable-shared was given.
+if test "${enable_shared+set}" = set; then :
+ enableval=$enable_shared; p=${PACKAGE-default}
+ case $enableval in
+ yes) enable_shared=yes ;;
+ no) enable_shared=no ;;
+ *)
+ enable_shared=no
+ # Look at the argument we got. We use all the common list separators.
+ lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
+ for pkg in $enableval; do
+ IFS=$lt_save_ifs
+ if test "X$pkg" = "X$p"; then
+ enable_shared=yes
+ fi
+ done
+ IFS=$lt_save_ifs
+ ;;
+ esac
+else
+ enable_shared=yes
+fi
+
+
+
+
+
+
+# Check whether --enable-static was given.
+if test "${enable_static+set}" = set; then :
+ enableval=$enable_static; p=${PACKAGE-default}
+ case $enableval in
+ yes) enable_static=yes ;;
+ no) enable_static=no ;;
+ *)
+ enable_static=no
+ # Look at the argument we got. We use all the common list separators.
+ lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
+ for pkg in $enableval; do
+ IFS=$lt_save_ifs
+ if test "X$pkg" = "X$p"; then
+ enable_static=yes
+ fi
+ done
+ IFS=$lt_save_ifs
+ ;;
+ esac
+else
+ enable_static=yes
+fi
+
+
+
+
+
+
+enable_win32_dll=yes
+
+case $host in
+*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-cegcc*)
+ if test -n "$ac_tool_prefix"; then
+ # Extract the first word of "${ac_tool_prefix}as", so it can be a program name with args.
+set dummy ${ac_tool_prefix}as; ac_word=$2
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if ${ac_cv_prog_AS+:} false; then :
+ $as_echo_n "(cached) " >&6
+else
+ if test -n "$AS"; then
+ ac_cv_prog_AS="$AS" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+ IFS=$as_save_IFS
+ test -z "$as_dir" && as_dir=.
+ for ac_exec_ext in '' $ac_executable_extensions; do
+ if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
+ ac_cv_prog_AS="${ac_tool_prefix}as"
+ $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5
+ break 2
+ fi
+done
+ done
+IFS=$as_save_IFS
+
+fi
+fi
+AS=$ac_cv_prog_AS
+if test -n "$AS"; then
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: $AS" >&5
+$as_echo "$AS" >&6; }
+else
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_AS"; then
+ ac_ct_AS=$AS
+ # Extract the first word of "as", so it can be a program name with args.
+set dummy as; ac_word=$2
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if ${ac_cv_prog_ac_ct_AS+:} false; then :
+ $as_echo_n "(cached) " >&6
+else
+ if test -n "$ac_ct_AS"; then
+ ac_cv_prog_ac_ct_AS="$ac_ct_AS" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+ IFS=$as_save_IFS
+ test -z "$as_dir" && as_dir=.
+ for ac_exec_ext in '' $ac_executable_extensions; do
+ if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
+ ac_cv_prog_ac_ct_AS="as"
+ $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5
+ break 2
+ fi
+done
+ done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_AS=$ac_cv_prog_ac_ct_AS
+if test -n "$ac_ct_AS"; then
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_AS" >&5
+$as_echo "$ac_ct_AS" >&6; }
+else
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+ if test "x$ac_ct_AS" = x; then
+ AS="false"
+ else
+ case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+ AS=$ac_ct_AS
+ fi
+else
+ AS="$ac_cv_prog_AS"
+fi
+
+ if test -n "$ac_tool_prefix"; then
+ # Extract the first word of "${ac_tool_prefix}dlltool", so it can be a program name with args.
+set dummy ${ac_tool_prefix}dlltool; ac_word=$2
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if ${ac_cv_prog_DLLTOOL+:} false; then :
+ $as_echo_n "(cached) " >&6
+else
+ if test -n "$DLLTOOL"; then
+ ac_cv_prog_DLLTOOL="$DLLTOOL" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+ IFS=$as_save_IFS
+ test -z "$as_dir" && as_dir=.
+ for ac_exec_ext in '' $ac_executable_extensions; do
+ if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
+ ac_cv_prog_DLLTOOL="${ac_tool_prefix}dlltool"
+ $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5
+ break 2
+ fi
+done
+ done
+IFS=$as_save_IFS
+
+fi
+fi
+DLLTOOL=$ac_cv_prog_DLLTOOL
+if test -n "$DLLTOOL"; then
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: $DLLTOOL" >&5
+$as_echo "$DLLTOOL" >&6; }
+else
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_DLLTOOL"; then
+ ac_ct_DLLTOOL=$DLLTOOL
+ # Extract the first word of "dlltool", so it can be a program name with args.
+set dummy dlltool; ac_word=$2
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if ${ac_cv_prog_ac_ct_DLLTOOL+:} false; then :
+ $as_echo_n "(cached) " >&6
+else
+ if test -n "$ac_ct_DLLTOOL"; then
+ ac_cv_prog_ac_ct_DLLTOOL="$ac_ct_DLLTOOL" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+ IFS=$as_save_IFS
+ test -z "$as_dir" && as_dir=.
+ for ac_exec_ext in '' $ac_executable_extensions; do
+ if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
+ ac_cv_prog_ac_ct_DLLTOOL="dlltool"
+ $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5
+ break 2
+ fi
+done
+ done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_DLLTOOL=$ac_cv_prog_ac_ct_DLLTOOL
+if test -n "$ac_ct_DLLTOOL"; then
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DLLTOOL" >&5
+$as_echo "$ac_ct_DLLTOOL" >&6; }
+else
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+ if test "x$ac_ct_DLLTOOL" = x; then
+ DLLTOOL="false"
+ else
+ case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+ DLLTOOL=$ac_ct_DLLTOOL
+ fi
+else
+ DLLTOOL="$ac_cv_prog_DLLTOOL"
+fi
+
+ if test -n "$ac_tool_prefix"; then
+ # Extract the first word of "${ac_tool_prefix}objdump", so it can be a program name with args.
+set dummy ${ac_tool_prefix}objdump; ac_word=$2
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if ${ac_cv_prog_OBJDUMP+:} false; then :
+ $as_echo_n "(cached) " >&6
+else
+ if test -n "$OBJDUMP"; then
+ ac_cv_prog_OBJDUMP="$OBJDUMP" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+ IFS=$as_save_IFS
+ test -z "$as_dir" && as_dir=.
+ for ac_exec_ext in '' $ac_executable_extensions; do
+ if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
+ ac_cv_prog_OBJDUMP="${ac_tool_prefix}objdump"
+ $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5
+ break 2
+ fi
+done
+ done
+IFS=$as_save_IFS
+
+fi
+fi
+OBJDUMP=$ac_cv_prog_OBJDUMP
+if test -n "$OBJDUMP"; then
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: $OBJDUMP" >&5
+$as_echo "$OBJDUMP" >&6; }
+else
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+
+fi
+if test -z "$ac_cv_prog_OBJDUMP"; then
+ ac_ct_OBJDUMP=$OBJDUMP
+ # Extract the first word of "objdump", so it can be a program name with args.
+set dummy objdump; ac_word=$2
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5
+$as_echo_n "checking for $ac_word... " >&6; }
+if ${ac_cv_prog_ac_ct_OBJDUMP+:} false; then :
+ $as_echo_n "(cached) " >&6
+else
+ if test -n "$ac_ct_OBJDUMP"; then
+ ac_cv_prog_ac_ct_OBJDUMP="$ac_ct_OBJDUMP" # Let the user override the test.
+else
+as_save_IFS=$IFS; IFS=$PATH_SEPARATOR
+for as_dir in $PATH
+do
+ IFS=$as_save_IFS
+ test -z "$as_dir" && as_dir=.
+ for ac_exec_ext in '' $ac_executable_extensions; do
+ if as_fn_executable_p "$as_dir/$ac_word$ac_exec_ext"; then
+ ac_cv_prog_ac_ct_OBJDUMP="objdump"
+ $as_echo "$as_me:${as_lineno-$LINENO}: found $as_dir/$ac_word$ac_exec_ext" >&5
+ break 2
+ fi
+done
+ done
+IFS=$as_save_IFS
+
+fi
+fi
+ac_ct_OBJDUMP=$ac_cv_prog_ac_ct_OBJDUMP
+if test -n "$ac_ct_OBJDUMP"; then
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OBJDUMP" >&5
+$as_echo "$ac_ct_OBJDUMP" >&6; }
+else
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
+$as_echo "no" >&6; }
+fi
+
+ if test "x$ac_ct_OBJDUMP" = x; then
+ OBJDUMP="false"
+ else
+ case $cross_compiling:$ac_tool_warned in
+yes:)
+{ $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5
+$as_echo "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;}
+ac_tool_warned=yes ;;
+esac
+ OBJDUMP=$ac_ct_OBJDUMP
+ fi
+else
+ OBJDUMP="$ac_cv_prog_OBJDUMP"
+fi
+
+ ;;
+esac
+
+test -z "$AS" && AS=as
+
+
+
+
+
+test -z "$DLLTOOL" && DLLTOOL=dlltool
+
+
+test -z "$OBJDUMP" && OBJDUMP=objdump
+
+
+
+
+
+
+
LIB_PLUGINS = ''
@@ -16366,6 +17065,20 @@ $as_echo "#define AC_APPLE_UNIVERSAL_BUILD 1" >>confdefs.h
esac
+# Check for functions that some compilers lack (or name differently)
+for ac_func in gmtime_r _gmtime64_s
+do :
+ as_ac_var=`$as_echo "ac_cv_func_$ac_func" | $as_tr_sh`
+ac_fn_c_check_func "$LINENO" "$ac_func" "$as_ac_var"
+if eval test \"x\$"$as_ac_var"\" = x"yes"; then :
+ cat >>confdefs.h <<_ACEOF
+#define `$as_echo "HAVE_$ac_func" | $as_tr_cpp` 1
+_ACEOF
+
+fi
+done
+
+
# Point to JPEG installed in DIR or disable JPEG with --without-jpeg.
# Check whether --with-jpeg was given.
@@ -16425,8 +17138,7 @@ fi
# Check whether --with-fastfloat was given.
if test "${with_fastfloat+set}" = set; then :
withval=$with_fastfloat;
- with_fastfloat='yes'
- LIB_PLUGINS="$LIB_PLUGINS -llcms2_fast_float"
+ with_fastfloat=$withval
else
@@ -16434,6 +17146,10 @@ else
fi
+if test "$with_fastfloat" == "yes"
+then
+ LIB_PLUGINS="$LIB_PLUGINS -llcms2_fast_float"
+fi
#
# Determine POSIX threads settings
@@ -16916,6 +17632,42 @@ $as_echo "$as_me: WARNING: Replacing compiler $CXX with compiler $PTHREAD_CXX to
fi
fi
+# check if compiler supports SSE2 intrinsics
+ac_ext=c
+ac_cpp='$CPP $CPPFLAGS'
+ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
+ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'
+ac_compiler_gnu=$ac_cv_c_compiler_gnu
+
+
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking whether compiler supports SSE2" >&5
+$as_echo_n "checking whether compiler supports SSE2... " >&6; }
+cat confdefs.h - <<_ACEOF >conftest.$ac_ext
+/* end confdefs.h. */
+
+ #include <emmintrin.h>
+ main() { __m128i n = _mm_set1_epi8(42); }
+_ACEOF
+if ac_fn_c_try_compile "$LINENO"; then :
+ ac_compiler_supports_sse2=yes
+else
+ ac_compiler_supports_sse2=no
+fi
+rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_compiler_supports_sse2" >&5
+$as_echo "$ac_compiler_supports_sse2" >&6; }
+if test "x$ac_compiler_supports_sse2" != "xyes"; then :
+
+$as_echo "#define CMS_DONT_USE_SSE2 1" >>confdefs.h
+
+fi
+
+ac_ext=c
+ac_cpp='$CPP $CPPFLAGS'
+ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5'
+ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5'
+ac_compiler_gnu=$ac_cv_c_compiler_gnu
+
#
# Find math library
@@ -18542,15 +19294,13 @@ AMDEP_TRUE="$AMDEP_TRUE" ac_aux_dir="$ac_aux_dir"
sed_quote_subst='$sed_quote_subst'
double_quote_subst='$double_quote_subst'
delay_variable_subst='$delay_variable_subst'
-enable_shared='`$ECHO "$enable_shared" | $SED "$delay_single_quote_subst"`'
-enable_static='`$ECHO "$enable_static" | $SED "$delay_single_quote_subst"`'
-AS='`$ECHO "$AS" | $SED "$delay_single_quote_subst"`'
-DLLTOOL='`$ECHO "$DLLTOOL" | $SED "$delay_single_quote_subst"`'
-OBJDUMP='`$ECHO "$OBJDUMP" | $SED "$delay_single_quote_subst"`'
macro_version='`$ECHO "$macro_version" | $SED "$delay_single_quote_subst"`'
macro_revision='`$ECHO "$macro_revision" | $SED "$delay_single_quote_subst"`'
+enable_shared='`$ECHO "$enable_shared" | $SED "$delay_single_quote_subst"`'
+enable_static='`$ECHO "$enable_static" | $SED "$delay_single_quote_subst"`'
pic_mode='`$ECHO "$pic_mode" | $SED "$delay_single_quote_subst"`'
enable_fast_install='`$ECHO "$enable_fast_install" | $SED "$delay_single_quote_subst"`'
+shared_archive_member_spec='`$ECHO "$shared_archive_member_spec" | $SED "$delay_single_quote_subst"`'
SHELL='`$ECHO "$SHELL" | $SED "$delay_single_quote_subst"`'
ECHO='`$ECHO "$ECHO" | $SED "$delay_single_quote_subst"`'
PATH_SEPARATOR='`$ECHO "$PATH_SEPARATOR" | $SED "$delay_single_quote_subst"`'
@@ -18578,10 +19328,12 @@ lt_cv_to_host_file_cmd='`$ECHO "$lt_cv_to_host_file_cmd" | $SED "$delay_single_q
lt_cv_to_tool_file_cmd='`$ECHO "$lt_cv_to_tool_file_cmd" | $SED "$delay_single_quote_subst"`'
reload_flag='`$ECHO "$reload_flag" | $SED "$delay_single_quote_subst"`'
reload_cmds='`$ECHO "$reload_cmds" | $SED "$delay_single_quote_subst"`'
+OBJDUMP='`$ECHO "$OBJDUMP" | $SED "$delay_single_quote_subst"`'
deplibs_check_method='`$ECHO "$deplibs_check_method" | $SED "$delay_single_quote_subst"`'
file_magic_cmd='`$ECHO "$file_magic_cmd" | $SED "$delay_single_quote_subst"`'
file_magic_glob='`$ECHO "$file_magic_glob" | $SED "$delay_single_quote_subst"`'
want_nocaseglob='`$ECHO "$want_nocaseglob" | $SED "$delay_single_quote_subst"`'
+DLLTOOL='`$ECHO "$DLLTOOL" | $SED "$delay_single_quote_subst"`'
sharedlib_from_linklib_cmd='`$ECHO "$sharedlib_from_linklib_cmd" | $SED "$delay_single_quote_subst"`'
AR='`$ECHO "$AR" | $SED "$delay_single_quote_subst"`'
AR_FLAGS='`$ECHO "$AR_FLAGS" | $SED "$delay_single_quote_subst"`'
@@ -18598,10 +19350,13 @@ compiler='`$ECHO "$compiler" | $SED "$delay_single_quote_subst"`'
GCC='`$ECHO "$GCC" | $SED "$delay_single_quote_subst"`'
lt_cv_sys_global_symbol_pipe='`$ECHO "$lt_cv_sys_global_symbol_pipe" | $SED "$delay_single_quote_subst"`'
lt_cv_sys_global_symbol_to_cdecl='`$ECHO "$lt_cv_sys_global_symbol_to_cdecl" | $SED "$delay_single_quote_subst"`'
+lt_cv_sys_global_symbol_to_import='`$ECHO "$lt_cv_sys_global_symbol_to_import" | $SED "$delay_single_quote_subst"`'
lt_cv_sys_global_symbol_to_c_name_address='`$ECHO "$lt_cv_sys_global_symbol_to_c_name_address" | $SED "$delay_single_quote_subst"`'
lt_cv_sys_global_symbol_to_c_name_address_lib_prefix='`$ECHO "$lt_cv_sys_global_symbol_to_c_name_address_lib_prefix" | $SED "$delay_single_quote_subst"`'
+lt_cv_nm_interface='`$ECHO "$lt_cv_nm_interface" | $SED "$delay_single_quote_subst"`'
nm_file_list_spec='`$ECHO "$nm_file_list_spec" | $SED "$delay_single_quote_subst"`'
lt_sysroot='`$ECHO "$lt_sysroot" | $SED "$delay_single_quote_subst"`'
+lt_cv_truncate_bin='`$ECHO "$lt_cv_truncate_bin" | $SED "$delay_single_quote_subst"`'
objdir='`$ECHO "$objdir" | $SED "$delay_single_quote_subst"`'
MAGIC_CMD='`$ECHO "$MAGIC_CMD" | $SED "$delay_single_quote_subst"`'
lt_prog_compiler_no_builtin_flag='`$ECHO "$lt_prog_compiler_no_builtin_flag" | $SED "$delay_single_quote_subst"`'
@@ -18666,7 +19421,8 @@ finish_cmds='`$ECHO "$finish_cmds" | $SED "$delay_single_quote_subst"`'
finish_eval='`$ECHO "$finish_eval" | $SED "$delay_single_quote_subst"`'
hardcode_into_libs='`$ECHO "$hardcode_into_libs" | $SED "$delay_single_quote_subst"`'
sys_lib_search_path_spec='`$ECHO "$sys_lib_search_path_spec" | $SED "$delay_single_quote_subst"`'
-sys_lib_dlsearch_path_spec='`$ECHO "$sys_lib_dlsearch_path_spec" | $SED "$delay_single_quote_subst"`'
+configure_time_dlsearch_path='`$ECHO "$configure_time_dlsearch_path" | $SED "$delay_single_quote_subst"`'
+configure_time_lt_sys_library_path='`$ECHO "$configure_time_lt_sys_library_path" | $SED "$delay_single_quote_subst"`'
hardcode_action='`$ECHO "$hardcode_action" | $SED "$delay_single_quote_subst"`'
enable_dlopen='`$ECHO "$enable_dlopen" | $SED "$delay_single_quote_subst"`'
enable_dlopen_self='`$ECHO "$enable_dlopen_self" | $SED "$delay_single_quote_subst"`'
@@ -18679,6 +19435,7 @@ postdep_objects='`$ECHO "$postdep_objects" | $SED "$delay_single_quote_subst"`'
predeps='`$ECHO "$predeps" | $SED "$delay_single_quote_subst"`'
postdeps='`$ECHO "$postdeps" | $SED "$delay_single_quote_subst"`'
compiler_lib_search_path='`$ECHO "$compiler_lib_search_path" | $SED "$delay_single_quote_subst"`'
+AS='`$ECHO "$AS" | $SED "$delay_single_quote_subst"`'
LD_CXX='`$ECHO "$LD_CXX" | $SED "$delay_single_quote_subst"`'
reload_flag_CXX='`$ECHO "$reload_flag_CXX" | $SED "$delay_single_quote_subst"`'
reload_cmds_CXX='`$ECHO "$reload_cmds_CXX" | $SED "$delay_single_quote_subst"`'
@@ -18741,10 +19498,7 @@ _LTECHO_EOF'
}
# Quote evaled strings.
-for var in AS \
-DLLTOOL \
-OBJDUMP \
-SHELL \
+for var in SHELL \
ECHO \
PATH_SEPARATOR \
SED \
@@ -18757,10 +19511,12 @@ LN_S \
lt_SP2NL \
lt_NL2SP \
reload_flag \
+OBJDUMP \
deplibs_check_method \
file_magic_cmd \
file_magic_glob \
want_nocaseglob \
+DLLTOOL \
sharedlib_from_linklib_cmd \
AR \
AR_FLAGS \
@@ -18772,9 +19528,12 @@ CFLAGS \
compiler \
lt_cv_sys_global_symbol_pipe \
lt_cv_sys_global_symbol_to_cdecl \
+lt_cv_sys_global_symbol_to_import \
lt_cv_sys_global_symbol_to_c_name_address \
lt_cv_sys_global_symbol_to_c_name_address_lib_prefix \
+lt_cv_nm_interface \
nm_file_list_spec \
+lt_cv_truncate_bin \
lt_prog_compiler_no_builtin_flag \
lt_prog_compiler_pic \
lt_prog_compiler_wl \
@@ -18813,6 +19572,7 @@ postdep_objects \
predeps \
postdeps \
compiler_lib_search_path \
+AS \
LD_CXX \
reload_flag_CXX \
compiler_CXX \
@@ -18840,7 +19600,7 @@ postdeps_CXX \
compiler_lib_search_path_CXX; do
case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in
*[\\\\\\\`\\"\\\$]*)
- eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\""
+ eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes
;;
*)
eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\""
@@ -18867,7 +19627,8 @@ postinstall_cmds \
postuninstall_cmds \
finish_cmds \
sys_lib_search_path_spec \
-sys_lib_dlsearch_path_spec \
+configure_time_dlsearch_path \
+configure_time_lt_sys_library_path \
reload_cmds_CXX \
old_archive_cmds_CXX \
old_archive_from_new_cmds_CXX \
@@ -18881,7 +19642,7 @@ prelink_cmds_CXX \
postlink_cmds_CXX; do
case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in
*[\\\\\\\`\\"\\\$]*)
- eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\""
+ eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes
;;
*)
eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\""
@@ -18890,19 +19651,16 @@ postlink_cmds_CXX; do
done
ac_aux_dir='$ac_aux_dir'
-xsi_shell='$xsi_shell'
-lt_shell_append='$lt_shell_append'
-# See if we are running on zsh, and set the options which allow our
+# See if we are running on zsh, and set the options that allow our
# commands through without removal of \ escapes INIT.
-if test -n "\${ZSH_VERSION+set}" ; then
+if test -n "\${ZSH_VERSION+set}"; then
setopt NO_GLOB_SUBST
fi
PACKAGE='$PACKAGE'
VERSION='$VERSION'
- TIMESTAMP='$TIMESTAMP'
RM='$RM'
ofile='$ofile'
@@ -19460,83 +20218,74 @@ $as_echo X"$file" |
;;
"libtool":C)
- # See if we are running on zsh, and set the options which allow our
+ # See if we are running on zsh, and set the options that allow our
# commands through without removal of \ escapes.
- if test -n "${ZSH_VERSION+set}" ; then
+ if test -n "${ZSH_VERSION+set}"; then
setopt NO_GLOB_SUBST
fi
- cfgfile="${ofile}T"
+ cfgfile=${ofile}T
trap "$RM \"$cfgfile\"; exit 1" 1 2 15
$RM "$cfgfile"
cat <<_LT_EOF >> "$cfgfile"
#! $SHELL
-
-# `$ECHO "$ofile" | sed 's%^.*/%%'` - Provide generalized library-building support services.
-# Generated automatically by $as_me ($PACKAGE$TIMESTAMP) $VERSION
-# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`:
+# Generated automatically by $as_me ($PACKAGE) $VERSION
# NOTE: Changes made to this file will be lost: look at ltmain.sh.
+
+# Provide generalized library-building support services.
+# Written by Gordon Matzigkeit, 1996
+
+# Copyright (C) 2014 Free Software Foundation, Inc.
+# This is free software; see the source for copying conditions. There is NO
+# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+
+# GNU Libtool is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of of the License, or
+# (at your option) any later version.
#
-# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005,
-# 2006, 2007, 2008, 2009, 2010, 2011 Free Software
-# Foundation, Inc.
-# Written by Gordon Matzigkeit, 1996
-#
-# This file is part of GNU Libtool.
-#
-# GNU Libtool is free software; you can redistribute it and/or
-# modify it under the terms of the GNU General Public License as
-# published by the Free Software Foundation; either version 2 of
-# the License, or (at your option) any later version.
-#
-# As a special exception to the GNU General Public License,
-# if you distribute this file as part of a program or library that
-# is built using GNU Libtool, you may include this file under the
-# same distribution terms that you use for the rest of that program.
+# As a special exception to the GNU General Public License, if you
+# distribute this file as part of a program or library that is built
+# using GNU Libtool, you may include this file under the same
+# distribution terms that you use for the rest of that program.
#
-# GNU Libtool is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# GNU Libtool is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
-# along with GNU Libtool; see the file COPYING. If not, a copy
-# can be downloaded from http://www.gnu.org/licenses/gpl.html, or
-# obtained by writing to the Free Software Foundation, Inc.,
-# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
# The names of the tagged configurations supported by this script.
-available_tags="CXX "
+available_tags='CXX '
+
+# Configured defaults for sys_lib_dlsearch_path munging.
+: \${LT_SYS_LIBRARY_PATH="$configure_time_lt_sys_library_path"}
# ### BEGIN LIBTOOL CONFIG
+# Which release of libtool.m4 was used?
+macro_version=$macro_version
+macro_revision=$macro_revision
+
# Whether or not to build shared libraries.
build_libtool_libs=$enable_shared
# Whether or not to build static libraries.
build_old_libs=$enable_static
-# Assembler program.
-AS=$lt_AS
-
-# DLL creation program.
-DLLTOOL=$lt_DLLTOOL
-
-# Object dumper program.
-OBJDUMP=$lt_OBJDUMP
-
-# Which release of libtool.m4 was used?
-macro_version=$macro_version
-macro_revision=$macro_revision
-
# What type of objects to build.
pic_mode=$pic_mode
# Whether or not to optimize for fast installation.
fast_install=$enable_fast_install
+# Shared archive member basename,for filename based shared library versioning on AIX.
+shared_archive_member_spec=$shared_archive_member_spec
+
# Shell to use when invoking shell scripts.
SHELL=$lt_SHELL
@@ -19601,6 +20350,9 @@ to_host_file_cmd=$lt_cv_to_host_file_cmd
# convert \$build files to toolchain format.
to_tool_file_cmd=$lt_cv_to_tool_file_cmd
+# An object symbol dumper.
+OBJDUMP=$lt_OBJDUMP
+
# Method to check whether dependent libraries are shared objects.
deplibs_check_method=$lt_deplibs_check_method
@@ -19613,6 +20365,9 @@ file_magic_glob=$lt_file_magic_glob
# Find potential files using nocaseglob when deplibs_check_method = "file_magic".
want_nocaseglob=$lt_want_nocaseglob
+# DLL creation program.
+DLLTOOL=$lt_DLLTOOL
+
# Command to associate shared and link libraries.
sharedlib_from_linklib_cmd=$lt_sharedlib_from_linklib_cmd
@@ -19648,18 +20403,27 @@ global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe
# Transform the output of nm in a proper C declaration.
global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl
+# Transform the output of nm into a list of symbols to manually relocate.
+global_symbol_to_import=$lt_lt_cv_sys_global_symbol_to_import
+
# Transform the output of nm in a C name address pair.
global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address
# Transform the output of nm in a C name address pair when lib prefix is needed.
global_symbol_to_c_name_address_lib_prefix=$lt_lt_cv_sys_global_symbol_to_c_name_address_lib_prefix
+# The name lister interface.
+nm_interface=$lt_lt_cv_nm_interface
+
# Specify filename containing input files for \$NM.
nm_file_list_spec=$lt_nm_file_list_spec
-# The root where to search for dependent libraries,and in which our libraries should be installed.
+# The root where to search for dependent libraries,and where our libraries should be installed.
lt_sysroot=$lt_sysroot
+# Command to truncate a binary pipe.
+lt_truncate_bin=$lt_lt_cv_truncate_bin
+
# The name of the directory that contains temporary libtool files.
objdir=$objdir
@@ -19750,8 +20514,11 @@ hardcode_into_libs=$hardcode_into_libs
# Compile-time system search path for libraries.
sys_lib_search_path_spec=$lt_sys_lib_search_path_spec
-# Run-time system search path for libraries.
-sys_lib_dlsearch_path_spec=$lt_sys_lib_dlsearch_path_spec
+# Detected run-time system search path for libraries.
+sys_lib_dlsearch_path_spec=$lt_configure_time_dlsearch_path
+
+# Explicit LT_SYS_LIBRARY_PATH set during ./configure time.
+configure_time_lt_sys_library_path=$lt_configure_time_lt_sys_library_path
# Whether dlopen is supported.
dlopen_support=$enable_dlopen
@@ -19766,6 +20533,9 @@ dlopen_self_static=$enable_dlopen_self_static
old_striplib=$lt_old_striplib
striplib=$lt_striplib
+# Assembler program.
+AS=$lt_AS
+
# The linker used to build libraries.
LD=$lt_LD
@@ -19844,13 +20614,13 @@ hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec
# Whether we need a single "-rpath" flag with a separated argument.
hardcode_libdir_separator=$lt_hardcode_libdir_separator
-# Set to "yes" if using DIR/libNAME\${shared_ext} during linking hardcodes
+# Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes
# DIR into the resulting binary.
hardcode_direct=$hardcode_direct
-# Set to "yes" if using DIR/libNAME\${shared_ext} during linking hardcodes
+# Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes
# DIR into the resulting binary and the resulting library dependency is
-# "absolute",i.e impossible to change by setting \${shlibpath_var} if the
+# "absolute",i.e impossible to change by setting \$shlibpath_var if the
# library is relocated.
hardcode_direct_absolute=$hardcode_direct_absolute
@@ -19916,13 +20686,72 @@ compiler_lib_search_path=$lt_compiler_lib_search_path
_LT_EOF
+ cat <<'_LT_EOF' >> "$cfgfile"
+
+# ### BEGIN FUNCTIONS SHARED WITH CONFIGURE
+
+# func_munge_path_list VARIABLE PATH
+# -----------------------------------
+# VARIABLE is name of variable containing _space_ separated list of
+# directories to be munged by the contents of PATH, which is string
+# having a format:
+# "DIR[:DIR]:"
+# string "DIR[ DIR]" will be prepended to VARIABLE
+# ":DIR[:DIR]"
+# string "DIR[ DIR]" will be appended to VARIABLE
+# "DIRP[:DIRP]::[DIRA:]DIRA"
+# string "DIRP[ DIRP]" will be prepended to VARIABLE and string
+# "DIRA[ DIRA]" will be appended to VARIABLE
+# "DIR[:DIR]"
+# VARIABLE will be replaced by "DIR[ DIR]"
+func_munge_path_list ()
+{
+ case x$2 in
+ x)
+ ;;
+ *:)
+ eval $1=\"`$ECHO $2 | $SED 's/:/ /g'` \$$1\"
+ ;;
+ x:*)
+ eval $1=\"\$$1 `$ECHO $2 | $SED 's/:/ /g'`\"
+ ;;
+ *::*)
+ eval $1=\"\$$1\ `$ECHO $2 | $SED -e 's/.*:://' -e 's/:/ /g'`\"
+ eval $1=\"`$ECHO $2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \$$1\"
+ ;;
+ *)
+ eval $1=\"`$ECHO $2 | $SED 's/:/ /g'`\"
+ ;;
+ esac
+}
+
+
+# Calculate cc_basename. Skip known compiler wrappers and cross-prefix.
+func_cc_basename ()
+{
+ for cc_temp in $*""; do
+ case $cc_temp in
+ compile | *[\\/]compile | ccache | *[\\/]ccache ) ;;
+ distcc | *[\\/]distcc | purify | *[\\/]purify ) ;;
+ \-*) ;;
+ *) break;;
+ esac
+ done
+ func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"`
+}
+
+
+# ### END FUNCTIONS SHARED WITH CONFIGURE
+
+_LT_EOF
+
case $host_os in
aix3*)
cat <<\_LT_EOF >> "$cfgfile"
# AIX sometimes has problems with the GCC collect2 program. For some
# reason, if we set the COLLECT_NAMES environment variable, the problems
# vanish in a puff of smoke.
-if test "X${COLLECT_NAMES+set}" != Xset; then
+if test set != "${COLLECT_NAMES+set}"; then
COLLECT_NAMES=
export COLLECT_NAMES
fi
@@ -19931,7 +20760,7 @@ _LT_EOF
esac
-ltmain="$ac_aux_dir/ltmain.sh"
+ltmain=$ac_aux_dir/ltmain.sh
# We use sed instead of cat because bash on DJGPP gets confused if
@@ -19941,165 +20770,6 @@ ltmain="$ac_aux_dir/ltmain.sh"
sed '$q' "$ltmain" >> "$cfgfile" \
|| (rm -f "$cfgfile"; exit 1)
- if test x"$xsi_shell" = xyes; then
- sed -e '/^func_dirname ()$/,/^} # func_dirname /c\
-func_dirname ()\
-{\
-\ case ${1} in\
-\ */*) func_dirname_result="${1%/*}${2}" ;;\
-\ * ) func_dirname_result="${3}" ;;\
-\ esac\
-} # Extended-shell func_dirname implementation' "$cfgfile" > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
- sed -e '/^func_basename ()$/,/^} # func_basename /c\
-func_basename ()\
-{\
-\ func_basename_result="${1##*/}"\
-} # Extended-shell func_basename implementation' "$cfgfile" > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
- sed -e '/^func_dirname_and_basename ()$/,/^} # func_dirname_and_basename /c\
-func_dirname_and_basename ()\
-{\
-\ case ${1} in\
-\ */*) func_dirname_result="${1%/*}${2}" ;;\
-\ * ) func_dirname_result="${3}" ;;\
-\ esac\
-\ func_basename_result="${1##*/}"\
-} # Extended-shell func_dirname_and_basename implementation' "$cfgfile" > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
- sed -e '/^func_stripname ()$/,/^} # func_stripname /c\
-func_stripname ()\
-{\
-\ # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are\
-\ # positional parameters, so assign one to ordinary parameter first.\
-\ func_stripname_result=${3}\
-\ func_stripname_result=${func_stripname_result#"${1}"}\
-\ func_stripname_result=${func_stripname_result%"${2}"}\
-} # Extended-shell func_stripname implementation' "$cfgfile" > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
- sed -e '/^func_split_long_opt ()$/,/^} # func_split_long_opt /c\
-func_split_long_opt ()\
-{\
-\ func_split_long_opt_name=${1%%=*}\
-\ func_split_long_opt_arg=${1#*=}\
-} # Extended-shell func_split_long_opt implementation' "$cfgfile" > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
- sed -e '/^func_split_short_opt ()$/,/^} # func_split_short_opt /c\
-func_split_short_opt ()\
-{\
-\ func_split_short_opt_arg=${1#??}\
-\ func_split_short_opt_name=${1%"$func_split_short_opt_arg"}\
-} # Extended-shell func_split_short_opt implementation' "$cfgfile" > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
- sed -e '/^func_lo2o ()$/,/^} # func_lo2o /c\
-func_lo2o ()\
-{\
-\ case ${1} in\
-\ *.lo) func_lo2o_result=${1%.lo}.${objext} ;;\
-\ *) func_lo2o_result=${1} ;;\
-\ esac\
-} # Extended-shell func_lo2o implementation' "$cfgfile" > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
- sed -e '/^func_xform ()$/,/^} # func_xform /c\
-func_xform ()\
-{\
- func_xform_result=${1%.*}.lo\
-} # Extended-shell func_xform implementation' "$cfgfile" > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
- sed -e '/^func_arith ()$/,/^} # func_arith /c\
-func_arith ()\
-{\
- func_arith_result=$(( $* ))\
-} # Extended-shell func_arith implementation' "$cfgfile" > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
- sed -e '/^func_len ()$/,/^} # func_len /c\
-func_len ()\
-{\
- func_len_result=${#1}\
-} # Extended-shell func_len implementation' "$cfgfile" > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-fi
-
-if test x"$lt_shell_append" = xyes; then
- sed -e '/^func_append ()$/,/^} # func_append /c\
-func_append ()\
-{\
- eval "${1}+=\\${2}"\
-} # Extended-shell func_append implementation' "$cfgfile" > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
- sed -e '/^func_append_quoted ()$/,/^} # func_append_quoted /c\
-func_append_quoted ()\
-{\
-\ func_quote_for_eval "${2}"\
-\ eval "${1}+=\\\\ \\$func_quote_for_eval_result"\
-} # Extended-shell func_append_quoted implementation' "$cfgfile" > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-
-
- # Save a `func_append' function call where possible by direct use of '+='
- sed -e 's%func_append \([a-zA-Z_]\{1,\}\) "%\1+="%g' $cfgfile > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
- test 0 -eq $? || _lt_function_replace_fail=:
-else
- # Save a `func_append' function call even when '+=' is not available
- sed -e 's%func_append \([a-zA-Z_]\{1,\}\) "%\1="$\1%g' $cfgfile > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
- test 0 -eq $? || _lt_function_replace_fail=:
-fi
-
-if test x"$_lt_function_replace_fail" = x":"; then
- { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: Unable to substitute extended shell functions in $ofile" >&5
-$as_echo "$as_me: WARNING: Unable to substitute extended shell functions in $ofile" >&2;}
-fi
-
-
mv -f "$cfgfile" "$ofile" ||
(rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile")
chmod +x "$ofile"
@@ -20186,13 +20856,13 @@ hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec_CXX
# Whether we need a single "-rpath" flag with a separated argument.
hardcode_libdir_separator=$lt_hardcode_libdir_separator_CXX
-# Set to "yes" if using DIR/libNAME\${shared_ext} during linking hardcodes
+# Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes
# DIR into the resulting binary.
hardcode_direct=$hardcode_direct_CXX
-# Set to "yes" if using DIR/libNAME\${shared_ext} during linking hardcodes
+# Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes
# DIR into the resulting binary and the resulting library dependency is
-# "absolute",i.e impossible to change by setting \${shlibpath_var} if the
+# "absolute",i.e impossible to change by setting \$shlibpath_var if the
# library is relocated.
hardcode_direct_absolute=$hardcode_direct_absolute_CXX
diff --git a/lcms2mt/configure.ac b/lcms2mt/configure.ac
index 439ca550..3597178e 100644
--- a/lcms2mt/configure.ac
+++ b/lcms2mt/configure.ac
@@ -33,6 +33,7 @@ AM_INIT_AUTOMAKE([foreign 1.9 tar-ustar no-define dist-zip subdir-objects])
AC_PROG_CC_STDC
AC_PROG_CPP
AC_PROG_CXX
+LT_INIT
#AM_PROG_LD
#AC_SUBST(LD)
@@ -80,6 +81,9 @@ AX_APPEND_COMPILE_FLAGS(["-fvisibility=hidden"])
# Motorola and SPARC CPUs), define `WORDS_BIGENDIAN'.
AC_C_BIGENDIAN
+# Check for functions that some compilers lack (or name differently)
+AC_CHECK_FUNCS([gmtime_r _gmtime64_s])
+
# Point to JPEG installed in DIR or disable JPEG with --without-jpeg.
AC_ARG_WITH(jpeg,
AS_HELP_STRING([--with-jpeg=DIR],[use jpeg installed in DIR]),
@@ -127,12 +131,15 @@ AC_ARG_WITH(fastfloat,
AS_HELP_STRING([--with-fastfloat],
[build and install fast_float plugin, use only if GPL 3.0 is acceptable]),
[
- with_fastfloat='yes'
- LIB_PLUGINS="$LIB_PLUGINS -llcms2_fast_float"
+ with_fastfloat=$withval
],
[
with_fastfloat='no'
])
+if test "$with_fastfloat" == "yes"
+then
+ LIB_PLUGINS="$LIB_PLUGINS -llcms2_fast_float"
+fi
#
# Determine POSIX threads settings
@@ -171,6 +178,19 @@ then
fi
fi
+# check if compiler supports SSE2 intrinsics
+AC_LANG_PUSH([C])
+
+AC_MSG_CHECKING([whether compiler supports SSE2])
+AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
+ #include <emmintrin.h>
+ main() { __m128i n = _mm_set1_epi8(42); }]])],
+ [ac_compiler_supports_sse2=yes], [ac_compiler_supports_sse2=no])
+AC_MSG_RESULT([$ac_compiler_supports_sse2])
+AS_IF([test "x$ac_compiler_supports_sse2" != "xyes"],
+ [AC_DEFINE([CMS_DONT_USE_SSE2], [1], [Define if compiler does not support SSE2 intrinsics])])
+
+AC_LANG_POP([C])
#
# Find math library
diff --git a/lcms2mt/depcomp b/lcms2mt/depcomp
index fc98710e..b39f98f9 100755
--- a/lcms2mt/depcomp
+++ b/lcms2mt/depcomp
@@ -1,9 +1,9 @@
#! /bin/sh
# depcomp - compile a program generating dependencies as side-effects
-scriptversion=2013-05-30.07; # UTC
+scriptversion=2016-01-11.22; # UTC
-# Copyright (C) 1999-2014 Free Software Foundation, Inc.
+# Copyright (C) 1999-2017 Free Software Foundation, Inc.
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
@@ -786,6 +786,6 @@ exit 0
# eval: (add-hook 'write-file-hooks 'time-stamp)
# time-stamp-start: "scriptversion="
# time-stamp-format: "%:y-%02m-%02d.%02H"
-# time-stamp-time-zone: "UTC"
+# time-stamp-time-zone: "UTC0"
# time-stamp-end: "; # UTC"
# End:
diff --git a/lcms2mt/doc/LittleCMS2.12 API.pdf b/lcms2mt/doc/LittleCMS2.12 API.pdf
new file mode 100644
index 00000000..2b34cda2
--- /dev/null
+++ b/lcms2mt/doc/LittleCMS2.12 API.pdf
Binary files differ
diff --git a/lcms2mt/doc/LittleCMS2.12 Plugin API.pdf b/lcms2mt/doc/LittleCMS2.12 Plugin API.pdf
new file mode 100644
index 00000000..1a5ed511
--- /dev/null
+++ b/lcms2mt/doc/LittleCMS2.12 Plugin API.pdf
Binary files differ
diff --git a/lcms2mt/doc/LittleCMS2.12 tutorial.pdf b/lcms2mt/doc/LittleCMS2.12 tutorial.pdf
new file mode 100644
index 00000000..779a39c9
--- /dev/null
+++ b/lcms2mt/doc/LittleCMS2.12 tutorial.pdf
Binary files differ
diff --git a/lcms2mt/include/Makefile.in b/lcms2mt/include/Makefile.in
index 40c86b7c..c6e1b88f 100644
--- a/lcms2mt/include/Makefile.in
+++ b/lcms2mt/include/Makefile.in
@@ -235,6 +235,7 @@ LIB_ZLIB = @LIB_ZLIB@
LIPO = @LIPO@
LN_S = @LN_S@
LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
MAINT = @MAINT@
MAKEINFO = @MAKEINFO@
MANIFEST_TOOL = @MANIFEST_TOOL@
diff --git a/lcms2mt/include/lcms2mt.h b/lcms2mt/include/lcms2mt.h
index a1652c34..d7515726 100644
--- a/lcms2mt/include/lcms2mt.h
+++ b/lcms2mt/include/lcms2mt.h
@@ -23,7 +23,7 @@
//
//---------------------------------------------------------------------------------
//
-// Version 2.12
+// Version 2.13alpha
//
#ifndef _lcms2mt_H
@@ -676,10 +676,11 @@ typedef void* cmsHTRANSFORM;
// Format of pixel is defined by one cmsUInt32Number, using bit fields as follows
//
-// 2 1 0
-// 543210 9 8 76543 2 1 0 9 8 7654 321
-// EEEEEE A O TTTTT Y F P X S CCCC BBB
+// 2 2222 1111 1111 11
+// 4 3210 9876 5432 1098 7654 3210
+// E EEEE EAOT TTTT YFPX SCCC CBBB
//
+// E: Extra samples
// A: Floating point -- With this flag we can differentiate 16 bits as float and as int
// O: Optimized -- previous optimization already returns the final 8-bit value
// T: Pixeltype
@@ -687,7 +688,6 @@ typedef void* cmsHTRANSFORM;
// P: Planar? 0=Chunky, 1=Planar
// X: swap 16 bps endianness?
// S: Do swap? ie, BGR, KYMC
-// E: Extra samples
// C: Channels (Samples per pixel)
// B: bytes per sample
// Y: Swap first - changes ABGR to BGRA and KCMY to CMYK
@@ -1661,6 +1661,9 @@ CMSAPI cmsUInt32Number CMSEXPORT cmsGetSupportedIntents(cmsContext ContextID,
// Copy alpha channels when transforming
#define cmsFLAGS_COPY_ALPHA 0x04000000 // Alpha channels are copied on cmsDoTransform()
+// Unpremultiply/premultiply by final alpha value when transforming
+#define cmsFLAGS_PREMULT 0x08000000 // Data is multiplied by final alpha channel on cmsDoTransform()
+
// Fine-tune control over number of gridpoints
#define cmsFLAGS_GRIDPOINTS(n) (((n) & 0xFF) << 16)
@@ -1862,6 +1865,8 @@ CMSAPI cmsBool CMSEXPORT cmsDetectDestinationBlackPoint(cmsContext Cont
// Estimate total area coverage
CMSAPI cmsFloat64Number CMSEXPORT cmsDetectTAC(cmsContext ContextID, cmsHPROFILE hProfile);
+// Estimate gamma space, alwasys positive. Returns -1 on error.
+CMSAPI cmsFloat64Number CMSEXPORT cmsDetectRGBProfileGamma(cmsContext ContextID, cmsHPROFILE hProfile, cmsFloat64Number thereshold);
// Poor man's gamut mapping
CMSAPI cmsBool CMSEXPORT cmsDesaturateLab(cmsContext ContextID, cmsCIELab* Lab,
diff --git a/lcms2mt/install-sh b/lcms2mt/install-sh
index 0b0fdcbb..8175c640 100755
--- a/lcms2mt/install-sh
+++ b/lcms2mt/install-sh
@@ -1,7 +1,7 @@
#!/bin/sh
# install - install a program, script, or datafile
-scriptversion=2013-12-25.23; # UTC
+scriptversion=2018-03-11.20; # UTC
# This originates from X11R5 (mit/util/scripts/install.sh), which was
# later released in X11R6 (xc/config/util/install.sh) with the
@@ -271,15 +271,18 @@ do
fi
dst=$dst_arg
- # If destination is a directory, append the input filename; won't work
- # if double slashes aren't ignored.
+ # If destination is a directory, append the input filename.
if test -d "$dst"; then
if test "$is_target_a_directory" = never; then
echo "$0: $dst_arg: Is a directory" >&2
exit 1
fi
dstdir=$dst
- dst=$dstdir/`basename "$src"`
+ dstbase=`basename "$src"`
+ case $dst in
+ */) dst=$dst$dstbase;;
+ *) dst=$dst/$dstbase;;
+ esac
dstdir_status=0
else
dstdir=`dirname "$dst"`
@@ -288,6 +291,11 @@ do
fi
fi
+ case $dstdir in
+ */) dstdirslash=$dstdir;;
+ *) dstdirslash=$dstdir/;;
+ esac
+
obsolete_mkdir_used=false
if test $dstdir_status != 0; then
@@ -324,34 +332,43 @@ do
# is incompatible with FreeBSD 'install' when (umask & 300) != 0.
;;
*)
+ # Note that $RANDOM variable is not portable (e.g. dash); Use it
+ # here however when possible just to lower collision chance.
tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$
- trap 'ret=$?; rmdir "$tmpdir/d" "$tmpdir" 2>/dev/null; exit $ret' 0
+ trap 'ret=$?; rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" 2>/dev/null; exit $ret' 0
+
+ # Because "mkdir -p" follows existing symlinks and we likely work
+ # directly in world-writeable /tmp, make sure that the '$tmpdir'
+ # directory is successfully created first before we actually test
+ # 'mkdir -p' feature.
if (umask $mkdir_umask &&
- exec $mkdirprog $mkdir_mode -p -- "$tmpdir/d") >/dev/null 2>&1
+ $mkdirprog $mkdir_mode "$tmpdir" &&
+ exec $mkdirprog $mkdir_mode -p -- "$tmpdir/a/b") >/dev/null 2>&1
then
if test -z "$dir_arg" || {
# Check for POSIX incompatibilities with -m.
# HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or
# other-writable bit of parent directory when it shouldn't.
# FreeBSD 6.1 mkdir -m -p sets mode of existing directory.
- ls_ld_tmpdir=`ls -ld "$tmpdir"`
+ test_tmpdir="$tmpdir/a"
+ ls_ld_tmpdir=`ls -ld "$test_tmpdir"`
case $ls_ld_tmpdir in
d????-?r-*) different_mode=700;;
d????-?--*) different_mode=755;;
*) false;;
esac &&
- $mkdirprog -m$different_mode -p -- "$tmpdir" && {
- ls_ld_tmpdir_1=`ls -ld "$tmpdir"`
+ $mkdirprog -m$different_mode -p -- "$test_tmpdir" && {
+ ls_ld_tmpdir_1=`ls -ld "$test_tmpdir"`
test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1"
}
}
then posix_mkdir=:
fi
- rmdir "$tmpdir/d" "$tmpdir"
+ rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir"
else
# Remove any dirs left behind by ancient mkdir implementations.
- rmdir ./$mkdir_mode ./-p ./-- 2>/dev/null
+ rmdir ./$mkdir_mode ./-p ./-- "$tmpdir" 2>/dev/null
fi
trap '' 0;;
esac;;
@@ -427,8 +444,8 @@ do
else
# Make a couple of temp file names in the proper directory.
- dsttmp=$dstdir/_inst.$$_
- rmtmp=$dstdir/_rm.$$_
+ dsttmp=${dstdirslash}_inst.$$_
+ rmtmp=${dstdirslash}_rm.$$_
# Trap to clean up those temp files at exit.
trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0
@@ -493,9 +510,9 @@ do
done
# Local variables:
-# eval: (add-hook 'write-file-hooks 'time-stamp)
+# eval: (add-hook 'before-save-hook 'time-stamp)
# time-stamp-start: "scriptversion="
# time-stamp-format: "%:y-%02m-%02d.%02H"
-# time-stamp-time-zone: "UTC"
+# time-stamp-time-zone: "UTC0"
# time-stamp-end: "; # UTC"
# End:
diff --git a/lcms2mt/lcms2mt.pc.in b/lcms2mt/lcms2mt.pc.in
index a2839830..f1ec7b4a 100644
--- a/lcms2mt/lcms2mt.pc.in
+++ b/lcms2mt/lcms2mt.pc.in
@@ -6,6 +6,6 @@ includedir=@includedir@
Name: @PACKAGE@
Description: LCMS Color Management Library
Version: @VERSION@
-Libs: -L${libdir} -llcms2 @LIB_PLUGINS@
+Libs: -L${libdir} -llcms2mt @LIB_PLUGINS@
Libs.private: @LIB_MATH@ @LIB_THREAD@
Cflags: -I${includedir}
diff --git a/lcms2mt/ltmain.sh b/lcms2mt/ltmain.sh
index 1b425a27..a736cf99 100755
--- a/lcms2mt/ltmain.sh
+++ b/lcms2mt/ltmain.sh
@@ -1,9 +1,12 @@
+#! /bin/sh
+## DO NOT EDIT - This file generated from ./build-aux/ltmain.in
+## by inline-source v2014-01-03.01
-# libtool (GNU libtool) 2.4.2
+# libtool (GNU libtool) 2.4.6
+# Provide generalized library-building support services.
# Written by Gordon Matzigkeit <gord@gnu.ai.mit.edu>, 1996
-# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005, 2006,
-# 2007, 2008, 2009, 2010, 2011 Free Software Foundation, Inc.
+# Copyright (C) 1996-2015 Free Software Foundation, Inc.
# This is free software; see the source for copying conditions. There is NO
# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
@@ -23,881 +26,2112 @@
# General Public License for more details.
#
# You should have received a copy of the GNU General Public License
-# along with GNU Libtool; see the file COPYING. If not, a copy
-# can be downloaded from http://www.gnu.org/licenses/gpl.html,
-# or obtained by writing to the Free Software Foundation, Inc.,
-# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
-# Usage: $progname [OPTION]... [MODE-ARG]...
-#
-# Provide generalized library-building support services.
-#
-# --config show all configuration variables
-# --debug enable verbose shell tracing
-# -n, --dry-run display commands without modifying any files
-# --features display basic configuration information and exit
-# --mode=MODE use operation mode MODE
-# --preserve-dup-deps don't remove duplicate dependency libraries
-# --quiet, --silent don't print informational messages
-# --no-quiet, --no-silent
-# print informational messages (default)
-# --no-warn don't display warning messages
-# --tag=TAG use configuration variables from tag TAG
-# -v, --verbose print more informational messages than default
-# --no-verbose don't print the extra informational messages
-# --version print version information
-# -h, --help, --help-all print short, long, or detailed help message
-#
-# MODE must be one of the following:
-#
-# clean remove files from the build directory
-# compile compile a source file into a libtool object
-# execute automatically set library path, then run a program
-# finish complete the installation of libtool libraries
-# install install libraries or executables
-# link create a library or an executable
-# uninstall remove libraries from an installed directory
-#
-# MODE-ARGS vary depending on the MODE. When passed as first option,
-# `--mode=MODE' may be abbreviated as `MODE' or a unique abbreviation of that.
-# Try `$progname --help --mode=MODE' for a more detailed description of MODE.
-#
-# When reporting a bug, please describe a test case to reproduce it and
-# include the following information:
-#
-# host-triplet: $host
-# shell: $SHELL
-# compiler: $LTCC
-# compiler flags: $LTCFLAGS
-# linker: $LD (gnu? $with_gnu_ld)
-# $progname: (GNU libtool) 2.4.2
-# automake: $automake_version
-# autoconf: $autoconf_version
-#
-# Report bugs to <bug-libtool@gnu.org>.
-# GNU libtool home page: <http://www.gnu.org/software/libtool/>.
-# General help using GNU software: <http://www.gnu.org/gethelp/>.
PROGRAM=libtool
PACKAGE=libtool
-VERSION=2.4.2
-TIMESTAMP=""
-package_revision=1.3337
+VERSION="2.4.6 Debian-2.4.6-2"
+package_revision=2.4.6
-# Be Bourne compatible
-if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then
+
+## ------ ##
+## Usage. ##
+## ------ ##
+
+# Run './libtool --help' for help with using this script from the
+# command line.
+
+
+## ------------------------------- ##
+## User overridable command paths. ##
+## ------------------------------- ##
+
+# After configure completes, it has a better idea of some of the
+# shell tools we need than the defaults used by the functions shared
+# with bootstrap, so set those here where they can still be over-
+# ridden by the user, but otherwise take precedence.
+
+: ${AUTOCONF="autoconf"}
+: ${AUTOMAKE="automake"}
+
+
+## -------------------------- ##
+## Source external libraries. ##
+## -------------------------- ##
+
+# Much of our low-level functionality needs to be sourced from external
+# libraries, which are installed to $pkgauxdir.
+
+# Set a version string for this script.
+scriptversion=2015-01-20.17; # UTC
+
+# General shell script boiler plate, and helper functions.
+# Written by Gary V. Vaughan, 2004
+
+# Copyright (C) 2004-2015 Free Software Foundation, Inc.
+# This is free software; see the source for copying conditions. There is NO
+# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+
+# As a special exception to the GNU General Public License, if you distribute
+# this file as part of a program or library that is built using GNU Libtool,
+# you may include this file under the same distribution terms that you use
+# for the rest of that program.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNES FOR A PARTICULAR PURPOSE. See the GNU
+# General Public License for more details.
+
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+# Please report bugs or propose patches to gary@gnu.org.
+
+
+## ------ ##
+## Usage. ##
+## ------ ##
+
+# Evaluate this file near the top of your script to gain access to
+# the functions and variables defined here:
+#
+# . `echo "$0" | ${SED-sed} 's|[^/]*$||'`/build-aux/funclib.sh
+#
+# If you need to override any of the default environment variable
+# settings, do that before evaluating this file.
+
+
+## -------------------- ##
+## Shell normalisation. ##
+## -------------------- ##
+
+# Some shells need a little help to be as Bourne compatible as possible.
+# Before doing anything else, make sure all that help has been provided!
+
+DUALCASE=1; export DUALCASE # for MKS sh
+if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then :
emulate sh
NULLCMD=:
- # Zsh 3.x and 4.x performs word splitting on ${1+"$@"}, which
+ # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which
# is contrary to our usage. Disable this feature.
alias -g '${1+"$@"}'='"$@"'
setopt NO_GLOB_SUBST
else
- case `(set -o) 2>/dev/null` in *posix*) set -o posix;; esac
+ case `(set -o) 2>/dev/null` in *posix*) set -o posix ;; esac
fi
-BIN_SH=xpg4; export BIN_SH # for Tru64
-DUALCASE=1; export DUALCASE # for MKS sh
-# A function that is used when there is no print builtin or printf.
-func_fallback_echo ()
-{
- eval 'cat <<_LTECHO_EOF
-$1
-_LTECHO_EOF'
-}
-
-# NLS nuisances: We save the old values to restore during execute mode.
-lt_user_locale=
-lt_safe_locale=
-for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES
+# NLS nuisances: We save the old values in case they are required later.
+_G_user_locale=
+_G_safe_locale=
+for _G_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES
do
- eval "if test \"\${$lt_var+set}\" = set; then
- save_$lt_var=\$$lt_var
- $lt_var=C
- export $lt_var
- lt_user_locale=\"$lt_var=\\\$save_\$lt_var; \$lt_user_locale\"
- lt_safe_locale=\"$lt_var=C; \$lt_safe_locale\"
+ eval "if test set = \"\${$_G_var+set}\"; then
+ save_$_G_var=\$$_G_var
+ $_G_var=C
+ export $_G_var
+ _G_user_locale=\"$_G_var=\\\$save_\$_G_var; \$_G_user_locale\"
+ _G_safe_locale=\"$_G_var=C; \$_G_safe_locale\"
fi"
done
-LC_ALL=C
-LANGUAGE=C
-export LANGUAGE LC_ALL
-$lt_unset CDPATH
+# CDPATH.
+(unset CDPATH) >/dev/null 2>&1 && unset CDPATH
+
+# Make sure IFS has a sensible default
+sp=' '
+nl='
+'
+IFS="$sp $nl"
+
+# There are apparently some retarded systems that use ';' as a PATH separator!
+if test "${PATH_SEPARATOR+set}" != set; then
+ PATH_SEPARATOR=:
+ (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && {
+ (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 ||
+ PATH_SEPARATOR=';'
+ }
+fi
+
-# Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh
-# is ksh but when the shell is invoked as "sh" and the current value of
-# the _XPG environment variable is not equal to 1 (one), the special
-# positional parameter $0, within a function call, is the name of the
-# function.
-progpath="$0"
+## ------------------------- ##
+## Locate command utilities. ##
+## ------------------------- ##
+
+# func_executable_p FILE
+# ----------------------
+# Check that FILE is an executable regular file.
+func_executable_p ()
+{
+ test -f "$1" && test -x "$1"
+}
+
+
+# func_path_progs PROGS_LIST CHECK_FUNC [PATH]
+# --------------------------------------------
+# Search for either a program that responds to --version with output
+# containing "GNU", or else returned by CHECK_FUNC otherwise, by
+# trying all the directories in PATH with each of the elements of
+# PROGS_LIST.
+#
+# CHECK_FUNC should accept the path to a candidate program, and
+# set $func_check_prog_result if it truncates its output less than
+# $_G_path_prog_max characters.
+func_path_progs ()
+{
+ _G_progs_list=$1
+ _G_check_func=$2
+ _G_PATH=${3-"$PATH"}
+
+ _G_path_prog_max=0
+ _G_path_prog_found=false
+ _G_save_IFS=$IFS; IFS=${PATH_SEPARATOR-:}
+ for _G_dir in $_G_PATH; do
+ IFS=$_G_save_IFS
+ test -z "$_G_dir" && _G_dir=.
+ for _G_prog_name in $_G_progs_list; do
+ for _exeext in '' .EXE; do
+ _G_path_prog=$_G_dir/$_G_prog_name$_exeext
+ func_executable_p "$_G_path_prog" || continue
+ case `"$_G_path_prog" --version 2>&1` in
+ *GNU*) func_path_progs_result=$_G_path_prog _G_path_prog_found=: ;;
+ *) $_G_check_func $_G_path_prog
+ func_path_progs_result=$func_check_prog_result
+ ;;
+ esac
+ $_G_path_prog_found && break 3
+ done
+ done
+ done
+ IFS=$_G_save_IFS
+ test -z "$func_path_progs_result" && {
+ echo "no acceptable sed could be found in \$PATH" >&2
+ exit 1
+ }
+}
+
+
+# We want to be able to use the functions in this file before configure
+# has figured out where the best binaries are kept, which means we have
+# to search for them ourselves - except when the results are already set
+# where we skip the searches.
+
+# Unless the user overrides by setting SED, search the path for either GNU
+# sed, or the sed that truncates its output the least.
+test -z "$SED" && {
+ _G_sed_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/
+ for _G_i in 1 2 3 4 5 6 7; do
+ _G_sed_script=$_G_sed_script$nl$_G_sed_script
+ done
+ echo "$_G_sed_script" 2>/dev/null | sed 99q >conftest.sed
+ _G_sed_script=
+
+ func_check_prog_sed ()
+ {
+ _G_path_prog=$1
+ _G_count=0
+ printf 0123456789 >conftest.in
+ while :
+ do
+ cat conftest.in conftest.in >conftest.tmp
+ mv conftest.tmp conftest.in
+ cp conftest.in conftest.nl
+ echo '' >> conftest.nl
+ "$_G_path_prog" -f conftest.sed <conftest.nl >conftest.out 2>/dev/null || break
+ diff conftest.out conftest.nl >/dev/null 2>&1 || break
+ _G_count=`expr $_G_count + 1`
+ if test "$_G_count" -gt "$_G_path_prog_max"; then
+ # Best one so far, save it but keep looking for a better one
+ func_check_prog_result=$_G_path_prog
+ _G_path_prog_max=$_G_count
+ fi
+ # 10*(2^10) chars as input seems more than enough
+ test 10 -lt "$_G_count" && break
+ done
+ rm -f conftest.in conftest.tmp conftest.nl conftest.out
+ }
+
+ func_path_progs "sed gsed" func_check_prog_sed $PATH:/usr/xpg4/bin
+ rm -f conftest.sed
+ SED=$func_path_progs_result
+}
+
+
+# Unless the user overrides by setting GREP, search the path for either GNU
+# grep, or the grep that truncates its output the least.
+test -z "$GREP" && {
+ func_check_prog_grep ()
+ {
+ _G_path_prog=$1
+
+ _G_count=0
+ _G_path_prog_max=0
+ printf 0123456789 >conftest.in
+ while :
+ do
+ cat conftest.in conftest.in >conftest.tmp
+ mv conftest.tmp conftest.in
+ cp conftest.in conftest.nl
+ echo 'GREP' >> conftest.nl
+ "$_G_path_prog" -e 'GREP$' -e '-(cannot match)-' <conftest.nl >conftest.out 2>/dev/null || break
+ diff conftest.out conftest.nl >/dev/null 2>&1 || break
+ _G_count=`expr $_G_count + 1`
+ if test "$_G_count" -gt "$_G_path_prog_max"; then
+ # Best one so far, save it but keep looking for a better one
+ func_check_prog_result=$_G_path_prog
+ _G_path_prog_max=$_G_count
+ fi
+ # 10*(2^10) chars as input seems more than enough
+ test 10 -lt "$_G_count" && break
+ done
+ rm -f conftest.in conftest.tmp conftest.nl conftest.out
+ }
+
+ func_path_progs "grep ggrep" func_check_prog_grep $PATH:/usr/xpg4/bin
+ GREP=$func_path_progs_result
+}
+
+
+## ------------------------------- ##
+## User overridable command paths. ##
+## ------------------------------- ##
+
+# All uppercase variable names are used for environment variables. These
+# variables can be overridden by the user before calling a script that
+# uses them if a suitable command of that name is not already available
+# in the command search PATH.
: ${CP="cp -f"}
-test "${ECHO+set}" = set || ECHO=${as_echo-'printf %s\n'}
+: ${ECHO="printf %s\n"}
+: ${EGREP="$GREP -E"}
+: ${FGREP="$GREP -F"}
+: ${LN_S="ln -s"}
: ${MAKE="make"}
: ${MKDIR="mkdir"}
: ${MV="mv -f"}
: ${RM="rm -f"}
: ${SHELL="${CONFIG_SHELL-/bin/sh}"}
-: ${Xsed="$SED -e 1s/^X//"}
-# Global variables:
-EXIT_SUCCESS=0
-EXIT_FAILURE=1
-EXIT_MISMATCH=63 # $? = 63 is used to indicate version mismatch to missing.
-EXIT_SKIP=77 # $? = 77 is used to indicate a skipped test to automake.
-exit_status=$EXIT_SUCCESS
-
-# Make sure IFS has a sensible default
-lt_nl='
-'
-IFS=" $lt_nl"
+## -------------------- ##
+## Useful sed snippets. ##
+## -------------------- ##
-dirname="s,/[^/]*$,,"
-basename="s,^.*/,,"
+sed_dirname='s|/[^/]*$||'
+sed_basename='s|^.*/||'
-# func_dirname file append nondir_replacement
-# Compute the dirname of FILE. If nonempty, add APPEND to the result,
-# otherwise set result to NONDIR_REPLACEMENT.
-func_dirname ()
-{
- func_dirname_result=`$ECHO "${1}" | $SED "$dirname"`
- if test "X$func_dirname_result" = "X${1}"; then
- func_dirname_result="${3}"
- else
- func_dirname_result="$func_dirname_result${2}"
- fi
-} # func_dirname may be replaced by extended shell implementation
-
-
-# func_basename file
-func_basename ()
-{
- func_basename_result=`$ECHO "${1}" | $SED "$basename"`
-} # func_basename may be replaced by extended shell implementation
+# Sed substitution that helps us do robust quoting. It backslashifies
+# metacharacters that are still active within double-quoted strings.
+sed_quote_subst='s|\([`"$\\]\)|\\\1|g'
+# Same as above, but do not quote variable references.
+sed_double_quote_subst='s/\(["`\\]\)/\\\1/g'
-# func_dirname_and_basename file append nondir_replacement
-# perform func_basename and func_dirname in a single function
-# call:
-# dirname: Compute the dirname of FILE. If nonempty,
-# add APPEND to the result, otherwise set result
-# to NONDIR_REPLACEMENT.
-# value returned in "$func_dirname_result"
-# basename: Compute filename of FILE.
-# value returned in "$func_basename_result"
-# Implementation must be kept synchronized with func_dirname
-# and func_basename. For efficiency, we do not delegate to
-# those functions but instead duplicate the functionality here.
-func_dirname_and_basename ()
-{
- # Extract subdirectory from the argument.
- func_dirname_result=`$ECHO "${1}" | $SED -e "$dirname"`
- if test "X$func_dirname_result" = "X${1}"; then
- func_dirname_result="${3}"
- else
- func_dirname_result="$func_dirname_result${2}"
- fi
- func_basename_result=`$ECHO "${1}" | $SED -e "$basename"`
-} # func_dirname_and_basename may be replaced by extended shell implementation
+# Sed substitution that turns a string into a regex matching for the
+# string literally.
+sed_make_literal_regex='s|[].[^$\\*\/]|\\&|g'
+# Sed substitution that converts a w32 file name or path
+# that contains forward slashes, into one that contains
+# (escaped) backslashes. A very naive implementation.
+sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g'
+
+# Re-'\' parameter expansions in output of sed_double_quote_subst that
+# were '\'-ed in input to the same. If an odd number of '\' preceded a
+# '$' in input to sed_double_quote_subst, that '$' was protected from
+# expansion. Since each input '\' is now two '\'s, look for any number
+# of runs of four '\'s followed by two '\'s and then a '$'. '\' that '$'.
+_G_bs='\\'
+_G_bs2='\\\\'
+_G_bs4='\\\\\\\\'
+_G_dollar='\$'
+sed_double_backslash="\
+ s/$_G_bs4/&\\
+/g
+ s/^$_G_bs2$_G_dollar/$_G_bs&/
+ s/\\([^$_G_bs]\\)$_G_bs2$_G_dollar/\\1$_G_bs2$_G_bs$_G_dollar/g
+ s/\n//g"
-# func_stripname prefix suffix name
-# strip PREFIX and SUFFIX off of NAME.
-# PREFIX and SUFFIX must not contain globbing or regex special
-# characters, hashes, percent signs, but SUFFIX may contain a leading
-# dot (in which case that matches only a dot).
-# func_strip_suffix prefix name
-func_stripname ()
-{
- case ${2} in
- .*) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%\\\\${2}\$%%"`;;
- *) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%${2}\$%%"`;;
- esac
-} # func_stripname may be replaced by extended shell implementation
+## ----------------- ##
+## Global variables. ##
+## ----------------- ##
-# These SED scripts presuppose an absolute path with a trailing slash.
-pathcar='s,^/\([^/]*\).*$,\1,'
-pathcdr='s,^/[^/]*,,'
-removedotparts=':dotsl
- s@/\./@/@g
- t dotsl
- s,/\.$,/,'
-collapseslashes='s@/\{1,\}@/@g'
-finalslash='s,/*$,/,'
+# Except for the global variables explicitly listed below, the following
+# functions in the '^func_' namespace, and the '^require_' namespace
+# variables initialised in the 'Resource management' section, sourcing
+# this file will not pollute your global namespace with anything
+# else. There's no portable way to scope variables in Bourne shell
+# though, so actually running these functions will sometimes place
+# results into a variable named after the function, and often use
+# temporary variables in the '^_G_' namespace. If you are careful to
+# avoid using those namespaces casually in your sourcing script, things
+# should continue to work as you expect. And, of course, you can freely
+# overwrite any of the functions or variables defined here before
+# calling anything to customize them.
-# func_normal_abspath PATH
-# Remove doubled-up and trailing slashes, "." path components,
-# and cancel out any ".." path components in PATH after making
-# it an absolute path.
-# value returned in "$func_normal_abspath_result"
-func_normal_abspath ()
-{
- # Start from root dir and reassemble the path.
- func_normal_abspath_result=
- func_normal_abspath_tpath=$1
- func_normal_abspath_altnamespace=
- case $func_normal_abspath_tpath in
- "")
- # Empty path, that just means $cwd.
- func_stripname '' '/' "`pwd`"
- func_normal_abspath_result=$func_stripname_result
- return
- ;;
- # The next three entries are used to spot a run of precisely
- # two leading slashes without using negated character classes;
- # we take advantage of case's first-match behaviour.
- ///*)
- # Unusual form of absolute path, do nothing.
- ;;
- //*)
- # Not necessarily an ordinary path; POSIX reserves leading '//'
- # and for example Cygwin uses it to access remote file shares
- # over CIFS/SMB, so we conserve a leading double slash if found.
- func_normal_abspath_altnamespace=/
- ;;
- /*)
- # Absolute path, do nothing.
- ;;
- *)
- # Relative path, prepend $cwd.
- func_normal_abspath_tpath=`pwd`/$func_normal_abspath_tpath
- ;;
- esac
- # Cancel out all the simple stuff to save iterations. We also want
- # the path to end with a slash for ease of parsing, so make sure
- # there is one (and only one) here.
- func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \
- -e "$removedotparts" -e "$collapseslashes" -e "$finalslash"`
- while :; do
- # Processed it all yet?
- if test "$func_normal_abspath_tpath" = / ; then
- # If we ascended to the root using ".." the result may be empty now.
- if test -z "$func_normal_abspath_result" ; then
- func_normal_abspath_result=/
- fi
- break
- fi
- func_normal_abspath_tcomponent=`$ECHO "$func_normal_abspath_tpath" | $SED \
- -e "$pathcar"`
- func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \
- -e "$pathcdr"`
- # Figure out what to do with it
- case $func_normal_abspath_tcomponent in
- "")
- # Trailing empty path component, ignore it.
- ;;
- ..)
- # Parent dir; strip last assembled component from result.
- func_dirname "$func_normal_abspath_result"
- func_normal_abspath_result=$func_dirname_result
- ;;
- *)
- # Actual path component, append it.
- func_normal_abspath_result=$func_normal_abspath_result/$func_normal_abspath_tcomponent
- ;;
- esac
- done
- # Restore leading double-slash if one was found on entry.
- func_normal_abspath_result=$func_normal_abspath_altnamespace$func_normal_abspath_result
-}
+EXIT_SUCCESS=0
+EXIT_FAILURE=1
+EXIT_MISMATCH=63 # $? = 63 is used to indicate version mismatch to missing.
+EXIT_SKIP=77 # $? = 77 is used to indicate a skipped test to automake.
-# func_relative_path SRCDIR DSTDIR
-# generates a relative path from SRCDIR to DSTDIR, with a trailing
-# slash if non-empty, suitable for immediately appending a filename
-# without needing to append a separator.
-# value returned in "$func_relative_path_result"
-func_relative_path ()
-{
- func_relative_path_result=
- func_normal_abspath "$1"
- func_relative_path_tlibdir=$func_normal_abspath_result
- func_normal_abspath "$2"
- func_relative_path_tbindir=$func_normal_abspath_result
-
- # Ascend the tree starting from libdir
- while :; do
- # check if we have found a prefix of bindir
- case $func_relative_path_tbindir in
- $func_relative_path_tlibdir)
- # found an exact match
- func_relative_path_tcancelled=
- break
- ;;
- $func_relative_path_tlibdir*)
- # found a matching prefix
- func_stripname "$func_relative_path_tlibdir" '' "$func_relative_path_tbindir"
- func_relative_path_tcancelled=$func_stripname_result
- if test -z "$func_relative_path_result"; then
- func_relative_path_result=.
- fi
- break
- ;;
- *)
- func_dirname $func_relative_path_tlibdir
- func_relative_path_tlibdir=${func_dirname_result}
- if test "x$func_relative_path_tlibdir" = x ; then
- # Have to descend all the way to the root!
- func_relative_path_result=../$func_relative_path_result
- func_relative_path_tcancelled=$func_relative_path_tbindir
- break
- fi
- func_relative_path_result=../$func_relative_path_result
- ;;
- esac
- done
+# Allow overriding, eg assuming that you follow the convention of
+# putting '$debug_cmd' at the start of all your functions, you can get
+# bash to show function call trace with:
+#
+# debug_cmd='eval echo "${FUNCNAME[0]} $*" >&2' bash your-script-name
+debug_cmd=${debug_cmd-":"}
+exit_cmd=:
- # Now calculate path; take care to avoid doubling-up slashes.
- func_stripname '' '/' "$func_relative_path_result"
- func_relative_path_result=$func_stripname_result
- func_stripname '/' '/' "$func_relative_path_tcancelled"
- if test "x$func_stripname_result" != x ; then
- func_relative_path_result=${func_relative_path_result}/${func_stripname_result}
- fi
+# By convention, finish your script with:
+#
+# exit $exit_status
+#
+# so that you can set exit_status to non-zero if you want to indicate
+# something went wrong during execution without actually bailing out at
+# the point of failure.
+exit_status=$EXIT_SUCCESS
- # Normalisation. If bindir is libdir, return empty string,
- # else relative path ending with a slash; either way, target
- # file name can be directly appended.
- if test ! -z "$func_relative_path_result"; then
- func_stripname './' '' "$func_relative_path_result/"
- func_relative_path_result=$func_stripname_result
- fi
-}
+# Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh
+# is ksh but when the shell is invoked as "sh" and the current value of
+# the _XPG environment variable is not equal to 1 (one), the special
+# positional parameter $0, within a function call, is the name of the
+# function.
+progpath=$0
-# The name of this program:
-func_dirname_and_basename "$progpath"
-progname=$func_basename_result
+# The name of this program.
+progname=`$ECHO "$progpath" |$SED "$sed_basename"`
-# Make sure we have an absolute path for reexecution:
+# Make sure we have an absolute progpath for reexecution:
case $progpath in
[\\/]*|[A-Za-z]:\\*) ;;
*[\\/]*)
- progdir=$func_dirname_result
+ progdir=`$ECHO "$progpath" |$SED "$sed_dirname"`
progdir=`cd "$progdir" && pwd`
- progpath="$progdir/$progname"
+ progpath=$progdir/$progname
;;
*)
- save_IFS="$IFS"
+ _G_IFS=$IFS
IFS=${PATH_SEPARATOR-:}
for progdir in $PATH; do
- IFS="$save_IFS"
+ IFS=$_G_IFS
test -x "$progdir/$progname" && break
done
- IFS="$save_IFS"
+ IFS=$_G_IFS
test -n "$progdir" || progdir=`pwd`
- progpath="$progdir/$progname"
+ progpath=$progdir/$progname
;;
esac
-# Sed substitution that helps us do robust quoting. It backslashifies
-# metacharacters that are still active within double-quoted strings.
-Xsed="${SED}"' -e 1s/^X//'
-sed_quote_subst='s/\([`"$\\]\)/\\\1/g'
-# Same as above, but do not quote variable references.
-double_quote_subst='s/\(["`\\]\)/\\\1/g'
+## ----------------- ##
+## Standard options. ##
+## ----------------- ##
-# Sed substitution that turns a string into a regex matching for the
-# string literally.
-sed_make_literal_regex='s,[].[^$\\*\/],\\&,g'
+# The following options affect the operation of the functions defined
+# below, and should be set appropriately depending on run-time para-
+# meters passed on the command line.
-# Sed substitution that converts a w32 file name or path
-# which contains forward slashes, into one that contains
-# (escaped) backslashes. A very naive implementation.
-lt_sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g'
-
-# Re-`\' parameter expansions in output of double_quote_subst that were
-# `\'-ed in input to the same. If an odd number of `\' preceded a '$'
-# in input to double_quote_subst, that '$' was protected from expansion.
-# Since each input `\' is now two `\'s, look for any number of runs of
-# four `\'s followed by two `\'s and then a '$'. `\' that '$'.
-bs='\\'
-bs2='\\\\'
-bs4='\\\\\\\\'
-dollar='\$'
-sed_double_backslash="\
- s/$bs4/&\\
-/g
- s/^$bs2$dollar/$bs&/
- s/\\([^$bs]\\)$bs2$dollar/\\1$bs2$bs$dollar/g
- s/\n//g"
-
-# Standard options:
opt_dry_run=false
-opt_help=false
opt_quiet=false
opt_verbose=false
-opt_warning=:
-# func_echo arg...
-# Echo program name prefixed message, along with the current mode
-# name if it has been set yet.
-func_echo ()
+# Categories 'all' and 'none' are always available. Append any others
+# you will pass as the first argument to func_warning from your own
+# code.
+warning_categories=
+
+# By default, display warnings according to 'opt_warning_types'. Set
+# 'warning_func' to ':' to elide all warnings, or func_fatal_error to
+# treat the next displayed warning as a fatal error.
+warning_func=func_warn_and_continue
+
+# Set to 'all' to display all warnings, 'none' to suppress all
+# warnings, or a space delimited list of some subset of
+# 'warning_categories' to display only the listed warnings.
+opt_warning_types=all
+
+
+## -------------------- ##
+## Resource management. ##
+## -------------------- ##
+
+# This section contains definitions for functions that each ensure a
+# particular resource (a file, or a non-empty configuration variable for
+# example) is available, and if appropriate to extract default values
+# from pertinent package files. Call them using their associated
+# 'require_*' variable to ensure that they are executed, at most, once.
+#
+# It's entirely deliberate that calling these functions can set
+# variables that don't obey the namespace limitations obeyed by the rest
+# of this file, in order that that they be as useful as possible to
+# callers.
+
+
+# require_term_colors
+# -------------------
+# Allow display of bold text on terminals that support it.
+require_term_colors=func_require_term_colors
+func_require_term_colors ()
{
- $ECHO "$progname: ${opt_mode+$opt_mode: }$*"
+ $debug_cmd
+
+ test -t 1 && {
+ # COLORTERM and USE_ANSI_COLORS environment variables take
+ # precedence, because most terminfo databases neglect to describe
+ # whether color sequences are supported.
+ test -n "${COLORTERM+set}" && : ${USE_ANSI_COLORS="1"}
+
+ if test 1 = "$USE_ANSI_COLORS"; then
+ # Standard ANSI escape sequences
+ tc_reset=''
+ tc_bold=''; tc_standout=''
+ tc_red=''; tc_green=''
+ tc_blue=''; tc_cyan=''
+ else
+ # Otherwise trust the terminfo database after all.
+ test -n "`tput sgr0 2>/dev/null`" && {
+ tc_reset=`tput sgr0`
+ test -n "`tput bold 2>/dev/null`" && tc_bold=`tput bold`
+ tc_standout=$tc_bold
+ test -n "`tput smso 2>/dev/null`" && tc_standout=`tput smso`
+ test -n "`tput setaf 1 2>/dev/null`" && tc_red=`tput setaf 1`
+ test -n "`tput setaf 2 2>/dev/null`" && tc_green=`tput setaf 2`
+ test -n "`tput setaf 4 2>/dev/null`" && tc_blue=`tput setaf 4`
+ test -n "`tput setaf 5 2>/dev/null`" && tc_cyan=`tput setaf 5`
+ }
+ fi
+ }
+
+ require_term_colors=:
}
-# func_verbose arg...
-# Echo program name prefixed message in verbose mode only.
-func_verbose ()
+
+## ----------------- ##
+## Function library. ##
+## ----------------- ##
+
+# This section contains a variety of useful functions to call in your
+# scripts. Take note of the portable wrappers for features provided by
+# some modern shells, which will fall back to slower equivalents on
+# less featureful shells.
+
+
+# func_append VAR VALUE
+# ---------------------
+# Append VALUE onto the existing contents of VAR.
+
+ # We should try to minimise forks, especially on Windows where they are
+ # unreasonably slow, so skip the feature probes when bash or zsh are
+ # being used:
+ if test set = "${BASH_VERSION+set}${ZSH_VERSION+set}"; then
+ : ${_G_HAVE_ARITH_OP="yes"}
+ : ${_G_HAVE_XSI_OPS="yes"}
+ # The += operator was introduced in bash 3.1
+ case $BASH_VERSION in
+ [12].* | 3.0 | 3.0*) ;;
+ *)
+ : ${_G_HAVE_PLUSEQ_OP="yes"}
+ ;;
+ esac
+ fi
+
+ # _G_HAVE_PLUSEQ_OP
+ # Can be empty, in which case the shell is probed, "yes" if += is
+ # useable or anything else if it does not work.
+ test -z "$_G_HAVE_PLUSEQ_OP" \
+ && (eval 'x=a; x+=" b"; test "a b" = "$x"') 2>/dev/null \
+ && _G_HAVE_PLUSEQ_OP=yes
+
+if test yes = "$_G_HAVE_PLUSEQ_OP"
+then
+ # This is an XSI compatible shell, allowing a faster implementation...
+ eval 'func_append ()
+ {
+ $debug_cmd
+
+ eval "$1+=\$2"
+ }'
+else
+ # ...otherwise fall back to using expr, which is often a shell builtin.
+ func_append ()
+ {
+ $debug_cmd
+
+ eval "$1=\$$1\$2"
+ }
+fi
+
+
+# func_append_quoted VAR VALUE
+# ----------------------------
+# Quote VALUE and append to the end of shell variable VAR, separated
+# by a space.
+if test yes = "$_G_HAVE_PLUSEQ_OP"; then
+ eval 'func_append_quoted ()
+ {
+ $debug_cmd
+
+ func_quote_for_eval "$2"
+ eval "$1+=\\ \$func_quote_for_eval_result"
+ }'
+else
+ func_append_quoted ()
+ {
+ $debug_cmd
+
+ func_quote_for_eval "$2"
+ eval "$1=\$$1\\ \$func_quote_for_eval_result"
+ }
+fi
+
+
+# func_append_uniq VAR VALUE
+# --------------------------
+# Append unique VALUE onto the existing contents of VAR, assuming
+# entries are delimited by the first character of VALUE. For example:
+#
+# func_append_uniq options " --another-option option-argument"
+#
+# will only append to $options if " --another-option option-argument "
+# is not already present somewhere in $options already (note spaces at
+# each end implied by leading space in second argument).
+func_append_uniq ()
{
- $opt_verbose && func_echo ${1+"$@"}
+ $debug_cmd
- # A bug in bash halts the script if the last line of a function
- # fails when set -e is in force, so we need another command to
- # work around that:
- :
+ eval _G_current_value='`$ECHO $'$1'`'
+ _G_delim=`expr "$2" : '\(.\)'`
+
+ case $_G_delim$_G_current_value$_G_delim in
+ *"$2$_G_delim"*) ;;
+ *) func_append "$@" ;;
+ esac
}
-# func_echo_all arg...
+
+# func_arith TERM...
+# ------------------
+# Set func_arith_result to the result of evaluating TERMs.
+ test -z "$_G_HAVE_ARITH_OP" \
+ && (eval 'test 2 = $(( 1 + 1 ))') 2>/dev/null \
+ && _G_HAVE_ARITH_OP=yes
+
+if test yes = "$_G_HAVE_ARITH_OP"; then
+ eval 'func_arith ()
+ {
+ $debug_cmd
+
+ func_arith_result=$(( $* ))
+ }'
+else
+ func_arith ()
+ {
+ $debug_cmd
+
+ func_arith_result=`expr "$@"`
+ }
+fi
+
+
+# func_basename FILE
+# ------------------
+# Set func_basename_result to FILE with everything up to and including
+# the last / stripped.
+if test yes = "$_G_HAVE_XSI_OPS"; then
+ # If this shell supports suffix pattern removal, then use it to avoid
+ # forking. Hide the definitions single quotes in case the shell chokes
+ # on unsupported syntax...
+ _b='func_basename_result=${1##*/}'
+ _d='case $1 in
+ */*) func_dirname_result=${1%/*}$2 ;;
+ * ) func_dirname_result=$3 ;;
+ esac'
+
+else
+ # ...otherwise fall back to using sed.
+ _b='func_basename_result=`$ECHO "$1" |$SED "$sed_basename"`'
+ _d='func_dirname_result=`$ECHO "$1" |$SED "$sed_dirname"`
+ if test "X$func_dirname_result" = "X$1"; then
+ func_dirname_result=$3
+ else
+ func_append func_dirname_result "$2"
+ fi'
+fi
+
+eval 'func_basename ()
+{
+ $debug_cmd
+
+ '"$_b"'
+}'
+
+
+# func_dirname FILE APPEND NONDIR_REPLACEMENT
+# -------------------------------------------
+# Compute the dirname of FILE. If nonempty, add APPEND to the result,
+# otherwise set result to NONDIR_REPLACEMENT.
+eval 'func_dirname ()
+{
+ $debug_cmd
+
+ '"$_d"'
+}'
+
+
+# func_dirname_and_basename FILE APPEND NONDIR_REPLACEMENT
+# --------------------------------------------------------
+# Perform func_basename and func_dirname in a single function
+# call:
+# dirname: Compute the dirname of FILE. If nonempty,
+# add APPEND to the result, otherwise set result
+# to NONDIR_REPLACEMENT.
+# value returned in "$func_dirname_result"
+# basename: Compute filename of FILE.
+# value retuned in "$func_basename_result"
+# For efficiency, we do not delegate to the functions above but instead
+# duplicate the functionality here.
+eval 'func_dirname_and_basename ()
+{
+ $debug_cmd
+
+ '"$_b"'
+ '"$_d"'
+}'
+
+
+# func_echo ARG...
+# ----------------
+# Echo program name prefixed message.
+func_echo ()
+{
+ $debug_cmd
+
+ _G_message=$*
+
+ func_echo_IFS=$IFS
+ IFS=$nl
+ for _G_line in $_G_message; do
+ IFS=$func_echo_IFS
+ $ECHO "$progname: $_G_line"
+ done
+ IFS=$func_echo_IFS
+}
+
+
+# func_echo_all ARG...
+# --------------------
# Invoke $ECHO with all args, space-separated.
func_echo_all ()
{
$ECHO "$*"
}
-# func_error arg...
-# Echo program name prefixed message to standard error.
-func_error ()
+
+# func_echo_infix_1 INFIX ARG...
+# ------------------------------
+# Echo program name, followed by INFIX on the first line, with any
+# additional lines not showing INFIX.
+func_echo_infix_1 ()
{
- $ECHO "$progname: ${opt_mode+$opt_mode: }"${1+"$@"} 1>&2
+ $debug_cmd
+
+ $require_term_colors
+
+ _G_infix=$1; shift
+ _G_indent=$_G_infix
+ _G_prefix="$progname: $_G_infix: "
+ _G_message=$*
+
+ # Strip color escape sequences before counting printable length
+ for _G_tc in "$tc_reset" "$tc_bold" "$tc_standout" "$tc_red" "$tc_green" "$tc_blue" "$tc_cyan"
+ do
+ test -n "$_G_tc" && {
+ _G_esc_tc=`$ECHO "$_G_tc" | $SED "$sed_make_literal_regex"`
+ _G_indent=`$ECHO "$_G_indent" | $SED "s|$_G_esc_tc||g"`
+ }
+ done
+ _G_indent="$progname: "`echo "$_G_indent" | $SED 's|.| |g'`" " ## exclude from sc_prohibit_nested_quotes
+
+ func_echo_infix_1_IFS=$IFS
+ IFS=$nl
+ for _G_line in $_G_message; do
+ IFS=$func_echo_infix_1_IFS
+ $ECHO "$_G_prefix$tc_bold$_G_line$tc_reset" >&2
+ _G_prefix=$_G_indent
+ done
+ IFS=$func_echo_infix_1_IFS
}
-# func_warning arg...
-# Echo program name prefixed warning message to standard error.
-func_warning ()
+
+# func_error ARG...
+# -----------------
+# Echo program name prefixed message to standard error.
+func_error ()
{
- $opt_warning && $ECHO "$progname: ${opt_mode+$opt_mode: }warning: "${1+"$@"} 1>&2
+ $debug_cmd
- # bash bug again:
- :
+ $require_term_colors
+
+ func_echo_infix_1 " $tc_standout${tc_red}error$tc_reset" "$*" >&2
}
-# func_fatal_error arg...
+
+# func_fatal_error ARG...
+# -----------------------
# Echo program name prefixed message to standard error, and exit.
func_fatal_error ()
{
- func_error ${1+"$@"}
- exit $EXIT_FAILURE
-}
+ $debug_cmd
-# func_fatal_help arg...
-# Echo program name prefixed message to standard error, followed by
-# a help hint, and exit.
-func_fatal_help ()
-{
- func_error ${1+"$@"}
- func_fatal_error "$help"
+ func_error "$*"
+ exit $EXIT_FAILURE
}
-help="Try \`$progname --help' for more information." ## default
-# func_grep expression filename
+# func_grep EXPRESSION FILENAME
+# -----------------------------
# Check whether EXPRESSION matches any line of FILENAME, without output.
func_grep ()
{
+ $debug_cmd
+
$GREP "$1" "$2" >/dev/null 2>&1
}
-# func_mkdir_p directory-path
+# func_len STRING
+# ---------------
+# Set func_len_result to the length of STRING. STRING may not
+# start with a hyphen.
+ test -z "$_G_HAVE_XSI_OPS" \
+ && (eval 'x=a/b/c;
+ test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \
+ && _G_HAVE_XSI_OPS=yes
+
+if test yes = "$_G_HAVE_XSI_OPS"; then
+ eval 'func_len ()
+ {
+ $debug_cmd
+
+ func_len_result=${#1}
+ }'
+else
+ func_len ()
+ {
+ $debug_cmd
+
+ func_len_result=`expr "$1" : ".*" 2>/dev/null || echo $max_cmd_len`
+ }
+fi
+
+
+# func_mkdir_p DIRECTORY-PATH
+# ---------------------------
# Make sure the entire path to DIRECTORY-PATH is available.
func_mkdir_p ()
{
- my_directory_path="$1"
- my_dir_list=
+ $debug_cmd
- if test -n "$my_directory_path" && test "$opt_dry_run" != ":"; then
+ _G_directory_path=$1
+ _G_dir_list=
- # Protect directory names starting with `-'
- case $my_directory_path in
- -*) my_directory_path="./$my_directory_path" ;;
+ if test -n "$_G_directory_path" && test : != "$opt_dry_run"; then
+
+ # Protect directory names starting with '-'
+ case $_G_directory_path in
+ -*) _G_directory_path=./$_G_directory_path ;;
esac
# While some portion of DIR does not yet exist...
- while test ! -d "$my_directory_path"; do
+ while test ! -d "$_G_directory_path"; do
# ...make a list in topmost first order. Use a colon delimited
# list incase some portion of path contains whitespace.
- my_dir_list="$my_directory_path:$my_dir_list"
+ _G_dir_list=$_G_directory_path:$_G_dir_list
# If the last portion added has no slash in it, the list is done
- case $my_directory_path in */*) ;; *) break ;; esac
+ case $_G_directory_path in */*) ;; *) break ;; esac
# ...otherwise throw away the child directory and loop
- my_directory_path=`$ECHO "$my_directory_path" | $SED -e "$dirname"`
+ _G_directory_path=`$ECHO "$_G_directory_path" | $SED -e "$sed_dirname"`
done
- my_dir_list=`$ECHO "$my_dir_list" | $SED 's,:*$,,'`
+ _G_dir_list=`$ECHO "$_G_dir_list" | $SED 's|:*$||'`
- save_mkdir_p_IFS="$IFS"; IFS=':'
- for my_dir in $my_dir_list; do
- IFS="$save_mkdir_p_IFS"
- # mkdir can fail with a `File exist' error if two processes
+ func_mkdir_p_IFS=$IFS; IFS=:
+ for _G_dir in $_G_dir_list; do
+ IFS=$func_mkdir_p_IFS
+ # mkdir can fail with a 'File exist' error if two processes
# try to create one of the directories concurrently. Don't
# stop in that case!
- $MKDIR "$my_dir" 2>/dev/null || :
+ $MKDIR "$_G_dir" 2>/dev/null || :
done
- IFS="$save_mkdir_p_IFS"
+ IFS=$func_mkdir_p_IFS
# Bail out if we (or some other process) failed to create a directory.
- test -d "$my_directory_path" || \
- func_fatal_error "Failed to create \`$1'"
+ test -d "$_G_directory_path" || \
+ func_fatal_error "Failed to create '$1'"
fi
}
-# func_mktempdir [string]
+# func_mktempdir [BASENAME]
+# -------------------------
# Make a temporary directory that won't clash with other running
# libtool processes, and avoids race conditions if possible. If
-# given, STRING is the basename for that directory.
+# given, BASENAME is the basename for that directory.
func_mktempdir ()
{
- my_template="${TMPDIR-/tmp}/${1-$progname}"
+ $debug_cmd
+
+ _G_template=${TMPDIR-/tmp}/${1-$progname}
- if test "$opt_dry_run" = ":"; then
+ if test : = "$opt_dry_run"; then
# Return a directory name, but don't create it in dry-run mode
- my_tmpdir="${my_template}-$$"
+ _G_tmpdir=$_G_template-$$
else
# If mktemp works, use that first and foremost
- my_tmpdir=`mktemp -d "${my_template}-XXXXXXXX" 2>/dev/null`
+ _G_tmpdir=`mktemp -d "$_G_template-XXXXXXXX" 2>/dev/null`
- if test ! -d "$my_tmpdir"; then
+ if test ! -d "$_G_tmpdir"; then
# Failing that, at least try and use $RANDOM to avoid a race
- my_tmpdir="${my_template}-${RANDOM-0}$$"
+ _G_tmpdir=$_G_template-${RANDOM-0}$$
- save_mktempdir_umask=`umask`
+ func_mktempdir_umask=`umask`
umask 0077
- $MKDIR "$my_tmpdir"
- umask $save_mktempdir_umask
+ $MKDIR "$_G_tmpdir"
+ umask $func_mktempdir_umask
fi
# If we're not in dry-run mode, bomb out on failure
- test -d "$my_tmpdir" || \
- func_fatal_error "cannot create temporary directory \`$my_tmpdir'"
+ test -d "$_G_tmpdir" || \
+ func_fatal_error "cannot create temporary directory '$_G_tmpdir'"
fi
- $ECHO "$my_tmpdir"
+ $ECHO "$_G_tmpdir"
}
-# func_quote_for_eval arg
-# Aesthetically quote ARG to be evaled later.
-# This function returns two values: FUNC_QUOTE_FOR_EVAL_RESULT
-# is double-quoted, suitable for a subsequent eval, whereas
-# FUNC_QUOTE_FOR_EVAL_UNQUOTED_RESULT has merely all characters
-# which are still active within double quotes backslashified.
-func_quote_for_eval ()
+# func_normal_abspath PATH
+# ------------------------
+# Remove doubled-up and trailing slashes, "." path components,
+# and cancel out any ".." path components in PATH after making
+# it an absolute path.
+func_normal_abspath ()
{
- case $1 in
- *[\\\`\"\$]*)
- func_quote_for_eval_unquoted_result=`$ECHO "$1" | $SED "$sed_quote_subst"` ;;
- *)
- func_quote_for_eval_unquoted_result="$1" ;;
- esac
+ $debug_cmd
- case $func_quote_for_eval_unquoted_result in
- # Double-quote args containing shell metacharacters to delay
- # word splitting, command substitution and and variable
- # expansion for a subsequent eval.
- # Many Bourne shells cannot handle close brackets correctly
- # in scan sets, so we specify it separately.
- *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- func_quote_for_eval_result="\"$func_quote_for_eval_unquoted_result\""
+ # These SED scripts presuppose an absolute path with a trailing slash.
+ _G_pathcar='s|^/\([^/]*\).*$|\1|'
+ _G_pathcdr='s|^/[^/]*||'
+ _G_removedotparts=':dotsl
+ s|/\./|/|g
+ t dotsl
+ s|/\.$|/|'
+ _G_collapseslashes='s|/\{1,\}|/|g'
+ _G_finalslash='s|/*$|/|'
+
+ # Start from root dir and reassemble the path.
+ func_normal_abspath_result=
+ func_normal_abspath_tpath=$1
+ func_normal_abspath_altnamespace=
+ case $func_normal_abspath_tpath in
+ "")
+ # Empty path, that just means $cwd.
+ func_stripname '' '/' "`pwd`"
+ func_normal_abspath_result=$func_stripname_result
+ return
+ ;;
+ # The next three entries are used to spot a run of precisely
+ # two leading slashes without using negated character classes;
+ # we take advantage of case's first-match behaviour.
+ ///*)
+ # Unusual form of absolute path, do nothing.
+ ;;
+ //*)
+ # Not necessarily an ordinary path; POSIX reserves leading '//'
+ # and for example Cygwin uses it to access remote file shares
+ # over CIFS/SMB, so we conserve a leading double slash if found.
+ func_normal_abspath_altnamespace=/
+ ;;
+ /*)
+ # Absolute path, do nothing.
;;
*)
- func_quote_for_eval_result="$func_quote_for_eval_unquoted_result"
+ # Relative path, prepend $cwd.
+ func_normal_abspath_tpath=`pwd`/$func_normal_abspath_tpath
+ ;;
esac
+
+ # Cancel out all the simple stuff to save iterations. We also want
+ # the path to end with a slash for ease of parsing, so make sure
+ # there is one (and only one) here.
+ func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \
+ -e "$_G_removedotparts" -e "$_G_collapseslashes" -e "$_G_finalslash"`
+ while :; do
+ # Processed it all yet?
+ if test / = "$func_normal_abspath_tpath"; then
+ # If we ascended to the root using ".." the result may be empty now.
+ if test -z "$func_normal_abspath_result"; then
+ func_normal_abspath_result=/
+ fi
+ break
+ fi
+ func_normal_abspath_tcomponent=`$ECHO "$func_normal_abspath_tpath" | $SED \
+ -e "$_G_pathcar"`
+ func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \
+ -e "$_G_pathcdr"`
+ # Figure out what to do with it
+ case $func_normal_abspath_tcomponent in
+ "")
+ # Trailing empty path component, ignore it.
+ ;;
+ ..)
+ # Parent dir; strip last assembled component from result.
+ func_dirname "$func_normal_abspath_result"
+ func_normal_abspath_result=$func_dirname_result
+ ;;
+ *)
+ # Actual path component, append it.
+ func_append func_normal_abspath_result "/$func_normal_abspath_tcomponent"
+ ;;
+ esac
+ done
+ # Restore leading double-slash if one was found on entry.
+ func_normal_abspath_result=$func_normal_abspath_altnamespace$func_normal_abspath_result
}
-# func_quote_for_expand arg
+# func_notquiet ARG...
+# --------------------
+# Echo program name prefixed message only when not in quiet mode.
+func_notquiet ()
+{
+ $debug_cmd
+
+ $opt_quiet || func_echo ${1+"$@"}
+
+ # A bug in bash halts the script if the last line of a function
+ # fails when set -e is in force, so we need another command to
+ # work around that:
+ :
+}
+
+
+# func_relative_path SRCDIR DSTDIR
+# --------------------------------
+# Set func_relative_path_result to the relative path from SRCDIR to DSTDIR.
+func_relative_path ()
+{
+ $debug_cmd
+
+ func_relative_path_result=
+ func_normal_abspath "$1"
+ func_relative_path_tlibdir=$func_normal_abspath_result
+ func_normal_abspath "$2"
+ func_relative_path_tbindir=$func_normal_abspath_result
+
+ # Ascend the tree starting from libdir
+ while :; do
+ # check if we have found a prefix of bindir
+ case $func_relative_path_tbindir in
+ $func_relative_path_tlibdir)
+ # found an exact match
+ func_relative_path_tcancelled=
+ break
+ ;;
+ $func_relative_path_tlibdir*)
+ # found a matching prefix
+ func_stripname "$func_relative_path_tlibdir" '' "$func_relative_path_tbindir"
+ func_relative_path_tcancelled=$func_stripname_result
+ if test -z "$func_relative_path_result"; then
+ func_relative_path_result=.
+ fi
+ break
+ ;;
+ *)
+ func_dirname $func_relative_path_tlibdir
+ func_relative_path_tlibdir=$func_dirname_result
+ if test -z "$func_relative_path_tlibdir"; then
+ # Have to descend all the way to the root!
+ func_relative_path_result=../$func_relative_path_result
+ func_relative_path_tcancelled=$func_relative_path_tbindir
+ break
+ fi
+ func_relative_path_result=../$func_relative_path_result
+ ;;
+ esac
+ done
+
+ # Now calculate path; take care to avoid doubling-up slashes.
+ func_stripname '' '/' "$func_relative_path_result"
+ func_relative_path_result=$func_stripname_result
+ func_stripname '/' '/' "$func_relative_path_tcancelled"
+ if test -n "$func_stripname_result"; then
+ func_append func_relative_path_result "/$func_stripname_result"
+ fi
+
+ # Normalisation. If bindir is libdir, return '.' else relative path.
+ if test -n "$func_relative_path_result"; then
+ func_stripname './' '' "$func_relative_path_result"
+ func_relative_path_result=$func_stripname_result
+ fi
+
+ test -n "$func_relative_path_result" || func_relative_path_result=.
+
+ :
+}
+
+
+# func_quote_for_eval ARG...
+# --------------------------
+# Aesthetically quote ARGs to be evaled later.
+# This function returns two values:
+# i) func_quote_for_eval_result
+# double-quoted, suitable for a subsequent eval
+# ii) func_quote_for_eval_unquoted_result
+# has all characters that are still active within double
+# quotes backslashified.
+func_quote_for_eval ()
+{
+ $debug_cmd
+
+ func_quote_for_eval_unquoted_result=
+ func_quote_for_eval_result=
+ while test 0 -lt $#; do
+ case $1 in
+ *[\\\`\"\$]*)
+ _G_unquoted_arg=`printf '%s\n' "$1" |$SED "$sed_quote_subst"` ;;
+ *)
+ _G_unquoted_arg=$1 ;;
+ esac
+ if test -n "$func_quote_for_eval_unquoted_result"; then
+ func_append func_quote_for_eval_unquoted_result " $_G_unquoted_arg"
+ else
+ func_append func_quote_for_eval_unquoted_result "$_G_unquoted_arg"
+ fi
+
+ case $_G_unquoted_arg in
+ # Double-quote args containing shell metacharacters to delay
+ # word splitting, command substitution and variable expansion
+ # for a subsequent eval.
+ # Many Bourne shells cannot handle close brackets correctly
+ # in scan sets, so we specify it separately.
+ *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
+ _G_quoted_arg=\"$_G_unquoted_arg\"
+ ;;
+ *)
+ _G_quoted_arg=$_G_unquoted_arg
+ ;;
+ esac
+
+ if test -n "$func_quote_for_eval_result"; then
+ func_append func_quote_for_eval_result " $_G_quoted_arg"
+ else
+ func_append func_quote_for_eval_result "$_G_quoted_arg"
+ fi
+ shift
+ done
+}
+
+
+# func_quote_for_expand ARG
+# -------------------------
# Aesthetically quote ARG to be evaled later; same as above,
# but do not quote variable references.
func_quote_for_expand ()
{
+ $debug_cmd
+
case $1 in
*[\\\`\"]*)
- my_arg=`$ECHO "$1" | $SED \
- -e "$double_quote_subst" -e "$sed_double_backslash"` ;;
+ _G_arg=`$ECHO "$1" | $SED \
+ -e "$sed_double_quote_subst" -e "$sed_double_backslash"` ;;
*)
- my_arg="$1" ;;
+ _G_arg=$1 ;;
esac
- case $my_arg in
+ case $_G_arg in
# Double-quote args containing shell metacharacters to delay
# word splitting and command substitution for a subsequent eval.
# Many Bourne shells cannot handle close brackets correctly
# in scan sets, so we specify it separately.
*[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"")
- my_arg="\"$my_arg\""
+ _G_arg=\"$_G_arg\"
;;
esac
- func_quote_for_expand_result="$my_arg"
+ func_quote_for_expand_result=$_G_arg
}
-# func_show_eval cmd [fail_exp]
-# Unless opt_silent is true, then output CMD. Then, if opt_dryrun is
+# func_stripname PREFIX SUFFIX NAME
+# ---------------------------------
+# strip PREFIX and SUFFIX from NAME, and store in func_stripname_result.
+# PREFIX and SUFFIX must not contain globbing or regex special
+# characters, hashes, percent signs, but SUFFIX may contain a leading
+# dot (in which case that matches only a dot).
+if test yes = "$_G_HAVE_XSI_OPS"; then
+ eval 'func_stripname ()
+ {
+ $debug_cmd
+
+ # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are
+ # positional parameters, so assign one to ordinary variable first.
+ func_stripname_result=$3
+ func_stripname_result=${func_stripname_result#"$1"}
+ func_stripname_result=${func_stripname_result%"$2"}
+ }'
+else
+ func_stripname ()
+ {
+ $debug_cmd
+
+ case $2 in
+ .*) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%\\\\$2\$%%"`;;
+ *) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%$2\$%%"`;;
+ esac
+ }
+fi
+
+
+# func_show_eval CMD [FAIL_EXP]
+# -----------------------------
+# Unless opt_quiet is true, then output CMD. Then, if opt_dryrun is
# not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP
# is given, then evaluate it.
func_show_eval ()
{
- my_cmd="$1"
- my_fail_exp="${2-:}"
+ $debug_cmd
- ${opt_silent-false} || {
- func_quote_for_expand "$my_cmd"
- eval "func_echo $func_quote_for_expand_result"
- }
+ _G_cmd=$1
+ _G_fail_exp=${2-':'}
+
+ func_quote_for_expand "$_G_cmd"
+ eval "func_notquiet $func_quote_for_expand_result"
- if ${opt_dry_run-false}; then :; else
- eval "$my_cmd"
- my_status=$?
- if test "$my_status" -eq 0; then :; else
- eval "(exit $my_status); $my_fail_exp"
+ $opt_dry_run || {
+ eval "$_G_cmd"
+ _G_status=$?
+ if test 0 -ne "$_G_status"; then
+ eval "(exit $_G_status); $_G_fail_exp"
fi
- fi
+ }
}
-# func_show_eval_locale cmd [fail_exp]
-# Unless opt_silent is true, then output CMD. Then, if opt_dryrun is
+# func_show_eval_locale CMD [FAIL_EXP]
+# ------------------------------------
+# Unless opt_quiet is true, then output CMD. Then, if opt_dryrun is
# not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP
# is given, then evaluate it. Use the saved locale for evaluation.
func_show_eval_locale ()
{
- my_cmd="$1"
- my_fail_exp="${2-:}"
+ $debug_cmd
+
+ _G_cmd=$1
+ _G_fail_exp=${2-':'}
- ${opt_silent-false} || {
- func_quote_for_expand "$my_cmd"
+ $opt_quiet || {
+ func_quote_for_expand "$_G_cmd"
eval "func_echo $func_quote_for_expand_result"
}
- if ${opt_dry_run-false}; then :; else
- eval "$lt_user_locale
- $my_cmd"
- my_status=$?
- eval "$lt_safe_locale"
- if test "$my_status" -eq 0; then :; else
- eval "(exit $my_status); $my_fail_exp"
+ $opt_dry_run || {
+ eval "$_G_user_locale
+ $_G_cmd"
+ _G_status=$?
+ eval "$_G_safe_locale"
+ if test 0 -ne "$_G_status"; then
+ eval "(exit $_G_status); $_G_fail_exp"
fi
- fi
+ }
}
+
# func_tr_sh
+# ----------
# Turn $1 into a string suitable for a shell variable name.
# Result is stored in $func_tr_sh_result. All characters
# not in the set a-zA-Z0-9_ are replaced with '_'. Further,
# if $1 begins with a digit, a '_' is prepended as well.
func_tr_sh ()
{
- case $1 in
- [0-9]* | *[!a-zA-Z0-9_]*)
- func_tr_sh_result=`$ECHO "$1" | $SED 's/^\([0-9]\)/_\1/; s/[^a-zA-Z0-9_]/_/g'`
- ;;
- * )
- func_tr_sh_result=$1
- ;;
- esac
+ $debug_cmd
+
+ case $1 in
+ [0-9]* | *[!a-zA-Z0-9_]*)
+ func_tr_sh_result=`$ECHO "$1" | $SED -e 's/^\([0-9]\)/_\1/' -e 's/[^a-zA-Z0-9_]/_/g'`
+ ;;
+ * )
+ func_tr_sh_result=$1
+ ;;
+ esac
}
-# func_version
-# Echo version message to standard output and exit.
-func_version ()
+# func_verbose ARG...
+# -------------------
+# Echo program name prefixed message in verbose mode only.
+func_verbose ()
{
- $opt_debug
+ $debug_cmd
- $SED -n '/(C)/!b go
- :more
- /\./!{
- N
- s/\n# / /
- b more
- }
- :go
- /^# '$PROGRAM' (GNU /,/# warranty; / {
- s/^# //
- s/^# *$//
- s/\((C)\)[ 0-9,-]*\( [1-9][0-9]*\)/\1\2/
- p
- }' < "$progpath"
- exit $?
+ $opt_verbose && func_echo "$*"
+
+ :
}
-# func_usage
-# Echo short help message to standard output and exit.
-func_usage ()
+
+# func_warn_and_continue ARG...
+# -----------------------------
+# Echo program name prefixed warning message to standard error.
+func_warn_and_continue ()
{
- $opt_debug
+ $debug_cmd
- $SED -n '/^# Usage:/,/^# *.*--help/ {
- s/^# //
- s/^# *$//
- s/\$progname/'$progname'/
- p
- }' < "$progpath"
- echo
- $ECHO "run \`$progname --help | more' for full usage"
- exit $?
+ $require_term_colors
+
+ func_echo_infix_1 "${tc_red}warning$tc_reset" "$*" >&2
+}
+
+
+# func_warning CATEGORY ARG...
+# ----------------------------
+# Echo program name prefixed warning message to standard error. Warning
+# messages can be filtered according to CATEGORY, where this function
+# elides messages where CATEGORY is not listed in the global variable
+# 'opt_warning_types'.
+func_warning ()
+{
+ $debug_cmd
+
+ # CATEGORY must be in the warning_categories list!
+ case " $warning_categories " in
+ *" $1 "*) ;;
+ *) func_internal_error "invalid warning category '$1'" ;;
+ esac
+
+ _G_category=$1
+ shift
+
+ case " $opt_warning_types " in
+ *" $_G_category "*) $warning_func ${1+"$@"} ;;
+ esac
+}
+
+
+# func_sort_ver VER1 VER2
+# -----------------------
+# 'sort -V' is not generally available.
+# Note this deviates from the version comparison in automake
+# in that it treats 1.5 < 1.5.0, and treats 1.4.4a < 1.4-p3a
+# but this should suffice as we won't be specifying old
+# version formats or redundant trailing .0 in bootstrap.conf.
+# If we did want full compatibility then we should probably
+# use m4_version_compare from autoconf.
+func_sort_ver ()
+{
+ $debug_cmd
+
+ printf '%s\n%s\n' "$1" "$2" \
+ | sort -t. -k 1,1n -k 2,2n -k 3,3n -k 4,4n -k 5,5n -k 6,6n -k 7,7n -k 8,8n -k 9,9n
+}
+
+# func_lt_ver PREV CURR
+# ---------------------
+# Return true if PREV and CURR are in the correct order according to
+# func_sort_ver, otherwise false. Use it like this:
+#
+# func_lt_ver "$prev_ver" "$proposed_ver" || func_fatal_error "..."
+func_lt_ver ()
+{
+ $debug_cmd
+
+ test "x$1" = x`func_sort_ver "$1" "$2" | $SED 1q`
+}
+
+
+# Local variables:
+# mode: shell-script
+# sh-indentation: 2
+# eval: (add-hook 'before-save-hook 'time-stamp)
+# time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC"
+# time-stamp-time-zone: "UTC"
+# End:
+#! /bin/sh
+
+# Set a version string for this script.
+scriptversion=2014-01-07.03; # UTC
+
+# A portable, pluggable option parser for Bourne shell.
+# Written by Gary V. Vaughan, 2010
+
+# Copyright (C) 2010-2015 Free Software Foundation, Inc.
+# This is free software; see the source for copying conditions. There is NO
+# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
+
+# Please report bugs or propose patches to gary@gnu.org.
+
+
+## ------ ##
+## Usage. ##
+## ------ ##
+
+# This file is a library for parsing options in your shell scripts along
+# with assorted other useful supporting features that you can make use
+# of too.
+#
+# For the simplest scripts you might need only:
+#
+# #!/bin/sh
+# . relative/path/to/funclib.sh
+# . relative/path/to/options-parser
+# scriptversion=1.0
+# func_options ${1+"$@"}
+# eval set dummy "$func_options_result"; shift
+# ...rest of your script...
+#
+# In order for the '--version' option to work, you will need to have a
+# suitably formatted comment like the one at the top of this file
+# starting with '# Written by ' and ending with '# warranty; '.
+#
+# For '-h' and '--help' to work, you will also need a one line
+# description of your script's purpose in a comment directly above the
+# '# Written by ' line, like the one at the top of this file.
+#
+# The default options also support '--debug', which will turn on shell
+# execution tracing (see the comment above debug_cmd below for another
+# use), and '--verbose' and the func_verbose function to allow your script
+# to display verbose messages only when your user has specified
+# '--verbose'.
+#
+# After sourcing this file, you can plug processing for additional
+# options by amending the variables from the 'Configuration' section
+# below, and following the instructions in the 'Option parsing'
+# section further down.
+
+## -------------- ##
+## Configuration. ##
+## -------------- ##
+
+# You should override these variables in your script after sourcing this
+# file so that they reflect the customisations you have added to the
+# option parser.
+
+# The usage line for option parsing errors and the start of '-h' and
+# '--help' output messages. You can embed shell variables for delayed
+# expansion at the time the message is displayed, but you will need to
+# quote other shell meta-characters carefully to prevent them being
+# expanded when the contents are evaled.
+usage='$progpath [OPTION]...'
+
+# Short help message in response to '-h' and '--help'. Add to this or
+# override it after sourcing this library to reflect the full set of
+# options your script accepts.
+usage_message="\
+ --debug enable verbose shell tracing
+ -W, --warnings=CATEGORY
+ report the warnings falling in CATEGORY [all]
+ -v, --verbose verbosely report processing
+ --version print version information and exit
+ -h, --help print short or long help message and exit
+"
+
+# Additional text appended to 'usage_message' in response to '--help'.
+long_help_message="
+Warning categories include:
+ 'all' show all warnings
+ 'none' turn off all the warnings
+ 'error' warnings are treated as fatal errors"
+
+# Help message printed before fatal option parsing errors.
+fatal_help="Try '\$progname --help' for more information."
+
+
+
+## ------------------------- ##
+## Hook function management. ##
+## ------------------------- ##
+
+# This section contains functions for adding, removing, and running hooks
+# to the main code. A hook is just a named list of of function, that can
+# be run in order later on.
+
+# func_hookable FUNC_NAME
+# -----------------------
+# Declare that FUNC_NAME will run hooks added with
+# 'func_add_hook FUNC_NAME ...'.
+func_hookable ()
+{
+ $debug_cmd
+
+ func_append hookable_fns " $1"
+}
+
+
+# func_add_hook FUNC_NAME HOOK_FUNC
+# ---------------------------------
+# Request that FUNC_NAME call HOOK_FUNC before it returns. FUNC_NAME must
+# first have been declared "hookable" by a call to 'func_hookable'.
+func_add_hook ()
+{
+ $debug_cmd
+
+ case " $hookable_fns " in
+ *" $1 "*) ;;
+ *) func_fatal_error "'$1' does not accept hook functions." ;;
+ esac
+
+ eval func_append ${1}_hooks '" $2"'
+}
+
+
+# func_remove_hook FUNC_NAME HOOK_FUNC
+# ------------------------------------
+# Remove HOOK_FUNC from the list of functions called by FUNC_NAME.
+func_remove_hook ()
+{
+ $debug_cmd
+
+ eval ${1}_hooks='`$ECHO "\$'$1'_hooks" |$SED "s| '$2'||"`'
+}
+
+
+# func_run_hooks FUNC_NAME [ARG]...
+# ---------------------------------
+# Run all hook functions registered to FUNC_NAME.
+# It is assumed that the list of hook functions contains nothing more
+# than a whitespace-delimited list of legal shell function names, and
+# no effort is wasted trying to catch shell meta-characters or preserve
+# whitespace.
+func_run_hooks ()
+{
+ $debug_cmd
+
+ case " $hookable_fns " in
+ *" $1 "*) ;;
+ *) func_fatal_error "'$1' does not support hook funcions.n" ;;
+ esac
+
+ eval _G_hook_fns=\$$1_hooks; shift
+
+ for _G_hook in $_G_hook_fns; do
+ eval $_G_hook '"$@"'
+
+ # store returned options list back into positional
+ # parameters for next 'cmd' execution.
+ eval _G_hook_result=\$${_G_hook}_result
+ eval set dummy "$_G_hook_result"; shift
+ done
+
+ func_quote_for_eval ${1+"$@"}
+ func_run_hooks_result=$func_quote_for_eval_result
+}
+
+
+
+## --------------- ##
+## Option parsing. ##
+## --------------- ##
+
+# In order to add your own option parsing hooks, you must accept the
+# full positional parameter list in your hook function, remove any
+# options that you action, and then pass back the remaining unprocessed
+# options in '<hooked_function_name>_result', escaped suitably for
+# 'eval'. Like this:
+#
+# my_options_prep ()
+# {
+# $debug_cmd
+#
+# # Extend the existing usage message.
+# usage_message=$usage_message'
+# -s, --silent don'\''t print informational messages
+# '
+#
+# func_quote_for_eval ${1+"$@"}
+# my_options_prep_result=$func_quote_for_eval_result
+# }
+# func_add_hook func_options_prep my_options_prep
+#
+#
+# my_silent_option ()
+# {
+# $debug_cmd
+#
+# # Note that for efficiency, we parse as many options as we can
+# # recognise in a loop before passing the remainder back to the
+# # caller on the first unrecognised argument we encounter.
+# while test $# -gt 0; do
+# opt=$1; shift
+# case $opt in
+# --silent|-s) opt_silent=: ;;
+# # Separate non-argument short options:
+# -s*) func_split_short_opt "$_G_opt"
+# set dummy "$func_split_short_opt_name" \
+# "-$func_split_short_opt_arg" ${1+"$@"}
+# shift
+# ;;
+# *) set dummy "$_G_opt" "$*"; shift; break ;;
+# esac
+# done
+#
+# func_quote_for_eval ${1+"$@"}
+# my_silent_option_result=$func_quote_for_eval_result
+# }
+# func_add_hook func_parse_options my_silent_option
+#
+#
+# my_option_validation ()
+# {
+# $debug_cmd
+#
+# $opt_silent && $opt_verbose && func_fatal_help "\
+# '--silent' and '--verbose' options are mutually exclusive."
+#
+# func_quote_for_eval ${1+"$@"}
+# my_option_validation_result=$func_quote_for_eval_result
+# }
+# func_add_hook func_validate_options my_option_validation
+#
+# You'll alse need to manually amend $usage_message to reflect the extra
+# options you parse. It's preferable to append if you can, so that
+# multiple option parsing hooks can be added safely.
+
+
+# func_options [ARG]...
+# ---------------------
+# All the functions called inside func_options are hookable. See the
+# individual implementations for details.
+func_hookable func_options
+func_options ()
+{
+ $debug_cmd
+
+ func_options_prep ${1+"$@"}
+ eval func_parse_options \
+ ${func_options_prep_result+"$func_options_prep_result"}
+ eval func_validate_options \
+ ${func_parse_options_result+"$func_parse_options_result"}
+
+ eval func_run_hooks func_options \
+ ${func_validate_options_result+"$func_validate_options_result"}
+
+ # save modified positional parameters for caller
+ func_options_result=$func_run_hooks_result
+}
+
+
+# func_options_prep [ARG]...
+# --------------------------
+# All initialisations required before starting the option parse loop.
+# Note that when calling hook functions, we pass through the list of
+# positional parameters. If a hook function modifies that list, and
+# needs to propogate that back to rest of this script, then the complete
+# modified list must be put in 'func_run_hooks_result' before
+# returning.
+func_hookable func_options_prep
+func_options_prep ()
+{
+ $debug_cmd
+
+ # Option defaults:
+ opt_verbose=false
+ opt_warning_types=
+
+ func_run_hooks func_options_prep ${1+"$@"}
+
+ # save modified positional parameters for caller
+ func_options_prep_result=$func_run_hooks_result
+}
+
+
+# func_parse_options [ARG]...
+# ---------------------------
+# The main option parsing loop.
+func_hookable func_parse_options
+func_parse_options ()
+{
+ $debug_cmd
+
+ func_parse_options_result=
+
+ # this just eases exit handling
+ while test $# -gt 0; do
+ # Defer to hook functions for initial option parsing, so they
+ # get priority in the event of reusing an option name.
+ func_run_hooks func_parse_options ${1+"$@"}
+
+ # Adjust func_parse_options positional parameters to match
+ eval set dummy "$func_run_hooks_result"; shift
+
+ # Break out of the loop if we already parsed every option.
+ test $# -gt 0 || break
+
+ _G_opt=$1
+ shift
+ case $_G_opt in
+ --debug|-x) debug_cmd='set -x'
+ func_echo "enabling shell trace mode"
+ $debug_cmd
+ ;;
+
+ --no-warnings|--no-warning|--no-warn)
+ set dummy --warnings none ${1+"$@"}
+ shift
+ ;;
+
+ --warnings|--warning|-W)
+ test $# = 0 && func_missing_arg $_G_opt && break
+ case " $warning_categories $1" in
+ *" $1 "*)
+ # trailing space prevents matching last $1 above
+ func_append_uniq opt_warning_types " $1"
+ ;;
+ *all)
+ opt_warning_types=$warning_categories
+ ;;
+ *none)
+ opt_warning_types=none
+ warning_func=:
+ ;;
+ *error)
+ opt_warning_types=$warning_categories
+ warning_func=func_fatal_error
+ ;;
+ *)
+ func_fatal_error \
+ "unsupported warning category: '$1'"
+ ;;
+ esac
+ shift
+ ;;
+
+ --verbose|-v) opt_verbose=: ;;
+ --version) func_version ;;
+ -\?|-h) func_usage ;;
+ --help) func_help ;;
+
+ # Separate optargs to long options (plugins may need this):
+ --*=*) func_split_equals "$_G_opt"
+ set dummy "$func_split_equals_lhs" \
+ "$func_split_equals_rhs" ${1+"$@"}
+ shift
+ ;;
+
+ # Separate optargs to short options:
+ -W*)
+ func_split_short_opt "$_G_opt"
+ set dummy "$func_split_short_opt_name" \
+ "$func_split_short_opt_arg" ${1+"$@"}
+ shift
+ ;;
+
+ # Separate non-argument short options:
+ -\?*|-h*|-v*|-x*)
+ func_split_short_opt "$_G_opt"
+ set dummy "$func_split_short_opt_name" \
+ "-$func_split_short_opt_arg" ${1+"$@"}
+ shift
+ ;;
+
+ --) break ;;
+ -*) func_fatal_help "unrecognised option: '$_G_opt'" ;;
+ *) set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
+ esac
+ done
+
+ # save modified positional parameters for caller
+ func_quote_for_eval ${1+"$@"}
+ func_parse_options_result=$func_quote_for_eval_result
+}
+
+
+# func_validate_options [ARG]...
+# ------------------------------
+# Perform any sanity checks on option settings and/or unconsumed
+# arguments.
+func_hookable func_validate_options
+func_validate_options ()
+{
+ $debug_cmd
+
+ # Display all warnings if -W was not given.
+ test -n "$opt_warning_types" || opt_warning_types=" $warning_categories"
+
+ func_run_hooks func_validate_options ${1+"$@"}
+
+ # Bail if the options were screwed!
+ $exit_cmd $EXIT_FAILURE
+
+ # save modified positional parameters for caller
+ func_validate_options_result=$func_run_hooks_result
+}
+
+
+
+## ----------------- ##
+## Helper functions. ##
+## ----------------- ##
+
+# This section contains the helper functions used by the rest of the
+# hookable option parser framework in ascii-betical order.
+
+
+# func_fatal_help ARG...
+# ----------------------
+# Echo program name prefixed message to standard error, followed by
+# a help hint, and exit.
+func_fatal_help ()
+{
+ $debug_cmd
+
+ eval \$ECHO \""Usage: $usage"\"
+ eval \$ECHO \""$fatal_help"\"
+ func_error ${1+"$@"}
+ exit $EXIT_FAILURE
}
-# func_help [NOEXIT]
-# Echo long help message to standard output and exit,
-# unless 'noexit' is passed as argument.
+
+# func_help
+# ---------
+# Echo long help message to standard output and exit.
func_help ()
{
- $opt_debug
-
- $SED -n '/^# Usage:/,/# Report bugs to/ {
- :print
- s/^# //
- s/^# *$//
- s*\$progname*'$progname'*
- s*\$host*'"$host"'*
- s*\$SHELL*'"$SHELL"'*
- s*\$LTCC*'"$LTCC"'*
- s*\$LTCFLAGS*'"$LTCFLAGS"'*
- s*\$LD*'"$LD"'*
- s/\$with_gnu_ld/'"$with_gnu_ld"'/
- s/\$automake_version/'"`(${AUTOMAKE-automake} --version) 2>/dev/null |$SED 1q`"'/
- s/\$autoconf_version/'"`(${AUTOCONF-autoconf} --version) 2>/dev/null |$SED 1q`"'/
- p
- d
- }
- /^# .* home page:/b print
- /^# General help using/b print
- ' < "$progpath"
- ret=$?
- if test -z "$1"; then
- exit $ret
- fi
+ $debug_cmd
+
+ func_usage_message
+ $ECHO "$long_help_message"
+ exit 0
}
-# func_missing_arg argname
+
+# func_missing_arg ARGNAME
+# ------------------------
# Echo program name prefixed message to standard error and set global
# exit_cmd.
func_missing_arg ()
{
- $opt_debug
+ $debug_cmd
- func_error "missing argument for $1."
+ func_error "Missing argument for '$1'."
exit_cmd=exit
}
-# func_split_short_opt shortopt
+# func_split_equals STRING
+# ------------------------
+# Set func_split_equals_lhs and func_split_equals_rhs shell variables after
+# splitting STRING at the '=' sign.
+test -z "$_G_HAVE_XSI_OPS" \
+ && (eval 'x=a/b/c;
+ test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \
+ && _G_HAVE_XSI_OPS=yes
+
+if test yes = "$_G_HAVE_XSI_OPS"
+then
+ # This is an XSI compatible shell, allowing a faster implementation...
+ eval 'func_split_equals ()
+ {
+ $debug_cmd
+
+ func_split_equals_lhs=${1%%=*}
+ func_split_equals_rhs=${1#*=}
+ test "x$func_split_equals_lhs" = "x$1" \
+ && func_split_equals_rhs=
+ }'
+else
+ # ...otherwise fall back to using expr, which is often a shell builtin.
+ func_split_equals ()
+ {
+ $debug_cmd
+
+ func_split_equals_lhs=`expr "x$1" : 'x\([^=]*\)'`
+ func_split_equals_rhs=
+ test "x$func_split_equals_lhs" = "x$1" \
+ || func_split_equals_rhs=`expr "x$1" : 'x[^=]*=\(.*\)$'`
+ }
+fi #func_split_equals
+
+
+# func_split_short_opt SHORTOPT
+# -----------------------------
# Set func_split_short_opt_name and func_split_short_opt_arg shell
# variables after splitting SHORTOPT after the 2nd character.
-func_split_short_opt ()
+if test yes = "$_G_HAVE_XSI_OPS"
+then
+ # This is an XSI compatible shell, allowing a faster implementation...
+ eval 'func_split_short_opt ()
+ {
+ $debug_cmd
+
+ func_split_short_opt_arg=${1#??}
+ func_split_short_opt_name=${1%"$func_split_short_opt_arg"}
+ }'
+else
+ # ...otherwise fall back to using expr, which is often a shell builtin.
+ func_split_short_opt ()
+ {
+ $debug_cmd
+
+ func_split_short_opt_name=`expr "x$1" : 'x-\(.\)'`
+ func_split_short_opt_arg=`expr "x$1" : 'x-.\(.*\)$'`
+ }
+fi #func_split_short_opt
+
+
+# func_usage
+# ----------
+# Echo short help message to standard output and exit.
+func_usage ()
{
- my_sed_short_opt='1s/^\(..\).*$/\1/;q'
- my_sed_short_rest='1s/^..\(.*\)$/\1/;q'
+ $debug_cmd
- func_split_short_opt_name=`$ECHO "$1" | $SED "$my_sed_short_opt"`
- func_split_short_opt_arg=`$ECHO "$1" | $SED "$my_sed_short_rest"`
-} # func_split_short_opt may be replaced by extended shell implementation
+ func_usage_message
+ $ECHO "Run '$progname --help |${PAGER-more}' for full usage"
+ exit 0
+}
-# func_split_long_opt longopt
-# Set func_split_long_opt_name and func_split_long_opt_arg shell
-# variables after splitting LONGOPT at the `=' sign.
-func_split_long_opt ()
+# func_usage_message
+# ------------------
+# Echo short help message to standard output.
+func_usage_message ()
{
- my_sed_long_opt='1s/^\(--[^=]*\)=.*/\1/;q'
- my_sed_long_arg='1s/^--[^=]*=//'
+ $debug_cmd
- func_split_long_opt_name=`$ECHO "$1" | $SED "$my_sed_long_opt"`
- func_split_long_opt_arg=`$ECHO "$1" | $SED "$my_sed_long_arg"`
-} # func_split_long_opt may be replaced by extended shell implementation
+ eval \$ECHO \""Usage: $usage"\"
+ echo
+ $SED -n 's|^# ||
+ /^Written by/{
+ x;p;x
+ }
+ h
+ /^Written by/q' < "$progpath"
+ echo
+ eval \$ECHO \""$usage_message"\"
+}
-exit_cmd=:
+# func_version
+# ------------
+# Echo version message to standard output and exit.
+func_version ()
+{
+ $debug_cmd
+ printf '%s\n' "$progname $scriptversion"
+ $SED -n '
+ /(C)/!b go
+ :more
+ /\./!{
+ N
+ s|\n# | |
+ b more
+ }
+ :go
+ /^# Written by /,/# warranty; / {
+ s|^# ||
+ s|^# *$||
+ s|\((C)\)[ 0-9,-]*[ ,-]\([1-9][0-9]* \)|\1 \2|
+ p
+ }
+ /^# Written by / {
+ s|^# ||
+ p
+ }
+ /^warranty; /q' < "$progpath"
+ exit $?
+}
-magic="%%%MAGIC variable%%%"
-magic_exe="%%%MAGIC EXE variable%%%"
+# Local variables:
+# mode: shell-script
+# sh-indentation: 2
+# eval: (add-hook 'before-save-hook 'time-stamp)
+# time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC"
+# time-stamp-time-zone: "UTC"
+# End:
-# Global variables.
-nonopt=
-preserve_args=
-lo2o="s/\\.lo\$/.${objext}/"
-o2lo="s/\\.${objext}\$/.lo/"
-extracted_archives=
-extracted_serial=0
+# Set a version string.
+scriptversion='(GNU libtool) 2.4.6'
-# If this variable is set in any of the actions, the command in it
-# will be execed at the end. This prevents here-documents from being
-# left over by shells.
-exec_cmd=
-# func_append var value
-# Append VALUE to the end of shell variable VAR.
-func_append ()
+# func_echo ARG...
+# ----------------
+# Libtool also displays the current mode in messages, so override
+# funclib.sh func_echo with this custom definition.
+func_echo ()
{
- eval "${1}=\$${1}\${2}"
-} # func_append may be replaced by extended shell implementation
+ $debug_cmd
-# func_append_quoted var value
-# Quote VALUE and append to the end of shell variable VAR, separated
-# by a space.
-func_append_quoted ()
-{
- func_quote_for_eval "${2}"
- eval "${1}=\$${1}\\ \$func_quote_for_eval_result"
-} # func_append_quoted may be replaced by extended shell implementation
+ _G_message=$*
+ func_echo_IFS=$IFS
+ IFS=$nl
+ for _G_line in $_G_message; do
+ IFS=$func_echo_IFS
+ $ECHO "$progname${opt_mode+: $opt_mode}: $_G_line"
+ done
+ IFS=$func_echo_IFS
+}
-# func_arith arithmetic-term...
-func_arith ()
+
+# func_warning ARG...
+# -------------------
+# Libtool warnings are not categorized, so override funclib.sh
+# func_warning with this simpler definition.
+func_warning ()
{
- func_arith_result=`expr "${@}"`
-} # func_arith may be replaced by extended shell implementation
+ $debug_cmd
+ $warning_func ${1+"$@"}
+}
-# func_len string
-# STRING may not start with a hyphen.
-func_len ()
-{
- func_len_result=`expr "${1}" : ".*" 2>/dev/null || echo $max_cmd_len`
-} # func_len may be replaced by extended shell implementation
+## ---------------- ##
+## Options parsing. ##
+## ---------------- ##
+
+# Hook in the functions to make sure our own options are parsed during
+# the option parsing loop.
+
+usage='$progpath [OPTION]... [MODE-ARG]...'
+
+# Short help message in response to '-h'.
+usage_message="Options:
+ --config show all configuration variables
+ --debug enable verbose shell tracing
+ -n, --dry-run display commands without modifying any files
+ --features display basic configuration information and exit
+ --mode=MODE use operation mode MODE
+ --no-warnings equivalent to '-Wnone'
+ --preserve-dup-deps don't remove duplicate dependency libraries
+ --quiet, --silent don't print informational messages
+ --tag=TAG use configuration variables from tag TAG
+ -v, --verbose print more informational messages than default
+ --version print version information
+ -W, --warnings=CATEGORY report the warnings falling in CATEGORY [all]
+ -h, --help, --help-all print short, long, or detailed help message
+"
-# func_lo2o object
-func_lo2o ()
+# Additional text appended to 'usage_message' in response to '--help'.
+func_help ()
{
- func_lo2o_result=`$ECHO "${1}" | $SED "$lo2o"`
-} # func_lo2o may be replaced by extended shell implementation
+ $debug_cmd
+
+ func_usage_message
+ $ECHO "$long_help_message
+
+MODE must be one of the following:
+
+ clean remove files from the build directory
+ compile compile a source file into a libtool object
+ execute automatically set library path, then run a program
+ finish complete the installation of libtool libraries
+ install install libraries or executables
+ link create a library or an executable
+ uninstall remove libraries from an installed directory
+
+MODE-ARGS vary depending on the MODE. When passed as first option,
+'--mode=MODE' may be abbreviated as 'MODE' or a unique abbreviation of that.
+Try '$progname --help --mode=MODE' for a more detailed description of MODE.
+
+When reporting a bug, please describe a test case to reproduce it and
+include the following information:
+
+ host-triplet: $host
+ shell: $SHELL
+ compiler: $LTCC
+ compiler flags: $LTCFLAGS
+ linker: $LD (gnu? $with_gnu_ld)
+ version: $progname $scriptversion Debian-2.4.6-2
+ automake: `($AUTOMAKE --version) 2>/dev/null |$SED 1q`
+ autoconf: `($AUTOCONF --version) 2>/dev/null |$SED 1q`
+
+Report bugs to <bug-libtool@gnu.org>.
+GNU libtool home page: <http://www.gnu.org/s/libtool/>.
+General help using GNU software: <http://www.gnu.org/gethelp/>."
+ exit 0
+}
-# func_xform libobj-or-source
-func_xform ()
-{
- func_xform_result=`$ECHO "${1}" | $SED 's/\.[^.]*$/.lo/'`
-} # func_xform may be replaced by extended shell implementation
+# func_lo2o OBJECT-NAME
+# ---------------------
+# Transform OBJECT-NAME from a '.lo' suffix to the platform specific
+# object suffix.
+
+lo2o=s/\\.lo\$/.$objext/
+o2lo=s/\\.$objext\$/.lo/
+
+if test yes = "$_G_HAVE_XSI_OPS"; then
+ eval 'func_lo2o ()
+ {
+ case $1 in
+ *.lo) func_lo2o_result=${1%.lo}.$objext ;;
+ * ) func_lo2o_result=$1 ;;
+ esac
+ }'
+ # func_xform LIBOBJ-OR-SOURCE
+ # ---------------------------
+ # Transform LIBOBJ-OR-SOURCE from a '.o' or '.c' (or otherwise)
+ # suffix to a '.lo' libtool-object suffix.
+ eval 'func_xform ()
+ {
+ func_xform_result=${1%.*}.lo
+ }'
+else
+ # ...otherwise fall back to using sed.
+ func_lo2o ()
+ {
+ func_lo2o_result=`$ECHO "$1" | $SED "$lo2o"`
+ }
+
+ func_xform ()
+ {
+ func_xform_result=`$ECHO "$1" | $SED 's|\.[^.]*$|.lo|'`
+ }
+fi
-# func_fatal_configuration arg...
+
+# func_fatal_configuration ARG...
+# -------------------------------
# Echo program name prefixed message to standard error, followed by
# a configuration failure hint, and exit.
func_fatal_configuration ()
{
- func_error ${1+"$@"}
- func_error "See the $PACKAGE documentation for more information."
- func_fatal_error "Fatal configuration error."
+ func__fatal_error ${1+"$@"} \
+ "See the $PACKAGE documentation for more information." \
+ "Fatal configuration error."
}
# func_config
+# -----------
# Display the configuration for all the tags in this script.
func_config ()
{
@@ -915,17 +2149,19 @@ func_config ()
exit $?
}
+
# func_features
+# -------------
# Display the features supported by this script.
func_features ()
{
echo "host: $host"
- if test "$build_libtool_libs" = yes; then
+ if test yes = "$build_libtool_libs"; then
echo "enable shared libraries"
else
echo "disable shared libraries"
fi
- if test "$build_old_libs" = yes; then
+ if test yes = "$build_old_libs"; then
echo "enable static libraries"
else
echo "disable static libraries"
@@ -934,289 +2170,297 @@ func_features ()
exit $?
}
-# func_enable_tag tagname
+
+# func_enable_tag TAGNAME
+# -----------------------
# Verify that TAGNAME is valid, and either flag an error and exit, or
# enable the TAGNAME tag. We also add TAGNAME to the global $taglist
# variable here.
func_enable_tag ()
{
- # Global variable:
- tagname="$1"
+ # Global variable:
+ tagname=$1
- re_begincf="^# ### BEGIN LIBTOOL TAG CONFIG: $tagname\$"
- re_endcf="^# ### END LIBTOOL TAG CONFIG: $tagname\$"
- sed_extractcf="/$re_begincf/,/$re_endcf/p"
+ re_begincf="^# ### BEGIN LIBTOOL TAG CONFIG: $tagname\$"
+ re_endcf="^# ### END LIBTOOL TAG CONFIG: $tagname\$"
+ sed_extractcf=/$re_begincf/,/$re_endcf/p
- # Validate tagname.
- case $tagname in
- *[!-_A-Za-z0-9,/]*)
- func_fatal_error "invalid tag name: $tagname"
- ;;
- esac
+ # Validate tagname.
+ case $tagname in
+ *[!-_A-Za-z0-9,/]*)
+ func_fatal_error "invalid tag name: $tagname"
+ ;;
+ esac
- # Don't test for the "default" C tag, as we know it's
- # there but not specially marked.
- case $tagname in
- CC) ;;
+ # Don't test for the "default" C tag, as we know it's
+ # there but not specially marked.
+ case $tagname in
+ CC) ;;
*)
- if $GREP "$re_begincf" "$progpath" >/dev/null 2>&1; then
- taglist="$taglist $tagname"
-
- # Evaluate the configuration. Be careful to quote the path
- # and the sed script, to avoid splitting on whitespace, but
- # also don't use non-portable quotes within backquotes within
- # quotes we have to do it in 2 steps:
- extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"`
- eval "$extractedcf"
- else
- func_error "ignoring unknown tag $tagname"
- fi
- ;;
- esac
+ if $GREP "$re_begincf" "$progpath" >/dev/null 2>&1; then
+ taglist="$taglist $tagname"
+
+ # Evaluate the configuration. Be careful to quote the path
+ # and the sed script, to avoid splitting on whitespace, but
+ # also don't use non-portable quotes within backquotes within
+ # quotes we have to do it in 2 steps:
+ extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"`
+ eval "$extractedcf"
+ else
+ func_error "ignoring unknown tag $tagname"
+ fi
+ ;;
+ esac
}
+
# func_check_version_match
+# ------------------------
# Ensure that we are using m4 macros, and libtool script from the same
# release of libtool.
func_check_version_match ()
{
- if test "$package_revision" != "$macro_revision"; then
- if test "$VERSION" != "$macro_version"; then
- if test -z "$macro_version"; then
- cat >&2 <<_LT_EOF
+ if test "$package_revision" != "$macro_revision"; then
+ if test "$VERSION" != "$macro_version"; then
+ if test -z "$macro_version"; then
+ cat >&2 <<_LT_EOF
$progname: Version mismatch error. This is $PACKAGE $VERSION, but the
$progname: definition of this LT_INIT comes from an older release.
$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION
$progname: and run autoconf again.
_LT_EOF
- else
- cat >&2 <<_LT_EOF
+ else
+ cat >&2 <<_LT_EOF
$progname: Version mismatch error. This is $PACKAGE $VERSION, but the
$progname: definition of this LT_INIT comes from $PACKAGE $macro_version.
$progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION
$progname: and run autoconf again.
_LT_EOF
- fi
- else
- cat >&2 <<_LT_EOF
+ fi
+ else
+ cat >&2 <<_LT_EOF
$progname: Version mismatch error. This is $PACKAGE $VERSION, revision $package_revision,
$progname: but the definition of this LT_INIT comes from revision $macro_revision.
$progname: You should recreate aclocal.m4 with macros from revision $package_revision
$progname: of $PACKAGE $VERSION and run autoconf again.
_LT_EOF
- fi
+ fi
- exit $EXIT_MISMATCH
- fi
+ exit $EXIT_MISMATCH
+ fi
}
-# Shorthand for --mode=foo, only valid as the first argument
-case $1 in
-clean|clea|cle|cl)
- shift; set dummy --mode clean ${1+"$@"}; shift
- ;;
-compile|compil|compi|comp|com|co|c)
- shift; set dummy --mode compile ${1+"$@"}; shift
- ;;
-execute|execut|execu|exec|exe|ex|e)
- shift; set dummy --mode execute ${1+"$@"}; shift
- ;;
-finish|finis|fini|fin|fi|f)
- shift; set dummy --mode finish ${1+"$@"}; shift
- ;;
-install|instal|insta|inst|ins|in|i)
- shift; set dummy --mode install ${1+"$@"}; shift
- ;;
-link|lin|li|l)
- shift; set dummy --mode link ${1+"$@"}; shift
- ;;
-uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u)
- shift; set dummy --mode uninstall ${1+"$@"}; shift
- ;;
-esac
+# libtool_options_prep [ARG]...
+# -----------------------------
+# Preparation for options parsed by libtool.
+libtool_options_prep ()
+{
+ $debug_mode
+ # Option defaults:
+ opt_config=false
+ opt_dlopen=
+ opt_dry_run=false
+ opt_help=false
+ opt_mode=
+ opt_preserve_dup_deps=false
+ opt_quiet=false
+ nonopt=
+ preserve_args=
-# Option defaults:
-opt_debug=:
-opt_dry_run=false
-opt_config=false
-opt_preserve_dup_deps=false
-opt_features=false
-opt_finish=false
-opt_help=false
-opt_help_all=false
-opt_silent=:
-opt_warning=:
-opt_verbose=:
-opt_silent=false
-opt_verbose=false
+ # Shorthand for --mode=foo, only valid as the first argument
+ case $1 in
+ clean|clea|cle|cl)
+ shift; set dummy --mode clean ${1+"$@"}; shift
+ ;;
+ compile|compil|compi|comp|com|co|c)
+ shift; set dummy --mode compile ${1+"$@"}; shift
+ ;;
+ execute|execut|execu|exec|exe|ex|e)
+ shift; set dummy --mode execute ${1+"$@"}; shift
+ ;;
+ finish|finis|fini|fin|fi|f)
+ shift; set dummy --mode finish ${1+"$@"}; shift
+ ;;
+ install|instal|insta|inst|ins|in|i)
+ shift; set dummy --mode install ${1+"$@"}; shift
+ ;;
+ link|lin|li|l)
+ shift; set dummy --mode link ${1+"$@"}; shift
+ ;;
+ uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u)
+ shift; set dummy --mode uninstall ${1+"$@"}; shift
+ ;;
+ esac
+ # Pass back the list of options.
+ func_quote_for_eval ${1+"$@"}
+ libtool_options_prep_result=$func_quote_for_eval_result
+}
+func_add_hook func_options_prep libtool_options_prep
-# Parse options once, thoroughly. This comes as soon as possible in the
-# script to make things like `--version' happen as quickly as we can.
+
+# libtool_parse_options [ARG]...
+# ---------------------------------
+# Provide handling for libtool specific options.
+libtool_parse_options ()
{
- # this just eases exit handling
- while test $# -gt 0; do
- opt="$1"
- shift
- case $opt in
- --debug|-x) opt_debug='set -x'
- func_echo "enabling shell trace mode"
- $opt_debug
- ;;
- --dry-run|--dryrun|-n)
- opt_dry_run=:
- ;;
- --config)
- opt_config=:
-func_config
- ;;
- --dlopen|-dlopen)
- optarg="$1"
- opt_dlopen="${opt_dlopen+$opt_dlopen
-}$optarg"
- shift
- ;;
- --preserve-dup-deps)
- opt_preserve_dup_deps=:
- ;;
- --features)
- opt_features=:
-func_features
- ;;
- --finish)
- opt_finish=:
-set dummy --mode finish ${1+"$@"}; shift
- ;;
- --help)
- opt_help=:
- ;;
- --help-all)
- opt_help_all=:
-opt_help=': help-all'
- ;;
- --mode)
- test $# = 0 && func_missing_arg $opt && break
- optarg="$1"
- opt_mode="$optarg"
-case $optarg in
- # Valid mode arguments:
- clean|compile|execute|finish|install|link|relink|uninstall) ;;
-
- # Catch anything else as an error
- *) func_error "invalid argument for $opt"
- exit_cmd=exit
- break
- ;;
-esac
- shift
- ;;
- --no-silent|--no-quiet)
- opt_silent=false
-func_append preserve_args " $opt"
- ;;
- --no-warning|--no-warn)
- opt_warning=false
-func_append preserve_args " $opt"
- ;;
- --no-verbose)
- opt_verbose=false
-func_append preserve_args " $opt"
- ;;
- --silent|--quiet)
- opt_silent=:
-func_append preserve_args " $opt"
- opt_verbose=false
- ;;
- --verbose|-v)
- opt_verbose=:
-func_append preserve_args " $opt"
-opt_silent=false
- ;;
- --tag)
- test $# = 0 && func_missing_arg $opt && break
- optarg="$1"
- opt_tag="$optarg"
-func_append preserve_args " $opt $optarg"
-func_enable_tag "$optarg"
- shift
- ;;
-
- -\?|-h) func_usage ;;
- --help) func_help ;;
- --version) func_version ;;
-
- # Separate optargs to long options:
- --*=*)
- func_split_long_opt "$opt"
- set dummy "$func_split_long_opt_name" "$func_split_long_opt_arg" ${1+"$@"}
- shift
- ;;
-
- # Separate non-argument short options:
- -\?*|-h*|-n*|-v*)
- func_split_short_opt "$opt"
- set dummy "$func_split_short_opt_name" "-$func_split_short_opt_arg" ${1+"$@"}
- shift
- ;;
-
- --) break ;;
- -*) func_fatal_help "unrecognized option \`$opt'" ;;
- *) set dummy "$opt" ${1+"$@"}; shift; break ;;
- esac
- done
+ $debug_cmd
- # Validate options:
+ # Perform our own loop to consume as many options as possible in
+ # each iteration.
+ while test $# -gt 0; do
+ _G_opt=$1
+ shift
+ case $_G_opt in
+ --dry-run|--dryrun|-n)
+ opt_dry_run=:
+ ;;
+
+ --config) func_config ;;
+
+ --dlopen|-dlopen)
+ opt_dlopen="${opt_dlopen+$opt_dlopen
+}$1"
+ shift
+ ;;
+
+ --preserve-dup-deps)
+ opt_preserve_dup_deps=: ;;
+
+ --features) func_features ;;
+
+ --finish) set dummy --mode finish ${1+"$@"}; shift ;;
+
+ --help) opt_help=: ;;
+
+ --help-all) opt_help=': help-all' ;;
+
+ --mode) test $# = 0 && func_missing_arg $_G_opt && break
+ opt_mode=$1
+ case $1 in
+ # Valid mode arguments:
+ clean|compile|execute|finish|install|link|relink|uninstall) ;;
+
+ # Catch anything else as an error
+ *) func_error "invalid argument for $_G_opt"
+ exit_cmd=exit
+ break
+ ;;
+ esac
+ shift
+ ;;
+
+ --no-silent|--no-quiet)
+ opt_quiet=false
+ func_append preserve_args " $_G_opt"
+ ;;
+
+ --no-warnings|--no-warning|--no-warn)
+ opt_warning=false
+ func_append preserve_args " $_G_opt"
+ ;;
+
+ --no-verbose)
+ opt_verbose=false
+ func_append preserve_args " $_G_opt"
+ ;;
+
+ --silent|--quiet)
+ opt_quiet=:
+ opt_verbose=false
+ func_append preserve_args " $_G_opt"
+ ;;
+
+ --tag) test $# = 0 && func_missing_arg $_G_opt && break
+ opt_tag=$1
+ func_append preserve_args " $_G_opt $1"
+ func_enable_tag "$1"
+ shift
+ ;;
+
+ --verbose|-v) opt_quiet=false
+ opt_verbose=:
+ func_append preserve_args " $_G_opt"
+ ;;
+
+ # An option not handled by this hook function:
+ *) set dummy "$_G_opt" ${1+"$@"}; shift; break ;;
+ esac
+ done
- # save first non-option argument
- if test "$#" -gt 0; then
- nonopt="$opt"
- shift
- fi
- # preserve --debug
- test "$opt_debug" = : || func_append preserve_args " --debug"
+ # save modified positional parameters for caller
+ func_quote_for_eval ${1+"$@"}
+ libtool_parse_options_result=$func_quote_for_eval_result
+}
+func_add_hook func_parse_options libtool_parse_options
- case $host in
- *cygwin* | *mingw* | *pw32* | *cegcc*)
- # don't eliminate duplications in $postdeps and $predeps
- opt_duplicate_compiler_generated_deps=:
- ;;
- *)
- opt_duplicate_compiler_generated_deps=$opt_preserve_dup_deps
- ;;
- esac
- $opt_help || {
- # Sanity checks first:
- func_check_version_match
- if test "$build_libtool_libs" != yes && test "$build_old_libs" != yes; then
- func_fatal_configuration "not configured to build any kind of library"
+# libtool_validate_options [ARG]...
+# ---------------------------------
+# Perform any sanity checks on option settings and/or unconsumed
+# arguments.
+libtool_validate_options ()
+{
+ # save first non-option argument
+ if test 0 -lt $#; then
+ nonopt=$1
+ shift
fi
- # Darwin sucks
- eval std_shrext=\"$shrext_cmds\"
+ # preserve --debug
+ test : = "$debug_cmd" || func_append preserve_args " --debug"
- # Only execute mode is allowed to have -dlopen flags.
- if test -n "$opt_dlopen" && test "$opt_mode" != execute; then
- func_error "unrecognized option \`-dlopen'"
- $ECHO "$help" 1>&2
- exit $EXIT_FAILURE
- fi
+ case $host in
+ # Solaris2 added to fix http://debbugs.gnu.org/cgi/bugreport.cgi?bug=16452
+ # see also: http://gcc.gnu.org/bugzilla/show_bug.cgi?id=59788
+ *cygwin* | *mingw* | *pw32* | *cegcc* | *solaris2* | *os2*)
+ # don't eliminate duplications in $postdeps and $predeps
+ opt_duplicate_compiler_generated_deps=:
+ ;;
+ *)
+ opt_duplicate_compiler_generated_deps=$opt_preserve_dup_deps
+ ;;
+ esac
- # Change the help message to a mode-specific one.
- generic_help="$help"
- help="Try \`$progname --help --mode=$opt_mode' for more information."
- }
+ $opt_help || {
+ # Sanity checks first:
+ func_check_version_match
+
+ test yes != "$build_libtool_libs" \
+ && test yes != "$build_old_libs" \
+ && func_fatal_configuration "not configured to build any kind of library"
+
+ # Darwin sucks
+ eval std_shrext=\"$shrext_cmds\"
+
+ # Only execute mode is allowed to have -dlopen flags.
+ if test -n "$opt_dlopen" && test execute != "$opt_mode"; then
+ func_error "unrecognized option '-dlopen'"
+ $ECHO "$help" 1>&2
+ exit $EXIT_FAILURE
+ fi
+ # Change the help message to a mode-specific one.
+ generic_help=$help
+ help="Try '$progname --help --mode=$opt_mode' for more information."
+ }
- # Bail if the options were screwed
- $exit_cmd $EXIT_FAILURE
+ # Pass back the unparsed argument list
+ func_quote_for_eval ${1+"$@"}
+ libtool_validate_options_result=$func_quote_for_eval_result
}
+func_add_hook func_validate_options libtool_validate_options
+
+# Process options as early as possible so that --help and --version
+# can return quickly.
+func_options ${1+"$@"}
+eval set dummy "$func_options_result"; shift
@@ -1224,24 +2468,52 @@ func_enable_tag "$optarg"
## Main. ##
## ----------- ##
+magic='%%%MAGIC variable%%%'
+magic_exe='%%%MAGIC EXE variable%%%'
+
+# Global variables.
+extracted_archives=
+extracted_serial=0
+
+# If this variable is set in any of the actions, the command in it
+# will be execed at the end. This prevents here-documents from being
+# left over by shells.
+exec_cmd=
+
+
+# A function that is used when there is no print builtin or printf.
+func_fallback_echo ()
+{
+ eval 'cat <<_LTECHO_EOF
+$1
+_LTECHO_EOF'
+}
+
+# func_generated_by_libtool
+# True iff stdin has been generated by Libtool. This function is only
+# a basic sanity check; it will hardly flush out determined imposters.
+func_generated_by_libtool_p ()
+{
+ $GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1
+}
+
# func_lalib_p file
-# True iff FILE is a libtool `.la' library or `.lo' object file.
+# True iff FILE is a libtool '.la' library or '.lo' object file.
# This function is only a basic sanity check; it will hardly flush out
# determined imposters.
func_lalib_p ()
{
test -f "$1" &&
- $SED -e 4q "$1" 2>/dev/null \
- | $GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1
+ $SED -e 4q "$1" 2>/dev/null | func_generated_by_libtool_p
}
# func_lalib_unsafe_p file
-# True iff FILE is a libtool `.la' library or `.lo' object file.
+# True iff FILE is a libtool '.la' library or '.lo' object file.
# This function implements the same check as func_lalib_p without
# resorting to external programs. To this end, it redirects stdin and
# closes it afterwards, without saving the original file descriptor.
# As a safety measure, use it only where a negative result would be
-# fatal anyway. Works if `file' does not exist.
+# fatal anyway. Works if 'file' does not exist.
func_lalib_unsafe_p ()
{
lalib_p=no
@@ -1249,13 +2521,13 @@ func_lalib_unsafe_p ()
for lalib_p_l in 1 2 3 4
do
read lalib_p_line
- case "$lalib_p_line" in
+ case $lalib_p_line in
\#\ Generated\ by\ *$PACKAGE* ) lalib_p=yes; break;;
esac
done
exec 0<&5 5<&-
fi
- test "$lalib_p" = yes
+ test yes = "$lalib_p"
}
# func_ltwrapper_script_p file
@@ -1264,7 +2536,8 @@ func_lalib_unsafe_p ()
# determined imposters.
func_ltwrapper_script_p ()
{
- func_lalib_p "$1"
+ test -f "$1" &&
+ $lt_truncate_bin < "$1" 2>/dev/null | func_generated_by_libtool_p
}
# func_ltwrapper_executable_p file
@@ -1289,7 +2562,7 @@ func_ltwrapper_scriptname ()
{
func_dirname_and_basename "$1" "" "."
func_stripname '' '.exe' "$func_basename_result"
- func_ltwrapper_scriptname_result="$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper"
+ func_ltwrapper_scriptname_result=$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper
}
# func_ltwrapper_p file
@@ -1308,11 +2581,13 @@ func_ltwrapper_p ()
# FAIL_CMD may read-access the current command in variable CMD!
func_execute_cmds ()
{
- $opt_debug
+ $debug_cmd
+
save_ifs=$IFS; IFS='~'
for cmd in $1; do
- IFS=$save_ifs
+ IFS=$sp$nl
eval cmd=\"$cmd\"
+ IFS=$save_ifs
func_show_eval "$cmd" "${2-:}"
done
IFS=$save_ifs
@@ -1324,10 +2599,11 @@ func_execute_cmds ()
# Note that it is not necessary on cygwin/mingw to append a dot to
# FILE even if both FILE and FILE.exe exist: automatic-append-.exe
# behavior happens only for exec(3), not for open(2)! Also, sourcing
-# `FILE.' does not work on cygwin managed mounts.
+# 'FILE.' does not work on cygwin managed mounts.
func_source ()
{
- $opt_debug
+ $debug_cmd
+
case $1 in
*/* | *\\*) . "$1" ;;
*) . "./$1" ;;
@@ -1354,10 +2630,10 @@ func_resolve_sysroot ()
# store the result into func_replace_sysroot_result.
func_replace_sysroot ()
{
- case "$lt_sysroot:$1" in
+ case $lt_sysroot:$1 in
?*:"$lt_sysroot"*)
func_stripname "$lt_sysroot" '' "$1"
- func_replace_sysroot_result="=$func_stripname_result"
+ func_replace_sysroot_result='='$func_stripname_result
;;
*)
# Including no sysroot.
@@ -1374,7 +2650,8 @@ func_replace_sysroot ()
# arg is usually of the form 'gcc ...'
func_infer_tag ()
{
- $opt_debug
+ $debug_cmd
+
if test -n "$available_tags" && test -z "$tagname"; then
CC_quoted=
for arg in $CC; do
@@ -1393,7 +2670,7 @@ func_infer_tag ()
for z in $available_tags; do
if $GREP "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then
# Evaluate the configuration.
- eval "`${SED} -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`"
+ eval "`$SED -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`"
CC_quoted=
for arg in $CC; do
# Double-quote args containing other shell metacharacters.
@@ -1418,7 +2695,7 @@ func_infer_tag ()
# line option must be used.
if test -z "$tagname"; then
func_echo "unable to infer tagged configuration"
- func_fatal_error "specify a tag with \`--tag'"
+ func_fatal_error "specify a tag with '--tag'"
# else
# func_verbose "using $tagname tagged configuration"
fi
@@ -1434,15 +2711,15 @@ func_infer_tag ()
# but don't create it if we're doing a dry run.
func_write_libtool_object ()
{
- write_libobj=${1}
- if test "$build_libtool_libs" = yes; then
- write_lobj=\'${2}\'
+ write_libobj=$1
+ if test yes = "$build_libtool_libs"; then
+ write_lobj=\'$2\'
else
write_lobj=none
fi
- if test "$build_old_libs" = yes; then
- write_oldobj=\'${3}\'
+ if test yes = "$build_old_libs"; then
+ write_oldobj=\'$3\'
else
write_oldobj=none
fi
@@ -1450,7 +2727,7 @@ func_write_libtool_object ()
$opt_dry_run || {
cat >${write_libobj}T <<EOF
# $write_libobj - a libtool object file
-# Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION
+# Generated by $PROGRAM (GNU $PACKAGE) $VERSION
#
# Please DO NOT delete this file!
# It is necessary for linking the library.
@@ -1462,7 +2739,7 @@ pic_object=$write_lobj
non_pic_object=$write_oldobj
EOF
- $MV "${write_libobj}T" "${write_libobj}"
+ $MV "${write_libobj}T" "$write_libobj"
}
}
@@ -1482,8 +2759,9 @@ EOF
# be empty on error (or when ARG is empty)
func_convert_core_file_wine_to_w32 ()
{
- $opt_debug
- func_convert_core_file_wine_to_w32_result="$1"
+ $debug_cmd
+
+ func_convert_core_file_wine_to_w32_result=$1
if test -n "$1"; then
# Unfortunately, winepath does not exit with a non-zero error code, so we
# are forced to check the contents of stdout. On the other hand, if the
@@ -1491,9 +2769,9 @@ func_convert_core_file_wine_to_w32 ()
# *an error message* to stdout. So we must check for both error code of
# zero AND non-empty stdout, which explains the odd construction:
func_convert_core_file_wine_to_w32_tmp=`winepath -w "$1" 2>/dev/null`
- if test "$?" -eq 0 && test -n "${func_convert_core_file_wine_to_w32_tmp}"; then
+ if test "$?" -eq 0 && test -n "$func_convert_core_file_wine_to_w32_tmp"; then
func_convert_core_file_wine_to_w32_result=`$ECHO "$func_convert_core_file_wine_to_w32_tmp" |
- $SED -e "$lt_sed_naive_backslashify"`
+ $SED -e "$sed_naive_backslashify"`
else
func_convert_core_file_wine_to_w32_result=
fi
@@ -1514,18 +2792,19 @@ func_convert_core_file_wine_to_w32 ()
# are convertible, then the result may be empty.
func_convert_core_path_wine_to_w32 ()
{
- $opt_debug
+ $debug_cmd
+
# unfortunately, winepath doesn't convert paths, only file names
- func_convert_core_path_wine_to_w32_result=""
+ func_convert_core_path_wine_to_w32_result=
if test -n "$1"; then
oldIFS=$IFS
IFS=:
for func_convert_core_path_wine_to_w32_f in $1; do
IFS=$oldIFS
func_convert_core_file_wine_to_w32 "$func_convert_core_path_wine_to_w32_f"
- if test -n "$func_convert_core_file_wine_to_w32_result" ; then
+ if test -n "$func_convert_core_file_wine_to_w32_result"; then
if test -z "$func_convert_core_path_wine_to_w32_result"; then
- func_convert_core_path_wine_to_w32_result="$func_convert_core_file_wine_to_w32_result"
+ func_convert_core_path_wine_to_w32_result=$func_convert_core_file_wine_to_w32_result
else
func_append func_convert_core_path_wine_to_w32_result ";$func_convert_core_file_wine_to_w32_result"
fi
@@ -1554,7 +2833,8 @@ func_convert_core_path_wine_to_w32 ()
# environment variable; do not put it in $PATH.
func_cygpath ()
{
- $opt_debug
+ $debug_cmd
+
if test -n "$LT_CYGPATH" && test -f "$LT_CYGPATH"; then
func_cygpath_result=`$LT_CYGPATH "$@" 2>/dev/null`
if test "$?" -ne 0; then
@@ -1563,7 +2843,7 @@ func_cygpath ()
fi
else
func_cygpath_result=
- func_error "LT_CYGPATH is empty or specifies non-existent file: \`$LT_CYGPATH'"
+ func_error "LT_CYGPATH is empty or specifies non-existent file: '$LT_CYGPATH'"
fi
}
#end: func_cygpath
@@ -1574,10 +2854,11 @@ func_cygpath ()
# result in func_convert_core_msys_to_w32_result.
func_convert_core_msys_to_w32 ()
{
- $opt_debug
+ $debug_cmd
+
# awkward: cmd appends spaces to result
func_convert_core_msys_to_w32_result=`( cmd //c echo "$1" ) 2>/dev/null |
- $SED -e 's/[ ]*$//' -e "$lt_sed_naive_backslashify"`
+ $SED -e 's/[ ]*$//' -e "$sed_naive_backslashify"`
}
#end: func_convert_core_msys_to_w32
@@ -1588,13 +2869,14 @@ func_convert_core_msys_to_w32 ()
# func_to_host_file_result to ARG1).
func_convert_file_check ()
{
- $opt_debug
- if test -z "$2" && test -n "$1" ; then
+ $debug_cmd
+
+ if test -z "$2" && test -n "$1"; then
func_error "Could not determine host file name corresponding to"
- func_error " \`$1'"
+ func_error " '$1'"
func_error "Continuing, but uninstalled executables may not work."
# Fallback:
- func_to_host_file_result="$1"
+ func_to_host_file_result=$1
fi
}
# end func_convert_file_check
@@ -1606,10 +2888,11 @@ func_convert_file_check ()
# func_to_host_file_result to a simplistic fallback value (see below).
func_convert_path_check ()
{
- $opt_debug
+ $debug_cmd
+
if test -z "$4" && test -n "$3"; then
func_error "Could not determine the host path corresponding to"
- func_error " \`$3'"
+ func_error " '$3'"
func_error "Continuing, but uninstalled executables may not work."
# Fallback. This is a deliberately simplistic "conversion" and
# should not be "improved". See libtool.info.
@@ -1618,7 +2901,7 @@ func_convert_path_check ()
func_to_host_path_result=`echo "$3" |
$SED -e "$lt_replace_pathsep_chars"`
else
- func_to_host_path_result="$3"
+ func_to_host_path_result=$3
fi
fi
}
@@ -1630,9 +2913,10 @@ func_convert_path_check ()
# and appending REPL if ORIG matches BACKPAT.
func_convert_path_front_back_pathsep ()
{
- $opt_debug
+ $debug_cmd
+
case $4 in
- $1 ) func_to_host_path_result="$3$func_to_host_path_result"
+ $1 ) func_to_host_path_result=$3$func_to_host_path_result
;;
esac
case $4 in
@@ -1646,7 +2930,7 @@ func_convert_path_front_back_pathsep ()
##################################################
# $build to $host FILE NAME CONVERSION FUNCTIONS #
##################################################
-# invoked via `$to_host_file_cmd ARG'
+# invoked via '$to_host_file_cmd ARG'
#
# In each case, ARG is the path to be converted from $build to $host format.
# Result will be available in $func_to_host_file_result.
@@ -1657,7 +2941,8 @@ func_convert_path_front_back_pathsep ()
# in func_to_host_file_result.
func_to_host_file ()
{
- $opt_debug
+ $debug_cmd
+
$to_host_file_cmd "$1"
}
# end func_to_host_file
@@ -1669,7 +2954,8 @@ func_to_host_file ()
# in (the comma separated) LAZY, no conversion takes place.
func_to_tool_file ()
{
- $opt_debug
+ $debug_cmd
+
case ,$2, in
*,"$to_tool_file_cmd",*)
func_to_tool_file_result=$1
@@ -1687,7 +2973,7 @@ func_to_tool_file ()
# Copy ARG to func_to_host_file_result.
func_convert_file_noop ()
{
- func_to_host_file_result="$1"
+ func_to_host_file_result=$1
}
# end func_convert_file_noop
@@ -1698,11 +2984,12 @@ func_convert_file_noop ()
# func_to_host_file_result.
func_convert_file_msys_to_w32 ()
{
- $opt_debug
- func_to_host_file_result="$1"
+ $debug_cmd
+
+ func_to_host_file_result=$1
if test -n "$1"; then
func_convert_core_msys_to_w32 "$1"
- func_to_host_file_result="$func_convert_core_msys_to_w32_result"
+ func_to_host_file_result=$func_convert_core_msys_to_w32_result
fi
func_convert_file_check "$1" "$func_to_host_file_result"
}
@@ -1714,8 +3001,9 @@ func_convert_file_msys_to_w32 ()
# func_to_host_file_result.
func_convert_file_cygwin_to_w32 ()
{
- $opt_debug
- func_to_host_file_result="$1"
+ $debug_cmd
+
+ func_to_host_file_result=$1
if test -n "$1"; then
# because $build is cygwin, we call "the" cygpath in $PATH; no need to use
# LT_CYGPATH in this case.
@@ -1731,11 +3019,12 @@ func_convert_file_cygwin_to_w32 ()
# and a working winepath. Returns result in func_to_host_file_result.
func_convert_file_nix_to_w32 ()
{
- $opt_debug
- func_to_host_file_result="$1"
+ $debug_cmd
+
+ func_to_host_file_result=$1
if test -n "$1"; then
func_convert_core_file_wine_to_w32 "$1"
- func_to_host_file_result="$func_convert_core_file_wine_to_w32_result"
+ func_to_host_file_result=$func_convert_core_file_wine_to_w32_result
fi
func_convert_file_check "$1" "$func_to_host_file_result"
}
@@ -1747,12 +3036,13 @@ func_convert_file_nix_to_w32 ()
# Returns result in func_to_host_file_result.
func_convert_file_msys_to_cygwin ()
{
- $opt_debug
- func_to_host_file_result="$1"
+ $debug_cmd
+
+ func_to_host_file_result=$1
if test -n "$1"; then
func_convert_core_msys_to_w32 "$1"
func_cygpath -u "$func_convert_core_msys_to_w32_result"
- func_to_host_file_result="$func_cygpath_result"
+ func_to_host_file_result=$func_cygpath_result
fi
func_convert_file_check "$1" "$func_to_host_file_result"
}
@@ -1765,13 +3055,14 @@ func_convert_file_msys_to_cygwin ()
# in func_to_host_file_result.
func_convert_file_nix_to_cygwin ()
{
- $opt_debug
- func_to_host_file_result="$1"
+ $debug_cmd
+
+ func_to_host_file_result=$1
if test -n "$1"; then
# convert from *nix to w32, then use cygpath to convert from w32 to cygwin.
func_convert_core_file_wine_to_w32 "$1"
func_cygpath -u "$func_convert_core_file_wine_to_w32_result"
- func_to_host_file_result="$func_cygpath_result"
+ func_to_host_file_result=$func_cygpath_result
fi
func_convert_file_check "$1" "$func_to_host_file_result"
}
@@ -1781,7 +3072,7 @@ func_convert_file_nix_to_cygwin ()
#############################################
# $build to $host PATH CONVERSION FUNCTIONS #
#############################################
-# invoked via `$to_host_path_cmd ARG'
+# invoked via '$to_host_path_cmd ARG'
#
# In each case, ARG is the path to be converted from $build to $host format.
# The result will be available in $func_to_host_path_result.
@@ -1805,10 +3096,11 @@ func_convert_file_nix_to_cygwin ()
to_host_path_cmd=
func_init_to_host_path_cmd ()
{
- $opt_debug
+ $debug_cmd
+
if test -z "$to_host_path_cmd"; then
func_stripname 'func_convert_file_' '' "$to_host_file_cmd"
- to_host_path_cmd="func_convert_path_${func_stripname_result}"
+ to_host_path_cmd=func_convert_path_$func_stripname_result
fi
}
@@ -1818,7 +3110,8 @@ func_init_to_host_path_cmd ()
# in func_to_host_path_result.
func_to_host_path ()
{
- $opt_debug
+ $debug_cmd
+
func_init_to_host_path_cmd
$to_host_path_cmd "$1"
}
@@ -1829,7 +3122,7 @@ func_to_host_path ()
# Copy ARG to func_to_host_path_result.
func_convert_path_noop ()
{
- func_to_host_path_result="$1"
+ func_to_host_path_result=$1
}
# end func_convert_path_noop
@@ -1840,8 +3133,9 @@ func_convert_path_noop ()
# func_to_host_path_result.
func_convert_path_msys_to_w32 ()
{
- $opt_debug
- func_to_host_path_result="$1"
+ $debug_cmd
+
+ func_to_host_path_result=$1
if test -n "$1"; then
# Remove leading and trailing path separator characters from ARG. MSYS
# behavior is inconsistent here; cygpath turns them into '.;' and ';.';
@@ -1849,7 +3143,7 @@ func_convert_path_msys_to_w32 ()
func_stripname : : "$1"
func_to_host_path_tmp1=$func_stripname_result
func_convert_core_msys_to_w32 "$func_to_host_path_tmp1"
- func_to_host_path_result="$func_convert_core_msys_to_w32_result"
+ func_to_host_path_result=$func_convert_core_msys_to_w32_result
func_convert_path_check : ";" \
"$func_to_host_path_tmp1" "$func_to_host_path_result"
func_convert_path_front_back_pathsep ":*" "*:" ";" "$1"
@@ -1863,8 +3157,9 @@ func_convert_path_msys_to_w32 ()
# func_to_host_file_result.
func_convert_path_cygwin_to_w32 ()
{
- $opt_debug
- func_to_host_path_result="$1"
+ $debug_cmd
+
+ func_to_host_path_result=$1
if test -n "$1"; then
# See func_convert_path_msys_to_w32:
func_stripname : : "$1"
@@ -1883,14 +3178,15 @@ func_convert_path_cygwin_to_w32 ()
# a working winepath. Returns result in func_to_host_file_result.
func_convert_path_nix_to_w32 ()
{
- $opt_debug
- func_to_host_path_result="$1"
+ $debug_cmd
+
+ func_to_host_path_result=$1
if test -n "$1"; then
# See func_convert_path_msys_to_w32:
func_stripname : : "$1"
func_to_host_path_tmp1=$func_stripname_result
func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1"
- func_to_host_path_result="$func_convert_core_path_wine_to_w32_result"
+ func_to_host_path_result=$func_convert_core_path_wine_to_w32_result
func_convert_path_check : ";" \
"$func_to_host_path_tmp1" "$func_to_host_path_result"
func_convert_path_front_back_pathsep ":*" "*:" ";" "$1"
@@ -1904,15 +3200,16 @@ func_convert_path_nix_to_w32 ()
# Returns result in func_to_host_file_result.
func_convert_path_msys_to_cygwin ()
{
- $opt_debug
- func_to_host_path_result="$1"
+ $debug_cmd
+
+ func_to_host_path_result=$1
if test -n "$1"; then
# See func_convert_path_msys_to_w32:
func_stripname : : "$1"
func_to_host_path_tmp1=$func_stripname_result
func_convert_core_msys_to_w32 "$func_to_host_path_tmp1"
func_cygpath -u -p "$func_convert_core_msys_to_w32_result"
- func_to_host_path_result="$func_cygpath_result"
+ func_to_host_path_result=$func_cygpath_result
func_convert_path_check : : \
"$func_to_host_path_tmp1" "$func_to_host_path_result"
func_convert_path_front_back_pathsep ":*" "*:" : "$1"
@@ -1927,8 +3224,9 @@ func_convert_path_msys_to_cygwin ()
# func_to_host_file_result.
func_convert_path_nix_to_cygwin ()
{
- $opt_debug
- func_to_host_path_result="$1"
+ $debug_cmd
+
+ func_to_host_path_result=$1
if test -n "$1"; then
# Remove leading and trailing path separator characters from
# ARG. msys behavior is inconsistent here, cygpath turns them
@@ -1937,7 +3235,7 @@ func_convert_path_nix_to_cygwin ()
func_to_host_path_tmp1=$func_stripname_result
func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1"
func_cygpath -u -p "$func_convert_core_path_wine_to_w32_result"
- func_to_host_path_result="$func_cygpath_result"
+ func_to_host_path_result=$func_cygpath_result
func_convert_path_check : : \
"$func_to_host_path_tmp1" "$func_to_host_path_result"
func_convert_path_front_back_pathsep ":*" "*:" : "$1"
@@ -1946,13 +3244,31 @@ func_convert_path_nix_to_cygwin ()
# end func_convert_path_nix_to_cygwin
+# func_dll_def_p FILE
+# True iff FILE is a Windows DLL '.def' file.
+# Keep in sync with _LT_DLL_DEF_P in libtool.m4
+func_dll_def_p ()
+{
+ $debug_cmd
+
+ func_dll_def_p_tmp=`$SED -n \
+ -e 's/^[ ]*//' \
+ -e '/^\(;.*\)*$/d' \
+ -e 's/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p' \
+ -e q \
+ "$1"`
+ test DEF = "$func_dll_def_p_tmp"
+}
+
+
# func_mode_compile arg...
func_mode_compile ()
{
- $opt_debug
+ $debug_cmd
+
# Get the compilation command and the source file.
base_compile=
- srcfile="$nonopt" # always keep a non-empty value in "srcfile"
+ srcfile=$nonopt # always keep a non-empty value in "srcfile"
suppress_opt=yes
suppress_output=
arg_mode=normal
@@ -1965,12 +3281,12 @@ func_mode_compile ()
case $arg_mode in
arg )
# do not "continue". Instead, add this to base_compile
- lastarg="$arg"
+ lastarg=$arg
arg_mode=normal
;;
target )
- libobj="$arg"
+ libobj=$arg
arg_mode=normal
continue
;;
@@ -1980,7 +3296,7 @@ func_mode_compile ()
case $arg in
-o)
test -n "$libobj" && \
- func_fatal_error "you cannot specify \`-o' more than once"
+ func_fatal_error "you cannot specify '-o' more than once"
arg_mode=target
continue
;;
@@ -2009,12 +3325,12 @@ func_mode_compile ()
func_stripname '-Wc,' '' "$arg"
args=$func_stripname_result
lastarg=
- save_ifs="$IFS"; IFS=','
+ save_ifs=$IFS; IFS=,
for arg in $args; do
- IFS="$save_ifs"
+ IFS=$save_ifs
func_append_quoted lastarg "$arg"
done
- IFS="$save_ifs"
+ IFS=$save_ifs
func_stripname ' ' '' "$lastarg"
lastarg=$func_stripname_result
@@ -2027,8 +3343,8 @@ func_mode_compile ()
# Accept the current argument as the source file.
# The previous "srcfile" becomes the current argument.
#
- lastarg="$srcfile"
- srcfile="$arg"
+ lastarg=$srcfile
+ srcfile=$arg
;;
esac # case $arg
;;
@@ -2043,13 +3359,13 @@ func_mode_compile ()
func_fatal_error "you must specify an argument for -Xcompile"
;;
target)
- func_fatal_error "you must specify a target with \`-o'"
+ func_fatal_error "you must specify a target with '-o'"
;;
*)
# Get the name of the library object.
test -z "$libobj" && {
func_basename "$srcfile"
- libobj="$func_basename_result"
+ libobj=$func_basename_result
}
;;
esac
@@ -2069,7 +3385,7 @@ func_mode_compile ()
case $libobj in
*.lo) func_lo2o "$libobj"; obj=$func_lo2o_result ;;
*)
- func_fatal_error "cannot determine name of library object from \`$libobj'"
+ func_fatal_error "cannot determine name of library object from '$libobj'"
;;
esac
@@ -2078,8 +3394,8 @@ func_mode_compile ()
for arg in $later; do
case $arg in
-shared)
- test "$build_libtool_libs" != yes && \
- func_fatal_configuration "can not build a shared library"
+ test yes = "$build_libtool_libs" \
+ || func_fatal_configuration "cannot build a shared library"
build_old_libs=no
continue
;;
@@ -2105,17 +3421,17 @@ func_mode_compile ()
func_quote_for_eval "$libobj"
test "X$libobj" != "X$func_quote_for_eval_result" \
&& $ECHO "X$libobj" | $GREP '[]~#^*{};<>?"'"'"' &()|`$[]' \
- && func_warning "libobj name \`$libobj' may not contain shell special characters."
+ && func_warning "libobj name '$libobj' may not contain shell special characters."
func_dirname_and_basename "$obj" "/" ""
- objname="$func_basename_result"
- xdir="$func_dirname_result"
- lobj=${xdir}$objdir/$objname
+ objname=$func_basename_result
+ xdir=$func_dirname_result
+ lobj=$xdir$objdir/$objname
test -z "$base_compile" && \
func_fatal_help "you must specify a compilation command"
# Delete any leftover library objects.
- if test "$build_old_libs" = yes; then
+ if test yes = "$build_old_libs"; then
removelist="$obj $lobj $libobj ${libobj}T"
else
removelist="$lobj $libobj ${libobj}T"
@@ -2127,16 +3443,16 @@ func_mode_compile ()
pic_mode=default
;;
esac
- if test "$pic_mode" = no && test "$deplibs_check_method" != pass_all; then
+ if test no = "$pic_mode" && test pass_all != "$deplibs_check_method"; then
# non-PIC code in shared libraries is not supported
pic_mode=default
fi
# Calculate the filename of the output object if compiler does
# not support -o with -c
- if test "$compiler_c_o" = no; then
- output_obj=`$ECHO "$srcfile" | $SED 's%^.*/%%; s%\.[^.]*$%%'`.${objext}
- lockfile="$output_obj.lock"
+ if test no = "$compiler_c_o"; then
+ output_obj=`$ECHO "$srcfile" | $SED 's%^.*/%%; s%\.[^.]*$%%'`.$objext
+ lockfile=$output_obj.lock
else
output_obj=
need_locks=no
@@ -2145,12 +3461,12 @@ func_mode_compile ()
# Lock this critical section if it is needed
# We use this script file to make the link, it avoids creating a new file
- if test "$need_locks" = yes; then
+ if test yes = "$need_locks"; then
until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do
func_echo "Waiting for $lockfile to be removed"
sleep 2
done
- elif test "$need_locks" = warn; then
+ elif test warn = "$need_locks"; then
if test -f "$lockfile"; then
$ECHO "\
*** ERROR, $lockfile exists and contains:
@@ -2158,7 +3474,7 @@ func_mode_compile ()
This indicates that another process is trying to use the same
temporary object file, and libtool could not work around it because
-your compiler does not support \`-c' and \`-o' together. If you
+your compiler does not support '-c' and '-o' together. If you
repeat this compilation, it may succeed, by chance, but you had better
avoid parallel builds (make -j) in this platform, or get a better
compiler."
@@ -2180,11 +3496,11 @@ compiler."
qsrcfile=$func_quote_for_eval_result
# Only build a PIC object if we are building libtool libraries.
- if test "$build_libtool_libs" = yes; then
+ if test yes = "$build_libtool_libs"; then
# Without this assignment, base_compile gets emptied.
fbsd_hideous_sh_bug=$base_compile
- if test "$pic_mode" != no; then
+ if test no != "$pic_mode"; then
command="$base_compile $qsrcfile $pic_flag"
else
# Don't build PIC code
@@ -2201,7 +3517,7 @@ compiler."
func_show_eval_locale "$command" \
'test -n "$output_obj" && $RM $removelist; exit $EXIT_FAILURE'
- if test "$need_locks" = warn &&
+ if test warn = "$need_locks" &&
test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then
$ECHO "\
*** ERROR, $lockfile contains:
@@ -2212,7 +3528,7 @@ $srcfile
This indicates that another process is trying to use the same
temporary object file, and libtool could not work around it because
-your compiler does not support \`-c' and \`-o' together. If you
+your compiler does not support '-c' and '-o' together. If you
repeat this compilation, it may succeed, by chance, but you had better
avoid parallel builds (make -j) in this platform, or get a better
compiler."
@@ -2228,20 +3544,20 @@ compiler."
fi
# Allow error messages only from the first compilation.
- if test "$suppress_opt" = yes; then
+ if test yes = "$suppress_opt"; then
suppress_output=' >/dev/null 2>&1'
fi
fi
# Only build a position-dependent object if we build old libraries.
- if test "$build_old_libs" = yes; then
- if test "$pic_mode" != yes; then
+ if test yes = "$build_old_libs"; then
+ if test yes != "$pic_mode"; then
# Don't build PIC code
command="$base_compile $qsrcfile$pie_flag"
else
command="$base_compile $qsrcfile $pic_flag"
fi
- if test "$compiler_c_o" = yes; then
+ if test yes = "$compiler_c_o"; then
func_append command " -o $obj"
fi
@@ -2250,7 +3566,7 @@ compiler."
func_show_eval_locale "$command" \
'$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE'
- if test "$need_locks" = warn &&
+ if test warn = "$need_locks" &&
test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then
$ECHO "\
*** ERROR, $lockfile contains:
@@ -2261,7 +3577,7 @@ $srcfile
This indicates that another process is trying to use the same
temporary object file, and libtool could not work around it because
-your compiler does not support \`-c' and \`-o' together. If you
+your compiler does not support '-c' and '-o' together. If you
repeat this compilation, it may succeed, by chance, but you had better
avoid parallel builds (make -j) in this platform, or get a better
compiler."
@@ -2281,7 +3597,7 @@ compiler."
func_write_libtool_object "$libobj" "$objdir/$objname" "$objname"
# Unlock the critical section if it was locked
- if test "$need_locks" != no; then
+ if test no != "$need_locks"; then
removelist=$lockfile
$RM "$lockfile"
fi
@@ -2291,7 +3607,7 @@ compiler."
}
$opt_help || {
- test "$opt_mode" = compile && func_mode_compile ${1+"$@"}
+ test compile = "$opt_mode" && func_mode_compile ${1+"$@"}
}
func_mode_help ()
@@ -2311,7 +3627,7 @@ func_mode_help ()
Remove files from the build directory.
RM is the name of the program to use to delete files associated with each FILE
-(typically \`/bin/rm'). RM-OPTIONS are options (such as \`-f') to be passed
+(typically '/bin/rm'). RM-OPTIONS are options (such as '-f') to be passed
to RM.
If FILE is a libtool library, object or program, all the files associated
@@ -2330,16 +3646,16 @@ This mode accepts the following additional options:
-no-suppress do not suppress compiler output for multiple passes
-prefer-pic try to build PIC objects only
-prefer-non-pic try to build non-PIC objects only
- -shared do not build a \`.o' file suitable for static linking
- -static only build a \`.o' file suitable for static linking
+ -shared do not build a '.o' file suitable for static linking
+ -static only build a '.o' file suitable for static linking
-Wc,FLAG pass FLAG directly to the compiler
-COMPILE-COMMAND is a command to be used in creating a \`standard' object file
+COMPILE-COMMAND is a command to be used in creating a 'standard' object file
from the given SOURCEFILE.
The output file name is determined by removing the directory component from
-SOURCEFILE, then substituting the C source code suffix \`.c' with the
-library object suffix, \`.lo'."
+SOURCEFILE, then substituting the C source code suffix '.c' with the
+library object suffix, '.lo'."
;;
execute)
@@ -2352,7 +3668,7 @@ This mode accepts the following additional options:
-dlopen FILE add the directory containing FILE to the library path
-This mode sets the library path environment variable according to \`-dlopen'
+This mode sets the library path environment variable according to '-dlopen'
flags.
If any of the ARGS are libtool executable wrappers, then they are translated
@@ -2371,7 +3687,7 @@ Complete the installation of libtool libraries.
Each LIBDIR is a directory that contains libtool libraries.
The commands that this mode executes may require superuser privileges. Use
-the \`--dry-run' option if you just want to see what would be executed."
+the '--dry-run' option if you just want to see what would be executed."
;;
install)
@@ -2381,7 +3697,7 @@ the \`--dry-run' option if you just want to see what would be executed."
Install executables or libraries.
INSTALL-COMMAND is the installation command. The first component should be
-either the \`install' or \`cp' program.
+either the 'install' or 'cp' program.
The following components of INSTALL-COMMAND are treated specially:
@@ -2407,7 +3723,7 @@ The following components of LINK-COMMAND are treated specially:
-avoid-version do not add a version suffix if possible
-bindir BINDIR specify path to binaries directory (for systems where
libraries must be found in the PATH setting at runtime)
- -dlopen FILE \`-dlpreopen' FILE if it cannot be dlopened at runtime
+ -dlopen FILE '-dlpreopen' FILE if it cannot be dlopened at runtime
-dlpreopen FILE link in FILE and add its symbols to lt_preloaded_symbols
-export-dynamic allow symbols from OUTPUT-FILE to be resolved with dlsym(3)
-export-symbols SYMFILE
@@ -2421,7 +3737,8 @@ The following components of LINK-COMMAND are treated specially:
-no-install link a not-installable executable
-no-undefined declare that a library does not refer to external symbols
-o OUTPUT-FILE create OUTPUT-FILE from the specified objects
- -objectlist FILE Use a list of object files found in FILE to specify objects
+ -objectlist FILE use a list of object files found in FILE to specify objects
+ -os2dllname NAME force a short DLL name on OS/2 (no effect on other OSes)
-precious-files-regex REGEX
don't remove output files matching REGEX
-release RELEASE specify package release information
@@ -2441,20 +3758,20 @@ The following components of LINK-COMMAND are treated specially:
-Xlinker FLAG pass linker-specific FLAG directly to the linker
-XCClinker FLAG pass link-specific FLAG to the compiler driver (CC)
-All other options (arguments beginning with \`-') are ignored.
+All other options (arguments beginning with '-') are ignored.
-Every other argument is treated as a filename. Files ending in \`.la' are
+Every other argument is treated as a filename. Files ending in '.la' are
treated as uninstalled libtool libraries, other files are standard or library
object files.
-If the OUTPUT-FILE ends in \`.la', then a libtool library is created,
-only library objects (\`.lo' files) may be specified, and \`-rpath' is
+If the OUTPUT-FILE ends in '.la', then a libtool library is created,
+only library objects ('.lo' files) may be specified, and '-rpath' is
required, except when creating a convenience library.
-If OUTPUT-FILE ends in \`.a' or \`.lib', then a standard library is created
-using \`ar' and \`ranlib', or on Windows using \`lib'.
+If OUTPUT-FILE ends in '.a' or '.lib', then a standard library is created
+using 'ar' and 'ranlib', or on Windows using 'lib'.
-If OUTPUT-FILE ends in \`.lo' or \`.${objext}', then a reloadable object file
+If OUTPUT-FILE ends in '.lo' or '.$objext', then a reloadable object file
is created, otherwise an executable program is created."
;;
@@ -2465,7 +3782,7 @@ is created, otherwise an executable program is created."
Remove libraries from an installation directory.
RM is the name of the program to use to delete files associated with each FILE
-(typically \`/bin/rm'). RM-OPTIONS are options (such as \`-f') to be passed
+(typically '/bin/rm'). RM-OPTIONS are options (such as '-f') to be passed
to RM.
If FILE is a libtool library, all the files associated with it are deleted.
@@ -2473,17 +3790,17 @@ Otherwise, only FILE itself is deleted using RM."
;;
*)
- func_fatal_help "invalid operation mode \`$opt_mode'"
+ func_fatal_help "invalid operation mode '$opt_mode'"
;;
esac
echo
- $ECHO "Try \`$progname --help' for more information about other modes."
+ $ECHO "Try '$progname --help' for more information about other modes."
}
# Now that we've collected a possible --mode arg, show help if necessary
if $opt_help; then
- if test "$opt_help" = :; then
+ if test : = "$opt_help"; then
func_mode_help
else
{
@@ -2491,7 +3808,7 @@ if $opt_help; then
for opt_mode in compile link execute install finish uninstall clean; do
func_mode_help
done
- } | sed -n '1p; 2,$s/^Usage:/ or: /p'
+ } | $SED -n '1p; 2,$s/^Usage:/ or: /p'
{
func_help noexit
for opt_mode in compile link execute install finish uninstall clean; do
@@ -2499,7 +3816,7 @@ if $opt_help; then
func_mode_help
done
} |
- sed '1d
+ $SED '1d
/^When reporting/,/^Report/{
H
d
@@ -2516,16 +3833,17 @@ fi
# func_mode_execute arg...
func_mode_execute ()
{
- $opt_debug
+ $debug_cmd
+
# The first argument is the command name.
- cmd="$nonopt"
+ cmd=$nonopt
test -z "$cmd" && \
func_fatal_help "you must specify a COMMAND"
# Handle -dlopen flags immediately.
for file in $opt_dlopen; do
test -f "$file" \
- || func_fatal_help "\`$file' is not a file"
+ || func_fatal_help "'$file' is not a file"
dir=
case $file in
@@ -2535,7 +3853,7 @@ func_mode_execute ()
# Check to see that this really is a libtool archive.
func_lalib_unsafe_p "$file" \
- || func_fatal_help "\`$lib' is not a valid libtool archive"
+ || func_fatal_help "'$lib' is not a valid libtool archive"
# Read the libtool library.
dlname=
@@ -2546,18 +3864,18 @@ func_mode_execute ()
if test -z "$dlname"; then
# Warn if it was a shared library.
test -n "$library_names" && \
- func_warning "\`$file' was not linked with \`-export-dynamic'"
+ func_warning "'$file' was not linked with '-export-dynamic'"
continue
fi
func_dirname "$file" "" "."
- dir="$func_dirname_result"
+ dir=$func_dirname_result
if test -f "$dir/$objdir/$dlname"; then
func_append dir "/$objdir"
else
if test ! -f "$dir/$dlname"; then
- func_fatal_error "cannot find \`$dlname' in \`$dir' or \`$dir/$objdir'"
+ func_fatal_error "cannot find '$dlname' in '$dir' or '$dir/$objdir'"
fi
fi
;;
@@ -2565,18 +3883,18 @@ func_mode_execute ()
*.lo)
# Just add the directory containing the .lo file.
func_dirname "$file" "" "."
- dir="$func_dirname_result"
+ dir=$func_dirname_result
;;
*)
- func_warning "\`-dlopen' is ignored for non-libtool libraries and objects"
+ func_warning "'-dlopen' is ignored for non-libtool libraries and objects"
continue
;;
esac
# Get the absolute pathname.
absdir=`cd "$dir" && pwd`
- test -n "$absdir" && dir="$absdir"
+ test -n "$absdir" && dir=$absdir
# Now add the directory to shlibpath_var.
if eval "test -z \"\$$shlibpath_var\""; then
@@ -2588,7 +3906,7 @@ func_mode_execute ()
# This variable tells wrapper scripts just to set shlibpath_var
# rather than running their programs.
- libtool_execute_magic="$magic"
+ libtool_execute_magic=$magic
# Check if any of the arguments is a wrapper script.
args=
@@ -2601,12 +3919,12 @@ func_mode_execute ()
if func_ltwrapper_script_p "$file"; then
func_source "$file"
# Transform arg to wrapped name.
- file="$progdir/$program"
+ file=$progdir/$program
elif func_ltwrapper_executable_p "$file"; then
func_ltwrapper_scriptname "$file"
func_source "$func_ltwrapper_scriptname_result"
# Transform arg to wrapped name.
- file="$progdir/$program"
+ file=$progdir/$program
fi
;;
esac
@@ -2614,7 +3932,15 @@ func_mode_execute ()
func_append_quoted args "$file"
done
- if test "X$opt_dry_run" = Xfalse; then
+ if $opt_dry_run; then
+ # Display what would be done.
+ if test -n "$shlibpath_var"; then
+ eval "\$ECHO \"\$shlibpath_var=\$$shlibpath_var\""
+ echo "export $shlibpath_var"
+ fi
+ $ECHO "$cmd$args"
+ exit $EXIT_SUCCESS
+ else
if test -n "$shlibpath_var"; then
# Export the shlibpath_var.
eval "export $shlibpath_var"
@@ -2631,25 +3957,18 @@ func_mode_execute ()
done
# Now prepare to actually exec the command.
- exec_cmd="\$cmd$args"
- else
- # Display what would be done.
- if test -n "$shlibpath_var"; then
- eval "\$ECHO \"\$shlibpath_var=\$$shlibpath_var\""
- echo "export $shlibpath_var"
- fi
- $ECHO "$cmd$args"
- exit $EXIT_SUCCESS
+ exec_cmd=\$cmd$args
fi
}
-test "$opt_mode" = execute && func_mode_execute ${1+"$@"}
+test execute = "$opt_mode" && func_mode_execute ${1+"$@"}
# func_mode_finish arg...
func_mode_finish ()
{
- $opt_debug
+ $debug_cmd
+
libs=
libdirs=
admincmds=
@@ -2663,11 +3982,11 @@ func_mode_finish ()
if func_lalib_unsafe_p "$opt"; then
func_append libs " $opt"
else
- func_warning "\`$opt' is not a valid libtool archive"
+ func_warning "'$opt' is not a valid libtool archive"
fi
else
- func_fatal_error "invalid argument \`$opt'"
+ func_fatal_error "invalid argument '$opt'"
fi
done
@@ -2682,12 +4001,12 @@ func_mode_finish ()
# Remove sysroot references
if $opt_dry_run; then
for lib in $libs; do
- echo "removing references to $lt_sysroot and \`=' prefixes from $lib"
+ echo "removing references to $lt_sysroot and '=' prefixes from $lib"
done
else
tmpdir=`func_mktempdir`
for lib in $libs; do
- sed -e "${sysroot_cmd} s/\([ ']-[LR]\)=/\1/g; s/\([ ']\)=/\1/g" $lib \
+ $SED -e "$sysroot_cmd s/\([ ']-[LR]\)=/\1/g; s/\([ ']\)=/\1/g" $lib \
> $tmpdir/tmp-la
mv -f $tmpdir/tmp-la $lib
done
@@ -2712,7 +4031,7 @@ func_mode_finish ()
fi
# Exit here if they wanted silent mode.
- $opt_silent && exit $EXIT_SUCCESS
+ $opt_quiet && exit $EXIT_SUCCESS
if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then
echo "----------------------------------------------------------------------"
@@ -2723,27 +4042,27 @@ func_mode_finish ()
echo
echo "If you ever happen to want to link against installed libraries"
echo "in a given directory, LIBDIR, you must either use libtool, and"
- echo "specify the full pathname of the library, or use the \`-LLIBDIR'"
+ echo "specify the full pathname of the library, or use the '-LLIBDIR'"
echo "flag during linking and do at least one of the following:"
if test -n "$shlibpath_var"; then
- echo " - add LIBDIR to the \`$shlibpath_var' environment variable"
+ echo " - add LIBDIR to the '$shlibpath_var' environment variable"
echo " during execution"
fi
if test -n "$runpath_var"; then
- echo " - add LIBDIR to the \`$runpath_var' environment variable"
+ echo " - add LIBDIR to the '$runpath_var' environment variable"
echo " during linking"
fi
if test -n "$hardcode_libdir_flag_spec"; then
libdir=LIBDIR
eval flag=\"$hardcode_libdir_flag_spec\"
- $ECHO " - use the \`$flag' linker flag"
+ $ECHO " - use the '$flag' linker flag"
fi
if test -n "$admincmds"; then
$ECHO " - have your system administrator run these commands:$admincmds"
fi
if test -f /etc/ld.so.conf; then
- echo " - have your system administrator add LIBDIR to \`/etc/ld.so.conf'"
+ echo " - have your system administrator add LIBDIR to '/etc/ld.so.conf'"
fi
echo
@@ -2762,18 +4081,20 @@ func_mode_finish ()
exit $EXIT_SUCCESS
}
-test "$opt_mode" = finish && func_mode_finish ${1+"$@"}
+test finish = "$opt_mode" && func_mode_finish ${1+"$@"}
# func_mode_install arg...
func_mode_install ()
{
- $opt_debug
+ $debug_cmd
+
# There may be an optional sh(1) argument at the beginning of
# install_prog (especially on Windows NT).
- if test "$nonopt" = "$SHELL" || test "$nonopt" = /bin/sh ||
+ if test "$SHELL" = "$nonopt" || test /bin/sh = "$nonopt" ||
# Allow the use of GNU shtool's install command.
- case $nonopt in *shtool*) :;; *) false;; esac; then
+ case $nonopt in *shtool*) :;; *) false;; esac
+ then
# Aesthetically quote it.
func_quote_for_eval "$nonopt"
install_prog="$func_quote_for_eval_result "
@@ -2800,7 +4121,7 @@ func_mode_install ()
opts=
prev=
install_type=
- isdir=no
+ isdir=false
stripme=
no_mode=:
for arg
@@ -2813,7 +4134,7 @@ func_mode_install ()
fi
case $arg in
- -d) isdir=yes ;;
+ -d) isdir=: ;;
-f)
if $install_cp; then :; else
prev=$arg
@@ -2831,7 +4152,7 @@ func_mode_install ()
*)
# If the previous option needed an argument, then skip it.
if test -n "$prev"; then
- if test "x$prev" = x-m && test -n "$install_override_mode"; then
+ if test X-m = "X$prev" && test -n "$install_override_mode"; then
arg2=$install_override_mode
no_mode=false
fi
@@ -2856,7 +4177,7 @@ func_mode_install ()
func_fatal_help "you must specify an install program"
test -n "$prev" && \
- func_fatal_help "the \`$prev' option requires an argument"
+ func_fatal_help "the '$prev' option requires an argument"
if test -n "$install_override_mode" && $no_mode; then
if $install_cp; then :; else
@@ -2878,19 +4199,19 @@ func_mode_install ()
dest=$func_stripname_result
# Check to see that the destination is a directory.
- test -d "$dest" && isdir=yes
- if test "$isdir" = yes; then
- destdir="$dest"
+ test -d "$dest" && isdir=:
+ if $isdir; then
+ destdir=$dest
destname=
else
func_dirname_and_basename "$dest" "" "."
- destdir="$func_dirname_result"
- destname="$func_basename_result"
+ destdir=$func_dirname_result
+ destname=$func_basename_result
# Not a directory, so check to see that there is only one file specified.
set dummy $files; shift
test "$#" -gt 1 && \
- func_fatal_help "\`$dest' is not a directory"
+ func_fatal_help "'$dest' is not a directory"
fi
case $destdir in
[\\/]* | [A-Za-z]:[\\/]*) ;;
@@ -2899,7 +4220,7 @@ func_mode_install ()
case $file in
*.lo) ;;
*)
- func_fatal_help "\`$destdir' must be an absolute directory name"
+ func_fatal_help "'$destdir' must be an absolute directory name"
;;
esac
done
@@ -2908,7 +4229,7 @@ func_mode_install ()
# This variable tells wrapper scripts just to set variables rather
# than running their programs.
- libtool_install_magic="$magic"
+ libtool_install_magic=$magic
staticlibs=
future_libdirs=
@@ -2928,7 +4249,7 @@ func_mode_install ()
# Check to see that this really is a libtool archive.
func_lalib_unsafe_p "$file" \
- || func_fatal_help "\`$file' is not a valid libtool archive"
+ || func_fatal_help "'$file' is not a valid libtool archive"
library_names=
old_library=
@@ -2950,7 +4271,7 @@ func_mode_install ()
fi
func_dirname "$file" "/" ""
- dir="$func_dirname_result"
+ dir=$func_dirname_result
func_append dir "$objdir"
if test -n "$relink_command"; then
@@ -2964,7 +4285,7 @@ func_mode_install ()
# are installed into $libdir/../bin (currently, that works fine)
# but it's something to keep an eye on.
test "$inst_prefix_dir" = "$destdir" && \
- func_fatal_error "error: cannot install \`$file' to a directory not ending in $libdir"
+ func_fatal_error "error: cannot install '$file' to a directory not ending in $libdir"
if test -n "$inst_prefix_dir"; then
# Stick the inst_prefix_dir data into the link command.
@@ -2973,29 +4294,36 @@ func_mode_install ()
relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%%"`
fi
- func_warning "relinking \`$file'"
+ func_warning "relinking '$file'"
func_show_eval "$relink_command" \
- 'func_fatal_error "error: relink \`$file'\'' with the above command before installing it"'
+ 'func_fatal_error "error: relink '\''$file'\'' with the above command before installing it"'
fi
# See the names of the shared library.
set dummy $library_names; shift
if test -n "$1"; then
- realname="$1"
+ realname=$1
shift
- srcname="$realname"
- test -n "$relink_command" && srcname="$realname"T
+ srcname=$realname
+ test -n "$relink_command" && srcname=${realname}T
# Install the shared library and build the symlinks.
func_show_eval "$install_shared_prog $dir/$srcname $destdir/$realname" \
'exit $?'
- tstripme="$stripme"
+ tstripme=$stripme
case $host_os in
cygwin* | mingw* | pw32* | cegcc*)
case $realname in
*.dll.a)
- tstripme=""
+ tstripme=
+ ;;
+ esac
+ ;;
+ os2*)
+ case $realname in
+ *_dll.a)
+ tstripme=
;;
esac
;;
@@ -3006,7 +4334,7 @@ func_mode_install ()
if test "$#" -gt 0; then
# Delete the old symlinks, and create new ones.
- # Try `ln -sf' first, because the `ln' binary might depend on
+ # Try 'ln -sf' first, because the 'ln' binary might depend on
# the symlink we replace! Solaris /bin/ln does not understand -f,
# so we also need to try rm && ln -s.
for linkname
@@ -3017,14 +4345,14 @@ func_mode_install ()
fi
# Do each command in the postinstall commands.
- lib="$destdir/$realname"
+ lib=$destdir/$realname
func_execute_cmds "$postinstall_cmds" 'exit $?'
fi
# Install the pseudo-library for information purposes.
func_basename "$file"
- name="$func_basename_result"
- instname="$dir/$name"i
+ name=$func_basename_result
+ instname=$dir/${name}i
func_show_eval "$install_prog $instname $destdir/$name" 'exit $?'
# Maybe install the static library, too.
@@ -3036,11 +4364,11 @@ func_mode_install ()
# Figure out destination file name, if it wasn't already specified.
if test -n "$destname"; then
- destfile="$destdir/$destname"
+ destfile=$destdir/$destname
else
func_basename "$file"
- destfile="$func_basename_result"
- destfile="$destdir/$destfile"
+ destfile=$func_basename_result
+ destfile=$destdir/$destfile
fi
# Deduce the name of the destination old-style object file.
@@ -3050,11 +4378,11 @@ func_mode_install ()
staticdest=$func_lo2o_result
;;
*.$objext)
- staticdest="$destfile"
+ staticdest=$destfile
destfile=
;;
*)
- func_fatal_help "cannot copy a libtool object to \`$destfile'"
+ func_fatal_help "cannot copy a libtool object to '$destfile'"
;;
esac
@@ -3063,7 +4391,7 @@ func_mode_install ()
func_show_eval "$install_prog $file $destfile" 'exit $?'
# Install the old object if enabled.
- if test "$build_old_libs" = yes; then
+ if test yes = "$build_old_libs"; then
# Deduce the name of the old-style object file.
func_lo2o "$file"
staticobj=$func_lo2o_result
@@ -3075,23 +4403,23 @@ func_mode_install ()
*)
# Figure out destination file name, if it wasn't already specified.
if test -n "$destname"; then
- destfile="$destdir/$destname"
+ destfile=$destdir/$destname
else
func_basename "$file"
- destfile="$func_basename_result"
- destfile="$destdir/$destfile"
+ destfile=$func_basename_result
+ destfile=$destdir/$destfile
fi
# If the file is missing, and there is a .exe on the end, strip it
# because it is most likely a libtool script we actually want to
# install
- stripped_ext=""
+ stripped_ext=
case $file in
*.exe)
if test ! -f "$file"; then
func_stripname '' '.exe' "$file"
file=$func_stripname_result
- stripped_ext=".exe"
+ stripped_ext=.exe
fi
;;
esac
@@ -3119,19 +4447,19 @@ func_mode_install ()
# Check the variables that should have been set.
test -z "$generated_by_libtool_version" && \
- func_fatal_error "invalid libtool wrapper script \`$wrapper'"
+ func_fatal_error "invalid libtool wrapper script '$wrapper'"
- finalize=yes
+ finalize=:
for lib in $notinst_deplibs; do
# Check to see that each library is installed.
libdir=
if test -f "$lib"; then
func_source "$lib"
fi
- libfile="$libdir/"`$ECHO "$lib" | $SED 's%^.*/%%g'` ### testsuite: skip nested quoting test
+ libfile=$libdir/`$ECHO "$lib" | $SED 's%^.*/%%g'`
if test -n "$libdir" && test ! -f "$libfile"; then
- func_warning "\`$lib' has not been installed in \`$libdir'"
- finalize=no
+ func_warning "'$lib' has not been installed in '$libdir'"
+ finalize=false
fi
done
@@ -3139,29 +4467,29 @@ func_mode_install ()
func_source "$wrapper"
outputname=
- if test "$fast_install" = no && test -n "$relink_command"; then
+ if test no = "$fast_install" && test -n "$relink_command"; then
$opt_dry_run || {
- if test "$finalize" = yes; then
+ if $finalize; then
tmpdir=`func_mktempdir`
func_basename "$file$stripped_ext"
- file="$func_basename_result"
- outputname="$tmpdir/$file"
+ file=$func_basename_result
+ outputname=$tmpdir/$file
# Replace the output file specification.
relink_command=`$ECHO "$relink_command" | $SED 's%@OUTPUT@%'"$outputname"'%g'`
- $opt_silent || {
+ $opt_quiet || {
func_quote_for_expand "$relink_command"
eval "func_echo $func_quote_for_expand_result"
}
if eval "$relink_command"; then :
else
- func_error "error: relink \`$file' with the above command before installing it"
+ func_error "error: relink '$file' with the above command before installing it"
$opt_dry_run || ${RM}r "$tmpdir"
continue
fi
- file="$outputname"
+ file=$outputname
else
- func_warning "cannot relink \`$file'"
+ func_warning "cannot relink '$file'"
fi
}
else
@@ -3198,10 +4526,10 @@ func_mode_install ()
for file in $staticlibs; do
func_basename "$file"
- name="$func_basename_result"
+ name=$func_basename_result
# Set up the ranlib parameters.
- oldlib="$destdir/$name"
+ oldlib=$destdir/$name
func_to_tool_file "$oldlib" func_convert_file_msys_to_w32
tool_oldlib=$func_to_tool_file_result
@@ -3216,18 +4544,18 @@ func_mode_install ()
done
test -n "$future_libdirs" && \
- func_warning "remember to run \`$progname --finish$future_libdirs'"
+ func_warning "remember to run '$progname --finish$future_libdirs'"
if test -n "$current_libdirs"; then
# Maybe just do a dry run.
$opt_dry_run && current_libdirs=" -n$current_libdirs"
- exec_cmd='$SHELL $progpath $preserve_args --finish$current_libdirs'
+ exec_cmd='$SHELL "$progpath" $preserve_args --finish$current_libdirs'
else
exit $EXIT_SUCCESS
fi
}
-test "$opt_mode" = install && func_mode_install ${1+"$@"}
+test install = "$opt_mode" && func_mode_install ${1+"$@"}
# func_generate_dlsyms outputname originator pic_p
@@ -3235,16 +4563,17 @@ test "$opt_mode" = install && func_mode_install ${1+"$@"}
# a dlpreopen symbol table.
func_generate_dlsyms ()
{
- $opt_debug
- my_outputname="$1"
- my_originator="$2"
- my_pic_p="${3-no}"
- my_prefix=`$ECHO "$my_originator" | sed 's%[^a-zA-Z0-9]%_%g'`
+ $debug_cmd
+
+ my_outputname=$1
+ my_originator=$2
+ my_pic_p=${3-false}
+ my_prefix=`$ECHO "$my_originator" | $SED 's%[^a-zA-Z0-9]%_%g'`
my_dlsyms=
- if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then
+ if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then
if test -n "$NM" && test -n "$global_symbol_pipe"; then
- my_dlsyms="${my_outputname}S.c"
+ my_dlsyms=${my_outputname}S.c
else
func_error "not configured to extract global symbols from dlpreopened files"
fi
@@ -3255,7 +4584,7 @@ func_generate_dlsyms ()
"") ;;
*.c)
# Discover the nlist of each of the dlfiles.
- nlist="$output_objdir/${my_outputname}.nm"
+ nlist=$output_objdir/$my_outputname.nm
func_show_eval "$RM $nlist ${nlist}S ${nlist}T"
@@ -3263,34 +4592,36 @@ func_generate_dlsyms ()
func_verbose "creating $output_objdir/$my_dlsyms"
$opt_dry_run || $ECHO > "$output_objdir/$my_dlsyms" "\
-/* $my_dlsyms - symbol resolution table for \`$my_outputname' dlsym emulation. */
-/* Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION */
+/* $my_dlsyms - symbol resolution table for '$my_outputname' dlsym emulation. */
+/* Generated by $PROGRAM (GNU $PACKAGE) $VERSION */
#ifdef __cplusplus
extern \"C\" {
#endif
-#if defined(__GNUC__) && (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 4)) || (__GNUC__ > 4))
+#if defined __GNUC__ && (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 4)) || (__GNUC__ > 4))
#pragma GCC diagnostic ignored \"-Wstrict-prototypes\"
#endif
/* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */
-#if defined(_WIN32) || defined(__CYGWIN__) || defined(_WIN32_WCE)
-/* DATA imports from DLLs on WIN32 con't be const, because runtime
+#if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE
+/* DATA imports from DLLs on WIN32 can't be const, because runtime
relocations are performed -- see ld's documentation on pseudo-relocs. */
# define LT_DLSYM_CONST
-#elif defined(__osf__)
+#elif defined __osf__
/* This system does not cope well with relocations in const data. */
# define LT_DLSYM_CONST
#else
# define LT_DLSYM_CONST const
#endif
+#define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0)
+
/* External symbol declarations for the compiler. */\
"
- if test "$dlself" = yes; then
- func_verbose "generating symbol list for \`$output'"
+ if test yes = "$dlself"; then
+ func_verbose "generating symbol list for '$output'"
$opt_dry_run || echo ': @PROGRAM@ ' > "$nlist"
@@ -3298,7 +4629,7 @@ extern \"C\" {
progfiles=`$ECHO "$objs$old_deplibs" | $SP2NL | $SED "$lo2o" | $NL2SP`
for progfile in $progfiles; do
func_to_tool_file "$progfile" func_convert_file_msys_to_w32
- func_verbose "extracting global C symbols from \`$func_to_tool_file_result'"
+ func_verbose "extracting global C symbols from '$func_to_tool_file_result'"
$opt_dry_run || eval "$NM $func_to_tool_file_result | $global_symbol_pipe >> '$nlist'"
done
@@ -3318,10 +4649,10 @@ extern \"C\" {
# Prepare the list of exported symbols
if test -z "$export_symbols"; then
- export_symbols="$output_objdir/$outputname.exp"
+ export_symbols=$output_objdir/$outputname.exp
$opt_dry_run || {
$RM $export_symbols
- eval "${SED} -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"'
+ eval "$SED -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"'
case $host in
*cygwin* | *mingw* | *cegcc* )
eval "echo EXPORTS "'> "$output_objdir/$outputname.def"'
@@ -3331,7 +4662,7 @@ extern \"C\" {
}
else
$opt_dry_run || {
- eval "${SED} -e 's/\([].[*^$]\)/\\\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"'
+ eval "$SED -e 's/\([].[*^$]\)/\\\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"'
eval '$GREP -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlist"T'
eval '$MV "$nlist"T "$nlist"'
case $host in
@@ -3345,22 +4676,22 @@ extern \"C\" {
fi
for dlprefile in $dlprefiles; do
- func_verbose "extracting global C symbols from \`$dlprefile'"
+ func_verbose "extracting global C symbols from '$dlprefile'"
func_basename "$dlprefile"
- name="$func_basename_result"
+ name=$func_basename_result
case $host in
*cygwin* | *mingw* | *cegcc* )
# if an import library, we need to obtain dlname
if func_win32_import_lib_p "$dlprefile"; then
func_tr_sh "$dlprefile"
eval "curr_lafile=\$libfile_$func_tr_sh_result"
- dlprefile_dlbasename=""
+ dlprefile_dlbasename=
if test -n "$curr_lafile" && func_lalib_p "$curr_lafile"; then
# Use subshell, to avoid clobbering current variable values
dlprefile_dlname=`source "$curr_lafile" && echo "$dlname"`
- if test -n "$dlprefile_dlname" ; then
+ if test -n "$dlprefile_dlname"; then
func_basename "$dlprefile_dlname"
- dlprefile_dlbasename="$func_basename_result"
+ dlprefile_dlbasename=$func_basename_result
else
# no lafile. user explicitly requested -dlpreopen <import library>.
$sharedlib_from_linklib_cmd "$dlprefile"
@@ -3368,7 +4699,7 @@ extern \"C\" {
fi
fi
$opt_dry_run || {
- if test -n "$dlprefile_dlbasename" ; then
+ if test -n "$dlprefile_dlbasename"; then
eval '$ECHO ": $dlprefile_dlbasename" >> "$nlist"'
else
func_warning "Could not compute DLL name from $name"
@@ -3424,6 +4755,11 @@ extern \"C\" {
echo '/* NONE */' >> "$output_objdir/$my_dlsyms"
fi
+ func_show_eval '$RM "${nlist}I"'
+ if test -n "$global_symbol_to_import"; then
+ eval "$global_symbol_to_import"' < "$nlist"S > "$nlist"I'
+ fi
+
echo >> "$output_objdir/$my_dlsyms" "\
/* The mapping between symbol names and symbols. */
@@ -3432,11 +4768,30 @@ typedef struct {
void *address;
} lt_dlsymlist;
extern LT_DLSYM_CONST lt_dlsymlist
-lt_${my_prefix}_LTX_preloaded_symbols[];
+lt_${my_prefix}_LTX_preloaded_symbols[];\
+"
+
+ if test -s "$nlist"I; then
+ echo >> "$output_objdir/$my_dlsyms" "\
+static void lt_syminit(void)
+{
+ LT_DLSYM_CONST lt_dlsymlist *symbol = lt_${my_prefix}_LTX_preloaded_symbols;
+ for (; symbol->name; ++symbol)
+ {"
+ $SED 's/.*/ if (STREQ (symbol->name, \"&\")) symbol->address = (void *) \&&;/' < "$nlist"I >> "$output_objdir/$my_dlsyms"
+ echo >> "$output_objdir/$my_dlsyms" "\
+ }
+}"
+ fi
+ echo >> "$output_objdir/$my_dlsyms" "\
LT_DLSYM_CONST lt_dlsymlist
lt_${my_prefix}_LTX_preloaded_symbols[] =
-{\
- { \"$my_originator\", (void *) 0 },"
+{ {\"$my_originator\", (void *) 0},"
+
+ if test -s "$nlist"I; then
+ echo >> "$output_objdir/$my_dlsyms" "\
+ {\"@INIT@\", (void *) &lt_syminit},"
+ fi
case $need_lib_prefix in
no)
@@ -3478,9 +4833,7 @@ static const void *lt_preloaded_setup() {
*-*-hpux*)
pic_flag_for_symtable=" $pic_flag" ;;
*)
- if test "X$my_pic_p" != Xno; then
- pic_flag_for_symtable=" $pic_flag"
- fi
+ $my_pic_p && pic_flag_for_symtable=" $pic_flag"
;;
esac
;;
@@ -3497,10 +4850,10 @@ static const void *lt_preloaded_setup() {
func_show_eval '(cd $output_objdir && $LTCC$symtab_cflags -c$no_builtin_flag$pic_flag_for_symtable "$my_dlsyms")' 'exit $?'
# Clean up the generated files.
- func_show_eval '$RM "$output_objdir/$my_dlsyms" "$nlist" "${nlist}S" "${nlist}T"'
+ func_show_eval '$RM "$output_objdir/$my_dlsyms" "$nlist" "${nlist}S" "${nlist}T" "${nlist}I"'
# Transform the symbol file into the correct name.
- symfileobj="$output_objdir/${my_outputname}S.$objext"
+ symfileobj=$output_objdir/${my_outputname}S.$objext
case $host in
*cygwin* | *mingw* | *cegcc* )
if test -f "$output_objdir/$my_outputname.def"; then
@@ -3518,7 +4871,7 @@ static const void *lt_preloaded_setup() {
esac
;;
*)
- func_fatal_error "unknown suffix for \`$my_dlsyms'"
+ func_fatal_error "unknown suffix for '$my_dlsyms'"
;;
esac
else
@@ -3532,6 +4885,32 @@ static const void *lt_preloaded_setup() {
fi
}
+# func_cygming_gnu_implib_p ARG
+# This predicate returns with zero status (TRUE) if
+# ARG is a GNU/binutils-style import library. Returns
+# with nonzero status (FALSE) otherwise.
+func_cygming_gnu_implib_p ()
+{
+ $debug_cmd
+
+ func_to_tool_file "$1" func_convert_file_msys_to_w32
+ func_cygming_gnu_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $EGREP ' (_head_[A-Za-z0-9_]+_[ad]l*|[A-Za-z0-9_]+_[ad]l*_iname)$'`
+ test -n "$func_cygming_gnu_implib_tmp"
+}
+
+# func_cygming_ms_implib_p ARG
+# This predicate returns with zero status (TRUE) if
+# ARG is an MS-style import library. Returns
+# with nonzero status (FALSE) otherwise.
+func_cygming_ms_implib_p ()
+{
+ $debug_cmd
+
+ func_to_tool_file "$1" func_convert_file_msys_to_w32
+ func_cygming_ms_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $GREP '_NULL_IMPORT_DESCRIPTOR'`
+ test -n "$func_cygming_ms_implib_tmp"
+}
+
# func_win32_libid arg
# return the library type of file 'arg'
#
@@ -3541,8 +4920,9 @@ static const void *lt_preloaded_setup() {
# Despite the name, also deal with 64 bit binaries.
func_win32_libid ()
{
- $opt_debug
- win32_libid_type="unknown"
+ $debug_cmd
+
+ win32_libid_type=unknown
win32_fileres=`file -L $1 2>/dev/null`
case $win32_fileres in
*ar\ archive\ import\ library*) # definitely import
@@ -3552,16 +4932,29 @@ func_win32_libid ()
# Keep the egrep pattern in sync with the one in _LT_CHECK_MAGIC_METHOD.
if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null |
$EGREP 'file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' >/dev/null; then
- func_to_tool_file "$1" func_convert_file_msys_to_w32
- win32_nmres=`eval $NM -f posix -A \"$func_to_tool_file_result\" |
- $SED -n -e '
+ case $nm_interface in
+ "MS dumpbin")
+ if func_cygming_ms_implib_p "$1" ||
+ func_cygming_gnu_implib_p "$1"
+ then
+ win32_nmres=import
+ else
+ win32_nmres=
+ fi
+ ;;
+ *)
+ func_to_tool_file "$1" func_convert_file_msys_to_w32
+ win32_nmres=`eval $NM -f posix -A \"$func_to_tool_file_result\" |
+ $SED -n -e '
1,100{
/ I /{
- s,.*,import,
+ s|.*|import|
p
q
}
}'`
+ ;;
+ esac
case $win32_nmres in
import*) win32_libid_type="x86 archive import";;
*) win32_libid_type="x86 archive static";;
@@ -3593,7 +4986,8 @@ func_win32_libid ()
# $sharedlib_from_linklib_result
func_cygming_dll_for_implib ()
{
- $opt_debug
+ $debug_cmd
+
sharedlib_from_linklib_result=`$DLLTOOL --identify-strict --identify "$1"`
}
@@ -3610,7 +5004,8 @@ func_cygming_dll_for_implib ()
# specified import library.
func_cygming_dll_for_implib_fallback_core ()
{
- $opt_debug
+ $debug_cmd
+
match_literal=`$ECHO "$1" | $SED "$sed_make_literal_regex"`
$OBJDUMP -s --section "$1" "$2" 2>/dev/null |
$SED '/^Contents of section '"$match_literal"':/{
@@ -3646,8 +5041,8 @@ func_cygming_dll_for_implib_fallback_core ()
/./p' |
# we now have a list, one entry per line, of the stringified
# contents of the appropriate section of all members of the
- # archive which possess that section. Heuristic: eliminate
- # all those which have a first or second character that is
+ # archive that possess that section. Heuristic: eliminate
+ # all those that have a first or second character that is
# a '.' (that is, objdump's representation of an unprintable
# character.) This should work for all archives with less than
# 0x302f exports -- but will fail for DLLs whose name actually
@@ -3658,30 +5053,6 @@ func_cygming_dll_for_implib_fallback_core ()
$SED -e '/^\./d;/^.\./d;q'
}
-# func_cygming_gnu_implib_p ARG
-# This predicate returns with zero status (TRUE) if
-# ARG is a GNU/binutils-style import library. Returns
-# with nonzero status (FALSE) otherwise.
-func_cygming_gnu_implib_p ()
-{
- $opt_debug
- func_to_tool_file "$1" func_convert_file_msys_to_w32
- func_cygming_gnu_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $EGREP ' (_head_[A-Za-z0-9_]+_[ad]l*|[A-Za-z0-9_]+_[ad]l*_iname)$'`
- test -n "$func_cygming_gnu_implib_tmp"
-}
-
-# func_cygming_ms_implib_p ARG
-# This predicate returns with zero status (TRUE) if
-# ARG is an MS-style import library. Returns
-# with nonzero status (FALSE) otherwise.
-func_cygming_ms_implib_p ()
-{
- $opt_debug
- func_to_tool_file "$1" func_convert_file_msys_to_w32
- func_cygming_ms_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $GREP '_NULL_IMPORT_DESCRIPTOR'`
- test -n "$func_cygming_ms_implib_tmp"
-}
-
# func_cygming_dll_for_implib_fallback ARG
# Platform-specific function to extract the
# name of the DLL associated with the specified
@@ -3695,16 +5066,17 @@ func_cygming_ms_implib_p ()
# $sharedlib_from_linklib_result
func_cygming_dll_for_implib_fallback ()
{
- $opt_debug
- if func_cygming_gnu_implib_p "$1" ; then
+ $debug_cmd
+
+ if func_cygming_gnu_implib_p "$1"; then
# binutils import library
sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$7' "$1"`
- elif func_cygming_ms_implib_p "$1" ; then
+ elif func_cygming_ms_implib_p "$1"; then
# ms-generated import library
sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$6' "$1"`
else
# unknown
- sharedlib_from_linklib_result=""
+ sharedlib_from_linklib_result=
fi
}
@@ -3712,10 +5084,11 @@ func_cygming_dll_for_implib_fallback ()
# func_extract_an_archive dir oldlib
func_extract_an_archive ()
{
- $opt_debug
- f_ex_an_ar_dir="$1"; shift
- f_ex_an_ar_oldlib="$1"
- if test "$lock_old_archive_extraction" = yes; then
+ $debug_cmd
+
+ f_ex_an_ar_dir=$1; shift
+ f_ex_an_ar_oldlib=$1
+ if test yes = "$lock_old_archive_extraction"; then
lockfile=$f_ex_an_ar_oldlib.lock
until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do
func_echo "Waiting for $lockfile to be removed"
@@ -3724,7 +5097,7 @@ func_extract_an_archive ()
fi
func_show_eval "(cd \$f_ex_an_ar_dir && $AR x \"\$f_ex_an_ar_oldlib\")" \
'stat=$?; rm -f "$lockfile"; exit $stat'
- if test "$lock_old_archive_extraction" = yes; then
+ if test yes = "$lock_old_archive_extraction"; then
$opt_dry_run || rm -f "$lockfile"
fi
if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then
@@ -3738,22 +5111,23 @@ func_extract_an_archive ()
# func_extract_archives gentop oldlib ...
func_extract_archives ()
{
- $opt_debug
- my_gentop="$1"; shift
+ $debug_cmd
+
+ my_gentop=$1; shift
my_oldlibs=${1+"$@"}
- my_oldobjs=""
- my_xlib=""
- my_xabs=""
- my_xdir=""
+ my_oldobjs=
+ my_xlib=
+ my_xabs=
+ my_xdir=
for my_xlib in $my_oldlibs; do
# Extract the objects.
case $my_xlib in
- [\\/]* | [A-Za-z]:[\\/]*) my_xabs="$my_xlib" ;;
+ [\\/]* | [A-Za-z]:[\\/]*) my_xabs=$my_xlib ;;
*) my_xabs=`pwd`"/$my_xlib" ;;
esac
func_basename "$my_xlib"
- my_xlib="$func_basename_result"
+ my_xlib=$func_basename_result
my_xlib_u=$my_xlib
while :; do
case " $extracted_archives " in
@@ -3765,7 +5139,7 @@ func_extract_archives ()
esac
done
extracted_archives="$extracted_archives $my_xlib_u"
- my_xdir="$my_gentop/$my_xlib_u"
+ my_xdir=$my_gentop/$my_xlib_u
func_mkdir_p "$my_xdir"
@@ -3778,22 +5152,23 @@ func_extract_archives ()
cd $my_xdir || exit $?
darwin_archive=$my_xabs
darwin_curdir=`pwd`
- darwin_base_archive=`basename "$darwin_archive"`
+ func_basename "$darwin_archive"
+ darwin_base_archive=$func_basename_result
darwin_arches=`$LIPO -info "$darwin_archive" 2>/dev/null | $GREP Architectures 2>/dev/null || true`
if test -n "$darwin_arches"; then
darwin_arches=`$ECHO "$darwin_arches" | $SED -e 's/.*are://'`
darwin_arch=
func_verbose "$darwin_base_archive has multiple architectures $darwin_arches"
- for darwin_arch in $darwin_arches ; do
- func_mkdir_p "unfat-$$/${darwin_base_archive}-${darwin_arch}"
- $LIPO -thin $darwin_arch -output "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_archive}" "${darwin_archive}"
- cd "unfat-$$/${darwin_base_archive}-${darwin_arch}"
- func_extract_an_archive "`pwd`" "${darwin_base_archive}"
+ for darwin_arch in $darwin_arches; do
+ func_mkdir_p "unfat-$$/$darwin_base_archive-$darwin_arch"
+ $LIPO -thin $darwin_arch -output "unfat-$$/$darwin_base_archive-$darwin_arch/$darwin_base_archive" "$darwin_archive"
+ cd "unfat-$$/$darwin_base_archive-$darwin_arch"
+ func_extract_an_archive "`pwd`" "$darwin_base_archive"
cd "$darwin_curdir"
- $RM "unfat-$$/${darwin_base_archive}-${darwin_arch}/${darwin_base_archive}"
+ $RM "unfat-$$/$darwin_base_archive-$darwin_arch/$darwin_base_archive"
done # $darwin_arches
## Okay now we've a bunch of thin objects, gotta fatten them up :)
- darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*.lo -print | $SED -e "$basename" | sort -u`
+ darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*.lo -print | $SED -e "$sed_basename" | sort -u`
darwin_file=
darwin_files=
for darwin_file in $darwin_filelist; do
@@ -3815,7 +5190,7 @@ func_extract_archives ()
my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | sort | $NL2SP`
done
- func_extract_archives_result="$my_oldobjs"
+ func_extract_archives_result=$my_oldobjs
}
@@ -3830,7 +5205,7 @@ func_extract_archives ()
#
# ARG is the value that the WRAPPER_SCRIPT_BELONGS_IN_OBJDIR
# variable will take. If 'yes', then the emitted script
-# will assume that the directory in which it is stored is
+# will assume that the directory where it is stored is
# the $objdir directory. This is a cygwin/mingw-specific
# behavior.
func_emit_wrapper ()
@@ -3841,7 +5216,7 @@ func_emit_wrapper ()
#! $SHELL
# $output - temporary wrapper script for $objdir/$outputname
-# Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION
+# Generated by $PROGRAM (GNU $PACKAGE) $VERSION
#
# The $output program cannot be directly executed until all the libtool
# libraries that it depends on are installed.
@@ -3898,9 +5273,9 @@ _LTECHO_EOF'
# Very basic option parsing. These options are (a) specific to
# the libtool wrapper, (b) are identical between the wrapper
-# /script/ and the wrapper /executable/ which is used only on
+# /script/ and the wrapper /executable/ that is used only on
# windows platforms, and (c) all begin with the string "--lt-"
-# (application programs are unlikely to have options which match
+# (application programs are unlikely to have options that match
# this pattern).
#
# There are only two supported options: --lt-debug and
@@ -3933,7 +5308,7 @@ func_parse_lt_options ()
# Print the debug banner immediately:
if test -n \"\$lt_option_debug\"; then
- echo \"${outputname}:${output}:\${LINENO}: libtool wrapper (GNU $PACKAGE$TIMESTAMP) $VERSION\" 1>&2
+ echo \"$outputname:$output:\$LINENO: libtool wrapper (GNU $PACKAGE) $VERSION\" 1>&2
fi
}
@@ -3944,7 +5319,7 @@ func_lt_dump_args ()
lt_dump_args_N=1;
for lt_arg
do
- \$ECHO \"${outputname}:${output}:\${LINENO}: newargv[\$lt_dump_args_N]: \$lt_arg\"
+ \$ECHO \"$outputname:$output:\$LINENO: newargv[\$lt_dump_args_N]: \$lt_arg\"
lt_dump_args_N=\`expr \$lt_dump_args_N + 1\`
done
}
@@ -3958,7 +5333,7 @@ func_exec_program_core ()
*-*-mingw | *-*-os2* | *-cegcc*)
$ECHO "\
if test -n \"\$lt_option_debug\"; then
- \$ECHO \"${outputname}:${output}:\${LINENO}: newargv[0]: \$progdir\\\\\$program\" 1>&2
+ \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir\\\\\$program\" 1>&2
func_lt_dump_args \${1+\"\$@\"} 1>&2
fi
exec \"\$progdir\\\\\$program\" \${1+\"\$@\"}
@@ -3968,7 +5343,7 @@ func_exec_program_core ()
*)
$ECHO "\
if test -n \"\$lt_option_debug\"; then
- \$ECHO \"${outputname}:${output}:\${LINENO}: newargv[0]: \$progdir/\$program\" 1>&2
+ \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir/\$program\" 1>&2
func_lt_dump_args \${1+\"\$@\"} 1>&2
fi
exec \"\$progdir/\$program\" \${1+\"\$@\"}
@@ -4043,13 +5418,13 @@ func_exec_program ()
test -n \"\$absdir\" && thisdir=\"\$absdir\"
"
- if test "$fast_install" = yes; then
+ if test yes = "$fast_install"; then
$ECHO "\
program=lt-'$outputname'$exeext
progdir=\"\$thisdir/$objdir\"
if test ! -f \"\$progdir/\$program\" ||
- { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | ${SED} 1q\`; \\
+ { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | $SED 1q\`; \\
test \"X\$file\" != \"X\$progdir/\$program\"; }; then
file=\"\$\$-\$program\"
@@ -4066,7 +5441,7 @@ func_exec_program ()
if test -n \"\$relink_command\"; then
if relink_command_output=\`eval \$relink_command 2>&1\`; then :
else
- $ECHO \"\$relink_command_output\" >&2
+ \$ECHO \"\$relink_command_output\" >&2
$RM \"\$progdir/\$file\"
exit 1
fi
@@ -4101,7 +5476,7 @@ func_exec_program ()
fi
# Export our shlibpath_var if we have one.
- if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
+ if test yes = "$shlibpath_overrides_runpath" && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
$ECHO "\
# Add our own library path to $shlibpath_var
$shlibpath_var=\"$temp_rpath\$$shlibpath_var\"
@@ -4121,7 +5496,7 @@ func_exec_program ()
fi
else
# The program doesn't exist.
- \$ECHO \"\$0: error: \\\`\$progdir/\$program' does not exist\" 1>&2
+ \$ECHO \"\$0: error: '\$progdir/\$program' does not exist\" 1>&2
\$ECHO \"This script is just a wrapper for \$program.\" 1>&2
\$ECHO \"See the $PACKAGE documentation for more information.\" 1>&2
exit 1
@@ -4140,7 +5515,7 @@ func_emit_cwrapperexe_src ()
cat <<EOF
/* $cwrappersource - temporary wrapper executable for $objdir/$outputname
- Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION
+ Generated by $PROGRAM (GNU $PACKAGE) $VERSION
The $output program cannot be directly executed until all the libtool
libraries that it depends on are installed.
@@ -4175,47 +5550,45 @@ EOF
#include <fcntl.h>
#include <sys/stat.h>
+#define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0)
+
/* declarations of non-ANSI functions */
-#if defined(__MINGW32__)
+#if defined __MINGW32__
# ifdef __STRICT_ANSI__
int _putenv (const char *);
# endif
-#elif defined(__CYGWIN__)
+#elif defined __CYGWIN__
# ifdef __STRICT_ANSI__
char *realpath (const char *, char *);
int putenv (char *);
int setenv (const char *, const char *, int);
# endif
-/* #elif defined (other platforms) ... */
+/* #elif defined other_platform || defined ... */
#endif
/* portability defines, excluding path handling macros */
-#if defined(_MSC_VER)
+#if defined _MSC_VER
# define setmode _setmode
# define stat _stat
# define chmod _chmod
# define getcwd _getcwd
# define putenv _putenv
# define S_IXUSR _S_IEXEC
-# ifndef _INTPTR_T_DEFINED
-# define _INTPTR_T_DEFINED
-# define intptr_t int
-# endif
-#elif defined(__MINGW32__)
+#elif defined __MINGW32__
# define setmode _setmode
# define stat _stat
# define chmod _chmod
# define getcwd _getcwd
# define putenv _putenv
-#elif defined(__CYGWIN__)
+#elif defined __CYGWIN__
# define HAVE_SETENV
# define FOPEN_WB "wb"
-/* #elif defined (other platforms) ... */
+/* #elif defined other platforms ... */
#endif
-#if defined(PATH_MAX)
+#if defined PATH_MAX
# define LT_PATHMAX PATH_MAX
-#elif defined(MAXPATHLEN)
+#elif defined MAXPATHLEN
# define LT_PATHMAX MAXPATHLEN
#else
# define LT_PATHMAX 1024
@@ -4234,8 +5607,8 @@ int setenv (const char *, const char *, int);
# define PATH_SEPARATOR ':'
#endif
-#if defined (_WIN32) || defined (__MSDOS__) || defined (__DJGPP__) || \
- defined (__OS2__)
+#if defined _WIN32 || defined __MSDOS__ || defined __DJGPP__ || \
+ defined __OS2__
# define HAVE_DOS_BASED_FILE_SYSTEM
# define FOPEN_WB "wb"
# ifndef DIR_SEPARATOR_2
@@ -4268,10 +5641,10 @@ int setenv (const char *, const char *, int);
#define XMALLOC(type, num) ((type *) xmalloc ((num) * sizeof(type)))
#define XFREE(stale) do { \
- if (stale) { free ((void *) stale); stale = 0; } \
+ if (stale) { free (stale); stale = 0; } \
} while (0)
-#if defined(LT_DEBUGWRAPPER)
+#if defined LT_DEBUGWRAPPER
static int lt_debug = 1;
#else
static int lt_debug = 0;
@@ -4300,11 +5673,16 @@ void lt_dump_script (FILE *f);
EOF
cat <<EOF
-volatile const char * MAGIC_EXE = "$magic_exe";
+#if __GNUC__ < 4 || (__GNUC__ == 4 && __GNUC_MINOR__ < 5)
+# define externally_visible volatile
+#else
+# define externally_visible __attribute__((externally_visible)) volatile
+#endif
+externally_visible const char * MAGIC_EXE = "$magic_exe";
const char * LIB_PATH_VARNAME = "$shlibpath_var";
EOF
- if test "$shlibpath_overrides_runpath" = yes && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
+ if test yes = "$shlibpath_overrides_runpath" && test -n "$shlibpath_var" && test -n "$temp_rpath"; then
func_to_host_path "$temp_rpath"
cat <<EOF
const char * LIB_PATH_VALUE = "$func_to_host_path_result";
@@ -4328,7 +5706,7 @@ const char * EXE_PATH_VALUE = "";
EOF
fi
- if test "$fast_install" = yes; then
+ if test yes = "$fast_install"; then
cat <<EOF
const char * TARGET_PROGRAM_NAME = "lt-$outputname"; /* hopefully, no .exe */
EOF
@@ -4357,12 +5735,12 @@ main (int argc, char *argv[])
char *actual_cwrapper_name;
char *target_name;
char *lt_argv_zero;
- intptr_t rval = 127;
+ int rval = 127;
int i;
program_name = (char *) xstrdup (base_name (argv[0]));
- newargz = XMALLOC (char *, argc + 1);
+ newargz = XMALLOC (char *, (size_t) argc + 1);
/* very simple arg parsing; don't want to rely on getopt
* also, copy all non cwrapper options to newargz, except
@@ -4371,10 +5749,10 @@ main (int argc, char *argv[])
newargc=0;
for (i = 1; i < argc; i++)
{
- if (strcmp (argv[i], dumpscript_opt) == 0)
+ if (STREQ (argv[i], dumpscript_opt))
{
EOF
- case "$host" in
+ case $host in
*mingw* | *cygwin* )
# make stdout use "unix" line endings
echo " setmode(1,_O_BINARY);"
@@ -4385,16 +5763,16 @@ EOF
lt_dump_script (stdout);
return 0;
}
- if (strcmp (argv[i], debug_opt) == 0)
+ if (STREQ (argv[i], debug_opt))
{
lt_debug = 1;
continue;
}
- if (strcmp (argv[i], ltwrapper_option_prefix) == 0)
+ if (STREQ (argv[i], ltwrapper_option_prefix))
{
/* however, if there is an option in the LTWRAPPER_OPTION_PREFIX
namespace, but it is not one of the ones we know about and
- have already dealt with, above (including dump-script), then
+ have already dealt with, above (inluding dump-script), then
report an error. Otherwise, targets might begin to believe
they are allowed to use options in the LTWRAPPER_OPTION_PREFIX
namespace. The first time any user complains about this, we'll
@@ -4413,7 +5791,7 @@ EOF
EOF
cat <<EOF
/* The GNU banner must be the first non-error debug message */
- lt_debugprintf (__FILE__, __LINE__, "libtool wrapper (GNU $PACKAGE$TIMESTAMP) $VERSION\n");
+ lt_debugprintf (__FILE__, __LINE__, "libtool wrapper (GNU $PACKAGE) $VERSION\n");
EOF
cat <<"EOF"
lt_debugprintf (__FILE__, __LINE__, "(main) argv[0]: %s\n", argv[0]);
@@ -4524,7 +5902,7 @@ EOF
cat <<"EOF"
/* execv doesn't actually work on mingw as expected on unix */
newargz = prepare_spawn (newargz);
- rval = _spawnv (_P_WAIT, lt_argv_zero, (const char * const *) newargz);
+ rval = (int) _spawnv (_P_WAIT, lt_argv_zero, (const char * const *) newargz);
if (rval == -1)
{
/* failed to start process */
@@ -4569,7 +5947,7 @@ base_name (const char *name)
{
const char *base;
-#if defined (HAVE_DOS_BASED_FILE_SYSTEM)
+#if defined HAVE_DOS_BASED_FILE_SYSTEM
/* Skip over the disk name in MSDOS pathnames. */
if (isalpha ((unsigned char) name[0]) && name[1] == ':')
name += 2;
@@ -4628,7 +6006,7 @@ find_executable (const char *wrapper)
const char *p_next;
/* static buffer for getcwd */
char tmp[LT_PATHMAX + 1];
- int tmp_len;
+ size_t tmp_len;
char *concat_name;
lt_debugprintf (__FILE__, __LINE__, "(find_executable): %s\n",
@@ -4638,7 +6016,7 @@ find_executable (const char *wrapper)
return NULL;
/* Absolute path? */
-#if defined (HAVE_DOS_BASED_FILE_SYSTEM)
+#if defined HAVE_DOS_BASED_FILE_SYSTEM
if (isalpha ((unsigned char) wrapper[0]) && wrapper[1] == ':')
{
concat_name = xstrdup (wrapper);
@@ -4656,7 +6034,7 @@ find_executable (const char *wrapper)
return concat_name;
XFREE (concat_name);
}
-#if defined (HAVE_DOS_BASED_FILE_SYSTEM)
+#if defined HAVE_DOS_BASED_FILE_SYSTEM
}
#endif
@@ -4679,7 +6057,7 @@ find_executable (const char *wrapper)
for (q = p; *q; q++)
if (IS_PATH_SEPARATOR (*q))
break;
- p_len = q - p;
+ p_len = (size_t) (q - p);
p_next = (*q == '\0' ? q : q + 1);
if (p_len == 0)
{
@@ -4798,7 +6176,7 @@ strendzap (char *str, const char *pat)
if (patlen <= len)
{
str += len - patlen;
- if (strcmp (str, pat) == 0)
+ if (STREQ (str, pat))
*str = '\0';
}
return str;
@@ -4863,7 +6241,7 @@ lt_setenv (const char *name, const char *value)
char *str = xstrdup (value);
setenv (name, str, 1);
#else
- int len = strlen (name) + 1 + strlen (value) + 1;
+ size_t len = strlen (name) + 1 + strlen (value) + 1;
char *str = XMALLOC (char, len);
sprintf (str, "%s=%s", name, value);
if (putenv (str) != EXIT_SUCCESS)
@@ -4880,8 +6258,8 @@ lt_extend_str (const char *orig_value, const char *add, int to_end)
char *new_value;
if (orig_value && *orig_value)
{
- int orig_value_len = strlen (orig_value);
- int add_len = strlen (add);
+ size_t orig_value_len = strlen (orig_value);
+ size_t add_len = strlen (add);
new_value = XMALLOC (char, add_len + orig_value_len + 1);
if (to_end)
{
@@ -4912,10 +6290,10 @@ lt_update_exe_path (const char *name, const char *value)
{
char *new_value = lt_extend_str (getenv (name), value, 0);
/* some systems can't cope with a ':'-terminated path #' */
- int len = strlen (new_value);
- while (((len = strlen (new_value)) > 0) && IS_PATH_SEPARATOR (new_value[len-1]))
+ size_t len = strlen (new_value);
+ while ((len > 0) && IS_PATH_SEPARATOR (new_value[len-1]))
{
- new_value[len-1] = '\0';
+ new_value[--len] = '\0';
}
lt_setenv (name, new_value);
XFREE (new_value);
@@ -5082,27 +6460,47 @@ EOF
# True if ARG is an import lib, as indicated by $file_magic_cmd
func_win32_import_lib_p ()
{
- $opt_debug
+ $debug_cmd
+
case `eval $file_magic_cmd \"\$1\" 2>/dev/null | $SED -e 10q` in
*import*) : ;;
*) false ;;
esac
}
+# func_suncc_cstd_abi
+# !!ONLY CALL THIS FOR SUN CC AFTER $compile_command IS FULLY EXPANDED!!
+# Several compiler flags select an ABI that is incompatible with the
+# Cstd library. Avoid specifying it if any are in CXXFLAGS.
+func_suncc_cstd_abi ()
+{
+ $debug_cmd
+
+ case " $compile_command " in
+ *" -compat=g "*|*\ -std=c++[0-9][0-9]\ *|*" -library=stdcxx4 "*|*" -library=stlport4 "*)
+ suncc_use_cstd_abi=no
+ ;;
+ *)
+ suncc_use_cstd_abi=yes
+ ;;
+ esac
+}
+
# func_mode_link arg...
func_mode_link ()
{
- $opt_debug
+ $debug_cmd
+
case $host in
*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*)
# It is impossible to link a dll without this setting, and
# we shouldn't force the makefile maintainer to figure out
- # which system we are compiling for in order to pass an extra
+ # what system we are compiling for in order to pass an extra
# flag for every libtool invocation.
# allow_undefined=no
# FIXME: Unfortunately, there are problems with the above when trying
- # to make a dll which has undefined symbols, in which case not
+ # to make a dll that has undefined symbols, in which case not
# even a static library is built. For now, we need to specify
# -no-undefined on the libtool link line when we can be certain
# that all symbols are satisfied, otherwise we get a static library.
@@ -5146,10 +6544,11 @@ func_mode_link ()
module=no
no_install=no
objs=
+ os2dllname=
non_pic_objects=
precious_files_regex=
prefer_static_libs=no
- preload=no
+ preload=false
prev=
prevarg=
release=
@@ -5161,7 +6560,7 @@ func_mode_link ()
vinfo=
vinfo_number=no
weak_libs=
- single_module="${wl}-single_module"
+ single_module=$wl-single_module
func_infer_tag $base_compile
# We need to know -static, to get the right output filenames.
@@ -5169,15 +6568,15 @@ func_mode_link ()
do
case $arg in
-shared)
- test "$build_libtool_libs" != yes && \
- func_fatal_configuration "can not build a shared library"
+ test yes != "$build_libtool_libs" \
+ && func_fatal_configuration "cannot build a shared library"
build_old_libs=no
break
;;
-all-static | -static | -static-libtool-libs)
case $arg in
-all-static)
- if test "$build_libtool_libs" = yes && test -z "$link_static_flag"; then
+ if test yes = "$build_libtool_libs" && test -z "$link_static_flag"; then
func_warning "complete static linking is impossible in this configuration"
fi
if test -n "$link_static_flag"; then
@@ -5210,7 +6609,7 @@ func_mode_link ()
# Go through the arguments, transforming them on the way.
while test "$#" -gt 0; do
- arg="$1"
+ arg=$1
shift
func_quote_for_eval "$arg"
qarg=$func_quote_for_eval_unquoted_result
@@ -5227,21 +6626,21 @@ func_mode_link ()
case $prev in
bindir)
- bindir="$arg"
+ bindir=$arg
prev=
continue
;;
dlfiles|dlprefiles)
- if test "$preload" = no; then
+ $preload || {
# Add the symbol object into the linking commands.
func_append compile_command " @SYMFILE@"
func_append finalize_command " @SYMFILE@"
- preload=yes
- fi
+ preload=:
+ }
case $arg in
*.la | *.lo) ;; # We handle these cases below.
force)
- if test "$dlself" = no; then
+ if test no = "$dlself"; then
dlself=needless
export_dynamic=yes
fi
@@ -5249,9 +6648,9 @@ func_mode_link ()
continue
;;
self)
- if test "$prev" = dlprefiles; then
+ if test dlprefiles = "$prev"; then
dlself=yes
- elif test "$prev" = dlfiles && test "$dlopen_self" != yes; then
+ elif test dlfiles = "$prev" && test yes != "$dlopen_self"; then
dlself=yes
else
dlself=needless
@@ -5261,7 +6660,7 @@ func_mode_link ()
continue
;;
*)
- if test "$prev" = dlfiles; then
+ if test dlfiles = "$prev"; then
func_append dlfiles " $arg"
else
func_append dlprefiles " $arg"
@@ -5272,14 +6671,14 @@ func_mode_link ()
esac
;;
expsyms)
- export_symbols="$arg"
+ export_symbols=$arg
test -f "$arg" \
- || func_fatal_error "symbol file \`$arg' does not exist"
+ || func_fatal_error "symbol file '$arg' does not exist"
prev=
continue
;;
expsyms_regex)
- export_symbols_regex="$arg"
+ export_symbols_regex=$arg
prev=
continue
;;
@@ -5297,7 +6696,13 @@ func_mode_link ()
continue
;;
inst_prefix)
- inst_prefix_dir="$arg"
+ inst_prefix_dir=$arg
+ prev=
+ continue
+ ;;
+ mllvm)
+ # Clang does not use LLVM to link, so we can simply discard any
+ # '-mllvm $arg' options when doing the link step.
prev=
continue
;;
@@ -5321,21 +6726,21 @@ func_mode_link ()
if test -z "$pic_object" ||
test -z "$non_pic_object" ||
- test "$pic_object" = none &&
- test "$non_pic_object" = none; then
- func_fatal_error "cannot find name of object for \`$arg'"
+ test none = "$pic_object" &&
+ test none = "$non_pic_object"; then
+ func_fatal_error "cannot find name of object for '$arg'"
fi
# Extract subdirectory from the argument.
func_dirname "$arg" "/" ""
- xdir="$func_dirname_result"
+ xdir=$func_dirname_result
- if test "$pic_object" != none; then
+ if test none != "$pic_object"; then
# Prepend the subdirectory the object is found in.
- pic_object="$xdir$pic_object"
+ pic_object=$xdir$pic_object
- if test "$prev" = dlfiles; then
- if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then
+ if test dlfiles = "$prev"; then
+ if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"; then
func_append dlfiles " $pic_object"
prev=
continue
@@ -5346,7 +6751,7 @@ func_mode_link ()
fi
# CHECK ME: I think I busted this. -Ossama
- if test "$prev" = dlprefiles; then
+ if test dlprefiles = "$prev"; then
# Preload the old-style object.
func_append dlprefiles " $pic_object"
prev=
@@ -5354,23 +6759,23 @@ func_mode_link ()
# A PIC object.
func_append libobjs " $pic_object"
- arg="$pic_object"
+ arg=$pic_object
fi
# Non-PIC object.
- if test "$non_pic_object" != none; then
+ if test none != "$non_pic_object"; then
# Prepend the subdirectory the object is found in.
- non_pic_object="$xdir$non_pic_object"
+ non_pic_object=$xdir$non_pic_object
# A standard non-PIC object
func_append non_pic_objects " $non_pic_object"
- if test -z "$pic_object" || test "$pic_object" = none ; then
- arg="$non_pic_object"
+ if test -z "$pic_object" || test none = "$pic_object"; then
+ arg=$non_pic_object
fi
else
# If the PIC object exists, use it instead.
# $xdir was prepended to $pic_object above.
- non_pic_object="$pic_object"
+ non_pic_object=$pic_object
func_append non_pic_objects " $non_pic_object"
fi
else
@@ -5378,7 +6783,7 @@ func_mode_link ()
if $opt_dry_run; then
# Extract subdirectory from the argument.
func_dirname "$arg" "/" ""
- xdir="$func_dirname_result"
+ xdir=$func_dirname_result
func_lo2o "$arg"
pic_object=$xdir$objdir/$func_lo2o_result
@@ -5386,24 +6791,29 @@ func_mode_link ()
func_append libobjs " $pic_object"
func_append non_pic_objects " $non_pic_object"
else
- func_fatal_error "\`$arg' is not a valid libtool object"
+ func_fatal_error "'$arg' is not a valid libtool object"
fi
fi
done
else
- func_fatal_error "link input file \`$arg' does not exist"
+ func_fatal_error "link input file '$arg' does not exist"
fi
arg=$save_arg
prev=
continue
;;
+ os2dllname)
+ os2dllname=$arg
+ prev=
+ continue
+ ;;
precious_regex)
- precious_files_regex="$arg"
+ precious_files_regex=$arg
prev=
continue
;;
release)
- release="-$arg"
+ release=-$arg
prev=
continue
;;
@@ -5415,7 +6825,7 @@ func_mode_link ()
func_fatal_error "only absolute run-paths are allowed"
;;
esac
- if test "$prev" = rpath; then
+ if test rpath = "$prev"; then
case "$rpath " in
*" $arg "*) ;;
*) func_append rpath " $arg" ;;
@@ -5430,7 +6840,7 @@ func_mode_link ()
continue
;;
shrext)
- shrext_cmds="$arg"
+ shrext_cmds=$arg
prev=
continue
;;
@@ -5470,7 +6880,7 @@ func_mode_link ()
esac
fi # test -n "$prev"
- prevarg="$arg"
+ prevarg=$arg
case $arg in
-all-static)
@@ -5484,7 +6894,7 @@ func_mode_link ()
-allow-undefined)
# FIXME: remove this flag sometime in the future.
- func_fatal_error "\`-allow-undefined' must not be used because it is the default"
+ func_fatal_error "'-allow-undefined' must not be used because it is the default"
;;
-avoid-version)
@@ -5516,7 +6926,7 @@ func_mode_link ()
if test -n "$export_symbols" || test -n "$export_symbols_regex"; then
func_fatal_error "more than one -exported-symbols argument is not allowed"
fi
- if test "X$arg" = "X-export-symbols"; then
+ if test X-export-symbols = "X$arg"; then
prev=expsyms
else
prev=expsyms_regex
@@ -5550,9 +6960,9 @@ func_mode_link ()
func_stripname "-L" '' "$arg"
if test -z "$func_stripname_result"; then
if test "$#" -gt 0; then
- func_fatal_error "require no space between \`-L' and \`$1'"
+ func_fatal_error "require no space between '-L' and '$1'"
else
- func_fatal_error "need path for \`-L' option"
+ func_fatal_error "need path for '-L' option"
fi
fi
func_resolve_sysroot "$func_stripname_result"
@@ -5563,8 +6973,8 @@ func_mode_link ()
*)
absdir=`cd "$dir" && pwd`
test -z "$absdir" && \
- func_fatal_error "cannot determine absolute directory name of \`$dir'"
- dir="$absdir"
+ func_fatal_error "cannot determine absolute directory name of '$dir'"
+ dir=$absdir
;;
esac
case "$deplibs " in
@@ -5599,7 +7009,7 @@ func_mode_link ()
;;
-l*)
- if test "X$arg" = "X-lc" || test "X$arg" = "X-lm"; then
+ if test X-lc = "X$arg" || test X-lm = "X$arg"; then
case $host in
*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos* | *-cegcc* | *-*-haiku*)
# These systems don't actually have a C or math library (as such)
@@ -5607,11 +7017,11 @@ func_mode_link ()
;;
*-*-os2*)
# These systems don't actually have a C library (as such)
- test "X$arg" = "X-lc" && continue
+ test X-lc = "X$arg" && continue
;;
- *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*)
+ *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig*)
# Do not include libc due to us having libc/libc_r.
- test "X$arg" = "X-lc" && continue
+ test X-lc = "X$arg" && continue
;;
*-*-rhapsody* | *-*-darwin1.[012])
# Rhapsody C and math libraries are in the System framework
@@ -5620,16 +7030,16 @@ func_mode_link ()
;;
*-*-sco3.2v5* | *-*-sco5v6*)
# Causes problems with __ctype
- test "X$arg" = "X-lc" && continue
+ test X-lc = "X$arg" && continue
;;
*-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*)
# Compiler inserts libc in the correct place for threads to work
- test "X$arg" = "X-lc" && continue
+ test X-lc = "X$arg" && continue
;;
esac
- elif test "X$arg" = "X-lc_r"; then
+ elif test X-lc_r = "X$arg"; then
case $host in
- *-*-openbsd* | *-*-freebsd* | *-*-dragonfly*)
+ *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig*)
# Do not include libc_r directly, use -pthread flag.
continue
;;
@@ -5639,6 +7049,11 @@ func_mode_link ()
continue
;;
+ -mllvm)
+ prev=mllvm
+ continue
+ ;;
+
-module)
module=yes
continue
@@ -5668,7 +7083,7 @@ func_mode_link ()
;;
-multi_module)
- single_module="${wl}-multi_module"
+ single_module=$wl-multi_module
continue
;;
@@ -5682,8 +7097,8 @@ func_mode_link ()
*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-darwin* | *-cegcc*)
# The PATH hackery in wrapper scripts is required on Windows
# and Darwin in order for the loader to find any dlls it needs.
- func_warning "\`-no-install' is ignored for $host"
- func_warning "assuming \`-no-fast-install' instead"
+ func_warning "'-no-install' is ignored for $host"
+ func_warning "assuming '-no-fast-install' instead"
fast_install=no
;;
*) no_install=yes ;;
@@ -5701,6 +7116,11 @@ func_mode_link ()
continue
;;
+ -os2dllname)
+ prev=os2dllname
+ continue
+ ;;
+
-o) prev=output ;;
-precious-files-regex)
@@ -5788,14 +7208,14 @@ func_mode_link ()
func_stripname '-Wc,' '' "$arg"
args=$func_stripname_result
arg=
- save_ifs="$IFS"; IFS=','
+ save_ifs=$IFS; IFS=,
for flag in $args; do
- IFS="$save_ifs"
+ IFS=$save_ifs
func_quote_for_eval "$flag"
func_append arg " $func_quote_for_eval_result"
func_append compiler_flags " $func_quote_for_eval_result"
done
- IFS="$save_ifs"
+ IFS=$save_ifs
func_stripname ' ' '' "$arg"
arg=$func_stripname_result
;;
@@ -5804,15 +7224,15 @@ func_mode_link ()
func_stripname '-Wl,' '' "$arg"
args=$func_stripname_result
arg=
- save_ifs="$IFS"; IFS=','
+ save_ifs=$IFS; IFS=,
for flag in $args; do
- IFS="$save_ifs"
+ IFS=$save_ifs
func_quote_for_eval "$flag"
func_append arg " $wl$func_quote_for_eval_result"
func_append compiler_flags " $wl$func_quote_for_eval_result"
func_append linker_flags " $func_quote_for_eval_result"
done
- IFS="$save_ifs"
+ IFS=$save_ifs
func_stripname ' ' '' "$arg"
arg=$func_stripname_result
;;
@@ -5835,7 +7255,7 @@ func_mode_link ()
# -msg_* for osf cc
-msg_*)
func_quote_for_eval "$arg"
- arg="$func_quote_for_eval_result"
+ arg=$func_quote_for_eval_result
;;
# Flags to be passed through unchanged, with rationale:
@@ -5847,26 +7267,49 @@ func_mode_link ()
# -m*, -t[45]*, -txscale* architecture-specific flags for GCC
# -F/path path to uninstalled frameworks, gcc on darwin
# -p, -pg, --coverage, -fprofile-* profiling flags for GCC
+ # -fstack-protector* stack protector flags for GCC
# @file GCC response files
# -tp=* Portland pgcc target processor selection
# --sysroot=* for sysroot support
- # -O*, -flto*, -fwhopr*, -fuse-linker-plugin GCC link-time optimization
+ # -O*, -g*, -flto*, -fwhopr*, -fuse-linker-plugin GCC link-time optimization
+ # -specs=* GCC specs files
+ # -stdlib=* select c++ std lib with clang
+ # -fsanitize=* Clang/GCC memory and address sanitizer
-64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \
-t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \
- -O*|-flto*|-fwhopr*|-fuse-linker-plugin|-fstack-protector*|-fgnu-tm| \
- -shared-libgcc|-static-libgcc|-static-libgfortran|-static-libstdc++)
+ -O*|-g*|-flto*|-fwhopr*|-fuse-linker-plugin|-fstack-protector*|-stdlib=*| \
+ -specs=*|-fsanitize=*)
func_quote_for_eval "$arg"
- arg="$func_quote_for_eval_result"
+ arg=$func_quote_for_eval_result
func_append compile_command " $arg"
func_append finalize_command " $arg"
func_append compiler_flags " $arg"
continue
;;
+ -Z*)
+ if test os2 = "`expr $host : '.*\(os2\)'`"; then
+ # OS/2 uses -Zxxx to specify OS/2-specific options
+ compiler_flags="$compiler_flags $arg"
+ func_append compile_command " $arg"
+ func_append finalize_command " $arg"
+ case $arg in
+ -Zlinker | -Zstack)
+ prev=xcompiler
+ ;;
+ esac
+ continue
+ else
+ # Otherwise treat like 'Some other compiler flag' below
+ func_quote_for_eval "$arg"
+ arg=$func_quote_for_eval_result
+ fi
+ ;;
+
# Some other compiler flag.
-* | +*)
func_quote_for_eval "$arg"
- arg="$func_quote_for_eval_result"
+ arg=$func_quote_for_eval_result
;;
*.$objext)
@@ -5887,21 +7330,21 @@ func_mode_link ()
if test -z "$pic_object" ||
test -z "$non_pic_object" ||
- test "$pic_object" = none &&
- test "$non_pic_object" = none; then
- func_fatal_error "cannot find name of object for \`$arg'"
+ test none = "$pic_object" &&
+ test none = "$non_pic_object"; then
+ func_fatal_error "cannot find name of object for '$arg'"
fi
# Extract subdirectory from the argument.
func_dirname "$arg" "/" ""
- xdir="$func_dirname_result"
+ xdir=$func_dirname_result
- if test "$pic_object" != none; then
+ test none = "$pic_object" || {
# Prepend the subdirectory the object is found in.
- pic_object="$xdir$pic_object"
+ pic_object=$xdir$pic_object
- if test "$prev" = dlfiles; then
- if test "$build_libtool_libs" = yes && test "$dlopen_support" = yes; then
+ if test dlfiles = "$prev"; then
+ if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"; then
func_append dlfiles " $pic_object"
prev=
continue
@@ -5912,7 +7355,7 @@ func_mode_link ()
fi
# CHECK ME: I think I busted this. -Ossama
- if test "$prev" = dlprefiles; then
+ if test dlprefiles = "$prev"; then
# Preload the old-style object.
func_append dlprefiles " $pic_object"
prev=
@@ -5920,23 +7363,23 @@ func_mode_link ()
# A PIC object.
func_append libobjs " $pic_object"
- arg="$pic_object"
- fi
+ arg=$pic_object
+ }
# Non-PIC object.
- if test "$non_pic_object" != none; then
+ if test none != "$non_pic_object"; then
# Prepend the subdirectory the object is found in.
- non_pic_object="$xdir$non_pic_object"
+ non_pic_object=$xdir$non_pic_object
# A standard non-PIC object
func_append non_pic_objects " $non_pic_object"
- if test -z "$pic_object" || test "$pic_object" = none ; then
- arg="$non_pic_object"
+ if test -z "$pic_object" || test none = "$pic_object"; then
+ arg=$non_pic_object
fi
else
# If the PIC object exists, use it instead.
# $xdir was prepended to $pic_object above.
- non_pic_object="$pic_object"
+ non_pic_object=$pic_object
func_append non_pic_objects " $non_pic_object"
fi
else
@@ -5944,7 +7387,7 @@ func_mode_link ()
if $opt_dry_run; then
# Extract subdirectory from the argument.
func_dirname "$arg" "/" ""
- xdir="$func_dirname_result"
+ xdir=$func_dirname_result
func_lo2o "$arg"
pic_object=$xdir$objdir/$func_lo2o_result
@@ -5952,7 +7395,7 @@ func_mode_link ()
func_append libobjs " $pic_object"
func_append non_pic_objects " $non_pic_object"
else
- func_fatal_error "\`$arg' is not a valid libtool object"
+ func_fatal_error "'$arg' is not a valid libtool object"
fi
fi
;;
@@ -5968,11 +7411,11 @@ func_mode_link ()
# A libtool-controlled library.
func_resolve_sysroot "$arg"
- if test "$prev" = dlfiles; then
+ if test dlfiles = "$prev"; then
# This library was specified with -dlopen.
func_append dlfiles " $func_resolve_sysroot_result"
prev=
- elif test "$prev" = dlprefiles; then
+ elif test dlprefiles = "$prev"; then
# The library was specified with -dlpreopen.
func_append dlprefiles " $func_resolve_sysroot_result"
prev=
@@ -5987,7 +7430,7 @@ func_mode_link ()
# Unknown arguments in both finalize_command and compile_command need
# to be aesthetically quoted because they are evaled later.
func_quote_for_eval "$arg"
- arg="$func_quote_for_eval_result"
+ arg=$func_quote_for_eval_result
;;
esac # arg
@@ -5999,9 +7442,9 @@ func_mode_link ()
done # argument parsing loop
test -n "$prev" && \
- func_fatal_help "the \`$prevarg' option requires an argument"
+ func_fatal_help "the '$prevarg' option requires an argument"
- if test "$export_dynamic" = yes && test -n "$export_dynamic_flag_spec"; then
+ if test yes = "$export_dynamic" && test -n "$export_dynamic_flag_spec"; then
eval arg=\"$export_dynamic_flag_spec\"
func_append compile_command " $arg"
func_append finalize_command " $arg"
@@ -6010,20 +7453,23 @@ func_mode_link ()
oldlibs=
# calculate the name of the file, without its directory
func_basename "$output"
- outputname="$func_basename_result"
- libobjs_save="$libobjs"
+ outputname=$func_basename_result
+ libobjs_save=$libobjs
if test -n "$shlibpath_var"; then
# get the directories listed in $shlibpath_var
- eval shlib_search_path=\`\$ECHO \"\${$shlibpath_var}\" \| \$SED \'s/:/ /g\'\`
+ eval shlib_search_path=\`\$ECHO \"\$$shlibpath_var\" \| \$SED \'s/:/ /g\'\`
else
shlib_search_path=
fi
eval sys_lib_search_path=\"$sys_lib_search_path_spec\"
eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\"
+ # Definition is injected by LT_CONFIG during libtool generation.
+ func_munge_path_list sys_lib_dlsearch_path "$LT_SYS_LIBRARY_PATH"
+
func_dirname "$output" "/" ""
- output_objdir="$func_dirname_result$objdir"
+ output_objdir=$func_dirname_result$objdir
func_to_tool_file "$output_objdir/"
tool_output_objdir=$func_to_tool_file_result
# Create the object directory.
@@ -6046,7 +7492,7 @@ func_mode_link ()
# Find all interdependent deplibs by searching for libraries
# that are linked more than once (e.g. -la -lb -la)
for deplib in $deplibs; do
- if $opt_preserve_dup_deps ; then
+ if $opt_preserve_dup_deps; then
case "$libs " in
*" $deplib "*) func_append specialdeplibs " $deplib" ;;
esac
@@ -6054,7 +7500,7 @@ func_mode_link ()
func_append libs " $deplib"
done
- if test "$linkmode" = lib; then
+ if test lib = "$linkmode"; then
libs="$predeps $libs $compiler_lib_search_path $postdeps"
# Compute libraries that are listed more than once in $predeps
@@ -6086,7 +7532,7 @@ func_mode_link ()
case $file in
*.la) ;;
*)
- func_fatal_help "libraries can \`-dlopen' only libtool libraries: $file"
+ func_fatal_help "libraries can '-dlopen' only libtool libraries: $file"
;;
esac
done
@@ -6094,7 +7540,7 @@ func_mode_link ()
prog)
compile_deplibs=
finalize_deplibs=
- alldeplibs=no
+ alldeplibs=false
newdlfiles=
newdlprefiles=
passes="conv scan dlopen dlpreopen link"
@@ -6106,29 +7552,32 @@ func_mode_link ()
for pass in $passes; do
# The preopen pass in lib mode reverses $deplibs; put it back here
# so that -L comes before libs that need it for instance...
- if test "$linkmode,$pass" = "lib,link"; then
+ if test lib,link = "$linkmode,$pass"; then
## FIXME: Find the place where the list is rebuilt in the wrong
## order, and fix it there properly
tmp_deplibs=
for deplib in $deplibs; do
tmp_deplibs="$deplib $tmp_deplibs"
done
- deplibs="$tmp_deplibs"
+ deplibs=$tmp_deplibs
fi
- if test "$linkmode,$pass" = "lib,link" ||
- test "$linkmode,$pass" = "prog,scan"; then
- libs="$deplibs"
+ if test lib,link = "$linkmode,$pass" ||
+ test prog,scan = "$linkmode,$pass"; then
+ libs=$deplibs
deplibs=
fi
- if test "$linkmode" = prog; then
+ if test prog = "$linkmode"; then
case $pass in
- dlopen) libs="$dlfiles" ;;
- dlpreopen) libs="$dlprefiles" ;;
- link) libs="$deplibs %DEPLIBS% $dependency_libs" ;;
+ dlopen) libs=$dlfiles ;;
+ dlpreopen) libs=$dlprefiles ;;
+ link)
+ libs="$deplibs %DEPLIBS%"
+ test "X$link_all_deplibs" != Xno && libs="$libs $dependency_libs"
+ ;;
esac
fi
- if test "$linkmode,$pass" = "lib,dlpreopen"; then
+ if test lib,dlpreopen = "$linkmode,$pass"; then
# Collect and forward deplibs of preopened libtool libs
for lib in $dlprefiles; do
# Ignore non-libtool-libs
@@ -6149,26 +7598,26 @@ func_mode_link ()
esac
done
done
- libs="$dlprefiles"
+ libs=$dlprefiles
fi
- if test "$pass" = dlopen; then
+ if test dlopen = "$pass"; then
# Collect dlpreopened libraries
- save_deplibs="$deplibs"
+ save_deplibs=$deplibs
deplibs=
fi
for deplib in $libs; do
lib=
- found=no
+ found=false
case $deplib in
-mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \
|-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*)
- if test "$linkmode,$pass" = "prog,link"; then
+ if test prog,link = "$linkmode,$pass"; then
compile_deplibs="$deplib $compile_deplibs"
finalize_deplibs="$deplib $finalize_deplibs"
else
func_append compiler_flags " $deplib"
- if test "$linkmode" = lib ; then
+ if test lib = "$linkmode"; then
case "$new_inherited_linker_flags " in
*" $deplib "*) ;;
* ) func_append new_inherited_linker_flags " $deplib" ;;
@@ -6178,13 +7627,13 @@ func_mode_link ()
continue
;;
-l*)
- if test "$linkmode" != lib && test "$linkmode" != prog; then
- func_warning "\`-l' is ignored for archives/objects"
+ if test lib != "$linkmode" && test prog != "$linkmode"; then
+ func_warning "'-l' is ignored for archives/objects"
continue
fi
func_stripname '-l' '' "$deplib"
name=$func_stripname_result
- if test "$linkmode" = lib; then
+ if test lib = "$linkmode"; then
searchdirs="$newlib_search_path $lib_search_path $compiler_lib_search_dirs $sys_lib_search_path $shlib_search_path"
else
searchdirs="$newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path"
@@ -6192,31 +7641,22 @@ func_mode_link ()
for searchdir in $searchdirs; do
for search_ext in .la $std_shrext .so .a; do
# Search the libtool library
- lib="$searchdir/lib${name}${search_ext}"
+ lib=$searchdir/lib$name$search_ext
if test -f "$lib"; then
- if test "$search_ext" = ".la"; then
- found=yes
+ if test .la = "$search_ext"; then
+ found=:
else
- found=no
+ found=false
fi
break 2
fi
done
done
- if test "$found" != yes; then
- # deplib doesn't seem to be a libtool library
- if test "$linkmode,$pass" = "prog,link"; then
- compile_deplibs="$deplib $compile_deplibs"
- finalize_deplibs="$deplib $finalize_deplibs"
- else
- deplibs="$deplib $deplibs"
- test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs"
- fi
- continue
- else # deplib is a libtool library
+ if $found; then
+ # deplib is a libtool library
# If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib,
# We need to do some special things here, and not later.
- if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
+ if test yes = "$allow_libtool_libs_with_static_runtimes"; then
case " $predeps $postdeps " in
*" $deplib "*)
if func_lalib_p "$lib"; then
@@ -6224,19 +7664,19 @@ func_mode_link ()
old_library=
func_source "$lib"
for l in $old_library $library_names; do
- ll="$l"
+ ll=$l
done
- if test "X$ll" = "X$old_library" ; then # only static version available
- found=no
+ if test "X$ll" = "X$old_library"; then # only static version available
+ found=false
func_dirname "$lib" "" "."
- ladir="$func_dirname_result"
+ ladir=$func_dirname_result
lib=$ladir/$old_library
- if test "$linkmode,$pass" = "prog,link"; then
+ if test prog,link = "$linkmode,$pass"; then
compile_deplibs="$deplib $compile_deplibs"
finalize_deplibs="$deplib $finalize_deplibs"
else
deplibs="$deplib $deplibs"
- test "$linkmode" = lib && newdependency_libs="$deplib $newdependency_libs"
+ test lib = "$linkmode" && newdependency_libs="$deplib $newdependency_libs"
fi
continue
fi
@@ -6245,15 +7685,25 @@ func_mode_link ()
*) ;;
esac
fi
+ else
+ # deplib doesn't seem to be a libtool library
+ if test prog,link = "$linkmode,$pass"; then
+ compile_deplibs="$deplib $compile_deplibs"
+ finalize_deplibs="$deplib $finalize_deplibs"
+ else
+ deplibs="$deplib $deplibs"
+ test lib = "$linkmode" && newdependency_libs="$deplib $newdependency_libs"
+ fi
+ continue
fi
;; # -l
*.ltframework)
- if test "$linkmode,$pass" = "prog,link"; then
+ if test prog,link = "$linkmode,$pass"; then
compile_deplibs="$deplib $compile_deplibs"
finalize_deplibs="$deplib $finalize_deplibs"
else
deplibs="$deplib $deplibs"
- if test "$linkmode" = lib ; then
+ if test lib = "$linkmode"; then
case "$new_inherited_linker_flags " in
*" $deplib "*) ;;
* ) func_append new_inherited_linker_flags " $deplib" ;;
@@ -6266,18 +7716,18 @@ func_mode_link ()
case $linkmode in
lib)
deplibs="$deplib $deplibs"
- test "$pass" = conv && continue
+ test conv = "$pass" && continue
newdependency_libs="$deplib $newdependency_libs"
func_stripname '-L' '' "$deplib"
func_resolve_sysroot "$func_stripname_result"
func_append newlib_search_path " $func_resolve_sysroot_result"
;;
prog)
- if test "$pass" = conv; then
+ if test conv = "$pass"; then
deplibs="$deplib $deplibs"
continue
fi
- if test "$pass" = scan; then
+ if test scan = "$pass"; then
deplibs="$deplib $deplibs"
else
compile_deplibs="$deplib $compile_deplibs"
@@ -6288,13 +7738,13 @@ func_mode_link ()
func_append newlib_search_path " $func_resolve_sysroot_result"
;;
*)
- func_warning "\`-L' is ignored for archives/objects"
+ func_warning "'-L' is ignored for archives/objects"
;;
esac # linkmode
continue
;; # -L
-R*)
- if test "$pass" = link; then
+ if test link = "$pass"; then
func_stripname '-R' '' "$deplib"
func_resolve_sysroot "$func_stripname_result"
dir=$func_resolve_sysroot_result
@@ -6312,7 +7762,7 @@ func_mode_link ()
lib=$func_resolve_sysroot_result
;;
*.$libext)
- if test "$pass" = conv; then
+ if test conv = "$pass"; then
deplibs="$deplib $deplibs"
continue
fi
@@ -6323,21 +7773,26 @@ func_mode_link ()
case " $dlpreconveniencelibs " in
*" $deplib "*) ;;
*)
- valid_a_lib=no
+ valid_a_lib=false
case $deplibs_check_method in
match_pattern*)
set dummy $deplibs_check_method; shift
match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"`
if eval "\$ECHO \"$deplib\"" 2>/dev/null | $SED 10q \
| $EGREP "$match_pattern_regex" > /dev/null; then
- valid_a_lib=yes
+ valid_a_lib=:
fi
;;
pass_all)
- valid_a_lib=yes
+ valid_a_lib=:
;;
esac
- if test "$valid_a_lib" != yes; then
+ if $valid_a_lib; then
+ echo
+ $ECHO "*** Warning: Linking the shared library $output against the"
+ $ECHO "*** static library $deplib is not portable!"
+ deplibs="$deplib $deplibs"
+ else
echo
$ECHO "*** Warning: Trying to link with static lib archive $deplib."
echo "*** I have the capability to make that library automatically link in when"
@@ -6345,18 +7800,13 @@ func_mode_link ()
echo "*** shared version of the library, which you do not appear to have"
echo "*** because the file extensions .$libext of this argument makes me believe"
echo "*** that it is just a static archive that I should not use here."
- else
- echo
- $ECHO "*** Warning: Linking the shared library $output against the"
- $ECHO "*** static library $deplib is not portable!"
- deplibs="$deplib $deplibs"
fi
;;
esac
continue
;;
prog)
- if test "$pass" != link; then
+ if test link != "$pass"; then
deplibs="$deplib $deplibs"
else
compile_deplibs="$deplib $compile_deplibs"
@@ -6367,10 +7817,10 @@ func_mode_link ()
esac # linkmode
;; # *.$libext
*.lo | *.$objext)
- if test "$pass" = conv; then
+ if test conv = "$pass"; then
deplibs="$deplib $deplibs"
- elif test "$linkmode" = prog; then
- if test "$pass" = dlpreopen || test "$dlopen_support" != yes || test "$build_libtool_libs" = no; then
+ elif test prog = "$linkmode"; then
+ if test dlpreopen = "$pass" || test yes != "$dlopen_support" || test no = "$build_libtool_libs"; then
# If there is no dlopen support or we're linking statically,
# we need to preload.
func_append newdlprefiles " $deplib"
@@ -6383,22 +7833,20 @@ func_mode_link ()
continue
;;
%DEPLIBS%)
- alldeplibs=yes
+ alldeplibs=:
continue
;;
esac # case $deplib
- if test "$found" = yes || test -f "$lib"; then :
- else
- func_fatal_error "cannot find the library \`$lib' or unhandled argument \`$deplib'"
- fi
+ $found || test -f "$lib" \
+ || func_fatal_error "cannot find the library '$lib' or unhandled argument '$deplib'"
# Check to see that this really is a libtool archive.
func_lalib_unsafe_p "$lib" \
- || func_fatal_error "\`$lib' is not a valid libtool archive"
+ || func_fatal_error "'$lib' is not a valid libtool archive"
func_dirname "$lib" "" "."
- ladir="$func_dirname_result"
+ ladir=$func_dirname_result
dlname=
dlopen=
@@ -6428,36 +7876,36 @@ func_mode_link ()
done
fi
dependency_libs=`$ECHO " $dependency_libs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
- if test "$linkmode,$pass" = "lib,link" ||
- test "$linkmode,$pass" = "prog,scan" ||
- { test "$linkmode" != prog && test "$linkmode" != lib; }; then
+ if test lib,link = "$linkmode,$pass" ||
+ test prog,scan = "$linkmode,$pass" ||
+ { test prog != "$linkmode" && test lib != "$linkmode"; }; then
test -n "$dlopen" && func_append dlfiles " $dlopen"
test -n "$dlpreopen" && func_append dlprefiles " $dlpreopen"
fi
- if test "$pass" = conv; then
+ if test conv = "$pass"; then
# Only check for convenience libraries
deplibs="$lib $deplibs"
if test -z "$libdir"; then
if test -z "$old_library"; then
- func_fatal_error "cannot find name of link library for \`$lib'"
+ func_fatal_error "cannot find name of link library for '$lib'"
fi
# It is a libtool convenience library, so add in its objects.
func_append convenience " $ladir/$objdir/$old_library"
func_append old_convenience " $ladir/$objdir/$old_library"
- elif test "$linkmode" != prog && test "$linkmode" != lib; then
- func_fatal_error "\`$lib' is not a convenience library"
+ tmp_libs=
+ for deplib in $dependency_libs; do
+ deplibs="$deplib $deplibs"
+ if $opt_preserve_dup_deps; then
+ case "$tmp_libs " in
+ *" $deplib "*) func_append specialdeplibs " $deplib" ;;
+ esac
+ fi
+ func_append tmp_libs " $deplib"
+ done
+ elif test prog != "$linkmode" && test lib != "$linkmode"; then
+ func_fatal_error "'$lib' is not a convenience library"
fi
- tmp_libs=
- for deplib in $dependency_libs; do
- deplibs="$deplib $deplibs"
- if $opt_preserve_dup_deps ; then
- case "$tmp_libs " in
- *" $deplib "*) func_append specialdeplibs " $deplib" ;;
- esac
- fi
- func_append tmp_libs " $deplib"
- done
continue
fi # $pass = conv
@@ -6465,26 +7913,26 @@ func_mode_link ()
# Get the name of the library we link against.
linklib=
if test -n "$old_library" &&
- { test "$prefer_static_libs" = yes ||
- test "$prefer_static_libs,$installed" = "built,no"; }; then
+ { test yes = "$prefer_static_libs" ||
+ test built,no = "$prefer_static_libs,$installed"; }; then
linklib=$old_library
else
for l in $old_library $library_names; do
- linklib="$l"
+ linklib=$l
done
fi
if test -z "$linklib"; then
- func_fatal_error "cannot find name of link library for \`$lib'"
+ func_fatal_error "cannot find name of link library for '$lib'"
fi
# This library was specified with -dlopen.
- if test "$pass" = dlopen; then
- if test -z "$libdir"; then
- func_fatal_error "cannot -dlopen a convenience library: \`$lib'"
- fi
+ if test dlopen = "$pass"; then
+ test -z "$libdir" \
+ && func_fatal_error "cannot -dlopen a convenience library: '$lib'"
if test -z "$dlname" ||
- test "$dlopen_support" != yes ||
- test "$build_libtool_libs" = no; then
+ test yes != "$dlopen_support" ||
+ test no = "$build_libtool_libs"
+ then
# If there is no dlname, no dlopen support or we're linking
# statically, we need to preload. We also need to preload any
# dependent libraries so libltdl's deplib preloader doesn't
@@ -6498,40 +7946,40 @@ func_mode_link ()
# We need an absolute path.
case $ladir in
- [\\/]* | [A-Za-z]:[\\/]*) abs_ladir="$ladir" ;;
+ [\\/]* | [A-Za-z]:[\\/]*) abs_ladir=$ladir ;;
*)
abs_ladir=`cd "$ladir" && pwd`
if test -z "$abs_ladir"; then
- func_warning "cannot determine absolute directory name of \`$ladir'"
+ func_warning "cannot determine absolute directory name of '$ladir'"
func_warning "passing it literally to the linker, although it might fail"
- abs_ladir="$ladir"
+ abs_ladir=$ladir
fi
;;
esac
func_basename "$lib"
- laname="$func_basename_result"
+ laname=$func_basename_result
# Find the relevant object directory and library name.
- if test "X$installed" = Xyes; then
+ if test yes = "$installed"; then
if test ! -f "$lt_sysroot$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then
- func_warning "library \`$lib' was moved."
- dir="$ladir"
- absdir="$abs_ladir"
- libdir="$abs_ladir"
+ func_warning "library '$lib' was moved."
+ dir=$ladir
+ absdir=$abs_ladir
+ libdir=$abs_ladir
else
- dir="$lt_sysroot$libdir"
- absdir="$lt_sysroot$libdir"
+ dir=$lt_sysroot$libdir
+ absdir=$lt_sysroot$libdir
fi
- test "X$hardcode_automatic" = Xyes && avoidtemprpath=yes
+ test yes = "$hardcode_automatic" && avoidtemprpath=yes
else
if test ! -f "$ladir/$objdir/$linklib" && test -f "$abs_ladir/$linklib"; then
- dir="$ladir"
- absdir="$abs_ladir"
+ dir=$ladir
+ absdir=$abs_ladir
# Remove this search path later
func_append notinst_path " $abs_ladir"
else
- dir="$ladir/$objdir"
- absdir="$abs_ladir/$objdir"
+ dir=$ladir/$objdir
+ absdir=$abs_ladir/$objdir
# Remove this search path later
func_append notinst_path " $abs_ladir"
fi
@@ -6540,11 +7988,11 @@ func_mode_link ()
name=$func_stripname_result
# This library was specified with -dlpreopen.
- if test "$pass" = dlpreopen; then
- if test -z "$libdir" && test "$linkmode" = prog; then
- func_fatal_error "only libraries may -dlpreopen a convenience library: \`$lib'"
+ if test dlpreopen = "$pass"; then
+ if test -z "$libdir" && test prog = "$linkmode"; then
+ func_fatal_error "only libraries may -dlpreopen a convenience library: '$lib'"
fi
- case "$host" in
+ case $host in
# special handling for platforms with PE-DLLs.
*cygwin* | *mingw* | *cegcc* )
# Linker will automatically link against shared library if both
@@ -6588,9 +8036,9 @@ func_mode_link ()
if test -z "$libdir"; then
# Link the convenience library
- if test "$linkmode" = lib; then
+ if test lib = "$linkmode"; then
deplibs="$dir/$old_library $deplibs"
- elif test "$linkmode,$pass" = "prog,link"; then
+ elif test prog,link = "$linkmode,$pass"; then
compile_deplibs="$dir/$old_library $compile_deplibs"
finalize_deplibs="$dir/$old_library $finalize_deplibs"
else
@@ -6600,14 +8048,14 @@ func_mode_link ()
fi
- if test "$linkmode" = prog && test "$pass" != link; then
+ if test prog = "$linkmode" && test link != "$pass"; then
func_append newlib_search_path " $ladir"
deplibs="$lib $deplibs"
- linkalldeplibs=no
- if test "$link_all_deplibs" != no || test -z "$library_names" ||
- test "$build_libtool_libs" = no; then
- linkalldeplibs=yes
+ linkalldeplibs=false
+ if test no != "$link_all_deplibs" || test -z "$library_names" ||
+ test no = "$build_libtool_libs"; then
+ linkalldeplibs=:
fi
tmp_libs=
@@ -6619,14 +8067,14 @@ func_mode_link ()
;;
esac
# Need to link against all dependency_libs?
- if test "$linkalldeplibs" = yes; then
+ if $linkalldeplibs; then
deplibs="$deplib $deplibs"
else
# Need to hardcode shared library paths
# or/and link against static libraries
newdependency_libs="$deplib $newdependency_libs"
fi
- if $opt_preserve_dup_deps ; then
+ if $opt_preserve_dup_deps; then
case "$tmp_libs " in
*" $deplib "*) func_append specialdeplibs " $deplib" ;;
esac
@@ -6636,15 +8084,15 @@ func_mode_link ()
continue
fi # $linkmode = prog...
- if test "$linkmode,$pass" = "prog,link"; then
+ if test prog,link = "$linkmode,$pass"; then
if test -n "$library_names" &&
- { { test "$prefer_static_libs" = no ||
- test "$prefer_static_libs,$installed" = "built,yes"; } ||
+ { { test no = "$prefer_static_libs" ||
+ test built,yes = "$prefer_static_libs,$installed"; } ||
test -z "$old_library"; }; then
# We need to hardcode the library path
- if test -n "$shlibpath_var" && test -z "$avoidtemprpath" ; then
+ if test -n "$shlibpath_var" && test -z "$avoidtemprpath"; then
# Make sure the rpath contains only unique directories.
- case "$temp_rpath:" in
+ case $temp_rpath: in
*"$absdir:"*) ;;
*) func_append temp_rpath "$absdir:" ;;
esac
@@ -6673,9 +8121,9 @@ func_mode_link ()
esac
fi # $linkmode,$pass = prog,link...
- if test "$alldeplibs" = yes &&
- { test "$deplibs_check_method" = pass_all ||
- { test "$build_libtool_libs" = yes &&
+ if $alldeplibs &&
+ { test pass_all = "$deplibs_check_method" ||
+ { test yes = "$build_libtool_libs" &&
test -n "$library_names"; }; }; then
# We only need to search for static libraries
continue
@@ -6684,19 +8132,19 @@ func_mode_link ()
link_static=no # Whether the deplib will be linked statically
use_static_libs=$prefer_static_libs
- if test "$use_static_libs" = built && test "$installed" = yes; then
+ if test built = "$use_static_libs" && test yes = "$installed"; then
use_static_libs=no
fi
if test -n "$library_names" &&
- { test "$use_static_libs" = no || test -z "$old_library"; }; then
+ { test no = "$use_static_libs" || test -z "$old_library"; }; then
case $host in
- *cygwin* | *mingw* | *cegcc*)
+ *cygwin* | *mingw* | *cegcc* | *os2*)
# No point in relinking DLLs because paths are not encoded
func_append notinst_deplibs " $lib"
need_relink=no
;;
*)
- if test "$installed" = no; then
+ if test no = "$installed"; then
func_append notinst_deplibs " $lib"
need_relink=yes
fi
@@ -6706,24 +8154,24 @@ func_mode_link ()
# Warn about portability, can't link against -module's on some
# systems (darwin). Don't bleat about dlopened modules though!
- dlopenmodule=""
+ dlopenmodule=
for dlpremoduletest in $dlprefiles; do
if test "X$dlpremoduletest" = "X$lib"; then
- dlopenmodule="$dlpremoduletest"
+ dlopenmodule=$dlpremoduletest
break
fi
done
- if test -z "$dlopenmodule" && test "$shouldnotlink" = yes && test "$pass" = link; then
+ if test -z "$dlopenmodule" && test yes = "$shouldnotlink" && test link = "$pass"; then
echo
- if test "$linkmode" = prog; then
+ if test prog = "$linkmode"; then
$ECHO "*** Warning: Linking the executable $output against the loadable module"
else
$ECHO "*** Warning: Linking the shared library $output against the loadable module"
fi
$ECHO "*** $linklib is not portable!"
fi
- if test "$linkmode" = lib &&
- test "$hardcode_into_libs" = yes; then
+ if test lib = "$linkmode" &&
+ test yes = "$hardcode_into_libs"; then
# Hardcode the library path.
# Skip directories that are in the system default run-time
# search path.
@@ -6751,43 +8199,43 @@ func_mode_link ()
# figure out the soname
set dummy $library_names
shift
- realname="$1"
+ realname=$1
shift
libname=`eval "\\$ECHO \"$libname_spec\""`
# use dlname if we got it. it's perfectly good, no?
if test -n "$dlname"; then
- soname="$dlname"
+ soname=$dlname
elif test -n "$soname_spec"; then
# bleh windows
case $host in
- *cygwin* | mingw* | *cegcc*)
+ *cygwin* | mingw* | *cegcc* | *os2*)
func_arith $current - $age
major=$func_arith_result
- versuffix="-$major"
+ versuffix=-$major
;;
esac
eval soname=\"$soname_spec\"
else
- soname="$realname"
+ soname=$realname
fi
# Make a new name for the extract_expsyms_cmds to use
- soroot="$soname"
+ soroot=$soname
func_basename "$soroot"
- soname="$func_basename_result"
+ soname=$func_basename_result
func_stripname 'lib' '.dll' "$soname"
newlib=libimp-$func_stripname_result.a
# If the library has no export list, then create one now
if test -f "$output_objdir/$soname-def"; then :
else
- func_verbose "extracting exported symbol list from \`$soname'"
+ func_verbose "extracting exported symbol list from '$soname'"
func_execute_cmds "$extract_expsyms_cmds" 'exit $?'
fi
# Create $newlib
if test -f "$output_objdir/$newlib"; then :; else
- func_verbose "generating import library for \`$soname'"
+ func_verbose "generating import library for '$soname'"
func_execute_cmds "$old_archive_from_expsyms_cmds" 'exit $?'
fi
# make sure the library variables are pointing to the new library
@@ -6795,58 +8243,58 @@ func_mode_link ()
linklib=$newlib
fi # test -n "$old_archive_from_expsyms_cmds"
- if test "$linkmode" = prog || test "$opt_mode" != relink; then
+ if test prog = "$linkmode" || test relink != "$opt_mode"; then
add_shlibpath=
add_dir=
add=
lib_linked=yes
case $hardcode_action in
immediate | unsupported)
- if test "$hardcode_direct" = no; then
- add="$dir/$linklib"
+ if test no = "$hardcode_direct"; then
+ add=$dir/$linklib
case $host in
- *-*-sco3.2v5.0.[024]*) add_dir="-L$dir" ;;
- *-*-sysv4*uw2*) add_dir="-L$dir" ;;
+ *-*-sco3.2v5.0.[024]*) add_dir=-L$dir ;;
+ *-*-sysv4*uw2*) add_dir=-L$dir ;;
*-*-sysv5OpenUNIX* | *-*-sysv5UnixWare7.[01].[10]* | \
- *-*-unixware7*) add_dir="-L$dir" ;;
+ *-*-unixware7*) add_dir=-L$dir ;;
*-*-darwin* )
- # if the lib is a (non-dlopened) module then we can not
+ # if the lib is a (non-dlopened) module then we cannot
# link against it, someone is ignoring the earlier warnings
if /usr/bin/file -L $add 2> /dev/null |
- $GREP ": [^:]* bundle" >/dev/null ; then
+ $GREP ": [^:]* bundle" >/dev/null; then
if test "X$dlopenmodule" != "X$lib"; then
$ECHO "*** Warning: lib $linklib is a module, not a shared library"
- if test -z "$old_library" ; then
+ if test -z "$old_library"; then
echo
echo "*** And there doesn't seem to be a static archive available"
echo "*** The link will probably fail, sorry"
else
- add="$dir/$old_library"
+ add=$dir/$old_library
fi
elif test -n "$old_library"; then
- add="$dir/$old_library"
+ add=$dir/$old_library
fi
fi
esac
- elif test "$hardcode_minus_L" = no; then
+ elif test no = "$hardcode_minus_L"; then
case $host in
- *-*-sunos*) add_shlibpath="$dir" ;;
+ *-*-sunos*) add_shlibpath=$dir ;;
esac
- add_dir="-L$dir"
- add="-l$name"
- elif test "$hardcode_shlibpath_var" = no; then
- add_shlibpath="$dir"
- add="-l$name"
+ add_dir=-L$dir
+ add=-l$name
+ elif test no = "$hardcode_shlibpath_var"; then
+ add_shlibpath=$dir
+ add=-l$name
else
lib_linked=no
fi
;;
relink)
- if test "$hardcode_direct" = yes &&
- test "$hardcode_direct_absolute" = no; then
- add="$dir/$linklib"
- elif test "$hardcode_minus_L" = yes; then
- add_dir="-L$absdir"
+ if test yes = "$hardcode_direct" &&
+ test no = "$hardcode_direct_absolute"; then
+ add=$dir/$linklib
+ elif test yes = "$hardcode_minus_L"; then
+ add_dir=-L$absdir
# Try looking first in the location we're being installed to.
if test -n "$inst_prefix_dir"; then
case $libdir in
@@ -6855,10 +8303,10 @@ func_mode_link ()
;;
esac
fi
- add="-l$name"
- elif test "$hardcode_shlibpath_var" = yes; then
- add_shlibpath="$dir"
- add="-l$name"
+ add=-l$name
+ elif test yes = "$hardcode_shlibpath_var"; then
+ add_shlibpath=$dir
+ add=-l$name
else
lib_linked=no
fi
@@ -6866,7 +8314,7 @@ func_mode_link ()
*) lib_linked=no ;;
esac
- if test "$lib_linked" != yes; then
+ if test yes != "$lib_linked"; then
func_fatal_configuration "unsupported hardcode properties"
fi
@@ -6876,15 +8324,15 @@ func_mode_link ()
*) func_append compile_shlibpath "$add_shlibpath:" ;;
esac
fi
- if test "$linkmode" = prog; then
+ if test prog = "$linkmode"; then
test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs"
test -n "$add" && compile_deplibs="$add $compile_deplibs"
else
test -n "$add_dir" && deplibs="$add_dir $deplibs"
test -n "$add" && deplibs="$add $deplibs"
- if test "$hardcode_direct" != yes &&
- test "$hardcode_minus_L" != yes &&
- test "$hardcode_shlibpath_var" = yes; then
+ if test yes != "$hardcode_direct" &&
+ test yes != "$hardcode_minus_L" &&
+ test yes = "$hardcode_shlibpath_var"; then
case :$finalize_shlibpath: in
*":$libdir:"*) ;;
*) func_append finalize_shlibpath "$libdir:" ;;
@@ -6893,33 +8341,33 @@ func_mode_link ()
fi
fi
- if test "$linkmode" = prog || test "$opt_mode" = relink; then
+ if test prog = "$linkmode" || test relink = "$opt_mode"; then
add_shlibpath=
add_dir=
add=
# Finalize command for both is simple: just hardcode it.
- if test "$hardcode_direct" = yes &&
- test "$hardcode_direct_absolute" = no; then
- add="$libdir/$linklib"
- elif test "$hardcode_minus_L" = yes; then
- add_dir="-L$libdir"
- add="-l$name"
- elif test "$hardcode_shlibpath_var" = yes; then
+ if test yes = "$hardcode_direct" &&
+ test no = "$hardcode_direct_absolute"; then
+ add=$libdir/$linklib
+ elif test yes = "$hardcode_minus_L"; then
+ add_dir=-L$libdir
+ add=-l$name
+ elif test yes = "$hardcode_shlibpath_var"; then
case :$finalize_shlibpath: in
*":$libdir:"*) ;;
*) func_append finalize_shlibpath "$libdir:" ;;
esac
- add="-l$name"
- elif test "$hardcode_automatic" = yes; then
+ add=-l$name
+ elif test yes = "$hardcode_automatic"; then
if test -n "$inst_prefix_dir" &&
- test -f "$inst_prefix_dir$libdir/$linklib" ; then
- add="$inst_prefix_dir$libdir/$linklib"
+ test -f "$inst_prefix_dir$libdir/$linklib"; then
+ add=$inst_prefix_dir$libdir/$linklib
else
- add="$libdir/$linklib"
+ add=$libdir/$linklib
fi
else
# We cannot seem to hardcode it, guess we'll fake it.
- add_dir="-L$libdir"
+ add_dir=-L$libdir
# Try looking first in the location we're being installed to.
if test -n "$inst_prefix_dir"; then
case $libdir in
@@ -6928,10 +8376,10 @@ func_mode_link ()
;;
esac
fi
- add="-l$name"
+ add=-l$name
fi
- if test "$linkmode" = prog; then
+ if test prog = "$linkmode"; then
test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs"
test -n "$add" && finalize_deplibs="$add $finalize_deplibs"
else
@@ -6939,43 +8387,43 @@ func_mode_link ()
test -n "$add" && deplibs="$add $deplibs"
fi
fi
- elif test "$linkmode" = prog; then
+ elif test prog = "$linkmode"; then
# Here we assume that one of hardcode_direct or hardcode_minus_L
# is not unsupported. This is valid on all known static and
# shared platforms.
- if test "$hardcode_direct" != unsupported; then
- test -n "$old_library" && linklib="$old_library"
+ if test unsupported != "$hardcode_direct"; then
+ test -n "$old_library" && linklib=$old_library
compile_deplibs="$dir/$linklib $compile_deplibs"
finalize_deplibs="$dir/$linklib $finalize_deplibs"
else
compile_deplibs="-l$name -L$dir $compile_deplibs"
finalize_deplibs="-l$name -L$dir $finalize_deplibs"
fi
- elif test "$build_libtool_libs" = yes; then
+ elif test yes = "$build_libtool_libs"; then
# Not a shared library
- if test "$deplibs_check_method" != pass_all; then
+ if test pass_all != "$deplibs_check_method"; then
# We're trying link a shared library against a static one
# but the system doesn't support it.
# Just print a warning and add the library to dependency_libs so
# that the program can be linked against the static library.
echo
- $ECHO "*** Warning: This system can not link to static lib archive $lib."
+ $ECHO "*** Warning: This system cannot link to static lib archive $lib."
echo "*** I have the capability to make that library automatically link in when"
echo "*** you link to this library. But I can only do this if you have a"
echo "*** shared version of the library, which you do not appear to have."
- if test "$module" = yes; then
+ if test yes = "$module"; then
echo "*** But as you try to build a module library, libtool will still create "
echo "*** a static module, that should work as long as the dlopening application"
echo "*** is linked with the -dlopen flag to resolve symbols at runtime."
if test -z "$global_symbol_pipe"; then
echo
echo "*** However, this would only work if libtool was able to extract symbol"
- echo "*** lists from a program, using \`nm' or equivalent, but libtool could"
+ echo "*** lists from a program, using 'nm' or equivalent, but libtool could"
echo "*** not find such a program. So, this module is probably useless."
- echo "*** \`nm' from GNU binutils and a full rebuild may help."
+ echo "*** 'nm' from GNU binutils and a full rebuild may help."
fi
- if test "$build_old_libs" = no; then
+ if test no = "$build_old_libs"; then
build_libtool_libs=module
build_old_libs=yes
else
@@ -6988,11 +8436,11 @@ func_mode_link ()
fi
fi # link shared/static library?
- if test "$linkmode" = lib; then
+ if test lib = "$linkmode"; then
if test -n "$dependency_libs" &&
- { test "$hardcode_into_libs" != yes ||
- test "$build_old_libs" = yes ||
- test "$link_static" = yes; }; then
+ { test yes != "$hardcode_into_libs" ||
+ test yes = "$build_old_libs" ||
+ test yes = "$link_static"; }; then
# Extract -R from dependency_libs
temp_deplibs=
for libdir in $dependency_libs; do
@@ -7006,12 +8454,12 @@ func_mode_link ()
*) func_append temp_deplibs " $libdir";;
esac
done
- dependency_libs="$temp_deplibs"
+ dependency_libs=$temp_deplibs
fi
func_append newlib_search_path " $absdir"
# Link against this library
- test "$link_static" = no && newdependency_libs="$abs_ladir/$laname $newdependency_libs"
+ test no = "$link_static" && newdependency_libs="$abs_ladir/$laname $newdependency_libs"
# ... and its dependency_libs
tmp_libs=
for deplib in $dependency_libs; do
@@ -7021,7 +8469,7 @@ func_mode_link ()
func_resolve_sysroot "$func_stripname_result";;
*) func_resolve_sysroot "$deplib" ;;
esac
- if $opt_preserve_dup_deps ; then
+ if $opt_preserve_dup_deps; then
case "$tmp_libs " in
*" $func_resolve_sysroot_result "*)
func_append specialdeplibs " $func_resolve_sysroot_result" ;;
@@ -7030,12 +8478,12 @@ func_mode_link ()
func_append tmp_libs " $func_resolve_sysroot_result"
done
- if test "$link_all_deplibs" != no; then
+ if test no != "$link_all_deplibs"; then
# Add the search paths of all dependency libraries
for deplib in $dependency_libs; do
path=
case $deplib in
- -L*) path="$deplib" ;;
+ -L*) path=$deplib ;;
*.la)
func_resolve_sysroot "$deplib"
deplib=$func_resolve_sysroot_result
@@ -7043,12 +8491,12 @@ func_mode_link ()
dir=$func_dirname_result
# We need an absolute path.
case $dir in
- [\\/]* | [A-Za-z]:[\\/]*) absdir="$dir" ;;
+ [\\/]* | [A-Za-z]:[\\/]*) absdir=$dir ;;
*)
absdir=`cd "$dir" && pwd`
if test -z "$absdir"; then
- func_warning "cannot determine absolute directory name of \`$dir'"
- absdir="$dir"
+ func_warning "cannot determine absolute directory name of '$dir'"
+ absdir=$dir
fi
;;
esac
@@ -7056,35 +8504,35 @@ func_mode_link ()
case $host in
*-*-darwin*)
depdepl=
- eval deplibrary_names=`${SED} -n -e 's/^library_names=\(.*\)$/\1/p' $deplib`
- if test -n "$deplibrary_names" ; then
- for tmp in $deplibrary_names ; do
+ eval deplibrary_names=`$SED -n -e 's/^library_names=\(.*\)$/\1/p' $deplib`
+ if test -n "$deplibrary_names"; then
+ for tmp in $deplibrary_names; do
depdepl=$tmp
done
- if test -f "$absdir/$objdir/$depdepl" ; then
- depdepl="$absdir/$objdir/$depdepl"
- darwin_install_name=`${OTOOL} -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'`
+ if test -f "$absdir/$objdir/$depdepl"; then
+ depdepl=$absdir/$objdir/$depdepl
+ darwin_install_name=`$OTOOL -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'`
if test -z "$darwin_install_name"; then
- darwin_install_name=`${OTOOL64} -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'`
+ darwin_install_name=`$OTOOL64 -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'`
fi
- func_append compiler_flags " ${wl}-dylib_file ${wl}${darwin_install_name}:${depdepl}"
- func_append linker_flags " -dylib_file ${darwin_install_name}:${depdepl}"
+ func_append compiler_flags " $wl-dylib_file $wl$darwin_install_name:$depdepl"
+ func_append linker_flags " -dylib_file $darwin_install_name:$depdepl"
path=
fi
fi
;;
*)
- path="-L$absdir/$objdir"
+ path=-L$absdir/$objdir
;;
esac
else
- eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $deplib`
+ eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $deplib`
test -z "$libdir" && \
- func_fatal_error "\`$deplib' is not a valid libtool archive"
+ func_fatal_error "'$deplib' is not a valid libtool archive"
test "$absdir" != "$libdir" && \
- func_warning "\`$deplib' seems to be moved"
+ func_warning "'$deplib' seems to be moved"
- path="-L$absdir"
+ path=-L$absdir
fi
;;
esac
@@ -7096,23 +8544,23 @@ func_mode_link ()
fi # link_all_deplibs != no
fi # linkmode = lib
done # for deplib in $libs
- if test "$pass" = link; then
- if test "$linkmode" = "prog"; then
+ if test link = "$pass"; then
+ if test prog = "$linkmode"; then
compile_deplibs="$new_inherited_linker_flags $compile_deplibs"
finalize_deplibs="$new_inherited_linker_flags $finalize_deplibs"
else
compiler_flags="$compiler_flags "`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'`
fi
fi
- dependency_libs="$newdependency_libs"
- if test "$pass" = dlpreopen; then
+ dependency_libs=$newdependency_libs
+ if test dlpreopen = "$pass"; then
# Link the dlpreopened libraries before other libraries
for deplib in $save_deplibs; do
deplibs="$deplib $deplibs"
done
fi
- if test "$pass" != dlopen; then
- if test "$pass" != conv; then
+ if test dlopen != "$pass"; then
+ test conv = "$pass" || {
# Make sure lib_search_path contains only unique directories.
lib_search_path=
for dir in $newlib_search_path; do
@@ -7122,12 +8570,12 @@ func_mode_link ()
esac
done
newlib_search_path=
- fi
+ }
- if test "$linkmode,$pass" != "prog,link"; then
- vars="deplibs"
- else
+ if test prog,link = "$linkmode,$pass"; then
vars="compile_deplibs finalize_deplibs"
+ else
+ vars=deplibs
fi
for var in $vars dependency_libs; do
# Add libraries to $var in reverse order
@@ -7185,62 +8633,93 @@ func_mode_link ()
eval $var=\"$tmp_libs\"
done # for var
fi
+
+ # Add Sun CC postdeps if required:
+ test CXX = "$tagname" && {
+ case $host_os in
+ linux*)
+ case `$CC -V 2>&1 | sed 5q` in
+ *Sun\ C*) # Sun C++ 5.9
+ func_suncc_cstd_abi
+
+ if test no != "$suncc_use_cstd_abi"; then
+ func_append postdeps ' -library=Cstd -library=Crun'
+ fi
+ ;;
+ esac
+ ;;
+
+ solaris*)
+ func_cc_basename "$CC"
+ case $func_cc_basename_result in
+ CC* | sunCC*)
+ func_suncc_cstd_abi
+
+ if test no != "$suncc_use_cstd_abi"; then
+ func_append postdeps ' -library=Cstd -library=Crun'
+ fi
+ ;;
+ esac
+ ;;
+ esac
+ }
+
# Last step: remove runtime libs from dependency_libs
# (they stay in deplibs)
tmp_libs=
- for i in $dependency_libs ; do
+ for i in $dependency_libs; do
case " $predeps $postdeps $compiler_lib_search_path " in
*" $i "*)
- i=""
+ i=
;;
esac
- if test -n "$i" ; then
+ if test -n "$i"; then
func_append tmp_libs " $i"
fi
done
dependency_libs=$tmp_libs
done # for pass
- if test "$linkmode" = prog; then
- dlfiles="$newdlfiles"
+ if test prog = "$linkmode"; then
+ dlfiles=$newdlfiles
fi
- if test "$linkmode" = prog || test "$linkmode" = lib; then
- dlprefiles="$newdlprefiles"
+ if test prog = "$linkmode" || test lib = "$linkmode"; then
+ dlprefiles=$newdlprefiles
fi
case $linkmode in
oldlib)
- if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then
- func_warning "\`-dlopen' is ignored for archives"
+ if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then
+ func_warning "'-dlopen' is ignored for archives"
fi
case " $deplibs" in
*\ -l* | *\ -L*)
- func_warning "\`-l' and \`-L' are ignored for archives" ;;
+ func_warning "'-l' and '-L' are ignored for archives" ;;
esac
test -n "$rpath" && \
- func_warning "\`-rpath' is ignored for archives"
+ func_warning "'-rpath' is ignored for archives"
test -n "$xrpath" && \
- func_warning "\`-R' is ignored for archives"
+ func_warning "'-R' is ignored for archives"
test -n "$vinfo" && \
- func_warning "\`-version-info/-version-number' is ignored for archives"
+ func_warning "'-version-info/-version-number' is ignored for archives"
test -n "$release" && \
- func_warning "\`-release' is ignored for archives"
+ func_warning "'-release' is ignored for archives"
test -n "$export_symbols$export_symbols_regex" && \
- func_warning "\`-export-symbols' is ignored for archives"
+ func_warning "'-export-symbols' is ignored for archives"
# Now set the variables for building old libraries.
build_libtool_libs=no
- oldlibs="$output"
+ oldlibs=$output
func_append objs "$old_deplibs"
;;
lib)
- # Make sure we only generate libraries of the form `libNAME.la'.
+ # Make sure we only generate libraries of the form 'libNAME.la'.
case $outputname in
lib*)
func_stripname 'lib' '.la' "$outputname"
@@ -7249,10 +8728,10 @@ func_mode_link ()
eval libname=\"$libname_spec\"
;;
*)
- test "$module" = no && \
- func_fatal_help "libtool library \`$output' must begin with \`lib'"
+ test no = "$module" \
+ && func_fatal_help "libtool library '$output' must begin with 'lib'"
- if test "$need_lib_prefix" != no; then
+ if test no != "$need_lib_prefix"; then
# Add the "lib" prefix for modules if required
func_stripname '' '.la' "$outputname"
name=$func_stripname_result
@@ -7266,8 +8745,8 @@ func_mode_link ()
esac
if test -n "$objs"; then
- if test "$deplibs_check_method" != pass_all; then
- func_fatal_error "cannot build libtool library \`$output' from non-libtool objects on this host:$objs"
+ if test pass_all != "$deplibs_check_method"; then
+ func_fatal_error "cannot build libtool library '$output' from non-libtool objects on this host:$objs"
else
echo
$ECHO "*** Warning: Linking the shared library $output against the non-libtool"
@@ -7276,21 +8755,21 @@ func_mode_link ()
fi
fi
- test "$dlself" != no && \
- func_warning "\`-dlopen self' is ignored for libtool libraries"
+ test no = "$dlself" \
+ || func_warning "'-dlopen self' is ignored for libtool libraries"
set dummy $rpath
shift
- test "$#" -gt 1 && \
- func_warning "ignoring multiple \`-rpath's for a libtool library"
+ test 1 -lt "$#" \
+ && func_warning "ignoring multiple '-rpath's for a libtool library"
- install_libdir="$1"
+ install_libdir=$1
oldlibs=
if test -z "$rpath"; then
- if test "$build_libtool_libs" = yes; then
+ if test yes = "$build_libtool_libs"; then
# Building a libtool convenience library.
- # Some compilers have problems with a `.al' extension so
+ # Some compilers have problems with a '.al' extension so
# convenience libraries should have the same extension an
# archive normally would.
oldlibs="$output_objdir/$libname.$libext $oldlibs"
@@ -7299,20 +8778,20 @@ func_mode_link ()
fi
test -n "$vinfo" && \
- func_warning "\`-version-info/-version-number' is ignored for convenience libraries"
+ func_warning "'-version-info/-version-number' is ignored for convenience libraries"
test -n "$release" && \
- func_warning "\`-release' is ignored for convenience libraries"
+ func_warning "'-release' is ignored for convenience libraries"
else
# Parse the version information argument.
- save_ifs="$IFS"; IFS=':'
+ save_ifs=$IFS; IFS=:
set dummy $vinfo 0 0 0
shift
- IFS="$save_ifs"
+ IFS=$save_ifs
test -n "$7" && \
- func_fatal_help "too many parameters to \`-version-info'"
+ func_fatal_help "too many parameters to '-version-info'"
# convert absolute version numbers to libtool ages
# this retains compatibility with .la files and attempts
@@ -7320,42 +8799,45 @@ func_mode_link ()
case $vinfo_number in
yes)
- number_major="$1"
- number_minor="$2"
- number_revision="$3"
+ number_major=$1
+ number_minor=$2
+ number_revision=$3
#
# There are really only two kinds -- those that
# use the current revision as the major version
# and those that subtract age and use age as
# a minor version. But, then there is irix
- # which has an extra 1 added just for fun
+ # that has an extra 1 added just for fun
#
case $version_type in
# correct linux to gnu/linux during the next big refactor
- darwin|linux|osf|windows|none)
+ darwin|freebsd-elf|linux|osf|windows|none)
func_arith $number_major + $number_minor
current=$func_arith_result
- age="$number_minor"
- revision="$number_revision"
+ age=$number_minor
+ revision=$number_revision
;;
- freebsd-aout|freebsd-elf|qnx|sunos)
- current="$number_major"
- revision="$number_minor"
- age="0"
+ freebsd-aout|qnx|sunos)
+ current=$number_major
+ revision=$number_minor
+ age=0
;;
irix|nonstopux)
func_arith $number_major + $number_minor
current=$func_arith_result
- age="$number_minor"
- revision="$number_minor"
+ age=$number_minor
+ revision=$number_minor
lt_irix_increment=no
;;
+ *)
+ func_fatal_configuration "$modename: unknown library version type '$version_type'"
+ ;;
esac
;;
no)
- current="$1"
- revision="$2"
- age="$3"
+ current=$1
+ revision=$2
+ age=$3
;;
esac
@@ -7363,30 +8845,30 @@ func_mode_link ()
case $current in
0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;;
*)
- func_error "CURRENT \`$current' must be a nonnegative integer"
- func_fatal_error "\`$vinfo' is not valid version information"
+ func_error "CURRENT '$current' must be a nonnegative integer"
+ func_fatal_error "'$vinfo' is not valid version information"
;;
esac
case $revision in
0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;;
*)
- func_error "REVISION \`$revision' must be a nonnegative integer"
- func_fatal_error "\`$vinfo' is not valid version information"
+ func_error "REVISION '$revision' must be a nonnegative integer"
+ func_fatal_error "'$vinfo' is not valid version information"
;;
esac
case $age in
0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;;
*)
- func_error "AGE \`$age' must be a nonnegative integer"
- func_fatal_error "\`$vinfo' is not valid version information"
+ func_error "AGE '$age' must be a nonnegative integer"
+ func_fatal_error "'$vinfo' is not valid version information"
;;
esac
if test "$age" -gt "$current"; then
- func_error "AGE \`$age' is greater than the current interface number \`$current'"
- func_fatal_error "\`$vinfo' is not valid version information"
+ func_error "AGE '$age' is greater than the current interface number '$current'"
+ func_fatal_error "'$vinfo' is not valid version information"
fi
# Calculate the version variables.
@@ -7401,26 +8883,36 @@ func_mode_link ()
# verstring for coding it into the library header
func_arith $current - $age
major=.$func_arith_result
- versuffix="$major.$age.$revision"
+ versuffix=$major.$age.$revision
# Darwin ld doesn't like 0 for these options...
func_arith $current + 1
minor_current=$func_arith_result
- xlcverstring="${wl}-compatibility_version ${wl}$minor_current ${wl}-current_version ${wl}$minor_current.$revision"
+ xlcverstring="$wl-compatibility_version $wl$minor_current $wl-current_version $wl$minor_current.$revision"
verstring="-compatibility_version $minor_current -current_version $minor_current.$revision"
+ # On Darwin other compilers
+ case $CC in
+ nagfor*)
+ verstring="$wl-compatibility_version $wl$minor_current $wl-current_version $wl$minor_current.$revision"
+ ;;
+ *)
+ verstring="-compatibility_version $minor_current -current_version $minor_current.$revision"
+ ;;
+ esac
;;
freebsd-aout)
- major=".$current"
- versuffix=".$current.$revision";
+ major=.$current
+ versuffix=.$current.$revision
;;
freebsd-elf)
- major=".$current"
- versuffix=".$current"
+ func_arith $current - $age
+ major=.$func_arith_result
+ versuffix=$major.$age.$revision
;;
irix | nonstopux)
- if test "X$lt_irix_increment" = "Xno"; then
+ if test no = "$lt_irix_increment"; then
func_arith $current - $age
else
func_arith $current - $age + 1
@@ -7431,69 +8923,74 @@ func_mode_link ()
nonstopux) verstring_prefix=nonstopux ;;
*) verstring_prefix=sgi ;;
esac
- verstring="$verstring_prefix$major.$revision"
+ verstring=$verstring_prefix$major.$revision
# Add in all the interfaces that we are compatible with.
loop=$revision
- while test "$loop" -ne 0; do
+ while test 0 -ne "$loop"; do
func_arith $revision - $loop
iface=$func_arith_result
func_arith $loop - 1
loop=$func_arith_result
- verstring="$verstring_prefix$major.$iface:$verstring"
+ verstring=$verstring_prefix$major.$iface:$verstring
done
- # Before this point, $major must not contain `.'.
+ # Before this point, $major must not contain '.'.
major=.$major
- versuffix="$major.$revision"
+ versuffix=$major.$revision
;;
linux) # correct to gnu/linux during the next big refactor
func_arith $current - $age
major=.$func_arith_result
- versuffix="$major.$age.$revision"
+ versuffix=$major.$age.$revision
;;
osf)
func_arith $current - $age
major=.$func_arith_result
- versuffix=".$current.$age.$revision"
- verstring="$current.$age.$revision"
+ versuffix=.$current.$age.$revision
+ verstring=$current.$age.$revision
# Add in all the interfaces that we are compatible with.
loop=$age
- while test "$loop" -ne 0; do
+ while test 0 -ne "$loop"; do
func_arith $current - $loop
iface=$func_arith_result
func_arith $loop - 1
loop=$func_arith_result
- verstring="$verstring:${iface}.0"
+ verstring=$verstring:$iface.0
done
# Make executables depend on our current version.
- func_append verstring ":${current}.0"
+ func_append verstring ":$current.0"
;;
qnx)
- major=".$current"
- versuffix=".$current"
+ major=.$current
+ versuffix=.$current
+ ;;
+
+ sco)
+ major=.$current
+ versuffix=.$current
;;
sunos)
- major=".$current"
- versuffix=".$current.$revision"
+ major=.$current
+ versuffix=.$current.$revision
;;
windows)
# Use '-' rather than '.', since we only want one
- # extension on DOS 8.3 filesystems.
+ # extension on DOS 8.3 file systems.
func_arith $current - $age
major=$func_arith_result
- versuffix="-$major"
+ versuffix=-$major
;;
*)
- func_fatal_configuration "unknown library version type \`$version_type'"
+ func_fatal_configuration "unknown library version type '$version_type'"
;;
esac
@@ -7507,42 +9004,45 @@ func_mode_link ()
verstring=
;;
*)
- verstring="0.0"
+ verstring=0.0
;;
esac
- if test "$need_version" = no; then
+ if test no = "$need_version"; then
versuffix=
else
- versuffix=".0.0"
+ versuffix=.0.0
fi
fi
# Remove version info from name if versioning should be avoided
- if test "$avoid_version" = yes && test "$need_version" = no; then
+ if test yes,no = "$avoid_version,$need_version"; then
major=
versuffix=
- verstring=""
+ verstring=
fi
# Check to see if the archive will have undefined symbols.
- if test "$allow_undefined" = yes; then
- if test "$allow_undefined_flag" = unsupported; then
- func_warning "undefined symbols not allowed in $host shared libraries"
- build_libtool_libs=no
- build_old_libs=yes
+ if test yes = "$allow_undefined"; then
+ if test unsupported = "$allow_undefined_flag"; then
+ if test yes = "$build_old_libs"; then
+ func_warning "undefined symbols not allowed in $host shared libraries; building static only"
+ build_libtool_libs=no
+ else
+ func_fatal_error "can't build $host shared library unless -no-undefined is specified"
+ fi
fi
else
# Don't allow undefined symbols.
- allow_undefined_flag="$no_undefined_flag"
+ allow_undefined_flag=$no_undefined_flag
fi
fi
- func_generate_dlsyms "$libname" "$libname" "yes"
+ func_generate_dlsyms "$libname" "$libname" :
func_append libobjs " $symfileobj"
- test "X$libobjs" = "X " && libobjs=
+ test " " = "$libobjs" && libobjs=
- if test "$opt_mode" != relink; then
+ if test relink != "$opt_mode"; then
# Remove our outputs, but don't remove object files since they
# may have been created when compiling PIC objects.
removelist=
@@ -7551,8 +9051,8 @@ func_mode_link ()
case $p in
*.$objext | *.gcno)
;;
- $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/${libname}${release}.*)
- if test "X$precious_files_regex" != "X"; then
+ $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/$libname$release.*)
+ if test -n "$precious_files_regex"; then
if $ECHO "$p" | $EGREP -e "$precious_files_regex" >/dev/null 2>&1
then
continue
@@ -7568,11 +9068,11 @@ func_mode_link ()
fi
# Now set the variables for building old libraries.
- if test "$build_old_libs" = yes && test "$build_libtool_libs" != convenience ; then
+ if test yes = "$build_old_libs" && test convenience != "$build_libtool_libs"; then
func_append oldlibs " $output_objdir/$libname.$libext"
# Transform .lo files to .o files.
- oldobjs="$objs "`$ECHO "$libobjs" | $SP2NL | $SED "/\.${libext}$/d; $lo2o" | $NL2SP`
+ oldobjs="$objs "`$ECHO "$libobjs" | $SP2NL | $SED "/\.$libext$/d; $lo2o" | $NL2SP`
fi
# Eliminate all temporary directories.
@@ -7593,13 +9093,13 @@ func_mode_link ()
*) func_append finalize_rpath " $libdir" ;;
esac
done
- if test "$hardcode_into_libs" != yes || test "$build_old_libs" = yes; then
+ if test yes != "$hardcode_into_libs" || test yes = "$build_old_libs"; then
dependency_libs="$temp_xrpath $dependency_libs"
fi
fi
# Make sure dlfiles contains only unique files that won't be dlpreopened
- old_dlfiles="$dlfiles"
+ old_dlfiles=$dlfiles
dlfiles=
for lib in $old_dlfiles; do
case " $dlprefiles $dlfiles " in
@@ -7609,7 +9109,7 @@ func_mode_link ()
done
# Make sure dlprefiles contains only unique files
- old_dlprefiles="$dlprefiles"
+ old_dlprefiles=$dlprefiles
dlprefiles=
for lib in $old_dlprefiles; do
case "$dlprefiles " in
@@ -7618,7 +9118,7 @@ func_mode_link ()
esac
done
- if test "$build_libtool_libs" = yes; then
+ if test yes = "$build_libtool_libs"; then
if test -n "$rpath"; then
case $host in
*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos* | *-cegcc* | *-*-haiku*)
@@ -7642,7 +9142,7 @@ func_mode_link ()
;;
*)
# Add libc to deplibs on all other systems if necessary.
- if test "$build_libtool_need_lc" = "yes"; then
+ if test yes = "$build_libtool_need_lc"; then
func_append deplibs " -lc"
fi
;;
@@ -7658,9 +9158,9 @@ func_mode_link ()
# I'm not sure if I'm treating the release correctly. I think
# release should show up in the -l (ie -lgmp5) so we don't want to
# add it in twice. Is that correct?
- release=""
- versuffix=""
- major=""
+ release=
+ versuffix=
+ major=
newdeplibs=
droppeddeps=no
case $deplibs_check_method in
@@ -7689,20 +9189,20 @@ EOF
-l*)
func_stripname -l '' "$i"
name=$func_stripname_result
- if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
+ if test yes = "$allow_libtool_libs_with_static_runtimes"; then
case " $predeps $postdeps " in
*" $i "*)
func_append newdeplibs " $i"
- i=""
+ i=
;;
esac
fi
- if test -n "$i" ; then
+ if test -n "$i"; then
libname=`eval "\\$ECHO \"$libname_spec\""`
deplib_matches=`eval "\\$ECHO \"$library_names_spec\""`
set dummy $deplib_matches; shift
deplib_match=$1
- if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0 ; then
+ if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0; then
func_append newdeplibs " $i"
else
droppeddeps=yes
@@ -7732,20 +9232,20 @@ EOF
$opt_dry_run || $RM conftest
if $LTCC $LTCFLAGS -o conftest conftest.c $i; then
ldd_output=`ldd conftest`
- if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
+ if test yes = "$allow_libtool_libs_with_static_runtimes"; then
case " $predeps $postdeps " in
*" $i "*)
func_append newdeplibs " $i"
- i=""
+ i=
;;
esac
fi
- if test -n "$i" ; then
+ if test -n "$i"; then
libname=`eval "\\$ECHO \"$libname_spec\""`
deplib_matches=`eval "\\$ECHO \"$library_names_spec\""`
set dummy $deplib_matches; shift
deplib_match=$1
- if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0 ; then
+ if test `expr "$ldd_output" : ".*$deplib_match"` -ne 0; then
func_append newdeplibs " $i"
else
droppeddeps=yes
@@ -7782,24 +9282,24 @@ EOF
-l*)
func_stripname -l '' "$a_deplib"
name=$func_stripname_result
- if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
+ if test yes = "$allow_libtool_libs_with_static_runtimes"; then
case " $predeps $postdeps " in
*" $a_deplib "*)
func_append newdeplibs " $a_deplib"
- a_deplib=""
+ a_deplib=
;;
esac
fi
- if test -n "$a_deplib" ; then
+ if test -n "$a_deplib"; then
libname=`eval "\\$ECHO \"$libname_spec\""`
if test -n "$file_magic_glob"; then
libnameglob=`func_echo_all "$libname" | $SED -e $file_magic_glob`
else
libnameglob=$libname
fi
- test "$want_nocaseglob" = yes && nocaseglob=`shopt -p nocaseglob`
+ test yes = "$want_nocaseglob" && nocaseglob=`shopt -p nocaseglob`
for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do
- if test "$want_nocaseglob" = yes; then
+ if test yes = "$want_nocaseglob"; then
shopt -s nocaseglob
potential_libs=`ls $i/$libnameglob[.-]* 2>/dev/null`
$nocaseglob
@@ -7817,25 +9317,25 @@ EOF
# We might still enter an endless loop, since a link
# loop can be closed while we follow links,
# but so what?
- potlib="$potent_lib"
+ potlib=$potent_lib
while test -h "$potlib" 2>/dev/null; do
- potliblink=`ls -ld $potlib | ${SED} 's/.* -> //'`
+ potliblink=`ls -ld $potlib | $SED 's/.* -> //'`
case $potliblink in
- [\\/]* | [A-Za-z]:[\\/]*) potlib="$potliblink";;
- *) potlib=`$ECHO "$potlib" | $SED 's,[^/]*$,,'`"$potliblink";;
+ [\\/]* | [A-Za-z]:[\\/]*) potlib=$potliblink;;
+ *) potlib=`$ECHO "$potlib" | $SED 's|[^/]*$||'`"$potliblink";;
esac
done
if eval $file_magic_cmd \"\$potlib\" 2>/dev/null |
$SED -e 10q |
$EGREP "$file_magic_regex" > /dev/null; then
func_append newdeplibs " $a_deplib"
- a_deplib=""
+ a_deplib=
break 2
fi
done
done
fi
- if test -n "$a_deplib" ; then
+ if test -n "$a_deplib"; then
droppeddeps=yes
echo
$ECHO "*** Warning: linker path does not have real file for library $a_deplib."
@@ -7843,7 +9343,7 @@ EOF
echo "*** you link to this library. But I can only do this if you have a"
echo "*** shared version of the library, which you do not appear to have"
echo "*** because I did check the linker path looking for a file starting"
- if test -z "$potlib" ; then
+ if test -z "$potlib"; then
$ECHO "*** with $libname but no candidates were found. (...for file magic test)"
else
$ECHO "*** with $libname and none of the candidates passed a file format test"
@@ -7866,30 +9366,30 @@ EOF
-l*)
func_stripname -l '' "$a_deplib"
name=$func_stripname_result
- if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
+ if test yes = "$allow_libtool_libs_with_static_runtimes"; then
case " $predeps $postdeps " in
*" $a_deplib "*)
func_append newdeplibs " $a_deplib"
- a_deplib=""
+ a_deplib=
;;
esac
fi
- if test -n "$a_deplib" ; then
+ if test -n "$a_deplib"; then
libname=`eval "\\$ECHO \"$libname_spec\""`
for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do
potential_libs=`ls $i/$libname[.-]* 2>/dev/null`
for potent_lib in $potential_libs; do
- potlib="$potent_lib" # see symlink-check above in file_magic test
+ potlib=$potent_lib # see symlink-check above in file_magic test
if eval "\$ECHO \"$potent_lib\"" 2>/dev/null | $SED 10q | \
$EGREP "$match_pattern_regex" > /dev/null; then
func_append newdeplibs " $a_deplib"
- a_deplib=""
+ a_deplib=
break 2
fi
done
done
fi
- if test -n "$a_deplib" ; then
+ if test -n "$a_deplib"; then
droppeddeps=yes
echo
$ECHO "*** Warning: linker path does not have real file for library $a_deplib."
@@ -7897,7 +9397,7 @@ EOF
echo "*** you link to this library. But I can only do this if you have a"
echo "*** shared version of the library, which you do not appear to have"
echo "*** because I did check the linker path looking for a file starting"
- if test -z "$potlib" ; then
+ if test -z "$potlib"; then
$ECHO "*** with $libname but no candidates were found. (...for regex pattern test)"
else
$ECHO "*** with $libname and none of the candidates passed a file format test"
@@ -7913,18 +9413,18 @@ EOF
done # Gone through all deplibs.
;;
none | unknown | *)
- newdeplibs=""
+ newdeplibs=
tmp_deplibs=`$ECHO " $deplibs" | $SED 's/ -lc$//; s/ -[LR][^ ]*//g'`
- if test "X$allow_libtool_libs_with_static_runtimes" = "Xyes" ; then
- for i in $predeps $postdeps ; do
+ if test yes = "$allow_libtool_libs_with_static_runtimes"; then
+ for i in $predeps $postdeps; do
# can't use Xsed below, because $i might contain '/'
- tmp_deplibs=`$ECHO " $tmp_deplibs" | $SED "s,$i,,"`
+ tmp_deplibs=`$ECHO " $tmp_deplibs" | $SED "s|$i||"`
done
fi
case $tmp_deplibs in
*[!\ \ ]*)
echo
- if test "X$deplibs_check_method" = "Xnone"; then
+ if test none = "$deplibs_check_method"; then
echo "*** Warning: inter-library dependencies are not supported in this platform."
else
echo "*** Warning: inter-library dependencies are not known to be supported."
@@ -7948,8 +9448,8 @@ EOF
;;
esac
- if test "$droppeddeps" = yes; then
- if test "$module" = yes; then
+ if test yes = "$droppeddeps"; then
+ if test yes = "$module"; then
echo
echo "*** Warning: libtool could not satisfy all declared inter-library"
$ECHO "*** dependencies of module $libname. Therefore, libtool will create"
@@ -7958,12 +9458,12 @@ EOF
if test -z "$global_symbol_pipe"; then
echo
echo "*** However, this would only work if libtool was able to extract symbol"
- echo "*** lists from a program, using \`nm' or equivalent, but libtool could"
+ echo "*** lists from a program, using 'nm' or equivalent, but libtool could"
echo "*** not find such a program. So, this module is probably useless."
- echo "*** \`nm' from GNU binutils and a full rebuild may help."
+ echo "*** 'nm' from GNU binutils and a full rebuild may help."
fi
- if test "$build_old_libs" = no; then
- oldlibs="$output_objdir/$libname.$libext"
+ if test no = "$build_old_libs"; then
+ oldlibs=$output_objdir/$libname.$libext
build_libtool_libs=module
build_old_libs=yes
else
@@ -7974,14 +9474,14 @@ EOF
echo "*** automatically added whenever a program is linked with this library"
echo "*** or is declared to -dlopen it."
- if test "$allow_undefined" = no; then
+ if test no = "$allow_undefined"; then
echo
echo "*** Since this library must not contain undefined symbols,"
echo "*** because either the platform does not support them or"
echo "*** it was explicitly requested with -no-undefined,"
echo "*** libtool will only create a static version of it."
- if test "$build_old_libs" = no; then
- oldlibs="$output_objdir/$libname.$libext"
+ if test no = "$build_old_libs"; then
+ oldlibs=$output_objdir/$libname.$libext
build_libtool_libs=module
build_old_libs=yes
else
@@ -8027,7 +9527,7 @@ EOF
*) func_append new_libs " $deplib" ;;
esac
done
- deplibs="$new_libs"
+ deplibs=$new_libs
# All the library-specific variables (install_libdir is set above).
library_names=
@@ -8035,25 +9535,25 @@ EOF
dlname=
# Test again, we may have decided not to build it any more
- if test "$build_libtool_libs" = yes; then
- # Remove ${wl} instances when linking with ld.
+ if test yes = "$build_libtool_libs"; then
+ # Remove $wl instances when linking with ld.
# FIXME: should test the right _cmds variable.
case $archive_cmds in
*\$LD\ *) wl= ;;
esac
- if test "$hardcode_into_libs" = yes; then
+ if test yes = "$hardcode_into_libs"; then
# Hardcode the library paths
hardcode_libdirs=
dep_rpath=
- rpath="$finalize_rpath"
- test "$opt_mode" != relink && rpath="$compile_rpath$rpath"
+ rpath=$finalize_rpath
+ test relink = "$opt_mode" || rpath=$compile_rpath$rpath
for libdir in $rpath; do
if test -n "$hardcode_libdir_flag_spec"; then
if test -n "$hardcode_libdir_separator"; then
func_replace_sysroot "$libdir"
libdir=$func_replace_sysroot_result
if test -z "$hardcode_libdirs"; then
- hardcode_libdirs="$libdir"
+ hardcode_libdirs=$libdir
else
# Just accumulate the unique libdirs.
case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
@@ -8078,7 +9578,7 @@ EOF
# Substitute the hardcoded libdirs into the rpath.
if test -n "$hardcode_libdir_separator" &&
test -n "$hardcode_libdirs"; then
- libdir="$hardcode_libdirs"
+ libdir=$hardcode_libdirs
eval "dep_rpath=\"$hardcode_libdir_flag_spec\""
fi
if test -n "$runpath_var" && test -n "$perm_rpath"; then
@@ -8092,8 +9592,8 @@ EOF
test -n "$dep_rpath" && deplibs="$dep_rpath $deplibs"
fi
- shlibpath="$finalize_shlibpath"
- test "$opt_mode" != relink && shlibpath="$compile_shlibpath$shlibpath"
+ shlibpath=$finalize_shlibpath
+ test relink = "$opt_mode" || shlibpath=$compile_shlibpath$shlibpath
if test -n "$shlibpath"; then
eval "$shlibpath_var='$shlibpath\$$shlibpath_var'; export $shlibpath_var"
fi
@@ -8103,19 +9603,19 @@ EOF
eval library_names=\"$library_names_spec\"
set dummy $library_names
shift
- realname="$1"
+ realname=$1
shift
if test -n "$soname_spec"; then
eval soname=\"$soname_spec\"
else
- soname="$realname"
+ soname=$realname
fi
if test -z "$dlname"; then
dlname=$soname
fi
- lib="$output_objdir/$realname"
+ lib=$output_objdir/$realname
linknames=
for link
do
@@ -8129,7 +9629,7 @@ EOF
delfiles=
if test -n "$export_symbols" && test -n "$include_expsyms"; then
$opt_dry_run || cp "$export_symbols" "$output_objdir/$libname.uexp"
- export_symbols="$output_objdir/$libname.uexp"
+ export_symbols=$output_objdir/$libname.uexp
func_append delfiles " $export_symbols"
fi
@@ -8138,31 +9638,31 @@ EOF
cygwin* | mingw* | cegcc*)
if test -n "$export_symbols" && test -z "$export_symbols_regex"; then
# exporting using user supplied symfile
- if test "x`$SED 1q $export_symbols`" != xEXPORTS; then
+ func_dll_def_p "$export_symbols" || {
# and it's NOT already a .def file. Must figure out
# which of the given symbols are data symbols and tag
# them as such. So, trigger use of export_symbols_cmds.
# export_symbols gets reassigned inside the "prepare
# the list of exported symbols" if statement, so the
# include_expsyms logic still works.
- orig_export_symbols="$export_symbols"
+ orig_export_symbols=$export_symbols
export_symbols=
always_export_symbols=yes
- fi
+ }
fi
;;
esac
# Prepare the list of exported symbols
if test -z "$export_symbols"; then
- if test "$always_export_symbols" = yes || test -n "$export_symbols_regex"; then
- func_verbose "generating symbol list for \`$libname.la'"
- export_symbols="$output_objdir/$libname.exp"
+ if test yes = "$always_export_symbols" || test -n "$export_symbols_regex"; then
+ func_verbose "generating symbol list for '$libname.la'"
+ export_symbols=$output_objdir/$libname.exp
$opt_dry_run || $RM $export_symbols
cmds=$export_symbols_cmds
- save_ifs="$IFS"; IFS='~'
+ save_ifs=$IFS; IFS='~'
for cmd1 in $cmds; do
- IFS="$save_ifs"
+ IFS=$save_ifs
# Take the normal branch if the nm_file_list_spec branch
# doesn't work or if tool conversion is not needed.
case $nm_file_list_spec~$to_tool_file_cmd in
@@ -8176,7 +9676,7 @@ EOF
try_normal_branch=no
;;
esac
- if test "$try_normal_branch" = yes \
+ if test yes = "$try_normal_branch" \
&& { test "$len" -lt "$max_cmd_len" \
|| test "$max_cmd_len" -le -1; }
then
@@ -8187,7 +9687,7 @@ EOF
output_la=$func_basename_result
save_libobjs=$libobjs
save_output=$output
- output=${output_objdir}/${output_la}.nm
+ output=$output_objdir/$output_la.nm
func_to_tool_file "$output"
libobjs=$nm_file_list_spec$func_to_tool_file_result
func_append delfiles " $output"
@@ -8210,8 +9710,8 @@ EOF
break
fi
done
- IFS="$save_ifs"
- if test -n "$export_symbols_regex" && test "X$skipped_export" != "X:"; then
+ IFS=$save_ifs
+ if test -n "$export_symbols_regex" && test : != "$skipped_export"; then
func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"'
func_show_eval '$MV "${export_symbols}T" "$export_symbols"'
fi
@@ -8219,16 +9719,16 @@ EOF
fi
if test -n "$export_symbols" && test -n "$include_expsyms"; then
- tmp_export_symbols="$export_symbols"
- test -n "$orig_export_symbols" && tmp_export_symbols="$orig_export_symbols"
+ tmp_export_symbols=$export_symbols
+ test -n "$orig_export_symbols" && tmp_export_symbols=$orig_export_symbols
$opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"'
fi
- if test "X$skipped_export" != "X:" && test -n "$orig_export_symbols"; then
+ if test : != "$skipped_export" && test -n "$orig_export_symbols"; then
# The given exports_symbols file has to be filtered, so filter it.
- func_verbose "filter symbol list for \`$libname.la' to tag DATA exports"
+ func_verbose "filter symbol list for '$libname.la' to tag DATA exports"
# FIXME: $output_objdir/$libname.filter potentially contains lots of
- # 's' commands which not all seds can handle. GNU sed should be fine
+ # 's' commands, which not all seds can handle. GNU sed should be fine
# though. Also, the filter scales superlinearly with the number of
# global variables. join(1) would be nice here, but unfortunately
# isn't a blessed tool.
@@ -8247,11 +9747,11 @@ EOF
;;
esac
done
- deplibs="$tmp_deplibs"
+ deplibs=$tmp_deplibs
if test -n "$convenience"; then
if test -n "$whole_archive_flag_spec" &&
- test "$compiler_needs_object" = yes &&
+ test yes = "$compiler_needs_object" &&
test -z "$libobjs"; then
# extract the archives, so we have objects to list.
# TODO: could optimize this to just extract one archive.
@@ -8262,7 +9762,7 @@ EOF
eval libobjs=\"\$libobjs $whole_archive_flag_spec\"
test "X$libobjs" = "X " && libobjs=
else
- gentop="$output_objdir/${outputname}x"
+ gentop=$output_objdir/${outputname}x
func_append generated " $gentop"
func_extract_archives $gentop $convenience
@@ -8271,18 +9771,18 @@ EOF
fi
fi
- if test "$thread_safe" = yes && test -n "$thread_safe_flag_spec"; then
+ if test yes = "$thread_safe" && test -n "$thread_safe_flag_spec"; then
eval flag=\"$thread_safe_flag_spec\"
func_append linker_flags " $flag"
fi
# Make a backup of the uninstalled library when relinking
- if test "$opt_mode" = relink; then
+ if test relink = "$opt_mode"; then
$opt_dry_run || eval '(cd $output_objdir && $RM ${realname}U && $MV $realname ${realname}U)' || exit $?
fi
# Do each of the archive commands.
- if test "$module" = yes && test -n "$module_cmds" ; then
+ if test yes = "$module" && test -n "$module_cmds"; then
if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then
eval test_cmds=\"$module_expsym_cmds\"
cmds=$module_expsym_cmds
@@ -8300,7 +9800,7 @@ EOF
fi
fi
- if test "X$skipped_export" != "X:" &&
+ if test : != "$skipped_export" &&
func_len " $test_cmds" &&
len=$func_len_result &&
test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then
@@ -8333,8 +9833,8 @@ EOF
last_robj=
k=1
- if test -n "$save_libobjs" && test "X$skipped_export" != "X:" && test "$with_gnu_ld" = yes; then
- output=${output_objdir}/${output_la}.lnkscript
+ if test -n "$save_libobjs" && test : != "$skipped_export" && test yes = "$with_gnu_ld"; then
+ output=$output_objdir/$output_la.lnkscript
func_verbose "creating GNU ld script: $output"
echo 'INPUT (' > $output
for obj in $save_libobjs
@@ -8346,14 +9846,14 @@ EOF
func_append delfiles " $output"
func_to_tool_file "$output"
output=$func_to_tool_file_result
- elif test -n "$save_libobjs" && test "X$skipped_export" != "X:" && test "X$file_list_spec" != X; then
- output=${output_objdir}/${output_la}.lnk
+ elif test -n "$save_libobjs" && test : != "$skipped_export" && test -n "$file_list_spec"; then
+ output=$output_objdir/$output_la.lnk
func_verbose "creating linker input file list: $output"
: > $output
set x $save_libobjs
shift
firstobj=
- if test "$compiler_needs_object" = yes; then
+ if test yes = "$compiler_needs_object"; then
firstobj="$1 "
shift
fi
@@ -8368,7 +9868,7 @@ EOF
else
if test -n "$save_libobjs"; then
func_verbose "creating reloadable object files..."
- output=$output_objdir/$output_la-${k}.$objext
+ output=$output_objdir/$output_la-$k.$objext
eval test_cmds=\"$reload_cmds\"
func_len " $test_cmds"
len0=$func_len_result
@@ -8380,13 +9880,13 @@ EOF
func_len " $obj"
func_arith $len + $func_len_result
len=$func_arith_result
- if test "X$objlist" = X ||
+ if test -z "$objlist" ||
test "$len" -lt "$max_cmd_len"; then
func_append objlist " $obj"
else
# The command $test_cmds is almost too long, add a
# command to the queue.
- if test "$k" -eq 1 ; then
+ if test 1 -eq "$k"; then
# The first file doesn't have a previous command to add.
reload_objs=$objlist
eval concat_cmds=\"$reload_cmds\"
@@ -8396,10 +9896,10 @@ EOF
reload_objs="$objlist $last_robj"
eval concat_cmds=\"\$concat_cmds~$reload_cmds~\$RM $last_robj\"
fi
- last_robj=$output_objdir/$output_la-${k}.$objext
+ last_robj=$output_objdir/$output_la-$k.$objext
func_arith $k + 1
k=$func_arith_result
- output=$output_objdir/$output_la-${k}.$objext
+ output=$output_objdir/$output_la-$k.$objext
objlist=" $obj"
func_len " $last_robj"
func_arith $len0 + $func_len_result
@@ -8411,9 +9911,9 @@ EOF
# files will link in the last one created.
test -z "$concat_cmds" || concat_cmds=$concat_cmds~
reload_objs="$objlist $last_robj"
- eval concat_cmds=\"\${concat_cmds}$reload_cmds\"
+ eval concat_cmds=\"\$concat_cmds$reload_cmds\"
if test -n "$last_robj"; then
- eval concat_cmds=\"\${concat_cmds}~\$RM $last_robj\"
+ eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\"
fi
func_append delfiles " $output"
@@ -8421,9 +9921,9 @@ EOF
output=
fi
- if ${skipped_export-false}; then
- func_verbose "generating symbol list for \`$libname.la'"
- export_symbols="$output_objdir/$libname.exp"
+ ${skipped_export-false} && {
+ func_verbose "generating symbol list for '$libname.la'"
+ export_symbols=$output_objdir/$libname.exp
$opt_dry_run || $RM $export_symbols
libobjs=$output
# Append the command to create the export file.
@@ -8432,16 +9932,16 @@ EOF
if test -n "$last_robj"; then
eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\"
fi
- fi
+ }
test -n "$save_libobjs" &&
func_verbose "creating a temporary reloadable object file: $output"
# Loop through the commands generated above and execute them.
- save_ifs="$IFS"; IFS='~'
+ save_ifs=$IFS; IFS='~'
for cmd in $concat_cmds; do
- IFS="$save_ifs"
- $opt_silent || {
+ IFS=$save_ifs
+ $opt_quiet || {
func_quote_for_expand "$cmd"
eval "func_echo $func_quote_for_expand_result"
}
@@ -8449,7 +9949,7 @@ EOF
lt_exit=$?
# Restore the uninstalled library and exit
- if test "$opt_mode" = relink; then
+ if test relink = "$opt_mode"; then
( cd "$output_objdir" && \
$RM "${realname}T" && \
$MV "${realname}U" "$realname" )
@@ -8458,7 +9958,7 @@ EOF
exit $lt_exit
}
done
- IFS="$save_ifs"
+ IFS=$save_ifs
if test -n "$export_symbols_regex" && ${skipped_export-false}; then
func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"'
@@ -8466,18 +9966,18 @@ EOF
fi
fi
- if ${skipped_export-false}; then
+ ${skipped_export-false} && {
if test -n "$export_symbols" && test -n "$include_expsyms"; then
- tmp_export_symbols="$export_symbols"
- test -n "$orig_export_symbols" && tmp_export_symbols="$orig_export_symbols"
+ tmp_export_symbols=$export_symbols
+ test -n "$orig_export_symbols" && tmp_export_symbols=$orig_export_symbols
$opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"'
fi
if test -n "$orig_export_symbols"; then
# The given exports_symbols file has to be filtered, so filter it.
- func_verbose "filter symbol list for \`$libname.la' to tag DATA exports"
+ func_verbose "filter symbol list for '$libname.la' to tag DATA exports"
# FIXME: $output_objdir/$libname.filter potentially contains lots of
- # 's' commands which not all seds can handle. GNU sed should be fine
+ # 's' commands, which not all seds can handle. GNU sed should be fine
# though. Also, the filter scales superlinearly with the number of
# global variables. join(1) would be nice here, but unfortunately
# isn't a blessed tool.
@@ -8486,7 +9986,7 @@ EOF
export_symbols=$output_objdir/$libname.def
$opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols
fi
- fi
+ }
libobjs=$output
# Restore the value of output.
@@ -8500,7 +10000,7 @@ EOF
# value of $libobjs for piecewise linking.
# Do each of the archive commands.
- if test "$module" = yes && test -n "$module_cmds" ; then
+ if test yes = "$module" && test -n "$module_cmds"; then
if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then
cmds=$module_expsym_cmds
else
@@ -8522,7 +10022,7 @@ EOF
# Add any objects from preloaded convenience libraries
if test -n "$dlprefiles"; then
- gentop="$output_objdir/${outputname}x"
+ gentop=$output_objdir/${outputname}x
func_append generated " $gentop"
func_extract_archives $gentop $dlprefiles
@@ -8530,11 +10030,12 @@ EOF
test "X$libobjs" = "X " && libobjs=
fi
- save_ifs="$IFS"; IFS='~'
+ save_ifs=$IFS; IFS='~'
for cmd in $cmds; do
- IFS="$save_ifs"
+ IFS=$sp$nl
eval cmd=\"$cmd\"
- $opt_silent || {
+ IFS=$save_ifs
+ $opt_quiet || {
func_quote_for_expand "$cmd"
eval "func_echo $func_quote_for_expand_result"
}
@@ -8542,7 +10043,7 @@ EOF
lt_exit=$?
# Restore the uninstalled library and exit
- if test "$opt_mode" = relink; then
+ if test relink = "$opt_mode"; then
( cd "$output_objdir" && \
$RM "${realname}T" && \
$MV "${realname}U" "$realname" )
@@ -8551,10 +10052,10 @@ EOF
exit $lt_exit
}
done
- IFS="$save_ifs"
+ IFS=$save_ifs
# Restore the uninstalled library and exit
- if test "$opt_mode" = relink; then
+ if test relink = "$opt_mode"; then
$opt_dry_run || eval '(cd $output_objdir && $RM ${realname}T && $MV $realname ${realname}T && $MV ${realname}U $realname)' || exit $?
if test -n "$convenience"; then
@@ -8574,39 +10075,39 @@ EOF
done
# If -module or -export-dynamic was specified, set the dlname.
- if test "$module" = yes || test "$export_dynamic" = yes; then
+ if test yes = "$module" || test yes = "$export_dynamic"; then
# On all known operating systems, these are identical.
- dlname="$soname"
+ dlname=$soname
fi
fi
;;
obj)
- if test -n "$dlfiles$dlprefiles" || test "$dlself" != no; then
- func_warning "\`-dlopen' is ignored for objects"
+ if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then
+ func_warning "'-dlopen' is ignored for objects"
fi
case " $deplibs" in
*\ -l* | *\ -L*)
- func_warning "\`-l' and \`-L' are ignored for objects" ;;
+ func_warning "'-l' and '-L' are ignored for objects" ;;
esac
test -n "$rpath" && \
- func_warning "\`-rpath' is ignored for objects"
+ func_warning "'-rpath' is ignored for objects"
test -n "$xrpath" && \
- func_warning "\`-R' is ignored for objects"
+ func_warning "'-R' is ignored for objects"
test -n "$vinfo" && \
- func_warning "\`-version-info' is ignored for objects"
+ func_warning "'-version-info' is ignored for objects"
test -n "$release" && \
- func_warning "\`-release' is ignored for objects"
+ func_warning "'-release' is ignored for objects"
case $output in
*.lo)
test -n "$objs$old_deplibs" && \
- func_fatal_error "cannot build library object \`$output' from non-libtool objects"
+ func_fatal_error "cannot build library object '$output' from non-libtool objects"
libobj=$output
func_lo2o "$libobj"
@@ -8614,7 +10115,7 @@ EOF
;;
*)
libobj=
- obj="$output"
+ obj=$output
;;
esac
@@ -8627,17 +10128,19 @@ EOF
# the extraction.
reload_conv_objs=
gentop=
- # reload_cmds runs $LD directly, so let us get rid of
- # -Wl from whole_archive_flag_spec and hope we can get by with
- # turning comma into space..
- wl=
-
+ # if reload_cmds runs $LD directly, get rid of -Wl from
+ # whole_archive_flag_spec and hope we can get by with turning comma
+ # into space.
+ case $reload_cmds in
+ *\$LD[\ \$]*) wl= ;;
+ esac
if test -n "$convenience"; then
if test -n "$whole_archive_flag_spec"; then
eval tmp_whole_archive_flags=\"$whole_archive_flag_spec\"
- reload_conv_objs=$reload_objs\ `$ECHO "$tmp_whole_archive_flags" | $SED 's|,| |g'`
+ test -n "$wl" || tmp_whole_archive_flags=`$ECHO "$tmp_whole_archive_flags" | $SED 's|,| |g'`
+ reload_conv_objs=$reload_objs\ $tmp_whole_archive_flags
else
- gentop="$output_objdir/${obj}x"
+ gentop=$output_objdir/${obj}x
func_append generated " $gentop"
func_extract_archives $gentop $convenience
@@ -8646,12 +10149,12 @@ EOF
fi
# If we're not building shared, we need to use non_pic_objs
- test "$build_libtool_libs" != yes && libobjs="$non_pic_objects"
+ test yes = "$build_libtool_libs" || libobjs=$non_pic_objects
# Create the old-style object.
- reload_objs="$objs$old_deplibs "`$ECHO "$libobjs" | $SP2NL | $SED "/\.${libext}$/d; /\.lib$/d; $lo2o" | $NL2SP`" $reload_conv_objs" ### testsuite: skip nested quoting test
+ reload_objs=$objs$old_deplibs' '`$ECHO "$libobjs" | $SP2NL | $SED "/\.$libext$/d; /\.lib$/d; $lo2o" | $NL2SP`' '$reload_conv_objs
- output="$obj"
+ output=$obj
func_execute_cmds "$reload_cmds" 'exit $?'
# Exit if we aren't doing a library object file.
@@ -8663,7 +10166,7 @@ EOF
exit $EXIT_SUCCESS
fi
- if test "$build_libtool_libs" != yes; then
+ test yes = "$build_libtool_libs" || {
if test -n "$gentop"; then
func_show_eval '${RM}r "$gentop"'
fi
@@ -8673,12 +10176,12 @@ EOF
# $show "echo timestamp > $libobj"
# $opt_dry_run || eval "echo timestamp > $libobj" || exit $?
exit $EXIT_SUCCESS
- fi
+ }
- if test -n "$pic_flag" || test "$pic_mode" != default; then
+ if test -n "$pic_flag" || test default != "$pic_mode"; then
# Only do commands if we really have different PIC objects.
reload_objs="$libobjs $reload_conv_objs"
- output="$libobj"
+ output=$libobj
func_execute_cmds "$reload_cmds" 'exit $?'
fi
@@ -8695,16 +10198,14 @@ EOF
output=$func_stripname_result.exe;;
esac
test -n "$vinfo" && \
- func_warning "\`-version-info' is ignored for programs"
+ func_warning "'-version-info' is ignored for programs"
test -n "$release" && \
- func_warning "\`-release' is ignored for programs"
+ func_warning "'-release' is ignored for programs"
- test "$preload" = yes \
- && test "$dlopen_support" = unknown \
- && test "$dlopen_self" = unknown \
- && test "$dlopen_self_static" = unknown && \
- func_warning "\`LT_INIT([dlopen])' not used. Assuming no dlopen support."
+ $preload \
+ && test unknown,unknown,unknown = "$dlopen_support,$dlopen_self,$dlopen_self_static" \
+ && func_warning "'LT_INIT([dlopen])' not used. Assuming no dlopen support."
case $host in
*-*-rhapsody* | *-*-darwin1.[012])
@@ -8718,11 +10219,11 @@ EOF
*-*-darwin*)
# Don't allow lazy linking, it breaks C++ global constructors
# But is supposedly fixed on 10.4 or later (yay!).
- if test "$tagname" = CXX ; then
+ if test CXX = "$tagname"; then
case ${MACOSX_DEPLOYMENT_TARGET-10.0} in
10.[0123])
- func_append compile_command " ${wl}-bind_at_load"
- func_append finalize_command " ${wl}-bind_at_load"
+ func_append compile_command " $wl-bind_at_load"
+ func_append finalize_command " $wl-bind_at_load"
;;
esac
fi
@@ -8758,7 +10259,7 @@ EOF
*) func_append new_libs " $deplib" ;;
esac
done
- compile_deplibs="$new_libs"
+ compile_deplibs=$new_libs
func_append compile_command " $compile_deplibs"
@@ -8782,7 +10283,7 @@ EOF
if test -n "$hardcode_libdir_flag_spec"; then
if test -n "$hardcode_libdir_separator"; then
if test -z "$hardcode_libdirs"; then
- hardcode_libdirs="$libdir"
+ hardcode_libdirs=$libdir
else
# Just accumulate the unique libdirs.
case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
@@ -8805,7 +10306,7 @@ EOF
fi
case $host in
*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*)
- testbindir=`${ECHO} "$libdir" | ${SED} -e 's*/lib$*/bin*'`
+ testbindir=`$ECHO "$libdir" | $SED -e 's*/lib$*/bin*'`
case :$dllsearchpath: in
*":$libdir:"*) ;;
::) dllsearchpath=$libdir;;
@@ -8822,10 +10323,10 @@ EOF
# Substitute the hardcoded libdirs into the rpath.
if test -n "$hardcode_libdir_separator" &&
test -n "$hardcode_libdirs"; then
- libdir="$hardcode_libdirs"
+ libdir=$hardcode_libdirs
eval rpath=\" $hardcode_libdir_flag_spec\"
fi
- compile_rpath="$rpath"
+ compile_rpath=$rpath
rpath=
hardcode_libdirs=
@@ -8833,7 +10334,7 @@ EOF
if test -n "$hardcode_libdir_flag_spec"; then
if test -n "$hardcode_libdir_separator"; then
if test -z "$hardcode_libdirs"; then
- hardcode_libdirs="$libdir"
+ hardcode_libdirs=$libdir
else
# Just accumulate the unique libdirs.
case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in
@@ -8858,45 +10359,43 @@ EOF
# Substitute the hardcoded libdirs into the rpath.
if test -n "$hardcode_libdir_separator" &&
test -n "$hardcode_libdirs"; then
- libdir="$hardcode_libdirs"
+ libdir=$hardcode_libdirs
eval rpath=\" $hardcode_libdir_flag_spec\"
fi
- finalize_rpath="$rpath"
+ finalize_rpath=$rpath
- if test -n "$libobjs" && test "$build_old_libs" = yes; then
+ if test -n "$libobjs" && test yes = "$build_old_libs"; then
# Transform all the library objects into standard objects.
compile_command=`$ECHO "$compile_command" | $SP2NL | $SED "$lo2o" | $NL2SP`
finalize_command=`$ECHO "$finalize_command" | $SP2NL | $SED "$lo2o" | $NL2SP`
fi
- func_generate_dlsyms "$outputname" "@PROGRAM@" "no"
+ func_generate_dlsyms "$outputname" "@PROGRAM@" false
# template prelinking step
if test -n "$prelink_cmds"; then
func_execute_cmds "$prelink_cmds" 'exit $?'
fi
- wrappers_required=yes
+ wrappers_required=:
case $host in
*cegcc* | *mingw32ce*)
# Disable wrappers for cegcc and mingw32ce hosts, we are cross compiling anyway.
- wrappers_required=no
+ wrappers_required=false
;;
*cygwin* | *mingw* )
- if test "$build_libtool_libs" != yes; then
- wrappers_required=no
- fi
+ test yes = "$build_libtool_libs" || wrappers_required=false
;;
*)
- if test "$need_relink" = no || test "$build_libtool_libs" != yes; then
- wrappers_required=no
+ if test no = "$need_relink" || test yes != "$build_libtool_libs"; then
+ wrappers_required=false
fi
;;
esac
- if test "$wrappers_required" = no; then
+ $wrappers_required || {
# Replace the output file specification.
compile_command=`$ECHO "$compile_command" | $SED 's%@OUTPUT@%'"$output"'%g'`
- link_command="$compile_command$compile_rpath"
+ link_command=$compile_command$compile_rpath
# We have no uninstalled library dependencies, so finalize right now.
exit_status=0
@@ -8909,12 +10408,12 @@ EOF
fi
# Delete the generated files.
- if test -f "$output_objdir/${outputname}S.${objext}"; then
- func_show_eval '$RM "$output_objdir/${outputname}S.${objext}"'
+ if test -f "$output_objdir/${outputname}S.$objext"; then
+ func_show_eval '$RM "$output_objdir/${outputname}S.$objext"'
fi
exit $exit_status
- fi
+ }
if test -n "$compile_shlibpath$finalize_shlibpath"; then
compile_command="$shlibpath_var=\"$compile_shlibpath$finalize_shlibpath\$$shlibpath_var\" $compile_command"
@@ -8944,9 +10443,9 @@ EOF
fi
fi
- if test "$no_install" = yes; then
+ if test yes = "$no_install"; then
# We don't need to create a wrapper script.
- link_command="$compile_var$compile_command$compile_rpath"
+ link_command=$compile_var$compile_command$compile_rpath
# Replace the output file specification.
link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output"'%g'`
# Delete the old output file.
@@ -8963,27 +10462,28 @@ EOF
exit $EXIT_SUCCESS
fi
- if test "$hardcode_action" = relink; then
- # Fast installation is not supported
- link_command="$compile_var$compile_command$compile_rpath"
- relink_command="$finalize_var$finalize_command$finalize_rpath"
+ case $hardcode_action,$fast_install in
+ relink,*)
+ # Fast installation is not supported
+ link_command=$compile_var$compile_command$compile_rpath
+ relink_command=$finalize_var$finalize_command$finalize_rpath
- func_warning "this platform does not like uninstalled shared libraries"
- func_warning "\`$output' will be relinked during installation"
- else
- if test "$fast_install" != no; then
- link_command="$finalize_var$compile_command$finalize_rpath"
- if test "$fast_install" = yes; then
- relink_command=`$ECHO "$compile_var$compile_command$compile_rpath" | $SED 's%@OUTPUT@%\$progdir/\$file%g'`
- else
- # fast_install is set to needless
- relink_command=
- fi
- else
- link_command="$compile_var$compile_command$compile_rpath"
- relink_command="$finalize_var$finalize_command$finalize_rpath"
- fi
- fi
+ func_warning "this platform does not like uninstalled shared libraries"
+ func_warning "'$output' will be relinked during installation"
+ ;;
+ *,yes)
+ link_command=$finalize_var$compile_command$finalize_rpath
+ relink_command=`$ECHO "$compile_var$compile_command$compile_rpath" | $SED 's%@OUTPUT@%\$progdir/\$file%g'`
+ ;;
+ *,no)
+ link_command=$compile_var$compile_command$compile_rpath
+ relink_command=$finalize_var$finalize_command$finalize_rpath
+ ;;
+ *,needless)
+ link_command=$finalize_var$compile_command$finalize_rpath
+ relink_command=
+ ;;
+ esac
# Replace the output file specification.
link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'`
@@ -9040,8 +10540,8 @@ EOF
func_dirname_and_basename "$output" "" "."
output_name=$func_basename_result
output_path=$func_dirname_result
- cwrappersource="$output_path/$objdir/lt-$output_name.c"
- cwrapper="$output_path/$output_name.exe"
+ cwrappersource=$output_path/$objdir/lt-$output_name.c
+ cwrapper=$output_path/$output_name.exe
$RM $cwrappersource $cwrapper
trap "$RM $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15
@@ -9062,7 +10562,7 @@ EOF
trap "$RM $func_ltwrapper_scriptname_result; exit $EXIT_FAILURE" 1 2 15
$opt_dry_run || {
# note: this script will not be executed, so do not chmod.
- if test "x$build" = "x$host" ; then
+ if test "x$build" = "x$host"; then
$cwrapper --lt-dump-script > $func_ltwrapper_scriptname_result
else
func_emit_wrapper no > $func_ltwrapper_scriptname_result
@@ -9085,25 +10585,27 @@ EOF
# See if we need to build an old-fashioned archive.
for oldlib in $oldlibs; do
- if test "$build_libtool_libs" = convenience; then
- oldobjs="$libobjs_save $symfileobj"
- addlibs="$convenience"
- build_libtool_libs=no
- else
- if test "$build_libtool_libs" = module; then
- oldobjs="$libobjs_save"
+ case $build_libtool_libs in
+ convenience)
+ oldobjs="$libobjs_save $symfileobj"
+ addlibs=$convenience
build_libtool_libs=no
- else
+ ;;
+ module)
+ oldobjs=$libobjs_save
+ addlibs=$old_convenience
+ build_libtool_libs=no
+ ;;
+ *)
oldobjs="$old_deplibs $non_pic_objects"
- if test "$preload" = yes && test -f "$symfileobj"; then
- func_append oldobjs " $symfileobj"
- fi
- fi
- addlibs="$old_convenience"
- fi
+ $preload && test -f "$symfileobj" \
+ && func_append oldobjs " $symfileobj"
+ addlibs=$old_convenience
+ ;;
+ esac
if test -n "$addlibs"; then
- gentop="$output_objdir/${outputname}x"
+ gentop=$output_objdir/${outputname}x
func_append generated " $gentop"
func_extract_archives $gentop $addlibs
@@ -9111,13 +10613,13 @@ EOF
fi
# Do each command in the archive commands.
- if test -n "$old_archive_from_new_cmds" && test "$build_libtool_libs" = yes; then
+ if test -n "$old_archive_from_new_cmds" && test yes = "$build_libtool_libs"; then
cmds=$old_archive_from_new_cmds
else
# Add any objects from preloaded convenience libraries
if test -n "$dlprefiles"; then
- gentop="$output_objdir/${outputname}x"
+ gentop=$output_objdir/${outputname}x
func_append generated " $gentop"
func_extract_archives $gentop $dlprefiles
@@ -9138,7 +10640,7 @@ EOF
:
else
echo "copying selected object files to avoid basename conflicts..."
- gentop="$output_objdir/${outputname}x"
+ gentop=$output_objdir/${outputname}x
func_append generated " $gentop"
func_mkdir_p "$gentop"
save_oldobjs=$oldobjs
@@ -9147,7 +10649,7 @@ EOF
for obj in $save_oldobjs
do
func_basename "$obj"
- objbase="$func_basename_result"
+ objbase=$func_basename_result
case " $oldobjs " in
" ") oldobjs=$obj ;;
*[\ /]"$objbase "*)
@@ -9216,18 +10718,18 @@ EOF
else
# the above command should be used before it gets too long
oldobjs=$objlist
- if test "$obj" = "$last_oldobj" ; then
+ if test "$obj" = "$last_oldobj"; then
RANLIB=$save_RANLIB
fi
test -z "$concat_cmds" || concat_cmds=$concat_cmds~
- eval concat_cmds=\"\${concat_cmds}$old_archive_cmds\"
+ eval concat_cmds=\"\$concat_cmds$old_archive_cmds\"
objlist=
len=$len0
fi
done
RANLIB=$save_RANLIB
oldobjs=$objlist
- if test "X$oldobjs" = "X" ; then
+ if test -z "$oldobjs"; then
eval cmds=\"\$concat_cmds\"
else
eval cmds=\"\$concat_cmds~\$old_archive_cmds\"
@@ -9244,7 +10746,7 @@ EOF
case $output in
*.la)
old_library=
- test "$build_old_libs" = yes && old_library="$libname.$libext"
+ test yes = "$build_old_libs" && old_library=$libname.$libext
func_verbose "creating $output"
# Preserve any variables that may affect compiler behavior
@@ -9259,31 +10761,31 @@ EOF
fi
done
# Quote the link command for shipping.
- relink_command="(cd `pwd`; $SHELL $progpath $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)"
+ relink_command="(cd `pwd`; $SHELL \"$progpath\" $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)"
relink_command=`$ECHO "$relink_command" | $SED "$sed_quote_subst"`
- if test "$hardcode_automatic" = yes ; then
+ if test yes = "$hardcode_automatic"; then
relink_command=
fi
# Only create the output if not a dry run.
$opt_dry_run || {
for installed in no yes; do
- if test "$installed" = yes; then
+ if test yes = "$installed"; then
if test -z "$install_libdir"; then
break
fi
- output="$output_objdir/$outputname"i
+ output=$output_objdir/${outputname}i
# Replace all uninstalled libtool libraries with the installed ones
newdependency_libs=
for deplib in $dependency_libs; do
case $deplib in
*.la)
func_basename "$deplib"
- name="$func_basename_result"
+ name=$func_basename_result
func_resolve_sysroot "$deplib"
- eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $func_resolve_sysroot_result`
+ eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $func_resolve_sysroot_result`
test -z "$libdir" && \
- func_fatal_error "\`$deplib' is not a valid libtool archive"
+ func_fatal_error "'$deplib' is not a valid libtool archive"
func_append newdependency_libs " ${lt_sysroot:+=}$libdir/$name"
;;
-L*)
@@ -9299,23 +10801,23 @@ EOF
*) func_append newdependency_libs " $deplib" ;;
esac
done
- dependency_libs="$newdependency_libs"
+ dependency_libs=$newdependency_libs
newdlfiles=
for lib in $dlfiles; do
case $lib in
*.la)
func_basename "$lib"
- name="$func_basename_result"
- eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
+ name=$func_basename_result
+ eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
test -z "$libdir" && \
- func_fatal_error "\`$lib' is not a valid libtool archive"
+ func_fatal_error "'$lib' is not a valid libtool archive"
func_append newdlfiles " ${lt_sysroot:+=}$libdir/$name"
;;
*) func_append newdlfiles " $lib" ;;
esac
done
- dlfiles="$newdlfiles"
+ dlfiles=$newdlfiles
newdlprefiles=
for lib in $dlprefiles; do
case $lib in
@@ -9325,34 +10827,34 @@ EOF
# didn't already link the preopened objects directly into
# the library:
func_basename "$lib"
- name="$func_basename_result"
- eval libdir=`${SED} -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
+ name=$func_basename_result
+ eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $lib`
test -z "$libdir" && \
- func_fatal_error "\`$lib' is not a valid libtool archive"
+ func_fatal_error "'$lib' is not a valid libtool archive"
func_append newdlprefiles " ${lt_sysroot:+=}$libdir/$name"
;;
esac
done
- dlprefiles="$newdlprefiles"
+ dlprefiles=$newdlprefiles
else
newdlfiles=
for lib in $dlfiles; do
case $lib in
- [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;;
+ [\\/]* | [A-Za-z]:[\\/]*) abs=$lib ;;
*) abs=`pwd`"/$lib" ;;
esac
func_append newdlfiles " $abs"
done
- dlfiles="$newdlfiles"
+ dlfiles=$newdlfiles
newdlprefiles=
for lib in $dlprefiles; do
case $lib in
- [\\/]* | [A-Za-z]:[\\/]*) abs="$lib" ;;
+ [\\/]* | [A-Za-z]:[\\/]*) abs=$lib ;;
*) abs=`pwd`"/$lib" ;;
esac
func_append newdlprefiles " $abs"
done
- dlprefiles="$newdlprefiles"
+ dlprefiles=$newdlprefiles
fi
$RM $output
# place dlname in correct position for cygwin
@@ -9368,10 +10870,9 @@ EOF
case $host,$output,$installed,$module,$dlname in
*cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll | *cegcc*,*lai,yes,no,*.dll)
# If a -bindir argument was supplied, place the dll there.
- if test "x$bindir" != x ;
- then
+ if test -n "$bindir"; then
func_relative_path "$install_libdir" "$bindir"
- tdlname=$func_relative_path_result$dlname
+ tdlname=$func_relative_path_result/$dlname
else
# Otherwise fall back on heuristic.
tdlname=../bin/$dlname
@@ -9380,7 +10881,7 @@ EOF
esac
$ECHO > $output "\
# $outputname - a libtool library file
-# Generated by $PROGRAM (GNU $PACKAGE$TIMESTAMP) $VERSION
+# Generated by $PROGRAM (GNU $PACKAGE) $VERSION
#
# Please DO NOT delete this file!
# It is necessary for linking the library.
@@ -9394,7 +10895,7 @@ library_names='$library_names'
# The name of the static archive.
old_library='$old_library'
-# Linker flags that can not go in dependency_libs.
+# Linker flags that cannot go in dependency_libs.
inherited_linker_flags='$new_inherited_linker_flags'
# Libraries that this one depends upon.
@@ -9420,7 +10921,7 @@ dlpreopen='$dlprefiles'
# Directory that this library needs to be installed in:
libdir='$install_libdir'"
- if test "$installed" = no && test "$need_relink" = yes; then
+ if test no,yes = "$installed,$need_relink"; then
$ECHO >> $output "\
relink_command=\"$relink_command\""
fi
@@ -9435,27 +10936,29 @@ relink_command=\"$relink_command\""
exit $EXIT_SUCCESS
}
-{ test "$opt_mode" = link || test "$opt_mode" = relink; } &&
- func_mode_link ${1+"$@"}
+if test link = "$opt_mode" || test relink = "$opt_mode"; then
+ func_mode_link ${1+"$@"}
+fi
# func_mode_uninstall arg...
func_mode_uninstall ()
{
- $opt_debug
- RM="$nonopt"
+ $debug_cmd
+
+ RM=$nonopt
files=
- rmforce=
+ rmforce=false
exit_status=0
# This variable tells wrapper scripts just to set variables rather
# than running their programs.
- libtool_install_magic="$magic"
+ libtool_install_magic=$magic
for arg
do
case $arg in
- -f) func_append RM " $arg"; rmforce=yes ;;
+ -f) func_append RM " $arg"; rmforce=: ;;
-*) func_append RM " $arg" ;;
*) func_append files " $arg" ;;
esac
@@ -9468,18 +10971,18 @@ func_mode_uninstall ()
for file in $files; do
func_dirname "$file" "" "."
- dir="$func_dirname_result"
- if test "X$dir" = X.; then
- odir="$objdir"
+ dir=$func_dirname_result
+ if test . = "$dir"; then
+ odir=$objdir
else
- odir="$dir/$objdir"
+ odir=$dir/$objdir
fi
func_basename "$file"
- name="$func_basename_result"
- test "$opt_mode" = uninstall && odir="$dir"
+ name=$func_basename_result
+ test uninstall = "$opt_mode" && odir=$dir
# Remember odir for removal later, being careful to avoid duplicates
- if test "$opt_mode" = clean; then
+ if test clean = "$opt_mode"; then
case " $rmdirs " in
*" $odir "*) ;;
*) func_append rmdirs " $odir" ;;
@@ -9494,11 +10997,11 @@ func_mode_uninstall ()
elif test -d "$file"; then
exit_status=1
continue
- elif test "$rmforce" = yes; then
+ elif $rmforce; then
continue
fi
- rmfiles="$file"
+ rmfiles=$file
case $name in
*.la)
@@ -9512,7 +11015,7 @@ func_mode_uninstall ()
done
test -n "$old_library" && func_append rmfiles " $odir/$old_library"
- case "$opt_mode" in
+ case $opt_mode in
clean)
case " $library_names " in
*" $dlname "*) ;;
@@ -9523,12 +11026,12 @@ func_mode_uninstall ()
uninstall)
if test -n "$library_names"; then
# Do each command in the postuninstall commands.
- func_execute_cmds "$postuninstall_cmds" 'test "$rmforce" = yes || exit_status=1'
+ func_execute_cmds "$postuninstall_cmds" '$rmforce || exit_status=1'
fi
if test -n "$old_library"; then
# Do each command in the old_postuninstall commands.
- func_execute_cmds "$old_postuninstall_cmds" 'test "$rmforce" = yes || exit_status=1'
+ func_execute_cmds "$old_postuninstall_cmds" '$rmforce || exit_status=1'
fi
# FIXME: should reinstall the best remaining shared library.
;;
@@ -9544,21 +11047,19 @@ func_mode_uninstall ()
func_source $dir/$name
# Add PIC object to the list of files to remove.
- if test -n "$pic_object" &&
- test "$pic_object" != none; then
+ if test -n "$pic_object" && test none != "$pic_object"; then
func_append rmfiles " $dir/$pic_object"
fi
# Add non-PIC object to the list of files to remove.
- if test -n "$non_pic_object" &&
- test "$non_pic_object" != none; then
+ if test -n "$non_pic_object" && test none != "$non_pic_object"; then
func_append rmfiles " $dir/$non_pic_object"
fi
fi
;;
*)
- if test "$opt_mode" = clean ; then
+ if test clean = "$opt_mode"; then
noexename=$name
case $file in
*.exe)
@@ -9585,12 +11086,12 @@ func_mode_uninstall ()
# note $name still contains .exe if it was in $file originally
# as does the version of $file that was added into $rmfiles
- func_append rmfiles " $odir/$name $odir/${name}S.${objext}"
- if test "$fast_install" = yes && test -n "$relink_command"; then
+ func_append rmfiles " $odir/$name $odir/${name}S.$objext"
+ if test yes = "$fast_install" && test -n "$relink_command"; then
func_append rmfiles " $odir/lt-$name"
fi
- if test "X$noexename" != "X$name" ; then
- func_append rmfiles " $odir/lt-${noexename}.c"
+ if test "X$noexename" != "X$name"; then
+ func_append rmfiles " $odir/lt-$noexename.c"
fi
fi
fi
@@ -9599,7 +11100,7 @@ func_mode_uninstall ()
func_show_eval "$RM $rmfiles" 'exit_status=1'
done
- # Try to remove the ${objdir}s in the directories where we deleted files
+ # Try to remove the $objdir's in the directories where we deleted files
for dir in $rmdirs; do
if test -d "$dir"; then
func_show_eval "rmdir $dir >/dev/null 2>&1"
@@ -9609,16 +11110,17 @@ func_mode_uninstall ()
exit $exit_status
}
-{ test "$opt_mode" = uninstall || test "$opt_mode" = clean; } &&
- func_mode_uninstall ${1+"$@"}
+if test uninstall = "$opt_mode" || test clean = "$opt_mode"; then
+ func_mode_uninstall ${1+"$@"}
+fi
test -z "$opt_mode" && {
- help="$generic_help"
+ help=$generic_help
func_fatal_help "you must specify a MODE"
}
test -z "$exec_cmd" && \
- func_fatal_help "invalid operation mode \`$opt_mode'"
+ func_fatal_help "invalid operation mode '$opt_mode'"
if test -n "$exec_cmd"; then
eval exec "$exec_cmd"
@@ -9629,7 +11131,7 @@ exit $exit_status
# The TAGs below are defined such that we never get into a situation
-# in which we disable both kinds of libraries. Given conflicting
+# where we disable both kinds of libraries. Given conflicting
# choices, we go for a static library, that is the most portable,
# since we can't tell whether shared libraries were disabled because
# the user asked for that or because the platform doesn't support
@@ -9652,5 +11154,3 @@ build_old_libs=`case $build_libtool_libs in yes) echo no;; *) echo yes;; esac`
# mode:shell-script
# sh-indentation:2
# End:
-# vi:sw=2
-
diff --git a/lcms2mt/m4/libtool.m4 b/lcms2mt/m4/libtool.m4
index ae1a3df9..ee80844b 100644
--- a/lcms2mt/m4/libtool.m4
+++ b/lcms2mt/m4/libtool.m4
@@ -1,8 +1,6 @@
# libtool.m4 - Configure libtool for the host system. -*-Autoconf-*-
#
-# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005,
-# 2006, 2007, 2008, 2009, 2010, 2011 Free Software
-# Foundation, Inc.
+# Copyright (C) 1996-2001, 2003-2015 Free Software Foundation, Inc.
# Written by Gordon Matzigkeit, 1996
#
# This file is free software; the Free Software Foundation gives
@@ -10,36 +8,30 @@
# modifications, as long as this notice is preserved.
m4_define([_LT_COPYING], [dnl
-# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005,
-# 2006, 2007, 2008, 2009, 2010, 2011 Free Software
-# Foundation, Inc.
-# Written by Gordon Matzigkeit, 1996
-#
-# This file is part of GNU Libtool.
-#
-# GNU Libtool is free software; you can redistribute it and/or
-# modify it under the terms of the GNU General Public License as
-# published by the Free Software Foundation; either version 2 of
-# the License, or (at your option) any later version.
+# Copyright (C) 2014 Free Software Foundation, Inc.
+# This is free software; see the source for copying conditions. There is NO
+# warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+
+# GNU Libtool is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of of the License, or
+# (at your option) any later version.
#
-# As a special exception to the GNU General Public License,
-# if you distribute this file as part of a program or library that
-# is built using GNU Libtool, you may include this file under the
-# same distribution terms that you use for the rest of that program.
+# As a special exception to the GNU General Public License, if you
+# distribute this file as part of a program or library that is built
+# using GNU Libtool, you may include this file under the same
+# distribution terms that you use for the rest of that program.
#
-# GNU Libtool is distributed in the hope that it will be useful,
-# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# GNU Libtool is distributed in the hope that it will be useful, but
+# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
-# along with GNU Libtool; see the file COPYING. If not, a copy
-# can be downloaded from http://www.gnu.org/licenses/gpl.html, or
-# obtained by writing to the Free Software Foundation, Inc.,
-# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+# along with this program. If not, see <http://www.gnu.org/licenses/>.
])
-# serial 57 LT_INIT
+# serial 58 LT_INIT
# LT_PREREQ(VERSION)
@@ -67,7 +59,7 @@ esac
# LT_INIT([OPTIONS])
# ------------------
AC_DEFUN([LT_INIT],
-[AC_PREREQ([2.58])dnl We use AC_INCLUDES_DEFAULT
+[AC_PREREQ([2.62])dnl We use AC_PATH_PROGS_FEATURE_CHECK
AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT])dnl
AC_BEFORE([$0], [LT_LANG])dnl
AC_BEFORE([$0], [LT_OUTPUT])dnl
@@ -91,7 +83,7 @@ dnl Parse OPTIONS
_LT_SET_OPTIONS([$0], [$1])
# This can be used to rebuild libtool when needed
-LIBTOOL_DEPS="$ltmain"
+LIBTOOL_DEPS=$ltmain
# Always use our own libtool.
LIBTOOL='$(SHELL) $(top_builddir)/libtool'
@@ -111,26 +103,43 @@ dnl AC_DEFUN([AC_PROG_LIBTOOL], [])
dnl AC_DEFUN([AM_PROG_LIBTOOL], [])
+# _LT_PREPARE_CC_BASENAME
+# -----------------------
+m4_defun([_LT_PREPARE_CC_BASENAME], [
+# Calculate cc_basename. Skip known compiler wrappers and cross-prefix.
+func_cc_basename ()
+{
+ for cc_temp in @S|@*""; do
+ case $cc_temp in
+ compile | *[[\\/]]compile | ccache | *[[\\/]]ccache ) ;;
+ distcc | *[[\\/]]distcc | purify | *[[\\/]]purify ) ;;
+ \-*) ;;
+ *) break;;
+ esac
+ done
+ func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"`
+}
+])# _LT_PREPARE_CC_BASENAME
+
+
# _LT_CC_BASENAME(CC)
# -------------------
-# Calculate cc_basename. Skip known compiler wrappers and cross-prefix.
+# It would be clearer to call AC_REQUIREs from _LT_PREPARE_CC_BASENAME,
+# but that macro is also expanded into generated libtool script, which
+# arranges for $SED and $ECHO to be set by different means.
m4_defun([_LT_CC_BASENAME],
-[for cc_temp in $1""; do
- case $cc_temp in
- compile | *[[\\/]]compile | ccache | *[[\\/]]ccache ) ;;
- distcc | *[[\\/]]distcc | purify | *[[\\/]]purify ) ;;
- \-*) ;;
- *) break;;
- esac
-done
-cc_basename=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"`
+[m4_require([_LT_PREPARE_CC_BASENAME])dnl
+AC_REQUIRE([_LT_DECL_SED])dnl
+AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH])dnl
+func_cc_basename $1
+cc_basename=$func_cc_basename_result
])
# _LT_FILEUTILS_DEFAULTS
# ----------------------
# It is okay to use these file commands and assume they have been set
-# sensibly after `m4_require([_LT_FILEUTILS_DEFAULTS])'.
+# sensibly after 'm4_require([_LT_FILEUTILS_DEFAULTS])'.
m4_defun([_LT_FILEUTILS_DEFAULTS],
[: ${CP="cp -f"}
: ${MV="mv -f"}
@@ -177,15 +186,16 @@ m4_require([_LT_CHECK_SHAREDLIB_FROM_LINKLIB])dnl
m4_require([_LT_CMD_OLD_ARCHIVE])dnl
m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl
m4_require([_LT_WITH_SYSROOT])dnl
+m4_require([_LT_CMD_TRUNCATE])dnl
_LT_CONFIG_LIBTOOL_INIT([
-# See if we are running on zsh, and set the options which allow our
+# See if we are running on zsh, and set the options that allow our
# commands through without removal of \ escapes INIT.
-if test -n "\${ZSH_VERSION+set}" ; then
+if test -n "\${ZSH_VERSION+set}"; then
setopt NO_GLOB_SUBST
fi
])
-if test -n "${ZSH_VERSION+set}" ; then
+if test -n "${ZSH_VERSION+set}"; then
setopt NO_GLOB_SUBST
fi
@@ -198,7 +208,7 @@ aix3*)
# AIX sometimes has problems with the GCC collect2 program. For some
# reason, if we set the COLLECT_NAMES environment variable, the problems
# vanish in a puff of smoke.
- if test "X${COLLECT_NAMES+set}" != Xset; then
+ if test set != "${COLLECT_NAMES+set}"; then
COLLECT_NAMES=
export COLLECT_NAMES
fi
@@ -209,14 +219,14 @@ esac
ofile=libtool
can_build_shared=yes
-# All known linkers require a `.a' archive for static linking (except MSVC,
+# All known linkers require a '.a' archive for static linking (except MSVC,
# which needs '.lib').
libext=a
-with_gnu_ld="$lt_cv_prog_gnu_ld"
+with_gnu_ld=$lt_cv_prog_gnu_ld
-old_CC="$CC"
-old_CFLAGS="$CFLAGS"
+old_CC=$CC
+old_CFLAGS=$CFLAGS
# Set sane defaults for various variables
test -z "$CC" && CC=cc
@@ -269,14 +279,14 @@ no_glob_subst='s/\*/\\\*/g'
# _LT_PROG_LTMAIN
# ---------------
-# Note that this code is called both from `configure', and `config.status'
+# Note that this code is called both from 'configure', and 'config.status'
# now that we use AC_CONFIG_COMMANDS to generate libtool. Notably,
-# `config.status' has no value for ac_aux_dir unless we are using Automake,
+# 'config.status' has no value for ac_aux_dir unless we are using Automake,
# so we pass a copy along to make sure it has a sensible value anyway.
m4_defun([_LT_PROG_LTMAIN],
[m4_ifdef([AC_REQUIRE_AUX_FILE], [AC_REQUIRE_AUX_FILE([ltmain.sh])])dnl
_LT_CONFIG_LIBTOOL_INIT([ac_aux_dir='$ac_aux_dir'])
-ltmain="$ac_aux_dir/ltmain.sh"
+ltmain=$ac_aux_dir/ltmain.sh
])# _LT_PROG_LTMAIN
@@ -286,7 +296,7 @@ ltmain="$ac_aux_dir/ltmain.sh"
# So that we can recreate a full libtool script including additional
# tags, we accumulate the chunks of code to send to AC_CONFIG_COMMANDS
-# in macros and then make a single call at the end using the `libtool'
+# in macros and then make a single call at the end using the 'libtool'
# label.
@@ -421,8 +431,8 @@ m4_define([_lt_decl_all_varnames],
# _LT_CONFIG_STATUS_DECLARE([VARNAME])
# ------------------------------------
-# Quote a variable value, and forward it to `config.status' so that its
-# declaration there will have the same value as in `configure'. VARNAME
+# Quote a variable value, and forward it to 'config.status' so that its
+# declaration there will have the same value as in 'configure'. VARNAME
# must have a single quote delimited value for this to work.
m4_define([_LT_CONFIG_STATUS_DECLARE],
[$1='`$ECHO "$][$1" | $SED "$delay_single_quote_subst"`'])
@@ -446,7 +456,7 @@ m4_defun([_LT_CONFIG_STATUS_DECLARATIONS],
# Output comment and list of tags supported by the script
m4_defun([_LT_LIBTOOL_TAGS],
[_LT_FORMAT_COMMENT([The names of the tagged configurations supported by this script])dnl
-available_tags="_LT_TAGS"dnl
+available_tags='_LT_TAGS'dnl
])
@@ -474,7 +484,7 @@ m4_ifval([$2], [_$2])[]m4_popdef([_libtool_name])[]dnl
# _LT_LIBTOOL_CONFIG_VARS
# -----------------------
# Produce commented declarations of non-tagged libtool config variables
-# suitable for insertion in the LIBTOOL CONFIG section of the `libtool'
+# suitable for insertion in the LIBTOOL CONFIG section of the 'libtool'
# script. Tagged libtool config variables (even for the LIBTOOL CONFIG
# section) are produced by _LT_LIBTOOL_TAG_VARS.
m4_defun([_LT_LIBTOOL_CONFIG_VARS],
@@ -500,8 +510,8 @@ m4_define([_LT_TAGVAR], [m4_ifval([$2], [$1_$2], [$1])])
# Send accumulated output to $CONFIG_STATUS. Thanks to the lists of
# variables for single and double quote escaping we saved from calls
# to _LT_DECL, we can put quote escaped variables declarations
-# into `config.status', and then the shell code to quote escape them in
-# for loops in `config.status'. Finally, any additional code accumulated
+# into 'config.status', and then the shell code to quote escape them in
+# for loops in 'config.status'. Finally, any additional code accumulated
# from calls to _LT_CONFIG_LIBTOOL_INIT is expanded.
m4_defun([_LT_CONFIG_COMMANDS],
[AC_PROVIDE_IFELSE([LT_OUTPUT],
@@ -547,7 +557,7 @@ for var in lt_decl_all_varnames([[ \
]], lt_decl_quote_varnames); do
case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in
*[[\\\\\\\`\\"\\\$]]*)
- eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\""
+ eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes
;;
*)
eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\""
@@ -560,7 +570,7 @@ for var in lt_decl_all_varnames([[ \
]], lt_decl_dquote_varnames); do
case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in
*[[\\\\\\\`\\"\\\$]]*)
- eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\""
+ eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes
;;
*)
eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\""
@@ -576,7 +586,7 @@ _LT_OUTPUT_LIBTOOL_INIT
# Generate a child script FILE with all initialization necessary to
# reuse the environment learned by the parent script, and make the
# file executable. If COMMENT is supplied, it is inserted after the
-# `#!' sequence but before initialization text begins. After this
+# '#!' sequence but before initialization text begins. After this
# macro, additional text can be appended to FILE to form the body of
# the child script. The macro ends with non-zero status if the
# file could not be fully written (such as if the disk is full).
@@ -598,7 +608,7 @@ AS_SHELL_SANITIZE
_AS_PREPARE
exec AS_MESSAGE_FD>&1
_ASEOF
-test $lt_write_fail = 0 && chmod +x $1[]dnl
+test 0 = "$lt_write_fail" && chmod +x $1[]dnl
m4_popdef([AS_MESSAGE_LOG_FD])])])# _LT_GENERATED_FILE_INIT
# LT_OUTPUT
@@ -621,7 +631,7 @@ exec AS_MESSAGE_LOG_FD>>config.log
} >&AS_MESSAGE_LOG_FD
lt_cl_help="\
-\`$as_me' creates a local libtool stub from the current configuration,
+'$as_me' creates a local libtool stub from the current configuration,
for use in further configure time tests before the real libtool is
generated.
@@ -641,9 +651,9 @@ configured by $[0], generated by m4_PACKAGE_STRING.
Copyright (C) 2011 Free Software Foundation, Inc.
This config.lt script is free software; the Free Software Foundation
-gives unlimited permission to copy, distribute and modify it."
+gives unlimited permision to copy, distribute and modify it."
-while test $[#] != 0
+while test 0 != $[#]
do
case $[1] in
--version | --v* | -V )
@@ -656,10 +666,10 @@ do
lt_cl_silent=: ;;
-*) AC_MSG_ERROR([unrecognized option: $[1]
-Try \`$[0] --help' for more information.]) ;;
+Try '$[0] --help' for more information.]) ;;
*) AC_MSG_ERROR([unrecognized argument: $[1]
-Try \`$[0] --help' for more information.]) ;;
+Try '$[0] --help' for more information.]) ;;
esac
shift
done
@@ -685,7 +695,7 @@ chmod +x "$CONFIG_LT"
# open by configure. Here we exec the FD to /dev/null, effectively closing
# config.log, so it can be properly (re)opened and appended to by config.lt.
lt_cl_success=:
-test "$silent" = yes &&
+test yes = "$silent" &&
lt_config_lt_args="$lt_config_lt_args --quiet"
exec AS_MESSAGE_LOG_FD>/dev/null
$SHELL "$CONFIG_LT" $lt_config_lt_args || lt_cl_success=false
@@ -705,27 +715,30 @@ m4_defun([_LT_CONFIG],
_LT_CONFIG_SAVE_COMMANDS([
m4_define([_LT_TAG], m4_if([$1], [], [C], [$1]))dnl
m4_if(_LT_TAG, [C], [
- # See if we are running on zsh, and set the options which allow our
+ # See if we are running on zsh, and set the options that allow our
# commands through without removal of \ escapes.
- if test -n "${ZSH_VERSION+set}" ; then
+ if test -n "${ZSH_VERSION+set}"; then
setopt NO_GLOB_SUBST
fi
- cfgfile="${ofile}T"
+ cfgfile=${ofile}T
trap "$RM \"$cfgfile\"; exit 1" 1 2 15
$RM "$cfgfile"
cat <<_LT_EOF >> "$cfgfile"
#! $SHELL
-
-# `$ECHO "$ofile" | sed 's%^.*/%%'` - Provide generalized library-building support services.
-# Generated automatically by $as_me ($PACKAGE$TIMESTAMP) $VERSION
-# Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`:
+# Generated automatically by $as_me ($PACKAGE) $VERSION
# NOTE: Changes made to this file will be lost: look at ltmain.sh.
-#
+
+# Provide generalized library-building support services.
+# Written by Gordon Matzigkeit, 1996
+
_LT_COPYING
_LT_LIBTOOL_TAGS
+# Configured defaults for sys_lib_dlsearch_path munging.
+: \${LT_SYS_LIBRARY_PATH="$configure_time_lt_sys_library_path"}
+
# ### BEGIN LIBTOOL CONFIG
_LT_LIBTOOL_CONFIG_VARS
_LT_LIBTOOL_TAG_VARS
@@ -733,13 +746,24 @@ _LT_LIBTOOL_TAG_VARS
_LT_EOF
+ cat <<'_LT_EOF' >> "$cfgfile"
+
+# ### BEGIN FUNCTIONS SHARED WITH CONFIGURE
+
+_LT_PREPARE_MUNGE_PATH_LIST
+_LT_PREPARE_CC_BASENAME
+
+# ### END FUNCTIONS SHARED WITH CONFIGURE
+
+_LT_EOF
+
case $host_os in
aix3*)
cat <<\_LT_EOF >> "$cfgfile"
# AIX sometimes has problems with the GCC collect2 program. For some
# reason, if we set the COLLECT_NAMES environment variable, the problems
# vanish in a puff of smoke.
-if test "X${COLLECT_NAMES+set}" != Xset; then
+if test set != "${COLLECT_NAMES+set}"; then
COLLECT_NAMES=
export COLLECT_NAMES
fi
@@ -756,8 +780,6 @@ _LT_EOF
sed '$q' "$ltmain" >> "$cfgfile" \
|| (rm -f "$cfgfile"; exit 1)
- _LT_PROG_REPLACE_SHELLFNS
-
mv -f "$cfgfile" "$ofile" ||
(rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile")
chmod +x "$ofile"
@@ -775,7 +797,6 @@ _LT_EOF
[m4_if([$1], [], [
PACKAGE='$PACKAGE'
VERSION='$VERSION'
- TIMESTAMP='$TIMESTAMP'
RM='$RM'
ofile='$ofile'], [])
])dnl /_LT_CONFIG_SAVE_COMMANDS
@@ -974,7 +995,7 @@ m4_defun_once([_LT_REQUIRED_DARWIN_CHECKS],[
AC_CACHE_CHECK([for -single_module linker flag],[lt_cv_apple_cc_single_mod],
[lt_cv_apple_cc_single_mod=no
- if test -z "${LT_MULTI_MODULE}"; then
+ if test -z "$LT_MULTI_MODULE"; then
# By default we will add the -single_module flag. You can override
# by either setting the environment variable LT_MULTI_MODULE
# non-empty at configure time, or by adding -multi_module to the
@@ -992,7 +1013,7 @@ m4_defun_once([_LT_REQUIRED_DARWIN_CHECKS],[
cat conftest.err >&AS_MESSAGE_LOG_FD
# Otherwise, if the output was created with a 0 exit code from
# the compiler, it worked.
- elif test -f libconftest.dylib && test $_lt_result -eq 0; then
+ elif test -f libconftest.dylib && test 0 = "$_lt_result"; then
lt_cv_apple_cc_single_mod=yes
else
cat conftest.err >&AS_MESSAGE_LOG_FD
@@ -1010,7 +1031,7 @@ m4_defun_once([_LT_REQUIRED_DARWIN_CHECKS],[
AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])],
[lt_cv_ld_exported_symbols_list=yes],
[lt_cv_ld_exported_symbols_list=no])
- LDFLAGS="$save_LDFLAGS"
+ LDFLAGS=$save_LDFLAGS
])
AC_CACHE_CHECK([for -force_load linker flag],[lt_cv_ld_force_load],
@@ -1032,7 +1053,7 @@ _LT_EOF
_lt_result=$?
if test -s conftest.err && $GREP force_load conftest.err; then
cat conftest.err >&AS_MESSAGE_LOG_FD
- elif test -f conftest && test $_lt_result -eq 0 && $GREP forced_load conftest >/dev/null 2>&1 ; then
+ elif test -f conftest && test 0 = "$_lt_result" && $GREP forced_load conftest >/dev/null 2>&1; then
lt_cv_ld_force_load=yes
else
cat conftest.err >&AS_MESSAGE_LOG_FD
@@ -1042,32 +1063,32 @@ _LT_EOF
])
case $host_os in
rhapsody* | darwin1.[[012]])
- _lt_dar_allow_undefined='${wl}-undefined ${wl}suppress' ;;
+ _lt_dar_allow_undefined='$wl-undefined ${wl}suppress' ;;
darwin1.*)
- _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;;
+ _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;;
darwin*) # darwin 5.x on
# if running on 10.5 or later, the deployment target defaults
# to the OS version, if on x86, and 10.4, the deployment
# target defaults to 10.4. Don't you love it?
case ${MACOSX_DEPLOYMENT_TARGET-10.0},$host in
10.0,*86*-darwin8*|10.0,*-darwin[[91]]*)
- _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;;
- 10.[[012]]*)
- _lt_dar_allow_undefined='${wl}-flat_namespace ${wl}-undefined ${wl}suppress' ;;
+ _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;;
+ 10.[[012]][[,.]]*)
+ _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;;
10.*)
- _lt_dar_allow_undefined='${wl}-undefined ${wl}dynamic_lookup' ;;
+ _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;;
esac
;;
esac
- if test "$lt_cv_apple_cc_single_mod" = "yes"; then
+ if test yes = "$lt_cv_apple_cc_single_mod"; then
_lt_dar_single_mod='$single_module'
fi
- if test "$lt_cv_ld_exported_symbols_list" = "yes"; then
- _lt_dar_export_syms=' ${wl}-exported_symbols_list,$output_objdir/${libname}-symbols.expsym'
+ if test yes = "$lt_cv_ld_exported_symbols_list"; then
+ _lt_dar_export_syms=' $wl-exported_symbols_list,$output_objdir/$libname-symbols.expsym'
else
- _lt_dar_export_syms='~$NMEDIT -s $output_objdir/${libname}-symbols.expsym ${lib}'
+ _lt_dar_export_syms='~$NMEDIT -s $output_objdir/$libname-symbols.expsym $lib'
fi
- if test "$DSYMUTIL" != ":" && test "$lt_cv_ld_force_load" = "no"; then
+ if test : != "$DSYMUTIL" && test no = "$lt_cv_ld_force_load"; then
_lt_dsymutil='~$DSYMUTIL $lib || :'
else
_lt_dsymutil=
@@ -1087,29 +1108,29 @@ m4_defun([_LT_DARWIN_LINKER_FEATURES],
_LT_TAGVAR(hardcode_direct, $1)=no
_LT_TAGVAR(hardcode_automatic, $1)=yes
_LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported
- if test "$lt_cv_ld_force_load" = "yes"; then
- _LT_TAGVAR(whole_archive_flag_spec, $1)='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience ${wl}-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`'
+ if test yes = "$lt_cv_ld_force_load"; then
+ _LT_TAGVAR(whole_archive_flag_spec, $1)='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`'
m4_case([$1], [F77], [_LT_TAGVAR(compiler_needs_object, $1)=yes],
[FC], [_LT_TAGVAR(compiler_needs_object, $1)=yes])
else
_LT_TAGVAR(whole_archive_flag_spec, $1)=''
fi
_LT_TAGVAR(link_all_deplibs, $1)=yes
- _LT_TAGVAR(allow_undefined_flag, $1)="$_lt_dar_allow_undefined"
+ _LT_TAGVAR(allow_undefined_flag, $1)=$_lt_dar_allow_undefined
case $cc_basename in
- ifort*) _lt_dar_can_shared=yes ;;
+ ifort*|nagfor*) _lt_dar_can_shared=yes ;;
*) _lt_dar_can_shared=$GCC ;;
esac
- if test "$_lt_dar_can_shared" = "yes"; then
+ if test yes = "$_lt_dar_can_shared"; then
output_verbose_link_cmd=func_echo_all
- _LT_TAGVAR(archive_cmds, $1)="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod${_lt_dsymutil}"
- _LT_TAGVAR(module_cmds, $1)="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dsymutil}"
- _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring ${_lt_dar_single_mod}${_lt_dar_export_syms}${_lt_dsymutil}"
- _LT_TAGVAR(module_expsym_cmds, $1)="sed -e 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags${_lt_dar_export_syms}${_lt_dsymutil}"
+ _LT_TAGVAR(archive_cmds, $1)="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil"
+ _LT_TAGVAR(module_cmds, $1)="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil"
+ _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil"
+ _LT_TAGVAR(module_expsym_cmds, $1)="sed -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil"
m4_if([$1], [CXX],
-[ if test "$lt_cv_apple_cc_single_mod" != "yes"; then
- _LT_TAGVAR(archive_cmds, $1)="\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dsymutil}"
- _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's,^,_,' < \$export_symbols > \$output_objdir/\${libname}-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \${lib}-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \${lib}-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring${_lt_dar_export_syms}${_lt_dsymutil}"
+[ if test yes != "$lt_cv_apple_cc_single_mod"; then
+ _LT_TAGVAR(archive_cmds, $1)="\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dsymutil"
+ _LT_TAGVAR(archive_expsym_cmds, $1)="sed 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dar_export_syms$_lt_dsymutil"
fi
],[])
else
@@ -1129,7 +1150,7 @@ m4_defun([_LT_DARWIN_LINKER_FEATURES],
# Allow to override them for all tags through lt_cv_aix_libpath.
m4_defun([_LT_SYS_MODULE_PATH_AIX],
[m4_require([_LT_DECL_SED])dnl
-if test "${lt_cv_aix_libpath+set}" = set; then
+if test set = "${lt_cv_aix_libpath+set}"; then
aix_libpath=$lt_cv_aix_libpath
else
AC_CACHE_VAL([_LT_TAGVAR([lt_cv_aix_libpath_], [$1])],
@@ -1147,7 +1168,7 @@ else
_LT_TAGVAR([lt_cv_aix_libpath_], [$1])=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"`
fi],[])
if test -z "$_LT_TAGVAR([lt_cv_aix_libpath_], [$1])"; then
- _LT_TAGVAR([lt_cv_aix_libpath_], [$1])="/usr/lib:/lib"
+ _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=/usr/lib:/lib
fi
])
aix_libpath=$_LT_TAGVAR([lt_cv_aix_libpath_], [$1])
@@ -1167,8 +1188,8 @@ m4_define([_LT_SHELL_INIT],
# -----------------------
# Find how we can fake an echo command that does not interpret backslash.
# In particular, with Autoconf 2.60 or later we add some code to the start
-# of the generated configure script which will find a shell with a builtin
-# printf (which we can use as an echo command).
+# of the generated configure script that will find a shell with a builtin
+# printf (that we can use as an echo command).
m4_defun([_LT_PROG_ECHO_BACKSLASH],
[ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\'
ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO
@@ -1196,10 +1217,10 @@ fi
# Invoke $ECHO with all args, space-separated.
func_echo_all ()
{
- $ECHO "$*"
+ $ECHO "$*"
}
-case "$ECHO" in
+case $ECHO in
printf*) AC_MSG_RESULT([printf]) ;;
print*) AC_MSG_RESULT([print -r]) ;;
*) AC_MSG_RESULT([cat]) ;;
@@ -1225,16 +1246,17 @@ _LT_DECL([], [ECHO], [1], [An echo program that protects backslashes])
AC_DEFUN([_LT_WITH_SYSROOT],
[AC_MSG_CHECKING([for sysroot])
AC_ARG_WITH([sysroot],
-[ --with-sysroot[=DIR] Search for dependent libraries within DIR
- (or the compiler's sysroot if not specified).],
+[AS_HELP_STRING([--with-sysroot@<:@=DIR@:>@],
+ [Search for dependent libraries within DIR (or the compiler's sysroot
+ if not specified).])],
[], [with_sysroot=no])
dnl lt_sysroot will always be passed unquoted. We quote it here
dnl in case the user passed a directory name.
lt_sysroot=
-case ${with_sysroot} in #(
+case $with_sysroot in #(
yes)
- if test "$GCC" = yes; then
+ if test yes = "$GCC"; then
lt_sysroot=`$CC --print-sysroot 2>/dev/null`
fi
;; #(
@@ -1244,14 +1266,14 @@ case ${with_sysroot} in #(
no|'')
;; #(
*)
- AC_MSG_RESULT([${with_sysroot}])
+ AC_MSG_RESULT([$with_sysroot])
AC_MSG_ERROR([The sysroot must be an absolute path.])
;;
esac
AC_MSG_RESULT([${lt_sysroot:-no}])
_LT_DECL([], [lt_sysroot], [0], [The root where to search for ]dnl
-[dependent libraries, and in which our libraries should be installed.])])
+[dependent libraries, and where our libraries should be installed.])])
# _LT_ENABLE_LOCK
# ---------------
@@ -1259,31 +1281,33 @@ m4_defun([_LT_ENABLE_LOCK],
[AC_ARG_ENABLE([libtool-lock],
[AS_HELP_STRING([--disable-libtool-lock],
[avoid locking (might break parallel builds)])])
-test "x$enable_libtool_lock" != xno && enable_libtool_lock=yes
+test no = "$enable_libtool_lock" || enable_libtool_lock=yes
# Some flags need to be propagated to the compiler or linker for good
# libtool support.
case $host in
ia64-*-hpux*)
- # Find out which ABI we are using.
+ # Find out what ABI is being produced by ac_compile, and set mode
+ # options accordingly.
echo 'int i;' > conftest.$ac_ext
if AC_TRY_EVAL(ac_compile); then
case `/usr/bin/file conftest.$ac_objext` in
*ELF-32*)
- HPUX_IA64_MODE="32"
+ HPUX_IA64_MODE=32
;;
*ELF-64*)
- HPUX_IA64_MODE="64"
+ HPUX_IA64_MODE=64
;;
esac
fi
rm -rf conftest*
;;
*-*-irix6*)
- # Find out which ABI we are using.
+ # Find out what ABI is being produced by ac_compile, and set linker
+ # options accordingly.
echo '[#]line '$LINENO' "configure"' > conftest.$ac_ext
if AC_TRY_EVAL(ac_compile); then
- if test "$lt_cv_prog_gnu_ld" = yes; then
+ if test yes = "$lt_cv_prog_gnu_ld"; then
case `/usr/bin/file conftest.$ac_objext` in
*32-bit*)
LD="${LD-ld} -melf32bsmip"
@@ -1312,9 +1336,46 @@ ia64-*-hpux*)
rm -rf conftest*
;;
-x86_64-*kfreebsd*-gnu|x86_64-*linux*|ppc*-*linux*|powerpc*-*linux*| \
+mips64*-*linux*)
+ # Find out what ABI is being produced by ac_compile, and set linker
+ # options accordingly.
+ echo '[#]line '$LINENO' "configure"' > conftest.$ac_ext
+ if AC_TRY_EVAL(ac_compile); then
+ emul=elf
+ case `/usr/bin/file conftest.$ac_objext` in
+ *32-bit*)
+ emul="${emul}32"
+ ;;
+ *64-bit*)
+ emul="${emul}64"
+ ;;
+ esac
+ case `/usr/bin/file conftest.$ac_objext` in
+ *MSB*)
+ emul="${emul}btsmip"
+ ;;
+ *LSB*)
+ emul="${emul}ltsmip"
+ ;;
+ esac
+ case `/usr/bin/file conftest.$ac_objext` in
+ *N32*)
+ emul="${emul}n32"
+ ;;
+ esac
+ LD="${LD-ld} -m $emul"
+ fi
+ rm -rf conftest*
+ ;;
+
+x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \
s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
- # Find out which ABI we are using.
+ # Find out what ABI is being produced by ac_compile, and set linker
+ # options accordingly. Note that the listed cases only cover the
+ # situations where additional linker options are needed (such as when
+ # doing 32-bit compilation for a host where ld defaults to 64-bit, or
+ # vice versa); the common cases where no linker options are needed do
+ # not appear in the list.
echo 'int i;' > conftest.$ac_ext
if AC_TRY_EVAL(ac_compile); then
case `/usr/bin/file conftest.o` in
@@ -1324,9 +1385,19 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
LD="${LD-ld} -m elf_i386_fbsd"
;;
x86_64-*linux*)
- LD="${LD-ld} -m elf_i386"
+ case `/usr/bin/file conftest.o` in
+ *x86-64*)
+ LD="${LD-ld} -m elf32_x86_64"
+ ;;
+ *)
+ LD="${LD-ld} -m elf_i386"
+ ;;
+ esac
+ ;;
+ powerpc64le-*linux*)
+ LD="${LD-ld} -m elf32lppclinux"
;;
- ppc64-*linux*|powerpc64-*linux*)
+ powerpc64-*linux*)
LD="${LD-ld} -m elf32ppclinux"
;;
s390x-*linux*)
@@ -1345,7 +1416,10 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
x86_64-*linux*)
LD="${LD-ld} -m elf_x86_64"
;;
- ppc*-*linux*|powerpc*-*linux*)
+ powerpcle-*linux*)
+ LD="${LD-ld} -m elf64lppc"
+ ;;
+ powerpc-*linux*)
LD="${LD-ld} -m elf64ppc"
;;
s390*-*linux*|s390*-*tpf*)
@@ -1363,19 +1437,20 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
*-*-sco3.2v5*)
# On SCO OpenServer 5, we need -belf to get full-featured binaries.
- SAVE_CFLAGS="$CFLAGS"
+ SAVE_CFLAGS=$CFLAGS
CFLAGS="$CFLAGS -belf"
AC_CACHE_CHECK([whether the C compiler needs -belf], lt_cv_cc_needs_belf,
[AC_LANG_PUSH(C)
AC_LINK_IFELSE([AC_LANG_PROGRAM([[]],[[]])],[lt_cv_cc_needs_belf=yes],[lt_cv_cc_needs_belf=no])
AC_LANG_POP])
- if test x"$lt_cv_cc_needs_belf" != x"yes"; then
+ if test yes != "$lt_cv_cc_needs_belf"; then
# this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf
- CFLAGS="$SAVE_CFLAGS"
+ CFLAGS=$SAVE_CFLAGS
fi
;;
*-*solaris*)
- # Find out which ABI we are using.
+ # Find out what ABI is being produced by ac_compile, and set linker
+ # options accordingly.
echo 'int i;' > conftest.$ac_ext
if AC_TRY_EVAL(ac_compile); then
case `/usr/bin/file conftest.o` in
@@ -1383,7 +1458,7 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
case $lt_cv_prog_gnu_ld in
yes*)
case $host in
- i?86-*-solaris*)
+ i?86-*-solaris*|x86_64-*-solaris*)
LD="${LD-ld} -m elf_x86_64"
;;
sparc*-*-solaris*)
@@ -1392,7 +1467,7 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
esac
# GNU ld 2.21 introduced _sol2 emulations. Use them if available.
if ${LD-ld} -V | grep _sol2 >/dev/null 2>&1; then
- LD="${LD-ld}_sol2"
+ LD=${LD-ld}_sol2
fi
;;
*)
@@ -1408,7 +1483,7 @@ s390*-*linux*|s390*-*tpf*|sparc*-*linux*)
;;
esac
-need_locks="$enable_libtool_lock"
+need_locks=$enable_libtool_lock
])# _LT_ENABLE_LOCK
@@ -1427,11 +1502,11 @@ AC_CACHE_CHECK([for archiver @FILE support], [lt_cv_ar_at_file],
[echo conftest.$ac_objext > conftest.lst
lt_ar_try='$AR $AR_FLAGS libconftest.a @conftest.lst >&AS_MESSAGE_LOG_FD'
AC_TRY_EVAL([lt_ar_try])
- if test "$ac_status" -eq 0; then
+ if test 0 -eq "$ac_status"; then
# Ensure the archiver fails upon bogus file names.
rm -f conftest.$ac_objext libconftest.a
AC_TRY_EVAL([lt_ar_try])
- if test "$ac_status" -ne 0; then
+ if test 0 -ne "$ac_status"; then
lt_cv_ar_at_file=@
fi
fi
@@ -1439,7 +1514,7 @@ AC_CACHE_CHECK([for archiver @FILE support], [lt_cv_ar_at_file],
])
])
-if test "x$lt_cv_ar_at_file" = xno; then
+if test no = "$lt_cv_ar_at_file"; then
archiver_list_spec=
else
archiver_list_spec=$lt_cv_ar_at_file
@@ -1470,7 +1545,7 @@ old_postuninstall_cmds=
if test -n "$RANLIB"; then
case $host_os in
- openbsd*)
+ bitrig* | openbsd*)
old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$tool_oldlib"
;;
*)
@@ -1506,7 +1581,7 @@ AC_CACHE_CHECK([$1], [$2],
[$2=no
m4_if([$4], , [ac_outfile=conftest.$ac_objext], [ac_outfile=$4])
echo "$lt_simple_compile_test_code" > conftest.$ac_ext
- lt_compiler_flag="$3"
+ lt_compiler_flag="$3" ## exclude from sc_useless_quotes_in_assignment
# Insert the option either (1) after the last *FLAGS variable, or
# (2) before a word containing "conftest.", or (3) at the end.
# Note that $ac_compile itself does not contain backslashes and begins
@@ -1533,7 +1608,7 @@ AC_CACHE_CHECK([$1], [$2],
$RM conftest*
])
-if test x"[$]$2" = xyes; then
+if test yes = "[$]$2"; then
m4_if([$5], , :, [$5])
else
m4_if([$6], , :, [$6])
@@ -1555,7 +1630,7 @@ AC_DEFUN([_LT_LINKER_OPTION],
m4_require([_LT_DECL_SED])dnl
AC_CACHE_CHECK([$1], [$2],
[$2=no
- save_LDFLAGS="$LDFLAGS"
+ save_LDFLAGS=$LDFLAGS
LDFLAGS="$LDFLAGS $3"
echo "$lt_simple_link_test_code" > conftest.$ac_ext
if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then
@@ -1574,10 +1649,10 @@ AC_CACHE_CHECK([$1], [$2],
fi
fi
$RM -r conftest*
- LDFLAGS="$save_LDFLAGS"
+ LDFLAGS=$save_LDFLAGS
])
-if test x"[$]$2" = xyes; then
+if test yes = "[$]$2"; then
m4_if([$4], , :, [$4])
else
m4_if([$5], , :, [$5])
@@ -1598,7 +1673,7 @@ AC_DEFUN([LT_CMD_MAX_LEN],
AC_MSG_CHECKING([the maximum length of command line arguments])
AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl
i=0
- teststring="ABCD"
+ teststring=ABCD
case $build_os in
msdosdjgpp*)
@@ -1638,7 +1713,7 @@ AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl
lt_cv_sys_max_cmd_len=8192;
;;
- netbsd* | freebsd* | openbsd* | darwin* | dragonfly*)
+ bitrig* | darwin* | dragonfly* | freebsd* | netbsd* | openbsd*)
# This has been around since 386BSD, at least. Likely further.
if test -x /sbin/sysctl; then
lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax`
@@ -1688,22 +1763,23 @@ AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl
;;
*)
lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null`
- if test -n "$lt_cv_sys_max_cmd_len"; then
+ if test -n "$lt_cv_sys_max_cmd_len" && \
+ test undefined != "$lt_cv_sys_max_cmd_len"; then
lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4`
lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3`
else
# Make teststring a little bigger before we do anything with it.
# a 1K string should be a reasonable start.
- for i in 1 2 3 4 5 6 7 8 ; do
+ for i in 1 2 3 4 5 6 7 8; do
teststring=$teststring$teststring
done
SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}}
# If test is not a shell built-in, we'll probably end up computing a
# maximum length that is only half of the actual maximum length, but
# we can't tell.
- while { test "X"`env echo "$teststring$teststring" 2>/dev/null` \
+ while { test X`env echo "$teststring$teststring" 2>/dev/null` \
= "X$teststring$teststring"; } >/dev/null 2>&1 &&
- test $i != 17 # 1/2 MB should be enough
+ test 17 != "$i" # 1/2 MB should be enough
do
i=`expr $i + 1`
teststring=$teststring$teststring
@@ -1719,7 +1795,7 @@ AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl
;;
esac
])
-if test -n $lt_cv_sys_max_cmd_len ; then
+if test -n "$lt_cv_sys_max_cmd_len"; then
AC_MSG_RESULT($lt_cv_sys_max_cmd_len)
else
AC_MSG_RESULT(none)
@@ -1747,7 +1823,7 @@ m4_defun([_LT_HEADER_DLFCN],
# ----------------------------------------------------------------
m4_defun([_LT_TRY_DLOPEN_SELF],
[m4_require([_LT_HEADER_DLFCN])dnl
-if test "$cross_compiling" = yes; then :
+if test yes = "$cross_compiling"; then :
[$4]
else
lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2
@@ -1794,9 +1870,9 @@ else
# endif
#endif
-/* When -fvisbility=hidden is used, assume the code has been annotated
+/* When -fvisibility=hidden is used, assume the code has been annotated
correspondingly for the symbols needed. */
-#if defined(__GNUC__) && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3))
+#if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3))
int fnord () __attribute__((visibility("default")));
#endif
@@ -1822,7 +1898,7 @@ int main ()
return status;
}]
_LT_EOF
- if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext} 2>/dev/null; then
+ if AC_TRY_EVAL(ac_link) && test -s "conftest$ac_exeext" 2>/dev/null; then
(./conftest; exit; ) >&AS_MESSAGE_LOG_FD 2>/dev/null
lt_status=$?
case x$lt_status in
@@ -1843,7 +1919,7 @@ rm -fr conftest*
# ------------------
AC_DEFUN([LT_SYS_DLOPEN_SELF],
[m4_require([_LT_HEADER_DLFCN])dnl
-if test "x$enable_dlopen" != xyes; then
+if test yes != "$enable_dlopen"; then
enable_dlopen=unknown
enable_dlopen_self=unknown
enable_dlopen_self_static=unknown
@@ -1853,44 +1929,52 @@ else
case $host_os in
beos*)
- lt_cv_dlopen="load_add_on"
+ lt_cv_dlopen=load_add_on
lt_cv_dlopen_libs=
lt_cv_dlopen_self=yes
;;
mingw* | pw32* | cegcc*)
- lt_cv_dlopen="LoadLibrary"
+ lt_cv_dlopen=LoadLibrary
lt_cv_dlopen_libs=
;;
cygwin*)
- lt_cv_dlopen="dlopen"
+ lt_cv_dlopen=dlopen
lt_cv_dlopen_libs=
;;
darwin*)
- # if libdl is installed we need to link against it
+ # if libdl is installed we need to link against it
AC_CHECK_LIB([dl], [dlopen],
- [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"],[
- lt_cv_dlopen="dyld"
+ [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl],[
+ lt_cv_dlopen=dyld
lt_cv_dlopen_libs=
lt_cv_dlopen_self=yes
])
;;
+ tpf*)
+ # Don't try to run any link tests for TPF. We know it's impossible
+ # because TPF is a cross-compiler, and we know how we open DSOs.
+ lt_cv_dlopen=dlopen
+ lt_cv_dlopen_libs=
+ lt_cv_dlopen_self=no
+ ;;
+
*)
AC_CHECK_FUNC([shl_load],
- [lt_cv_dlopen="shl_load"],
+ [lt_cv_dlopen=shl_load],
[AC_CHECK_LIB([dld], [shl_load],
- [lt_cv_dlopen="shl_load" lt_cv_dlopen_libs="-ldld"],
+ [lt_cv_dlopen=shl_load lt_cv_dlopen_libs=-ldld],
[AC_CHECK_FUNC([dlopen],
- [lt_cv_dlopen="dlopen"],
+ [lt_cv_dlopen=dlopen],
[AC_CHECK_LIB([dl], [dlopen],
- [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-ldl"],
+ [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl],
[AC_CHECK_LIB([svld], [dlopen],
- [lt_cv_dlopen="dlopen" lt_cv_dlopen_libs="-lsvld"],
+ [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-lsvld],
[AC_CHECK_LIB([dld], [dld_link],
- [lt_cv_dlopen="dld_link" lt_cv_dlopen_libs="-ldld"])
+ [lt_cv_dlopen=dld_link lt_cv_dlopen_libs=-ldld])
])
])
])
@@ -1899,21 +1983,21 @@ else
;;
esac
- if test "x$lt_cv_dlopen" != xno; then
- enable_dlopen=yes
- else
+ if test no = "$lt_cv_dlopen"; then
enable_dlopen=no
+ else
+ enable_dlopen=yes
fi
case $lt_cv_dlopen in
dlopen)
- save_CPPFLAGS="$CPPFLAGS"
- test "x$ac_cv_header_dlfcn_h" = xyes && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H"
+ save_CPPFLAGS=$CPPFLAGS
+ test yes = "$ac_cv_header_dlfcn_h" && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H"
- save_LDFLAGS="$LDFLAGS"
+ save_LDFLAGS=$LDFLAGS
wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\"
- save_LIBS="$LIBS"
+ save_LIBS=$LIBS
LIBS="$lt_cv_dlopen_libs $LIBS"
AC_CACHE_CHECK([whether a program can dlopen itself],
@@ -1923,7 +2007,7 @@ else
lt_cv_dlopen_self=no, lt_cv_dlopen_self=cross)
])
- if test "x$lt_cv_dlopen_self" = xyes; then
+ if test yes = "$lt_cv_dlopen_self"; then
wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\"
AC_CACHE_CHECK([whether a statically linked program can dlopen itself],
lt_cv_dlopen_self_static, [dnl
@@ -1933,9 +2017,9 @@ else
])
fi
- CPPFLAGS="$save_CPPFLAGS"
- LDFLAGS="$save_LDFLAGS"
- LIBS="$save_LIBS"
+ CPPFLAGS=$save_CPPFLAGS
+ LDFLAGS=$save_LDFLAGS
+ LIBS=$save_LIBS
;;
esac
@@ -2027,8 +2111,8 @@ m4_defun([_LT_COMPILER_FILE_LOCKS],
m4_require([_LT_FILEUTILS_DEFAULTS])dnl
_LT_COMPILER_C_O([$1])
-hard_links="nottested"
-if test "$_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)" = no && test "$need_locks" != no; then
+hard_links=nottested
+if test no = "$_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)" && test no != "$need_locks"; then
# do not overwrite the value of need_locks provided by the user
AC_MSG_CHECKING([if we can lock with hard links])
hard_links=yes
@@ -2038,8 +2122,8 @@ if test "$_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)" = no && test "$need_locks" !=
ln conftest.a conftest.b 2>&5 || hard_links=no
ln conftest.a conftest.b 2>/dev/null && hard_links=no
AC_MSG_RESULT([$hard_links])
- if test "$hard_links" = no; then
- AC_MSG_WARN([`$CC' does not support `-c -o', so `make -j' may be unsafe])
+ if test no = "$hard_links"; then
+ AC_MSG_WARN(['$CC' does not support '-c -o', so 'make -j' may be unsafe])
need_locks=warn
fi
else
@@ -2066,8 +2150,8 @@ objdir=$lt_cv_objdir
_LT_DECL([], [objdir], [0],
[The name of the directory that contains temporary libtool files])dnl
m4_pattern_allow([LT_OBJDIR])dnl
-AC_DEFINE_UNQUOTED(LT_OBJDIR, "$lt_cv_objdir/",
- [Define to the sub-directory in which libtool stores uninstalled libraries.])
+AC_DEFINE_UNQUOTED([LT_OBJDIR], "$lt_cv_objdir/",
+ [Define to the sub-directory where libtool stores uninstalled libraries.])
])# _LT_CHECK_OBJDIR
@@ -2079,15 +2163,15 @@ m4_defun([_LT_LINKER_HARDCODE_LIBPATH],
_LT_TAGVAR(hardcode_action, $1)=
if test -n "$_LT_TAGVAR(hardcode_libdir_flag_spec, $1)" ||
test -n "$_LT_TAGVAR(runpath_var, $1)" ||
- test "X$_LT_TAGVAR(hardcode_automatic, $1)" = "Xyes" ; then
+ test yes = "$_LT_TAGVAR(hardcode_automatic, $1)"; then
# We can hardcode non-existent directories.
- if test "$_LT_TAGVAR(hardcode_direct, $1)" != no &&
+ if test no != "$_LT_TAGVAR(hardcode_direct, $1)" &&
# If the only mechanism to avoid hardcoding is shlibpath_var, we
# have to relink, otherwise we might link with an installed library
# when we should be linking with a yet-to-be-installed one
- ## test "$_LT_TAGVAR(hardcode_shlibpath_var, $1)" != no &&
- test "$_LT_TAGVAR(hardcode_minus_L, $1)" != no; then
+ ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, $1)" &&
+ test no != "$_LT_TAGVAR(hardcode_minus_L, $1)"; then
# Linking always hardcodes the temporary library directory.
_LT_TAGVAR(hardcode_action, $1)=relink
else
@@ -2101,12 +2185,12 @@ else
fi
AC_MSG_RESULT([$_LT_TAGVAR(hardcode_action, $1)])
-if test "$_LT_TAGVAR(hardcode_action, $1)" = relink ||
- test "$_LT_TAGVAR(inherit_rpath, $1)" = yes; then
+if test relink = "$_LT_TAGVAR(hardcode_action, $1)" ||
+ test yes = "$_LT_TAGVAR(inherit_rpath, $1)"; then
# Fast installation is not supported
enable_fast_install=no
-elif test "$shlibpath_overrides_runpath" = yes ||
- test "$enable_shared" = no; then
+elif test yes = "$shlibpath_overrides_runpath" ||
+ test no = "$enable_shared"; then
# Fast installation is not necessary
enable_fast_install=needless
fi
@@ -2130,7 +2214,7 @@ else
# FIXME - insert some real tests, host_os isn't really good enough
case $host_os in
darwin*)
- if test -n "$STRIP" ; then
+ if test -n "$STRIP"; then
striplib="$STRIP -x"
old_striplib="$STRIP -S"
AC_MSG_RESULT([yes])
@@ -2148,6 +2232,47 @@ _LT_DECL([], [striplib], [1])
])# _LT_CMD_STRIPLIB
+# _LT_PREPARE_MUNGE_PATH_LIST
+# ---------------------------
+# Make sure func_munge_path_list() is defined correctly.
+m4_defun([_LT_PREPARE_MUNGE_PATH_LIST],
+[[# func_munge_path_list VARIABLE PATH
+# -----------------------------------
+# VARIABLE is name of variable containing _space_ separated list of
+# directories to be munged by the contents of PATH, which is string
+# having a format:
+# "DIR[:DIR]:"
+# string "DIR[ DIR]" will be prepended to VARIABLE
+# ":DIR[:DIR]"
+# string "DIR[ DIR]" will be appended to VARIABLE
+# "DIRP[:DIRP]::[DIRA:]DIRA"
+# string "DIRP[ DIRP]" will be prepended to VARIABLE and string
+# "DIRA[ DIRA]" will be appended to VARIABLE
+# "DIR[:DIR]"
+# VARIABLE will be replaced by "DIR[ DIR]"
+func_munge_path_list ()
+{
+ case x@S|@2 in
+ x)
+ ;;
+ *:)
+ eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'` \@S|@@S|@1\"
+ ;;
+ x:*)
+ eval @S|@1=\"\@S|@@S|@1 `$ECHO @S|@2 | $SED 's/:/ /g'`\"
+ ;;
+ *::*)
+ eval @S|@1=\"\@S|@@S|@1\ `$ECHO @S|@2 | $SED -e 's/.*:://' -e 's/:/ /g'`\"
+ eval @S|@1=\"`$ECHO @S|@2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \@S|@@S|@1\"
+ ;;
+ *)
+ eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'`\"
+ ;;
+ esac
+}
+]])# _LT_PREPARE_PATH_LIST
+
+
# _LT_SYS_DYNAMIC_LINKER([TAG])
# -----------------------------
# PORTME Fill in your ld.so characteristics
@@ -2158,17 +2283,18 @@ m4_require([_LT_FILEUTILS_DEFAULTS])dnl
m4_require([_LT_DECL_OBJDUMP])dnl
m4_require([_LT_DECL_SED])dnl
m4_require([_LT_CHECK_SHELL_FEATURES])dnl
+m4_require([_LT_PREPARE_MUNGE_PATH_LIST])dnl
AC_MSG_CHECKING([dynamic linker characteristics])
m4_if([$1],
[], [
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
case $host_os in
- darwin*) lt_awk_arg="/^libraries:/,/LR/" ;;
- *) lt_awk_arg="/^libraries:/" ;;
+ darwin*) lt_awk_arg='/^libraries:/,/LR/' ;;
+ *) lt_awk_arg='/^libraries:/' ;;
esac
case $host_os in
- mingw* | cegcc*) lt_sed_strip_eq="s,=\([[A-Za-z]]:\),\1,g" ;;
- *) lt_sed_strip_eq="s,=/,/,g" ;;
+ mingw* | cegcc*) lt_sed_strip_eq='s|=\([[A-Za-z]]:\)|\1|g' ;;
+ *) lt_sed_strip_eq='s|=/|/|g' ;;
esac
lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e $lt_sed_strip_eq`
case $lt_search_path_spec in
@@ -2184,28 +2310,35 @@ if test "$GCC" = yes; then
;;
esac
# Ok, now we have the path, separated by spaces, we can step through it
- # and add multilib dir if necessary.
+ # and add multilib dir if necessary...
lt_tmp_lt_search_path_spec=
- lt_multi_os_dir=`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null`
+ lt_multi_os_dir=/`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null`
+ # ...but if some path component already ends with the multilib dir we assume
+ # that all is fine and trust -print-search-dirs as is (GCC 4.2? or newer).
+ case "$lt_multi_os_dir; $lt_search_path_spec " in
+ "/; "* | "/.; "* | "/./; "* | *"$lt_multi_os_dir "* | *"$lt_multi_os_dir/ "*)
+ lt_multi_os_dir=
+ ;;
+ esac
for lt_sys_path in $lt_search_path_spec; do
- if test -d "$lt_sys_path/$lt_multi_os_dir"; then
- lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path/$lt_multi_os_dir"
- else
+ if test -d "$lt_sys_path$lt_multi_os_dir"; then
+ lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path$lt_multi_os_dir"
+ elif test -n "$lt_multi_os_dir"; then
test -d "$lt_sys_path" && \
lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path"
fi
done
lt_search_path_spec=`$ECHO "$lt_tmp_lt_search_path_spec" | awk '
-BEGIN {RS=" "; FS="/|\n";} {
- lt_foo="";
- lt_count=0;
+BEGIN {RS = " "; FS = "/|\n";} {
+ lt_foo = "";
+ lt_count = 0;
for (lt_i = NF; lt_i > 0; lt_i--) {
if ($lt_i != "" && $lt_i != ".") {
if ($lt_i == "..") {
lt_count++;
} else {
if (lt_count == 0) {
- lt_foo="/" $lt_i lt_foo;
+ lt_foo = "/" $lt_i lt_foo;
} else {
lt_count--;
}
@@ -2219,7 +2352,7 @@ BEGIN {RS=" "; FS="/|\n";} {
# for these hosts.
case $host_os in
mingw* | cegcc*) lt_search_path_spec=`$ECHO "$lt_search_path_spec" |\
- $SED 's,/\([[A-Za-z]]:\),\1,g'` ;;
+ $SED 's|/\([[A-Za-z]]:\)|\1|g'` ;;
esac
sys_lib_search_path_spec=`$ECHO "$lt_search_path_spec" | $lt_NL2SP`
else
@@ -2228,7 +2361,7 @@ fi])
library_names_spec=
libname_spec='lib$name'
soname_spec=
-shrext_cmds=".so"
+shrext_cmds=.so
postinstall_cmds=
postuninstall_cmds=
finish_cmds=
@@ -2245,14 +2378,17 @@ hardcode_into_libs=no
# flags to be left without arguments
need_version=unknown
+AC_ARG_VAR([LT_SYS_LIBRARY_PATH],
+[User-defined run-time library search path.])
+
case $host_os in
aix3*)
version_type=linux # correct to gnu/linux during the next big refactor
- library_names_spec='${libname}${release}${shared_ext}$versuffix $libname.a'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname.a'
shlibpath_var=LIBPATH
# AIX 3 has no versioning support, so we append a major version to the name.
- soname_spec='${libname}${release}${shared_ext}$major'
+ soname_spec='$libname$release$shared_ext$major'
;;
aix[[4-9]]*)
@@ -2260,41 +2396,91 @@ aix[[4-9]]*)
need_lib_prefix=no
need_version=no
hardcode_into_libs=yes
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# AIX 5 supports IA64
- library_names_spec='${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext}$versuffix $libname${shared_ext}'
+ library_names_spec='$libname$release$shared_ext$major $libname$release$shared_ext$versuffix $libname$shared_ext'
shlibpath_var=LD_LIBRARY_PATH
else
# With GCC up to 2.95.x, collect2 would create an import file
# for dependence libraries. The import file would start with
- # the line `#! .'. This would cause the generated library to
- # depend on `.', always an invalid library. This was fixed in
+ # the line '#! .'. This would cause the generated library to
+ # depend on '.', always an invalid library. This was fixed in
# development snapshots of GCC prior to 3.0.
case $host_os in
aix4 | aix4.[[01]] | aix4.[[01]].*)
if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)'
echo ' yes '
- echo '#endif'; } | ${CC} -E - | $GREP yes > /dev/null; then
+ echo '#endif'; } | $CC -E - | $GREP yes > /dev/null; then
:
else
can_build_shared=no
fi
;;
esac
- # AIX (on Power*) has no versioning support, so currently we can not hardcode correct
+ # Using Import Files as archive members, it is possible to support
+ # filename-based versioning of shared library archives on AIX. While
+ # this would work for both with and without runtime linking, it will
+ # prevent static linking of such archives. So we do filename-based
+ # shared library versioning with .so extension only, which is used
+ # when both runtime linking and shared linking is enabled.
+ # Unfortunately, runtime linking may impact performance, so we do
+ # not want this to be the default eventually. Also, we use the
+ # versioned .so libs for executables only if there is the -brtl
+ # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only.
+ # To allow for filename-based versioning support, we need to create
+ # libNAME.so.V as an archive file, containing:
+ # *) an Import File, referring to the versioned filename of the
+ # archive as well as the shared archive member, telling the
+ # bitwidth (32 or 64) of that shared object, and providing the
+ # list of exported symbols of that shared object, eventually
+ # decorated with the 'weak' keyword
+ # *) the shared object with the F_LOADONLY flag set, to really avoid
+ # it being seen by the linker.
+ # At run time we better use the real file rather than another symlink,
+ # but for link time we create the symlink libNAME.so -> libNAME.so.V
+
+ case $with_aix_soname,$aix_use_runtimelinking in
+ # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct
# soname into executable. Probably we can add versioning support to
# collect2, so additional links can be useful in future.
- if test "$aix_use_runtimelinking" = yes; then
+ aix,yes) # traditional libtool
+ dynamic_linker='AIX unversionable lib.so'
# If using run time linking (on AIX 4.2 or later) use lib<name>.so
# instead of lib<name>.a to let people know that these are not
# typical AIX shared libraries.
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- else
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ ;;
+ aix,no) # traditional AIX only
+ dynamic_linker='AIX lib.a[(]lib.so.V[)]'
# We preserve .a as extension for shared libraries through AIX4.2
# and later when we are not doing run time linking.
- library_names_spec='${libname}${release}.a $libname.a'
- soname_spec='${libname}${release}${shared_ext}$major'
- fi
+ library_names_spec='$libname$release.a $libname.a'
+ soname_spec='$libname$release$shared_ext$major'
+ ;;
+ svr4,*) # full svr4 only
+ dynamic_linker="AIX lib.so.V[(]$shared_archive_member_spec.o[)]"
+ library_names_spec='$libname$release$shared_ext$major $libname$shared_ext'
+ # We do not specify a path in Import Files, so LIBPATH fires.
+ shlibpath_overrides_runpath=yes
+ ;;
+ *,yes) # both, prefer svr4
+ dynamic_linker="AIX lib.so.V[(]$shared_archive_member_spec.o[)], lib.a[(]lib.so.V[)]"
+ library_names_spec='$libname$release$shared_ext$major $libname$shared_ext'
+ # unpreferred sharedlib libNAME.a needs extra handling
+ postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"'
+ postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"'
+ # We do not specify a path in Import Files, so LIBPATH fires.
+ shlibpath_overrides_runpath=yes
+ ;;
+ *,no) # both, prefer aix
+ dynamic_linker="AIX lib.a[(]lib.so.V[)], lib.so.V[(]$shared_archive_member_spec.o[)]"
+ library_names_spec='$libname$release.a $libname.a'
+ soname_spec='$libname$release$shared_ext$major'
+ # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling
+ postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)'
+ postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"'
+ ;;
+ esac
shlibpath_var=LIBPATH
fi
;;
@@ -2304,18 +2490,18 @@ amigaos*)
powerpc)
# Since July 2007 AmigaOS4 officially supports .so libraries.
# When compiling the executable, add -use-dynld -Lsobjs: to the compileline.
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
;;
m68k)
library_names_spec='$libname.ixlibrary $libname.a'
# Create ${libname}_ixlibrary.a entries in /sys/libs.
- finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([[^/]]*\)\.ixlibrary$%\1%'\''`; test $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done'
+ finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([[^/]]*\)\.ixlibrary$%\1%'\''`; $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done'
;;
esac
;;
beos*)
- library_names_spec='${libname}${shared_ext}'
+ library_names_spec='$libname$shared_ext'
dynamic_linker="$host_os ld.so"
shlibpath_var=LIBRARY_PATH
;;
@@ -2323,8 +2509,8 @@ beos*)
bsdi[[45]]*)
version_type=linux # correct to gnu/linux during the next big refactor
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir'
shlibpath_var=LD_LIBRARY_PATH
sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib"
@@ -2336,7 +2522,7 @@ bsdi[[45]]*)
cygwin* | mingw* | pw32* | cegcc*)
version_type=windows
- shrext_cmds=".dll"
+ shrext_cmds=.dll
need_version=no
need_lib_prefix=no
@@ -2345,8 +2531,8 @@ cygwin* | mingw* | pw32* | cegcc*)
# gcc
library_names_spec='$libname.dll.a'
# DLL is installed to $(libdir)/../bin by postinstall_cmds
- postinstall_cmds='base_file=`basename \${file}`~
- dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~
+ postinstall_cmds='base_file=`basename \$file`~
+ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~
dldir=$destdir/`dirname \$dlpath`~
test -d \$dldir || mkdir -p \$dldir~
$install_prog $dir/$dlname \$dldir/$dlname~
@@ -2362,17 +2548,17 @@ cygwin* | mingw* | pw32* | cegcc*)
case $host_os in
cygwin*)
# Cygwin DLLs use 'cyg' prefix rather than 'lib'
- soname_spec='`echo ${libname} | sed -e 's/^lib/cyg/'``echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}'
+ soname_spec='`echo $libname | sed -e 's/^lib/cyg/'``echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext'
m4_if([$1], [],[
sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/lib/w32api"])
;;
mingw* | cegcc*)
# MinGW DLLs use traditional 'lib' prefix
- soname_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}'
+ soname_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext'
;;
pw32*)
# pw32 DLLs use 'pw' prefix rather than 'lib'
- library_names_spec='`echo ${libname} | sed -e 's/^lib/pw/'``echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}'
+ library_names_spec='`echo $libname | sed -e 's/^lib/pw/'``echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext'
;;
esac
dynamic_linker='Win32 ld.exe'
@@ -2381,8 +2567,8 @@ m4_if([$1], [],[
*,cl*)
# Native MSVC
libname_spec='$name'
- soname_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext}'
- library_names_spec='${libname}.dll.lib'
+ soname_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext'
+ library_names_spec='$libname.dll.lib'
case $build_os in
mingw*)
@@ -2409,7 +2595,7 @@ m4_if([$1], [],[
sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"`
;;
*)
- sys_lib_search_path_spec="$LIB"
+ sys_lib_search_path_spec=$LIB
if $ECHO "$sys_lib_search_path_spec" | [$GREP ';[c-zC-Z]:/' >/dev/null]; then
# It is most probably a Windows format PATH.
sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'`
@@ -2422,8 +2608,8 @@ m4_if([$1], [],[
esac
# DLL is installed to $(libdir)/../bin by postinstall_cmds
- postinstall_cmds='base_file=`basename \${file}`~
- dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\${base_file}'\''i; echo \$dlname'\''`~
+ postinstall_cmds='base_file=`basename \$file`~
+ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~
dldir=$destdir/`dirname \$dlpath`~
test -d \$dldir || mkdir -p \$dldir~
$install_prog $dir/$dlname \$dldir/$dlname'
@@ -2436,7 +2622,7 @@ m4_if([$1], [],[
*)
# Assume MSVC wrapper
- library_names_spec='${libname}`echo ${release} | $SED -e 's/[[.]]/-/g'`${versuffix}${shared_ext} $libname.lib'
+ library_names_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext $libname.lib'
dynamic_linker='Win32 ld.exe'
;;
esac
@@ -2449,8 +2635,8 @@ darwin* | rhapsody*)
version_type=darwin
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${major}$shared_ext ${libname}$shared_ext'
- soname_spec='${libname}${release}${major}$shared_ext'
+ library_names_spec='$libname$release$major$shared_ext $libname$shared_ext'
+ soname_spec='$libname$release$major$shared_ext'
shlibpath_overrides_runpath=yes
shlibpath_var=DYLD_LIBRARY_PATH
shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`'
@@ -2463,8 +2649,8 @@ dgux*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname$shared_ext'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
;;
@@ -2482,12 +2668,13 @@ freebsd* | dragonfly*)
version_type=freebsd-$objformat
case $version_type in
freebsd-elf*)
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
need_version=no
need_lib_prefix=no
;;
freebsd-*)
- library_names_spec='${libname}${release}${shared_ext}$versuffix $libname${shared_ext}$versuffix'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix'
need_version=yes
;;
esac
@@ -2512,26 +2699,15 @@ freebsd* | dragonfly*)
esac
;;
-gnu*)
- version_type=linux # correct to gnu/linux during the next big refactor
- need_lib_prefix=no
- need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
- shlibpath_var=LD_LIBRARY_PATH
- shlibpath_overrides_runpath=no
- hardcode_into_libs=yes
- ;;
-
haiku*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
dynamic_linker="$host_os runtime_loader"
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}${major} ${libname}${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LIBRARY_PATH
- shlibpath_overrides_runpath=yes
+ shlibpath_overrides_runpath=no
sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib'
hardcode_into_libs=yes
;;
@@ -2549,14 +2725,15 @@ hpux9* | hpux10* | hpux11*)
dynamic_linker="$host_os dld.so"
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=yes # Unless +noenvvar is specified.
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
- if test "X$HPUX_IA64_MODE" = X32; then
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
+ if test 32 = "$HPUX_IA64_MODE"; then
sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib"
+ sys_lib_dlsearch_path_spec=/usr/lib/hpux32
else
sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64"
+ sys_lib_dlsearch_path_spec=/usr/lib/hpux64
fi
- sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
;;
hppa*64*)
shrext_cmds='.sl'
@@ -2564,8 +2741,8 @@ hpux9* | hpux10* | hpux11*)
dynamic_linker="$host_os dld.sl"
shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH
shlibpath_overrides_runpath=yes # Unless +noenvvar is specified.
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64"
sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
;;
@@ -2574,8 +2751,8 @@ hpux9* | hpux10* | hpux11*)
dynamic_linker="$host_os dld.sl"
shlibpath_var=SHLIB_PATH
shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
;;
esac
# HP-UX runs *really* slowly unless shared libraries are mode 555, ...
@@ -2588,8 +2765,8 @@ interix[[3-9]]*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=no
@@ -2600,7 +2777,7 @@ irix5* | irix6* | nonstopux*)
case $host_os in
nonstopux*) version_type=nonstopux ;;
*)
- if test "$lt_cv_prog_gnu_ld" = yes; then
+ if test yes = "$lt_cv_prog_gnu_ld"; then
version_type=linux # correct to gnu/linux during the next big refactor
else
version_type=irix
@@ -2608,8 +2785,8 @@ irix5* | irix6* | nonstopux*)
esac
need_lib_prefix=no
need_version=no
- soname_spec='${libname}${release}${shared_ext}$major'
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${release}${shared_ext} $libname${shared_ext}'
+ soname_spec='$libname$release$shared_ext$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$release$shared_ext $libname$shared_ext'
case $host_os in
irix5* | nonstopux*)
libsuff= shlibsuff=
@@ -2628,8 +2805,8 @@ irix5* | irix6* | nonstopux*)
esac
shlibpath_var=LD_LIBRARY${shlibsuff}_PATH
shlibpath_overrides_runpath=no
- sys_lib_search_path_spec="/usr/lib${libsuff} /lib${libsuff} /usr/local/lib${libsuff}"
- sys_lib_dlsearch_path_spec="/usr/lib${libsuff} /lib${libsuff}"
+ sys_lib_search_path_spec="/usr/lib$libsuff /lib$libsuff /usr/local/lib$libsuff"
+ sys_lib_dlsearch_path_spec="/usr/lib$libsuff /lib$libsuff"
hardcode_into_libs=yes
;;
@@ -2638,13 +2815,33 @@ linux*oldld* | linux*aout* | linux*coff*)
dynamic_linker=no
;;
+linux*android*)
+ version_type=none # Android doesn't support versioned libraries.
+ need_lib_prefix=no
+ need_version=no
+ library_names_spec='$libname$release$shared_ext'
+ soname_spec='$libname$release$shared_ext'
+ finish_cmds=
+ shlibpath_var=LD_LIBRARY_PATH
+ shlibpath_overrides_runpath=yes
+
+ # This implies no fast_install, which is unacceptable.
+ # Some rework will be needed to allow for fast_install
+ # before this can be enabled.
+ hardcode_into_libs=yes
+
+ dynamic_linker='Android linker'
+ # Don't embed -rpath directories since the linker doesn't support them.
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
+ ;;
+
# This must be glibc/ELF.
-linux* | k*bsd*-gnu | kopensolaris*-gnu)
+linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=no
@@ -2669,7 +2866,12 @@ linux* | k*bsd*-gnu | kopensolaris*-gnu)
# before this can be enabled.
hardcode_into_libs=yes
- # Append ld.so.conf contents to the search path
+ # Ideally, we could use ldconfig to report *all* directores which are
+ # searched for libraries, however this is still not possible. Aside from not
+ # being certain /sbin/ldconfig is available, command
+ # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64,
+ # even though it is searched at run-time. Try to do the best guess by
+ # appending ld.so.conf contents (and includes) to the search path.
if test -f /etc/ld.so.conf; then
lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \[$]2)); skip = 1; } { if (!skip) print \[$]0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '`
sys_lib_dlsearch_path_spec="/lib /usr/lib $lt_ld_extra"
@@ -2684,17 +2886,29 @@ linux* | k*bsd*-gnu | kopensolaris*-gnu)
dynamic_linker='GNU/Linux ld.so'
;;
+netbsdelf*-gnu)
+ version_type=linux
+ need_lib_prefix=no
+ need_version=no
+ library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}'
+ soname_spec='${libname}${release}${shared_ext}$major'
+ shlibpath_var=LD_LIBRARY_PATH
+ shlibpath_overrides_runpath=no
+ hardcode_into_libs=yes
+ dynamic_linker='NetBSD ld.elf_so'
+ ;;
+
netbsd*)
version_type=sunos
need_lib_prefix=no
need_version=no
if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix'
finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir'
dynamic_linker='NetBSD (a.out) ld.so'
else
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major ${libname}${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
dynamic_linker='NetBSD ld.elf_so'
fi
shlibpath_var=LD_LIBRARY_PATH
@@ -2704,7 +2918,7 @@ netbsd*)
newsos6)
version_type=linux # correct to gnu/linux during the next big refactor
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=yes
;;
@@ -2713,58 +2927,68 @@ newsos6)
version_type=qnx
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=no
hardcode_into_libs=yes
dynamic_linker='ldqnx.so'
;;
-openbsd*)
+openbsd* | bitrig*)
version_type=sunos
- sys_lib_dlsearch_path_spec="/usr/lib"
+ sys_lib_dlsearch_path_spec=/usr/lib
need_lib_prefix=no
- # Some older versions of OpenBSD (3.3 at least) *do* need versioned libs.
- case $host_os in
- openbsd3.3 | openbsd3.3.*) need_version=yes ;;
- *) need_version=no ;;
- esac
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
- finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir'
- shlibpath_var=LD_LIBRARY_PATH
- if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
- case $host_os in
- openbsd2.[[89]] | openbsd2.[[89]].*)
- shlibpath_overrides_runpath=no
- ;;
- *)
- shlibpath_overrides_runpath=yes
- ;;
- esac
+ if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then
+ need_version=no
else
- shlibpath_overrides_runpath=yes
+ need_version=yes
fi
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix'
+ finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir'
+ shlibpath_var=LD_LIBRARY_PATH
+ shlibpath_overrides_runpath=yes
;;
os2*)
libname_spec='$name'
- shrext_cmds=".dll"
+ version_type=windows
+ shrext_cmds=.dll
+ need_version=no
need_lib_prefix=no
- library_names_spec='$libname${shared_ext} $libname.a'
+ # OS/2 can only load a DLL with a base name of 8 characters or less.
+ soname_spec='`test -n "$os2dllname" && libname="$os2dllname";
+ v=$($ECHO $release$versuffix | tr -d .-);
+ n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _);
+ $ECHO $n$v`$shared_ext'
+ library_names_spec='${libname}_dll.$libext'
dynamic_linker='OS/2 ld.exe'
- shlibpath_var=LIBPATH
+ shlibpath_var=BEGINLIBPATH
+ sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib"
+ sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
+ postinstall_cmds='base_file=`basename \$file`~
+ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; $ECHO \$dlname'\''`~
+ dldir=$destdir/`dirname \$dlpath`~
+ test -d \$dldir || mkdir -p \$dldir~
+ $install_prog $dir/$dlname \$dldir/$dlname~
+ chmod a+x \$dldir/$dlname~
+ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then
+ eval '\''$striplib \$dldir/$dlname'\'' || exit \$?;
+ fi'
+ postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~
+ dlpath=$dir/\$dldll~
+ $RM \$dlpath'
;;
osf3* | osf4* | osf5*)
version_type=osf
need_lib_prefix=no
need_version=no
- soname_spec='${libname}${release}${shared_ext}$major'
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+ soname_spec='$libname$release$shared_ext$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
shlibpath_var=LD_LIBRARY_PATH
sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib"
- sys_lib_dlsearch_path_spec="$sys_lib_search_path_spec"
+ sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec
;;
rdos*)
@@ -2775,8 +2999,8 @@ solaris*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=yes
hardcode_into_libs=yes
@@ -2786,11 +3010,11 @@ solaris*)
sunos4*)
version_type=sunos
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${shared_ext}$versuffix'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix'
finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=yes
- if test "$with_gnu_ld" = yes; then
+ if test yes = "$with_gnu_ld"; then
need_lib_prefix=no
fi
need_version=yes
@@ -2798,8 +3022,8 @@ sunos4*)
sysv4 | sysv4.3*)
version_type=linux # correct to gnu/linux during the next big refactor
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
case $host_vendor in
sni)
@@ -2820,24 +3044,24 @@ sysv4 | sysv4.3*)
;;
sysv4*MP*)
- if test -d /usr/nec ;then
+ if test -d /usr/nec; then
version_type=linux # correct to gnu/linux during the next big refactor
- library_names_spec='$libname${shared_ext}.$versuffix $libname${shared_ext}.$major $libname${shared_ext}'
- soname_spec='$libname${shared_ext}.$major'
+ library_names_spec='$libname$shared_ext.$versuffix $libname$shared_ext.$major $libname$shared_ext'
+ soname_spec='$libname$shared_ext.$major'
shlibpath_var=LD_LIBRARY_PATH
fi
;;
sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*)
- version_type=freebsd-elf
+ version_type=sco
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext} $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=yes
hardcode_into_libs=yes
- if test "$with_gnu_ld" = yes; then
+ if test yes = "$with_gnu_ld"; then
sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib'
else
sys_lib_search_path_spec='/usr/ccs/lib /usr/lib'
@@ -2855,7 +3079,7 @@ tpf*)
version_type=linux # correct to gnu/linux during the next big refactor
need_lib_prefix=no
need_version=no
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
shlibpath_var=LD_LIBRARY_PATH
shlibpath_overrides_runpath=no
hardcode_into_libs=yes
@@ -2863,8 +3087,8 @@ tpf*)
uts4*)
version_type=linux # correct to gnu/linux during the next big refactor
- library_names_spec='${libname}${release}${shared_ext}$versuffix ${libname}${release}${shared_ext}$major $libname${shared_ext}'
- soname_spec='${libname}${release}${shared_ext}$major'
+ library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext'
+ soname_spec='$libname$release$shared_ext$major'
shlibpath_var=LD_LIBRARY_PATH
;;
@@ -2873,20 +3097,30 @@ uts4*)
;;
esac
AC_MSG_RESULT([$dynamic_linker])
-test "$dynamic_linker" = no && can_build_shared=no
+test no = "$dynamic_linker" && can_build_shared=no
variables_saved_for_relink="PATH $shlibpath_var $runpath_var"
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH"
fi
-if test "${lt_cv_sys_lib_search_path_spec+set}" = set; then
- sys_lib_search_path_spec="$lt_cv_sys_lib_search_path_spec"
+if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then
+ sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec
fi
-if test "${lt_cv_sys_lib_dlsearch_path_spec+set}" = set; then
- sys_lib_dlsearch_path_spec="$lt_cv_sys_lib_dlsearch_path_spec"
+
+if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then
+ sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec
fi
+# remember unaugmented sys_lib_dlsearch_path content for libtool script decls...
+configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec
+
+# ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code
+func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH"
+
+# to be used as default LT_SYS_LIBRARY_PATH value in generated libtool
+configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH
+
_LT_DECL([], [variables_saved_for_relink], [1],
[Variables whose values should be saved in libtool wrapper scripts and
restored at link time])
@@ -2919,39 +3153,41 @@ _LT_DECL([], [hardcode_into_libs], [0],
[Whether we should hardcode library paths into libraries])
_LT_DECL([], [sys_lib_search_path_spec], [2],
[Compile-time system search path for libraries])
-_LT_DECL([], [sys_lib_dlsearch_path_spec], [2],
- [Run-time system search path for libraries])
+_LT_DECL([sys_lib_dlsearch_path_spec], [configure_time_dlsearch_path], [2],
+ [Detected run-time system search path for libraries])
+_LT_DECL([], [configure_time_lt_sys_library_path], [2],
+ [Explicit LT_SYS_LIBRARY_PATH set during ./configure time])
])# _LT_SYS_DYNAMIC_LINKER
# _LT_PATH_TOOL_PREFIX(TOOL)
# --------------------------
-# find a file program which can recognize shared library
+# find a file program that can recognize shared library
AC_DEFUN([_LT_PATH_TOOL_PREFIX],
[m4_require([_LT_DECL_EGREP])dnl
AC_MSG_CHECKING([for $1])
AC_CACHE_VAL(lt_cv_path_MAGIC_CMD,
[case $MAGIC_CMD in
[[\\/*] | ?:[\\/]*])
- lt_cv_path_MAGIC_CMD="$MAGIC_CMD" # Let the user override the test with a path.
+ lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path.
;;
*)
- lt_save_MAGIC_CMD="$MAGIC_CMD"
- lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+ lt_save_MAGIC_CMD=$MAGIC_CMD
+ lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR
dnl $ac_dummy forces splitting on constant user-supplied paths.
dnl POSIX.2 word splitting is done only on the output of word expansions,
dnl not every word. This closes a longstanding sh security hole.
ac_dummy="m4_if([$2], , $PATH, [$2])"
for ac_dir in $ac_dummy; do
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
test -z "$ac_dir" && ac_dir=.
- if test -f $ac_dir/$1; then
- lt_cv_path_MAGIC_CMD="$ac_dir/$1"
+ if test -f "$ac_dir/$1"; then
+ lt_cv_path_MAGIC_CMD=$ac_dir/"$1"
if test -n "$file_magic_test_file"; then
case $deplibs_check_method in
"file_magic "*)
file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"`
- MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
+ MAGIC_CMD=$lt_cv_path_MAGIC_CMD
if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null |
$EGREP "$file_magic_regex" > /dev/null; then
:
@@ -2974,11 +3210,11 @@ _LT_EOF
break
fi
done
- IFS="$lt_save_ifs"
- MAGIC_CMD="$lt_save_MAGIC_CMD"
+ IFS=$lt_save_ifs
+ MAGIC_CMD=$lt_save_MAGIC_CMD
;;
esac])
-MAGIC_CMD="$lt_cv_path_MAGIC_CMD"
+MAGIC_CMD=$lt_cv_path_MAGIC_CMD
if test -n "$MAGIC_CMD"; then
AC_MSG_RESULT($MAGIC_CMD)
else
@@ -2996,7 +3232,7 @@ dnl AC_DEFUN([AC_PATH_TOOL_PREFIX], [])
# _LT_PATH_MAGIC
# --------------
-# find a file program which can recognize a shared library
+# find a file program that can recognize a shared library
m4_defun([_LT_PATH_MAGIC],
[_LT_PATH_TOOL_PREFIX(${ac_tool_prefix}file, /usr/bin$PATH_SEPARATOR$PATH)
if test -z "$lt_cv_path_MAGIC_CMD"; then
@@ -3023,16 +3259,16 @@ m4_require([_LT_PROG_ECHO_BACKSLASH])dnl
AC_ARG_WITH([gnu-ld],
[AS_HELP_STRING([--with-gnu-ld],
[assume the C compiler uses GNU ld @<:@default=no@:>@])],
- [test "$withval" = no || with_gnu_ld=yes],
+ [test no = "$withval" || with_gnu_ld=yes],
[with_gnu_ld=no])dnl
ac_prog=ld
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
# Check if gcc -print-prog-name=ld gives a path.
AC_MSG_CHECKING([for ld used by $CC])
case $host in
*-*-mingw*)
- # gcc leaves a trailing carriage return which upsets mingw
+ # gcc leaves a trailing carriage return, which upsets mingw
ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;;
*)
ac_prog=`($CC -print-prog-name=ld) 2>&5` ;;
@@ -3046,7 +3282,7 @@ if test "$GCC" = yes; then
while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do
ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"`
done
- test -z "$LD" && LD="$ac_prog"
+ test -z "$LD" && LD=$ac_prog
;;
"")
# If it fails, then pretend we aren't using GCC.
@@ -3057,37 +3293,37 @@ if test "$GCC" = yes; then
with_gnu_ld=unknown
;;
esac
-elif test "$with_gnu_ld" = yes; then
+elif test yes = "$with_gnu_ld"; then
AC_MSG_CHECKING([for GNU ld])
else
AC_MSG_CHECKING([for non-GNU ld])
fi
AC_CACHE_VAL(lt_cv_path_LD,
[if test -z "$LD"; then
- lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+ lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR
for ac_dir in $PATH; do
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
test -z "$ac_dir" && ac_dir=.
if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then
- lt_cv_path_LD="$ac_dir/$ac_prog"
+ lt_cv_path_LD=$ac_dir/$ac_prog
# Check to see if the program is GNU ld. I'd rather use --version,
# but apparently some variants of GNU ld only accept -v.
# Break only if it was the GNU/non-GNU ld that we prefer.
case `"$lt_cv_path_LD" -v 2>&1 </dev/null` in
*GNU* | *'with BFD'*)
- test "$with_gnu_ld" != no && break
+ test no != "$with_gnu_ld" && break
;;
*)
- test "$with_gnu_ld" != yes && break
+ test yes != "$with_gnu_ld" && break
;;
esac
fi
done
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
else
- lt_cv_path_LD="$LD" # Let the user override the test with a path.
+ lt_cv_path_LD=$LD # Let the user override the test with a path.
fi])
-LD="$lt_cv_path_LD"
+LD=$lt_cv_path_LD
if test -n "$LD"; then
AC_MSG_RESULT($LD)
else
@@ -3141,13 +3377,13 @@ esac
reload_cmds='$LD$reload_flag -o $output$reload_objs'
case $host_os in
cygwin* | mingw* | pw32* | cegcc*)
- if test "$GCC" != yes; then
+ if test yes != "$GCC"; then
reload_cmds=false
fi
;;
darwin*)
- if test "$GCC" = yes; then
- reload_cmds='$LTCC $LTCFLAGS -nostdlib ${wl}-r -o $output$reload_objs'
+ if test yes = "$GCC"; then
+ reload_cmds='$LTCC $LTCFLAGS -nostdlib $wl-r -o $output$reload_objs'
else
reload_cmds='$LD$reload_flag -o $output$reload_objs'
fi
@@ -3158,6 +3394,43 @@ _LT_TAGDECL([], [reload_cmds], [2])dnl
])# _LT_CMD_RELOAD
+# _LT_PATH_DD
+# -----------
+# find a working dd
+m4_defun([_LT_PATH_DD],
+[AC_CACHE_CHECK([for a working dd], [ac_cv_path_lt_DD],
+[printf 0123456789abcdef0123456789abcdef >conftest.i
+cat conftest.i conftest.i >conftest2.i
+: ${lt_DD:=$DD}
+AC_PATH_PROGS_FEATURE_CHECK([lt_DD], [dd],
+[if "$ac_path_lt_DD" bs=32 count=1 <conftest2.i >conftest.out 2>/dev/null; then
+ cmp -s conftest.i conftest.out \
+ && ac_cv_path_lt_DD="$ac_path_lt_DD" ac_path_lt_DD_found=:
+fi])
+rm -f conftest.i conftest2.i conftest.out])
+])# _LT_PATH_DD
+
+
+# _LT_CMD_TRUNCATE
+# ----------------
+# find command to truncate a binary pipe
+m4_defun([_LT_CMD_TRUNCATE],
+[m4_require([_LT_PATH_DD])
+AC_CACHE_CHECK([how to truncate binary pipes], [lt_cv_truncate_bin],
+[printf 0123456789abcdef0123456789abcdef >conftest.i
+cat conftest.i conftest.i >conftest2.i
+lt_cv_truncate_bin=
+if "$ac_cv_path_lt_DD" bs=32 count=1 <conftest2.i >conftest.out 2>/dev/null; then
+ cmp -s conftest.i conftest.out \
+ && lt_cv_truncate_bin="$ac_cv_path_lt_DD bs=4096 count=1"
+fi
+rm -f conftest.i conftest2.i conftest.out
+test -z "$lt_cv_truncate_bin" && lt_cv_truncate_bin="$SED -e 4q"])
+_LT_DECL([lt_truncate_bin], [lt_cv_truncate_bin], [1],
+ [Command to truncate a binary pipe])
+])# _LT_CMD_TRUNCATE
+
+
# _LT_CHECK_MAGIC_METHOD
# ----------------------
# how to check for library dependencies
@@ -3173,13 +3446,13 @@ lt_cv_deplibs_check_method='unknown'
# Need to set the preceding variable on all platforms that support
# interlibrary dependencies.
# 'none' -- dependencies not supported.
-# `unknown' -- same as none, but documents that we really don't know.
+# 'unknown' -- same as none, but documents that we really don't know.
# 'pass_all' -- all dependencies passed with no checks.
# 'test_compile' -- check by making test program.
# 'file_magic [[regex]]' -- check by looking for files in library path
-# which responds to the $file_magic_cmd with a given extended regex.
-# If you have `file' or equivalent on your system and you're not sure
-# whether `pass_all' will *always* work, you probably want this one.
+# that responds to the $file_magic_cmd with a given extended regex.
+# If you have 'file' or equivalent on your system and you're not sure
+# whether 'pass_all' will *always* work, you probably want this one.
case $host_os in
aix[[4-9]]*)
@@ -3206,8 +3479,7 @@ mingw* | pw32*)
# Base MSYS/MinGW do not provide the 'file' command needed by
# func_win32_libid shell function, so use a weaker test based on 'objdump',
# unless we find 'file', for example because we are cross-compiling.
- # func_win32_libid assumes BSD nm, so disallow it if using MS dumpbin.
- if ( test "$lt_cv_nm_interface" = "BSD nm" && file / ) >/dev/null 2>&1; then
+ if ( file / ) >/dev/null 2>&1; then
lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL'
lt_cv_file_magic_cmd='func_win32_libid'
else
@@ -3243,10 +3515,6 @@ freebsd* | dragonfly*)
fi
;;
-gnu*)
- lt_cv_deplibs_check_method=pass_all
- ;;
-
haiku*)
lt_cv_deplibs_check_method=pass_all
;;
@@ -3285,11 +3553,11 @@ irix5* | irix6* | nonstopux*)
;;
# This must be glibc/ELF.
-linux* | k*bsd*-gnu | kopensolaris*-gnu)
+linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
lt_cv_deplibs_check_method=pass_all
;;
-netbsd*)
+netbsd* | netbsdelf*-gnu)
if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then
lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$'
else
@@ -3307,8 +3575,8 @@ newos6*)
lt_cv_deplibs_check_method=pass_all
;;
-openbsd*)
- if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
+openbsd* | bitrig*)
+ if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then
lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|\.so|_pic\.a)$'
else
lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$'
@@ -3361,6 +3629,9 @@ sysv4 | sysv4.3*)
tpf*)
lt_cv_deplibs_check_method=pass_all
;;
+os2*)
+ lt_cv_deplibs_check_method=pass_all
+ ;;
esac
])
@@ -3401,33 +3672,38 @@ AC_DEFUN([LT_PATH_NM],
AC_CACHE_CHECK([for BSD- or MS-compatible name lister (nm)], lt_cv_path_NM,
[if test -n "$NM"; then
# Let the user override the test.
- lt_cv_path_NM="$NM"
+ lt_cv_path_NM=$NM
else
- lt_nm_to_check="${ac_tool_prefix}nm"
+ lt_nm_to_check=${ac_tool_prefix}nm
if test -n "$ac_tool_prefix" && test "$build" = "$host"; then
lt_nm_to_check="$lt_nm_to_check nm"
fi
for lt_tmp_nm in $lt_nm_to_check; do
- lt_save_ifs="$IFS"; IFS=$PATH_SEPARATOR
+ lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR
for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
test -z "$ac_dir" && ac_dir=.
- tmp_nm="$ac_dir/$lt_tmp_nm"
- if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext" ; then
+ tmp_nm=$ac_dir/$lt_tmp_nm
+ if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext"; then
# Check to see if the nm accepts a BSD-compat flag.
- # Adding the `sed 1q' prevents false positives on HP-UX, which says:
+ # Adding the 'sed 1q' prevents false positives on HP-UX, which says:
# nm: unknown option "B" ignored
# Tru64's nm complains that /dev/null is an invalid object file
- case `"$tmp_nm" -B /dev/null 2>&1 | sed '1q'` in
- */dev/null* | *'Invalid file or object type'*)
+ # MSYS converts /dev/null to NUL, MinGW nm treats NUL as empty
+ case $build_os in
+ mingw*) lt_bad_file=conftest.nm/nofile ;;
+ *) lt_bad_file=/dev/null ;;
+ esac
+ case `"$tmp_nm" -B $lt_bad_file 2>&1 | sed '1q'` in
+ *$lt_bad_file* | *'Invalid file or object type'*)
lt_cv_path_NM="$tmp_nm -B"
- break
+ break 2
;;
*)
case `"$tmp_nm" -p /dev/null 2>&1 | sed '1q'` in
*/dev/null*)
lt_cv_path_NM="$tmp_nm -p"
- break
+ break 2
;;
*)
lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but
@@ -3438,21 +3714,21 @@ else
esac
fi
done
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
done
: ${lt_cv_path_NM=no}
fi])
-if test "$lt_cv_path_NM" != "no"; then
- NM="$lt_cv_path_NM"
+if test no != "$lt_cv_path_NM"; then
+ NM=$lt_cv_path_NM
else
# Didn't find any BSD compatible name lister, look for dumpbin.
if test -n "$DUMPBIN"; then :
# Let the user override the test.
else
AC_CHECK_TOOLS(DUMPBIN, [dumpbin "link -dump"], :)
- case `$DUMPBIN -symbols /dev/null 2>&1 | sed '1q'` in
+ case `$DUMPBIN -symbols -headers /dev/null 2>&1 | sed '1q'` in
*COFF*)
- DUMPBIN="$DUMPBIN -symbols"
+ DUMPBIN="$DUMPBIN -symbols -headers"
;;
*)
DUMPBIN=:
@@ -3460,8 +3736,8 @@ else
esac
fi
AC_SUBST([DUMPBIN])
- if test "$DUMPBIN" != ":"; then
- NM="$DUMPBIN"
+ if test : != "$DUMPBIN"; then
+ NM=$DUMPBIN
fi
fi
test -z "$NM" && NM=nm
@@ -3507,8 +3783,8 @@ lt_cv_sharedlib_from_linklib_cmd,
case $host_os in
cygwin* | mingw* | pw32* | cegcc*)
- # two different shell functions defined in ltmain.sh
- # decide which to use based on capabilities of $DLLTOOL
+ # two different shell functions defined in ltmain.sh;
+ # decide which one to use based on capabilities of $DLLTOOL
case `$DLLTOOL --help 2>&1` in
*--identify-strict*)
lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib
@@ -3520,7 +3796,7 @@ cygwin* | mingw* | pw32* | cegcc*)
;;
*)
# fallback: assume linklib IS sharedlib
- lt_cv_sharedlib_from_linklib_cmd="$ECHO"
+ lt_cv_sharedlib_from_linklib_cmd=$ECHO
;;
esac
])
@@ -3547,13 +3823,28 @@ AC_CACHE_CHECK([if $MANIFEST_TOOL is a manifest tool], [lt_cv_path_mainfest_tool
lt_cv_path_mainfest_tool=yes
fi
rm -f conftest*])
-if test "x$lt_cv_path_mainfest_tool" != xyes; then
+if test yes != "$lt_cv_path_mainfest_tool"; then
MANIFEST_TOOL=:
fi
_LT_DECL([], [MANIFEST_TOOL], [1], [Manifest tool])dnl
])# _LT_PATH_MANIFEST_TOOL
+# _LT_DLL_DEF_P([FILE])
+# ---------------------
+# True iff FILE is a Windows DLL '.def' file.
+# Keep in sync with func_dll_def_p in the libtool script
+AC_DEFUN([_LT_DLL_DEF_P],
+[dnl
+ test DEF = "`$SED -n dnl
+ -e '\''s/^[[ ]]*//'\'' dnl Strip leading whitespace
+ -e '\''/^\(;.*\)*$/d'\'' dnl Delete empty lines and comments
+ -e '\''s/^\(EXPORTS\|LIBRARY\)\([[ ]].*\)*$/DEF/p'\'' dnl
+ -e q dnl Only consider the first "real" line
+ $1`" dnl
+])# _LT_DLL_DEF_P
+
+
# LT_LIB_M
# --------
# check for math library
@@ -3565,11 +3856,11 @@ case $host in
# These system don't have libm, or don't need it
;;
*-ncr-sysv4.3*)
- AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM="-lmw")
+ AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM=-lmw)
AC_CHECK_LIB(m, cos, LIBM="$LIBM -lm")
;;
*)
- AC_CHECK_LIB(m, cos, LIBM="-lm")
+ AC_CHECK_LIB(m, cos, LIBM=-lm)
;;
esac
AC_SUBST([LIBM])
@@ -3588,7 +3879,7 @@ m4_defun([_LT_COMPILER_NO_RTTI],
_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=
-if test "$GCC" = yes; then
+if test yes = "$GCC"; then
case $cc_basename in
nvcc*)
_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -Xcompiler -fno-builtin' ;;
@@ -3640,7 +3931,7 @@ cygwin* | mingw* | pw32* | cegcc*)
symcode='[[ABCDGISTW]]'
;;
hpux*)
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
symcode='[[ABCDEGRST]]'
fi
;;
@@ -3673,14 +3964,44 @@ case `$NM -V 2>&1` in
symcode='[[ABCDGIRSTW]]' ;;
esac
+if test "$lt_cv_nm_interface" = "MS dumpbin"; then
+ # Gets list of data symbols to import.
+ lt_cv_sys_global_symbol_to_import="sed -n -e 's/^I .* \(.*\)$/\1/p'"
+ # Adjust the below global symbol transforms to fixup imported variables.
+ lt_cdecl_hook=" -e 's/^I .* \(.*\)$/extern __declspec(dllimport) char \1;/p'"
+ lt_c_name_hook=" -e 's/^I .* \(.*\)$/ {\"\1\", (void *) 0},/p'"
+ lt_c_name_lib_hook="\
+ -e 's/^I .* \(lib.*\)$/ {\"\1\", (void *) 0},/p'\
+ -e 's/^I .* \(.*\)$/ {\"lib\1\", (void *) 0},/p'"
+else
+ # Disable hooks by default.
+ lt_cv_sys_global_symbol_to_import=
+ lt_cdecl_hook=
+ lt_c_name_hook=
+ lt_c_name_lib_hook=
+fi
+
# Transform an extracted symbol line into a proper C declaration.
# Some systems (esp. on ia64) link data and code symbols differently,
# so use this general approach.
-lt_cv_sys_global_symbol_to_cdecl="sed -n -e 's/^T .* \(.*\)$/extern int \1();/p' -e 's/^$symcode* .* \(.*\)$/extern char \1;/p'"
+lt_cv_sys_global_symbol_to_cdecl="sed -n"\
+$lt_cdecl_hook\
+" -e 's/^T .* \(.*\)$/extern int \1();/p'"\
+" -e 's/^$symcode$symcode* .* \(.*\)$/extern char \1;/p'"
# Transform an extracted symbol line into symbol name and symbol address
-lt_cv_sys_global_symbol_to_c_name_address="sed -n -e 's/^: \([[^ ]]*\)[[ ]]*$/ {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([[^ ]]*\) \([[^ ]]*\)$/ {\"\2\", (void *) \&\2},/p'"
-lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n -e 's/^: \([[^ ]]*\)[[ ]]*$/ {\\\"\1\\\", (void *) 0},/p' -e 's/^$symcode* \([[^ ]]*\) \(lib[[^ ]]*\)$/ {\"\2\", (void *) \&\2},/p' -e 's/^$symcode* \([[^ ]]*\) \([[^ ]]*\)$/ {\"lib\2\", (void *) \&\2},/p'"
+lt_cv_sys_global_symbol_to_c_name_address="sed -n"\
+$lt_c_name_hook\
+" -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\
+" -e 's/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/p'"
+
+# Transform an extracted symbol line into symbol name with lib prefix and
+# symbol address.
+lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="sed -n"\
+$lt_c_name_lib_hook\
+" -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\
+" -e 's/^$symcode$symcode* .* \(lib.*\)$/ {\"\1\", (void *) \&\1},/p'"\
+" -e 's/^$symcode$symcode* .* \(.*\)$/ {\"lib\1\", (void *) \&\1},/p'"
# Handle CRLF in mingw tool chain
opt_cr=
@@ -3698,21 +4019,24 @@ for ac_symprfx in "" "_"; do
# Write the raw and C identifiers.
if test "$lt_cv_nm_interface" = "MS dumpbin"; then
- # Fake it for dumpbin and say T for any non-static function
- # and D for any global variable.
+ # Fake it for dumpbin and say T for any non-static function,
+ # D for any global variable and I for any imported variable.
# Also find C++ and __fastcall symbols from MSVC++,
# which start with @ or ?.
lt_cv_sys_global_symbol_pipe="$AWK ['"\
" {last_section=section; section=\$ 3};"\
" /^COFF SYMBOL TABLE/{for(i in hide) delete hide[i]};"\
" /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\
+" /^ *Symbol name *: /{split(\$ 0,sn,\":\"); si=substr(sn[2],2)};"\
+" /^ *Type *: code/{print \"T\",si,substr(si,length(prfx))};"\
+" /^ *Type *: data/{print \"I\",si,substr(si,length(prfx))};"\
" \$ 0!~/External *\|/{next};"\
" / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\
" {if(hide[section]) next};"\
-" {f=0}; \$ 0~/\(\).*\|/{f=1}; {printf f ? \"T \" : \"D \"};"\
-" {split(\$ 0, a, /\||\r/); split(a[2], s)};"\
-" s[1]~/^[@?]/{print s[1], s[1]; next};"\
-" s[1]~prfx {split(s[1],t,\"@\"); print t[1], substr(t[1],length(prfx))}"\
+" {f=\"D\"}; \$ 0~/\(\).*\|/{f=\"T\"};"\
+" {split(\$ 0,a,/\||\r/); split(a[2],s)};"\
+" s[1]~/^[@?]/{print f,s[1],s[1]; next};"\
+" s[1]~prfx {split(s[1],t,\"@\"); print f,t[1],substr(t[1],length(prfx))}"\
" ' prfx=^$ac_symprfx]"
else
lt_cv_sys_global_symbol_pipe="sed -n -e 's/^.*[[ ]]\($symcode$symcode*\)[[ ]][[ ]]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'"
@@ -3752,11 +4076,11 @@ _LT_EOF
if $GREP ' nm_test_func$' "$nlist" >/dev/null; then
cat <<_LT_EOF > conftest.$ac_ext
/* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */
-#if defined(_WIN32) || defined(__CYGWIN__) || defined(_WIN32_WCE)
-/* DATA imports from DLLs on WIN32 con't be const, because runtime
+#if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE
+/* DATA imports from DLLs on WIN32 can't be const, because runtime
relocations are performed -- see ld's documentation on pseudo-relocs. */
# define LT@&t@_DLSYM_CONST
-#elif defined(__osf__)
+#elif defined __osf__
/* This system does not cope well with relocations in const data. */
# define LT@&t@_DLSYM_CONST
#else
@@ -3782,7 +4106,7 @@ lt__PROGRAM__LTX_preloaded_symbols[[]] =
{
{ "@PROGRAM@", (void *) 0 },
_LT_EOF
- $SED "s/^$symcode$symcode* \(.*\) \(.*\)$/ {\"\2\", (void *) \&\2},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext
+ $SED "s/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext
cat <<\_LT_EOF >> conftest.$ac_ext
{0, (void *) 0}
};
@@ -3802,9 +4126,9 @@ _LT_EOF
mv conftest.$ac_objext conftstm.$ac_objext
lt_globsym_save_LIBS=$LIBS
lt_globsym_save_CFLAGS=$CFLAGS
- LIBS="conftstm.$ac_objext"
+ LIBS=conftstm.$ac_objext
CFLAGS="$CFLAGS$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)"
- if AC_TRY_EVAL(ac_link) && test -s conftest${ac_exeext}; then
+ if AC_TRY_EVAL(ac_link) && test -s conftest$ac_exeext; then
pipe_works=yes
fi
LIBS=$lt_globsym_save_LIBS
@@ -3825,7 +4149,7 @@ _LT_EOF
rm -rf conftest* conftst*
# Do not use the global_symbol_pipe unless it works.
- if test "$pipe_works" = yes; then
+ if test yes = "$pipe_works"; then
break
else
lt_cv_sys_global_symbol_pipe=
@@ -3852,12 +4176,16 @@ _LT_DECL([global_symbol_pipe], [lt_cv_sys_global_symbol_pipe], [1],
[Take the output of nm and produce a listing of raw symbols and C names])
_LT_DECL([global_symbol_to_cdecl], [lt_cv_sys_global_symbol_to_cdecl], [1],
[Transform the output of nm in a proper C declaration])
+_LT_DECL([global_symbol_to_import], [lt_cv_sys_global_symbol_to_import], [1],
+ [Transform the output of nm into a list of symbols to manually relocate])
_LT_DECL([global_symbol_to_c_name_address],
[lt_cv_sys_global_symbol_to_c_name_address], [1],
[Transform the output of nm in a C name address pair])
_LT_DECL([global_symbol_to_c_name_address_lib_prefix],
[lt_cv_sys_global_symbol_to_c_name_address_lib_prefix], [1],
[Transform the output of nm in a C name address pair when lib prefix is needed])
+_LT_DECL([nm_interface], [lt_cv_nm_interface], [1],
+ [The name lister interface])
_LT_DECL([], [nm_file_list_spec], [1],
[Specify filename containing input files for $NM])
]) # _LT_CMD_GLOBAL_SYMBOLS
@@ -3873,17 +4201,18 @@ _LT_TAGVAR(lt_prog_compiler_static, $1)=
m4_if([$1], [CXX], [
# C++ specific cases for pic, static, wl, etc.
- if test "$GXX" = yes; then
+ if test yes = "$GXX"; then
_LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
_LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
case $host_os in
aix*)
# All AIX code is PIC.
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# AIX 5 now supports IA64 processor
_LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
fi
+ _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
;;
amigaos*)
@@ -3894,8 +4223,8 @@ m4_if([$1], [CXX], [
;;
m68k)
# FIXME: we need at least 68020 code to build shared libraries, but
- # adding the `-m68020' flag to GCC prevents building anything better,
- # like `-m68040'.
+ # adding the '-m68020' flag to GCC prevents building anything better,
+ # like '-m68040'.
_LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4'
;;
esac
@@ -3911,6 +4240,11 @@ m4_if([$1], [CXX], [
# (--disable-auto-import) libraries
m4_if([$1], [GCJ], [],
[_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT'])
+ case $host_os in
+ os2*)
+ _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static'
+ ;;
+ esac
;;
darwin* | rhapsody*)
# PIC is the default on this platform
@@ -3960,7 +4294,7 @@ m4_if([$1], [CXX], [
case $host_os in
aix[[4-9]]*)
# All AIX code is PIC.
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# AIX 5 now supports IA64 processor
_LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
else
@@ -4001,14 +4335,14 @@ m4_if([$1], [CXX], [
case $cc_basename in
CC*)
_LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
- _LT_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive'
- if test "$host_cpu" != ia64; then
+ _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive'
+ if test ia64 != "$host_cpu"; then
_LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z'
fi
;;
aCC*)
_LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
- _LT_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive'
+ _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive'
case $host_cpu in
hppa*64*|ia64*)
# +Z the default
@@ -4037,7 +4371,7 @@ m4_if([$1], [CXX], [
;;
esac
;;
- linux* | k*bsd*-gnu | kopensolaris*-gnu)
+ linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
case $cc_basename in
KCC*)
# KAI C++ Compiler
@@ -4045,7 +4379,7 @@ m4_if([$1], [CXX], [
_LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
;;
ecpc* )
- # old Intel C++ for x86_64 which still supported -KPIC.
+ # old Intel C++ for x86_64, which still supported -KPIC.
_LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
_LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
_LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
@@ -4101,7 +4435,7 @@ m4_if([$1], [CXX], [
;;
esac
;;
- netbsd*)
+ netbsd* | netbsdelf*-gnu)
;;
*qnx* | *nto*)
# QNX uses GNU C++, but need to define -shared option too, otherwise
@@ -4190,17 +4524,18 @@ m4_if([$1], [CXX], [
fi
],
[
- if test "$GCC" = yes; then
+ if test yes = "$GCC"; then
_LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
_LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
case $host_os in
aix*)
# All AIX code is PIC.
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# AIX 5 now supports IA64 processor
_LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
fi
+ _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
;;
amigaos*)
@@ -4211,8 +4546,8 @@ m4_if([$1], [CXX], [
;;
m68k)
# FIXME: we need at least 68020 code to build shared libraries, but
- # adding the `-m68020' flag to GCC prevents building anything better,
- # like `-m68040'.
+ # adding the '-m68020' flag to GCC prevents building anything better,
+ # like '-m68040'.
_LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4'
;;
esac
@@ -4229,6 +4564,11 @@ m4_if([$1], [CXX], [
# (--disable-auto-import) libraries
m4_if([$1], [GCJ], [],
[_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT'])
+ case $host_os in
+ os2*)
+ _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static'
+ ;;
+ esac
;;
darwin* | rhapsody*)
@@ -4299,7 +4639,7 @@ m4_if([$1], [CXX], [
case $host_os in
aix*)
_LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# AIX 5 now supports IA64 processor
_LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
else
@@ -4307,11 +4647,30 @@ m4_if([$1], [CXX], [
fi
;;
+ darwin* | rhapsody*)
+ # PIC is the default on this platform
+ # Common symbols not allowed in MH_DYLIB files
+ _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common'
+ case $cc_basename in
+ nagfor*)
+ # NAG Fortran compiler
+ _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,-Wl,,'
+ _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC'
+ _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
+ ;;
+ esac
+ ;;
+
mingw* | cygwin* | pw32* | os2* | cegcc*)
# This hack is so that the source file can tell whether it is being
# built for inclusion in a dll (and should export symbols for example).
m4_if([$1], [GCJ], [],
[_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT'])
+ case $host_os in
+ os2*)
+ _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static'
+ ;;
+ esac
;;
hpux9* | hpux10* | hpux11*)
@@ -4327,7 +4686,7 @@ m4_if([$1], [CXX], [
;;
esac
# Is there a better lt_prog_compiler_static that works with the bundled CC?
- _LT_TAGVAR(lt_prog_compiler_static, $1)='${wl}-a ${wl}archive'
+ _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive'
;;
irix5* | irix6* | nonstopux*)
@@ -4336,9 +4695,9 @@ m4_if([$1], [CXX], [
_LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared'
;;
- linux* | k*bsd*-gnu | kopensolaris*-gnu)
+ linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
case $cc_basename in
- # old Intel for x86_64 which still supported -KPIC.
+ # old Intel for x86_64, which still supported -KPIC.
ecc*)
_LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
_LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC'
@@ -4363,6 +4722,12 @@ m4_if([$1], [CXX], [
_LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC'
_LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
;;
+ tcc*)
+ # Fabrice Bellard et al's Tiny C Compiler
+ _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,'
+ _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC'
+ _LT_TAGVAR(lt_prog_compiler_static, $1)='-static'
+ ;;
pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*)
# Portland Group compilers (*not* the Pentium gcc compiler,
# which looks to be a dead project)
@@ -4460,7 +4825,7 @@ m4_if([$1], [CXX], [
;;
sysv4*MP*)
- if test -d /usr/nec ;then
+ if test -d /usr/nec; then
_LT_TAGVAR(lt_prog_compiler_pic, $1)='-Kconform_pic'
_LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic'
fi
@@ -4489,7 +4854,7 @@ m4_if([$1], [CXX], [
fi
])
case $host_os in
- # For platforms which do not support PIC, -DPIC is meaningless:
+ # For platforms that do not support PIC, -DPIC is meaningless:
*djgpp*)
_LT_TAGVAR(lt_prog_compiler_pic, $1)=
;;
@@ -4555,17 +4920,21 @@ m4_if([$1], [CXX], [
case $host_os in
aix[[4-9]]*)
# If we're using GNU nm, then we don't want the "-C" option.
- # -C means demangle to AIX nm, but means don't demangle with GNU nm
- # Also, AIX nm treats weak defined symbols like other global defined
- # symbols, whereas GNU nm marks them as "W".
+ # -C means demangle to GNU nm, but means don't demangle to AIX nm.
+ # Without the "-l" option, or with the "-B" option, AIX nm treats
+ # weak defined symbols like other global defined symbols, whereas
+ # GNU nm marks them as "W".
+ # While the 'weak' keyword is ignored in the Export File, we need
+ # it in the Import File for the 'aix-soname' feature, so we have
+ # to replace the "-B" option with "-P" for AIX nm.
if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then
- _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+ _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols'
else
- _LT_TAGVAR(export_symbols_cmds, $1)='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+ _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\([[^B]]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && ([substr](\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols'
fi
;;
pw32*)
- _LT_TAGVAR(export_symbols_cmds, $1)="$ltdll_cmds"
+ _LT_TAGVAR(export_symbols_cmds, $1)=$ltdll_cmds
;;
cygwin* | mingw* | cegcc*)
case $cc_basename in
@@ -4578,6 +4947,9 @@ m4_if([$1], [CXX], [
;;
esac
;;
+ linux* | k*bsd*-gnu | gnu*)
+ _LT_TAGVAR(link_all_deplibs, $1)=no
+ ;;
*)
_LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols'
;;
@@ -4611,9 +4983,9 @@ m4_if([$1], [CXX], [
# included in the symbol list
_LT_TAGVAR(include_expsyms, $1)=
# exclude_expsyms can be an extended regexp of symbols to exclude
- # it will be wrapped by ` (' and `)$', so one must not match beginning or
- # end of line. Example: `a|bc|.*d.*' will exclude the symbols `a' and `bc',
- # as well as any symbol that contains `d'.
+ # it will be wrapped by ' (' and ')$', so one must not match beginning or
+ # end of line. Example: 'a|bc|.*d.*' will exclude the symbols 'a' and 'bc',
+ # as well as any symbol that contains 'd'.
_LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*']
# Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out
# platforms (ab)use it in PIC code, but their linkers get confused if
@@ -4629,7 +5001,7 @@ dnl Note also adjust exclude_expsyms for C++ above.
# FIXME: the MSVC++ port hasn't been tested in a loooong time
# When not using gcc, we currently assume that we are using
# Microsoft Visual C++.
- if test "$GCC" != yes; then
+ if test yes != "$GCC"; then
with_gnu_ld=no
fi
;;
@@ -4637,9 +5009,12 @@ dnl Note also adjust exclude_expsyms for C++ above.
# we just hope/assume this is gcc and not c89 (= MSVC++)
with_gnu_ld=yes
;;
- openbsd*)
+ openbsd* | bitrig*)
with_gnu_ld=no
;;
+ linux* | k*bsd*-gnu | gnu*)
+ _LT_TAGVAR(link_all_deplibs, $1)=no
+ ;;
esac
_LT_TAGVAR(ld_shlibs, $1)=yes
@@ -4647,7 +5022,7 @@ dnl Note also adjust exclude_expsyms for C++ above.
# On some targets, GNU ld is compatible enough with the native linker
# that we're better off using the native interface for both.
lt_use_gnu_ld_interface=no
- if test "$with_gnu_ld" = yes; then
+ if test yes = "$with_gnu_ld"; then
case $host_os in
aix*)
# The AIX port of GNU ld has always aspired to compatibility
@@ -4669,24 +5044,24 @@ dnl Note also adjust exclude_expsyms for C++ above.
esac
fi
- if test "$lt_use_gnu_ld_interface" = yes; then
+ if test yes = "$lt_use_gnu_ld_interface"; then
# If archive_cmds runs LD, not CC, wlarc should be empty
- wlarc='${wl}'
+ wlarc='$wl'
# Set some defaults for GNU ld with shared library support. These
# are reset later if shared libraries are not supported. Putting them
# here allows them to be overridden if necessary.
runpath_var=LD_RUN_PATH
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic'
# ancient GNU ld didn't support --whole-archive et. al.
if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then
- _LT_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive'
+ _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive'
else
_LT_TAGVAR(whole_archive_flag_spec, $1)=
fi
supports_anon_versioning=no
- case `$LD -v 2>&1` in
+ case `$LD -v | $SED -e 's/([^)]\+)\s\+//' 2>&1` in
*GNU\ gold*) supports_anon_versioning=yes ;;
*\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.10.*) ;; # catch versions < 2.11
*\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ...
@@ -4699,7 +5074,7 @@ dnl Note also adjust exclude_expsyms for C++ above.
case $host_os in
aix[[3-9]]*)
# On AIX/PPC, the GNU linker is very broken
- if test "$host_cpu" != ia64; then
+ if test ia64 != "$host_cpu"; then
_LT_TAGVAR(ld_shlibs, $1)=no
cat <<_LT_EOF 1>&2
@@ -4718,7 +5093,7 @@ _LT_EOF
case $host_cpu in
powerpc)
# see comment about AmigaOS4 .so support
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
_LT_TAGVAR(archive_expsym_cmds, $1)=''
;;
m68k)
@@ -4734,7 +5109,7 @@ _LT_EOF
_LT_TAGVAR(allow_undefined_flag, $1)=unsupported
# Joseph Beckenbach <jrb3@best.com> says some releases of gcc
# support --undefined. This deserves some investigation. FIXME
- _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
else
_LT_TAGVAR(ld_shlibs, $1)=no
fi
@@ -4744,7 +5119,7 @@ _LT_EOF
# _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless,
# as there is no search path for DLLs.
_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-all-symbols'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-all-symbols'
_LT_TAGVAR(allow_undefined_flag, $1)=unsupported
_LT_TAGVAR(always_export_symbols, $1)=no
_LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
@@ -4752,61 +5127,89 @@ _LT_EOF
_LT_TAGVAR(exclude_expsyms, $1)=['[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname']
if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
- # If the export-symbols file already is a .def file (1st line
- # is EXPORTS), use it as is; otherwise, prepend...
- _LT_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then
- cp $export_symbols $output_objdir/$soname.def;
- else
- echo EXPORTS > $output_objdir/$soname.def;
- cat $export_symbols >> $output_objdir/$soname.def;
- fi~
- $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+ # If the export-symbols file already is a .def file, use it as
+ # is; otherwise, prepend EXPORTS...
+ _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then
+ cp $export_symbols $output_objdir/$soname.def;
+ else
+ echo EXPORTS > $output_objdir/$soname.def;
+ cat $export_symbols >> $output_objdir/$soname.def;
+ fi~
+ $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
else
_LT_TAGVAR(ld_shlibs, $1)=no
fi
;;
haiku*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
_LT_TAGVAR(link_all_deplibs, $1)=yes
;;
+ os2*)
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
+ _LT_TAGVAR(hardcode_minus_L, $1)=yes
+ _LT_TAGVAR(allow_undefined_flag, $1)=unsupported
+ shrext_cmds=.dll
+ _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+ $ECHO EXPORTS >> $output_objdir/$libname.def~
+ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~
+ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+ emximp -o $lib $output_objdir/$libname.def'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+ $ECHO EXPORTS >> $output_objdir/$libname.def~
+ prefix_cmds="$SED"~
+ if test EXPORTS = "`$SED 1q $export_symbols`"; then
+ prefix_cmds="$prefix_cmds -e 1d";
+ fi~
+ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~
+ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~
+ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+ emximp -o $lib $output_objdir/$libname.def'
+ _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def'
+ _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
+ ;;
+
interix[[3-9]]*)
_LT_TAGVAR(hardcode_direct, $1)=no
_LT_TAGVAR(hardcode_shlibpath_var, $1)=no
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E'
# Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc.
# Instead, shared libraries are loaded at an image base (0x10000000 by
# default) and relocated if they conflict, which is a slow very memory
# consuming and fragmenting process. To avoid this, we pick a random,
# 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link
# time. Moving up from 0x10000000 also allows more sbrk(2) space.
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
- _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
;;
gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu)
tmp_diet=no
- if test "$host_os" = linux-dietlibc; then
+ if test linux-dietlibc = "$host_os"; then
case $cc_basename in
diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn)
esac
fi
if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \
- && test "$tmp_diet" = no
+ && test no = "$tmp_diet"
then
tmp_addflag=' $pic_flag'
tmp_sharedflag='-shared'
case $cc_basename,$host_cpu in
pgcc*) # Portland Group C compiler
- _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+ _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
tmp_addflag=' $pic_flag'
;;
pgf77* | pgf90* | pgf95* | pgfortran*)
# Portland Group f77 and f90 compilers
- _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+ _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
tmp_addflag=' $pic_flag -Mnomain' ;;
ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64
tmp_addflag=' -i_dynamic' ;;
@@ -4817,42 +5220,47 @@ _LT_EOF
lf95*) # Lahey Fortran 8.1
_LT_TAGVAR(whole_archive_flag_spec, $1)=
tmp_sharedflag='--shared' ;;
+ nagfor*) # NAGFOR 5.3
+ tmp_sharedflag='-Wl,-shared' ;;
xl[[cC]]* | bgxl[[cC]]* | mpixl[[cC]]*) # IBM XL C 8.0 on PPC (deal with xlf below)
tmp_sharedflag='-qmkshrobj'
tmp_addflag= ;;
nvcc*) # Cuda Compiler Driver 2.2
- _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+ _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
_LT_TAGVAR(compiler_needs_object, $1)=yes
;;
esac
case `$CC -V 2>&1 | sed 5q` in
*Sun\ C*) # Sun C 5.9
- _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+ _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
_LT_TAGVAR(compiler_needs_object, $1)=yes
tmp_sharedflag='-G' ;;
*Sun\ F*) # Sun Fortran 8.3
tmp_sharedflag='-G' ;;
esac
- _LT_TAGVAR(archive_cmds, $1)='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
- if test "x$supports_anon_versioning" = xyes; then
+ if test yes = "$supports_anon_versioning"; then
_LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~
- cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
- echo "local: *; };" >> $output_objdir/$libname.ver~
- $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib'
+ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
+ echo "local: *; };" >> $output_objdir/$libname.ver~
+ $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib'
fi
case $cc_basename in
+ tcc*)
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='-rdynamic'
+ ;;
xlf* | bgf* | bgxlf* | mpixlf*)
# IBM XL Fortran 10.1 on PPC cannot create shared libs itself
_LT_TAGVAR(whole_archive_flag_spec, $1)='--whole-archive$convenience --no-whole-archive'
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
_LT_TAGVAR(archive_cmds, $1)='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib'
- if test "x$supports_anon_versioning" = xyes; then
+ if test yes = "$supports_anon_versioning"; then
_LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~
- cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
- echo "local: *; };" >> $output_objdir/$libname.ver~
- $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib'
+ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
+ echo "local: *; };" >> $output_objdir/$libname.ver~
+ $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib'
fi
;;
esac
@@ -4861,13 +5269,13 @@ _LT_EOF
fi
;;
- netbsd*)
+ netbsd* | netbsdelf*-gnu)
if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then
_LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib'
wlarc=
else
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
fi
;;
@@ -4885,8 +5293,8 @@ _LT_EOF
_LT_EOF
elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
else
_LT_TAGVAR(ld_shlibs, $1)=no
fi
@@ -4898,7 +5306,7 @@ _LT_EOF
_LT_TAGVAR(ld_shlibs, $1)=no
cat <<_LT_EOF 1>&2
-*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 can not
+*** Warning: Releases of the GNU linker prior to 2.16.91.0.3 cannot
*** reliably create shared libraries on SCO systems. Therefore, libtool
*** is disabling shared libraries support. We urge you to upgrade GNU
*** binutils to release 2.16.91.0.3 or newer. Another option is to modify
@@ -4913,9 +5321,9 @@ _LT_EOF
# DT_RUNPATH tag from executables and libraries. But doing so
# requires that you compile everything twice, which is a pain.
if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
else
_LT_TAGVAR(ld_shlibs, $1)=no
fi
@@ -4932,15 +5340,15 @@ _LT_EOF
*)
if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
else
_LT_TAGVAR(ld_shlibs, $1)=no
fi
;;
esac
- if test "$_LT_TAGVAR(ld_shlibs, $1)" = no; then
+ if test no = "$_LT_TAGVAR(ld_shlibs, $1)"; then
runpath_var=
_LT_TAGVAR(hardcode_libdir_flag_spec, $1)=
_LT_TAGVAR(export_dynamic_flag_spec, $1)=
@@ -4956,7 +5364,7 @@ _LT_EOF
# Note: this linker hardcodes the directories in LIBPATH if there
# are no directories specified by -L.
_LT_TAGVAR(hardcode_minus_L, $1)=yes
- if test "$GCC" = yes && test -z "$lt_prog_compiler_static"; then
+ if test yes = "$GCC" && test -z "$lt_prog_compiler_static"; then
# Neither direct hardcoding nor static linking is supported with a
# broken collect2.
_LT_TAGVAR(hardcode_direct, $1)=unsupported
@@ -4964,34 +5372,57 @@ _LT_EOF
;;
aix[[4-9]]*)
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# On IA64, the linker does run time linking by default, so we don't
# have to do anything special.
aix_use_runtimelinking=no
exp_sym_flag='-Bexport'
- no_entry_flag=""
+ no_entry_flag=
else
# If we're using GNU nm, then we don't want the "-C" option.
- # -C means demangle to AIX nm, but means don't demangle with GNU nm
- # Also, AIX nm treats weak defined symbols like other global
- # defined symbols, whereas GNU nm marks them as "W".
+ # -C means demangle to GNU nm, but means don't demangle to AIX nm.
+ # Without the "-l" option, or with the "-B" option, AIX nm treats
+ # weak defined symbols like other global defined symbols, whereas
+ # GNU nm marks them as "W".
+ # While the 'weak' keyword is ignored in the Export File, we need
+ # it in the Import File for the 'aix-soname' feature, so we have
+ # to replace the "-B" option with "-P" for AIX nm.
if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then
- _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+ _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols'
else
- _LT_TAGVAR(export_symbols_cmds, $1)='$NM -BCpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B")) && ([substr](\$ 3,1,1) != ".")) { print \$ 3 } }'\'' | sort -u > $export_symbols'
+ _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\([[^B]]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && ([substr](\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols'
fi
aix_use_runtimelinking=no
# Test if we are trying to use run time linking or normal
# AIX style linking. If -brtl is somewhere in LDFLAGS, we
- # need to do runtime linking.
+ # have runtime linking enabled, and use it for executables.
+ # For shared libraries, we enable/disable runtime linking
+ # depending on the kind of the shared library created -
+ # when "with_aix_soname,aix_use_runtimelinking" is:
+ # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables
+ # "aix,yes" lib.so shared, rtl:yes, for executables
+ # lib.a static archive
+ # "both,no" lib.so.V(shr.o) shared, rtl:yes
+ # lib.a(lib.so.V) shared, rtl:no, for executables
+ # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables
+ # lib.a(lib.so.V) shared, rtl:no
+ # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables
+ # lib.a static archive
case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*)
for ld_flag in $LDFLAGS; do
- if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then
+ if (test x-brtl = "x$ld_flag" || test x-Wl,-brtl = "x$ld_flag"); then
aix_use_runtimelinking=yes
break
fi
done
+ if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then
+ # With aix-soname=svr4, we create the lib.so.V shared archives only,
+ # so we don't have lib.a shared libs to link our executables.
+ # We have to force runtime linking in this case.
+ aix_use_runtimelinking=yes
+ LDFLAGS="$LDFLAGS -Wl,-brtl"
+ fi
;;
esac
@@ -5010,13 +5441,21 @@ _LT_EOF
_LT_TAGVAR(hardcode_direct_absolute, $1)=yes
_LT_TAGVAR(hardcode_libdir_separator, $1)=':'
_LT_TAGVAR(link_all_deplibs, $1)=yes
- _LT_TAGVAR(file_list_spec, $1)='${wl}-f,'
+ _LT_TAGVAR(file_list_spec, $1)='$wl-f,'
+ case $with_aix_soname,$aix_use_runtimelinking in
+ aix,*) ;; # traditional, no import file
+ svr4,* | *,yes) # use import file
+ # The Import File defines what to hardcode.
+ _LT_TAGVAR(hardcode_direct, $1)=no
+ _LT_TAGVAR(hardcode_direct_absolute, $1)=no
+ ;;
+ esac
- if test "$GCC" = yes; then
+ if test yes = "$GCC"; then
case $host_os in aix4.[[012]]|aix4.[[012]].*)
# We only want to do this on AIX 4.2 and lower, the check
# below for broken collect2 doesn't work under 4.3+
- collect2name=`${CC} -print-prog-name=collect2`
+ collect2name=`$CC -print-prog-name=collect2`
if test -f "$collect2name" &&
strings "$collect2name" | $GREP resolve_lib_name >/dev/null
then
@@ -5035,61 +5474,80 @@ _LT_EOF
;;
esac
shared_flag='-shared'
- if test "$aix_use_runtimelinking" = yes; then
- shared_flag="$shared_flag "'${wl}-G'
+ if test yes = "$aix_use_runtimelinking"; then
+ shared_flag="$shared_flag "'$wl-G'
fi
+ # Need to ensure runtime linking is disabled for the traditional
+ # shared library, or the linker may eventually find shared libraries
+ # /with/ Import File - we do not want to mix them.
+ shared_flag_aix='-shared'
+ shared_flag_svr4='-shared $wl-G'
else
# not using gcc
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release
# chokes on -Wl,-G. The following line is correct:
shared_flag='-G'
else
- if test "$aix_use_runtimelinking" = yes; then
- shared_flag='${wl}-G'
+ if test yes = "$aix_use_runtimelinking"; then
+ shared_flag='$wl-G'
else
- shared_flag='${wl}-bM:SRE'
+ shared_flag='$wl-bM:SRE'
fi
+ shared_flag_aix='$wl-bM:SRE'
+ shared_flag_svr4='$wl-G'
fi
fi
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-bexpall'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-bexpall'
# It seems that -bexpall does not export symbols beginning with
# underscore (_), so it is better to generate a list of symbols to export.
_LT_TAGVAR(always_export_symbols, $1)=yes
- if test "$aix_use_runtimelinking" = yes; then
+ if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then
# Warning - without using the other runtime loading flags (-brtl),
# -berok will link without error, but may produce a broken library.
_LT_TAGVAR(allow_undefined_flag, $1)='-berok'
# Determine the default libpath from the value encoded in an
# empty executable.
_LT_SYS_MODULE_PATH_AIX([$1])
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath"
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then func_echo_all "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag"
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath"
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag
else
- if test "$host_cpu" = ia64; then
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $libdir:/usr/lib:/lib'
+ if test ia64 = "$host_cpu"; then
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $libdir:/usr/lib:/lib'
_LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs"
- _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols"
+ _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols"
else
# Determine the default libpath from the value encoded in an
# empty executable.
_LT_SYS_MODULE_PATH_AIX([$1])
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath"
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath"
# Warning - without using the other run time loading flags,
# -berok will link without error, but may produce a broken library.
- _LT_TAGVAR(no_undefined_flag, $1)=' ${wl}-bernotok'
- _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-berok'
- if test "$with_gnu_ld" = yes; then
+ _LT_TAGVAR(no_undefined_flag, $1)=' $wl-bernotok'
+ _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-berok'
+ if test yes = "$with_gnu_ld"; then
# We only use this code for GNU lds that support --whole-archive.
- _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive$convenience ${wl}--no-whole-archive'
+ _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive'
else
# Exported symbols can be pulled into shared objects from archives
_LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience'
fi
_LT_TAGVAR(archive_cmds_need_lc, $1)=yes
- # This is similar to how AIX traditionally builds its shared libraries.
- _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d'
+ # -brtl affects multiple linker settings, -berok does not and is overridden later
+ compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([[, ]]\\)%-berok\\1%g"`'
+ if test svr4 != "$with_aix_soname"; then
+ # This is similar to how AIX traditionally builds its shared libraries.
+ _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname'
+ fi
+ if test aix != "$with_aix_soname"; then
+ _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp'
+ else
+ # used by -dlpreopen to get the symbols
+ _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV $output_objdir/$realname.d/$soname $output_objdir'
+ fi
+ _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d'
fi
fi
;;
@@ -5098,7 +5556,7 @@ _LT_EOF
case $host_cpu in
powerpc)
# see comment about AmigaOS4 .so support
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
_LT_TAGVAR(archive_expsym_cmds, $1)=''
;;
m68k)
@@ -5128,16 +5586,17 @@ _LT_EOF
# Tell ltmain to make .lib files, not .a files.
libext=lib
# Tell ltmain to make .dll files, not .so files.
- shrext_cmds=".dll"
+ shrext_cmds=.dll
# FIXME: Setting linknames here is a bad hack.
- _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-dll~linknames='
- _LT_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then
- sed -n -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' -e '1\\\!p' < $export_symbols > $output_objdir/$soname.exp;
- else
- sed -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' < $export_symbols > $output_objdir/$soname.exp;
- fi~
- $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~
- linknames='
+ _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames='
+ _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then
+ cp "$export_symbols" "$output_objdir/$soname.def";
+ echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp";
+ else
+ $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp;
+ fi~
+ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~
+ linknames='
# The linker will not automatically build a static lib if we build a DLL.
# _LT_TAGVAR(old_archive_from_new_cmds, $1)='true'
_LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
@@ -5146,18 +5605,18 @@ _LT_EOF
# Don't use ranlib
_LT_TAGVAR(old_postinstall_cmds, $1)='chmod 644 $oldlib'
_LT_TAGVAR(postlink_cmds, $1)='lt_outputfile="@OUTPUT@"~
- lt_tool_outputfile="@TOOL_OUTPUT@"~
- case $lt_outputfile in
- *.exe|*.EXE) ;;
- *)
- lt_outputfile="$lt_outputfile.exe"
- lt_tool_outputfile="$lt_tool_outputfile.exe"
- ;;
- esac~
- if test "$MANIFEST_TOOL" != ":" && test -f "$lt_outputfile.manifest"; then
- $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1;
- $RM "$lt_outputfile.manifest";
- fi'
+ lt_tool_outputfile="@TOOL_OUTPUT@"~
+ case $lt_outputfile in
+ *.exe|*.EXE) ;;
+ *)
+ lt_outputfile=$lt_outputfile.exe
+ lt_tool_outputfile=$lt_tool_outputfile.exe
+ ;;
+ esac~
+ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then
+ $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1;
+ $RM "$lt_outputfile.manifest";
+ fi'
;;
*)
# Assume MSVC wrapper
@@ -5166,7 +5625,7 @@ _LT_EOF
# Tell ltmain to make .lib files, not .a files.
libext=lib
# Tell ltmain to make .dll files, not .so files.
- shrext_cmds=".dll"
+ shrext_cmds=.dll
# FIXME: Setting linknames here is a bad hack.
_LT_TAGVAR(archive_cmds, $1)='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames='
# The linker will automatically build a .lib file if we build a DLL.
@@ -5216,33 +5675,33 @@ _LT_EOF
;;
hpux9*)
- if test "$GCC" = yes; then
- _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared $pic_flag ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
+ if test yes = "$GCC"; then
+ _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib'
else
- _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib'
fi
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir'
_LT_TAGVAR(hardcode_libdir_separator, $1)=:
_LT_TAGVAR(hardcode_direct, $1)=yes
# hardcode_minus_L: Not really in the search PATH,
# but as the default location of the library.
_LT_TAGVAR(hardcode_minus_L, $1)=yes
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E'
;;
hpux10*)
- if test "$GCC" = yes && test "$with_gnu_ld" = no; then
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
+ if test yes,no = "$GCC,$with_gnu_ld"; then
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
else
_LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'
fi
- if test "$with_gnu_ld" = no; then
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
+ if test no = "$with_gnu_ld"; then
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir'
_LT_TAGVAR(hardcode_libdir_separator, $1)=:
_LT_TAGVAR(hardcode_direct, $1)=yes
_LT_TAGVAR(hardcode_direct_absolute, $1)=yes
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E'
# hardcode_minus_L: Not really in the search PATH,
# but as the default location of the library.
_LT_TAGVAR(hardcode_minus_L, $1)=yes
@@ -5250,25 +5709,25 @@ _LT_EOF
;;
hpux11*)
- if test "$GCC" = yes && test "$with_gnu_ld" = no; then
+ if test yes,no = "$GCC,$with_gnu_ld"; then
case $host_cpu in
hppa*64*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags'
;;
ia64*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
;;
*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'
;;
esac
else
case $host_cpu in
hppa*64*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags'
;;
ia64*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags'
;;
*)
m4_if($1, [], [
@@ -5276,14 +5735,14 @@ _LT_EOF
# (HP92453-01 A.11.01.20 doesn't, HP92453-01 B.11.X.35175-35176.GP does)
_LT_LINKER_OPTION([if $CC understands -b],
_LT_TAGVAR(lt_cv_prog_compiler__b, $1), [-b],
- [_LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'],
+ [_LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'],
[_LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'])],
- [_LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $libobjs $deplibs $compiler_flags'])
+ [_LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'])
;;
esac
fi
- if test "$with_gnu_ld" = no; then
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
+ if test no = "$with_gnu_ld"; then
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir'
_LT_TAGVAR(hardcode_libdir_separator, $1)=:
case $host_cpu in
@@ -5294,7 +5753,7 @@ _LT_EOF
*)
_LT_TAGVAR(hardcode_direct, $1)=yes
_LT_TAGVAR(hardcode_direct_absolute, $1)=yes
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E'
# hardcode_minus_L: Not really in the search PATH,
# but as the default location of the library.
@@ -5305,16 +5764,16 @@ _LT_EOF
;;
irix5* | irix6* | nonstopux*)
- if test "$GCC" = yes; then
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+ if test yes = "$GCC"; then
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
# Try to use the -exported_symbol ld option, if it does not
# work, assume that -exports_file does not work either and
# implicitly export all symbols.
# This should be the same for all languages, so no per-tag cache variable.
AC_CACHE_CHECK([whether the $host_os linker accepts -exported_symbol],
[lt_cv_irix_exported_symbol],
- [save_LDFLAGS="$LDFLAGS"
- LDFLAGS="$LDFLAGS -shared ${wl}-exported_symbol ${wl}foo ${wl}-update_registry ${wl}/dev/null"
+ [save_LDFLAGS=$LDFLAGS
+ LDFLAGS="$LDFLAGS -shared $wl-exported_symbol ${wl}foo $wl-update_registry $wl/dev/null"
AC_LINK_IFELSE(
[AC_LANG_SOURCE(
[AC_LANG_CASE([C], [[int foo (void) { return 0; }]],
@@ -5327,22 +5786,33 @@ _LT_EOF
end]])])],
[lt_cv_irix_exported_symbol=yes],
[lt_cv_irix_exported_symbol=no])
- LDFLAGS="$save_LDFLAGS"])
- if test "$lt_cv_irix_exported_symbol" = yes; then
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations ${wl}-exports_file ${wl}$export_symbols -o $lib'
+ LDFLAGS=$save_LDFLAGS])
+ if test yes = "$lt_cv_irix_exported_symbol"; then
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations $wl-exports_file $wl$export_symbols -o $lib'
fi
+ _LT_TAGVAR(link_all_deplibs, $1)=no
else
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -exports_file $export_symbols -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -exports_file $export_symbols -o $lib'
fi
_LT_TAGVAR(archive_cmds_need_lc, $1)='no'
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
_LT_TAGVAR(hardcode_libdir_separator, $1)=:
_LT_TAGVAR(inherit_rpath, $1)=yes
_LT_TAGVAR(link_all_deplibs, $1)=yes
;;
- netbsd*)
+ linux*)
+ case $cc_basename in
+ tcc*)
+ # Fabrice Bellard et al's Tiny C Compiler
+ _LT_TAGVAR(ld_shlibs, $1)=yes
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
+ ;;
+ esac
+ ;;
+
+ netbsd* | netbsdelf*-gnu)
if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then
_LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out
else
@@ -5356,7 +5826,7 @@ _LT_EOF
newsos6)
_LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags'
_LT_TAGVAR(hardcode_direct, $1)=yes
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
_LT_TAGVAR(hardcode_libdir_separator, $1)=:
_LT_TAGVAR(hardcode_shlibpath_var, $1)=no
;;
@@ -5364,27 +5834,19 @@ _LT_EOF
*nto* | *qnx*)
;;
- openbsd*)
+ openbsd* | bitrig*)
if test -f /usr/libexec/ld.so; then
_LT_TAGVAR(hardcode_direct, $1)=yes
_LT_TAGVAR(hardcode_shlibpath_var, $1)=no
_LT_TAGVAR(hardcode_direct_absolute, $1)=yes
- if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
+ if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then
_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags ${wl}-retain-symbols-file,$export_symbols'
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags $wl-retain-symbols-file,$export_symbols'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E'
else
- case $host_os in
- openbsd[[01]].* | openbsd2.[[0-7]] | openbsd2.[[0-7]].*)
- _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags'
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
- ;;
- *)
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
- ;;
- esac
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir'
fi
else
_LT_TAGVAR(ld_shlibs, $1)=no
@@ -5395,33 +5857,53 @@ _LT_EOF
_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
_LT_TAGVAR(hardcode_minus_L, $1)=yes
_LT_TAGVAR(allow_undefined_flag, $1)=unsupported
- _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY $libname INITINSTANCE" > $output_objdir/$libname.def~$ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~echo DATA >> $output_objdir/$libname.def~echo " SINGLE NONSHARED" >> $output_objdir/$libname.def~echo EXPORTS >> $output_objdir/$libname.def~emxexp $libobjs >> $output_objdir/$libname.def~$CC -Zdll -Zcrtdll -o $lib $libobjs $deplibs $compiler_flags $output_objdir/$libname.def'
- _LT_TAGVAR(old_archive_from_new_cmds, $1)='emximp -o $output_objdir/$libname.a $output_objdir/$libname.def'
+ shrext_cmds=.dll
+ _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+ $ECHO EXPORTS >> $output_objdir/$libname.def~
+ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~
+ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+ emximp -o $lib $output_objdir/$libname.def'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+ $ECHO EXPORTS >> $output_objdir/$libname.def~
+ prefix_cmds="$SED"~
+ if test EXPORTS = "`$SED 1q $export_symbols`"; then
+ prefix_cmds="$prefix_cmds -e 1d";
+ fi~
+ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~
+ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~
+ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+ emximp -o $lib $output_objdir/$libname.def'
+ _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def'
+ _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
;;
osf3*)
- if test "$GCC" = yes; then
- _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+ if test yes = "$GCC"; then
+ _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
else
_LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*'
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
fi
_LT_TAGVAR(archive_cmds_need_lc, $1)='no'
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
_LT_TAGVAR(hardcode_libdir_separator, $1)=:
;;
osf4* | osf5*) # as osf3* with the addition of -msym flag
- if test "$GCC" = yes; then
- _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $pic_flag $libobjs $deplibs $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+ if test yes = "$GCC"; then
+ _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $pic_flag $libobjs $deplibs $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
else
_LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*'
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
_LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~
- $CC -shared${allow_undefined_flag} ${wl}-input ${wl}$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib~$RM $lib.exp'
+ $CC -shared$allow_undefined_flag $wl-input $wl$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~$RM $lib.exp'
# Both c and cxx compiler support -rpath directly
_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir'
@@ -5432,24 +5914,24 @@ _LT_EOF
solaris*)
_LT_TAGVAR(no_undefined_flag, $1)=' -z defs'
- if test "$GCC" = yes; then
- wlarc='${wl}'
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag ${wl}-z ${wl}text ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags'
+ if test yes = "$GCC"; then
+ wlarc='$wl'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl-z ${wl}text $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags'
_LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
- $CC -shared $pic_flag ${wl}-z ${wl}text ${wl}-M ${wl}$lib.exp ${wl}-h ${wl}$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
+ $CC -shared $pic_flag $wl-z ${wl}text $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
else
case `$CC -V 2>&1` in
*"Compilers 5.0"*)
wlarc=''
- _LT_TAGVAR(archive_cmds, $1)='$LD -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $linker_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$LD -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $linker_flags'
_LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
- $LD -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp'
+ $LD -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp'
;;
*)
- wlarc='${wl}'
- _LT_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -h $soname -o $lib $libobjs $deplibs $compiler_flags'
+ wlarc='$wl'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $compiler_flags'
_LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
- $CC -G${allow_undefined_flag} -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
+ $CC -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp'
;;
esac
fi
@@ -5459,11 +5941,11 @@ _LT_EOF
solaris2.[[0-5]] | solaris2.[[0-5]].*) ;;
*)
# The compiler driver will combine and reorder linker options,
- # but understands `-z linker_flag'. GCC discards it without `$wl',
+ # but understands '-z linker_flag'. GCC discards it without '$wl',
# but is careful enough not to reorder.
# Supported since Solaris 2.6 (maybe 2.5.1?)
- if test "$GCC" = yes; then
- _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract'
+ if test yes = "$GCC"; then
+ _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract'
else
_LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract'
fi
@@ -5473,10 +5955,10 @@ _LT_EOF
;;
sunos4*)
- if test "x$host_vendor" = xsequent; then
+ if test sequent = "$host_vendor"; then
# Use $CC to link under sequent, because it throws in some extra .o
# files that make .init and .fini sections work.
- _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h $soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h $soname -o $lib $libobjs $deplibs $compiler_flags'
else
_LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags'
fi
@@ -5525,43 +6007,43 @@ _LT_EOF
;;
sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*)
- _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text'
+ _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text'
_LT_TAGVAR(archive_cmds_need_lc, $1)=no
_LT_TAGVAR(hardcode_shlibpath_var, $1)=no
runpath_var='LD_RUN_PATH'
- if test "$GCC" = yes; then
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ if test yes = "$GCC"; then
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
else
- _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
fi
;;
sysv5* | sco3.2v5* | sco5v6*)
- # Note: We can NOT use -z defs as we might desire, because we do not
+ # Note: We CANNOT use -z defs as we might desire, because we do not
# link with -lc, and that would cause any symbols used from libc to
# always be unresolved, which means just about no library would
# ever link correctly. If we're not using GNU ld we use -z text
# though, which does catch some bad symbols but isn't as heavy-handed
# as -z defs.
- _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text'
- _LT_TAGVAR(allow_undefined_flag, $1)='${wl}-z,nodefs'
+ _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text'
+ _LT_TAGVAR(allow_undefined_flag, $1)='$wl-z,nodefs'
_LT_TAGVAR(archive_cmds_need_lc, $1)=no
_LT_TAGVAR(hardcode_shlibpath_var, $1)=no
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R,$libdir'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R,$libdir'
_LT_TAGVAR(hardcode_libdir_separator, $1)=':'
_LT_TAGVAR(link_all_deplibs, $1)=yes
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Bexport'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Bexport'
runpath_var='LD_RUN_PATH'
- if test "$GCC" = yes; then
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ if test yes = "$GCC"; then
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
else
- _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
fi
;;
@@ -5576,17 +6058,17 @@ _LT_EOF
;;
esac
- if test x$host_vendor = xsni; then
+ if test sni = "$host_vendor"; then
case $host in
sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*)
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Blargedynsym'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Blargedynsym'
;;
esac
fi
fi
])
AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)])
-test "$_LT_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no
+test no = "$_LT_TAGVAR(ld_shlibs, $1)" && can_build_shared=no
_LT_TAGVAR(with_gnu_ld, $1)=$with_gnu_ld
@@ -5603,7 +6085,7 @@ x|xyes)
# Assume -lc should be added
_LT_TAGVAR(archive_cmds_need_lc, $1)=yes
- if test "$enable_shared" = yes && test "$GCC" = yes; then
+ if test yes,yes = "$GCC,$enable_shared"; then
case $_LT_TAGVAR(archive_cmds, $1) in
*'~'*)
# FIXME: we may have to deal with multi-command sequences.
@@ -5683,12 +6165,12 @@ _LT_TAGDECL([], [hardcode_libdir_flag_spec], [1],
_LT_TAGDECL([], [hardcode_libdir_separator], [1],
[Whether we need a single "-rpath" flag with a separated argument])
_LT_TAGDECL([], [hardcode_direct], [0],
- [Set to "yes" if using DIR/libNAME${shared_ext} during linking hardcodes
+ [Set to "yes" if using DIR/libNAME$shared_ext during linking hardcodes
DIR into the resulting binary])
_LT_TAGDECL([], [hardcode_direct_absolute], [0],
- [Set to "yes" if using DIR/libNAME${shared_ext} during linking hardcodes
+ [Set to "yes" if using DIR/libNAME$shared_ext during linking hardcodes
DIR into the resulting binary and the resulting library dependency is
- "absolute", i.e impossible to change by setting ${shlibpath_var} if the
+ "absolute", i.e impossible to change by setting $shlibpath_var if the
library is relocated])
_LT_TAGDECL([], [hardcode_minus_L], [0],
[Set to "yes" if using the -LDIR flag during linking hardcodes DIR
@@ -5729,10 +6211,10 @@ dnl [Compiler flag to generate thread safe objects])
# ------------------------
# Ensure that the configuration variables for a C compiler are suitably
# defined. These variables are subsequently used by _LT_CONFIG to write
-# the compiler configuration to `libtool'.
+# the compiler configuration to 'libtool'.
m4_defun([_LT_LANG_C_CONFIG],
[m4_require([_LT_DECL_EGREP])dnl
-lt_save_CC="$CC"
+lt_save_CC=$CC
AC_LANG_PUSH(C)
# Source file extension for C test sources.
@@ -5772,18 +6254,18 @@ if test -n "$compiler"; then
LT_SYS_DLOPEN_SELF
_LT_CMD_STRIPLIB
- # Report which library types will actually be built
+ # Report what library types will actually be built
AC_MSG_CHECKING([if libtool supports shared libraries])
AC_MSG_RESULT([$can_build_shared])
AC_MSG_CHECKING([whether to build shared libraries])
- test "$can_build_shared" = "no" && enable_shared=no
+ test no = "$can_build_shared" && enable_shared=no
# On AIX, shared libraries and static libraries use the same namespace, and
# are all built from PIC.
case $host_os in
aix3*)
- test "$enable_shared" = yes && enable_static=no
+ test yes = "$enable_shared" && enable_static=no
if test -n "$RANLIB"; then
archive_cmds="$archive_cmds~\$RANLIB \$lib"
postinstall_cmds='$RANLIB $lib'
@@ -5791,8 +6273,12 @@ if test -n "$compiler"; then
;;
aix[[4-9]]*)
- if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then
- test "$enable_shared" = yes && enable_static=no
+ if test ia64 != "$host_cpu"; then
+ case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in
+ yes,aix,yes) ;; # shared object as lib.so file only
+ yes,svr4,*) ;; # shared object as lib.so archive member only
+ yes,*) enable_static=no ;; # shared object in lib.a archive as well
+ esac
fi
;;
esac
@@ -5800,13 +6286,13 @@ if test -n "$compiler"; then
AC_MSG_CHECKING([whether to build static libraries])
# Make sure either enable_shared or enable_static is yes.
- test "$enable_shared" = yes || enable_static=yes
+ test yes = "$enable_shared" || enable_static=yes
AC_MSG_RESULT([$enable_static])
_LT_CONFIG($1)
fi
AC_LANG_POP
-CC="$lt_save_CC"
+CC=$lt_save_CC
])# _LT_LANG_C_CONFIG
@@ -5814,14 +6300,14 @@ CC="$lt_save_CC"
# --------------------------
# Ensure that the configuration variables for a C++ compiler are suitably
# defined. These variables are subsequently used by _LT_CONFIG to write
-# the compiler configuration to `libtool'.
+# the compiler configuration to 'libtool'.
m4_defun([_LT_LANG_CXX_CONFIG],
[m4_require([_LT_FILEUTILS_DEFAULTS])dnl
m4_require([_LT_DECL_EGREP])dnl
m4_require([_LT_PATH_MANIFEST_TOOL])dnl
-if test -n "$CXX" && ( test "X$CXX" != "Xno" &&
- ( (test "X$CXX" = "Xg++" && `g++ -v >/dev/null 2>&1` ) ||
- (test "X$CXX" != "Xg++"))) ; then
+if test -n "$CXX" && ( test no != "$CXX" &&
+ ( (test g++ = "$CXX" && `g++ -v >/dev/null 2>&1` ) ||
+ (test g++ != "$CXX"))); then
AC_PROG_CXXCPP
else
_lt_caught_CXX_error=yes
@@ -5863,7 +6349,7 @@ _LT_TAGVAR(objext, $1)=$objext
# the CXX compiler isn't working. Some variables (like enable_shared)
# are currently assumed to apply to all compilers on this platform,
# and will be corrupted by setting them based on a non-working compiler.
-if test "$_lt_caught_CXX_error" != yes; then
+if test yes != "$_lt_caught_CXX_error"; then
# Code to be used in simple compile tests
lt_simple_compile_test_code="int some_variable = 0;"
@@ -5905,35 +6391,35 @@ if test "$_lt_caught_CXX_error" != yes; then
if test -n "$compiler"; then
# We don't want -fno-exception when compiling C++ code, so set the
# no_builtin_flag separately
- if test "$GXX" = yes; then
+ if test yes = "$GXX"; then
_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin'
else
_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=
fi
- if test "$GXX" = yes; then
+ if test yes = "$GXX"; then
# Set up default GNU C++ configuration
LT_PATH_LD
# Check if GNU C++ uses GNU ld as the underlying linker, since the
# archiving commands below assume that GNU ld is being used.
- if test "$with_gnu_ld" = yes; then
- _LT_TAGVAR(archive_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+ if test yes = "$with_gnu_ld"; then
+ _LT_TAGVAR(archive_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic'
# If archive_cmds runs LD, not CC, wlarc should be empty
# XXX I think wlarc can be eliminated in ltcf-cxx, but I need to
# investigate it a little bit more. (MM)
- wlarc='${wl}'
+ wlarc='$wl'
# ancient GNU ld didn't support --whole-archive et. al.
if eval "`$CC -print-prog-name=ld` --help 2>&1" |
$GREP 'no-whole-archive' > /dev/null; then
- _LT_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive'
+ _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive'
else
_LT_TAGVAR(whole_archive_flag_spec, $1)=
fi
@@ -5969,18 +6455,30 @@ if test "$_lt_caught_CXX_error" != yes; then
_LT_TAGVAR(ld_shlibs, $1)=no
;;
aix[[4-9]]*)
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# On IA64, the linker does run time linking by default, so we don't
# have to do anything special.
aix_use_runtimelinking=no
exp_sym_flag='-Bexport'
- no_entry_flag=""
+ no_entry_flag=
else
aix_use_runtimelinking=no
# Test if we are trying to use run time linking or normal
# AIX style linking. If -brtl is somewhere in LDFLAGS, we
- # need to do runtime linking.
+ # have runtime linking enabled, and use it for executables.
+ # For shared libraries, we enable/disable runtime linking
+ # depending on the kind of the shared library created -
+ # when "with_aix_soname,aix_use_runtimelinking" is:
+ # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables
+ # "aix,yes" lib.so shared, rtl:yes, for executables
+ # lib.a static archive
+ # "both,no" lib.so.V(shr.o) shared, rtl:yes
+ # lib.a(lib.so.V) shared, rtl:no, for executables
+ # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables
+ # lib.a(lib.so.V) shared, rtl:no
+ # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables
+ # lib.a static archive
case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*)
for ld_flag in $LDFLAGS; do
case $ld_flag in
@@ -5990,6 +6488,13 @@ if test "$_lt_caught_CXX_error" != yes; then
;;
esac
done
+ if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then
+ # With aix-soname=svr4, we create the lib.so.V shared archives only,
+ # so we don't have lib.a shared libs to link our executables.
+ # We have to force runtime linking in this case.
+ aix_use_runtimelinking=yes
+ LDFLAGS="$LDFLAGS -Wl,-brtl"
+ fi
;;
esac
@@ -6008,13 +6513,21 @@ if test "$_lt_caught_CXX_error" != yes; then
_LT_TAGVAR(hardcode_direct_absolute, $1)=yes
_LT_TAGVAR(hardcode_libdir_separator, $1)=':'
_LT_TAGVAR(link_all_deplibs, $1)=yes
- _LT_TAGVAR(file_list_spec, $1)='${wl}-f,'
+ _LT_TAGVAR(file_list_spec, $1)='$wl-f,'
+ case $with_aix_soname,$aix_use_runtimelinking in
+ aix,*) ;; # no import file
+ svr4,* | *,yes) # use import file
+ # The Import File defines what to hardcode.
+ _LT_TAGVAR(hardcode_direct, $1)=no
+ _LT_TAGVAR(hardcode_direct_absolute, $1)=no
+ ;;
+ esac
- if test "$GXX" = yes; then
+ if test yes = "$GXX"; then
case $host_os in aix4.[[012]]|aix4.[[012]].*)
# We only want to do this on AIX 4.2 and lower, the check
# below for broken collect2 doesn't work under 4.3+
- collect2name=`${CC} -print-prog-name=collect2`
+ collect2name=`$CC -print-prog-name=collect2`
if test -f "$collect2name" &&
strings "$collect2name" | $GREP resolve_lib_name >/dev/null
then
@@ -6032,64 +6545,84 @@ if test "$_lt_caught_CXX_error" != yes; then
fi
esac
shared_flag='-shared'
- if test "$aix_use_runtimelinking" = yes; then
- shared_flag="$shared_flag "'${wl}-G'
+ if test yes = "$aix_use_runtimelinking"; then
+ shared_flag=$shared_flag' $wl-G'
fi
+ # Need to ensure runtime linking is disabled for the traditional
+ # shared library, or the linker may eventually find shared libraries
+ # /with/ Import File - we do not want to mix them.
+ shared_flag_aix='-shared'
+ shared_flag_svr4='-shared $wl-G'
else
# not using gcc
- if test "$host_cpu" = ia64; then
+ if test ia64 = "$host_cpu"; then
# VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release
# chokes on -Wl,-G. The following line is correct:
shared_flag='-G'
else
- if test "$aix_use_runtimelinking" = yes; then
- shared_flag='${wl}-G'
+ if test yes = "$aix_use_runtimelinking"; then
+ shared_flag='$wl-G'
else
- shared_flag='${wl}-bM:SRE'
+ shared_flag='$wl-bM:SRE'
fi
+ shared_flag_aix='$wl-bM:SRE'
+ shared_flag_svr4='$wl-G'
fi
fi
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-bexpall'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-bexpall'
# It seems that -bexpall does not export symbols beginning with
# underscore (_), so it is better to generate a list of symbols to
# export.
_LT_TAGVAR(always_export_symbols, $1)=yes
- if test "$aix_use_runtimelinking" = yes; then
+ if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then
# Warning - without using the other runtime loading flags (-brtl),
# -berok will link without error, but may produce a broken library.
- _LT_TAGVAR(allow_undefined_flag, $1)='-berok'
+ # The "-G" linker flag allows undefined symbols.
+ _LT_TAGVAR(no_undefined_flag, $1)='-bernotok'
# Determine the default libpath from the value encoded in an empty
# executable.
_LT_SYS_MODULE_PATH_AIX([$1])
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath"
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath"
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags `if test "x${allow_undefined_flag}" != "x"; then func_echo_all "${wl}${allow_undefined_flag}"; else :; fi` '"\${wl}$exp_sym_flag:\$export_symbols $shared_flag"
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag
else
- if test "$host_cpu" = ia64; then
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $libdir:/usr/lib:/lib'
+ if test ia64 = "$host_cpu"; then
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $libdir:/usr/lib:/lib'
_LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs"
- _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\${wl}$no_entry_flag"' $compiler_flags ${wl}${allow_undefined_flag} '"\${wl}$exp_sym_flag:\$export_symbols"
+ _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols"
else
# Determine the default libpath from the value encoded in an
# empty executable.
_LT_SYS_MODULE_PATH_AIX([$1])
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-blibpath:$libdir:'"$aix_libpath"
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath"
# Warning - without using the other run time loading flags,
# -berok will link without error, but may produce a broken library.
- _LT_TAGVAR(no_undefined_flag, $1)=' ${wl}-bernotok'
- _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-berok'
- if test "$with_gnu_ld" = yes; then
+ _LT_TAGVAR(no_undefined_flag, $1)=' $wl-bernotok'
+ _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-berok'
+ if test yes = "$with_gnu_ld"; then
# We only use this code for GNU lds that support --whole-archive.
- _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive$convenience ${wl}--no-whole-archive'
+ _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive'
else
# Exported symbols can be pulled into shared objects from archives
_LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience'
fi
_LT_TAGVAR(archive_cmds_need_lc, $1)=yes
- # This is similar to how AIX traditionally builds its shared
- # libraries.
- _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs ${wl}-bnoentry $compiler_flags ${wl}-bE:$export_symbols${allow_undefined_flag}~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$soname'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d'
+ # -brtl affects multiple linker settings, -berok does not and is overridden later
+ compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([[, ]]\\)%-berok\\1%g"`'
+ if test svr4 != "$with_aix_soname"; then
+ # This is similar to how AIX traditionally builds its shared
+ # libraries. Need -bnortl late, we may have -brtl in LDFLAGS.
+ _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname'
+ fi
+ if test aix != "$with_aix_soname"; then
+ _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp'
+ else
+ # used by -dlpreopen to get the symbols
+ _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV $output_objdir/$realname.d/$soname $output_objdir'
+ fi
+ _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d'
fi
fi
;;
@@ -6099,7 +6632,7 @@ if test "$_lt_caught_CXX_error" != yes; then
_LT_TAGVAR(allow_undefined_flag, $1)=unsupported
# Joseph Beckenbach <jrb3@best.com> says some releases of gcc
# support --undefined. This deserves some investigation. FIXME
- _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
else
_LT_TAGVAR(ld_shlibs, $1)=no
fi
@@ -6127,57 +6660,58 @@ if test "$_lt_caught_CXX_error" != yes; then
# Tell ltmain to make .lib files, not .a files.
libext=lib
# Tell ltmain to make .dll files, not .so files.
- shrext_cmds=".dll"
+ shrext_cmds=.dll
# FIXME: Setting linknames here is a bad hack.
- _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-dll~linknames='
- _LT_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then
- $SED -n -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' -e '1\\\!p' < $export_symbols > $output_objdir/$soname.exp;
- else
- $SED -e 's/\\\\\\\(.*\\\\\\\)/-link\\\ -EXPORT:\\\\\\\1/' < $export_symbols > $output_objdir/$soname.exp;
- fi~
- $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~
- linknames='
+ _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames='
+ _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then
+ cp "$export_symbols" "$output_objdir/$soname.def";
+ echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp";
+ else
+ $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp;
+ fi~
+ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~
+ linknames='
# The linker will not automatically build a static lib if we build a DLL.
# _LT_TAGVAR(old_archive_from_new_cmds, $1)='true'
_LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
# Don't use ranlib
_LT_TAGVAR(old_postinstall_cmds, $1)='chmod 644 $oldlib'
_LT_TAGVAR(postlink_cmds, $1)='lt_outputfile="@OUTPUT@"~
- lt_tool_outputfile="@TOOL_OUTPUT@"~
- case $lt_outputfile in
- *.exe|*.EXE) ;;
- *)
- lt_outputfile="$lt_outputfile.exe"
- lt_tool_outputfile="$lt_tool_outputfile.exe"
- ;;
- esac~
- func_to_tool_file "$lt_outputfile"~
- if test "$MANIFEST_TOOL" != ":" && test -f "$lt_outputfile.manifest"; then
- $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1;
- $RM "$lt_outputfile.manifest";
- fi'
+ lt_tool_outputfile="@TOOL_OUTPUT@"~
+ case $lt_outputfile in
+ *.exe|*.EXE) ;;
+ *)
+ lt_outputfile=$lt_outputfile.exe
+ lt_tool_outputfile=$lt_tool_outputfile.exe
+ ;;
+ esac~
+ func_to_tool_file "$lt_outputfile"~
+ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then
+ $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1;
+ $RM "$lt_outputfile.manifest";
+ fi'
;;
*)
# g++
# _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless,
# as there is no search path for DLLs.
_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-all-symbols'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-all-symbols'
_LT_TAGVAR(allow_undefined_flag, $1)=unsupported
_LT_TAGVAR(always_export_symbols, $1)=no
_LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
- # If the export-symbols file already is a .def file (1st line
- # is EXPORTS), use it as is; otherwise, prepend...
- _LT_TAGVAR(archive_expsym_cmds, $1)='if test "x`$SED 1q $export_symbols`" = xEXPORTS; then
- cp $export_symbols $output_objdir/$soname.def;
- else
- echo EXPORTS > $output_objdir/$soname.def;
- cat $export_symbols >> $output_objdir/$soname.def;
- fi~
- $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname ${wl}--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
+ # If the export-symbols file already is a .def file, use it as
+ # is; otherwise, prepend EXPORTS...
+ _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then
+ cp $export_symbols $output_objdir/$soname.def;
+ else
+ echo EXPORTS > $output_objdir/$soname.def;
+ cat $export_symbols >> $output_objdir/$soname.def;
+ fi~
+ $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib'
else
_LT_TAGVAR(ld_shlibs, $1)=no
fi
@@ -6188,6 +6722,34 @@ if test "$_lt_caught_CXX_error" != yes; then
_LT_DARWIN_LINKER_FEATURES($1)
;;
+ os2*)
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir'
+ _LT_TAGVAR(hardcode_minus_L, $1)=yes
+ _LT_TAGVAR(allow_undefined_flag, $1)=unsupported
+ shrext_cmds=.dll
+ _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+ $ECHO EXPORTS >> $output_objdir/$libname.def~
+ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~
+ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+ emximp -o $lib $output_objdir/$libname.def'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~
+ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~
+ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~
+ $ECHO EXPORTS >> $output_objdir/$libname.def~
+ prefix_cmds="$SED"~
+ if test EXPORTS = "`$SED 1q $export_symbols`"; then
+ prefix_cmds="$prefix_cmds -e 1d";
+ fi~
+ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~
+ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~
+ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~
+ emximp -o $lib $output_objdir/$libname.def'
+ _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def'
+ _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes
+ ;;
+
dgux*)
case $cc_basename in
ec++*)
@@ -6222,18 +6784,15 @@ if test "$_lt_caught_CXX_error" != yes; then
_LT_TAGVAR(ld_shlibs, $1)=yes
;;
- gnu*)
- ;;
-
haiku*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
_LT_TAGVAR(link_all_deplibs, $1)=yes
;;
hpux9*)
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir'
_LT_TAGVAR(hardcode_libdir_separator, $1)=:
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E'
_LT_TAGVAR(hardcode_direct, $1)=yes
_LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH,
# but as the default
@@ -6245,7 +6804,7 @@ if test "$_lt_caught_CXX_error" != yes; then
_LT_TAGVAR(ld_shlibs, $1)=no
;;
aCC*)
- _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -b ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -b $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib'
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
@@ -6254,11 +6813,11 @@ if test "$_lt_caught_CXX_error" != yes; then
# explicitly linking system object files so we need to strip them
# from the output so that they don't get included in the library
# dependencies.
- output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
+ output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
;;
*)
- if test "$GXX" = yes; then
- _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared -nostdlib $pic_flag ${wl}+b ${wl}$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test $output_objdir/$soname = $lib || mv $output_objdir/$soname $lib'
+ if test yes = "$GXX"; then
+ _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared -nostdlib $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib'
else
# FIXME: insert proper C++ library support
_LT_TAGVAR(ld_shlibs, $1)=no
@@ -6268,15 +6827,15 @@ if test "$_lt_caught_CXX_error" != yes; then
;;
hpux10*|hpux11*)
- if test $with_gnu_ld = no; then
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}+b ${wl}$libdir'
+ if test no = "$with_gnu_ld"; then
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir'
_LT_TAGVAR(hardcode_libdir_separator, $1)=:
case $host_cpu in
hppa*64*|ia64*)
;;
*)
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E'
;;
esac
fi
@@ -6302,13 +6861,13 @@ if test "$_lt_caught_CXX_error" != yes; then
aCC*)
case $host_cpu in
hppa*64*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
;;
ia64*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
;;
*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -b ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
;;
esac
# Commands to make compiler produce verbose output that lists
@@ -6319,20 +6878,20 @@ if test "$_lt_caught_CXX_error" != yes; then
# explicitly linking system object files so we need to strip them
# from the output so that they don't get included in the library
# dependencies.
- output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
+ output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
;;
*)
- if test "$GXX" = yes; then
- if test $with_gnu_ld = no; then
+ if test yes = "$GXX"; then
+ if test no = "$with_gnu_ld"; then
case $host_cpu in
hppa*64*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC ${wl}+h ${wl}$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
;;
ia64*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag ${wl}+h ${wl}$soname ${wl}+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
;;
*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag ${wl}+h ${wl}$soname ${wl}+b ${wl}$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
;;
esac
fi
@@ -6347,22 +6906,22 @@ if test "$_lt_caught_CXX_error" != yes; then
interix[[3-9]]*)
_LT_TAGVAR(hardcode_direct, $1)=no
_LT_TAGVAR(hardcode_shlibpath_var, $1)=no
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E'
# Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc.
# Instead, shared libraries are loaded at an image base (0x10000000 by
# default) and relocated if they conflict, which is a slow very memory
# consuming and fragmenting process. To avoid this, we pick a random,
# 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link
# time. Moving up from 0x10000000 also allows more sbrk(2) space.
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
- _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s,^,_," $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags ${wl}-h,$soname ${wl}--retain-symbols-file,$output_objdir/$soname.expsym ${wl}--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='sed "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib'
;;
irix5* | irix6*)
case $cc_basename in
CC*)
# SGI C++
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
# Archives containing C++ object files must be created using
# "CC -ar", where "CC" is the IRIX C++ compiler. This is
@@ -6371,22 +6930,22 @@ if test "$_lt_caught_CXX_error" != yes; then
_LT_TAGVAR(old_archive_cmds, $1)='$CC -ar -WR,-u -o $oldlib $oldobjs'
;;
*)
- if test "$GXX" = yes; then
- if test "$with_gnu_ld" = no; then
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+ if test yes = "$GXX"; then
+ if test no = "$with_gnu_ld"; then
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
else
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` -o $lib'
fi
fi
_LT_TAGVAR(link_all_deplibs, $1)=yes
;;
esac
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
_LT_TAGVAR(hardcode_libdir_separator, $1)=:
_LT_TAGVAR(inherit_rpath, $1)=yes
;;
- linux* | k*bsd*-gnu | kopensolaris*-gnu)
+ linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*)
case $cc_basename in
KCC*)
# Kuck and Associates, Inc. (KAI) C++ Compiler
@@ -6394,8 +6953,8 @@ if test "$_lt_caught_CXX_error" != yes; then
# KCC will only create a shared library if the output file
# ends with ".so" (or ".sl" for HP-UX), so rename the library
# to its proper name (with version) after linking.
- _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib'
- _LT_TAGVAR(archive_expsym_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib ${wl}-retain-symbols-file,$export_symbols; mv \$templib $lib'
+ _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib $wl-retain-symbols-file,$export_symbols; mv \$templib $lib'
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
@@ -6404,10 +6963,10 @@ if test "$_lt_caught_CXX_error" != yes; then
# explicitly linking system object files so we need to strip them
# from the output so that they don't get included in the library
# dependencies.
- output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | $GREP "ld"`; rm -f libconftest$shared_ext; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
+ output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | $GREP "ld"`; rm -f libconftest$shared_ext; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic'
# Archives containing C++ object files must be created using
# "CC -Bstatic", where "CC" is the KAI C++ compiler.
@@ -6421,59 +6980,59 @@ if test "$_lt_caught_CXX_error" != yes; then
# earlier do not add the objects themselves.
case `$CC -V 2>&1` in
*"Version 7."*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
;;
*) # Version 8.0 or newer
tmp_idyn=
case $host_cpu in
ia64*) tmp_idyn=' -i_dynamic';;
esac
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-retain-symbols-file $wl$export_symbols -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
;;
esac
_LT_TAGVAR(archive_cmds_need_lc, $1)=no
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
- _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive$convenience ${wl}--no-whole-archive'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic'
+ _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive'
;;
pgCC* | pgcpp*)
# Portland Group C++ compiler
case `$CC -V` in
*pgCC\ [[1-5]].* | *pgcpp\ [[1-5]].*)
_LT_TAGVAR(prelink_cmds, $1)='tpldir=Template.dir~
- rm -rf $tpldir~
- $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~
- compile_command="$compile_command `find $tpldir -name \*.o | sort | $NL2SP`"'
+ rm -rf $tpldir~
+ $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~
+ compile_command="$compile_command `find $tpldir -name \*.o | sort | $NL2SP`"'
_LT_TAGVAR(old_archive_cmds, $1)='tpldir=Template.dir~
- rm -rf $tpldir~
- $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~
- $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | sort | $NL2SP`~
- $RANLIB $oldlib'
+ rm -rf $tpldir~
+ $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~
+ $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | sort | $NL2SP`~
+ $RANLIB $oldlib'
_LT_TAGVAR(archive_cmds, $1)='tpldir=Template.dir~
- rm -rf $tpldir~
- $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~
- $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib'
+ rm -rf $tpldir~
+ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~
+ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib'
_LT_TAGVAR(archive_expsym_cmds, $1)='tpldir=Template.dir~
- rm -rf $tpldir~
- $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~
- $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib'
+ rm -rf $tpldir~
+ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~
+ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
;;
*) # Version 6 and above use weak symbols
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname -o $lib'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname ${wl}-retain-symbols-file ${wl}$export_symbols -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib'
;;
esac
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}--rpath ${wl}$libdir'
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
- _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl--rpath $wl$libdir'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic'
+ _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
;;
cxx*)
# Compaq C++
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $wl$soname -o $lib ${wl}-retain-symbols-file $wl$export_symbols'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib $wl-retain-symbols-file $wl$export_symbols'
runpath_var=LD_RUN_PATH
_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir'
@@ -6487,18 +7046,18 @@ if test "$_lt_caught_CXX_error" != yes; then
# explicitly linking system object files so we need to strip them
# from the output so that they don't get included in the library
# dependencies.
- output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "X$list" | $Xsed'
+ output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "X$list" | $Xsed'
;;
xl* | mpixl* | bgxl*)
# IBM XL 8.0 on PPC, with GNU ld
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}--export-dynamic'
- _LT_TAGVAR(archive_cmds, $1)='$CC -qmkshrobj $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname -o $lib'
- if test "x$supports_anon_versioning" = xyes; then
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib'
+ if test yes = "$supports_anon_versioning"; then
_LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~
- cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
- echo "local: *; };" >> $output_objdir/$libname.ver~
- $CC -qmkshrobj $libobjs $deplibs $compiler_flags ${wl}-soname $wl$soname ${wl}-version-script ${wl}$output_objdir/$libname.ver -o $lib'
+ cat $export_symbols | sed -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~
+ echo "local: *; };" >> $output_objdir/$libname.ver~
+ $CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib'
fi
;;
*)
@@ -6506,10 +7065,10 @@ if test "$_lt_caught_CXX_error" != yes; then
*Sun\ C*)
# Sun C++ 5.9
_LT_TAGVAR(no_undefined_flag, $1)=' -zdefs'
- _LT_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file ${wl}$export_symbols'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file $wl$export_symbols'
_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
- _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` ${wl}--no-whole-archive'
+ _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive'
_LT_TAGVAR(compiler_needs_object, $1)=yes
# Not sure whether something based on
@@ -6567,22 +7126,17 @@ if test "$_lt_caught_CXX_error" != yes; then
_LT_TAGVAR(ld_shlibs, $1)=yes
;;
- openbsd2*)
- # C++ shared libraries are fairly broken
- _LT_TAGVAR(ld_shlibs, $1)=no
- ;;
-
- openbsd*)
+ openbsd* | bitrig*)
if test -f /usr/libexec/ld.so; then
_LT_TAGVAR(hardcode_direct, $1)=yes
_LT_TAGVAR(hardcode_shlibpath_var, $1)=no
_LT_TAGVAR(hardcode_direct_absolute, $1)=yes
_LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib'
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
- if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-retain-symbols-file,$export_symbols -o $lib'
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-E'
- _LT_TAGVAR(whole_archive_flag_spec, $1)="$wlarc"'--whole-archive$convenience '"$wlarc"'--no-whole-archive'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir'
+ if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`"; then
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file,$export_symbols -o $lib'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E'
+ _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive'
fi
output_verbose_link_cmd=func_echo_all
else
@@ -6598,9 +7152,9 @@ if test "$_lt_caught_CXX_error" != yes; then
# KCC will only create a shared library if the output file
# ends with ".so" (or ".sl" for HP-UX), so rename the library
# to its proper name (with version) after linking.
- _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo "$lib" | $SED -e "s/\${tempext}\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib'
+ _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo "$lib" | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib'
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath,$libdir'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir'
_LT_TAGVAR(hardcode_libdir_separator, $1)=:
# Archives containing C++ object files must be created using
@@ -6618,17 +7172,17 @@ if test "$_lt_caught_CXX_error" != yes; then
cxx*)
case $host in
osf3*)
- _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname $soname `test -n "$verstring" && func_echo_all "${wl}-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+ _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $soname `test -n "$verstring" && func_echo_all "$wl-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
;;
*)
_LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*'
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib'
_LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~
- echo "-hidden">> $lib.exp~
- $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname ${wl}-input ${wl}$lib.exp `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry ${output_objdir}/so_locations -o $lib~
- $RM $lib.exp'
+ echo "-hidden">> $lib.exp~
+ $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname $wl-input $wl$lib.exp `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~
+ $RM $lib.exp'
_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir'
;;
esac
@@ -6643,21 +7197,21 @@ if test "$_lt_caught_CXX_error" != yes; then
# explicitly linking system object files so we need to strip them
# from the output so that they don't get included in the library
# dependencies.
- output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list=""; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
+ output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"'
;;
*)
- if test "$GXX" = yes && test "$with_gnu_ld" = no; then
- _LT_TAGVAR(allow_undefined_flag, $1)=' ${wl}-expect_unresolved ${wl}\*'
+ if test yes,no = "$GXX,$with_gnu_ld"; then
+ _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*'
case $host in
osf3*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
;;
*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib ${allow_undefined_flag} $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-msym ${wl}-soname ${wl}$soname `test -n "$verstring" && func_echo_all "${wl}-set_version ${wl}$verstring"` ${wl}-update_registry ${wl}${output_objdir}/so_locations -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib'
;;
esac
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-rpath ${wl}$libdir'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir'
_LT_TAGVAR(hardcode_libdir_separator, $1)=:
# Commands to make compiler produce verbose output that lists
@@ -6703,9 +7257,9 @@ if test "$_lt_caught_CXX_error" != yes; then
# Sun C++ 4.2, 5.x and Centerline C++
_LT_TAGVAR(archive_cmds_need_lc,$1)=yes
_LT_TAGVAR(no_undefined_flag, $1)=' -zdefs'
- _LT_TAGVAR(archive_cmds, $1)='$CC -G${allow_undefined_flag} -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags'
_LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
- $CC -G${allow_undefined_flag} ${wl}-M ${wl}$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp'
+ $CC -G$allow_undefined_flag $wl-M $wl$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp'
_LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir'
_LT_TAGVAR(hardcode_shlibpath_var, $1)=no
@@ -6713,7 +7267,7 @@ if test "$_lt_caught_CXX_error" != yes; then
solaris2.[[0-5]] | solaris2.[[0-5]].*) ;;
*)
# The compiler driver will combine and reorder linker options,
- # but understands `-z linker_flag'.
+ # but understands '-z linker_flag'.
# Supported since Solaris 2.6 (maybe 2.5.1?)
_LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract'
;;
@@ -6730,30 +7284,30 @@ if test "$_lt_caught_CXX_error" != yes; then
;;
gcx*)
# Green Hills C++ Compiler
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib'
# The C++ compiler must be used to create the archive.
_LT_TAGVAR(old_archive_cmds, $1)='$CC $LDFLAGS -archive -o $oldlib $oldobjs'
;;
*)
# GNU C++ compiler with Solaris linker
- if test "$GXX" = yes && test "$with_gnu_ld" = no; then
- _LT_TAGVAR(no_undefined_flag, $1)=' ${wl}-z ${wl}defs'
+ if test yes,no = "$GXX,$with_gnu_ld"; then
+ _LT_TAGVAR(no_undefined_flag, $1)=' $wl-z ${wl}defs'
if $CC --version | $GREP -v '^2\.7' > /dev/null; then
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib'
_LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
- $CC -shared $pic_flag -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp'
+ $CC -shared $pic_flag -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp'
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
# linking a shared library.
output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
else
- # g++ 2.7 appears to require `-G' NOT `-shared' on this
+ # g++ 2.7 appears to require '-G' NOT '-shared' on this
# platform.
- _LT_TAGVAR(archive_cmds, $1)='$CC -G -nostdlib $LDFLAGS $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags ${wl}-h $wl$soname -o $lib'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -G -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib'
_LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~
- $CC -G -nostdlib ${wl}-M $wl$lib.exp -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp'
+ $CC -G -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp'
# Commands to make compiler produce verbose output that lists
# what "hidden" libraries, object files and flags are used when
@@ -6761,11 +7315,11 @@ if test "$_lt_caught_CXX_error" != yes; then
output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"'
fi
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R $wl$libdir'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $wl$libdir'
case $host_os in
solaris2.[[0-5]] | solaris2.[[0-5]].*) ;;
*)
- _LT_TAGVAR(whole_archive_flag_spec, $1)='${wl}-z ${wl}allextract$convenience ${wl}-z ${wl}defaultextract'
+ _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract'
;;
esac
fi
@@ -6774,52 +7328,52 @@ if test "$_lt_caught_CXX_error" != yes; then
;;
sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*)
- _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text'
+ _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text'
_LT_TAGVAR(archive_cmds_need_lc, $1)=no
_LT_TAGVAR(hardcode_shlibpath_var, $1)=no
runpath_var='LD_RUN_PATH'
case $cc_basename in
CC*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
;;
*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
;;
esac
;;
sysv5* | sco3.2v5* | sco5v6*)
- # Note: We can NOT use -z defs as we might desire, because we do not
+ # Note: We CANNOT use -z defs as we might desire, because we do not
# link with -lc, and that would cause any symbols used from libc to
# always be unresolved, which means just about no library would
# ever link correctly. If we're not using GNU ld we use -z text
# though, which does catch some bad symbols but isn't as heavy-handed
# as -z defs.
- _LT_TAGVAR(no_undefined_flag, $1)='${wl}-z,text'
- _LT_TAGVAR(allow_undefined_flag, $1)='${wl}-z,nodefs'
+ _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text'
+ _LT_TAGVAR(allow_undefined_flag, $1)='$wl-z,nodefs'
_LT_TAGVAR(archive_cmds_need_lc, $1)=no
_LT_TAGVAR(hardcode_shlibpath_var, $1)=no
- _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='${wl}-R,$libdir'
+ _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R,$libdir'
_LT_TAGVAR(hardcode_libdir_separator, $1)=':'
_LT_TAGVAR(link_all_deplibs, $1)=yes
- _LT_TAGVAR(export_dynamic_flag_spec, $1)='${wl}-Bexport'
+ _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Bexport'
runpath_var='LD_RUN_PATH'
case $cc_basename in
CC*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -G ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
_LT_TAGVAR(old_archive_cmds, $1)='$CC -Tprelink_objects $oldobjs~
- '"$_LT_TAGVAR(old_archive_cmds, $1)"
+ '"$_LT_TAGVAR(old_archive_cmds, $1)"
_LT_TAGVAR(reload_cmds, $1)='$CC -Tprelink_objects $reload_objs~
- '"$_LT_TAGVAR(reload_cmds, $1)"
+ '"$_LT_TAGVAR(reload_cmds, $1)"
;;
*)
- _LT_TAGVAR(archive_cmds, $1)='$CC -shared ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
- _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared ${wl}-Bexport:$export_symbols ${wl}-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
+ _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags'
;;
esac
;;
@@ -6850,10 +7404,10 @@ if test "$_lt_caught_CXX_error" != yes; then
esac
AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)])
- test "$_LT_TAGVAR(ld_shlibs, $1)" = no && can_build_shared=no
+ test no = "$_LT_TAGVAR(ld_shlibs, $1)" && can_build_shared=no
- _LT_TAGVAR(GCC, $1)="$GXX"
- _LT_TAGVAR(LD, $1)="$LD"
+ _LT_TAGVAR(GCC, $1)=$GXX
+ _LT_TAGVAR(LD, $1)=$LD
## CAVEAT EMPTOR:
## There is no encapsulation within the following macros, do not change
@@ -6880,7 +7434,7 @@ if test "$_lt_caught_CXX_error" != yes; then
lt_cv_path_LD=$lt_save_path_LD
lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld
lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld
-fi # test "$_lt_caught_CXX_error" != yes
+fi # test yes != "$_lt_caught_CXX_error"
AC_LANG_POP
])# _LT_LANG_CXX_CONFIG
@@ -6902,13 +7456,14 @@ AC_REQUIRE([_LT_DECL_SED])
AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH])
func_stripname_cnf ()
{
- case ${2} in
- .*) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%\\\\${2}\$%%"`;;
- *) func_stripname_result=`$ECHO "${3}" | $SED "s%^${1}%%; s%${2}\$%%"`;;
+ case @S|@2 in
+ .*) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%\\\\@S|@2\$%%"`;;
+ *) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%@S|@2\$%%"`;;
esac
} # func_stripname_cnf
])# _LT_FUNC_STRIPNAME_CNF
+
# _LT_SYS_HIDDEN_LIBDEPS([TAGNAME])
# ---------------------------------
# Figure out "hidden" library dependencies from verbose
@@ -6992,13 +7547,13 @@ if AC_TRY_EVAL(ac_compile); then
pre_test_object_deps_done=no
for p in `eval "$output_verbose_link_cmd"`; do
- case ${prev}${p} in
+ case $prev$p in
-L* | -R* | -l*)
# Some compilers place space between "-{L,R}" and the path.
# Remove the space.
- if test $p = "-L" ||
- test $p = "-R"; then
+ if test x-L = "$p" ||
+ test x-R = "$p"; then
prev=$p
continue
fi
@@ -7014,16 +7569,16 @@ if AC_TRY_EVAL(ac_compile); then
case $p in
=*) func_stripname_cnf '=' '' "$p"; p=$lt_sysroot$func_stripname_result ;;
esac
- if test "$pre_test_object_deps_done" = no; then
- case ${prev} in
+ if test no = "$pre_test_object_deps_done"; then
+ case $prev in
-L | -R)
# Internal compiler library paths should come after those
# provided the user. The postdeps already come after the
# user supplied libs so there is no need to process them.
if test -z "$_LT_TAGVAR(compiler_lib_search_path, $1)"; then
- _LT_TAGVAR(compiler_lib_search_path, $1)="${prev}${p}"
+ _LT_TAGVAR(compiler_lib_search_path, $1)=$prev$p
else
- _LT_TAGVAR(compiler_lib_search_path, $1)="${_LT_TAGVAR(compiler_lib_search_path, $1)} ${prev}${p}"
+ _LT_TAGVAR(compiler_lib_search_path, $1)="${_LT_TAGVAR(compiler_lib_search_path, $1)} $prev$p"
fi
;;
# The "-l" case would never come before the object being
@@ -7031,9 +7586,9 @@ if AC_TRY_EVAL(ac_compile); then
esac
else
if test -z "$_LT_TAGVAR(postdeps, $1)"; then
- _LT_TAGVAR(postdeps, $1)="${prev}${p}"
+ _LT_TAGVAR(postdeps, $1)=$prev$p
else
- _LT_TAGVAR(postdeps, $1)="${_LT_TAGVAR(postdeps, $1)} ${prev}${p}"
+ _LT_TAGVAR(postdeps, $1)="${_LT_TAGVAR(postdeps, $1)} $prev$p"
fi
fi
prev=
@@ -7048,15 +7603,15 @@ if AC_TRY_EVAL(ac_compile); then
continue
fi
- if test "$pre_test_object_deps_done" = no; then
+ if test no = "$pre_test_object_deps_done"; then
if test -z "$_LT_TAGVAR(predep_objects, $1)"; then
- _LT_TAGVAR(predep_objects, $1)="$p"
+ _LT_TAGVAR(predep_objects, $1)=$p
else
_LT_TAGVAR(predep_objects, $1)="$_LT_TAGVAR(predep_objects, $1) $p"
fi
else
if test -z "$_LT_TAGVAR(postdep_objects, $1)"; then
- _LT_TAGVAR(postdep_objects, $1)="$p"
+ _LT_TAGVAR(postdep_objects, $1)=$p
else
_LT_TAGVAR(postdep_objects, $1)="$_LT_TAGVAR(postdep_objects, $1) $p"
fi
@@ -7087,51 +7642,6 @@ interix[[3-9]]*)
_LT_TAGVAR(postdep_objects,$1)=
_LT_TAGVAR(postdeps,$1)=
;;
-
-linux*)
- case `$CC -V 2>&1 | sed 5q` in
- *Sun\ C*)
- # Sun C++ 5.9
-
- # The more standards-conforming stlport4 library is
- # incompatible with the Cstd library. Avoid specifying
- # it if it's in CXXFLAGS. Ignore libCrun as
- # -library=stlport4 depends on it.
- case " $CXX $CXXFLAGS " in
- *" -library=stlport4 "*)
- solaris_use_stlport4=yes
- ;;
- esac
-
- if test "$solaris_use_stlport4" != yes; then
- _LT_TAGVAR(postdeps,$1)='-library=Cstd -library=Crun'
- fi
- ;;
- esac
- ;;
-
-solaris*)
- case $cc_basename in
- CC* | sunCC*)
- # The more standards-conforming stlport4 library is
- # incompatible with the Cstd library. Avoid specifying
- # it if it's in CXXFLAGS. Ignore libCrun as
- # -library=stlport4 depends on it.
- case " $CXX $CXXFLAGS " in
- *" -library=stlport4 "*)
- solaris_use_stlport4=yes
- ;;
- esac
-
- # Adding this requires a known-good setup of shared libraries for
- # Sun compiler versions before 5.6, else PIC objects from an old
- # archive will be linked into the output, leading to subtle bugs.
- if test "$solaris_use_stlport4" != yes; then
- _LT_TAGVAR(postdeps,$1)='-library=Cstd -library=Crun'
- fi
- ;;
- esac
- ;;
esac
])
@@ -7140,7 +7650,7 @@ case " $_LT_TAGVAR(postdeps, $1) " in
esac
_LT_TAGVAR(compiler_lib_search_dirs, $1)=
if test -n "${_LT_TAGVAR(compiler_lib_search_path, $1)}"; then
- _LT_TAGVAR(compiler_lib_search_dirs, $1)=`echo " ${_LT_TAGVAR(compiler_lib_search_path, $1)}" | ${SED} -e 's! -L! !g' -e 's!^ !!'`
+ _LT_TAGVAR(compiler_lib_search_dirs, $1)=`echo " ${_LT_TAGVAR(compiler_lib_search_path, $1)}" | $SED -e 's! -L! !g' -e 's!^ !!'`
fi
_LT_TAGDECL([], [compiler_lib_search_dirs], [1],
[The directories searched by this compiler when creating a shared library])
@@ -7160,10 +7670,10 @@ _LT_TAGDECL([], [compiler_lib_search_path], [1],
# --------------------------
# Ensure that the configuration variables for a Fortran 77 compiler are
# suitably defined. These variables are subsequently used by _LT_CONFIG
-# to write the compiler configuration to `libtool'.
+# to write the compiler configuration to 'libtool'.
m4_defun([_LT_LANG_F77_CONFIG],
[AC_LANG_PUSH(Fortran 77)
-if test -z "$F77" || test "X$F77" = "Xno"; then
+if test -z "$F77" || test no = "$F77"; then
_lt_disable_F77=yes
fi
@@ -7200,7 +7710,7 @@ _LT_TAGVAR(objext, $1)=$objext
# the F77 compiler isn't working. Some variables (like enable_shared)
# are currently assumed to apply to all compilers on this platform,
# and will be corrupted by setting them based on a non-working compiler.
-if test "$_lt_disable_F77" != yes; then
+if test yes != "$_lt_disable_F77"; then
# Code to be used in simple compile tests
lt_simple_compile_test_code="\
subroutine t
@@ -7222,7 +7732,7 @@ if test "$_lt_disable_F77" != yes; then
_LT_LINKER_BOILERPLATE
# Allow CC to be a program name with arguments.
- lt_save_CC="$CC"
+ lt_save_CC=$CC
lt_save_GCC=$GCC
lt_save_CFLAGS=$CFLAGS
CC=${F77-"f77"}
@@ -7236,21 +7746,25 @@ if test "$_lt_disable_F77" != yes; then
AC_MSG_RESULT([$can_build_shared])
AC_MSG_CHECKING([whether to build shared libraries])
- test "$can_build_shared" = "no" && enable_shared=no
+ test no = "$can_build_shared" && enable_shared=no
# On AIX, shared libraries and static libraries use the same namespace, and
# are all built from PIC.
case $host_os in
aix3*)
- test "$enable_shared" = yes && enable_static=no
+ test yes = "$enable_shared" && enable_static=no
if test -n "$RANLIB"; then
archive_cmds="$archive_cmds~\$RANLIB \$lib"
postinstall_cmds='$RANLIB $lib'
fi
;;
aix[[4-9]]*)
- if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then
- test "$enable_shared" = yes && enable_static=no
+ if test ia64 != "$host_cpu"; then
+ case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in
+ yes,aix,yes) ;; # shared object as lib.so file only
+ yes,svr4,*) ;; # shared object as lib.so archive member only
+ yes,*) enable_static=no ;; # shared object in lib.a archive as well
+ esac
fi
;;
esac
@@ -7258,11 +7772,11 @@ if test "$_lt_disable_F77" != yes; then
AC_MSG_CHECKING([whether to build static libraries])
# Make sure either enable_shared or enable_static is yes.
- test "$enable_shared" = yes || enable_static=yes
+ test yes = "$enable_shared" || enable_static=yes
AC_MSG_RESULT([$enable_static])
- _LT_TAGVAR(GCC, $1)="$G77"
- _LT_TAGVAR(LD, $1)="$LD"
+ _LT_TAGVAR(GCC, $1)=$G77
+ _LT_TAGVAR(LD, $1)=$LD
## CAVEAT EMPTOR:
## There is no encapsulation within the following macros, do not change
@@ -7279,9 +7793,9 @@ if test "$_lt_disable_F77" != yes; then
fi # test -n "$compiler"
GCC=$lt_save_GCC
- CC="$lt_save_CC"
- CFLAGS="$lt_save_CFLAGS"
-fi # test "$_lt_disable_F77" != yes
+ CC=$lt_save_CC
+ CFLAGS=$lt_save_CFLAGS
+fi # test yes != "$_lt_disable_F77"
AC_LANG_POP
])# _LT_LANG_F77_CONFIG
@@ -7291,11 +7805,11 @@ AC_LANG_POP
# -------------------------
# Ensure that the configuration variables for a Fortran compiler are
# suitably defined. These variables are subsequently used by _LT_CONFIG
-# to write the compiler configuration to `libtool'.
+# to write the compiler configuration to 'libtool'.
m4_defun([_LT_LANG_FC_CONFIG],
[AC_LANG_PUSH(Fortran)
-if test -z "$FC" || test "X$FC" = "Xno"; then
+if test -z "$FC" || test no = "$FC"; then
_lt_disable_FC=yes
fi
@@ -7332,7 +7846,7 @@ _LT_TAGVAR(objext, $1)=$objext
# the FC compiler isn't working. Some variables (like enable_shared)
# are currently assumed to apply to all compilers on this platform,
# and will be corrupted by setting them based on a non-working compiler.
-if test "$_lt_disable_FC" != yes; then
+if test yes != "$_lt_disable_FC"; then
# Code to be used in simple compile tests
lt_simple_compile_test_code="\
subroutine t
@@ -7354,7 +7868,7 @@ if test "$_lt_disable_FC" != yes; then
_LT_LINKER_BOILERPLATE
# Allow CC to be a program name with arguments.
- lt_save_CC="$CC"
+ lt_save_CC=$CC
lt_save_GCC=$GCC
lt_save_CFLAGS=$CFLAGS
CC=${FC-"f95"}
@@ -7370,21 +7884,25 @@ if test "$_lt_disable_FC" != yes; then
AC_MSG_RESULT([$can_build_shared])
AC_MSG_CHECKING([whether to build shared libraries])
- test "$can_build_shared" = "no" && enable_shared=no
+ test no = "$can_build_shared" && enable_shared=no
# On AIX, shared libraries and static libraries use the same namespace, and
# are all built from PIC.
case $host_os in
aix3*)
- test "$enable_shared" = yes && enable_static=no
+ test yes = "$enable_shared" && enable_static=no
if test -n "$RANLIB"; then
archive_cmds="$archive_cmds~\$RANLIB \$lib"
postinstall_cmds='$RANLIB $lib'
fi
;;
aix[[4-9]]*)
- if test "$host_cpu" != ia64 && test "$aix_use_runtimelinking" = no ; then
- test "$enable_shared" = yes && enable_static=no
+ if test ia64 != "$host_cpu"; then
+ case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in
+ yes,aix,yes) ;; # shared object as lib.so file only
+ yes,svr4,*) ;; # shared object as lib.so archive member only
+ yes,*) enable_static=no ;; # shared object in lib.a archive as well
+ esac
fi
;;
esac
@@ -7392,11 +7910,11 @@ if test "$_lt_disable_FC" != yes; then
AC_MSG_CHECKING([whether to build static libraries])
# Make sure either enable_shared or enable_static is yes.
- test "$enable_shared" = yes || enable_static=yes
+ test yes = "$enable_shared" || enable_static=yes
AC_MSG_RESULT([$enable_static])
- _LT_TAGVAR(GCC, $1)="$ac_cv_fc_compiler_gnu"
- _LT_TAGVAR(LD, $1)="$LD"
+ _LT_TAGVAR(GCC, $1)=$ac_cv_fc_compiler_gnu
+ _LT_TAGVAR(LD, $1)=$LD
## CAVEAT EMPTOR:
## There is no encapsulation within the following macros, do not change
@@ -7416,7 +7934,7 @@ if test "$_lt_disable_FC" != yes; then
GCC=$lt_save_GCC
CC=$lt_save_CC
CFLAGS=$lt_save_CFLAGS
-fi # test "$_lt_disable_FC" != yes
+fi # test yes != "$_lt_disable_FC"
AC_LANG_POP
])# _LT_LANG_FC_CONFIG
@@ -7426,7 +7944,7 @@ AC_LANG_POP
# --------------------------
# Ensure that the configuration variables for the GNU Java Compiler compiler
# are suitably defined. These variables are subsequently used by _LT_CONFIG
-# to write the compiler configuration to `libtool'.
+# to write the compiler configuration to 'libtool'.
m4_defun([_LT_LANG_GCJ_CONFIG],
[AC_REQUIRE([LT_PROG_GCJ])dnl
AC_LANG_SAVE
@@ -7460,7 +7978,7 @@ CC=${GCJ-"gcj"}
CFLAGS=$GCJFLAGS
compiler=$CC
_LT_TAGVAR(compiler, $1)=$CC
-_LT_TAGVAR(LD, $1)="$LD"
+_LT_TAGVAR(LD, $1)=$LD
_LT_CC_BASENAME([$compiler])
# GCJ did not exist at the time GCC didn't implicitly link libc in.
@@ -7497,7 +8015,7 @@ CFLAGS=$lt_save_CFLAGS
# --------------------------
# Ensure that the configuration variables for the GNU Go compiler
# are suitably defined. These variables are subsequently used by _LT_CONFIG
-# to write the compiler configuration to `libtool'.
+# to write the compiler configuration to 'libtool'.
m4_defun([_LT_LANG_GO_CONFIG],
[AC_REQUIRE([LT_PROG_GO])dnl
AC_LANG_SAVE
@@ -7531,7 +8049,7 @@ CC=${GOC-"gccgo"}
CFLAGS=$GOFLAGS
compiler=$CC
_LT_TAGVAR(compiler, $1)=$CC
-_LT_TAGVAR(LD, $1)="$LD"
+_LT_TAGVAR(LD, $1)=$LD
_LT_CC_BASENAME([$compiler])
# Go did not exist at the time GCC didn't implicitly link libc in.
@@ -7568,7 +8086,7 @@ CFLAGS=$lt_save_CFLAGS
# -------------------------
# Ensure that the configuration variables for the Windows resource compiler
# are suitably defined. These variables are subsequently used by _LT_CONFIG
-# to write the compiler configuration to `libtool'.
+# to write the compiler configuration to 'libtool'.
m4_defun([_LT_LANG_RC_CONFIG],
[AC_REQUIRE([LT_PROG_RC])dnl
AC_LANG_SAVE
@@ -7584,7 +8102,7 @@ _LT_TAGVAR(objext, $1)=$objext
lt_simple_compile_test_code='sample MENU { MENUITEM "&Soup", 100, CHECKED }'
# Code to be used in simple link tests
-lt_simple_link_test_code="$lt_simple_compile_test_code"
+lt_simple_link_test_code=$lt_simple_compile_test_code
# ltmain only uses $CC for tagged configurations so make sure $CC is set.
_LT_TAG_COMPILER
@@ -7594,7 +8112,7 @@ _LT_COMPILER_BOILERPLATE
_LT_LINKER_BOILERPLATE
# Allow CC to be a program name with arguments.
-lt_save_CC="$CC"
+lt_save_CC=$CC
lt_save_CFLAGS=$CFLAGS
lt_save_GCC=$GCC
GCC=
@@ -7623,7 +8141,7 @@ AC_DEFUN([LT_PROG_GCJ],
[m4_ifdef([AC_PROG_GCJ], [AC_PROG_GCJ],
[m4_ifdef([A][M_PROG_GCJ], [A][M_PROG_GCJ],
[AC_CHECK_TOOL(GCJ, gcj,)
- test "x${GCJFLAGS+set}" = xset || GCJFLAGS="-g -O2"
+ test set = "${GCJFLAGS+set}" || GCJFLAGS="-g -O2"
AC_SUBST(GCJFLAGS)])])[]dnl
])
@@ -7734,7 +8252,7 @@ lt_ac_count=0
# Add /usr/xpg4/bin/sed as it is typically found on Solaris
# along with /bin/sed that truncates output.
for lt_ac_sed in $lt_ac_sed_list /usr/xpg4/bin/sed; do
- test ! -f $lt_ac_sed && continue
+ test ! -f "$lt_ac_sed" && continue
cat /dev/null > conftest.in
lt_ac_count=0
echo $ECHO_N "0123456789$ECHO_C" >conftest.in
@@ -7751,9 +8269,9 @@ for lt_ac_sed in $lt_ac_sed_list /usr/xpg4/bin/sed; do
$lt_ac_sed -e 's/a$//' < conftest.nl >conftest.out || break
cmp -s conftest.out conftest.nl || break
# 10000 chars as input seems more than enough
- test $lt_ac_count -gt 10 && break
+ test 10 -lt "$lt_ac_count" && break
lt_ac_count=`expr $lt_ac_count + 1`
- if test $lt_ac_count -gt $lt_ac_max; then
+ if test "$lt_ac_count" -gt "$lt_ac_max"; then
lt_ac_max=$lt_ac_count
lt_cv_path_SED=$lt_ac_sed
fi
@@ -7777,27 +8295,7 @@ dnl AC_DEFUN([LT_AC_PROG_SED], [])
# Find out whether the shell is Bourne or XSI compatible,
# or has some other useful features.
m4_defun([_LT_CHECK_SHELL_FEATURES],
-[AC_MSG_CHECKING([whether the shell understands some XSI constructs])
-# Try some XSI features
-xsi_shell=no
-( _lt_dummy="a/b/c"
- test "${_lt_dummy##*/},${_lt_dummy%/*},${_lt_dummy#??}"${_lt_dummy%"$_lt_dummy"}, \
- = c,a/b,b/c, \
- && eval 'test $(( 1 + 1 )) -eq 2 \
- && test "${#_lt_dummy}" -eq 5' ) >/dev/null 2>&1 \
- && xsi_shell=yes
-AC_MSG_RESULT([$xsi_shell])
-_LT_CONFIG_LIBTOOL_INIT([xsi_shell='$xsi_shell'])
-
-AC_MSG_CHECKING([whether the shell understands "+="])
-lt_shell_append=no
-( foo=bar; set foo baz; eval "$[1]+=\$[2]" && test "$foo" = barbaz ) \
- >/dev/null 2>&1 \
- && lt_shell_append=yes
-AC_MSG_RESULT([$lt_shell_append])
-_LT_CONFIG_LIBTOOL_INIT([lt_shell_append='$lt_shell_append'])
-
-if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then
+[if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then
lt_unset=unset
else
lt_unset=false
@@ -7821,102 +8319,9 @@ _LT_DECL([NL2SP], [lt_NL2SP], [1], [turn newlines into spaces])dnl
])# _LT_CHECK_SHELL_FEATURES
-# _LT_PROG_FUNCTION_REPLACE (FUNCNAME, REPLACEMENT-BODY)
-# ------------------------------------------------------
-# In `$cfgfile', look for function FUNCNAME delimited by `^FUNCNAME ()$' and
-# '^} FUNCNAME ', and replace its body with REPLACEMENT-BODY.
-m4_defun([_LT_PROG_FUNCTION_REPLACE],
-[dnl {
-sed -e '/^$1 ()$/,/^} # $1 /c\
-$1 ()\
-{\
-m4_bpatsubsts([$2], [$], [\\], [^\([ ]\)], [\\\1])
-} # Extended-shell $1 implementation' "$cfgfile" > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
-test 0 -eq $? || _lt_function_replace_fail=:
-])
-
-
-# _LT_PROG_REPLACE_SHELLFNS
-# -------------------------
-# Replace existing portable implementations of several shell functions with
-# equivalent extended shell implementations where those features are available..
-m4_defun([_LT_PROG_REPLACE_SHELLFNS],
-[if test x"$xsi_shell" = xyes; then
- _LT_PROG_FUNCTION_REPLACE([func_dirname], [dnl
- case ${1} in
- */*) func_dirname_result="${1%/*}${2}" ;;
- * ) func_dirname_result="${3}" ;;
- esac])
-
- _LT_PROG_FUNCTION_REPLACE([func_basename], [dnl
- func_basename_result="${1##*/}"])
-
- _LT_PROG_FUNCTION_REPLACE([func_dirname_and_basename], [dnl
- case ${1} in
- */*) func_dirname_result="${1%/*}${2}" ;;
- * ) func_dirname_result="${3}" ;;
- esac
- func_basename_result="${1##*/}"])
-
- _LT_PROG_FUNCTION_REPLACE([func_stripname], [dnl
- # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are
- # positional parameters, so assign one to ordinary parameter first.
- func_stripname_result=${3}
- func_stripname_result=${func_stripname_result#"${1}"}
- func_stripname_result=${func_stripname_result%"${2}"}])
-
- _LT_PROG_FUNCTION_REPLACE([func_split_long_opt], [dnl
- func_split_long_opt_name=${1%%=*}
- func_split_long_opt_arg=${1#*=}])
-
- _LT_PROG_FUNCTION_REPLACE([func_split_short_opt], [dnl
- func_split_short_opt_arg=${1#??}
- func_split_short_opt_name=${1%"$func_split_short_opt_arg"}])
-
- _LT_PROG_FUNCTION_REPLACE([func_lo2o], [dnl
- case ${1} in
- *.lo) func_lo2o_result=${1%.lo}.${objext} ;;
- *) func_lo2o_result=${1} ;;
- esac])
-
- _LT_PROG_FUNCTION_REPLACE([func_xform], [ func_xform_result=${1%.*}.lo])
-
- _LT_PROG_FUNCTION_REPLACE([func_arith], [ func_arith_result=$(( $[*] ))])
-
- _LT_PROG_FUNCTION_REPLACE([func_len], [ func_len_result=${#1}])
-fi
-
-if test x"$lt_shell_append" = xyes; then
- _LT_PROG_FUNCTION_REPLACE([func_append], [ eval "${1}+=\\${2}"])
-
- _LT_PROG_FUNCTION_REPLACE([func_append_quoted], [dnl
- func_quote_for_eval "${2}"
-dnl m4 expansion turns \\\\ into \\, and then the shell eval turns that into \
- eval "${1}+=\\\\ \\$func_quote_for_eval_result"])
-
- # Save a `func_append' function call where possible by direct use of '+='
- sed -e 's%func_append \([[a-zA-Z_]]\{1,\}\) "%\1+="%g' $cfgfile > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
- test 0 -eq $? || _lt_function_replace_fail=:
-else
- # Save a `func_append' function call even when '+=' is not available
- sed -e 's%func_append \([[a-zA-Z_]]\{1,\}\) "%\1="$\1%g' $cfgfile > $cfgfile.tmp \
- && mv -f "$cfgfile.tmp" "$cfgfile" \
- || (rm -f "$cfgfile" && cp "$cfgfile.tmp" "$cfgfile" && rm -f "$cfgfile.tmp")
- test 0 -eq $? || _lt_function_replace_fail=:
-fi
-
-if test x"$_lt_function_replace_fail" = x":"; then
- AC_MSG_WARN([Unable to substitute extended shell functions in $ofile])
-fi
-])
-
# _LT_PATH_CONVERSION_FUNCTIONS
# -----------------------------
-# Determine which file name conversion functions should be used by
+# Determine what file name conversion functions should be used by
# func_to_host_file (and, implicitly, by func_to_host_path). These are needed
# for certain cross-compile configurations and native mingw.
m4_defun([_LT_PATH_CONVERSION_FUNCTIONS],
diff --git a/lcms2mt/m4/ltoptions.m4 b/lcms2mt/m4/ltoptions.m4
index 5d9acd8e..94b08297 100644
--- a/lcms2mt/m4/ltoptions.m4
+++ b/lcms2mt/m4/ltoptions.m4
@@ -1,14 +1,14 @@
# Helper functions for option handling. -*- Autoconf -*-
#
-# Copyright (C) 2004, 2005, 2007, 2008, 2009 Free Software Foundation,
-# Inc.
+# Copyright (C) 2004-2005, 2007-2009, 2011-2015 Free Software
+# Foundation, Inc.
# Written by Gary V. Vaughan, 2004
#
# This file is free software; the Free Software Foundation gives
# unlimited permission to copy and/or distribute it, with or without
# modifications, as long as this notice is preserved.
-# serial 7 ltoptions.m4
+# serial 8 ltoptions.m4
# This is to help aclocal find these macros, as it can't see m4_define.
AC_DEFUN([LTOPTIONS_VERSION], [m4_if([1])])
@@ -29,7 +29,7 @@ m4_define([_LT_SET_OPTION],
[m4_define(_LT_MANGLE_OPTION([$1], [$2]))dnl
m4_ifdef(_LT_MANGLE_DEFUN([$1], [$2]),
_LT_MANGLE_DEFUN([$1], [$2]),
- [m4_warning([Unknown $1 option `$2'])])[]dnl
+ [m4_warning([Unknown $1 option '$2'])])[]dnl
])
@@ -75,13 +75,15 @@ m4_if([$1],[LT_INIT],[
dnl
dnl If no reference was made to various pairs of opposing options, then
dnl we run the default mode handler for the pair. For example, if neither
- dnl `shared' nor `disable-shared' was passed, we enable building of shared
+ dnl 'shared' nor 'disable-shared' was passed, we enable building of shared
dnl archives by default:
_LT_UNLESS_OPTIONS([LT_INIT], [shared disable-shared], [_LT_ENABLE_SHARED])
_LT_UNLESS_OPTIONS([LT_INIT], [static disable-static], [_LT_ENABLE_STATIC])
_LT_UNLESS_OPTIONS([LT_INIT], [pic-only no-pic], [_LT_WITH_PIC])
_LT_UNLESS_OPTIONS([LT_INIT], [fast-install disable-fast-install],
- [_LT_ENABLE_FAST_INSTALL])
+ [_LT_ENABLE_FAST_INSTALL])
+ _LT_UNLESS_OPTIONS([LT_INIT], [aix-soname=aix aix-soname=both aix-soname=svr4],
+ [_LT_WITH_AIX_SONAME([aix])])
])
])# _LT_SET_OPTIONS
@@ -112,7 +114,7 @@ AU_DEFUN([AC_LIBTOOL_DLOPEN],
[_LT_SET_OPTION([LT_INIT], [dlopen])
AC_DIAGNOSE([obsolete],
[$0: Remove this warning and the call to _LT_SET_OPTION when you
-put the `dlopen' option into LT_INIT's first parameter.])
+put the 'dlopen' option into LT_INIT's first parameter.])
])
dnl aclocal-1.4 backwards compatibility:
@@ -148,7 +150,7 @@ AU_DEFUN([AC_LIBTOOL_WIN32_DLL],
_LT_SET_OPTION([LT_INIT], [win32-dll])
AC_DIAGNOSE([obsolete],
[$0: Remove this warning and the call to _LT_SET_OPTION when you
-put the `win32-dll' option into LT_INIT's first parameter.])
+put the 'win32-dll' option into LT_INIT's first parameter.])
])
dnl aclocal-1.4 backwards compatibility:
@@ -157,9 +159,9 @@ dnl AC_DEFUN([AC_LIBTOOL_WIN32_DLL], [])
# _LT_ENABLE_SHARED([DEFAULT])
# ----------------------------
-# implement the --enable-shared flag, and supports the `shared' and
-# `disable-shared' LT_INIT options.
-# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'.
+# implement the --enable-shared flag, and supports the 'shared' and
+# 'disable-shared' LT_INIT options.
+# DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'.
m4_define([_LT_ENABLE_SHARED],
[m4_define([_LT_ENABLE_SHARED_DEFAULT], [m4_if($1, no, no, yes)])dnl
AC_ARG_ENABLE([shared],
@@ -172,14 +174,14 @@ AC_ARG_ENABLE([shared],
*)
enable_shared=no
# Look at the argument we got. We use all the common list separators.
- lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+ lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
for pkg in $enableval; do
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
if test "X$pkg" = "X$p"; then
enable_shared=yes
fi
done
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
;;
esac],
[enable_shared=]_LT_ENABLE_SHARED_DEFAULT)
@@ -211,9 +213,9 @@ dnl AC_DEFUN([AM_DISABLE_SHARED], [])
# _LT_ENABLE_STATIC([DEFAULT])
# ----------------------------
-# implement the --enable-static flag, and support the `static' and
-# `disable-static' LT_INIT options.
-# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'.
+# implement the --enable-static flag, and support the 'static' and
+# 'disable-static' LT_INIT options.
+# DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'.
m4_define([_LT_ENABLE_STATIC],
[m4_define([_LT_ENABLE_STATIC_DEFAULT], [m4_if($1, no, no, yes)])dnl
AC_ARG_ENABLE([static],
@@ -226,14 +228,14 @@ AC_ARG_ENABLE([static],
*)
enable_static=no
# Look at the argument we got. We use all the common list separators.
- lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+ lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
for pkg in $enableval; do
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
if test "X$pkg" = "X$p"; then
enable_static=yes
fi
done
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
;;
esac],
[enable_static=]_LT_ENABLE_STATIC_DEFAULT)
@@ -265,9 +267,9 @@ dnl AC_DEFUN([AM_DISABLE_STATIC], [])
# _LT_ENABLE_FAST_INSTALL([DEFAULT])
# ----------------------------------
-# implement the --enable-fast-install flag, and support the `fast-install'
-# and `disable-fast-install' LT_INIT options.
-# DEFAULT is either `yes' or `no'. If omitted, it defaults to `yes'.
+# implement the --enable-fast-install flag, and support the 'fast-install'
+# and 'disable-fast-install' LT_INIT options.
+# DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'.
m4_define([_LT_ENABLE_FAST_INSTALL],
[m4_define([_LT_ENABLE_FAST_INSTALL_DEFAULT], [m4_if($1, no, no, yes)])dnl
AC_ARG_ENABLE([fast-install],
@@ -280,14 +282,14 @@ AC_ARG_ENABLE([fast-install],
*)
enable_fast_install=no
# Look at the argument we got. We use all the common list separators.
- lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+ lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
for pkg in $enableval; do
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
if test "X$pkg" = "X$p"; then
enable_fast_install=yes
fi
done
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
;;
esac],
[enable_fast_install=]_LT_ENABLE_FAST_INSTALL_DEFAULT)
@@ -304,14 +306,14 @@ AU_DEFUN([AC_ENABLE_FAST_INSTALL],
[_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[fast-install])
AC_DIAGNOSE([obsolete],
[$0: Remove this warning and the call to _LT_SET_OPTION when you put
-the `fast-install' option into LT_INIT's first parameter.])
+the 'fast-install' option into LT_INIT's first parameter.])
])
AU_DEFUN([AC_DISABLE_FAST_INSTALL],
[_LT_SET_OPTION([LT_INIT], [disable-fast-install])
AC_DIAGNOSE([obsolete],
[$0: Remove this warning and the call to _LT_SET_OPTION when you put
-the `disable-fast-install' option into LT_INIT's first parameter.])
+the 'disable-fast-install' option into LT_INIT's first parameter.])
])
dnl aclocal-1.4 backwards compatibility:
@@ -319,11 +321,64 @@ dnl AC_DEFUN([AC_ENABLE_FAST_INSTALL], [])
dnl AC_DEFUN([AM_DISABLE_FAST_INSTALL], [])
+# _LT_WITH_AIX_SONAME([DEFAULT])
+# ----------------------------------
+# implement the --with-aix-soname flag, and support the `aix-soname=aix'
+# and `aix-soname=both' and `aix-soname=svr4' LT_INIT options. DEFAULT
+# is either `aix', `both' or `svr4'. If omitted, it defaults to `aix'.
+m4_define([_LT_WITH_AIX_SONAME],
+[m4_define([_LT_WITH_AIX_SONAME_DEFAULT], [m4_if($1, svr4, svr4, m4_if($1, both, both, aix))])dnl
+shared_archive_member_spec=
+case $host,$enable_shared in
+power*-*-aix[[5-9]]*,yes)
+ AC_MSG_CHECKING([which variant of shared library versioning to provide])
+ AC_ARG_WITH([aix-soname],
+ [AS_HELP_STRING([--with-aix-soname=aix|svr4|both],
+ [shared library versioning (aka "SONAME") variant to provide on AIX, @<:@default=]_LT_WITH_AIX_SONAME_DEFAULT[@:>@.])],
+ [case $withval in
+ aix|svr4|both)
+ ;;
+ *)
+ AC_MSG_ERROR([Unknown argument to --with-aix-soname])
+ ;;
+ esac
+ lt_cv_with_aix_soname=$with_aix_soname],
+ [AC_CACHE_VAL([lt_cv_with_aix_soname],
+ [lt_cv_with_aix_soname=]_LT_WITH_AIX_SONAME_DEFAULT)
+ with_aix_soname=$lt_cv_with_aix_soname])
+ AC_MSG_RESULT([$with_aix_soname])
+ if test aix != "$with_aix_soname"; then
+ # For the AIX way of multilib, we name the shared archive member
+ # based on the bitwidth used, traditionally 'shr.o' or 'shr_64.o',
+ # and 'shr.imp' or 'shr_64.imp', respectively, for the Import File.
+ # Even when GNU compilers ignore OBJECT_MODE but need '-maix64' flag,
+ # the AIX toolchain works better with OBJECT_MODE set (default 32).
+ if test 64 = "${OBJECT_MODE-32}"; then
+ shared_archive_member_spec=shr_64
+ else
+ shared_archive_member_spec=shr
+ fi
+ fi
+ ;;
+*)
+ with_aix_soname=aix
+ ;;
+esac
+
+_LT_DECL([], [shared_archive_member_spec], [0],
+ [Shared archive member basename, for filename based shared library versioning on AIX])dnl
+])# _LT_WITH_AIX_SONAME
+
+LT_OPTION_DEFINE([LT_INIT], [aix-soname=aix], [_LT_WITH_AIX_SONAME([aix])])
+LT_OPTION_DEFINE([LT_INIT], [aix-soname=both], [_LT_WITH_AIX_SONAME([both])])
+LT_OPTION_DEFINE([LT_INIT], [aix-soname=svr4], [_LT_WITH_AIX_SONAME([svr4])])
+
+
# _LT_WITH_PIC([MODE])
# --------------------
-# implement the --with-pic flag, and support the `pic-only' and `no-pic'
+# implement the --with-pic flag, and support the 'pic-only' and 'no-pic'
# LT_INIT options.
-# MODE is either `yes' or `no'. If omitted, it defaults to `both'.
+# MODE is either 'yes' or 'no'. If omitted, it defaults to 'both'.
m4_define([_LT_WITH_PIC],
[AC_ARG_WITH([pic],
[AS_HELP_STRING([--with-pic@<:@=PKGS@:>@],
@@ -334,19 +389,17 @@ m4_define([_LT_WITH_PIC],
*)
pic_mode=default
# Look at the argument we got. We use all the common list separators.
- lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
+ lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR,
for lt_pkg in $withval; do
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
if test "X$lt_pkg" = "X$lt_p"; then
pic_mode=yes
fi
done
- IFS="$lt_save_ifs"
+ IFS=$lt_save_ifs
;;
esac],
- [pic_mode=default])
-
-test -z "$pic_mode" && pic_mode=m4_default([$1], [default])
+ [pic_mode=m4_default([$1], [default])])
_LT_DECL([], [pic_mode], [0], [What type of objects to build])dnl
])# _LT_WITH_PIC
@@ -359,7 +412,7 @@ AU_DEFUN([AC_LIBTOOL_PICMODE],
[_LT_SET_OPTION([LT_INIT], [pic-only])
AC_DIAGNOSE([obsolete],
[$0: Remove this warning and the call to _LT_SET_OPTION when you
-put the `pic-only' option into LT_INIT's first parameter.])
+put the 'pic-only' option into LT_INIT's first parameter.])
])
dnl aclocal-1.4 backwards compatibility:
diff --git a/lcms2mt/m4/ltsugar.m4 b/lcms2mt/m4/ltsugar.m4
index 9000a057..48bc9344 100644
--- a/lcms2mt/m4/ltsugar.m4
+++ b/lcms2mt/m4/ltsugar.m4
@@ -1,6 +1,7 @@
# ltsugar.m4 -- libtool m4 base layer. -*-Autoconf-*-
#
-# Copyright (C) 2004, 2005, 2007, 2008 Free Software Foundation, Inc.
+# Copyright (C) 2004-2005, 2007-2008, 2011-2015 Free Software
+# Foundation, Inc.
# Written by Gary V. Vaughan, 2004
#
# This file is free software; the Free Software Foundation gives
@@ -33,7 +34,7 @@ m4_define([_lt_join],
# ------------
# Manipulate m4 lists.
# These macros are necessary as long as will still need to support
-# Autoconf-2.59 which quotes differently.
+# Autoconf-2.59, which quotes differently.
m4_define([lt_car], [[$1]])
m4_define([lt_cdr],
[m4_if([$#], 0, [m4_fatal([$0: cannot be called without arguments])],
@@ -44,7 +45,7 @@ m4_define([lt_unquote], $1)
# lt_append(MACRO-NAME, STRING, [SEPARATOR])
# ------------------------------------------
-# Redefine MACRO-NAME to hold its former content plus `SEPARATOR'`STRING'.
+# Redefine MACRO-NAME to hold its former content plus 'SEPARATOR''STRING'.
# Note that neither SEPARATOR nor STRING are expanded; they are appended
# to MACRO-NAME as is (leaving the expansion for when MACRO-NAME is invoked).
# No SEPARATOR is output if MACRO-NAME was previously undefined (different
diff --git a/lcms2mt/m4/ltversion.m4 b/lcms2mt/m4/ltversion.m4
index 07a8602d..fa04b52a 100644
--- a/lcms2mt/m4/ltversion.m4
+++ b/lcms2mt/m4/ltversion.m4
@@ -1,6 +1,6 @@
# ltversion.m4 -- version numbers -*- Autoconf -*-
#
-# Copyright (C) 2004 Free Software Foundation, Inc.
+# Copyright (C) 2004, 2011-2015 Free Software Foundation, Inc.
# Written by Scott James Remnant, 2004
#
# This file is free software; the Free Software Foundation gives
@@ -9,15 +9,15 @@
# @configure_input@
-# serial 3337 ltversion.m4
+# serial 4179 ltversion.m4
# This file is part of GNU Libtool
-m4_define([LT_PACKAGE_VERSION], [2.4.2])
-m4_define([LT_PACKAGE_REVISION], [1.3337])
+m4_define([LT_PACKAGE_VERSION], [2.4.6])
+m4_define([LT_PACKAGE_REVISION], [2.4.6])
AC_DEFUN([LTVERSION_VERSION],
-[macro_version='2.4.2'
-macro_revision='1.3337'
+[macro_version='2.4.6'
+macro_revision='2.4.6'
_LT_DECL(, macro_version, 0, [Which release of libtool.m4 was used?])
_LT_DECL(, macro_revision, 0)
])
diff --git a/lcms2mt/m4/lt~obsolete.m4 b/lcms2mt/m4/lt~obsolete.m4
index c573da90..c6b26f88 100644
--- a/lcms2mt/m4/lt~obsolete.m4
+++ b/lcms2mt/m4/lt~obsolete.m4
@@ -1,6 +1,7 @@
# lt~obsolete.m4 -- aclocal satisfying obsolete definitions. -*-Autoconf-*-
#
-# Copyright (C) 2004, 2005, 2007, 2009 Free Software Foundation, Inc.
+# Copyright (C) 2004-2005, 2007, 2009, 2011-2015 Free Software
+# Foundation, Inc.
# Written by Scott James Remnant, 2004.
#
# This file is free software; the Free Software Foundation gives
@@ -11,7 +12,7 @@
# These exist entirely to fool aclocal when bootstrapping libtool.
#
-# In the past libtool.m4 has provided macros via AC_DEFUN (or AU_DEFUN)
+# In the past libtool.m4 has provided macros via AC_DEFUN (or AU_DEFUN),
# which have later been changed to m4_define as they aren't part of the
# exported API, or moved to Autoconf or Automake where they belong.
#
@@ -25,7 +26,7 @@
# included after everything else. This provides aclocal with the
# AC_DEFUNs it wants, but when m4 processes it, it doesn't do anything
# because those macros already exist, or will be overwritten later.
-# We use AC_DEFUN over AU_DEFUN for compatibility with aclocal-1.6.
+# We use AC_DEFUN over AU_DEFUN for compatibility with aclocal-1.6.
#
# Anytime we withdraw an AC_DEFUN or AU_DEFUN, remember to add it here.
# Yes, that means every name once taken will need to remain here until
diff --git a/lcms2mt/plugins/Makefile.am b/lcms2mt/plugins/Makefile.am
new file mode 100644
index 00000000..3e04f597
--- /dev/null
+++ b/lcms2mt/plugins/Makefile.am
@@ -0,0 +1 @@
+SUBDIRS = fast_float
diff --git a/lcms2mt/plugins/Makefile.in b/lcms2mt/plugins/Makefile.in
new file mode 100644
index 00000000..3ee88dea
--- /dev/null
+++ b/lcms2mt/plugins/Makefile.in
@@ -0,0 +1,646 @@
+# Makefile.in generated by automake 1.15.1 from Makefile.am.
+# @configure_input@
+
+# Copyright (C) 1994-2017 Free Software Foundation, Inc.
+
+# This Makefile.in is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+@SET_MAKE@
+VPATH = @srcdir@
+am__is_gnu_make = { \
+ if test -z '$(MAKELEVEL)'; then \
+ false; \
+ elif test -n '$(MAKE_HOST)'; then \
+ true; \
+ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \
+ true; \
+ else \
+ false; \
+ fi; \
+}
+am__make_running_with_option = \
+ case $${target_option-} in \
+ ?) ;; \
+ *) echo "am__make_running_with_option: internal error: invalid" \
+ "target option '$${target_option-}' specified" >&2; \
+ exit 1;; \
+ esac; \
+ has_opt=no; \
+ sane_makeflags=$$MAKEFLAGS; \
+ if $(am__is_gnu_make); then \
+ sane_makeflags=$$MFLAGS; \
+ else \
+ case $$MAKEFLAGS in \
+ *\\[\ \ ]*) \
+ bs=\\; \
+ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \
+ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \
+ esac; \
+ fi; \
+ skip_next=no; \
+ strip_trailopt () \
+ { \
+ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \
+ }; \
+ for flg in $$sane_makeflags; do \
+ test $$skip_next = yes && { skip_next=no; continue; }; \
+ case $$flg in \
+ *=*|--*) continue;; \
+ -*I) strip_trailopt 'I'; skip_next=yes;; \
+ -*I?*) strip_trailopt 'I';; \
+ -*O) strip_trailopt 'O'; skip_next=yes;; \
+ -*O?*) strip_trailopt 'O';; \
+ -*l) strip_trailopt 'l'; skip_next=yes;; \
+ -*l?*) strip_trailopt 'l';; \
+ -[dEDm]) skip_next=yes;; \
+ -[JT]) skip_next=yes;; \
+ esac; \
+ case $$flg in \
+ *$$target_option*) has_opt=yes; break;; \
+ esac; \
+ done; \
+ test $$has_opt = yes
+am__make_dryrun = (target_option=n; $(am__make_running_with_option))
+am__make_keepgoing = (target_option=k; $(am__make_running_with_option))
+pkgdatadir = $(datadir)/@PACKAGE@
+pkgincludedir = $(includedir)/@PACKAGE@
+pkglibdir = $(libdir)/@PACKAGE@
+pkglibexecdir = $(libexecdir)/@PACKAGE@
+am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
+install_sh_DATA = $(install_sh) -c -m 644
+install_sh_PROGRAM = $(install_sh) -c
+install_sh_SCRIPT = $(install_sh) -c
+INSTALL_HEADER = $(INSTALL_DATA)
+transform = $(program_transform_name)
+NORMAL_INSTALL = :
+PRE_INSTALL = :
+POST_INSTALL = :
+NORMAL_UNINSTALL = :
+PRE_UNINSTALL = :
+POST_UNINSTALL = :
+build_triplet = @build@
+host_triplet = @host@
+subdir = plugins
+ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
+am__aclocal_m4_deps = $(top_srcdir)/m4/acx_pthread.m4 \
+ $(top_srcdir)/m4/ax_append_compile_flags.m4 \
+ $(top_srcdir)/m4/ax_append_flag.m4 \
+ $(top_srcdir)/m4/ax_check_compile_flag.m4 \
+ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \
+ $(top_srcdir)/m4/ax_require_defined.m4 \
+ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \
+ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \
+ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/configure.ac
+am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
+ $(ACLOCAL_M4)
+DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON)
+mkinstalldirs = $(install_sh) -d
+CONFIG_CLEAN_FILES =
+CONFIG_CLEAN_VPATH_FILES =
+AM_V_P = $(am__v_P_@AM_V@)
+am__v_P_ = $(am__v_P_@AM_DEFAULT_V@)
+am__v_P_0 = false
+am__v_P_1 = :
+AM_V_GEN = $(am__v_GEN_@AM_V@)
+am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@)
+am__v_GEN_0 = @echo " GEN " $@;
+am__v_GEN_1 =
+AM_V_at = $(am__v_at_@AM_V@)
+am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
+am__v_at_0 = @
+am__v_at_1 =
+SOURCES =
+DIST_SOURCES =
+RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \
+ ctags-recursive dvi-recursive html-recursive info-recursive \
+ install-data-recursive install-dvi-recursive \
+ install-exec-recursive install-html-recursive \
+ install-info-recursive install-pdf-recursive \
+ install-ps-recursive install-recursive installcheck-recursive \
+ installdirs-recursive pdf-recursive ps-recursive \
+ tags-recursive uninstall-recursive
+am__can_run_installinfo = \
+ case $$AM_UPDATE_INFO_DIR in \
+ n|no|NO) false;; \
+ *) (install-info --version) >/dev/null 2>&1;; \
+ esac
+RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive \
+ distclean-recursive maintainer-clean-recursive
+am__recursive_targets = \
+ $(RECURSIVE_TARGETS) \
+ $(RECURSIVE_CLEAN_TARGETS) \
+ $(am__extra_recursive_targets)
+AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \
+ distdir
+am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP)
+# Read a list of newline-separated strings from the standard input,
+# and print each of them once, without duplicates. Input order is
+# *not* preserved.
+am__uniquify_input = $(AWK) '\
+ BEGIN { nonempty = 0; } \
+ { items[$$0] = 1; nonempty = 1; } \
+ END { if (nonempty) { for (i in items) print i; }; } \
+'
+# Make sure the list of sources is unique. This is necessary because,
+# e.g., the same source file might be shared among _SOURCES variables
+# for different programs/libraries.
+am__define_uniq_tagged_files = \
+ list='$(am__tagged_files)'; \
+ unique=`for i in $$list; do \
+ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+ done | $(am__uniquify_input)`
+ETAGS = etags
+CTAGS = ctags
+DIST_SUBDIRS = $(SUBDIRS)
+am__DIST_COMMON = $(srcdir)/Makefile.in
+DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
+am__relativize = \
+ dir0=`pwd`; \
+ sed_first='s,^\([^/]*\)/.*$$,\1,'; \
+ sed_rest='s,^[^/]*/*,,'; \
+ sed_last='s,^.*/\([^/]*\)$$,\1,'; \
+ sed_butlast='s,/*[^/]*$$,,'; \
+ while test -n "$$dir1"; do \
+ first=`echo "$$dir1" | sed -e "$$sed_first"`; \
+ if test "$$first" != "."; then \
+ if test "$$first" = ".."; then \
+ dir2=`echo "$$dir0" | sed -e "$$sed_last"`/"$$dir2"; \
+ dir0=`echo "$$dir0" | sed -e "$$sed_butlast"`; \
+ else \
+ first2=`echo "$$dir2" | sed -e "$$sed_first"`; \
+ if test "$$first2" = "$$first"; then \
+ dir2=`echo "$$dir2" | sed -e "$$sed_rest"`; \
+ else \
+ dir2="../$$dir2"; \
+ fi; \
+ dir0="$$dir0"/"$$first"; \
+ fi; \
+ fi; \
+ dir1=`echo "$$dir1" | sed -e "$$sed_rest"`; \
+ done; \
+ reldir="$$dir2"
+ACLOCAL = @ACLOCAL@
+AMTAR = @AMTAR@
+AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@
+AR = @AR@
+AS = @AS@
+AUTOCONF = @AUTOCONF@
+AUTOHEADER = @AUTOHEADER@
+AUTOMAKE = @AUTOMAKE@
+AWK = @AWK@
+CC = @CC@
+CCDEPMODE = @CCDEPMODE@
+CFLAGS = @CFLAGS@
+CPP = @CPP@
+CPPFLAGS = @CPPFLAGS@
+CXX = @CXX@
+CXXCPP = @CXXCPP@
+CXXDEPMODE = @CXXDEPMODE@
+CXXFLAGS = @CXXFLAGS@
+CYGPATH_W = @CYGPATH_W@
+DEFS = @DEFS@
+DEPDIR = @DEPDIR@
+DLLTOOL = @DLLTOOL@
+DSYMUTIL = @DSYMUTIL@
+DUMPBIN = @DUMPBIN@
+ECHO_C = @ECHO_C@
+ECHO_N = @ECHO_N@
+ECHO_T = @ECHO_T@
+EGREP = @EGREP@
+EXEEXT = @EXEEXT@
+FGREP = @FGREP@
+GREP = @GREP@
+INSTALL = @INSTALL@
+INSTALL_DATA = @INSTALL_DATA@
+INSTALL_PROGRAM = @INSTALL_PROGRAM@
+INSTALL_SCRIPT = @INSTALL_SCRIPT@
+INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
+JPEGICC_DEPLIBS = @JPEGICC_DEPLIBS@
+LCMS_LIB_DEPLIBS = @LCMS_LIB_DEPLIBS@
+LD = @LD@
+LDFLAGS = @LDFLAGS@
+LIBOBJS = @LIBOBJS@
+LIBRARY_AGE = @LIBRARY_AGE@
+LIBRARY_CURRENT = @LIBRARY_CURRENT@
+LIBRARY_REVISION = @LIBRARY_REVISION@
+LIBS = @LIBS@
+LIBTOOL = @LIBTOOL@
+LIBTOOL_DEPS = @LIBTOOL_DEPS@
+LIB_JPEG = @LIB_JPEG@
+LIB_MATH = @LIB_MATH@
+LIB_PLUGINS = @LIB_PLUGINS@
+LIB_THREAD = @LIB_THREAD@
+LIB_TIFF = @LIB_TIFF@
+LIB_ZLIB = @LIB_ZLIB@
+LIPO = @LIPO@
+LN_S = @LN_S@
+LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
+MAINT = @MAINT@
+MAKEINFO = @MAKEINFO@
+MANIFEST_TOOL = @MANIFEST_TOOL@
+MKDIR_P = @MKDIR_P@
+NM = @NM@
+NMEDIT = @NMEDIT@
+OBJDUMP = @OBJDUMP@
+OBJEXT = @OBJEXT@
+OTOOL = @OTOOL@
+OTOOL64 = @OTOOL64@
+PACKAGE = @PACKAGE@
+PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
+PACKAGE_NAME = @PACKAGE_NAME@
+PACKAGE_STRING = @PACKAGE_STRING@
+PACKAGE_TARNAME = @PACKAGE_TARNAME@
+PACKAGE_URL = @PACKAGE_URL@
+PACKAGE_VERSION = @PACKAGE_VERSION@
+PATH_SEPARATOR = @PATH_SEPARATOR@
+PTHREAD_CC = @PTHREAD_CC@
+PTHREAD_CFLAGS = @PTHREAD_CFLAGS@
+PTHREAD_CXX = @PTHREAD_CXX@
+PTHREAD_LIBS = @PTHREAD_LIBS@
+RANLIB = @RANLIB@
+SED = @SED@
+SET_MAKE = @SET_MAKE@
+SHELL = @SHELL@
+STRIP = @STRIP@
+TIFFICC_DEPLIBS = @TIFFICC_DEPLIBS@
+VERSION = @VERSION@
+abs_builddir = @abs_builddir@
+abs_srcdir = @abs_srcdir@
+abs_top_builddir = @abs_top_builddir@
+abs_top_srcdir = @abs_top_srcdir@
+ac_ct_AR = @ac_ct_AR@
+ac_ct_CC = @ac_ct_CC@
+ac_ct_CXX = @ac_ct_CXX@
+ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
+acx_pthread_config = @acx_pthread_config@
+am__include = @am__include@
+am__leading_dot = @am__leading_dot@
+am__quote = @am__quote@
+am__tar = @am__tar@
+am__untar = @am__untar@
+bindir = @bindir@
+build = @build@
+build_alias = @build_alias@
+build_cpu = @build_cpu@
+build_os = @build_os@
+build_vendor = @build_vendor@
+builddir = @builddir@
+datadir = @datadir@
+datarootdir = @datarootdir@
+docdir = @docdir@
+dvidir = @dvidir@
+exec_prefix = @exec_prefix@
+host = @host@
+host_alias = @host_alias@
+host_cpu = @host_cpu@
+host_os = @host_os@
+host_vendor = @host_vendor@
+htmldir = @htmldir@
+includedir = @includedir@
+infodir = @infodir@
+inline = @inline@
+install_sh = @install_sh@
+libdir = @libdir@
+libexecdir = @libexecdir@
+localedir = @localedir@
+localstatedir = @localstatedir@
+mandir = @mandir@
+mkdir_p = @mkdir_p@
+oldincludedir = @oldincludedir@
+pdfdir = @pdfdir@
+prefix = @prefix@
+program_transform_name = @program_transform_name@
+psdir = @psdir@
+runstatedir = @runstatedir@
+sbindir = @sbindir@
+sharedstatedir = @sharedstatedir@
+srcdir = @srcdir@
+sysconfdir = @sysconfdir@
+target_alias = @target_alias@
+top_build_prefix = @top_build_prefix@
+top_builddir = @top_builddir@
+top_srcdir = @top_srcdir@
+SUBDIRS = fast_float
+all: all-recursive
+
+.SUFFIXES:
+$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.am $(am__configure_deps)
+ @for dep in $?; do \
+ case '$(am__configure_deps)' in \
+ *$$dep*) \
+ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \
+ && { if test -f $@; then exit 0; else break; fi; }; \
+ exit 1;; \
+ esac; \
+ done; \
+ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign plugins/Makefile'; \
+ $(am__cd) $(top_srcdir) && \
+ $(AUTOMAKE) --foreign plugins/Makefile
+Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
+ @case '$?' in \
+ *config.status*) \
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
+ *) \
+ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
+ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
+ esac;
+
+$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
+
+$(top_srcdir)/configure: @MAINTAINER_MODE_TRUE@ $(am__configure_deps)
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
+$(ACLOCAL_M4): @MAINTAINER_MODE_TRUE@ $(am__aclocal_m4_deps)
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
+$(am__aclocal_m4_deps):
+
+mostlyclean-libtool:
+ -rm -f *.lo
+
+clean-libtool:
+ -rm -rf .libs _libs
+
+# This directory's subdirectories are mostly independent; you can cd
+# into them and run 'make' without going through this Makefile.
+# To change the values of 'make' variables: instead of editing Makefiles,
+# (1) if the variable is set in 'config.status', edit 'config.status'
+# (which will cause the Makefiles to be regenerated when you run 'make');
+# (2) otherwise, pass the desired values on the 'make' command line.
+$(am__recursive_targets):
+ @fail=; \
+ if $(am__make_keepgoing); then \
+ failcom='fail=yes'; \
+ else \
+ failcom='exit 1'; \
+ fi; \
+ dot_seen=no; \
+ target=`echo $@ | sed s/-recursive//`; \
+ case "$@" in \
+ distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \
+ *) list='$(SUBDIRS)' ;; \
+ esac; \
+ for subdir in $$list; do \
+ echo "Making $$target in $$subdir"; \
+ if test "$$subdir" = "."; then \
+ dot_seen=yes; \
+ local_target="$$target-am"; \
+ else \
+ local_target="$$target"; \
+ fi; \
+ ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
+ || eval $$failcom; \
+ done; \
+ if test "$$dot_seen" = "no"; then \
+ $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \
+ fi; test -z "$$fail"
+
+ID: $(am__tagged_files)
+ $(am__define_uniq_tagged_files); mkid -fID $$unique
+tags: tags-recursive
+TAGS: tags
+
+tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
+ set x; \
+ here=`pwd`; \
+ if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \
+ include_option=--etags-include; \
+ empty_fix=.; \
+ else \
+ include_option=--include; \
+ empty_fix=; \
+ fi; \
+ list='$(SUBDIRS)'; for subdir in $$list; do \
+ if test "$$subdir" = .; then :; else \
+ test ! -f $$subdir/TAGS || \
+ set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \
+ fi; \
+ done; \
+ $(am__define_uniq_tagged_files); \
+ shift; \
+ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
+ test -n "$$unique" || unique=$$empty_fix; \
+ if test $$# -gt 0; then \
+ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+ "$$@" $$unique; \
+ else \
+ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+ $$unique; \
+ fi; \
+ fi
+ctags: ctags-recursive
+
+CTAGS: ctags
+ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
+ $(am__define_uniq_tagged_files); \
+ test -z "$(CTAGS_ARGS)$$unique" \
+ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
+ $$unique
+
+GTAGS:
+ here=`$(am__cd) $(top_builddir) && pwd` \
+ && $(am__cd) $(top_srcdir) \
+ && gtags -i $(GTAGS_ARGS) "$$here"
+cscopelist: cscopelist-recursive
+
+cscopelist-am: $(am__tagged_files)
+ list='$(am__tagged_files)'; \
+ case "$(srcdir)" in \
+ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \
+ *) sdir=$(subdir)/$(srcdir) ;; \
+ esac; \
+ for i in $$list; do \
+ if test -f "$$i"; then \
+ echo "$(subdir)/$$i"; \
+ else \
+ echo "$$sdir/$$i"; \
+ fi; \
+ done >> $(top_builddir)/cscope.files
+
+distclean-tags:
+ -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
+
+distdir: $(DISTFILES)
+ @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
+ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
+ list='$(DISTFILES)'; \
+ dist_files=`for file in $$list; do echo $$file; done | \
+ sed -e "s|^$$srcdirstrip/||;t" \
+ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \
+ case $$dist_files in \
+ */*) $(MKDIR_P) `echo "$$dist_files" | \
+ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \
+ sort -u` ;; \
+ esac; \
+ for file in $$dist_files; do \
+ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
+ if test -d $$d/$$file; then \
+ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
+ if test -d "$(distdir)/$$file"; then \
+ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
+ fi; \
+ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \
+ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
+ fi; \
+ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \
+ else \
+ test -f "$(distdir)/$$file" \
+ || cp -p $$d/$$file "$(distdir)/$$file" \
+ || exit 1; \
+ fi; \
+ done
+ @list='$(DIST_SUBDIRS)'; for subdir in $$list; do \
+ if test "$$subdir" = .; then :; else \
+ $(am__make_dryrun) \
+ || test -d "$(distdir)/$$subdir" \
+ || $(MKDIR_P) "$(distdir)/$$subdir" \
+ || exit 1; \
+ dir1=$$subdir; dir2="$(distdir)/$$subdir"; \
+ $(am__relativize); \
+ new_distdir=$$reldir; \
+ dir1=$$subdir; dir2="$(top_distdir)"; \
+ $(am__relativize); \
+ new_top_distdir=$$reldir; \
+ echo " (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir="$$new_top_distdir" distdir="$$new_distdir" \\"; \
+ echo " am__remove_distdir=: am__skip_length_check=: am__skip_mode_fix=: distdir)"; \
+ ($(am__cd) $$subdir && \
+ $(MAKE) $(AM_MAKEFLAGS) \
+ top_distdir="$$new_top_distdir" \
+ distdir="$$new_distdir" \
+ am__remove_distdir=: \
+ am__skip_length_check=: \
+ am__skip_mode_fix=: \
+ distdir) \
+ || exit 1; \
+ fi; \
+ done
+check-am: all-am
+check: check-recursive
+all-am: Makefile
+installdirs: installdirs-recursive
+installdirs-am:
+install: install-recursive
+install-exec: install-exec-recursive
+install-data: install-data-recursive
+uninstall: uninstall-recursive
+
+install-am: all-am
+ @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
+
+installcheck: installcheck-recursive
+install-strip:
+ if test -z '$(STRIP)'; then \
+ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
+ install; \
+ else \
+ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
+ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \
+ fi
+mostlyclean-generic:
+
+clean-generic:
+
+distclean-generic:
+ -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
+ -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
+
+maintainer-clean-generic:
+ @echo "This command is intended for maintainers to use"
+ @echo "it deletes files that may require special tools to rebuild."
+clean: clean-recursive
+
+clean-am: clean-generic clean-libtool mostlyclean-am
+
+distclean: distclean-recursive
+ -rm -f Makefile
+distclean-am: clean-am distclean-generic distclean-tags
+
+dvi: dvi-recursive
+
+dvi-am:
+
+html: html-recursive
+
+html-am:
+
+info: info-recursive
+
+info-am:
+
+install-data-am:
+
+install-dvi: install-dvi-recursive
+
+install-dvi-am:
+
+install-exec-am:
+
+install-html: install-html-recursive
+
+install-html-am:
+
+install-info: install-info-recursive
+
+install-info-am:
+
+install-man:
+
+install-pdf: install-pdf-recursive
+
+install-pdf-am:
+
+install-ps: install-ps-recursive
+
+install-ps-am:
+
+installcheck-am:
+
+maintainer-clean: maintainer-clean-recursive
+ -rm -f Makefile
+maintainer-clean-am: distclean-am maintainer-clean-generic
+
+mostlyclean: mostlyclean-recursive
+
+mostlyclean-am: mostlyclean-generic mostlyclean-libtool
+
+pdf: pdf-recursive
+
+pdf-am:
+
+ps: ps-recursive
+
+ps-am:
+
+uninstall-am:
+
+.MAKE: $(am__recursive_targets) install-am install-strip
+
+.PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am check \
+ check-am clean clean-generic clean-libtool cscopelist-am ctags \
+ ctags-am distclean distclean-generic distclean-libtool \
+ distclean-tags distdir dvi dvi-am html html-am info info-am \
+ install install-am install-data install-data-am install-dvi \
+ install-dvi-am install-exec install-exec-am install-html \
+ install-html-am install-info install-info-am install-man \
+ install-pdf install-pdf-am install-ps install-ps-am \
+ install-strip installcheck installcheck-am installdirs \
+ installdirs-am maintainer-clean maintainer-clean-generic \
+ mostlyclean mostlyclean-generic mostlyclean-libtool pdf pdf-am \
+ ps ps-am tags tags-am uninstall uninstall-am
+
+.PRECIOUS: Makefile
+
+
+# Tell versions [3.59,3.63) of GNU make to not export all variables.
+# Otherwise a system limit (for SysV at least) may be exceeded.
+.NOEXPORT:
diff --git a/lcms2mt/plugins/fast_float/Makefile.am b/lcms2mt/plugins/fast_float/Makefile.am
new file mode 100644
index 00000000..625c93b5
--- /dev/null
+++ b/lcms2mt/plugins/fast_float/Makefile.am
@@ -0,0 +1 @@
+SUBDIRS = src include testbed
diff --git a/lcms2mt/plugins/fast_float/Makefile.in b/lcms2mt/plugins/fast_float/Makefile.in
new file mode 100644
index 00000000..655c5728
--- /dev/null
+++ b/lcms2mt/plugins/fast_float/Makefile.in
@@ -0,0 +1,646 @@
+# Makefile.in generated by automake 1.15.1 from Makefile.am.
+# @configure_input@
+
+# Copyright (C) 1994-2017 Free Software Foundation, Inc.
+
+# This Makefile.in is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+@SET_MAKE@
+VPATH = @srcdir@
+am__is_gnu_make = { \
+ if test -z '$(MAKELEVEL)'; then \
+ false; \
+ elif test -n '$(MAKE_HOST)'; then \
+ true; \
+ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \
+ true; \
+ else \
+ false; \
+ fi; \
+}
+am__make_running_with_option = \
+ case $${target_option-} in \
+ ?) ;; \
+ *) echo "am__make_running_with_option: internal error: invalid" \
+ "target option '$${target_option-}' specified" >&2; \
+ exit 1;; \
+ esac; \
+ has_opt=no; \
+ sane_makeflags=$$MAKEFLAGS; \
+ if $(am__is_gnu_make); then \
+ sane_makeflags=$$MFLAGS; \
+ else \
+ case $$MAKEFLAGS in \
+ *\\[\ \ ]*) \
+ bs=\\; \
+ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \
+ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \
+ esac; \
+ fi; \
+ skip_next=no; \
+ strip_trailopt () \
+ { \
+ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \
+ }; \
+ for flg in $$sane_makeflags; do \
+ test $$skip_next = yes && { skip_next=no; continue; }; \
+ case $$flg in \
+ *=*|--*) continue;; \
+ -*I) strip_trailopt 'I'; skip_next=yes;; \
+ -*I?*) strip_trailopt 'I';; \
+ -*O) strip_trailopt 'O'; skip_next=yes;; \
+ -*O?*) strip_trailopt 'O';; \
+ -*l) strip_trailopt 'l'; skip_next=yes;; \
+ -*l?*) strip_trailopt 'l';; \
+ -[dEDm]) skip_next=yes;; \
+ -[JT]) skip_next=yes;; \
+ esac; \
+ case $$flg in \
+ *$$target_option*) has_opt=yes; break;; \
+ esac; \
+ done; \
+ test $$has_opt = yes
+am__make_dryrun = (target_option=n; $(am__make_running_with_option))
+am__make_keepgoing = (target_option=k; $(am__make_running_with_option))
+pkgdatadir = $(datadir)/@PACKAGE@
+pkgincludedir = $(includedir)/@PACKAGE@
+pkglibdir = $(libdir)/@PACKAGE@
+pkglibexecdir = $(libexecdir)/@PACKAGE@
+am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
+install_sh_DATA = $(install_sh) -c -m 644
+install_sh_PROGRAM = $(install_sh) -c
+install_sh_SCRIPT = $(install_sh) -c
+INSTALL_HEADER = $(INSTALL_DATA)
+transform = $(program_transform_name)
+NORMAL_INSTALL = :
+PRE_INSTALL = :
+POST_INSTALL = :
+NORMAL_UNINSTALL = :
+PRE_UNINSTALL = :
+POST_UNINSTALL = :
+build_triplet = @build@
+host_triplet = @host@
+subdir = plugins/fast_float
+ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
+am__aclocal_m4_deps = $(top_srcdir)/m4/acx_pthread.m4 \
+ $(top_srcdir)/m4/ax_append_compile_flags.m4 \
+ $(top_srcdir)/m4/ax_append_flag.m4 \
+ $(top_srcdir)/m4/ax_check_compile_flag.m4 \
+ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \
+ $(top_srcdir)/m4/ax_require_defined.m4 \
+ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \
+ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \
+ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/configure.ac
+am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
+ $(ACLOCAL_M4)
+DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON)
+mkinstalldirs = $(install_sh) -d
+CONFIG_CLEAN_FILES =
+CONFIG_CLEAN_VPATH_FILES =
+AM_V_P = $(am__v_P_@AM_V@)
+am__v_P_ = $(am__v_P_@AM_DEFAULT_V@)
+am__v_P_0 = false
+am__v_P_1 = :
+AM_V_GEN = $(am__v_GEN_@AM_V@)
+am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@)
+am__v_GEN_0 = @echo " GEN " $@;
+am__v_GEN_1 =
+AM_V_at = $(am__v_at_@AM_V@)
+am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
+am__v_at_0 = @
+am__v_at_1 =
+SOURCES =
+DIST_SOURCES =
+RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \
+ ctags-recursive dvi-recursive html-recursive info-recursive \
+ install-data-recursive install-dvi-recursive \
+ install-exec-recursive install-html-recursive \
+ install-info-recursive install-pdf-recursive \
+ install-ps-recursive install-recursive installcheck-recursive \
+ installdirs-recursive pdf-recursive ps-recursive \
+ tags-recursive uninstall-recursive
+am__can_run_installinfo = \
+ case $$AM_UPDATE_INFO_DIR in \
+ n|no|NO) false;; \
+ *) (install-info --version) >/dev/null 2>&1;; \
+ esac
+RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive \
+ distclean-recursive maintainer-clean-recursive
+am__recursive_targets = \
+ $(RECURSIVE_TARGETS) \
+ $(RECURSIVE_CLEAN_TARGETS) \
+ $(am__extra_recursive_targets)
+AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \
+ distdir
+am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP)
+# Read a list of newline-separated strings from the standard input,
+# and print each of them once, without duplicates. Input order is
+# *not* preserved.
+am__uniquify_input = $(AWK) '\
+ BEGIN { nonempty = 0; } \
+ { items[$$0] = 1; nonempty = 1; } \
+ END { if (nonempty) { for (i in items) print i; }; } \
+'
+# Make sure the list of sources is unique. This is necessary because,
+# e.g., the same source file might be shared among _SOURCES variables
+# for different programs/libraries.
+am__define_uniq_tagged_files = \
+ list='$(am__tagged_files)'; \
+ unique=`for i in $$list; do \
+ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+ done | $(am__uniquify_input)`
+ETAGS = etags
+CTAGS = ctags
+DIST_SUBDIRS = $(SUBDIRS)
+am__DIST_COMMON = $(srcdir)/Makefile.in
+DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
+am__relativize = \
+ dir0=`pwd`; \
+ sed_first='s,^\([^/]*\)/.*$$,\1,'; \
+ sed_rest='s,^[^/]*/*,,'; \
+ sed_last='s,^.*/\([^/]*\)$$,\1,'; \
+ sed_butlast='s,/*[^/]*$$,,'; \
+ while test -n "$$dir1"; do \
+ first=`echo "$$dir1" | sed -e "$$sed_first"`; \
+ if test "$$first" != "."; then \
+ if test "$$first" = ".."; then \
+ dir2=`echo "$$dir0" | sed -e "$$sed_last"`/"$$dir2"; \
+ dir0=`echo "$$dir0" | sed -e "$$sed_butlast"`; \
+ else \
+ first2=`echo "$$dir2" | sed -e "$$sed_first"`; \
+ if test "$$first2" = "$$first"; then \
+ dir2=`echo "$$dir2" | sed -e "$$sed_rest"`; \
+ else \
+ dir2="../$$dir2"; \
+ fi; \
+ dir0="$$dir0"/"$$first"; \
+ fi; \
+ fi; \
+ dir1=`echo "$$dir1" | sed -e "$$sed_rest"`; \
+ done; \
+ reldir="$$dir2"
+ACLOCAL = @ACLOCAL@
+AMTAR = @AMTAR@
+AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@
+AR = @AR@
+AS = @AS@
+AUTOCONF = @AUTOCONF@
+AUTOHEADER = @AUTOHEADER@
+AUTOMAKE = @AUTOMAKE@
+AWK = @AWK@
+CC = @CC@
+CCDEPMODE = @CCDEPMODE@
+CFLAGS = @CFLAGS@
+CPP = @CPP@
+CPPFLAGS = @CPPFLAGS@
+CXX = @CXX@
+CXXCPP = @CXXCPP@
+CXXDEPMODE = @CXXDEPMODE@
+CXXFLAGS = @CXXFLAGS@
+CYGPATH_W = @CYGPATH_W@
+DEFS = @DEFS@
+DEPDIR = @DEPDIR@
+DLLTOOL = @DLLTOOL@
+DSYMUTIL = @DSYMUTIL@
+DUMPBIN = @DUMPBIN@
+ECHO_C = @ECHO_C@
+ECHO_N = @ECHO_N@
+ECHO_T = @ECHO_T@
+EGREP = @EGREP@
+EXEEXT = @EXEEXT@
+FGREP = @FGREP@
+GREP = @GREP@
+INSTALL = @INSTALL@
+INSTALL_DATA = @INSTALL_DATA@
+INSTALL_PROGRAM = @INSTALL_PROGRAM@
+INSTALL_SCRIPT = @INSTALL_SCRIPT@
+INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
+JPEGICC_DEPLIBS = @JPEGICC_DEPLIBS@
+LCMS_LIB_DEPLIBS = @LCMS_LIB_DEPLIBS@
+LD = @LD@
+LDFLAGS = @LDFLAGS@
+LIBOBJS = @LIBOBJS@
+LIBRARY_AGE = @LIBRARY_AGE@
+LIBRARY_CURRENT = @LIBRARY_CURRENT@
+LIBRARY_REVISION = @LIBRARY_REVISION@
+LIBS = @LIBS@
+LIBTOOL = @LIBTOOL@
+LIBTOOL_DEPS = @LIBTOOL_DEPS@
+LIB_JPEG = @LIB_JPEG@
+LIB_MATH = @LIB_MATH@
+LIB_PLUGINS = @LIB_PLUGINS@
+LIB_THREAD = @LIB_THREAD@
+LIB_TIFF = @LIB_TIFF@
+LIB_ZLIB = @LIB_ZLIB@
+LIPO = @LIPO@
+LN_S = @LN_S@
+LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
+MAINT = @MAINT@
+MAKEINFO = @MAKEINFO@
+MANIFEST_TOOL = @MANIFEST_TOOL@
+MKDIR_P = @MKDIR_P@
+NM = @NM@
+NMEDIT = @NMEDIT@
+OBJDUMP = @OBJDUMP@
+OBJEXT = @OBJEXT@
+OTOOL = @OTOOL@
+OTOOL64 = @OTOOL64@
+PACKAGE = @PACKAGE@
+PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
+PACKAGE_NAME = @PACKAGE_NAME@
+PACKAGE_STRING = @PACKAGE_STRING@
+PACKAGE_TARNAME = @PACKAGE_TARNAME@
+PACKAGE_URL = @PACKAGE_URL@
+PACKAGE_VERSION = @PACKAGE_VERSION@
+PATH_SEPARATOR = @PATH_SEPARATOR@
+PTHREAD_CC = @PTHREAD_CC@
+PTHREAD_CFLAGS = @PTHREAD_CFLAGS@
+PTHREAD_CXX = @PTHREAD_CXX@
+PTHREAD_LIBS = @PTHREAD_LIBS@
+RANLIB = @RANLIB@
+SED = @SED@
+SET_MAKE = @SET_MAKE@
+SHELL = @SHELL@
+STRIP = @STRIP@
+TIFFICC_DEPLIBS = @TIFFICC_DEPLIBS@
+VERSION = @VERSION@
+abs_builddir = @abs_builddir@
+abs_srcdir = @abs_srcdir@
+abs_top_builddir = @abs_top_builddir@
+abs_top_srcdir = @abs_top_srcdir@
+ac_ct_AR = @ac_ct_AR@
+ac_ct_CC = @ac_ct_CC@
+ac_ct_CXX = @ac_ct_CXX@
+ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
+acx_pthread_config = @acx_pthread_config@
+am__include = @am__include@
+am__leading_dot = @am__leading_dot@
+am__quote = @am__quote@
+am__tar = @am__tar@
+am__untar = @am__untar@
+bindir = @bindir@
+build = @build@
+build_alias = @build_alias@
+build_cpu = @build_cpu@
+build_os = @build_os@
+build_vendor = @build_vendor@
+builddir = @builddir@
+datadir = @datadir@
+datarootdir = @datarootdir@
+docdir = @docdir@
+dvidir = @dvidir@
+exec_prefix = @exec_prefix@
+host = @host@
+host_alias = @host_alias@
+host_cpu = @host_cpu@
+host_os = @host_os@
+host_vendor = @host_vendor@
+htmldir = @htmldir@
+includedir = @includedir@
+infodir = @infodir@
+inline = @inline@
+install_sh = @install_sh@
+libdir = @libdir@
+libexecdir = @libexecdir@
+localedir = @localedir@
+localstatedir = @localstatedir@
+mandir = @mandir@
+mkdir_p = @mkdir_p@
+oldincludedir = @oldincludedir@
+pdfdir = @pdfdir@
+prefix = @prefix@
+program_transform_name = @program_transform_name@
+psdir = @psdir@
+runstatedir = @runstatedir@
+sbindir = @sbindir@
+sharedstatedir = @sharedstatedir@
+srcdir = @srcdir@
+sysconfdir = @sysconfdir@
+target_alias = @target_alias@
+top_build_prefix = @top_build_prefix@
+top_builddir = @top_builddir@
+top_srcdir = @top_srcdir@
+SUBDIRS = src include testbed
+all: all-recursive
+
+.SUFFIXES:
+$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.am $(am__configure_deps)
+ @for dep in $?; do \
+ case '$(am__configure_deps)' in \
+ *$$dep*) \
+ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \
+ && { if test -f $@; then exit 0; else break; fi; }; \
+ exit 1;; \
+ esac; \
+ done; \
+ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign plugins/fast_float/Makefile'; \
+ $(am__cd) $(top_srcdir) && \
+ $(AUTOMAKE) --foreign plugins/fast_float/Makefile
+Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
+ @case '$?' in \
+ *config.status*) \
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
+ *) \
+ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
+ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
+ esac;
+
+$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
+
+$(top_srcdir)/configure: @MAINTAINER_MODE_TRUE@ $(am__configure_deps)
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
+$(ACLOCAL_M4): @MAINTAINER_MODE_TRUE@ $(am__aclocal_m4_deps)
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
+$(am__aclocal_m4_deps):
+
+mostlyclean-libtool:
+ -rm -f *.lo
+
+clean-libtool:
+ -rm -rf .libs _libs
+
+# This directory's subdirectories are mostly independent; you can cd
+# into them and run 'make' without going through this Makefile.
+# To change the values of 'make' variables: instead of editing Makefiles,
+# (1) if the variable is set in 'config.status', edit 'config.status'
+# (which will cause the Makefiles to be regenerated when you run 'make');
+# (2) otherwise, pass the desired values on the 'make' command line.
+$(am__recursive_targets):
+ @fail=; \
+ if $(am__make_keepgoing); then \
+ failcom='fail=yes'; \
+ else \
+ failcom='exit 1'; \
+ fi; \
+ dot_seen=no; \
+ target=`echo $@ | sed s/-recursive//`; \
+ case "$@" in \
+ distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \
+ *) list='$(SUBDIRS)' ;; \
+ esac; \
+ for subdir in $$list; do \
+ echo "Making $$target in $$subdir"; \
+ if test "$$subdir" = "."; then \
+ dot_seen=yes; \
+ local_target="$$target-am"; \
+ else \
+ local_target="$$target"; \
+ fi; \
+ ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \
+ || eval $$failcom; \
+ done; \
+ if test "$$dot_seen" = "no"; then \
+ $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \
+ fi; test -z "$$fail"
+
+ID: $(am__tagged_files)
+ $(am__define_uniq_tagged_files); mkid -fID $$unique
+tags: tags-recursive
+TAGS: tags
+
+tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
+ set x; \
+ here=`pwd`; \
+ if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \
+ include_option=--etags-include; \
+ empty_fix=.; \
+ else \
+ include_option=--include; \
+ empty_fix=; \
+ fi; \
+ list='$(SUBDIRS)'; for subdir in $$list; do \
+ if test "$$subdir" = .; then :; else \
+ test ! -f $$subdir/TAGS || \
+ set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \
+ fi; \
+ done; \
+ $(am__define_uniq_tagged_files); \
+ shift; \
+ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
+ test -n "$$unique" || unique=$$empty_fix; \
+ if test $$# -gt 0; then \
+ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+ "$$@" $$unique; \
+ else \
+ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+ $$unique; \
+ fi; \
+ fi
+ctags: ctags-recursive
+
+CTAGS: ctags
+ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
+ $(am__define_uniq_tagged_files); \
+ test -z "$(CTAGS_ARGS)$$unique" \
+ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
+ $$unique
+
+GTAGS:
+ here=`$(am__cd) $(top_builddir) && pwd` \
+ && $(am__cd) $(top_srcdir) \
+ && gtags -i $(GTAGS_ARGS) "$$here"
+cscopelist: cscopelist-recursive
+
+cscopelist-am: $(am__tagged_files)
+ list='$(am__tagged_files)'; \
+ case "$(srcdir)" in \
+ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \
+ *) sdir=$(subdir)/$(srcdir) ;; \
+ esac; \
+ for i in $$list; do \
+ if test -f "$$i"; then \
+ echo "$(subdir)/$$i"; \
+ else \
+ echo "$$sdir/$$i"; \
+ fi; \
+ done >> $(top_builddir)/cscope.files
+
+distclean-tags:
+ -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
+
+distdir: $(DISTFILES)
+ @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
+ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
+ list='$(DISTFILES)'; \
+ dist_files=`for file in $$list; do echo $$file; done | \
+ sed -e "s|^$$srcdirstrip/||;t" \
+ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \
+ case $$dist_files in \
+ */*) $(MKDIR_P) `echo "$$dist_files" | \
+ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \
+ sort -u` ;; \
+ esac; \
+ for file in $$dist_files; do \
+ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
+ if test -d $$d/$$file; then \
+ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
+ if test -d "$(distdir)/$$file"; then \
+ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
+ fi; \
+ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \
+ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
+ fi; \
+ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \
+ else \
+ test -f "$(distdir)/$$file" \
+ || cp -p $$d/$$file "$(distdir)/$$file" \
+ || exit 1; \
+ fi; \
+ done
+ @list='$(DIST_SUBDIRS)'; for subdir in $$list; do \
+ if test "$$subdir" = .; then :; else \
+ $(am__make_dryrun) \
+ || test -d "$(distdir)/$$subdir" \
+ || $(MKDIR_P) "$(distdir)/$$subdir" \
+ || exit 1; \
+ dir1=$$subdir; dir2="$(distdir)/$$subdir"; \
+ $(am__relativize); \
+ new_distdir=$$reldir; \
+ dir1=$$subdir; dir2="$(top_distdir)"; \
+ $(am__relativize); \
+ new_top_distdir=$$reldir; \
+ echo " (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir="$$new_top_distdir" distdir="$$new_distdir" \\"; \
+ echo " am__remove_distdir=: am__skip_length_check=: am__skip_mode_fix=: distdir)"; \
+ ($(am__cd) $$subdir && \
+ $(MAKE) $(AM_MAKEFLAGS) \
+ top_distdir="$$new_top_distdir" \
+ distdir="$$new_distdir" \
+ am__remove_distdir=: \
+ am__skip_length_check=: \
+ am__skip_mode_fix=: \
+ distdir) \
+ || exit 1; \
+ fi; \
+ done
+check-am: all-am
+check: check-recursive
+all-am: Makefile
+installdirs: installdirs-recursive
+installdirs-am:
+install: install-recursive
+install-exec: install-exec-recursive
+install-data: install-data-recursive
+uninstall: uninstall-recursive
+
+install-am: all-am
+ @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
+
+installcheck: installcheck-recursive
+install-strip:
+ if test -z '$(STRIP)'; then \
+ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
+ install; \
+ else \
+ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
+ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \
+ fi
+mostlyclean-generic:
+
+clean-generic:
+
+distclean-generic:
+ -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
+ -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
+
+maintainer-clean-generic:
+ @echo "This command is intended for maintainers to use"
+ @echo "it deletes files that may require special tools to rebuild."
+clean: clean-recursive
+
+clean-am: clean-generic clean-libtool mostlyclean-am
+
+distclean: distclean-recursive
+ -rm -f Makefile
+distclean-am: clean-am distclean-generic distclean-tags
+
+dvi: dvi-recursive
+
+dvi-am:
+
+html: html-recursive
+
+html-am:
+
+info: info-recursive
+
+info-am:
+
+install-data-am:
+
+install-dvi: install-dvi-recursive
+
+install-dvi-am:
+
+install-exec-am:
+
+install-html: install-html-recursive
+
+install-html-am:
+
+install-info: install-info-recursive
+
+install-info-am:
+
+install-man:
+
+install-pdf: install-pdf-recursive
+
+install-pdf-am:
+
+install-ps: install-ps-recursive
+
+install-ps-am:
+
+installcheck-am:
+
+maintainer-clean: maintainer-clean-recursive
+ -rm -f Makefile
+maintainer-clean-am: distclean-am maintainer-clean-generic
+
+mostlyclean: mostlyclean-recursive
+
+mostlyclean-am: mostlyclean-generic mostlyclean-libtool
+
+pdf: pdf-recursive
+
+pdf-am:
+
+ps: ps-recursive
+
+ps-am:
+
+uninstall-am:
+
+.MAKE: $(am__recursive_targets) install-am install-strip
+
+.PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am check \
+ check-am clean clean-generic clean-libtool cscopelist-am ctags \
+ ctags-am distclean distclean-generic distclean-libtool \
+ distclean-tags distdir dvi dvi-am html html-am info info-am \
+ install install-am install-data install-data-am install-dvi \
+ install-dvi-am install-exec install-exec-am install-html \
+ install-html-am install-info install-info-am install-man \
+ install-pdf install-pdf-am install-ps install-ps-am \
+ install-strip installcheck installcheck-am installdirs \
+ installdirs-am maintainer-clean maintainer-clean-generic \
+ mostlyclean mostlyclean-generic mostlyclean-libtool pdf pdf-am \
+ ps ps-am tags tags-am uninstall uninstall-am
+
+.PRECIOUS: Makefile
+
+
+# Tell versions [3.59,3.63) of GNU make to not export all variables.
+# Otherwise a system limit (for SysV at least) may be exceeded.
+.NOEXPORT:
diff --git a/lcms2mt/plugins/fast_float/doc/LittleCMS floating point extensions 1.4.pdf b/lcms2mt/plugins/fast_float/doc/LittleCMS floating point extensions 1.4.pdf
new file mode 100644
index 00000000..949b50b9
--- /dev/null
+++ b/lcms2mt/plugins/fast_float/doc/LittleCMS floating point extensions 1.4.pdf
Binary files differ
diff --git a/lcms2mt/plugins/fast_float/include/Makefile.in b/lcms2mt/plugins/fast_float/include/Makefile.in
new file mode 100644
index 00000000..afe3337b
--- /dev/null
+++ b/lcms2mt/plugins/fast_float/include/Makefile.in
@@ -0,0 +1,591 @@
+# Makefile.in generated by automake 1.15.1 from Makefile.am.
+# @configure_input@
+
+# Copyright (C) 1994-2017 Free Software Foundation, Inc.
+
+# This Makefile.in is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+@SET_MAKE@
+
+#
+# Makefile for include directory
+
+VPATH = @srcdir@
+am__is_gnu_make = { \
+ if test -z '$(MAKELEVEL)'; then \
+ false; \
+ elif test -n '$(MAKE_HOST)'; then \
+ true; \
+ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \
+ true; \
+ else \
+ false; \
+ fi; \
+}
+am__make_running_with_option = \
+ case $${target_option-} in \
+ ?) ;; \
+ *) echo "am__make_running_with_option: internal error: invalid" \
+ "target option '$${target_option-}' specified" >&2; \
+ exit 1;; \
+ esac; \
+ has_opt=no; \
+ sane_makeflags=$$MAKEFLAGS; \
+ if $(am__is_gnu_make); then \
+ sane_makeflags=$$MFLAGS; \
+ else \
+ case $$MAKEFLAGS in \
+ *\\[\ \ ]*) \
+ bs=\\; \
+ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \
+ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \
+ esac; \
+ fi; \
+ skip_next=no; \
+ strip_trailopt () \
+ { \
+ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \
+ }; \
+ for flg in $$sane_makeflags; do \
+ test $$skip_next = yes && { skip_next=no; continue; }; \
+ case $$flg in \
+ *=*|--*) continue;; \
+ -*I) strip_trailopt 'I'; skip_next=yes;; \
+ -*I?*) strip_trailopt 'I';; \
+ -*O) strip_trailopt 'O'; skip_next=yes;; \
+ -*O?*) strip_trailopt 'O';; \
+ -*l) strip_trailopt 'l'; skip_next=yes;; \
+ -*l?*) strip_trailopt 'l';; \
+ -[dEDm]) skip_next=yes;; \
+ -[JT]) skip_next=yes;; \
+ esac; \
+ case $$flg in \
+ *$$target_option*) has_opt=yes; break;; \
+ esac; \
+ done; \
+ test $$has_opt = yes
+am__make_dryrun = (target_option=n; $(am__make_running_with_option))
+am__make_keepgoing = (target_option=k; $(am__make_running_with_option))
+pkgdatadir = $(datadir)/@PACKAGE@
+pkgincludedir = $(includedir)/@PACKAGE@
+pkglibdir = $(libdir)/@PACKAGE@
+pkglibexecdir = $(libexecdir)/@PACKAGE@
+am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
+install_sh_DATA = $(install_sh) -c -m 644
+install_sh_PROGRAM = $(install_sh) -c
+install_sh_SCRIPT = $(install_sh) -c
+INSTALL_HEADER = $(INSTALL_DATA)
+transform = $(program_transform_name)
+NORMAL_INSTALL = :
+PRE_INSTALL = :
+POST_INSTALL = :
+NORMAL_UNINSTALL = :
+PRE_UNINSTALL = :
+POST_UNINSTALL = :
+build_triplet = @build@
+host_triplet = @host@
+subdir = plugins/fast_float/include
+ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
+am__aclocal_m4_deps = $(top_srcdir)/m4/acx_pthread.m4 \
+ $(top_srcdir)/m4/ax_append_compile_flags.m4 \
+ $(top_srcdir)/m4/ax_append_flag.m4 \
+ $(top_srcdir)/m4/ax_check_compile_flag.m4 \
+ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \
+ $(top_srcdir)/m4/ax_require_defined.m4 \
+ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \
+ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \
+ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/configure.ac
+am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
+ $(ACLOCAL_M4)
+DIST_COMMON = $(srcdir)/Makefile.am $(include_HEADERS) \
+ $(am__DIST_COMMON)
+mkinstalldirs = $(install_sh) -d
+CONFIG_CLEAN_FILES =
+CONFIG_CLEAN_VPATH_FILES =
+AM_V_P = $(am__v_P_@AM_V@)
+am__v_P_ = $(am__v_P_@AM_DEFAULT_V@)
+am__v_P_0 = false
+am__v_P_1 = :
+AM_V_GEN = $(am__v_GEN_@AM_V@)
+am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@)
+am__v_GEN_0 = @echo " GEN " $@;
+am__v_GEN_1 =
+AM_V_at = $(am__v_at_@AM_V@)
+am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
+am__v_at_0 = @
+am__v_at_1 =
+SOURCES =
+DIST_SOURCES =
+am__can_run_installinfo = \
+ case $$AM_UPDATE_INFO_DIR in \
+ n|no|NO) false;; \
+ *) (install-info --version) >/dev/null 2>&1;; \
+ esac
+am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
+am__vpath_adj = case $$p in \
+ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \
+ *) f=$$p;; \
+ esac;
+am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`;
+am__install_max = 40
+am__nobase_strip_setup = \
+ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'`
+am__nobase_strip = \
+ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||"
+am__nobase_list = $(am__nobase_strip_setup); \
+ for p in $$list; do echo "$$p $$p"; done | \
+ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \
+ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \
+ if (++n[$$2] == $(am__install_max)) \
+ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \
+ END { for (dir in files) print dir, files[dir] }'
+am__base_list = \
+ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \
+ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g'
+am__uninstall_files_from_dir = { \
+ test -z "$$files" \
+ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \
+ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \
+ $(am__cd) "$$dir" && rm -f $$files; }; \
+ }
+am__installdirs = "$(DESTDIR)$(includedir)"
+HEADERS = $(include_HEADERS)
+am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP)
+# Read a list of newline-separated strings from the standard input,
+# and print each of them once, without duplicates. Input order is
+# *not* preserved.
+am__uniquify_input = $(AWK) '\
+ BEGIN { nonempty = 0; } \
+ { items[$$0] = 1; nonempty = 1; } \
+ END { if (nonempty) { for (i in items) print i; }; } \
+'
+# Make sure the list of sources is unique. This is necessary because,
+# e.g., the same source file might be shared among _SOURCES variables
+# for different programs/libraries.
+am__define_uniq_tagged_files = \
+ list='$(am__tagged_files)'; \
+ unique=`for i in $$list; do \
+ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+ done | $(am__uniquify_input)`
+ETAGS = etags
+CTAGS = ctags
+am__DIST_COMMON = $(srcdir)/Makefile.in
+DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
+ACLOCAL = @ACLOCAL@
+AMTAR = @AMTAR@
+AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@
+AR = @AR@
+AS = @AS@
+AUTOCONF = @AUTOCONF@
+AUTOHEADER = @AUTOHEADER@
+AUTOMAKE = @AUTOMAKE@
+AWK = @AWK@
+CC = @CC@
+CCDEPMODE = @CCDEPMODE@
+CFLAGS = @CFLAGS@
+CPP = @CPP@
+CPPFLAGS = @CPPFLAGS@
+CXX = @CXX@
+CXXCPP = @CXXCPP@
+CXXDEPMODE = @CXXDEPMODE@
+CXXFLAGS = @CXXFLAGS@
+CYGPATH_W = @CYGPATH_W@
+DEFS = @DEFS@
+DEPDIR = @DEPDIR@
+DLLTOOL = @DLLTOOL@
+DSYMUTIL = @DSYMUTIL@
+DUMPBIN = @DUMPBIN@
+ECHO_C = @ECHO_C@
+ECHO_N = @ECHO_N@
+ECHO_T = @ECHO_T@
+EGREP = @EGREP@
+EXEEXT = @EXEEXT@
+FGREP = @FGREP@
+GREP = @GREP@
+INSTALL = @INSTALL@
+INSTALL_DATA = @INSTALL_DATA@
+INSTALL_PROGRAM = @INSTALL_PROGRAM@
+INSTALL_SCRIPT = @INSTALL_SCRIPT@
+INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
+JPEGICC_DEPLIBS = @JPEGICC_DEPLIBS@
+LCMS_LIB_DEPLIBS = @LCMS_LIB_DEPLIBS@
+LD = @LD@
+LDFLAGS = @LDFLAGS@
+LIBOBJS = @LIBOBJS@
+LIBRARY_AGE = @LIBRARY_AGE@
+LIBRARY_CURRENT = @LIBRARY_CURRENT@
+LIBRARY_REVISION = @LIBRARY_REVISION@
+LIBS = @LIBS@
+LIBTOOL = @LIBTOOL@
+LIBTOOL_DEPS = @LIBTOOL_DEPS@
+LIB_JPEG = @LIB_JPEG@
+LIB_MATH = @LIB_MATH@
+LIB_PLUGINS = @LIB_PLUGINS@
+LIB_THREAD = @LIB_THREAD@
+LIB_TIFF = @LIB_TIFF@
+LIB_ZLIB = @LIB_ZLIB@
+LIPO = @LIPO@
+LN_S = @LN_S@
+LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
+MAINT = @MAINT@
+MAKEINFO = @MAKEINFO@
+MANIFEST_TOOL = @MANIFEST_TOOL@
+MKDIR_P = @MKDIR_P@
+NM = @NM@
+NMEDIT = @NMEDIT@
+OBJDUMP = @OBJDUMP@
+OBJEXT = @OBJEXT@
+OTOOL = @OTOOL@
+OTOOL64 = @OTOOL64@
+PACKAGE = @PACKAGE@
+PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
+PACKAGE_NAME = @PACKAGE_NAME@
+PACKAGE_STRING = @PACKAGE_STRING@
+PACKAGE_TARNAME = @PACKAGE_TARNAME@
+PACKAGE_URL = @PACKAGE_URL@
+PACKAGE_VERSION = @PACKAGE_VERSION@
+PATH_SEPARATOR = @PATH_SEPARATOR@
+PTHREAD_CC = @PTHREAD_CC@
+PTHREAD_CFLAGS = @PTHREAD_CFLAGS@
+PTHREAD_CXX = @PTHREAD_CXX@
+PTHREAD_LIBS = @PTHREAD_LIBS@
+RANLIB = @RANLIB@
+SED = @SED@
+SET_MAKE = @SET_MAKE@
+SHELL = @SHELL@
+STRIP = @STRIP@
+TIFFICC_DEPLIBS = @TIFFICC_DEPLIBS@
+VERSION = @VERSION@
+abs_builddir = @abs_builddir@
+abs_srcdir = @abs_srcdir@
+abs_top_builddir = @abs_top_builddir@
+abs_top_srcdir = @abs_top_srcdir@
+ac_ct_AR = @ac_ct_AR@
+ac_ct_CC = @ac_ct_CC@
+ac_ct_CXX = @ac_ct_CXX@
+ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
+acx_pthread_config = @acx_pthread_config@
+am__include = @am__include@
+am__leading_dot = @am__leading_dot@
+am__quote = @am__quote@
+am__tar = @am__tar@
+am__untar = @am__untar@
+bindir = @bindir@
+build = @build@
+build_alias = @build_alias@
+build_cpu = @build_cpu@
+build_os = @build_os@
+build_vendor = @build_vendor@
+builddir = @builddir@
+datadir = @datadir@
+datarootdir = @datarootdir@
+docdir = @docdir@
+dvidir = @dvidir@
+exec_prefix = @exec_prefix@
+host = @host@
+host_alias = @host_alias@
+host_cpu = @host_cpu@
+host_os = @host_os@
+host_vendor = @host_vendor@
+htmldir = @htmldir@
+includedir = @includedir@
+infodir = @infodir@
+inline = @inline@
+install_sh = @install_sh@
+libdir = @libdir@
+libexecdir = @libexecdir@
+localedir = @localedir@
+localstatedir = @localstatedir@
+mandir = @mandir@
+mkdir_p = @mkdir_p@
+oldincludedir = @oldincludedir@
+pdfdir = @pdfdir@
+prefix = @prefix@
+program_transform_name = @program_transform_name@
+psdir = @psdir@
+runstatedir = @runstatedir@
+sbindir = @sbindir@
+sharedstatedir = @sharedstatedir@
+srcdir = @srcdir@
+sysconfdir = @sysconfdir@
+target_alias = @target_alias@
+top_build_prefix = @top_build_prefix@
+top_builddir = @top_builddir@
+top_srcdir = @top_srcdir@
+include_HEADERS = lcms2mt_fast_float.h
+EXTRA_DIST = lcms2mt_fast_float.h
+all: all-am
+
+.SUFFIXES:
+$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.am $(am__configure_deps)
+ @for dep in $?; do \
+ case '$(am__configure_deps)' in \
+ *$$dep*) \
+ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \
+ && { if test -f $@; then exit 0; else break; fi; }; \
+ exit 1;; \
+ esac; \
+ done; \
+ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign plugins/fast_float/include/Makefile'; \
+ $(am__cd) $(top_srcdir) && \
+ $(AUTOMAKE) --foreign plugins/fast_float/include/Makefile
+Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
+ @case '$?' in \
+ *config.status*) \
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
+ *) \
+ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
+ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
+ esac;
+
+$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
+
+$(top_srcdir)/configure: @MAINTAINER_MODE_TRUE@ $(am__configure_deps)
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
+$(ACLOCAL_M4): @MAINTAINER_MODE_TRUE@ $(am__aclocal_m4_deps)
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
+$(am__aclocal_m4_deps):
+
+mostlyclean-libtool:
+ -rm -f *.lo
+
+clean-libtool:
+ -rm -rf .libs _libs
+install-includeHEADERS: $(include_HEADERS)
+ @$(NORMAL_INSTALL)
+ @list='$(include_HEADERS)'; test -n "$(includedir)" || list=; \
+ if test -n "$$list"; then \
+ echo " $(MKDIR_P) '$(DESTDIR)$(includedir)'"; \
+ $(MKDIR_P) "$(DESTDIR)$(includedir)" || exit 1; \
+ fi; \
+ for p in $$list; do \
+ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \
+ echo "$$d$$p"; \
+ done | $(am__base_list) | \
+ while read files; do \
+ echo " $(INSTALL_HEADER) $$files '$(DESTDIR)$(includedir)'"; \
+ $(INSTALL_HEADER) $$files "$(DESTDIR)$(includedir)" || exit $$?; \
+ done
+
+uninstall-includeHEADERS:
+ @$(NORMAL_UNINSTALL)
+ @list='$(include_HEADERS)'; test -n "$(includedir)" || list=; \
+ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \
+ dir='$(DESTDIR)$(includedir)'; $(am__uninstall_files_from_dir)
+
+ID: $(am__tagged_files)
+ $(am__define_uniq_tagged_files); mkid -fID $$unique
+tags: tags-am
+TAGS: tags
+
+tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
+ set x; \
+ here=`pwd`; \
+ $(am__define_uniq_tagged_files); \
+ shift; \
+ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
+ test -n "$$unique" || unique=$$empty_fix; \
+ if test $$# -gt 0; then \
+ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+ "$$@" $$unique; \
+ else \
+ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+ $$unique; \
+ fi; \
+ fi
+ctags: ctags-am
+
+CTAGS: ctags
+ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
+ $(am__define_uniq_tagged_files); \
+ test -z "$(CTAGS_ARGS)$$unique" \
+ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
+ $$unique
+
+GTAGS:
+ here=`$(am__cd) $(top_builddir) && pwd` \
+ && $(am__cd) $(top_srcdir) \
+ && gtags -i $(GTAGS_ARGS) "$$here"
+cscopelist: cscopelist-am
+
+cscopelist-am: $(am__tagged_files)
+ list='$(am__tagged_files)'; \
+ case "$(srcdir)" in \
+ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \
+ *) sdir=$(subdir)/$(srcdir) ;; \
+ esac; \
+ for i in $$list; do \
+ if test -f "$$i"; then \
+ echo "$(subdir)/$$i"; \
+ else \
+ echo "$$sdir/$$i"; \
+ fi; \
+ done >> $(top_builddir)/cscope.files
+
+distclean-tags:
+ -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
+
+distdir: $(DISTFILES)
+ @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
+ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
+ list='$(DISTFILES)'; \
+ dist_files=`for file in $$list; do echo $$file; done | \
+ sed -e "s|^$$srcdirstrip/||;t" \
+ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \
+ case $$dist_files in \
+ */*) $(MKDIR_P) `echo "$$dist_files" | \
+ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \
+ sort -u` ;; \
+ esac; \
+ for file in $$dist_files; do \
+ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
+ if test -d $$d/$$file; then \
+ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
+ if test -d "$(distdir)/$$file"; then \
+ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
+ fi; \
+ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \
+ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
+ fi; \
+ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \
+ else \
+ test -f "$(distdir)/$$file" \
+ || cp -p $$d/$$file "$(distdir)/$$file" \
+ || exit 1; \
+ fi; \
+ done
+check-am: all-am
+check: check-am
+all-am: Makefile $(HEADERS)
+installdirs:
+ for dir in "$(DESTDIR)$(includedir)"; do \
+ test -z "$$dir" || $(MKDIR_P) "$$dir"; \
+ done
+install: install-am
+install-exec: install-exec-am
+install-data: install-data-am
+uninstall: uninstall-am
+
+install-am: all-am
+ @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
+
+installcheck: installcheck-am
+install-strip:
+ if test -z '$(STRIP)'; then \
+ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
+ install; \
+ else \
+ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
+ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \
+ fi
+mostlyclean-generic:
+
+clean-generic:
+
+distclean-generic:
+ -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
+ -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
+
+maintainer-clean-generic:
+ @echo "This command is intended for maintainers to use"
+ @echo "it deletes files that may require special tools to rebuild."
+clean: clean-am
+
+clean-am: clean-generic clean-libtool mostlyclean-am
+
+distclean: distclean-am
+ -rm -f Makefile
+distclean-am: clean-am distclean-generic distclean-tags
+
+dvi: dvi-am
+
+dvi-am:
+
+html: html-am
+
+html-am:
+
+info: info-am
+
+info-am:
+
+install-data-am: install-includeHEADERS
+
+install-dvi: install-dvi-am
+
+install-dvi-am:
+
+install-exec-am:
+
+install-html: install-html-am
+
+install-html-am:
+
+install-info: install-info-am
+
+install-info-am:
+
+install-man:
+
+install-pdf: install-pdf-am
+
+install-pdf-am:
+
+install-ps: install-ps-am
+
+install-ps-am:
+
+installcheck-am:
+
+maintainer-clean: maintainer-clean-am
+ -rm -f Makefile
+maintainer-clean-am: distclean-am maintainer-clean-generic
+
+mostlyclean: mostlyclean-am
+
+mostlyclean-am: mostlyclean-generic mostlyclean-libtool
+
+pdf: pdf-am
+
+pdf-am:
+
+ps: ps-am
+
+ps-am:
+
+uninstall-am: uninstall-includeHEADERS
+
+.MAKE: install-am install-strip
+
+.PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \
+ clean-libtool cscopelist-am ctags ctags-am distclean \
+ distclean-generic distclean-libtool distclean-tags distdir dvi \
+ dvi-am html html-am info info-am install install-am \
+ install-data install-data-am install-dvi install-dvi-am \
+ install-exec install-exec-am install-html install-html-am \
+ install-includeHEADERS install-info install-info-am \
+ install-man install-pdf install-pdf-am install-ps \
+ install-ps-am install-strip installcheck installcheck-am \
+ installdirs maintainer-clean maintainer-clean-generic \
+ mostlyclean mostlyclean-generic mostlyclean-libtool pdf pdf-am \
+ ps ps-am tags tags-am uninstall uninstall-am \
+ uninstall-includeHEADERS
+
+.PRECIOUS: Makefile
+
+
+# Tell versions [3.59,3.63) of GNU make to not export all variables.
+# Otherwise a system limit (for SysV at least) may be exceeded.
+.NOEXPORT:
diff --git a/lcms2mt/plugins/fast_float/src/Makefile.in b/lcms2mt/plugins/fast_float/src/Makefile.in
new file mode 100644
index 00000000..c54ae2f2
--- /dev/null
+++ b/lcms2mt/plugins/fast_float/src/Makefile.in
@@ -0,0 +1,713 @@
+# Makefile.in generated by automake 1.15.1 from Makefile.am.
+# @configure_input@
+
+# Copyright (C) 1994-2017 Free Software Foundation, Inc.
+
+# This Makefile.in is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+@SET_MAKE@
+
+#
+# Makefile for building lcms2_fast_float library
+#
+
+VPATH = @srcdir@
+am__is_gnu_make = { \
+ if test -z '$(MAKELEVEL)'; then \
+ false; \
+ elif test -n '$(MAKE_HOST)'; then \
+ true; \
+ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \
+ true; \
+ else \
+ false; \
+ fi; \
+}
+am__make_running_with_option = \
+ case $${target_option-} in \
+ ?) ;; \
+ *) echo "am__make_running_with_option: internal error: invalid" \
+ "target option '$${target_option-}' specified" >&2; \
+ exit 1;; \
+ esac; \
+ has_opt=no; \
+ sane_makeflags=$$MAKEFLAGS; \
+ if $(am__is_gnu_make); then \
+ sane_makeflags=$$MFLAGS; \
+ else \
+ case $$MAKEFLAGS in \
+ *\\[\ \ ]*) \
+ bs=\\; \
+ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \
+ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \
+ esac; \
+ fi; \
+ skip_next=no; \
+ strip_trailopt () \
+ { \
+ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \
+ }; \
+ for flg in $$sane_makeflags; do \
+ test $$skip_next = yes && { skip_next=no; continue; }; \
+ case $$flg in \
+ *=*|--*) continue;; \
+ -*I) strip_trailopt 'I'; skip_next=yes;; \
+ -*I?*) strip_trailopt 'I';; \
+ -*O) strip_trailopt 'O'; skip_next=yes;; \
+ -*O?*) strip_trailopt 'O';; \
+ -*l) strip_trailopt 'l'; skip_next=yes;; \
+ -*l?*) strip_trailopt 'l';; \
+ -[dEDm]) skip_next=yes;; \
+ -[JT]) skip_next=yes;; \
+ esac; \
+ case $$flg in \
+ *$$target_option*) has_opt=yes; break;; \
+ esac; \
+ done; \
+ test $$has_opt = yes
+am__make_dryrun = (target_option=n; $(am__make_running_with_option))
+am__make_keepgoing = (target_option=k; $(am__make_running_with_option))
+pkgdatadir = $(datadir)/@PACKAGE@
+pkgincludedir = $(includedir)/@PACKAGE@
+pkglibdir = $(libdir)/@PACKAGE@
+pkglibexecdir = $(libexecdir)/@PACKAGE@
+am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
+install_sh_DATA = $(install_sh) -c -m 644
+install_sh_PROGRAM = $(install_sh) -c
+install_sh_SCRIPT = $(install_sh) -c
+INSTALL_HEADER = $(INSTALL_DATA)
+transform = $(program_transform_name)
+NORMAL_INSTALL = :
+PRE_INSTALL = :
+POST_INSTALL = :
+NORMAL_UNINSTALL = :
+PRE_UNINSTALL = :
+POST_UNINSTALL = :
+build_triplet = @build@
+host_triplet = @host@
+subdir = plugins/fast_float/src
+ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
+am__aclocal_m4_deps = $(top_srcdir)/m4/acx_pthread.m4 \
+ $(top_srcdir)/m4/ax_append_compile_flags.m4 \
+ $(top_srcdir)/m4/ax_append_flag.m4 \
+ $(top_srcdir)/m4/ax_check_compile_flag.m4 \
+ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \
+ $(top_srcdir)/m4/ax_require_defined.m4 \
+ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \
+ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \
+ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/configure.ac
+am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
+ $(ACLOCAL_M4)
+DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON)
+mkinstalldirs = $(install_sh) -d
+CONFIG_CLEAN_FILES =
+CONFIG_CLEAN_VPATH_FILES =
+am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`;
+am__vpath_adj = case $$p in \
+ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \
+ *) f=$$p;; \
+ esac;
+am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`;
+am__install_max = 40
+am__nobase_strip_setup = \
+ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'`
+am__nobase_strip = \
+ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||"
+am__nobase_list = $(am__nobase_strip_setup); \
+ for p in $$list; do echo "$$p $$p"; done | \
+ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \
+ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \
+ if (++n[$$2] == $(am__install_max)) \
+ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \
+ END { for (dir in files) print dir, files[dir] }'
+am__base_list = \
+ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \
+ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g'
+am__uninstall_files_from_dir = { \
+ test -z "$$files" \
+ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \
+ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \
+ $(am__cd) "$$dir" && rm -f $$files; }; \
+ }
+am__installdirs = "$(DESTDIR)$(libdir)"
+LTLIBRARIES = $(lib_LTLIBRARIES)
+am__DEPENDENCIES_1 =
+liblcms2mt_fast_float_la_DEPENDENCIES = $(am__DEPENDENCIES_1) \
+ $(top_builddir)/src/liblcms2mt.la
+am_liblcms2mt_fast_float_la_OBJECTS = fast_8_curves.lo \
+ fast_8_matsh_sse.lo fast_8_matsh.lo fast_8_tethra.lo \
+ fast_16_tethra.lo fast_float_15bits.lo fast_float_15mats.lo \
+ fast_float_cmyk.lo fast_float_curves.lo fast_float_matsh.lo \
+ fast_float_separate.lo fast_float_sup.lo fast_float_tethra.lo \
+ fast_float_lab.lo
+liblcms2mt_fast_float_la_OBJECTS = \
+ $(am_liblcms2mt_fast_float_la_OBJECTS)
+AM_V_lt = $(am__v_lt_@AM_V@)
+am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@)
+am__v_lt_0 = --silent
+am__v_lt_1 =
+liblcms2mt_fast_float_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \
+ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \
+ $(AM_CFLAGS) $(CFLAGS) $(liblcms2mt_fast_float_la_LDFLAGS) \
+ $(LDFLAGS) -o $@
+AM_V_P = $(am__v_P_@AM_V@)
+am__v_P_ = $(am__v_P_@AM_DEFAULT_V@)
+am__v_P_0 = false
+am__v_P_1 = :
+AM_V_GEN = $(am__v_GEN_@AM_V@)
+am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@)
+am__v_GEN_0 = @echo " GEN " $@;
+am__v_GEN_1 =
+AM_V_at = $(am__v_at_@AM_V@)
+am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
+am__v_at_0 = @
+am__v_at_1 =
+DEFAULT_INCLUDES = -I.@am__isrc@
+depcomp = $(SHELL) $(top_srcdir)/depcomp
+am__depfiles_maybe = depfiles
+am__mv = mv -f
+COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
+ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
+LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
+ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \
+ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \
+ $(AM_CFLAGS) $(CFLAGS)
+AM_V_CC = $(am__v_CC_@AM_V@)
+am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@)
+am__v_CC_0 = @echo " CC " $@;
+am__v_CC_1 =
+CCLD = $(CC)
+LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
+ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
+ $(AM_LDFLAGS) $(LDFLAGS) -o $@
+AM_V_CCLD = $(am__v_CCLD_@AM_V@)
+am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@)
+am__v_CCLD_0 = @echo " CCLD " $@;
+am__v_CCLD_1 =
+SOURCES = $(liblcms2mt_fast_float_la_SOURCES)
+DIST_SOURCES = $(liblcms2mt_fast_float_la_SOURCES)
+am__can_run_installinfo = \
+ case $$AM_UPDATE_INFO_DIR in \
+ n|no|NO) false;; \
+ *) (install-info --version) >/dev/null 2>&1;; \
+ esac
+am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP)
+# Read a list of newline-separated strings from the standard input,
+# and print each of them once, without duplicates. Input order is
+# *not* preserved.
+am__uniquify_input = $(AWK) '\
+ BEGIN { nonempty = 0; } \
+ { items[$$0] = 1; nonempty = 1; } \
+ END { if (nonempty) { for (i in items) print i; }; } \
+'
+# Make sure the list of sources is unique. This is necessary because,
+# e.g., the same source file might be shared among _SOURCES variables
+# for different programs/libraries.
+am__define_uniq_tagged_files = \
+ list='$(am__tagged_files)'; \
+ unique=`for i in $$list; do \
+ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+ done | $(am__uniquify_input)`
+ETAGS = etags
+CTAGS = ctags
+am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp
+DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
+ACLOCAL = @ACLOCAL@
+AMTAR = @AMTAR@
+AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@
+AR = @AR@
+AS = @AS@
+AUTOCONF = @AUTOCONF@
+AUTOHEADER = @AUTOHEADER@
+AUTOMAKE = @AUTOMAKE@
+AWK = @AWK@
+CC = @CC@
+CCDEPMODE = @CCDEPMODE@
+CFLAGS = @CFLAGS@
+CPP = @CPP@
+CPPFLAGS = @CPPFLAGS@
+CXX = @CXX@
+CXXCPP = @CXXCPP@
+CXXDEPMODE = @CXXDEPMODE@
+CXXFLAGS = @CXXFLAGS@
+CYGPATH_W = @CYGPATH_W@
+DEFS = @DEFS@
+DEPDIR = @DEPDIR@
+DLLTOOL = @DLLTOOL@
+DSYMUTIL = @DSYMUTIL@
+DUMPBIN = @DUMPBIN@
+ECHO_C = @ECHO_C@
+ECHO_N = @ECHO_N@
+ECHO_T = @ECHO_T@
+EGREP = @EGREP@
+EXEEXT = @EXEEXT@
+FGREP = @FGREP@
+GREP = @GREP@
+INSTALL = @INSTALL@
+INSTALL_DATA = @INSTALL_DATA@
+INSTALL_PROGRAM = @INSTALL_PROGRAM@
+INSTALL_SCRIPT = @INSTALL_SCRIPT@
+INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
+JPEGICC_DEPLIBS = @JPEGICC_DEPLIBS@
+LCMS_LIB_DEPLIBS = @LCMS_LIB_DEPLIBS@
+LD = @LD@
+LDFLAGS = @LDFLAGS@
+LIBOBJS = @LIBOBJS@
+LIBRARY_AGE = 0
+LIBRARY_CURRENT = 1
+LIBRARY_REVISION = 1
+LIBS = @LIBS@
+LIBTOOL = @LIBTOOL@
+LIBTOOL_DEPS = @LIBTOOL_DEPS@
+LIB_JPEG = @LIB_JPEG@
+LIB_MATH = @LIB_MATH@
+LIB_PLUGINS = @LIB_PLUGINS@
+LIB_THREAD = @LIB_THREAD@
+LIB_TIFF = @LIB_TIFF@
+LIB_ZLIB = @LIB_ZLIB@
+LIPO = @LIPO@
+LN_S = @LN_S@
+LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
+MAINT = @MAINT@
+MAKEINFO = @MAKEINFO@
+MANIFEST_TOOL = @MANIFEST_TOOL@
+MKDIR_P = @MKDIR_P@
+NM = @NM@
+NMEDIT = @NMEDIT@
+OBJDUMP = @OBJDUMP@
+OBJEXT = @OBJEXT@
+OTOOL = @OTOOL@
+OTOOL64 = @OTOOL64@
+PACKAGE = @PACKAGE@
+PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
+PACKAGE_NAME = @PACKAGE_NAME@
+PACKAGE_STRING = @PACKAGE_STRING@
+PACKAGE_TARNAME = @PACKAGE_TARNAME@
+PACKAGE_URL = @PACKAGE_URL@
+PACKAGE_VERSION = @PACKAGE_VERSION@
+PATH_SEPARATOR = @PATH_SEPARATOR@
+PTHREAD_CC = @PTHREAD_CC@
+PTHREAD_CFLAGS = @PTHREAD_CFLAGS@
+PTHREAD_CXX = @PTHREAD_CXX@
+PTHREAD_LIBS = @PTHREAD_LIBS@
+RANLIB = @RANLIB@
+SED = @SED@
+SET_MAKE = @SET_MAKE@
+SHELL = @SHELL@
+STRIP = @STRIP@
+TIFFICC_DEPLIBS = @TIFFICC_DEPLIBS@
+VERSION = @VERSION@
+abs_builddir = @abs_builddir@
+abs_srcdir = @abs_srcdir@
+abs_top_builddir = @abs_top_builddir@
+abs_top_srcdir = @abs_top_srcdir@
+ac_ct_AR = @ac_ct_AR@
+ac_ct_CC = @ac_ct_CC@
+ac_ct_CXX = @ac_ct_CXX@
+ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
+acx_pthread_config = @acx_pthread_config@
+am__include = @am__include@
+am__leading_dot = @am__leading_dot@
+am__quote = @am__quote@
+am__tar = @am__tar@
+am__untar = @am__untar@
+bindir = @bindir@
+build = @build@
+build_alias = @build_alias@
+build_cpu = @build_cpu@
+build_os = @build_os@
+build_vendor = @build_vendor@
+builddir = @builddir@
+datadir = @datadir@
+datarootdir = @datarootdir@
+docdir = @docdir@
+dvidir = @dvidir@
+exec_prefix = @exec_prefix@
+host = @host@
+host_alias = @host_alias@
+host_cpu = @host_cpu@
+host_os = @host_os@
+host_vendor = @host_vendor@
+htmldir = @htmldir@
+includedir = ${prefix}/include
+infodir = @infodir@
+inline = @inline@
+install_sh = @install_sh@
+libdir = @libdir@
+libexecdir = @libexecdir@
+localedir = @localedir@
+localstatedir = @localstatedir@
+mandir = @mandir@
+mkdir_p = @mkdir_p@
+oldincludedir = @oldincludedir@
+pdfdir = @pdfdir@
+prefix = @prefix@
+program_transform_name = @program_transform_name@
+psdir = @psdir@
+runstatedir = @runstatedir@
+sbindir = @sbindir@
+sharedstatedir = @sharedstatedir@
+srcdir = @srcdir@
+sysconfdir = @sysconfdir@
+target_alias = @target_alias@
+top_build_prefix = @top_build_prefix@
+top_builddir = @top_builddir@
+top_srcdir = @top_srcdir@
+
+# Don't require all the GNU mandated files
+AUTOMAKE_OPTIONS = 1.7 foreign
+
+# Shared libraries built in this directory
+lib_LTLIBRARIES = liblcms2mt_fast_float.la
+AM_CPPFLAGS = -Ofast -I$(top_builddir)/include -I$(top_srcdir)/include -I$(srcdir)/../include -I$(builddir)/../include
+liblcms2mt_fast_float_la_LDFLAGS = -no-undefined \
+ -version-info $(LIBRARY_CURRENT):$(LIBRARY_REVISION):$(LIBRARY_AGE)
+
+liblcms2mt_fast_float_la_LIBADD = $(LCMS_LIB_DEPLIBS) $(top_builddir)/src/liblcms2mt.la
+liblcms2mt_fast_float_la_SOURCES = fast_8_curves.c fast_8_matsh_sse.c fast_8_matsh.c fast_8_tethra.c \
+ fast_16_tethra.c fast_float_15bits.c fast_float_15mats.c fast_float_cmyk.c fast_float_curves.c fast_float_matsh.c \
+ fast_float_separate.c fast_float_sup.c fast_float_tethra.c fast_float_lab.c fast_float_internal.h
+
+all: all-am
+
+.SUFFIXES:
+.SUFFIXES: .c .lo .o .obj
+$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.am $(am__configure_deps)
+ @for dep in $?; do \
+ case '$(am__configure_deps)' in \
+ *$$dep*) \
+ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \
+ && { if test -f $@; then exit 0; else break; fi; }; \
+ exit 1;; \
+ esac; \
+ done; \
+ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign plugins/fast_float/src/Makefile'; \
+ $(am__cd) $(top_srcdir) && \
+ $(AUTOMAKE) --foreign plugins/fast_float/src/Makefile
+Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
+ @case '$?' in \
+ *config.status*) \
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
+ *) \
+ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
+ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
+ esac;
+
+$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
+
+$(top_srcdir)/configure: @MAINTAINER_MODE_TRUE@ $(am__configure_deps)
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
+$(ACLOCAL_M4): @MAINTAINER_MODE_TRUE@ $(am__aclocal_m4_deps)
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
+$(am__aclocal_m4_deps):
+
+install-libLTLIBRARIES: $(lib_LTLIBRARIES)
+ @$(NORMAL_INSTALL)
+ @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \
+ list2=; for p in $$list; do \
+ if test -f $$p; then \
+ list2="$$list2 $$p"; \
+ else :; fi; \
+ done; \
+ test -z "$$list2" || { \
+ echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \
+ $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \
+ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \
+ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \
+ }
+
+uninstall-libLTLIBRARIES:
+ @$(NORMAL_UNINSTALL)
+ @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \
+ for p in $$list; do \
+ $(am__strip_dir) \
+ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \
+ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \
+ done
+
+clean-libLTLIBRARIES:
+ -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES)
+ @list='$(lib_LTLIBRARIES)'; \
+ locs=`for p in $$list; do echo $$p; done | \
+ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \
+ sort -u`; \
+ test -z "$$locs" || { \
+ echo rm -f $${locs}; \
+ rm -f $${locs}; \
+ }
+
+liblcms2mt_fast_float.la: $(liblcms2mt_fast_float_la_OBJECTS) $(liblcms2mt_fast_float_la_DEPENDENCIES) $(EXTRA_liblcms2mt_fast_float_la_DEPENDENCIES)
+ $(AM_V_CCLD)$(liblcms2mt_fast_float_la_LINK) -rpath $(libdir) $(liblcms2mt_fast_float_la_OBJECTS) $(liblcms2mt_fast_float_la_LIBADD) $(LIBS)
+
+mostlyclean-compile:
+ -rm -f *.$(OBJEXT)
+
+distclean-compile:
+ -rm -f *.tab.c
+
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fast_16_tethra.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fast_8_curves.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fast_8_matsh.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fast_8_matsh_sse.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fast_8_tethra.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fast_float_15bits.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fast_float_15mats.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fast_float_cmyk.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fast_float_curves.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fast_float_lab.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fast_float_matsh.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fast_float_separate.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fast_float_sup.Plo@am__quote@
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fast_float_tethra.Plo@am__quote@
+
+.c.o:
+@am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\
+@am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\
+@am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $<
+
+.c.obj:
+@am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\
+@am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\
+@am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'`
+
+.c.lo:
+@am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\
+@am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\
+@am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $<
+
+mostlyclean-libtool:
+ -rm -f *.lo
+
+clean-libtool:
+ -rm -rf .libs _libs
+
+ID: $(am__tagged_files)
+ $(am__define_uniq_tagged_files); mkid -fID $$unique
+tags: tags-am
+TAGS: tags
+
+tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
+ set x; \
+ here=`pwd`; \
+ $(am__define_uniq_tagged_files); \
+ shift; \
+ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
+ test -n "$$unique" || unique=$$empty_fix; \
+ if test $$# -gt 0; then \
+ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+ "$$@" $$unique; \
+ else \
+ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+ $$unique; \
+ fi; \
+ fi
+ctags: ctags-am
+
+CTAGS: ctags
+ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
+ $(am__define_uniq_tagged_files); \
+ test -z "$(CTAGS_ARGS)$$unique" \
+ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
+ $$unique
+
+GTAGS:
+ here=`$(am__cd) $(top_builddir) && pwd` \
+ && $(am__cd) $(top_srcdir) \
+ && gtags -i $(GTAGS_ARGS) "$$here"
+cscopelist: cscopelist-am
+
+cscopelist-am: $(am__tagged_files)
+ list='$(am__tagged_files)'; \
+ case "$(srcdir)" in \
+ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \
+ *) sdir=$(subdir)/$(srcdir) ;; \
+ esac; \
+ for i in $$list; do \
+ if test -f "$$i"; then \
+ echo "$(subdir)/$$i"; \
+ else \
+ echo "$$sdir/$$i"; \
+ fi; \
+ done >> $(top_builddir)/cscope.files
+
+distclean-tags:
+ -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
+
+distdir: $(DISTFILES)
+ @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
+ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
+ list='$(DISTFILES)'; \
+ dist_files=`for file in $$list; do echo $$file; done | \
+ sed -e "s|^$$srcdirstrip/||;t" \
+ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \
+ case $$dist_files in \
+ */*) $(MKDIR_P) `echo "$$dist_files" | \
+ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \
+ sort -u` ;; \
+ esac; \
+ for file in $$dist_files; do \
+ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
+ if test -d $$d/$$file; then \
+ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
+ if test -d "$(distdir)/$$file"; then \
+ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
+ fi; \
+ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \
+ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
+ fi; \
+ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \
+ else \
+ test -f "$(distdir)/$$file" \
+ || cp -p $$d/$$file "$(distdir)/$$file" \
+ || exit 1; \
+ fi; \
+ done
+check-am: all-am
+check: check-am
+all-am: Makefile $(LTLIBRARIES)
+installdirs:
+ for dir in "$(DESTDIR)$(libdir)"; do \
+ test -z "$$dir" || $(MKDIR_P) "$$dir"; \
+ done
+install: install-am
+install-exec: install-exec-am
+install-data: install-data-am
+uninstall: uninstall-am
+
+install-am: all-am
+ @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
+
+installcheck: installcheck-am
+install-strip:
+ if test -z '$(STRIP)'; then \
+ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
+ install; \
+ else \
+ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
+ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \
+ fi
+mostlyclean-generic:
+
+clean-generic:
+
+distclean-generic:
+ -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
+ -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
+
+maintainer-clean-generic:
+ @echo "This command is intended for maintainers to use"
+ @echo "it deletes files that may require special tools to rebuild."
+clean: clean-am
+
+clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \
+ mostlyclean-am
+
+distclean: distclean-am
+ -rm -rf ./$(DEPDIR)
+ -rm -f Makefile
+distclean-am: clean-am distclean-compile distclean-generic \
+ distclean-tags
+
+dvi: dvi-am
+
+dvi-am:
+
+html: html-am
+
+html-am:
+
+info: info-am
+
+info-am:
+
+install-data-am:
+
+install-dvi: install-dvi-am
+
+install-dvi-am:
+
+install-exec-am: install-libLTLIBRARIES
+
+install-html: install-html-am
+
+install-html-am:
+
+install-info: install-info-am
+
+install-info-am:
+
+install-man:
+
+install-pdf: install-pdf-am
+
+install-pdf-am:
+
+install-ps: install-ps-am
+
+install-ps-am:
+
+installcheck-am:
+
+maintainer-clean: maintainer-clean-am
+ -rm -rf ./$(DEPDIR)
+ -rm -f Makefile
+maintainer-clean-am: distclean-am maintainer-clean-generic
+
+mostlyclean: mostlyclean-am
+
+mostlyclean-am: mostlyclean-compile mostlyclean-generic \
+ mostlyclean-libtool
+
+pdf: pdf-am
+
+pdf-am:
+
+ps: ps-am
+
+ps-am:
+
+uninstall-am: uninstall-libLTLIBRARIES
+
+.MAKE: install-am install-strip
+
+.PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \
+ clean-libLTLIBRARIES clean-libtool cscopelist-am ctags \
+ ctags-am distclean distclean-compile distclean-generic \
+ distclean-libtool distclean-tags distdir dvi dvi-am html \
+ html-am info info-am install install-am install-data \
+ install-data-am install-dvi install-dvi-am install-exec \
+ install-exec-am install-html install-html-am install-info \
+ install-info-am install-libLTLIBRARIES install-man install-pdf \
+ install-pdf-am install-ps install-ps-am install-strip \
+ installcheck installcheck-am installdirs maintainer-clean \
+ maintainer-clean-generic mostlyclean mostlyclean-compile \
+ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \
+ tags tags-am uninstall uninstall-am uninstall-libLTLIBRARIES
+
+.PRECIOUS: Makefile
+
+
+# Tell versions [3.59,3.63) of GNU make to not export all variables.
+# Otherwise a system limit (for SysV at least) may be exceeded.
+.NOEXPORT:
diff --git a/lcms2mt/plugins/fast_float/src/fast_16_tethra.c b/lcms2mt/plugins/fast_float/src/fast_16_tethra.c
index 6b3110ae..75fac75a 100644
--- a/lcms2mt/plugins/fast_float/src/fast_16_tethra.c
+++ b/lcms2mt/plugins/fast_float/src/fast_16_tethra.c
@@ -316,7 +316,6 @@ cmsBool Optimize16BitRGBTransform(cmsContext ContextID,
cmsUInt32Number* OutputFormat,
cmsUInt32Number* dwFlags)
{
- cmsStage* mpe;
Performance16Data* p16;
_cmsStageCLutData* data;
cmsUInt32Number newFlags;
@@ -351,12 +350,6 @@ cmsBool Optimize16BitRGBTransform(cmsContext ContextID,
cmsSigCurveSetElemType, cmsSigCurveSetElemType,
NULL, NULL)) return FALSE;
- // Named color pipelines cannot be optimized either
- for (mpe = cmsPipelineGetPtrToFirstStage(ContextID, *Lut);
- mpe != NULL;
- mpe = cmsStageNext(ContextID, mpe)) {
- if (cmsStageType(ContextID, mpe) == cmsSigNamedColorElemType) return FALSE;
- }
newFlags = *dwFlags | cmsFLAGS_FORCE_CLUT;
diff --git a/lcms2mt/plugins/fast_float/src/fast_8_matsh_sse.c b/lcms2mt/plugins/fast_float/src/fast_8_matsh_sse.c
new file mode 100644
index 00000000..96c7a492
--- /dev/null
+++ b/lcms2mt/plugins/fast_float/src/fast_8_matsh_sse.c
@@ -0,0 +1,420 @@
+//---------------------------------------------------------------------------------
+//
+// Little Color Management System, fast floating point extensions
+// Copyright (c) 1998-2020 Marti Maria Saguer, all rights reserved
+//
+//
+// This program is free software: you can redistribute it and/or modify
+// it under the terms of the GNU General Public License as published by
+// the Free Software Foundation, either version 3 of the License, or
+// (at your option) any later version.
+//
+// This program is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with this program. If not, see <http://www.gnu.org/licenses/>.
+//
+//---------------------------------------------------------------------------------
+
+// Optimization for matrix-shaper in 8 bits using SSE2 intrinsics
+
+#include "fast_float_internal.h"
+
+
+#ifndef CMS_DONT_USE_SSE2
+
+#ifdef _MSC_VER
+#include <intrin.h>
+#else
+#include <x86intrin.h>
+#include <cpuid.h>
+#endif
+
+#include <emmintrin.h>
+
+
+// This is the private data container used by this optimization
+typedef struct {
+
+ // This is for SSE, MUST be aligned at 16 bit boundary
+
+ cmsFloat32Number Mat[4][4]; // n.14 to n.14 (needs a saturation after that)
+
+ void * real_ptr;
+
+ cmsContext ContextID;
+
+ cmsFloat32Number Shaper1R[256]; // from 0..255 to 1.14 (0.0...1.0)
+ cmsFloat32Number Shaper1G[256];
+ cmsFloat32Number Shaper1B[256];
+
+ cmsUInt8Number Shaper2R[0x4001]; // 1.14 to 0..255
+ cmsUInt8Number Shaper2G[0x4001];
+ cmsUInt8Number Shaper2B[0x4001];
+
+} XMatShaper8Data;
+
+
+static
+XMatShaper8Data* malloc_aligned(cmsContext ContextID)
+{
+ cmsUInt8Number* real_ptr = (cmsUInt8Number*) _cmsMallocZero(ContextID, sizeof(XMatShaper8Data) + 32);
+ cmsUInt8Number* aligned = (cmsUInt8Number*) (((uintptr_t)real_ptr + 16) & ~0xf);
+ XMatShaper8Data* p = (XMatShaper8Data*) aligned;
+
+ p ->real_ptr = real_ptr;
+ return p;
+}
+
+static
+void free_aligned(cmsContext ContextID, XMatShaper8Data* a)
+{
+ _cmsFree(ContextID, a->real_ptr);
+}
+
+
+// Free the private data container
+static
+void FreeMatShaper(cmsContext ContextID, void* Data)
+{
+ UNUSED_PARAMETER(ContextID);
+
+ if (Data != NULL) free_aligned(ContextID, (XMatShaper8Data*) Data);
+}
+
+
+// This table converts from 8 bits to 1.14 after applying the curve
+static
+void FillFirstShaper(cmsContext ContextID, cmsFloat32Number* Table, cmsToneCurve* Curve)
+{
+ cmsInt32Number i;
+ cmsFloat32Number R;
+
+ for (i = 0; i < 256; i++) {
+
+ R = (cmsFloat32Number)(i / 255.0);
+ Table[i] = cmsEvalToneCurveFloat(ContextID, Curve, R);
+ }
+}
+
+
+// This table converts form 1.14 (being 0x4000 the last entry) to 8 bits after applying the curve
+static
+void FillSecondShaper(cmsContext ContextID, cmsUInt8Number* Table, cmsToneCurve* Curve)
+{
+ int i;
+ cmsFloat32Number R, Val;
+ cmsInt32Number w;
+
+ for (i=0; i < 0x4001; i++) {
+
+ R = (cmsFloat32Number) (i / 16384.0f);
+ Val = cmsEvalToneCurveFloat(ContextID, Curve, R);
+ w = (cmsInt32Number) (Val * 255.0f + 0.5f);
+ if (w < 0) w = 0;
+ if (w > 255) w = 255;
+
+ Table[i] = (cmsInt8Number) w;
+
+ }
+}
+
+// Compute the matrix-shaper structure
+static
+XMatShaper8Data* SetMatShaper(cmsContext ContextID, cmsToneCurve* Curve1[3], cmsMAT3* Mat, cmsVEC3* Off, cmsToneCurve* Curve2[3])
+{
+ XMatShaper8Data* p;
+ int i, j;
+
+ // Allocate a big chuck of memory to store precomputed tables
+ p = malloc_aligned(ContextID);
+ if (p == NULL) return FALSE;
+
+ // Precompute tables
+ FillFirstShaper(ContextID, p ->Shaper1R, Curve1[0]);
+ FillFirstShaper(ContextID, p ->Shaper1G, Curve1[1]);
+ FillFirstShaper(ContextID, p ->Shaper1B, Curve1[2]);
+
+ FillSecondShaper(ContextID, p ->Shaper2R, Curve2[0]);
+ FillSecondShaper(ContextID, p ->Shaper2G, Curve2[1]);
+ FillSecondShaper(ContextID, p ->Shaper2B, Curve2[2]);
+
+
+ // Convert matrix to float
+ for (i=0; i < 3; i++) {
+ for (j=0; j < 3; j++) {
+ p ->Mat[j][i] = (cmsFloat32Number) Mat->v[i].n[j];
+ }
+ }
+
+ // Roundoff
+ for (i=0; i < 3; i++) {
+
+ if (Off == NULL) {
+
+ p->Mat[3][i] = 0.0f;
+ }
+ else {
+ p->Mat[3][i] = (cmsFloat32Number)Off->n[i];
+ }
+ }
+
+
+ return p;
+}
+
+// A fast matrix-shaper evaluator for 8 bits.
+static
+void MatShaperXform8SSE(cmsContext ContextID,
+ struct _cmstransform_struct *CMMcargo,
+ const void* Input,
+ void* Output,
+ cmsUInt32Number PixelsPerLine,
+ cmsUInt32Number LineCount,
+ const cmsStride* Stride)
+{
+ XMatShaper8Data* p = (XMatShaper8Data*) _cmsGetTransformUserData(CMMcargo);
+
+ cmsUInt32Number i, ii;
+
+ cmsUInt32Number SourceStartingOrder[cmsMAXCHANNELS];
+ cmsUInt32Number SourceIncrements[cmsMAXCHANNELS];
+ cmsUInt32Number DestStartingOrder[cmsMAXCHANNELS];
+ cmsUInt32Number DestIncrements[cmsMAXCHANNELS];
+
+ const cmsUInt8Number* rin;
+ const cmsUInt8Number* gin;
+ const cmsUInt8Number* bin;
+ const cmsUInt8Number* ain = NULL;
+
+ cmsUInt8Number* rout;
+ cmsUInt8Number* gout;
+ cmsUInt8Number* bout;
+ cmsUInt8Number* aout = NULL;
+
+ cmsUInt32Number nalpha, strideIn, strideOut;
+
+ __m128 mat0 = _mm_load_ps(p->Mat[0]);
+ __m128 mat1 = _mm_load_ps(p->Mat[1]);
+ __m128 mat2 = _mm_load_ps(p->Mat[2]);
+ __m128 mat3 = _mm_load_ps(p->Mat[3]);
+
+ __m128 zero = _mm_setzero_ps();
+ __m128 one = _mm_set1_ps(1.0f);
+ __m128 scale = _mm_set1_ps((cmsFloat32Number)0x4000);
+
+ cmsUInt8Number buffer[32];
+ cmsUInt32Number* output_index = (cmsUInt32Number*)(((uintptr_t)buffer + 16) & ~0xf);
+
+
+ _cmsComputeComponentIncrements(cmsGetTransformInputFormat(ContextID, (cmsHTRANSFORM)CMMcargo), Stride->BytesPerPlaneIn, NULL, &nalpha, SourceStartingOrder, SourceIncrements);
+ _cmsComputeComponentIncrements(cmsGetTransformOutputFormat(ContextID, (cmsHTRANSFORM)CMMcargo), Stride->BytesPerPlaneOut, NULL, &nalpha, DestStartingOrder, DestIncrements);
+
+ if (!(_cmsGetTransformFlags((cmsHTRANSFORM)CMMcargo) & cmsFLAGS_COPY_ALPHA))
+ nalpha = 0;
+
+ strideIn = strideOut = 0;
+ for (i = 0; i < LineCount; i++) {
+
+ rin = (const cmsUInt8Number*)Input + SourceStartingOrder[0] + strideIn;
+ gin = (const cmsUInt8Number*)Input + SourceStartingOrder[1] + strideIn;
+ bin = (const cmsUInt8Number*)Input + SourceStartingOrder[2] + strideIn;
+ if (nalpha)
+ ain = (const cmsUInt8Number*)Input + SourceStartingOrder[3] + strideIn;
+
+
+ rout = (cmsUInt8Number*)Output + DestStartingOrder[0] + strideOut;
+ gout = (cmsUInt8Number*)Output + DestStartingOrder[1] + strideOut;
+ bout = (cmsUInt8Number*)Output + DestStartingOrder[2] + strideOut;
+ if (nalpha)
+ aout = (cmsUInt8Number*)Output + DestStartingOrder[3] + strideOut;
+
+ /**
+ * Prefetch
+ */
+ __m128 rvector = _mm_set1_ps(p->Shaper1R[*rin]);
+ __m128 gvector = _mm_set1_ps(p->Shaper1G[*gin]);
+ __m128 bvector = _mm_set1_ps(p->Shaper1B[*bin]);
+
+ for (ii = 0; ii < PixelsPerLine; ii++) {
+
+ __m128 el1 = _mm_mul_ps(rvector, mat0);
+ __m128 el2 = _mm_mul_ps(gvector, mat1);
+ __m128 el3 = _mm_mul_ps(bvector, mat2);
+
+ __m128 sum = _mm_add_ps(el1, _mm_add_ps(el2, _mm_add_ps(el3, mat3)));
+
+ __m128 out = _mm_min_ps(_mm_max_ps(sum, zero), one);
+
+ out = _mm_mul_ps(out, scale);
+
+ /**
+ * Rounding and converting to index.
+ * Actually this is a costly instruction that may be blocking performance
+ */
+ _mm_store_si128((__m128i*)output_index, _mm_cvtps_epi32(out));
+
+
+ // Handle alpha
+ if (ain) {
+ *aout = *ain;
+ }
+
+ rin += SourceIncrements[0];
+ gin += SourceIncrements[1];
+ bin += SourceIncrements[2];
+ if (ain) ain += SourceIncrements[3];
+
+ /**
+ * Take next value whilst store is being performed
+ */
+ if (ii < PixelsPerLine - 1)
+ {
+ rvector = _mm_set1_ps(p->Shaper1R[*rin]);
+ gvector = _mm_set1_ps(p->Shaper1G[*gin]);
+ bvector = _mm_set1_ps(p->Shaper1B[*bin]);
+ }
+
+ *rout = p->Shaper2R[output_index[0]];
+ *gout = p->Shaper2G[output_index[1]];
+ *bout = p->Shaper2B[output_index[2]];
+
+ rout += DestIncrements[0];
+ gout += DestIncrements[1];
+ bout += DestIncrements[2];
+ if (aout) aout += DestIncrements[3];
+ }
+
+ strideIn += Stride->BytesPerLineIn;
+ strideOut += Stride->BytesPerLineOut;
+ }
+}
+
+
+static
+cmsBool IsSSE2Available(void)
+{
+#ifdef _MSC_VER
+ int cpuinfo[4];
+
+ __cpuid(cpuinfo, 1);
+ if (!(cpuinfo[3] & (1 << 26))) return FALSE;
+ return TRUE;
+
+#else
+ unsigned int level = 1u;
+ unsigned int eax, ebx, ecx, edx;
+ unsigned int bits = (1u << 26);
+ unsigned int max = __get_cpuid_max(0, NULL);
+ if (level > max) {
+ return FALSE;
+ }
+ __cpuid_count(level, 0, eax, ebx, ecx, edx);
+ return (edx & bits) == bits;
+#endif
+}
+
+
+// 8 bits on input allows matrix-shaper boost up a little bit
+cmsBool Optimize8MatrixShaperSSE(cmsContext ContextID,
+ _cmsTransformFn* TransformFn,
+ void** UserData,
+ _cmsFreeUserDataFn* FreeUserData,
+ cmsPipeline** Lut,
+ cmsUInt32Number* InputFormat,
+ cmsUInt32Number* OutputFormat,
+ cmsUInt32Number* dwFlags)
+{
+ cmsStage* Curve1, *Curve2;
+ cmsStage* Matrix1, *Matrix2;
+ _cmsStageMatrixData* Data1;
+ _cmsStageMatrixData* Data2;
+ cmsMAT3 res;
+ cmsBool IdentityMat = FALSE;
+ cmsPipeline* Dest, *Src;
+ cmsUInt32Number nChans;
+
+ // Check for SSE2 support
+ if (!(IsSSE2Available())) return FALSE;
+
+ // Only works on 3 to 3, probably RGB
+ if ( !( (T_CHANNELS(*InputFormat) == 3 && T_CHANNELS(*OutputFormat) == 3) ) ) return FALSE;
+
+ // Only works on 8 bit input
+ if (T_BYTES(*InputFormat) != 1 || T_BYTES(*OutputFormat) != 1) return FALSE;
+
+ // Seems suitable, proceed
+ Src = *Lut;
+
+ // Check for shaper-matrix-matrix-shaper structure, that is what this optimizer stands for
+ if (!cmsPipelineCheckAndRetreiveStages(ContextID, Src, 4,
+ cmsSigCurveSetElemType, cmsSigMatrixElemType, cmsSigMatrixElemType, cmsSigCurveSetElemType,
+ &Curve1, &Matrix1, &Matrix2, &Curve2)) return FALSE;
+
+ nChans = T_CHANNELS(*InputFormat);
+
+ // Get both matrices, which are 3x3
+ Data1 = (_cmsStageMatrixData*) cmsStageData(ContextID, Matrix1);
+ Data2 = (_cmsStageMatrixData*) cmsStageData(ContextID, Matrix2);
+
+ // Input offset should be zero
+ if (Data1->Offset != NULL) return FALSE;
+
+ // Multiply both matrices to get the result
+ _cmsMAT3per(ContextID, &res, (cmsMAT3*)Data2->Double, (cmsMAT3*)Data1->Double);
+
+ // Now the result is in res + Data2 -> Offset. Maybe is a plain identity?
+ IdentityMat = FALSE;
+ if (_cmsMAT3isIdentity(ContextID, &res) && Data2->Offset == NULL) {
+
+ // We can get rid of full matrix
+ IdentityMat = TRUE;
+ }
+
+ // Allocate an empty LUT
+ Dest = cmsPipelineAlloc(ContextID, nChans, nChans);
+ if (!Dest) return FALSE;
+
+ // Assamble the new LUT
+ cmsPipelineInsertStage(ContextID, Dest, cmsAT_BEGIN, cmsStageDup(ContextID, Curve1));
+
+ if (!IdentityMat) {
+
+ cmsPipelineInsertStage(ContextID, Dest, cmsAT_END,
+ cmsStageAllocMatrix(ContextID, 3, 3, (const cmsFloat64Number*) &res, Data2 ->Offset));
+ }
+
+
+ cmsPipelineInsertStage(ContextID, Dest, cmsAT_END, cmsStageDup(ContextID, Curve2));
+
+ // If identity on matrix, we can further optimize the curves, so call the join curves routine
+ if (IdentityMat) {
+
+ Optimize8ByJoiningCurves(ContextID, TransformFn, UserData, FreeUserData, &Dest, InputFormat, OutputFormat, dwFlags);
+ }
+ else {
+ _cmsStageToneCurvesData* mpeC1 = (_cmsStageToneCurvesData*) cmsStageData(ContextID, Curve1);
+ _cmsStageToneCurvesData* mpeC2 = (_cmsStageToneCurvesData*) cmsStageData(ContextID, Curve2);
+
+ // In this particular optimization, cache does not help as it takes more time to deal with
+ // the cache that with the pixel handling
+ *dwFlags |= cmsFLAGS_NOCACHE;
+
+
+ // Setup the optimizarion routines
+ *UserData = SetMatShaper(ContextID, mpeC1 ->TheCurves, &res, (cmsVEC3*) Data2 ->Offset, mpeC2->TheCurves);
+ *FreeUserData = FreeMatShaper;
+
+ *TransformFn = (_cmsTransformFn) MatShaperXform8SSE;
+ }
+
+ *dwFlags &= ~cmsFLAGS_CAN_CHANGE_FORMATTER;
+ cmsPipelineFree(ContextID, Src);
+ *Lut = Dest;
+ return TRUE;
+}
+
+#endif
diff --git a/lcms2mt/plugins/fast_float/src/fast_8_tethra.c b/lcms2mt/plugins/fast_float/src/fast_8_tethra.c
index a43a337b..ace2bdbd 100644
--- a/lcms2mt/plugins/fast_float/src/fast_8_tethra.c
+++ b/lcms2mt/plugins/fast_float/src/fast_8_tethra.c
@@ -247,11 +247,12 @@ void PerformanceEval8(cmsContext ContextID,
*out[OutChan] = FROM_16_TO_8(res16);
out[OutChan] += DestIncrements[OutChan];
- if (ain)
- *out[TotalOut] = *ain;
-
}
+ if (ain) {
+ *out[TotalOut] = *ain;
+ out[TotalOut] += DestIncrements[TotalOut];
+ }
}
@@ -344,7 +345,6 @@ cmsBool Optimize8BitRGBTransform( cmsContext ContextID,
cmsPipeline* OptimizedLUT = NULL, *LutPlusCurves = NULL;
cmsStage* OptimizedCLUTmpe;
cmsStage* OptimizedPrelinMpe;
- cmsStage* mpe;
Performance8Data* p8;
cmsUInt16Number* MyTable[3];
_cmsStageCLutData* data;
@@ -363,13 +363,6 @@ cmsBool Optimize8BitRGBTransform( cmsContext ContextID,
OriginalLut = *Lut;
- // Named color pipelines cannot be optimized either
- for (mpe = cmsPipelineGetPtrToFirstStage(ContextID, OriginalLut);
- mpe != NULL;
- mpe = cmsStageNext(ContextID, mpe)) {
- if (cmsStageType(ContextID, mpe) == cmsSigNamedColorElemType) return FALSE;
- }
-
nGridPoints = _cmsReasonableGridpointsByColorspace(cmsSigRgbData, *dwFlags);
// Empty gamma containers
diff --git a/lcms2mt/plugins/fast_float/src/fast_float_cmyk.c b/lcms2mt/plugins/fast_float/src/fast_float_cmyk.c
index 5c463631..1e7abf66 100644
--- a/lcms2mt/plugins/fast_float/src/fast_float_cmyk.c
+++ b/lcms2mt/plugins/fast_float/src/fast_float_cmyk.c
@@ -62,7 +62,7 @@ cmsINLINE cmsFloat32Number LinearInterpInt(cmsFloat32Number a, cmsFloat32Number
// To prevent out of bounds indexing
cmsINLINE cmsFloat32Number fclamp100(cmsFloat32Number v)
{
- return v < 0.0f ? 0.0f : (v > 100.0f ? 100.0f : v);
+ return ((v < 1.0e-9f) || isnan(v)) ? 0.0f : (v > 100.0f ? 100.0f : v);
}
@@ -331,7 +331,6 @@ cmsBool OptimizeCLUTCMYKTransform(cmsContext ContextID,
int nGridPoints;
cmsPipeline* OptimizedLUT = NULL;
cmsStage* OptimizedCLUTmpe;
- cmsStage* mpe;
FloatCMYKData* pcmyk;
_cmsStageCLutData* data;
@@ -349,13 +348,6 @@ cmsBool OptimizeCLUTCMYKTransform(cmsContext ContextID,
OriginalLut = *Lut;
- // Named color pipelines cannot be optimized either
- for (mpe = cmsPipelineGetPtrToFirstStage(ContextID, OriginalLut);
- mpe != NULL;
- mpe = cmsStageNext(ContextID, mpe)) {
- if (cmsStageType(ContextID, mpe) == cmsSigNamedColorElemType) return FALSE;
- }
-
nGridPoints = _cmsReasonableGridpointsByColorspace(cmsSigRgbData, *dwFlags);
// Create the result LUT
diff --git a/lcms2mt/plugins/fast_float/src/fast_float_internal.h b/lcms2mt/plugins/fast_float/src/fast_float_internal.h
index 27415a8f..81abe507 100644
--- a/lcms2mt/plugins/fast_float/src/fast_float_internal.h
+++ b/lcms2mt/plugins/fast_float/src/fast_float_internal.h
@@ -41,6 +41,21 @@
# define cmsINLINE static inline
#endif
+/// Properly define some macros to accommodate
+/// older MSVC versions.
+# if defined(_MSC_VER) && _MSC_VER <= 1700
+#include <float.h>
+#define isnan _isnan
+#define isinf(x) (!_finite((x)))
+# endif
+
+#if !defined(_MSC_VER) && (defined(__STDC_VERSION__) && __STDC_VERSION__ < 199901L)
+#if !defined(isinf)
+#define isinf(x) (!finite((x)))
+#endif
+#endif
+
+
// A fast way to convert from/to 16 <-> 8 bits
#define FROM_8_TO_16(rgb) (cmsUInt16Number) ((((cmsUInt16Number) (rgb)) << 8)|(rgb))
#define FROM_16_TO_8(rgb) (cmsUInt8Number) ((((rgb) * 65281 + 8388608) >> 24) & 0xFF)
@@ -72,11 +87,10 @@ typedef struct {
#define MAX_NODES_IN_CURVE 0x8001
-
// To prevent out of bounds indexing
cmsINLINE cmsFloat32Number fclamp(cmsFloat32Number v)
{
- return v < 0.0f ? 0.0f : (v > 1.0f ? 1.0f : v);
+ return ((v < 1.0e-9f) || isnan(v)) ? 0.0f : (v > 1.0f ? 1.0f : v);
}
// Fast floor conversion logic.
@@ -120,7 +134,7 @@ cmsINLINE cmsFloat32Number flerp(const cmsFloat32Number LutTable[], cmsFloat32Nu
cmsFloat32Number rest;
int cell0, cell1;
- if (v <= 0.0) {
+ if ((v < 1.0e-9f) || isnan(v)) {
return LutTable[0];
}
else
diff --git a/lcms2mt/plugins/fast_float/src/fast_float_lab.c b/lcms2mt/plugins/fast_float/src/fast_float_lab.c
new file mode 100644
index 00000000..6e088aef
--- /dev/null
+++ b/lcms2mt/plugins/fast_float/src/fast_float_lab.c
@@ -0,0 +1,433 @@
+//---------------------------------------------------------------------------------
+//
+// Little Color Management System, fast floating point extensions
+// Copyright (c) 1998-2020 Marti Maria Saguer, all rights reserved
+//
+//
+// This program is free software: you can redistribute it and/or modify
+// it under the terms of the GNU General Public License as published by
+// the Free Software Foundation, either version 3 of the License, or
+// (at your option) any later version.
+//
+// This program is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+// GNU General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with this program. If not, see <http://www.gnu.org/licenses/>.
+//
+//---------------------------------------------------------------------------------
+
+#include "fast_float_internal.h"
+
+
+#define SIGMOID_POINTS 1024
+
+// Optimization for floating point tetrahedral interpolation using Lab as indexing space
+typedef struct {
+
+ cmsContext ContextID;
+ const cmsInterpParams* p; // Tetrahedrical interpolation parameters. This is a not-owned pointer.
+
+ cmsFloat32Number sigmoidIn[SIGMOID_POINTS]; // to apply to a*/b* axis on indexing
+ cmsFloat32Number sigmoidOut[SIGMOID_POINTS]; // the curve above, inverted.
+
+} LabCLUTdata;
+
+
+typedef struct {
+
+ LabCLUTdata* data;
+ cmsPipeline* original;
+
+} ResamplingContainer;
+
+/**
+* Predefined tone curve
+*/
+#define TYPE_SIGMOID 109
+
+
+// Floating-point version of 1D interpolation
+cmsINLINE cmsFloat32Number LinLerp1D(cmsFloat32Number Value, const cmsFloat32Number* LutTable)
+{
+ if (Value >= 1.0f)
+ {
+ return LutTable[SIGMOID_POINTS - 1];
+ }
+ else
+ if (Value <= 0)
+ {
+ return LutTable[0];
+ }
+ else
+ {
+ cmsFloat32Number y1, y0;
+ cmsFloat32Number rest;
+ int cell0, cell1;
+
+ Value *= (SIGMOID_POINTS - 1);
+
+ cell0 = _cmsQuickFloor(Value);
+ cell1 = cell0 + 1;
+
+ rest = Value - cell0;
+
+ y0 = LutTable[cell0];
+ y1 = LutTable[cell1];
+
+ return y0 + (y1 - y0) * rest;
+ }
+}
+
+static
+void tabulateSigmoid(cmsContext ContextID, cmsInt32Number type, cmsFloat32Number table[], cmsInt32Number tablePoints)
+{
+ const cmsFloat64Number sigmoidal_slope = 2.5;
+ cmsToneCurve* original;
+ cmsInt32Number i;
+
+ memset(table, 0, sizeof(cmsFloat32Number) * tablePoints);
+ original = cmsBuildParametricToneCurve(ContextID, type, &sigmoidal_slope);
+ if (original != NULL)
+ {
+ for (i = 0; i < tablePoints; i++)
+ {
+ cmsFloat32Number v = (cmsFloat32Number)i / (cmsFloat32Number)(tablePoints - 1);
+
+ table[i] = fclamp(cmsEvalToneCurveFloat(ContextID, original, v));
+ }
+
+ cmsFreeToneCurve(ContextID, original);
+ }
+}
+
+
+// Allocates container and curves
+static
+LabCLUTdata* LabCLUTAlloc(cmsContext ContextID, const cmsInterpParams* p)
+{
+ LabCLUTdata* fd;
+
+ fd = (LabCLUTdata*) _cmsMallocZero(ContextID, sizeof(LabCLUTdata));
+ if (fd == NULL) return NULL;
+
+ fd ->ContextID = ContextID;
+ fd ->p = p;
+
+ tabulateSigmoid(ContextID, +TYPE_SIGMOID, fd->sigmoidIn, SIGMOID_POINTS);
+ tabulateSigmoid(ContextID, -TYPE_SIGMOID, fd->sigmoidOut, SIGMOID_POINTS);
+
+ return fd;
+}
+
+static
+void LabCLUTFree(cmsContext ContextID, void* v)
+{
+ _cmsFree(ContextID, v);
+}
+
+// Sampler implemented by another LUT.
+static
+int XFormSampler(cmsContext ContextID, CMSREGISTER const cmsFloat32Number In[], CMSREGISTER cmsFloat32Number Out[], CMSREGISTER void* Cargo)
+{
+ ResamplingContainer* container = (ResamplingContainer*)Cargo;
+ cmsFloat32Number linearized[3];
+
+ // Apply inverse sigmoid
+ linearized[0] = In[0];
+ linearized[1] = LinLerp1D(In[1], container->data->sigmoidOut);
+ linearized[2] = LinLerp1D(In[2], container->data->sigmoidOut);
+
+ cmsPipelineEvalFloat(ContextID, linearized, Out, container->original);
+ return TRUE;
+}
+
+
+// To prevent out of bounds indexing
+cmsINLINE cmsFloat32Number fclamp128(cmsFloat32Number v)
+{
+ return ((v < -128) || isnan(v)) ? -128.0f : (v > 128.0f ? 128.0f : v);
+}
+
+cmsINLINE cmsFloat32Number fclamp100(cmsFloat32Number v)
+{
+ return ((v < 1.0e-9f) || isnan(v)) ? 0.0f : (v > 100.0f ? 100.0f : v);
+}
+
+// A optimized interpolation for Lab.
+#define DENS(i,j,k) (LutTable[(i)+(j)+(k)+OutChan])
+
+static
+void LabCLUTEval(cmsContext ContextID,
+ struct _cmstransform_struct* CMMcargo,
+ const void* Input,
+ void* Output,
+ cmsUInt32Number PixelsPerLine,
+ cmsUInt32Number LineCount,
+ const cmsStride* Stride)
+
+{
+
+ LabCLUTdata* pfloat = (LabCLUTdata*)_cmsGetTransformUserData(CMMcargo);
+
+ cmsFloat32Number l, a, b;
+ cmsFloat32Number px, py, pz;
+ int x0, y0, z0;
+ int X0, Y0, Z0, X1, Y1, Z1;
+ cmsFloat32Number rx, ry, rz;
+ cmsFloat32Number c0, c1 = 0, c2 = 0, c3 = 0;
+ cmsUInt32Number OutChan;
+
+ const cmsInterpParams* p = pfloat->p;
+ cmsUInt32Number TotalOut = p->nOutputs;
+ cmsUInt32Number TotalPlusAlpha;
+ const cmsFloat32Number* LutTable = (const cmsFloat32Number*)p->Table;
+
+ cmsUInt32Number i, ii;
+ const cmsUInt8Number* lin;
+ const cmsUInt8Number* ain;
+ const cmsUInt8Number* bin;
+ const cmsUInt8Number* xin = NULL;
+
+ cmsUInt8Number* out[cmsMAXCHANNELS];
+ cmsUInt32Number SourceStartingOrder[cmsMAXCHANNELS];
+ cmsUInt32Number SourceIncrements[cmsMAXCHANNELS];
+ cmsUInt32Number DestStartingOrder[cmsMAXCHANNELS];
+ cmsUInt32Number DestIncrements[cmsMAXCHANNELS];
+
+ cmsUInt32Number InputFormat = cmsGetTransformInputFormat(ContextID, (cmsHTRANSFORM)CMMcargo);
+ cmsUInt32Number OutputFormat = cmsGetTransformOutputFormat(ContextID, (cmsHTRANSFORM)CMMcargo);
+
+ cmsUInt32Number nchans, nalpha;
+ cmsUInt32Number strideIn, strideOut;
+
+ _cmsComputeComponentIncrements(InputFormat, Stride->BytesPerPlaneIn, &nchans, &nalpha, SourceStartingOrder, SourceIncrements);
+ _cmsComputeComponentIncrements(OutputFormat, Stride->BytesPerPlaneOut, &nchans, &nalpha, DestStartingOrder, DestIncrements);
+
+ if (!(_cmsGetTransformFlags((cmsHTRANSFORM)CMMcargo) & cmsFLAGS_COPY_ALPHA))
+ nalpha = 0;
+
+ strideIn = strideOut = 0;
+ for (i = 0; i < LineCount; i++) {
+
+ lin = (const cmsUInt8Number*)Input + SourceStartingOrder[0] + strideIn;
+ ain = (const cmsUInt8Number*)Input + SourceStartingOrder[1] + strideIn;
+ bin = (const cmsUInt8Number*)Input + SourceStartingOrder[2] + strideIn;
+
+ if (nalpha)
+ xin = (const cmsUInt8Number*)Input + SourceStartingOrder[3] + strideIn;
+
+ TotalPlusAlpha = TotalOut;
+ if (xin) TotalPlusAlpha++;
+
+ for (ii = 0; ii < TotalPlusAlpha; ii++)
+ out[ii] = (cmsUInt8Number*)Output + DestStartingOrder[ii] + strideOut;
+
+ for (ii = 0; ii < PixelsPerLine; ii++) {
+
+ // Decode Lab and go across sigmoids on a*/b*
+ l = fclamp100( *(cmsFloat32Number*)lin ) / 100.0f;
+
+ a = LinLerp1D((( fclamp128( *(cmsFloat32Number*)ain)) + 128.0f) / 255.0f, pfloat->sigmoidIn);
+ b = LinLerp1D((( fclamp128( *(cmsFloat32Number*)bin)) + 128.0f) / 255.0f, pfloat->sigmoidIn);
+
+ lin += SourceIncrements[0];
+ ain += SourceIncrements[1];
+ bin += SourceIncrements[2];
+
+ px = l * p->Domain[0];
+ py = a * p->Domain[1];
+ pz = b * p->Domain[2];
+
+ x0 = _cmsQuickFloor(px); rx = (px - (cmsFloat32Number)x0);
+ y0 = _cmsQuickFloor(py); ry = (py - (cmsFloat32Number)y0);
+ z0 = _cmsQuickFloor(pz); rz = (pz - (cmsFloat32Number)z0);
+
+ X0 = p->opta[2] * x0;
+ X1 = X0 + (l >= 1.0f ? 0 : p->opta[2]);
+
+ Y0 = p->opta[1] * y0;
+ Y1 = Y0 + (a >= 1.0f ? 0 : p->opta[1]);
+
+ Z0 = p->opta[0] * z0;
+ Z1 = Z0 + (b >= 1.0f ? 0 : p->opta[0]);
+
+ for (OutChan = 0; OutChan < TotalOut; OutChan++) {
+
+ // These are the 6 Tetrahedral
+
+ c0 = DENS(X0, Y0, Z0);
+
+ if (rx >= ry && ry >= rz) {
+
+ c1 = DENS(X1, Y0, Z0) - c0;
+ c2 = DENS(X1, Y1, Z0) - DENS(X1, Y0, Z0);
+ c3 = DENS(X1, Y1, Z1) - DENS(X1, Y1, Z0);
+
+ }
+ else
+ if (rx >= rz && rz >= ry) {
+
+ c1 = DENS(X1, Y0, Z0) - c0;
+ c2 = DENS(X1, Y1, Z1) - DENS(X1, Y0, Z1);
+ c3 = DENS(X1, Y0, Z1) - DENS(X1, Y0, Z0);
+
+ }
+ else
+ if (rz >= rx && rx >= ry) {
+
+ c1 = DENS(X1, Y0, Z1) - DENS(X0, Y0, Z1);
+ c2 = DENS(X1, Y1, Z1) - DENS(X1, Y0, Z1);
+ c3 = DENS(X0, Y0, Z1) - c0;
+
+ }
+ else
+ if (ry >= rx && rx >= rz) {
+
+ c1 = DENS(X1, Y1, Z0) - DENS(X0, Y1, Z0);
+ c2 = DENS(X0, Y1, Z0) - c0;
+ c3 = DENS(X1, Y1, Z1) - DENS(X1, Y1, Z0);
+
+ }
+ else
+ if (ry >= rz && rz >= rx) {
+
+ c1 = DENS(X1, Y1, Z1) - DENS(X0, Y1, Z1);
+ c2 = DENS(X0, Y1, Z0) - c0;
+ c3 = DENS(X0, Y1, Z1) - DENS(X0, Y1, Z0);
+
+ }
+ else
+ if (rz >= ry && ry >= rx) {
+
+ c1 = DENS(X1, Y1, Z1) - DENS(X0, Y1, Z1);
+ c2 = DENS(X0, Y1, Z1) - DENS(X0, Y0, Z1);
+ c3 = DENS(X0, Y0, Z1) - c0;
+
+ }
+ else {
+ c1 = c2 = c3 = 0;
+ }
+
+ *(cmsFloat32Number*)(out[OutChan]) = c0 + c1 * rx + c2 * ry + c3 * rz;
+
+ out[OutChan] += DestIncrements[OutChan];
+ }
+
+ if (xin)
+ {
+ *(cmsFloat32Number*) (out[TotalOut]) = *xin;
+ out[TotalOut] += DestIncrements[TotalOut];
+ }
+ }
+
+ strideIn += Stride->BytesPerLineIn;
+ strideOut += Stride->BytesPerLineOut;
+ }
+}
+
+#undef DENS
+
+
+/**
+* Get from flags
+*/
+static
+int GetGridpoints(cmsUInt32Number dwFlags)
+{
+ // Already specified?
+ if (dwFlags & 0x00FF0000) {
+ return (dwFlags >> 16) & 0xFF;
+ }
+
+ // HighResPrecalc is maximum resolution
+ if (dwFlags & cmsFLAGS_HIGHRESPRECALC) {
+ return 66;
+ }
+ else
+ // LowResPrecal is lower resolution
+ if (dwFlags & cmsFLAGS_LOWRESPRECALC) {
+ return 33;
+ }
+ else
+ return 51;
+
+}
+
+// --------------------------------------------------------------------------------------------------------------
+
+cmsBool OptimizeCLUTLabTransform(cmsContext ContextID,
+ _cmsTransformFn* TransformFn,
+ void** UserData,
+ _cmsFreeUserDataFn* FreeDataFn,
+ cmsPipeline** Lut,
+ cmsUInt32Number* InputFormat,
+ cmsUInt32Number* OutputFormat,
+ cmsUInt32Number* dwFlags)
+{
+ cmsPipeline* OriginalLut;
+ int nGridPoints;
+ cmsPipeline* OptimizedLUT = NULL;
+ cmsStage* OptimizedCLUTmpe;
+ LabCLUTdata* pfloat;
+ _cmsStageCLutData* data;
+ ResamplingContainer container;
+
+
+ // For empty transforms, do nothing
+ if (*Lut == NULL) return FALSE;
+
+ // Check for floating point only
+ if (!T_FLOAT(*InputFormat) || !T_FLOAT(*OutputFormat)) return FALSE;
+
+ // Only on floats
+ if (T_BYTES(*InputFormat) != sizeof(cmsFloat32Number) ||
+ T_BYTES(*OutputFormat) != sizeof(cmsFloat32Number)) return FALSE;
+
+ if (T_COLORSPACE(*InputFormat) != PT_Lab) return FALSE;
+
+ OriginalLut = *Lut;
+
+ nGridPoints = GetGridpoints(*dwFlags);
+
+ // Create the result LUT
+ OptimizedLUT = cmsPipelineAlloc(ContextID, 3, cmsPipelineOutputChannels(ContextID, OriginalLut));
+ if (OptimizedLUT == NULL) goto Error;
+
+ // Allocate the CLUT for result
+ OptimizedCLUTmpe = cmsStageAllocCLutFloat(ContextID, nGridPoints, 3, cmsPipelineOutputChannels(ContextID, OriginalLut), NULL);
+
+ // Add the CLUT to the destination LUT
+ cmsPipelineInsertStage(ContextID, OptimizedLUT, cmsAT_BEGIN, OptimizedCLUTmpe);
+
+ // Set the evaluator, copy parameters
+ data = (_cmsStageCLutData*) cmsStageData(ContextID, OptimizedCLUTmpe);
+
+ // Allocate data
+ pfloat = LabCLUTAlloc(ContextID, data ->Params);
+ if (pfloat == NULL) return FALSE;
+
+ container.data = pfloat;
+ container.original = OriginalLut;
+
+ // Resample the LUT
+ if (!cmsStageSampleCLutFloat(ContextID, OptimizedCLUTmpe, XFormSampler, (void*)&container, 0)) goto Error;
+
+ // And return the obtained LUT
+ cmsPipelineFree(ContextID, OriginalLut);
+
+ *Lut = OptimizedLUT;
+ *TransformFn = (_cmsTransformFn)LabCLUTEval;
+ *UserData = pfloat;
+ *FreeDataFn = LabCLUTFree;
+ *dwFlags &= ~cmsFLAGS_CAN_CHANGE_FORMATTER;
+ return TRUE;
+
+Error:
+
+ if (OptimizedLUT != NULL) cmsPipelineFree(ContextID, OptimizedLUT);
+
+ return FALSE;
+}
diff --git a/lcms2mt/plugins/fast_float/src/fast_float_tethra.c b/lcms2mt/plugins/fast_float/src/fast_float_tethra.c
index d8abc0f4..8aa681cf 100644
--- a/lcms2mt/plugins/fast_float/src/fast_float_tethra.c
+++ b/lcms2mt/plugins/fast_float/src/fast_float_tethra.c
@@ -209,8 +209,10 @@ void FloatCLUTEval(cmsContext ContextID,
out[OutChan] += DestIncrements[OutChan];
}
- if (ain)
- *out[TotalOut] = *ain;
+ if (ain) {
+ *(cmsFloat32Number*)(out[TotalOut]) = *ain;
+ out[TotalOut] += DestIncrements[TotalOut];
+ }
}
strideIn += Stride->BytesPerLineIn;
@@ -237,7 +239,6 @@ cmsBool OptimizeCLUTRGBTransform(cmsContext ContextID,
int nGridPoints;
cmsPipeline* OptimizedLUT = NULL;
cmsStage* OptimizedCLUTmpe;
- cmsStage* mpe;
FloatCLUTData* pfloat;
_cmsStageCLutData* data;
@@ -256,13 +257,6 @@ cmsBool OptimizeCLUTRGBTransform(cmsContext ContextID,
OriginalLut = *Lut;
- // Named color pipelines cannot be optimized either
- for (mpe = cmsPipelineGetPtrToFirstStage(ContextID, OriginalLut);
- mpe != NULL;
- mpe = cmsStageNext(ContextID, mpe)) {
- if (cmsStageType(ContextID, mpe) == cmsSigNamedColorElemType) return FALSE;
- }
-
nGridPoints = _cmsReasonableGridpointsByColorspace(cmsSigRgbData, *dwFlags);
// Create the result LUT
diff --git a/lcms2mt/plugins/fast_float/testbed/Makefile.in b/lcms2mt/plugins/fast_float/testbed/Makefile.in
new file mode 100644
index 00000000..0acf8e72
--- /dev/null
+++ b/lcms2mt/plugins/fast_float/testbed/Makefile.in
@@ -0,0 +1,635 @@
+# Makefile.in generated by automake 1.15.1 from Makefile.am.
+# @configure_input@
+
+# Copyright (C) 1994-2017 Free Software Foundation, Inc.
+
+# This Makefile.in is free software; the Free Software Foundation
+# gives unlimited permission to copy and/or distribute it,
+# with or without modifications, as long as this notice is preserved.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY, to the extent permitted by law; without
+# even the implied warranty of MERCHANTABILITY or FITNESS FOR A
+# PARTICULAR PURPOSE.
+
+@SET_MAKE@
+
+#
+# Makefile for building fast_float_testbed
+#
+VPATH = @srcdir@
+am__is_gnu_make = { \
+ if test -z '$(MAKELEVEL)'; then \
+ false; \
+ elif test -n '$(MAKE_HOST)'; then \
+ true; \
+ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \
+ true; \
+ else \
+ false; \
+ fi; \
+}
+am__make_running_with_option = \
+ case $${target_option-} in \
+ ?) ;; \
+ *) echo "am__make_running_with_option: internal error: invalid" \
+ "target option '$${target_option-}' specified" >&2; \
+ exit 1;; \
+ esac; \
+ has_opt=no; \
+ sane_makeflags=$$MAKEFLAGS; \
+ if $(am__is_gnu_make); then \
+ sane_makeflags=$$MFLAGS; \
+ else \
+ case $$MAKEFLAGS in \
+ *\\[\ \ ]*) \
+ bs=\\; \
+ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \
+ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \
+ esac; \
+ fi; \
+ skip_next=no; \
+ strip_trailopt () \
+ { \
+ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \
+ }; \
+ for flg in $$sane_makeflags; do \
+ test $$skip_next = yes && { skip_next=no; continue; }; \
+ case $$flg in \
+ *=*|--*) continue;; \
+ -*I) strip_trailopt 'I'; skip_next=yes;; \
+ -*I?*) strip_trailopt 'I';; \
+ -*O) strip_trailopt 'O'; skip_next=yes;; \
+ -*O?*) strip_trailopt 'O';; \
+ -*l) strip_trailopt 'l'; skip_next=yes;; \
+ -*l?*) strip_trailopt 'l';; \
+ -[dEDm]) skip_next=yes;; \
+ -[JT]) skip_next=yes;; \
+ esac; \
+ case $$flg in \
+ *$$target_option*) has_opt=yes; break;; \
+ esac; \
+ done; \
+ test $$has_opt = yes
+am__make_dryrun = (target_option=n; $(am__make_running_with_option))
+am__make_keepgoing = (target_option=k; $(am__make_running_with_option))
+pkgdatadir = $(datadir)/@PACKAGE@
+pkgincludedir = $(includedir)/@PACKAGE@
+pkglibdir = $(libdir)/@PACKAGE@
+pkglibexecdir = $(libexecdir)/@PACKAGE@
+am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd
+install_sh_DATA = $(install_sh) -c -m 644
+install_sh_PROGRAM = $(install_sh) -c
+install_sh_SCRIPT = $(install_sh) -c
+INSTALL_HEADER = $(INSTALL_DATA)
+transform = $(program_transform_name)
+NORMAL_INSTALL = :
+PRE_INSTALL = :
+POST_INSTALL = :
+NORMAL_UNINSTALL = :
+PRE_UNINSTALL = :
+POST_UNINSTALL = :
+build_triplet = @build@
+host_triplet = @host@
+check_PROGRAMS = fast_float_testbed$(EXEEXT)
+subdir = plugins/fast_float/testbed
+ACLOCAL_M4 = $(top_srcdir)/aclocal.m4
+am__aclocal_m4_deps = $(top_srcdir)/m4/acx_pthread.m4 \
+ $(top_srcdir)/m4/ax_append_compile_flags.m4 \
+ $(top_srcdir)/m4/ax_append_flag.m4 \
+ $(top_srcdir)/m4/ax_check_compile_flag.m4 \
+ $(top_srcdir)/m4/ax_gcc_func_attribute.m4 \
+ $(top_srcdir)/m4/ax_require_defined.m4 \
+ $(top_srcdir)/m4/libtool.m4 $(top_srcdir)/m4/ltoptions.m4 \
+ $(top_srcdir)/m4/ltsugar.m4 $(top_srcdir)/m4/ltversion.m4 \
+ $(top_srcdir)/m4/lt~obsolete.m4 $(top_srcdir)/configure.ac
+am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \
+ $(ACLOCAL_M4)
+DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON)
+mkinstalldirs = $(install_sh) -d
+CONFIG_CLEAN_FILES =
+CONFIG_CLEAN_VPATH_FILES =
+am_fast_float_testbed_OBJECTS = fast_float_testbed.$(OBJEXT)
+fast_float_testbed_OBJECTS = $(am_fast_float_testbed_OBJECTS)
+fast_float_testbed_DEPENDENCIES = \
+ $(srcdir)/../src/liblcms2mt_fast_float.la
+AM_V_lt = $(am__v_lt_@AM_V@)
+am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@)
+am__v_lt_0 = --silent
+am__v_lt_1 =
+fast_float_testbed_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC \
+ $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=link $(CCLD) \
+ $(AM_CFLAGS) $(CFLAGS) $(fast_float_testbed_LDFLAGS) \
+ $(LDFLAGS) -o $@
+AM_V_P = $(am__v_P_@AM_V@)
+am__v_P_ = $(am__v_P_@AM_DEFAULT_V@)
+am__v_P_0 = false
+am__v_P_1 = :
+AM_V_GEN = $(am__v_GEN_@AM_V@)
+am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@)
+am__v_GEN_0 = @echo " GEN " $@;
+am__v_GEN_1 =
+AM_V_at = $(am__v_at_@AM_V@)
+am__v_at_ = $(am__v_at_@AM_DEFAULT_V@)
+am__v_at_0 = @
+am__v_at_1 =
+DEFAULT_INCLUDES = -I.@am__isrc@
+depcomp = $(SHELL) $(top_srcdir)/depcomp
+am__depfiles_maybe = depfiles
+am__mv = mv -f
+COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \
+ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS)
+LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
+ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \
+ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \
+ $(AM_CFLAGS) $(CFLAGS)
+AM_V_CC = $(am__v_CC_@AM_V@)
+am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@)
+am__v_CC_0 = @echo " CC " $@;
+am__v_CC_1 =
+CCLD = $(CC)
+LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \
+ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \
+ $(AM_LDFLAGS) $(LDFLAGS) -o $@
+AM_V_CCLD = $(am__v_CCLD_@AM_V@)
+am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@)
+am__v_CCLD_0 = @echo " CCLD " $@;
+am__v_CCLD_1 =
+SOURCES = $(fast_float_testbed_SOURCES)
+DIST_SOURCES = $(fast_float_testbed_SOURCES)
+am__can_run_installinfo = \
+ case $$AM_UPDATE_INFO_DIR in \
+ n|no|NO) false;; \
+ *) (install-info --version) >/dev/null 2>&1;; \
+ esac
+am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP)
+# Read a list of newline-separated strings from the standard input,
+# and print each of them once, without duplicates. Input order is
+# *not* preserved.
+am__uniquify_input = $(AWK) '\
+ BEGIN { nonempty = 0; } \
+ { items[$$0] = 1; nonempty = 1; } \
+ END { if (nonempty) { for (i in items) print i; }; } \
+'
+# Make sure the list of sources is unique. This is necessary because,
+# e.g., the same source file might be shared among _SOURCES variables
+# for different programs/libraries.
+am__define_uniq_tagged_files = \
+ list='$(am__tagged_files)'; \
+ unique=`for i in $$list; do \
+ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \
+ done | $(am__uniquify_input)`
+ETAGS = etags
+CTAGS = ctags
+am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp
+DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST)
+ACLOCAL = @ACLOCAL@
+AMTAR = @AMTAR@
+AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@
+AR = @AR@
+AS = @AS@
+AUTOCONF = @AUTOCONF@
+AUTOHEADER = @AUTOHEADER@
+AUTOMAKE = @AUTOMAKE@
+AWK = @AWK@
+CC = @CC@
+CCDEPMODE = @CCDEPMODE@
+CFLAGS = @CFLAGS@
+CPP = @CPP@
+CPPFLAGS = @CPPFLAGS@
+CXX = @CXX@
+CXXCPP = @CXXCPP@
+CXXDEPMODE = @CXXDEPMODE@
+CXXFLAGS = @CXXFLAGS@
+CYGPATH_W = @CYGPATH_W@
+DEFS = @DEFS@
+DEPDIR = @DEPDIR@
+DLLTOOL = @DLLTOOL@
+DSYMUTIL = @DSYMUTIL@
+DUMPBIN = @DUMPBIN@
+ECHO_C = @ECHO_C@
+ECHO_N = @ECHO_N@
+ECHO_T = @ECHO_T@
+EGREP = @EGREP@
+EXEEXT = @EXEEXT@
+FGREP = @FGREP@
+GREP = @GREP@
+INSTALL = @INSTALL@
+INSTALL_DATA = @INSTALL_DATA@
+INSTALL_PROGRAM = @INSTALL_PROGRAM@
+INSTALL_SCRIPT = @INSTALL_SCRIPT@
+INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@
+JPEGICC_DEPLIBS = @JPEGICC_DEPLIBS@
+LCMS_LIB_DEPLIBS = @LCMS_LIB_DEPLIBS@
+LD = @LD@
+LDFLAGS = @LDFLAGS@
+LIBOBJS = @LIBOBJS@
+LIBRARY_AGE = @LIBRARY_AGE@
+LIBRARY_CURRENT = @LIBRARY_CURRENT@
+LIBRARY_REVISION = @LIBRARY_REVISION@
+LIBS = @LIBS@
+LIBTOOL = @LIBTOOL@
+LIBTOOL_DEPS = @LIBTOOL_DEPS@
+LIB_JPEG = @LIB_JPEG@
+LIB_MATH = @LIB_MATH@
+LIB_PLUGINS = @LIB_PLUGINS@
+LIB_THREAD = @LIB_THREAD@
+LIB_TIFF = @LIB_TIFF@
+LIB_ZLIB = @LIB_ZLIB@
+LIPO = @LIPO@
+LN_S = @LN_S@
+LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
+MAINT = @MAINT@
+MAKEINFO = @MAKEINFO@
+MANIFEST_TOOL = @MANIFEST_TOOL@
+MKDIR_P = @MKDIR_P@
+NM = @NM@
+NMEDIT = @NMEDIT@
+OBJDUMP = @OBJDUMP@
+OBJEXT = @OBJEXT@
+OTOOL = @OTOOL@
+OTOOL64 = @OTOOL64@
+PACKAGE = @PACKAGE@
+PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@
+PACKAGE_NAME = @PACKAGE_NAME@
+PACKAGE_STRING = @PACKAGE_STRING@
+PACKAGE_TARNAME = @PACKAGE_TARNAME@
+PACKAGE_URL = @PACKAGE_URL@
+PACKAGE_VERSION = @PACKAGE_VERSION@
+PATH_SEPARATOR = @PATH_SEPARATOR@
+PTHREAD_CC = @PTHREAD_CC@
+PTHREAD_CFLAGS = @PTHREAD_CFLAGS@
+PTHREAD_CXX = @PTHREAD_CXX@
+PTHREAD_LIBS = @PTHREAD_LIBS@
+RANLIB = @RANLIB@
+SED = @SED@
+SET_MAKE = @SET_MAKE@
+SHELL = @SHELL@
+STRIP = @STRIP@
+TIFFICC_DEPLIBS = @TIFFICC_DEPLIBS@
+VERSION = @VERSION@
+abs_builddir = @abs_builddir@
+abs_srcdir = @abs_srcdir@
+abs_top_builddir = @abs_top_builddir@
+abs_top_srcdir = @abs_top_srcdir@
+ac_ct_AR = @ac_ct_AR@
+ac_ct_CC = @ac_ct_CC@
+ac_ct_CXX = @ac_ct_CXX@
+ac_ct_DUMPBIN = @ac_ct_DUMPBIN@
+acx_pthread_config = @acx_pthread_config@
+am__include = @am__include@
+am__leading_dot = @am__leading_dot@
+am__quote = @am__quote@
+am__tar = @am__tar@
+am__untar = @am__untar@
+bindir = @bindir@
+build = @build@
+build_alias = @build_alias@
+build_cpu = @build_cpu@
+build_os = @build_os@
+build_vendor = @build_vendor@
+builddir = @builddir@
+datadir = @datadir@
+datarootdir = @datarootdir@
+docdir = @docdir@
+dvidir = @dvidir@
+exec_prefix = @exec_prefix@
+host = @host@
+host_alias = @host_alias@
+host_cpu = @host_cpu@
+host_os = @host_os@
+host_vendor = @host_vendor@
+htmldir = @htmldir@
+includedir = @includedir@
+infodir = @infodir@
+inline = @inline@
+install_sh = @install_sh@
+libdir = @libdir@
+libexecdir = @libexecdir@
+localedir = @localedir@
+localstatedir = @localstatedir@
+mandir = @mandir@
+mkdir_p = @mkdir_p@
+oldincludedir = @oldincludedir@
+pdfdir = @pdfdir@
+prefix = @prefix@
+program_transform_name = @program_transform_name@
+psdir = @psdir@
+runstatedir = @runstatedir@
+sbindir = @sbindir@
+sharedstatedir = @sharedstatedir@
+srcdir = @srcdir@
+sysconfdir = @sysconfdir@
+target_alias = @target_alias@
+top_build_prefix = @top_build_prefix@
+top_builddir = @top_builddir@
+top_srcdir = @top_srcdir@
+
+# Don't require all the GNU mandated files
+AUTOMAKE_OPTIONS = 1.7 foreign
+AM_CPPFLAGS = -I$(builddir)/../include -I$(srcdir)/../include -I$(srcdir)/../src \
+ -I$(top_builddir)/include
+
+fast_float_testbed_LDADD = $(srcdir)/../src/liblcms2mt_fast_float.la
+fast_float_testbed_LDFLAGS = @LDFLAGS@
+fast_float_testbed_SOURCES = fast_float_testbed.c
+EXTRA_DIST = test0.icc test1.icc test2.icc test3.icc test5.icc
+all: all-am
+
+.SUFFIXES:
+.SUFFIXES: .c .lo .o .obj
+$(srcdir)/Makefile.in: @MAINTAINER_MODE_TRUE@ $(srcdir)/Makefile.am $(am__configure_deps)
+ @for dep in $?; do \
+ case '$(am__configure_deps)' in \
+ *$$dep*) \
+ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \
+ && { if test -f $@; then exit 0; else break; fi; }; \
+ exit 1;; \
+ esac; \
+ done; \
+ echo ' cd $(top_srcdir) && $(AUTOMAKE) --foreign plugins/fast_float/testbed/Makefile'; \
+ $(am__cd) $(top_srcdir) && \
+ $(AUTOMAKE) --foreign plugins/fast_float/testbed/Makefile
+Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status
+ @case '$?' in \
+ *config.status*) \
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \
+ *) \
+ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe)'; \
+ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__depfiles_maybe);; \
+ esac;
+
+$(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES)
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
+
+$(top_srcdir)/configure: @MAINTAINER_MODE_TRUE@ $(am__configure_deps)
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
+$(ACLOCAL_M4): @MAINTAINER_MODE_TRUE@ $(am__aclocal_m4_deps)
+ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh
+$(am__aclocal_m4_deps):
+
+clean-checkPROGRAMS:
+ @list='$(check_PROGRAMS)'; test -n "$$list" || exit 0; \
+ echo " rm -f" $$list; \
+ rm -f $$list || exit $$?; \
+ test -n "$(EXEEXT)" || exit 0; \
+ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \
+ echo " rm -f" $$list; \
+ rm -f $$list
+
+fast_float_testbed$(EXEEXT): $(fast_float_testbed_OBJECTS) $(fast_float_testbed_DEPENDENCIES) $(EXTRA_fast_float_testbed_DEPENDENCIES)
+ @rm -f fast_float_testbed$(EXEEXT)
+ $(AM_V_CCLD)$(fast_float_testbed_LINK) $(fast_float_testbed_OBJECTS) $(fast_float_testbed_LDADD) $(LIBS)
+
+mostlyclean-compile:
+ -rm -f *.$(OBJEXT)
+
+distclean-compile:
+ -rm -f *.tab.c
+
+@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/fast_float_testbed.Po@am__quote@
+
+.c.o:
+@am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.o$$||'`;\
+@am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\
+@am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $<
+
+.c.obj:
+@am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.obj$$||'`;\
+@am__fastdepCC_TRUE@ $(COMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ `$(CYGPATH_W) '$<'` &&\
+@am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Po
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'`
+
+.c.lo:
+@am__fastdepCC_TRUE@ $(AM_V_CC)depbase=`echo $@ | sed 's|[^/]*$$|$(DEPDIR)/&|;s|\.lo$$||'`;\
+@am__fastdepCC_TRUE@ $(LTCOMPILE) -MT $@ -MD -MP -MF $$depbase.Tpo -c -o $@ $< &&\
+@am__fastdepCC_TRUE@ $(am__mv) $$depbase.Tpo $$depbase.Plo
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@
+@AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@
+@am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $<
+
+mostlyclean-libtool:
+ -rm -f *.lo
+
+clean-libtool:
+ -rm -rf .libs _libs
+
+ID: $(am__tagged_files)
+ $(am__define_uniq_tagged_files); mkid -fID $$unique
+tags: tags-am
+TAGS: tags
+
+tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
+ set x; \
+ here=`pwd`; \
+ $(am__define_uniq_tagged_files); \
+ shift; \
+ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \
+ test -n "$$unique" || unique=$$empty_fix; \
+ if test $$# -gt 0; then \
+ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+ "$$@" $$unique; \
+ else \
+ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \
+ $$unique; \
+ fi; \
+ fi
+ctags: ctags-am
+
+CTAGS: ctags
+ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files)
+ $(am__define_uniq_tagged_files); \
+ test -z "$(CTAGS_ARGS)$$unique" \
+ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \
+ $$unique
+
+GTAGS:
+ here=`$(am__cd) $(top_builddir) && pwd` \
+ && $(am__cd) $(top_srcdir) \
+ && gtags -i $(GTAGS_ARGS) "$$here"
+cscopelist: cscopelist-am
+
+cscopelist-am: $(am__tagged_files)
+ list='$(am__tagged_files)'; \
+ case "$(srcdir)" in \
+ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \
+ *) sdir=$(subdir)/$(srcdir) ;; \
+ esac; \
+ for i in $$list; do \
+ if test -f "$$i"; then \
+ echo "$(subdir)/$$i"; \
+ else \
+ echo "$$sdir/$$i"; \
+ fi; \
+ done >> $(top_builddir)/cscope.files
+
+distclean-tags:
+ -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags
+
+distdir: $(DISTFILES)
+ @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
+ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \
+ list='$(DISTFILES)'; \
+ dist_files=`for file in $$list; do echo $$file; done | \
+ sed -e "s|^$$srcdirstrip/||;t" \
+ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \
+ case $$dist_files in \
+ */*) $(MKDIR_P) `echo "$$dist_files" | \
+ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \
+ sort -u` ;; \
+ esac; \
+ for file in $$dist_files; do \
+ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \
+ if test -d $$d/$$file; then \
+ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \
+ if test -d "$(distdir)/$$file"; then \
+ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
+ fi; \
+ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \
+ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \
+ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \
+ fi; \
+ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \
+ else \
+ test -f "$(distdir)/$$file" \
+ || cp -p $$d/$$file "$(distdir)/$$file" \
+ || exit 1; \
+ fi; \
+ done
+check-am: all-am
+ $(MAKE) $(AM_MAKEFLAGS) $(check_PROGRAMS)
+check: check-am
+all-am: Makefile
+installdirs:
+install: install-am
+install-exec: install-exec-am
+install-data: install-data-am
+uninstall: uninstall-am
+
+install-am: all-am
+ @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am
+
+installcheck: installcheck-am
+install-strip:
+ if test -z '$(STRIP)'; then \
+ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
+ install; \
+ else \
+ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \
+ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \
+ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \
+ fi
+mostlyclean-generic:
+
+clean-generic:
+
+distclean-generic:
+ -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES)
+ -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES)
+
+maintainer-clean-generic:
+ @echo "This command is intended for maintainers to use"
+ @echo "it deletes files that may require special tools to rebuild."
+clean: clean-am
+
+clean-am: clean-checkPROGRAMS clean-generic clean-libtool \
+ mostlyclean-am
+
+distclean: distclean-am
+ -rm -rf ./$(DEPDIR)
+ -rm -f Makefile
+distclean-am: clean-am distclean-compile distclean-generic \
+ distclean-tags
+
+dvi: dvi-am
+
+dvi-am:
+
+html: html-am
+
+html-am:
+
+info: info-am
+
+info-am:
+
+install-data-am:
+
+install-dvi: install-dvi-am
+
+install-dvi-am:
+
+install-exec-am:
+
+install-html: install-html-am
+
+install-html-am:
+
+install-info: install-info-am
+
+install-info-am:
+
+install-man:
+
+install-pdf: install-pdf-am
+
+install-pdf-am:
+
+install-ps: install-ps-am
+
+install-ps-am:
+
+installcheck-am:
+
+maintainer-clean: maintainer-clean-am
+ -rm -rf ./$(DEPDIR)
+ -rm -f Makefile
+maintainer-clean-am: distclean-am maintainer-clean-generic
+
+mostlyclean: mostlyclean-am
+
+mostlyclean-am: mostlyclean-compile mostlyclean-generic \
+ mostlyclean-libtool
+
+pdf: pdf-am
+
+pdf-am:
+
+ps: ps-am
+
+ps-am:
+
+uninstall-am:
+
+.MAKE: check-am install-am install-strip
+
+.PHONY: CTAGS GTAGS TAGS all all-am check check-am clean \
+ clean-checkPROGRAMS clean-generic clean-libtool cscopelist-am \
+ ctags ctags-am distclean distclean-compile distclean-generic \
+ distclean-libtool distclean-tags distdir dvi dvi-am html \
+ html-am info info-am install install-am install-data \
+ install-data-am install-dvi install-dvi-am install-exec \
+ install-exec-am install-html install-html-am install-info \
+ install-info-am install-man install-pdf install-pdf-am \
+ install-ps install-ps-am install-strip installcheck \
+ installcheck-am installdirs maintainer-clean \
+ maintainer-clean-generic mostlyclean mostlyclean-compile \
+ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \
+ tags tags-am uninstall uninstall-am
+
+.PRECIOUS: Makefile
+
+
+check:
+ ./fast_float_testbed
+
+# Tell versions [3.59,3.63) of GNU make to not export all variables.
+# Otherwise a system limit (for SysV at least) may be exceeded.
+.NOEXPORT:
diff --git a/lcms2mt/plugins/fast_float/testbed/fast_float_testbed.c b/lcms2mt/plugins/fast_float/testbed/fast_float_testbed.c
index 34bafd78..adac09a9 100644
--- a/lcms2mt/plugins/fast_float/testbed/fast_float_testbed.c
+++ b/lcms2mt/plugins/fast_float/testbed/fast_float_testbed.c
@@ -48,6 +48,18 @@ typedef struct { cmsFloat32Number L, a, b; } Scanline_LabFloat;
// Floating point acuracy for tests
#define EPSILON_FLOAT_TESTS 0.005
+// A flushed printf
+static
+void trace(const char* frm, ...)
+{
+ va_list args;
+
+ va_start(args, frm);
+ vfprintf(stderr, frm, args);
+ fflush(stderr);
+ va_end(args);
+}
+
// The callback function used by cmsSetLogErrorHandler()
static
@@ -56,7 +68,7 @@ void FatalErrorQuit(cmsContext ContextID, cmsUInt32Number ErrorCode, const char
UNUSED_PARAMETER(ContextID);
UNUSED_PARAMETER(ErrorCode);
- printf("** Fatal error: %s\n", Text);
+ trace("** Fatal error: %s\n", Text);
exit(1);
}
@@ -229,7 +241,7 @@ Error:
return rc;
}
-#define CHECK(frm, plane, chans, alpha, ...) if (!checkSingleComputeIncrements(frm, plane, chans, alpha, __VA_ARGS__)) { printf("Format failed!\n"); return 0; }
+#define CHECK(frm, plane, chans, alpha, ...) if (!checkSingleComputeIncrements(frm, plane, chans, alpha, __VA_ARGS__)) { trace("Format failed!\n"); return 0; }
@@ -343,7 +355,7 @@ void Check15bitMacros(void)
{
int i;
- printf("Checking 15 bit <=> 8 bit macros...");
+ trace("Checking 15 bit <=> 8 bit macros...");
for (i = 0; i < 256; i++)
{
@@ -353,7 +365,7 @@ void Check15bitMacros(void)
if (m != i)
Fail("Failed on %d (->%d->%d)", i, n, m);
}
- printf("ok\n");
+ trace("ok\n");
}
// Do an in-depth test by checking all RGB cube of 8 bits, going from profilein to profileout.
@@ -433,19 +445,19 @@ void Check15bitsConversions(cmsContext ContextID)
{
Check15bitMacros();
- printf("Checking accuracy of 15 bits on CLUT...");
+ trace("Checking accuracy of 15 bits on CLUT...");
TryAllValues15(ContextID, cmsOpenProfileFromFile(ContextID, "test5.icc", "r"), cmsOpenProfileFromFile(ContextID, "test3.icc", "r"), INTENT_PERCEPTUAL);
- printf("Ok\n");
+ trace("Ok\n");
- printf("Checking accuracy of 15 bits on same profile ...");
+ trace("Checking accuracy of 15 bits on same profile ...");
TryAllValues15(ContextID, cmsOpenProfileFromFile(ContextID, "test0.icc", "r"), cmsOpenProfileFromFile(ContextID, "test0.icc", "r"), INTENT_PERCEPTUAL);
- printf("Ok\n");
+ trace("Ok\n");
- printf("Checking accuracy of 15 bits on Matrix...");
+ trace("Checking accuracy of 15 bits on Matrix...");
TryAllValues15(ContextID, cmsOpenProfileFromFile(ContextID, "test5.icc", "r"), cmsOpenProfileFromFile(ContextID, "test0.icc", "r"), INTENT_PERCEPTUAL);
- printf("Ok\n");
+ trace("Ok\n");
- printf("All 15 bits tests passed OK\n\n");
+ trace("All 15 bits tests passed OK\n\n");
}
// Next test checks results of optimized 16 bits versus raw 16 bits.
@@ -524,11 +536,85 @@ static
void CheckAccuracy16Bits(cmsContext Raw, cmsContext Plugin)
{
// CLUT should be as 16 bits or better
- printf("Checking accuracy of 16 bits CLUT...");
+ trace("Checking accuracy of 16 bits CLUT...");
TryAllValues16bits(Raw, Plugin, cmsOpenProfileFromFile(Raw, "test5.icc", "r"), cmsOpenProfileFromFile(Raw, "test3.icc", "r"), INTENT_PERCEPTUAL);
- printf("All 16 bits tests passed OK\n\n");
+ trace("All 16 bits tests passed OK\n\n");
+}
+
+
+// Try values that are denormalized, not-a-number and out of range
+static
+void CheckUncommonValues(cmsHPROFILE hlcmsProfileIn, cmsHPROFILE hlcmsProfileOut, cmsInt32Number Intent)
+{
+ union
+ {
+ cmsFloat32Number subnormal;
+ cmsUInt32Number Int;
+
+ } sub_pos, sub_neg;
+
+ Scanline_rgbFloat* bufferIn;
+ Scanline_rgbFloat* bufferPluginOut;
+
+ cmsUInt32Number i, npixels = 100;
+
+ cmsContext Plugin = cmsCreateContext(cmsFastFloatExtensions(), NULL);
+
+ cmsHTRANSFORM xformPlugin = cmsCreateTransformTHR(Plugin, hlcmsProfileIn, TYPE_RGB_FLT, hlcmsProfileOut, TYPE_RGB_FLT, Intent, 0);
+
+
+ sub_pos.Int = 0x00000002;
+ sub_neg.Int = 0x80000002;
+
+ cmsCloseProfile(hlcmsProfileIn);
+ cmsCloseProfile(hlcmsProfileOut);
+
+ if (xformPlugin == NULL) {
+
+ Fail("NULL transform on check uncommon values");
+ }
+
+
+ bufferIn = (Scanline_rgbFloat*)malloc(npixels * sizeof(Scanline_rgbFloat));
+ bufferPluginOut = (Scanline_rgbFloat*)malloc(npixels * sizeof(Scanline_rgbFloat));
+
+ for (i = 0; i < npixels; i++)
+ {
+ bufferIn[i].r = i / 40.0 - 0.5;
+ bufferIn[i].g = i / 20.0 - 0.5;
+ bufferIn[i].b = i / 60.0 - 0.5;
+ }
+
+ cmsDoTransform(xformPlugin, bufferIn, bufferPluginOut, npixels);
+
+
+ bufferIn[0].r = NAN;
+ bufferIn[0].g = NAN;
+ bufferIn[0].b = NAN;
+
+ bufferIn[1].r = INFINITY;
+ bufferIn[1].g = INFINITY;
+ bufferIn[1].b = INFINITY;
+
+ bufferIn[2].r = sub_pos.subnormal;
+ bufferIn[2].g = sub_pos.subnormal;
+ bufferIn[2].b = sub_pos.subnormal;
+
+ bufferIn[3].r = sub_neg.subnormal;
+ bufferIn[3].g = sub_neg.subnormal;
+ bufferIn[3].b = sub_neg.subnormal;
+
+ cmsDoTransform(xformPlugin, bufferIn, bufferPluginOut, 4);
+
+ free(bufferIn);
+ free(bufferPluginOut);
+
+ cmsDeleteTransform(xformPlugin);
+
+ cmsDeleteContext(Plugin);
}
+
// --------------------------------------------------------------------------------------------------
// A C C U R A C Y C H E C K S
// --------------------------------------------------------------------------------------------------
@@ -779,7 +865,7 @@ void CheckChangeFormat(cmsContext ContextID)
cmsUInt16Number rgb16[3] = { 10* 257, 120*257, 40*257 };
cmsUInt16Number lab16_1[3], lab16_2[3];
- printf("Checking change format feature...");
+ trace("Checking change format feature...");
hsRGB = cmsCreate_sRGBProfile(ContextID);
hLab = cmsCreateLab4Profile(ContextID, NULL);
@@ -797,7 +883,7 @@ void CheckChangeFormat(cmsContext ContextID)
if (memcmp(lab16_1, lab16_2, sizeof(lab16_1)) != 0)
Fail("Change format failed!");
- printf("Ok\n");
+ trace("Ok\n");
}
@@ -818,7 +904,7 @@ void CheckLab2Roundtrip(cmsContext ContextID)
Scanline_rgb8bits* In;
Scanline_rgb8bits* Out;
- printf("Checking lab2 roundtrip...");
+ trace("Checking lab2 roundtrip...");
hsRGB = cmsCreate_sRGBProfile(ContextID);
hLab = cmsCreateLab2Profile(ContextID, NULL);
@@ -875,7 +961,7 @@ void CheckLab2Roundtrip(cmsContext ContextID)
free(In);
free(Out);
free(lab);
- printf("Ok\n");
+ trace("Ok\n");
}
@@ -883,34 +969,45 @@ void CheckLab2Roundtrip(cmsContext ContextID)
static
void CheckConversionFloat(cmsContext Raw, cmsContext Plugin)
{
- printf("Crash test.");
+ trace("Crash test.");
TryAllValuesFloatAlpha(Raw, Plugin, cmsOpenProfileFromFile(Raw, "test5.icc", "r"), cmsOpenProfileFromFile(Raw, "test0.icc", "r"), INTENT_PERCEPTUAL, FALSE);
- printf("..");
+ trace("..");
TryAllValuesFloatAlpha(Raw, Plugin, cmsOpenProfileFromFile(Raw, "test5.icc", "r"), cmsOpenProfileFromFile(Raw, "test0.icc", "r"), INTENT_PERCEPTUAL, TRUE);
- printf("Ok\n");
+ trace("Ok\n");
- printf("Crash (II) test.");
+ trace("Crash (II) test.");
TryAllValuesFloatAlpha(Raw, Plugin, cmsOpenProfileFromFile(Raw, "test0.icc", "r"), cmsOpenProfileFromFile(Raw, "test0.icc", "r"), INTENT_PERCEPTUAL, FALSE);
- printf("..");
+ trace("..");
TryAllValuesFloatAlpha(Raw, Plugin, cmsOpenProfileFromFile(Raw, "test0.icc", "r"), cmsOpenProfileFromFile(Raw, "test0.icc", "r"), INTENT_PERCEPTUAL, TRUE);
- printf("Ok\n");
+ trace("Ok\n");
+
+
+ /*
+ * FIXME!!
+ */
+ trace("Crash (III) test.");
+ CheckUncommonValues(cmsOpenProfileFromFile("test5.icc", "r"), cmsOpenProfileFromFile("test3.icc", "r"), INTENT_PERCEPTUAL);
+ trace("..");
+ CheckUncommonValues(cmsOpenProfileFromFile("test5.icc", "r"), cmsOpenProfileFromFile("test0.icc", "r"), INTENT_PERCEPTUAL);
+ trace("Ok\n");
+
// Matrix-shaper should be accurate
- printf("Checking accuracy on Matrix-shaper...");
+ trace("Checking accuracy on Matrix-shaper...");
TryAllValuesFloat(Raw, Plugin, cmsOpenProfileFromFile(Raw, "test5.icc", "r"), cmsOpenProfileFromFile(Raw, "test0.icc", "r"), INTENT_PERCEPTUAL);
- printf("Ok\n");
+ trace("Ok\n");
// CLUT should be as 16 bits or better
- printf("Checking accuracy of CLUT...");
+ trace("Checking accuracy of CLUT...");
TryAllValuesFloatVs16(Raw, Plugin, cmsOpenProfileFromFile(Raw, "test5.icc", "r"), cmsOpenProfileFromFile(Raw, "test3.icc", "r"), INTENT_PERCEPTUAL);
- printf("Ok\n");
+ trace("Ok\n");
// Same profile should give same values (we test both methods)
- printf("Checking accuracy on same profile ...");
+ trace("Checking accuracy on same profile ...");
TryAllValuesFloatVs16(Raw, Plugin, cmsOpenProfileFromFile(Raw, "test0.icc", "r"), cmsOpenProfileFromFile(Raw, "test0.icc", "r"), INTENT_PERCEPTUAL);
TryAllValuesFloat(Raw, Plugin, cmsOpenProfileFromFile(Raw, "test0.icc", "r"), cmsOpenProfileFromFile(Raw, "test0.icc", "r"), INTENT_PERCEPTUAL);
- printf("Ok\n");
+ trace("Ok\n");
}
@@ -945,7 +1042,7 @@ void CheckLab2RGB(cmsContext plugin)
cmsFloat32Number maxInside = 0, maxOutside = 0, L, a, b;
- printf("Checking Lab -> RGB...");
+ trace("Checking Lab -> RGB...");
for (L = 4; L <= 100; L++)
{
for (a = -30; a < +30; a++)
@@ -983,7 +1080,7 @@ void CheckLab2RGB(cmsContext plugin)
}
- printf("Max distance: Inside gamut %f, Outside gamut %f\n", sqrtf(maxInside), sqrtf(maxOutside));
+ trace("Max distance: Inside gamut %f, Outside gamut %f\n", sqrtf(maxInside), sqrtf(maxOutside));
cmsDeleteTransform(hXformNoPlugin);
cmsDeleteTransform(hXformPlugin);
@@ -1012,7 +1109,7 @@ typedef cmsFloat64Number(*perf_fn)(cmsContext ct, cmsHPROFILE hlcmsProfileIn, cm
static
void PerformanceHeader(void)
{
- printf(" MPixel/sec. MByte/sec.\n");
+ trace(" MPixel/sec. MByte/sec.\n");
}
@@ -1052,17 +1149,17 @@ cmsFloat64Number Performance(const char* Title, perf_fn fn, cmsContext ct, const
cmsFloat64Number n = fn(ct, hlcmsProfileIn, hlcmsProfileOut);
- printf("%-30s: ", Title); fflush(stdout);
- printf("%-12.2f %-12.2f", n, n * sz);
+ trace("%-30s: ", Title); fflush(stdout);
+ trace("%-12.2f %-12.2f", n, n * sz);
if (prev > 0.0) {
cmsFloat64Number imp = n / prev;
if (imp > 1)
- printf(" (x %-2.1f)", imp);
+ trace(" (x %-2.1f)", imp);
}
- printf("\n"); fflush(stdout);
+ trace("\n"); fflush(stdout);
return n;
}
@@ -1099,8 +1196,8 @@ void ComparativeCt(cmsContext ct1, cmsContext ct2, const char* Title, perf_fn fn
cmsFloat64Number n2 = fn2(ct2, hlcmsProfileIn, hlcmsProfileOut);
- printf("%-30s: ", Title); fflush(stdout);
- printf("%-12.2f %-12.2f\n", n1, n2);
+ trace("%-30s: ", Title); fflush(stdout);
+ trace("%-12.2f %-12.2f\n", n1, n2);
}
static
@@ -1434,9 +1531,9 @@ void SpeedTest8(void)
cmsFloat64Number t[10];
- printf("\n\n");
- printf("P E R F O R M A N C E T E S T S 8 B I T S (D E F A U L T)\n");
- printf("==============================================================\n\n");
+ trace("\n\n");
+ trace("P E R F O R M A N C E T E S T S 8 B I T S (D E F A U L T)\n");
+ trace("==============================================================\n\n");
fflush(stdout);
PerformanceHeader();
@@ -1447,9 +1544,9 @@ void SpeedTest8(void)
// Note that context 0 has the plug-in installed
- printf("\n\n");
- printf("P E R F O R M A N C E T E S T S 8 B I T S (P L U G I N)\n");
- printf("===========================================================\n\n");
+ trace("\n\n");
+ trace("P E R F O R M A N C E T E S T S 8 B I T S (P L U G I N)\n");
+ trace("===========================================================\n\n");
fflush(stdout);
PerformanceHeader();
@@ -1464,8 +1561,8 @@ void SpeedTest8(void)
static
void SpeedTest15(cmsContext ct)
{
- printf("\n\nP E R F O R M A N C E T E S T S 1 5 B I T S (P L U G I N)\n");
- printf( "===============================================================\n\n");
+ trace("\n\nP E R F O R M A N C E T E S T S 1 5 B I T S (P L U G I N)\n");
+ trace( "===============================================================\n\n");
PerformanceHeader();
Performance("15 bits on CLUT profiles ", SpeedTest15bitsRGB, ct, "test5.icc", "test3.icc", sizeof(Scanline_rgb15bits), 0);
@@ -1481,9 +1578,9 @@ void SpeedTest16(cmsContext ct)
cmsContext noPlugin = cmsCreateContext(0, 0);
- printf("\n\n");
- printf("P E R F O R M A N C E T E S T S 1 6 B I T S (D E F A U L T)\n");
- printf("=================================================================\n\n");
+ trace("\n\n");
+ trace("P E R F O R M A N C E T E S T S 1 6 B I T S (D E F A U L T)\n");
+ trace("=================================================================\n\n");
PerformanceHeader();
Performance("16 bits on CLUT profiles ", SpeedTest16bitsRGB, noPlugin, "test5.icc", "test3.icc", sizeof(Scanline_rgb16bits), 0);
@@ -1492,9 +1589,9 @@ void SpeedTest16(cmsContext ct)
Performance("16 bits on curves ", SpeedTest16bitsRGB, noPlugin, "*curves", "*curves", sizeof(Scanline_rgb16bits), 0);
Performance("16 bits on CMYK CLUT profiles ", SpeedTest16bitsCMYK, noPlugin, "test1.icc", "test2.icc", sizeof(Scanline_cmyk16bits), 0);
- printf("\n\n");
- printf("P E R F O R M A N C E T E S T S 1 6 B I T S (P L U G I N)\n");
- printf("===============================================================\n\n");
+ trace("\n\n");
+ trace("P E R F O R M A N C E T E S T S 1 6 B I T S (P L U G I N)\n");
+ trace("===============================================================\n\n");
PerformanceHeader();
Performance("16 bits on CLUT profiles ", SpeedTest16bitsRGB, ct, "test5.icc", "test3.icc", sizeof(Scanline_rgb16bits), 0);
@@ -1732,9 +1829,9 @@ void SpeedTestFloat(cmsContext noPlugin, cmsContext plugin)
cmsFloat64Number t[10] = { 0 };
- printf("\n\n");
- printf("P E R F O R M A N C E T E S T S F L O A T (D E F A U L T)\n");
- printf("==============================================================\n\n");
+ trace("\n\n");
+ trace("P E R F O R M A N C E T E S T S F L O A T (D E F A U L T)\n");
+ trace("==============================================================\n\n");
fflush(stdout);
PerformanceHeader();
@@ -1750,9 +1847,9 @@ void SpeedTestFloat(cmsContext noPlugin, cmsContext plugin)
// Note that context 0 has the plug-in installed
- printf("\n\n");
- printf("P E R F O R M A N C E T E S T S F L O A T (P L U G I N)\n");
- printf("===========================================================\n\n");
+ trace("\n\n");
+ trace("P E R F O R M A N C E T E S T S F L O A T (P L U G I N)\n");
+ trace("===========================================================\n\n");
fflush(stdout);
PerformanceHeader();
@@ -1847,11 +1944,11 @@ cmsFloat64Number SpeedTestFloatByUsing16BitsRGB(cmsContext ct, cmsHPROFILE hlcms
static
void ComparativeFloatVs16bits(cmsContext Raw, cmsContext Plugin)
{
- printf("\n\n");
- printf("C O M P A R A T I V E converting to 16 bit vs. using float plug-in.\n");
- printf(" values given in MegaPixels per second.\n");
- printf("====================================================================\n");
- printf(" 16 bits tmp. Float plugin\n");
+ trace("\n\n");
+ trace("C O M P A R A T I V E converting to 16 bit vs. using float plug-in.\n");
+ trace(" values given in MegaPixels per second.\n");
+ trace("====================================================================\n");
+ trace(" 16 bits tmp. Float plugin\n");
fflush(stdout);
Comparative(Raw, Plugin, "Floating point on CLUT profiles ", SpeedTestFloatByUsing16BitsRGB, SpeedTestFloatRGB, "test5.icc", "test3.icc");
@@ -1980,10 +2077,10 @@ cmsFloat64Number SpeedTest8bitLineStride(cmsContext ct, cmsHPROFILE hlcmsProfile
static
void ComparativeLineStride8bits(cmsContext NoPlugin, cmsContext Plugin)
{
- printf("\n\n");
- printf("C O M P A R A T I V E cmsDoTransform() vs. cmsDoTransformLineStride()\n");
- printf(" values given in MegaPixels per second.\n");
- printf("====================================================================\n");
+ trace("\n\n");
+ trace("C O M P A R A T I V E cmsDoTransform() vs. cmsDoTransformLineStride()\n");
+ trace(" values given in MegaPixels per second.\n");
+ trace("====================================================================\n");
fflush(stdout);
@@ -2042,7 +2139,7 @@ void TestGrayTransformPerformance(cmsContext ct)
free(In);
cmsDeleteTransform(ct, hlcmsxform);
- printf("Gray conversion using two gray profiles\t %-12.2f MPixels/Sec.\n", MPixSec(diff));
+ trace("Gray conversion using two gray profiles\t %-12.2f MPixels/Sec.\n", MPixSec(diff));
}
static
@@ -2091,7 +2188,7 @@ void TestGrayTransformPerformance1(cmsContext ct)
free(In);
cmsDeleteTransform(ct, hlcmsxform);
- printf("Gray conversion using two devicelinks\t %-12.2f MPixels/Sec.\n", MPixSec(diff));
+ trace("Gray conversion using two devicelinks\t %-12.2f MPixels/Sec.\n", MPixSec(diff));
}
@@ -2101,17 +2198,17 @@ int main()
cmsContext raw = cmsCreateContext(NULL, NULL);
cmsContext plugin = cmsCreateContext(NULL, NULL);
- printf("FastFloating point extensions testbed - 1.3\n");
- printf("Copyright (c) 1998-2020 Marti Maria Saguer, all rights reserved\n");
+ trace("FastFloating point extensions testbed - 1.3\n");
+ trace("Copyright (c) 1998-2020 Marti Maria Saguer, all rights reserved\n");
- printf("\nInstalling error logger ... ");
+ trace("\nInstalling error logger ... ");
cmsSetLogErrorHandler(raw, FatalErrorQuit);
cmsSetLogErrorHandler(plugin, FatalErrorQuit);
- printf("done.\n");
+ trace("done.\n");
- printf("Installing plug-in ... ");
+ trace("Installing plug-in ... ");
cmsPlugin(plugin, cmsFastFloatExtensions());
- printf("done.\n\n");
+ trace("done.\n\n");
CheckComputeIncrements();
@@ -2131,7 +2228,7 @@ int main()
// Floating point functionality
CheckConversionFloat(raw, plugin);
- printf("All floating point tests passed OK\n");
+ trace("All floating point tests passed OK\n");
SpeedTest8(plugin);
SpeedTest16(plugin);
@@ -2143,13 +2240,13 @@ int main()
ComparativeLineStride8bits(raw, plugin);
// Test gray performance
- printf("\n\n");
- printf("F L O A T G R A Y conversions performance.\n");
- printf("====================================================================\n");
+ trace("\n\n");
+ trace("F L O A T G R A Y conversions performance.\n");
+ trace("====================================================================\n");
TestGrayTransformPerformance(plugin);
TestGrayTransformPerformance1(plugin);
- printf("\nAll tests passed OK\n");
+ trace("\nAll tests passed OK\n");
return 0;
diff --git a/lcms2mt/src/Makefile.in b/lcms2mt/src/Makefile.in
index 2ac60348..46235be8 100644
--- a/lcms2mt/src/Makefile.in
+++ b/lcms2mt/src/Makefile.in
@@ -272,6 +272,7 @@ LIB_ZLIB = @LIB_ZLIB@
LIPO = @LIPO@
LN_S = @LN_S@
LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
MAINT = @MAINT@
MAKEINFO = @MAKEINFO@
MANIFEST_TOOL = @MANIFEST_TOOL@
diff --git a/lcms2mt/src/cmscgats.c b/lcms2mt/src/cmscgats.c
index dcad06a0..87ee1db3 100644
--- a/lcms2mt/src/cmscgats.c
+++ b/lcms2mt/src/cmscgats.c
@@ -1503,6 +1503,25 @@ cmsInt32Number satoi(const char* b)
return atoi(b);
}
+// Convert to binary
+static
+const char* satob(const char* v)
+{
+ cmsUInt32Number x;
+ static char buf[33];
+ char *s = buf + 33;
+
+ if (v == NULL) return "0";
+
+ x = atoi(v);
+ *--s = 0;
+ if (!x) *--s = '0';
+ for (; x; x /= 2) *--s = '0' + x%2;
+
+ return s;
+}
+
+
static
void AllocateDataSet(cmsContext ContextID, cmsIT8* it8)
{
@@ -1689,7 +1708,7 @@ void WriteHeader(cmsContext ContextID, cmsIT8* it8, SAVESTREAM* fp)
break;
case WRITE_BINARY:
- Writef(ContextID, fp, "\t0x%B", satoi(p ->Value));
+ Writef(ContextID, fp, "\t0b%s", satob(p ->Value));
break;
case WRITE_PAIR:
diff --git a/lcms2mt/src/cmsgmt.c b/lcms2mt/src/cmsgmt.c
index e255ab9d..941e59ce 100644
--- a/lcms2mt/src/cmsgmt.c
+++ b/lcms2mt/src/cmsgmt.c
@@ -587,3 +587,64 @@ cmsBool CMSEXPORT cmsDesaturateLab(cmsContext ContextID, cmsCIELab* Lab,
return TRUE;
}
+
+// Detect whatever a given ICC profile works in linear (gamma 1.0) space
+// Actually, doing that "well" is quite hard, since every component may behave completely different.
+// Since the true point of this function is to detect suitable optimizations, I am imposing some requirements
+// that simplifies things: only RGB, and only profiles that can got in both directions.
+// The algorith obtains Y from a syntetical gray R=G=B. Then least squares fitting is used to estimate gamma.
+// For gamma close to 1.0, RGB is linear. On profiles not supported, -1 is returned.
+
+cmsFloat64Number CMSEXPORT cmsDetectRGBProfileGamma(cmsContext ContextID, cmsHPROFILE hProfile, cmsFloat64Number thereshold)
+{
+ cmsHPROFILE hXYZ;
+ cmsHTRANSFORM xform;
+ cmsToneCurve* Y_curve;
+ cmsUInt16Number rgb[256][3];
+ cmsCIEXYZ XYZ[256];
+ cmsFloat32Number Y_normalized[256];
+ cmsFloat64Number gamma;
+ cmsProfileClassSignature cl;
+ int i;
+
+ if (cmsGetColorSpace(ContextID, hProfile) != cmsSigRgbData)
+ return -1;
+
+ cl = cmsGetDeviceClass(ContextID, hProfile);
+ if (cl != cmsSigInputClass && cl != cmsSigDisplayClass &&
+ cl != cmsSigOutputClass && cl != cmsSigColorSpaceClass)
+ return -1;
+
+ hXYZ = cmsCreateXYZProfile(ContextID);
+ xform = cmsCreateTransform(ContextID, hProfile, TYPE_RGB_16, hXYZ, TYPE_XYZ_DBL,
+ INTENT_RELATIVE_COLORIMETRIC, cmsFLAGS_NOOPTIMIZE);
+
+ if (xform == NULL) { // If not RGB or forward direction is not supported, regret with the previous error
+
+ cmsCloseProfile(ContextID, hXYZ);
+ return -1;
+ }
+
+ for (i = 0; i < 256; i++) {
+ rgb[i][0] = rgb[i][1] = rgb[i][2] = FROM_8_TO_16(i);
+ }
+
+ cmsDoTransform(ContextID, xform, rgb, XYZ, 256);
+
+ cmsDeleteTransform(ContextID, xform);
+ cmsCloseProfile(ContextID, hXYZ);
+
+ for (i = 0; i < 256; i++) {
+ Y_normalized[i] = (cmsFloat32Number) XYZ[i].Y;
+ }
+
+ Y_curve = cmsBuildTabulatedToneCurveFloat(ContextID, 256, Y_normalized);
+ if (Y_curve == NULL)
+ return -1;
+
+ gamma = cmsEstimateGamma(ContextID, Y_curve, thereshold);
+
+ cmsFreeToneCurve(ContextID, Y_curve);
+
+ return gamma;
+}
diff --git a/lcms2mt/src/cmsio0.c b/lcms2mt/src/cmsio0.c
index 83b37445..2fce03c9 100644
--- a/lcms2mt/src/cmsio0.c
+++ b/lcms2mt/src/cmsio0.c
@@ -492,7 +492,6 @@ cmsIOHANDLER* CMSEXPORT cmsGetProfileIOhandler(cmsContext ContextID, cmsHPROFILE
// Creates an empty structure holding all required parameters
cmsHPROFILE CMSEXPORT cmsCreateProfilePlaceholder(cmsContext ContextID)
{
- time_t now = time(NULL);
_cmsICCPROFILE* Icc = (_cmsICCPROFILE*) _cmsMallocZero(ContextID, sizeof(_cmsICCPROFILE));
if (Icc == NULL) return NULL;
@@ -504,13 +503,18 @@ cmsHPROFILE CMSEXPORT cmsCreateProfilePlaceholder(cmsContext ContextID)
Icc ->Version = 0x02100000;
// Set creation date/time
- memmove(&Icc ->Created, gmtime(&now), sizeof(Icc ->Created));
+ if (!_cmsGetTime(&Icc->Created))
+ goto Error;
// Create a mutex if the user provided proper plugin. NULL otherwise
Icc ->UsrMutex = _cmsCreateMutex(ContextID);
// Return the handle
return (cmsHPROFILE) Icc;
+
+Error:
+ _cmsFree(ContextID, Icc);
+ return NULL;
}
// Return the number of tags
diff --git a/lcms2mt/src/cmsopt.c b/lcms2mt/src/cmsopt.c
index 8fca60f8..562911ec 100644
--- a/lcms2mt/src/cmsopt.c
+++ b/lcms2mt/src/cmsopt.c
@@ -648,7 +648,6 @@ cmsBool OptimizeByResampling(cmsContext ContextID, cmsPipeline** Lut, cmsUInt32N
{
cmsPipeline* Src = NULL;
cmsPipeline* Dest = NULL;
- cmsStage* mpe;
cmsStage* CLUT;
cmsStage *KeepPreLin = NULL, *KeepPostLin = NULL;
cmsUInt32Number nGridPoints;
@@ -670,7 +669,7 @@ cmsBool OptimizeByResampling(cmsContext ContextID, cmsPipeline** Lut, cmsUInt32N
if (ColorSpace == (cmsColorSpaceSignature)0 ||
OutputColorSpace == (cmsColorSpaceSignature)0) return FALSE;
- nGridPoints = _cmsReasonableGridpointsByColorspace(ContextID, ColorSpace, *dwFlags);
+ nGridPoints = _cmsReasonableGridpointsByColorspace(ContextID, ColorSpace, *dwFlags);
// For empty LUTs, 2 points are enough
if (cmsPipelineStageCount(ContextID, *Lut) == 0)
@@ -678,13 +677,6 @@ cmsBool OptimizeByResampling(cmsContext ContextID, cmsPipeline** Lut, cmsUInt32N
Src = *Lut;
- // Named color pipelines cannot be optimized either
- for (mpe = cmsPipelineGetPtrToFirstStage(ContextID, Src);
- mpe != NULL;
- mpe = cmsStageNext(ContextID, mpe)) {
- if (cmsStageType(ContextID, mpe) == cmsSigNamedColorElemType) return FALSE;
- }
-
// Allocate an empty LUT
Dest = cmsPipelineAlloc(ContextID, Src ->InputChannels, Src ->OutputChannels);
if (!Dest) return FALSE;
@@ -1053,7 +1045,6 @@ cmsBool OptimizeByComputingLinearization(cmsContext ContextID, cmsPipeline** Lut
cmsStage* OptimizedCLUTmpe;
cmsColorSpaceSignature ColorSpace, OutputColorSpace;
cmsStage* OptimizedPrelinMpe;
- cmsStage* mpe;
cmsToneCurve** OptimizedPrelinCurves;
_cmsStageCLutData* OptimizedPrelinCLUT;
@@ -1074,14 +1065,6 @@ cmsBool OptimizeByComputingLinearization(cmsContext ContextID, cmsPipeline** Lut
}
OriginalLut = *Lut;
-
- // Named color pipelines cannot be optimized either
- for (mpe = cmsPipelineGetPtrToFirstStage(ContextID, OriginalLut);
- mpe != NULL;
- mpe = cmsStageNext(ContextID, mpe)) {
- if (cmsStageType(ContextID, mpe) == cmsSigNamedColorElemType) return FALSE;
- }
-
ColorSpace = _cmsICCcolorSpace(ContextID, (int) T_COLORSPACE(*InputFormat));
OutputColorSpace = _cmsICCcolorSpace(ContextID, (int) T_COLORSPACE(*OutputFormat));
@@ -1699,6 +1682,10 @@ cmsBool OptimizeMatrixShaper(cmsContext ContextID, cmsPipeline** Lut, cmsUInt32N
// Only works on 8 bit input
if (!_cmsFormatterIs8bit(*InputFormat)) return FALSE;
+ // Does not work in the presence of premultiplied alpha, as that causes the values
+ // passed in to not actually be '8 bit' in the way that we rely on.
+ if (*dwFlags & cmsFLAGS_PREMULT) return FALSE;
+
// Seems suitable, proceed
Src = *Lut;
@@ -1926,6 +1913,7 @@ cmsBool CMSEXPORT _cmsOptimizePipeline(cmsContext ContextID,
_cmsOptimizationPluginChunkType* ctx = ( _cmsOptimizationPluginChunkType*) _cmsContextGetClientChunk(ContextID, OptimizationPlugin);
_cmsOptimizationCollection* Opts;
cmsBool AnySuccess = FALSE;
+ cmsStage* mpe;
// A CLUT is being asked, so force this specific optimization
if (*dwFlags & cmsFLAGS_FORCE_CLUT) {
@@ -1940,6 +1928,13 @@ cmsBool CMSEXPORT _cmsOptimizePipeline(cmsContext ContextID,
return TRUE;
}
+ // Named color pipelines cannot be optimized
+ for (mpe = cmsPipelineGetPtrToFirstStage(ContextID, *PtrLut);
+ mpe != NULL;
+ mpe = cmsStageNext(ContextID, mpe)) {
+ if (cmsStageType(ContextID, mpe) == cmsSigNamedColorElemType) return FALSE;
+ }
+
// Try to get rid of identities and trivial conversions.
AnySuccess = PreOptimize(ContextID, *PtrLut);
diff --git a/lcms2mt/src/cmsplugin.c b/lcms2mt/src/cmsplugin.c
index 2a6e6b6b..279bcbd1 100644
--- a/lcms2mt/src/cmsplugin.c
+++ b/lcms2mt/src/cmsplugin.c
@@ -571,7 +571,7 @@ cmsBool CMSEXPORT cmsPlugin(cmsContext id, void* Plug_in)
if (Plugin ->ExpectedVersion < LCMS2MT_VERSION_MIN ||
Plugin ->ExpectedVersion > LCMS2MT_VERSION_MAX) {
- cmsSignalError(id, cmsERROR_UNKNOWN_EXTENSION, "plugin version %d not in acceptable version range. LCMS2.art cannot use LCMS2 plugins!",
+ cmsSignalError(id, cmsERROR_UNKNOWN_EXTENSION, "plugin version %d not in acceptable version range. LCMS2MT cannot use LCMS2 plugins!",
Plugin ->ExpectedVersion);
return FALSE;
}
@@ -1001,3 +1001,31 @@ cmsUInt32Number _cmsAdjustReferenceCount(cmsUInt32Number *rc, int delta)
return refs;
}
+
+// Use context mutex to provide thread-safe time
+cmsBool _cmsGetTime(struct tm* ptr_time)
+{
+ struct tm* t;
+#if defined(HAVE_GMTIME_R) || defined(HAVE__GMTIME64_S)
+ struct tm tm;
+#endif
+
+ time_t now = time(NULL);
+
+#ifdef HAVE_GMTIME_R
+ t = gmtime_r(&now, &tm);
+#elif defined(HAVE__GMTIME64_S)
+ t = _gmtime64_s(&tm, &now) == 0 ? &tm : NULL;
+#else
+ _cmsEnterCriticalSectionPrimitive(&_cmsContextPoolHeadMutex);
+ t = gmtime(&now);
+ _cmsLeaveCriticalSectionPrimitive(&_cmsContextPoolHeadMutex);
+#endif
+
+ if (t == NULL)
+ return FALSE;
+ else {
+ *ptr_time = *t;
+ return TRUE;
+ }
+}
diff --git a/lcms2mt/src/cmstypes.c b/lcms2mt/src/cmstypes.c
index 1d8c2a38..32471b92 100644
--- a/lcms2mt/src/cmstypes.c
+++ b/lcms2mt/src/cmstypes.c
@@ -1893,7 +1893,7 @@ Error:
static
cmsBool Type_LUT8_Write(cmsContext ContextID, struct _cms_typehandler_struct* self, cmsIOHANDLER* io, void* Ptr, cmsUInt32Number nItems)
{
- cmsUInt32Number j, nTabSize, i, n;
+ cmsUInt32Number j, nTabSize, i;
cmsUInt8Number val;
cmsPipeline* NewLUT = (cmsPipeline*) Ptr;
cmsStage* mpe;
@@ -1943,8 +1943,6 @@ cmsBool Type_LUT8_Write(cmsContext ContextID, struct _cms_typehandler_struct* s
if (!_cmsWriteUInt8Number(ContextID, io, (cmsUInt8Number) clutPoints)) return FALSE;
if (!_cmsWriteUInt8Number(ContextID, io, 0)) return FALSE; // Padding
- n = NewLUT->InputChannels * NewLUT->OutputChannels;
-
if (MatMPE != NULL) {
for (i = 0; i < 9; i++)
diff --git a/lcms2mt/src/cmsxform.c b/lcms2mt/src/cmsxform.c
index 2d85434e..7f4e1589 100644
--- a/lcms2mt/src/cmsxform.c
+++ b/lcms2mt/src/cmsxform.c
@@ -352,6 +352,22 @@ void NullFloatXFORM(cmsContext ContextID, _cmsTRANSFORM* p,
}
}
+cmsINLINE int mul255(cmsUInt32Number a, cmsUInt32Number b)
+{
+ /* see Jim Blinn's book "Dirty Pixels" for how this works */
+ cmsUInt32Number x = a * b + 128;
+ x += x >> 8;
+ return x >> 8;
+}
+
+cmsINLINE cmsUInt32Number mul65535(cmsUInt32Number a, cmsUInt32Number b)
+{
+ /* see Jim Blinn's book "Dirty Pixels" for how this works */
+ cmsUInt32Number x = a * b + 0x8000;
+ x += x >> 16;
+ return x >> 16;
+}
+
// 16 bit precision -----------------------------------------------------------------------------------------------------------
// Null transformation, only applies formatters. No cache
@@ -397,6 +413,11 @@ void NullXFORM(cmsContext ContextID,
#define FUNCTION_NAME PrecalculatedXFORM
#include "extra_xform.h"
+// No gamut check, no cache, 16 bits
+#define PREALPHA
+#define FUNCTION_NAME PrecalculatedXFORM_P
+#include "extra_xform.h"
+
// No gamut check, no cache, Identity transform, including pack/unpack
static
void PrecalculatedXFORMIdentity(cmsContext ContextID,
@@ -510,6 +531,12 @@ void TransformOnePixelWithGamutCheck(cmsContext ContextID, _cmsTRANSFORM* p,
#define GAMUTCHECK
#include "extra_xform.h"
+// Gamut check, No cache, 16 bits.
+#define FUNCTION_NAME PrecalculatedXFORMGamutCheck_P
+#define PREALPHA
+#define GAMUTCHECK
+#include "extra_xform.h"
+
// No gamut check, Cache, 16 bits,
#define FUNCTION_NAME CachedXFORM
#define CACHED
@@ -521,30 +548,40 @@ void TransformOnePixelWithGamutCheck(cmsContext ContextID, _cmsTRANSFORM* p,
#define GAMUTCHECK
#include "extra_xform.h"
+// All those nice features together
+#define FUNCTION_NAME CachedXFORMGamutCheck_P
+#define CACHED
+#define PREALPHA
+#define GAMUTCHECK
+#include "extra_xform.h"
+
// No gamut check, Cache, 16 bits, <= 4 bytes
#define FUNCTION_NAME CachedXFORM4
#define CACHED
-#define INBYTES 4
-#define EXTRABYTES 0
+#define CMPBYTES 4
+#define NUMEXTRAS 0
#include "extra_xform.h"
// No gamut check, Cache, 16 bits, <= 8 bytes total
#define FUNCTION_NAME CachedXFORM8
#define CACHED
-#define INBYTES 8
-#define EXTRABYTES 0
+#define CMPBYTES 8
+#define NUMEXTRAS 0
#include "extra_xform.h"
// Special ones for common cases.
#define FUNCTION_NAME CachedXFORM1to1
#define CACHED
-#define INBYTES 2
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = FROM_8_TO_16(*(S)); (S)++; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(D)++ = FROM_16_TO_8((S)[0]); \
} while (0)
@@ -552,13 +589,16 @@ do { \
#define FUNCTION_NAME CachedXFORM1x2to1x2
#define CACHED
-#define INBYTES 2
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
} while (0)
@@ -566,13 +606,16 @@ do { \
#define FUNCTION_NAME CachedXFORM1to3
#define CACHED
-#define INBYTES 2
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = FROM_8_TO_16(*(S)); (S)++; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(D)++ = FROM_16_TO_8((S)[0]); \
*(D)++ = FROM_16_TO_8((S)[1]); \
@@ -582,13 +625,16 @@ do { \
#define FUNCTION_NAME CachedXFORM1x2to3x2
#define CACHED
-#define INBYTES 2
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
*(cmsUInt16Number *)(D) = (S)[1]; (D) += 2; \
@@ -598,13 +644,16 @@ do { \
#define FUNCTION_NAME CachedXFORM1to4
#define CACHED
-#define INBYTES 2
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = FROM_8_TO_16(*(S)); (S)++; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(D)++ = FROM_16_TO_8((S)[0]); \
*(D)++ = FROM_16_TO_8((S)[1]); \
@@ -615,13 +664,16 @@ do { \
#define FUNCTION_NAME CachedXFORM1x2to4x2
#define CACHED
-#define INBYTES 2
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
*(cmsUInt16Number *)(D) = (S)[1]; (D) += 2; \
@@ -632,15 +684,18 @@ do { \
#define FUNCTION_NAME CachedXFORM3to1
#define CACHED
-#define INBYTES 6
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = FROM_8_TO_16(*(S)); (S)++; \
(D)[1] = FROM_8_TO_16(*(S)); (S)++; \
(D)[2] = FROM_8_TO_16(*(S)); (S)++; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(D)++ = FROM_16_TO_8((S)[0]); \
} while (0)
@@ -648,15 +703,18 @@ do { \
#define FUNCTION_NAME CachedXFORM3x2to1x2
#define CACHED
-#define INBYTES 6
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
(D)[1] = *(cmsUInt16Number *)(S); (S) += 2; \
(D)[2] = *(cmsUInt16Number *)(S); (S) += 2; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
} while (0)
@@ -664,15 +722,18 @@ do { \
#define FUNCTION_NAME CachedXFORM3to3
#define CACHED
-#define INBYTES 6
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = FROM_8_TO_16(*(S)); (S)++; \
(D)[1] = FROM_8_TO_16(*(S)); (S)++; \
(D)[2] = FROM_8_TO_16(*(S)); (S)++; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(D)++ = FROM_16_TO_8((S)[0]); \
*(D)++ = FROM_16_TO_8((S)[1]); \
@@ -682,15 +743,18 @@ do { \
#define FUNCTION_NAME CachedXFORM3x2to3x2
#define CACHED
-#define INBYTES 6
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
(D)[1] = *(cmsUInt16Number *)(S); (S) += 2; \
(D)[2] = *(cmsUInt16Number *)(S); (S) += 2; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
*(cmsUInt16Number *)(D) = (S)[1]; (D) += 2; \
@@ -700,15 +764,18 @@ do { \
#define FUNCTION_NAME CachedXFORM3to4
#define CACHED
-#define INBYTES 6
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = FROM_8_TO_16(*(S)); (S)++; \
(D)[1] = FROM_8_TO_16(*(S)); (S)++; \
(D)[2] = FROM_8_TO_16(*(S)); (S)++; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(D)++ = FROM_16_TO_8((S)[0]); \
*(D)++ = FROM_16_TO_8((S)[1]); \
@@ -719,15 +786,18 @@ do { \
#define FUNCTION_NAME CachedXFORM3x2to4x2
#define CACHED
-#define INBYTES 6
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
(D)[1] = *(cmsUInt16Number *)(S); (S) += 2; \
(D)[2] = *(cmsUInt16Number *)(S); (S) += 2; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
*(cmsUInt16Number *)(D) = (S)[1]; (D) += 2; \
@@ -738,16 +808,19 @@ do { \
#define FUNCTION_NAME CachedXFORM4to1
#define CACHED
-#define INBYTES 8
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = FROM_8_TO_16(*(S)); (S)++; \
(D)[1] = FROM_8_TO_16(*(S)); (S)++; \
(D)[2] = FROM_8_TO_16(*(S)); (S)++; \
(D)[3] = FROM_8_TO_16(*(S)); (S)++; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(D)++ = FROM_16_TO_8((S)[0]); \
} while (0)
@@ -755,16 +828,19 @@ do { \
#define FUNCTION_NAME CachedXFORM4x2to1x2
#define CACHED
-#define INBYTES 8
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
(D)[1] = *(cmsUInt16Number *)(S); (S) += 2; \
(D)[2] = *(cmsUInt16Number *)(S); (S) += 2; \
(D)[3] = *(cmsUInt16Number *)(S); (S) += 2; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
} while (0)
@@ -772,16 +848,19 @@ do { \
#define FUNCTION_NAME CachedXFORM4to3
#define CACHED
-#define INBYTES 8
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = FROM_8_TO_16(*(S)); (S)++; \
(D)[1] = FROM_8_TO_16(*(S)); (S)++; \
(D)[2] = FROM_8_TO_16(*(S)); (S)++; \
(D)[3] = FROM_8_TO_16(*(S)); (S)++; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(D)++ = FROM_16_TO_8((S)[0]); \
*(D)++ = FROM_16_TO_8((S)[1]); \
@@ -791,16 +870,19 @@ do { \
#define FUNCTION_NAME CachedXFORM4x2to3x2
#define CACHED
-#define INBYTES 8
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
(D)[1] = *(cmsUInt16Number *)(S); (S) += 2; \
(D)[2] = *(cmsUInt16Number *)(S); (S) += 2; \
(D)[3] = *(cmsUInt16Number *)(S); (S) += 2; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
*(cmsUInt16Number *)(D) = (S)[1]; (D) += 2; \
@@ -810,16 +892,19 @@ do { \
#define FUNCTION_NAME CachedXFORM4to4
#define CACHED
-#define INBYTES 8
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = FROM_8_TO_16(*(S)); (S)++; \
(D)[1] = FROM_8_TO_16(*(S)); (S)++; \
(D)[2] = FROM_8_TO_16(*(S)); (S)++; \
(D)[3] = FROM_8_TO_16(*(S)); (S)++; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(D)++ = FROM_16_TO_8((S)[0]); \
*(D)++ = FROM_16_TO_8((S)[1]); \
@@ -830,16 +915,387 @@ do { \
#define FUNCTION_NAME CachedXFORM4x2to4x2
#define CACHED
-#define INBYTES 8
-#define EXTRABYTES 0
-#define UNPACK(CTX,T,D,S,Z) \
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 0
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
+ (D)[1] = *(cmsUInt16Number *)(S); (S) += 2; \
+ (D)[2] = *(cmsUInt16Number *)(S); (S) += 2; \
+ (D)[3] = *(cmsUInt16Number *)(S); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
+ *(cmsUInt16Number *)(D) = (S)[1]; (D) += 2; \
+ *(cmsUInt16Number *)(D) = (S)[2]; (D) += 2; \
+ *(cmsUInt16Number *)(D) = (S)[3]; (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+// Same again, but with alpha
+// Special ones for common cases.
+#define FUNCTION_NAME CachedXFORM1to1_1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = FROM_8_TO_16(*(S)); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = FROM_16_TO_8((S)[0]); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM1x2to1x2_2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM1to3_1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 3
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = FROM_8_TO_16(*(S)); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = FROM_16_TO_8((S)[0]); \
+ *(D)++ = FROM_16_TO_8((S)[1]); \
+ *(D)++ = FROM_16_TO_8((S)[2]); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM1x2to3x2_2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
+ *(cmsUInt16Number *)(D) = (S)[1]; (D) += 2; \
+ *(cmsUInt16Number *)(D) = (S)[2]; (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM1to4_1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = FROM_8_TO_16(*(S)); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = FROM_16_TO_8((S)[0]); \
+ *(D)++ = FROM_16_TO_8((S)[1]); \
+ *(D)++ = FROM_16_TO_8((S)[2]); \
+ *(D)++ = FROM_16_TO_8((S)[3]); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM1x2to4x2_2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
+ *(cmsUInt16Number *)(D) = (S)[1]; (D) += 2; \
+ *(cmsUInt16Number *)(D) = (S)[2]; (D) += 2; \
+ *(cmsUInt16Number *)(D) = (S)[3]; (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM3to1_1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = FROM_8_TO_16(*(S)); (S)++; \
+ (D)[1] = FROM_8_TO_16(*(S)); (S)++; \
+ (D)[2] = FROM_8_TO_16(*(S)); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = FROM_16_TO_8((S)[0]); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM3x2to1x2_2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
+ (D)[1] = *(cmsUInt16Number *)(S); (S) += 2; \
+ (D)[2] = *(cmsUInt16Number *)(S); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM3to3_1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = FROM_8_TO_16(*(S)); (S)++; \
+ (D)[1] = FROM_8_TO_16(*(S)); (S)++; \
+ (D)[2] = FROM_8_TO_16(*(S)); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = FROM_16_TO_8((S)[0]); \
+ *(D)++ = FROM_16_TO_8((S)[1]); \
+ *(D)++ = FROM_16_TO_8((S)[2]); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM3x2to3x2_2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
+ (D)[1] = *(cmsUInt16Number *)(S); (S) += 2; \
+ (D)[2] = *(cmsUInt16Number *)(S); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
+ *(cmsUInt16Number *)(D) = (S)[1]; (D) += 2; \
+ *(cmsUInt16Number *)(D) = (S)[2]; (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM3to4_1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = FROM_8_TO_16(*(S)); (S)++; \
+ (D)[1] = FROM_8_TO_16(*(S)); (S)++; \
+ (D)[2] = FROM_8_TO_16(*(S)); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = FROM_16_TO_8((S)[0]); \
+ *(D)++ = FROM_16_TO_8((S)[1]); \
+ *(D)++ = FROM_16_TO_8((S)[2]); \
+ *(D)++ = FROM_16_TO_8((S)[3]); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM3x2to4x2_2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
+ (D)[1] = *(cmsUInt16Number *)(S); (S) += 2; \
+ (D)[2] = *(cmsUInt16Number *)(S); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
+ *(cmsUInt16Number *)(D) = (S)[1]; (D) += 2; \
+ *(cmsUInt16Number *)(D) = (S)[2]; (D) += 2; \
+ *(cmsUInt16Number *)(D) = (S)[3]; (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM4to1_1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = FROM_8_TO_16(*(S)); (S)++; \
+ (D)[1] = FROM_8_TO_16(*(S)); (S)++; \
+ (D)[2] = FROM_8_TO_16(*(S)); (S)++; \
+ (D)[3] = FROM_8_TO_16(*(S)); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = FROM_16_TO_8((S)[0]); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM4x2to1x2_2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
+ (D)[1] = *(cmsUInt16Number *)(S); (S) += 2; \
+ (D)[2] = *(cmsUInt16Number *)(S); (S) += 2; \
+ (D)[3] = *(cmsUInt16Number *)(S); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM4to3_1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = FROM_8_TO_16(*(S)); (S)++; \
+ (D)[1] = FROM_8_TO_16(*(S)); (S)++; \
+ (D)[2] = FROM_8_TO_16(*(S)); (S)++; \
+ (D)[3] = FROM_8_TO_16(*(S)); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = FROM_16_TO_8((S)[0]); \
+ *(D)++ = FROM_16_TO_8((S)[1]); \
+ *(D)++ = FROM_16_TO_8((S)[2]); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM4x2to3x2_2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
+ (D)[1] = *(cmsUInt16Number *)(S); (S) += 2; \
+ (D)[2] = *(cmsUInt16Number *)(S); (S) += 2; \
+ (D)[3] = *(cmsUInt16Number *)(S); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
+ *(cmsUInt16Number *)(D) = (S)[1]; (D) += 2; \
+ *(cmsUInt16Number *)(D) = (S)[2]; (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM4to4_1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ (D)[0] = FROM_8_TO_16(*(S)); (S)++; \
+ (D)[1] = FROM_8_TO_16(*(S)); (S)++; \
+ (D)[2] = FROM_8_TO_16(*(S)); (S)++; \
+ (D)[3] = FROM_8_TO_16(*(S)); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = FROM_16_TO_8((S)[0]); \
+ *(D)++ = FROM_16_TO_8((S)[1]); \
+ *(D)++ = FROM_16_TO_8((S)[2]); \
+ *(D)++ = FROM_16_TO_8((S)[3]); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM4x2to4x2_2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 1
+#define UNPACK(CTX,T,D,S,Z,A) \
do { \
(D)[0] = *(cmsUInt16Number *)(S); (S) += 2; \
(D)[1] = *(cmsUInt16Number *)(S); (S) += 2; \
(D)[2] = *(cmsUInt16Number *)(S); (S) += 2; \
(D)[3] = *(cmsUInt16Number *)(S); (S) += 2; \
} while (0)
-#define PACK(CTX,T,S,D,Z) \
+#define PACK(CTX,T,S,D,Z,A) \
do { \
*(cmsUInt16Number *)(D) = (S)[0]; (D) += 2; \
*(cmsUInt16Number *)(D) = (S)[1]; (D) += 2; \
@@ -848,6 +1304,465 @@ do { \
} while (0)
#include "extra_xform.h"
+
+// Same again, but with premultiplied alpha
+//
+// No gamut check, Cache, 16 bits,
+#define FUNCTION_NAME CachedXFORM_P1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define PREALPHA
+#include "extra_xform.h"
+
+// No gamut check, Cache, 16 bits,
+#define FUNCTION_NAME CachedXFORM_P2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define PREALPHA
+#include "extra_xform.h"
+
+// Special ones for common cases.
+#define FUNCTION_NAME CachedXFORM1to1_P1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xFFFFU / (A); \
+ (D)[0] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = mul255(FROM_16_TO_8((S)[0]),(A)); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM1x2to1x2_P2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xffff0000U / (A); \
+ (D)[0] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = mul65535((S)[0],A); (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM1to3_P1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xFFFFU / (A); \
+ (D)[0] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = mul255(FROM_16_TO_8((S)[0]),(A)); \
+ *(D)++ = mul255(FROM_16_TO_8((S)[1]),(A)); \
+ *(D)++ = mul255(FROM_16_TO_8((S)[2]),(A)); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM1x2to3x2_P2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xffff0000U / (A); \
+ (D)[0] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = mul65535((S)[0],A); (D) += 2; \
+ *(cmsUInt16Number *)(D) = mul65535((S)[1],A); (D) += 2; \
+ *(cmsUInt16Number *)(D) = mul65535((S)[2],A); (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM1to4_P1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xFFFFU / (A); \
+ (D)[0] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = mul255(FROM_16_TO_8((S)[0]),(A)); \
+ *(D)++ = mul255(FROM_16_TO_8((S)[1]),(A)); \
+ *(D)++ = mul255(FROM_16_TO_8((S)[2]),(A)); \
+ *(D)++ = mul255(FROM_16_TO_8((S)[3]),(A)); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM1x2to4x2_P2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 1
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xffff0000U / (A); \
+ (D)[0] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = mul65535((S)[0],A); (D) += 2; \
+ *(cmsUInt16Number *)(D) = mul65535((S)[1],A); (D) += 2; \
+ *(cmsUInt16Number *)(D) = mul65535((S)[2],A); (D) += 2; \
+ *(cmsUInt16Number *)(D) = mul65535((S)[3],A); (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM3to1_P1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xFFFFU / (A); \
+ (D)[0] = (cmsUInt16Number)((*(S) * inva)); (S)++; \
+ (D)[1] = (cmsUInt16Number)((*(S) * inva)); (S)++; \
+ (D)[2] = (cmsUInt16Number)((*(S) * inva)); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = mul255(FROM_16_TO_8((S)[0]),(A)); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM3x2to1x2_P2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xffff0000U / (A); \
+ (D)[0] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+ (D)[1] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+ (D)[2] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = mul65535((S)[0],A); (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM3to3_P1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xFFFFU / (A); \
+ (D)[0] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+ (D)[1] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+ (D)[2] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = mul255(FROM_16_TO_8((S)[0]),(A)); \
+ *(D)++ = mul255(FROM_16_TO_8((S)[1]),(A)); \
+ *(D)++ = mul255(FROM_16_TO_8((S)[2]),(A)); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM3x2to3x2_P2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xffff0000U / (A); \
+ (D)[0] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+ (D)[1] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+ (D)[2] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = mul65535((S)[0],A); (D) += 2; \
+ *(cmsUInt16Number *)(D) = mul65535((S)[1],A); (D) += 2; \
+ *(cmsUInt16Number *)(D) = mul65535((S)[2],A); (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM3to4_P1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xFFFFU / (A); \
+ (D)[0] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+ (D)[1] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+ (D)[2] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = mul255(FROM_16_TO_8((S)[0]),(A)); \
+ *(D)++ = mul255(FROM_16_TO_8((S)[1]),(A)); \
+ *(D)++ = mul255(FROM_16_TO_8((S)[2]),(A)); \
+ *(D)++ = mul255(FROM_16_TO_8((S)[3]),(A)); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM3x2to4x2_P2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 3
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xffff0000U / (A); \
+ (D)[0] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+ (D)[1] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+ (D)[2] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = mul65535((S)[0],A); (D) += 2; \
+ *(cmsUInt16Number *)(D) = mul65535((S)[1],A); (D) += 2; \
+ *(cmsUInt16Number *)(D) = mul65535((S)[2],A); (D) += 2; \
+ *(cmsUInt16Number *)(D) = mul65535((S)[3],A); (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM4to1_P1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xFFFFU / (A); \
+ (D)[0] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+ (D)[1] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+ (D)[2] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+ (D)[3] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = mul255(FROM_16_TO_8((S)[0]),(A)); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM4x2to1x2_P2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 1
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xffff0000U / (A); \
+ (D)[0] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+ (D)[1] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+ (D)[2] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+ (D)[3] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = mul65535((S)[0],A); (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM4to3_P1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xFFFFU / (A); \
+ (D)[0] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+ (D)[1] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+ (D)[2] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+ (D)[3] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = mul255(FROM_16_TO_8((S)[0]),(A)); \
+ *(D)++ = mul255(FROM_16_TO_8((S)[1]),(A)); \
+ *(D)++ = mul255(FROM_16_TO_8((S)[2]),(A)); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM4x2to3x2_P2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 3
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xffff0000U / (A); \
+ (D)[0] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+ (D)[1] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+ (D)[2] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+ (D)[3] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = mul65535((S)[0],A); (D) += 2; \
+ *(cmsUInt16Number *)(D) = mul65535((S)[1],A); (D) += 2; \
+ *(cmsUInt16Number *)(D) = mul65535((S)[2],A); (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM4to4_P1
+#define CACHED
+#define INPACKEDSAMPLESIZE 1
+#define OUTPACKEDSAMPLESIZE 1
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xFFFFU / (A); \
+ (D)[0] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+ (D)[1] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+ (D)[2] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+ (D)[3] = (cmsUInt16Number)(*(S) * inva); (S)++; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(D)++ = mul255(FROM_16_TO_8((S)[0]),(A)); \
+ *(D)++ = mul255(FROM_16_TO_8((S)[1]),(A)); \
+ *(D)++ = mul255(FROM_16_TO_8((S)[2]),(A)); \
+ *(D)++ = mul255(FROM_16_TO_8((S)[3]),(A)); \
+} while (0)
+#include "extra_xform.h"
+
+#define FUNCTION_NAME CachedXFORM4x2to4x2_P2
+#define CACHED
+#define INPACKEDSAMPLESIZE 2
+#define OUTPACKEDSAMPLESIZE 2
+#define NUMINCHANNELS 4
+#define NUMOUTCHANNELS 4
+#define NUMEXTRAS 1
+#define PREALPHA
+#define UNPACKINCLUDESPREALPHA
+#define PACKINCLUDESPREALPHA
+#define UNPACK(CTX,T,D,S,Z,A) \
+do { \
+ cmsUInt32Number inva = 0xffff0000U / (A); \
+ (D)[0] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+ (D)[1] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+ (D)[2] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+ (D)[3] = (cmsUInt16Number)(((*(cmsUInt16Number *)(S)) * inva)>>16); (S) += 2; \
+} while (0)
+#define PACK(CTX,T,S,D,Z,A) \
+do { \
+ *(cmsUInt16Number *)(D) = mul65535((S)[0],A); (D) += 2; \
+ *(cmsUInt16Number *)(D) = mul65535((S)[1],A); (D) += 2; \
+ *(cmsUInt16Number *)(D) = mul65535((S)[2],A); (D) += 2; \
+ *(cmsUInt16Number *)(D) = mul65535((S)[3],A); (D) += 2; \
+} while (0)
+#include "extra_xform.h"
+
+
// Transform plug-ins ----------------------------------------------------------------------------------------------------
// List of used-defined transform factories
@@ -966,8 +1881,10 @@ cmsBool _cmsRegisterTransformPlugin(cmsContext ContextID, cmsPluginBase* Data)
if (fl == NULL) return FALSE;
// Check for full xform plug-ins previous to 2.8, we would need an adapter in that case
- if (Plugin->base.ExpectedVersion < 2080-2000) {
-
+ if ((Plugin->base.ExpectedVersion <= LCMS2MT_VERSION_MAX &&
+ Plugin->base.ExpectedVersion < 2080-2000) ||
+ (Plugin->base.ExpectedVersion > LCMS2MT_VERSION_MAX &&
+ Plugin->base.ExpectedVersion < 2080)) {
fl->OldXform = TRUE;
}
else
@@ -1028,6 +1945,34 @@ _cmsFindFormatter(_cmsTRANSFORM* p, cmsUInt32Number InputFormat, cmsUInt32Number
p ->xform = NullXFORM;
return;
}
+ if (dwFlags & cmsFLAGS_PREMULT) {
+ if (dwFlags & cmsFLAGS_NOCACHE) {
+ if (dwFlags & cmsFLAGS_GAMUTCHECK)
+ p ->xform = PrecalculatedXFORMGamutCheck_P; // Gamut check, no cache
+ else if ((InputFormat & ~COLORSPACE_SH(31)) == (OutputFormat & ~COLORSPACE_SH(31)) &&
+ _cmsLutIsIdentity(p->core->Lut)) {
+ if (T_PLANAR(InputFormat))
+ p ->xform = PrecalculatedXFORMIdentityPlanar;
+ else
+ p ->xform = PrecalculatedXFORMIdentity;
+ } else
+ p ->xform = PrecalculatedXFORM_P; // No cache, no gamut check
+ return;
+ }
+ if (dwFlags & cmsFLAGS_GAMUTCHECK) {
+ p ->xform = CachedXFORMGamutCheck_P; // Gamut check, cache
+ return;
+ }
+ if ((InputFormat & ~COLORSPACE_SH(31)) == (OutputFormat & ~COLORSPACE_SH(31)) &&
+ _cmsLutIsIdentity(p->core->Lut)) {
+ /* No point in a cache here! */
+ if (T_PLANAR(InputFormat))
+ p ->xform = PrecalculatedXFORMIdentityPlanar;
+ else
+ p ->xform = PrecalculatedXFORMIdentity;
+ return;
+ }
+ }
if (dwFlags & cmsFLAGS_NOCACHE) {
if (dwFlags & cmsFLAGS_GAMUTCHECK)
p ->xform = PrecalculatedXFORMGamutCheck; // Gamut check, no cache
@@ -1039,11 +1984,11 @@ _cmsFindFormatter(_cmsTRANSFORM* p, cmsUInt32Number InputFormat, cmsUInt32Number
p ->xform = PrecalculatedXFORMIdentity;
} else
p ->xform = PrecalculatedXFORM; // No cache, no gamut check
- return;
+ return;
}
if (dwFlags & cmsFLAGS_GAMUTCHECK) {
p ->xform = CachedXFORMGamutCheck; // Gamut check, cache
- return;
+ return;
}
if ((InputFormat & ~COLORSPACE_SH(31)) == (OutputFormat & ~COLORSPACE_SH(31)) &&
_cmsLutIsIdentity(p->core->Lut)) {
@@ -1054,8 +1999,140 @@ _cmsFindFormatter(_cmsTRANSFORM* p, cmsUInt32Number InputFormat, cmsUInt32Number
p ->xform = PrecalculatedXFORMIdentity;
return;
}
+ if (T_EXTRA(InputFormat) == 1 && T_EXTRA(OutputFormat) == 1) {
+ if (dwFlags & cmsFLAGS_PREMULT) {
+ if ((InputFormat & ~(COLORSPACE_SH(31)|CHANNELS_SH(7)|BYTES_SH(3)|EXTRA_SH(1))) == 0 &&
+ (OutputFormat & ~(COLORSPACE_SH(31)|CHANNELS_SH(7)|BYTES_SH(3)|EXTRA_SH(1))) == 0) {
+ switch ((InputFormat & (CHANNELS_SH(7)|BYTES_SH(3)))|
+ ((OutputFormat & (CHANNELS_SH(7)|BYTES_SH(3)))<<6)) {
+ case CHANNELS_SH(1) | BYTES_SH(1) | ((CHANNELS_SH(1) | BYTES_SH(1))<<6):
+ p->xform = CachedXFORM1to1_P1;
+ return;
+ case CHANNELS_SH(1) | BYTES_SH(2) | ((CHANNELS_SH(1) | BYTES_SH(2))<<6):
+ p->xform = CachedXFORM1x2to1x2_P2;
+ return;
+ case CHANNELS_SH(1) | BYTES_SH(1) | ((CHANNELS_SH(3) | BYTES_SH(1))<<6):
+ p->xform = CachedXFORM1to3_P1;
+ return;
+ case CHANNELS_SH(1) | BYTES_SH(2) | ((CHANNELS_SH(3) | BYTES_SH(2))<<6):
+ p->xform = CachedXFORM1x2to3x2_P2;
+ return;
+ case CHANNELS_SH(1) | BYTES_SH(1) | ((CHANNELS_SH(4) | BYTES_SH(1))<<6):
+ p->xform = CachedXFORM1to4_P1;
+ return;
+ case CHANNELS_SH(1) | BYTES_SH(2) | ((CHANNELS_SH(4) | BYTES_SH(2))<<6):
+ p->xform = CachedXFORM1x2to4x2_P2;
+ return;
+ case CHANNELS_SH(3) | BYTES_SH(1) | ((CHANNELS_SH(1) | BYTES_SH(1))<<6):
+ p ->xform = CachedXFORM3to1_P1;
+ return;
+ case CHANNELS_SH(3) | BYTES_SH(2) | ((CHANNELS_SH(1) | BYTES_SH(2))<<6):
+ p ->xform = CachedXFORM3x2to1x2_P2;
+ return;
+ case CHANNELS_SH(3) | BYTES_SH(1) | ((CHANNELS_SH(3) | BYTES_SH(1))<<6):
+ p->xform = CachedXFORM3to3_P1;
+ return;
+ case CHANNELS_SH(3) | BYTES_SH(2) | ((CHANNELS_SH(3) | BYTES_SH(2))<<6):
+ p->xform = CachedXFORM3x2to3x2_P2;
+ return;
+ case CHANNELS_SH(3) | BYTES_SH(1) | ((CHANNELS_SH(4) | BYTES_SH(1))<<6):
+ p->xform = CachedXFORM3to4_P1;
+ return;
+ case CHANNELS_SH(3) | BYTES_SH(2) | ((CHANNELS_SH(4) | BYTES_SH(2))<<6):
+ p->xform = CachedXFORM3x2to4x2_P2;
+ return;
+ case CHANNELS_SH(4) | BYTES_SH(1) | ((CHANNELS_SH(1) | BYTES_SH(1))<<6):
+ p->xform = CachedXFORM4to1_P1;
+ return;
+ case CHANNELS_SH(4) | BYTES_SH(2) | ((CHANNELS_SH(1) | BYTES_SH(2))<<6):
+ p->xform = CachedXFORM4x2to1x2_P2;
+ return;
+ case CHANNELS_SH(4) | BYTES_SH(1) | ((CHANNELS_SH(3) | BYTES_SH(1))<<6):
+ p->xform = CachedXFORM4to3_P1;
+ return;
+ case CHANNELS_SH(4) | BYTES_SH(2) | ((CHANNELS_SH(3) | BYTES_SH(2))<<6):
+ p->xform = CachedXFORM4x2to3x2_P2;
+ return;
+ case CHANNELS_SH(4) | BYTES_SH(1) | ((CHANNELS_SH(4) | BYTES_SH(1))<<6):
+ p->xform = CachedXFORM4to4_P1;
+ return;
+ case CHANNELS_SH(4) | BYTES_SH(2) | ((CHANNELS_SH(4) | BYTES_SH(2))<<6):
+ p->xform = CachedXFORM4x2to4x2_P2;
+ return;
+ }
+ }
+ } else {
+ if ((InputFormat & ~(COLORSPACE_SH(31)|CHANNELS_SH(7)|BYTES_SH(3)|EXTRA_SH(1))) == 0 &&
+ (OutputFormat & ~(COLORSPACE_SH(31)|CHANNELS_SH(7)|BYTES_SH(3)|EXTRA_SH(1))) == 0) {
+ switch ((InputFormat & (CHANNELS_SH(7)|BYTES_SH(3)))|
+ ((OutputFormat & (CHANNELS_SH(7)|BYTES_SH(3)))<<6)) {
+ case CHANNELS_SH(1) | BYTES_SH(1) | ((CHANNELS_SH(1) | BYTES_SH(1))<<6):
+ p->xform = CachedXFORM1to1_1;
+ return;
+ case CHANNELS_SH(1) | BYTES_SH(2) | ((CHANNELS_SH(1) | BYTES_SH(2))<<6):
+ p->xform = CachedXFORM1x2to1x2_2;
+ return;
+ case CHANNELS_SH(1) | BYTES_SH(1) | ((CHANNELS_SH(3) | BYTES_SH(1))<<6):
+ p->xform = CachedXFORM1to3_1;
+ return;
+ case CHANNELS_SH(1) | BYTES_SH(2) | ((CHANNELS_SH(3) | BYTES_SH(2))<<6):
+ p->xform = CachedXFORM1x2to3x2_2;
+ return;
+ case CHANNELS_SH(1) | BYTES_SH(1) | ((CHANNELS_SH(4) | BYTES_SH(1))<<6):
+ p->xform = CachedXFORM1to4_1;
+ return;
+ case CHANNELS_SH(1) | BYTES_SH(2) | ((CHANNELS_SH(4) | BYTES_SH(2))<<6):
+ p->xform = CachedXFORM1x2to4x2_2;
+ return;
+ case CHANNELS_SH(3) | BYTES_SH(1) | ((CHANNELS_SH(1) | BYTES_SH(1))<<6):
+ p ->xform = CachedXFORM3to1_1;
+ return;
+ case CHANNELS_SH(3) | BYTES_SH(2) | ((CHANNELS_SH(1) | BYTES_SH(2))<<6):
+ p ->xform = CachedXFORM3x2to1x2_2;
+ return;
+ case CHANNELS_SH(3) | BYTES_SH(1) | ((CHANNELS_SH(3) | BYTES_SH(1))<<6):
+ p->xform = CachedXFORM3to3_1;
+ return;
+ case CHANNELS_SH(3) | BYTES_SH(2) | ((CHANNELS_SH(3) | BYTES_SH(2))<<6):
+ p->xform = CachedXFORM3x2to3x2_2;
+ return;
+ case CHANNELS_SH(3) | BYTES_SH(1) | ((CHANNELS_SH(4) | BYTES_SH(1))<<6):
+ p->xform = CachedXFORM3to4_1;
+ return;
+ case CHANNELS_SH(3) | BYTES_SH(2) | ((CHANNELS_SH(4) | BYTES_SH(2))<<6):
+ p->xform = CachedXFORM3x2to4x2_2;
+ return;
+ case CHANNELS_SH(4) | BYTES_SH(1) | ((CHANNELS_SH(1) | BYTES_SH(1))<<6):
+ p->xform = CachedXFORM4to1_1;
+ return;
+ case CHANNELS_SH(4) | BYTES_SH(2) | ((CHANNELS_SH(1) | BYTES_SH(2))<<6):
+ p->xform = CachedXFORM4x2to1x2_2;
+ return;
+ case CHANNELS_SH(4) | BYTES_SH(1) | ((CHANNELS_SH(3) | BYTES_SH(1))<<6):
+ p->xform = CachedXFORM4to3_1;
+ return;
+ case CHANNELS_SH(4) | BYTES_SH(2) | ((CHANNELS_SH(3) | BYTES_SH(2))<<6):
+ p->xform = CachedXFORM4x2to3x2_2;
+ return;
+ case CHANNELS_SH(4) | BYTES_SH(1) | ((CHANNELS_SH(4) | BYTES_SH(1))<<6):
+ p->xform = CachedXFORM4to4_1;
+ return;
+ case CHANNELS_SH(4) | BYTES_SH(2) | ((CHANNELS_SH(4) | BYTES_SH(2))<<6):
+ p->xform = CachedXFORM4x2to4x2_2;
+ return;
+ }
+ }
+ }
+ }
if (T_EXTRA(InputFormat) != 0) {
- p ->xform = CachedXFORM; // No gamut check, cache
+ if (dwFlags & cmsFLAGS_PREMULT) {
+ if (T_BYTES(InputFormat) == 1)
+ p ->xform = CachedXFORM_P1;// No gamut check, cache
+ else
+ p ->xform = CachedXFORM_P2;// No gamut check, cache
+ } else {
+ p ->xform = CachedXFORM; // No gamut check, cache
+ }
return;
}
if ((InputFormat & ~(COLORSPACE_SH(31)|CHANNELS_SH(7)|BYTES_SH(3))) == 0 &&
@@ -1082,7 +2159,7 @@ _cmsFindFormatter(_cmsTRANSFORM* p, cmsUInt32Number InputFormat, cmsUInt32Number
return;
case CHANNELS_SH(3) | BYTES_SH(1) | ((CHANNELS_SH(1) | BYTES_SH(1))<<6):
p ->xform = CachedXFORM3to1;
- return;
+ return;
case CHANNELS_SH(3) | BYTES_SH(2) | ((CHANNELS_SH(1) | BYTES_SH(2))<<6):
p ->xform = CachedXFORM3x2to1x2;
return;
@@ -1416,6 +2493,15 @@ cmsHTRANSFORM CMSEXPORT cmsCreateExtendedTransform(cmsContext ContextID,
return NULL;
}
+ // Check whatever the transform is 16 bits and involves linear RGB in first profile. If so, disable optimizations
+ if (EntryColorSpace == cmsSigRgbData && T_BYTES(InputFormat) == 2 && !(dwFlags & cmsFLAGS_NOOPTIMIZE))
+ {
+ cmsFloat64Number gamma = cmsDetectRGBProfileGamma(ContextID, hProfiles[0], 0.1);
+
+ if (gamma > 0 && gamma < 1.6)
+ dwFlags |= cmsFLAGS_NOOPTIMIZE;
+ }
+
// Create a pipeline with all transformations
Lut = _cmsLinkProfiles(ContextID, nProfiles, Intents, hProfiles, BPC, AdaptationStates, dwFlags);
if (Lut == NULL) {
@@ -1431,6 +2517,21 @@ cmsHTRANSFORM CMSEXPORT cmsCreateExtendedTransform(cmsContext ContextID,
return NULL;
}
+ // Check premultiplication requirements
+ if (dwFlags & cmsFLAGS_PREMULT) {
+ if (T_BYTES(InputFormat) != T_BYTES(OutputFormat)) {
+ cmsPipelineFree(ContextID, Lut);
+ cmsSignalError(ContextID, cmsERROR_NOT_SUITABLE, "Premultiplication requires input and output to be in the same format.");
+ return NULL;
+ }
+
+ if (T_EXTRA(InputFormat) < 1 || T_EXTRA(OutputFormat) < 1 || T_EXTRA(InputFormat) != T_EXTRA(OutputFormat) || (dwFlags & cmsFLAGS_COPY_ALPHA) == 0) {
+ cmsPipelineFree(ContextID, Lut);
+ cmsSignalError(ContextID, cmsERROR_NOT_SUITABLE, "Premultiplication must preserve the extra channels");
+ return NULL;
+ }
+ }
+
// All seems ok
xform = AllocEmptyTransform(ContextID, Lut, LastIntent, &InputFormat, &OutputFormat, &dwFlags);
diff --git a/lcms2mt/src/extra_xform.h b/lcms2mt/src/extra_xform.h
index 51dd0e05..3f8a75f7 100644
--- a/lcms2mt/src/extra_xform.h
+++ b/lcms2mt/src/extra_xform.h
@@ -14,20 +14,48 @@
//
// If caching is wanted, define CACHED.
//
-// To reduce the amount of surplus memory checking done, set INBYTES to the
-// number of bytes in an unpacked data chunk. INBYTES will only have an
-// effect if CACHED or NO_UNPACK
+// If the representation/calculations are to be done using floating point
+// define XFORM_FLOAT. In the absence of this it is assumed that the
+// calculations will be done in 16 bit with appropriate unpacking/repacking.
+//
+// If you know the number of input/output channels, define NUMINCHANNELS and
+// NUMOUTCHANNELS.
+//
+// If you know the number of bytes used for the packed version of input and/or
+// output, define INPACKEDSAMPLESIZE and OUTPACKEDSAMPLESIZE.
+//
+// If you do not know the number of channels and/or the sample size, but you
+// do know a maximum bound on the number of bytes used to represent the
+// unpacked samples, then operation with CACHE can be accelerated by defining
+// CMPBYTES to the number of bytes that should be compared to the cached result.
+// Usually that is calculated from NUMINCHANNELS and INPACKEDSAMPLESIZE, so
+// specifying it directly is only useful if either (or both) of those is not
+// known in advance.
+//
+// For Premultiplied Alpha modes, you must define PREMULT. We only support
+// premultiplied alpha where the alpha is the last 'extra' channel, and
+// where both source and destination are packed in the same way.
//
// If you know the code to be used to unpack (or pack, or both) data to/from
// the simple 16 bit transform input/output format, then you can choose
// to this directly by defining UNPACK/PACK macros as follows:
-// UNPACK(T,TO,FROM,SIZE) (Opt) code to unpack input data (T = Transform
-// TO = buffer to unpack into, FROM = data,
-// SIZE = size of data)
-// PACK(T,FROM,TO,SIZE) (Opt) code to pack transformed input data
-// (T = Transform, FROM = transformed data,
-// TO = output buffer to pack into,
-// SIZE = size of data)
+// UNPACK(T,TO,FROM,SIZE,AL) (Opt) code to unpack input data (T = Transform
+// TO = buffer to unpack into, FROM = data,
+// SIZE = size of data, AL = Alpha)
+// PACK(T,FROM,TO,SIZE,AL) (Opt) code to pack transformed input data
+// (T = Transform, FROM = transformed data,
+// TO = output buffer to pack into,
+// SIZE = size of data, AL = Alpha)
+//
+// Ignore AL unless PREMULT is defined, in which case it will be in the packed
+// format. AL is guaranteed to be non-zero.
+//
+// If UNPACKINCLUDESPREALPHA is defined, then UNPACK should undo the
+// premultiplication by AL (i.e. divide by AL). Otherwise AL should be ignored
+// and this routine will do it for you.
+//
+// If PACKINCLUDESPREALPHA is defined, then PACK should apply AL (i.e. multiply
+// by AL). Otherwise AL should be ignored and this routine will do it for you.
//
// As an alternative to the above, if you know the function name that would
// be called, supply that in UNPACKFN and PACKFN and inlining compilers
@@ -38,7 +66,7 @@
// If the data happens to be in the correct input format anyway, we can skip
// unpacking it entirely and just use it direct.
// NO_UNPACK (Opt) if defined, transform direct from the input
-// data. INBYTES must be defined.
+// data.
//
// UNPACK/PACK/UNPACKFN/PACKFN/NO_UNPACK are all expected to update their
// TO pointer to point to the next pixels data. This means for cases where
@@ -47,7 +75,7 @@
// If the data happens to be in the correct output format anyway, we can skip
// packing it entirely and just transform it direct into the buffer.
// NO_PACK (Opt) if defined, transform direct to the output
-// data. OUTBYTES must be defined.
+// data.
// COPY_MATCHED(FROM,TO)(Opt)if defined, copy output values from FROM to
// TO. Used in the case CACHED case where the
// cache matches and we have to copy forwards.
@@ -60,73 +88,126 @@
// COPY_EXTRAS(TRANS,FROM,TO) to do so.
// If none of these are defined, we call cmsHandleExtraChannels.
-#ifdef INBYTES
+#ifndef CMPBYTES
+#ifdef NUMINCHANNELS
+#ifdef XFORM_FLOAT
+#define CMPBYTES (NUMINCHANNELS*4)
+#else
+#define CMPBYTES (NUMINCHANNELS*2)
+#endif
+#endif
+#endif
+
+#ifdef CMPBYTES
// Previously, we've attempted to do 'int' based checks here, but this falls
// foul of some compilers with their strict pointer aliasing. We have the
// choice of calling memcmp (which tests using chars, so is safe), or of
// testing using the actual type.
#ifdef XFORM_FLOAT
- #if INBYTES == 4
+ #if CMPBYTES == 4
#define COMPARE(A,B) ((A)[0] != (B)[0])
- #elif INBYTES == 8
+ #elif CMPBYTES == 8
#define COMPARE(A,B) (((A)[0] != (B)[0]) || ((A)[1] != (B)[1]))
- #elif INBYTES == 12
+ #elif CMPBYTES == 12
#define COMPARE(A,B) (((A)[0] != (B)[0]) || ((A)[1] != (B)[1]) || ((A)[2] != (B)[2]))
- #elif INBYTES == 16
+ #elif CMPBYTES == 16
#define COMPARE(A,B) (((A)[0] != (B)[0]) || ((A)[1] != (B)[1]) || ((A)[2] != (B)[2]) || ((A)[3] != (B)[3]))
#endif
#else
- #if INBYTES == 2
+ #if CMPBYTES == 2
#define COMPARE(A,B) ((A)[0] != (B)[0])
- #elif INBYTES == 4
+ #elif CMPBYTES == 4
#define COMPARE(A,B) (((A)[0] != (B)[0]) || ((A)[1] != (B)[1]))
- #elif INBYTES == 6
+ #elif CMPBYTES == 6
#define COMPARE(A,B) (((A)[0] != (B)[0]) || ((A)[1] != (B)[1]) || ((A)[2] != (B)[2]))
- #elif INBYTES == 8
+ #elif CMPBYTES == 8
#define COMPARE(A,B) (((A)[0] != (B)[0]) || ((A)[1] != (B)[1]) || ((A)[2] != (B)[2]) || ((A)[3] != (B)[3]))
#endif
#endif
#else
// Otherwise, set INBYTES to be the maximum size it could possibly be.
- #define INBYTES (sizeof(cmsUInt16Number)*cmsMAXCHANNELS)
+ #ifdef XFORM_FLOAT
+ #define CMPBYTES (sizeof(cmsFloat32Number)*cmsMAXCHANNELS)
+ #else
+ #define CMPBYTES (sizeof(cmsUInt16Number)*cmsMAXCHANNELS)
+ #endif
#endif
#ifndef COMPARE
- #define COMPARE(A,B) memcmp((A),(B), INBYTES)
+ #define COMPARE(A,B) memcmp((A),(B), CMPBYTES)
#endif
#if defined(UNPACK)
// Nothing to do, UNPACK is already defined
#elif defined(NO_UNPACK)
- #define UNPACK(CTX,T,TO,FROM,STRIDE) do { } while (0)
+ #define UNPACK(CTX,T,TO,FROM,STRIDE,AL) do { } while (0)
#elif defined(UNPACKFN)
- #define UNPACK(CTX,T,TO,FROM,STRIDE) \
- do { (FROM) = UNPACKFN((CTX),(T),(TO),(FROM),(STRIDE)); } while (0)
+ #define UNPACK(CTX,T,TO,FROM,STRIDE,AL) \
+ do { (FROM) = UNPACKFN((CTX),(T),(TO),(FROM),(STRIDE),(AL)); } while (0)
#elif defined(XFORM_FLOAT)
- #define UNPACK(CTX,T,TO,FROM,STRIDE) \
+ #define UNPACK(CTX,T,TO,FROM,STRIDE,AL) \
do { (FROM) = (T)->FromInputFloat((CTX),(T),(TO),(FROM),(STRIDE)); } while (0)
#else
- #define UNPACK(CTX,T,TO,FROM,STRIDE) \
+ #define UNPACK(CTX,T,TO,FROM,STRIDE,AL) \
do { (FROM) = (T)->FromInput((CTX),(T),(TO),(FROM),(STRIDE)); } while (0)
#endif
#if defined(PACK)
// Nothing to do, PACK is already defined
#elif defined(NO_PACK)
- #define PACK(CTX,T,FROM,TO,STRIDE) \
- do { (FROM) += ((OUTBYTES)/sizeof(XFORM_TYPE)); } while (0)
+ #define PACK(CTX,T,FROM,TO,STRIDE,AL) \
+ do { (FROM) += (totaloutbytes/sizeof(XFORM_TYPE)); } while (0)
#elif defined(PACKFN)
- #define PACK(CTX,T,FROM,TO,STRIDE) \
+ #define PACK(CTX,T,FROM,TO,STRIDE,AL) \
do { (TO) = PACKFN((CTX),(T),(FROM),(TO),(STRIDE)); } while (0)
#elif defined(XFORM_FLOAT)
- #define PACK(CTX,T,FROM,TO,STRIDE) \
+ #define PACK(CTX,T,FROM,TO,STRIDE,AL) \
do { (TO) = (T)->ToOutputFloat((CTX),(T),(FROM),(TO),(STRIDE)); } while (0)
#else
- #define PACK(CTX,T,FROM,TO,STRIDE) \
+ #define PACK(CTX,T,FROM,TO,STRIDE,AL) \
do { (TO) = (T)->ToOutput((CTX),(T),(FROM),(TO),(STRIDE)); } while (0)
#endif
-#if defined(NO_PACK) && !defined(COPY_MATCHED)
+#ifndef ZEROPACK
+/* The 'default' definition of ZEROPACK only works when
+ * inpackedsamplesize == outpackedsamplesize. */
+#define ZEROPACK(CTX,T,TO,FROM) do { \
+ memset((TO),0,numoutchannels*outpackedsamplesize);\
+ if (numextras != 0) memcpy((TO)+numoutchannels*outpackedsamplesize,\
+ (FROM)+numinchannels*inpackedsamplesize,\
+ numextras*outpackedsamplesize);\
+ (TO)+=(1+prealphaindexout)*outpackedsamplesize; } while (0)
+#endif
+
+#ifndef UNPRE
+#ifdef PREALPHA
+#else
+#define UNPRE(CTX,T,S,A) do {} while (0)
+#endif
+#endif
+
+#ifndef REPRE
+#ifdef PREALPHA
+#define REPRE(CTX,T,S,A) do { int i; for (i = 0; i < numoutchannels; i++) \
+ (S)[i] = mul65535((S)[i],A); } while (0)
+#else
+#define REPRE(CTX,T,S,A) do {} while (0)
+#endif
+#endif
+
+#ifndef XFORMVARS
+#define XFORMVARS(p) do { } while (0)
+#endif
+
+#if defined(NUMOUTCHANNELS)
+ #ifdef XFORM_FLOAT
+ #define OUTBYTES (sizeof(cmsFloat32Number)*NUMOUTCHANNELS)
+ #else
+ #define OUTBYTES (sizeof(cmsUInt16Number)*NUMOUTCHANNELS)
+ #endif
+#endif
+
+#if defined(NO_PACK) && !defined(COPY_MATCHED) && defined(OUTBYTES)
#if (defined(XFORM_FLOAT) && OUTBYTES == 4) || OUTBYTES == 2
#define COPY_MATCHED(FROM,TO) ((TO)[0] = (FROM)[0])
#elif (defined(XFORM_FLOAT) && OUTBYTES == 8) || OUTBYTES == 4
@@ -147,11 +228,15 @@
#endif
#ifndef COPY_EXTRAS
- #ifdef EXTRABYTES
- #if EXTRABYTES == 0
+ #ifdef NUMEXTRAS
+ #if NUMEXTRAS == 0
#define COPY_EXTRAS(TRANS,FROM,TO) do { } while (0)
#else
- #define COPY_EXTRAS(TRANS,FROM,TO) memcpy((TO),(FROM),(EXTRABYTES))
+ #define COPY_EXTRAS(TRANS,FROM,TO) \
+ do { memcpy((TO),(FROM),(NUMEXTRAS)*inpackedsamplesize); \
+ (TO) += (NUMEXTRAS)*inpackedsamplesize; \
+ (FROM) += (NUMEXTRAS)*inpackedsamplesize; \
+ } while (0)
#endif
#else
#define BULK_COPY_EXTRAS
@@ -188,6 +273,9 @@ void FUNCTION_NAME(cmsContext ContextID,
#else
XFORM_TYPE wOut[cmsMAXCHANNELS];
#endif
+#if defined(PREALPHA) && !defined(PACKINCLUDESPREALPHA)
+ XFORM_TYPE wScaled[cmsMAXCHANNELS];
+#endif
#ifdef GAMUTCHECK
_cmsPipelineEval16Fn evalGamut = core->GamutCheck->Eval16Fn;
#endif /* GAMUTCHECK */
@@ -200,10 +288,46 @@ void FUNCTION_NAME(cmsContext ContextID,
#endif
cmsUInt32Number bppi = Stride->BytesPerPlaneIn;
cmsUInt32Number bppo = Stride->BytesPerPlaneOut;
+#ifdef NUMINCHANNELS
+ int numinchannels = NUMINCHANNELS;
+#else
+ int numinchannels = T_CHANNELS(p->InputFormat);
+#endif
+#ifdef NUMOUTCHANNELS
+ int numoutchannels = NUMOUTCHANNELS;
+#else
+ int numoutchannels = T_CHANNELS(p->OutputFormat);
+#endif
+#ifdef NUMEXTRAS
+ int numextras = NUMEXTRAS;
+#else
+ int numextras = T_EXTRA(p->InputFormat);
+#endif
+#ifdef INPACKEDSAMPLESIZE
+ int inpackedsamplesize = INPACKEDSAMPLESIZE;
+#else
+ int inpackedsamplesize = T_BYTES(p->InputFormat);
+#endif
+#ifdef OUTPACKEDSAMPLESIZE
+ int outpackedsamplesize = OUTPACKEDSAMPLESIZE;
+#else
+ int outpackedsamplesize = T_BYTES(p->OutputFormat);
+#endif
+ int prealphaindexin = numinchannels + numextras - 1;
+ int prealphaindexout = numoutchannels + numextras - 1;
+ int totalinbytes = (numinchannels + numextras)*inpackedsamplesize;
+ int totaloutbytes = (numoutchannels + numextras)*outpackedsamplesize;
/* Silence some warnings */
(void)bppi;
(void)bppo;
+ (void)prealphaindexin;
+ (void)numextras;
+ (void)prealphaindexout;
+ (void)inpackedsamplesize;
+ (void)outpackedsamplesize;
+ (void)totalinbytes;
+ (void)totaloutbytes;
#ifdef BULK_COPY_EXTRAS
if (core->dwOriginalFlags & cmsFLAGS_COPY_ALPHA)
@@ -240,53 +364,111 @@ void FUNCTION_NAME(cmsContext ContextID,
currIn = (XFORM_TYPE *)accum;
#endif
while (n-- > 0) { // prevIn == CacheIn, wOut = CacheOut
- UNPACK(ContextID,p,currIn,accum,bppi);
+#ifdef PREALPHA
+ #ifdef XFORM_FLOAT
+ cmsFloat32Number alpha = ((cmsFloat32Number *)accum)[prealphaindexin];
+ #else
+ cmsUInt32Number alpha = inpackedsamplesize == 2 ?
+ ((cmsUInt16Number *)accum)[prealphaindexin] :
+ (accum[prealphaindexin]);
+ #endif
+ if (alpha == 0) {
+ ZEROPACK(ContextID,p,output,accum);
+ accum += inpackedsamplesize*(prealphaindexin+1);
+ } else {
+#endif
+ UNPACK(ContextID,p,currIn,accum,bppi,alpha);
+#ifdef PREALPHA
+ #ifndef UNPACKINCLUDESPREALPHA
+ #ifdef XFORM_FLOAT
+ {
+ int i;
+ cmsFloat32Number inva = 1.0f / alpha;
+ for (i = 0; i < numinchannels; i++)
+ currIn[i] *= inva;
+ }
+ #else
+ {
+ int i;
+ cmsUInt32Number al = inpackedsamplesize == 1 ? alpha*0x101 : alpha;
+ cmsUInt32Number inva = 0xffff0000U / al;
+ for (i = 0; i < numinchannels; i++)
+ currIn[i] = ((currIn[i] * inva)>>16);
+ }
+ #endif
+ #endif
+#endif
#ifdef CACHED
- if (COMPARE(currIn, prevIn))
+ if (COMPARE(currIn, prevIn))
#endif /* CACHED */
- {
+ {
#ifdef GAMUTCHECK
#ifdef XFORM_FLOAT
- cmsFloat32Number OutOfGamut;
+ cmsFloat32Number OutOfGamut;
- // Evaluate gamut marker.
- cmsPipelineEvalFloat(currIn, &OutOfGamut, core->GamutCheck);
+ // Evaluate gamut marker.
+ cmsPipelineEvalFloat(currIn, &OutOfGamut, core->GamutCheck);
- // Is current color out of gamut?
- if (OutOfGamut > 0.0)
- // Certainly, out of gamut
- for (j=0; j < cmsMAXCHANNELS; j++)
- fOut[j] = -1.0;
- else
+ // Is current color out of gamut?
+ if (OutOfGamut > 0.0)
+ // Certainly, out of gamut
+ for (j=0; j < cmsMAXCHANNELS; j++)
+ fOut[j] = -1.0;
+ else
#else
- cmsUInt16Number wOutOfGamut;
+ cmsUInt16Number wOutOfGamut;
- evalGamut(ContextID, currIn, &wOutOfGamut, core->GamutCheck->Data);
- if (wOutOfGamut >= 1)
- /* RJW: Could be faster? copy once to a local buffer? */
- cmsGetAlarmCodes(ContextID, wOut);
- else
+ evalGamut(ContextID, currIn, &wOutOfGamut, core->GamutCheck->Data);
+ if (wOutOfGamut >= 1)
+ /* RJW: Could be faster? copy once to a local buffer? */
+ cmsGetAlarmCodes(ContextID, wOut);
+ else
#endif /* FLOAT_XFORM */
#endif /* GAMUTCHECK */
- eval(ContextID, currIn, wOut, data);
+ eval(ContextID, currIn, wOut, data);
#ifdef NO_UNPACK
#ifdef CACHED
- prevIn = currIn;
+ prevIn = currIn;
#endif
- currIn = (XFORM_TYPE *)(((char *)currIn) + INBYTES);
+ currIn = (XFORM_TYPE *)(((char *)currIn) + totalinbytes);
#else
#ifdef CACHED
- {XFORM_TYPE *tmp = currIn; currIn = prevIn; prevIn = tmp;} // SWAP
+ {XFORM_TYPE *tmp = currIn; currIn = prevIn; prevIn = tmp;} // SWAP
#endif /* CACHED */
#endif /* NO_UNPACK */
- }
+ }
#ifdef NO_PACK
- else
- COPY_MATCHED(prevOut,wOut);
- prevOut = wOut;
+ else
+ COPY_MATCHED(prevOut,wOut);
+ prevOut = wOut;
+#endif
+#ifdef PREALPHA
+ #ifndef PACKINCLUDESPREALPHA
+ #ifdef XFORM_FLOAT
+ {
+ int i;
+ for (i = 0; i < numoutchannels; i++)
+ wScaled = wOut[i] * alpha;
+ }
+ #else
+ {
+ int i;
+ cmsUInt32Number al = inpackedsamplesize == 1 ? alpha*0x101 : alpha;
+ for (i = 0; i < numoutchannels; i++)
+ wScaled[i] = mul65535(wOut[i],al);
+ }
+ #endif
+ PACK(ContextID,p,wScaled,output,bppo,alpha);
+ #else
+ PACK(ContextID,p,wOut,output,bppo,alpha);
+ #endif
+#else
+ PACK(ContextID,p,wOut,output,bppo,alpha);
+#endif
+ COPY_EXTRAS(p,accum,output);
+#ifdef PREALPHA
+ }
#endif
- PACK(ContextID,p,wOut,output,bppo);
- COPY_EXTRAS(p,accum,output);
} /* End x loop */
in = (void *)((cmsUInt8Number *)in + Stride->BytesPerLineIn);
out = (void *)((cmsUInt8Number *)out + Stride->BytesPerLineOut);
@@ -296,7 +478,7 @@ void FUNCTION_NAME(cmsContext ContextID,
#if 0
#ifdef CACHED
#ifdef NO_UNPACK
- memcpy(p->Cache.CacheIn,prevIn,INBYTES);
+ memcpy(p->Cache.CacheIn,prevIn, CMPBYTES);
#else
memcpy(p->Cache.CacheIn, prevIn, sizeof(XFORM_TYPE) * cmsMAXCHANNELS);
#endif
@@ -316,7 +498,7 @@ void FUNCTION_NAME(cmsContext ContextID,
#undef FUNCTION_NAME
#undef COMPARE
-#undef INBYTES
+#undef CMPBYTES
#undef OUTBYTES
#undef UNPACK
#undef NO_UNPACK
@@ -330,3 +512,13 @@ void FUNCTION_NAME(cmsContext ContextID,
#undef EXTRABYTES
#undef COPY_EXTRAS
#undef BULK_COPY_EXTRAS
+#undef PREALPHA
+#undef ZEROPACK
+#undef XFORMVARS
+#undef UNPRE
+#undef REPRE
+#undef INPACKEDSAMPLESIZE
+#undef OUTPACKEDSAMPLESIZE
+#undef NUMINCHANNELS
+#undef NUMOUTCHANNELS
+#undef NUMEXTRAS
diff --git a/lcms2mt/src/lcms2_internal.h b/lcms2mt/src/lcms2_internal.h
index da205ebf..504393e2 100644
--- a/lcms2mt/src/lcms2_internal.h
+++ b/lcms2mt/src/lcms2_internal.h
@@ -1120,5 +1120,8 @@ void _cmsFindFormatter(_cmsTRANSFORM* p, cmsUInt32Number InputFormat, cmsUInt32N
cmsUInt32Number _cmsAdjustReferenceCount(cmsUInt32Number *rc, int delta);
+// thread-safe gettime
+cmsBool _cmsGetTime(struct tm* ptr_time);
+
#define _lcms_internal_H
#endif
diff --git a/lcms2mt/testbed/Makefile.in b/lcms2mt/testbed/Makefile.in
index 5ad60a7d..98b7449b 100644
--- a/lcms2mt/testbed/Makefile.in
+++ b/lcms2mt/testbed/Makefile.in
@@ -238,6 +238,7 @@ LIB_ZLIB = @LIB_ZLIB@
LIPO = @LIPO@
LN_S = @LN_S@
LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
MAINT = @MAINT@
MAKEINFO = @MAKEINFO@
MANIFEST_TOOL = @MANIFEST_TOOL@
diff --git a/lcms2mt/testbed/new.icc b/lcms2mt/testbed/new.icc
index bd90c3dc..53b3505c 100644
--- a/lcms2mt/testbed/new.icc
+++ b/lcms2mt/testbed/new.icc
Binary files differ
diff --git a/lcms2mt/testbed/testcms2.c b/lcms2mt/testbed/testcms2.c
index 87c3d460..d88120cf 100644
--- a/lcms2mt/testbed/testcms2.c
+++ b/lcms2mt/testbed/testcms2.c
@@ -1,7 +1,7 @@
//---------------------------------------------------------------------------------
//
// Little Color Management System
-// Copyright (c) 1998-2020 Marti Maria Saguer
+// Copyright (c) 1998-2021 Marti Maria Saguer
//
// Permission is hereby granted, free of charge, to any person obtaining
// a copy of this software and associated documentation files (the "Software"),
@@ -3769,7 +3769,7 @@ static
cmsInt32Number CreateNamedColorProfile(cmsContext ContextID)
{
// Color list database
- cmsNAMEDCOLORLIST* colors = cmsAllocNamedColorList(ContextID, 0, 10, 4, "PANTONE", "TCX");
+ cmsNAMEDCOLORLIST* colors = cmsAllocNamedColorList(ContextID, 10, 4, "PANTONE", "TCX");
// Containers for names
cmsMLU* DescriptionMLU, *CopyrightMLU;
@@ -3799,7 +3799,7 @@ cmsInt32Number CreateNamedColorProfile(cmsContext ContextID)
cmsWriteTag(ContextID, hProfile, cmsSigCopyrightTag, CopyrightMLU);
// Set the media white point
- cmsWriteTag(ContextID, hProfile, cmsSigMediaWhitePointTag, cmsD50_XYZ());
+ cmsWriteTag(ContextID, hProfile, cmsSigMediaWhitePointTag, cmsD50_XYZ(ContextID));
// Populate one value, Colorant = CMYK values in 16 bits, PCS[] = Encoded Lab values (in V2 format!!)
@@ -8236,30 +8236,200 @@ int CheckEmptyMLUC(cmsContext context)
cmsToneCurve* toneCurve = cmsBuildParametricToneCurve(context, 1, parameters);
cmsToneCurve* toneCurves[3] = { toneCurve, toneCurve, toneCurve };
- cmsHPROFILE profile = cmsCreateRGBProfileTHR(context, &white, &primaries, toneCurves);
+ cmsHPROFILE profile = cmsCreateRGBProfile(context, &white, &primaries, toneCurves);
- cmsSetLogErrorHandlerTHR(context, FatalErrorQuit);
+ cmsSetLogErrorHandler(context, FatalErrorQuit);
- cmsFreeToneCurve(toneCurve);
+ cmsFreeToneCurve(context, toneCurve);
// Set an empty copyright tag. This should log an error.
cmsMLU* mlu = cmsMLUalloc(context, 1);
- cmsMLUsetASCII(mlu, "en", "AU", "");
- cmsMLUsetWide(mlu, "en", "EN", L"");
- cmsWriteTag(profile, cmsSigCopyrightTag, mlu);
- cmsMLUfree(mlu);
+ cmsMLUsetASCII(context, mlu, "en", "AU", "");
+ cmsMLUsetWide(context, mlu, "en", "EN", L"");
+ cmsWriteTag(context, profile, cmsSigCopyrightTag, mlu);
+ cmsMLUfree(context, mlu);
// This will cause a crash after setting an empty copyright tag.
- cmsMD5computeID(profile);
+ cmsMD5computeID(context, profile);
// Cleanup
- cmsCloseProfile(profile);
- DebugMemDontCheckThis(context);
+ cmsCloseProfile(context, profile);
return 1;
}
+static
+double distance(const cmsUInt16Number* a, const cmsUInt16Number* b)
+{
+ double d1 = a[0] - b[0];
+ double d2 = a[1] - b[1];
+ double d3 = a[2] - b[2];
+
+ return sqrt(d1 * d1 + d2 * d2 + d3 * d3);
+}
+
+/**
+* In 2.12, a report suggest that the built-in sRGB has roundtrip errors that makes color to move
+* when rountripping again and again
+*/
+static
+int Check_sRGB_Rountrips(cmsContext contextID)
+{
+ cmsUInt16Number rgb[3], seed[3];
+ cmsCIELab Lab;
+ int i, r, g, b;
+ double err, maxErr;
+ cmsHPROFILE hsRGB = cmsCreate_sRGBProfile(contextID);
+ cmsHPROFILE hLab = cmsCreateLab4Profile(contextID, NULL);
+
+ cmsHTRANSFORM hBack = cmsCreateTransform(contextID, hLab, TYPE_Lab_DBL, hsRGB, TYPE_RGB_16, INTENT_RELATIVE_COLORIMETRIC, 0);
+ cmsHTRANSFORM hForth = cmsCreateTransform(contextID, hsRGB, TYPE_RGB_16, hLab, TYPE_Lab_DBL, INTENT_RELATIVE_COLORIMETRIC, 0);
+
+ cmsCloseProfile(contextID, hLab);
+ cmsCloseProfile(contextID, hsRGB);
+
+ maxErr = 0.0;
+ for (r = 0; r <= 255; r += 16)
+ for (g = 0; g <= 255; g += 16)
+ for (b = 0; b <= 255; b += 16)
+ {
+ seed[0] = rgb[0] = ((r << 8) | r);
+ seed[1] = rgb[1] = ((g << 8) | g);
+ seed[2] = rgb[2] = ((b << 8) | b);
+
+ for (i = 0; i < 50; i++)
+ {
+ cmsDoTransform(contextID, hForth, rgb, &Lab, 1);
+ cmsDoTransform(contextID, hBack, &Lab, rgb, 1);
+ }
+
+ err = distance(seed, rgb);
+
+ if (err > maxErr)
+ maxErr = err;
+ }
+
+
+ cmsDeleteTransform(contextID, hBack);
+ cmsDeleteTransform(contextID, hForth);
+
+ if (maxErr > 20.0)
+ {
+ printf("Maximum sRGB roundtrip error %f!\n", maxErr);
+ return 0;
+ }
+
+ return 1;
+}
+
+static
+cmsHPROFILE createRgbGamma(cmsContext contextID, cmsFloat64Number g)
+{
+ cmsCIExyY D65 = { 0.3127, 0.3290, 1.0 };
+ cmsCIExyYTRIPLE Rec709Primaries = {
+ {0.6400, 0.3300, 1.0},
+ {0.3000, 0.6000, 1.0},
+ {0.1500, 0.0600, 1.0}
+ };
+ cmsToneCurve* Gamma[3];
+ cmsHPROFILE hRGB;
+
+ Gamma[0] = Gamma[1] = Gamma[2] = cmsBuildGamma(contextID, g);
+ if (Gamma[0] == NULL) return NULL;
+
+ hRGB = cmsCreateRGBProfile(contextID, &D65, &Rec709Primaries, Gamma);
+ cmsFreeToneCurve(contextID, Gamma[0]);
+ return hRGB;
+}
+
+
+static
+int CheckGammaSpaceDetection(cmsContext contextID)
+{
+ cmsFloat64Number i;
+
+ for (i = 0.5; i < 3; i += 0.1)
+ {
+ cmsHPROFILE hProfile = createRgbGamma(contextID, i);
+
+ cmsFloat64Number gamma = cmsDetectRGBProfileGamma(contextID, hProfile, 0.01);
+
+ cmsCloseProfile(contextID, hProfile);
+
+ if (fabs(gamma - i) > 0.1)
+ {
+ Fail("Failed profile gamma detection of %f (got %f)", i, gamma);
+ return 0;
+ }
+ }
+
+ return 1;
+}
+
+
+#if 0
+
+// You need to download folowing profilies to execute this test: sRGB-elle-V4-srgbtrc.icc, sRGB-elle-V4-g10.icc
+// The include this line in the checks list: Check("KInear spaces detection", CheckLinearSpacesOptimization);
+static
+void uint16toFloat(cmsUInt16Number* src, cmsFloat32Number* dst)
+{
+ for (int i = 0; i < 3; i++) {
+ dst[i] = src[i] / 65535.f;
+ }
+}
+
+static
+int CheckLinearSpacesOptimization(cmsContext contextID)
+{
+ cmsHPROFILE lcms_sRGB = cmsCreate_sRGBProfile(contextID);
+ cmsHPROFILE elle_sRGB = cmsOpenProfileFromFile(contextID, "sRGB-elle-V4-srgbtrc.icc", "r");
+ cmsHPROFILE elle_linear = cmsOpenProfileFromFile(contextID, "sRGB-elle-V4-g10.icc", "r");
+ cmsHTRANSFORM transform1 = cmsCreateTransform(contextID, elle_sRGB, TYPE_RGB_16, elle_linear, TYPE_RGB_16, INTENT_RELATIVE_COLORIMETRIC, 0);
+ cmsHTRANSFORM transform2 = cmsCreateTransform(contextID, elle_linear, TYPE_RGB_16, lcms_sRGB, TYPE_RGB_16, INTENT_RELATIVE_COLORIMETRIC, 0);
+ cmsHTRANSFORM transform2a = cmsCreateTransform(contextID, elle_linear, TYPE_RGB_FLT, lcms_sRGB, TYPE_RGB_16, INTENT_RELATIVE_COLORIMETRIC, 0);
+
+ cmsUInt16Number sourceCol[3] = { 43 * 257, 27 * 257, 6 * 257 };
+ cmsUInt16Number linearCol[3] = { 0 };
+ float linearColF[3] = { 0 };
+ cmsUInt16Number finalCol[3] = { 0 };
+ int difR, difG, difB;
+ int difR2, difG2, difB2;
+
+ cmsDoTransform(contextID, transform1, sourceCol, linearCol, 1);
+ cmsDoTransform(contextID, transform2, linearCol, finalCol, 1);
+
+ cmsCloseProfile(contextID, lcms_sRGB); cmsCloseProfile(contextID, elle_sRGB); cmsCloseProfile(contextID, elle_linear);
+
+
+ difR = (int)sourceCol[0] - finalCol[0];
+ difG = (int)sourceCol[1] - finalCol[1];
+ difB = (int)sourceCol[2] - finalCol[2];
+
+
+ uint16toFloat(linearCol, linearColF);
+ cmsDoTransform(contextID, transform2a, linearColF, finalCol, 1);
+
+ difR2 = (int)sourceCol[0] - finalCol[0];
+ difG2 = (int)sourceCol[1] - finalCol[1];
+ difB2 = (int)sourceCol[2] - finalCol[2];
+
+ cmsDeleteTransform(contextID, transform1);
+ cmsDeleteTransform(contextID, transform2);
+ cmsDeleteTransform(contextID, transform2a);
+
+ if (abs(difR2 - difR) > 5 || abs(difG2 - difG) > 5 || abs(difB2 - difB) > 5)
+ {
+ Fail("Linear detection failed");
+ return 0;
+ }
+
+ return 1;
+}
+#endif
+
+
// --------------------------------------------------------------------------------------------------
// P E R F O R M A N C E C H E C K S
// --------------------------------------------------------------------------------------------------
@@ -9199,6 +9369,8 @@ int main(int argc, char* argv[])
Check(ctx, "Forged MPE profile", CheckForgedMPE);
Check(ctx, "Proofing intersection", CheckProofingIntersection);
Check(ctx, "Empty MLUC", CheckEmptyMLUC);
+ Check(ctx, "sRGB round-trips", Check_sRGB_Rountrips);
+ Check(ctx, "Gamma space detection", CheckGammaSpaceDetection);
}
if (DoPluginTests)
diff --git a/lcms2mt/utils/delphi/lcms2dll.pas b/lcms2mt/utils/delphi/lcms2dll.pas
index 9af7a0d1..9368fc92 100644
--- a/lcms2mt/utils/delphi/lcms2dll.pas
+++ b/lcms2mt/utils/delphi/lcms2dll.pas
@@ -3,7 +3,7 @@
//---------------------------------------------------------------------------------
//
// Little Color Management System
-// Copyright (c) 1998-2014 Marti Maria Saguer
+// Copyright (c) 1998-2021 Marti Maria Saguer
//
// Permission is hereby granted, free of charge, to any person obtaining
// a copy of this software and associated documentation files (the "Software"),
@@ -25,7 +25,7 @@
//
//---------------------------------------------------------------------------------
//
-// Version 2.6
+// Version 2.13
//
UNIT lcms2dll;
@@ -1659,6 +1659,9 @@ FUNCTION cmsDetectDestinationBlackPoint( BlackPoint: LPcmsCIEXYZ; hProfile: cmsH
// Estimate total area coverage
FUNCTION cmsDetectTAC(hProfile: cmsHPROFILE): cmsFloat64Number; StdCall;
+// Estimate profile gamma
+FUNCTION cmsDetectRGBProfileGamma(hProfile: cmsHPROFILE): cmsFloat64Number; StdCall;
+
// Poor man's gamut mapping
FUNCTION cmsDesaturateLab(Lab: LPcmsCIELab; amax, amin, bmax, bmin: cmsFloat64Number): cmsBool; StdCall;
diff --git a/lcms2mt/utils/jpgicc/Makefile.in b/lcms2mt/utils/jpgicc/Makefile.in
index 3d27bddc..e5f805f9 100644
--- a/lcms2mt/utils/jpgicc/Makefile.in
+++ b/lcms2mt/utils/jpgicc/Makefile.in
@@ -272,6 +272,7 @@ LIB_ZLIB = @LIB_ZLIB@
LIPO = @LIPO@
LN_S = @LN_S@
LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
MAINT = @MAINT@
MAKEINFO = @MAKEINFO@
MANIFEST_TOOL = @MANIFEST_TOOL@
diff --git a/lcms2mt/utils/jpgicc/jpgicc.c b/lcms2mt/utils/jpgicc/jpgicc.c
index 00ac7aea..d03a79b5 100644
--- a/lcms2mt/utils/jpgicc/jpgicc.c
+++ b/lcms2mt/utils/jpgicc/jpgicc.c
@@ -274,7 +274,7 @@ cmsHPROFILE CreatePCS2ITU_ICC(void)
#define PS_FIXED_TO_FLOAT(h, l) ((float) (h) + ((float) (l)/(1<<16)))
static
-cmsBool ProcessPhotoshopAPP13(JOCTET FAR *data, int datalen)
+cmsBool ProcessPhotoshopAPP13(JOCTET *data, int datalen)
{
int i;
@@ -299,6 +299,8 @@ cmsBool ProcessPhotoshopAPP13(JOCTET FAR *data, int datalen)
len = ((((GETJOCTET(data[i]<<8) + GETJOCTET(data[i+1]))<<8) +
GETJOCTET(data[i+2]))<<8) + GETJOCTET(data[i+3]);
+ if (len < 0) return FALSE; // Keep bug hunters away
+
i += 4; // Size
if (type == 0x03ED && len >= 16) {
@@ -330,7 +332,7 @@ cmsBool HandlePhotoshopAPP13(jpeg_saved_marker_ptr ptr)
if (ptr -> marker == (JPEG_APP0 + 13) && ptr -> data_length > 9)
{
- JOCTET FAR* data = ptr -> data;
+ JOCTET* data = ptr -> data;
if(GETJOCTET(data[0]) == 0x50 &&
GETJOCTET(data[1]) == 0x68 &&
@@ -363,45 +365,62 @@ typedef unsigned int uint32_t;
#define YRESOLUTION 0x011b
#define RESOLUTION_UNIT 0x128
+// Abort if crafted file
+static
+void craftedFile(void)
+{
+ FatalError("Corrupted EXIF data");
+}
+
// Read a 16-bit word
static
-uint16_t read16(uint8_t* arr, int pos, int swapBytes)
+uint16_t read16(uint8_t* arr, size_t pos, int swapBytes, size_t max)
{
- uint8_t b1 = arr[pos];
- uint8_t b2 = arr[pos+1];
+ if (pos + 2 >= max)
+ {
+ craftedFile();
+ return 0;
+ }
+ else
+ {
+ uint8_t b1 = arr[pos];
+ uint8_t b2 = arr[pos + 1];
- return (swapBytes) ? ((b2 << 8) | b1) : ((b1 << 8) | b2);
+ return (swapBytes) ? ((b2 << 8) | b1) : ((b1 << 8) | b2);
+ }
}
// Read a 32-bit word
static
-uint32_t read32(uint8_t* arr, int pos, int swapBytes)
+uint32_t read32(uint8_t* arr, size_t pos, int swapBytes, size_t max)
{
- if(!swapBytes) {
-
- return (arr[pos] << 24) |
- (arr[pos+1] << 16) |
- (arr[pos+2] << 8) |
- arr[pos+3];
+ if (pos + 4 >= max)
+ {
+ craftedFile();
+ return 0;
}
+ else
+ {
+ if (!swapBytes) {
- return arr[pos] |
- (arr[pos+1] << 8) |
- (arr[pos+2] << 16) |
- (arr[pos+3] << 24);
+ return (arr[pos] << 24) | (arr[pos + 1] << 16) | (arr[pos + 2] << 8) | arr[pos + 3];
+ }
+
+ return arr[pos] | (arr[pos + 1] << 8) | (arr[pos + 2] << 16) | (arr[pos + 3] << 24);
+ }
}
static
-int read_tag(uint8_t* arr, int pos, int swapBytes, void* dest)
+int read_tag(uint8_t* arr, int pos, int swapBytes, void* dest, size_t max)
{
// Format should be 5 over here (rational)
- uint32_t format = read16(arr, pos + 2, swapBytes);
+ uint32_t format = read16(arr, pos + 2, swapBytes, max);
// Components should be 1
- uint32_t components = read32(arr, pos + 4, swapBytes);
+ uint32_t components = read32(arr, pos + 4, swapBytes, max);
// Points to the value
uint32_t offset;
@@ -411,20 +430,20 @@ int read_tag(uint8_t* arr, int pos, int swapBytes, void* dest)
if (format == 3)
offset = pos + 8;
else
- offset = read32(arr, pos + 8, swapBytes);
+ offset = read32(arr, pos + 8, swapBytes, max);
switch (format) {
case 5: // Rational
{
- double num = read32(arr, offset, swapBytes);
- double den = read32(arr, offset + 4, swapBytes);
+ double num = read32(arr, offset, swapBytes, max);
+ double den = read32(arr, offset + 4, swapBytes, max);
*(double *) dest = num / den;
}
break;
case 3: // uint 16
- *(int*) dest = read16(arr, offset, swapBytes);
+ *(int*) dest = read16(arr, offset, swapBytes, max);
break;
default: return 0;
@@ -437,7 +456,7 @@ int read_tag(uint8_t* arr, int pos, int swapBytes, void* dest)
// Handler for EXIF data
static
- cmsBool HandleEXIF(struct jpeg_decompress_struct* cinfo)
+cmsBool HandleEXIF(struct jpeg_decompress_struct* cinfo)
{
jpeg_saved_marker_ptr ptr;
uint32_t ifd_ofs;
@@ -450,7 +469,9 @@ static
for (ptr = cinfo ->marker_list; ptr; ptr = ptr ->next) {
if ((ptr ->marker == JPEG_APP0+1) && ptr ->data_length > 6) {
- JOCTET FAR* data = ptr -> data;
+
+ JOCTET* data = ptr -> data;
+ size_t max = ptr->data_length;
if (memcmp(data, "Exif\0\0", 6) == 0) {
@@ -459,7 +480,7 @@ static
// 8 byte TIFF header
// first two determine byte order
pos = 0;
- if (read16(data, pos, 0) == INTEL_BYTE_ORDER) {
+ if (read16(data, pos, 0, max) == INTEL_BYTE_ORDER) {
swapBytes = 1;
}
@@ -469,28 +490,28 @@ static
pos += 2;
// offset to Image File Directory (includes the previous 8 bytes)
- ifd_ofs = read32(data, pos, swapBytes);
+ ifd_ofs = read32(data, pos, swapBytes, max);
// Search the directory for resolution tags
- numEntries = read16(data, ifd_ofs, swapBytes);
+ numEntries = read16(data, ifd_ofs, swapBytes, max);
for (i=0; i < numEntries; i++) {
uint32_t entryOffset = ifd_ofs + 2 + (12 * i);
- uint32_t tag = read16(data, entryOffset, swapBytes);
+ uint32_t tag = read16(data, entryOffset, swapBytes, max);
switch (tag) {
case RESOLUTION_UNIT:
- if (!read_tag(data, entryOffset, swapBytes, &Unit)) return FALSE;
+ if (!read_tag(data, entryOffset, swapBytes, &Unit, max)) return FALSE;
break;
case XRESOLUTION:
- if (!read_tag(data, entryOffset, swapBytes, &XRes)) return FALSE;
+ if (!read_tag(data, entryOffset, swapBytes, &XRes, max)) return FALSE;
break;
case YRESOLUTION:
- if (!read_tag(data, entryOffset, swapBytes, &YRes)) return FALSE;
+ if (!read_tag(data, entryOffset, swapBytes, &YRes, max)) return FALSE;
break;
default:;
diff --git a/lcms2mt/utils/linkicc/Makefile.in b/lcms2mt/utils/linkicc/Makefile.in
index 4477c79a..b6772f7a 100644
--- a/lcms2mt/utils/linkicc/Makefile.in
+++ b/lcms2mt/utils/linkicc/Makefile.in
@@ -272,6 +272,7 @@ LIB_ZLIB = @LIB_ZLIB@
LIPO = @LIPO@
LN_S = @LN_S@
LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
MAINT = @MAINT@
MAKEINFO = @MAKEINFO@
MANIFEST_TOOL = @MANIFEST_TOOL@
diff --git a/lcms2mt/utils/matlab/howto.txt b/lcms2mt/utils/matlab/howto.txt
new file mode 100644
index 00000000..2490d3df
--- /dev/null
+++ b/lcms2mt/utils/matlab/howto.txt
@@ -0,0 +1,4 @@
+
+To compile for matlab use:
+
+mex @lcms_rsp
diff --git a/lcms2mt/utils/psicc/Makefile.in b/lcms2mt/utils/psicc/Makefile.in
index 06e6959c..0d271590 100644
--- a/lcms2mt/utils/psicc/Makefile.in
+++ b/lcms2mt/utils/psicc/Makefile.in
@@ -272,6 +272,7 @@ LIB_ZLIB = @LIB_ZLIB@
LIPO = @LIPO@
LN_S = @LN_S@
LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
MAINT = @MAINT@
MAKEINFO = @MAKEINFO@
MANIFEST_TOOL = @MANIFEST_TOOL@
diff --git a/lcms2mt/utils/tificc/Makefile.in b/lcms2mt/utils/tificc/Makefile.in
index 53bcd8b3..009654c5 100644
--- a/lcms2mt/utils/tificc/Makefile.in
+++ b/lcms2mt/utils/tificc/Makefile.in
@@ -272,6 +272,7 @@ LIB_ZLIB = @LIB_ZLIB@
LIPO = @LIPO@
LN_S = @LN_S@
LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
MAINT = @MAINT@
MAKEINFO = @MAKEINFO@
MANIFEST_TOOL = @MANIFEST_TOOL@
diff --git a/lcms2mt/utils/tificc/tificc.c b/lcms2mt/utils/tificc/tificc.c
index 9801a1c4..91687d9f 100644
--- a/lcms2mt/utils/tificc/tificc.c
+++ b/lcms2mt/utils/tificc/tificc.c
@@ -29,6 +29,14 @@
#include "tiffio.h"
#include "utils.h"
+// Fix broken libtiff 4.3.0, thanks to Bob Friesenhahn for uncovering this
+
+#if defined(HAVE_STDINT_H) && (TIFFLIB_VERSION >= 20201219)
+# undef uint16
+# define uint16 uint16_t
+# undef uint32
+# define uint32 uint32_t
+#endif /* TIFFLIB_VERSION */
// Flags
@@ -57,16 +65,15 @@ static const char* SaveEmbedded = NULL;
static
void ConsoleWarningHandler(const char* module, const char* fmt, va_list ap)
{
- char e[512] = { '\0' };
- if (module != NULL)
- strcat(strcpy(e, module), ": ");
-
- vsprintf(e+strlen(e), fmt, ap);
- strcat(e, ".");
if (Verbose) {
- fprintf(stderr, "\nWarning");
- fprintf(stderr, " %s\n", e);
+ fprintf(stderr, "Warning: ");
+
+ if (module != NULL)
+ fprintf(stderr, "[%s] ", module);
+
+ vfprintf(stderr, fmt, ap);
+ fprintf(stderr, "\n");
fflush(stderr);
}
}
@@ -74,18 +81,18 @@ void ConsoleWarningHandler(const char* module, const char* fmt, va_list ap)
static
void ConsoleErrorHandler(const char* module, const char* fmt, va_list ap)
{
- char e[512] = { '\0' };
+ if (Verbose) {
+
+ fprintf(stderr, "Error: ");
- if (module != NULL) {
- if (strlen(module) < 500)
- strcat(strcpy(e, module), ": ");
+ if (module != NULL)
+ fprintf(stderr, "[%s] ", module);
+
+ vfprintf(stderr, fmt, ap);
+ fprintf(stderr, "\n");
+ fflush(stderr);
}
- vsprintf(e+strlen(e), fmt, ap);
- strcat(e, ".");
- fprintf(stderr, "\nError");
- fprintf(stderr, " %s\n", e);
- fflush(stderr);
}
@@ -96,7 +103,7 @@ void Warning(const char *frm, ...)
va_list args;
va_start(args, frm);
- ConsoleWarningHandler("[tificc]", frm, args);
+ ConsoleWarningHandler("tificc", frm, args);
va_end(args);
}
@@ -304,6 +311,8 @@ cmsUInt32Number GetInputPixelType(TIFF *Bank)
case PHOTOMETRIC_RGB:
pt = PT_RGB;
+ if (ColorChannels < 3)
+ FatalError("Sorry, RGB needs at least 3 samples per pixel");
break;
@@ -312,7 +321,6 @@ cmsUInt32Number GetInputPixelType(TIFF *Bank)
break;
case PHOTOMETRIC_SEPARATED:
-
pt = PixelTypeFromChanCount(ColorChannels);
break;
@@ -409,6 +417,9 @@ int TileBasedXform(cmsContext ContextID, cmsHTRANSFORM hXForm, TIFF* in, TIFF* o
BufferIn + (j*BufSizeIn), BufSizeIn) < 0) goto cleanup;
}
+ if (PixelCount < 0)
+ FatalError("TIFF is corrupted");
+
cmsDoTransform(ContextID, hXForm, BufferIn, BufferOut, PixelCount);
for (j=0; j < nPlanes; j++) {
@@ -477,6 +488,9 @@ int StripBasedXform(cmsContext ContextID, cmsHTRANSFORM hXForm, TIFF* in, TIFF*
PixelCount = (int) sw * (iml < sl ? iml : sl);
iml -= sl;
+ if (PixelCount < 0)
+ FatalError("TIFF is corrupted");
+
cmsDoTransform(ContextID, hXForm, BufferIn, BufferOut, PixelCount);
for (j=0; j < nPlanes; j++) {
@@ -1141,8 +1155,8 @@ int main(int argc, char* argv[])
TIFF *in, *out;
- fprintf(stderr, "Little CMS ICC profile applier for TIFF - v6.3 [LittleCMS %2.2f]\n\n", LCMS_VERSION / 1000.0);
- fprintf(stderr, "Copyright (c) 1998-2020 Marti Maria Saguer. See COPYING file for details.\n");
+ fprintf(stderr, "Little CMS ICC profile applier for TIFF - v6.4 [LittleCMS %2.2f]\n\n", LCMS_VERSION / 1000.0);
+ fprintf(stderr, "Copyright (c) 1998-2021 Marti Maria Saguer. See COPYING file for details.\n");
fflush(stderr);
ContextID = cmsCreateContext(NULL, NULL);
diff --git a/lcms2mt/utils/transicc/Makefile.in b/lcms2mt/utils/transicc/Makefile.in
index f3e029b5..7e2d1fb8 100644
--- a/lcms2mt/utils/transicc/Makefile.in
+++ b/lcms2mt/utils/transicc/Makefile.in
@@ -272,6 +272,7 @@ LIB_ZLIB = @LIB_ZLIB@
LIPO = @LIPO@
LN_S = @LN_S@
LTLIBOBJS = @LTLIBOBJS@
+LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@
MAINT = @MAINT@
MAKEINFO = @MAKEINFO@
MANIFEST_TOOL = @MANIFEST_TOOL@
diff --git a/lib/PDFA_def.ps b/lib/PDFA_def.ps
index f77c90ef..c5e2aa68 100644
--- a/lib/PDFA_def.ps
+++ b/lib/PDFA_def.ps
@@ -35,13 +35,13 @@ def
/CMYK eq {
/N 4 false
}{
- (ColorConversionStrategy not a device space, falling back to ProcessColorModel, output may not be valid PDF/A.)=
+ (\tColorConversionStrategy not a device space, falling back to ProcessColorModel, output may not be valid PDF/A.\n)=
true
} ifelse
} ifelse
} ifelse
} {
- (ColorConversionStrategy not set, falling back to ProcessColorModel, output may not be valid PDF/A.)=
+ (\tColorConversionStrategy not set, falling back to ProcessColorModel, output may not be valid PDF/A.\n)=
true
} ifelse
@@ -56,7 +56,7 @@ def
dup /DeviceCMYK eq {
pop /N 4
} {
- (ProcessColorModel not a device space.)=
+ (\tProcessColorModel not a device space.)=
/ProcessColorModel cvx /rangecheck signalerror
} ifelse
} ifelse
@@ -65,15 +65,27 @@ def
%% ----------8<--------------8<-------------8<--------------8<----------
>> /PUT pdfmark
-[{icc_PDFA} ICCProfile (r) file /PUT pdfmark
+[
+{icc_PDFA}
+{ICCProfile (r) file} stopped
+{
+ (\n\tFailed to open the supplied ICCProfile for reading. This may be due to\n) print
+ (\t an incorrect filename or a failure to add --permif-file-read=<profile>\n) print
+ (\t to the command line. This PostScript program needs to open the file\n) print
+ (\t and you must explicitly grant it permission to do so.\n\n) print
+ (\tPDF/A processing aborted, output may not be a PDF/A file.\n\n) print
+ cleartomark
+}
+{
+ /PUT pdfmark
+ % Define the output intent dictionary :
-% Define the output intent dictionary :
-
-[/_objdef {OutputIntent_PDFA} /type /dict /OBJ pdfmark
-[{OutputIntent_PDFA} <<
- /Type /OutputIntent % Must be so (the standard requires).
- /S /GTS_PDFA1 % Must be so (the standard requires).
- /DestOutputProfile {icc_PDFA} % Must be so (see above).
- /OutputConditionIdentifier (sRGB) % Customize
->> /PUT pdfmark
-[{Catalog} <</OutputIntents [ {OutputIntent_PDFA} ]>> /PUT pdfmark
+ [/_objdef {OutputIntent_PDFA} /type /dict /OBJ pdfmark
+ [{OutputIntent_PDFA} <<
+ /Type /OutputIntent % Must be so (the standard requires).
+ /S /GTS_PDFA1 % Must be so (the standard requires).
+ /DestOutputProfile {icc_PDFA} % Must be so (see above).
+ /OutputConditionIdentifier (sRGB) % Customize
+ >> /PUT pdfmark
+ [{Catalog} <</OutputIntents [ {OutputIntent_PDFA} ]>> /PUT pdfmark
+} ifelse
diff --git a/lib/ghostpdf.cat b/lib/ghostpdf.cat
index 4c6fc304..ec51696f 100644
--- a/lib/ghostpdf.cat
+++ b/lib/ghostpdf.cat
Binary files differ
diff --git a/lib/gslp.ps b/lib/gslp.ps
index 173d52c2..9a3a2f3e 100644
--- a/lib/gslp.ps
+++ b/lib/gslp.ps
@@ -38,10 +38,13 @@
% --detect
% treat the file as PostScript if it starts with %!
% --first-page <n>
-% --duplex(|-long-edge|-short-edge)
-% use duplex if available; if not specified, select long edge
-% for portrait printing, short edge for landscape
+% --duplex(|-long-edge|-short-edge)
+% use duplex if available; if not specified, select long edge
+% for portrait printing, short edge for landscape
% start printing at page <n>
+% --encoding <encodingname> default ISOLatin1Encoding
+% Note this only takes effect during -f or -F option thus the
+% body text and header text can use different encodings.
% --kern <file.afm>
% kern using information from the given .AFM file
% --last-page <n>
@@ -60,17 +63,26 @@
/lpdict 150 dict def
lpdict begin
-% build iso-latin-1 version of a font
-/font-to-iso-latin-1 { % <font> font-to-iso-latin-1 <font>
+/encoding /ISOLatin1Encoding def % the default encoding
+
+% build a version of the font with the requested encoding (default ISOLatin1)
+/font-to-encoding { % <font> font-to-encoding <font>
%% reencode for iso latin1; from the 2nd edition red book, sec 5.6.1
dup length dict begin {1 index /FID ne {def} {pop pop} ifelse} forall
- /Encoding ISOLatin1Encoding def currentdict end
- dup /FontName get 80 string cvs (-ISOLatin1) concatstrings cvn
+ /Encoding encoding /Encoding findresource readonly def
+ currentdict end
+ % strip off the "Encoding" part of the encoding (if present)
+ dup /FontName get 80 string cvs
+ encoding 256 string cvs (Encoding) search {
+ exch pop exch pop
+ } if
+ exch (-) concatstrings exch
+ concatstrings cvn
exch definefont
} def
/find-latin-font { % <name> find-latin-font <font>
- findfont font-to-iso-latin-1
+ findfont font-to-encoding
} def
% Define the initial values of the printing parameters.
@@ -275,14 +287,17 @@ lpdict begin
/StringTAB (\t) def
/CharTAB StringTAB 0 get def
-/showline % line -> leftover_line (handles \f)
- { { showline1 dup length 0 eq { exit } if
- dup 0 get CharFF ne { exit } if
+/showline { % line -> leftover_line (handles \f)
+ { showline1 dup length 0 eq { exit } if
+ dup 0 get CharFF ne {
+ Truncate { pop () } if
+ exit
+ } if
EjectFF { endpage beginpage } { endcolumn } ifelse
skip1
- }
+ }
loop
- } def
+} def
/showline1 % line -> leftover_line (handles page break)
{ lindex llength eq { endpage beginpage } if
@@ -409,9 +424,9 @@ lpdict begin
/S {currentfile =string readline pop show} lpdef
/RE { % <isoname> <fontname> RE <font>
findfont
- %% reencode for iso latin1; from the 2nd edition red book, sec 5.6.1
+ %% reencode for current 'encoding' from the 2nd edition red book, sec 5.6.1
dup length dict begin {1 index /FID ne {def} {pop pop} ifelse} forall
- /Encoding ISOLatin1Encoding def currentdict end
+ /Encoding encoding def currentdict end
definefont
} lpdef
} def
@@ -506,24 +521,31 @@ lpdict begin
% Iterate through the file.
lpline
- { dup length /pos exch def
- lbuf exch 0 exch putinterval
- { lpfile lbuf pos lbuf length pos sub getinterval readline } stopped
- { % Filled the line before a CR or EOF.
- exch pop showline
- }
- { % Reached CR and/or EOF first.
+ % First handle new-lines in the initial string (--detect mode)
+ (\n) search {
+ showline % output up to the first new-line
+ pop pop % done with that string and the new-line
+ (\n) search {
+ showline % output the second new-line
+ pop pop % done
+ } if
+ } if
+ { dup length /pos exch def
+ lbuf exch 0 exch putinterval
+ { lpfile lbuf pos lbuf length pos sub getinterval readline } stopped
+ { % Filled the line before a CR or EOF.
+ exch pop showline
+ }
+ { % Reached CR and/or EOF first.
exch length pos add lbuf exch 0 exch getinterval
1 index { showline } if % omit final empty line
- { dup length 0 eq Truncate or { pop () exit } if
+ { dup length 0 eq { pop () exit } if
showline
- }
- loop
+ } loop
exch not { exit } if
- }
- ifelse
+ } ifelse
pindex PageLast gt { exit } if
- } loop
+ } loop
pop
% Wrap up.
@@ -588,6 +610,7 @@ lpdict begin
/--duplex { /Duplex {Landscape} def } def
/--duplex-long-edge { /Duplex false def } def
/--duplex-short-edge { /Duplex true def } def
+/--encoding { cvn /encoding exch def } def
/--first-page { cvi /PageFirst exch def } def
/--footing-center { /FootingCenter exch def /Footers true def } def
/--footing-left { /FootingLeft exch def /Footers true def } def
diff --git a/lib/viewgif.ps b/lib/viewgif.ps
index a261bf7e..0426e2f4 100644
--- a/lib/viewgif.ps
+++ b/lib/viewgif.ps
@@ -42,7 +42,9 @@
GlobalColor
{ PaletteSize 3 mul string readstring pop
/GlobalPalette exch def
- } if
+ } {
+ pop
+ } ifelse
currentdict end
} bind def
@@ -159,7 +161,7 @@
} bind def
% This lets you do stuff on the command line like:
-% gs -sDEVICE=pdfwrite -o stuff%03d.pdf viewgif.ps -c "(image.gif) << /PageSize 2 index viewGIFgetsize 2 array astore >> setpagedevice viewGIF"
+% gs -sDEVICE=pdfwrite -o stuff%03d.pdf viewgif.ps -c "(image.gif) << /PageSize 2 index viewGIFgetsize 2 array astore /HWResolution [ 72 72 ] >> setpagedevice viewGIF"
% so the output size is influenced by the original image.
/viewGIFgetsize % <file|string> ==> [width height]
{
diff --git a/lib/zugferd.ps b/lib/zugferd.ps
index 0320fb69..97d33d4d 100644
--- a/lib/zugferd.ps
+++ b/lib/zugferd.ps
@@ -1,3 +1,5 @@
+%!PS
+
% Copyright (C) 2001-2021 Artifex Software, Inc.
% All Rights Reserved.
%
@@ -12,38 +14,68 @@
% Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
% CA 94945, U.S.A., +1(415)492-9861, for further information.
%
-% zugferd.ps
-% This program will create an (unsigned) ZUGFeRD compliant PDF file. In
-% order to do so the user must provide certain information, or edit this program.
+% ZUGFeRD.ps
+% This program will create an (unsigned) ZUGFeRD compliant PDF file.
+% In order to do so the user must provide certain information, or edit
+% this program.
+%
+% Required information is the path to the XML file containing the invoice
+% data, and the path to an ICC profile appropriate for the chosen
+% ColorConversionStrategy.
+%
+% -sZUGFeRDXMLFile defines a path to the XML invoice file.
+%
+% -sZUGFeRDProfile defines the path to the ICC profile.
+%
+% -sZUGFeRDVersion defines the version of the ZUGFeRD standard to be used.
+% Missing or invalid values would be silently replaced by the default ("2p1").
+%
+% -sZUGFeRDConformanceLevel defines the level of conformance.
+% Missing or invalid values would be silently replaced by the default ("BASIC").
%
-% Required information is the path to the XML file containing the invoice data,
-% and the path to an ICC profile appropriate for the chosen ColorConversionStrategy.
-% -sZUGFeRDXMLFile defines a path to the XML invoice file and -sZUGFeRDProfile
-% defines the path to the ICC profile.
+% Note that the ZUGFeRD standard states:
%
-% The user must additionally set -dPDFA=3 and -sColorConversionStrategy on the
-% Ghostscript command line, and set the permissions for Ghostscript to read
-% both these files. It is simplest to put the files in a directory and then
-% permit reading of the entire directory.
+% The content of the field fx:ConformanceLevel has to be picked from
+% the content of the element "GuidelineSpecifiedDocumentContextParameter"
+% (specification identifier BT-24) of the XML instance file.
+%
+% The user must additionally set -dPDFA=3 and -sColorConversionStrategy
+% on the Ghostscript command line, and set the permissions for Ghostscript
+% to read both these files. It is simplest to put the files in a directory
+% and then permit reading of the entire directory.
%
% Example command line :
%
-% gs --permit-file-read=/usr/home/me/zugferd/ -sDEVICE=pdfwrite -dPDFA=3 -sColorConversionStrategy=RGB \
-% -sZUGFeRDXMLFile=/usr/home/me/zugferd/invoice.xml -sZUGFeRDProfile=/usr/home/me/rgb.icc \
-% -o /usr/home/me/zugferd/zugferd.pdf /usr/home/me/zugferd/zugferd.ps /usr/home/me/zugferd/original.pdf
+% gs --permit-file-read=/usr/home/me/zugferd/ \
+% -sDEVICE=pdfwrite \
+% -dPDFA=3 \
+% -sColorConversionStrategy=RGB \
+% -sZUGFeRDXMLFile=/usr/home/me/zugferd/invoice.xml \
+% -sZUGFeRDProfile=/usr/home/me/zugferd/rgb.icc \
+% -sZUGFeRDVersion=2p1 \
+% -sZUGFeRDConformanceLevel=BASIC \
+% -o /usr/home/me/zugferd/zugferd.pdf \
+% /usr/home/me/zugferd/zugferd.ps \
+% /usr/home/me/zugferd/original.pdf
%
-% Much of this program results from a Ghostscript bug report, the thread can be found at
-% https://bugs.ghostscript.com/show_bug.cgi?id=696472 Portions of the code below were
-% supplied by Reinhard Nissl and I'm indebted to him for his efforts in helping me create
-% a solution for this problem as well as for the code he supplied, particularly for the
+% Much of this program results from a Ghostscript bug report, the thread
+% can be found at
+% https://bugs.ghostscript.com/show_bug.cgi?id=696472
+% Portions of the code below were supplied by Reinhard Nissl and
+% I'm indebted to him for his efforts in helping me create a solution for
+% this problem as well as for the code he supplied, particularly for the
% SimpleUTF16BE routine.
%
-% It should not be necessary to modify this program, the comments in the code are there purely for information,
-% but there are two areas which might reasonably be altered. The section with the --8<-- lines could be replaced
-% with a simpler /N 3 or /N 4 if you always intend to produce the same kind of files; RGB or CMYK.
-% In step 7, the large XML string will need to be replaced if you want to produce a ZUGFeRD 2.1
-% file, and in future may require similar modification for later versions.
+% The program was further refined and expanded by Adrian Devries in :
+% https://bugs.ghostscript.com/show_bug.cgi?id=703862
+%
+% It should not be necessary to modify this program, the comments in the
+% code are there purely for information, but there is one area which
+% might reasonably be altered. The section with the --8<-- lines could be
+% replaced with a simpler /N 3 or /N 4 if you always intend to produce
+% the same kind of files; RGB or CMYK.
%
+% Remaining tasks have been marked with "TODO".
% istring SimpleUTF16BE ostring
/SimpleUTF16BE
@@ -52,13 +84,11 @@
1 add
2 mul
string
-
% istring ostring
dup 0 16#FE put
dup 1 16#FF put
2
3 -1 roll
-
% ostring index istring
{
% ostring index ichar
@@ -74,12 +104,246 @@
% ostring index
}
forall
-
% ostring index
pop
}
bind def
+% Cf. https://en.wikibooks.org/wiki/PostScript_FAQ#How_to_concatenate_strings%3F
+/concatstringarray { % [(a) (b) ... (z)] --> (ab...z)
+ 0 1 index {
+ length add
+ } forall
+ string
+ 0 3 2 roll {
+ 3 copy putinterval
+ length add
+ } forall
+ pop
+} bind def
+
+/ZUGFeRDVersion where {
+ pop % Discard the dictionary
+ ZUGFeRDVersion (rc) ne {
+ ZUGFeRDVersion (1p0) ne {
+ ZUGFeRDVersion (2p0) ne {
+ ZUGFeRDVersion (2p1) ne {
+ /ZUGFeRDVersion (2p1) def
+ } if
+ } if
+ } if
+ } if
+}{
+ /ZUGFeRDVersion (2p1) def
+} ifelse
+
+/ZUGFeRDConformanceLevel where {
+ pop % Discard the dictionary
+ ZUGFeRDVersion (rc) eq
+ ZUGFeRDVersion (1p0) eq or {
+ ZUGFeRDConformanceLevel (BASIC) ne {
+ ZUGFeRDConformanceLevel (COMFORT) ne {
+ ZUGFeRDConformanceLevel (EXTENDED) ne {
+ /ZUGFeRDConformanceLevel (BASIC) def
+ } if
+ } if
+ } if
+ } if
+ ZUGFeRDVersion (2p0) eq
+ ZUGFeRDVersion (2p1) eq or {
+ ZUGFeRDConformanceLevel (MINIMUM) ne {
+ ZUGFeRDConformanceLevel (BASIC WL) ne {
+ ZUGFeRDConformanceLevel (BASIC) ne {
+ ZUGFeRDConformanceLevel (EN 16931) ne {
+ ZUGFeRDConformanceLevel (EXTENDED) ne {
+ ZUGFeRDConformanceLevel (XRECHNUNG) ne {
+ /ZUGFeRDConformanceLevel (BASIC) def
+ } if
+ } if
+ } if
+ } if
+ } if
+ } if
+ } if
+}{
+ /ZUGFeRDConformanceLevel (BASIC) def
+} ifelse
+
+% ZUGFeRDSchema
+/ZUGFeRDSchema () def
+ZUGFeRDVersion (rc) eq
+ZUGFeRDVersion (1p0) eq or
+ZUGFeRDVersion (2p0) eq or {
+ /ZUGFeRDSchema (ZUGFeRD PDFA Extension Schema) def
+} if
+ZUGFeRDVersion (2p1) eq {
+ /ZUGFeRDSchema (Factur-X PDFA Extension Schema) def
+} if
+
+% ZUGFeRDNamespaceURI
+/ZUGFeRDNamespaceURI () def
+ZUGFeRDVersion (rc) eq {
+ /ZUGFeRDNamespaceURI (urn:ferd:pdfa:invoice:rc#) def
+} if
+ZUGFeRDVersion (1p0) eq {
+ /ZUGFeRDNamespaceURI (urn:ferd:pdfa:CrossIndustryDocument:invoice:1p0#) def
+} if
+ZUGFeRDVersion (2p0) eq {
+ /ZUGFeRDNamespaceURI (urn:zugferd:pdfa:CrossIndustryDocument:invoice:2p0#) def
+} if
+ZUGFeRDVersion (2p1) eq {
+ /ZUGFeRDNamespaceURI (urn:factur-x:pdfa:CrossIndustryDocument:invoice:1p0#) def
+} if
+
+% ZUGFeRDPrefix
+/ZUGFeRDPrefix () def
+ZUGFeRDVersion (rc) eq
+ZUGFeRDVersion (1p0) eq or
+ZUGFeRDVersion (2p0) eq or {
+ /ZUGFeRDPrefix (zf) def
+} if
+ZUGFeRDVersion (2p1) eq {
+ /ZUGFeRDPrefix (fx) def
+} if
+
+% ZUGFeRDVersionDescription
+/ZUGFeRDVersionDescription () def
+ZUGFeRDVersion (rc) eq
+ZUGFeRDVersion (1p0) eq or
+ZUGFeRDVersion (2p0) eq or {
+ /ZUGFeRDVersionDescription (The actual version of the ZUGFeRD XML schema) def
+} if
+ZUGFeRDVersion (2p1) eq {
+ /ZUGFeRDVersionDescription (The actual version of the Factur-X XML schema) def
+} if
+
+% ZUGFeRDConformanceLevelDescription
+/ZUGFeRDConformanceLevelDescription () def
+ZUGFeRDVersion (rc) eq
+ZUGFeRDVersion (1p0) eq or
+ZUGFeRDVersion (2p0) eq or {
+ /ZUGFeRDConformanceLevelDescription (The conformance level of the embedded ZUGFeRD data) def
+} if
+ZUGFeRDVersion (2p1) eq {
+ /ZUGFeRDConformanceLevelDescription (The conformance level of the embedded Factur-X data) def
+} if
+
+% ZUGFeRDDocumentFileName
+/ZUGFeRDDocumentFileName () def
+ZUGFeRDVersion (rc) eq {
+ /ZUGFeRDDocumentFileName (ZUGFeRD-invoice.xml) def
+} if
+ZUGFeRDVersion (1p0) eq {
+ /ZUGFeRDDocumentFileName (ZUGFeRD-invoice.xml) def
+} if
+ZUGFeRDVersion (2p0) eq {
+ ZUGFeRDConformanceLevel (XRECHNUNG) ne {
+ /ZUGFeRDDocumentFileName (zugferd-invoice.xml) def
+ }{
+ /ZUGFeRDDocumentFileName (xrechnung.xml) def
+ } ifelse
+} if
+ZUGFeRDVersion (2p1) eq {
+ ZUGFeRDConformanceLevel (XRECHNUNG) ne {
+ /ZUGFeRDDocumentFileName (factur-x.xml) def
+ }{
+ /ZUGFeRDDocumentFileName (xrechnung.xml) def
+ } ifelse
+} if
+
+% ZUGFeRDVersionData
+/ZUGFeRDVersionData () def
+ZUGFeRDVersion (rc) eq {
+ /ZUGFeRDVersionData (RC) def
+} if
+ZUGFeRDVersion (1p0) eq {
+ /ZUGFeRDVersionData (1.0) def
+} if
+ZUGFeRDVersion (2p0) eq {
+ ZUGFeRDConformanceLevel (XRECHNUNG) ne {
+ /ZUGFeRDVersionData (2p0) def
+ }{
+ /ZUGFeRDVersionData (1p2) def
+ } ifelse
+} if
+ZUGFeRDVersion (2p1) eq {
+ ZUGFeRDConformanceLevel (XRECHNUNG) ne {
+ /ZUGFeRDVersionData (1.0) def
+ }{
+ /ZUGFeRDVersionData (1p2) def
+ } ifelse
+} if
+
+/ZUGFeRDMetadata [
+(
+<rdf:Description)
+( xmlns:pdfaExtension="http://www.aiim.org/pdfa/ns/extension/")
+( xmlns:pdfaProperty="http://www.aiim.org/pdfa/ns/property#")
+( xmlns:pdfaSchema="http://www.aiim.org/pdfa/ns/schema#")
+( rdf:about="">
+ <pdfaExtension:schemas>
+ <rdf:Bag>
+ <rdf:li rdf:parseType="Resource">
+ <pdfaSchema:schema>)ZUGFeRDSchema(</pdfaSchema:schema>
+ <pdfaSchema:namespaceURI>)ZUGFeRDNamespaceURI(</pdfaSchema:namespaceURI>
+ <pdfaSchema:prefix>)ZUGFeRDPrefix(</pdfaSchema:prefix>
+ <pdfaSchema:property>
+ <rdf:Seq>
+ <rdf:li rdf:parseType="Resource">
+ <pdfaProperty:name>DocumentFileName</pdfaProperty:name>
+ <pdfaProperty:valueType>Text</pdfaProperty:valueType>
+ <pdfaProperty:category>external</pdfaProperty:category>
+ <pdfaProperty:description>Name of the embedded XML invoice file</pdfaProperty:description>
+ </rdf:li>
+ <rdf:li rdf:parseType="Resource">
+ <pdfaProperty:name>DocumentType</pdfaProperty:name>
+ <pdfaProperty:valueType>Text</pdfaProperty:valueType>
+ <pdfaProperty:category>external</pdfaProperty:category>
+ <pdfaProperty:description>INVOICE</pdfaProperty:description>
+ </rdf:li>
+ <rdf:li rdf:parseType="Resource">
+ <pdfaProperty:name>Version</pdfaProperty:name>
+ <pdfaProperty:valueType>Text</pdfaProperty:valueType>
+ <pdfaProperty:category>external</pdfaProperty:category>
+ <pdfaProperty:description>)ZUGFeRDVersionDescription(</pdfaProperty:description>
+ </rdf:li>
+ <rdf:li rdf:parseType="Resource">
+ <pdfaProperty:name>ConformanceLevel</pdfaProperty:name>
+ <pdfaProperty:valueType>Text</pdfaProperty:valueType>
+ <pdfaProperty:category>external</pdfaProperty:category>
+ <pdfaProperty:description>)ZUGFeRDConformanceLevelDescription(</pdfaProperty:description>
+ </rdf:li>
+ </rdf:Seq>
+ </pdfaSchema:property>
+ </rdf:li>
+ </rdf:Bag>
+ </pdfaExtension:schemas>
+</rdf:Description>
+<rdf:Description xmlns:)ZUGFeRDPrefix(=")ZUGFeRDNamespaceURI(" rdf:about="">
+ <)ZUGFeRDPrefix(:ConformanceLevel>)ZUGFeRDConformanceLevel(</)ZUGFeRDPrefix(:ConformanceLevel>
+ <)ZUGFeRDPrefix(:DocumentFileName>)ZUGFeRDDocumentFileName(</)ZUGFeRDPrefix(:DocumentFileName>
+ <)ZUGFeRDPrefix(:DocumentType>INVOICE</)ZUGFeRDPrefix(:DocumentType>
+ <)ZUGFeRDPrefix(:Version>)ZUGFeRDVersionData(</)ZUGFeRDPrefix(:Version>
+</rdf:Description>
+)
+ ] concatstringarray def
+
+/Usage {
+ (example usage: \n) print
+ ( gs --permit-file-read=/usr/home/me/zugferd/ \\\n) print
+ ( -sDEVICE=pdfwrite \\\n) print
+ ( -dPDFA=3 \\\n) print
+ ( -sColorConversionStrategy=RGB \\\n) print
+ ( -sZUGFeRDXMLFile=/usr/home/me/zugferd/invoice.xml \\\n) print
+ ( -sZUGFeRDProfile=/usr/home/me/zugferd\rgb.icc \\\n) print
+ ( -sZUGFeRDVersion=2p1 \\\n) print
+ ( -sZUGFeRDConformanceLevel=BASIC \\\n) print
+ ( -o /usr/home/me/zugferd/zugferd.pdf \\\n) print
+ ( /usr/home/me/zugferd/zugferd.ps \\\n) print
+ ( /usr/home/me/zugferd/original.pdf \n) print
+ flush
+} def
+
% First check that the user has defined the XML invoice file on the command line
%
/ZUGFeRDXMLFile where {
@@ -90,7 +354,9 @@ bind def
/ZUGFeRDProfile where {
pop % Discard the dictionary
- % Step 1, add the required PDF/A boilerplate. This is mostly copied from lib/pdfa_de.ps
+ % Step 1, add the required PDF/A boilerplate.
+ % This is mostly copied from lib/pdfa_def.ps
+
% Create a PDF stream object to hold the ICC profile.
[ /_objdef {icc_PDFA} /type /stream /OBJ pdfmark
@@ -157,45 +423,43 @@ bind def
/Type /OutputIntent
/S /GTS_PDFA1 % Required for PDF/A.
/DestOutputProfile {icc_PDFA} % The actual profile.
- /OutputConditionIdentifier (Custom) % A better solution is a string from the ICC Registry, but Custom is always valid.
+ /OutputConditionIdentifier (Custom) % TODO: A better solution is a
+ % a string from the ICC
+ % Registry, but Custom
+ % is always valid.
>> /PUT pdfmark
% And now add the OutputIntent to the Catalog dictionary
[ {Catalog} << /OutputIntents [ {OutputIntent_PDFA} ]>> /PUT pdfmark
-
% Step 2, define the XML file and read it into the PDF
% First we define the PDF stream to contain the XML invoice
[ /_objdef {InvoiceStream} /type /stream /OBJ pdfmark
-
% Fill in the dictionary elements we need. We believe the
% ModDate is not useful so it's just set to a valid value.
[ {InvoiceStream} <<
- /Type /EmbeddedFile
- /Subtype (text/xml) cvn
+ /Type /EmbeddedFile
+ /Subtype (text/xml) cvn
+ % TODO: Determine file length, and add /Length entry
/Params <<
- /ModDate (D:20130121081433+0100)
+ /ModDate (D:20130121081433+01'00') % TODO: Determine file date.
>>
>> /PUT pdfmark
-
% Now read the data from the file and store it in the stream
[ {InvoiceStream} ZUGFeRDXMLFile (r) file /PUT pdfmark
-
% and close the stream
[ {InvoiceStream} /CLOSE pdfmark
-
% Step 3 create the File Specification dictionary for the embedded file
% Create the dictionary
[ /_objdef {FSDict} /type /dict /OBJ pdfmark
-
% Fill in the required dictionary elements
[ {FSDict} <<
/Type /FileSpec
- /F ZUGFeRDXMLFile
- /UF ZUGFeRDXMLFile SimpleUTF16BE
+ /F ZUGFeRDDocumentFileName
+ /UF ZUGFeRDDocumentFileName SimpleUTF16BE
/Desc (ZUGFeRD electronic invoice)
- /AFRelationship /Alternative
+ /AFRelationship /Alternative
/EF <<
/F {InvoiceStream}
/UF {InvoiceStream}
@@ -203,114 +467,38 @@ bind def
>>
/PUT pdfmark
-
% Step 4 Create the Associated Files dictionary to hold the FS dict
% Create the dictionary
[ /_objdef {AFArray} /type /array /OBJ pdfmark
-
% Put (append) the FS dictionary into the Associated Files array
[ {AFArray} {FSDict} /APPEND pdfmark
-
% Step 5 Add an entry in the Catalog dictionary containing the AF array
[ {Catalog} << /AF {AFArray} >> /PUT pdfmark
-
% Step 6 use the EMBED pdfmark to add the XML file and FS dictionary to the PDF name tree
- [ /Name ZUGFeRDXMLFile /FS {FSDict} /EMBED pdfmark
-
+ [ /Name ZUGFeRDDocumentFileName /FS {FSDict} /EMBED pdfmark
% Step 7 Add the extra ZUGFeRD XML data to the Metadata
- [ /XML
-(
- <!-- XMP extension schema container for the zugferd schema -->
- <rdf:Description rdf:about=""
- xmlns:pdfaExtension="http://www.aiim.org/pdfa/ns/extension/"
- xmlns:pdfaSchema="http://www.aiim.org/pdfa/ns/schema#"
- xmlns:pdfaProperty="http://www.aiim.org/pdfa/ns/property#">
-
- <!-- Container for all embedded extension schema descriptions -->
- <pdfaExtension:schemas>
- <rdf:Bag>
- <rdf:li rdf:parseType="Resource">
- <!-- Optional description of schema -->
- <pdfaSchema:schema>ZUGFeRD PDFA Extension Schema</pdfaSchema:schema>
- <!-- Schema namespace URI -->
- <pdfaSchema:namespaceURI>urn:ferd:pdfa:invoice:rc#</pdfaSchema:namespaceURI>
- <!-- Preferred schema namespace prefix -->
- <pdfaSchema:prefix>zf</pdfaSchema:prefix>
-
- <!-- Description of schema properties -->
- <pdfaSchema:property>
- <rdf:Seq>!
- <rdf:li rdf:parseType="Resource">
- <!-- DocumentFileName: Name of the embedded file;
- must be equal with the value of the /F tag in the /EF
- structure -->
- <pdfaProperty:name>DocumentFileName</pdfaProperty:name>
- <pdfaProperty:valueType>Text</pdfaProperty:valueType>
- <pdfaProperty:category>external</pdfaProperty:category>
- <pdfaProperty:description>name of the embedded xml invoice file</pdfaProperty:description>
- </rdf:li>
- <rdf:li rdf:parseType="Resource">
- <!-- DocumentType: INVOICE -->
- <pdfaProperty:name>DocumentType</pdfaProperty:name>
- <pdfaProperty:valueType>Text</pdfaProperty:valueType>
- <pdfaProperty:category>external</pdfaProperty:category>
- <pdfaProperty:description>INVOICE</pdfaProperty:description>
- </rdf:li>
- <rdf:li rdf:parseType="Resource">
- <!-- Version: The actual version of the
- ZUGFeRD standard -->
- <pdfaProperty:name>Version</pdfaProperty:name>
- <pdfaProperty:valueType>Text</pdfaProperty:valueType>
- <pdfaProperty:category>external</pdfaProperty:category>
- <pdfaProperty:description>The actual version of the ZUGFeRD data</pdfaProperty:description>
- </rdf:li>
- <rdf:li rdf:parseType="Resource">
- <!-- ConformanceLevel: The actual conformance
- level of the ZUGFeRD standard,
- e.g. BASIC, COMFORT, EXTENDED -->
- <pdfaProperty:name>ConformanceLevel</pdfaProperty:name>
- <pdfaProperty:valueType>Text</pdfaProperty:valueType>
- <pdfaProperty:category>external</pdfaProperty:category>
- <pdfaProperty:description>The conformance level of the ZUGFeRD data</pdfaProperty:description>
- </rdf:li>
- </rdf:Seq>
- </pdfaSchema:property>
- </rdf:li>
- </rdf:Bag>
- </pdfaExtension:schemas>
- </rdf:Description>
-
- <rdf:Description rdf:about="" xmlns:zf="urn:ferd:pdfa:invoice:rc#">
- <zf:DocumentType>INVOICE</zf:DocumentType>
- <zf:DocumentFileName>ZUGFeRD-invoice.xml</zf:DocumentFileName>
- <zf:Version>RC</zf:Version>
- <zf:ConformanceLevel>BASIC</zf:ConformanceLevel>
- </rdf:Description>
-) /Ext_Metadata pdfmark
+ [ /XML ZUGFeRDMetadata /Ext_Metadata pdfmark
}
{
- % No ICC Profile definition on the command line; chide the user and give them an example
- %
- (\nERROR - ZUGFeRDProfile has not been supplied, you must supply an ICC profile\n) print
- ( Producing a potentially invalid PDF/A file!!\n) print
- (example usage - gs --permit-file-read=/usr/home/me/zugferd/ -sDEVICE=pdfwrite -dPDFA=3\\\n) print
- ( -sColorConversionStrategy=RGB -sZUGFeRDXMLFile=/usr/home/me/zugferd/invoice.xml\\\n) print
- ( -sZUGFeRDProfile=/usr/home/me/rgb.icc -o /usr/home/me/zugferd/zugferd.pdf\\\n) print
- ( /usr/home/me/zugferd/zugferd.ps /usr/home/me/zugferd/original.pdf\n\n) print flush
+ % No ICC Profile definition on the command line;
+ % chide the user and give them an example
+ (\nERROR - ZUGFeRDProfile has not been supplied, you must supply an ICC profile) print
+ (\n Producing a potentially INVALID PDF/A file. \n) print
+ Usage
} ifelse
}
{
- % No XML invoice definition on the command line; chide the user and give them an example
- %
- (\nERROR - ZUGFeRDXMLFile has not been supplied, you must supply an XML invoice file\n) print
- ( Producing a PDF/A file not a ZUGFeRD file.\n) print
- (example usage - gs --permit-file-read=/usr/home/me/zugferd/ -sDEVICE=pdfwrite -dPDFA=3\\\n) print
- ( -sColorConversionStrategy=RGB -sZUGFeRDXMLFile=/usr/home/me/zugferd/invoice.xml\\\n) print
- ( -sZUGFeRDProfile=/usr/home/me/rgb.icc -o /usr/home/me/zugferd/zugferd.pdf\\\n) print
- ( /usr/home/me/zugferd/zugferd.ps /usr/home/me/zugferd/original.pdf\n\n) print flush
+ % No XML invoice definition on the command line;
+ % chide the user and give them an example
+ (\nERROR - ZUGFeRDXMLFile has not been supplied, you must supply a XML invoice file) print
+ (\n Producing a PDF/A file, NOT a ZUGFeRD file. \n) print
+ Usage
} ifelse
-% That's all the ZUGFeRD and PDF/A-3 setup completed, all that remains now is to run the input file
+% That's all the ZUGFeRD and PDF/A-3 setup completed,
+% all that remains now is to run the input file
+
+%%EOF \ No newline at end of file
diff --git a/man/dvipdf.1 b/man/dvipdf.1
index f0afa248..ad5e144a 100644
--- a/man/dvipdf.1
+++ b/man/dvipdf.1
@@ -1,4 +1,4 @@
-.TH DVIPDF 1 "30 March 2021" 9.54.0 Ghostscript \" -*- nroff -*-
+.TH DVIPDF 1 "27 September 2021" 9.55.0 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.54.0.
+This document was last revised for Ghostscript version 9.55.0.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/gs.1 b/man/gs.1
index 86763afb..360ba121 100644
--- a/man/gs.1
+++ b/man/gs.1
@@ -1,4 +1,4 @@
-.TH GS 1 "30 March 2021" 9.54.0 Ghostscript \" -*- nroff -*-
+.TH GS 1 "27 September 2021" 9.55.0 Ghostscript \" -*- nroff -*-
.SH NAME
gs \- Ghostscript (PostScript and PDF language interpreter and previewer)
.SH SYNOPSIS
@@ -423,7 +423,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.54.0.
+This document was last revised for Ghostscript version 9.55.0.
.SH AUTHOR
Artifex Software, Inc. are the primary maintainers
of Ghostscript.
diff --git a/man/gslp.1 b/man/gslp.1
index 50953bfb..1c9ae921 100644
--- a/man/gslp.1
+++ b/man/gslp.1
@@ -1,4 +1,4 @@
-.TH GSLP 1 "30 March 2021" 9.54.0 Ghostscript \" -*- nroff -*-
+.TH GSLP 1 "27 September 2021" 9.55.0 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.54.0.
+This document was last revised for Ghostscript version 9.55.0.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/gsnd.1 b/man/gsnd.1
index c3097fcf..52739970 100644
--- a/man/gsnd.1
+++ b/man/gsnd.1
@@ -1,4 +1,4 @@
-.TH GSND 1 "30 March 2021" 9.54.0 Ghostscript \" -*- nroff -*-
+.TH GSND 1 "27 September 2021" 9.55.0 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.54.0.
+This document was last revised for Ghostscript version 9.55.0.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/pdf2dsc.1 b/man/pdf2dsc.1
index 5973d494..0ad19035 100644
--- a/man/pdf2dsc.1
+++ b/man/pdf2dsc.1
@@ -1,4 +1,4 @@
-.TH PDF2DSC 1 "30 March 2021" 9.54.0 "Ghostscript Tools" \" -*- nroff -*-
+.TH PDF2DSC 1 "27 September 2021" 9.55.0 "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.54.0.
+This document was last revised for Ghostscript version 9.55.0.
.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 899ad6e4..1e40e3f4 100644
--- a/man/pdf2ps.1
+++ b/man/pdf2ps.1
@@ -1,4 +1,4 @@
-.TH PDF2PS 1 "30 March 2021" 9.54.0 "Ghostscript Tools" \" -*- nroff -*-
+.TH PDF2PS 1 "27 September 2021" 9.55.0 "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.54.0.
+This document was last revised for Ghostscript version 9.55.0.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/pf2afm.1 b/man/pf2afm.1
index 5173ea08..65e2be5a 100644
--- a/man/pf2afm.1
+++ b/man/pf2afm.1
@@ -1,4 +1,4 @@
-.TH PF2AFM 1 "30 March 2021" 9.54.0 Ghostscript \" -*- nroff -*-
+.TH PF2AFM 1 "27 September 2021" 9.55.0 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.54.0.
+This document was last revised for Ghostscript version 9.55.0.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/pfbtopfa.1 b/man/pfbtopfa.1
index cc18c39a..0979113e 100644
--- a/man/pfbtopfa.1
+++ b/man/pfbtopfa.1
@@ -1,4 +1,4 @@
-.TH PFBTOPFA 1 "30 March 2021" 9.54.0 Ghostscript \" -*- nroff -*-
+.TH PFBTOPFA 1 "27 September 2021" 9.55.0 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.54.0.
+This document was last revised for Ghostscript version 9.55.0.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/printafm.1 b/man/printafm.1
index 698ee63a..95030353 100644
--- a/man/printafm.1
+++ b/man/printafm.1
@@ -1,4 +1,4 @@
-.TH PRINTAFM 1 "30 March 2021" 9.54.0 Ghostscript \" -*- nroff -*-
+.TH PRINTAFM 1 "27 September 2021" 9.55.0 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.54.0.
+This document was last revised for Ghostscript version 9.55.0.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/ps2ascii.1 b/man/ps2ascii.1
index 613ed95d..670d541a 100644
--- a/man/ps2ascii.1
+++ b/man/ps2ascii.1
@@ -1,4 +1,4 @@
-.TH PS2ASCII 1 "30 March 2021" 9.54.0 "Ghostscript Tools" \" -*- nroff -*-
+.TH PS2ASCII 1 "27 September 2021" 9.55.0 "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.54.0.
+This document was last revised for Ghostscript version 9.55.0.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/ps2epsi.1 b/man/ps2epsi.1
index abae65b7..ff8a1f12 100644
--- a/man/ps2epsi.1
+++ b/man/ps2epsi.1
@@ -1,4 +1,4 @@
-.TH PS2EPSI 1 "30 March 2021" 9.54.0 "Ghostscript Tools" \" -*- nroff -*-
+.TH PS2EPSI 1 "27 September 2021" 9.55.0 "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.54.0.
+This document was last revised for Ghostscript version 9.55.0.
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 9fc62fad..a1187200 100644
--- a/man/ps2pdf.1
+++ b/man/ps2pdf.1
@@ -1,4 +1,4 @@
-.TH PS2PDF 1 "30 March 2021" 9.54.0 Ghostscript \" -*- nroff -*-
+.TH PS2PDF 1 "27 September 2021" 9.55.0 Ghostscript \" -*- nroff -*-
.SH NAME
ps2pdf \- Convert PostScript to PDF using ghostscript
.br
@@ -89,7 +89,7 @@ VectorDevices.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.54.0.
+This document was last revised for Ghostscript version 9.55.0.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/ps2pdfwr.1 b/man/ps2pdfwr.1
index 7e878f07..b59c2ca3 100644
--- a/man/ps2pdfwr.1
+++ b/man/ps2pdfwr.1
@@ -1,4 +1,4 @@
-.TH PS2PDFWR 1 "30 March 2021" 9.54.0 Ghostscript \" -*- nroff -*-
+.TH PS2PDFWR 1 "27 September 2021" 9.55.0 Ghostscript \" -*- nroff -*-
.SH NAME
ps2pdfwr \- Convert PostScript to PDF without specifying CompatibilityLevel, using ghostscript
.SH SYNOPSIS
@@ -24,7 +24,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.54.0.
+This document was last revised for Ghostscript version 9.55.0.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/man/ps2ps.1 b/man/ps2ps.1
index 3ed02f4e..b76556aa 100644
--- a/man/ps2ps.1
+++ b/man/ps2ps.1
@@ -1,4 +1,4 @@
-.TH PS2PS 1 "30 March 2021" 9.54.0 "Ghostscript Tools" \" -*- nroff -*-
+.TH PS2PS 1 "27 September 2021" 9.55.0 "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.54.0.
+This document was last revised for Ghostscript version 9.55.0.
.SH AUTHOR
Artifex Software, Inc. are the
primary maintainers of Ghostscript.
diff --git a/pdf/ghostpdf.c b/pdf/ghostpdf.c
new file mode 100644
index 00000000..5080a839
--- /dev/null
+++ b/pdf/ghostpdf.c
@@ -0,0 +1,1938 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Top level PDF access routines */
+#include "ghostpdf.h"
+#include "pdf_types.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_int.h"
+#include "pdf_misc.h"
+#include "pdf_stack.h"
+#include "pdf_file.h"
+#include "pdf_loop_detect.h"
+#include "pdf_trans.h"
+#include "pdf_gstate.h"
+#include "stream.h"
+#include "strmio.h"
+#include "pdf_colour.h"
+#include "pdf_font.h"
+#include "pdf_text.h"
+#include "pdf_page.h"
+#include "pdf_check.h"
+#include "pdf_optcontent.h"
+#include "pdf_sec.h"
+#include "pdf_doc.h"
+#include "pdf_repair.h"
+#include "pdf_xref.h"
+#include "pdf_device.h"
+
+#include "gsstate.h" /* For gs_gstate */
+#include "gsicc_manage.h" /* For gsicc_init_iccmanager() */
+
+#if PDFI_LEAK_CHECK
+#include "gsmchunk.h"
+#endif
+
+extern const char gp_file_name_list_separator;
+/*
+ * Convenience routine to check if a given string exists in a dictionary
+ * verify its contents and print it in a particular fashion to stdout. This
+ * is used to display information about the PDF in response to -dPDFINFO
+ */
+static int dump_info_string(pdf_context *ctx, pdf_dict *source_dict, const char *Key)
+{
+ int code;
+ pdf_string *s = NULL;
+ char *Cstr;
+
+ code = pdfi_dict_knownget_type(ctx, source_dict, Key, PDF_STRING, (pdf_obj **)&s);
+ if (code > 0) {
+ Cstr = (char *)gs_alloc_bytes(ctx->memory, s->length + 1, "Working memory for string dumping");
+ if (Cstr) {
+ memcpy(Cstr, s->data, s->length);
+ Cstr[s->length] = 0x00;
+ dmprintf2(ctx->memory, "%s: %s\n", Key, Cstr);
+ gs_free_object(ctx->memory, Cstr, "Working memory for string dumping");
+ }
+ code = 0;
+ }
+ pdfi_countdown(s);
+
+ return code;
+}
+
+static int pdfi_output_metadata(pdf_context *ctx)
+{
+ int code = 0;
+
+ if (ctx->num_pages > 1)
+ dmprintf2(ctx->memory, "\n %s has %"PRIi64" pages\n\n", ctx->filename, ctx->num_pages);
+ else
+ dmprintf2(ctx->memory, "\n %s has %"PRIi64" page.\n\n", ctx->filename, ctx->num_pages);
+
+ if (ctx->Info != NULL) {
+ pdf_name *n = NULL;
+ char *Cstr;
+
+ code = dump_info_string(ctx, ctx->Info, "Title");
+ if (code < 0) {
+ if (ctx->args.pdfstoponerror)
+ return code;
+ }
+
+ code = dump_info_string(ctx, ctx->Info, "Author");
+ if (code < 0) {
+ if (ctx->args.pdfstoponerror)
+ return code;
+ }
+
+ code = dump_info_string(ctx, ctx->Info, "Subject");
+ if (code < 0) {
+ if (ctx->args.pdfstoponerror)
+ return code;
+ }
+
+ code = dump_info_string(ctx, ctx->Info, "Keywords");
+ if (code < 0) {
+ if (ctx->args.pdfstoponerror)
+ return code;
+ }
+
+ code = dump_info_string(ctx, ctx->Info, "Creator");
+ if (code < 0) {
+ if (ctx->args.pdfstoponerror)
+ return code;
+ }
+
+ code = dump_info_string(ctx, ctx->Info, "Producer");
+ if (code < 0) {
+ if (ctx->args.pdfstoponerror)
+ return code;
+ }
+
+ code = dump_info_string(ctx, ctx->Info, "CreationDate");
+ if (code < 0) {
+ if (ctx->args.pdfstoponerror)
+ return code;
+ }
+
+ code = dump_info_string(ctx, ctx->Info, "ModDate");
+ if (code < 0) {
+ if (ctx->args.pdfstoponerror)
+ return code;
+ }
+
+
+ code = pdfi_dict_knownget_type(ctx, ctx->Info, "Trapped", PDF_NAME, (pdf_obj **)&n);
+ if (code > 0) {
+ Cstr = (char *)gs_alloc_bytes(ctx->memory, n->length + 1, "Working memory for string dumping");
+ if (Cstr) {
+ memcpy(Cstr, n->data, n->length);
+ Cstr[n->length] = 0x00;
+ dmprintf1(ctx->memory, "Trapped: %s\n\n", Cstr);
+ gs_free_object(ctx->memory, Cstr, "Working memory for string dumping");
+ }
+ code = 0;
+ }
+ pdfi_countdown(n);
+ n = NULL;
+ }
+ return code;
+}
+
+/*
+ * Convenience routine to check if a given *Box exists in a page dictionary
+ * verify its contents and print it in a particular fashion to stdout. This
+ * is used to display information about the PDF in response to -dPDFINFO
+ */
+static int pdfi_dump_box(pdf_context *ctx, pdf_dict *page_dict, const char *Key)
+{
+ int code, i;
+ pdf_array *a = NULL;
+ double f;
+
+ code = pdfi_dict_knownget_type(ctx, page_dict, Key, PDF_ARRAY, (pdf_obj **)&a);
+ if (code > 0) {
+ if (pdfi_array_size(a) != 4) {
+ dmprintf1(ctx->memory, "Error - %s does not contain 4 values.\n", Key);
+ code = gs_note_error(gs_error_rangecheck);
+ } else {
+ dmprintf1(ctx->memory, " %s: [", Key);
+ for (i = 0; i < pdfi_array_size(a); i++) {
+ code = pdfi_array_get_number(ctx, a, (uint64_t)i, &f);
+ if (i != 0)
+ dmprintf(ctx->memory, " ");
+ if (code == 0) {
+ if (a->values[i]->type == PDF_INT)
+ dmprintf1(ctx->memory, "%"PRIi64"", ((pdf_num *)a->values[i])->value.i);
+ else
+ dmprintf1(ctx->memory, "%f", ((pdf_num *)a->values[i])->value.d);
+ } else {
+ dmprintf(ctx->memory, "NAN");
+ }
+ }
+ dmprintf(ctx->memory, "]");
+ }
+ }
+ pdfi_countdown(a);
+ return code;
+}
+
+/*
+ * This routine along with pdfi_output_metadtaa above, dumps certain kinds
+ * of metadata from the PDF file, and from each page in the PDF file. It is
+ * intended to duplicate the pdf_info.ps functionality of the PostScript-based
+ * PDF interpreter in Ghostscript.
+ *
+ * It is not yet complete, we don't allow an option for dumping media sizes
+ * we always emit them, and the switches -dDumpFontsNeeded, -dDumpXML,
+ * -dDumpFontsUsed and -dShowEmbeddedFonts are not implemented at all yet.
+ */
+static int pdfi_output_page_info(pdf_context *ctx, uint64_t page_num)
+{
+ int code;
+ bool known = false;
+ double f;
+ pdf_dict *page_dict = NULL;
+
+ code = pdfi_page_get_dict(ctx, page_num, &page_dict);
+ if (code < 0)
+ return code;
+
+ dmprintf1(ctx->memory, "Page %"PRIi64"", page_num + 1);
+
+ code = pdfi_dict_knownget_number(ctx, page_dict, "UserUnit", &f);
+ if (code > 0)
+ dmprintf1(ctx->memory, " UserUnit: %f ", f);
+ if (code < 0) {
+ pdfi_countdown(page_dict);
+ return code;
+ }
+
+ code = pdfi_dump_box(ctx, page_dict, "MediaBox");
+ if (code < 0) {
+ if (code != gs_error_undefined && ctx->args.pdfstoponerror) {
+ pdfi_countdown(page_dict);
+ return code;
+ }
+ }
+
+ code = pdfi_dump_box(ctx, page_dict, "CropBox");
+ if (code < 0) {
+ if (code != gs_error_undefined && ctx->args.pdfstoponerror) {
+ pdfi_countdown(page_dict);
+ return code;
+ }
+ }
+
+ code = pdfi_dump_box(ctx, page_dict, "BleedBox");
+ if (code < 0) {
+ if (code != gs_error_undefined && ctx->args.pdfstoponerror) {
+ pdfi_countdown(page_dict);
+ return code;
+ }
+ }
+
+ code = pdfi_dump_box(ctx, page_dict, "TrimBox");
+ if (code < 0) {
+ if (code != gs_error_undefined && ctx->args.pdfstoponerror) {
+ pdfi_countdown(page_dict);
+ return code;
+ }
+ }
+
+ code = pdfi_dump_box(ctx, page_dict, "ArtBox");
+ if (code < 0) {
+ if (code != gs_error_undefined && ctx->args.pdfstoponerror) {
+ pdfi_countdown(page_dict);
+ return code;
+ }
+ }
+
+ code = pdfi_dict_knownget_number(ctx, page_dict, "Rotate", &f);
+ if (code > 0)
+ dmprintf1(ctx->memory, " Rotate = %d ", (int)f);
+ if (code < 0) {
+ pdfi_countdown(page_dict);
+ return code;
+ }
+
+ code = pdfi_check_page(ctx, page_dict, false);
+ if (code < 0) {
+ if (ctx->args.pdfstoponerror)
+ return code;
+ } else {
+ if (ctx->page.has_transparency)
+ dmprintf(ctx->memory, " Page uses transparency features");
+ }
+
+ code = pdfi_dict_known(ctx, page_dict, "Annots", &known);
+ if (code < 0) {
+ if (code != gs_error_undefined && ctx->args.pdfstoponerror)
+ return code;
+ } else {
+ if (known == true)
+ dmprintf(ctx->memory, " Page contains Annotations");
+ }
+
+ dmprintf(ctx->memory, "\n\n");
+ pdfi_countdown(page_dict);
+
+ return 0;
+}
+
+/* Error and warning string tables. There should be a string for each error and warning
+ * defined in the error (pdf_error_e) and warning (pdf_warning_e) enumerators. Having
+ * more strings is harmless, having too few may cause crashes. These need to be kept in sync.
+ *
+ * The Ghostscript graphics library errors should be kept up to date, but this is less critical
+ * if the error code is greater than the last error we know about we just print a generic
+ * 'unknown' message.
+ */
+const char *pdf_error_strings[] = {
+ "no error",
+ "no header detected",
+ "header lacks a version number",
+ "no startxref token found",
+ "startxref offset invalid",
+ "couldn't read hybrid file's XrefStm",
+ "error in xref table",
+ "too few entries in xref table",
+ "content stream lacks endstream",
+ "request for unknown filter",
+ "missing white space after number",
+ "malformed number",
+ "invalid unescaped character '(' in string",
+ "invalid object number",
+ "object lacks an endobj",
+ "error executing PDF token",
+ "potential token is too long",
+ "Page object doe snot have /Page type",
+ "circular reference to indirect object",
+ "couldn't repair PDF file",
+ "PDF file was repaired",
+ "error reading a stream",
+ "obj token missing",
+ "error in Page dictionary",
+ "out of memory",
+ "error reading page dictionary",
+ "stack underflow",
+ "error in stream dictionary",
+ "stream inherited a resource",
+ "counting down reference to freed object",
+ "error in transparency XObject",
+ "object lacks a required Subtype",
+ "error in image colour",
+ "" /* last error, should not be used */
+};
+
+const char *pdf_warning_strings[] = {
+ "no warning",
+ "incorrect xref size",
+ "used inline filter name inappropriately",
+ "used inline colour space inappropriately",
+ "used inline image key inappropriately",
+ "recoverable image error",
+ "recoverable error in image dictionary",
+ "encountered more Q than q",
+ "encountered more q than Q",
+ "garbage left on stack",
+ "stack underflow",
+ "error in group definition",
+ "invalid operator used in text block",
+ "used invalid operator in CharProc",
+ "BT found inside a text block",
+ "ET found outside text block",
+ "text operator outside text block",
+ "degenerate text matrix",
+ "bad ICC colour profile, using alternate",
+ "bad ICC vs number components, using components",
+ "bad value for text rendering mode",
+ "error in shading",
+ "error in pattern",
+ "non standard operator found - ignoring",
+ "number uses illegal exponent form",
+ "Stream has inappropriate /Contents entry",
+ "bad DecodeParms",
+ "error in Mask",
+ "error in annotation Appearance",
+ "badly escaped name",
+ "typecheck error",
+ "bad trailer dictionary",
+ "error in annotation",
+ "failed to create ICC profile link",
+ "overflowed a real reading a number, assuming 0",
+ "failed to read a valid number, assuming 0",
+ "A DeviceN space used the /All ink name.",
+ "Couldn't retrieve MediaBox for page, using current media size",
+ "" /* Last warning shuld not be used */
+};
+
+const char *gs_error_strings[] = {
+ "no error",
+ "unknownerror",
+ "dictfull",
+ "dictstackoverflow",
+ "dictstackunderflow",
+ "execstackoverflow",
+ "interrupt",
+ "invalidaccess",
+ "invalidexit",
+ "invalidfileaccess",
+ "invalidfont",
+ "invalidrestore",
+ "ioerror",
+ "limitcheck",
+ "nocurrentpoint",
+ "rangecheck",
+ "stackoverflow",
+ "stackunderflow",
+ "syntaxerror",
+ "timeout",
+ "typecheck",
+ "undefined",
+ "undefinedfilename",
+ "undefinedresult",
+ "unmatchedmark",
+ "VMerror",
+ "configurationerror",
+ "undefinedresource",
+ "unregistered",
+ "invalidcontext",
+ "invalidid",
+};
+
+const char *gs_internal_error_strings[] = {
+ "error hit",
+ "fatal error",
+ "quit",
+ "interpreter exit",
+ "remap color",
+ "exec stack underflow",
+ "VMreclaim",
+ "Need input",
+ "No defined error",
+ "No defined error (2)",
+ "need file",
+ "error info",
+ "handled",
+ "circular reference"
+};
+#define LASTNORMALGSERROR gs_error_invalidid * -1
+#define FIRSTINTERNALERROR gs_error_hit_detected * -1
+#define LASTGSERROR gs_error_circular_reference * -1
+
+void pdfi_verbose_error(pdf_context *ctx, int gs_error, const char *gs_lib_function, int pdfi_error, const char *pdfi_function_name, const char *extra_info)
+{
+ char fallback[] = "unknown graphics library error";
+
+ if (ctx->args.verbose_errors && !ctx->args.QUIET) {
+ if (gs_error != 0) {
+ char *error_string;
+ unsigned int code = gs_error * -1;
+
+ if (code > LASTGSERROR)
+ error_string = fallback;
+ else {
+ if (code > LASTNORMALGSERROR) {
+ if (code < FIRSTINTERNALERROR)
+ error_string = fallback;
+ else
+ error_string = (char *)gs_internal_error_strings[code - FIRSTINTERNALERROR];
+ } else
+ error_string = (char *)gs_error_strings[code];
+ }
+ errprintf(ctx->memory, "Graphics library error %d (%s) in function '%s'", gs_error, error_string, pdfi_function_name);
+ if (gs_lib_function != NULL)
+ errprintf(ctx->memory, " from lib routine '%s'.\n", gs_lib_function);
+ else
+ errprintf(ctx->memory, ".\n");
+
+ if (pdfi_error != 0)
+ errprintf(ctx->memory, "\tSetting pdfi error %d - %s.\n", pdfi_error, pdf_error_strings[pdfi_error]);
+ if (extra_info != NULL)
+ errprintf(ctx->memory, "\t%s\n", extra_info);
+ } else {
+ if (pdfi_error != 0) {
+ errprintf(ctx->memory, "Function '%s' set pdfi error %d - %s.\n", pdfi_function_name, pdfi_error, pdf_error_strings[pdfi_error]);
+ if (extra_info != NULL)
+ errprintf(ctx->memory, "\t%s\n", extra_info);
+ } else {
+ if (extra_info != NULL)
+ errprintf(ctx->memory, "%s\n", extra_info);
+ }
+ }
+ }
+}
+
+void pdfi_verbose_warning(pdf_context *ctx, int gs_error, const char *gs_lib_function, int pdfi_warning, const char *pdfi_function_name, const char *extra_info)
+{
+ char fallback[] = "unknown graphics library error";
+
+ if (ctx->args.verbose_warnings && !ctx->args.QUIET) {
+ if (gs_error != 0) {
+ char *error_string;
+ unsigned int code = gs_error * -1;
+
+ if (code > LASTGSERROR)
+ error_string = fallback;
+ else {
+ if (code > LASTNORMALGSERROR) {
+ if (code < FIRSTINTERNALERROR)
+ error_string = fallback;
+ else
+ error_string = (char *)gs_internal_error_strings[code - FIRSTINTERNALERROR];
+ } else
+ error_string = (char *)gs_error_strings[code];
+ }
+ outprintf(ctx->memory, "Graphics library error %d (%s) in function '%s'", gs_error, error_string, pdfi_function_name);
+ if (gs_lib_function != NULL)
+ outprintf(ctx->memory, " from lib routine '%s'.\n", gs_lib_function);
+ else
+ outprintf(ctx->memory, ".\n");
+
+ if (pdfi_warning != 0)
+ outprintf(ctx->memory, "\tsetting pdfi warning %d - %s.\n", pdfi_warning, pdf_warning_strings[pdfi_warning]);
+ if (extra_info != NULL)
+ outprintf(ctx->memory, "\t%s\n", extra_info);
+ } else {
+ if (pdfi_warning != 0) {
+ outprintf(ctx->memory, "Function '%s' set pdfi warning %d - %s.\n", pdfi_function_name, pdfi_warning, pdf_warning_strings[pdfi_warning]);
+ if (extra_info != NULL)
+ errprintf(ctx->memory, "\t%s\n", extra_info);
+ } else {
+ if (extra_info != NULL)
+ errprintf(ctx->memory, "\t%s\n", extra_info);
+ }
+ }
+ }
+}
+
+void pdfi_log_info(pdf_context *ctx, const char *pdfi_function, const char *info)
+{
+#ifdef DEBUG
+ if (!ctx->args.QUIET)
+ outprintf(ctx->memory, "%s", info);
+#endif
+}
+
+static void
+pdfi_report_errors(pdf_context *ctx)
+{
+ int code, i, j;
+ bool warnings_exist = false, errors_exist = false;
+
+ if (ctx->args.QUIET)
+ return;
+
+ for (i = 0; i < PDF_ERROR_BYTE_SIZE; i++) {
+ if (ctx->pdf_errors[i] != 0)
+ errors_exist = true;
+ }
+
+ for (i = 0; i < PDF_WARNING_BYTE_SIZE; i++) {
+ if (ctx->pdf_warnings[i] != 0)
+ warnings_exist = true;
+ }
+
+ if (!errors_exist && !warnings_exist)
+ return;
+
+ if (errors_exist)
+ {
+ dmprintf(ctx->memory, "\nThe following errors were encountered at least once while processing this file:\n");
+ for (i = 0; i < PDF_ERROR_BYTE_SIZE; i++) {
+ if (ctx->pdf_errors[i] != 0) {
+ for (j=0;j < sizeof(char) * 8; j++) {
+ if (ctx->pdf_errors[i] & 1 << j) {
+ int error_num = (i * sizeof(char) * 8) + j;
+
+ errprintf(ctx->memory, "\t%s\n", pdf_error_strings[error_num]);
+ }
+ }
+ }
+ }
+ }
+
+ if (warnings_exist)
+ {
+ dmprintf(ctx->memory, "\nThe following warnings were encountered at least once while processing this file:\n");
+ for (i = 0; i < PDF_WARNING_BYTE_SIZE; i++) {
+ if (ctx->pdf_warnings[i] != 0) {
+ for (j=0;j < sizeof(char) * 8; j++) {
+ if (ctx->pdf_warnings[i] & 1 << j) {
+ int warning_num = (i * sizeof(char) * 8) + j;
+
+ outprintf(ctx->memory, "\t%s\n", pdf_warning_strings[warning_num]);
+ }
+ }
+ }
+ }
+ }
+
+ dmprintf(ctx->memory, "\n **** This file had errors that were repaired or ignored.\n");
+ if (ctx->Info) {
+ pdf_string *s = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, ctx->Info, "Producer", PDF_STRING, (pdf_obj **)&s);
+ if (code > 0) {
+ char *cs;
+
+ cs = (char *)gs_alloc_bytes(ctx->memory, s->length + 1, "temporary string for error report");
+ memcpy(cs, s->data, s->length);
+ cs[s->length] = 0x00;
+ dmprintf1(ctx->memory, " **** The file was produced by: \n **** >>>> %s <<<<\n", cs);
+ gs_free_object(ctx->memory, cs, "temporary string for error report");
+ }
+ pdfi_countdown(s);
+ }
+ dmprintf(ctx->memory, " **** Please notify the author of the software that produced this\n");
+ dmprintf(ctx->memory, " **** file that it does not conform to Adobe's published PDF\n");
+ dmprintf(ctx->memory, " **** specification.\n\n");
+}
+
+/* Name table
+ * I've been trying to avoid this for as long as possible, but it seems it cannot
+ * be evaded. We need functions to get an index for a given string (which will
+ * add the string to the table if its not present) and to cleear up the table
+ * on finishing a PDF file.
+ */
+
+int pdfi_get_name_index(pdf_context *ctx, char *name, int len, unsigned int *returned)
+{
+ pdfi_name_entry_t *e = NULL, *last_entry = NULL, *new_entry = NULL;
+ int index = 0;
+
+ if (ctx->name_table == NULL) {
+ e = NULL;
+ } else {
+ e = ctx->name_table;
+ }
+
+ while(e != NULL) {
+ if (e->len == len) {
+ if (memcmp(e->name, name, e->len) == 0) {
+ *returned = e->index;
+ return 0;
+ }
+ }
+ last_entry = e;
+ index = e->index;
+ e = e->next;
+ }
+
+ new_entry = (pdfi_name_entry_t *)gs_alloc_bytes(ctx->memory, sizeof(pdfi_name_entry_t), "Alloc name table entry");
+ if (new_entry == NULL)
+ return_error(gs_error_VMerror);
+ memset(new_entry, 0x00, sizeof(pdfi_name_entry_t));
+ new_entry->name = (char *)gs_alloc_bytes(ctx->memory, len+1, "Alloc name table name");
+ if (new_entry->name == NULL) {
+ gs_free_object(ctx->memory, new_entry, "Failed to allocate name entry");
+ return_error(gs_error_VMerror);
+ }
+ memset(new_entry->name, 0x00, len+1);
+ memcpy(new_entry->name, name, len);
+ new_entry->len = len;
+ new_entry->index = ++index;
+
+ if (last_entry)
+ last_entry->next = new_entry;
+ else
+ ctx->name_table = new_entry;
+
+ *returned = new_entry->index;
+ return 0;
+}
+
+static int pdfi_free_name_table(pdf_context *ctx)
+{
+ if (ctx->name_table) {
+ pdfi_name_entry_t *next = NULL, *e = (pdfi_name_entry_t *)ctx->name_table;
+
+ while (e != NULL) {
+ next = (pdfi_name_entry_t *)e->next;
+ gs_free_object(ctx->memory, e->name, "free name table entries");
+ gs_free_object(ctx->memory, e, "free name table entries");
+ e = next;
+ }
+ }
+ ctx->name_table = NULL;
+ return 0;
+}
+
+int pdfi_name_from_index(pdf_context *ctx, int index, unsigned char **name, unsigned int *len)
+{
+ pdfi_name_entry_t *e = (pdfi_name_entry_t *)ctx->name_table;
+
+ while (e != NULL) {
+ if (e->index == index) {
+ *name = (unsigned char *)e->name;
+ *len = e->len;
+ return 0;
+ }
+ e = e->next;
+ }
+
+ return_error(gs_error_undefined);
+}
+
+int pdfi_separation_name_from_index(gs_gstate *pgs, gs_separation_name index, unsigned char **name, unsigned int *len)
+{
+ pdfi_int_gstate *igs = (pdfi_int_gstate *)pgs->client_data;
+ pdf_context *ctx = NULL;
+ pdfi_name_entry_t *e = NULL;
+
+ if (igs == NULL)
+ return_error(gs_error_undefined);
+
+ ctx = igs->ctx;
+ if (ctx == NULL)
+ return_error(gs_error_undefined);
+
+ e = (pdfi_name_entry_t *)ctx->name_table;
+
+ while (e != NULL) {
+ if (e->index == index) {
+ *name = (unsigned char *)e->name;
+ *len = e->len;
+ return 0;
+ }
+ e = e->next;
+ }
+
+ return_error(gs_error_undefined);
+}
+
+/* These functions are used by the 'PL' implementation, eventually we will */
+/* need to have custom PostScript operators to process the file or at */
+/* (least pages from it). */
+
+int pdfi_close_pdf_file(pdf_context *ctx)
+{
+ if (ctx->main_stream) {
+ if (ctx->main_stream->s) {
+ sfclose(ctx->main_stream->s);
+ }
+ gs_free_object(ctx->memory, ctx->main_stream, "Closing main PDF file");
+ ctx->main_stream = NULL;
+ }
+ ctx->main_stream_length = 0;
+
+ if (ctx->filename) {
+ gs_free_object(ctx->memory, ctx->filename, "pdfi_close_pdf_file, free copy of filename");
+ ctx->filename = NULL;
+ }
+
+ pdfi_clear_context(ctx);
+ return 0;
+}
+
+static int pdfi_process(pdf_context *ctx)
+{
+ int code = 0, i;
+
+ /* Loop over each page and either render it or output the
+ * required information.
+ */
+ for (i=0;i < ctx->num_pages;i++) {
+ if (ctx->args.first_page != 0) {
+ if (i < ctx->args.first_page - 1)
+ continue;
+ }
+ if (ctx->args.last_page != 0) {
+ if (i > ctx->args.last_page - 1)
+ break;;
+ }
+ if (ctx->args.pdfinfo)
+ code = pdfi_output_page_info(ctx, i);
+ else
+ code = pdfi_page_render(ctx, i, true);
+
+ if (code < 0 && ctx->args.pdfstoponerror)
+ goto exit;
+ code = 0;
+ }
+ exit:
+ pdfi_report_errors(ctx);
+
+ return code;
+}
+
+/* This works by reading each embedded file referenced by the collection. If it
+ * has a MIME type indicating it's a PDF file, or somewhere in the first 2KB it
+ * has the PDF header (%PDF-) then we treat it as a PDF file. We read the contents
+ * of the refrenced stream and write them to disk in a scratch file.
+ *
+ * We then process each scratch file in turn. Note that we actually return an
+ * array of strings; the first string is the temporary filename, the second is
+ * the entry from the names tree. Since this can be in UTF16-BE format, it can
+ * contain embedded single byte NULL characters, so we can't use a regular C
+ * string. Instead we use a triple byte NULL termination.
+ *
+ * It ought to be possible to do all the processing without creating scratch files, by saving the
+ * current file state, and opening a new 'file' on the stream in the original PDF
+ * file. But I couldn't immediately get that to work.
+ * So this is a FIXME future enhancement.
+ */
+int pdfi_prep_collection(pdf_context *ctx, uint64_t *TotalFiles, char ***names_array)
+{
+ int code = 0, i, NumEmbeddedFiles = 0;
+ pdf_obj *Names = NULL, *EmbeddedFiles = NULL;
+ pdf_array *FileNames = NULL;
+ pdf_obj *EF = NULL, *F = NULL;
+ char **working_array = NULL;
+
+ if (pdfi_dict_knownget_type(ctx, ctx->Root, "Names", PDF_DICT, &Names)) {
+ if(pdfi_dict_knownget_type(ctx, (pdf_dict *)Names, "EmbeddedFiles", PDF_DICT, &EmbeddedFiles)) {
+ if (pdfi_dict_knownget_type(ctx, (pdf_dict *)EmbeddedFiles, "Names", PDF_ARRAY, (pdf_obj **)&FileNames)) {
+ int ix = 0, index = 0;
+ gp_file *scratch_file = NULL;
+ char scratch_name[gp_file_name_sizeof];
+
+ NumEmbeddedFiles = pdfi_array_size(FileNames) / 2;
+
+ working_array = (char **)gs_alloc_bytes(ctx->memory, NumEmbeddedFiles * 2 * sizeof(char *), "Collection file working names array");
+ if (working_array == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto exit;
+ }
+ memset(working_array, 0x00, NumEmbeddedFiles * 2 * sizeof(char *));
+
+ for (ix = 0;ix < NumEmbeddedFiles;ix++) {
+ pdf_obj *File = NULL;
+ pdf_obj *Subtype = NULL;
+
+ code = pdfi_array_get(ctx, FileNames, (ix * 2) + 1, &File);
+ if (code < 0)
+ goto exit;
+
+ if (File->type == PDF_DICT) {
+ if (pdfi_dict_knownget_type(ctx, (pdf_dict *)File, "EF", PDF_DICT, &EF)) {
+ if (pdfi_dict_knownget_type(ctx, (pdf_dict *)EF, "F", PDF_STREAM, &F)) {
+ pdf_dict *stream_dict = NULL;
+ pdf_c_stream *s = NULL;
+
+ /* pdfi_dict_from_object does not increment the reference count of the stream dictionary
+ * so we do not need to count it down later.
+ */
+ code = pdfi_dict_from_obj(ctx, F, &stream_dict);
+ if (code >= 0) {
+ if (!pdfi_dict_knownget_type(ctx, stream_dict, "Subtype", PDF_NAME, &Subtype)) {
+ /* No Subtype, (or not a name) we can't check the Mime type, so try to read the first 2Kb
+ * and look for a %PDF- in that. If not present, assume its not a PDF
+ */
+ code = pdfi_seek(ctx, ctx->main_stream, pdfi_stream_offset(ctx, (pdf_stream *)F), SEEK_SET);
+ if (code >= 0) {
+ code = pdfi_filter(ctx, (pdf_stream *)F, ctx->main_stream, &s, false);
+ if (code >= 0) {
+ char Buffer[2048];
+ int bytes;
+
+ bytes = pdfi_read_bytes(ctx, (byte *)Buffer, 1, 2048, s);
+ pdfi_close_file(ctx, s);
+ s = NULL;
+ /* Assertion; the smallest real PDF file is at least 400 bytes */
+ if (bytes >= 400) {
+ if (strstr(Buffer, "%PDF-") == NULL)
+ code = -1;
+ } else
+ code = -1;
+ }
+ }
+ } else {
+ if (!pdfi_name_is((const pdf_name *)Subtype, "application/pdf"))
+ code = -1;
+ }
+
+ if (code >= 0) {
+ /* Appears to be a PDF file. Create a scratch file to hold it, and then
+ * read the file from the PDF, and write it to the scratch file. Record
+ * the scratch filename in the working_array for later processing.
+ */
+ scratch_file = gp_open_scratch_file(ctx->memory, "gpdf-collection-", scratch_name, "wb");
+ if (scratch_file != NULL) {
+ code = pdfi_seek(ctx, ctx->main_stream, pdfi_stream_offset(ctx, (pdf_stream *)F), SEEK_SET);
+ if (code >= 0) {
+ double L;
+ pdf_c_stream *SubFile_stream = NULL;
+
+ /* Start by setting up the file to be read. Apply a SubFileDecode so that, if the input stream
+ * is not compressed we will stop reading when we get to the end of the stream.
+ */
+ if (pdfi_dict_knownget_number(ctx, stream_dict, "Length", &L)) {
+
+ code = pdfi_apply_SubFileDecode_filter(ctx, (int)L, NULL, ctx->main_stream, &SubFile_stream, false);
+ if (code >= 0)
+ code = pdfi_filter(ctx, (pdf_stream *)F, SubFile_stream, &s, false);
+ } else
+ code = pdfi_filter(ctx, (pdf_stream *)F, ctx->main_stream, &s, false);
+
+ if (code >= 0) {
+ char Buffer[2048];
+ int bytes;
+ pdf_string *Name = NULL;
+
+ /* Read the stream contents and write them to the scratch file */
+ do {
+ bytes = pdfi_read_bytes(ctx, (byte *)Buffer, 1, 2048, s);
+ (void)gp_fwrite(Buffer, 1, bytes, scratch_file);
+ } while (bytes > 0);
+
+ /* Create an entry for the Description in the names array */
+ code = pdfi_array_get(ctx, FileNames, ix * 2, (pdf_obj **)&Name);
+ if (code >= 0) {
+ if (Name->type == PDF_STRING) {
+ working_array[(index * 2) + 1] = (char *)gs_alloc_bytes(ctx->memory, Name->length + 3, "Collection file names array entry");
+ if (working_array[(index * 2) + 1] != NULL) {
+ memset(working_array[(index * 2) + 1], 0x00, Name->length + 3);
+ memcpy(working_array[(index * 2) + 1], Name->data, Name->length);
+ }
+ }
+ pdfi_countdown(Name);
+ Name = NULL;
+ }
+
+ /* And now the scratch file name */
+ working_array[index * 2] = (char *)gs_alloc_bytes(ctx->memory, strlen(scratch_name) + 3, "Collection file names array entry");
+ if (working_array[index * 2] != NULL) {
+ memset(working_array[index * 2], 0x00, strlen(scratch_name) + 3);
+ strcpy(working_array[index * 2], scratch_name);
+ }
+
+ index++;
+ (*TotalFiles)++;
+ pdfi_close_file(ctx, s);
+ s = NULL;
+ }
+ if (SubFile_stream != NULL)
+ pdfi_close_file(ctx, SubFile_stream);
+ SubFile_stream = NULL;
+ }
+ gp_fclose(scratch_file);
+ } else
+ dmprintf(ctx->memory, "\n **** Warning: Failed to open a scratch file.\n");
+ }
+ }
+ }
+ }
+ }
+ pdfi_countdown(Subtype);
+ Subtype = NULL;
+ pdfi_countdown(F);
+ F = NULL;
+ pdfi_countdown(EF);
+ EF = NULL;
+ pdfi_countdown(File);
+ File = NULL;
+ }
+ } else {
+ dmprintf(ctx->memory, "\n **** Warning: Failed to read EmbeededFiles Names tree.\n");
+ }
+ } else {
+ dmprintf(ctx->memory, "\n **** Warning: Failed to read EmbeddedFiles.\n");
+ }
+ } else {
+ dmprintf(ctx->memory, "\n **** Warning: Failed to find Names tree.\n");
+ }
+ code = 0;
+
+exit:
+ if (code >= 0) {
+ uint64_t ix = 0;
+
+ (*names_array) = (char **)gs_alloc_bytes(ctx->memory, *TotalFiles * 2 * sizeof(char *), "Collection file namesarray");
+ for (i = 0; i < NumEmbeddedFiles;i++) {
+ if (working_array[i * 2] != NULL && working_array[(i * 2) + 1] != NULL) {
+ (*names_array)[ix * 2] = working_array[i * 2];
+ working_array[i * 2] = NULL;
+ (*names_array)[(ix * 2) + 1] = working_array[(i * 2) + 1];
+ working_array[(i * 2) + 1] = NULL;
+ ix++;
+ }
+ }
+ }
+
+ if (working_array != NULL) {
+ for (i = 0; i < NumEmbeddedFiles;i++)
+ gs_free_object(ctx->memory, working_array[i], "free collection temporary filenames");
+ gs_free_object(ctx->memory, working_array, "free collection working array");
+ }
+ pdfi_countdown(F);
+ pdfi_countdown(EF);
+ pdfi_countdown(FileNames);
+ pdfi_countdown(EmbeddedFiles);
+ pdfi_countdown(Names);
+ return code;
+}
+
+static int pdfi_process_collection(pdf_context *ctx)
+{
+ int code, i;
+ uint64_t TotalFiles = 0, ix = 0;
+ char **names_array = NULL;
+
+ code = pdfi_prep_collection(ctx, &TotalFiles, &names_array);
+ if (code >= 0 && TotalFiles > 0)
+ {
+ /* names_array is full of pointers to the scratch file names containing PDF files.
+ * Now we need to run each PDF file. First we close down the current file.
+ */
+ (void)pdfi_close_pdf_file(ctx);
+
+ for (ix = 0;ix < TotalFiles * 2;ix+=2) {
+ if (names_array[ix] != NULL) {
+ (void)pdfi_process_pdf_file(ctx, names_array[ix]);
+ (void)pdfi_close_pdf_file(ctx);
+ }
+ }
+ } else
+ /* We didn't find any PDF files in the Embedded Files. So just run the
+ * pages in the container file (the original PDF file)
+ */
+ pdfi_process(ctx);
+
+ for (i = 0; i < TotalFiles * 2;i++)
+ gs_free_object(ctx->memory, names_array[i], "free collection temporary filenames");
+ gs_free_object(ctx->memory, names_array, "free collection names array");
+
+ return 0;
+}
+
+int pdfi_process_pdf_file(pdf_context *ctx, char *filename)
+{
+ int code = 0;
+
+ code = pdfi_open_pdf_file(ctx, filename);
+ if (code < 0) {
+ pdfi_report_errors(ctx);
+ return code;
+ }
+
+ /* Need to do this here so that ctx->writepdfmarks will be setup
+ * It is also called in pdfi_page_render()
+ * TODO: Should probably look into that..
+ */
+ pdfi_device_set_flags(ctx);
+ /* Do any custom device configuration */
+ pdfi_device_misc_config(ctx);
+
+ if (ctx->Collection != NULL)
+ code = pdfi_process_collection(ctx);
+ else
+ code = pdfi_process(ctx);
+
+ pdfi_close_pdf_file(ctx);
+ return code;
+}
+
+static int pdfi_init_file(pdf_context *ctx)
+{
+ int code = 0;
+ pdf_obj *o = NULL;
+
+ code = pdfi_read_xref(ctx);
+ if (code < 0) {
+ if (ctx->is_hybrid) {
+ /* If its a hybrid file, and we failed to read the XrefStm, try
+ * again, but this time read the xref table instead.
+ */
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADXREFSTREAM, "pdfi_init_file", NULL);
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ ctx->prefer_xrefstm = false;
+ code = pdfi_read_xref(ctx);
+ if (code < 0)
+ goto exit;
+ } else {
+ pdfi_set_error(ctx, code, NULL, E_PDF_BADXREFSTREAM, "pdfi_init_file", NULL);
+ goto exit;
+ }
+ }
+
+ if (ctx->Trailer) {
+ code = pdfi_dict_get(ctx, ctx->Trailer, "Encrypt", &o);
+ if (code < 0 && code != gs_error_undefined)
+ goto exit;
+ if (code == 0) {
+ code = pdfi_initialise_Decryption(ctx);
+ if (code < 0)
+ goto exit;
+ }
+ }
+
+read_root:
+ if (ctx->Trailer) {
+ code = pdfi_read_Root(ctx);
+ if (code < 0) {
+ /* If we couldn#'t find the Root object, and we were using the XrefStm
+ * from a hybrid file, then try again, but this time use the xref table
+ */
+ if (code == gs_error_undefined && ctx->is_hybrid && ctx->prefer_xrefstm) {
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADXREFSTREAM, "pdfi_init_file", NULL);
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ ctx->prefer_xrefstm = false;
+ code = pdfi_read_xref(ctx);
+ if (code < 0) {
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADXREF, "pdfi_init_file", NULL);
+ goto exit;
+ }
+ code = pdfi_read_Root(ctx);
+ if (code < 0)
+ goto exit;
+ } else {
+ int code1 = pdfi_repair_file(ctx);
+ if (code1 < 0)
+ goto exit;
+ goto read_root;
+ }
+ }
+ }
+
+ if (ctx->Trailer) {
+ code = pdfi_read_Info(ctx);
+ if (code < 0 && code != gs_error_undefined) {
+ if (ctx->args.pdfstoponerror)
+ goto exit;
+ pdfi_clearstack(ctx);
+ }
+ }
+
+ if (!ctx->Root) {
+ dmprintf(ctx->memory, "Catalog dictionary not located in file, unable to proceed\n");
+ return_error(gs_error_syntaxerror);
+ }
+
+ code = pdfi_read_Pages(ctx);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_doc_page_array_init(ctx);
+ if (code < 0)
+ goto exit;
+
+ if (ctx->num_pages == 0)
+ dmprintf(ctx->memory, "\n **** Warning: PDF document has no pages.\n");
+
+ code = pdfi_doc_trailer(ctx);
+ if (code < 0)
+ goto exit;
+
+ pdfi_read_OptionalRoot(ctx);
+
+ if (ctx->args.pdfinfo) {
+ code = pdfi_output_metadata(ctx);
+ if (code < 0 && ctx->args.pdfstoponerror)
+ goto exit;
+ }
+
+exit:
+ if (code < 0)
+ pdfi_set_error(ctx, code, NULL, 0, "pdfi_init_file", NULL);
+ pdfi_countdown(o);
+ return code;
+}
+
+int pdfi_set_input_stream(pdf_context *ctx, stream *stm)
+{
+ byte *Buffer = NULL;
+ char *s = NULL;
+ float version = 0.0;
+ gs_offset_t Offset = 0;
+ int64_t bytes = 0, leftover = 0;
+ bool found = false;
+ int code;
+
+ /* In case of broken PDF files, the repair could run off the end of the
+ * file, so make sure that doing so does *not* automagically close the file
+ */
+ stm->close_at_eod = false;
+
+ ctx->main_stream = (pdf_c_stream *)gs_alloc_bytes(ctx->memory, sizeof(pdf_c_stream), "PDF interpreter allocate main PDF stream");
+ if (ctx->main_stream == NULL)
+ return_error(gs_error_VMerror);
+ memset(ctx->main_stream, 0x00, sizeof(pdf_c_stream));
+ ctx->main_stream->s = stm;
+
+ Buffer = gs_alloc_bytes(ctx->memory, BUF_SIZE, "PDF interpreter - allocate working buffer for file validation");
+ if (Buffer == NULL) {
+ code = gs_error_VMerror;
+ goto error;
+ }
+
+ /* Determine file size */
+ pdfi_seek(ctx, ctx->main_stream, 0, SEEK_END);
+ ctx->main_stream_length = pdfi_tell(ctx->main_stream);
+ Offset = BUF_SIZE;
+ bytes = BUF_SIZE;
+ pdfi_seek(ctx, ctx->main_stream, 0, SEEK_SET);
+
+ bytes = Offset = min(BUF_SIZE - 1, ctx->main_stream_length);
+
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "%% Reading header\n");
+
+ bytes = pdfi_read_bytes(ctx, Buffer, 1, Offset, ctx->main_stream);
+ if (bytes <= 0) {
+ emprintf(ctx->memory, "Failed to read any bytes from input stream\n");
+ code = gs_error_ioerror;
+ goto error;
+ }
+ if (bytes < 8) {
+ emprintf(ctx->memory, "Failed to read enough bytes for a valid PDF header from input stream\n");
+ code = gs_error_ioerror;
+ goto error;
+ }
+ Buffer[Offset] = 0x00;
+
+ /* First check for existence of header */
+ s = strstr((char *)Buffer, "%PDF");
+ if (s == NULL) {
+ char extra_info[gp_file_name_sizeof];
+
+ if (ctx->filename)
+ gs_sprintf(extra_info, "%% File %s does not appear to be a PDF file (no %%PDF in first 2Kb of file)\n", ctx->filename);
+ else
+ gs_sprintf(extra_info, "%% File does not appear to be a PDF stream (no %%PDF in first 2Kb of stream)\n");
+
+ pdfi_set_error(ctx, 0, NULL, E_PDF_NOHEADER, "pdfi_set_input_stream", extra_info);
+ } else {
+ /* Now extract header version (may be overridden later) */
+ if (sscanf(s + 5, "%f", &version) != 1) {
+ ctx->HeaderVersion = 0;
+ pdfi_set_error(ctx, 0, NULL, E_PDF_NOHEADERVERSION, "pdfi_set_input_stream", (char *)"%% Unable to read PDF version from header\n");
+ }
+ else {
+ ctx->HeaderVersion = version;
+ }
+ if (ctx->args.pdfdebug)
+ dmprintf1(ctx->memory, "%% Found header, PDF version is %f\n", ctx->HeaderVersion);
+ }
+
+ /* Jump to EOF and scan backwards looking for startxref */
+ pdfi_seek(ctx, ctx->main_stream, 0, SEEK_END);
+
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "%% Searching for 'startxerf' keyword\n");
+
+ /* Initially read min(BUF_SIZE, file_length) bytes of data to the buffer */
+ bytes = Offset;
+
+ do {
+ byte *last_lineend = NULL;
+ uint32_t read;
+
+ if (pdfi_seek(ctx, ctx->main_stream, ctx->main_stream_length - Offset, SEEK_SET) != 0) {
+ emprintf1(ctx->memory, "File is smaller than %"PRIi64" bytes\n", (int64_t)Offset);
+ code = gs_error_ioerror;
+ goto error;
+ }
+ read = pdfi_read_bytes(ctx, Buffer, 1, bytes, ctx->main_stream);
+
+ if (read <= 0) {
+ emprintf1(ctx->memory, "Failed to read %"PRIi64" bytes from file\n", (int64_t)bytes);
+ code = gs_error_ioerror;
+ goto error;
+ }
+
+ /* When reading backwards, if we ran out of data in the last buffer while looking
+ * for a 'startxref, but we had found a linefeed, then we preserved everything
+ * from the beginning of the buffer up to that linefeed, by copying it to the end
+ * of the buffer and reducing the number of bytes to read so that it should have filled
+ * in the gap. If we didn't read enough bytes, then we have a gap between the end of
+ * the data we just read and the leftover data from teh last buffer. Move the preserved
+ * data down to meet the end of the data we just read.
+ */
+ if (bytes != read && leftover != 0)
+ memcpy(Buffer + read, Buffer + bytes, leftover);
+
+ /* As above, if we had any leftover data from the last buffer then increase the
+ * number of bytes available by that amount. We increase 'bytes' (the number of bytes
+ * to read) to the same value, which should mean we read an entire buffer's worth. Of
+ * course if we have any data left out of this buffer we'll reduce bytes again...
+ */
+ read = bytes = read + leftover;
+
+ /* Now search backwards in the buffer for the startxref token */
+ while(read) {
+ if (memcmp(Buffer + read - 9, "startxref", 9) == 0) {
+ found = true;
+ break;
+ } else {
+ if (Buffer[read - 1] == 0x0a || Buffer[read - 1] == 0x0d)
+ last_lineend = Buffer + read;
+ }
+ read--;
+ }
+ if (found) {
+ byte *b = Buffer + read;
+
+ /* Success! stop now */
+ if(sscanf((char *)b, " %ld", &ctx->startxref) != 1) {
+ dmprintf(ctx->memory, "Unable to read offset of xref from PDF file\n");
+ }
+ break;
+ } else {
+ /* Our file read could conceivably have read back to the point where we read
+ * part of the 'startxref' token, but not all of it. So we want to preserve
+ * the data in the buffer, but not all of it obviously! The 'startxref' should be followed
+ * by a line ending, so above we keep a note of the last line ending. If we found one, then
+ * we preserve from the start of the buffer to that point. This could slow us up if the file
+ * Is broken, or has a load of junk after the EOF, because we could potentially be saving a
+ * lot of data on each pass, but that's only going to happen with bad files.
+ * Note we reduce the number of bytes to read so that it just fits into the buffer up to the
+ * beginning of the data we preserved.
+ */
+ if (last_lineend) {
+ leftover = last_lineend - Buffer;
+ memcpy(Buffer + bytes - leftover, last_lineend, leftover);
+ bytes -= leftover;
+ } else
+ leftover = 0;
+ }
+
+ Offset += bytes;
+ } while(Offset < ctx->main_stream_length);
+
+ if (!found)
+ pdfi_set_error(ctx, 0, NULL, E_PDF_NOSTARTXREF, "pdfi_set_input_stream", NULL);
+
+ code = pdfi_init_file(ctx);
+
+error:
+ gs_free_object(ctx->memory, Buffer, "PDF interpreter - allocate working buffer for file validation");
+ return code;
+}
+
+int pdfi_open_pdf_file(pdf_context *ctx, char *filename)
+{
+ stream *s = NULL;
+ int code;
+
+ if (ctx->args.pdfdebug)
+ dmprintf1(ctx->memory, "%% Attempting to open %s as a PDF file\n", filename);
+
+ ctx->filename = (char *)gs_alloc_bytes(ctx->memory, strlen(filename) + 1, "copy of filename");
+ if (ctx->filename == NULL)
+ return_error(gs_error_VMerror);
+ strcpy(ctx->filename, filename);
+
+ s = sfopen(filename, "r", ctx->memory);
+ if (s == NULL) {
+ emprintf1(ctx->memory, "Failed to open file %s\n", filename);
+ return_error(gs_error_ioerror);
+ }
+ code = pdfi_set_input_stream(ctx, s);
+ return code;
+}
+
+static size_t pdfi_grdir_path_string_match(const byte *str, size_t sl0, byte *pat, size_t pl)
+{
+ bool found = false;
+ size_t sl = sl0;
+
+ while (found == false) {
+ if (pl > sl)
+ break;
+ if (*str == *pat && memcmp(str, pat, pl) == 0)
+ found = true;
+ else {
+ str++;
+ sl--;
+ }
+ }
+ if (found)
+ return (sl0 - sl) + pl;
+ else
+ return 0;
+}
+
+int pdfi_add_paths_to_search_paths(pdf_context *ctx, const char *ppath, int l, bool fontpath)
+{
+ int i, slen, npaths = (l > 0);
+ const char *p = ppath;
+ char *ps;
+ const char *pe = p + l + 1;
+ int code = 0;
+ static const char *resstr = "Resource";
+ const int restrlen = strlen(resstr);
+ const char *dirsepstr = gp_file_name_directory_separator();
+ const int dirsepstrlen = strlen(dirsepstr);
+ char genresstr[64];
+
+ for (ps = (char *)p; ps < pe; ps++) {
+ if (*ps == gp_file_name_list_separator)
+ npaths++;
+ }
+
+ if (npaths > 0) {
+ gs_param_string *pathstrings;
+ int new_npaths = ctx->search_paths.num_resource_paths + npaths;
+
+ if (fontpath != true) {
+ pathstrings = (gs_param_string *)gs_alloc_bytes(ctx->memory, sizeof(gs_param_string) * new_npaths, "array of paths");
+ if (pathstrings == NULL)
+ return_error(gs_error_VMerror);
+
+ memset(pathstrings, 0x00, sizeof(gs_param_string) * new_npaths);
+
+ for (i = 1; i <= ctx->search_paths.num_init_resource_paths; i++) {
+ pathstrings[new_npaths - i] = ctx->search_paths.resource_paths[ctx->search_paths.num_resource_paths - i];
+ }
+
+ for (i = 0; i < ctx->search_paths.num_resource_paths - ctx->search_paths.num_init_resource_paths; i++) {
+ pathstrings[i] = ctx->search_paths.resource_paths[i];
+ }
+ /* NO NOT CHANGE "i" BETWEEN HERE....... */
+ gs_free_object(ctx->memory, ctx->search_paths.resource_paths, "old array of paths");
+ ctx->search_paths.resource_paths = pathstrings;
+ ctx->search_paths.num_resource_paths += npaths;
+
+ /* .....AND HERE */
+ for (ps = (char *)p; ps < pe; ps++) {
+ if (*ps == gp_file_name_list_separator || ps == pe - 1) {
+ if (*p == gp_file_name_list_separator) p++; /* move past the separator */
+ slen = ps - p;
+ pathstrings[i].data = (byte *)gs_alloc_bytes(ctx->memory, slen, "path string body");
+
+ if (pathstrings[i].data == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ break;
+ }
+
+ memcpy((char *)pathstrings[i].data, p, slen);
+ pathstrings[i].size = slen;
+ pathstrings[i].persistent = false;
+ i++;
+ p = ps++;
+ }
+ }
+ if ((restrlen + 2 * dirsepstrlen) < 64) {
+ size_t grdlen;
+
+ memcpy(genresstr, resstr, restrlen +1); /* +1 So we get the null terminator */
+ strncat(genresstr, dirsepstr, dirsepstrlen);
+
+ for (i = 0; i < ctx->search_paths.num_resource_paths; i++) {
+ if ((grdlen = pdfi_grdir_path_string_match(ctx->search_paths.resource_paths[i].data, ctx->search_paths.resource_paths[i].size, (byte *)genresstr, restrlen + dirsepstrlen)) > 0) {
+ ctx->search_paths.genericresourcedir.data = ctx->search_paths.resource_paths[i].data;
+ ctx->search_paths.genericresourcedir.size = grdlen;
+ ctx->search_paths.genericresourcedir.persistent = true;
+ break;
+ }
+ }
+ }
+ }
+ else {
+ p = ppath;
+ pathstrings = (gs_param_string *)gs_alloc_bytes(ctx->memory, sizeof(gs_param_string) * (npaths + ctx->search_paths.num_font_paths), "array of font paths");
+ if (pathstrings == NULL)
+ return_error(gs_error_VMerror);
+
+ memset(pathstrings, 0x00, sizeof(gs_param_string) * (npaths + ctx->search_paths.num_font_paths));
+
+ for (i = 0; i < ctx->search_paths.num_font_paths; i++) {
+ pathstrings[ctx->search_paths.num_font_paths + i] = ctx->search_paths.font_paths[i];
+ }
+ gs_free_object(ctx->memory, ctx->search_paths.font_paths, "old array of paths");
+ ctx->search_paths.font_paths = pathstrings;
+ ctx->search_paths.num_font_paths += npaths;
+
+ i = 0;
+ for (ps = (char *)p; ps < pe; ps++) {
+ if (*ps == gp_file_name_list_separator || ps == pe - 1) {
+ slen = ps - p;
+ pathstrings[i].data = (byte *)gs_alloc_bytes(ctx->memory, slen, "path string body");
+
+ if (pathstrings[i].data == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ break;
+ }
+
+ memcpy((char *)pathstrings[i].data, p, slen);
+ pathstrings[i].size = slen;
+ pathstrings[i].persistent = false;
+ i++;
+ p = ps++;
+ }
+ }
+ }
+ }
+
+ return code;
+}
+
+int pdfi_add_initial_paths_to_search_paths(pdf_context *ctx, const char *ppath, int l)
+{
+ int code;
+ if (ctx->search_paths.num_resource_paths != 0)
+ return_error(gs_error_invalidaccess);
+
+ code = pdfi_add_paths_to_search_paths(ctx, ppath, l, false);
+ ctx->search_paths.num_init_resource_paths = ctx->search_paths.num_resource_paths;
+
+ return code;
+}
+
+static void pdfi_free_search_paths(pdf_context *ctx)
+{
+ int i;
+ for (i = 0; i < ctx->search_paths.num_resource_paths; i++) {
+ if (ctx->search_paths.resource_paths[i].persistent == false)
+ gs_free_object(ctx->memory, (byte *)ctx->search_paths.resource_paths[i].data, "path string body");
+ }
+ for (i = 0; i < ctx->search_paths.num_font_paths; i++) {
+ if (ctx->search_paths.font_paths[i].persistent == false)
+ gs_free_object(ctx->memory, (byte *)ctx->search_paths.font_paths[i].data, "path string body");
+ }
+ gs_free_object(ctx->memory, (byte *)ctx->search_paths.resource_paths, "array of paths");
+ gs_free_object(ctx->memory, (byte *)ctx->search_paths.font_paths, "array of font paths");
+}
+
+/***********************************************************************************/
+/* Highest level functions. The context we create here is returned to the 'PL' */
+/* implementation, in future we plan to return it to PostScript by wrapping a */
+/* gargabe collected object 'ref' around it and returning that to the PostScript */
+/* world. custom PostScript operators will then be able to render pages, annots, */
+/* AcroForms etc by passing the opaque object back to functions here, allowing */
+/* the interpreter access to its context. */
+
+/* We start with routines for creating and destroying the interpreter context */
+pdf_context *pdfi_create_context(gs_memory_t *mem)
+{
+ pdf_context *ctx = NULL;
+ gs_gstate *pgs = NULL;
+ int code = 0;
+ gs_memory_t *pmem = mem->non_gc_memory;
+#if PDFI_LEAK_CHECK
+ gs_memory_status_t mstat;
+ code = gs_memory_chunk_wrap(&pmem, mem->non_gc_memory);
+ if (code < 0)
+ return NULL;
+ gs_memory_status(pmem, &mstat);
+#endif
+
+ ctx = (pdf_context *) gs_alloc_bytes(pmem, sizeof(pdf_context), "pdf_create_context");
+
+#if PDFI_LEAK_CHECK
+ ctx->memstat = mstat;
+#endif
+
+ pgs = gs_gstate_alloc(pmem);
+
+ if (!ctx || !pgs)
+ {
+ if (ctx)
+ gs_free_object(pmem, ctx, "pdf_create_context");
+ if (pgs)
+ gs_gstate_free(pgs);
+ return NULL;
+ }
+
+ memset(ctx, 0, sizeof(pdf_context));
+ ctx->memory = pmem;
+
+ ctx->stack_bot = (pdf_obj **)gs_alloc_bytes(ctx->memory, INITIAL_STACK_SIZE * sizeof (pdf_obj *), "pdf_imp_allocate_interp_stack");
+ if (ctx->stack_bot == NULL) {
+ gs_free_object(pmem, ctx, "pdf_create_context");
+ gs_gstate_free(pgs);
+ return NULL;
+ }
+ ctx->stack_size = INITIAL_STACK_SIZE;
+ ctx->stack_top = ctx->stack_bot - 1;
+ code = sizeof(pdf_obj *);
+ code *= ctx->stack_size;
+ ctx->stack_limit = ctx->stack_bot + ctx->stack_size;
+
+ code = pdfi_init_font_directory(ctx);
+ if (code < 0) {
+ gs_free_object(pmem, ctx->stack_bot, "pdf_create_context");
+ gs_free_object(pmem, ctx, "pdf_create_context");
+ gs_gstate_free(pgs);
+ return NULL;
+ }
+
+ code = gsicc_init_iccmanager(pgs);
+ if (code < 0) {
+ gs_free_object(ctx->memory, ctx->font_dir, "pdf_create_context");
+ gs_free_object(pmem, ctx->stack_bot, "pdf_create_context");
+ gs_free_object(pmem, ctx, "pdf_create_context");
+ gs_gstate_free(pgs);
+ return NULL;
+ }
+
+ ctx->pgs = pgs;
+ pdfi_gstate_set_client(ctx, pgs);
+
+ /* Declare PDL client support for high level patterns, for the benefit
+ * of pdfwrite and other high-level devices
+ */
+ ctx->pgs->have_pattern_streams = true;
+ ctx->device_state.preserve_tr_mode = 0;
+ ctx->args.notransparency = false;
+
+ ctx->main_stream = NULL;
+
+ /* Setup some flags that don't default to 'false' */
+ ctx->args.showannots = true;
+ ctx->args.preserveannots = true;
+ /* NOTE: For testing certain annotations on cluster, might want to set this to false */
+ ctx->args.printed = true; /* TODO: Should be true if OutputFile is set, false otherwise */
+
+ /* Initially, prefer the XrefStm in a hybrid file */
+ ctx->prefer_xrefstm = true;
+
+ /* We decrypt strings from encrypted files until we start a page */
+ ctx->encryption.decrypt_strings = true;
+ ctx->get_glyph_name = pdfi_glyph_name;
+ ctx->get_glyph_index = pdfi_glyph_index;
+
+ ctx->job_gstate_level = ctx->pgs->level;
+ /* Weirdly the graphics library wants us to always have two gstates, the
+ * initial state and at least one saved state. if we don't then when we
+ * grestore back to the initial state, it immediately saves another one.
+ */
+ code = gs_gsave(ctx->pgs);
+#if REFCNT_DEBUG
+ ctx->UID = 1;
+#endif
+#if CACHE_STATISTICS
+ ctx->hits = 0;
+ ctx->misses = 0;
+ ctx->compressed_hits = 0;
+ ctx->compressed_misses = 0;
+#endif
+#ifdef DEBUG
+ ctx->args.verbose_errors = ctx->args.verbose_warnings = 1;
+#endif
+ return ctx;
+}
+
+/* Purge all */
+static bool
+pdfi_fontdir_purge_all(const gs_memory_t * mem, cached_char * cc, void *dummy)
+{
+ return true;
+}
+
+#if DEBUG_CACHE
+#if DEBUG_CACHE_FREE
+static void
+pdfi_print_cache(pdf_context *ctx)
+{
+ pdf_obj_cache_entry *entry = ctx->cache_LRU, *next;
+
+ dmprintf1(ctx->memory, "CACHE: #entries=%d\n", ctx->cache_entries);
+ while(entry) {
+ next = entry->next;
+#if REFCNT_DEBUG
+ dmprintf5(ctx->memory, "UID:%ld, Object:%d, refcnt:%d, next=%p, prev=%p\n",
+ entry->o->UID, entry->o->object_num, entry->o->refcnt,
+ entry->next, entry->previous);
+#else
+ dmprintf4(ctx->memory, "Object:%d, refcnt:%d, next=%p, prev=%p\n",
+ entry->o->object_num, entry->o->refcnt,
+ entry->next, entry->previous);
+#endif
+ entry = next;
+ }
+}
+#else
+static void
+pdfi_print_cache(pdf_context *ctx)
+{}
+#endif
+#endif /* DEBUG */
+
+#if PURGE_CACHE_PER_PAGE
+void
+pdfi_purge_obj_cache(pdf_context *ctx)
+{
+ if (ctx->cache_entries != 0) {
+ pdf_obj_cache_entry *entry = ctx->cache_LRU, *next;
+
+ while(entry) {
+ next = entry->next;
+ if (entry->o->object_num != 0) {
+ ctx->xref_table->xref[entry->o->object_num].cache = NULL;
+ }
+ pdfi_countdown(entry->o);
+ ctx->cache_entries--;
+ gs_free_object(ctx->memory, entry, "pdfi_clear_context, free LRU");
+ entry = next;
+#if REFCNT_DEBUG
+ ctx->cache_LRU = entry;
+#endif
+ }
+ ctx->cache_LRU = ctx->cache_MRU = NULL;
+ ctx->cache_entries = 0;
+ }
+}
+#endif
+
+/* pdfi_clear_context frees all the PDF objects associated with interpreting a given
+ * PDF file. Once we've called this we can happily run another file. This function is
+ * called by pdf_free_context (in case of errors during the file leaving state around)
+ * and by pdfi_close_pdf_file.
+ */
+int pdfi_clear_context(pdf_context *ctx)
+{
+#if CACHE_STATISTICS
+ float compressed_hit_rate = 0.0, hit_rate = 0.0;
+
+ if (ctx->compressed_hits > 0 || ctx->compressed_misses > 0)
+ compressed_hit_rate = (float)ctx->compressed_hits / (float)(ctx->compressed_hits + ctx->compressed_misses);
+ if (ctx->hits > 0 || ctx->misses > 0)
+ hit_rate = (float)ctx->hits / (float)(ctx->hits + ctx->misses);
+
+ dmprintf1(ctx->memory, "Number of normal object cache hits: %"PRIi64"\n", ctx->hits);
+ dmprintf1(ctx->memory, "Number of normal object cache misses: %"PRIi64"\n", ctx->misses);
+ dmprintf1(ctx->memory, "Number of compressed object cache hits: %"PRIi64"\n", ctx->compressed_hits);
+ dmprintf1(ctx->memory, "Number of compressed object cache misses: %"PRIi64"\n", ctx->compressed_misses);
+ dmprintf1(ctx->memory, "Normal object cache hit rate: %f\n", hit_rate);
+ dmprintf1(ctx->memory, "Compressed object cache hit rate: %f\n", compressed_hit_rate);
+#endif
+ if (ctx->args.PageList) {
+ gs_free_object(ctx->memory, ctx->args.PageList, "pdfi_clear_context");
+ ctx->args.PageList = NULL;
+ }
+ if (ctx->Trailer) {
+ pdfi_countdown(ctx->Trailer);
+ ctx->Trailer = NULL;
+ }
+
+ if (ctx->AcroForm) {
+ pdfi_countdown(ctx->AcroForm);
+ ctx->AcroForm = NULL;
+ }
+
+ if(ctx->Root) {
+ pdfi_countdown(ctx->Root);
+ ctx->Root = NULL;
+ }
+
+ if (ctx->Info) {
+ pdfi_countdown(ctx->Info);
+ ctx->Info = NULL;
+ }
+
+ if (ctx->PagesTree) {
+ pdfi_countdown(ctx->PagesTree);
+ ctx->PagesTree = NULL;
+ }
+
+ pdfi_free_cstring_array(ctx, &ctx->args.showannottypes);
+ pdfi_free_cstring_array(ctx, &ctx->args.preserveannottypes);
+
+ pdfi_doc_page_array_free(ctx);
+
+ if (ctx->xref_table) {
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ }
+
+ pdfi_free_OptionalRoot(ctx);
+
+ if (ctx->stack_bot)
+ pdfi_clearstack(ctx);
+
+ if (ctx->filename) {
+ /* This should already be closed! */
+ pdfi_close_pdf_file(ctx);
+ gs_free_object(ctx->memory, ctx->filename, "pdfi_clear_context, free copy of filename");
+ ctx->filename = NULL;
+ }
+
+ if (ctx->main_stream) {
+ gs_free_object(ctx->memory, ctx->main_stream, "pdfi_clear_context, free main PDF stream");
+ ctx->main_stream = NULL;
+ }
+ ctx->main_stream_length = 0;
+
+ if(ctx->pgs != NULL) {
+ gx_pattern_cache_free(ctx->pgs->pattern_cache);
+ ctx->pgs->pattern_cache = NULL;
+ if (ctx->pgs->font)
+ pdfi_countdown_current_font(ctx);
+
+ /* We use gs_grestore_only() instead of gs_grestore, because gs_grestore
+ * will not restore below two gstates and we want to clear the entire
+ * stack of saved states, back to the initial state.
+ */
+ while (ctx->pgs->level != ctx->job_gstate_level && ctx->pgs->saved)
+ gs_grestore_only(ctx->pgs);
+ }
+
+ pdfi_free_DefaultQState(ctx);
+ pdfi_oc_free(ctx);
+
+ if(ctx->encryption.EKey) {
+ pdfi_countdown(ctx->encryption.EKey);
+ ctx->encryption.EKey = NULL;
+ }
+ if (ctx->encryption.Password) {
+ gs_free_object(ctx->memory, ctx->encryption.Password, "PDF Password from params");
+ ctx->encryption.Password = NULL;
+ }
+
+ if (ctx->cache_entries != 0) {
+ pdf_obj_cache_entry *entry = ctx->cache_LRU, *next;
+
+#if DEBUG_CACHE
+ int count;
+ bool stop = true;
+ pdf_obj_cache_entry *prev;
+
+ do {
+ pdfi_print_cache(ctx);
+ entry = ctx->cache_LRU;
+ stop = true;
+ while(entry) {
+ pdfi_print_cache(ctx);
+ next = entry->next;
+ prev = entry->previous;
+
+ /* pass through the cache, count down any objects which are only referenced by the cache (refcnt == 1)
+ * this may cause other objects (referred to by the newly freed object) to decrement their refcnt
+ * until they are also only pointed at by the cache.
+ */
+ if (entry->o->refcnt == 1) {
+ stop = false;
+ pdfi_countdown(entry->o);
+ if (prev != NULL)
+ prev->next = next;
+ else
+ ctx->cache_LRU = next;
+ if (next)
+ next->previous = prev;
+ ctx->cache_entries--;
+ gs_free_object(ctx->memory, entry, "pdfi_clear_context, free LRU");
+ }
+ entry = next;
+ }
+ } while (stop == false);
+
+ entry = ctx->cache_LRU;
+ while(entry) {
+ next = entry->next;
+ prev = entry->previous;
+ count = entry->o->refcnt;
+ dbgmprintf1(ctx->memory, "CLEANUP cache entry obj %d", entry->o->object_num);
+ dbgmprintf1(ctx->memory, " has refcnt %d\n", count);
+ entry = next;
+ }
+#else
+ while(entry) {
+ next = entry->next;
+ pdfi_countdown(entry->o);
+ ctx->cache_entries--;
+ gs_free_object(ctx->memory, entry, "pdfi_clear_context, free LRU");
+ entry = next;
+#if REFCNT_DEBUG
+ ctx->cache_LRU = entry;
+#endif
+ }
+#endif
+ ctx->cache_LRU = ctx->cache_MRU = NULL;
+ ctx->cache_entries = 0;
+ }
+
+ /* We can't free the font directory before the graphics library fonts fonts are freed, as they reference the font_dir.
+ * graphics library fonts are refrenced from pdf_font objects, and those may be in the cache, which means they
+ * won't be freed until we empty the cache. So we can't free 'font_dir' until after the cache has been cleared.
+ */
+ if (ctx->font_dir)
+ gx_purge_selected_cached_chars(ctx->font_dir, pdfi_fontdir_purge_all, (void *)NULL);
+
+ pdfi_countdown(ctx->pdffontmap);
+ ctx->pdffontmap = NULL;
+
+ return 0;
+}
+
+int pdfi_free_context(pdf_context *ctx)
+{
+#if PDFI_LEAK_CHECK
+ gs_memory_status_t mstat, ctxmstat = ctx->memstat;
+ gs_memory_t *mem = ctx->memory;
+#endif
+ pdfi_clear_context(ctx);
+
+ gs_free_object(ctx->memory, ctx->stack_bot, "pdfi_free_context");
+
+ pdfi_free_name_table(ctx);
+
+ /* And here we free the initial graphics state */
+ while (ctx->pgs->saved)
+ gs_grestore_only(ctx->pgs);
+
+ gs_gstate_free(ctx->pgs);
+
+ ctx->pgs = NULL;
+
+ if (ctx->font_dir)
+ gs_free_object(ctx->memory, ctx->font_dir, "pdfi_free_context");
+
+ /* Currently this should never happen, but in future it might if we choose
+ * not to keep freeing and reallocating the array.
+ */
+ if (ctx->loop_detection != NULL) {
+ dbgmprintf(ctx->memory, "Loop detection array exists at EOJ\n");
+ gs_free_object(ctx->memory, ctx->loop_detection, "pdfi_free_context");
+ }
+
+ pdfi_free_search_paths(ctx);
+
+ gs_free_object(ctx->memory, ctx, "pdfi_free_context");
+#if PDFI_LEAK_CHECK
+ gs_memory_status(mem, &mstat);
+ if (mstat.allocated > ctxmstat.allocated)
+ errprintf(mem, "\nMemory Leak Detected: Pre %d, Post %d\n", (int)ctxmstat.allocated, (int)mstat.allocated);
+ (void)gs_memory_chunk_unwrap(mem);
+#endif
+ return 0;
+}
+
+/* These routines are used from the PostScript interpreter inteerface. It is important that
+ * the 'interpreter part of the graphics state' should be a pdfi interpreter context while pdfi is running
+ * but the PostScript itnerpreter context when the PostScript interpreter is running. If we are going
+ * to inherit the PostScript graphics state for pdfi, then we need to turn it into a 'pdfi'
+ * graphics state for the duration of the interpretation, and back to a PostScript one when
+ * we return to the PostScript interpreter.
+ *
+ * Bizarrely it appears that the interpreter part of the gstate does not obey grestore, instead we copy
+ * the 'current' context to the saved context when we do a grestore. This seems wrong to me, but
+ * it seems to be what happens, so we can't rely on grestore to put back the interpreter context, but must
+ * do so ourselves.
+ *
+ * Hence the 'from_PS' routine fills in pointers with the current context and procs, wit the expectation that
+ * these will be saved and used to restore the data in the 'to_PS' routine.
+ */
+void pdfi_gstate_from_PS(pdf_context *ctx, gs_gstate *pgs, void **saved_client_data, gs_gstate_client_procs *saved_procs)
+{
+ *saved_client_data = pgs->client_data;
+ *saved_procs = pgs->client_procs;
+ pdfi_gstate_set_client(ctx, pgs);
+ return;
+}
+
+void pdfi_gstate_to_PS(pdf_context *ctx, gs_gstate *pgs, void *client_data, const gs_gstate_client_procs *procs)
+{
+ pgs->client_procs.free(pgs->client_data, pgs->memory, pgs);
+ pgs->client_data = NULL;
+ gs_gstate_set_client(pgs, client_data, procs, true);
+ return;
+}
diff --git a/pdf/ghostpdf.h b/pdf/ghostpdf.h
new file mode 100644
index 00000000..3cc1b8cd
--- /dev/null
+++ b/pdf/ghostpdf.h
@@ -0,0 +1,537 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+
+#ifndef PDF_CONTEXT
+#define PDF_CONTEXT
+
+#include "gserrors.h" /* Most files use this to set errors of the gs_error_ form */
+#include "gxgstate.h"
+
+#define BUF_SIZE 2048
+
+#include "pdf_types.h"
+
+#if defined(MEMENTO)
+#define PDFI_LEAK_CHECK 0
+#endif
+
+#ifndef PDFI_LEAK_CHECK
+#define PDFI_LEAK_CHECK 0
+#endif
+
+/*
+ * The interpreter context.
+ */
+/* Warnings and errors. The difference between a warning and an error is that we use a warning where
+ * the file is technically illegal but we can be certain as to the real intent. At the time of writing
+ * the only case is also a perfect example; the use of an inline image filter abbreviation (eg A85)
+ * on a stream or object which is not an inline image. Although technically incorrect, its obvious
+ * how to deal with this.
+ */
+typedef enum pdf_error_e {
+ E_PDF_NOERROR,
+ E_PDF_NOHEADER,
+ E_PDF_NOHEADERVERSION,
+ E_PDF_NOSTARTXREF,
+ E_PDF_BADSTARTXREF,
+ E_PDF_BADXREFSTREAM,
+ E_PDF_BADXREF,
+ E_PDF_SHORTXREF,
+ E_PDF_MISSINGENDSTREAM,
+ E_PDF_UNKNOWNFILTER,
+ E_PDF_MISSINGWHITESPACE,
+ E_PDF_MALFORMEDNUMBER,
+ E_PDF_UNESCAPEDSTRING,
+ E_PDF_BADOBJNUMBER,
+ E_PDF_MISSINGENDOBJ,
+ E_PDF_TOKENERROR,
+ E_PDF_KEYWORDTOOLONG,
+ E_PDF_BADPAGETYPE,
+ E_PDF_CIRCULARREF,
+ E_PDF_UNREPAIRABLE,
+ E_PDF_REPAIRED,
+ E_PDF_BADSTREAM,
+ E_PDF_MISSINGOBJ,
+ E_PDF_BADPAGEDICT,
+ E_PDF_OUTOFMEMORY,
+ E_PDF_PAGEDICTERROR,
+ E_PDF_STACKUNDERFLOWERROR,
+ E_PDF_BADSTREAMDICT,
+ E_PDF_INHERITED_STREAM_RESOURCE,
+ E_PDF_DEREF_FREE_OBJ,
+ E_PDF_INVALID_TRANS_XOBJECT,
+ E_PDF_NO_SUBTYPE,
+ E_PDF_IMAGECOLOR_ERROR,
+ E_PDF_MAX_ERROR /* Must be last entry, add new errors immediately before this and update pdf_error_strings in ghostpdf.c */
+}pdf_error;
+
+typedef enum pdf_warning_e {
+ W_PDF_NOWARNING,
+ W_PDF_BAD_XREF_SIZE,
+ W_PDF_BAD_INLINEFILTER,
+ W_PDF_BAD_INLINECOLORSPACE,
+ W_PDF_BAD_INLINEIMAGEKEY,
+ W_PDF_IMAGE_ERROR,
+ W_PDF_BAD_IMAGEDICT,
+ W_PDF_TOOMANYQ,
+ W_PDF_TOOMANYq,
+ W_PDF_STACKGARBAGE,
+ W_PDF_STACKUNDERFLOW,
+ W_PDF_GROUPERROR,
+ W_PDF_OPINVALIDINTEXT,
+ W_PDF_NOTINCHARPROC,
+ W_PDF_NESTEDTEXTBLOCK,
+ W_PDF_ETNOTEXTBLOCK,
+ W_PDF_TEXTOPNOBT,
+ W_PDF_DEGENERATETM,
+ W_PDF_BADICC_USE_ALT,
+ W_PDF_BADICC_USECOMPS,
+ W_PDF_BADTRSWITCH,
+ W_PDF_BADSHADING,
+ W_PDF_BADPATTERN,
+ W_PDF_NONSTANDARD_OP,
+ W_PDF_NUM_EXPONENT,
+ W_PDF_STREAM_HAS_CONTENTS,
+ W_PDF_STREAM_BAD_DECODEPARMS,
+ W_PDF_MASK_ERROR,
+ W_PDF_ANNOT_AP_ERROR,
+ W_PDF_BAD_NAME_ESCAPE,
+ W_PDF_TYPECHECK,
+ W_PDF_BAD_TRAILER,
+ W_PDF_ANNOT_ERROR,
+ W_PDF_BAD_ICC_PROFILE_LINK,
+ W_PDF_OVERFLOW_REAL,
+ W_PDF_INVALID_REAL,
+ W_PDF_DEVICEN_USES_ALL,
+ W_PDF_BAD_MEDIABOX,
+ W_PDF_MAX_WARNING /* Must be last entry, add new warnings immediately before this and update pdf_warning_strings in ghostpdf.c */
+} pdf_warning;
+
+#define PDF_ERROR_BYTE_SIZE ((E_PDF_MAX_ERROR - 1) / (sizeof(char) * 8) + 1)
+#define PDF_WARNING_BYTE_SIZE ((W_PDF_MAX_WARNING - 1) / (sizeof(char) * 8) + 1)
+
+typedef enum pdf_crypt_filter_e {
+ CRYPT_NONE, /* Not an encrypted file */
+ CRYPT_IDENTITY, /* Encrypted file, but no encryption on this object type */
+ CRYPT_V1, /* 40-bit RC4 */
+ CRYPT_V2, /* 128-bit RC4 */
+ CRYPT_AESV2, /* 128-bit AES */
+ CRYPT_AESV3, /* 256-bit AES */
+} pdf_crypt_filter;
+
+
+typedef enum pdf_overprint_control_e {
+ PDF_OVERPRINT_ENABLE = 0,/* Default */
+ PDF_OVERPRINT_DISABLE,
+ PDF_OVERPRINT_SIMULATE
+} pdf_overprint_control_t;
+
+#define INITIAL_STACK_SIZE 32
+#define MAX_STACK_SIZE 524288
+#define MAX_OBJECT_CACHE_SIZE 200
+#define INITIAL_LOOP_TRACKER_SIZE 32
+
+typedef struct pdf_transfer_s {
+ gs_mapping_proc proc; /* typedef is in gxtmap.h */
+ frac values[transfer_map_size];
+} pdf_transfer_t;
+
+/* Items we want preserved around content stream executions */
+typedef struct stream_save_s {
+ gs_offset_t stream_offset;
+ int gsave_level;
+ int stack_count;
+ gs_matrix intial_CTM;
+ int group_depth;
+} stream_save;
+
+typedef struct name_entry_s {
+ char *name;
+ int len;
+ unsigned int index;
+ void *next;
+} pdfi_name_entry_t;
+
+typedef struct cmd_args_s {
+ /* These are various command line switches, the list is not yet complete */
+ int first_page; /* -dFirstPage= */
+ int last_page; /* -dLastPage= */
+ bool pdfdebug;
+ bool pdfstoponerror;
+ bool pdfstoponwarning;
+ bool notransparency;
+ bool nocidfallback;
+ bool no_pdfmark_outlines; /* can be overridden to true if multi-page output */
+ bool no_pdfmark_dests; /* can be overridden to true if multi-page output */
+ bool pdffitpage;
+ bool usecropbox;
+ bool useartbox;
+ bool usebleedbox;
+ bool usetrimbox;
+ bool printed;
+ bool showacroform;
+ bool showannots;
+ char **showannottypes; /* Null terminated array of strings, NULL if none */
+ bool dopdfmarks;
+ bool preserveannots;
+ char **preserveannottypes; /* Null terminated array of strings, NULL if none */
+ bool nouserunit;
+ bool renderttnotdef;
+ bool pdfinfo;
+ bool UsePDFX3Profile;
+ bool NOSUBSTDEVICECOLORS;
+ bool ditherppi;
+ int PDFX3Profile_num;
+ char *UseOutputIntent;
+ pdf_overprint_control_t overprint_control; /* Overprint -- enabled, disabled, simulated */
+ char *PageList;
+ bool QUIET;
+ bool verbose_errors;
+ bool verbose_warnings;
+} cmd_args_t;
+
+typedef struct encryption_state_s {
+ /* Encryption, passwords and filter details */
+ bool is_encrypted;
+ int V;
+ int Length;
+ char *Password;
+ int PasswordLen;
+ int R;
+ /* Revision 1-4 have O and E being 32 bytes, revision 5 and 6 48 bytes */
+ char O[48];
+ char U[48];
+ /* OE and UE are used for revision 5 and 6 encryption */
+ char OE[32];
+ char UE[32];
+ int P;
+ pdf_string *EKey;
+ bool EncryptMetadata;
+ pdf_crypt_filter StrF;
+ pdf_crypt_filter StmF;
+ /* decrypting strings is complicated :-(
+ * Streams are easy, because they can't be in compressed ObjStms, and they
+ * have to be indirect objects. Strings can be indirect references or directly
+ * defined, can be in compressed ObjStms and can appear inside content streams.
+ * When they are in content streams we don't decrypt them, because the *stream*
+ * was already decrypted. So when strings are directly or indirectly defined,
+ * and *NOT* defined as part of a content stream, and not in an Objstm, we
+ * need to decrypt them. We can handle the checking for ObjStm in the actual
+ * decryption routine, where we also handle picking out the object number of the
+ * enclosing parent, if its a directly defined string, but we cannot tell
+ * whether we are executing a content stream or not, so we need to know that. This
+ * flag is set whenever we are executing a content stream, it is temporarily reset
+ * by pdfi_dereference() because indirect references can't appear in a content stream
+ * so we know we need to decrypt any strings that are indirectly referenced. Note that
+ * Form handling needs to set this flag for the duration of a Form content stream,
+ * because we can execute Forms outside a page context (eg Annotations).
+ */
+ bool decrypt_strings;
+} encryption_state_t;
+
+typedef struct page_state_s {
+ /* Page level PDF objects */
+ /* DefaultGray, RGB and CMYK spaces */
+ gs_color_space *DefaultGray_cs;
+ gs_color_space *DefaultRGB_cs;
+ gs_color_space *DefaultCMYK_cs;
+ /* Last-ditch resource lookup */
+ pdf_dict *CurrentPageDict;
+ /* Page leve 'Default' transfer functions, black generation and under colour removal */
+ pdf_transfer_t DefaultTransfers[4];
+ pdf_transfer_t DefaultBG;
+ pdf_transfer_t DefaultUCR;
+ /* This tracks whether the current page uses transparency features */
+ bool has_transparency;
+ /* This tracks how many spots are on the current page */
+ int num_spots;
+ /* Does this page need overprint support? */
+ bool needs_OP;
+ /* Does this page have OP=true in ExtGState? */
+ bool has_OP;
+ /* Are we simulating overprint on this page? */
+ bool simulate_op;
+ double Size[4];
+ double Crop[4];
+ double UserUnit;
+} page_state_t;
+
+typedef struct text_state_s {
+ /* we need the text enumerator in order to call gs_text_setcharwidth() for d0 and d1 */
+ gs_text_enum_t *current_enum;
+ /* Detect if we are inside a text block at any time. Nested text blocks are illegal and certain
+ * marking operations are illegal inside text blocks. We also manipulate this when rendering
+ * type 3 BuildChar procedures, as those marking operations are legal in a BuildChar, even
+ * when we are in a text block.
+ */
+ int BlockDepth;
+ /* This is to determine if we get Type 3 Charproc operators (d0 and d1) outside
+ * a Type 3 BuildChar.
+ */
+ bool inside_CharProc;
+ /* We need to know if we're in a type 3 CharProc which has executed a 'd1' operator.
+ * Colour operators are technically invalid if we are in a 'd1' context and we must
+ * ignore them.
+ */
+ bool CharProc_is_d1;
+ /* If there is no current point when we do a BT we start by doing a 0 0 moveto in order
+ * to establish an initial point. However, this also starts a path. When we finish
+ * off with a BT we need to clear that path by doing a newpath, otherwise we might
+ * end up drawing it. See /tests_private/comparefiles/Bug692867.pdf
+ * We store the initial current poitn validity and if t was not initially valid
+ * (ie no path) then we do a newpath on a ET.
+ * BT/ET are not supposed to be nested, and path construction is not permitted inside
+ * a BT/ET block.
+ */
+ bool initial_current_point_valid;
+} text_state_t;
+
+typedef struct device_state_s {
+ /* Parameters/capabilities of the selected device */
+ /* Needed to determine whether we need to reset the device to handle any spots
+ * and whether we need to prescan the PDF file to determine how many spot colourants
+ * (if any) are used in the file.
+ */
+ bool spot_capable;
+ /* for avoiding charpath with pdfwrite */
+ bool preserve_tr_mode;
+ /* Are SMask's preserved by device (pdfwrite) */
+ bool preserve_smask;
+ bool ForOPDFRead;
+ bool pdfmark;
+ bool HighLevelDevice;
+ /* These are derived from the device parameters rather than extracted from the device */
+ /* But this is a convenient place to keep them. */
+ /* Does current output device handle pdfmark */
+ bool writepdfmarks;
+ /* Should annotations be preserved or marked for current output device? */
+ bool annotations_preserved;
+} device_state_t;
+
+/*
+ * resource_paths: for CMaps, iccprofiles, fonts... mainly build time settings and from
+ * "-I" command line options.
+ * font_paths: Specific to fonts: from the -sFONTPATH=<> option
+ * We keep a running count (num_resource_paths) of all, and a one off count of paths that
+ * came from the build (num_init_resource_paths) so we can keep the (weird) search order
+ * that gs uses.
+ */
+typedef struct search_paths_s
+{
+ gs_param_string *resource_paths;
+ int num_resource_paths; /* total */
+ int num_init_resource_paths; /* number of paths that came from the build */
+ gs_param_string *font_paths;
+ int num_font_paths;
+ gs_param_string genericresourcedir;
+ bool search_here_first;
+} search_paths_t;
+
+typedef struct pdf_context_s
+{
+ void *instance;
+ gs_memory_t *memory;
+
+ /* command line argument storage */
+ cmd_args_t args;
+
+ /* Encryption state */
+ encryption_state_t encryption;
+
+ /* Text and text state parameters */
+ text_state_t text;
+
+ /* The state of the current page being processed */
+ page_state_t page;
+
+ device_state_t device_state;
+
+
+ /* PDF interpreter state */
+
+ /* State for handling the wacky W and W* operators */
+ bool clip_active;
+ bool do_eoclip;
+
+ /* Doing a high level form for pdfwrite (annotations) */
+ bool PreservePDFForm;
+
+ /* Optional things from Root */
+ pdf_dict *OCProperties;
+ pdf_dict *Collection;
+
+ /* Optional/Marked Content stuff */
+ void *OFFlevels;
+ uint64_t BMClevel;
+
+ /* Bitfields recording whether any errors or warnings were encountered */
+ char pdf_errors[PDF_ERROR_BYTE_SIZE];
+ char pdf_warnings[PDF_WARNING_BYTE_SIZE];
+
+ /* We need a gs_font_dir for gs_definefotn() */
+ gs_font_dir * font_dir;
+ /* Obviously we need a graphics state */
+ gs_gstate *pgs;
+ /* set up by pdf_impl_set_device, this is the 'high water mark' for
+ * restoring back to when we close a PDF file. This ensures the device
+ * is correctly set up for any subesquent file to be run.
+ */
+ int job_gstate_level;
+ /* This is currently used for Patterns, but I suspect needs to be changed to use
+ * 'the enclosing context'
+ */
+ gs_gstate *DefaultQState;
+
+
+ /* The input PDF filename and the stream for it */
+ char *filename;
+ pdf_c_stream *main_stream;
+
+ /* Length of the main file */
+ gs_offset_t main_stream_length;
+ /* offset to the xref table */
+ gs_offset_t startxref;
+
+ /* Track whether file is a hybrid. Initially prefer XRefStm but
+ * if we fail to read the structure using an XRefStm, try again
+ * using the xref
+ */
+ bool prefer_xrefstm;
+ bool is_hybrid;
+ /* If we've already repaired the file once, and it still fails, don't try to repair it again */
+ bool repaired;
+
+ /* The HeaderVersion is the declared version from the PDF header, but this
+ * can be overridden by later trailer dictionaries, so the FinalVersion is
+ * the version as finally read from the file. Note we don't currently use
+ * these for anything, we might in future emit warnings if PDF files use features
+ * inconsistent with the FinalVersion.
+ */
+ float HeaderVersion, FinalVersion;
+
+ /* Document level PDF objects */
+ xref_table_t *xref_table;
+ pdf_dict *Trailer;
+ pdf_dict *Root;
+ pdf_dict *Info;
+ pdf_dict *PagesTree;
+ uint64_t num_pages;
+ uint32_t *page_array; /* cache of page dict object_num's for pdfmark Dest */
+ pdf_dict *AcroForm;
+ bool NeedAppearances; /* From AcroForm, if any */
+
+
+ /* Interpreter level PDF objects */
+
+ /* The interpreter operand stack */
+ uint32_t stack_size;
+ pdf_obj **stack_bot;
+ pdf_obj **stack_top;
+ pdf_obj **stack_limit;
+
+ /* The object cache */
+ uint32_t cache_entries;
+ pdf_obj_cache_entry *cache_LRU;
+ pdf_obj_cache_entry *cache_MRU;
+
+ /* The loop detection state */
+ uint32_t loop_detection_size;
+ uint32_t loop_detection_entries;
+ uint64_t *loop_detection;
+
+ /* Used to set the 'parent' stream of a stream that gets created by dereferencing
+ * We should not need this but badly fromed PDF files can use Resources defined in
+ * an earlier (non-Page) stream object, and Acrobat handles this, so we need to.
+ * We could haev done this more neatly if we'd known this during design :-(
+ */
+ pdf_stream *current_stream;
+ stream_save current_stream_save;
+
+ /* A name table :-( */
+ pdfi_name_entry_t *name_table;
+
+ search_paths_t search_paths;
+ pdf_dict *pdffontmap;
+
+ /* These function pointers can be replaced by ones intended to replicate
+ * PostScript functionality when running inside the Ghostscript PostScript
+ * interpreter.
+ */
+ int (*finish_page) (struct pdf_context_s *ctx);
+ int (*get_glyph_name)(gs_font *font, gs_glyph index, gs_const_string *pstr);
+ int (*get_glyph_index)(gs_font *font, byte *str, uint size, uint *glyph);
+
+#if REFCNT_DEBUG
+ uint64_t UID;
+#endif
+#if CACHE_STATISTICS
+ uint64_t hits;
+ uint64_t misses;
+ uint64_t compressed_hits;
+ uint64_t compressed_misses;
+#endif
+#if PDFI_LEAK_CHECK
+ gs_memory_status_t memstat;
+#endif
+}pdf_context;
+
+#define OBJ_CTX(o) ((pdf_context *)(o->ctx))
+#define OBJ_MEMORY(o) OBJ_CTX(o)->memory
+
+int pdfi_add_paths_to_search_paths(pdf_context *ctx, const char *ppath, int l, bool fontpath);
+int pdfi_add_initial_paths_to_search_paths(pdf_context *ctx, const char *ppath, int l);
+
+pdf_context *pdfi_create_context(gs_memory_t *pmem);
+int pdfi_clear_context(pdf_context *ctx);
+int pdfi_free_context(pdf_context *ctx);
+
+int pdfi_get_name_index(pdf_context *ctx, char *name, int len, unsigned int *returned);
+int pdfi_name_from_index(pdf_context *ctx, int index, unsigned char **name, unsigned int *len);
+int pdfi_separation_name_from_index(gs_gstate *pgs, gs_separation_name index, unsigned char **name, unsigned int *len);
+int pdfi_open_pdf_file(pdf_context *ctx, char *filename);
+int pdfi_set_input_stream(pdf_context *ctx, stream *stm);
+int pdfi_process_pdf_file(pdf_context *ctx, char *filename);
+int pdfi_prep_collection(pdf_context *ctx, uint64_t *TotalFiles, char ***names_array);
+int pdfi_close_pdf_file(pdf_context *ctx);
+void pdfi_gstate_from_PS(pdf_context *ctx, gs_gstate *pgs, void **saved_client_data, gs_gstate_client_procs *saved_procs);
+void pdfi_gstate_to_PS(pdf_context *ctx, gs_gstate *pgs, void *client_data, const gs_gstate_client_procs *procs);
+
+void pdfi_verbose_error(pdf_context *ctx, int gs_error, const char *gs_lib_function, int pdfi_error, const char *pdfi_function_name, const char *extra_info);
+void pdfi_verbose_warning(pdf_context *ctx, int gs_error, const char *gs_lib_function, int pdfi_warning, const char *pdfi_function_name, const char *extra_info);
+void pdfi_log_info(pdf_context *ctx, const char *pdfi_function, const char *info);
+
+static inline void pdfi_set_error(pdf_context *ctx, int gs_error, const char *gs_lib_function, pdf_error pdfi_error, const char *pdfi_function_name, const char *extra_info)
+{
+ if (pdfi_error != 0)
+ ctx->pdf_errors[pdfi_error / (sizeof(char) * 8)] |= 1 << pdfi_error % (sizeof(char) * 8);
+ if (ctx->args.verbose_errors)
+ pdfi_verbose_error(ctx, gs_error, gs_lib_function, pdfi_error, pdfi_function_name, extra_info);
+}
+
+static inline void pdfi_set_warning(pdf_context *ctx, int gs_error, const char *gs_lib_function, pdf_warning pdfi_warning, const char *pdfi_function_name, const char *extra_info)
+{
+ ctx->pdf_warnings[pdfi_warning / (sizeof(char) * 8)] |= 1 << pdfi_warning % (sizeof(char) * 8);
+ if (ctx->args.verbose_warnings)
+ pdfi_verbose_warning(ctx, gs_error, gs_lib_function, pdfi_warning, pdfi_function_name, extra_info);
+}
+
+#define PURGE_CACHE_PER_PAGE 0
+
+#if PURGE_CACHE_PER_PAGE
+void pdfi_purge_obj_cache(pdf_context *ctx);
+#endif
+
+#endif
diff --git a/pdf/pdf.mak b/pdf/pdf.mak
new file mode 100644
index 00000000..ccb70916
--- /dev/null
+++ b/pdf/pdf.mak
@@ -0,0 +1,340 @@
+# Copyright (C) 2018-2021 Artifex Software, Inc.
+# All Rights Reserved.
+#
+# This software is provided AS-IS with no warranty, either express or
+# implied.
+#
+# This software is distributed under license and may not be copied,
+# modified or distributed except as expressly authorized under the terms
+# of the license contained in the file LICENSE in this distribution.
+#
+# Refer to licensing information at http://www.artifex.com or contact
+# Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+# CA 94945, U.S.A., +1(415)492-9861, for further information.
+#
+# Platform-independent makefile for the PDF interpreter
+
+PDFSRC = $(PDFSRCDIR)$(D)
+PDFGEN = $(PDFGENDIR)$(D)
+PDFOBJ = $(PDFOBJDIR)$(D)
+PDFO_ = $(O_)$(PDFOBJ)
+PLOBJ = $(PLOBJDIR)$(D)
+
+PDFCCC_WIN = $(CC) $(ZM) $(JPX_CFLAGS) $(D_)PDF_INCLUDED$(_D) $(I_)$(PDFSRCDIR)$(_I) $(I_)$(PDFGENDIR)$(_I) \
+ $(I_)$(PLSRCDIR)$(_I) $(I_)$(GLSRCDIR)$(_I) \
+ $(I_)$(EXPATINCDIR)$(_I) $(I_)$(JPEGXR_SRCDIR)$(_I) $(I_)$(ZSRCDIR)$(_I) \
+ $(I_)$(JPX_OPENJPEG_I_)$(_I) $(I_)$(JB2I_)$(_I) $(C_)
+
+PDFCCC = $(CC_) $(JPX_CFLAGS) $(D_)PDF_INCLUDED$(_D) $(I_)$(PDFSRCDIR)$(_I) $(I_)$(PDFGENDIR)$(_I) \
+ $(I_)$(PLSRCDIR)$(_I) $(I_)$(GLSRCDIR)$(_I) \
+ $(I_)$(EXPATINCDIR)$(_I) $(I_)$(JPEGXR_SRCDIR)$(_I) $(I_)$(ZSRCDIR)$(_I) \
+ $(I_)$(JPX_OPENJPEG_I_)$(_I) $(I_)$(JB2I_)$(_I) $(C_)
+
+PDFJB2CC=$(CC_) $(JPX_CFLAGS) $(D_)PDF_INCLUDED$(_D) $(I_)$(PDFSRCDIR)$(_I) $(I_)$(PDFGENDIR)$(_I) \
+ $(I_)$(PLSRCDIR)$(_I) $(I_)$(GLSRCDIR)$(_I) \
+ $(I_)$(EXPATINCDIR)$(_I) $(I_)$(JPEGXR_SRCDIR)$(_I) $(I_)$(ZSRCDIR)$(_I) \
+ $(I_)$(JPX_OPENJPEG_I_)$(_I) $(I_)$(JB2I_)$(_I) $(JB2CF_) $(C_)
+
+PDFLURCC=$(CC_) $(JPX_CFLAGS) $(D_)PDF_INCLUDED$(_D) $(I_)$(PDFSRCDIR)$(_I) $(I_)$(PDFGENDIR)$(_I) \
+ $(I_)$(PLSRCDIR)$(_I) $(I_)$(GLSRCDIR)$(_I) \
+ $(I_)$(EXPATINCDIR)$(_I) $(I_)$(JPEGXR_SRCDIR)$(_I) $(I_)$(ZSRCDIR)$(_I) \
+ $(I_)$(LWF_JPXI_)$(_I) $(I_)$(LDF_JB2I_)$(_I) $(JB2CF_) $(C_)
+
+# Define the name of this makefile.
+PDF_MAK = $(PDFSRC)pdf.mak $(TOP_MAKEFILES)
+
+PDF.clean: PDF.config-clean PDF.clean-not-config-clean
+
+PDF.clean-not-config-clean:
+ $(RM_) $(PDFOBJ)*.$(OBJ)
+
+PDF.config-clean: clean_gs
+ $(RM_) $(PDFOBJ)*.dev
+ $(RM_) $(PDFOBJ)devs.tr5
+
+PDF_TOP_OBJ=$(PDFOBJDIR)$(D)pdftop.$(OBJ)
+PDF_TOP_OBJS= $(PDF_TOP_OBJ) $(PDFOBJDIR)$(D)pdfimpl.$(OBJ)
+
+PDFINCLUDES=$(PDFSRC)*.h $(GLGEN)arch.h $(strmio_h) $(stream_h) $(gsmatrix_h) $(gslparam_h)\
+ $(gstypes_h) $(szlibx_h) $(spngpx_h) $(sstring_h) $(sa85d_h) $(scfx_h) $(srlx_h)\
+ $(jpeglib__h) $(sdct_h) $(spdiffx_h)
+
+$(PDFOBJ)ghostpdf.$(OBJ): $(PDFSRC)ghostpdf.c $(PDFINCLUDES) $(plmain_h) $(stream_h) $(strmio_h) \
+ $(gsmchunk_h) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)ghostpdf.c $(PDFO_)ghostpdf.$(OBJ)
+
+$(PDFOBJ)pdf_dict.$(OBJ): $(PDFSRC)pdf_dict.c $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_dict.c $(PDFO_)pdf_dict.$(OBJ)
+
+$(PDFOBJ)pdf_array.$(OBJ): $(PDFSRC)pdf_array.c $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_array.c $(PDFO_)pdf_array.$(OBJ)
+
+$(PDFOBJ)pdf_xref.$(OBJ): $(PDFSRC)pdf_xref.c $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_xref.c $(PDFO_)pdf_xref.$(OBJ)
+
+$(PDFOBJ)pdf_fapi.$(OBJ): $(PDFSRC)pdf_fapi.c $(PDFINCLUDES) \
+ $(memory__h) $(gsmemory_h) $(gserrors_h) $(gxdevice_h) $(gxfont_h) $(gxfcid_h) \
+ $(gzstate_h) $(gxchar_h) $(gdebug_h) $(gxfapi_h) $(gscoord_h) $(gspath_h) $(gscencs_h) \
+ $(gsagl_h) \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_fapi.c $(PDFO_)pdf_fapi.$(OBJ)
+
+$(PDFOBJ)pdf_font.$(OBJ): $(PDFSRC)pdf_font.c $(PDFINCLUDES) $(PDF_MAK) \
+ $(gscencs_h) $(stream_h) $(strmio_h) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_font.c $(PDFO_)pdf_font.$(OBJ)
+
+$(PDFOBJ)pdf_font0.$(OBJ): $(PDFSRC)pdf_font0.c $(PDFINCLUDES) $(PDF_MAK) \
+ $(gxfont_h) $(gxfont0_h) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_font0.c $(PDFO_)pdf_font0.$(OBJ)
+
+$(PDFOBJ)pdf_ciddec.$(OBJ): $(PDFSRC)pdf_ciddec.c $(PDFINCLUDES) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_ciddec.c $(PDFO_)pdf_ciddec.$(OBJ)
+
+$(PDFOBJ)pdf_font1.$(OBJ): $(PDFSRC)pdf_font1.c $(PDFINCLUDES) \
+ $(gsgdata_h) $(gstype1_h) $(gscencs_h) $(strmio_h) $(strimpl_h) $(stream_h) \
+ $(sfilter_h) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_font1.c $(PDFO_)pdf_font1.$(OBJ)
+
+$(PDFOBJ)pdf_font1C.$(OBJ): $(PDFSRC)pdf_font1C.c $(PDFINCLUDES) \
+ $(gscedata_h) $(gscencs_h) $(gxfont0_h) $(gxfcid_h) \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_font1C.c $(PDFO_)pdf_font1C.$(OBJ)
+
+$(PDFOBJ)pdf_fontps.$(OBJ): $(PDFSRC)pdf_fontps.c $(PDFINCLUDES) \
+ $(scanchar_h) $(strimpl_h) $(stream_h) $(sfilter_h) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_fontps.c $(PDFO_)pdf_fontps.$(OBJ)
+
+$(PDFOBJ)pdf_font3.$(OBJ): $(PDFSRC)pdf_font3.c $(PDFINCLUDES) \
+ $(gscencs_h) $(gscedata_h) $(gsccode_h) $(gsuid_h) \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_font3.c $(PDFO_)pdf_font3.$(OBJ)
+
+$(PDFOBJ)pdf_fontTT.$(OBJ): $(PDFSRC)pdf_fontTT.c $(PDFINCLUDES) \
+ $(gxfont42_h) $(gscencs_h) $(gsagl_h) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_fontTT.c $(PDFO_)pdf_fontTT.$(OBJ)
+
+$(PDFOBJ)pdf_font9.$(OBJ): $(PDFSRC)pdf_font9.c $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_font9.c $(PDFO_)pdf_font9.$(OBJ)
+
+$(PDFOBJ)pdf_font11.$(OBJ): $(PDFSRC)pdf_font11.c $(PDFINCLUDES) $(gxfont42_h) \
+ $(gxfcid_h) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_font11.c $(PDFO_)pdf_font11.$(OBJ)
+
+$(PDFOBJ)pdf_cmap.$(OBJ): $(PDFSRC)pdf_cmap.c $(PDFINCLUDES) \
+ $(strmio_h) $(stream_h) $(scanchar_h) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_cmap.c $(PDFO_)pdf_cmap.$(OBJ)
+
+$(PDFOBJ)pdf_fmap.$(OBJ): $(PDFSRC)pdf_fmap.c $(PDFINCLUDES) \
+ $(strmio_h) $(stream_h) $(scanchar_h) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_fmap.c $(PDFO_)pdf_fmap.$(OBJ)
+
+$(PDFOBJ)pdf_text.$(OBJ): $(PDFSRC)pdf_text.c $(PDFINCLUDES) \
+ $(gsstate_h) $(gsmatrix_h) $(gdevbbox_h) \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_text.c $(PDFO_)pdf_text.$(OBJ)
+
+$(PDFOBJ)pdf_shading.$(OBJ): $(PDFSRC)pdf_shading.c $(PDFINCLUDES) \
+ $(gxshade_h) $(gsptype2_h) $(gsfunc0_h) \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_shading.c $(PDFO_)pdf_shading.$(OBJ)
+
+$(PDFOBJ)pdf_func.$(OBJ): $(PDFSRC)pdf_func.c $(PDFINCLUDES) \
+ $(gsdsrc_h) $(gsfunc0_h) $(gsfunc3_h) $(gsfunc4_h) $(stream_h) \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_func.c $(PDFO_)pdf_func.$(OBJ)
+
+$(PDFOBJ)pdf_image.$(OBJ): $(PDFSRC)pdf_image.c $(PDFINCLUDES) \
+ $(stream_h) $(gspath2_h) $(gsiparm4_h) $(gsiparm3_h) $(gsiparm3x_h) \
+ $(gsform1_h) $(gstrans_h) \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_image.c $(PDFO_)pdf_image.$(OBJ)
+
+$(PDFOBJ)pdf_page.$(OBJ): $(PDFSRC)pdf_page.c $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_page.c $(PDFO_)pdf_page.$(OBJ)
+
+$(PDFOBJ)pdf_annot.$(OBJ): $(PDFSRC)pdf_annot.c $(PDFINCLUDES) $(gspath2_h) $(gxfarith_h) \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_annot.c $(PDFO_)pdf_annot.$(OBJ)
+
+$(PDFOBJ)pdf_mark.$(OBJ): $(PDFSRC)pdf_mark.c $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_mark.c $(PDFO_)pdf_mark.$(OBJ)
+
+$(PDFOBJ)pdf_sec.$(OBJ): $(PDFSRC)pdf_sec.c $(PDFINCLUDES) \
+ $(strmio_h) $(smd5_h) $(sarc4_h) $(aes_h) $(sha2_h) \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_sec.c $(PDFO_)pdf_sec.$(OBJ)
+
+$(PDFOBJ)pdf_utf8_mswin32_.$(OBJ): $(PDFSRC)pdf_utf8.c $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC_WIN) $(PDFSRC)pdf_utf8.c $(PDFO_)pdf_utf8_mswin32_.$(OBJ)
+
+$(PDFOBJ)pdf_utf8_metro_.$(OBJ): $(PDFOBJ)pdf_utf8_mswin32_.$(OBJ) $(PDF_MAK) $(MAKEDIRS)
+ $(CP_) $(PDFOBJ)pdf_utf8_mswin32_.$(OBJ) $(PDFOBJ)pdf_utf8_metro.$(OBJ)
+
+$(PDFOBJ)pdf_utf8_unix_.$(OBJ): $(PDFSRC)pdf_utf8.c $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_utf8.c $(PDFO_)pdf_utf8_unix_.$(OBJ)
+
+$(PDFOBJ)pdf_utf8_openvms_.$(OBJ): $(PDFOBJ)pdf_utf8_unix_.$(OBJ) $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(CP_) $(PDFOBJ)pdf_utf8_unix_.$(OBJ) $(PDFOBJ)pdf_utf8_openvms_.$(OBJ)
+
+$(PDFOBJ)pdf_utf8.$(OBJ): $(PDFOBJ)pdf_utf8_$(GSPLATFORM).$(OBJ) $(PDF_MAK) $(MAKEDIRS)
+ $(CP_) $(PDFOBJ)pdf_utf8_$(GSPLATFORM).$(OBJ) $(PDFOBJ)pdf_utf8.$(OBJ)
+
+$(PDFOBJ)pdf_stack.$(OBJ): $(PDFSRC)pdf_stack.c $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_stack.c $(PDFO_)pdf_stack.$(OBJ)
+
+$(PDFOBJ)pdf_gstate.$(OBJ): $(PDFSRC)pdf_gstate.c $(PDFINCLUDES) \
+ $(gsmatrix_h) $(gslparam_h) $(gstparam_h) $(gxdht_h) $(gxht_h) $(gzht_h) $(gsht_h) \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_gstate.c $(PDFO_)pdf_gstate.$(OBJ)
+
+$(PDFOBJ)pdf_colour.$(OBJ): $(PDFSRC)pdf_colour.c $(PDFINCLUDES) \
+ $(gsicc_manage_h) $(gsicc_create_h) $(gsptype2_h) $(gscsepr_h) \
+ $(stream_h) $(strmio_h) $(gscdevn_h) $(gxcdevn_h) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_colour.c $(PDFO_)pdf_colour.$(OBJ)
+
+$(PDFOBJ)pdf_pattern.$(OBJ): $(PDFSRC)pdf_pattern.c $(PDFINCLUDES) \
+ $(gsicc_manage_h) $(gsicc_profilecache_h) $(gsicc_create_h) $(gscsepr_h) \
+ $(stream_h) $(strmio_h) $(gscdevn_h) \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_pattern.c $(PDFO_)pdf_pattern.$(OBJ)
+
+$(PDFOBJ)pdf_path.$(OBJ): $(PDFSRC)pdf_path.c $(PDFINCLUDES) $(gstypes_h) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_path.c $(PDFO_)pdf_path.$(OBJ)
+
+$(PDFOBJ)pdf_loop_detect.$(OBJ): $(PDFSRC)pdf_loop_detect.c $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_loop_detect.c $(PDFO_)pdf_loop_detect.$(OBJ)
+
+$(PDFOBJ)pdf_int.$(OBJ): $(PDFSRC)pdf_int.c $(PDFINCLUDES) $(plmain_h) \
+ $(stream_h) $(strmio_h) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_int.c $(PDFO_)pdf_int.$(OBJ)
+
+$(PDFOBJ)pdf_file_luratech.$(OBJ): $(PDFSRC)pdf_file.c $(sjpeg_h) $(stream_h) $(strimpl_h) \
+ $(strmio_h) $(gpmisc_h) $(simscale_h) $(szlibx_h) $(spngx_h) $(spdiffx_h) $(slzw_h) $(sstring_h) \
+ $(sa85d_h) $(scfx_h) $(srlx_h) $(jpeglib__h) $(sdct_h) $(sjpeg_h) $(sfilter_h) $(sarc4_h) \
+ $(saes_h) $(ssha2_h) $(sjbig2_luratech_h) $(sjpx_luratech_h) \
+ $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFLURCC) $(PDFSRC)pdf_file.c $(PDFO_)pdf_file_luratech.$(OBJ)
+
+$(PDFOBJ)pdf_file_jbig2dec.$(OBJ): $(PDFSRC)pdf_file.c $(sjpeg_h) $(stream_h) $(strimpl_h) \
+ $(strmio_h) $(simscale_h) $(szlibx_h) $(spngx_h) $(spdiffx_h) $(slzw_h) $(sstring_h) \
+ $(sa85d_h) $(scfx_h) $(srlx_h) $(jpeglib__h) $(sdct_h) $(sjpeg_h) $(sfilter_h) $(sarc4_h) \
+ $(saes_h) $(ssha2_h) $(sjbig2_h) $(sjpx_openjpeg_h) \
+ $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFJB2CC) $(PDFSRC)pdf_file.c $(PDFO_)pdf_file_jbig2dec.$(OBJ)
+
+$(PDFOBJ)pdf_file.$(OBJ): $(PDFOBJ)pdf_file_$(JBIG2_LIB).$(OBJ)
+ $(CP_) $(PDFOBJ)pdf_file_$(JBIG2_LIB).$(OBJ) $(PDFOBJ)pdf_file.$(OBJ)
+
+$(PDFOBJ)pdf_trans.$(OBJ): $(PDFSRC)pdf_trans.c $(PDFINCLUDES) $(gstparam_h) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_trans.c $(PDFO_)pdf_trans.$(OBJ)
+
+$(PDFOBJ)pdf_device.$(OBJ): $(PDFSRC)pdf_device.c $(PDFINCLUDES) $(gdevvec_h) \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_device.c $(PDFO_)pdf_device.$(OBJ)
+
+$(PDFOBJ)pdf_misc.$(OBJ): $(PDFSRC)pdf_misc.c $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_misc.c $(PDFO_)pdf_misc.$(OBJ)
+
+$(PDFOBJ)pdf_optcontent.$(OBJ): $(PDFSRC)pdf_optcontent.c $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_optcontent.c $(PDFO_)pdf_optcontent.$(OBJ)
+
+$(PDFOBJ)pdf_check.$(OBJ): $(PDFSRC)pdf_check.c $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_check.c $(PDFO_)pdf_check.$(OBJ)
+
+$(PDFOBJ)pdf_deref.$(OBJ): $(PDFSRC)pdf_deref.c $(PDFINCLUDES) $(strmio_h) $(stream_h) \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_deref.c $(PDFO_)pdf_deref.$(OBJ)
+
+$(PDFOBJ)pdf_repair.$(OBJ): $(PDFSRC)pdf_repair.c $(PDFINCLUDES) \
+ $(strmio_h) $(stream_h) \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_repair.c $(PDFO_)pdf_repair.$(OBJ)
+
+$(PDFOBJ)pdf_obj.$(OBJ): $(PDFSRC)pdf_obj.c $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_obj.c $(PDFO_)pdf_obj.$(OBJ)
+
+$(PDFOBJ)pdf_doc.$(OBJ): $(PDFSRC)pdf_doc.c $(PDFINCLUDES) $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(PDFSRC)pdf_doc.c $(PDFO_)pdf_doc.$(OBJ)
+
+$(PDFGEN)pdfimpl.c: $(PLSRC)plimpl.c $(PDF_MAK) $(MAKEDIRS)
+ $(CP_) $(PLSRC)plimpl.c $(PDFGEN)pdfimpl.c
+
+$(PLOBJ)pdfimpl.$(OBJ): $(PDFGEN)pdfimpl.c \
+ $(AK) \
+ $(memory__h) \
+ $(scommon_h) \
+ $(gxdevice_h) \
+ $(pltop_h) \
+ $(PDF_MAK) \
+ $(MAKEDIRS)
+ $(PDFCCC) $(PDFGEN)pdfimpl.c $(PDFO_)pdfimpl.$(OBJ)
+
+$(PDF_TOP_OBJ): $(PDFSRC)pdftop.c $(plmain_h) $(pltop_h) $(PDFINCLUDES) \
+ $(GLGEN)gconfig.$(OBJ) $(pltop_h) $(plmain_h) $(plparse_h) $(gxdevice_h) \
+ $(gxht_h) $(gsht1_h) $(pconfig_h) \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(PDFCCC) $(D_)GS_LIB_DEFAULT=$(GS_LIB_DEFAULT)$(_D) $(D_)COMPILE_INITS=$(COMPILE_INITS)$(_D) $(PDFSRC)pdftop.c $(PDFO_)pdftop.$(OBJ)
+
+PDF_OBJS=\
+ $(PDFOBJ)pdf_loop_detect.$(OBJ)\
+ $(PDFOBJ)ghostpdf.$(OBJ)\
+ $(PDFOBJ)pdf_dict.$(OBJ)\
+ $(PDFOBJ)pdf_array.$(OBJ)\
+ $(PDFOBJ)pdf_xref.$(OBJ)\
+ $(PDFOBJ)pdf_int.$(OBJ)\
+ $(PDFOBJ)pdf_file.$(OBJ)\
+ $(PDFOBJ)pdf_path.$(OBJ)\
+ $(PDFOBJ)pdf_colour.$(OBJ)\
+ $(PDFOBJ)pdf_pattern.$(OBJ)\
+ $(PDFOBJ)pdf_gstate.$(OBJ)\
+ $(PDFOBJ)pdf_stack.$(OBJ)\
+ $(PDFOBJ)pdf_image.$(OBJ)\
+ $(PDFOBJ)pdf_page.$(OBJ)\
+ $(PDFOBJ)pdf_annot.$(OBJ)\
+ $(PDFOBJ)pdf_mark.$(OBJ)\
+ $(PDFOBJ)pdf_fapi.$(OBJ)\
+ $(PDFOBJ)pdf_font.$(OBJ)\
+ $(PDFOBJ)pdf_font0.$(OBJ)\
+ $(PDFOBJ)pdf_ciddec.$(OBJ)\
+ $(PDFOBJ)pdf_font1.$(OBJ)\
+ $(PDFOBJ)pdf_font1C.$(OBJ)\
+ $(PDFOBJ)pdf_fontps.$(OBJ)\
+ $(PDFOBJ)pdf_font3.$(OBJ)\
+ $(PDFOBJ)pdf_fontTT.$(OBJ)\
+ $(PDFOBJ)pdf_font9.$(OBJ)\
+ $(PDFOBJ)pdf_font11.$(OBJ)\
+ $(PDFOBJ)pdf_cmap.$(OBJ)\
+ $(PDFOBJ)pdf_fmap.$(OBJ)\
+ $(PDFOBJ)pdf_text.$(OBJ)\
+ $(PDFOBJ)pdf_shading.$(OBJ)\
+ $(PDFOBJ)pdf_func.$(OBJ)\
+ $(PDFOBJ)pdf_trans.$(OBJ)\
+ $(PDFOBJ)pdf_device.$(OBJ)\
+ $(PDFOBJ)pdf_misc.$(OBJ)\
+ $(PDFOBJ)pdf_optcontent.$(OBJ)\
+ $(PDFOBJ)pdf_check.$(OBJ)\
+ $(PDFOBJ)pdf_sec.$(OBJ)\
+ $(PDFOBJ)pdf_utf8.$(OBJ)\
+ $(PDFOBJ)pdf_deref.$(OBJ)\
+ $(PDFOBJ)pdf_repair.$(OBJ)\
+ $(PDFOBJ)pdf_obj.$(OBJ)\
+ $(PDFOBJ)pdf_doc.$(OBJ)\
+
+
+# NB - note this is a bit squirrely. Right now the pjl interpreter is
+# required and shouldn't be and PLOBJ==PDFGEN is required.
+
+$(PDFOBJ)pdfi.dev: $(ECHOGS_XE) $(PDF_OBJS) \
+ $(PDFGEN)func4lib.dev \
+ $(PDFGEN)pdiff.dev $(PDFGEN)psfilters.dev $(PDFGEN)saes.dev $(PDFGEN)ssha2.dev $(PDFGEN)sjpx.dev $(PDFGEN)psfilters.dev \
+ $(PDFGEN)sdct.dev $(PDFGEN)simscale.dev $(GLD)gsagl.dev \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(SETMOD) $(PDFOBJ)pdfi $(PDF_OBJS)
+ $(ADDMOD) $(PDFOBJ)pdfi -include $(PDFGEN)func4lib.dev $(GLD)gsagl.dev
+ $(ADDMOD) $(PDFOBJ)pdfi -include $(PDFGEN)pdiff.dev $(PDFGEN)psfilters.dev $(PDFGEN)saes.dev $(PDFGEN)sjpx.dev
+ $(ADDMOD) $(PDFOBJ)pdfi -include $(PDFGEN)ssha2.dev $(PDFGEN)psfilters.dev $(PDFGEN)sdct.dev $(PDFGEN)simscale.dev
+
+$(PDFOBJ)gpdf.dev: $(ECHOGS_XE) $(PDF_OBJS) \
+ $(PDFGEN)pl.dev $(PDFGEN)$(PL_SCALER).dev $(PDFGEN)pjl.dev $(PDFOBJ)pdfi.dev \
+ $(PDF_MAK) $(MAKEDIRS)
+ $(SETMOD) $(PDFOBJ)gpdf -include $(PDFOBJ)pdfi.dev $(PDFGEN)$(PL_SCALER) $(PDFGEN)pjl.dev
diff --git a/pdf/pdf_annot.c b/pdf/pdf_annot.c
new file mode 100644
index 00000000..116081c2
--- /dev/null
+++ b/pdf/pdf_annot.c
@@ -0,0 +1,4517 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Annotation handling for the PDF interpreter */
+
+#include "pdf_int.h"
+#include "pdf_stack.h"
+#include "pdf_annot.h"
+#include "pdf_file.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_loop_detect.h"
+#include "pdf_colour.h"
+#include "pdf_trans.h"
+#include "pdf_gstate.h"
+#include "pdf_misc.h"
+#include "pdf_optcontent.h"
+#include "pdf_annot.h"
+#include "pdf_colour.h"
+#include "pdf_deref.h"
+#include "pdf_image.h"
+#include "pdf_mark.h"
+#include "pdf_font.h"
+#include "pdf_text.h"
+
+#include "gspath2.h"
+#include "gxfarith.h"
+#include "gxdevsop.h" /* For special ops */
+#include "gsstrtok.h" /* For gs_strtok */
+#include "gscoord.h" /* for gs_concat() and others */
+#include "gsline.h" /* For gs_setlinejoin() and friends */
+#include "gsutil.h" /* For gs_next_ids() */
+#include "gspaint.h" /* For gs_fill() and friends */
+
+/* Detect if there is a BOM at beginning of string */
+#define IS_UTF8(str) (!strcmp((char *)(str), "\xef\xbb\xbf"))
+#define IS_UTF16(str) (!strcmp((char *)(str), "\xfe\xff"))
+
+typedef int (*annot_func)(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done);
+
+typedef struct {
+ const char *subtype;
+ annot_func func;
+ bool simpleAP; /* Just Render AP if it exists? (false means more complicated) */
+} annot_dispatch_t;
+
+
+typedef int (*annot_LE_func)(pdf_context *ctx, pdf_dict *annot);
+
+typedef struct {
+ const char *name;
+ annot_LE_func func;
+} annot_LE_dispatch_t;
+
+typedef int (*annot_preserve_func)(pdf_context *ctx, pdf_dict *annot, pdf_name *subtype);
+
+typedef struct {
+ const char *subtype;
+ annot_preserve_func func;
+} annot_preserve_dispatch_t;
+
+static int pdfi_annot_start_transparency(pdf_context *ctx, pdf_dict *annot)
+{
+ int code;
+
+ if (!ctx->page.has_transparency)
+ return 0;
+
+ /* TODO: ps code does something with /BM which is apparently the Blend Mode,
+ * but I am not sure that the value is actually used properly. Look into it.
+ * (see pdf_draw.ps/startannottransparency)
+ */
+ code = gs_clippath(ctx->pgs);
+ if (code < 0)
+ return code;
+ code = pdfi_trans_begin_simple_group(ctx, NULL, false, false, false);
+ (void)gs_newpath(ctx->pgs);
+ return code;
+}
+
+static int pdfi_annot_end_transparency(pdf_context *ctx, pdf_dict *annot)
+{
+ if (!ctx->page.has_transparency)
+ return 0;
+
+ return pdfi_trans_end_simple_group(ctx);
+}
+
+/* Get width from BS, if it exists
+ * Default to 1.0 if not
+ */
+static int pdfi_annot_get_BS_width(pdf_context *ctx, pdf_dict *annot, double *width)
+{
+ int code;
+ pdf_dict *BS = NULL;
+
+ *width = 1.0;
+
+ code = pdfi_dict_knownget_type(ctx, annot, "BS", PDF_DICT, (pdf_obj **)&BS);
+ if (code <= 0)
+ goto exit;
+
+ code = pdfi_dict_knownget_number(ctx, BS, "W", width);
+
+ exit:
+ pdfi_countdown(BS);
+ return code;
+}
+
+/* Set both stroke opacity and fill opacity to either CA or ca
+ * For annotations, the one value seems to control both.
+ */
+static int pdfi_annot_opacity(pdf_context *ctx, pdf_dict *annot)
+{
+ int code = 0;
+ double CA;
+
+ /* CA -- opacity */
+ code = pdfi_dict_knownget_number(ctx, annot, "CA", &CA);
+ if (code > 0) {
+ code = gs_setstrokeconstantalpha(ctx->pgs, CA);
+ if (code < 0) goto exit;
+ code = gs_setfillconstantalpha(ctx->pgs, CA);
+ goto exit;
+ }
+ /* If CA not found, we also check for 'ca' even though it's not in the spec */
+ code = pdfi_dict_knownget_number(ctx, annot, "ca", &CA);
+ if (code > 0) {
+ code = gs_setstrokeconstantalpha(ctx->pgs, CA);
+ if (code < 0) goto exit;
+ code = gs_setfillconstantalpha(ctx->pgs, CA);
+ }
+ exit:
+ return code;
+}
+
+/* Apply RD to provided rect */
+static int pdfi_annot_applyRD(pdf_context *ctx, pdf_dict *annot, gs_rect *rect)
+{
+ int code;
+ pdf_array *RD = NULL;
+ gs_rect rd;
+
+ code = pdfi_dict_knownget_type(ctx, annot, "RD", PDF_ARRAY, (pdf_obj **)&RD);
+ if (code <= 0) goto exit;
+
+ code = pdfi_array_to_gs_rect(ctx, RD, &rd);
+ if (code < 0) goto exit;
+
+ rect->p.x += rd.p.x;
+ rect->p.y += rd.p.y;
+ rect->q.x -= rd.q.x;
+ rect->q.y -= rd.q.y;
+
+ exit:
+ pdfi_countdown(RD);
+ return code;
+}
+
+static int pdfi_annot_Rect(pdf_context *ctx, pdf_dict *annot, gs_rect *rect)
+{
+ int code;
+ pdf_array *Rect = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, annot, "Rect", PDF_ARRAY, (pdf_obj **)&Rect);
+ if (code < 0) goto exit;
+
+ code = pdfi_array_to_gs_rect(ctx, Rect, rect);
+ if (code < 0) goto exit;
+
+ pdfi_normalize_rect(ctx, rect);
+
+ exit:
+ pdfi_countdown(Rect);
+ return code;
+}
+
+static int pdfi_annot_position_AP(pdf_context *ctx, pdf_dict *annot, pdf_stream *AP)
+{
+ int code = 0;
+ gs_rect rect;
+ pdf_array *BBox = NULL;
+ gs_rect bbox;
+ pdf_array *Matrix = NULL;
+ gs_matrix matrix;
+ double xscale, yscale;
+ pdf_dict *Annot_dict;
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)AP, &Annot_dict);
+ if (code < 0)
+ return code;
+
+ /* TODO: graphicsbeginpage, textbeginpage
+ * These should match what was done at the beginning of the page,
+ * but current implementation has things kind of mixed around.
+ * Need to figure out exactly what to do. I'd like it to be one
+ * function in both places.
+ * see pdfi_page_render()
+ */
+ /* graphicsbeginpage() */
+ /* textbeginpage() */
+ /* code = gs_initgraphics(ctx->pgs); */
+ ctx->text.BlockDepth = 0;
+ /* TODO: FIXME */
+
+ code = pdfi_annot_Rect(ctx, annot, &rect);
+ if (code < 0) goto exit;
+
+ code = pdfi_dict_knownget_type(ctx, Annot_dict, "BBox", PDF_ARRAY, (pdf_obj **)&BBox);
+ if (code < 0) goto exit;
+ code = pdfi_array_to_gs_rect(ctx, BBox, &bbox);
+ if (code < 0) goto exit;
+
+ code = pdfi_dict_knownget_type(ctx, Annot_dict, "Matrix", PDF_ARRAY, (pdf_obj **)&Matrix);
+ if (code < 0) goto exit;
+ code = pdfi_array_to_gs_matrix(ctx, Matrix, &matrix);
+ if (code < 0) goto exit;
+
+ xscale = yscale = 1.0;
+
+ code = gs_translate(ctx->pgs, rect.p.x, rect.p.y);
+ if (code < 0) goto exit;
+
+ if (BBox != NULL) {
+ pdfi_bbox_transform(ctx, &bbox, &matrix);
+
+ /* Calculate scale factor */
+ xscale = (rect.q.x - rect.p.x) / (bbox.q.x - bbox.p.x);
+ yscale = (rect.q.y - rect.p.y) / (bbox.q.y - bbox.p.y);
+
+ if (xscale * yscale <= 0) {
+ dbgmprintf(ctx->memory, "ANNOT: Ignoring annotation with scale factor of 0\n");
+ code = 0;
+ goto exit;
+ }
+
+ /* Scale it */
+ code = gs_scale(ctx->pgs, xscale, yscale);
+ if (code < 0) goto exit;
+
+ /* Compensate for non-zero origin of BBox */
+ code = gs_translate(ctx->pgs, -bbox.p.x, -bbox.p.y);
+ if (code < 0) goto exit;
+ }
+
+ exit:
+ pdfi_countdown(BBox);
+ pdfi_countdown(Matrix);
+ return code;
+}
+
+/* See pdf_draw.ps/drawwidget (draws the AP for any type of thingy) */
+static int pdfi_annot_draw_AP(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP)
+{
+ int code = 0;
+
+ if (NormAP == NULL)
+ return 0;
+ if (NormAP->type != PDF_STREAM)
+ return_error(gs_error_typecheck);
+
+ code = pdfi_op_q(ctx);
+ if (code < 0)
+ return code;
+
+ code = pdfi_annot_position_AP(ctx, annot, (pdf_stream *)NormAP);
+ if (code < 0)
+ goto exit;
+
+ /* Render the annotation */
+ code = pdfi_do_image_or_form(ctx, NULL, ctx->page.CurrentPageDict, NormAP);
+
+exit:
+ (void)pdfi_op_Q(ctx);
+ return code;
+}
+
+static int pdfi_annot_setcolor_key(pdf_context *ctx, pdf_dict *annot, const char *key,
+ bool usedefault, bool *drawit)
+{
+ int code = 0;
+ pdf_array *C = NULL;
+
+ *drawit = true;
+
+ code = pdfi_dict_knownget_type(ctx, annot, key, PDF_ARRAY, (pdf_obj **)&C);
+ if (code < 0) goto exit;
+
+ if (code == 0) {
+ if (usedefault)
+ code = pdfi_gs_setgray(ctx, 0);
+ else
+ *drawit = false;
+ } else {
+ if (pdfi_array_size(C) == 0) {
+ code = 0;
+ *drawit = false;
+ } else {
+ code = pdfi_setcolor_from_array(ctx, C);
+ }
+ }
+
+ exit:
+ if (code < 0)
+ *drawit = false;
+ pdfi_countdown(C);
+ return code;
+}
+
+static int pdfi_annot_setinteriorcolor(pdf_context *ctx, pdf_dict *annot, bool usedefault, bool *drawit)
+{
+ return pdfi_annot_setcolor_key(ctx, annot, "IC", usedefault, drawit);
+}
+
+static int pdfi_annot_setcolor(pdf_context *ctx, pdf_dict *annot, bool usedefault, bool *drawit)
+{
+ return pdfi_annot_setcolor_key(ctx, annot, "C", usedefault, drawit);
+}
+
+/* Stroke border using current path */
+static int pdfi_annot_strokeborderpath(pdf_context *ctx, pdf_dict *annot, double width, pdf_array *dash)
+{
+ int code = 0;
+
+ if (width <= 0)
+ return 0;
+
+ code = pdfi_setdash_impl(ctx, dash, 0);
+ if (code < 0) goto exit;
+ code = gs_setlinewidth(ctx->pgs, width);
+ if (code < 0) goto exit;
+
+ code = gs_stroke(ctx->pgs);
+
+ exit:
+ return code;
+}
+
+/* Fill border path */
+static int pdfi_annot_fillborderpath(pdf_context *ctx, pdf_dict *annot)
+{
+ int code;
+ bool drawit;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) return code;
+
+ code = pdfi_annot_opacity(ctx, annot);
+ if (code < 0) goto exit;
+ code = pdfi_annot_setinteriorcolor(ctx, annot, false, &drawit);
+ if (code < 0) goto exit;
+ if (drawit)
+ code = gs_fill(ctx->pgs);
+
+ exit:
+ (void)pdfi_grestore(ctx);
+ return code;
+}
+
+
+/* Draw a path from a rectangle */
+static int pdfi_annot_rect_path(pdf_context *ctx, gs_rect *rect)
+{
+ int code;
+
+ code = gs_moveto(ctx->pgs, rect->p.x, rect->p.y);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, rect->q.x, rect->p.y);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, rect->q.x, rect->q.y);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, rect->p.x, rect->q.y);
+ if (code < 0) goto exit;
+ code = gs_closepath(ctx->pgs);
+
+ exit:
+ return code;
+}
+
+/* Make a rectangle path from Rect (see /re, /normal_re in pdf_ops.ps)
+ * See also /Square
+ * Not sure if I have to worry about the /inside_text_re here
+ */
+static int pdfi_annot_RectRD_path(pdf_context *ctx, pdf_dict *annot)
+{
+ gs_rect rect;
+ int code;
+
+ code = pdfi_annot_Rect(ctx, annot, &rect);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_applyRD(ctx, annot, &rect);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_rect_path(ctx, &rect);
+
+ exit:
+ return code;
+}
+
+/* Adjust rectangle by specified width */
+static void pdfi_annot_rect_adjust(pdf_context *ctx, gs_rect *rect, double width)
+{
+ rect->p.x += width;
+ rect->p.y += width;
+ rect->q.x -= width;
+ rect->q.y -= width;
+}
+
+/* Fill Rect with current color */
+static int pdfi_annot_fillRect(pdf_context *ctx, pdf_dict *annot)
+{
+ int code;
+ gs_rect rect;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) return code;
+
+ code = pdfi_annot_Rect(ctx, annot, &rect);
+ if (code < 0) goto exit;
+
+ code = gs_rectclip(ctx->pgs, &rect, 1);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_applyRD(ctx, annot, &rect);
+ if (code < 0) goto exit;
+
+ code = gs_rectfill(ctx->pgs, &rect, 1);
+ if (code < 0) goto exit;
+
+ exit:
+ (void)pdfi_grestore(ctx);
+ return code;
+}
+
+/* Stroke border, drawing path from rect */
+static int pdfi_annot_strokeborder(pdf_context *ctx, pdf_dict *annot, double width, pdf_array *dash)
+{
+ int code = 0;
+ gs_rect rect;
+
+ if (width <= 0)
+ return 0;
+
+ code = pdfi_gsave(ctx);
+
+ code = pdfi_setdash_impl(ctx, dash, 0);
+ if (code < 0) goto exit;
+
+ code = gs_setlinewidth(ctx->pgs, width);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_Rect(ctx, annot, &rect);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_applyRD(ctx, annot, &rect);
+ if (code < 0) goto exit;
+
+
+ /* Stroke the rectangle */
+ /* Adjust rectangle by the width */
+ pdfi_annot_rect_adjust(ctx, &rect, width/2);
+ code = gs_rectstroke(ctx->pgs, &rect, 1, NULL);
+
+ exit:
+ (void)pdfi_grestore(ctx);
+ return code;
+}
+
+/* Draw border from a Border array
+ * Note: Border can be null
+ */
+static int pdfi_annot_draw_Border(pdf_context *ctx, pdf_dict *annot, pdf_array *Border, bool usepath)
+{
+ pdf_array *dash = NULL;
+ int code = 0;
+ uint64_t size = 0;
+ double width = 0;
+
+ if (Border)
+ size = pdfi_array_size(Border);
+ if (Border && size < 3) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_ANNOT_ERROR, "pdfi_annot_draw_Border", "WARNING: Annotation Border array invalid");
+ goto exit;
+ }
+ if (!Border) {
+ code = pdfi_array_alloc(ctx, 0, &dash);
+ pdfi_countup(dash);
+ if (code < 0) goto exit;
+ width = 1;
+ } else {
+ if (size > 3) {
+ code = pdfi_array_get_type(ctx, Border, 3, PDF_ARRAY, (pdf_obj **)&dash);
+ if (code < 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_ANNOT_ERROR,
+ "pdfi_annot_draw_Border", "WARNING: Annotation Border Dash array invalid");
+ code = pdfi_array_alloc(ctx, 0, &dash);
+ if (code < 0) goto exit;
+ pdfi_countup(dash);
+ }
+ } else {
+ code = pdfi_array_alloc(ctx, 0, &dash);
+ if (code < 0) goto exit;
+ pdfi_countup(dash);
+ }
+ code = pdfi_array_get_number(ctx, Border, 2, &width);
+ if (code < 0) goto exit;
+ }
+
+ /* At this point we have a dash array (which could be length 0) and a width */
+ if (usepath)
+ code = pdfi_annot_strokeborderpath(ctx, annot, width, dash);
+ else
+ code = pdfi_annot_strokeborder(ctx, annot, width, dash);
+
+ exit:
+ pdfi_countdown(dash);
+ return code;
+}
+
+/* Draw border from a BS dict */
+static int pdfi_annot_draw_BS(pdf_context *ctx, pdf_dict *annot, pdf_dict *BS, bool usepath)
+{
+ double W;
+ int code = 0;
+ pdf_name *S = NULL;
+ pdf_array *dash = NULL;
+
+ /* Get the width */
+ code = pdfi_dict_knownget_number(ctx, BS, "W", &W);
+ if (code < 0) goto exit;
+ if (code == 0)
+ W = 1; /* Default */
+
+ /* TODO: Some junk about scaling to UserUnit */
+ /* ... */
+
+ /* Lookup border style */
+ code = pdfi_dict_knownget_type(ctx, BS, "S", PDF_NAME, (pdf_obj **)&S);
+ if (code < 0) goto exit;
+
+ if (code > 0 && pdfi_name_is(S, "D")) {
+ /* Handle Dash array */
+ code = pdfi_dict_knownget_type(ctx, BS, "D", PDF_ARRAY, (pdf_obj **)&dash);
+ if (code < 0) goto exit;
+
+ /* If there is no Dash array, then create one containing a 3 (the default) */
+ if (code == 0) {
+ code = pdfi_array_alloc(ctx, 1, &dash);
+ if (code < 0) goto exit;
+ pdfi_countup(dash);
+
+ code = pdfi_array_put_int(ctx, dash, 0, 3);
+ if (code < 0) goto exit;
+ }
+ } else {
+ /* Empty array */
+ code = pdfi_array_alloc(ctx, 0, &dash);
+ if (code < 0) goto exit;
+ pdfi_countup(dash);
+ }
+
+ /* At this point we have a dash array (which could be length 0) and a width */
+ if (usepath)
+ code = pdfi_annot_strokeborderpath(ctx, annot, W, dash);
+ else
+ code = pdfi_annot_strokeborder(ctx, annot, W, dash);
+
+ exit:
+ pdfi_countdown(S);
+ pdfi_countdown(dash);
+ return code;
+}
+
+/* Draw the border
+ * This spec seems to be scattered around. There might be:
+ * /Border -- an array of 3-4 elements, where the optional 4th element is a "dash array"
+ * (default value: [0 0 1])
+ * /BS -- a Border Style dictionary
+ * Spec says /Border would be ignored in favor of /BS
+ *
+ * usepath -- indicates whether to stroke existing path, or use Rect to draw a path first
+ */
+static int pdfi_annot_draw_border(pdf_context *ctx, pdf_dict *annot, bool usepath)
+{
+ int code, code1;
+ pdf_dict *BS = NULL;
+ pdf_array *Border = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, annot, "BS", PDF_DICT, (pdf_obj **)&BS);
+ if (code < 0) goto exit;
+ code = pdfi_dict_knownget_type(ctx, annot, "Border", PDF_ARRAY, (pdf_obj **)&Border);
+ if (code < 0) goto exit;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) goto exit;
+
+ if (BS) {
+ code = pdfi_annot_draw_BS(ctx, annot, BS, usepath);
+ } else {
+ /* Note: Border can be null */
+ code = pdfi_annot_draw_Border(ctx, annot, Border, usepath);
+ }
+ code1 = pdfi_grestore(ctx);
+ if (code == 0) code = code1;
+
+ exit:
+ pdfi_countdown(BS);
+ pdfi_countdown(Border);
+ return code;
+}
+
+/*********** BEGIN Font/Text ***************/
+
+/* Set font */
+static int
+pdfi_annot_set_font(pdf_context *ctx, const char *font, double size)
+{
+ int code = 0;
+
+ if (font != NULL) {
+ code = pdfi_font_set_internal_string(ctx, font, size);
+ if (code < 0) goto exit;
+ }
+
+ exit:
+ return code;
+}
+
+/* Get value from a field, or its Parents (recursive)
+ * If no Parent, will also check ctx->AcroForm
+ * Returns <0 on error, 0 if not found, >0 if found
+ */
+static int pdfi_form_get_inheritable(pdf_context *ctx, pdf_dict *field, const char *Key,
+ pdf_obj_type type, pdf_obj **o)
+{
+ int code = 0;
+ pdf_dict *Parent = NULL;
+
+ /* Check this field */
+ code = pdfi_dict_knownget_type(ctx, field, Key, type, o);
+ if (code != 0) goto exit;
+
+ /* If not found, recursively check Parent, if any */
+ code = pdfi_dict_knownget_type(ctx, field, "Parent", PDF_DICT, (pdf_obj **)&Parent);
+ if (code < 0) goto exit;
+ if (code > 0) {
+ /* Check Parent */
+ code = pdfi_form_get_inheritable(ctx, Parent, Key, type, o);
+ } else {
+ /* No Parent, so check AcroForm, if any */
+ if (ctx->AcroForm)
+ code = pdfi_dict_knownget_type(ctx, ctx->AcroForm, Key, type, o);
+ }
+
+ exit:
+ pdfi_countdown(Parent);
+ return code;
+}
+
+/* Get int value from a field, or its Parents (recursive)
+ * Returns <0 on error, 0 if not found, >0 if found
+ */
+static int pdfi_form_get_inheritable_int(pdf_context *ctx, pdf_dict *field, const char *Key,
+ int64_t *val)
+{
+ int code = 0;
+ pdf_num *num = NULL;
+
+ *val = 0;
+ code = pdfi_form_get_inheritable(ctx, field, Key, PDF_INT, (pdf_obj **)&num);
+ if (code < 0) goto exit;
+
+ if (code > 0)
+ *val = num->value.i;
+
+ exit:
+ pdfi_countdown(num);
+ return code;
+}
+
+/* Scan DA to see if font size is 0, if so make a new DA with font size scaled by gs_rect */
+static int pdfi_form_modDA(pdf_context *ctx, pdf_string *DA, pdf_string **mod_DA, gs_rect *rect)
+{
+ char *token, *prev_token;
+ char *parse_str = NULL;
+ bool did_mod = false;
+ int code = 0;
+ double size;
+ char size_str[20];
+ char *last;
+ pdf_string *newDA = NULL;
+
+ /* Make a copy of the string because we are going to destructively parse it */
+ parse_str = (char *)gs_alloc_bytes(ctx->memory, DA->length+1, "pdfi_annot_display_text(strbuf)");
+ if (parse_str == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto exit;
+ }
+ memcpy(parse_str, DA->data, DA->length);
+ parse_str[DA->length] = 0; /* Null terminate */
+
+ /* find the 'Tf' token, if any */
+ token = gs_strtok(parse_str, " ", &last);
+ prev_token = NULL;
+ while (token != NULL) {
+ if (!strcmp(token, "Tf"))
+ break;
+ prev_token = token;
+ token = gs_strtok(NULL, " ", &last);
+ }
+
+ /* See if we found it */
+ if (!token)
+ goto exit;
+
+ /* See if there was a prev_token and it was "0" */
+ if (!(prev_token && !strcmp(prev_token, "0")))
+ goto exit;
+
+ /* Case with '<font> 0 Tf', need to calculate correct size */
+ size = (rect->q.y - rect->p.y) * .75; /* empirical from gs code make_tx_da */
+
+ snprintf(size_str, sizeof(size_str), "%g ", size);
+
+ /* Create a new DA and reassemble the old DA into it */
+ code = pdfi_object_alloc(ctx, PDF_STRING, DA->length+strlen(size_str)+1, (pdf_obj **)&newDA);
+ if (code < 0)
+ goto exit;
+ pdfi_countup(newDA);
+
+ strncpy((char *)newDA->data, (char *)DA->data, prev_token-parse_str);
+ strncpy((char *)newDA->data + (prev_token-parse_str), size_str, strlen(size_str)+1);
+ strncpy((char *)newDA->data + strlen((char *)newDA->data), (char *)DA->data + (token - parse_str),
+ DA->length-(token-parse_str));
+ newDA->length = strlen((char *)newDA->data);
+ did_mod = true;
+
+ exit:
+ /* If didn't need to mod it, just copy the original and get a ref */
+ if (did_mod) {
+ *mod_DA = newDA;
+ } else {
+ *mod_DA = DA;
+ pdfi_countup(DA);
+ }
+
+ if (parse_str)
+ gs_free_object(ctx->memory, parse_str, "pdfi_form_modDA(parse_str)");
+
+ return code;
+}
+
+/* Process the /DA string by either running it through the interpreter
+ * or providing a bunch of defaults
+ *
+ * According to the spec, if there is a "<fontname> <size> Tf" in the /DA,
+ * and the <size> = 0, we autosize it using the annotation's rect. (see PDF1.7, pages 678-679)
+ *
+ * rect -- the annotation's rect, for auto-sizing the font
+ * is_form -- is this a form, so check inheritable?
+ */
+static int pdfi_annot_process_DA(pdf_context *ctx, pdf_dict *page_dict, pdf_dict *annot, gs_rect *rect,
+ bool is_form)
+{
+ int code = 0;
+ pdf_string *DA = NULL;
+ pdf_string *mod_DA = NULL;
+ pdf_dict *resource_dict = annot; /* dict to use for resources, alias no need to refcnt */
+ pdf_dict *DR = NULL;
+ bool known;
+
+ /* TODO -- see gs code make_tx_da, need to handle case where we need to set a UTF-16 font */
+
+ if (!page_dict)
+ page_dict = ctx->page.CurrentPageDict;
+
+ if (is_form) {
+ code = pdfi_dict_known(ctx, annot, "DR", &known);
+ if (code < 0) goto exit;
+ /* If there is no "DR" and no Parent in the annotation, have it use the AcroForm instead
+ * This is a hack. May need to use fancier inheritance approach.
+ */
+ if (!known) {
+ code = pdfi_dict_known(ctx, annot, "Parent", &known);
+ if (code < 0) goto exit;
+ if (!known && ctx->AcroForm != NULL)
+ resource_dict = ctx->AcroForm;
+ }
+ code = pdfi_form_get_inheritable(ctx, annot, "DA", PDF_STRING, (pdf_obj **)&DA);
+ } else {
+ code = pdfi_dict_knownget_type(ctx, annot, "DA", PDF_STRING, (pdf_obj **)&DA);
+ }
+ if (code < 0) goto exit;
+ if (code > 0) {
+ if (is_form) {
+ code = pdfi_form_modDA(ctx, DA, &mod_DA, rect);
+ if (code < 0) goto exit;
+ } else {
+ mod_DA = DA;
+ pdfi_countup(mod_DA);
+ }
+
+ code = pdfi_interpret_inner_content_string(ctx, mod_DA, resource_dict,
+ page_dict, false, "DA");
+ if (code < 0) goto exit;
+ /* If no font got set, set one */
+ if (pdfi_get_current_pdf_font(ctx) == NULL) {
+ code = pdfi_annot_set_font(ctx, "Helvetica", 12.0);
+ if (code < 0) goto exit;
+ }
+ } else {
+ code = pdfi_gs_setgray(ctx, 0);
+ if (code < 0) goto exit;
+ code = pdfi_annot_set_font(ctx, "Helvetica", 12.0);
+ if (code < 0) goto exit;
+ }
+
+ exit:
+ pdfi_countdown(DR);
+ pdfi_countdown(DA);
+ pdfi_countdown(mod_DA);
+ return code;
+}
+
+/* Put a string into buffer as a hexstring and return ptr to end of it
+ * Skip over any BOM that is present.
+ */
+static char *pdfi_get_hexstring(pdf_context *ctx, char *outbuf, byte *inbuf, int len)
+{
+ int i;
+ char *ptr;
+
+ i = 0;
+ /* skip over BOM if it's there */
+ if (IS_UTF16(inbuf)) {
+ i += 2; /* UTF-16 */
+ } else if (IS_UTF16(inbuf)) {
+ i += 3; /* UTF-8 */
+ }
+
+ ptr = outbuf;
+ *ptr++ = '<';
+ for ( ; i<len; i++) {
+ snprintf(ptr, 3, "%02X", *(inbuf+i));
+ ptr += 2;
+ }
+
+ *ptr++ = '>';
+ *ptr = 0;
+
+ return ptr;
+}
+
+/* Display text at current position (inside BT/ET) */
+static int
+pdfi_annot_display_nexttext(pdf_context *ctx, pdf_dict *annot, pdf_string *text)
+{
+ char *strbuf = NULL;
+ size_t buflen = 50 + text->length*2; /* 50 to account for formatting, plus the text itself */
+ int code = 0;
+ char *ptr;
+
+ strbuf = (char *)gs_alloc_bytes(ctx->memory, buflen, "pdfi_annot_display_text(strbuf)");
+ if (strbuf == NULL)
+ return_error(gs_error_VMerror);
+ ptr = pdfi_get_hexstring(ctx, strbuf, text->data, text->length);
+ strncpy(ptr, " Tj", buflen-strlen(strbuf));
+
+ code = pdfi_interpret_inner_content_c_string(ctx, strbuf, annot,
+ ctx->page.CurrentPageDict, false, "Annot text Tj");
+ if (code < 0) goto exit;
+
+ exit:
+ if (strbuf)
+ gs_free_object(ctx->memory, strbuf, "pdfi_annot_display_text(strbuf)");
+ return code;
+}
+
+/* Display text with positioning (inside BT/ET) */
+static int
+pdfi_annot_display_text(pdf_context *ctx, pdf_dict *annot, double x, double y, pdf_string *text)
+{
+ char *strbuf = NULL;
+ size_t buflen = 50 + text->length*2; /* 50 to account for formatting, plus the text itself */
+ int code = 0;
+ char *ptr;
+
+ strbuf = (char *)gs_alloc_bytes(ctx->memory, buflen, "pdfi_annot_display_text(strbuf)");
+ if (strbuf == NULL)
+ return_error(gs_error_VMerror);
+ snprintf(strbuf, buflen, "%g %g Td ", x, y);
+ ptr = strbuf + strlen(strbuf);
+ ptr = pdfi_get_hexstring(ctx, ptr, text->data, text->length);
+ strncpy(ptr, " Tj", buflen-strlen(strbuf));
+
+ code = pdfi_interpret_inner_content_c_string(ctx, strbuf, annot,
+ ctx->page.CurrentPageDict, false, "Annot text Tj");
+ if (code < 0) goto exit;
+
+ exit:
+ if (strbuf)
+ gs_free_object(ctx->memory, strbuf, "pdfi_annot_display_text(strbuf)");
+ return code;
+}
+
+/* Get Text height for current font (assumes font is already set, inside BT/ET)
+ * TODO: See /Tform implementation that uses FontBBox and ScaleMatrix instead
+ * Maybe use this technique as a backup if those entries aren't available?
+ */
+static int
+pdfi_annot_get_text_height(pdf_context *ctx, double *height)
+{
+ int code;
+ pdf_string *temp_string = NULL;
+ gs_rect bbox;
+ gs_point awidth;
+
+ if (ctx->pgs->PDFfontsize == 0) {
+ *height = 0;
+ return 0;
+ }
+
+ code = pdfi_obj_charstr_to_string(ctx, "Hy", &temp_string);
+ if (code < 0)
+ goto exit;
+
+ /* Find the bbox of the string "Hy" */
+ code = pdfi_string_bbox(ctx, temp_string, &bbox, &awidth, false);
+ if (code < 0)
+ goto exit;
+
+ *height = bbox.q.y - bbox.p.y;
+
+ exit:
+ pdfi_countdown(temp_string);
+ return code;
+}
+
+/* Display a simple text string (outside BT/ET) */
+static int
+pdfi_annot_display_simple_text(pdf_context *ctx, pdf_dict *annot, double x, double y, pdf_string *text)
+{
+ int code = 0;
+ int code1 = 0;
+
+ code = pdfi_BT(ctx);
+ if (code < 0)
+ return code;
+
+ code = pdfi_annot_display_text(ctx, annot, x, y, text);
+ code1 = pdfi_ET(ctx);
+ if (code == 0) code = code1;
+
+ return code;
+}
+
+/* Display a centered text string (outside BT/ET) */
+static int
+pdfi_annot_display_centered_text(pdf_context *ctx, pdf_dict *annot, gs_rect *rect, pdf_string *text)
+{
+ int code = 0;
+ int code1 = 0;
+ gs_rect bbox;
+ gs_point awidth;
+ double x, y;
+
+ code = pdfi_BT(ctx);
+ if (code < 0)
+ return code;
+
+ /* Get width of the string */
+ code = pdfi_string_bbox(ctx, text, &bbox, &awidth, false);
+ if (code < 0) goto exit;
+
+ /* Center the title in the box */
+ x = rect->p.x + ((rect->q.x - rect->p.x) - awidth.x) / 2;
+ y = rect->q.y - 11;
+
+ code = pdfi_annot_display_text(ctx, annot, x, y, text);
+ if (code < 0) goto exit;
+
+ exit:
+ code1 = pdfi_ET(ctx);
+ if (code == 0) code = code1;
+ return code;
+}
+
+/* Display a string formatted to fit in rect (outside BT/ET)
+ *
+ * TODO: I am sharing code between the FreeText and field/Tx implementation.
+ * The gs code has completely different implementations for these.
+ * I am not sure if there are some different assumptions about font encodings?
+ * The Tx field can apparently be UTF8 or UTF16, whereas the FreeText implementation just assumed
+ * it was ASCII.
+ * If you see some weird behavior with character mappings or line breaks, then
+ * this might be something to revisit.
+ */
+static int
+pdfi_annot_display_formatted_text(pdf_context *ctx, pdf_dict *annot,
+ gs_rect *rect, pdf_string *text, bool is_UTF16)
+{
+ double x;
+ double lineheight = 0;
+ double y_start;
+ double x_start, x_max;
+ gs_rect bbox;
+ gs_point awidth; /* Advance width */
+ int code = 0;
+ int code1 = 0;
+ pdf_string *temp_string = NULL;
+ int i;
+ byte ch;
+ bool firstchar = true;
+ bool linestart = true;
+ int charlen;
+
+ if (is_UTF16)
+ charlen = 2;
+ else
+ charlen = 1;
+
+ if (ctx->pgs->PDFfontsize == 0)
+ return 0;
+
+ code = pdfi_BT(ctx);
+ if (code < 0)
+ return code;
+
+ /* Allocate a temp string to use, length 1 char */
+ code = pdfi_object_alloc(ctx, PDF_STRING, charlen, (pdf_obj **)&temp_string);
+ if (code < 0) goto exit;
+ pdfi_countup(temp_string);
+
+ code = pdfi_annot_get_text_height(ctx, &lineheight);
+ if (code < 0) goto exit;
+
+ y_start = rect->q.y - lineheight;
+ x_start = rect->p.x;
+ x_max = rect->q.x;
+ x = x_start;
+
+ for (i=0; i<text->length; i+=charlen) {
+ int j;
+
+ if (linestart) {
+ x = x_start;
+ }
+
+ for (j = 0; j < charlen; j++) {
+ ch = text->data[i+j];
+ temp_string->data[j] = ch;
+ }
+
+ /* If EOL character encountered, move down to next line */
+ if (charlen == 1) { /* Can only check this for ASCII font */
+ if (ch == '\r' || ch == '\n') {
+ linestart = true;
+ continue;
+ }
+ }
+
+ /* get size of the character */
+ code = pdfi_string_bbox(ctx, temp_string, &bbox, &awidth, false);
+ if (code < 0) goto exit;
+
+ if (linestart || ((x + awidth.x) <= x_max)) {
+ } else {
+ x = x_start;
+ linestart = true;
+ }
+
+ /* display the character */
+ if (firstchar) {
+ code = pdfi_annot_display_text(ctx, annot, x, y_start, temp_string);
+ firstchar = false;
+ } else {
+ if (linestart)
+ code = pdfi_annot_display_text(ctx, annot, 0, -lineheight, temp_string);
+ else
+ code = pdfi_annot_display_nexttext(ctx, annot, temp_string);
+ }
+ if (code < 0) goto exit;
+ x += awidth.x;
+ linestart = false;
+ }
+
+ exit:
+ code1 = pdfi_ET(ctx);
+ if (code == 0) code = code1;
+ pdfi_countdown(temp_string);
+ return code;
+}
+
+/*********** END Font/Text ***************/
+
+
+/*********** BEGIN /LE ***************/
+
+/* Draw Butt LE */
+static int pdfi_annot_draw_LE_Butt(pdf_context *ctx, pdf_dict *annot)
+{
+ int code;
+ double width;
+ double seglength;
+
+ code = pdfi_annot_get_BS_width(ctx, annot, &width);
+ if (code < 0) goto exit;
+
+ seglength = 3*width;
+ code = gs_moveto(ctx->pgs, 0, -seglength);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, 0, seglength);
+ if (code < 0) goto exit;
+ code = pdfi_annot_draw_border(ctx, annot, true);
+ if (code < 0) goto exit;
+
+ exit:
+ return code;
+}
+
+/* Draw Circle LE */
+static int pdfi_annot_draw_LE_Circle(pdf_context *ctx, pdf_dict *annot)
+{
+ double radius;
+ int code;
+ double width;
+
+ code = pdfi_annot_get_BS_width(ctx, annot, &width);
+ if (code < 0) goto exit;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) goto exit;
+
+ radius = width * 2.5;
+ code = gs_moveto(ctx->pgs, radius, 0);
+ if (code < 0) goto exit_grestore;
+ code = gs_arc(ctx->pgs, 0, 0, radius, 0, 360);
+ if (code < 0) goto exit_grestore;
+ code = pdfi_annot_opacity(ctx, annot);
+ if (code < 0) goto exit_grestore;
+ code = pdfi_annot_fillborderpath(ctx, annot);
+ if (code < 0) goto exit_grestore;
+
+ code = pdfi_grestore(ctx);
+ if (code < 0) goto exit;
+
+ radius = width * 3;
+ code = gs_moveto(ctx->pgs, radius, 0);
+ if (code < 0) goto exit;
+ code = gs_arc(ctx->pgs, 0, 0, radius, 0, 360);
+ if (code < 0) goto exit;
+ code = pdfi_annot_draw_border(ctx, annot, true);
+ goto exit;
+
+ exit_grestore:
+ (void)pdfi_grestore(ctx);
+ exit:
+ return code;
+}
+
+/* Draw Diamond LE */
+static int pdfi_annot_draw_LE_Diamond(pdf_context *ctx, pdf_dict *annot)
+{
+ int code;
+ double width;
+ double seglength;
+
+ code = pdfi_annot_get_BS_width(ctx, annot, &width);
+ if (code < 0) goto exit;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) goto exit;
+
+ seglength = width * 2.5;
+ code = gs_moveto(ctx->pgs, 0, -seglength);
+ if (code < 0) goto exit_grestore;
+ code = gs_lineto(ctx->pgs, -seglength, 0);
+ if (code < 0) goto exit_grestore;
+ code = gs_lineto(ctx->pgs, 0, seglength);
+ if (code < 0) goto exit_grestore;
+ code = gs_lineto(ctx->pgs, seglength, 0);
+ if (code < 0) goto exit_grestore;
+ code = gs_closepath(ctx->pgs);
+ if (code < 0) goto exit_grestore;
+ code = pdfi_annot_opacity(ctx, annot);
+ if (code < 0) goto exit_grestore;
+ code = pdfi_annot_fillborderpath(ctx, annot);
+ if (code < 0) goto exit_grestore;
+
+ code = pdfi_grestore(ctx);
+ if (code < 0) goto exit;
+
+ seglength = width * 3;
+ code = gs_moveto(ctx->pgs, 0, -seglength);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, -seglength, 0);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, 0, seglength);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, seglength, 0);
+ if (code < 0) goto exit;
+ code = gs_closepath(ctx->pgs);
+ if (code < 0) goto exit;
+ code = pdfi_annot_draw_border(ctx, annot, true);
+ goto exit;
+
+ exit_grestore:
+ (void)pdfi_grestore(ctx);
+ exit:
+ return code;
+}
+
+/* Draw Square LE */
+static int pdfi_annot_draw_LE_Square(pdf_context *ctx, pdf_dict *annot)
+{
+ int code;
+ double width;
+ double seglength;
+
+ code = pdfi_annot_get_BS_width(ctx, annot, &width);
+ if (code < 0) goto exit;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) goto exit;
+
+ seglength = width * 2.5;
+ code = gs_moveto(ctx->pgs, -seglength, -seglength);
+ if (code < 0) goto exit_grestore;
+ code = gs_lineto(ctx->pgs, -seglength, seglength);
+ if (code < 0) goto exit_grestore;
+ code = gs_lineto(ctx->pgs, seglength, seglength);
+ if (code < 0) goto exit_grestore;
+ code = gs_lineto(ctx->pgs, seglength, -seglength);
+ if (code < 0) goto exit_grestore;
+ code = gs_closepath(ctx->pgs);
+ if (code < 0) goto exit_grestore;
+ code = pdfi_annot_opacity(ctx, annot);
+ if (code < 0) goto exit_grestore;
+ code = pdfi_annot_fillborderpath(ctx, annot);
+ if (code < 0) goto exit_grestore;
+
+ code = pdfi_grestore(ctx);
+ if (code < 0) goto exit;
+
+ seglength = width * 3;
+ code = gs_moveto(ctx->pgs, -seglength, -seglength);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, -seglength, seglength);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, seglength, seglength);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, seglength, -seglength);
+ if (code < 0) goto exit;
+ code = gs_closepath(ctx->pgs);
+ if (code < 0) goto exit;
+ code = pdfi_annot_draw_border(ctx, annot, true);
+ goto exit;
+
+ exit_grestore:
+ (void)pdfi_grestore(ctx);
+ exit:
+ return code;
+}
+
+/* Draw Slash LE */
+static int pdfi_annot_draw_LE_Slash(pdf_context *ctx, pdf_dict *annot)
+{
+ int code;
+ double width;
+ double seglength;
+
+ code = pdfi_annot_get_BS_width(ctx, annot, &width);
+ if (code < 0) goto exit;
+
+ seglength = 3*width;
+ code = gs_rotate(ctx->pgs, 330);
+ if (code < 0) goto exit;
+ code = gs_moveto(ctx->pgs, 0, -seglength);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, 0, seglength);
+ if (code < 0) goto exit;
+ code = pdfi_annot_draw_border(ctx, annot, true);
+ if (code < 0) goto exit;
+
+ exit:
+ return code;
+}
+
+/* Draw ClosedArrow LE */
+static int pdfi_annot_draw_LE_ClosedArrow(pdf_context *ctx, pdf_dict *annot)
+{
+ int code;
+ double width;
+ double seglen;
+
+ code = pdfi_annot_get_BS_width(ctx, annot, &width);
+ if (code < 0) goto exit;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) goto exit_grestore;
+
+ code = gs_setlinejoin(ctx->pgs, 0);
+ if (code < 0) goto exit_grestore;
+ code = gs_moveto(ctx->pgs, -width*6, -width*4);
+ if (code < 0) goto exit_grestore;
+ code = gs_lineto(ctx->pgs, -width/1.2, 0);
+ if (code < 0) goto exit_grestore;
+ code = gs_lineto(ctx->pgs, -width*6, width*4);
+ if (code < 0) goto exit_grestore;
+ code = gs_closepath(ctx->pgs);
+ if (code < 0) goto exit_grestore;
+ code = pdfi_annot_draw_border(ctx, annot, true);
+ if (code < 0) goto exit_grestore;
+
+ code = pdfi_grestore(ctx);
+ if (code < 0) goto exit;
+
+ code = gs_translate(ctx->pgs, -1.3*width, 0);
+ if (code < 0) goto exit;
+ seglen = width / 2;
+ code = gs_moveto(ctx->pgs, -seglen*8.4, -seglen*5.9);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, -seglen/1.2, 0);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, -seglen*8.4, seglen*5.9);
+ if (code < 0) goto exit;
+ code = gs_closepath(ctx->pgs);
+ if (code < 0) goto exit;
+ code = pdfi_annot_opacity(ctx, annot);
+ if (code < 0) goto exit;
+ code = pdfi_annot_fillborderpath(ctx, annot);
+ goto exit;
+
+ exit_grestore:
+ (void)pdfi_grestore(ctx);
+ exit:
+ return code;
+}
+
+/* Draw OpenArrow LE */
+static int pdfi_annot_draw_LE_OpenArrow(pdf_context *ctx, pdf_dict *annot)
+{
+ int code;
+ double width;
+
+ code = pdfi_annot_get_BS_width(ctx, annot, &width);
+ if (code < 0) goto exit;
+
+ code = gs_setlinejoin(ctx->pgs, 0);
+ if (code < 0) goto exit;
+
+ code = gs_moveto(ctx->pgs, -width*6, -width*4);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, -width/1.2, 0);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, -width*6, width*4);
+ if (code < 0) goto exit;
+ code = pdfi_annot_draw_border(ctx, annot, true);
+ if (code < 0) goto exit;
+
+ exit:
+ return code;
+}
+
+/* Draw RClosedArrow LE */
+static int pdfi_annot_draw_LE_RClosedArrow(pdf_context *ctx, pdf_dict *annot)
+{
+ int code;
+
+ code = gs_rotate(ctx->pgs, 180);
+ if (code < 0) goto exit;
+ code = pdfi_annot_draw_LE_ClosedArrow(ctx, annot);
+ if (code < 0) goto exit;
+
+ exit:
+ return code;
+}
+
+/* Draw ROpenArrow LE */
+static int pdfi_annot_draw_LE_ROpenArrow(pdf_context *ctx, pdf_dict *annot)
+{
+ int code;
+
+ code = gs_rotate(ctx->pgs, 180);
+ if (code < 0) goto exit;
+ code = pdfi_annot_draw_LE_OpenArrow(ctx, annot);
+ if (code < 0) goto exit;
+
+ exit:
+ return code;
+}
+
+/* Draw None or null LE (do nothing) */
+static int pdfi_annot_draw_LE_None(pdf_context *ctx, pdf_dict *annot)
+{
+ return 0;
+}
+
+annot_LE_dispatch_t annot_LE_dispatch[] = {
+ {"Butt", pdfi_annot_draw_LE_Butt},
+ {"Circle", pdfi_annot_draw_LE_Circle},
+ {"Diamond", pdfi_annot_draw_LE_Diamond},
+ {"Slash", pdfi_annot_draw_LE_Slash},
+ {"Square", pdfi_annot_draw_LE_Square},
+ {"ClosedArrow", pdfi_annot_draw_LE_ClosedArrow},
+ {"OpenArrow", pdfi_annot_draw_LE_OpenArrow},
+ {"RClosedArrow", pdfi_annot_draw_LE_RClosedArrow},
+ {"ROpenArrow", pdfi_annot_draw_LE_ROpenArrow},
+ {"None", pdfi_annot_draw_LE_None},
+ { NULL, NULL},
+};
+
+/* Draw one line ending at (x,y) */
+static int pdfi_annot_draw_LE_one(pdf_context *ctx, pdf_dict *annot, pdf_name *LE,
+ double x, double y, double angle)
+{
+ int code;
+ int code1;
+ annot_LE_dispatch_t *dispatch_ptr;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) goto exit1;
+
+ code = gs_translate(ctx->pgs, x, y);
+ code = gs_moveto(ctx->pgs, 0, 0);
+ code = gs_rotate(ctx->pgs, angle);
+
+ /* Draw the LE */
+ for (dispatch_ptr = annot_LE_dispatch; dispatch_ptr->name; dispatch_ptr ++) {
+ if (pdfi_name_is(LE, dispatch_ptr->name)) {
+ code = dispatch_ptr->func(ctx, annot);
+ break;
+ }
+ }
+ if (!dispatch_ptr->name) {
+ char str[100];
+ memcpy(str, (const char *)LE->data, LE->length);
+ str[LE->length] = '\0';
+ dbgmprintf1(ctx->memory, "ANNOT: WARNING No handler for LE %s\n", str);
+ }
+
+ exit1:
+ code1 = pdfi_grestore(ctx);
+ if (code < 0)
+ code = code1;
+ return code;
+}
+
+/* Draw line endings using LE entry in annotation dictionary
+ * Draws one at (x1,y1) and one at (x2,y2)
+ * If LE is a name instead of an array, only draws at x2,y2 (but needs x1,y1 for angle)
+ * (defaults to None if not there)
+ *
+ * which -- tells whether to draw both ends (0) or just the first one (1) or second one (2)
+ */
+static int pdfi_annot_draw_LE(pdf_context *ctx, pdf_dict *annot,
+ double x1, double y1, double x2, double y2, int which)
+{
+ pdf_obj *LE = NULL;
+ pdf_name *LE1 = NULL;
+ pdf_name *LE2 = NULL;
+ double dx, dy;
+ double angle;
+ int code;
+
+ code = pdfi_dict_knownget(ctx, annot, "LE", (pdf_obj **)&LE);
+ if (code <= 0)
+ goto exit;
+ if (LE->type != PDF_ARRAY && LE->type != PDF_NAME) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+
+ dx = x2 - x1;
+ dy = y2 - y1;
+ code = gs_atan2_degrees(dy, dx, &angle);
+ if (code < 0)
+ angle = 0;
+
+ if (LE->type == PDF_ARRAY) {
+ code = pdfi_array_get_type(ctx, (pdf_array *)LE, 0, PDF_NAME, (pdf_obj **)&LE1);
+ if (code < 0) goto exit;
+
+ code = pdfi_array_get_type(ctx, (pdf_array *)LE, 1, PDF_NAME, (pdf_obj **)&LE2);
+ if (code < 0) goto exit;
+ } else {
+ LE1 = (pdf_name *)LE;
+ LE = NULL;
+ }
+ if (LE1 && (!which || which == 1)) {
+ code = pdfi_annot_draw_LE_one(ctx, annot, LE1, x1, y1, angle+180);
+ if (code < 0) goto exit;
+ }
+
+ if (LE2 && (!which || which == 2)) {
+ code = pdfi_annot_draw_LE_one(ctx, annot, LE2, x2, y2, angle);
+ if (code < 0) goto exit;
+ }
+
+ exit:
+ pdfi_countdown(LE);
+ pdfi_countdown(LE1);
+ pdfi_countdown(LE2);
+ return code;
+}
+/*********** END /LE ***************/
+
+
+/* Get the Normal AP dictionary/stream, if it exists
+ * Not an error if it doesn't exist, it will just be NULL
+ */
+static int pdfi_annot_get_NormAP(pdf_context *ctx, pdf_dict *annot, pdf_obj **NormAP)
+{
+ int code;
+ pdf_dict *AP_dict = NULL;
+ pdf_stream *AP = NULL;
+ pdf_obj *baseAP = NULL;
+ pdf_name *AS = NULL;
+
+ *NormAP = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, annot, "AP", PDF_DICT, (pdf_obj **)&AP_dict);
+ if (code <= 0) goto exit;
+
+ code = pdfi_dict_knownget(ctx, AP_dict, "N", (pdf_obj **)&baseAP);
+ if (code < 0) goto exit;
+
+ /* Look for /R and /D if there was no /N */
+ if (code == 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_ANNOT_AP_ERROR, "pdfi_annot_get_NormAP", "*** Error: Annotation (AP) lacks the mandatory normal (N) appearance");
+
+ code = pdfi_dict_knownget(ctx, AP_dict, "R", (pdf_obj **)&baseAP);
+ if (code < 0) goto exit;
+
+ if (code == 0) {
+ code = pdfi_dict_knownget(ctx, AP_dict, "D", (pdf_obj **)&baseAP);
+ if (code < 0) goto exit;
+ }
+ }
+
+ /* Nothing found */
+ if (code == 0) goto exit;
+
+ if (baseAP->type == PDF_STREAM) {
+ /* Use baseAP for the AP */
+ AP = (pdf_stream *)baseAP;
+ baseAP = NULL;
+ } else {
+ if (baseAP->type != PDF_DICT) {
+ code = gs_error_typecheck;
+ goto exit;
+ }
+
+ code = pdfi_dict_knownget_type(ctx, annot, "AS", PDF_NAME, (pdf_obj **)&AS);
+ if (code < 0) goto exit;
+ if (code == 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_ANNOT_AP_ERROR, "pdfi_annot_get_NormAP", "WARNING Annotation has non-stream AP but no AS. Don't know what to render");
+ goto exit;
+ }
+
+ /* Lookup the AS in the NormAP and use that as the AP */
+ code = pdfi_dict_get_by_key(ctx, (pdf_dict *)baseAP, AS, (pdf_obj **)&AP);
+ if (code < 0) {
+ /* Apparently this is not an error, just silently don't have an AP */
+ code = 0;
+ goto exit;
+ }
+ if (AP->type != PDF_STREAM) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+ }
+
+ *NormAP = (pdf_obj *)AP;
+ pdfi_countup(AP);
+
+ exit:
+ pdfi_countdown(AP_dict);
+ pdfi_countdown(AP);
+ pdfi_countdown(AS);
+ pdfi_countdown(baseAP);
+ return code;
+}
+
+static int pdfi_annot_draw_Link(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ int code;
+ int code1;
+ bool drawit;
+
+ dbgmprintf(ctx->memory, "ANNOT: Drawing Link\n");
+
+ code = pdfi_annot_start_transparency(ctx, annot);
+ if (code < 0)
+ return code;
+
+ code = pdfi_annot_setcolor(ctx, annot, true, &drawit);
+ if (code < 0) goto exit;
+ if (!drawit) goto exit;
+
+ code = pdfi_annot_draw_border(ctx, annot, false);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_draw_AP(ctx, annot, NormAP);
+
+ exit:
+ code1 = pdfi_annot_end_transparency(ctx, annot);
+ if (code < 0) code = code1;
+
+ *render_done = true;
+ return code;
+}
+
+/* Draw a path from an InkList
+ * see zpdfops.c/zpdfinkpath()
+ *
+ * Construct a smooth path passing though a number of points on the stack
+ * for PDF ink annotations. The program is based on a very simple method of
+ * smoothing polygons by Maxim Shemanarev.
+ * http://www.antigrain.com/research/bezier_interpolation/
+ *
+ * InkList is array of arrays, each representing a stroked path
+ */
+static int pdfi_annot_draw_InkList(pdf_context *ctx, pdf_dict *annot, pdf_array *InkList)
+{
+ int code = 0;
+ pdf_array *points = NULL;
+ int i;
+ int num_points;
+ double x0, y0, x1, y1, x2, y2, x3, y3, xc1, yc1, xc2, yc2, xc3, yc3;
+ double len1, len2, len3, k1, k2, xm1, ym1, xm2, ym2;
+ double ctrl1_x, ctrl1_y, ctrl2_x, ctrl2_y;
+ const double smooth_value = 1; /* from 0..1 range */
+
+ for (i=0; i<pdfi_array_size(InkList); i++) {
+ int j;
+
+ code = pdfi_array_get_type(ctx, InkList, i, PDF_ARRAY, (pdf_obj **)&points);
+ if (code < 0)
+ goto exit;
+
+ num_points = pdfi_array_size(points);
+ if (num_points < 2)
+ goto exit;
+
+ code = pdfi_array_get_number(ctx, points, 0, &x1);
+ if (code < 0) goto exit;
+ code = pdfi_array_get_number(ctx, points, 1, &y1);
+ if (code < 0) goto exit;
+ code = gs_moveto(ctx->pgs, x1, y1);
+ if (code < 0) goto exit;
+ if (num_points == 2)
+ goto stroke;
+
+ code = pdfi_array_get_number(ctx, points, 2, &x2);
+ if (code < 0) goto exit;
+ code = pdfi_array_get_number(ctx, points, 3, &y2);
+ if (code < 0) goto exit;
+ if (num_points == 4) {
+ code = gs_lineto(ctx->pgs, x2, y2);
+ if (code < 0)
+ goto exit;
+ goto stroke;
+ }
+
+ x0 = 2*x1 - x2;
+ y0 = 2*y1 - y2;
+
+ for (j = 4; j <= num_points; j += 2) {
+ if (j < num_points) {
+ code = pdfi_array_get_number(ctx, points, j, &x3);
+ if (code < 0) goto exit;
+ code = pdfi_array_get_number(ctx, points, j+1, &y3);
+ if (code < 0) goto exit;
+ } else {
+ x3 = 2*x2 - x1;
+ y3 = 2*y2 - y1;
+ }
+
+ xc1 = (x0 + x1) / 2.0;
+ yc1 = (y0 + y1) / 2.0;
+ xc2 = (x1 + x2) / 2.0;
+ yc2 = (y1 + y2) / 2.0;
+ xc3 = (x2 + x3) / 2.0;
+ yc3 = (y2 + y3) / 2.0;
+
+ len1 = hypot(x1 - x0, y1 - y0);
+ len2 = hypot(x2 - x1, y2 - y1);
+ len3 = hypot(x3 - x2, y3 - y2);
+
+ if ((len1 + len2) == 0)
+ k1 = 0;
+ else
+ k1 = len1 / (len1 + len2);
+ if ((len2 + len3) == 0)
+ k2 = 0;
+ else
+ k2 = len2 / (len2 + len3);
+
+ xm1 = xc1 + (xc2 - xc1) * k1;
+ ym1 = yc1 + (yc2 - yc1) * k1;
+
+ xm2 = xc2 + (xc3 - xc2) * k2;
+ ym2 = yc2 + (yc3 - yc2) * k2;
+
+ ctrl1_x = xm1 + (xc2 - xm1) * smooth_value + x1 - xm1;
+ ctrl1_y = ym1 + (yc2 - ym1) * smooth_value + y1 - ym1;
+
+ ctrl2_x = xm2 + (xc2 - xm2) * smooth_value + x2 - xm2;
+ ctrl2_y = ym2 + (yc2 - ym2) * smooth_value + y2 - ym2;
+
+ code = gs_curveto(ctx->pgs, ctrl1_x, ctrl1_y, ctrl2_x, ctrl2_y, x2, y2);
+ if (code < 0) goto exit;
+
+ x0 = x1, x1 = x2, x2 = x3;
+ y0 = y1, y1 = y2, y2 = y3;
+ }
+
+ stroke:
+ code = gs_stroke(ctx->pgs);
+ if (code < 0) goto exit;
+ pdfi_countdown(points);
+ points = NULL;
+ }
+
+ exit:
+ pdfi_countdown(points);
+ return code;
+}
+
+/* Draw a path from a Path array (see 2.0 spec 12.5.6.13)
+ * Path is array of arrays.
+ * First array is 2 args for moveto
+ * The rest of the arrays are either 2 args for lineto or 6 args for curveto
+ */
+static int pdfi_annot_draw_Path(pdf_context *ctx, pdf_dict *annot, pdf_array *Path)
+{
+ int code = 0;
+ pdf_array *points = NULL;
+ double array[6];
+ int i;
+ int num_points;
+
+ for (i=0; i<pdfi_array_size(Path); i++) {
+ code = pdfi_array_get_type(ctx, Path, i, PDF_ARRAY, (pdf_obj **)&points);
+ if (code < 0)
+ goto exit;
+
+ num_points = pdfi_array_size(points);
+ if (num_points != 2 && num_points != 6) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+
+ code = pdfi_array_to_num_array(ctx, points, array, 0, num_points);
+ if (code < 0) goto exit;
+
+ if (i == 0) {
+ code = gs_moveto(ctx->pgs, array[0], array[1]);
+ if (code < 0) goto exit;
+ } else {
+ if (num_points == 2) {
+ code = gs_lineto(ctx->pgs, array[0], array[1]);
+ if (code < 0) goto exit;
+ } else {
+ code = gs_curveto(ctx->pgs, array[0], array[1],
+ array[2], array[3], array[4], array[5]);
+ if (code < 0) goto exit;
+ }
+ }
+
+ pdfi_countdown(points);
+ points = NULL;
+ }
+
+ code = pdfi_annot_draw_border(ctx, annot, true);
+
+ exit:
+ pdfi_countdown(points);
+ return code;
+}
+
+/* Generate appearance (see pdf_draw.ps/Ink
+ *
+ * If there was an AP it was already handled.
+ */
+static int pdfi_annot_draw_Ink(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ int code = 0;
+ int code1 = 0;
+ bool drawit;
+ pdf_array *array = NULL;
+
+ code = pdfi_annot_setcolor(ctx, annot, false, &drawit);
+ if (code <0 || !drawit)
+ goto exit1;
+
+ code = pdfi_annot_start_transparency(ctx, annot);
+ if (code < 0) goto exit1;
+
+ code = gs_setlinewidth(ctx->pgs, 1);
+ if (code < 0) goto exit;
+ code = gs_setlinecap(ctx->pgs, 1);
+ if (code < 0) goto exit;
+ code = gs_setlinejoin(ctx->pgs, 1);
+ if (code < 0) goto exit;
+
+ code = pdfi_dict_knownget_type(ctx, annot, "InkList", PDF_ARRAY, (pdf_obj **)&array);
+ if (code < 0) goto exit;
+ if (code > 0) {
+ code = pdfi_annot_draw_InkList(ctx, annot, array);
+ goto exit;
+ }
+ code = pdfi_dict_knownget_type(ctx, annot, "Path", PDF_ARRAY, (pdf_obj **)&array);
+ if (code < 0) goto exit;
+ if (code > 0) {
+ code = pdfi_annot_draw_Path(ctx, annot, array);
+ goto exit;
+ }
+
+ exit:
+ code1 = pdfi_annot_end_transparency(ctx, annot);
+ if (code >= 0)
+ code = code1;
+ exit1:
+ pdfi_countdown(array);
+ *render_done = true;
+ return code;
+}
+
+/* from pdf_draw.ps/drawellipse
+ * "Don Lancaster's code for drawing an ellipse"
+ * https://www.tinaja.com/glib/ellipse4.pdf
+ *
+/magic 0.55228475 0.00045 sub store % improved value
+/drawellipse {
+2 div /yrad exch store
+2 div /xrad exch store
+/xmag xrad magic mul store
+/ymag yrad magic mul store xrad
+neg 0 moveto
+xrad neg ymag xmag neg yrad 0 yrad curveto
+xmag yrad xrad ymag xrad 0 curveto
+xrad ymag neg xmag yrad neg 0 yrad neg curveto
+xmag neg yrad neg xrad neg ymag neg xrad neg 0 curveto
+} bind def
+
+ */
+static int pdfi_annot_drawellipse(pdf_context *ctx, double width, double height)
+{
+ int code = 0;
+ double magic = .55228475 - .00045; /* Magic value */
+ double xrad = width / 2;
+ double yrad = height / 2;
+ double xmag = xrad * magic;
+ double ymag = yrad * magic;
+
+ code = gs_moveto(ctx->pgs, -xrad, 0);
+ if (code < 0) return code;
+ code = gs_curveto(ctx->pgs, -xrad, ymag, -xmag, yrad, 0, yrad);
+ if (code < 0) return code;
+ code = gs_curveto(ctx->pgs, xmag, yrad, xrad, ymag, xrad, 0);
+ if (code < 0) return code;
+ code = gs_curveto(ctx->pgs, xrad, -ymag, xmag, -yrad, 0, -yrad);
+ if (code < 0) return code;
+ code = gs_curveto(ctx->pgs, -xmag, -yrad, -xrad, -ymag, -xrad, 0);
+
+ return code;
+}
+
+/* Generate appearance (see pdf_draw.ps/Circle)
+ *
+ * If there was an AP it was already handled.
+ */
+static int pdfi_annot_draw_Circle(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ int code = 0;
+ int code1 = 0;
+ gs_rect rect;
+ bool drawit;
+ double width, height;
+
+ code = pdfi_annot_start_transparency(ctx, annot);
+ if (code < 0) goto exit1;
+
+ code = pdfi_annot_Rect(ctx, annot, &rect);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_applyRD(ctx, annot, &rect);
+ if (code < 0) goto exit;
+
+ /* Translate to the center of the ellipse */
+ width = rect.q.x - rect.p.x;
+ height = rect.q.y - rect.p.y;
+ code = gs_translate(ctx->pgs, rect.p.x + width/2, rect.p.y + height/2);
+ if (code < 0) goto exit;
+
+ /* Draw the ellipse */
+ code = pdfi_annot_drawellipse(ctx, width, height);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_fillborderpath(ctx, annot);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_setcolor(ctx, annot, false, &drawit);
+ if (code < 0) goto exit;
+
+ if (drawit) {
+ code = pdfi_annot_draw_border(ctx, annot, true);
+ if (code < 0) goto exit;
+ }
+
+ exit:
+ code1 = pdfi_annot_end_transparency(ctx, annot);
+ if (code >= 0)
+ code = code1;
+ exit1:
+ *render_done = true;
+ return code;
+}
+
+
+/*********** BEGIN /Stamp ***************/
+typedef struct {
+ double r,g,b;
+} pdfi_annot_stamp_rgb_t;
+
+#define STAMP_RED {0xef/255.,0x40/255.,0x23/255.}
+#define STAMP_GREEN {0x2f/255.,0xae/255.,0x49/255.}
+#define STAMP_BLUE {0x00/255.,0x72/255.,0xbc/255.}
+
+typedef struct {
+ const char *text;
+ double y;
+ double h;
+} pdfi_annot_stamp_text_t;
+
+typedef struct {
+ const char *type;
+ pdfi_annot_stamp_rgb_t rgb;
+ pdfi_annot_stamp_text_t text[2];
+} pdfi_annot_stamp_type_t;
+
+#define STAMP_1LINE(text,y,h) {{text,y,h},{0}}
+#define STAMP_2LINE(text,y,h,text2,y2,h2) {{text,y,h},{text2,y2,h2}}
+
+static pdfi_annot_stamp_type_t pdfi_annot_stamp_types[] = {
+ {"Approved", STAMP_GREEN, STAMP_1LINE("APPROVED", 13, 30)},
+ {"AsIs", STAMP_RED, STAMP_1LINE("AS IS", 13, 30)},
+ {"Confidential", STAMP_RED, STAMP_1LINE("CONFIDENTIAL", 17, 20)},
+ {"Departmental", STAMP_BLUE, STAMP_1LINE("DEPARTMENTAL", 17, 20)},
+ {"Draft", STAMP_RED, STAMP_1LINE("DRAFT", 13, 30)},
+ {"Experimental", STAMP_BLUE, STAMP_1LINE("EXPERIMENTAL", 17, 20)},
+ {"Expired", STAMP_RED, STAMP_1LINE("EXPIRED", 13, 30)},
+ {"Final", STAMP_RED, STAMP_1LINE("FINAL", 13, 30)},
+ {"ForComment", STAMP_GREEN, STAMP_1LINE("FOR COMMENT", 17, 20)},
+ {"ForPublicRelease", STAMP_GREEN, STAMP_2LINE("FOR PUBLIC",26,18,"RELEASE",8.5,18)},
+ {"NotApproved", STAMP_RED, STAMP_1LINE("NOT APPROVED", 17, 20)},
+ {"NotForPublicRelease", STAMP_RED, STAMP_2LINE("NOT FOR",26,18,"PUBLIC RELEASE",8.5,18)},
+ {"Sold", STAMP_BLUE, STAMP_1LINE("SOLD", 13, 30)},
+ {"TopSecret", STAMP_RED, STAMP_1LINE("TOP SECRET", 14, 26)},
+ {0}
+};
+/* Use "Draft" if not found, make sure this value is correct if above array changes */
+#define STAMP_DRAFT_INDEX 4
+
+/* Draw the frame for the stamp. This is taken straight form the PS code. */
+static int pdfi_annot_draw_stamp_frame(pdf_context *ctx)
+{
+ int code;
+
+ code = gs_moveto(ctx->pgs, 6.0, 0.0);
+ if (code < 0) goto exit;
+ code = gs_arcto(ctx->pgs, 190, 0, 190, 6, 6, 0);
+ if (code < 0) goto exit;
+ code = gs_arcto(ctx->pgs, 190, 47, 184, 47, 6, 0);
+ if (code < 0) goto exit;
+ code = gs_arcto(ctx->pgs, 0, 47, 0, 41, 6, 0);
+ if (code < 0) goto exit;
+ code = gs_arcto(ctx->pgs, 0, 0, 6, 0, 6, 0);
+ if (code < 0) goto exit;
+ code = gs_closepath(ctx->pgs);
+ if (code < 0) goto exit;
+
+ code = gs_moveto(ctx->pgs, 10, 4);
+ if (code < 0) goto exit;
+ code = gs_arcto(ctx->pgs, 185, 4, 185, 9, 5, 0);
+ if (code < 0) goto exit;
+ code = gs_arcto(ctx->pgs, 185, 43, 180, 43, 5, 0);
+ if (code < 0) goto exit;
+ code = gs_arcto(ctx->pgs, 5, 43, 5, 38, 5, 0);
+ if (code < 0) goto exit;
+ code = gs_arcto(ctx->pgs, 5, 4, 9, 4, 5, 0);
+ if (code < 0) goto exit;
+ code = gs_closepath(ctx->pgs);
+ if (code < 0) goto exit;
+ code = gs_eofill(ctx->pgs);
+ if (code < 0) goto exit;
+
+ exit:
+ return code;
+}
+
+/* draw text for stamp */
+static int pdfi_annot_draw_stamp_text(pdf_context *ctx, pdf_dict *annot, gs_rect *rect,
+ pdfi_annot_stamp_text_t *text)
+{
+ int code = 0;
+ int code1 = 0;
+ pdf_string *string = NULL;
+ gs_rect bbox;
+ gs_point awidth;
+ double x,y;
+
+ if (!text->text)
+ return 0;
+
+ code = pdfi_BT(ctx);
+ if (code < 0)
+ return code;
+
+ code = pdfi_annot_set_font(ctx, "Times-Bold", text->h);
+ if (code < 0) goto exit;
+
+ code = pdfi_obj_charstr_to_string(ctx, text->text, &string);
+ if (code < 0) goto exit;
+
+
+ /* At this point the graphics state is slightly rotated and current position
+ * is at the lower left corner of the stamp's box.
+ * The math here matches what the gs code does, so it's kind of confusing.
+ */
+ /* Get width of the string */
+ code = pdfi_string_bbox(ctx, string, &bbox, &awidth, false);
+ if (code < 0) goto exit;
+
+ /* Calculate offset from corner (95 is hard-coded value based on size of the stamp I think) */
+ x = 95 - (bbox.q.x-bbox.p.x)/2; /* hard-coded value taken from gs code */
+ y = text->y;
+
+ code = pdfi_gsave(ctx);
+ code = pdfi_gs_setgray(ctx, .75);
+ code = pdfi_annot_display_simple_text(ctx, annot, x+1, y-1, string);
+ if (code < 0) goto exit;
+ code = pdfi_grestore(ctx);
+
+ code = pdfi_annot_display_simple_text(ctx, annot, x, y, string);
+ if (code < 0) goto exit;
+
+ exit:
+ code1 = pdfi_ET(ctx);
+ if (code == 0) code = code1;
+ pdfi_countdown(string);
+ return 0;
+}
+
+/* Generate appearance (see pdf_draw.ps/Stamp)
+ *
+ * If there was an AP it was already handled.
+ * For testing, see tests_private/pdf/PDF_1.7_FTS/fts_32_3204.pdf
+ */
+static int pdfi_annot_draw_Stamp(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ int code = 0;
+ int code1 = 0;
+ gs_rect rect;
+ double width, height;
+ pdfi_annot_stamp_type_t *stamp_type;
+ pdf_name *Name = NULL;
+ double xscale, yscale;
+ double angle;
+ int i;
+
+ code = pdfi_annot_start_transparency(ctx, annot);
+ if (code < 0) goto exit1;
+
+ code = pdfi_annot_Rect(ctx, annot, &rect);
+ if (code < 0) goto exit;
+
+ code = pdfi_dict_knownget_type(ctx, annot, "Name", PDF_NAME, (pdf_obj **)&Name);
+ if (code <= 0) goto exit;
+
+ /* Translate to the center of Rect */
+ width = rect.q.x - rect.p.x;
+ height = rect.q.y - rect.p.y;
+ code = gs_translate(ctx->pgs, rect.p.x + width/2, rect.p.y + height/2);
+ if (code < 0) goto exit;
+
+ /* This math comes from the PS code. I assume the values are related to
+ the h and y values in the various Stamp type data.
+ */
+ /* Scale by the minimum of the two ratios, but make sure it's not 0 */
+ yscale = height / 50.;
+ xscale = width / 190.;
+ if (xscale < yscale)
+ yscale = xscale;
+ if (yscale <= 0.0)
+ yscale = 1.0;
+ code = gs_scale(ctx->pgs, yscale, yscale);
+ if (code < 0) goto exit;
+
+ /* Search through types and find a match, if no match use Draft */
+ for (stamp_type = pdfi_annot_stamp_types; stamp_type->type; stamp_type ++) {
+ if (Name && pdfi_name_is(Name, stamp_type->type))
+ break;
+ }
+
+ /* TODO: There are a bunch of Stamp Names built into AR that are not part of
+ * the spec. Since we don't know about them, we will just display nothing.
+ * Example: the "Faces" stamps, such as FacesZippy
+ * See file tests_private/pdf/uploads/annots-noAP.pdf
+ */
+ if (!stamp_type->type) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_ANNOT_ERROR, "pdfi_annot_draw_Stamp", "WARNING: Annotation: No AP, unknown Stamp Name, omitting");
+ code = 0;
+ goto exit;
+ }
+
+ /* Draw the frame */
+ code = pdfi_gs_setrgbcolor(ctx, stamp_type->rgb.r, stamp_type->rgb.g,
+ stamp_type->rgb.b);
+ if (code < 0) goto exit;
+
+ code = gs_translate(ctx->pgs, -95, -25);
+ if (code < 0) goto exit;
+ code = gs_atan2_degrees(2.0, 190.0, &angle);
+ if (code < 0) goto exit;
+ code = gs_rotate(ctx->pgs, angle);
+ if (code < 0) goto exit;
+
+ /* Draw frame in gray */
+ code = pdfi_gsave(ctx);
+ code = gs_translate(ctx->pgs, 1, -1);
+ code = pdfi_gs_setgray(ctx, 0.75);
+ code = pdfi_annot_draw_stamp_frame(ctx);
+ code = pdfi_grestore(ctx);
+
+ /* Draw frame colored */
+ code = pdfi_annot_draw_stamp_frame(ctx);
+
+ /* Draw the text */
+ for (i=0; i<2; i++) {
+ code = pdfi_annot_draw_stamp_text(ctx, annot, &rect, &stamp_type->text[i]);
+ if (code < 0) goto exit;
+ }
+
+ exit:
+ code1 = pdfi_annot_end_transparency(ctx, annot);
+ if (code >= 0)
+ code = code1;
+ exit1:
+ pdfi_countdown(Name);
+ *render_done = true;
+ return code;
+}
+/*********** END /Stamp ***************/
+
+
+/* Draw Callout Line (CL) */
+static int pdfi_annot_draw_CL(pdf_context *ctx, pdf_dict *annot)
+{
+ int code;
+ pdf_array *CL = NULL;
+ double array[6];
+ int length;
+
+ code = pdfi_dict_knownget_type(ctx, annot, "CL", PDF_ARRAY, (pdf_obj **)&CL);
+ if (code <= 0) goto exit;
+
+ length = pdfi_array_size(CL);
+
+ if (length != 4 && length != 6) {
+ code = gs_note_error(gs_error_syntaxerror);
+ goto exit;
+ }
+
+ code = pdfi_array_to_num_array(ctx, CL, array, 0, length);
+ if (code < 0) goto exit;
+
+ /* Draw the line */
+ code = gs_moveto(ctx->pgs, array[0], array[1]);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, array[2], array[3]);
+ if (code < 0) goto exit;
+ if (length == 6) {
+ code = gs_lineto(ctx->pgs, array[4], array[5]);
+ if (code < 0) goto exit;
+ }
+ code = gs_stroke(ctx->pgs);
+
+ /* Line ending
+ * NOTE: This renders a different arrow than the gs code, but I used the
+ * same LE code I used elsewhere, which is clearly better. So there will be diffs...
+ */
+ code = pdfi_annot_draw_LE(ctx, annot, array[0], array[1], array[2], array[3], 1);
+ if (code < 0) goto exit;
+
+ exit:
+ pdfi_countdown(CL);
+ return code;
+}
+
+/* FreeText -- Draw text with border around it.
+ *
+ * See pdf_draw.ps/FreeText
+ * If there was an AP it was already handled
+ */
+static int pdfi_annot_draw_FreeText(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ int code = 0;
+ int code1 = 0;
+ bool drawbackground;
+ pdf_dict *BS = NULL;
+ pdf_string *Contents = NULL;
+ gs_rect annotrect, modrect;
+ int64_t Rotate;
+
+ *render_done = false;
+
+ code = pdfi_annot_start_transparency(ctx, annot);
+ if (code < 0) goto exit1;
+
+ code = pdfi_annot_opacity(ctx, annot);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_Rect(ctx, annot, &annotrect);
+ if (code < 0) goto exit;
+
+ /* Set the (background?) color if applicable */
+ code = pdfi_annot_setcolor(ctx, annot, false, &drawbackground);
+ if (code < 0) goto exit;
+
+ /* Only draw rectangle if a color was specified */
+ if (drawbackground) {
+ code = pdfi_annot_fillRect(ctx, annot);
+ if (code < 0) goto exit;
+ }
+
+ /* Set DA (Default Appearance)
+ * This will generally set a color and font.
+ *
+ * TODO: Unclear if this is supposed to also determine the color
+ * of the border box, but it seems like it does in gs, so we set the DA
+ * before drawing the border, like gs does.
+ */
+ code = pdfi_annot_process_DA(ctx, NULL, annot, &annotrect, false);
+ if (code < 0) goto exit;
+
+ /* Draw border around text */
+ /* TODO: gs-compatible implementation is commented out. Would rather just delete it... */
+#if 1
+ /* TODO: Prefer to do it this way! */
+ code = pdfi_annot_draw_border(ctx, annot, false);
+ if (code < 0) goto exit;
+#else
+ /* NOTE: I would really like to just call pdfi_annot_draw_border()
+ * without checking for BS, but the implementation in gs is subtly different (see below)
+ * and I want to make it possible to bmpcmp.
+ */
+ code = pdfi_dict_knownget_type(ctx, annot, "BS", PDF_DICT, (pdf_obj **)&BS);
+ if (code < 0) goto exit;
+ if (BS) {
+ code = pdfi_annot_draw_border(ctx, annot, false);
+ if (code < 0) goto exit;
+ } else {
+ gs_rect rect;
+
+ /* Draw our own border */
+ code = pdfi_gs_setgray(ctx, 0);
+ if (code < 0) goto exit;
+
+ /* NOTE: This is almost identical to pdfi_annot_strokeborder() with a width=1.0
+ * except it adjusts the rectangle by 1.0 instead of 0.5.
+ * Should probably just call that function, but I want to match gs implementation
+ * exactly for bmpcmp purposes.
+ */
+ code = gs_setlinewidth(ctx->pgs, 1);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_Rect(ctx, annot, &rect);
+ if (code < 0) goto exit;
+
+ pdfi_annot_rect_adjust(ctx, &rect, 1);
+ code = gs_rectstroke(ctx->pgs, &rect, 1, NULL);
+ if (code < 0) goto exit;
+ }
+#endif
+
+ code = pdfi_annot_draw_CL(ctx, annot);
+ if (code < 0) goto exit;
+
+ /* Modify rect by RD if applicable */
+ code = pdfi_annot_applyRD(ctx, annot, &annotrect);
+ if (code < 0) goto exit;
+
+ /* /Rotate */
+ code = pdfi_dict_get_int_def(ctx, annot, "Rotate", &Rotate, 0);
+ if (code < 0) goto exit;
+
+ modrect = annotrect; /* structure copy */
+ /* TODO: I think this can all be done in a generic way using gs_transform() but it
+ * makes my head explode...
+ */
+ switch(Rotate) {
+ case 270:
+ code = gs_moveto(ctx->pgs, modrect.q.y, modrect.q.x);
+ if (code < 0) goto exit;
+ code = gs_rotate(ctx->pgs, 270.0);
+ modrect.p.x = -annotrect.q.y;
+ modrect.q.x = -annotrect.p.y;
+ modrect.p.y = annotrect.p.x;
+ modrect.q.y = annotrect.q.x;
+ break;
+ case 180:
+ code = gs_moveto(ctx->pgs, modrect.q.x, modrect.p.y);
+ if (code < 0) goto exit;
+ code = gs_rotate(ctx->pgs, 180.0);
+ modrect.p.x = -annotrect.q.x;
+ modrect.q.x = -annotrect.p.x;
+ modrect.p.y = -annotrect.q.y;
+ modrect.q.y = -annotrect.p.y;
+ break;
+ break;
+ case 90:
+ code = gs_moveto(ctx->pgs, modrect.p.y, modrect.p.x);
+ if (code < 0) goto exit;
+ code = gs_rotate(ctx->pgs, 90.0);
+ modrect.p.x = annotrect.p.y;
+ modrect.q.x = annotrect.q.y;
+ modrect.p.y = -annotrect.q.x;
+ modrect.q.y = -annotrect.p.x;
+ break;
+ case 0:
+ default:
+ modrect.p.x += 2;
+ modrect.p.y += 2;
+ modrect.q.x -= 2;
+ modrect.q.y -= 2;
+
+ /* Move to initial position (slightly offset from the corner of the rect) */
+ code = gs_moveto(ctx->pgs, modrect.p.x, modrect.q.y);
+ if (code < 0) goto exit;
+ break;
+ }
+
+ /* /Contents */
+ code = pdfi_dict_knownget_type(ctx, annot, "Contents", PDF_STRING, (pdf_obj **)&Contents);
+ if (code < 0) goto exit;
+ if (code > 0) {
+ code = pdfi_annot_display_formatted_text(ctx, annot, &modrect, Contents, false);
+ if (code < 0) goto exit;
+ }
+
+ exit:
+ code1 = pdfi_annot_end_transparency(ctx, annot);
+ if (code >= 0)
+ code = code1;
+ exit1:
+ *render_done = true;
+ pdfi_countdown(BS);
+ pdfi_countdown(Contents);
+ return code;
+}
+
+/* Generate appearance (see pdf_draw.ps/Text)
+ * This draws the default "Note" thingy which looks like a little page.
+ * TODO: Spec lists a whole bunch of different /Name with different appearances that we don't handle.
+ * See page 1 of tests_private/pdf/sumatra/annotations_without_appearance_streams.pdf
+ *
+ * If there was an AP it was already handled.
+ */
+static int pdfi_annot_draw_Text(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ int code = 0;
+ int code1 = 0;
+ gs_rect rect;
+
+ code = pdfi_annot_start_transparency(ctx, annot);
+ if (code < 0) goto exit1;
+
+ code = pdfi_annot_Rect(ctx, annot, &rect);
+ if (code < 0) goto exit;
+ code = gs_translate(ctx->pgs, rect.p.x, rect.p.y);
+ if (code < 0) goto exit;
+
+ /* Draw a page icon (/Note) */
+ /* TODO: All the other /Name appearances */
+ code = gs_translate(ctx->pgs, 0.5, (rect.q.y-rect.p.y)-18.5);
+ if (code < 0) goto exit;
+ code = gs_setlinewidth(ctx->pgs, 1.0);
+ if (code < 0) goto exit;
+ code = pdfi_gs_setgray(ctx, 0.75);
+ if (code < 0) goto exit;
+ code = gs_moveto(ctx->pgs, 0.5, -1);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, 10, -1);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, 15, 4);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, 15, 17.5);
+ if (code < 0) goto exit;
+ code = gs_stroke(ctx->pgs);
+ if (code < 0) goto exit;
+
+ code = gs_moveto(ctx->pgs, 0, 0);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, 9, 0);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, 14, 5);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, 14, 18);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, 0, 18);
+ if (code < 0) goto exit;
+ code = gs_closepath(ctx->pgs);
+ if (code < 0) goto exit;
+
+ code = pdfi_gsave(ctx);
+ if (code >= 0) {
+ code = pdfi_gs_setgray(ctx, 0.5);
+ code = gs_fill(ctx->pgs);
+ code = pdfi_grestore(ctx);
+ } else
+ goto exit;
+
+ code = pdfi_gs_setgray(ctx, 0);
+ if (code < 0) goto exit;
+ code = gs_stroke(ctx->pgs);
+ if (code < 0) goto exit;
+
+ code = gs_moveto(ctx->pgs, 3, 8);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, 7.5, 8);
+ if (code < 0) goto exit;
+ code = gs_moveto(ctx->pgs, 3, 11);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, 10, 11);
+ if (code < 0) goto exit;
+ code = gs_moveto(ctx->pgs, 3, 14);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, 10, 14);
+ if (code < 0) goto exit;
+ code = gs_moveto(ctx->pgs, 9, 0);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, 9, 5);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, 14, 5);
+ if (code < 0) goto exit;
+ code = gs_stroke(ctx->pgs);
+ if (code < 0) goto exit;
+
+ exit:
+ code1 = pdfi_annot_end_transparency(ctx, annot);
+ if (code >= 0)
+ code = code1;
+ exit1:
+ *render_done = true;
+ return code;
+}
+
+/* Converts array of 4 points to a basis and 2 dimensions (6 values altogether)
+ * x0 y0 x1 y1 x2 y2 x3 y3 -> x0 y0 x1-x0 y1-y0 x2-x0 y2-y0
+ *
+ * ^
+ * |
+ * * (x2,y2) * (x3,y3)
+ * |
+ * |
+ * *------------*->
+ * (x0,y0) (x1,y1)
+ */
+static void pdfi_annot_quadpoints2basis(pdf_context *ctx, double *array,
+ double *px0, double *py0,
+ double *dx1, double *dy1,
+ double *dx2, double *dy2)
+{
+ double x0,x1,x2,x3,y0,y1,y2,y3;
+ double minx, miny;
+ int i, mindex;
+
+ /* comment from the PS code
+ % The text is oriented with respect to the vertex with the smallest
+ % y value (or the leftmost of those, if there are two such vertices)
+ % (x0, y0) and the next vertex in a counterclockwise direction
+ % (x1, y1), regardless of whether these are the first two points in
+ % the QuadPoints array.
+ */
+
+ /* starting min point */
+ minx = array[0];
+ miny = array[1];
+ mindex = 0;
+ /* This finds the index of the point with miny and if there were two points with same
+ * miny, it finds the one with minx
+ */
+ for (i=2; i<8; i+=2) {
+ if ((array[i+1] == miny && array[i] < minx) || (array[i+1] < miny)) {
+ /* Set new min point */
+ miny = array[i+1];
+ minx = array[i];
+ mindex = i;
+ }
+ }
+
+ /* Pull out the points such that x0 = minx, y0 = miny, etc */
+ i = mindex;
+ x0 = array[i];
+ y0 = array[i+1];
+ i += 2;
+ if (i == 8) i = 0;
+ x1 = array[i];
+ y1 = array[i+1];
+ i += 2;
+ if (i == 8) i = 0;
+ x2 = array[i];
+ y2 = array[i+1];
+ i += 2;
+ if (i == 8) i = 0;
+ x3 = array[i];
+ y3 = array[i+1];
+
+ /* Make it go counterclockwise by picking lower of these 2 points */
+ if (y3 < y1) {
+ y1 = y3;
+ x1 = x3;
+ }
+
+ /* Convert into a starting point and two sets of lengths */
+ *px0 = x0;
+ *py0 = y0;
+ *dx1 = x1 - x0;
+ *dy1 = y1 - y0;
+ *dx2 = x2 - x0;
+ *dy2 = y2 - y0;
+}
+
+/* Generate appearance for Underline or StrikeOut (see pdf_draw.ps/Underline and Strikeout)
+ *
+ * offset -- how far above the QuadPoints box bottom to draw the line
+ *
+ */
+static int pdfi_annot_draw_line_offset(pdf_context *ctx, pdf_dict *annot, double offset)
+{
+ int code = 0;
+ bool drawit;
+ pdf_array *QuadPoints = NULL;
+ double array[8];
+ int size;
+ int num_quads;
+ int i;
+ double x0, y0, dx1, dy1, dx2, dy2;
+ double linewidth;
+
+ code = pdfi_annot_setcolor(ctx, annot, false, &drawit);
+ if (code <0 || !drawit)
+ goto exit;
+
+ code = pdfi_dict_knownget_type(ctx, annot, "QuadPoints", PDF_ARRAY, (pdf_obj **)&QuadPoints);
+ if (code <= 0) goto exit;
+
+ size = pdfi_array_size(QuadPoints);
+ num_quads = size / 8;
+
+ for (i=0; i<num_quads; i++) {
+ code = pdfi_array_to_num_array(ctx, QuadPoints, array, i*8, 8);
+ if (code < 0) goto exit;
+
+ pdfi_annot_quadpoints2basis(ctx, array, &x0, &y0, &dx1, &dy1, &dx2, &dy2);
+
+ /* Acrobat draws the line at offset-ratio of the box width from the bottom of the box
+ * and 1/16 thick of the box width. /Rect is ignored.
+ */
+ linewidth = sqrt((dx2*dx2) + (dy2*dy2)) / 16.;
+ code = gs_setlinewidth(ctx->pgs, linewidth);
+ if (code < 0) goto exit;
+ code = gs_moveto(ctx->pgs, dx2*offset + x0 , dy2*offset + y0);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, dx2*offset + x0 + dx1, dy2*offset + y0 + dy1);
+ if (code < 0) goto exit;
+ code = gs_stroke(ctx->pgs);
+ if (code < 0) goto exit;
+ }
+
+ exit:
+ pdfi_countdown(QuadPoints);
+ return code;
+}
+
+/* Generate appearance (see pdf_draw.ps/StrikeOut)
+ *
+ * If there was an AP it was already handled.
+ */
+static int pdfi_annot_draw_StrikeOut(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ *render_done = true;
+ return pdfi_annot_draw_line_offset(ctx, annot, 3/7.);
+}
+
+/* Generate appearance (see pdf_draw.ps/Underline)
+ *
+ * If there was an AP it was already handled.
+ */
+static int pdfi_annot_draw_Underline(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ *render_done = true;
+ return pdfi_annot_draw_line_offset(ctx, annot, 1/7.);
+}
+
+/* Connect 2 points with an arc that has max distance from the line segment to the arc
+ * equal to 1/4 of the radius.
+ */
+static int pdfi_annot_highlight_arc(pdf_context *ctx, double x0, double y0,
+ double x1, double y1)
+{
+ int code = 0;
+ double dx, dy;
+ double xc, yc, r, a1, a2;
+
+ dx = x1 - x0;
+ dy = y1 - y0;
+
+ yc = (y1+y0)/2. - 15./16.*dx;
+ xc = (x1+x0)/2. + 15./16.*dy;
+ r = sqrt((y1-yc)*(y1-yc) + (x1-xc)*(x1-xc));
+ code = gs_atan2_degrees(y1-yc, x1-xc, &a1);
+ if (code < 0)
+ a1 = 0;
+ code = gs_atan2_degrees(y0-yc, x0-xc, &a2);
+ if (code < 0)
+ a2 = 0;
+ code = gs_arcn(ctx->pgs, xc, yc, r, a2, a1);
+
+ return code;
+}
+
+/* Generate appearance (see pdf_draw.ps/Highlight)
+ *
+ * If there was an AP it was already handled.
+ */
+static int pdfi_annot_draw_Highlight(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ int code = 0;
+ bool drawit;
+ pdf_array *QuadPoints = NULL;
+ double array[8];
+ int size;
+ int num_quads;
+ int i;
+
+ code = pdfi_annot_setcolor(ctx, annot, false, &drawit);
+ if (code <0 || !drawit)
+ goto exit;
+
+ code = gs_setlinecap(ctx->pgs, 1);
+ if (code < 0) goto exit;
+
+ code = pdfi_dict_knownget_type(ctx, annot, "QuadPoints", PDF_ARRAY, (pdf_obj **)&QuadPoints);
+ if (code <= 0) goto exit;
+
+ size = pdfi_array_size(QuadPoints);
+ num_quads = size / 8;
+
+ for (i=0; i<num_quads; i++) {
+ code = pdfi_array_to_num_array(ctx, QuadPoints, array, i*8, 8);
+ if (code < 0) goto exit;
+
+ code = gs_moveto(ctx->pgs, array[2], array[3]);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_highlight_arc(ctx, array[2], array[3], array[6], array[7]);
+ if (code < 0) goto exit;
+
+ code = gs_lineto(ctx->pgs, array[4], array[5]);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_highlight_arc(ctx, array[4], array[5], array[0], array[1]);
+ if (code < 0) goto exit;
+
+ code = gs_closepath(ctx->pgs);
+ if (code < 0) goto exit;
+
+ if (ctx->page.has_transparency) {
+ code = pdfi_trans_begin_simple_group(ctx, NULL, false, false, false);
+ if (code < 0) goto exit;
+
+ code = gs_setblendmode(ctx->pgs, BLEND_MODE_Multiply);
+ if (code < 0) {
+ (void)pdfi_trans_end_simple_group(ctx);
+ goto exit;
+ }
+ code = gs_fill(ctx->pgs);
+ (void)pdfi_trans_end_simple_group(ctx);
+ if (code < 0) goto exit;
+ } else {
+ code = gs_stroke(ctx->pgs);
+ if (code < 0) goto exit;
+
+ code = gs_newpath(ctx->pgs);
+ if (code < 0) goto exit;
+ }
+ }
+
+ exit:
+ pdfi_countdown(QuadPoints);
+ return code;
+}
+
+/* Generate appearance (see pdf_draw.ps/Squiggly)
+ *
+ * If there was an AP it was already handled.
+ */
+static int pdfi_annot_draw_Squiggly(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ int code = 0;
+ bool drawit;
+ pdf_array *QuadPoints = NULL;
+ double array[8];
+ int size;
+ int num_quads;
+ int i;
+ double x0, y0, dx1, dy1, dx2, dy2;
+ double p1, p2, p12;
+ int count;
+ bool need_grestore = false;
+ gs_matrix matrix;
+
+ code = pdfi_annot_setcolor(ctx, annot, false, &drawit);
+ if (code <0 || !drawit)
+ goto exit;
+
+ code = gs_setlinecap(ctx->pgs, gs_cap_round);
+ if (code < 0) goto exit;
+ code = gs_setlinejoin(ctx->pgs, gs_join_round);
+ if (code < 0) goto exit;
+ code = gs_setlinewidth(ctx->pgs, 1.0);
+ if (code < 0) goto exit;
+
+ code = pdfi_dict_knownget_type(ctx, annot, "QuadPoints", PDF_ARRAY, (pdf_obj **)&QuadPoints);
+ if (code <= 0) goto exit;
+
+ size = pdfi_array_size(QuadPoints);
+ num_quads = size / 8;
+
+ for (i=0; i<num_quads; i++) {
+ code = pdfi_array_to_num_array(ctx, QuadPoints, array, i*8, 8);
+ if (code < 0) goto exit;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) goto exit;
+ need_grestore = true;
+
+ /* Make clipping region */
+ code = gs_moveto(ctx->pgs, array[6], array[7]);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, array[4], array[5]);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, array[0], array[1]);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, array[2], array[3]);
+ if (code < 0) goto exit;
+ code = gs_closepath(ctx->pgs);
+ if (code < 0) goto exit;
+ code = gs_clip(ctx->pgs);
+ if (code < 0) goto exit;
+ code = gs_newpath(ctx->pgs);
+ if (code < 0) goto exit;
+
+ pdfi_annot_quadpoints2basis(ctx, array, &x0, &y0, &dx1, &dy1, &dx2, &dy2);
+
+ code = gs_translate(ctx->pgs, x0+dx2/56+dx2/72, y0+dy2/56+dy2/72);
+ if (code < 0) goto exit;
+
+ p2 = sqrt(dx2*dx2 + dy2*dy2);
+ p1 = sqrt(dx1*dx1 + dy1*dy1);
+
+ if (p2 > 0 && p1 > 0) {
+ p12 = p2 / p1;
+
+ count = (int)((1/p12) * 4 + 1);
+
+ matrix.xx = dx1 * p12;
+ matrix.xy = dy1 * p12;
+ matrix.yx = dx2;
+ matrix.yy = dy2;
+ matrix.tx = 0.0;
+ matrix.ty = 0.0;
+ code = gs_concat(ctx->pgs, &matrix);
+ if (code < 0) goto exit;
+
+ code = gs_scale(ctx->pgs, 1/40., 1/72.);
+ if (code < 0) goto exit;
+
+ code = gs_moveto(ctx->pgs, 0, 0);
+ if (code < 0) goto exit;
+
+ while (count >= 0) {
+ code = gs_lineto(ctx->pgs, 5, 10);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, 10, 0);
+ if (code < 0) goto exit;
+ code = gs_translate(ctx->pgs, 10, 0);
+ if (code < 0) goto exit;
+
+ count --;
+ }
+ code = gs_stroke(ctx->pgs);
+ if (code < 0) goto exit;
+ }
+
+ need_grestore = false;
+ code = pdfi_grestore(ctx);
+ if (code < 0) goto exit;
+ }
+
+ exit:
+ if (need_grestore)
+ (void)pdfi_grestore(ctx);
+ pdfi_countdown(QuadPoints);
+ *render_done = true;
+ return code;
+}
+
+/* Generate appearance (see pdf_draw.ps/Redact)
+ *
+ * If there was an AP it was already handled.
+ */
+static int pdfi_annot_draw_Redact(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ /* comment from PS code:
+ %% Redact annotations are part of a process, a Redact annotation is only present
+ %% until the content is removed, before that the content should be present and
+ %% I believe we should print it. So take no action for Redact annotations if they
+ %% have no appearance.
+ */
+ /* Render nothing, don't print warning */
+ *render_done = true;
+ return 0;
+}
+
+/* Handle PopUp (see pdf_draw.ps/Popup)
+ * Renders only if /Open=true
+ *
+ * If there's an AP, caller will handle it on return
+ */
+static int pdfi_annot_draw_Popup(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ int code = 0, code1 = 0;
+ bool Open = false;
+ pdf_dict *Parent = NULL;
+ pdf_string *Contents = NULL;
+ pdf_string *T = NULL;
+ bool has_color;
+ gs_rect rect, rect2;
+ bool need_grestore = false;
+ double x, y;
+
+ /* Render only if open */
+ code = pdfi_dict_get_bool(ctx, annot, "Open", &Open);
+ if (code < 0 && (code != gs_error_undefined))
+ goto exit1;
+
+ code = 0;
+
+ /* Don't render if not Open */
+ if (!Open) {
+ *render_done = true;
+ goto exit1;
+ }
+
+ /* Let caller render if there is an AP */
+ if (NormAP) {
+ *render_done = false;
+ goto exit1;
+ }
+
+ /* regardless what happens next, tell caller we rendered it */
+ *render_done = true;
+
+ code = pdfi_annot_start_transparency(ctx, annot);
+ if (code < 0) goto exit1;
+
+ code = gs_setlinewidth(ctx->pgs, 0.05);
+
+ /* Use Parent to get color */
+ code = pdfi_dict_knownget_type(ctx, annot, "Parent", PDF_DICT, (pdf_obj **)&Parent);
+ if (code < 0) goto exit;
+ if (code == 0) {
+ code = pdfi_dict_knownget_type(ctx, annot, "P", PDF_DICT, (pdf_obj **)&Parent);
+ if (code < 0) goto exit;
+ }
+ if (code == 0) {
+ /* If no parent, we will use the annotation itself */
+ Parent = annot;
+ pdfi_countup(Parent);
+ }
+
+ /* Set color if there is one specified */
+ code = pdfi_annot_setcolor(ctx, Parent, false, &has_color);
+ if (code < 0) goto exit;
+
+ /* Set a default color if nothing specified */
+ if (!has_color) {
+ code = pdfi_gs_setrgbcolor(ctx, 1.0, 1.0, 0);
+ if (code < 0) goto exit;
+ }
+
+ code = pdfi_annot_Rect(ctx, annot, &rect);
+ if (code < 0) goto exit;
+
+ /* Draw big box (the frame around the /Contents) */
+ code = pdfi_gsave(ctx);
+ if (code < 0) goto exit;
+ need_grestore = true;
+ code = pdfi_gs_setgray(ctx, 1);
+ if (code < 0) goto exit;
+ code = gs_rectfill(ctx->pgs, &rect, 1);
+ if (code < 0) goto exit;
+ code = pdfi_gs_setgray(ctx, 0);
+ if (code < 0) goto exit;
+ code = gs_rectstroke(ctx->pgs, &rect, 1, NULL);
+ if (code < 0) goto exit;
+ code = pdfi_grestore(ctx);
+ need_grestore = false;
+ if (code < 0) goto exit;
+
+ /* Display /Contents in Helvetica */
+ code = pdfi_dict_knownget_type(ctx, Parent, "Contents", PDF_STRING, (pdf_obj **)&Contents);
+ if (code < 0) goto exit;
+ if (code > 0) {
+ code = pdfi_gsave(ctx);
+ if (code < 0) goto exit;
+ need_grestore = true;
+ code = pdfi_gs_setgray(ctx, 0);
+ if (code < 0) goto exit;
+ x = rect.p.x + 5;
+ y = rect.q.y - 30;
+
+ code = pdfi_annot_set_font(ctx, "Helvetica", 9);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_display_simple_text(ctx, annot, x, y, Contents);
+ if (code < 0) goto exit;
+
+ code = pdfi_grestore(ctx);
+ need_grestore = false;
+ if (code < 0) goto exit;
+ }
+
+ /* Draw small, thin box (the frame around the top /T text) */
+ rect2.p.x = rect.p.x;
+ rect2.p.y = rect.q.y - 15;
+ rect2.q.x = rect.q.x;
+ rect2.q.y = rect.p.y + (rect.q.y - rect.p.y);
+
+ code = gs_rectfill(ctx->pgs, &rect2, 1);
+ if (code < 0) goto exit;
+ code = pdfi_gs_setgray(ctx, 0);
+ if (code < 0) goto exit;
+ code = gs_rectstroke(ctx->pgs, &rect2, 1, NULL);
+ if (code < 0) goto exit;
+
+ /* Display /T in Helvetica */
+ code = pdfi_dict_knownget_type(ctx, Parent, "T", PDF_STRING, (pdf_obj **)&T);
+ if (code < 0) goto exit;
+ if (code > 0) {
+ code = pdfi_annot_set_font(ctx, "Helvetica", 9);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_display_centered_text(ctx, annot, &rect, T);
+ if (code < 0) goto exit;
+
+ }
+
+ exit:
+ if (need_grestore) {
+ code1= pdfi_grestore(ctx);
+ if (code == 0) code = code1;
+ }
+ code1 = pdfi_annot_end_transparency(ctx, annot);
+ if (code == 0) code = code1;
+ exit1:
+ pdfi_countdown(Parent);
+ pdfi_countdown(Contents);
+ pdfi_countdown(T);
+ return code;
+}
+
+/* Generate appearance (see pdf_draw.ps/Line)
+ *
+ * If there was an AP it was already handled.
+ */
+static int pdfi_annot_draw_Line(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ int code = 0;
+ int code1 = 0;
+ gs_rect lrect;
+ pdf_array *L = NULL;
+ bool drawit;
+
+ code = pdfi_annot_start_transparency(ctx, annot);
+ if (code < 0) goto exit1;
+
+ code = pdfi_dict_knownget_type(ctx, annot, "L", PDF_ARRAY, (pdf_obj **)&L);
+ if (code < 0) goto exit;
+
+ code = pdfi_array_to_gs_rect(ctx, L, &lrect);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_setcolor(ctx, annot, false, &drawit);
+ if (code < 0) goto exit;
+
+ /* Handle LE */
+ code = pdfi_annot_draw_LE(ctx, annot, lrect.p.x, lrect.p.y, lrect.q.x, lrect.q.y, 0);
+ if (code < 0) goto exit;
+
+ /* Draw the actual line */
+ code = gs_moveto(ctx->pgs, lrect.p.x, lrect.p.y);
+ if (code < 0) goto exit;
+ code = gs_lineto(ctx->pgs, lrect.q.x, lrect.q.y);
+ if (code < 0) goto exit;
+ code = pdfi_annot_draw_border(ctx, annot, true);
+ if (code < 0) goto exit;
+
+ exit:
+ code1 = pdfi_annot_end_transparency(ctx, annot);
+ if (code >= 0)
+ code = code1;
+ exit1:
+ *render_done = true;
+ pdfi_countdown(L);
+ return code;
+}
+
+/* Create a path from an array of points */
+static int pdfi_annot_path_array(pdf_context *ctx, pdf_dict *annot, pdf_array *Vertices)
+{
+ int code = 0;
+ int i;
+
+ for (i=0; i<pdfi_array_size(Vertices); i+=2) {
+ double x,y;
+
+ code = pdfi_array_get_number(ctx, Vertices, i, &x);
+ if (code < 0) goto exit;
+ code = pdfi_array_get_number(ctx, Vertices, i+1, &y);
+ if (code < 0) goto exit;
+
+ if (i == 0) {
+ code = gs_moveto(ctx->pgs, x, y);
+ if (code < 0) goto exit;
+ } else {
+ code = gs_lineto(ctx->pgs, x, y);
+ if (code < 0) goto exit;
+ }
+ }
+
+ exit:
+ return code;
+}
+
+/* Generate appearance (see pdf_draw.ps/PolyLine)
+ * NOTE: as of 5-7-20, the gs implementation of this is actually broken
+ *
+ * If there was an AP it was already handled.
+ */
+static int pdfi_annot_draw_PolyLine(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ int code = 0;
+ int code1 = 0;
+ pdf_array *Vertices = NULL;
+ bool drawit;
+ int size;
+ double x1, y1, x2, y2;
+
+ code = pdfi_annot_start_transparency(ctx, annot);
+ if (code < 0) goto exit1;
+
+ code = pdfi_dict_knownget_type(ctx, annot, "Vertices", PDF_ARRAY, (pdf_obj **)&Vertices);
+ if (code < 0) goto exit;
+
+ size = pdfi_array_size(Vertices);
+ if (size == 0) {
+ code = 0;
+ goto exit;
+ }
+ code = pdfi_annot_path_array(ctx, annot, Vertices);
+ if (code < 0) goto exit1;
+
+ code = pdfi_annot_setcolor(ctx, annot, false, &drawit);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_draw_border(ctx, annot, true);
+ if (code < 0) goto exit;
+
+ if (size >= 4) {
+ code = pdfi_array_get_number(ctx, Vertices, 0, &x1);
+ if (code < 0) goto exit;
+ code = pdfi_array_get_number(ctx, Vertices, 1, &y1);
+ if (code < 0) goto exit;
+ code = pdfi_array_get_number(ctx, Vertices, 2, &x2);
+ if (code < 0) goto exit;
+ code = pdfi_array_get_number(ctx, Vertices, 3, &y2);
+ if (code < 0) goto exit;
+ code = pdfi_annot_draw_LE(ctx, annot, x1, y1, x2, y2, 1);
+ if (code < 0) goto exit;
+
+ code = pdfi_array_get_number(ctx, Vertices, size-4, &x1);
+ if (code < 0) goto exit;
+ code = pdfi_array_get_number(ctx, Vertices, size-3, &y1);
+ if (code < 0) goto exit;
+ code = pdfi_array_get_number(ctx, Vertices, size-2, &x2);
+ if (code < 0) goto exit;
+ code = pdfi_array_get_number(ctx, Vertices, size-1, &y2);
+ if (code < 0) goto exit;
+ code = pdfi_annot_draw_LE(ctx, annot, x1, y1, x2, y2, 2);
+ if (code < 0) goto exit;
+ }
+
+ exit:
+ code1 = pdfi_annot_end_transparency(ctx, annot);
+ if (code >= 0)
+ code = code1;
+
+ exit1:
+ *render_done = true;
+ pdfi_countdown(Vertices);
+ return code;
+}
+
+/* Generate appearance (see pdf_draw.ps/Polygon)
+ *
+ * If there was an AP it was already handled.
+ */
+static int pdfi_annot_draw_Polygon(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ int code = 0;
+ int code1 = 0;
+ pdf_array *Vertices = NULL;
+ bool drawit;
+
+ code = pdfi_annot_start_transparency(ctx, annot);
+ if (code < 0) goto exit1;
+
+ code = pdfi_dict_knownget_type(ctx, annot, "Vertices", PDF_ARRAY, (pdf_obj **)&Vertices);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_path_array(ctx, annot, Vertices);
+ if (code < 0) goto exit1;
+
+ code = gs_closepath(ctx->pgs);
+
+ /* NOTE: The logic here seems a bit wonky. Why only set opacity if there was a fill?
+ * Anyway, it is based on the ps code (pdf_draw.ps/Polygon).
+ * Maybe can be improved.
+ */
+ code = pdfi_annot_setinteriorcolor(ctx, annot, false, &drawit);
+ if (code < 0) goto exit;
+ if (drawit) {
+ code = pdfi_annot_fillborderpath(ctx, annot);
+ if (code < 0) goto exit;
+ code = pdfi_annot_opacity(ctx, annot); /* TODO: Why only on this path? */
+ if (code < 0) goto exit;
+ }
+ code = pdfi_annot_setcolor(ctx, annot, false, &drawit);
+ if (code < 0) goto exit;
+ if (drawit) {
+ code = pdfi_annot_draw_border(ctx, annot, true);
+ if (code < 0) goto exit;
+ }
+
+ exit:
+ code1 = pdfi_annot_end_transparency(ctx, annot);
+ if (code >= 0)
+ code = code1;
+ exit1:
+ *render_done = true;
+ pdfi_countdown(Vertices);
+ return code;
+}
+
+/* Generate appearance (see pdf_draw.ps/Square)
+ *
+ * If there was an AP it was already handled.
+ */
+static int pdfi_annot_draw_Square(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ int code = 0;
+ int code1 = 0;
+ bool drawit;
+
+ code = pdfi_annot_start_transparency(ctx, annot);
+ if (code < 0) goto exit1;
+
+ code = pdfi_annot_setinteriorcolor(ctx, annot, false, &drawit);
+ if (code < 0) goto exit;
+ if (drawit) {
+ code = pdfi_annot_opacity(ctx, annot);
+ if (code < 0) goto exit;
+ code = pdfi_annot_fillRect(ctx, annot);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_setcolor(ctx, annot, false, &drawit);
+ if (code < 0) goto exit;
+
+ if (drawit) {
+ code = pdfi_annot_draw_border(ctx, annot, false);
+ if (code < 0) goto exit;
+ }
+ } else {
+ code = pdfi_annot_RectRD_path(ctx, annot);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_setcolor(ctx, annot, false, &drawit);
+ if (code < 0) goto exit;
+
+ if (drawit) {
+ code = pdfi_annot_draw_border(ctx, annot, true);
+ if (code < 0) goto exit;
+ }
+ }
+
+ exit:
+ code1 = pdfi_annot_end_transparency(ctx, annot);
+ if (code >= 0)
+ code = code1;
+ exit1:
+ *render_done = true;
+ return code;
+}
+
+static int pdfi_annot_render_MK_box(pdf_context *ctx, pdf_dict *annot, pdf_dict *MK)
+{
+ int code = 0;
+ bool drawit = false;
+ gs_rect rect;
+ bool need_grestore = false;
+
+ /* Basically just render the rectangle around the widget for now */
+ code = pdfi_annot_Rect(ctx, annot, &rect);
+ if (code < 0) goto exit;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) goto exit;
+ need_grestore = true;
+ code = pdfi_annot_setcolor_key(ctx, MK, "BG", false, &drawit);
+ if (code < 0) goto exit;
+ if (drawit)
+ code = gs_rectfill(ctx->pgs, &rect, 1);
+ if (code < 0) goto exit;
+ need_grestore = false;
+ code = pdfi_grestore(ctx);
+ if (code < 0) goto exit;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) goto exit;
+ need_grestore = true;
+ code = pdfi_annot_setcolor_key(ctx, MK, "BC", false, &drawit);
+ if (code < 0) goto exit;
+ if (drawit)
+ code = gs_rectstroke(ctx->pgs, &rect, 1, NULL);
+ if (code < 0) goto exit;
+ need_grestore = false;
+ code = pdfi_grestore(ctx);
+ if (code < 0) goto exit;
+
+ /* TODO: Stuff with can-regenerate-ap ?? */
+
+ exit:
+ if (need_grestore)
+ (void)pdfi_grestore(ctx);
+ return code;
+}
+
+typedef enum {
+ PDFI_FORM_FF_READONLY = 1, /* Bit 1 */
+ PDFI_FORM_FF_REQUIRED = 1 << 1, /* Bit 2 */
+ PDFI_FORM_FF_NOEXPORT = 1 << 2, /* Bit 3 */
+ PDFI_FORM_FF_MULTILINE = 1 << 12, /* Bit 13 */
+ PDFI_FORM_FF_PASSWORD = 1 << 13, /* Bit 14 */
+ PDFI_FORM_FF_NOTOGGLETOOFF = 1 << 14, /* Bit 15 */
+ PDFI_FORM_FF_RADIO = 1 << 15, /* Bit 16 */
+ PDFI_FORM_FF_PUSHBUTTON = 1 << 16, /* Bit 17 */
+ PDFI_FORM_FF_COMBO = 1 << 17, /* Bit 18 */
+ PDFI_FORM_FF_EDIT = 1 << 18, /* Bit 19 */
+ PDFI_FORM_FF_SORT = 1 << 19, /* Bit 20 */
+ PDFI_FORM_FF_FILESELECT = 1 << 20, /* Bit 21 */
+ PDFI_FORM_FF_MULTISELECT = 1 << 21, /* Bit 22 */
+ PDFI_FORM_FF_DONOTSPELLCHECK = 1 << 22, /* Bit 23 */
+ PDFI_FORM_FF_DONOTSCROLL = 1 << 23, /* Bit 24 */
+ PDFI_FORM_FF_COMB = 1 << 24, /* Bit 25 */
+ PDFI_FORM_FF_RICHTEXT = 1 << 25, /* Bit 26 */ /* also PDFI_FORM_FF_RADIOSINUNISON */
+ PDFI_FORM_FF_COMMITONSELCHANGE = 1 << 26, /* Bit 27 */
+} pdfi_form_Ff;
+
+/* draw field Btn */
+static int pdfi_form_draw_Btn(pdf_context *ctx, pdf_dict *field, pdf_obj *AP)
+{
+ int code;
+ bool Radio = false;
+ bool Pushbutton = false;
+ int64_t value;
+
+ /* TODO: There can be Kids array. I think it should be handled in caller.
+ * Need an example...
+ */
+ if (AP != NULL) {
+ code = pdfi_annot_draw_AP(ctx, field, AP);
+ goto exit;
+ }
+
+ /* Get Ff field (default is 0) */
+ code = pdfi_form_get_inheritable_int(ctx, field, "Ff", &value);
+ if (code < 0) goto exit;
+
+ Radio = value & PDFI_FORM_FF_RADIO;
+ Pushbutton = value & PDFI_FORM_FF_PUSHBUTTON;
+
+ dmprintf(ctx->memory, "WARNING: AcroForm field 'Btn' with no AP not implemented.\n");
+ dmprintf2(ctx->memory, " : Radio = %s, Pushbutton = %s.\n",
+ Radio ? "TRUE" : "FALSE", Pushbutton ? "TRUE" : "FALSE");
+ exit:
+ return 0;
+}
+
+/* Modify V from Tx widget to skip past the BOM and indicate if UTF-16 was found */
+static int pdfi_form_modV(pdf_context *ctx, pdf_string *V, pdf_string **mod_V, bool *is_UTF16)
+{
+ bool did_mod = false;
+ int code = 0;
+ int skip = 0;
+ pdf_string *newV = NULL;
+
+ *is_UTF16 = false;
+
+ if (IS_UTF8(V->data)) {
+ skip = 3;
+ } else if (IS_UTF16(V->data)) {
+ skip = 2;
+ *is_UTF16 = true;
+ }
+
+ if (skip == 0)
+ goto exit;
+
+ /* Create a new V that skips over the BOM */
+ code = pdfi_object_alloc(ctx, PDF_STRING, V->length-skip, (pdf_obj **)&newV);
+ if (code < 0)
+ goto exit;
+ pdfi_countup(newV);
+
+ memcpy(newV->data, V->data+skip, newV->length);
+ did_mod = true;
+
+ exit:
+ /* If didn't need to mod it, just copy the original and get a ref */
+ if (did_mod) {
+ *mod_V = newV;
+ } else {
+ *mod_V = V;
+ pdfi_countup(V);
+ }
+ return code;
+}
+
+/* Display simple text (no multiline or comb) */
+static int pdfi_form_Tx_simple(pdf_context *ctx, pdf_dict *annot, gs_rect *rect, pdf_string *V,
+ int64_t Ff, int64_t Q, bool is_UTF16)
+{
+ int code = 0;
+ gs_rect modrect;
+ double lineheight = 0;
+ gs_rect bbox;
+ gs_point awidth;
+ double y_adjust = 0.0f, x_adjust = 0.0f;
+
+ modrect = *rect; /* structure copy */
+
+ code = pdfi_annot_get_text_height(ctx, &lineheight);
+ if (code < 0) goto exit;
+
+ /* text placement adjustments */
+ switch (Q) {
+ case 0: /* Left-justified */
+ x_adjust = 2; /* empirical value */
+ break;
+ case 1: /* Centered */
+ /* Get width of the string */
+ code = pdfi_string_bbox(ctx, V, &bbox, &awidth, false);
+ if (code < 0) goto exit;
+ x_adjust = ((rect->q.x - rect->p.x) - awidth.x) / 2;
+ break;
+ case 2: /* Right-justified */
+ /* Get width of the string */
+ code = pdfi_string_bbox(ctx, V, &bbox, &awidth, false);
+ if (code < 0) goto exit;
+ x_adjust = rect->q.x - awidth.x;
+ break;
+ }
+
+ /* Center vertically */
+ y_adjust = ((rect->q.y - rect->p.y) - lineheight) / 2;
+
+ modrect.p.x += x_adjust;
+ modrect.p.y += y_adjust;
+ modrect.p.y += (lineheight + 6.) / 10.; /* empirical */
+
+ code = pdfi_annot_display_simple_text(ctx, annot, modrect.p.x, modrect.p.y, V);
+ if (code < 0) goto exit;
+ exit:
+ return code;
+}
+
+/* Display text from Tx MULTILINE */
+static int pdfi_form_Tx_multiline(pdf_context *ctx, pdf_dict *annot, gs_rect *rect, pdf_string *V,
+ int64_t Ff, int64_t Q, bool is_UTF16)
+{
+ int code = 0;
+ gs_rect modrect;
+
+ modrect = *rect; /* structure copy */
+ /* empirical tweaks */
+ modrect.p.x += 2;
+ modrect.p.y += 2;
+ modrect.q.x -= 2;
+ modrect.q.y -= 2;
+
+ code = pdfi_annot_display_formatted_text(ctx, annot, &modrect, V, is_UTF16);
+ if (code < 0) goto exit;
+
+ exit:
+ return code;
+}
+
+
+/* Display text from Tx COMB */
+static int pdfi_form_Tx_comb(pdf_context *ctx, pdf_dict *annot, gs_rect *rect, pdf_string *V,
+ int64_t Ff, int64_t Q, int64_t MaxLen, bool is_UTF16)
+{
+ int code = 0;
+
+ /* TODO: Implement... Need a sample that uses COMB! */
+ code = pdfi_form_Tx_simple(ctx, annot, rect, V, Ff, Q, is_UTF16);
+ return code;
+}
+
+
+/* Display text from Tx in a field or widget */
+static int pdfi_form_display_Tx(pdf_context *ctx, pdf_dict *annot, gs_rect *rect, pdf_string *V,
+ int64_t Ff, int64_t Q, int64_t MaxLen)
+{
+ int code = 0;
+ pdf_string *modV = NULL;
+ bool is_UTF16;
+
+ /* TODO: If we wanted to preserve this for pdfwrite, we would have to generate
+ * a stream for the AP. See PDF1.7 spec, Variable Text (page 677).
+ */
+
+ /* Get modified V that skips the BOM, if any */
+ code = pdfi_form_modV(ctx, V, &modV, &is_UTF16);
+ if (code < 0) goto exit;
+
+ if (Ff & PDFI_FORM_FF_MULTILINE) {
+ code = pdfi_form_Tx_multiline(ctx, annot, rect, modV, Ff, Q, is_UTF16);
+ } else if (Ff & PDFI_FORM_FF_COMB) {
+ code = pdfi_form_Tx_comb(ctx, annot, rect, modV, Ff, Q, MaxLen, is_UTF16);
+ } else {
+ code = pdfi_form_Tx_simple(ctx, annot, rect, modV, Ff, Q, is_UTF16);
+ }
+
+ exit:
+ pdfi_countdown(modV);
+ return code;
+}
+
+
+/* At least for now, Tx and Ch are handled the same */
+static int pdfi_form_draw_Tx_Ch(pdf_context *ctx, pdf_dict *annot)
+{
+ int code = 0;
+ pdf_string *V = NULL;
+ gs_rect annotrect;
+ int64_t Ff;
+ int64_t MaxLen;
+ int64_t Q;
+
+ code = pdfi_annot_Rect(ctx, annot, &annotrect);
+ if (code < 0) goto exit;
+
+ /* Set DA (Default Appearance)
+ * This will generally set a color and font.
+ */
+ code = pdfi_annot_process_DA(ctx, annot, annot, &annotrect, true);
+ if (code < 0) goto exit;
+
+ code = pdfi_form_get_inheritable_int(ctx, annot, "Ff", &Ff);
+ if (code < 0) goto exit;
+
+ code = pdfi_form_get_inheritable_int(ctx, annot, "MaxLen", &MaxLen);
+ if (code < 0) goto exit;
+
+ code = pdfi_form_get_inheritable_int(ctx, annot, "Q", &Q);
+ if (code < 0) goto exit;
+
+ code = pdfi_dict_knownget_type(ctx, annot, "V", PDF_STRING, (pdf_obj **)&V);
+ if (code < 0) goto exit;
+ if (code > 0) {
+ code = pdfi_form_display_Tx(ctx, annot, &annotrect, V, Ff, Q, MaxLen);
+ if (code < 0) goto exit;
+ }
+
+ exit:
+ pdfi_countdown(V);
+ return code;
+}
+
+/* draw field Tx */
+static int pdfi_form_draw_Tx(pdf_context *ctx, pdf_dict *annot, pdf_obj *AP)
+{
+ if (AP != NULL)
+ return pdfi_annot_draw_AP(ctx, annot, AP);
+
+ return pdfi_form_draw_Tx_Ch(ctx, annot);
+}
+
+/* draw field Ch */
+static int pdfi_form_draw_Ch(pdf_context *ctx, pdf_dict *field, pdf_obj *AP)
+{
+ if (!ctx->NeedAppearances && AP != NULL)
+ return pdfi_annot_draw_AP(ctx, field, AP);
+
+ return pdfi_form_draw_Tx_Ch(ctx, field);
+}
+
+/* draw field Sig */
+static int pdfi_form_draw_Sig(pdf_context *ctx, pdf_dict *field, pdf_obj *AP)
+{
+ int code = 0;
+
+ if (!ctx->NeedAppearances && AP != NULL)
+ return pdfi_annot_draw_AP(ctx, field, AP);
+
+ dmprintf(ctx->memory, "WARNING: AcroForm field 'Sig' with no AP not implemented.\n");
+
+ return code;
+}
+
+/* TODO: The spec handles "regenerate appearance", which it does by generating
+ * a new AP stream for the field, and then rendering it as a form.
+ * The gs code does try to handle this case.
+ * For now I am just going to generate the data inline, without building it as a Form/Stream.
+ * If we have want to preserve the AP (i.e. for pdfwrite device, generate the AP and include
+ * it in the output, rather than just rendering it into the output) then this needs to change.
+ * Currently gs doesn't try to preserve AcroForms, so we aren't losing any functionality by
+ * not doing this. But it is a place for a future enhancement.
+ *
+ * See also, the comment on pdfi_annot_preserve_Widget().
+ */
+static int pdfi_annot_render_field(pdf_context *ctx, pdf_dict *field, pdf_name *FT, pdf_obj *AP)
+{
+ int code;
+
+ if (pdfi_name_is(FT, "Btn")) {
+ code = pdfi_form_draw_Btn(ctx, field, AP);
+ } else if (pdfi_name_is(FT, "Tx")) {
+ code = pdfi_form_draw_Tx(ctx, field, AP);
+ } else if (pdfi_name_is(FT, "Ch")) {
+ code = pdfi_form_draw_Ch(ctx, field, AP);
+ } else if (pdfi_name_is(FT, "Sig")) {
+ code = pdfi_form_draw_Sig(ctx, field, AP);
+ } else {
+ dmprintf(ctx->memory, "*** WARNING unknown field FT ignored\n");
+ /* TODO: Handle warning better */
+ code = 0;
+ }
+
+ return code;
+}
+
+/* Render Widget with no AP
+ */
+static int pdfi_annot_render_Widget(pdf_context *ctx, pdf_dict *annot)
+{
+ int code = 0;
+ pdf_dict *MK = NULL;
+ pdf_name *FT = NULL;
+
+ /* Render box around the widget using MK */
+ code = pdfi_dict_knownget_type(ctx, annot, "MK", PDF_DICT, (pdf_obj **)&MK);
+ if (code < 0) goto exit;
+ if (code > 0) {
+ code = pdfi_annot_render_MK_box(ctx, annot, MK);
+ if (code < 0) goto exit;
+ }
+
+ /* Render the other contents */
+ code = pdfi_dict_knownget_type(ctx, annot, "FT", PDF_NAME, (pdf_obj **)&FT);
+ if (code < 0) goto exit;
+ if (code > 0) {
+ code = pdfi_annot_render_field(ctx, annot, FT, NULL);
+ if (code < 0) goto exit;
+ }
+
+ exit:
+ pdfi_countdown(FT);
+ pdfi_countdown(MK);
+ return code;
+}
+
+/* Draws a thing of type /Widget */
+static int pdfi_annot_draw_Widget(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ int code = 0;
+ bool found_T = false;
+ bool found_TF = false;
+ pdf_obj *T = NULL;
+ pdf_obj *TF = NULL;
+ pdf_dict *Parent = NULL;
+ pdf_dict *currdict = NULL;
+
+ /* From pdf_draw.ps/drawwidget:
+ % Acrobat doesn't draw Widget annotations unles they have both /FT
+ % (which is defined as required) and /T keys present. Annoyingly
+ % these can either be inherited from the Form Definition Field
+ % dictionary (via the AcroForm tree) or present directly in the
+ % annotation, so we need to check the annotation to make sure its
+ % a Widget, then follow any /Parent key up to the root node
+ % extracting and storing any FT or T keys as we go (we only care if
+ % these are present, their value is immaterial). If after all that
+ % both keys are not present, then we don't draw the annotation.
+ */
+
+ /* TODO: See top part of pdf_draw.ps/drawwidget
+ * check for /FT and /T and stuff
+ */
+ currdict = annot;
+ pdfi_countup(currdict);
+ while (true) {
+ code = pdfi_dict_knownget(ctx, currdict, "T", &T);
+ if (code < 0) goto exit;
+ if (code > 0) {
+ found_T = true;
+ break;
+ }
+ code = pdfi_dict_knownget(ctx, currdict, "TF", &TF);
+ if (code < 0) goto exit;
+ if (code > 0) {
+ found_TF = true;
+ break;
+ }
+ /* Check for Parent */
+ code = pdfi_dict_knownget_type(ctx, currdict, "Parent", PDF_DICT, (pdf_obj **)&Parent);
+ if (code < 0) goto exit;
+ if (code == 0)
+ break;
+ pdfi_countdown(currdict);
+ currdict = Parent;
+ pdfi_countup(currdict);
+ }
+
+ code = 0;
+ if (!found_T && !found_TF) {
+ *render_done = true;
+ dmprintf(ctx->memory, "**** Warning: A Widget annotation dictionary lacks either the FT or T key.\n");
+ dmprintf(ctx->memory, " Acrobat ignores such annoataions, annotation will not be rendered.\n");
+ dmprintf(ctx->memory, " Output may not be as expected.\n");
+ goto exit;
+ }
+
+ if (NormAP) {
+ /* Let caller render it */
+ *render_done = false;
+ goto exit;
+ }
+
+ /* No AP, try to render the Widget ourselves */
+ code = pdfi_annot_render_Widget(ctx, annot);
+ *render_done = true;
+
+ exit:
+ pdfi_countdown(T);
+ pdfi_countdown(TF);
+ pdfi_countdown(Parent);
+ pdfi_countdown(currdict);
+ return code;
+}
+
+/* Handle Annotations that are not implemented */
+static int pdfi_annot_draw_NotImplemented(pdf_context *ctx, pdf_dict *annot, pdf_obj *NormAP, bool *render_done)
+{
+ int code = 0;
+ pdf_name *Subtype = NULL;
+ char str[100];
+
+ code = pdfi_dict_get_type(ctx, annot, "Subtype", PDF_NAME, (pdf_obj **)&Subtype);
+ if (code < 0) goto exit;
+
+ memcpy(str, (const char *)Subtype->data, Subtype->length);
+ str[Subtype->length] = '\0';
+ dbgmprintf1(ctx->memory, "ANNOT: No AP, default appearance for Subtype %s Not Implemented\n", str);
+
+ exit:
+ *render_done = false;
+ pdfi_countdown(Subtype);
+ return code;
+}
+
+annot_dispatch_t annot_dispatch[] = {
+ /* These are in the same order as the PDF 2.0 spec 12.5.6.1 */
+ {"Text", pdfi_annot_draw_Text, true},
+ {"Link", pdfi_annot_draw_Link, false},
+ {"FreeText", pdfi_annot_draw_FreeText, true},
+ {"Line", pdfi_annot_draw_Line, true},
+ {"Square", pdfi_annot_draw_Square, true},
+ {"Circle", pdfi_annot_draw_Circle, true},
+ {"Polygon", pdfi_annot_draw_Polygon, true},
+ {"PolyLine", pdfi_annot_draw_PolyLine, true},
+ {"Highlight", pdfi_annot_draw_Highlight, true},
+ {"Underline", pdfi_annot_draw_Underline, true},
+ {"Squiggly", pdfi_annot_draw_Squiggly, true},
+ {"StrikeOut", pdfi_annot_draw_StrikeOut, true},
+ {"Caret", pdfi_annot_draw_NotImplemented, true},
+ {"Stamp", pdfi_annot_draw_Stamp, true},
+ {"Ink", pdfi_annot_draw_Ink, true},
+ {"Popup", pdfi_annot_draw_Popup, false},
+ {"FileAttachment", pdfi_annot_draw_NotImplemented, true},
+ {"Sound", pdfi_annot_draw_NotImplemented, true},
+ {"Movie", pdfi_annot_draw_NotImplemented, true},
+ {"Screen", pdfi_annot_draw_NotImplemented, true},
+ {"Widget", pdfi_annot_draw_Widget, false},
+ {"PrinterMark", pdfi_annot_draw_NotImplemented, true},
+ {"TrapNet", pdfi_annot_draw_NotImplemented, true},
+ {"Watermark", pdfi_annot_draw_NotImplemented, true},
+ {"3D", pdfi_annot_draw_NotImplemented, true},
+ {"Redact", pdfi_annot_draw_Redact, true},
+ {"Projection", pdfi_annot_draw_NotImplemented, true},
+ {"RichMedia", pdfi_annot_draw_NotImplemented, true},
+ { NULL, NULL},
+};
+
+/* Check if annotation is visible
+ * (from ps code:)
+%
+% The PDF annotation F (flags) integer is bit encoded.
+% Bit 1 (LSB) Invisible: 1 --> Do not display if no handler.
+% Note: We have no handlers but we ignore this bit.
+% Bit 2 Hidden: 1 --> Do not display. We will not display if this bit is set.
+% Bit 3 Print: 1 --> Display if printing. We will display if this bit set
+% (and not hidden) and Printed is true
+% Bit 4 NoZoom: 1 --> Do not zoom annotation even if image is zoomed.
+% Bit 5 NoRotate: 1 --> Do not rotate annotation even if image is rotated.
+% Bit 6 NoView: 0 --> Display if this is a 'viewer'. We will display
+% if this bit is not set (and not hidden) and Printed is false
+% Bit 7 Read Only - 1 --> No interaction. We ignore this bit
+%
+% AR8 and AR9 print 3D annotations even if Print flag is off. Bug 691486.
+%
+*/
+static bool pdfi_annot_visible(pdf_context *ctx, pdf_dict *annot, pdf_name *subtype)
+{
+ int code;
+ bool is_3D = false;
+ bool is_visible = true;
+ int64_t F;
+
+ if (pdfi_name_is(subtype, "3D"))
+ is_3D = true;
+
+ code = pdfi_dict_get_int(ctx, annot, "F", &F);
+ if (code < 0)
+ F = 0;
+
+ if ((F & 0x2) != 0) { /* Bit 2 -- Hidden */
+ is_visible = false; /* Hidden */
+ goto exit;
+ }
+
+ if (ctx->args.printed) {
+ /* Even if Print flag (bit 3) is off, will print if 3D */
+ is_visible = ((F & 0x4) != 0) || is_3D;
+ } else {
+ /* Not NoView (bit 7) */
+ is_visible = (F & 0x80) == 0;
+ }
+
+ exit:
+ return is_visible;
+}
+
+/* Check to see if subtype is on the ShowAnnotTypes list
+ * Defaults to true if there is no list
+ */
+static bool pdfi_annot_check_type(pdf_context *ctx, pdf_name *subtype)
+{
+ char **ptr;
+
+ /* True if no list */
+ if (!ctx->args.showannottypes)
+ return true;
+
+ /* Null terminated list, return true if subtype is on the list */
+ ptr = ctx->args.showannottypes;
+ while (*ptr) {
+ char *str = *ptr;
+ if (pdfi_name_is(subtype, str))
+ return true;
+ ptr ++;
+ }
+ /* List exists, but subtype is not on it */
+ return false;
+}
+
+/* Check to see if subtype is on the PreserveAnnotTypes list
+ * Defaults to true if there is no list
+ */
+static bool pdfi_annot_preserve_type(pdf_context *ctx, pdf_name *subtype)
+{
+ char **ptr;
+
+ /* True if no list */
+ if (!ctx->args.preserveannottypes)
+ return true;
+
+ /* Null terminated list, return true if subtype is on the list */
+ ptr = ctx->args.preserveannottypes;
+ while (*ptr) {
+ char *str = *ptr;
+ if (pdfi_name_is(subtype, str))
+ return true;
+ ptr ++;
+ }
+ /* List exists, but subtype is not on it */
+ return false;
+}
+
+static int pdfi_annot_draw(pdf_context *ctx, pdf_dict *annot, pdf_name *subtype)
+{
+ pdf_obj *NormAP = NULL;
+ int code = 0;
+ annot_dispatch_t *dispatch_ptr;
+ bool render_done = true;
+
+ /* See if annotation is visible */
+ if (!pdfi_annot_visible(ctx, annot, subtype))
+ goto exit;
+
+ /* See if we are rendering this type of annotation */
+ if (!pdfi_annot_check_type(ctx, subtype))
+ goto exit;
+
+ /* Get the Normal AP, if it exists */
+ code = pdfi_annot_get_NormAP(ctx, annot, &NormAP);
+ if (code < 0) goto exit;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) goto exit;
+
+ /* Draw the annotation */
+ for (dispatch_ptr = annot_dispatch; dispatch_ptr->subtype; dispatch_ptr ++) {
+ if (pdfi_name_is(subtype, dispatch_ptr->subtype)) {
+ if (NormAP && dispatch_ptr->simpleAP)
+ render_done = false;
+ else
+ code = dispatch_ptr->func(ctx, annot, NormAP, &render_done);
+ break;
+ }
+ }
+ if (!dispatch_ptr->subtype) {
+ char str[100];
+ memcpy(str, (const char *)subtype->data, subtype->length);
+ str[subtype->length] = '\0';
+ dbgmprintf1(ctx->memory, "ANNOT: No handler for subtype %s\n", str);
+
+ /* Not necessarily an error? We can just render the AP if there is one */
+ render_done = false;
+ }
+
+ if (!render_done)
+ code = pdfi_annot_draw_AP(ctx, annot, NormAP);
+
+ (void)pdfi_grestore(ctx);
+
+ exit:
+ pdfi_countdown(NormAP);
+ return code;
+}
+
+/* Create a string containing form label
+ * I don't think the format actually matters, though it probably needs to be unique
+ * Just use a counter to ensure uniqueness
+ *
+ * Format: {FormName%d}
+ */
+static int pdfi_annot_preserve_nextformlabel(pdf_context *ctx, byte **data, int *len)
+{
+ int size = 40;
+ char *buf;
+ gs_id counter = gs_next_ids(ctx->memory, 1);
+
+ buf = (char *)gs_alloc_bytes(ctx->memory, size, "pdfi_annot_preserve_nextformlabel(buf)");
+ if (buf == NULL)
+ return_error(gs_error_VMerror);
+ snprintf(buf, size, "{FN%ld}", counter);
+ *len = strlen(buf);
+ *data = (byte *)buf;
+ return 0;
+}
+
+/* Modify the QuadPoints array to correct for some BS in the pdfwrite driver.
+ * comment from gs code (pdf_draw.ps/ApplyCMTToQuadPoints()):
+ %% Nasty hackery here really. We need to undo the HWResolution scaling which
+ %% is done by pdfwrite. Default is 720 dpi, so 0.1. We also need to make
+ %% sure that any translation of the page (because its been rotated for example)
+ %% is also modified by the requisite amount. SO we ned to calculate a matrix
+ %% which does the scaling and concatenate it with the current matrix.
+ %% Do this inside a gsave/grestore pair to avoid side effects!
+ *
+ * TODO: In practice, when I was debugging this code I found that it does nothing
+ * useful, since the matrice it calculates is essentially the identity matrix.
+ * I am not sure under what circumstance it is needed?
+ */
+static int pdfi_annot_preserve_modQP(pdf_context *ctx, pdf_dict *annot, pdf_name *QP_key)
+{
+ int code = 0;
+ pdf_array *QP = NULL;
+ gx_device *device = gs_currentdevice(ctx->pgs);
+ gs_matrix devmatrix, ctm, matrix;
+ uint64_t arraysize, index;
+ double old_x, old_y;
+ gs_point point;
+
+ code = pdfi_dict_get(ctx, annot, "QuadPoints", (pdf_obj **)&QP);
+ if (code < 0) goto exit;
+
+ if (QP->type != PDF_ARRAY) {
+ /* Invalid QuadPoints, just delete it because I dunno what to do...
+ * TODO: Should flag a warning here
+ */
+ code = pdfi_dict_delete_pair(ctx, annot, QP_key);
+ goto exit;
+ }
+
+ arraysize = pdfi_array_size(QP);
+ if (arraysize % 8 != 0) {
+ /* TODO: Flag a warning -- must be sets of 8 values (4 points) */
+ code = gs_note_error(gs_error_syntaxerror);
+ goto exit;
+ }
+
+
+ /* Get device matrix and adjust by default 72.0 (no idea, just following PS code...) */
+ devmatrix.xx = 72.0 / device->HWResolution[0];
+ devmatrix.xy = 0;
+ devmatrix.yx = 0;
+ devmatrix.yy = 72.0 / device->HWResolution[1];
+ devmatrix.tx = 0;
+ devmatrix.ty = 0;
+
+ /* Get the CTM */
+ gs_currentmatrix(ctx->pgs, &ctm);
+
+ /* Get matrix to adjust the QuadPoints */
+ code = gs_matrix_multiply(&ctm, &devmatrix, &matrix);
+ if (code < 0) goto exit;
+
+ /* Transform all the points by the calculated matrix */
+ for (index = 0; index < arraysize; index += 2) {
+ code = pdfi_array_get_number(ctx, QP, index, &old_x);
+ if (code < 0) goto exit;
+ code = pdfi_array_get_number(ctx, QP, index+1, &old_y);
+ if (code < 0) goto exit;
+
+ code = gs_point_transform(old_x, old_y, &matrix, &point);
+ if (code < 0) goto exit;
+
+ code = pdfi_array_put_real(ctx, QP, index, point.x);
+ if (code < 0) goto exit;
+ code = pdfi_array_put_real(ctx, QP, index+1, point.y);
+ if (code < 0) goto exit;
+ }
+
+
+ exit:
+ pdfi_countdown(QP);
+ return code;
+}
+
+/* Build a high level form for the AP and replace it with an indirect reference
+ *
+ * There can multiple AP in the dictionary, so do all of them.
+ */
+static int pdfi_annot_preserve_modAP(pdf_context *ctx, pdf_dict *annot, pdf_name *AP_key)
+{
+ int code = 0;
+ pdf_dict *AP = NULL;
+ uint64_t index;
+ pdf_name *Key = NULL;
+ pdf_indirect_ref *Value = NULL;
+ byte *labeldata = NULL;
+ int labellen;
+ int form_id;
+ gx_device *device = gs_currentdevice(ctx->pgs);
+ bool found_ap = false; /* found at least one AP stream? */
+ pdf_obj *object = NULL;
+
+ code = pdfi_dict_get(ctx, annot, "AP", (pdf_obj **)&AP);
+ if (code < 0) goto exit;
+
+ if (AP->type != PDF_DICT) {
+ /* This is an invalid AP, we will flag and delete it below */
+ found_ap = false;
+ goto exit;
+ }
+
+ code = pdfi_dict_key_first(ctx, AP, (pdf_obj **)&Key, &index);
+ while (code >= 0) {
+ found_ap = true;
+ code = pdfi_dict_get_no_deref(ctx, AP, Key, (pdf_obj **)&Value);
+ if (code < 0) goto exit;
+
+ /* Handle indirect object */
+ if (Value->type != PDF_INDIRECT)
+ goto loop_continue;
+
+ /* Dereference it */
+ code = pdfi_dereference(ctx, Value->ref_object_num, Value->ref_generation_num, &object);
+ if (code < 0) goto exit;
+
+ if (object->type == PDF_STREAM) {
+ /* Get a form label */
+ code = pdfi_annot_preserve_nextformlabel(ctx, &labeldata, &labellen);
+ if (code < 0) goto exit;
+
+ /* Notify the driver of the label name */
+ code = (*dev_proc(device, dev_spec_op))
+ (device, gxdso_pdf_form_name, labeldata, labellen);
+
+ code = pdfi_op_q(ctx);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_annot_position_AP(ctx, annot, (pdf_stream *)object);
+ /* Draw the high-level form */
+ code = pdfi_do_highlevel_form(ctx, ctx->page.CurrentPageDict, (pdf_stream *)object);
+ (void)pdfi_op_Q(ctx);
+ if (code < 0) goto exit;
+
+ /* Get the object number (form_id) of the high level form */
+ code = (*dev_proc(device, dev_spec_op))
+ (device, gxdso_get_form_ID, &form_id, sizeof(int));
+
+ /* Save the highlevel form info for pdfi_obj_indirect_str() */
+ Value->highlevel_object_num = form_id;
+ Value->is_highlevelform = true;
+
+ }
+
+ loop_continue:
+ pdfi_countdown(Key);
+ Key = NULL;
+ pdfi_countdown(Value);
+ Value = NULL;
+ pdfi_countdown(object);
+ object = NULL;
+ gs_free_object(ctx->memory, labeldata, "pdfi_annot_preserve_modAP(labeldata)");
+ labeldata = NULL;
+
+ code = pdfi_dict_key_next(ctx, AP, (pdf_obj **)&Key, &index);
+ if (code == gs_error_undefined) {
+ code = 0;
+ break;
+ }
+ }
+ if (code < 0) goto exit;
+
+ exit:
+ /* If there was no AP found, then delete the key completely.
+ * (Bug697951.pdf)
+ */
+ if (!found_ap) {
+ /* TODO: Flag a warning for broken file? */
+ code = pdfi_dict_delete_pair(ctx, annot, AP_key);
+ }
+
+ if (labeldata)
+ gs_free_object(ctx->memory, labeldata, "pdfi_annot_preserve_modAP(labeldata)");
+ pdfi_countdown(AP);
+ pdfi_countdown(Key);
+ pdfi_countdown(Value);
+ pdfi_countdown(object);
+ return code;
+}
+
+/* Make a temporary copy of the annotation dict with some fields left out or
+ * modified, then do a pdfmark on it
+ */
+static int pdfi_annot_preserve_mark(pdf_context *ctx, pdf_dict *annot, pdf_name *subtype)
+{
+ int code = 0;
+ gs_matrix ctm;
+ pdf_dict *tempdict = NULL;
+ uint64_t dictsize;
+ uint64_t index;
+ pdf_name *Key = NULL;
+ pdf_obj *Value = NULL;
+ bool resolve = false;
+
+ /* Create a temporary copy of the annot dict */
+ dictsize = pdfi_dict_entries(annot);
+ code = pdfi_dict_alloc(ctx, dictsize, &tempdict);
+ if (code < 0) goto exit;
+ pdfi_countup(tempdict);
+ code = pdfi_dict_copy(ctx, tempdict, annot);
+ if (code < 0) goto exit;
+
+
+ /* see also: 'loadannot' in gs code */
+ /* Go through the dict, deleting and modifying some entries
+ * Note that I am iterating through the original dict because I will
+ * be deleting some keys from tempdict and the iterators wouldn't work right.
+ */
+ code = pdfi_dict_key_first(ctx, annot, (pdf_obj **)&Key, &index);
+ while (code >= 0) {
+ resolve = false;
+
+ if (pdfi_name_is(Key, "Popup") || pdfi_name_is(Key, "IRT") || pdfi_name_is(Key, "RT") ||
+ pdfi_name_is(Key, "P") || pdfi_name_is(Key, "Parent")) {
+ /* Delete some keys
+ * These would not be handled correctly and are optional.
+ * (see pdf_draw.ps/loadannot())
+ * TODO: Could probably handle some of these since they are typically
+ * just references, and we do have a way to handle references?
+ * Look into it later...
+ */
+ code = pdfi_dict_delete_pair(ctx, tempdict, Key);
+ if (code < 0) goto exit;
+ } else if (pdfi_name_is(Key, "AP")) {
+ /* Special handling for AP -- have fun! */
+ code = pdfi_annot_preserve_modAP(ctx, tempdict, Key);
+ if (code < 0) goto exit;
+ } else if (pdfi_name_is(Key, "QuadPoints")) {
+ code = pdfi_annot_preserve_modQP(ctx, tempdict, Key);
+ if (code < 0) goto exit;
+ } else if (pdfi_name_is(Key, "A")) {
+ code = pdfi_mark_modA(ctx, tempdict);
+ if (code < 0) goto exit;
+ } else if (pdfi_name_is(Key, "Dest")) {
+ if (ctx->args.no_pdfmark_dests) {
+ /* If omitting dests, such as for multi-page output, then omit this whole annotation */
+ code = 0;
+ goto exit;
+ }
+ code = pdfi_mark_modDest(ctx, tempdict);
+ if (code < 0) goto exit;
+ } else if (pdfi_name_is(Key, "StructTreeRoot")) {
+ /* TODO: Bug691785 has Link annots with /StructTreeRoot
+ * It is super-circular, and causes issues.
+ * GS code only adds in certain values for Link so it doesn't
+ * run into a problem. I am just going to delete it.
+ * There should be a better solution to handle circular stuff
+ * generically.
+ */
+ code = pdfi_dict_delete_pair(ctx, tempdict, Key);
+ if (code < 0) goto exit;
+ } else if (pdfi_name_is(Key, "Sound") || pdfi_name_is(Key, "Movie")) {
+ resolve = false;
+ } else {
+ resolve = true;
+ }
+
+ if (resolve) {
+ code = pdfi_dict_get_by_key(ctx, annot, (const pdf_name *)Key, &Value);
+ if (code < 0) goto exit;
+
+ /* Pre-resolve indirect references of any arrays/dicts
+ * TODO: I am doing this because the gs code does it, but I
+ * noticed it only goes down one level, not recursively through
+ * everything. I am not sure what the point is in that case.
+ * For now, also doing only one level.
+ */
+ code = pdfi_resolve_indirect_loop_detect(ctx, (pdf_obj *)annot, Value, false);
+ if (code < 0) goto exit;
+ }
+
+ pdfi_countdown(Key);
+ Key = NULL;
+ pdfi_countdown(Value);
+ Value = NULL;
+
+ code = pdfi_dict_key_next(ctx, annot, (pdf_obj **)&Key, &index);
+ if (code == gs_error_undefined) {
+ code = 0;
+ break;
+ }
+ }
+ if (code < 0) goto exit;
+
+ /* Do pdfmark from the tempdict */
+ gs_currentmatrix(ctx->pgs, &ctm);
+
+ if (pdfi_name_is(subtype, "Link"))
+ code = pdfi_mark_from_dict(ctx, tempdict, &ctm, "LNK");
+ else
+ code = pdfi_mark_from_dict(ctx, tempdict, &ctm, "ANN");
+ if (code < 0) goto exit;
+
+ exit:
+ pdfi_countdown(tempdict);
+ pdfi_countdown(Key);
+ pdfi_countdown(Value);
+ return code;
+}
+
+static int pdfi_annot_preserve_default(pdf_context *ctx, pdf_dict *annot, pdf_name *subtype)
+{
+ return pdfi_annot_preserve_mark(ctx, annot, subtype);
+}
+
+static int pdfi_annot_preserve_Link(pdf_context *ctx, pdf_dict *annot, pdf_name *subtype)
+{
+ int code = 0;
+
+ /* TODO: The gs code does a whole bunch of stuff I don't understand yet.
+ * I think doing the default behavior might work in most cases?
+ * See: pdf_draw.ps/preserveannottypes dict/Link()
+ */
+ code = pdfi_annot_preserve_mark(ctx, annot, subtype);
+ return code;
+}
+
+static int pdfi_annot_preserve_Widget(pdf_context *ctx, pdf_dict *annot, pdf_name *subtype)
+{
+ /* According to the gs implementation:
+%% Widget annotations are only used with AcroForms, and since we don't preserve AcroForms
+%% we don't want to preserve widget annotations either, because the consumer of the new
+%% PDF won't know what values they should take. So we draw widget annotations instead. If we
+%% ever preserve AcroForms then we should alter this to preserve Widgets as well.
+ *
+ * TODO: See also, comment on pdfi_annot_render_field().
+ */
+
+ return pdfi_annot_draw(ctx, annot, subtype);
+}
+
+/* TODO: When I started writing this, I thought these handlers were necessary because
+ * the PS code has a bunch of special cases. As it turns out, I think it could easily have
+ * been done without the handlers. Maybe they should be taken out...
+ */
+annot_preserve_dispatch_t annot_preserve_dispatch[] = {
+ {"Link", pdfi_annot_preserve_Link},
+ {"Widget", pdfi_annot_preserve_Widget},
+ {"Circle", pdfi_annot_preserve_default},
+ {"FileAttachment", pdfi_annot_preserve_default},
+ {"FreeText", pdfi_annot_preserve_default},
+ {"Highlight", pdfi_annot_preserve_default},
+ {"Ink", pdfi_annot_preserve_default},
+ {"Line", pdfi_annot_preserve_default},
+ {"Movie", pdfi_annot_preserve_default},
+ {"PolyLine", pdfi_annot_preserve_default},
+ {"Popup", pdfi_annot_preserve_default},
+ // {"Screen", pdfi_annot_preserve_default}, /* TODO: fts_07_0709.pdf */
+ {"Sound", pdfi_annot_preserve_default},
+ {"Square", pdfi_annot_preserve_default},
+ {"Squiggly", pdfi_annot_preserve_default},
+ {"StrikeOut", pdfi_annot_preserve_default},
+ {"Underline", pdfi_annot_preserve_default},
+ {"Stamp", pdfi_annot_preserve_default},
+ {"Text", pdfi_annot_preserve_default},
+ {"TrapNet", pdfi_annot_preserve_default},
+ { NULL, NULL},
+};
+
+static int pdfi_annot_preserve(pdf_context *ctx, pdf_dict *annot, pdf_name *subtype)
+{
+ int code = 0;
+ annot_preserve_dispatch_t *dispatch_ptr;
+
+ /* If not preserving this subtype, draw it instead */
+ if (!pdfi_annot_preserve_type(ctx, subtype))
+ return pdfi_annot_draw(ctx, annot, subtype);
+
+ /* Handle the annotation */
+ for (dispatch_ptr = annot_preserve_dispatch; dispatch_ptr->subtype; dispatch_ptr ++) {
+ if (pdfi_name_is(subtype, dispatch_ptr->subtype)) {
+ code = dispatch_ptr->func(ctx, annot, subtype);
+ break;
+ }
+ }
+
+ /* If there is no handler, just draw it */
+ /* NOTE: gs does a drawwidget here instead (?) */
+ if (!dispatch_ptr->subtype)
+ code = pdfi_annot_draw(ctx, annot, subtype);
+
+ return code;
+}
+
+static int pdfi_annot_handle(pdf_context *ctx, pdf_dict *annot)
+{
+ int code = 0;
+ pdf_name *Subtype = NULL;
+
+ code = pdfi_dict_get_type(ctx, annot, "Subtype", PDF_NAME, (pdf_obj **)&Subtype);
+ if (code != 0) {
+ /* TODO: Set warning flag */
+ dbgmprintf(ctx->memory, "WARNING: Ignoring annotation with missing Subtype\n");
+ code = 0;
+ goto exit;
+ }
+
+ if (ctx->args.preserveannots && ctx->device_state.annotations_preserved)
+ code = pdfi_annot_preserve(ctx, annot, Subtype);
+ else
+ code = pdfi_annot_draw(ctx, annot, Subtype);
+
+ exit:
+ pdfi_countdown(Subtype);
+ return code;
+}
+
+int pdfi_do_annotations(pdf_context *ctx, pdf_dict *page_dict)
+{
+ int code = 0;
+ pdf_array *Annots = NULL;
+ pdf_dict *annot = NULL;
+ int i;
+
+ if (!ctx->args.showannots)
+ return 0;
+
+ code = pdfi_dict_knownget_type(ctx, page_dict, "Annots", PDF_ARRAY, (pdf_obj **)&Annots);
+ if (code <= 0)
+ return code;
+
+ for (i = 0; i < pdfi_array_size(Annots); i++) {
+ code = pdfi_array_get_type(ctx, Annots, i, PDF_DICT, (pdf_obj **)&annot);
+ if (code < 0)
+ continue;
+ code = pdfi_annot_handle(ctx, annot);
+ if (code < 0 && ctx->args.pdfstoponerror)
+ goto exit;
+ pdfi_countdown(annot);
+ annot = NULL;
+ }
+
+ exit:
+ pdfi_countdown(annot);
+ pdfi_countdown(Annots);
+ return code;
+}
+
+/* draw terminal field */
+static int pdfi_form_draw_terminal(pdf_context *ctx, pdf_dict *Page, pdf_dict *field)
+{
+ int code = 0;
+ pdf_indirect_ref *P = NULL;
+ pdf_name *FT = NULL;
+ pdf_obj *AP = NULL;
+
+ /* See if the field goes on this page */
+ /* NOTE: We know the "P" is an indirect ref, so just fetch it that way.
+ * If we fetch the actual object, it will result in a cyclical reference in the cache
+ * that causes a memory leak, so don't do that.
+ * (The cyclical reference is because the object containing P is actually inside P)
+ */
+ code = pdfi_dict_get_ref(ctx, field, "P", &P);
+ if (code < 0) {
+ if (code == gs_error_undefined)
+ code = 0;
+ goto exit;
+ }
+
+ if (P->ref_object_num != Page->object_num) {
+ /* Not this page */
+ code = 0;
+ goto exit;
+ }
+
+ /* Render the field */
+
+ /* NOTE: The spec says the FT is inheritable, implying it might be present in
+ * a Parent and not explicitly in a Child. The gs implementation doesn't seem
+ * to handle this case, but I am going to go ahead and handle it. We will figure
+ * out if this causes diffs later, if ever...
+ */
+ code = pdfi_form_get_inheritable(ctx, field, "FT", PDF_NAME, (pdf_obj **)&FT);
+ if (code <= 0) goto exit;
+
+ code = pdfi_annot_get_NormAP(ctx, field, &AP);
+ if (code < 0) goto exit;
+
+ code = pdfi_annot_render_field(ctx, field, FT, AP);
+ if (code < 0) goto exit;
+
+ exit:
+ pdfi_countdown(FT);
+ pdfi_countdown(P);
+ pdfi_countdown(AP);
+ return code;
+}
+
+/* From pdf_draw.ps/draw_form_field():
+% We distinguish 4 types of nodes on the form field tree:
+% - non-terminal field - has a kid that refers to the parent (or anywhere else)
+% - terminal field with separate widget annotations - has a kid that doesn't have a parent
+% - terminal field with a merged widget annotation - has no kids
+% - widget annotation - has /Subtype and /Rect
+%
+% The recursive enumeration of the form fields doesn't descend into widget annotations.
+*/
+static int pdfi_form_draw_field(pdf_context *ctx, pdf_dict *Page, pdf_dict *field)
+{
+ int code = 0;
+ pdf_array *Kids = NULL;
+ pdf_dict *child = NULL;
+ pdf_dict *Parent = NULL;
+ int i;
+
+ code = pdfi_dict_knownget_type(ctx, field, "Kids", PDF_ARRAY, (pdf_obj **)&Kids);
+ if (code < 0) goto exit;
+ if (code == 0) {
+ code = pdfi_form_draw_terminal(ctx, Page, field);
+ goto exit;
+ }
+
+ /* Handle Kids */
+ if (pdfi_array_size(Kids) <= 0) {
+ dmprintf(ctx->memory, "*** Error: Ignoring empty /Kids array in Form field.\n");
+ dmprintf(ctx->memory, " Output may be incorrect.\n");
+ /* TODO: Set warning flag */
+ code = 0;
+ goto exit;
+ }
+
+ /* Check first child to see if it has a parent */
+ code = pdfi_array_get_type(ctx, Kids, 0, PDF_DICT, (pdf_obj **)&child);
+ if (code < 0) goto exit;
+ code = pdfi_dict_knownget_type(ctx, child, "Parent", PDF_DICT, (pdf_obj **)&Parent);
+ if (code < 0) goto exit;
+
+ /* If kid has no parent, then treat this as terminal field */
+ if (code == 0) {
+ /* TODO: This case isn't tested because no examples available.
+ * I think it's only relevant for Btn, and not sure if it
+ * should be dealt with here or in Btn routine.
+ */
+ code = pdfi_form_draw_terminal(ctx, Page, field);
+ goto exit;
+ }
+
+ pdfi_countdown(child);
+ child = NULL;
+ /* Render the Kids (recursive) */
+ for (i=0; i<pdfi_array_size(Kids); i++) {
+ code = pdfi_array_get_type(ctx, Kids, i, PDF_DICT, (pdf_obj **)&child);
+ if (code < 0) goto exit;
+
+ code = pdfi_form_draw_field(ctx, Page, child);
+ if (code < 0) goto exit;
+
+ pdfi_countdown(child);
+ child = NULL;
+ }
+
+ exit:
+ pdfi_countdown(child);
+ pdfi_countdown(Kids);
+ pdfi_countdown(Parent);
+ return code;
+}
+
+int pdfi_do_acroform(pdf_context *ctx, pdf_dict *page_dict)
+{
+ int code = 0;
+ pdf_array *Fields = NULL;
+ pdf_dict *field = NULL;
+ int i;
+
+ if (!ctx->args.showacroform)
+ return 0;
+
+ if (!ctx->AcroForm)
+ return 0;
+
+ code = pdfi_dict_knownget_type(ctx, ctx->AcroForm, "Fields", PDF_ARRAY, (pdf_obj **)&Fields);
+ if (code <= 0)
+ goto exit;
+
+ for (i=0; i<pdfi_array_size(Fields); i++) {
+ code = pdfi_array_get_type(ctx, Fields, i, PDF_DICT, (pdf_obj **)&field);
+ if (code < 0)
+ continue;
+ code = pdfi_form_draw_field(ctx, page_dict, field);
+ if (code < 0)
+ goto exit;
+ pdfi_countdown(field);
+ field = NULL;
+ }
+
+ exit:
+ pdfi_countdown(field);
+ pdfi_countdown(Fields);
+ return code;
+}
diff --git a/base/gxdevrop.h b/pdf/pdf_annot.h
index 10e502a1..ae86bb2c 100644
--- a/base/gxdevrop.h
+++ b/pdf/pdf_annot.h
@@ -1,4 +1,4 @@
-/* Copyright (C) 2001-2021 Artifex Software, Inc.
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
All Rights Reserved.
This software is provided AS-IS with no warranty, either express or
@@ -13,16 +13,12 @@
CA 94945, U.S.A., +1(415)492-9861, for further information.
*/
+/* Annotation handling for the PDF interpreter */
-/* Extension of gxdevice.h for RasterOp */
+#ifndef PDF_ANNOTATIONS
+#define PDF_ANNOTATIONS
-#ifndef gxdevrop_INCLUDED
-# define gxdevrop_INCLUDED
+int pdfi_do_annotations(pdf_context *ctx, pdf_dict *page_dict);
+int pdfi_do_acroform(pdf_context *ctx, pdf_dict *page_dict);
-#include "gxdevcli.h"
-
-/* Define an unaligned implementation of [strip_]copy_rop. */
-dev_proc_copy_rop(gx_copy_rop_unaligned);
-dev_proc_strip_copy_rop(gx_strip_copy_rop_unaligned);
-
-#endif /* gxdevrop_INCLUDED */
+#endif
diff --git a/pdf/pdf_array.c b/pdf/pdf_array.c
new file mode 100644
index 00000000..07a90812
--- /dev/null
+++ b/pdf/pdf_array.c
@@ -0,0 +1,541 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* array handling for the PDF interpreter */
+
+#include "ghostpdf.h"
+#include "pdf_types.h"
+#include "pdf_stack.h"
+#include "pdf_deref.h"
+#include "pdf_array.h"
+
+/* NOTE: I think this should take a pdf_context param, but it's not available where it's
+ * called, would require some surgery.
+ */
+void pdfi_free_array(pdf_obj *o)
+{
+ pdf_array *a = (pdf_array *)o;
+ int i;
+
+ for (i=0;i < a->size;i++) {
+ if (a->values[i] != NULL)
+ pdfi_countdown(a->values[i]);
+ }
+ gs_free_object(OBJ_MEMORY(a), a->values, "pdf interpreter free array contents");
+ gs_free_object(OBJ_MEMORY(a), a, "pdf interpreter free array");
+}
+
+int pdfi_array_alloc(pdf_context *ctx, uint64_t size, pdf_array **a)
+{
+ int code, i;
+ pdf_obj *n = NULL;
+
+ *a = NULL;
+ code = pdfi_object_alloc(ctx, PDF_ARRAY, size, (pdf_obj **)a);
+ if (code < 0)
+ return code;
+
+ (*a)->size = size;
+
+ if (size > 0) {
+ /* Make a null object */
+ code = pdfi_object_alloc(ctx, PDF_NULL, 1, &n);
+ if (code < 0) {
+ pdfi_countdown(*a);
+ *a = NULL;
+ return code;
+ }
+ /* And start all the array entries pointing at that null object.
+ * array_put will replace tehm. This ensures we always have a valid
+ * object for every entry. pdfi_array_from_stack() doesn't do this
+ * initialisation because we know how many obejcts there are in the array
+ * and we have valid objects for each entry on the stack already created.
+ */
+ for (i=0;i<size;i++){
+ (*a)->values[i] = n;
+ pdfi_countup(n);
+ }
+ }
+ return 0;
+}
+
+/* This was defined in pdf_int.c until we moved the equivalent pdfi_dict_from_stack() into
+ * pdf_dict.c, because we needed to be able to create dictionaries for images. We don't have
+ * that need, but its less confusing to have the array_from_stack function defined in
+ * here, similarly to the dictionary routine.
+ */
+int pdfi_array_from_stack(pdf_context *ctx, uint32_t indirect_num, uint32_t indirect_gen)
+{
+ uint64_t index = 0;
+ pdf_array *a = NULL;
+ pdf_obj *o;
+ int code;
+
+ code = pdfi_count_to_mark(ctx, &index);
+ if (code < 0)
+ return code;
+
+ code = pdfi_array_alloc(ctx, index, &a);
+ if (code < 0)
+ return code;
+
+ while (index) {
+ o = ctx->stack_top[-1];
+ code = pdfi_array_put(ctx, a, --index, o);
+ if (code < 0) {
+ (void)pdfi_clear_to_mark(ctx);
+ return code;
+ }
+ pdfi_pop(ctx, 1);
+ }
+
+ code = pdfi_clear_to_mark(ctx);
+ if (code < 0)
+ return code;
+
+ if (ctx->args.pdfdebug)
+ dmprintf (ctx->memory, " ]\n");
+
+ a->indirect_num = indirect_num;
+ a->indirect_gen = indirect_gen;
+
+ code = pdfi_push(ctx, (pdf_obj *)a);
+ if (code < 0)
+ pdfi_free_array((pdf_obj *)a);
+
+ return code;
+}
+
+/* Fetch object from array, resolving indirect reference if needed
+ * setref -- indicates whether to replace indirect ref with the object
+ */
+static int pdfi_array_fetch(pdf_context *ctx, pdf_array *a, uint64_t index, pdf_obj **o, bool setref)
+{
+ int code;
+ pdf_obj *obj;
+
+ *o = NULL;
+
+ if (a->type != PDF_ARRAY)
+ return_error(gs_error_typecheck);
+
+ if (index >= a->size)
+ return_error(gs_error_rangecheck);
+ obj = a->values[index];
+
+ if (obj->type == PDF_INDIRECT) {
+ pdf_obj *o1 = NULL;
+ pdf_indirect_ref *r = (pdf_indirect_ref *)obj;
+
+ code = pdfi_deref_loop_detect(ctx, r->ref_object_num, r->ref_generation_num, &o1);
+ if (code < 0)
+ return code;
+
+ if (setref)
+ (void)pdfi_array_put(ctx, a, index, o1);
+ obj = o1;
+ } else {
+ pdfi_countup(obj);
+ }
+
+ *o = obj;
+ return 0;
+}
+
+/* The object returned by pdfi_array_get has its reference count incremented by 1 to
+ * indicate the reference now held by the caller, in **o.
+ */
+int pdfi_array_get(pdf_context *ctx, pdf_array *a, uint64_t index, pdf_obj **o)
+{
+ int code;
+
+ code = pdfi_array_fetch(ctx, a, index, o, true);
+ if (code < 0) return code;
+
+ return 0;
+}
+
+/* Get element from array without resolving PDF_INDIRECT dereferences.
+ * It looks to me like some usages need to do the checking themselves to
+ * avoid circular references? Can remove this if not really needed.
+ */
+int pdfi_array_get_no_deref(pdf_context *ctx, pdf_array *a, uint64_t index, pdf_obj **o)
+{
+ if (a->type != PDF_ARRAY)
+ return_error(gs_error_typecheck);
+
+ if (index >= a->size)
+ return_error(gs_error_rangecheck);
+
+ *o = a->values[index];
+ pdfi_countup(*o);
+ return 0;
+}
+
+/* Same as pdfi_array_get() but doesn't replace indirect ref with a new object.
+ */
+int pdfi_array_get_no_store_R(pdf_context *ctx, pdf_array *a, uint64_t index, pdf_obj **o)
+{
+ int code;
+
+ code = pdfi_array_fetch(ctx, a, index, o, false);
+ if (code < 0) return code;
+
+ return 0;
+}
+
+/* Get value from pdfi_array.
+ * Handles type-checking and resolving indirect references.
+ */
+int pdfi_array_get_type(pdf_context *ctx, pdf_array *a, uint64_t index,
+ pdf_obj_type type, pdf_obj **o)
+{
+ int code;
+
+ code = pdfi_array_get(ctx, a, index, o);
+ if (code < 0)
+ return code;
+
+ if ((*o)->type != type) {
+ pdfi_countdown(*o);
+ *o = NULL;
+ return_error(gs_error_typecheck);
+ }
+ return 0;
+}
+
+int pdfi_array_get_int(pdf_context *ctx, pdf_array *a, uint64_t index, int64_t *i)
+{
+ int code;
+ pdf_num *n;
+
+ code = pdfi_array_get_type(ctx, a, index, PDF_INT, (pdf_obj **)&n);
+ if (code < 0)
+ return code;
+ *i = n->value.i;
+ pdfi_countdown(n);
+ return 0;
+}
+
+int pdfi_array_get_number(pdf_context *ctx, pdf_array *a, uint64_t index, double *f)
+{
+ int code;
+ pdf_num *n;
+
+ code = pdfi_array_get(ctx, a, index, (pdf_obj **)&n);
+ if (code < 0)
+ return code;
+
+ if (n->type == PDF_INT)
+ *f = (double)n->value.i;
+ else {
+ if (n->type == PDF_REAL)
+ *f = n->value.d;
+ else {
+ code = gs_note_error(gs_error_typecheck);
+ }
+ }
+ pdfi_countdown(n);
+
+ return code;
+}
+
+/* Check whether a particular object is in an array.
+ * If index is not NULL, fill it in with the index of the object.
+ * Note that this will resolve indirect references if needed.
+ */
+bool pdfi_array_known(pdf_context *ctx, pdf_array *a, pdf_obj *o, int *index)
+{
+ int i;
+
+ if (a->type != PDF_ARRAY)
+ return_error(gs_error_typecheck);
+
+ for (i=0; i < a->size; i++) {
+ pdf_obj *val;
+ int code;
+
+ code = pdfi_array_fetch(ctx, a, i, &val, true);
+ if (code < 0)
+ continue;
+ if (val->object_num == o->object_num) {
+ if (index != NULL) *index = i;
+ pdfi_countdown(val);
+ return true;
+ }
+ pdfi_countdown(val);
+ }
+ return false;
+}
+
+int pdfi_array_put(pdf_context *ctx, pdf_array *a, uint64_t index, pdf_obj *o)
+{
+ if (a->type != PDF_ARRAY)
+ return_error(gs_error_typecheck);
+
+ if (index >= a->size)
+ return_error(gs_error_rangecheck);
+
+ pdfi_countdown(a->values[index]);
+ a->values[index] = o;
+ pdfi_countup(o);
+ return 0;
+}
+
+int pdfi_array_put_int(pdf_context *ctx, pdf_array *a, uint64_t index, int64_t val)
+{
+ int code;
+ pdf_num *obj;
+
+ if (a->type != PDF_ARRAY)
+ return_error(gs_error_typecheck);
+
+ code = pdfi_object_alloc(ctx, PDF_INT, 0, (pdf_obj **)&obj);
+ obj->value.i = val;
+ if (code < 0)
+ return code;
+
+ return pdfi_array_put(ctx, a, index, (pdf_obj *)obj);
+}
+
+int pdfi_array_put_real(pdf_context *ctx, pdf_array *a, uint64_t index, double val)
+{
+ int code;
+ pdf_num *obj;
+
+ if (a->type != PDF_ARRAY)
+ return_error(gs_error_typecheck);
+
+ code = pdfi_object_alloc(ctx, PDF_REAL, 0, (pdf_obj **)&obj);
+ obj->value.d = val;
+ if (code < 0)
+ return code;
+
+ return pdfi_array_put(ctx, a, index, (pdf_obj *)obj);
+}
+
+/* Strictly speaking the normalize_rect isn't really part of the PDF array
+ * processing, but its very likely that any time we want to use it, the
+ * rectangle will have come from a PDF array in a PDF file so it makes
+ * sense to have it here.
+ */
+
+/* Normalize rectangle */
+void pdfi_normalize_rect(pdf_context *ctx, gs_rect *rect)
+{
+ double temp;
+
+ /* Normalize the rectangle */
+ if (rect->p.x > rect->q.x) {
+ temp = rect->p.x;
+ rect->p.x = rect->q.x;
+ rect->q.x = temp;
+ }
+ if (rect->p.y > rect->q.y) {
+ temp = rect->p.y;
+ rect->p.y = rect->q.y;
+ rect->q.y = temp;
+ }
+}
+
+/*
+ * Turn an Array into a gs_rect. If Array is NULL, makes a tiny rect
+ */
+int pdfi_array_to_gs_rect(pdf_context *ctx, pdf_array *array, gs_rect *rect)
+{
+ double number;
+ int code = 0;
+
+ /* Init to tiny rect to allow sane continuation on errors */
+ rect->p.x = 0.0;
+ rect->p.y = 0.0;
+ rect->q.x = 1.0;
+ rect->q.y = 1.0;
+
+ /* Identity matrix if no array */
+ if (array == NULL || array->type != PDF_ARRAY) {
+ return 0;
+ }
+ if (pdfi_array_size(array) != 4) {
+ return_error(gs_error_rangecheck);
+ }
+ code = pdfi_array_get_number(ctx, array, 0, &number);
+ if (code < 0) goto errorExit;
+ rect->p.x = (float)number;
+ code = pdfi_array_get_number(ctx, array, 1, &number);
+ if (code < 0) goto errorExit;
+ rect->p.y = (float)number;
+ code = pdfi_array_get_number(ctx, array, 2, &number);
+ if (code < 0) goto errorExit;
+ rect->q.x = (float)number;
+ code = pdfi_array_get_number(ctx, array, 3, &number);
+ if (code < 0) goto errorExit;
+ rect->q.y = (float)number;
+
+ return 0;
+
+ errorExit:
+ return code;
+}
+
+/* Create a new PDF array object with 4 entires, and store the values from a
+ * gs_rect to it.
+ */
+int pdfi_gs_rect_to_array(pdf_context *ctx, gs_rect *rect, pdf_array **new_array)
+{
+ pdf_num *num = NULL;
+ int code = 0;
+
+ code = pdfi_array_alloc(ctx, 4, new_array);
+ if (code < 0)
+ return code;
+
+ pdfi_countup(*new_array);
+
+ code = pdfi_num_alloc(ctx, rect->p.x, &num);
+ if (code < 0)
+ goto error;
+
+ code = pdfi_array_put(ctx, *new_array, 0, (pdf_obj *)num);
+ if (code < 0)
+ goto error;
+
+ code = pdfi_num_alloc(ctx, rect->p.y, &num);
+ if (code < 0)
+ goto error;
+
+ code = pdfi_array_put(ctx, *new_array, 1, (pdf_obj *)num);
+ if (code < 0)
+ goto error;
+
+ code = pdfi_num_alloc(ctx, rect->q.x, &num);
+ if (code < 0)
+ goto error;
+
+ code = pdfi_array_put(ctx, *new_array, 2, (pdf_obj *)num);
+ if (code < 0)
+ goto error;
+
+ code = pdfi_num_alloc(ctx, rect->q.y, &num);
+ if (code < 0)
+ goto error;
+
+ code = pdfi_array_put(ctx, *new_array, 3, (pdf_obj *)num);
+ if (code < 0)
+ goto error;
+
+ return 0;
+
+error:
+ pdfi_countdown(new_array);
+ return code;
+}
+
+/* Turn a /Matrix Array into a gs_matrix. If Array is NULL, makes an identity matrix */
+int pdfi_array_to_gs_matrix(pdf_context *ctx, pdf_array *array, gs_matrix *mat)
+{
+ double number;
+ int code = 0;
+
+ /* Init to identity matrix to allow sane continuation on errors */
+ mat->xx = 1.0;
+ mat->xy = 0.0;
+ mat->yx = 0.0;
+ mat->yy = 1.0;
+ mat->tx = 0.0;
+ mat->ty = 0.0;
+
+ /* Identity matrix if no array */
+ if (array == NULL || array->type != PDF_ARRAY) {
+ return 0;
+ }
+ if (pdfi_array_size(array) != 6) {
+ return_error(gs_error_rangecheck);
+ }
+ code = pdfi_array_get_number(ctx, array, 0, &number);
+ if (code < 0) goto errorExit;
+ mat->xx = (float)number;
+ code = pdfi_array_get_number(ctx, array, 1, &number);
+ if (code < 0) goto errorExit;
+ mat->xy = (float)number;
+ code = pdfi_array_get_number(ctx, array, 2, &number);
+ if (code < 0) goto errorExit;
+ mat->yx = (float)number;
+ code = pdfi_array_get_number(ctx, array, 3, &number);
+ if (code < 0) goto errorExit;
+ mat->yy = (float)number;
+ code = pdfi_array_get_number(ctx, array, 4, &number);
+ if (code < 0) goto errorExit;
+ mat->tx = (float)number;
+ code = pdfi_array_get_number(ctx, array, 5, &number);
+ if (code < 0) goto errorExit;
+ mat->ty = (float)number;
+ return 0;
+
+ errorExit:
+ return code;
+}
+
+/* Turn a pdf_array into a double array of specified size */
+int pdfi_array_to_num_array(pdf_context *ctx, pdf_array *array, double *out, int offset, int size)
+{
+ int i;
+ int code;
+ double num;
+
+ for (i=0; i<size; i++) {
+ code = pdfi_array_get_number(ctx, array, offset+i, &num);
+ if (code < 0)
+ return code;
+ out[i] = num;
+ }
+ return 0;
+}
+
+/* Transform a BBox by a matrix (from zmatrix.c/zbbox_transform())*/
+void
+pdfi_bbox_transform(pdf_context *ctx, gs_rect *bbox, gs_matrix *matrix)
+{
+ gs_point aa, az, za, zz;
+ double temp;
+
+ gs_point_transform(bbox->p.x, bbox->p.y, matrix, &aa);
+ gs_point_transform(bbox->p.x, bbox->q.y, matrix, &az);
+ gs_point_transform(bbox->q.x, bbox->p.y, matrix, &za);
+ gs_point_transform(bbox->q.x, bbox->q.y, matrix, &zz);
+
+ if ( aa.x > az.x)
+ temp = aa.x, aa.x = az.x, az.x = temp;
+ if ( za.x > zz.x)
+ temp = za.x, za.x = zz.x, zz.x = temp;
+ if ( za.x < aa.x)
+ aa.x = za.x; /* min */
+ if ( az.x > zz.x)
+ zz.x = az.x; /* max */
+
+ if ( aa.y > az.y)
+ temp = aa.y, aa.y = az.y, az.y = temp;
+ if ( za.y > zz.y)
+ temp = za.y, za.y = zz.y, zz.y = temp;
+ if ( za.y < aa.y)
+ aa.y = za.y; /* min */
+ if ( az.y > zz.y)
+ zz.y = az.y; /* max */
+
+ bbox->p.x = aa.x;
+ bbox->p.y = aa.y;
+ bbox->q.x = zz.x;
+ bbox->q.y = zz.y;
+}
diff --git a/pdf/pdf_array.h b/pdf/pdf_array.h
new file mode 100644
index 00000000..f118737e
--- /dev/null
+++ b/pdf/pdf_array.h
@@ -0,0 +1,45 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* array handling for the PDF interpreter */
+
+#ifndef PDF_ARRAY_FUNCTIONS
+#define PDF_ARRAY_FUNCTIONS
+
+static inline uint64_t pdfi_array_size(pdf_array *a) { return a->size; }
+
+void pdfi_free_array(pdf_obj *o);
+int pdfi_array_alloc(pdf_context *ctx, uint64_t size, pdf_array **a);
+int pdfi_array_from_stack(pdf_context *ctx, uint32_t indirect_num, uint32_t indirect_gen);
+int pdfi_array_get_no_deref(pdf_context *ctx, pdf_array *a, uint64_t index, pdf_obj **o);
+int pdfi_array_get_no_store_R(pdf_context *ctx, pdf_array *a, uint64_t index, pdf_obj **o);
+int pdfi_array_get(pdf_context *ctx, pdf_array *a, uint64_t index, pdf_obj **o);
+int pdfi_array_get_type(pdf_context *ctx, pdf_array *a, uint64_t index, pdf_obj_type t, pdf_obj **o);
+int pdfi_array_get_int(pdf_context *ctx, pdf_array *a, uint64_t index, int64_t *i);
+int pdfi_array_get_number(pdf_context *ctx, pdf_array *a, uint64_t index, double *f);
+int pdfi_array_put(pdf_context *ctx, pdf_array *a, uint64_t index, pdf_obj *o);
+int pdfi_array_put_int(pdf_context *ctx, pdf_array *a, uint64_t index, int64_t val);
+int pdfi_array_put_real(pdf_context *ctx, pdf_array *a, uint64_t index, double val);
+
+bool pdfi_array_known(pdf_context *ctx, pdf_array *a, pdf_obj *, int *index);
+
+void pdfi_normalize_rect(pdf_context *ctx, gs_rect *rect);
+int pdfi_array_to_gs_rect(pdf_context *ctx, pdf_array *array, gs_rect *rect);
+int pdfi_gs_rect_to_array(pdf_context *ctx, gs_rect *rect, pdf_array **new_array);
+int pdfi_array_to_gs_matrix(pdf_context *ctx, pdf_array *array, gs_matrix *matrix);
+int pdfi_array_to_num_array(pdf_context *ctx, pdf_array *array, double *out, int start, int size);
+void pdfi_bbox_transform(pdf_context *ctx, gs_rect *bbox, gs_matrix *matrix);
+
+#endif
diff --git a/pdf/pdf_check.c b/pdf/pdf_check.c
new file mode 100644
index 00000000..13d974cb
--- /dev/null
+++ b/pdf/pdf_check.c
@@ -0,0 +1,1190 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Checks for transparency and spots for the PDF interpreter */
+
+#include "pdf_int.h"
+#include "pdf_stack.h"
+#include "pdf_page.h"
+#include "pdf_file.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_loop_detect.h"
+#include "pdf_colour.h"
+#include "pdf_trans.h"
+#include "pdf_gstate.h"
+#include "pdf_misc.h"
+#include "pdf_check.h"
+#include "pdf_device.h"
+#include "gspaint.h" /* For gs_erasepage() */
+
+/* For performance and resource reasons we do not want to install the transparency blending
+ * compositor unless we need it. Similarly, if a device handles spot colours it can minimise
+ * memory usage if it knows ahead of time how many spot colours there will be.
+ *
+ * The PDF interpreter written in PostScript performed these as two separate tasks, on opening
+ * a PDF file it would count spot colour usage and then for each page it would chek if the page
+ * used any transparency. The code below is used to check for both transparency and spot colours.
+ * If the int pointer to num_spots is NULL then we aren't interested in spot colours (not supported
+ * by the device), if the int pointer to transparent is NULL then we aren't interested in transparency
+ * (-dNOTRANSPARENCY is set).
+ *
+ * Currently the code is run when we open the PDF file, the existence of transparency on any given
+ * page is recorded in a bit array for later use. If it turns out that checking every page when we
+ * open the file is a performance burden then we could do it on a per-page basis instead. NB if
+ * the device supports spot colours then we do need to scan the file before starting any page.
+ *
+ * The technique is fairly straight-forward, we start with each page, and open its Resources
+ * dictionary, we then check by type each possible resource. Some resources (eg Pattern, XObject)
+ * can themselves contain Resources, in which case we recursively check that dictionary. Note; not
+ * all Resource types need to be checked for both transparency and spot colours, some types can
+ * only contain one or the other.
+ *
+ * Routines with the name pdfi_check_xxx_dict are intended to check a Resource dictionary entry, this
+ * will be a dictioanry of names and values, where the values are objects of the given Resource type.
+ *
+ */
+
+/* Structure for keeping track of resources as they are being checked */
+/* CheckedResources is a bit of a hack, for the file Bug697655.pdf. That file has many (unused)
+ * XObjects which use Resources and the Resources use other XObjects and so on nested
+ * very deeply. This takes *hours* to check. Ghostscript gets around this because it
+ * stores all the objects (which we don't want to do because its wasteful) and checking
+ * to see if its already tested a given resource for spots/transparency.
+ * This is a temporary allocation, big enough to hold all the objects in the file (1 per bit)
+ * each time we have fully checked a resource we add it here, when checking a resoruce we
+ * first check this list to see if its already been checked, in which case we can skip
+ * it. When done we release the memory.
+ */
+typedef struct {
+ bool transparent;
+ bool has_overprint; /* Does it have OP or op in an ExtGState? */
+ pdf_dict *spot_dict;
+ uint32_t size;
+ byte *CheckedResources;
+} pdfi_check_tracker_t;
+
+static int pdfi_check_Resources(pdf_context *ctx, pdf_dict *Resources_dict, pdf_dict *page_dict, pdfi_check_tracker_t *tracker);
+
+static inline bool resource_is_checked(pdfi_check_tracker_t *tracker, pdf_obj *o)
+{
+ uint32_t byte_offset;
+ byte bit_offset;
+
+ if(tracker->CheckedResources == NULL)
+ return 0;
+
+ /* objects with object number 0 are directly defined, we can't
+ * store those so just return immediately
+ */
+ if (o->object_num > 0 && (o->object_num >> 3) < tracker->size) {
+ /* CheckedResources is a byte array, each byte represents
+ * 8 objects. So the object number / 8 is the byte offset
+ * into the array, and then object number % 8 is the bit
+ * within that byte that we want.
+ */
+ bit_offset = 0x01 << (o->object_num % 8);
+ byte_offset = o->object_num >> 3;
+
+ /* If its already set, then return that. */
+ if (tracker->CheckedResources[byte_offset] & bit_offset)
+ return true;
+ else
+ /* Otherwise set it for futre reference */
+ tracker->CheckedResources[byte_offset] |= bit_offset;
+ }
+ return false;
+}
+
+
+static int
+pdfi_check_free_tracker(pdf_context *ctx, pdfi_check_tracker_t *tracker)
+{
+ gs_free_object(ctx->memory, tracker->CheckedResources, "pdfi_check_free_tracker(flags)");
+ pdfi_countdown(tracker->spot_dict);
+ memset(tracker, 0, sizeof(*tracker));
+ return 0;
+}
+
+static int
+pdfi_check_init_tracker(pdf_context *ctx, pdfi_check_tracker_t *tracker)
+{
+ int code = 0;
+
+ memset(tracker, 0, sizeof(*tracker));
+
+ tracker->size = (ctx->xref_table->xref_size + 7) / 8;
+ tracker->CheckedResources = gs_alloc_bytes(ctx->memory, tracker->size,
+ "pdfi_check_init_tracker(flags)");
+ if (tracker->CheckedResources == NULL)
+ return_error(gs_error_VMerror);
+
+ memset(tracker->CheckedResources, 0x00, tracker->size);
+
+ if (ctx->device_state.spot_capable || ctx->args.overprint_control == PDF_OVERPRINT_SIMULATE) {
+ code = pdfi_dict_alloc(ctx, 32, &tracker->spot_dict);
+ if (code < 0)
+ goto cleanup;
+ pdfi_countup(tracker->spot_dict);
+ }
+
+ return 0;
+
+ cleanup:
+ pdfi_check_free_tracker(ctx, tracker);
+ return code;
+}
+
+/*
+ * Check the Resources dictionary ColorSpace entry. pdfi_check_ColorSpace_for_spots is defined
+ * in pdf_colour.c
+ */
+static int pdfi_check_ColorSpace_dict(pdf_context *ctx, pdf_dict *cspace_dict,
+ pdf_dict *page_dict, pdfi_check_tracker_t *tracker)
+{
+ int code;
+ uint64_t i, index;
+ pdf_obj *Key = NULL, *Value = NULL;
+
+ if (resource_is_checked(tracker, (pdf_obj *)cspace_dict))
+ return 0;
+
+ if (pdfi_dict_entries(cspace_dict) > 0) {
+ code = pdfi_loop_detector_mark(ctx); /* Mark the start of the ColorSpace dictionary loop */
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_first(ctx, cspace_dict, &Key, &Value, &index);
+ if (code < 0)
+ goto error1;
+
+ i = 1;
+ do {
+ code = pdfi_check_ColorSpace_for_spots(ctx, Value, cspace_dict, page_dict, tracker->spot_dict);
+ if (code < 0)
+ goto error2;
+
+ pdfi_countdown(Key);
+ Key = NULL;
+ pdfi_countdown(Value);
+ Value = NULL;
+
+ (void)pdfi_loop_detector_cleartomark(ctx); /* Clear to the mark for the Shading dictionary loop */
+
+ code = pdfi_loop_detector_mark(ctx); /* Mark the new start of the Shading dictionary loop */
+ if (code < 0)
+ goto error1;
+
+ do {
+ if (i++ >= pdfi_dict_entries(cspace_dict)) {
+ code = 0;
+ goto transparency_exit;
+ }
+
+ code = pdfi_dict_next(ctx, cspace_dict, &Key, &Value, &index);
+ if (code == 0 && Value->type == PDF_ARRAY)
+ break;
+ pdfi_countdown(Key);
+ Key = NULL;
+ pdfi_countdown(Value);
+ Value = NULL;
+ } while(1);
+ }while (1);
+ }
+ return 0;
+
+transparency_exit:
+error2:
+ pdfi_countdown(Key);
+ pdfi_countdown(Value);
+
+error1:
+ (void)pdfi_loop_detector_cleartomark(ctx); /* Clear to the mark for the current resource loop */
+ return code;
+}
+
+/*
+ * Process an individual Shading dictionary to see if it contains a ColorSpace with a spot colour
+ */
+static int pdfi_check_Shading(pdf_context *ctx, pdf_obj *shading,
+ pdf_dict *page_dict, pdfi_check_tracker_t *tracker)
+{
+ int code;
+ pdf_obj *o = NULL;
+ pdf_dict *shading_dict = NULL;
+
+ if (resource_is_checked(tracker, shading))
+ return 0;
+
+ code = pdfi_dict_from_obj(ctx, shading, &shading_dict);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_knownget(ctx, shading_dict, "ColorSpace", (pdf_obj **)&o);
+ if (code > 0) {
+ code = pdfi_check_ColorSpace_for_spots(ctx, o, shading_dict, page_dict, tracker->spot_dict);
+ pdfi_countdown(o);
+ return code;
+ }
+ return 0;
+}
+
+/*
+ * Check the Resources dictionary Shading entry.
+ */
+static int pdfi_check_Shading_dict(pdf_context *ctx, pdf_dict *shading_dict,
+ pdf_dict *page_dict, pdfi_check_tracker_t *tracker)
+{
+ int code;
+ uint64_t i, index;
+ pdf_obj *Key = NULL, *Value = NULL;
+
+ if (resource_is_checked(tracker, (pdf_obj *)shading_dict))
+ return 0;
+
+ if (pdfi_dict_entries(shading_dict) > 0) {
+ code = pdfi_loop_detector_mark(ctx); /* Mark the start of the Shading dictionary loop */
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_first(ctx, shading_dict, &Key, &Value, &index);
+ if (code < 0 || !(Value->type == PDF_DICT || Value->type == PDF_STREAM))
+ goto error1;
+
+ i = 1;
+ do {
+ code = pdfi_check_Shading(ctx, Value, page_dict, tracker);
+ if (code < 0)
+ goto error2;
+
+ pdfi_countdown(Key);
+ Key = NULL;
+ pdfi_countdown(Value);
+ Value = NULL;
+
+ (void)pdfi_loop_detector_cleartomark(ctx); /* Clear to the mark for the Shading dictionary loop */
+
+ code = pdfi_loop_detector_mark(ctx); /* Mark the new start of the Shading dictionary loop */
+ if (code < 0)
+ goto error1;
+
+ do {
+ if (i++ >= pdfi_dict_entries(shading_dict)) {
+ code = 0;
+ goto transparency_exit;
+ }
+
+ code = pdfi_dict_next(ctx, shading_dict, &Key, &Value, &index);
+ if (code == 0 && Value->type == PDF_DICT)
+ break;
+ pdfi_countdown(Key);
+ Key = NULL;
+ pdfi_countdown(Value);
+ Value = NULL;
+ } while(1);
+ }while (1);
+ }
+ return 0;
+
+transparency_exit:
+error2:
+ pdfi_countdown(Key);
+ pdfi_countdown(Value);
+
+error1:
+ (void)pdfi_loop_detector_cleartomark(ctx); /* Clear to the mark for the current resource loop */
+ return code;
+}
+
+/*
+ * This routine checks an XObject to see if it contains any spot
+ * colour definitions, or transparency usage.
+ */
+static int pdfi_check_XObject(pdf_context *ctx, pdf_dict *xobject, pdf_dict *page_dict,
+ pdfi_check_tracker_t *tracker)
+{
+ int code = 0;
+ pdf_name *n = NULL;
+ bool known = false;
+ double f;
+
+ if (resource_is_checked(tracker, (pdf_obj *)xobject))
+ return 0;
+
+ code = pdfi_dict_get_type(ctx, xobject, "Subtype", PDF_NAME, (pdf_obj **)&n);
+ if (code >= 0) {
+ if (pdfi_name_is((const pdf_name *)n, "Image")) {
+ pdf_obj *CS = NULL;
+
+ pdfi_countdown(n);
+ n = NULL;
+ code = pdfi_dict_known(ctx, xobject, "SMask", &known);
+ if (code >= 0) {
+ if (known == true) {
+ tracker->transparent = true;
+ if (tracker->spot_dict == NULL)
+ goto transparency_exit;
+ }
+ code = pdfi_dict_knownget_number(ctx, xobject, "SMaskInData", &f);
+ if (code > 0) {
+ code = 0;
+ if (f != 0.0)
+ tracker->transparent = true;
+ if (tracker->spot_dict == NULL)
+ goto transparency_exit;
+ }
+ /* Check the image dictionary for a ColorSpace entry, if we are checking spot names */
+ if (tracker->spot_dict) {
+ code = pdfi_dict_knownget(ctx, xobject, "ColorSpace", (pdf_obj **)&CS);
+ if (code > 0) {
+ /* We don't care if there's an error here, it'll be picked up if we use the ColorSpace later */
+ (void)pdfi_check_ColorSpace_for_spots(ctx, CS, xobject, page_dict, tracker->spot_dict);
+ pdfi_countdown(CS);
+ }
+ }
+ }
+ } else {
+ if (pdfi_name_is((const pdf_name *)n, "Form")) {
+ pdf_dict *group_dict = NULL, *resource_dict = NULL;
+ pdf_obj *CS = NULL;
+
+ pdfi_countdown(n);
+ code = pdfi_dict_knownget_type(ctx, xobject, "Group", PDF_DICT, (pdf_obj **)&group_dict);
+ if (code > 0) {
+ tracker->transparent = true;
+ if (tracker->spot_dict == NULL) {
+ pdfi_countdown(group_dict);
+ goto transparency_exit;
+ }
+
+ /* Start a new loop detector group to avoid this being detected in the Resources check below */
+ code = pdfi_loop_detector_mark(ctx); /* Mark the start of the XObject dictionary loop */
+ if (code == 0) {
+ code = pdfi_dict_knownget(ctx, group_dict, "CS", &CS);
+ if (code > 0)
+ /* We don't care if there's an error here, it'll be picked up if we use the ColorSpace later */
+ (void)pdfi_check_ColorSpace_for_spots(ctx, CS, group_dict, page_dict, tracker->spot_dict);
+ (void)pdfi_loop_detector_cleartomark(ctx); /* Clear to the mark for the XObject dictionary loop */
+ }
+ pdfi_countdown(group_dict);
+ pdfi_countdown(CS);
+ }
+
+ code = pdfi_dict_knownget_type(ctx, xobject, "Resources", PDF_DICT, (pdf_obj **)&resource_dict);
+ if (code > 0) {
+ code = pdfi_check_Resources(ctx, resource_dict, page_dict, tracker);
+ pdfi_countdown(resource_dict);
+ if (code < 0)
+ goto transparency_exit;
+ }
+ } else
+ pdfi_countdown(n);
+ }
+ }
+
+ return 0;
+
+transparency_exit:
+ return code;
+}
+
+/*
+ * Check the Resources dictionary XObject entry.
+ */
+static int pdfi_check_XObject_dict(pdf_context *ctx, pdf_dict *xobject_dict, pdf_dict *page_dict,
+ pdfi_check_tracker_t *tracker)
+{
+ int code;
+ uint64_t i, index;
+ pdf_obj *Key = NULL, *Value = NULL;
+ pdf_dict *Value_dict = NULL;
+
+ if (resource_is_checked(tracker, (pdf_obj *)xobject_dict))
+ return 0;
+
+ if (pdfi_dict_entries(xobject_dict) > 0) {
+ code = pdfi_loop_detector_mark(ctx); /* Mark the start of the XObject dictionary loop */
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_first(ctx, xobject_dict, &Key, &Value, &index);
+ if (code < 0)
+ goto error_exit;
+ if (Value->type != PDF_STREAM)
+ goto error_exit;
+
+ i = 1;
+ do {
+ code = pdfi_dict_from_obj(ctx, Value, &Value_dict);
+ if (code < 0)
+ goto error_exit;
+
+ code = pdfi_check_XObject(ctx, Value_dict, page_dict, tracker);
+ if (code < 0)
+ goto error_exit;
+
+ (void)pdfi_loop_detector_cleartomark(ctx); /* Clear to the mark for the XObject dictionary loop */
+
+ code = pdfi_loop_detector_mark(ctx); /* Mark the new start of the XObject dictionary loop */
+ if (code < 0)
+ goto error_exit;
+
+ pdfi_countdown(Key);
+ Key = NULL;
+ pdfi_countdown(Value);
+ Value = NULL;
+ Value_dict = NULL;
+
+ do {
+ if (i++ >= pdfi_dict_entries(xobject_dict)) {
+ code = 0;
+ goto transparency_exit;
+ }
+
+ code = pdfi_dict_next(ctx, xobject_dict, &Key, &Value, &index);
+ if (code == 0 && Value->type == PDF_STREAM)
+ break;
+ pdfi_countdown(Key);
+ Key = NULL;
+ pdfi_countdown(Value);
+ Value = NULL;
+ } while(1);
+ }while(1);
+ }
+ return 0;
+
+transparency_exit:
+error_exit:
+ pdfi_countdown(Key);
+ pdfi_countdown(Value);
+ (void)pdfi_loop_detector_cleartomark(ctx); /* Clear to the mark for the current resource loop */
+ return code;
+}
+
+/*
+ * This routine checks an ExtGState dictionary to see if it contains transparency or OP
+ */
+static int pdfi_check_ExtGState(pdf_context *ctx, pdf_dict *extgstate_dict, pdf_dict *page_dict,
+ pdfi_check_tracker_t *tracker)
+{
+ int code;
+ pdf_obj *o = NULL;
+ double f;
+ bool overprint;
+
+ if (resource_is_checked(tracker, (pdf_obj *)extgstate_dict))
+ return 0;
+
+ if (pdfi_dict_entries(extgstate_dict) > 0) {
+ /* See if /OP or /op is true */
+ code = pdfi_dict_get_bool(ctx, extgstate_dict, "OP", &overprint);
+ if (code == 0 && overprint)
+ tracker->has_overprint = true;
+ code = pdfi_dict_get_bool(ctx, extgstate_dict, "op", &overprint);
+ if (code == 0 && overprint)
+ tracker->has_overprint = true;
+
+ /* Check SMask */
+ code = pdfi_dict_knownget(ctx, extgstate_dict, "SMask", &o);
+ if (code > 0) {
+ if (o->type == PDF_NAME) {
+ if (!pdfi_name_is((pdf_name *)o, "None")) {
+ pdfi_countdown(o);
+ tracker->transparent = true;
+ return 0;
+ }
+ } else {
+ if (o->type == PDF_DICT) {
+ pdf_obj *G = NULL;
+
+ tracker->transparent = true;
+
+ if (tracker->spot_dict != NULL) {
+ /* Check if the SMask has a /G (Group) */
+ code = pdfi_dict_knownget(ctx, (pdf_dict *)o, "G", &G);
+ if (code > 0) {
+ code = pdfi_check_XObject(ctx, (pdf_dict *)G, page_dict,
+ tracker);
+ pdfi_countdown(G);
+ }
+ }
+ pdfi_countdown(o);
+ return code;
+ }
+ }
+ }
+ pdfi_countdown(o);
+ o = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, extgstate_dict, "BM", PDF_NAME, &o);
+ if (code > 0) {
+ if (!pdfi_name_is((pdf_name *)o, "Normal")) {
+ if (!pdfi_name_is((pdf_name *)o, "Compatible")) {
+ pdfi_countdown(o);
+ tracker->transparent = true;
+ return 0;
+ }
+ }
+ }
+ pdfi_countdown(o);
+ o = NULL;
+
+ code = pdfi_dict_knownget_number(ctx, extgstate_dict, "CA", &f);
+ if (code > 0) {
+ if (f != 1.0) {
+ tracker->transparent = true;
+ return 0;
+ }
+ }
+
+ code = pdfi_dict_knownget_number(ctx, extgstate_dict, "ca", &f);
+ if (code > 0) {
+ if (f != 1.0) {
+ tracker->transparent = true;
+ return 0;
+ }
+ }
+
+ }
+ return 0;
+}
+
+/*
+ * Check the Resources dictionary ExtGState entry.
+ */
+static int pdfi_check_ExtGState_dict(pdf_context *ctx, pdf_dict *extgstate_dict, pdf_dict *page_dict,
+ pdfi_check_tracker_t *tracker)
+{
+ int code;
+ uint64_t i, index;
+ pdf_obj *Key = NULL, *Value = NULL;
+
+ if (resource_is_checked(tracker, (pdf_obj *)extgstate_dict))
+ return 0;
+
+ if (pdfi_dict_entries(extgstate_dict) > 0) {
+ code = pdfi_loop_detector_mark(ctx); /* Mark the start of the ColorSpace dictionary loop */
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_first(ctx, extgstate_dict, &Key, &Value, &index);
+ if (code < 0)
+ goto error1;
+
+ i = 1;
+ do {
+
+ (void)pdfi_check_ExtGState(ctx, (pdf_dict *)Value, page_dict, tracker);
+ if (tracker->transparent == true && tracker->spot_dict == NULL)
+ goto transparency_exit;
+
+ pdfi_countdown(Key);
+ Key = NULL;
+ pdfi_countdown(Value);
+ Value = NULL;
+
+ (void)pdfi_loop_detector_cleartomark(ctx); /* Clear to the mark for the ExtGState dictionary loop */
+
+ code = pdfi_loop_detector_mark(ctx); /* Mark the new start of the ExtGState dictionary loop */
+ if (code < 0)
+ goto error1;
+
+ do {
+ if (i++ >= pdfi_dict_entries(extgstate_dict)) {
+ code = 0;
+ goto transparency_exit;
+ }
+
+ code = pdfi_dict_next(ctx, extgstate_dict, &Key, &Value, &index);
+ if (code == 0 && Value->type == PDF_DICT)
+ break;
+ pdfi_countdown(Key);
+ Key = NULL;
+ pdfi_countdown(Value);
+ Value = NULL;
+ } while(1);
+ }while (1);
+ }
+ return 0;
+
+transparency_exit:
+ pdfi_countdown(Key);
+ pdfi_countdown(Value);
+
+error1:
+ (void)pdfi_loop_detector_cleartomark(ctx); /* Clear to the mark for the current resource loop */
+ return code;
+}
+
+/*
+ * This routine checks a Pattern dictionary to see if it contains any spot
+ * colour definitions, or transparency usage.
+ */
+static int pdfi_check_Pattern(pdf_context *ctx, pdf_dict *pattern, pdf_dict *page_dict,
+ pdfi_check_tracker_t *tracker)
+{
+ int code = 0;
+ pdf_obj *o = NULL;
+
+ if (resource_is_checked(tracker, (pdf_obj *)pattern))
+ return 0;
+
+ if (tracker->spot_dict != NULL) {
+ code = pdfi_dict_knownget(ctx, pattern, "Shading", &o);
+ if (code > 0)
+ (void)pdfi_check_Shading(ctx, o, page_dict, tracker);
+ pdfi_countdown(o);
+ o = NULL;
+ }
+
+ code = pdfi_dict_knownget_type(ctx, pattern, "Resources", PDF_DICT, &o);
+ if (code > 0)
+ (void)pdfi_check_Resources(ctx, (pdf_dict *)o, page_dict, tracker);
+ pdfi_countdown(o);
+ o = NULL;
+ if (tracker->transparent == true && tracker->spot_dict == NULL)
+ goto transparency_exit;
+
+ code = pdfi_dict_knownget_type(ctx, pattern, "ExtGState", PDF_DICT, &o);
+ if (code > 0)
+ (void)pdfi_check_ExtGState(ctx, (pdf_dict *)o, page_dict, tracker);
+ pdfi_countdown(o);
+ o = NULL;
+
+transparency_exit:
+ return 0;
+}
+
+/*
+ * This routine checks a Pattern dictionary for transparency.
+ */
+int pdfi_check_Pattern_transparency(pdf_context *ctx, pdf_dict *pattern, pdf_dict *page_dict,
+ bool *transparent)
+{
+ int code;
+ pdfi_check_tracker_t tracker = {0, 0, NULL, 0, NULL};
+
+ /* NOTE: We use a "null" tracker that won't do any optimization to prevent
+ * checking the same resource twice.
+ * This means we don't get the optimization, but we also don't have the overhead
+ * of setting it up.
+ * If we do want the optimization, call pdfi_check_init_tracker() and
+ * pdfi_check_free_tracker() as in pdfi_check_page(), below.
+ */
+ code = pdfi_check_Pattern(ctx, pattern, page_dict, &tracker);
+ if (code == 0)
+ *transparent = tracker.transparent;
+ else
+ *transparent = false;
+ return code;
+}
+
+/*
+ * Check the Resources dictionary Pattern entry.
+ */
+static int pdfi_check_Pattern_dict(pdf_context *ctx, pdf_dict *pattern_dict, pdf_dict *page_dict,
+ pdfi_check_tracker_t *tracker)
+{
+ int code;
+ uint64_t i, index;
+ pdf_obj *Key = NULL, *Value = NULL;
+ pdf_dict *instance_dict = NULL;
+
+ if (resource_is_checked(tracker, (pdf_obj *)pattern_dict))
+ return 0;
+
+ if (pdfi_dict_entries(pattern_dict) > 0) {
+ code = pdfi_loop_detector_mark(ctx); /* Mark the start of the Pattern dictionary loop */
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_first(ctx, pattern_dict, &Key, &Value, &index);
+ if (code < 0)
+ goto error1;
+
+ if(Value->type != PDF_DICT && Value->type != PDF_STREAM)
+ goto transparency_exit;
+
+ i = 1;
+ do {
+ code = pdfi_dict_from_obj(ctx, Value, &instance_dict);
+ if (code < 0)
+ goto transparency_exit;
+
+ code = pdfi_check_Pattern(ctx, instance_dict, page_dict, tracker);
+ if (code < 0)
+ goto transparency_exit;
+
+ pdfi_countdown(Key);
+ Key = NULL;
+ pdfi_countdown(Value);
+ instance_dict = NULL;
+ Value = NULL;
+ (void)pdfi_loop_detector_cleartomark(ctx); /* Clear to the mark for the Shading dictionary loop */
+
+ code = pdfi_loop_detector_mark(ctx); /* Mark the new start of the Shading dictionary loop */
+ if (code < 0)
+ goto error1;
+
+ do {
+ if (i++ >= pdfi_dict_entries(pattern_dict)) {
+ code = 0;
+ goto transparency_exit;
+ }
+
+ code = pdfi_dict_next(ctx, pattern_dict, &Key, &Value, &index);
+ if (code == 0 && (Value->type == PDF_DICT || Value->type == PDF_STREAM))
+ break;
+ pdfi_countdown(Key);
+ Key = NULL;
+ pdfi_countdown(Value);
+ Value = NULL;
+ } while(1);
+ }while (1);
+ }
+ return 0;
+
+transparency_exit:
+ pdfi_countdown(Key);
+ pdfi_countdown(Value);
+ pdfi_countdown(instance_dict);
+
+error1:
+ (void)pdfi_loop_detector_cleartomark(ctx); /* Clear to the mark for the current resource loop */
+ return code;
+}
+
+/*
+ * This routine checks a Font dictionary to see if it contains any spot
+ * colour definitions, or transparency usage.
+ */
+static int pdfi_check_Font(pdf_context *ctx, pdf_dict *font, pdf_dict *page_dict,
+ pdfi_check_tracker_t *tracker)
+{
+ int code = 0;
+ pdf_obj *o = NULL;
+
+ if (resource_is_checked(tracker, (pdf_obj *)font))
+ return 0;
+
+ if (font->type != PDF_DICT)
+ return_error(gs_error_typecheck);
+
+ code = pdfi_dict_knownget_type(ctx, font, "Subtype", PDF_NAME, &o);
+ if (code > 0) {
+ if (pdfi_name_is((pdf_name *)o, "Type3")) {
+ pdfi_countdown(o);
+ o = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, font, "Resources", PDF_DICT, &o);
+ if (code > 0)
+ (void)pdfi_check_Resources(ctx, (pdf_dict *)o, page_dict, tracker);
+ }
+ }
+ pdfi_countdown(o);
+ o = NULL;
+
+ return 0;
+}
+
+/*
+ * Check the Resources dictionary Font entry.
+ */
+static int pdfi_check_Font_dict(pdf_context *ctx, pdf_dict *font_dict, pdf_dict *page_dict,
+ pdfi_check_tracker_t *tracker)
+{
+ int code;
+ uint64_t i, index;
+ pdf_obj *Key = NULL, *Value = NULL;
+
+ if (resource_is_checked(tracker, (pdf_obj *)font_dict))
+ return 0;
+
+ if (pdfi_dict_entries(font_dict) > 0) {
+ code = pdfi_loop_detector_mark(ctx); /* Mark the start of the Font dictionary loop */
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_first(ctx, font_dict, &Key, &Value, &index);
+ if (code < 0)
+ goto error1;
+
+ i = 1;
+ do {
+ code = pdfi_check_Font(ctx, (pdf_dict *)Value, page_dict, tracker);
+
+ pdfi_countdown(Key);
+ Key = NULL;
+ pdfi_countdown(Value);
+ Value = NULL;
+
+ (void)pdfi_loop_detector_cleartomark(ctx); /* Clear to the mark for the Font dictionary loop */
+
+ code = pdfi_loop_detector_mark(ctx); /* Mark the new start of the Font dictionary loop */
+ if (code < 0)
+ goto error1;
+
+ do {
+ if (i++ >= pdfi_dict_entries(font_dict)) {
+ code = 0;
+ goto transparency_exit;
+ }
+
+ code = pdfi_dict_next(ctx, font_dict, &Key, &Value, &index);
+ if (code == 0 && Value->type == PDF_DICT)
+ break;
+ pdfi_countdown(Key);
+ Key = NULL;
+ pdfi_countdown(Value);
+ Value = NULL;
+ } while(1);
+ }while (1);
+ }
+ return 0;
+
+transparency_exit:
+ pdfi_countdown(Key);
+ pdfi_countdown(Value);
+
+error1:
+ (void)pdfi_loop_detector_cleartomark(ctx); /* Clear to the mark for the current resource loop */
+ return code;
+}
+
+static int pdfi_check_Resources(pdf_context *ctx, pdf_dict *Resources_dict,
+ pdf_dict *page_dict, pdfi_check_tracker_t *tracker)
+{
+ int code;
+ pdf_obj *d = NULL;
+
+ if (resource_is_checked(tracker, (pdf_obj *)Resources_dict))
+ return 0;
+
+ /* First up, check any colour spaces, for new spot colours.
+ * We only do this if asked because its expensive. spot_dict being NULL
+ * means we aren't interested in spot colours (not a DeviceN or Separation device)
+ */
+ if (tracker->spot_dict != NULL) {
+ code = pdfi_dict_knownget_type(ctx, Resources_dict, "ColorSpace", PDF_DICT, &d);
+ if (code > 0)
+ (void)pdfi_check_ColorSpace_dict(ctx, (pdf_dict *)d, page_dict, tracker);
+
+ pdfi_countdown(d);
+ d = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, Resources_dict, "Shading", PDF_DICT, &d);
+ if (code > 0)
+ (void)pdfi_check_Shading_dict(ctx, (pdf_dict *)d, page_dict, tracker);
+ pdfi_countdown(d);
+ d = NULL;
+ }
+
+ code = pdfi_dict_knownget_type(ctx, Resources_dict, "XObject", PDF_DICT, &d);
+ if (code > 0)
+ (void)pdfi_check_XObject_dict(ctx, (pdf_dict *)d, page_dict, tracker);
+ pdfi_countdown(d);
+ d = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, Resources_dict, "Pattern", PDF_DICT, &d);
+ if (code > 0)
+ (void)pdfi_check_Pattern_dict(ctx, (pdf_dict *)d, page_dict, tracker);
+ pdfi_countdown(d);
+ d = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, Resources_dict, "Font", PDF_DICT, &d);
+ if (code > 0)
+ (void)pdfi_check_Font_dict(ctx, (pdf_dict *)d, page_dict, tracker);
+ /* From this point onwards, if we detect transparency (or have already detected it) we
+ * can exit, we have already counted up any spot colours.
+ */
+ pdfi_countdown(d);
+ d = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, Resources_dict, "ExtGState", PDF_DICT, &d);
+ if (code > 0)
+ (void)pdfi_check_ExtGState_dict(ctx, (pdf_dict *)d, page_dict, tracker);
+ pdfi_countdown(d);
+ d = NULL;
+
+ return 0;
+}
+
+static int pdfi_check_annot_for_transparency(pdf_context *ctx, pdf_dict *annot, pdf_dict *page_dict,
+ pdfi_check_tracker_t *tracker)
+{
+ int code;
+ pdf_name *n;
+ pdf_obj *N = NULL;
+ pdf_dict *ap = NULL;
+ pdf_dict *Resources = NULL;
+ double f;
+
+ if (resource_is_checked(tracker, (pdf_obj *)annot))
+ return 0;
+
+ /* Check #1 Does the (Normal) Appearnce stream use any Resources which include transparency.
+ * We check this first, because this also checks for spot colour spaces. Once we've done that we
+ * can exit the checks as soon as we detect transparency.
+ */
+ code = pdfi_dict_knownget_type(ctx, annot, "AP", PDF_DICT, (pdf_obj **)&ap);
+ if (code > 0)
+ {
+ /* Fetch without resolving indirect ref because pdfmark wants it that way later */
+ code = pdfi_dict_get_no_store_R(ctx, ap, "N", (pdf_obj **)&N);
+ if (code >= 0) {
+ pdf_dict *dict = NULL;
+
+ code = pdfi_dict_from_obj(ctx, N, &dict);
+ if (code == 0)
+ code = pdfi_dict_knownget_type(ctx, dict, "Resources", PDF_DICT, (pdf_obj **)&Resources);
+ if (code > 0)
+ code = pdfi_check_Resources(ctx, (pdf_dict *)Resources, page_dict, tracker);
+ }
+ if (code == gs_error_undefined)
+ code = 0;
+ }
+ pdfi_countdown(ap);
+ pdfi_countdown(N);
+ pdfi_countdown(Resources);
+
+ if (code < 0)
+ return code;
+ /* We've checked the Resources, and nothing else in an annotation can define spot colours, so
+ * if we detected transparency in the Resources we need not check further.
+ */
+ if (tracker->transparent == true)
+ return 0;
+
+ code = pdfi_dict_get_type(ctx, annot, "Subtype", PDF_NAME, (pdf_obj **)&n);
+ if (code < 0) {
+ if (ctx->args.pdfstoponerror)
+ return code;
+ } else {
+ /* Check #2, Highlight annotations are always preformed with transparency */
+ if (pdfi_name_is((const pdf_name *)n, "Highlight")) {
+ pdfi_countdown(n);
+ tracker->transparent = true;
+ return 0;
+ }
+ pdfi_countdown(n);
+ n = NULL;
+
+ /* Check #3 Blend Mode (BM) not being 'Normal' or 'Compatible' */
+ code = pdfi_dict_knownget_type(ctx, annot, "BM", PDF_NAME, (pdf_obj **)&n);
+ if (code > 0) {
+ if (!pdfi_name_is((const pdf_name *)n, "Normal")) {
+ if (!pdfi_name_is((const pdf_name *)n, "Compatible")) {
+ pdfi_countdown(n);
+ tracker->transparent = true;
+ return 0;
+ }
+ }
+ code = 0;
+ }
+ pdfi_countdown(n);
+ if (code < 0)
+ return code;
+
+ /* Check #4 stroke constant alpha (CA) is not 1 (100% opaque) */
+ code = pdfi_dict_knownget_number(ctx, annot, "CA", &f);
+ if (code > 0) {
+ if (f != 1.0) {
+ tracker->transparent = true;
+ return 0;
+ }
+ }
+ if (code < 0)
+ return code;
+
+ /* Check #5 non-stroke constant alpha (ca) is not 1 (100% opaque) */
+ code = pdfi_dict_knownget_number(ctx, annot, "ca", &f);
+ if (code > 0) {
+ if (f != 1.0) {
+ tracker->transparent = true;
+ return 0;
+ }
+ }
+ if (code < 0)
+ return code;
+ }
+
+ return 0;
+}
+
+static int pdfi_check_Annots_for_transparency(pdf_context *ctx, pdf_array *annots_array,
+ pdf_dict *page_dict, pdfi_check_tracker_t *tracker)
+{
+ int i, code = 0;
+ pdf_dict *annot = NULL;
+
+ if (resource_is_checked(tracker, (pdf_obj *)annots_array))
+ return 0;
+
+ for (i=0; i < pdfi_array_size(annots_array); i++) {
+ code = pdfi_array_get_type(ctx, annots_array, (uint64_t)i, PDF_DICT, (pdf_obj **)&annot);
+ if (code >= 0) {
+ code = pdfi_check_annot_for_transparency(ctx, annot, page_dict, tracker);
+ if (code < 0 && ctx->args.pdfstoponerror)
+ goto exit;
+
+ /* If we've found transparency, and don't need to continue checkign for spot colours
+ * just exit as fast as possible.
+ */
+ if (tracker->transparent == true && tracker->spot_dict == NULL)
+ goto exit;
+
+ pdfi_countdown(annot);
+ annot = NULL;
+ }
+ if (code < 0 && ctx->args.pdfstoponerror)
+ goto exit;
+ code = 0;
+ }
+exit:
+ pdfi_countdown(annot);
+ return code;
+}
+
+/* Check for transparency and spots on page.
+ *
+ * Sets ctx->spot_capable_device
+ * Builds a dictionary of the unique spot names in spot_dict
+ * Set 'transparent' to true if there is transparency on the page
+ *
+ * From the original PDF interpreter written in PostScript:
+ * Note: we deliberately don't check to see whether a Group is defined,
+ * because Adobe Illustrator 10 (and possibly other applications) define
+ * a page-level group whether transparency is actually used or not.
+ * Ignoring the presence of Group is justified because, in the absence
+ * of any other transparency features, they have no effect.
+ */
+static int pdfi_check_page_inner(pdf_context *ctx, pdf_dict *page_dict,
+ pdfi_check_tracker_t *tracker)
+{
+ int code;
+ pdf_dict *Resources = NULL;
+ pdf_array *Annots = NULL;
+ pdf_dict *Group = NULL;
+ pdf_obj *CS = NULL;
+
+ tracker->transparent = false;
+
+ /* Check if the page dictionary has a page Group entry (for spots).
+ * Page group should mean the page has transparency but we ignore it for the purposes
+ * of transparency detection. See above.
+ */
+ if (tracker->spot_dict) {
+ code = pdfi_dict_knownget_type(ctx, page_dict, "Group", PDF_DICT, (pdf_obj **)&Group);
+ if (code > 0) {
+ /* If Group has a ColorSpace (CS), then check it for spot colours */
+ code = pdfi_dict_knownget(ctx, Group, "CS", &CS);
+ if (code > 0)
+ code = pdfi_check_ColorSpace_for_spots(ctx, CS, Group, page_dict, tracker->spot_dict);
+ if (code < 0 && ctx->args.pdfstoponerror)
+ goto exit;
+ }
+ }
+
+ /* Now check any Resources dictionary in the Page dictionary */
+ code = pdfi_dict_knownget_type(ctx, page_dict, "Resources", PDF_DICT, (pdf_obj **)&Resources);
+ if (code > 0)
+ code = pdfi_check_Resources(ctx, Resources, page_dict, tracker);
+ if ((code < 0 && ctx->args.pdfstoponerror) || (code == gs_error_stackoverflow))
+ goto exit;
+
+ /* If we are drawing Annotations, check to see if the page uses any Annots */
+ if (ctx->args.showannots) {
+ code = pdfi_dict_knownget_type(ctx, page_dict, "Annots", PDF_ARRAY, (pdf_obj **)&Annots);
+ if (code > 0)
+ code = pdfi_check_Annots_for_transparency(ctx, Annots, page_dict,
+ tracker);
+ if (code < 0 && ctx->args.pdfstoponerror)
+ goto exit;
+ }
+
+ code = 0;
+ exit:
+ pdfi_countdown(Resources);
+ pdfi_countdown(Annots);
+ pdfi_countdown(CS);
+ pdfi_countdown(Group);
+ return code;
+}
+
+/* Checks page for transparency, and sets up device for spots, if applicable
+ * Sets ctx->page.has_transparency and ctx->page.num_spots
+ * do_setup -- indicates whether to actually set up the device with the spot count.
+ */
+int pdfi_check_page(pdf_context *ctx, pdf_dict *page_dict, bool do_setup)
+{
+ int code;
+ int spots = 0;
+ pdfi_check_tracker_t tracker;
+
+ ctx->page.num_spots = 0;
+ ctx->page.has_transparency = false;
+
+ /* Need to do this here so that pdfi_check_init_tracker will be setup
+ * for spot colours, if the device is spot colour capable.
+ * It is also called in pdfi_page_render() and pdfi_process_pdf_file()
+ * TODO: Should probably look into that..
+ */
+ pdfi_device_set_flags(ctx);
+ code = pdfi_check_init_tracker(ctx, &tracker);
+
+ /* Check for spots and transparency in this page */
+ code = pdfi_check_page_inner(ctx, page_dict, &tracker);
+ if (code < 0)
+ goto exit;
+
+ /* Count the spots */
+ if (tracker.spot_dict)
+ spots = pdfi_dict_entries(tracker.spot_dict);
+
+ /* If setup requested, tell the device about spots and transparency */
+ if (do_setup) {
+ gs_c_param_list list;
+
+ gs_c_param_list_write(&list, ctx->memory);
+
+ /* If there are spot colours (and by inference, the device renders spot plates) then
+ * send the number of Spots to the device, so it can setup correctly.
+ */
+ if (tracker.spot_dict)
+ param_write_int((gs_param_list *)&list, "PageSpotColors", &spots);
+
+ code = param_write_bool((gs_param_list *)&list, "PageUsesTransparency",
+ &tracker.transparent);
+ gs_c_param_list_read(&list);
+ code = gs_putdeviceparams(ctx->pgs->device, (gs_param_list *)&list);
+ gs_c_param_list_release(&list);
+ if (code > 0) {
+ /* The device was closed, we need to reopen it */
+ code = gs_setdevice_no_erase(ctx->pgs, ctx->pgs->device);
+ if (code < 0)
+ goto exit;
+ gs_erasepage(ctx->pgs);
+ }
+ }
+
+ /* Set our values in the context, for caller */
+ ctx->page.has_transparency = tracker.transparent;
+ ctx->page.num_spots = spots;
+ ctx->page.has_OP = tracker.has_overprint;
+
+ exit:
+ (void)pdfi_check_free_tracker(ctx, &tracker);
+ return code;
+}
diff --git a/pdf/pdf_check.h b/pdf/pdf_check.h
new file mode 100644
index 00000000..eee5c82b
--- /dev/null
+++ b/pdf/pdf_check.h
@@ -0,0 +1,24 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+#ifndef PDF_CHECK
+#define PDF_CHECK
+
+int pdfi_check_page(pdf_context *ctx, pdf_dict *page_dict, bool do_setup);
+
+int pdfi_check_Pattern_transparency(pdf_context *ctx, pdf_dict *pattern,
+ pdf_dict *page_dict, bool *transparent);
+
+#endif
diff --git a/pdf/pdf_ciddec.c b/pdf/pdf_ciddec.c
new file mode 100644
index 00000000..8f7e876d
--- /dev/null
+++ b/pdf/pdf_ciddec.c
@@ -0,0 +1,530 @@
+/* Copyright (C) 2021-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+#include "pdf_font0.h"
+
+/* Each "value" is actually multiple values (calculated by the Postscript that
+ created this table. *Most* are one "real" value and multiple "-1" entries.
+ "-1" indicates an empty code. This is to cope with the relatively few cases
+ where a CID maps to more than one candidate code point. Handling that gives
+ us a better chance of finding a codepoint supported by the TTF cmap table
+ */
+static const pdfi_cid_decoding_t cns1_unicode = {
+ "CNS1", "Unicode",
+ 74,
+ 4,
+ {
+ {{-1, -1, -1, -1}, {32, -1, -1, -1}, {33, -1, -1, -1}, {34, -1, -1, -1}, {35, -1, -1, -1}, {36, -1, -1, -1}, {37, -1, -1, -1}, {38, -1, -1, -1}, {39, -1, -1, -1}, {40, -1, -1, -1}, {41, -1, -1, -1}, {42, -1, -1, -1}, {43, -1, -1, -1}, {44, -1, -1, -1}, {45, -1, -1, -1}, {46, -1, -1, -1}, {47, -1, -1, -1}, {48, -1, -1, -1}, {49, -1, -1, -1}, {50, -1, -1, -1}, {51, -1, -1, -1}, {52, -1, -1, -1}, {53, -1, -1, -1}, {54, -1, -1, -1}, {55, -1, -1, -1}, {56, -1, -1, -1}, {57, -1, -1, -1}, {58, -1, -1, -1}, {59, -1, -1, -1}, {60, -1, -1, -1}, {61, -1, -1, -1}, {62, -1, -1, -1}, {63, -1, -1, -1}, {64, -1, -1, -1}, {65, -1, -1, -1}, {66, -1, -1, -1}, {67, -1, -1, -1}, {68, -1, -1, -1}, {69, -1, -1, -1}, {70, -1, -1, -1}, {71, -1, -1, -1}, {72, -1, -1, -1}, {73, -1, -1, -1}, {74, -1, -1, -1}, {75, -1, -1, -1}, {76, -1, -1, -1}, {77, -1, -1, -1}, {78, -1, -1, -1}, {79, -1, -1, -1}, {80, -1, -1, -1}, {81, -1, -1, -1}, {82, -1, -1, -1}, {83, -1, -1, -1}, {84, -1, -1, -1}, {85, -1, -1, -1}, {86, -1, -1, -1}, {87, -1, -1, -1}, {88, -1, -1, -1}, {89, -1, -1, -1}, {90, -1, -1, -1}, {91, -1, -1, -1}, {92, -1, -1, -1}, {93, -1, -1, -1}, {94, -1, -1, -1}, {95, -1, -1, -1}, {96, -1, -1, -1}, {97, -1, -1, -1}, {98, -1, -1, -1}, {99, -1, -1, -1}, {100, -1, -1, -1}, {101, -1, -1, -1}, {102, -1, -1, -1}, {103, -1, -1, -1}, {104, -1, -1, -1}, {105, -1, -1, -1}, {106, -1, -1, -1}, {107, -1, -1, -1}, {108, -1, -1, -1}, {109, -1, -1, -1}, {110, -1, -1, -1}, {111, -1, -1, -1}, {112, -1, -1, -1}, {113, -1, -1, -1}, {114, -1, -1, -1}, {115, -1, -1, -1}, {116, -1, -1, -1}, {117, -1, -1, -1}, {118, -1, -1, -1}, {119, -1, -1, -1}, {120, -1, -1, -1}, {121, -1, -1, -1}, {122, -1, -1, -1}, {123, -1, -1, -1}, {124, -1, -1, -1}, {125, -1, -1, -1}, {126, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12288, -1, -1, -1}, {65292, -1, -1, -1}, {12289, -1, -1, -1}, {12290, -1, -1, -1}, {65294, -1, -1, -1}, {8226, -1, -1, -1}, {65307, -1, -1, -1}, {65306, -1, -1, -1}, {65311, -1, -1, -1}, {65281, -1, -1, -1}, {65072, 8229, -1, -1}, {8230, -1, -1, -1}, {8229, -1, -1, -1}, {65104, -1, -1, -1}, {65380, -1, -1, -1}, {65106, -1, -1, -1}, {183, -1, -1, -1}, {65108, -1, -1, -1}, {65109, -1, -1, -1}, {65110, -1, -1, -1}, {65111, -1, -1, -1}, {65372, 8211, -1, -1}, {8211, -1, -1, -1}, {65073, 8212, -1, -1}, {8212, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {65288, -1, -1, -1}, {65289, -1, -1, -1}, {65077, 65288, -1, -1}, {65078, 65289, -1, -1}, {65371, -1, -1, -1}, {65373, -1, -1, -1}, {65079, 65371, -1, -1}, {65080, 65373, -1, -1}, {12308, -1, -1, -1}, {12309, -1, -1, -1}, {65081, 12308, -1, -1}, {65082, 12309, -1, -1}, {12304, -1, -1, -1}, {12305, -1, -1, -1}, {65083, 12304, -1, -1}, {65084, 12305, -1, -1}, {12298, -1, -1, -1}, {12299, -1, -1, -1}, {65085, 12298, -1, -1}, {65086, 12299, -1, -1}, {12296, -1, -1, -1}, {12297, -1, -1, -1}, {65087, 12296, -1, -1}, {65088, 12297, -1, -1}, {12300, -1, -1, -1}, {12301, -1, -1, -1}, {65089, 12300, -1, -1}, {65090, 12301, -1, -1}, {12302, -1, -1, -1}, {12303, -1, -1, -1}, {65091, 12302, -1, -1}, {65092, 12303, -1, -1}, {65113, -1, -1, -1}, {65114, -1, -1, -1}, {65115, -1, -1, -1}, {65116, -1, -1, -1}, {65117, -1, -1, -1}, {65118, -1, -1, -1}, {8216, -1, -1, -1}, {8217, -1, -1, -1}, {8220, -1, -1, -1}, {8221, -1, -1, -1}, {12317, -1, -1, -1}, {12318, -1, -1, -1}, {8245, -1, -1, -1}, {8242, -1, -1, -1}, {65283, -1, -1, -1}, {65286, -1, -1, -1}, {65290, -1, -1, -1}, {8251, -1, -1, -1}, {167, -1, -1, -1}, {12291, -1, -1, -1}, {9675, -1, -1, -1}, {9679, -1, -1, -1}, {9651, -1, -1, -1}, {9650, -1, -1, -1}, {9678, -1, -1, -1}, {9734, -1, -1, -1}, {9733, -1, -1, -1}, {9671, -1, -1, -1}, {9670, -1, -1, -1}, {9633, -1, -1, -1}, {9632, -1, -1, -1}, {9661, -1, -1, -1}, {9660, -1, -1, -1}, {12963, -1, -1, -1}, {8453, -1, -1, -1}, {8254, -1, -1, -1}, {-1, -1, -1, -1}, {65343, -1, -1, -1}, {-1, -1, -1, -1}, {65097, -1, -1, -1}, {65098, -1, -1, -1}, {65101, -1, -1, -1}, {65102, -1, -1, -1}, {65099, -1, -1, -1}, {65100, -1, -1, -1}, {65119, -1, -1, -1}, {65120, -1, -1, -1}, {65121, -1, -1, -1}, {65291, -1, -1, -1}, {65293, -1, -1, -1}, {215, -1, -1, -1}, {247, -1, -1, -1}, {177, -1, -1, -1}, {8730, -1, -1, -1}, {65308, -1, -1, -1}, {65310, -1, -1, -1}, {65309, -1, -1, -1}, {8806, -1, -1, -1}, {8807, -1, -1, -1}, {8800, -1, -1, -1}, {8734, -1, -1, -1}, {8786, -1, -1, -1}, {8801, -1, -1, -1}, {65122, -1, -1, -1}, {65123, -1, -1, -1}, {65124, -1, -1, -1}, {65125, -1, -1, -1}, {65126, -1, -1, -1}, {8764, -1, -1, -1}, {8745, -1, -1, -1}, {8746, -1, -1, -1}, {8869, -1, -1, -1}, {8736, -1, -1, -1}, {8735, -1, -1, -1}, {8895, -1, -1, -1}, {13266, -1, -1, -1}, {13265, -1, -1, -1}, {8747, -1, -1, -1}, {8750, -1, -1, -1}, {8757, -1, -1, -1}, {8756, -1, -1, -1}, {9792, -1, -1, -1}, {9794, -1, -1, -1}, {9793, -1, -1, -1}, {9737, -1, -1, -1}, {8593, -1, -1, -1}, {8595, -1, -1, -1}, {8594, -1, -1, -1}, {8592, -1, -1, -1}, {8598, -1, -1, -1}, {8599, -1, -1, -1}, {8601, -1, -1, -1}, {8600, -1, -1, -1}, {8741, -1, -1, -1}, {8739, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {65295, -1, -1, -1}, {65340, -1, -1, -1}, {65284, -1, -1, -1}, {165, -1, -1, -1}, {12306, -1, -1, -1}, {162, -1, -1, -1}, {163, -1, -1, -1}, {65285, -1, -1, -1}, {65312, -1, -1, -1}, {8451, -1, -1, -1}, {8457, -1, -1, -1}, {65129, -1, -1, -1}, {65130, -1, -1, -1}, {65131, -1, -1, -1}, {13269, -1, -1, -1}, {13212, -1, -1, -1}, {13213, -1, -1, -1}, {13214, -1, -1, -1}, {13262, -1, -1, -1}, {13217, -1, -1, -1}, {13198, -1, -1, -1}, {13199, -1, -1, -1}, {13252, -1, -1, -1}, {176, -1, -1, -1}, {20825, -1, -1, -1}, {20827, -1, -1, -1}, {20830, -1, -1, -1}, {20829, -1, -1, -1}, {20833, -1, -1, -1}, {20835, -1, -1, -1}, {21991, -1, -1, -1}, {29929, -1, -1, -1}, {31950, -1, -1, -1}, {9601, -1, -1, -1}, {9602, -1, -1, -1}, {9603, -1, -1, -1}, {9604, -1, -1, -1}, {9605, -1, -1, -1}, {9606, -1, -1, -1}, {9607, -1, -1, -1}, {9608, -1, -1, -1}, {9615, -1, -1, -1}, {9614, -1, -1, -1}, {9613, -1, -1, -1}, {9612, -1, -1, -1}, {9611, -1, -1, -1}, {9610, -1, -1, -1}, {9609, -1, -1, -1}, {9532, -1, -1, -1}, {9524, -1, -1, -1}, {9516, -1, -1, -1}, {9508, -1, -1, -1}, {9500, -1, -1, -1}, {9620, -1, -1, -1}, {9472, -1, -1, -1}, {9474, -1, -1, -1}, {9621, -1, -1, -1}, {9484, -1, -1, -1}, {9488, -1, -1, -1}, {9492, -1, -1, -1}, {9496, -1, -1, -1}, {9581, -1, -1, -1}, {9582, -1, -1, -1}, {9584, -1, -1, -1}, {9583, -1, -1, -1}, {9552, -1, -1, -1}, {9566, -1, -1, -1}, {9578, -1, -1, -1}, {9569, -1, -1, -1}, {9698, -1, -1, -1}, {9699, -1, -1, -1}, {9701, -1, -1, -1}, {9700, -1, -1, -1}, {9585, -1, -1, -1}, {9586, -1, -1, -1}, {9587, -1, -1, -1}, {65296, -1, -1, -1}, {65297, -1, -1, -1}, {65298, -1, -1, -1}, {65299, -1, -1, -1}, {65300, -1, -1, -1}, {65301, -1, -1, -1}, {65302, -1, -1, -1}, {65303, -1, -1, -1}, {65304, -1, -1, -1}, {65305, -1, -1, -1}, {8544, -1, -1, -1}, {8545, -1, -1, -1}, {8546, -1, -1, -1}, {8547, -1, -1, -1}, {8548, -1, -1, -1}, {8549, -1, -1, -1}, {8550, -1, -1, -1}, {8551, -1, -1, -1}, {8552, -1, -1, -1}, {8553, -1, -1, -1}, {12321, -1, -1, -1}, {12322, -1, -1, -1}, {12323, -1, -1, -1}, {12324, -1, -1, -1}, {12325, -1, -1, -1}, {12326, -1, -1, -1}, {12327, -1, -1, -1}, {12328, -1, -1, -1}, {12329, -1, -1, -1}, {-1, -1, -1, -1}, {21316, -1, -1, -1}, {-1, -1, -1, -1}, {65313, -1, -1, -1}, {65314, -1, -1, -1}, {65315, -1, -1, -1}, {65316, -1, -1, -1}, {65317, -1, -1, -1}, {65318, -1, -1, -1}, {65319, -1, -1, -1}, {65320, -1, -1, -1}, {65321, -1, -1, -1}, {65322, -1, -1, -1}, {65323, -1, -1, -1}, {65324, -1, -1, -1}, {65325, -1, -1, -1}, {65326, -1, -1, -1}, {65327, -1, -1, -1}, {65328, -1, -1, -1}, {65329, -1, -1, -1}, {65330, -1, -1, -1}, {65331, -1, -1, -1}, {65332, -1, -1, -1}, {65333, -1, -1, -1}, {65334, -1, -1, -1}, {65335, -1, -1, -1}, {65336, -1, -1, -1}, {65337, -1, -1, -1}, {65338, -1, -1, -1}, {65345, -1, -1, -1}, {65346, -1, -1, -1}, {65347, -1, -1, -1}, {65348, -1, -1, -1}, {65349, -1, -1, -1}, {65350, -1, -1, -1}, {65351, -1, -1, -1}, {65352, -1, -1, -1}, {65353, -1, -1, -1}, {65354, -1, -1, -1}, {65355, -1, -1, -1}, {65356, -1, -1, -1}, {65357, -1, -1, -1}, {65358, -1, -1, -1}, {65359, -1, -1, -1}, {65360, -1, -1, -1}, {65361, -1, -1, -1}, {65362, -1, -1, -1}, {65363, -1, -1, -1}, {65364, -1, -1, -1}, {65365, -1, -1, -1}, {65366, -1, -1, -1}, {65367, -1, -1, -1}, {65368, -1, -1, -1}, {65369, -1, -1, -1}, {65370, -1, -1, -1}, {913, -1, -1, -1}, {914, -1, -1, -1}, {915, -1, -1, -1}, {916, -1, -1, -1}, {917, -1, -1, -1}, {918, -1, -1, -1}, {919, -1, -1, -1}, {920, -1, -1, -1}, {921, -1, -1, -1}, {922, -1, -1, -1}, {923, -1, -1, -1}, {924, -1, -1, -1}, {925, -1, -1, -1}, {926, -1, -1, -1}, {927, -1, -1, -1}, {928, -1, -1, -1}, {929, -1, -1, -1}, {931, -1, -1, -1}, {932, -1, -1, -1}, {933, -1, -1, -1}, {934, -1, -1, -1}, {935, -1, -1, -1}, {936, -1, -1, -1}, {937, -1, -1, -1}, {945, -1, -1, -1}, {946, -1, -1, -1}, {947, -1, -1, -1}, {948, -1, -1, -1}, {949, -1, -1, -1}, {950, -1, -1, -1}, {951, -1, -1, -1}, {952, -1, -1, -1}, {953, -1, -1, -1}, {954, -1, -1, -1}, {955, -1, -1, -1}, {956, -1, -1, -1}, {957, -1, -1, -1}, {958, -1, -1, -1}, {959, -1, -1, -1}, {960, -1, -1, -1}, {961, -1, -1, -1}, {963, -1, -1, -1}, {964, -1, -1, -1}, {965, -1, -1, -1}, {966, -1, -1, -1}, {967, -1, -1, -1}, {968, -1, -1, -1}, {969, -1, -1, -1}, {12549, -1, -1, -1}, {12550, -1, -1, -1}, {12551, -1, -1, -1}, {12552, -1, -1, -1}, {12553, -1, -1, -1}, {12554, -1, -1, -1}, {12555, -1, -1, -1}, {12556, -1, -1, -1}, {12557, -1, -1, -1}, {12558, -1, -1, -1}, {12559, -1, -1, -1}, {12560, -1, -1, -1}, {12561, -1, -1, -1}, {12562, -1, -1, -1}, {12563, -1, -1, -1}, {12564, -1, -1, -1}, {12565, -1, -1, -1}, {12566, -1, -1, -1}, {12567, -1, -1, -1}, {12568, -1, -1, -1}, {12569, -1, -1, -1}, {12570, -1, -1, -1}, {12571, -1, -1, -1}, {12572, -1, -1, -1}, {12573, -1, -1, -1}, {12574, -1, -1, -1}, {12575, -1, -1, -1}, {12576, -1, -1, -1}, {12577, -1, -1, -1}, {12578, -1, -1, -1}, {12579, -1, -1, -1}, {12580, -1, -1, -1}, {12581, -1, -1, -1}, {12582, -1, -1, -1}, {12583, -1, -1, -1}, {12584, -1, -1, -1}, {12585, -1, -1, -1}, {729, -1, -1, -1}, {714, -1, -1, -1}, {711, -1, -1, -1}, {715, -1, -1, -1}, {9312, -1, -1, -1}, {9313, -1, -1, -1}, {9314, -1, -1, -1}, {9315, -1, -1, -1}, {9316, -1, -1, -1}, {9317, -1, -1, -1} },
+ {{9318, -1, -1, -1}, {9319, -1, -1, -1}, {9320, -1, -1, -1}, {9321, -1, -1, -1}, {9332, -1, -1, -1}, {9333, -1, -1, -1}, {9334, -1, -1, -1}, {9335, -1, -1, -1}, {9336, -1, -1, -1}, {9337, -1, -1, -1}, {9338, -1, -1, -1}, {9339, -1, -1, -1}, {9340, -1, -1, -1}, {9341, -1, -1, -1}, {8560, -1, -1, -1}, {8561, -1, -1, -1}, {8562, -1, -1, -1}, {8563, -1, -1, -1}, {8564, -1, -1, -1}, {8565, -1, -1, -1}, {8566, -1, -1, -1}, {8567, -1, -1, -1}, {8568, -1, -1, -1}, {8569, -1, -1, -1}, {20008, -1, -1, -1}, {20022, -1, -1, -1}, {20031, -1, -1, -1}, {20101, -1, -1, -1}, {20128, -1, -1, -1}, {20866, -1, -1, -1}, {20886, -1, -1, -1}, {20907, -1, -1, -1}, {21241, -1, -1, -1}, {21304, -1, -1, -1}, {21353, -1, -1, -1}, {21430, -1, -1, -1}, {22794, 22786, -1, -1}, {23424, -1, -1, -1}, {24027, -1, -1, -1}, {12083, 24186, -1, -1}, {24191, -1, -1, -1}, {24308, -1, -1, -1}, {24400, -1, -1, -1}, {24417, -1, -1, -1}, {25908, -1, -1, -1}, {26080, -1, -1, -1}, {30098, -1, -1, -1}, {30326, -1, -1, -1}, {36789, -1, -1, -1}, {38582, -1, -1, -1}, {9216, -1, -1, -1}, {9217, -1, -1, -1}, {9218, -1, -1, -1}, {9219, -1, -1, -1}, {9220, -1, -1, -1}, {9221, -1, -1, -1}, {9222, -1, -1, -1}, {9223, -1, -1, -1}, {9224, -1, -1, -1}, {9225, -1, -1, -1}, {9226, -1, -1, -1}, {9227, -1, -1, -1}, {9228, -1, -1, -1}, {9229, -1, -1, -1}, {9230, -1, -1, -1}, {9231, -1, -1, -1}, {9232, -1, -1, -1}, {9233, -1, -1, -1}, {9234, -1, -1, -1}, {9235, -1, -1, -1}, {9236, -1, -1, -1}, {9237, -1, -1, -1}, {9238, -1, -1, -1}, {9239, -1, -1, -1}, {9240, -1, -1, -1}, {9241, -1, -1, -1}, {9242, -1, -1, -1}, {9243, -1, -1, -1}, {9244, -1, -1, -1}, {9245, -1, -1, -1}, {9246, -1, -1, -1}, {9247, -1, -1, -1}, {9249, -1, -1, -1}, {19968, -1, -1, -1}, {20057, -1, -1, -1}, {19969, -1, -1, -1}, {19971, -1, -1, -1}, {20035, -1, -1, -1}, {20061, -1, -1, -1}, {20102, -1, -1, -1}, {20108, -1, -1, -1}, {20154, -1, -1, -1}, {20799, -1, -1, -1}, {20837, -1, -1, -1}, {20843, -1, -1, -1}, {20960, -1, -1, -1}, {20992, -1, -1, -1}, {20993, -1, -1, -1}, {21147, -1, -1, -1}, {21269, -1, -1, -1}, {21313, -1, -1, -1}, {21340, -1, -1, -1}, {21448, -1, -1, -1}, {19977, -1, -1, -1}, {19979, -1, -1, -1}, {19976, -1, -1, -1}, {19978, -1, -1, -1}, {20011, -1, -1, -1}, {20024, -1, -1, -1}, {20961, -1, -1, -1}, {20037, -1, -1, -1}, {20040, -1, -1, -1}, {20063, -1, -1, -1}, {20062, -1, -1, -1}, {20110, -1, -1, -1}, {20129, -1, -1, -1}, {20800, 64012, -1, -1}, {20995, -1, -1, -1}, {21242, -1, -1, -1}, {21315, -1, -1, -1}, {21449, -1, -1, -1}, {21475, -1, -1, -1}, {22303, -1, -1, -1}, {22763, -1, -1, -1}, {22805, -1, -1, -1}, {22823, -1, -1, -1}, {22899, -1, -1, -1}, {23376, -1, -1, -1}, {23377, -1, -1, -1}, {23379, -1, -1, -1}, {23544, -1, -1, -1}, {23567, -1, -1, -1}, {23586, -1, -1, -1}, {23608, -1, -1, -1}, {23665, -1, -1, -1}, {24029, -1, -1, -1}, {24037, -1, -1, -1}, {24049, -1, -1, -1}, {24050, -1, -1, -1}, {24051, -1, -1, -1}, {24062, -1, -1, -1}, {24178, -1, -1, -1}, {24318, -1, -1, -1}, {24331, -1, -1, -1}, {24339, -1, -1, -1}, {25165, -1, -1, -1}, {19985, -1, -1, -1}, {19984, -1, -1, -1}, {19981, -1, -1, -1}, {20013, -1, -1, -1}, {20016, -1, -1, -1}, {20025, -1, -1, -1}, {20043, -1, -1, -1}, {23609, -1, -1, -1}, {20104, -1, -1, -1}, {20113, -1, -1, -1}, {20117, -1, -1, -1}, {20114, -1, -1, -1}, {20116, -1, -1, -1}, {20130, -1, -1, -1}, {20161, -1, -1, -1}, {20160, -1, -1, -1}, {20163, -1, -1, -1}, {20166, -1, -1, -1}, {20167, -1, -1, -1}, {20173, -1, -1, -1}, {20170, -1, -1, -1}, {20171, -1, -1, -1}, {20164, -1, -1, -1}, {20803, -1, -1, -1}, {20801, -1, -1, -1}, {20839, -1, -1, -1}, {20845, -1, -1, -1}, {20846, -1, -1, -1}, {20844, -1, -1, -1}, {20887, -1, -1, -1}, {20982, -1, -1, -1}, {20998, -1, -1, -1}, {20999, -1, -1, -1}, {21000, -1, -1, -1}, {21243, -1, -1, -1}, {21246, -1, -1, -1}, {21247, -1, -1, -1}, {21270, -1, -1, -1}, {21305, -1, -1, -1}, {21320, -1, -1, -1}, {21319, -1, -1, -1}, {21317, -1, -1, -1}, {21342, -1, -1, -1}, {21380, -1, -1, -1}, {21451, -1, -1, -1}, {21450, -1, -1, -1}, {21453, -1, -1, -1}, {22764, -1, -1, -1}, {22825, -1, -1, -1}, {22827, -1, -1, -1}, {22826, -1, -1, -1}, {22829, -1, -1, -1}, {23380, -1, -1, -1}, {23569, -1, -1, -1}, {23588, -1, -1, -1}, {23610, -1, -1, -1}, {23663, -1, -1, -1}, {24052, -1, -1, -1}, {24187, -1, -1, -1}, {24319, -1, -1, -1}, {24340, -1, -1, -1}, {24341, -1, -1, -1}, {24515, -1, -1, -1}, {25096, -1, -1, -1}, {25142, -1, -1, -1}, {25163, -1, -1, -1}, {25166, -1, -1, -1}, {25903, -1, -1, -1}, {25991, -1, -1, -1}, {26007, -1, -1, -1}, {26020, -1, -1, -1}, {26041, -1, -1, -1}, {26085, -1, -1, -1}, {26352, -1, -1, -1}, {11933, 26376, -1, -1}, {26408, -1, -1, -1}, {27424, -1, -1, -1}, {27490, -1, -1, -1}, {27513, -1, -1, -1}, {27595, -1, -1, -1}, {27604, -1, -1, -1}, {27611, -1, -1, -1}, {27663, -1, -1, -1}, {27700, -1, -1, -1}, {28779, -1, -1, -1}, {29226, -1, -1, -1}, {29238, -1, -1, -1}, {29243, -1, -1, -1}, {29255, -1, -1, -1}, {29273, -1, -1, -1}, {29275, -1, -1, -1}, {29356, -1, -1, -1}, {29579, -1, -1, -1}, {19993, -1, -1, -1}, {19990, -1, -1, -1}, {19989, -1, -1, -1}, {19988, -1, -1, -1}, {19992, -1, -1, -1}, {20027, -1, -1, -1}, {20045, -1, -1, -1}, {20047, -1, -1, -1}, {20046, -1, -1, -1}, {20197, -1, -1, -1}, {20184, -1, -1, -1}, {20180, -1, -1, -1}, {20181, -1, -1, -1}, {20182, -1, -1, -1}, {20183, -1, -1, -1}, {20195, -1, -1, -1}, {20196, -1, -1, -1} },
+ {{20185, -1, -1, -1}, {20190, -1, -1, -1}, {20805, -1, -1, -1}, {20804, -1, -1, -1}, {20873, -1, -1, -1}, {20874, -1, -1, -1}, {20908, -1, -1, -1}, {20985, -1, -1, -1}, {20986, -1, -1, -1}, {20984, -1, -1, -1}, {21002, -1, -1, -1}, {21152, -1, -1, -1}, {21151, -1, -1, -1}, {21253, -1, -1, -1}, {21254, -1, -1, -1}, {21271, -1, -1, -1}, {21277, -1, -1, -1}, {20191, -1, -1, -1}, {21322, -1, -1, -1}, {21321, -1, -1, -1}, {21345, -1, -1, -1}, {21344, -1, -1, -1}, {21359, -1, -1, -1}, {21358, -1, -1, -1}, {21435, -1, -1, -1}, {21487, -1, -1, -1}, {21476, -1, -1, -1}, {21491, -1, -1, -1}, {21484, -1, -1, -1}, {21486, -1, -1, -1}, {21481, -1, -1, -1}, {21480, -1, -1, -1}, {21500, -1, -1, -1}, {21496, -1, -1, -1}, {21493, -1, -1, -1}, {21483, -1, -1, -1}, {21478, -1, -1, -1}, {21482, -1, -1, -1}, {21490, -1, -1, -1}, {21489, -1, -1, -1}, {21488, -1, -1, -1}, {21477, -1, -1, -1}, {21485, -1, -1, -1}, {21499, -1, -1, -1}, {22235, -1, -1, -1}, {22234, -1, -1, -1}, {22806, -1, -1, -1}, {22830, -1, -1, -1}, {22833, -1, -1, -1}, {22900, -1, -1, -1}, {22902, -1, -1, -1}, {23381, -1, -1, -1}, {23427, -1, -1, -1}, {23612, -1, -1, -1}, {24040, -1, -1, -1}, {24039, -1, -1, -1}, {24038, -1, -1, -1}, {24066, -1, -1, -1}, {24067, -1, -1, -1}, {24179, -1, -1, -1}, {24188, -1, -1, -1}, {24321, -1, -1, -1}, {24344, -1, -1, -1}, {24343, -1, -1, -1}, {24517, -1, -1, -1}, {25098, -1, -1, -1}, {25171, -1, -1, -1}, {25172, -1, -1, -1}, {25170, -1, -1, -1}, {25169, -1, -1, -1}, {26021, -1, -1, -1}, {26086, -1, -1, -1}, {26414, -1, -1, -1}, {26412, -1, -1, -1}, {26410, -1, -1, -1}, {26411, -1, -1, -1}, {26413, -1, -1, -1}, {27491, -1, -1, -1}, {27597, -1, -1, -1}, {27665, -1, -1, -1}, {27664, -1, -1, -1}, {27704, -1, -1, -1}, {27713, -1, -1, -1}, {27712, -1, -1, -1}, {27710, -1, -1, -1}, {29359, -1, -1, -1}, {29572, -1, -1, -1}, {29577, -1, -1, -1}, {29916, -1, -1, -1}, {29926, -1, -1, -1}, {29976, -1, -1, -1}, {29983, -1, -1, -1}, {29992, -1, -1, -1}, {29993, -1, -1, -1}, {30000, -1, -1, -1}, {30001, -1, -1, -1}, {30002, -1, -1, -1}, {30003, -1, -1, -1}, {30091, -1, -1, -1}, {30333, -1, -1, -1}, {30382, -1, -1, -1}, {30399, -1, -1, -1}, {30446, -1, -1, -1}, {30683, -1, -1, -1}, {30690, -1, -1, -1}, {30707, -1, -1, -1}, {31034, -1, -1, -1}, {31166, -1, -1, -1}, {31348, -1, -1, -1}, {31435, -1, -1, -1}, {19998, -1, -1, -1}, {19999, -1, -1, -1}, {20050, -1, -1, -1}, {20051, -1, -1, -1}, {20073, -1, -1, -1}, {20121, -1, -1, -1}, {20132, -1, -1, -1}, {20134, -1, -1, -1}, {20133, -1, -1, -1}, {20223, -1, -1, -1}, {20233, -1, -1, -1}, {20249, -1, -1, -1}, {20234, -1, -1, -1}, {20245, -1, -1, -1}, {20237, -1, -1, -1}, {20240, -1, -1, -1}, {20241, -1, -1, -1}, {20239, -1, -1, -1}, {20210, -1, -1, -1}, {20214, -1, -1, -1}, {20219, -1, -1, -1}, {20208, -1, -1, -1}, {20211, -1, -1, -1}, {20221, -1, -1, -1}, {20225, -1, -1, -1}, {20235, -1, -1, -1}, {20809, -1, -1, -1}, {20807, -1, -1, -1}, {20806, -1, -1, -1}, {20808, -1, -1, -1}, {20840, -1, -1, -1}, {20849, -1, -1, -1}, {20877, -1, -1, -1}, {20912, -1, -1, -1}, {21015, -1, -1, -1}, {21009, -1, -1, -1}, {21010, -1, -1, -1}, {21006, -1, -1, -1}, {21014, -1, -1, -1}, {21155, -1, -1, -1}, {21256, -1, -1, -1}, {21281, -1, -1, -1}, {21280, -1, -1, -1}, {21360, -1, -1, -1}, {21361, -1, -1, -1}, {21513, -1, -1, -1}, {21519, -1, -1, -1}, {21516, -1, -1, -1}, {21514, -1, -1, -1}, {21520, -1, -1, -1}, {21505, -1, -1, -1}, {21515, -1, -1, -1}, {21508, -1, -1, -1}, {21521, -1, -1, -1}, {21517, -1, -1, -1}, {21512, -1, -1, -1}, {21507, -1, -1, -1}, {21518, -1, -1, -1}, {21510, -1, -1, -1}, {21522, -1, -1, -1}, {22240, -1, -1, -1}, {22238, -1, -1, -1}, {22237, -1, -1, -1}, {22323, -1, -1, -1}, {22320, -1, -1, -1}, {22312, -1, -1, -1}, {22317, -1, -1, -1}, {22316, -1, -1, -1}, {22319, -1, -1, -1}, {22313, -1, -1, -1}, {22809, -1, -1, -1}, {22810, -1, -1, -1}, {22839, -1, -1, -1}, {22840, -1, -1, -1}, {22916, -1, -1, -1}, {22904, -1, -1, -1}, {22915, -1, -1, -1}, {22909, -1, -1, -1}, {22905, -1, -1, -1}, {22914, -1, -1, -1}, {22913, -1, -1, -1}, {23383, -1, -1, -1}, {23384, -1, -1, -1}, {23431, -1, -1, -1}, {23432, -1, -1, -1}, {23429, -1, -1, -1}, {23433, -1, -1, -1}, {23546, -1, -1, -1}, {23574, -1, -1, -1}, {23673, -1, -1, -1}, {24030, -1, -1, -1}, {24070, -1, -1, -1}, {24182, -1, -1, -1}, {24180, -1, -1, -1}, {24335, -1, -1, -1}, {24347, -1, -1, -1}, {24537, -1, -1, -1}, {24534, -1, -1, -1}, {25102, -1, -1, -1}, {25100, -1, -1, -1}, {25101, -1, -1, -1}, {25104, -1, -1, -1}, {25187, -1, -1, -1}, {25179, -1, -1, -1}, {25176, -1, -1, -1}, {25910, -1, -1, -1}, {26089, -1, -1, -1}, {26088, -1, -1, -1}, {26092, -1, -1, -1}, {26093, -1, -1, -1}, {26354, -1, -1, -1}, {26355, -1, -1, -1}, {26377, -1, -1, -1}, {26429, -1, -1, -1}, {26420, -1, -1, -1}, {26417, -1, -1, -1}, {26421, -1, -1, -1}, {27425, -1, -1, -1}, {27492, -1, -1, -1}, {27515, -1, -1, -1}, {27670, -1, -1, -1}, {27741, -1, -1, -1}, {27735, -1, -1, -1}, {27737, -1, -1, -1}, {27743, -1, -1, -1}, {27744, -1, -1, -1}, {27728, -1, -1, -1}, {27733, -1, -1, -1}, {27745, -1, -1, -1}, {27739, -1, -1, -1}, {27725, -1, -1, -1}, {27726, -1, -1, -1}, {28784, -1, -1, -1}, {29279, -1, -1, -1}, {29277, -1, -1, -1}, {30334, -1, -1, -1}, {31481, -1, -1, -1}, {31859, -1, -1, -1}, {31992, -1, -1, -1}, {32566, -1, -1, -1}, {32650, -1, -1, -1}, {32701, -1, -1, -1}, {32769, -1, -1, -1}, {32771, -1, -1, -1}, {32780, -1, -1, -1}, {32786, -1, -1, -1} },
+ {{32819, -1, -1, -1}, {32895, -1, -1, -1}, {32905, -1, -1, -1}, {32907, -1, -1, -1}, {32908, -1, -1, -1}, {33251, -1, -1, -1}, {33258, -1, -1, -1}, {33267, -1, -1, -1}, {33276, -1, -1, -1}, {33292, -1, -1, -1}, {33307, -1, -1, -1}, {33311, -1, -1, -1}, {33390, -1, -1, -1}, {33394, -1, -1, -1}, {33406, -1, -1, -1}, {34411, -1, -1, -1}, {34880, -1, -1, -1}, {34892, -1, -1, -1}, {34915, -1, -1, -1}, {35199, -1, -1, -1}, {38433, -1, -1, -1}, {20018, -1, -1, -1}, {20136, -1, -1, -1}, {20301, -1, -1, -1}, {20303, -1, -1, -1}, {20295, -1, -1, -1}, {20311, -1, -1, -1}, {20318, -1, -1, -1}, {20276, -1, -1, -1}, {20315, -1, -1, -1}, {20309, -1, -1, -1}, {20272, -1, -1, -1}, {20304, -1, -1, -1}, {20305, -1, -1, -1}, {20285, -1, -1, -1}, {20282, -1, -1, -1}, {20280, -1, -1, -1}, {20291, -1, -1, -1}, {20308, -1, -1, -1}, {20284, -1, -1, -1}, {20294, -1, -1, -1}, {20323, -1, -1, -1}, {20316, -1, -1, -1}, {20320, -1, -1, -1}, {20271, -1, -1, -1}, {20302, -1, -1, -1}, {20278, -1, -1, -1}, {20313, -1, -1, -1}, {20317, -1, -1, -1}, {20296, -1, -1, -1}, {20314, -1, -1, -1}, {20812, -1, -1, -1}, {20811, -1, -1, -1}, {20813, -1, -1, -1}, {20853, -1, -1, -1}, {20918, -1, -1, -1}, {20919, -1, -1, -1}, {21029, -1, -1, -1}, {21028, -1, -1, -1}, {21033, -1, -1, -1}, {21034, -1, -1, -1}, {21032, -1, -1, -1}, {21163, -1, -1, -1}, {21161, -1, -1, -1}, {21162, -1, -1, -1}, {21164, -1, -1, -1}, {21283, -1, -1, -1}, {21363, -1, -1, -1}, {21365, -1, -1, -1}, {21533, -1, -1, -1}, {21549, -1, -1, -1}, {21534, -1, -1, -1}, {21566, -1, -1, -1}, {21542, -1, -1, -1}, {21582, -1, -1, -1}, {21543, -1, -1, -1}, {21574, -1, -1, -1}, {21571, -1, -1, -1}, {21555, -1, -1, -1}, {21576, -1, -1, -1}, {21570, -1, -1, -1}, {21531, -1, -1, -1}, {21545, -1, -1, -1}, {21578, -1, -1, -1}, {21561, -1, -1, -1}, {21563, -1, -1, -1}, {21560, -1, -1, -1}, {21550, -1, -1, -1}, {21557, -1, -1, -1}, {21558, -1, -1, -1}, {21536, -1, -1, -1}, {21564, -1, -1, -1}, {21568, -1, -1, -1}, {21553, -1, -1, -1}, {21547, -1, -1, -1}, {21535, -1, -1, -1}, {21548, -1, -1, -1}, {22250, -1, -1, -1}, {22256, -1, -1, -1}, {22244, -1, -1, -1}, {22251, -1, -1, -1}, {22346, -1, -1, -1}, {22353, -1, -1, -1}, {22336, -1, -1, -1}, {22349, -1, -1, -1}, {22343, -1, -1, -1}, {22350, -1, -1, -1}, {22334, -1, -1, -1}, {22352, -1, -1, -1}, {22351, -1, -1, -1}, {22331, -1, -1, -1}, {22767, -1, -1, -1}, {22846, -1, -1, -1}, {22941, -1, -1, -1}, {22930, -1, -1, -1}, {22952, -1, -1, -1}, {22942, -1, -1, -1}, {22947, -1, -1, -1}, {22937, -1, -1, -1}, {22934, -1, -1, -1}, {22925, -1, -1, -1}, {22948, -1, -1, -1}, {22931, -1, -1, -1}, {22922, -1, -1, -1}, {22949, -1, -1, -1}, {23389, -1, -1, -1}, {23388, -1, -1, -1}, {23386, -1, -1, -1}, {23387, -1, -1, -1}, {23436, -1, -1, -1}, {23435, -1, -1, -1}, {23439, -1, -1, -1}, {23596, -1, -1, -1}, {23616, -1, -1, -1}, {23617, -1, -1, -1}, {23615, -1, -1, -1}, {23614, -1, -1, -1}, {23696, -1, -1, -1}, {23697, -1, -1, -1}, {23700, -1, -1, -1}, {23692, -1, -1, -1}, {24043, -1, -1, -1}, {24076, -1, -1, -1}, {24207, -1, -1, -1}, {24199, -1, -1, -1}, {24202, -1, -1, -1}, {24311, -1, -1, -1}, {24324, -1, -1, -1}, {24351, -1, -1, -1}, {24420, -1, -1, -1}, {24418, -1, -1, -1}, {24439, -1, -1, -1}, {24441, -1, -1, -1}, {24536, -1, -1, -1}, {24524, -1, -1, -1}, {24535, -1, -1, -1}, {24525, -1, -1, -1}, {24561, -1, -1, -1}, {24555, -1, -1, -1}, {24568, -1, -1, -1}, {24554, -1, -1, -1}, {25106, -1, -1, -1}, {25105, -1, -1, -1}, {25220, -1, -1, -1}, {25239, -1, -1, -1}, {25238, -1, -1, -1}, {25216, -1, -1, -1}, {25206, -1, -1, -1}, {25225, -1, -1, -1}, {25197, -1, -1, -1}, {25226, -1, -1, -1}, {25212, -1, -1, -1}, {25214, -1, -1, -1}, {25209, -1, -1, -1}, {25203, -1, -1, -1}, {25234, -1, -1, -1}, {25199, -1, -1, -1}, {25240, -1, -1, -1}, {25198, -1, -1, -1}, {25237, -1, -1, -1}, {25235, -1, -1, -1}, {25233, -1, -1, -1}, {25222, -1, -1, -1}, {25913, -1, -1, -1}, {25915, -1, -1, -1}, {25912, -1, -1, -1}, {26097, -1, -1, -1}, {26356, -1, -1, -1}, {26463, -1, -1, -1}, {26446, -1, -1, -1}, {26447, -1, -1, -1}, {26448, -1, -1, -1}, {26449, -1, -1, -1}, {26460, -1, -1, -1}, {26454, -1, -1, -1}, {26462, -1, -1, -1}, {26441, -1, -1, -1}, {26438, -1, -1, -1}, {26464, -1, -1, -1}, {26451, -1, -1, -1}, {26455, -1, -1, -1}, {27493, -1, -1, -1}, {27599, -1, -1, -1}, {27714, -1, -1, -1}, {27742, -1, -1, -1}, {27801, -1, -1, -1}, {27777, -1, -1, -1}, {27784, -1, -1, -1}, {27785, -1, -1, -1}, {27781, -1, -1, -1}, {27803, -1, -1, -1}, {27754, -1, -1, -1}, {27770, -1, -1, -1}, {27792, -1, -1, -1}, {27760, -1, -1, -1}, {27788, -1, -1, -1}, {27752, -1, -1, -1}, {27798, -1, -1, -1}, {27794, -1, -1, -1}, {27773, -1, -1, -1}, {27779, -1, -1, -1}, {27762, -1, -1, -1}, {27774, -1, -1, -1}, {27764, -1, -1, -1}, {27782, -1, -1, -1}, {27766, -1, -1, -1}, {27789, -1, -1, -1}, {27796, -1, -1, -1}, {27800, -1, -1, -1}, {27778, -1, -1, -1}, {28790, -1, -1, -1}, {28796, -1, -1, -1}, {28797, -1, -1, -1}, {28792, -1, -1, -1}, {29282, -1, -1, -1}, {29281, -1, -1, -1}, {29280, -1, -1, -1}, {29380, -1, -1, -1}, {29378, -1, -1, -1}, {29590, -1, -1, -1}, {29996, -1, -1, -1}, {29995, -1, -1, -1}, {30007, -1, -1, -1}, {30008, -1, -1, -1}, {30338, -1, -1, -1}, {30447, -1, -1, -1}, {30691, -1, -1, -1}, {31169, -1, -1, -1}, {31168, -1, -1, -1}, {31167, -1, -1, -1}, {31350, -1, -1, -1}, {31995, -1, -1, -1}, {32597, -1, -1, -1}, {32918, -1, -1, -1}, {32915, -1, -1, -1}, {32925, -1, -1, -1} },
+ {{32920, -1, -1, -1}, {32923, -1, -1, -1}, {32922, -1, -1, -1}, {32946, -1, -1, -1}, {33391, -1, -1, -1}, {33426, -1, -1, -1}, {33419, -1, -1, -1}, {33421, -1, -1, -1}, {35211, -1, -1, -1}, {11974, 35282, -1, -1}, {35328, -1, -1, -1}, {35895, -1, -1, -1}, {35910, -1, -1, -1}, {35925, -1, -1, -1}, {35997, -1, -1, -1}, {36196, -1, -1, -1}, {36208, -1, -1, -1}, {36275, -1, -1, -1}, {36523, -1, -1, -1}, {36554, -1, -1, -1}, {36763, -1, -1, -1}, {36784, -1, -1, -1}, {36802, -1, -1, -1}, {36806, -1, -1, -1}, {36805, -1, -1, -1}, {36804, -1, -1, -1}, {24033, -1, -1, -1}, {37009, -1, -1, -1}, {37026, -1, -1, -1}, {37034, -1, -1, -1}, {37030, -1, -1, -1}, {37027, -1, -1, -1}, {37193, -1, -1, -1}, {37318, -1, -1, -1}, {37324, -1, -1, -1}, {38450, -1, -1, -1}, {38446, -1, -1, -1}, {38449, -1, -1, -1}, {38442, -1, -1, -1}, {38444, -1, -1, -1}, {20006, -1, -1, -1}, {20054, -1, -1, -1}, {20083, -1, -1, -1}, {20107, -1, -1, -1}, {20123, -1, -1, -1}, {20126, -1, -1, -1}, {20139, -1, -1, -1}, {20140, -1, -1, -1}, {20335, -1, -1, -1}, {20381, -1, -1, -1}, {20365, -1, -1, -1}, {20339, -1, -1, -1}, {20351, -1, -1, -1}, {20332, -1, -1, -1}, {20379, -1, -1, -1}, {20363, -1, -1, -1}, {20358, -1, -1, -1}, {20355, -1, -1, -1}, {20336, -1, -1, -1}, {20341, -1, -1, -1}, {20360, -1, -1, -1}, {20329, -1, -1, -1}, {20347, -1, -1, -1}, {20374, -1, -1, -1}, {20350, -1, -1, -1}, {20367, -1, -1, -1}, {20369, -1, -1, -1}, {20346, -1, -1, -1}, {20820, -1, -1, -1}, {20818, -1, -1, -1}, {20821, -1, -1, -1}, {20841, -1, -1, -1}, {20855, -1, -1, -1}, {20854, -1, -1, -1}, {20856, -1, -1, -1}, {20925, -1, -1, -1}, {20989, -1, -1, -1}, {21051, -1, -1, -1}, {21048, -1, -1, -1}, {21047, -1, -1, -1}, {21050, -1, -1, -1}, {21040, -1, -1, -1}, {21038, -1, -1, -1}, {21046, -1, -1, -1}, {21057, -1, -1, -1}, {21182, -1, -1, -1}, {21179, -1, -1, -1}, {21330, -1, -1, -1}, {21332, -1, -1, -1}, {21331, -1, -1, -1}, {21329, -1, -1, -1}, {21350, -1, -1, -1}, {21367, -1, -1, -1}, {21368, -1, -1, -1}, {21369, -1, -1, -1}, {21462, -1, -1, -1}, {21460, -1, -1, -1}, {21463, -1, -1, -1}, {21619, -1, -1, -1}, {21621, -1, -1, -1}, {21654, -1, -1, -1}, {21624, -1, -1, -1}, {21653, -1, -1, -1}, {21632, -1, -1, -1}, {21627, -1, -1, -1}, {21623, -1, -1, -1}, {21636, -1, -1, -1}, {21650, -1, -1, -1}, {21638, -1, -1, -1}, {21628, -1, -1, -1}, {21648, -1, -1, -1}, {21617, -1, -1, -1}, {21622, -1, -1, -1}, {21644, -1, -1, -1}, {21658, -1, -1, -1}, {21602, -1, -1, -1}, {21608, -1, -1, -1}, {21643, -1, -1, -1}, {21629, -1, -1, -1}, {21646, -1, -1, -1}, {22266, -1, -1, -1}, {22403, -1, -1, -1}, {22391, -1, -1, -1}, {22378, -1, -1, -1}, {22377, -1, -1, -1}, {22369, -1, -1, -1}, {22374, -1, -1, -1}, {22372, -1, -1, -1}, {22396, -1, -1, -1}, {22812, -1, -1, -1}, {22857, -1, -1, -1}, {22855, -1, -1, -1}, {22856, -1, -1, -1}, {22852, -1, -1, -1}, {22868, -1, -1, -1}, {22974, -1, -1, -1}, {22971, -1, -1, -1}, {22996, -1, -1, -1}, {22969, -1, -1, -1}, {22958, -1, -1, -1}, {22993, -1, -1, -1}, {22982, -1, -1, -1}, {22992, -1, -1, -1}, {22989, -1, -1, -1}, {22987, -1, -1, -1}, {22995, -1, -1, -1}, {22986, -1, -1, -1}, {22959, -1, -1, -1}, {22963, -1, -1, -1}, {22994, -1, -1, -1}, {22981, -1, -1, -1}, {23391, -1, -1, -1}, {23396, -1, -1, -1}, {23395, -1, -1, -1}, {23447, -1, -1, -1}, {23450, -1, -1, -1}, {23448, -1, -1, -1}, {23452, -1, -1, -1}, {23449, -1, -1, -1}, {23451, -1, -1, -1}, {23578, -1, -1, -1}, {23624, -1, -1, -1}, {23621, -1, -1, -1}, {23622, -1, -1, -1}, {23735, -1, -1, -1}, {23713, -1, -1, -1}, {23736, -1, -1, -1}, {23721, -1, -1, -1}, {23723, -1, -1, -1}, {23729, -1, -1, -1}, {23731, -1, -1, -1}, {24088, -1, -1, -1}, {24090, -1, -1, -1}, {24086, -1, -1, -1}, {24085, -1, -1, -1}, {24091, -1, -1, -1}, {24081, -1, -1, -1}, {24184, -1, -1, -1}, {24218, -1, -1, -1}, {24215, -1, -1, -1}, {24220, -1, -1, -1}, {24213, -1, -1, -1}, {24214, -1, -1, -1}, {24310, -1, -1, -1}, {24358, -1, -1, -1}, {24359, -1, -1, -1}, {24361, -1, -1, -1}, {24448, -1, -1, -1}, {24449, -1, -1, -1}, {24447, -1, -1, -1}, {24444, -1, -1, -1}, {24541, -1, -1, -1}, {24544, -1, -1, -1}, {24573, -1, -1, -1}, {24565, -1, -1, -1}, {24575, -1, -1, -1}, {24591, -1, -1, -1}, {24596, -1, -1, -1}, {24623, -1, -1, -1}, {24629, -1, -1, -1}, {24598, -1, -1, -1}, {24618, -1, -1, -1}, {24597, -1, -1, -1}, {24609, -1, -1, -1}, {24615, -1, -1, -1}, {24617, -1, -1, -1}, {24619, -1, -1, -1}, {24603, -1, -1, -1}, {25110, -1, -1, -1}, {25109, -1, -1, -1}, {25151, -1, -1, -1}, {25150, -1, -1, -1}, {25152, -1, -1, -1}, {25215, -1, -1, -1}, {25289, -1, -1, -1}, {25292, -1, -1, -1}, {25284, -1, -1, -1}, {25279, -1, -1, -1}, {25282, -1, -1, -1}, {25273, -1, -1, -1}, {25298, -1, -1, -1}, {25307, -1, -1, -1}, {25259, -1, -1, -1}, {25299, -1, -1, -1}, {25300, -1, -1, -1}, {25291, -1, -1, -1}, {25288, -1, -1, -1}, {25256, -1, -1, -1}, {25277, -1, -1, -1}, {25276, -1, -1, -1}, {25296, -1, -1, -1}, {25305, -1, -1, -1}, {25287, -1, -1, -1}, {25293, -1, -1, -1}, {25269, -1, -1, -1}, {25306, -1, -1, -1}, {25265, -1, -1, -1}, {25304, -1, -1, -1}, {25302, -1, -1, -1}, {25303, -1, -1, -1}, {25286, -1, -1, -1}, {25260, -1, -1, -1}, {25294, -1, -1, -1}, {25918, -1, -1, -1}, {26023, -1, -1, -1}, {26044, -1, -1, -1}, {26106, -1, -1, -1}, {26132, -1, -1, -1}, {26131, -1, -1, -1}, {26124, -1, -1, -1}, {26118, -1, -1, -1}, {26114, -1, -1, -1}, {26126, -1, -1, -1}, {26112, -1, -1, -1}, {26127, -1, -1, -1}, {26133, -1, -1, -1} },
+ {{26122, -1, -1, -1}, {26119, -1, -1, -1}, {26381, -1, -1, -1}, {26379, -1, -1, -1}, {26477, -1, -1, -1}, {26507, -1, -1, -1}, {26517, -1, -1, -1}, {26481, -1, -1, -1}, {26524, -1, -1, -1}, {26483, -1, -1, -1}, {26487, -1, -1, -1}, {26503, -1, -1, -1}, {26525, -1, -1, -1}, {26519, -1, -1, -1}, {26479, -1, -1, -1}, {26480, -1, -1, -1}, {26495, -1, -1, -1}, {26505, -1, -1, -1}, {26494, -1, -1, -1}, {26512, -1, -1, -1}, {26485, -1, -1, -1}, {26522, -1, -1, -1}, {26515, -1, -1, -1}, {26492, -1, -1, -1}, {26474, -1, -1, -1}, {26482, -1, -1, -1}, {27427, -1, -1, -1}, {27494, -1, -1, -1}, {27495, -1, -1, -1}, {27519, -1, -1, -1}, {27667, -1, -1, -1}, {27675, -1, -1, -1}, {27875, -1, -1, -1}, {27880, -1, -1, -1}, {27891, -1, -1, -1}, {27825, -1, -1, -1}, {27852, -1, -1, -1}, {27877, -1, -1, -1}, {27827, -1, -1, -1}, {27837, -1, -1, -1}, {27838, -1, -1, -1}, {27836, -1, -1, -1}, {27874, -1, -1, -1}, {27819, -1, -1, -1}, {27861, -1, -1, -1}, {27859, -1, -1, -1}, {27832, -1, -1, -1}, {27844, -1, -1, -1}, {27833, -1, -1, -1}, {27841, -1, -1, -1}, {27822, -1, -1, -1}, {27863, -1, -1, -1}, {27845, -1, -1, -1}, {27889, -1, -1, -1}, {27839, -1, -1, -1}, {27835, -1, -1, -1}, {27873, -1, -1, -1}, {27867, -1, -1, -1}, {27850, -1, -1, -1}, {27820, -1, -1, -1}, {27887, -1, -1, -1}, {27868, -1, -1, -1}, {27862, -1, -1, -1}, {27872, -1, -1, -1}, {28821, -1, -1, -1}, {28814, -1, -1, -1}, {28818, -1, -1, -1}, {28810, -1, -1, -1}, {28825, -1, -1, -1}, {29228, -1, -1, -1}, {29229, -1, -1, -1}, {29240, -1, -1, -1}, {29256, -1, -1, -1}, {29287, -1, -1, -1}, {29289, -1, -1, -1}, {29376, -1, -1, -1}, {29390, -1, -1, -1}, {29401, -1, -1, -1}, {29399, -1, -1, -1}, {29392, -1, -1, -1}, {29609, -1, -1, -1}, {29608, -1, -1, -1}, {29599, -1, -1, -1}, {29611, -1, -1, -1}, {29605, -1, -1, -1}, {30013, -1, -1, -1}, {30109, -1, -1, -1}, {30105, -1, -1, -1}, {30106, -1, -1, -1}, {30340, -1, -1, -1}, {30402, -1, -1, -1}, {30450, -1, -1, -1}, {30452, -1, -1, -1}, {30693, -1, -1, -1}, {30717, -1, -1, -1}, {31038, -1, -1, -1}, {31040, -1, -1, -1}, {31041, -1, -1, -1}, {31177, -1, -1, -1}, {31176, -1, -1, -1}, {31354, -1, -1, -1}, {31353, -1, -1, -1}, {31482, -1, -1, -1}, {31998, -1, -1, -1}, {32596, -1, -1, -1}, {32652, -1, -1, -1}, {32651, -1, -1, -1}, {32773, -1, -1, -1}, {32954, -1, -1, -1}, {32933, -1, -1, -1}, {32930, -1, -1, -1}, {32945, -1, -1, -1}, {32929, -1, -1, -1}, {32939, -1, -1, -1}, {32937, -1, -1, -1}, {32948, -1, -1, -1}, {32938, -1, -1, -1}, {32943, -1, -1, -1}, {33253, -1, -1, -1}, {33278, -1, -1, -1}, {33293, -1, -1, -1}, {33459, -1, -1, -1}, {33437, -1, -1, -1}, {33433, -1, -1, -1}, {33453, -1, -1, -1}, {33469, -1, -1, -1}, {33439, -1, -1, -1}, {33465, -1, -1, -1}, {33457, -1, -1, -1}, {33452, -1, -1, -1}, {33445, -1, -1, -1}, {33455, -1, -1, -1}, {33464, -1, -1, -1}, {33443, -1, -1, -1}, {33456, -1, -1, -1}, {33470, -1, -1, -1}, {33463, -1, -1, -1}, {34382, -1, -1, -1}, {34417, -1, -1, -1}, {21021, -1, -1, -1}, {34920, -1, -1, -1}, {36555, -1, -1, -1}, {36814, -1, -1, -1}, {36820, -1, -1, -1}, {36817, -1, -1, -1}, {37045, -1, -1, -1}, {37048, -1, -1, -1}, {37041, -1, -1, -1}, {37046, -1, -1, -1}, {37319, -1, -1, -1}, {37329, -1, -1, -1}, {38263, -1, -1, -1}, {38272, -1, -1, -1}, {38428, -1, -1, -1}, {38464, -1, -1, -1}, {38463, -1, -1, -1}, {38459, -1, -1, -1}, {38468, -1, -1, -1}, {38466, -1, -1, -1}, {38585, -1, -1, -1}, {38632, -1, -1, -1}, {38738, -1, -1, -1}, {38750, -1, -1, -1}, {20127, -1, -1, -1}, {20141, -1, -1, -1}, {20142, -1, -1, -1}, {20449, -1, -1, -1}, {20405, -1, -1, -1}, {20399, -1, -1, -1}, {20415, -1, -1, -1}, {20448, -1, -1, -1}, {20433, -1, -1, -1}, {20431, -1, -1, -1}, {20445, -1, -1, -1}, {20419, -1, -1, -1}, {20406, -1, -1, -1}, {20440, -1, -1, -1}, {20447, -1, -1, -1}, {20426, -1, -1, -1}, {20439, -1, -1, -1}, {20398, -1, -1, -1}, {20432, -1, -1, -1}, {20420, -1, -1, -1}, {20418, -1, -1, -1}, {20442, -1, -1, -1}, {20430, -1, -1, -1}, {20446, -1, -1, -1}, {20407, -1, -1, -1}, {20823, -1, -1, -1}, {20882, -1, -1, -1}, {20881, -1, -1, -1}, {20896, -1, -1, -1}, {21070, -1, -1, -1}, {21059, -1, -1, -1}, {21066, -1, -1, -1}, {21069, -1, -1, -1}, {21068, -1, -1, -1}, {21067, -1, -1, -1}, {21063, -1, -1, -1}, {21191, -1, -1, -1}, {21193, -1, -1, -1}, {21187, -1, -1, -1}, {21185, -1, -1, -1}, {21261, -1, -1, -1}, {21335, -1, -1, -1}, {21371, -1, -1, -1}, {21402, -1, -1, -1}, {21467, -1, -1, -1}, {21676, -1, -1, -1}, {21696, -1, -1, -1}, {21672, -1, -1, -1}, {21710, -1, -1, -1}, {21705, -1, -1, -1}, {21688, -1, -1, -1}, {21670, -1, -1, -1}, {21683, -1, -1, -1}, {21703, -1, -1, -1}, {21698, -1, -1, -1}, {21693, -1, -1, -1}, {21674, -1, -1, -1}, {21697, -1, -1, -1}, {21700, -1, -1, -1}, {21704, -1, -1, -1}, {21679, -1, -1, -1}, {21675, -1, -1, -1}, {21681, -1, -1, -1}, {21691, -1, -1, -1}, {21673, -1, -1, -1}, {21671, -1, -1, -1}, {21695, -1, -1, -1}, {22271, -1, -1, -1}, {22402, -1, -1, -1}, {22411, -1, -1, -1}, {22432, -1, -1, -1}, {22435, -1, -1, -1}, {22434, -1, -1, -1}, {22478, -1, -1, -1}, {22446, -1, -1, -1}, {22419, -1, -1, -1}, {22869, -1, -1, -1}, {22865, -1, -1, -1}, {22863, -1, -1, -1}, {22862, -1, -1, -1}, {22864, -1, -1, -1}, {23004, -1, -1, -1}, {23000, -1, -1, -1}, {23039, -1, -1, -1}, {23011, -1, -1, -1}, {23016, -1, -1, -1}, {23043, -1, -1, -1}, {23013, -1, -1, -1}, {23018, -1, -1, -1}, {23002, -1, -1, -1}, {23014, -1, -1, -1}, {23041, -1, -1, -1}, {23035, -1, -1, -1} },
+ {{23401, -1, -1, -1}, {23459, -1, -1, -1}, {23462, -1, -1, -1}, {23460, -1, -1, -1}, {23458, -1, -1, -1}, {23461, -1, -1, -1}, {23553, -1, -1, -1}, {23630, -1, -1, -1}, {23631, -1, -1, -1}, {23629, -1, -1, -1}, {23627, -1, -1, -1}, {23769, -1, -1, -1}, {23762, -1, -1, -1}, {24055, -1, -1, -1}, {24093, -1, -1, -1}, {24101, -1, -1, -1}, {24095, -1, -1, -1}, {24189, -1, -1, -1}, {24224, -1, -1, -1}, {24230, -1, -1, -1}, {24314, -1, -1, -1}, {24328, -1, -1, -1}, {24365, -1, -1, -1}, {24421, -1, -1, -1}, {24456, -1, -1, -1}, {24453, -1, -1, -1}, {24458, -1, -1, -1}, {24459, -1, -1, -1}, {24455, -1, -1, -1}, {24460, -1, -1, -1}, {24457, -1, -1, -1}, {24594, -1, -1, -1}, {24605, -1, -1, -1}, {24608, -1, -1, -1}, {24613, -1, -1, -1}, {24590, -1, -1, -1}, {24616, -1, -1, -1}, {24653, -1, -1, -1}, {24688, -1, -1, -1}, {24680, -1, -1, -1}, {24674, -1, -1, -1}, {24646, -1, -1, -1}, {24643, -1, -1, -1}, {24684, -1, -1, -1}, {24683, -1, -1, -1}, {24682, -1, -1, -1}, {24676, -1, -1, -1}, {25153, -1, -1, -1}, {25308, -1, -1, -1}, {25366, -1, -1, -1}, {25353, -1, -1, -1}, {25340, -1, -1, -1}, {25325, -1, -1, -1}, {25345, -1, -1, -1}, {25326, -1, -1, -1}, {25341, -1, -1, -1}, {25351, -1, -1, -1}, {25329, -1, -1, -1}, {25335, -1, -1, -1}, {25327, -1, -1, -1}, {25324, -1, -1, -1}, {25342, -1, -1, -1}, {25332, -1, -1, -1}, {25361, -1, -1, -1}, {25346, -1, -1, -1}, {25919, -1, -1, -1}, {25925, -1, -1, -1}, {26027, -1, -1, -1}, {26045, -1, -1, -1}, {26082, -1, -1, -1}, {26149, -1, -1, -1}, {26157, -1, -1, -1}, {26144, -1, -1, -1}, {26151, -1, -1, -1}, {26159, -1, -1, -1}, {26143, -1, -1, -1}, {26152, -1, -1, -1}, {26161, -1, -1, -1}, {26148, -1, -1, -1}, {26359, -1, -1, -1}, {26623, -1, -1, -1}, {26579, -1, -1, -1}, {26609, -1, -1, -1}, {26580, -1, -1, -1}, {26576, -1, -1, -1}, {26604, -1, -1, -1}, {26550, -1, -1, -1}, {26543, -1, -1, -1}, {26613, -1, -1, -1}, {26601, -1, -1, -1}, {26607, -1, -1, -1}, {26564, -1, -1, -1}, {26577, -1, -1, -1}, {26548, -1, -1, -1}, {26586, -1, -1, -1}, {26597, -1, -1, -1}, {26552, -1, -1, -1}, {26575, -1, -1, -1}, {26590, -1, -1, -1}, {26611, -1, -1, -1}, {26544, -1, -1, -1}, {26585, -1, -1, -1}, {26594, -1, -1, -1}, {26589, -1, -1, -1}, {26578, -1, -1, -1}, {27498, -1, -1, -1}, {27523, -1, -1, -1}, {27526, -1, -1, -1}, {27573, -1, -1, -1}, {27602, -1, -1, -1}, {27607, -1, -1, -1}, {27679, -1, -1, -1}, {27849, -1, -1, -1}, {27915, -1, -1, -1}, {27954, -1, -1, -1}, {27946, -1, -1, -1}, {27969, -1, -1, -1}, {27941, -1, -1, -1}, {27916, -1, -1, -1}, {27953, -1, -1, -1}, {27934, -1, -1, -1}, {27927, -1, -1, -1}, {27963, -1, -1, -1}, {27965, -1, -1, -1}, {27966, -1, -1, -1}, {27958, -1, -1, -1}, {27931, -1, -1, -1}, {27893, -1, -1, -1}, {27961, -1, -1, -1}, {27943, -1, -1, -1}, {27960, -1, -1, -1}, {27945, -1, -1, -1}, {27950, -1, -1, -1}, {27957, -1, -1, -1}, {27918, -1, -1, -1}, {27947, -1, -1, -1}, {28843, -1, -1, -1}, {28858, -1, -1, -1}, {28851, -1, -1, -1}, {28844, -1, -1, -1}, {28847, -1, -1, -1}, {28845, -1, -1, -1}, {28856, -1, -1, -1}, {28846, -1, -1, -1}, {28836, -1, -1, -1}, {29232, -1, -1, -1}, {29298, -1, -1, -1}, {29295, -1, -1, -1}, {29300, -1, -1, -1}, {29417, -1, -1, -1}, {29408, -1, -1, -1}, {29409, -1, -1, -1}, {29623, -1, -1, -1}, {29642, -1, -1, -1}, {29627, -1, -1, -1}, {29618, -1, -1, -1}, {29645, -1, -1, -1}, {29632, -1, -1, -1}, {29619, -1, -1, -1}, {29978, -1, -1, -1}, {29997, -1, -1, -1}, {30031, -1, -1, -1}, {30028, -1, -1, -1}, {30030, -1, -1, -1}, {30027, -1, -1, -1}, {30123, -1, -1, -1}, {30116, -1, -1, -1}, {30117, -1, -1, -1}, {30114, -1, -1, -1}, {30115, -1, -1, -1}, {30328, -1, -1, -1}, {30342, -1, -1, -1}, {30343, -1, -1, -1}, {30344, -1, -1, -1}, {30408, -1, -1, -1}, {30406, -1, -1, -1}, {30403, -1, -1, -1}, {30405, -1, -1, -1}, {30465, -1, -1, -1}, {30457, -1, -1, -1}, {30456, -1, -1, -1}, {30473, -1, -1, -1}, {30475, -1, -1, -1}, {30462, -1, -1, -1}, {30460, -1, -1, -1}, {30471, -1, -1, -1}, {30684, -1, -1, -1}, {30722, -1, -1, -1}, {30740, -1, -1, -1}, {30732, -1, -1, -1}, {30733, -1, -1, -1}, {31046, -1, -1, -1}, {31049, -1, -1, -1}, {31048, -1, -1, -1}, {31047, -1, -1, -1}, {31161, -1, -1, -1}, {31162, -1, -1, -1}, {31185, -1, -1, -1}, {31186, -1, -1, -1}, {31179, -1, -1, -1}, {31359, -1, -1, -1}, {31361, -1, -1, -1}, {31487, -1, -1, -1}, {31485, -1, -1, -1}, {31869, -1, -1, -1}, {32002, -1, -1, -1}, {32005, -1, -1, -1}, {32000, -1, -1, -1}, {32009, -1, -1, -1}, {32007, -1, -1, -1}, {32004, -1, -1, -1}, {32006, -1, -1, -1}, {32568, -1, -1, -1}, {32654, -1, -1, -1}, {32703, -1, -1, -1}, {32784, -1, -1, -1}, {32781, -1, -1, -1}, {32785, -1, -1, -1}, {32822, -1, -1, -1}, {32982, -1, -1, -1}, {32997, -1, -1, -1}, {32986, -1, -1, -1}, {32963, -1, -1, -1}, {32964, -1, -1, -1}, {32972, -1, -1, -1}, {32993, -1, -1, -1}, {32987, -1, -1, -1}, {32974, -1, -1, -1}, {32990, -1, -1, -1}, {32996, -1, -1, -1}, {32989, -1, -1, -1}, {33268, -1, -1, -1}, {33314, -1, -1, -1}, {33511, -1, -1, -1}, {33539, -1, -1, -1}, {33541, -1, -1, -1}, {33507, -1, -1, -1}, {33499, -1, -1, -1}, {33510, -1, -1, -1}, {33540, -1, -1, -1}, {33509, -1, -1, -1}, {33538, -1, -1, -1}, {33545, -1, -1, -1}, {33490, -1, -1, -1}, {33495, -1, -1, -1}, {33521, -1, -1, -1}, {33537, -1, -1, -1}, {33500, -1, -1, -1}, {33492, -1, -1, -1}, {33489, -1, -1, -1}, {33502, -1, -1, -1}, {33491, -1, -1, -1}, {33503, -1, -1, -1}, {33519, -1, -1, -1}, {33542, -1, -1, -1}, {34384, -1, -1, -1} },
+ {{34425, -1, -1, -1}, {34427, -1, -1, -1}, {34426, -1, -1, -1}, {34893, -1, -1, -1}, {34923, -1, -1, -1}, {35201, -1, -1, -1}, {35284, -1, -1, -1}, {35336, -1, -1, -1}, {35330, -1, -1, -1}, {35331, -1, -1, -1}, {35998, -1, -1, -1}, {36000, -1, -1, -1}, {36212, -1, -1, -1}, {36211, -1, -1, -1}, {36276, -1, -1, -1}, {36557, -1, -1, -1}, {36556, -1, -1, -1}, {36848, -1, -1, -1}, {36838, -1, -1, -1}, {36834, -1, -1, -1}, {36842, -1, -1, -1}, {36837, -1, -1, -1}, {36845, -1, -1, -1}, {36843, -1, -1, -1}, {36836, -1, -1, -1}, {36840, -1, -1, -1}, {37066, -1, -1, -1}, {37070, -1, -1, -1}, {37057, -1, -1, -1}, {37059, -1, -1, -1}, {37195, -1, -1, -1}, {37194, -1, -1, -1}, {37325, -1, -1, -1}, {38274, -1, -1, -1}, {38480, -1, -1, -1}, {38475, -1, -1, -1}, {38476, -1, -1, -1}, {38477, -1, -1, -1}, {38754, -1, -1, -1}, {38761, -1, -1, -1}, {38859, -1, -1, -1}, {38893, -1, -1, -1}, {38899, -1, -1, -1}, {38913, -1, -1, -1}, {39080, -1, -1, -1}, {39131, -1, -1, -1}, {39135, -1, -1, -1}, {39318, -1, -1, -1}, {39321, -1, -1, -1}, {20056, -1, -1, -1}, {20147, -1, -1, -1}, {20492, -1, -1, -1}, {20493, -1, -1, -1}, {20515, -1, -1, -1}, {20463, -1, -1, -1}, {20518, -1, -1, -1}, {20517, -1, -1, -1}, {20472, -1, -1, -1}, {20521, -1, -1, -1}, {20502, -1, -1, -1}, {20486, -1, -1, -1}, {20540, -1, -1, -1}, {20511, -1, -1, -1}, {20506, -1, -1, -1}, {20498, -1, -1, -1}, {20497, -1, -1, -1}, {20474, -1, -1, -1}, {20480, -1, -1, -1}, {20500, -1, -1, -1}, {20520, -1, -1, -1}, {20465, -1, -1, -1}, {20513, -1, -1, -1}, {20491, -1, -1, -1}, {20505, -1, -1, -1}, {20504, -1, -1, -1}, {20467, -1, -1, -1}, {20462, -1, -1, -1}, {20525, -1, -1, -1}, {20522, -1, -1, -1}, {20478, -1, -1, -1}, {20523, -1, -1, -1}, {20489, -1, -1, -1}, {20860, -1, -1, -1}, {20900, -1, -1, -1}, {20901, -1, -1, -1}, {20898, -1, -1, -1}, {20941, -1, -1, -1}, {20940, -1, -1, -1}, {20934, -1, -1, -1}, {20939, -1, -1, -1}, {21078, -1, -1, -1}, {21084, -1, -1, -1}, {21076, -1, -1, -1}, {21083, -1, -1, -1}, {21085, -1, -1, -1}, {21290, -1, -1, -1}, {21375, -1, -1, -1}, {21407, -1, -1, -1}, {21405, -1, -1, -1}, {21471, -1, -1, -1}, {21736, -1, -1, -1}, {21776, -1, -1, -1}, {21761, -1, -1, -1}, {21815, -1, -1, -1}, {21756, -1, -1, -1}, {21733, -1, -1, -1}, {21746, -1, -1, -1}, {21766, -1, -1, -1}, {21754, -1, -1, -1}, {21780, -1, -1, -1}, {21737, -1, -1, -1}, {21741, -1, -1, -1}, {21729, -1, -1, -1}, {21769, -1, -1, -1}, {21742, -1, -1, -1}, {21738, -1, -1, -1}, {21734, -1, -1, -1}, {21799, -1, -1, -1}, {21767, -1, -1, -1}, {21757, -1, -1, -1}, {21775, -1, -1, -1}, {22275, -1, -1, -1}, {22276, -1, -1, -1}, {22466, -1, -1, -1}, {22484, -1, -1, -1}, {22475, -1, -1, -1}, {22467, -1, -1, -1}, {22537, -1, -1, -1}, {22799, -1, -1, -1}, {22871, -1, -1, -1}, {22872, -1, -1, -1}, {22874, -1, -1, -1}, {23057, -1, -1, -1}, {23064, -1, -1, -1}, {23068, -1, -1, -1}, {23071, -1, -1, -1}, {23067, -1, -1, -1}, {23059, -1, -1, -1}, {23020, -1, -1, -1}, {23072, -1, -1, -1}, {23075, -1, -1, -1}, {23081, -1, -1, -1}, {23077, -1, -1, -1}, {23052, -1, -1, -1}, {23049, -1, -1, -1}, {23403, -1, -1, -1}, {23640, -1, -1, -1}, {23472, -1, -1, -1}, {23475, -1, -1, -1}, {23478, -1, -1, -1}, {23476, -1, -1, -1}, {23470, -1, -1, -1}, {23477, -1, -1, -1}, {23481, -1, -1, -1}, {23480, -1, -1, -1}, {23556, -1, -1, -1}, {23633, -1, -1, -1}, {23637, -1, -1, -1}, {23632, -1, -1, -1}, {23789, -1, -1, -1}, {23805, -1, -1, -1}, {23803, -1, -1, -1}, {23786, -1, -1, -1}, {23784, -1, -1, -1}, {23792, -1, -1, -1}, {23798, -1, -1, -1}, {23809, -1, -1, -1}, {23796, -1, -1, -1}, {24046, -1, -1, -1}, {24109, -1, -1, -1}, {24107, -1, -1, -1}, {24235, -1, -1, -1}, {24237, -1, -1, -1}, {24231, -1, -1, -1}, {24369, -1, -1, -1}, {24466, -1, -1, -1}, {24465, -1, -1, -1}, {24464, -1, -1, -1}, {24665, -1, -1, -1}, {24675, -1, -1, -1}, {24677, -1, -1, -1}, {24656, -1, -1, -1}, {24661, -1, -1, -1}, {24685, -1, -1, -1}, {24681, -1, -1, -1}, {24687, -1, -1, -1}, {24708, -1, -1, -1}, {24735, -1, -1, -1}, {24730, -1, -1, -1}, {24717, -1, -1, -1}, {24724, -1, -1, -1}, {24716, -1, -1, -1}, {24709, -1, -1, -1}, {24726, -1, -1, -1}, {25159, -1, -1, -1}, {25331, -1, -1, -1}, {25352, -1, -1, -1}, {25343, -1, -1, -1}, {25422, -1, -1, -1}, {25406, -1, -1, -1}, {25391, -1, -1, -1}, {25429, -1, -1, -1}, {25410, -1, -1, -1}, {25414, -1, -1, -1}, {25423, -1, -1, -1}, {25417, -1, -1, -1}, {25402, -1, -1, -1}, {25424, -1, -1, -1}, {25405, -1, -1, -1}, {25386, -1, -1, -1}, {25387, -1, -1, -1}, {25384, -1, -1, -1}, {25421, -1, -1, -1}, {25420, -1, -1, -1}, {25928, -1, -1, -1}, {25929, -1, -1, -1}, {26009, -1, -1, -1}, {26049, -1, -1, -1}, {26053, -1, -1, -1}, {26178, -1, -1, -1}, {26185, -1, -1, -1}, {26191, -1, -1, -1}, {26179, -1, -1, -1}, {26194, -1, -1, -1}, {26188, -1, -1, -1}, {26181, -1, -1, -1}, {26177, -1, -1, -1}, {26360, -1, -1, -1}, {26388, -1, -1, -1}, {26389, -1, -1, -1}, {26391, -1, -1, -1}, {26657, -1, -1, -1}, {26680, -1, -1, -1}, {26696, -1, -1, -1}, {26694, -1, -1, -1}, {26707, -1, -1, -1}, {26681, -1, -1, -1}, {26690, -1, -1, -1}, {26708, -1, -1, -1}, {26665, -1, -1, -1}, {26803, -1, -1, -1}, {26647, -1, -1, -1}, {26700, -1, -1, -1}, {26705, -1, -1, -1}, {26685, -1, -1, -1}, {26612, -1, -1, -1}, {26704, -1, -1, -1}, {26688, -1, -1, -1}, {26684, -1, -1, -1}, {26691, -1, -1, -1}, {26666, -1, -1, -1}, {26693, -1, -1, -1}, {26643, -1, -1, -1}, {26648, -1, -1, -1}, {26689, -1, -1, -1}, {27530, -1, -1, -1} },
+ {{27529, -1, -1, -1}, {27575, -1, -1, -1}, {27683, -1, -1, -1}, {27687, -1, -1, -1}, {27688, -1, -1, -1}, {27686, -1, -1, -1}, {27684, -1, -1, -1}, {27888, -1, -1, -1}, {28010, -1, -1, -1}, {28053, -1, -1, -1}, {28040, -1, -1, -1}, {28039, -1, -1, -1}, {28006, -1, -1, -1}, {28024, -1, -1, -1}, {28023, -1, -1, -1}, {27993, -1, -1, -1}, {28051, -1, -1, -1}, {28012, -1, -1, -1}, {28041, -1, -1, -1}, {28014, -1, -1, -1}, {27994, -1, -1, -1}, {28020, -1, -1, -1}, {28009, -1, -1, -1}, {28044, -1, -1, -1}, {28042, -1, -1, -1}, {28025, -1, -1, -1}, {28037, -1, -1, -1}, {28005, -1, -1, -1}, {28052, -1, -1, -1}, {28874, -1, -1, -1}, {28888, -1, -1, -1}, {28900, -1, -1, -1}, {28889, -1, -1, -1}, {28872, -1, -1, -1}, {28879, -1, -1, -1}, {29241, -1, -1, -1}, {29305, -1, -1, -1}, {29436, -1, -1, -1}, {29433, -1, -1, -1}, {29437, -1, -1, -1}, {29432, -1, -1, -1}, {29431, -1, -1, -1}, {29574, -1, -1, -1}, {29677, -1, -1, -1}, {29705, -1, -1, -1}, {29678, -1, -1, -1}, {29664, -1, -1, -1}, {29674, -1, -1, -1}, {29662, -1, -1, -1}, {30036, -1, -1, -1}, {30045, -1, -1, -1}, {30044, -1, -1, -1}, {30042, -1, -1, -1}, {30041, -1, -1, -1}, {30142, -1, -1, -1}, {30149, -1, -1, -1}, {30151, -1, -1, -1}, {30130, -1, -1, -1}, {30131, -1, -1, -1}, {30141, -1, -1, -1}, {30140, -1, -1, -1}, {30137, -1, -1, -1}, {30146, -1, -1, -1}, {30136, -1, -1, -1}, {30347, -1, -1, -1}, {30384, -1, -1, -1}, {30410, -1, -1, -1}, {30413, -1, -1, -1}, {30414, -1, -1, -1}, {30505, -1, -1, -1}, {30495, -1, -1, -1}, {30496, -1, -1, -1}, {30504, -1, -1, -1}, {30697, -1, -1, -1}, {30768, -1, -1, -1}, {30759, -1, -1, -1}, {30776, -1, -1, -1}, {30749, -1, -1, -1}, {30772, -1, -1, -1}, {30775, -1, -1, -1}, {30757, -1, -1, -1}, {30765, -1, -1, -1}, {30752, -1, -1, -1}, {30751, -1, -1, -1}, {30770, -1, -1, -1}, {31061, -1, -1, -1}, {31056, -1, -1, -1}, {31072, -1, -1, -1}, {31071, -1, -1, -1}, {31062, -1, -1, -1}, {31070, -1, -1, -1}, {31069, -1, -1, -1}, {31063, -1, -1, -1}, {31066, -1, -1, -1}, {31204, -1, -1, -1}, {31203, -1, -1, -1}, {31207, -1, -1, -1}, {31199, -1, -1, -1}, {31206, -1, -1, -1}, {31209, -1, -1, -1}, {31192, -1, -1, -1}, {31364, -1, -1, -1}, {31368, -1, -1, -1}, {31449, -1, -1, -1}, {31494, -1, -1, -1}, {31505, -1, -1, -1}, {31881, -1, -1, -1}, {32033, -1, -1, -1}, {32023, -1, -1, -1}, {32011, -1, -1, -1}, {32010, -1, -1, -1}, {32032, -1, -1, -1}, {32034, -1, -1, -1}, {32020, -1, -1, -1}, {32016, -1, -1, -1}, {32021, -1, -1, -1}, {32026, -1, -1, -1}, {32028, -1, -1, -1}, {32013, -1, -1, -1}, {32025, -1, -1, -1}, {32027, -1, -1, -1}, {32570, -1, -1, -1}, {32607, -1, -1, -1}, {32660, -1, -1, -1}, {32709, -1, -1, -1}, {32705, -1, -1, -1}, {32774, -1, -1, -1}, {32772, -1, -1, -1}, {32792, -1, -1, -1}, {32789, -1, -1, -1}, {32793, -1, -1, -1}, {32791, -1, -1, -1}, {32829, -1, -1, -1}, {32831, -1, -1, -1}, {33009, -1, -1, -1}, {33026, -1, -1, -1}, {33008, -1, -1, -1}, {33029, -1, -1, -1}, {33005, -1, -1, -1}, {33012, -1, -1, -1}, {33030, -1, -1, -1}, {33016, -1, -1, -1}, {33011, -1, -1, -1}, {33032, -1, -1, -1}, {33021, -1, -1, -1}, {33034, -1, -1, -1}, {33020, -1, -1, -1}, {33007, -1, -1, -1}, {33261, -1, -1, -1}, {33260, -1, -1, -1}, {33280, -1, -1, -1}, {33296, -1, -1, -1}, {33322, -1, -1, -1}, {33323, -1, -1, -1}, {33320, -1, -1, -1}, {33324, -1, -1, -1}, {33467, -1, -1, -1}, {33579, -1, -1, -1}, {33618, -1, -1, -1}, {33620, -1, -1, -1}, {33610, -1, -1, -1}, {33592, -1, -1, -1}, {33616, -1, -1, -1}, {33609, -1, -1, -1}, {33589, -1, -1, -1}, {33588, -1, -1, -1}, {33615, -1, -1, -1}, {33586, -1, -1, -1}, {33593, -1, -1, -1}, {33590, -1, -1, -1}, {33559, -1, -1, -1}, {33600, -1, -1, -1}, {33585, -1, -1, -1}, {33576, -1, -1, -1}, {33603, -1, -1, -1}, {34388, -1, -1, -1}, {34442, -1, -1, -1}, {34474, -1, -1, -1}, {34451, -1, -1, -1}, {34468, -1, -1, -1}, {34473, -1, -1, -1}, {34444, -1, -1, -1}, {34467, -1, -1, -1}, {34460, -1, -1, -1}, {34928, -1, -1, -1}, {34935, -1, -1, -1}, {34945, -1, -1, -1}, {34946, -1, -1, -1}, {34941, -1, -1, -1}, {34937, -1, -1, -1}, {35352, -1, -1, -1}, {35344, -1, -1, -1}, {35342, -1, -1, -1}, {35340, -1, -1, -1}, {35349, -1, -1, -1}, {35338, -1, -1, -1}, {35351, -1, -1, -1}, {35347, -1, -1, -1}, {35350, -1, -1, -1}, {35343, -1, -1, -1}, {35345, -1, -1, -1}, {35912, -1, -1, -1}, {35962, -1, -1, -1}, {35961, -1, -1, -1}, {36001, -1, -1, -1}, {36002, -1, -1, -1}, {36215, -1, -1, -1}, {36524, -1, -1, -1}, {36562, -1, -1, -1}, {36564, -1, -1, -1}, {36559, -1, -1, -1}, {36785, -1, -1, -1}, {36865, -1, -1, -1}, {36870, -1, -1, -1}, {36855, -1, -1, -1}, {36864, -1, -1, -1}, {36858, -1, -1, -1}, {36852, -1, -1, -1}, {36867, -1, -1, -1}, {36861, -1, -1, -1}, {36869, -1, -1, -1}, {36856, -1, -1, -1}, {37013, -1, -1, -1}, {37089, -1, -1, -1}, {37085, -1, -1, -1}, {37090, -1, -1, -1}, {37202, -1, -1, -1}, {37197, -1, -1, -1}, {37196, -1, -1, -1}, {37336, -1, -1, -1}, {37341, -1, -1, -1}, {37335, -1, -1, -1}, {37340, -1, -1, -1}, {37337, -1, -1, -1}, {38275, -1, -1, -1}, {38498, -1, -1, -1}, {38499, -1, -1, -1}, {38497, -1, -1, -1}, {38491, -1, -1, -1}, {38493, -1, -1, -1}, {38500, -1, -1, -1}, {38488, -1, -1, -1}, {38494, -1, -1, -1}, {38587, -1, -1, -1}, {39138, -1, -1, -1}, {39340, -1, -1, -1}, {12003, 39592, -1, -1}, {39640, -1, -1, -1}, {39717, -1, -1, -1}, {39730, -1, -1, -1}, {39740, -1, -1, -1}, {20094, -1, -1, -1}, {20602, -1, -1, -1}, {20605, -1, -1, -1}, {20572, -1, -1, -1}, {20551, -1, -1, -1} },
+ {{20547, -1, -1, -1}, {20556, -1, -1, -1}, {20570, -1, -1, -1}, {20553, -1, -1, -1}, {20581, -1, -1, -1}, {20598, -1, -1, -1}, {20558, -1, -1, -1}, {20565, -1, -1, -1}, {20597, -1, -1, -1}, {20596, -1, -1, -1}, {20599, -1, -1, -1}, {20559, -1, -1, -1}, {20495, -1, -1, -1}, {20591, -1, -1, -1}, {20589, -1, -1, -1}, {20828, -1, -1, -1}, {20885, -1, -1, -1}, {20976, -1, -1, -1}, {21098, -1, -1, -1}, {21103, -1, -1, -1}, {21202, -1, -1, -1}, {21209, -1, -1, -1}, {21208, -1, -1, -1}, {21205, -1, -1, -1}, {21264, -1, -1, -1}, {21263, -1, -1, -1}, {21273, -1, -1, -1}, {21311, -1, -1, -1}, {21312, -1, -1, -1}, {21310, -1, -1, -1}, {21443, -1, -1, -1}, {26364, -1, -1, -1}, {21830, -1, -1, -1}, {21866, -1, -1, -1}, {21862, -1, -1, -1}, {21828, -1, -1, -1}, {21854, -1, -1, -1}, {21857, -1, -1, -1}, {21827, -1, -1, -1}, {21834, -1, -1, -1}, {21809, -1, -1, -1}, {21846, -1, -1, -1}, {21839, -1, -1, -1}, {21845, -1, -1, -1}, {21807, -1, -1, -1}, {21860, -1, -1, -1}, {21816, -1, -1, -1}, {21806, -1, -1, -1}, {21852, -1, -1, -1}, {21804, -1, -1, -1}, {21859, -1, -1, -1}, {21811, -1, -1, -1}, {21825, -1, -1, -1}, {21847, -1, -1, -1}, {22280, -1, -1, -1}, {22283, -1, -1, -1}, {22281, -1, -1, -1}, {22495, -1, -1, -1}, {22533, -1, -1, -1}, {22538, -1, -1, -1}, {22534, -1, -1, -1}, {22496, -1, -1, -1}, {22500, -1, -1, -1}, {22522, -1, -1, -1}, {22530, -1, -1, -1}, {22581, -1, -1, -1}, {22519, -1, -1, -1}, {22521, -1, -1, -1}, {22816, -1, -1, -1}, {22882, -1, -1, -1}, {23094, -1, -1, -1}, {23105, -1, -1, -1}, {23113, -1, -1, -1}, {23142, -1, -1, -1}, {23146, -1, -1, -1}, {23104, -1, -1, -1}, {23100, -1, -1, -1}, {23138, -1, -1, -1}, {23130, -1, -1, -1}, {23110, -1, -1, -1}, {23114, -1, -1, -1}, {23408, -1, -1, -1}, {23495, -1, -1, -1}, {23493, -1, -1, -1}, {23492, -1, -1, -1}, {23490, -1, -1, -1}, {23487, -1, -1, -1}, {23494, -1, -1, -1}, {23561, -1, -1, -1}, {23560, -1, -1, -1}, {23559, -1, -1, -1}, {23648, -1, -1, -1}, {23644, -1, -1, -1}, {23645, -1, -1, -1}, {23815, -1, -1, -1}, {23814, -1, -1, -1}, {23822, -1, -1, -1}, {23835, -1, -1, -1}, {23830, -1, -1, -1}, {23842, -1, -1, -1}, {23825, -1, -1, -1}, {23849, -1, -1, -1}, {23828, -1, -1, -1}, {23833, -1, -1, -1}, {23844, -1, -1, -1}, {23847, -1, -1, -1}, {23831, -1, -1, -1}, {24034, -1, -1, -1}, {24120, -1, -1, -1}, {24118, -1, -1, -1}, {24115, -1, -1, -1}, {24119, -1, -1, -1}, {24247, -1, -1, -1}, {24248, -1, -1, -1}, {24246, -1, -1, -1}, {24245, -1, -1, -1}, {24254, -1, -1, -1}, {24373, -1, -1, -1}, {24375, -1, -1, -1}, {24407, -1, -1, -1}, {24428, -1, -1, -1}, {24425, -1, -1, -1}, {24427, -1, -1, -1}, {24471, -1, -1, -1}, {24473, -1, -1, -1}, {24478, -1, -1, -1}, {24472, -1, -1, -1}, {24481, -1, -1, -1}, {24480, -1, -1, -1}, {24476, -1, -1, -1}, {24703, -1, -1, -1}, {24739, -1, -1, -1}, {24713, -1, -1, -1}, {24736, -1, -1, -1}, {24744, -1, -1, -1}, {24779, -1, -1, -1}, {24756, -1, -1, -1}, {24806, -1, -1, -1}, {24765, -1, -1, -1}, {24773, -1, -1, -1}, {24763, -1, -1, -1}, {24757, -1, -1, -1}, {24796, -1, -1, -1}, {24764, -1, -1, -1}, {24792, -1, -1, -1}, {24789, -1, -1, -1}, {24774, -1, -1, -1}, {24799, -1, -1, -1}, {24760, -1, -1, -1}, {24794, -1, -1, -1}, {24775, -1, -1, -1}, {25114, -1, -1, -1}, {25115, -1, -1, -1}, {25160, -1, -1, -1}, {25504, -1, -1, -1}, {25511, -1, -1, -1}, {25458, -1, -1, -1}, {25494, -1, -1, -1}, {25506, -1, -1, -1}, {25509, -1, -1, -1}, {25463, -1, -1, -1}, {25447, -1, -1, -1}, {25496, -1, -1, -1}, {25514, -1, -1, -1}, {25457, -1, -1, -1}, {25513, -1, -1, -1}, {25481, -1, -1, -1}, {25475, -1, -1, -1}, {25499, -1, -1, -1}, {25451, -1, -1, -1}, {25512, -1, -1, -1}, {25476, -1, -1, -1}, {25480, -1, -1, -1}, {25497, -1, -1, -1}, {25505, -1, -1, -1}, {25516, -1, -1, -1}, {25490, -1, -1, -1}, {25487, -1, -1, -1}, {25472, -1, -1, -1}, {25467, -1, -1, -1}, {25449, -1, -1, -1}, {25448, -1, -1, -1}, {25466, -1, -1, -1}, {25949, -1, -1, -1}, {25942, -1, -1, -1}, {25937, -1, -1, -1}, {25945, -1, -1, -1}, {25943, -1, -1, -1}, {21855, -1, -1, -1}, {25935, -1, -1, -1}, {25944, -1, -1, -1}, {25941, -1, -1, -1}, {25940, -1, -1, -1}, {26012, -1, -1, -1}, {26011, -1, -1, -1}, {26028, -1, -1, -1}, {26063, -1, -1, -1}, {26059, -1, -1, -1}, {26060, -1, -1, -1}, {26062, -1, -1, -1}, {26205, -1, -1, -1}, {26202, -1, -1, -1}, {26212, -1, -1, -1}, {26216, -1, -1, -1}, {26214, -1, -1, -1}, {26206, -1, -1, -1}, {26361, -1, -1, -1}, {21207, -1, -1, -1}, {26395, -1, -1, -1}, {26753, -1, -1, -1}, {26799, -1, -1, -1}, {26786, -1, -1, -1}, {26771, -1, -1, -1}, {26805, -1, -1, -1}, {26751, -1, -1, -1}, {26742, -1, -1, -1}, {26801, -1, -1, -1}, {26791, -1, -1, -1}, {26775, -1, -1, -1}, {26800, -1, -1, -1}, {26755, -1, -1, -1}, {26820, -1, -1, -1}, {26797, -1, -1, -1}, {26758, -1, -1, -1}, {26757, -1, -1, -1}, {26772, -1, -1, -1}, {26781, -1, -1, -1}, {26792, -1, -1, -1}, {26783, -1, -1, -1}, {26785, -1, -1, -1}, {26754, -1, -1, -1}, {27442, -1, -1, -1}, {27578, -1, -1, -1}, {27627, -1, -1, -1}, {27628, -1, -1, -1}, {27691, -1, -1, -1}, {28046, -1, -1, -1}, {28092, -1, -1, -1}, {28147, -1, -1, -1}, {28121, -1, -1, -1}, {28082, -1, -1, -1}, {28129, -1, -1, -1}, {28108, -1, -1, -1}, {28132, -1, -1, -1}, {28155, -1, -1, -1}, {28154, -1, -1, -1}, {28165, -1, -1, -1}, {28103, -1, -1, -1}, {28107, -1, -1, -1}, {28079, -1, -1, -1}, {28113, -1, -1, -1}, {28078, -1, -1, -1}, {28126, -1, -1, -1}, {28153, -1, -1, -1}, {28088, -1, -1, -1}, {28151, -1, -1, -1} },
+ {{28149, -1, -1, -1}, {28101, -1, -1, -1}, {28114, -1, -1, -1}, {28186, -1, -1, -1}, {28085, -1, -1, -1}, {28122, -1, -1, -1}, {28139, -1, -1, -1}, {28120, -1, -1, -1}, {28138, -1, -1, -1}, {28145, -1, -1, -1}, {28142, -1, -1, -1}, {28136, -1, -1, -1}, {28102, -1, -1, -1}, {28100, -1, -1, -1}, {28074, -1, -1, -1}, {28140, -1, -1, -1}, {28095, -1, -1, -1}, {28134, -1, -1, -1}, {28921, -1, -1, -1}, {28937, -1, -1, -1}, {28938, -1, -1, -1}, {28925, -1, -1, -1}, {28911, -1, -1, -1}, {29245, -1, -1, -1}, {29309, -1, -1, -1}, {29313, -1, -1, -1}, {29468, -1, -1, -1}, {29467, -1, -1, -1}, {29462, -1, -1, -1}, {29459, -1, -1, -1}, {29465, -1, -1, -1}, {29575, -1, -1, -1}, {29701, -1, -1, -1}, {29706, -1, -1, -1}, {29699, -1, -1, -1}, {29702, -1, -1, -1}, {29694, -1, -1, -1}, {29709, -1, -1, -1}, {29920, -1, -1, -1}, {29942, -1, -1, -1}, {29943, -1, -1, -1}, {29980, -1, -1, -1}, {29986, -1, -1, -1}, {30053, -1, -1, -1}, {30054, -1, -1, -1}, {30050, -1, -1, -1}, {30064, -1, -1, -1}, {30095, -1, -1, -1}, {30164, -1, -1, -1}, {30165, -1, -1, -1}, {30133, -1, -1, -1}, {30154, -1, -1, -1}, {30157, -1, -1, -1}, {30350, -1, -1, -1}, {30420, -1, -1, -1}, {30418, -1, -1, -1}, {30427, -1, -1, -1}, {30519, -1, -1, -1}, {30526, -1, -1, -1}, {30524, -1, -1, -1}, {30518, -1, -1, -1}, {30520, -1, -1, -1}, {30522, -1, -1, -1}, {30827, -1, -1, -1}, {30787, -1, -1, -1}, {30798, -1, -1, -1}, {31077, -1, -1, -1}, {31080, -1, -1, -1}, {31085, -1, -1, -1}, {31227, -1, -1, -1}, {31378, -1, -1, -1}, {31381, -1, -1, -1}, {31520, -1, -1, -1}, {31528, -1, -1, -1}, {31515, -1, -1, -1}, {31532, -1, -1, -1}, {31526, -1, -1, -1}, {31513, -1, -1, -1}, {31518, -1, -1, -1}, {31534, -1, -1, -1}, {31890, -1, -1, -1}, {31895, -1, -1, -1}, {31893, -1, -1, -1}, {32070, -1, -1, -1}, {32067, -1, -1, -1}, {32113, -1, -1, -1}, {32046, -1, -1, -1}, {32057, -1, -1, -1}, {32060, -1, -1, -1}, {32064, -1, -1, -1}, {32048, -1, -1, -1}, {32051, -1, -1, -1}, {32068, -1, -1, -1}, {32047, -1, -1, -1}, {32066, -1, -1, -1}, {32050, -1, -1, -1}, {32049, -1, -1, -1}, {32573, -1, -1, -1}, {32670, -1, -1, -1}, {32666, -1, -1, -1}, {32716, -1, -1, -1}, {32718, -1, -1, -1}, {32722, -1, -1, -1}, {32796, -1, -1, -1}, {32842, -1, -1, -1}, {32838, -1, -1, -1}, {33071, -1, -1, -1}, {33046, -1, -1, -1}, {33059, -1, -1, -1}, {33067, -1, -1, -1}, {33065, -1, -1, -1}, {33072, -1, -1, -1}, {33060, -1, -1, -1}, {33282, -1, -1, -1}, {33333, -1, -1, -1}, {33335, -1, -1, -1}, {33334, -1, -1, -1}, {33337, -1, -1, -1}, {33678, -1, -1, -1}, {33694, -1, -1, -1}, {33688, -1, -1, -1}, {33656, -1, -1, -1}, {33698, -1, -1, -1}, {33686, -1, -1, -1}, {33725, -1, -1, -1}, {33707, -1, -1, -1}, {33682, -1, -1, -1}, {33674, -1, -1, -1}, {33683, -1, -1, -1}, {33673, -1, -1, -1}, {33696, -1, -1, -1}, {33655, -1, -1, -1}, {33659, -1, -1, -1}, {33660, -1, -1, -1}, {33670, -1, -1, -1}, {33703, -1, -1, -1}, {34389, -1, -1, -1}, {24426, -1, -1, -1}, {34503, -1, -1, -1}, {34496, -1, -1, -1}, {34486, -1, -1, -1}, {34500, -1, -1, -1}, {34485, -1, -1, -1}, {34502, -1, -1, -1}, {34507, -1, -1, -1}, {34481, -1, -1, -1}, {34479, -1, -1, -1}, {34505, -1, -1, -1}, {34899, -1, -1, -1}, {34974, -1, -1, -1}, {34952, -1, -1, -1}, {34987, -1, -1, -1}, {34962, -1, -1, -1}, {34966, -1, -1, -1}, {34957, -1, -1, -1}, {34955, -1, -1, -1}, {35219, -1, -1, -1}, {35215, -1, -1, -1}, {35370, -1, -1, -1}, {35357, -1, -1, -1}, {35363, -1, -1, -1}, {35365, -1, -1, -1}, {35377, -1, -1, -1}, {35373, -1, -1, -1}, {35359, -1, -1, -1}, {35355, -1, -1, -1}, {35362, -1, -1, -1}, {35913, -1, -1, -1}, {35930, -1, -1, -1}, {36009, -1, -1, -1}, {36012, -1, -1, -1}, {36011, -1, -1, -1}, {36008, -1, -1, -1}, {36010, -1, -1, -1}, {36007, -1, -1, -1}, {36199, -1, -1, -1}, {36198, -1, -1, -1}, {36286, -1, -1, -1}, {36282, -1, -1, -1}, {36571, -1, -1, -1}, {36575, -1, -1, -1}, {36889, -1, -1, -1}, {36877, -1, -1, -1}, {36890, -1, -1, -1}, {36887, -1, -1, -1}, {36899, -1, -1, -1}, {36895, -1, -1, -1}, {36893, -1, -1, -1}, {36880, -1, -1, -1}, {36885, -1, -1, -1}, {36894, -1, -1, -1}, {36896, -1, -1, -1}, {36879, -1, -1, -1}, {36898, -1, -1, -1}, {36886, -1, -1, -1}, {36891, -1, -1, -1}, {36884, -1, -1, -1}, {37096, -1, -1, -1}, {37101, -1, -1, -1}, {37117, -1, -1, -1}, {37207, -1, -1, -1}, {37326, -1, -1, -1}, {37365, -1, -1, -1}, {37350, -1, -1, -1}, {37347, -1, -1, -1}, {37351, -1, -1, -1}, {37357, -1, -1, -1}, {37353, -1, -1, -1}, {38281, -1, -1, -1}, {38506, -1, -1, -1}, {38517, -1, -1, -1}, {38515, -1, -1, -1}, {38520, -1, -1, -1}, {38512, -1, -1, -1}, {38516, -1, -1, -1}, {38518, -1, -1, -1}, {38519, -1, -1, -1}, {38508, -1, -1, -1}, {38592, -1, -1, -1}, {38634, -1, -1, -1}, {38633, -1, -1, -1}, {31456, -1, -1, -1}, {31455, -1, -1, -1}, {38914, -1, -1, -1}, {38915, -1, -1, -1}, {39770, -1, -1, -1}, {40165, -1, -1, -1}, {40565, -1, -1, -1}, {40575, -1, -1, -1}, {40613, -1, -1, -1}, {40635, -1, -1, -1}, {20642, -1, -1, -1}, {20621, -1, -1, -1}, {20613, -1, -1, -1}, {20633, -1, -1, -1}, {20625, -1, -1, -1}, {20608, -1, -1, -1}, {20630, -1, -1, -1}, {20632, -1, -1, -1}, {20634, -1, -1, -1}, {26368, -1, -1, -1}, {20977, -1, -1, -1}, {21106, -1, -1, -1}, {21108, -1, -1, -1}, {21109, -1, -1, -1}, {21097, -1, -1, -1}, {21214, -1, -1, -1}, {21213, -1, -1, -1}, {21211, -1, -1, -1}, {21338, -1, -1, -1}, {21413, -1, -1, -1}, {21883, -1, -1, -1}, {21888, -1, -1, -1}, {21927, -1, -1, -1}, {21884, -1, -1, -1}, {21898, -1, -1, -1} },
+ {{21917, -1, -1, -1}, {21912, -1, -1, -1}, {21890, -1, -1, -1}, {21916, -1, -1, -1}, {21930, -1, -1, -1}, {21908, -1, -1, -1}, {21895, -1, -1, -1}, {21899, -1, -1, -1}, {21891, -1, -1, -1}, {21939, -1, -1, -1}, {21934, -1, -1, -1}, {21919, -1, -1, -1}, {21822, -1, -1, -1}, {21938, -1, -1, -1}, {21914, -1, -1, -1}, {21947, -1, -1, -1}, {21932, -1, -1, -1}, {21937, -1, -1, -1}, {21886, -1, -1, -1}, {21897, -1, -1, -1}, {21931, -1, -1, -1}, {21913, -1, -1, -1}, {22285, -1, -1, -1}, {22575, -1, -1, -1}, {22570, -1, -1, -1}, {22580, -1, -1, -1}, {22564, -1, -1, -1}, {22576, -1, -1, -1}, {22577, -1, -1, -1}, {22561, -1, -1, -1}, {22557, -1, -1, -1}, {22560, -1, -1, -1}, {22777, -1, -1, -1}, {22778, -1, -1, -1}, {22880, -1, -1, -1}, {23159, -1, -1, -1}, {23194, -1, -1, -1}, {23167, -1, -1, -1}, {23186, -1, -1, -1}, {23195, -1, -1, -1}, {23207, -1, -1, -1}, {23411, -1, -1, -1}, {23409, -1, -1, -1}, {23506, -1, -1, -1}, {23500, -1, -1, -1}, {23507, -1, -1, -1}, {23504, -1, -1, -1}, {23562, -1, -1, -1}, {23563, -1, -1, -1}, {23601, -1, -1, -1}, {23884, -1, -1, -1}, {23888, -1, -1, -1}, {23860, -1, -1, -1}, {23879, -1, -1, -1}, {24061, -1, -1, -1}, {24133, -1, -1, -1}, {24125, -1, -1, -1}, {24128, -1, -1, -1}, {24131, -1, -1, -1}, {24190, -1, -1, -1}, {24266, -1, -1, -1}, {24257, -1, -1, -1}, {24258, -1, -1, -1}, {24260, -1, -1, -1}, {24380, -1, -1, -1}, {24429, -1, -1, -1}, {24489, -1, -1, -1}, {24490, -1, -1, -1}, {24488, -1, -1, -1}, {24785, -1, -1, -1}, {24801, -1, -1, -1}, {24754, -1, -1, -1}, {24758, -1, -1, -1}, {24800, -1, -1, -1}, {24860, -1, -1, -1}, {24867, -1, -1, -1}, {24826, -1, -1, -1}, {24853, -1, -1, -1}, {24816, -1, -1, -1}, {24827, -1, -1, -1}, {24820, -1, -1, -1}, {24936, -1, -1, -1}, {24817, -1, -1, -1}, {24846, -1, -1, -1}, {24822, -1, -1, -1}, {24841, -1, -1, -1}, {24832, -1, -1, -1}, {24850, -1, -1, -1}, {25119, -1, -1, -1}, {25161, -1, -1, -1}, {25507, -1, -1, -1}, {25484, -1, -1, -1}, {25551, -1, -1, -1}, {25536, -1, -1, -1}, {25577, -1, -1, -1}, {25545, -1, -1, -1}, {25542, -1, -1, -1}, {25549, -1, -1, -1}, {25554, -1, -1, -1}, {25571, -1, -1, -1}, {25552, -1, -1, -1}, {25569, -1, -1, -1}, {25558, -1, -1, -1}, {25581, -1, -1, -1}, {25582, -1, -1, -1}, {25462, -1, -1, -1}, {25588, -1, -1, -1}, {25578, -1, -1, -1}, {25563, -1, -1, -1}, {25682, -1, -1, -1}, {25562, -1, -1, -1}, {25593, -1, -1, -1}, {25950, -1, -1, -1}, {25958, -1, -1, -1}, {25954, -1, -1, -1}, {25955, -1, -1, -1}, {26001, -1, -1, -1}, {26000, -1, -1, -1}, {26031, -1, -1, -1}, {26222, -1, -1, -1}, {26224, -1, -1, -1}, {26228, -1, -1, -1}, {26230, -1, -1, -1}, {26223, -1, -1, -1}, {26257, -1, -1, -1}, {26234, -1, -1, -1}, {26238, -1, -1, -1}, {26231, -1, -1, -1}, {26366, -1, -1, -1}, {26367, -1, -1, -1}, {26399, -1, -1, -1}, {26397, -1, -1, -1}, {26874, -1, -1, -1}, {26837, -1, -1, -1}, {26848, -1, -1, -1}, {26840, -1, -1, -1}, {26839, -1, -1, -1}, {26885, -1, -1, -1}, {26847, -1, -1, -1}, {26869, -1, -1, -1}, {26862, -1, -1, -1}, {26855, -1, -1, -1}, {26873, -1, -1, -1}, {26834, -1, -1, -1}, {26866, -1, -1, -1}, {26851, -1, -1, -1}, {26827, -1, -1, -1}, {26829, -1, -1, -1}, {26893, -1, -1, -1}, {26898, -1, -1, -1}, {26894, -1, -1, -1}, {26825, -1, -1, -1}, {26842, -1, -1, -1}, {26990, -1, -1, -1}, {26875, -1, -1, -1}, {27454, -1, -1, -1}, {27450, -1, -1, -1}, {27453, -1, -1, -1}, {27544, -1, -1, -1}, {27542, -1, -1, -1}, {27580, -1, -1, -1}, {27631, -1, -1, -1}, {27694, -1, -1, -1}, {27695, -1, -1, -1}, {27692, -1, -1, -1}, {28207, -1, -1, -1}, {28216, -1, -1, -1}, {28244, -1, -1, -1}, {28193, -1, -1, -1}, {28210, -1, -1, -1}, {28263, -1, -1, -1}, {28234, -1, -1, -1}, {28192, -1, -1, -1}, {28197, -1, -1, -1}, {28195, -1, -1, -1}, {28187, -1, -1, -1}, {28251, -1, -1, -1}, {28248, -1, -1, -1}, {28196, -1, -1, -1}, {28246, -1, -1, -1}, {28270, -1, -1, -1}, {28205, -1, -1, -1}, {28198, -1, -1, -1}, {28271, -1, -1, -1}, {28212, -1, -1, -1}, {28237, -1, -1, -1}, {28218, -1, -1, -1}, {28204, -1, -1, -1}, {28227, -1, -1, -1}, {28189, -1, -1, -1}, {28222, -1, -1, -1}, {28363, -1, -1, -1}, {28297, -1, -1, -1}, {28185, -1, -1, -1}, {28238, -1, -1, -1}, {28259, -1, -1, -1}, {28228, -1, -1, -1}, {28274, -1, -1, -1}, {28265, -1, -1, -1}, {28255, -1, -1, -1}, {28953, -1, -1, -1}, {28954, -1, -1, -1}, {28966, -1, -1, -1}, {28976, -1, -1, -1}, {28961, -1, -1, -1}, {28982, -1, -1, -1}, {29038, -1, -1, -1}, {28956, -1, -1, -1}, {29260, -1, -1, -1}, {29316, -1, -1, -1}, {29312, -1, -1, -1}, {29494, -1, -1, -1}, {29477, -1, -1, -1}, {29492, -1, -1, -1}, {29481, -1, -1, -1}, {29754, -1, -1, -1}, {29738, -1, -1, -1}, {29747, -1, -1, -1}, {29730, -1, -1, -1}, {29733, -1, -1, -1}, {29749, -1, -1, -1}, {29750, -1, -1, -1}, {29748, -1, -1, -1}, {29743, -1, -1, -1}, {29723, -1, -1, -1}, {29734, -1, -1, -1}, {29736, -1, -1, -1}, {29989, -1, -1, -1}, {29990, -1, -1, -1}, {30059, -1, -1, -1}, {30058, -1, -1, -1}, {30178, -1, -1, -1}, {30171, -1, -1, -1}, {30179, -1, -1, -1}, {30169, -1, -1, -1}, {30168, -1, -1, -1}, {30174, -1, -1, -1}, {30176, -1, -1, -1}, {30331, -1, -1, -1}, {30332, -1, -1, -1}, {30358, -1, -1, -1}, {30355, -1, -1, -1}, {30388, -1, -1, -1}, {30428, -1, -1, -1}, {30543, -1, -1, -1}, {30701, -1, -1, -1}, {30813, -1, -1, -1}, {30828, -1, -1, -1}, {30831, -1, -1, -1}, {31245, -1, -1, -1}, {31240, -1, -1, -1}, {31243, -1, -1, -1}, {31237, -1, -1, -1}, {31232, -1, -1, -1}, {31384, -1, -1, -1}, {31383, -1, -1, -1} },
+ {{31382, -1, -1, -1}, {31461, -1, -1, -1}, {31459, -1, -1, -1}, {31561, -1, -1, -1}, {31574, -1, -1, -1}, {31558, -1, -1, -1}, {31568, -1, -1, -1}, {31570, -1, -1, -1}, {31572, -1, -1, -1}, {31565, -1, -1, -1}, {31563, -1, -1, -1}, {31567, -1, -1, -1}, {31569, -1, -1, -1}, {31903, -1, -1, -1}, {31909, -1, -1, -1}, {32094, -1, -1, -1}, {32080, -1, -1, -1}, {32104, -1, -1, -1}, {32085, -1, -1, -1}, {32043, -1, -1, -1}, {32110, -1, -1, -1}, {32114, -1, -1, -1}, {32097, -1, -1, -1}, {32102, -1, -1, -1}, {32098, -1, -1, -1}, {32112, -1, -1, -1}, {32115, -1, -1, -1}, {21892, -1, -1, -1}, {32724, -1, -1, -1}, {32725, -1, -1, -1}, {32779, -1, -1, -1}, {32850, -1, -1, -1}, {32901, -1, -1, -1}, {33109, -1, -1, -1}, {33108, -1, -1, -1}, {33099, -1, -1, -1}, {33105, -1, -1, -1}, {33102, -1, -1, -1}, {33081, -1, -1, -1}, {33094, -1, -1, -1}, {33086, -1, -1, -1}, {33100, -1, -1, -1}, {33107, -1, -1, -1}, {33140, -1, -1, -1}, {33298, -1, -1, -1}, {33308, -1, -1, -1}, {33769, -1, -1, -1}, {33795, -1, -1, -1}, {33784, -1, -1, -1}, {33805, -1, -1, -1}, {33760, -1, -1, -1}, {33733, -1, -1, -1}, {33803, -1, -1, -1}, {33729, -1, -1, -1}, {33775, -1, -1, -1}, {33777, -1, -1, -1}, {33780, -1, -1, -1}, {33879, -1, -1, -1}, {33802, -1, -1, -1}, {33776, -1, -1, -1}, {33804, -1, -1, -1}, {33740, -1, -1, -1}, {33789, -1, -1, -1}, {33778, -1, -1, -1}, {33738, -1, -1, -1}, {33848, -1, -1, -1}, {33806, -1, -1, -1}, {33796, -1, -1, -1}, {33756, -1, -1, -1}, {33799, -1, -1, -1}, {33748, -1, -1, -1}, {33759, -1, -1, -1}, {34395, -1, -1, -1}, {34527, -1, -1, -1}, {34521, -1, -1, -1}, {34541, -1, -1, -1}, {34516, -1, -1, -1}, {34523, -1, -1, -1}, {34532, -1, -1, -1}, {34512, -1, -1, -1}, {34526, -1, -1, -1}, {34903, -1, -1, -1}, {35009, -1, -1, -1}, {35010, -1, -1, -1}, {34993, -1, -1, -1}, {35203, -1, -1, -1}, {35222, -1, -1, -1}, {35387, -1, -1, -1}, {35424, -1, -1, -1}, {35413, -1, -1, -1}, {35422, -1, -1, -1}, {35388, -1, -1, -1}, {35393, -1, -1, -1}, {35412, -1, -1, -1}, {35419, -1, -1, -1}, {35408, -1, -1, -1}, {35398, -1, -1, -1}, {35380, -1, -1, -1}, {35386, -1, -1, -1}, {35382, -1, -1, -1}, {35414, -1, -1, -1}, {35937, -1, -1, -1}, {35970, -1, -1, -1}, {36015, -1, -1, -1}, {36028, -1, -1, -1}, {36019, -1, -1, -1}, {36029, -1, -1, -1}, {36033, -1, -1, -1}, {36027, -1, -1, -1}, {36032, -1, -1, -1}, {36020, -1, -1, -1}, {36023, -1, -1, -1}, {36022, -1, -1, -1}, {36031, -1, -1, -1}, {36024, -1, -1, -1}, {36234, -1, -1, -1}, {36229, -1, -1, -1}, {36225, -1, -1, -1}, {36302, -1, -1, -1}, {36317, -1, -1, -1}, {36299, -1, -1, -1}, {36314, -1, -1, -1}, {36305, -1, -1, -1}, {36300, -1, -1, -1}, {36315, -1, -1, -1}, {36294, -1, -1, -1}, {36603, -1, -1, -1}, {36600, -1, -1, -1}, {36604, -1, -1, -1}, {36764, -1, -1, -1}, {36910, -1, -1, -1}, {36917, -1, -1, -1}, {36913, -1, -1, -1}, {36920, -1, -1, -1}, {36914, -1, -1, -1}, {36918, -1, -1, -1}, {37122, -1, -1, -1}, {37109, -1, -1, -1}, {37129, -1, -1, -1}, {37118, -1, -1, -1}, {37219, -1, -1, -1}, {37221, -1, -1, -1}, {37327, -1, -1, -1}, {37396, -1, -1, -1}, {37397, -1, -1, -1}, {37411, -1, -1, -1}, {37385, -1, -1, -1}, {37406, -1, -1, -1}, {37389, -1, -1, -1}, {37392, -1, -1, -1}, {37383, -1, -1, -1}, {37393, -1, -1, -1}, {38292, -1, -1, -1}, {38287, -1, -1, -1}, {38283, -1, -1, -1}, {38289, -1, -1, -1}, {38291, -1, -1, -1}, {38290, -1, -1, -1}, {38286, -1, -1, -1}, {38538, -1, -1, -1}, {38542, -1, -1, -1}, {38539, -1, -1, -1}, {38525, -1, -1, -1}, {38533, -1, -1, -1}, {38534, -1, -1, -1}, {38541, -1, -1, -1}, {38514, -1, -1, -1}, {38532, -1, -1, -1}, {38593, -1, -1, -1}, {38597, -1, -1, -1}, {38596, -1, -1, -1}, {38598, -1, -1, -1}, {38599, -1, -1, -1}, {38639, -1, -1, -1}, {38642, -1, -1, -1}, {38860, -1, -1, -1}, {38917, -1, -1, -1}, {38918, -1, -1, -1}, {38920, -1, -1, -1}, {39143, -1, -1, -1}, {39146, -1, -1, -1}, {39151, -1, -1, -1}, {39145, -1, -1, -1}, {39154, -1, -1, -1}, {39149, -1, -1, -1}, {39342, -1, -1, -1}, {39341, -1, -1, -1}, {40643, -1, -1, -1}, {40653, -1, -1, -1}, {40657, -1, -1, -1}, {20098, -1, -1, -1}, {20653, -1, -1, -1}, {20661, -1, -1, -1}, {20658, -1, -1, -1}, {20659, -1, -1, -1}, {20677, -1, -1, -1}, {20670, -1, -1, -1}, {20652, -1, -1, -1}, {20663, -1, -1, -1}, {20667, -1, -1, -1}, {20655, -1, -1, -1}, {20679, -1, -1, -1}, {21119, -1, -1, -1}, {21111, -1, -1, -1}, {21117, -1, -1, -1}, {21215, -1, -1, -1}, {21222, -1, -1, -1}, {21220, -1, -1, -1}, {21218, -1, -1, -1}, {21219, -1, -1, -1}, {21295, -1, -1, -1}, {21983, -1, -1, -1}, {21992, -1, -1, -1}, {21971, -1, -1, -1}, {21990, -1, -1, -1}, {21966, -1, -1, -1}, {21980, -1, -1, -1}, {21959, -1, -1, -1}, {21969, -1, -1, -1}, {21987, -1, -1, -1}, {21988, -1, -1, -1}, {21999, -1, -1, -1}, {21978, -1, -1, -1}, {21985, -1, -1, -1}, {21957, -1, -1, -1}, {21958, -1, -1, -1}, {21989, -1, -1, -1}, {21961, -1, -1, -1}, {22290, -1, -1, -1}, {22291, -1, -1, -1}, {22622, -1, -1, -1}, {22609, -1, -1, -1}, {22616, -1, -1, -1}, {22615, -1, -1, -1}, {22618, -1, -1, -1}, {22612, -1, -1, -1}, {22635, -1, -1, -1}, {22604, -1, -1, -1}, {22637, -1, -1, -1}, {22602, -1, -1, -1}, {22626, -1, -1, -1}, {22610, -1, -1, -1}, {22603, -1, -1, -1}, {22887, -1, -1, -1}, {23233, -1, -1, -1}, {23241, -1, -1, -1}, {23244, -1, -1, -1}, {23230, -1, -1, -1}, {23229, -1, -1, -1}, {23228, -1, -1, -1}, {23219, -1, -1, -1}, {23234, -1, -1, -1}, {23218, -1, -1, -1}, {23913, -1, -1, -1}, {23919, -1, -1, -1}, {24140, -1, -1, -1} },
+ {{24185, -1, -1, -1}, {24265, -1, -1, -1}, {24264, -1, -1, -1}, {24338, -1, -1, -1}, {24409, -1, -1, -1}, {24492, -1, -1, -1}, {24494, -1, -1, -1}, {24858, -1, -1, -1}, {24847, -1, -1, -1}, {24904, -1, -1, -1}, {24863, -1, -1, -1}, {24819, -1, -1, -1}, {24859, -1, -1, -1}, {24825, -1, -1, -1}, {24833, -1, -1, -1}, {24840, -1, -1, -1}, {24910, -1, -1, -1}, {24908, -1, -1, -1}, {24900, -1, -1, -1}, {24909, -1, -1, -1}, {24894, -1, -1, -1}, {24884, -1, -1, -1}, {24871, -1, -1, -1}, {24845, -1, -1, -1}, {24838, -1, -1, -1}, {24887, -1, -1, -1}, {25121, -1, -1, -1}, {25122, -1, -1, -1}, {25619, -1, -1, -1}, {25662, -1, -1, -1}, {25630, -1, -1, -1}, {25642, -1, -1, -1}, {25645, -1, -1, -1}, {25661, -1, -1, -1}, {25644, -1, -1, -1}, {25615, -1, -1, -1}, {25628, -1, -1, -1}, {25620, -1, -1, -1}, {25613, -1, -1, -1}, {25654, -1, -1, -1}, {25622, -1, -1, -1}, {25623, -1, -1, -1}, {25606, -1, -1, -1}, {25964, -1, -1, -1}, {26015, -1, -1, -1}, {26032, -1, -1, -1}, {26263, -1, -1, -1}, {26249, -1, -1, -1}, {26247, -1, -1, -1}, {26248, -1, -1, -1}, {26262, -1, -1, -1}, {26244, -1, -1, -1}, {26264, -1, -1, -1}, {26253, -1, -1, -1}, {26371, -1, -1, -1}, {27028, -1, -1, -1}, {26989, -1, -1, -1}, {26970, -1, -1, -1}, {26999, -1, -1, -1}, {26976, -1, -1, -1}, {26964, -1, -1, -1}, {26997, -1, -1, -1}, {26928, -1, -1, -1}, {27010, -1, -1, -1}, {26954, -1, -1, -1}, {26984, -1, -1, -1}, {26987, -1, -1, -1}, {26974, -1, -1, -1}, {26963, -1, -1, -1}, {27001, -1, -1, -1}, {27014, -1, -1, -1}, {26973, -1, -1, -1}, {26979, -1, -1, -1}, {26971, -1, -1, -1}, {27463, -1, -1, -1}, {27506, -1, -1, -1}, {27584, -1, -1, -1}, {27583, -1, -1, -1}, {27603, -1, -1, -1}, {27645, -1, -1, -1}, {28322, -1, -1, -1}, {28335, -1, -1, -1}, {28371, -1, -1, -1}, {28342, -1, -1, -1}, {28354, -1, -1, -1}, {28304, -1, -1, -1}, {28317, -1, -1, -1}, {28359, -1, -1, -1}, {28357, -1, -1, -1}, {28325, -1, -1, -1}, {28312, -1, -1, -1}, {28348, -1, -1, -1}, {28346, -1, -1, -1}, {28331, -1, -1, -1}, {28369, -1, -1, -1}, {28310, -1, -1, -1}, {28316, -1, -1, -1}, {28356, -1, -1, -1}, {28372, -1, -1, -1}, {28330, -1, -1, -1}, {28327, -1, -1, -1}, {28340, -1, -1, -1}, {29006, -1, -1, -1}, {29017, -1, -1, -1}, {29033, -1, -1, -1}, {29028, -1, -1, -1}, {29001, -1, -1, -1}, {29031, -1, -1, -1}, {29020, -1, -1, -1}, {29036, -1, -1, -1}, {29030, -1, -1, -1}, {29004, -1, -1, -1}, {29029, -1, -1, -1}, {29022, -1, -1, -1}, {28998, -1, -1, -1}, {29032, -1, -1, -1}, {29014, -1, -1, -1}, {29242, -1, -1, -1}, {29266, -1, -1, -1}, {29495, -1, -1, -1}, {29509, -1, -1, -1}, {29503, -1, -1, -1}, {29502, -1, -1, -1}, {29807, -1, -1, -1}, {29786, -1, -1, -1}, {29781, -1, -1, -1}, {29791, -1, -1, -1}, {29790, -1, -1, -1}, {29761, -1, -1, -1}, {29759, -1, -1, -1}, {29785, -1, -1, -1}, {29787, -1, -1, -1}, {29788, -1, -1, -1}, {30070, -1, -1, -1}, {30072, -1, -1, -1}, {30208, -1, -1, -1}, {30192, -1, -1, -1}, {30209, -1, -1, -1}, {30194, -1, -1, -1}, {30193, -1, -1, -1}, {30202, -1, -1, -1}, {30207, -1, -1, -1}, {30196, -1, -1, -1}, {30195, -1, -1, -1}, {30430, -1, -1, -1}, {30431, -1, -1, -1}, {30555, -1, -1, -1}, {30571, -1, -1, -1}, {30566, -1, -1, -1}, {30558, -1, -1, -1}, {30563, -1, -1, -1}, {30585, -1, -1, -1}, {30570, -1, -1, -1}, {30572, -1, -1, -1}, {30556, -1, -1, -1}, {30565, -1, -1, -1}, {30568, -1, -1, -1}, {30562, -1, -1, -1}, {30702, -1, -1, -1}, {30862, -1, -1, -1}, {30896, -1, -1, -1}, {30871, -1, -1, -1}, {30872, -1, -1, -1}, {30860, -1, -1, -1}, {30857, -1, -1, -1}, {30844, -1, -1, -1}, {30865, -1, -1, -1}, {30867, -1, -1, -1}, {30847, -1, -1, -1}, {31098, -1, -1, -1}, {31103, -1, -1, -1}, {31105, -1, -1, -1}, {33836, -1, -1, -1}, {31165, -1, -1, -1}, {31260, -1, -1, -1}, {31258, -1, -1, -1}, {31264, -1, -1, -1}, {31252, -1, -1, -1}, {31263, -1, -1, -1}, {31262, -1, -1, -1}, {31391, -1, -1, -1}, {31392, -1, -1, -1}, {31607, -1, -1, -1}, {31680, -1, -1, -1}, {31584, -1, -1, -1}, {31598, -1, -1, -1}, {31591, -1, -1, -1}, {31921, -1, -1, -1}, {31923, -1, -1, -1}, {31925, -1, -1, -1}, {32147, -1, -1, -1}, {32121, -1, -1, -1}, {32145, -1, -1, -1}, {32129, -1, -1, -1}, {32143, -1, -1, -1}, {32091, -1, -1, -1}, {32622, -1, -1, -1}, {32617, -1, -1, -1}, {32618, -1, -1, -1}, {32626, -1, -1, -1}, {32681, -1, -1, -1}, {32680, -1, -1, -1}, {32676, -1, -1, -1}, {32854, -1, -1, -1}, {32856, -1, -1, -1}, {32902, -1, -1, -1}, {32900, -1, -1, -1}, {33137, -1, -1, -1}, {33136, -1, -1, -1}, {33144, -1, -1, -1}, {33125, -1, -1, -1}, {33134, -1, -1, -1}, {33139, -1, -1, -1}, {33131, -1, -1, -1}, {33145, -1, -1, -1}, {33146, -1, -1, -1}, {33126, -1, -1, -1}, {33285, -1, -1, -1}, {33351, -1, -1, -1}, {33922, -1, -1, -1}, {33911, -1, -1, -1}, {33853, -1, -1, -1}, {33841, -1, -1, -1}, {33909, -1, -1, -1}, {33894, -1, -1, -1}, {33899, -1, -1, -1}, {33865, -1, -1, -1}, {33900, -1, -1, -1}, {33883, -1, -1, -1}, {33852, -1, -1, -1}, {33845, -1, -1, -1}, {33889, -1, -1, -1}, {33891, -1, -1, -1}, {33897, -1, -1, -1}, {33901, -1, -1, -1}, {33862, -1, -1, -1}, {34398, -1, -1, -1}, {34396, -1, -1, -1}, {34399, -1, -1, -1}, {34553, -1, -1, -1}, {34579, -1, -1, -1}, {34568, -1, -1, -1}, {34567, -1, -1, -1}, {34560, -1, -1, -1}, {34558, -1, -1, -1}, {34555, -1, -1, -1}, {34562, -1, -1, -1}, {34563, -1, -1, -1}, {34566, -1, -1, -1}, {34570, -1, -1, -1}, {34905, -1, -1, -1}, {35039, -1, -1, -1}, {35028, -1, -1, -1}, {35033, -1, -1, -1}, {35036, -1, -1, -1}, {35032, -1, -1, -1} },
+ {{35037, -1, -1, -1}, {35041, -1, -1, -1}, {35018, -1, -1, -1}, {35029, -1, -1, -1}, {35026, -1, -1, -1}, {35228, -1, -1, -1}, {35299, -1, -1, -1}, {35435, -1, -1, -1}, {35442, -1, -1, -1}, {35443, -1, -1, -1}, {35430, -1, -1, -1}, {35433, -1, -1, -1}, {35440, -1, -1, -1}, {35463, -1, -1, -1}, {35452, -1, -1, -1}, {35427, -1, -1, -1}, {35488, -1, -1, -1}, {35441, -1, -1, -1}, {35461, -1, -1, -1}, {35437, -1, -1, -1}, {35426, -1, -1, -1}, {35438, -1, -1, -1}, {35436, -1, -1, -1}, {35449, -1, -1, -1}, {35451, -1, -1, -1}, {35390, -1, -1, -1}, {35432, -1, -1, -1}, {35938, -1, -1, -1}, {35978, -1, -1, -1}, {35977, -1, -1, -1}, {36042, -1, -1, -1}, {36039, -1, -1, -1}, {36040, -1, -1, -1}, {36036, -1, -1, -1}, {36018, -1, -1, -1}, {36035, -1, -1, -1}, {36034, -1, -1, -1}, {36037, -1, -1, -1}, {36321, -1, -1, -1}, {36319, -1, -1, -1}, {36328, -1, -1, -1}, {36335, -1, -1, -1}, {36339, -1, -1, -1}, {36346, -1, -1, -1}, {36330, -1, -1, -1}, {36324, -1, -1, -1}, {36326, -1, -1, -1}, {36530, -1, -1, -1}, {36611, -1, -1, -1}, {36617, -1, -1, -1}, {36606, -1, -1, -1}, {36618, -1, -1, -1}, {36767, -1, -1, -1}, {36786, -1, -1, -1}, {36939, -1, -1, -1}, {36938, -1, -1, -1}, {36947, -1, -1, -1}, {36930, -1, -1, -1}, {36948, -1, -1, -1}, {36924, -1, -1, -1}, {36949, -1, -1, -1}, {36944, -1, -1, -1}, {36935, -1, -1, -1}, {36943, -1, -1, -1}, {36942, -1, -1, -1}, {36941, -1, -1, -1}, {36945, -1, -1, -1}, {36926, -1, -1, -1}, {36929, -1, -1, -1}, {37138, -1, -1, -1}, {37143, -1, -1, -1}, {37228, -1, -1, -1}, {37226, -1, -1, -1}, {37225, -1, -1, -1}, {37321, -1, -1, -1}, {37431, -1, -1, -1}, {37463, -1, -1, -1}, {37432, -1, -1, -1}, {37437, -1, -1, -1}, {37440, -1, -1, -1}, {37438, -1, -1, -1}, {37467, -1, -1, -1}, {37451, -1, -1, -1}, {37476, -1, -1, -1}, {37457, -1, -1, -1}, {37428, -1, -1, -1}, {37449, -1, -1, -1}, {37453, -1, -1, -1}, {37445, -1, -1, -1}, {37433, -1, -1, -1}, {37439, -1, -1, -1}, {37466, -1, -1, -1}, {38296, -1, -1, -1}, {38552, -1, -1, -1}, {38548, -1, -1, -1}, {38549, -1, -1, -1}, {38605, -1, -1, -1}, {38603, -1, -1, -1}, {38601, -1, -1, -1}, {38602, -1, -1, -1}, {38647, -1, -1, -1}, {38651, -1, -1, -1}, {38649, -1, -1, -1}, {38646, -1, -1, -1}, {38742, -1, -1, -1}, {38772, -1, -1, -1}, {38774, -1, -1, -1}, {38928, -1, -1, -1}, {38929, -1, -1, -1}, {38931, -1, -1, -1}, {38922, -1, -1, -1}, {38930, -1, -1, -1}, {38924, -1, -1, -1}, {39164, -1, -1, -1}, {39156, -1, -1, -1}, {39165, -1, -1, -1}, {39166, -1, -1, -1}, {39347, -1, -1, -1}, {39345, -1, -1, -1}, {39348, -1, -1, -1}, {39649, -1, -1, -1}, {40169, -1, -1, -1}, {40578, -1, -1, -1}, {40718, -1, -1, -1}, {40723, -1, -1, -1}, {40736, -1, -1, -1}, {20711, -1, -1, -1}, {20718, -1, -1, -1}, {20709, -1, -1, -1}, {20694, -1, -1, -1}, {20717, -1, -1, -1}, {20698, -1, -1, -1}, {20693, -1, -1, -1}, {20687, -1, -1, -1}, {20689, -1, -1, -1}, {20721, -1, -1, -1}, {20686, -1, -1, -1}, {20713, -1, -1, -1}, {20834, -1, -1, -1}, {20979, -1, -1, -1}, {21123, -1, -1, -1}, {21122, -1, -1, -1}, {21297, -1, -1, -1}, {21421, -1, -1, -1}, {22014, -1, -1, -1}, {22016, -1, -1, -1}, {22043, -1, -1, -1}, {22039, -1, -1, -1}, {22013, -1, -1, -1}, {22036, -1, -1, -1}, {22022, -1, -1, -1}, {22025, -1, -1, -1}, {22029, -1, -1, -1}, {22030, -1, -1, -1}, {22007, -1, -1, -1}, {22038, -1, -1, -1}, {22047, -1, -1, -1}, {22024, -1, -1, -1}, {22032, -1, -1, -1}, {22006, -1, -1, -1}, {22296, -1, -1, -1}, {22294, -1, -1, -1}, {22645, -1, -1, -1}, {22654, -1, -1, -1}, {22659, -1, -1, -1}, {22675, -1, -1, -1}, {22666, -1, -1, -1}, {22649, -1, -1, -1}, {22661, -1, -1, -1}, {22653, -1, -1, -1}, {22781, -1, -1, -1}, {22821, -1, -1, -1}, {22818, -1, -1, -1}, {22820, -1, -1, -1}, {22890, -1, -1, -1}, {22889, -1, -1, -1}, {23265, -1, -1, -1}, {23270, -1, -1, -1}, {23273, -1, -1, -1}, {23255, -1, -1, -1}, {23254, -1, -1, -1}, {23256, -1, -1, -1}, {23267, -1, -1, -1}, {23413, -1, -1, -1}, {23518, -1, -1, -1}, {23527, -1, -1, -1}, {23521, -1, -1, -1}, {23525, -1, -1, -1}, {23526, -1, -1, -1}, {23528, -1, -1, -1}, {23522, -1, -1, -1}, {23524, -1, -1, -1}, {23519, -1, -1, -1}, {23565, -1, -1, -1}, {23650, -1, -1, -1}, {23940, -1, -1, -1}, {23943, -1, -1, -1}, {24155, -1, -1, -1}, {24163, -1, -1, -1}, {24149, -1, -1, -1}, {24151, -1, -1, -1}, {24148, -1, -1, -1}, {24275, -1, -1, -1}, {24278, -1, -1, -1}, {24330, -1, -1, -1}, {24390, -1, -1, -1}, {24432, -1, -1, -1}, {24505, -1, -1, -1}, {24903, -1, -1, -1}, {24895, -1, -1, -1}, {24907, -1, -1, -1}, {24951, -1, -1, -1}, {24930, -1, -1, -1}, {24931, -1, -1, -1}, {24927, -1, -1, -1}, {24922, -1, -1, -1}, {24920, -1, -1, -1}, {24949, -1, -1, -1}, {25130, -1, -1, -1}, {25735, -1, -1, -1}, {25688, -1, -1, -1}, {25684, -1, -1, -1}, {25764, -1, -1, -1}, {25720, -1, -1, -1}, {25695, -1, -1, -1}, {25722, -1, -1, -1}, {25681, -1, -1, -1}, {25703, -1, -1, -1}, {25652, -1, -1, -1}, {25709, -1, -1, -1}, {25723, -1, -1, -1}, {25970, -1, -1, -1}, {26017, -1, -1, -1}, {26071, -1, -1, -1}, {26070, -1, -1, -1}, {26274, -1, -1, -1}, {26280, -1, -1, -1}, {26269, -1, -1, -1}, {27036, -1, -1, -1}, {27048, -1, -1, -1}, {27029, -1, -1, -1}, {27073, -1, -1, -1}, {27054, -1, -1, -1}, {27091, -1, -1, -1}, {27083, -1, -1, -1}, {27035, -1, -1, -1}, {27063, -1, -1, -1}, {27067, -1, -1, -1}, {27051, -1, -1, -1}, {27060, -1, -1, -1}, {27088, -1, -1, -1}, {27085, -1, -1, -1}, {27053, -1, -1, -1}, {27084, -1, -1, -1}, {27046, -1, -1, -1}, {27075, -1, -1, -1} },
+ {{27043, -1, -1, -1}, {27465, -1, -1, -1}, {27468, -1, -1, -1}, {27699, -1, -1, -1}, {28467, -1, -1, -1}, {28436, -1, -1, -1}, {28414, -1, -1, -1}, {28435, -1, -1, -1}, {28404, -1, -1, -1}, {28457, -1, -1, -1}, {28478, -1, -1, -1}, {28448, -1, -1, -1}, {28460, -1, -1, -1}, {28431, -1, -1, -1}, {28418, -1, -1, -1}, {28450, -1, -1, -1}, {28415, -1, -1, -1}, {28399, -1, -1, -1}, {28422, -1, -1, -1}, {28465, -1, -1, -1}, {28472, -1, -1, -1}, {28466, -1, -1, -1}, {28451, -1, -1, -1}, {28437, -1, -1, -1}, {28459, -1, -1, -1}, {28463, -1, -1, -1}, {28552, -1, -1, -1}, {28458, -1, -1, -1}, {28396, -1, -1, -1}, {28417, -1, -1, -1}, {28402, -1, -1, -1}, {28364, -1, -1, -1}, {28407, -1, -1, -1}, {29076, -1, -1, -1}, {29081, -1, -1, -1}, {29053, -1, -1, -1}, {29066, -1, -1, -1}, {29060, -1, -1, -1}, {29074, -1, -1, -1}, {29246, -1, -1, -1}, {29330, -1, -1, -1}, {29334, -1, -1, -1}, {29508, -1, -1, -1}, {29520, -1, -1, -1}, {29796, -1, -1, -1}, {29795, -1, -1, -1}, {29802, -1, -1, -1}, {29808, -1, -1, -1}, {29805, -1, -1, -1}, {29956, -1, -1, -1}, {30097, -1, -1, -1}, {30247, -1, -1, -1}, {30221, -1, -1, -1}, {30219, -1, -1, -1}, {30217, -1, -1, -1}, {30227, -1, -1, -1}, {30433, -1, -1, -1}, {30435, -1, -1, -1}, {30596, -1, -1, -1}, {30589, -1, -1, -1}, {30591, -1, -1, -1}, {30561, -1, -1, -1}, {30913, -1, -1, -1}, {30879, -1, -1, -1}, {30887, -1, -1, -1}, {30899, -1, -1, -1}, {30889, -1, -1, -1}, {30883, -1, -1, -1}, {31118, -1, -1, -1}, {31119, -1, -1, -1}, {31117, -1, -1, -1}, {31278, -1, -1, -1}, {31281, -1, -1, -1}, {31402, -1, -1, -1}, {31401, -1, -1, -1}, {31469, -1, -1, -1}, {31471, -1, -1, -1}, {31649, -1, -1, -1}, {31637, -1, -1, -1}, {31627, -1, -1, -1}, {31605, -1, -1, -1}, {31639, -1, -1, -1}, {31645, -1, -1, -1}, {31636, -1, -1, -1}, {31631, -1, -1, -1}, {31672, -1, -1, -1}, {31623, -1, -1, -1}, {31620, -1, -1, -1}, {31929, -1, -1, -1}, {31933, -1, -1, -1}, {31934, -1, -1, -1}, {32187, -1, -1, -1}, {32176, -1, -1, -1}, {32156, -1, -1, -1}, {32189, -1, -1, -1}, {32190, -1, -1, -1}, {32160, -1, -1, -1}, {32202, -1, -1, -1}, {32180, -1, -1, -1}, {32178, -1, -1, -1}, {32177, -1, -1, -1}, {32186, -1, -1, -1}, {32162, -1, -1, -1}, {32191, -1, -1, -1}, {32181, -1, -1, -1}, {32184, -1, -1, -1}, {32173, -1, -1, -1}, {32210, -1, -1, -1}, {32199, -1, -1, -1}, {32172, -1, -1, -1}, {32624, -1, -1, -1}, {32736, -1, -1, -1}, {32737, -1, -1, -1}, {32735, -1, -1, -1}, {32862, -1, -1, -1}, {32858, -1, -1, -1}, {32903, -1, -1, -1}, {33104, -1, -1, -1}, {33152, -1, -1, -1}, {33167, -1, -1, -1}, {33160, -1, -1, -1}, {33162, -1, -1, -1}, {33151, -1, -1, -1}, {33154, -1, -1, -1}, {33255, -1, -1, -1}, {33274, -1, -1, -1}, {33287, -1, -1, -1}, {33300, -1, -1, -1}, {33310, -1, -1, -1}, {33355, -1, -1, -1}, {33993, -1, -1, -1}, {33983, -1, -1, -1}, {33990, -1, -1, -1}, {33988, -1, -1, -1}, {33945, -1, -1, -1}, {33950, -1, -1, -1}, {33970, -1, -1, -1}, {33948, -1, -1, -1}, {33995, -1, -1, -1}, {33976, -1, -1, -1}, {33984, -1, -1, -1}, {34003, -1, -1, -1}, {33936, -1, -1, -1}, {33980, -1, -1, -1}, {34001, -1, -1, -1}, {33994, -1, -1, -1}, {34623, -1, -1, -1}, {34588, -1, -1, -1}, {34619, -1, -1, -1}, {34594, -1, -1, -1}, {34597, -1, -1, -1}, {34612, -1, -1, -1}, {34584, -1, -1, -1}, {34645, -1, -1, -1}, {34615, -1, -1, -1}, {34601, -1, -1, -1}, {35059, -1, -1, -1}, {35074, -1, -1, -1}, {35060, -1, -1, -1}, {35065, -1, -1, -1}, {35064, -1, -1, -1}, {35069, -1, -1, -1}, {35048, -1, -1, -1}, {35098, -1, -1, -1}, {35055, -1, -1, -1}, {35494, -1, -1, -1}, {35468, -1, -1, -1}, {35486, -1, -1, -1}, {35491, -1, -1, -1}, {35469, -1, -1, -1}, {35489, -1, -1, -1}, {35475, -1, -1, -1}, {35492, -1, -1, -1}, {35498, -1, -1, -1}, {35493, -1, -1, -1}, {35496, -1, -1, -1}, {35480, -1, -1, -1}, {35473, -1, -1, -1}, {35482, -1, -1, -1}, {35495, -1, -1, -1}, {35946, -1, -1, -1}, {35981, -1, -1, -1}, {35980, -1, -1, -1}, {36051, -1, -1, -1}, {36049, -1, -1, -1}, {36050, -1, -1, -1}, {36203, -1, -1, -1}, {36249, -1, -1, -1}, {36245, -1, -1, -1}, {36348, -1, -1, -1}, {36628, -1, -1, -1}, {36626, -1, -1, -1}, {36629, -1, -1, -1}, {36627, -1, -1, -1}, {36771, -1, -1, -1}, {36960, -1, -1, -1}, {36952, -1, -1, -1}, {36956, -1, -1, -1}, {36963, -1, -1, -1}, {36953, -1, -1, -1}, {36958, -1, -1, -1}, {36962, -1, -1, -1}, {36957, -1, -1, -1}, {36955, -1, -1, -1}, {37145, -1, -1, -1}, {37144, -1, -1, -1}, {37150, -1, -1, -1}, {37237, -1, -1, -1}, {37240, -1, -1, -1}, {37239, -1, -1, -1}, {37236, -1, -1, -1}, {37496, -1, -1, -1}, {37548, -1, -1, -1}, {37504, -1, -1, -1}, {37509, -1, -1, -1}, {37528, -1, -1, -1}, {37526, -1, -1, -1}, {37499, -1, -1, -1}, {37523, -1, -1, -1}, {37532, -1, -1, -1}, {37544, -1, -1, -1}, {37500, -1, -1, -1}, {37521, -1, -1, -1}, {38305, -1, -1, -1}, {38312, -1, -1, -1}, {38313, -1, -1, -1}, {38307, -1, -1, -1}, {38309, -1, -1, -1}, {38308, -1, -1, -1}, {38553, -1, -1, -1}, {38556, -1, -1, -1}, {38555, -1, -1, -1}, {38604, -1, -1, -1}, {38610, -1, -1, -1}, {38656, -1, -1, -1}, {38780, -1, -1, -1}, {38789, -1, -1, -1}, {38902, -1, -1, -1}, {38935, -1, -1, -1}, {38936, -1, -1, -1}, {39087, -1, -1, -1}, {39089, -1, -1, -1}, {39171, -1, -1, -1}, {39173, -1, -1, -1}, {39180, -1, -1, -1}, {39177, -1, -1, -1}, {39361, -1, -1, -1}, {39599, -1, -1, -1}, {39600, -1, -1, -1}, {39654, -1, -1, -1}, {39745, -1, -1, -1}, {39746, -1, -1, -1}, {40180, -1, -1, -1}, {40182, -1, -1, -1}, {40179, -1, -1, -1}, {40636, -1, -1, -1} },
+ {{40763, -1, -1, -1}, {40778, -1, -1, -1}, {20740, -1, -1, -1}, {20736, -1, -1, -1}, {20731, -1, -1, -1}, {20725, -1, -1, -1}, {20729, -1, -1, -1}, {20738, -1, -1, -1}, {20744, -1, -1, -1}, {20745, -1, -1, -1}, {20741, -1, -1, -1}, {20956, -1, -1, -1}, {21127, -1, -1, -1}, {21128, -1, -1, -1}, {21129, -1, -1, -1}, {21133, -1, -1, -1}, {21130, -1, -1, -1}, {21232, -1, -1, -1}, {21426, -1, -1, -1}, {22062, -1, -1, -1}, {22075, -1, -1, -1}, {22073, -1, -1, -1}, {22066, -1, -1, -1}, {22079, -1, -1, -1}, {22068, -1, -1, -1}, {22057, -1, -1, -1}, {22099, -1, -1, -1}, {22094, -1, -1, -1}, {22103, -1, -1, -1}, {22132, -1, -1, -1}, {22070, -1, -1, -1}, {22063, -1, -1, -1}, {22064, -1, -1, -1}, {22656, -1, -1, -1}, {22687, -1, -1, -1}, {22686, -1, -1, -1}, {22707, -1, -1, -1}, {22684, -1, -1, -1}, {22702, -1, -1, -1}, {22697, -1, -1, -1}, {22694, -1, -1, -1}, {22893, -1, -1, -1}, {23305, -1, -1, -1}, {23291, -1, -1, -1}, {23307, -1, -1, -1}, {23285, -1, -1, -1}, {23308, -1, -1, -1}, {23304, -1, -1, -1}, {23534, -1, -1, -1}, {23532, -1, -1, -1}, {23529, -1, -1, -1}, {23531, -1, -1, -1}, {23652, -1, -1, -1}, {23653, -1, -1, -1}, {23965, -1, -1, -1}, {23956, -1, -1, -1}, {24162, -1, -1, -1}, {24159, -1, -1, -1}, {24161, -1, -1, -1}, {24290, -1, -1, -1}, {24282, -1, -1, -1}, {24287, -1, -1, -1}, {24285, -1, -1, -1}, {24291, -1, -1, -1}, {24288, -1, -1, -1}, {24392, -1, -1, -1}, {24433, -1, -1, -1}, {24503, -1, -1, -1}, {24501, -1, -1, -1}, {24950, -1, -1, -1}, {24935, -1, -1, -1}, {24942, -1, -1, -1}, {24925, -1, -1, -1}, {24917, -1, -1, -1}, {24962, -1, -1, -1}, {24956, -1, -1, -1}, {24944, -1, -1, -1}, {24939, -1, -1, -1}, {24958, -1, -1, -1}, {24999, -1, -1, -1}, {24976, -1, -1, -1}, {25003, -1, -1, -1}, {24974, -1, -1, -1}, {25004, -1, -1, -1}, {24986, -1, -1, -1}, {24996, -1, -1, -1}, {24980, -1, -1, -1}, {25006, -1, -1, -1}, {25134, -1, -1, -1}, {25705, -1, -1, -1}, {25711, -1, -1, -1}, {25721, -1, -1, -1}, {25758, -1, -1, -1}, {25778, -1, -1, -1}, {25736, -1, -1, -1}, {25744, -1, -1, -1}, {25776, -1, -1, -1}, {25765, -1, -1, -1}, {25747, -1, -1, -1}, {25749, -1, -1, -1}, {25769, -1, -1, -1}, {25746, -1, -1, -1}, {25774, -1, -1, -1}, {25773, -1, -1, -1}, {25771, -1, -1, -1}, {25754, -1, -1, -1}, {25772, -1, -1, -1}, {25753, -1, -1, -1}, {25762, -1, -1, -1}, {25779, -1, -1, -1}, {25973, -1, -1, -1}, {25975, -1, -1, -1}, {25976, -1, -1, -1}, {26286, -1, -1, -1}, {26283, -1, -1, -1}, {26292, -1, -1, -1}, {26289, -1, -1, -1}, {27171, -1, -1, -1}, {27167, -1, -1, -1}, {27112, -1, -1, -1}, {27137, -1, -1, -1}, {27166, -1, -1, -1}, {27161, -1, -1, -1}, {27133, -1, -1, -1}, {27169, -1, -1, -1}, {27155, -1, -1, -1}, {27146, -1, -1, -1}, {27123, -1, -1, -1}, {27138, -1, -1, -1}, {27141, -1, -1, -1}, {27117, -1, -1, -1}, {27153, -1, -1, -1}, {27472, -1, -1, -1}, {27470, -1, -1, -1}, {27556, -1, -1, -1}, {27589, -1, -1, -1}, {27590, -1, -1, -1}, {28479, -1, -1, -1}, {28540, -1, -1, -1}, {28548, -1, -1, -1}, {28497, -1, -1, -1}, {28518, -1, -1, -1}, {28500, -1, -1, -1}, {28550, -1, -1, -1}, {28525, -1, -1, -1}, {28507, -1, -1, -1}, {28536, -1, -1, -1}, {28526, -1, -1, -1}, {28558, -1, -1, -1}, {28538, -1, -1, -1}, {28528, -1, -1, -1}, {28516, -1, -1, -1}, {28567, -1, -1, -1}, {28504, -1, -1, -1}, {28373, -1, -1, -1}, {28527, -1, -1, -1}, {28512, -1, -1, -1}, {28511, -1, -1, -1}, {29087, -1, -1, -1}, {29100, -1, -1, -1}, {29105, -1, -1, -1}, {29096, -1, -1, -1}, {29270, -1, -1, -1}, {29339, -1, -1, -1}, {29518, -1, -1, -1}, {29527, -1, -1, -1}, {29801, -1, -1, -1}, {29835, -1, -1, -1}, {29827, -1, -1, -1}, {29822, -1, -1, -1}, {29824, -1, -1, -1}, {30079, -1, -1, -1}, {30240, -1, -1, -1}, {30249, -1, -1, -1}, {30239, -1, -1, -1}, {30244, -1, -1, -1}, {30246, -1, -1, -1}, {30241, -1, -1, -1}, {30242, -1, -1, -1}, {30362, -1, -1, -1}, {30394, -1, -1, -1}, {30436, -1, -1, -1}, {30606, -1, -1, -1}, {30599, -1, -1, -1}, {30604, -1, -1, -1}, {30609, -1, -1, -1}, {30603, -1, -1, -1}, {30923, -1, -1, -1}, {30917, -1, -1, -1}, {30906, -1, -1, -1}, {30922, -1, -1, -1}, {30910, -1, -1, -1}, {30933, -1, -1, -1}, {30908, -1, -1, -1}, {30928, -1, -1, -1}, {31295, -1, -1, -1}, {31292, -1, -1, -1}, {31296, -1, -1, -1}, {31293, -1, -1, -1}, {31287, -1, -1, -1}, {31291, -1, -1, -1}, {31407, -1, -1, -1}, {31406, -1, -1, -1}, {31661, -1, -1, -1}, {31665, -1, -1, -1}, {31684, -1, -1, -1}, {31668, -1, -1, -1}, {31686, -1, -1, -1}, {31687, -1, -1, -1}, {31681, -1, -1, -1}, {31648, -1, -1, -1}, {31692, -1, -1, -1}, {31946, -1, -1, -1}, {32224, -1, -1, -1}, {32244, -1, -1, -1}, {32239, -1, -1, -1}, {32251, -1, -1, -1}, {32216, -1, -1, -1}, {32236, -1, -1, -1}, {32221, -1, -1, -1}, {32232, -1, -1, -1}, {32227, -1, -1, -1}, {32218, -1, -1, -1}, {32222, -1, -1, -1}, {32233, -1, -1, -1}, {32158, -1, -1, -1}, {32217, -1, -1, -1}, {32242, -1, -1, -1}, {32249, -1, -1, -1}, {32629, -1, -1, -1}, {32631, -1, -1, -1}, {32687, -1, -1, -1}, {32745, -1, -1, -1}, {32806, -1, -1, -1}, {33179, -1, -1, -1}, {33180, -1, -1, -1}, {33181, -1, -1, -1}, {33184, -1, -1, -1}, {33178, -1, -1, -1}, {33176, -1, -1, -1}, {34071, -1, -1, -1}, {34109, -1, -1, -1}, {34074, -1, -1, -1}, {34030, -1, -1, -1}, {34092, -1, -1, -1}, {34093, -1, -1, -1}, {34067, -1, -1, -1}, {34065, -1, -1, -1}, {34083, -1, -1, -1}, {34081, -1, -1, -1}, {34068, -1, -1, -1}, {34028, -1, -1, -1}, {34085, -1, -1, -1}, {34047, -1, -1, -1}, {34054, -1, -1, -1}, {34690, -1, -1, -1} },
+ {{34676, -1, -1, -1}, {34678, -1, -1, -1}, {34656, -1, -1, -1}, {34662, -1, -1, -1}, {34680, -1, -1, -1}, {34664, -1, -1, -1}, {34649, -1, -1, -1}, {34647, -1, -1, -1}, {34636, -1, -1, -1}, {34643, -1, -1, -1}, {34907, -1, -1, -1}, {34909, -1, -1, -1}, {35088, -1, -1, -1}, {35079, -1, -1, -1}, {35090, -1, -1, -1}, {35091, -1, -1, -1}, {35093, -1, -1, -1}, {35082, -1, -1, -1}, {35516, -1, -1, -1}, {35538, -1, -1, -1}, {35527, -1, -1, -1}, {35524, -1, -1, -1}, {35477, -1, -1, -1}, {35531, -1, -1, -1}, {35576, -1, -1, -1}, {35506, -1, -1, -1}, {35529, -1, -1, -1}, {35522, -1, -1, -1}, {35519, -1, -1, -1}, {35504, -1, -1, -1}, {35542, -1, -1, -1}, {35533, -1, -1, -1}, {35510, -1, -1, -1}, {35513, -1, -1, -1}, {35547, -1, -1, -1}, {35916, -1, -1, -1}, {35918, -1, -1, -1}, {35948, -1, -1, -1}, {36064, -1, -1, -1}, {36062, -1, -1, -1}, {36070, -1, -1, -1}, {36068, -1, -1, -1}, {36076, -1, -1, -1}, {36077, -1, -1, -1}, {36066, -1, -1, -1}, {36067, -1, -1, -1}, {36060, -1, -1, -1}, {36074, -1, -1, -1}, {36065, -1, -1, -1}, {36205, -1, -1, -1}, {36255, -1, -1, -1}, {36259, -1, -1, -1}, {36395, -1, -1, -1}, {36368, -1, -1, -1}, {36381, -1, -1, -1}, {36386, -1, -1, -1}, {36367, -1, -1, -1}, {36393, -1, -1, -1}, {36383, -1, -1, -1}, {36385, -1, -1, -1}, {36382, -1, -1, -1}, {36538, -1, -1, -1}, {36637, -1, -1, -1}, {36635, -1, -1, -1}, {36639, -1, -1, -1}, {36649, -1, -1, -1}, {36646, -1, -1, -1}, {36650, -1, -1, -1}, {36636, -1, -1, -1}, {36638, -1, -1, -1}, {36645, -1, -1, -1}, {36969, -1, -1, -1}, {36974, -1, -1, -1}, {36968, -1, -1, -1}, {36973, -1, -1, -1}, {36983, -1, -1, -1}, {37168, -1, -1, -1}, {37165, -1, -1, -1}, {37159, -1, -1, -1}, {37169, -1, -1, -1}, {37255, -1, -1, -1}, {37257, -1, -1, -1}, {37259, -1, -1, -1}, {37251, -1, -1, -1}, {37573, -1, -1, -1}, {37563, -1, -1, -1}, {37559, -1, -1, -1}, {37610, -1, -1, -1}, {37604, -1, -1, -1}, {37569, -1, -1, -1}, {37555, -1, -1, -1}, {37564, -1, -1, -1}, {37586, -1, -1, -1}, {37575, -1, -1, -1}, {37616, -1, -1, -1}, {37554, -1, -1, -1}, {38317, -1, -1, -1}, {38321, -1, -1, -1}, {38660, -1, -1, -1}, {38662, -1, -1, -1}, {38663, -1, -1, -1}, {38665, -1, -1, -1}, {38752, -1, -1, -1}, {38797, -1, -1, -1}, {38795, -1, -1, -1}, {38799, -1, -1, -1}, {38945, -1, -1, -1}, {38955, -1, -1, -1}, {38940, -1, -1, -1}, {39091, -1, -1, -1}, {39178, -1, -1, -1}, {39187, -1, -1, -1}, {39186, -1, -1, -1}, {39192, -1, -1, -1}, {39389, -1, -1, -1}, {39376, -1, -1, -1}, {39391, -1, -1, -1}, {39387, -1, -1, -1}, {39377, -1, -1, -1}, {39381, -1, -1, -1}, {39378, -1, -1, -1}, {39385, -1, -1, -1}, {39607, -1, -1, -1}, {39662, -1, -1, -1}, {39663, -1, -1, -1}, {39719, -1, -1, -1}, {39749, -1, -1, -1}, {39748, -1, -1, -1}, {39799, -1, -1, -1}, {39791, -1, -1, -1}, {40198, -1, -1, -1}, {40201, -1, -1, -1}, {40195, -1, -1, -1}, {40617, -1, -1, -1}, {40638, -1, -1, -1}, {40654, -1, -1, -1}, {22696, -1, -1, -1}, {40786, -1, -1, -1}, {20754, -1, -1, -1}, {20760, -1, -1, -1}, {20756, -1, -1, -1}, {20752, -1, -1, -1}, {20757, -1, -1, -1}, {20864, -1, -1, -1}, {20906, -1, -1, -1}, {20957, -1, -1, -1}, {21137, -1, -1, -1}, {21139, -1, -1, -1}, {21235, -1, -1, -1}, {22105, -1, -1, -1}, {22123, -1, -1, -1}, {22137, -1, -1, -1}, {22121, -1, -1, -1}, {22116, -1, -1, -1}, {22136, -1, -1, -1}, {22122, -1, -1, -1}, {22120, -1, -1, -1}, {22117, -1, -1, -1}, {22129, -1, -1, -1}, {22127, -1, -1, -1}, {22124, -1, -1, -1}, {22114, -1, -1, -1}, {22134, -1, -1, -1}, {22721, -1, -1, -1}, {22718, -1, -1, -1}, {22727, -1, -1, -1}, {22725, -1, -1, -1}, {22894, -1, -1, -1}, {23325, -1, -1, -1}, {23348, -1, -1, -1}, {23416, -1, -1, -1}, {23536, -1, -1, -1}, {23566, -1, -1, -1}, {24394, -1, -1, -1}, {25010, -1, -1, -1}, {24977, -1, -1, -1}, {25001, -1, -1, -1}, {24970, -1, -1, -1}, {25037, -1, -1, -1}, {25014, -1, -1, -1}, {25022, -1, -1, -1}, {25034, -1, -1, -1}, {25032, -1, -1, -1}, {25136, -1, -1, -1}, {25797, -1, -1, -1}, {25793, -1, -1, -1}, {25803, -1, -1, -1}, {25787, -1, -1, -1}, {25788, -1, -1, -1}, {25818, -1, -1, -1}, {25796, -1, -1, -1}, {25799, -1, -1, -1}, {25794, -1, -1, -1}, {25805, -1, -1, -1}, {25791, -1, -1, -1}, {25810, -1, -1, -1}, {25812, -1, -1, -1}, {25790, -1, -1, -1}, {25972, -1, -1, -1}, {26310, -1, -1, -1}, {26313, -1, -1, -1}, {26297, -1, -1, -1}, {26308, -1, -1, -1}, {26311, -1, -1, -1}, {26296, -1, -1, -1}, {27197, -1, -1, -1}, {27192, -1, -1, -1}, {27194, -1, -1, -1}, {27225, -1, -1, -1}, {27243, -1, -1, -1}, {27224, -1, -1, -1}, {27193, -1, -1, -1}, {27204, -1, -1, -1}, {27234, -1, -1, -1}, {27233, -1, -1, -1}, {27211, -1, -1, -1}, {27207, -1, -1, -1}, {27189, -1, -1, -1}, {27231, -1, -1, -1}, {27208, -1, -1, -1}, {27481, -1, -1, -1}, {27511, -1, -1, -1}, {27653, -1, -1, -1}, {28610, -1, -1, -1}, {28593, -1, -1, -1}, {28577, -1, -1, -1}, {28611, -1, -1, -1}, {28580, -1, -1, -1}, {28609, -1, -1, -1}, {28583, -1, -1, -1}, {28595, -1, -1, -1}, {28608, -1, -1, -1}, {28601, -1, -1, -1}, {28598, -1, -1, -1}, {28582, -1, -1, -1}, {28576, -1, -1, -1}, {28596, -1, -1, -1}, {29118, -1, -1, -1}, {29129, -1, -1, -1}, {29136, -1, -1, -1}, {29138, -1, -1, -1}, {29128, -1, -1, -1}, {29141, -1, -1, -1}, {29113, -1, -1, -1}, {29134, -1, -1, -1}, {29145, -1, -1, -1}, {29148, -1, -1, -1}, {29123, -1, -1, -1}, {29124, -1, -1, -1}, {29544, -1, -1, -1}, {29852, -1, -1, -1}, {29859, -1, -1, -1}, {29848, -1, -1, -1}, {29855, -1, -1, -1}, {29854, -1, -1, -1}, {29922, -1, -1, -1} },
+ {{29964, -1, -1, -1}, {29965, -1, -1, -1}, {30260, -1, -1, -1}, {30264, -1, -1, -1}, {30266, -1, -1, -1}, {30439, -1, -1, -1}, {30437, -1, -1, -1}, {30624, -1, -1, -1}, {30622, -1, -1, -1}, {30623, -1, -1, -1}, {30629, -1, -1, -1}, {30952, -1, -1, -1}, {30938, -1, -1, -1}, {30956, -1, -1, -1}, {30951, -1, -1, -1}, {31142, -1, -1, -1}, {31309, -1, -1, -1}, {31310, -1, -1, -1}, {31302, -1, -1, -1}, {31308, -1, -1, -1}, {31307, -1, -1, -1}, {31418, -1, -1, -1}, {31705, -1, -1, -1}, {31761, -1, -1, -1}, {31689, -1, -1, -1}, {31716, -1, -1, -1}, {31707, -1, -1, -1}, {31713, -1, -1, -1}, {31721, -1, -1, -1}, {31718, -1, -1, -1}, {31957, -1, -1, -1}, {31958, -1, -1, -1}, {32266, -1, -1, -1}, {32273, -1, -1, -1}, {32264, -1, -1, -1}, {32283, -1, -1, -1}, {32291, -1, -1, -1}, {32286, -1, -1, -1}, {32285, -1, -1, -1}, {32265, -1, -1, -1}, {32272, -1, -1, -1}, {32633, -1, -1, -1}, {32690, -1, -1, -1}, {32752, -1, -1, -1}, {32753, -1, -1, -1}, {32750, -1, -1, -1}, {32808, -1, -1, -1}, {33203, -1, -1, -1}, {33193, -1, -1, -1}, {33192, -1, -1, -1}, {33275, -1, -1, -1}, {33288, -1, -1, -1}, {33368, -1, -1, -1}, {33369, -1, -1, -1}, {34122, -1, -1, -1}, {34137, -1, -1, -1}, {34120, -1, -1, -1}, {34152, -1, -1, -1}, {34153, -1, -1, -1}, {34115, -1, -1, -1}, {34121, -1, -1, -1}, {34157, -1, -1, -1}, {34154, -1, -1, -1}, {34142, -1, -1, -1}, {34691, -1, -1, -1}, {34719, -1, -1, -1}, {34718, -1, -1, -1}, {34722, -1, -1, -1}, {34701, -1, -1, -1}, {34913, -1, -1, -1}, {35114, -1, -1, -1}, {35122, -1, -1, -1}, {35109, -1, -1, -1}, {35115, -1, -1, -1}, {35105, -1, -1, -1}, {35242, -1, -1, -1}, {35238, -1, -1, -1}, {35558, -1, -1, -1}, {35578, -1, -1, -1}, {35563, -1, -1, -1}, {35569, -1, -1, -1}, {35584, -1, -1, -1}, {35548, -1, -1, -1}, {35559, -1, -1, -1}, {35566, -1, -1, -1}, {35582, -1, -1, -1}, {35585, -1, -1, -1}, {35586, -1, -1, -1}, {35575, -1, -1, -1}, {35565, -1, -1, -1}, {35571, -1, -1, -1}, {35574, -1, -1, -1}, {35580, -1, -1, -1}, {35947, -1, -1, -1}, {35949, -1, -1, -1}, {35987, -1, -1, -1}, {36084, -1, -1, -1}, {36420, -1, -1, -1}, {36401, -1, -1, -1}, {36404, -1, -1, -1}, {36418, -1, -1, -1}, {36409, -1, -1, -1}, {36405, -1, -1, -1}, {36667, -1, -1, -1}, {36655, -1, -1, -1}, {36664, -1, -1, -1}, {36659, -1, -1, -1}, {36776, -1, -1, -1}, {36774, -1, -1, -1}, {36981, -1, -1, -1}, {36980, -1, -1, -1}, {36984, -1, -1, -1}, {36978, -1, -1, -1}, {36988, -1, -1, -1}, {36986, -1, -1, -1}, {37172, -1, -1, -1}, {37266, -1, -1, -1}, {37664, -1, -1, -1}, {37686, -1, -1, -1}, {37624, -1, -1, -1}, {37683, -1, -1, -1}, {37679, -1, -1, -1}, {37666, -1, -1, -1}, {37628, -1, -1, -1}, {37675, -1, -1, -1}, {37636, -1, -1, -1}, {37658, -1, -1, -1}, {37648, -1, -1, -1}, {37670, -1, -1, -1}, {37665, -1, -1, -1}, {37653, -1, -1, -1}, {37678, -1, -1, -1}, {37657, -1, -1, -1}, {38331, -1, -1, -1}, {38567, -1, -1, -1}, {38568, -1, -1, -1}, {38570, -1, -1, -1}, {38613, -1, -1, -1}, {38670, -1, -1, -1}, {38673, -1, -1, -1}, {38678, -1, -1, -1}, {38669, -1, -1, -1}, {38675, -1, -1, -1}, {38671, -1, -1, -1}, {38747, -1, -1, -1}, {38748, -1, -1, -1}, {38758, -1, -1, -1}, {38808, -1, -1, -1}, {38960, -1, -1, -1}, {38968, -1, -1, -1}, {38971, -1, -1, -1}, {38967, -1, -1, -1}, {38957, -1, -1, -1}, {38969, -1, -1, -1}, {38948, -1, -1, -1}, {39184, -1, -1, -1}, {39208, -1, -1, -1}, {39198, -1, -1, -1}, {39195, -1, -1, -1}, {39201, -1, -1, -1}, {39194, -1, -1, -1}, {39405, -1, -1, -1}, {39394, -1, -1, -1}, {39409, -1, -1, -1}, {39608, -1, -1, -1}, {39612, -1, -1, -1}, {39675, -1, -1, -1}, {39661, -1, -1, -1}, {39720, -1, -1, -1}, {39825, -1, -1, -1}, {40213, -1, -1, -1}, {40227, -1, -1, -1}, {40230, -1, -1, -1}, {40232, -1, -1, -1}, {40210, -1, -1, -1}, {40219, -1, -1, -1}, {40664, -1, -1, -1}, {40660, -1, -1, -1}, {40845, -1, -1, -1}, {40860, -1, -1, -1}, {20778, -1, -1, -1}, {20767, -1, -1, -1}, {20769, -1, -1, -1}, {20786, -1, -1, -1}, {21237, -1, -1, -1}, {22158, -1, -1, -1}, {22144, -1, -1, -1}, {22160, -1, -1, -1}, {22149, -1, -1, -1}, {22151, -1, -1, -1}, {22159, -1, -1, -1}, {22741, -1, -1, -1}, {22739, -1, -1, -1}, {22737, -1, -1, -1}, {22734, -1, -1, -1}, {23344, -1, -1, -1}, {23338, -1, -1, -1}, {23332, -1, -1, -1}, {23418, -1, -1, -1}, {23607, -1, -1, -1}, {23656, -1, -1, -1}, {23996, -1, -1, -1}, {23994, -1, -1, -1}, {23997, -1, -1, -1}, {23992, -1, -1, -1}, {24171, -1, -1, -1}, {24396, -1, -1, -1}, {24509, -1, -1, -1}, {25033, -1, -1, -1}, {25026, -1, -1, -1}, {25031, -1, -1, -1}, {25062, -1, -1, -1}, {25035, -1, -1, -1}, {25138, -1, -1, -1}, {25140, -1, -1, -1}, {25806, -1, -1, -1}, {25802, -1, -1, -1}, {25816, -1, -1, -1}, {25824, -1, -1, -1}, {25840, -1, -1, -1}, {25830, -1, -1, -1}, {25836, -1, -1, -1}, {25841, -1, -1, -1}, {25826, -1, -1, -1}, {25837, -1, -1, -1}, {25986, -1, -1, -1}, {25987, -1, -1, -1}, {26329, -1, -1, -1}, {26326, -1, -1, -1}, {27264, -1, -1, -1}, {27284, -1, -1, -1}, {27268, -1, -1, -1}, {27298, -1, -1, -1}, {27292, -1, -1, -1}, {27355, -1, -1, -1}, {27299, -1, -1, -1}, {27262, -1, -1, -1}, {27287, -1, -1, -1}, {27280, -1, -1, -1}, {27296, -1, -1, -1}, {27484, -1, -1, -1}, {27566, -1, -1, -1}, {27610, -1, -1, -1}, {27656, -1, -1, -1}, {28632, -1, -1, -1}, {28657, -1, -1, -1}, {28639, -1, -1, -1}, {28640, -1, -1, -1}, {28635, -1, -1, -1}, {28644, -1, -1, -1}, {28651, -1, -1, -1}, {28655, -1, -1, -1}, {28544, -1, -1, -1}, {28652, -1, -1, -1}, {28641, -1, -1, -1}, {28649, -1, -1, -1} },
+ {{28629, -1, -1, -1}, {28654, -1, -1, -1}, {28656, -1, -1, -1}, {29159, -1, -1, -1}, {29151, -1, -1, -1}, {29166, -1, -1, -1}, {29158, -1, -1, -1}, {29157, -1, -1, -1}, {29165, -1, -1, -1}, {29164, -1, -1, -1}, {29172, -1, -1, -1}, {29152, -1, -1, -1}, {29237, -1, -1, -1}, {29254, -1, -1, -1}, {29552, -1, -1, -1}, {29554, -1, -1, -1}, {29865, -1, -1, -1}, {29872, -1, -1, -1}, {29862, -1, -1, -1}, {29864, -1, -1, -1}, {30278, -1, -1, -1}, {30274, -1, -1, -1}, {30284, -1, -1, -1}, {30442, -1, -1, -1}, {30643, -1, -1, -1}, {30634, -1, -1, -1}, {30640, -1, -1, -1}, {30636, -1, -1, -1}, {30631, -1, -1, -1}, {30637, -1, -1, -1}, {30703, -1, -1, -1}, {30967, -1, -1, -1}, {30970, -1, -1, -1}, {30964, -1, -1, -1}, {30959, -1, -1, -1}, {30977, -1, -1, -1}, {31143, -1, -1, -1}, {31146, -1, -1, -1}, {31319, -1, -1, -1}, {31423, -1, -1, -1}, {31751, -1, -1, -1}, {31757, -1, -1, -1}, {31742, -1, -1, -1}, {31735, -1, -1, -1}, {31756, -1, -1, -1}, {31712, -1, -1, -1}, {31968, -1, -1, -1}, {31964, -1, -1, -1}, {31966, -1, -1, -1}, {31970, -1, -1, -1}, {31967, -1, -1, -1}, {31961, -1, -1, -1}, {31965, -1, -1, -1}, {32302, -1, -1, -1}, {32318, -1, -1, -1}, {32326, -1, -1, -1}, {32311, -1, -1, -1}, {32306, -1, -1, -1}, {32323, -1, -1, -1}, {32299, -1, -1, -1}, {32317, -1, -1, -1}, {32305, -1, -1, -1}, {32325, -1, -1, -1}, {32321, -1, -1, -1}, {32308, -1, -1, -1}, {32313, -1, -1, -1}, {32328, -1, -1, -1}, {32309, -1, -1, -1}, {32319, -1, -1, -1}, {32303, -1, -1, -1}, {32580, -1, -1, -1}, {32755, -1, -1, -1}, {32764, -1, -1, -1}, {32881, -1, -1, -1}, {32882, -1, -1, -1}, {32880, -1, -1, -1}, {32879, -1, -1, -1}, {32883, -1, -1, -1}, {33222, -1, -1, -1}, {33219, -1, -1, -1}, {33210, -1, -1, -1}, {33218, -1, -1, -1}, {33216, -1, -1, -1}, {33215, -1, -1, -1}, {33213, -1, -1, -1}, {33225, -1, -1, -1}, {33214, -1, -1, -1}, {33256, -1, -1, -1}, {33289, -1, -1, -1}, {33393, -1, -1, -1}, {34218, -1, -1, -1}, {34180, -1, -1, -1}, {34174, -1, -1, -1}, {34204, -1, -1, -1}, {34193, -1, -1, -1}, {34196, -1, -1, -1}, {34223, -1, -1, -1}, {34203, -1, -1, -1}, {34183, -1, -1, -1}, {34216, -1, -1, -1}, {34186, -1, -1, -1}, {34214, -1, -1, -1}, {34407, -1, -1, -1}, {34752, -1, -1, -1}, {34769, -1, -1, -1}, {34739, -1, -1, -1}, {34770, -1, -1, -1}, {34758, -1, -1, -1}, {34731, -1, -1, -1}, {34747, -1, -1, -1}, {34746, -1, -1, -1}, {34760, -1, -1, -1}, {34763, -1, -1, -1}, {35131, -1, -1, -1}, {35126, -1, -1, -1}, {35140, -1, -1, -1}, {35128, -1, -1, -1}, {35133, -1, -1, -1}, {35244, -1, -1, -1}, {35598, -1, -1, -1}, {35607, -1, -1, -1}, {35609, -1, -1, -1}, {35611, -1, -1, -1}, {35594, -1, -1, -1}, {35616, -1, -1, -1}, {35613, -1, -1, -1}, {35588, -1, -1, -1}, {35600, -1, -1, -1}, {35905, -1, -1, -1}, {35903, -1, -1, -1}, {35955, -1, -1, -1}, {36090, -1, -1, -1}, {36093, -1, -1, -1}, {36092, -1, -1, -1}, {36088, -1, -1, -1}, {36091, -1, -1, -1}, {36264, -1, -1, -1}, {36425, -1, -1, -1}, {36427, -1, -1, -1}, {36424, -1, -1, -1}, {36426, -1, -1, -1}, {36676, -1, -1, -1}, {36670, -1, -1, -1}, {36674, -1, -1, -1}, {36677, -1, -1, -1}, {36671, -1, -1, -1}, {36991, -1, -1, -1}, {36989, -1, -1, -1}, {36996, -1, -1, -1}, {36993, -1, -1, -1}, {36994, -1, -1, -1}, {36992, -1, -1, -1}, {37177, -1, -1, -1}, {37283, -1, -1, -1}, {37278, -1, -1, -1}, {37276, -1, -1, -1}, {37709, -1, -1, -1}, {37762, -1, -1, -1}, {37672, -1, -1, -1}, {37749, -1, -1, -1}, {37706, -1, -1, -1}, {37733, -1, -1, -1}, {37707, -1, -1, -1}, {37656, -1, -1, -1}, {37758, -1, -1, -1}, {37740, -1, -1, -1}, {37723, -1, -1, -1}, {37744, -1, -1, -1}, {37722, -1, -1, -1}, {37716, -1, -1, -1}, {38346, -1, -1, -1}, {38347, -1, -1, -1}, {38348, -1, -1, -1}, {38344, -1, -1, -1}, {38342, -1, -1, -1}, {38577, -1, -1, -1}, {38584, -1, -1, -1}, {38614, -1, -1, -1}, {38684, -1, -1, -1}, {38686, -1, -1, -1}, {38816, -1, -1, -1}, {38867, -1, -1, -1}, {38982, -1, -1, -1}, {39094, -1, -1, -1}, {39221, -1, -1, -1}, {39425, -1, -1, -1}, {39423, -1, -1, -1}, {39854, -1, -1, -1}, {39851, -1, -1, -1}, {39850, -1, -1, -1}, {39853, -1, -1, -1}, {40251, -1, -1, -1}, {40255, -1, -1, -1}, {40587, -1, -1, -1}, {40655, -1, -1, -1}, {40670, -1, -1, -1}, {40668, -1, -1, -1}, {40669, -1, -1, -1}, {40667, -1, -1, -1}, {40766, -1, -1, -1}, {40779, -1, -1, -1}, {21474, -1, -1, -1}, {22165, -1, -1, -1}, {22190, -1, -1, -1}, {22745, -1, -1, -1}, {22744, -1, -1, -1}, {23352, -1, -1, -1}, {24413, -1, -1, -1}, {25059, -1, -1, -1}, {25139, -1, -1, -1}, {25844, -1, -1, -1}, {25842, -1, -1, -1}, {25854, -1, -1, -1}, {25862, -1, -1, -1}, {25850, -1, -1, -1}, {25851, -1, -1, -1}, {25847, -1, -1, -1}, {26039, -1, -1, -1}, {26332, -1, -1, -1}, {26406, -1, -1, -1}, {27315, -1, -1, -1}, {27308, -1, -1, -1}, {27331, -1, -1, -1}, {27323, -1, -1, -1}, {27320, -1, -1, -1}, {27330, -1, -1, -1}, {27310, -1, -1, -1}, {27311, -1, -1, -1}, {27487, -1, -1, -1}, {27512, -1, -1, -1}, {27567, -1, -1, -1}, {28681, -1, -1, -1}, {28683, -1, -1, -1}, {28670, -1, -1, -1}, {28678, -1, -1, -1}, {28666, -1, -1, -1}, {28689, -1, -1, -1}, {28687, -1, -1, -1}, {29179, -1, -1, -1}, {29180, -1, -1, -1}, {29182, -1, -1, -1}, {29176, -1, -1, -1}, {29559, -1, -1, -1}, {29557, -1, -1, -1}, {29863, -1, -1, -1}, {29887, -1, -1, -1}, {29973, -1, -1, -1}, {30294, -1, -1, -1}, {30296, -1, -1, -1}, {30290, -1, -1, -1}, {30653, -1, -1, -1}, {30655, -1, -1, -1}, {30651, -1, -1, -1}, {30652, -1, -1, -1}, {30990, -1, -1, -1}, {31150, -1, -1, -1} },
+ {{31329, -1, -1, -1}, {31330, -1, -1, -1}, {31328, -1, -1, -1}, {31428, -1, -1, -1}, {31429, -1, -1, -1}, {31787, -1, -1, -1}, {31783, -1, -1, -1}, {31786, -1, -1, -1}, {31774, -1, -1, -1}, {31779, -1, -1, -1}, {31777, -1, -1, -1}, {31975, -1, -1, -1}, {32340, -1, -1, -1}, {32341, -1, -1, -1}, {32350, -1, -1, -1}, {32346, -1, -1, -1}, {32353, -1, -1, -1}, {32338, -1, -1, -1}, {32345, -1, -1, -1}, {32584, -1, -1, -1}, {32761, -1, -1, -1}, {32763, -1, -1, -1}, {32887, -1, -1, -1}, {32886, -1, -1, -1}, {33229, -1, -1, -1}, {33231, -1, -1, -1}, {33290, -1, -1, -1}, {34255, -1, -1, -1}, {34217, -1, -1, -1}, {34253, -1, -1, -1}, {34256, -1, -1, -1}, {34249, -1, -1, -1}, {34224, -1, -1, -1}, {34234, -1, -1, -1}, {34233, -1, -1, -1}, {34799, -1, -1, -1}, {34796, -1, -1, -1}, {34802, -1, -1, -1}, {34784, -1, -1, -1}, {35206, -1, -1, -1}, {35250, -1, -1, -1}, {35316, -1, -1, -1}, {35624, -1, -1, -1}, {35641, -1, -1, -1}, {35628, -1, -1, -1}, {35627, -1, -1, -1}, {35920, -1, -1, -1}, {36101, -1, -1, -1}, {36441, -1, -1, -1}, {36451, -1, -1, -1}, {36454, -1, -1, -1}, {36452, -1, -1, -1}, {36447, -1, -1, -1}, {36437, -1, -1, -1}, {36544, -1, -1, -1}, {36681, -1, -1, -1}, {36685, -1, -1, -1}, {36999, -1, -1, -1}, {36995, -1, -1, -1}, {37000, -1, -1, -1}, {37291, -1, -1, -1}, {37292, -1, -1, -1}, {37328, -1, -1, -1}, {37780, -1, -1, -1}, {37770, -1, -1, -1}, {37782, -1, -1, -1}, {37794, -1, -1, -1}, {37811, -1, -1, -1}, {37806, -1, -1, -1}, {37804, -1, -1, -1}, {37808, -1, -1, -1}, {37784, -1, -1, -1}, {37786, -1, -1, -1}, {37783, -1, -1, -1}, {38356, -1, -1, -1}, {38358, -1, -1, -1}, {38352, -1, -1, -1}, {38357, -1, -1, -1}, {38626, -1, -1, -1}, {38620, -1, -1, -1}, {38617, -1, -1, -1}, {38619, -1, -1, -1}, {38622, -1, -1, -1}, {38692, -1, -1, -1}, {38819, -1, -1, -1}, {38822, -1, -1, -1}, {38829, -1, -1, -1}, {38905, -1, -1, -1}, {38989, -1, -1, -1}, {38991, -1, -1, -1}, {38988, -1, -1, -1}, {38990, -1, -1, -1}, {38995, -1, -1, -1}, {39098, -1, -1, -1}, {39230, -1, -1, -1}, {39231, -1, -1, -1}, {39229, -1, -1, -1}, {39214, -1, -1, -1}, {39333, -1, -1, -1}, {39438, -1, -1, -1}, {39617, -1, -1, -1}, {39683, -1, -1, -1}, {39686, -1, -1, -1}, {39759, -1, -1, -1}, {39758, -1, -1, -1}, {39757, -1, -1, -1}, {39882, -1, -1, -1}, {39881, -1, -1, -1}, {39933, -1, -1, -1}, {39880, -1, -1, -1}, {39872, -1, -1, -1}, {40273, -1, -1, -1}, {40285, -1, -1, -1}, {40288, -1, -1, -1}, {40672, -1, -1, -1}, {40725, -1, -1, -1}, {40748, -1, -1, -1}, {20787, -1, -1, -1}, {22181, -1, -1, -1}, {22184, -1, -1, -1}, {22750, -1, -1, -1}, {22751, -1, -1, -1}, {22754, -1, -1, -1}, {23541, -1, -1, -1}, {40848, -1, -1, -1}, {24300, -1, -1, -1}, {25074, -1, -1, -1}, {25079, -1, -1, -1}, {25078, -1, -1, -1}, {25077, -1, -1, -1}, {25856, -1, -1, -1}, {25871, -1, -1, -1}, {26336, -1, -1, -1}, {26333, -1, -1, -1}, {27365, -1, -1, -1}, {27357, -1, -1, -1}, {27354, -1, -1, -1}, {27347, -1, -1, -1}, {28699, -1, -1, -1}, {28703, -1, -1, -1}, {28712, -1, -1, -1}, {28698, -1, -1, -1}, {28701, -1, -1, -1}, {28693, -1, -1, -1}, {28696, -1, -1, -1}, {29190, -1, -1, -1}, {29197, -1, -1, -1}, {29272, -1, -1, -1}, {29346, -1, -1, -1}, {29560, -1, -1, -1}, {29562, -1, -1, -1}, {29885, -1, -1, -1}, {29898, -1, -1, -1}, {29923, -1, -1, -1}, {30087, -1, -1, -1}, {30086, -1, -1, -1}, {30303, -1, -1, -1}, {30305, -1, -1, -1}, {30663, -1, -1, -1}, {31001, -1, -1, -1}, {31153, -1, -1, -1}, {31339, -1, -1, -1}, {31337, -1, -1, -1}, {31806, -1, -1, -1}, {31807, -1, -1, -1}, {31800, -1, -1, -1}, {31805, -1, -1, -1}, {31799, -1, -1, -1}, {31808, -1, -1, -1}, {32363, -1, -1, -1}, {32365, -1, -1, -1}, {32377, -1, -1, -1}, {32361, -1, -1, -1}, {32362, -1, -1, -1}, {32371, -1, -1, -1}, {32645, -1, -1, -1}, {32694, -1, -1, -1}, {32697, -1, -1, -1}, {32696, -1, -1, -1}, {33240, -1, -1, -1}, {34281, -1, -1, -1}, {34269, -1, -1, -1}, {34282, -1, -1, -1}, {34261, -1, -1, -1}, {34276, -1, -1, -1}, {34277, -1, -1, -1}, {34295, -1, -1, -1}, {34811, -1, -1, -1}, {34821, -1, -1, -1}, {34829, -1, -1, -1}, {34809, -1, -1, -1}, {34814, -1, -1, -1}, {35168, -1, -1, -1}, {35167, -1, -1, -1}, {35158, -1, -1, -1}, {35166, -1, -1, -1}, {35649, -1, -1, -1}, {35676, -1, -1, -1}, {35672, -1, -1, -1}, {35657, -1, -1, -1}, {35674, -1, -1, -1}, {35662, -1, -1, -1}, {35663, -1, -1, -1}, {35654, -1, -1, -1}, {35673, -1, -1, -1}, {36104, -1, -1, -1}, {36106, -1, -1, -1}, {36476, -1, -1, -1}, {36466, -1, -1, -1}, {36487, -1, -1, -1}, {36470, -1, -1, -1}, {36460, -1, -1, -1}, {36474, -1, -1, -1}, {36468, -1, -1, -1}, {36692, -1, -1, -1}, {36686, -1, -1, -1}, {36781, -1, -1, -1}, {37002, -1, -1, -1}, {37003, -1, -1, -1}, {37297, -1, -1, -1}, {37294, -1, -1, -1}, {37857, -1, -1, -1}, {37841, -1, -1, -1}, {37855, -1, -1, -1}, {37827, -1, -1, -1}, {37832, -1, -1, -1}, {37852, -1, -1, -1}, {37853, -1, -1, -1}, {37846, -1, -1, -1}, {37858, -1, -1, -1}, {37837, -1, -1, -1}, {37848, -1, -1, -1}, {37860, -1, -1, -1}, {37847, -1, -1, -1}, {37864, -1, -1, -1}, {38364, -1, -1, -1}, {38580, -1, -1, -1}, {38627, -1, -1, -1}, {38698, -1, -1, -1}, {38695, -1, -1, -1}, {38753, -1, -1, -1}, {38876, -1, -1, -1}, {38907, -1, -1, -1}, {39006, -1, -1, -1}, {39000, -1, -1, -1}, {39003, -1, -1, -1}, {39100, -1, -1, -1}, {39237, -1, -1, -1}, {39241, -1, -1, -1}, {39446, -1, -1, -1}, {39449, -1, -1, -1}, {39693, -1, -1, -1}, {39912, -1, -1, -1}, {39911, -1, -1, -1}, {39894, -1, -1, -1}, {39899, -1, -1, -1} },
+ {{40329, -1, -1, -1}, {40289, -1, -1, -1}, {40306, -1, -1, -1}, {40298, -1, -1, -1}, {40300, -1, -1, -1}, {40594, -1, -1, -1}, {40599, -1, -1, -1}, {40595, -1, -1, -1}, {40628, -1, -1, -1}, {21240, -1, -1, -1}, {22199, -1, -1, -1}, {22198, -1, -1, -1}, {22196, -1, -1, -1}, {22204, -1, -1, -1}, {22756, -1, -1, -1}, {23360, -1, -1, -1}, {23363, -1, -1, -1}, {23421, -1, -1, -1}, {23542, -1, -1, -1}, {24009, -1, -1, -1}, {25080, -1, -1, -1}, {25082, -1, -1, -1}, {25880, -1, -1, -1}, {25876, -1, -1, -1}, {25881, -1, -1, -1}, {26342, -1, -1, -1}, {26407, -1, -1, -1}, {27372, -1, -1, -1}, {28734, -1, -1, -1}, {28720, -1, -1, -1}, {28722, -1, -1, -1}, {29200, -1, -1, -1}, {29563, -1, -1, -1}, {29903, -1, -1, -1}, {30306, -1, -1, -1}, {30309, -1, -1, -1}, {31014, -1, -1, -1}, {31018, -1, -1, -1}, {31020, -1, -1, -1}, {31019, -1, -1, -1}, {31431, -1, -1, -1}, {31478, -1, -1, -1}, {31820, -1, -1, -1}, {31811, -1, -1, -1}, {31821, -1, -1, -1}, {31983, -1, -1, -1}, {31984, -1, -1, -1}, {36782, -1, -1, -1}, {32381, -1, -1, -1}, {32380, -1, -1, -1}, {32386, -1, -1, -1}, {32588, -1, -1, -1}, {32768, -1, -1, -1}, {33242, -1, -1, -1}, {33382, -1, -1, -1}, {34299, -1, -1, -1}, {34297, -1, -1, -1}, {34321, -1, -1, -1}, {34298, -1, -1, -1}, {34310, -1, -1, -1}, {34315, -1, -1, -1}, {34311, -1, -1, -1}, {34314, -1, -1, -1}, {34836, -1, -1, -1}, {34837, -1, -1, -1}, {35172, -1, -1, -1}, {35258, -1, -1, -1}, {35320, -1, -1, -1}, {35696, -1, -1, -1}, {35692, -1, -1, -1}, {35686, -1, -1, -1}, {35695, -1, -1, -1}, {35679, -1, -1, -1}, {35691, -1, -1, -1}, {36111, -1, -1, -1}, {36109, -1, -1, -1}, {36489, -1, -1, -1}, {36481, -1, -1, -1}, {36485, -1, -1, -1}, {36482, -1, -1, -1}, {37300, -1, -1, -1}, {37323, -1, -1, -1}, {37912, -1, -1, -1}, {37891, -1, -1, -1}, {37885, -1, -1, -1}, {38369, -1, -1, -1}, {38704, -1, -1, -1}, {39108, -1, -1, -1}, {39250, -1, -1, -1}, {39249, -1, -1, -1}, {39336, -1, -1, -1}, {39467, -1, -1, -1}, {39472, -1, -1, -1}, {39479, -1, -1, -1}, {39477, -1, -1, -1}, {39955, -1, -1, -1}, {39949, -1, -1, -1}, {40569, -1, -1, -1}, {40629, -1, -1, -1}, {40680, -1, -1, -1}, {40751, -1, -1, -1}, {40799, -1, -1, -1}, {40803, -1, -1, -1}, {40801, -1, -1, -1}, {20791, -1, -1, -1}, {20792, -1, -1, -1}, {22209, -1, -1, -1}, {22208, -1, -1, -1}, {22210, -1, -1, -1}, {22804, -1, -1, -1}, {23660, -1, -1, -1}, {24013, -1, -1, -1}, {25084, -1, -1, -1}, {25086, -1, -1, -1}, {25885, -1, -1, -1}, {25884, -1, -1, -1}, {26005, -1, -1, -1}, {26345, -1, -1, -1}, {27387, -1, -1, -1}, {27396, -1, -1, -1}, {27386, -1, -1, -1}, {27570, -1, -1, -1}, {28748, -1, -1, -1}, {29211, -1, -1, -1}, {29351, -1, -1, -1}, {29910, -1, -1, -1}, {29908, -1, -1, -1}, {30313, -1, -1, -1}, {30675, -1, -1, -1}, {31824, -1, -1, -1}, {32399, -1, -1, -1}, {32396, -1, -1, -1}, {32700, -1, -1, -1}, {34327, -1, -1, -1}, {34349, -1, -1, -1}, {34330, -1, -1, -1}, {34851, -1, -1, -1}, {34850, -1, -1, -1}, {34849, -1, -1, -1}, {34847, -1, -1, -1}, {35178, -1, -1, -1}, {35180, -1, -1, -1}, {35261, -1, -1, -1}, {35700, -1, -1, -1}, {35703, -1, -1, -1}, {35709, -1, -1, -1}, {36115, -1, -1, -1}, {36490, -1, -1, -1}, {36493, -1, -1, -1}, {36491, -1, -1, -1}, {36703, -1, -1, -1}, {36783, -1, -1, -1}, {37306, -1, -1, -1}, {37934, -1, -1, -1}, {37939, -1, -1, -1}, {37941, -1, -1, -1}, {37946, -1, -1, -1}, {37944, -1, -1, -1}, {37938, -1, -1, -1}, {37931, -1, -1, -1}, {38370, -1, -1, -1}, {38712, -1, -1, -1}, {38713, -1, -1, -1}, {38706, -1, -1, -1}, {38911, -1, -1, -1}, {39015, -1, -1, -1}, {39013, -1, -1, -1}, {39255, -1, -1, -1}, {39493, -1, -1, -1}, {39491, -1, -1, -1}, {39488, -1, -1, -1}, {39486, -1, -1, -1}, {39631, -1, -1, -1}, {39764, -1, -1, -1}, {39761, -1, -1, -1}, {39981, -1, -1, -1}, {39973, -1, -1, -1}, {40367, -1, -1, -1}, {40372, -1, -1, -1}, {40386, -1, -1, -1}, {40376, -1, -1, -1}, {40605, -1, -1, -1}, {40687, -1, -1, -1}, {40729, -1, -1, -1}, {40796, -1, -1, -1}, {40806, -1, -1, -1}, {40807, -1, -1, -1}, {20796, -1, -1, -1}, {20795, -1, -1, -1}, {22216, -1, -1, -1}, {22218, -1, -1, -1}, {22217, -1, -1, -1}, {23423, -1, -1, -1}, {24020, -1, -1, -1}, {24018, -1, -1, -1}, {24398, -1, -1, -1}, {25087, -1, -1, -1}, {25892, -1, -1, -1}, {27402, -1, -1, -1}, {27489, -1, -1, -1}, {28753, -1, -1, -1}, {28760, -1, -1, -1}, {29568, -1, -1, -1}, {29924, -1, -1, -1}, {30090, -1, -1, -1}, {30318, -1, -1, -1}, {30316, -1, -1, -1}, {31155, -1, -1, -1}, {31840, -1, -1, -1}, {31839, -1, -1, -1}, {32894, -1, -1, -1}, {32893, -1, -1, -1}, {33247, -1, -1, -1}, {35186, -1, -1, -1}, {35183, -1, -1, -1}, {35324, -1, -1, -1}, {35712, -1, -1, -1}, {36118, -1, -1, -1}, {36119, -1, -1, -1}, {36497, -1, -1, -1}, {36499, -1, -1, -1}, {36705, -1, -1, -1}, {37192, -1, -1, -1}, {37956, -1, -1, -1}, {37969, -1, -1, -1}, {37970, -1, -1, -1}, {38717, -1, -1, -1}, {38718, -1, -1, -1}, {38851, -1, -1, -1}, {38849, -1, -1, -1}, {39019, -1, -1, -1}, {39253, -1, -1, -1}, {39509, -1, -1, -1}, {39501, -1, -1, -1}, {39634, -1, -1, -1}, {39706, -1, -1, -1}, {40009, -1, -1, -1}, {39985, -1, -1, -1}, {39998, -1, -1, -1}, {39995, -1, -1, -1}, {40403, -1, -1, -1}, {40407, -1, -1, -1}, {40756, -1, -1, -1}, {40812, -1, -1, -1}, {40810, -1, -1, -1}, {40852, -1, -1, -1}, {22220, -1, -1, -1}, {24022, -1, -1, -1}, {25088, -1, -1, -1}, {25891, -1, -1, -1}, {25899, -1, -1, -1}, {25898, -1, -1, -1}, {26348, -1, -1, -1}, {27408, -1, -1, -1}, {29914, -1, -1, -1}, {31434, -1, -1, -1} },
+ {{31844, -1, -1, -1}, {31843, -1, -1, -1}, {31845, -1, -1, -1}, {32403, -1, -1, -1}, {32406, -1, -1, -1}, {32404, -1, -1, -1}, {33250, -1, -1, -1}, {34360, -1, -1, -1}, {34367, -1, -1, -1}, {34865, -1, -1, -1}, {35722, -1, -1, -1}, {37008, -1, -1, -1}, {37007, -1, -1, -1}, {37987, -1, -1, -1}, {37984, -1, -1, -1}, {37988, -1, -1, -1}, {38760, -1, -1, -1}, {39023, -1, -1, -1}, {39260, -1, -1, -1}, {39514, -1, -1, -1}, {39515, -1, -1, -1}, {39511, -1, -1, -1}, {39635, -1, -1, -1}, {39636, -1, -1, -1}, {39633, -1, -1, -1}, {40020, -1, -1, -1}, {40023, -1, -1, -1}, {40022, -1, -1, -1}, {40421, -1, -1, -1}, {40607, -1, -1, -1}, {40692, -1, -1, -1}, {22225, -1, -1, -1}, {22761, -1, -1, -1}, {25900, -1, -1, -1}, {28766, -1, -1, -1}, {30321, -1, -1, -1}, {30322, -1, -1, -1}, {30679, -1, -1, -1}, {32592, -1, -1, -1}, {32648, -1, -1, -1}, {34870, -1, -1, -1}, {34873, -1, -1, -1}, {34914, -1, -1, -1}, {35731, -1, -1, -1}, {35730, -1, -1, -1}, {35734, -1, -1, -1}, {33399, -1, -1, -1}, {36123, -1, -1, -1}, {37312, -1, -1, -1}, {37994, -1, -1, -1}, {38722, -1, -1, -1}, {38728, -1, -1, -1}, {38724, -1, -1, -1}, {38854, -1, -1, -1}, {39024, -1, -1, -1}, {39519, -1, -1, -1}, {39714, -1, -1, -1}, {39768, -1, -1, -1}, {40031, -1, -1, -1}, {40441, -1, -1, -1}, {40442, -1, -1, -1}, {40572, -1, -1, -1}, {40573, -1, -1, -1}, {40711, -1, -1, -1}, {40823, -1, -1, -1}, {40818, -1, -1, -1}, {24307, -1, -1, -1}, {27414, -1, -1, -1}, {28771, -1, -1, -1}, {31852, -1, -1, -1}, {31854, -1, -1, -1}, {34875, -1, -1, -1}, {35264, -1, -1, -1}, {36513, -1, -1, -1}, {37313, -1, -1, -1}, {38002, -1, -1, -1}, {38000, -1, -1, -1}, {39025, -1, -1, -1}, {39262, -1, -1, -1}, {39638, -1, -1, -1}, {39715, -1, -1, -1}, {40652, -1, -1, -1}, {28772, -1, -1, -1}, {30682, -1, -1, -1}, {35738, -1, -1, -1}, {38007, -1, -1, -1}, {38857, -1, -1, -1}, {39522, -1, -1, -1}, {39525, -1, -1, -1}, {32412, -1, -1, -1}, {35740, -1, -1, -1}, {36522, -1, -1, -1}, {37317, -1, -1, -1}, {38013, -1, -1, -1}, {38014, -1, -1, -1}, {38012, -1, -1, -1}, {40055, -1, -1, -1}, {40056, -1, -1, -1}, {40695, -1, -1, -1}, {35924, -1, -1, -1}, {38015, -1, -1, -1}, {40474, -1, -1, -1}, {29224, -1, -1, -1}, {39530, -1, -1, -1}, {39729, -1, -1, -1}, {40475, -1, -1, -1}, {40478, -1, -1, -1}, {31858, -1, -1, -1}, {20034, -1, -1, -1}, {20060, -1, -1, -1}, {20981, -1, -1, -1}, {21274, -1, -1, -1}, {21378, -1, -1, -1}, {19975, -1, -1, -1}, {19980, -1, -1, -1}, {20039, -1, -1, -1}, {20109, -1, -1, -1}, {22231, -1, -1, -1}, {23662, -1, -1, -1}, {24435, -1, -1, -1}, {19983, -1, -1, -1}, {20871, -1, -1, -1}, {19982, -1, -1, -1}, {20014, -1, -1, -1}, {20115, -1, -1, -1}, {20162, -1, -1, -1}, {20169, -1, -1, -1}, {20168, -1, -1, -1}, {20888, -1, -1, -1}, {21244, -1, -1, -1}, {21356, -1, -1, -1}, {21433, -1, -1, -1}, {22304, -1, -1, -1}, {22787, -1, -1, -1}, {22828, -1, -1, -1}, {23568, -1, -1, -1}, {24063, -1, -1, -1}, {26081, -1, -1, -1}, {27571, -1, -1, -1}, {27596, -1, -1, -1}, {27668, -1, -1, -1}, {29247, -1, -1, -1}, {20017, -1, -1, -1}, {20028, -1, -1, -1}, {20200, -1, -1, -1}, {20188, -1, -1, -1}, {20201, -1, -1, -1}, {20193, -1, -1, -1}, {20189, -1, -1, -1}, {20186, -1, -1, -1}, {21004, -1, -1, -1}, {21001, -1, -1, -1}, {21276, -1, -1, -1}, {21324, -1, -1, -1}, {22306, -1, -1, -1}, {22307, -1, -1, -1}, {22807, -1, -1, -1}, {22831, -1, -1, -1}, {23425, -1, -1, -1}, {23428, -1, -1, -1}, {23570, -1, -1, -1}, {23611, -1, -1, -1}, {23668, -1, -1, -1}, {23667, -1, -1, -1}, {24068, -1, -1, -1}, {24192, -1, -1, -1}, {24194, -1, -1, -1}, {24521, -1, -1, -1}, {25097, -1, -1, -1}, {25168, -1, -1, -1}, {27669, -1, -1, -1}, {27702, -1, -1, -1}, {27715, -1, -1, -1}, {27711, -1, -1, -1}, {27707, -1, -1, -1}, {29358, -1, -1, -1}, {29360, -1, -1, -1}, {29578, -1, -1, -1}, {31160, -1, -1, -1}, {32906, -1, -1, -1}, {38430, -1, -1, -1}, {20238, -1, -1, -1}, {20248, -1, -1, -1}, {20268, -1, -1, -1}, {20213, -1, -1, -1}, {20244, -1, -1, -1}, {20209, -1, -1, -1}, {20224, -1, -1, -1}, {20215, -1, -1, -1}, {20232, -1, -1, -1}, {20253, -1, -1, -1}, {20226, -1, -1, -1}, {20229, -1, -1, -1}, {20258, -1, -1, -1}, {20243, -1, -1, -1}, {20228, -1, -1, -1}, {20212, -1, -1, -1}, {20242, -1, -1, -1}, {20913, -1, -1, -1}, {21011, -1, -1, -1}, {21008, -1, -1, -1}, {21158, -1, -1, -1}, {21282, -1, -1, -1}, {21279, -1, -1, -1}, {21325, -1, -1, -1}, {21386, -1, -1, -1}, {21511, -1, -1, -1}, {22241, -1, -1, -1}, {22239, -1, -1, -1}, {22318, -1, -1, -1}, {22314, -1, -1, -1}, {22324, -1, -1, -1}, {22844, -1, -1, -1}, {22912, -1, -1, -1}, {22908, -1, -1, -1}, {22917, -1, -1, -1}, {22907, -1, -1, -1}, {22910, -1, -1, -1}, {22903, -1, -1, -1}, {22911, -1, -1, -1}, {23382, -1, -1, -1}, {23573, -1, -1, -1}, {23589, -1, -1, -1}, {23676, -1, -1, -1}, {23674, -1, -1, -1}, {23675, -1, -1, -1}, {23678, -1, -1, -1}, {24031, -1, -1, -1}, {24181, -1, -1, -1}, {24196, -1, -1, -1}, {24322, -1, -1, -1}, {24346, -1, -1, -1}, {24436, -1, -1, -1}, {24533, -1, -1, -1}, {24532, -1, -1, -1}, {24527, -1, -1, -1}, {25180, -1, -1, -1}, {25182, -1, -1, -1}, {25188, -1, -1, -1}, {25185, -1, -1, -1}, {25190, -1, -1, -1}, {25186, -1, -1, -1}, {25177, -1, -1, -1}, {25184, -1, -1, -1}, {25178, -1, -1, -1}, {25189, -1, -1, -1}, {25911, -1, -1, -1}, {26095, -1, -1, -1}, {26094, -1, -1, -1}, {26430, -1, -1, -1}, {26425, -1, -1, -1}, {26424, -1, -1, -1}, {26427, -1, -1, -1}, {26426, -1, -1, -1}, {26431, -1, -1, -1}, {26428, -1, -1, -1} },
+ {{26419, -1, -1, -1}, {27672, -1, -1, -1}, {27718, -1, -1, -1}, {27730, -1, -1, -1}, {27740, -1, -1, -1}, {27727, -1, -1, -1}, {27722, -1, -1, -1}, {27732, -1, -1, -1}, {27723, -1, -1, -1}, {27724, -1, -1, -1}, {28785, -1, -1, -1}, {29278, -1, -1, -1}, {29364, -1, -1, -1}, {29365, -1, -1, -1}, {29582, -1, -1, -1}, {29994, -1, -1, -1}, {30335, -1, -1, -1}, {31349, -1, -1, -1}, {32593, -1, -1, -1}, {33400, -1, -1, -1}, {33404, -1, -1, -1}, {33408, -1, -1, -1}, {33405, -1, -1, -1}, {33407, -1, -1, -1}, {34381, -1, -1, -1}, {35198, -1, -1, -1}, {37017, -1, -1, -1}, {37015, -1, -1, -1}, {37016, -1, -1, -1}, {37019, -1, -1, -1}, {37012, -1, -1, -1}, {38434, -1, -1, -1}, {38436, -1, -1, -1}, {38432, -1, -1, -1}, {38435, -1, -1, -1}, {20310, -1, -1, -1}, {20283, -1, -1, -1}, {20322, -1, -1, -1}, {20297, -1, -1, -1}, {20307, -1, -1, -1}, {20324, -1, -1, -1}, {20286, -1, -1, -1}, {20327, -1, -1, -1}, {20306, -1, -1, -1}, {20319, -1, -1, -1}, {20289, -1, -1, -1}, {20312, -1, -1, -1}, {20269, -1, -1, -1}, {20275, -1, -1, -1}, {20287, -1, -1, -1}, {20321, -1, -1, -1}, {20879, -1, -1, -1}, {20921, -1, -1, -1}, {21020, -1, -1, -1}, {21022, -1, -1, -1}, {21025, -1, -1, -1}, {21165, -1, -1, -1}, {21166, -1, -1, -1}, {21257, -1, -1, -1}, {21347, -1, -1, -1}, {21362, -1, -1, -1}, {21390, -1, -1, -1}, {21391, -1, -1, -1}, {21552, -1, -1, -1}, {21559, -1, -1, -1}, {21546, -1, -1, -1}, {21588, -1, -1, -1}, {21573, -1, -1, -1}, {21529, -1, -1, -1}, {21532, -1, -1, -1}, {21541, -1, -1, -1}, {21528, -1, -1, -1}, {21565, -1, -1, -1}, {21583, -1, -1, -1}, {21569, -1, -1, -1}, {21544, -1, -1, -1}, {21540, -1, -1, -1}, {21575, -1, -1, -1}, {22254, -1, -1, -1}, {22247, -1, -1, -1}, {22245, -1, -1, -1}, {22337, -1, -1, -1}, {22341, -1, -1, -1}, {22348, -1, -1, -1}, {22345, -1, -1, -1}, {22347, -1, -1, -1}, {22354, -1, -1, -1}, {22790, -1, -1, -1}, {22848, -1, -1, -1}, {22950, -1, -1, -1}, {22936, -1, -1, -1}, {22944, -1, -1, -1}, {22935, -1, -1, -1}, {22926, -1, -1, -1}, {22946, -1, -1, -1}, {22928, -1, -1, -1}, {22927, -1, -1, -1}, {22951, -1, -1, -1}, {22945, -1, -1, -1}, {23438, -1, -1, -1}, {23442, -1, -1, -1}, {23592, -1, -1, -1}, {23594, -1, -1, -1}, {23693, -1, -1, -1}, {23695, -1, -1, -1}, {23688, -1, -1, -1}, {23691, -1, -1, -1}, {23689, -1, -1, -1}, {23698, -1, -1, -1}, {23690, -1, -1, -1}, {23686, -1, -1, -1}, {23699, -1, -1, -1}, {23701, -1, -1, -1}, {24032, -1, -1, -1}, {24074, -1, -1, -1}, {24078, -1, -1, -1}, {24203, -1, -1, -1}, {24201, -1, -1, -1}, {24204, -1, -1, -1}, {24200, -1, -1, -1}, {24205, -1, -1, -1}, {24325, -1, -1, -1}, {24349, -1, -1, -1}, {24440, -1, -1, -1}, {24438, -1, -1, -1}, {24530, -1, -1, -1}, {24529, -1, -1, -1}, {24528, -1, -1, -1}, {24557, -1, -1, -1}, {24552, -1, -1, -1}, {24558, -1, -1, -1}, {24563, -1, -1, -1}, {24545, -1, -1, -1}, {24548, -1, -1, -1}, {24547, -1, -1, -1}, {24570, -1, -1, -1}, {24559, -1, -1, -1}, {24567, -1, -1, -1}, {24571, -1, -1, -1}, {24576, -1, -1, -1}, {24564, -1, -1, -1}, {25146, -1, -1, -1}, {25219, -1, -1, -1}, {25228, -1, -1, -1}, {25230, -1, -1, -1}, {25231, -1, -1, -1}, {25236, -1, -1, -1}, {25223, -1, -1, -1}, {25201, -1, -1, -1}, {25211, -1, -1, -1}, {25210, -1, -1, -1}, {25200, -1, -1, -1}, {25217, -1, -1, -1}, {25224, -1, -1, -1}, {25207, -1, -1, -1}, {25213, -1, -1, -1}, {25202, -1, -1, -1}, {25204, -1, -1, -1}, {26096, -1, -1, -1}, {26100, -1, -1, -1}, {26099, -1, -1, -1}, {26098, -1, -1, -1}, {26101, -1, -1, -1}, {26437, -1, -1, -1}, {26439, -1, -1, -1}, {26457, -1, -1, -1}, {26453, -1, -1, -1}, {26444, -1, -1, -1}, {26440, -1, -1, -1}, {26461, -1, -1, -1}, {26445, -1, -1, -1}, {26458, -1, -1, -1}, {26443, -1, -1, -1}, {27600, -1, -1, -1}, {27673, -1, -1, -1}, {27674, -1, -1, -1}, {27768, -1, -1, -1}, {27751, -1, -1, -1}, {27755, -1, -1, -1}, {27780, -1, -1, -1}, {27787, -1, -1, -1}, {27791, -1, -1, -1}, {27761, -1, -1, -1}, {27759, -1, -1, -1}, {27753, -1, -1, -1}, {27802, -1, -1, -1}, {27757, -1, -1, -1}, {27783, -1, -1, -1}, {27797, -1, -1, -1}, {27804, -1, -1, -1}, {27750, -1, -1, -1}, {27763, -1, -1, -1}, {27749, -1, -1, -1}, {27771, -1, -1, -1}, {27790, -1, -1, -1}, {28788, -1, -1, -1}, {28794, -1, -1, -1}, {29283, -1, -1, -1}, {29375, -1, -1, -1}, {29373, -1, -1, -1}, {29379, -1, -1, -1}, {29382, -1, -1, -1}, {29377, -1, -1, -1}, {29370, -1, -1, -1}, {29381, -1, -1, -1}, {29589, -1, -1, -1}, {29591, -1, -1, -1}, {29587, -1, -1, -1}, {29588, -1, -1, -1}, {29586, -1, -1, -1}, {30010, -1, -1, -1}, {30009, -1, -1, -1}, {30100, -1, -1, -1}, {30101, -1, -1, -1}, {30337, -1, -1, -1}, {31037, -1, -1, -1}, {32820, -1, -1, -1}, {32917, -1, -1, -1}, {32921, -1, -1, -1}, {32912, -1, -1, -1}, {32914, -1, -1, -1}, {32924, -1, -1, -1}, {33424, -1, -1, -1}, {33423, -1, -1, -1}, {33413, -1, -1, -1}, {33422, -1, -1, -1}, {33425, -1, -1, -1}, {33427, -1, -1, -1}, {33418, -1, -1, -1}, {33411, -1, -1, -1}, {33412, -1, -1, -1}, {35960, -1, -1, -1}, {36809, -1, -1, -1}, {36799, -1, -1, -1}, {37023, -1, -1, -1}, {37025, -1, -1, -1}, {37029, -1, -1, -1}, {37022, -1, -1, -1}, {37031, -1, -1, -1}, {37024, -1, -1, -1}, {38448, -1, -1, -1}, {38440, -1, -1, -1}, {38447, -1, -1, -1}, {38445, -1, -1, -1}, {20019, -1, -1, -1}, {20376, -1, -1, -1}, {20348, -1, -1, -1}, {20357, -1, -1, -1}, {20349, -1, -1, -1}, {20352, -1, -1, -1}, {20359, -1, -1, -1}, {20342, -1, -1, -1}, {20340, -1, -1, -1}, {20361, -1, -1, -1}, {20356, -1, -1, -1}, {20343, -1, -1, -1} },
+ {{20300, -1, -1, -1}, {20375, -1, -1, -1}, {20330, -1, -1, -1}, {20378, -1, -1, -1}, {20345, -1, -1, -1}, {20353, -1, -1, -1}, {20344, -1, -1, -1}, {20368, -1, -1, -1}, {20380, -1, -1, -1}, {20372, -1, -1, -1}, {20382, -1, -1, -1}, {20370, -1, -1, -1}, {20354, -1, -1, -1}, {20373, -1, -1, -1}, {20331, -1, -1, -1}, {20334, -1, -1, -1}, {20894, -1, -1, -1}, {20924, -1, -1, -1}, {20926, -1, -1, -1}, {21045, -1, -1, -1}, {21042, -1, -1, -1}, {21043, -1, -1, -1}, {21062, -1, -1, -1}, {21041, -1, -1, -1}, {21180, -1, -1, -1}, {21258, -1, -1, -1}, {21259, -1, -1, -1}, {21308, -1, -1, -1}, {21394, -1, -1, -1}, {21396, -1, -1, -1}, {21639, -1, -1, -1}, {21631, -1, -1, -1}, {21633, -1, -1, -1}, {21649, -1, -1, -1}, {21634, -1, -1, -1}, {21640, -1, -1, -1}, {21611, -1, -1, -1}, {21626, -1, -1, -1}, {21630, -1, -1, -1}, {21605, -1, -1, -1}, {21612, -1, -1, -1}, {21620, -1, -1, -1}, {21606, -1, -1, -1}, {21645, -1, -1, -1}, {21615, -1, -1, -1}, {21601, -1, -1, -1}, {21600, -1, -1, -1}, {21656, -1, -1, -1}, {21603, -1, -1, -1}, {21607, -1, -1, -1}, {21604, -1, -1, -1}, {22263, -1, -1, -1}, {22265, -1, -1, -1}, {22383, -1, -1, -1}, {22386, -1, -1, -1}, {22381, -1, -1, -1}, {22379, -1, -1, -1}, {22385, -1, -1, -1}, {22384, -1, -1, -1}, {22390, -1, -1, -1}, {22400, -1, -1, -1}, {22389, -1, -1, -1}, {22395, -1, -1, -1}, {22387, -1, -1, -1}, {22388, -1, -1, -1}, {22370, -1, -1, -1}, {22376, -1, -1, -1}, {22397, -1, -1, -1}, {22796, -1, -1, -1}, {22853, -1, -1, -1}, {22965, -1, -1, -1}, {22970, -1, -1, -1}, {22991, -1, -1, -1}, {22990, -1, -1, -1}, {22962, -1, -1, -1}, {22988, -1, -1, -1}, {22977, -1, -1, -1}, {22966, -1, -1, -1}, {22972, -1, -1, -1}, {22979, -1, -1, -1}, {22998, -1, -1, -1}, {22961, -1, -1, -1}, {22973, -1, -1, -1}, {22976, -1, -1, -1}, {22984, -1, -1, -1}, {22964, -1, -1, -1}, {22983, -1, -1, -1}, {23394, -1, -1, -1}, {23397, -1, -1, -1}, {23443, -1, -1, -1}, {23445, -1, -1, -1}, {23620, -1, -1, -1}, {23623, -1, -1, -1}, {23726, -1, -1, -1}, {23716, -1, -1, -1}, {23712, -1, -1, -1}, {23733, -1, -1, -1}, {23727, -1, -1, -1}, {23720, -1, -1, -1}, {23724, -1, -1, -1}, {23711, -1, -1, -1}, {23715, -1, -1, -1}, {23725, -1, -1, -1}, {23714, -1, -1, -1}, {23722, -1, -1, -1}, {23719, -1, -1, -1}, {23709, -1, -1, -1}, {23717, -1, -1, -1}, {23734, -1, -1, -1}, {23728, -1, -1, -1}, {23718, -1, -1, -1}, {24087, -1, -1, -1}, {24084, -1, -1, -1}, {24089, -1, -1, -1}, {24360, -1, -1, -1}, {24354, -1, -1, -1}, {24355, -1, -1, -1}, {24356, -1, -1, -1}, {24404, -1, -1, -1}, {24450, -1, -1, -1}, {24446, -1, -1, -1}, {24445, -1, -1, -1}, {24542, -1, -1, -1}, {24549, -1, -1, -1}, {24621, -1, -1, -1}, {24614, -1, -1, -1}, {24601, -1, -1, -1}, {24626, -1, -1, -1}, {24587, -1, -1, -1}, {24628, -1, -1, -1}, {24586, -1, -1, -1}, {24599, -1, -1, -1}, {24627, -1, -1, -1}, {24602, -1, -1, -1}, {24606, -1, -1, -1}, {24620, -1, -1, -1}, {24610, -1, -1, -1}, {24589, -1, -1, -1}, {24592, -1, -1, -1}, {24622, -1, -1, -1}, {24595, -1, -1, -1}, {24593, -1, -1, -1}, {24588, -1, -1, -1}, {24585, -1, -1, -1}, {24604, -1, -1, -1}, {25108, -1, -1, -1}, {25149, -1, -1, -1}, {25261, -1, -1, -1}, {25268, -1, -1, -1}, {25297, -1, -1, -1}, {25278, -1, -1, -1}, {25258, -1, -1, -1}, {25270, -1, -1, -1}, {25290, -1, -1, -1}, {25262, -1, -1, -1}, {25267, -1, -1, -1}, {25263, -1, -1, -1}, {25275, -1, -1, -1}, {25257, -1, -1, -1}, {25264, -1, -1, -1}, {25272, -1, -1, -1}, {25917, -1, -1, -1}, {26024, -1, -1, -1}, {26043, -1, -1, -1}, {26121, -1, -1, -1}, {26108, -1, -1, -1}, {26116, -1, -1, -1}, {26130, -1, -1, -1}, {26120, -1, -1, -1}, {26107, -1, -1, -1}, {26115, -1, -1, -1}, {26123, -1, -1, -1}, {26125, -1, -1, -1}, {26117, -1, -1, -1}, {26109, -1, -1, -1}, {26129, -1, -1, -1}, {26128, -1, -1, -1}, {26358, -1, -1, -1}, {26378, -1, -1, -1}, {26501, -1, -1, -1}, {26476, -1, -1, -1}, {26510, -1, -1, -1}, {26514, -1, -1, -1}, {26486, -1, -1, -1}, {26491, -1, -1, -1}, {26520, -1, -1, -1}, {26502, -1, -1, -1}, {26500, -1, -1, -1}, {26484, -1, -1, -1}, {26509, -1, -1, -1}, {26508, -1, -1, -1}, {26490, -1, -1, -1}, {26527, -1, -1, -1}, {26513, -1, -1, -1}, {26521, -1, -1, -1}, {26499, -1, -1, -1}, {26493, -1, -1, -1}, {26497, -1, -1, -1}, {26488, -1, -1, -1}, {26489, -1, -1, -1}, {26516, -1, -1, -1}, {27429, -1, -1, -1}, {27520, -1, -1, -1}, {27518, -1, -1, -1}, {27614, -1, -1, -1}, {27677, -1, -1, -1}, {27795, -1, -1, -1}, {27884, -1, -1, -1}, {27883, -1, -1, -1}, {27886, -1, -1, -1}, {27865, -1, -1, -1}, {27830, -1, -1, -1}, {27860, -1, -1, -1}, {27821, -1, -1, -1}, {27879, -1, -1, -1}, {27831, -1, -1, -1}, {27856, -1, -1, -1}, {27842, -1, -1, -1}, {27834, -1, -1, -1}, {27843, -1, -1, -1}, {27846, -1, -1, -1}, {27885, -1, -1, -1}, {27890, -1, -1, -1}, {27858, -1, -1, -1}, {27869, -1, -1, -1}, {27828, -1, -1, -1}, {27786, -1, -1, -1}, {27805, -1, -1, -1}, {27776, -1, -1, -1}, {27870, -1, -1, -1}, {27840, -1, -1, -1}, {27952, -1, -1, -1}, {27853, -1, -1, -1}, {27847, -1, -1, -1}, {27824, -1, -1, -1}, {27897, -1, -1, -1}, {27855, -1, -1, -1}, {27881, -1, -1, -1}, {27857, -1, -1, -1}, {28820, -1, -1, -1}, {28824, -1, -1, -1}, {28805, -1, -1, -1}, {28819, -1, -1, -1}, {28806, -1, -1, -1}, {28804, -1, -1, -1}, {28817, -1, -1, -1}, {28822, -1, -1, -1}, {28802, -1, -1, -1}, {28826, -1, -1, -1}, {28803, -1, -1, -1}, {29290, -1, -1, -1}, {29398, -1, -1, -1}, {29387, -1, -1, -1}, {29400, -1, -1, -1}, {29385, -1, -1, -1}, {29404, -1, -1, -1} },
+ {{29394, -1, -1, -1}, {29396, -1, -1, -1}, {29402, -1, -1, -1}, {29388, -1, -1, -1}, {29393, -1, -1, -1}, {29604, -1, -1, -1}, {29601, -1, -1, -1}, {29613, -1, -1, -1}, {29606, -1, -1, -1}, {29602, -1, -1, -1}, {29600, -1, -1, -1}, {29612, -1, -1, -1}, {29597, -1, -1, -1}, {29917, -1, -1, -1}, {29928, -1, -1, -1}, {30015, -1, -1, -1}, {30016, -1, -1, -1}, {30014, -1, -1, -1}, {30092, -1, -1, -1}, {30104, -1, -1, -1}, {30383, -1, -1, -1}, {30451, -1, -1, -1}, {30449, -1, -1, -1}, {30448, -1, -1, -1}, {30453, -1, -1, -1}, {30712, -1, -1, -1}, {30716, -1, -1, -1}, {30713, -1, -1, -1}, {30715, -1, -1, -1}, {30714, -1, -1, -1}, {30711, -1, -1, -1}, {31042, -1, -1, -1}, {31039, -1, -1, -1}, {31173, -1, -1, -1}, {31352, -1, -1, -1}, {31355, -1, -1, -1}, {31483, -1, -1, -1}, {31861, -1, -1, -1}, {31997, -1, -1, -1}, {32821, -1, -1, -1}, {32911, -1, -1, -1}, {32942, -1, -1, -1}, {32931, -1, -1, -1}, {32952, -1, -1, -1}, {32949, -1, -1, -1}, {32941, -1, -1, -1}, {33312, -1, -1, -1}, {33440, -1, -1, -1}, {33472, -1, -1, -1}, {33451, -1, -1, -1}, {33434, -1, -1, -1}, {33432, -1, -1, -1}, {33435, -1, -1, -1}, {33461, -1, -1, -1}, {33447, -1, -1, -1}, {33454, -1, -1, -1}, {33468, -1, -1, -1}, {33438, -1, -1, -1}, {33466, -1, -1, -1}, {33460, -1, -1, -1}, {33448, -1, -1, -1}, {33441, -1, -1, -1}, {33449, -1, -1, -1}, {33474, -1, -1, -1}, {33444, -1, -1, -1}, {33475, -1, -1, -1}, {33462, -1, -1, -1}, {33442, -1, -1, -1}, {34416, -1, -1, -1}, {34415, -1, -1, -1}, {34413, -1, -1, -1}, {34414, -1, -1, -1}, {35926, -1, -1, -1}, {36818, -1, -1, -1}, {36811, -1, -1, -1}, {36819, -1, -1, -1}, {36813, -1, -1, -1}, {36822, -1, -1, -1}, {36821, -1, -1, -1}, {36823, -1, -1, -1}, {37042, -1, -1, -1}, {37044, -1, -1, -1}, {37039, -1, -1, -1}, {37043, -1, -1, -1}, {37040, -1, -1, -1}, {38457, -1, -1, -1}, {38461, -1, -1, -1}, {38460, -1, -1, -1}, {38458, -1, -1, -1}, {38467, -1, -1, -1}, {20429, -1, -1, -1}, {20421, -1, -1, -1}, {20435, -1, -1, -1}, {20402, -1, -1, -1}, {20425, -1, -1, -1}, {20427, -1, -1, -1}, {20417, -1, -1, -1}, {20436, -1, -1, -1}, {20444, -1, -1, -1}, {20441, -1, -1, -1}, {20411, -1, -1, -1}, {20403, -1, -1, -1}, {20443, -1, -1, -1}, {20423, -1, -1, -1}, {20438, -1, -1, -1}, {20410, -1, -1, -1}, {20416, -1, -1, -1}, {20409, -1, -1, -1}, {20460, -1, -1, -1}, {21060, -1, -1, -1}, {21065, -1, -1, -1}, {21184, -1, -1, -1}, {21186, -1, -1, -1}, {21309, -1, -1, -1}, {21372, -1, -1, -1}, {21399, -1, -1, -1}, {21398, -1, -1, -1}, {21401, -1, -1, -1}, {21400, -1, -1, -1}, {21690, -1, -1, -1}, {21665, -1, -1, -1}, {21677, -1, -1, -1}, {21669, -1, -1, -1}, {21711, -1, -1, -1}, {21699, -1, -1, -1}, {33549, -1, -1, -1}, {21687, -1, -1, -1}, {21678, -1, -1, -1}, {21718, -1, -1, -1}, {21686, -1, -1, -1}, {21701, -1, -1, -1}, {21702, -1, -1, -1}, {21664, -1, -1, -1}, {21616, -1, -1, -1}, {21692, -1, -1, -1}, {21666, -1, -1, -1}, {21694, -1, -1, -1}, {21618, -1, -1, -1}, {21726, -1, -1, -1}, {21680, -1, -1, -1}, {22453, -1, -1, -1}, {22430, -1, -1, -1}, {22431, -1, -1, -1}, {22436, -1, -1, -1}, {22412, -1, -1, -1}, {22423, -1, -1, -1}, {22429, -1, -1, -1}, {22427, -1, -1, -1}, {22420, -1, -1, -1}, {22424, -1, -1, -1}, {22415, -1, -1, -1}, {22425, -1, -1, -1}, {22437, -1, -1, -1}, {22426, -1, -1, -1}, {22421, -1, -1, -1}, {22772, -1, -1, -1}, {22797, -1, -1, -1}, {22867, -1, -1, -1}, {23009, -1, -1, -1}, {23006, -1, -1, -1}, {23022, -1, -1, -1}, {23040, -1, -1, -1}, {23025, -1, -1, -1}, {23005, -1, -1, -1}, {23034, -1, -1, -1}, {23037, -1, -1, -1}, {23036, -1, -1, -1}, {23030, -1, -1, -1}, {23012, -1, -1, -1}, {23026, -1, -1, -1}, {23031, -1, -1, -1}, {23003, -1, -1, -1}, {23017, -1, -1, -1}, {23027, -1, -1, -1}, {23029, -1, -1, -1}, {23008, -1, -1, -1}, {23038, -1, -1, -1}, {23028, -1, -1, -1}, {23021, -1, -1, -1}, {23464, -1, -1, -1}, {23628, -1, -1, -1}, {23760, -1, -1, -1}, {23768, -1, -1, -1}, {23756, -1, -1, -1}, {23767, -1, -1, -1}, {23755, -1, -1, -1}, {23771, -1, -1, -1}, {23774, -1, -1, -1}, {23770, -1, -1, -1}, {23753, -1, -1, -1}, {23751, -1, -1, -1}, {23754, -1, -1, -1}, {23766, -1, -1, -1}, {23763, -1, -1, -1}, {23764, -1, -1, -1}, {23759, -1, -1, -1}, {23752, -1, -1, -1}, {23750, -1, -1, -1}, {23758, -1, -1, -1}, {23775, -1, -1, -1}, {23800, -1, -1, -1}, {24057, -1, -1, -1}, {24097, -1, -1, -1}, {24098, -1, -1, -1}, {24099, -1, -1, -1}, {24096, -1, -1, -1}, {24100, -1, -1, -1}, {24240, -1, -1, -1}, {24228, -1, -1, -1}, {24226, -1, -1, -1}, {24219, -1, -1, -1}, {24227, -1, -1, -1}, {24229, -1, -1, -1}, {24327, -1, -1, -1}, {24366, -1, -1, -1}, {24406, -1, -1, -1}, {24454, -1, -1, -1}, {24631, -1, -1, -1}, {24633, -1, -1, -1}, {24660, -1, -1, -1}, {24690, -1, -1, -1}, {24670, -1, -1, -1}, {24645, -1, -1, -1}, {24659, -1, -1, -1}, {24647, -1, -1, -1}, {24649, -1, -1, -1}, {24667, -1, -1, -1}, {24652, -1, -1, -1}, {24640, -1, -1, -1}, {24642, -1, -1, -1}, {24671, -1, -1, -1}, {24612, -1, -1, -1}, {24644, -1, -1, -1}, {24664, -1, -1, -1}, {24678, -1, -1, -1}, {24686, -1, -1, -1}, {25154, -1, -1, -1}, {25155, -1, -1, -1}, {25295, -1, -1, -1}, {25357, -1, -1, -1}, {25355, -1, -1, -1}, {25333, -1, -1, -1}, {25358, -1, -1, -1}, {25347, -1, -1, -1}, {25323, -1, -1, -1}, {25337, -1, -1, -1}, {25359, -1, -1, -1}, {25356, -1, -1, -1}, {25336, -1, -1, -1}, {25334, -1, -1, -1}, {25344, -1, -1, -1}, {25363, -1, -1, -1}, {25364, -1, -1, -1}, {25338, -1, -1, -1}, {25365, -1, -1, -1}, {25339, -1, -1, -1} },
+ {{25328, -1, -1, -1}, {25921, -1, -1, -1}, {25923, -1, -1, -1}, {26026, -1, -1, -1}, {26047, -1, -1, -1}, {26166, -1, -1, -1}, {26145, -1, -1, -1}, {26162, -1, -1, -1}, {26165, -1, -1, -1}, {26140, -1, -1, -1}, {26150, -1, -1, -1}, {26146, -1, -1, -1}, {26163, -1, -1, -1}, {26155, -1, -1, -1}, {26170, -1, -1, -1}, {26141, -1, -1, -1}, {26164, -1, -1, -1}, {26169, -1, -1, -1}, {26158, -1, -1, -1}, {26383, -1, -1, -1}, {26384, -1, -1, -1}, {26561, -1, -1, -1}, {26610, -1, -1, -1}, {26568, -1, -1, -1}, {26554, -1, -1, -1}, {26588, -1, -1, -1}, {26555, -1, -1, -1}, {26616, -1, -1, -1}, {26584, -1, -1, -1}, {26560, -1, -1, -1}, {26551, -1, -1, -1}, {26565, -1, -1, -1}, {26603, -1, -1, -1}, {26596, -1, -1, -1}, {26591, -1, -1, -1}, {26549, -1, -1, -1}, {26573, -1, -1, -1}, {26547, -1, -1, -1}, {26615, -1, -1, -1}, {26614, -1, -1, -1}, {26606, -1, -1, -1}, {26595, -1, -1, -1}, {26562, -1, -1, -1}, {26553, -1, -1, -1}, {26574, -1, -1, -1}, {26599, -1, -1, -1}, {26608, -1, -1, -1}, {26546, -1, -1, -1}, {26620, -1, -1, -1}, {26566, -1, -1, -1}, {26605, -1, -1, -1}, {26572, -1, -1, -1}, {26542, -1, -1, -1}, {26598, -1, -1, -1}, {26587, -1, -1, -1}, {26618, -1, -1, -1}, {26569, -1, -1, -1}, {26570, -1, -1, -1}, {26563, -1, -1, -1}, {26602, -1, -1, -1}, {26571, -1, -1, -1}, {27432, -1, -1, -1}, {27522, -1, -1, -1}, {27524, -1, -1, -1}, {27574, -1, -1, -1}, {27606, -1, -1, -1}, {27608, -1, -1, -1}, {27616, -1, -1, -1}, {27680, -1, -1, -1}, {27681, -1, -1, -1}, {27944, -1, -1, -1}, {27956, -1, -1, -1}, {27949, -1, -1, -1}, {27935, -1, -1, -1}, {27964, -1, -1, -1}, {27967, -1, -1, -1}, {27922, -1, -1, -1}, {27914, -1, -1, -1}, {27866, -1, -1, -1}, {27955, -1, -1, -1}, {27908, -1, -1, -1}, {27929, -1, -1, -1}, {27962, -1, -1, -1}, {27930, -1, -1, -1}, {27921, -1, -1, -1}, {27904, -1, -1, -1}, {27933, -1, -1, -1}, {27970, -1, -1, -1}, {27905, -1, -1, -1}, {27928, -1, -1, -1}, {27959, -1, -1, -1}, {27907, -1, -1, -1}, {27919, -1, -1, -1}, {27968, -1, -1, -1}, {27911, -1, -1, -1}, {27936, -1, -1, -1}, {27948, -1, -1, -1}, {27912, -1, -1, -1}, {27938, -1, -1, -1}, {27913, -1, -1, -1}, {27920, -1, -1, -1}, {28855, -1, -1, -1}, {28831, -1, -1, -1}, {28862, -1, -1, -1}, {28849, -1, -1, -1}, {28848, -1, -1, -1}, {28833, -1, -1, -1}, {28852, -1, -1, -1}, {28853, -1, -1, -1}, {28841, -1, -1, -1}, {29249, -1, -1, -1}, {29257, -1, -1, -1}, {29258, -1, -1, -1}, {29292, -1, -1, -1}, {29296, -1, -1, -1}, {29299, -1, -1, -1}, {29294, -1, -1, -1}, {29386, -1, -1, -1}, {29412, -1, -1, -1}, {29416, -1, -1, -1}, {29419, -1, -1, -1}, {29407, -1, -1, -1}, {29418, -1, -1, -1}, {29414, -1, -1, -1}, {29411, -1, -1, -1}, {29573, -1, -1, -1}, {29644, -1, -1, -1}, {29634, -1, -1, -1}, {29640, -1, -1, -1}, {29637, -1, -1, -1}, {29625, -1, -1, -1}, {29622, -1, -1, -1}, {29621, -1, -1, -1}, {29620, -1, -1, -1}, {29675, -1, -1, -1}, {29631, -1, -1, -1}, {29639, -1, -1, -1}, {29630, -1, -1, -1}, {29635, -1, -1, -1}, {29638, -1, -1, -1}, {29624, -1, -1, -1}, {29643, -1, -1, -1}, {29932, -1, -1, -1}, {29934, -1, -1, -1}, {29998, -1, -1, -1}, {30023, -1, -1, -1}, {30024, -1, -1, -1}, {30119, -1, -1, -1}, {30122, -1, -1, -1}, {30329, -1, -1, -1}, {30404, -1, -1, -1}, {30472, -1, -1, -1}, {30467, -1, -1, -1}, {30468, -1, -1, -1}, {30469, -1, -1, -1}, {30474, -1, -1, -1}, {30455, -1, -1, -1}, {30459, -1, -1, -1}, {30458, -1, -1, -1}, {30695, -1, -1, -1}, {30696, -1, -1, -1}, {30726, -1, -1, -1}, {30737, -1, -1, -1}, {30738, -1, -1, -1}, {30725, -1, -1, -1}, {30736, -1, -1, -1}, {30735, -1, -1, -1}, {30734, -1, -1, -1}, {30729, -1, -1, -1}, {30723, -1, -1, -1}, {30739, -1, -1, -1}, {31050, -1, -1, -1}, {31052, -1, -1, -1}, {31051, -1, -1, -1}, {31045, -1, -1, -1}, {31044, -1, -1, -1}, {31189, -1, -1, -1}, {31181, -1, -1, -1}, {31183, -1, -1, -1}, {31190, -1, -1, -1}, {31182, -1, -1, -1}, {31360, -1, -1, -1}, {31358, -1, -1, -1}, {31441, -1, -1, -1}, {31488, -1, -1, -1}, {31489, -1, -1, -1}, {31866, -1, -1, -1}, {31864, -1, -1, -1}, {31865, -1, -1, -1}, {31871, -1, -1, -1}, {31872, -1, -1, -1}, {31873, -1, -1, -1}, {32003, -1, -1, -1}, {32008, -1, -1, -1}, {32001, -1, -1, -1}, {32600, -1, -1, -1}, {32657, -1, -1, -1}, {32653, -1, -1, -1}, {32702, -1, -1, -1}, {32775, -1, -1, -1}, {32782, -1, -1, -1}, {32783, -1, -1, -1}, {32788, -1, -1, -1}, {32823, -1, -1, -1}, {32984, -1, -1, -1}, {32967, -1, -1, -1}, {32992, -1, -1, -1}, {32977, -1, -1, -1}, {32968, -1, -1, -1}, {32962, -1, -1, -1}, {32976, -1, -1, -1}, {32965, -1, -1, -1}, {32995, -1, -1, -1}, {32985, -1, -1, -1}, {32988, -1, -1, -1}, {32970, -1, -1, -1}, {32981, -1, -1, -1}, {32969, -1, -1, -1}, {32975, -1, -1, -1}, {32983, -1, -1, -1}, {32998, -1, -1, -1}, {32973, -1, -1, -1}, {33279, -1, -1, -1}, {33313, -1, -1, -1}, {33428, -1, -1, -1}, {33497, -1, -1, -1}, {33534, -1, -1, -1}, {33529, -1, -1, -1}, {33543, -1, -1, -1}, {33512, -1, -1, -1}, {33536, -1, -1, -1}, {33493, -1, -1, -1}, {33594, -1, -1, -1}, {33515, -1, -1, -1}, {33494, -1, -1, -1}, {33524, -1, -1, -1}, {33516, -1, -1, -1}, {33505, -1, -1, -1}, {33522, -1, -1, -1}, {33525, -1, -1, -1}, {33548, -1, -1, -1}, {33531, -1, -1, -1}, {33526, -1, -1, -1}, {33520, -1, -1, -1}, {33514, -1, -1, -1}, {33508, -1, -1, -1}, {33504, -1, -1, -1}, {33530, -1, -1, -1}, {33523, -1, -1, -1}, {33517, -1, -1, -1}, {34423, -1, -1, -1}, {34420, -1, -1, -1}, {34428, -1, -1, -1}, {34419, -1, -1, -1}, {34881, -1, -1, -1}, {34894, -1, -1, -1} },
+ {{34919, -1, -1, -1}, {34922, -1, -1, -1}, {34921, -1, -1, -1}, {35283, -1, -1, -1}, {35332, -1, -1, -1}, {35335, -1, -1, -1}, {36210, -1, -1, -1}, {36835, -1, -1, -1}, {36833, -1, -1, -1}, {36846, -1, -1, -1}, {36832, -1, -1, -1}, {37105, -1, -1, -1}, {37053, -1, -1, -1}, {37055, -1, -1, -1}, {37077, -1, -1, -1}, {37061, -1, -1, -1}, {37054, -1, -1, -1}, {37063, -1, -1, -1}, {37067, -1, -1, -1}, {37064, -1, -1, -1}, {37332, -1, -1, -1}, {37331, -1, -1, -1}, {38484, -1, -1, -1}, {38479, -1, -1, -1}, {38481, -1, -1, -1}, {38483, -1, -1, -1}, {38474, -1, -1, -1}, {38478, -1, -1, -1}, {20510, -1, -1, -1}, {20485, -1, -1, -1}, {20487, -1, -1, -1}, {20499, -1, -1, -1}, {20514, -1, -1, -1}, {20528, -1, -1, -1}, {20507, -1, -1, -1}, {20469, -1, -1, -1}, {20468, -1, -1, -1}, {20531, -1, -1, -1}, {20535, -1, -1, -1}, {20524, -1, -1, -1}, {20470, -1, -1, -1}, {20471, -1, -1, -1}, {20503, -1, -1, -1}, {20508, -1, -1, -1}, {20512, -1, -1, -1}, {20519, -1, -1, -1}, {20533, -1, -1, -1}, {20527, -1, -1, -1}, {20529, -1, -1, -1}, {20494, -1, -1, -1}, {20826, -1, -1, -1}, {20884, -1, -1, -1}, {20883, -1, -1, -1}, {20938, -1, -1, -1}, {20932, -1, -1, -1}, {20933, -1, -1, -1}, {20936, -1, -1, -1}, {20942, -1, -1, -1}, {21089, -1, -1, -1}, {21082, -1, -1, -1}, {21074, -1, -1, -1}, {21086, -1, -1, -1}, {21087, -1, -1, -1}, {21077, -1, -1, -1}, {21090, -1, -1, -1}, {21197, -1, -1, -1}, {21262, -1, -1, -1}, {21406, -1, -1, -1}, {21798, -1, -1, -1}, {21730, -1, -1, -1}, {21783, -1, -1, -1}, {21778, -1, -1, -1}, {21735, -1, -1, -1}, {21747, -1, -1, -1}, {21732, -1, -1, -1}, {21786, -1, -1, -1}, {21759, -1, -1, -1}, {21764, -1, -1, -1}, {21768, -1, -1, -1}, {21739, -1, -1, -1}, {21777, -1, -1, -1}, {21765, -1, -1, -1}, {21745, -1, -1, -1}, {21770, -1, -1, -1}, {21755, -1, -1, -1}, {21751, -1, -1, -1}, {21752, -1, -1, -1}, {21728, -1, -1, -1}, {21774, -1, -1, -1}, {21763, -1, -1, -1}, {21771, -1, -1, -1}, {22273, -1, -1, -1}, {22274, -1, -1, -1}, {22476, -1, -1, -1}, {22578, -1, -1, -1}, {22485, -1, -1, -1}, {22482, -1, -1, -1}, {22458, -1, -1, -1}, {22470, -1, -1, -1}, {22461, -1, -1, -1}, {22460, -1, -1, -1}, {22456, -1, -1, -1}, {22454, -1, -1, -1}, {22463, -1, -1, -1}, {22471, -1, -1, -1}, {22480, -1, -1, -1}, {22457, -1, -1, -1}, {22465, -1, -1, -1}, {22798, -1, -1, -1}, {22858, -1, -1, -1}, {23065, -1, -1, -1}, {23062, -1, -1, -1}, {23085, -1, -1, -1}, {23086, -1, -1, -1}, {23061, -1, -1, -1}, {23055, -1, -1, -1}, {23063, -1, -1, -1}, {23050, -1, -1, -1}, {23070, -1, -1, -1}, {23091, -1, -1, -1}, {23404, -1, -1, -1}, {23463, -1, -1, -1}, {23469, -1, -1, -1}, {23468, -1, -1, -1}, {23555, -1, -1, -1}, {23638, -1, -1, -1}, {23636, -1, -1, -1}, {23788, -1, -1, -1}, {23807, -1, -1, -1}, {23790, -1, -1, -1}, {23793, -1, -1, -1}, {23799, -1, -1, -1}, {23808, -1, -1, -1}, {23801, -1, -1, -1}, {24105, -1, -1, -1}, {24104, -1, -1, -1}, {24232, -1, -1, -1}, {24238, -1, -1, -1}, {24234, -1, -1, -1}, {24236, -1, -1, -1}, {24371, -1, -1, -1}, {24368, -1, -1, -1}, {24423, -1, -1, -1}, {24669, -1, -1, -1}, {24666, -1, -1, -1}, {24679, -1, -1, -1}, {24641, -1, -1, -1}, {24738, -1, -1, -1}, {24712, -1, -1, -1}, {24704, -1, -1, -1}, {24722, -1, -1, -1}, {24705, -1, -1, -1}, {24733, -1, -1, -1}, {24707, -1, -1, -1}, {24725, -1, -1, -1}, {24731, -1, -1, -1}, {24727, -1, -1, -1}, {24711, -1, -1, -1}, {24732, -1, -1, -1}, {24718, -1, -1, -1}, {25113, -1, -1, -1}, {25158, -1, -1, -1}, {25330, -1, -1, -1}, {25360, -1, -1, -1}, {25430, -1, -1, -1}, {25388, -1, -1, -1}, {25412, -1, -1, -1}, {25413, -1, -1, -1}, {25398, -1, -1, -1}, {25411, -1, -1, -1}, {25572, -1, -1, -1}, {25401, -1, -1, -1}, {25419, -1, -1, -1}, {25418, -1, -1, -1}, {25404, -1, -1, -1}, {25385, -1, -1, -1}, {25409, -1, -1, -1}, {25396, -1, -1, -1}, {25432, -1, -1, -1}, {25428, -1, -1, -1}, {25433, -1, -1, -1}, {25389, -1, -1, -1}, {25415, -1, -1, -1}, {25395, -1, -1, -1}, {25434, -1, -1, -1}, {25425, -1, -1, -1}, {25400, -1, -1, -1}, {25431, -1, -1, -1}, {25408, -1, -1, -1}, {25416, -1, -1, -1}, {25930, -1, -1, -1}, {25926, -1, -1, -1}, {26054, -1, -1, -1}, {26051, -1, -1, -1}, {26052, -1, -1, -1}, {26050, -1, -1, -1}, {26186, -1, -1, -1}, {26207, -1, -1, -1}, {26183, -1, -1, -1}, {26193, -1, -1, -1}, {26386, -1, -1, -1}, {26387, -1, -1, -1}, {26655, -1, -1, -1}, {26650, -1, -1, -1}, {26697, -1, -1, -1}, {26674, -1, -1, -1}, {26675, -1, -1, -1}, {26683, -1, -1, -1}, {26699, -1, -1, -1}, {26703, -1, -1, -1}, {26646, -1, -1, -1}, {26673, -1, -1, -1}, {26652, -1, -1, -1}, {26677, -1, -1, -1}, {26667, -1, -1, -1}, {26669, -1, -1, -1}, {26671, -1, -1, -1}, {26702, -1, -1, -1}, {26692, -1, -1, -1}, {26676, -1, -1, -1}, {26653, -1, -1, -1}, {26642, -1, -1, -1}, {26644, -1, -1, -1}, {26662, -1, -1, -1}, {26664, -1, -1, -1}, {26670, -1, -1, -1}, {26701, -1, -1, -1}, {26682, -1, -1, -1}, {26661, -1, -1, -1}, {26656, -1, -1, -1}, {27436, -1, -1, -1}, {27439, -1, -1, -1}, {27437, -1, -1, -1}, {27441, -1, -1, -1}, {27444, -1, -1, -1}, {27501, -1, -1, -1}, {32898, -1, -1, -1}, {27528, -1, -1, -1}, {27622, -1, -1, -1}, {27620, -1, -1, -1}, {27624, -1, -1, -1}, {27619, -1, -1, -1}, {27618, -1, -1, -1}, {27623, -1, -1, -1}, {27685, -1, -1, -1}, {28026, -1, -1, -1}, {28003, -1, -1, -1}, {28004, -1, -1, -1}, {28022, -1, -1, -1}, {27917, -1, -1, -1}, {28001, -1, -1, -1}, {28050, -1, -1, -1}, {27992, -1, -1, -1}, {28002, -1, -1, -1}, {28013, -1, -1, -1}, {28015, -1, -1, -1} },
+ {{28049, -1, -1, -1}, {28045, -1, -1, -1}, {28143, -1, -1, -1}, {28031, -1, -1, -1}, {28038, -1, -1, -1}, {27998, -1, -1, -1}, {28007, -1, -1, -1}, {28000, -1, -1, -1}, {28055, -1, -1, -1}, {28016, -1, -1, -1}, {28028, -1, -1, -1}, {27999, -1, -1, -1}, {28034, -1, -1, -1}, {28056, -1, -1, -1}, {27951, -1, -1, -1}, {28008, -1, -1, -1}, {28043, -1, -1, -1}, {28030, -1, -1, -1}, {28032, -1, -1, -1}, {28036, -1, -1, -1}, {27926, -1, -1, -1}, {28035, -1, -1, -1}, {28027, -1, -1, -1}, {28029, -1, -1, -1}, {28021, -1, -1, -1}, {28048, -1, -1, -1}, {28892, -1, -1, -1}, {28883, -1, -1, -1}, {28881, -1, -1, -1}, {28893, -1, -1, -1}, {28875, -1, -1, -1}, {32569, -1, -1, -1}, {28898, -1, -1, -1}, {28887, -1, -1, -1}, {28882, -1, -1, -1}, {28894, -1, -1, -1}, {28896, -1, -1, -1}, {28884, -1, -1, -1}, {28877, -1, -1, -1}, {28869, -1, -1, -1}, {28870, -1, -1, -1}, {28871, -1, -1, -1}, {28890, -1, -1, -1}, {28878, -1, -1, -1}, {28897, -1, -1, -1}, {29250, -1, -1, -1}, {29304, -1, -1, -1}, {29303, -1, -1, -1}, {29302, -1, -1, -1}, {29440, -1, -1, -1}, {29434, -1, -1, -1}, {29428, -1, -1, -1}, {29438, -1, -1, -1}, {29430, -1, -1, -1}, {29427, -1, -1, -1}, {29435, -1, -1, -1}, {29441, -1, -1, -1}, {29651, -1, -1, -1}, {29657, -1, -1, -1}, {29669, -1, -1, -1}, {29654, -1, -1, -1}, {29628, -1, -1, -1}, {29671, -1, -1, -1}, {29667, -1, -1, -1}, {29673, -1, -1, -1}, {29660, -1, -1, -1}, {29650, -1, -1, -1}, {29659, -1, -1, -1}, {29652, -1, -1, -1}, {29661, -1, -1, -1}, {29658, -1, -1, -1}, {29655, -1, -1, -1}, {29656, -1, -1, -1}, {29672, -1, -1, -1}, {29918, -1, -1, -1}, {29919, -1, -1, -1}, {29940, -1, -1, -1}, {29941, -1, -1, -1}, {29985, -1, -1, -1}, {30043, -1, -1, -1}, {30047, -1, -1, -1}, {30128, -1, -1, -1}, {30145, -1, -1, -1}, {30139, -1, -1, -1}, {30148, -1, -1, -1}, {30144, -1, -1, -1}, {30143, -1, -1, -1}, {30134, -1, -1, -1}, {30138, -1, -1, -1}, {30346, -1, -1, -1}, {30409, -1, -1, -1}, {30493, -1, -1, -1}, {30491, -1, -1, -1}, {30480, -1, -1, -1}, {30483, -1, -1, -1}, {30482, -1, -1, -1}, {30499, -1, -1, -1}, {30481, -1, -1, -1}, {30485, -1, -1, -1}, {30489, -1, -1, -1}, {30490, -1, -1, -1}, {30498, -1, -1, -1}, {30503, -1, -1, -1}, {30755, -1, -1, -1}, {30764, -1, -1, -1}, {30754, -1, -1, -1}, {30773, -1, -1, -1}, {30767, -1, -1, -1}, {30760, -1, -1, -1}, {30766, -1, -1, -1}, {30763, -1, -1, -1}, {30753, -1, -1, -1}, {30761, -1, -1, -1}, {30771, -1, -1, -1}, {30762, -1, -1, -1}, {30769, -1, -1, -1}, {31060, -1, -1, -1}, {31067, -1, -1, -1}, {31055, -1, -1, -1}, {31068, -1, -1, -1}, {31059, -1, -1, -1}, {31058, -1, -1, -1}, {31057, -1, -1, -1}, {31211, -1, -1, -1}, {31212, -1, -1, -1}, {31200, -1, -1, -1}, {31214, -1, -1, -1}, {31213, -1, -1, -1}, {31210, -1, -1, -1}, {31196, -1, -1, -1}, {31198, -1, -1, -1}, {31197, -1, -1, -1}, {31366, -1, -1, -1}, {31369, -1, -1, -1}, {31365, -1, -1, -1}, {31371, -1, -1, -1}, {31372, -1, -1, -1}, {31370, -1, -1, -1}, {31367, -1, -1, -1}, {31448, -1, -1, -1}, {31504, -1, -1, -1}, {31492, -1, -1, -1}, {31507, -1, -1, -1}, {31493, -1, -1, -1}, {31503, -1, -1, -1}, {31496, -1, -1, -1}, {31498, -1, -1, -1}, {31502, -1, -1, -1}, {31497, -1, -1, -1}, {31506, -1, -1, -1}, {31876, -1, -1, -1}, {31889, -1, -1, -1}, {31882, -1, -1, -1}, {31884, -1, -1, -1}, {31880, -1, -1, -1}, {31885, -1, -1, -1}, {31877, -1, -1, -1}, {32030, -1, -1, -1}, {32029, -1, -1, -1}, {32017, -1, -1, -1}, {32014, -1, -1, -1}, {32024, -1, -1, -1}, {32022, -1, -1, -1}, {32019, -1, -1, -1}, {32031, -1, -1, -1}, {32018, -1, -1, -1}, {32015, -1, -1, -1}, {32012, -1, -1, -1}, {32604, -1, -1, -1}, {32609, -1, -1, -1}, {32606, -1, -1, -1}, {32608, -1, -1, -1}, {32605, -1, -1, -1}, {32603, -1, -1, -1}, {32662, -1, -1, -1}, {32658, -1, -1, -1}, {32707, -1, -1, -1}, {32706, -1, -1, -1}, {32704, -1, -1, -1}, {32790, -1, -1, -1}, {32830, -1, -1, -1}, {32825, -1, -1, -1}, {33018, -1, -1, -1}, {33010, -1, -1, -1}, {33017, -1, -1, -1}, {33013, -1, -1, -1}, {33025, -1, -1, -1}, {33019, -1, -1, -1}, {33024, -1, -1, -1}, {33281, -1, -1, -1}, {33327, -1, -1, -1}, {33317, -1, -1, -1}, {33587, -1, -1, -1}, {33581, -1, -1, -1}, {33604, -1, -1, -1}, {33561, -1, -1, -1}, {33617, -1, -1, -1}, {33573, -1, -1, -1}, {33622, -1, -1, -1}, {33599, -1, -1, -1}, {33601, -1, -1, -1}, {33574, -1, -1, -1}, {33564, -1, -1, -1}, {33570, -1, -1, -1}, {33602, -1, -1, -1}, {33614, -1, -1, -1}, {33563, -1, -1, -1}, {33578, -1, -1, -1}, {33544, -1, -1, -1}, {33596, -1, -1, -1}, {33613, -1, -1, -1}, {33558, -1, -1, -1}, {33572, -1, -1, -1}, {33568, -1, -1, -1}, {33591, -1, -1, -1}, {33583, -1, -1, -1}, {33577, -1, -1, -1}, {33607, -1, -1, -1}, {33605, -1, -1, -1}, {33612, -1, -1, -1}, {33619, -1, -1, -1}, {33566, -1, -1, -1}, {33580, -1, -1, -1}, {33611, -1, -1, -1}, {33575, -1, -1, -1}, {33608, -1, -1, -1}, {34387, -1, -1, -1}, {34386, -1, -1, -1}, {34466, -1, -1, -1}, {34472, -1, -1, -1}, {34454, -1, -1, -1}, {34445, -1, -1, -1}, {34449, -1, -1, -1}, {34462, -1, -1, -1}, {34439, -1, -1, -1}, {34455, -1, -1, -1}, {34438, -1, -1, -1}, {34443, -1, -1, -1}, {34458, -1, -1, -1}, {34437, -1, -1, -1}, {34469, -1, -1, -1}, {34457, -1, -1, -1}, {34465, -1, -1, -1}, {34471, -1, -1, -1}, {34453, -1, -1, -1}, {34456, -1, -1, -1}, {34446, -1, -1, -1}, {34461, -1, -1, -1}, {34448, -1, -1, -1}, {34452, -1, -1, -1}, {34883, -1, -1, -1}, {34884, -1, -1, -1}, {34925, -1, -1, -1}, {34933, -1, -1, -1}, {34934, -1, -1, -1}, {34930, -1, -1, -1} },
+ {{34944, -1, -1, -1}, {34929, -1, -1, -1}, {34943, -1, -1, -1}, {34927, -1, -1, -1}, {34947, -1, -1, -1}, {34942, -1, -1, -1}, {34932, -1, -1, -1}, {34940, -1, -1, -1}, {35346, -1, -1, -1}, {35911, -1, -1, -1}, {35927, -1, -1, -1}, {35963, -1, -1, -1}, {36004, -1, -1, -1}, {36003, -1, -1, -1}, {36214, -1, -1, -1}, {36216, -1, -1, -1}, {36277, -1, -1, -1}, {36279, -1, -1, -1}, {36278, -1, -1, -1}, {36561, -1, -1, -1}, {36563, -1, -1, -1}, {36862, -1, -1, -1}, {36853, -1, -1, -1}, {36866, -1, -1, -1}, {36863, -1, -1, -1}, {36859, -1, -1, -1}, {36868, -1, -1, -1}, {36860, -1, -1, -1}, {36854, -1, -1, -1}, {37078, -1, -1, -1}, {37088, -1, -1, -1}, {37081, -1, -1, -1}, {37082, -1, -1, -1}, {37091, -1, -1, -1}, {37087, -1, -1, -1}, {37093, -1, -1, -1}, {37080, -1, -1, -1}, {37083, -1, -1, -1}, {37079, -1, -1, -1}, {37084, -1, -1, -1}, {37092, -1, -1, -1}, {37200, -1, -1, -1}, {37198, -1, -1, -1}, {37199, -1, -1, -1}, {37333, -1, -1, -1}, {37346, -1, -1, -1}, {37338, -1, -1, -1}, {38492, -1, -1, -1}, {38495, -1, -1, -1}, {38588, -1, -1, -1}, {39139, -1, -1, -1}, {39647, -1, -1, -1}, {39727, -1, -1, -1}, {20095, -1, -1, -1}, {20592, -1, -1, -1}, {20586, -1, -1, -1}, {20577, -1, -1, -1}, {20574, -1, -1, -1}, {20576, -1, -1, -1}, {20563, -1, -1, -1}, {20555, -1, -1, -1}, {20573, -1, -1, -1}, {20594, -1, -1, -1}, {20552, -1, -1, -1}, {20557, -1, -1, -1}, {20545, -1, -1, -1}, {20571, -1, -1, -1}, {20554, -1, -1, -1}, {20578, -1, -1, -1}, {20501, -1, -1, -1}, {20549, -1, -1, -1}, {20575, -1, -1, -1}, {20585, -1, -1, -1}, {20587, -1, -1, -1}, {20579, -1, -1, -1}, {20580, -1, -1, -1}, {20550, -1, -1, -1}, {20544, -1, -1, -1}, {20590, -1, -1, -1}, {20595, -1, -1, -1}, {20567, -1, -1, -1}, {20561, -1, -1, -1}, {20944, -1, -1, -1}, {21099, -1, -1, -1}, {21101, -1, -1, -1}, {21100, -1, -1, -1}, {21102, -1, -1, -1}, {21206, -1, -1, -1}, {21203, -1, -1, -1}, {21293, -1, -1, -1}, {21404, -1, -1, -1}, {21877, -1, -1, -1}, {21878, -1, -1, -1}, {21820, -1, -1, -1}, {21837, -1, -1, -1}, {21840, -1, -1, -1}, {21812, -1, -1, -1}, {21802, -1, -1, -1}, {21841, -1, -1, -1}, {21858, -1, -1, -1}, {21814, -1, -1, -1}, {21813, -1, -1, -1}, {21808, -1, -1, -1}, {21842, -1, -1, -1}, {21829, -1, -1, -1}, {21772, -1, -1, -1}, {21810, -1, -1, -1}, {21861, -1, -1, -1}, {21838, -1, -1, -1}, {21817, -1, -1, -1}, {21832, -1, -1, -1}, {21805, -1, -1, -1}, {21819, -1, -1, -1}, {21824, -1, -1, -1}, {21835, -1, -1, -1}, {22282, -1, -1, -1}, {22279, -1, -1, -1}, {22523, -1, -1, -1}, {22548, -1, -1, -1}, {22498, -1, -1, -1}, {22518, -1, -1, -1}, {22492, -1, -1, -1}, {22516, -1, -1, -1}, {22528, -1, -1, -1}, {22509, -1, -1, -1}, {22525, -1, -1, -1}, {22536, -1, -1, -1}, {22520, -1, -1, -1}, {22539, -1, -1, -1}, {22515, -1, -1, -1}, {22479, -1, -1, -1}, {22535, -1, -1, -1}, {22510, -1, -1, -1}, {22499, -1, -1, -1}, {22514, -1, -1, -1}, {22501, -1, -1, -1}, {22508, -1, -1, -1}, {22497, -1, -1, -1}, {22542, -1, -1, -1}, {22524, -1, -1, -1}, {22544, -1, -1, -1}, {22503, -1, -1, -1}, {22529, -1, -1, -1}, {22540, -1, -1, -1}, {22513, -1, -1, -1}, {22505, -1, -1, -1}, {22512, -1, -1, -1}, {22541, -1, -1, -1}, {22532, -1, -1, -1}, {22876, -1, -1, -1}, {23136, -1, -1, -1}, {23128, -1, -1, -1}, {23125, -1, -1, -1}, {23143, -1, -1, -1}, {23134, -1, -1, -1}, {23096, -1, -1, -1}, {23093, -1, -1, -1}, {23149, -1, -1, -1}, {23120, -1, -1, -1}, {23135, -1, -1, -1}, {23141, -1, -1, -1}, {23148, -1, -1, -1}, {23123, -1, -1, -1}, {23140, -1, -1, -1}, {23127, -1, -1, -1}, {23107, -1, -1, -1}, {23133, -1, -1, -1}, {23122, -1, -1, -1}, {23108, -1, -1, -1}, {23131, -1, -1, -1}, {23112, -1, -1, -1}, {23182, -1, -1, -1}, {23102, -1, -1, -1}, {23117, -1, -1, -1}, {23097, -1, -1, -1}, {23116, -1, -1, -1}, {23152, -1, -1, -1}, {23145, -1, -1, -1}, {23111, -1, -1, -1}, {23121, -1, -1, -1}, {23126, -1, -1, -1}, {23106, -1, -1, -1}, {23132, -1, -1, -1}, {23410, -1, -1, -1}, {23406, -1, -1, -1}, {23489, -1, -1, -1}, {23488, -1, -1, -1}, {23641, -1, -1, -1}, {23838, -1, -1, -1}, {23819, -1, -1, -1}, {23837, -1, -1, -1}, {23834, -1, -1, -1}, {23840, -1, -1, -1}, {23820, -1, -1, -1}, {23848, -1, -1, -1}, {23821, -1, -1, -1}, {23846, -1, -1, -1}, {23845, -1, -1, -1}, {23823, -1, -1, -1}, {23856, -1, -1, -1}, {23826, -1, -1, -1}, {23843, -1, -1, -1}, {23839, -1, -1, -1}, {23854, -1, -1, -1}, {24126, -1, -1, -1}, {24116, -1, -1, -1}, {24241, -1, -1, -1}, {24244, -1, -1, -1}, {24249, -1, -1, -1}, {24242, -1, -1, -1}, {24243, -1, -1, -1}, {24374, -1, -1, -1}, {24376, -1, -1, -1}, {24475, -1, -1, -1}, {24470, -1, -1, -1}, {24479, -1, -1, -1}, {24714, -1, -1, -1}, {24720, -1, -1, -1}, {24710, -1, -1, -1}, {24766, -1, -1, -1}, {24752, -1, -1, -1}, {24762, -1, -1, -1}, {24787, -1, -1, -1}, {24788, -1, -1, -1}, {24783, -1, -1, -1}, {24804, -1, -1, -1}, {24793, -1, -1, -1}, {24797, -1, -1, -1}, {24776, -1, -1, -1}, {24753, -1, -1, -1}, {24795, -1, -1, -1}, {24759, -1, -1, -1}, {24778, -1, -1, -1}, {24767, -1, -1, -1}, {24771, -1, -1, -1}, {24781, -1, -1, -1}, {24768, -1, -1, -1}, {25394, -1, -1, -1}, {25445, -1, -1, -1}, {25482, -1, -1, -1}, {25474, -1, -1, -1}, {25469, -1, -1, -1}, {25533, -1, -1, -1}, {25502, -1, -1, -1}, {25517, -1, -1, -1}, {25501, -1, -1, -1}, {25495, -1, -1, -1}, {25515, -1, -1, -1}, {25486, -1, -1, -1}, {25455, -1, -1, -1}, {25479, -1, -1, -1}, {25488, -1, -1, -1}, {25454, -1, -1, -1}, {25519, -1, -1, -1}, {25461, -1, -1, -1}, {25500, -1, -1, -1} },
+ {{25453, -1, -1, -1}, {25518, -1, -1, -1}, {25468, -1, -1, -1}, {25508, -1, -1, -1}, {25403, -1, -1, -1}, {25503, -1, -1, -1}, {25464, -1, -1, -1}, {25477, -1, -1, -1}, {25473, -1, -1, -1}, {25489, -1, -1, -1}, {25485, -1, -1, -1}, {25456, -1, -1, -1}, {25939, -1, -1, -1}, {26061, -1, -1, -1}, {26213, -1, -1, -1}, {26209, -1, -1, -1}, {26203, -1, -1, -1}, {26201, -1, -1, -1}, {26204, -1, -1, -1}, {26210, -1, -1, -1}, {26392, -1, -1, -1}, {26745, -1, -1, -1}, {26759, -1, -1, -1}, {26768, -1, -1, -1}, {26780, -1, -1, -1}, {26733, -1, -1, -1}, {26734, -1, -1, -1}, {26798, -1, -1, -1}, {26795, -1, -1, -1}, {26966, -1, -1, -1}, {26735, -1, -1, -1}, {26787, -1, -1, -1}, {26796, -1, -1, -1}, {26793, -1, -1, -1}, {26741, -1, -1, -1}, {26740, -1, -1, -1}, {26802, -1, -1, -1}, {26767, -1, -1, -1}, {26743, -1, -1, -1}, {26770, -1, -1, -1}, {26748, -1, -1, -1}, {26731, -1, -1, -1}, {26738, -1, -1, -1}, {26794, -1, -1, -1}, {26752, -1, -1, -1}, {26737, -1, -1, -1}, {26750, -1, -1, -1}, {26779, -1, -1, -1}, {26774, -1, -1, -1}, {26763, -1, -1, -1}, {26784, -1, -1, -1}, {26761, -1, -1, -1}, {26788, -1, -1, -1}, {26744, -1, -1, -1}, {26747, -1, -1, -1}, {26769, -1, -1, -1}, {26764, -1, -1, -1}, {26762, -1, -1, -1}, {26749, -1, -1, -1}, {27446, -1, -1, -1}, {27443, -1, -1, -1}, {27447, -1, -1, -1}, {27448, -1, -1, -1}, {27537, -1, -1, -1}, {27535, -1, -1, -1}, {27533, -1, -1, -1}, {27534, -1, -1, -1}, {27532, -1, -1, -1}, {27690, -1, -1, -1}, {28096, -1, -1, -1}, {28075, -1, -1, -1}, {28084, -1, -1, -1}, {28083, -1, -1, -1}, {28276, -1, -1, -1}, {28076, -1, -1, -1}, {28137, -1, -1, -1}, {28130, -1, -1, -1}, {28087, -1, -1, -1}, {28150, -1, -1, -1}, {28116, -1, -1, -1}, {28160, -1, -1, -1}, {28104, -1, -1, -1}, {28128, -1, -1, -1}, {28127, -1, -1, -1}, {28118, -1, -1, -1}, {28094, -1, -1, -1}, {28133, -1, -1, -1}, {28124, -1, -1, -1}, {28125, -1, -1, -1}, {28123, -1, -1, -1}, {28148, -1, -1, -1}, {28106, -1, -1, -1}, {28093, -1, -1, -1}, {28141, -1, -1, -1}, {28144, -1, -1, -1}, {28090, -1, -1, -1}, {28117, -1, -1, -1}, {28098, -1, -1, -1}, {28111, -1, -1, -1}, {28105, -1, -1, -1}, {28112, -1, -1, -1}, {28146, -1, -1, -1}, {28115, -1, -1, -1}, {28157, -1, -1, -1}, {28119, -1, -1, -1}, {28109, -1, -1, -1}, {28131, -1, -1, -1}, {28091, -1, -1, -1}, {28922, -1, -1, -1}, {28941, -1, -1, -1}, {28919, -1, -1, -1}, {28951, -1, -1, -1}, {28916, -1, -1, -1}, {28940, -1, -1, -1}, {28912, -1, -1, -1}, {28932, -1, -1, -1}, {28915, -1, -1, -1}, {28944, -1, -1, -1}, {28924, -1, -1, -1}, {28927, -1, -1, -1}, {28934, -1, -1, -1}, {28947, -1, -1, -1}, {28928, -1, -1, -1}, {28920, -1, -1, -1}, {28918, -1, -1, -1}, {28939, -1, -1, -1}, {28930, -1, -1, -1}, {28942, -1, -1, -1}, {29310, -1, -1, -1}, {29307, -1, -1, -1}, {29308, -1, -1, -1}, {29311, -1, -1, -1}, {29469, -1, -1, -1}, {29463, -1, -1, -1}, {29447, -1, -1, -1}, {29457, -1, -1, -1}, {29464, -1, -1, -1}, {29450, -1, -1, -1}, {29448, -1, -1, -1}, {29439, -1, -1, -1}, {29455, -1, -1, -1}, {29470, -1, -1, -1}, {29576, -1, -1, -1}, {29686, -1, -1, -1}, {29688, -1, -1, -1}, {29685, -1, -1, -1}, {29700, -1, -1, -1}, {29697, -1, -1, -1}, {29693, -1, -1, -1}, {29703, -1, -1, -1}, {29696, -1, -1, -1}, {29690, -1, -1, -1}, {29692, -1, -1, -1}, {29695, -1, -1, -1}, {29708, -1, -1, -1}, {29707, -1, -1, -1}, {29684, -1, -1, -1}, {29704, -1, -1, -1}, {30052, -1, -1, -1}, {30051, -1, -1, -1}, {30158, -1, -1, -1}, {30162, -1, -1, -1}, {30159, -1, -1, -1}, {30155, -1, -1, -1}, {30156, -1, -1, -1}, {30161, -1, -1, -1}, {30160, -1, -1, -1}, {30351, -1, -1, -1}, {30345, -1, -1, -1}, {30419, -1, -1, -1}, {30521, -1, -1, -1}, {30511, -1, -1, -1}, {30509, -1, -1, -1}, {30513, -1, -1, -1}, {30514, -1, -1, -1}, {30516, -1, -1, -1}, {30515, -1, -1, -1}, {30525, -1, -1, -1}, {30501, -1, -1, -1}, {30523, -1, -1, -1}, {30517, -1, -1, -1}, {30792, -1, -1, -1}, {30802, -1, -1, -1}, {30793, -1, -1, -1}, {30797, -1, -1, -1}, {30794, -1, -1, -1}, {30796, -1, -1, -1}, {30758, -1, -1, -1}, {30789, -1, -1, -1}, {30800, -1, -1, -1}, {31076, -1, -1, -1}, {31079, -1, -1, -1}, {31081, -1, -1, -1}, {31082, -1, -1, -1}, {31075, -1, -1, -1}, {31083, -1, -1, -1}, {31073, -1, -1, -1}, {31163, -1, -1, -1}, {31226, -1, -1, -1}, {31224, -1, -1, -1}, {31222, -1, -1, -1}, {31223, -1, -1, -1}, {31375, -1, -1, -1}, {31380, -1, -1, -1}, {31376, -1, -1, -1}, {31541, -1, -1, -1}, {31547, -1, -1, -1}, {31540, -1, -1, -1}, {31525, -1, -1, -1}, {31536, -1, -1, -1}, {31522, -1, -1, -1}, {31524, -1, -1, -1}, {31539, -1, -1, -1}, {31512, -1, -1, -1}, {31530, -1, -1, -1}, {31517, -1, -1, -1}, {31537, -1, -1, -1}, {31531, -1, -1, -1}, {31533, -1, -1, -1}, {31535, -1, -1, -1}, {31538, -1, -1, -1}, {31544, -1, -1, -1}, {31514, -1, -1, -1}, {31523, -1, -1, -1}, {31892, -1, -1, -1}, {31896, -1, -1, -1}, {31894, -1, -1, -1}, {31907, -1, -1, -1}, {32053, -1, -1, -1}, {32061, -1, -1, -1}, {32056, -1, -1, -1}, {32054, -1, -1, -1}, {32058, -1, -1, -1}, {32069, -1, -1, -1}, {32044, -1, -1, -1}, {32041, -1, -1, -1}, {32065, -1, -1, -1}, {32071, -1, -1, -1}, {32062, -1, -1, -1}, {32063, -1, -1, -1}, {32074, -1, -1, -1}, {32059, -1, -1, -1}, {32040, -1, -1, -1}, {32611, -1, -1, -1}, {32661, -1, -1, -1}, {32668, -1, -1, -1}, {32669, -1, -1, -1}, {32667, -1, -1, -1}, {32714, -1, -1, -1}, {32715, -1, -1, -1}, {32717, -1, -1, -1}, {32720, -1, -1, -1}, {32721, -1, -1, -1}, {32711, -1, -1, -1}, {32719, -1, -1, -1}, {32713, -1, -1, -1} },
+ {{32799, -1, -1, -1}, {32798, -1, -1, -1}, {32795, -1, -1, -1}, {32839, -1, -1, -1}, {32835, -1, -1, -1}, {32840, -1, -1, -1}, {33048, -1, -1, -1}, {33061, -1, -1, -1}, {33049, -1, -1, -1}, {33051, -1, -1, -1}, {33069, -1, -1, -1}, {33055, -1, -1, -1}, {33068, -1, -1, -1}, {33054, -1, -1, -1}, {33057, -1, -1, -1}, {33045, -1, -1, -1}, {33063, -1, -1, -1}, {33053, -1, -1, -1}, {33058, -1, -1, -1}, {33297, -1, -1, -1}, {33336, -1, -1, -1}, {33331, -1, -1, -1}, {33338, -1, -1, -1}, {33332, -1, -1, -1}, {33330, -1, -1, -1}, {33396, -1, -1, -1}, {33680, -1, -1, -1}, {33699, -1, -1, -1}, {33704, -1, -1, -1}, {33677, -1, -1, -1}, {33658, -1, -1, -1}, {33651, -1, -1, -1}, {33700, -1, -1, -1}, {33652, -1, -1, -1}, {33679, -1, -1, -1}, {33665, -1, -1, -1}, {33685, -1, -1, -1}, {33689, -1, -1, -1}, {33653, -1, -1, -1}, {33684, -1, -1, -1}, {33705, -1, -1, -1}, {33661, -1, -1, -1}, {33667, -1, -1, -1}, {33676, -1, -1, -1}, {33693, -1, -1, -1}, {33691, -1, -1, -1}, {33706, -1, -1, -1}, {33675, -1, -1, -1}, {33662, -1, -1, -1}, {33701, -1, -1, -1}, {33711, -1, -1, -1}, {33672, -1, -1, -1}, {33687, -1, -1, -1}, {33712, -1, -1, -1}, {33663, -1, -1, -1}, {33702, -1, -1, -1}, {33671, -1, -1, -1}, {33710, -1, -1, -1}, {33654, -1, -1, -1}, {34393, -1, -1, -1}, {34390, -1, -1, -1}, {34495, -1, -1, -1}, {34487, -1, -1, -1}, {34498, -1, -1, -1}, {34497, -1, -1, -1}, {34501, -1, -1, -1}, {34490, -1, -1, -1}, {34480, -1, -1, -1}, {34504, -1, -1, -1}, {34489, -1, -1, -1}, {34483, -1, -1, -1}, {34488, -1, -1, -1}, {34508, -1, -1, -1}, {34484, -1, -1, -1}, {34491, -1, -1, -1}, {34492, -1, -1, -1}, {34499, -1, -1, -1}, {34493, -1, -1, -1}, {34494, -1, -1, -1}, {34898, -1, -1, -1}, {34953, -1, -1, -1}, {34965, -1, -1, -1}, {34984, -1, -1, -1}, {34978, -1, -1, -1}, {34986, -1, -1, -1}, {34970, -1, -1, -1}, {34961, -1, -1, -1}, {34977, -1, -1, -1}, {34975, -1, -1, -1}, {34968, -1, -1, -1}, {34983, -1, -1, -1}, {34969, -1, -1, -1}, {34971, -1, -1, -1}, {34967, -1, -1, -1}, {34980, -1, -1, -1}, {34988, -1, -1, -1}, {34956, -1, -1, -1}, {34963, -1, -1, -1}, {34958, -1, -1, -1}, {35202, -1, -1, -1}, {35286, -1, -1, -1}, {35289, -1, -1, -1}, {35285, -1, -1, -1}, {35376, -1, -1, -1}, {35367, -1, -1, -1}, {35372, -1, -1, -1}, {35358, -1, -1, -1}, {35897, -1, -1, -1}, {35899, -1, -1, -1}, {35932, -1, -1, -1}, {35933, -1, -1, -1}, {35965, -1, -1, -1}, {36005, -1, -1, -1}, {36221, -1, -1, -1}, {36219, -1, -1, -1}, {36217, -1, -1, -1}, {36284, -1, -1, -1}, {36290, -1, -1, -1}, {36281, -1, -1, -1}, {36287, -1, -1, -1}, {36289, -1, -1, -1}, {36568, -1, -1, -1}, {36574, -1, -1, -1}, {36573, -1, -1, -1}, {36572, -1, -1, -1}, {36567, -1, -1, -1}, {36576, -1, -1, -1}, {36577, -1, -1, -1}, {36900, -1, -1, -1}, {36875, -1, -1, -1}, {36881, -1, -1, -1}, {36892, -1, -1, -1}, {36876, -1, -1, -1}, {36897, -1, -1, -1}, {37103, -1, -1, -1}, {37098, -1, -1, -1}, {37104, -1, -1, -1}, {37108, -1, -1, -1}, {37106, -1, -1, -1}, {37107, -1, -1, -1}, {37076, -1, -1, -1}, {37099, -1, -1, -1}, {37100, -1, -1, -1}, {37097, -1, -1, -1}, {37206, -1, -1, -1}, {37208, -1, -1, -1}, {37210, -1, -1, -1}, {37203, -1, -1, -1}, {37205, -1, -1, -1}, {37356, -1, -1, -1}, {37364, -1, -1, -1}, {37361, -1, -1, -1}, {37363, -1, -1, -1}, {37368, -1, -1, -1}, {37348, -1, -1, -1}, {37369, -1, -1, -1}, {37354, -1, -1, -1}, {37355, -1, -1, -1}, {37367, -1, -1, -1}, {37352, -1, -1, -1}, {37358, -1, -1, -1}, {38266, -1, -1, -1}, {38278, -1, -1, -1}, {38280, -1, -1, -1}, {38524, -1, -1, -1}, {38509, -1, -1, -1}, {38507, -1, -1, -1}, {38513, -1, -1, -1}, {38511, -1, -1, -1}, {38591, -1, -1, -1}, {38762, -1, -1, -1}, {38916, -1, -1, -1}, {39141, -1, -1, -1}, {39319, -1, -1, -1}, {20635, -1, -1, -1}, {20629, -1, -1, -1}, {20628, -1, -1, -1}, {20638, -1, -1, -1}, {20619, -1, -1, -1}, {20643, -1, -1, -1}, {20611, -1, -1, -1}, {20620, -1, -1, -1}, {20622, -1, -1, -1}, {20637, -1, -1, -1}, {20584, -1, -1, -1}, {20636, -1, -1, -1}, {20626, -1, -1, -1}, {20610, -1, -1, -1}, {20615, -1, -1, -1}, {20831, -1, -1, -1}, {20948, -1, -1, -1}, {21266, -1, -1, -1}, {21265, -1, -1, -1}, {21412, -1, -1, -1}, {21415, -1, -1, -1}, {21905, -1, -1, -1}, {21928, -1, -1, -1}, {21925, -1, -1, -1}, {21933, -1, -1, -1}, {21879, -1, -1, -1}, {22085, -1, -1, -1}, {21922, -1, -1, -1}, {21907, -1, -1, -1}, {21896, -1, -1, -1}, {21903, -1, -1, -1}, {21941, -1, -1, -1}, {21889, -1, -1, -1}, {21923, -1, -1, -1}, {21906, -1, -1, -1}, {21924, -1, -1, -1}, {21885, -1, -1, -1}, {21900, -1, -1, -1}, {21926, -1, -1, -1}, {21887, -1, -1, -1}, {21909, -1, -1, -1}, {21921, -1, -1, -1}, {21902, -1, -1, -1}, {22284, -1, -1, -1}, {22569, -1, -1, -1}, {22583, -1, -1, -1}, {22553, -1, -1, -1}, {22558, -1, -1, -1}, {22567, -1, -1, -1}, {22563, -1, -1, -1}, {22568, -1, -1, -1}, {22517, -1, -1, -1}, {22600, -1, -1, -1}, {22565, -1, -1, -1}, {22556, -1, -1, -1}, {22555, -1, -1, -1}, {22579, -1, -1, -1}, {22591, -1, -1, -1}, {22582, -1, -1, -1}, {22574, -1, -1, -1}, {22585, -1, -1, -1}, {22584, -1, -1, -1}, {22573, -1, -1, -1}, {22572, -1, -1, -1}, {22587, -1, -1, -1}, {22881, -1, -1, -1}, {23215, -1, -1, -1}, {23188, -1, -1, -1}, {23199, -1, -1, -1}, {23162, -1, -1, -1}, {23202, -1, -1, -1}, {23198, -1, -1, -1}, {23160, -1, -1, -1}, {23206, -1, -1, -1}, {23164, -1, -1, -1}, {23205, -1, -1, -1}, {23212, -1, -1, -1}, {23189, -1, -1, -1}, {23214, -1, -1, -1}, {23095, -1, -1, -1}, {23172, -1, -1, -1}, {23178, -1, -1, -1} },
+ {{23191, -1, -1, -1}, {23171, -1, -1, -1}, {23179, -1, -1, -1}, {23209, -1, -1, -1}, {23163, -1, -1, -1}, {23165, -1, -1, -1}, {23180, -1, -1, -1}, {23196, -1, -1, -1}, {23183, -1, -1, -1}, {23187, -1, -1, -1}, {23197, -1, -1, -1}, {23530, -1, -1, -1}, {23501, -1, -1, -1}, {23499, -1, -1, -1}, {23508, -1, -1, -1}, {23505, -1, -1, -1}, {23498, -1, -1, -1}, {23502, -1, -1, -1}, {23564, -1, -1, -1}, {23600, -1, -1, -1}, {23863, -1, -1, -1}, {23875, -1, -1, -1}, {23915, -1, -1, -1}, {23873, -1, -1, -1}, {23883, -1, -1, -1}, {23871, -1, -1, -1}, {23861, -1, -1, -1}, {23889, -1, -1, -1}, {23886, -1, -1, -1}, {23893, -1, -1, -1}, {23859, -1, -1, -1}, {23866, -1, -1, -1}, {23890, -1, -1, -1}, {23869, -1, -1, -1}, {23857, -1, -1, -1}, {23897, -1, -1, -1}, {23874, -1, -1, -1}, {23865, -1, -1, -1}, {23881, -1, -1, -1}, {23864, -1, -1, -1}, {23868, -1, -1, -1}, {23858, -1, -1, -1}, {23862, -1, -1, -1}, {23872, -1, -1, -1}, {23877, -1, -1, -1}, {24132, -1, -1, -1}, {24129, -1, -1, -1}, {24408, -1, -1, -1}, {24486, -1, -1, -1}, {24485, -1, -1, -1}, {24491, -1, -1, -1}, {24777, -1, -1, -1}, {24761, -1, -1, -1}, {24780, -1, -1, -1}, {24802, -1, -1, -1}, {24782, -1, -1, -1}, {24772, -1, -1, -1}, {24852, -1, -1, -1}, {24818, -1, -1, -1}, {24842, -1, -1, -1}, {24854, -1, -1, -1}, {24837, -1, -1, -1}, {24821, -1, -1, -1}, {24851, -1, -1, -1}, {24824, -1, -1, -1}, {24828, -1, -1, -1}, {24830, -1, -1, -1}, {24769, -1, -1, -1}, {24835, -1, -1, -1}, {24856, -1, -1, -1}, {24861, -1, -1, -1}, {24848, -1, -1, -1}, {24831, -1, -1, -1}, {24836, -1, -1, -1}, {24843, -1, -1, -1}, {25162, -1, -1, -1}, {25492, -1, -1, -1}, {25521, -1, -1, -1}, {25520, -1, -1, -1}, {25550, -1, -1, -1}, {25573, -1, -1, -1}, {25576, -1, -1, -1}, {25583, -1, -1, -1}, {25539, -1, -1, -1}, {25757, -1, -1, -1}, {25587, -1, -1, -1}, {25546, -1, -1, -1}, {25568, -1, -1, -1}, {25590, -1, -1, -1}, {25557, -1, -1, -1}, {25586, -1, -1, -1}, {25589, -1, -1, -1}, {25697, -1, -1, -1}, {25567, -1, -1, -1}, {25534, -1, -1, -1}, {25565, -1, -1, -1}, {25564, -1, -1, -1}, {25540, -1, -1, -1}, {25560, -1, -1, -1}, {25555, -1, -1, -1}, {25538, -1, -1, -1}, {25543, -1, -1, -1}, {25548, -1, -1, -1}, {25547, -1, -1, -1}, {25544, -1, -1, -1}, {25584, -1, -1, -1}, {25559, -1, -1, -1}, {25561, -1, -1, -1}, {25906, -1, -1, -1}, {25959, -1, -1, -1}, {25962, -1, -1, -1}, {25956, -1, -1, -1}, {25948, -1, -1, -1}, {25960, -1, -1, -1}, {25957, -1, -1, -1}, {25996, -1, -1, -1}, {26013, -1, -1, -1}, {26014, -1, -1, -1}, {26030, -1, -1, -1}, {26064, -1, -1, -1}, {26066, -1, -1, -1}, {26236, -1, -1, -1}, {26220, -1, -1, -1}, {26235, -1, -1, -1}, {26240, -1, -1, -1}, {26225, -1, -1, -1}, {26233, -1, -1, -1}, {26218, -1, -1, -1}, {26226, -1, -1, -1}, {26369, -1, -1, -1}, {26892, -1, -1, -1}, {26835, -1, -1, -1}, {26884, -1, -1, -1}, {26844, -1, -1, -1}, {26922, -1, -1, -1}, {26860, -1, -1, -1}, {26858, -1, -1, -1}, {26865, -1, -1, -1}, {26895, -1, -1, -1}, {26838, -1, -1, -1}, {26871, -1, -1, -1}, {26859, -1, -1, -1}, {26852, -1, -1, -1}, {26870, -1, -1, -1}, {26899, -1, -1, -1}, {26896, -1, -1, -1}, {26867, -1, -1, -1}, {26849, -1, -1, -1}, {26887, -1, -1, -1}, {26828, -1, -1, -1}, {26888, -1, -1, -1}, {26992, -1, -1, -1}, {26804, -1, -1, -1}, {26897, -1, -1, -1}, {26863, -1, -1, -1}, {26822, -1, -1, -1}, {26900, -1, -1, -1}, {26872, -1, -1, -1}, {26832, -1, -1, -1}, {26877, -1, -1, -1}, {26876, -1, -1, -1}, {26856, -1, -1, -1}, {26891, -1, -1, -1}, {26890, -1, -1, -1}, {26903, -1, -1, -1}, {26830, -1, -1, -1}, {26824, -1, -1, -1}, {26845, -1, -1, -1}, {26846, -1, -1, -1}, {26854, -1, -1, -1}, {26868, -1, -1, -1}, {26833, -1, -1, -1}, {26886, -1, -1, -1}, {26836, -1, -1, -1}, {26857, -1, -1, -1}, {26901, -1, -1, -1}, {26917, -1, -1, -1}, {26823, -1, -1, -1}, {27449, -1, -1, -1}, {27451, -1, -1, -1}, {27455, -1, -1, -1}, {27452, -1, -1, -1}, {27540, -1, -1, -1}, {27543, -1, -1, -1}, {27545, -1, -1, -1}, {27541, -1, -1, -1}, {27581, -1, -1, -1}, {27632, -1, -1, -1}, {27634, -1, -1, -1}, {27635, -1, -1, -1}, {27696, -1, -1, -1}, {28156, -1, -1, -1}, {28230, -1, -1, -1}, {28231, -1, -1, -1}, {28191, -1, -1, -1}, {28233, -1, -1, -1}, {28296, -1, -1, -1}, {28220, -1, -1, -1}, {28221, -1, -1, -1}, {28229, -1, -1, -1}, {28258, -1, -1, -1}, {28203, -1, -1, -1}, {28223, -1, -1, -1}, {28225, -1, -1, -1}, {28253, -1, -1, -1}, {28275, -1, -1, -1}, {28188, -1, -1, -1}, {28211, -1, -1, -1}, {28235, -1, -1, -1}, {28224, -1, -1, -1}, {28241, -1, -1, -1}, {28219, -1, -1, -1}, {28163, -1, -1, -1}, {28206, -1, -1, -1}, {28254, -1, -1, -1}, {28264, -1, -1, -1}, {28252, -1, -1, -1}, {28257, -1, -1, -1}, {28209, -1, -1, -1}, {28200, -1, -1, -1}, {28256, -1, -1, -1}, {28273, -1, -1, -1}, {28267, -1, -1, -1}, {28217, -1, -1, -1}, {28194, -1, -1, -1}, {28208, -1, -1, -1}, {28243, -1, -1, -1}, {28261, -1, -1, -1}, {28199, -1, -1, -1}, {28280, -1, -1, -1}, {28260, -1, -1, -1}, {28279, -1, -1, -1}, {28245, -1, -1, -1}, {28281, -1, -1, -1}, {28242, -1, -1, -1}, {28262, -1, -1, -1}, {28213, -1, -1, -1}, {28214, -1, -1, -1}, {28250, -1, -1, -1}, {28960, -1, -1, -1}, {28958, -1, -1, -1}, {28975, -1, -1, -1}, {28923, -1, -1, -1}, {28974, -1, -1, -1}, {28977, -1, -1, -1}, {28963, -1, -1, -1}, {28965, -1, -1, -1}, {28962, -1, -1, -1}, {28978, -1, -1, -1}, {28959, -1, -1, -1}, {28968, -1, -1, -1}, {28986, -1, -1, -1}, {28955, -1, -1, -1}, {29259, -1, -1, -1}, {29274, -1, -1, -1}, {29320, -1, -1, -1} },
+ {{29321, -1, -1, -1}, {29318, -1, -1, -1}, {29317, -1, -1, -1}, {29323, -1, -1, -1}, {29458, -1, -1, -1}, {29451, -1, -1, -1}, {29488, -1, -1, -1}, {29474, -1, -1, -1}, {29489, -1, -1, -1}, {29491, -1, -1, -1}, {29479, -1, -1, -1}, {29490, -1, -1, -1}, {29485, -1, -1, -1}, {29478, -1, -1, -1}, {29475, -1, -1, -1}, {29493, -1, -1, -1}, {29452, -1, -1, -1}, {29742, -1, -1, -1}, {29740, -1, -1, -1}, {29744, -1, -1, -1}, {29739, -1, -1, -1}, {29718, -1, -1, -1}, {29722, -1, -1, -1}, {29729, -1, -1, -1}, {29741, -1, -1, -1}, {29745, -1, -1, -1}, {29732, -1, -1, -1}, {29731, -1, -1, -1}, {29725, -1, -1, -1}, {29737, -1, -1, -1}, {29728, -1, -1, -1}, {29746, -1, -1, -1}, {29947, -1, -1, -1}, {29999, -1, -1, -1}, {30063, -1, -1, -1}, {30060, -1, -1, -1}, {30183, -1, -1, -1}, {30170, -1, -1, -1}, {30177, -1, -1, -1}, {30182, -1, -1, -1}, {30173, -1, -1, -1}, {30175, -1, -1, -1}, {30180, -1, -1, -1}, {30167, -1, -1, -1}, {30357, -1, -1, -1}, {30354, -1, -1, -1}, {30426, -1, -1, -1}, {30534, -1, -1, -1}, {30535, -1, -1, -1}, {30532, -1, -1, -1}, {30541, -1, -1, -1}, {30533, -1, -1, -1}, {30538, -1, -1, -1}, {30542, -1, -1, -1}, {30539, -1, -1, -1}, {30540, -1, -1, -1}, {30686, -1, -1, -1}, {30700, -1, -1, -1}, {30816, -1, -1, -1}, {30820, -1, -1, -1}, {30821, -1, -1, -1}, {30812, -1, -1, -1}, {30829, -1, -1, -1}, {30833, -1, -1, -1}, {30826, -1, -1, -1}, {30830, -1, -1, -1}, {30832, -1, -1, -1}, {30825, -1, -1, -1}, {30824, -1, -1, -1}, {30814, -1, -1, -1}, {30818, -1, -1, -1}, {31092, -1, -1, -1}, {31091, -1, -1, -1}, {31090, -1, -1, -1}, {31088, -1, -1, -1}, {31234, -1, -1, -1}, {31242, -1, -1, -1}, {31235, -1, -1, -1}, {31244, -1, -1, -1}, {31236, -1, -1, -1}, {31385, -1, -1, -1}, {31462, -1, -1, -1}, {31460, -1, -1, -1}, {31562, -1, -1, -1}, {31559, -1, -1, -1}, {31556, -1, -1, -1}, {31560, -1, -1, -1}, {31564, -1, -1, -1}, {31566, -1, -1, -1}, {31552, -1, -1, -1}, {31576, -1, -1, -1}, {31557, -1, -1, -1}, {31906, -1, -1, -1}, {31902, -1, -1, -1}, {31912, -1, -1, -1}, {31905, -1, -1, -1}, {32088, -1, -1, -1}, {32111, -1, -1, -1}, {32099, -1, -1, -1}, {32083, -1, -1, -1}, {32086, -1, -1, -1}, {32103, -1, -1, -1}, {32106, -1, -1, -1}, {32079, -1, -1, -1}, {32109, -1, -1, -1}, {32092, -1, -1, -1}, {32107, -1, -1, -1}, {32082, -1, -1, -1}, {32084, -1, -1, -1}, {32105, -1, -1, -1}, {32081, -1, -1, -1}, {32095, -1, -1, -1}, {32078, -1, -1, -1}, {32574, -1, -1, -1}, {32575, -1, -1, -1}, {32613, -1, -1, -1}, {32614, -1, -1, -1}, {32674, -1, -1, -1}, {32672, -1, -1, -1}, {32673, -1, -1, -1}, {32727, -1, -1, -1}, {32849, -1, -1, -1}, {32847, -1, -1, -1}, {32848, -1, -1, -1}, {33022, -1, -1, -1}, {32980, -1, -1, -1}, {33091, -1, -1, -1}, {33098, -1, -1, -1}, {33106, -1, -1, -1}, {33103, -1, -1, -1}, {33095, -1, -1, -1}, {33085, -1, -1, -1}, {33101, -1, -1, -1}, {33082, -1, -1, -1}, {33254, -1, -1, -1}, {33262, -1, -1, -1}, {33271, -1, -1, -1}, {33272, -1, -1, -1}, {33273, -1, -1, -1}, {33284, -1, -1, -1}, {33340, -1, -1, -1}, {33341, -1, -1, -1}, {33343, -1, -1, -1}, {33397, -1, -1, -1}, {33595, -1, -1, -1}, {33743, -1, -1, -1}, {33785, -1, -1, -1}, {33827, -1, -1, -1}, {33728, -1, -1, -1}, {33768, -1, -1, -1}, {33810, -1, -1, -1}, {33767, -1, -1, -1}, {33764, -1, -1, -1}, {33788, -1, -1, -1}, {33782, -1, -1, -1}, {33808, -1, -1, -1}, {33734, -1, -1, -1}, {33736, -1, -1, -1}, {33771, -1, -1, -1}, {33763, -1, -1, -1}, {33727, -1, -1, -1}, {33793, -1, -1, -1}, {33757, -1, -1, -1}, {33765, -1, -1, -1}, {33752, -1, -1, -1}, {33791, -1, -1, -1}, {33761, -1, -1, -1}, {33739, -1, -1, -1}, {33742, -1, -1, -1}, {33750, -1, -1, -1}, {33781, -1, -1, -1}, {33737, -1, -1, -1}, {33801, -1, -1, -1}, {33807, -1, -1, -1}, {33758, -1, -1, -1}, {33809, -1, -1, -1}, {33798, -1, -1, -1}, {33730, -1, -1, -1}, {33779, -1, -1, -1}, {33749, -1, -1, -1}, {33786, -1, -1, -1}, {33735, -1, -1, -1}, {33745, -1, -1, -1}, {33770, -1, -1, -1}, {33811, -1, -1, -1}, {33690, -1, -1, -1}, {33731, -1, -1, -1}, {33772, -1, -1, -1}, {33774, -1, -1, -1}, {33732, -1, -1, -1}, {33787, -1, -1, -1}, {33751, -1, -1, -1}, {33762, -1, -1, -1}, {33819, -1, -1, -1}, {33755, -1, -1, -1}, {33790, -1, -1, -1}, {34520, -1, -1, -1}, {34530, -1, -1, -1}, {34534, -1, -1, -1}, {34515, -1, -1, -1}, {34531, -1, -1, -1}, {34522, -1, -1, -1}, {34538, -1, -1, -1}, {34525, -1, -1, -1}, {34539, -1, -1, -1}, {34524, -1, -1, -1}, {34540, -1, -1, -1}, {34537, -1, -1, -1}, {34519, -1, -1, -1}, {34536, -1, -1, -1}, {34513, -1, -1, -1}, {34888, -1, -1, -1}, {34902, -1, -1, -1}, {34901, -1, -1, -1}, {35002, -1, -1, -1}, {35031, -1, -1, -1}, {35001, -1, -1, -1}, {35000, -1, -1, -1}, {35008, -1, -1, -1}, {35006, -1, -1, -1}, {34998, -1, -1, -1}, {35004, -1, -1, -1}, {34999, -1, -1, -1}, {35005, -1, -1, -1}, {34994, -1, -1, -1}, {35073, -1, -1, -1}, {35017, -1, -1, -1}, {35221, -1, -1, -1}, {35224, -1, -1, -1}, {35223, -1, -1, -1}, {35293, -1, -1, -1}, {35290, -1, -1, -1}, {35291, -1, -1, -1}, {35406, -1, -1, -1}, {35405, -1, -1, -1}, {35385, -1, -1, -1}, {35417, -1, -1, -1}, {35392, -1, -1, -1}, {35415, -1, -1, -1}, {35416, -1, -1, -1}, {35396, -1, -1, -1}, {35397, -1, -1, -1}, {35410, -1, -1, -1}, {35400, -1, -1, -1}, {35409, -1, -1, -1}, {35402, -1, -1, -1}, {35404, -1, -1, -1}, {35407, -1, -1, -1}, {35935, -1, -1, -1}, {35969, -1, -1, -1}, {35968, -1, -1, -1}, {36026, -1, -1, -1}, {36030, -1, -1, -1}, {36016, -1, -1, -1}, {36025, -1, -1, -1}, {36021, -1, -1, -1} },
+ {{36228, -1, -1, -1}, {36224, -1, -1, -1}, {36233, -1, -1, -1}, {36312, -1, -1, -1}, {36307, -1, -1, -1}, {36301, -1, -1, -1}, {36295, -1, -1, -1}, {36310, -1, -1, -1}, {36316, -1, -1, -1}, {36303, -1, -1, -1}, {36309, -1, -1, -1}, {36313, -1, -1, -1}, {36296, -1, -1, -1}, {36311, -1, -1, -1}, {36293, -1, -1, -1}, {36591, -1, -1, -1}, {36599, -1, -1, -1}, {36602, -1, -1, -1}, {36601, -1, -1, -1}, {36582, -1, -1, -1}, {36590, -1, -1, -1}, {36581, -1, -1, -1}, {36597, -1, -1, -1}, {36583, -1, -1, -1}, {36584, -1, -1, -1}, {36598, -1, -1, -1}, {36587, -1, -1, -1}, {36593, -1, -1, -1}, {36588, -1, -1, -1}, {36596, -1, -1, -1}, {36585, -1, -1, -1}, {36909, -1, -1, -1}, {36916, -1, -1, -1}, {36911, -1, -1, -1}, {37126, -1, -1, -1}, {37164, -1, -1, -1}, {37124, -1, -1, -1}, {37119, -1, -1, -1}, {37116, -1, -1, -1}, {37128, -1, -1, -1}, {37113, -1, -1, -1}, {37115, -1, -1, -1}, {37121, -1, -1, -1}, {37120, -1, -1, -1}, {37127, -1, -1, -1}, {37125, -1, -1, -1}, {37123, -1, -1, -1}, {37217, -1, -1, -1}, {37220, -1, -1, -1}, {37215, -1, -1, -1}, {37218, -1, -1, -1}, {37216, -1, -1, -1}, {37377, -1, -1, -1}, {37386, -1, -1, -1}, {37413, -1, -1, -1}, {37379, -1, -1, -1}, {37402, -1, -1, -1}, {37414, -1, -1, -1}, {37391, -1, -1, -1}, {37388, -1, -1, -1}, {37376, -1, -1, -1}, {37394, -1, -1, -1}, {37375, -1, -1, -1}, {37373, -1, -1, -1}, {37382, -1, -1, -1}, {37380, -1, -1, -1}, {37415, -1, -1, -1}, {37378, -1, -1, -1}, {37404, -1, -1, -1}, {37412, -1, -1, -1}, {37401, -1, -1, -1}, {37399, -1, -1, -1}, {37381, -1, -1, -1}, {37398, -1, -1, -1}, {38267, -1, -1, -1}, {38285, -1, -1, -1}, {38284, -1, -1, -1}, {38288, -1, -1, -1}, {38535, -1, -1, -1}, {38526, -1, -1, -1}, {38536, -1, -1, -1}, {38537, -1, -1, -1}, {38531, -1, -1, -1}, {38528, -1, -1, -1}, {38594, -1, -1, -1}, {38600, -1, -1, -1}, {38595, -1, -1, -1}, {38641, -1, -1, -1}, {38640, -1, -1, -1}, {38764, -1, -1, -1}, {38768, -1, -1, -1}, {38766, -1, -1, -1}, {38919, -1, -1, -1}, {39081, -1, -1, -1}, {39147, -1, -1, -1}, {40166, -1, -1, -1}, {40697, -1, -1, -1}, {20099, -1, -1, -1}, {20100, -1, -1, -1}, {20150, -1, -1, -1}, {20669, -1, -1, -1}, {20671, -1, -1, -1}, {20678, -1, -1, -1}, {20654, -1, -1, -1}, {20676, -1, -1, -1}, {20682, -1, -1, -1}, {20660, -1, -1, -1}, {20680, -1, -1, -1}, {20674, -1, -1, -1}, {20656, -1, -1, -1}, {20673, -1, -1, -1}, {20666, -1, -1, -1}, {20657, -1, -1, -1}, {20683, -1, -1, -1}, {20681, -1, -1, -1}, {20662, -1, -1, -1}, {20664, -1, -1, -1}, {20951, -1, -1, -1}, {21114, -1, -1, -1}, {21112, -1, -1, -1}, {21115, -1, -1, -1}, {21116, -1, -1, -1}, {21955, -1, -1, -1}, {21979, -1, -1, -1}, {21964, -1, -1, -1}, {21968, -1, -1, -1}, {21963, -1, -1, -1}, {21962, -1, -1, -1}, {21981, -1, -1, -1}, {21952, 64013, -1, -1}, {21972, -1, -1, -1}, {21956, -1, -1, -1}, {21993, -1, -1, -1}, {21951, -1, -1, -1}, {21970, -1, -1, -1}, {21901, -1, -1, -1}, {21967, -1, -1, -1}, {21973, -1, -1, -1}, {21986, -1, -1, -1}, {21974, -1, -1, -1}, {21960, -1, -1, -1}, {22002, -1, -1, -1}, {21965, -1, -1, -1}, {21977, -1, -1, -1}, {21954, -1, -1, -1}, {22292, -1, -1, -1}, {22611, -1, -1, -1}, {22632, -1, -1, -1}, {22628, -1, -1, -1}, {22607, -1, -1, -1}, {22605, -1, -1, -1}, {22601, -1, -1, -1}, {22639, -1, -1, -1}, {22613, -1, -1, -1}, {22606, -1, -1, -1}, {22621, -1, -1, -1}, {22617, -1, -1, -1}, {22629, -1, -1, -1}, {22619, -1, -1, -1}, {22589, -1, -1, -1}, {22627, -1, -1, -1}, {22641, -1, -1, -1}, {22780, -1, -1, -1}, {23239, -1, -1, -1}, {23236, -1, -1, -1}, {23243, -1, -1, -1}, {23226, -1, -1, -1}, {23224, -1, -1, -1}, {23217, -1, -1, -1}, {23221, -1, -1, -1}, {23216, -1, -1, -1}, {23231, -1, -1, -1}, {23240, -1, -1, -1}, {23227, -1, -1, -1}, {23238, -1, -1, -1}, {23223, -1, -1, -1}, {23232, -1, -1, -1}, {23242, -1, -1, -1}, {23220, -1, -1, -1}, {23222, -1, -1, -1}, {23245, -1, -1, -1}, {23225, -1, -1, -1}, {23184, -1, -1, -1}, {23510, -1, -1, -1}, {23512, -1, -1, -1}, {23513, -1, -1, -1}, {23583, -1, -1, -1}, {23603, -1, -1, -1}, {23921, -1, -1, -1}, {23907, -1, -1, -1}, {23882, -1, -1, -1}, {23909, -1, -1, -1}, {23922, -1, -1, -1}, {23916, -1, -1, -1}, {23902, -1, -1, -1}, {23912, -1, -1, -1}, {23911, -1, -1, -1}, {23906, -1, -1, -1}, {24048, -1, -1, -1}, {24143, -1, -1, -1}, {24142, -1, -1, -1}, {24138, -1, -1, -1}, {24141, -1, -1, -1}, {24139, -1, -1, -1}, {24261, -1, -1, -1}, {24268, -1, -1, -1}, {24262, -1, -1, -1}, {24267, -1, -1, -1}, {24263, -1, -1, -1}, {24384, -1, -1, -1}, {24495, -1, -1, -1}, {24493, -1, -1, -1}, {24823, -1, -1, -1}, {24905, -1, -1, -1}, {24906, -1, -1, -1}, {24875, -1, -1, -1}, {24901, -1, -1, -1}, {24886, -1, -1, -1}, {24882, -1, -1, -1}, {24878, -1, -1, -1}, {24902, -1, -1, -1}, {24879, -1, -1, -1}, {24911, -1, -1, -1}, {24873, -1, -1, -1}, {24896, -1, -1, -1}, {25120, -1, -1, -1}, {37224, -1, -1, -1}, {25123, -1, -1, -1}, {25125, -1, -1, -1}, {25124, -1, -1, -1}, {25541, -1, -1, -1}, {25585, -1, -1, -1}, {25579, -1, -1, -1}, {25616, -1, -1, -1}, {25618, -1, -1, -1}, {25609, -1, -1, -1}, {25632, -1, -1, -1}, {25636, -1, -1, -1}, {25651, -1, -1, -1}, {25667, -1, -1, -1}, {25631, -1, -1, -1}, {25621, -1, -1, -1}, {25624, -1, -1, -1}, {25657, -1, -1, -1}, {25655, -1, -1, -1}, {25634, -1, -1, -1}, {25635, -1, -1, -1}, {25612, -1, -1, -1}, {25638, -1, -1, -1}, {25648, -1, -1, -1}, {25640, -1, -1, -1}, {25665, -1, -1, -1}, {25653, -1, -1, -1}, {25647, -1, -1, -1}, {25610, -1, -1, -1}, {25626, -1, -1, -1} },
+ {{25664, -1, -1, -1}, {25637, -1, -1, -1}, {25639, -1, -1, -1}, {25611, -1, -1, -1}, {25575, -1, -1, -1}, {25627, -1, -1, -1}, {25646, -1, -1, -1}, {25633, -1, -1, -1}, {25614, -1, -1, -1}, {25967, -1, -1, -1}, {26002, -1, -1, -1}, {26067, -1, -1, -1}, {26246, -1, -1, -1}, {26252, -1, -1, -1}, {26261, -1, -1, -1}, {26256, -1, -1, -1}, {26251, -1, -1, -1}, {26250, -1, -1, -1}, {26265, -1, -1, -1}, {26260, -1, -1, -1}, {26232, -1, -1, -1}, {26400, -1, -1, -1}, {26982, -1, -1, -1}, {26975, -1, -1, -1}, {26936, -1, -1, -1}, {26958, -1, -1, -1}, {26978, -1, -1, -1}, {26993, -1, -1, -1}, {26943, -1, -1, -1}, {26949, -1, -1, -1}, {26986, -1, -1, -1}, {26937, -1, -1, -1}, {26946, -1, -1, -1}, {26967, -1, -1, -1}, {26969, -1, -1, -1}, {27002, -1, -1, -1}, {26952, -1, -1, -1}, {26953, -1, -1, -1}, {26933, -1, -1, -1}, {26988, -1, -1, -1}, {26931, -1, -1, -1}, {26941, -1, -1, -1}, {26981, -1, -1, -1}, {26864, -1, -1, -1}, {27000, -1, -1, -1}, {26932, -1, -1, -1}, {26985, -1, -1, -1}, {26944, -1, -1, -1}, {26991, -1, -1, -1}, {26948, -1, -1, -1}, {26998, -1, -1, -1}, {26968, -1, -1, -1}, {26945, -1, -1, -1}, {26996, -1, -1, -1}, {26956, -1, -1, -1}, {26939, -1, -1, -1}, {26955, -1, -1, -1}, {26935, -1, -1, -1}, {26972, -1, -1, -1}, {26959, -1, -1, -1}, {26961, -1, -1, -1}, {26930, -1, -1, -1}, {26962, -1, -1, -1}, {26927, -1, -1, -1}, {27003, -1, -1, -1}, {26940, -1, -1, -1}, {27462, -1, -1, -1}, {27461, -1, -1, -1}, {27459, -1, -1, -1}, {27458, -1, -1, -1}, {27464, -1, -1, -1}, {27457, -1, -1, -1}, {27547, -1, -1, -1}, {27643, -1, -1, -1}, {27644, -1, -1, -1}, {27641, -1, -1, -1}, {27639, -1, -1, -1}, {27640, -1, -1, -1}, {28315, -1, -1, -1}, {28374, -1, -1, -1}, {28360, -1, -1, -1}, {28303, -1, -1, -1}, {28352, -1, -1, -1}, {28319, -1, -1, -1}, {28307, -1, -1, -1}, {28308, -1, -1, -1}, {28320, -1, -1, -1}, {28337, -1, -1, -1}, {28345, -1, -1, -1}, {28358, -1, -1, -1}, {28370, -1, -1, -1}, {28349, -1, -1, -1}, {28353, -1, -1, -1}, {28318, -1, -1, -1}, {28361, -1, -1, -1}, {28343, -1, -1, -1}, {28336, -1, -1, -1}, {28365, -1, -1, -1}, {28326, -1, -1, -1}, {28367, -1, -1, -1}, {28338, -1, -1, -1}, {28350, -1, -1, -1}, {28355, -1, -1, -1}, {28380, -1, -1, -1}, {28376, -1, -1, -1}, {28313, -1, -1, -1}, {28306, -1, -1, -1}, {28302, -1, -1, -1}, {28301, -1, -1, -1}, {28324, -1, -1, -1}, {28321, -1, -1, -1}, {28351, -1, -1, -1}, {28339, -1, -1, -1}, {28368, -1, -1, -1}, {28362, -1, -1, -1}, {28311, -1, -1, -1}, {28334, -1, -1, -1}, {28323, -1, -1, -1}, {28999, -1, -1, -1}, {29012, -1, -1, -1}, {29010, -1, -1, -1}, {29027, -1, -1, -1}, {29024, -1, -1, -1}, {28993, -1, -1, -1}, {29021, -1, -1, -1}, {29026, -1, -1, -1}, {29042, -1, -1, -1}, {29048, -1, -1, -1}, {29034, -1, -1, -1}, {29025, -1, -1, -1}, {28994, -1, -1, -1}, {29016, -1, -1, -1}, {28995, -1, -1, -1}, {29003, -1, -1, -1}, {29040, -1, -1, -1}, {29023, -1, -1, -1}, {29008, -1, -1, -1}, {29011, -1, -1, -1}, {28996, -1, -1, -1}, {29005, -1, -1, -1}, {29018, -1, -1, -1}, {29263, -1, -1, -1}, {29325, -1, -1, -1}, {29324, -1, -1, -1}, {29329, -1, -1, -1}, {29328, -1, -1, -1}, {29326, -1, -1, -1}, {29500, -1, -1, -1}, {29506, -1, -1, -1}, {29499, -1, -1, -1}, {29498, -1, -1, -1}, {29504, -1, -1, -1}, {29514, -1, -1, -1}, {29513, -1, -1, -1}, {29764, -1, -1, -1}, {29770, -1, -1, -1}, {29771, -1, -1, -1}, {29778, -1, -1, -1}, {29777, -1, -1, -1}, {29783, -1, -1, -1}, {29760, -1, -1, -1}, {29775, -1, -1, -1}, {29776, -1, -1, -1}, {29774, -1, -1, -1}, {29762, -1, -1, -1}, {29766, -1, -1, -1}, {29773, -1, -1, -1}, {29780, -1, -1, -1}, {29921, -1, -1, -1}, {29951, -1, -1, -1}, {29950, -1, -1, -1}, {29949, -1, -1, -1}, {29981, -1, -1, -1}, {30073, -1, -1, -1}, {30071, -1, -1, -1}, {27011, -1, -1, -1}, {30191, -1, -1, -1}, {30223, -1, -1, -1}, {30211, -1, -1, -1}, {30199, -1, -1, -1}, {30206, -1, -1, -1}, {30204, -1, -1, -1}, {30201, -1, -1, -1}, {30200, -1, -1, -1}, {30224, -1, -1, -1}, {30203, -1, -1, -1}, {30198, -1, -1, -1}, {30189, -1, -1, -1}, {30197, -1, -1, -1}, {30205, -1, -1, -1}, {30361, -1, -1, -1}, {30389, -1, -1, -1}, {30429, -1, -1, -1}, {30549, -1, -1, -1}, {30559, -1, -1, -1}, {30560, -1, -1, -1}, {30546, -1, -1, -1}, {30550, -1, -1, -1}, {30554, -1, -1, -1}, {30569, -1, -1, -1}, {30567, -1, -1, -1}, {30548, -1, -1, -1}, {30553, -1, -1, -1}, {30573, -1, -1, -1}, {30688, -1, -1, -1}, {30855, -1, -1, -1}, {30874, -1, -1, -1}, {30868, -1, -1, -1}, {30863, -1, -1, -1}, {30852, -1, -1, -1}, {30869, -1, -1, -1}, {30853, -1, -1, -1}, {30854, -1, -1, -1}, {30881, -1, -1, -1}, {30851, -1, -1, -1}, {30841, -1, -1, -1}, {30873, -1, -1, -1}, {30848, -1, -1, -1}, {30870, -1, -1, -1}, {30843, -1, -1, -1}, {31100, -1, -1, -1}, {31106, -1, -1, -1}, {31101, -1, -1, -1}, {31097, -1, -1, -1}, {31249, -1, -1, -1}, {31256, -1, -1, -1}, {31257, -1, -1, -1}, {31250, -1, -1, -1}, {31255, -1, -1, -1}, {31253, -1, -1, -1}, {31266, -1, -1, -1}, {31251, -1, -1, -1}, {31259, -1, -1, -1}, {31248, -1, -1, -1}, {31395, -1, -1, -1}, {31394, -1, -1, -1}, {31390, -1, -1, -1}, {31467, -1, -1, -1}, {31590, -1, -1, -1}, {31588, -1, -1, -1}, {31597, -1, -1, -1}, {31604, -1, -1, -1}, {31593, -1, -1, -1}, {31602, -1, -1, -1}, {31589, -1, -1, -1}, {31603, -1, -1, -1}, {31601, -1, -1, -1}, {31600, -1, -1, -1}, {31585, -1, -1, -1}, {31608, -1, -1, -1}, {31606, -1, -1, -1}, {31587, -1, -1, -1}, {31922, -1, -1, -1}, {31924, -1, -1, -1}, {31919, -1, -1, -1}, {32136, -1, -1, -1} },
+ {{32134, -1, -1, -1}, {32128, -1, -1, -1}, {32141, -1, -1, -1}, {32127, -1, -1, -1}, {32133, -1, -1, -1}, {32122, -1, -1, -1}, {32142, -1, -1, -1}, {32123, -1, -1, -1}, {32131, -1, -1, -1}, {32124, -1, -1, -1}, {32140, -1, -1, -1}, {32148, -1, -1, -1}, {32132, -1, -1, -1}, {32125, -1, -1, -1}, {32146, -1, -1, -1}, {32621, -1, -1, -1}, {32619, -1, -1, -1}, {32615, -1, -1, -1}, {32616, -1, -1, -1}, {32620, -1, -1, -1}, {32678, -1, -1, -1}, {32677, -1, -1, -1}, {32679, -1, -1, -1}, {32731, -1, -1, -1}, {32732, -1, -1, -1}, {32801, -1, -1, -1}, {33124, -1, -1, -1}, {33120, -1, -1, -1}, {33143, -1, -1, -1}, {33116, -1, -1, -1}, {33129, -1, -1, -1}, {33115, -1, -1, -1}, {33122, -1, -1, -1}, {33138, -1, -1, -1}, {26401, -1, -1, -1}, {33118, -1, -1, -1}, {33142, -1, -1, -1}, {33127, -1, -1, -1}, {33135, -1, -1, -1}, {33092, -1, -1, -1}, {33121, -1, -1, -1}, {33309, -1, -1, -1}, {33353, -1, -1, -1}, {33348, -1, -1, -1}, {33344, -1, -1, -1}, {33346, -1, -1, -1}, {33349, -1, -1, -1}, {34033, -1, -1, -1}, {33855, -1, -1, -1}, {33878, -1, -1, -1}, {33910, -1, -1, -1}, {33913, -1, -1, -1}, {33935, -1, -1, -1}, {33933, -1, -1, -1}, {33893, -1, -1, -1}, {33873, -1, -1, -1}, {33856, -1, -1, -1}, {33926, -1, -1, -1}, {33895, -1, -1, -1}, {33840, -1, -1, -1}, {33869, -1, -1, -1}, {33917, -1, -1, -1}, {33882, -1, -1, -1}, {33881, -1, -1, -1}, {33908, -1, -1, -1}, {33907, -1, -1, -1}, {33885, -1, -1, -1}, {34055, -1, -1, -1}, {33886, -1, -1, -1}, {33847, -1, -1, -1}, {33850, -1, -1, -1}, {33844, -1, -1, -1}, {33914, -1, -1, -1}, {33859, -1, -1, -1}, {33912, -1, -1, -1}, {33842, -1, -1, -1}, {33861, -1, -1, -1}, {33833, -1, -1, -1}, {33753, -1, -1, -1}, {33867, -1, -1, -1}, {33839, -1, -1, -1}, {33858, -1, -1, -1}, {33837, -1, -1, -1}, {33887, -1, -1, -1}, {33904, -1, -1, -1}, {33849, -1, -1, -1}, {33870, -1, -1, -1}, {33868, -1, -1, -1}, {33874, -1, -1, -1}, {33903, -1, -1, -1}, {33989, -1, -1, -1}, {33934, -1, -1, -1}, {33851, -1, -1, -1}, {33863, -1, -1, -1}, {33846, -1, -1, -1}, {33843, -1, -1, -1}, {33896, -1, -1, -1}, {33918, -1, -1, -1}, {33860, -1, -1, -1}, {33835, -1, -1, -1}, {33888, -1, -1, -1}, {33876, -1, -1, -1}, {33902, -1, -1, -1}, {33872, -1, -1, -1}, {34571, -1, -1, -1}, {34564, -1, -1, -1}, {34551, -1, -1, -1}, {34572, -1, -1, -1}, {34554, -1, -1, -1}, {34518, -1, -1, -1}, {34549, -1, -1, -1}, {34637, -1, -1, -1}, {34552, -1, -1, -1}, {34574, -1, -1, -1}, {34569, -1, -1, -1}, {34561, -1, -1, -1}, {34550, -1, -1, -1}, {34573, -1, -1, -1}, {34565, -1, -1, -1}, {35030, -1, -1, -1}, {35019, -1, -1, -1}, {35021, -1, -1, -1}, {35022, -1, -1, -1}, {35038, -1, -1, -1}, {35035, -1, -1, -1}, {35034, -1, -1, -1}, {35020, -1, -1, -1}, {35024, -1, -1, -1}, {35205, -1, -1, -1}, {35227, -1, -1, -1}, {35295, -1, -1, -1}, {35301, -1, -1, -1}, {35300, -1, -1, -1}, {35297, -1, -1, -1}, {35296, -1, -1, -1}, {35298, -1, -1, -1}, {35292, -1, -1, -1}, {35302, -1, -1, -1}, {35446, -1, -1, -1}, {35462, -1, -1, -1}, {35455, -1, -1, -1}, {35425, -1, -1, -1}, {35391, -1, -1, -1}, {35447, -1, -1, -1}, {35458, -1, -1, -1}, {35460, -1, -1, -1}, {35445, -1, -1, -1}, {35459, -1, -1, -1}, {35457, -1, -1, -1}, {35444, -1, -1, -1}, {35450, -1, -1, -1}, {35900, -1, -1, -1}, {35915, -1, -1, -1}, {35914, -1, -1, -1}, {35941, -1, -1, -1}, {35940, -1, -1, -1}, {35942, -1, -1, -1}, {35974, -1, -1, -1}, {35972, -1, -1, -1}, {35973, -1, -1, -1}, {36044, -1, -1, -1}, {36200, -1, -1, -1}, {36201, -1, -1, -1}, {36241, -1, -1, -1}, {36236, -1, -1, -1}, {36238, -1, -1, -1}, {36239, -1, -1, -1}, {36237, -1, -1, -1}, {36243, -1, -1, -1}, {36244, -1, -1, -1}, {36240, -1, -1, -1}, {36242, -1, -1, -1}, {36336, -1, -1, -1}, {36320, -1, -1, -1}, {36332, -1, -1, -1}, {36337, -1, -1, -1}, {36334, -1, -1, -1}, {36304, -1, -1, -1}, {36329, -1, -1, -1}, {36323, -1, -1, -1}, {36322, -1, -1, -1}, {36327, -1, -1, -1}, {36338, -1, -1, -1}, {36331, -1, -1, -1}, {36340, -1, -1, -1}, {36614, -1, -1, -1}, {36607, -1, -1, -1}, {36609, -1, -1, -1}, {36608, -1, -1, -1}, {36613, -1, -1, -1}, {36615, -1, -1, -1}, {36616, -1, -1, -1}, {36610, -1, -1, -1}, {36619, -1, -1, -1}, {36946, -1, -1, -1}, {36927, -1, -1, -1}, {36932, -1, -1, -1}, {36937, -1, -1, -1}, {36925, -1, -1, -1}, {37136, -1, -1, -1}, {37133, -1, -1, -1}, {37135, -1, -1, -1}, {37137, -1, -1, -1}, {37142, -1, -1, -1}, {37140, -1, -1, -1}, {37131, -1, -1, -1}, {37134, -1, -1, -1}, {37230, -1, -1, -1}, {37231, -1, -1, -1}, {37448, -1, -1, -1}, {37458, -1, -1, -1}, {37424, -1, -1, -1}, {37434, -1, -1, -1}, {37478, -1, -1, -1}, {37427, -1, -1, -1}, {37477, -1, -1, -1}, {37470, -1, -1, -1}, {37507, -1, -1, -1}, {37422, -1, -1, -1}, {37450, -1, -1, -1}, {37446, -1, -1, -1}, {37485, -1, -1, -1}, {37484, -1, -1, -1}, {37455, -1, -1, -1}, {37472, -1, -1, -1}, {37479, -1, -1, -1}, {37487, -1, -1, -1}, {37430, -1, -1, -1}, {37473, -1, -1, -1}, {37488, -1, -1, -1}, {37425, -1, -1, -1}, {37460, -1, -1, -1}, {37475, -1, -1, -1}, {37456, -1, -1, -1}, {37490, -1, -1, -1}, {37454, -1, -1, -1}, {37459, -1, -1, -1}, {37452, -1, -1, -1}, {37462, -1, -1, -1}, {37426, -1, -1, -1}, {38303, -1, -1, -1}, {38300, -1, -1, -1}, {38302, -1, -1, -1}, {38299, -1, -1, -1}, {38546, -1, -1, -1}, {38547, -1, -1, -1}, {38545, -1, -1, -1}, {38551, -1, -1, -1}, {38606, -1, -1, -1}, {38650, -1, -1, -1}, {38653, -1, -1, -1}, {38648, -1, -1, -1}, {38645, -1, -1, -1}, {38771, -1, -1, -1}, {38775, -1, -1, -1}, {38776, -1, -1, -1} },
+ {{38770, -1, -1, -1}, {38927, -1, -1, -1}, {38925, -1, -1, -1}, {38926, -1, -1, -1}, {39084, -1, -1, -1}, {39158, -1, -1, -1}, {39161, -1, -1, -1}, {39343, -1, -1, -1}, {39346, -1, -1, -1}, {39344, -1, -1, -1}, {39349, -1, -1, -1}, {39597, -1, -1, -1}, {39595, -1, -1, -1}, {39771, -1, -1, -1}, {40170, -1, -1, -1}, {40173, -1, -1, -1}, {40167, -1, -1, -1}, {40576, -1, -1, -1}, {40701, -1, -1, -1}, {20710, -1, -1, -1}, {20692, -1, -1, -1}, {20695, -1, -1, -1}, {20712, -1, -1, -1}, {20723, -1, -1, -1}, {20699, -1, -1, -1}, {20714, -1, -1, -1}, {20701, -1, -1, -1}, {20708, -1, -1, -1}, {20691, -1, -1, -1}, {20716, -1, -1, -1}, {20720, -1, -1, -1}, {20719, -1, -1, -1}, {20707, -1, -1, -1}, {20704, -1, -1, -1}, {20952, -1, -1, -1}, {21120, -1, -1, -1}, {21121, -1, -1, -1}, {21225, -1, -1, -1}, {21227, -1, -1, -1}, {21296, -1, -1, -1}, {21420, -1, -1, -1}, {22055, -1, -1, -1}, {22037, -1, -1, -1}, {22028, -1, -1, -1}, {22034, -1, -1, -1}, {22012, -1, -1, -1}, {22031, -1, -1, -1}, {22044, -1, -1, -1}, {22017, -1, -1, -1}, {22035, -1, -1, -1}, {22018, -1, -1, -1}, {22010, -1, -1, -1}, {22045, -1, -1, -1}, {22020, -1, -1, -1}, {22015, -1, -1, -1}, {22009, -1, -1, -1}, {22665, -1, -1, -1}, {22652, -1, -1, -1}, {22672, -1, -1, -1}, {22680, -1, -1, -1}, {22662, -1, -1, -1}, {22657, -1, -1, -1}, {22655, -1, -1, -1}, {22644, -1, -1, -1}, {22667, -1, -1, -1}, {22650, -1, -1, -1}, {22663, -1, -1, -1}, {22673, -1, -1, -1}, {22670, -1, -1, -1}, {22646, -1, -1, -1}, {22658, -1, -1, -1}, {22664, -1, -1, -1}, {22651, -1, -1, -1}, {22676, -1, -1, -1}, {22671, -1, -1, -1}, {22782, -1, -1, -1}, {22891, -1, -1, -1}, {23260, -1, -1, -1}, {23278, -1, -1, -1}, {23269, -1, -1, -1}, {23253, -1, -1, -1}, {23274, -1, -1, -1}, {23258, -1, -1, -1}, {23277, -1, -1, -1}, {23275, -1, -1, -1}, {23283, -1, -1, -1}, {23266, -1, -1, -1}, {23264, -1, -1, -1}, {23259, -1, -1, -1}, {23276, -1, -1, -1}, {23262, -1, -1, -1}, {23261, -1, -1, -1}, {23257, -1, -1, -1}, {23272, -1, -1, -1}, {23263, -1, -1, -1}, {23415, -1, -1, -1}, {23520, -1, -1, -1}, {23523, -1, -1, -1}, {23651, -1, -1, -1}, {23938, -1, -1, -1}, {23936, -1, -1, -1}, {23933, -1, -1, -1}, {23942, -1, -1, -1}, {23930, -1, -1, -1}, {23937, -1, -1, -1}, {23927, -1, -1, -1}, {23946, -1, -1, -1}, {23945, -1, -1, -1}, {23944, -1, -1, -1}, {23934, -1, -1, -1}, {23932, -1, -1, -1}, {23949, -1, -1, -1}, {23929, -1, -1, -1}, {23935, -1, -1, -1}, {24152, -1, -1, -1}, {24153, -1, -1, -1}, {24147, -1, -1, -1}, {24280, -1, -1, -1}, {24273, -1, -1, -1}, {24279, -1, -1, -1}, {24270, -1, -1, -1}, {24284, -1, -1, -1}, {24277, -1, -1, -1}, {24281, -1, -1, -1}, {24274, -1, -1, -1}, {24276, -1, -1, -1}, {24388, -1, -1, -1}, {24387, -1, -1, -1}, {24431, -1, -1, -1}, {24502, -1, -1, -1}, {24876, -1, -1, -1}, {24872, -1, -1, -1}, {24897, -1, -1, -1}, {24926, -1, -1, -1}, {24945, -1, -1, -1}, {24947, -1, -1, -1}, {24914, -1, -1, -1}, {24915, -1, -1, -1}, {24946, -1, -1, -1}, {24940, -1, -1, -1}, {24960, -1, -1, -1}, {24948, -1, -1, -1}, {24916, -1, -1, -1}, {24954, -1, -1, -1}, {24923, -1, -1, -1}, {24933, -1, -1, -1}, {24891, -1, -1, -1}, {24938, -1, -1, -1}, {24929, -1, -1, -1}, {24918, -1, -1, -1}, {25129, -1, -1, -1}, {25127, -1, -1, -1}, {25131, -1, -1, -1}, {25643, -1, -1, -1}, {25677, -1, -1, -1}, {25691, -1, -1, -1}, {25693, -1, -1, -1}, {25716, -1, -1, -1}, {25718, -1, -1, -1}, {25714, -1, -1, -1}, {25715, -1, -1, -1}, {25725, -1, -1, -1}, {25717, -1, -1, -1}, {25702, -1, -1, -1}, {25766, -1, -1, -1}, {25678, -1, -1, -1}, {25730, -1, -1, -1}, {25694, -1, -1, -1}, {25692, -1, -1, -1}, {25675, -1, -1, -1}, {25683, -1, -1, -1}, {25696, -1, -1, -1}, {25680, -1, -1, -1}, {25727, -1, -1, -1}, {25663, -1, -1, -1}, {25708, -1, -1, -1}, {25707, -1, -1, -1}, {25689, -1, -1, -1}, {25701, -1, -1, -1}, {25719, -1, -1, -1}, {25971, -1, -1, -1}, {26016, -1, -1, -1}, {26273, -1, -1, -1}, {26272, -1, -1, -1}, {26271, -1, -1, -1}, {26373, -1, -1, -1}, {26372, -1, -1, -1}, {26402, -1, -1, -1}, {27057, -1, -1, -1}, {27062, -1, -1, -1}, {27081, -1, -1, -1}, {27040, -1, -1, -1}, {27086, -1, -1, -1}, {27030, -1, -1, -1}, {27056, -1, -1, -1}, {27052, -1, -1, -1}, {27068, -1, -1, -1}, {27025, -1, -1, -1}, {27033, -1, -1, -1}, {27022, -1, -1, -1}, {27047, -1, -1, -1}, {27021, -1, -1, -1}, {27049, -1, -1, -1}, {27070, -1, -1, -1}, {27055, -1, -1, -1}, {27071, -1, -1, -1}, {27076, -1, -1, -1}, {27069, -1, -1, -1}, {27044, -1, -1, -1}, {27092, -1, -1, -1}, {27065, -1, -1, -1}, {27082, -1, -1, -1}, {27034, -1, -1, -1}, {27087, -1, -1, -1}, {27059, -1, -1, -1}, {27027, -1, -1, -1}, {27050, -1, -1, -1}, {27041, -1, -1, -1}, {27038, -1, -1, -1}, {27097, -1, -1, -1}, {27031, -1, -1, -1}, {27024, -1, -1, -1}, {27074, -1, -1, -1}, {27061, -1, -1, -1}, {27045, -1, -1, -1}, {27078, -1, -1, -1}, {27466, -1, -1, -1}, {27469, -1, -1, -1}, {27467, -1, -1, -1}, {27550, -1, -1, -1}, {27551, -1, -1, -1}, {27552, -1, -1, -1}, {27587, -1, -1, -1}, {27588, -1, -1, -1}, {27646, -1, -1, -1}, {28366, -1, -1, -1}, {28405, -1, -1, -1}, {28401, -1, -1, -1}, {28419, -1, -1, -1}, {28453, -1, -1, -1}, {28408, -1, -1, -1}, {28471, -1, -1, -1}, {28411, -1, -1, -1}, {28462, -1, -1, -1}, {28425, -1, -1, -1}, {28494, -1, -1, -1}, {28441, -1, -1, -1}, {28442, -1, -1, -1}, {28455, -1, -1, -1}, {28440, -1, -1, -1}, {28475, -1, -1, -1}, {28434, -1, -1, -1}, {28397, -1, -1, -1}, {28426, -1, -1, -1}, {28470, -1, -1, -1}, {28531, -1, -1, -1} },
+ {{28409, -1, -1, -1}, {28398, -1, -1, -1}, {28461, -1, -1, -1}, {28480, -1, -1, -1}, {28464, -1, -1, -1}, {28476, -1, -1, -1}, {28469, -1, -1, -1}, {28395, -1, -1, -1}, {28423, -1, -1, -1}, {28430, -1, -1, -1}, {28483, -1, -1, -1}, {28421, -1, -1, -1}, {28413, -1, -1, -1}, {28406, -1, -1, -1}, {28473, -1, -1, -1}, {28444, -1, -1, -1}, {28412, -1, -1, -1}, {28474, -1, -1, -1}, {28447, -1, -1, -1}, {28429, -1, -1, -1}, {28446, -1, -1, -1}, {28424, -1, -1, -1}, {28449, -1, -1, -1}, {29063, -1, -1, -1}, {29072, -1, -1, -1}, {29065, -1, -1, -1}, {29056, -1, -1, -1}, {29061, -1, -1, -1}, {29058, -1, -1, -1}, {29071, -1, -1, -1}, {29051, -1, -1, -1}, {29062, -1, -1, -1}, {29057, -1, -1, -1}, {29079, -1, -1, -1}, {29252, -1, -1, -1}, {29267, -1, -1, -1}, {29335, -1, -1, -1}, {29333, -1, -1, -1}, {29331, -1, -1, -1}, {29507, -1, -1, -1}, {29517, -1, -1, -1}, {29521, -1, -1, -1}, {29516, -1, -1, -1}, {29794, -1, -1, -1}, {29811, -1, -1, -1}, {29809, -1, -1, -1}, {29813, -1, -1, -1}, {29810, -1, -1, -1}, {29799, -1, -1, -1}, {29806, -1, -1, -1}, {29952, -1, -1, -1}, {29954, -1, -1, -1}, {29955, -1, -1, -1}, {30077, -1, -1, -1}, {30096, -1, -1, -1}, {30230, -1, -1, -1}, {30216, -1, -1, -1}, {30220, -1, -1, -1}, {30229, -1, -1, -1}, {30225, -1, -1, -1}, {30218, -1, -1, -1}, {30228, -1, -1, -1}, {30392, -1, -1, -1}, {30593, -1, -1, -1}, {30588, -1, -1, -1}, {30597, -1, -1, -1}, {30594, -1, -1, -1}, {30574, -1, -1, -1}, {30592, -1, -1, -1}, {30575, -1, -1, -1}, {30590, -1, -1, -1}, {30595, -1, -1, -1}, {30898, -1, -1, -1}, {30890, -1, -1, -1}, {30900, -1, -1, -1}, {30893, -1, -1, -1}, {30888, -1, -1, -1}, {30846, -1, -1, -1}, {30891, -1, -1, -1}, {30878, -1, -1, -1}, {30885, -1, -1, -1}, {30880, -1, -1, -1}, {30892, -1, -1, -1}, {30882, -1, -1, -1}, {30884, -1, -1, -1}, {31128, -1, -1, -1}, {31114, -1, -1, -1}, {31115, -1, -1, -1}, {31126, -1, -1, -1}, {31125, -1, -1, -1}, {31124, -1, -1, -1}, {31123, -1, -1, -1}, {31127, -1, -1, -1}, {31112, -1, -1, -1}, {31122, -1, -1, -1}, {31120, -1, -1, -1}, {31275, -1, -1, -1}, {31306, -1, -1, -1}, {31280, -1, -1, -1}, {31279, -1, -1, -1}, {31272, -1, -1, -1}, {31270, -1, -1, -1}, {31400, -1, -1, -1}, {31403, -1, -1, -1}, {31404, -1, -1, -1}, {31470, -1, -1, -1}, {31624, -1, -1, -1}, {31644, -1, -1, -1}, {31626, -1, -1, -1}, {31633, -1, -1, -1}, {31632, -1, -1, -1}, {31638, -1, -1, -1}, {31629, -1, -1, -1}, {31628, -1, -1, -1}, {31643, -1, -1, -1}, {31630, -1, -1, -1}, {31621, -1, -1, -1}, {31640, -1, -1, -1}, {21124, -1, -1, -1}, {31641, -1, -1, -1}, {31652, -1, -1, -1}, {31618, -1, -1, -1}, {31931, -1, -1, -1}, {31935, -1, -1, -1}, {31932, -1, -1, -1}, {31930, -1, -1, -1}, {32167, -1, -1, -1}, {32183, -1, -1, -1}, {32194, -1, -1, -1}, {32163, -1, -1, -1}, {32170, -1, -1, -1}, {32193, -1, -1, -1}, {32192, -1, -1, -1}, {32197, -1, -1, -1}, {32157, -1, -1, -1}, {32206, -1, -1, -1}, {32196, -1, -1, -1}, {32198, -1, -1, -1}, {32203, -1, -1, -1}, {32204, -1, -1, -1}, {32175, -1, -1, -1}, {32185, -1, -1, -1}, {32150, -1, -1, -1}, {32188, -1, -1, -1}, {32159, -1, -1, -1}, {32166, -1, -1, -1}, {32174, -1, -1, -1}, {32169, -1, -1, -1}, {32161, -1, -1, -1}, {32201, -1, -1, -1}, {32627, -1, -1, -1}, {32738, -1, -1, -1}, {32739, -1, -1, -1}, {32741, -1, -1, -1}, {32734, -1, -1, -1}, {32804, -1, -1, -1}, {32861, -1, -1, -1}, {32860, -1, -1, -1}, {33161, -1, -1, -1}, {33158, -1, -1, -1}, {33155, -1, -1, -1}, {33159, -1, -1, -1}, {33165, -1, -1, -1}, {33164, -1, -1, -1}, {33163, -1, -1, -1}, {33301, -1, -1, -1}, {33943, -1, -1, -1}, {33956, -1, -1, -1}, {33953, -1, -1, -1}, {33951, -1, -1, -1}, {33978, -1, -1, -1}, {33998, -1, -1, -1}, {33986, -1, -1, -1}, {33964, -1, -1, -1}, {33966, -1, -1, -1}, {33963, -1, -1, -1}, {33977, -1, -1, -1}, {33972, -1, -1, -1}, {33985, -1, -1, -1}, {33997, -1, -1, -1}, {33962, -1, -1, -1}, {33946, -1, -1, -1}, {33969, -1, -1, -1}, {34000, -1, -1, -1}, {33949, -1, -1, -1}, {33959, -1, -1, -1}, {33979, -1, -1, -1}, {33954, -1, -1, -1}, {33940, -1, -1, -1}, {33991, -1, -1, -1}, {33996, -1, -1, -1}, {33947, -1, -1, -1}, {33961, -1, -1, -1}, {33967, -1, -1, -1}, {33960, -1, -1, -1}, {34006, -1, -1, -1}, {33944, -1, -1, -1}, {33974, -1, -1, -1}, {33999, -1, -1, -1}, {33952, -1, -1, -1}, {34007, -1, -1, -1}, {34004, -1, -1, -1}, {34002, -1, -1, -1}, {34011, -1, -1, -1}, {33968, -1, -1, -1}, {33937, -1, -1, -1}, {34401, -1, -1, -1}, {34611, -1, -1, -1}, {34595, -1, -1, -1}, {34600, -1, -1, -1}, {34667, -1, -1, -1}, {34624, -1, -1, -1}, {34606, -1, -1, -1}, {34590, -1, -1, -1}, {34593, -1, -1, -1}, {34585, -1, -1, -1}, {34587, -1, -1, -1}, {34627, -1, -1, -1}, {34604, -1, -1, -1}, {34625, -1, -1, -1}, {34622, -1, -1, -1}, {34630, -1, -1, -1}, {34592, -1, -1, -1}, {34610, -1, -1, -1}, {34602, -1, -1, -1}, {34605, -1, -1, -1}, {34620, -1, -1, -1}, {34578, -1, -1, -1}, {34618, -1, -1, -1}, {34609, -1, -1, -1}, {34613, -1, -1, -1}, {34626, -1, -1, -1}, {34598, -1, -1, -1}, {34599, -1, -1, -1}, {34616, -1, -1, -1}, {34596, -1, -1, -1}, {34586, -1, -1, -1}, {34608, -1, -1, -1}, {34577, -1, -1, -1}, {35063, -1, -1, -1}, {35047, -1, -1, -1}, {35057, -1, -1, -1}, {35058, -1, -1, -1}, {35066, -1, -1, -1}, {35070, -1, -1, -1}, {35054, -1, -1, -1}, {35068, -1, -1, -1}, {35062, -1, -1, -1}, {35067, -1, -1, -1}, {35056, -1, -1, -1}, {35052, -1, -1, -1}, {35051, -1, -1, -1}, {35229, -1, -1, -1}, {35233, -1, -1, -1}, {35231, -1, -1, -1}, {35230, -1, -1, -1} },
+ {{35305, -1, -1, -1}, {35307, -1, -1, -1}, {35304, -1, -1, -1}, {35499, -1, -1, -1}, {35481, -1, -1, -1}, {35467, -1, -1, -1}, {35474, -1, -1, -1}, {35471, -1, -1, -1}, {35478, -1, -1, -1}, {35901, -1, -1, -1}, {35944, -1, -1, -1}, {35945, -1, -1, -1}, {36053, -1, -1, -1}, {36047, -1, -1, -1}, {36055, -1, -1, -1}, {36246, -1, -1, -1}, {36361, -1, -1, -1}, {36354, -1, -1, -1}, {36351, -1, -1, -1}, {36365, -1, -1, -1}, {36349, -1, -1, -1}, {36362, -1, -1, -1}, {36355, -1, -1, -1}, {36359, -1, -1, -1}, {36358, -1, -1, -1}, {36357, -1, -1, -1}, {36350, -1, -1, -1}, {36352, -1, -1, -1}, {36356, -1, -1, -1}, {36624, -1, -1, -1}, {36625, -1, -1, -1}, {36622, -1, -1, -1}, {36621, -1, -1, -1}, {37155, -1, -1, -1}, {37148, -1, -1, -1}, {37152, -1, -1, -1}, {37154, -1, -1, -1}, {37151, -1, -1, -1}, {37149, -1, -1, -1}, {37146, -1, -1, -1}, {37156, -1, -1, -1}, {37153, -1, -1, -1}, {37147, -1, -1, -1}, {37242, -1, -1, -1}, {37234, -1, -1, -1}, {37241, -1, -1, -1}, {37235, -1, -1, -1}, {37541, -1, -1, -1}, {37540, -1, -1, -1}, {37494, -1, -1, -1}, {37531, -1, -1, -1}, {37498, -1, -1, -1}, {37536, -1, -1, -1}, {37524, -1, -1, -1}, {37546, -1, -1, -1}, {37517, -1, -1, -1}, {37542, -1, -1, -1}, {37530, -1, -1, -1}, {37547, -1, -1, -1}, {37497, -1, -1, -1}, {37527, -1, -1, -1}, {37503, -1, -1, -1}, {37539, -1, -1, -1}, {37614, -1, -1, -1}, {37518, -1, -1, -1}, {37506, -1, -1, -1}, {37525, -1, -1, -1}, {37538, -1, -1, -1}, {37501, -1, -1, -1}, {37512, -1, -1, -1}, {37537, -1, -1, -1}, {37514, -1, -1, -1}, {37510, -1, -1, -1}, {37516, -1, -1, -1}, {37529, -1, -1, -1}, {37543, -1, -1, -1}, {37502, -1, -1, -1}, {37511, -1, -1, -1}, {37545, -1, -1, -1}, {37533, -1, -1, -1}, {37515, -1, -1, -1}, {37421, -1, -1, -1}, {38558, -1, -1, -1}, {38561, -1, -1, -1}, {38655, -1, -1, -1}, {38744, -1, -1, -1}, {38781, -1, -1, -1}, {38778, -1, -1, -1}, {38782, -1, -1, -1}, {38787, -1, -1, -1}, {38784, -1, -1, -1}, {38786, -1, -1, -1}, {38779, -1, -1, -1}, {38788, -1, -1, -1}, {38785, -1, -1, -1}, {38783, -1, -1, -1}, {38862, -1, -1, -1}, {38861, -1, -1, -1}, {38934, -1, -1, -1}, {39085, -1, -1, -1}, {39086, -1, -1, -1}, {39170, -1, -1, -1}, {39168, -1, -1, -1}, {39175, -1, -1, -1}, {39325, -1, -1, -1}, {39324, -1, -1, -1}, {39363, -1, -1, -1}, {39353, -1, -1, -1}, {39355, -1, -1, -1}, {39354, -1, -1, -1}, {39362, -1, -1, -1}, {39357, -1, -1, -1}, {39367, -1, -1, -1}, {39601, -1, -1, -1}, {39651, -1, -1, -1}, {39655, -1, -1, -1}, {39742, -1, -1, -1}, {39743, -1, -1, -1}, {39776, -1, -1, -1}, {39777, -1, -1, -1}, {39775, -1, -1, -1}, {40177, -1, -1, -1}, {40178, -1, -1, -1}, {40181, -1, -1, -1}, {40615, -1, -1, -1}, {20735, -1, -1, -1}, {20739, -1, -1, -1}, {20784, -1, -1, -1}, {20728, -1, -1, -1}, {20742, -1, -1, -1}, {20743, -1, -1, -1}, {20726, -1, -1, -1}, {20734, -1, -1, -1}, {20747, -1, -1, -1}, {20748, -1, -1, -1}, {20733, -1, -1, -1}, {20746, -1, -1, -1}, {21131, -1, -1, -1}, {21132, -1, -1, -1}, {21233, -1, -1, -1}, {21231, -1, -1, -1}, {22088, -1, -1, -1}, {22082, -1, -1, -1}, {22092, -1, -1, -1}, {22069, -1, -1, -1}, {22081, -1, -1, -1}, {22090, -1, -1, -1}, {22089, -1, -1, -1}, {22086, -1, -1, -1}, {22104, -1, -1, -1}, {22106, -1, -1, -1}, {22080, -1, -1, -1}, {22067, -1, -1, -1}, {22077, -1, -1, -1}, {22060, -1, -1, -1}, {22078, -1, -1, -1}, {22072, -1, -1, -1}, {22058, -1, -1, -1}, {22074, -1, -1, -1}, {22298, -1, -1, -1}, {22699, -1, -1, -1}, {22685, -1, -1, -1}, {22705, -1, -1, -1}, {22688, -1, -1, -1}, {22691, -1, -1, -1}, {22703, -1, -1, -1}, {22700, -1, -1, -1}, {22693, -1, -1, -1}, {22689, -1, -1, -1}, {22783, -1, -1, -1}, {23295, -1, -1, -1}, {23284, -1, -1, -1}, {23293, -1, -1, -1}, {23287, -1, -1, -1}, {23286, -1, -1, -1}, {23299, -1, -1, -1}, {23288, -1, -1, -1}, {23298, -1, -1, -1}, {23289, -1, -1, -1}, {23297, -1, -1, -1}, {23303, -1, -1, -1}, {23301, -1, -1, -1}, {23311, -1, -1, -1}, {23655, -1, -1, -1}, {23961, -1, -1, -1}, {23959, -1, -1, -1}, {23967, -1, -1, -1}, {23954, -1, -1, -1}, {23970, -1, -1, -1}, {23955, -1, -1, -1}, {23957, -1, -1, -1}, {23968, -1, -1, -1}, {23964, -1, -1, -1}, {23969, -1, -1, -1}, {23962, -1, -1, -1}, {23966, -1, -1, -1}, {24169, -1, -1, -1}, {24157, -1, -1, -1}, {24160, -1, -1, -1}, {24156, -1, -1, -1}, {32243, -1, -1, -1}, {24283, -1, -1, -1}, {24286, -1, -1, -1}, {24289, -1, -1, -1}, {24393, -1, -1, -1}, {24498, -1, -1, -1}, {24971, -1, -1, -1}, {24963, -1, -1, -1}, {24953, -1, -1, -1}, {25009, -1, -1, -1}, {25008, -1, -1, -1}, {24994, -1, -1, -1}, {24969, -1, -1, -1}, {24987, -1, -1, -1}, {24979, -1, -1, -1}, {25007, -1, -1, -1}, {25005, -1, -1, -1}, {24991, -1, -1, -1}, {24978, -1, -1, -1}, {25002, -1, -1, -1}, {24993, -1, -1, -1}, {24973, -1, -1, -1}, {24934, -1, -1, -1}, {25011, -1, -1, -1}, {25133, -1, -1, -1}, {25710, -1, -1, -1}, {25712, -1, -1, -1}, {25750, -1, -1, -1}, {25760, -1, -1, -1}, {25733, -1, -1, -1}, {25751, -1, -1, -1}, {25756, -1, -1, -1}, {25743, -1, -1, -1}, {25739, -1, -1, -1}, {25738, -1, -1, -1}, {25740, -1, -1, -1}, {25763, -1, -1, -1}, {25759, -1, -1, -1}, {25704, -1, -1, -1}, {25777, -1, -1, -1}, {25752, -1, -1, -1}, {25974, -1, -1, -1}, {25978, -1, -1, -1}, {25977, -1, -1, -1}, {25979, -1, -1, -1}, {26034, -1, -1, -1}, {26035, -1, -1, -1}, {26293, -1, -1, -1}, {26288, -1, -1, -1}, {26281, -1, -1, -1}, {26290, -1, -1, -1}, {26295, -1, -1, -1}, {26282, -1, -1, -1}, {26287, -1, -1, -1}, {27136, -1, -1, -1}, {27142, -1, -1, -1} },
+ {{27159, -1, -1, -1}, {27109, -1, -1, -1}, {27128, -1, -1, -1}, {27157, -1, -1, -1}, {27121, -1, -1, -1}, {27108, -1, -1, -1}, {27168, -1, -1, -1}, {27135, -1, -1, -1}, {27116, -1, -1, -1}, {27106, -1, -1, -1}, {27163, -1, -1, -1}, {27165, -1, -1, -1}, {27134, -1, -1, -1}, {27175, -1, -1, -1}, {27122, -1, -1, -1}, {27118, -1, -1, -1}, {27156, -1, -1, -1}, {27127, -1, -1, -1}, {27111, -1, -1, -1}, {27200, -1, -1, -1}, {27144, -1, -1, -1}, {27110, -1, -1, -1}, {27131, -1, -1, -1}, {27149, -1, -1, -1}, {27132, -1, -1, -1}, {27115, -1, -1, -1}, {27145, -1, -1, -1}, {27140, -1, -1, -1}, {27160, -1, -1, -1}, {27173, -1, -1, -1}, {27151, -1, -1, -1}, {27126, -1, -1, -1}, {27174, -1, -1, -1}, {27143, -1, -1, -1}, {27124, -1, -1, -1}, {27158, -1, -1, -1}, {27473, -1, -1, -1}, {27557, -1, -1, -1}, {27555, -1, -1, -1}, {27554, -1, -1, -1}, {27558, -1, -1, -1}, {27649, -1, -1, -1}, {27648, -1, -1, -1}, {27647, -1, -1, -1}, {27650, -1, -1, -1}, {28481, -1, -1, -1}, {28454, -1, -1, -1}, {28542, -1, -1, -1}, {28551, -1, -1, -1}, {28614, -1, -1, -1}, {28562, -1, -1, -1}, {28557, -1, -1, -1}, {28553, -1, -1, -1}, {28556, -1, -1, -1}, {28514, -1, -1, -1}, {28495, -1, -1, -1}, {28549, -1, -1, -1}, {28506, -1, -1, -1}, {28566, -1, -1, -1}, {28534, -1, -1, -1}, {28524, -1, -1, -1}, {28546, -1, -1, -1}, {28501, -1, -1, -1}, {28530, -1, -1, -1}, {28498, -1, -1, -1}, {28496, -1, -1, -1}, {28503, -1, -1, -1}, {28564, -1, -1, -1}, {28563, -1, -1, -1}, {28509, -1, -1, -1}, {28416, -1, -1, -1}, {28513, -1, -1, -1}, {28523, -1, -1, -1}, {28541, -1, -1, -1}, {28519, -1, -1, -1}, {28560, -1, -1, -1}, {28499, -1, -1, -1}, {28555, -1, -1, -1}, {28521, -1, -1, -1}, {28543, -1, -1, -1}, {28565, -1, -1, -1}, {28515, -1, -1, -1}, {28535, -1, -1, -1}, {28522, -1, -1, -1}, {28539, -1, -1, -1}, {29106, -1, -1, -1}, {29103, -1, -1, -1}, {29083, -1, -1, -1}, {29104, -1, -1, -1}, {29088, -1, -1, -1}, {29082, -1, -1, -1}, {29097, -1, -1, -1}, {29109, -1, -1, -1}, {29085, -1, -1, -1}, {29093, -1, -1, -1}, {29086, -1, -1, -1}, {29092, -1, -1, -1}, {29089, -1, -1, -1}, {29098, -1, -1, -1}, {29084, -1, -1, -1}, {29095, -1, -1, -1}, {29107, -1, -1, -1}, {29336, -1, -1, -1}, {29338, -1, -1, -1}, {29528, -1, -1, -1}, {29522, -1, -1, -1}, {29534, -1, -1, -1}, {29535, -1, -1, -1}, {29536, -1, -1, -1}, {29533, -1, -1, -1}, {29531, -1, -1, -1}, {29537, -1, -1, -1}, {29530, -1, -1, -1}, {29529, -1, -1, -1}, {29538, -1, -1, -1}, {29831, -1, -1, -1}, {29833, -1, -1, -1}, {29834, -1, -1, -1}, {29830, -1, -1, -1}, {29825, -1, -1, -1}, {29821, -1, -1, -1}, {29829, -1, -1, -1}, {29832, -1, -1, -1}, {29820, -1, -1, -1}, {29817, -1, -1, -1}, {29960, -1, -1, -1}, {29959, -1, -1, -1}, {30078, -1, -1, -1}, {30245, -1, -1, -1}, {30238, -1, -1, -1}, {30233, -1, -1, -1}, {30237, -1, -1, -1}, {30236, -1, -1, -1}, {30243, -1, -1, -1}, {30234, -1, -1, -1}, {30248, -1, -1, -1}, {30235, -1, -1, -1}, {30364, -1, -1, -1}, {30365, -1, -1, -1}, {30366, -1, -1, -1}, {30363, -1, -1, -1}, {30605, -1, -1, -1}, {30607, -1, -1, -1}, {30601, -1, -1, -1}, {30600, -1, -1, -1}, {30925, -1, -1, -1}, {30907, -1, -1, -1}, {30927, -1, -1, -1}, {30924, -1, -1, -1}, {30929, -1, -1, -1}, {30926, -1, -1, -1}, {30932, -1, -1, -1}, {30920, -1, -1, -1}, {30915, -1, -1, -1}, {30916, -1, -1, -1}, {30921, -1, -1, -1}, {31130, -1, -1, -1}, {31137, -1, -1, -1}, {31136, -1, -1, -1}, {31132, -1, -1, -1}, {31138, -1, -1, -1}, {31131, -1, -1, -1}, {27510, -1, -1, -1}, {31289, -1, -1, -1}, {31410, -1, -1, -1}, {31412, -1, -1, -1}, {31411, -1, -1, -1}, {31671, -1, -1, -1}, {31691, -1, -1, -1}, {31678, -1, -1, -1}, {31660, -1, -1, -1}, {31694, -1, -1, -1}, {31663, -1, -1, -1}, {31673, -1, -1, -1}, {31690, -1, -1, -1}, {31669, -1, -1, -1}, {31941, -1, -1, -1}, {31944, -1, -1, -1}, {31948, -1, -1, -1}, {31947, -1, -1, -1}, {32247, -1, -1, -1}, {32219, -1, -1, -1}, {32234, -1, -1, -1}, {32231, -1, -1, -1}, {32215, -1, -1, -1}, {32225, -1, -1, -1}, {32259, -1, -1, -1}, {32250, -1, -1, -1}, {32230, -1, -1, -1}, {32246, -1, -1, -1}, {32241, -1, -1, -1}, {32240, -1, -1, -1}, {32238, -1, -1, -1}, {32223, -1, -1, -1}, {32630, -1, -1, -1}, {32684, -1, -1, -1}, {32688, -1, -1, -1}, {32685, -1, -1, -1}, {32749, -1, -1, -1}, {32747, -1, -1, -1}, {32746, -1, -1, -1}, {32748, -1, -1, -1}, {32742, -1, -1, -1}, {32744, -1, -1, -1}, {32868, -1, -1, -1}, {32871, -1, -1, -1}, {33187, -1, -1, -1}, {33183, -1, -1, -1}, {33182, -1, -1, -1}, {33173, -1, -1, -1}, {33186, -1, -1, -1}, {33177, -1, -1, -1}, {33175, -1, -1, -1}, {33302, -1, -1, -1}, {33359, -1, -1, -1}, {33363, -1, -1, -1}, {33362, -1, -1, -1}, {33360, -1, -1, -1}, {33358, -1, -1, -1}, {33361, -1, -1, -1}, {34084, -1, -1, -1}, {34107, -1, -1, -1}, {34063, -1, -1, -1}, {34048, -1, -1, -1}, {34089, -1, -1, -1}, {34062, -1, -1, -1}, {34057, -1, -1, -1}, {34061, -1, -1, -1}, {34079, -1, -1, -1}, {34058, -1, -1, -1}, {34087, -1, -1, -1}, {34076, -1, -1, -1}, {34043, -1, -1, -1}, {34091, -1, -1, -1}, {34042, -1, -1, -1}, {34056, -1, -1, -1}, {34060, -1, -1, -1}, {34036, -1, -1, -1}, {34090, -1, -1, -1}, {34034, -1, -1, -1}, {34069, -1, -1, -1}, {34039, -1, -1, -1}, {34027, -1, -1, -1}, {34035, -1, -1, -1}, {34044, -1, -1, -1}, {34066, -1, -1, -1}, {34026, -1, -1, -1}, {34025, -1, -1, -1}, {34070, -1, -1, -1}, {34046, -1, -1, -1}, {34088, -1, -1, -1}, {34077, -1, -1, -1}, {34094, -1, -1, -1}, {34050, -1, -1, -1}, {34045, -1, -1, -1}, {34078, -1, -1, -1} },
+ {{34038, -1, -1, -1}, {34097, -1, -1, -1}, {34086, -1, -1, -1}, {34023, -1, -1, -1}, {34024, -1, -1, -1}, {34032, -1, -1, -1}, {34031, -1, -1, -1}, {34041, -1, -1, -1}, {34072, -1, -1, -1}, {34080, -1, -1, -1}, {34096, -1, -1, -1}, {34059, -1, -1, -1}, {34073, -1, -1, -1}, {34095, -1, -1, -1}, {34402, -1, -1, -1}, {34646, -1, -1, -1}, {34659, -1, -1, -1}, {34660, -1, -1, -1}, {34679, -1, -1, -1}, {34785, -1, -1, -1}, {34675, -1, -1, -1}, {34648, -1, -1, -1}, {34644, -1, -1, -1}, {34651, -1, -1, -1}, {34642, -1, -1, -1}, {34657, -1, -1, -1}, {34650, -1, -1, -1}, {34641, -1, -1, -1}, {34654, -1, -1, -1}, {34669, -1, -1, -1}, {34666, -1, -1, -1}, {34640, -1, -1, -1}, {34638, -1, -1, -1}, {34655, -1, -1, -1}, {34653, -1, -1, -1}, {34671, -1, -1, -1}, {34668, -1, -1, -1}, {34682, -1, -1, -1}, {34670, -1, -1, -1}, {34652, -1, -1, -1}, {34661, -1, -1, -1}, {34639, -1, -1, -1}, {34683, -1, -1, -1}, {34677, -1, -1, -1}, {34658, -1, -1, -1}, {34663, -1, -1, -1}, {34665, -1, -1, -1}, {34906, -1, -1, -1}, {35077, -1, -1, -1}, {35084, -1, -1, -1}, {35092, -1, -1, -1}, {35083, -1, -1, -1}, {35095, -1, -1, -1}, {35096, -1, -1, -1}, {35097, -1, -1, -1}, {35078, -1, -1, -1}, {35094, -1, -1, -1}, {35089, -1, -1, -1}, {35086, -1, -1, -1}, {35081, -1, -1, -1}, {35234, -1, -1, -1}, {35236, -1, -1, -1}, {35235, -1, -1, -1}, {35309, -1, -1, -1}, {35312, -1, -1, -1}, {35308, -1, -1, -1}, {35535, -1, -1, -1}, {35526, -1, -1, -1}, {35512, -1, -1, -1}, {35539, -1, -1, -1}, {35537, -1, -1, -1}, {35540, -1, -1, -1}, {35541, -1, -1, -1}, {35515, -1, -1, -1}, {35543, -1, -1, -1}, {35518, -1, -1, -1}, {35520, -1, -1, -1}, {35525, -1, -1, -1}, {35544, -1, -1, -1}, {35523, -1, -1, -1}, {35514, -1, -1, -1}, {35517, -1, -1, -1}, {35545, -1, -1, -1}, {35902, -1, -1, -1}, {35917, -1, -1, -1}, {35983, -1, -1, -1}, {36069, -1, -1, -1}, {36063, -1, -1, -1}, {36057, -1, -1, -1}, {36072, -1, -1, -1}, {36058, -1, -1, -1}, {36061, -1, -1, -1}, {36071, -1, -1, -1}, {36256, -1, -1, -1}, {36252, -1, -1, -1}, {36257, -1, -1, -1}, {36251, -1, -1, -1}, {36384, -1, -1, -1}, {36387, -1, -1, -1}, {36389, -1, -1, -1}, {36388, -1, -1, -1}, {36398, -1, -1, -1}, {36373, -1, -1, -1}, {36379, -1, -1, -1}, {36374, -1, -1, -1}, {36369, -1, -1, -1}, {36377, -1, -1, -1}, {36390, -1, -1, -1}, {36391, -1, -1, -1}, {36372, -1, -1, -1}, {36370, -1, -1, -1}, {36376, -1, -1, -1}, {36371, -1, -1, -1}, {36380, -1, -1, -1}, {36375, -1, -1, -1}, {36378, -1, -1, -1}, {36652, -1, -1, -1}, {36644, -1, -1, -1}, {36632, -1, -1, -1}, {36634, -1, -1, -1}, {36640, -1, -1, -1}, {36643, -1, -1, -1}, {36630, -1, -1, -1}, {36631, -1, -1, -1}, {36979, -1, -1, -1}, {36976, -1, -1, -1}, {36975, -1, -1, -1}, {36967, -1, -1, -1}, {36971, -1, -1, -1}, {37167, -1, -1, -1}, {37163, -1, -1, -1}, {37161, -1, -1, -1}, {37162, -1, -1, -1}, {37170, -1, -1, -1}, {37158, -1, -1, -1}, {37166, -1, -1, -1}, {37253, -1, -1, -1}, {37254, -1, -1, -1}, {37258, -1, -1, -1}, {37249, -1, -1, -1}, {37250, -1, -1, -1}, {37252, -1, -1, -1}, {37248, -1, -1, -1}, {37584, -1, -1, -1}, {37571, -1, -1, -1}, {37572, -1, -1, -1}, {37568, -1, -1, -1}, {37593, -1, -1, -1}, {37558, -1, -1, -1}, {37583, -1, -1, -1}, {37617, -1, -1, -1}, {37599, -1, -1, -1}, {37592, -1, -1, -1}, {37609, -1, -1, -1}, {37591, -1, -1, -1}, {37597, -1, -1, -1}, {37580, -1, -1, -1}, {37615, -1, -1, -1}, {37570, -1, -1, -1}, {37608, -1, -1, -1}, {37578, -1, -1, -1}, {37576, -1, -1, -1}, {37582, -1, -1, -1}, {37606, -1, -1, -1}, {37581, -1, -1, -1}, {37589, -1, -1, -1}, {37577, -1, -1, -1}, {37600, -1, -1, -1}, {37598, -1, -1, -1}, {37607, -1, -1, -1}, {37585, -1, -1, -1}, {37587, -1, -1, -1}, {37557, -1, -1, -1}, {37601, -1, -1, -1}, {37669, -1, -1, -1}, {37574, -1, -1, -1}, {37556, -1, -1, -1}, {38268, -1, -1, -1}, {38316, -1, -1, -1}, {38315, -1, -1, -1}, {38318, -1, -1, -1}, {38320, -1, -1, -1}, {38564, -1, -1, -1}, {38562, -1, -1, -1}, {38611, -1, -1, -1}, {38661, -1, -1, -1}, {38664, -1, -1, -1}, {38658, -1, -1, -1}, {38746, -1, -1, -1}, {38794, -1, -1, -1}, {38798, -1, -1, -1}, {38792, -1, -1, -1}, {38864, -1, -1, -1}, {38863, -1, -1, -1}, {38942, -1, -1, -1}, {38941, -1, -1, -1}, {38950, -1, -1, -1}, {38953, -1, -1, -1}, {38952, -1, -1, -1}, {38944, -1, -1, -1}, {38939, -1, -1, -1}, {38951, -1, -1, -1}, {39090, -1, -1, -1}, {39176, -1, -1, -1}, {39162, -1, -1, -1}, {39185, -1, -1, -1}, {39188, -1, -1, -1}, {39190, -1, -1, -1}, {39191, -1, -1, -1}, {39189, -1, -1, -1}, {39388, -1, -1, -1}, {39373, -1, -1, -1}, {39375, -1, -1, -1}, {39379, -1, -1, -1}, {39380, -1, -1, -1}, {39374, -1, -1, -1}, {39369, -1, -1, -1}, {39382, -1, -1, -1}, {39384, -1, -1, -1}, {39371, -1, -1, -1}, {39383, -1, -1, -1}, {39372, -1, -1, -1}, {39603, -1, -1, -1}, {39660, -1, -1, -1}, {39659, -1, -1, -1}, {39667, -1, -1, -1}, {39666, -1, -1, -1}, {39665, -1, -1, -1}, {39750, -1, -1, -1}, {39747, -1, -1, -1}, {39783, -1, -1, -1}, {39796, -1, -1, -1}, {39793, -1, -1, -1}, {39782, -1, -1, -1}, {39798, -1, -1, -1}, {39797, -1, -1, -1}, {39792, -1, -1, -1}, {39784, -1, -1, -1}, {39780, -1, -1, -1}, {39788, -1, -1, -1}, {40188, -1, -1, -1}, {40186, -1, -1, -1}, {40189, -1, -1, -1}, {40191, -1, -1, -1}, {40183, -1, -1, -1}, {40199, -1, -1, -1}, {40192, -1, -1, -1}, {40185, -1, -1, -1}, {40187, -1, -1, -1}, {40200, -1, -1, -1}, {40197, -1, -1, -1}, {40196, -1, -1, -1}, {40579, -1, -1, -1}, {40659, -1, -1, -1}, {40719, -1, -1, -1}, {40720, -1, -1, -1} },
+ {{20764, -1, -1, -1}, {20755, -1, -1, -1}, {20759, -1, -1, -1}, {20762, -1, -1, -1}, {20753, -1, -1, -1}, {20958, -1, -1, -1}, {21300, -1, -1, -1}, {21473, -1, -1, -1}, {22128, -1, -1, -1}, {22112, -1, -1, -1}, {22126, -1, -1, -1}, {22131, -1, -1, -1}, {22118, -1, -1, -1}, {22115, -1, -1, -1}, {22125, -1, -1, -1}, {22130, -1, -1, -1}, {22110, -1, -1, -1}, {22135, -1, -1, -1}, {22300, -1, -1, -1}, {22299, -1, -1, -1}, {22728, -1, -1, -1}, {22717, -1, -1, -1}, {22729, -1, -1, -1}, {22719, -1, -1, -1}, {22714, -1, -1, -1}, {22722, -1, -1, -1}, {22716, -1, -1, -1}, {22726, -1, -1, -1}, {23319, -1, -1, -1}, {23321, -1, -1, -1}, {23323, -1, -1, -1}, {23329, -1, -1, -1}, {23316, -1, -1, -1}, {23315, -1, -1, -1}, {23312, -1, -1, -1}, {23318, -1, -1, -1}, {23336, -1, -1, -1}, {23322, -1, -1, -1}, {23328, -1, -1, -1}, {23326, -1, -1, -1}, {23535, -1, -1, -1}, {23980, -1, -1, -1}, {23985, -1, -1, -1}, {23977, -1, -1, -1}, {23975, -1, -1, -1}, {23989, -1, -1, -1}, {23984, -1, -1, -1}, {23982, -1, -1, -1}, {23978, -1, -1, -1}, {23976, -1, -1, -1}, {23986, -1, -1, -1}, {23981, -1, -1, -1}, {23983, -1, -1, -1}, {23988, -1, -1, -1}, {24167, -1, -1, -1}, {24168, -1, -1, -1}, {24166, -1, -1, -1}, {24175, -1, -1, -1}, {24297, -1, -1, -1}, {24295, -1, -1, -1}, {24294, -1, -1, -1}, {24296, -1, -1, -1}, {24293, -1, -1, -1}, {24395, -1, -1, -1}, {24508, -1, -1, -1}, {24507, -1, -1, -1}, {24989, -1, -1, -1}, {25000, -1, -1, -1}, {24982, -1, -1, -1}, {25029, -1, -1, -1}, {25012, -1, -1, -1}, {25030, -1, -1, -1}, {25025, -1, -1, -1}, {25036, -1, -1, -1}, {25018, -1, -1, -1}, {25023, -1, -1, -1}, {25016, -1, -1, -1}, {24972, -1, -1, -1}, {25815, -1, -1, -1}, {25814, -1, -1, -1}, {25808, -1, -1, -1}, {25807, -1, -1, -1}, {25801, -1, -1, -1}, {25789, -1, -1, -1}, {25737, -1, -1, -1}, {25795, -1, -1, -1}, {25819, -1, -1, -1}, {25843, -1, -1, -1}, {25817, -1, -1, -1}, {25907, -1, -1, -1}, {25983, -1, -1, -1}, {25980, -1, -1, -1}, {26018, -1, -1, -1}, {26312, -1, -1, -1}, {26302, -1, -1, -1}, {26304, -1, -1, -1}, {26314, -1, -1, -1}, {26315, -1, -1, -1}, {26319, -1, -1, -1}, {26301, -1, -1, -1}, {26299, -1, -1, -1}, {26298, -1, -1, -1}, {26316, -1, -1, -1}, {26403, -1, -1, -1}, {27188, -1, -1, -1}, {27238, -1, -1, -1}, {27209, -1, -1, -1}, {27239, -1, -1, -1}, {27186, -1, -1, -1}, {27240, -1, -1, -1}, {27198, -1, -1, -1}, {27229, -1, -1, -1}, {27245, -1, -1, -1}, {27254, -1, -1, -1}, {27227, -1, -1, -1}, {27217, -1, -1, -1}, {27176, -1, -1, -1}, {27226, -1, -1, -1}, {27195, -1, -1, -1}, {27199, -1, -1, -1}, {27201, -1, -1, -1}, {27242, -1, -1, -1}, {27236, -1, -1, -1}, {27216, -1, -1, -1}, {27215, -1, -1, -1}, {27220, -1, -1, -1}, {27247, -1, -1, -1}, {27241, -1, -1, -1}, {27232, -1, -1, -1}, {27196, -1, -1, -1}, {27230, -1, -1, -1}, {27222, -1, -1, -1}, {27221, -1, -1, -1}, {27213, -1, -1, -1}, {27214, -1, -1, -1}, {27206, -1, -1, -1}, {27477, -1, -1, -1}, {27476, -1, -1, -1}, {27478, -1, -1, -1}, {27559, -1, -1, -1}, {27562, -1, -1, -1}, {27563, -1, -1, -1}, {27592, -1, -1, -1}, {27591, -1, -1, -1}, {27652, -1, -1, -1}, {27651, -1, -1, -1}, {27654, -1, -1, -1}, {28589, -1, -1, -1}, {28619, -1, -1, -1}, {28579, -1, -1, -1}, {28615, -1, -1, -1}, {28604, -1, -1, -1}, {28622, -1, -1, -1}, {28616, -1, -1, -1}, {28510, -1, -1, -1}, {28612, -1, -1, -1}, {28605, -1, -1, -1}, {28574, -1, -1, -1}, {28618, -1, -1, -1}, {28584, -1, -1, -1}, {28676, -1, -1, -1}, {28581, -1, -1, -1}, {28590, -1, -1, -1}, {28602, -1, -1, -1}, {28588, -1, -1, -1}, {28586, -1, -1, -1}, {28623, -1, -1, -1}, {28607, -1, -1, -1}, {28600, -1, -1, -1}, {28578, -1, -1, -1}, {28617, -1, -1, -1}, {28587, -1, -1, -1}, {28621, -1, -1, -1}, {28591, -1, -1, -1}, {28594, -1, -1, -1}, {28592, -1, -1, -1}, {29125, -1, -1, -1}, {29122, -1, -1, -1}, {29119, -1, -1, -1}, {29112, -1, -1, -1}, {29142, -1, -1, -1}, {29120, -1, -1, -1}, {29121, -1, -1, -1}, {29131, -1, -1, -1}, {29140, -1, -1, -1}, {29130, -1, -1, -1}, {29127, -1, -1, -1}, {29135, -1, -1, -1}, {29117, -1, -1, -1}, {29144, -1, -1, -1}, {29116, -1, -1, -1}, {29126, -1, -1, -1}, {29146, -1, -1, -1}, {29147, -1, -1, -1}, {29341, -1, -1, -1}, {29342, -1, -1, -1}, {29545, -1, -1, -1}, {29542, -1, -1, -1}, {29543, -1, -1, -1}, {29548, -1, -1, -1}, {29541, -1, -1, -1}, {29547, -1, -1, -1}, {29546, -1, -1, -1}, {29823, -1, -1, -1}, {29850, -1, -1, -1}, {29856, -1, -1, -1}, {29844, -1, -1, -1}, {29842, -1, -1, -1}, {29845, -1, -1, -1}, {29857, -1, -1, -1}, {29963, -1, -1, -1}, {30080, -1, -1, -1}, {30255, -1, -1, -1}, {30253, -1, -1, -1}, {30257, -1, -1, -1}, {30269, -1, -1, -1}, {30259, -1, -1, -1}, {30268, -1, -1, -1}, {30261, -1, -1, -1}, {30258, -1, -1, -1}, {30256, -1, -1, -1}, {30395, -1, -1, -1}, {30438, -1, -1, -1}, {30618, -1, -1, -1}, {30621, -1, -1, -1}, {30625, -1, -1, -1}, {30620, -1, -1, -1}, {30619, -1, -1, -1}, {30626, -1, -1, -1}, {30627, -1, -1, -1}, {30613, -1, -1, -1}, {30617, -1, -1, -1}, {30615, -1, -1, -1}, {30941, -1, -1, -1}, {30953, -1, -1, -1}, {30949, -1, -1, -1}, {30954, -1, -1, -1}, {30942, -1, -1, -1}, {30947, -1, -1, -1}, {30939, -1, -1, -1}, {30945, -1, -1, -1}, {30946, -1, -1, -1}, {30957, -1, -1, -1}, {30943, -1, -1, -1}, {30944, -1, -1, -1}, {31140, -1, -1, -1}, {31300, -1, -1, -1}, {31304, -1, -1, -1}, {31303, -1, -1, -1}, {31414, -1, -1, -1}, {31416, -1, -1, -1}, {31413, -1, -1, -1}, {31409, -1, -1, -1}, {31415, -1, -1, -1}, {31710, -1, -1, -1}, {31715, -1, -1, -1} },
+ {{31719, -1, -1, -1}, {31709, -1, -1, -1}, {31701, -1, -1, -1}, {31717, -1, -1, -1}, {31706, -1, -1, -1}, {31720, -1, -1, -1}, {31737, -1, -1, -1}, {31700, -1, -1, -1}, {31722, -1, -1, -1}, {31714, -1, -1, -1}, {31708, -1, -1, -1}, {31723, -1, -1, -1}, {31704, -1, -1, -1}, {31711, -1, -1, -1}, {31954, -1, -1, -1}, {31956, -1, -1, -1}, {31959, -1, -1, -1}, {31952, -1, -1, -1}, {31953, -1, -1, -1}, {32274, -1, -1, -1}, {32289, -1, -1, -1}, {32279, -1, -1, -1}, {32268, -1, -1, -1}, {32287, -1, -1, -1}, {32288, -1, -1, -1}, {32275, -1, -1, -1}, {32270, -1, -1, -1}, {32284, -1, -1, -1}, {32277, -1, -1, -1}, {32282, -1, -1, -1}, {32290, -1, -1, -1}, {32267, -1, -1, -1}, {32271, -1, -1, -1}, {32278, -1, -1, -1}, {32269, -1, -1, -1}, {32276, -1, -1, -1}, {32293, -1, -1, -1}, {32292, -1, -1, -1}, {32579, -1, -1, -1}, {32635, -1, -1, -1}, {32636, -1, -1, -1}, {32634, -1, -1, -1}, {32689, -1, -1, -1}, {32751, -1, -1, -1}, {32810, -1, -1, -1}, {32809, -1, -1, -1}, {32876, -1, -1, -1}, {33201, -1, -1, -1}, {33190, -1, -1, -1}, {33198, -1, -1, -1}, {33209, -1, -1, -1}, {33205, -1, -1, -1}, {33195, -1, -1, -1}, {33200, -1, -1, -1}, {33196, -1, -1, -1}, {33204, -1, -1, -1}, {33202, -1, -1, -1}, {33207, -1, -1, -1}, {33191, -1, -1, -1}, {33266, -1, -1, -1}, {33365, -1, -1, -1}, {33366, -1, -1, -1}, {33367, -1, -1, -1}, {34134, -1, -1, -1}, {34117, -1, -1, -1}, {34155, -1, -1, -1}, {34125, -1, -1, -1}, {34131, -1, -1, -1}, {34145, -1, -1, -1}, {34136, -1, -1, -1}, {34112, -1, -1, -1}, {34118, -1, -1, -1}, {34148, -1, -1, -1}, {34113, -1, -1, -1}, {34146, -1, -1, -1}, {34116, -1, -1, -1}, {34129, -1, -1, -1}, {34119, -1, -1, -1}, {34147, -1, -1, -1}, {34110, -1, -1, -1}, {34139, -1, -1, -1}, {34161, -1, -1, -1}, {34126, -1, -1, -1}, {34158, -1, -1, -1}, {34165, -1, -1, -1}, {34133, -1, -1, -1}, {34151, -1, -1, -1}, {34144, -1, -1, -1}, {34188, -1, -1, -1}, {34150, -1, -1, -1}, {34141, -1, -1, -1}, {34132, -1, -1, -1}, {34149, -1, -1, -1}, {34156, -1, -1, -1}, {34403, -1, -1, -1}, {34405, -1, -1, -1}, {34404, -1, -1, -1}, {34724, -1, -1, -1}, {34715, -1, -1, -1}, {34703, -1, -1, -1}, {34711, -1, -1, -1}, {34707, -1, -1, -1}, {34706, -1, -1, -1}, {34696, -1, -1, -1}, {34689, -1, -1, -1}, {34710, -1, -1, -1}, {34712, -1, -1, -1}, {34681, -1, -1, -1}, {34695, -1, -1, -1}, {34723, -1, -1, -1}, {34693, -1, -1, -1}, {34704, -1, -1, -1}, {34705, -1, -1, -1}, {34717, -1, -1, -1}, {34692, -1, -1, -1}, {34708, -1, -1, -1}, {34716, -1, -1, -1}, {34714, -1, -1, -1}, {34697, -1, -1, -1}, {35102, -1, -1, -1}, {35110, -1, -1, -1}, {35120, -1, -1, -1}, {35117, -1, -1, -1}, {35118, -1, -1, -1}, {35111, -1, -1, -1}, {35121, -1, -1, -1}, {35106, -1, -1, -1}, {35113, -1, -1, -1}, {35107, -1, -1, -1}, {35119, -1, -1, -1}, {35116, -1, -1, -1}, {35103, -1, -1, -1}, {35313, -1, -1, -1}, {35552, -1, -1, -1}, {35554, -1, -1, -1}, {35570, -1, -1, -1}, {35572, -1, -1, -1}, {35573, -1, -1, -1}, {35549, -1, -1, -1}, {35604, -1, -1, -1}, {35556, -1, -1, -1}, {35551, -1, -1, -1}, {35568, -1, -1, -1}, {35528, -1, -1, -1}, {35550, -1, -1, -1}, {35553, -1, -1, -1}, {35560, -1, -1, -1}, {35583, -1, -1, -1}, {35567, -1, -1, -1}, {35579, -1, -1, -1}, {35985, -1, -1, -1}, {35986, -1, -1, -1}, {35984, -1, -1, -1}, {36085, -1, -1, -1}, {36078, -1, -1, -1}, {36081, -1, -1, -1}, {36080, -1, -1, -1}, {36083, -1, -1, -1}, {36204, -1, -1, -1}, {36206, -1, -1, -1}, {36261, -1, -1, -1}, {36263, -1, -1, -1}, {36403, -1, -1, -1}, {36414, -1, -1, -1}, {36408, -1, -1, -1}, {36416, -1, -1, -1}, {36421, -1, -1, -1}, {36406, -1, -1, -1}, {36412, -1, -1, -1}, {36413, -1, -1, -1}, {36417, -1, -1, -1}, {36400, -1, -1, -1}, {36415, -1, -1, -1}, {36541, -1, -1, -1}, {36662, -1, -1, -1}, {36654, -1, -1, -1}, {36661, -1, -1, -1}, {36658, -1, -1, -1}, {36665, -1, -1, -1}, {36663, -1, -1, -1}, {36660, -1, -1, -1}, {36982, -1, -1, -1}, {36985, -1, -1, -1}, {36987, -1, -1, -1}, {36998, -1, -1, -1}, {37114, -1, -1, -1}, {37171, -1, -1, -1}, {37173, -1, -1, -1}, {37174, -1, -1, -1}, {37267, -1, -1, -1}, {37264, -1, -1, -1}, {37265, -1, -1, -1}, {37261, -1, -1, -1}, {37263, -1, -1, -1}, {37671, -1, -1, -1}, {37662, -1, -1, -1}, {37640, -1, -1, -1}, {37663, -1, -1, -1}, {37638, -1, -1, -1}, {37647, -1, -1, -1}, {37754, -1, -1, -1}, {37688, -1, -1, -1}, {37692, -1, -1, -1}, {37659, -1, -1, -1}, {37667, -1, -1, -1}, {37650, -1, -1, -1}, {37633, -1, -1, -1}, {37702, -1, -1, -1}, {37677, -1, -1, -1}, {37646, -1, -1, -1}, {37645, -1, -1, -1}, {37579, -1, -1, -1}, {37661, -1, -1, -1}, {37626, -1, -1, -1}, {37651, -1, -1, -1}, {37625, -1, -1, -1}, {37623, -1, -1, -1}, {37684, -1, -1, -1}, {37634, -1, -1, -1}, {37668, -1, -1, -1}, {37631, -1, -1, -1}, {37673, -1, -1, -1}, {37689, -1, -1, -1}, {37685, -1, -1, -1}, {37674, -1, -1, -1}, {37652, -1, -1, -1}, {37644, -1, -1, -1}, {37643, -1, -1, -1}, {37630, -1, -1, -1}, {37641, -1, -1, -1}, {37632, -1, -1, -1}, {37627, -1, -1, -1}, {37654, -1, -1, -1}, {38332, -1, -1, -1}, {38349, -1, -1, -1}, {38334, -1, -1, -1}, {38329, -1, -1, -1}, {38330, -1, -1, -1}, {38326, -1, -1, -1}, {38335, -1, -1, -1}, {38325, -1, -1, -1}, {38333, -1, -1, -1}, {38569, -1, -1, -1}, {38612, -1, -1, -1}, {38667, -1, -1, -1}, {38674, -1, -1, -1}, {38672, -1, -1, -1}, {38809, -1, -1, -1}, {38807, -1, -1, -1}, {38804, -1, -1, -1}, {38896, -1, -1, -1}, {38904, -1, -1, -1}, {38965, -1, -1, -1}, {38959, -1, -1, -1}, {38962, -1, -1, -1}, {39204, -1, -1, -1} },
+ {{39199, -1, -1, -1}, {39207, -1, -1, -1}, {39209, -1, -1, -1}, {39326, -1, -1, -1}, {39406, -1, -1, -1}, {39404, -1, -1, -1}, {39397, -1, -1, -1}, {39396, -1, -1, -1}, {39408, -1, -1, -1}, {39395, -1, -1, -1}, {39402, -1, -1, -1}, {39401, -1, -1, -1}, {39399, -1, -1, -1}, {39609, -1, -1, -1}, {39615, -1, -1, -1}, {39604, -1, -1, -1}, {39611, -1, -1, -1}, {39670, -1, -1, -1}, {39674, -1, -1, -1}, {39673, -1, -1, -1}, {39671, -1, -1, -1}, {39731, -1, -1, -1}, {39808, -1, -1, -1}, {39813, -1, -1, -1}, {39815, -1, -1, -1}, {39804, -1, -1, -1}, {39806, -1, -1, -1}, {39803, -1, -1, -1}, {39810, -1, -1, -1}, {39827, -1, -1, -1}, {39826, -1, -1, -1}, {39824, -1, -1, -1}, {39802, -1, -1, -1}, {39829, -1, -1, -1}, {39805, -1, -1, -1}, {39816, -1, -1, -1}, {40229, -1, -1, -1}, {40215, -1, -1, -1}, {40224, -1, -1, -1}, {40222, -1, -1, -1}, {40212, -1, -1, -1}, {40233, -1, -1, -1}, {40221, -1, -1, -1}, {40216, -1, -1, -1}, {40226, -1, -1, -1}, {40208, -1, -1, -1}, {40217, -1, -1, -1}, {40223, -1, -1, -1}, {40584, -1, -1, -1}, {40582, -1, -1, -1}, {40583, -1, -1, -1}, {40622, -1, -1, -1}, {40621, -1, -1, -1}, {40661, -1, -1, -1}, {40662, -1, -1, -1}, {40698, -1, -1, -1}, {40722, -1, -1, -1}, {40765, -1, -1, -1}, {20774, -1, -1, -1}, {20773, -1, -1, -1}, {20770, -1, -1, -1}, {20772, -1, -1, -1}, {20768, -1, -1, -1}, {20777, -1, -1, -1}, {21236, -1, -1, -1}, {22163, -1, -1, -1}, {22156, -1, -1, -1}, {22157, -1, -1, -1}, {22150, -1, -1, -1}, {22148, -1, -1, -1}, {22147, -1, -1, -1}, {22142, -1, -1, -1}, {22146, -1, -1, -1}, {22143, -1, -1, -1}, {22145, -1, -1, -1}, {22742, -1, -1, -1}, {22740, -1, -1, -1}, {22735, -1, -1, -1}, {22738, -1, -1, -1}, {23341, -1, -1, -1}, {23333, -1, -1, -1}, {23346, -1, -1, -1}, {23331, -1, -1, -1}, {23340, -1, -1, -1}, {23335, -1, -1, -1}, {23334, -1, -1, -1}, {23343, -1, -1, -1}, {23342, -1, -1, -1}, {23419, -1, -1, -1}, {23537, -1, -1, -1}, {23538, -1, -1, -1}, {23991, -1, -1, -1}, {24172, -1, -1, -1}, {24170, -1, -1, -1}, {24510, -1, -1, -1}, {25027, -1, -1, -1}, {25013, -1, -1, -1}, {25020, -1, -1, -1}, {25063, -1, -1, -1}, {25056, -1, -1, -1}, {25061, -1, -1, -1}, {25060, -1, -1, -1}, {25064, -1, -1, -1}, {25054, -1, -1, -1}, {25839, -1, -1, -1}, {25833, -1, -1, -1}, {25827, -1, -1, -1}, {25835, -1, -1, -1}, {25828, -1, -1, -1}, {25832, -1, -1, -1}, {25985, -1, -1, -1}, {25984, -1, -1, -1}, {26038, -1, -1, -1}, {26074, -1, -1, -1}, {26322, -1, -1, -1}, {27277, -1, -1, -1}, {27286, -1, -1, -1}, {27265, -1, -1, -1}, {27301, -1, -1, -1}, {27273, -1, -1, -1}, {27295, -1, -1, -1}, {27291, -1, -1, -1}, {27297, -1, -1, -1}, {27294, -1, -1, -1}, {27271, -1, -1, -1}, {27283, -1, -1, -1}, {27278, -1, -1, -1}, {27285, -1, -1, -1}, {27267, -1, -1, -1}, {27304, -1, -1, -1}, {27300, -1, -1, -1}, {27281, -1, -1, -1}, {27263, -1, -1, -1}, {27302, -1, -1, -1}, {27290, -1, -1, -1}, {27269, -1, -1, -1}, {27276, -1, -1, -1}, {27282, -1, -1, -1}, {27483, -1, -1, -1}, {27565, -1, -1, -1}, {27657, -1, -1, -1}, {28620, -1, -1, -1}, {28585, -1, -1, -1}, {28660, -1, -1, -1}, {28628, -1, -1, -1}, {28643, -1, -1, -1}, {28636, -1, -1, -1}, {28653, -1, -1, -1}, {28647, -1, -1, -1}, {28646, -1, -1, -1}, {28638, -1, -1, -1}, {28658, -1, -1, -1}, {28637, -1, -1, -1}, {28642, -1, -1, -1}, {28648, -1, -1, -1}, {29153, -1, -1, -1}, {29169, -1, -1, -1}, {29160, -1, -1, -1}, {29170, -1, -1, -1}, {29156, -1, -1, -1}, {29168, -1, -1, -1}, {29154, -1, -1, -1}, {29555, -1, -1, -1}, {29550, -1, -1, -1}, {29551, -1, -1, -1}, {29847, -1, -1, -1}, {29874, -1, -1, -1}, {29867, -1, -1, -1}, {29840, -1, -1, -1}, {29866, -1, -1, -1}, {29869, -1, -1, -1}, {29873, -1, -1, -1}, {29861, -1, -1, -1}, {29871, -1, -1, -1}, {29968, -1, -1, -1}, {29969, -1, -1, -1}, {29970, -1, -1, -1}, {29967, -1, -1, -1}, {30084, -1, -1, -1}, {30275, -1, -1, -1}, {30280, -1, -1, -1}, {30281, -1, -1, -1}, {30279, -1, -1, -1}, {30372, -1, -1, -1}, {30441, -1, -1, -1}, {30645, -1, -1, -1}, {30635, -1, -1, -1}, {30642, -1, -1, -1}, {30647, -1, -1, -1}, {30646, -1, -1, -1}, {30644, -1, -1, -1}, {30641, -1, -1, -1}, {30632, -1, -1, -1}, {30704, -1, -1, -1}, {30963, -1, -1, -1}, {30973, -1, -1, -1}, {30978, -1, -1, -1}, {30971, -1, -1, -1}, {30972, -1, -1, -1}, {30975, -1, -1, -1}, {30962, -1, -1, -1}, {30981, -1, -1, -1}, {30969, -1, -1, -1}, {30974, -1, -1, -1}, {30980, -1, -1, -1}, {31147, -1, -1, -1}, {31144, -1, -1, -1}, {31324, -1, -1, -1}, {31323, -1, -1, -1}, {31318, -1, -1, -1}, {31320, -1, -1, -1}, {31316, -1, -1, -1}, {31322, -1, -1, -1}, {31422, -1, -1, -1}, {31424, -1, -1, -1}, {31425, -1, -1, -1}, {31749, -1, -1, -1}, {31759, -1, -1, -1}, {31730, -1, -1, -1}, {31744, -1, -1, -1}, {31743, -1, -1, -1}, {31739, -1, -1, -1}, {31758, -1, -1, -1}, {31732, -1, -1, -1}, {31755, -1, -1, -1}, {31731, -1, -1, -1}, {31746, -1, -1, -1}, {31753, -1, -1, -1}, {31747, -1, -1, -1}, {31745, -1, -1, -1}, {31736, -1, -1, -1}, {31741, -1, -1, -1}, {31750, -1, -1, -1}, {31728, -1, -1, -1}, {31729, -1, -1, -1}, {31760, -1, -1, -1}, {31754, -1, -1, -1}, {31976, -1, -1, -1}, {32301, -1, -1, -1}, {32316, -1, -1, -1}, {32322, -1, -1, -1}, {32307, -1, -1, -1}, {38984, -1, -1, -1}, {32312, -1, -1, -1}, {32298, -1, -1, -1}, {32329, -1, -1, -1}, {32320, -1, -1, -1}, {32327, -1, -1, -1}, {32297, -1, -1, -1}, {32332, -1, -1, -1}, {32304, -1, -1, -1}, {32315, -1, -1, -1}, {32310, -1, -1, -1}, {32324, -1, -1, -1}, {32314, -1, -1, -1}, {32581, -1, -1, -1} },
+ {{32639, -1, -1, -1}, {32638, -1, -1, -1}, {32637, -1, -1, -1}, {32756, -1, -1, -1}, {32754, -1, -1, -1}, {32812, -1, -1, -1}, {33211, -1, -1, -1}, {33220, -1, -1, -1}, {33228, -1, -1, -1}, {33226, -1, -1, -1}, {33221, -1, -1, -1}, {33223, -1, -1, -1}, {33212, -1, -1, -1}, {33257, -1, -1, -1}, {33371, -1, -1, -1}, {33370, -1, -1, -1}, {33372, -1, -1, -1}, {34179, -1, -1, -1}, {34176, -1, -1, -1}, {34191, -1, -1, -1}, {34215, -1, -1, -1}, {34197, -1, -1, -1}, {34208, -1, -1, -1}, {34187, -1, -1, -1}, {34211, -1, -1, -1}, {34171, -1, -1, -1}, {34212, -1, -1, -1}, {34202, -1, -1, -1}, {34206, -1, -1, -1}, {34167, -1, -1, -1}, {34172, -1, -1, -1}, {34185, -1, -1, -1}, {34209, -1, -1, -1}, {34170, -1, -1, -1}, {34168, -1, -1, -1}, {34135, -1, -1, -1}, {34190, -1, -1, -1}, {34198, -1, -1, -1}, {34182, -1, -1, -1}, {34189, -1, -1, -1}, {34201, -1, -1, -1}, {34205, -1, -1, -1}, {34177, -1, -1, -1}, {34210, -1, -1, -1}, {34178, -1, -1, -1}, {34184, -1, -1, -1}, {34181, -1, -1, -1}, {34169, -1, -1, -1}, {34166, -1, -1, -1}, {34200, -1, -1, -1}, {34192, -1, -1, -1}, {34207, -1, -1, -1}, {34408, -1, -1, -1}, {34750, -1, -1, -1}, {34730, -1, -1, -1}, {34733, -1, -1, -1}, {34757, -1, -1, -1}, {34736, -1, -1, -1}, {34732, -1, -1, -1}, {34745, -1, -1, -1}, {34741, -1, -1, -1}, {34748, -1, -1, -1}, {34734, -1, -1, -1}, {34761, -1, -1, -1}, {34755, -1, -1, -1}, {34754, -1, -1, -1}, {34764, -1, -1, -1}, {34743, -1, -1, -1}, {34735, -1, -1, -1}, {34756, -1, -1, -1}, {34762, -1, -1, -1}, {34740, -1, -1, -1}, {34742, -1, -1, -1}, {34751, -1, -1, -1}, {34744, -1, -1, -1}, {34749, -1, -1, -1}, {34782, -1, -1, -1}, {34738, -1, -1, -1}, {35125, -1, -1, -1}, {35123, -1, -1, -1}, {35132, -1, -1, -1}, {35134, -1, -1, -1}, {35137, -1, -1, -1}, {35154, -1, -1, -1}, {35127, -1, -1, -1}, {35138, -1, -1, -1}, {35245, -1, -1, -1}, {35247, -1, -1, -1}, {35246, -1, -1, -1}, {35314, -1, -1, -1}, {35315, -1, -1, -1}, {35614, -1, -1, -1}, {35608, -1, -1, -1}, {35606, -1, -1, -1}, {35601, -1, -1, -1}, {35589, -1, -1, -1}, {35595, -1, -1, -1}, {35618, -1, -1, -1}, {35599, -1, -1, -1}, {35602, -1, -1, -1}, {35605, -1, -1, -1}, {35591, -1, -1, -1}, {35597, -1, -1, -1}, {35592, -1, -1, -1}, {35590, -1, -1, -1}, {35612, -1, -1, -1}, {35603, -1, -1, -1}, {35610, -1, -1, -1}, {35919, -1, -1, -1}, {35952, -1, -1, -1}, {35954, -1, -1, -1}, {35953, -1, -1, -1}, {35951, -1, -1, -1}, {35989, -1, -1, -1}, {35988, -1, -1, -1}, {36089, -1, -1, -1}, {36207, -1, -1, -1}, {36430, -1, -1, -1}, {36429, -1, -1, -1}, {36435, -1, -1, -1}, {36432, -1, -1, -1}, {36428, -1, -1, -1}, {36423, -1, -1, -1}, {36675, -1, -1, -1}, {36672, -1, -1, -1}, {36997, -1, -1, -1}, {36990, -1, -1, -1}, {37176, -1, -1, -1}, {37274, -1, -1, -1}, {37282, -1, -1, -1}, {37275, -1, -1, -1}, {37273, -1, -1, -1}, {37279, -1, -1, -1}, {37281, -1, -1, -1}, {37277, -1, -1, -1}, {37280, -1, -1, -1}, {37793, -1, -1, -1}, {37763, -1, -1, -1}, {37807, -1, -1, -1}, {37732, -1, -1, -1}, {37718, -1, -1, -1}, {37703, -1, -1, -1}, {37756, -1, -1, -1}, {37720, -1, -1, -1}, {37724, -1, -1, -1}, {37750, -1, -1, -1}, {37705, -1, -1, -1}, {37712, -1, -1, -1}, {37713, -1, -1, -1}, {37728, -1, -1, -1}, {37741, -1, -1, -1}, {37775, -1, -1, -1}, {37708, -1, -1, -1}, {37738, -1, -1, -1}, {37753, -1, -1, -1}, {37719, -1, -1, -1}, {37717, -1, -1, -1}, {37714, -1, -1, -1}, {37711, -1, -1, -1}, {37745, -1, -1, -1}, {37751, -1, -1, -1}, {37755, -1, -1, -1}, {37729, -1, -1, -1}, {37726, -1, -1, -1}, {37731, -1, -1, -1}, {37735, -1, -1, -1}, {37710, -1, -1, -1}, {37721, -1, -1, -1}, {38343, -1, -1, -1}, {38336, -1, -1, -1}, {38345, -1, -1, -1}, {38339, -1, -1, -1}, {38341, -1, -1, -1}, {38327, -1, -1, -1}, {38574, -1, -1, -1}, {38576, -1, -1, -1}, {38572, -1, -1, -1}, {38688, -1, -1, -1}, {38687, -1, -1, -1}, {38680, -1, -1, -1}, {38685, -1, -1, -1}, {38681, -1, -1, -1}, {38810, -1, -1, -1}, {38817, -1, -1, -1}, {38812, -1, -1, -1}, {38814, -1, -1, -1}, {38813, -1, -1, -1}, {38869, -1, -1, -1}, {38868, -1, -1, -1}, {38897, -1, -1, -1}, {38977, -1, -1, -1}, {38980, -1, -1, -1}, {38986, -1, -1, -1}, {38985, -1, -1, -1}, {38981, -1, -1, -1}, {38979, -1, -1, -1}, {39205, -1, -1, -1}, {39211, -1, -1, -1}, {39212, -1, -1, -1}, {39210, -1, -1, -1}, {39219, -1, -1, -1}, {39218, -1, -1, -1}, {39215, -1, -1, -1}, {39213, -1, -1, -1}, {39217, -1, -1, -1}, {39216, -1, -1, -1}, {39320, -1, -1, -1}, {39331, -1, -1, -1}, {39329, -1, -1, -1}, {39426, -1, -1, -1}, {39418, -1, -1, -1}, {39412, -1, -1, -1}, {39415, -1, -1, -1}, {39417, -1, -1, -1}, {39416, -1, -1, -1}, {39414, -1, -1, -1}, {39419, -1, -1, -1}, {39421, -1, -1, -1}, {39422, -1, -1, -1}, {39420, -1, -1, -1}, {39427, -1, -1, -1}, {39614, -1, -1, -1}, {39678, -1, -1, -1}, {39677, -1, -1, -1}, {39681, -1, -1, -1}, {39676, -1, -1, -1}, {39752, -1, -1, -1}, {39834, -1, -1, -1}, {39848, -1, -1, -1}, {39838, -1, -1, -1}, {39835, -1, -1, -1}, {39846, -1, -1, -1}, {39841, -1, -1, -1}, {39845, -1, -1, -1}, {39844, -1, -1, -1}, {39814, -1, -1, -1}, {39842, -1, -1, -1}, {39840, -1, -1, -1}, {39855, -1, -1, -1}, {40243, -1, -1, -1}, {40257, -1, -1, -1}, {40295, -1, -1, -1}, {40246, -1, -1, -1}, {40238, -1, -1, -1}, {40239, -1, -1, -1}, {40241, -1, -1, -1}, {40248, -1, -1, -1}, {40240, -1, -1, -1}, {40261, -1, -1, -1}, {40258, -1, -1, -1}, {40259, -1, -1, -1}, {40254, -1, -1, -1}, {40247, -1, -1, -1}, {40256, -1, -1, -1}, {40253, -1, -1, -1}, {32757, -1, -1, -1} },
+ {{40237, -1, -1, -1}, {40586, -1, -1, -1}, {40585, -1, -1, -1}, {40589, -1, -1, -1}, {40624, -1, -1, -1}, {40648, -1, -1, -1}, {40666, -1, -1, -1}, {40699, -1, -1, -1}, {40703, -1, -1, -1}, {40740, -1, -1, -1}, {40739, -1, -1, -1}, {40738, -1, -1, -1}, {40788, -1, -1, -1}, {40864, -1, -1, -1}, {20785, -1, -1, -1}, {20781, -1, -1, -1}, {20782, -1, -1, -1}, {22168, -1, -1, -1}, {22172, -1, -1, -1}, {22167, -1, -1, -1}, {22170, -1, -1, -1}, {22173, -1, -1, -1}, {22169, -1, -1, -1}, {22896, -1, -1, -1}, {23356, -1, -1, -1}, {23657, -1, -1, -1}, {23658, -1, -1, -1}, {24000, -1, -1, -1}, {24173, -1, -1, -1}, {24174, -1, -1, -1}, {25048, -1, -1, -1}, {25055, -1, -1, -1}, {25069, -1, -1, -1}, {25070, -1, -1, -1}, {25073, -1, -1, -1}, {25066, -1, -1, -1}, {25072, -1, -1, -1}, {25067, -1, -1, -1}, {25046, -1, -1, -1}, {25065, -1, -1, -1}, {25855, -1, -1, -1}, {25860, -1, -1, -1}, {25853, -1, -1, -1}, {25848, -1, -1, -1}, {25857, -1, -1, -1}, {25859, -1, -1, -1}, {25852, -1, -1, -1}, {26004, -1, -1, -1}, {26075, -1, -1, -1}, {26330, -1, -1, -1}, {26331, -1, -1, -1}, {26328, -1, -1, -1}, {27333, -1, -1, -1}, {27321, -1, -1, -1}, {27325, -1, -1, -1}, {27361, -1, -1, -1}, {27334, -1, -1, -1}, {27322, -1, -1, -1}, {27318, -1, -1, -1}, {27319, -1, -1, -1}, {27335, -1, -1, -1}, {27316, -1, -1, -1}, {27309, -1, -1, -1}, {27486, -1, -1, -1}, {27593, -1, -1, -1}, {27659, -1, -1, -1}, {28679, -1, -1, -1}, {28684, -1, -1, -1}, {28685, -1, -1, -1}, {28673, -1, -1, -1}, {28677, -1, -1, -1}, {28692, -1, -1, -1}, {28686, -1, -1, -1}, {28671, -1, -1, -1}, {28672, -1, -1, -1}, {28667, -1, -1, -1}, {28710, -1, -1, -1}, {28668, -1, -1, -1}, {28663, -1, -1, -1}, {28682, -1, -1, -1}, {29185, -1, -1, -1}, {29183, -1, -1, -1}, {29177, -1, -1, -1}, {29187, -1, -1, -1}, {29181, -1, -1, -1}, {29558, -1, -1, -1}, {29880, -1, -1, -1}, {29888, -1, -1, -1}, {29877, -1, -1, -1}, {29889, -1, -1, -1}, {29886, -1, -1, -1}, {29878, -1, -1, -1}, {29883, -1, -1, -1}, {29890, -1, -1, -1}, {29972, -1, -1, -1}, {29971, -1, -1, -1}, {30300, -1, -1, -1}, {30308, -1, -1, -1}, {30297, -1, -1, -1}, {30288, -1, -1, -1}, {30291, -1, -1, -1}, {30295, -1, -1, -1}, {30298, -1, -1, -1}, {30374, -1, -1, -1}, {30397, -1, -1, -1}, {30444, -1, -1, -1}, {30658, -1, -1, -1}, {30650, -1, -1, -1}, {30988, -1, -1, -1}, {30995, -1, -1, -1}, {30996, -1, -1, -1}, {30985, -1, -1, -1}, {30992, -1, -1, -1}, {30994, -1, -1, -1}, {30993, -1, -1, -1}, {31149, -1, -1, -1}, {31148, -1, -1, -1}, {31327, -1, -1, -1}, {31772, -1, -1, -1}, {31785, -1, -1, -1}, {31769, -1, -1, -1}, {31776, -1, -1, -1}, {31775, -1, -1, -1}, {31789, -1, -1, -1}, {31773, -1, -1, -1}, {31782, -1, -1, -1}, {31784, -1, -1, -1}, {31778, -1, -1, -1}, {31781, -1, -1, -1}, {31792, -1, -1, -1}, {32348, -1, -1, -1}, {32336, -1, -1, -1}, {32342, -1, -1, -1}, {32355, -1, -1, -1}, {32344, -1, -1, -1}, {32354, -1, -1, -1}, {32351, -1, -1, -1}, {32337, -1, -1, -1}, {32352, -1, -1, -1}, {32343, -1, -1, -1}, {32339, -1, -1, -1}, {32693, -1, -1, -1}, {32691, -1, -1, -1}, {32759, -1, -1, -1}, {32760, -1, -1, -1}, {32885, -1, -1, -1}, {33233, -1, -1, -1}, {33234, -1, -1, -1}, {33232, -1, -1, -1}, {33375, -1, -1, -1}, {33374, -1, -1, -1}, {34228, -1, -1, -1}, {34246, -1, -1, -1}, {34240, -1, -1, -1}, {34243, -1, -1, -1}, {34242, -1, -1, -1}, {34227, -1, -1, -1}, {34229, -1, -1, -1}, {34237, -1, -1, -1}, {34247, -1, -1, -1}, {34244, -1, -1, -1}, {34239, -1, -1, -1}, {34251, -1, -1, -1}, {34254, -1, -1, -1}, {34248, -1, -1, -1}, {34245, -1, -1, -1}, {34225, -1, -1, -1}, {34230, -1, -1, -1}, {34258, -1, -1, -1}, {34340, -1, -1, -1}, {34232, -1, -1, -1}, {34231, -1, -1, -1}, {34238, -1, -1, -1}, {34409, -1, -1, -1}, {34791, -1, -1, -1}, {34790, -1, -1, -1}, {34786, -1, -1, -1}, {34779, -1, -1, -1}, {34795, -1, -1, -1}, {34794, -1, -1, -1}, {34789, -1, -1, -1}, {34783, -1, -1, -1}, {34803, -1, -1, -1}, {34788, -1, -1, -1}, {34772, -1, -1, -1}, {34780, -1, -1, -1}, {34771, -1, -1, -1}, {34797, -1, -1, -1}, {34776, -1, -1, -1}, {34787, -1, -1, -1}, {34775, -1, -1, -1}, {34777, -1, -1, -1}, {34817, -1, -1, -1}, {34804, -1, -1, -1}, {34792, -1, -1, -1}, {34781, -1, -1, -1}, {35155, -1, -1, -1}, {35147, -1, -1, -1}, {35151, -1, -1, -1}, {35148, -1, -1, -1}, {35142, -1, -1, -1}, {35152, -1, -1, -1}, {35153, -1, -1, -1}, {35145, -1, -1, -1}, {35626, -1, -1, -1}, {35623, -1, -1, -1}, {35619, -1, -1, -1}, {35635, -1, -1, -1}, {35632, -1, -1, -1}, {35637, -1, -1, -1}, {35655, -1, -1, -1}, {35631, -1, -1, -1}, {35644, -1, -1, -1}, {35646, -1, -1, -1}, {35633, -1, -1, -1}, {35621, -1, -1, -1}, {35639, -1, -1, -1}, {35622, -1, -1, -1}, {35638, -1, -1, -1}, {35630, -1, -1, -1}, {35620, -1, -1, -1}, {35643, -1, -1, -1}, {35645, -1, -1, -1}, {35642, -1, -1, -1}, {35906, -1, -1, -1}, {35957, -1, -1, -1}, {35993, -1, -1, -1}, {35992, -1, -1, -1}, {35991, -1, -1, -1}, {36094, -1, -1, -1}, {36100, -1, -1, -1}, {36098, -1, -1, -1}, {36096, -1, -1, -1}, {36444, -1, -1, -1}, {36450, -1, -1, -1}, {36448, -1, -1, -1}, {36439, -1, -1, -1}, {36438, -1, -1, -1}, {36446, -1, -1, -1}, {36453, -1, -1, -1}, {36455, -1, -1, -1}, {36443, -1, -1, -1}, {36442, -1, -1, -1}, {36449, -1, -1, -1}, {36445, -1, -1, -1}, {36457, -1, -1, -1}, {36436, -1, -1, -1}, {36678, -1, -1, -1}, {36679, -1, -1, -1}, {36680, -1, -1, -1}, {36683, -1, -1, -1}, {37160, -1, -1, -1}, {37178, -1, -1, -1}, {37179, -1, -1, -1}, {37182, -1, -1, -1}, {37288, -1, -1, -1} },
+ {{37285, -1, -1, -1}, {37287, -1, -1, -1}, {37295, -1, -1, -1}, {37290, -1, -1, -1}, {37813, -1, -1, -1}, {37772, -1, -1, -1}, {37778, -1, -1, -1}, {37815, -1, -1, -1}, {37787, -1, -1, -1}, {37789, -1, -1, -1}, {37769, -1, -1, -1}, {37799, -1, -1, -1}, {37774, -1, -1, -1}, {37802, -1, -1, -1}, {37790, -1, -1, -1}, {37798, -1, -1, -1}, {37781, -1, -1, -1}, {37768, -1, -1, -1}, {37785, -1, -1, -1}, {37791, -1, -1, -1}, {37760, -1, -1, -1}, {37773, -1, -1, -1}, {37809, -1, -1, -1}, {37777, -1, -1, -1}, {37810, -1, -1, -1}, {37796, -1, -1, -1}, {37800, -1, -1, -1}, {37812, -1, -1, -1}, {37795, -1, -1, -1}, {38354, -1, -1, -1}, {38355, -1, -1, -1}, {38353, -1, -1, -1}, {38579, -1, -1, -1}, {38615, -1, -1, -1}, {38618, -1, -1, -1}, {24002, -1, -1, -1}, {38623, -1, -1, -1}, {38616, -1, -1, -1}, {38621, -1, -1, -1}, {38691, -1, -1, -1}, {38690, -1, -1, -1}, {38693, -1, -1, -1}, {38828, -1, -1, -1}, {38830, -1, -1, -1}, {38824, -1, -1, -1}, {38827, -1, -1, -1}, {38820, -1, -1, -1}, {38826, -1, -1, -1}, {38818, -1, -1, -1}, {38821, -1, -1, -1}, {38871, -1, -1, -1}, {38873, -1, -1, -1}, {38870, -1, -1, -1}, {38872, -1, -1, -1}, {38906, -1, -1, -1}, {38992, -1, -1, -1}, {38993, -1, -1, -1}, {38994, -1, -1, -1}, {39096, -1, -1, -1}, {39233, -1, -1, -1}, {39228, -1, -1, -1}, {39226, -1, -1, -1}, {39439, -1, -1, -1}, {39435, -1, -1, -1}, {39433, -1, -1, -1}, {39437, -1, -1, -1}, {39428, -1, -1, -1}, {39441, -1, -1, -1}, {39434, -1, -1, -1}, {39429, -1, -1, -1}, {39431, -1, -1, -1}, {39430, -1, -1, -1}, {39616, -1, -1, -1}, {39644, -1, -1, -1}, {39688, -1, -1, -1}, {39684, -1, -1, -1}, {39685, -1, -1, -1}, {39721, -1, -1, -1}, {39733, -1, -1, -1}, {39754, -1, -1, -1}, {39756, -1, -1, -1}, {39755, -1, -1, -1}, {39879, -1, -1, -1}, {39878, -1, -1, -1}, {39875, -1, -1, -1}, {39871, -1, -1, -1}, {39873, -1, -1, -1}, {39861, -1, -1, -1}, {39864, -1, -1, -1}, {39891, -1, -1, -1}, {39862, -1, -1, -1}, {39876, -1, -1, -1}, {39865, -1, -1, -1}, {39869, -1, -1, -1}, {40284, -1, -1, -1}, {40275, -1, -1, -1}, {40271, -1, -1, -1}, {40266, -1, -1, -1}, {40283, -1, -1, -1}, {40267, -1, -1, -1}, {40281, -1, -1, -1}, {40278, -1, -1, -1}, {40268, -1, -1, -1}, {40279, -1, -1, -1}, {40274, -1, -1, -1}, {40276, -1, -1, -1}, {40287, -1, -1, -1}, {40280, -1, -1, -1}, {40282, -1, -1, -1}, {40590, -1, -1, -1}, {40588, -1, -1, -1}, {40671, -1, -1, -1}, {40705, -1, -1, -1}, {40704, -1, -1, -1}, {40726, -1, -1, -1}, {40741, -1, -1, -1}, {40747, -1, -1, -1}, {40746, -1, -1, -1}, {40745, -1, -1, -1}, {40744, -1, -1, -1}, {40780, -1, -1, -1}, {40789, -1, -1, -1}, {20788, -1, -1, -1}, {20789, -1, -1, -1}, {21142, -1, -1, -1}, {21239, -1, -1, -1}, {21428, -1, -1, -1}, {22187, -1, -1, -1}, {22189, -1, -1, -1}, {22182, -1, -1, -1}, {22183, -1, -1, -1}, {22186, -1, -1, -1}, {22188, -1, -1, -1}, {22746, -1, -1, -1}, {22749, -1, -1, -1}, {22747, -1, -1, -1}, {22802, -1, -1, -1}, {23357, -1, -1, -1}, {23358, -1, -1, -1}, {23359, -1, -1, -1}, {24003, -1, -1, -1}, {24176, -1, -1, -1}, {24511, -1, -1, -1}, {25083, -1, -1, -1}, {25863, -1, -1, -1}, {25872, -1, -1, -1}, {25869, -1, -1, -1}, {25865, -1, -1, -1}, {25868, -1, -1, -1}, {25870, -1, -1, -1}, {25988, -1, -1, -1}, {26078, -1, -1, -1}, {26077, -1, -1, -1}, {26334, -1, -1, -1}, {27367, -1, -1, -1}, {27360, -1, -1, -1}, {27340, -1, -1, -1}, {27345, -1, -1, -1}, {27353, -1, -1, -1}, {27339, -1, -1, -1}, {27359, -1, -1, -1}, {27356, -1, -1, -1}, {27344, -1, -1, -1}, {27371, -1, -1, -1}, {27343, -1, -1, -1}, {27341, -1, -1, -1}, {27358, -1, -1, -1}, {27488, -1, -1, -1}, {27568, -1, -1, -1}, {27660, -1, -1, -1}, {28697, -1, -1, -1}, {28711, -1, -1, -1}, {28704, -1, -1, -1}, {28694, -1, -1, -1}, {28715, -1, -1, -1}, {28705, -1, -1, -1}, {28706, -1, -1, -1}, {28707, -1, -1, -1}, {28713, -1, -1, -1}, {28695, -1, -1, -1}, {28708, -1, -1, -1}, {28700, -1, -1, -1}, {29196, -1, -1, -1}, {29194, -1, -1, -1}, {29191, -1, -1, -1}, {29186, -1, -1, -1}, {29189, -1, -1, -1}, {29349, -1, -1, -1}, {29350, -1, -1, -1}, {29348, -1, -1, -1}, {29347, -1, -1, -1}, {29345, -1, -1, -1}, {29899, -1, -1, -1}, {29893, -1, -1, -1}, {29879, -1, -1, -1}, {29891, -1, -1, -1}, {29974, -1, -1, -1}, {30304, -1, -1, -1}, {30665, -1, -1, -1}, {30666, -1, -1, -1}, {30660, -1, -1, -1}, {30705, -1, -1, -1}, {31005, -1, -1, -1}, {31003, -1, -1, -1}, {31009, -1, -1, -1}, {31004, -1, -1, -1}, {30999, -1, -1, -1}, {31006, -1, -1, -1}, {31152, -1, -1, -1}, {31335, -1, -1, -1}, {31336, -1, -1, -1}, {31795, -1, -1, -1}, {31804, -1, -1, -1}, {31801, -1, -1, -1}, {31788, -1, -1, -1}, {31803, -1, -1, -1}, {31980, -1, -1, -1}, {31978, -1, -1, -1}, {32374, -1, -1, -1}, {32373, -1, -1, -1}, {32376, -1, -1, -1}, {32368, -1, -1, -1}, {32375, -1, -1, -1}, {32367, -1, -1, -1}, {32378, -1, -1, -1}, {32370, -1, -1, -1}, {32372, -1, -1, -1}, {32360, -1, -1, -1}, {32587, -1, -1, -1}, {32586, -1, -1, -1}, {32643, -1, -1, -1}, {32646, -1, -1, -1}, {32695, -1, -1, -1}, {32765, -1, -1, -1}, {32766, -1, -1, -1}, {32888, -1, -1, -1}, {33239, -1, -1, -1}, {33237, -1, -1, -1}, {33291, -1, -1, -1}, {33380, -1, -1, -1}, {33377, -1, -1, -1}, {33379, -1, -1, -1}, {34283, -1, -1, -1}, {34289, -1, -1, -1}, {34285, -1, -1, -1}, {34265, -1, -1, -1}, {34273, -1, -1, -1}, {34280, -1, -1, -1}, {34266, -1, -1, -1}, {34263, -1, -1, -1}, {34284, -1, -1, -1}, {34290, -1, -1, -1}, {34296, -1, -1, -1}, {34264, -1, -1, -1}, {34271, -1, -1, -1}, {34275, -1, -1, -1} },
+ {{34268, -1, -1, -1}, {34257, -1, -1, -1}, {34288, -1, -1, -1}, {34278, -1, -1, -1}, {34287, -1, -1, -1}, {34270, -1, -1, -1}, {34274, -1, -1, -1}, {34816, -1, -1, -1}, {34810, -1, -1, -1}, {34819, -1, -1, -1}, {34806, -1, -1, -1}, {34807, -1, -1, -1}, {34825, -1, -1, -1}, {34828, -1, -1, -1}, {34827, -1, -1, -1}, {34822, -1, -1, -1}, {34812, -1, -1, -1}, {34824, -1, -1, -1}, {34815, -1, -1, -1}, {34826, -1, -1, -1}, {34818, -1, -1, -1}, {35170, -1, -1, -1}, {35162, -1, -1, -1}, {35163, -1, -1, -1}, {35159, -1, -1, -1}, {35169, -1, -1, -1}, {35164, -1, -1, -1}, {35160, -1, -1, -1}, {35165, -1, -1, -1}, {35161, -1, -1, -1}, {35208, -1, -1, -1}, {35255, -1, -1, -1}, {35254, -1, -1, -1}, {35318, -1, -1, -1}, {35664, -1, -1, -1}, {35656, -1, -1, -1}, {35658, -1, -1, -1}, {35648, -1, -1, -1}, {35667, -1, -1, -1}, {35670, -1, -1, -1}, {35668, -1, -1, -1}, {35659, -1, -1, -1}, {35669, -1, -1, -1}, {35665, -1, -1, -1}, {35650, -1, -1, -1}, {35666, -1, -1, -1}, {35671, -1, -1, -1}, {35907, -1, -1, -1}, {35959, -1, -1, -1}, {35958, -1, -1, -1}, {35994, -1, -1, -1}, {36102, -1, -1, -1}, {36103, -1, -1, -1}, {36105, -1, -1, -1}, {36268, -1, -1, -1}, {36266, -1, -1, -1}, {36269, -1, -1, -1}, {36267, -1, -1, -1}, {36461, -1, -1, -1}, {36472, -1, -1, -1}, {36467, -1, -1, -1}, {36458, -1, -1, -1}, {36463, -1, -1, -1}, {36475, -1, -1, -1}, {36546, -1, -1, -1}, {36690, -1, -1, -1}, {36689, -1, -1, -1}, {36687, -1, -1, -1}, {36688, -1, -1, -1}, {36691, -1, -1, -1}, {36788, -1, -1, -1}, {37184, -1, -1, -1}, {37183, -1, -1, -1}, {37296, -1, -1, -1}, {37293, -1, -1, -1}, {37854, -1, -1, -1}, {37831, -1, -1, -1}, {37839, -1, -1, -1}, {37826, -1, -1, -1}, {37850, -1, -1, -1}, {37840, -1, -1, -1}, {37881, -1, -1, -1}, {37868, -1, -1, -1}, {37836, -1, -1, -1}, {37849, -1, -1, -1}, {37801, -1, -1, -1}, {37862, -1, -1, -1}, {37834, -1, -1, -1}, {37844, -1, -1, -1}, {37870, -1, -1, -1}, {37859, -1, -1, -1}, {37845, -1, -1, -1}, {37828, -1, -1, -1}, {37838, -1, -1, -1}, {37824, -1, -1, -1}, {37842, -1, -1, -1}, {37797, -1, -1, -1}, {37863, -1, -1, -1}, {38269, -1, -1, -1}, {38362, -1, -1, -1}, {38363, -1, -1, -1}, {38625, -1, -1, -1}, {38697, -1, -1, -1}, {38699, -1, -1, -1}, {38700, -1, -1, -1}, {38696, -1, -1, -1}, {38694, -1, -1, -1}, {38835, -1, -1, -1}, {38839, -1, -1, -1}, {38838, -1, -1, -1}, {38877, -1, -1, -1}, {38878, -1, -1, -1}, {38879, -1, -1, -1}, {39004, -1, -1, -1}, {39001, -1, -1, -1}, {39005, -1, -1, -1}, {38999, -1, -1, -1}, {39103, -1, -1, -1}, {39101, -1, -1, -1}, {39099, -1, -1, -1}, {39102, -1, -1, -1}, {39240, -1, -1, -1}, {39239, -1, -1, -1}, {39235, -1, -1, -1}, {39334, -1, -1, -1}, {39335, -1, -1, -1}, {39450, -1, -1, -1}, {39445, -1, -1, -1}, {39461, -1, -1, -1}, {39453, -1, -1, -1}, {39460, -1, -1, -1}, {39451, -1, -1, -1}, {39458, -1, -1, -1}, {39456, -1, -1, -1}, {39463, -1, -1, -1}, {39459, -1, -1, -1}, {39454, -1, -1, -1}, {39452, -1, -1, -1}, {39444, -1, -1, -1}, {39618, -1, -1, -1}, {39691, -1, -1, -1}, {39690, -1, -1, -1}, {39694, -1, -1, -1}, {39692, -1, -1, -1}, {39735, -1, -1, -1}, {39914, -1, -1, -1}, {39915, -1, -1, -1}, {39904, -1, -1, -1}, {39902, -1, -1, -1}, {39908, -1, -1, -1}, {39910, -1, -1, -1}, {39906, -1, -1, -1}, {39920, -1, -1, -1}, {39892, -1, -1, -1}, {39895, -1, -1, -1}, {39916, -1, -1, -1}, {39900, -1, -1, -1}, {39897, -1, -1, -1}, {39909, -1, -1, -1}, {39893, -1, -1, -1}, {39905, -1, -1, -1}, {39898, -1, -1, -1}, {40311, -1, -1, -1}, {40321, -1, -1, -1}, {40330, -1, -1, -1}, {40324, -1, -1, -1}, {40328, -1, -1, -1}, {40305, -1, -1, -1}, {40320, -1, -1, -1}, {40312, -1, -1, -1}, {40326, -1, -1, -1}, {40331, -1, -1, -1}, {40332, -1, -1, -1}, {40317, -1, -1, -1}, {40299, -1, -1, -1}, {40308, -1, -1, -1}, {40309, -1, -1, -1}, {40304, -1, -1, -1}, {40297, -1, -1, -1}, {40325, -1, -1, -1}, {40307, -1, -1, -1}, {40315, -1, -1, -1}, {40322, -1, -1, -1}, {40303, -1, -1, -1}, {40313, -1, -1, -1}, {40319, -1, -1, -1}, {40327, -1, -1, -1}, {40296, -1, -1, -1}, {40596, -1, -1, -1}, {40593, -1, -1, -1}, {40640, -1, -1, -1}, {40700, -1, -1, -1}, {40749, -1, -1, -1}, {40768, -1, -1, -1}, {40769, -1, -1, -1}, {40781, -1, -1, -1}, {40790, -1, -1, -1}, {40791, -1, -1, -1}, {40792, -1, -1, -1}, {21303, -1, -1, -1}, {22194, -1, -1, -1}, {22197, -1, -1, -1}, {22195, -1, -1, -1}, {22755, -1, -1, -1}, {23365, -1, -1, -1}, {24006, -1, -1, -1}, {24007, -1, -1, -1}, {24302, -1, -1, -1}, {24303, -1, -1, -1}, {24512, -1, -1, -1}, {24513, -1, -1, -1}, {25081, -1, -1, -1}, {25879, -1, -1, -1}, {25878, -1, -1, -1}, {25877, -1, -1, -1}, {25875, -1, -1, -1}, {26079, -1, -1, -1}, {26344, -1, -1, -1}, {26339, -1, -1, -1}, {26340, -1, -1, -1}, {27379, -1, -1, -1}, {27376, -1, -1, -1}, {27370, -1, -1, -1}, {27368, -1, -1, -1}, {27385, -1, -1, -1}, {27377, -1, -1, -1}, {27374, -1, -1, -1}, {27375, -1, -1, -1}, {28732, -1, -1, -1}, {28725, -1, -1, -1}, {28719, -1, -1, -1}, {28727, -1, -1, -1}, {28724, -1, -1, -1}, {28721, -1, -1, -1}, {28738, -1, -1, -1}, {28728, -1, -1, -1}, {28735, -1, -1, -1}, {28730, -1, -1, -1}, {28729, -1, -1, -1}, {28714, -1, -1, -1}, {28736, -1, -1, -1}, {28731, -1, -1, -1}, {28723, -1, -1, -1}, {28737, -1, -1, -1}, {29203, -1, -1, -1}, {29204, -1, -1, -1}, {29352, -1, -1, -1}, {29565, -1, -1, -1}, {29564, -1, -1, -1}, {29882, -1, -1, -1}, {30379, -1, -1, -1}, {30378, -1, -1, -1}, {30398, -1, -1, -1}, {30445, -1, -1, -1}, {30668, -1, -1, -1}, {30670, -1, -1, -1} },
+ {{30671, -1, -1, -1}, {30669, -1, -1, -1}, {30706, -1, -1, -1}, {31013, -1, -1, -1}, {31011, -1, -1, -1}, {31015, -1, -1, -1}, {31016, -1, -1, -1}, {31012, -1, -1, -1}, {31017, -1, -1, -1}, {31154, -1, -1, -1}, {31342, -1, -1, -1}, {31340, -1, -1, -1}, {31341, -1, -1, -1}, {31479, -1, -1, -1}, {31817, -1, -1, -1}, {31816, -1, -1, -1}, {31818, -1, -1, -1}, {31815, -1, -1, -1}, {31813, -1, -1, -1}, {31982, -1, -1, -1}, {32379, -1, -1, -1}, {32382, -1, -1, -1}, {32385, -1, -1, -1}, {32384, -1, -1, -1}, {32698, -1, -1, -1}, {32767, -1, -1, -1}, {32889, -1, -1, -1}, {33243, -1, -1, -1}, {33241, -1, -1, -1}, {33384, -1, -1, -1}, {33385, -1, -1, -1}, {34338, -1, -1, -1}, {34303, -1, -1, -1}, {34305, -1, -1, -1}, {34302, -1, -1, -1}, {34331, -1, -1, -1}, {34304, -1, -1, -1}, {34294, -1, -1, -1}, {34308, -1, -1, -1}, {34313, -1, -1, -1}, {34309, -1, -1, -1}, {34316, -1, -1, -1}, {34301, -1, -1, -1}, {34841, -1, -1, -1}, {34832, -1, -1, -1}, {34833, -1, -1, -1}, {34839, -1, -1, -1}, {34835, -1, -1, -1}, {34838, -1, -1, -1}, {35171, -1, -1, -1}, {35174, -1, -1, -1}, {35257, -1, -1, -1}, {35319, -1, -1, -1}, {35680, -1, -1, -1}, {35690, -1, -1, -1}, {35677, -1, -1, -1}, {35688, -1, -1, -1}, {35683, -1, -1, -1}, {35685, -1, -1, -1}, {35687, -1, -1, -1}, {35693, -1, -1, -1}, {36270, -1, -1, -1}, {36486, -1, -1, -1}, {36488, -1, -1, -1}, {36484, -1, -1, -1}, {36697, -1, -1, -1}, {36694, -1, -1, -1}, {36695, -1, -1, -1}, {36693, -1, -1, -1}, {36696, -1, -1, -1}, {36698, -1, -1, -1}, {37005, -1, -1, -1}, {37187, -1, -1, -1}, {37185, -1, -1, -1}, {37303, -1, -1, -1}, {37301, -1, -1, -1}, {37298, -1, -1, -1}, {37299, -1, -1, -1}, {37899, -1, -1, -1}, {37907, -1, -1, -1}, {37883, -1, -1, -1}, {37920, -1, -1, -1}, {37903, -1, -1, -1}, {37908, -1, -1, -1}, {37886, -1, -1, -1}, {37909, -1, -1, -1}, {37904, -1, -1, -1}, {37928, -1, -1, -1}, {37913, -1, -1, -1}, {37901, -1, -1, -1}, {37877, -1, -1, -1}, {37888, -1, -1, -1}, {37879, -1, -1, -1}, {37895, -1, -1, -1}, {37902, -1, -1, -1}, {37910, -1, -1, -1}, {37906, -1, -1, -1}, {37882, -1, -1, -1}, {37897, -1, -1, -1}, {37880, -1, -1, -1}, {37948, -1, -1, -1}, {37898, -1, -1, -1}, {37887, -1, -1, -1}, {37884, -1, -1, -1}, {37900, -1, -1, -1}, {37878, -1, -1, -1}, {37905, -1, -1, -1}, {37894, -1, -1, -1}, {38366, -1, -1, -1}, {38368, -1, -1, -1}, {38367, -1, -1, -1}, {38702, -1, -1, -1}, {38703, -1, -1, -1}, {38841, -1, -1, -1}, {38843, -1, -1, -1}, {38909, -1, -1, -1}, {38910, -1, -1, -1}, {39008, -1, -1, -1}, {39010, -1, -1, -1}, {39011, -1, -1, -1}, {39007, -1, -1, -1}, {39105, -1, -1, -1}, {39106, -1, -1, -1}, {39248, -1, -1, -1}, {39246, -1, -1, -1}, {39257, -1, -1, -1}, {39244, -1, -1, -1}, {39243, -1, -1, -1}, {39251, -1, -1, -1}, {39474, -1, -1, -1}, {39476, -1, -1, -1}, {39473, -1, -1, -1}, {39468, -1, -1, -1}, {39466, -1, -1, -1}, {39478, -1, -1, -1}, {39465, -1, -1, -1}, {39470, -1, -1, -1}, {39480, -1, -1, -1}, {39469, -1, -1, -1}, {39623, -1, -1, -1}, {39626, -1, -1, -1}, {39622, -1, -1, -1}, {39696, -1, -1, -1}, {39698, -1, -1, -1}, {39697, -1, -1, -1}, {39947, -1, -1, -1}, {39944, -1, -1, -1}, {39927, -1, -1, -1}, {39941, -1, -1, -1}, {39954, -1, -1, -1}, {39928, -1, -1, -1}, {40000, -1, -1, -1}, {39943, -1, -1, -1}, {39950, -1, -1, -1}, {39942, -1, -1, -1}, {39959, -1, -1, -1}, {39956, -1, -1, -1}, {39945, -1, -1, -1}, {40351, -1, -1, -1}, {40345, -1, -1, -1}, {40356, -1, -1, -1}, {40349, -1, -1, -1}, {40338, -1, -1, -1}, {40344, -1, -1, -1}, {40336, -1, -1, -1}, {40347, -1, -1, -1}, {40352, -1, -1, -1}, {40340, -1, -1, -1}, {40348, -1, -1, -1}, {40362, -1, -1, -1}, {40343, -1, -1, -1}, {40353, -1, -1, -1}, {40346, -1, -1, -1}, {40354, -1, -1, -1}, {40360, -1, -1, -1}, {40350, -1, -1, -1}, {40355, -1, -1, -1}, {40383, -1, -1, -1}, {40361, -1, -1, -1}, {40342, -1, -1, -1}, {40358, -1, -1, -1}, {40359, -1, -1, -1}, {40601, -1, -1, -1}, {40603, -1, -1, -1}, {40602, -1, -1, -1}, {40677, -1, -1, -1}, {40676, -1, -1, -1}, {40679, -1, -1, -1}, {40678, -1, -1, -1}, {40752, -1, -1, -1}, {40750, -1, -1, -1}, {40795, -1, -1, -1}, {40800, -1, -1, -1}, {40798, -1, -1, -1}, {40797, -1, -1, -1}, {40793, -1, -1, -1}, {40849, -1, -1, -1}, {20794, -1, -1, -1}, {20793, -1, -1, -1}, {21144, -1, -1, -1}, {21143, -1, -1, -1}, {22211, -1, -1, -1}, {22205, -1, -1, -1}, {22206, -1, -1, -1}, {23368, -1, -1, -1}, {23367, -1, -1, -1}, {24011, -1, -1, -1}, {24015, -1, -1, -1}, {24305, -1, -1, -1}, {25085, -1, -1, -1}, {25883, -1, -1, -1}, {27394, -1, -1, -1}, {27388, -1, -1, -1}, {27395, -1, -1, -1}, {27384, -1, -1, -1}, {27392, -1, -1, -1}, {28739, -1, -1, -1}, {28740, -1, -1, -1}, {28746, -1, -1, -1}, {28744, -1, -1, -1}, {28745, -1, -1, -1}, {28741, -1, -1, -1}, {28742, -1, -1, -1}, {29213, -1, -1, -1}, {29210, -1, -1, -1}, {29209, -1, -1, -1}, {29566, -1, -1, -1}, {29975, -1, -1, -1}, {30314, -1, -1, -1}, {30672, -1, -1, -1}, {31021, -1, -1, -1}, {31025, -1, -1, -1}, {31023, -1, -1, -1}, {31828, -1, -1, -1}, {31827, -1, -1, -1}, {31986, -1, -1, -1}, {32394, -1, -1, -1}, {32391, -1, -1, -1}, {32392, -1, -1, -1}, {32395, -1, -1, -1}, {32390, -1, -1, -1}, {32397, -1, -1, -1}, {32589, -1, -1, -1}, {32699, -1, -1, -1}, {32816, -1, -1, -1}, {33245, -1, -1, -1}, {34328, -1, -1, -1}, {34346, -1, -1, -1}, {34342, -1, -1, -1}, {34335, -1, -1, -1}, {34339, -1, -1, -1}, {34332, -1, -1, -1}, {34329, -1, -1, -1}, {34343, -1, -1, -1}, {34350, -1, -1, -1}, {34337, -1, -1, -1} },
+ {{34336, -1, -1, -1}, {34345, -1, -1, -1}, {34334, -1, -1, -1}, {34341, -1, -1, -1}, {34857, -1, -1, -1}, {34845, -1, -1, -1}, {34843, -1, -1, -1}, {34848, -1, -1, -1}, {34852, -1, -1, -1}, {34844, -1, -1, -1}, {34859, -1, -1, -1}, {34890, -1, -1, -1}, {35181, -1, -1, -1}, {35177, -1, -1, -1}, {35182, -1, -1, -1}, {35179, -1, -1, -1}, {35322, -1, -1, -1}, {35705, -1, -1, -1}, {35704, -1, -1, -1}, {35653, -1, -1, -1}, {35706, -1, -1, -1}, {35707, -1, -1, -1}, {36112, -1, -1, -1}, {36116, -1, -1, -1}, {36271, -1, -1, -1}, {36494, -1, -1, -1}, {36492, -1, -1, -1}, {36702, -1, -1, -1}, {36699, -1, -1, -1}, {36701, -1, -1, -1}, {37190, -1, -1, -1}, {37188, -1, -1, -1}, {37189, -1, -1, -1}, {37305, -1, -1, -1}, {37951, -1, -1, -1}, {37947, -1, -1, -1}, {37942, -1, -1, -1}, {37929, -1, -1, -1}, {37949, -1, -1, -1}, {37936, -1, -1, -1}, {37945, -1, -1, -1}, {37930, -1, -1, -1}, {37943, -1, -1, -1}, {37932, -1, -1, -1}, {37952, -1, -1, -1}, {37937, -1, -1, -1}, {38373, -1, -1, -1}, {38372, -1, -1, -1}, {38371, -1, -1, -1}, {38709, -1, -1, -1}, {38714, -1, -1, -1}, {38847, -1, -1, -1}, {38881, -1, -1, -1}, {39012, -1, -1, -1}, {39113, -1, -1, -1}, {39110, -1, -1, -1}, {39104, -1, -1, -1}, {39256, -1, -1, -1}, {39254, -1, -1, -1}, {39481, -1, -1, -1}, {39485, -1, -1, -1}, {39494, -1, -1, -1}, {39492, -1, -1, -1}, {39490, -1, -1, -1}, {39489, -1, -1, -1}, {39482, -1, -1, -1}, {39487, -1, -1, -1}, {39629, -1, -1, -1}, {39701, -1, -1, -1}, {39703, -1, -1, -1}, {39704, -1, -1, -1}, {39702, -1, -1, -1}, {39738, -1, -1, -1}, {39762, -1, -1, -1}, {39979, -1, -1, -1}, {39965, -1, -1, -1}, {39964, -1, -1, -1}, {39980, -1, -1, -1}, {39971, -1, -1, -1}, {39976, -1, -1, -1}, {39977, -1, -1, -1}, {39972, -1, -1, -1}, {39969, -1, -1, -1}, {40375, -1, -1, -1}, {40374, -1, -1, -1}, {40380, -1, -1, -1}, {40385, -1, -1, -1}, {40391, -1, -1, -1}, {40394, -1, -1, -1}, {40399, -1, -1, -1}, {40382, -1, -1, -1}, {40389, -1, -1, -1}, {40387, -1, -1, -1}, {40379, -1, -1, -1}, {40373, -1, -1, -1}, {40398, -1, -1, -1}, {40377, -1, -1, -1}, {40378, -1, -1, -1}, {40364, -1, -1, -1}, {40392, -1, -1, -1}, {40369, -1, -1, -1}, {40365, -1, -1, -1}, {40396, -1, -1, -1}, {40371, -1, -1, -1}, {40397, -1, -1, -1}, {40370, -1, -1, -1}, {40570, -1, -1, -1}, {40604, -1, -1, -1}, {40683, -1, -1, -1}, {40686, -1, -1, -1}, {40685, -1, -1, -1}, {40731, -1, -1, -1}, {40728, -1, -1, -1}, {40730, -1, -1, -1}, {40753, -1, -1, -1}, {40782, -1, -1, -1}, {40805, -1, -1, -1}, {40804, -1, -1, -1}, {40850, -1, -1, -1}, {20153, -1, -1, -1}, {22214, -1, -1, -1}, {22213, -1, -1, -1}, {22219, -1, -1, -1}, {22897, -1, -1, -1}, {23371, -1, -1, -1}, {23372, -1, -1, -1}, {24021, -1, -1, -1}, {24017, -1, -1, -1}, {24306, -1, -1, -1}, {25889, -1, -1, -1}, {25888, -1, -1, -1}, {25894, -1, -1, -1}, {25890, -1, -1, -1}, {27403, -1, -1, -1}, {27400, -1, -1, -1}, {27401, -1, -1, -1}, {27661, -1, -1, -1}, {28757, -1, -1, -1}, {28758, -1, -1, -1}, {28759, -1, -1, -1}, {28754, -1, -1, -1}, {29214, -1, -1, -1}, {29215, -1, -1, -1}, {29353, -1, -1, -1}, {29567, -1, -1, -1}, {29912, -1, -1, -1}, {29909, -1, -1, -1}, {29913, -1, -1, -1}, {29911, -1, -1, -1}, {30317, -1, -1, -1}, {30381, -1, -1, -1}, {31029, -1, -1, -1}, {31156, -1, -1, -1}, {31344, -1, -1, -1}, {31345, -1, -1, -1}, {31831, -1, -1, -1}, {31836, -1, -1, -1}, {31833, -1, -1, -1}, {31835, -1, -1, -1}, {31834, -1, -1, -1}, {31988, -1, -1, -1}, {31985, -1, -1, -1}, {32401, -1, -1, -1}, {32591, -1, -1, -1}, {32647, -1, -1, -1}, {33246, -1, -1, -1}, {33387, -1, -1, -1}, {34356, -1, -1, -1}, {34357, -1, -1, -1}, {34355, -1, -1, -1}, {34348, -1, -1, -1}, {34354, -1, -1, -1}, {34358, -1, -1, -1}, {34860, -1, -1, -1}, {34856, -1, -1, -1}, {34854, -1, -1, -1}, {34858, -1, -1, -1}, {34853, -1, -1, -1}, {35185, -1, -1, -1}, {35263, -1, -1, -1}, {35262, -1, -1, -1}, {35323, -1, -1, -1}, {35710, -1, -1, -1}, {35716, -1, -1, -1}, {35714, -1, -1, -1}, {35718, -1, -1, -1}, {35717, -1, -1, -1}, {35711, -1, -1, -1}, {36117, -1, -1, -1}, {36501, -1, -1, -1}, {36500, -1, -1, -1}, {36506, -1, -1, -1}, {36498, -1, -1, -1}, {36496, -1, -1, -1}, {36502, -1, -1, -1}, {36503, -1, -1, -1}, {36704, -1, -1, -1}, {36706, -1, -1, -1}, {37191, -1, -1, -1}, {37964, -1, -1, -1}, {37968, -1, -1, -1}, {37962, -1, -1, -1}, {37963, -1, -1, -1}, {37967, -1, -1, -1}, {37959, -1, -1, -1}, {37957, -1, -1, -1}, {37960, -1, -1, -1}, {37961, -1, -1, -1}, {37958, -1, -1, -1}, {38719, -1, -1, -1}, {38883, -1, -1, -1}, {39018, -1, -1, -1}, {39017, -1, -1, -1}, {39115, -1, -1, -1}, {39252, -1, -1, -1}, {39259, -1, -1, -1}, {39502, -1, -1, -1}, {39507, -1, -1, -1}, {39508, -1, -1, -1}, {39500, -1, -1, -1}, {39503, -1, -1, -1}, {39496, -1, -1, -1}, {39498, -1, -1, -1}, {39497, -1, -1, -1}, {39506, -1, -1, -1}, {39504, -1, -1, -1}, {39632, -1, -1, -1}, {39705, -1, -1, -1}, {39723, -1, -1, -1}, {39739, -1, -1, -1}, {39766, -1, -1, -1}, {39765, -1, -1, -1}, {40006, -1, -1, -1}, {40008, -1, -1, -1}, {39999, -1, -1, -1}, {40004, -1, -1, -1}, {39993, -1, -1, -1}, {39987, -1, -1, -1}, {40001, -1, -1, -1}, {39996, -1, -1, -1}, {39991, -1, -1, -1}, {39988, -1, -1, -1}, {39986, -1, -1, -1}, {39997, -1, -1, -1}, {39990, -1, -1, -1}, {40411, -1, -1, -1}, {40402, -1, -1, -1}, {40414, -1, -1, -1}, {40410, -1, -1, -1}, {40395, -1, -1, -1}, {40400, -1, -1, -1}, {40412, -1, -1, -1}, {40401, -1, -1, -1}, {40415, -1, -1, -1}, {40425, -1, -1, -1}, {40409, -1, -1, -1} },
+ {{40408, -1, -1, -1}, {40406, -1, -1, -1}, {40437, -1, -1, -1}, {40405, -1, -1, -1}, {40413, -1, -1, -1}, {40630, -1, -1, -1}, {40688, -1, -1, -1}, {40757, -1, -1, -1}, {40755, -1, -1, -1}, {40754, -1, -1, -1}, {40770, -1, -1, -1}, {40811, -1, -1, -1}, {40853, -1, -1, -1}, {40866, -1, -1, -1}, {20797, -1, -1, -1}, {21145, -1, -1, -1}, {22760, -1, -1, -1}, {22759, -1, -1, -1}, {22898, -1, -1, -1}, {23373, -1, -1, -1}, {24024, -1, -1, -1}, {34863, -1, -1, -1}, {24399, -1, -1, -1}, {25089, -1, -1, -1}, {25091, -1, -1, -1}, {25092, -1, -1, -1}, {25897, -1, -1, -1}, {25893, -1, -1, -1}, {26006, -1, -1, -1}, {26347, -1, -1, -1}, {27409, -1, -1, -1}, {27410, -1, -1, -1}, {27407, -1, -1, -1}, {27594, -1, -1, -1}, {28763, -1, -1, -1}, {28762, -1, -1, -1}, {29218, -1, -1, -1}, {29570, -1, -1, -1}, {29569, -1, -1, -1}, {29571, -1, -1, -1}, {30320, -1, -1, -1}, {30676, -1, -1, -1}, {31847, -1, -1, -1}, {31846, -1, -1, -1}, {32405, -1, -1, -1}, {33388, -1, -1, -1}, {34362, -1, -1, -1}, {34368, -1, -1, -1}, {34361, -1, -1, -1}, {34364, -1, -1, -1}, {34353, -1, -1, -1}, {34363, -1, -1, -1}, {34366, -1, -1, -1}, {34864, -1, -1, -1}, {34866, -1, -1, -1}, {34862, -1, -1, -1}, {34867, -1, -1, -1}, {35190, -1, -1, -1}, {35188, -1, -1, -1}, {35187, -1, -1, -1}, {35326, -1, -1, -1}, {35724, -1, -1, -1}, {35726, -1, -1, -1}, {35723, -1, -1, -1}, {35720, -1, -1, -1}, {35909, -1, -1, -1}, {36121, -1, -1, -1}, {36504, -1, -1, -1}, {36708, -1, -1, -1}, {36707, -1, -1, -1}, {37308, -1, -1, -1}, {37986, -1, -1, -1}, {37973, -1, -1, -1}, {37981, -1, -1, -1}, {37975, -1, -1, -1}, {37982, -1, -1, -1}, {38852, -1, -1, -1}, {38853, -1, -1, -1}, {38912, -1, -1, -1}, {39510, -1, -1, -1}, {39513, -1, -1, -1}, {39710, -1, -1, -1}, {39711, -1, -1, -1}, {39712, -1, -1, -1}, {40018, -1, -1, -1}, {40024, -1, -1, -1}, {40016, -1, -1, -1}, {40010, -1, -1, -1}, {40013, -1, -1, -1}, {40011, -1, -1, -1}, {40021, -1, -1, -1}, {40025, -1, -1, -1}, {40012, -1, -1, -1}, {40014, -1, -1, -1}, {40443, -1, -1, -1}, {40439, -1, -1, -1}, {40431, -1, -1, -1}, {40419, -1, -1, -1}, {40427, -1, -1, -1}, {40440, -1, -1, -1}, {40420, -1, -1, -1}, {40438, -1, -1, -1}, {40417, -1, -1, -1}, {40430, -1, -1, -1}, {40422, -1, -1, -1}, {40434, -1, -1, -1}, {40432, -1, -1, -1}, {40418, -1, -1, -1}, {40428, -1, -1, -1}, {40436, -1, -1, -1}, {40435, -1, -1, -1}, {40424, -1, -1, -1}, {40429, -1, -1, -1}, {40642, -1, -1, -1}, {40656, -1, -1, -1}, {40690, -1, -1, -1}, {40691, -1, -1, -1}, {40710, -1, -1, -1}, {40732, -1, -1, -1}, {40760, -1, -1, -1}, {40759, -1, -1, -1}, {40758, -1, -1, -1}, {40771, -1, -1, -1}, {40783, -1, -1, -1}, {40817, -1, -1, -1}, {40816, -1, -1, -1}, {40814, -1, -1, -1}, {40815, -1, -1, -1}, {22227, -1, -1, -1}, {22221, -1, -1, -1}, {23374, -1, -1, -1}, {23661, -1, -1, -1}, {25901, -1, -1, -1}, {26349, -1, -1, -1}, {26350, -1, -1, -1}, {27411, -1, -1, -1}, {28767, -1, -1, -1}, {28769, -1, -1, -1}, {28765, -1, -1, -1}, {28768, -1, -1, -1}, {29219, -1, -1, -1}, {29915, -1, -1, -1}, {29925, -1, -1, -1}, {30677, -1, -1, -1}, {31032, -1, -1, -1}, {31159, -1, -1, -1}, {31158, -1, -1, -1}, {31850, -1, -1, -1}, {32407, -1, -1, -1}, {32649, -1, -1, -1}, {33389, -1, -1, -1}, {34371, -1, -1, -1}, {34872, -1, -1, -1}, {34871, -1, -1, -1}, {34869, -1, -1, -1}, {34891, -1, -1, -1}, {35732, -1, -1, -1}, {35733, -1, -1, -1}, {36510, -1, -1, -1}, {36511, -1, -1, -1}, {36512, -1, -1, -1}, {36509, -1, -1, -1}, {37310, -1, -1, -1}, {37309, -1, -1, -1}, {37314, -1, -1, -1}, {37995, -1, -1, -1}, {37992, -1, -1, -1}, {37993, -1, -1, -1}, {38629, -1, -1, -1}, {38726, -1, -1, -1}, {38723, -1, -1, -1}, {38727, -1, -1, -1}, {38855, -1, -1, -1}, {38885, -1, -1, -1}, {39518, -1, -1, -1}, {39637, -1, -1, -1}, {39769, -1, -1, -1}, {40035, -1, -1, -1}, {40039, -1, -1, -1}, {40038, -1, -1, -1}, {40034, -1, -1, -1}, {40030, -1, -1, -1}, {40032, -1, -1, -1}, {40450, -1, -1, -1}, {40446, -1, -1, -1}, {40455, -1, -1, -1}, {40451, -1, -1, -1}, {40454, -1, -1, -1}, {40453, -1, -1, -1}, {40448, -1, -1, -1}, {40449, -1, -1, -1}, {40457, -1, -1, -1}, {40447, -1, -1, -1}, {40445, -1, -1, -1}, {40452, -1, -1, -1}, {40608, -1, -1, -1}, {40734, -1, -1, -1}, {40774, -1, -1, -1}, {40820, -1, -1, -1}, {40821, -1, -1, -1}, {40822, -1, -1, -1}, {22228, -1, -1, -1}, {25902, -1, -1, -1}, {26040, -1, -1, -1}, {27416, -1, -1, -1}, {27417, -1, -1, -1}, {27415, -1, -1, -1}, {27418, -1, -1, -1}, {28770, -1, -1, -1}, {29222, -1, -1, -1}, {29354, -1, -1, -1}, {30680, -1, -1, -1}, {30681, -1, -1, -1}, {31033, -1, -1, -1}, {31849, -1, -1, -1}, {31851, -1, -1, -1}, {31990, -1, -1, -1}, {32410, -1, -1, -1}, {32408, -1, -1, -1}, {32411, -1, -1, -1}, {32409, -1, -1, -1}, {33248, -1, -1, -1}, {33249, -1, -1, -1}, {34374, -1, -1, -1}, {34375, -1, -1, -1}, {34376, -1, -1, -1}, {35193, -1, -1, -1}, {35194, -1, -1, -1}, {35196, -1, -1, -1}, {35195, -1, -1, -1}, {35327, -1, -1, -1}, {35736, -1, -1, -1}, {35737, -1, -1, -1}, {36517, -1, -1, -1}, {36516, -1, -1, -1}, {36515, -1, -1, -1}, {37998, -1, -1, -1}, {37997, -1, -1, -1}, {37999, -1, -1, -1}, {38001, -1, -1, -1}, {38003, -1, -1, -1}, {38729, -1, -1, -1}, {39026, -1, -1, -1}, {39263, -1, -1, -1}, {40040, -1, -1, -1}, {40046, -1, -1, -1}, {40045, -1, -1, -1}, {40459, -1, -1, -1}, {40461, -1, -1, -1}, {40464, -1, -1, -1}, {40463, -1, -1, -1}, {40466, -1, -1, -1}, {40465, -1, -1, -1}, {40609, -1, -1, -1}, {40693, -1, -1, -1}, {40713, -1, -1, -1} },
+ {{40775, -1, -1, -1}, {40824, -1, -1, -1}, {40827, -1, -1, -1}, {40826, -1, -1, -1}, {40825, -1, -1, -1}, {22302, -1, -1, -1}, {28774, -1, -1, -1}, {31855, -1, -1, -1}, {34876, -1, -1, -1}, {36274, -1, -1, -1}, {36518, -1, -1, -1}, {37315, -1, -1, -1}, {38004, -1, -1, -1}, {38008, -1, -1, -1}, {38006, -1, -1, -1}, {38005, -1, -1, -1}, {39520, -1, -1, -1}, {39726, -1, -1, -1}, {40052, -1, -1, -1}, {40051, -1, -1, -1}, {40049, -1, -1, -1}, {40053, -1, -1, -1}, {40468, -1, -1, -1}, {40467, -1, -1, -1}, {40694, -1, -1, -1}, {40714, -1, -1, -1}, {40868, -1, -1, -1}, {28776, -1, -1, -1}, {28773, -1, -1, -1}, {31991, -1, -1, -1}, {34410, -1, -1, -1}, {34878, -1, -1, -1}, {34877, -1, -1, -1}, {34879, -1, -1, -1}, {35742, -1, -1, -1}, {35996, -1, -1, -1}, {36521, -1, -1, -1}, {36553, -1, -1, -1}, {38731, -1, -1, -1}, {39027, -1, -1, -1}, {39028, -1, -1, -1}, {39116, -1, -1, -1}, {39265, -1, -1, -1}, {39339, -1, -1, -1}, {39524, -1, -1, -1}, {39526, -1, -1, -1}, {39527, -1, -1, -1}, {39716, -1, -1, -1}, {40469, -1, -1, -1}, {40471, -1, -1, -1}, {40776, -1, -1, -1}, {25095, -1, -1, -1}, {27422, -1, -1, -1}, {29223, -1, -1, -1}, {34380, -1, -1, -1}, {36520, -1, -1, -1}, {38018, -1, -1, -1}, {38016, -1, -1, -1}, {38017, -1, -1, -1}, {39529, -1, -1, -1}, {39528, -1, -1, -1}, {40473, -1, -1, -1}, {34379, -1, -1, -1}, {35743, -1, -1, -1}, {38019, -1, -1, -1}, {40057, -1, -1, -1}, {40631, -1, -1, -1}, {30325, -1, -1, -1}, {39531, -1, -1, -1}, {40058, -1, -1, -1}, {40477, -1, -1, -1}, {28777, -1, -1, -1}, {28778, -1, -1, -1}, {29225, -1, -1, -1}, {40612, -1, -1, -1}, {40830, -1, -1, -1}, {40777, -1, -1, -1}, {40856, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {65075, -1, -1, -1}, {-1, -1, -1, -1}, {65076, 65103, -1, -1}, {65103, -1, -1, -1}, {776, 168, -1, -1}, {710, 65342, -1, -1}, {12541, -1, -1, -1}, {12542, -1, -1, -1}, {12445, -1, -1, -1}, {12446, -1, -1, -1}, {-1, -1, -1, -1}, {12293, -1, -1, -1}, {12294, -1, -1, -1}, {12295, -1, -1, -1}, {12540, -1, -1, -1}, {65339, -1, -1, -1}, {65341, -1, -1, -1}, {10045, -1, -1, -1}, {12353, -1, -1, -1}, {12354, -1, -1, -1}, {12355, -1, -1, -1}, {12356, -1, -1, -1}, {12357, -1, -1, -1}, {12358, -1, -1, -1}, {12359, -1, -1, -1}, {12360, -1, -1, -1}, {12361, -1, -1, -1}, {12362, -1, -1, -1}, {12363, -1, -1, -1}, {12364, -1, -1, -1}, {12365, -1, -1, -1}, {12366, -1, -1, -1}, {12367, -1, -1, -1}, {12368, -1, -1, -1}, {12369, -1, -1, -1}, {12370, -1, -1, -1}, {12371, -1, -1, -1}, {12372, -1, -1, -1}, {12373, -1, -1, -1}, {12374, -1, -1, -1}, {12375, -1, -1, -1}, {12376, -1, -1, -1}, {12377, -1, -1, -1}, {12378, -1, -1, -1}, {12379, -1, -1, -1}, {12380, -1, -1, -1}, {12381, -1, -1, -1}, {12382, -1, -1, -1}, {12383, -1, -1, -1}, {12384, -1, -1, -1}, {12385, -1, -1, -1}, {12386, -1, -1, -1}, {12387, -1, -1, -1}, {12388, -1, -1, -1}, {12389, -1, -1, -1}, {12390, -1, -1, -1}, {12391, -1, -1, -1}, {12392, -1, -1, -1}, {12393, -1, -1, -1}, {12394, -1, -1, -1}, {12395, -1, -1, -1}, {12396, -1, -1, -1}, {12397, -1, -1, -1}, {12398, -1, -1, -1}, {12399, -1, -1, -1}, {12400, -1, -1, -1}, {12401, -1, -1, -1}, {12402, -1, -1, -1}, {12403, -1, -1, -1}, {12404, -1, -1, -1}, {12405, -1, -1, -1}, {12406, -1, -1, -1}, {12407, -1, -1, -1}, {12408, -1, -1, -1}, {12409, -1, -1, -1}, {12410, -1, -1, -1}, {12411, -1, -1, -1}, {12412, -1, -1, -1}, {12413, -1, -1, -1}, {12414, -1, -1, -1}, {12415, -1, -1, -1} },
+ {{12416, -1, -1, -1}, {12417, -1, -1, -1}, {12418, -1, -1, -1}, {12419, -1, -1, -1}, {12420, -1, -1, -1}, {12421, -1, -1, -1}, {12422, -1, -1, -1}, {12423, -1, -1, -1}, {12424, -1, -1, -1}, {12425, -1, -1, -1}, {12426, -1, -1, -1}, {12427, -1, -1, -1}, {12428, -1, -1, -1}, {12429, -1, -1, -1}, {12430, -1, -1, -1}, {12431, -1, -1, -1}, {12432, -1, -1, -1}, {12433, -1, -1, -1}, {12434, -1, -1, -1}, {12435, -1, -1, -1}, {12449, -1, -1, -1}, {12450, -1, -1, -1}, {12451, -1, -1, -1}, {12452, -1, -1, -1}, {12453, -1, -1, -1}, {12454, -1, -1, -1}, {12455, -1, -1, -1}, {12456, -1, -1, -1}, {12457, -1, -1, -1}, {12458, -1, -1, -1}, {12459, -1, -1, -1}, {12460, -1, -1, -1}, {12461, -1, -1, -1}, {12462, -1, -1, -1}, {12463, -1, -1, -1}, {12464, -1, -1, -1}, {12465, -1, -1, -1}, {12466, -1, -1, -1}, {12467, -1, -1, -1}, {12468, -1, -1, -1}, {12469, -1, -1, -1}, {12470, -1, -1, -1}, {12471, -1, -1, -1}, {12472, -1, -1, -1}, {12473, -1, -1, -1}, {12474, -1, -1, -1}, {12475, -1, -1, -1}, {12476, -1, -1, -1}, {12477, -1, -1, -1}, {12478, -1, -1, -1}, {12479, -1, -1, -1}, {12480, -1, -1, -1}, {12481, -1, -1, -1}, {12482, -1, -1, -1}, {12483, -1, -1, -1}, {12484, -1, -1, -1}, {12485, -1, -1, -1}, {12486, -1, -1, -1}, {12487, -1, -1, -1}, {12488, -1, -1, -1}, {12489, -1, -1, -1}, {12490, -1, -1, -1}, {12491, -1, -1, -1}, {12492, -1, -1, -1}, {12493, -1, -1, -1}, {12494, -1, -1, -1}, {12495, -1, -1, -1}, {12496, -1, -1, -1}, {12497, -1, -1, -1}, {12498, -1, -1, -1}, {12499, -1, -1, -1}, {12500, -1, -1, -1}, {12501, -1, -1, -1}, {12502, -1, -1, -1}, {12503, -1, -1, -1}, {12504, -1, -1, -1}, {12505, -1, -1, -1}, {12506, -1, -1, -1}, {12507, -1, -1, -1}, {12508, -1, -1, -1}, {12509, -1, -1, -1}, {12510, -1, -1, -1}, {12511, -1, -1, -1}, {12512, -1, -1, -1}, {12513, -1, -1, -1}, {12514, -1, -1, -1}, {12515, -1, -1, -1}, {12516, -1, -1, -1}, {12517, -1, -1, -1}, {12518, -1, -1, -1}, {12519, -1, -1, -1}, {12520, -1, -1, -1}, {12521, -1, -1, -1}, {12522, -1, -1, -1}, {12523, -1, -1, -1}, {12524, -1, -1, -1}, {12525, -1, -1, -1}, {12526, -1, -1, -1}, {12527, -1, -1, -1}, {12528, -1, -1, -1}, {12529, -1, -1, -1}, {12530, -1, -1, -1}, {12531, -1, -1, -1}, {12532, -1, -1, -1}, {12533, -1, -1, -1}, {12534, -1, -1, -1}, {1040, -1, -1, -1}, {1041, -1, -1, -1}, {1042, -1, -1, -1}, {1043, -1, -1, -1}, {1044, -1, -1, -1}, {1045, -1, -1, -1}, {1025, -1, -1, -1}, {1046, -1, -1, -1}, {1047, -1, -1, -1}, {1048, -1, -1, -1}, {1049, -1, -1, -1}, {1050, -1, -1, -1}, {1051, -1, -1, -1}, {1052, -1, -1, -1}, {1053, -1, -1, -1}, {1054, -1, -1, -1}, {1055, -1, -1, -1}, {1056, -1, -1, -1}, {1057, -1, -1, -1}, {1058, -1, -1, -1}, {1059, -1, -1, -1}, {1060, -1, -1, -1}, {1061, -1, -1, -1}, {1062, -1, -1, -1}, {1063, -1, -1, -1}, {1064, -1, -1, -1}, {1065, -1, -1, -1}, {1066, -1, -1, -1}, {1067, -1, -1, -1}, {1068, -1, -1, -1}, {1069, -1, -1, -1}, {1070, -1, -1, -1}, {1071, -1, -1, -1}, {1072, -1, -1, -1}, {1073, -1, -1, -1}, {1074, -1, -1, -1}, {1075, -1, -1, -1}, {1076, -1, -1, -1}, {1077, -1, -1, -1}, {1105, -1, -1, -1}, {1078, -1, -1, -1}, {1079, -1, -1, -1}, {1080, -1, -1, -1}, {1081, -1, -1, -1}, {1082, -1, -1, -1}, {1083, -1, -1, -1}, {1084, -1, -1, -1}, {1085, -1, -1, -1}, {1086, -1, -1, -1}, {1087, -1, -1, -1}, {1088, -1, -1, -1}, {1089, -1, -1, -1}, {1090, -1, -1, -1}, {1091, -1, -1, -1}, {1092, -1, -1, -1}, {1093, -1, -1, -1}, {1094, -1, -1, -1}, {1095, -1, -1, -1}, {1096, -1, -1, -1}, {1097, -1, -1, -1}, {1098, -1, -1, -1}, {1099, -1, -1, -1}, {1100, -1, -1, -1}, {1101, -1, -1, -1}, {1102, -1, -1, -1}, {1103, -1, -1, -1}, {8679, -1, -1, -1}, {8632, -1, -1, -1}, {8633, -1, -1, -1}, {20033, 63461, -1, -1}, {63462, -1, -1, -1}, {20058, -1, -1, -1}, {63464, -1, -1, -1}, {20994, -1, -1, -1}, {63466, -1, -1, -1}, {63467, -1, -1, -1}, {20872, -1, -1, -1}, {63469, -1, -1, -1}, {63470, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {172, 65506, -1, -1}, {65508, -1, -1, -1}, {65287, -1, -1, -1}, {65282, -1, -1, -1}, {12849, -1, -1, -1}, {8470, -1, -1, -1}, {8481, -1, -1, -1}, {30849, -1, -1, -1}, {37561, -1, -1, -1}, {35023, -1, -1, -1}, {22715, -1, -1, -1}, {24658, -1, -1, -1}, {31911, -1, -1, -1}, {23290, -1, -1, -1}, {9556, -1, -1, -1}, {9574, -1, -1, -1}, {9559, -1, -1, -1}, {9568, -1, -1, -1}, {9580, -1, -1, -1}, {9571, -1, -1, -1}, {9562, -1, -1, -1}, {9577, -1, -1, -1}, {9565, -1, -1, -1}, {9554, -1, -1, -1}, {9572, -1, -1, -1}, {9557, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9560, -1, -1, -1}, {9575, -1, -1, -1} },
+ {{9563, -1, -1, -1}, {9555, -1, -1, -1}, {9573, -1, -1, -1}, {9558, -1, -1, -1}, {9567, -1, -1, -1}, {9579, -1, -1, -1}, {9570, -1, -1, -1}, {9561, -1, -1, -1}, {9576, -1, -1, -1}, {9564, -1, -1, -1}, {9553, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9619, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {58129, -1, -1, -1}, {22462, -1, -1, -1}, {58131, -1, -1, -1}, {28990, -1, -1, -1}, {58133, -1, -1, -1}, {27042, -1, -1, -1}, {58136, -1, -1, -1}, {23412, -1, -1, -1}, {31305, -1, -1, -1}, {58139, -1, -1, -1}, {58140, -1, -1, -1}, {31333, -1, -1, -1}, {31357, -1, -1, -1}, {58143, -1, -1, -1}, {31419, -1, -1, -1}, {31408, -1, -1, -1}, {31426, -1, -1, -1}, {31427, -1, -1, -1}, {29137, -1, -1, -1}, {58149, -1, -1, -1}, {16842, -1, -1, -1}, {31450, -1, -1, -1}, {31453, -1, -1, -1}, {31466, -1, -1, -1}, {16879, -1, -1, -1}, {21682, -1, -1, -1}, {58156, -1, -1, -1}, {31499, -1, -1, -1}, {31573, -1, -1, -1}, {31529, -1, -1, -1}, {58160, -1, -1, -1}, {58161, -1, -1, -1}, {31650, -1, -1, -1}, {31599, -1, -1, -1}, {33692, -1, -1, -1}, {58165, -1, -1, -1}, {58166, -1, -1, -1}, {31696, -1, -1, -1}, {33825, -1, -1, -1}, {31634, -1, -1, -1}, {-1, -1, -1, -1}, {58171, -1, -1, -1}, {-1, -1, -1, -1}, {33938, -1, -1, -1}, {31738, -1, -1, -1}, {-1, -1, -1, -1}, {31797, -1, -1, -1}, {58178, -1, -1, -1}, {31812, -1, -1, -1}, {31875, -1, -1, -1}, {58181, -1, -1, -1}, {31910, -1, -1, -1}, {58184, -1, -1, -1}, {31945, -1, -1, -1}, {31943, -1, -1, -1}, {31974, -1, -1, -1}, {-1, -1, -1, -1}, {31987, -1, -1, -1}, {31989, -1, -1, -1}, {32359, -1, -1, -1}, {17693, -1, -1, -1}, {58194, -1, -1, -1}, {32093, -1, -1, -1}, {58196, -1, -1, -1}, {32137, -1, -1, -1}, {32171, -1, -1, -1}, {28981, -1, -1, -1}, {32179, -1, -1, -1}, {32214, -1, -1, -1}, {58203, -1, -1, -1}, {58204, -1, -1, -1}, {32228, -1, -1, -1}, {15635, -1, -1, -1}, {32245, -1, -1, -1}, {58208, -1, -1, -1}, {32229, -1, -1, -1}, {58210, -1, -1, -1}, {-1, -1, -1, -1}, {58212, -1, -1, -1}, {58213, -1, -1, -1}, {32366, -1, -1, -1}, {-1, -1, -1, -1}, {17195, -1, -1, -1}, {37996, -1, -1, -1}, {32295, -1, -1, -1}, {32576, -1, -1, -1}, {32577, -1, -1, -1}, {32583, -1, -1, -1}, {31030, -1, -1, -1}, {58223, -1, -1, -1}, {39393, -1, -1, -1}, {32663, -1, -1, -1}, {58226, -1, -1, -1}, {32675, -1, -1, -1}, {58228, -1, -1, -1}, {58229, -1, -1, -1}, {17756, -1, -1, -1}, {58231, -1, -1, -1}, {58233, -1, -1, -1}, {32762, -1, -1, -1}, {58235, -1, -1, -1}, {-1, -1, -1, -1}, {32776, -1, -1, -1}, {32797, -1, -1, -1}, {-1, -1, -1, -1}, {32815, -1, -1, -1}, {58241, -1, -1, -1}, {58242, -1, -1, -1}, {32827, -1, -1, -1}, {32828, -1, -1, -1}, {32865, -1, -1, -1}, {58246, -1, -1, -1}, {18825, -1, -1, -1}, {58248, -1, -1, -1}, {58249, -1, -1, -1}, {58250, -1, -1, -1}, {26405, -1, -1, -1}, {32935, -1, -1, -1}, {58253, -1, -1, -1}, {33031, -1, -1, -1}, {33050, -1, -1, -1}, {22704, -1, -1, -1}, {58257, -1, -1, -1}, {27775, -1, -1, -1}, {58259, -1, -1, -1}, {25831, -1, -1, -1}, {58262, -1, -1, -1}, {33304, -1, -1, -1}, {58264, -1, -1, -1}, {27219, -1, -1, -1}, {58266, -1, -1, -1}, {58267, -1, -1, -1}, {17530, -1, -1, -1}, {33321, -1, -1, -1}, {58271, -1, -1, -1}, {58272, -1, -1, -1}, {20473, -1, -1, -1}, {58274, -1, -1, -1}, {34018, -1, -1, -1}, {33634, -1, -1, -1}, {-1, -1, -1, -1}, {58278, -1, -1, -1}, {58279, -1, -1, -1}, {58280, -1, -1, -1}, {58281, -1, -1, -1}, {33450, -1, -1, -1}, {26907, -1, -1, -1}, {58284, -1, -1, -1}, {16859, -1, -1, -1}, {34123, -1, -1, -1}, {33488, -1, -1, -1}, {33562, -1, -1, -1}, {58289, -1, -1, -1}, {58290, -1, -1, -1}, {14017, -1, -1, -1}, {58292, -1, -1, -1}, {58293, -1, -1, -1}, {33403, -1, -1, -1}, {33506, -1, -1, -1}, {33560, -1, -1, -1}, {58297, -1, -1, -1}, {58298, -1, -1, -1}, {58299, -1, -1, -1}, {58300, -1, -1, -1}, {58301, -1, -1, -1}, {15807, -1, -1, -1}, {33565, -1, -1, -1}, {21996, -1, -1, -1}, {33669, -1, -1, -1}, {17675, -1, -1, -1}, {58307, -1, -1, -1}, {33708, -1, -1, -1}, {-1, -1, -1, -1}, {33747, -1, -1, -1}, {58312, -1, -1, -1}, {27223, -1, -1, -1}, {34138, -1, -1, -1}, {13462, -1, -1, -1}, {58316, -1, -1, -1}, {33880, -1, -1, -1}, {58319, -1, -1, -1}, {33905, -1, -1, -1}, {15827, -1, -1, -1}, {17636, -1, -1, -1}, {27303, -1, -1, -1}, {33866, -1, -1, -1}, {31064, -1, -1, -1}, {-1, -1, -1, -1}, {58328, -1, -1, -1}, {58329, -1, -1, -1}, {58330, -1, -1, -1}, {34014, -1, -1, -1}, {-1, -1, -1, -1}, {33681, -1, -1, -1}, {17568, -1, -1, -1}, {33939, -1, -1, -1}, {34020, -1, -1, -1}, {58337, -1, -1, -1}, {16960, -1, -1, -1}, {58339, -1, -1, -1}, {17731, -1, -1, -1}, {34100, -1, -1, -1}, {23282, -1, -1, -1}, {-1, -1, -1, -1}, {17703, -1, -1, -1}, {34163, -1, -1, -1}, {17686, -1, -1, -1}, {26559, -1, -1, -1}, {34326, -1, -1, -1}, {58349, -1, -1, -1}, {58350, -1, -1, -1}, {34241, -1, -1, -1}, {58352, -1, -1, -1} },
+ {{34306, -1, -1, -1}, {58354, -1, -1, -1}, {58355, -1, -1, -1}, {58356, -1, -1, -1}, {17770, -1, -1, -1}, {34344, -1, -1, -1}, {13896, -1, -1, -1}, {58360, -1, -1, -1}, {21495, -1, -1, -1}, {58362, -1, -1, -1}, {34430, -1, -1, -1}, {34673, -1, -1, -1}, {58365, -1, -1, -1}, {34798, -1, -1, -1}, {58367, -1, -1, -1}, {34737, -1, -1, -1}, {34778, -1, -1, -1}, {34831, -1, -1, -1}, {22113, -1, -1, -1}, {34412, -1, -1, -1}, {26710, -1, -1, -1}, {17935, -1, -1, -1}, {34885, -1, -1, -1}, {34886, -1, -1, -1}, {58377, -1, -1, -1}, {58378, -1, -1, -1}, {58379, -1, -1, -1}, {34910, -1, -1, -1}, {34972, -1, -1, -1}, {18011, -1, -1, -1}, {34996, -1, -1, -1}, {34997, -1, -1, -1}, {35013, -1, -1, -1}, {58388, -1, -1, -1}, {35207, -1, -1, -1}, {35210, -1, -1, -1}, {-1, -1, -1, -1}, {35241, -1, -1, -1}, {35239, -1, -1, -1}, {35260, -1, -1, -1}, {58395, -1, -1, -1}, {35303, -1, -1, -1}, {58397, -1, -1, -1}, {58398, -1, -1, -1}, {35484, -1, -1, -1}, {30611, -1, -1, -1}, {37374, -1, -1, -1}, {35472, -1, -1, -1}, {58403, -1, -1, -1}, {31465, -1, -1, -1}, {58405, -1, -1, -1}, {18195, -1, -1, -1}, {58408, -1, -1, -1}, {29052, -1, -1, -1}, {35596, -1, -1, -1}, {35615, -1, -1, -1}, {58412, -1, -1, -1}, {58413, -1, -1, -1}, {35647, -1, -1, -1}, {35660, -1, -1, -1}, {35661, -1, -1, -1}, {35497, -1, -1, -1}, {58418, -1, -1, -1}, {35728, -1, -1, -1}, {35739, -1, -1, -1}, {35503, -1, -1, -1}, {58422, -1, -1, -1}, {17941, -1, -1, -1}, {34895, -1, -1, -1}, {35995, -1, -1, -1}, {58426, -1, -1, -1}, {58427, -1, -1, -1}, {58428, -1, -1, -1}, {14117, -1, -1, -1}, {58430, -1, -1, -1}, {36054, -1, -1, -1}, {58432, -1, -1, -1}, {58433, -1, -1, -1}, {36114, -1, -1, -1}, {36099, -1, -1, -1}, {58436, -1, -1, -1}, {36059, -1, -1, -1}, {28764, -1, -1, -1}, {36113, -1, -1, -1}, {16080, -1, -1, -1}, {-1, -1, -1, -1}, {36265, -1, -1, -1}, {58444, -1, -1, -1}, {58445, -1, -1, -1}, {58446, -1, -1, -1}, {15228, -1, -1, -1}, {58448, -1, -1, -1}, {58449, -1, -1, -1}, {31463, -1, -1, -1}, {36525, -1, -1, -1}, {36534, -1, -1, -1}, {36547, -1, -1, -1}, {37588, -1, -1, -1}, {36633, -1, -1, -1}, {36653, -1, -1, -1}, {58457, -1, -1, -1}, {58458, -1, -1, -1}, {36773, -1, -1, -1}, {37635, -1, -1, -1}, {58461, -1, -1, -1}, {58462, -1, -1, -1}, {36787, -1, -1, -1}, {-1, -1, -1, -1}, {58465, -1, -1, -1}, {58466, -1, -1, -1}, {58467, -1, -1, -1}, {24312, -1, -1, -1}, {58469, -1, -1, -1}, {36857, -1, -1, -1}, {-1, -1, -1, -1}, {58474, -1, -1, -1}, {14720, -1, -1, -1}, {58476, -1, -1, -1}, {36919, -1, -1, -1}, {58478, -1, -1, -1}, {58479, -1, -1, -1}, {36961, -1, -1, -1}, {58481, -1, -1, -1}, {58482, -1, -1, -1}, {37032, -1, -1, -1}, {58484, -1, -1, -1}, {37060, -1, -1, -1}, {58486, -1, -1, -1}, {37038, -1, -1, -1}, {-1, -1, -1, -1}, {37223, -1, -1, -1}, {37289, -1, -1, -1}, {37316, -1, -1, -1}, {31916, -1, -1, -1}, {58494, -1, -1, -1}, {58495, -1, -1, -1}, {37390, -1, -1, -1}, {27807, -1, -1, -1}, {37441, -1, -1, -1}, {37474, -1, -1, -1}, {58500, -1, -1, -1}, {58502, -1, -1, -1}, {58503, -1, -1, -1}, {58504, -1, -1, -1}, {58505, -1, -1, -1}, {58506, -1, -1, -1}, {37676, -1, -1, -1}, {37739, -1, -1, -1}, {58509, -1, -1, -1}, {58510, -1, -1, -1}, {23235, -1, -1, -1}, {58513, -1, -1, -1}, {58514, -1, -1, -1}, {18789, -1, -1, -1}, {37444, -1, -1, -1}, {58517, -1, -1, -1}, {58518, -1, -1, -1}, {58519, -1, -1, -1}, {37747, -1, -1, -1}, {37979, -1, -1, -1}, {36540, -1, -1, -1}, {38277, -1, -1, -1}, {38310, -1, -1, -1}, {37926, -1, -1, -1}, {38304, -1, -1, -1}, {28662, -1, -1, -1}, {17081, -1, -1, -1}, {58530, -1, -1, -1}, {58531, -1, -1, -1}, {58532, -1, -1, -1}, {18911, -1, -1, -1}, {27676, -1, -1, -1}, {38523, -1, -1, -1}, {38550, -1, -1, -1}, {16748, -1, -1, -1}, {38563, -1, -1, -1}, {58539, -1, -1, -1}, {25050, -1, -1, -1}, {-1, -1, -1, -1}, {30965, -1, -1, -1}, {58543, -1, -1, -1}, {38589, -1, -1, -1}, {21452, -1, -1, -1}, {18849, -1, -1, -1}, {58547, -1, -1, -1}, {58548, -1, -1, -1}, {58549, -1, -1, -1}, {58550, -1, -1, -1}, {58551, -1, -1, -1}, {58552, -1, -1, -1}, {58553, -1, -1, -1}, {58554, -1, -1, -1}, {38705, -1, -1, -1}, {34370, -1, -1, -1}, {38710, -1, -1, -1}, {18959, -1, -1, -1}, {17725, -1, -1, -1}, {17797, -1, -1, -1}, {58561, -1, -1, -1}, {28789, -1, -1, -1}, {23361, -1, -1, -1}, {38683, -1, -1, -1}, {-1, -1, -1, -1}, {58566, -1, -1, -1}, {38743, -1, -1, -1}, {23370, -1, -1, -1}, {58569, -1, -1, -1}, {38751, -1, -1, -1}, {37925, -1, -1, -1}, {20688, -1, -1, -1}, {58573, -1, -1, -1}, {58574, -1, -1, -1}, {38793, -1, -1, -1}, {38815, -1, -1, -1}, {38833, -1, -1, -1}, {38846, -1, -1, -1}, {38848, -1, -1, -1}, {38866, -1, -1, -1}, {38880, -1, -1, -1}, {58582, -1, -1, -1}, {38894, -1, -1, -1}, {29724, -1, -1, -1}, {58585, -1, -1, -1}, {-1, -1, -1, -1}, {38901, -1, -1, -1}, {58588, -1, -1, -1}, {58589, -1, -1, -1}, {19153, -1, -1, -1}, {38964, -1, -1, -1}, {38963, -1, -1, -1}, {38987, -1, -1, -1}, {39014, -1, -1, -1}, {15118, -1, -1, -1}, {58596, -1, -1, -1}, {15697, -1, -1, -1}, {58598, -1, -1, -1}, {58599, -1, -1, -1}, {58600, -1, -1, -1}, {39114, -1, -1, -1}, {39095, -1, -1, -1}, {39112, -1, -1, -1}, {39111, -1, -1, -1}, {19199, -1, -1, -1}, {58606, -1, -1, -1}, {58607, -1, -1, -1}, {21936, -1, -1, -1}, {39137, -1, -1, -1}, {39142, -1, -1, -1}, {39148, -1, -1, -1}, {37752, -1, -1, -1}, {39225, -1, -1, -1}, {58614, -1, -1, -1}, {19314, -1, -1, -1}, {58616, -1, -1, -1}, {58617, -1, -1, -1}, {39413, -1, -1, -1} },
+ {{39436, -1, -1, -1}, {39483, -1, -1, -1}, {39440, -1, -1, -1}, {39512, -1, -1, -1}, {58623, -1, -1, -1}, {14020, -1, -1, -1}, {58625, -1, -1, -1}, {58626, -1, -1, -1}, {39648, -1, -1, -1}, {39650, -1, -1, -1}, {58629, -1, -1, -1}, {39668, -1, -1, -1}, {19470, -1, -1, -1}, {39700, -1, -1, -1}, {39725, -1, -1, -1}, {58634, -1, -1, -1}, {20532, -1, -1, -1}, {39732, -1, -1, -1}, {14531, -1, -1, -1}, {58639, -1, -1, -1}, {39760, -1, -1, -1}, {39744, -1, -1, -1}, {58642, -1, -1, -1}, {23109, -1, -1, -1}, {58644, -1, -1, -1}, {39822, -1, -1, -1}, {39938, -1, -1, -1}, {39935, -1, -1, -1}, {39948, -1, -1, -1}, {58650, -1, -1, -1}, {40404, -1, -1, -1}, {58652, -1, -1, -1}, {58653, -1, -1, -1}, {58654, -1, -1, -1}, {58655, -1, -1, -1}, {58656, -1, -1, -1}, {58657, -1, -1, -1}, {40318, -1, -1, -1}, {40323, -1, -1, -1}, {58660, -1, -1, -1}, {40462, -1, -1, -1}, {40388, -1, -1, -1}, {58665, -1, -1, -1}, {58666, -1, -1, -1}, {58667, -1, -1, -1}, {58668, -1, -1, -1}, {40249, -1, -1, -1}, {58670, -1, -1, -1}, {58671, -1, -1, -1}, {40592, -1, -1, -1}, {40597, -1, -1, -1}, {40606, -1, -1, -1}, {40610, -1, -1, -1}, {19764, -1, -1, -1}, {40618, -1, -1, -1}, {40623, -1, -1, -1}, {58679, -1, -1, -1}, {40641, -1, -1, -1}, {15200, -1, -1, -1}, {14821, -1, -1, -1}, {15645, -1, -1, -1}, {20274, -1, -1, -1}, {14270, -1, -1, -1}, {58686, -1, -1, -1}, {40706, -1, -1, -1}, {40712, -1, -1, -1}, {19350, -1, -1, -1}, {37924, -1, -1, -1}, {58691, -1, -1, -1}, {40727, -1, -1, -1}, {-1, -1, -1, -1}, {40761, -1, -1, -1}, {22175, -1, -1, -1}, {22154, -1, -1, -1}, {40773, -1, -1, -1}, {39352, -1, -1, -1}, {58699, -1, -1, -1}, {38898, -1, -1, -1}, {33919, -1, -1, -1}, {40802, -1, -1, -1}, {40809, -1, -1, -1}, {31452, -1, -1, -1}, {40846, -1, -1, -1}, {29206, -1, -1, -1}, {19390, -1, -1, -1}, {58708, -1, -1, -1}, {58709, -1, -1, -1}, {29047, -1, -1, -1}, {58711, -1, -1, -1}, {58712, -1, -1, -1}, {58713, -1, -1, -1}, {29598, -1, -1, -1}, {58715, -1, -1, -1}, {58716, -1, -1, -1}, {31135, -1, -1, -1}, {58718, -1, -1, -1}, {58719, -1, -1, -1}, {37737, -1, -1, -1}, {37875, -1, -1, -1}, {58722, -1, -1, -1}, {37612, -1, -1, -1}, {37761, -1, -1, -1}, {37835, -1, -1, -1}, {58726, -1, -1, -1}, {58727, -1, -1, -1}, {29207, -1, -1, -1}, {16107, -1, -1, -1}, {30578, -1, -1, -1}, {31299, -1, -1, -1}, {28880, -1, -1, -1}, {58733, -1, -1, -1}, {58734, -1, -1, -1}, {29054, -1, -1, -1}, {58736, -1, -1, -1}, {28835, -1, -1, -1}, {58738, -1, -1, -1}, {58739, -1, -1, -1}, {16071, -1, -1, -1}, {58741, -1, -1, -1}, {58742, -1, -1, -1}, {58743, -1, -1, -1}, {14114, -1, -1, -1}, {58745, -1, -1, -1}, {58746, -1, -1, -1}, {14049, -1, -1, -1}, {58748, -1, -1, -1}, {58749, -1, -1, -1}, {58750, -1, -1, -1}, {14115, -1, -1, -1}, {58752, -1, -1, -1}, {22363, -1, -1, -1}, {58754, -1, -1, -1}, {58755, -1, -1, -1}, {58756, -1, -1, -1}, {58757, -1, -1, -1}, {58758, -1, -1, -1}, {-1, -1, -1, -1}, {58760, -1, -1, -1}, {34051, -1, -1, -1}, {33877, -1, -1, -1}, {58763, -1, -1, -1}, {58764, -1, -1, -1}, {58765, -1, -1, -1}, {58766, -1, -1, -1}, {58767, -1, -1, -1}, {58768, -1, -1, -1}, {17652, -1, -1, -1}, {58770, -1, -1, -1}, {58771, -1, -1, -1}, {58772, -1, -1, -1}, {26617, -1, -1, -1}, {14131, -1, -1, -1}, {15381, -1, -1, -1}, {15847, -1, -1, -1}, {22636, -1, -1, -1}, {58778, -1, -1, -1}, {26640, -1, -1, -1}, {16471, -1, -1, -1}, {58781, -1, -1, -1}, {58782, -1, -1, -1}, {58783, -1, -1, -1}, {58784, -1, -1, -1}, {58785, -1, -1, -1}, {21707, -1, -1, -1}, {22174, -1, -1, -1}, {58788, -1, -1, -1}, {22162, -1, -1, -1}, {58790, -1, -1, -1}, {58791, -1, -1, -1}, {58792, -1, -1, -1}, {37830, -1, -1, -1}, {58794, -1, -1, -1}, {37788, -1, -1, -1}, {20216, -1, -1, -1}, {20779, -1, -1, -1}, {14361, -1, -1, -1}, {58799, -1, -1, -1}, {20156, -1, -1, -1}, {58801, -1, -1, -1}, {-1, -1, -1, -1}, {20299, -1, -1, -1}, {20362, -1, -1, -1}, {58805, -1, -1, -1}, {23144, -1, -1, -1}, {58807, -1, -1, -1}, {58808, -1, -1, -1}, {14745, -1, -1, -1}, {58810, -1, -1, -1}, {58811, -1, -1, -1}, {13365, -1, -1, -1}, {20265, -1, -1, -1}, {58814, -1, -1, -1}, {58815, -1, -1, -1}, {58816, -1, -1, -1}, {35546, -1, -1, -1}, {58818, -1, -1, -1}, {20120, -1, -1, -1}, {20685, -1, -1, -1}, {20749, -1, -1, -1}, {20386, -1, -1, -1}, {20227, -1, -1, -1}, {58824, -1, -1, -1}, {58825, -1, -1, -1}, {20290, -1, -1, -1}, {20526, -1, -1, -1}, {20588, -1, -1, -1}, {20609, -1, -1, -1}, {20428, -1, -1, -1}, {20453, -1, -1, -1}, {20568, -1, -1, -1}, {20732, -1, -1, -1}, {28278, -1, -1, -1}, {58839, -1, -1, -1}, {58840, -1, -1, -1}, {58841, -1, -1, -1}, {28018, -1, -1, -1}, {58843, -1, -1, -1}, {58844, -1, -1, -1}, {20904, -1, -1, -1}, {20931, -1, -1, -1}, {58847, -1, -1, -1}, {17629, -1, -1, -1}, {58849, -1, -1, -1}, {58850, -1, -1, -1}, {58851, -1, -1, -1}, {36218, -1, -1, -1}, {58853, -1, -1, -1}, {58854, -1, -1, -1}, {21081, -1, -1, -1}, {21156, -1, -1, -1}, {58857, -1, -1, -1}, {21217, -1, -1, -1}, {37742, -1, -1, -1}, {18042, -1, -1, -1}, {29068, -1, -1, -1}, {58862, -1, -1, -1}, {58863, -1, -1, -1}, {58864, -1, -1, -1}, {58865, -1, -1, -1}, {27089, -1, -1, -1}, {58867, -1, -1, -1}, {-1, -1, -1, -1}, {16094, -1, -1, -1}, {29849, -1, -1, -1}, {29716, -1, -1, -1}, {29782, -1, -1, -1}, {29592, -1, -1, -1}, {19342, -1, -1, -1}, {58875, -1, -1, -1}, {58876, -1, -1, -1}, {21456, -1, -1, -1}, {13700, -1, -1, -1}, {29199, -1, -1, -1}, {58880, -1, -1, -1}, {21940, -1, -1, -1}, {58882, -1, -1, -1} },
+ {{21709, -1, -1, -1}, {58884, -1, -1, -1}, {22301, -1, -1, -1}, {37469, -1, -1, -1}, {38644, -1, -1, -1}, {22493, -1, -1, -1}, {22413, -1, -1, -1}, {22399, -1, -1, -1}, {13886, -1, -1, -1}, {22731, -1, -1, -1}, {23193, -1, -1, -1}, {58895, -1, -1, -1}, {58896, -1, -1, -1}, {58897, -1, -1, -1}, {58898, -1, -1, -1}, {23084, -1, -1, -1}, {22968, -1, -1, -1}, {23166, -1, -1, -1}, {-1, -1, -1, -1}, {23058, -1, -1, -1}, {58905, -1, -1, -1}, {58906, -1, -1, -1}, {58907, -1, -1, -1}, {58908, -1, -1, -1}, {14069, -1, -1, -1}, {27909, -1, -1, -1}, {29763, -1, -1, -1}, {23073, -1, -1, -1}, {58913, -1, -1, -1}, {23169, -1, -1, -1}, {58915, -1, -1, -1}, {58916, -1, -1, -1}, {37856, -1, -1, -1}, {29836, -1, -1, -1}, {58919, -1, -1, -1}, {28933, -1, -1, -1}, {18802, -1, -1, -1}, {37896, -1, -1, -1}, {58923, -1, -1, -1}, {37821, -1, -1, -1}, {14240, -1, -1, -1}, {23582, -1, -1, -1}, {23710, -1, -1, -1}, {24158, -1, -1, -1}, {24136, -1, -1, -1}, {58930, -1, -1, -1}, {58931, -1, -1, -1}, {58932, -1, -1, -1}, {24269, -1, -1, -1}, {23375, -1, -1, -1}, {58935, -1, -1, -1}, {58936, -1, -1, -1}, {14081, -1, -1, -1}, {58938, -1, -1, -1}, {14045, -1, -1, -1}, {58940, -1, -1, -1}, {14035, -1, -1, -1}, {33066, -1, -1, -1}, {58943, -1, -1, -1}, {58944, -1, -1, -1}, {58945, -1, -1, -1}, {58946, -1, -1, -1}, {24332, -1, -1, -1}, {24334, -1, -1, -1}, {58949, -1, -1, -1}, {58950, -1, -1, -1}, {23147, -1, -1, -1}, {58952, -1, -1, -1}, {23364, -1, -1, -1}, {58955, -1, -1, -1}, {34912, -1, -1, -1}, {24702, -1, -1, -1}, {58958, -1, -1, -1}, {58959, -1, -1, -1}, {24539, -1, -1, -1}, {16056, -1, -1, -1}, {58962, -1, -1, -1}, {58963, -1, -1, -1}, {58964, -1, -1, -1}, {58965, -1, -1, -1}, {25024, -1, -1, -1}, {58967, -1, -1, -1}, {58968, -1, -1, -1}, {58969, -1, -1, -1}, {24985, -1, -1, -1}, {24984, -1, -1, -1}, {24693, -1, -1, -1}, {58973, -1, -1, -1}, {58974, -1, -1, -1}, {58975, -1, -1, -1}, {58976, -1, -1, -1}, {25713, -1, -1, -1}, {58978, -1, -1, -1}, {58979, -1, -1, -1}, {14889, -1, -1, -1}, {58981, -1, -1, -1}, {58982, -1, -1, -1}, {58983, -1, -1, -1}, {58984, -1, -1, -1}, {25399, -1, -1, -1}, {25782, -1, -1, -1}, {25393, -1, -1, -1}, {25553, -1, -1, -1}, {58990, -1, -1, -1}, {58991, -1, -1, -1}, {25252, -1, -1, -1}, {58993, -1, -1, -1}, {25659, -1, -1, -1}, {25963, -1, -1, -1}, {26994, -1, -1, -1}, {15348, -1, -1, -1}, {58998, -1, -1, -1}, {58999, -1, -1, -1}, {59000, -1, -1, -1}, {59001, -1, -1, -1}, {21773, -1, -1, -1}, {59003, -1, -1, -1}, {59004, -1, -1, -1}, {59005, -1, -1, -1}, {26318, -1, -1, -1}, {59007, -1, -1, -1}, {59008, -1, -1, -1}, {15072, -1, -1, -1}, {59011, -1, -1, -1}, {59012, -1, -1, -1}, {59013, -1, -1, -1}, {59014, -1, -1, -1}, {59015, -1, -1, -1}, {59016, -1, -1, -1}, {30958, -1, -1, -1}, {59018, -1, -1, -1}, {59019, -1, -1, -1}, {59020, -1, -1, -1}, {13412, -1, -1, -1}, {59022, -1, -1, -1}, {59023, -1, -1, -1}, {59024, -1, -1, -1}, {26254, -1, -1, -1}, {59026, -1, -1, -1}, {26219, -1, -1, -1}, {19347, -1, -1, -1}, {26160, -1, -1, -1}, {59030, -1, -1, -1}, {59031, -1, -1, -1}, {26211, -1, -1, -1}, {59033, -1, -1, -1}, {59034, -1, -1, -1}, {26142, -1, -1, -1}, {59036, -1, -1, -1}, {14545, -1, -1, -1}, {59038, -1, -1, -1}, {59039, -1, -1, -1}, {15257, -1, -1, -1}, {59041, -1, -1, -1}, {59042, -1, -1, -1}, {29904, -1, -1, -1}, {15254, -1, -1, -1}, {59046, -1, -1, -1}, {26806, -1, -1, -1}, {-1, -1, -1, -1}, {15300, -1, -1, -1}, {27326, -1, -1, -1}, {59052, -1, -1, -1}, {59053, -1, -1, -1}, {27187, -1, -1, -1}, {27218, -1, -1, -1}, {27337, -1, -1, -1}, {27397, -1, -1, -1}, {59058, -1, -1, -1}, {25873, -1, -1, -1}, {26776, -1, -1, -1}, {27212, -1, -1, -1}, {15319, -1, -1, -1}, {27258, -1, -1, -1}, {27479, -1, -1, -1}, {59065, -1, -1, -1}, {59066, -1, -1, -1}, {37792, -1, -1, -1}, {37618, -1, -1, -1}, {59069, -1, -1, -1}, {59070, -1, -1, -1}, {37513, -1, -1, -1}, {59072, -1, -1, -1}, {59073, -1, -1, -1}, {37991, -1, -1, -1}, {28069, -1, -1, -1}, {28427, -1, -1, -1}, {-1, -1, -1, -1}, {59079, -1, -1, -1}, {15759, -1, -1, -1}, {28164, -1, -1, -1}, {59082, -1, -1, -1}, {23101, -1, -1, -1}, {28170, -1, -1, -1}, {22599, -1, -1, -1}, {27940, -1, -1, -1}, {30786, -1, -1, -1}, {28987, -1, -1, -1}, {59089, -1, -1, -1}, {59090, -1, -1, -1}, {28913, -1, -1, -1}, {29264, -1, -1, -1}, {29319, -1, -1, -1}, {29332, -1, -1, -1}, {59095, -1, -1, -1}, {59096, -1, -1, -1}, {20857, -1, -1, -1}, {59098, -1, -1, -1}, {59099, -1, -1, -1}, {29818, -1, -1, -1}, {59101, -1, -1, -1}, {59102, -1, -1, -1}, {59103, -1, -1, -1}, {59104, -1, -1, -1}, {59105, -1, -1, -1}, {16134, -1, -1, -1}, {16049, -1, -1, -1}, {59108, -1, -1, -1}, {59109, -1, -1, -1}, {59110, -1, -1, -1}, {24743, -1, -1, -1}, {16115, -1, -1, -1}, {29900, -1, -1, -1}, {29756, -1, -1, -1}, {37767, -1, -1, -1}, {29751, -1, -1, -1}, {17567, -1, -1, -1}, {59118, -1, -1, -1}, {17745, -1, -1, -1}, {30083, -1, -1, -1}, {16227, -1, -1, -1}, {59122, -1, -1, -1}, {59123, -1, -1, -1}, {16216, -1, -1, -1}, {30037, -1, -1, -1}, {30323, -1, -1, -1}, {59127, -1, -1, -1}, {-1, -1, -1, -1}, {29800, -1, -1, -1}, {59130, -1, -1, -1}, {59131, -1, -1, -1}, {59132, -1, -1, -1}, {15099, -1, -1, -1}, {15821, -1, -1, -1}, {59135, -1, -1, -1}, {16127, -1, -1, -1}, {59137, -1, -1, -1}, {59138, -1, -1, -1}, {37370, -1, -1, -1}, {22322, -1, -1, -1}, {37698, -1, -1, -1}, {59142, -1, -1, -1}, {59143, -1, -1, -1}, {20703, -1, -1, -1}, {59145, -1, -1, -1}, {59146, -1, -1, -1} },
+ {{30584, -1, -1, -1}, {59148, -1, -1, -1}, {30478, -1, -1, -1}, {30479, -1, -1, -1}, {30587, -1, -1, -1}, {59152, -1, -1, -1}, {59153, -1, -1, -1}, {14942, -1, -1, -1}, {59155, -1, -1, -1}, {29752, -1, -1, -1}, {29851, -1, -1, -1}, {16063, -1, -1, -1}, {59159, -1, -1, -1}, {59160, -1, -1, -1}, {16584, -1, -1, -1}, {59162, -1, -1, -1}, {59163, -1, -1, -1}, {37639, -1, -1, -1}, {59165, -1, -1, -1}, {30750, -1, -1, -1}, {30861, -1, -1, -1}, {30856, -1, -1, -1}, {30930, -1, -1, -1}, {29648, -1, -1, -1}, {31065, -1, -1, -1}, {59172, -1, -1, -1}, {59173, -1, -1, -1}, {16654, -1, -1, -1}, {-1, -1, -1, -1}, {33942, -1, -1, -1}, {31141, -1, -1, -1}, {27181, -1, -1, -1}, {59179, -1, -1, -1}, {31290, -1, -1, -1}, {31220, -1, -1, -1}, {16750, -1, -1, -1}, {59183, -1, -1, -1}, {16690, -1, -1, -1}, {37429, -1, -1, -1}, {31217, -1, -1, -1}, {59187, -1, -1, -1}, {59188, -1, -1, -1}, {59189, -1, -1, -1}, {59190, -1, -1, -1}, {59191, -1, -1, -1}, {13719, -1, -1, -1}, {21867, -1, -1, -1}, {13680, -1, -1, -1}, {13994, -1, -1, -1}, {59196, -1, -1, -1}, {59197, -1, -1, -1}, {31458, -1, -1, -1}, {23129, -1, -1, -1}, {59200, -1, -1, -1}, {59201, -1, -1, -1}, {59202, -1, -1, -1}, {23053, -1, -1, -1}, {59204, -1, -1, -1}, {30960, -1, -1, -1}, {23082, -1, -1, -1}, {59207, -1, -1, -1}, {31486, -1, -1, -1}, {16889, -1, -1, -1}, {31837, -1, -1, -1}, {31853, -1, -1, -1}, {16913, -1, -1, -1}, {59213, -1, -1, -1}, {59214, -1, -1, -1}, {59215, -1, -1, -1}, {31949, -1, -1, -1}, {59217, -1, -1, -1}, {59218, -1, -1, -1}, {31886, -1, -1, -1}, {31868, -1, -1, -1}, {31918, -1, -1, -1}, {27314, -1, -1, -1}, {32220, -1, -1, -1}, {32263, -1, -1, -1}, {32211, -1, -1, -1}, {32590, -1, -1, -1}, {59227, -1, -1, -1}, {59228, -1, -1, -1}, {59229, -1, -1, -1}, {32151, -1, -1, -1}, {59231, -1, -1, -1}, {17002, -1, -1, -1}, {59233, -1, -1, -1}, {59234, -1, -1, -1}, {26582, -1, -1, -1}, {59236, -1, -1, -1}, {59237, -1, -1, -1}, {22468, -1, -1, -1}, {59239, -1, -1, -1}, {59240, -1, -1, -1}, {32733, -1, -1, -1}, {31527, -1, -1, -1}, {59244, -1, -1, -1}, {59245, -1, -1, -1}, {59246, -1, -1, -1}, {31500, -1, -1, -1}, {59248, -1, -1, -1}, {39398, -1, -1, -1}, {34373, -1, -1, -1}, {39523, -1, -1, -1}, {27164, -1, -1, -1}, {59253, -1, -1, -1}, {59255, -1, -1, -1}, {59256, -1, -1, -1}, {39455, -1, -1, -1}, {59258, -1, -1, -1}, {33920, -1, -1, -1}, {59260, -1, -1, -1}, {59261, -1, -1, -1}, {17642, -1, -1, -1}, {33079, -1, -1, -1}, {17410, -1, -1, -1}, {32966, -1, -1, -1}, {33033, -1, -1, -1}, {33090, -1, -1, -1}, {59268, -1, -1, -1}, {39107, -1, -1, -1}, {59270, -1, -1, -1}, {33378, -1, -1, -1}, {33381, -1, -1, -1}, {59273, -1, -1, -1}, {33875, -1, -1, -1}, {59275, -1, -1, -1}, {34320, -1, -1, -1}, {59277, -1, -1, -1}, {23174, -1, -1, -1}, {16767, -1, -1, -1}, {59280, -1, -1, -1}, {23339, -1, -1, -1}, {59282, -1, -1, -1}, {23268, -1, -1, -1}, {59284, -1, -1, -1}, {34464, -1, -1, -1}, {59286, -1, -1, -1}, {59287, -1, -1, -1}, {34861, -1, -1, -1}, {59289, -1, -1, -1}, {23042, -1, -1, -1}, {34926, -1, -1, -1}, {20293, -1, -1, -1}, {34951, -1, -1, -1}, {35007, -1, -1, -1}, {35046, -1, -1, -1}, {35173, -1, -1, -1}, {35149, -1, -1, -1}, {59298, -1, -1, -1}, {35156, -1, -1, -1}, {59300, -1, -1, -1}, {59301, -1, -1, -1}, {59302, -1, -1, -1}, {59303, -1, -1, -1}, {59304, -1, -1, -1}, {59305, -1, -1, -1}, {16045, -1, -1, -1}, {33955, -1, -1, -1}, {18165, -1, -1, -1}, {18127, -1, -1, -1}, {14322, -1, -1, -1}, {35389, -1, -1, -1}, {35356, -1, -1, -1}, {59313, -1, -1, -1}, {24397, -1, -1, -1}, {37419, -1, -1, -1}, {59316, -1, -1, -1}, {26068, -1, -1, -1}, {28969, -1, -1, -1}, {28868, -1, -1, -1}, {59320, -1, -1, -1}, {40301, -1, -1, -1}, {35999, -1, -1, -1}, {36073, -1, -1, -1}, {59324, -1, -1, -1}, {22938, -1, -1, -1}, {30659, -1, -1, -1}, {23024, -1, -1, -1}, {14036, -1, -1, -1}, {36394, -1, -1, -1}, {36519, -1, -1, -1}, {59332, -1, -1, -1}, {36656, -1, -1, -1}, {36682, -1, -1, -1}, {17140, -1, -1, -1}, {27736, -1, -1, -1}, {28603, -1, -1, -1}, {59338, -1, -1, -1}, {18587, -1, -1, -1}, {28537, -1, -1, -1}, {28299, -1, -1, -1}, {59342, -1, -1, -1}, {39913, -1, -1, -1}, {14005, -1, -1, -1}, {59345, -1, -1, -1}, {37051, -1, -1, -1}, {-1, -1, -1, -1}, {21873, -1, -1, -1}, {18694, -1, -1, -1}, {37307, -1, -1, -1}, {37892, -1, -1, -1}, {59352, -1, -1, -1}, {16482, -1, -1, -1}, {59354, -1, -1, -1}, {37927, -1, -1, -1}, {59356, -1, -1, -1}, {59357, -1, -1, -1}, {34021, -1, -1, -1}, {35371, -1, -1, -1}, {38297, -1, -1, -1}, {38311, -1, -1, -1}, {38295, -1, -1, -1}, {38294, -1, -1, -1}, {59364, -1, -1, -1}, {29765, -1, -1, -1}, {16066, -1, -1, -1}, {59367, -1, -1, -1}, {59368, -1, -1, -1}, {59369, -1, -1, -1}, {16103, -1, -1, -1}, {59371, -1, -1, -1}, {38543, -1, -1, -1}, {59373, -1, -1, -1}, {59374, -1, -1, -1}, {59375, -1, -1, -1}, {16076, -1, -1, -1}, {59377, -1, -1, -1}, {59378, -1, -1, -1}, {59379, -1, -1, -1}, {29714, -1, -1, -1}, {29803, -1, -1, -1}, {16124, -1, -1, -1}, {38721, -1, -1, -1}, {59384, -1, -1, -1}, {26695, -1, -1, -1}, {18973, -1, -1, -1}, {59387, -1, -1, -1}, {59388, -1, -1, -1}, {38749, -1, -1, -1}, {37736, -1, -1, -1}, {59391, -1, -1, -1}, {59392, -1, -1, -1}, {59393, -1, -1, -1}, {59394, -1, -1, -1}, {37562, -1, -1, -1}, {23313, -1, -1, -1}, {35689, -1, -1, -1}, {18748, -1, -1, -1}, {29689, -1, -1, -1}, {59400, -1, -1, -1}, {38811, -1, -1, -1}, {38769, -1, -1, -1}, {39224, -1, -1, -1}, {59404, -1, -1, -1}, {24001, -1, -1, -1} },
+ {{59406, -1, -1, -1}, {59407, -1, -1, -1}, {38943, -1, -1, -1}, {59409, -1, -1, -1}, {37622, -1, -1, -1}, {59411, -1, -1, -1}, {37349, -1, -1, -1}, {17600, -1, -1, -1}, {59414, -1, -1, -1}, {59415, -1, -1, -1}, {59416, -1, -1, -1}, {39132, -1, -1, -1}, {59418, -1, -1, -1}, {16128, -1, -1, -1}, {37418, -1, -1, -1}, {18725, -1, -1, -1}, {33812, -1, -1, -1}, {39227, -1, -1, -1}, {39245, -1, -1, -1}, {59425, -1, -1, -1}, {15869, -1, -1, -1}, {39323, -1, -1, -1}, {19311, -1, -1, -1}, {39338, -1, -1, -1}, {39516, -1, -1, -1}, {59431, -1, -1, -1}, {59432, -1, -1, -1}, {27279, -1, -1, -1}, {39457, -1, -1, -1}, {23294, -1, -1, -1}, {39471, -1, -1, -1}, {59437, -1, -1, -1}, {19344, -1, -1, -1}, {59439, -1, -1, -1}, {39356, -1, -1, -1}, {19389, -1, -1, -1}, {19351, -1, -1, -1}, {37757, -1, -1, -1}, {22642, -1, -1, -1}, {59445, -1, -1, -1}, {22562, -1, -1, -1}, {59447, -1, -1, -1}, {59448, -1, -1, -1}, {30788, -1, -1, -1}, {59450, -1, -1, -1}, {59451, -1, -1, -1}, {26821, -1, -1, -1}, {15741, -1, -1, -1}, {37976, -1, -1, -1}, {14631, -1, -1, -1}, {24912, -1, -1, -1}, {59457, -1, -1, -1}, {59458, -1, -1, -1}, {24839, -1, -1, -1}, {40015, -1, -1, -1}, {40019, -1, -1, -1}, {40059, -1, -1, -1}, {39989, -1, -1, -1}, {39952, -1, -1, -1}, {39807, -1, -1, -1}, {39887, -1, -1, -1}, {59467, -1, -1, -1}, {39839, -1, -1, -1}, {59469, -1, -1, -1}, {59470, -1, -1, -1}, {40225, -1, -1, -1}, {19630, -1, -1, -1}, {59473, -1, -1, -1}, {40472, -1, -1, -1}, {19632, -1, -1, -1}, {40204, -1, -1, -1}, {59477, -1, -1, -1}, {59478, -1, -1, -1}, {59479, -1, -1, -1}, {59480, -1, -1, -1}, {40357, -1, -1, -1}, {33981, -1, -1, -1}, {59483, -1, -1, -1}, {59484, -1, -1, -1}, {59485, -1, -1, -1}, {34300, -1, -1, -1}, {17715, -1, -1, -1}, {59488, -1, -1, -1}, {59489, -1, -1, -1}, {59490, -1, -1, -1}, {33824, -1, -1, -1}, {34286, -1, -1, -1}, {59493, -1, -1, -1}, {59494, -1, -1, -1}, {59495, -1, -1, -1}, {31202, -1, -1, -1}, {59497, -1, -1, -1}, {59498, -1, -1, -1}, {59500, -1, -1, -1}, {15714, -1, -1, -1}, {37851, -1, -1, -1}, {37566, -1, -1, -1}, {37704, -1, -1, -1}, {59505, -1, -1, -1}, {30905, -1, -1, -1}, {37495, -1, -1, -1}, {37965, -1, -1, -1}, {20452, -1, -1, -1}, {13376, -1, -1, -1}, {36964, -1, -1, -1}, {59512, -1, -1, -1}, {30781, -1, -1, -1}, {30804, -1, -1, -1}, {30902, -1, -1, -1}, {30795, -1, -1, -1}, {59517, -1, -1, -1}, {59518, -1, -1, -1}, {59519, -1, -1, -1}, {13978, -1, -1, -1}, {20338, -1, -1, -1}, {28634, -1, -1, -1}, {28633, -1, -1, -1}, {-1, -1, -1, -1}, {28702, -1, -1, -1}, {21524, -1, -1, -1}, {59527, -1, -1, -1}, {22459, -1, -1, -1}, {22771, -1, -1, -1}, {22410, -1, -1, -1}, {40214, -1, -1, -1}, {22487, -1, -1, -1}, {28980, -1, -1, -1}, {13487, -1, -1, -1}, {59535, -1, -1, -1}, {29163, -1, -1, -1}, {59537, -1, -1, -1}, {59538, -1, -1, -1}, {-1, -1, -1, -1}, {59540, -1, -1, -1}, {59541, -1, -1, -1}, {24844, -1, -1, -1}, {23246, -1, -1, -1}, {23051, -1, -1, -1}, {17084, -1, -1, -1}, {59546, -1, -1, -1}, {14124, -1, -1, -1}, {19323, -1, -1, -1}, {59549, -1, -1, -1}, {37819, -1, -1, -1}, {37816, -1, -1, -1}, {59552, -1, -1, -1}, {59553, -1, -1, -1}, {33906, -1, -1, -1}, {59555, -1, -1, -1}, {59556, -1, -1, -1}, {59557, -1, -1, -1}, {59558, -1, -1, -1}, {59559, -1, -1, -1}, {22932, -1, -1, -1}, {59561, -1, -1, -1}, {59562, -1, -1, -1}, {32168, -1, -1, -1}, {59564, -1, -1, -1}, {59565, -1, -1, -1}, {59566, -1, -1, -1}, {59567, -1, -1, -1}, {59568, -1, -1, -1}, {37605, -1, -1, -1}, {29666, -1, -1, -1}, {16105, -1, -1, -1}, {29876, -1, -1, -1}, {59573, -1, -1, -1}, {59574, -1, -1, -1}, {16097, -1, -1, -1}, {59576, -1, -1, -1}, {27352, -1, -1, -1}, {29683, -1, -1, -1}, {29691, -1, -1, -1}, {16086, -1, -1, -1}, {59581, -1, -1, -1}, {59582, -1, -1, -1}, {59583, -1, -1, -1}, {59584, -1, -1, -1}, {59585, -1, -1, -1}, {59586, -1, -1, -1}, {59587, -1, -1, -1}, {29768, -1, -1, -1}, {59589, -1, -1, -1}, {28837, -1, -1, -1}, {59591, -1, -1, -1}, {37508, -1, -1, -1}, {29670, -1, -1, -1}, {37727, -1, -1, -1}, {59595, -1, -1, -1}, {37681, -1, -1, -1}, {59597, -1, -1, -1}, {59598, -1, -1, -1}, {37766, -1, -1, -1}, {59600, -1, -1, -1}, {59601, -1, -1, -1}, {18741, -1, -1, -1}, {59603, -1, -1, -1}, {29035, -1, -1, -1}, {59605, -1, -1, -1}, {59606, -1, -1, -1}, {22180, -1, -1, -1}, {59608, -1, -1, -1}, {59609, -1, -1, -1}, {59610, -1, -1, -1}, {21762, -1, -1, -1}, {31172, -1, -1, -1}, {59613, -1, -1, -1}, {32254, -1, -1, -1}, {59615, -1, -1, -1}, {59616, -1, -1, -1}, {59617, -1, -1, -1}, {17710, -1, -1, -1}, {37889, -1, -1, -1}, {14090, -1, -1, -1}, {59621, -1, -1, -1}, {59622, -1, -1, -1}, {22960, -1, -1, -1}, {59624, -1, -1, -1}, {59625, -1, -1, -1}, {59626, -1, -1, -1}, {23201, -1, -1, -1}, {14050, -1, -1, -1}, {59629, -1, -1, -1}, {14000, -1, -1, -1}, {37471, -1, -1, -1}, {23161, -1, -1, -1}, {59633, -1, -1, -1}, {59634, -1, -1, -1}, {37748, -1, -1, -1}, {15565, -1, -1, -1}, {59637, -1, -1, -1}, {19094, -1, -1, -1}, {14730, -1, -1, -1}, {20724, -1, -1, -1}, {15721, -1, -1, -1}, {15692, -1, -1, -1}, {59643, -1, -1, -1}, {29045, -1, -1, -1}, {17147, -1, -1, -1}, {59646, -1, -1, -1}, {28175, -1, -1, -1}, {59648, -1, -1, -1}, {17643, -1, -1, -1}, {27991, -1, -1, -1}, {59651, -1, -1, -1}, {28775, -1, -1, -1}, {27823, -1, -1, -1}, {15574, -1, -1, -1}, {59655, -1, -1, -1}, {59656, -1, -1, -1}, {28162, -1, -1, -1}, {28428, -1, -1, -1}, {15727, -1, -1, -1}, {59660, -1, -1, -1}, {30033, -1, -1, -1}, {14012, -1, -1, -1} },
+ {{13512, -1, -1, -1}, {18048, -1, -1, -1}, {16090, -1, -1, -1}, {18545, -1, -1, -1}, {22980, -1, -1, -1}, {37486, -1, -1, -1}, {18750, -1, -1, -1}, {36673, -1, -1, -1}, {59671, -1, -1, -1}, {59672, -1, -1, -1}, {22546, -1, -1, -1}, {22472, -1, -1, -1}, {14038, -1, -1, -1}, {59676, -1, -1, -1}, {28926, -1, -1, -1}, {59678, -1, -1, -1}, {59679, -1, -1, -1}, {59680, -1, -1, -1}, {59681, -1, -1, -1}, {59682, -1, -1, -1}, {26809, -1, -1, -1}, {26983, -1, -1, -1}, {59685, -1, -1, -1}, {59686, -1, -1, -1}, {59687, -1, -1, -1}, {59688, -1, -1, -1}, {59689, -1, -1, -1}, {59690, -1, -1, -1}, {59691, -1, -1, -1}, {59692, -1, -1, -1}, {27162, -1, -1, -1}, {59694, -1, -1, -1}, {59695, -1, -1, -1}, {33854, -1, -1, -1}, {17631, -1, -1, -1}, {17614, -1, -1, -1}, {59699, -1, -1, -1}, {59700, -1, -1, -1}, {59701, -1, -1, -1}, {59702, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {33597, -1, -1, -1}, {59706, -1, -1, -1}, {33773, -1, -1, -1}, {59708, -1, -1, -1}, {59709, -1, -1, -1}, {59710, -1, -1, -1}, {22921, -1, -1, -1}, {23170, -1, -1, -1}, {59713, -1, -1, -1}, {23137, -1, -1, -1}, {23153, -1, -1, -1}, {59716, -1, -1, -1}, {59717, -1, -1, -1}, {14125, -1, -1, -1}, {23023, -1, -1, -1}, {59720, -1, -1, -1}, {14023, -1, -1, -1}, {29070, -1, -1, -1}, {37776, -1, -1, -1}, {26266, -1, -1, -1}, {59725, -1, -1, -1}, {23150, -1, -1, -1}, {23083, -1, -1, -1}, {59728, -1, -1, -1}, {27179, -1, -1, -1}, {59730, -1, -1, -1}, {59731, -1, -1, -1}, {59732, -1, -1, -1}, {59733, -1, -1, -1}, {28957, -1, -1, -1}, {59735, -1, -1, -1}, {59736, -1, -1, -1}, {20400, -1, -1, -1}, {59738, -1, -1, -1}, {23746, -1, -1, -1}, {59740, -1, -1, -1}, {59741, -1, -1, -1}, {59742, -1, -1, -1}, {27148, -1, -1, -1}, {59744, -1, -1, -1}, {59745, -1, -1, -1}, {28838, -1, -1, -1}, {28979, -1, -1, -1}, {59748, -1, -1, -1}, {15781, -1, -1, -1}, {27871, -1, -1, -1}, {59751, -1, -1, -1}, {23019, -1, -1, -1}, {24412, -1, -1, -1}, {59764, -1, -1, -1}, {31955, -1, -1, -1}, {59783, -1, -1, -1}, {59786, -1, -1, -1}, {59790, -1, -1, -1}, {36972, -1, -1, -1}, {33270, -1, -1, -1}, {30476, -1, -1, -1}, {27810, -1, -1, -1}, {22269, -1, -1, -1}, {22633, -1, -1, -1}, {26465, -1, -1, -1}, {23646, -1, -1, -1}, {22770, -1, -1, -1}, {28857, -1, -1, -1}, {26627, -1, -1, -1}, {36795, -1, -1, -1}, {36796, -1, -1, -1}, {20001, -1, -1, -1}, {31545, -1, -1, -1}, {15820, -1, -1, -1}, {29482, -1, -1, -1}, {30048, -1, -1, -1}, {22586, -1, -1, -1}, {33446, -1, -1, -1}, {27018, -1, -1, -1}, {24803, -1, -1, -1}, {20206, -1, -1, -1}, {39364, -1, -1, -1}, {40639, -1, -1, -1}, {21249, -1, -1, -1}, {26528, -1, -1, -1}, {24808, -1, -1, -1}, {20916, -1, -1, -1}, {31363, -1, -1, -1}, {39994, -1, -1, -1}, {31432, -1, -1, -1}, {26906, -1, -1, -1}, {22956, -1, -1, -1}, {22592, -1, -1, -1}, {21610, -1, -1, -1}, {24807, -1, -1, -1}, {22138, -1, -1, -1}, {26965, -1, -1, -1}, {39983, -1, -1, -1}, {34725, -1, -1, -1}, {23584, -1, -1, -1}, {24075, -1, -1, -1}, {26398, -1, -1, -1}, {33965, -1, -1, -1}, {35713, -1, -1, -1}, {20088, -1, -1, -1}, {25283, -1, -1, -1}, {26709, -1, -1, -1}, {27113, -1, -1, -1}, {33533, -1, -1, -1}, {35237, -1, -1, -1}, {36768, -1, -1, -1}, {38840, -1, -1, -1}, {38983, -1, -1, -1}, {39613, -1, -1, -1}, {24497, -1, -1, -1}, {26184, -1, -1, -1}, {26303, -1, -1, -1}, {60221, -1, -1, -1}, {-1, -1, -1, -1}, {60225, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {60230, -1, -1, -1}, {26382, -1, -1, -1}, {26904, -1, -1, -1}, {60235, -1, -1, -1}, {60236, -1, -1, -1}, {60239, -1, -1, -1}, {60240, -1, -1, -1}, {18640, -1, -1, -1}, {19128, -1, -1, -1}, {60244, -1, -1, -1}, {60247, -1, -1, -1}, {60250, -1, -1, -1}, {60251, -1, -1, -1}, {20946, -1, -1, -1}, {60253, -1, -1, -1}, {22943, -1, -1, -1}, {60255, -1, -1, -1}, {15294, -1, -1, -1}, {60257, -1, -1, -1}, {14747, -1, -1, -1}, {60264, -1, -1, -1}, {60265, -1, -1, -1}, {14178, -1, -1, -1}, {60267, -1, -1, -1}, {35678, -1, -1, -1}, {60269, -1, -1, -1}, {-1, -1, -1, -1}, {29193, -1, -1, -1}, {60276, -1, -1, -1}, {60280, -1, -1, -1}, {36570, -1, -1, -1}, {21135, -1, -1, -1}, {29041, -1, -1, -1}, {60288, -1, -1, -1}, {60289, -1, -1, -1}, {21948, -1, -1, -1}, {60293, -1, -1, -1}, {13427, -1, -1, -1}, {60297, -1, -1, -1}, {18200, -1, -1, -1}, {60303, -1, -1, -1}, {20582, -1, -1, -1}, {13563, -1, -1, -1}, {60307, -1, -1, -1}, {24798, -1, -1, -1}, {18300, -1, -1, -1}, {60311, -1, -1, -1}, {60315, -1, -1, -1}, {-1, -1, -1, -1}, {60320, -1, -1, -1}, {36950, -1, -1, -1}, {60323, -1, -1, -1}, {35682, -1, -1, -1}, {23899, -1, -1, -1}, {60328, -1, -1, -1}, {-1, -1, -1, -1}, {60331, -1, -1, -1}, {35562, -1, -1, -1}, {60333, -1, -1, -1}, {60335, -1, -1, -1}, {19392, -1, -1, -1}, {60340, -1, -1, -1}, {37989, -1, -1, -1}, {60342, -1, -1, -1}, {24981, -1, -1, -1}, {23079, -1, -1, -1}, {60345, -1, -1, -1}, {-1, -1, -1, -1}, {60348, -1, -1, -1}, {20074, -1, -1, -1}, {60351, -1, -1, -1}, {38486, -1, -1, -1}, {28047, -1, -1, -1}, {60354, -1, -1, -1}, {35191, -1, -1, -1}, {60359, -1, -1, -1}, {-1, -1, -1, -1}, {31554, -1, -1, -1}, {60364, -1, -1, -1}, {60365, -1, -1, -1}, {-1, -1, -1, -1}, {31301, -1, -1, -1}, {39462, -1, -1, -1}, {13919, -1, -1, -1}, {60375, -1, -1, -1}, {60376, -1, -1, -1}, {31107, -1, -1, -1}, {23852, -1, -1, -1}, {60381, -1, -1, -1}, {-1, -1, -1, -1}, {18128, -1, -1, -1}, {30011, -1, -1, -1}, {34917, -1, -1, -1}, {22710, -1, -1, -1}, {14108, -1, -1, -1}, {60391, -1, -1, -1} },
+ {{15444, -1, -1, -1}, {37505, -1, -1, -1}, {60398, -1, -1, -1}, {37680, -1, -1, -1}, {60402, -1, -1, -1}, {27705, -1, -1, -1}, {60406, -1, -1, -1}, {34855, -1, -1, -1}, {35061, -1, -1, -1}, {60409, -1, -1, -1}, {60410, -1, -1, -1}, {60411, -1, -1, -1}, {28344, -1, -1, -1}, {60413, -1, -1, -1}, {60414, -1, -1, -1}, {14756, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {17727, -1, -1, -1}, {26294, -1, -1, -1}, {60421, -1, -1, -1}, {60422, -1, -1, -1}, {35139, -1, -1, -1}, {16607, -1, -1, -1}, {60428, -1, -1, -1}, {14753, -1, -1, -1}, {60430, -1, -1, -1}, {60431, -1, -1, -1}, {60432, -1, -1, -1}, {29101, -1, -1, -1}, {33638, -1, -1, -1}, {60436, -1, -1, -1}, {-1, -1, -1, -1}, {19639, -1, -1, -1}, {60439, -1, -1, -1}, {60440, -1, -1, -1}, {60445, -1, -1, -1}, {31555, -1, -1, -1}, {31102, -1, -1, -1}, {28597, -1, -1, -1}, {60450, -1, -1, -1}, {27139, -1, -1, -1}, {60452, -1, -1, -1}, {21410, -1, -1, -1}, {60454, -1, -1, -1}, {37823, -1, -1, -1}, {26678, -1, -1, -1}, {-1, -1, -1, -1}, {60458, -1, -1, -1}, {60460, -1, -1, -1}, {60461, -1, -1, -1}, {60462, -1, -1, -1}, {23941, -1, -1, -1}, {60465, -1, -1, -1}, {22293, -1, -1, -1}, {38947, -1, -1, -1}, {60469, -1, -1, -1}, {23979, -1, -1, -1}, {60471, -1, -1, -1}, {26046, -1, -1, -1}, {27093, -1, -1, -1}, {21458, -1, -1, -1}, {60475, -1, -1, -1}, {60476, -1, -1, -1}, {15377, -1, -1, -1}, {26422, -1, -1, -1}, {60482, -1, -1, -1}, {13770, -1, -1, -1}, {18682, -1, -1, -1}, {-1, -1, -1, -1}, {30728, -1, -1, -1}, {37461, -1, -1, -1}, {17394, -1, -1, -1}, {17375, -1, -1, -1}, {23032, -1, -1, -1}, {-1, -1, -1, -1}, {22155, -1, -1, -1}, {60520, -1, -1, -1}, {36882, -1, -1, -1}, {21953, -1, -1, -1}, {17673, -1, -1, -1}, {32383, -1, -1, -1}, {28502, -1, -1, -1}, {27313, -1, -1, -1}, {13540, -1, -1, -1}, {60558, -1, -1, -1}, {14138, -1, -1, -1}, {36480, -1, -1, -1}, {60562, -1, -1, -1}, {60565, -1, -1, -1}, {15851, -1, -1, -1}, {60569, -1, -1, -1}, {60574, -1, -1, -1}, {22207, -1, -1, -1}, {36366, -1, -1, -1}, {23405, -1, -1, -1}, {25566, -1, -1, -1}, {-1, -1, -1, -1}, {25904, -1, -1, -1}, {22061, -1, -1, -1}, {21530, -1, -1, -1}, {60591, -1, -1, -1}, {19581, -1, -1, -1}, {22050, -1, -1, -1}, {22046, -1, -1, -1}, {32585, -1, -1, -1}, {22901, -1, -1, -1}, {60598, -1, -1, -1}, {34672, -1, -1, -1}, {33047, -1, -1, -1}, {40286, -1, -1, -1}, {36120, -1, -1, -1}, {30267, -1, -1, -1}, {40005, -1, -1, -1}, {30286, -1, -1, -1}, {30649, -1, -1, -1}, {37701, -1, -1, -1}, {21554, -1, -1, -1}, {33096, -1, -1, -1}, {33527, -1, -1, -1}, {22053, -1, -1, -1}, {33074, -1, -1, -1}, {33816, -1, -1, -1}, {32957, -1, -1, -1}, {21994, -1, -1, -1}, {31074, -1, -1, -1}, {22083, -1, -1, -1}, {21526, -1, -1, -1}, {60623, -1, -1, -1}, {13774, -1, -1, -1}, {22021, -1, -1, -1}, {22001, -1, -1, -1}, {26353, -1, -1, -1}, {60628, -1, -1, -1}, {13869, -1, -1, -1}, {30004, -1, -1, -1}, {22000, -1, -1, -1}, {21946, -1, -1, -1}, {21655, -1, -1, -1}, {21874, -1, -1, -1}, {60635, -1, -1, -1}, {60636, -1, -1, -1}, {-1, -1, -1, -1}, {60639, -1, -1, -1}, {60640, -1, -1, -1}, {60641, -1, -1, -1}, {40619, -1, -1, -1}, {32090, -1, -1, -1}, {21982, -1, -1, -1}, {60645, -1, -1, -1}, {25245, -1, -1, -1}, {38765, -1, -1, -1}, {21652, -1, -1, -1}, {36045, -1, -1, -1}, {29174, -1, -1, -1}, {37238, -1, -1, -1}, {25596, -1, -1, -1}, {25529, -1, -1, -1}, {25598, -1, -1, -1}, {21865, -1, -1, -1}, {60656, -1, -1, -1}, {40050, -1, -1, -1}, {60658, -1, -1, -1}, {20890, -1, -1, -1}, {13535, -1, -1, -1}, {60661, -1, -1, -1}, {20903, -1, -1, -1}, {21581, -1, -1, -1}, {21790, -1, -1, -1}, {21779, -1, -1, -1}, {30310, -1, -1, -1}, {36397, -1, -1, -1}, {60668, -1, -1, -1}, {30129, -1, -1, -1}, {32950, -1, -1, -1}, {34820, -1, -1, -1}, {34694, -1, -1, -1}, {35015, -1, -1, -1}, {33206, -1, -1, -1}, {33820, -1, -1, -1}, {17644, -1, -1, -1}, {29444, -1, -1, -1}, {33547, -1, -1, -1}, {22139, -1, -1, -1}, {37232, -1, -1, -1}, {37384, -1, -1, -1}, {60696, -1, -1, -1}, {29286, -1, -1, -1}, {18254, -1, -1, -1}, {60701, -1, -1, -1}, {16634, -1, -1, -1}, {40029, -1, -1, -1}, {25887, -1, -1, -1}, {18675, -1, -1, -1}, {60708, -1, -1, -1}, {60709, -1, -1, -1}, {-1, -1, -1, -1}, {60713, -1, -1, -1}, {-1, -1, -1, -1}, {60716, -1, -1, -1}, {29091, -1, -1, -1}, {32398, -1, -1, -1}, {40272, -1, -1, -1}, {13687, -1, -1, -1}, {27826, -1, -1, -1}, {21351, -1, -1, -1}, {14812, -1, -1, -1}, {60731, -1, -1, -1}, {33325, -1, -1, -1}, {21579, -1, -1, -1}, {-1, -1, -1, -1}, {14930, -1, -1, -1}, {29556, -1, -1, -1}, {60743, -1, -1, -1}, {19721, -1, -1, -1}, {39917, -1, -1, -1}, {-1, -1, -1, -1}, {19547, -1, -1, -1}, {60751, -1, -1, -1}, {33884, -1, -1, -1}, {60754, -1, -1, -1}, {25390, -1, -1, -1}, {32037, -1, -1, -1}, {14890, -1, -1, -1}, {36872, -1, -1, -1}, {21196, -1, -1, -1}, {15988, -1, -1, -1}, {13946, -1, -1, -1}, {17897, -1, -1, -1}, {60767, -1, -1, -1}, {30272, -1, -1, -1}, {23280, -1, -1, -1}, {60770, -1, -1, -1}, {30842, -1, -1, -1}, {18358, -1, -1, -1}, {22695, -1, -1, -1}, {16575, -1, -1, -1}, {22140, -1, -1, -1}, {39819, -1, -1, -1}, {23924, -1, -1, -1}, {30292, -1, -1, -1}, {60779, -1, -1, -1}, {40581, -1, -1, -1}, {19681, -1, -1, -1}, {-1, -1, -1, -1}, {14331, -1, -1, -1}, {24857, -1, -1, -1}, {60786, -1, -1, -1}, {-1, -1, -1, -1}, {22109, -1, -1, -1}, {60792, -1, -1, -1}, {21044, -1, -1, -1}, {13741, -1, -1, -1}, {-1, -1, -1, -1}, {40316, -1, -1, -1}, {31830, -1, -1, -1} },
+ {{39737, -1, -1, -1}, {22494, -1, -1, -1}, {23635, -1, -1, -1}, {25811, -1, -1, -1}, {60804, -1, -1, -1}, {60805, -1, -1, -1}, {34477, -1, -1, -1}, {60808, -1, -1, -1}, {60811, -1, -1, -1}, {-1, -1, -1, -1}, {20990, -1, -1, -1}, {60814, -1, -1, -1}, {23950, -1, -1, -1}, {38659, -1, -1, -1}, {60817, -1, -1, -1}, {40577, -1, -1, -1}, {36940, -1, -1, -1}, {31519, -1, -1, -1}, {39682, -1, -1, -1}, {23761, -1, -1, -1}, {31651, -1, -1, -1}, {25192, -1, -1, -1}, {25397, -1, -1, -1}, {39679, -1, -1, -1}, {31695, -1, -1, -1}, {39722, -1, -1, -1}, {31870, -1, -1, -1}, {-1, -1, -1, -1}, {31810, -1, -1, -1}, {31878, -1, -1, -1}, {39957, -1, -1, -1}, {31740, -1, -1, -1}, {39689, -1, -1, -1}, {-1, -1, -1, -1}, {39982, -1, -1, -1}, {40794, -1, -1, -1}, {21875, -1, -1, -1}, {23491, -1, -1, -1}, {20477, -1, -1, -1}, {40600, -1, -1, -1}, {20466, -1, -1, -1}, {21088, -1, -1, -1}, {21201, -1, -1, -1}, {22375, -1, -1, -1}, {20566, -1, -1, -1}, {22967, -1, -1, -1}, {24082, -1, -1, -1}, {38856, -1, -1, -1}, {40363, -1, -1, -1}, {36700, -1, -1, -1}, {21609, -1, -1, -1}, {38836, -1, -1, -1}, {39232, -1, -1, -1}, {38842, -1, -1, -1}, {21292, -1, -1, -1}, {24880, -1, -1, -1}, {26924, -1, -1, -1}, {21466, -1, -1, -1}, {39946, -1, -1, -1}, {40194, -1, -1, -1}, {19515, -1, -1, -1}, {38465, -1, -1, -1}, {27008, -1, -1, -1}, {20646, -1, -1, -1}, {30022, -1, -1, -1}, {60870, -1, -1, -1}, {39386, -1, -1, -1}, {21107, -1, -1, -1}, {-1, -1, -1, -1}, {37209, -1, -1, -1}, {38529, -1, -1, -1}, {37212, -1, -1, -1}, {-1, -1, -1, -1}, {37201, -1, -1, -1}, {60879, -1, -1, -1}, {25471, -1, -1, -1}, {27338, -1, -1, -1}, {22033, -1, -1, -1}, {37262, -1, -1, -1}, {30074, -1, -1, -1}, {25221, -1, -1, -1}, {29519, -1, -1, -1}, {31856, -1, -1, -1}, {60890, -1, -1, -1}, {-1, -1, -1, -1}, {30422, -1, -1, -1}, {39837, -1, -1, -1}, {20010, -1, -1, -1}, {60897, -1, -1, -1}, {33726, -1, -1, -1}, {34882, -1, -1, -1}, {-1, -1, -1, -1}, {23626, -1, -1, -1}, {27072, -1, -1, -1}, {-1, -1, -1, -1}, {22394, -1, -1, -1}, {21023, -1, -1, -1}, {24053, -1, -1, -1}, {20174, -1, -1, -1}, {27697, -1, -1, -1}, {60909, -1, -1, -1}, {20281, -1, -1, -1}, {21660, -1, -1, -1}, {-1, -1, -1, -1}, {21146, -1, -1, -1}, {36226, -1, -1, -1}, {13822, -1, -1, -1}, {-1, -1, -1, -1}, {13811, -1, -1, -1}, {-1, -1, -1, -1}, {27474, -1, -1, -1}, {37244, -1, -1, -1}, {40869, -1, -1, -1}, {39831, -1, -1, -1}, {38958, -1, -1, -1}, {39092, -1, -1, -1}, {39610, -1, -1, -1}, {40616, -1, -1, -1}, {40580, -1, -1, -1}, {31508, -1, -1, -1}, {-1, -1, -1, -1}, {27642, -1, -1, -1}, {34840, -1, -1, -1}, {32632, -1, -1, -1}, {-1, -1, -1, -1}, {22048, -1, -1, -1}, {60936, -1, -1, -1}, {36471, -1, -1, -1}, {40787, -1, -1, -1}, {-1, -1, -1, -1}, {36308, -1, -1, -1}, {36431, -1, -1, -1}, {40476, -1, -1, -1}, {36353, -1, -1, -1}, {25218, -1, -1, -1}, {60945, -1, -1, -1}, {36392, -1, -1, -1}, {36469, -1, -1, -1}, {31443, -1, -1, -1}, {31294, -1, -1, -1}, {30936, -1, -1, -1}, {27882, -1, -1, -1}, {35431, -1, -1, -1}, {30215, -1, -1, -1}, {40742, -1, -1, -1}, {27854, -1, -1, -1}, {34774, -1, -1, -1}, {30147, -1, -1, -1}, {60960, -1, -1, -1}, {30803, -1, -1, -1}, {36108, -1, -1, -1}, {29410, -1, -1, -1}, {29553, -1, -1, -1}, {35629, -1, -1, -1}, {29442, -1, -1, -1}, {29937, -1, -1, -1}, {36075, -1, -1, -1}, {60970, -1, -1, -1}, {34351, -1, -1, -1}, {24506, -1, -1, -1}, {34976, -1, -1, -1}, {17591, -1, -1, -1}, {-1, -1, -1, -1}, {60977, -1, -1, -1}, {-1, -1, -1, -1}, {35454, -1, -1, -1}, {60980, -1, -1, -1}, {-1, -1, -1, -1}, {24829, -1, -1, -1}, {30311, -1, -1, -1}, {39639, -1, -1, -1}, {40260, -1, -1, -1}, {-1, -1, -1, -1}, {39823, -1, -1, -1}, {34805, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {36087, -1, -1, -1}, {29484, -1, -1, -1}, {38689, -1, -1, -1}, {39856, -1, -1, -1}, {13782, -1, -1, -1}, {29362, -1, -1, -1}, {19463, -1, -1, -1}, {31825, -1, -1, -1}, {39242, -1, -1, -1}, {24921, -1, -1, -1}, {19460, -1, -1, -1}, {40598, -1, -1, -1}, {24957, -1, -1, -1}, {-1, -1, -1, -1}, {22367, -1, -1, -1}, {24943, -1, -1, -1}, {25254, -1, -1, -1}, {25145, -1, -1, -1}, {-1, -1, -1, -1}, {14940, -1, -1, -1}, {25058, -1, -1, -1}, {21418, -1, -1, -1}, {25444, -1, -1, -1}, {26626, -1, -1, -1}, {13778, -1, -1, -1}, {23895, -1, -1, -1}, {36826, -1, -1, -1}, {61021, -1, -1, -1}, {-1, -1, -1, -1}, {20697, -1, -1, -1}, {30982, -1, -1, -1}, {21298, -1, -1, -1}, {38456, -1, -1, -1}, {61028, -1, -1, -1}, {16485, -1, -1, -1}, {-1, -1, -1, -1}, {30718, -1, -1, -1}, {-1, -1, -1, -1}, {31938, -1, -1, -1}, {61034, -1, -1, -1}, {31962, -1, -1, -1}, {31277, -1, -1, -1}, {32870, -1, -1, -1}, {32867, -1, -1, -1}, {32077, -1, -1, -1}, {29957, -1, -1, -1}, {29938, -1, -1, -1}, {35220, -1, -1, -1}, {33306, -1, -1, -1}, {26380, -1, -1, -1}, {32866, -1, -1, -1}, {61046, -1, -1, -1}, {32859, -1, -1, -1}, {29936, -1, -1, -1}, {33027, -1, -1, -1}, {30500, -1, -1, -1}, {35209, -1, -1, -1}, {61052, -1, -1, -1}, {30035, -1, -1, -1}, {34729, -1, -1, -1}, {34766, -1, -1, -1}, {33224, -1, -1, -1}, {34700, -1, -1, -1}, {35401, -1, -1, -1}, {36013, -1, -1, -1}, {35651, -1, -1, -1}, {30507, -1, -1, -1}, {29944, -1, -1, -1}, {34010, -1, -1, -1}, {27058, -1, -1, -1}, {36262, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {28089, -1, -1, -1}, {34753, -1, -1, -1}, {61073, -1, -1, -1}, {29927, -1, -1, -1}, {15835, -1, -1, -1} },
+ {{29046, -1, -1, -1}, {24740, -1, -1, -1}, {24988, -1, -1, -1}, {15569, -1, -1, -1}, {-1, -1, -1, -1}, {24695, -1, -1, -1}, {-1, -1, -1, -1}, {32625, -1, -1, -1}, {-1, -1, -1, -1}, {24809, -1, -1, -1}, {19326, -1, -1, -1}, {57344, -1, -1, -1}, {37595, -1, -1, -1}, {57346, -1, -1, -1}, {57347, -1, -1, -1}, {34124, -1, -1, -1}, {17077, -1, -1, -1}, {29679, -1, -1, -1}, {20917, -1, -1, -1}, {13897, -1, -1, -1}, {57353, -1, -1, -1}, {57354, -1, -1, -1}, {37700, -1, -1, -1}, {57356, -1, -1, -1}, {33518, -1, -1, -1}, {57358, -1, -1, -1}, {30780, -1, -1, -1}, {26436, -1, -1, -1}, {25311, -1, -1, -1}, {57362, -1, -1, -1}, {57363, -1, -1, -1}, {57364, -1, -1, -1}, {57365, -1, -1, -1}, {57366, -1, -1, -1}, {20395, -1, -1, -1}, {57368, -1, -1, -1}, {20488, -1, -1, -1}, {57370, -1, -1, -1}, {57371, -1, -1, -1}, {57372, -1, -1, -1}, {57373, -1, -1, -1}, {57374, -1, -1, -1}, {-1, -1, -1, -1}, {57376, -1, -1, -1}, {24484, -1, -1, -1}, {57378, -1, -1, -1}, {57379, -1, -1, -1}, {28379, -1, -1, -1}, {57381, -1, -1, -1}, {20702, -1, -1, -1}, {20737, -1, -1, -1}, {13434, -1, -1, -1}, {20750, -1, -1, -1}, {39020, -1, -1, -1}, {14147, -1, -1, -1}, {33814, -1, -1, -1}, {57389, -1, -1, -1}, {57390, -1, -1, -1}, {20832, -1, -1, -1}, {57392, -1, -1, -1}, {20842, -1, -1, -1}, {57394, -1, -1, -1}, {57395, -1, -1, -1}, {57396, -1, -1, -1}, {57397, -1, -1, -1}, {57398, -1, -1, -1}, {57399, -1, -1, -1}, {57400, -1, -1, -1}, {23426, -1, -1, -1}, {34685, -1, -1, -1}, {57403, -1, -1, -1}, {57404, -1, -1, -1}, {20914, -1, -1, -1}, {20920, -1, -1, -1}, {40244, -1, -1, -1}, {20937, -1, -1, -1}, {20943, -1, -1, -1}, {20945, -1, -1, -1}, {15580, -1, -1, -1}, {20947, -1, -1, -1}, {57413, -1, -1, -1}, {20915, -1, -1, -1}, {20962, -1, -1, -1}, {-1, -1, -1, -1}, {20973, -1, -1, -1}, {33741, -1, -1, -1}, {26942, -1, -1, -1}, {57420, -1, -1, -1}, {24443, -1, -1, -1}, {21003, -1, -1, -1}, {21030, -1, -1, -1}, {21052, -1, -1, -1}, {21173, -1, -1, -1}, {21079, -1, -1, -1}, {21140, -1, -1, -1}, {21177, -1, -1, -1}, {21189, -1, -1, -1}, {31765, -1, -1, -1}, {34114, -1, -1, -1}, {21216, -1, -1, -1}, {34317, -1, -1, -1}, {57434, -1, -1, -1}, {-1, -1, -1, -1}, {57436, -1, -1, -1}, {21833, -1, -1, -1}, {28377, -1, -1, -1}, {57439, -1, -1, -1}, {57440, -1, -1, -1}, {57441, -1, -1, -1}, {21299, -1, -1, -1}, {-1, -1, -1, -1}, {57444, -1, -1, -1}, {27851, -1, -1, -1}, {57446, -1, -1, -1}, {26651, -1, -1, -1}, {29653, -1, -1, -1}, {24650, -1, -1, -1}, {16042, -1, -1, -1}, {14540, -1, -1, -1}, {57452, -1, -1, -1}, {29149, -1, -1, -1}, {17570, -1, -1, -1}, {21357, -1, -1, -1}, {21364, -1, -1, -1}, {57457, -1, -1, -1}, {21374, -1, -1, -1}, {-1, -1, -1, -1}, {57460, -1, -1, -1}, {57461, -1, -1, -1}, {30694, -1, -1, -1}, {21395, -1, -1, -1}, {57464, -1, -1, -1}, {21408, -1, -1, -1}, {21419, -1, -1, -1}, {21422, -1, -1, -1}, {29607, -1, -1, -1}, {57469, -1, -1, -1}, {16217, -1, -1, -1}, {29596, -1, -1, -1}, {21441, -1, -1, -1}, {21445, -1, -1, -1}, {27721, -1, -1, -1}, {20041, -1, -1, -1}, {22526, -1, -1, -1}, {21465, -1, -1, -1}, {15019, -1, -1, -1}, {57479, -1, -1, -1}, {21472, -1, -1, -1}, {57481, -1, -1, -1}, {57482, -1, -1, -1}, {21494, -1, -1, -1}, {57484, -1, -1, -1}, {21523, -1, -1, -1}, {28793, -1, -1, -1}, {21803, -1, -1, -1}, {26199, -1, -1, -1}, {27995, -1, -1, -1}, {21613, -1, -1, -1}, {57491, -1, -1, -1}, {57492, -1, -1, -1}, {21853, -1, -1, -1}, {21647, -1, -1, -1}, {21668, -1, -1, -1}, {18342, -1, -1, -1}, {57497, -1, -1, -1}, {57498, -1, -1, -1}, {15796, -1, -1, -1}, {57500, -1, -1, -1}, {57501, -1, -1, -1}, {57502, -1, -1, -1}, {21831, -1, -1, -1}, {19693, -1, -1, -1}, {21551, -1, -1, -1}, {29719, -1, -1, -1}, {21894, -1, -1, -1}, {21929, -1, -1, -1}, {-1, -1, -1, -1}, {57510, -1, -1, -1}, {57511, -1, -1, -1}, {17746, -1, -1, -1}, {57513, -1, -1, -1}, {26291, -1, -1, -1}, {57515, -1, -1, -1}, {22071, -1, -1, -1}, {26317, -1, -1, -1}, {57518, -1, -1, -1}, {26276, -1, -1, -1}, {-1, -1, -1, -1}, {22093, -1, -1, -1}, {22095, -1, -1, -1}, {30961, -1, -1, -1}, {22257, -1, -1, -1}, {38791, -1, -1, -1}, {21502, -1, -1, -1}, {22272, -1, -1, -1}, {22255, -1, -1, -1}, {22253, -1, -1, -1}, {57530, -1, -1, -1}, {13859, -1, -1, -1}, {57532, -1, -1, -1}, {22342, -1, -1, -1}, {57534, -1, -1, -1}, {27758, -1, -1, -1}, {28811, -1, -1, -1}, {22338, -1, -1, -1}, {14001, -1, -1, -1}, {57539, -1, -1, -1}, {22502, -1, -1, -1}, {57541, -1, -1, -1}, {22531, -1, -1, -1}, {57543, -1, -1, -1}, {57544, -1, -1, -1}, {22566, -1, -1, -1}, {57546, -1, -1, -1}, {-1, -1, -1, -1}, {22698, -1, -1, -1}, {13665, -1, -1, -1}, {22752, -1, -1, -1}, {22748, -1, -1, -1}, {57552, -1, -1, -1}, {22779, -1, -1, -1}, {23551, -1, -1, -1}, {22339, -1, -1, -1}, {57556, -1, -1, -1}, {57557, -1, -1, -1}, {37843, -1, -1, -1}, {13729, -1, -1, -1}, {22815, -1, -1, -1}, {26790, -1, -1, -1}, {14019, -1, -1, -1}, {28249, -1, -1, -1}, {57564, -1, -1, -1}, {23076, -1, -1, -1}, {-1, -1, -1, -1}, {57567, -1, -1, -1}, {34053, -1, -1, -1}, {22985, -1, -1, -1}, {57570, -1, -1, -1}, {57571, -1, -1, -1}, {57572, -1, -1, -1}, {57573, -1, -1, -1}, {23001, -1, -1, -1}, {57575, -1, -1, -1}, {57576, -1, -1, -1}, {57577, -1, -1, -1}, {28017, -1, -1, -1}, {57579, -1, -1, -1}, {57580, -1, -1, -1}, {23033, -1, -1, -1}, {57582, -1, -1, -1}, {23211, -1, -1, -1}, {23139, -1, -1, -1}, {14054, -1, -1, -1}, {57586, -1, -1, -1}, {-1, -1, -1, -1}, {14088, -1, -1, -1} },
+ {{23190, -1, -1, -1}, {29797, -1, -1, -1}, {23251, -1, -1, -1}, {57592, -1, -1, -1}, {57593, -1, -1, -1}, {57595, -1, -1, -1}, {14130, -1, -1, -1}, {57597, -1, -1, -1}, {24195, -1, -1, -1}, {21200, -1, -1, -1}, {23414, -1, -1, -1}, {25992, -1, -1, -1}, {23420, -1, -1, -1}, {57603, -1, -1, -1}, {16388, -1, -1, -1}, {18525, -1, -1, -1}, {57606, -1, -1, -1}, {23509, -1, -1, -1}, {57609, -1, -1, -1}, {57610, -1, -1, -1}, {57611, -1, -1, -1}, {23539, -1, -1, -1}, {23453, -1, -1, -1}, {19728, -1, -1, -1}, {23557, -1, -1, -1}, {57616, -1, -1, -1}, {23571, -1, -1, -1}, {29646, -1, -1, -1}, {23572, -1, -1, -1}, {57620, -1, -1, -1}, {57621, -1, -1, -1}, {23625, -1, -1, -1}, {18653, -1, -1, -1}, {23685, -1, -1, -1}, {23785, -1, -1, -1}, {23791, -1, -1, -1}, {23947, -1, -1, -1}, {57628, -1, -1, -1}, {57629, -1, -1, -1}, {23824, -1, -1, -1}, {23832, -1, -1, -1}, {23878, -1, -1, -1}, {57633, -1, -1, -1}, {23738, -1, -1, -1}, {24023, -1, -1, -1}, {33532, -1, -1, -1}, {14381, -1, -1, -1}, {57638, -1, -1, -1}, {57639, -1, -1, -1}, {57640, -1, -1, -1}, {33415, -1, -1, -1}, {14390, -1, -1, -1}, {15298, -1, -1, -1}, {24110, -1, -1, -1}, {27274, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {57648, -1, -1, -1}, {57649, -1, -1, -1}, {21414, -1, -1, -1}, {20151, -1, -1, -1}, {24272, -1, -1, -1}, {21416, -1, -1, -1}, {57654, -1, -1, -1}, {24073, -1, -1, -1}, {-1, -1, -1, -1}, {57657, -1, -1, -1}, {24313, -1, -1, -1}, {24315, -1, -1, -1}, {14496, -1, -1, -1}, {24316, -1, -1, -1}, {26686, -1, -1, -1}, {37915, -1, -1, -1}, {24333, -1, -1, -1}, {57665, -1, -1, -1}, {57666, -1, -1, -1}, {15070, -1, -1, -1}, {57669, -1, -1, -1}, {24378, -1, -1, -1}, {57671, -1, -1, -1}, {57672, -1, -1, -1}, {57674, -1, -1, -1}, {24419, -1, -1, -1}, {57677, -1, -1, -1}, {24434, -1, -1, -1}, {37696, -1, -1, -1}, {57680, -1, -1, -1}, {24487, -1, -1, -1}, {23990, -1, -1, -1}, {15711, -1, -1, -1}, {57684, -1, -1, -1}, {57685, -1, -1, -1}, {57686, -1, -1, -1}, {57687, -1, -1, -1}, {37334, -1, -1, -1}, {57689, -1, -1, -1}, {57690, -1, -1, -1}, {24625, -1, -1, -1}, {26245, -1, -1, -1}, {14691, -1, -1, -1}, {15815, -1, -1, -1}, {13881, -1, -1, -1}, {22416, -1, -1, -1}, {57698, -1, -1, -1}, {31089, -1, -1, -1}, {15936, -1, -1, -1}, {24734, -1, -1, -1}, {-1, -1, -1, -1}, {24755, -1, -1, -1}, {57704, -1, -1, -1}, {57705, -1, -1, -1}, {57706, -1, -1, -1}, {29860, -1, -1, -1}, {20705, -1, -1, -1}, {23200, -1, -1, -1}, {24932, -1, -1, -1}, {24898, -1, -1, -1}, {57713, -1, -1, -1}, {57714, -1, -1, -1}, {24961, -1, -1, -1}, {20980, -1, -1, -1}, {57717, -1, -1, -1}, {24967, -1, -1, -1}, {23466, -1, -1, -1}, {57720, -1, -1, -1}, {57721, -1, -1, -1}, {25043, -1, -1, -1}, {57723, -1, -1, -1}, {57724, -1, -1, -1}, {25040, -1, -1, -1}, {14642, -1, -1, -1}, {57727, -1, -1, -1}, {57728, -1, -1, -1}, {24611, -1, -1, -1}, {24924, -1, -1, -1}, {25886, -1, -1, -1}, {25483, -1, -1, -1}, {57733, -1, -1, -1}, {25285, -1, -1, -1}, {57735, -1, -1, -1}, {25301, -1, -1, -1}, {57737, -1, -1, -1}, {25452, -1, -1, -1}, {57739, -1, -1, -1}, {14871, -1, -1, -1}, {25656, -1, -1, -1}, {25592, -1, -1, -1}, {57743, -1, -1, -1}, {57744, -1, -1, -1}, {28554, -1, -1, -1}, {57747, -1, -1, -1}, {-1, -1, -1, -1}, {57750, -1, -1, -1}, {25825, -1, -1, -1}, {25829, -1, -1, -1}, {38011, -1, -1, -1}, {14950, -1, -1, -1}, {25658, -1, -1, -1}, {14935, -1, -1, -1}, {25933, -1, -1, -1}, {28438, -1, -1, -1}, {57759, -1, -1, -1}, {57760, -1, -1, -1}, {25989, -1, -1, -1}, {25965, -1, -1, -1}, {25951, -1, -1, -1}, {-1, -1, -1, -1}, {26037, -1, -1, -1}, {57766, -1, -1, -1}, {19255, -1, -1, -1}, {26065, -1, -1, -1}, {16600, -1, -1, -1}, {57770, -1, -1, -1}, {-1, -1, -1, -1}, {26083, -1, -1, -1}, {24543, -1, -1, -1}, {57774, -1, -1, -1}, {26136, -1, -1, -1}, {57776, -1, -1, -1}, {57777, -1, -1, -1}, {26180, -1, -1, -1}, {57779, -1, -1, -1}, {57780, -1, -1, -1}, {26187, -1, -1, -1}, {57782, -1, -1, -1}, {26215, -1, -1, -1}, {57784, -1, -1, -1}, {26227, -1, -1, -1}, {-1, -1, -1, -1}, {57788, -1, -1, -1}, {57789, -1, -1, -1}, {57790, -1, -1, -1}, {57791, -1, -1, -1}, {30661, -1, -1, -1}, {57793, -1, -1, -1}, {39332, -1, -1, -1}, {26370, -1, -1, -1}, {57796, -1, -1, -1}, {57797, -1, -1, -1}, {27130, -1, -1, -1}, {57800, -1, -1, -1}, {-1, -1, -1, -1}, {26471, -1, -1, -1}, {26466, -1, -1, -1}, {57804, -1, -1, -1}, {57805, -1, -1, -1}, {26583, -1, -1, -1}, {17641, -1, -1, -1}, {26658, -1, -1, -1}, {28240, -1, -1, -1}, {37436, -1, -1, -1}, {26625, -1, -1, -1}, {57812, -1, -1, -1}, {57813, -1, -1, -1}, {26717, -1, -1, -1}, {57815, -1, -1, -1}, {27105, -1, -1, -1}, {27147, -1, -1, -1}, {57818, -1, -1, -1}, {26995, -1, -1, -1}, {26819, -1, -1, -1}, {57821, -1, -1, -1}, {26881, -1, -1, -1}, {26880, -1, -1, -1}, {14849, -1, -1, -1}, {57826, -1, -1, -1}, {15232, -1, -1, -1}, {26540, -1, -1, -1}, {26977, -1, -1, -1}, {57830, -1, -1, -1}, {17148, -1, -1, -1}, {26934, -1, -1, -1}, {27032, -1, -1, -1}, {15265, -1, -1, -1}, {57835, -1, -1, -1}, {33635, -1, -1, -1}, {20624, -1, -1, -1}, {27129, -1, -1, -1}, {57839, -1, -1, -1}, {57840, -1, -1, -1}, {27205, -1, -1, -1}, {57842, -1, -1, -1}, {27293, -1, -1, -1}, {15347, -1, -1, -1}, {26545, -1, -1, -1}, {27336, -1, -1, -1}, {57847, -1, -1, -1}, {15373, -1, -1, -1}, {27421, -1, -1, -1}, {57850, -1, -1, -1}, {-1, -1, -1, -1}, {27445, -1, -1, -1}, {27508, -1, -1, -1}, {57854, -1, -1, -1}, {28341, -1, -1, -1}, {57856, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {57858, -1, -1, -1}, {14144, -1, -1, -1}, {21537, -1, -1, -1}, {57861, -1, -1, -1}, {27617, -1, -1, -1}, {57863, -1, -1, -1}, {27612, -1, -1, -1}, {27703, -1, -1, -1}, {57866, -1, -1, -1}, {57867, -1, -1, -1}, {57868, -1, -1, -1}, {27738, -1, -1, -1}, {33318, -1, -1, -1}, {27769, -1, -1, -1}, {57872, -1, -1, -1}, {17605, -1, -1, -1}, {57874, -1, -1, -1}, {57875, -1, -1, -1}, {57876, -1, -1, -1}, {57877, -1, -1, -1}, {57878, -1, -1, -1}, {14053, -1, -1, -1}, {15595, -1, -1, -1}, {57881, -1, -1, -1}, {39811, -1, -1, -1}, {57883, -1, -1, -1}, {57884, -1, -1, -1}, {32655, -1, -1, -1}, {26679, -1, -1, -1}, {57887, -1, -1, -1}, {57888, -1, -1, -1}, {57889, -1, -1, -1}, {28054, -1, -1, -1}, {27996, -1, -1, -1}, {28284, -1, -1, -1}, {28420, -1, -1, -1}, {57894, -1, -1, -1}, {57895, -1, -1, -1}, {57896, -1, -1, -1}, {34099, -1, -1, -1}, {57898, -1, -1, -1}, {20935, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {33838, -1, -1, -1}, {57903, -1, -1, -1}, {-1, -1, -1, -1}, {57905, -1, -1, -1}, {29779, -1, -1, -1}, {57907, -1, -1, -1}, {31180, -1, -1, -1}, {28239, -1, -1, -1}, {23185, -1, -1, -1}, {57911, -1, -1, -1}, {28664, -1, -1, -1}, {14093, -1, -1, -1}, {28573, -1, -1, -1}, {57915, -1, -1, -1}, {28410, -1, -1, -1}, {57917, -1, -1, -1}, {57918, -1, -1, -1}, {17749, -1, -1, -1}, {37872, -1, -1, -1}, {28484, -1, -1, -1}, {28508, -1, -1, -1}, {15694, -1, -1, -1}, {28532, -1, -1, -1}, {57925, -1, -1, -1}, {15675, -1, -1, -1}, {28575, -1, -1, -1}, {57928, -1, -1, -1}, {28627, -1, -1, -1}, {57930, -1, -1, -1}, {57931, -1, -1, -1}, {57932, -1, -1, -1}, {57933, -1, -1, -1}, {57934, -1, -1, -1}, {57935, -1, -1, -1}, {20959, -1, -1, -1}, {57937, -1, -1, -1}, {57938, -1, -1, -1}, {57939, -1, -1, -1}, {57940, -1, -1, -1}, {28747, -1, -1, -1}, {28798, -1, -1, -1}, {28839, -1, -1, -1}, {-1, -1, -1, -1}, {28876, -1, -1, -1}, {28885, -1, -1, -1}, {28886, -1, -1, -1}, {28895, -1, -1, -1}, {16644, -1, -1, -1}, {15848, -1, -1, -1}, {29108, -1, -1, -1}, {29078, -1, -1, -1}, {57953, -1, -1, -1}, {28971, -1, -1, -1}, {28997, -1, -1, -1}, {23176, -1, -1, -1}, {29002, -1, -1, -1}, {-1, -1, -1, -1}, {57960, -1, -1, -1}, {29007, -1, -1, -1}, {37730, -1, -1, -1}, {57963, -1, -1, -1}, {28972, -1, -1, -1}, {57965, -1, -1, -1}, {57966, -1, -1, -1}, {57967, -1, -1, -1}, {29114, -1, -1, -1}, {57969, -1, -1, -1}, {28861, -1, -1, -1}, {29198, -1, -1, -1}, {37954, -1, -1, -1}, {29205, -1, -1, -1}, {22801, -1, -1, -1}, {37955, -1, -1, -1}, {29220, -1, -1, -1}, {37697, -1, -1, -1}, {57978, -1, -1, -1}, {29230, -1, -1, -1}, {29248, -1, -1, -1}, {57981, -1, -1, -1}, {26813, -1, -1, -1}, {29269, -1, -1, -1}, {29271, -1, -1, -1}, {15957, -1, -1, -1}, {57986, -1, -1, -1}, {26637, -1, -1, -1}, {28477, -1, -1, -1}, {29314, -1, -1, -1}, {-1, -1, -1, -1}, {29483, -1, -1, -1}, {57992, -1, -1, -1}, {57993, -1, -1, -1}, {18669, -1, -1, -1}, {57995, -1, -1, -1}, {29480, -1, -1, -1}, {29486, -1, -1, -1}, {29647, -1, -1, -1}, {29610, -1, -1, -1}, {58000, -1, -1, -1}, {58001, -1, -1, -1}, {29641, -1, -1, -1}, {29769, -1, -1, -1}, {58004, -1, -1, -1}, {58005, -1, -1, -1}, {58006, -1, -1, -1}, {26147, -1, -1, -1}, {14021, -1, -1, -1}, {58009, -1, -1, -1}, {58010, -1, -1, -1}, {58011, -1, -1, -1}, {29687, -1, -1, -1}, {29717, -1, -1, -1}, {26883, -1, -1, -1}, {58015, -1, -1, -1}, {29753, -1, -1, -1}, {16087, -1, -1, -1}, {-1, -1, -1, -1}, {58020, -1, -1, -1}, {29792, -1, -1, -1}, {58022, -1, -1, -1}, {29767, -1, -1, -1}, {29668, -1, -1, -1}, {29814, -1, -1, -1}, {33721, -1, -1, -1}, {29804, -1, -1, -1}, {29812, -1, -1, -1}, {37873, -1, -1, -1}, {27180, -1, -1, -1}, {29826, -1, -1, -1}, {18771, -1, -1, -1}, {58034, -1, -1, -1}, {58035, -1, -1, -1}, {58036, -1, -1, -1}, {58037, -1, -1, -1}, {23366, -1, -1, -1}, {58039, -1, -1, -1}, {58040, -1, -1, -1}, {29896, -1, -1, -1}, {58042, -1, -1, -1}, {29966, -1, -1, -1}, {29982, -1, -1, -1}, {58046, -1, -1, -1}, {58047, -1, -1, -1}, {23511, -1, -1, -1}, {58049, -1, -1, -1}, {37765, -1, -1, -1}, {30029, -1, -1, -1}, {30026, -1, -1, -1}, {30055, -1, -1, -1}, {30062, -1, -1, -1}, {58055, -1, -1, -1}, {16132, -1, -1, -1}, {58057, -1, -1, -1}, {30094, -1, -1, -1}, {29789, -1, -1, -1}, {30110, -1, -1, -1}, {30132, -1, -1, -1}, {30210, -1, -1, -1}, {30252, -1, -1, -1}, {30289, -1, -1, -1}, {30287, -1, -1, -1}, {30319, -1, -1, -1}, {-1, -1, -1, -1}, {58068, -1, -1, -1}, {30352, -1, -1, -1}, {33263, -1, -1, -1}, {14328, -1, -1, -1}, {58072, -1, -1, -1}, {58073, -1, -1, -1}, {30369, -1, -1, -1}, {30373, -1, -1, -1}, {30391, -1, -1, -1}, {30412, -1, -1, -1}, {58078, -1, -1, -1}, {33890, -1, -1, -1}, {58080, -1, -1, -1}, {58081, -1, -1, -1}, {58082, -1, -1, -1}, {30494, -1, -1, -1}, {30502, -1, -1, -1}, {30528, -1, -1, -1}, {25775, -1, -1, -1}, {58087, -1, -1, -1}, {30552, -1, -1, -1}, {58089, -1, -1, -1}, {30639, -1, -1, -1}, {58091, -1, -1, -1}, {58092, -1, -1, -1}, {58093, -1, -1, -1}, {30708, -1, -1, -1}, {-1, -1, -1, -1}, {26826, -1, -1, -1}, {30895, -1, -1, -1}, {30919, -1, -1, -1}, {30931, -1, -1, -1}, {38565, -1, -1, -1}, {31022, -1, -1, -1}, {58104, -1, -1, -1}, {30935, -1, -1, -1}, {31028, -1, -1, -1}, {30897, -1, -1, -1}, {58108, -1, -1, -1}, {36792, -1, -1, -1}, {34948, -1, -1, -1}, {58113, -1, -1, -1}, {31110, -1, -1, -1}, {35072, -1, -1, -1}, {26882, -1, -1, -1}, {31104, -1, -1, -1}, {58118, -1, -1, -1}, {31133, -1, -1, -1}, {58120, -1, -1, -1} },
+ {{31036, -1, -1, -1}, {31145, -1, -1, -1}, {28202, -1, -1, -1}, {58124, -1, -1, -1}, {16040, -1, -1, -1}, {31174, -1, -1, -1}, {58127, -1, -1, -1}, {31188, -1, -1, -1}, {-1, -1, -1, -1}, {21797, -1, -1, -1}, {-1, -1, -1, -1}, {62528, -1, -1, -1}, {62529, -1, -1, -1}, {62530, -1, -1, -1}, {21904, -1, -1, -1}, {62532, -1, -1, -1}, {14828, -1, -1, -1}, {62534, -1, -1, -1}, {36422, -1, -1, -1}, {62536, -1, -1, -1}, {62537, -1, -1, -1}, {-1, -1, -1, -1}, {62539, -1, -1, -1}, {30586, -1, -1, -1}, {62541, -1, -1, -1}, {14900, -1, -1, -1}, {18389, -1, -1, -1}, {62544, -1, -1, -1}, {62545, -1, -1, -1}, {62546, -1, -1, -1}, {25821, -1, -1, -1}, {62548, -1, -1, -1}, {62549, -1, -1, -1}, {62550, -1, -1, -1}, {-1, -1, -1, -1}, {25741, -1, -1, -1}, {36478, -1, -1, -1}, {62554, -1, -1, -1}, {-1, -1, -1, -1}, {62556, -1, -1, -1}, {62557, -1, -1, -1}, {62558, -1, -1, -1}, {62559, -1, -1, -1}, {-1, -1, -1, -1}, {62561, -1, -1, -1}, {62562, -1, -1, -1}, {62563, -1, -1, -1}, {18420, -1, -1, -1}, {62565, -1, -1, -1}, {62566, -1, -1, -1}, {39602, -1, -1, -1}, {14951, -1, -1, -1}, {62569, -1, -1, -1}, {16365, -1, -1, -1}, {13574, -1, -1, -1}, {62572, -1, -1, -1}, {62573, -1, -1, -1}, {-1, -1, -1, -1}, {62575, -1, -1, -1}, {40302, -1, -1, -1}, {38933, -1, -1, -1}, {-1, -1, -1, -1}, {17369, -1, -1, -1}, {-1, -1, -1, -1}, {25780, -1, -1, -1}, {21731, -1, -1, -1}, {-1, -1, -1, -1}, {62584, -1, -1, -1}, {-1, -1, -1, -1}, {14843, -1, -1, -1}, {-1, -1, -1, -1}, {62588, -1, -1, -1}, {62589, -1, -1, -1}, {62590, -1, -1, -1}, {25834, -1, -1, -1}, {62592, -1, -1, -1}, {62593, -1, -1, -1}, {36456, -1, -1, -1}, {-1, -1, -1, -1}, {62596, -1, -1, -1}, {62597, -1, -1, -1}, {-1, -1, -1, -1}, {18443, -1, -1, -1}, {62600, -1, -1, -1}, {16378, -1, -1, -1}, {22643, -1, -1, -1}, {62603, -1, -1, -1}, {-1, -1, -1, -1}, {62605, -1, -1, -1}, {62606, -1, -1, -1}, {62607, -1, -1, -1}, {62608, -1, -1, -1}, {-1, -1, -1, -1}, {21881, -1, -1, -1}, {-1, -1, -1, -1}, {17338, -1, -1, -1}, {-1, -1, -1, -1}, {19124, -1, -1, -1}, {62615, -1, -1, -1}, {62616, -1, -1, -1}, {33194, -1, -1, -1}, {39157, -1, -1, -1}, {62619, -1, -1, -1}, {25465, -1, -1, -1}, {14846, -1, -1, -1}, {62622, -1, -1, -1}, {36288, -1, -1, -1}, {22177, -1, -1, -1}, {25724, -1, -1, -1}, {15939, -1, -1, -1}, {-1, -1, -1, -1}, {62628, -1, -1, -1}, {62629, -1, -1, -1}, {62630, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {62633, -1, -1, -1}, {62634, -1, -1, -1}, {14738, -1, -1, -1}, {14854, -1, -1, -1}, {62637, -1, -1, -1}, {13688, -1, -1, -1}, {62639, -1, -1, -1}, {62640, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {62643, -1, -1, -1}, {62644, -1, -1, -1}, {13500, -1, -1, -1}, {27709, -1, -1, -1}, {62647, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {62650, -1, -1, -1}, {62651, -1, -1, -1}, {62652, -1, -1, -1}, {62653, -1, -1, -1}, {62654, -1, -1, -1}, {62655, -1, -1, -1}, {62656, -1, -1, -1}, {62683, -1, -1, -1}, {62684, -1, -1, -1}, {62687, -1, -1, -1}, {14872, -1, -1, -1}, {62691, -1, -1, -1}, {62693, -1, -1, -1}, {62695, -1, -1, -1}, {62696, -1, -1, -1}, {62697, -1, -1, -1}, {38314, -1, -1, -1}, {-1, -1, -1, -1}, {62706, -1, -1, -1}, {28992, -1, -1, -1}, {-1, -1, -1, -1}, {20822, -1, -1, -1}, {-1, -1, -1, -1}, {20616, -1, -1, -1}, {-1, -1, -1, -1}, {13459, -1, -1, -1}, {20870, -1, -1, -1}, {24130, -1, -1, -1}, {20997, -1, -1, -1}, {21031, -1, -1, -1}, {21113, -1, -1, -1}, {-1, -1, -1, -1}, {13651, -1, -1, -1}, {21442, -1, -1, -1}, {21343, -1, -1, -1}, {21708, -1, -1, -1}, {21823, -1, -1, -1}, {21945, -1, -1, -1}, {21976, -1, -1, -1}, {13789, -1, -1, -1}, {22049, -1, -1, -1}, {21843, -1, -1, -1}, {22100, -1, -1, -1}, {60148, -1, -1, -1}, {-1, -1, -1, -1}, {60153, -1, -1, -1}, {-1, -1, -1, -1}, {61095, -1, -1, -1}, {23247, -1, -1, -1}, {-1, -1, -1, -1}, {14265, -1, -1, -1}, {23745, -1, -1, -1}, {23829, -1, -1, -1}, {23894, -1, -1, -1}, {14392, -1, -1, -1}, {20097, -1, -1, -1}, {24253, -1, -1, -1}, {14612, -1, -1, -1}, {25017, -1, -1, -1}, {25232, -1, -1, -1}, {25368, -1, -1, -1}, {25690, -1, -1, -1}, {25745, -1, -1, -1}, {33133, -1, -1, -1}, {33156, -1, -1, -1}, {33171, -1, -1, -1}, {26624, -1, -1, -1}, {15292, -1, -1, -1}, {29327, -1, -1, -1}, {29389, -1, -1, -1}, {-1, -1, -1, -1}, {29497, -1, -1, -1}, {30018, -1, -1, -1}, {30172, -1, -1, -1}, {16320, -1, -1, -1}, {60278, -1, -1, -1}, {16343, -1, -1, -1}, {-1, -1, -1, -1}, {30336, -1, -1, -1}, {30348, 59824, -1, -1}, {16552, -1, -1, -1}, {30777, -1, -1, -1}, {16643, -1, -1, -1}, {31377, -1, -1, -1}, {31771, -1, -1, -1}, {31981, -1, -1, -1}, {32659, -1, -1, -1}, {32686, -1, -1, -1}, {-1, -1, -1, -1}, {33535, -1, -1, -1}, {22623, -1, -1, -1}, {34482, -1, -1, -1}, {-1, -1, -1, -1}, {34699, -1, -1, -1}, {35143, -1, -1, -1}, {-1, -1, -1, -1}, {35369, -1, -1, -1}, {-1, -1, -1, -1}, {36465, -1, -1, -1}, {60484, -1, -1, -1}, {36528, -1, -1, -1}, {-1, -1, -1, -1}, {37214, -1, -1, -1}, {37260, -1, -1, -1}, {39182, -1, -1, -1}, {39196, -1, -1, -1}, {39266, -1, -1, -1}, {39606, -1, -1, -1}, {39809, -1, -1, -1}, {40384, -1, -1, -1}, {40339, -1, -1, -1}, {40620, -1, -1, -1}, {19857, -1, -1, -1}, {-1, -1, -1, -1}, {37818, -1, -1, -1}, {40571, -1, -1, -1}, {28809, -1, -1, -1}, {29512, -1, -1, -1}, {-1, -1, -1, -1}, {31129, -1, -1, -1}, {36791, -1, -1, -1}, {-1, -1, -1, -1}, {39234, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8364, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12443, -1, -1, -1}, {12444, -1, -1, -1}, {11904, -1, -1, -1}, {62211, -1, -1, -1}, {62212, -1, -1, -1}, {62213, -1, -1, -1}, {62214, -1, -1, -1}, {62215, -1, -1, -1}, {62216, -1, -1, -1}, {62217, -1, -1, -1}, {62218, -1, -1, -1}, {62219, -1, -1, -1}, {62220, -1, -1, -1}, {62221, -1, -1, -1}, {62222, -1, -1, -1}, {62223, -1, -1, -1}, {62224, -1, -1, -1}, {62225, -1, -1, -1}, {62226, -1, -1, -1}, {62227, -1, -1, -1}, {62228, -1, -1, -1}, {62229, -1, -1, -1}, {62230, -1, -1, -1}, {62231, -1, -1, -1}, {62232, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {62778, -1, -1, -1}, {62779, -1, -1, -1}, {38737, -1, -1, -1}, {62781, -1, -1, -1}, {20059, -1, -1, -1}, {20155, -1, -1, -1}, {13630, -1, -1, -1}, {23587, -1, -1, -1}, {24401, -1, -1, -1}, {24516, -1, -1, -1}, {14586, -1, -1, -1}, {25164, -1, -1, -1}, {25909, -1, -1, -1}, {27514, -1, -1, -1}, {27701, -1, -1, -1}, {27706, -1, -1, -1}, {28780, -1, -1, -1}, {29227, -1, -1, -1}, {20012, -1, -1, -1}, {29357, -1, -1, -1}, {62798, -1, -1, -1}, {32594, -1, -1, -1}, {31035, -1, -1, -1}, {31993, -1, -1, -1}, {32595, -1, -1, -1}, {62803, -1, -1, -1}, {13505, -1, -1, -1}, {62806, -1, -1, -1}, {32770, -1, -1, -1}, {32896, -1, -1, -1}, {62809, -1, -1, -1} },
+ {{62810, -1, -1, -1}, {21341, -1, -1, -1}, {34916, -1, -1, -1}, {35265, -1, -1, -1}, {62814, -1, -1, -1}, {35744, -1, -1, -1}, {36125, -1, -1, -1}, {38021, -1, -1, -1}, {38264, -1, -1, -1}, {38271, -1, -1, -1}, {38376, -1, -1, -1}, {62821, -1, -1, -1}, {38886, -1, -1, -1}, {39029, -1, -1, -1}, {39118, -1, -1, -1}, {39134, -1, -1, -1}, {39267, -1, -1, -1}, {62827, -1, -1, -1}, {40060, -1, -1, -1}, {40479, -1, -1, -1}, {40644, -1, -1, -1}, {27503, -1, -1, -1}, {-1, -1, -1, -1}, {20023, -1, -1, -1}, {62834, -1, -1, -1}, {38429, -1, -1, -1}, {25143, -1, -1, -1}, {38050, -1, -1, -1}, {11908, -1, -1, -1}, {11910, -1, -1, -1}, {11911, -1, -1, -1}, {11912, -1, -1, -1}, {11914, -1, -1, -1}, {11916, -1, -1, -1}, {11917, -1, -1, -1}, {11925, -1, -1, -1}, {11932, -1, -1, -1}, {11941, -1, -1, -1}, {11943, -1, -1, -1}, {11946, -1, -1, -1}, {11948, -1, -1, -1}, {11950, -1, -1, -1}, {11958, -1, -1, -1}, {11964, -1, -1, -1}, {11966, -1, -1, -1}, {11978, -1, -1, -1}, {11980, -1, -1, -1}, {11981, -1, -1, -1}, {11983, -1, -1, -1}, {11990, -1, -1, -1}, {11991, -1, -1, -1}, {11998, -1, -1, -1}, {62368, -1, -1, -1}, {62369, -1, -1, -1}, {25866, -1, -1, -1}, {20029, -1, -1, -1}, {28381, -1, -1, -1}, {40270, -1, -1, -1}, {37343, -1, -1, -1}, {62380, -1, -1, -1}, {20250, -1, -1, -1}, {20264, -1, -1, -1}, {20392, -1, -1, -1}, {20852, -1, -1, -1}, {20892, -1, -1, -1}, {20964, -1, -1, -1}, {21153, -1, -1, -1}, {21160, -1, -1, -1}, {21307, -1, -1, -1}, {21326, -1, -1, -1}, {21457, -1, -1, -1}, {21464, -1, -1, -1}, {22242, -1, -1, -1}, {22768, -1, -1, -1}, {22788, -1, -1, -1}, {22791, -1, -1, -1}, {22834, -1, -1, -1}, {22836, -1, -1, -1}, {23398, -1, -1, -1}, {23454, -1, -1, -1}, {23455, -1, -1, -1}, {23706, -1, -1, -1}, {24198, -1, -1, -1}, {24635, -1, -1, -1}, {25993, -1, -1, -1}, {26622, -1, -1, -1}, {26628, -1, -1, -1}, {26725, -1, -1, -1}, {27982, -1, -1, -1}, {28860, -1, -1, -1}, {30005, -1, -1, -1}, {32420, -1, -1, -1}, {32428, -1, -1, -1}, {32442, -1, -1, -1}, {32455, -1, -1, -1}, {32463, -1, -1, -1}, {32479, -1, -1, -1}, {32518, -1, -1, -1}, {32567, -1, -1, -1}, {33402, -1, -1, -1}, {33487, -1, -1, -1}, {33647, -1, -1, -1}, {35270, -1, -1, -1}, {35774, -1, -1, -1}, {35810, -1, -1, -1}, {36710, -1, -1, -1}, {36711, -1, -1, -1}, {36718, -1, -1, -1}, {29713, -1, -1, -1}, {31996, -1, -1, -1}, {32205, -1, -1, -1}, {26950, -1, -1, -1}, {31433, -1, -1, -1}, {30904, -1, -1, -1}, {32956, -1, -1, -1}, {36107, -1, -1, -1}, {33014, -1, -1, -1}, {62448, -1, -1, -1}, {32927, -1, -1, -1}, {40647, -1, -1, -1}, {19661, -1, -1, -1}, {40393, -1, -1, -1}, {40460, -1, -1, -1}, {19518, -1, -1, -1}, {62457, -1, -1, -1}, {62458, -1, -1, -1}, {40458, -1, -1, -1}, {62460, -1, -1, -1}, {13761, -1, -1, -1}, {28314, -1, -1, -1}, {33342, -1, -1, -1}, {29977, -1, -1, -1}, {18705, -1, -1, -1}, {39532, -1, -1, -1}, {39567, -1, -1, -1}, {40857, -1, -1, -1}, {31111, -1, -1, -1}, {62472, -1, -1, -1}, {62473, -1, -1, -1}, {62474, -1, -1, -1}, {62475, -1, -1, -1}, {20004, -1, -1, -1}, {20096, -1, -1, -1}, {20103, -1, -1, -1}, {20159, -1, -1, -1}, {20203, -1, -1, -1}, {20279, -1, -1, -1}, {13388, -1, -1, -1}, {20413, -1, -1, -1}, {15944, -1, -1, -1}, {20483, -1, -1, -1}, {13437, -1, -1, -1}, {13477, -1, -1, -1}, {22789, -1, -1, -1}, {20955, -1, -1, -1}, {20988, -1, -1, -1}, {20105, -1, -1, -1}, {21136, -1, -1, -1}, {21287, -1, -1, -1}, {13767, -1, -1, -1}, {21417, -1, -1, -1}, {13649, -1, -1, -1}, {21424, -1, -1, -1}, {21539, -1, -1, -1}, {13677, -1, -1, -1}, {13682, -1, -1, -1}, {13953, -1, -1, -1}, {21651, -1, -1, -1}, {21667, -1, -1, -1}, {21684, -1, -1, -1}, {21689, -1, -1, -1}, {21712, -1, -1, -1}, {21743, -1, -1, -1}, {21784, -1, -1, -1}, {21795, -1, -1, -1}, {21800, -1, -1, -1}, {13720, -1, -1, -1}, {13733, -1, -1, -1}, {13759, -1, -1, -1}, {21975, -1, -1, -1}, {13765, -1, -1, -1}, {62525, -1, -1, -1}, {16467, -1, -1, -1}, {62551, -1, -1, -1}, {62555, -1, -1, -1}, {62574, -1, -1, -1}, {62580, -1, -1, -1}, {62583, -1, -1, -1}, {62585, -1, -1, -1}, {62587, -1, -1, -1}, {62595, -1, -1, -1}, {62609, -1, -1, -1}, {16571, -1, -1, -1}, {62631, -1, -1, -1}, {22098, -1, -1, -1}, {62642, -1, -1, -1}, {62657, -1, -1, -1}, {62659, -1, -1, -1}, {62660, -1, -1, -1}, {62661, -1, -1, -1}, {13819, -1, -1, -1}, {62663, -1, -1, -1}, {62664, -1, -1, -1}, {62665, -1, -1, -1}, {62666, -1, -1, -1}, {16275, -1, -1, -1}, {62668, -1, -1, -1}, {62669, -1, -1, -1}, {62670, -1, -1, -1}, {62671, -1, -1, -1}, {62673, -1, -1, -1}, {62674, -1, -1, -1}, {62675, -1, -1, -1}, {62676, -1, -1, -1}, {62677, -1, -1, -1}, {16377, -1, -1, -1}, {62679, -1, -1, -1}, {25650, -1, -1, -1}, {62681, -1, -1, -1}, {62682, -1, -1, -1}, {62685, -1, -1, -1}, {62686, -1, -1, -1}, {62688, -1, -1, -1}, {62690, -1, -1, -1}, {62692, -1, -1, -1}, {62694, -1, -1, -1}, {-1, -1, -1, -1}, {33476, -1, -1, -1}, {-1, -1, -1, -1}, {62703, -1, -1, -1}, {39974, -1, -1, -1}, {-1, -1, -1, -1}, {62707, -1, -1, -1}, {33004, -1, -1, -1}, {23580, -1, -1, -1}, {62712, -1, -1, -1}, {33076, -1, -1, -1}, {14231, -1, -1, -1}, {62716, -1, -1, -1}, {37302, -1, -1, -1}, {62718, -1, -1, -1}, {62719, -1, -1, -1}, {62720, -1, -1, -1}, {62721, -1, -1, -1}, {62723, -1, -1, -1}, {13833, -1, -1, -1}, {62725, -1, -1, -1}, {22191, -1, -1, -1}, {62727, -1, -1, -1}, {62728, -1, -1, -1}, {62729, -1, -1, -1}, {62730, -1, -1, -1}, {62731, -1, -1, -1}, {62732, -1, -1, -1}, {62733, -1, -1, -1}, {62734, -1, -1, -1} },
+ {{62735, -1, -1, -1}, {62736, -1, -1, -1}, {62737, -1, -1, -1}, {23124, -1, -1, -1}, {62739, -1, -1, -1}, {62740, -1, -1, -1}, {62741, -1, -1, -1}, {62742, -1, -1, -1}, {22428, -1, -1, -1}, {62744, -1, -1, -1}, {62745, -1, -1, -1}, {62746, -1, -1, -1}, {62747, -1, -1, -1}, {62748, -1, -1, -1}, {62749, -1, -1, -1}, {14083, -1, -1, -1}, {62751, -1, -1, -1}, {62752, -1, -1, -1}, {62753, -1, -1, -1}, {62754, -1, -1, -1}, {62755, -1, -1, -1}, {62756, -1, -1, -1}, {62757, -1, -1, -1}, {62758, -1, -1, -1}, {22681, -1, -1, -1}, {21096, -1, -1, -1}, {13850, -1, -1, -1}, {62762, -1, -1, -1}, {31666, -1, -1, -1}, {23400, -1, -1, -1}, {18432, -1, -1, -1}, {19244, -1, -1, -1}, {40743, -1, -1, -1}, {18919, -1, -1, -1}, {39967, -1, -1, -1}, {39821, -1, -1, -1}, {62771, -1, -1, -1}, {62772, -1, -1, -1}, {22011, -1, -1, -1}, {13810, -1, -1, -1}, {22153, -1, -1, -1}, {23870, -1, -1, -1}, {23880, -1, -1, -1}, {15868, -1, -1, -1}, {14351, -1, -1, -1}, {23972, -1, -1, -1}, {23993, -1, -1, -1}, {14368, -1, -1, -1}, {24357, -1, -1, -1}, {24451, -1, -1, -1}, {14600, -1, -1, -1}, {14655, -1, -1, -1}, {14669, -1, -1, -1}, {24791, -1, -1, -1}, {24893, -1, -1, -1}, {23781, -1, -1, -1}, {14729, -1, -1, -1}, {25015, -1, -1, -1}, {25039, -1, -1, -1}, {14776, -1, -1, -1}, {25132, -1, -1, -1}, {25317, -1, -1, -1}, {14840, -1, -1, -1}, {22193, -1, -1, -1}, {14851, -1, -1, -1}, {25570, -1, -1, -1}, {25595, -1, -1, -1}, {25607, -1, -1, -1}, {14923, -1, -1, -1}, {25792, -1, -1, -1}, {40863, -1, -1, -1}, {14999, -1, -1, -1}, {25990, -1, -1, -1}, {15037, -1, -1, -1}, {26111, -1, -1, -1}, {26195, -1, -1, -1}, {15090, -1, -1, -1}, {26258, -1, -1, -1}, {15138, -1, -1, -1}, {26390, -1, -1, -1}, {15170, -1, -1, -1}, {26532, -1, -1, -1}, {15192, -1, -1, -1}, {26698, -1, -1, -1}, {26756, -1, -1, -1}, {15218, -1, -1, -1}, {15217, -1, -1, -1}, {15227, -1, -1, -1}, {26889, -1, -1, -1}, {26947, -1, -1, -1}, {29276, -1, -1, -1}, {26980, -1, -1, -1}, {27039, -1, -1, -1}, {27013, -1, -1, -1}, {27094, -1, -1, -1}, {15325, -1, -1, -1}, {27237, -1, -1, -1}, {27252, -1, -1, -1}, {27249, -1, -1, -1}, {27266, -1, -1, -1}, {15340, -1, -1, -1}, {27289, -1, -1, -1}, {15346, -1, -1, -1}, {27307, -1, -1, -1}, {27317, -1, -1, -1}, {27348, -1, -1, -1}, {27382, -1, -1, -1}, {27521, -1, -1, -1}, {27585, -1, -1, -1}, {27626, -1, -1, -1}, {27765, -1, -1, -1}, {27818, -1, -1, -1}, {15563, -1, -1, -1}, {27906, -1, -1, -1}, {27910, -1, -1, -1}, {27942, -1, -1, -1}, {28033, -1, -1, -1}, {15599, -1, -1, -1}, {28068, -1, -1, -1}, {28081, -1, -1, -1}, {28181, -1, -1, -1}, {28184, -1, -1, -1}, {28201, -1, -1, -1}, {28294, -1, -1, -1}, {63124, -1, -1, -1}, {28347, -1, -1, -1}, {28386, -1, -1, -1}, {28378, -1, -1, -1}, {40831, -1, -1, -1}, {28392, -1, -1, -1}, {28393, -1, -1, -1}, {28452, -1, -1, -1}, {28468, -1, -1, -1}, {15686, -1, -1, -1}, {63134, -1, -1, -1}, {28545, -1, -1, -1}, {28606, -1, -1, -1}, {15722, -1, -1, -1}, {15733, -1, -1, -1}, {29111, -1, -1, -1}, {23705, -1, -1, -1}, {15754, -1, -1, -1}, {28716, -1, -1, -1}, {15761, -1, -1, -1}, {28752, -1, -1, -1}, {28756, -1, -1, -1}, {28783, -1, -1, -1}, {28799, -1, -1, -1}, {63149, -1, -1, -1}, {17345, -1, -1, -1}, {13809, -1, -1, -1}, {63152, -1, -1, -1}, {13902, -1, -1, -1}, {15789, -1, -1, -1}, {58173, -1, -1, -1}, {26237, -1, -1, -1}, {31860, -1, -1, -1}, {29837, -1, -1, -1}, {32402, -1, -1, -1}, {17667, -1, -1, -1}, {58260, -1, -1, -1}, {58270, -1, -1, -1}, {58277, -1, -1, -1}, {13438, -1, -1, -1}, {58317, -1, -1, -1}, {58325, -1, -1, -1}, {58343, -1, -1, -1}, {-1, -1, -1, -1}, {25537, -1, -1, -1}, {30583, -1, -1, -1}, {-1, -1, -1, -1}, {58406, -1, -1, -1}, {-1, -1, -1, -1}, {58440, -1, -1, -1}, {18730, -1, -1, -1}, {58471, -1, -1, -1}, {58472, -1, -1, -1}, {58473, -1, -1, -1}, {15088, -1, -1, -1}, {28815, -1, -1, -1}, {58529, -1, -1, -1}, {58637, -1, -1, -1}, {58646, -1, -1, -1}, {26760, -1, -1, -1}, {58664, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {58802, -1, -1, -1}, {37734, -1, -1, -1}, {37519, -1, -1, -1}, {34324, -1, -1, -1}, {58986, -1, -1, -1}, {16784, -1, -1, -1}, {26511, -1, -1, -1}, {26654, -1, -1, -1}, {14435, -1, -1, -1}, {59077, -1, -1, -1}, {15129, -1, -1, -1}, {-1, -1, -1, -1}, {59241, -1, -1, -1}, {14818, -1, -1, -1}, {-1, -1, -1, -1}, {17262, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {18733, -1, -1, -1}, {28439, -1, -1, -1}, {59704, -1, -1, -1}, {-1, -1, -1, -1}, {59752, -1, -1, -1}, {32357, -1, -1, -1}, {23855, -1, -1, -1}, {15859, -1, -1, -1}, {59758, -1, -1, -1}, {59759, -1, -1, -1}, {32164, -1, -1, -1}, {33830, -1, -1, -1}, {21637, -1, -1, -1}, {59763, -1, -1, -1}, {59765, -1, -1, -1}, {22398, -1, -1, -1}, {59767, -1, -1, -1}, {59768, -1, -1, -1}, {16357, -1, -1, -1}, {59770, -1, -1, -1}, {59771, -1, -1, -1}, {28675, -1, -1, -1}, {59773, -1, -1, -1}, {23920, -1, -1, -1}, {29583, -1, -1, -1}, {59777, -1, -1, -1}, {59778, -1, -1, -1}, {20424, -1, -1, -1}, {32743, -1, -1, -1}, {29456, -1, -1, -1}, {29496, -1, -1, -1}, {29505, -1, -1, -1}, {16041, -1, -1, -1}, {29173, -1, -1, -1}, {59793, -1, -1, -1}, {29665, -1, -1, -1}, {16074, -1, -1, -1}, {16081, -1, -1, -1}, {29721, -1, -1, -1}, {29726, -1, -1, -1}, {29727, -1, -1, -1}, {16098, -1, -1, -1}, {16112, -1, -1, -1}, {16116, -1, -1, -1}, {16122, -1, -1, -1}, {29907, -1, -1, -1}, {16142, -1, -1, -1}, {16211, -1, -1, -1}, {30061, -1, -1, -1}, {30066, -1, -1, -1}, {30093, -1, -1, -1} },
+ {{16252, -1, -1, -1}, {30152, -1, -1, -1}, {30285, -1, -1, -1}, {30324, -1, -1, -1}, {16348, -1, -1, -1}, {30330, -1, -1, -1}, {29064, -1, -1, -1}, {22051, -1, -1, -1}, {35200, -1, -1, -1}, {16413, -1, -1, -1}, {30531, -1, -1, -1}, {16441, -1, -1, -1}, {16453, -1, -1, -1}, {13787, -1, -1, -1}, {30616, -1, -1, -1}, {16490, -1, -1, -1}, {16495, -1, -1, -1}, {30654, -1, -1, -1}, {30667, -1, -1, -1}, {30744, -1, -1, -1}, {30748, -1, -1, -1}, {30791, -1, -1, -1}, {30801, -1, -1, -1}, {30822, -1, -1, -1}, {33864, -1, -1, -1}, {59851, -1, -1, -1}, {31027, -1, -1, -1}, {31026, -1, -1, -1}, {16649, -1, -1, -1}, {31121, -1, -1, -1}, {31238, -1, -1, -1}, {16743, -1, -1, -1}, {16818, -1, -1, -1}, {31420, -1, -1, -1}, {33401, -1, -1, -1}, {16836, -1, -1, -1}, {31439, -1, -1, -1}, {31451, -1, -1, -1}, {16847, -1, -1, -1}, {31586, -1, -1, -1}, {31596, -1, -1, -1}, {31611, -1, -1, -1}, {31762, -1, -1, -1}, {16992, -1, -1, -1}, {17018, -1, -1, -1}, {31867, -1, -1, -1}, {31900, -1, -1, -1}, {17036, -1, -1, -1}, {31928, -1, -1, -1}, {17044, -1, -1, -1}, {36755, -1, -1, -1}, {28864, -1, -1, -1}, {59887, -1, -1, -1}, {32207, -1, -1, -1}, {32212, -1, -1, -1}, {32208, -1, -1, -1}, {32253, -1, -1, -1}, {32692, -1, -1, -1}, {29343, -1, -1, -1}, {17303, -1, -1, -1}, {32800, -1, -1, -1}, {32805, -1, -1, -1}, {32814, -1, -1, -1}, {32817, -1, -1, -1}, {32852, -1, -1, -1}, {22452, -1, -1, -1}, {28832, -1, -1, -1}, {32951, -1, -1, -1}, {33001, -1, -1, -1}, {17389, -1, -1, -1}, {33036, -1, -1, -1}, {33038, -1, -1, -1}, {33042, -1, -1, -1}, {33044, -1, -1, -1}, {17409, -1, -1, -1}, {15161, -1, -1, -1}, {33110, -1, -1, -1}, {33113, -1, -1, -1}, {33114, -1, -1, -1}, {17427, -1, -1, -1}, {33148, -1, -1, -1}, {17445, -1, -1, -1}, {17453, -1, -1, -1}, {33189, -1, -1, -1}, {22511, -1, -1, -1}, {33217, -1, -1, -1}, {33252, -1, -1, -1}, {33364, -1, -1, -1}, {17551, -1, -1, -1}, {33398, -1, -1, -1}, {33482, -1, -1, -1}, {33496, -1, -1, -1}, {17584, -1, -1, -1}, {33623, -1, -1, -1}, {38505, -1, -1, -1}, {33797, -1, -1, -1}, {28917, -1, -1, -1}, {33892, -1, -1, -1}, {33928, -1, -1, -1}, {17668, -1, -1, -1}, {33982, -1, -1, -1}, {34017, -1, -1, -1}, {34040, -1, -1, -1}, {34064, -1, -1, -1}, {34104, -1, -1, -1}, {34130, -1, -1, -1}, {17723, -1, -1, -1}, {34159, -1, -1, -1}, {34160, -1, -1, -1}, {34272, -1, -1, -1}, {17783, -1, -1, -1}, {34418, -1, -1, -1}, {34450, -1, -1, -1}, {34543, -1, -1, -1}, {38469, -1, -1, -1}, {17926, -1, -1, -1}, {17943, -1, -1, -1}, {34990, -1, -1, -1}, {35071, -1, -1, -1}, {35108, -1, -1, -1}, {35217, -1, -1, -1}, {59971, -1, -1, -1}, {35384, -1, -1, -1}, {35476, -1, -1, -1}, {35508, -1, -1, -1}, {35921, -1, -1, -1}, {36052, -1, -1, -1}, {36082, -1, -1, -1}, {36124, -1, -1, -1}, {18328, -1, -1, -1}, {36291, -1, -1, -1}, {18413, -1, -1, -1}, {36410, -1, -1, -1}, {22356, -1, -1, -1}, {22005, -1, -1, -1}, {18487, -1, -1, -1}, {36558, -1, -1, -1}, {36578, -1, -1, -1}, {36580, -1, -1, -1}, {36589, -1, -1, -1}, {36594, -1, -1, -1}, {36801, -1, -1, -1}, {36810, -1, -1, -1}, {36812, -1, -1, -1}, {36915, -1, -1, -1}, {18605, -1, -1, -1}, {39136, -1, -1, -1}, {37395, -1, -1, -1}, {18718, -1, -1, -1}, {37416, -1, -1, -1}, {37464, -1, -1, -1}, {37483, -1, -1, -1}, {37553, -1, -1, -1}, {37550, -1, -1, -1}, {37567, -1, -1, -1}, {37603, -1, -1, -1}, {37611, -1, -1, -1}, {37619, -1, -1, -1}, {37620, -1, -1, -1}, {37629, -1, -1, -1}, {37699, -1, -1, -1}, {37764, -1, -1, -1}, {37805, -1, -1, -1}, {18757, -1, -1, -1}, {18769, -1, -1, -1}, {37911, -1, -1, -1}, {37917, -1, -1, -1}, {37933, -1, -1, -1}, {37950, -1, -1, -1}, {18794, -1, -1, -1}, {37972, -1, -1, -1}, {38009, -1, -1, -1}, {38189, -1, -1, -1}, {38306, -1, -1, -1}, {18855, -1, -1, -1}, {38388, -1, -1, -1}, {38451, -1, -1, -1}, {18917, -1, -1, -1}, {18980, -1, -1, -1}, {38720, -1, -1, -1}, {18997, -1, -1, -1}, {38834, -1, -1, -1}, {38850, -1, -1, -1}, {19172, -1, -1, -1}, {39097, -1, -1, -1}, {19225, -1, -1, -1}, {39153, -1, -1, -1}, {22596, -1, -1, -1}, {39193, -1, -1, -1}, {39223, -1, -1, -1}, {39261, -1, -1, -1}, {-1, -1, -1, -1}, {19312, -1, -1, -1}, {39365, -1, -1, -1}, {19357, -1, -1, -1}, {39484, -1, -1, -1}, {39695, -1, -1, -1}, {39785, -1, -1, -1}, {39901, -1, -1, -1}, {39921, -1, -1, -1}, {39924, -1, -1, -1}, {19565, -1, -1, -1}, {39968, -1, -1, -1}, {14191, -1, -1, -1}, {60073, -1, -1, -1}, {40265, -1, -1, -1}, {40702, -1, -1, -1}, {22096, -1, -1, -1}, {40381, -1, -1, -1}, {40444, -1, -1, -1}, {38134, -1, -1, -1}, {36790, -1, -1, -1}, {40625, -1, -1, -1}, {40637, -1, -1, -1}, {40646, -1, -1, -1}, {38108, -1, -1, -1}, {40674, -1, -1, -1}, {40689, -1, -1, -1}, {40696, -1, -1, -1}, {40772, -1, -1, -1}, {60095, -1, -1, -1}, {60096, -1, -1, -1}, {60097, -1, -1, -1}, {38083, -1, -1, -1}, {60101, -1, -1, -1}, {38081, -1, -1, -1}, {60105, -1, -1, -1}, {60106, -1, -1, -1}, {60107, -1, -1, -1}, {60108, -1, -1, -1}, {22359, -1, -1, -1}, {29043, -1, -1, -1}, {60111, -1, -1, -1}, {60112, -1, -1, -1}, {60113, -1, -1, -1}, {60115, -1, -1, -1}, {60116, -1, -1, -1}, {21662, -1, -1, -1}, {60118, -1, -1, -1}, {60119, -1, -1, -1}, {60120, -1, -1, -1}, {60121, -1, -1, -1}, {60122, -1, -1, -1}, {60124, -1, -1, -1}, {60126, -1, -1, -1}, {60127, -1, -1, -1}, {60128, -1, -1, -1}, {60129, -1, -1, -1}, {60130, -1, -1, -1}, {60131, -1, -1, -1}, {60135, -1, -1, -1}, {60136, -1, -1, -1}, {60137, -1, -1, -1}, {60138, -1, -1, -1}, {60139, -1, -1, -1}, {60140, -1, -1, -1} },
+ {{60142, -1, -1, -1}, {60144, -1, -1, -1}, {60145, -1, -1, -1}, {60146, -1, -1, -1}, {60149, -1, -1, -1}, {60150, -1, -1, -1}, {13895, -1, -1, -1}, {60152, -1, -1, -1}, {60154, -1, -1, -1}, {60155, -1, -1, -1}, {21348, -1, -1, -1}, {60158, -1, -1, -1}, {60159, -1, -1, -1}, {60160, -1, -1, -1}, {60162, -1, -1, -1}, {60163, -1, -1, -1}, {60164, -1, -1, -1}, {60165, -1, -1, -1}, {28859, -1, -1, -1}, {60168, -1, -1, -1}, {60169, -1, -1, -1}, {60170, -1, -1, -1}, {60171, -1, -1, -1}, {60172, -1, -1, -1}, {60173, -1, -1, -1}, {60174, -1, -1, -1}, {60175, -1, -1, -1}, {60177, -1, -1, -1}, {60178, -1, -1, -1}, {29080, -1, -1, -1}, {60181, -1, -1, -1}, {-1, -1, -1, -1}, {14024, -1, -1, -1}, {60184, -1, -1, -1}, {60185, -1, -1, -1}, {60186, -1, -1, -1}, {60187, -1, -1, -1}, {60188, -1, -1, -1}, {60189, -1, -1, -1}, {60191, -1, -1, -1}, {60192, -1, -1, -1}, {60193, -1, -1, -1}, {60195, -1, -1, -1}, {60197, -1, -1, -1}, {60199, -1, -1, -1}, {60202, -1, -1, -1}, {60204, -1, -1, -1}, {60205, -1, -1, -1}, {60206, -1, -1, -1}, {60207, -1, -1, -1}, {60208, -1, -1, -1}, {60209, -1, -1, -1}, {60210, -1, -1, -1}, {60211, -1, -1, -1}, {60212, -1, -1, -1}, {60213, -1, -1, -1}, {60214, -1, -1, -1}, {60215, -1, -1, -1}, {60216, -1, -1, -1}, {60217, -1, -1, -1}, {60222, -1, -1, -1}, {60223, -1, -1, -1}, {60227, -1, -1, -1}, {60228, -1, -1, -1}, {22709, -1, -1, -1}, {60234, -1, -1, -1}, {60237, -1, -1, -1}, {60238, -1, -1, -1}, {60243, -1, -1, -1}, {60245, -1, -1, -1}, {60246, -1, -1, -1}, {60248, -1, -1, -1}, {60249, -1, -1, -1}, {60258, -1, -1, -1}, {60259, -1, -1, -1}, {22408, -1, -1, -1}, {60261, -1, -1, -1}, {60263, -1, -1, -1}, {60271, -1, -1, -1}, {60272, -1, -1, -1}, {60273, -1, -1, -1}, {60275, -1, -1, -1}, {22885, -1, -1, -1}, {60279, -1, -1, -1}, {60282, -1, -1, -1}, {22335, -1, -1, -1}, {60286, -1, -1, -1}, {60287, -1, -1, -1}, {60291, -1, -1, -1}, {60292, -1, -1, -1}, {60296, -1, -1, -1}, {60298, -1, -1, -1}, {60300, -1, -1, -1}, {60301, -1, -1, -1}, {60302, -1, -1, -1}, {60304, -1, -1, -1}, {60309, -1, -1, -1}, {60312, -1, -1, -1}, {60313, -1, -1, -1}, {60314, -1, -1, -1}, {22433, -1, -1, -1}, {29009, -1, -1, -1}, {60319, -1, -1, -1}, {60322, -1, -1, -1}, {60325, -1, -1, -1}, {60326, -1, -1, -1}, {60330, -1, -1, -1}, {60334, -1, -1, -1}, {60336, -1, -1, -1}, {60338, -1, -1, -1}, {60339, -1, -1, -1}, {22201, -1, -1, -1}, {60349, -1, -1, -1}, {13848, -1, -1, -1}, {60357, -1, -1, -1}, {60358, -1, -1, -1}, {60360, -1, -1, -1}, {60362, -1, -1, -1}, {60366, -1, -1, -1}, {60368, -1, -1, -1}, {60371, -1, -1, -1}, {60373, -1, -1, -1}, {60378, -1, -1, -1}, {60379, -1, -1, -1}, {60383, -1, -1, -1}, {60385, -1, -1, -1}, {60388, -1, -1, -1}, {60392, -1, -1, -1}, {60393, -1, -1, -1}, {60395, -1, -1, -1}, {60396, -1, -1, -1}, {60399, -1, -1, -1}, {60401, -1, -1, -1}, {38047, -1, -1, -1}, {60405, -1, -1, -1}, {14009, -1, -1, -1}, {60424, -1, -1, -1}, {60425, -1, -1, -1}, {22230, -1, -1, -1}, {60435, -1, -1, -1}, {60441, -1, -1, -1}, {60442, -1, -1, -1}, {60443, -1, -1, -1}, {60444, -1, -1, -1}, {60448, -1, -1, -1}, {60459, -1, -1, -1}, {60463, -1, -1, -1}, {60466, -1, -1, -1}, {60479, -1, -1, -1}, {60480, -1, -1, -1}, {60481, -1, -1, -1}, {60483, -1, -1, -1}, {60485, -1, -1, -1}, {60486, -1, -1, -1}, {60487, -1, -1, -1}, {60488, -1, -1, -1}, {60489, -1, -1, -1}, {60491, -1, -1, -1}, {60492, -1, -1, -1}, {25574, -1, -1, -1}, {60495, -1, -1, -1}, {60498, -1, -1, -1}, {60500, -1, -1, -1}, {60502, -1, -1, -1}, {60503, -1, -1, -1}, {60504, -1, -1, -1}, {60506, -1, -1, -1}, {60508, -1, -1, -1}, {60509, -1, -1, -1}, {60511, -1, -1, -1}, {60512, -1, -1, -1}, {15863, -1, -1, -1}, {60514, -1, -1, -1}, {60515, -1, -1, -1}, {36816, -1, -1, -1}, {60519, -1, -1, -1}, {60521, -1, -1, -1}, {60522, -1, -1, -1}, {60523, -1, -1, -1}, {60524, -1, -1, -1}, {60525, -1, -1, -1}, {60526, -1, -1, -1}, {60527, -1, -1, -1}, {60528, -1, -1, -1}, {60529, -1, -1, -1}, {60530, -1, -1, -1}, {60531, -1, -1, -1}, {32415, -1, -1, -1}, {60533, -1, -1, -1}, {60534, -1, -1, -1}, {19620, -1, -1, -1}, {38215, -1, -1, -1}, {60537, -1, -1, -1}, {29090, -1, -1, -1}, {60539, -1, -1, -1}, {60542, -1, -1, -1}, {19868, -1, -1, -1}, {60544, -1, -1, -1}, {36798, -1, -1, -1}, {36794, -1, -1, -1}, {60548, -1, -1, -1}, {36793, -1, -1, -1}, {60550, -1, -1, -1}, {20202, -1, -1, -1}, {60557, -1, -1, -1}, {-1, -1, -1, -1}, {60561, -1, -1, -1}, {60563, -1, -1, -1}, {60564, -1, -1, -1}, {60566, -1, -1, -1}, {60568, -1, -1, -1}, {60570, -1, -1, -1}, {60571, -1, -1, -1}, {20122, -1, -1, -1}, {60573, -1, -1, -1}, {60576, -1, -1, -1}, {60579, -1, -1, -1}, {60580, -1, -1, -1}, {60583, -1, -1, -1}, {60584, -1, -1, -1}, {60587, -1, -1, -1}, {60589, -1, -1, -1}, {15814, -1, -1, -1}, {60596, -1, -1, -1}, {19996, -1, -1, -1}, {60601, -1, -1, -1}, {60602, -1, -1, -1}, {60603, -1, -1, -1}, {60638, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {60676, -1, -1, -1}, {60679, -1, -1, -1}, {23440, -1, -1, -1}, {60682, -1, -1, -1}, {60684, -1, -1, -1}, {60685, -1, -1, -1}, {60686, -1, -1, -1}, {60687, -1, -1, -1}, {60688, -1, -1, -1}, {60689, -1, -1, -1}, {60691, -1, -1, -1}, {60693, -1, -1, -1}, {60694, -1, -1, -1}, {60695, -1, -1, -1}, {60698, -1, -1, -1}, {60700, -1, -1, -1}, {60702, -1, -1, -1}, {60706, -1, -1, -1}, {60710, -1, -1, -1}, {60711, -1, -1, -1}, {60714, -1, -1, -1}, {60717, -1, -1, -1}, {19994, -1, -1, -1}, {19972, -1, -1, -1}, {23309, -1, -1, -1} },
+ {{13996, -1, -1, -1}, {21373, -1, -1, -1}, {13989, -1, -1, -1}, {22682, -1, -1, -1}, {60733, -1, -1, -1}, {22442, -1, -1, -1}, {60737, -1, -1, -1}, {60738, -1, -1, -1}, {60741, -1, -1, -1}, {60746, -1, -1, -1}, {60747, -1, -1, -1}, {60749, -1, -1, -1}, {60750, -1, -1, -1}, {60753, -1, -1, -1}, {60755, -1, -1, -1}, {60756, -1, -1, -1}, {60759, -1, -1, -1}, {60760, -1, -1, -1}, {60785, -1, -1, -1}, {60789, -1, -1, -1}, {22439, -1, -1, -1}, {60791, -1, -1, -1}, {60794, -1, -1, -1}, {60801, -1, -1, -1}, {60806, -1, -1, -1}, {60809, -1, -1, -1}, {60810, -1, -1, -1}, {39963, -1, -1, -1}, {60838, -1, -1, -1}, {15878, -1, -1, -1}, {60881, -1, -1, -1}, {60887, -1, -1, -1}, {60891, -1, -1, -1}, {60893, -1, -1, -1}, {-1, -1, -1, -1}, {21722, -1, -1, -1}, {29050, -1, -1, -1}, {60949, -1, -1, -1}, {60955, -1, -1, -1}, {60962, -1, -1, -1}, {60976, -1, -1, -1}, {61000, -1, -1, -1}, {61014, -1, -1, -1}, {61019, -1, -1, -1}, {61024, -1, -1, -1}, {61054, -1, -1, -1}, {13877, -1, -1, -1}, {61084, -1, -1, -1}, {21024, -1, -1, -1}, {61089, -1, -1, -1}, {61090, -1, -1, -1}, {61091, -1, -1, -1}, {61092, -1, -1, -1}, {61093, -1, -1, -1}, {61094, -1, -1, -1}, {61096, -1, -1, -1}, {61097, -1, -1, -1}, {61098, -1, -1, -1}, {61100, -1, -1, -1}, {61101, -1, -1, -1}, {61102, -1, -1, -1}, {61103, -1, -1, -1}, {61104, -1, -1, -1}, {61105, -1, -1, -1}, {17762, -1, -1, -1}, {23327, -1, -1, -1}, {61108, -1, -1, -1}, {40784, -1, -1, -1}, {40614, -1, -1, -1}, {61111, -1, -1, -1}, {-1, -1, -1, -1}, {21314, -1, -1, -1}, {26285, -1, -1, -1}, {22620, -1, -1, -1}, {-1, -1, -1, -1}, {15749, -1, -1, -1}, {24928, -1, -1, -1}, {18606, -1, -1, -1}, {38845, -1, -1, -1}, {57693, -1, -1, -1}, {-1, -1, -1, -1}, {33828, -1, -1, -1}, {38932, -1, -1, -1}, {57749, -1, -1, -1}, {57764, -1, -1, -1}, {57787, -1, -1, -1}, {15147, -1, -1, -1}, {15666, -1, -1, -1}, {57857, -1, -1, -1}, {28801, -1, -1, -1}, {23708, -1, -1, -1}, {58017, -1, -1, -1}, {14128, -1, -1, -1}, {58096, -1, -1, -1}, {58097, -1, -1, -1}, {58111, -1, -1, -1}, {58112, -1, -1, -1}, {256, -1, -1, -1}, {193, -1, -1, -1}, {461, -1, -1, -1}, {192, -1, -1, -1}, {274, -1, -1, -1}, {201, -1, -1, -1}, {282, -1, -1, -1}, {200, -1, -1, -1}, {332, -1, -1, -1}, {211, -1, -1, -1}, {465, -1, -1, -1}, {210, -1, -1, -1}, {62245, -1, -1, -1}, {7870, -1, -1, -1}, {62247, -1, -1, -1}, {7872, -1, -1, -1}, {202, -1, -1, -1}, {257, -1, -1, -1}, {225, -1, -1, -1}, {462, -1, -1, -1}, {224, -1, -1, -1}, {593, -1, -1, -1}, {275, -1, -1, -1}, {233, -1, -1, -1}, {283, -1, -1, -1}, {232, -1, -1, -1}, {299, -1, -1, -1}, {237, -1, -1, -1}, {464, -1, -1, -1}, {236, -1, -1, -1}, {333, -1, -1, -1}, {243, -1, -1, -1}, {466, -1, -1, -1}, {242, -1, -1, -1}, {363, -1, -1, -1}, {250, -1, -1, -1}, {468, -1, -1, -1}, {249, -1, -1, -1}, {470, -1, -1, -1}, {472, -1, -1, -1}, {474, -1, -1, -1}, {476, -1, -1, -1}, {252, -1, -1, -1}, {62276, -1, -1, -1}, {7871, -1, -1, -1}, {62278, -1, -1, -1}, {7873, -1, -1, -1}, {234, -1, -1, -1}, {609, -1, -1, -1}, {643, -1, -1, -1}, {592, -1, -1, -1}, {603, -1, -1, -1}, {596, -1, -1, -1}, {629, -1, -1, -1}, {339, -1, -1, -1}, {248, -1, -1, -1}, {331, -1, -1, -1}, {650, -1, -1, -1}, {618, -1, -1, -1}, {62282, -1, -1, -1}, {62283, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ }
+};
+
+static const pdfi_cid_decoding_t gb1_unicode = {
+ "GB1", "Unicode",
+ 114,
+ 4,
+ {
+ {{-1, -1, -1, -1}, {32, -1, -1, -1}, {33, -1, -1, -1}, {34, -1, -1, -1}, {35, -1, -1, -1}, {36, -1, -1, -1}, {37, -1, -1, -1}, {38, -1, -1, -1}, {39, -1, -1, -1}, {40, -1, -1, -1}, {41, -1, -1, -1}, {42, -1, -1, -1}, {43, -1, -1, -1}, {44, -1, -1, -1}, {45, -1, -1, -1}, {46, -1, -1, -1}, {47, -1, -1, -1}, {48, -1, -1, -1}, {49, -1, -1, -1}, {50, -1, -1, -1}, {51, -1, -1, -1}, {52, -1, -1, -1}, {53, -1, -1, -1}, {54, -1, -1, -1}, {55, -1, -1, -1}, {56, -1, -1, -1}, {57, -1, -1, -1}, {58, -1, -1, -1}, {59, -1, -1, -1}, {60, -1, -1, -1}, {61, -1, -1, -1}, {62, -1, -1, -1}, {63, -1, -1, -1}, {64, -1, -1, -1}, {65, -1, -1, -1}, {66, -1, -1, -1}, {67, -1, -1, -1}, {68, -1, -1, -1}, {69, -1, -1, -1}, {70, -1, -1, -1}, {71, -1, -1, -1}, {72, -1, -1, -1}, {73, -1, -1, -1}, {74, -1, -1, -1}, {75, -1, -1, -1}, {76, -1, -1, -1}, {77, -1, -1, -1}, {78, -1, -1, -1}, {79, -1, -1, -1}, {80, -1, -1, -1}, {81, -1, -1, -1}, {82, -1, -1, -1}, {83, -1, -1, -1}, {84, -1, -1, -1}, {85, -1, -1, -1}, {86, -1, -1, -1}, {87, -1, -1, -1}, {88, -1, -1, -1}, {89, -1, -1, -1}, {90, -1, -1, -1}, {91, -1, -1, -1}, {92, -1, -1, -1}, {93, -1, -1, -1}, {94, -1, -1, -1}, {95, -1, -1, -1}, {96, -1, -1, -1}, {97, -1, -1, -1}, {98, -1, -1, -1}, {99, -1, -1, -1}, {100, -1, -1, -1}, {101, -1, -1, -1}, {102, -1, -1, -1}, {103, -1, -1, -1}, {104, -1, -1, -1}, {105, -1, -1, -1}, {106, -1, -1, -1}, {107, -1, -1, -1}, {108, -1, -1, -1}, {109, -1, -1, -1}, {110, -1, -1, -1}, {111, -1, -1, -1}, {112, -1, -1, -1}, {113, -1, -1, -1}, {114, -1, -1, -1}, {115, -1, -1, -1}, {116, -1, -1, -1}, {117, -1, -1, -1}, {118, -1, -1, -1}, {119, -1, -1, -1}, {120, -1, -1, -1}, {121, -1, -1, -1}, {122, -1, -1, -1}, {123, -1, -1, -1}, {124, -1, -1, -1}, {125, -1, -1, -1}, {126, -1, -1, -1}, {12288, -1, -1, -1}, {12289, -1, -1, -1}, {12290, -1, -1, -1}, {12539, -1, -1, -1}, {713, -1, -1, -1}, {711, -1, -1, -1}, {168, -1, -1, -1}, {12291, -1, -1, -1}, {12293, -1, -1, -1}, {8212, -1, -1, -1}, {65374, -1, -1, -1}, {8214, -1, -1, -1}, {8230, 8943, -1, -1}, {8216, -1, -1, -1}, {8217, -1, -1, -1}, {8220, -1, -1, -1}, {8221, -1, -1, -1}, {12308, -1, -1, -1}, {12309, -1, -1, -1}, {12296, -1, -1, -1}, {12297, -1, -1, -1}, {12298, -1, -1, -1}, {12299, -1, -1, -1}, {12300, -1, -1, -1}, {12301, -1, -1, -1}, {12302, -1, -1, -1}, {12303, -1, -1, -1}, {12310, -1, -1, -1}, {12311, -1, -1, -1}, {12304, -1, -1, -1}, {12305, -1, -1, -1}, {177, -1, -1, -1}, {215, -1, -1, -1}, {247, -1, -1, -1}, {8758, -1, -1, -1}, {8743, -1, -1, -1}, {8744, -1, -1, -1}, {8721, -1, -1, -1}, {8719, -1, -1, -1}, {8746, -1, -1, -1}, {8745, -1, -1, -1}, {8712, -1, -1, -1}, {8759, -1, -1, -1}, {8730, -1, -1, -1}, {8869, -1, -1, -1}, {8741, -1, -1, -1}, {8736, -1, -1, -1}, {8978, -1, -1, -1}, {8857, -1, -1, -1}, {8747, -1, -1, -1}, {8750, -1, -1, -1}, {8801, -1, -1, -1}, {8780, -1, -1, -1}, {8776, -1, -1, -1}, {8765, -1, -1, -1}, {8733, -1, -1, -1}, {8800, -1, -1, -1}, {8814, -1, -1, -1}, {8815, -1, -1, -1}, {8804, -1, -1, -1}, {8805, -1, -1, -1}, {8734, -1, -1, -1}, {8757, -1, -1, -1}, {8756, -1, -1, -1}, {9794, -1, -1, -1}, {9792, -1, -1, -1}, {176, -1, -1, -1}, {8242, -1, -1, -1}, {8243, -1, -1, -1}, {8451, -1, -1, -1}, {65284, -1, -1, -1}, {164, -1, -1, -1}, {65504, -1, -1, -1}, {65505, -1, -1, -1}, {8240, -1, -1, -1}, {167, -1, -1, -1}, {8470, -1, -1, -1}, {9734, -1, -1, -1}, {9733, -1, -1, -1}, {9675, -1, -1, -1}, {9679, -1, -1, -1}, {9678, -1, -1, -1}, {9671, -1, -1, -1}, {9670, -1, -1, -1}, {9633, -1, -1, -1}, {9632, -1, -1, -1}, {9651, -1, -1, -1}, {9650, -1, -1, -1}, {8251, -1, -1, -1}, {8594, -1, -1, -1}, {8592, -1, -1, -1}, {8593, -1, -1, -1}, {8595, -1, -1, -1}, {12307, -1, -1, -1}, {9352, -1, -1, -1}, {9353, -1, -1, -1}, {9354, -1, -1, -1}, {9355, -1, -1, -1}, {9356, -1, -1, -1}, {9357, -1, -1, -1}, {9358, -1, -1, -1}, {9359, -1, -1, -1}, {9360, -1, -1, -1}, {9361, -1, -1, -1}, {9362, -1, -1, -1}, {9363, -1, -1, -1}, {9364, -1, -1, -1}, {9365, -1, -1, -1}, {9366, -1, -1, -1}, {9367, -1, -1, -1}, {9368, -1, -1, -1}, {9369, -1, -1, -1}, {9370, -1, -1, -1}, {9371, -1, -1, -1}, {9332, -1, -1, -1}, {9333, -1, -1, -1}, {9334, -1, -1, -1}, {9335, -1, -1, -1}, {9336, -1, -1, -1}, {9337, -1, -1, -1}, {9338, -1, -1, -1}, {9339, -1, -1, -1}, {9340, -1, -1, -1}, {9341, -1, -1, -1}, {9342, -1, -1, -1}, {9343, -1, -1, -1}, {9344, -1, -1, -1}, {9345, -1, -1, -1}, {9346, -1, -1, -1}, {9347, -1, -1, -1}, {9348, -1, -1, -1}, {9349, -1, -1, -1}, {9350, -1, -1, -1}, {9351, -1, -1, -1}, {9312, -1, -1, -1}, {9313, -1, -1, -1}, {9314, -1, -1, -1}, {9315, -1, -1, -1}, {9316, -1, -1, -1}, {9317, -1, -1, -1}, {9318, -1, -1, -1}, {9319, -1, -1, -1}, {9320, -1, -1, -1}, {9321, -1, -1, -1}, {12832, -1, -1, -1}, {12833, -1, -1, -1}, {12834, -1, -1, -1}, {12835, -1, -1, -1}, {12836, -1, -1, -1}, {12837, -1, -1, -1}, {12838, -1, -1, -1}, {12839, -1, -1, -1}, {12840, -1, -1, -1}, {12841, -1, -1, -1}, {8544, -1, -1, -1}, {8545, -1, -1, -1}, {8546, -1, -1, -1}, {8547, -1, -1, -1}, {8548, -1, -1, -1}, {8549, -1, -1, -1} },
+ {{8550, -1, -1, -1}, {8551, -1, -1, -1}, {8552, -1, -1, -1}, {8553, -1, -1, -1}, {8554, -1, -1, -1}, {8555, -1, -1, -1}, {65281, -1, -1, -1}, {65282, -1, -1, -1}, {65283, -1, -1, -1}, {65509, -1, -1, -1}, {65285, -1, -1, -1}, {65286, -1, -1, -1}, {65287, -1, -1, -1}, {65288, -1, -1, -1}, {65289, -1, -1, -1}, {65290, -1, -1, -1}, {65291, -1, -1, -1}, {65292, -1, -1, -1}, {65293, -1, -1, -1}, {65294, -1, -1, -1}, {65295, -1, -1, -1}, {65296, -1, -1, -1}, {65297, -1, -1, -1}, {65298, -1, -1, -1}, {65299, -1, -1, -1}, {65300, -1, -1, -1}, {65301, -1, -1, -1}, {65302, -1, -1, -1}, {65303, -1, -1, -1}, {65304, -1, -1, -1}, {65305, -1, -1, -1}, {65306, -1, -1, -1}, {65307, -1, -1, -1}, {65308, -1, -1, -1}, {65309, -1, -1, -1}, {65310, -1, -1, -1}, {65311, -1, -1, -1}, {65312, -1, -1, -1}, {65313, -1, -1, -1}, {65314, -1, -1, -1}, {65315, -1, -1, -1}, {65316, -1, -1, -1}, {65317, -1, -1, -1}, {65318, -1, -1, -1}, {65319, -1, -1, -1}, {65320, -1, -1, -1}, {65321, -1, -1, -1}, {65322, -1, -1, -1}, {65323, -1, -1, -1}, {65324, -1, -1, -1}, {65325, -1, -1, -1}, {65326, -1, -1, -1}, {65327, -1, -1, -1}, {65328, -1, -1, -1}, {65329, -1, -1, -1}, {65330, -1, -1, -1}, {65331, -1, -1, -1}, {65332, -1, -1, -1}, {65333, -1, -1, -1}, {65334, -1, -1, -1}, {65335, -1, -1, -1}, {65336, -1, -1, -1}, {65337, -1, -1, -1}, {65338, -1, -1, -1}, {65339, -1, -1, -1}, {65340, -1, -1, -1}, {65341, -1, -1, -1}, {65342, -1, -1, -1}, {65343, -1, -1, -1}, {65344, -1, -1, -1}, {65345, -1, -1, -1}, {65346, -1, -1, -1}, {65347, -1, -1, -1}, {65348, -1, -1, -1}, {65349, -1, -1, -1}, {65350, -1, -1, -1}, {65351, -1, -1, -1}, {65352, -1, -1, -1}, {65353, -1, -1, -1}, {65354, -1, -1, -1}, {65355, -1, -1, -1}, {65356, -1, -1, -1}, {65357, -1, -1, -1}, {65358, -1, -1, -1}, {65359, -1, -1, -1}, {65360, -1, -1, -1}, {65361, -1, -1, -1}, {65362, -1, -1, -1}, {65363, -1, -1, -1}, {65364, -1, -1, -1}, {65365, -1, -1, -1}, {65366, -1, -1, -1}, {65367, -1, -1, -1}, {65368, -1, -1, -1}, {65369, -1, -1, -1}, {65370, -1, -1, -1}, {65371, -1, -1, -1}, {65372, -1, -1, -1}, {65373, -1, -1, -1}, {65507, -1, -1, -1}, {12353, -1, -1, -1}, {12354, -1, -1, -1}, {12355, -1, -1, -1}, {12356, -1, -1, -1}, {12357, -1, -1, -1}, {12358, -1, -1, -1}, {12359, -1, -1, -1}, {12360, -1, -1, -1}, {12361, -1, -1, -1}, {12362, -1, -1, -1}, {12363, -1, -1, -1}, {12364, -1, -1, -1}, {12365, -1, -1, -1}, {12366, -1, -1, -1}, {12367, -1, -1, -1}, {12368, -1, -1, -1}, {12369, -1, -1, -1}, {12370, -1, -1, -1}, {12371, -1, -1, -1}, {12372, -1, -1, -1}, {12373, -1, -1, -1}, {12374, -1, -1, -1}, {12375, -1, -1, -1}, {12376, -1, -1, -1}, {12377, -1, -1, -1}, {12378, -1, -1, -1}, {12379, -1, -1, -1}, {12380, -1, -1, -1}, {12381, -1, -1, -1}, {12382, -1, -1, -1}, {12383, -1, -1, -1}, {12384, -1, -1, -1}, {12385, -1, -1, -1}, {12386, -1, -1, -1}, {12387, -1, -1, -1}, {12388, -1, -1, -1}, {12389, -1, -1, -1}, {12390, -1, -1, -1}, {12391, -1, -1, -1}, {12392, -1, -1, -1}, {12393, -1, -1, -1}, {12394, -1, -1, -1}, {12395, -1, -1, -1}, {12396, -1, -1, -1}, {12397, -1, -1, -1}, {12398, -1, -1, -1}, {12399, -1, -1, -1}, {12400, -1, -1, -1}, {12401, -1, -1, -1}, {12402, -1, -1, -1}, {12403, -1, -1, -1}, {12404, -1, -1, -1}, {12405, -1, -1, -1}, {12406, -1, -1, -1}, {12407, -1, -1, -1}, {12408, -1, -1, -1}, {12409, -1, -1, -1}, {12410, -1, -1, -1}, {12411, -1, -1, -1}, {12412, -1, -1, -1}, {12413, -1, -1, -1}, {12414, -1, -1, -1}, {12415, -1, -1, -1}, {12416, -1, -1, -1}, {12417, -1, -1, -1}, {12418, -1, -1, -1}, {12419, -1, -1, -1}, {12420, -1, -1, -1}, {12421, -1, -1, -1}, {12422, -1, -1, -1}, {12423, -1, -1, -1}, {12424, -1, -1, -1}, {12425, -1, -1, -1}, {12426, -1, -1, -1}, {12427, -1, -1, -1}, {12428, -1, -1, -1}, {12429, -1, -1, -1}, {12430, -1, -1, -1}, {12431, -1, -1, -1}, {12432, -1, -1, -1}, {12433, -1, -1, -1}, {12434, -1, -1, -1}, {12435, -1, -1, -1}, {12449, -1, -1, -1}, {12450, -1, -1, -1}, {12451, -1, -1, -1}, {12452, -1, -1, -1}, {12453, -1, -1, -1}, {12454, -1, -1, -1}, {12455, -1, -1, -1}, {12456, -1, -1, -1}, {12457, -1, -1, -1}, {12458, -1, -1, -1}, {12459, -1, -1, -1}, {12460, -1, -1, -1}, {12461, -1, -1, -1}, {12462, -1, -1, -1}, {12463, -1, -1, -1}, {12464, -1, -1, -1}, {12465, -1, -1, -1}, {12466, -1, -1, -1}, {12467, -1, -1, -1}, {12468, -1, -1, -1}, {12469, -1, -1, -1}, {12470, -1, -1, -1}, {12471, -1, -1, -1}, {12472, -1, -1, -1}, {12473, -1, -1, -1}, {12474, -1, -1, -1}, {12475, -1, -1, -1}, {12476, -1, -1, -1}, {12477, -1, -1, -1}, {12478, -1, -1, -1}, {12479, -1, -1, -1}, {12480, -1, -1, -1}, {12481, -1, -1, -1}, {12482, -1, -1, -1}, {12483, -1, -1, -1}, {12484, -1, -1, -1}, {12485, -1, -1, -1}, {12486, -1, -1, -1}, {12487, -1, -1, -1}, {12488, -1, -1, -1}, {12489, -1, -1, -1}, {12490, -1, -1, -1}, {12491, -1, -1, -1}, {12492, -1, -1, -1}, {12493, -1, -1, -1}, {12494, -1, -1, -1}, {12495, -1, -1, -1}, {12496, -1, -1, -1}, {12497, -1, -1, -1}, {12498, -1, -1, -1}, {12499, -1, -1, -1}, {12500, -1, -1, -1}, {12501, -1, -1, -1}, {12502, -1, -1, -1}, {12503, -1, -1, -1}, {12504, -1, -1, -1}, {12505, -1, -1, -1}, {12506, -1, -1, -1}, {12507, -1, -1, -1}, {12508, -1, -1, -1}, {12509, -1, -1, -1}, {12510, -1, -1, -1}, {12511, -1, -1, -1}, {12512, -1, -1, -1}, {12513, -1, -1, -1}, {12514, -1, -1, -1}, {12515, -1, -1, -1}, {12516, -1, -1, -1}, {12517, -1, -1, -1}, {12518, -1, -1, -1}, {12519, -1, -1, -1}, {12520, -1, -1, -1}, {12521, -1, -1, -1} },
+ {{12522, -1, -1, -1}, {12523, -1, -1, -1}, {12524, -1, -1, -1}, {12525, -1, -1, -1}, {12526, -1, -1, -1}, {12527, -1, -1, -1}, {12528, -1, -1, -1}, {12529, -1, -1, -1}, {12530, -1, -1, -1}, {12531, -1, -1, -1}, {12532, -1, -1, -1}, {12533, -1, -1, -1}, {12534, -1, -1, -1}, {913, -1, -1, -1}, {914, -1, -1, -1}, {915, -1, -1, -1}, {916, -1, -1, -1}, {917, -1, -1, -1}, {918, -1, -1, -1}, {919, -1, -1, -1}, {920, -1, -1, -1}, {921, -1, -1, -1}, {922, -1, -1, -1}, {923, -1, -1, -1}, {924, -1, -1, -1}, {925, -1, -1, -1}, {926, -1, -1, -1}, {927, -1, -1, -1}, {928, -1, -1, -1}, {929, -1, -1, -1}, {931, -1, -1, -1}, {932, -1, -1, -1}, {933, -1, -1, -1}, {934, -1, -1, -1}, {935, -1, -1, -1}, {936, -1, -1, -1}, {937, -1, -1, -1}, {945, -1, -1, -1}, {946, -1, -1, -1}, {947, -1, -1, -1}, {948, -1, -1, -1}, {949, -1, -1, -1}, {950, -1, -1, -1}, {951, -1, -1, -1}, {952, -1, -1, -1}, {953, -1, -1, -1}, {954, -1, -1, -1}, {955, -1, -1, -1}, {956, -1, -1, -1}, {957, -1, -1, -1}, {958, -1, -1, -1}, {959, -1, -1, -1}, {960, -1, -1, -1}, {961, -1, -1, -1}, {963, -1, -1, -1}, {964, -1, -1, -1}, {965, -1, -1, -1}, {966, -1, -1, -1}, {967, -1, -1, -1}, {968, -1, -1, -1}, {969, -1, -1, -1}, {65292, -1, -1, -1}, {12290, -1, -1, -1}, {12289, -1, -1, -1}, {65306, -1, -1, -1}, {65307, -1, -1, -1}, {65281, -1, -1, -1}, {65311, -1, -1, -1}, {65288, -1, -1, -1}, {65289, -1, -1, -1}, {12308, -1, -1, -1}, {12309, -1, -1, -1}, {12296, -1, -1, -1}, {12297, -1, -1, -1}, {12298, -1, -1, -1}, {12299, -1, -1, -1}, {12300, -1, -1, -1}, {12301, -1, -1, -1}, {12302, -1, -1, -1}, {12303, -1, -1, -1}, {12310, -1, -1, -1}, {12311, -1, -1, -1}, {12304, -1, -1, -1}, {12305, -1, -1, -1}, {65371, -1, -1, -1}, {65373, -1, -1, -1}, {8212, -1, -1, -1}, {8230, -1, -1, -1}, {65343, -1, -1, -1}, {-1, -1, -1, -1}, {1040, -1, -1, -1}, {1041, -1, -1, -1}, {1042, -1, -1, -1}, {1043, -1, -1, -1}, {1044, -1, -1, -1}, {1045, -1, -1, -1}, {1025, -1, -1, -1}, {1046, -1, -1, -1}, {1047, -1, -1, -1}, {1048, -1, -1, -1}, {1049, -1, -1, -1}, {1050, -1, -1, -1}, {1051, -1, -1, -1}, {1052, -1, -1, -1}, {1053, -1, -1, -1}, {1054, -1, -1, -1}, {1055, -1, -1, -1}, {1056, -1, -1, -1}, {1057, -1, -1, -1}, {1058, -1, -1, -1}, {1059, -1, -1, -1}, {1060, -1, -1, -1}, {1061, -1, -1, -1}, {1062, -1, -1, -1}, {1063, -1, -1, -1}, {1064, -1, -1, -1}, {1065, -1, -1, -1}, {1066, -1, -1, -1}, {1067, -1, -1, -1}, {1068, -1, -1, -1}, {1069, -1, -1, -1}, {1070, -1, -1, -1}, {1071, -1, -1, -1}, {1072, -1, -1, -1}, {1073, -1, -1, -1}, {1074, -1, -1, -1}, {1075, -1, -1, -1}, {1076, -1, -1, -1}, {1077, -1, -1, -1}, {1105, -1, -1, -1}, {1078, -1, -1, -1}, {1079, -1, -1, -1}, {1080, -1, -1, -1}, {1081, -1, -1, -1}, {1082, -1, -1, -1}, {1083, -1, -1, -1}, {1084, -1, -1, -1}, {1085, -1, -1, -1}, {1086, -1, -1, -1}, {1087, -1, -1, -1}, {1088, -1, -1, -1}, {1089, -1, -1, -1}, {1090, -1, -1, -1}, {1091, -1, -1, -1}, {1092, -1, -1, -1}, {1093, -1, -1, -1}, {1094, -1, -1, -1}, {1095, -1, -1, -1}, {1096, -1, -1, -1}, {1097, -1, -1, -1}, {1098, -1, -1, -1}, {1099, -1, -1, -1}, {1100, -1, -1, -1}, {1101, -1, -1, -1}, {1102, -1, -1, -1}, {1103, -1, -1, -1}, {257, -1, -1, -1}, {225, -1, -1, -1}, {462, -1, -1, -1}, {224, -1, -1, -1}, {275, -1, -1, -1}, {233, -1, -1, -1}, {283, -1, -1, -1}, {232, -1, -1, -1}, {299, -1, -1, -1}, {237, -1, -1, -1}, {464, -1, -1, -1}, {236, -1, -1, -1}, {333, -1, -1, -1}, {243, -1, -1, -1}, {466, -1, -1, -1}, {242, -1, -1, -1}, {363, -1, -1, -1}, {250, -1, -1, -1}, {468, -1, -1, -1}, {249, -1, -1, -1}, {470, -1, -1, -1}, {472, -1, -1, -1}, {474, -1, -1, -1}, {476, -1, -1, -1}, {252, -1, -1, -1}, {234, -1, -1, -1}, {-1, -1, -1, -1}, {7743, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {505, -1, -1, -1}, {-1, -1, -1, -1}, {12549, -1, -1, -1}, {12550, -1, -1, -1}, {12551, -1, -1, -1}, {12552, -1, -1, -1}, {12553, -1, -1, -1}, {12554, -1, -1, -1}, {12555, -1, -1, -1}, {12556, -1, -1, -1}, {12557, -1, -1, -1}, {12558, -1, -1, -1}, {12559, -1, -1, -1}, {12560, -1, -1, -1}, {12561, -1, -1, -1}, {12562, -1, -1, -1}, {12563, -1, -1, -1}, {12564, -1, -1, -1}, {12565, -1, -1, -1}, {12566, -1, -1, -1}, {12567, -1, -1, -1}, {12568, -1, -1, -1}, {12569, -1, -1, -1}, {12570, -1, -1, -1}, {12571, -1, -1, -1}, {12572, -1, -1, -1}, {12573, -1, -1, -1}, {12574, -1, -1, -1}, {12575, -1, -1, -1}, {12576, -1, -1, -1}, {12577, -1, -1, -1}, {12578, -1, -1, -1}, {12579, -1, -1, -1}, {12580, -1, -1, -1}, {12581, -1, -1, -1}, {12582, -1, -1, -1}, {12583, -1, -1, -1}, {12584, -1, -1, -1}, {12585, -1, -1, -1}, {-1, -1, -1, -1}, {9472, -1, -1, -1}, {9473, -1, -1, -1}, {9474, -1, -1, -1}, {9475, -1, -1, -1}, {9476, -1, -1, -1}, {9477, -1, -1, -1}, {9478, -1, -1, -1}, {9479, -1, -1, -1}, {9480, -1, -1, -1}, {9481, -1, -1, -1}, {9482, -1, -1, -1}, {9483, -1, -1, -1}, {9484, -1, -1, -1}, {9485, -1, -1, -1}, {9486, -1, -1, -1}, {9487, -1, -1, -1}, {9488, -1, -1, -1}, {9489, -1, -1, -1}, {9490, -1, -1, -1}, {9491, -1, -1, -1}, {9492, -1, -1, -1}, {9493, -1, -1, -1}, {9494, -1, -1, -1}, {9495, -1, -1, -1}, {9496, -1, -1, -1}, {9497, -1, -1, -1}, {9498, -1, -1, -1}, {9499, -1, -1, -1}, {9500, -1, -1, -1}, {9501, -1, -1, -1} },
+ {{9502, -1, -1, -1}, {9503, -1, -1, -1}, {9504, -1, -1, -1}, {9505, -1, -1, -1}, {9506, -1, -1, -1}, {9507, -1, -1, -1}, {9508, -1, -1, -1}, {9509, -1, -1, -1}, {9510, -1, -1, -1}, {9511, -1, -1, -1}, {9512, -1, -1, -1}, {9513, -1, -1, -1}, {9514, -1, -1, -1}, {9515, -1, -1, -1}, {9516, -1, -1, -1}, {9517, -1, -1, -1}, {9518, -1, -1, -1}, {9519, -1, -1, -1}, {9520, -1, -1, -1}, {9521, -1, -1, -1}, {9522, -1, -1, -1}, {9523, -1, -1, -1}, {9524, -1, -1, -1}, {9525, -1, -1, -1}, {9526, -1, -1, -1}, {9527, -1, -1, -1}, {9528, -1, -1, -1}, {9529, -1, -1, -1}, {9530, -1, -1, -1}, {9531, -1, -1, -1}, {9532, -1, -1, -1}, {9533, -1, -1, -1}, {9534, -1, -1, -1}, {9535, -1, -1, -1}, {9536, -1, -1, -1}, {9537, -1, -1, -1}, {9538, -1, -1, -1}, {9539, -1, -1, -1}, {9540, -1, -1, -1}, {9541, -1, -1, -1}, {9542, -1, -1, -1}, {9543, -1, -1, -1}, {9544, -1, -1, -1}, {9545, -1, -1, -1}, {9546, -1, -1, -1}, {9547, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {21834, -1, -1, -1}, {38463, -1, -1, -1}, {22467, -1, -1, -1}, {25384, -1, -1, -1}, {21710, -1, -1, -1}, {21769, -1, -1, -1}, {21696, -1, -1, -1}, {30353, -1, -1, -1}, {30284, -1, -1, -1}, {34108, -1, -1, -1}, {30702, -1, -1, -1}, {33406, -1, -1, -1}, {30861, -1, -1, -1}, {29233, -1, -1, -1}, {38552, -1, -1, -1}, {38797, -1, -1, -1}, {27688, -1, -1, -1}, {23433, -1, -1, -1}, {20474, -1, -1, -1}, {25353, -1, -1, -1}, {26263, -1, -1, -1}, {23736, -1, -1, -1}, {33018, -1, -1, -1}, {26696, -1, -1, -1}, {32942, -1, -1, -1}, {26114, -1, -1, -1}, {30414, -1, -1, -1}, {20985, -1, -1, -1}, {25942, -1, -1, -1}, {29100, -1, -1, -1}, {32753, -1, -1, -1}, {34948, -1, -1, -1}, {20658, -1, -1, -1}, {22885, -1, -1, -1}, {25034, -1, -1, -1}, {28595, -1, -1, -1}, {33453, -1, -1, -1}, {25420, -1, -1, -1}, {25170, -1, -1, -1}, {21485, -1, -1, -1}, {21543, -1, -1, -1}, {31494, -1, -1, -1}, {12043, 20843, -1, -1}, {30116, -1, -1, -1}, {24052, -1, -1, -1}, {25300, -1, -1, -1}, {36299, -1, -1, -1}, {38774, -1, -1, -1}, {25226, -1, -1, -1}, {32793, -1, -1, -1}, {22365, -1, -1, -1}, {38712, -1, -1, -1}, {32610, -1, -1, -1}, {29240, -1, -1, -1}, {12137, 30333, -1, -1}, {26575, -1, -1, -1}, {30334, -1, -1, -1}, {25670, -1, -1, -1}, {20336, -1, -1, -1}, {36133, -1, -1, -1}, {25308, -1, -1, -1}, {31255, -1, -1, -1}, {26001, -1, -1, -1}, {29677, -1, -1, -1}, {25644, -1, -1, -1}, {25203, -1, -1, -1}, {33324, -1, -1, -1}, {39041, -1, -1, -1}, {26495, -1, -1, -1}, {29256, -1, -1, -1}, {25198, -1, -1, -1}, {25292, -1, -1, -1}, {20276, -1, -1, -1}, {29923, -1, -1, -1}, {21322, -1, -1, -1}, {21150, -1, -1, -1}, {32458, -1, -1, -1}, {37030, -1, -1, -1}, {24110, -1, -1, -1}, {26758, -1, -1, -1}, {27036, -1, -1, -1}, {33152, -1, -1, -1}, {32465, -1, -1, -1}, {26834, -1, -1, -1} },
+ {{30917, -1, -1, -1}, {34444, -1, -1, -1}, {38225, -1, -1, -1}, {20621, -1, -1, -1}, {35876, -1, -1, -1}, {33502, -1, -1, -1}, {32990, -1, -1, -1}, {21253, -1, -1, -1}, {35090, -1, -1, -1}, {21093, -1, -1, -1}, {34180, -1, -1, -1}, {38649, -1, -1, -1}, {20445, -1, -1, -1}, {22561, -1, -1, -1}, {39281, -1, -1, -1}, {23453, -1, -1, -1}, {25265, -1, -1, -1}, {25253, -1, -1, -1}, {26292, -1, -1, -1}, {35961, -1, -1, -1}, {40077, -1, -1, -1}, {29190, -1, -1, -1}, {26479, -1, -1, -1}, {30865, -1, -1, -1}, {24754, -1, -1, -1}, {21329, -1, -1, -1}, {21271, -1, -1, -1}, {36744, -1, -1, -1}, {32972, -1, -1, -1}, {36125, -1, -1, -1}, {38049, -1, -1, -1}, {20493, -1, -1, -1}, {29384, -1, -1, -1}, {22791, -1, -1, -1}, {24811, -1, -1, -1}, {28953, -1, -1, -1}, {34987, -1, -1, -1}, {22868, -1, -1, -1}, {33519, -1, -1, -1}, {26412, -1, -1, -1}, {31528, -1, -1, -1}, {23849, -1, -1, -1}, {32503, -1, -1, -1}, {29997, -1, -1, -1}, {27893, -1, -1, -1}, {36454, -1, -1, -1}, {36856, -1, -1, -1}, {36924, -1, -1, -1}, {12240, 40763, -1, -1}, {12112, 27604, -1, -1}, {37145, -1, -1, -1}, {31508, -1, -1, -1}, {24444, -1, -1, -1}, {30887, -1, -1, -1}, {34006, -1, -1, -1}, {34109, -1, -1, -1}, {27605, -1, -1, -1}, {27609, -1, -1, -1}, {27606, -1, -1, -1}, {24065, -1, -1, -1}, {24199, -1, -1, -1}, {30201, -1, -1, -1}, {38381, -1, -1, -1}, {25949, -1, -1, -1}, {24330, -1, -1, -1}, {24517, -1, -1, -1}, {36767, -1, -1, -1}, {22721, -1, -1, -1}, {33218, -1, -1, -1}, {36991, -1, -1, -1}, {38491, -1, -1, -1}, {38829, -1, -1, -1}, {36793, -1, -1, -1}, {32534, -1, -1, -1}, {36140, -1, -1, -1}, {25153, -1, -1, -1}, {20415, -1, -1, -1}, {21464, -1, -1, -1}, {21342, -1, -1, -1}, {36776, -1, -1, -1}, {36777, -1, -1, -1}, {36779, -1, -1, -1}, {36941, -1, -1, -1}, {26631, -1, -1, -1}, {24426, -1, -1, -1}, {33176, -1, -1, -1}, {34920, -1, -1, -1}, {40150, -1, -1, -1}, {24971, -1, -1, -1}, {21035, -1, -1, -1}, {30250, -1, -1, -1}, {24428, -1, -1, -1}, {25996, -1, -1, -1}, {28626, -1, -1, -1}, {28392, -1, -1, -1}, {23486, -1, -1, -1}, {25672, -1, -1, -1}, {20853, -1, -1, -1}, {20912, -1, -1, -1}, {26564, -1, -1, -1}, {19993, -1, -1, -1}, {31177, -1, -1, -1}, {39292, -1, -1, -1}, {28851, -1, -1, -1}, {30149, -1, -1, -1}, {24182, -1, -1, -1}, {29627, -1, -1, -1}, {33760, -1, -1, -1}, {25773, -1, -1, -1}, {25320, -1, -1, -1}, {38069, -1, -1, -1}, {27874, -1, -1, -1}, {21338, -1, -1, -1}, {21187, -1, -1, -1}, {25615, -1, -1, -1}, {38082, -1, -1, -1}, {31636, -1, -1, -1}, {20271, -1, -1, -1}, {24091, -1, -1, -1}, {33334, -1, -1, -1}, {33046, -1, -1, -1}, {33162, -1, -1, -1}, {28196, -1, -1, -1}, {27850, -1, -1, -1}, {39539, -1, -1, -1}, {25429, -1, -1, -1}, {12056, 21340, -1, -1}, {21754, -1, -1, -1}, {34917, -1, -1, -1}, {22496, -1, -1, -1}, {19981, -1, -1, -1}, {24067, -1, -1, -1}, {27493, -1, -1, -1}, {31807, -1, -1, -1}, {37096, -1, -1, -1}, {24598, -1, -1, -1}, {25830, -1, -1, -1}, {29468, -1, -1, -1}, {35009, -1, -1, -1}, {26448, -1, -1, -1}, {25165, -1, -1, -1}, {36130, -1, -1, -1}, {30572, -1, -1, -1}, {36393, -1, -1, -1}, {37319, -1, -1, -1}, {24425, -1, -1, -1}, {33756, -1, -1, -1}, {34081, -1, -1, -1}, {39184, -1, -1, -1}, {21442, -1, -1, -1}, {34453, -1, -1, -1}, {27531, -1, -1, -1}, {24813, -1, -1, -1}, {24808, -1, -1, -1}, {28799, -1, -1, -1}, {33485, -1, -1, -1}, {33329, -1, -1, -1}, {20179, -1, -1, -1}, {27815, -1, -1, -1}, {34255, -1, -1, -1}, {25805, -1, -1, -1}, {31961, -1, -1, -1}, {27133, -1, -1, -1}, {26361, -1, -1, -1}, {33609, -1, -1, -1}, {21397, -1, -1, -1}, {31574, -1, -1, -1}, {20391, -1, -1, -1}, {20876, -1, -1, -1}, {27979, -1, -1, -1}, {23618, -1, -1, -1}, {36461, -1, -1, -1}, {25554, -1, -1, -1}, {21449, -1, -1, -1}, {33580, -1, -1, -1}, {33590, -1, -1, -1}, {26597, -1, -1, -1}, {30900, -1, -1, -1}, {25661, -1, -1, -1}, {23519, -1, -1, -1}, {23700, -1, -1, -1}, {24046, -1, -1, -1}, {35815, -1, -1, -1}, {25286, -1, -1, -1}, {26612, -1, -1, -1}, {35962, -1, -1, -1}, {25600, -1, -1, -1}, {25530, -1, -1, -1}, {34633, -1, -1, -1}, {39307, -1, -1, -1}, {35863, -1, -1, -1}, {32544, -1, -1, -1}, {38130, -1, -1, -1}, {20135, -1, -1, -1}, {38416, -1, -1, -1}, {39076, -1, -1, -1}, {26124, -1, -1, -1}, {29462, -1, -1, -1}, {22330, -1, -1, -1}, {23581, -1, -1, -1}, {24120, -1, -1, -1}, {38271, -1, -1, -1}, {20607, -1, -1, -1}, {32928, -1, -1, -1}, {12058, 21378, -1, -1}, {25950, -1, -1, -1}, {30021, -1, -1, -1}, {21809, -1, -1, -1}, {20513, -1, -1, -1}, {36229, -1, -1, -1}, {25220, -1, -1, -1}, {38046, -1, -1, -1}, {26397, -1, -1, -1}, {22066, -1, -1, -1}, {28526, -1, -1, -1}, {24034, -1, -1, -1}, {21557, -1, -1, -1}, {28818, -1, -1, -1}, {36710, -1, -1, -1}, {25199, -1, -1, -1}, {25764, -1, -1, -1}, {25507, -1, -1, -1}, {24443, -1, -1, -1}, {28552, -1, -1, -1}, {37108, -1, -1, -1}, {12162, 33251, -1, -1}, {12192, 36784, -1, -1}, {23576, -1, -1, -1}, {26216, -1, -1, -1}, {24561, -1, -1, -1}, {27785, -1, -1, -1}, {38472, -1, -1, -1}, {36225, -1, -1, -1}, {34924, -1, -1, -1}, {25745, -1, -1, -1}, {31216, -1, -1, -1}, {22478, -1, -1, -1}, {27225, -1, -1, -1}, {25104, -1, -1, -1}, {21576, -1, -1, -1}, {20056, -1, -1, -1}, {31243, -1, -1, -1}, {24809, -1, -1, -1}, {28548, -1, -1, -1}, {35802, -1, -1, -1}, {25215, -1, -1, -1}, {36894, -1, -1, -1}, {39563, -1, -1, -1}, {31204, -1, -1, -1}, {21507, -1, -1, -1}, {30196, -1, -1, -1}, {25345, -1, -1, -1}, {21273, -1, -1, -1}, {27744, -1, -1, -1}, {36831, -1, -1, -1}, {24347, -1, -1, -1} },
+ {{39536, -1, -1, -1}, {32827, -1, -1, -1}, {40831, -1, -1, -1}, {20360, -1, -1, -1}, {23610, -1, -1, -1}, {12186, 36196, -1, -1}, {32709, -1, -1, -1}, {26021, -1, -1, -1}, {28861, -1, -1, -1}, {20805, -1, -1, -1}, {20914, -1, -1, -1}, {12173, 34411, -1, -1}, {23815, -1, -1, -1}, {23456, -1, -1, -1}, {25277, -1, -1, -1}, {37228, -1, -1, -1}, {30068, -1, -1, -1}, {36364, -1, -1, -1}, {31264, -1, -1, -1}, {24833, -1, -1, -1}, {31609, -1, -1, -1}, {20167, -1, -1, -1}, {32504, -1, -1, -1}, {30597, -1, -1, -1}, {19985, -1, -1, -1}, {33261, -1, -1, -1}, {21021, -1, -1, -1}, {20986, -1, -1, -1}, {27249, -1, -1, -1}, {21416, -1, -1, -1}, {36487, -1, -1, -1}, {38148, -1, -1, -1}, {38607, -1, -1, -1}, {28353, -1, -1, -1}, {38500, -1, -1, -1}, {26970, -1, -1, -1}, {30784, -1, -1, -1}, {20648, -1, -1, -1}, {30679, -1, -1, -1}, {25616, -1, -1, -1}, {35302, -1, -1, -1}, {22788, -1, -1, -1}, {25571, -1, -1, -1}, {24029, -1, -1, -1}, {31359, -1, -1, -1}, {26941, -1, -1, -1}, {20256, -1, -1, -1}, {33337, -1, -1, -1}, {21912, -1, -1, -1}, {20018, -1, -1, -1}, {30126, -1, -1, -1}, {31383, -1, -1, -1}, {24162, -1, -1, -1}, {24202, -1, -1, -1}, {38383, -1, -1, -1}, {21019, -1, -1, -1}, {21561, -1, -1, -1}, {28810, -1, -1, -1}, {25462, -1, -1, -1}, {38180, -1, -1, -1}, {22402, -1, -1, -1}, {26149, -1, -1, -1}, {26943, -1, -1, -1}, {37255, -1, -1, -1}, {21767, -1, -1, -1}, {28147, -1, -1, -1}, {32431, -1, -1, -1}, {34850, -1, -1, -1}, {25139, -1, -1, -1}, {32496, -1, -1, -1}, {30133, -1, -1, -1}, {33576, -1, -1, -1}, {30913, -1, -1, -1}, {38604, -1, -1, -1}, {36766, -1, -1, -1}, {24904, -1, -1, -1}, {29943, -1, -1, -1}, {35789, -1, -1, -1}, {27492, -1, -1, -1}, {21050, -1, -1, -1}, {36176, -1, -1, -1}, {27425, -1, -1, -1}, {32874, -1, -1, -1}, {33905, -1, -1, -1}, {22257, -1, -1, -1}, {21254, -1, -1, -1}, {20174, -1, -1, -1}, {19995, -1, -1, -1}, {20945, -1, -1, -1}, {31895, -1, -1, -1}, {37259, -1, -1, -1}, {31751, -1, -1, -1}, {20419, -1, -1, -1}, {36479, -1, -1, -1}, {31713, -1, -1, -1}, {31388, -1, -1, -1}, {25703, -1, -1, -1}, {23828, -1, -1, -1}, {20652, -1, -1, -1}, {33030, -1, -1, -1}, {30209, -1, -1, -1}, {31929, -1, -1, -1}, {28140, -1, -1, -1}, {32736, -1, -1, -1}, {26449, -1, -1, -1}, {23384, -1, -1, -1}, {12072, 23544, -1, -1}, {30923, -1, -1, -1}, {25774, -1, -1, -1}, {25619, -1, -1, -1}, {25514, -1, -1, -1}, {25387, -1, -1, -1}, {38169, -1, -1, -1}, {25645, -1, -1, -1}, {36798, -1, -1, -1}, {31572, -1, -1, -1}, {30249, -1, -1, -1}, {25171, -1, -1, -1}, {12068, 22823, -1, -1}, {21574, -1, -1, -1}, {12109, 27513, -1, -1}, {20643, -1, -1, -1}, {25140, -1, -1, -1}, {24102, -1, -1, -1}, {27526, -1, -1, -1}, {20195, -1, -1, -1}, {36151, -1, -1, -1}, {34955, -1, -1, -1}, {24453, -1, -1, -1}, {36910, -1, -1, -1}, {24608, -1, -1, -1}, {32829, -1, -1, -1}, {25285, -1, -1, -1}, {20025, -1, -1, -1}, {21333, -1, -1, -1}, {37112, -1, -1, -1}, {25528, -1, -1, -1}, {32966, -1, -1, -1}, {26086, -1, -1, -1}, {27694, -1, -1, -1}, {20294, -1, -1, -1}, {24814, -1, -1, -1}, {28129, -1, -1, -1}, {35806, -1, -1, -1}, {24377, -1, -1, -1}, {34507, -1, -1, -1}, {24403, -1, -1, -1}, {25377, -1, -1, -1}, {20826, -1, -1, -1}, {33633, -1, -1, -1}, {26723, -1, -1, -1}, {12049, 20992, -1, -1}, {25443, -1, -1, -1}, {36424, -1, -1, -1}, {20498, -1, -1, -1}, {23707, -1, -1, -1}, {31095, -1, -1, -1}, {23548, -1, -1, -1}, {21040, -1, -1, -1}, {31291, -1, -1, -1}, {24764, -1, -1, -1}, {36947, -1, -1, -1}, {30423, -1, -1, -1}, {24503, -1, -1, -1}, {24471, -1, -1, -1}, {30340, -1, -1, -1}, {36460, -1, -1, -1}, {28783, -1, -1, -1}, {30331, -1, -1, -1}, {31561, -1, -1, -1}, {30634, -1, -1, -1}, {20979, -1, -1, -1}, {37011, -1, -1, -1}, {22564, -1, -1, -1}, {20302, -1, -1, -1}, {28404, -1, -1, -1}, {36842, -1, -1, -1}, {25932, -1, -1, -1}, {31515, -1, -1, -1}, {29380, -1, -1, -1}, {28068, -1, -1, -1}, {32735, -1, -1, -1}, {23265, -1, -1, -1}, {25269, -1, -1, -1}, {24213, -1, -1, -1}, {22320, -1, -1, -1}, {33922, -1, -1, -1}, {31532, -1, -1, -1}, {24093, -1, -1, -1}, {24351, -1, -1, -1}, {36882, -1, -1, -1}, {32532, -1, -1, -1}, {39072, -1, -1, -1}, {25474, -1, -1, -1}, {28359, -1, -1, -1}, {30872, -1, -1, -1}, {28857, -1, -1, -1}, {20856, -1, -1, -1}, {38747, -1, -1, -1}, {22443, -1, -1, -1}, {30005, -1, -1, -1}, {20291, -1, -1, -1}, {30008, -1, -1, -1}, {24215, -1, -1, -1}, {24806, -1, -1, -1}, {22880, -1, -1, -1}, {28096, -1, -1, -1}, {27583, -1, -1, -1}, {30857, -1, -1, -1}, {21500, -1, -1, -1}, {38613, -1, -1, -1}, {20939, -1, -1, -1}, {20993, -1, -1, -1}, {25481, -1, -1, -1}, {21514, -1, -1, -1}, {38035, -1, -1, -1}, {35843, -1, -1, -1}, {36300, -1, -1, -1}, {29241, -1, -1, -1}, {30879, -1, -1, -1}, {34678, -1, -1, -1}, {36845, -1, -1, -1}, {35853, -1, -1, -1}, {21472, -1, -1, -1}, {19969, -1, -1, -1}, {30447, -1, -1, -1}, {21486, -1, -1, -1}, {38025, -1, -1, -1}, {39030, -1, -1, -1}, {12237, 40718, -1, -1}, {38189, -1, -1, -1}, {23450, -1, -1, -1}, {35746, -1, -1, -1}, {20002, -1, -1, -1}, {19996, -1, -1, -1}, {20908, -1, -1, -1}, {33891, -1, -1, -1}, {25026, -1, -1, -1}, {21160, -1, -1, -1}, {26635, -1, -1, -1}, {20375, -1, -1, -1}, {24683, -1, -1, -1}, {20923, -1, -1, -1}, {27934, -1, -1, -1}, {20828, -1, -1, -1}, {25238, -1, -1, -1}, {12099, 26007, -1, -1}, {38497, -1, -1, -1}, {12182, 35910, -1, -1}, {36887, -1, -1, -1}, {30168, -1, -1, -1}, {37117, -1, -1, -1}, {30563, -1, -1, -1}, {27602, -1, -1, -1}, {29322, -1, -1, -1}, {29420, -1, -1, -1} },
+ {{35835, -1, -1, -1}, {22581, -1, -1, -1}, {30585, -1, -1, -1}, {36172, -1, -1, -1}, {26460, -1, -1, -1}, {38208, -1, -1, -1}, {32922, -1, -1, -1}, {24230, -1, -1, -1}, {28193, -1, -1, -1}, {22930, -1, -1, -1}, {31471, -1, -1, -1}, {30701, -1, -1, -1}, {38203, -1, -1, -1}, {27573, -1, -1, -1}, {26029, -1, -1, -1}, {32526, -1, -1, -1}, {22534, -1, -1, -1}, {20817, -1, -1, -1}, {38431, -1, -1, -1}, {23545, -1, -1, -1}, {22697, -1, -1, -1}, {21544, -1, -1, -1}, {36466, -1, -1, -1}, {25958, -1, -1, -1}, {39039, -1, -1, -1}, {22244, -1, -1, -1}, {38045, -1, -1, -1}, {30462, -1, -1, -1}, {36929, -1, -1, -1}, {25479, -1, -1, -1}, {21702, -1, -1, -1}, {22810, -1, -1, -1}, {22842, -1, -1, -1}, {22427, -1, -1, -1}, {36530, -1, -1, -1}, {26421, -1, -1, -1}, {36346, -1, -1, -1}, {33333, -1, -1, -1}, {21057, -1, -1, -1}, {24816, -1, -1, -1}, {22549, -1, -1, -1}, {34558, -1, -1, -1}, {23784, -1, -1, -1}, {40517, -1, -1, -1}, {20420, -1, -1, -1}, {39069, -1, -1, -1}, {35769, -1, -1, -1}, {23077, -1, -1, -1}, {24694, -1, -1, -1}, {21380, -1, -1, -1}, {25212, -1, -1, -1}, {36943, -1, -1, -1}, {37122, -1, -1, -1}, {39295, -1, -1, -1}, {24681, -1, -1, -1}, {12157, 32780, -1, -1}, {12041, 20799, -1, -1}, {12159, 32819, -1, -1}, {23572, -1, -1, -1}, {39285, -1, -1, -1}, {27953, -1, -1, -1}, {12038, 20108, -1, -1}, {36144, -1, -1, -1}, {21457, -1, -1, -1}, {32602, -1, -1, -1}, {31567, -1, -1, -1}, {20240, -1, -1, -1}, {20047, -1, -1, -1}, {38400, -1, -1, -1}, {27861, -1, -1, -1}, {29648, -1, -1, -1}, {34281, -1, -1, -1}, {24070, -1, -1, -1}, {30058, -1, -1, -1}, {32763, -1, -1, -1}, {27146, -1, -1, -1}, {30718, -1, -1, -1}, {38034, -1, -1, -1}, {32321, -1, -1, -1}, {20961, -1, -1, -1}, {28902, -1, -1, -1}, {21453, -1, -1, -1}, {36820, -1, -1, -1}, {33539, -1, -1, -1}, {36137, -1, -1, -1}, {29359, -1, -1, -1}, {39277, -1, -1, -1}, {27867, -1, -1, -1}, {22346, -1, -1, -1}, {33459, -1, -1, -1}, {12101, 26041, -1, -1}, {32938, -1, -1, -1}, {25151, -1, -1, -1}, {38450, -1, -1, -1}, {22952, -1, -1, -1}, {20223, -1, -1, -1}, {35775, -1, -1, -1}, {32442, -1, -1, -1}, {25918, -1, -1, -1}, {33778, -1, -1, -1}, {12206, 38750, -1, -1}, {21857, -1, -1, -1}, {39134, -1, -1, -1}, {32933, -1, -1, -1}, {21290, -1, -1, -1}, {35837, -1, -1, -1}, {21536, -1, -1, -1}, {32954, -1, -1, -1}, {24223, -1, -1, -1}, {27832, -1, -1, -1}, {36153, -1, -1, -1}, {33452, -1, -1, -1}, {37210, -1, -1, -1}, {21545, -1, -1, -1}, {27675, -1, -1, -1}, {20998, -1, -1, -1}, {32439, -1, -1, -1}, {22367, -1, -1, -1}, {28954, -1, -1, -1}, {27774, -1, -1, -1}, {31881, -1, -1, -1}, {22859, -1, -1, -1}, {20221, -1, -1, -1}, {24575, -1, -1, -1}, {24868, -1, -1, -1}, {31914, -1, -1, -1}, {20016, -1, -1, -1}, {23553, -1, -1, -1}, {26539, -1, -1, -1}, {34562, -1, -1, -1}, {23792, -1, -1, -1}, {38155, -1, -1, -1}, {39118, -1, -1, -1}, {30127, -1, -1, -1}, {28925, -1, -1, -1}, {36898, -1, -1, -1}, {20911, -1, -1, -1}, {32541, -1, -1, -1}, {35773, -1, -1, -1}, {22857, -1, -1, -1}, {20964, -1, -1, -1}, {20315, -1, -1, -1}, {21542, -1, -1, -1}, {22827, -1, -1, -1}, {25975, -1, -1, -1}, {32932, -1, -1, -1}, {23413, -1, -1, -1}, {25206, -1, -1, -1}, {25282, -1, -1, -1}, {36752, -1, -1, -1}, {24133, -1, -1, -1}, {27679, -1, -1, -1}, {31526, -1, -1, -1}, {20239, -1, -1, -1}, {20440, -1, -1, -1}, {26381, -1, -1, -1}, {28014, -1, -1, -1}, {28074, -1, -1, -1}, {31119, -1, -1, -1}, {34993, -1, -1, -1}, {24343, -1, -1, -1}, {29995, -1, -1, -1}, {25242, -1, -1, -1}, {36741, -1, -1, -1}, {20463, -1, -1, -1}, {37340, -1, -1, -1}, {26023, -1, -1, -1}, {33071, -1, -1, -1}, {33105, -1, -1, -1}, {24220, -1, -1, -1}, {33104, -1, -1, -1}, {36212, -1, -1, -1}, {21103, -1, -1, -1}, {35206, -1, -1, -1}, {36171, -1, -1, -1}, {22797, -1, -1, -1}, {20613, -1, -1, -1}, {20184, -1, -1, -1}, {12201, 38428, -1, -1}, {12119, 29238, -1, -1}, {33145, -1, -1, -1}, {36127, -1, -1, -1}, {23500, -1, -1, -1}, {35747, -1, -1, -1}, {38468, -1, -1, -1}, {22919, -1, -1, -1}, {32538, -1, -1, -1}, {21648, -1, -1, -1}, {22134, -1, -1, -1}, {22030, -1, -1, -1}, {35813, -1, -1, -1}, {25913, -1, -1, -1}, {27010, -1, -1, -1}, {38041, -1, -1, -1}, {30422, -1, -1, -1}, {28297, -1, -1, -1}, {12082, 24178, -1, -1}, {12130, 29976, -1, -1}, {26438, -1, -1, -1}, {26577, -1, -1, -1}, {31487, -1, -1, -1}, {32925, -1, -1, -1}, {36214, -1, -1, -1}, {24863, -1, -1, -1}, {31174, -1, -1, -1}, {25954, -1, -1, -1}, {36195, -1, -1, -1}, {20872, -1, -1, -1}, {21018, -1, -1, -1}, {38050, -1, -1, -1}, {32568, -1, -1, -1}, {32923, -1, -1, -1}, {32434, -1, -1, -1}, {23703, -1, -1, -1}, {28207, -1, -1, -1}, {26464, -1, -1, -1}, {31705, -1, -1, -1}, {30347, -1, -1, -1}, {12220, 39640, -1, -1}, {33167, -1, -1, -1}, {32660, -1, -1, -1}, {31957, -1, -1, -1}, {25630, -1, -1, -1}, {38224, -1, -1, -1}, {31295, -1, -1, -1}, {21578, -1, -1, -1}, {21733, -1, -1, -1}, {27468, -1, -1, -1}, {25601, -1, -1, -1}, {12093, 25096, -1, -1}, {40509, -1, -1, -1}, {33011, -1, -1, -1}, {30105, -1, -1, -1}, {21106, -1, -1, -1}, {12208, 38761, -1, -1}, {33883, -1, -1, -1}, {26684, -1, -1, -1}, {34532, -1, -1, -1}, {38401, -1, -1, -1}, {38548, -1, -1, -1}, {38124, -1, -1, -1}, {20010, -1, -1, -1}, {21508, -1, -1, -1}, {32473, -1, -1, -1}, {26681, -1, -1, -1}, {36319, -1, -1, -1}, {32789, -1, -1, -1}, {26356, -1, -1, -1}, {24218, -1, -1, -1}, {32697, -1, -1, -1}, {22466, -1, -1, -1}, {32831, -1, -1, -1}, {26775, -1, -1, -1}, {12079, 24037, -1, -1}, {25915, -1, -1, -1}, {21151, -1, -1, -1} },
+ {{24685, -1, -1, -1}, {40858, -1, -1, -1}, {20379, -1, -1, -1}, {36524, -1, -1, -1}, {20844, -1, -1, -1}, {23467, -1, -1, -1}, {12088, 24339, -1, -1}, {24041, -1, -1, -1}, {27742, -1, -1, -1}, {25329, -1, -1, -1}, {36129, -1, -1, -1}, {20849, -1, -1, -1}, {38057, -1, -1, -1}, {21246, -1, -1, -1}, {27807, -1, -1, -1}, {33503, -1, -1, -1}, {29399, -1, -1, -1}, {22434, -1, -1, -1}, {26500, -1, -1, -1}, {36141, -1, -1, -1}, {22815, -1, -1, -1}, {36764, -1, -1, -1}, {33735, -1, -1, -1}, {21653, -1, -1, -1}, {31629, -1, -1, -1}, {20272, -1, -1, -1}, {27837, -1, -1, -1}, {23396, -1, -1, -1}, {22993, -1, -1, -1}, {12238, 40723, -1, -1}, {21476, -1, -1, -1}, {34506, -1, -1, -1}, {12219, 39592, -1, -1}, {12181, 35895, -1, -1}, {32929, -1, -1, -1}, {25925, -1, -1, -1}, {39038, -1, -1, -1}, {22266, -1, -1, -1}, {38599, -1, -1, -1}, {21038, -1, -1, -1}, {12128, 29916, -1, -1}, {21072, -1, -1, -1}, {23521, -1, -1, -1}, {25346, -1, -1, -1}, {35074, -1, -1, -1}, {20054, -1, -1, -1}, {25296, -1, -1, -1}, {24618, -1, -1, -1}, {26874, -1, -1, -1}, {20851, -1, -1, -1}, {23448, -1, -1, -1}, {20896, -1, -1, -1}, {35266, -1, -1, -1}, {31649, -1, -1, -1}, {39302, -1, -1, -1}, {32592, -1, -1, -1}, {24815, -1, -1, -1}, {28748, -1, -1, -1}, {36143, -1, -1, -1}, {20809, -1, -1, -1}, {12084, 24191, -1, -1}, {36891, -1, -1, -1}, {29808, -1, -1, -1}, {35268, -1, -1, -1}, {22317, -1, -1, -1}, {30789, -1, -1, -1}, {24402, -1, -1, -1}, {40863, -1, -1, -1}, {38394, -1, -1, -1}, {36712, -1, -1, -1}, {12225, 39740, -1, -1}, {35809, -1, -1, -1}, {30328, -1, -1, -1}, {26690, -1, -1, -1}, {26588, -1, -1, -1}, {36330, -1, -1, -1}, {36149, -1, -1, -1}, {21053, -1, -1, -1}, {36746, -1, -1, -1}, {28378, -1, -1, -1}, {26829, -1, -1, -1}, {38149, -1, -1, -1}, {37101, -1, -1, -1}, {22269, -1, -1, -1}, {26524, -1, -1, -1}, {35065, -1, -1, -1}, {36807, -1, -1, -1}, {21704, -1, -1, -1}, {39608, -1, -1, -1}, {23401, -1, -1, -1}, {28023, -1, -1, -1}, {27686, -1, -1, -1}, {20133, -1, -1, -1}, {23475, -1, -1, -1}, {39559, -1, -1, -1}, {37219, -1, -1, -1}, {25000, -1, -1, -1}, {37039, -1, -1, -1}, {38889, -1, -1, -1}, {21547, -1, -1, -1}, {28085, -1, -1, -1}, {23506, -1, -1, -1}, {20989, -1, -1, -1}, {21898, -1, -1, -1}, {32597, -1, -1, -1}, {32752, -1, -1, -1}, {25788, -1, -1, -1}, {25421, -1, -1, -1}, {26097, -1, -1, -1}, {25022, -1, -1, -1}, {24717, -1, -1, -1}, {28938, -1, -1, -1}, {27735, -1, -1, -1}, {27721, -1, -1, -1}, {22831, -1, -1, -1}, {26477, -1, -1, -1}, {33322, -1, -1, -1}, {22741, -1, -1, -1}, {22158, -1, -1, -1}, {35946, -1, -1, -1}, {27627, -1, -1, -1}, {37085, -1, -1, -1}, {22909, -1, -1, -1}, {32791, -1, -1, -1}, {21495, -1, -1, -1}, {28009, -1, -1, -1}, {21621, -1, -1, -1}, {21917, -1, -1, -1}, {33655, -1, -1, -1}, {33743, -1, -1, -1}, {26680, -1, -1, -1}, {12146, 31166, -1, -1}, {21644, -1, -1, -1}, {20309, -1, -1, -1}, {21512, -1, -1, -1}, {30418, -1, -1, -1}, {35977, -1, -1, -1}, {38402, -1, -1, -1}, {27827, -1, -1, -1}, {28088, -1, -1, -1}, {36203, -1, -1, -1}, {35088, -1, -1, -1}, {40548, -1, -1, -1}, {36154, -1, -1, -1}, {22079, -1, -1, -1}, {12234, 40657, -1, -1}, {30165, -1, -1, -1}, {24456, -1, -1, -1}, {29408, -1, -1, -1}, {24680, -1, -1, -1}, {21756, -1, -1, -1}, {20136, -1, -1, -1}, {27178, -1, -1, -1}, {34913, -1, -1, -1}, {24658, -1, -1, -1}, {36720, -1, -1, -1}, {21700, -1, -1, -1}, {28888, -1, -1, -1}, {34425, -1, -1, -1}, {40511, -1, -1, -1}, {27946, -1, -1, -1}, {23439, -1, -1, -1}, {24344, -1, -1, -1}, {32418, -1, -1, -1}, {21897, -1, -1, -1}, {20399, -1, -1, -1}, {29492, -1, -1, -1}, {21564, -1, -1, -1}, {21402, -1, -1, -1}, {20505, -1, -1, -1}, {21518, -1, -1, -1}, {21628, -1, -1, -1}, {20046, -1, -1, -1}, {24573, -1, -1, -1}, {29786, -1, -1, -1}, {22774, -1, -1, -1}, {33899, -1, -1, -1}, {32993, -1, -1, -1}, {34676, -1, -1, -1}, {29392, -1, -1, -1}, {31946, -1, -1, -1}, {28246, -1, -1, -1}, {24359, -1, -1, -1}, {34382, -1, -1, -1}, {21804, -1, -1, -1}, {25252, -1, -1, -1}, {20114, -1, -1, -1}, {27818, -1, -1, -1}, {25143, -1, -1, -1}, {33457, -1, -1, -1}, {21719, -1, -1, -1}, {21326, -1, -1, -1}, {29502, -1, -1, -1}, {28369, -1, -1, -1}, {30011, -1, -1, -1}, {21010, -1, -1, -1}, {21270, -1, -1, -1}, {35805, -1, -1, -1}, {27088, -1, -1, -1}, {24458, -1, -1, -1}, {24576, -1, -1, -1}, {28142, -1, -1, -1}, {22351, -1, -1, -1}, {27426, -1, -1, -1}, {29615, -1, -1, -1}, {26707, -1, -1, -1}, {36824, -1, -1, -1}, {32531, -1, -1, -1}, {25442, -1, -1, -1}, {24739, -1, -1, -1}, {21796, -1, -1, -1}, {30186, -1, -1, -1}, {35938, -1, -1, -1}, {28949, -1, -1, -1}, {28067, -1, -1, -1}, {23462, -1, -1, -1}, {24187, -1, -1, -1}, {33618, -1, -1, -1}, {24908, -1, -1, -1}, {40644, -1, -1, -1}, {30970, -1, -1, -1}, {34647, -1, -1, -1}, {31783, -1, -1, -1}, {30343, -1, -1, -1}, {20976, -1, -1, -1}, {24822, -1, -1, -1}, {29004, -1, -1, -1}, {26179, -1, -1, -1}, {24140, -1, -1, -1}, {24653, -1, -1, -1}, {35854, -1, -1, -1}, {28784, -1, -1, -1}, {25381, -1, -1, -1}, {36745, -1, -1, -1}, {24509, -1, -1, -1}, {24674, -1, -1, -1}, {34516, -1, -1, -1}, {22238, -1, -1, -1}, {27585, -1, -1, -1}, {24724, -1, -1, -1}, {24935, -1, -1, -1}, {21321, -1, -1, -1}, {24800, -1, -1, -1}, {26214, -1, -1, -1}, {36159, -1, -1, -1}, {31229, -1, -1, -1}, {20250, -1, -1, -1}, {28905, -1, -1, -1}, {27719, -1, -1, -1}, {35763, -1, -1, -1}, {35826, -1, -1, -1}, {32472, -1, -1, -1}, {33636, -1, -1, -1}, {26127, -1, -1, -1}, {23130, -1, -1, -1}, {39746, -1, -1, -1} },
+ {{27985, -1, -1, -1}, {28151, -1, -1, -1}, {35905, -1, -1, -1}, {27963, -1, -1, -1}, {20249, -1, -1, -1}, {12117, 28779, -1, -1}, {33719, -1, -1, -1}, {25110, -1, -1, -1}, {24785, -1, -1, -1}, {38669, -1, -1, -1}, {36135, -1, -1, -1}, {31096, -1, -1, -1}, {20987, -1, -1, -1}, {22334, -1, -1, -1}, {22522, -1, -1, -1}, {26426, -1, -1, -1}, {30072, -1, -1, -1}, {31293, -1, -1, -1}, {31215, -1, -1, -1}, {31637, -1, -1, -1}, {32908, -1, -1, -1}, {39269, -1, -1, -1}, {36857, -1, -1, -1}, {28608, -1, -1, -1}, {35749, -1, -1, -1}, {40481, -1, -1, -1}, {23020, -1, -1, -1}, {32489, -1, -1, -1}, {32521, -1, -1, -1}, {21513, -1, -1, -1}, {26497, -1, -1, -1}, {26840, -1, -1, -1}, {36753, -1, -1, -1}, {31821, -1, -1, -1}, {38598, -1, -1, -1}, {21450, -1, -1, -1}, {24613, -1, -1, -1}, {30142, -1, -1, -1}, {27762, -1, -1, -1}, {21363, -1, -1, -1}, {23241, -1, -1, -1}, {32423, -1, -1, -1}, {25380, -1, -1, -1}, {12047, 20960, -1, -1}, {33034, -1, -1, -1}, {12080, 24049, -1, -1}, {34015, -1, -1, -1}, {25216, -1, -1, -1}, {20864, -1, -1, -1}, {23395, -1, -1, -1}, {20238, -1, -1, -1}, {31085, -1, -1, -1}, {21058, -1, -1, -1}, {24760, -1, -1, -1}, {27982, -1, -1, -1}, {23492, -1, -1, -1}, {23490, -1, -1, -1}, {35745, -1, -1, -1}, {35760, -1, -1, -1}, {26082, -1, -1, -1}, {24524, -1, -1, -1}, {38469, -1, -1, -1}, {22931, -1, -1, -1}, {32487, -1, -1, -1}, {32426, -1, -1, -1}, {22025, -1, -1, -1}, {26551, -1, -1, -1}, {22841, -1, -1, -1}, {20339, -1, -1, -1}, {23478, -1, -1, -1}, {21152, -1, -1, -1}, {33626, -1, -1, -1}, {39050, -1, -1, -1}, {36158, -1, -1, -1}, {30002, -1, -1, -1}, {38078, -1, -1, -1}, {20551, -1, -1, -1}, {31292, -1, -1, -1}, {20215, -1, -1, -1}, {26550, -1, -1, -1}, {39550, -1, -1, -1}, {23233, -1, -1, -1}, {27516, -1, -1, -1}, {30417, -1, -1, -1}, {22362, -1, -1, -1}, {23574, -1, -1, -1}, {31546, -1, -1, -1}, {38388, -1, -1, -1}, {29006, -1, -1, -1}, {20860, -1, -1, -1}, {32937, -1, -1, -1}, {33392, -1, -1, -1}, {22904, -1, -1, -1}, {32516, -1, -1, -1}, {33575, -1, -1, -1}, {26816, -1, -1, -1}, {26604, -1, -1, -1}, {30897, -1, -1, -1}, {30839, -1, -1, -1}, {25315, -1, -1, -1}, {25441, -1, -1, -1}, {31616, -1, -1, -1}, {20461, -1, -1, -1}, {21098, -1, -1, -1}, {20943, -1, -1, -1}, {33616, -1, -1, -1}, {27099, -1, -1, -1}, {37492, -1, -1, -1}, {36341, -1, -1, -1}, {36145, -1, -1, -1}, {35265, -1, -1, -1}, {38190, -1, -1, -1}, {31661, -1, -1, -1}, {20214, -1, -1, -1}, {20581, -1, -1, -1}, {33328, -1, -1, -1}, {21073, -1, -1, -1}, {39279, -1, -1, -1}, {28176, -1, -1, -1}, {28293, -1, -1, -1}, {28071, -1, -1, -1}, {24314, -1, -1, -1}, {20725, -1, -1, -1}, {23004, -1, -1, -1}, {23558, -1, -1, -1}, {27974, -1, -1, -1}, {27743, -1, -1, -1}, {30086, -1, -1, -1}, {33931, -1, -1, -1}, {26728, -1, -1, -1}, {22870, -1, -1, -1}, {35762, -1, -1, -1}, {21280, -1, -1, -1}, {37233, -1, -1, -1}, {38477, -1, -1, -1}, {34121, -1, -1, -1}, {26898, -1, -1, -1}, {30977, -1, -1, -1}, {28966, -1, -1, -1}, {33014, -1, -1, -1}, {20132, -1, -1, -1}, {37066, -1, -1, -1}, {27975, -1, -1, -1}, {39556, -1, -1, -1}, {23047, -1, -1, -1}, {22204, -1, -1, -1}, {25605, -1, -1, -1}, {38128, -1, -1, -1}, {30699, -1, -1, -1}, {20389, -1, -1, -1}, {33050, -1, -1, -1}, {29409, -1, -1, -1}, {12179, 35282, -1, -1}, {39290, -1, -1, -1}, {32564, -1, -1, -1}, {32478, -1, -1, -1}, {21119, -1, -1, -1}, {25945, -1, -1, -1}, {37237, -1, -1, -1}, {36735, -1, -1, -1}, {36739, -1, -1, -1}, {21483, -1, -1, -1}, {31382, -1, -1, -1}, {25581, -1, -1, -1}, {25509, -1, -1, -1}, {30342, -1, -1, -1}, {31224, -1, -1, -1}, {34903, -1, -1, -1}, {38454, -1, -1, -1}, {25130, -1, -1, -1}, {21163, -1, -1, -1}, {33410, -1, -1, -1}, {26708, -1, -1, -1}, {26480, -1, -1, -1}, {25463, -1, -1, -1}, {30571, -1, -1, -1}, {31469, -1, -1, -1}, {27905, -1, -1, -1}, {32467, -1, -1, -1}, {35299, -1, -1, -1}, {22992, -1, -1, -1}, {25106, -1, -1, -1}, {34249, -1, -1, -1}, {33445, -1, -1, -1}, {30028, -1, -1, -1}, {20511, -1, -1, -1}, {20171, -1, -1, -1}, {30117, -1, -1, -1}, {35819, -1, -1, -1}, {23626, -1, -1, -1}, {12081, 24062, -1, -1}, {31563, -1, -1, -1}, {12100, 26020, -1, -1}, {12198, 37329, -1, -1}, {20170, -1, -1, -1}, {27941, -1, -1, -1}, {35167, -1, -1, -1}, {32039, -1, -1, -1}, {38182, -1, -1, -1}, {20165, -1, -1, -1}, {35880, -1, -1, -1}, {36827, -1, -1, -1}, {38771, -1, -1, -1}, {26187, -1, -1, -1}, {31105, -1, -1, -1}, {36817, -1, -1, -1}, {28908, -1, -1, -1}, {28024, -1, -1, -1}, {23613, -1, -1, -1}, {21170, -1, -1, -1}, {33606, -1, -1, -1}, {20834, -1, -1, -1}, {33550, -1, -1, -1}, {30555, -1, -1, -1}, {26230, -1, -1, -1}, {40120, -1, -1, -1}, {20140, -1, -1, -1}, {24778, -1, -1, -1}, {31934, -1, -1, -1}, {31923, -1, -1, -1}, {32463, -1, -1, -1}, {20117, -1, -1, -1}, {35686, -1, -1, -1}, {26223, -1, -1, -1}, {39048, -1, -1, -1}, {38745, -1, -1, -1}, {22659, -1, -1, -1}, {25964, -1, -1, -1}, {38236, -1, -1, -1}, {24452, -1, -1, -1}, {30153, -1, -1, -1}, {38742, -1, -1, -1}, {31455, -1, -1, -1}, {31454, -1, -1, -1}, {20928, -1, -1, -1}, {28847, -1, -1, -1}, {31384, -1, -1, -1}, {25578, -1, -1, -1}, {31350, -1, -1, -1}, {32416, -1, -1, -1}, {29590, -1, -1, -1}, {12210, 38893, -1, -1}, {20037, -1, -1, -1}, {28792, -1, -1, -1}, {20061, -1, -1, -1}, {37202, -1, -1, -1}, {21417, -1, -1, -1}, {25937, -1, -1, -1}, {26087, -1, -1, -1}, {12165, 33276, -1, -1}, {33285, -1, -1, -1}, {21646, -1, -1, -1}, {23601, -1, -1, -1}, {30106, -1, -1, -1}, {38816, -1, -1, -1}, {25304, -1, -1, -1} },
+ {{29401, -1, -1, -1}, {30141, -1, -1, -1}, {23621, -1, -1, -1}, {39545, -1, -1, -1}, {33738, -1, -1, -1}, {23616, -1, -1, -1}, {21632, -1, -1, -1}, {30697, -1, -1, -1}, {20030, -1, -1, -1}, {27822, -1, -1, -1}, {32858, -1, -1, -1}, {25298, -1, -1, -1}, {25454, -1, -1, -1}, {24040, -1, -1, -1}, {20855, -1, -1, -1}, {36317, -1, -1, -1}, {36382, -1, -1, -1}, {38191, -1, -1, -1}, {20465, -1, -1, -1}, {21477, -1, -1, -1}, {24807, -1, -1, -1}, {28844, -1, -1, -1}, {21095, -1, -1, -1}, {25424, -1, -1, -1}, {40515, -1, -1, -1}, {23071, -1, -1, -1}, {20518, -1, -1, -1}, {30519, -1, -1, -1}, {21367, -1, -1, -1}, {32482, -1, -1, -1}, {25733, -1, -1, -1}, {25899, -1, -1, -1}, {25225, -1, -1, -1}, {25496, -1, -1, -1}, {20500, -1, -1, -1}, {29237, -1, -1, -1}, {35273, -1, -1, -1}, {20915, -1, -1, -1}, {35776, -1, -1, -1}, {32477, -1, -1, -1}, {22343, -1, -1, -1}, {33740, -1, -1, -1}, {38055, -1, -1, -1}, {20891, -1, -1, -1}, {21531, -1, -1, -1}, {23803, -1, -1, -1}, {20426, -1, -1, -1}, {31459, -1, -1, -1}, {27994, -1, -1, -1}, {37089, -1, -1, -1}, {39567, -1, -1, -1}, {21888, -1, -1, -1}, {21654, -1, -1, -1}, {21345, -1, -1, -1}, {21679, -1, -1, -1}, {24320, -1, -1, -1}, {25577, -1, -1, -1}, {26999, -1, -1, -1}, {20975, -1, -1, -1}, {24936, -1, -1, -1}, {21002, -1, -1, -1}, {22570, -1, -1, -1}, {21208, -1, -1, -1}, {22350, -1, -1, -1}, {30733, -1, -1, -1}, {30475, -1, -1, -1}, {24247, -1, -1, -1}, {24951, -1, -1, -1}, {31968, -1, -1, -1}, {25179, -1, -1, -1}, {25239, -1, -1, -1}, {20130, -1, -1, -1}, {28821, -1, -1, -1}, {32771, -1, -1, -1}, {25335, -1, -1, -1}, {28900, -1, -1, -1}, {38752, -1, -1, -1}, {22391, -1, -1, -1}, {33499, -1, -1, -1}, {26607, -1, -1, -1}, {26869, -1, -1, -1}, {30933, -1, -1, -1}, {39063, -1, -1, -1}, {31185, -1, -1, -1}, {22771, -1, -1, -1}, {21683, -1, -1, -1}, {21487, -1, -1, -1}, {28212, -1, -1, -1}, {20811, -1, -1, -1}, {21051, -1, -1, -1}, {23458, -1, -1, -1}, {35838, -1, -1, -1}, {32943, -1, -1, -1}, {21827, -1, -1, -1}, {22438, -1, -1, -1}, {24691, -1, -1, -1}, {22353, -1, -1, -1}, {21549, -1, -1, -1}, {31354, -1, -1, -1}, {24656, -1, -1, -1}, {23380, -1, -1, -1}, {25511, -1, -1, -1}, {25248, -1, -1, -1}, {12061, 21475, -1, -1}, {25187, -1, -1, -1}, {23495, -1, -1, -1}, {26543, -1, -1, -1}, {21741, -1, -1, -1}, {31391, -1, -1, -1}, {33510, -1, -1, -1}, {37239, -1, -1, -1}, {24211, -1, -1, -1}, {35044, -1, -1, -1}, {22840, -1, -1, -1}, {22446, -1, -1, -1}, {25358, -1, -1, -1}, {36328, -1, -1, -1}, {33007, -1, -1, -1}, {22359, -1, -1, -1}, {31607, -1, -1, -1}, {20393, -1, -1, -1}, {24555, -1, -1, -1}, {23485, -1, -1, -1}, {27454, -1, -1, -1}, {21281, -1, -1, -1}, {31568, -1, -1, -1}, {29378, -1, -1, -1}, {26694, -1, -1, -1}, {30719, -1, -1, -1}, {30518, -1, -1, -1}, {26103, -1, -1, -1}, {20917, -1, -1, -1}, {20111, -1, -1, -1}, {30420, -1, -1, -1}, {23743, -1, -1, -1}, {31397, -1, -1, -1}, {33909, -1, -1, -1}, {22862, -1, -1, -1}, {39745, -1, -1, -1}, {20608, -1, -1, -1}, {39304, -1, -1, -1}, {24871, -1, -1, -1}, {28291, -1, -1, -1}, {22372, -1, -1, -1}, {26118, -1, -1, -1}, {25414, -1, -1, -1}, {22256, -1, -1, -1}, {25324, -1, -1, -1}, {25193, -1, -1, -1}, {24275, -1, -1, -1}, {38420, -1, -1, -1}, {22403, -1, -1, -1}, {25289, -1, -1, -1}, {21895, -1, -1, -1}, {34593, -1, -1, -1}, {33098, -1, -1, -1}, {36771, -1, -1, -1}, {21862, -1, -1, -1}, {33713, -1, -1, -1}, {26469, -1, -1, -1}, {36182, -1, -1, -1}, {34013, -1, -1, -1}, {23146, -1, -1, -1}, {26639, -1, -1, -1}, {25318, -1, -1, -1}, {31726, -1, -1, -1}, {38417, -1, -1, -1}, {20848, -1, -1, -1}, {28572, -1, -1, -1}, {35888, -1, -1, -1}, {25597, -1, -1, -1}, {35272, -1, -1, -1}, {25042, -1, -1, -1}, {32518, -1, -1, -1}, {28866, -1, -1, -1}, {28389, -1, -1, -1}, {29701, -1, -1, -1}, {27028, -1, -1, -1}, {29436, -1, -1, -1}, {24266, -1, -1, -1}, {37070, -1, -1, -1}, {26391, -1, -1, -1}, {28010, -1, -1, -1}, {25438, -1, -1, -1}, {21171, -1, -1, -1}, {29282, -1, -1, -1}, {12156, 32769, -1, -1}, {20332, -1, -1, -1}, {23013, -1, -1, -1}, {37226, -1, -1, -1}, {28889, -1, -1, -1}, {28061, -1, -1, -1}, {21202, -1, -1, -1}, {20048, -1, -1, -1}, {38647, -1, -1, -1}, {38253, -1, -1, -1}, {34174, -1, -1, -1}, {30922, -1, -1, -1}, {32047, -1, -1, -1}, {20769, -1, -1, -1}, {22418, -1, -1, -1}, {25794, -1, -1, -1}, {32907, -1, -1, -1}, {31867, -1, -1, -1}, {27882, -1, -1, -1}, {26865, -1, -1, -1}, {26974, -1, -1, -1}, {20919, -1, -1, -1}, {21400, -1, -1, -1}, {26792, -1, -1, -1}, {29313, -1, -1, -1}, {40654, -1, -1, -1}, {31729, -1, -1, -1}, {29432, -1, -1, -1}, {31163, -1, -1, -1}, {28435, -1, -1, -1}, {29702, -1, -1, -1}, {26446, -1, -1, -1}, {12197, 37324, -1, -1}, {40100, -1, -1, -1}, {31036, -1, -1, -1}, {33673, -1, -1, -1}, {33620, -1, -1, -1}, {21519, -1, -1, -1}, {26647, -1, -1, -1}, {20029, -1, -1, -1}, {21385, -1, -1, -1}, {21169, -1, -1, -1}, {30782, -1, -1, -1}, {21382, -1, -1, -1}, {21033, -1, -1, -1}, {20616, -1, -1, -1}, {20363, -1, -1, -1}, {20432, -1, -1, -1}, {30178, -1, -1, -1}, {12148, 31435, -1, -1}, {31890, -1, -1, -1}, {27813, -1, -1, -1}, {12202, 38582, -1, -1}, {12050, 21147, -1, -1}, {29827, -1, -1, -1}, {21737, -1, -1, -1}, {20457, -1, -1, -1}, {32852, -1, -1, -1}, {33714, -1, -1, -1}, {36830, -1, -1, -1}, {38256, -1, -1, -1}, {24265, -1, -1, -1}, {24604, -1, -1, -1}, {28063, -1, -1, -1}, {24088, -1, -1, -1}, {25947, -1, -1, -1}, {33080, -1, -1, -1}, {38142, -1, -1, -1}, {24651, -1, -1, -1}, {28860, -1, -1, -1} },
+ {{32451, -1, -1, -1}, {31918, -1, -1, -1}, {20937, -1, -1, -1}, {26753, -1, -1, -1}, {31921, -1, -1, -1}, {33391, -1, -1, -1}, {20004, -1, -1, -1}, {36742, -1, -1, -1}, {37327, -1, -1, -1}, {26238, -1, -1, -1}, {20142, -1, -1, -1}, {35845, -1, -1, -1}, {25769, -1, -1, -1}, {32842, -1, -1, -1}, {20698, -1, -1, -1}, {30103, -1, -1, -1}, {29134, -1, -1, -1}, {23525, -1, -1, -1}, {36797, -1, -1, -1}, {28518, -1, -1, -1}, {20102, -1, -1, -1}, {25730, -1, -1, -1}, {38243, -1, -1, -1}, {24278, -1, -1, -1}, {26009, -1, -1, -1}, {21015, -1, -1, -1}, {35010, -1, -1, -1}, {28872, -1, -1, -1}, {21155, -1, -1, -1}, {29454, -1, -1, -1}, {29747, -1, -1, -1}, {26519, -1, -1, -1}, {30967, -1, -1, -1}, {38678, -1, -1, -1}, {20020, -1, -1, -1}, {37051, -1, -1, -1}, {40158, -1, -1, -1}, {28107, -1, -1, -1}, {20955, -1, -1, -1}, {36161, -1, -1, -1}, {21533, -1, -1, -1}, {25294, -1, -1, -1}, {29618, -1, -1, -1}, {33777, -1, -1, -1}, {38646, -1, -1, -1}, {40836, -1, -1, -1}, {38083, -1, -1, -1}, {20278, -1, -1, -1}, {32666, -1, -1, -1}, {20940, -1, -1, -1}, {28789, -1, -1, -1}, {38517, -1, -1, -1}, {23725, -1, -1, -1}, {39046, -1, -1, -1}, {21478, -1, -1, -1}, {20196, -1, -1, -1}, {28316, -1, -1, -1}, {29705, -1, -1, -1}, {27060, -1, -1, -1}, {30827, -1, -1, -1}, {39311, -1, -1, -1}, {30041, -1, -1, -1}, {21016, -1, -1, -1}, {30244, -1, -1, -1}, {27969, -1, -1, -1}, {26611, -1, -1, -1}, {20845, -1, -1, -1}, {40857, -1, -1, -1}, {32843, -1, -1, -1}, {21657, -1, -1, -1}, {31548, -1, -1, -1}, {31423, -1, -1, -1}, {38534, -1, -1, -1}, {22404, -1, -1, -1}, {25314, -1, -1, -1}, {38471, -1, -1, -1}, {27004, -1, -1, -1}, {23044, -1, -1, -1}, {25602, -1, -1, -1}, {31699, -1, -1, -1}, {28431, -1, -1, -1}, {38475, -1, -1, -1}, {33446, -1, -1, -1}, {21346, -1, -1, -1}, {39045, -1, -1, -1}, {24208, -1, -1, -1}, {28809, -1, -1, -1}, {25523, -1, -1, -1}, {21348, -1, -1, -1}, {34383, -1, -1, -1}, {40065, -1, -1, -1}, {40595, -1, -1, -1}, {30860, -1, -1, -1}, {38706, -1, -1, -1}, {36335, -1, -1, -1}, {36162, -1, -1, -1}, {12229, 40575, -1, -1}, {28510, -1, -1, -1}, {31108, -1, -1, -1}, {24405, -1, -1, -1}, {38470, -1, -1, -1}, {25134, -1, -1, -1}, {39540, -1, -1, -1}, {21525, -1, -1, -1}, {38109, -1, -1, -1}, {20387, -1, -1, -1}, {26053, -1, -1, -1}, {23653, -1, -1, -1}, {23649, -1, -1, -1}, {32533, -1, -1, -1}, {34385, -1, -1, -1}, {27695, -1, -1, -1}, {24459, -1, -1, -1}, {29575, -1, -1, -1}, {28388, -1, -1, -1}, {32511, -1, -1, -1}, {23782, -1, -1, -1}, {25371, -1, -1, -1}, {23402, -1, -1, -1}, {28390, -1, -1, -1}, {21365, -1, -1, -1}, {20081, -1, -1, -1}, {25504, -1, -1, -1}, {30053, -1, -1, -1}, {25249, -1, -1, -1}, {36718, -1, -1, -1}, {20262, -1, -1, -1}, {20177, -1, -1, -1}, {27814, -1, -1, -1}, {32438, -1, -1, -1}, {35770, -1, -1, -1}, {33821, -1, -1, -1}, {34746, -1, -1, -1}, {32599, -1, -1, -1}, {36923, -1, -1, -1}, {38179, -1, -1, -1}, {31657, -1, -1, -1}, {39585, -1, -1, -1}, {35064, -1, -1, -1}, {33853, -1, -1, -1}, {27931, -1, -1, -1}, {39558, -1, -1, -1}, {32476, -1, -1, -1}, {22920, -1, -1, -1}, {12231, 40635, -1, -1}, {29595, -1, -1, -1}, {30721, -1, -1, -1}, {34434, -1, -1, -1}, {39532, -1, -1, -1}, {39554, -1, -1, -1}, {22043, -1, -1, -1}, {21527, -1, -1, -1}, {22475, -1, -1, -1}, {20080, -1, -1, -1}, {40614, -1, -1, -1}, {21334, -1, -1, -1}, {36808, -1, -1, -1}, {33033, -1, -1, -1}, {30610, -1, -1, -1}, {39314, -1, -1, -1}, {34542, -1, -1, -1}, {28385, -1, -1, -1}, {34067, -1, -1, -1}, {26364, -1, -1, -1}, {24930, -1, -1, -1}, {28459, -1, -1, -1}, {35881, -1, -1, -1}, {33426, -1, -1, -1}, {33579, -1, -1, -1}, {30450, -1, -1, -1}, {27667, -1, -1, -1}, {24537, -1, -1, -1}, {33725, -1, -1, -1}, {29483, -1, -1, -1}, {33541, -1, -1, -1}, {38170, -1, -1, -1}, {12113, 27611, -1, -1}, {12141, 30683, -1, -1}, {38086, -1, -1, -1}, {21359, -1, -1, -1}, {33538, -1, -1, -1}, {20882, -1, -1, -1}, {24125, -1, -1, -1}, {35980, -1, -1, -1}, {36152, -1, -1, -1}, {20040, -1, -1, -1}, {29611, -1, -1, -1}, {26522, -1, -1, -1}, {26757, -1, -1, -1}, {37238, -1, -1, -1}, {38665, -1, -1, -1}, {29028, -1, -1, -1}, {27809, -1, -1, -1}, {30473, -1, -1, -1}, {23186, -1, -1, -1}, {38209, -1, -1, -1}, {27599, -1, -1, -1}, {32654, -1, -1, -1}, {26151, -1, -1, -1}, {23504, -1, -1, -1}, {22969, -1, -1, -1}, {23194, -1, -1, -1}, {38376, -1, -1, -1}, {38391, -1, -1, -1}, {20204, -1, -1, -1}, {33804, -1, -1, -1}, {33945, -1, -1, -1}, {27308, -1, -1, -1}, {30431, -1, -1, -1}, {38192, -1, -1, -1}, {29467, -1, -1, -1}, {26790, -1, -1, -1}, {23391, -1, -1, -1}, {30511, -1, -1, -1}, {37274, -1, -1, -1}, {38753, -1, -1, -1}, {31964, -1, -1, -1}, {36855, -1, -1, -1}, {35868, -1, -1, -1}, {24357, -1, -1, -1}, {12150, 31859, -1, -1}, {31192, -1, -1, -1}, {35269, -1, -1, -1}, {27852, -1, -1, -1}, {34588, -1, -1, -1}, {23494, -1, -1, -1}, {24130, -1, -1, -1}, {26825, -1, -1, -1}, {30496, -1, -1, -1}, {32501, -1, -1, -1}, {20885, -1, -1, -1}, {20813, -1, -1, -1}, {21193, -1, -1, -1}, {23081, -1, -1, -1}, {32517, -1, -1, -1}, {12207, 38754, -1, -1}, {33495, -1, -1, -1}, {25551, -1, -1, -1}, {30596, -1, -1, -1}, {34256, -1, -1, -1}, {31186, -1, -1, -1}, {28218, -1, -1, -1}, {24217, -1, -1, -1}, {22937, -1, -1, -1}, {34065, -1, -1, -1}, {28781, -1, -1, -1}, {27665, -1, -1, -1}, {25279, -1, -1, -1}, {12139, 30399, -1, -1}, {25935, -1, -1, -1}, {24751, -1, -1, -1}, {38397, -1, -1, -1}, {26126, -1, -1, -1}, {34719, -1, -1, -1}, {40483, -1, -1, -1}, {38125, -1, -1, -1} },
+ {{21517, -1, -1, -1}, {21629, -1, -1, -1}, {35884, -1, -1, -1}, {25720, -1, -1, -1}, {25721, -1, -1, -1}, {34321, -1, -1, -1}, {27169, -1, -1, -1}, {33180, -1, -1, -1}, {30952, -1, -1, -1}, {25705, -1, -1, -1}, {39764, -1, -1, -1}, {25273, -1, -1, -1}, {26411, -1, -1, -1}, {33707, -1, -1, -1}, {22696, -1, -1, -1}, {40664, -1, -1, -1}, {27819, -1, -1, -1}, {28448, -1, -1, -1}, {23518, -1, -1, -1}, {38476, -1, -1, -1}, {35851, -1, -1, -1}, {29279, -1, -1, -1}, {26576, -1, -1, -1}, {25287, -1, -1, -1}, {29281, -1, -1, -1}, {20137, -1, -1, -1}, {22982, -1, -1, -1}, {27597, -1, -1, -1}, {22675, -1, -1, -1}, {26286, -1, -1, -1}, {24149, -1, -1, -1}, {21215, -1, -1, -1}, {24917, -1, -1, -1}, {12106, 26408, -1, -1}, {12140, 30446, -1, -1}, {30566, -1, -1, -1}, {29287, -1, -1, -1}, {31302, -1, -1, -1}, {25343, -1, -1, -1}, {21738, -1, -1, -1}, {21584, -1, -1, -1}, {38048, -1, -1, -1}, {37027, -1, -1, -1}, {23068, -1, -1, -1}, {32435, -1, -1, -1}, {27670, -1, -1, -1}, {20035, -1, -1, -1}, {22902, -1, -1, -1}, {32784, -1, -1, -1}, {22856, -1, -1, -1}, {21335, -1, -1, -1}, {30007, -1, -1, -1}, {38590, -1, -1, -1}, {22218, -1, -1, -1}, {25376, -1, -1, -1}, {33041, -1, -1, -1}, {24700, -1, -1, -1}, {38393, -1, -1, -1}, {28118, -1, -1, -1}, {21602, -1, -1, -1}, {39297, -1, -1, -1}, {20869, -1, -1, -1}, {23273, -1, -1, -1}, {33021, -1, -1, -1}, {22958, -1, -1, -1}, {38675, -1, -1, -1}, {20522, -1, -1, -1}, {27877, -1, -1, -1}, {23612, -1, -1, -1}, {25311, -1, -1, -1}, {20320, -1, -1, -1}, {21311, -1, -1, -1}, {33147, -1, -1, -1}, {36870, -1, -1, -1}, {28346, -1, -1, -1}, {34091, -1, -1, -1}, {25288, -1, -1, -1}, {24180, -1, -1, -1}, {30910, -1, -1, -1}, {25781, -1, -1, -1}, {25467, -1, -1, -1}, {24565, -1, -1, -1}, {23064, -1, -1, -1}, {37247, -1, -1, -1}, {40479, -1, -1, -1}, {23615, -1, -1, -1}, {25423, -1, -1, -1}, {32834, -1, -1, -1}, {23421, -1, -1, -1}, {21870, -1, -1, -1}, {38218, -1, -1, -1}, {38221, -1, -1, -1}, {28037, -1, -1, -1}, {24744, -1, -1, -1}, {26592, -1, -1, -1}, {29406, -1, -1, -1}, {20957, -1, -1, -1}, {23425, -1, -1, -1}, {25319, -1, -1, -1}, {27870, -1, -1, -1}, {12124, 29275, -1, -1}, {25197, -1, -1, -1}, {38062, -1, -1, -1}, {32445, -1, -1, -1}, {33043, -1, -1, -1}, {27987, -1, -1, -1}, {20892, -1, -1, -1}, {24324, -1, -1, -1}, {22900, -1, -1, -1}, {21162, -1, -1, -1}, {24594, -1, -1, -1}, {12069, 22899, -1, -1}, {26262, -1, -1, -1}, {34384, -1, -1, -1}, {30111, -1, -1, -1}, {25386, -1, -1, -1}, {25062, -1, -1, -1}, {31983, -1, -1, -1}, {35834, -1, -1, -1}, {21734, -1, -1, -1}, {27431, -1, -1, -1}, {40485, -1, -1, -1}, {27572, -1, -1, -1}, {34261, -1, -1, -1}, {21589, -1, -1, -1}, {20598, -1, -1, -1}, {27812, -1, -1, -1}, {21866, -1, -1, -1}, {36276, -1, -1, -1}, {29228, -1, -1, -1}, {24085, -1, -1, -1}, {24597, -1, -1, -1}, {29750, -1, -1, -1}, {25293, -1, -1, -1}, {25490, -1, -1, -1}, {29260, -1, -1, -1}, {24472, -1, -1, -1}, {28227, -1, -1, -1}, {27966, -1, -1, -1}, {25856, -1, -1, -1}, {28504, -1, -1, -1}, {30424, -1, -1, -1}, {30928, -1, -1, -1}, {30460, -1, -1, -1}, {30036, -1, -1, -1}, {21028, -1, -1, -1}, {21467, -1, -1, -1}, {20051, -1, -1, -1}, {24222, -1, -1, -1}, {26049, -1, -1, -1}, {32810, -1, -1, -1}, {32982, -1, -1, -1}, {25243, -1, -1, -1}, {21638, -1, -1, -1}, {21032, -1, -1, -1}, {28846, -1, -1, -1}, {34957, -1, -1, -1}, {36305, -1, -1, -1}, {27873, -1, -1, -1}, {21624, -1, -1, -1}, {32986, -1, -1, -1}, {22521, -1, -1, -1}, {35060, -1, -1, -1}, {36180, -1, -1, -1}, {38506, -1, -1, -1}, {37197, -1, -1, -1}, {20329, -1, -1, -1}, {27803, -1, -1, -1}, {21943, -1, -1, -1}, {30406, -1, -1, -1}, {30768, -1, -1, -1}, {25256, -1, -1, -1}, {28921, -1, -1, -1}, {28558, -1, -1, -1}, {24429, -1, -1, -1}, {34028, -1, -1, -1}, {26842, -1, -1, -1}, {30844, -1, -1, -1}, {31735, -1, -1, -1}, {33192, -1, -1, -1}, {26379, -1, -1, -1}, {40527, -1, -1, -1}, {25447, -1, -1, -1}, {30896, -1, -1, -1}, {22383, -1, -1, -1}, {30738, -1, -1, -1}, {38713, -1, -1, -1}, {25209, -1, -1, -1}, {25259, -1, -1, -1}, {21128, -1, -1, -1}, {29749, -1, -1, -1}, {27607, -1, -1, -1}, {21860, -1, -1, -1}, {33086, -1, -1, -1}, {30130, -1, -1, -1}, {12138, 30382, -1, -1}, {21305, -1, -1, -1}, {30174, -1, -1, -1}, {20731, -1, -1, -1}, {23617, -1, -1, -1}, {35692, -1, -1, -1}, {31687, -1, -1, -1}, {20559, -1, -1, -1}, {12122, 29255, -1, -1}, {39575, -1, -1, -1}, {39128, -1, -1, -1}, {28418, -1, -1, -1}, {29922, -1, -1, -1}, {31080, -1, -1, -1}, {25735, -1, -1, -1}, {30629, -1, -1, -1}, {25340, -1, -1, -1}, {39057, -1, -1, -1}, {36139, -1, -1, -1}, {21697, -1, -1, -1}, {32856, -1, -1, -1}, {20050, -1, -1, -1}, {22378, -1, -1, -1}, {33529, -1, -1, -1}, {33805, -1, -1, -1}, {24179, -1, -1, -1}, {20973, -1, -1, -1}, {29942, -1, -1, -1}, {35780, -1, -1, -1}, {23631, -1, -1, -1}, {22369, -1, -1, -1}, {27900, -1, -1, -1}, {39047, -1, -1, -1}, {23110, -1, -1, -1}, {30772, -1, -1, -1}, {39748, -1, -1, -1}, {36843, -1, -1, -1}, {31893, -1, -1, -1}, {21078, -1, -1, -1}, {25169, -1, -1, -1}, {38138, -1, -1, -1}, {20166, -1, -1, -1}, {33670, -1, -1, -1}, {33889, -1, -1, -1}, {33769, -1, -1, -1}, {33970, -1, -1, -1}, {22484, -1, -1, -1}, {26420, -1, -1, -1}, {22275, -1, -1, -1}, {26222, -1, -1, -1}, {28006, -1, -1, -1}, {35889, -1, -1, -1}, {26333, -1, -1, -1}, {28689, -1, -1, -1}, {26399, -1, -1, -1}, {27450, -1, -1, -1}, {26646, -1, -1, -1}, {25114, -1, -1, -1}, {22971, -1, -1, -1}, {19971, -1, -1, -1}, {20932, -1, -1, -1} },
+ {{28422, -1, -1, -1}, {26578, -1, -1, -1}, {27791, -1, -1, -1}, {20854, -1, -1, -1}, {26827, -1, -1, -1}, {22855, -1, -1, -1}, {27495, -1, -1, -1}, {30054, -1, -1, -1}, {23822, -1, -1, -1}, {33040, -1, -1, -1}, {40784, -1, -1, -1}, {26071, -1, -1, -1}, {31048, -1, -1, -1}, {31041, -1, -1, -1}, {39569, -1, -1, -1}, {36215, -1, -1, -1}, {23682, -1, -1, -1}, {20062, -1, -1, -1}, {20225, -1, -1, -1}, {21551, -1, -1, -1}, {22865, -1, -1, -1}, {30732, -1, -1, -1}, {22120, -1, -1, -1}, {12115, 27668, -1, -1}, {36804, -1, -1, -1}, {24323, -1, -1, -1}, {27773, -1, -1, -1}, {27875, -1, -1, -1}, {35755, -1, -1, -1}, {25488, -1, -1, -1}, {24688, -1, -1, -1}, {27965, -1, -1, -1}, {29301, -1, -1, -1}, {25190, -1, -1, -1}, {38030, -1, -1, -1}, {38085, -1, -1, -1}, {21315, -1, -1, -1}, {36801, -1, -1, -1}, {31614, -1, -1, -1}, {20191, -1, -1, -1}, {35878, -1, -1, -1}, {20094, -1, -1, -1}, {40660, -1, -1, -1}, {38065, -1, -1, -1}, {38067, -1, -1, -1}, {21069, -1, -1, -1}, {28508, -1, -1, -1}, {36963, -1, -1, -1}, {27973, -1, -1, -1}, {35892, -1, -1, -1}, {22545, -1, -1, -1}, {23884, -1, -1, -1}, {12107, 27424, -1, -1}, {27465, -1, -1, -1}, {26538, -1, -1, -1}, {21595, -1, -1, -1}, {33108, -1, -1, -1}, {32652, -1, -1, -1}, {22681, -1, -1, -1}, {34103, -1, -1, -1}, {24378, -1, -1, -1}, {25250, -1, -1, -1}, {27207, -1, -1, -1}, {38201, -1, -1, -1}, {25970, -1, -1, -1}, {24708, -1, -1, -1}, {26725, -1, -1, -1}, {30631, -1, -1, -1}, {20052, -1, -1, -1}, {20392, -1, -1, -1}, {24039, -1, -1, -1}, {38808, -1, -1, -1}, {25772, -1, -1, -1}, {32728, -1, -1, -1}, {23789, -1, -1, -1}, {20431, -1, -1, -1}, {31373, -1, -1, -1}, {20999, -1, -1, -1}, {33540, -1, -1, -1}, {19988, -1, -1, -1}, {24623, -1, -1, -1}, {31363, -1, -1, -1}, {38054, -1, -1, -1}, {20405, -1, -1, -1}, {20146, -1, -1, -1}, {31206, -1, -1, -1}, {29748, -1, -1, -1}, {21220, -1, -1, -1}, {33465, -1, -1, -1}, {25810, -1, -1, -1}, {31165, -1, -1, -1}, {23517, -1, -1, -1}, {27777, -1, -1, -1}, {38738, -1, -1, -1}, {36731, -1, -1, -1}, {27682, -1, -1, -1}, {20542, -1, -1, -1}, {21375, -1, -1, -1}, {28165, -1, -1, -1}, {25806, -1, -1, -1}, {26228, -1, -1, -1}, {27696, -1, -1, -1}, {24773, -1, -1, -1}, {39031, -1, -1, -1}, {35831, -1, -1, -1}, {24198, -1, -1, -1}, {29756, -1, -1, -1}, {31351, -1, -1, -1}, {31179, -1, -1, -1}, {19992, -1, -1, -1}, {37041, -1, -1, -1}, {29699, -1, -1, -1}, {27714, -1, -1, -1}, {22234, -1, -1, -1}, {37195, -1, -1, -1}, {27845, -1, -1, -1}, {36235, -1, -1, -1}, {21306, -1, -1, -1}, {34502, -1, -1, -1}, {26354, -1, -1, -1}, {36527, -1, -1, -1}, {23624, -1, -1, -1}, {39537, -1, -1, -1}, {28192, -1, -1, -1}, {21462, -1, -1, -1}, {23094, -1, -1, -1}, {40843, -1, -1, -1}, {36259, -1, -1, -1}, {21435, -1, -1, -1}, {22280, -1, -1, -1}, {39079, -1, -1, -1}, {26435, -1, -1, -1}, {37275, -1, -1, -1}, {27849, -1, -1, -1}, {20840, -1, -1, -1}, {30154, -1, -1, -1}, {25331, -1, -1, -1}, {12125, 29356, -1, -1}, {21048, -1, -1, -1}, {21149, -1, -1, -1}, {32570, -1, -1, -1}, {28820, -1, -1, -1}, {30264, -1, -1, -1}, {21364, -1, -1, -1}, {40522, -1, -1, -1}, {27063, -1, -1, -1}, {30830, -1, -1, -1}, {38592, -1, -1, -1}, {35033, -1, -1, -1}, {32676, -1, -1, -1}, {28982, -1, -1, -1}, {29123, -1, -1, -1}, {20873, -1, -1, -1}, {26579, -1, -1, -1}, {29924, -1, -1, -1}, {22756, -1, -1, -1}, {25880, -1, -1, -1}, {22199, -1, -1, -1}, {35753, -1, -1, -1}, {39286, -1, -1, -1}, {25200, -1, -1, -1}, {32469, -1, -1, -1}, {24825, -1, -1, -1}, {28909, -1, -1, -1}, {22764, -1, -1, -1}, {20161, -1, -1, -1}, {12040, 20154, -1, -1}, {24525, -1, -1, -1}, {38887, -1, -1, -1}, {20219, -1, -1, -1}, {35748, -1, -1, -1}, {20995, -1, -1, -1}, {22922, -1, -1, -1}, {32427, -1, -1, -1}, {25172, -1, -1, -1}, {20173, -1, -1, -1}, {12103, 26085, -1, -1}, {25102, -1, -1, -1}, {33592, -1, -1, -1}, {33993, -1, -1, -1}, {33635, -1, -1, -1}, {34701, -1, -1, -1}, {29076, -1, -1, -1}, {28342, -1, -1, -1}, {23481, -1, -1, -1}, {32466, -1, -1, -1}, {20887, -1, -1, -1}, {25545, -1, -1, -1}, {26580, -1, -1, -1}, {12161, 32905, -1, -1}, {33593, -1, -1, -1}, {34837, -1, -1, -1}, {20754, -1, -1, -1}, {23418, -1, -1, -1}, {22914, -1, -1, -1}, {36785, -1, -1, -1}, {20083, -1, -1, -1}, {27741, -1, -1, -1}, {12042, 20837, -1, -1}, {35109, -1, -1, -1}, {36719, -1, -1, -1}, {38446, -1, -1, -1}, {34122, -1, -1, -1}, {29790, -1, -1, -1}, {38160, -1, -1, -1}, {38384, -1, -1, -1}, {28070, -1, -1, -1}, {33509, -1, -1, -1}, {24369, -1, -1, -1}, {25746, -1, -1, -1}, {27922, -1, -1, -1}, {33832, -1, -1, -1}, {33134, -1, -1, -1}, {40131, -1, -1, -1}, {22622, -1, -1, -1}, {36187, -1, -1, -1}, {19977, -1, -1, -1}, {21441, -1, -1, -1}, {20254, -1, -1, -1}, {25955, -1, -1, -1}, {26705, -1, -1, -1}, {21971, -1, -1, -1}, {20007, -1, -1, -1}, {25620, -1, -1, -1}, {39578, -1, -1, -1}, {25195, -1, -1, -1}, {23234, -1, -1, -1}, {29791, -1, -1, -1}, {12170, 33394, -1, -1}, {28073, -1, -1, -1}, {26862, -1, -1, -1}, {20711, -1, -1, -1}, {33678, -1, -1, -1}, {30722, -1, -1, -1}, {26432, -1, -1, -1}, {21049, -1, -1, -1}, {27801, -1, -1, -1}, {32433, -1, -1, -1}, {20667, -1, -1, -1}, {21861, -1, -1, -1}, {29022, -1, -1, -1}, {31579, -1, -1, -1}, {26194, -1, -1, -1}, {29642, -1, -1, -1}, {33515, -1, -1, -1}, {26441, -1, -1, -1}, {12077, 23665, -1, -1}, {21024, -1, -1, -1}, {29053, -1, -1, -1}, {34923, -1, -1, -1}, {38378, -1, -1, -1}, {38485, -1, -1, -1}, {25797, -1, -1, -1}, {36193, -1, -1, -1}, {33203, -1, -1, -1}, {21892, -1, -1, -1} },
+ {{27733, -1, -1, -1}, {25159, -1, -1, -1}, {32558, -1, -1, -1}, {22674, -1, -1, -1}, {20260, -1, -1, -1}, {21830, -1, -1, -1}, {36175, -1, -1, -1}, {26188, -1, -1, -1}, {19978, -1, -1, -1}, {23578, -1, -1, -1}, {35059, -1, -1, -1}, {26786, -1, -1, -1}, {25422, -1, -1, -1}, {31245, -1, -1, -1}, {28903, -1, -1, -1}, {33421, -1, -1, -1}, {21242, -1, -1, -1}, {38902, -1, -1, -1}, {23569, -1, -1, -1}, {21736, -1, -1, -1}, {37045, -1, -1, -1}, {32461, -1, -1, -1}, {22882, -1, -1, -1}, {36170, -1, -1, -1}, {34503, -1, -1, -1}, {12166, 33292, -1, -1}, {33293, -1, -1, -1}, {36198, -1, -1, -1}, {25668, -1, -1, -1}, {23556, -1, -1, -1}, {24913, -1, -1, -1}, {28041, -1, -1, -1}, {31038, -1, -1, -1}, {35774, -1, -1, -1}, {30775, -1, -1, -1}, {30003, -1, -1, -1}, {21627, -1, -1, -1}, {20280, -1, -1, -1}, {12189, 36523, -1, -1}, {28145, -1, -1, -1}, {23072, -1, -1, -1}, {32453, -1, -1, -1}, {31070, -1, -1, -1}, {27784, -1, -1, -1}, {23457, -1, -1, -1}, {23158, -1, -1, -1}, {29978, -1, -1, -1}, {32958, -1, -1, -1}, {24910, -1, -1, -1}, {28183, -1, -1, -1}, {22768, -1, -1, -1}, {12131, 29983, -1, -1}, {29989, -1, -1, -1}, {29298, -1, -1, -1}, {21319, -1, -1, -1}, {32499, -1, -1, -1}, {30465, -1, -1, -1}, {30427, -1, -1, -1}, {21097, -1, -1, -1}, {32988, -1, -1, -1}, {22307, -1, -1, -1}, {24072, -1, -1, -1}, {22833, -1, -1, -1}, {29422, -1, -1, -1}, {26045, -1, -1, -1}, {28287, -1, -1, -1}, {35799, -1, -1, -1}, {12075, 23608, -1, -1}, {34417, -1, -1, -1}, {12055, 21313, -1, -1}, {12143, 30707, -1, -1}, {25342, -1, -1, -1}, {26102, -1, -1, -1}, {20160, -1, -1, -1}, {12215, 39135, -1, -1}, {34432, -1, -1, -1}, {23454, -1, -1, -1}, {35782, -1, -1, -1}, {21490, -1, -1, -1}, {12142, 30690, -1, -1}, {20351, -1, -1, -1}, {23630, -1, -1, -1}, {39542, -1, -1, -1}, {22987, -1, -1, -1}, {24335, -1, -1, -1}, {12144, 31034, -1, -1}, {12064, 22763, -1, -1}, {19990, -1, -1, -1}, {26623, -1, -1, -1}, {20107, -1, -1, -1}, {25325, -1, -1, -1}, {35475, -1, -1, -1}, {36893, -1, -1, -1}, {21183, -1, -1, -1}, {26159, -1, -1, -1}, {21980, -1, -1, -1}, {22124, -1, -1, -1}, {36866, -1, -1, -1}, {20181, -1, -1, -1}, {20365, -1, -1, -1}, {37322, -1, -1, -1}, {39280, -1, -1, -1}, {12114, 27663, -1, -1}, {24066, -1, -1, -1}, {24643, -1, -1, -1}, {23460, -1, -1, -1}, {35270, -1, -1, -1}, {35797, -1, -1, -1}, {25910, -1, -1, -1}, {12095, 25163, -1, -1}, {12216, 39318, -1, -1}, {23432, -1, -1, -1}, {23551, -1, -1, -1}, {25480, -1, -1, -1}, {21806, -1, -1, -1}, {21463, -1, -1, -1}, {30246, -1, -1, -1}, {20861, -1, -1, -1}, {34092, -1, -1, -1}, {26530, -1, -1, -1}, {26803, -1, -1, -1}, {27530, -1, -1, -1}, {25234, -1, -1, -1}, {36755, -1, -1, -1}, {21460, -1, -1, -1}, {33298, -1, -1, -1}, {28113, -1, -1, -1}, {30095, -1, -1, -1}, {20070, -1, -1, -1}, {36174, -1, -1, -1}, {23408, -1, -1, -1}, {29087, -1, -1, -1}, {34223, -1, -1, -1}, {26257, -1, -1, -1}, {26329, -1, -1, -1}, {32626, -1, -1, -1}, {34560, -1, -1, -1}, {12233, 40653, -1, -1}, {12239, 40736, -1, -1}, {23646, -1, -1, -1}, {26415, -1, -1, -1}, {36848, -1, -1, -1}, {26641, -1, -1, -1}, {26463, -1, -1, -1}, {25101, -1, -1, -1}, {31446, -1, -1, -1}, {22661, -1, -1, -1}, {24246, -1, -1, -1}, {25968, -1, -1, -1}, {28465, -1, -1, -1}, {24661, -1, -1, -1}, {21047, -1, -1, -1}, {32781, -1, -1, -1}, {25684, -1, -1, -1}, {34928, -1, -1, -1}, {29993, -1, -1, -1}, {24069, -1, -1, -1}, {26643, -1, -1, -1}, {25332, -1, -1, -1}, {38684, -1, -1, -1}, {21452, -1, -1, -1}, {29245, -1, -1, -1}, {35841, -1, -1, -1}, {12116, 27700, -1, -1}, {30561, -1, -1, -1}, {31246, -1, -1, -1}, {21550, -1, -1, -1}, {30636, -1, -1, -1}, {39034, -1, -1, -1}, {33308, -1, -1, -1}, {35828, -1, -1, -1}, {30805, -1, -1, -1}, {26388, -1, -1, -1}, {28865, -1, -1, -1}, {26031, -1, -1, -1}, {25749, -1, -1, -1}, {22070, -1, -1, -1}, {24605, -1, -1, -1}, {31169, -1, -1, -1}, {21496, -1, -1, -1}, {19997, -1, -1, -1}, {27515, -1, -1, -1}, {32902, -1, -1, -1}, {23546, -1, -1, -1}, {21987, -1, -1, -1}, {22235, -1, -1, -1}, {20282, -1, -1, -1}, {20284, -1, -1, -1}, {39282, -1, -1, -1}, {24051, -1, -1, -1}, {26494, -1, -1, -1}, {32824, -1, -1, -1}, {24578, -1, -1, -1}, {39042, -1, -1, -1}, {36865, -1, -1, -1}, {23435, -1, -1, -1}, {35772, -1, -1, -1}, {35829, -1, -1, -1}, {25628, -1, -1, -1}, {33368, -1, -1, -1}, {25822, -1, -1, -1}, {22013, -1, -1, -1}, {33487, -1, -1, -1}, {37221, -1, -1, -1}, {20439, -1, -1, -1}, {32032, -1, -1, -1}, {36895, -1, -1, -1}, {31903, -1, -1, -1}, {20723, -1, -1, -1}, {22609, -1, -1, -1}, {28335, -1, -1, -1}, {23487, -1, -1, -1}, {35785, -1, -1, -1}, {32899, -1, -1, -1}, {37240, -1, -1, -1}, {33948, -1, -1, -1}, {31639, -1, -1, -1}, {34429, -1, -1, -1}, {38539, -1, -1, -1}, {38543, -1, -1, -1}, {32485, -1, -1, -1}, {39635, -1, -1, -1}, {30862, -1, -1, -1}, {23681, -1, -1, -1}, {31319, -1, -1, -1}, {36930, -1, -1, -1}, {38567, -1, -1, -1}, {31071, -1, -1, -1}, {23385, -1, -1, -1}, {25439, -1, -1, -1}, {31499, -1, -1, -1}, {34001, -1, -1, -1}, {26797, -1, -1, -1}, {21766, -1, -1, -1}, {32553, -1, -1, -1}, {29712, -1, -1, -1}, {32034, -1, -1, -1}, {38145, -1, -1, -1}, {25152, -1, -1, -1}, {22604, -1, -1, -1}, {20182, -1, -1, -1}, {23427, -1, -1, -1}, {22905, -1, -1, -1}, {22612, -1, -1, -1}, {29549, -1, -1, -1}, {25374, -1, -1, -1}, {36427, -1, -1, -1}, {36367, -1, -1, -1}, {32974, -1, -1, -1}, {33492, -1, -1, -1}, {25260, -1, -1, -1}, {21488, -1, -1, -1}, {27888, -1, -1, -1}, {37214, -1, -1, -1}, {22826, -1, -1, -1}, {24577, -1, -1, -1} },
+ {{27760, -1, -1, -1}, {22349, -1, -1, -1}, {25674, -1, -1, -1}, {36138, -1, -1, -1}, {30251, -1, -1, -1}, {28393, -1, -1, -1}, {22363, -1, -1, -1}, {27264, -1, -1, -1}, {30192, -1, -1, -1}, {28525, -1, -1, -1}, {35885, -1, -1, -1}, {35848, -1, -1, -1}, {22374, -1, -1, -1}, {27631, -1, -1, -1}, {34962, -1, -1, -1}, {30899, -1, -1, -1}, {25506, -1, -1, -1}, {21497, -1, -1, -1}, {28845, -1, -1, -1}, {27748, -1, -1, -1}, {22616, -1, -1, -1}, {25642, -1, -1, -1}, {22530, -1, -1, -1}, {26848, -1, -1, -1}, {33179, -1, -1, -1}, {21776, -1, -1, -1}, {31958, -1, -1, -1}, {20504, -1, -1, -1}, {36538, -1, -1, -1}, {28108, -1, -1, -1}, {36255, -1, -1, -1}, {28907, -1, -1, -1}, {25487, -1, -1, -1}, {28059, -1, -1, -1}, {28372, -1, -1, -1}, {32486, -1, -1, -1}, {33796, -1, -1, -1}, {26691, -1, -1, -1}, {36867, -1, -1, -1}, {28120, -1, -1, -1}, {38518, -1, -1, -1}, {35752, -1, -1, -1}, {22871, -1, -1, -1}, {29305, -1, -1, -1}, {34276, -1, -1, -1}, {33150, -1, -1, -1}, {30140, -1, -1, -1}, {35466, -1, -1, -1}, {26799, -1, -1, -1}, {21076, -1, -1, -1}, {36386, -1, -1, -1}, {38161, -1, -1, -1}, {25552, -1, -1, -1}, {39064, -1, -1, -1}, {36420, -1, -1, -1}, {21884, -1, -1, -1}, {20307, -1, -1, -1}, {26367, -1, -1, -1}, {22159, -1, -1, -1}, {24789, -1, -1, -1}, {28053, -1, -1, -1}, {21059, -1, -1, -1}, {23625, -1, -1, -1}, {22825, -1, -1, -1}, {28155, -1, -1, -1}, {22635, -1, -1, -1}, {12133, 30000, -1, -1}, {29980, -1, -1, -1}, {24684, -1, -1, -1}, {33300, -1, -1, -1}, {33094, -1, -1, -1}, {25361, -1, -1, -1}, {26465, -1, -1, -1}, {36834, -1, -1, -1}, {30522, -1, -1, -1}, {36339, -1, -1, -1}, {36148, -1, -1, -1}, {38081, -1, -1, -1}, {24086, -1, -1, -1}, {21381, -1, -1, -1}, {21548, -1, -1, -1}, {28867, -1, -1, -1}, {27712, -1, -1, -1}, {24311, -1, -1, -1}, {20572, -1, -1, -1}, {20141, -1, -1, -1}, {24237, -1, -1, -1}, {25402, -1, -1, -1}, {33351, -1, -1, -1}, {36890, -1, -1, -1}, {26704, -1, -1, -1}, {37230, -1, -1, -1}, {30643, -1, -1, -1}, {21516, -1, -1, -1}, {38108, -1, -1, -1}, {24420, -1, -1, -1}, {31461, -1, -1, -1}, {26742, -1, -1, -1}, {25413, -1, -1, -1}, {31570, -1, -1, -1}, {32479, -1, -1, -1}, {30171, -1, -1, -1}, {20599, -1, -1, -1}, {25237, -1, -1, -1}, {22836, -1, -1, -1}, {36879, -1, -1, -1}, {20984, -1, -1, -1}, {31171, -1, -1, -1}, {31361, -1, -1, -1}, {22270, -1, -1, -1}, {24466, -1, -1, -1}, {36884, -1, -1, -1}, {28034, -1, -1, -1}, {23648, -1, -1, -1}, {12063, 22303, -1, -1}, {21520, -1, -1, -1}, {20820, -1, -1, -1}, {28237, -1, -1, -1}, {22242, -1, -1, -1}, {25512, -1, -1, -1}, {39059, -1, -1, -1}, {33151, -1, -1, -1}, {34581, -1, -1, -1}, {35114, -1, -1, -1}, {36864, -1, -1, -1}, {21534, -1, -1, -1}, {23663, -1, -1, -1}, {33216, -1, -1, -1}, {25302, -1, -1, -1}, {25176, -1, -1, -1}, {33073, -1, -1, -1}, {40501, -1, -1, -1}, {38464, -1, -1, -1}, {39534, -1, -1, -1}, {39548, -1, -1, -1}, {26925, -1, -1, -1}, {22949, -1, -1, -1}, {25299, -1, -1, -1}, {21822, -1, -1, -1}, {25366, -1, -1, -1}, {21703, -1, -1, -1}, {34521, -1, -1, -1}, {27964, -1, -1, -1}, {23043, -1, -1, -1}, {12129, 29926, -1, -1}, {34972, -1, -1, -1}, {27498, -1, -1, -1}, {22806, -1, -1, -1}, {35916, -1, -1, -1}, {24367, -1, -1, -1}, {28286, -1, -1, -1}, {29609, -1, -1, -1}, {39037, -1, -1, -1}, {20024, -1, -1, -1}, {28919, -1, -1, -1}, {23436, -1, -1, -1}, {30871, -1, -1, -1}, {25405, -1, -1, -1}, {26202, -1, -1, -1}, {30358, -1, -1, -1}, {24779, -1, -1, -1}, {23451, -1, -1, -1}, {23113, -1, -1, -1}, {19975, -1, -1, -1}, {33109, -1, -1, -1}, {27754, -1, -1, -1}, {29579, -1, -1, -1}, {20129, -1, -1, -1}, {26505, -1, -1, -1}, {12153, 32593, -1, -1}, {24448, -1, -1, -1}, {26106, -1, -1, -1}, {26395, -1, -1, -1}, {24536, -1, -1, -1}, {22916, -1, -1, -1}, {23041, -1, -1, -1}, {24013, -1, -1, -1}, {24494, -1, -1, -1}, {21361, -1, -1, -1}, {38886, -1, -1, -1}, {36829, -1, -1, -1}, {26693, -1, -1, -1}, {22260, -1, -1, -1}, {21807, -1, -1, -1}, {24799, -1, -1, -1}, {20026, -1, -1, -1}, {28493, -1, -1, -1}, {32500, -1, -1, -1}, {33479, -1, -1, -1}, {33806, -1, -1, -1}, {22996, -1, -1, -1}, {20255, -1, -1, -1}, {20266, -1, -1, -1}, {23614, -1, -1, -1}, {32428, -1, -1, -1}, {26410, -1, -1, -1}, {34074, -1, -1, -1}, {21619, -1, -1, -1}, {30031, -1, -1, -1}, {32963, -1, -1, -1}, {21890, -1, -1, -1}, {39759, -1, -1, -1}, {20301, -1, -1, -1}, {28205, -1, -1, -1}, {35859, -1, -1, -1}, {23561, -1, -1, -1}, {24944, -1, -1, -1}, {21355, -1, -1, -1}, {30239, -1, -1, -1}, {28201, -1, -1, -1}, {34442, -1, -1, -1}, {12098, 25991, -1, -1}, {38395, -1, -1, -1}, {32441, -1, -1, -1}, {21563, -1, -1, -1}, {31283, -1, -1, -1}, {32010, -1, -1, -1}, {38382, -1, -1, -1}, {21985, -1, -1, -1}, {32705, -1, -1, -1}, {29934, -1, -1, -1}, {25373, -1, -1, -1}, {34583, -1, -1, -1}, {28065, -1, -1, -1}, {31389, -1, -1, -1}, {25105, -1, -1, -1}, {26017, -1, -1, -1}, {21351, -1, -1, -1}, {25569, -1, -1, -1}, {27779, -1, -1, -1}, {24043, -1, -1, -1}, {21596, -1, -1, -1}, {38056, -1, -1, -1}, {20044, -1, -1, -1}, {27745, -1, -1, -1}, {35820, -1, -1, -1}, {23627, -1, -1, -1}, {12102, 26080, -1, -1}, {33436, -1, -1, -1}, {26791, -1, -1, -1}, {21566, -1, -1, -1}, {21556, -1, -1, -1}, {12111, 27595, -1, -1}, {27494, -1, -1, -1}, {20116, -1, -1, -1}, {25410, -1, -1, -1}, {21320, -1, -1, -1}, {33310, -1, -1, -1}, {20237, -1, -1, -1}, {20398, -1, -1, -1}, {22366, -1, -1, -1}, {25098, -1, -1, -1}, {38654, -1, -1, -1}, {26212, -1, -1, -1}, {29289, -1, -1, -1}, {21247, -1, -1, -1} },
+ {{21153, -1, -1, -1}, {24735, -1, -1, -1}, {35823, -1, -1, -1}, {26132, -1, -1, -1}, {29081, -1, -1, -1}, {26512, -1, -1, -1}, {35199, -1, -1, -1}, {30802, -1, -1, -1}, {30717, -1, -1, -1}, {26224, -1, -1, -1}, {22075, -1, -1, -1}, {21560, -1, -1, -1}, {38177, -1, -1, -1}, {29306, -1, -1, -1}, {31232, -1, -1, -1}, {24687, -1, -1, -1}, {24076, -1, -1, -1}, {24713, -1, -1, -1}, {33181, -1, -1, -1}, {12067, 22805, -1, -1}, {24796, -1, -1, -1}, {29060, -1, -1, -1}, {28911, -1, -1, -1}, {28330, -1, -1, -1}, {27728, -1, -1, -1}, {29312, -1, -1, -1}, {27268, -1, -1, -1}, {34989, -1, -1, -1}, {24109, -1, -1, -1}, {20064, -1, -1, -1}, {23219, -1, -1, -1}, {21916, -1, -1, -1}, {38115, -1, -1, -1}, {27927, -1, -1, -1}, {31995, -1, -1, -1}, {38553, -1, -1, -1}, {25103, -1, -1, -1}, {32454, -1, -1, -1}, {30606, -1, -1, -1}, {34430, -1, -1, -1}, {21283, -1, -1, -1}, {38686, -1, -1, -1}, {36758, -1, -1, -1}, {26247, -1, -1, -1}, {23777, -1, -1, -1}, {20384, -1, -1, -1}, {29421, -1, -1, -1}, {19979, -1, -1, -1}, {21414, -1, -1, -1}, {22799, -1, -1, -1}, {21523, -1, -1, -1}, {25472, -1, -1, -1}, {38184, -1, -1, -1}, {20808, -1, -1, -1}, {20185, -1, -1, -1}, {40092, -1, -1, -1}, {32420, -1, -1, -1}, {21688, -1, -1, -1}, {36132, -1, -1, -1}, {34900, -1, -1, -1}, {33335, -1, -1, -1}, {38386, -1, -1, -1}, {28046, -1, -1, -1}, {24358, -1, -1, -1}, {23244, -1, -1, -1}, {26174, -1, -1, -1}, {38505, -1, -1, -1}, {29616, -1, -1, -1}, {29486, -1, -1, -1}, {21439, -1, -1, -1}, {33146, -1, -1, -1}, {39301, -1, -1, -1}, {32673, -1, -1, -1}, {23466, -1, -1, -1}, {38519, -1, -1, -1}, {38480, -1, -1, -1}, {32447, -1, -1, -1}, {30456, -1, -1, -1}, {21410, -1, -1, -1}, {38262, -1, -1, -1}, {12217, 39321, -1, -1}, {31665, -1, -1, -1}, {35140, -1, -1, -1}, {28248, -1, -1, -1}, {20065, -1, -1, -1}, {32724, -1, -1, -1}, {31077, -1, -1, -1}, {35814, -1, -1, -1}, {24819, -1, -1, -1}, {21709, -1, -1, -1}, {20139, -1, -1, -1}, {39033, -1, -1, -1}, {24055, -1, -1, -1}, {27233, -1, -1, -1}, {20687, -1, -1, -1}, {21521, -1, -1, -1}, {35937, -1, -1, -1}, {33831, -1, -1, -1}, {30813, -1, -1, -1}, {38660, -1, -1, -1}, {21066, -1, -1, -1}, {21742, -1, -1, -1}, {22179, -1, -1, -1}, {38144, -1, -1, -1}, {28040, -1, -1, -1}, {23477, -1, -1, -1}, {28102, -1, -1, -1}, {26195, -1, -1, -1}, {12073, 23567, -1, -1}, {23389, -1, -1, -1}, {26657, -1, -1, -1}, {32918, -1, -1, -1}, {21880, -1, -1, -1}, {31505, -1, -1, -1}, {25928, -1, -1, -1}, {26964, -1, -1, -1}, {20123, -1, -1, -1}, {27463, -1, -1, -1}, {34638, -1, -1, -1}, {38795, -1, -1, -1}, {21327, -1, -1, -1}, {25375, -1, -1, -1}, {25658, -1, -1, -1}, {37034, -1, -1, -1}, {26012, -1, -1, -1}, {32961, -1, -1, -1}, {35856, -1, -1, -1}, {20889, -1, -1, -1}, {26800, -1, -1, -1}, {21368, -1, -1, -1}, {34809, -1, -1, -1}, {25032, -1, -1, -1}, {27844, -1, -1, -1}, {27899, -1, -1, -1}, {35874, -1, -1, -1}, {23633, -1, -1, -1}, {34218, -1, -1, -1}, {33455, -1, -1, -1}, {38156, -1, -1, -1}, {27427, -1, -1, -1}, {12191, 36763, -1, -1}, {26032, -1, -1, -1}, {24571, -1, -1, -1}, {12092, 24515, -1, -1}, {20449, -1, -1, -1}, {34885, -1, -1, -1}, {26143, -1, -1, -1}, {33125, -1, -1, -1}, {29481, -1, -1, -1}, {24826, -1, -1, -1}, {20852, -1, -1, -1}, {21009, -1, -1, -1}, {22411, -1, -1, -1}, {24418, -1, -1, -1}, {37026, -1, -1, -1}, {12175, 34892, -1, -1}, {37266, -1, -1, -1}, {24184, -1, -1, -1}, {26447, -1, -1, -1}, {24615, -1, -1, -1}, {22995, -1, -1, -1}, {20804, -1, -1, -1}, {20982, -1, -1, -1}, {33016, -1, -1, -1}, {21256, -1, -1, -1}, {27769, -1, -1, -1}, {38596, -1, -1, -1}, {29066, -1, -1, -1}, {20241, -1, -1, -1}, {20462, -1, -1, -1}, {32670, -1, -1, -1}, {26429, -1, -1, -1}, {21957, -1, -1, -1}, {38152, -1, -1, -1}, {31168, -1, -1, -1}, {34966, -1, -1, -1}, {32483, -1, -1, -1}, {22687, -1, -1, -1}, {25100, -1, -1, -1}, {38656, -1, -1, -1}, {34394, -1, -1, -1}, {22040, -1, -1, -1}, {39035, -1, -1, -1}, {24464, -1, -1, -1}, {35768, -1, -1, -1}, {33988, -1, -1, -1}, {37207, -1, -1, -1}, {21465, -1, -1, -1}, {26093, -1, -1, -1}, {24207, -1, -1, -1}, {30044, -1, -1, -1}, {24676, -1, -1, -1}, {32110, -1, -1, -1}, {23167, -1, -1, -1}, {32490, -1, -1, -1}, {32493, -1, -1, -1}, {36713, -1, -1, -1}, {21927, -1, -1, -1}, {23459, -1, -1, -1}, {24748, -1, -1, -1}, {26059, -1, -1, -1}, {12126, 29572, -1, -1}, {36873, -1, -1, -1}, {30307, -1, -1, -1}, {30505, -1, -1, -1}, {32474, -1, -1, -1}, {38772, -1, -1, -1}, {34203, -1, -1, -1}, {23398, -1, -1, -1}, {12147, 31348, -1, -1}, {38634, -1, -1, -1}, {12174, 34880, -1, -1}, {21195, -1, -1, -1}, {29071, -1, -1, -1}, {24490, -1, -1, -1}, {26092, -1, -1, -1}, {35810, -1, -1, -1}, {23547, -1, -1, -1}, {39535, -1, -1, -1}, {24033, -1, -1, -1}, {27529, -1, -1, -1}, {27739, -1, -1, -1}, {35757, -1, -1, -1}, {35759, -1, -1, -1}, {36874, -1, -1, -1}, {36805, -1, -1, -1}, {21387, -1, -1, -1}, {25276, -1, -1, -1}, {40486, -1, -1, -1}, {40493, -1, -1, -1}, {21568, -1, -1, -1}, {20011, -1, -1, -1}, {33469, -1, -1, -1}, {12123, 29273, -1, -1}, {34460, -1, -1, -1}, {23830, -1, -1, -1}, {34905, -1, -1, -1}, {28079, -1, -1, -1}, {38597, -1, -1, -1}, {21713, -1, -1, -1}, {20122, -1, -1, -1}, {35766, -1, -1, -1}, {28937, -1, -1, -1}, {21693, -1, -1, -1}, {38409, -1, -1, -1}, {28895, -1, -1, -1}, {28153, -1, -1, -1}, {30416, -1, -1, -1}, {20005, -1, -1, -1}, {30740, -1, -1, -1}, {34578, -1, -1, -1}, {23721, -1, -1, -1}, {24310, -1, -1, -1}, {12180, 35328, -1, -1}, {39068, -1, -1, -1}, {38414, -1, -1, -1} },
+ {{28814, -1, -1, -1}, {27839, -1, -1, -1}, {22852, -1, -1, -1}, {25513, -1, -1, -1}, {30524, -1, -1, -1}, {34893, -1, -1, -1}, {28436, -1, -1, -1}, {33395, -1, -1, -1}, {22576, -1, -1, -1}, {29141, -1, -1, -1}, {21388, -1, -1, -1}, {30746, -1, -1, -1}, {38593, -1, -1, -1}, {21761, -1, -1, -1}, {24422, -1, -1, -1}, {28976, -1, -1, -1}, {23476, -1, -1, -1}, {35866, -1, -1, -1}, {39564, -1, -1, -1}, {27523, -1, -1, -1}, {22830, -1, -1, -1}, {40495, -1, -1, -1}, {31207, -1, -1, -1}, {26472, -1, -1, -1}, {25196, -1, -1, -1}, {20335, -1, -1, -1}, {30113, -1, -1, -1}, {12154, 32650, -1, -1}, {27915, -1, -1, -1}, {38451, -1, -1, -1}, {27687, -1, -1, -1}, {20208, -1, -1, -1}, {30162, -1, -1, -1}, {20859, -1, -1, -1}, {26679, -1, -1, -1}, {28478, -1, -1, -1}, {36992, -1, -1, -1}, {33136, -1, -1, -1}, {22934, -1, -1, -1}, {29814, -1, -1, -1}, {25671, -1, -1, -1}, {23591, -1, -1, -1}, {36965, -1, -1, -1}, {31377, -1, -1, -1}, {35875, -1, -1, -1}, {23002, -1, -1, -1}, {21676, -1, -1, -1}, {33280, -1, -1, -1}, {33647, -1, -1, -1}, {35201, -1, -1, -1}, {32768, -1, -1, -1}, {26928, -1, -1, -1}, {22094, -1, -1, -1}, {32822, -1, -1, -1}, {29239, -1, -1, -1}, {37326, -1, -1, -1}, {20918, -1, -1, -1}, {20063, -1, -1, -1}, {39029, -1, -1, -1}, {25494, -1, -1, -1}, {19994, -1, -1, -1}, {21494, -1, -1, -1}, {26355, -1, -1, -1}, {33099, -1, -1, -1}, {22812, -1, -1, -1}, {28082, -1, -1, -1}, {12032, 19968, -1, -1}, {22777, -1, -1, -1}, {21307, -1, -1, -1}, {25558, -1, -1, -1}, {38129, -1, -1, -1}, {20381, -1, -1, -1}, {20234, -1, -1, -1}, {12176, 34915, -1, -1}, {39056, -1, -1, -1}, {22839, -1, -1, -1}, {36951, -1, -1, -1}, {31227, -1, -1, -1}, {20202, -1, -1, -1}, {33008, -1, -1, -1}, {30097, -1, -1, -1}, {27778, -1, -1, -1}, {23452, -1, -1, -1}, {23016, -1, -1, -1}, {24413, -1, -1, -1}, {26885, -1, -1, -1}, {34433, -1, -1, -1}, {20506, -1, -1, -1}, {24050, -1, -1, -1}, {12036, 20057, -1, -1}, {30691, -1, -1, -1}, {20197, -1, -1, -1}, {33402, -1, -1, -1}, {25233, -1, -1, -1}, {26131, -1, -1, -1}, {12194, 37009, -1, -1}, {23673, -1, -1, -1}, {20159, -1, -1, -1}, {24441, -1, -1, -1}, {33222, -1, -1, -1}, {36920, -1, -1, -1}, {32900, -1, -1, -1}, {30123, -1, -1, -1}, {20134, -1, -1, -1}, {35028, -1, -1, -1}, {24847, -1, -1, -1}, {27589, -1, -1, -1}, {24518, -1, -1, -1}, {20041, -1, -1, -1}, {30410, -1, -1, -1}, {28322, -1, -1, -1}, {35811, -1, -1, -1}, {35758, -1, -1, -1}, {35850, -1, -1, -1}, {35793, -1, -1, -1}, {24322, -1, -1, -1}, {32764, -1, -1, -1}, {32716, -1, -1, -1}, {32462, -1, -1, -1}, {33589, -1, -1, -1}, {33643, -1, -1, -1}, {22240, -1, -1, -1}, {27575, -1, -1, -1}, {12211, 38899, -1, -1}, {38452, -1, -1, -1}, {23035, -1, -1, -1}, {21535, -1, -1, -1}, {38134, -1, -1, -1}, {28139, -1, -1, -1}, {23493, -1, -1, -1}, {39278, -1, -1, -1}, {23609, -1, -1, -1}, {24341, -1, -1, -1}, {38544, -1, -1, -1}, {21360, -1, -1, -1}, {33521, -1, -1, -1}, {27185, -1, -1, -1}, {23156, -1, -1, -1}, {40560, -1, -1, -1}, {24212, -1, -1, -1}, {32552, -1, -1, -1}, {33721, -1, -1, -1}, {33828, -1, -1, -1}, {33829, -1, -1, -1}, {33639, -1, -1, -1}, {34631, -1, -1, -1}, {36814, -1, -1, -1}, {36194, -1, -1, -1}, {30408, -1, -1, -1}, {24433, -1, -1, -1}, {39062, -1, -1, -1}, {30828, -1, -1, -1}, {26144, -1, -1, -1}, {21727, -1, -1, -1}, {25317, -1, -1, -1}, {20323, -1, -1, -1}, {33219, -1, -1, -1}, {30152, -1, -1, -1}, {24248, -1, -1, -1}, {38605, -1, -1, -1}, {36362, -1, -1, -1}, {34553, -1, -1, -1}, {21647, -1, -1, -1}, {27891, -1, -1, -1}, {28044, -1, -1, -1}, {27704, -1, -1, -1}, {24703, -1, -1, -1}, {21191, -1, -1, -1}, {12132, 29992, -1, -1}, {24189, -1, -1, -1}, {20248, -1, -1, -1}, {24736, -1, -1, -1}, {24551, -1, -1, -1}, {23588, -1, -1, -1}, {30001, -1, -1, -1}, {37038, -1, -1, -1}, {38080, -1, -1, -1}, {29369, -1, -1, -1}, {27833, -1, -1, -1}, {28216, -1, -1, -1}, {12195, 37193, -1, -1}, {26377, -1, -1, -1}, {21451, -1, -1, -1}, {21491, -1, -1, -1}, {20305, -1, -1, -1}, {37321, -1, -1, -1}, {35825, -1, -1, -1}, {12060, 21448, -1, -1}, {24188, -1, -1, -1}, {36802, -1, -1, -1}, {28132, -1, -1, -1}, {20110, -1, -1, -1}, {30402, -1, -1, -1}, {27014, -1, -1, -1}, {34398, -1, -1, -1}, {24858, -1, -1, -1}, {33286, -1, -1, -1}, {20313, -1, -1, -1}, {20446, -1, -1, -1}, {36926, -1, -1, -1}, {40060, -1, -1, -1}, {24841, -1, -1, -1}, {28189, -1, -1, -1}, {28180, -1, -1, -1}, {38533, -1, -1, -1}, {20104, -1, -1, -1}, {23089, -1, -1, -1}, {12204, 38632, -1, -1}, {19982, -1, -1, -1}, {23679, -1, -1, -1}, {31161, -1, -1, -1}, {23431, -1, -1, -1}, {35821, -1, -1, -1}, {12155, 32701, -1, -1}, {12127, 29577, -1, -1}, {22495, -1, -1, -1}, {33419, -1, -1, -1}, {37057, -1, -1, -1}, {21505, -1, -1, -1}, {36935, -1, -1, -1}, {21947, -1, -1, -1}, {23786, -1, -1, -1}, {24481, -1, -1, -1}, {24840, -1, -1, -1}, {27442, -1, -1, -1}, {29425, -1, -1, -1}, {32946, -1, -1, -1}, {35465, -1, -1, -1}, {28020, -1, -1, -1}, {23507, -1, -1, -1}, {35029, -1, -1, -1}, {39044, -1, -1, -1}, {35947, -1, -1, -1}, {39533, -1, -1, -1}, {40499, -1, -1, -1}, {28170, -1, -1, -1}, {20900, -1, -1, -1}, {20803, -1, -1, -1}, {22435, -1, -1, -1}, {34945, -1, -1, -1}, {21407, -1, -1, -1}, {25588, -1, -1, -1}, {36757, -1, -1, -1}, {22253, -1, -1, -1}, {21592, -1, -1, -1}, {22278, -1, -1, -1}, {29503, -1, -1, -1}, {28304, -1, -1, -1}, {32536, -1, -1, -1}, {36828, -1, -1, -1}, {33489, -1, -1, -1}, {24895, -1, -1, -1}, {24616, -1, -1, -1}, {38498, -1, -1, -1}, {12104, 26352, -1, -1}, {32422, -1, -1, -1} },
+ {{36234, -1, -1, -1}, {36291, -1, -1, -1}, {38053, -1, -1, -1}, {23731, -1, -1, -1}, {31908, -1, -1, -1}, {12105, 26376, -1, -1}, {24742, -1, -1, -1}, {38405, -1, -1, -1}, {32792, -1, -1, -1}, {20113, -1, -1, -1}, {37095, -1, -1, -1}, {21248, -1, -1, -1}, {38504, -1, -1, -1}, {20801, -1, -1, -1}, {36816, -1, -1, -1}, {34164, -1, -1, -1}, {37213, -1, -1, -1}, {26197, -1, -1, -1}, {38901, -1, -1, -1}, {23381, -1, -1, -1}, {21277, -1, -1, -1}, {30776, -1, -1, -1}, {26434, -1, -1, -1}, {26685, -1, -1, -1}, {21705, -1, -1, -1}, {28798, -1, -1, -1}, {23472, -1, -1, -1}, {36733, -1, -1, -1}, {20877, -1, -1, -1}, {22312, -1, -1, -1}, {21681, -1, -1, -1}, {25874, -1, -1, -1}, {26242, -1, -1, -1}, {36190, -1, -1, -1}, {36163, -1, -1, -1}, {33039, -1, -1, -1}, {33900, -1, -1, -1}, {36973, -1, -1, -1}, {31967, -1, -1, -1}, {20991, -1, -1, -1}, {34299, -1, -1, -1}, {26531, -1, -1, -1}, {26089, -1, -1, -1}, {28577, -1, -1, -1}, {34468, -1, -1, -1}, {36481, -1, -1, -1}, {22122, -1, -1, -1}, {36896, -1, -1, -1}, {30338, -1, -1, -1}, {28790, -1, -1, -1}, {29157, -1, -1, -1}, {36131, -1, -1, -1}, {25321, -1, -1, -1}, {21017, -1, -1, -1}, {27901, -1, -1, -1}, {36156, -1, -1, -1}, {24590, -1, -1, -1}, {22686, -1, -1, -1}, {24974, -1, -1, -1}, {26366, -1, -1, -1}, {36192, -1, -1, -1}, {25166, -1, -1, -1}, {21939, -1, -1, -1}, {28195, -1, -1, -1}, {26413, -1, -1, -1}, {36711, -1, -1, -1}, {38113, -1, -1, -1}, {38392, -1, -1, -1}, {30504, -1, -1, -1}, {26629, -1, -1, -1}, {27048, -1, -1, -1}, {21643, -1, -1, -1}, {20045, -1, -1, -1}, {28856, -1, -1, -1}, {35784, -1, -1, -1}, {25688, -1, -1, -1}, {25995, -1, -1, -1}, {23429, -1, -1, -1}, {31364, -1, -1, -1}, {20538, -1, -1, -1}, {23528, -1, -1, -1}, {30651, -1, -1, -1}, {27617, -1, -1, -1}, {35449, -1, -1, -1}, {31896, -1, -1, -1}, {27838, -1, -1, -1}, {30415, -1, -1, -1}, {26025, -1, -1, -1}, {36759, -1, -1, -1}, {23853, -1, -1, -1}, {23637, -1, -1, -1}, {34360, -1, -1, -1}, {26632, -1, -1, -1}, {21344, -1, -1, -1}, {25112, -1, -1, -1}, {31449, -1, -1, -1}, {28251, -1, -1, -1}, {32509, -1, -1, -1}, {27167, -1, -1, -1}, {31456, -1, -1, -1}, {24432, -1, -1, -1}, {28467, -1, -1, -1}, {24352, -1, -1, -1}, {25484, -1, -1, -1}, {28072, -1, -1, -1}, {26454, -1, -1, -1}, {19976, -1, -1, -1}, {24080, -1, -1, -1}, {36134, -1, -1, -1}, {20183, -1, -1, -1}, {32960, -1, -1, -1}, {30260, -1, -1, -1}, {38556, -1, -1, -1}, {25307, -1, -1, -1}, {26157, -1, -1, -1}, {25214, -1, -1, -1}, {27836, -1, -1, -1}, {36213, -1, -1, -1}, {29031, -1, -1, -1}, {32617, -1, -1, -1}, {20806, -1, -1, -1}, {32903, -1, -1, -1}, {21484, -1, -1, -1}, {36974, -1, -1, -1}, {25240, -1, -1, -1}, {21746, -1, -1, -1}, {34544, -1, -1, -1}, {36761, -1, -1, -1}, {32773, -1, -1, -1}, {38167, -1, -1, -1}, {34071, -1, -1, -1}, {36825, -1, -1, -1}, {27993, -1, -1, -1}, {29645, -1, -1, -1}, {26015, -1, -1, -1}, {30495, -1, -1, -1}, {29956, -1, -1, -1}, {30759, -1, -1, -1}, {33275, -1, -1, -1}, {36126, -1, -1, -1}, {38024, -1, -1, -1}, {20390, -1, -1, -1}, {26517, -1, -1, -1}, {30137, -1, -1, -1}, {35786, -1, -1, -1}, {38663, -1, -1, -1}, {25391, -1, -1, -1}, {38215, -1, -1, -1}, {38453, -1, -1, -1}, {33976, -1, -1, -1}, {25379, -1, -1, -1}, {30529, -1, -1, -1}, {24449, -1, -1, -1}, {29424, -1, -1, -1}, {20105, -1, -1, -1}, {24596, -1, -1, -1}, {25972, -1, -1, -1}, {25327, -1, -1, -1}, {27491, -1, -1, -1}, {25919, -1, -1, -1}, {24103, -1, -1, -1}, {30151, -1, -1, -1}, {37073, -1, -1, -1}, {35777, -1, -1, -1}, {33437, -1, -1, -1}, {26525, -1, -1, -1}, {12096, 25903, -1, -1}, {21553, -1, -1, -1}, {34584, -1, -1, -1}, {30693, -1, -1, -1}, {32930, -1, -1, -1}, {33026, -1, -1, -1}, {27713, -1, -1, -1}, {20043, -1, -1, -1}, {32455, -1, -1, -1}, {32844, -1, -1, -1}, {30452, -1, -1, -1}, {26893, -1, -1, -1}, {27542, -1, -1, -1}, {25191, -1, -1, -1}, {20540, -1, -1, -1}, {20356, -1, -1, -1}, {22336, -1, -1, -1}, {25351, -1, -1, -1}, {12108, 27490, -1, -1}, {36286, -1, -1, -1}, {21482, -1, -1, -1}, {26088, -1, -1, -1}, {32440, -1, -1, -1}, {24535, -1, -1, -1}, {25370, -1, -1, -1}, {25527, -1, -1, -1}, {12164, 33267, -1, -1}, {33268, -1, -1, -1}, {32622, -1, -1, -1}, {24092, -1, -1, -1}, {23769, -1, -1, -1}, {21046, -1, -1, -1}, {26234, -1, -1, -1}, {31209, -1, -1, -1}, {31258, -1, -1, -1}, {36136, -1, -1, -1}, {28825, -1, -1, -1}, {30164, -1, -1, -1}, {28382, -1, -1, -1}, {27835, -1, -1, -1}, {31378, -1, -1, -1}, {20013, -1, -1, -1}, {30405, -1, -1, -1}, {24544, -1, -1, -1}, {38047, -1, -1, -1}, {34935, -1, -1, -1}, {32456, -1, -1, -1}, {31181, -1, -1, -1}, {32959, -1, -1, -1}, {37325, -1, -1, -1}, {20210, -1, -1, -1}, {20247, -1, -1, -1}, {12168, 33311, -1, -1}, {21608, -1, -1, -1}, {24030, -1, -1, -1}, {27954, -1, -1, -1}, {35788, -1, -1, -1}, {31909, -1, -1, -1}, {36724, -1, -1, -1}, {32920, -1, -1, -1}, {24090, -1, -1, -1}, {21650, -1, -1, -1}, {30385, -1, -1, -1}, {23449, -1, -1, -1}, {26172, -1, -1, -1}, {39588, -1, -1, -1}, {29664, -1, -1, -1}, {26666, -1, -1, -1}, {34523, -1, -1, -1}, {26417, -1, -1, -1}, {29482, -1, -1, -1}, {35832, -1, -1, -1}, {35803, -1, -1, -1}, {36880, -1, -1, -1}, {12149, 31481, -1, -1}, {28891, -1, -1, -1}, {29038, -1, -1, -1}, {25284, -1, -1, -1}, {30633, -1, -1, -1}, {22065, -1, -1, -1}, {20027, -1, -1, -1}, {33879, -1, -1, -1}, {26609, -1, -1, -1}, {21161, -1, -1, -1}, {34496, -1, -1, -1}, {36142, -1, -1, -1}, {38136, -1, -1, -1}, {31569, -1, -1, -1}, {20303, -1, -1, -1}, {27880, -1, -1, -1} },
+ {{31069, -1, -1, -1}, {39547, -1, -1, -1}, {25235, -1, -1, -1}, {12118, 29226, -1, -1}, {25341, -1, -1, -1}, {19987, -1, -1, -1}, {30742, -1, -1, -1}, {36716, -1, -1, -1}, {25776, -1, -1, -1}, {36186, -1, -1, -1}, {31686, -1, -1, -1}, {26729, -1, -1, -1}, {24196, -1, -1, -1}, {35013, -1, -1, -1}, {22918, -1, -1, -1}, {25758, -1, -1, -1}, {22766, -1, -1, -1}, {29366, -1, -1, -1}, {26894, -1, -1, -1}, {38181, -1, -1, -1}, {36861, -1, -1, -1}, {36184, -1, -1, -1}, {22368, -1, -1, -1}, {32512, -1, -1, -1}, {35846, -1, -1, -1}, {20934, -1, -1, -1}, {25417, -1, -1, -1}, {25305, -1, -1, -1}, {21331, -1, -1, -1}, {26700, -1, -1, -1}, {29730, -1, -1, -1}, {33537, -1, -1, -1}, {37196, -1, -1, -1}, {21828, -1, -1, -1}, {30528, -1, -1, -1}, {28796, -1, -1, -1}, {27978, -1, -1, -1}, {20857, -1, -1, -1}, {21672, -1, -1, -1}, {36164, -1, -1, -1}, {23039, -1, -1, -1}, {28363, -1, -1, -1}, {28100, -1, -1, -1}, {23388, -1, -1, -1}, {32043, -1, -1, -1}, {20180, -1, -1, -1}, {31869, -1, -1, -1}, {28371, -1, -1, -1}, {12070, 23376, -1, -1}, {12163, 33258, -1, -1}, {28173, -1, -1, -1}, {23383, -1, -1, -1}, {39683, -1, -1, -1}, {26837, -1, -1, -1}, {36394, -1, -1, -1}, {23447, -1, -1, -1}, {32508, -1, -1, -1}, {24635, -1, -1, -1}, {32437, -1, -1, -1}, {37049, -1, -1, -1}, {12187, 36208, -1, -1}, {22863, -1, -1, -1}, {25549, -1, -1, -1}, {31199, -1, -1, -1}, {12188, 36275, -1, -1}, {21330, -1, -1, -1}, {26063, -1, -1, -1}, {31062, -1, -1, -1}, {35781, -1, -1, -1}, {38459, -1, -1, -1}, {32452, -1, -1, -1}, {38075, -1, -1, -1}, {32386, -1, -1, -1}, {22068, -1, -1, -1}, {37257, -1, -1, -1}, {26368, -1, -1, -1}, {32618, -1, -1, -1}, {23562, -1, -1, -1}, {36981, -1, -1, -1}, {26152, -1, -1, -1}, {24038, -1, -1, -1}, {20304, -1, -1, -1}, {26590, -1, -1, -1}, {20570, -1, -1, -1}, {20316, -1, -1, -1}, {22352, -1, -1, -1}, {24231, -1, -1, -1}, {20109, -1, -1, -1}, {19980, -1, -1, -1}, {20800, -1, -1, -1}, {19984, -1, -1, -1}, {24319, -1, -1, -1}, {21317, -1, -1, -1}, {19989, -1, -1, -1}, {20120, -1, -1, -1}, {19998, -1, -1, -1}, {12224, 39730, -1, -1}, {23404, -1, -1, -1}, {22121, -1, -1, -1}, {12033, 20008, -1, -1}, {31162, -1, -1, -1}, {12035, 20031, -1, -1}, {12052, 21269, -1, -1}, {20039, -1, -1, -1}, {22829, -1, -1, -1}, {12120, 29243, -1, -1}, {21358, -1, -1, -1}, {27664, -1, -1, -1}, {22239, -1, -1, -1}, {32996, -1, -1, -1}, {39319, -1, -1, -1}, {27603, -1, -1, -1}, {30590, -1, -1, -1}, {40727, -1, -1, -1}, {12034, 20022, -1, -1}, {20127, -1, -1, -1}, {40720, -1, -1, -1}, {20060, -1, -1, -1}, {20073, -1, -1, -1}, {20115, -1, -1, -1}, {33416, -1, -1, -1}, {23387, -1, -1, -1}, {21868, -1, -1, -1}, {22031, -1, -1, -1}, {20164, -1, -1, -1}, {21389, -1, -1, -1}, {21405, -1, -1, -1}, {21411, -1, -1, -1}, {21413, -1, -1, -1}, {21422, -1, -1, -1}, {38757, -1, -1, -1}, {36189, -1, -1, -1}, {12053, 21274, -1, -1}, {21493, -1, -1, -1}, {21286, -1, -1, -1}, {21294, -1, -1, -1}, {21310, -1, -1, -1}, {36188, -1, -1, -1}, {21350, -1, -1, -1}, {21347, -1, -1, -1}, {20994, -1, -1, -1}, {21000, -1, -1, -1}, {21006, -1, -1, -1}, {21037, -1, -1, -1}, {21043, -1, -1, -1}, {21055, -1, -1, -1}, {21056, -1, -1, -1}, {21068, -1, -1, -1}, {21086, -1, -1, -1}, {21089, -1, -1, -1}, {21084, -1, -1, -1}, {33967, -1, -1, -1}, {21117, -1, -1, -1}, {21122, -1, -1, -1}, {21121, -1, -1, -1}, {21136, -1, -1, -1}, {21139, -1, -1, -1}, {12044, 20866, -1, -1}, {32596, -1, -1, -1}, {20155, -1, -1, -1}, {20163, -1, -1, -1}, {20169, -1, -1, -1}, {20162, -1, -1, -1}, {20200, -1, -1, -1}, {20193, -1, -1, -1}, {20203, -1, -1, -1}, {20190, -1, -1, -1}, {20251, -1, -1, -1}, {20211, -1, -1, -1}, {20258, -1, -1, -1}, {20324, -1, -1, -1}, {20213, -1, -1, -1}, {20261, -1, -1, -1}, {20263, -1, -1, -1}, {20233, -1, -1, -1}, {20267, -1, -1, -1}, {20318, -1, -1, -1}, {20327, -1, -1, -1}, {25912, -1, -1, -1}, {20314, -1, -1, -1}, {20317, -1, -1, -1}, {20319, -1, -1, -1}, {20311, -1, -1, -1}, {20274, -1, -1, -1}, {20285, -1, -1, -1}, {20342, -1, -1, -1}, {20340, -1, -1, -1}, {20369, -1, -1, -1}, {20361, -1, -1, -1}, {20355, -1, -1, -1}, {20367, -1, -1, -1}, {20350, -1, -1, -1}, {20347, -1, -1, -1}, {20394, -1, -1, -1}, {20348, -1, -1, -1}, {20396, -1, -1, -1}, {20372, -1, -1, -1}, {20454, -1, -1, -1}, {20456, -1, -1, -1}, {20458, -1, -1, -1}, {20421, -1, -1, -1}, {20442, -1, -1, -1}, {20451, -1, -1, -1}, {20444, -1, -1, -1}, {20433, -1, -1, -1}, {20447, -1, -1, -1}, {20472, -1, -1, -1}, {20521, -1, -1, -1}, {20556, -1, -1, -1}, {20467, -1, -1, -1}, {20524, -1, -1, -1}, {20495, -1, -1, -1}, {20526, -1, -1, -1}, {20525, -1, -1, -1}, {20478, -1, -1, -1}, {20508, -1, -1, -1}, {20492, -1, -1, -1}, {20517, -1, -1, -1}, {20520, -1, -1, -1}, {20606, -1, -1, -1}, {20547, -1, -1, -1}, {20565, -1, -1, -1}, {20552, -1, -1, -1}, {20558, -1, -1, -1}, {20588, -1, -1, -1}, {20603, -1, -1, -1}, {20645, -1, -1, -1}, {20647, -1, -1, -1}, {20649, -1, -1, -1}, {20666, -1, -1, -1}, {20694, -1, -1, -1}, {20742, -1, -1, -1}, {20717, -1, -1, -1}, {20716, -1, -1, -1}, {20710, -1, -1, -1}, {20718, -1, -1, -1}, {20743, -1, -1, -1}, {20747, -1, -1, -1}, {20189, -1, -1, -1}, {27709, -1, -1, -1}, {20312, -1, -1, -1}, {20325, -1, -1, -1}, {20430, -1, -1, -1}, {12245, 40864, -1, -1}, {27718, -1, -1, -1}, {31860, -1, -1, -1}, {20846, -1, -1, -1}, {24061, -1, -1, -1}, {40649, -1, -1, -1}, {39320, -1, -1, -1}, {20865, -1, -1, -1}, {22804, -1, -1, -1}, {12051, 21241, -1, -1}, {21261, -1, -1, -1}, {35335, -1, -1, -1}, {21264, -1, -1, -1} },
+ {{20971, -1, -1, -1}, {22809, -1, -1, -1}, {20821, -1, -1, -1}, {12039, 20128, -1, -1}, {20822, -1, -1, -1}, {20147, -1, -1, -1}, {34926, -1, -1, -1}, {34980, -1, -1, -1}, {20149, -1, -1, -1}, {33044, -1, -1, -1}, {35026, -1, -1, -1}, {31104, -1, -1, -1}, {23348, -1, -1, -1}, {34819, -1, -1, -1}, {32696, -1, -1, -1}, {12046, 20907, -1, -1}, {20913, -1, -1, -1}, {20925, -1, -1, -1}, {20924, -1, -1, -1}, {20935, -1, -1, -1}, {12045, 20886, -1, -1}, {20898, -1, -1, -1}, {20901, -1, -1, -1}, {35744, -1, -1, -1}, {35750, -1, -1, -1}, {35751, -1, -1, -1}, {35754, -1, -1, -1}, {35764, -1, -1, -1}, {35765, -1, -1, -1}, {35767, -1, -1, -1}, {35778, -1, -1, -1}, {35779, -1, -1, -1}, {35787, -1, -1, -1}, {35791, -1, -1, -1}, {35790, -1, -1, -1}, {35794, -1, -1, -1}, {35795, -1, -1, -1}, {35796, -1, -1, -1}, {35798, -1, -1, -1}, {35800, -1, -1, -1}, {35801, -1, -1, -1}, {35804, -1, -1, -1}, {35807, -1, -1, -1}, {35808, -1, -1, -1}, {35812, -1, -1, -1}, {35816, -1, -1, -1}, {35817, -1, -1, -1}, {35822, -1, -1, -1}, {35824, -1, -1, -1}, {35827, -1, -1, -1}, {35830, -1, -1, -1}, {35833, -1, -1, -1}, {35836, -1, -1, -1}, {35839, -1, -1, -1}, {35840, -1, -1, -1}, {35842, -1, -1, -1}, {35844, -1, -1, -1}, {35847, -1, -1, -1}, {35852, -1, -1, -1}, {35855, -1, -1, -1}, {35857, -1, -1, -1}, {35858, -1, -1, -1}, {35860, -1, -1, -1}, {35861, -1, -1, -1}, {35862, -1, -1, -1}, {35865, -1, -1, -1}, {35867, -1, -1, -1}, {35864, -1, -1, -1}, {35869, -1, -1, -1}, {35871, -1, -1, -1}, {35872, -1, -1, -1}, {35873, -1, -1, -1}, {35877, -1, -1, -1}, {35879, -1, -1, -1}, {35882, -1, -1, -1}, {35883, -1, -1, -1}, {35886, -1, -1, -1}, {35887, -1, -1, -1}, {35890, -1, -1, -1}, {35891, -1, -1, -1}, {35893, -1, -1, -1}, {35894, -1, -1, -1}, {12057, 21353, -1, -1}, {21370, -1, -1, -1}, {38429, -1, -1, -1}, {38434, -1, -1, -1}, {38433, -1, -1, -1}, {38449, -1, -1, -1}, {38442, -1, -1, -1}, {38461, -1, -1, -1}, {38460, -1, -1, -1}, {38466, -1, -1, -1}, {38473, -1, -1, -1}, {38484, -1, -1, -1}, {38495, -1, -1, -1}, {38503, -1, -1, -1}, {38508, -1, -1, -1}, {38514, -1, -1, -1}, {38516, -1, -1, -1}, {38536, -1, -1, -1}, {38541, -1, -1, -1}, {38551, -1, -1, -1}, {38576, -1, -1, -1}, {37015, -1, -1, -1}, {37019, -1, -1, -1}, {37021, -1, -1, -1}, {37017, -1, -1, -1}, {37036, -1, -1, -1}, {37025, -1, -1, -1}, {37044, -1, -1, -1}, {37043, -1, -1, -1}, {37046, -1, -1, -1}, {37050, -1, -1, -1}, {37048, -1, -1, -1}, {37040, -1, -1, -1}, {37071, -1, -1, -1}, {37061, -1, -1, -1}, {37054, -1, -1, -1}, {37072, -1, -1, -1}, {37060, -1, -1, -1}, {37063, -1, -1, -1}, {37075, -1, -1, -1}, {37094, -1, -1, -1}, {37090, -1, -1, -1}, {37084, -1, -1, -1}, {37079, -1, -1, -1}, {37083, -1, -1, -1}, {37099, -1, -1, -1}, {37103, -1, -1, -1}, {37118, -1, -1, -1}, {37124, -1, -1, -1}, {37154, -1, -1, -1}, {37150, -1, -1, -1}, {37155, -1, -1, -1}, {37169, -1, -1, -1}, {37167, -1, -1, -1}, {37177, -1, -1, -1}, {37187, -1, -1, -1}, {37190, -1, -1, -1}, {21005, -1, -1, -1}, {22850, -1, -1, -1}, {21154, -1, -1, -1}, {21164, -1, -1, -1}, {21165, -1, -1, -1}, {21182, -1, -1, -1}, {21759, -1, -1, -1}, {21200, -1, -1, -1}, {21206, -1, -1, -1}, {21232, -1, -1, -1}, {21471, -1, -1, -1}, {29166, -1, -1, -1}, {30669, -1, -1, -1}, {12085, 24308, -1, -1}, {12048, 20981, -1, -1}, {20988, -1, -1, -1}, {12223, 39727, -1, -1}, {12059, 21430, -1, -1}, {24321, -1, -1, -1}, {30042, -1, -1, -1}, {24047, -1, -1, -1}, {22348, -1, -1, -1}, {22441, -1, -1, -1}, {22433, -1, -1, -1}, {22654, -1, -1, -1}, {22716, -1, -1, -1}, {22725, -1, -1, -1}, {22737, -1, -1, -1}, {22313, -1, -1, -1}, {22316, -1, -1, -1}, {22314, -1, -1, -1}, {22323, -1, -1, -1}, {22329, -1, -1, -1}, {22318, -1, -1, -1}, {22319, -1, -1, -1}, {22364, -1, -1, -1}, {22331, -1, -1, -1}, {22338, -1, -1, -1}, {22377, -1, -1, -1}, {22405, -1, -1, -1}, {22379, -1, -1, -1}, {22406, -1, -1, -1}, {22396, -1, -1, -1}, {22395, -1, -1, -1}, {22376, -1, -1, -1}, {22381, -1, -1, -1}, {22390, -1, -1, -1}, {22387, -1, -1, -1}, {22445, -1, -1, -1}, {22436, -1, -1, -1}, {22412, -1, -1, -1}, {22450, -1, -1, -1}, {22479, -1, -1, -1}, {22439, -1, -1, -1}, {22452, -1, -1, -1}, {22419, -1, -1, -1}, {22432, -1, -1, -1}, {22485, -1, -1, -1}, {22488, -1, -1, -1}, {22490, -1, -1, -1}, {22489, -1, -1, -1}, {22482, -1, -1, -1}, {22456, -1, -1, -1}, {22516, -1, -1, -1}, {22511, -1, -1, -1}, {22520, -1, -1, -1}, {22500, -1, -1, -1}, {22493, -1, -1, -1}, {22539, -1, -1, -1}, {22541, -1, -1, -1}, {22525, -1, -1, -1}, {22509, -1, -1, -1}, {22528, -1, -1, -1}, {22558, -1, -1, -1}, {22553, -1, -1, -1}, {22596, -1, -1, -1}, {22560, -1, -1, -1}, {22629, -1, -1, -1}, {22636, -1, -1, -1}, {22657, -1, -1, -1}, {22665, -1, -1, -1}, {22682, -1, -1, -1}, {22656, -1, -1, -1}, {39336, -1, -1, -1}, {40729, -1, -1, -1}, {25087, -1, -1, -1}, {33401, -1, -1, -1}, {33405, -1, -1, -1}, {33407, -1, -1, -1}, {33423, -1, -1, -1}, {33418, -1, -1, -1}, {33448, -1, -1, -1}, {33412, -1, -1, -1}, {33422, -1, -1, -1}, {33425, -1, -1, -1}, {33431, -1, -1, -1}, {33433, -1, -1, -1}, {33451, -1, -1, -1}, {33464, -1, -1, -1}, {33470, -1, -1, -1}, {33456, -1, -1, -1}, {33480, -1, -1, -1}, {33482, -1, -1, -1}, {33507, -1, -1, -1}, {33432, -1, -1, -1}, {33463, -1, -1, -1}, {33454, -1, -1, -1}, {33483, -1, -1, -1}, {33484, -1, -1, -1}, {33473, -1, -1, -1}, {33449, -1, -1, -1}, {33460, -1, -1, -1}, {33441, -1, -1, -1}, {33450, -1, -1, -1}, {33439, -1, -1, -1}, {33476, -1, -1, -1}, {33486, -1, -1, -1} },
+ {{33444, -1, -1, -1}, {33505, -1, -1, -1}, {33545, -1, -1, -1}, {33527, -1, -1, -1}, {33508, -1, -1, -1}, {33551, -1, -1, -1}, {33543, -1, -1, -1}, {33500, -1, -1, -1}, {33524, -1, -1, -1}, {33490, -1, -1, -1}, {33496, -1, -1, -1}, {33548, -1, -1, -1}, {33531, -1, -1, -1}, {33491, -1, -1, -1}, {33553, -1, -1, -1}, {33562, -1, -1, -1}, {33542, -1, -1, -1}, {33556, -1, -1, -1}, {33557, -1, -1, -1}, {33504, -1, -1, -1}, {33493, -1, -1, -1}, {33564, -1, -1, -1}, {33617, -1, -1, -1}, {33627, -1, -1, -1}, {33628, -1, -1, -1}, {33544, -1, -1, -1}, {33682, -1, -1, -1}, {33596, -1, -1, -1}, {33588, -1, -1, -1}, {33585, -1, -1, -1}, {33691, -1, -1, -1}, {33630, -1, -1, -1}, {33583, -1, -1, -1}, {33615, -1, -1, -1}, {33607, -1, -1, -1}, {33603, -1, -1, -1}, {33631, -1, -1, -1}, {33600, -1, -1, -1}, {33559, -1, -1, -1}, {33632, -1, -1, -1}, {33581, -1, -1, -1}, {33594, -1, -1, -1}, {33587, -1, -1, -1}, {33638, -1, -1, -1}, {33637, -1, -1, -1}, {33640, -1, -1, -1}, {33563, -1, -1, -1}, {33641, -1, -1, -1}, {33644, -1, -1, -1}, {33642, -1, -1, -1}, {33645, -1, -1, -1}, {33646, -1, -1, -1}, {33712, -1, -1, -1}, {33656, -1, -1, -1}, {33715, -1, -1, -1}, {33716, -1, -1, -1}, {33696, -1, -1, -1}, {33706, -1, -1, -1}, {33683, -1, -1, -1}, {33692, -1, -1, -1}, {33669, -1, -1, -1}, {33660, -1, -1, -1}, {33718, -1, -1, -1}, {33705, -1, -1, -1}, {33661, -1, -1, -1}, {33720, -1, -1, -1}, {33659, -1, -1, -1}, {33688, -1, -1, -1}, {33694, -1, -1, -1}, {33704, -1, -1, -1}, {33722, -1, -1, -1}, {33724, -1, -1, -1}, {33729, -1, -1, -1}, {33793, -1, -1, -1}, {33765, -1, -1, -1}, {33752, -1, -1, -1}, {22535, -1, -1, -1}, {33816, -1, -1, -1}, {33803, -1, -1, -1}, {33757, -1, -1, -1}, {33789, -1, -1, -1}, {33750, -1, -1, -1}, {33820, -1, -1, -1}, {33848, -1, -1, -1}, {33809, -1, -1, -1}, {33798, -1, -1, -1}, {33748, -1, -1, -1}, {33759, -1, -1, -1}, {33807, -1, -1, -1}, {33795, -1, -1, -1}, {33784, -1, -1, -1}, {33785, -1, -1, -1}, {33770, -1, -1, -1}, {33733, -1, -1, -1}, {33728, -1, -1, -1}, {33830, -1, -1, -1}, {33776, -1, -1, -1}, {33761, -1, -1, -1}, {33884, -1, -1, -1}, {33873, -1, -1, -1}, {33882, -1, -1, -1}, {33881, -1, -1, -1}, {33907, -1, -1, -1}, {33927, -1, -1, -1}, {33928, -1, -1, -1}, {33914, -1, -1, -1}, {33929, -1, -1, -1}, {33912, -1, -1, -1}, {33852, -1, -1, -1}, {33862, -1, -1, -1}, {33897, -1, -1, -1}, {33910, -1, -1, -1}, {33932, -1, -1, -1}, {33934, -1, -1, -1}, {33841, -1, -1, -1}, {33901, -1, -1, -1}, {33985, -1, -1, -1}, {33997, -1, -1, -1}, {34000, -1, -1, -1}, {34022, -1, -1, -1}, {33981, -1, -1, -1}, {34003, -1, -1, -1}, {33994, -1, -1, -1}, {33983, -1, -1, -1}, {33978, -1, -1, -1}, {34016, -1, -1, -1}, {33953, -1, -1, -1}, {33977, -1, -1, -1}, {33972, -1, -1, -1}, {33943, -1, -1, -1}, {34021, -1, -1, -1}, {34019, -1, -1, -1}, {34060, -1, -1, -1}, {29965, -1, -1, -1}, {34104, -1, -1, -1}, {34032, -1, -1, -1}, {34105, -1, -1, -1}, {34079, -1, -1, -1}, {34106, -1, -1, -1}, {34134, -1, -1, -1}, {34107, -1, -1, -1}, {34047, -1, -1, -1}, {34044, -1, -1, -1}, {34137, -1, -1, -1}, {34120, -1, -1, -1}, {34152, -1, -1, -1}, {34148, -1, -1, -1}, {34142, -1, -1, -1}, {34170, -1, -1, -1}, {30626, -1, -1, -1}, {34115, -1, -1, -1}, {34162, -1, -1, -1}, {34171, -1, -1, -1}, {34212, -1, -1, -1}, {34216, -1, -1, -1}, {34183, -1, -1, -1}, {34191, -1, -1, -1}, {34169, -1, -1, -1}, {34222, -1, -1, -1}, {34204, -1, -1, -1}, {34181, -1, -1, -1}, {34233, -1, -1, -1}, {34231, -1, -1, -1}, {34224, -1, -1, -1}, {34259, -1, -1, -1}, {34241, -1, -1, -1}, {34268, -1, -1, -1}, {34303, -1, -1, -1}, {34343, -1, -1, -1}, {34309, -1, -1, -1}, {34345, -1, -1, -1}, {34326, -1, -1, -1}, {34364, -1, -1, -1}, {12086, 24318, -1, -1}, {24328, -1, -1, -1}, {22844, -1, -1, -1}, {22849, -1, -1, -1}, {32823, -1, -1, -1}, {22869, -1, -1, -1}, {22874, -1, -1, -1}, {22872, -1, -1, -1}, {21263, -1, -1, -1}, {12074, 23586, -1, -1}, {23589, -1, -1, -1}, {23596, -1, -1, -1}, {23604, -1, -1, -1}, {25164, -1, -1, -1}, {25194, -1, -1, -1}, {25247, -1, -1, -1}, {25275, -1, -1, -1}, {25290, -1, -1, -1}, {25306, -1, -1, -1}, {25303, -1, -1, -1}, {25326, -1, -1, -1}, {25378, -1, -1, -1}, {25334, -1, -1, -1}, {25401, -1, -1, -1}, {25419, -1, -1, -1}, {25411, -1, -1, -1}, {25517, -1, -1, -1}, {25590, -1, -1, -1}, {25457, -1, -1, -1}, {25466, -1, -1, -1}, {25486, -1, -1, -1}, {25524, -1, -1, -1}, {25453, -1, -1, -1}, {25516, -1, -1, -1}, {25482, -1, -1, -1}, {25449, -1, -1, -1}, {25518, -1, -1, -1}, {25532, -1, -1, -1}, {25586, -1, -1, -1}, {25592, -1, -1, -1}, {25568, -1, -1, -1}, {25599, -1, -1, -1}, {25540, -1, -1, -1}, {25566, -1, -1, -1}, {25550, -1, -1, -1}, {25682, -1, -1, -1}, {25542, -1, -1, -1}, {25534, -1, -1, -1}, {25669, -1, -1, -1}, {25665, -1, -1, -1}, {25611, -1, -1, -1}, {25627, -1, -1, -1}, {25632, -1, -1, -1}, {25612, -1, -1, -1}, {25638, -1, -1, -1}, {25633, -1, -1, -1}, {25694, -1, -1, -1}, {25732, -1, -1, -1}, {25709, -1, -1, -1}, {25750, -1, -1, -1}, {25722, -1, -1, -1}, {25783, -1, -1, -1}, {25784, -1, -1, -1}, {25753, -1, -1, -1}, {25786, -1, -1, -1}, {25792, -1, -1, -1}, {25808, -1, -1, -1}, {25815, -1, -1, -1}, {25828, -1, -1, -1}, {25826, -1, -1, -1}, {25865, -1, -1, -1}, {25893, -1, -1, -1}, {25902, -1, -1, -1}, {12087, 24331, -1, -1}, {24530, -1, -1, -1}, {29977, -1, -1, -1}, {24337, -1, -1, -1}, {21343, -1, -1, -1}, {21489, -1, -1, -1}, {21501, -1, -1, -1}, {21481, -1, -1, -1}, {21480, -1, -1, -1}, {21499, -1, -1, -1} },
+ {{21522, -1, -1, -1}, {21526, -1, -1, -1}, {21510, -1, -1, -1}, {21579, -1, -1, -1}, {21586, -1, -1, -1}, {21587, -1, -1, -1}, {21588, -1, -1, -1}, {21590, -1, -1, -1}, {21571, -1, -1, -1}, {21537, -1, -1, -1}, {21591, -1, -1, -1}, {21593, -1, -1, -1}, {21539, -1, -1, -1}, {21554, -1, -1, -1}, {21634, -1, -1, -1}, {21652, -1, -1, -1}, {21623, -1, -1, -1}, {21617, -1, -1, -1}, {21604, -1, -1, -1}, {21658, -1, -1, -1}, {21659, -1, -1, -1}, {21636, -1, -1, -1}, {21622, -1, -1, -1}, {21606, -1, -1, -1}, {21661, -1, -1, -1}, {21712, -1, -1, -1}, {21677, -1, -1, -1}, {21698, -1, -1, -1}, {21684, -1, -1, -1}, {21714, -1, -1, -1}, {21671, -1, -1, -1}, {21670, -1, -1, -1}, {21715, -1, -1, -1}, {21716, -1, -1, -1}, {21618, -1, -1, -1}, {21667, -1, -1, -1}, {21717, -1, -1, -1}, {21691, -1, -1, -1}, {21695, -1, -1, -1}, {21708, -1, -1, -1}, {21721, -1, -1, -1}, {21722, -1, -1, -1}, {21724, -1, -1, -1}, {21673, -1, -1, -1}, {21674, -1, -1, -1}, {21668, -1, -1, -1}, {21725, -1, -1, -1}, {21711, -1, -1, -1}, {21726, -1, -1, -1}, {21787, -1, -1, -1}, {21735, -1, -1, -1}, {21792, -1, -1, -1}, {21757, -1, -1, -1}, {21780, -1, -1, -1}, {21747, -1, -1, -1}, {21794, -1, -1, -1}, {21795, -1, -1, -1}, {21775, -1, -1, -1}, {21777, -1, -1, -1}, {21799, -1, -1, -1}, {21802, -1, -1, -1}, {21863, -1, -1, -1}, {21903, -1, -1, -1}, {21941, -1, -1, -1}, {21833, -1, -1, -1}, {21869, -1, -1, -1}, {21825, -1, -1, -1}, {21845, -1, -1, -1}, {21823, -1, -1, -1}, {21840, -1, -1, -1}, {21820, -1, -1, -1}, {21815, -1, -1, -1}, {21846, -1, -1, -1}, {21877, -1, -1, -1}, {21878, -1, -1, -1}, {21879, -1, -1, -1}, {21811, -1, -1, -1}, {21808, -1, -1, -1}, {21852, -1, -1, -1}, {21899, -1, -1, -1}, {21970, -1, -1, -1}, {21891, -1, -1, -1}, {21937, -1, -1, -1}, {21945, -1, -1, -1}, {21896, -1, -1, -1}, {21889, -1, -1, -1}, {21919, -1, -1, -1}, {21886, -1, -1, -1}, {21974, -1, -1, -1}, {21905, -1, -1, -1}, {21883, -1, -1, -1}, {21983, -1, -1, -1}, {21949, -1, -1, -1}, {21950, -1, -1, -1}, {21908, -1, -1, -1}, {21913, -1, -1, -1}, {21994, -1, -1, -1}, {22007, -1, -1, -1}, {21961, -1, -1, -1}, {22047, -1, -1, -1}, {21969, -1, -1, -1}, {21995, -1, -1, -1}, {21996, -1, -1, -1}, {21972, -1, -1, -1}, {21990, -1, -1, -1}, {21981, -1, -1, -1}, {21956, -1, -1, -1}, {21999, -1, -1, -1}, {21989, -1, -1, -1}, {22002, -1, -1, -1}, {22003, -1, -1, -1}, {21964, -1, -1, -1}, {21965, -1, -1, -1}, {21992, -1, -1, -1}, {22005, -1, -1, -1}, {21988, -1, -1, -1}, {36756, -1, -1, -1}, {22046, -1, -1, -1}, {22024, -1, -1, -1}, {22028, -1, -1, -1}, {22017, -1, -1, -1}, {22052, -1, -1, -1}, {22051, -1, -1, -1}, {22014, -1, -1, -1}, {22016, -1, -1, -1}, {22055, -1, -1, -1}, {22061, -1, -1, -1}, {22104, -1, -1, -1}, {22073, -1, -1, -1}, {22103, -1, -1, -1}, {22060, -1, -1, -1}, {22093, -1, -1, -1}, {22114, -1, -1, -1}, {22105, -1, -1, -1}, {22108, -1, -1, -1}, {22092, -1, -1, -1}, {22100, -1, -1, -1}, {22150, -1, -1, -1}, {22116, -1, -1, -1}, {22129, -1, -1, -1}, {22123, -1, -1, -1}, {22139, -1, -1, -1}, {22140, -1, -1, -1}, {22149, -1, -1, -1}, {22163, -1, -1, -1}, {22191, -1, -1, -1}, {22228, -1, -1, -1}, {12062, 22231, -1, -1}, {22237, -1, -1, -1}, {22241, -1, -1, -1}, {22261, -1, -1, -1}, {22251, -1, -1, -1}, {22265, -1, -1, -1}, {22271, -1, -1, -1}, {22276, -1, -1, -1}, {22282, -1, -1, -1}, {22281, -1, -1, -1}, {22300, -1, -1, -1}, {24079, -1, -1, -1}, {24089, -1, -1, -1}, {24084, -1, -1, -1}, {24081, -1, -1, -1}, {24113, -1, -1, -1}, {24123, -1, -1, -1}, {24124, -1, -1, -1}, {24119, -1, -1, -1}, {24132, -1, -1, -1}, {24148, -1, -1, -1}, {24155, -1, -1, -1}, {24158, -1, -1, -1}, {24161, -1, -1, -1}, {23692, -1, -1, -1}, {23674, -1, -1, -1}, {23693, -1, -1, -1}, {23696, -1, -1, -1}, {23702, -1, -1, -1}, {23688, -1, -1, -1}, {23704, -1, -1, -1}, {23705, -1, -1, -1}, {23697, -1, -1, -1}, {23706, -1, -1, -1}, {23708, -1, -1, -1}, {23733, -1, -1, -1}, {23714, -1, -1, -1}, {23741, -1, -1, -1}, {23724, -1, -1, -1}, {23723, -1, -1, -1}, {23729, -1, -1, -1}, {23715, -1, -1, -1}, {23745, -1, -1, -1}, {23735, -1, -1, -1}, {23748, -1, -1, -1}, {23762, -1, -1, -1}, {23780, -1, -1, -1}, {23755, -1, -1, -1}, {23781, -1, -1, -1}, {23810, -1, -1, -1}, {23811, -1, -1, -1}, {23847, -1, -1, -1}, {23846, -1, -1, -1}, {23854, -1, -1, -1}, {23844, -1, -1, -1}, {23838, -1, -1, -1}, {23814, -1, -1, -1}, {23835, -1, -1, -1}, {23896, -1, -1, -1}, {23870, -1, -1, -1}, {23860, -1, -1, -1}, {23869, -1, -1, -1}, {23916, -1, -1, -1}, {23899, -1, -1, -1}, {23919, -1, -1, -1}, {23901, -1, -1, -1}, {23915, -1, -1, -1}, {23883, -1, -1, -1}, {23882, -1, -1, -1}, {23913, -1, -1, -1}, {23924, -1, -1, -1}, {23938, -1, -1, -1}, {23961, -1, -1, -1}, {23965, -1, -1, -1}, {35955, -1, -1, -1}, {23991, -1, -1, -1}, {24005, -1, -1, -1}, {12091, 24435, -1, -1}, {24439, -1, -1, -1}, {24450, -1, -1, -1}, {24455, -1, -1, -1}, {24457, -1, -1, -1}, {24460, -1, -1, -1}, {24469, -1, -1, -1}, {24473, -1, -1, -1}, {24476, -1, -1, -1}, {24488, -1, -1, -1}, {24493, -1, -1, -1}, {24501, -1, -1, -1}, {24508, -1, -1, -1}, {34914, -1, -1, -1}, {12090, 24417, -1, -1}, {29357, -1, -1, -1}, {29360, -1, -1, -1}, {29364, -1, -1, -1}, {29367, -1, -1, -1}, {29368, -1, -1, -1}, {29379, -1, -1, -1}, {29377, -1, -1, -1}, {29390, -1, -1, -1}, {29389, -1, -1, -1}, {29394, -1, -1, -1}, {29416, -1, -1, -1}, {29423, -1, -1, -1}, {29417, -1, -1, -1}, {29426, -1, -1, -1}, {29428, -1, -1, -1}, {29431, -1, -1, -1}, {29441, -1, -1, -1} },
+ {{29427, -1, -1, -1}, {29443, -1, -1, -1}, {29434, -1, -1, -1}, {29435, -1, -1, -1}, {29463, -1, -1, -1}, {29459, -1, -1, -1}, {29473, -1, -1, -1}, {29450, -1, -1, -1}, {29470, -1, -1, -1}, {29469, -1, -1, -1}, {29461, -1, -1, -1}, {29474, -1, -1, -1}, {29497, -1, -1, -1}, {29477, -1, -1, -1}, {29484, -1, -1, -1}, {29496, -1, -1, -1}, {29489, -1, -1, -1}, {29520, -1, -1, -1}, {29517, -1, -1, -1}, {29527, -1, -1, -1}, {29536, -1, -1, -1}, {29548, -1, -1, -1}, {29551, -1, -1, -1}, {29566, -1, -1, -1}, {12167, 33307, -1, -1}, {22821, -1, -1, -1}, {39143, -1, -1, -1}, {22820, -1, -1, -1}, {12065, 22786, -1, -1}, {39267, -1, -1, -1}, {39271, -1, -1, -1}, {39272, -1, -1, -1}, {39273, -1, -1, -1}, {39274, -1, -1, -1}, {39275, -1, -1, -1}, {39276, -1, -1, -1}, {39284, -1, -1, -1}, {39287, -1, -1, -1}, {39293, -1, -1, -1}, {39296, -1, -1, -1}, {39300, -1, -1, -1}, {39303, -1, -1, -1}, {39306, -1, -1, -1}, {39309, -1, -1, -1}, {39312, -1, -1, -1}, {39313, -1, -1, -1}, {39315, -1, -1, -1}, {39316, -1, -1, -1}, {39317, -1, -1, -1}, {24192, -1, -1, -1}, {24209, -1, -1, -1}, {24203, -1, -1, -1}, {24214, -1, -1, -1}, {24229, -1, -1, -1}, {24224, -1, -1, -1}, {24249, -1, -1, -1}, {24245, -1, -1, -1}, {24254, -1, -1, -1}, {24243, -1, -1, -1}, {36179, -1, -1, -1}, {24274, -1, -1, -1}, {24273, -1, -1, -1}, {24283, -1, -1, -1}, {24296, -1, -1, -1}, {24298, -1, -1, -1}, {33210, -1, -1, -1}, {24516, -1, -1, -1}, {24521, -1, -1, -1}, {24534, -1, -1, -1}, {24527, -1, -1, -1}, {24579, -1, -1, -1}, {24558, -1, -1, -1}, {24580, -1, -1, -1}, {24545, -1, -1, -1}, {24548, -1, -1, -1}, {24574, -1, -1, -1}, {24581, -1, -1, -1}, {24582, -1, -1, -1}, {24554, -1, -1, -1}, {24557, -1, -1, -1}, {24568, -1, -1, -1}, {24601, -1, -1, -1}, {24629, -1, -1, -1}, {24614, -1, -1, -1}, {24603, -1, -1, -1}, {24591, -1, -1, -1}, {24589, -1, -1, -1}, {24617, -1, -1, -1}, {24619, -1, -1, -1}, {24586, -1, -1, -1}, {24639, -1, -1, -1}, {24609, -1, -1, -1}, {24696, -1, -1, -1}, {24697, -1, -1, -1}, {24699, -1, -1, -1}, {24698, -1, -1, -1}, {24642, -1, -1, -1}, {24682, -1, -1, -1}, {24701, -1, -1, -1}, {24726, -1, -1, -1}, {24730, -1, -1, -1}, {24749, -1, -1, -1}, {24733, -1, -1, -1}, {24707, -1, -1, -1}, {24722, -1, -1, -1}, {24716, -1, -1, -1}, {24731, -1, -1, -1}, {24812, -1, -1, -1}, {24763, -1, -1, -1}, {24753, -1, -1, -1}, {24797, -1, -1, -1}, {24792, -1, -1, -1}, {24774, -1, -1, -1}, {24794, -1, -1, -1}, {24756, -1, -1, -1}, {24864, -1, -1, -1}, {24870, -1, -1, -1}, {24853, -1, -1, -1}, {24867, -1, -1, -1}, {24820, -1, -1, -1}, {24832, -1, -1, -1}, {24846, -1, -1, -1}, {24875, -1, -1, -1}, {24906, -1, -1, -1}, {24949, -1, -1, -1}, {25004, -1, -1, -1}, {24980, -1, -1, -1}, {24999, -1, -1, -1}, {25015, -1, -1, -1}, {25044, -1, -1, -1}, {25077, -1, -1, -1}, {24541, -1, -1, -1}, {38579, -1, -1, -1}, {38377, -1, -1, -1}, {38379, -1, -1, -1}, {38385, -1, -1, -1}, {38387, -1, -1, -1}, {38389, -1, -1, -1}, {38390, -1, -1, -1}, {38396, -1, -1, -1}, {38398, -1, -1, -1}, {38403, -1, -1, -1}, {38404, -1, -1, -1}, {38406, -1, -1, -1}, {38408, -1, -1, -1}, {38410, -1, -1, -1}, {38411, -1, -1, -1}, {38412, -1, -1, -1}, {38413, -1, -1, -1}, {38415, -1, -1, -1}, {38418, -1, -1, -1}, {38421, -1, -1, -1}, {38422, -1, -1, -1}, {38423, -1, -1, -1}, {38425, -1, -1, -1}, {38426, -1, -1, -1}, {20012, -1, -1, -1}, {12121, 29247, -1, -1}, {25109, -1, -1, -1}, {27701, -1, -1, -1}, {27732, -1, -1, -1}, {27740, -1, -1, -1}, {27722, -1, -1, -1}, {27811, -1, -1, -1}, {27781, -1, -1, -1}, {27792, -1, -1, -1}, {27796, -1, -1, -1}, {27788, -1, -1, -1}, {27752, -1, -1, -1}, {27753, -1, -1, -1}, {27764, -1, -1, -1}, {27766, -1, -1, -1}, {27782, -1, -1, -1}, {27817, -1, -1, -1}, {27856, -1, -1, -1}, {27860, -1, -1, -1}, {27821, -1, -1, -1}, {27895, -1, -1, -1}, {27896, -1, -1, -1}, {27889, -1, -1, -1}, {27863, -1, -1, -1}, {27826, -1, -1, -1}, {27872, -1, -1, -1}, {27862, -1, -1, -1}, {27898, -1, -1, -1}, {27883, -1, -1, -1}, {27886, -1, -1, -1}, {27825, -1, -1, -1}, {27859, -1, -1, -1}, {27887, -1, -1, -1}, {27902, -1, -1, -1}, {27961, -1, -1, -1}, {27943, -1, -1, -1}, {27916, -1, -1, -1}, {27971, -1, -1, -1}, {27976, -1, -1, -1}, {27911, -1, -1, -1}, {27908, -1, -1, -1}, {27929, -1, -1, -1}, {27918, -1, -1, -1}, {27947, -1, -1, -1}, {27981, -1, -1, -1}, {27950, -1, -1, -1}, {27957, -1, -1, -1}, {27930, -1, -1, -1}, {27983, -1, -1, -1}, {27986, -1, -1, -1}, {27988, -1, -1, -1}, {27955, -1, -1, -1}, {28049, -1, -1, -1}, {28015, -1, -1, -1}, {28062, -1, -1, -1}, {28064, -1, -1, -1}, {27998, -1, -1, -1}, {28051, -1, -1, -1}, {28052, -1, -1, -1}, {27996, -1, -1, -1}, {28000, -1, -1, -1}, {28028, -1, -1, -1}, {28003, -1, -1, -1}, {28186, -1, -1, -1}, {28103, -1, -1, -1}, {28101, -1, -1, -1}, {28126, -1, -1, -1}, {28174, -1, -1, -1}, {28095, -1, -1, -1}, {28128, -1, -1, -1}, {28177, -1, -1, -1}, {28134, -1, -1, -1}, {28125, -1, -1, -1}, {28121, -1, -1, -1}, {28182, -1, -1, -1}, {28075, -1, -1, -1}, {28172, -1, -1, -1}, {28078, -1, -1, -1}, {28203, -1, -1, -1}, {28270, -1, -1, -1}, {28238, -1, -1, -1}, {28267, -1, -1, -1}, {28338, -1, -1, -1}, {28255, -1, -1, -1}, {28294, -1, -1, -1}, {28243, -1, -1, -1}, {28244, -1, -1, -1}, {28210, -1, -1, -1}, {28197, -1, -1, -1}, {28228, -1, -1, -1}, {28383, -1, -1, -1}, {28337, -1, -1, -1}, {28312, -1, -1, -1}, {28384, -1, -1, -1}, {28461, -1, -1, -1}, {28386, -1, -1, -1}, {28325, -1, -1, -1}, {28327, -1, -1, -1}, {28349, -1, -1, -1} },
+ {{28347, -1, -1, -1}, {28343, -1, -1, -1}, {28375, -1, -1, -1}, {28340, -1, -1, -1}, {28367, -1, -1, -1}, {28303, -1, -1, -1}, {28354, -1, -1, -1}, {28319, -1, -1, -1}, {28514, -1, -1, -1}, {28486, -1, -1, -1}, {28487, -1, -1, -1}, {28452, -1, -1, -1}, {28437, -1, -1, -1}, {28409, -1, -1, -1}, {28463, -1, -1, -1}, {28470, -1, -1, -1}, {28491, -1, -1, -1}, {28532, -1, -1, -1}, {28458, -1, -1, -1}, {28425, -1, -1, -1}, {28457, -1, -1, -1}, {28553, -1, -1, -1}, {28557, -1, -1, -1}, {28556, -1, -1, -1}, {28536, -1, -1, -1}, {28530, -1, -1, -1}, {28540, -1, -1, -1}, {28538, -1, -1, -1}, {28625, -1, -1, -1}, {28617, -1, -1, -1}, {28583, -1, -1, -1}, {28601, -1, -1, -1}, {28598, -1, -1, -1}, {28610, -1, -1, -1}, {28641, -1, -1, -1}, {28654, -1, -1, -1}, {28638, -1, -1, -1}, {28640, -1, -1, -1}, {28655, -1, -1, -1}, {28698, -1, -1, -1}, {28707, -1, -1, -1}, {28699, -1, -1, -1}, {28729, -1, -1, -1}, {28725, -1, -1, -1}, {28751, -1, -1, -1}, {28766, -1, -1, -1}, {12071, 23424, -1, -1}, {23428, -1, -1, -1}, {23445, -1, -1, -1}, {23443, -1, -1, -1}, {23461, -1, -1, -1}, {23480, -1, -1, -1}, {29999, -1, -1, -1}, {39582, -1, -1, -1}, {25652, -1, -1, -1}, {23524, -1, -1, -1}, {23534, -1, -1, -1}, {35120, -1, -1, -1}, {23536, -1, -1, -1}, {36423, -1, -1, -1}, {35591, -1, -1, -1}, {36790, -1, -1, -1}, {36819, -1, -1, -1}, {36821, -1, -1, -1}, {36837, -1, -1, -1}, {36846, -1, -1, -1}, {36836, -1, -1, -1}, {36841, -1, -1, -1}, {36838, -1, -1, -1}, {36851, -1, -1, -1}, {36840, -1, -1, -1}, {36869, -1, -1, -1}, {36868, -1, -1, -1}, {36875, -1, -1, -1}, {36902, -1, -1, -1}, {36881, -1, -1, -1}, {36877, -1, -1, -1}, {36886, -1, -1, -1}, {36897, -1, -1, -1}, {36917, -1, -1, -1}, {36918, -1, -1, -1}, {36909, -1, -1, -1}, {36911, -1, -1, -1}, {36932, -1, -1, -1}, {36945, -1, -1, -1}, {36946, -1, -1, -1}, {36944, -1, -1, -1}, {36968, -1, -1, -1}, {36952, -1, -1, -1}, {36962, -1, -1, -1}, {36955, -1, -1, -1}, {26297, -1, -1, -1}, {36980, -1, -1, -1}, {36989, -1, -1, -1}, {36994, -1, -1, -1}, {37000, -1, -1, -1}, {36995, -1, -1, -1}, {37003, -1, -1, -1}, {12089, 24400, -1, -1}, {24407, -1, -1, -1}, {24406, -1, -1, -1}, {24408, -1, -1, -1}, {23611, -1, -1, -1}, {21675, -1, -1, -1}, {23632, -1, -1, -1}, {23641, -1, -1, -1}, {23409, -1, -1, -1}, {23651, -1, -1, -1}, {23654, -1, -1, -1}, {32700, -1, -1, -1}, {24362, -1, -1, -1}, {24361, -1, -1, -1}, {24365, -1, -1, -1}, {33396, -1, -1, -1}, {24380, -1, -1, -1}, {39739, -1, -1, -1}, {12076, 23662, -1, -1}, {22913, -1, -1, -1}, {22915, -1, -1, -1}, {22925, -1, -1, -1}, {22953, -1, -1, -1}, {22954, -1, -1, -1}, {22947, -1, -1, -1}, {22935, -1, -1, -1}, {22986, -1, -1, -1}, {22955, -1, -1, -1}, {22942, -1, -1, -1}, {22948, -1, -1, -1}, {22994, -1, -1, -1}, {22962, -1, -1, -1}, {22959, -1, -1, -1}, {22999, -1, -1, -1}, {22974, -1, -1, -1}, {23045, -1, -1, -1}, {23046, -1, -1, -1}, {23005, -1, -1, -1}, {23048, -1, -1, -1}, {23011, -1, -1, -1}, {23000, -1, -1, -1}, {23033, -1, -1, -1}, {23052, -1, -1, -1}, {23049, -1, -1, -1}, {23090, -1, -1, -1}, {23092, -1, -1, -1}, {23057, -1, -1, -1}, {23075, -1, -1, -1}, {23059, -1, -1, -1}, {23104, -1, -1, -1}, {23143, -1, -1, -1}, {23114, -1, -1, -1}, {23125, -1, -1, -1}, {23100, -1, -1, -1}, {23138, -1, -1, -1}, {23157, -1, -1, -1}, {33004, -1, -1, -1}, {23210, -1, -1, -1}, {23195, -1, -1, -1}, {23159, -1, -1, -1}, {23162, -1, -1, -1}, {23230, -1, -1, -1}, {23275, -1, -1, -1}, {23218, -1, -1, -1}, {23250, -1, -1, -1}, {23252, -1, -1, -1}, {23224, -1, -1, -1}, {23264, -1, -1, -1}, {23267, -1, -1, -1}, {23281, -1, -1, -1}, {23254, -1, -1, -1}, {23270, -1, -1, -1}, {23256, -1, -1, -1}, {23260, -1, -1, -1}, {23305, -1, -1, -1}, {23319, -1, -1, -1}, {23318, -1, -1, -1}, {23346, -1, -1, -1}, {23351, -1, -1, -1}, {23360, -1, -1, -1}, {23573, -1, -1, -1}, {23580, -1, -1, -1}, {23386, -1, -1, -1}, {23397, -1, -1, -1}, {23411, -1, -1, -1}, {23377, -1, -1, -1}, {23379, -1, -1, -1}, {23394, -1, -1, -1}, {39541, -1, -1, -1}, {39543, -1, -1, -1}, {39544, -1, -1, -1}, {39546, -1, -1, -1}, {39551, -1, -1, -1}, {39549, -1, -1, -1}, {39552, -1, -1, -1}, {39553, -1, -1, -1}, {39557, -1, -1, -1}, {39560, -1, -1, -1}, {39562, -1, -1, -1}, {39568, -1, -1, -1}, {39570, -1, -1, -1}, {39571, -1, -1, -1}, {39574, -1, -1, -1}, {39576, -1, -1, -1}, {39579, -1, -1, -1}, {39580, -1, -1, -1}, {39581, -1, -1, -1}, {39583, -1, -1, -1}, {39584, -1, -1, -1}, {39586, -1, -1, -1}, {39587, -1, -1, -1}, {39589, -1, -1, -1}, {39591, -1, -1, -1}, {32415, -1, -1, -1}, {32417, -1, -1, -1}, {32419, -1, -1, -1}, {32421, -1, -1, -1}, {32424, -1, -1, -1}, {32425, -1, -1, -1}, {32429, -1, -1, -1}, {32432, -1, -1, -1}, {32446, -1, -1, -1}, {32448, -1, -1, -1}, {32449, -1, -1, -1}, {32450, -1, -1, -1}, {32457, -1, -1, -1}, {32459, -1, -1, -1}, {32460, -1, -1, -1}, {32464, -1, -1, -1}, {32468, -1, -1, -1}, {32471, -1, -1, -1}, {32475, -1, -1, -1}, {32480, -1, -1, -1}, {32481, -1, -1, -1}, {32488, -1, -1, -1}, {32491, -1, -1, -1}, {32494, -1, -1, -1}, {32495, -1, -1, -1}, {32497, -1, -1, -1}, {32498, -1, -1, -1}, {32525, -1, -1, -1}, {32502, -1, -1, -1}, {32506, -1, -1, -1}, {32507, -1, -1, -1}, {32510, -1, -1, -1}, {32513, -1, -1, -1}, {32514, -1, -1, -1}, {32515, -1, -1, -1}, {32519, -1, -1, -1}, {32520, -1, -1, -1}, {32523, -1, -1, -1}, {32524, -1, -1, -1}, {32527, -1, -1, -1}, {32529, -1, -1, -1}, {32530, -1, -1, -1}, {32535, -1, -1, -1}, {32537, -1, -1, -1}, {32540, -1, -1, -1} },
+ {{32539, -1, -1, -1}, {32543, -1, -1, -1}, {32545, -1, -1, -1}, {32546, -1, -1, -1}, {32547, -1, -1, -1}, {32548, -1, -1, -1}, {32549, -1, -1, -1}, {32550, -1, -1, -1}, {32551, -1, -1, -1}, {32554, -1, -1, -1}, {32555, -1, -1, -1}, {32556, -1, -1, -1}, {32557, -1, -1, -1}, {32559, -1, -1, -1}, {32560, -1, -1, -1}, {32561, -1, -1, -1}, {32562, -1, -1, -1}, {32563, -1, -1, -1}, {32565, -1, -1, -1}, {12083, 24186, -1, -1}, {30079, -1, -1, -1}, {12078, 24027, -1, -1}, {30014, -1, -1, -1}, {37013, -1, -1, -1}, {29582, -1, -1, -1}, {29585, -1, -1, -1}, {29614, -1, -1, -1}, {29602, -1, -1, -1}, {29599, -1, -1, -1}, {29647, -1, -1, -1}, {29634, -1, -1, -1}, {29649, -1, -1, -1}, {29623, -1, -1, -1}, {29619, -1, -1, -1}, {29632, -1, -1, -1}, {29641, -1, -1, -1}, {29640, -1, -1, -1}, {29669, -1, -1, -1}, {29657, -1, -1, -1}, {39036, -1, -1, -1}, {29706, -1, -1, -1}, {29673, -1, -1, -1}, {29671, -1, -1, -1}, {29662, -1, -1, -1}, {29626, -1, -1, -1}, {29682, -1, -1, -1}, {29711, -1, -1, -1}, {29738, -1, -1, -1}, {29787, -1, -1, -1}, {29734, -1, -1, -1}, {29733, -1, -1, -1}, {29736, -1, -1, -1}, {29744, -1, -1, -1}, {29742, -1, -1, -1}, {29740, -1, -1, -1}, {29723, -1, -1, -1}, {29722, -1, -1, -1}, {29761, -1, -1, -1}, {29788, -1, -1, -1}, {29783, -1, -1, -1}, {29781, -1, -1, -1}, {29785, -1, -1, -1}, {29815, -1, -1, -1}, {29805, -1, -1, -1}, {29822, -1, -1, -1}, {29852, -1, -1, -1}, {29838, -1, -1, -1}, {29824, -1, -1, -1}, {29825, -1, -1, -1}, {29831, -1, -1, -1}, {29835, -1, -1, -1}, {29854, -1, -1, -1}, {29864, -1, -1, -1}, {29865, -1, -1, -1}, {29840, -1, -1, -1}, {29863, -1, -1, -1}, {29906, -1, -1, -1}, {29882, -1, -1, -1}, {38890, -1, -1, -1}, {38891, -1, -1, -1}, {38892, -1, -1, -1}, {26444, -1, -1, -1}, {26451, -1, -1, -1}, {26462, -1, -1, -1}, {26440, -1, -1, -1}, {26473, -1, -1, -1}, {26533, -1, -1, -1}, {26503, -1, -1, -1}, {26474, -1, -1, -1}, {26483, -1, -1, -1}, {26520, -1, -1, -1}, {26535, -1, -1, -1}, {26485, -1, -1, -1}, {26536, -1, -1, -1}, {26526, -1, -1, -1}, {26541, -1, -1, -1}, {26507, -1, -1, -1}, {26487, -1, -1, -1}, {26492, -1, -1, -1}, {26608, -1, -1, -1}, {26633, -1, -1, -1}, {26584, -1, -1, -1}, {26634, -1, -1, -1}, {26601, -1, -1, -1}, {26544, -1, -1, -1}, {26636, -1, -1, -1}, {26585, -1, -1, -1}, {26549, -1, -1, -1}, {26586, -1, -1, -1}, {26547, -1, -1, -1}, {26589, -1, -1, -1}, {26624, -1, -1, -1}, {26563, -1, -1, -1}, {26552, -1, -1, -1}, {26594, -1, -1, -1}, {26638, -1, -1, -1}, {26561, -1, -1, -1}, {26621, -1, -1, -1}, {26674, -1, -1, -1}, {26675, -1, -1, -1}, {26720, -1, -1, -1}, {26721, -1, -1, -1}, {26702, -1, -1, -1}, {26722, -1, -1, -1}, {26692, -1, -1, -1}, {26724, -1, -1, -1}, {26755, -1, -1, -1}, {26653, -1, -1, -1}, {26709, -1, -1, -1}, {26726, -1, -1, -1}, {26689, -1, -1, -1}, {26727, -1, -1, -1}, {26688, -1, -1, -1}, {26686, -1, -1, -1}, {26698, -1, -1, -1}, {26697, -1, -1, -1}, {26665, -1, -1, -1}, {26805, -1, -1, -1}, {26767, -1, -1, -1}, {26740, -1, -1, -1}, {26743, -1, -1, -1}, {26771, -1, -1, -1}, {26731, -1, -1, -1}, {26818, -1, -1, -1}, {26990, -1, -1, -1}, {26876, -1, -1, -1}, {26911, -1, -1, -1}, {26912, -1, -1, -1}, {26873, -1, -1, -1}, {26916, -1, -1, -1}, {26864, -1, -1, -1}, {26891, -1, -1, -1}, {26881, -1, -1, -1}, {26967, -1, -1, -1}, {26851, -1, -1, -1}, {26896, -1, -1, -1}, {26993, -1, -1, -1}, {26937, -1, -1, -1}, {26976, -1, -1, -1}, {26946, -1, -1, -1}, {26973, -1, -1, -1}, {27012, -1, -1, -1}, {26987, -1, -1, -1}, {27008, -1, -1, -1}, {27032, -1, -1, -1}, {27000, -1, -1, -1}, {26932, -1, -1, -1}, {27084, -1, -1, -1}, {27015, -1, -1, -1}, {27016, -1, -1, -1}, {27086, -1, -1, -1}, {27017, -1, -1, -1}, {26982, -1, -1, -1}, {26979, -1, -1, -1}, {27001, -1, -1, -1}, {27035, -1, -1, -1}, {27047, -1, -1, -1}, {27067, -1, -1, -1}, {27051, -1, -1, -1}, {27053, -1, -1, -1}, {27092, -1, -1, -1}, {27057, -1, -1, -1}, {27073, -1, -1, -1}, {27082, -1, -1, -1}, {27103, -1, -1, -1}, {27029, -1, -1, -1}, {27104, -1, -1, -1}, {27021, -1, -1, -1}, {27135, -1, -1, -1}, {27183, -1, -1, -1}, {27117, -1, -1, -1}, {27159, -1, -1, -1}, {27160, -1, -1, -1}, {27237, -1, -1, -1}, {27122, -1, -1, -1}, {27204, -1, -1, -1}, {27198, -1, -1, -1}, {27296, -1, -1, -1}, {27216, -1, -1, -1}, {27227, -1, -1, -1}, {27189, -1, -1, -1}, {27278, -1, -1, -1}, {27257, -1, -1, -1}, {27197, -1, -1, -1}, {27176, -1, -1, -1}, {27224, -1, -1, -1}, {27260, -1, -1, -1}, {27281, -1, -1, -1}, {27280, -1, -1, -1}, {27305, -1, -1, -1}, {27287, -1, -1, -1}, {27307, -1, -1, -1}, {29495, -1, -1, -1}, {29522, -1, -1, -1}, {27521, -1, -1, -1}, {27522, -1, -1, -1}, {27527, -1, -1, -1}, {27524, -1, -1, -1}, {27538, -1, -1, -1}, {27539, -1, -1, -1}, {27533, -1, -1, -1}, {27546, -1, -1, -1}, {27547, -1, -1, -1}, {27553, -1, -1, -1}, {27562, -1, -1, -1}, {36715, -1, -1, -1}, {36717, -1, -1, -1}, {36721, -1, -1, -1}, {36722, -1, -1, -1}, {36723, -1, -1, -1}, {36725, -1, -1, -1}, {36726, -1, -1, -1}, {36728, -1, -1, -1}, {36727, -1, -1, -1}, {36729, -1, -1, -1}, {36730, -1, -1, -1}, {36732, -1, -1, -1}, {36734, -1, -1, -1}, {36737, -1, -1, -1}, {36738, -1, -1, -1}, {36740, -1, -1, -1}, {36743, -1, -1, -1}, {36747, -1, -1, -1}, {36749, -1, -1, -1}, {36750, -1, -1, -1}, {36751, -1, -1, -1}, {36760, -1, -1, -1}, {36762, -1, -1, -1}, {36558, -1, -1, -1}, {25099, -1, -1, -1}, {25111, -1, -1, -1}, {25115, -1, -1, -1}, {25119, -1, -1, -1}, {25122, -1, -1, -1}, {25121, -1, -1, -1}, {25125, -1, -1, -1} },
+ {{25124, -1, -1, -1}, {25132, -1, -1, -1}, {33255, -1, -1, -1}, {29935, -1, -1, -1}, {29940, -1, -1, -1}, {29951, -1, -1, -1}, {29967, -1, -1, -1}, {29969, -1, -1, -1}, {29971, -1, -1, -1}, {12097, 25908, -1, -1}, {26094, -1, -1, -1}, {26095, -1, -1, -1}, {26096, -1, -1, -1}, {26122, -1, -1, -1}, {26137, -1, -1, -1}, {26482, -1, -1, -1}, {26115, -1, -1, -1}, {26133, -1, -1, -1}, {26112, -1, -1, -1}, {28805, -1, -1, -1}, {26359, -1, -1, -1}, {26141, -1, -1, -1}, {26164, -1, -1, -1}, {26161, -1, -1, -1}, {26166, -1, -1, -1}, {26165, -1, -1, -1}, {32774, -1, -1, -1}, {26207, -1, -1, -1}, {26196, -1, -1, -1}, {26177, -1, -1, -1}, {26191, -1, -1, -1}, {26198, -1, -1, -1}, {26209, -1, -1, -1}, {26199, -1, -1, -1}, {26231, -1, -1, -1}, {26244, -1, -1, -1}, {26252, -1, -1, -1}, {26279, -1, -1, -1}, {26269, -1, -1, -1}, {26302, -1, -1, -1}, {26331, -1, -1, -1}, {26332, -1, -1, -1}, {26342, -1, -1, -1}, {26345, -1, -1, -1}, {36146, -1, -1, -1}, {36147, -1, -1, -1}, {36150, -1, -1, -1}, {36155, -1, -1, -1}, {36157, -1, -1, -1}, {36160, -1, -1, -1}, {36165, -1, -1, -1}, {36166, -1, -1, -1}, {36168, -1, -1, -1}, {36169, -1, -1, -1}, {36167, -1, -1, -1}, {36173, -1, -1, -1}, {36181, -1, -1, -1}, {36185, -1, -1, -1}, {35271, -1, -1, -1}, {35274, -1, -1, -1}, {35275, -1, -1, -1}, {35276, -1, -1, -1}, {35278, -1, -1, -1}, {35279, -1, -1, -1}, {35280, -1, -1, -1}, {35281, -1, -1, -1}, {29294, -1, -1, -1}, {29343, -1, -1, -1}, {29277, -1, -1, -1}, {29286, -1, -1, -1}, {29295, -1, -1, -1}, {29310, -1, -1, -1}, {29311, -1, -1, -1}, {29316, -1, -1, -1}, {29323, -1, -1, -1}, {29325, -1, -1, -1}, {29327, -1, -1, -1}, {29330, -1, -1, -1}, {25352, -1, -1, -1}, {25394, -1, -1, -1}, {25520, -1, -1, -1}, {25663, -1, -1, -1}, {25816, -1, -1, -1}, {32772, -1, -1, -1}, {27626, -1, -1, -1}, {27635, -1, -1, -1}, {27645, -1, -1, -1}, {27637, -1, -1, -1}, {27641, -1, -1, -1}, {27653, -1, -1, -1}, {27655, -1, -1, -1}, {27654, -1, -1, -1}, {27661, -1, -1, -1}, {27669, -1, -1, -1}, {27672, -1, -1, -1}, {27673, -1, -1, -1}, {27674, -1, -1, -1}, {27681, -1, -1, -1}, {27689, -1, -1, -1}, {27684, -1, -1, -1}, {27690, -1, -1, -1}, {27698, -1, -1, -1}, {25909, -1, -1, -1}, {25941, -1, -1, -1}, {25963, -1, -1, -1}, {29261, -1, -1, -1}, {29266, -1, -1, -1}, {29270, -1, -1, -1}, {29232, -1, -1, -1}, {34402, -1, -1, -1}, {21014, -1, -1, -1}, {32927, -1, -1, -1}, {32924, -1, -1, -1}, {32915, -1, -1, -1}, {32956, -1, -1, -1}, {26378, -1, -1, -1}, {32957, -1, -1, -1}, {32945, -1, -1, -1}, {32939, -1, -1, -1}, {32941, -1, -1, -1}, {32948, -1, -1, -1}, {32951, -1, -1, -1}, {32999, -1, -1, -1}, {33000, -1, -1, -1}, {33001, -1, -1, -1}, {33002, -1, -1, -1}, {32987, -1, -1, -1}, {32962, -1, -1, -1}, {32964, -1, -1, -1}, {32985, -1, -1, -1}, {32973, -1, -1, -1}, {32983, -1, -1, -1}, {26384, -1, -1, -1}, {32989, -1, -1, -1}, {33003, -1, -1, -1}, {33009, -1, -1, -1}, {33012, -1, -1, -1}, {33005, -1, -1, -1}, {33037, -1, -1, -1}, {33038, -1, -1, -1}, {33010, -1, -1, -1}, {33020, -1, -1, -1}, {26389, -1, -1, -1}, {33042, -1, -1, -1}, {35930, -1, -1, -1}, {33078, -1, -1, -1}, {33054, -1, -1, -1}, {33068, -1, -1, -1}, {33048, -1, -1, -1}, {33074, -1, -1, -1}, {33096, -1, -1, -1}, {33100, -1, -1, -1}, {33107, -1, -1, -1}, {33140, -1, -1, -1}, {33113, -1, -1, -1}, {33114, -1, -1, -1}, {33137, -1, -1, -1}, {33120, -1, -1, -1}, {33129, -1, -1, -1}, {33148, -1, -1, -1}, {33149, -1, -1, -1}, {33133, -1, -1, -1}, {33127, -1, -1, -1}, {22605, -1, -1, -1}, {23221, -1, -1, -1}, {33160, -1, -1, -1}, {33154, -1, -1, -1}, {33169, -1, -1, -1}, {28373, -1, -1, -1}, {33187, -1, -1, -1}, {33194, -1, -1, -1}, {33228, -1, -1, -1}, {26406, -1, -1, -1}, {33226, -1, -1, -1}, {33211, -1, -1, -1}, {33217, -1, -1, -1}, {33190, -1, -1, -1}, {27428, -1, -1, -1}, {27447, -1, -1, -1}, {27449, -1, -1, -1}, {27459, -1, -1, -1}, {27462, -1, -1, -1}, {27481, -1, -1, -1}, {39121, -1, -1, -1}, {39122, -1, -1, -1}, {39123, -1, -1, -1}, {39125, -1, -1, -1}, {39129, -1, -1, -1}, {39130, -1, -1, -1}, {12110, 27571, -1, -1}, {24384, -1, -1, -1}, {27586, -1, -1, -1}, {35315, -1, -1, -1}, {26000, -1, -1, -1}, {40785, -1, -1, -1}, {26003, -1, -1, -1}, {26044, -1, -1, -1}, {26054, -1, -1, -1}, {26052, -1, -1, -1}, {26051, -1, -1, -1}, {26060, -1, -1, -1}, {26062, -1, -1, -1}, {26066, -1, -1, -1}, {26070, -1, -1, -1}, {28800, -1, -1, -1}, {28828, -1, -1, -1}, {28822, -1, -1, -1}, {28829, -1, -1, -1}, {28859, -1, -1, -1}, {28864, -1, -1, -1}, {28855, -1, -1, -1}, {28843, -1, -1, -1}, {28849, -1, -1, -1}, {28904, -1, -1, -1}, {28874, -1, -1, -1}, {28944, -1, -1, -1}, {28947, -1, -1, -1}, {28950, -1, -1, -1}, {28975, -1, -1, -1}, {28977, -1, -1, -1}, {29043, -1, -1, -1}, {29020, -1, -1, -1}, {29032, -1, -1, -1}, {28997, -1, -1, -1}, {29042, -1, -1, -1}, {29002, -1, -1, -1}, {29048, -1, -1, -1}, {29050, -1, -1, -1}, {29080, -1, -1, -1}, {29107, -1, -1, -1}, {29109, -1, -1, -1}, {29096, -1, -1, -1}, {29088, -1, -1, -1}, {29152, -1, -1, -1}, {29140, -1, -1, -1}, {29159, -1, -1, -1}, {29177, -1, -1, -1}, {29213, -1, -1, -1}, {29224, -1, -1, -1}, {28780, -1, -1, -1}, {28952, -1, -1, -1}, {29030, -1, -1, -1}, {29113, -1, -1, -1}, {25150, -1, -1, -1}, {25149, -1, -1, -1}, {25155, -1, -1, -1}, {25160, -1, -1, -1}, {25161, -1, -1, -1}, {31035, -1, -1, -1}, {31040, -1, -1, -1}, {31046, -1, -1, -1}, {31049, -1, -1, -1}, {31067, -1, -1, -1}, {31068, -1, -1, -1}, {31059, -1, -1, -1}, {31066, -1, -1, -1} },
+ {{31074, -1, -1, -1}, {31063, -1, -1, -1}, {31072, -1, -1, -1}, {31087, -1, -1, -1}, {31079, -1, -1, -1}, {31098, -1, -1, -1}, {31109, -1, -1, -1}, {31114, -1, -1, -1}, {31130, -1, -1, -1}, {31143, -1, -1, -1}, {31155, -1, -1, -1}, {24529, -1, -1, -1}, {24528, -1, -1, -1}, {24636, -1, -1, -1}, {24669, -1, -1, -1}, {24666, -1, -1, -1}, {24679, -1, -1, -1}, {24641, -1, -1, -1}, {24665, -1, -1, -1}, {24675, -1, -1, -1}, {24747, -1, -1, -1}, {24838, -1, -1, -1}, {24845, -1, -1, -1}, {24925, -1, -1, -1}, {25001, -1, -1, -1}, {24989, -1, -1, -1}, {25035, -1, -1, -1}, {25041, -1, -1, -1}, {25094, -1, -1, -1}, {32896, -1, -1, -1}, {12160, 32895, -1, -1}, {27795, -1, -1, -1}, {27894, -1, -1, -1}, {28156, -1, -1, -1}, {30710, -1, -1, -1}, {30712, -1, -1, -1}, {30720, -1, -1, -1}, {30729, -1, -1, -1}, {30743, -1, -1, -1}, {30744, -1, -1, -1}, {30737, -1, -1, -1}, {26027, -1, -1, -1}, {30765, -1, -1, -1}, {30748, -1, -1, -1}, {30749, -1, -1, -1}, {30777, -1, -1, -1}, {30778, -1, -1, -1}, {30779, -1, -1, -1}, {30751, -1, -1, -1}, {30780, -1, -1, -1}, {30757, -1, -1, -1}, {30764, -1, -1, -1}, {30755, -1, -1, -1}, {30761, -1, -1, -1}, {30798, -1, -1, -1}, {30829, -1, -1, -1}, {30806, -1, -1, -1}, {30807, -1, -1, -1}, {30758, -1, -1, -1}, {30800, -1, -1, -1}, {30791, -1, -1, -1}, {30796, -1, -1, -1}, {30826, -1, -1, -1}, {30875, -1, -1, -1}, {30867, -1, -1, -1}, {30874, -1, -1, -1}, {30855, -1, -1, -1}, {30876, -1, -1, -1}, {30881, -1, -1, -1}, {30883, -1, -1, -1}, {30898, -1, -1, -1}, {30905, -1, -1, -1}, {30885, -1, -1, -1}, {30932, -1, -1, -1}, {30937, -1, -1, -1}, {30921, -1, -1, -1}, {30956, -1, -1, -1}, {30962, -1, -1, -1}, {30981, -1, -1, -1}, {30964, -1, -1, -1}, {30995, -1, -1, -1}, {31012, -1, -1, -1}, {31006, -1, -1, -1}, {31028, -1, -1, -1}, {40859, -1, -1, -1}, {12235, 40697, -1, -1}, {40699, -1, -1, -1}, {40700, -1, -1, -1}, {30449, -1, -1, -1}, {30468, -1, -1, -1}, {30477, -1, -1, -1}, {30457, -1, -1, -1}, {30471, -1, -1, -1}, {30472, -1, -1, -1}, {30490, -1, -1, -1}, {30498, -1, -1, -1}, {30489, -1, -1, -1}, {30509, -1, -1, -1}, {30502, -1, -1, -1}, {30517, -1, -1, -1}, {30520, -1, -1, -1}, {30544, -1, -1, -1}, {30545, -1, -1, -1}, {30535, -1, -1, -1}, {30531, -1, -1, -1}, {30554, -1, -1, -1}, {30568, -1, -1, -1}, {30562, -1, -1, -1}, {30565, -1, -1, -1}, {30591, -1, -1, -1}, {30605, -1, -1, -1}, {30589, -1, -1, -1}, {30592, -1, -1, -1}, {30604, -1, -1, -1}, {30609, -1, -1, -1}, {30623, -1, -1, -1}, {30624, -1, -1, -1}, {30640, -1, -1, -1}, {30645, -1, -1, -1}, {30653, -1, -1, -1}, {30010, -1, -1, -1}, {30016, -1, -1, -1}, {30030, -1, -1, -1}, {30027, -1, -1, -1}, {30024, -1, -1, -1}, {30043, -1, -1, -1}, {30066, -1, -1, -1}, {30073, -1, -1, -1}, {30083, -1, -1, -1}, {32600, -1, -1, -1}, {32609, -1, -1, -1}, {32607, -1, -1, -1}, {35400, -1, -1, -1}, {32616, -1, -1, -1}, {32628, -1, -1, -1}, {32625, -1, -1, -1}, {32633, -1, -1, -1}, {32641, -1, -1, -1}, {32638, -1, -1, -1}, {30413, -1, -1, -1}, {30437, -1, -1, -1}, {34866, -1, -1, -1}, {38021, -1, -1, -1}, {38022, -1, -1, -1}, {38023, -1, -1, -1}, {38027, -1, -1, -1}, {38026, -1, -1, -1}, {38028, -1, -1, -1}, {38029, -1, -1, -1}, {38031, -1, -1, -1}, {38032, -1, -1, -1}, {38036, -1, -1, -1}, {38039, -1, -1, -1}, {38037, -1, -1, -1}, {38042, -1, -1, -1}, {38043, -1, -1, -1}, {38044, -1, -1, -1}, {38051, -1, -1, -1}, {38052, -1, -1, -1}, {38059, -1, -1, -1}, {38058, -1, -1, -1}, {38061, -1, -1, -1}, {38060, -1, -1, -1}, {38063, -1, -1, -1}, {38064, -1, -1, -1}, {38066, -1, -1, -1}, {38068, -1, -1, -1}, {38070, -1, -1, -1}, {38071, -1, -1, -1}, {38072, -1, -1, -1}, {38073, -1, -1, -1}, {38074, -1, -1, -1}, {38076, -1, -1, -1}, {38077, -1, -1, -1}, {38079, -1, -1, -1}, {38084, -1, -1, -1}, {38088, -1, -1, -1}, {38089, -1, -1, -1}, {38090, -1, -1, -1}, {38091, -1, -1, -1}, {38092, -1, -1, -1}, {38093, -1, -1, -1}, {38094, -1, -1, -1}, {38096, -1, -1, -1}, {38097, -1, -1, -1}, {38098, -1, -1, -1}, {38101, -1, -1, -1}, {38102, -1, -1, -1}, {38103, -1, -1, -1}, {38105, -1, -1, -1}, {38104, -1, -1, -1}, {38107, -1, -1, -1}, {38110, -1, -1, -1}, {38111, -1, -1, -1}, {38112, -1, -1, -1}, {38114, -1, -1, -1}, {38116, -1, -1, -1}, {38117, -1, -1, -1}, {38119, -1, -1, -1}, {38120, -1, -1, -1}, {38122, -1, -1, -1}, {38121, -1, -1, -1}, {38123, -1, -1, -1}, {38126, -1, -1, -1}, {38127, -1, -1, -1}, {38131, -1, -1, -1}, {38132, -1, -1, -1}, {38133, -1, -1, -1}, {38135, -1, -1, -1}, {38137, -1, -1, -1}, {38140, -1, -1, -1}, {38141, -1, -1, -1}, {38143, -1, -1, -1}, {38147, -1, -1, -1}, {38146, -1, -1, -1}, {38150, -1, -1, -1}, {38151, -1, -1, -1}, {38153, -1, -1, -1}, {38154, -1, -1, -1}, {38157, -1, -1, -1}, {38158, -1, -1, -1}, {38159, -1, -1, -1}, {38162, -1, -1, -1}, {38163, -1, -1, -1}, {38164, -1, -1, -1}, {38165, -1, -1, -1}, {38166, -1, -1, -1}, {38168, -1, -1, -1}, {38171, -1, -1, -1}, {38173, -1, -1, -1}, {38174, -1, -1, -1}, {38175, -1, -1, -1}, {38178, -1, -1, -1}, {38186, -1, -1, -1}, {38187, -1, -1, -1}, {38185, -1, -1, -1}, {38188, -1, -1, -1}, {38193, -1, -1, -1}, {38194, -1, -1, -1}, {38196, -1, -1, -1}, {38198, -1, -1, -1}, {38199, -1, -1, -1}, {38200, -1, -1, -1}, {38204, -1, -1, -1}, {38206, -1, -1, -1}, {38207, -1, -1, -1}, {38210, -1, -1, -1}, {38197, -1, -1, -1}, {38212, -1, -1, -1}, {38213, -1, -1, -1}, {38214, -1, -1, -1}, {38217, -1, -1, -1}, {38220, -1, -1, -1}, {38222, -1, -1, -1}, {38223, -1, -1, -1}, {38226, -1, -1, -1} },
+ {{38227, -1, -1, -1}, {38228, -1, -1, -1}, {38230, -1, -1, -1}, {38231, -1, -1, -1}, {38232, -1, -1, -1}, {38233, -1, -1, -1}, {38235, -1, -1, -1}, {38238, -1, -1, -1}, {38239, -1, -1, -1}, {38237, -1, -1, -1}, {38241, -1, -1, -1}, {38242, -1, -1, -1}, {38244, -1, -1, -1}, {38245, -1, -1, -1}, {38246, -1, -1, -1}, {38247, -1, -1, -1}, {38248, -1, -1, -1}, {38249, -1, -1, -1}, {38250, -1, -1, -1}, {38251, -1, -1, -1}, {38252, -1, -1, -1}, {38255, -1, -1, -1}, {38257, -1, -1, -1}, {38258, -1, -1, -1}, {38259, -1, -1, -1}, {38202, -1, -1, -1}, {30695, -1, -1, -1}, {30700, -1, -1, -1}, {38601, -1, -1, -1}, {31189, -1, -1, -1}, {31213, -1, -1, -1}, {31203, -1, -1, -1}, {31211, -1, -1, -1}, {31238, -1, -1, -1}, {23879, -1, -1, -1}, {31235, -1, -1, -1}, {31234, -1, -1, -1}, {31262, -1, -1, -1}, {31252, -1, -1, -1}, {31289, -1, -1, -1}, {31287, -1, -1, -1}, {31313, -1, -1, -1}, {40655, -1, -1, -1}, {39333, -1, -1, -1}, {31344, -1, -1, -1}, {30344, -1, -1, -1}, {30350, -1, -1, -1}, {30355, -1, -1, -1}, {30361, -1, -1, -1}, {30372, -1, -1, -1}, {29918, -1, -1, -1}, {29920, -1, -1, -1}, {29996, -1, -1, -1}, {40480, -1, -1, -1}, {40482, -1, -1, -1}, {40488, -1, -1, -1}, {40489, -1, -1, -1}, {40490, -1, -1, -1}, {40491, -1, -1, -1}, {40492, -1, -1, -1}, {40498, -1, -1, -1}, {40497, -1, -1, -1}, {40502, -1, -1, -1}, {40504, -1, -1, -1}, {40503, -1, -1, -1}, {40505, -1, -1, -1}, {40506, -1, -1, -1}, {40510, -1, -1, -1}, {40513, -1, -1, -1}, {40514, -1, -1, -1}, {40516, -1, -1, -1}, {40518, -1, -1, -1}, {40519, -1, -1, -1}, {40520, -1, -1, -1}, {40521, -1, -1, -1}, {40523, -1, -1, -1}, {40524, -1, -1, -1}, {40526, -1, -1, -1}, {40529, -1, -1, -1}, {40533, -1, -1, -1}, {40535, -1, -1, -1}, {40538, -1, -1, -1}, {40539, -1, -1, -1}, {40540, -1, -1, -1}, {40542, -1, -1, -1}, {40547, -1, -1, -1}, {40550, -1, -1, -1}, {40551, -1, -1, -1}, {40552, -1, -1, -1}, {40553, -1, -1, -1}, {40554, -1, -1, -1}, {40555, -1, -1, -1}, {40556, -1, -1, -1}, {40561, -1, -1, -1}, {40557, -1, -1, -1}, {40563, -1, -1, -1}, {12135, 30098, -1, -1}, {30100, -1, -1, -1}, {30102, -1, -1, -1}, {30112, -1, -1, -1}, {30109, -1, -1, -1}, {30124, -1, -1, -1}, {30115, -1, -1, -1}, {30131, -1, -1, -1}, {30132, -1, -1, -1}, {30136, -1, -1, -1}, {30148, -1, -1, -1}, {30129, -1, -1, -1}, {30128, -1, -1, -1}, {30147, -1, -1, -1}, {30146, -1, -1, -1}, {30166, -1, -1, -1}, {30157, -1, -1, -1}, {30179, -1, -1, -1}, {30184, -1, -1, -1}, {30182, -1, -1, -1}, {30180, -1, -1, -1}, {30187, -1, -1, -1}, {30183, -1, -1, -1}, {30211, -1, -1, -1}, {30193, -1, -1, -1}, {30204, -1, -1, -1}, {30207, -1, -1, -1}, {30224, -1, -1, -1}, {30208, -1, -1, -1}, {30213, -1, -1, -1}, {30220, -1, -1, -1}, {30231, -1, -1, -1}, {30218, -1, -1, -1}, {30245, -1, -1, -1}, {30232, -1, -1, -1}, {30229, -1, -1, -1}, {30233, -1, -1, -1}, {30235, -1, -1, -1}, {30268, -1, -1, -1}, {30242, -1, -1, -1}, {30240, -1, -1, -1}, {30272, -1, -1, -1}, {30253, -1, -1, -1}, {30256, -1, -1, -1}, {30271, -1, -1, -1}, {30261, -1, -1, -1}, {30275, -1, -1, -1}, {30270, -1, -1, -1}, {30259, -1, -1, -1}, {30285, -1, -1, -1}, {30302, -1, -1, -1}, {30292, -1, -1, -1}, {30300, -1, -1, -1}, {30294, -1, -1, -1}, {30315, -1, -1, -1}, {30319, -1, -1, -1}, {32714, -1, -1, -1}, {31462, -1, -1, -1}, {31352, -1, -1, -1}, {31353, -1, -1, -1}, {31360, -1, -1, -1}, {31366, -1, -1, -1}, {31368, -1, -1, -1}, {31381, -1, -1, -1}, {31398, -1, -1, -1}, {31392, -1, -1, -1}, {31404, -1, -1, -1}, {31400, -1, -1, -1}, {31405, -1, -1, -1}, {31411, -1, -1, -1}, {34916, -1, -1, -1}, {34921, -1, -1, -1}, {34930, -1, -1, -1}, {34941, -1, -1, -1}, {34943, -1, -1, -1}, {34946, -1, -1, -1}, {34978, -1, -1, -1}, {35014, -1, -1, -1}, {34999, -1, -1, -1}, {35004, -1, -1, -1}, {35017, -1, -1, -1}, {35042, -1, -1, -1}, {35022, -1, -1, -1}, {35043, -1, -1, -1}, {35045, -1, -1, -1}, {35057, -1, -1, -1}, {35098, -1, -1, -1}, {35068, -1, -1, -1}, {35048, -1, -1, -1}, {35070, -1, -1, -1}, {35056, -1, -1, -1}, {35105, -1, -1, -1}, {35097, -1, -1, -1}, {35091, -1, -1, -1}, {35099, -1, -1, -1}, {35082, -1, -1, -1}, {35124, -1, -1, -1}, {35115, -1, -1, -1}, {35126, -1, -1, -1}, {35137, -1, -1, -1}, {35174, -1, -1, -1}, {35195, -1, -1, -1}, {12134, 30091, -1, -1}, {32997, -1, -1, -1}, {30386, -1, -1, -1}, {30388, -1, -1, -1}, {30684, -1, -1, -1}, {12158, 32786, -1, -1}, {32788, -1, -1, -1}, {32790, -1, -1, -1}, {32796, -1, -1, -1}, {32800, -1, -1, -1}, {32802, -1, -1, -1}, {32805, -1, -1, -1}, {32806, -1, -1, -1}, {32807, -1, -1, -1}, {32809, -1, -1, -1}, {32808, -1, -1, -1}, {32817, -1, -1, -1}, {32779, -1, -1, -1}, {32821, -1, -1, -1}, {32835, -1, -1, -1}, {32838, -1, -1, -1}, {32845, -1, -1, -1}, {32850, -1, -1, -1}, {32873, -1, -1, -1}, {32881, -1, -1, -1}, {35203, -1, -1, -1}, {39032, -1, -1, -1}, {39040, -1, -1, -1}, {39043, -1, -1, -1}, {39049, -1, -1, -1}, {39052, -1, -1, -1}, {39053, -1, -1, -1}, {39055, -1, -1, -1}, {39060, -1, -1, -1}, {39066, -1, -1, -1}, {39067, -1, -1, -1}, {39070, -1, -1, -1}, {39071, -1, -1, -1}, {39073, -1, -1, -1}, {39074, -1, -1, -1}, {39077, -1, -1, -1}, {39078, -1, -1, -1}, {12172, 34381, -1, -1}, {34388, -1, -1, -1}, {34412, -1, -1, -1}, {34414, -1, -1, -1}, {34431, -1, -1, -1}, {34426, -1, -1, -1}, {34428, -1, -1, -1}, {34427, -1, -1, -1}, {34472, -1, -1, -1}, {34445, -1, -1, -1}, {34443, -1, -1, -1}, {34476, -1, -1, -1}, {34461, -1, -1, -1}, {34471, -1, -1, -1}, {34467, -1, -1, -1}, {34474, -1, -1, -1} },
+ {{34451, -1, -1, -1}, {34473, -1, -1, -1}, {34486, -1, -1, -1}, {34500, -1, -1, -1}, {34485, -1, -1, -1}, {34510, -1, -1, -1}, {34480, -1, -1, -1}, {34490, -1, -1, -1}, {34481, -1, -1, -1}, {34479, -1, -1, -1}, {34505, -1, -1, -1}, {34511, -1, -1, -1}, {34484, -1, -1, -1}, {34537, -1, -1, -1}, {34545, -1, -1, -1}, {34546, -1, -1, -1}, {34541, -1, -1, -1}, {34547, -1, -1, -1}, {34512, -1, -1, -1}, {34579, -1, -1, -1}, {34526, -1, -1, -1}, {34548, -1, -1, -1}, {34527, -1, -1, -1}, {34520, -1, -1, -1}, {34513, -1, -1, -1}, {34563, -1, -1, -1}, {34567, -1, -1, -1}, {34552, -1, -1, -1}, {34568, -1, -1, -1}, {34570, -1, -1, -1}, {34573, -1, -1, -1}, {34569, -1, -1, -1}, {34595, -1, -1, -1}, {34619, -1, -1, -1}, {34590, -1, -1, -1}, {34597, -1, -1, -1}, {34606, -1, -1, -1}, {34586, -1, -1, -1}, {34622, -1, -1, -1}, {34632, -1, -1, -1}, {34612, -1, -1, -1}, {34609, -1, -1, -1}, {34601, -1, -1, -1}, {34615, -1, -1, -1}, {34623, -1, -1, -1}, {34690, -1, -1, -1}, {34594, -1, -1, -1}, {34685, -1, -1, -1}, {34686, -1, -1, -1}, {34683, -1, -1, -1}, {34656, -1, -1, -1}, {34672, -1, -1, -1}, {34636, -1, -1, -1}, {34670, -1, -1, -1}, {34699, -1, -1, -1}, {34643, -1, -1, -1}, {34659, -1, -1, -1}, {34684, -1, -1, -1}, {34660, -1, -1, -1}, {34649, -1, -1, -1}, {34661, -1, -1, -1}, {34707, -1, -1, -1}, {34735, -1, -1, -1}, {34728, -1, -1, -1}, {34770, -1, -1, -1}, {34758, -1, -1, -1}, {34696, -1, -1, -1}, {34693, -1, -1, -1}, {34733, -1, -1, -1}, {34711, -1, -1, -1}, {34691, -1, -1, -1}, {34731, -1, -1, -1}, {34789, -1, -1, -1}, {34732, -1, -1, -1}, {34741, -1, -1, -1}, {34739, -1, -1, -1}, {34763, -1, -1, -1}, {34771, -1, -1, -1}, {34749, -1, -1, -1}, {34769, -1, -1, -1}, {34752, -1, -1, -1}, {34762, -1, -1, -1}, {34779, -1, -1, -1}, {34794, -1, -1, -1}, {34784, -1, -1, -1}, {34798, -1, -1, -1}, {34838, -1, -1, -1}, {34835, -1, -1, -1}, {34814, -1, -1, -1}, {34826, -1, -1, -1}, {34843, -1, -1, -1}, {34849, -1, -1, -1}, {34873, -1, -1, -1}, {34876, -1, -1, -1}, {12152, 32566, -1, -1}, {32578, -1, -1, -1}, {32580, -1, -1, -1}, {32581, -1, -1, -1}, {33296, -1, -1, -1}, {31482, -1, -1, -1}, {31485, -1, -1, -1}, {31496, -1, -1, -1}, {31491, -1, -1, -1}, {31492, -1, -1, -1}, {31509, -1, -1, -1}, {31498, -1, -1, -1}, {31531, -1, -1, -1}, {31503, -1, -1, -1}, {31559, -1, -1, -1}, {31544, -1, -1, -1}, {31530, -1, -1, -1}, {31513, -1, -1, -1}, {31534, -1, -1, -1}, {31537, -1, -1, -1}, {31520, -1, -1, -1}, {31525, -1, -1, -1}, {31524, -1, -1, -1}, {31539, -1, -1, -1}, {31550, -1, -1, -1}, {31518, -1, -1, -1}, {31576, -1, -1, -1}, {31578, -1, -1, -1}, {31557, -1, -1, -1}, {31605, -1, -1, -1}, {31564, -1, -1, -1}, {31581, -1, -1, -1}, {31584, -1, -1, -1}, {31598, -1, -1, -1}, {31611, -1, -1, -1}, {31586, -1, -1, -1}, {31602, -1, -1, -1}, {31601, -1, -1, -1}, {31632, -1, -1, -1}, {31654, -1, -1, -1}, {31655, -1, -1, -1}, {31672, -1, -1, -1}, {31660, -1, -1, -1}, {31645, -1, -1, -1}, {31656, -1, -1, -1}, {31621, -1, -1, -1}, {31658, -1, -1, -1}, {31644, -1, -1, -1}, {31650, -1, -1, -1}, {31659, -1, -1, -1}, {31668, -1, -1, -1}, {31697, -1, -1, -1}, {31681, -1, -1, -1}, {31692, -1, -1, -1}, {31709, -1, -1, -1}, {31706, -1, -1, -1}, {31717, -1, -1, -1}, {31718, -1, -1, -1}, {31722, -1, -1, -1}, {31756, -1, -1, -1}, {31742, -1, -1, -1}, {31740, -1, -1, -1}, {31759, -1, -1, -1}, {31766, -1, -1, -1}, {31755, -1, -1, -1}, {31775, -1, -1, -1}, {31786, -1, -1, -1}, {31782, -1, -1, -1}, {31800, -1, -1, -1}, {31809, -1, -1, -1}, {31808, -1, -1, -1}, {33278, -1, -1, -1}, {33281, -1, -1, -1}, {33282, -1, -1, -1}, {33284, -1, -1, -1}, {33260, -1, -1, -1}, {34884, -1, -1, -1}, {33313, -1, -1, -1}, {33314, -1, -1, -1}, {33315, -1, -1, -1}, {33325, -1, -1, -1}, {33327, -1, -1, -1}, {33320, -1, -1, -1}, {33323, -1, -1, -1}, {33336, -1, -1, -1}, {33339, -1, -1, -1}, {33331, -1, -1, -1}, {33332, -1, -1, -1}, {33342, -1, -1, -1}, {33348, -1, -1, -1}, {33353, -1, -1, -1}, {33355, -1, -1, -1}, {33359, -1, -1, -1}, {33370, -1, -1, -1}, {33375, -1, -1, -1}, {33384, -1, -1, -1}, {34942, -1, -1, -1}, {34949, -1, -1, -1}, {34952, -1, -1, -1}, {35032, -1, -1, -1}, {35039, -1, -1, -1}, {35166, -1, -1, -1}, {32669, -1, -1, -1}, {32671, -1, -1, -1}, {32679, -1, -1, -1}, {32687, -1, -1, -1}, {32688, -1, -1, -1}, {32690, -1, -1, -1}, {31868, -1, -1, -1}, {25929, -1, -1, -1}, {31889, -1, -1, -1}, {31901, -1, -1, -1}, {31900, -1, -1, -1}, {31902, -1, -1, -1}, {31906, -1, -1, -1}, {31922, -1, -1, -1}, {31932, -1, -1, -1}, {31933, -1, -1, -1}, {31937, -1, -1, -1}, {31943, -1, -1, -1}, {31948, -1, -1, -1}, {31949, -1, -1, -1}, {31944, -1, -1, -1}, {31941, -1, -1, -1}, {31959, -1, -1, -1}, {31976, -1, -1, -1}, {12169, 33390, -1, -1}, {26280, -1, -1, -1}, {32703, -1, -1, -1}, {32718, -1, -1, -1}, {32725, -1, -1, -1}, {32741, -1, -1, -1}, {32737, -1, -1, -1}, {32742, -1, -1, -1}, {32745, -1, -1, -1}, {32750, -1, -1, -1}, {32755, -1, -1, -1}, {12151, 31992, -1, -1}, {32119, -1, -1, -1}, {32166, -1, -1, -1}, {32174, -1, -1, -1}, {32327, -1, -1, -1}, {32411, -1, -1, -1}, {40632, -1, -1, -1}, {40628, -1, -1, -1}, {36211, -1, -1, -1}, {36228, -1, -1, -1}, {36244, -1, -1, -1}, {36241, -1, -1, -1}, {36273, -1, -1, -1}, {36199, -1, -1, -1}, {36205, -1, -1, -1}, {35911, -1, -1, -1}, {35913, -1, -1, -1}, {37194, -1, -1, -1}, {37200, -1, -1, -1}, {37198, -1, -1, -1}, {37199, -1, -1, -1}, {37220, -1, -1, -1}, {37218, -1, -1, -1}, {37217, -1, -1, -1}, {37232, -1, -1, -1} },
+ {{37225, -1, -1, -1}, {37231, -1, -1, -1}, {37245, -1, -1, -1}, {37246, -1, -1, -1}, {37234, -1, -1, -1}, {37236, -1, -1, -1}, {37241, -1, -1, -1}, {37260, -1, -1, -1}, {37253, -1, -1, -1}, {37264, -1, -1, -1}, {37261, -1, -1, -1}, {37265, -1, -1, -1}, {37282, -1, -1, -1}, {37283, -1, -1, -1}, {37290, -1, -1, -1}, {37293, -1, -1, -1}, {37294, -1, -1, -1}, {37295, -1, -1, -1}, {37301, -1, -1, -1}, {37300, -1, -1, -1}, {37306, -1, -1, -1}, {12183, 35925, -1, -1}, {40574, -1, -1, -1}, {36280, -1, -1, -1}, {36331, -1, -1, -1}, {36357, -1, -1, -1}, {36441, -1, -1, -1}, {36457, -1, -1, -1}, {36277, -1, -1, -1}, {36287, -1, -1, -1}, {36284, -1, -1, -1}, {36282, -1, -1, -1}, {36292, -1, -1, -1}, {36310, -1, -1, -1}, {36311, -1, -1, -1}, {36314, -1, -1, -1}, {36318, -1, -1, -1}, {36302, -1, -1, -1}, {36303, -1, -1, -1}, {36315, -1, -1, -1}, {36294, -1, -1, -1}, {36332, -1, -1, -1}, {36343, -1, -1, -1}, {36344, -1, -1, -1}, {36323, -1, -1, -1}, {36345, -1, -1, -1}, {36347, -1, -1, -1}, {36324, -1, -1, -1}, {36361, -1, -1, -1}, {36349, -1, -1, -1}, {36372, -1, -1, -1}, {36381, -1, -1, -1}, {36383, -1, -1, -1}, {36396, -1, -1, -1}, {36398, -1, -1, -1}, {36387, -1, -1, -1}, {36399, -1, -1, -1}, {36410, -1, -1, -1}, {36416, -1, -1, -1}, {36409, -1, -1, -1}, {36405, -1, -1, -1}, {36413, -1, -1, -1}, {36401, -1, -1, -1}, {36425, -1, -1, -1}, {36417, -1, -1, -1}, {36418, -1, -1, -1}, {36433, -1, -1, -1}, {36434, -1, -1, -1}, {36426, -1, -1, -1}, {36464, -1, -1, -1}, {36470, -1, -1, -1}, {36476, -1, -1, -1}, {36463, -1, -1, -1}, {36468, -1, -1, -1}, {36485, -1, -1, -1}, {36495, -1, -1, -1}, {36500, -1, -1, -1}, {36496, -1, -1, -1}, {36508, -1, -1, -1}, {36510, -1, -1, -1}, {12184, 35960, -1, -1}, {35970, -1, -1, -1}, {35978, -1, -1, -1}, {35973, -1, -1, -1}, {35992, -1, -1, -1}, {35988, -1, -1, -1}, {26011, -1, -1, -1}, {35286, -1, -1, -1}, {35294, -1, -1, -1}, {35290, -1, -1, -1}, {35292, -1, -1, -1}, {35301, -1, -1, -1}, {35307, -1, -1, -1}, {35311, -1, -1, -1}, {35390, -1, -1, -1}, {35622, -1, -1, -1}, {38739, -1, -1, -1}, {38633, -1, -1, -1}, {38643, -1, -1, -1}, {38639, -1, -1, -1}, {38662, -1, -1, -1}, {38657, -1, -1, -1}, {38664, -1, -1, -1}, {38671, -1, -1, -1}, {38670, -1, -1, -1}, {38698, -1, -1, -1}, {38701, -1, -1, -1}, {38704, -1, -1, -1}, {38718, -1, -1, -1}, {40832, -1, -1, -1}, {40835, -1, -1, -1}, {40837, -1, -1, -1}, {40838, -1, -1, -1}, {40839, -1, -1, -1}, {40840, -1, -1, -1}, {40841, -1, -1, -1}, {40842, -1, -1, -1}, {40844, -1, -1, -1}, {40702, -1, -1, -1}, {40715, -1, -1, -1}, {40717, -1, -1, -1}, {12203, 38585, -1, -1}, {38588, -1, -1, -1}, {38589, -1, -1, -1}, {38606, -1, -1, -1}, {38610, -1, -1, -1}, {30655, -1, -1, -1}, {38624, -1, -1, -1}, {37518, -1, -1, -1}, {37550, -1, -1, -1}, {37576, -1, -1, -1}, {37694, -1, -1, -1}, {37738, -1, -1, -1}, {37834, -1, -1, -1}, {37775, -1, -1, -1}, {37950, -1, -1, -1}, {37995, -1, -1, -1}, {40063, -1, -1, -1}, {40066, -1, -1, -1}, {40069, -1, -1, -1}, {40070, -1, -1, -1}, {40071, -1, -1, -1}, {40072, -1, -1, -1}, {31267, -1, -1, -1}, {40075, -1, -1, -1}, {40078, -1, -1, -1}, {40080, -1, -1, -1}, {40081, -1, -1, -1}, {40082, -1, -1, -1}, {40084, -1, -1, -1}, {40085, -1, -1, -1}, {40090, -1, -1, -1}, {40091, -1, -1, -1}, {40094, -1, -1, -1}, {40095, -1, -1, -1}, {40096, -1, -1, -1}, {40097, -1, -1, -1}, {40098, -1, -1, -1}, {40099, -1, -1, -1}, {40101, -1, -1, -1}, {40102, -1, -1, -1}, {40103, -1, -1, -1}, {40104, -1, -1, -1}, {40105, -1, -1, -1}, {40107, -1, -1, -1}, {40109, -1, -1, -1}, {40110, -1, -1, -1}, {40112, -1, -1, -1}, {40113, -1, -1, -1}, {40114, -1, -1, -1}, {40115, -1, -1, -1}, {40116, -1, -1, -1}, {40117, -1, -1, -1}, {40118, -1, -1, -1}, {40119, -1, -1, -1}, {40122, -1, -1, -1}, {40123, -1, -1, -1}, {40124, -1, -1, -1}, {40125, -1, -1, -1}, {40132, -1, -1, -1}, {40133, -1, -1, -1}, {40134, -1, -1, -1}, {40135, -1, -1, -1}, {40138, -1, -1, -1}, {40139, -1, -1, -1}, {40140, -1, -1, -1}, {40141, -1, -1, -1}, {40142, -1, -1, -1}, {40143, -1, -1, -1}, {40144, -1, -1, -1}, {40147, -1, -1, -1}, {40148, -1, -1, -1}, {40149, -1, -1, -1}, {40151, -1, -1, -1}, {40152, -1, -1, -1}, {40153, -1, -1, -1}, {40156, -1, -1, -1}, {40157, -1, -1, -1}, {40159, -1, -1, -1}, {40162, -1, -1, -1}, {38780, -1, -1, -1}, {38789, -1, -1, -1}, {38801, -1, -1, -1}, {38802, -1, -1, -1}, {38804, -1, -1, -1}, {38831, -1, -1, -1}, {38827, -1, -1, -1}, {38819, -1, -1, -1}, {38834, -1, -1, -1}, {38836, -1, -1, -1}, {39601, -1, -1, -1}, {39600, -1, -1, -1}, {39607, -1, -1, -1}, {40536, -1, -1, -1}, {39606, -1, -1, -1}, {39610, -1, -1, -1}, {39612, -1, -1, -1}, {39617, -1, -1, -1}, {39616, -1, -1, -1}, {39621, -1, -1, -1}, {39618, -1, -1, -1}, {39627, -1, -1, -1}, {39628, -1, -1, -1}, {39633, -1, -1, -1}, {39749, -1, -1, -1}, {39747, -1, -1, -1}, {39751, -1, -1, -1}, {39753, -1, -1, -1}, {39752, -1, -1, -1}, {39757, -1, -1, -1}, {39761, -1, -1, -1}, {39144, -1, -1, -1}, {39181, -1, -1, -1}, {39214, -1, -1, -1}, {39253, -1, -1, -1}, {39252, -1, -1, -1}, {12221, 39647, -1, -1}, {39649, -1, -1, -1}, {39654, -1, -1, -1}, {39663, -1, -1, -1}, {39659, -1, -1, -1}, {39675, -1, -1, -1}, {39661, -1, -1, -1}, {39673, -1, -1, -1}, {39688, -1, -1, -1}, {39695, -1, -1, -1}, {39699, -1, -1, -1}, {39711, -1, -1, -1}, {39715, -1, -1, -1}, {40637, -1, -1, -1}, {40638, -1, -1, -1}, {32315, -1, -1, -1}, {40578, -1, -1, -1}, {40583, -1, -1, -1}, {40584, -1, -1, -1}, {40587, -1, -1, -1} },
+ {{40594, -1, -1, -1}, {37846, -1, -1, -1}, {40605, -1, -1, -1}, {40607, -1, -1, -1}, {40667, -1, -1, -1}, {40668, -1, -1, -1}, {40669, -1, -1, -1}, {40672, -1, -1, -1}, {40671, -1, -1, -1}, {40674, -1, -1, -1}, {40681, -1, -1, -1}, {40679, -1, -1, -1}, {40677, -1, -1, -1}, {40682, -1, -1, -1}, {40687, -1, -1, -1}, {40738, -1, -1, -1}, {40748, -1, -1, -1}, {40751, -1, -1, -1}, {40761, -1, -1, -1}, {40759, -1, -1, -1}, {40765, -1, -1, -1}, {40766, -1, -1, -1}, {40772, -1, -1, -1}, {12295, -1, -1, -1}, {65374, -1, -1, -1}, {-1, -1, -1, -1}, {12307, -1, -1, -1}, {65294, -1, -1, -1}, {65309, 8741, -1, -1}, {65339, -1, -1, -1}, {65341, -1, -1, -1}, {65507, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {30362, -1, -1, -1}, {34297, -1, -1, -1}, {31001, -1, -1, -1}, {24859, -1, -1, -1}, {39599, -1, -1, -1}, {35158, -1, -1, -1}, {22761, -1, -1, -1}, {32631, -1, -1, -1}, {25850, -1, -1, -1}, {25943, -1, -1, -1}, {38930, -1, -1, -1}, {36774, -1, -1, -1}, {32070, -1, -1, -1}, {24171, -1, -1, -1}, {32129, -1, -1, -1}, {37770, -1, -1, -1}, {35607, -1, -1, -1}, {39165, -1, -1, -1}, {23542, -1, -1, -1}, {22577, -1, -1, -1}, {39825, -1, -1, -1}, {36649, -1, -1, -1}, {12185, 35997, -1, -1}, {37575, -1, -1, -1}, {29437, -1, -1, -1}, {20633, -1, -1, -1}, {24970, -1, -1, -1}, {32179, -1, -1, -1}, {31558, -1, -1, -1}, {30050, -1, -1, -1}, {25987, -1, -1, -1}, {24163, -1, -1, -1}, {38281, -1, -1, -1}, {37002, -1, -1, -1}, {32232, -1, -1, -1}, {36022, -1, -1, -1}, {35722, -1, -1, -1}, {36783, -1, -1, -1}, {36782, -1, -1, -1}, {27161, -1, -1, -1}, {40009, -1, -1, -1}, {30303, -1, -1, -1}, {28693, -1, -1, -1}, {28657, -1, -1, -1}, {36051, -1, -1, -1}, {25839, -1, -1, -1}, {39173, -1, -1, -1}, {25765, -1, -1, -1}, {37474, -1, -1, -1}, {37457, -1, -1, -1}, {39361, -1, -1, -1}, {35036, -1, -1, -1}, {36001, -1, -1, -1}, {21443, -1, -1, -1}, {34870, -1, -1, -1}, {27544, -1, -1, -1}, {24922, -1, -1, -1}, {24920, -1, -1, -1}, {29158, -1, -1, -1}, {33980, -1, -1, -1}, {33369, -1, -1, -1}, {20489, -1, -1, -1}, {28356, -1, -1, -1}, {21408, -1, -1, -1}, {20596, -1, -1, -1}, {28204, -1, -1, -1}, {23652, -1, -1, -1}, {35435, -1, -1, -1}, {25881, -1, -1, -1}, {25723, -1, -1, -1}, {34796, -1, -1, -1}, {39262, -1, -1, -1}, {35730, -1, -1, -1}, {32399, -1, -1, -1}, {37855, -1, -1, -1}, {29987, -1, -1, -1}, {38369, -1, -1, -1}, {39019, -1, -1, -1}, {22580, -1, -1, -1}, {22039, -1, -1, -1}, {12199, 38263, -1, -1}, {20767, -1, -1, -1}, {33144, -1, -1, -1}, {24288, -1, -1, -1}, {26274, -1, -1, -1}, {37396, -1, -1, -1}, {12190, 36554, -1, -1}, {24505, -1, -1, -1}, {22645, -1, -1, -1}, {38515, -1, -1, -1}, {35183, -1, -1, -1}, {31281, -1, -1, -1}, {25074, -1, -1, -1}, {35488, -1, -1, -1}, {39425, -1, -1, -1}, {36978, -1, -1, -1}, {39347, -1, -1, -1}, {12242, 40786, -1, -1}, {29118, -1, -1, -1}, {34909, -1, -1, -1}, {34802, -1, -1, -1}, {23541, -1, -1, -1}, {30087, -1, -1, -1}, {36490, -1, -1, -1}, {31820, -1, -1, -1}, {32162, -1, -1, -1}, {37276, -1, -1, -1}, {37604, -1, -1, -1}, {38619, -1, -1, -1}, {30990, -1, -1, -1}, {20786, -1, -1, -1}, {35320, -1, -1, -1}, {34389, -1, -1, -1}, {20659, -1, -1, -1}, {30241, -1, -1, -1}, {38358, -1, -1, -1}, {21109, -1, -1, -1}, {37656, -1, -1, -1}, {32020, -1, -1, -1}, {32189, -1, -1, -1}, {36781, -1, -1, -1}, {35422, -1, -1, -1}, {36060, -1, -1, -1}, {32880, -1, -1, -1}, {24478, -1, -1, -1}, {21474, -1, -1, -1}, {36517, -1, -1, -1}, {31428, -1, -1, -1}, {37679, -1, -1, -1}, {36948, -1, -1, -1}, {24118, -1, -1, -1}, {36024, -1, -1, -1}, {25812, -1, -1, -1}, {21934, -1, -1, -1}, {37170, -1, -1, -1}, {25763, -1, -1, -1}, {33213, -1, -1, -1}, {24986, -1, -1, -1}, {35477, -1, -1, -1}, {24392, -1, -1, -1}, {30070, -1, -1, -1}, {25803, -1, -1, -1}, {40680, -1, -1, -1}, {34153, -1, -1, -1}, {27284, -1, -1, -1}, {25623, -1, -1, -1}, {23798, -1, -1, -1}, {31153, -1, -1, -1}, {23566, -1, -1, -1}, {29128, -1, -1, -1}, {37159, -1, -1, -1}, {25973, -1, -1, -1}, {28364, -1, -1, -1}, {36958, -1, -1, -1}, {32224, -1, -1, -1}, {39003, -1, -1, -1}, {40670, -1, -1, -1}, {22666, -1, -1, -1}, {38651, -1, -1, -1}, {28593, -1, -1, -1}, {37347, -1, -1, -1}, {35519, -1, -1, -1}, {35548, -1, -1, -1}, {37336, -1, -1, -1}, {38914, -1, -1, -1}, {37664, -1, -1, -1}, {35330, -1, -1, -1}, {26481, -1, -1, -1}, {21205, -1, -1, -1}, {26847, -1, -1, -1}, {20941, -1, -1, -1}, {12222, 39717, -1, -1}, {29346, -1, -1, -1}, {29544, -1, -1, -1}, {35712, -1, -1, -1}, {36077, -1, -1, -1}, {37709, -1, -1, -1}, {37723, -1, -1, -1}, {26039, -1, -1, -1}, {32222, -1, -1, -1}, {38538, -1, -1, -1}, {23565, -1, -1, -1}, {22136, -1, -1, -1}, {38931, -1, -1, -1}, {37389, -1, -1, -1}, {22890, -1, -1, -1}, {22702, -1, -1, -1}, {40285, -1, -1, -1}, {38989, -1, -1, -1}, {35355, -1, -1, -1}, {24801, -1, -1, -1}, {39187, -1, -1, -1}, {20818, -1, -1, -1}, {29246, -1, -1, -1}, {39180, -1, -1, -1}, {36019, -1, -1, -1}, {30332, -1, -1, -1}, {32624, -1, -1, -1}, {38309, -1, -1, -1}, {31020, -1, -1, -1}, {37353, -1, -1, -1}, {29033, -1, -1, -1}, {31684, -1, -1, -1}, {36009, -1, -1, -1}, {39151, -1, -1, -1}, {35370, -1, -1, -1}, {32033, -1, -1, -1}, {12214, 39131, -1, -1}, {35513, -1, -1, -1}, {24290, -1, -1, -1}, {36027, -1, -1, -1}, {32027, -1, -1, -1}, {22707, -1, -1, -1}, {22894, -1, -1, -1}, {24996, -1, -1, -1}, {31966, -1, -1, -1}, {35920, -1, -1, -1}, {26963, -1, -1, -1}, {37586, -1, -1, -1} },
+ {{12213, 39080, -1, -1}, {30219, -1, -1, -1}, {39342, -1, -1, -1}, {32299, -1, -1, -1}, {35575, -1, -1, -1}, {40179, -1, -1, -1}, {33178, -1, -1, -1}, {36667, -1, -1, -1}, {25771, -1, -1, -1}, {36628, -1, -1, -1}, {36070, -1, -1, -1}, {24489, -1, -1, -1}, {36000, -1, -1, -1}, {35331, -1, -1, -1}, {23142, -1, -1, -1}, {32283, -1, -1, -1}, {35442, -1, -1, -1}, {37411, -1, -1, -1}, {33995, -1, -1, -1}, {24185, -1, -1, -1}, {36245, -1, -1, -1}, {36123, -1, -1, -1}, {23713, -1, -1, -1}, {21083, -1, -1, -1}, {37628, -1, -1, -1}, {32177, -1, -1, -1}, {23831, -1, -1, -1}, {37804, -1, -1, -1}, {25841, -1, -1, -1}, {40255, -1, -1, -1}, {38307, -1, -1, -1}, {37499, -1, -1, -1}, {20491, -1, -1, -1}, {32102, -1, -1, -1}, {40852, -1, -1, -1}, {38799, -1, -1, -1}, {36002, -1, -1, -1}, {37390, -1, -1, -1}, {28317, -1, -1, -1}, {27083, -1, -1, -1}, {36092, -1, -1, -1}, {34865, -1, -1, -1}, {39015, -1, -1, -1}, {21102, -1, -1, -1}, {38364, -1, -1, -1}, {35264, -1, -1, -1}, {39208, -1, -1, -1}, {24931, -1, -1, -1}, {36011, -1, -1, -1}, {24291, -1, -1, -1}, {35215, -1, -1, -1}, {27512, -1, -1, -1}, {12244, 40860, -1, -1}, {38312, -1, -1, -1}, {36556, -1, -1, -1}, {35437, -1, -1, -1}, {27331, -1, -1, -1}, {36020, -1, -1, -1}, {21130, -1, -1, -1}, {36645, -1, -1, -1}, {37707, -1, -1, -1}, {22283, -1, -1, -1}, {36942, -1, -1, -1}, {39405, -1, -1, -1}, {38867, -1, -1, -1}, {28450, -1, -1, -1}, {34399, -1, -1, -1}, {38305, -1, -1, -1}, {40372, -1, -1, -1}, {36032, -1, -1, -1}, {36703, -1, -1, -1}, {40251, -1, -1, -1}, {32005, -1, -1, -1}, {22778, -1, -1, -1}, {35703, -1, -1, -1}, {28396, -1, -1, -1}, {22057, -1, -1, -1}, {33775, -1, -1, -1}, {30059, -1, -1, -1}, {21123, -1, -1, -1}, {35441, -1, -1, -1}, {25079, -1, -1, -1}, {22750, -1, -1, -1}, {27489, -1, -1, -1}, {29872, -1, -1, -1}, {36996, -1, -1, -1}, {32233, -1, -1, -1}, {35594, -1, -1, -1}, {25582, -1, -1, -1}, {36637, -1, -1, -1}, {36036, -1, -1, -1}, {31330, -1, -1, -1}, {26371, -1, -1, -1}, {29172, -1, -1, -1}, {21295, -1, -1, -1}, {35569, -1, -1, -1}, {35496, -1, -1, -1}, {32362, -1, -1, -1}, {33911, -1, -1, -1}, {28222, -1, -1, -1}, {29554, -1, -1, -1}, {36008, -1, -1, -1}, {31117, -1, -1, -1}, {25802, -1, -1, -1}, {27231, -1, -1, -1}, {31309, -1, -1, -1}, {39249, -1, -1, -1}, {35663, -1, -1, -1}, {40388, -1, -1, -1}, {32318, -1, -1, -1}, {32221, -1, -1, -1}, {26997, -1, -1, -1}, {36655, -1, -1, -1}, {32026, -1, -1, -1}, {25824, -1, -1, -1}, {24190, -1, -1, -1}, {34186, -1, -1, -1}, {21137, -1, -1, -1}, {28639, -1, -1, -1}, {35336, -1, -1, -1}, {35352, -1, -1, -1}, {38555, -1, -1, -1}, {32380, -1, -1, -1}, {32000, -1, -1, -1}, {22846, -1, -1, -1}, {33698, -1, -1, -1}, {38960, -1, -1, -1}, {36040, -1, -1, -1}, {37440, -1, -1, -1}, {20729, -1, -1, -1}, {39381, -1, -1, -1}, {27570, -1, -1, -1}, {30435, -1, -1, -1}, {22533, -1, -1, -1}, {31627, -1, -1, -1}, {38291, -1, -1, -1}, {33393, -1, -1, -1}, {32216, -1, -1, -1}, {32365, -1, -1, -1}, {27298, -1, -1, -1}, {40572, -1, -1, -1}, {25536, -1, -1, -1}, {25791, -1, -1, -1}, {31777, -1, -1, -1}, {20745, -1, -1, -1}, {34214, -1, -1, -1}, {27323, -1, -1, -1}, {37970, -1, -1, -1}, {36368, -1, -1, -1}, {36068, -1, -1, -1}, {12178, 35211, -1, -1}, {37749, -1, -1, -1}, {33382, -1, -1, -1}, {21133, -1, -1, -1}, {39198, -1, -1, -1}, {28472, -1, -1, -1}, {28666, -1, -1, -1}, {28567, -1, -1, -1}, {23559, -1, -1, -1}, {28479, -1, -1, -1}, {34083, -1, -1, -1}, {27123, -1, -1, -1}, {22892, -1, -1, -1}, {35611, -1, -1, -1}, {37292, -1, -1, -1}, {33184, -1, -1, -1}, {28550, -1, -1, -1}, {39509, -1, -1, -1}, {23308, -1, -1, -1}, {25898, -1, -1, -1}, {37496, -1, -1, -1}, {30703, -1, -1, -1}, {20709, -1, -1, -1}, {39171, -1, -1, -1}, {32371, -1, -1, -1}, {32094, -1, -1, -1}, {36686, -1, -1, -1}, {36611, -1, -1, -1}, {38542, -1, -1, -1}, {31680, -1, -1, -1}, {28500, -1, -1, -1}, {32080, -1, -1, -1}, {35489, -1, -1, -1}, {32202, -1, -1, -1}, {37670, -1, -1, -1}, {20677, -1, -1, -1}, {35641, -1, -1, -1}, {36914, -1, -1, -1}, {29180, -1, -1, -1}, {30433, -1, -1, -1}, {21185, -1, -1, -1}, {33686, -1, -1, -1}, {39912, -1, -1, -1}, {39514, -1, -1, -1}, {32147, -1, -1, -1}, {38968, -1, -1, -1}, {37857, -1, -1, -1}, {24465, -1, -1, -1}, {30169, -1, -1, -1}, {31478, -1, -1, -1}, {31998, -1, -1, -1}, {33290, -1, -1, -1}, {39378, -1, -1, -1}, {33289, -1, -1, -1}, {25818, -1, -1, -1}, {37624, -1, -1, -1}, {25084, -1, -1, -1}, {21127, -1, -1, -1}, {40273, -1, -1, -1}, {32121, -1, -1, -1}, {35258, -1, -1, -1}, {35363, -1, -1, -1}, {32118, -1, -1, -1}, {37406, -1, -1, -1}, {36557, -1, -1, -1}, {39423, -1, -1, -1}, {38283, -1, -1, -1}, {20977, -1, -1, -1}, {38982, -1, -1, -1}, {27579, -1, -1, -1}, {35506, -1, -1, -1}, {22718, -1, -1, -1}, {25031, -1, -1, -1}, {25715, -1, -1, -1}, {24235, -1, -1, -1}, {35122, -1, -1, -1}, {35463, -1, -1, -1}, {22602, -1, -1, -1}, {20744, -1, -1, -1}, {23532, -1, -1, -1}, {31014, -1, -1, -1}, {26336, -1, -1, -1}, {34407, -1, -1, -1}, {24011, -1, -1, -1}, {31418, -1, -1, -1}, {39243, -1, -1, -1}, {28528, -1, -1, -1}, {25844, -1, -1, -1}, {38346, -1, -1, -1}, {34847, -1, -1, -1}, {33240, -1, -1, -1}, {33802, -1, -1, -1}, {20358, -1, -1, -1}, {36084, -1, -1, -1}, {34253, -1, -1, -1}, {27396, -1, -1, -1}, {25876, -1, -1, -1}, {31811, -1, -1, -1}, {38348, -1, -1, -1}, {34349, -1, -1, -1}, {28734, -1, -1, -1}, {35733, -1, -1, -1}, {25900, -1, -1, -1}, {35261, -1, -1, -1}, {25078, -1, -1, -1}, {32412, -1, -1, -1} },
+ {{29211, -1, -1, -1}, {28651, -1, -1, -1}, {25736, -1, -1, -1}, {21214, -1, -1, -1}, {28551, -1, -1, -1}, {27138, -1, -1, -1}, {37939, -1, -1, -1}, {22744, -1, -1, -1}, {39006, -1, -1, -1}, {31852, -1, -1, -1}, {38626, -1, -1, -1}, {28757, -1, -1, -1}, {35023, -1, -1, -1}, {39881, -1, -1, -1}, {31150, -1, -1, -1}, {40599, -1, -1, -1}, {21426, -1, -1, -1}, {21237, -1, -1, -1}, {31019, -1, -1, -1}, {27511, -1, -1, -1}, {28701, -1, -1, -1}, {38584, -1, -1, -1}, {20486, -1, -1, -1}, {32879, -1, -1, -1}, {34030, -1, -1, -1}, {36899, -1, -1, -1}, {37934, -1, -1, -1}, {24976, -1, -1, -1}, {28451, -1, -1, -1}, {31806, -1, -1, -1}, {25986, -1, -1, -1}, {33225, -1, -1, -1}, {37832, -1, -1, -1}, {25088, -1, -1, -1}, {29001, -1, -1, -1}, {32244, -1, -1, -1}, {31975, -1, -1, -1}, {20841, -1, -1, -1}, {36635, -1, -1, -1}, {35538, -1, -1, -1}, {30274, -1, -1, -1}, {36988, -1, -1, -1}, {37904, -1, -1, -1}, {29557, -1, -1, -1}, {33256, -1, -1, -1}, {37168, -1, -1, -1}, {40023, -1, -1, -1}, {36035, -1, -1, -1}, {40801, -1, -1, -1}, {37428, -1, -1, -1}, {38728, -1, -1, -1}, {23994, -1, -1, -1}, {38936, -1, -1, -1}, {39230, -1, -1, -1}, {21129, -1, -1, -1}, {12243, 40845, -1, -1}, {32894, -1, -1, -1}, {22184, -1, -1, -1}, {31840, -1, -1, -1}, {22751, -1, -1, -1}, {25871, -1, -1, -1}, {38580, -1, -1, -1}, {27155, -1, -1, -1}, {23105, -1, -1, -1}, {25695, -1, -1, -1}, {31757, -1, -1, -1}, {34310, -1, -1, -1}, {30439, -1, -1, -1}, {39025, -1, -1, -1}, {24300, -1, -1, -1}, {29200, -1, -1, -1}, {25796, -1, -1, -1}, {28407, -1, -1, -1}, {34396, -1, -1, -1}, {39791, -1, -1, -1}, {36034, -1, -1, -1}, {37682, -1, -1, -1}, {38520, -1, -1, -1}, {39522, -1, -1, -1}, {37569, -1, -1, -1}, {23650, -1, -1, -1}, {32311, -1, -1, -1}, {24942, -1, -1, -1}, {28670, -1, -1, -1}, {32209, -1, -1, -1}, {24018, -1, -1, -1}, {25891, -1, -1, -1}, {23423, -1, -1, -1}, {28772, -1, -1, -1}, {20098, -1, -1, -1}, {25476, -1, -1, -1}, {36650, -1, -1, -1}, {20523, -1, -1, -1}, {20374, -1, -1, -1}, {28138, -1, -1, -1}, {32184, -1, -1, -1}, {35542, -1, -1, -1}, {34367, -1, -1, -1}, {32645, -1, -1, -1}, {37007, -1, -1, -1}, {38012, -1, -1, -1}, {31854, -1, -1, -1}, {39486, -1, -1, -1}, {39409, -1, -1, -1}, {32097, -1, -1, -1}, {23229, -1, -1, -1}, {29802, -1, -1, -1}, {30908, -1, -1, -1}, {34718, -1, -1, -1}, {12218, 39340, -1, -1}, {39393, -1, -1, -1}, {21966, -1, -1, -1}, {36023, -1, -1, -1}, {12230, 40613, -1, -1}, {36067, -1, -1, -1}, {36993, -1, -1, -1}, {30622, -1, -1, -1}, {39237, -1, -1, -1}, {34875, -1, -1, -1}, {28415, -1, -1, -1}, {35646, -1, -1, -1}, {37672, -1, -1, -1}, {37466, -1, -1, -1}, {36031, -1, -1, -1}, {37762, -1, -1, -1}, {12200, 38272, -1, -1}, {24758, -1, -1, -1}, {20497, -1, -1, -1}, {37683, -1, -1, -1}, {22818, -1, -1, -1}, {35598, -1, -1, -1}, {24396, -1, -1, -1}, {35219, -1, -1, -1}, {32191, -1, -1, -1}, {32236, -1, -1, -1}, {24287, -1, -1, -1}, {28357, -1, -1, -1}, {25003, -1, -1, -1}, {38313, -1, -1, -1}, {40180, -1, -1, -1}, {37528, -1, -1, -1}, {35628, -1, -1, -1}, {35584, -1, -1, -1}, {30045, -1, -1, -1}, {37385, -1, -1, -1}, {32013, -1, -1, -1}, {38627, -1, -1, -1}, {25747, -1, -1, -1}, {33126, -1, -1, -1}, {24817, -1, -1, -1}, {39719, -1, -1, -1}, {39186, -1, -1, -1}, {25836, -1, -1, -1}, {33193, -1, -1, -1}, {25862, -1, -1, -1}, {37312, -1, -1, -1}, {12227, 40165, -1, -1}, {32886, -1, -1, -1}, {22169, -1, -1, -1}, {38007, -1, -1, -1}, {37811, -1, -1, -1}, {27320, -1, -1, -1}, {29552, -1, -1, -1}, {23527, -1, -1, -1}, {25840, -1, -1, -1}, {28632, -1, -1, -1}, {37397, -1, -1, -1}, {32016, -1, -1, -1}, {33215, -1, -1, -1}, {28611, -1, -1, -1}, {36786, -1, -1, -1}, {30247, -1, -1, -1}, {35582, -1, -1, -1}, {27472, -1, -1, -1}, {40407, -1, -1, -1}, {27590, -1, -1, -1}, {22036, -1, -1, -1}, {28442, -1, -1, -1}, {30436, -1, -1, -1}, {40848, -1, -1, -1}, {36064, -1, -1, -1}, {22132, -1, -1, -1}, {40300, -1, -1, -1}, {39449, -1, -1, -1}, {39108, -1, -1, -1}, {38971, -1, -1, -1}, {36007, -1, -1, -1}, {34315, -1, -1, -1}, {24977, -1, -1, -1}, {35413, -1, -1, -1}, {28497, -1, -1, -1}, {38935, -1, -1, -1}, {25778, -1, -1, -1}, {37610, -1, -1, -1}, {20693, -1, -1, -1}, {27192, -1, -1, -1}, {35676, -1, -1, -1}, {33229, -1, -1, -1}, {12241, 40778, -1, -1}, {39438, -1, -1, -1}, {35912, -1, -1, -1}, {21843, -1, -1, -1}, {27683, -1, -1, -1}, {35350, -1, -1, -1}, {29309, -1, -1, -1}, {37370, -1, -1, -1}, {37467, -1, -1, -1}, {36983, -1, -1, -1}, {31805, -1, -1, -1}, {35609, -1, -1, -1}, {37666, -1, -1, -1}, {37463, -1, -1, -1}, {28154, -1, -1, -1}, {35700, -1, -1, -1}, {22649, -1, -1, -1}, {27085, -1, -1, -1}, {21958, -1, -1, -1}, {22715, -1, -1, -1}, {34196, -1, -1, -1}, {25654, -1, -1, -1}, {37740, -1, -1, -1}, {27211, -1, -1, -1}, {21932, -1, -1, -1}, {20689, -1, -1, -1}, {32761, -1, -1, -1}, {31429, -1, -1, -1}, {31434, -1, -1, -1}, {27453, -1, -1, -1}, {35242, -1, -1, -1}, {23522, -1, -1, -1}, {36629, -1, -1, -1}, {27691, -1, -1, -1}, {20670, -1, -1, -1}, {38915, -1, -1, -1}, {35531, -1, -1, -1}, {24950, -1, -1, -1}, {29898, -1, -1, -1}, {31406, -1, -1, -1}, {36264, -1, -1, -1}, {21312, -1, -1, -1}, {36544, -1, -1, -1}, {39493, -1, -1, -1}, {40818, -1, -1, -1}, {39028, -1, -1, -1}, {27402, -1, -1, -1}, {21240, -1, -1, -1}, {40306, -1, -1, -1}, {30906, -1, -1, -1}, {35731, -1, -1, -1}, {39250, -1, -1, -1}, {25854, -1, -1, -1}, {32350, -1, -1, -1}, {29105, -1, -1, -1}, {38860, -1, -1, -1}, {35469, -1, -1, -1}, {32009, -1, -1, -1} },
+ {{27054, -1, -1, -1}, {32104, -1, -1, -1}, {36575, -1, -1, -1}, {37613, -1, -1, -1}, {38287, -1, -1, -1}, {28516, -1, -1, -1}, {28753, -1, -1, -1}, {34217, -1, -1, -1}, {39955, -1, -1, -1}, {36093, -1, -1, -1}, {20632, -1, -1, -1}, {21930, -1, -1, -1}, {39479, -1, -1, -1}, {25475, -1, -1, -1}, {28544, -1, -1, -1}, {27578, -1, -1, -1}, {32023, -1, -1, -1}, {31721, -1, -1, -1}, {26348, -1, -1, -1}, {38275, -1, -1, -1}, {38493, -1, -1, -1}, {36109, -1, -1, -1}, {32341, -1, -1, -1}, {20663, -1, -1, -1}, {36062, -1, -1, -1}, {29138, -1, -1, -1}, {32057, -1, -1, -1}, {36050, -1, -1, -1}, {25448, -1, -1, -1}, {25885, -1, -1, -1}, {25086, -1, -1, -1}, {35373, -1, -1, -1}, {32051, -1, -1, -1}, {23529, -1, -1, -1}, {23352, -1, -1, -1}, {33102, -1, -1, -1}, {28402, -1, -1, -1}, {32882, -1, -1, -1}, {32361, -1, -1, -1}, {21213, -1, -1, -1}, {32854, -1, -1, -1}, {24107, -1, -1, -1}, {29509, -1, -1, -1}, {28629, -1, -1, -1}, {35433, -1, -1, -1}, {26178, -1, -1, -1}, {34645, -1, -1, -1}, {23526, -1, -1, -1}, {35672, -1, -1, -1}, {39387, -1, -1, -1}, {21218, -1, -1, -1}, {36969, -1, -1, -1}, {37323, -1, -1, -1}, {39166, -1, -1, -1}, {35222, -1, -1, -1}, {35430, -1, -1, -1}, {22781, -1, -1, -1}, {29560, -1, -1, -1}, {27166, -1, -1, -1}, {36664, -1, -1, -1}, {26360, -1, -1, -1}, {36118, -1, -1, -1}, {23660, -1, -1, -1}, {34899, -1, -1, -1}, {27193, -1, -1, -1}, {31466, -1, -1, -1}, {25976, -1, -1, -1}, {24101, -1, -1, -1}, {38617, -1, -1, -1}, {35504, -1, -1, -1}, {38918, -1, -1, -1}, {35500, -1, -1, -1}, {30889, -1, -1, -1}, {29197, -1, -1, -1}, {32114, -1, -1, -1}, {39164, -1, -1, -1}, {39686, -1, -1, -1}, {32883, -1, -1, -1}, {24939, -1, -1, -1}, {38924, -1, -1, -1}, {35359, -1, -1, -1}, {35494, -1, -1, -1}, {25851, -1, -1, -1}, {34311, -1, -1, -1}, {35380, -1, -1, -1}, {32901, -1, -1, -1}, {38614, -1, -1, -1}, {38568, -1, -1, -1}, {32143, -1, -1, -1}, {27506, -1, -1, -1}, {23403, -1, -1, -1}, {25613, -1, -1, -1}, {32302, -1, -1, -1}, {29795, -1, -1, -1}, {37782, -1, -1, -1}, {29562, -1, -1, -1}, {25787, -1, -1, -1}, {33274, -1, -1, -1}, {24907, -1, -1, -1}, {25892, -1, -1, -1}, {36010, -1, -1, -1}, {30321, -1, -1, -1}, {28760, -1, -1, -1}, {22727, -1, -1, -1}, {35674, -1, -1, -1}, {35527, -1, -1, -1}, {22022, -1, -1, -1}, {28271, -1, -1, -1}, {29145, -1, -1, -1}, {28644, -1, -1, -1}, {32295, -1, -1, -1}, {35342, -1, -1, -1}, {39472, -1, -1, -1}, {35588, -1, -1, -1}, {37563, -1, -1, -1}, {38988, -1, -1, -1}, {39636, -1, -1, -1}, {26781, -1, -1, -1}, {36028, -1, -1, -1}, {37941, -1, -1, -1}, {24307, -1, -1, -1}, {32893, -1, -1, -1}, {28916, -1, -1, -1}, {37509, -1, -1, -1}, {32113, -1, -1, -1}, {38957, -1, -1, -1}, {22294, -1, -1, -1}, {22615, -1, -1, -1}, {22296, -1, -1, -1}, {38973, -1, -1, -1}, {40213, -1, -1, -1}, {39345, -1, -1, -1}, {39389, -1, -1, -1}, {27234, -1, -1, -1}, {31402, -1, -1, -1}, {35178, -1, -1, -1}, {24398, -1, -1, -1}, {28771, -1, -1, -1}, {38929, -1, -1, -1}, {33836, -1, -1, -1}, {32178, -1, -1, -1}, {12209, 38859, -1, -1}, {36949, -1, -1, -1}, {22285, -1, -1, -1}, {29234, -1, -1, -1}, {28656, -1, -1, -1}, {32173, -1, -1, -1}, {33894, -1, -1, -1}, {20553, -1, -1, -1}, {20702, -1, -1, -1}, {32239, -1, -1, -1}, {35586, -1, -1, -1}, {34907, -1, -1, -1}, {32862, -1, -1, -1}, {32011, -1, -1, -1}, {31337, -1, -1, -1}, {21839, -1, -1, -1}, {25790, -1, -1, -1}, {34680, -1, -1, -1}, {28198, -1, -1, -1}, {31401, -1, -1, -1}, {21978, -1, -1, -1}, {37794, -1, -1, -1}, {28879, -1, -1, -1}, {35491, -1, -1, -1}, {28961, -1, -1, -1}, {34154, -1, -1, -1}, {22626, -1, -1, -1}, {38695, -1, -1, -1}, {21209, -1, -1, -1}, {35492, -1, -1, -1}, {37675, -1, -1, -1}, {29351, -1, -1, -1}, {35186, -1, -1, -1}, {32722, -1, -1, -1}, {37521, -1, -1, -1}, {25138, -1, -1, -1}, {32048, -1, -1, -1}, {34662, -1, -1, -1}, {36676, -1, -1, -1}, {23805, -1, -1, -1}, {20448, -1, -1, -1}, {29433, -1, -1, -1}, {22151, -1, -1, -1}, {37697, -1, -1, -1}, {39854, -1, -1, -1}, {32406, -1, -1, -1}, {36066, -1, -1, -1}, {37532, -1, -1, -1}, {38289, -1, -1, -1}, {39023, -1, -1, -1}, {38570, -1, -1, -1}, {29694, -1, -1, -1}, {29563, -1, -1, -1}, {32291, -1, -1, -1}, {39201, -1, -1, -1}, {25010, -1, -1, -1}, {32171, -1, -1, -1}, {38002, -1, -1, -1}, {37129, -1, -1, -1}, {35443, -1, -1, -1}, {38911, -1, -1, -1}, {38917, -1, -1, -1}, {34157, -1, -1, -1}, {22210, -1, -1, -1}, {37559, -1, -1, -1}, {26313, -1, -1, -1}, {22063, -1, -1, -1}, {21332, -1, -1, -1}, {25406, -1, -1, -1}, {33029, -1, -1, -1}, {35559, -1, -1, -1}, {23531, -1, -1, -1}, {28681, -1, -1, -1}, {35613, -1, -1, -1}, {37573, -1, -1, -1}, {37313, -1, -1, -1}, {33288, -1, -1, -1}, {37561, -1, -1, -1}, {32137, -1, -1, -1}, {38920, -1, -1, -1}, {35377, -1, -1, -1}, {32210, -1, -1, -1}, {32396, -1, -1, -1}, {36562, -1, -1, -1}, {25080, -1, -1, -1}, {36984, -1, -1, -1}, {30316, -1, -1, -1}, {32098, -1, -1, -1}, {23416, -1, -1, -1}, {21211, -1, -1, -1}, {35426, -1, -1, -1}, {23563, -1, -1, -1}, {39348, -1, -1, -1}, {35347, -1, -1, -1}, {35338, -1, -1, -1}, {36956, -1, -1, -1}, {22739, -1, -1, -1}, {40201, -1, -1, -1}, {40232, -1, -1, -1}, {21854, -1, -1, -1}, {20126, -1, -1, -1}, {35357, -1, -1, -1}, {38329, -1, -1, -1}, {40573, -1, -1, -1}, {22196, -1, -1, -1}, {38996, -1, -1, -1}, {38331, -1, -1, -1}, {33399, -1, -1, -1}, {21421, -1, -1, -1}, {30831, -1, -1, -1}, {35578, -1, -1, -1}, {39511, -1, -1, -1}, {40230, -1, -1, -1}, {26954, -1, -1, -1}, {25562, -1, -1, -1} },
+ {{30221, -1, -1, -1}, {38525, -1, -1, -1}, {30306, -1, -1, -1}, {39178, -1, -1, -1}, {27171, -1, -1, -1}, {22575, -1, -1, -1}, {35617, -1, -1, -1}, {34277, -1, -1, -1}, {29242, -1, -1, -1}, {12212, 38913, -1, -1}, {26989, -1, -1, -1}, {33865, -1, -1, -1}, {37291, -1, -1, -1}, {37541, -1, -1, -1}, {38948, -1, -1, -1}, {36986, -1, -1, -1}, {20736, -1, -1, -1}, {34811, -1, -1, -1}, {34269, -1, -1, -1}, {20740, -1, -1, -1}, {25014, -1, -1, -1}, {32681, -1, -1, -1}, {35427, -1, -1, -1}, {35696, -1, -1, -1}, {35516, -1, -1, -1}, {35695, -1, -1, -1}, {32377, -1, -1, -1}, {34093, -1, -1, -1}, {38512, -1, -1, -1}, {37504, -1, -1, -1}, {39154, -1, -1, -1}, {38577, -1, -1, -1}, {27387, -1, -1, -1}, {23344, -1, -1, -1}, {40441, -1, -1, -1}, {25033, -1, -1, -1}, {32403, -1, -1, -1}, {29801, -1, -1, -1}, {34722, -1, -1, -1}, {29151, -1, -1, -1}, {29074, -1, -1, -1}, {34821, -1, -1, -1}, {36111, -1, -1, -1}, {31310, -1, -1, -1}, {21938, -1, -1, -1}, {25793, -1, -1, -1}, {20653, -1, -1, -1}, {30320, -1, -1, -1}, {36404, -1, -1, -1}, {20778, -1, -1, -1}, {24962, -1, -1, -1}, {37109, -1, -1, -1}, {37438, -1, -1, -1}, {29494, -1, -1, -1}, {35480, -1, -1, -1}, {36671, -1, -1, -1}, {39192, -1, -1, -1}, {12226, 39770, -1, -1}, {28417, -1, -1, -1}, {33287, -1, -1, -1}, {23996, -1, -1, -1}, {35486, -1, -1, -1}, {39729, -1, -1, -1}, {29508, -1, -1, -1}, {35709, -1, -1, -1}, {38928, -1, -1, -1}, {39341, -1, -1, -1}, {40219, -1, -1, -1}, {28149, -1, -1, -1}, {36677, -1, -1, -1}, {22290, -1, -1, -1}, {21729, -1, -1, -1}, {22291, -1, -1, -1}, {32227, -1, -1, -1}, {36960, -1, -1, -1}, {39000, -1, -1, -1}, {32004, -1, -1, -1}, {36493, -1, -1, -1}, {38000, -1, -1, -1}, {38322, -1, -1, -1}, {38642, -1, -1, -1}, {37142, -1, -1, -1}, {38549, -1, -1, -1}, {36939, -1, -1, -1}, {34292, -1, -1, -1}, {37270, -1, -1, -1}, {26248, -1, -1, -1}, {38620, -1, -1, -1}, {36617, -1, -1, -1}, {25890, -1, -1, -1}, {26283, -1, -1, -1}, {36106, -1, -1, -1}, {36124, -1, -1, -1}, {33247, -1, -1, -1}, {38015, -1, -1, -1}, {26839, -1, -1, -1}, {31432, -1, -1, -1}, {36012, -1, -1, -1}, {25799, -1, -1, -1}, {21063, -1, -1, -1}, {28580, -1, -1, -1}, {36042, -1, -1, -1}, {36104, -1, -1, -1}, {36555, -1, -1, -1}, {37720, -1, -1, -1}, {38296, -1, -1, -1}, {35408, -1, -1, -1}, {40779, -1, -1, -1}, {20661, -1, -1, -1}, {27656, -1, -1, -1}, {30430, -1, -1, -1}, {26028, -1, -1, -1}, {36670, -1, -1, -1}, {23940, -1, -1, -1}, {26855, -1, -1, -1}, {25136, -1, -1, -1}, {32187, -1, -1, -1}, {24373, -1, -1, -1}, {28466, -1, -1, -1}, {24115, -1, -1, -1}, {36076, -1, -1, -1}, {33081, -1, -1, -1}, {36249, -1, -1, -1}, {34756, -1, -1, -1}, {36685, -1, -1, -1}, {37754, -1, -1, -1}, {36889, -1, -1, -1}, {35998, -1, -1, -1}, {37341, -1, -1, -1}, {20597, -1, -1, -1}, {35386, -1, -1, -1}, {37806, -1, -1, -1}, {38499, -1, -1, -1}, {24128, -1, -1, -1}, {30309, -1, -1, -1}, {37165, -1, -1, -1}, {35657, -1, -1, -1}, {32340, -1, -1, -1}, {32887, -1, -1, -1}, {22519, -1, -1, -1}, {34937, -1, -1, -1}, {32025, -1, -1, -1}, {25711, -1, -1, -1}, {25842, -1, -1, -1}, {24159, -1, -1, -1}, {36074, -1, -1, -1}, {28399, -1, -1, -1}, {37912, -1, -1, -1}, {32066, -1, -1, -1}, {31278, -1, -1, -1}, {33131, -1, -1, -1}, {34886, -1, -1, -1}, {35589, -1, -1, -1}, {36600, -1, -1, -1}, {30394, -1, -1, -1}, {26205, -1, -1, -1}, {39519, -1, -1, -1}, {35576, -1, -1, -1}, {35461, -1, -1, -1}, {29165, -1, -1, -1}, {30682, -1, -1, -1}, {22225, -1, -1, -1}, {36015, -1, -1, -1}, {37956, -1, -1, -1}, {31689, -1, -1, -1}, {39376, -1, -1, -1}, {23560, -1, -1, -1}, {30938, -1, -1, -1}, {36681, -1, -1, -1}, {36090, -1, -1, -1}, {27137, -1, -1, -1}, {33674, -1, -1, -1}, {35037, -1, -1, -1}, {22941, -1, -1, -1}, {22767, -1, -1, -1}, {29376, -1, -1, -1}, {37648, -1, -1, -1}, {36101, -1, -1, -1}, {22684, -1, -1, -1}, {32180, -1, -1, -1}, {35524, -1, -1, -1}, {28310, -1, -1, -1}, {28609, -1, -1, -1}, {36039, -1, -1, -1}, {28460, -1, -1, -1}, {32156, -1, -1, -1}, {32317, -1, -1, -1}, {32305, -1, -1, -1}, {37138, -1, -1, -1}, {35419, -1, -1, -1}, {32068, -1, -1, -1}, {38013, -1, -1, -1}, {21959, -1, -1, -1}, {21401, -1, -1, -1}, {21428, -1, -1, -1}, {38760, -1, -1, -1}, {36107, -1, -1, -1}, {21293, -1, -1, -1}, {21297, -1, -1, -1}, {36094, -1, -1, -1}, {21060, -1, -1, -1}, {21132, -1, -1, -1}, {21108, -1, -1, -1}, {20660, -1, -1, -1}, {20480, -1, -1, -1}, {20630, -1, -1, -1}, {20757, -1, -1, -1}, {20738, -1, -1, -1}, {20756, -1, -1, -1}, {20796, -1, -1, -1}, {20791, -1, -1, -1}, {20712, -1, -1, -1}, {20674, -1, -1, -1}, {20795, -1, -1, -1}, {20752, -1, -1, -1}, {20794, -1, -1, -1}, {20681, -1, -1, -1}, {31988, -1, -1, -1}, {40652, -1, -1, -1}, {22213, -1, -1, -1}, {40172, -1, -1, -1}, {35131, -1, -1, -1}, {33248, -1, -1, -1}, {35329, -1, -1, -1}, {35344, -1, -1, -1}, {35340, -1, -1, -1}, {35349, -1, -1, -1}, {35635, -1, -1, -1}, {35406, -1, -1, -1}, {35365, -1, -1, -1}, {35393, -1, -1, -1}, {35382, -1, -1, -1}, {35398, -1, -1, -1}, {35412, -1, -1, -1}, {35416, -1, -1, -1}, {35410, -1, -1, -1}, {35462, -1, -1, -1}, {35460, -1, -1, -1}, {35455, -1, -1, -1}, {35440, -1, -1, -1}, {35452, -1, -1, -1}, {35445, -1, -1, -1}, {35436, -1, -1, -1}, {35438, -1, -1, -1}, {35533, -1, -1, -1}, {35554, -1, -1, -1}, {35425, -1, -1, -1}, {35482, -1, -1, -1}, {35493, -1, -1, -1}, {35473, -1, -1, -1}, {35474, -1, -1, -1}, {35535, -1, -1, -1}, {35537, -1, -1, -1}, {35529, -1, -1, -1}, {35547, -1, -1, -1}, {35543, -1, -1, -1} },
+ {{35522, -1, -1, -1}, {35510, -1, -1, -1}, {35574, -1, -1, -1}, {35563, -1, -1, -1}, {35604, -1, -1, -1}, {35585, -1, -1, -1}, {35556, -1, -1, -1}, {35565, -1, -1, -1}, {35580, -1, -1, -1}, {35571, -1, -1, -1}, {35558, -1, -1, -1}, {35566, -1, -1, -1}, {35550, -1, -1, -1}, {35624, -1, -1, -1}, {35740, -1, -1, -1}, {35606, -1, -1, -1}, {35610, -1, -1, -1}, {35600, -1, -1, -1}, {35627, -1, -1, -1}, {35629, -1, -1, -1}, {35670, -1, -1, -1}, {35673, -1, -1, -1}, {35662, -1, -1, -1}, {35742, -1, -1, -1}, {35691, -1, -1, -1}, {35734, -1, -1, -1}, {38488, -1, -1, -1}, {37178, -1, -1, -1}, {37140, -1, -1, -1}, {37172, -1, -1, -1}, {37087, -1, -1, -1}, {37174, -1, -1, -1}, {37126, -1, -1, -1}, {37192, -1, -1, -1}, {33467, -1, -1, -1}, {21233, -1, -1, -1}, {24048, -1, -1, -1}, {22538, -1, -1, -1}, {22745, -1, -1, -1}, {22754, -1, -1, -1}, {22752, -1, -1, -1}, {22746, -1, -1, -1}, {22497, -1, -1, -1}, {22607, -1, -1, -1}, {22550, -1, -1, -1}, {22610, -1, -1, -1}, {22557, -1, -1, -1}, {22628, -1, -1, -1}, {34188, -1, -1, -1}, {34131, -1, -1, -1}, {34294, -1, -1, -1}, {33703, -1, -1, -1}, {33799, -1, -1, -1}, {34031, -1, -1, -1}, {33511, -1, -1, -1}, {34338, -1, -1, -1}, {34086, -1, -1, -1}, {22603, -1, -1, -1}, {29026, -1, -1, -1}, {34136, -1, -1, -1}, {34045, -1, -1, -1}, {34126, -1, -1, -1}, {34184, -1, -1, -1}, {34234, -1, -1, -1}, {29334, -1, -1, -1}, {28366, -1, -1, -1}, {34113, -1, -1, -1}, {34254, -1, -1, -1}, {34130, -1, -1, -1}, {33984, -1, -1, -1}, {33874, -1, -1, -1}, {33892, -1, -1, -1}, {33940, -1, -1, -1}, {33845, -1, -1, -1}, {34207, -1, -1, -1}, {34133, -1, -1, -1}, {40367, -1, -1, -1}, {33939, -1, -1, -1}, {32264, -1, -1, -1}, {34118, -1, -1, -1}, {34146, -1, -1, -1}, {34078, -1, -1, -1}, {39488, -1, -1, -1}, {34362, -1, -1, -1}, {37795, -1, -1, -1}, {34167, -1, -1, -1}, {34334, -1, -1, -1}, {34298, -1, -1, -1}, {34308, -1, -1, -1}, {34282, -1, -1, -1}, {34330, -1, -1, -1}, {22889, -1, -1, -1}, {23607, -1, -1, -1}, {25451, -1, -1, -1}, {25718, -1, -1, -1}, {25759, -1, -1, -1}, {25681, -1, -1, -1}, {25692, -1, -1, -1}, {25779, -1, -1, -1}, {25860, -1, -1, -1}, {25878, -1, -1, -1}, {25847, -1, -1, -1}, {25852, -1, -1, -1}, {25883, -1, -1, -1}, {22064, -1, -1, -1}, {22072, -1, -1, -1}, {22216, -1, -1, -1}, {22182, -1, -1, -1}, {21764, -1, -1, -1}, {21692, -1, -1, -1}, {22144, -1, -1, -1}, {22109, -1, -1, -1}, {22112, -1, -1, -1}, {22069, -1, -1, -1}, {22006, -1, -1, -1}, {22118, -1, -1, -1}, {22130, -1, -1, -1}, {22156, -1, -1, -1}, {22117, -1, -1, -1}, {22044, -1, -1, -1}, {22062, -1, -1, -1}, {21993, -1, -1, -1}, {22038, -1, -1, -1}, {22208, -1, -1, -1}, {22029, -1, -1, -1}, {22195, -1, -1, -1}, {22209, -1, -1, -1}, {22127, -1, -1, -1}, {36705, -1, -1, -1}, {22198, -1, -1, -1}, {22165, -1, -1, -1}, {22279, -1, -1, -1}, {24131, -1, -1, -1}, {24172, -1, -1, -1}, {24152, -1, -1, -1}, {24151, -1, -1, -1}, {23943, -1, -1, -1}, {23796, -1, -1, -1}, {23888, -1, -1, -1}, {23852, -1, -1, -1}, {23975, -1, -1, -1}, {23968, -1, -1, -1}, {23959, -1, -1, -1}, {23821, -1, -1, -1}, {23992, -1, -1, -1}, {23937, -1, -1, -1}, {24020, -1, -1, -1}, {24480, -1, -1, -1}, {29559, -1, -1, -1}, {29505, -1, -1, -1}, {29546, -1, -1, -1}, {29499, -1, -1, -1}, {29547, -1, -1, -1}, {29568, -1, -1, -1}, {29564, -1, -1, -1}, {39136, -1, -1, -1}, {39219, -1, -1, -1}, {39145, -1, -1, -1}, {39228, -1, -1, -1}, {39146, -1, -1, -1}, {39147, -1, -1, -1}, {39149, -1, -1, -1}, {39156, -1, -1, -1}, {39177, -1, -1, -1}, {39185, -1, -1, -1}, {39195, -1, -1, -1}, {39223, -1, -1, -1}, {39231, -1, -1, -1}, {39235, -1, -1, -1}, {39240, -1, -1, -1}, {39241, -1, -1, -1}, {39242, -1, -1, -1}, {39244, -1, -1, -1}, {39266, -1, -1, -1}, {24289, -1, -1, -1}, {36065, -1, -1, -1}, {25082, -1, -1, -1}, {25006, -1, -1, -1}, {24938, -1, -1, -1}, {24894, -1, -1, -1}, {24757, -1, -1, -1}, {24884, -1, -1, -1}, {25036, -1, -1, -1}, {24927, -1, -1, -1}, {25064, -1, -1, -1}, {24827, -1, -1, -1}, {24887, -1, -1, -1}, {24818, -1, -1, -1}, {24947, -1, -1, -1}, {24860, -1, -1, -1}, {24978, -1, -1, -1}, {38274, -1, -1, -1}, {38278, -1, -1, -1}, {38344, -1, -1, -1}, {38286, -1, -1, -1}, {38292, -1, -1, -1}, {38284, -1, -1, -1}, {38373, -1, -1, -1}, {38317, -1, -1, -1}, {38315, -1, -1, -1}, {39726, -1, -1, -1}, {38316, -1, -1, -1}, {38334, -1, -1, -1}, {38326, -1, -1, -1}, {39721, -1, -1, -1}, {38335, -1, -1, -1}, {38333, -1, -1, -1}, {38332, -1, -1, -1}, {38339, -1, -1, -1}, {38347, -1, -1, -1}, {38356, -1, -1, -1}, {38352, -1, -1, -1}, {38357, -1, -1, -1}, {38366, -1, -1, -1}, {28739, -1, -1, -1}, {28505, -1, -1, -1}, {28711, -1, -1, -1}, {28696, -1, -1, -1}, {28668, -1, -1, -1}, {28039, -1, -1, -1}, {28025, -1, -1, -1}, {28254, -1, -1, -1}, {28590, -1, -1, -1}, {28687, -1, -1, -1}, {28408, -1, -1, -1}, {28527, -1, -1, -1}, {28150, -1, -1, -1}, {28543, -1, -1, -1}, {28678, -1, -1, -1}, {28576, -1, -1, -1}, {28683, -1, -1, -1}, {28775, -1, -1, -1}, {28740, -1, -1, -1}, {28677, -1, -1, -1}, {28535, -1, -1, -1}, {28704, -1, -1, -1}, {28703, -1, -1, -1}, {28722, -1, -1, -1}, {28712, -1, -1, -1}, {28765, -1, -1, -1}, {39467, -1, -1, -1}, {36999, -1, -1, -1}, {36885, -1, -1, -1}, {37008, -1, -1, -1}, {23656, -1, -1, -1}, {24371, -1, -1, -1}, {23285, -1, -1, -1}, {23255, -1, -1, -1}, {23296, -1, -1, -1}, {23149, -1, -1, -1}, {23304, -1, -1, -1}, {23372, -1, -1, -1}, {23207, -1, -1, -1}, {23291, -1, -1, -1}, {23307, -1, -1, -1}, {23329, -1, -1, -1} },
+ {{23338, -1, -1, -1}, {23321, -1, -1, -1}, {39380, -1, -1, -1}, {39391, -1, -1, -1}, {39385, -1, -1, -1}, {39478, -1, -1, -1}, {39515, -1, -1, -1}, {39377, -1, -1, -1}, {39384, -1, -1, -1}, {39501, -1, -1, -1}, {39498, -1, -1, -1}, {39394, -1, -1, -1}, {39530, -1, -1, -1}, {39439, -1, -1, -1}, {39437, -1, -1, -1}, {39429, -1, -1, -1}, {39490, -1, -1, -1}, {39469, -1, -1, -1}, {39446, -1, -1, -1}, {39489, -1, -1, -1}, {39470, -1, -1, -1}, {39480, -1, -1, -1}, {39491, -1, -1, -1}, {39492, -1, -1, -1}, {39503, -1, -1, -1}, {39525, -1, -1, -1}, {39524, -1, -1, -1}, {31993, -1, -1, -1}, {32006, -1, -1, -1}, {32002, -1, -1, -1}, {32007, -1, -1, -1}, {32008, -1, -1, -1}, {32394, -1, -1, -1}, {32028, -1, -1, -1}, {32021, -1, -1, -1}, {32019, -1, -1, -1}, {32058, -1, -1, -1}, {32050, -1, -1, -1}, {32049, -1, -1, -1}, {32272, -1, -1, -1}, {32060, -1, -1, -1}, {32064, -1, -1, -1}, {32063, -1, -1, -1}, {32093, -1, -1, -1}, {32078, -1, -1, -1}, {32115, -1, -1, -1}, {32134, -1, -1, -1}, {32131, -1, -1, -1}, {32136, -1, -1, -1}, {32190, -1, -1, -1}, {32186, -1, -1, -1}, {32203, -1, -1, -1}, {32212, -1, -1, -1}, {32196, -1, -1, -1}, {32158, -1, -1, -1}, {32172, -1, -1, -1}, {32185, -1, -1, -1}, {32163, -1, -1, -1}, {32176, -1, -1, -1}, {32199, -1, -1, -1}, {32217, -1, -1, -1}, {32215, -1, -1, -1}, {32249, -1, -1, -1}, {32242, -1, -1, -1}, {32354, -1, -1, -1}, {32230, -1, -1, -1}, {32246, -1, -1, -1}, {32241, -1, -1, -1}, {32267, -1, -1, -1}, {32225, -1, -1, -1}, {32265, -1, -1, -1}, {32285, -1, -1, -1}, {32287, -1, -1, -1}, {32286, -1, -1, -1}, {32301, -1, -1, -1}, {32266, -1, -1, -1}, {32273, -1, -1, -1}, {32381, -1, -1, -1}, {32313, -1, -1, -1}, {32309, -1, -1, -1}, {32306, -1, -1, -1}, {32326, -1, -1, -1}, {32325, -1, -1, -1}, {32392, -1, -1, -1}, {32346, -1, -1, -1}, {32338, -1, -1, -1}, {32366, -1, -1, -1}, {32382, -1, -1, -1}, {32368, -1, -1, -1}, {32367, -1, -1, -1}, {32408, -1, -1, -1}, {29859, -1, -1, -1}, {29771, -1, -1, -1}, {29903, -1, -1, -1}, {38922, -1, -1, -1}, {29885, -1, -1, -1}, {29759, -1, -1, -1}, {29833, -1, -1, -1}, {29862, -1, -1, -1}, {29908, -1, -1, -1}, {29914, -1, -1, -1}, {38873, -1, -1, -1}, {38878, -1, -1, -1}, {38876, -1, -1, -1}, {27050, -1, -1, -1}, {27370, -1, -1, -1}, {26776, -1, -1, -1}, {26838, -1, -1, -1}, {27141, -1, -1, -1}, {26783, -1, -1, -1}, {27355, -1, -1, -1}, {27379, -1, -1, -1}, {27368, -1, -1, -1}, {27359, -1, -1, -1}, {27273, -1, -1, -1}, {26895, -1, -1, -1}, {27208, -1, -1, -1}, {26984, -1, -1, -1}, {27071, -1, -1, -1}, {27194, -1, -1, -1}, {27292, -1, -1, -1}, {27410, -1, -1, -1}, {27422, -1, -1, -1}, {27357, -1, -1, -1}, {27111, -1, -1, -1}, {27407, -1, -1, -1}, {27414, -1, -1, -1}, {27372, -1, -1, -1}, {27354, -1, -1, -1}, {27384, -1, -1, -1}, {27315, -1, -1, -1}, {27367, -1, -1, -1}, {27299, -1, -1, -1}, {27347, -1, -1, -1}, {27358, -1, -1, -1}, {27556, -1, -1, -1}, {27550, -1, -1, -1}, {27566, -1, -1, -1}, {27563, -1, -1, -1}, {27567, -1, -1, -1}, {36564, -1, -1, -1}, {36571, -1, -1, -1}, {36594, -1, -1, -1}, {36603, -1, -1, -1}, {36708, -1, -1, -1}, {36601, -1, -1, -1}, {36604, -1, -1, -1}, {36587, -1, -1, -1}, {36580, -1, -1, -1}, {36706, -1, -1, -1}, {36602, -1, -1, -1}, {36606, -1, -1, -1}, {36618, -1, -1, -1}, {36615, -1, -1, -1}, {36613, -1, -1, -1}, {36626, -1, -1, -1}, {36646, -1, -1, -1}, {36638, -1, -1, -1}, {36639, -1, -1, -1}, {36636, -1, -1, -1}, {36659, -1, -1, -1}, {36678, -1, -1, -1}, {36692, -1, -1, -1}, {25108, -1, -1, -1}, {25127, -1, -1, -1}, {29964, -1, -1, -1}, {26311, -1, -1, -1}, {26308, -1, -1, -1}, {26249, -1, -1, -1}, {26326, -1, -1, -1}, {36033, -1, -1, -1}, {36016, -1, -1, -1}, {36026, -1, -1, -1}, {36029, -1, -1, -1}, {36100, -1, -1, -1}, {36018, -1, -1, -1}, {36037, -1, -1, -1}, {36112, -1, -1, -1}, {36049, -1, -1, -1}, {36058, -1, -1, -1}, {36053, -1, -1, -1}, {36075, -1, -1, -1}, {36071, -1, -1, -1}, {36091, -1, -1, -1}, {35224, -1, -1, -1}, {35244, -1, -1, -1}, {35233, -1, -1, -1}, {35263, -1, -1, -1}, {35238, -1, -1, -1}, {35247, -1, -1, -1}, {35250, -1, -1, -1}, {35255, -1, -1, -1}, {27647, -1, -1, -1}, {27660, -1, -1, -1}, {27692, -1, -1, -1}, {29272, -1, -1, -1}, {26407, -1, -1, -1}, {33110, -1, -1, -1}, {33242, -1, -1, -1}, {33051, -1, -1, -1}, {33214, -1, -1, -1}, {33121, -1, -1, -1}, {33231, -1, -1, -1}, {27487, -1, -1, -1}, {39086, -1, -1, -1}, {39087, -1, -1, -1}, {39094, -1, -1, -1}, {39100, -1, -1, -1}, {39110, -1, -1, -1}, {39112, -1, -1, -1}, {36674, -1, -1, -1}, {40783, -1, -1, -1}, {26005, -1, -1, -1}, {29036, -1, -1, -1}, {29010, -1, -1, -1}, {29079, -1, -1, -1}, {29121, -1, -1, -1}, {29148, -1, -1, -1}, {29182, -1, -1, -1}, {31152, -1, -1, -1}, {31118, -1, -1, -1}, {31146, -1, -1, -1}, {25055, -1, -1, -1}, {24932, -1, -1, -1}, {25059, -1, -1, -1}, {25095, -1, -1, -1}, {28585, -1, -1, -1}, {30959, -1, -1, -1}, {30893, -1, -1, -1}, {30824, -1, -1, -1}, {30904, -1, -1, -1}, {31018, -1, -1, -1}, {31025, -1, -1, -1}, {30820, -1, -1, -1}, {30973, -1, -1, -1}, {30951, -1, -1, -1}, {30947, -1, -1, -1}, {40853, -1, -1, -1}, {30616, -1, -1, -1}, {30558, -1, -1, -1}, {30652, -1, -1, -1}, {32646, -1, -1, -1}, {32648, -1, -1, -1}, {37330, -1, -1, -1}, {37331, -1, -1, -1}, {37332, -1, -1, -1}, {37337, -1, -1, -1}, {37335, -1, -1, -1}, {37333, -1, -1, -1}, {37367, -1, -1, -1}, {37351, -1, -1, -1}, {37348, -1, -1, -1}, {37702, -1, -1, -1}, {37365, -1, -1, -1}, {37369, -1, -1, -1}, {37384, -1, -1, -1} },
+ {{37414, -1, -1, -1}, {37445, -1, -1, -1}, {37393, -1, -1, -1}, {37392, -1, -1, -1}, {37377, -1, -1, -1}, {37415, -1, -1, -1}, {37380, -1, -1, -1}, {37413, -1, -1, -1}, {37376, -1, -1, -1}, {37434, -1, -1, -1}, {37478, -1, -1, -1}, {37431, -1, -1, -1}, {37427, -1, -1, -1}, {37461, -1, -1, -1}, {37437, -1, -1, -1}, {37432, -1, -1, -1}, {37470, -1, -1, -1}, {37484, -1, -1, -1}, {37485, -1, -1, -1}, {37439, -1, -1, -1}, {37984, -1, -1, -1}, {37424, -1, -1, -1}, {37449, -1, -1, -1}, {37448, -1, -1, -1}, {37453, -1, -1, -1}, {37422, -1, -1, -1}, {37433, -1, -1, -1}, {37944, -1, -1, -1}, {37548, -1, -1, -1}, {37536, -1, -1, -1}, {37498, -1, -1, -1}, {37546, -1, -1, -1}, {37614, -1, -1, -1}, {37583, -1, -1, -1}, {37891, -1, -1, -1}, {37603, -1, -1, -1}, {37946, -1, -1, -1}, {37553, -1, -1, -1}, {37542, -1, -1, -1}, {37799, -1, -1, -1}, {37526, -1, -1, -1}, {37580, -1, -1, -1}, {37545, -1, -1, -1}, {37877, -1, -1, -1}, {37523, -1, -1, -1}, {37503, -1, -1, -1}, {37801, -1, -1, -1}, {37530, -1, -1, -1}, {37658, -1, -1, -1}, {37547, -1, -1, -1}, {37507, -1, -1, -1}, {37899, -1, -1, -1}, {37544, -1, -1, -1}, {37539, -1, -1, -1}, {37906, -1, -1, -1}, {37688, -1, -1, -1}, {37617, -1, -1, -1}, {37847, -1, -1, -1}, {37605, -1, -1, -1}, {37616, -1, -1, -1}, {37615, -1, -1, -1}, {37608, -1, -1, -1}, {37564, -1, -1, -1}, {37597, -1, -1, -1}, {37622, -1, -1, -1}, {37926, -1, -1, -1}, {37927, -1, -1, -1}, {37571, -1, -1, -1}, {37599, -1, -1, -1}, {37606, -1, -1, -1}, {37650, -1, -1, -1}, {37638, -1, -1, -1}, {37737, -1, -1, -1}, {37659, -1, -1, -1}, {37696, -1, -1, -1}, {37633, -1, -1, -1}, {37653, -1, -1, -1}, {37678, -1, -1, -1}, {37699, -1, -1, -1}, {37639, -1, -1, -1}, {37640, -1, -1, -1}, {37663, -1, -1, -1}, {37657, -1, -1, -1}, {37733, -1, -1, -1}, {37703, -1, -1, -1}, {37750, -1, -1, -1}, {37716, -1, -1, -1}, {37732, -1, -1, -1}, {37802, -1, -1, -1}, {37744, -1, -1, -1}, {37764, -1, -1, -1}, {37860, -1, -1, -1}, {37848, -1, -1, -1}, {37928, -1, -1, -1}, {37767, -1, -1, -1}, {37836, -1, -1, -1}, {37784, -1, -1, -1}, {37816, -1, -1, -1}, {37823, -1, -1, -1}, {37798, -1, -1, -1}, {37808, -1, -1, -1}, {37813, -1, -1, -1}, {37964, -1, -1, -1}, {37858, -1, -1, -1}, {37852, -1, -1, -1}, {37853, -1, -1, -1}, {37837, -1, -1, -1}, {37854, -1, -1, -1}, {37827, -1, -1, -1}, {37831, -1, -1, -1}, {37841, -1, -1, -1}, {37908, -1, -1, -1}, {37917, -1, -1, -1}, {37879, -1, -1, -1}, {37989, -1, -1, -1}, {37907, -1, -1, -1}, {37997, -1, -1, -1}, {37920, -1, -1, -1}, {38009, -1, -1, -1}, {37881, -1, -1, -1}, {37913, -1, -1, -1}, {37962, -1, -1, -1}, {37938, -1, -1, -1}, {37951, -1, -1, -1}, {37972, -1, -1, -1}, {37987, -1, -1, -1}, {37758, -1, -1, -1}, {31329, -1, -1, -1}, {40169, -1, -1, -1}, {40182, -1, -1, -1}, {40199, -1, -1, -1}, {40198, -1, -1, -1}, {40227, -1, -1, -1}, {40327, -1, -1, -1}, {40469, -1, -1, -1}, {40221, -1, -1, -1}, {40223, -1, -1, -1}, {40421, -1, -1, -1}, {40239, -1, -1, -1}, {40409, -1, -1, -1}, {40240, -1, -1, -1}, {40258, -1, -1, -1}, {40478, -1, -1, -1}, {40275, -1, -1, -1}, {40477, -1, -1, -1}, {40288, -1, -1, -1}, {40274, -1, -1, -1}, {40435, -1, -1, -1}, {40284, -1, -1, -1}, {40289, -1, -1, -1}, {40339, -1, -1, -1}, {40298, -1, -1, -1}, {40303, -1, -1, -1}, {40329, -1, -1, -1}, {40344, -1, -1, -1}, {40346, -1, -1, -1}, {40384, -1, -1, -1}, {40357, -1, -1, -1}, {40361, -1, -1, -1}, {40386, -1, -1, -1}, {40380, -1, -1, -1}, {40474, -1, -1, -1}, {40403, -1, -1, -1}, {40410, -1, -1, -1}, {40431, -1, -1, -1}, {40422, -1, -1, -1}, {40434, -1, -1, -1}, {40440, -1, -1, -1}, {40460, -1, -1, -1}, {40442, -1, -1, -1}, {40475, -1, -1, -1}, {30308, -1, -1, -1}, {30296, -1, -1, -1}, {30311, -1, -1, -1}, {30210, -1, -1, -1}, {30278, -1, -1, -1}, {30279, -1, -1, -1}, {30281, -1, -1, -1}, {30238, -1, -1, -1}, {30267, -1, -1, -1}, {30317, -1, -1, -1}, {30318, -1, -1, -1}, {30313, -1, -1, -1}, {30322, -1, -1, -1}, {31431, -1, -1, -1}, {31414, -1, -1, -1}, {35168, -1, -1, -1}, {35123, -1, -1, -1}, {35165, -1, -1, -1}, {35143, -1, -1, -1}, {35128, -1, -1, -1}, {35172, -1, -1, -1}, {30392, -1, -1, -1}, {32814, -1, -1, -1}, {32812, -1, -1, -1}, {32889, -1, -1, -1}, {32885, -1, -1, -1}, {38919, -1, -1, -1}, {38926, -1, -1, -1}, {38927, -1, -1, -1}, {38945, -1, -1, -1}, {38940, -1, -1, -1}, {28481, -1, -1, -1}, {38950, -1, -1, -1}, {38967, -1, -1, -1}, {38990, -1, -1, -1}, {38995, -1, -1, -1}, {39027, -1, -1, -1}, {39010, -1, -1, -1}, {39001, -1, -1, -1}, {39013, -1, -1, -1}, {39020, -1, -1, -1}, {39024, -1, -1, -1}, {34787, -1, -1, -1}, {34822, -1, -1, -1}, {34566, -1, -1, -1}, {34851, -1, -1, -1}, {34806, -1, -1, -1}, {34554, -1, -1, -1}, {34799, -1, -1, -1}, {34692, -1, -1, -1}, {34832, -1, -1, -1}, {34760, -1, -1, -1}, {34833, -1, -1, -1}, {34747, -1, -1, -1}, {34766, -1, -1, -1}, {32588, -1, -1, -1}, {31716, -1, -1, -1}, {31591, -1, -1, -1}, {31849, -1, -1, -1}, {31731, -1, -1, -1}, {31744, -1, -1, -1}, {31691, -1, -1, -1}, {31836, -1, -1, -1}, {31774, -1, -1, -1}, {31787, -1, -1, -1}, {31779, -1, -1, -1}, {31850, -1, -1, -1}, {31839, -1, -1, -1}, {33380, -1, -1, -1}, {33387, -1, -1, -1}, {35018, -1, -1, -1}, {32677, -1, -1, -1}, {31986, -1, -1, -1}, {31990, -1, -1, -1}, {31965, -1, -1, -1}, {32310, -1, -1, -1}, {40617, -1, -1, -1}, {36274, -1, -1, -1}, {37317, -1, -1, -1}, {37315, -1, -1, -1}, {40570, -1, -1, -1}, {36489, -1, -1, -1}, {36428, -1, -1, -1}, {36498, -1, -1, -1}, {36474, -1, -1, -1} },
+ {{36437, -1, -1, -1}, {36506, -1, -1, -1}, {36491, -1, -1, -1}, {36499, -1, -1, -1}, {36497, -1, -1, -1}, {36513, -1, -1, -1}, {36451, -1, -1, -1}, {36522, -1, -1, -1}, {36518, -1, -1, -1}, {35316, -1, -1, -1}, {35318, -1, -1, -1}, {38746, -1, -1, -1}, {38722, -1, -1, -1}, {38717, -1, -1, -1}, {38724, -1, -1, -1}, {40788, -1, -1, -1}, {40799, -1, -1, -1}, {40793, -1, -1, -1}, {40800, -1, -1, -1}, {40796, -1, -1, -1}, {40806, -1, -1, -1}, {40812, -1, -1, -1}, {40810, -1, -1, -1}, {40823, -1, -1, -1}, {12236, 40701, -1, -1}, {40703, -1, -1, -1}, {40713, -1, -1, -1}, {35726, -1, -1, -1}, {38014, -1, -1, -1}, {37864, -1, -1, -1}, {39799, -1, -1, -1}, {39796, -1, -1, -1}, {39809, -1, -1, -1}, {39811, -1, -1, -1}, {39822, -1, -1, -1}, {40056, -1, -1, -1}, {31308, -1, -1, -1}, {39826, -1, -1, -1}, {40031, -1, -1, -1}, {39824, -1, -1, -1}, {39853, -1, -1, -1}, {39834, -1, -1, -1}, {39850, -1, -1, -1}, {39838, -1, -1, -1}, {40045, -1, -1, -1}, {39851, -1, -1, -1}, {39837, -1, -1, -1}, {40024, -1, -1, -1}, {39873, -1, -1, -1}, {40058, -1, -1, -1}, {39985, -1, -1, -1}, {39993, -1, -1, -1}, {39971, -1, -1, -1}, {39991, -1, -1, -1}, {39872, -1, -1, -1}, {39882, -1, -1, -1}, {39879, -1, -1, -1}, {39933, -1, -1, -1}, {39894, -1, -1, -1}, {39914, -1, -1, -1}, {39915, -1, -1, -1}, {39905, -1, -1, -1}, {39908, -1, -1, -1}, {39911, -1, -1, -1}, {39901, -1, -1, -1}, {39906, -1, -1, -1}, {39920, -1, -1, -1}, {39899, -1, -1, -1}, {39924, -1, -1, -1}, {39892, -1, -1, -1}, {40029, -1, -1, -1}, {39944, -1, -1, -1}, {39952, -1, -1, -1}, {39949, -1, -1, -1}, {39954, -1, -1, -1}, {39945, -1, -1, -1}, {39935, -1, -1, -1}, {39968, -1, -1, -1}, {39986, -1, -1, -1}, {39981, -1, -1, -1}, {39976, -1, -1, -1}, {39973, -1, -1, -1}, {39977, -1, -1, -1}, {39987, -1, -1, -1}, {39998, -1, -1, -1}, {40008, -1, -1, -1}, {39995, -1, -1, -1}, {39989, -1, -1, -1}, {40005, -1, -1, -1}, {40022, -1, -1, -1}, {40020, -1, -1, -1}, {40018, -1, -1, -1}, {40039, -1, -1, -1}, {38851, -1, -1, -1}, {38845, -1, -1, -1}, {38857, -1, -1, -1}, {40379, -1, -1, -1}, {39631, -1, -1, -1}, {39638, -1, -1, -1}, {39637, -1, -1, -1}, {39768, -1, -1, -1}, {39758, -1, -1, -1}, {39255, -1, -1, -1}, {39260, -1, -1, -1}, {39714, -1, -1, -1}, {40695, -1, -1, -1}, {40690, -1, -1, -1}, {35180, -1, -1, -1}, {38342, -1, -1, -1}, {37686, -1, -1, -1}, {24390, -1, -1, -1}, {34068, -1, -1, -1}, {32404, -1, -1, -1}, {40803, -1, -1, -1}, {22137, -1, -1, -1}, {40725, -1, -1, -1}, {22081, -1, -1, -1}, {39662, -1, -1, -1}, {35079, -1, -1, -1}, {31296, -1, -1, -1}, {39091, -1, -1, -1}, {38308, -1, -1, -1}, {39693, -1, -1, -1}, {36852, -1, -1, -1}, {24409, -1, -1, -1}, {31339, -1, -1, -1}, {39138, -1, -1, -1}, {20642, -1, -1, -1}, {34193, -1, -1, -1}, {20760, -1, -1, -1}, {25458, -1, -1, -1}, {21067, -1, -1, -1}, {30543, -1, -1, -1}, {32397, -1, -1, -1}, {26310, -1, -1, -1}, {30637, -1, -1, -1}, {12228, 40565, -1, -1}, {22217, -1, -1, -1}, {40692, -1, -1, -1}, {28635, -1, -1, -1}, {25054, -1, -1, -1}, {30663, -1, -1, -1}, {28720, -1, -1, -1}, {40629, -1, -1, -1}, {34890, -1, -1, -1}, {38370, -1, -1, -1}, {38854, -1, -1, -1}, {31844, -1, -1, -1}, {32308, -1, -1, -1}, {38822, -1, -1, -1}, {40623, -1, -1, -1}, {22220, -1, -1, -1}, {39089, -1, -1, -1}, {27311, -1, -1, -1}, {32590, -1, -1, -1}, {31984, -1, -1, -1}, {20418, -1, -1, -1}, {32363, -1, -1, -1}, {40569, -1, -1, -1}, {22190, -1, -1, -1}, {39706, -1, -1, -1}, {33903, -1, -1, -1}, {31142, -1, -1, -1}, {31858, -1, -1, -1}, {39634, -1, -1, -1}, {38587, -1, -1, -1}, {32251, -1, -1, -1}, {35069, -1, -1, -1}, {30787, -1, -1, -1}, {8560, -1, -1, -1}, {8561, -1, -1, -1}, {8562, -1, -1, -1}, {8563, -1, -1, -1}, {8564, -1, -1, -1}, {8565, -1, -1, -1}, {8566, -1, -1, -1}, {8567, -1, -1, -1}, {8568, -1, -1, -1}, {8569, -1, -1, -1}, {714, -1, -1, -1}, {715, -1, -1, -1}, {729, -1, -1, -1}, {8211, -1, -1, -1}, {8213, -1, -1, -1}, {8229, -1, -1, -1}, {8245, -1, -1, -1}, {8453, -1, -1, -1}, {8457, -1, -1, -1}, {8598, -1, -1, -1}, {8599, -1, -1, -1}, {8600, -1, -1, -1}, {8601, -1, -1, -1}, {8725, -1, -1, -1}, {8735, -1, -1, -1}, {8739, -1, -1, -1}, {8786, -1, -1, -1}, {8806, -1, -1, -1}, {8807, -1, -1, -1}, {8895, -1, -1, -1}, {9552, -1, -1, -1}, {9553, -1, -1, -1}, {9554, -1, -1, -1}, {9555, -1, -1, -1}, {9556, -1, -1, -1}, {9557, -1, -1, -1}, {9558, -1, -1, -1}, {9559, -1, -1, -1}, {9560, -1, -1, -1}, {9561, -1, -1, -1}, {9562, -1, -1, -1}, {9563, -1, -1, -1}, {9564, -1, -1, -1}, {9565, -1, -1, -1}, {9566, -1, -1, -1}, {9567, -1, -1, -1}, {9568, -1, -1, -1}, {9569, -1, -1, -1}, {9570, -1, -1, -1}, {9571, -1, -1, -1}, {9572, -1, -1, -1}, {9573, -1, -1, -1}, {9574, -1, -1, -1}, {9575, -1, -1, -1}, {9576, -1, -1, -1}, {9577, -1, -1, -1}, {9578, -1, -1, -1}, {9579, -1, -1, -1}, {9580, -1, -1, -1}, {9581, -1, -1, -1}, {9582, -1, -1, -1}, {9583, -1, -1, -1}, {9584, -1, -1, -1}, {9585, -1, -1, -1}, {9586, -1, -1, -1}, {9587, -1, -1, -1}, {9601, -1, -1, -1}, {9602, -1, -1, -1}, {9603, -1, -1, -1}, {9604, -1, -1, -1}, {9605, -1, -1, -1}, {9606, -1, -1, -1}, {9607, -1, -1, -1}, {9608, -1, -1, -1}, {9609, -1, -1, -1}, {9610, -1, -1, -1}, {9611, -1, -1, -1}, {9612, -1, -1, -1}, {9613, -1, -1, -1}, {9614, -1, -1, -1}, {9615, -1, -1, -1}, {9619, -1, -1, -1}, {9620, -1, -1, -1}, {9621, -1, -1, -1}, {9660, -1, -1, -1}, {9661, -1, -1, -1}, {9698, -1, -1, -1} },
+ {{9699, -1, -1, -1}, {9700, -1, -1, -1}, {9701, -1, -1, -1}, {9737, -1, -1, -1}, {8853, -1, -1, -1}, {12306, -1, -1, -1}, {12317, -1, -1, -1}, {12318, -1, -1, -1}, {12321, -1, -1, -1}, {12322, -1, -1, -1}, {12323, -1, -1, -1}, {12324, -1, -1, -1}, {12325, -1, -1, -1}, {12326, -1, -1, -1}, {12327, -1, -1, -1}, {12328, -1, -1, -1}, {12329, -1, -1, -1}, {12963, -1, -1, -1}, {13198, -1, -1, -1}, {13199, -1, -1, -1}, {13212, -1, -1, -1}, {13213, -1, -1, -1}, {13214, -1, -1, -1}, {13217, -1, -1, -1}, {13252, -1, -1, -1}, {13262, -1, -1, -1}, {13265, -1, -1, -1}, {13266, -1, -1, -1}, {13269, -1, -1, -1}, {65072, -1, -1, -1}, {65506, -1, -1, -1}, {65508, -1, -1, -1}, {8481, -1, -1, -1}, {12849, -1, -1, -1}, {8208, -1, -1, -1}, {12540, -1, -1, -1}, {12443, -1, -1, -1}, {12444, -1, -1, -1}, {12541, -1, -1, -1}, {12542, -1, -1, -1}, {12294, -1, -1, -1}, {12445, -1, -1, -1}, {12446, -1, -1, -1}, {65097, -1, -1, -1}, {65098, -1, -1, -1}, {65099, -1, -1, -1}, {65100, -1, -1, -1}, {65101, -1, -1, -1}, {65102, -1, -1, -1}, {65103, -1, -1, -1}, {65104, -1, -1, -1}, {65105, -1, -1, -1}, {65106, -1, -1, -1}, {65108, -1, -1, -1}, {65109, -1, -1, -1}, {65110, -1, -1, -1}, {65111, -1, -1, -1}, {65113, -1, -1, -1}, {65114, -1, -1, -1}, {65115, -1, -1, -1}, {65116, -1, -1, -1}, {65117, -1, -1, -1}, {65118, -1, -1, -1}, {65119, -1, -1, -1}, {65120, -1, -1, -1}, {65121, -1, -1, -1}, {65122, -1, -1, -1}, {65123, -1, -1, -1}, {65124, -1, -1, -1}, {65125, -1, -1, -1}, {65126, -1, -1, -1}, {65128, -1, -1, -1}, {65129, -1, -1, -1}, {65130, -1, -1, -1}, {65131, -1, -1, -1}, {12350, -1, -1, -1}, {12272, -1, -1, -1}, {12273, -1, -1, -1}, {12274, -1, -1, -1}, {12275, -1, -1, -1}, {12276, -1, -1, -1}, {12277, -1, -1, -1}, {12278, -1, -1, -1}, {12279, -1, -1, -1}, {12280, -1, -1, -1}, {12281, -1, -1, -1}, {12282, -1, -1, -1}, {12283, -1, -1, -1}, {19970, -1, -1, -1}, {19972, -1, -1, -1}, {19973, -1, -1, -1}, {19974, -1, -1, -1}, {19983, -1, -1, -1}, {19986, -1, -1, -1}, {19991, -1, -1, -1}, {19999, -1, -1, -1}, {20000, -1, -1, -1}, {20001, -1, -1, -1}, {20003, -1, -1, -1}, {20006, -1, -1, -1}, {20009, -1, -1, -1}, {20014, -1, -1, -1}, {20015, -1, -1, -1}, {20017, -1, -1, -1}, {20019, -1, -1, -1}, {20021, -1, -1, -1}, {20023, -1, -1, -1}, {20028, -1, -1, -1}, {20032, -1, -1, -1}, {20033, -1, -1, -1}, {20034, -1, -1, -1}, {20036, -1, -1, -1}, {20038, -1, -1, -1}, {20042, -1, -1, -1}, {20049, -1, -1, -1}, {20053, -1, -1, -1}, {20055, -1, -1, -1}, {20058, -1, -1, -1}, {20059, -1, -1, -1}, {20066, -1, -1, -1}, {20067, -1, -1, -1}, {20068, -1, -1, -1}, {20069, -1, -1, -1}, {20071, -1, -1, -1}, {20072, -1, -1, -1}, {20074, -1, -1, -1}, {20075, -1, -1, -1}, {20076, -1, -1, -1}, {20077, -1, -1, -1}, {20078, -1, -1, -1}, {20079, -1, -1, -1}, {20082, -1, -1, -1}, {20084, -1, -1, -1}, {20085, -1, -1, -1}, {20086, -1, -1, -1}, {20087, -1, -1, -1}, {20088, -1, -1, -1}, {20089, -1, -1, -1}, {20090, -1, -1, -1}, {20091, -1, -1, -1}, {20092, -1, -1, -1}, {20093, -1, -1, -1}, {20095, -1, -1, -1}, {20096, -1, -1, -1}, {20097, -1, -1, -1}, {20099, -1, -1, -1}, {20100, -1, -1, -1}, {12037, 20101, -1, -1}, {20103, -1, -1, -1}, {20106, -1, -1, -1}, {20112, -1, -1, -1}, {20118, -1, -1, -1}, {20119, -1, -1, -1}, {20121, -1, -1, -1}, {20124, -1, -1, -1}, {20125, -1, -1, -1}, {20131, -1, -1, -1}, {20138, -1, -1, -1}, {20143, -1, -1, -1}, {20144, -1, -1, -1}, {20145, -1, -1, -1}, {20148, -1, -1, -1}, {20150, -1, -1, -1}, {20151, -1, -1, -1}, {20152, -1, -1, -1}, {20153, -1, -1, -1}, {20156, -1, -1, -1}, {20157, -1, -1, -1}, {20158, -1, -1, -1}, {20168, -1, -1, -1}, {20172, -1, -1, -1}, {20175, -1, -1, -1}, {20176, -1, -1, -1}, {20178, -1, -1, -1}, {20186, -1, -1, -1}, {20187, -1, -1, -1}, {20188, -1, -1, -1}, {20192, -1, -1, -1}, {20194, -1, -1, -1}, {20198, -1, -1, -1}, {20199, -1, -1, -1}, {20201, -1, -1, -1}, {20205, -1, -1, -1}, {20206, -1, -1, -1}, {20207, -1, -1, -1}, {20209, -1, -1, -1}, {20212, -1, -1, -1}, {20216, -1, -1, -1}, {20217, -1, -1, -1}, {20218, -1, -1, -1}, {20220, -1, -1, -1}, {20222, -1, -1, -1}, {20224, -1, -1, -1}, {20226, -1, -1, -1}, {20227, -1, -1, -1}, {20228, -1, -1, -1}, {20229, -1, -1, -1}, {20230, -1, -1, -1}, {20231, -1, -1, -1}, {20232, -1, -1, -1}, {20235, -1, -1, -1}, {20236, -1, -1, -1}, {20242, -1, -1, -1}, {20243, -1, -1, -1}, {20244, -1, -1, -1}, {20245, -1, -1, -1}, {20246, -1, -1, -1}, {20252, -1, -1, -1}, {20253, -1, -1, -1}, {20257, -1, -1, -1}, {20259, -1, -1, -1}, {20264, -1, -1, -1}, {20265, -1, -1, -1}, {20268, -1, -1, -1}, {20269, -1, -1, -1}, {20270, -1, -1, -1}, {20273, -1, -1, -1}, {20275, -1, -1, -1}, {20277, -1, -1, -1}, {20279, -1, -1, -1}, {20281, -1, -1, -1}, {20283, -1, -1, -1}, {20286, -1, -1, -1}, {20287, -1, -1, -1}, {20288, -1, -1, -1}, {20289, -1, -1, -1}, {20290, -1, -1, -1}, {20292, -1, -1, -1}, {20293, -1, -1, -1}, {20295, -1, -1, -1}, {20296, -1, -1, -1}, {20297, -1, -1, -1}, {20298, -1, -1, -1}, {20299, -1, -1, -1}, {20300, -1, -1, -1}, {20306, -1, -1, -1}, {20308, -1, -1, -1}, {20310, -1, -1, -1}, {20321, -1, -1, -1}, {20322, -1, -1, -1}, {20326, -1, -1, -1}, {20328, -1, -1, -1}, {20330, -1, -1, -1}, {20331, -1, -1, -1}, {20333, -1, -1, -1}, {20334, -1, -1, -1}, {20337, -1, -1, -1}, {20338, -1, -1, -1}, {20341, -1, -1, -1}, {20343, -1, -1, -1}, {20344, -1, -1, -1}, {20345, -1, -1, -1}, {20346, -1, -1, -1}, {20349, -1, -1, -1}, {20352, -1, -1, -1}, {20353, -1, -1, -1} },
+ {{20354, -1, -1, -1}, {20357, -1, -1, -1}, {20359, -1, -1, -1}, {20362, -1, -1, -1}, {20364, -1, -1, -1}, {20366, -1, -1, -1}, {20368, -1, -1, -1}, {20370, -1, -1, -1}, {20371, -1, -1, -1}, {20373, -1, -1, -1}, {20376, -1, -1, -1}, {20377, -1, -1, -1}, {20378, -1, -1, -1}, {20380, -1, -1, -1}, {20382, -1, -1, -1}, {20383, -1, -1, -1}, {20385, -1, -1, -1}, {20386, -1, -1, -1}, {20388, -1, -1, -1}, {20395, -1, -1, -1}, {20397, -1, -1, -1}, {20400, -1, -1, -1}, {20401, -1, -1, -1}, {20402, -1, -1, -1}, {20403, -1, -1, -1}, {20404, -1, -1, -1}, {20406, -1, -1, -1}, {20407, -1, -1, -1}, {20408, -1, -1, -1}, {20409, -1, -1, -1}, {20410, -1, -1, -1}, {20411, -1, -1, -1}, {20412, -1, -1, -1}, {20413, -1, -1, -1}, {20414, -1, -1, -1}, {20416, -1, -1, -1}, {20417, -1, -1, -1}, {20422, -1, -1, -1}, {20423, -1, -1, -1}, {20424, -1, -1, -1}, {20425, -1, -1, -1}, {20427, -1, -1, -1}, {20428, -1, -1, -1}, {20429, -1, -1, -1}, {20434, -1, -1, -1}, {20435, -1, -1, -1}, {20436, -1, -1, -1}, {20437, -1, -1, -1}, {20438, -1, -1, -1}, {20441, -1, -1, -1}, {20443, -1, -1, -1}, {20450, -1, -1, -1}, {20452, -1, -1, -1}, {20453, -1, -1, -1}, {20455, -1, -1, -1}, {20459, -1, -1, -1}, {20460, -1, -1, -1}, {20464, -1, -1, -1}, {20466, -1, -1, -1}, {20468, -1, -1, -1}, {20469, -1, -1, -1}, {20470, -1, -1, -1}, {20471, -1, -1, -1}, {20473, -1, -1, -1}, {20475, -1, -1, -1}, {20476, -1, -1, -1}, {20477, -1, -1, -1}, {20479, -1, -1, -1}, {20481, -1, -1, -1}, {20482, -1, -1, -1}, {20483, -1, -1, -1}, {20484, -1, -1, -1}, {20485, -1, -1, -1}, {20487, -1, -1, -1}, {20488, -1, -1, -1}, {20490, -1, -1, -1}, {20494, -1, -1, -1}, {20496, -1, -1, -1}, {20499, -1, -1, -1}, {20501, -1, -1, -1}, {20502, -1, -1, -1}, {20503, -1, -1, -1}, {20507, -1, -1, -1}, {20509, -1, -1, -1}, {20510, -1, -1, -1}, {20512, -1, -1, -1}, {20514, -1, -1, -1}, {20515, -1, -1, -1}, {20516, -1, -1, -1}, {20519, -1, -1, -1}, {20527, -1, -1, -1}, {20528, -1, -1, -1}, {20529, -1, -1, -1}, {20530, -1, -1, -1}, {20531, -1, -1, -1}, {20532, -1, -1, -1}, {20533, -1, -1, -1}, {20534, -1, -1, -1}, {20535, -1, -1, -1}, {20536, -1, -1, -1}, {20537, -1, -1, -1}, {20539, -1, -1, -1}, {20541, -1, -1, -1}, {20543, -1, -1, -1}, {20544, -1, -1, -1}, {20545, -1, -1, -1}, {20546, -1, -1, -1}, {20548, -1, -1, -1}, {20549, -1, -1, -1}, {20550, -1, -1, -1}, {20554, -1, -1, -1}, {20555, -1, -1, -1}, {20557, -1, -1, -1}, {20560, -1, -1, -1}, {20561, -1, -1, -1}, {20562, -1, -1, -1}, {20563, -1, -1, -1}, {20564, -1, -1, -1}, {20566, -1, -1, -1}, {20567, -1, -1, -1}, {20568, -1, -1, -1}, {20569, -1, -1, -1}, {20571, -1, -1, -1}, {20573, -1, -1, -1}, {20574, -1, -1, -1}, {20575, -1, -1, -1}, {20576, -1, -1, -1}, {20577, -1, -1, -1}, {20578, -1, -1, -1}, {20579, -1, -1, -1}, {20580, -1, -1, -1}, {20582, -1, -1, -1}, {20583, -1, -1, -1}, {20584, -1, -1, -1}, {20585, -1, -1, -1}, {20586, -1, -1, -1}, {20587, -1, -1, -1}, {20589, -1, -1, -1}, {20590, -1, -1, -1}, {20591, -1, -1, -1}, {20592, -1, -1, -1}, {20593, -1, -1, -1}, {20594, -1, -1, -1}, {20595, -1, -1, -1}, {20600, -1, -1, -1}, {20601, -1, -1, -1}, {20602, -1, -1, -1}, {20604, -1, -1, -1}, {20605, -1, -1, -1}, {20609, -1, -1, -1}, {20610, -1, -1, -1}, {20611, -1, -1, -1}, {20612, -1, -1, -1}, {20614, -1, -1, -1}, {20615, -1, -1, -1}, {20617, -1, -1, -1}, {20618, -1, -1, -1}, {20619, -1, -1, -1}, {20620, -1, -1, -1}, {20622, -1, -1, -1}, {20623, -1, -1, -1}, {20624, -1, -1, -1}, {20625, -1, -1, -1}, {20626, -1, -1, -1}, {20627, -1, -1, -1}, {20628, -1, -1, -1}, {20629, -1, -1, -1}, {20631, -1, -1, -1}, {20634, -1, -1, -1}, {20635, -1, -1, -1}, {20636, -1, -1, -1}, {20637, -1, -1, -1}, {20638, -1, -1, -1}, {20639, -1, -1, -1}, {20640, -1, -1, -1}, {20641, -1, -1, -1}, {20644, -1, -1, -1}, {20646, -1, -1, -1}, {20650, -1, -1, -1}, {20651, -1, -1, -1}, {20654, -1, -1, -1}, {20655, -1, -1, -1}, {20656, -1, -1, -1}, {20657, -1, -1, -1}, {20662, -1, -1, -1}, {20664, -1, -1, -1}, {20665, -1, -1, -1}, {20668, -1, -1, -1}, {20669, -1, -1, -1}, {20671, -1, -1, -1}, {20672, -1, -1, -1}, {20673, -1, -1, -1}, {20675, -1, -1, -1}, {20676, -1, -1, -1}, {20678, -1, -1, -1}, {20679, -1, -1, -1}, {20680, -1, -1, -1}, {20682, -1, -1, -1}, {20683, -1, -1, -1}, {20684, -1, -1, -1}, {20685, -1, -1, -1}, {20686, -1, -1, -1}, {20688, -1, -1, -1}, {20690, -1, -1, -1}, {20691, -1, -1, -1}, {20692, -1, -1, -1}, {20695, -1, -1, -1}, {20696, -1, -1, -1}, {20697, -1, -1, -1}, {20699, -1, -1, -1}, {20700, -1, -1, -1}, {20701, -1, -1, -1}, {20703, -1, -1, -1}, {20704, -1, -1, -1}, {20705, -1, -1, -1}, {20706, -1, -1, -1}, {20707, -1, -1, -1}, {20708, -1, -1, -1}, {20713, -1, -1, -1}, {20714, -1, -1, -1}, {20715, -1, -1, -1}, {20719, -1, -1, -1}, {20720, -1, -1, -1}, {20721, -1, -1, -1}, {20722, -1, -1, -1}, {20724, -1, -1, -1}, {20726, -1, -1, -1}, {20727, -1, -1, -1}, {20728, -1, -1, -1}, {20730, -1, -1, -1}, {20732, -1, -1, -1}, {20733, -1, -1, -1}, {20734, -1, -1, -1}, {20735, -1, -1, -1}, {20737, -1, -1, -1}, {20739, -1, -1, -1}, {20741, -1, -1, -1}, {20746, -1, -1, -1}, {20748, -1, -1, -1}, {20749, -1, -1, -1}, {20750, -1, -1, -1}, {20751, -1, -1, -1}, {20753, -1, -1, -1}, {20755, -1, -1, -1}, {20758, -1, -1, -1}, {20759, -1, -1, -1}, {20761, -1, -1, -1}, {20762, -1, -1, -1}, {20763, -1, -1, -1}, {20764, -1, -1, -1}, {20765, -1, -1, -1}, {20766, -1, -1, -1}, {20768, -1, -1, -1}, {20770, -1, -1, -1}, {20771, -1, -1, -1}, {20772, -1, -1, -1} },
+ {{20773, -1, -1, -1}, {20774, -1, -1, -1}, {20775, -1, -1, -1}, {20776, -1, -1, -1}, {20777, -1, -1, -1}, {20779, -1, -1, -1}, {20780, -1, -1, -1}, {20781, -1, -1, -1}, {20782, -1, -1, -1}, {20783, -1, -1, -1}, {20784, -1, -1, -1}, {20785, -1, -1, -1}, {20787, -1, -1, -1}, {20788, -1, -1, -1}, {20789, -1, -1, -1}, {20790, -1, -1, -1}, {20792, -1, -1, -1}, {20793, -1, -1, -1}, {20797, -1, -1, -1}, {20798, -1, -1, -1}, {20802, -1, -1, -1}, {20807, -1, -1, -1}, {20810, -1, -1, -1}, {20812, -1, -1, -1}, {20814, -1, -1, -1}, {20815, -1, -1, -1}, {20816, -1, -1, -1}, {20819, -1, -1, -1}, {20823, -1, -1, -1}, {20824, -1, -1, -1}, {20825, -1, -1, -1}, {20827, -1, -1, -1}, {20829, -1, -1, -1}, {20830, -1, -1, -1}, {20831, -1, -1, -1}, {20832, -1, -1, -1}, {20833, -1, -1, -1}, {20835, -1, -1, -1}, {20836, -1, -1, -1}, {20838, -1, -1, -1}, {20839, -1, -1, -1}, {20842, -1, -1, -1}, {20847, -1, -1, -1}, {20850, -1, -1, -1}, {20858, -1, -1, -1}, {20862, -1, -1, -1}, {20863, -1, -1, -1}, {20867, -1, -1, -1}, {20868, -1, -1, -1}, {20870, -1, -1, -1}, {20871, -1, -1, -1}, {20874, -1, -1, -1}, {20875, -1, -1, -1}, {20878, -1, -1, -1}, {20879, -1, -1, -1}, {20880, -1, -1, -1}, {20881, -1, -1, -1}, {20883, -1, -1, -1}, {20884, -1, -1, -1}, {20888, -1, -1, -1}, {20890, -1, -1, -1}, {20893, -1, -1, -1}, {20894, -1, -1, -1}, {20895, -1, -1, -1}, {20897, -1, -1, -1}, {20899, -1, -1, -1}, {20902, -1, -1, -1}, {20903, -1, -1, -1}, {20904, -1, -1, -1}, {20905, -1, -1, -1}, {20906, -1, -1, -1}, {20909, -1, -1, -1}, {20910, -1, -1, -1}, {20916, -1, -1, -1}, {20920, -1, -1, -1}, {20921, -1, -1, -1}, {20922, -1, -1, -1}, {20926, -1, -1, -1}, {20927, -1, -1, -1}, {20929, -1, -1, -1}, {20930, -1, -1, -1}, {20931, -1, -1, -1}, {20933, -1, -1, -1}, {20936, -1, -1, -1}, {20938, -1, -1, -1}, {20942, -1, -1, -1}, {20944, -1, -1, -1}, {20946, -1, -1, -1}, {20947, -1, -1, -1}, {20948, -1, -1, -1}, {20949, -1, -1, -1}, {20950, -1, -1, -1}, {20951, -1, -1, -1}, {20952, -1, -1, -1}, {20953, -1, -1, -1}, {20954, -1, -1, -1}, {20956, -1, -1, -1}, {20958, -1, -1, -1}, {20959, -1, -1, -1}, {20962, -1, -1, -1}, {20963, -1, -1, -1}, {20965, -1, -1, -1}, {20966, -1, -1, -1}, {20967, -1, -1, -1}, {20968, -1, -1, -1}, {20969, -1, -1, -1}, {20970, -1, -1, -1}, {20972, -1, -1, -1}, {20974, -1, -1, -1}, {20978, -1, -1, -1}, {20980, -1, -1, -1}, {20983, -1, -1, -1}, {20990, -1, -1, -1}, {20996, -1, -1, -1}, {20997, -1, -1, -1}, {21001, -1, -1, -1}, {21003, -1, -1, -1}, {21004, -1, -1, -1}, {21007, -1, -1, -1}, {21008, -1, -1, -1}, {21011, -1, -1, -1}, {21012, -1, -1, -1}, {21013, -1, -1, -1}, {21020, -1, -1, -1}, {21022, -1, -1, -1}, {21023, -1, -1, -1}, {21025, -1, -1, -1}, {21026, -1, -1, -1}, {21027, -1, -1, -1}, {21029, -1, -1, -1}, {21030, -1, -1, -1}, {21031, -1, -1, -1}, {21034, -1, -1, -1}, {21036, -1, -1, -1}, {21039, -1, -1, -1}, {21041, -1, -1, -1}, {21042, -1, -1, -1}, {21044, -1, -1, -1}, {21045, -1, -1, -1}, {21052, -1, -1, -1}, {21054, -1, -1, -1}, {21061, -1, -1, -1}, {21062, -1, -1, -1}, {21064, -1, -1, -1}, {21065, -1, -1, -1}, {21070, -1, -1, -1}, {21071, -1, -1, -1}, {21074, -1, -1, -1}, {21075, -1, -1, -1}, {21077, -1, -1, -1}, {21079, -1, -1, -1}, {21080, -1, -1, -1}, {21081, -1, -1, -1}, {21082, -1, -1, -1}, {21085, -1, -1, -1}, {21087, -1, -1, -1}, {21088, -1, -1, -1}, {21090, -1, -1, -1}, {21091, -1, -1, -1}, {21092, -1, -1, -1}, {21094, -1, -1, -1}, {21096, -1, -1, -1}, {21099, -1, -1, -1}, {21100, -1, -1, -1}, {21101, -1, -1, -1}, {21104, -1, -1, -1}, {21105, -1, -1, -1}, {21107, -1, -1, -1}, {21110, -1, -1, -1}, {21111, -1, -1, -1}, {21112, -1, -1, -1}, {21113, -1, -1, -1}, {21114, -1, -1, -1}, {21115, -1, -1, -1}, {21116, -1, -1, -1}, {21118, -1, -1, -1}, {21120, -1, -1, -1}, {21124, -1, -1, -1}, {21125, -1, -1, -1}, {21126, -1, -1, -1}, {21131, -1, -1, -1}, {21134, -1, -1, -1}, {21135, -1, -1, -1}, {21138, -1, -1, -1}, {21140, -1, -1, -1}, {21141, -1, -1, -1}, {21142, -1, -1, -1}, {21143, -1, -1, -1}, {21144, -1, -1, -1}, {21145, -1, -1, -1}, {21146, -1, -1, -1}, {21148, -1, -1, -1}, {21156, -1, -1, -1}, {21157, -1, -1, -1}, {21158, -1, -1, -1}, {21159, -1, -1, -1}, {21166, -1, -1, -1}, {21167, -1, -1, -1}, {21168, -1, -1, -1}, {21172, -1, -1, -1}, {21173, -1, -1, -1}, {21174, -1, -1, -1}, {21175, -1, -1, -1}, {21176, -1, -1, -1}, {21177, -1, -1, -1}, {21178, -1, -1, -1}, {21179, -1, -1, -1}, {21180, -1, -1, -1}, {21181, -1, -1, -1}, {21184, -1, -1, -1}, {21186, -1, -1, -1}, {21188, -1, -1, -1}, {21189, -1, -1, -1}, {21190, -1, -1, -1}, {21192, -1, -1, -1}, {21194, -1, -1, -1}, {21196, -1, -1, -1}, {21197, -1, -1, -1}, {21198, -1, -1, -1}, {21199, -1, -1, -1}, {21201, -1, -1, -1}, {21203, -1, -1, -1}, {21204, -1, -1, -1}, {21207, -1, -1, -1}, {21210, -1, -1, -1}, {21212, -1, -1, -1}, {21216, -1, -1, -1}, {21217, -1, -1, -1}, {21219, -1, -1, -1}, {21221, -1, -1, -1}, {21222, -1, -1, -1}, {21223, -1, -1, -1}, {21224, -1, -1, -1}, {21225, -1, -1, -1}, {21226, -1, -1, -1}, {21227, -1, -1, -1}, {21228, -1, -1, -1}, {21229, -1, -1, -1}, {21230, -1, -1, -1}, {21231, -1, -1, -1}, {21234, -1, -1, -1}, {21235, -1, -1, -1}, {21236, -1, -1, -1}, {21238, -1, -1, -1}, {21239, -1, -1, -1}, {21243, -1, -1, -1}, {21244, -1, -1, -1}, {21245, -1, -1, -1}, {21249, -1, -1, -1}, {21250, -1, -1, -1}, {21251, -1, -1, -1}, {21252, -1, -1, -1}, {21255, -1, -1, -1}, {21257, -1, -1, -1}, {21258, -1, -1, -1}, {21259, -1, -1, -1} },
+ {{21260, -1, -1, -1}, {21262, -1, -1, -1}, {21265, -1, -1, -1}, {21266, -1, -1, -1}, {21267, -1, -1, -1}, {21268, -1, -1, -1}, {21272, -1, -1, -1}, {21275, -1, -1, -1}, {21276, -1, -1, -1}, {21278, -1, -1, -1}, {21279, -1, -1, -1}, {21282, -1, -1, -1}, {21284, -1, -1, -1}, {21285, -1, -1, -1}, {21287, -1, -1, -1}, {21288, -1, -1, -1}, {21289, -1, -1, -1}, {21291, -1, -1, -1}, {21292, -1, -1, -1}, {21296, -1, -1, -1}, {21298, -1, -1, -1}, {21299, -1, -1, -1}, {21300, -1, -1, -1}, {21301, -1, -1, -1}, {21302, -1, -1, -1}, {21303, -1, -1, -1}, {12054, 21304, -1, -1}, {21308, -1, -1, -1}, {21309, -1, -1, -1}, {21314, -1, -1, -1}, {21316, -1, -1, -1}, {21318, -1, -1, -1}, {21323, -1, -1, -1}, {21324, -1, -1, -1}, {21325, -1, -1, -1}, {21328, -1, -1, -1}, {21336, -1, -1, -1}, {21337, -1, -1, -1}, {21339, -1, -1, -1}, {21341, -1, -1, -1}, {21349, -1, -1, -1}, {21352, -1, -1, -1}, {21354, -1, -1, -1}, {21356, -1, -1, -1}, {21357, -1, -1, -1}, {21362, -1, -1, -1}, {21366, -1, -1, -1}, {21369, -1, -1, -1}, {21371, -1, -1, -1}, {21372, -1, -1, -1}, {21373, -1, -1, -1}, {21374, -1, -1, -1}, {21376, -1, -1, -1}, {21377, -1, -1, -1}, {21379, -1, -1, -1}, {21383, -1, -1, -1}, {21384, -1, -1, -1}, {21386, -1, -1, -1}, {21390, -1, -1, -1}, {21391, -1, -1, -1}, {21392, -1, -1, -1}, {21393, -1, -1, -1}, {21394, -1, -1, -1}, {21395, -1, -1, -1}, {21396, -1, -1, -1}, {21398, -1, -1, -1}, {21399, -1, -1, -1}, {21403, -1, -1, -1}, {21404, -1, -1, -1}, {21406, -1, -1, -1}, {21409, -1, -1, -1}, {21412, -1, -1, -1}, {21415, -1, -1, -1}, {21418, -1, -1, -1}, {21419, -1, -1, -1}, {21420, -1, -1, -1}, {21423, -1, -1, -1}, {21424, -1, -1, -1}, {21425, -1, -1, -1}, {21427, -1, -1, -1}, {21429, -1, -1, -1}, {21431, -1, -1, -1}, {21432, -1, -1, -1}, {21433, -1, -1, -1}, {21434, -1, -1, -1}, {21436, -1, -1, -1}, {21437, -1, -1, -1}, {21438, -1, -1, -1}, {21440, -1, -1, -1}, {21444, -1, -1, -1}, {21445, -1, -1, -1}, {21446, -1, -1, -1}, {21447, -1, -1, -1}, {21454, -1, -1, -1}, {21455, -1, -1, -1}, {21456, -1, -1, -1}, {21458, -1, -1, -1}, {21459, -1, -1, -1}, {21461, -1, -1, -1}, {21466, -1, -1, -1}, {21468, -1, -1, -1}, {21469, -1, -1, -1}, {21470, -1, -1, -1}, {21473, -1, -1, -1}, {21479, -1, -1, -1}, {21492, -1, -1, -1}, {21498, -1, -1, -1}, {21502, -1, -1, -1}, {21503, -1, -1, -1}, {21504, -1, -1, -1}, {21506, -1, -1, -1}, {21509, -1, -1, -1}, {21511, -1, -1, -1}, {21515, -1, -1, -1}, {21524, -1, -1, -1}, {21528, -1, -1, -1}, {21529, -1, -1, -1}, {21530, -1, -1, -1}, {21532, -1, -1, -1}, {21538, -1, -1, -1}, {21540, -1, -1, -1}, {21541, -1, -1, -1}, {21546, -1, -1, -1}, {21552, -1, -1, -1}, {21555, -1, -1, -1}, {21558, -1, -1, -1}, {21559, -1, -1, -1}, {21562, -1, -1, -1}, {21565, -1, -1, -1}, {21567, -1, -1, -1}, {21569, -1, -1, -1}, {21570, -1, -1, -1}, {21572, -1, -1, -1}, {21573, -1, -1, -1}, {21575, -1, -1, -1}, {21577, -1, -1, -1}, {21580, -1, -1, -1}, {21581, -1, -1, -1}, {21582, -1, -1, -1}, {21583, -1, -1, -1}, {21585, -1, -1, -1}, {21594, -1, -1, -1}, {21597, -1, -1, -1}, {21598, -1, -1, -1}, {21599, -1, -1, -1}, {21600, -1, -1, -1}, {21601, -1, -1, -1}, {21603, -1, -1, -1}, {21605, -1, -1, -1}, {21607, -1, -1, -1}, {21609, -1, -1, -1}, {21610, -1, -1, -1}, {21611, -1, -1, -1}, {21612, -1, -1, -1}, {21613, -1, -1, -1}, {21614, -1, -1, -1}, {21615, -1, -1, -1}, {21616, -1, -1, -1}, {21620, -1, -1, -1}, {21625, -1, -1, -1}, {21626, -1, -1, -1}, {21630, -1, -1, -1}, {21631, -1, -1, -1}, {21633, -1, -1, -1}, {21635, -1, -1, -1}, {21637, -1, -1, -1}, {21639, -1, -1, -1}, {21640, -1, -1, -1}, {21641, -1, -1, -1}, {21642, -1, -1, -1}, {21645, -1, -1, -1}, {21649, -1, -1, -1}, {21651, -1, -1, -1}, {21655, -1, -1, -1}, {21656, -1, -1, -1}, {21660, -1, -1, -1}, {21662, -1, -1, -1}, {21663, -1, -1, -1}, {21664, -1, -1, -1}, {21665, -1, -1, -1}, {21666, -1, -1, -1}, {21669, -1, -1, -1}, {21678, -1, -1, -1}, {21680, -1, -1, -1}, {21682, -1, -1, -1}, {21685, -1, -1, -1}, {21686, -1, -1, -1}, {21687, -1, -1, -1}, {21689, -1, -1, -1}, {21690, -1, -1, -1}, {21694, -1, -1, -1}, {21699, -1, -1, -1}, {21701, -1, -1, -1}, {21706, -1, -1, -1}, {21707, -1, -1, -1}, {21718, -1, -1, -1}, {21720, -1, -1, -1}, {21723, -1, -1, -1}, {21728, -1, -1, -1}, {21730, -1, -1, -1}, {21731, -1, -1, -1}, {21732, -1, -1, -1}, {21739, -1, -1, -1}, {21740, -1, -1, -1}, {21743, -1, -1, -1}, {21744, -1, -1, -1}, {21745, -1, -1, -1}, {21748, -1, -1, -1}, {21749, -1, -1, -1}, {21750, -1, -1, -1}, {21751, -1, -1, -1}, {21752, -1, -1, -1}, {21753, -1, -1, -1}, {21755, -1, -1, -1}, {21758, -1, -1, -1}, {21760, -1, -1, -1}, {21762, -1, -1, -1}, {21763, -1, -1, -1}, {21765, -1, -1, -1}, {21768, -1, -1, -1}, {21770, -1, -1, -1}, {21771, -1, -1, -1}, {21772, -1, -1, -1}, {21773, -1, -1, -1}, {21774, -1, -1, -1}, {21778, -1, -1, -1}, {21779, -1, -1, -1}, {21781, -1, -1, -1}, {21782, -1, -1, -1}, {21783, -1, -1, -1}, {21784, -1, -1, -1}, {21785, -1, -1, -1}, {21786, -1, -1, -1}, {21788, -1, -1, -1}, {21789, -1, -1, -1}, {21790, -1, -1, -1}, {21791, -1, -1, -1}, {21793, -1, -1, -1}, {21797, -1, -1, -1}, {21798, -1, -1, -1}, {21800, -1, -1, -1}, {21801, -1, -1, -1}, {21803, -1, -1, -1}, {21805, -1, -1, -1}, {21810, -1, -1, -1}, {21812, -1, -1, -1}, {21813, -1, -1, -1}, {21814, -1, -1, -1}, {21816, -1, -1, -1}, {21817, -1, -1, -1}, {21818, -1, -1, -1}, {21819, -1, -1, -1}, {21821, -1, -1, -1}, {21824, -1, -1, -1}, {21826, -1, -1, -1}, {21829, -1, -1, -1} },
+ {{21831, -1, -1, -1}, {21832, -1, -1, -1}, {21835, -1, -1, -1}, {21836, -1, -1, -1}, {21837, -1, -1, -1}, {21838, -1, -1, -1}, {21841, -1, -1, -1}, {21842, -1, -1, -1}, {21844, -1, -1, -1}, {21847, -1, -1, -1}, {21848, -1, -1, -1}, {21849, -1, -1, -1}, {21850, -1, -1, -1}, {21851, -1, -1, -1}, {21853, -1, -1, -1}, {21855, -1, -1, -1}, {21856, -1, -1, -1}, {21858, -1, -1, -1}, {21859, -1, -1, -1}, {21864, -1, -1, -1}, {21865, -1, -1, -1}, {21867, -1, -1, -1}, {21871, -1, -1, -1}, {21872, -1, -1, -1}, {21873, -1, -1, -1}, {21874, -1, -1, -1}, {21875, -1, -1, -1}, {21876, -1, -1, -1}, {21881, -1, -1, -1}, {21882, -1, -1, -1}, {21885, -1, -1, -1}, {21887, -1, -1, -1}, {21893, -1, -1, -1}, {21894, -1, -1, -1}, {21900, -1, -1, -1}, {21901, -1, -1, -1}, {21902, -1, -1, -1}, {21904, -1, -1, -1}, {21906, -1, -1, -1}, {21907, -1, -1, -1}, {21909, -1, -1, -1}, {21910, -1, -1, -1}, {21911, -1, -1, -1}, {21914, -1, -1, -1}, {21915, -1, -1, -1}, {21918, -1, -1, -1}, {21920, -1, -1, -1}, {21921, -1, -1, -1}, {21922, -1, -1, -1}, {21923, -1, -1, -1}, {21924, -1, -1, -1}, {21925, -1, -1, -1}, {21926, -1, -1, -1}, {21928, -1, -1, -1}, {21929, -1, -1, -1}, {21931, -1, -1, -1}, {21933, -1, -1, -1}, {21935, -1, -1, -1}, {21936, -1, -1, -1}, {21940, -1, -1, -1}, {21942, -1, -1, -1}, {21944, -1, -1, -1}, {21946, -1, -1, -1}, {21948, -1, -1, -1}, {21951, -1, -1, -1}, {21952, -1, -1, -1}, {21953, -1, -1, -1}, {21954, -1, -1, -1}, {21955, -1, -1, -1}, {21960, -1, -1, -1}, {21962, -1, -1, -1}, {21963, -1, -1, -1}, {21967, -1, -1, -1}, {21968, -1, -1, -1}, {21973, -1, -1, -1}, {21975, -1, -1, -1}, {21976, -1, -1, -1}, {21977, -1, -1, -1}, {21979, -1, -1, -1}, {21982, -1, -1, -1}, {21984, -1, -1, -1}, {21986, -1, -1, -1}, {21991, -1, -1, -1}, {21997, -1, -1, -1}, {21998, -1, -1, -1}, {22000, -1, -1, -1}, {22001, -1, -1, -1}, {22004, -1, -1, -1}, {22008, -1, -1, -1}, {22009, -1, -1, -1}, {22010, -1, -1, -1}, {22011, -1, -1, -1}, {22012, -1, -1, -1}, {22015, -1, -1, -1}, {22018, -1, -1, -1}, {22019, -1, -1, -1}, {22020, -1, -1, -1}, {22021, -1, -1, -1}, {22023, -1, -1, -1}, {22026, -1, -1, -1}, {22027, -1, -1, -1}, {22032, -1, -1, -1}, {22033, -1, -1, -1}, {22034, -1, -1, -1}, {22035, -1, -1, -1}, {22037, -1, -1, -1}, {22041, -1, -1, -1}, {22042, -1, -1, -1}, {22045, -1, -1, -1}, {22048, -1, -1, -1}, {22049, -1, -1, -1}, {22050, -1, -1, -1}, {22053, -1, -1, -1}, {22054, -1, -1, -1}, {22056, -1, -1, -1}, {22058, -1, -1, -1}, {22059, -1, -1, -1}, {22067, -1, -1, -1}, {22071, -1, -1, -1}, {22074, -1, -1, -1}, {22076, -1, -1, -1}, {22077, -1, -1, -1}, {22078, -1, -1, -1}, {22080, -1, -1, -1}, {22082, -1, -1, -1}, {22083, -1, -1, -1}, {22084, -1, -1, -1}, {22085, -1, -1, -1}, {22086, -1, -1, -1}, {22087, -1, -1, -1}, {22088, -1, -1, -1}, {22089, -1, -1, -1}, {22090, -1, -1, -1}, {22091, -1, -1, -1}, {22095, -1, -1, -1}, {22096, -1, -1, -1}, {22097, -1, -1, -1}, {22098, -1, -1, -1}, {22099, -1, -1, -1}, {22101, -1, -1, -1}, {22102, -1, -1, -1}, {22106, -1, -1, -1}, {22107, -1, -1, -1}, {22110, -1, -1, -1}, {22111, -1, -1, -1}, {22113, -1, -1, -1}, {22115, -1, -1, -1}, {22119, -1, -1, -1}, {22125, -1, -1, -1}, {22126, -1, -1, -1}, {22128, -1, -1, -1}, {22131, -1, -1, -1}, {22133, -1, -1, -1}, {22135, -1, -1, -1}, {22138, -1, -1, -1}, {22141, -1, -1, -1}, {22142, -1, -1, -1}, {22143, -1, -1, -1}, {22145, -1, -1, -1}, {22146, -1, -1, -1}, {22147, -1, -1, -1}, {22148, -1, -1, -1}, {22152, -1, -1, -1}, {22153, -1, -1, -1}, {22154, -1, -1, -1}, {22155, -1, -1, -1}, {22157, -1, -1, -1}, {22160, -1, -1, -1}, {22161, -1, -1, -1}, {22162, -1, -1, -1}, {22164, -1, -1, -1}, {22166, -1, -1, -1}, {22167, -1, -1, -1}, {22168, -1, -1, -1}, {22170, -1, -1, -1}, {22171, -1, -1, -1}, {22172, -1, -1, -1}, {22173, -1, -1, -1}, {22174, -1, -1, -1}, {22175, -1, -1, -1}, {22176, -1, -1, -1}, {22177, -1, -1, -1}, {22178, -1, -1, -1}, {22180, -1, -1, -1}, {22181, -1, -1, -1}, {22183, -1, -1, -1}, {22185, -1, -1, -1}, {22186, -1, -1, -1}, {22187, -1, -1, -1}, {22188, -1, -1, -1}, {22189, -1, -1, -1}, {22192, -1, -1, -1}, {22193, -1, -1, -1}, {22194, -1, -1, -1}, {22197, -1, -1, -1}, {22200, -1, -1, -1}, {22201, -1, -1, -1}, {22202, -1, -1, -1}, {22203, -1, -1, -1}, {22205, -1, -1, -1}, {22206, -1, -1, -1}, {22207, -1, -1, -1}, {22211, -1, -1, -1}, {22212, -1, -1, -1}, {22214, -1, -1, -1}, {22215, -1, -1, -1}, {22219, -1, -1, -1}, {22221, -1, -1, -1}, {22222, -1, -1, -1}, {22223, -1, -1, -1}, {22224, -1, -1, -1}, {22226, -1, -1, -1}, {22227, -1, -1, -1}, {22229, -1, -1, -1}, {22230, -1, -1, -1}, {22232, -1, -1, -1}, {22233, -1, -1, -1}, {22236, -1, -1, -1}, {22243, -1, -1, -1}, {22245, -1, -1, -1}, {22246, -1, -1, -1}, {22247, -1, -1, -1}, {22248, -1, -1, -1}, {22249, -1, -1, -1}, {22250, -1, -1, -1}, {22252, -1, -1, -1}, {22254, -1, -1, -1}, {22255, -1, -1, -1}, {22258, -1, -1, -1}, {22259, -1, -1, -1}, {22262, -1, -1, -1}, {22263, -1, -1, -1}, {22264, -1, -1, -1}, {22267, -1, -1, -1}, {22268, -1, -1, -1}, {22272, -1, -1, -1}, {22273, -1, -1, -1}, {22274, -1, -1, -1}, {22277, -1, -1, -1}, {22284, -1, -1, -1}, {22286, -1, -1, -1}, {22287, -1, -1, -1}, {22288, -1, -1, -1}, {22289, -1, -1, -1}, {22292, -1, -1, -1}, {22293, -1, -1, -1}, {22295, -1, -1, -1}, {22297, -1, -1, -1}, {22298, -1, -1, -1}, {22299, -1, -1, -1}, {22301, -1, -1, -1}, {22302, -1, -1, -1}, {22304, -1, -1, -1}, {22305, -1, -1, -1}, {22306, -1, -1, -1}, {22308, -1, -1, -1} },
+ {{22309, -1, -1, -1}, {22310, -1, -1, -1}, {22311, -1, -1, -1}, {22315, -1, -1, -1}, {22321, -1, -1, -1}, {22322, -1, -1, -1}, {22324, -1, -1, -1}, {22325, -1, -1, -1}, {22326, -1, -1, -1}, {22327, -1, -1, -1}, {22328, -1, -1, -1}, {22332, -1, -1, -1}, {22333, -1, -1, -1}, {22335, -1, -1, -1}, {22337, -1, -1, -1}, {22339, -1, -1, -1}, {22340, -1, -1, -1}, {22341, -1, -1, -1}, {22342, -1, -1, -1}, {22344, -1, -1, -1}, {22345, -1, -1, -1}, {22347, -1, -1, -1}, {22354, -1, -1, -1}, {22355, -1, -1, -1}, {22356, -1, -1, -1}, {22357, -1, -1, -1}, {22358, -1, -1, -1}, {22360, -1, -1, -1}, {22361, -1, -1, -1}, {22370, -1, -1, -1}, {22371, -1, -1, -1}, {22373, -1, -1, -1}, {22375, -1, -1, -1}, {22380, -1, -1, -1}, {22382, -1, -1, -1}, {22384, -1, -1, -1}, {22385, -1, -1, -1}, {22386, -1, -1, -1}, {22388, -1, -1, -1}, {22389, -1, -1, -1}, {22392, -1, -1, -1}, {22393, -1, -1, -1}, {22394, -1, -1, -1}, {22397, -1, -1, -1}, {22398, -1, -1, -1}, {22399, -1, -1, -1}, {22400, -1, -1, -1}, {22401, -1, -1, -1}, {22407, -1, -1, -1}, {22408, -1, -1, -1}, {22409, -1, -1, -1}, {22410, -1, -1, -1}, {22413, -1, -1, -1}, {22414, -1, -1, -1}, {22415, -1, -1, -1}, {22416, -1, -1, -1}, {22417, -1, -1, -1}, {22420, -1, -1, -1}, {22421, -1, -1, -1}, {22422, -1, -1, -1}, {22423, -1, -1, -1}, {22424, -1, -1, -1}, {22425, -1, -1, -1}, {22426, -1, -1, -1}, {22428, -1, -1, -1}, {22429, -1, -1, -1}, {22430, -1, -1, -1}, {22431, -1, -1, -1}, {22437, -1, -1, -1}, {22440, -1, -1, -1}, {22442, -1, -1, -1}, {22444, -1, -1, -1}, {22447, -1, -1, -1}, {22448, -1, -1, -1}, {22449, -1, -1, -1}, {22451, -1, -1, -1}, {22453, -1, -1, -1}, {22454, -1, -1, -1}, {22455, -1, -1, -1}, {22457, -1, -1, -1}, {22458, -1, -1, -1}, {22459, -1, -1, -1}, {22460, -1, -1, -1}, {22461, -1, -1, -1}, {22462, -1, -1, -1}, {22463, -1, -1, -1}, {22464, -1, -1, -1}, {22465, -1, -1, -1}, {22468, -1, -1, -1}, {22469, -1, -1, -1}, {22470, -1, -1, -1}, {22471, -1, -1, -1}, {22472, -1, -1, -1}, {22473, -1, -1, -1}, {22474, -1, -1, -1}, {22476, -1, -1, -1}, {22477, -1, -1, -1}, {22480, -1, -1, -1}, {22481, -1, -1, -1}, {22483, -1, -1, -1}, {22486, -1, -1, -1}, {22487, -1, -1, -1}, {22491, -1, -1, -1}, {22492, -1, -1, -1}, {22494, -1, -1, -1}, {22498, -1, -1, -1}, {22499, -1, -1, -1}, {22501, -1, -1, -1}, {22502, -1, -1, -1}, {22503, -1, -1, -1}, {22504, -1, -1, -1}, {22505, -1, -1, -1}, {22506, -1, -1, -1}, {22507, -1, -1, -1}, {22508, -1, -1, -1}, {22510, -1, -1, -1}, {22512, -1, -1, -1}, {22513, -1, -1, -1}, {22514, -1, -1, -1}, {22515, -1, -1, -1}, {22517, -1, -1, -1}, {22518, -1, -1, -1}, {22523, -1, -1, -1}, {22524, -1, -1, -1}, {22526, -1, -1, -1}, {22527, -1, -1, -1}, {22529, -1, -1, -1}, {22531, -1, -1, -1}, {22532, -1, -1, -1}, {22536, -1, -1, -1}, {22537, -1, -1, -1}, {22540, -1, -1, -1}, {22542, -1, -1, -1}, {22543, -1, -1, -1}, {22544, -1, -1, -1}, {22546, -1, -1, -1}, {22547, -1, -1, -1}, {22548, -1, -1, -1}, {22551, -1, -1, -1}, {22552, -1, -1, -1}, {22554, -1, -1, -1}, {22555, -1, -1, -1}, {22556, -1, -1, -1}, {22559, -1, -1, -1}, {22562, -1, -1, -1}, {22563, -1, -1, -1}, {22565, -1, -1, -1}, {22566, -1, -1, -1}, {22567, -1, -1, -1}, {22568, -1, -1, -1}, {22569, -1, -1, -1}, {22571, -1, -1, -1}, {22572, -1, -1, -1}, {22573, -1, -1, -1}, {22574, -1, -1, -1}, {22578, -1, -1, -1}, {22579, -1, -1, -1}, {22582, -1, -1, -1}, {22583, -1, -1, -1}, {22584, -1, -1, -1}, {22585, -1, -1, -1}, {22586, -1, -1, -1}, {22587, -1, -1, -1}, {22588, -1, -1, -1}, {22589, -1, -1, -1}, {22590, -1, -1, -1}, {22591, -1, -1, -1}, {22592, -1, -1, -1}, {22593, -1, -1, -1}, {22594, -1, -1, -1}, {22595, -1, -1, -1}, {22597, -1, -1, -1}, {22598, -1, -1, -1}, {22599, -1, -1, -1}, {22600, -1, -1, -1}, {22601, -1, -1, -1}, {22606, -1, -1, -1}, {22608, -1, -1, -1}, {22611, -1, -1, -1}, {22613, -1, -1, -1}, {22614, -1, -1, -1}, {22617, -1, -1, -1}, {22618, -1, -1, -1}, {22619, -1, -1, -1}, {22620, -1, -1, -1}, {22621, -1, -1, -1}, {22623, -1, -1, -1}, {22624, -1, -1, -1}, {22625, -1, -1, -1}, {22627, -1, -1, -1}, {22630, -1, -1, -1}, {22631, -1, -1, -1}, {22632, -1, -1, -1}, {22633, -1, -1, -1}, {22634, -1, -1, -1}, {22637, -1, -1, -1}, {22638, -1, -1, -1}, {22639, -1, -1, -1}, {22640, -1, -1, -1}, {22641, -1, -1, -1}, {22642, -1, -1, -1}, {22643, -1, -1, -1}, {22644, -1, -1, -1}, {22646, -1, -1, -1}, {22647, -1, -1, -1}, {22648, -1, -1, -1}, {22650, -1, -1, -1}, {22651, -1, -1, -1}, {22652, -1, -1, -1}, {22653, -1, -1, -1}, {22655, -1, -1, -1}, {22658, -1, -1, -1}, {22660, -1, -1, -1}, {22662, -1, -1, -1}, {22663, -1, -1, -1}, {22664, -1, -1, -1}, {22667, -1, -1, -1}, {22668, -1, -1, -1}, {22669, -1, -1, -1}, {22670, -1, -1, -1}, {22671, -1, -1, -1}, {22672, -1, -1, -1}, {22673, -1, -1, -1}, {22676, -1, -1, -1}, {22677, -1, -1, -1}, {22678, -1, -1, -1}, {22679, -1, -1, -1}, {22680, -1, -1, -1}, {22683, -1, -1, -1}, {22685, -1, -1, -1}, {22688, -1, -1, -1}, {22689, -1, -1, -1}, {22690, -1, -1, -1}, {22691, -1, -1, -1}, {22692, -1, -1, -1}, {22693, -1, -1, -1}, {22694, -1, -1, -1}, {22695, -1, -1, -1}, {22698, -1, -1, -1}, {22699, -1, -1, -1}, {22700, -1, -1, -1}, {22701, -1, -1, -1}, {22703, -1, -1, -1}, {22704, -1, -1, -1}, {22705, -1, -1, -1}, {22706, -1, -1, -1}, {22708, -1, -1, -1}, {22709, -1, -1, -1}, {22710, -1, -1, -1}, {22711, -1, -1, -1}, {22712, -1, -1, -1}, {22713, -1, -1, -1}, {22714, -1, -1, -1}, {22717, -1, -1, -1}, {22719, -1, -1, -1}, {22720, -1, -1, -1} },
+ {{22722, -1, -1, -1}, {22723, -1, -1, -1}, {22724, -1, -1, -1}, {22726, -1, -1, -1}, {22728, -1, -1, -1}, {22729, -1, -1, -1}, {22730, -1, -1, -1}, {22731, -1, -1, -1}, {22732, -1, -1, -1}, {22733, -1, -1, -1}, {22734, -1, -1, -1}, {22735, -1, -1, -1}, {22736, -1, -1, -1}, {22738, -1, -1, -1}, {22740, -1, -1, -1}, {22742, -1, -1, -1}, {22743, -1, -1, -1}, {22747, -1, -1, -1}, {22748, -1, -1, -1}, {22749, -1, -1, -1}, {22753, -1, -1, -1}, {22755, -1, -1, -1}, {22757, -1, -1, -1}, {22758, -1, -1, -1}, {22759, -1, -1, -1}, {22760, -1, -1, -1}, {22762, -1, -1, -1}, {22765, -1, -1, -1}, {22769, -1, -1, -1}, {22770, -1, -1, -1}, {22772, -1, -1, -1}, {22773, -1, -1, -1}, {22775, -1, -1, -1}, {22776, -1, -1, -1}, {22779, -1, -1, -1}, {22780, -1, -1, -1}, {22782, -1, -1, -1}, {22783, -1, -1, -1}, {22784, -1, -1, -1}, {22785, -1, -1, -1}, {22787, -1, -1, -1}, {22789, -1, -1, -1}, {22790, -1, -1, -1}, {22792, -1, -1, -1}, {22793, -1, -1, -1}, {12066, 22794, -1, -1}, {22795, -1, -1, -1}, {22796, -1, -1, -1}, {22798, -1, -1, -1}, {22800, -1, -1, -1}, {22801, -1, -1, -1}, {22802, -1, -1, -1}, {22803, -1, -1, -1}, {22807, -1, -1, -1}, {22808, -1, -1, -1}, {22811, -1, -1, -1}, {22813, -1, -1, -1}, {22814, -1, -1, -1}, {22816, -1, -1, -1}, {22817, -1, -1, -1}, {22819, -1, -1, -1}, {22822, -1, -1, -1}, {22824, -1, -1, -1}, {22828, -1, -1, -1}, {22832, -1, -1, -1}, {22834, -1, -1, -1}, {22835, -1, -1, -1}, {22837, -1, -1, -1}, {22838, -1, -1, -1}, {22843, -1, -1, -1}, {22845, -1, -1, -1}, {22847, -1, -1, -1}, {22848, -1, -1, -1}, {22851, -1, -1, -1}, {22853, -1, -1, -1}, {22854, -1, -1, -1}, {22858, -1, -1, -1}, {22860, -1, -1, -1}, {22861, -1, -1, -1}, {22864, -1, -1, -1}, {22866, -1, -1, -1}, {22867, -1, -1, -1}, {22873, -1, -1, -1}, {22875, -1, -1, -1}, {22876, -1, -1, -1}, {22877, -1, -1, -1}, {22878, -1, -1, -1}, {22879, -1, -1, -1}, {22881, -1, -1, -1}, {22883, -1, -1, -1}, {22884, -1, -1, -1}, {22886, -1, -1, -1}, {22887, -1, -1, -1}, {22888, -1, -1, -1}, {22891, -1, -1, -1}, {22893, -1, -1, -1}, {22895, -1, -1, -1}, {22896, -1, -1, -1}, {22897, -1, -1, -1}, {22898, -1, -1, -1}, {22901, -1, -1, -1}, {22903, -1, -1, -1}, {22906, -1, -1, -1}, {22907, -1, -1, -1}, {22908, -1, -1, -1}, {22910, -1, -1, -1}, {22911, -1, -1, -1}, {22912, -1, -1, -1}, {22917, -1, -1, -1}, {22921, -1, -1, -1}, {22923, -1, -1, -1}, {22924, -1, -1, -1}, {22926, -1, -1, -1}, {22927, -1, -1, -1}, {22928, -1, -1, -1}, {22929, -1, -1, -1}, {22932, -1, -1, -1}, {22933, -1, -1, -1}, {22936, -1, -1, -1}, {22938, -1, -1, -1}, {22939, -1, -1, -1}, {22940, -1, -1, -1}, {22943, -1, -1, -1}, {22944, -1, -1, -1}, {22945, -1, -1, -1}, {22946, -1, -1, -1}, {22950, -1, -1, -1}, {22951, -1, -1, -1}, {22956, -1, -1, -1}, {22957, -1, -1, -1}, {22960, -1, -1, -1}, {22961, -1, -1, -1}, {22963, -1, -1, -1}, {22964, -1, -1, -1}, {22965, -1, -1, -1}, {22966, -1, -1, -1}, {22967, -1, -1, -1}, {22968, -1, -1, -1}, {22970, -1, -1, -1}, {22972, -1, -1, -1}, {22973, -1, -1, -1}, {22975, -1, -1, -1}, {22976, -1, -1, -1}, {22977, -1, -1, -1}, {22978, -1, -1, -1}, {22979, -1, -1, -1}, {22980, -1, -1, -1}, {22981, -1, -1, -1}, {22983, -1, -1, -1}, {22984, -1, -1, -1}, {22985, -1, -1, -1}, {22988, -1, -1, -1}, {22989, -1, -1, -1}, {22990, -1, -1, -1}, {22991, -1, -1, -1}, {22997, -1, -1, -1}, {22998, -1, -1, -1}, {23001, -1, -1, -1}, {23003, -1, -1, -1}, {23006, -1, -1, -1}, {23007, -1, -1, -1}, {23008, -1, -1, -1}, {23009, -1, -1, -1}, {23010, -1, -1, -1}, {23012, -1, -1, -1}, {23014, -1, -1, -1}, {23015, -1, -1, -1}, {23017, -1, -1, -1}, {23018, -1, -1, -1}, {23019, -1, -1, -1}, {23021, -1, -1, -1}, {23022, -1, -1, -1}, {23023, -1, -1, -1}, {23024, -1, -1, -1}, {23025, -1, -1, -1}, {23026, -1, -1, -1}, {23027, -1, -1, -1}, {23028, -1, -1, -1}, {23029, -1, -1, -1}, {23030, -1, -1, -1}, {23031, -1, -1, -1}, {23032, -1, -1, -1}, {23034, -1, -1, -1}, {23036, -1, -1, -1}, {23037, -1, -1, -1}, {23038, -1, -1, -1}, {23040, -1, -1, -1}, {23042, -1, -1, -1}, {23050, -1, -1, -1}, {23051, -1, -1, -1}, {23053, -1, -1, -1}, {23054, -1, -1, -1}, {23055, -1, -1, -1}, {23056, -1, -1, -1}, {23058, -1, -1, -1}, {23060, -1, -1, -1}, {23061, -1, -1, -1}, {23062, -1, -1, -1}, {23063, -1, -1, -1}, {23065, -1, -1, -1}, {23066, -1, -1, -1}, {23067, -1, -1, -1}, {23069, -1, -1, -1}, {23070, -1, -1, -1}, {23073, -1, -1, -1}, {23074, -1, -1, -1}, {23076, -1, -1, -1}, {23078, -1, -1, -1}, {23079, -1, -1, -1}, {23080, -1, -1, -1}, {23082, -1, -1, -1}, {23083, -1, -1, -1}, {23084, -1, -1, -1}, {23085, -1, -1, -1}, {23086, -1, -1, -1}, {23087, -1, -1, -1}, {23088, -1, -1, -1}, {23091, -1, -1, -1}, {23093, -1, -1, -1}, {23095, -1, -1, -1}, {23096, -1, -1, -1}, {23097, -1, -1, -1}, {23098, -1, -1, -1}, {23099, -1, -1, -1}, {23101, -1, -1, -1}, {23102, -1, -1, -1}, {23103, -1, -1, -1}, {23106, -1, -1, -1}, {23107, -1, -1, -1}, {23108, -1, -1, -1}, {23109, -1, -1, -1}, {23111, -1, -1, -1}, {23112, -1, -1, -1}, {23115, -1, -1, -1}, {23116, -1, -1, -1}, {23117, -1, -1, -1}, {23118, -1, -1, -1}, {23119, -1, -1, -1}, {23120, -1, -1, -1}, {23121, -1, -1, -1}, {23122, -1, -1, -1}, {23123, -1, -1, -1}, {23124, -1, -1, -1}, {23126, -1, -1, -1}, {23127, -1, -1, -1}, {23128, -1, -1, -1}, {23129, -1, -1, -1}, {23131, -1, -1, -1}, {23132, -1, -1, -1}, {23133, -1, -1, -1}, {23134, -1, -1, -1}, {23135, -1, -1, -1}, {23136, -1, -1, -1}, {23137, -1, -1, -1}, {23139, -1, -1, -1}, {23140, -1, -1, -1} },
+ {{23141, -1, -1, -1}, {23144, -1, -1, -1}, {23145, -1, -1, -1}, {23147, -1, -1, -1}, {23148, -1, -1, -1}, {23150, -1, -1, -1}, {23151, -1, -1, -1}, {23152, -1, -1, -1}, {23153, -1, -1, -1}, {23154, -1, -1, -1}, {23155, -1, -1, -1}, {23160, -1, -1, -1}, {23161, -1, -1, -1}, {23163, -1, -1, -1}, {23164, -1, -1, -1}, {23165, -1, -1, -1}, {23166, -1, -1, -1}, {23168, -1, -1, -1}, {23169, -1, -1, -1}, {23170, -1, -1, -1}, {23171, -1, -1, -1}, {23172, -1, -1, -1}, {23173, -1, -1, -1}, {23174, -1, -1, -1}, {23175, -1, -1, -1}, {23176, -1, -1, -1}, {23177, -1, -1, -1}, {23178, -1, -1, -1}, {23179, -1, -1, -1}, {23180, -1, -1, -1}, {23181, -1, -1, -1}, {23182, -1, -1, -1}, {23183, -1, -1, -1}, {23184, -1, -1, -1}, {23185, -1, -1, -1}, {23187, -1, -1, -1}, {23188, -1, -1, -1}, {23189, -1, -1, -1}, {23190, -1, -1, -1}, {23191, -1, -1, -1}, {23192, -1, -1, -1}, {23193, -1, -1, -1}, {23196, -1, -1, -1}, {23197, -1, -1, -1}, {23198, -1, -1, -1}, {23199, -1, -1, -1}, {23200, -1, -1, -1}, {23201, -1, -1, -1}, {23202, -1, -1, -1}, {23203, -1, -1, -1}, {23204, -1, -1, -1}, {23205, -1, -1, -1}, {23206, -1, -1, -1}, {23208, -1, -1, -1}, {23209, -1, -1, -1}, {23211, -1, -1, -1}, {23212, -1, -1, -1}, {23213, -1, -1, -1}, {23214, -1, -1, -1}, {23215, -1, -1, -1}, {23216, -1, -1, -1}, {23217, -1, -1, -1}, {23220, -1, -1, -1}, {23222, -1, -1, -1}, {23223, -1, -1, -1}, {23225, -1, -1, -1}, {23226, -1, -1, -1}, {23227, -1, -1, -1}, {23228, -1, -1, -1}, {23231, -1, -1, -1}, {23232, -1, -1, -1}, {23235, -1, -1, -1}, {23236, -1, -1, -1}, {23237, -1, -1, -1}, {23238, -1, -1, -1}, {23239, -1, -1, -1}, {23240, -1, -1, -1}, {23242, -1, -1, -1}, {23243, -1, -1, -1}, {23245, -1, -1, -1}, {23246, -1, -1, -1}, {23247, -1, -1, -1}, {23248, -1, -1, -1}, {23249, -1, -1, -1}, {23251, -1, -1, -1}, {23253, -1, -1, -1}, {23257, -1, -1, -1}, {23258, -1, -1, -1}, {23259, -1, -1, -1}, {23261, -1, -1, -1}, {23262, -1, -1, -1}, {23263, -1, -1, -1}, {23266, -1, -1, -1}, {23268, -1, -1, -1}, {23269, -1, -1, -1}, {23271, -1, -1, -1}, {23272, -1, -1, -1}, {23274, -1, -1, -1}, {23276, -1, -1, -1}, {23277, -1, -1, -1}, {23278, -1, -1, -1}, {23279, -1, -1, -1}, {23280, -1, -1, -1}, {23282, -1, -1, -1}, {23283, -1, -1, -1}, {23284, -1, -1, -1}, {23286, -1, -1, -1}, {23287, -1, -1, -1}, {23288, -1, -1, -1}, {23289, -1, -1, -1}, {23290, -1, -1, -1}, {23292, -1, -1, -1}, {23293, -1, -1, -1}, {23294, -1, -1, -1}, {23295, -1, -1, -1}, {23297, -1, -1, -1}, {23298, -1, -1, -1}, {23299, -1, -1, -1}, {23300, -1, -1, -1}, {23301, -1, -1, -1}, {23302, -1, -1, -1}, {23303, -1, -1, -1}, {23306, -1, -1, -1}, {23309, -1, -1, -1}, {23310, -1, -1, -1}, {23311, -1, -1, -1}, {23312, -1, -1, -1}, {23313, -1, -1, -1}, {23314, -1, -1, -1}, {23315, -1, -1, -1}, {23316, -1, -1, -1}, {23317, -1, -1, -1}, {23320, -1, -1, -1}, {23322, -1, -1, -1}, {23323, -1, -1, -1}, {23324, -1, -1, -1}, {23325, -1, -1, -1}, {23326, -1, -1, -1}, {23327, -1, -1, -1}, {23328, -1, -1, -1}, {23330, -1, -1, -1}, {23331, -1, -1, -1}, {23332, -1, -1, -1}, {23333, -1, -1, -1}, {23334, -1, -1, -1}, {23335, -1, -1, -1}, {23336, -1, -1, -1}, {23337, -1, -1, -1}, {23339, -1, -1, -1}, {23340, -1, -1, -1}, {23341, -1, -1, -1}, {23342, -1, -1, -1}, {23343, -1, -1, -1}, {23345, -1, -1, -1}, {23347, -1, -1, -1}, {23349, -1, -1, -1}, {23350, -1, -1, -1}, {23353, -1, -1, -1}, {23354, -1, -1, -1}, {23355, -1, -1, -1}, {23356, -1, -1, -1}, {23357, -1, -1, -1}, {23358, -1, -1, -1}, {23359, -1, -1, -1}, {23361, -1, -1, -1}, {23362, -1, -1, -1}, {23363, -1, -1, -1}, {23364, -1, -1, -1}, {23365, -1, -1, -1}, {23366, -1, -1, -1}, {23367, -1, -1, -1}, {23368, -1, -1, -1}, {23369, -1, -1, -1}, {23370, -1, -1, -1}, {23371, -1, -1, -1}, {23373, -1, -1, -1}, {23374, -1, -1, -1}, {23375, -1, -1, -1}, {23378, -1, -1, -1}, {23382, -1, -1, -1}, {23390, -1, -1, -1}, {23392, -1, -1, -1}, {23393, -1, -1, -1}, {23399, -1, -1, -1}, {23400, -1, -1, -1}, {23405, -1, -1, -1}, {23406, -1, -1, -1}, {23407, -1, -1, -1}, {23410, -1, -1, -1}, {23412, -1, -1, -1}, {23414, -1, -1, -1}, {23415, -1, -1, -1}, {23417, -1, -1, -1}, {23419, -1, -1, -1}, {23420, -1, -1, -1}, {23422, -1, -1, -1}, {23426, -1, -1, -1}, {23430, -1, -1, -1}, {23434, -1, -1, -1}, {23437, -1, -1, -1}, {23438, -1, -1, -1}, {23440, -1, -1, -1}, {23441, -1, -1, -1}, {23442, -1, -1, -1}, {23444, -1, -1, -1}, {23446, -1, -1, -1}, {23455, -1, -1, -1}, {23463, -1, -1, -1}, {23464, -1, -1, -1}, {23465, -1, -1, -1}, {23468, -1, -1, -1}, {23469, -1, -1, -1}, {23470, -1, -1, -1}, {23471, -1, -1, -1}, {23473, -1, -1, -1}, {23474, -1, -1, -1}, {23479, -1, -1, -1}, {23482, -1, -1, -1}, {23483, -1, -1, -1}, {23484, -1, -1, -1}, {23488, -1, -1, -1}, {23489, -1, -1, -1}, {23491, -1, -1, -1}, {23496, -1, -1, -1}, {23497, -1, -1, -1}, {23498, -1, -1, -1}, {23499, -1, -1, -1}, {23501, -1, -1, -1}, {23502, -1, -1, -1}, {23503, -1, -1, -1}, {23505, -1, -1, -1}, {23508, -1, -1, -1}, {23509, -1, -1, -1}, {23510, -1, -1, -1}, {23511, -1, -1, -1}, {23512, -1, -1, -1}, {23513, -1, -1, -1}, {23514, -1, -1, -1}, {23515, -1, -1, -1}, {23516, -1, -1, -1}, {23520, -1, -1, -1}, {23523, -1, -1, -1}, {23530, -1, -1, -1}, {23533, -1, -1, -1}, {23535, -1, -1, -1}, {23537, -1, -1, -1}, {23538, -1, -1, -1}, {23539, -1, -1, -1}, {23540, -1, -1, -1}, {23543, -1, -1, -1}, {23549, -1, -1, -1}, {23550, -1, -1, -1}, {23552, -1, -1, -1}, {23554, -1, -1, -1}, {23555, -1, -1, -1}, {23557, -1, -1, -1} },
+ {{23564, -1, -1, -1}, {23568, -1, -1, -1}, {23570, -1, -1, -1}, {23571, -1, -1, -1}, {23575, -1, -1, -1}, {23577, -1, -1, -1}, {23579, -1, -1, -1}, {23582, -1, -1, -1}, {23583, -1, -1, -1}, {23584, -1, -1, -1}, {23585, -1, -1, -1}, {23587, -1, -1, -1}, {23590, -1, -1, -1}, {23592, -1, -1, -1}, {23593, -1, -1, -1}, {23594, -1, -1, -1}, {23595, -1, -1, -1}, {23597, -1, -1, -1}, {23598, -1, -1, -1}, {23599, -1, -1, -1}, {23600, -1, -1, -1}, {23602, -1, -1, -1}, {23603, -1, -1, -1}, {23605, -1, -1, -1}, {23606, -1, -1, -1}, {23619, -1, -1, -1}, {23620, -1, -1, -1}, {23622, -1, -1, -1}, {23623, -1, -1, -1}, {23628, -1, -1, -1}, {23629, -1, -1, -1}, {23634, -1, -1, -1}, {23635, -1, -1, -1}, {23636, -1, -1, -1}, {23638, -1, -1, -1}, {23639, -1, -1, -1}, {23640, -1, -1, -1}, {23642, -1, -1, -1}, {23643, -1, -1, -1}, {23644, -1, -1, -1}, {23645, -1, -1, -1}, {23647, -1, -1, -1}, {23655, -1, -1, -1}, {23657, -1, -1, -1}, {23658, -1, -1, -1}, {23659, -1, -1, -1}, {23661, -1, -1, -1}, {23664, -1, -1, -1}, {23666, -1, -1, -1}, {23667, -1, -1, -1}, {23668, -1, -1, -1}, {23669, -1, -1, -1}, {23670, -1, -1, -1}, {23671, -1, -1, -1}, {23672, -1, -1, -1}, {23675, -1, -1, -1}, {23676, -1, -1, -1}, {23677, -1, -1, -1}, {23678, -1, -1, -1}, {23680, -1, -1, -1}, {23683, -1, -1, -1}, {23684, -1, -1, -1}, {23685, -1, -1, -1}, {23686, -1, -1, -1}, {23687, -1, -1, -1}, {23689, -1, -1, -1}, {23690, -1, -1, -1}, {23691, -1, -1, -1}, {23694, -1, -1, -1}, {23695, -1, -1, -1}, {23698, -1, -1, -1}, {23699, -1, -1, -1}, {23701, -1, -1, -1}, {23709, -1, -1, -1}, {23710, -1, -1, -1}, {23711, -1, -1, -1}, {23712, -1, -1, -1}, {23716, -1, -1, -1}, {23717, -1, -1, -1}, {23718, -1, -1, -1}, {23719, -1, -1, -1}, {23720, -1, -1, -1}, {23722, -1, -1, -1}, {23726, -1, -1, -1}, {23727, -1, -1, -1}, {23728, -1, -1, -1}, {23730, -1, -1, -1}, {23732, -1, -1, -1}, {23734, -1, -1, -1}, {23737, -1, -1, -1}, {23738, -1, -1, -1}, {23739, -1, -1, -1}, {23740, -1, -1, -1}, {23742, -1, -1, -1}, {23744, -1, -1, -1}, {23746, -1, -1, -1}, {23747, -1, -1, -1}, {23749, -1, -1, -1}, {23750, -1, -1, -1}, {23751, -1, -1, -1}, {23752, -1, -1, -1}, {23753, -1, -1, -1}, {23754, -1, -1, -1}, {23756, -1, -1, -1}, {23757, -1, -1, -1}, {23758, -1, -1, -1}, {23759, -1, -1, -1}, {23760, -1, -1, -1}, {23761, -1, -1, -1}, {23763, -1, -1, -1}, {23764, -1, -1, -1}, {23765, -1, -1, -1}, {23766, -1, -1, -1}, {23767, -1, -1, -1}, {23768, -1, -1, -1}, {23770, -1, -1, -1}, {23771, -1, -1, -1}, {23772, -1, -1, -1}, {23773, -1, -1, -1}, {23774, -1, -1, -1}, {23775, -1, -1, -1}, {23776, -1, -1, -1}, {23778, -1, -1, -1}, {23779, -1, -1, -1}, {23783, -1, -1, -1}, {23785, -1, -1, -1}, {23787, -1, -1, -1}, {23788, -1, -1, -1}, {23790, -1, -1, -1}, {23791, -1, -1, -1}, {23793, -1, -1, -1}, {23794, -1, -1, -1}, {23795, -1, -1, -1}, {23797, -1, -1, -1}, {23799, -1, -1, -1}, {23800, -1, -1, -1}, {23801, -1, -1, -1}, {23802, -1, -1, -1}, {23804, -1, -1, -1}, {23806, -1, -1, -1}, {23807, -1, -1, -1}, {23808, -1, -1, -1}, {23809, -1, -1, -1}, {23812, -1, -1, -1}, {23813, -1, -1, -1}, {23816, -1, -1, -1}, {23817, -1, -1, -1}, {23818, -1, -1, -1}, {23819, -1, -1, -1}, {23820, -1, -1, -1}, {23823, -1, -1, -1}, {23824, -1, -1, -1}, {23825, -1, -1, -1}, {23826, -1, -1, -1}, {23827, -1, -1, -1}, {23829, -1, -1, -1}, {23832, -1, -1, -1}, {23833, -1, -1, -1}, {23834, -1, -1, -1}, {23836, -1, -1, -1}, {23837, -1, -1, -1}, {23839, -1, -1, -1}, {23840, -1, -1, -1}, {23841, -1, -1, -1}, {23842, -1, -1, -1}, {23843, -1, -1, -1}, {23845, -1, -1, -1}, {23848, -1, -1, -1}, {23850, -1, -1, -1}, {23851, -1, -1, -1}, {23855, -1, -1, -1}, {23856, -1, -1, -1}, {23857, -1, -1, -1}, {23858, -1, -1, -1}, {23859, -1, -1, -1}, {23861, -1, -1, -1}, {23862, -1, -1, -1}, {23863, -1, -1, -1}, {23864, -1, -1, -1}, {23865, -1, -1, -1}, {23866, -1, -1, -1}, {23867, -1, -1, -1}, {23868, -1, -1, -1}, {23871, -1, -1, -1}, {23872, -1, -1, -1}, {23873, -1, -1, -1}, {23874, -1, -1, -1}, {23875, -1, -1, -1}, {23876, -1, -1, -1}, {23877, -1, -1, -1}, {23878, -1, -1, -1}, {23880, -1, -1, -1}, {23881, -1, -1, -1}, {23885, -1, -1, -1}, {23886, -1, -1, -1}, {23887, -1, -1, -1}, {23889, -1, -1, -1}, {23890, -1, -1, -1}, {23891, -1, -1, -1}, {23892, -1, -1, -1}, {23893, -1, -1, -1}, {23894, -1, -1, -1}, {23895, -1, -1, -1}, {23897, -1, -1, -1}, {23898, -1, -1, -1}, {23900, -1, -1, -1}, {23902, -1, -1, -1}, {23903, -1, -1, -1}, {23904, -1, -1, -1}, {23905, -1, -1, -1}, {23906, -1, -1, -1}, {23907, -1, -1, -1}, {23908, -1, -1, -1}, {23909, -1, -1, -1}, {23910, -1, -1, -1}, {23911, -1, -1, -1}, {23912, -1, -1, -1}, {23914, -1, -1, -1}, {23917, -1, -1, -1}, {23918, -1, -1, -1}, {23920, -1, -1, -1}, {23921, -1, -1, -1}, {23922, -1, -1, -1}, {23923, -1, -1, -1}, {23925, -1, -1, -1}, {23926, -1, -1, -1}, {23927, -1, -1, -1}, {23928, -1, -1, -1}, {23929, -1, -1, -1}, {23930, -1, -1, -1}, {23931, -1, -1, -1}, {23932, -1, -1, -1}, {23933, -1, -1, -1}, {23934, -1, -1, -1}, {23935, -1, -1, -1}, {23936, -1, -1, -1}, {23939, -1, -1, -1}, {23941, -1, -1, -1}, {23942, -1, -1, -1}, {23944, -1, -1, -1}, {23945, -1, -1, -1}, {23946, -1, -1, -1}, {23947, -1, -1, -1}, {23948, -1, -1, -1}, {23949, -1, -1, -1}, {23950, -1, -1, -1}, {23951, -1, -1, -1}, {23952, -1, -1, -1}, {23953, -1, -1, -1}, {23954, -1, -1, -1}, {23955, -1, -1, -1}, {23956, -1, -1, -1}, {23957, -1, -1, -1}, {23958, -1, -1, -1}, {23960, -1, -1, -1}, {23962, -1, -1, -1} },
+ {{23963, -1, -1, -1}, {23964, -1, -1, -1}, {23966, -1, -1, -1}, {23967, -1, -1, -1}, {23969, -1, -1, -1}, {23970, -1, -1, -1}, {23971, -1, -1, -1}, {23972, -1, -1, -1}, {23973, -1, -1, -1}, {23974, -1, -1, -1}, {23976, -1, -1, -1}, {23977, -1, -1, -1}, {23978, -1, -1, -1}, {23979, -1, -1, -1}, {23980, -1, -1, -1}, {23981, -1, -1, -1}, {23982, -1, -1, -1}, {23983, -1, -1, -1}, {23984, -1, -1, -1}, {23985, -1, -1, -1}, {23986, -1, -1, -1}, {23987, -1, -1, -1}, {23988, -1, -1, -1}, {23989, -1, -1, -1}, {23990, -1, -1, -1}, {23993, -1, -1, -1}, {23995, -1, -1, -1}, {23997, -1, -1, -1}, {23998, -1, -1, -1}, {23999, -1, -1, -1}, {24000, -1, -1, -1}, {24001, -1, -1, -1}, {24002, -1, -1, -1}, {24003, -1, -1, -1}, {24004, -1, -1, -1}, {24006, -1, -1, -1}, {24007, -1, -1, -1}, {24008, -1, -1, -1}, {24009, -1, -1, -1}, {24010, -1, -1, -1}, {24012, -1, -1, -1}, {24014, -1, -1, -1}, {24015, -1, -1, -1}, {24016, -1, -1, -1}, {24017, -1, -1, -1}, {24019, -1, -1, -1}, {24021, -1, -1, -1}, {24022, -1, -1, -1}, {24023, -1, -1, -1}, {24024, -1, -1, -1}, {24025, -1, -1, -1}, {24026, -1, -1, -1}, {24028, -1, -1, -1}, {24031, -1, -1, -1}, {24032, -1, -1, -1}, {24035, -1, -1, -1}, {24036, -1, -1, -1}, {24042, -1, -1, -1}, {24044, -1, -1, -1}, {24045, -1, -1, -1}, {24053, -1, -1, -1}, {24054, -1, -1, -1}, {24056, -1, -1, -1}, {24057, -1, -1, -1}, {24058, -1, -1, -1}, {24059, -1, -1, -1}, {24060, -1, -1, -1}, {24063, -1, -1, -1}, {24064, -1, -1, -1}, {24068, -1, -1, -1}, {24071, -1, -1, -1}, {24073, -1, -1, -1}, {24074, -1, -1, -1}, {24075, -1, -1, -1}, {24077, -1, -1, -1}, {24078, -1, -1, -1}, {24082, -1, -1, -1}, {24083, -1, -1, -1}, {24087, -1, -1, -1}, {24094, -1, -1, -1}, {24095, -1, -1, -1}, {24096, -1, -1, -1}, {24097, -1, -1, -1}, {24098, -1, -1, -1}, {24099, -1, -1, -1}, {24100, -1, -1, -1}, {24104, -1, -1, -1}, {24105, -1, -1, -1}, {24106, -1, -1, -1}, {24108, -1, -1, -1}, {24111, -1, -1, -1}, {24112, -1, -1, -1}, {24114, -1, -1, -1}, {24116, -1, -1, -1}, {24117, -1, -1, -1}, {24121, -1, -1, -1}, {24122, -1, -1, -1}, {24126, -1, -1, -1}, {24127, -1, -1, -1}, {24129, -1, -1, -1}, {24134, -1, -1, -1}, {24135, -1, -1, -1}, {24136, -1, -1, -1}, {24137, -1, -1, -1}, {24138, -1, -1, -1}, {24139, -1, -1, -1}, {24141, -1, -1, -1}, {24142, -1, -1, -1}, {24143, -1, -1, -1}, {24144, -1, -1, -1}, {24145, -1, -1, -1}, {24146, -1, -1, -1}, {24147, -1, -1, -1}, {24150, -1, -1, -1}, {24153, -1, -1, -1}, {24154, -1, -1, -1}, {24156, -1, -1, -1}, {24157, -1, -1, -1}, {24160, -1, -1, -1}, {24164, -1, -1, -1}, {24165, -1, -1, -1}, {24166, -1, -1, -1}, {24167, -1, -1, -1}, {24168, -1, -1, -1}, {24169, -1, -1, -1}, {24170, -1, -1, -1}, {24173, -1, -1, -1}, {24174, -1, -1, -1}, {24175, -1, -1, -1}, {24176, -1, -1, -1}, {24177, -1, -1, -1}, {24181, -1, -1, -1}, {24183, -1, -1, -1}, {24193, -1, -1, -1}, {24194, -1, -1, -1}, {24195, -1, -1, -1}, {24197, -1, -1, -1}, {24200, -1, -1, -1}, {24201, -1, -1, -1}, {24204, -1, -1, -1}, {24205, -1, -1, -1}, {24206, -1, -1, -1}, {24210, -1, -1, -1}, {24216, -1, -1, -1}, {24219, -1, -1, -1}, {24221, -1, -1, -1}, {24225, -1, -1, -1}, {24226, -1, -1, -1}, {24227, -1, -1, -1}, {24228, -1, -1, -1}, {24232, -1, -1, -1}, {24233, -1, -1, -1}, {24234, -1, -1, -1}, {24236, -1, -1, -1}, {24238, -1, -1, -1}, {24239, -1, -1, -1}, {24240, -1, -1, -1}, {24241, -1, -1, -1}, {24242, -1, -1, -1}, {24244, -1, -1, -1}, {24250, -1, -1, -1}, {24251, -1, -1, -1}, {24252, -1, -1, -1}, {24253, -1, -1, -1}, {24255, -1, -1, -1}, {24256, -1, -1, -1}, {24257, -1, -1, -1}, {24258, -1, -1, -1}, {24259, -1, -1, -1}, {24260, -1, -1, -1}, {24261, -1, -1, -1}, {24262, -1, -1, -1}, {24263, -1, -1, -1}, {24264, -1, -1, -1}, {24267, -1, -1, -1}, {24268, -1, -1, -1}, {24269, -1, -1, -1}, {24270, -1, -1, -1}, {24271, -1, -1, -1}, {24272, -1, -1, -1}, {24276, -1, -1, -1}, {24277, -1, -1, -1}, {24279, -1, -1, -1}, {24280, -1, -1, -1}, {24281, -1, -1, -1}, {24282, -1, -1, -1}, {24284, -1, -1, -1}, {24285, -1, -1, -1}, {24286, -1, -1, -1}, {24292, -1, -1, -1}, {24293, -1, -1, -1}, {24294, -1, -1, -1}, {24295, -1, -1, -1}, {24297, -1, -1, -1}, {24299, -1, -1, -1}, {24301, -1, -1, -1}, {24302, -1, -1, -1}, {24303, -1, -1, -1}, {24304, -1, -1, -1}, {24305, -1, -1, -1}, {24306, -1, -1, -1}, {24309, -1, -1, -1}, {24312, -1, -1, -1}, {24313, -1, -1, -1}, {24315, -1, -1, -1}, {24316, -1, -1, -1}, {24317, -1, -1, -1}, {24325, -1, -1, -1}, {24326, -1, -1, -1}, {24327, -1, -1, -1}, {24329, -1, -1, -1}, {24332, -1, -1, -1}, {24333, -1, -1, -1}, {24334, -1, -1, -1}, {24336, -1, -1, -1}, {24338, -1, -1, -1}, {24340, -1, -1, -1}, {24342, -1, -1, -1}, {24345, -1, -1, -1}, {24346, -1, -1, -1}, {24348, -1, -1, -1}, {24349, -1, -1, -1}, {24350, -1, -1, -1}, {24353, -1, -1, -1}, {24354, -1, -1, -1}, {24355, -1, -1, -1}, {24356, -1, -1, -1}, {24360, -1, -1, -1}, {24363, -1, -1, -1}, {24364, -1, -1, -1}, {24366, -1, -1, -1}, {24368, -1, -1, -1}, {24370, -1, -1, -1}, {24372, -1, -1, -1}, {24374, -1, -1, -1}, {24375, -1, -1, -1}, {24376, -1, -1, -1}, {24379, -1, -1, -1}, {24381, -1, -1, -1}, {24382, -1, -1, -1}, {24383, -1, -1, -1}, {24385, -1, -1, -1}, {24386, -1, -1, -1}, {24387, -1, -1, -1}, {24388, -1, -1, -1}, {24389, -1, -1, -1}, {24391, -1, -1, -1}, {24393, -1, -1, -1}, {24394, -1, -1, -1}, {24395, -1, -1, -1}, {24397, -1, -1, -1}, {24399, -1, -1, -1}, {24401, -1, -1, -1}, {24404, -1, -1, -1}, {24410, -1, -1, -1}, {24411, -1, -1, -1} },
+ {{24412, -1, -1, -1}, {24414, -1, -1, -1}, {24415, -1, -1, -1}, {24416, -1, -1, -1}, {24419, -1, -1, -1}, {24421, -1, -1, -1}, {24423, -1, -1, -1}, {24424, -1, -1, -1}, {24427, -1, -1, -1}, {24430, -1, -1, -1}, {24431, -1, -1, -1}, {24434, -1, -1, -1}, {24436, -1, -1, -1}, {24437, -1, -1, -1}, {24438, -1, -1, -1}, {24440, -1, -1, -1}, {24442, -1, -1, -1}, {24445, -1, -1, -1}, {24446, -1, -1, -1}, {24447, -1, -1, -1}, {24451, -1, -1, -1}, {24454, -1, -1, -1}, {24461, -1, -1, -1}, {24462, -1, -1, -1}, {24463, -1, -1, -1}, {24467, -1, -1, -1}, {24468, -1, -1, -1}, {24470, -1, -1, -1}, {24474, -1, -1, -1}, {24475, -1, -1, -1}, {24477, -1, -1, -1}, {24479, -1, -1, -1}, {24482, -1, -1, -1}, {24483, -1, -1, -1}, {24484, -1, -1, -1}, {24485, -1, -1, -1}, {24486, -1, -1, -1}, {24487, -1, -1, -1}, {24491, -1, -1, -1}, {24492, -1, -1, -1}, {24495, -1, -1, -1}, {24496, -1, -1, -1}, {24497, -1, -1, -1}, {24498, -1, -1, -1}, {24499, -1, -1, -1}, {24500, -1, -1, -1}, {24502, -1, -1, -1}, {24504, -1, -1, -1}, {24506, -1, -1, -1}, {24507, -1, -1, -1}, {24510, -1, -1, -1}, {24511, -1, -1, -1}, {24512, -1, -1, -1}, {24513, -1, -1, -1}, {24514, -1, -1, -1}, {24519, -1, -1, -1}, {24520, -1, -1, -1}, {24522, -1, -1, -1}, {24523, -1, -1, -1}, {24526, -1, -1, -1}, {24531, -1, -1, -1}, {24532, -1, -1, -1}, {24533, -1, -1, -1}, {24538, -1, -1, -1}, {24539, -1, -1, -1}, {24540, -1, -1, -1}, {24542, -1, -1, -1}, {24543, -1, -1, -1}, {24546, -1, -1, -1}, {24547, -1, -1, -1}, {24549, -1, -1, -1}, {24550, -1, -1, -1}, {24552, -1, -1, -1}, {24553, -1, -1, -1}, {24556, -1, -1, -1}, {24559, -1, -1, -1}, {24560, -1, -1, -1}, {24562, -1, -1, -1}, {24563, -1, -1, -1}, {24564, -1, -1, -1}, {24566, -1, -1, -1}, {24567, -1, -1, -1}, {24569, -1, -1, -1}, {24570, -1, -1, -1}, {24572, -1, -1, -1}, {24583, -1, -1, -1}, {24584, -1, -1, -1}, {24585, -1, -1, -1}, {24587, -1, -1, -1}, {24588, -1, -1, -1}, {24592, -1, -1, -1}, {24593, -1, -1, -1}, {24595, -1, -1, -1}, {24599, -1, -1, -1}, {24600, -1, -1, -1}, {24602, -1, -1, -1}, {24606, -1, -1, -1}, {24607, -1, -1, -1}, {24610, -1, -1, -1}, {24611, -1, -1, -1}, {24612, -1, -1, -1}, {24620, -1, -1, -1}, {24621, -1, -1, -1}, {24622, -1, -1, -1}, {24624, -1, -1, -1}, {24625, -1, -1, -1}, {24626, -1, -1, -1}, {24627, -1, -1, -1}, {24628, -1, -1, -1}, {24630, -1, -1, -1}, {24631, -1, -1, -1}, {24632, -1, -1, -1}, {24633, -1, -1, -1}, {24634, -1, -1, -1}, {24637, -1, -1, -1}, {24638, -1, -1, -1}, {24640, -1, -1, -1}, {24644, -1, -1, -1}, {24645, -1, -1, -1}, {24646, -1, -1, -1}, {24647, -1, -1, -1}, {24648, -1, -1, -1}, {24649, -1, -1, -1}, {24650, -1, -1, -1}, {24652, -1, -1, -1}, {24654, -1, -1, -1}, {24655, -1, -1, -1}, {24657, -1, -1, -1}, {24659, -1, -1, -1}, {24660, -1, -1, -1}, {24662, -1, -1, -1}, {24663, -1, -1, -1}, {24664, -1, -1, -1}, {24667, -1, -1, -1}, {24668, -1, -1, -1}, {24670, -1, -1, -1}, {24671, -1, -1, -1}, {24672, -1, -1, -1}, {24673, -1, -1, -1}, {24677, -1, -1, -1}, {24678, -1, -1, -1}, {24686, -1, -1, -1}, {24689, -1, -1, -1}, {24690, -1, -1, -1}, {24692, -1, -1, -1}, {24693, -1, -1, -1}, {24695, -1, -1, -1}, {24702, -1, -1, -1}, {24704, -1, -1, -1}, {24705, -1, -1, -1}, {24706, -1, -1, -1}, {24709, -1, -1, -1}, {24710, -1, -1, -1}, {24711, -1, -1, -1}, {24712, -1, -1, -1}, {24714, -1, -1, -1}, {24715, -1, -1, -1}, {24718, -1, -1, -1}, {24719, -1, -1, -1}, {24720, -1, -1, -1}, {24721, -1, -1, -1}, {24723, -1, -1, -1}, {24725, -1, -1, -1}, {24727, -1, -1, -1}, {24728, -1, -1, -1}, {24729, -1, -1, -1}, {24732, -1, -1, -1}, {24734, -1, -1, -1}, {24737, -1, -1, -1}, {24738, -1, -1, -1}, {24740, -1, -1, -1}, {24741, -1, -1, -1}, {24743, -1, -1, -1}, {24745, -1, -1, -1}, {24746, -1, -1, -1}, {24750, -1, -1, -1}, {24752, -1, -1, -1}, {24755, -1, -1, -1}, {24759, -1, -1, -1}, {24761, -1, -1, -1}, {24762, -1, -1, -1}, {24765, -1, -1, -1}, {24766, -1, -1, -1}, {24767, -1, -1, -1}, {24768, -1, -1, -1}, {24769, -1, -1, -1}, {24770, -1, -1, -1}, {24771, -1, -1, -1}, {24772, -1, -1, -1}, {24775, -1, -1, -1}, {24776, -1, -1, -1}, {24777, -1, -1, -1}, {24780, -1, -1, -1}, {24781, -1, -1, -1}, {24782, -1, -1, -1}, {24783, -1, -1, -1}, {24784, -1, -1, -1}, {24786, -1, -1, -1}, {24787, -1, -1, -1}, {24788, -1, -1, -1}, {24790, -1, -1, -1}, {24791, -1, -1, -1}, {24793, -1, -1, -1}, {24795, -1, -1, -1}, {24798, -1, -1, -1}, {24802, -1, -1, -1}, {24803, -1, -1, -1}, {24804, -1, -1, -1}, {24805, -1, -1, -1}, {24810, -1, -1, -1}, {24821, -1, -1, -1}, {24823, -1, -1, -1}, {24824, -1, -1, -1}, {24828, -1, -1, -1}, {24829, -1, -1, -1}, {24830, -1, -1, -1}, {24831, -1, -1, -1}, {24834, -1, -1, -1}, {24835, -1, -1, -1}, {24836, -1, -1, -1}, {24837, -1, -1, -1}, {24839, -1, -1, -1}, {24842, -1, -1, -1}, {24843, -1, -1, -1}, {24844, -1, -1, -1}, {24848, -1, -1, -1}, {24849, -1, -1, -1}, {24850, -1, -1, -1}, {24851, -1, -1, -1}, {24852, -1, -1, -1}, {24854, -1, -1, -1}, {24855, -1, -1, -1}, {24856, -1, -1, -1}, {24857, -1, -1, -1}, {24861, -1, -1, -1}, {24862, -1, -1, -1}, {24865, -1, -1, -1}, {24866, -1, -1, -1}, {24869, -1, -1, -1}, {24872, -1, -1, -1}, {24873, -1, -1, -1}, {24874, -1, -1, -1}, {24876, -1, -1, -1}, {24877, -1, -1, -1}, {24878, -1, -1, -1}, {24879, -1, -1, -1}, {24880, -1, -1, -1}, {24881, -1, -1, -1}, {24882, -1, -1, -1}, {24883, -1, -1, -1}, {24885, -1, -1, -1}, {24886, -1, -1, -1}, {24888, -1, -1, -1}, {24889, -1, -1, -1}, {24890, -1, -1, -1}, {24891, -1, -1, -1} },
+ {{24892, -1, -1, -1}, {24893, -1, -1, -1}, {24896, -1, -1, -1}, {24897, -1, -1, -1}, {24898, -1, -1, -1}, {24899, -1, -1, -1}, {24900, -1, -1, -1}, {24901, -1, -1, -1}, {24902, -1, -1, -1}, {24903, -1, -1, -1}, {24905, -1, -1, -1}, {24909, -1, -1, -1}, {24911, -1, -1, -1}, {24912, -1, -1, -1}, {24914, -1, -1, -1}, {24915, -1, -1, -1}, {24916, -1, -1, -1}, {24918, -1, -1, -1}, {24919, -1, -1, -1}, {24921, -1, -1, -1}, {24923, -1, -1, -1}, {24924, -1, -1, -1}, {24926, -1, -1, -1}, {24928, -1, -1, -1}, {24929, -1, -1, -1}, {24933, -1, -1, -1}, {24934, -1, -1, -1}, {24937, -1, -1, -1}, {24940, -1, -1, -1}, {24941, -1, -1, -1}, {24943, -1, -1, -1}, {24945, -1, -1, -1}, {24946, -1, -1, -1}, {24948, -1, -1, -1}, {24952, -1, -1, -1}, {24953, -1, -1, -1}, {24954, -1, -1, -1}, {24955, -1, -1, -1}, {24956, -1, -1, -1}, {24957, -1, -1, -1}, {24958, -1, -1, -1}, {24959, -1, -1, -1}, {24960, -1, -1, -1}, {24961, -1, -1, -1}, {24963, -1, -1, -1}, {24964, -1, -1, -1}, {24965, -1, -1, -1}, {24966, -1, -1, -1}, {24967, -1, -1, -1}, {24968, -1, -1, -1}, {24969, -1, -1, -1}, {24972, -1, -1, -1}, {24973, -1, -1, -1}, {24975, -1, -1, -1}, {24979, -1, -1, -1}, {24981, -1, -1, -1}, {24982, -1, -1, -1}, {24983, -1, -1, -1}, {24984, -1, -1, -1}, {24985, -1, -1, -1}, {24987, -1, -1, -1}, {24988, -1, -1, -1}, {24990, -1, -1, -1}, {24991, -1, -1, -1}, {24992, -1, -1, -1}, {24993, -1, -1, -1}, {24994, -1, -1, -1}, {24995, -1, -1, -1}, {24997, -1, -1, -1}, {24998, -1, -1, -1}, {25002, -1, -1, -1}, {25005, -1, -1, -1}, {25007, -1, -1, -1}, {25008, -1, -1, -1}, {25009, -1, -1, -1}, {25011, -1, -1, -1}, {25012, -1, -1, -1}, {25013, -1, -1, -1}, {25016, -1, -1, -1}, {25017, -1, -1, -1}, {25018, -1, -1, -1}, {25019, -1, -1, -1}, {25020, -1, -1, -1}, {25021, -1, -1, -1}, {25023, -1, -1, -1}, {25024, -1, -1, -1}, {25025, -1, -1, -1}, {25027, -1, -1, -1}, {25028, -1, -1, -1}, {25029, -1, -1, -1}, {25030, -1, -1, -1}, {25037, -1, -1, -1}, {25038, -1, -1, -1}, {25039, -1, -1, -1}, {25040, -1, -1, -1}, {25043, -1, -1, -1}, {25045, -1, -1, -1}, {25046, -1, -1, -1}, {25047, -1, -1, -1}, {25048, -1, -1, -1}, {25049, -1, -1, -1}, {25050, -1, -1, -1}, {25051, -1, -1, -1}, {25052, -1, -1, -1}, {25053, -1, -1, -1}, {25056, -1, -1, -1}, {25057, -1, -1, -1}, {25058, -1, -1, -1}, {25060, -1, -1, -1}, {25061, -1, -1, -1}, {25063, -1, -1, -1}, {25065, -1, -1, -1}, {25066, -1, -1, -1}, {25067, -1, -1, -1}, {25068, -1, -1, -1}, {25069, -1, -1, -1}, {25070, -1, -1, -1}, {25071, -1, -1, -1}, {25072, -1, -1, -1}, {25073, -1, -1, -1}, {25075, -1, -1, -1}, {25076, -1, -1, -1}, {25081, -1, -1, -1}, {25083, -1, -1, -1}, {25085, -1, -1, -1}, {25089, -1, -1, -1}, {25090, -1, -1, -1}, {25091, -1, -1, -1}, {25092, -1, -1, -1}, {25093, -1, -1, -1}, {25097, -1, -1, -1}, {25107, -1, -1, -1}, {25113, -1, -1, -1}, {25116, -1, -1, -1}, {25117, -1, -1, -1}, {25118, -1, -1, -1}, {25120, -1, -1, -1}, {25123, -1, -1, -1}, {25126, -1, -1, -1}, {25128, -1, -1, -1}, {25129, -1, -1, -1}, {25131, -1, -1, -1}, {25133, -1, -1, -1}, {25135, -1, -1, -1}, {25137, -1, -1, -1}, {25141, -1, -1, -1}, {12094, 25142, -1, -1}, {25144, -1, -1, -1}, {25145, -1, -1, -1}, {25146, -1, -1, -1}, {25147, -1, -1, -1}, {25148, -1, -1, -1}, {25154, -1, -1, -1}, {25156, -1, -1, -1}, {25157, -1, -1, -1}, {25158, -1, -1, -1}, {25162, -1, -1, -1}, {25167, -1, -1, -1}, {25168, -1, -1, -1}, {25173, -1, -1, -1}, {25174, -1, -1, -1}, {25175, -1, -1, -1}, {25177, -1, -1, -1}, {25178, -1, -1, -1}, {25180, -1, -1, -1}, {25181, -1, -1, -1}, {25182, -1, -1, -1}, {25183, -1, -1, -1}, {25184, -1, -1, -1}, {25185, -1, -1, -1}, {25186, -1, -1, -1}, {25188, -1, -1, -1}, {25189, -1, -1, -1}, {25192, -1, -1, -1}, {25201, -1, -1, -1}, {25202, -1, -1, -1}, {25204, -1, -1, -1}, {25205, -1, -1, -1}, {25207, -1, -1, -1}, {25208, -1, -1, -1}, {25210, -1, -1, -1}, {25211, -1, -1, -1}, {25213, -1, -1, -1}, {25217, -1, -1, -1}, {25218, -1, -1, -1}, {25219, -1, -1, -1}, {25221, -1, -1, -1}, {25222, -1, -1, -1}, {25223, -1, -1, -1}, {25224, -1, -1, -1}, {25227, -1, -1, -1}, {25228, -1, -1, -1}, {25229, -1, -1, -1}, {25230, -1, -1, -1}, {25231, -1, -1, -1}, {25232, -1, -1, -1}, {25236, -1, -1, -1}, {25241, -1, -1, -1}, {25244, -1, -1, -1}, {25245, -1, -1, -1}, {25246, -1, -1, -1}, {25251, -1, -1, -1}, {25254, -1, -1, -1}, {25255, -1, -1, -1}, {25257, -1, -1, -1}, {25258, -1, -1, -1}, {25261, -1, -1, -1}, {25262, -1, -1, -1}, {25263, -1, -1, -1}, {25264, -1, -1, -1}, {25266, -1, -1, -1}, {25267, -1, -1, -1}, {25268, -1, -1, -1}, {25270, -1, -1, -1}, {25271, -1, -1, -1}, {25272, -1, -1, -1}, {25274, -1, -1, -1}, {25278, -1, -1, -1}, {25280, -1, -1, -1}, {25281, -1, -1, -1}, {25283, -1, -1, -1}, {25291, -1, -1, -1}, {25295, -1, -1, -1}, {25297, -1, -1, -1}, {25301, -1, -1, -1}, {25309, -1, -1, -1}, {25310, -1, -1, -1}, {25312, -1, -1, -1}, {25313, -1, -1, -1}, {25316, -1, -1, -1}, {25322, -1, -1, -1}, {25323, -1, -1, -1}, {25328, -1, -1, -1}, {25330, -1, -1, -1}, {25333, -1, -1, -1}, {25336, -1, -1, -1}, {25337, -1, -1, -1}, {25338, -1, -1, -1}, {25339, -1, -1, -1}, {25344, -1, -1, -1}, {25347, -1, -1, -1}, {25348, -1, -1, -1}, {25349, -1, -1, -1}, {25350, -1, -1, -1}, {25354, -1, -1, -1}, {25355, -1, -1, -1}, {25356, -1, -1, -1}, {25357, -1, -1, -1}, {25359, -1, -1, -1}, {25360, -1, -1, -1}, {25362, -1, -1, -1}, {25363, -1, -1, -1}, {25364, -1, -1, -1}, {25365, -1, -1, -1}, {25367, -1, -1, -1}, {25368, -1, -1, -1} },
+ {{25369, -1, -1, -1}, {25372, -1, -1, -1}, {25382, -1, -1, -1}, {25383, -1, -1, -1}, {25385, -1, -1, -1}, {25388, -1, -1, -1}, {25389, -1, -1, -1}, {25390, -1, -1, -1}, {25392, -1, -1, -1}, {25393, -1, -1, -1}, {25395, -1, -1, -1}, {25396, -1, -1, -1}, {25397, -1, -1, -1}, {25398, -1, -1, -1}, {25399, -1, -1, -1}, {25400, -1, -1, -1}, {25403, -1, -1, -1}, {25404, -1, -1, -1}, {25407, -1, -1, -1}, {25408, -1, -1, -1}, {25409, -1, -1, -1}, {25412, -1, -1, -1}, {25415, -1, -1, -1}, {25416, -1, -1, -1}, {25418, -1, -1, -1}, {25425, -1, -1, -1}, {25426, -1, -1, -1}, {25427, -1, -1, -1}, {25428, -1, -1, -1}, {25430, -1, -1, -1}, {25431, -1, -1, -1}, {25432, -1, -1, -1}, {25433, -1, -1, -1}, {25434, -1, -1, -1}, {25435, -1, -1, -1}, {25436, -1, -1, -1}, {25437, -1, -1, -1}, {25440, -1, -1, -1}, {25444, -1, -1, -1}, {25445, -1, -1, -1}, {25446, -1, -1, -1}, {25450, -1, -1, -1}, {25452, -1, -1, -1}, {25455, -1, -1, -1}, {25456, -1, -1, -1}, {25459, -1, -1, -1}, {25460, -1, -1, -1}, {25461, -1, -1, -1}, {25464, -1, -1, -1}, {25465, -1, -1, -1}, {25468, -1, -1, -1}, {25469, -1, -1, -1}, {25470, -1, -1, -1}, {25471, -1, -1, -1}, {25473, -1, -1, -1}, {25477, -1, -1, -1}, {25478, -1, -1, -1}, {25483, -1, -1, -1}, {25485, -1, -1, -1}, {25489, -1, -1, -1}, {25491, -1, -1, -1}, {25492, -1, -1, -1}, {25493, -1, -1, -1}, {25495, -1, -1, -1}, {25497, -1, -1, -1}, {25498, -1, -1, -1}, {25499, -1, -1, -1}, {25500, -1, -1, -1}, {25501, -1, -1, -1}, {25502, -1, -1, -1}, {25503, -1, -1, -1}, {25505, -1, -1, -1}, {25508, -1, -1, -1}, {25510, -1, -1, -1}, {25515, -1, -1, -1}, {25519, -1, -1, -1}, {25521, -1, -1, -1}, {25522, -1, -1, -1}, {25525, -1, -1, -1}, {25526, -1, -1, -1}, {25529, -1, -1, -1}, {25531, -1, -1, -1}, {25533, -1, -1, -1}, {25535, -1, -1, -1}, {25537, -1, -1, -1}, {25538, -1, -1, -1}, {25539, -1, -1, -1}, {25541, -1, -1, -1}, {25543, -1, -1, -1}, {25544, -1, -1, -1}, {25546, -1, -1, -1}, {25547, -1, -1, -1}, {25548, -1, -1, -1}, {25553, -1, -1, -1}, {25555, -1, -1, -1}, {25556, -1, -1, -1}, {25557, -1, -1, -1}, {25559, -1, -1, -1}, {25560, -1, -1, -1}, {25561, -1, -1, -1}, {25563, -1, -1, -1}, {25564, -1, -1, -1}, {25565, -1, -1, -1}, {25567, -1, -1, -1}, {25570, -1, -1, -1}, {25572, -1, -1, -1}, {25573, -1, -1, -1}, {25574, -1, -1, -1}, {25575, -1, -1, -1}, {25576, -1, -1, -1}, {25579, -1, -1, -1}, {25580, -1, -1, -1}, {25583, -1, -1, -1}, {25584, -1, -1, -1}, {25585, -1, -1, -1}, {25587, -1, -1, -1}, {25589, -1, -1, -1}, {25591, -1, -1, -1}, {25593, -1, -1, -1}, {25594, -1, -1, -1}, {25595, -1, -1, -1}, {25596, -1, -1, -1}, {25598, -1, -1, -1}, {25603, -1, -1, -1}, {25604, -1, -1, -1}, {25606, -1, -1, -1}, {25607, -1, -1, -1}, {25608, -1, -1, -1}, {25609, -1, -1, -1}, {25610, -1, -1, -1}, {25614, -1, -1, -1}, {25617, -1, -1, -1}, {25618, -1, -1, -1}, {25621, -1, -1, -1}, {25622, -1, -1, -1}, {25624, -1, -1, -1}, {25625, -1, -1, -1}, {25626, -1, -1, -1}, {25629, -1, -1, -1}, {25631, -1, -1, -1}, {25634, -1, -1, -1}, {25635, -1, -1, -1}, {25636, -1, -1, -1}, {25637, -1, -1, -1}, {25639, -1, -1, -1}, {25640, -1, -1, -1}, {25641, -1, -1, -1}, {25643, -1, -1, -1}, {25646, -1, -1, -1}, {25647, -1, -1, -1}, {25648, -1, -1, -1}, {25649, -1, -1, -1}, {25650, -1, -1, -1}, {25651, -1, -1, -1}, {25653, -1, -1, -1}, {25655, -1, -1, -1}, {25656, -1, -1, -1}, {25657, -1, -1, -1}, {25659, -1, -1, -1}, {25660, -1, -1, -1}, {25662, -1, -1, -1}, {25664, -1, -1, -1}, {25666, -1, -1, -1}, {25667, -1, -1, -1}, {25673, -1, -1, -1}, {25675, -1, -1, -1}, {25676, -1, -1, -1}, {25677, -1, -1, -1}, {25678, -1, -1, -1}, {25679, -1, -1, -1}, {25680, -1, -1, -1}, {25683, -1, -1, -1}, {25685, -1, -1, -1}, {25686, -1, -1, -1}, {25687, -1, -1, -1}, {25689, -1, -1, -1}, {25690, -1, -1, -1}, {25691, -1, -1, -1}, {25693, -1, -1, -1}, {25696, -1, -1, -1}, {25697, -1, -1, -1}, {25698, -1, -1, -1}, {25699, -1, -1, -1}, {25700, -1, -1, -1}, {25701, -1, -1, -1}, {25702, -1, -1, -1}, {25704, -1, -1, -1}, {25706, -1, -1, -1}, {25707, -1, -1, -1}, {25708, -1, -1, -1}, {25710, -1, -1, -1}, {25712, -1, -1, -1}, {25713, -1, -1, -1}, {25714, -1, -1, -1}, {25716, -1, -1, -1}, {25717, -1, -1, -1}, {25719, -1, -1, -1}, {25724, -1, -1, -1}, {25725, -1, -1, -1}, {25726, -1, -1, -1}, {25727, -1, -1, -1}, {25728, -1, -1, -1}, {25729, -1, -1, -1}, {25731, -1, -1, -1}, {25734, -1, -1, -1}, {25737, -1, -1, -1}, {25738, -1, -1, -1}, {25739, -1, -1, -1}, {25740, -1, -1, -1}, {25741, -1, -1, -1}, {25742, -1, -1, -1}, {25743, -1, -1, -1}, {25744, -1, -1, -1}, {25748, -1, -1, -1}, {25751, -1, -1, -1}, {25752, -1, -1, -1}, {25754, -1, -1, -1}, {25755, -1, -1, -1}, {25756, -1, -1, -1}, {25757, -1, -1, -1}, {25760, -1, -1, -1}, {25761, -1, -1, -1}, {25762, -1, -1, -1}, {25766, -1, -1, -1}, {25767, -1, -1, -1}, {25768, -1, -1, -1}, {25770, -1, -1, -1}, {25775, -1, -1, -1}, {25777, -1, -1, -1}, {25780, -1, -1, -1}, {25782, -1, -1, -1}, {25785, -1, -1, -1}, {25789, -1, -1, -1}, {25795, -1, -1, -1}, {25798, -1, -1, -1}, {25800, -1, -1, -1}, {25801, -1, -1, -1}, {25804, -1, -1, -1}, {25807, -1, -1, -1}, {25809, -1, -1, -1}, {25811, -1, -1, -1}, {25813, -1, -1, -1}, {25814, -1, -1, -1}, {25817, -1, -1, -1}, {25819, -1, -1, -1}, {25820, -1, -1, -1}, {25821, -1, -1, -1}, {25823, -1, -1, -1}, {25825, -1, -1, -1}, {25827, -1, -1, -1}, {25829, -1, -1, -1}, {25831, -1, -1, -1}, {25832, -1, -1, -1}, {25833, -1, -1, -1}, {25834, -1, -1, -1}, {25835, -1, -1, -1} },
+ {{25837, -1, -1, -1}, {25838, -1, -1, -1}, {25843, -1, -1, -1}, {25845, -1, -1, -1}, {25846, -1, -1, -1}, {25848, -1, -1, -1}, {25849, -1, -1, -1}, {25853, -1, -1, -1}, {25855, -1, -1, -1}, {25857, -1, -1, -1}, {25858, -1, -1, -1}, {25859, -1, -1, -1}, {25861, -1, -1, -1}, {25863, -1, -1, -1}, {25864, -1, -1, -1}, {25866, -1, -1, -1}, {25867, -1, -1, -1}, {25868, -1, -1, -1}, {25869, -1, -1, -1}, {25870, -1, -1, -1}, {25872, -1, -1, -1}, {25873, -1, -1, -1}, {25875, -1, -1, -1}, {25877, -1, -1, -1}, {25879, -1, -1, -1}, {25882, -1, -1, -1}, {25884, -1, -1, -1}, {25886, -1, -1, -1}, {25887, -1, -1, -1}, {25888, -1, -1, -1}, {25889, -1, -1, -1}, {25894, -1, -1, -1}, {25895, -1, -1, -1}, {25896, -1, -1, -1}, {25897, -1, -1, -1}, {25901, -1, -1, -1}, {25904, -1, -1, -1}, {25905, -1, -1, -1}, {25906, -1, -1, -1}, {25907, -1, -1, -1}, {25911, -1, -1, -1}, {25914, -1, -1, -1}, {25916, -1, -1, -1}, {25917, -1, -1, -1}, {25920, -1, -1, -1}, {25921, -1, -1, -1}, {25922, -1, -1, -1}, {25923, -1, -1, -1}, {25924, -1, -1, -1}, {25926, -1, -1, -1}, {25927, -1, -1, -1}, {25930, -1, -1, -1}, {25931, -1, -1, -1}, {25933, -1, -1, -1}, {25934, -1, -1, -1}, {25936, -1, -1, -1}, {25938, -1, -1, -1}, {25939, -1, -1, -1}, {25940, -1, -1, -1}, {25944, -1, -1, -1}, {25946, -1, -1, -1}, {25948, -1, -1, -1}, {25951, -1, -1, -1}, {25952, -1, -1, -1}, {25953, -1, -1, -1}, {25956, -1, -1, -1}, {25957, -1, -1, -1}, {25959, -1, -1, -1}, {25960, -1, -1, -1}, {25961, -1, -1, -1}, {25962, -1, -1, -1}, {25965, -1, -1, -1}, {25966, -1, -1, -1}, {25967, -1, -1, -1}, {25969, -1, -1, -1}, {25971, -1, -1, -1}, {25974, -1, -1, -1}, {25977, -1, -1, -1}, {25978, -1, -1, -1}, {25979, -1, -1, -1}, {25980, -1, -1, -1}, {25981, -1, -1, -1}, {25982, -1, -1, -1}, {25983, -1, -1, -1}, {25984, -1, -1, -1}, {25985, -1, -1, -1}, {25988, -1, -1, -1}, {25989, -1, -1, -1}, {25990, -1, -1, -1}, {25992, -1, -1, -1}, {25993, -1, -1, -1}, {25994, -1, -1, -1}, {25997, -1, -1, -1}, {25998, -1, -1, -1}, {25999, -1, -1, -1}, {26002, -1, -1, -1}, {26004, -1, -1, -1}, {26006, -1, -1, -1}, {26008, -1, -1, -1}, {26010, -1, -1, -1}, {26013, -1, -1, -1}, {26014, -1, -1, -1}, {26016, -1, -1, -1}, {26018, -1, -1, -1}, {26019, -1, -1, -1}, {26022, -1, -1, -1}, {26024, -1, -1, -1}, {26026, -1, -1, -1}, {26030, -1, -1, -1}, {26033, -1, -1, -1}, {26034, -1, -1, -1}, {26035, -1, -1, -1}, {26036, -1, -1, -1}, {26037, -1, -1, -1}, {26038, -1, -1, -1}, {26040, -1, -1, -1}, {26042, -1, -1, -1}, {26043, -1, -1, -1}, {26046, -1, -1, -1}, {26047, -1, -1, -1}, {26048, -1, -1, -1}, {26050, -1, -1, -1}, {26055, -1, -1, -1}, {26056, -1, -1, -1}, {26057, -1, -1, -1}, {26058, -1, -1, -1}, {26061, -1, -1, -1}, {26064, -1, -1, -1}, {26065, -1, -1, -1}, {26067, -1, -1, -1}, {26068, -1, -1, -1}, {26069, -1, -1, -1}, {26072, -1, -1, -1}, {26073, -1, -1, -1}, {26074, -1, -1, -1}, {26075, -1, -1, -1}, {26076, -1, -1, -1}, {26077, -1, -1, -1}, {26078, -1, -1, -1}, {26079, -1, -1, -1}, {26081, -1, -1, -1}, {26083, -1, -1, -1}, {26084, -1, -1, -1}, {26090, -1, -1, -1}, {26091, -1, -1, -1}, {26098, -1, -1, -1}, {26099, -1, -1, -1}, {26100, -1, -1, -1}, {26101, -1, -1, -1}, {26104, -1, -1, -1}, {26105, -1, -1, -1}, {26107, -1, -1, -1}, {26108, -1, -1, -1}, {26109, -1, -1, -1}, {26110, -1, -1, -1}, {26111, -1, -1, -1}, {26113, -1, -1, -1}, {26116, -1, -1, -1}, {26117, -1, -1, -1}, {26119, -1, -1, -1}, {26120, -1, -1, -1}, {26121, -1, -1, -1}, {26123, -1, -1, -1}, {26125, -1, -1, -1}, {26128, -1, -1, -1}, {26129, -1, -1, -1}, {26130, -1, -1, -1}, {26134, -1, -1, -1}, {26135, -1, -1, -1}, {26136, -1, -1, -1}, {26138, -1, -1, -1}, {26139, -1, -1, -1}, {26140, -1, -1, -1}, {26142, -1, -1, -1}, {26145, -1, -1, -1}, {26146, -1, -1, -1}, {26147, -1, -1, -1}, {26148, -1, -1, -1}, {26150, -1, -1, -1}, {26153, -1, -1, -1}, {26154, -1, -1, -1}, {26155, -1, -1, -1}, {26156, -1, -1, -1}, {26158, -1, -1, -1}, {26160, -1, -1, -1}, {26162, -1, -1, -1}, {26163, -1, -1, -1}, {26167, -1, -1, -1}, {26168, -1, -1, -1}, {26169, -1, -1, -1}, {26170, -1, -1, -1}, {26171, -1, -1, -1}, {26173, -1, -1, -1}, {26175, -1, -1, -1}, {26176, -1, -1, -1}, {26180, -1, -1, -1}, {26181, -1, -1, -1}, {26182, -1, -1, -1}, {26183, -1, -1, -1}, {26184, -1, -1, -1}, {26185, -1, -1, -1}, {26186, -1, -1, -1}, {26189, -1, -1, -1}, {26190, -1, -1, -1}, {26192, -1, -1, -1}, {26193, -1, -1, -1}, {26200, -1, -1, -1}, {26201, -1, -1, -1}, {26203, -1, -1, -1}, {26204, -1, -1, -1}, {26206, -1, -1, -1}, {26208, -1, -1, -1}, {26210, -1, -1, -1}, {26211, -1, -1, -1}, {26213, -1, -1, -1}, {26215, -1, -1, -1}, {26217, -1, -1, -1}, {26218, -1, -1, -1}, {26219, -1, -1, -1}, {26220, -1, -1, -1}, {26221, -1, -1, -1}, {26225, -1, -1, -1}, {26226, -1, -1, -1}, {26227, -1, -1, -1}, {26229, -1, -1, -1}, {26232, -1, -1, -1}, {26233, -1, -1, -1}, {26235, -1, -1, -1}, {26236, -1, -1, -1}, {26237, -1, -1, -1}, {26239, -1, -1, -1}, {26240, -1, -1, -1}, {26241, -1, -1, -1}, {26243, -1, -1, -1}, {26245, -1, -1, -1}, {26246, -1, -1, -1}, {26250, -1, -1, -1}, {26251, -1, -1, -1}, {26253, -1, -1, -1}, {26254, -1, -1, -1}, {26255, -1, -1, -1}, {26256, -1, -1, -1}, {26258, -1, -1, -1}, {26259, -1, -1, -1}, {26260, -1, -1, -1}, {26261, -1, -1, -1}, {26264, -1, -1, -1}, {26265, -1, -1, -1}, {26266, -1, -1, -1}, {26267, -1, -1, -1}, {26268, -1, -1, -1}, {26270, -1, -1, -1}, {26271, -1, -1, -1}, {26272, -1, -1, -1}, {26273, -1, -1, -1}, {26275, -1, -1, -1} },
+ {{26276, -1, -1, -1}, {26277, -1, -1, -1}, {26278, -1, -1, -1}, {26281, -1, -1, -1}, {26282, -1, -1, -1}, {26284, -1, -1, -1}, {26285, -1, -1, -1}, {26287, -1, -1, -1}, {26288, -1, -1, -1}, {26289, -1, -1, -1}, {26290, -1, -1, -1}, {26291, -1, -1, -1}, {26293, -1, -1, -1}, {26294, -1, -1, -1}, {26295, -1, -1, -1}, {26296, -1, -1, -1}, {26298, -1, -1, -1}, {26299, -1, -1, -1}, {26300, -1, -1, -1}, {26301, -1, -1, -1}, {26303, -1, -1, -1}, {26304, -1, -1, -1}, {26305, -1, -1, -1}, {26306, -1, -1, -1}, {26307, -1, -1, -1}, {26309, -1, -1, -1}, {26312, -1, -1, -1}, {26314, -1, -1, -1}, {26315, -1, -1, -1}, {26316, -1, -1, -1}, {26317, -1, -1, -1}, {26318, -1, -1, -1}, {26319, -1, -1, -1}, {26320, -1, -1, -1}, {26321, -1, -1, -1}, {26322, -1, -1, -1}, {26323, -1, -1, -1}, {26324, -1, -1, -1}, {26325, -1, -1, -1}, {26327, -1, -1, -1}, {26328, -1, -1, -1}, {26330, -1, -1, -1}, {26334, -1, -1, -1}, {26335, -1, -1, -1}, {26337, -1, -1, -1}, {26338, -1, -1, -1}, {26339, -1, -1, -1}, {26340, -1, -1, -1}, {26341, -1, -1, -1}, {26343, -1, -1, -1}, {26344, -1, -1, -1}, {26346, -1, -1, -1}, {26347, -1, -1, -1}, {26349, -1, -1, -1}, {26350, -1, -1, -1}, {26351, -1, -1, -1}, {26353, -1, -1, -1}, {26357, -1, -1, -1}, {26358, -1, -1, -1}, {26362, -1, -1, -1}, {26363, -1, -1, -1}, {26365, -1, -1, -1}, {26369, -1, -1, -1}, {26370, -1, -1, -1}, {26372, -1, -1, -1}, {26373, -1, -1, -1}, {26374, -1, -1, -1}, {26375, -1, -1, -1}, {26380, -1, -1, -1}, {26382, -1, -1, -1}, {26383, -1, -1, -1}, {26385, -1, -1, -1}, {26386, -1, -1, -1}, {26387, -1, -1, -1}, {26390, -1, -1, -1}, {26392, -1, -1, -1}, {26393, -1, -1, -1}, {26394, -1, -1, -1}, {26396, -1, -1, -1}, {26398, -1, -1, -1}, {26400, -1, -1, -1}, {26401, -1, -1, -1}, {26402, -1, -1, -1}, {26403, -1, -1, -1}, {26404, -1, -1, -1}, {26405, -1, -1, -1}, {26409, -1, -1, -1}, {26414, -1, -1, -1}, {26416, -1, -1, -1}, {26418, -1, -1, -1}, {26419, -1, -1, -1}, {26422, -1, -1, -1}, {26423, -1, -1, -1}, {26424, -1, -1, -1}, {26425, -1, -1, -1}, {26427, -1, -1, -1}, {26428, -1, -1, -1}, {26430, -1, -1, -1}, {26431, -1, -1, -1}, {26433, -1, -1, -1}, {26436, -1, -1, -1}, {26437, -1, -1, -1}, {26439, -1, -1, -1}, {26442, -1, -1, -1}, {26443, -1, -1, -1}, {26445, -1, -1, -1}, {26450, -1, -1, -1}, {26452, -1, -1, -1}, {26453, -1, -1, -1}, {26455, -1, -1, -1}, {26456, -1, -1, -1}, {26457, -1, -1, -1}, {26458, -1, -1, -1}, {26459, -1, -1, -1}, {26461, -1, -1, -1}, {26466, -1, -1, -1}, {26467, -1, -1, -1}, {26468, -1, -1, -1}, {26470, -1, -1, -1}, {26471, -1, -1, -1}, {26475, -1, -1, -1}, {26476, -1, -1, -1}, {26478, -1, -1, -1}, {26484, -1, -1, -1}, {26486, -1, -1, -1}, {26488, -1, -1, -1}, {26489, -1, -1, -1}, {26490, -1, -1, -1}, {26491, -1, -1, -1}, {26493, -1, -1, -1}, {26496, -1, -1, -1}, {26498, -1, -1, -1}, {26499, -1, -1, -1}, {26501, -1, -1, -1}, {26502, -1, -1, -1}, {26504, -1, -1, -1}, {26506, -1, -1, -1}, {26508, -1, -1, -1}, {26509, -1, -1, -1}, {26510, -1, -1, -1}, {26511, -1, -1, -1}, {26513, -1, -1, -1}, {26514, -1, -1, -1}, {26515, -1, -1, -1}, {26516, -1, -1, -1}, {26518, -1, -1, -1}, {26521, -1, -1, -1}, {26523, -1, -1, -1}, {26527, -1, -1, -1}, {26528, -1, -1, -1}, {26529, -1, -1, -1}, {26532, -1, -1, -1}, {26534, -1, -1, -1}, {26537, -1, -1, -1}, {26540, -1, -1, -1}, {26542, -1, -1, -1}, {26545, -1, -1, -1}, {26546, -1, -1, -1}, {26548, -1, -1, -1}, {26553, -1, -1, -1}, {26554, -1, -1, -1}, {26555, -1, -1, -1}, {26556, -1, -1, -1}, {26557, -1, -1, -1}, {26558, -1, -1, -1}, {26559, -1, -1, -1}, {26560, -1, -1, -1}, {26562, -1, -1, -1}, {26565, -1, -1, -1}, {26566, -1, -1, -1}, {26567, -1, -1, -1}, {26568, -1, -1, -1}, {26569, -1, -1, -1}, {26570, -1, -1, -1}, {26571, -1, -1, -1}, {26572, -1, -1, -1}, {26573, -1, -1, -1}, {26574, -1, -1, -1}, {26581, -1, -1, -1}, {26582, -1, -1, -1}, {26583, -1, -1, -1}, {26587, -1, -1, -1}, {26591, -1, -1, -1}, {26593, -1, -1, -1}, {26595, -1, -1, -1}, {26596, -1, -1, -1}, {26598, -1, -1, -1}, {26599, -1, -1, -1}, {26600, -1, -1, -1}, {26602, -1, -1, -1}, {26603, -1, -1, -1}, {26605, -1, -1, -1}, {26606, -1, -1, -1}, {26610, -1, -1, -1}, {26613, -1, -1, -1}, {26614, -1, -1, -1}, {26615, -1, -1, -1}, {26616, -1, -1, -1}, {26617, -1, -1, -1}, {26618, -1, -1, -1}, {26619, -1, -1, -1}, {26620, -1, -1, -1}, {26622, -1, -1, -1}, {26625, -1, -1, -1}, {26626, -1, -1, -1}, {26627, -1, -1, -1}, {26628, -1, -1, -1}, {26630, -1, -1, -1}, {26637, -1, -1, -1}, {26640, -1, -1, -1}, {26642, -1, -1, -1}, {26644, -1, -1, -1}, {26645, -1, -1, -1}, {26648, -1, -1, -1}, {26649, -1, -1, -1}, {26650, -1, -1, -1}, {26651, -1, -1, -1}, {26652, -1, -1, -1}, {26654, -1, -1, -1}, {26655, -1, -1, -1}, {26656, -1, -1, -1}, {26658, -1, -1, -1}, {26659, -1, -1, -1}, {26660, -1, -1, -1}, {26661, -1, -1, -1}, {26662, -1, -1, -1}, {26663, -1, -1, -1}, {26664, -1, -1, -1}, {26667, -1, -1, -1}, {26668, -1, -1, -1}, {26669, -1, -1, -1}, {26670, -1, -1, -1}, {26671, -1, -1, -1}, {26672, -1, -1, -1}, {26673, -1, -1, -1}, {26676, -1, -1, -1}, {26677, -1, -1, -1}, {26678, -1, -1, -1}, {26682, -1, -1, -1}, {26683, -1, -1, -1}, {26687, -1, -1, -1}, {26695, -1, -1, -1}, {26699, -1, -1, -1}, {26701, -1, -1, -1}, {26703, -1, -1, -1}, {26706, -1, -1, -1}, {26710, -1, -1, -1}, {26711, -1, -1, -1}, {26712, -1, -1, -1}, {26713, -1, -1, -1}, {26714, -1, -1, -1}, {26715, -1, -1, -1}, {26716, -1, -1, -1}, {26717, -1, -1, -1}, {26718, -1, -1, -1}, {26719, -1, -1, -1} },
+ {{26730, -1, -1, -1}, {26732, -1, -1, -1}, {26733, -1, -1, -1}, {26734, -1, -1, -1}, {26735, -1, -1, -1}, {26736, -1, -1, -1}, {26737, -1, -1, -1}, {26738, -1, -1, -1}, {26739, -1, -1, -1}, {26741, -1, -1, -1}, {26744, -1, -1, -1}, {26745, -1, -1, -1}, {26746, -1, -1, -1}, {26747, -1, -1, -1}, {26748, -1, -1, -1}, {26749, -1, -1, -1}, {26750, -1, -1, -1}, {26751, -1, -1, -1}, {26752, -1, -1, -1}, {26754, -1, -1, -1}, {26756, -1, -1, -1}, {26759, -1, -1, -1}, {26760, -1, -1, -1}, {26761, -1, -1, -1}, {26762, -1, -1, -1}, {26763, -1, -1, -1}, {26764, -1, -1, -1}, {26765, -1, -1, -1}, {26766, -1, -1, -1}, {26768, -1, -1, -1}, {26769, -1, -1, -1}, {26770, -1, -1, -1}, {26772, -1, -1, -1}, {26773, -1, -1, -1}, {26774, -1, -1, -1}, {26777, -1, -1, -1}, {26778, -1, -1, -1}, {26779, -1, -1, -1}, {26780, -1, -1, -1}, {26782, -1, -1, -1}, {26784, -1, -1, -1}, {26785, -1, -1, -1}, {26787, -1, -1, -1}, {26788, -1, -1, -1}, {26789, -1, -1, -1}, {26793, -1, -1, -1}, {26794, -1, -1, -1}, {26795, -1, -1, -1}, {26796, -1, -1, -1}, {26798, -1, -1, -1}, {26801, -1, -1, -1}, {26802, -1, -1, -1}, {26804, -1, -1, -1}, {26806, -1, -1, -1}, {26807, -1, -1, -1}, {26808, -1, -1, -1}, {26809, -1, -1, -1}, {26810, -1, -1, -1}, {26811, -1, -1, -1}, {26812, -1, -1, -1}, {26813, -1, -1, -1}, {26814, -1, -1, -1}, {26815, -1, -1, -1}, {26817, -1, -1, -1}, {26819, -1, -1, -1}, {26820, -1, -1, -1}, {26821, -1, -1, -1}, {26822, -1, -1, -1}, {26823, -1, -1, -1}, {26824, -1, -1, -1}, {26826, -1, -1, -1}, {26828, -1, -1, -1}, {26830, -1, -1, -1}, {26831, -1, -1, -1}, {26832, -1, -1, -1}, {26833, -1, -1, -1}, {26835, -1, -1, -1}, {26836, -1, -1, -1}, {26841, -1, -1, -1}, {26843, -1, -1, -1}, {26844, -1, -1, -1}, {26845, -1, -1, -1}, {26846, -1, -1, -1}, {26849, -1, -1, -1}, {26850, -1, -1, -1}, {26852, -1, -1, -1}, {26853, -1, -1, -1}, {26854, -1, -1, -1}, {26856, -1, -1, -1}, {26857, -1, -1, -1}, {26858, -1, -1, -1}, {26859, -1, -1, -1}, {26860, -1, -1, -1}, {26861, -1, -1, -1}, {26863, -1, -1, -1}, {26866, -1, -1, -1}, {26867, -1, -1, -1}, {26868, -1, -1, -1}, {26870, -1, -1, -1}, {26871, -1, -1, -1}, {26872, -1, -1, -1}, {26875, -1, -1, -1}, {26877, -1, -1, -1}, {26878, -1, -1, -1}, {26879, -1, -1, -1}, {26880, -1, -1, -1}, {26882, -1, -1, -1}, {26883, -1, -1, -1}, {26884, -1, -1, -1}, {26886, -1, -1, -1}, {26887, -1, -1, -1}, {26888, -1, -1, -1}, {26889, -1, -1, -1}, {26890, -1, -1, -1}, {26892, -1, -1, -1}, {26897, -1, -1, -1}, {26899, -1, -1, -1}, {26900, -1, -1, -1}, {26901, -1, -1, -1}, {26902, -1, -1, -1}, {26903, -1, -1, -1}, {26904, -1, -1, -1}, {26905, -1, -1, -1}, {26906, -1, -1, -1}, {26907, -1, -1, -1}, {26908, -1, -1, -1}, {26909, -1, -1, -1}, {26910, -1, -1, -1}, {26913, -1, -1, -1}, {26914, -1, -1, -1}, {26915, -1, -1, -1}, {26917, -1, -1, -1}, {26918, -1, -1, -1}, {26919, -1, -1, -1}, {26920, -1, -1, -1}, {26921, -1, -1, -1}, {26922, -1, -1, -1}, {26923, -1, -1, -1}, {26924, -1, -1, -1}, {26926, -1, -1, -1}, {26927, -1, -1, -1}, {26929, -1, -1, -1}, {26930, -1, -1, -1}, {26931, -1, -1, -1}, {26933, -1, -1, -1}, {26934, -1, -1, -1}, {26935, -1, -1, -1}, {26936, -1, -1, -1}, {26938, -1, -1, -1}, {26939, -1, -1, -1}, {26940, -1, -1, -1}, {26942, -1, -1, -1}, {26944, -1, -1, -1}, {26945, -1, -1, -1}, {26947, -1, -1, -1}, {26948, -1, -1, -1}, {26949, -1, -1, -1}, {26950, -1, -1, -1}, {26951, -1, -1, -1}, {26952, -1, -1, -1}, {26953, -1, -1, -1}, {26955, -1, -1, -1}, {26956, -1, -1, -1}, {26957, -1, -1, -1}, {26958, -1, -1, -1}, {26959, -1, -1, -1}, {26960, -1, -1, -1}, {26961, -1, -1, -1}, {26962, -1, -1, -1}, {26965, -1, -1, -1}, {26966, -1, -1, -1}, {26968, -1, -1, -1}, {26969, -1, -1, -1}, {26971, -1, -1, -1}, {26972, -1, -1, -1}, {26975, -1, -1, -1}, {26977, -1, -1, -1}, {26978, -1, -1, -1}, {26980, -1, -1, -1}, {26981, -1, -1, -1}, {26983, -1, -1, -1}, {26985, -1, -1, -1}, {26986, -1, -1, -1}, {26988, -1, -1, -1}, {26991, -1, -1, -1}, {26992, -1, -1, -1}, {26994, -1, -1, -1}, {26995, -1, -1, -1}, {26996, -1, -1, -1}, {26998, -1, -1, -1}, {27002, -1, -1, -1}, {27003, -1, -1, -1}, {27005, -1, -1, -1}, {27006, -1, -1, -1}, {27007, -1, -1, -1}, {27009, -1, -1, -1}, {27011, -1, -1, -1}, {27013, -1, -1, -1}, {27018, -1, -1, -1}, {27019, -1, -1, -1}, {27020, -1, -1, -1}, {27022, -1, -1, -1}, {27023, -1, -1, -1}, {27024, -1, -1, -1}, {27025, -1, -1, -1}, {27026, -1, -1, -1}, {27027, -1, -1, -1}, {27030, -1, -1, -1}, {27031, -1, -1, -1}, {27033, -1, -1, -1}, {27034, -1, -1, -1}, {27037, -1, -1, -1}, {27038, -1, -1, -1}, {27039, -1, -1, -1}, {27040, -1, -1, -1}, {27041, -1, -1, -1}, {27042, -1, -1, -1}, {27043, -1, -1, -1}, {27044, -1, -1, -1}, {27045, -1, -1, -1}, {27046, -1, -1, -1}, {27049, -1, -1, -1}, {27052, -1, -1, -1}, {27055, -1, -1, -1}, {27056, -1, -1, -1}, {27058, -1, -1, -1}, {27059, -1, -1, -1}, {27061, -1, -1, -1}, {27062, -1, -1, -1}, {27064, -1, -1, -1}, {27065, -1, -1, -1}, {27066, -1, -1, -1}, {27068, -1, -1, -1}, {27069, -1, -1, -1}, {27070, -1, -1, -1}, {27072, -1, -1, -1}, {27074, -1, -1, -1}, {27075, -1, -1, -1}, {27076, -1, -1, -1}, {27077, -1, -1, -1}, {27078, -1, -1, -1}, {27079, -1, -1, -1}, {27080, -1, -1, -1}, {27081, -1, -1, -1}, {27087, -1, -1, -1}, {27089, -1, -1, -1}, {27090, -1, -1, -1}, {27091, -1, -1, -1}, {27093, -1, -1, -1}, {27094, -1, -1, -1}, {27095, -1, -1, -1}, {27096, -1, -1, -1}, {27097, -1, -1, -1}, {27098, -1, -1, -1}, {27100, -1, -1, -1}, {27101, -1, -1, -1} },
+ {{27102, -1, -1, -1}, {27105, -1, -1, -1}, {27106, -1, -1, -1}, {27107, -1, -1, -1}, {27108, -1, -1, -1}, {27109, -1, -1, -1}, {27110, -1, -1, -1}, {27112, -1, -1, -1}, {27113, -1, -1, -1}, {27114, -1, -1, -1}, {27115, -1, -1, -1}, {27116, -1, -1, -1}, {27118, -1, -1, -1}, {27119, -1, -1, -1}, {27120, -1, -1, -1}, {27121, -1, -1, -1}, {27124, -1, -1, -1}, {27125, -1, -1, -1}, {27126, -1, -1, -1}, {27127, -1, -1, -1}, {27128, -1, -1, -1}, {27129, -1, -1, -1}, {27130, -1, -1, -1}, {27131, -1, -1, -1}, {27132, -1, -1, -1}, {27134, -1, -1, -1}, {27136, -1, -1, -1}, {27139, -1, -1, -1}, {27140, -1, -1, -1}, {27142, -1, -1, -1}, {27143, -1, -1, -1}, {27144, -1, -1, -1}, {27145, -1, -1, -1}, {27147, -1, -1, -1}, {27148, -1, -1, -1}, {27149, -1, -1, -1}, {27150, -1, -1, -1}, {27151, -1, -1, -1}, {27152, -1, -1, -1}, {27153, -1, -1, -1}, {27154, -1, -1, -1}, {27156, -1, -1, -1}, {27157, -1, -1, -1}, {27158, -1, -1, -1}, {27162, -1, -1, -1}, {27163, -1, -1, -1}, {27164, -1, -1, -1}, {27165, -1, -1, -1}, {27168, -1, -1, -1}, {27170, -1, -1, -1}, {27172, -1, -1, -1}, {27173, -1, -1, -1}, {27174, -1, -1, -1}, {27175, -1, -1, -1}, {27177, -1, -1, -1}, {27179, -1, -1, -1}, {27180, -1, -1, -1}, {27181, -1, -1, -1}, {27182, -1, -1, -1}, {27184, -1, -1, -1}, {27186, -1, -1, -1}, {27187, -1, -1, -1}, {27188, -1, -1, -1}, {27190, -1, -1, -1}, {27191, -1, -1, -1}, {27195, -1, -1, -1}, {27196, -1, -1, -1}, {27199, -1, -1, -1}, {27200, -1, -1, -1}, {27201, -1, -1, -1}, {27202, -1, -1, -1}, {27203, -1, -1, -1}, {27205, -1, -1, -1}, {27206, -1, -1, -1}, {27209, -1, -1, -1}, {27210, -1, -1, -1}, {27212, -1, -1, -1}, {27213, -1, -1, -1}, {27214, -1, -1, -1}, {27215, -1, -1, -1}, {27217, -1, -1, -1}, {27218, -1, -1, -1}, {27219, -1, -1, -1}, {27220, -1, -1, -1}, {27221, -1, -1, -1}, {27222, -1, -1, -1}, {27223, -1, -1, -1}, {27226, -1, -1, -1}, {27228, -1, -1, -1}, {27229, -1, -1, -1}, {27230, -1, -1, -1}, {27232, -1, -1, -1}, {27235, -1, -1, -1}, {27236, -1, -1, -1}, {27238, -1, -1, -1}, {27239, -1, -1, -1}, {27240, -1, -1, -1}, {27241, -1, -1, -1}, {27242, -1, -1, -1}, {27243, -1, -1, -1}, {27244, -1, -1, -1}, {27245, -1, -1, -1}, {27246, -1, -1, -1}, {27247, -1, -1, -1}, {27248, -1, -1, -1}, {27250, -1, -1, -1}, {27251, -1, -1, -1}, {27252, -1, -1, -1}, {27253, -1, -1, -1}, {27254, -1, -1, -1}, {27255, -1, -1, -1}, {27256, -1, -1, -1}, {27258, -1, -1, -1}, {27259, -1, -1, -1}, {27261, -1, -1, -1}, {27262, -1, -1, -1}, {27263, -1, -1, -1}, {27265, -1, -1, -1}, {27266, -1, -1, -1}, {27267, -1, -1, -1}, {27269, -1, -1, -1}, {27270, -1, -1, -1}, {27271, -1, -1, -1}, {27272, -1, -1, -1}, {27274, -1, -1, -1}, {27275, -1, -1, -1}, {27276, -1, -1, -1}, {27277, -1, -1, -1}, {27279, -1, -1, -1}, {27282, -1, -1, -1}, {27283, -1, -1, -1}, {27285, -1, -1, -1}, {27286, -1, -1, -1}, {27288, -1, -1, -1}, {27289, -1, -1, -1}, {27290, -1, -1, -1}, {27291, -1, -1, -1}, {27293, -1, -1, -1}, {27294, -1, -1, -1}, {27295, -1, -1, -1}, {27297, -1, -1, -1}, {27300, -1, -1, -1}, {27301, -1, -1, -1}, {27302, -1, -1, -1}, {27303, -1, -1, -1}, {27304, -1, -1, -1}, {27306, -1, -1, -1}, {27309, -1, -1, -1}, {27310, -1, -1, -1}, {27312, -1, -1, -1}, {27313, -1, -1, -1}, {27314, -1, -1, -1}, {27316, -1, -1, -1}, {27317, -1, -1, -1}, {27318, -1, -1, -1}, {27319, -1, -1, -1}, {27321, -1, -1, -1}, {27322, -1, -1, -1}, {27324, -1, -1, -1}, {27325, -1, -1, -1}, {27326, -1, -1, -1}, {27327, -1, -1, -1}, {27328, -1, -1, -1}, {27329, -1, -1, -1}, {27330, -1, -1, -1}, {27332, -1, -1, -1}, {27333, -1, -1, -1}, {27334, -1, -1, -1}, {27335, -1, -1, -1}, {27336, -1, -1, -1}, {27337, -1, -1, -1}, {27338, -1, -1, -1}, {27339, -1, -1, -1}, {27340, -1, -1, -1}, {27341, -1, -1, -1}, {27342, -1, -1, -1}, {27343, -1, -1, -1}, {27344, -1, -1, -1}, {27345, -1, -1, -1}, {27346, -1, -1, -1}, {27348, -1, -1, -1}, {27349, -1, -1, -1}, {27350, -1, -1, -1}, {27351, -1, -1, -1}, {27352, -1, -1, -1}, {27353, -1, -1, -1}, {27356, -1, -1, -1}, {27360, -1, -1, -1}, {27361, -1, -1, -1}, {27362, -1, -1, -1}, {27363, -1, -1, -1}, {27364, -1, -1, -1}, {27365, -1, -1, -1}, {27366, -1, -1, -1}, {27369, -1, -1, -1}, {27371, -1, -1, -1}, {27373, -1, -1, -1}, {27374, -1, -1, -1}, {27375, -1, -1, -1}, {27376, -1, -1, -1}, {27377, -1, -1, -1}, {27378, -1, -1, -1}, {27380, -1, -1, -1}, {27381, -1, -1, -1}, {27382, -1, -1, -1}, {27383, -1, -1, -1}, {27385, -1, -1, -1}, {27386, -1, -1, -1}, {27388, -1, -1, -1}, {27389, -1, -1, -1}, {27390, -1, -1, -1}, {27391, -1, -1, -1}, {27392, -1, -1, -1}, {27393, -1, -1, -1}, {27394, -1, -1, -1}, {27395, -1, -1, -1}, {27397, -1, -1, -1}, {27398, -1, -1, -1}, {27399, -1, -1, -1}, {27400, -1, -1, -1}, {27401, -1, -1, -1}, {27403, -1, -1, -1}, {27404, -1, -1, -1}, {27405, -1, -1, -1}, {27406, -1, -1, -1}, {27408, -1, -1, -1}, {27409, -1, -1, -1}, {27411, -1, -1, -1}, {27412, -1, -1, -1}, {27413, -1, -1, -1}, {27415, -1, -1, -1}, {27416, -1, -1, -1}, {27417, -1, -1, -1}, {27418, -1, -1, -1}, {27419, -1, -1, -1}, {27420, -1, -1, -1}, {27421, -1, -1, -1}, {27423, -1, -1, -1}, {27429, -1, -1, -1}, {27430, -1, -1, -1}, {27432, -1, -1, -1}, {27433, -1, -1, -1}, {27434, -1, -1, -1}, {27435, -1, -1, -1}, {27436, -1, -1, -1}, {27437, -1, -1, -1}, {27438, -1, -1, -1}, {27439, -1, -1, -1}, {27440, -1, -1, -1}, {27441, -1, -1, -1}, {27443, -1, -1, -1}, {27444, -1, -1, -1}, {27445, -1, -1, -1}, {27446, -1, -1, -1}, {27448, -1, -1, -1}, {27451, -1, -1, -1} },
+ {{27452, -1, -1, -1}, {27455, -1, -1, -1}, {27456, -1, -1, -1}, {27457, -1, -1, -1}, {27458, -1, -1, -1}, {27460, -1, -1, -1}, {27461, -1, -1, -1}, {27464, -1, -1, -1}, {27466, -1, -1, -1}, {27467, -1, -1, -1}, {27469, -1, -1, -1}, {27470, -1, -1, -1}, {27471, -1, -1, -1}, {27473, -1, -1, -1}, {27474, -1, -1, -1}, {27475, -1, -1, -1}, {27476, -1, -1, -1}, {27477, -1, -1, -1}, {27478, -1, -1, -1}, {27479, -1, -1, -1}, {27480, -1, -1, -1}, {27482, -1, -1, -1}, {27483, -1, -1, -1}, {27484, -1, -1, -1}, {27485, -1, -1, -1}, {27486, -1, -1, -1}, {27488, -1, -1, -1}, {27496, -1, -1, -1}, {27497, -1, -1, -1}, {27499, -1, -1, -1}, {27500, -1, -1, -1}, {27501, -1, -1, -1}, {27502, -1, -1, -1}, {27503, -1, -1, -1}, {27504, -1, -1, -1}, {27505, -1, -1, -1}, {27507, -1, -1, -1}, {27508, -1, -1, -1}, {27509, -1, -1, -1}, {27510, -1, -1, -1}, {27514, -1, -1, -1}, {27517, -1, -1, -1}, {27518, -1, -1, -1}, {27519, -1, -1, -1}, {27520, -1, -1, -1}, {27525, -1, -1, -1}, {27528, -1, -1, -1}, {27532, -1, -1, -1}, {27534, -1, -1, -1}, {27535, -1, -1, -1}, {27536, -1, -1, -1}, {27537, -1, -1, -1}, {27540, -1, -1, -1}, {27541, -1, -1, -1}, {27543, -1, -1, -1}, {27545, -1, -1, -1}, {27548, -1, -1, -1}, {27549, -1, -1, -1}, {27551, -1, -1, -1}, {27552, -1, -1, -1}, {27554, -1, -1, -1}, {27555, -1, -1, -1}, {27557, -1, -1, -1}, {27558, -1, -1, -1}, {27559, -1, -1, -1}, {27560, -1, -1, -1}, {27561, -1, -1, -1}, {27564, -1, -1, -1}, {27565, -1, -1, -1}, {27568, -1, -1, -1}, {27569, -1, -1, -1}, {27574, -1, -1, -1}, {27576, -1, -1, -1}, {27577, -1, -1, -1}, {27580, -1, -1, -1}, {27581, -1, -1, -1}, {27582, -1, -1, -1}, {27584, -1, -1, -1}, {27587, -1, -1, -1}, {27588, -1, -1, -1}, {27591, -1, -1, -1}, {27592, -1, -1, -1}, {27593, -1, -1, -1}, {27594, -1, -1, -1}, {27596, -1, -1, -1}, {27598, -1, -1, -1}, {27600, -1, -1, -1}, {27601, -1, -1, -1}, {27608, -1, -1, -1}, {27610, -1, -1, -1}, {27612, -1, -1, -1}, {27613, -1, -1, -1}, {27614, -1, -1, -1}, {27615, -1, -1, -1}, {27616, -1, -1, -1}, {27618, -1, -1, -1}, {27619, -1, -1, -1}, {27620, -1, -1, -1}, {27621, -1, -1, -1}, {27622, -1, -1, -1}, {27623, -1, -1, -1}, {27624, -1, -1, -1}, {27625, -1, -1, -1}, {27628, -1, -1, -1}, {27629, -1, -1, -1}, {27630, -1, -1, -1}, {27632, -1, -1, -1}, {27633, -1, -1, -1}, {27634, -1, -1, -1}, {27636, -1, -1, -1}, {27638, -1, -1, -1}, {27639, -1, -1, -1}, {27640, -1, -1, -1}, {27642, -1, -1, -1}, {27643, -1, -1, -1}, {27644, -1, -1, -1}, {27646, -1, -1, -1}, {27648, -1, -1, -1}, {27649, -1, -1, -1}, {27650, -1, -1, -1}, {27651, -1, -1, -1}, {27652, -1, -1, -1}, {27657, -1, -1, -1}, {27658, -1, -1, -1}, {27659, -1, -1, -1}, {27662, -1, -1, -1}, {27666, -1, -1, -1}, {27671, -1, -1, -1}, {27676, -1, -1, -1}, {27677, -1, -1, -1}, {27678, -1, -1, -1}, {27680, -1, -1, -1}, {27685, -1, -1, -1}, {27693, -1, -1, -1}, {27697, -1, -1, -1}, {27699, -1, -1, -1}, {27702, -1, -1, -1}, {27703, -1, -1, -1}, {27705, -1, -1, -1}, {27706, -1, -1, -1}, {27707, -1, -1, -1}, {27708, -1, -1, -1}, {27710, -1, -1, -1}, {27711, -1, -1, -1}, {27715, -1, -1, -1}, {27716, -1, -1, -1}, {27717, -1, -1, -1}, {27720, -1, -1, -1}, {27723, -1, -1, -1}, {27724, -1, -1, -1}, {27725, -1, -1, -1}, {27726, -1, -1, -1}, {27727, -1, -1, -1}, {27729, -1, -1, -1}, {27730, -1, -1, -1}, {27731, -1, -1, -1}, {27734, -1, -1, -1}, {27736, -1, -1, -1}, {27737, -1, -1, -1}, {27738, -1, -1, -1}, {27746, -1, -1, -1}, {27747, -1, -1, -1}, {27749, -1, -1, -1}, {27750, -1, -1, -1}, {27751, -1, -1, -1}, {27755, -1, -1, -1}, {27756, -1, -1, -1}, {27757, -1, -1, -1}, {27758, -1, -1, -1}, {27759, -1, -1, -1}, {27761, -1, -1, -1}, {27763, -1, -1, -1}, {27765, -1, -1, -1}, {27767, -1, -1, -1}, {27768, -1, -1, -1}, {27770, -1, -1, -1}, {27771, -1, -1, -1}, {27772, -1, -1, -1}, {27775, -1, -1, -1}, {27776, -1, -1, -1}, {27780, -1, -1, -1}, {27783, -1, -1, -1}, {27786, -1, -1, -1}, {27787, -1, -1, -1}, {27789, -1, -1, -1}, {27790, -1, -1, -1}, {27793, -1, -1, -1}, {27794, -1, -1, -1}, {27797, -1, -1, -1}, {27798, -1, -1, -1}, {27799, -1, -1, -1}, {27800, -1, -1, -1}, {27802, -1, -1, -1}, {27804, -1, -1, -1}, {27805, -1, -1, -1}, {27806, -1, -1, -1}, {27808, -1, -1, -1}, {27810, -1, -1, -1}, {27816, -1, -1, -1}, {27820, -1, -1, -1}, {27823, -1, -1, -1}, {27824, -1, -1, -1}, {27828, -1, -1, -1}, {27829, -1, -1, -1}, {27830, -1, -1, -1}, {27831, -1, -1, -1}, {27834, -1, -1, -1}, {27840, -1, -1, -1}, {27841, -1, -1, -1}, {27842, -1, -1, -1}, {27843, -1, -1, -1}, {27846, -1, -1, -1}, {27847, -1, -1, -1}, {27848, -1, -1, -1}, {27851, -1, -1, -1}, {27853, -1, -1, -1}, {27854, -1, -1, -1}, {27855, -1, -1, -1}, {27857, -1, -1, -1}, {27858, -1, -1, -1}, {27864, -1, -1, -1}, {27865, -1, -1, -1}, {27866, -1, -1, -1}, {27868, -1, -1, -1}, {27869, -1, -1, -1}, {27871, -1, -1, -1}, {27876, -1, -1, -1}, {27878, -1, -1, -1}, {27879, -1, -1, -1}, {27881, -1, -1, -1}, {27884, -1, -1, -1}, {27885, -1, -1, -1}, {27890, -1, -1, -1}, {27892, -1, -1, -1}, {27897, -1, -1, -1}, {27903, -1, -1, -1}, {27904, -1, -1, -1}, {27906, -1, -1, -1}, {27907, -1, -1, -1}, {27909, -1, -1, -1}, {27910, -1, -1, -1}, {27912, -1, -1, -1}, {27913, -1, -1, -1}, {27914, -1, -1, -1}, {27917, -1, -1, -1}, {27919, -1, -1, -1}, {27920, -1, -1, -1}, {27921, -1, -1, -1}, {27923, -1, -1, -1}, {27924, -1, -1, -1}, {27925, -1, -1, -1}, {27926, -1, -1, -1}, {27928, -1, -1, -1}, {27932, -1, -1, -1}, {27933, -1, -1, -1}, {27935, -1, -1, -1} },
+ {{27936, -1, -1, -1}, {27937, -1, -1, -1}, {27938, -1, -1, -1}, {27939, -1, -1, -1}, {27940, -1, -1, -1}, {27942, -1, -1, -1}, {27944, -1, -1, -1}, {27945, -1, -1, -1}, {27948, -1, -1, -1}, {27949, -1, -1, -1}, {27951, -1, -1, -1}, {27952, -1, -1, -1}, {27956, -1, -1, -1}, {27958, -1, -1, -1}, {27959, -1, -1, -1}, {27960, -1, -1, -1}, {27962, -1, -1, -1}, {27967, -1, -1, -1}, {27968, -1, -1, -1}, {27970, -1, -1, -1}, {27972, -1, -1, -1}, {27977, -1, -1, -1}, {27980, -1, -1, -1}, {27984, -1, -1, -1}, {27989, -1, -1, -1}, {27990, -1, -1, -1}, {27991, -1, -1, -1}, {27992, -1, -1, -1}, {27995, -1, -1, -1}, {27997, -1, -1, -1}, {27999, -1, -1, -1}, {28001, -1, -1, -1}, {28002, -1, -1, -1}, {28004, -1, -1, -1}, {28005, -1, -1, -1}, {28007, -1, -1, -1}, {28008, -1, -1, -1}, {28011, -1, -1, -1}, {28012, -1, -1, -1}, {28013, -1, -1, -1}, {28016, -1, -1, -1}, {28017, -1, -1, -1}, {28018, -1, -1, -1}, {28019, -1, -1, -1}, {28021, -1, -1, -1}, {28022, -1, -1, -1}, {28026, -1, -1, -1}, {28027, -1, -1, -1}, {28029, -1, -1, -1}, {28030, -1, -1, -1}, {28031, -1, -1, -1}, {28032, -1, -1, -1}, {28033, -1, -1, -1}, {28035, -1, -1, -1}, {28036, -1, -1, -1}, {28038, -1, -1, -1}, {28042, -1, -1, -1}, {28043, -1, -1, -1}, {28045, -1, -1, -1}, {28047, -1, -1, -1}, {28048, -1, -1, -1}, {28050, -1, -1, -1}, {28054, -1, -1, -1}, {28055, -1, -1, -1}, {28056, -1, -1, -1}, {28057, -1, -1, -1}, {28058, -1, -1, -1}, {28060, -1, -1, -1}, {28066, -1, -1, -1}, {28069, -1, -1, -1}, {28076, -1, -1, -1}, {28077, -1, -1, -1}, {28080, -1, -1, -1}, {28081, -1, -1, -1}, {28083, -1, -1, -1}, {28084, -1, -1, -1}, {28086, -1, -1, -1}, {28087, -1, -1, -1}, {28089, -1, -1, -1}, {28090, -1, -1, -1}, {28091, -1, -1, -1}, {28092, -1, -1, -1}, {28093, -1, -1, -1}, {28094, -1, -1, -1}, {28097, -1, -1, -1}, {28098, -1, -1, -1}, {28099, -1, -1, -1}, {28104, -1, -1, -1}, {28105, -1, -1, -1}, {28106, -1, -1, -1}, {28109, -1, -1, -1}, {28110, -1, -1, -1}, {28111, -1, -1, -1}, {28112, -1, -1, -1}, {28114, -1, -1, -1}, {28115, -1, -1, -1}, {28116, -1, -1, -1}, {28117, -1, -1, -1}, {28119, -1, -1, -1}, {28122, -1, -1, -1}, {28123, -1, -1, -1}, {28124, -1, -1, -1}, {28127, -1, -1, -1}, {28130, -1, -1, -1}, {28131, -1, -1, -1}, {28133, -1, -1, -1}, {28135, -1, -1, -1}, {28136, -1, -1, -1}, {28137, -1, -1, -1}, {28141, -1, -1, -1}, {28143, -1, -1, -1}, {28144, -1, -1, -1}, {28146, -1, -1, -1}, {28148, -1, -1, -1}, {28152, -1, -1, -1}, {28157, -1, -1, -1}, {28158, -1, -1, -1}, {28159, -1, -1, -1}, {28160, -1, -1, -1}, {28161, -1, -1, -1}, {28162, -1, -1, -1}, {28163, -1, -1, -1}, {28164, -1, -1, -1}, {28166, -1, -1, -1}, {28167, -1, -1, -1}, {28168, -1, -1, -1}, {28169, -1, -1, -1}, {28171, -1, -1, -1}, {28175, -1, -1, -1}, {28178, -1, -1, -1}, {28179, -1, -1, -1}, {28181, -1, -1, -1}, {28184, -1, -1, -1}, {28185, -1, -1, -1}, {28187, -1, -1, -1}, {28188, -1, -1, -1}, {28190, -1, -1, -1}, {28191, -1, -1, -1}, {28194, -1, -1, -1}, {28199, -1, -1, -1}, {28200, -1, -1, -1}, {28202, -1, -1, -1}, {28206, -1, -1, -1}, {28208, -1, -1, -1}, {28209, -1, -1, -1}, {28211, -1, -1, -1}, {28213, -1, -1, -1}, {28214, -1, -1, -1}, {28215, -1, -1, -1}, {28217, -1, -1, -1}, {28219, -1, -1, -1}, {28220, -1, -1, -1}, {28221, -1, -1, -1}, {28223, -1, -1, -1}, {28224, -1, -1, -1}, {28225, -1, -1, -1}, {28226, -1, -1, -1}, {28229, -1, -1, -1}, {28230, -1, -1, -1}, {28231, -1, -1, -1}, {28232, -1, -1, -1}, {28233, -1, -1, -1}, {28234, -1, -1, -1}, {28235, -1, -1, -1}, {28236, -1, -1, -1}, {28239, -1, -1, -1}, {28240, -1, -1, -1}, {28241, -1, -1, -1}, {28242, -1, -1, -1}, {28245, -1, -1, -1}, {28247, -1, -1, -1}, {28249, -1, -1, -1}, {28250, -1, -1, -1}, {28252, -1, -1, -1}, {28253, -1, -1, -1}, {28256, -1, -1, -1}, {28257, -1, -1, -1}, {28258, -1, -1, -1}, {28259, -1, -1, -1}, {28260, -1, -1, -1}, {28261, -1, -1, -1}, {28262, -1, -1, -1}, {28263, -1, -1, -1}, {28264, -1, -1, -1}, {28265, -1, -1, -1}, {28266, -1, -1, -1}, {28268, -1, -1, -1}, {28269, -1, -1, -1}, {28272, -1, -1, -1}, {28273, -1, -1, -1}, {28274, -1, -1, -1}, {28275, -1, -1, -1}, {28276, -1, -1, -1}, {28277, -1, -1, -1}, {28278, -1, -1, -1}, {28279, -1, -1, -1}, {28280, -1, -1, -1}, {28281, -1, -1, -1}, {28282, -1, -1, -1}, {28283, -1, -1, -1}, {28284, -1, -1, -1}, {28285, -1, -1, -1}, {28288, -1, -1, -1}, {28289, -1, -1, -1}, {28290, -1, -1, -1}, {28292, -1, -1, -1}, {28295, -1, -1, -1}, {28296, -1, -1, -1}, {28298, -1, -1, -1}, {28299, -1, -1, -1}, {28300, -1, -1, -1}, {28301, -1, -1, -1}, {28302, -1, -1, -1}, {28305, -1, -1, -1}, {28306, -1, -1, -1}, {28307, -1, -1, -1}, {28308, -1, -1, -1}, {28309, -1, -1, -1}, {28311, -1, -1, -1}, {28313, -1, -1, -1}, {28314, -1, -1, -1}, {28315, -1, -1, -1}, {28318, -1, -1, -1}, {28320, -1, -1, -1}, {28321, -1, -1, -1}, {28323, -1, -1, -1}, {28324, -1, -1, -1}, {28326, -1, -1, -1}, {28328, -1, -1, -1}, {28329, -1, -1, -1}, {28331, -1, -1, -1}, {28332, -1, -1, -1}, {28333, -1, -1, -1}, {28334, -1, -1, -1}, {28336, -1, -1, -1}, {28339, -1, -1, -1}, {28341, -1, -1, -1}, {28344, -1, -1, -1}, {28345, -1, -1, -1}, {28348, -1, -1, -1}, {28350, -1, -1, -1}, {28351, -1, -1, -1}, {28352, -1, -1, -1}, {28355, -1, -1, -1}, {28358, -1, -1, -1}, {28360, -1, -1, -1}, {28361, -1, -1, -1}, {28362, -1, -1, -1}, {28365, -1, -1, -1}, {28368, -1, -1, -1}, {28370, -1, -1, -1}, {28374, -1, -1, -1}, {28376, -1, -1, -1}, {28377, -1, -1, -1}, {28379, -1, -1, -1}, {28380, -1, -1, -1} },
+ {{28381, -1, -1, -1}, {28387, -1, -1, -1}, {28391, -1, -1, -1}, {28394, -1, -1, -1}, {28395, -1, -1, -1}, {28397, -1, -1, -1}, {28398, -1, -1, -1}, {28400, -1, -1, -1}, {28401, -1, -1, -1}, {28403, -1, -1, -1}, {28405, -1, -1, -1}, {28406, -1, -1, -1}, {28410, -1, -1, -1}, {28411, -1, -1, -1}, {28412, -1, -1, -1}, {28413, -1, -1, -1}, {28414, -1, -1, -1}, {28416, -1, -1, -1}, {28419, -1, -1, -1}, {28420, -1, -1, -1}, {28421, -1, -1, -1}, {28423, -1, -1, -1}, {28424, -1, -1, -1}, {28426, -1, -1, -1}, {28427, -1, -1, -1}, {28428, -1, -1, -1}, {28429, -1, -1, -1}, {28430, -1, -1, -1}, {28432, -1, -1, -1}, {28433, -1, -1, -1}, {28434, -1, -1, -1}, {28438, -1, -1, -1}, {28439, -1, -1, -1}, {28440, -1, -1, -1}, {28441, -1, -1, -1}, {28443, -1, -1, -1}, {28444, -1, -1, -1}, {28445, -1, -1, -1}, {28446, -1, -1, -1}, {28447, -1, -1, -1}, {28449, -1, -1, -1}, {28453, -1, -1, -1}, {28454, -1, -1, -1}, {28455, -1, -1, -1}, {28456, -1, -1, -1}, {28462, -1, -1, -1}, {28464, -1, -1, -1}, {28468, -1, -1, -1}, {28469, -1, -1, -1}, {28471, -1, -1, -1}, {28473, -1, -1, -1}, {28474, -1, -1, -1}, {28475, -1, -1, -1}, {28476, -1, -1, -1}, {28477, -1, -1, -1}, {28480, -1, -1, -1}, {28482, -1, -1, -1}, {28483, -1, -1, -1}, {28484, -1, -1, -1}, {28485, -1, -1, -1}, {28488, -1, -1, -1}, {28489, -1, -1, -1}, {28490, -1, -1, -1}, {28492, -1, -1, -1}, {28494, -1, -1, -1}, {28495, -1, -1, -1}, {28496, -1, -1, -1}, {28498, -1, -1, -1}, {28499, -1, -1, -1}, {28501, -1, -1, -1}, {28502, -1, -1, -1}, {28503, -1, -1, -1}, {28506, -1, -1, -1}, {28507, -1, -1, -1}, {28509, -1, -1, -1}, {28511, -1, -1, -1}, {28512, -1, -1, -1}, {28513, -1, -1, -1}, {28515, -1, -1, -1}, {28517, -1, -1, -1}, {28519, -1, -1, -1}, {28520, -1, -1, -1}, {28521, -1, -1, -1}, {28522, -1, -1, -1}, {28523, -1, -1, -1}, {28524, -1, -1, -1}, {28529, -1, -1, -1}, {28531, -1, -1, -1}, {28533, -1, -1, -1}, {28534, -1, -1, -1}, {28537, -1, -1, -1}, {28539, -1, -1, -1}, {28541, -1, -1, -1}, {28542, -1, -1, -1}, {28545, -1, -1, -1}, {28546, -1, -1, -1}, {28547, -1, -1, -1}, {28549, -1, -1, -1}, {28554, -1, -1, -1}, {28555, -1, -1, -1}, {28559, -1, -1, -1}, {28560, -1, -1, -1}, {28561, -1, -1, -1}, {28562, -1, -1, -1}, {28563, -1, -1, -1}, {28564, -1, -1, -1}, {28565, -1, -1, -1}, {28566, -1, -1, -1}, {28568, -1, -1, -1}, {28569, -1, -1, -1}, {28570, -1, -1, -1}, {28571, -1, -1, -1}, {28573, -1, -1, -1}, {28574, -1, -1, -1}, {28575, -1, -1, -1}, {28578, -1, -1, -1}, {28579, -1, -1, -1}, {28581, -1, -1, -1}, {28582, -1, -1, -1}, {28584, -1, -1, -1}, {28586, -1, -1, -1}, {28587, -1, -1, -1}, {28588, -1, -1, -1}, {28589, -1, -1, -1}, {28591, -1, -1, -1}, {28592, -1, -1, -1}, {28594, -1, -1, -1}, {28596, -1, -1, -1}, {28597, -1, -1, -1}, {28599, -1, -1, -1}, {28600, -1, -1, -1}, {28602, -1, -1, -1}, {28603, -1, -1, -1}, {28604, -1, -1, -1}, {28605, -1, -1, -1}, {28606, -1, -1, -1}, {28607, -1, -1, -1}, {28612, -1, -1, -1}, {28613, -1, -1, -1}, {28614, -1, -1, -1}, {28615, -1, -1, -1}, {28616, -1, -1, -1}, {28618, -1, -1, -1}, {28619, -1, -1, -1}, {28620, -1, -1, -1}, {28621, -1, -1, -1}, {28622, -1, -1, -1}, {28623, -1, -1, -1}, {28624, -1, -1, -1}, {28627, -1, -1, -1}, {28628, -1, -1, -1}, {28630, -1, -1, -1}, {28631, -1, -1, -1}, {28633, -1, -1, -1}, {28634, -1, -1, -1}, {28636, -1, -1, -1}, {28637, -1, -1, -1}, {28642, -1, -1, -1}, {28643, -1, -1, -1}, {28645, -1, -1, -1}, {28646, -1, -1, -1}, {28647, -1, -1, -1}, {28648, -1, -1, -1}, {28649, -1, -1, -1}, {28650, -1, -1, -1}, {28652, -1, -1, -1}, {28653, -1, -1, -1}, {28658, -1, -1, -1}, {28659, -1, -1, -1}, {28660, -1, -1, -1}, {28661, -1, -1, -1}, {28662, -1, -1, -1}, {28663, -1, -1, -1}, {28664, -1, -1, -1}, {28665, -1, -1, -1}, {28667, -1, -1, -1}, {28669, -1, -1, -1}, {28671, -1, -1, -1}, {28672, -1, -1, -1}, {28673, -1, -1, -1}, {28674, -1, -1, -1}, {28675, -1, -1, -1}, {28676, -1, -1, -1}, {28679, -1, -1, -1}, {28680, -1, -1, -1}, {28682, -1, -1, -1}, {28684, -1, -1, -1}, {28685, -1, -1, -1}, {28686, -1, -1, -1}, {28688, -1, -1, -1}, {28690, -1, -1, -1}, {28691, -1, -1, -1}, {28692, -1, -1, -1}, {28694, -1, -1, -1}, {28695, -1, -1, -1}, {28697, -1, -1, -1}, {28700, -1, -1, -1}, {28702, -1, -1, -1}, {28705, -1, -1, -1}, {28706, -1, -1, -1}, {28708, -1, -1, -1}, {28709, -1, -1, -1}, {28710, -1, -1, -1}, {28713, -1, -1, -1}, {28714, -1, -1, -1}, {28715, -1, -1, -1}, {28716, -1, -1, -1}, {28717, -1, -1, -1}, {28718, -1, -1, -1}, {28719, -1, -1, -1}, {28721, -1, -1, -1}, {28723, -1, -1, -1}, {28724, -1, -1, -1}, {28726, -1, -1, -1}, {28727, -1, -1, -1}, {28728, -1, -1, -1}, {28730, -1, -1, -1}, {28731, -1, -1, -1}, {28732, -1, -1, -1}, {28733, -1, -1, -1}, {28735, -1, -1, -1}, {28736, -1, -1, -1}, {28737, -1, -1, -1}, {28738, -1, -1, -1}, {28741, -1, -1, -1}, {28742, -1, -1, -1}, {28743, -1, -1, -1}, {28744, -1, -1, -1}, {28745, -1, -1, -1}, {28746, -1, -1, -1}, {28747, -1, -1, -1}, {28749, -1, -1, -1}, {28750, -1, -1, -1}, {28752, -1, -1, -1}, {28754, -1, -1, -1}, {28755, -1, -1, -1}, {28756, -1, -1, -1}, {28758, -1, -1, -1}, {28759, -1, -1, -1}, {28761, -1, -1, -1}, {28762, -1, -1, -1}, {28763, -1, -1, -1}, {28764, -1, -1, -1}, {28767, -1, -1, -1}, {28768, -1, -1, -1}, {28769, -1, -1, -1}, {28770, -1, -1, -1}, {28773, -1, -1, -1}, {28774, -1, -1, -1}, {28776, -1, -1, -1}, {28777, -1, -1, -1}, {28778, -1, -1, -1}, {28782, -1, -1, -1}, {28785, -1, -1, -1}, {28786, -1, -1, -1}, {28787, -1, -1, -1} },
+ {{28788, -1, -1, -1}, {28791, -1, -1, -1}, {28793, -1, -1, -1}, {28794, -1, -1, -1}, {28795, -1, -1, -1}, {28797, -1, -1, -1}, {28801, -1, -1, -1}, {28802, -1, -1, -1}, {28803, -1, -1, -1}, {28804, -1, -1, -1}, {28806, -1, -1, -1}, {28807, -1, -1, -1}, {28808, -1, -1, -1}, {28811, -1, -1, -1}, {28812, -1, -1, -1}, {28813, -1, -1, -1}, {28815, -1, -1, -1}, {28816, -1, -1, -1}, {28817, -1, -1, -1}, {28819, -1, -1, -1}, {28823, -1, -1, -1}, {28824, -1, -1, -1}, {28826, -1, -1, -1}, {28827, -1, -1, -1}, {28830, -1, -1, -1}, {28831, -1, -1, -1}, {28832, -1, -1, -1}, {28833, -1, -1, -1}, {28834, -1, -1, -1}, {28835, -1, -1, -1}, {28836, -1, -1, -1}, {28837, -1, -1, -1}, {28838, -1, -1, -1}, {28839, -1, -1, -1}, {28840, -1, -1, -1}, {28841, -1, -1, -1}, {28842, -1, -1, -1}, {28848, -1, -1, -1}, {28850, -1, -1, -1}, {28852, -1, -1, -1}, {28853, -1, -1, -1}, {28854, -1, -1, -1}, {28858, -1, -1, -1}, {28862, -1, -1, -1}, {28863, -1, -1, -1}, {28868, -1, -1, -1}, {28869, -1, -1, -1}, {28870, -1, -1, -1}, {28871, -1, -1, -1}, {28873, -1, -1, -1}, {28875, -1, -1, -1}, {28876, -1, -1, -1}, {28877, -1, -1, -1}, {28878, -1, -1, -1}, {28880, -1, -1, -1}, {28881, -1, -1, -1}, {28882, -1, -1, -1}, {28883, -1, -1, -1}, {28884, -1, -1, -1}, {28885, -1, -1, -1}, {28886, -1, -1, -1}, {28887, -1, -1, -1}, {28890, -1, -1, -1}, {28892, -1, -1, -1}, {28893, -1, -1, -1}, {28894, -1, -1, -1}, {28896, -1, -1, -1}, {28897, -1, -1, -1}, {28898, -1, -1, -1}, {28899, -1, -1, -1}, {28901, -1, -1, -1}, {28906, -1, -1, -1}, {28910, -1, -1, -1}, {28912, -1, -1, -1}, {28913, -1, -1, -1}, {28914, -1, -1, -1}, {28915, -1, -1, -1}, {28917, -1, -1, -1}, {28918, -1, -1, -1}, {28920, -1, -1, -1}, {28922, -1, -1, -1}, {28923, -1, -1, -1}, {28924, -1, -1, -1}, {28926, -1, -1, -1}, {28927, -1, -1, -1}, {28928, -1, -1, -1}, {28929, -1, -1, -1}, {28930, -1, -1, -1}, {28931, -1, -1, -1}, {28932, -1, -1, -1}, {28933, -1, -1, -1}, {28934, -1, -1, -1}, {28935, -1, -1, -1}, {28936, -1, -1, -1}, {28939, -1, -1, -1}, {28940, -1, -1, -1}, {28941, -1, -1, -1}, {28942, -1, -1, -1}, {28943, -1, -1, -1}, {28945, -1, -1, -1}, {28946, -1, -1, -1}, {28948, -1, -1, -1}, {28951, -1, -1, -1}, {28955, -1, -1, -1}, {28956, -1, -1, -1}, {28957, -1, -1, -1}, {28958, -1, -1, -1}, {28959, -1, -1, -1}, {28960, -1, -1, -1}, {28962, -1, -1, -1}, {28963, -1, -1, -1}, {28964, -1, -1, -1}, {28965, -1, -1, -1}, {28967, -1, -1, -1}, {28968, -1, -1, -1}, {28969, -1, -1, -1}, {28970, -1, -1, -1}, {28971, -1, -1, -1}, {28972, -1, -1, -1}, {28973, -1, -1, -1}, {28974, -1, -1, -1}, {28978, -1, -1, -1}, {28979, -1, -1, -1}, {28980, -1, -1, -1}, {28981, -1, -1, -1}, {28983, -1, -1, -1}, {28984, -1, -1, -1}, {28985, -1, -1, -1}, {28986, -1, -1, -1}, {28987, -1, -1, -1}, {28988, -1, -1, -1}, {28989, -1, -1, -1}, {28990, -1, -1, -1}, {28991, -1, -1, -1}, {28992, -1, -1, -1}, {28993, -1, -1, -1}, {28994, -1, -1, -1}, {28995, -1, -1, -1}, {28996, -1, -1, -1}, {28998, -1, -1, -1}, {28999, -1, -1, -1}, {29000, -1, -1, -1}, {29003, -1, -1, -1}, {29005, -1, -1, -1}, {29007, -1, -1, -1}, {29008, -1, -1, -1}, {29009, -1, -1, -1}, {29011, -1, -1, -1}, {29012, -1, -1, -1}, {29013, -1, -1, -1}, {29014, -1, -1, -1}, {29015, -1, -1, -1}, {29016, -1, -1, -1}, {29017, -1, -1, -1}, {29018, -1, -1, -1}, {29019, -1, -1, -1}, {29021, -1, -1, -1}, {29023, -1, -1, -1}, {29024, -1, -1, -1}, {29025, -1, -1, -1}, {29027, -1, -1, -1}, {29029, -1, -1, -1}, {29034, -1, -1, -1}, {29035, -1, -1, -1}, {29037, -1, -1, -1}, {29039, -1, -1, -1}, {29040, -1, -1, -1}, {29041, -1, -1, -1}, {29044, -1, -1, -1}, {29045, -1, -1, -1}, {29046, -1, -1, -1}, {29047, -1, -1, -1}, {29049, -1, -1, -1}, {29051, -1, -1, -1}, {29052, -1, -1, -1}, {29054, -1, -1, -1}, {29055, -1, -1, -1}, {29056, -1, -1, -1}, {29057, -1, -1, -1}, {29058, -1, -1, -1}, {29059, -1, -1, -1}, {29061, -1, -1, -1}, {29062, -1, -1, -1}, {29063, -1, -1, -1}, {29064, -1, -1, -1}, {29065, -1, -1, -1}, {29067, -1, -1, -1}, {29068, -1, -1, -1}, {29069, -1, -1, -1}, {29070, -1, -1, -1}, {29072, -1, -1, -1}, {29073, -1, -1, -1}, {29075, -1, -1, -1}, {29077, -1, -1, -1}, {29078, -1, -1, -1}, {29082, -1, -1, -1}, {29083, -1, -1, -1}, {29084, -1, -1, -1}, {29085, -1, -1, -1}, {29086, -1, -1, -1}, {29089, -1, -1, -1}, {29090, -1, -1, -1}, {29091, -1, -1, -1}, {29092, -1, -1, -1}, {29093, -1, -1, -1}, {29094, -1, -1, -1}, {29095, -1, -1, -1}, {29097, -1, -1, -1}, {29098, -1, -1, -1}, {29099, -1, -1, -1}, {29101, -1, -1, -1}, {29102, -1, -1, -1}, {29103, -1, -1, -1}, {29104, -1, -1, -1}, {29106, -1, -1, -1}, {29108, -1, -1, -1}, {29110, -1, -1, -1}, {29111, -1, -1, -1}, {29112, -1, -1, -1}, {29114, -1, -1, -1}, {29115, -1, -1, -1}, {29116, -1, -1, -1}, {29117, -1, -1, -1}, {29119, -1, -1, -1}, {29120, -1, -1, -1}, {29122, -1, -1, -1}, {29124, -1, -1, -1}, {29125, -1, -1, -1}, {29126, -1, -1, -1}, {29127, -1, -1, -1}, {29129, -1, -1, -1}, {29130, -1, -1, -1}, {29131, -1, -1, -1}, {29132, -1, -1, -1}, {29133, -1, -1, -1}, {29135, -1, -1, -1}, {29136, -1, -1, -1}, {29137, -1, -1, -1}, {29139, -1, -1, -1}, {29142, -1, -1, -1}, {29143, -1, -1, -1}, {29144, -1, -1, -1}, {29146, -1, -1, -1}, {29147, -1, -1, -1}, {29149, -1, -1, -1}, {29150, -1, -1, -1}, {29153, -1, -1, -1}, {29154, -1, -1, -1}, {29155, -1, -1, -1}, {29156, -1, -1, -1}, {29160, -1, -1, -1}, {29161, -1, -1, -1}, {29162, -1, -1, -1}, {29163, -1, -1, -1}, {29164, -1, -1, -1}, {29167, -1, -1, -1} },
+ {{29168, -1, -1, -1}, {29169, -1, -1, -1}, {29170, -1, -1, -1}, {29171, -1, -1, -1}, {29173, -1, -1, -1}, {29174, -1, -1, -1}, {29175, -1, -1, -1}, {29176, -1, -1, -1}, {29178, -1, -1, -1}, {29179, -1, -1, -1}, {29181, -1, -1, -1}, {29183, -1, -1, -1}, {29184, -1, -1, -1}, {29185, -1, -1, -1}, {29186, -1, -1, -1}, {29187, -1, -1, -1}, {29188, -1, -1, -1}, {29189, -1, -1, -1}, {29191, -1, -1, -1}, {29192, -1, -1, -1}, {29193, -1, -1, -1}, {29194, -1, -1, -1}, {29195, -1, -1, -1}, {29196, -1, -1, -1}, {29198, -1, -1, -1}, {29199, -1, -1, -1}, {29201, -1, -1, -1}, {29202, -1, -1, -1}, {29203, -1, -1, -1}, {29204, -1, -1, -1}, {29205, -1, -1, -1}, {29206, -1, -1, -1}, {29207, -1, -1, -1}, {29208, -1, -1, -1}, {29209, -1, -1, -1}, {29210, -1, -1, -1}, {29212, -1, -1, -1}, {29214, -1, -1, -1}, {29215, -1, -1, -1}, {29216, -1, -1, -1}, {29217, -1, -1, -1}, {29218, -1, -1, -1}, {29219, -1, -1, -1}, {29220, -1, -1, -1}, {29221, -1, -1, -1}, {29222, -1, -1, -1}, {29223, -1, -1, -1}, {29225, -1, -1, -1}, {29227, -1, -1, -1}, {29229, -1, -1, -1}, {29230, -1, -1, -1}, {29231, -1, -1, -1}, {29235, -1, -1, -1}, {29236, -1, -1, -1}, {29244, -1, -1, -1}, {29248, -1, -1, -1}, {29249, -1, -1, -1}, {29250, -1, -1, -1}, {29251, -1, -1, -1}, {29252, -1, -1, -1}, {29253, -1, -1, -1}, {29254, -1, -1, -1}, {29257, -1, -1, -1}, {29258, -1, -1, -1}, {29259, -1, -1, -1}, {29262, -1, -1, -1}, {29263, -1, -1, -1}, {29264, -1, -1, -1}, {29265, -1, -1, -1}, {29267, -1, -1, -1}, {29268, -1, -1, -1}, {29269, -1, -1, -1}, {29271, -1, -1, -1}, {29274, -1, -1, -1}, {29276, -1, -1, -1}, {29278, -1, -1, -1}, {29280, -1, -1, -1}, {29283, -1, -1, -1}, {29284, -1, -1, -1}, {29285, -1, -1, -1}, {29288, -1, -1, -1}, {29290, -1, -1, -1}, {29291, -1, -1, -1}, {29292, -1, -1, -1}, {29293, -1, -1, -1}, {29296, -1, -1, -1}, {29297, -1, -1, -1}, {29299, -1, -1, -1}, {29300, -1, -1, -1}, {29302, -1, -1, -1}, {29303, -1, -1, -1}, {29304, -1, -1, -1}, {29307, -1, -1, -1}, {29308, -1, -1, -1}, {29314, -1, -1, -1}, {29315, -1, -1, -1}, {29317, -1, -1, -1}, {29318, -1, -1, -1}, {29319, -1, -1, -1}, {29320, -1, -1, -1}, {29321, -1, -1, -1}, {29324, -1, -1, -1}, {29326, -1, -1, -1}, {29328, -1, -1, -1}, {29329, -1, -1, -1}, {29331, -1, -1, -1}, {29332, -1, -1, -1}, {29333, -1, -1, -1}, {29335, -1, -1, -1}, {29336, -1, -1, -1}, {29337, -1, -1, -1}, {29338, -1, -1, -1}, {29339, -1, -1, -1}, {29340, -1, -1, -1}, {29341, -1, -1, -1}, {29342, -1, -1, -1}, {29344, -1, -1, -1}, {29345, -1, -1, -1}, {29347, -1, -1, -1}, {29348, -1, -1, -1}, {29349, -1, -1, -1}, {29350, -1, -1, -1}, {29352, -1, -1, -1}, {29353, -1, -1, -1}, {29354, -1, -1, -1}, {29355, -1, -1, -1}, {29358, -1, -1, -1}, {29361, -1, -1, -1}, {29362, -1, -1, -1}, {29363, -1, -1, -1}, {29365, -1, -1, -1}, {29370, -1, -1, -1}, {29371, -1, -1, -1}, {29372, -1, -1, -1}, {29373, -1, -1, -1}, {29374, -1, -1, -1}, {29375, -1, -1, -1}, {29381, -1, -1, -1}, {29382, -1, -1, -1}, {29383, -1, -1, -1}, {29385, -1, -1, -1}, {29386, -1, -1, -1}, {29387, -1, -1, -1}, {29388, -1, -1, -1}, {29391, -1, -1, -1}, {29393, -1, -1, -1}, {29395, -1, -1, -1}, {29396, -1, -1, -1}, {29397, -1, -1, -1}, {29398, -1, -1, -1}, {29400, -1, -1, -1}, {29402, -1, -1, -1}, {29403, -1, -1, -1}, {29404, -1, -1, -1}, {29405, -1, -1, -1}, {29407, -1, -1, -1}, {29410, -1, -1, -1}, {29411, -1, -1, -1}, {29412, -1, -1, -1}, {29413, -1, -1, -1}, {29414, -1, -1, -1}, {29415, -1, -1, -1}, {29418, -1, -1, -1}, {29419, -1, -1, -1}, {29429, -1, -1, -1}, {29430, -1, -1, -1}, {29438, -1, -1, -1}, {29439, -1, -1, -1}, {29440, -1, -1, -1}, {29442, -1, -1, -1}, {29444, -1, -1, -1}, {29445, -1, -1, -1}, {29446, -1, -1, -1}, {29447, -1, -1, -1}, {29448, -1, -1, -1}, {29449, -1, -1, -1}, {29451, -1, -1, -1}, {29452, -1, -1, -1}, {29453, -1, -1, -1}, {29455, -1, -1, -1}, {29456, -1, -1, -1}, {29457, -1, -1, -1}, {29458, -1, -1, -1}, {29460, -1, -1, -1}, {29464, -1, -1, -1}, {29465, -1, -1, -1}, {29466, -1, -1, -1}, {29471, -1, -1, -1}, {29472, -1, -1, -1}, {29475, -1, -1, -1}, {29476, -1, -1, -1}, {29478, -1, -1, -1}, {29479, -1, -1, -1}, {29480, -1, -1, -1}, {29485, -1, -1, -1}, {29487, -1, -1, -1}, {29488, -1, -1, -1}, {29490, -1, -1, -1}, {29491, -1, -1, -1}, {29493, -1, -1, -1}, {29498, -1, -1, -1}, {29500, -1, -1, -1}, {29501, -1, -1, -1}, {29504, -1, -1, -1}, {29506, -1, -1, -1}, {29507, -1, -1, -1}, {29510, -1, -1, -1}, {29511, -1, -1, -1}, {29512, -1, -1, -1}, {29513, -1, -1, -1}, {29514, -1, -1, -1}, {29515, -1, -1, -1}, {29516, -1, -1, -1}, {29518, -1, -1, -1}, {29519, -1, -1, -1}, {29521, -1, -1, -1}, {29523, -1, -1, -1}, {29524, -1, -1, -1}, {29525, -1, -1, -1}, {29526, -1, -1, -1}, {29528, -1, -1, -1}, {29529, -1, -1, -1}, {29530, -1, -1, -1}, {29531, -1, -1, -1}, {29532, -1, -1, -1}, {29533, -1, -1, -1}, {29534, -1, -1, -1}, {29535, -1, -1, -1}, {29537, -1, -1, -1}, {29538, -1, -1, -1}, {29539, -1, -1, -1}, {29540, -1, -1, -1}, {29541, -1, -1, -1}, {29542, -1, -1, -1}, {29543, -1, -1, -1}, {29545, -1, -1, -1}, {29550, -1, -1, -1}, {29553, -1, -1, -1}, {29555, -1, -1, -1}, {29556, -1, -1, -1}, {29558, -1, -1, -1}, {29561, -1, -1, -1}, {29565, -1, -1, -1}, {29567, -1, -1, -1}, {29569, -1, -1, -1}, {29570, -1, -1, -1}, {29571, -1, -1, -1}, {29573, -1, -1, -1}, {29574, -1, -1, -1}, {29576, -1, -1, -1}, {29578, -1, -1, -1}, {29580, -1, -1, -1}, {29581, -1, -1, -1}, {29583, -1, -1, -1}, {29584, -1, -1, -1}, {29586, -1, -1, -1} },
+ {{29587, -1, -1, -1}, {29588, -1, -1, -1}, {29589, -1, -1, -1}, {29591, -1, -1, -1}, {29592, -1, -1, -1}, {29593, -1, -1, -1}, {29594, -1, -1, -1}, {29596, -1, -1, -1}, {29597, -1, -1, -1}, {29598, -1, -1, -1}, {29600, -1, -1, -1}, {29601, -1, -1, -1}, {29603, -1, -1, -1}, {29604, -1, -1, -1}, {29605, -1, -1, -1}, {29606, -1, -1, -1}, {29607, -1, -1, -1}, {29608, -1, -1, -1}, {29610, -1, -1, -1}, {29612, -1, -1, -1}, {29613, -1, -1, -1}, {29617, -1, -1, -1}, {29620, -1, -1, -1}, {29621, -1, -1, -1}, {29622, -1, -1, -1}, {29624, -1, -1, -1}, {29625, -1, -1, -1}, {29628, -1, -1, -1}, {29629, -1, -1, -1}, {29630, -1, -1, -1}, {29631, -1, -1, -1}, {29633, -1, -1, -1}, {29635, -1, -1, -1}, {29636, -1, -1, -1}, {29637, -1, -1, -1}, {29638, -1, -1, -1}, {29639, -1, -1, -1}, {29643, -1, -1, -1}, {29644, -1, -1, -1}, {29646, -1, -1, -1}, {29650, -1, -1, -1}, {29651, -1, -1, -1}, {29652, -1, -1, -1}, {29653, -1, -1, -1}, {29654, -1, -1, -1}, {29655, -1, -1, -1}, {29656, -1, -1, -1}, {29658, -1, -1, -1}, {29659, -1, -1, -1}, {29660, -1, -1, -1}, {29661, -1, -1, -1}, {29663, -1, -1, -1}, {29665, -1, -1, -1}, {29666, -1, -1, -1}, {29667, -1, -1, -1}, {29668, -1, -1, -1}, {29670, -1, -1, -1}, {29672, -1, -1, -1}, {29674, -1, -1, -1}, {29675, -1, -1, -1}, {29676, -1, -1, -1}, {29678, -1, -1, -1}, {29679, -1, -1, -1}, {29680, -1, -1, -1}, {29681, -1, -1, -1}, {29683, -1, -1, -1}, {29684, -1, -1, -1}, {29685, -1, -1, -1}, {29686, -1, -1, -1}, {29687, -1, -1, -1}, {29688, -1, -1, -1}, {29689, -1, -1, -1}, {29690, -1, -1, -1}, {29691, -1, -1, -1}, {29692, -1, -1, -1}, {29693, -1, -1, -1}, {29695, -1, -1, -1}, {29696, -1, -1, -1}, {29697, -1, -1, -1}, {29698, -1, -1, -1}, {29700, -1, -1, -1}, {29703, -1, -1, -1}, {29704, -1, -1, -1}, {29707, -1, -1, -1}, {29708, -1, -1, -1}, {29709, -1, -1, -1}, {29710, -1, -1, -1}, {29713, -1, -1, -1}, {29714, -1, -1, -1}, {29715, -1, -1, -1}, {29716, -1, -1, -1}, {29717, -1, -1, -1}, {29718, -1, -1, -1}, {29719, -1, -1, -1}, {29720, -1, -1, -1}, {29721, -1, -1, -1}, {29724, -1, -1, -1}, {29725, -1, -1, -1}, {29726, -1, -1, -1}, {29727, -1, -1, -1}, {29728, -1, -1, -1}, {29729, -1, -1, -1}, {29731, -1, -1, -1}, {29732, -1, -1, -1}, {29735, -1, -1, -1}, {29737, -1, -1, -1}, {29739, -1, -1, -1}, {29741, -1, -1, -1}, {29743, -1, -1, -1}, {29745, -1, -1, -1}, {29746, -1, -1, -1}, {29751, -1, -1, -1}, {29752, -1, -1, -1}, {29753, -1, -1, -1}, {29754, -1, -1, -1}, {29755, -1, -1, -1}, {29757, -1, -1, -1}, {29758, -1, -1, -1}, {29760, -1, -1, -1}, {29762, -1, -1, -1}, {29763, -1, -1, -1}, {29764, -1, -1, -1}, {29765, -1, -1, -1}, {29766, -1, -1, -1}, {29767, -1, -1, -1}, {29768, -1, -1, -1}, {29769, -1, -1, -1}, {29770, -1, -1, -1}, {29772, -1, -1, -1}, {29773, -1, -1, -1}, {29774, -1, -1, -1}, {29775, -1, -1, -1}, {29776, -1, -1, -1}, {29777, -1, -1, -1}, {29778, -1, -1, -1}, {29779, -1, -1, -1}, {29780, -1, -1, -1}, {29782, -1, -1, -1}, {29784, -1, -1, -1}, {29789, -1, -1, -1}, {29792, -1, -1, -1}, {29793, -1, -1, -1}, {29794, -1, -1, -1}, {29796, -1, -1, -1}, {29797, -1, -1, -1}, {29798, -1, -1, -1}, {29799, -1, -1, -1}, {29800, -1, -1, -1}, {29803, -1, -1, -1}, {29804, -1, -1, -1}, {29806, -1, -1, -1}, {29807, -1, -1, -1}, {29809, -1, -1, -1}, {29810, -1, -1, -1}, {29811, -1, -1, -1}, {29812, -1, -1, -1}, {29813, -1, -1, -1}, {29816, -1, -1, -1}, {29817, -1, -1, -1}, {29818, -1, -1, -1}, {29819, -1, -1, -1}, {29820, -1, -1, -1}, {29821, -1, -1, -1}, {29823, -1, -1, -1}, {29826, -1, -1, -1}, {29828, -1, -1, -1}, {29829, -1, -1, -1}, {29830, -1, -1, -1}, {29832, -1, -1, -1}, {29834, -1, -1, -1}, {29836, -1, -1, -1}, {29837, -1, -1, -1}, {29839, -1, -1, -1}, {29841, -1, -1, -1}, {29842, -1, -1, -1}, {29843, -1, -1, -1}, {29844, -1, -1, -1}, {29845, -1, -1, -1}, {29846, -1, -1, -1}, {29847, -1, -1, -1}, {29848, -1, -1, -1}, {29849, -1, -1, -1}, {29850, -1, -1, -1}, {29851, -1, -1, -1}, {29853, -1, -1, -1}, {29855, -1, -1, -1}, {29856, -1, -1, -1}, {29857, -1, -1, -1}, {29858, -1, -1, -1}, {29860, -1, -1, -1}, {29861, -1, -1, -1}, {29866, -1, -1, -1}, {29867, -1, -1, -1}, {29868, -1, -1, -1}, {29869, -1, -1, -1}, {29870, -1, -1, -1}, {29871, -1, -1, -1}, {29873, -1, -1, -1}, {29874, -1, -1, -1}, {29875, -1, -1, -1}, {29876, -1, -1, -1}, {29877, -1, -1, -1}, {29878, -1, -1, -1}, {29879, -1, -1, -1}, {29880, -1, -1, -1}, {29881, -1, -1, -1}, {29883, -1, -1, -1}, {29884, -1, -1, -1}, {29886, -1, -1, -1}, {29887, -1, -1, -1}, {29888, -1, -1, -1}, {29889, -1, -1, -1}, {29890, -1, -1, -1}, {29891, -1, -1, -1}, {29892, -1, -1, -1}, {29893, -1, -1, -1}, {29894, -1, -1, -1}, {29895, -1, -1, -1}, {29896, -1, -1, -1}, {29897, -1, -1, -1}, {29899, -1, -1, -1}, {29900, -1, -1, -1}, {29901, -1, -1, -1}, {29902, -1, -1, -1}, {29904, -1, -1, -1}, {29905, -1, -1, -1}, {29907, -1, -1, -1}, {29909, -1, -1, -1}, {29910, -1, -1, -1}, {29911, -1, -1, -1}, {29912, -1, -1, -1}, {29913, -1, -1, -1}, {29915, -1, -1, -1}, {29917, -1, -1, -1}, {29919, -1, -1, -1}, {29921, -1, -1, -1}, {29925, -1, -1, -1}, {29927, -1, -1, -1}, {29928, -1, -1, -1}, {29929, -1, -1, -1}, {29930, -1, -1, -1}, {29931, -1, -1, -1}, {29932, -1, -1, -1}, {29933, -1, -1, -1}, {29936, -1, -1, -1}, {29937, -1, -1, -1}, {29938, -1, -1, -1}, {29939, -1, -1, -1}, {29941, -1, -1, -1}, {29944, -1, -1, -1}, {29945, -1, -1, -1}, {29946, -1, -1, -1}, {29947, -1, -1, -1}, {29948, -1, -1, -1}, {29949, -1, -1, -1}, {29950, -1, -1, -1} },
+ {{29952, -1, -1, -1}, {29953, -1, -1, -1}, {29954, -1, -1, -1}, {29955, -1, -1, -1}, {29957, -1, -1, -1}, {29958, -1, -1, -1}, {29959, -1, -1, -1}, {29960, -1, -1, -1}, {29961, -1, -1, -1}, {29962, -1, -1, -1}, {29963, -1, -1, -1}, {29966, -1, -1, -1}, {29968, -1, -1, -1}, {29970, -1, -1, -1}, {29972, -1, -1, -1}, {29973, -1, -1, -1}, {29974, -1, -1, -1}, {29975, -1, -1, -1}, {29979, -1, -1, -1}, {29981, -1, -1, -1}, {29982, -1, -1, -1}, {29984, -1, -1, -1}, {29985, -1, -1, -1}, {29986, -1, -1, -1}, {29988, -1, -1, -1}, {29990, -1, -1, -1}, {29991, -1, -1, -1}, {29994, -1, -1, -1}, {29998, -1, -1, -1}, {30004, -1, -1, -1}, {30006, -1, -1, -1}, {30009, -1, -1, -1}, {30012, -1, -1, -1}, {30013, -1, -1, -1}, {30015, -1, -1, -1}, {30017, -1, -1, -1}, {30018, -1, -1, -1}, {30019, -1, -1, -1}, {30020, -1, -1, -1}, {30022, -1, -1, -1}, {30023, -1, -1, -1}, {30025, -1, -1, -1}, {30026, -1, -1, -1}, {30029, -1, -1, -1}, {30032, -1, -1, -1}, {30033, -1, -1, -1}, {30034, -1, -1, -1}, {30035, -1, -1, -1}, {30037, -1, -1, -1}, {30038, -1, -1, -1}, {30039, -1, -1, -1}, {30040, -1, -1, -1}, {30046, -1, -1, -1}, {30047, -1, -1, -1}, {30048, -1, -1, -1}, {30049, -1, -1, -1}, {30051, -1, -1, -1}, {30052, -1, -1, -1}, {30055, -1, -1, -1}, {30056, -1, -1, -1}, {30057, -1, -1, -1}, {30060, -1, -1, -1}, {30061, -1, -1, -1}, {30062, -1, -1, -1}, {30063, -1, -1, -1}, {30064, -1, -1, -1}, {30065, -1, -1, -1}, {30067, -1, -1, -1}, {30069, -1, -1, -1}, {30071, -1, -1, -1}, {30074, -1, -1, -1}, {30075, -1, -1, -1}, {30076, -1, -1, -1}, {30077, -1, -1, -1}, {30078, -1, -1, -1}, {30080, -1, -1, -1}, {30081, -1, -1, -1}, {30082, -1, -1, -1}, {30084, -1, -1, -1}, {30085, -1, -1, -1}, {30088, -1, -1, -1}, {30089, -1, -1, -1}, {30090, -1, -1, -1}, {30092, -1, -1, -1}, {30093, -1, -1, -1}, {30094, -1, -1, -1}, {30096, -1, -1, -1}, {30099, -1, -1, -1}, {30101, -1, -1, -1}, {30104, -1, -1, -1}, {30107, -1, -1, -1}, {30108, -1, -1, -1}, {30110, -1, -1, -1}, {30114, -1, -1, -1}, {30118, -1, -1, -1}, {30119, -1, -1, -1}, {30120, -1, -1, -1}, {30121, -1, -1, -1}, {30122, -1, -1, -1}, {30125, -1, -1, -1}, {30134, -1, -1, -1}, {30135, -1, -1, -1}, {30138, -1, -1, -1}, {30139, -1, -1, -1}, {30143, -1, -1, -1}, {30144, -1, -1, -1}, {30145, -1, -1, -1}, {30150, -1, -1, -1}, {30155, -1, -1, -1}, {30156, -1, -1, -1}, {30158, -1, -1, -1}, {30159, -1, -1, -1}, {30160, -1, -1, -1}, {30161, -1, -1, -1}, {30163, -1, -1, -1}, {30167, -1, -1, -1}, {30170, -1, -1, -1}, {30172, -1, -1, -1}, {30173, -1, -1, -1}, {30175, -1, -1, -1}, {30176, -1, -1, -1}, {30177, -1, -1, -1}, {30181, -1, -1, -1}, {30185, -1, -1, -1}, {30188, -1, -1, -1}, {30189, -1, -1, -1}, {30190, -1, -1, -1}, {30191, -1, -1, -1}, {30194, -1, -1, -1}, {30195, -1, -1, -1}, {30197, -1, -1, -1}, {30198, -1, -1, -1}, {30199, -1, -1, -1}, {30200, -1, -1, -1}, {30202, -1, -1, -1}, {30203, -1, -1, -1}, {30205, -1, -1, -1}, {30206, -1, -1, -1}, {30212, -1, -1, -1}, {30214, -1, -1, -1}, {30215, -1, -1, -1}, {30216, -1, -1, -1}, {30217, -1, -1, -1}, {30222, -1, -1, -1}, {30223, -1, -1, -1}, {30225, -1, -1, -1}, {30226, -1, -1, -1}, {30227, -1, -1, -1}, {30228, -1, -1, -1}, {30230, -1, -1, -1}, {30234, -1, -1, -1}, {30236, -1, -1, -1}, {30237, -1, -1, -1}, {30243, -1, -1, -1}, {30248, -1, -1, -1}, {30252, -1, -1, -1}, {30254, -1, -1, -1}, {30255, -1, -1, -1}, {30257, -1, -1, -1}, {30258, -1, -1, -1}, {30262, -1, -1, -1}, {30263, -1, -1, -1}, {30265, -1, -1, -1}, {30266, -1, -1, -1}, {30269, -1, -1, -1}, {30273, -1, -1, -1}, {30276, -1, -1, -1}, {30277, -1, -1, -1}, {30280, -1, -1, -1}, {30282, -1, -1, -1}, {30283, -1, -1, -1}, {30286, -1, -1, -1}, {30287, -1, -1, -1}, {30288, -1, -1, -1}, {30289, -1, -1, -1}, {30290, -1, -1, -1}, {30291, -1, -1, -1}, {30293, -1, -1, -1}, {30295, -1, -1, -1}, {30297, -1, -1, -1}, {30298, -1, -1, -1}, {30299, -1, -1, -1}, {30301, -1, -1, -1}, {30304, -1, -1, -1}, {30305, -1, -1, -1}, {30310, -1, -1, -1}, {30312, -1, -1, -1}, {30314, -1, -1, -1}, {30323, -1, -1, -1}, {30324, -1, -1, -1}, {30325, -1, -1, -1}, {12136, 30326, -1, -1}, {30327, -1, -1, -1}, {30329, -1, -1, -1}, {30330, -1, -1, -1}, {30335, -1, -1, -1}, {30336, -1, -1, -1}, {30337, -1, -1, -1}, {30339, -1, -1, -1}, {30341, -1, -1, -1}, {30345, -1, -1, -1}, {30346, -1, -1, -1}, {30348, -1, -1, -1}, {30349, -1, -1, -1}, {30351, -1, -1, -1}, {30352, -1, -1, -1}, {30354, -1, -1, -1}, {30356, -1, -1, -1}, {30357, -1, -1, -1}, {30359, -1, -1, -1}, {30360, -1, -1, -1}, {30363, -1, -1, -1}, {30364, -1, -1, -1}, {30365, -1, -1, -1}, {30366, -1, -1, -1}, {30367, -1, -1, -1}, {30368, -1, -1, -1}, {30369, -1, -1, -1}, {30370, -1, -1, -1}, {30371, -1, -1, -1}, {30373, -1, -1, -1}, {30374, -1, -1, -1}, {30375, -1, -1, -1}, {30376, -1, -1, -1}, {30377, -1, -1, -1}, {30378, -1, -1, -1}, {30379, -1, -1, -1}, {30380, -1, -1, -1}, {30381, -1, -1, -1}, {30383, -1, -1, -1}, {30384, -1, -1, -1}, {30387, -1, -1, -1}, {30389, -1, -1, -1}, {30390, -1, -1, -1}, {30391, -1, -1, -1}, {30393, -1, -1, -1}, {30395, -1, -1, -1}, {30396, -1, -1, -1}, {30397, -1, -1, -1}, {30398, -1, -1, -1}, {30400, -1, -1, -1}, {30401, -1, -1, -1}, {30403, -1, -1, -1}, {30404, -1, -1, -1}, {30407, -1, -1, -1}, {30409, -1, -1, -1}, {30411, -1, -1, -1}, {30412, -1, -1, -1}, {30419, -1, -1, -1}, {30421, -1, -1, -1}, {30425, -1, -1, -1}, {30426, -1, -1, -1}, {30428, -1, -1, -1}, {30429, -1, -1, -1}, {30432, -1, -1, -1}, {30434, -1, -1, -1} },
+ {{30438, -1, -1, -1}, {30440, -1, -1, -1}, {30441, -1, -1, -1}, {30442, -1, -1, -1}, {30443, -1, -1, -1}, {30444, -1, -1, -1}, {30445, -1, -1, -1}, {30448, -1, -1, -1}, {30451, -1, -1, -1}, {30453, -1, -1, -1}, {30454, -1, -1, -1}, {30455, -1, -1, -1}, {30458, -1, -1, -1}, {30459, -1, -1, -1}, {30461, -1, -1, -1}, {30463, -1, -1, -1}, {30464, -1, -1, -1}, {30466, -1, -1, -1}, {30467, -1, -1, -1}, {30469, -1, -1, -1}, {30470, -1, -1, -1}, {30474, -1, -1, -1}, {30476, -1, -1, -1}, {30478, -1, -1, -1}, {30479, -1, -1, -1}, {30480, -1, -1, -1}, {30481, -1, -1, -1}, {30482, -1, -1, -1}, {30483, -1, -1, -1}, {30484, -1, -1, -1}, {30485, -1, -1, -1}, {30486, -1, -1, -1}, {30487, -1, -1, -1}, {30488, -1, -1, -1}, {30491, -1, -1, -1}, {30492, -1, -1, -1}, {30493, -1, -1, -1}, {30494, -1, -1, -1}, {30497, -1, -1, -1}, {30499, -1, -1, -1}, {30500, -1, -1, -1}, {30501, -1, -1, -1}, {30503, -1, -1, -1}, {30506, -1, -1, -1}, {30507, -1, -1, -1}, {30508, -1, -1, -1}, {30510, -1, -1, -1}, {30512, -1, -1, -1}, {30513, -1, -1, -1}, {30514, -1, -1, -1}, {30515, -1, -1, -1}, {30516, -1, -1, -1}, {30521, -1, -1, -1}, {30523, -1, -1, -1}, {30525, -1, -1, -1}, {30526, -1, -1, -1}, {30527, -1, -1, -1}, {30530, -1, -1, -1}, {30532, -1, -1, -1}, {30533, -1, -1, -1}, {30534, -1, -1, -1}, {30536, -1, -1, -1}, {30537, -1, -1, -1}, {30538, -1, -1, -1}, {30539, -1, -1, -1}, {30540, -1, -1, -1}, {30541, -1, -1, -1}, {30542, -1, -1, -1}, {30546, -1, -1, -1}, {30547, -1, -1, -1}, {30548, -1, -1, -1}, {30549, -1, -1, -1}, {30550, -1, -1, -1}, {30551, -1, -1, -1}, {30552, -1, -1, -1}, {30553, -1, -1, -1}, {30556, -1, -1, -1}, {30557, -1, -1, -1}, {30559, -1, -1, -1}, {30560, -1, -1, -1}, {30564, -1, -1, -1}, {30567, -1, -1, -1}, {30569, -1, -1, -1}, {30570, -1, -1, -1}, {30573, -1, -1, -1}, {30574, -1, -1, -1}, {30575, -1, -1, -1}, {30576, -1, -1, -1}, {30577, -1, -1, -1}, {30578, -1, -1, -1}, {30579, -1, -1, -1}, {30580, -1, -1, -1}, {30581, -1, -1, -1}, {30582, -1, -1, -1}, {30583, -1, -1, -1}, {30584, -1, -1, -1}, {30586, -1, -1, -1}, {30587, -1, -1, -1}, {30588, -1, -1, -1}, {30593, -1, -1, -1}, {30594, -1, -1, -1}, {30595, -1, -1, -1}, {30598, -1, -1, -1}, {30599, -1, -1, -1}, {30600, -1, -1, -1}, {30601, -1, -1, -1}, {30602, -1, -1, -1}, {30603, -1, -1, -1}, {30607, -1, -1, -1}, {30608, -1, -1, -1}, {30611, -1, -1, -1}, {30612, -1, -1, -1}, {30613, -1, -1, -1}, {30614, -1, -1, -1}, {30615, -1, -1, -1}, {30617, -1, -1, -1}, {30618, -1, -1, -1}, {30619, -1, -1, -1}, {30620, -1, -1, -1}, {30621, -1, -1, -1}, {30625, -1, -1, -1}, {30627, -1, -1, -1}, {30628, -1, -1, -1}, {30630, -1, -1, -1}, {30632, -1, -1, -1}, {30635, -1, -1, -1}, {30638, -1, -1, -1}, {30639, -1, -1, -1}, {30641, -1, -1, -1}, {30642, -1, -1, -1}, {30644, -1, -1, -1}, {30646, -1, -1, -1}, {30647, -1, -1, -1}, {30648, -1, -1, -1}, {30649, -1, -1, -1}, {30650, -1, -1, -1}, {30654, -1, -1, -1}, {30656, -1, -1, -1}, {30657, -1, -1, -1}, {30658, -1, -1, -1}, {30659, -1, -1, -1}, {30660, -1, -1, -1}, {30661, -1, -1, -1}, {30662, -1, -1, -1}, {30664, -1, -1, -1}, {30665, -1, -1, -1}, {30666, -1, -1, -1}, {30667, -1, -1, -1}, {30668, -1, -1, -1}, {30670, -1, -1, -1}, {30671, -1, -1, -1}, {30672, -1, -1, -1}, {30673, -1, -1, -1}, {30674, -1, -1, -1}, {30675, -1, -1, -1}, {30676, -1, -1, -1}, {30677, -1, -1, -1}, {30678, -1, -1, -1}, {30680, -1, -1, -1}, {30681, -1, -1, -1}, {30685, -1, -1, -1}, {30686, -1, -1, -1}, {30687, -1, -1, -1}, {30688, -1, -1, -1}, {30689, -1, -1, -1}, {30692, -1, -1, -1}, {30694, -1, -1, -1}, {30696, -1, -1, -1}, {30698, -1, -1, -1}, {30704, -1, -1, -1}, {30705, -1, -1, -1}, {30706, -1, -1, -1}, {30708, -1, -1, -1}, {30709, -1, -1, -1}, {30711, -1, -1, -1}, {30713, -1, -1, -1}, {30714, -1, -1, -1}, {30715, -1, -1, -1}, {30716, -1, -1, -1}, {30723, -1, -1, -1}, {30724, -1, -1, -1}, {30725, -1, -1, -1}, {30726, -1, -1, -1}, {30727, -1, -1, -1}, {30728, -1, -1, -1}, {30730, -1, -1, -1}, {30731, -1, -1, -1}, {30734, -1, -1, -1}, {30735, -1, -1, -1}, {30736, -1, -1, -1}, {30739, -1, -1, -1}, {30741, -1, -1, -1}, {30745, -1, -1, -1}, {30747, -1, -1, -1}, {30750, -1, -1, -1}, {30752, -1, -1, -1}, {30753, -1, -1, -1}, {30754, -1, -1, -1}, {30756, -1, -1, -1}, {30760, -1, -1, -1}, {30762, -1, -1, -1}, {30763, -1, -1, -1}, {30766, -1, -1, -1}, {30767, -1, -1, -1}, {30769, -1, -1, -1}, {30770, -1, -1, -1}, {30771, -1, -1, -1}, {30773, -1, -1, -1}, {30774, -1, -1, -1}, {30781, -1, -1, -1}, {30783, -1, -1, -1}, {30785, -1, -1, -1}, {30786, -1, -1, -1}, {30788, -1, -1, -1}, {30790, -1, -1, -1}, {30792, -1, -1, -1}, {30793, -1, -1, -1}, {30794, -1, -1, -1}, {30795, -1, -1, -1}, {30797, -1, -1, -1}, {30799, -1, -1, -1}, {30801, -1, -1, -1}, {30803, -1, -1, -1}, {30804, -1, -1, -1}, {30808, -1, -1, -1}, {30809, -1, -1, -1}, {30810, -1, -1, -1}, {30811, -1, -1, -1}, {30812, -1, -1, -1}, {30814, -1, -1, -1}, {30815, -1, -1, -1}, {30816, -1, -1, -1}, {30817, -1, -1, -1}, {30818, -1, -1, -1}, {30819, -1, -1, -1}, {30821, -1, -1, -1}, {30822, -1, -1, -1}, {30823, -1, -1, -1}, {30825, -1, -1, -1}, {30832, -1, -1, -1}, {30833, -1, -1, -1}, {30834, -1, -1, -1}, {30835, -1, -1, -1}, {30836, -1, -1, -1}, {30837, -1, -1, -1}, {30838, -1, -1, -1}, {30840, -1, -1, -1}, {30841, -1, -1, -1}, {30842, -1, -1, -1}, {30843, -1, -1, -1}, {30845, -1, -1, -1}, {30846, -1, -1, -1}, {30847, -1, -1, -1}, {30848, -1, -1, -1}, {30849, -1, -1, -1}, {30850, -1, -1, -1} },
+ {{30851, -1, -1, -1}, {30852, -1, -1, -1}, {30853, -1, -1, -1}, {30854, -1, -1, -1}, {30856, -1, -1, -1}, {30858, -1, -1, -1}, {30859, -1, -1, -1}, {30863, -1, -1, -1}, {30864, -1, -1, -1}, {30866, -1, -1, -1}, {30868, -1, -1, -1}, {30869, -1, -1, -1}, {30870, -1, -1, -1}, {30873, -1, -1, -1}, {30877, -1, -1, -1}, {30878, -1, -1, -1}, {30880, -1, -1, -1}, {30882, -1, -1, -1}, {30884, -1, -1, -1}, {30886, -1, -1, -1}, {30888, -1, -1, -1}, {30890, -1, -1, -1}, {30891, -1, -1, -1}, {30892, -1, -1, -1}, {30894, -1, -1, -1}, {30895, -1, -1, -1}, {30901, -1, -1, -1}, {30902, -1, -1, -1}, {30903, -1, -1, -1}, {30907, -1, -1, -1}, {30909, -1, -1, -1}, {30911, -1, -1, -1}, {30912, -1, -1, -1}, {30914, -1, -1, -1}, {30915, -1, -1, -1}, {30916, -1, -1, -1}, {30918, -1, -1, -1}, {30919, -1, -1, -1}, {30920, -1, -1, -1}, {30924, -1, -1, -1}, {30925, -1, -1, -1}, {30926, -1, -1, -1}, {30927, -1, -1, -1}, {30929, -1, -1, -1}, {30930, -1, -1, -1}, {30931, -1, -1, -1}, {30934, -1, -1, -1}, {30935, -1, -1, -1}, {30936, -1, -1, -1}, {30939, -1, -1, -1}, {30940, -1, -1, -1}, {30941, -1, -1, -1}, {30942, -1, -1, -1}, {30943, -1, -1, -1}, {30944, -1, -1, -1}, {30945, -1, -1, -1}, {30946, -1, -1, -1}, {30948, -1, -1, -1}, {30949, -1, -1, -1}, {30950, -1, -1, -1}, {30953, -1, -1, -1}, {30954, -1, -1, -1}, {30955, -1, -1, -1}, {30957, -1, -1, -1}, {30958, -1, -1, -1}, {30960, -1, -1, -1}, {30961, -1, -1, -1}, {30963, -1, -1, -1}, {30965, -1, -1, -1}, {30966, -1, -1, -1}, {30968, -1, -1, -1}, {30969, -1, -1, -1}, {30971, -1, -1, -1}, {30972, -1, -1, -1}, {30974, -1, -1, -1}, {30975, -1, -1, -1}, {30976, -1, -1, -1}, {30978, -1, -1, -1}, {30979, -1, -1, -1}, {30980, -1, -1, -1}, {30982, -1, -1, -1}, {30983, -1, -1, -1}, {30984, -1, -1, -1}, {30985, -1, -1, -1}, {30986, -1, -1, -1}, {30987, -1, -1, -1}, {30988, -1, -1, -1}, {30989, -1, -1, -1}, {30991, -1, -1, -1}, {30992, -1, -1, -1}, {30993, -1, -1, -1}, {30994, -1, -1, -1}, {30996, -1, -1, -1}, {30997, -1, -1, -1}, {30998, -1, -1, -1}, {30999, -1, -1, -1}, {31000, -1, -1, -1}, {31002, -1, -1, -1}, {31003, -1, -1, -1}, {31004, -1, -1, -1}, {31005, -1, -1, -1}, {31007, -1, -1, -1}, {31008, -1, -1, -1}, {31009, -1, -1, -1}, {31010, -1, -1, -1}, {31011, -1, -1, -1}, {31013, -1, -1, -1}, {31015, -1, -1, -1}, {31016, -1, -1, -1}, {31017, -1, -1, -1}, {31021, -1, -1, -1}, {31022, -1, -1, -1}, {31023, -1, -1, -1}, {31024, -1, -1, -1}, {31026, -1, -1, -1}, {31027, -1, -1, -1}, {31029, -1, -1, -1}, {31030, -1, -1, -1}, {31031, -1, -1, -1}, {31032, -1, -1, -1}, {31033, -1, -1, -1}, {31037, -1, -1, -1}, {31039, -1, -1, -1}, {31042, -1, -1, -1}, {31043, -1, -1, -1}, {31044, -1, -1, -1}, {31045, -1, -1, -1}, {31047, -1, -1, -1}, {31050, -1, -1, -1}, {31051, -1, -1, -1}, {31052, -1, -1, -1}, {31053, -1, -1, -1}, {31054, -1, -1, -1}, {31055, -1, -1, -1}, {31056, -1, -1, -1}, {31057, -1, -1, -1}, {31058, -1, -1, -1}, {31060, -1, -1, -1}, {31061, -1, -1, -1}, {31064, -1, -1, -1}, {31065, -1, -1, -1}, {31073, -1, -1, -1}, {31075, -1, -1, -1}, {31076, -1, -1, -1}, {31078, -1, -1, -1}, {31081, -1, -1, -1}, {31082, -1, -1, -1}, {31083, -1, -1, -1}, {31084, -1, -1, -1}, {31086, -1, -1, -1}, {31088, -1, -1, -1}, {31089, -1, -1, -1}, {31090, -1, -1, -1}, {31091, -1, -1, -1}, {31092, -1, -1, -1}, {31093, -1, -1, -1}, {31094, -1, -1, -1}, {31097, -1, -1, -1}, {31099, -1, -1, -1}, {31100, -1, -1, -1}, {31101, -1, -1, -1}, {31102, -1, -1, -1}, {31103, -1, -1, -1}, {31106, -1, -1, -1}, {31107, -1, -1, -1}, {31110, -1, -1, -1}, {31111, -1, -1, -1}, {31112, -1, -1, -1}, {31113, -1, -1, -1}, {31115, -1, -1, -1}, {31116, -1, -1, -1}, {31120, -1, -1, -1}, {31121, -1, -1, -1}, {31122, -1, -1, -1}, {31123, -1, -1, -1}, {31124, -1, -1, -1}, {31125, -1, -1, -1}, {31126, -1, -1, -1}, {31127, -1, -1, -1}, {31128, -1, -1, -1}, {31129, -1, -1, -1}, {31131, -1, -1, -1}, {31132, -1, -1, -1}, {31133, -1, -1, -1}, {31134, -1, -1, -1}, {31135, -1, -1, -1}, {31136, -1, -1, -1}, {31137, -1, -1, -1}, {31138, -1, -1, -1}, {31139, -1, -1, -1}, {31140, -1, -1, -1}, {31141, -1, -1, -1}, {31144, -1, -1, -1}, {31145, -1, -1, -1}, {31147, -1, -1, -1}, {31148, -1, -1, -1}, {31149, -1, -1, -1}, {31151, -1, -1, -1}, {31154, -1, -1, -1}, {31156, -1, -1, -1}, {31157, -1, -1, -1}, {31158, -1, -1, -1}, {31159, -1, -1, -1}, {12145, 31160, -1, -1}, {31164, -1, -1, -1}, {31167, -1, -1, -1}, {31170, -1, -1, -1}, {31172, -1, -1, -1}, {31173, -1, -1, -1}, {31175, -1, -1, -1}, {31176, -1, -1, -1}, {31178, -1, -1, -1}, {31180, -1, -1, -1}, {31182, -1, -1, -1}, {31183, -1, -1, -1}, {31184, -1, -1, -1}, {31187, -1, -1, -1}, {31188, -1, -1, -1}, {31190, -1, -1, -1}, {31191, -1, -1, -1}, {31193, -1, -1, -1}, {31194, -1, -1, -1}, {31195, -1, -1, -1}, {31196, -1, -1, -1}, {31197, -1, -1, -1}, {31198, -1, -1, -1}, {31200, -1, -1, -1}, {31201, -1, -1, -1}, {31202, -1, -1, -1}, {31205, -1, -1, -1}, {31208, -1, -1, -1}, {31210, -1, -1, -1}, {31212, -1, -1, -1}, {31214, -1, -1, -1}, {31217, -1, -1, -1}, {31218, -1, -1, -1}, {31219, -1, -1, -1}, {31220, -1, -1, -1}, {31221, -1, -1, -1}, {31222, -1, -1, -1}, {31223, -1, -1, -1}, {31225, -1, -1, -1}, {31226, -1, -1, -1}, {31228, -1, -1, -1}, {31230, -1, -1, -1}, {31231, -1, -1, -1}, {31233, -1, -1, -1}, {31236, -1, -1, -1}, {31237, -1, -1, -1}, {31239, -1, -1, -1}, {31240, -1, -1, -1}, {31241, -1, -1, -1}, {31242, -1, -1, -1}, {31244, -1, -1, -1}, {31247, -1, -1, -1}, {31248, -1, -1, -1} },
+ {{31249, -1, -1, -1}, {31250, -1, -1, -1}, {31251, -1, -1, -1}, {31253, -1, -1, -1}, {31254, -1, -1, -1}, {31256, -1, -1, -1}, {31257, -1, -1, -1}, {31259, -1, -1, -1}, {31260, -1, -1, -1}, {31261, -1, -1, -1}, {31263, -1, -1, -1}, {31265, -1, -1, -1}, {31266, -1, -1, -1}, {31268, -1, -1, -1}, {31269, -1, -1, -1}, {31270, -1, -1, -1}, {31271, -1, -1, -1}, {31272, -1, -1, -1}, {31273, -1, -1, -1}, {31274, -1, -1, -1}, {31275, -1, -1, -1}, {31276, -1, -1, -1}, {31277, -1, -1, -1}, {31279, -1, -1, -1}, {31280, -1, -1, -1}, {31282, -1, -1, -1}, {31284, -1, -1, -1}, {31285, -1, -1, -1}, {31286, -1, -1, -1}, {31288, -1, -1, -1}, {31290, -1, -1, -1}, {31294, -1, -1, -1}, {31297, -1, -1, -1}, {31298, -1, -1, -1}, {31299, -1, -1, -1}, {31300, -1, -1, -1}, {31301, -1, -1, -1}, {31303, -1, -1, -1}, {31304, -1, -1, -1}, {31305, -1, -1, -1}, {31306, -1, -1, -1}, {31307, -1, -1, -1}, {31311, -1, -1, -1}, {31312, -1, -1, -1}, {31314, -1, -1, -1}, {31315, -1, -1, -1}, {31316, -1, -1, -1}, {31317, -1, -1, -1}, {31318, -1, -1, -1}, {31320, -1, -1, -1}, {31321, -1, -1, -1}, {31322, -1, -1, -1}, {31323, -1, -1, -1}, {31324, -1, -1, -1}, {31325, -1, -1, -1}, {31326, -1, -1, -1}, {31327, -1, -1, -1}, {31328, -1, -1, -1}, {31331, -1, -1, -1}, {31332, -1, -1, -1}, {31333, -1, -1, -1}, {31334, -1, -1, -1}, {31335, -1, -1, -1}, {31336, -1, -1, -1}, {31338, -1, -1, -1}, {31340, -1, -1, -1}, {31341, -1, -1, -1}, {31342, -1, -1, -1}, {31343, -1, -1, -1}, {31345, -1, -1, -1}, {31346, -1, -1, -1}, {31347, -1, -1, -1}, {31349, -1, -1, -1}, {31355, -1, -1, -1}, {31356, -1, -1, -1}, {31357, -1, -1, -1}, {31358, -1, -1, -1}, {31362, -1, -1, -1}, {31365, -1, -1, -1}, {31367, -1, -1, -1}, {31369, -1, -1, -1}, {31370, -1, -1, -1}, {31371, -1, -1, -1}, {31372, -1, -1, -1}, {31374, -1, -1, -1}, {31375, -1, -1, -1}, {31376, -1, -1, -1}, {31379, -1, -1, -1}, {31380, -1, -1, -1}, {31385, -1, -1, -1}, {31386, -1, -1, -1}, {31387, -1, -1, -1}, {31390, -1, -1, -1}, {31393, -1, -1, -1}, {31394, -1, -1, -1}, {31395, -1, -1, -1}, {31396, -1, -1, -1}, {31399, -1, -1, -1}, {31403, -1, -1, -1}, {31407, -1, -1, -1}, {31408, -1, -1, -1}, {31409, -1, -1, -1}, {31410, -1, -1, -1}, {31412, -1, -1, -1}, {31413, -1, -1, -1}, {31415, -1, -1, -1}, {31416, -1, -1, -1}, {31417, -1, -1, -1}, {31419, -1, -1, -1}, {31420, -1, -1, -1}, {31421, -1, -1, -1}, {31422, -1, -1, -1}, {31424, -1, -1, -1}, {31425, -1, -1, -1}, {31426, -1, -1, -1}, {31427, -1, -1, -1}, {31430, -1, -1, -1}, {31433, -1, -1, -1}, {31436, -1, -1, -1}, {31437, -1, -1, -1}, {31438, -1, -1, -1}, {31439, -1, -1, -1}, {31440, -1, -1, -1}, {31441, -1, -1, -1}, {31442, -1, -1, -1}, {31443, -1, -1, -1}, {31444, -1, -1, -1}, {31445, -1, -1, -1}, {31447, -1, -1, -1}, {31448, -1, -1, -1}, {31450, -1, -1, -1}, {31451, -1, -1, -1}, {31452, -1, -1, -1}, {31453, -1, -1, -1}, {31457, -1, -1, -1}, {31458, -1, -1, -1}, {31460, -1, -1, -1}, {31463, -1, -1, -1}, {31464, -1, -1, -1}, {31465, -1, -1, -1}, {31467, -1, -1, -1}, {31468, -1, -1, -1}, {31470, -1, -1, -1}, {31472, -1, -1, -1}, {31473, -1, -1, -1}, {31474, -1, -1, -1}, {31475, -1, -1, -1}, {31476, -1, -1, -1}, {31477, -1, -1, -1}, {31479, -1, -1, -1}, {31480, -1, -1, -1}, {31483, -1, -1, -1}, {31484, -1, -1, -1}, {31486, -1, -1, -1}, {31488, -1, -1, -1}, {31489, -1, -1, -1}, {31490, -1, -1, -1}, {31493, -1, -1, -1}, {31495, -1, -1, -1}, {31497, -1, -1, -1}, {31500, -1, -1, -1}, {31501, -1, -1, -1}, {31502, -1, -1, -1}, {31504, -1, -1, -1}, {31506, -1, -1, -1}, {31507, -1, -1, -1}, {31510, -1, -1, -1}, {31511, -1, -1, -1}, {31512, -1, -1, -1}, {31514, -1, -1, -1}, {31516, -1, -1, -1}, {31517, -1, -1, -1}, {31519, -1, -1, -1}, {31521, -1, -1, -1}, {31522, -1, -1, -1}, {31523, -1, -1, -1}, {31527, -1, -1, -1}, {31529, -1, -1, -1}, {31533, -1, -1, -1}, {31535, -1, -1, -1}, {31536, -1, -1, -1}, {31538, -1, -1, -1}, {31540, -1, -1, -1}, {31541, -1, -1, -1}, {31542, -1, -1, -1}, {31543, -1, -1, -1}, {31545, -1, -1, -1}, {31547, -1, -1, -1}, {31549, -1, -1, -1}, {31551, -1, -1, -1}, {31552, -1, -1, -1}, {31553, -1, -1, -1}, {31554, -1, -1, -1}, {31555, -1, -1, -1}, {31556, -1, -1, -1}, {31560, -1, -1, -1}, {31562, -1, -1, -1}, {31565, -1, -1, -1}, {31566, -1, -1, -1}, {31571, -1, -1, -1}, {31573, -1, -1, -1}, {31575, -1, -1, -1}, {31577, -1, -1, -1}, {31580, -1, -1, -1}, {31582, -1, -1, -1}, {31583, -1, -1, -1}, {31585, -1, -1, -1}, {31587, -1, -1, -1}, {31588, -1, -1, -1}, {31589, -1, -1, -1}, {31590, -1, -1, -1}, {31592, -1, -1, -1}, {31593, -1, -1, -1}, {31594, -1, -1, -1}, {31595, -1, -1, -1}, {31596, -1, -1, -1}, {31597, -1, -1, -1}, {31599, -1, -1, -1}, {31600, -1, -1, -1}, {31603, -1, -1, -1}, {31604, -1, -1, -1}, {31606, -1, -1, -1}, {31608, -1, -1, -1}, {31610, -1, -1, -1}, {31612, -1, -1, -1}, {31613, -1, -1, -1}, {31615, -1, -1, -1}, {31617, -1, -1, -1}, {31618, -1, -1, -1}, {31619, -1, -1, -1}, {31620, -1, -1, -1}, {31622, -1, -1, -1}, {31623, -1, -1, -1}, {31624, -1, -1, -1}, {31625, -1, -1, -1}, {31626, -1, -1, -1}, {31628, -1, -1, -1}, {31630, -1, -1, -1}, {31631, -1, -1, -1}, {31633, -1, -1, -1}, {31634, -1, -1, -1}, {31635, -1, -1, -1}, {31638, -1, -1, -1}, {31640, -1, -1, -1}, {31641, -1, -1, -1}, {31642, -1, -1, -1}, {31643, -1, -1, -1}, {31646, -1, -1, -1}, {31647, -1, -1, -1}, {31648, -1, -1, -1}, {31651, -1, -1, -1}, {31652, -1, -1, -1}, {31653, -1, -1, -1}, {31662, -1, -1, -1}, {31663, -1, -1, -1}, {31664, -1, -1, -1} },
+ {{31666, -1, -1, -1}, {31667, -1, -1, -1}, {31669, -1, -1, -1}, {31670, -1, -1, -1}, {31671, -1, -1, -1}, {31673, -1, -1, -1}, {31674, -1, -1, -1}, {31675, -1, -1, -1}, {31676, -1, -1, -1}, {31677, -1, -1, -1}, {31678, -1, -1, -1}, {31679, -1, -1, -1}, {31682, -1, -1, -1}, {31683, -1, -1, -1}, {31685, -1, -1, -1}, {31688, -1, -1, -1}, {31690, -1, -1, -1}, {31693, -1, -1, -1}, {31694, -1, -1, -1}, {31695, -1, -1, -1}, {31696, -1, -1, -1}, {31698, -1, -1, -1}, {31700, -1, -1, -1}, {31701, -1, -1, -1}, {31702, -1, -1, -1}, {31703, -1, -1, -1}, {31704, -1, -1, -1}, {31707, -1, -1, -1}, {31708, -1, -1, -1}, {31710, -1, -1, -1}, {31711, -1, -1, -1}, {31712, -1, -1, -1}, {31714, -1, -1, -1}, {31715, -1, -1, -1}, {31719, -1, -1, -1}, {31720, -1, -1, -1}, {31723, -1, -1, -1}, {31724, -1, -1, -1}, {31725, -1, -1, -1}, {31727, -1, -1, -1}, {31728, -1, -1, -1}, {31730, -1, -1, -1}, {31732, -1, -1, -1}, {31733, -1, -1, -1}, {31734, -1, -1, -1}, {31736, -1, -1, -1}, {31737, -1, -1, -1}, {31738, -1, -1, -1}, {31739, -1, -1, -1}, {31741, -1, -1, -1}, {31743, -1, -1, -1}, {31745, -1, -1, -1}, {31746, -1, -1, -1}, {31747, -1, -1, -1}, {31748, -1, -1, -1}, {31749, -1, -1, -1}, {31750, -1, -1, -1}, {31752, -1, -1, -1}, {31753, -1, -1, -1}, {31754, -1, -1, -1}, {31758, -1, -1, -1}, {31760, -1, -1, -1}, {31761, -1, -1, -1}, {31762, -1, -1, -1}, {31763, -1, -1, -1}, {31764, -1, -1, -1}, {31765, -1, -1, -1}, {31767, -1, -1, -1}, {31768, -1, -1, -1}, {31769, -1, -1, -1}, {31770, -1, -1, -1}, {31771, -1, -1, -1}, {31772, -1, -1, -1}, {31773, -1, -1, -1}, {31776, -1, -1, -1}, {31778, -1, -1, -1}, {31780, -1, -1, -1}, {31781, -1, -1, -1}, {31784, -1, -1, -1}, {31785, -1, -1, -1}, {31788, -1, -1, -1}, {31789, -1, -1, -1}, {31790, -1, -1, -1}, {31791, -1, -1, -1}, {31792, -1, -1, -1}, {31793, -1, -1, -1}, {31794, -1, -1, -1}, {31795, -1, -1, -1}, {31796, -1, -1, -1}, {31797, -1, -1, -1}, {31798, -1, -1, -1}, {31799, -1, -1, -1}, {31801, -1, -1, -1}, {31802, -1, -1, -1}, {31803, -1, -1, -1}, {31804, -1, -1, -1}, {31810, -1, -1, -1}, {31812, -1, -1, -1}, {31813, -1, -1, -1}, {31814, -1, -1, -1}, {31815, -1, -1, -1}, {31816, -1, -1, -1}, {31817, -1, -1, -1}, {31818, -1, -1, -1}, {31819, -1, -1, -1}, {31822, -1, -1, -1}, {31823, -1, -1, -1}, {31824, -1, -1, -1}, {31825, -1, -1, -1}, {31826, -1, -1, -1}, {31827, -1, -1, -1}, {31828, -1, -1, -1}, {31829, -1, -1, -1}, {31830, -1, -1, -1}, {31831, -1, -1, -1}, {31832, -1, -1, -1}, {31833, -1, -1, -1}, {31834, -1, -1, -1}, {31835, -1, -1, -1}, {31837, -1, -1, -1}, {31838, -1, -1, -1}, {31841, -1, -1, -1}, {31842, -1, -1, -1}, {31843, -1, -1, -1}, {31845, -1, -1, -1}, {31846, -1, -1, -1}, {31847, -1, -1, -1}, {31848, -1, -1, -1}, {31851, -1, -1, -1}, {31853, -1, -1, -1}, {31855, -1, -1, -1}, {31856, -1, -1, -1}, {31857, -1, -1, -1}, {31861, -1, -1, -1}, {31862, -1, -1, -1}, {31863, -1, -1, -1}, {31864, -1, -1, -1}, {31865, -1, -1, -1}, {31866, -1, -1, -1}, {31870, -1, -1, -1}, {31871, -1, -1, -1}, {31872, -1, -1, -1}, {31873, -1, -1, -1}, {31874, -1, -1, -1}, {31875, -1, -1, -1}, {31876, -1, -1, -1}, {31877, -1, -1, -1}, {31878, -1, -1, -1}, {31879, -1, -1, -1}, {31880, -1, -1, -1}, {31882, -1, -1, -1}, {31883, -1, -1, -1}, {31884, -1, -1, -1}, {31885, -1, -1, -1}, {31886, -1, -1, -1}, {31887, -1, -1, -1}, {31888, -1, -1, -1}, {31891, -1, -1, -1}, {31892, -1, -1, -1}, {31894, -1, -1, -1}, {31897, -1, -1, -1}, {31898, -1, -1, -1}, {31899, -1, -1, -1}, {31904, -1, -1, -1}, {31905, -1, -1, -1}, {31907, -1, -1, -1}, {31910, -1, -1, -1}, {31911, -1, -1, -1}, {31912, -1, -1, -1}, {31913, -1, -1, -1}, {31915, -1, -1, -1}, {31916, -1, -1, -1}, {31917, -1, -1, -1}, {31919, -1, -1, -1}, {31920, -1, -1, -1}, {31924, -1, -1, -1}, {31925, -1, -1, -1}, {31926, -1, -1, -1}, {31927, -1, -1, -1}, {31928, -1, -1, -1}, {31930, -1, -1, -1}, {31931, -1, -1, -1}, {31935, -1, -1, -1}, {31936, -1, -1, -1}, {31938, -1, -1, -1}, {31939, -1, -1, -1}, {31940, -1, -1, -1}, {31942, -1, -1, -1}, {31945, -1, -1, -1}, {31947, -1, -1, -1}, {31950, -1, -1, -1}, {31951, -1, -1, -1}, {31952, -1, -1, -1}, {31953, -1, -1, -1}, {31954, -1, -1, -1}, {31955, -1, -1, -1}, {31956, -1, -1, -1}, {31960, -1, -1, -1}, {31962, -1, -1, -1}, {31963, -1, -1, -1}, {31969, -1, -1, -1}, {31970, -1, -1, -1}, {31971, -1, -1, -1}, {31972, -1, -1, -1}, {31973, -1, -1, -1}, {31974, -1, -1, -1}, {31977, -1, -1, -1}, {31978, -1, -1, -1}, {31979, -1, -1, -1}, {31980, -1, -1, -1}, {31981, -1, -1, -1}, {31982, -1, -1, -1}, {31985, -1, -1, -1}, {31987, -1, -1, -1}, {31989, -1, -1, -1}, {31991, -1, -1, -1}, {31994, -1, -1, -1}, {31996, -1, -1, -1}, {31997, -1, -1, -1}, {31999, -1, -1, -1}, {32001, -1, -1, -1}, {32003, -1, -1, -1}, {32012, -1, -1, -1}, {32014, -1, -1, -1}, {32015, -1, -1, -1}, {32017, -1, -1, -1}, {32018, -1, -1, -1}, {32022, -1, -1, -1}, {32024, -1, -1, -1}, {32029, -1, -1, -1}, {32030, -1, -1, -1}, {32031, -1, -1, -1}, {32035, -1, -1, -1}, {32036, -1, -1, -1}, {32037, -1, -1, -1}, {32038, -1, -1, -1}, {32040, -1, -1, -1}, {32041, -1, -1, -1}, {32042, -1, -1, -1}, {32044, -1, -1, -1}, {32045, -1, -1, -1}, {32046, -1, -1, -1}, {32052, -1, -1, -1}, {32053, -1, -1, -1}, {32054, -1, -1, -1}, {32055, -1, -1, -1}, {32056, -1, -1, -1}, {32059, -1, -1, -1}, {32061, -1, -1, -1}, {32062, -1, -1, -1}, {32065, -1, -1, -1}, {32067, -1, -1, -1}, {32069, -1, -1, -1}, {32071, -1, -1, -1}, {32072, -1, -1, -1}, {32073, -1, -1, -1} },
+ {{32074, -1, -1, -1}, {32075, -1, -1, -1}, {32076, -1, -1, -1}, {32077, -1, -1, -1}, {32079, -1, -1, -1}, {32081, -1, -1, -1}, {32082, -1, -1, -1}, {32083, -1, -1, -1}, {32084, -1, -1, -1}, {32085, -1, -1, -1}, {32086, -1, -1, -1}, {32087, -1, -1, -1}, {32088, -1, -1, -1}, {32089, -1, -1, -1}, {32090, -1, -1, -1}, {32091, -1, -1, -1}, {32092, -1, -1, -1}, {32095, -1, -1, -1}, {32096, -1, -1, -1}, {32099, -1, -1, -1}, {32100, -1, -1, -1}, {32101, -1, -1, -1}, {32103, -1, -1, -1}, {32105, -1, -1, -1}, {32106, -1, -1, -1}, {32107, -1, -1, -1}, {32108, -1, -1, -1}, {32109, -1, -1, -1}, {32111, -1, -1, -1}, {32112, -1, -1, -1}, {32116, -1, -1, -1}, {32117, -1, -1, -1}, {32120, -1, -1, -1}, {32122, -1, -1, -1}, {32123, -1, -1, -1}, {32124, -1, -1, -1}, {32125, -1, -1, -1}, {32126, -1, -1, -1}, {32127, -1, -1, -1}, {32128, -1, -1, -1}, {32130, -1, -1, -1}, {32132, -1, -1, -1}, {32133, -1, -1, -1}, {32135, -1, -1, -1}, {32138, -1, -1, -1}, {32139, -1, -1, -1}, {32140, -1, -1, -1}, {32141, -1, -1, -1}, {32142, -1, -1, -1}, {32144, -1, -1, -1}, {32145, -1, -1, -1}, {32146, -1, -1, -1}, {32148, -1, -1, -1}, {32149, -1, -1, -1}, {32150, -1, -1, -1}, {32151, -1, -1, -1}, {32152, -1, -1, -1}, {32153, -1, -1, -1}, {32154, -1, -1, -1}, {32155, -1, -1, -1}, {32157, -1, -1, -1}, {32159, -1, -1, -1}, {32160, -1, -1, -1}, {32161, -1, -1, -1}, {32164, -1, -1, -1}, {32165, -1, -1, -1}, {32167, -1, -1, -1}, {32168, -1, -1, -1}, {32169, -1, -1, -1}, {32170, -1, -1, -1}, {32175, -1, -1, -1}, {32181, -1, -1, -1}, {32182, -1, -1, -1}, {32183, -1, -1, -1}, {32188, -1, -1, -1}, {32192, -1, -1, -1}, {32193, -1, -1, -1}, {32194, -1, -1, -1}, {32195, -1, -1, -1}, {32197, -1, -1, -1}, {32198, -1, -1, -1}, {32200, -1, -1, -1}, {32201, -1, -1, -1}, {32204, -1, -1, -1}, {32205, -1, -1, -1}, {32206, -1, -1, -1}, {32207, -1, -1, -1}, {32208, -1, -1, -1}, {32211, -1, -1, -1}, {32213, -1, -1, -1}, {32214, -1, -1, -1}, {32218, -1, -1, -1}, {32219, -1, -1, -1}, {32220, -1, -1, -1}, {32223, -1, -1, -1}, {32226, -1, -1, -1}, {32228, -1, -1, -1}, {32229, -1, -1, -1}, {32231, -1, -1, -1}, {32234, -1, -1, -1}, {32235, -1, -1, -1}, {32237, -1, -1, -1}, {32238, -1, -1, -1}, {32240, -1, -1, -1}, {32243, -1, -1, -1}, {32245, -1, -1, -1}, {32247, -1, -1, -1}, {32248, -1, -1, -1}, {32250, -1, -1, -1}, {32252, -1, -1, -1}, {32253, -1, -1, -1}, {32254, -1, -1, -1}, {32255, -1, -1, -1}, {32256, -1, -1, -1}, {32257, -1, -1, -1}, {32258, -1, -1, -1}, {32259, -1, -1, -1}, {32260, -1, -1, -1}, {32261, -1, -1, -1}, {32262, -1, -1, -1}, {32263, -1, -1, -1}, {32268, -1, -1, -1}, {32269, -1, -1, -1}, {32270, -1, -1, -1}, {32271, -1, -1, -1}, {32274, -1, -1, -1}, {32275, -1, -1, -1}, {32276, -1, -1, -1}, {32277, -1, -1, -1}, {32278, -1, -1, -1}, {32279, -1, -1, -1}, {32280, -1, -1, -1}, {32281, -1, -1, -1}, {32282, -1, -1, -1}, {32284, -1, -1, -1}, {32288, -1, -1, -1}, {32289, -1, -1, -1}, {32290, -1, -1, -1}, {32292, -1, -1, -1}, {32293, -1, -1, -1}, {32294, -1, -1, -1}, {32296, -1, -1, -1}, {32297, -1, -1, -1}, {32298, -1, -1, -1}, {32300, -1, -1, -1}, {32303, -1, -1, -1}, {32304, -1, -1, -1}, {32307, -1, -1, -1}, {32312, -1, -1, -1}, {32314, -1, -1, -1}, {32316, -1, -1, -1}, {32319, -1, -1, -1}, {32320, -1, -1, -1}, {32322, -1, -1, -1}, {32323, -1, -1, -1}, {32324, -1, -1, -1}, {32328, -1, -1, -1}, {32329, -1, -1, -1}, {32330, -1, -1, -1}, {32331, -1, -1, -1}, {32332, -1, -1, -1}, {32333, -1, -1, -1}, {32334, -1, -1, -1}, {32335, -1, -1, -1}, {32336, -1, -1, -1}, {32337, -1, -1, -1}, {32339, -1, -1, -1}, {32342, -1, -1, -1}, {32343, -1, -1, -1}, {32344, -1, -1, -1}, {32345, -1, -1, -1}, {32347, -1, -1, -1}, {32348, -1, -1, -1}, {32349, -1, -1, -1}, {32351, -1, -1, -1}, {32352, -1, -1, -1}, {32353, -1, -1, -1}, {32355, -1, -1, -1}, {32356, -1, -1, -1}, {32357, -1, -1, -1}, {32358, -1, -1, -1}, {32359, -1, -1, -1}, {32360, -1, -1, -1}, {32364, -1, -1, -1}, {32369, -1, -1, -1}, {32370, -1, -1, -1}, {32372, -1, -1, -1}, {32373, -1, -1, -1}, {32374, -1, -1, -1}, {32375, -1, -1, -1}, {32376, -1, -1, -1}, {32378, -1, -1, -1}, {32379, -1, -1, -1}, {32383, -1, -1, -1}, {32384, -1, -1, -1}, {32385, -1, -1, -1}, {32387, -1, -1, -1}, {32388, -1, -1, -1}, {32389, -1, -1, -1}, {32390, -1, -1, -1}, {32391, -1, -1, -1}, {32393, -1, -1, -1}, {32395, -1, -1, -1}, {32398, -1, -1, -1}, {32400, -1, -1, -1}, {32401, -1, -1, -1}, {32402, -1, -1, -1}, {32405, -1, -1, -1}, {32407, -1, -1, -1}, {32409, -1, -1, -1}, {32410, -1, -1, -1}, {32413, -1, -1, -1}, {32414, -1, -1, -1}, {32430, -1, -1, -1}, {32436, -1, -1, -1}, {32443, -1, -1, -1}, {32444, -1, -1, -1}, {32470, -1, -1, -1}, {32484, -1, -1, -1}, {32492, -1, -1, -1}, {32505, -1, -1, -1}, {32522, -1, -1, -1}, {32528, -1, -1, -1}, {32542, -1, -1, -1}, {32567, -1, -1, -1}, {32569, -1, -1, -1}, {32571, -1, -1, -1}, {32572, -1, -1, -1}, {32573, -1, -1, -1}, {32574, -1, -1, -1}, {32575, -1, -1, -1}, {32576, -1, -1, -1}, {32577, -1, -1, -1}, {32579, -1, -1, -1}, {32582, -1, -1, -1}, {32583, -1, -1, -1}, {32584, -1, -1, -1}, {32585, -1, -1, -1}, {32586, -1, -1, -1}, {32587, -1, -1, -1}, {32589, -1, -1, -1}, {32591, -1, -1, -1}, {32594, -1, -1, -1}, {32595, -1, -1, -1}, {32598, -1, -1, -1}, {32601, -1, -1, -1}, {32603, -1, -1, -1}, {32604, -1, -1, -1}, {32605, -1, -1, -1}, {32606, -1, -1, -1}, {32608, -1, -1, -1}, {32611, -1, -1, -1}, {32612, -1, -1, -1}, {32613, -1, -1, -1}, {32614, -1, -1, -1}, {32615, -1, -1, -1} },
+ {{32619, -1, -1, -1}, {32620, -1, -1, -1}, {32621, -1, -1, -1}, {32623, -1, -1, -1}, {32627, -1, -1, -1}, {32629, -1, -1, -1}, {32630, -1, -1, -1}, {32632, -1, -1, -1}, {32634, -1, -1, -1}, {32635, -1, -1, -1}, {32636, -1, -1, -1}, {32637, -1, -1, -1}, {32639, -1, -1, -1}, {32640, -1, -1, -1}, {32642, -1, -1, -1}, {32643, -1, -1, -1}, {32644, -1, -1, -1}, {32647, -1, -1, -1}, {32649, -1, -1, -1}, {32651, -1, -1, -1}, {32653, -1, -1, -1}, {32655, -1, -1, -1}, {32656, -1, -1, -1}, {32657, -1, -1, -1}, {32658, -1, -1, -1}, {32659, -1, -1, -1}, {32661, -1, -1, -1}, {32662, -1, -1, -1}, {32663, -1, -1, -1}, {32664, -1, -1, -1}, {32665, -1, -1, -1}, {32667, -1, -1, -1}, {32668, -1, -1, -1}, {32672, -1, -1, -1}, {32674, -1, -1, -1}, {32675, -1, -1, -1}, {32678, -1, -1, -1}, {32680, -1, -1, -1}, {32682, -1, -1, -1}, {32683, -1, -1, -1}, {32684, -1, -1, -1}, {32685, -1, -1, -1}, {32686, -1, -1, -1}, {32689, -1, -1, -1}, {32691, -1, -1, -1}, {32692, -1, -1, -1}, {32693, -1, -1, -1}, {32694, -1, -1, -1}, {32695, -1, -1, -1}, {32698, -1, -1, -1}, {32699, -1, -1, -1}, {32702, -1, -1, -1}, {32704, -1, -1, -1}, {32706, -1, -1, -1}, {32707, -1, -1, -1}, {32708, -1, -1, -1}, {32710, -1, -1, -1}, {32711, -1, -1, -1}, {32712, -1, -1, -1}, {32713, -1, -1, -1}, {32715, -1, -1, -1}, {32717, -1, -1, -1}, {32719, -1, -1, -1}, {32720, -1, -1, -1}, {32721, -1, -1, -1}, {32723, -1, -1, -1}, {32726, -1, -1, -1}, {32727, -1, -1, -1}, {32729, -1, -1, -1}, {32730, -1, -1, -1}, {32731, -1, -1, -1}, {32732, -1, -1, -1}, {32733, -1, -1, -1}, {32734, -1, -1, -1}, {32738, -1, -1, -1}, {32739, -1, -1, -1}, {32740, -1, -1, -1}, {32743, -1, -1, -1}, {32744, -1, -1, -1}, {32746, -1, -1, -1}, {32747, -1, -1, -1}, {32748, -1, -1, -1}, {32749, -1, -1, -1}, {32751, -1, -1, -1}, {32754, -1, -1, -1}, {32756, -1, -1, -1}, {32757, -1, -1, -1}, {32758, -1, -1, -1}, {32759, -1, -1, -1}, {32760, -1, -1, -1}, {32762, -1, -1, -1}, {32765, -1, -1, -1}, {32766, -1, -1, -1}, {32767, -1, -1, -1}, {32770, -1, -1, -1}, {32775, -1, -1, -1}, {32776, -1, -1, -1}, {32777, -1, -1, -1}, {32778, -1, -1, -1}, {32782, -1, -1, -1}, {32783, -1, -1, -1}, {32785, -1, -1, -1}, {32787, -1, -1, -1}, {32794, -1, -1, -1}, {32795, -1, -1, -1}, {32797, -1, -1, -1}, {32798, -1, -1, -1}, {32799, -1, -1, -1}, {32801, -1, -1, -1}, {32803, -1, -1, -1}, {32804, -1, -1, -1}, {32811, -1, -1, -1}, {32813, -1, -1, -1}, {32815, -1, -1, -1}, {32816, -1, -1, -1}, {32818, -1, -1, -1}, {32820, -1, -1, -1}, {32825, -1, -1, -1}, {32826, -1, -1, -1}, {32828, -1, -1, -1}, {32830, -1, -1, -1}, {32832, -1, -1, -1}, {32833, -1, -1, -1}, {32836, -1, -1, -1}, {32837, -1, -1, -1}, {32839, -1, -1, -1}, {32840, -1, -1, -1}, {32841, -1, -1, -1}, {32846, -1, -1, -1}, {32847, -1, -1, -1}, {32848, -1, -1, -1}, {32849, -1, -1, -1}, {32851, -1, -1, -1}, {32853, -1, -1, -1}, {32855, -1, -1, -1}, {32857, -1, -1, -1}, {32859, -1, -1, -1}, {32860, -1, -1, -1}, {32861, -1, -1, -1}, {32863, -1, -1, -1}, {32864, -1, -1, -1}, {32865, -1, -1, -1}, {32866, -1, -1, -1}, {32867, -1, -1, -1}, {32868, -1, -1, -1}, {32869, -1, -1, -1}, {32870, -1, -1, -1}, {32871, -1, -1, -1}, {32872, -1, -1, -1}, {32875, -1, -1, -1}, {32876, -1, -1, -1}, {32877, -1, -1, -1}, {32878, -1, -1, -1}, {32884, -1, -1, -1}, {32888, -1, -1, -1}, {32890, -1, -1, -1}, {32891, -1, -1, -1}, {32892, -1, -1, -1}, {32897, -1, -1, -1}, {32898, -1, -1, -1}, {32904, -1, -1, -1}, {32906, -1, -1, -1}, {32909, -1, -1, -1}, {32910, -1, -1, -1}, {32911, -1, -1, -1}, {32912, -1, -1, -1}, {32913, -1, -1, -1}, {32914, -1, -1, -1}, {32916, -1, -1, -1}, {32917, -1, -1, -1}, {32919, -1, -1, -1}, {32921, -1, -1, -1}, {32926, -1, -1, -1}, {32931, -1, -1, -1}, {32934, -1, -1, -1}, {32935, -1, -1, -1}, {32936, -1, -1, -1}, {32940, -1, -1, -1}, {32944, -1, -1, -1}, {32947, -1, -1, -1}, {32949, -1, -1, -1}, {32950, -1, -1, -1}, {32952, -1, -1, -1}, {32953, -1, -1, -1}, {32955, -1, -1, -1}, {32965, -1, -1, -1}, {32967, -1, -1, -1}, {32968, -1, -1, -1}, {32969, -1, -1, -1}, {32970, -1, -1, -1}, {32971, -1, -1, -1}, {32975, -1, -1, -1}, {32976, -1, -1, -1}, {32977, -1, -1, -1}, {32978, -1, -1, -1}, {32979, -1, -1, -1}, {32980, -1, -1, -1}, {32981, -1, -1, -1}, {32984, -1, -1, -1}, {32991, -1, -1, -1}, {32992, -1, -1, -1}, {32994, -1, -1, -1}, {32995, -1, -1, -1}, {32998, -1, -1, -1}, {33006, -1, -1, -1}, {33013, -1, -1, -1}, {33015, -1, -1, -1}, {33017, -1, -1, -1}, {33019, -1, -1, -1}, {33022, -1, -1, -1}, {33023, -1, -1, -1}, {33024, -1, -1, -1}, {33025, -1, -1, -1}, {33027, -1, -1, -1}, {33028, -1, -1, -1}, {33031, -1, -1, -1}, {33032, -1, -1, -1}, {33035, -1, -1, -1}, {33036, -1, -1, -1}, {33045, -1, -1, -1}, {33047, -1, -1, -1}, {33049, -1, -1, -1}, {33052, -1, -1, -1}, {33053, -1, -1, -1}, {33055, -1, -1, -1}, {33056, -1, -1, -1}, {33057, -1, -1, -1}, {33058, -1, -1, -1}, {33059, -1, -1, -1}, {33060, -1, -1, -1}, {33061, -1, -1, -1}, {33062, -1, -1, -1}, {33063, -1, -1, -1}, {33064, -1, -1, -1}, {33065, -1, -1, -1}, {33066, -1, -1, -1}, {33067, -1, -1, -1}, {33069, -1, -1, -1}, {33070, -1, -1, -1}, {33072, -1, -1, -1}, {33075, -1, -1, -1}, {33076, -1, -1, -1}, {33077, -1, -1, -1}, {33079, -1, -1, -1}, {33082, -1, -1, -1}, {33083, -1, -1, -1}, {33084, -1, -1, -1}, {33085, -1, -1, -1}, {33087, -1, -1, -1}, {33088, -1, -1, -1}, {33089, -1, -1, -1}, {33090, -1, -1, -1}, {33091, -1, -1, -1}, {33092, -1, -1, -1}, {33093, -1, -1, -1}, {33095, -1, -1, -1} },
+ {{33097, -1, -1, -1}, {33101, -1, -1, -1}, {33103, -1, -1, -1}, {33106, -1, -1, -1}, {33111, -1, -1, -1}, {33112, -1, -1, -1}, {33115, -1, -1, -1}, {33116, -1, -1, -1}, {33117, -1, -1, -1}, {33118, -1, -1, -1}, {33119, -1, -1, -1}, {33122, -1, -1, -1}, {33123, -1, -1, -1}, {33124, -1, -1, -1}, {33128, -1, -1, -1}, {33130, -1, -1, -1}, {33132, -1, -1, -1}, {33135, -1, -1, -1}, {33138, -1, -1, -1}, {33139, -1, -1, -1}, {33141, -1, -1, -1}, {33142, -1, -1, -1}, {33143, -1, -1, -1}, {33153, -1, -1, -1}, {33155, -1, -1, -1}, {33156, -1, -1, -1}, {33157, -1, -1, -1}, {33158, -1, -1, -1}, {33159, -1, -1, -1}, {33161, -1, -1, -1}, {33163, -1, -1, -1}, {33164, -1, -1, -1}, {33165, -1, -1, -1}, {33166, -1, -1, -1}, {33168, -1, -1, -1}, {33170, -1, -1, -1}, {33171, -1, -1, -1}, {33172, -1, -1, -1}, {33173, -1, -1, -1}, {33174, -1, -1, -1}, {33175, -1, -1, -1}, {33177, -1, -1, -1}, {33182, -1, -1, -1}, {33183, -1, -1, -1}, {33185, -1, -1, -1}, {33186, -1, -1, -1}, {33188, -1, -1, -1}, {33189, -1, -1, -1}, {33191, -1, -1, -1}, {33195, -1, -1, -1}, {33196, -1, -1, -1}, {33197, -1, -1, -1}, {33198, -1, -1, -1}, {33199, -1, -1, -1}, {33200, -1, -1, -1}, {33201, -1, -1, -1}, {33202, -1, -1, -1}, {33204, -1, -1, -1}, {33205, -1, -1, -1}, {33206, -1, -1, -1}, {33207, -1, -1, -1}, {33208, -1, -1, -1}, {33209, -1, -1, -1}, {33212, -1, -1, -1}, {33220, -1, -1, -1}, {33221, -1, -1, -1}, {33223, -1, -1, -1}, {33224, -1, -1, -1}, {33227, -1, -1, -1}, {33230, -1, -1, -1}, {33232, -1, -1, -1}, {33233, -1, -1, -1}, {33234, -1, -1, -1}, {33235, -1, -1, -1}, {33236, -1, -1, -1}, {33237, -1, -1, -1}, {33238, -1, -1, -1}, {33239, -1, -1, -1}, {33241, -1, -1, -1}, {33243, -1, -1, -1}, {33244, -1, -1, -1}, {33245, -1, -1, -1}, {33246, -1, -1, -1}, {33249, -1, -1, -1}, {33250, -1, -1, -1}, {33252, -1, -1, -1}, {33253, -1, -1, -1}, {33254, -1, -1, -1}, {33257, -1, -1, -1}, {33259, -1, -1, -1}, {33262, -1, -1, -1}, {33263, -1, -1, -1}, {33264, -1, -1, -1}, {33265, -1, -1, -1}, {33266, -1, -1, -1}, {33269, -1, -1, -1}, {33270, -1, -1, -1}, {33271, -1, -1, -1}, {33272, -1, -1, -1}, {33273, -1, -1, -1}, {33277, -1, -1, -1}, {33279, -1, -1, -1}, {33283, -1, -1, -1}, {33291, -1, -1, -1}, {33294, -1, -1, -1}, {33295, -1, -1, -1}, {33297, -1, -1, -1}, {33299, -1, -1, -1}, {33301, -1, -1, -1}, {33302, -1, -1, -1}, {33303, -1, -1, -1}, {33304, -1, -1, -1}, {33305, -1, -1, -1}, {33306, -1, -1, -1}, {33309, -1, -1, -1}, {33312, -1, -1, -1}, {33316, -1, -1, -1}, {33317, -1, -1, -1}, {33318, -1, -1, -1}, {33319, -1, -1, -1}, {33321, -1, -1, -1}, {33326, -1, -1, -1}, {33330, -1, -1, -1}, {33338, -1, -1, -1}, {33340, -1, -1, -1}, {33341, -1, -1, -1}, {33343, -1, -1, -1}, {33344, -1, -1, -1}, {33345, -1, -1, -1}, {33346, -1, -1, -1}, {33347, -1, -1, -1}, {33349, -1, -1, -1}, {33350, -1, -1, -1}, {33352, -1, -1, -1}, {33354, -1, -1, -1}, {33356, -1, -1, -1}, {33357, -1, -1, -1}, {33358, -1, -1, -1}, {33360, -1, -1, -1}, {33361, -1, -1, -1}, {33362, -1, -1, -1}, {33363, -1, -1, -1}, {33364, -1, -1, -1}, {33365, -1, -1, -1}, {33366, -1, -1, -1}, {33367, -1, -1, -1}, {33371, -1, -1, -1}, {33372, -1, -1, -1}, {33373, -1, -1, -1}, {33374, -1, -1, -1}, {33376, -1, -1, -1}, {33377, -1, -1, -1}, {33378, -1, -1, -1}, {33379, -1, -1, -1}, {33381, -1, -1, -1}, {33383, -1, -1, -1}, {33385, -1, -1, -1}, {33386, -1, -1, -1}, {33388, -1, -1, -1}, {33389, -1, -1, -1}, {33397, -1, -1, -1}, {33398, -1, -1, -1}, {12171, 33400, -1, -1}, {33403, -1, -1, -1}, {33404, -1, -1, -1}, {33408, -1, -1, -1}, {33409, -1, -1, -1}, {33411, -1, -1, -1}, {33413, -1, -1, -1}, {33414, -1, -1, -1}, {33415, -1, -1, -1}, {33417, -1, -1, -1}, {33420, -1, -1, -1}, {33424, -1, -1, -1}, {33427, -1, -1, -1}, {33428, -1, -1, -1}, {33429, -1, -1, -1}, {33430, -1, -1, -1}, {33434, -1, -1, -1}, {33435, -1, -1, -1}, {33438, -1, -1, -1}, {33440, -1, -1, -1}, {33442, -1, -1, -1}, {33443, -1, -1, -1}, {33447, -1, -1, -1}, {33458, -1, -1, -1}, {33461, -1, -1, -1}, {33462, -1, -1, -1}, {33466, -1, -1, -1}, {33468, -1, -1, -1}, {33471, -1, -1, -1}, {33472, -1, -1, -1}, {33474, -1, -1, -1}, {33475, -1, -1, -1}, {33477, -1, -1, -1}, {33478, -1, -1, -1}, {33481, -1, -1, -1}, {33488, -1, -1, -1}, {33494, -1, -1, -1}, {33497, -1, -1, -1}, {33498, -1, -1, -1}, {33501, -1, -1, -1}, {33506, -1, -1, -1}, {33512, -1, -1, -1}, {33513, -1, -1, -1}, {33514, -1, -1, -1}, {33516, -1, -1, -1}, {33517, -1, -1, -1}, {33518, -1, -1, -1}, {33520, -1, -1, -1}, {33522, -1, -1, -1}, {33523, -1, -1, -1}, {33525, -1, -1, -1}, {33526, -1, -1, -1}, {33528, -1, -1, -1}, {33530, -1, -1, -1}, {33532, -1, -1, -1}, {33533, -1, -1, -1}, {33534, -1, -1, -1}, {33535, -1, -1, -1}, {33536, -1, -1, -1}, {33546, -1, -1, -1}, {33547, -1, -1, -1}, {33549, -1, -1, -1}, {33552, -1, -1, -1}, {33554, -1, -1, -1}, {33555, -1, -1, -1}, {33558, -1, -1, -1}, {33560, -1, -1, -1}, {33561, -1, -1, -1}, {33565, -1, -1, -1}, {33566, -1, -1, -1}, {33567, -1, -1, -1}, {33568, -1, -1, -1}, {33569, -1, -1, -1}, {33570, -1, -1, -1}, {33571, -1, -1, -1}, {33572, -1, -1, -1}, {33573, -1, -1, -1}, {33574, -1, -1, -1}, {33577, -1, -1, -1}, {33578, -1, -1, -1}, {33582, -1, -1, -1}, {33584, -1, -1, -1}, {33586, -1, -1, -1}, {33591, -1, -1, -1}, {33595, -1, -1, -1}, {33597, -1, -1, -1}, {33598, -1, -1, -1}, {33599, -1, -1, -1}, {33601, -1, -1, -1}, {33602, -1, -1, -1}, {33604, -1, -1, -1}, {33605, -1, -1, -1}, {33608, -1, -1, -1}, {33610, -1, -1, -1} },
+ {{33611, -1, -1, -1}, {33612, -1, -1, -1}, {33613, -1, -1, -1}, {33614, -1, -1, -1}, {33619, -1, -1, -1}, {33621, -1, -1, -1}, {33622, -1, -1, -1}, {33623, -1, -1, -1}, {33624, -1, -1, -1}, {33625, -1, -1, -1}, {33629, -1, -1, -1}, {33634, -1, -1, -1}, {33648, -1, -1, -1}, {33649, -1, -1, -1}, {33650, -1, -1, -1}, {33651, -1, -1, -1}, {33652, -1, -1, -1}, {33653, -1, -1, -1}, {33654, -1, -1, -1}, {33657, -1, -1, -1}, {33658, -1, -1, -1}, {33662, -1, -1, -1}, {33663, -1, -1, -1}, {33664, -1, -1, -1}, {33665, -1, -1, -1}, {33666, -1, -1, -1}, {33667, -1, -1, -1}, {33668, -1, -1, -1}, {33671, -1, -1, -1}, {33672, -1, -1, -1}, {33675, -1, -1, -1}, {33676, -1, -1, -1}, {33677, -1, -1, -1}, {33679, -1, -1, -1}, {33680, -1, -1, -1}, {33681, -1, -1, -1}, {33684, -1, -1, -1}, {33685, -1, -1, -1}, {33687, -1, -1, -1}, {33689, -1, -1, -1}, {33690, -1, -1, -1}, {33693, -1, -1, -1}, {33695, -1, -1, -1}, {33697, -1, -1, -1}, {33699, -1, -1, -1}, {33700, -1, -1, -1}, {33701, -1, -1, -1}, {33702, -1, -1, -1}, {33708, -1, -1, -1}, {33709, -1, -1, -1}, {33710, -1, -1, -1}, {33711, -1, -1, -1}, {33717, -1, -1, -1}, {33723, -1, -1, -1}, {33726, -1, -1, -1}, {33727, -1, -1, -1}, {33730, -1, -1, -1}, {33731, -1, -1, -1}, {33732, -1, -1, -1}, {33734, -1, -1, -1}, {33736, -1, -1, -1}, {33737, -1, -1, -1}, {33739, -1, -1, -1}, {33741, -1, -1, -1}, {33742, -1, -1, -1}, {33744, -1, -1, -1}, {33745, -1, -1, -1}, {33746, -1, -1, -1}, {33747, -1, -1, -1}, {33749, -1, -1, -1}, {33751, -1, -1, -1}, {33753, -1, -1, -1}, {33754, -1, -1, -1}, {33755, -1, -1, -1}, {33758, -1, -1, -1}, {33762, -1, -1, -1}, {33763, -1, -1, -1}, {33764, -1, -1, -1}, {33766, -1, -1, -1}, {33767, -1, -1, -1}, {33768, -1, -1, -1}, {33771, -1, -1, -1}, {33772, -1, -1, -1}, {33773, -1, -1, -1}, {33774, -1, -1, -1}, {33779, -1, -1, -1}, {33780, -1, -1, -1}, {33781, -1, -1, -1}, {33782, -1, -1, -1}, {33783, -1, -1, -1}, {33786, -1, -1, -1}, {33787, -1, -1, -1}, {33788, -1, -1, -1}, {33790, -1, -1, -1}, {33791, -1, -1, -1}, {33792, -1, -1, -1}, {33794, -1, -1, -1}, {33797, -1, -1, -1}, {33800, -1, -1, -1}, {33801, -1, -1, -1}, {33808, -1, -1, -1}, {33810, -1, -1, -1}, {33811, -1, -1, -1}, {33812, -1, -1, -1}, {33813, -1, -1, -1}, {33814, -1, -1, -1}, {33815, -1, -1, -1}, {33817, -1, -1, -1}, {33818, -1, -1, -1}, {33819, -1, -1, -1}, {33822, -1, -1, -1}, {33823, -1, -1, -1}, {33824, -1, -1, -1}, {33825, -1, -1, -1}, {33826, -1, -1, -1}, {33827, -1, -1, -1}, {33833, -1, -1, -1}, {33834, -1, -1, -1}, {33835, -1, -1, -1}, {33837, -1, -1, -1}, {33838, -1, -1, -1}, {33839, -1, -1, -1}, {33840, -1, -1, -1}, {33842, -1, -1, -1}, {33843, -1, -1, -1}, {33844, -1, -1, -1}, {33846, -1, -1, -1}, {33847, -1, -1, -1}, {33849, -1, -1, -1}, {33850, -1, -1, -1}, {33851, -1, -1, -1}, {33854, -1, -1, -1}, {33855, -1, -1, -1}, {33856, -1, -1, -1}, {33857, -1, -1, -1}, {33858, -1, -1, -1}, {33859, -1, -1, -1}, {33860, -1, -1, -1}, {33861, -1, -1, -1}, {33863, -1, -1, -1}, {33864, -1, -1, -1}, {33866, -1, -1, -1}, {33867, -1, -1, -1}, {33868, -1, -1, -1}, {33869, -1, -1, -1}, {33870, -1, -1, -1}, {33871, -1, -1, -1}, {33872, -1, -1, -1}, {33875, -1, -1, -1}, {33876, -1, -1, -1}, {33877, -1, -1, -1}, {33878, -1, -1, -1}, {33880, -1, -1, -1}, {33885, -1, -1, -1}, {33886, -1, -1, -1}, {33887, -1, -1, -1}, {33888, -1, -1, -1}, {33890, -1, -1, -1}, {33893, -1, -1, -1}, {33895, -1, -1, -1}, {33896, -1, -1, -1}, {33898, -1, -1, -1}, {33902, -1, -1, -1}, {33904, -1, -1, -1}, {33906, -1, -1, -1}, {33908, -1, -1, -1}, {33913, -1, -1, -1}, {33915, -1, -1, -1}, {33916, -1, -1, -1}, {33917, -1, -1, -1}, {33918, -1, -1, -1}, {33919, -1, -1, -1}, {33920, -1, -1, -1}, {33921, -1, -1, -1}, {33923, -1, -1, -1}, {33924, -1, -1, -1}, {33925, -1, -1, -1}, {33926, -1, -1, -1}, {33930, -1, -1, -1}, {33933, -1, -1, -1}, {33935, -1, -1, -1}, {33936, -1, -1, -1}, {33937, -1, -1, -1}, {33938, -1, -1, -1}, {33941, -1, -1, -1}, {33942, -1, -1, -1}, {33944, -1, -1, -1}, {33946, -1, -1, -1}, {33947, -1, -1, -1}, {33949, -1, -1, -1}, {33950, -1, -1, -1}, {33951, -1, -1, -1}, {33952, -1, -1, -1}, {33954, -1, -1, -1}, {33955, -1, -1, -1}, {33956, -1, -1, -1}, {33957, -1, -1, -1}, {33958, -1, -1, -1}, {33959, -1, -1, -1}, {33960, -1, -1, -1}, {33961, -1, -1, -1}, {33962, -1, -1, -1}, {33963, -1, -1, -1}, {33964, -1, -1, -1}, {33965, -1, -1, -1}, {33966, -1, -1, -1}, {33968, -1, -1, -1}, {33969, -1, -1, -1}, {33971, -1, -1, -1}, {33973, -1, -1, -1}, {33974, -1, -1, -1}, {33975, -1, -1, -1}, {33979, -1, -1, -1}, {33982, -1, -1, -1}, {33986, -1, -1, -1}, {33987, -1, -1, -1}, {33989, -1, -1, -1}, {33990, -1, -1, -1}, {33991, -1, -1, -1}, {33992, -1, -1, -1}, {33996, -1, -1, -1}, {33998, -1, -1, -1}, {33999, -1, -1, -1}, {34002, -1, -1, -1}, {34004, -1, -1, -1}, {34005, -1, -1, -1}, {34007, -1, -1, -1}, {34008, -1, -1, -1}, {34009, -1, -1, -1}, {34010, -1, -1, -1}, {34011, -1, -1, -1}, {34012, -1, -1, -1}, {34014, -1, -1, -1}, {34017, -1, -1, -1}, {34018, -1, -1, -1}, {34020, -1, -1, -1}, {34023, -1, -1, -1}, {34024, -1, -1, -1}, {34025, -1, -1, -1}, {34026, -1, -1, -1}, {34027, -1, -1, -1}, {34029, -1, -1, -1}, {34033, -1, -1, -1}, {34034, -1, -1, -1}, {34035, -1, -1, -1}, {34036, -1, -1, -1}, {34037, -1, -1, -1}, {34038, -1, -1, -1}, {34039, -1, -1, -1}, {34040, -1, -1, -1}, {34041, -1, -1, -1}, {34042, -1, -1, -1}, {34043, -1, -1, -1}, {34046, -1, -1, -1}, {34048, -1, -1, -1}, {34049, -1, -1, -1} },
+ {{34050, -1, -1, -1}, {34051, -1, -1, -1}, {34052, -1, -1, -1}, {34053, -1, -1, -1}, {34054, -1, -1, -1}, {34055, -1, -1, -1}, {34056, -1, -1, -1}, {34057, -1, -1, -1}, {34058, -1, -1, -1}, {34059, -1, -1, -1}, {34061, -1, -1, -1}, {34062, -1, -1, -1}, {34063, -1, -1, -1}, {34064, -1, -1, -1}, {34066, -1, -1, -1}, {34069, -1, -1, -1}, {34070, -1, -1, -1}, {34072, -1, -1, -1}, {34073, -1, -1, -1}, {34075, -1, -1, -1}, {34076, -1, -1, -1}, {34077, -1, -1, -1}, {34080, -1, -1, -1}, {34082, -1, -1, -1}, {34084, -1, -1, -1}, {34085, -1, -1, -1}, {34087, -1, -1, -1}, {34088, -1, -1, -1}, {34089, -1, -1, -1}, {34090, -1, -1, -1}, {34094, -1, -1, -1}, {34095, -1, -1, -1}, {34096, -1, -1, -1}, {34097, -1, -1, -1}, {34098, -1, -1, -1}, {34099, -1, -1, -1}, {34100, -1, -1, -1}, {34101, -1, -1, -1}, {34102, -1, -1, -1}, {34110, -1, -1, -1}, {34111, -1, -1, -1}, {34112, -1, -1, -1}, {34114, -1, -1, -1}, {34116, -1, -1, -1}, {34117, -1, -1, -1}, {34119, -1, -1, -1}, {34123, -1, -1, -1}, {34124, -1, -1, -1}, {34125, -1, -1, -1}, {34127, -1, -1, -1}, {34128, -1, -1, -1}, {34129, -1, -1, -1}, {34132, -1, -1, -1}, {34135, -1, -1, -1}, {34138, -1, -1, -1}, {34139, -1, -1, -1}, {34140, -1, -1, -1}, {34141, -1, -1, -1}, {34143, -1, -1, -1}, {34144, -1, -1, -1}, {34145, -1, -1, -1}, {34147, -1, -1, -1}, {34149, -1, -1, -1}, {34150, -1, -1, -1}, {34151, -1, -1, -1}, {34155, -1, -1, -1}, {34156, -1, -1, -1}, {34158, -1, -1, -1}, {34159, -1, -1, -1}, {34160, -1, -1, -1}, {34161, -1, -1, -1}, {34163, -1, -1, -1}, {34165, -1, -1, -1}, {34166, -1, -1, -1}, {34168, -1, -1, -1}, {34172, -1, -1, -1}, {34173, -1, -1, -1}, {34175, -1, -1, -1}, {34176, -1, -1, -1}, {34177, -1, -1, -1}, {34178, -1, -1, -1}, {34179, -1, -1, -1}, {34182, -1, -1, -1}, {34185, -1, -1, -1}, {34187, -1, -1, -1}, {34189, -1, -1, -1}, {34190, -1, -1, -1}, {34192, -1, -1, -1}, {34194, -1, -1, -1}, {34195, -1, -1, -1}, {34197, -1, -1, -1}, {34198, -1, -1, -1}, {34199, -1, -1, -1}, {34200, -1, -1, -1}, {34201, -1, -1, -1}, {34202, -1, -1, -1}, {34205, -1, -1, -1}, {34206, -1, -1, -1}, {34208, -1, -1, -1}, {34209, -1, -1, -1}, {34210, -1, -1, -1}, {34211, -1, -1, -1}, {34213, -1, -1, -1}, {34215, -1, -1, -1}, {34219, -1, -1, -1}, {34220, -1, -1, -1}, {34221, -1, -1, -1}, {34225, -1, -1, -1}, {34226, -1, -1, -1}, {34227, -1, -1, -1}, {34228, -1, -1, -1}, {34229, -1, -1, -1}, {34230, -1, -1, -1}, {34232, -1, -1, -1}, {34235, -1, -1, -1}, {34236, -1, -1, -1}, {34237, -1, -1, -1}, {34238, -1, -1, -1}, {34239, -1, -1, -1}, {34240, -1, -1, -1}, {34242, -1, -1, -1}, {34243, -1, -1, -1}, {34244, -1, -1, -1}, {34245, -1, -1, -1}, {34246, -1, -1, -1}, {34247, -1, -1, -1}, {34248, -1, -1, -1}, {34250, -1, -1, -1}, {34251, -1, -1, -1}, {34252, -1, -1, -1}, {34257, -1, -1, -1}, {34258, -1, -1, -1}, {34260, -1, -1, -1}, {34262, -1, -1, -1}, {34263, -1, -1, -1}, {34264, -1, -1, -1}, {34265, -1, -1, -1}, {34266, -1, -1, -1}, {34267, -1, -1, -1}, {34270, -1, -1, -1}, {34271, -1, -1, -1}, {34272, -1, -1, -1}, {34273, -1, -1, -1}, {34274, -1, -1, -1}, {34275, -1, -1, -1}, {34278, -1, -1, -1}, {34279, -1, -1, -1}, {34280, -1, -1, -1}, {34283, -1, -1, -1}, {34284, -1, -1, -1}, {34285, -1, -1, -1}, {34286, -1, -1, -1}, {34287, -1, -1, -1}, {34288, -1, -1, -1}, {34289, -1, -1, -1}, {34290, -1, -1, -1}, {34291, -1, -1, -1}, {34293, -1, -1, -1}, {34295, -1, -1, -1}, {34296, -1, -1, -1}, {34300, -1, -1, -1}, {34301, -1, -1, -1}, {34302, -1, -1, -1}, {34304, -1, -1, -1}, {34305, -1, -1, -1}, {34306, -1, -1, -1}, {34307, -1, -1, -1}, {34312, -1, -1, -1}, {34313, -1, -1, -1}, {34314, -1, -1, -1}, {34316, -1, -1, -1}, {34317, -1, -1, -1}, {34318, -1, -1, -1}, {34319, -1, -1, -1}, {34320, -1, -1, -1}, {34322, -1, -1, -1}, {34323, -1, -1, -1}, {34324, -1, -1, -1}, {34325, -1, -1, -1}, {34327, -1, -1, -1}, {34328, -1, -1, -1}, {34329, -1, -1, -1}, {34331, -1, -1, -1}, {34332, -1, -1, -1}, {34333, -1, -1, -1}, {34335, -1, -1, -1}, {34336, -1, -1, -1}, {34337, -1, -1, -1}, {34339, -1, -1, -1}, {34340, -1, -1, -1}, {34341, -1, -1, -1}, {34342, -1, -1, -1}, {34344, -1, -1, -1}, {34346, -1, -1, -1}, {34347, -1, -1, -1}, {34348, -1, -1, -1}, {34350, -1, -1, -1}, {34351, -1, -1, -1}, {34352, -1, -1, -1}, {34353, -1, -1, -1}, {34354, -1, -1, -1}, {34355, -1, -1, -1}, {34356, -1, -1, -1}, {34357, -1, -1, -1}, {34358, -1, -1, -1}, {34359, -1, -1, -1}, {34361, -1, -1, -1}, {34363, -1, -1, -1}, {34365, -1, -1, -1}, {34366, -1, -1, -1}, {34368, -1, -1, -1}, {34369, -1, -1, -1}, {34370, -1, -1, -1}, {34371, -1, -1, -1}, {34372, -1, -1, -1}, {34373, -1, -1, -1}, {34374, -1, -1, -1}, {34375, -1, -1, -1}, {34376, -1, -1, -1}, {34377, -1, -1, -1}, {34378, -1, -1, -1}, {34379, -1, -1, -1}, {34380, -1, -1, -1}, {34386, -1, -1, -1}, {34387, -1, -1, -1}, {34390, -1, -1, -1}, {34391, -1, -1, -1}, {34392, -1, -1, -1}, {34393, -1, -1, -1}, {34395, -1, -1, -1}, {34397, -1, -1, -1}, {34400, -1, -1, -1}, {34401, -1, -1, -1}, {34403, -1, -1, -1}, {34404, -1, -1, -1}, {34405, -1, -1, -1}, {34406, -1, -1, -1}, {34408, -1, -1, -1}, {34409, -1, -1, -1}, {34410, -1, -1, -1}, {34413, -1, -1, -1}, {34415, -1, -1, -1}, {34416, -1, -1, -1}, {34418, -1, -1, -1}, {34419, -1, -1, -1}, {34420, -1, -1, -1}, {34421, -1, -1, -1}, {34422, -1, -1, -1}, {34423, -1, -1, -1}, {34424, -1, -1, -1}, {34435, -1, -1, -1}, {34436, -1, -1, -1}, {34437, -1, -1, -1}, {34438, -1, -1, -1}, {34439, -1, -1, -1}, {34440, -1, -1, -1} },
+ {{34441, -1, -1, -1}, {34446, -1, -1, -1}, {34447, -1, -1, -1}, {34448, -1, -1, -1}, {34449, -1, -1, -1}, {34450, -1, -1, -1}, {34452, -1, -1, -1}, {34454, -1, -1, -1}, {34455, -1, -1, -1}, {34456, -1, -1, -1}, {34457, -1, -1, -1}, {34458, -1, -1, -1}, {34459, -1, -1, -1}, {34462, -1, -1, -1}, {34463, -1, -1, -1}, {34464, -1, -1, -1}, {34465, -1, -1, -1}, {34466, -1, -1, -1}, {34469, -1, -1, -1}, {34470, -1, -1, -1}, {34475, -1, -1, -1}, {34477, -1, -1, -1}, {34478, -1, -1, -1}, {34482, -1, -1, -1}, {34483, -1, -1, -1}, {34487, -1, -1, -1}, {34488, -1, -1, -1}, {34489, -1, -1, -1}, {34491, -1, -1, -1}, {34492, -1, -1, -1}, {34493, -1, -1, -1}, {34494, -1, -1, -1}, {34495, -1, -1, -1}, {34497, -1, -1, -1}, {34498, -1, -1, -1}, {34499, -1, -1, -1}, {34501, -1, -1, -1}, {34504, -1, -1, -1}, {34508, -1, -1, -1}, {34509, -1, -1, -1}, {34514, -1, -1, -1}, {34515, -1, -1, -1}, {34517, -1, -1, -1}, {34518, -1, -1, -1}, {34519, -1, -1, -1}, {34522, -1, -1, -1}, {34524, -1, -1, -1}, {34525, -1, -1, -1}, {34528, -1, -1, -1}, {34529, -1, -1, -1}, {34530, -1, -1, -1}, {34531, -1, -1, -1}, {34533, -1, -1, -1}, {34534, -1, -1, -1}, {34535, -1, -1, -1}, {34536, -1, -1, -1}, {34538, -1, -1, -1}, {34539, -1, -1, -1}, {34540, -1, -1, -1}, {34543, -1, -1, -1}, {34549, -1, -1, -1}, {34550, -1, -1, -1}, {34551, -1, -1, -1}, {34555, -1, -1, -1}, {34556, -1, -1, -1}, {34557, -1, -1, -1}, {34559, -1, -1, -1}, {34561, -1, -1, -1}, {34564, -1, -1, -1}, {34565, -1, -1, -1}, {34571, -1, -1, -1}, {34572, -1, -1, -1}, {34574, -1, -1, -1}, {34575, -1, -1, -1}, {34576, -1, -1, -1}, {34577, -1, -1, -1}, {34580, -1, -1, -1}, {34582, -1, -1, -1}, {34585, -1, -1, -1}, {34587, -1, -1, -1}, {34589, -1, -1, -1}, {34591, -1, -1, -1}, {34592, -1, -1, -1}, {34596, -1, -1, -1}, {34598, -1, -1, -1}, {34599, -1, -1, -1}, {34600, -1, -1, -1}, {34602, -1, -1, -1}, {34603, -1, -1, -1}, {34604, -1, -1, -1}, {34605, -1, -1, -1}, {34607, -1, -1, -1}, {34608, -1, -1, -1}, {34610, -1, -1, -1}, {34611, -1, -1, -1}, {34613, -1, -1, -1}, {34614, -1, -1, -1}, {34616, -1, -1, -1}, {34617, -1, -1, -1}, {34618, -1, -1, -1}, {34620, -1, -1, -1}, {34621, -1, -1, -1}, {34624, -1, -1, -1}, {34625, -1, -1, -1}, {34626, -1, -1, -1}, {34627, -1, -1, -1}, {34628, -1, -1, -1}, {34629, -1, -1, -1}, {34630, -1, -1, -1}, {34634, -1, -1, -1}, {34635, -1, -1, -1}, {34637, -1, -1, -1}, {34639, -1, -1, -1}, {34640, -1, -1, -1}, {34641, -1, -1, -1}, {34642, -1, -1, -1}, {34644, -1, -1, -1}, {34646, -1, -1, -1}, {34648, -1, -1, -1}, {34650, -1, -1, -1}, {34651, -1, -1, -1}, {34652, -1, -1, -1}, {34653, -1, -1, -1}, {34654, -1, -1, -1}, {34655, -1, -1, -1}, {34657, -1, -1, -1}, {34658, -1, -1, -1}, {34663, -1, -1, -1}, {34664, -1, -1, -1}, {34665, -1, -1, -1}, {34666, -1, -1, -1}, {34667, -1, -1, -1}, {34668, -1, -1, -1}, {34669, -1, -1, -1}, {34671, -1, -1, -1}, {34673, -1, -1, -1}, {34674, -1, -1, -1}, {34675, -1, -1, -1}, {34677, -1, -1, -1}, {34679, -1, -1, -1}, {34681, -1, -1, -1}, {34682, -1, -1, -1}, {34687, -1, -1, -1}, {34688, -1, -1, -1}, {34689, -1, -1, -1}, {34694, -1, -1, -1}, {34695, -1, -1, -1}, {34697, -1, -1, -1}, {34698, -1, -1, -1}, {34700, -1, -1, -1}, {34702, -1, -1, -1}, {34703, -1, -1, -1}, {34704, -1, -1, -1}, {34705, -1, -1, -1}, {34706, -1, -1, -1}, {34708, -1, -1, -1}, {34709, -1, -1, -1}, {34710, -1, -1, -1}, {34712, -1, -1, -1}, {34713, -1, -1, -1}, {34714, -1, -1, -1}, {34715, -1, -1, -1}, {34716, -1, -1, -1}, {34717, -1, -1, -1}, {34720, -1, -1, -1}, {34721, -1, -1, -1}, {34723, -1, -1, -1}, {34724, -1, -1, -1}, {34725, -1, -1, -1}, {34726, -1, -1, -1}, {34727, -1, -1, -1}, {34729, -1, -1, -1}, {34730, -1, -1, -1}, {34734, -1, -1, -1}, {34736, -1, -1, -1}, {34737, -1, -1, -1}, {34738, -1, -1, -1}, {34740, -1, -1, -1}, {34742, -1, -1, -1}, {34743, -1, -1, -1}, {34744, -1, -1, -1}, {34745, -1, -1, -1}, {34748, -1, -1, -1}, {34750, -1, -1, -1}, {34751, -1, -1, -1}, {34753, -1, -1, -1}, {34754, -1, -1, -1}, {34755, -1, -1, -1}, {34757, -1, -1, -1}, {34759, -1, -1, -1}, {34761, -1, -1, -1}, {34764, -1, -1, -1}, {34765, -1, -1, -1}, {34767, -1, -1, -1}, {34768, -1, -1, -1}, {34772, -1, -1, -1}, {34773, -1, -1, -1}, {34774, -1, -1, -1}, {34775, -1, -1, -1}, {34776, -1, -1, -1}, {34777, -1, -1, -1}, {34778, -1, -1, -1}, {34780, -1, -1, -1}, {34781, -1, -1, -1}, {34782, -1, -1, -1}, {34783, -1, -1, -1}, {34785, -1, -1, -1}, {34786, -1, -1, -1}, {34788, -1, -1, -1}, {34790, -1, -1, -1}, {34791, -1, -1, -1}, {34792, -1, -1, -1}, {34793, -1, -1, -1}, {34795, -1, -1, -1}, {34797, -1, -1, -1}, {34800, -1, -1, -1}, {34801, -1, -1, -1}, {34803, -1, -1, -1}, {34804, -1, -1, -1}, {34805, -1, -1, -1}, {34807, -1, -1, -1}, {34808, -1, -1, -1}, {34810, -1, -1, -1}, {34812, -1, -1, -1}, {34813, -1, -1, -1}, {34815, -1, -1, -1}, {34816, -1, -1, -1}, {34817, -1, -1, -1}, {34818, -1, -1, -1}, {34820, -1, -1, -1}, {34823, -1, -1, -1}, {34824, -1, -1, -1}, {34825, -1, -1, -1}, {34827, -1, -1, -1}, {34828, -1, -1, -1}, {34829, -1, -1, -1}, {34830, -1, -1, -1}, {34831, -1, -1, -1}, {34834, -1, -1, -1}, {34836, -1, -1, -1}, {34839, -1, -1, -1}, {34840, -1, -1, -1}, {34841, -1, -1, -1}, {34842, -1, -1, -1}, {34844, -1, -1, -1}, {34845, -1, -1, -1}, {34846, -1, -1, -1}, {34848, -1, -1, -1}, {34852, -1, -1, -1}, {34853, -1, -1, -1}, {34854, -1, -1, -1}, {34855, -1, -1, -1}, {34856, -1, -1, -1}, {34857, -1, -1, -1}, {34858, -1, -1, -1}, {34859, -1, -1, -1} },
+ {{34860, -1, -1, -1}, {34861, -1, -1, -1}, {34862, -1, -1, -1}, {34863, -1, -1, -1}, {34864, -1, -1, -1}, {34867, -1, -1, -1}, {34868, -1, -1, -1}, {34869, -1, -1, -1}, {34871, -1, -1, -1}, {34872, -1, -1, -1}, {34874, -1, -1, -1}, {34877, -1, -1, -1}, {34878, -1, -1, -1}, {34879, -1, -1, -1}, {34881, -1, -1, -1}, {34882, -1, -1, -1}, {34883, -1, -1, -1}, {34887, -1, -1, -1}, {34888, -1, -1, -1}, {34889, -1, -1, -1}, {34891, -1, -1, -1}, {34894, -1, -1, -1}, {34895, -1, -1, -1}, {34896, -1, -1, -1}, {34897, -1, -1, -1}, {34898, -1, -1, -1}, {34901, -1, -1, -1}, {34902, -1, -1, -1}, {34904, -1, -1, -1}, {34906, -1, -1, -1}, {34908, -1, -1, -1}, {34910, -1, -1, -1}, {34911, -1, -1, -1}, {34912, -1, -1, -1}, {34918, -1, -1, -1}, {34919, -1, -1, -1}, {34922, -1, -1, -1}, {34925, -1, -1, -1}, {34927, -1, -1, -1}, {34929, -1, -1, -1}, {34931, -1, -1, -1}, {34932, -1, -1, -1}, {34933, -1, -1, -1}, {34934, -1, -1, -1}, {34936, -1, -1, -1}, {34938, -1, -1, -1}, {34939, -1, -1, -1}, {34940, -1, -1, -1}, {34944, -1, -1, -1}, {34947, -1, -1, -1}, {34950, -1, -1, -1}, {34951, -1, -1, -1}, {34953, -1, -1, -1}, {34954, -1, -1, -1}, {34956, -1, -1, -1}, {34958, -1, -1, -1}, {34959, -1, -1, -1}, {34960, -1, -1, -1}, {34961, -1, -1, -1}, {34963, -1, -1, -1}, {34964, -1, -1, -1}, {34965, -1, -1, -1}, {34967, -1, -1, -1}, {34968, -1, -1, -1}, {34969, -1, -1, -1}, {34970, -1, -1, -1}, {34971, -1, -1, -1}, {34973, -1, -1, -1}, {34974, -1, -1, -1}, {34975, -1, -1, -1}, {34976, -1, -1, -1}, {34977, -1, -1, -1}, {34979, -1, -1, -1}, {34981, -1, -1, -1}, {34982, -1, -1, -1}, {34983, -1, -1, -1}, {34984, -1, -1, -1}, {34985, -1, -1, -1}, {34986, -1, -1, -1}, {34988, -1, -1, -1}, {34990, -1, -1, -1}, {34991, -1, -1, -1}, {34992, -1, -1, -1}, {34994, -1, -1, -1}, {34995, -1, -1, -1}, {34996, -1, -1, -1}, {34997, -1, -1, -1}, {34998, -1, -1, -1}, {35000, -1, -1, -1}, {35001, -1, -1, -1}, {35002, -1, -1, -1}, {35003, -1, -1, -1}, {35005, -1, -1, -1}, {35006, -1, -1, -1}, {35007, -1, -1, -1}, {35008, -1, -1, -1}, {35011, -1, -1, -1}, {35012, -1, -1, -1}, {35015, -1, -1, -1}, {35016, -1, -1, -1}, {35019, -1, -1, -1}, {35020, -1, -1, -1}, {35021, -1, -1, -1}, {35024, -1, -1, -1}, {35025, -1, -1, -1}, {35027, -1, -1, -1}, {35030, -1, -1, -1}, {35031, -1, -1, -1}, {35034, -1, -1, -1}, {35035, -1, -1, -1}, {35038, -1, -1, -1}, {35040, -1, -1, -1}, {35041, -1, -1, -1}, {35046, -1, -1, -1}, {35047, -1, -1, -1}, {35049, -1, -1, -1}, {35050, -1, -1, -1}, {35051, -1, -1, -1}, {35052, -1, -1, -1}, {35053, -1, -1, -1}, {35054, -1, -1, -1}, {35055, -1, -1, -1}, {35058, -1, -1, -1}, {35061, -1, -1, -1}, {35062, -1, -1, -1}, {35063, -1, -1, -1}, {35066, -1, -1, -1}, {35067, -1, -1, -1}, {35071, -1, -1, -1}, {35072, -1, -1, -1}, {35073, -1, -1, -1}, {35075, -1, -1, -1}, {35076, -1, -1, -1}, {35077, -1, -1, -1}, {35078, -1, -1, -1}, {35080, -1, -1, -1}, {35081, -1, -1, -1}, {35083, -1, -1, -1}, {35084, -1, -1, -1}, {35085, -1, -1, -1}, {35086, -1, -1, -1}, {35087, -1, -1, -1}, {35089, -1, -1, -1}, {35092, -1, -1, -1}, {35093, -1, -1, -1}, {35094, -1, -1, -1}, {35095, -1, -1, -1}, {35096, -1, -1, -1}, {35100, -1, -1, -1}, {35101, -1, -1, -1}, {35102, -1, -1, -1}, {35103, -1, -1, -1}, {35104, -1, -1, -1}, {35106, -1, -1, -1}, {35107, -1, -1, -1}, {35108, -1, -1, -1}, {35110, -1, -1, -1}, {35111, -1, -1, -1}, {35112, -1, -1, -1}, {35113, -1, -1, -1}, {35116, -1, -1, -1}, {35117, -1, -1, -1}, {35118, -1, -1, -1}, {35119, -1, -1, -1}, {35121, -1, -1, -1}, {35125, -1, -1, -1}, {35127, -1, -1, -1}, {35129, -1, -1, -1}, {35130, -1, -1, -1}, {35132, -1, -1, -1}, {35133, -1, -1, -1}, {35134, -1, -1, -1}, {35135, -1, -1, -1}, {35136, -1, -1, -1}, {35138, -1, -1, -1}, {35139, -1, -1, -1}, {35141, -1, -1, -1}, {35142, -1, -1, -1}, {35144, -1, -1, -1}, {35145, -1, -1, -1}, {35146, -1, -1, -1}, {35147, -1, -1, -1}, {35148, -1, -1, -1}, {35149, -1, -1, -1}, {35150, -1, -1, -1}, {35151, -1, -1, -1}, {35152, -1, -1, -1}, {35153, -1, -1, -1}, {35154, -1, -1, -1}, {35155, -1, -1, -1}, {35156, -1, -1, -1}, {35157, -1, -1, -1}, {35159, -1, -1, -1}, {35160, -1, -1, -1}, {35161, -1, -1, -1}, {35162, -1, -1, -1}, {35163, -1, -1, -1}, {35164, -1, -1, -1}, {35169, -1, -1, -1}, {35170, -1, -1, -1}, {35171, -1, -1, -1}, {35173, -1, -1, -1}, {35175, -1, -1, -1}, {35176, -1, -1, -1}, {35177, -1, -1, -1}, {35179, -1, -1, -1}, {35181, -1, -1, -1}, {35182, -1, -1, -1}, {35184, -1, -1, -1}, {35185, -1, -1, -1}, {35187, -1, -1, -1}, {35188, -1, -1, -1}, {35189, -1, -1, -1}, {35190, -1, -1, -1}, {35191, -1, -1, -1}, {35192, -1, -1, -1}, {35193, -1, -1, -1}, {35194, -1, -1, -1}, {35196, -1, -1, -1}, {35197, -1, -1, -1}, {12177, 35198, -1, -1}, {35200, -1, -1, -1}, {35202, -1, -1, -1}, {35204, -1, -1, -1}, {35205, -1, -1, -1}, {35207, -1, -1, -1}, {35208, -1, -1, -1}, {35209, -1, -1, -1}, {35210, -1, -1, -1}, {35212, -1, -1, -1}, {35213, -1, -1, -1}, {35214, -1, -1, -1}, {35216, -1, -1, -1}, {35217, -1, -1, -1}, {35218, -1, -1, -1}, {35220, -1, -1, -1}, {35221, -1, -1, -1}, {35223, -1, -1, -1}, {35225, -1, -1, -1}, {35226, -1, -1, -1}, {35227, -1, -1, -1}, {35228, -1, -1, -1}, {35229, -1, -1, -1}, {35230, -1, -1, -1}, {35231, -1, -1, -1}, {35232, -1, -1, -1}, {35234, -1, -1, -1}, {35235, -1, -1, -1}, {35236, -1, -1, -1}, {35237, -1, -1, -1}, {35239, -1, -1, -1}, {35240, -1, -1, -1}, {35241, -1, -1, -1}, {35243, -1, -1, -1}, {35245, -1, -1, -1}, {35246, -1, -1, -1} },
+ {{35248, -1, -1, -1}, {35249, -1, -1, -1}, {35251, -1, -1, -1}, {35252, -1, -1, -1}, {35253, -1, -1, -1}, {35254, -1, -1, -1}, {35256, -1, -1, -1}, {35257, -1, -1, -1}, {35259, -1, -1, -1}, {35260, -1, -1, -1}, {35262, -1, -1, -1}, {35267, -1, -1, -1}, {35277, -1, -1, -1}, {35283, -1, -1, -1}, {35284, -1, -1, -1}, {35285, -1, -1, -1}, {35287, -1, -1, -1}, {35288, -1, -1, -1}, {35289, -1, -1, -1}, {35291, -1, -1, -1}, {35293, -1, -1, -1}, {35295, -1, -1, -1}, {35296, -1, -1, -1}, {35297, -1, -1, -1}, {35298, -1, -1, -1}, {35300, -1, -1, -1}, {35303, -1, -1, -1}, {35304, -1, -1, -1}, {35305, -1, -1, -1}, {35306, -1, -1, -1}, {35308, -1, -1, -1}, {35309, -1, -1, -1}, {35310, -1, -1, -1}, {35312, -1, -1, -1}, {35313, -1, -1, -1}, {35314, -1, -1, -1}, {35317, -1, -1, -1}, {35319, -1, -1, -1}, {35321, -1, -1, -1}, {35322, -1, -1, -1}, {35323, -1, -1, -1}, {35324, -1, -1, -1}, {35325, -1, -1, -1}, {35326, -1, -1, -1}, {35327, -1, -1, -1}, {35332, -1, -1, -1}, {35333, -1, -1, -1}, {35334, -1, -1, -1}, {35337, -1, -1, -1}, {35339, -1, -1, -1}, {35341, -1, -1, -1}, {35343, -1, -1, -1}, {35345, -1, -1, -1}, {35346, -1, -1, -1}, {35348, -1, -1, -1}, {35351, -1, -1, -1}, {35353, -1, -1, -1}, {35354, -1, -1, -1}, {35356, -1, -1, -1}, {35358, -1, -1, -1}, {35360, -1, -1, -1}, {35361, -1, -1, -1}, {35362, -1, -1, -1}, {35364, -1, -1, -1}, {35366, -1, -1, -1}, {35367, -1, -1, -1}, {35368, -1, -1, -1}, {35369, -1, -1, -1}, {35371, -1, -1, -1}, {35372, -1, -1, -1}, {35374, -1, -1, -1}, {35375, -1, -1, -1}, {35376, -1, -1, -1}, {35378, -1, -1, -1}, {35379, -1, -1, -1}, {35381, -1, -1, -1}, {35383, -1, -1, -1}, {35384, -1, -1, -1}, {35385, -1, -1, -1}, {35387, -1, -1, -1}, {35388, -1, -1, -1}, {35389, -1, -1, -1}, {35391, -1, -1, -1}, {35392, -1, -1, -1}, {35394, -1, -1, -1}, {35395, -1, -1, -1}, {35396, -1, -1, -1}, {35397, -1, -1, -1}, {35399, -1, -1, -1}, {35401, -1, -1, -1}, {35402, -1, -1, -1}, {35403, -1, -1, -1}, {35404, -1, -1, -1}, {35405, -1, -1, -1}, {35407, -1, -1, -1}, {35409, -1, -1, -1}, {35411, -1, -1, -1}, {35414, -1, -1, -1}, {35415, -1, -1, -1}, {35417, -1, -1, -1}, {35418, -1, -1, -1}, {35420, -1, -1, -1}, {35421, -1, -1, -1}, {35423, -1, -1, -1}, {35424, -1, -1, -1}, {35428, -1, -1, -1}, {35429, -1, -1, -1}, {35431, -1, -1, -1}, {35432, -1, -1, -1}, {35434, -1, -1, -1}, {35439, -1, -1, -1}, {35444, -1, -1, -1}, {35446, -1, -1, -1}, {35447, -1, -1, -1}, {35448, -1, -1, -1}, {35450, -1, -1, -1}, {35451, -1, -1, -1}, {35453, -1, -1, -1}, {35454, -1, -1, -1}, {35456, -1, -1, -1}, {35457, -1, -1, -1}, {35458, -1, -1, -1}, {35459, -1, -1, -1}, {35464, -1, -1, -1}, {35467, -1, -1, -1}, {35468, -1, -1, -1}, {35470, -1, -1, -1}, {35471, -1, -1, -1}, {35472, -1, -1, -1}, {35476, -1, -1, -1}, {35478, -1, -1, -1}, {35479, -1, -1, -1}, {35481, -1, -1, -1}, {35483, -1, -1, -1}, {35484, -1, -1, -1}, {35485, -1, -1, -1}, {35487, -1, -1, -1}, {35490, -1, -1, -1}, {35495, -1, -1, -1}, {35497, -1, -1, -1}, {35498, -1, -1, -1}, {35499, -1, -1, -1}, {35501, -1, -1, -1}, {35502, -1, -1, -1}, {35503, -1, -1, -1}, {35505, -1, -1, -1}, {35507, -1, -1, -1}, {35508, -1, -1, -1}, {35509, -1, -1, -1}, {35511, -1, -1, -1}, {35512, -1, -1, -1}, {35514, -1, -1, -1}, {35515, -1, -1, -1}, {35517, -1, -1, -1}, {35518, -1, -1, -1}, {35520, -1, -1, -1}, {35521, -1, -1, -1}, {35523, -1, -1, -1}, {35525, -1, -1, -1}, {35526, -1, -1, -1}, {35528, -1, -1, -1}, {35530, -1, -1, -1}, {35532, -1, -1, -1}, {35534, -1, -1, -1}, {35536, -1, -1, -1}, {35539, -1, -1, -1}, {35540, -1, -1, -1}, {35541, -1, -1, -1}, {35544, -1, -1, -1}, {35545, -1, -1, -1}, {35546, -1, -1, -1}, {35549, -1, -1, -1}, {35551, -1, -1, -1}, {35552, -1, -1, -1}, {35553, -1, -1, -1}, {35555, -1, -1, -1}, {35557, -1, -1, -1}, {35560, -1, -1, -1}, {35561, -1, -1, -1}, {35562, -1, -1, -1}, {35564, -1, -1, -1}, {35567, -1, -1, -1}, {35568, -1, -1, -1}, {35570, -1, -1, -1}, {35572, -1, -1, -1}, {35573, -1, -1, -1}, {35577, -1, -1, -1}, {35579, -1, -1, -1}, {35581, -1, -1, -1}, {35583, -1, -1, -1}, {35587, -1, -1, -1}, {35590, -1, -1, -1}, {35592, -1, -1, -1}, {35593, -1, -1, -1}, {35595, -1, -1, -1}, {35596, -1, -1, -1}, {35597, -1, -1, -1}, {35599, -1, -1, -1}, {35601, -1, -1, -1}, {35602, -1, -1, -1}, {35603, -1, -1, -1}, {35605, -1, -1, -1}, {35608, -1, -1, -1}, {35612, -1, -1, -1}, {35614, -1, -1, -1}, {35615, -1, -1, -1}, {35616, -1, -1, -1}, {35618, -1, -1, -1}, {35619, -1, -1, -1}, {35620, -1, -1, -1}, {35621, -1, -1, -1}, {35623, -1, -1, -1}, {35625, -1, -1, -1}, {35626, -1, -1, -1}, {35630, -1, -1, -1}, {35631, -1, -1, -1}, {35632, -1, -1, -1}, {35633, -1, -1, -1}, {35634, -1, -1, -1}, {35636, -1, -1, -1}, {35637, -1, -1, -1}, {35638, -1, -1, -1}, {35639, -1, -1, -1}, {35640, -1, -1, -1}, {35642, -1, -1, -1}, {35643, -1, -1, -1}, {35644, -1, -1, -1}, {35645, -1, -1, -1}, {35647, -1, -1, -1}, {35648, -1, -1, -1}, {35649, -1, -1, -1}, {35650, -1, -1, -1}, {35651, -1, -1, -1}, {35652, -1, -1, -1}, {35653, -1, -1, -1}, {35654, -1, -1, -1}, {35655, -1, -1, -1}, {35656, -1, -1, -1}, {35658, -1, -1, -1}, {35659, -1, -1, -1}, {35660, -1, -1, -1}, {35661, -1, -1, -1}, {35664, -1, -1, -1}, {35665, -1, -1, -1}, {35666, -1, -1, -1}, {35667, -1, -1, -1}, {35668, -1, -1, -1}, {35669, -1, -1, -1}, {35671, -1, -1, -1}, {35675, -1, -1, -1}, {35677, -1, -1, -1}, {35678, -1, -1, -1}, {35679, -1, -1, -1}, {35680, -1, -1, -1}, {35681, -1, -1, -1}, {35682, -1, -1, -1} },
+ {{35683, -1, -1, -1}, {35684, -1, -1, -1}, {35685, -1, -1, -1}, {35687, -1, -1, -1}, {35688, -1, -1, -1}, {35689, -1, -1, -1}, {35690, -1, -1, -1}, {35693, -1, -1, -1}, {35694, -1, -1, -1}, {35697, -1, -1, -1}, {35698, -1, -1, -1}, {35699, -1, -1, -1}, {35701, -1, -1, -1}, {35702, -1, -1, -1}, {35704, -1, -1, -1}, {35705, -1, -1, -1}, {35706, -1, -1, -1}, {35707, -1, -1, -1}, {35708, -1, -1, -1}, {35710, -1, -1, -1}, {35711, -1, -1, -1}, {35713, -1, -1, -1}, {35714, -1, -1, -1}, {35715, -1, -1, -1}, {35716, -1, -1, -1}, {35717, -1, -1, -1}, {35718, -1, -1, -1}, {35719, -1, -1, -1}, {35720, -1, -1, -1}, {35721, -1, -1, -1}, {35723, -1, -1, -1}, {35724, -1, -1, -1}, {35725, -1, -1, -1}, {35727, -1, -1, -1}, {35728, -1, -1, -1}, {35729, -1, -1, -1}, {35732, -1, -1, -1}, {35735, -1, -1, -1}, {35736, -1, -1, -1}, {35737, -1, -1, -1}, {35738, -1, -1, -1}, {35739, -1, -1, -1}, {35741, -1, -1, -1}, {35743, -1, -1, -1}, {35756, -1, -1, -1}, {35761, -1, -1, -1}, {35771, -1, -1, -1}, {35783, -1, -1, -1}, {35792, -1, -1, -1}, {35818, -1, -1, -1}, {35849, -1, -1, -1}, {35870, -1, -1, -1}, {35896, -1, -1, -1}, {35897, -1, -1, -1}, {35898, -1, -1, -1}, {35899, -1, -1, -1}, {35900, -1, -1, -1}, {35901, -1, -1, -1}, {35902, -1, -1, -1}, {35903, -1, -1, -1}, {35904, -1, -1, -1}, {35906, -1, -1, -1}, {35907, -1, -1, -1}, {35908, -1, -1, -1}, {35909, -1, -1, -1}, {35914, -1, -1, -1}, {35915, -1, -1, -1}, {35917, -1, -1, -1}, {35918, -1, -1, -1}, {35919, -1, -1, -1}, {35921, -1, -1, -1}, {35922, -1, -1, -1}, {35923, -1, -1, -1}, {35924, -1, -1, -1}, {35926, -1, -1, -1}, {35927, -1, -1, -1}, {35928, -1, -1, -1}, {35929, -1, -1, -1}, {35931, -1, -1, -1}, {35932, -1, -1, -1}, {35933, -1, -1, -1}, {35934, -1, -1, -1}, {35935, -1, -1, -1}, {35936, -1, -1, -1}, {35939, -1, -1, -1}, {35940, -1, -1, -1}, {35941, -1, -1, -1}, {35942, -1, -1, -1}, {35943, -1, -1, -1}, {35944, -1, -1, -1}, {35945, -1, -1, -1}, {35948, -1, -1, -1}, {35949, -1, -1, -1}, {35950, -1, -1, -1}, {35951, -1, -1, -1}, {35952, -1, -1, -1}, {35953, -1, -1, -1}, {35954, -1, -1, -1}, {35956, -1, -1, -1}, {35957, -1, -1, -1}, {35958, -1, -1, -1}, {35959, -1, -1, -1}, {35963, -1, -1, -1}, {35964, -1, -1, -1}, {35965, -1, -1, -1}, {35966, -1, -1, -1}, {35967, -1, -1, -1}, {35968, -1, -1, -1}, {35969, -1, -1, -1}, {35971, -1, -1, -1}, {35972, -1, -1, -1}, {35974, -1, -1, -1}, {35975, -1, -1, -1}, {35976, -1, -1, -1}, {35979, -1, -1, -1}, {35981, -1, -1, -1}, {35982, -1, -1, -1}, {35983, -1, -1, -1}, {35984, -1, -1, -1}, {35985, -1, -1, -1}, {35986, -1, -1, -1}, {35987, -1, -1, -1}, {35989, -1, -1, -1}, {35990, -1, -1, -1}, {35991, -1, -1, -1}, {35993, -1, -1, -1}, {35994, -1, -1, -1}, {35995, -1, -1, -1}, {35996, -1, -1, -1}, {35999, -1, -1, -1}, {36003, -1, -1, -1}, {36004, -1, -1, -1}, {36005, -1, -1, -1}, {36006, -1, -1, -1}, {36013, -1, -1, -1}, {36014, -1, -1, -1}, {36017, -1, -1, -1}, {36021, -1, -1, -1}, {36025, -1, -1, -1}, {36030, -1, -1, -1}, {36038, -1, -1, -1}, {36041, -1, -1, -1}, {36043, -1, -1, -1}, {36044, -1, -1, -1}, {36045, -1, -1, -1}, {36046, -1, -1, -1}, {36047, -1, -1, -1}, {36048, -1, -1, -1}, {36052, -1, -1, -1}, {36054, -1, -1, -1}, {36055, -1, -1, -1}, {36056, -1, -1, -1}, {36057, -1, -1, -1}, {36059, -1, -1, -1}, {36061, -1, -1, -1}, {36063, -1, -1, -1}, {36069, -1, -1, -1}, {36072, -1, -1, -1}, {36073, -1, -1, -1}, {36078, -1, -1, -1}, {36079, -1, -1, -1}, {36080, -1, -1, -1}, {36081, -1, -1, -1}, {36082, -1, -1, -1}, {36083, -1, -1, -1}, {36085, -1, -1, -1}, {36086, -1, -1, -1}, {36087, -1, -1, -1}, {36088, -1, -1, -1}, {36089, -1, -1, -1}, {36095, -1, -1, -1}, {36096, -1, -1, -1}, {36097, -1, -1, -1}, {36098, -1, -1, -1}, {36099, -1, -1, -1}, {36102, -1, -1, -1}, {36103, -1, -1, -1}, {36105, -1, -1, -1}, {36108, -1, -1, -1}, {36110, -1, -1, -1}, {36113, -1, -1, -1}, {36114, -1, -1, -1}, {36115, -1, -1, -1}, {36116, -1, -1, -1}, {36117, -1, -1, -1}, {36119, -1, -1, -1}, {36120, -1, -1, -1}, {36121, -1, -1, -1}, {36122, -1, -1, -1}, {36128, -1, -1, -1}, {36177, -1, -1, -1}, {36178, -1, -1, -1}, {36183, -1, -1, -1}, {36191, -1, -1, -1}, {36197, -1, -1, -1}, {36200, -1, -1, -1}, {36201, -1, -1, -1}, {36202, -1, -1, -1}, {36204, -1, -1, -1}, {36206, -1, -1, -1}, {36207, -1, -1, -1}, {36209, -1, -1, -1}, {36210, -1, -1, -1}, {36216, -1, -1, -1}, {36217, -1, -1, -1}, {36218, -1, -1, -1}, {36219, -1, -1, -1}, {36220, -1, -1, -1}, {36221, -1, -1, -1}, {36222, -1, -1, -1}, {36223, -1, -1, -1}, {36224, -1, -1, -1}, {36226, -1, -1, -1}, {36227, -1, -1, -1}, {36230, -1, -1, -1}, {36231, -1, -1, -1}, {36232, -1, -1, -1}, {36233, -1, -1, -1}, {36236, -1, -1, -1}, {36237, -1, -1, -1}, {36238, -1, -1, -1}, {36239, -1, -1, -1}, {36240, -1, -1, -1}, {36242, -1, -1, -1}, {36243, -1, -1, -1}, {36246, -1, -1, -1}, {36247, -1, -1, -1}, {36248, -1, -1, -1}, {36250, -1, -1, -1}, {36251, -1, -1, -1}, {36252, -1, -1, -1}, {36253, -1, -1, -1}, {36254, -1, -1, -1}, {36256, -1, -1, -1}, {36257, -1, -1, -1}, {36258, -1, -1, -1}, {36260, -1, -1, -1}, {36261, -1, -1, -1}, {36262, -1, -1, -1}, {36263, -1, -1, -1}, {36265, -1, -1, -1}, {36266, -1, -1, -1}, {36267, -1, -1, -1}, {36268, -1, -1, -1}, {36269, -1, -1, -1}, {36270, -1, -1, -1}, {36271, -1, -1, -1}, {36272, -1, -1, -1}, {36278, -1, -1, -1}, {36279, -1, -1, -1}, {36281, -1, -1, -1}, {36283, -1, -1, -1}, {36285, -1, -1, -1}, {36288, -1, -1, -1}, {36289, -1, -1, -1}, {36290, -1, -1, -1} },
+ {{36293, -1, -1, -1}, {36295, -1, -1, -1}, {36296, -1, -1, -1}, {36297, -1, -1, -1}, {36298, -1, -1, -1}, {36301, -1, -1, -1}, {36304, -1, -1, -1}, {36306, -1, -1, -1}, {36307, -1, -1, -1}, {36308, -1, -1, -1}, {36309, -1, -1, -1}, {36312, -1, -1, -1}, {36313, -1, -1, -1}, {36316, -1, -1, -1}, {36320, -1, -1, -1}, {36321, -1, -1, -1}, {36322, -1, -1, -1}, {36325, -1, -1, -1}, {36326, -1, -1, -1}, {36327, -1, -1, -1}, {36329, -1, -1, -1}, {36333, -1, -1, -1}, {36334, -1, -1, -1}, {36336, -1, -1, -1}, {36337, -1, -1, -1}, {36338, -1, -1, -1}, {36340, -1, -1, -1}, {36342, -1, -1, -1}, {36348, -1, -1, -1}, {36350, -1, -1, -1}, {36351, -1, -1, -1}, {36352, -1, -1, -1}, {36353, -1, -1, -1}, {36354, -1, -1, -1}, {36355, -1, -1, -1}, {36356, -1, -1, -1}, {36358, -1, -1, -1}, {36359, -1, -1, -1}, {36360, -1, -1, -1}, {36363, -1, -1, -1}, {36365, -1, -1, -1}, {36366, -1, -1, -1}, {36369, -1, -1, -1}, {36370, -1, -1, -1}, {36371, -1, -1, -1}, {36373, -1, -1, -1}, {36374, -1, -1, -1}, {36375, -1, -1, -1}, {36376, -1, -1, -1}, {36377, -1, -1, -1}, {36378, -1, -1, -1}, {36379, -1, -1, -1}, {36380, -1, -1, -1}, {36384, -1, -1, -1}, {36385, -1, -1, -1}, {36388, -1, -1, -1}, {36389, -1, -1, -1}, {36390, -1, -1, -1}, {36391, -1, -1, -1}, {36392, -1, -1, -1}, {36395, -1, -1, -1}, {36397, -1, -1, -1}, {36400, -1, -1, -1}, {36402, -1, -1, -1}, {36403, -1, -1, -1}, {36406, -1, -1, -1}, {36407, -1, -1, -1}, {36408, -1, -1, -1}, {36411, -1, -1, -1}, {36412, -1, -1, -1}, {36414, -1, -1, -1}, {36415, -1, -1, -1}, {36419, -1, -1, -1}, {36421, -1, -1, -1}, {36422, -1, -1, -1}, {36429, -1, -1, -1}, {36430, -1, -1, -1}, {36431, -1, -1, -1}, {36432, -1, -1, -1}, {36435, -1, -1, -1}, {36436, -1, -1, -1}, {36438, -1, -1, -1}, {36439, -1, -1, -1}, {36440, -1, -1, -1}, {36442, -1, -1, -1}, {36443, -1, -1, -1}, {36444, -1, -1, -1}, {36445, -1, -1, -1}, {36446, -1, -1, -1}, {36447, -1, -1, -1}, {36448, -1, -1, -1}, {36449, -1, -1, -1}, {36450, -1, -1, -1}, {36452, -1, -1, -1}, {36453, -1, -1, -1}, {36455, -1, -1, -1}, {36456, -1, -1, -1}, {36458, -1, -1, -1}, {36459, -1, -1, -1}, {36462, -1, -1, -1}, {36465, -1, -1, -1}, {36467, -1, -1, -1}, {36469, -1, -1, -1}, {36471, -1, -1, -1}, {36472, -1, -1, -1}, {36473, -1, -1, -1}, {36475, -1, -1, -1}, {36477, -1, -1, -1}, {36478, -1, -1, -1}, {36480, -1, -1, -1}, {36482, -1, -1, -1}, {36483, -1, -1, -1}, {36484, -1, -1, -1}, {36486, -1, -1, -1}, {36488, -1, -1, -1}, {36492, -1, -1, -1}, {36494, -1, -1, -1}, {36501, -1, -1, -1}, {36502, -1, -1, -1}, {36503, -1, -1, -1}, {36504, -1, -1, -1}, {36505, -1, -1, -1}, {36507, -1, -1, -1}, {36509, -1, -1, -1}, {36511, -1, -1, -1}, {36512, -1, -1, -1}, {36514, -1, -1, -1}, {36515, -1, -1, -1}, {36516, -1, -1, -1}, {36519, -1, -1, -1}, {36520, -1, -1, -1}, {36521, -1, -1, -1}, {36525, -1, -1, -1}, {36526, -1, -1, -1}, {36528, -1, -1, -1}, {36529, -1, -1, -1}, {36531, -1, -1, -1}, {36532, -1, -1, -1}, {36533, -1, -1, -1}, {36534, -1, -1, -1}, {36535, -1, -1, -1}, {36536, -1, -1, -1}, {36537, -1, -1, -1}, {36539, -1, -1, -1}, {36540, -1, -1, -1}, {36541, -1, -1, -1}, {36542, -1, -1, -1}, {36543, -1, -1, -1}, {36545, -1, -1, -1}, {36546, -1, -1, -1}, {36547, -1, -1, -1}, {36548, -1, -1, -1}, {36549, -1, -1, -1}, {36550, -1, -1, -1}, {36551, -1, -1, -1}, {36552, -1, -1, -1}, {36553, -1, -1, -1}, {36559, -1, -1, -1}, {36560, -1, -1, -1}, {36561, -1, -1, -1}, {36563, -1, -1, -1}, {36565, -1, -1, -1}, {36566, -1, -1, -1}, {36567, -1, -1, -1}, {36568, -1, -1, -1}, {36569, -1, -1, -1}, {36570, -1, -1, -1}, {36572, -1, -1, -1}, {36573, -1, -1, -1}, {36574, -1, -1, -1}, {36576, -1, -1, -1}, {36577, -1, -1, -1}, {36578, -1, -1, -1}, {36579, -1, -1, -1}, {36581, -1, -1, -1}, {36582, -1, -1, -1}, {36583, -1, -1, -1}, {36584, -1, -1, -1}, {36585, -1, -1, -1}, {36586, -1, -1, -1}, {36588, -1, -1, -1}, {36589, -1, -1, -1}, {36590, -1, -1, -1}, {36591, -1, -1, -1}, {36592, -1, -1, -1}, {36593, -1, -1, -1}, {36595, -1, -1, -1}, {36596, -1, -1, -1}, {36597, -1, -1, -1}, {36598, -1, -1, -1}, {36599, -1, -1, -1}, {36605, -1, -1, -1}, {36607, -1, -1, -1}, {36608, -1, -1, -1}, {36609, -1, -1, -1}, {36610, -1, -1, -1}, {36612, -1, -1, -1}, {36614, -1, -1, -1}, {36616, -1, -1, -1}, {36619, -1, -1, -1}, {36620, -1, -1, -1}, {36621, -1, -1, -1}, {36622, -1, -1, -1}, {36623, -1, -1, -1}, {36624, -1, -1, -1}, {36625, -1, -1, -1}, {36627, -1, -1, -1}, {36630, -1, -1, -1}, {36631, -1, -1, -1}, {36632, -1, -1, -1}, {36633, -1, -1, -1}, {36634, -1, -1, -1}, {36640, -1, -1, -1}, {36641, -1, -1, -1}, {36642, -1, -1, -1}, {36643, -1, -1, -1}, {36644, -1, -1, -1}, {36647, -1, -1, -1}, {36648, -1, -1, -1}, {36651, -1, -1, -1}, {36652, -1, -1, -1}, {36653, -1, -1, -1}, {36654, -1, -1, -1}, {36656, -1, -1, -1}, {36657, -1, -1, -1}, {36658, -1, -1, -1}, {36660, -1, -1, -1}, {36661, -1, -1, -1}, {36662, -1, -1, -1}, {36663, -1, -1, -1}, {36665, -1, -1, -1}, {36666, -1, -1, -1}, {36668, -1, -1, -1}, {36669, -1, -1, -1}, {36672, -1, -1, -1}, {36673, -1, -1, -1}, {36675, -1, -1, -1}, {36679, -1, -1, -1}, {36680, -1, -1, -1}, {36682, -1, -1, -1}, {36683, -1, -1, -1}, {36684, -1, -1, -1}, {36687, -1, -1, -1}, {36688, -1, -1, -1}, {36689, -1, -1, -1}, {36690, -1, -1, -1}, {36691, -1, -1, -1}, {36693, -1, -1, -1}, {36694, -1, -1, -1}, {36695, -1, -1, -1}, {36696, -1, -1, -1}, {36697, -1, -1, -1}, {36698, -1, -1, -1}, {36699, -1, -1, -1}, {36700, -1, -1, -1}, {36701, -1, -1, -1} },
+ {{36702, -1, -1, -1}, {36704, -1, -1, -1}, {36707, -1, -1, -1}, {36709, -1, -1, -1}, {36714, -1, -1, -1}, {36736, -1, -1, -1}, {36748, -1, -1, -1}, {36754, -1, -1, -1}, {36765, -1, -1, -1}, {36768, -1, -1, -1}, {36769, -1, -1, -1}, {36770, -1, -1, -1}, {36772, -1, -1, -1}, {36773, -1, -1, -1}, {36775, -1, -1, -1}, {36778, -1, -1, -1}, {36780, -1, -1, -1}, {36787, -1, -1, -1}, {36788, -1, -1, -1}, {12193, 36789, -1, -1}, {36791, -1, -1, -1}, {36792, -1, -1, -1}, {36794, -1, -1, -1}, {36795, -1, -1, -1}, {36796, -1, -1, -1}, {36799, -1, -1, -1}, {36800, -1, -1, -1}, {36803, -1, -1, -1}, {36806, -1, -1, -1}, {36809, -1, -1, -1}, {36810, -1, -1, -1}, {36811, -1, -1, -1}, {36812, -1, -1, -1}, {36813, -1, -1, -1}, {36815, -1, -1, -1}, {36818, -1, -1, -1}, {36822, -1, -1, -1}, {36823, -1, -1, -1}, {36826, -1, -1, -1}, {36832, -1, -1, -1}, {36833, -1, -1, -1}, {36835, -1, -1, -1}, {36839, -1, -1, -1}, {36844, -1, -1, -1}, {36847, -1, -1, -1}, {36849, -1, -1, -1}, {36850, -1, -1, -1}, {36853, -1, -1, -1}, {36854, -1, -1, -1}, {36858, -1, -1, -1}, {36859, -1, -1, -1}, {36860, -1, -1, -1}, {36862, -1, -1, -1}, {36863, -1, -1, -1}, {36871, -1, -1, -1}, {36872, -1, -1, -1}, {36876, -1, -1, -1}, {36878, -1, -1, -1}, {36883, -1, -1, -1}, {36888, -1, -1, -1}, {36892, -1, -1, -1}, {36900, -1, -1, -1}, {36901, -1, -1, -1}, {36903, -1, -1, -1}, {36904, -1, -1, -1}, {36905, -1, -1, -1}, {36906, -1, -1, -1}, {36907, -1, -1, -1}, {36908, -1, -1, -1}, {36912, -1, -1, -1}, {36913, -1, -1, -1}, {36915, -1, -1, -1}, {36916, -1, -1, -1}, {36919, -1, -1, -1}, {36921, -1, -1, -1}, {36922, -1, -1, -1}, {36925, -1, -1, -1}, {36927, -1, -1, -1}, {36928, -1, -1, -1}, {36931, -1, -1, -1}, {36933, -1, -1, -1}, {36934, -1, -1, -1}, {36936, -1, -1, -1}, {36937, -1, -1, -1}, {36938, -1, -1, -1}, {36940, -1, -1, -1}, {36950, -1, -1, -1}, {36953, -1, -1, -1}, {36954, -1, -1, -1}, {36957, -1, -1, -1}, {36959, -1, -1, -1}, {36961, -1, -1, -1}, {36964, -1, -1, -1}, {36966, -1, -1, -1}, {36967, -1, -1, -1}, {36970, -1, -1, -1}, {36971, -1, -1, -1}, {36972, -1, -1, -1}, {36975, -1, -1, -1}, {36976, -1, -1, -1}, {36977, -1, -1, -1}, {36979, -1, -1, -1}, {36982, -1, -1, -1}, {36985, -1, -1, -1}, {36987, -1, -1, -1}, {36990, -1, -1, -1}, {36997, -1, -1, -1}, {36998, -1, -1, -1}, {37001, -1, -1, -1}, {37004, -1, -1, -1}, {37005, -1, -1, -1}, {37006, -1, -1, -1}, {37010, -1, -1, -1}, {37012, -1, -1, -1}, {37014, -1, -1, -1}, {37016, -1, -1, -1}, {37018, -1, -1, -1}, {37020, -1, -1, -1}, {37022, -1, -1, -1}, {37023, -1, -1, -1}, {37024, -1, -1, -1}, {37028, -1, -1, -1}, {37029, -1, -1, -1}, {37031, -1, -1, -1}, {37032, -1, -1, -1}, {37033, -1, -1, -1}, {37035, -1, -1, -1}, {37037, -1, -1, -1}, {37042, -1, -1, -1}, {37047, -1, -1, -1}, {37052, -1, -1, -1}, {37053, -1, -1, -1}, {37055, -1, -1, -1}, {37056, -1, -1, -1}, {37058, -1, -1, -1}, {37059, -1, -1, -1}, {37062, -1, -1, -1}, {37064, -1, -1, -1}, {37065, -1, -1, -1}, {37067, -1, -1, -1}, {37068, -1, -1, -1}, {37069, -1, -1, -1}, {37074, -1, -1, -1}, {37076, -1, -1, -1}, {37077, -1, -1, -1}, {37078, -1, -1, -1}, {37080, -1, -1, -1}, {37081, -1, -1, -1}, {37082, -1, -1, -1}, {37086, -1, -1, -1}, {37088, -1, -1, -1}, {37091, -1, -1, -1}, {37092, -1, -1, -1}, {37093, -1, -1, -1}, {37097, -1, -1, -1}, {37098, -1, -1, -1}, {37100, -1, -1, -1}, {37102, -1, -1, -1}, {37104, -1, -1, -1}, {37105, -1, -1, -1}, {37106, -1, -1, -1}, {37107, -1, -1, -1}, {37110, -1, -1, -1}, {37111, -1, -1, -1}, {37113, -1, -1, -1}, {37114, -1, -1, -1}, {37115, -1, -1, -1}, {37116, -1, -1, -1}, {37119, -1, -1, -1}, {37120, -1, -1, -1}, {37121, -1, -1, -1}, {37123, -1, -1, -1}, {37125, -1, -1, -1}, {37127, -1, -1, -1}, {37128, -1, -1, -1}, {37130, -1, -1, -1}, {37131, -1, -1, -1}, {37132, -1, -1, -1}, {37133, -1, -1, -1}, {37134, -1, -1, -1}, {37135, -1, -1, -1}, {37136, -1, -1, -1}, {37137, -1, -1, -1}, {37139, -1, -1, -1}, {37141, -1, -1, -1}, {37143, -1, -1, -1}, {37144, -1, -1, -1}, {37146, -1, -1, -1}, {37147, -1, -1, -1}, {37148, -1, -1, -1}, {37149, -1, -1, -1}, {37151, -1, -1, -1}, {37152, -1, -1, -1}, {37153, -1, -1, -1}, {37156, -1, -1, -1}, {37157, -1, -1, -1}, {37158, -1, -1, -1}, {37160, -1, -1, -1}, {37161, -1, -1, -1}, {37162, -1, -1, -1}, {37163, -1, -1, -1}, {37164, -1, -1, -1}, {37166, -1, -1, -1}, {37171, -1, -1, -1}, {37173, -1, -1, -1}, {37175, -1, -1, -1}, {37176, -1, -1, -1}, {37179, -1, -1, -1}, {37180, -1, -1, -1}, {37181, -1, -1, -1}, {37182, -1, -1, -1}, {37183, -1, -1, -1}, {37184, -1, -1, -1}, {37185, -1, -1, -1}, {37186, -1, -1, -1}, {37188, -1, -1, -1}, {37189, -1, -1, -1}, {37191, -1, -1, -1}, {37201, -1, -1, -1}, {37203, -1, -1, -1}, {37204, -1, -1, -1}, {37205, -1, -1, -1}, {37206, -1, -1, -1}, {37208, -1, -1, -1}, {37209, -1, -1, -1}, {37211, -1, -1, -1}, {37212, -1, -1, -1}, {37215, -1, -1, -1}, {37216, -1, -1, -1}, {37222, -1, -1, -1}, {37223, -1, -1, -1}, {37224, -1, -1, -1}, {37227, -1, -1, -1}, {37229, -1, -1, -1}, {37235, -1, -1, -1}, {37242, -1, -1, -1}, {37243, -1, -1, -1}, {37244, -1, -1, -1}, {37248, -1, -1, -1}, {37249, -1, -1, -1}, {37250, -1, -1, -1}, {37251, -1, -1, -1}, {37252, -1, -1, -1}, {37254, -1, -1, -1}, {37256, -1, -1, -1}, {37258, -1, -1, -1}, {37262, -1, -1, -1}, {37263, -1, -1, -1}, {37267, -1, -1, -1}, {37268, -1, -1, -1}, {37269, -1, -1, -1}, {37271, -1, -1, -1}, {37272, -1, -1, -1}, {37273, -1, -1, -1}, {37277, -1, -1, -1}, {37278, -1, -1, -1} },
+ {{37279, -1, -1, -1}, {37280, -1, -1, -1}, {37281, -1, -1, -1}, {37284, -1, -1, -1}, {37285, -1, -1, -1}, {37286, -1, -1, -1}, {37287, -1, -1, -1}, {37288, -1, -1, -1}, {37289, -1, -1, -1}, {37296, -1, -1, -1}, {37297, -1, -1, -1}, {37298, -1, -1, -1}, {37299, -1, -1, -1}, {37302, -1, -1, -1}, {37303, -1, -1, -1}, {37304, -1, -1, -1}, {37305, -1, -1, -1}, {37307, -1, -1, -1}, {37308, -1, -1, -1}, {37309, -1, -1, -1}, {37310, -1, -1, -1}, {37311, -1, -1, -1}, {37314, -1, -1, -1}, {37316, -1, -1, -1}, {12196, 37318, -1, -1}, {37320, -1, -1, -1}, {37328, -1, -1, -1}, {37334, -1, -1, -1}, {37338, -1, -1, -1}, {37339, -1, -1, -1}, {37342, -1, -1, -1}, {37343, -1, -1, -1}, {37344, -1, -1, -1}, {37345, -1, -1, -1}, {37346, -1, -1, -1}, {37349, -1, -1, -1}, {37350, -1, -1, -1}, {37352, -1, -1, -1}, {37354, -1, -1, -1}, {37355, -1, -1, -1}, {37356, -1, -1, -1}, {37357, -1, -1, -1}, {37358, -1, -1, -1}, {37359, -1, -1, -1}, {37360, -1, -1, -1}, {37361, -1, -1, -1}, {37362, -1, -1, -1}, {37363, -1, -1, -1}, {37364, -1, -1, -1}, {37366, -1, -1, -1}, {37368, -1, -1, -1}, {37371, -1, -1, -1}, {37372, -1, -1, -1}, {37373, -1, -1, -1}, {37374, -1, -1, -1}, {37375, -1, -1, -1}, {37378, -1, -1, -1}, {37379, -1, -1, -1}, {37381, -1, -1, -1}, {37382, -1, -1, -1}, {37383, -1, -1, -1}, {37386, -1, -1, -1}, {37387, -1, -1, -1}, {37388, -1, -1, -1}, {37391, -1, -1, -1}, {37394, -1, -1, -1}, {37395, -1, -1, -1}, {37398, -1, -1, -1}, {37399, -1, -1, -1}, {37400, -1, -1, -1}, {37401, -1, -1, -1}, {37402, -1, -1, -1}, {37403, -1, -1, -1}, {37404, -1, -1, -1}, {37405, -1, -1, -1}, {37407, -1, -1, -1}, {37408, -1, -1, -1}, {37409, -1, -1, -1}, {37410, -1, -1, -1}, {37412, -1, -1, -1}, {37416, -1, -1, -1}, {37417, -1, -1, -1}, {37418, -1, -1, -1}, {37419, -1, -1, -1}, {37420, -1, -1, -1}, {37421, -1, -1, -1}, {37423, -1, -1, -1}, {37425, -1, -1, -1}, {37426, -1, -1, -1}, {37429, -1, -1, -1}, {37430, -1, -1, -1}, {37435, -1, -1, -1}, {37436, -1, -1, -1}, {37441, -1, -1, -1}, {37442, -1, -1, -1}, {37443, -1, -1, -1}, {37444, -1, -1, -1}, {37446, -1, -1, -1}, {37447, -1, -1, -1}, {37450, -1, -1, -1}, {37451, -1, -1, -1}, {37452, -1, -1, -1}, {37454, -1, -1, -1}, {37455, -1, -1, -1}, {37456, -1, -1, -1}, {37458, -1, -1, -1}, {37459, -1, -1, -1}, {37460, -1, -1, -1}, {37462, -1, -1, -1}, {37464, -1, -1, -1}, {37465, -1, -1, -1}, {37468, -1, -1, -1}, {37469, -1, -1, -1}, {37471, -1, -1, -1}, {37472, -1, -1, -1}, {37473, -1, -1, -1}, {37475, -1, -1, -1}, {37476, -1, -1, -1}, {37477, -1, -1, -1}, {37479, -1, -1, -1}, {37480, -1, -1, -1}, {37481, -1, -1, -1}, {37482, -1, -1, -1}, {37483, -1, -1, -1}, {37486, -1, -1, -1}, {37487, -1, -1, -1}, {37488, -1, -1, -1}, {37489, -1, -1, -1}, {37490, -1, -1, -1}, {37491, -1, -1, -1}, {37493, -1, -1, -1}, {37494, -1, -1, -1}, {37495, -1, -1, -1}, {37497, -1, -1, -1}, {37500, -1, -1, -1}, {37501, -1, -1, -1}, {37502, -1, -1, -1}, {37505, -1, -1, -1}, {37506, -1, -1, -1}, {37508, -1, -1, -1}, {37510, -1, -1, -1}, {37511, -1, -1, -1}, {37512, -1, -1, -1}, {37513, -1, -1, -1}, {37514, -1, -1, -1}, {37515, -1, -1, -1}, {37516, -1, -1, -1}, {37517, -1, -1, -1}, {37519, -1, -1, -1}, {37520, -1, -1, -1}, {37522, -1, -1, -1}, {37524, -1, -1, -1}, {37525, -1, -1, -1}, {37527, -1, -1, -1}, {37529, -1, -1, -1}, {37531, -1, -1, -1}, {37533, -1, -1, -1}, {37534, -1, -1, -1}, {37535, -1, -1, -1}, {37537, -1, -1, -1}, {37538, -1, -1, -1}, {37540, -1, -1, -1}, {37543, -1, -1, -1}, {37549, -1, -1, -1}, {37551, -1, -1, -1}, {37552, -1, -1, -1}, {37554, -1, -1, -1}, {37555, -1, -1, -1}, {37556, -1, -1, -1}, {37557, -1, -1, -1}, {37558, -1, -1, -1}, {37560, -1, -1, -1}, {37562, -1, -1, -1}, {37565, -1, -1, -1}, {37566, -1, -1, -1}, {37567, -1, -1, -1}, {37568, -1, -1, -1}, {37570, -1, -1, -1}, {37572, -1, -1, -1}, {37574, -1, -1, -1}, {37577, -1, -1, -1}, {37578, -1, -1, -1}, {37579, -1, -1, -1}, {37581, -1, -1, -1}, {37582, -1, -1, -1}, {37584, -1, -1, -1}, {37585, -1, -1, -1}, {37587, -1, -1, -1}, {37588, -1, -1, -1}, {37589, -1, -1, -1}, {37590, -1, -1, -1}, {37591, -1, -1, -1}, {37592, -1, -1, -1}, {37593, -1, -1, -1}, {37594, -1, -1, -1}, {37595, -1, -1, -1}, {37596, -1, -1, -1}, {37598, -1, -1, -1}, {37600, -1, -1, -1}, {37601, -1, -1, -1}, {37602, -1, -1, -1}, {37607, -1, -1, -1}, {37609, -1, -1, -1}, {37611, -1, -1, -1}, {37612, -1, -1, -1}, {37618, -1, -1, -1}, {37619, -1, -1, -1}, {37620, -1, -1, -1}, {37621, -1, -1, -1}, {37623, -1, -1, -1}, {37625, -1, -1, -1}, {37626, -1, -1, -1}, {37627, -1, -1, -1}, {37629, -1, -1, -1}, {37630, -1, -1, -1}, {37631, -1, -1, -1}, {37632, -1, -1, -1}, {37634, -1, -1, -1}, {37635, -1, -1, -1}, {37636, -1, -1, -1}, {37637, -1, -1, -1}, {37641, -1, -1, -1}, {37642, -1, -1, -1}, {37643, -1, -1, -1}, {37644, -1, -1, -1}, {37645, -1, -1, -1}, {37646, -1, -1, -1}, {37647, -1, -1, -1}, {37649, -1, -1, -1}, {37651, -1, -1, -1}, {37652, -1, -1, -1}, {37654, -1, -1, -1}, {37655, -1, -1, -1}, {37660, -1, -1, -1}, {37661, -1, -1, -1}, {37662, -1, -1, -1}, {37665, -1, -1, -1}, {37667, -1, -1, -1}, {37668, -1, -1, -1}, {37669, -1, -1, -1}, {37671, -1, -1, -1}, {37673, -1, -1, -1}, {37674, -1, -1, -1}, {37676, -1, -1, -1}, {37677, -1, -1, -1}, {37680, -1, -1, -1}, {37681, -1, -1, -1}, {37684, -1, -1, -1}, {37685, -1, -1, -1}, {37687, -1, -1, -1}, {37689, -1, -1, -1}, {37690, -1, -1, -1}, {37691, -1, -1, -1}, {37692, -1, -1, -1}, {37693, -1, -1, -1}, {37695, -1, -1, -1} },
+ {{37698, -1, -1, -1}, {37700, -1, -1, -1}, {37701, -1, -1, -1}, {37704, -1, -1, -1}, {37705, -1, -1, -1}, {37706, -1, -1, -1}, {37708, -1, -1, -1}, {37710, -1, -1, -1}, {37711, -1, -1, -1}, {37712, -1, -1, -1}, {37713, -1, -1, -1}, {37714, -1, -1, -1}, {37715, -1, -1, -1}, {37717, -1, -1, -1}, {37718, -1, -1, -1}, {37719, -1, -1, -1}, {37721, -1, -1, -1}, {37722, -1, -1, -1}, {37724, -1, -1, -1}, {37725, -1, -1, -1}, {37726, -1, -1, -1}, {37727, -1, -1, -1}, {37728, -1, -1, -1}, {37729, -1, -1, -1}, {37730, -1, -1, -1}, {37731, -1, -1, -1}, {37734, -1, -1, -1}, {37735, -1, -1, -1}, {37736, -1, -1, -1}, {37739, -1, -1, -1}, {37741, -1, -1, -1}, {37742, -1, -1, -1}, {37743, -1, -1, -1}, {37745, -1, -1, -1}, {37746, -1, -1, -1}, {37747, -1, -1, -1}, {37748, -1, -1, -1}, {37751, -1, -1, -1}, {37752, -1, -1, -1}, {37753, -1, -1, -1}, {37755, -1, -1, -1}, {37756, -1, -1, -1}, {37757, -1, -1, -1}, {37759, -1, -1, -1}, {37760, -1, -1, -1}, {37761, -1, -1, -1}, {37763, -1, -1, -1}, {37765, -1, -1, -1}, {37766, -1, -1, -1}, {37768, -1, -1, -1}, {37769, -1, -1, -1}, {37771, -1, -1, -1}, {37772, -1, -1, -1}, {37773, -1, -1, -1}, {37774, -1, -1, -1}, {37776, -1, -1, -1}, {37777, -1, -1, -1}, {37778, -1, -1, -1}, {37779, -1, -1, -1}, {37780, -1, -1, -1}, {37781, -1, -1, -1}, {37783, -1, -1, -1}, {37785, -1, -1, -1}, {37786, -1, -1, -1}, {37787, -1, -1, -1}, {37788, -1, -1, -1}, {37789, -1, -1, -1}, {37790, -1, -1, -1}, {37791, -1, -1, -1}, {37792, -1, -1, -1}, {37793, -1, -1, -1}, {37796, -1, -1, -1}, {37797, -1, -1, -1}, {37800, -1, -1, -1}, {37803, -1, -1, -1}, {37805, -1, -1, -1}, {37807, -1, -1, -1}, {37809, -1, -1, -1}, {37810, -1, -1, -1}, {37812, -1, -1, -1}, {37814, -1, -1, -1}, {37815, -1, -1, -1}, {37817, -1, -1, -1}, {37818, -1, -1, -1}, {37819, -1, -1, -1}, {37820, -1, -1, -1}, {37821, -1, -1, -1}, {37822, -1, -1, -1}, {37824, -1, -1, -1}, {37825, -1, -1, -1}, {37826, -1, -1, -1}, {37828, -1, -1, -1}, {37829, -1, -1, -1}, {37830, -1, -1, -1}, {37833, -1, -1, -1}, {37835, -1, -1, -1}, {37838, -1, -1, -1}, {37839, -1, -1, -1}, {37840, -1, -1, -1}, {37842, -1, -1, -1}, {37843, -1, -1, -1}, {37844, -1, -1, -1}, {37845, -1, -1, -1}, {37849, -1, -1, -1}, {37850, -1, -1, -1}, {37851, -1, -1, -1}, {37856, -1, -1, -1}, {37859, -1, -1, -1}, {37861, -1, -1, -1}, {37862, -1, -1, -1}, {37863, -1, -1, -1}, {37865, -1, -1, -1}, {37866, -1, -1, -1}, {37867, -1, -1, -1}, {37868, -1, -1, -1}, {37869, -1, -1, -1}, {37870, -1, -1, -1}, {37871, -1, -1, -1}, {37872, -1, -1, -1}, {37873, -1, -1, -1}, {37874, -1, -1, -1}, {37875, -1, -1, -1}, {37876, -1, -1, -1}, {37878, -1, -1, -1}, {37880, -1, -1, -1}, {37882, -1, -1, -1}, {37883, -1, -1, -1}, {37884, -1, -1, -1}, {37885, -1, -1, -1}, {37886, -1, -1, -1}, {37887, -1, -1, -1}, {37888, -1, -1, -1}, {37889, -1, -1, -1}, {37890, -1, -1, -1}, {37892, -1, -1, -1}, {37893, -1, -1, -1}, {37894, -1, -1, -1}, {37895, -1, -1, -1}, {37896, -1, -1, -1}, {37897, -1, -1, -1}, {37898, -1, -1, -1}, {37900, -1, -1, -1}, {37901, -1, -1, -1}, {37902, -1, -1, -1}, {37903, -1, -1, -1}, {37905, -1, -1, -1}, {37909, -1, -1, -1}, {37910, -1, -1, -1}, {37911, -1, -1, -1}, {37914, -1, -1, -1}, {37915, -1, -1, -1}, {37916, -1, -1, -1}, {37918, -1, -1, -1}, {37919, -1, -1, -1}, {37921, -1, -1, -1}, {37922, -1, -1, -1}, {37923, -1, -1, -1}, {37924, -1, -1, -1}, {37925, -1, -1, -1}, {37929, -1, -1, -1}, {37930, -1, -1, -1}, {37931, -1, -1, -1}, {37932, -1, -1, -1}, {37933, -1, -1, -1}, {37935, -1, -1, -1}, {37936, -1, -1, -1}, {37937, -1, -1, -1}, {37940, -1, -1, -1}, {37942, -1, -1, -1}, {37943, -1, -1, -1}, {37945, -1, -1, -1}, {37947, -1, -1, -1}, {37948, -1, -1, -1}, {37949, -1, -1, -1}, {37952, -1, -1, -1}, {37953, -1, -1, -1}, {37954, -1, -1, -1}, {37955, -1, -1, -1}, {37957, -1, -1, -1}, {37958, -1, -1, -1}, {37959, -1, -1, -1}, {37960, -1, -1, -1}, {37961, -1, -1, -1}, {37963, -1, -1, -1}, {37965, -1, -1, -1}, {37966, -1, -1, -1}, {37967, -1, -1, -1}, {37968, -1, -1, -1}, {37969, -1, -1, -1}, {37971, -1, -1, -1}, {37973, -1, -1, -1}, {37974, -1, -1, -1}, {37975, -1, -1, -1}, {37976, -1, -1, -1}, {37977, -1, -1, -1}, {37978, -1, -1, -1}, {37979, -1, -1, -1}, {37980, -1, -1, -1}, {37981, -1, -1, -1}, {37982, -1, -1, -1}, {37983, -1, -1, -1}, {37985, -1, -1, -1}, {37986, -1, -1, -1}, {37988, -1, -1, -1}, {37990, -1, -1, -1}, {37991, -1, -1, -1}, {37992, -1, -1, -1}, {37993, -1, -1, -1}, {37994, -1, -1, -1}, {37996, -1, -1, -1}, {37998, -1, -1, -1}, {37999, -1, -1, -1}, {38001, -1, -1, -1}, {38003, -1, -1, -1}, {38004, -1, -1, -1}, {38005, -1, -1, -1}, {38006, -1, -1, -1}, {38008, -1, -1, -1}, {38010, -1, -1, -1}, {38011, -1, -1, -1}, {38016, -1, -1, -1}, {38017, -1, -1, -1}, {38018, -1, -1, -1}, {38019, -1, -1, -1}, {38020, -1, -1, -1}, {38033, -1, -1, -1}, {38038, -1, -1, -1}, {38040, -1, -1, -1}, {38087, -1, -1, -1}, {38095, -1, -1, -1}, {38099, -1, -1, -1}, {38100, -1, -1, -1}, {38106, -1, -1, -1}, {38118, -1, -1, -1}, {38139, -1, -1, -1}, {38172, -1, -1, -1}, {38176, -1, -1, -1}, {38183, -1, -1, -1}, {38195, -1, -1, -1}, {38205, -1, -1, -1}, {38211, -1, -1, -1}, {38216, -1, -1, -1}, {38219, -1, -1, -1}, {38229, -1, -1, -1}, {38234, -1, -1, -1}, {38240, -1, -1, -1}, {38254, -1, -1, -1}, {38260, -1, -1, -1}, {38261, -1, -1, -1}, {38264, -1, -1, -1}, {38265, -1, -1, -1}, {38266, -1, -1, -1}, {38267, -1, -1, -1}, {38268, -1, -1, -1}, {38269, -1, -1, -1}, {38270, -1, -1, -1} },
+ {{38273, -1, -1, -1}, {38276, -1, -1, -1}, {38277, -1, -1, -1}, {38279, -1, -1, -1}, {38280, -1, -1, -1}, {38282, -1, -1, -1}, {38285, -1, -1, -1}, {38288, -1, -1, -1}, {38290, -1, -1, -1}, {38293, -1, -1, -1}, {38294, -1, -1, -1}, {38295, -1, -1, -1}, {38297, -1, -1, -1}, {38298, -1, -1, -1}, {38299, -1, -1, -1}, {38300, -1, -1, -1}, {38301, -1, -1, -1}, {38302, -1, -1, -1}, {38303, -1, -1, -1}, {38304, -1, -1, -1}, {38306, -1, -1, -1}, {38310, -1, -1, -1}, {38311, -1, -1, -1}, {38314, -1, -1, -1}, {38318, -1, -1, -1}, {38319, -1, -1, -1}, {38320, -1, -1, -1}, {38321, -1, -1, -1}, {38323, -1, -1, -1}, {38324, -1, -1, -1}, {38325, -1, -1, -1}, {38327, -1, -1, -1}, {38328, -1, -1, -1}, {38330, -1, -1, -1}, {38336, -1, -1, -1}, {38337, -1, -1, -1}, {38338, -1, -1, -1}, {38340, -1, -1, -1}, {38341, -1, -1, -1}, {38343, -1, -1, -1}, {38345, -1, -1, -1}, {38349, -1, -1, -1}, {38350, -1, -1, -1}, {38351, -1, -1, -1}, {38353, -1, -1, -1}, {38354, -1, -1, -1}, {38355, -1, -1, -1}, {38359, -1, -1, -1}, {38360, -1, -1, -1}, {38361, -1, -1, -1}, {38362, -1, -1, -1}, {38363, -1, -1, -1}, {38365, -1, -1, -1}, {38367, -1, -1, -1}, {38368, -1, -1, -1}, {38371, -1, -1, -1}, {38372, -1, -1, -1}, {38374, -1, -1, -1}, {38375, -1, -1, -1}, {38380, -1, -1, -1}, {38399, -1, -1, -1}, {38407, -1, -1, -1}, {38419, -1, -1, -1}, {38424, -1, -1, -1}, {38427, -1, -1, -1}, {38430, -1, -1, -1}, {38432, -1, -1, -1}, {38435, -1, -1, -1}, {38436, -1, -1, -1}, {38437, -1, -1, -1}, {38438, -1, -1, -1}, {38439, -1, -1, -1}, {38440, -1, -1, -1}, {38441, -1, -1, -1}, {38443, -1, -1, -1}, {38444, -1, -1, -1}, {38445, -1, -1, -1}, {38447, -1, -1, -1}, {38448, -1, -1, -1}, {38455, -1, -1, -1}, {38456, -1, -1, -1}, {38457, -1, -1, -1}, {38458, -1, -1, -1}, {38462, -1, -1, -1}, {38465, -1, -1, -1}, {38467, -1, -1, -1}, {38474, -1, -1, -1}, {38478, -1, -1, -1}, {38479, -1, -1, -1}, {38481, -1, -1, -1}, {38482, -1, -1, -1}, {38483, -1, -1, -1}, {38486, -1, -1, -1}, {38487, -1, -1, -1}, {38489, -1, -1, -1}, {38490, -1, -1, -1}, {38492, -1, -1, -1}, {38494, -1, -1, -1}, {38496, -1, -1, -1}, {38501, -1, -1, -1}, {38502, -1, -1, -1}, {38507, -1, -1, -1}, {38509, -1, -1, -1}, {38510, -1, -1, -1}, {38511, -1, -1, -1}, {38513, -1, -1, -1}, {38521, -1, -1, -1}, {38522, -1, -1, -1}, {38523, -1, -1, -1}, {38524, -1, -1, -1}, {38526, -1, -1, -1}, {38527, -1, -1, -1}, {38528, -1, -1, -1}, {38529, -1, -1, -1}, {38530, -1, -1, -1}, {38531, -1, -1, -1}, {38532, -1, -1, -1}, {38535, -1, -1, -1}, {38537, -1, -1, -1}, {38540, -1, -1, -1}, {38545, -1, -1, -1}, {38546, -1, -1, -1}, {38547, -1, -1, -1}, {38550, -1, -1, -1}, {38554, -1, -1, -1}, {38557, -1, -1, -1}, {38558, -1, -1, -1}, {38559, -1, -1, -1}, {38560, -1, -1, -1}, {38561, -1, -1, -1}, {38562, -1, -1, -1}, {38563, -1, -1, -1}, {38564, -1, -1, -1}, {38565, -1, -1, -1}, {38566, -1, -1, -1}, {38569, -1, -1, -1}, {38571, -1, -1, -1}, {38572, -1, -1, -1}, {38573, -1, -1, -1}, {38574, -1, -1, -1}, {38575, -1, -1, -1}, {38578, -1, -1, -1}, {38581, -1, -1, -1}, {38583, -1, -1, -1}, {38586, -1, -1, -1}, {38591, -1, -1, -1}, {38594, -1, -1, -1}, {38595, -1, -1, -1}, {38600, -1, -1, -1}, {38602, -1, -1, -1}, {38603, -1, -1, -1}, {38608, -1, -1, -1}, {38609, -1, -1, -1}, {38611, -1, -1, -1}, {38612, -1, -1, -1}, {38615, -1, -1, -1}, {38616, -1, -1, -1}, {38618, -1, -1, -1}, {38621, -1, -1, -1}, {38622, -1, -1, -1}, {38623, -1, -1, -1}, {38625, -1, -1, -1}, {38628, -1, -1, -1}, {38629, -1, -1, -1}, {38630, -1, -1, -1}, {38631, -1, -1, -1}, {38635, -1, -1, -1}, {38636, -1, -1, -1}, {38637, -1, -1, -1}, {38638, -1, -1, -1}, {38640, -1, -1, -1}, {38641, -1, -1, -1}, {38644, -1, -1, -1}, {38645, -1, -1, -1}, {38648, -1, -1, -1}, {38650, -1, -1, -1}, {38652, -1, -1, -1}, {38653, -1, -1, -1}, {38655, -1, -1, -1}, {38658, -1, -1, -1}, {38659, -1, -1, -1}, {38661, -1, -1, -1}, {38666, -1, -1, -1}, {38667, -1, -1, -1}, {38668, -1, -1, -1}, {38672, -1, -1, -1}, {38673, -1, -1, -1}, {38674, -1, -1, -1}, {38676, -1, -1, -1}, {38677, -1, -1, -1}, {38679, -1, -1, -1}, {38680, -1, -1, -1}, {38681, -1, -1, -1}, {38682, -1, -1, -1}, {38683, -1, -1, -1}, {38685, -1, -1, -1}, {38687, -1, -1, -1}, {38688, -1, -1, -1}, {38689, -1, -1, -1}, {38690, -1, -1, -1}, {38691, -1, -1, -1}, {38692, -1, -1, -1}, {38693, -1, -1, -1}, {38694, -1, -1, -1}, {38696, -1, -1, -1}, {38697, -1, -1, -1}, {38699, -1, -1, -1}, {38700, -1, -1, -1}, {38702, -1, -1, -1}, {38703, -1, -1, -1}, {38705, -1, -1, -1}, {38707, -1, -1, -1}, {38708, -1, -1, -1}, {38709, -1, -1, -1}, {38710, -1, -1, -1}, {38711, -1, -1, -1}, {38714, -1, -1, -1}, {38715, -1, -1, -1}, {38716, -1, -1, -1}, {38719, -1, -1, -1}, {38720, -1, -1, -1}, {38721, -1, -1, -1}, {38723, -1, -1, -1}, {38725, -1, -1, -1}, {38726, -1, -1, -1}, {38727, -1, -1, -1}, {38729, -1, -1, -1}, {38730, -1, -1, -1}, {38731, -1, -1, -1}, {38732, -1, -1, -1}, {38733, -1, -1, -1}, {38734, -1, -1, -1}, {38735, -1, -1, -1}, {38736, -1, -1, -1}, {12205, 38737, -1, -1}, {38740, -1, -1, -1}, {38741, -1, -1, -1}, {38743, -1, -1, -1}, {38744, -1, -1, -1}, {38748, -1, -1, -1}, {38749, -1, -1, -1}, {38751, -1, -1, -1}, {38755, -1, -1, -1}, {38756, -1, -1, -1}, {38758, -1, -1, -1}, {38759, -1, -1, -1}, {38762, -1, -1, -1}, {38763, -1, -1, -1}, {38764, -1, -1, -1}, {38765, -1, -1, -1}, {38766, -1, -1, -1}, {38767, -1, -1, -1}, {38768, -1, -1, -1}, {38769, -1, -1, -1}, {38770, -1, -1, -1}, {38773, -1, -1, -1} },
+ {{38775, -1, -1, -1}, {38776, -1, -1, -1}, {38777, -1, -1, -1}, {38778, -1, -1, -1}, {38779, -1, -1, -1}, {38781, -1, -1, -1}, {38782, -1, -1, -1}, {38783, -1, -1, -1}, {38784, -1, -1, -1}, {38785, -1, -1, -1}, {38786, -1, -1, -1}, {38787, -1, -1, -1}, {38788, -1, -1, -1}, {38790, -1, -1, -1}, {38791, -1, -1, -1}, {38792, -1, -1, -1}, {38793, -1, -1, -1}, {38794, -1, -1, -1}, {38796, -1, -1, -1}, {38798, -1, -1, -1}, {38800, -1, -1, -1}, {38803, -1, -1, -1}, {38805, -1, -1, -1}, {38806, -1, -1, -1}, {38807, -1, -1, -1}, {38809, -1, -1, -1}, {38810, -1, -1, -1}, {38811, -1, -1, -1}, {38812, -1, -1, -1}, {38813, -1, -1, -1}, {38814, -1, -1, -1}, {38815, -1, -1, -1}, {38817, -1, -1, -1}, {38818, -1, -1, -1}, {38820, -1, -1, -1}, {38821, -1, -1, -1}, {38823, -1, -1, -1}, {38824, -1, -1, -1}, {38825, -1, -1, -1}, {38826, -1, -1, -1}, {38828, -1, -1, -1}, {38830, -1, -1, -1}, {38832, -1, -1, -1}, {38833, -1, -1, -1}, {38835, -1, -1, -1}, {38837, -1, -1, -1}, {38838, -1, -1, -1}, {38839, -1, -1, -1}, {38840, -1, -1, -1}, {38841, -1, -1, -1}, {38842, -1, -1, -1}, {38843, -1, -1, -1}, {38844, -1, -1, -1}, {38846, -1, -1, -1}, {38847, -1, -1, -1}, {38848, -1, -1, -1}, {38849, -1, -1, -1}, {38850, -1, -1, -1}, {38852, -1, -1, -1}, {38853, -1, -1, -1}, {38855, -1, -1, -1}, {38856, -1, -1, -1}, {38858, -1, -1, -1}, {38861, -1, -1, -1}, {38862, -1, -1, -1}, {38863, -1, -1, -1}, {38864, -1, -1, -1}, {38865, -1, -1, -1}, {38866, -1, -1, -1}, {38868, -1, -1, -1}, {38869, -1, -1, -1}, {38870, -1, -1, -1}, {38871, -1, -1, -1}, {38872, -1, -1, -1}, {38874, -1, -1, -1}, {38875, -1, -1, -1}, {38877, -1, -1, -1}, {38879, -1, -1, -1}, {38880, -1, -1, -1}, {38881, -1, -1, -1}, {38882, -1, -1, -1}, {38883, -1, -1, -1}, {38884, -1, -1, -1}, {38885, -1, -1, -1}, {38888, -1, -1, -1}, {38894, -1, -1, -1}, {38895, -1, -1, -1}, {38896, -1, -1, -1}, {38897, -1, -1, -1}, {38898, -1, -1, -1}, {38900, -1, -1, -1}, {38903, -1, -1, -1}, {38904, -1, -1, -1}, {38905, -1, -1, -1}, {38906, -1, -1, -1}, {38907, -1, -1, -1}, {38908, -1, -1, -1}, {38909, -1, -1, -1}, {38910, -1, -1, -1}, {38912, -1, -1, -1}, {38916, -1, -1, -1}, {38921, -1, -1, -1}, {38923, -1, -1, -1}, {38925, -1, -1, -1}, {38932, -1, -1, -1}, {38933, -1, -1, -1}, {38934, -1, -1, -1}, {38937, -1, -1, -1}, {38938, -1, -1, -1}, {38939, -1, -1, -1}, {38941, -1, -1, -1}, {38942, -1, -1, -1}, {38943, -1, -1, -1}, {38944, -1, -1, -1}, {38946, -1, -1, -1}, {38947, -1, -1, -1}, {38949, -1, -1, -1}, {38951, -1, -1, -1}, {38952, -1, -1, -1}, {38953, -1, -1, -1}, {38954, -1, -1, -1}, {38955, -1, -1, -1}, {38956, -1, -1, -1}, {38958, -1, -1, -1}, {38959, -1, -1, -1}, {38961, -1, -1, -1}, {38962, -1, -1, -1}, {38963, -1, -1, -1}, {38964, -1, -1, -1}, {38965, -1, -1, -1}, {38966, -1, -1, -1}, {38969, -1, -1, -1}, {38970, -1, -1, -1}, {38972, -1, -1, -1}, {38974, -1, -1, -1}, {38975, -1, -1, -1}, {38976, -1, -1, -1}, {38977, -1, -1, -1}, {38978, -1, -1, -1}, {38979, -1, -1, -1}, {38980, -1, -1, -1}, {38981, -1, -1, -1}, {38983, -1, -1, -1}, {38984, -1, -1, -1}, {38985, -1, -1, -1}, {38986, -1, -1, -1}, {38987, -1, -1, -1}, {38991, -1, -1, -1}, {38992, -1, -1, -1}, {38993, -1, -1, -1}, {38994, -1, -1, -1}, {38997, -1, -1, -1}, {38998, -1, -1, -1}, {38999, -1, -1, -1}, {39002, -1, -1, -1}, {39004, -1, -1, -1}, {39005, -1, -1, -1}, {39007, -1, -1, -1}, {39008, -1, -1, -1}, {39009, -1, -1, -1}, {39011, -1, -1, -1}, {39012, -1, -1, -1}, {39014, -1, -1, -1}, {39016, -1, -1, -1}, {39017, -1, -1, -1}, {39018, -1, -1, -1}, {39021, -1, -1, -1}, {39022, -1, -1, -1}, {39026, -1, -1, -1}, {39051, -1, -1, -1}, {39054, -1, -1, -1}, {39058, -1, -1, -1}, {39061, -1, -1, -1}, {39065, -1, -1, -1}, {39075, -1, -1, -1}, {39081, -1, -1, -1}, {39082, -1, -1, -1}, {39083, -1, -1, -1}, {39084, -1, -1, -1}, {39085, -1, -1, -1}, {39088, -1, -1, -1}, {39090, -1, -1, -1}, {39092, -1, -1, -1}, {39093, -1, -1, -1}, {39095, -1, -1, -1}, {39096, -1, -1, -1}, {39097, -1, -1, -1}, {39098, -1, -1, -1}, {39099, -1, -1, -1}, {39101, -1, -1, -1}, {39102, -1, -1, -1}, {39103, -1, -1, -1}, {39104, -1, -1, -1}, {39105, -1, -1, -1}, {39106, -1, -1, -1}, {39107, -1, -1, -1}, {39109, -1, -1, -1}, {39111, -1, -1, -1}, {39113, -1, -1, -1}, {39114, -1, -1, -1}, {39115, -1, -1, -1}, {39116, -1, -1, -1}, {39117, -1, -1, -1}, {39119, -1, -1, -1}, {39120, -1, -1, -1}, {39124, -1, -1, -1}, {39126, -1, -1, -1}, {39127, -1, -1, -1}, {39132, -1, -1, -1}, {39133, -1, -1, -1}, {39137, -1, -1, -1}, {39139, -1, -1, -1}, {39140, -1, -1, -1}, {39141, -1, -1, -1}, {39142, -1, -1, -1}, {39148, -1, -1, -1}, {39150, -1, -1, -1}, {39152, -1, -1, -1}, {39153, -1, -1, -1}, {39155, -1, -1, -1}, {39157, -1, -1, -1}, {39158, -1, -1, -1}, {39159, -1, -1, -1}, {39160, -1, -1, -1}, {39161, -1, -1, -1}, {39162, -1, -1, -1}, {39163, -1, -1, -1}, {39167, -1, -1, -1}, {39168, -1, -1, -1}, {39169, -1, -1, -1}, {39170, -1, -1, -1}, {39172, -1, -1, -1}, {39174, -1, -1, -1}, {39175, -1, -1, -1}, {39176, -1, -1, -1}, {39179, -1, -1, -1}, {39182, -1, -1, -1}, {39183, -1, -1, -1}, {39188, -1, -1, -1}, {39189, -1, -1, -1}, {39190, -1, -1, -1}, {39191, -1, -1, -1}, {39193, -1, -1, -1}, {39194, -1, -1, -1}, {39196, -1, -1, -1}, {39197, -1, -1, -1}, {39199, -1, -1, -1}, {39200, -1, -1, -1}, {39202, -1, -1, -1}, {39203, -1, -1, -1}, {39204, -1, -1, -1}, {39205, -1, -1, -1}, {39206, -1, -1, -1}, {39207, -1, -1, -1}, {39209, -1, -1, -1}, {39210, -1, -1, -1} },
+ {{39211, -1, -1, -1}, {39212, -1, -1, -1}, {39213, -1, -1, -1}, {39215, -1, -1, -1}, {39216, -1, -1, -1}, {39217, -1, -1, -1}, {39218, -1, -1, -1}, {39220, -1, -1, -1}, {39221, -1, -1, -1}, {39222, -1, -1, -1}, {39224, -1, -1, -1}, {39225, -1, -1, -1}, {39226, -1, -1, -1}, {39227, -1, -1, -1}, {39229, -1, -1, -1}, {39232, -1, -1, -1}, {39233, -1, -1, -1}, {39234, -1, -1, -1}, {39236, -1, -1, -1}, {39238, -1, -1, -1}, {39239, -1, -1, -1}, {39245, -1, -1, -1}, {39246, -1, -1, -1}, {39247, -1, -1, -1}, {39248, -1, -1, -1}, {39251, -1, -1, -1}, {39254, -1, -1, -1}, {39256, -1, -1, -1}, {39257, -1, -1, -1}, {39258, -1, -1, -1}, {39259, -1, -1, -1}, {39261, -1, -1, -1}, {39263, -1, -1, -1}, {39264, -1, -1, -1}, {39265, -1, -1, -1}, {39268, -1, -1, -1}, {39270, -1, -1, -1}, {39283, -1, -1, -1}, {39288, -1, -1, -1}, {39289, -1, -1, -1}, {39291, -1, -1, -1}, {39294, -1, -1, -1}, {39298, -1, -1, -1}, {39299, -1, -1, -1}, {39305, -1, -1, -1}, {39308, -1, -1, -1}, {39310, -1, -1, -1}, {39322, -1, -1, -1}, {39323, -1, -1, -1}, {39324, -1, -1, -1}, {39325, -1, -1, -1}, {39326, -1, -1, -1}, {39327, -1, -1, -1}, {39328, -1, -1, -1}, {39329, -1, -1, -1}, {39330, -1, -1, -1}, {39331, -1, -1, -1}, {39332, -1, -1, -1}, {39334, -1, -1, -1}, {39335, -1, -1, -1}, {39337, -1, -1, -1}, {39338, -1, -1, -1}, {39339, -1, -1, -1}, {39343, -1, -1, -1}, {39344, -1, -1, -1}, {39346, -1, -1, -1}, {39349, -1, -1, -1}, {39350, -1, -1, -1}, {39351, -1, -1, -1}, {39352, -1, -1, -1}, {39353, -1, -1, -1}, {39354, -1, -1, -1}, {39355, -1, -1, -1}, {39356, -1, -1, -1}, {39357, -1, -1, -1}, {39358, -1, -1, -1}, {39359, -1, -1, -1}, {39360, -1, -1, -1}, {39362, -1, -1, -1}, {39363, -1, -1, -1}, {39364, -1, -1, -1}, {39365, -1, -1, -1}, {39366, -1, -1, -1}, {39367, -1, -1, -1}, {39368, -1, -1, -1}, {39369, -1, -1, -1}, {39370, -1, -1, -1}, {39371, -1, -1, -1}, {39372, -1, -1, -1}, {39373, -1, -1, -1}, {39374, -1, -1, -1}, {39375, -1, -1, -1}, {39379, -1, -1, -1}, {39382, -1, -1, -1}, {39383, -1, -1, -1}, {39386, -1, -1, -1}, {39388, -1, -1, -1}, {39390, -1, -1, -1}, {39392, -1, -1, -1}, {39395, -1, -1, -1}, {39396, -1, -1, -1}, {39397, -1, -1, -1}, {39398, -1, -1, -1}, {39399, -1, -1, -1}, {39400, -1, -1, -1}, {39401, -1, -1, -1}, {39402, -1, -1, -1}, {39403, -1, -1, -1}, {39404, -1, -1, -1}, {39406, -1, -1, -1}, {39407, -1, -1, -1}, {39408, -1, -1, -1}, {39410, -1, -1, -1}, {39411, -1, -1, -1}, {39412, -1, -1, -1}, {39413, -1, -1, -1}, {39414, -1, -1, -1}, {39415, -1, -1, -1}, {39416, -1, -1, -1}, {39417, -1, -1, -1}, {39418, -1, -1, -1}, {39419, -1, -1, -1}, {39420, -1, -1, -1}, {39421, -1, -1, -1}, {39422, -1, -1, -1}, {39424, -1, -1, -1}, {39426, -1, -1, -1}, {39427, -1, -1, -1}, {39428, -1, -1, -1}, {39430, -1, -1, -1}, {39431, -1, -1, -1}, {39432, -1, -1, -1}, {39433, -1, -1, -1}, {39434, -1, -1, -1}, {39435, -1, -1, -1}, {39436, -1, -1, -1}, {39440, -1, -1, -1}, {39441, -1, -1, -1}, {39442, -1, -1, -1}, {39443, -1, -1, -1}, {39444, -1, -1, -1}, {39445, -1, -1, -1}, {39447, -1, -1, -1}, {39448, -1, -1, -1}, {39450, -1, -1, -1}, {39451, -1, -1, -1}, {39452, -1, -1, -1}, {39453, -1, -1, -1}, {39454, -1, -1, -1}, {39455, -1, -1, -1}, {39456, -1, -1, -1}, {39457, -1, -1, -1}, {39458, -1, -1, -1}, {39459, -1, -1, -1}, {39460, -1, -1, -1}, {39461, -1, -1, -1}, {39462, -1, -1, -1}, {39463, -1, -1, -1}, {39464, -1, -1, -1}, {39465, -1, -1, -1}, {39466, -1, -1, -1}, {39468, -1, -1, -1}, {39471, -1, -1, -1}, {39473, -1, -1, -1}, {39474, -1, -1, -1}, {39475, -1, -1, -1}, {39476, -1, -1, -1}, {39477, -1, -1, -1}, {39481, -1, -1, -1}, {39482, -1, -1, -1}, {39483, -1, -1, -1}, {39484, -1, -1, -1}, {39485, -1, -1, -1}, {39487, -1, -1, -1}, {39494, -1, -1, -1}, {39495, -1, -1, -1}, {39496, -1, -1, -1}, {39497, -1, -1, -1}, {39499, -1, -1, -1}, {39500, -1, -1, -1}, {39502, -1, -1, -1}, {39504, -1, -1, -1}, {39505, -1, -1, -1}, {39506, -1, -1, -1}, {39507, -1, -1, -1}, {39508, -1, -1, -1}, {39510, -1, -1, -1}, {39512, -1, -1, -1}, {39513, -1, -1, -1}, {39516, -1, -1, -1}, {39517, -1, -1, -1}, {39518, -1, -1, -1}, {39520, -1, -1, -1}, {39521, -1, -1, -1}, {39523, -1, -1, -1}, {39526, -1, -1, -1}, {39527, -1, -1, -1}, {39528, -1, -1, -1}, {39529, -1, -1, -1}, {39531, -1, -1, -1}, {39538, -1, -1, -1}, {39555, -1, -1, -1}, {39561, -1, -1, -1}, {39565, -1, -1, -1}, {39566, -1, -1, -1}, {39572, -1, -1, -1}, {39573, -1, -1, -1}, {39577, -1, -1, -1}, {39590, -1, -1, -1}, {39593, -1, -1, -1}, {39594, -1, -1, -1}, {39595, -1, -1, -1}, {39596, -1, -1, -1}, {39597, -1, -1, -1}, {39598, -1, -1, -1}, {39602, -1, -1, -1}, {39603, -1, -1, -1}, {39604, -1, -1, -1}, {39605, -1, -1, -1}, {39609, -1, -1, -1}, {39611, -1, -1, -1}, {39613, -1, -1, -1}, {39614, -1, -1, -1}, {39615, -1, -1, -1}, {39619, -1, -1, -1}, {39620, -1, -1, -1}, {39622, -1, -1, -1}, {39623, -1, -1, -1}, {39624, -1, -1, -1}, {39625, -1, -1, -1}, {39626, -1, -1, -1}, {39629, -1, -1, -1}, {39630, -1, -1, -1}, {39632, -1, -1, -1}, {39639, -1, -1, -1}, {39641, -1, -1, -1}, {39642, -1, -1, -1}, {39643, -1, -1, -1}, {39644, -1, -1, -1}, {39645, -1, -1, -1}, {39646, -1, -1, -1}, {39648, -1, -1, -1}, {39650, -1, -1, -1}, {39651, -1, -1, -1}, {39652, -1, -1, -1}, {39653, -1, -1, -1}, {39655, -1, -1, -1}, {39656, -1, -1, -1}, {39657, -1, -1, -1}, {39658, -1, -1, -1}, {39660, -1, -1, -1}, {39664, -1, -1, -1}, {39665, -1, -1, -1}, {39666, -1, -1, -1}, {39667, -1, -1, -1}, {39668, -1, -1, -1} },
+ {{39669, -1, -1, -1}, {39670, -1, -1, -1}, {39671, -1, -1, -1}, {39672, -1, -1, -1}, {39674, -1, -1, -1}, {39676, -1, -1, -1}, {39677, -1, -1, -1}, {39678, -1, -1, -1}, {39679, -1, -1, -1}, {39680, -1, -1, -1}, {39681, -1, -1, -1}, {39682, -1, -1, -1}, {39684, -1, -1, -1}, {39685, -1, -1, -1}, {39687, -1, -1, -1}, {39689, -1, -1, -1}, {39690, -1, -1, -1}, {39691, -1, -1, -1}, {39692, -1, -1, -1}, {39694, -1, -1, -1}, {39696, -1, -1, -1}, {39697, -1, -1, -1}, {39698, -1, -1, -1}, {39700, -1, -1, -1}, {39701, -1, -1, -1}, {39702, -1, -1, -1}, {39703, -1, -1, -1}, {39704, -1, -1, -1}, {39705, -1, -1, -1}, {39707, -1, -1, -1}, {39708, -1, -1, -1}, {39709, -1, -1, -1}, {39710, -1, -1, -1}, {39712, -1, -1, -1}, {39713, -1, -1, -1}, {39716, -1, -1, -1}, {39718, -1, -1, -1}, {39720, -1, -1, -1}, {39722, -1, -1, -1}, {39723, -1, -1, -1}, {39724, -1, -1, -1}, {39725, -1, -1, -1}, {39728, -1, -1, -1}, {39731, -1, -1, -1}, {39732, -1, -1, -1}, {39733, -1, -1, -1}, {39734, -1, -1, -1}, {39735, -1, -1, -1}, {39736, -1, -1, -1}, {39737, -1, -1, -1}, {39738, -1, -1, -1}, {39741, -1, -1, -1}, {39742, -1, -1, -1}, {39743, -1, -1, -1}, {39744, -1, -1, -1}, {39750, -1, -1, -1}, {39754, -1, -1, -1}, {39755, -1, -1, -1}, {39756, -1, -1, -1}, {39760, -1, -1, -1}, {39762, -1, -1, -1}, {39763, -1, -1, -1}, {39765, -1, -1, -1}, {39766, -1, -1, -1}, {39767, -1, -1, -1}, {39769, -1, -1, -1}, {39771, -1, -1, -1}, {39772, -1, -1, -1}, {39773, -1, -1, -1}, {39774, -1, -1, -1}, {39775, -1, -1, -1}, {39776, -1, -1, -1}, {39777, -1, -1, -1}, {39778, -1, -1, -1}, {39779, -1, -1, -1}, {39780, -1, -1, -1}, {39781, -1, -1, -1}, {39782, -1, -1, -1}, {39783, -1, -1, -1}, {39784, -1, -1, -1}, {39785, -1, -1, -1}, {39786, -1, -1, -1}, {39787, -1, -1, -1}, {39788, -1, -1, -1}, {39789, -1, -1, -1}, {39790, -1, -1, -1}, {39792, -1, -1, -1}, {39793, -1, -1, -1}, {39794, -1, -1, -1}, {39795, -1, -1, -1}, {39797, -1, -1, -1}, {39798, -1, -1, -1}, {39800, -1, -1, -1}, {39801, -1, -1, -1}, {39802, -1, -1, -1}, {39803, -1, -1, -1}, {39804, -1, -1, -1}, {39805, -1, -1, -1}, {39806, -1, -1, -1}, {39807, -1, -1, -1}, {39808, -1, -1, -1}, {39810, -1, -1, -1}, {39812, -1, -1, -1}, {39813, -1, -1, -1}, {39814, -1, -1, -1}, {39815, -1, -1, -1}, {39816, -1, -1, -1}, {39817, -1, -1, -1}, {39818, -1, -1, -1}, {39819, -1, -1, -1}, {39820, -1, -1, -1}, {39821, -1, -1, -1}, {39823, -1, -1, -1}, {39827, -1, -1, -1}, {39828, -1, -1, -1}, {39829, -1, -1, -1}, {39830, -1, -1, -1}, {39831, -1, -1, -1}, {39832, -1, -1, -1}, {39833, -1, -1, -1}, {39835, -1, -1, -1}, {39836, -1, -1, -1}, {39839, -1, -1, -1}, {39840, -1, -1, -1}, {39841, -1, -1, -1}, {39842, -1, -1, -1}, {39843, -1, -1, -1}, {39844, -1, -1, -1}, {39845, -1, -1, -1}, {39846, -1, -1, -1}, {39847, -1, -1, -1}, {39848, -1, -1, -1}, {39849, -1, -1, -1}, {39852, -1, -1, -1}, {39855, -1, -1, -1}, {39856, -1, -1, -1}, {39857, -1, -1, -1}, {39858, -1, -1, -1}, {39859, -1, -1, -1}, {39860, -1, -1, -1}, {39861, -1, -1, -1}, {39862, -1, -1, -1}, {39863, -1, -1, -1}, {39864, -1, -1, -1}, {39865, -1, -1, -1}, {39866, -1, -1, -1}, {39867, -1, -1, -1}, {39868, -1, -1, -1}, {39869, -1, -1, -1}, {39870, -1, -1, -1}, {39871, -1, -1, -1}, {39874, -1, -1, -1}, {39875, -1, -1, -1}, {39876, -1, -1, -1}, {39877, -1, -1, -1}, {39878, -1, -1, -1}, {39880, -1, -1, -1}, {39883, -1, -1, -1}, {39884, -1, -1, -1}, {39885, -1, -1, -1}, {39886, -1, -1, -1}, {39887, -1, -1, -1}, {39888, -1, -1, -1}, {39889, -1, -1, -1}, {39890, -1, -1, -1}, {39891, -1, -1, -1}, {39893, -1, -1, -1}, {39895, -1, -1, -1}, {39896, -1, -1, -1}, {39897, -1, -1, -1}, {39898, -1, -1, -1}, {39900, -1, -1, -1}, {39902, -1, -1, -1}, {39903, -1, -1, -1}, {39904, -1, -1, -1}, {39907, -1, -1, -1}, {39909, -1, -1, -1}, {39910, -1, -1, -1}, {39913, -1, -1, -1}, {39916, -1, -1, -1}, {39917, -1, -1, -1}, {39918, -1, -1, -1}, {39919, -1, -1, -1}, {39921, -1, -1, -1}, {39922, -1, -1, -1}, {39923, -1, -1, -1}, {39925, -1, -1, -1}, {39926, -1, -1, -1}, {39927, -1, -1, -1}, {39928, -1, -1, -1}, {39929, -1, -1, -1}, {39930, -1, -1, -1}, {39931, -1, -1, -1}, {39932, -1, -1, -1}, {39934, -1, -1, -1}, {39936, -1, -1, -1}, {39937, -1, -1, -1}, {39938, -1, -1, -1}, {39939, -1, -1, -1}, {39940, -1, -1, -1}, {39941, -1, -1, -1}, {39942, -1, -1, -1}, {39943, -1, -1, -1}, {39946, -1, -1, -1}, {39947, -1, -1, -1}, {39948, -1, -1, -1}, {39950, -1, -1, -1}, {39951, -1, -1, -1}, {39953, -1, -1, -1}, {39956, -1, -1, -1}, {39957, -1, -1, -1}, {39958, -1, -1, -1}, {39959, -1, -1, -1}, {39960, -1, -1, -1}, {39961, -1, -1, -1}, {39962, -1, -1, -1}, {39963, -1, -1, -1}, {39964, -1, -1, -1}, {39965, -1, -1, -1}, {39966, -1, -1, -1}, {39967, -1, -1, -1}, {39969, -1, -1, -1}, {39970, -1, -1, -1}, {39972, -1, -1, -1}, {39974, -1, -1, -1}, {39975, -1, -1, -1}, {39978, -1, -1, -1}, {39979, -1, -1, -1}, {39980, -1, -1, -1}, {39982, -1, -1, -1}, {39983, -1, -1, -1}, {39984, -1, -1, -1}, {39988, -1, -1, -1}, {39990, -1, -1, -1}, {39992, -1, -1, -1}, {39994, -1, -1, -1}, {39996, -1, -1, -1}, {39997, -1, -1, -1}, {39999, -1, -1, -1}, {40000, -1, -1, -1}, {40001, -1, -1, -1}, {40002, -1, -1, -1}, {40003, -1, -1, -1}, {40004, -1, -1, -1}, {40006, -1, -1, -1}, {40007, -1, -1, -1}, {40010, -1, -1, -1}, {40011, -1, -1, -1}, {40012, -1, -1, -1}, {40013, -1, -1, -1}, {40014, -1, -1, -1}, {40015, -1, -1, -1}, {40016, -1, -1, -1}, {40017, -1, -1, -1}, {40019, -1, -1, -1}, {40021, -1, -1, -1} },
+ {{40025, -1, -1, -1}, {40026, -1, -1, -1}, {40027, -1, -1, -1}, {40028, -1, -1, -1}, {40030, -1, -1, -1}, {40032, -1, -1, -1}, {40033, -1, -1, -1}, {40034, -1, -1, -1}, {40035, -1, -1, -1}, {40036, -1, -1, -1}, {40037, -1, -1, -1}, {40038, -1, -1, -1}, {40040, -1, -1, -1}, {40041, -1, -1, -1}, {40042, -1, -1, -1}, {40043, -1, -1, -1}, {40044, -1, -1, -1}, {40046, -1, -1, -1}, {40047, -1, -1, -1}, {40048, -1, -1, -1}, {40049, -1, -1, -1}, {40050, -1, -1, -1}, {40051, -1, -1, -1}, {40052, -1, -1, -1}, {40053, -1, -1, -1}, {40054, -1, -1, -1}, {40055, -1, -1, -1}, {40057, -1, -1, -1}, {40059, -1, -1, -1}, {40061, -1, -1, -1}, {40062, -1, -1, -1}, {40064, -1, -1, -1}, {40067, -1, -1, -1}, {40068, -1, -1, -1}, {40073, -1, -1, -1}, {40074, -1, -1, -1}, {40076, -1, -1, -1}, {40079, -1, -1, -1}, {40083, -1, -1, -1}, {40086, -1, -1, -1}, {40087, -1, -1, -1}, {40088, -1, -1, -1}, {40089, -1, -1, -1}, {40093, -1, -1, -1}, {40106, -1, -1, -1}, {40108, -1, -1, -1}, {40111, -1, -1, -1}, {40121, -1, -1, -1}, {40126, -1, -1, -1}, {40127, -1, -1, -1}, {40128, -1, -1, -1}, {40129, -1, -1, -1}, {40130, -1, -1, -1}, {40136, -1, -1, -1}, {40137, -1, -1, -1}, {40145, -1, -1, -1}, {40146, -1, -1, -1}, {40154, -1, -1, -1}, {40155, -1, -1, -1}, {40160, -1, -1, -1}, {40161, -1, -1, -1}, {40163, -1, -1, -1}, {40164, -1, -1, -1}, {40166, -1, -1, -1}, {40167, -1, -1, -1}, {40168, -1, -1, -1}, {40170, -1, -1, -1}, {40171, -1, -1, -1}, {40173, -1, -1, -1}, {40174, -1, -1, -1}, {40175, -1, -1, -1}, {40176, -1, -1, -1}, {40177, -1, -1, -1}, {40178, -1, -1, -1}, {40181, -1, -1, -1}, {40183, -1, -1, -1}, {40184, -1, -1, -1}, {40185, -1, -1, -1}, {40186, -1, -1, -1}, {40187, -1, -1, -1}, {40188, -1, -1, -1}, {40189, -1, -1, -1}, {40190, -1, -1, -1}, {40191, -1, -1, -1}, {40192, -1, -1, -1}, {40193, -1, -1, -1}, {40194, -1, -1, -1}, {40195, -1, -1, -1}, {40196, -1, -1, -1}, {40197, -1, -1, -1}, {40200, -1, -1, -1}, {40202, -1, -1, -1}, {40203, -1, -1, -1}, {40204, -1, -1, -1}, {40205, -1, -1, -1}, {40206, -1, -1, -1}, {40207, -1, -1, -1}, {40208, -1, -1, -1}, {40209, -1, -1, -1}, {40210, -1, -1, -1}, {40211, -1, -1, -1}, {40212, -1, -1, -1}, {40214, -1, -1, -1}, {40215, -1, -1, -1}, {40216, -1, -1, -1}, {40217, -1, -1, -1}, {40218, -1, -1, -1}, {40220, -1, -1, -1}, {40222, -1, -1, -1}, {40224, -1, -1, -1}, {40225, -1, -1, -1}, {40226, -1, -1, -1}, {40228, -1, -1, -1}, {40229, -1, -1, -1}, {40231, -1, -1, -1}, {40233, -1, -1, -1}, {40234, -1, -1, -1}, {40235, -1, -1, -1}, {40236, -1, -1, -1}, {40237, -1, -1, -1}, {40238, -1, -1, -1}, {40241, -1, -1, -1}, {40242, -1, -1, -1}, {40243, -1, -1, -1}, {40244, -1, -1, -1}, {40245, -1, -1, -1}, {40246, -1, -1, -1}, {40247, -1, -1, -1}, {40248, -1, -1, -1}, {40249, -1, -1, -1}, {40250, -1, -1, -1}, {40252, -1, -1, -1}, {40253, -1, -1, -1}, {40254, -1, -1, -1}, {40256, -1, -1, -1}, {40257, -1, -1, -1}, {40259, -1, -1, -1}, {40260, -1, -1, -1}, {40261, -1, -1, -1}, {40262, -1, -1, -1}, {40263, -1, -1, -1}, {40264, -1, -1, -1}, {40265, -1, -1, -1}, {40266, -1, -1, -1}, {40267, -1, -1, -1}, {40268, -1, -1, -1}, {40269, -1, -1, -1}, {40270, -1, -1, -1}, {40271, -1, -1, -1}, {40272, -1, -1, -1}, {40276, -1, -1, -1}, {40277, -1, -1, -1}, {40278, -1, -1, -1}, {40279, -1, -1, -1}, {40280, -1, -1, -1}, {40281, -1, -1, -1}, {40282, -1, -1, -1}, {40283, -1, -1, -1}, {40286, -1, -1, -1}, {40287, -1, -1, -1}, {40290, -1, -1, -1}, {40291, -1, -1, -1}, {40292, -1, -1, -1}, {40293, -1, -1, -1}, {40294, -1, -1, -1}, {40295, -1, -1, -1}, {40296, -1, -1, -1}, {40297, -1, -1, -1}, {40299, -1, -1, -1}, {40301, -1, -1, -1}, {40302, -1, -1, -1}, {40304, -1, -1, -1}, {40305, -1, -1, -1}, {40307, -1, -1, -1}, {40308, -1, -1, -1}, {40309, -1, -1, -1}, {40310, -1, -1, -1}, {40311, -1, -1, -1}, {40312, -1, -1, -1}, {40313, -1, -1, -1}, {40314, -1, -1, -1}, {40315, -1, -1, -1}, {40316, -1, -1, -1}, {40317, -1, -1, -1}, {40318, -1, -1, -1}, {40319, -1, -1, -1}, {40320, -1, -1, -1}, {40321, -1, -1, -1}, {40322, -1, -1, -1}, {40323, -1, -1, -1}, {40324, -1, -1, -1}, {40325, -1, -1, -1}, {40326, -1, -1, -1}, {40328, -1, -1, -1}, {40330, -1, -1, -1}, {40331, -1, -1, -1}, {40332, -1, -1, -1}, {40333, -1, -1, -1}, {40334, -1, -1, -1}, {40335, -1, -1, -1}, {40336, -1, -1, -1}, {40337, -1, -1, -1}, {40338, -1, -1, -1}, {40340, -1, -1, -1}, {40341, -1, -1, -1}, {40342, -1, -1, -1}, {40343, -1, -1, -1}, {40345, -1, -1, -1}, {40347, -1, -1, -1}, {40348, -1, -1, -1}, {40349, -1, -1, -1}, {40350, -1, -1, -1}, {40351, -1, -1, -1}, {40352, -1, -1, -1}, {40353, -1, -1, -1}, {40354, -1, -1, -1}, {40355, -1, -1, -1}, {40356, -1, -1, -1}, {40358, -1, -1, -1}, {40359, -1, -1, -1}, {40360, -1, -1, -1}, {40362, -1, -1, -1}, {40363, -1, -1, -1}, {40364, -1, -1, -1}, {40365, -1, -1, -1}, {40366, -1, -1, -1}, {40368, -1, -1, -1}, {40369, -1, -1, -1}, {40370, -1, -1, -1}, {40371, -1, -1, -1}, {40373, -1, -1, -1}, {40374, -1, -1, -1}, {40375, -1, -1, -1}, {40376, -1, -1, -1}, {40377, -1, -1, -1}, {40378, -1, -1, -1}, {40381, -1, -1, -1}, {40382, -1, -1, -1}, {40383, -1, -1, -1}, {40385, -1, -1, -1}, {40387, -1, -1, -1}, {40389, -1, -1, -1}, {40390, -1, -1, -1}, {40391, -1, -1, -1}, {40392, -1, -1, -1}, {40393, -1, -1, -1}, {40394, -1, -1, -1}, {40395, -1, -1, -1}, {40396, -1, -1, -1}, {40397, -1, -1, -1}, {40398, -1, -1, -1}, {40399, -1, -1, -1}, {40400, -1, -1, -1}, {40401, -1, -1, -1}, {40402, -1, -1, -1}, {40404, -1, -1, -1} },
+ {{40405, -1, -1, -1}, {40406, -1, -1, -1}, {40408, -1, -1, -1}, {40411, -1, -1, -1}, {40412, -1, -1, -1}, {40413, -1, -1, -1}, {40414, -1, -1, -1}, {40415, -1, -1, -1}, {40416, -1, -1, -1}, {40417, -1, -1, -1}, {40418, -1, -1, -1}, {40419, -1, -1, -1}, {40420, -1, -1, -1}, {40423, -1, -1, -1}, {40424, -1, -1, -1}, {40425, -1, -1, -1}, {40426, -1, -1, -1}, {40427, -1, -1, -1}, {40428, -1, -1, -1}, {40429, -1, -1, -1}, {40430, -1, -1, -1}, {40432, -1, -1, -1}, {40433, -1, -1, -1}, {40436, -1, -1, -1}, {40437, -1, -1, -1}, {40438, -1, -1, -1}, {40439, -1, -1, -1}, {40443, -1, -1, -1}, {40444, -1, -1, -1}, {40445, -1, -1, -1}, {40446, -1, -1, -1}, {40447, -1, -1, -1}, {40448, -1, -1, -1}, {40449, -1, -1, -1}, {40450, -1, -1, -1}, {40451, -1, -1, -1}, {40452, -1, -1, -1}, {40453, -1, -1, -1}, {40454, -1, -1, -1}, {40455, -1, -1, -1}, {40456, -1, -1, -1}, {40457, -1, -1, -1}, {40458, -1, -1, -1}, {40459, -1, -1, -1}, {40461, -1, -1, -1}, {40462, -1, -1, -1}, {40463, -1, -1, -1}, {40464, -1, -1, -1}, {40465, -1, -1, -1}, {40466, -1, -1, -1}, {40467, -1, -1, -1}, {40468, -1, -1, -1}, {40470, -1, -1, -1}, {40471, -1, -1, -1}, {40472, -1, -1, -1}, {40473, -1, -1, -1}, {40476, -1, -1, -1}, {40484, -1, -1, -1}, {40487, -1, -1, -1}, {40494, -1, -1, -1}, {40496, -1, -1, -1}, {40500, -1, -1, -1}, {40507, -1, -1, -1}, {40508, -1, -1, -1}, {40512, -1, -1, -1}, {40525, -1, -1, -1}, {40528, -1, -1, -1}, {40530, -1, -1, -1}, {40531, -1, -1, -1}, {40532, -1, -1, -1}, {40534, -1, -1, -1}, {40537, -1, -1, -1}, {40541, -1, -1, -1}, {40543, -1, -1, -1}, {40544, -1, -1, -1}, {40545, -1, -1, -1}, {40546, -1, -1, -1}, {40549, -1, -1, -1}, {40558, -1, -1, -1}, {40559, -1, -1, -1}, {40562, -1, -1, -1}, {40564, -1, -1, -1}, {40566, -1, -1, -1}, {40567, -1, -1, -1}, {40568, -1, -1, -1}, {40571, -1, -1, -1}, {40576, -1, -1, -1}, {40577, -1, -1, -1}, {40579, -1, -1, -1}, {40580, -1, -1, -1}, {40581, -1, -1, -1}, {40582, -1, -1, -1}, {40585, -1, -1, -1}, {40586, -1, -1, -1}, {40588, -1, -1, -1}, {40589, -1, -1, -1}, {40590, -1, -1, -1}, {40591, -1, -1, -1}, {40592, -1, -1, -1}, {40593, -1, -1, -1}, {40596, -1, -1, -1}, {40597, -1, -1, -1}, {40598, -1, -1, -1}, {40600, -1, -1, -1}, {40601, -1, -1, -1}, {40602, -1, -1, -1}, {40603, -1, -1, -1}, {40604, -1, -1, -1}, {40606, -1, -1, -1}, {40608, -1, -1, -1}, {40609, -1, -1, -1}, {40610, -1, -1, -1}, {40611, -1, -1, -1}, {40612, -1, -1, -1}, {40615, -1, -1, -1}, {40616, -1, -1, -1}, {40618, -1, -1, -1}, {40619, -1, -1, -1}, {40620, -1, -1, -1}, {40621, -1, -1, -1}, {40622, -1, -1, -1}, {40624, -1, -1, -1}, {40625, -1, -1, -1}, {40626, -1, -1, -1}, {40627, -1, -1, -1}, {40630, -1, -1, -1}, {40631, -1, -1, -1}, {40633, -1, -1, -1}, {40634, -1, -1, -1}, {40636, -1, -1, -1}, {40639, -1, -1, -1}, {40640, -1, -1, -1}, {40641, -1, -1, -1}, {40642, -1, -1, -1}, {12232, 40643, -1, -1}, {40645, -1, -1, -1}, {40646, -1, -1, -1}, {40647, -1, -1, -1}, {40648, -1, -1, -1}, {40650, -1, -1, -1}, {40651, -1, -1, -1}, {40656, -1, -1, -1}, {40658, -1, -1, -1}, {40659, -1, -1, -1}, {40661, -1, -1, -1}, {40662, -1, -1, -1}, {40663, -1, -1, -1}, {40665, -1, -1, -1}, {40666, -1, -1, -1}, {40673, -1, -1, -1}, {40675, -1, -1, -1}, {40676, -1, -1, -1}, {40678, -1, -1, -1}, {40683, -1, -1, -1}, {40684, -1, -1, -1}, {40685, -1, -1, -1}, {40686, -1, -1, -1}, {40688, -1, -1, -1}, {40689, -1, -1, -1}, {40691, -1, -1, -1}, {40693, -1, -1, -1}, {40694, -1, -1, -1}, {40696, -1, -1, -1}, {40698, -1, -1, -1}, {40704, -1, -1, -1}, {40705, -1, -1, -1}, {40706, -1, -1, -1}, {40707, -1, -1, -1}, {40708, -1, -1, -1}, {40709, -1, -1, -1}, {40710, -1, -1, -1}, {40711, -1, -1, -1}, {40712, -1, -1, -1}, {40714, -1, -1, -1}, {40716, -1, -1, -1}, {40719, -1, -1, -1}, {40721, -1, -1, -1}, {40722, -1, -1, -1}, {40724, -1, -1, -1}, {40726, -1, -1, -1}, {40728, -1, -1, -1}, {40730, -1, -1, -1}, {40731, -1, -1, -1}, {40732, -1, -1, -1}, {40733, -1, -1, -1}, {40734, -1, -1, -1}, {40735, -1, -1, -1}, {40737, -1, -1, -1}, {40739, -1, -1, -1}, {40740, -1, -1, -1}, {40741, -1, -1, -1}, {40742, -1, -1, -1}, {40743, -1, -1, -1}, {40744, -1, -1, -1}, {40745, -1, -1, -1}, {40746, -1, -1, -1}, {40747, -1, -1, -1}, {40749, -1, -1, -1}, {40750, -1, -1, -1}, {40752, -1, -1, -1}, {40753, -1, -1, -1}, {40754, -1, -1, -1}, {40755, -1, -1, -1}, {40756, -1, -1, -1}, {40757, -1, -1, -1}, {40758, -1, -1, -1}, {40760, -1, -1, -1}, {40762, -1, -1, -1}, {40764, -1, -1, -1}, {40767, -1, -1, -1}, {40768, -1, -1, -1}, {40769, -1, -1, -1}, {40770, -1, -1, -1}, {40771, -1, -1, -1}, {40773, -1, -1, -1}, {40774, -1, -1, -1}, {40775, -1, -1, -1}, {40776, -1, -1, -1}, {40777, -1, -1, -1}, {40780, -1, -1, -1}, {40781, -1, -1, -1}, {40782, -1, -1, -1}, {40787, -1, -1, -1}, {40789, -1, -1, -1}, {40790, -1, -1, -1}, {40791, -1, -1, -1}, {40792, -1, -1, -1}, {40794, -1, -1, -1}, {40795, -1, -1, -1}, {40797, -1, -1, -1}, {40798, -1, -1, -1}, {40802, -1, -1, -1}, {40804, -1, -1, -1}, {40805, -1, -1, -1}, {40807, -1, -1, -1}, {40808, -1, -1, -1}, {40809, -1, -1, -1}, {40811, -1, -1, -1}, {40813, -1, -1, -1}, {40814, -1, -1, -1}, {40815, -1, -1, -1}, {40816, -1, -1, -1}, {40817, -1, -1, -1}, {40819, -1, -1, -1}, {40820, -1, -1, -1}, {40821, -1, -1, -1}, {40822, -1, -1, -1}, {40824, -1, -1, -1}, {40825, -1, -1, -1}, {40826, -1, -1, -1}, {40827, -1, -1, -1}, {40828, -1, -1, -1}, {40829, -1, -1, -1}, {40830, -1, -1, -1}, {40833, -1, -1, -1}, {40834, -1, -1, -1} },
+ {{40846, -1, -1, -1}, {40847, -1, -1, -1}, {40849, -1, -1, -1}, {40850, -1, -1, -1}, {40851, -1, -1, -1}, {40854, -1, -1, -1}, {40855, -1, -1, -1}, {40856, -1, -1, -1}, {40861, -1, -1, -1}, {40862, -1, -1, -1}, {40865, -1, -1, -1}, {40866, -1, -1, -1}, {40867, -1, -1, -1}, {40868, -1, -1, -1}, {40869, -1, -1, -1}, {63788, -1, -1, -1}, {64013, -1, -1, -1}, {64014, -1, -1, -1}, {64015, -1, -1, -1}, {64017, -1, -1, -1}, {64019, -1, -1, -1}, {64020, -1, -1, -1}, {64024, -1, -1, -1}, {64031, -1, -1, -1}, {64032, -1, -1, -1}, {64033, -1, -1, -1}, {64035, -1, -1, -1}, {64036, -1, -1, -1}, {64039, -1, -1, -1}, {64040, -1, -1, -1}, {64041, -1, -1, -1}, {11905, -1, -1, -1}, {59414, -1, -1, -1}, {59415, -1, -1, -1}, {59416, -1, -1, -1}, {11908, -1, -1, -1}, {13427, -1, -1, -1}, {13383, -1, -1, -1}, {11912, -1, -1, -1}, {11915, -1, -1, -1}, {59422, -1, -1, -1}, {13726, -1, -1, -1}, {13850, -1, -1, -1}, {13838, -1, -1, -1}, {11916, -1, -1, -1}, {11927, -1, -1, -1}, {14702, -1, -1, -1}, {14616, -1, -1, -1}, {59430, -1, -1, -1}, {14799, -1, -1, -1}, {14815, -1, -1, -1}, {14963, -1, -1, -1}, {14800, -1, -1, -1}, {59435, -1, -1, -1}, {59436, -1, -1, -1}, {15182, -1, -1, -1}, {15470, -1, -1, -1}, {15584, -1, -1, -1}, {11943, -1, -1, -1}, {59441, -1, -1, -1}, {59442, -1, -1, -1}, {11946, -1, -1, -1}, {16470, -1, -1, -1}, {16735, -1, -1, -1}, {11950, -1, -1, -1}, {17207, -1, -1, -1}, {11955, -1, -1, -1}, {11958, -1, -1, -1}, {11959, -1, -1, -1}, {59451, -1, -1, -1}, {17329, -1, -1, -1}, {17324, -1, -1, -1}, {11963, -1, -1, -1}, {17373, -1, -1, -1}, {17622, -1, -1, -1}, {18017, -1, -1, -1}, {17996, -1, -1, -1}, {59459, -1, -1, -1}, {18211, -1, -1, -1}, {18217, -1, -1, -1}, {18300, -1, -1, -1}, {18317, -1, -1, -1}, {11978, -1, -1, -1}, {18759, -1, -1, -1}, {18810, -1, -1, -1}, {18813, -1, -1, -1}, {18818, -1, -1, -1}, {18819, -1, -1, -1}, {18821, -1, -1, -1}, {18822, -1, -1, -1}, {18847, -1, -1, -1}, {18843, -1, -1, -1}, {18871, -1, -1, -1}, {18870, -1, -1, -1}, {59476, -1, -1, -1}, {59477, -1, -1, -1}, {19619, -1, -1, -1}, {19615, -1, -1, -1}, {19616, -1, -1, -1}, {19617, -1, -1, -1}, {19575, -1, -1, -1}, {19618, -1, -1, -1}, {19731, -1, -1, -1}, {19732, -1, -1, -1}, {19733, -1, -1, -1}, {19734, -1, -1, -1}, {19735, -1, -1, -1}, {19736, -1, -1, -1}, {19737, -1, -1, -1}, {19886, -1, -1, -1}, {59492, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8364, -1, -1, -1}, {165, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12351, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12436, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12535, -1, -1, -1}, {12536, -1, -1, -1}, {12537, -1, -1, -1}, {12538, -1, -1, -1}, {-1, -1, -1, -1}, {12339, -1, -1, -1}, {12340, -1, -1, -1}, {12341, -1, -1, -1}, {12344, -1, -1, -1}, {12345, -1, -1, -1}, {12346, -1, -1, -1}, {12586, -1, -1, -1}, {12587, -1, -1, -1}, {12588, -1, -1, -1}, {12704, -1, -1, -1}, {12705, -1, -1, -1}, {12706, -1, -1, -1}, {12707, -1, -1, -1}, {12708, -1, -1, -1}, {12709, -1, -1, -1}, {12710, -1, -1, -1}, {12711, -1, -1, -1}, {12712, -1, -1, -1}, {12713, -1, -1, -1}, {12714, -1, -1, -1}, {12715, -1, -1, -1}, {12716, -1, -1, -1}, {12717, -1, -1, -1}, {12718, -1, -1, -1}, {12719, -1, -1, -1}, {12720, -1, -1, -1}, {12721, -1, -1, -1}, {12722, -1, -1, -1}, {12723, -1, -1, -1}, {12724, -1, -1, -1}, {12725, -1, -1, -1}, {12726, -1, -1, -1}, {12727, -1, -1, -1}, {11904, -1, -1, -1}, {11906, -1, -1, -1}, {11907, -1, -1, -1}, {11909, -1, -1, -1}, {11910, -1, -1, -1}, {11911, -1, -1, -1}, {11913, -1, -1, -1}, {11914, -1, -1, -1}, {11917, -1, -1, -1}, {11918, -1, -1, -1}, {11919, -1, -1, -1}, {11920, -1, -1, -1}, {11921, -1, -1, -1}, {11922, -1, -1, -1}, {11923, -1, -1, -1}, {11924, -1, -1, -1}, {11925, -1, -1, -1}, {11926, -1, -1, -1}, {11928, -1, -1, -1}, {11929, -1, -1, -1}, {11931, -1, -1, -1}, {11932, -1, -1, -1}, {11933, -1, -1, -1}, {11934, -1, -1, -1}, {11935, -1, -1, -1}, {11936, -1, -1, -1}, {11937, -1, -1, -1}, {11938, -1, -1, -1}, {11939, -1, -1, -1}, {11940, -1, -1, -1}, {11941, -1, -1, -1}, {11942, -1, -1, -1}, {11944, -1, -1, -1}, {11945, -1, -1, -1}, {11947, -1, -1, -1}, {11948, -1, -1, -1}, {11949, -1, -1, -1}, {11951, -1, -1, -1}, {11952, -1, -1, -1}, {11953, -1, -1, -1}, {11954, -1, -1, -1}, {11956, -1, -1, -1}, {11957, -1, -1, -1}, {11960, -1, -1, -1}, {11961, -1, -1, -1}, {11962, -1, -1, -1}, {11964, -1, -1, -1}, {11965, -1, -1, -1}, {11966, -1, -1, -1}, {11967, -1, -1, -1}, {11968, -1, -1, -1}, {11969, -1, -1, -1}, {11970, -1, -1, -1}, {11971, -1, -1, -1}, {11972, -1, -1, -1}, {11973, -1, -1, -1}, {11974, -1, -1, -1}, {11975, -1, -1, -1}, {11976, -1, -1, -1}, {11977, -1, -1, -1}, {11979, -1, -1, -1}, {11980, -1, -1, -1}, {11981, -1, -1, -1}, {11982, -1, -1, -1}, {11983, -1, -1, -1}, {11984, -1, -1, -1}, {11985, -1, -1, -1}, {11986, -1, -1, -1}, {11987, -1, -1, -1}, {11988, -1, -1, -1}, {11989, -1, -1, -1}, {11990, -1, -1, -1}, {11991, -1, -1, -1}, {11992, -1, -1, -1}, {11993, -1, -1, -1}, {11994, -1, -1, -1}, {11995, -1, -1, -1}, {11996, -1, -1, -1}, {11997, -1, -1, -1}, {11998, -1, -1, -1}, {11999, -1, -1, -1}, {12000, -1, -1, -1}, {12001, -1, -1, -1}, {12002, -1, -1, -1}, {12003, -1, -1, -1}, {12004, -1, -1, -1}, {12005, -1, -1, -1}, {12006, -1, -1, -1}, {12007, -1, -1, -1}, {12008, -1, -1, -1}, {12009, -1, -1, -1}, {12010, -1, -1, -1}, {12011, -1, -1, -1}, {12012, -1, -1, -1}, {12013, -1, -1, -1}, {12014, -1, -1, -1}, {12015, -1, -1, -1}, {12016, -1, -1, -1}, {12017, -1, -1, -1}, {12018, -1, -1, -1} },
+ {{12019, -1, -1, -1}, {13312, -1, -1, -1}, {13313, -1, -1, -1}, {13314, -1, -1, -1}, {13315, -1, -1, -1}, {13316, -1, -1, -1}, {13317, -1, -1, -1}, {13318, -1, -1, -1}, {13319, -1, -1, -1}, {13320, -1, -1, -1}, {13321, -1, -1, -1}, {13322, -1, -1, -1}, {13323, -1, -1, -1}, {13324, -1, -1, -1}, {13325, -1, -1, -1}, {13326, -1, -1, -1}, {13327, -1, -1, -1}, {13328, -1, -1, -1}, {13329, -1, -1, -1}, {13330, -1, -1, -1}, {13331, -1, -1, -1}, {13332, -1, -1, -1}, {13333, -1, -1, -1}, {13334, -1, -1, -1}, {13335, -1, -1, -1}, {13336, -1, -1, -1}, {13337, -1, -1, -1}, {13338, -1, -1, -1}, {13339, -1, -1, -1}, {13340, -1, -1, -1}, {13341, -1, -1, -1}, {13342, -1, -1, -1}, {13343, -1, -1, -1}, {13344, -1, -1, -1}, {13345, -1, -1, -1}, {13346, -1, -1, -1}, {13347, -1, -1, -1}, {13348, -1, -1, -1}, {13349, -1, -1, -1}, {13350, -1, -1, -1}, {13351, -1, -1, -1}, {13352, -1, -1, -1}, {13353, -1, -1, -1}, {13354, -1, -1, -1}, {13355, -1, -1, -1}, {13356, -1, -1, -1}, {13357, -1, -1, -1}, {13358, -1, -1, -1}, {13359, -1, -1, -1}, {13360, -1, -1, -1}, {13361, -1, -1, -1}, {13362, -1, -1, -1}, {13363, -1, -1, -1}, {13364, -1, -1, -1}, {13365, -1, -1, -1}, {13366, -1, -1, -1}, {13367, -1, -1, -1}, {13368, -1, -1, -1}, {13369, -1, -1, -1}, {13370, -1, -1, -1}, {13371, -1, -1, -1}, {13372, -1, -1, -1}, {13373, -1, -1, -1}, {13374, -1, -1, -1}, {13375, -1, -1, -1}, {13376, -1, -1, -1}, {13377, -1, -1, -1}, {13378, -1, -1, -1}, {13379, -1, -1, -1}, {13380, -1, -1, -1}, {13381, -1, -1, -1}, {13382, -1, -1, -1}, {13384, -1, -1, -1}, {13385, -1, -1, -1}, {13386, -1, -1, -1}, {13387, -1, -1, -1}, {13388, -1, -1, -1}, {13389, -1, -1, -1}, {13390, -1, -1, -1}, {13391, -1, -1, -1}, {13392, -1, -1, -1}, {13393, -1, -1, -1}, {13394, -1, -1, -1}, {13395, -1, -1, -1}, {13396, -1, -1, -1}, {13397, -1, -1, -1}, {13398, -1, -1, -1}, {13399, -1, -1, -1}, {13400, -1, -1, -1}, {13401, -1, -1, -1}, {13402, -1, -1, -1}, {13403, -1, -1, -1}, {13404, -1, -1, -1}, {13405, -1, -1, -1}, {13406, -1, -1, -1}, {13407, -1, -1, -1}, {13408, -1, -1, -1}, {13409, -1, -1, -1}, {13410, -1, -1, -1}, {13411, -1, -1, -1}, {13412, -1, -1, -1}, {13413, -1, -1, -1}, {13414, -1, -1, -1}, {13415, -1, -1, -1}, {13416, -1, -1, -1}, {13417, -1, -1, -1}, {13418, -1, -1, -1}, {13419, -1, -1, -1}, {13420, -1, -1, -1}, {13421, -1, -1, -1}, {13422, -1, -1, -1}, {13423, -1, -1, -1}, {13424, -1, -1, -1}, {13425, -1, -1, -1}, {13426, -1, -1, -1}, {13428, -1, -1, -1}, {13429, -1, -1, -1}, {13430, -1, -1, -1}, {13431, -1, -1, -1}, {13432, -1, -1, -1}, {13433, -1, -1, -1}, {13434, -1, -1, -1}, {13435, -1, -1, -1}, {13436, -1, -1, -1}, {13437, -1, -1, -1}, {13438, -1, -1, -1}, {13439, -1, -1, -1}, {13440, -1, -1, -1}, {13441, -1, -1, -1}, {13442, -1, -1, -1}, {13443, -1, -1, -1}, {13444, -1, -1, -1}, {13445, -1, -1, -1}, {13446, -1, -1, -1}, {13447, -1, -1, -1}, {13448, -1, -1, -1}, {13449, -1, -1, -1}, {13450, -1, -1, -1}, {13451, -1, -1, -1}, {13452, -1, -1, -1}, {13453, -1, -1, -1}, {13454, -1, -1, -1}, {13455, -1, -1, -1}, {13456, -1, -1, -1}, {13457, -1, -1, -1}, {13458, -1, -1, -1}, {13459, -1, -1, -1}, {13460, -1, -1, -1}, {13461, -1, -1, -1}, {13462, -1, -1, -1}, {13463, -1, -1, -1}, {13464, -1, -1, -1}, {13465, -1, -1, -1}, {13466, -1, -1, -1}, {13467, -1, -1, -1}, {13468, -1, -1, -1}, {13469, -1, -1, -1}, {13470, -1, -1, -1}, {13471, -1, -1, -1}, {13472, -1, -1, -1}, {13473, -1, -1, -1}, {13474, -1, -1, -1}, {13475, -1, -1, -1}, {13476, -1, -1, -1}, {13477, -1, -1, -1}, {13478, -1, -1, -1}, {13479, -1, -1, -1}, {13480, -1, -1, -1}, {13481, -1, -1, -1}, {13482, -1, -1, -1}, {13483, -1, -1, -1}, {13484, -1, -1, -1}, {13485, -1, -1, -1}, {13486, -1, -1, -1}, {13487, -1, -1, -1}, {13488, -1, -1, -1}, {13489, -1, -1, -1}, {13490, -1, -1, -1}, {13491, -1, -1, -1}, {13492, -1, -1, -1}, {13493, -1, -1, -1}, {13494, -1, -1, -1}, {13495, -1, -1, -1}, {13496, -1, -1, -1}, {13497, -1, -1, -1}, {13498, -1, -1, -1}, {13499, -1, -1, -1}, {13500, -1, -1, -1}, {13501, -1, -1, -1}, {13502, -1, -1, -1}, {13503, -1, -1, -1}, {13504, -1, -1, -1}, {13505, -1, -1, -1}, {13506, -1, -1, -1}, {13507, -1, -1, -1}, {13508, -1, -1, -1}, {13509, -1, -1, -1}, {13510, -1, -1, -1}, {13511, -1, -1, -1}, {13512, -1, -1, -1}, {13513, -1, -1, -1}, {13514, -1, -1, -1}, {13515, -1, -1, -1}, {13516, -1, -1, -1}, {13517, -1, -1, -1}, {13518, -1, -1, -1}, {13519, -1, -1, -1}, {13520, -1, -1, -1}, {13521, -1, -1, -1}, {13522, -1, -1, -1}, {13523, -1, -1, -1}, {13524, -1, -1, -1}, {13525, -1, -1, -1}, {13526, -1, -1, -1}, {13527, -1, -1, -1}, {13528, -1, -1, -1}, {13529, -1, -1, -1}, {13530, -1, -1, -1}, {13531, -1, -1, -1}, {13532, -1, -1, -1}, {13533, -1, -1, -1}, {13534, -1, -1, -1}, {13535, -1, -1, -1}, {13536, -1, -1, -1}, {13537, -1, -1, -1}, {13538, -1, -1, -1}, {13539, -1, -1, -1}, {13540, -1, -1, -1}, {13541, -1, -1, -1}, {13542, -1, -1, -1}, {13543, -1, -1, -1}, {13544, -1, -1, -1}, {13545, -1, -1, -1}, {13546, -1, -1, -1}, {13547, -1, -1, -1}, {13548, -1, -1, -1}, {13549, -1, -1, -1}, {13550, -1, -1, -1}, {13551, -1, -1, -1}, {13552, -1, -1, -1}, {13553, -1, -1, -1}, {13554, -1, -1, -1}, {13555, -1, -1, -1}, {13556, -1, -1, -1}, {13557, -1, -1, -1}, {13558, -1, -1, -1}, {13559, -1, -1, -1}, {13560, -1, -1, -1}, {13561, -1, -1, -1}, {13562, -1, -1, -1}, {13563, -1, -1, -1}, {13564, -1, -1, -1}, {13565, -1, -1, -1}, {13566, -1, -1, -1}, {13567, -1, -1, -1}, {13568, -1, -1, -1} },
+ {{13569, -1, -1, -1}, {13570, -1, -1, -1}, {13571, -1, -1, -1}, {13572, -1, -1, -1}, {13573, -1, -1, -1}, {13574, -1, -1, -1}, {13575, -1, -1, -1}, {13576, -1, -1, -1}, {13577, -1, -1, -1}, {13578, -1, -1, -1}, {13579, -1, -1, -1}, {13580, -1, -1, -1}, {13581, -1, -1, -1}, {13582, -1, -1, -1}, {13583, -1, -1, -1}, {13584, -1, -1, -1}, {13585, -1, -1, -1}, {13586, -1, -1, -1}, {13587, -1, -1, -1}, {13588, -1, -1, -1}, {13589, -1, -1, -1}, {13590, -1, -1, -1}, {13591, -1, -1, -1}, {13592, -1, -1, -1}, {13593, -1, -1, -1}, {13594, -1, -1, -1}, {13595, -1, -1, -1}, {13596, -1, -1, -1}, {13597, -1, -1, -1}, {13598, -1, -1, -1}, {13599, -1, -1, -1}, {13600, -1, -1, -1}, {13601, -1, -1, -1}, {13602, -1, -1, -1}, {13603, -1, -1, -1}, {13604, -1, -1, -1}, {13605, -1, -1, -1}, {13606, -1, -1, -1}, {13607, -1, -1, -1}, {13608, -1, -1, -1}, {13609, -1, -1, -1}, {13610, -1, -1, -1}, {13611, -1, -1, -1}, {13612, -1, -1, -1}, {13613, -1, -1, -1}, {13614, -1, -1, -1}, {13615, -1, -1, -1}, {13616, -1, -1, -1}, {13617, -1, -1, -1}, {13618, -1, -1, -1}, {13619, -1, -1, -1}, {13620, -1, -1, -1}, {13621, -1, -1, -1}, {13622, -1, -1, -1}, {13623, -1, -1, -1}, {13624, -1, -1, -1}, {13625, -1, -1, -1}, {13626, -1, -1, -1}, {13627, -1, -1, -1}, {13628, -1, -1, -1}, {13629, -1, -1, -1}, {13630, -1, -1, -1}, {13631, -1, -1, -1}, {13632, -1, -1, -1}, {13633, -1, -1, -1}, {13634, -1, -1, -1}, {13635, -1, -1, -1}, {13636, -1, -1, -1}, {13637, -1, -1, -1}, {13638, -1, -1, -1}, {13639, -1, -1, -1}, {13640, -1, -1, -1}, {13641, -1, -1, -1}, {13642, -1, -1, -1}, {13643, -1, -1, -1}, {13644, -1, -1, -1}, {13645, -1, -1, -1}, {13646, -1, -1, -1}, {13647, -1, -1, -1}, {13648, -1, -1, -1}, {13649, -1, -1, -1}, {13650, -1, -1, -1}, {13651, -1, -1, -1}, {13652, -1, -1, -1}, {13653, -1, -1, -1}, {13654, -1, -1, -1}, {13655, -1, -1, -1}, {13656, -1, -1, -1}, {13657, -1, -1, -1}, {13658, -1, -1, -1}, {13659, -1, -1, -1}, {13660, -1, -1, -1}, {13661, -1, -1, -1}, {13662, -1, -1, -1}, {13663, -1, -1, -1}, {13664, -1, -1, -1}, {13665, -1, -1, -1}, {13666, -1, -1, -1}, {13667, -1, -1, -1}, {13668, -1, -1, -1}, {13669, -1, -1, -1}, {13670, -1, -1, -1}, {13671, -1, -1, -1}, {13672, -1, -1, -1}, {13673, -1, -1, -1}, {13674, -1, -1, -1}, {13675, -1, -1, -1}, {13676, -1, -1, -1}, {13677, -1, -1, -1}, {13678, -1, -1, -1}, {13679, -1, -1, -1}, {13680, -1, -1, -1}, {13681, -1, -1, -1}, {13682, -1, -1, -1}, {13683, -1, -1, -1}, {13684, -1, -1, -1}, {13685, -1, -1, -1}, {13686, -1, -1, -1}, {13687, -1, -1, -1}, {13688, -1, -1, -1}, {13689, -1, -1, -1}, {13690, -1, -1, -1}, {13691, -1, -1, -1}, {13692, -1, -1, -1}, {13693, -1, -1, -1}, {13694, -1, -1, -1}, {13695, -1, -1, -1}, {13696, -1, -1, -1}, {13697, -1, -1, -1}, {13698, -1, -1, -1}, {13699, -1, -1, -1}, {13700, -1, -1, -1}, {13701, -1, -1, -1}, {13702, -1, -1, -1}, {13703, -1, -1, -1}, {13704, -1, -1, -1}, {13705, -1, -1, -1}, {13706, -1, -1, -1}, {13707, -1, -1, -1}, {13708, -1, -1, -1}, {13709, -1, -1, -1}, {13710, -1, -1, -1}, {13711, -1, -1, -1}, {13712, -1, -1, -1}, {13713, -1, -1, -1}, {13714, -1, -1, -1}, {13715, -1, -1, -1}, {13716, -1, -1, -1}, {13717, -1, -1, -1}, {13718, -1, -1, -1}, {13719, -1, -1, -1}, {13720, -1, -1, -1}, {13721, -1, -1, -1}, {13722, -1, -1, -1}, {13723, -1, -1, -1}, {13724, -1, -1, -1}, {13725, -1, -1, -1}, {13727, -1, -1, -1}, {13728, -1, -1, -1}, {13729, -1, -1, -1}, {13730, -1, -1, -1}, {13731, -1, -1, -1}, {13732, -1, -1, -1}, {13733, -1, -1, -1}, {13734, -1, -1, -1}, {13735, -1, -1, -1}, {13736, -1, -1, -1}, {13737, -1, -1, -1}, {13738, -1, -1, -1}, {13739, -1, -1, -1}, {13740, -1, -1, -1}, {13741, -1, -1, -1}, {13742, -1, -1, -1}, {13743, -1, -1, -1}, {13744, -1, -1, -1}, {13745, -1, -1, -1}, {13746, -1, -1, -1}, {13747, -1, -1, -1}, {13748, -1, -1, -1}, {13749, -1, -1, -1}, {13750, -1, -1, -1}, {13751, -1, -1, -1}, {13752, -1, -1, -1}, {13753, -1, -1, -1}, {13754, -1, -1, -1}, {13755, -1, -1, -1}, {13756, -1, -1, -1}, {13757, -1, -1, -1}, {13758, -1, -1, -1}, {13759, -1, -1, -1}, {13760, -1, -1, -1}, {13761, -1, -1, -1}, {13762, -1, -1, -1}, {13763, -1, -1, -1}, {13764, -1, -1, -1}, {13765, -1, -1, -1}, {13766, -1, -1, -1}, {13767, -1, -1, -1}, {13768, -1, -1, -1}, {13769, -1, -1, -1}, {13770, -1, -1, -1}, {13771, -1, -1, -1}, {13772, -1, -1, -1}, {13773, -1, -1, -1}, {13774, -1, -1, -1}, {13775, -1, -1, -1}, {13776, -1, -1, -1}, {13777, -1, -1, -1}, {13778, -1, -1, -1}, {13779, -1, -1, -1}, {13780, -1, -1, -1}, {13781, -1, -1, -1}, {13782, -1, -1, -1}, {13783, -1, -1, -1}, {13784, -1, -1, -1}, {13785, -1, -1, -1}, {13786, -1, -1, -1}, {13787, -1, -1, -1}, {13788, -1, -1, -1}, {13789, -1, -1, -1}, {13790, -1, -1, -1}, {13791, -1, -1, -1}, {13792, -1, -1, -1}, {13793, -1, -1, -1}, {13794, -1, -1, -1}, {13795, -1, -1, -1}, {13796, -1, -1, -1}, {13797, -1, -1, -1}, {13798, -1, -1, -1}, {13799, -1, -1, -1}, {13800, -1, -1, -1}, {13801, -1, -1, -1}, {13802, -1, -1, -1}, {13803, -1, -1, -1}, {13804, -1, -1, -1}, {13805, -1, -1, -1}, {13806, -1, -1, -1}, {13807, -1, -1, -1}, {13808, -1, -1, -1}, {13809, -1, -1, -1}, {13810, -1, -1, -1}, {13811, -1, -1, -1}, {13812, -1, -1, -1}, {13813, -1, -1, -1}, {13814, -1, -1, -1}, {13815, -1, -1, -1}, {13816, -1, -1, -1}, {13817, -1, -1, -1}, {13818, -1, -1, -1}, {13819, -1, -1, -1}, {13820, -1, -1, -1}, {13821, -1, -1, -1}, {13822, -1, -1, -1}, {13823, -1, -1, -1}, {13824, -1, -1, -1}, {13825, -1, -1, -1} },
+ {{13826, -1, -1, -1}, {13827, -1, -1, -1}, {13828, -1, -1, -1}, {13829, -1, -1, -1}, {13830, -1, -1, -1}, {13831, -1, -1, -1}, {13832, -1, -1, -1}, {13833, -1, -1, -1}, {13834, -1, -1, -1}, {13835, -1, -1, -1}, {13836, -1, -1, -1}, {13837, -1, -1, -1}, {13839, -1, -1, -1}, {13840, -1, -1, -1}, {13841, -1, -1, -1}, {13842, -1, -1, -1}, {13843, -1, -1, -1}, {13844, -1, -1, -1}, {13845, -1, -1, -1}, {13846, -1, -1, -1}, {13847, -1, -1, -1}, {13848, -1, -1, -1}, {13849, -1, -1, -1}, {13851, -1, -1, -1}, {13852, -1, -1, -1}, {13853, -1, -1, -1}, {13854, -1, -1, -1}, {13855, -1, -1, -1}, {13856, -1, -1, -1}, {13857, -1, -1, -1}, {13858, -1, -1, -1}, {13859, -1, -1, -1}, {13860, -1, -1, -1}, {13861, -1, -1, -1}, {13862, -1, -1, -1}, {13863, -1, -1, -1}, {13864, -1, -1, -1}, {13865, -1, -1, -1}, {13866, -1, -1, -1}, {13867, -1, -1, -1}, {13868, -1, -1, -1}, {13869, -1, -1, -1}, {13870, -1, -1, -1}, {13871, -1, -1, -1}, {13872, -1, -1, -1}, {13873, -1, -1, -1}, {13874, -1, -1, -1}, {13875, -1, -1, -1}, {13876, -1, -1, -1}, {13877, -1, -1, -1}, {13878, -1, -1, -1}, {13879, -1, -1, -1}, {13880, -1, -1, -1}, {13881, -1, -1, -1}, {13882, -1, -1, -1}, {13883, -1, -1, -1}, {13884, -1, -1, -1}, {13885, -1, -1, -1}, {13886, -1, -1, -1}, {13887, -1, -1, -1}, {13888, -1, -1, -1}, {13889, -1, -1, -1}, {13890, -1, -1, -1}, {13891, -1, -1, -1}, {13892, -1, -1, -1}, {13893, -1, -1, -1}, {13894, -1, -1, -1}, {13895, -1, -1, -1}, {13896, -1, -1, -1}, {13897, -1, -1, -1}, {13898, -1, -1, -1}, {13899, -1, -1, -1}, {13900, -1, -1, -1}, {13901, -1, -1, -1}, {13902, -1, -1, -1}, {13903, -1, -1, -1}, {13904, -1, -1, -1}, {13905, -1, -1, -1}, {13906, -1, -1, -1}, {13907, -1, -1, -1}, {13908, -1, -1, -1}, {13909, -1, -1, -1}, {13910, -1, -1, -1}, {13911, -1, -1, -1}, {13912, -1, -1, -1}, {13913, -1, -1, -1}, {13914, -1, -1, -1}, {13915, -1, -1, -1}, {13916, -1, -1, -1}, {13917, -1, -1, -1}, {13918, -1, -1, -1}, {13919, -1, -1, -1}, {13920, -1, -1, -1}, {13921, -1, -1, -1}, {13922, -1, -1, -1}, {13923, -1, -1, -1}, {13924, -1, -1, -1}, {13925, -1, -1, -1}, {13926, -1, -1, -1}, {13927, -1, -1, -1}, {13928, -1, -1, -1}, {13929, -1, -1, -1}, {13930, -1, -1, -1}, {13931, -1, -1, -1}, {13932, -1, -1, -1}, {13933, -1, -1, -1}, {13934, -1, -1, -1}, {13935, -1, -1, -1}, {13936, -1, -1, -1}, {13937, -1, -1, -1}, {13938, -1, -1, -1}, {13939, -1, -1, -1}, {13940, -1, -1, -1}, {13941, -1, -1, -1}, {13942, -1, -1, -1}, {13943, -1, -1, -1}, {13944, -1, -1, -1}, {13945, -1, -1, -1}, {13946, -1, -1, -1}, {13947, -1, -1, -1}, {13948, -1, -1, -1}, {13949, -1, -1, -1}, {13950, -1, -1, -1}, {13951, -1, -1, -1}, {13952, -1, -1, -1}, {13953, -1, -1, -1}, {13954, -1, -1, -1}, {13955, -1, -1, -1}, {13956, -1, -1, -1}, {13957, -1, -1, -1}, {13958, -1, -1, -1}, {13959, -1, -1, -1}, {13960, -1, -1, -1}, {13961, -1, -1, -1}, {13962, -1, -1, -1}, {13963, -1, -1, -1}, {13964, -1, -1, -1}, {13965, -1, -1, -1}, {13966, -1, -1, -1}, {13967, -1, -1, -1}, {13968, -1, -1, -1}, {13969, -1, -1, -1}, {13970, -1, -1, -1}, {13971, -1, -1, -1}, {13972, -1, -1, -1}, {13973, -1, -1, -1}, {13974, -1, -1, -1}, {13975, -1, -1, -1}, {13976, -1, -1, -1}, {13977, -1, -1, -1}, {13978, -1, -1, -1}, {13979, -1, -1, -1}, {13980, -1, -1, -1}, {13981, -1, -1, -1}, {13982, -1, -1, -1}, {13983, -1, -1, -1}, {13984, -1, -1, -1}, {13985, -1, -1, -1}, {13986, -1, -1, -1}, {13987, -1, -1, -1}, {13988, -1, -1, -1}, {13989, -1, -1, -1}, {13990, -1, -1, -1}, {13991, -1, -1, -1}, {13992, -1, -1, -1}, {13993, -1, -1, -1}, {13994, -1, -1, -1}, {13995, -1, -1, -1}, {13996, -1, -1, -1}, {13997, -1, -1, -1}, {13998, -1, -1, -1}, {13999, -1, -1, -1}, {14000, -1, -1, -1}, {14001, -1, -1, -1}, {14002, -1, -1, -1}, {14003, -1, -1, -1}, {14004, -1, -1, -1}, {14005, -1, -1, -1}, {14006, -1, -1, -1}, {14007, -1, -1, -1}, {14008, -1, -1, -1}, {14009, -1, -1, -1}, {14010, -1, -1, -1}, {14011, -1, -1, -1}, {14012, -1, -1, -1}, {14013, -1, -1, -1}, {14014, -1, -1, -1}, {14015, -1, -1, -1}, {14016, -1, -1, -1}, {14017, -1, -1, -1}, {14018, -1, -1, -1}, {14019, -1, -1, -1}, {14020, -1, -1, -1}, {14021, -1, -1, -1}, {14022, -1, -1, -1}, {14023, -1, -1, -1}, {14024, -1, -1, -1}, {14025, -1, -1, -1}, {14026, -1, -1, -1}, {14027, -1, -1, -1}, {14028, -1, -1, -1}, {14029, -1, -1, -1}, {14030, -1, -1, -1}, {14031, -1, -1, -1}, {14032, -1, -1, -1}, {14033, -1, -1, -1}, {14034, -1, -1, -1}, {14035, -1, -1, -1}, {14036, -1, -1, -1}, {14037, -1, -1, -1}, {14038, -1, -1, -1}, {14039, -1, -1, -1}, {14040, -1, -1, -1}, {14041, -1, -1, -1}, {14042, -1, -1, -1}, {14043, -1, -1, -1}, {14044, -1, -1, -1}, {14045, -1, -1, -1}, {14046, -1, -1, -1}, {14047, -1, -1, -1}, {14048, -1, -1, -1}, {14049, -1, -1, -1}, {14050, -1, -1, -1}, {14051, -1, -1, -1}, {14052, -1, -1, -1}, {14053, -1, -1, -1}, {14054, -1, -1, -1}, {14055, -1, -1, -1}, {14056, -1, -1, -1}, {14057, -1, -1, -1}, {14058, -1, -1, -1}, {14059, -1, -1, -1}, {14060, -1, -1, -1}, {14061, -1, -1, -1}, {14062, -1, -1, -1}, {14063, -1, -1, -1}, {14064, -1, -1, -1}, {14065, -1, -1, -1}, {14066, -1, -1, -1}, {14067, -1, -1, -1}, {14068, -1, -1, -1}, {14069, -1, -1, -1}, {14070, -1, -1, -1}, {14071, -1, -1, -1}, {14072, -1, -1, -1}, {14073, -1, -1, -1}, {14074, -1, -1, -1}, {14075, -1, -1, -1}, {14076, -1, -1, -1}, {14077, -1, -1, -1}, {14078, -1, -1, -1}, {14079, -1, -1, -1}, {14080, -1, -1, -1}, {14081, -1, -1, -1}, {14082, -1, -1, -1}, {14083, -1, -1, -1} },
+ {{14084, -1, -1, -1}, {14085, -1, -1, -1}, {14086, -1, -1, -1}, {14087, -1, -1, -1}, {14088, -1, -1, -1}, {14089, -1, -1, -1}, {14090, -1, -1, -1}, {14091, -1, -1, -1}, {14092, -1, -1, -1}, {14093, -1, -1, -1}, {14094, -1, -1, -1}, {14095, -1, -1, -1}, {14096, -1, -1, -1}, {14097, -1, -1, -1}, {14098, -1, -1, -1}, {14099, -1, -1, -1}, {14100, -1, -1, -1}, {14101, -1, -1, -1}, {14102, -1, -1, -1}, {14103, -1, -1, -1}, {14104, -1, -1, -1}, {14105, -1, -1, -1}, {14106, -1, -1, -1}, {14107, -1, -1, -1}, {14108, -1, -1, -1}, {14109, -1, -1, -1}, {14110, -1, -1, -1}, {14111, -1, -1, -1}, {14112, -1, -1, -1}, {14113, -1, -1, -1}, {14114, -1, -1, -1}, {14115, -1, -1, -1}, {14116, -1, -1, -1}, {14117, -1, -1, -1}, {14118, -1, -1, -1}, {14119, -1, -1, -1}, {14120, -1, -1, -1}, {14121, -1, -1, -1}, {14122, -1, -1, -1}, {14123, -1, -1, -1}, {14124, -1, -1, -1}, {14125, -1, -1, -1}, {14126, -1, -1, -1}, {14127, -1, -1, -1}, {14128, -1, -1, -1}, {14129, -1, -1, -1}, {14130, -1, -1, -1}, {14131, -1, -1, -1}, {14132, -1, -1, -1}, {14133, -1, -1, -1}, {14134, -1, -1, -1}, {14135, -1, -1, -1}, {14136, -1, -1, -1}, {14137, -1, -1, -1}, {14138, -1, -1, -1}, {14139, -1, -1, -1}, {14140, -1, -1, -1}, {14141, -1, -1, -1}, {14142, -1, -1, -1}, {14143, -1, -1, -1}, {14144, -1, -1, -1}, {14145, -1, -1, -1}, {14146, -1, -1, -1}, {14147, -1, -1, -1}, {14148, -1, -1, -1}, {14149, -1, -1, -1}, {14150, -1, -1, -1}, {14151, -1, -1, -1}, {14152, -1, -1, -1}, {14153, -1, -1, -1}, {14154, -1, -1, -1}, {14155, -1, -1, -1}, {14156, -1, -1, -1}, {14157, -1, -1, -1}, {14158, -1, -1, -1}, {14159, -1, -1, -1}, {14160, -1, -1, -1}, {14161, -1, -1, -1}, {14162, -1, -1, -1}, {14163, -1, -1, -1}, {14164, -1, -1, -1}, {14165, -1, -1, -1}, {14166, -1, -1, -1}, {14167, -1, -1, -1}, {14168, -1, -1, -1}, {14169, -1, -1, -1}, {14170, -1, -1, -1}, {14171, -1, -1, -1}, {14172, -1, -1, -1}, {14173, -1, -1, -1}, {14174, -1, -1, -1}, {14175, -1, -1, -1}, {14176, -1, -1, -1}, {14177, -1, -1, -1}, {14178, -1, -1, -1}, {14179, -1, -1, -1}, {14180, -1, -1, -1}, {14181, -1, -1, -1}, {14182, -1, -1, -1}, {14183, -1, -1, -1}, {14184, -1, -1, -1}, {14185, -1, -1, -1}, {14186, -1, -1, -1}, {14187, -1, -1, -1}, {14188, -1, -1, -1}, {14189, -1, -1, -1}, {14190, -1, -1, -1}, {14191, -1, -1, -1}, {14192, -1, -1, -1}, {14193, -1, -1, -1}, {14194, -1, -1, -1}, {14195, -1, -1, -1}, {14196, -1, -1, -1}, {14197, -1, -1, -1}, {14198, -1, -1, -1}, {14199, -1, -1, -1}, {14200, -1, -1, -1}, {14201, -1, -1, -1}, {14202, -1, -1, -1}, {14203, -1, -1, -1}, {14204, -1, -1, -1}, {14205, -1, -1, -1}, {14206, -1, -1, -1}, {14207, -1, -1, -1}, {14208, -1, -1, -1}, {14209, -1, -1, -1}, {14210, -1, -1, -1}, {14211, -1, -1, -1}, {14212, -1, -1, -1}, {14213, -1, -1, -1}, {14214, -1, -1, -1}, {14215, -1, -1, -1}, {14216, -1, -1, -1}, {14217, -1, -1, -1}, {14218, -1, -1, -1}, {14219, -1, -1, -1}, {14220, -1, -1, -1}, {14221, -1, -1, -1}, {14222, -1, -1, -1}, {14223, -1, -1, -1}, {14224, -1, -1, -1}, {14225, -1, -1, -1}, {14226, -1, -1, -1}, {14227, -1, -1, -1}, {14228, -1, -1, -1}, {14229, -1, -1, -1}, {14230, -1, -1, -1}, {14231, -1, -1, -1}, {14232, -1, -1, -1}, {14233, -1, -1, -1}, {14234, -1, -1, -1}, {14235, -1, -1, -1}, {14236, -1, -1, -1}, {14237, -1, -1, -1}, {14238, -1, -1, -1}, {14239, -1, -1, -1}, {14240, -1, -1, -1}, {14241, -1, -1, -1}, {14242, -1, -1, -1}, {14243, -1, -1, -1}, {14244, -1, -1, -1}, {14245, -1, -1, -1}, {14246, -1, -1, -1}, {14247, -1, -1, -1}, {14248, -1, -1, -1}, {14249, -1, -1, -1}, {14250, -1, -1, -1}, {14251, -1, -1, -1}, {14252, -1, -1, -1}, {14253, -1, -1, -1}, {14254, -1, -1, -1}, {14255, -1, -1, -1}, {14256, -1, -1, -1}, {14257, -1, -1, -1}, {14258, -1, -1, -1}, {14259, -1, -1, -1}, {14260, -1, -1, -1}, {14261, -1, -1, -1}, {14262, -1, -1, -1}, {14263, -1, -1, -1}, {14264, -1, -1, -1}, {14265, -1, -1, -1}, {14266, -1, -1, -1}, {14267, -1, -1, -1}, {14268, -1, -1, -1}, {14269, -1, -1, -1}, {14270, -1, -1, -1}, {14271, -1, -1, -1}, {14272, -1, -1, -1}, {14273, -1, -1, -1}, {14274, -1, -1, -1}, {14275, -1, -1, -1}, {14276, -1, -1, -1}, {14277, -1, -1, -1}, {14278, -1, -1, -1}, {14279, -1, -1, -1}, {14280, -1, -1, -1}, {14281, -1, -1, -1}, {14282, -1, -1, -1}, {14283, -1, -1, -1}, {14284, -1, -1, -1}, {14285, -1, -1, -1}, {14286, -1, -1, -1}, {14287, -1, -1, -1}, {14288, -1, -1, -1}, {14289, -1, -1, -1}, {14290, -1, -1, -1}, {14291, -1, -1, -1}, {14292, -1, -1, -1}, {14293, -1, -1, -1}, {14294, -1, -1, -1}, {14295, -1, -1, -1}, {14296, -1, -1, -1}, {14297, -1, -1, -1}, {14298, -1, -1, -1}, {14299, -1, -1, -1}, {14300, -1, -1, -1}, {14301, -1, -1, -1}, {14302, -1, -1, -1}, {14303, -1, -1, -1}, {14304, -1, -1, -1}, {14305, -1, -1, -1}, {14306, -1, -1, -1}, {14307, -1, -1, -1}, {14308, -1, -1, -1}, {14309, -1, -1, -1}, {14310, -1, -1, -1}, {14311, -1, -1, -1}, {14312, -1, -1, -1}, {14313, -1, -1, -1}, {14314, -1, -1, -1}, {14315, -1, -1, -1}, {14316, -1, -1, -1}, {14317, -1, -1, -1}, {14318, -1, -1, -1}, {14319, -1, -1, -1}, {14320, -1, -1, -1}, {14321, -1, -1, -1}, {14322, -1, -1, -1}, {14323, -1, -1, -1}, {14324, -1, -1, -1}, {14325, -1, -1, -1}, {14326, -1, -1, -1}, {14327, -1, -1, -1}, {14328, -1, -1, -1}, {14329, -1, -1, -1}, {14330, -1, -1, -1}, {14331, -1, -1, -1}, {14332, -1, -1, -1}, {14333, -1, -1, -1}, {14334, -1, -1, -1}, {14335, -1, -1, -1}, {14336, -1, -1, -1}, {14337, -1, -1, -1}, {14338, -1, -1, -1}, {14339, -1, -1, -1} },
+ {{14340, -1, -1, -1}, {14341, -1, -1, -1}, {14342, -1, -1, -1}, {14343, -1, -1, -1}, {14344, -1, -1, -1}, {14345, -1, -1, -1}, {14346, -1, -1, -1}, {14347, -1, -1, -1}, {14348, -1, -1, -1}, {14349, -1, -1, -1}, {14350, -1, -1, -1}, {14351, -1, -1, -1}, {14352, -1, -1, -1}, {14353, -1, -1, -1}, {14354, -1, -1, -1}, {14355, -1, -1, -1}, {14356, -1, -1, -1}, {14357, -1, -1, -1}, {14358, -1, -1, -1}, {14359, -1, -1, -1}, {14360, -1, -1, -1}, {14361, -1, -1, -1}, {14362, -1, -1, -1}, {14363, -1, -1, -1}, {14364, -1, -1, -1}, {14365, -1, -1, -1}, {14366, -1, -1, -1}, {14367, -1, -1, -1}, {14368, -1, -1, -1}, {14369, -1, -1, -1}, {14370, -1, -1, -1}, {14371, -1, -1, -1}, {14372, -1, -1, -1}, {14373, -1, -1, -1}, {14374, -1, -1, -1}, {14375, -1, -1, -1}, {14376, -1, -1, -1}, {14377, -1, -1, -1}, {14378, -1, -1, -1}, {14379, -1, -1, -1}, {14380, -1, -1, -1}, {14381, -1, -1, -1}, {14382, -1, -1, -1}, {14383, -1, -1, -1}, {14384, -1, -1, -1}, {14385, -1, -1, -1}, {14386, -1, -1, -1}, {14387, -1, -1, -1}, {14388, -1, -1, -1}, {14389, -1, -1, -1}, {14390, -1, -1, -1}, {14391, -1, -1, -1}, {14392, -1, -1, -1}, {14393, -1, -1, -1}, {14394, -1, -1, -1}, {14395, -1, -1, -1}, {14396, -1, -1, -1}, {14397, -1, -1, -1}, {14398, -1, -1, -1}, {14399, -1, -1, -1}, {14400, -1, -1, -1}, {14401, -1, -1, -1}, {14402, -1, -1, -1}, {14403, -1, -1, -1}, {14404, -1, -1, -1}, {14405, -1, -1, -1}, {14406, -1, -1, -1}, {14407, -1, -1, -1}, {14408, -1, -1, -1}, {14409, -1, -1, -1}, {14410, -1, -1, -1}, {14411, -1, -1, -1}, {14412, -1, -1, -1}, {14413, -1, -1, -1}, {14414, -1, -1, -1}, {14415, -1, -1, -1}, {14416, -1, -1, -1}, {14417, -1, -1, -1}, {14418, -1, -1, -1}, {14419, -1, -1, -1}, {14420, -1, -1, -1}, {14421, -1, -1, -1}, {14422, -1, -1, -1}, {14423, -1, -1, -1}, {14424, -1, -1, -1}, {14425, -1, -1, -1}, {14426, -1, -1, -1}, {14427, -1, -1, -1}, {14428, -1, -1, -1}, {14429, -1, -1, -1}, {14430, -1, -1, -1}, {14431, -1, -1, -1}, {14432, -1, -1, -1}, {14433, -1, -1, -1}, {14434, -1, -1, -1}, {14435, -1, -1, -1}, {14436, -1, -1, -1}, {14437, -1, -1, -1}, {14438, -1, -1, -1}, {14439, -1, -1, -1}, {14440, -1, -1, -1}, {14441, -1, -1, -1}, {14442, -1, -1, -1}, {14443, -1, -1, -1}, {14444, -1, -1, -1}, {14445, -1, -1, -1}, {14446, -1, -1, -1}, {14447, -1, -1, -1}, {14448, -1, -1, -1}, {14449, -1, -1, -1}, {14450, -1, -1, -1}, {14451, -1, -1, -1}, {14452, -1, -1, -1}, {14453, -1, -1, -1}, {14454, -1, -1, -1}, {14455, -1, -1, -1}, {14456, -1, -1, -1}, {14457, -1, -1, -1}, {14458, -1, -1, -1}, {14459, -1, -1, -1}, {14460, -1, -1, -1}, {14461, -1, -1, -1}, {14462, -1, -1, -1}, {14463, -1, -1, -1}, {14464, -1, -1, -1}, {14465, -1, -1, -1}, {14466, -1, -1, -1}, {14467, -1, -1, -1}, {14468, -1, -1, -1}, {14469, -1, -1, -1}, {14470, -1, -1, -1}, {14471, -1, -1, -1}, {14472, -1, -1, -1}, {14473, -1, -1, -1}, {14474, -1, -1, -1}, {14475, -1, -1, -1}, {14476, -1, -1, -1}, {14477, -1, -1, -1}, {14478, -1, -1, -1}, {14479, -1, -1, -1}, {14480, -1, -1, -1}, {14481, -1, -1, -1}, {14482, -1, -1, -1}, {14483, -1, -1, -1}, {14484, -1, -1, -1}, {14485, -1, -1, -1}, {14486, -1, -1, -1}, {14487, -1, -1, -1}, {14488, -1, -1, -1}, {14489, -1, -1, -1}, {14490, -1, -1, -1}, {14491, -1, -1, -1}, {14492, -1, -1, -1}, {14493, -1, -1, -1}, {14494, -1, -1, -1}, {14495, -1, -1, -1}, {14496, -1, -1, -1}, {14497, -1, -1, -1}, {14498, -1, -1, -1}, {14499, -1, -1, -1}, {14500, -1, -1, -1}, {14501, -1, -1, -1}, {14502, -1, -1, -1}, {14503, -1, -1, -1}, {14504, -1, -1, -1}, {14505, -1, -1, -1}, {14506, -1, -1, -1}, {14507, -1, -1, -1}, {14508, -1, -1, -1}, {14509, -1, -1, -1}, {14510, -1, -1, -1}, {14511, -1, -1, -1}, {14512, -1, -1, -1}, {14513, -1, -1, -1}, {14514, -1, -1, -1}, {14515, -1, -1, -1}, {14516, -1, -1, -1}, {14517, -1, -1, -1}, {14518, -1, -1, -1}, {14519, -1, -1, -1}, {14520, -1, -1, -1}, {14521, -1, -1, -1}, {14522, -1, -1, -1}, {14523, -1, -1, -1}, {14524, -1, -1, -1}, {14525, -1, -1, -1}, {14526, -1, -1, -1}, {14527, -1, -1, -1}, {14528, -1, -1, -1}, {14529, -1, -1, -1}, {14530, -1, -1, -1}, {14531, -1, -1, -1}, {14532, -1, -1, -1}, {14533, -1, -1, -1}, {14534, -1, -1, -1}, {14535, -1, -1, -1}, {14536, -1, -1, -1}, {14537, -1, -1, -1}, {14538, -1, -1, -1}, {14539, -1, -1, -1}, {14540, -1, -1, -1}, {14541, -1, -1, -1}, {14542, -1, -1, -1}, {14543, -1, -1, -1}, {14544, -1, -1, -1}, {14545, -1, -1, -1}, {14546, -1, -1, -1}, {14547, -1, -1, -1}, {14548, -1, -1, -1}, {14549, -1, -1, -1}, {14550, -1, -1, -1}, {14551, -1, -1, -1}, {14552, -1, -1, -1}, {14553, -1, -1, -1}, {14554, -1, -1, -1}, {14555, -1, -1, -1}, {14556, -1, -1, -1}, {14557, -1, -1, -1}, {14558, -1, -1, -1}, {14559, -1, -1, -1}, {14560, -1, -1, -1}, {14561, -1, -1, -1}, {14562, -1, -1, -1}, {14563, -1, -1, -1}, {14564, -1, -1, -1}, {14565, -1, -1, -1}, {14566, -1, -1, -1}, {14567, -1, -1, -1}, {14568, -1, -1, -1}, {14569, -1, -1, -1}, {14570, -1, -1, -1}, {14571, -1, -1, -1}, {14572, -1, -1, -1}, {14573, -1, -1, -1}, {14574, -1, -1, -1}, {14575, -1, -1, -1}, {14576, -1, -1, -1}, {14577, -1, -1, -1}, {14578, -1, -1, -1}, {14579, -1, -1, -1}, {14580, -1, -1, -1}, {14581, -1, -1, -1}, {14582, -1, -1, -1}, {14583, -1, -1, -1}, {14584, -1, -1, -1}, {14585, -1, -1, -1}, {14586, -1, -1, -1}, {14587, -1, -1, -1}, {14588, -1, -1, -1}, {14589, -1, -1, -1}, {14590, -1, -1, -1}, {14591, -1, -1, -1}, {14592, -1, -1, -1}, {14593, -1, -1, -1}, {14594, -1, -1, -1}, {14595, -1, -1, -1} },
+ {{14596, -1, -1, -1}, {14597, -1, -1, -1}, {14598, -1, -1, -1}, {14599, -1, -1, -1}, {14600, -1, -1, -1}, {14601, -1, -1, -1}, {14602, -1, -1, -1}, {14603, -1, -1, -1}, {14604, -1, -1, -1}, {14605, -1, -1, -1}, {14606, -1, -1, -1}, {14607, -1, -1, -1}, {14608, -1, -1, -1}, {14609, -1, -1, -1}, {14610, -1, -1, -1}, {14611, -1, -1, -1}, {14612, -1, -1, -1}, {14613, -1, -1, -1}, {14614, -1, -1, -1}, {14615, -1, -1, -1}, {14617, -1, -1, -1}, {14618, -1, -1, -1}, {14619, -1, -1, -1}, {14620, -1, -1, -1}, {14621, -1, -1, -1}, {14622, -1, -1, -1}, {14623, -1, -1, -1}, {14624, -1, -1, -1}, {14625, -1, -1, -1}, {14626, -1, -1, -1}, {14627, -1, -1, -1}, {14628, -1, -1, -1}, {14629, -1, -1, -1}, {14630, -1, -1, -1}, {14631, -1, -1, -1}, {14632, -1, -1, -1}, {14633, -1, -1, -1}, {14634, -1, -1, -1}, {14635, -1, -1, -1}, {14636, -1, -1, -1}, {14637, -1, -1, -1}, {14638, -1, -1, -1}, {14639, -1, -1, -1}, {14640, -1, -1, -1}, {14641, -1, -1, -1}, {14642, -1, -1, -1}, {14643, -1, -1, -1}, {14644, -1, -1, -1}, {14645, -1, -1, -1}, {14646, -1, -1, -1}, {14647, -1, -1, -1}, {14648, -1, -1, -1}, {14649, -1, -1, -1}, {14650, -1, -1, -1}, {14651, -1, -1, -1}, {14652, -1, -1, -1}, {14653, -1, -1, -1}, {14654, -1, -1, -1}, {14655, -1, -1, -1}, {14656, -1, -1, -1}, {14657, -1, -1, -1}, {14658, -1, -1, -1}, {14659, -1, -1, -1}, {14660, -1, -1, -1}, {14661, -1, -1, -1}, {14662, -1, -1, -1}, {14663, -1, -1, -1}, {14664, -1, -1, -1}, {14665, -1, -1, -1}, {14666, -1, -1, -1}, {14667, -1, -1, -1}, {14668, -1, -1, -1}, {14669, -1, -1, -1}, {14670, -1, -1, -1}, {14671, -1, -1, -1}, {14672, -1, -1, -1}, {14673, -1, -1, -1}, {14674, -1, -1, -1}, {14675, -1, -1, -1}, {14676, -1, -1, -1}, {14677, -1, -1, -1}, {14678, -1, -1, -1}, {14679, -1, -1, -1}, {14680, -1, -1, -1}, {14681, -1, -1, -1}, {14682, -1, -1, -1}, {14683, -1, -1, -1}, {14684, -1, -1, -1}, {14685, -1, -1, -1}, {14686, -1, -1, -1}, {14687, -1, -1, -1}, {14688, -1, -1, -1}, {14689, -1, -1, -1}, {14690, -1, -1, -1}, {14691, -1, -1, -1}, {14692, -1, -1, -1}, {14693, -1, -1, -1}, {14694, -1, -1, -1}, {14695, -1, -1, -1}, {14696, -1, -1, -1}, {14697, -1, -1, -1}, {14698, -1, -1, -1}, {14699, -1, -1, -1}, {14700, -1, -1, -1}, {14701, -1, -1, -1}, {14703, -1, -1, -1}, {14704, -1, -1, -1}, {14705, -1, -1, -1}, {14706, -1, -1, -1}, {14707, -1, -1, -1}, {14708, -1, -1, -1}, {14709, -1, -1, -1}, {14710, -1, -1, -1}, {14711, -1, -1, -1}, {14712, -1, -1, -1}, {14713, -1, -1, -1}, {14714, -1, -1, -1}, {14715, -1, -1, -1}, {14716, -1, -1, -1}, {14717, -1, -1, -1}, {14718, -1, -1, -1}, {14719, -1, -1, -1}, {14720, -1, -1, -1}, {14721, -1, -1, -1}, {14722, -1, -1, -1}, {14723, -1, -1, -1}, {14724, -1, -1, -1}, {14725, -1, -1, -1}, {14726, -1, -1, -1}, {14727, -1, -1, -1}, {14728, -1, -1, -1}, {14729, -1, -1, -1}, {14730, -1, -1, -1}, {14731, -1, -1, -1}, {14732, -1, -1, -1}, {14733, -1, -1, -1}, {14734, -1, -1, -1}, {14735, -1, -1, -1}, {14736, -1, -1, -1}, {14737, -1, -1, -1}, {14738, -1, -1, -1}, {14739, -1, -1, -1}, {14740, -1, -1, -1}, {14741, -1, -1, -1}, {14742, -1, -1, -1}, {14743, -1, -1, -1}, {14744, -1, -1, -1}, {14745, -1, -1, -1}, {14746, -1, -1, -1}, {14747, -1, -1, -1}, {14748, -1, -1, -1}, {14749, -1, -1, -1}, {14750, -1, -1, -1}, {14751, -1, -1, -1}, {14752, -1, -1, -1}, {14753, -1, -1, -1}, {14754, -1, -1, -1}, {14755, -1, -1, -1}, {14756, -1, -1, -1}, {14757, -1, -1, -1}, {14758, -1, -1, -1}, {14759, -1, -1, -1}, {14760, -1, -1, -1}, {14761, -1, -1, -1}, {14762, -1, -1, -1}, {14763, -1, -1, -1}, {14764, -1, -1, -1}, {14765, -1, -1, -1}, {14766, -1, -1, -1}, {14767, -1, -1, -1}, {14768, -1, -1, -1}, {14769, -1, -1, -1}, {14770, -1, -1, -1}, {14771, -1, -1, -1}, {14772, -1, -1, -1}, {14773, -1, -1, -1}, {14774, -1, -1, -1}, {14775, -1, -1, -1}, {14776, -1, -1, -1}, {14777, -1, -1, -1}, {14778, -1, -1, -1}, {14779, -1, -1, -1}, {14780, -1, -1, -1}, {14781, -1, -1, -1}, {14782, -1, -1, -1}, {14783, -1, -1, -1}, {14784, -1, -1, -1}, {14785, -1, -1, -1}, {14786, -1, -1, -1}, {14787, -1, -1, -1}, {14788, -1, -1, -1}, {14789, -1, -1, -1}, {14790, -1, -1, -1}, {14791, -1, -1, -1}, {14792, -1, -1, -1}, {14793, -1, -1, -1}, {14794, -1, -1, -1}, {14795, -1, -1, -1}, {14796, -1, -1, -1}, {14797, -1, -1, -1}, {14798, -1, -1, -1}, {14801, -1, -1, -1}, {14802, -1, -1, -1}, {14803, -1, -1, -1}, {14804, -1, -1, -1}, {14805, -1, -1, -1}, {14806, -1, -1, -1}, {14807, -1, -1, -1}, {14808, -1, -1, -1}, {14809, -1, -1, -1}, {14810, -1, -1, -1}, {14811, -1, -1, -1}, {14812, -1, -1, -1}, {14813, -1, -1, -1}, {14814, -1, -1, -1}, {14816, -1, -1, -1}, {14817, -1, -1, -1}, {14818, -1, -1, -1}, {14819, -1, -1, -1}, {14820, -1, -1, -1}, {14821, -1, -1, -1}, {14822, -1, -1, -1}, {14823, -1, -1, -1}, {14824, -1, -1, -1}, {14825, -1, -1, -1}, {14826, -1, -1, -1}, {14827, -1, -1, -1}, {14828, -1, -1, -1}, {14829, -1, -1, -1}, {14830, -1, -1, -1}, {14831, -1, -1, -1}, {14832, -1, -1, -1}, {14833, -1, -1, -1}, {14834, -1, -1, -1}, {14835, -1, -1, -1}, {14836, -1, -1, -1}, {14837, -1, -1, -1}, {14838, -1, -1, -1}, {14839, -1, -1, -1}, {14840, -1, -1, -1}, {14841, -1, -1, -1}, {14842, -1, -1, -1}, {14843, -1, -1, -1}, {14844, -1, -1, -1}, {14845, -1, -1, -1}, {14846, -1, -1, -1}, {14847, -1, -1, -1}, {14848, -1, -1, -1}, {14849, -1, -1, -1}, {14850, -1, -1, -1}, {14851, -1, -1, -1}, {14852, -1, -1, -1}, {14853, -1, -1, -1}, {14854, -1, -1, -1}, {14855, -1, -1, -1}, {14856, -1, -1, -1} },
+ {{14857, -1, -1, -1}, {14858, -1, -1, -1}, {14859, -1, -1, -1}, {14860, -1, -1, -1}, {14861, -1, -1, -1}, {14862, -1, -1, -1}, {14863, -1, -1, -1}, {14864, -1, -1, -1}, {14865, -1, -1, -1}, {14866, -1, -1, -1}, {14867, -1, -1, -1}, {14868, -1, -1, -1}, {14869, -1, -1, -1}, {14870, -1, -1, -1}, {14871, -1, -1, -1}, {14872, -1, -1, -1}, {14873, -1, -1, -1}, {14874, -1, -1, -1}, {14875, -1, -1, -1}, {14876, -1, -1, -1}, {14877, -1, -1, -1}, {14878, -1, -1, -1}, {14879, -1, -1, -1}, {14880, -1, -1, -1}, {14881, -1, -1, -1}, {14882, -1, -1, -1}, {14883, -1, -1, -1}, {14884, -1, -1, -1}, {14885, -1, -1, -1}, {14886, -1, -1, -1}, {14887, -1, -1, -1}, {14888, -1, -1, -1}, {14889, -1, -1, -1}, {14890, -1, -1, -1}, {14891, -1, -1, -1}, {14892, -1, -1, -1}, {14893, -1, -1, -1}, {14894, -1, -1, -1}, {14895, -1, -1, -1}, {14896, -1, -1, -1}, {14897, -1, -1, -1}, {14898, -1, -1, -1}, {14899, -1, -1, -1}, {14900, -1, -1, -1}, {14901, -1, -1, -1}, {14902, -1, -1, -1}, {14903, -1, -1, -1}, {14904, -1, -1, -1}, {14905, -1, -1, -1}, {14906, -1, -1, -1}, {14907, -1, -1, -1}, {14908, -1, -1, -1}, {14909, -1, -1, -1}, {14910, -1, -1, -1}, {14911, -1, -1, -1}, {14912, -1, -1, -1}, {14913, -1, -1, -1}, {14914, -1, -1, -1}, {14915, -1, -1, -1}, {14916, -1, -1, -1}, {14917, -1, -1, -1}, {14918, -1, -1, -1}, {14919, -1, -1, -1}, {14920, -1, -1, -1}, {14921, -1, -1, -1}, {14922, -1, -1, -1}, {14923, -1, -1, -1}, {14924, -1, -1, -1}, {14925, -1, -1, -1}, {14926, -1, -1, -1}, {14927, -1, -1, -1}, {14928, -1, -1, -1}, {14929, -1, -1, -1}, {14930, -1, -1, -1}, {14931, -1, -1, -1}, {14932, -1, -1, -1}, {14933, -1, -1, -1}, {14934, -1, -1, -1}, {14935, -1, -1, -1}, {14936, -1, -1, -1}, {14937, -1, -1, -1}, {14938, -1, -1, -1}, {14939, -1, -1, -1}, {14940, -1, -1, -1}, {14941, -1, -1, -1}, {14942, -1, -1, -1}, {14943, -1, -1, -1}, {14944, -1, -1, -1}, {14945, -1, -1, -1}, {14946, -1, -1, -1}, {14947, -1, -1, -1}, {14948, -1, -1, -1}, {14949, -1, -1, -1}, {14950, -1, -1, -1}, {14951, -1, -1, -1}, {14952, -1, -1, -1}, {14953, -1, -1, -1}, {14954, -1, -1, -1}, {14955, -1, -1, -1}, {14956, -1, -1, -1}, {14957, -1, -1, -1}, {14958, -1, -1, -1}, {14959, -1, -1, -1}, {14960, -1, -1, -1}, {14961, -1, -1, -1}, {14962, -1, -1, -1}, {14964, -1, -1, -1}, {14965, -1, -1, -1}, {14966, -1, -1, -1}, {14967, -1, -1, -1}, {14968, -1, -1, -1}, {14969, -1, -1, -1}, {14970, -1, -1, -1}, {14971, -1, -1, -1}, {14972, -1, -1, -1}, {14973, -1, -1, -1}, {14974, -1, -1, -1}, {14975, -1, -1, -1}, {14976, -1, -1, -1}, {14977, -1, -1, -1}, {14978, -1, -1, -1}, {14979, -1, -1, -1}, {14980, -1, -1, -1}, {14981, -1, -1, -1}, {14982, -1, -1, -1}, {14983, -1, -1, -1}, {14984, -1, -1, -1}, {14985, -1, -1, -1}, {14986, -1, -1, -1}, {14987, -1, -1, -1}, {14988, -1, -1, -1}, {14989, -1, -1, -1}, {14990, -1, -1, -1}, {14991, -1, -1, -1}, {14992, -1, -1, -1}, {14993, -1, -1, -1}, {14994, -1, -1, -1}, {14995, -1, -1, -1}, {14996, -1, -1, -1}, {14997, -1, -1, -1}, {14998, -1, -1, -1}, {14999, -1, -1, -1}, {15000, -1, -1, -1}, {15001, -1, -1, -1}, {15002, -1, -1, -1}, {15003, -1, -1, -1}, {15004, -1, -1, -1}, {15005, -1, -1, -1}, {15006, -1, -1, -1}, {15007, -1, -1, -1}, {15008, -1, -1, -1}, {15009, -1, -1, -1}, {15010, -1, -1, -1}, {15011, -1, -1, -1}, {15012, -1, -1, -1}, {15013, -1, -1, -1}, {15014, -1, -1, -1}, {15015, -1, -1, -1}, {15016, -1, -1, -1}, {15017, -1, -1, -1}, {15018, -1, -1, -1}, {15019, -1, -1, -1}, {15020, -1, -1, -1}, {15021, -1, -1, -1}, {15022, -1, -1, -1}, {15023, -1, -1, -1}, {15024, -1, -1, -1}, {15025, -1, -1, -1}, {15026, -1, -1, -1}, {15027, -1, -1, -1}, {15028, -1, -1, -1}, {15029, -1, -1, -1}, {15030, -1, -1, -1}, {15031, -1, -1, -1}, {15032, -1, -1, -1}, {15033, -1, -1, -1}, {15034, -1, -1, -1}, {15035, -1, -1, -1}, {15036, -1, -1, -1}, {15037, -1, -1, -1}, {15038, -1, -1, -1}, {15039, -1, -1, -1}, {15040, -1, -1, -1}, {15041, -1, -1, -1}, {15042, -1, -1, -1}, {15043, -1, -1, -1}, {15044, -1, -1, -1}, {15045, -1, -1, -1}, {15046, -1, -1, -1}, {15047, -1, -1, -1}, {15048, -1, -1, -1}, {15049, -1, -1, -1}, {15050, -1, -1, -1}, {15051, -1, -1, -1}, {15052, -1, -1, -1}, {15053, -1, -1, -1}, {15054, -1, -1, -1}, {15055, -1, -1, -1}, {15056, -1, -1, -1}, {15057, -1, -1, -1}, {15058, -1, -1, -1}, {15059, -1, -1, -1}, {15060, -1, -1, -1}, {15061, -1, -1, -1}, {15062, -1, -1, -1}, {15063, -1, -1, -1}, {15064, -1, -1, -1}, {15065, -1, -1, -1}, {15066, -1, -1, -1}, {15067, -1, -1, -1}, {15068, -1, -1, -1}, {15069, -1, -1, -1}, {15070, -1, -1, -1}, {15071, -1, -1, -1}, {15072, -1, -1, -1}, {15073, -1, -1, -1}, {15074, -1, -1, -1}, {15075, -1, -1, -1}, {15076, -1, -1, -1}, {15077, -1, -1, -1}, {15078, -1, -1, -1}, {15079, -1, -1, -1}, {15080, -1, -1, -1}, {15081, -1, -1, -1}, {15082, -1, -1, -1}, {15083, -1, -1, -1}, {15084, -1, -1, -1}, {15085, -1, -1, -1}, {15086, -1, -1, -1}, {15087, -1, -1, -1}, {15088, -1, -1, -1}, {15089, -1, -1, -1}, {15090, -1, -1, -1}, {15091, -1, -1, -1}, {15092, -1, -1, -1}, {15093, -1, -1, -1}, {15094, -1, -1, -1}, {15095, -1, -1, -1}, {15096, -1, -1, -1}, {15097, -1, -1, -1}, {15098, -1, -1, -1}, {15099, -1, -1, -1}, {15100, -1, -1, -1}, {15101, -1, -1, -1}, {15102, -1, -1, -1}, {15103, -1, -1, -1}, {15104, -1, -1, -1}, {15105, -1, -1, -1}, {15106, -1, -1, -1}, {15107, -1, -1, -1}, {15108, -1, -1, -1}, {15109, -1, -1, -1}, {15110, -1, -1, -1}, {15111, -1, -1, -1}, {15112, -1, -1, -1}, {15113, -1, -1, -1} },
+ {{15114, -1, -1, -1}, {15115, -1, -1, -1}, {15116, -1, -1, -1}, {15117, -1, -1, -1}, {15118, -1, -1, -1}, {15119, -1, -1, -1}, {15120, -1, -1, -1}, {15121, -1, -1, -1}, {15122, -1, -1, -1}, {15123, -1, -1, -1}, {15124, -1, -1, -1}, {15125, -1, -1, -1}, {15126, -1, -1, -1}, {15127, -1, -1, -1}, {15128, -1, -1, -1}, {15129, -1, -1, -1}, {15130, -1, -1, -1}, {15131, -1, -1, -1}, {15132, -1, -1, -1}, {15133, -1, -1, -1}, {15134, -1, -1, -1}, {15135, -1, -1, -1}, {15136, -1, -1, -1}, {15137, -1, -1, -1}, {15138, -1, -1, -1}, {15139, -1, -1, -1}, {15140, -1, -1, -1}, {15141, -1, -1, -1}, {15142, -1, -1, -1}, {15143, -1, -1, -1}, {15144, -1, -1, -1}, {15145, -1, -1, -1}, {15146, -1, -1, -1}, {15147, -1, -1, -1}, {15148, -1, -1, -1}, {15149, -1, -1, -1}, {15150, -1, -1, -1}, {15151, -1, -1, -1}, {15152, -1, -1, -1}, {15153, -1, -1, -1}, {15154, -1, -1, -1}, {15155, -1, -1, -1}, {15156, -1, -1, -1}, {15157, -1, -1, -1}, {15158, -1, -1, -1}, {15159, -1, -1, -1}, {15160, -1, -1, -1}, {15161, -1, -1, -1}, {15162, -1, -1, -1}, {15163, -1, -1, -1}, {15164, -1, -1, -1}, {15165, -1, -1, -1}, {15166, -1, -1, -1}, {15167, -1, -1, -1}, {15168, -1, -1, -1}, {15169, -1, -1, -1}, {15170, -1, -1, -1}, {15171, -1, -1, -1}, {15172, -1, -1, -1}, {15173, -1, -1, -1}, {15174, -1, -1, -1}, {15175, -1, -1, -1}, {15176, -1, -1, -1}, {15177, -1, -1, -1}, {15178, -1, -1, -1}, {15179, -1, -1, -1}, {15180, -1, -1, -1}, {15181, -1, -1, -1}, {15183, -1, -1, -1}, {15184, -1, -1, -1}, {15185, -1, -1, -1}, {15186, -1, -1, -1}, {15187, -1, -1, -1}, {15188, -1, -1, -1}, {15189, -1, -1, -1}, {15190, -1, -1, -1}, {15191, -1, -1, -1}, {15192, -1, -1, -1}, {15193, -1, -1, -1}, {15194, -1, -1, -1}, {15195, -1, -1, -1}, {15196, -1, -1, -1}, {15197, -1, -1, -1}, {15198, -1, -1, -1}, {15199, -1, -1, -1}, {15200, -1, -1, -1}, {15201, -1, -1, -1}, {15202, -1, -1, -1}, {15203, -1, -1, -1}, {15204, -1, -1, -1}, {15205, -1, -1, -1}, {15206, -1, -1, -1}, {15207, -1, -1, -1}, {15208, -1, -1, -1}, {15209, -1, -1, -1}, {15210, -1, -1, -1}, {15211, -1, -1, -1}, {15212, -1, -1, -1}, {15213, -1, -1, -1}, {15214, -1, -1, -1}, {15215, -1, -1, -1}, {15216, -1, -1, -1}, {15217, -1, -1, -1}, {15218, -1, -1, -1}, {15219, -1, -1, -1}, {15220, -1, -1, -1}, {15221, -1, -1, -1}, {15222, -1, -1, -1}, {15223, -1, -1, -1}, {15224, -1, -1, -1}, {15225, -1, -1, -1}, {15226, -1, -1, -1}, {15227, -1, -1, -1}, {15228, -1, -1, -1}, {15229, -1, -1, -1}, {15230, -1, -1, -1}, {15231, -1, -1, -1}, {15232, -1, -1, -1}, {15233, -1, -1, -1}, {15234, -1, -1, -1}, {15235, -1, -1, -1}, {15236, -1, -1, -1}, {15237, -1, -1, -1}, {15238, -1, -1, -1}, {15239, -1, -1, -1}, {15240, -1, -1, -1}, {15241, -1, -1, -1}, {15242, -1, -1, -1}, {15243, -1, -1, -1}, {15244, -1, -1, -1}, {15245, -1, -1, -1}, {15246, -1, -1, -1}, {15247, -1, -1, -1}, {15248, -1, -1, -1}, {15249, -1, -1, -1}, {15250, -1, -1, -1}, {15251, -1, -1, -1}, {15252, -1, -1, -1}, {15253, -1, -1, -1}, {15254, -1, -1, -1}, {15255, -1, -1, -1}, {15256, -1, -1, -1}, {15257, -1, -1, -1}, {15258, -1, -1, -1}, {15259, -1, -1, -1}, {15260, -1, -1, -1}, {15261, -1, -1, -1}, {15262, -1, -1, -1}, {15263, -1, -1, -1}, {15264, -1, -1, -1}, {15265, -1, -1, -1}, {15266, -1, -1, -1}, {15267, -1, -1, -1}, {15268, -1, -1, -1}, {15269, -1, -1, -1}, {15270, -1, -1, -1}, {15271, -1, -1, -1}, {15272, -1, -1, -1}, {15273, -1, -1, -1}, {15274, -1, -1, -1}, {15275, -1, -1, -1}, {15276, -1, -1, -1}, {15277, -1, -1, -1}, {15278, -1, -1, -1}, {15279, -1, -1, -1}, {15280, -1, -1, -1}, {15281, -1, -1, -1}, {15282, -1, -1, -1}, {15283, -1, -1, -1}, {15284, -1, -1, -1}, {15285, -1, -1, -1}, {15286, -1, -1, -1}, {15287, -1, -1, -1}, {15288, -1, -1, -1}, {15289, -1, -1, -1}, {15290, -1, -1, -1}, {15291, -1, -1, -1}, {15292, -1, -1, -1}, {15293, -1, -1, -1}, {15294, -1, -1, -1}, {15295, -1, -1, -1}, {15296, -1, -1, -1}, {15297, -1, -1, -1}, {15298, -1, -1, -1}, {15299, -1, -1, -1}, {15300, -1, -1, -1}, {15301, -1, -1, -1}, {15302, -1, -1, -1}, {15303, -1, -1, -1}, {15304, -1, -1, -1}, {15305, -1, -1, -1}, {15306, -1, -1, -1}, {15307, -1, -1, -1}, {15308, -1, -1, -1}, {15309, -1, -1, -1}, {15310, -1, -1, -1}, {15311, -1, -1, -1}, {15312, -1, -1, -1}, {15313, -1, -1, -1}, {15314, -1, -1, -1}, {15315, -1, -1, -1}, {15316, -1, -1, -1}, {15317, -1, -1, -1}, {15318, -1, -1, -1}, {15319, -1, -1, -1}, {15320, -1, -1, -1}, {15321, -1, -1, -1}, {15322, -1, -1, -1}, {15323, -1, -1, -1}, {15324, -1, -1, -1}, {15325, -1, -1, -1}, {15326, -1, -1, -1}, {15327, -1, -1, -1}, {15328, -1, -1, -1}, {15329, -1, -1, -1}, {15330, -1, -1, -1}, {15331, -1, -1, -1}, {15332, -1, -1, -1}, {15333, -1, -1, -1}, {15334, -1, -1, -1}, {15335, -1, -1, -1}, {15336, -1, -1, -1}, {15337, -1, -1, -1}, {15338, -1, -1, -1}, {15339, -1, -1, -1}, {15340, -1, -1, -1}, {15341, -1, -1, -1}, {15342, -1, -1, -1}, {15343, -1, -1, -1}, {15344, -1, -1, -1}, {15345, -1, -1, -1}, {15346, -1, -1, -1}, {15347, -1, -1, -1}, {15348, -1, -1, -1}, {15349, -1, -1, -1}, {15350, -1, -1, -1}, {15351, -1, -1, -1}, {15352, -1, -1, -1}, {15353, -1, -1, -1}, {15354, -1, -1, -1}, {15355, -1, -1, -1}, {15356, -1, -1, -1}, {15357, -1, -1, -1}, {15358, -1, -1, -1}, {15359, -1, -1, -1}, {15360, -1, -1, -1}, {15361, -1, -1, -1}, {15362, -1, -1, -1}, {15363, -1, -1, -1}, {15364, -1, -1, -1}, {15365, -1, -1, -1}, {15366, -1, -1, -1}, {15367, -1, -1, -1}, {15368, -1, -1, -1}, {15369, -1, -1, -1}, {15370, -1, -1, -1} },
+ {{15371, -1, -1, -1}, {15372, -1, -1, -1}, {15373, -1, -1, -1}, {15374, -1, -1, -1}, {15375, -1, -1, -1}, {15376, -1, -1, -1}, {15377, -1, -1, -1}, {15378, -1, -1, -1}, {15379, -1, -1, -1}, {15380, -1, -1, -1}, {15381, -1, -1, -1}, {15382, -1, -1, -1}, {15383, -1, -1, -1}, {15384, -1, -1, -1}, {15385, -1, -1, -1}, {15386, -1, -1, -1}, {15387, -1, -1, -1}, {15388, -1, -1, -1}, {15389, -1, -1, -1}, {15390, -1, -1, -1}, {15391, -1, -1, -1}, {15392, -1, -1, -1}, {15393, -1, -1, -1}, {15394, -1, -1, -1}, {15395, -1, -1, -1}, {15396, -1, -1, -1}, {15397, -1, -1, -1}, {15398, -1, -1, -1}, {15399, -1, -1, -1}, {15400, -1, -1, -1}, {15401, -1, -1, -1}, {15402, -1, -1, -1}, {15403, -1, -1, -1}, {15404, -1, -1, -1}, {15405, -1, -1, -1}, {15406, -1, -1, -1}, {15407, -1, -1, -1}, {15408, -1, -1, -1}, {15409, -1, -1, -1}, {15410, -1, -1, -1}, {15411, -1, -1, -1}, {15412, -1, -1, -1}, {15413, -1, -1, -1}, {15414, -1, -1, -1}, {15415, -1, -1, -1}, {15416, -1, -1, -1}, {15417, -1, -1, -1}, {15418, -1, -1, -1}, {15419, -1, -1, -1}, {15420, -1, -1, -1}, {15421, -1, -1, -1}, {15422, -1, -1, -1}, {15423, -1, -1, -1}, {15424, -1, -1, -1}, {15425, -1, -1, -1}, {15426, -1, -1, -1}, {15427, -1, -1, -1}, {15428, -1, -1, -1}, {15429, -1, -1, -1}, {15430, -1, -1, -1}, {15431, -1, -1, -1}, {15432, -1, -1, -1}, {15433, -1, -1, -1}, {15434, -1, -1, -1}, {15435, -1, -1, -1}, {15436, -1, -1, -1}, {15437, -1, -1, -1}, {15438, -1, -1, -1}, {15439, -1, -1, -1}, {15440, -1, -1, -1}, {15441, -1, -1, -1}, {15442, -1, -1, -1}, {15443, -1, -1, -1}, {15444, -1, -1, -1}, {15445, -1, -1, -1}, {15446, -1, -1, -1}, {15447, -1, -1, -1}, {15448, -1, -1, -1}, {15449, -1, -1, -1}, {15450, -1, -1, -1}, {15451, -1, -1, -1}, {15452, -1, -1, -1}, {15453, -1, -1, -1}, {15454, -1, -1, -1}, {15455, -1, -1, -1}, {15456, -1, -1, -1}, {15457, -1, -1, -1}, {15458, -1, -1, -1}, {15459, -1, -1, -1}, {15460, -1, -1, -1}, {15461, -1, -1, -1}, {15462, -1, -1, -1}, {15463, -1, -1, -1}, {15464, -1, -1, -1}, {15465, -1, -1, -1}, {15466, -1, -1, -1}, {15467, -1, -1, -1}, {15468, -1, -1, -1}, {15469, -1, -1, -1}, {15471, -1, -1, -1}, {15472, -1, -1, -1}, {15473, -1, -1, -1}, {15474, -1, -1, -1}, {15475, -1, -1, -1}, {15476, -1, -1, -1}, {15477, -1, -1, -1}, {15478, -1, -1, -1}, {15479, -1, -1, -1}, {15480, -1, -1, -1}, {15481, -1, -1, -1}, {15482, -1, -1, -1}, {15483, -1, -1, -1}, {15484, -1, -1, -1}, {15485, -1, -1, -1}, {15486, -1, -1, -1}, {15487, -1, -1, -1}, {15488, -1, -1, -1}, {15489, -1, -1, -1}, {15490, -1, -1, -1}, {15491, -1, -1, -1}, {15492, -1, -1, -1}, {15493, -1, -1, -1}, {15494, -1, -1, -1}, {15495, -1, -1, -1}, {15496, -1, -1, -1}, {15497, -1, -1, -1}, {15498, -1, -1, -1}, {15499, -1, -1, -1}, {15500, -1, -1, -1}, {15501, -1, -1, -1}, {15502, -1, -1, -1}, {15503, -1, -1, -1}, {15504, -1, -1, -1}, {15505, -1, -1, -1}, {15506, -1, -1, -1}, {15507, -1, -1, -1}, {15508, -1, -1, -1}, {15509, -1, -1, -1}, {15510, -1, -1, -1}, {15511, -1, -1, -1}, {15512, -1, -1, -1}, {15513, -1, -1, -1}, {15514, -1, -1, -1}, {15515, -1, -1, -1}, {15516, -1, -1, -1}, {15517, -1, -1, -1}, {15518, -1, -1, -1}, {15519, -1, -1, -1}, {15520, -1, -1, -1}, {15521, -1, -1, -1}, {15522, -1, -1, -1}, {15523, -1, -1, -1}, {15524, -1, -1, -1}, {15525, -1, -1, -1}, {15526, -1, -1, -1}, {15527, -1, -1, -1}, {15528, -1, -1, -1}, {15529, -1, -1, -1}, {15530, -1, -1, -1}, {15531, -1, -1, -1}, {15532, -1, -1, -1}, {15533, -1, -1, -1}, {15534, -1, -1, -1}, {15535, -1, -1, -1}, {15536, -1, -1, -1}, {15537, -1, -1, -1}, {15538, -1, -1, -1}, {15539, -1, -1, -1}, {15540, -1, -1, -1}, {15541, -1, -1, -1}, {15542, -1, -1, -1}, {15543, -1, -1, -1}, {15544, -1, -1, -1}, {15545, -1, -1, -1}, {15546, -1, -1, -1}, {15547, -1, -1, -1}, {15548, -1, -1, -1}, {15549, -1, -1, -1}, {15550, -1, -1, -1}, {15551, -1, -1, -1}, {15552, -1, -1, -1}, {15553, -1, -1, -1}, {15554, -1, -1, -1}, {15555, -1, -1, -1}, {15556, -1, -1, -1}, {15557, -1, -1, -1}, {15558, -1, -1, -1}, {15559, -1, -1, -1}, {15560, -1, -1, -1}, {15561, -1, -1, -1}, {15562, -1, -1, -1}, {15563, -1, -1, -1}, {15564, -1, -1, -1}, {15565, -1, -1, -1}, {15566, -1, -1, -1}, {15567, -1, -1, -1}, {15568, -1, -1, -1}, {15569, -1, -1, -1}, {15570, -1, -1, -1}, {15571, -1, -1, -1}, {15572, -1, -1, -1}, {15573, -1, -1, -1}, {15574, -1, -1, -1}, {15575, -1, -1, -1}, {15576, -1, -1, -1}, {15577, -1, -1, -1}, {15578, -1, -1, -1}, {15579, -1, -1, -1}, {15580, -1, -1, -1}, {15581, -1, -1, -1}, {15582, -1, -1, -1}, {15583, -1, -1, -1}, {15585, -1, -1, -1}, {15586, -1, -1, -1}, {15587, -1, -1, -1}, {15588, -1, -1, -1}, {15589, -1, -1, -1}, {15590, -1, -1, -1}, {15591, -1, -1, -1}, {15592, -1, -1, -1}, {15593, -1, -1, -1}, {15594, -1, -1, -1}, {15595, -1, -1, -1}, {15596, -1, -1, -1}, {15597, -1, -1, -1}, {15598, -1, -1, -1}, {15599, -1, -1, -1}, {15600, -1, -1, -1}, {15601, -1, -1, -1}, {15602, -1, -1, -1}, {15603, -1, -1, -1}, {15604, -1, -1, -1}, {15605, -1, -1, -1}, {15606, -1, -1, -1}, {15607, -1, -1, -1}, {15608, -1, -1, -1}, {15609, -1, -1, -1}, {15610, -1, -1, -1}, {15611, -1, -1, -1}, {15612, -1, -1, -1}, {15613, -1, -1, -1}, {15614, -1, -1, -1}, {15615, -1, -1, -1}, {15616, -1, -1, -1}, {15617, -1, -1, -1}, {15618, -1, -1, -1}, {15619, -1, -1, -1}, {15620, -1, -1, -1}, {15621, -1, -1, -1}, {15622, -1, -1, -1}, {15623, -1, -1, -1}, {15624, -1, -1, -1}, {15625, -1, -1, -1}, {15626, -1, -1, -1}, {15627, -1, -1, -1}, {15628, -1, -1, -1} },
+ {{15629, -1, -1, -1}, {15630, -1, -1, -1}, {15631, -1, -1, -1}, {15632, -1, -1, -1}, {15633, -1, -1, -1}, {15634, -1, -1, -1}, {15635, -1, -1, -1}, {15636, -1, -1, -1}, {15637, -1, -1, -1}, {15638, -1, -1, -1}, {15639, -1, -1, -1}, {15640, -1, -1, -1}, {15641, -1, -1, -1}, {15642, -1, -1, -1}, {15643, -1, -1, -1}, {15644, -1, -1, -1}, {15645, -1, -1, -1}, {15646, -1, -1, -1}, {15647, -1, -1, -1}, {15648, -1, -1, -1}, {15649, -1, -1, -1}, {15650, -1, -1, -1}, {15651, -1, -1, -1}, {15652, -1, -1, -1}, {15653, -1, -1, -1}, {15654, -1, -1, -1}, {15655, -1, -1, -1}, {15656, -1, -1, -1}, {15657, -1, -1, -1}, {15658, -1, -1, -1}, {15659, -1, -1, -1}, {15660, -1, -1, -1}, {15661, -1, -1, -1}, {15662, -1, -1, -1}, {15663, -1, -1, -1}, {15664, -1, -1, -1}, {15665, -1, -1, -1}, {15666, -1, -1, -1}, {15667, -1, -1, -1}, {15668, -1, -1, -1}, {15669, -1, -1, -1}, {15670, -1, -1, -1}, {15671, -1, -1, -1}, {15672, -1, -1, -1}, {15673, -1, -1, -1}, {15674, -1, -1, -1}, {15675, -1, -1, -1}, {15676, -1, -1, -1}, {15677, -1, -1, -1}, {15678, -1, -1, -1}, {15679, -1, -1, -1}, {15680, -1, -1, -1}, {15681, -1, -1, -1}, {15682, -1, -1, -1}, {15683, -1, -1, -1}, {15684, -1, -1, -1}, {15685, -1, -1, -1}, {15686, -1, -1, -1}, {15687, -1, -1, -1}, {15688, -1, -1, -1}, {15689, -1, -1, -1}, {15690, -1, -1, -1}, {15691, -1, -1, -1}, {15692, -1, -1, -1}, {15693, -1, -1, -1}, {15694, -1, -1, -1}, {15695, -1, -1, -1}, {15696, -1, -1, -1}, {15697, -1, -1, -1}, {15698, -1, -1, -1}, {15699, -1, -1, -1}, {15700, -1, -1, -1}, {15701, -1, -1, -1}, {15702, -1, -1, -1}, {15703, -1, -1, -1}, {15704, -1, -1, -1}, {15705, -1, -1, -1}, {15706, -1, -1, -1}, {15707, -1, -1, -1}, {15708, -1, -1, -1}, {15709, -1, -1, -1}, {15710, -1, -1, -1}, {15711, -1, -1, -1}, {15712, -1, -1, -1}, {15713, -1, -1, -1}, {15714, -1, -1, -1}, {15715, -1, -1, -1}, {15716, -1, -1, -1}, {15717, -1, -1, -1}, {15718, -1, -1, -1}, {15719, -1, -1, -1}, {15720, -1, -1, -1}, {15721, -1, -1, -1}, {15722, -1, -1, -1}, {15723, -1, -1, -1}, {15724, -1, -1, -1}, {15725, -1, -1, -1}, {15726, -1, -1, -1}, {15727, -1, -1, -1}, {15728, -1, -1, -1}, {15729, -1, -1, -1}, {15730, -1, -1, -1}, {15731, -1, -1, -1}, {15732, -1, -1, -1}, {15733, -1, -1, -1}, {15734, -1, -1, -1}, {15735, -1, -1, -1}, {15736, -1, -1, -1}, {15737, -1, -1, -1}, {15738, -1, -1, -1}, {15739, -1, -1, -1}, {15740, -1, -1, -1}, {15741, -1, -1, -1}, {15742, -1, -1, -1}, {15743, -1, -1, -1}, {15744, -1, -1, -1}, {15745, -1, -1, -1}, {15746, -1, -1, -1}, {15747, -1, -1, -1}, {15748, -1, -1, -1}, {15749, -1, -1, -1}, {15750, -1, -1, -1}, {15751, -1, -1, -1}, {15752, -1, -1, -1}, {15753, -1, -1, -1}, {15754, -1, -1, -1}, {15755, -1, -1, -1}, {15756, -1, -1, -1}, {15757, -1, -1, -1}, {15758, -1, -1, -1}, {15759, -1, -1, -1}, {15760, -1, -1, -1}, {15761, -1, -1, -1}, {15762, -1, -1, -1}, {15763, -1, -1, -1}, {15764, -1, -1, -1}, {15765, -1, -1, -1}, {15766, -1, -1, -1}, {15767, -1, -1, -1}, {15768, -1, -1, -1}, {15769, -1, -1, -1}, {15770, -1, -1, -1}, {15771, -1, -1, -1}, {15772, -1, -1, -1}, {15773, -1, -1, -1}, {15774, -1, -1, -1}, {15775, -1, -1, -1}, {15776, -1, -1, -1}, {15777, -1, -1, -1}, {15778, -1, -1, -1}, {15779, -1, -1, -1}, {15780, -1, -1, -1}, {15781, -1, -1, -1}, {15782, -1, -1, -1}, {15783, -1, -1, -1}, {15784, -1, -1, -1}, {15785, -1, -1, -1}, {15786, -1, -1, -1}, {15787, -1, -1, -1}, {15788, -1, -1, -1}, {15789, -1, -1, -1}, {15790, -1, -1, -1}, {15791, -1, -1, -1}, {15792, -1, -1, -1}, {15793, -1, -1, -1}, {15794, -1, -1, -1}, {15795, -1, -1, -1}, {15796, -1, -1, -1}, {15797, -1, -1, -1}, {15798, -1, -1, -1}, {15799, -1, -1, -1}, {15800, -1, -1, -1}, {15801, -1, -1, -1}, {15802, -1, -1, -1}, {15803, -1, -1, -1}, {15804, -1, -1, -1}, {15805, -1, -1, -1}, {15806, -1, -1, -1}, {15807, -1, -1, -1}, {15808, -1, -1, -1}, {15809, -1, -1, -1}, {15810, -1, -1, -1}, {15811, -1, -1, -1}, {15812, -1, -1, -1}, {15813, -1, -1, -1}, {15814, -1, -1, -1}, {15815, -1, -1, -1}, {15816, -1, -1, -1}, {15817, -1, -1, -1}, {15818, -1, -1, -1}, {15819, -1, -1, -1}, {15820, -1, -1, -1}, {15821, -1, -1, -1}, {15822, -1, -1, -1}, {15823, -1, -1, -1}, {15824, -1, -1, -1}, {15825, -1, -1, -1}, {15826, -1, -1, -1}, {15827, -1, -1, -1}, {15828, -1, -1, -1}, {15829, -1, -1, -1}, {15830, -1, -1, -1}, {15831, -1, -1, -1}, {15832, -1, -1, -1}, {15833, -1, -1, -1}, {15834, -1, -1, -1}, {15835, -1, -1, -1}, {15836, -1, -1, -1}, {15837, -1, -1, -1}, {15838, -1, -1, -1}, {15839, -1, -1, -1}, {15840, -1, -1, -1}, {15841, -1, -1, -1}, {15842, -1, -1, -1}, {15843, -1, -1, -1}, {15844, -1, -1, -1}, {15845, -1, -1, -1}, {15846, -1, -1, -1}, {15847, -1, -1, -1}, {15848, -1, -1, -1}, {15849, -1, -1, -1}, {15850, -1, -1, -1}, {15851, -1, -1, -1}, {15852, -1, -1, -1}, {15853, -1, -1, -1}, {15854, -1, -1, -1}, {15855, -1, -1, -1}, {15856, -1, -1, -1}, {15857, -1, -1, -1}, {15858, -1, -1, -1}, {15859, -1, -1, -1}, {15860, -1, -1, -1}, {15861, -1, -1, -1}, {15862, -1, -1, -1}, {15863, -1, -1, -1}, {15864, -1, -1, -1}, {15865, -1, -1, -1}, {15866, -1, -1, -1}, {15867, -1, -1, -1}, {15868, -1, -1, -1}, {15869, -1, -1, -1}, {15870, -1, -1, -1}, {15871, -1, -1, -1}, {15872, -1, -1, -1}, {15873, -1, -1, -1}, {15874, -1, -1, -1}, {15875, -1, -1, -1}, {15876, -1, -1, -1}, {15877, -1, -1, -1}, {15878, -1, -1, -1}, {15879, -1, -1, -1}, {15880, -1, -1, -1}, {15881, -1, -1, -1}, {15882, -1, -1, -1}, {15883, -1, -1, -1}, {15884, -1, -1, -1} },
+ {{15885, -1, -1, -1}, {15886, -1, -1, -1}, {15887, -1, -1, -1}, {15888, -1, -1, -1}, {15889, -1, -1, -1}, {15890, -1, -1, -1}, {15891, -1, -1, -1}, {15892, -1, -1, -1}, {15893, -1, -1, -1}, {15894, -1, -1, -1}, {15895, -1, -1, -1}, {15896, -1, -1, -1}, {15897, -1, -1, -1}, {15898, -1, -1, -1}, {15899, -1, -1, -1}, {15900, -1, -1, -1}, {15901, -1, -1, -1}, {15902, -1, -1, -1}, {15903, -1, -1, -1}, {15904, -1, -1, -1}, {15905, -1, -1, -1}, {15906, -1, -1, -1}, {15907, -1, -1, -1}, {15908, -1, -1, -1}, {15909, -1, -1, -1}, {15910, -1, -1, -1}, {15911, -1, -1, -1}, {15912, -1, -1, -1}, {15913, -1, -1, -1}, {15914, -1, -1, -1}, {15915, -1, -1, -1}, {15916, -1, -1, -1}, {15917, -1, -1, -1}, {15918, -1, -1, -1}, {15919, -1, -1, -1}, {15920, -1, -1, -1}, {15921, -1, -1, -1}, {15922, -1, -1, -1}, {15923, -1, -1, -1}, {15924, -1, -1, -1}, {15925, -1, -1, -1}, {15926, -1, -1, -1}, {15927, -1, -1, -1}, {15928, -1, -1, -1}, {15929, -1, -1, -1}, {15930, -1, -1, -1}, {15931, -1, -1, -1}, {15932, -1, -1, -1}, {15933, -1, -1, -1}, {15934, -1, -1, -1}, {15935, -1, -1, -1}, {15936, -1, -1, -1}, {15937, -1, -1, -1}, {15938, -1, -1, -1}, {15939, -1, -1, -1}, {15940, -1, -1, -1}, {15941, -1, -1, -1}, {15942, -1, -1, -1}, {15943, -1, -1, -1}, {15944, -1, -1, -1}, {15945, -1, -1, -1}, {15946, -1, -1, -1}, {15947, -1, -1, -1}, {15948, -1, -1, -1}, {15949, -1, -1, -1}, {15950, -1, -1, -1}, {15951, -1, -1, -1}, {15952, -1, -1, -1}, {15953, -1, -1, -1}, {15954, -1, -1, -1}, {15955, -1, -1, -1}, {15956, -1, -1, -1}, {15957, -1, -1, -1}, {15958, -1, -1, -1}, {15959, -1, -1, -1}, {15960, -1, -1, -1}, {15961, -1, -1, -1}, {15962, -1, -1, -1}, {15963, -1, -1, -1}, {15964, -1, -1, -1}, {15965, -1, -1, -1}, {15966, -1, -1, -1}, {15967, -1, -1, -1}, {15968, -1, -1, -1}, {15969, -1, -1, -1}, {15970, -1, -1, -1}, {15971, -1, -1, -1}, {15972, -1, -1, -1}, {15973, -1, -1, -1}, {15974, -1, -1, -1}, {15975, -1, -1, -1}, {15976, -1, -1, -1}, {15977, -1, -1, -1}, {15978, -1, -1, -1}, {15979, -1, -1, -1}, {15980, -1, -1, -1}, {15981, -1, -1, -1}, {15982, -1, -1, -1}, {15983, -1, -1, -1}, {15984, -1, -1, -1}, {15985, -1, -1, -1}, {15986, -1, -1, -1}, {15987, -1, -1, -1}, {15988, -1, -1, -1}, {15989, -1, -1, -1}, {15990, -1, -1, -1}, {15991, -1, -1, -1}, {15992, -1, -1, -1}, {15993, -1, -1, -1}, {15994, -1, -1, -1}, {15995, -1, -1, -1}, {15996, -1, -1, -1}, {15997, -1, -1, -1}, {15998, -1, -1, -1}, {15999, -1, -1, -1}, {16000, -1, -1, -1}, {16001, -1, -1, -1}, {16002, -1, -1, -1}, {16003, -1, -1, -1}, {16004, -1, -1, -1}, {16005, -1, -1, -1}, {16006, -1, -1, -1}, {16007, -1, -1, -1}, {16008, -1, -1, -1}, {16009, -1, -1, -1}, {16010, -1, -1, -1}, {16011, -1, -1, -1}, {16012, -1, -1, -1}, {16013, -1, -1, -1}, {16014, -1, -1, -1}, {16015, -1, -1, -1}, {16016, -1, -1, -1}, {16017, -1, -1, -1}, {16018, -1, -1, -1}, {16019, -1, -1, -1}, {16020, -1, -1, -1}, {16021, -1, -1, -1}, {16022, -1, -1, -1}, {16023, -1, -1, -1}, {16024, -1, -1, -1}, {16025, -1, -1, -1}, {16026, -1, -1, -1}, {16027, -1, -1, -1}, {16028, -1, -1, -1}, {16029, -1, -1, -1}, {16030, -1, -1, -1}, {16031, -1, -1, -1}, {16032, -1, -1, -1}, {16033, -1, -1, -1}, {16034, -1, -1, -1}, {16035, -1, -1, -1}, {16036, -1, -1, -1}, {16037, -1, -1, -1}, {16038, -1, -1, -1}, {16039, -1, -1, -1}, {16040, -1, -1, -1}, {16041, -1, -1, -1}, {16042, -1, -1, -1}, {16043, -1, -1, -1}, {16044, -1, -1, -1}, {16045, -1, -1, -1}, {16046, -1, -1, -1}, {16047, -1, -1, -1}, {16048, -1, -1, -1}, {16049, -1, -1, -1}, {16050, -1, -1, -1}, {16051, -1, -1, -1}, {16052, -1, -1, -1}, {16053, -1, -1, -1}, {16054, -1, -1, -1}, {16055, -1, -1, -1}, {16056, -1, -1, -1}, {16057, -1, -1, -1}, {16058, -1, -1, -1}, {16059, -1, -1, -1}, {16060, -1, -1, -1}, {16061, -1, -1, -1}, {16062, -1, -1, -1}, {16063, -1, -1, -1}, {16064, -1, -1, -1}, {16065, -1, -1, -1}, {16066, -1, -1, -1}, {16067, -1, -1, -1}, {16068, -1, -1, -1}, {16069, -1, -1, -1}, {16070, -1, -1, -1}, {16071, -1, -1, -1}, {16072, -1, -1, -1}, {16073, -1, -1, -1}, {16074, -1, -1, -1}, {16075, -1, -1, -1}, {16076, -1, -1, -1}, {16077, -1, -1, -1}, {16078, -1, -1, -1}, {16079, -1, -1, -1}, {16080, -1, -1, -1}, {16081, -1, -1, -1}, {16082, -1, -1, -1}, {16083, -1, -1, -1}, {16084, -1, -1, -1}, {16085, -1, -1, -1}, {16086, -1, -1, -1}, {16087, -1, -1, -1}, {16088, -1, -1, -1}, {16089, -1, -1, -1}, {16090, -1, -1, -1}, {16091, -1, -1, -1}, {16092, -1, -1, -1}, {16093, -1, -1, -1}, {16094, -1, -1, -1}, {16095, -1, -1, -1}, {16096, -1, -1, -1}, {16097, -1, -1, -1}, {16098, -1, -1, -1}, {16099, -1, -1, -1}, {16100, -1, -1, -1}, {16101, -1, -1, -1}, {16102, -1, -1, -1}, {16103, -1, -1, -1}, {16104, -1, -1, -1}, {16105, -1, -1, -1}, {16106, -1, -1, -1}, {16107, -1, -1, -1}, {16108, -1, -1, -1}, {16109, -1, -1, -1}, {16110, -1, -1, -1}, {16111, -1, -1, -1}, {16112, -1, -1, -1}, {16113, -1, -1, -1}, {16114, -1, -1, -1}, {16115, -1, -1, -1}, {16116, -1, -1, -1}, {16117, -1, -1, -1}, {16118, -1, -1, -1}, {16119, -1, -1, -1}, {16120, -1, -1, -1}, {16121, -1, -1, -1}, {16122, -1, -1, -1}, {16123, -1, -1, -1}, {16124, -1, -1, -1}, {16125, -1, -1, -1}, {16126, -1, -1, -1}, {16127, -1, -1, -1}, {16128, -1, -1, -1}, {16129, -1, -1, -1}, {16130, -1, -1, -1}, {16131, -1, -1, -1}, {16132, -1, -1, -1}, {16133, -1, -1, -1}, {16134, -1, -1, -1}, {16135, -1, -1, -1}, {16136, -1, -1, -1}, {16137, -1, -1, -1}, {16138, -1, -1, -1}, {16139, -1, -1, -1}, {16140, -1, -1, -1} },
+ {{16141, -1, -1, -1}, {16142, -1, -1, -1}, {16143, -1, -1, -1}, {16144, -1, -1, -1}, {16145, -1, -1, -1}, {16146, -1, -1, -1}, {16147, -1, -1, -1}, {16148, -1, -1, -1}, {16149, -1, -1, -1}, {16150, -1, -1, -1}, {16151, -1, -1, -1}, {16152, -1, -1, -1}, {16153, -1, -1, -1}, {16154, -1, -1, -1}, {16155, -1, -1, -1}, {16156, -1, -1, -1}, {16157, -1, -1, -1}, {16158, -1, -1, -1}, {16159, -1, -1, -1}, {16160, -1, -1, -1}, {16161, -1, -1, -1}, {16162, -1, -1, -1}, {16163, -1, -1, -1}, {16164, -1, -1, -1}, {16165, -1, -1, -1}, {16166, -1, -1, -1}, {16167, -1, -1, -1}, {16168, -1, -1, -1}, {16169, -1, -1, -1}, {16170, -1, -1, -1}, {16171, -1, -1, -1}, {16172, -1, -1, -1}, {16173, -1, -1, -1}, {16174, -1, -1, -1}, {16175, -1, -1, -1}, {16176, -1, -1, -1}, {16177, -1, -1, -1}, {16178, -1, -1, -1}, {16179, -1, -1, -1}, {16180, -1, -1, -1}, {16181, -1, -1, -1}, {16182, -1, -1, -1}, {16183, -1, -1, -1}, {16184, -1, -1, -1}, {16185, -1, -1, -1}, {16186, -1, -1, -1}, {16187, -1, -1, -1}, {16188, -1, -1, -1}, {16189, -1, -1, -1}, {16190, -1, -1, -1}, {16191, -1, -1, -1}, {16192, -1, -1, -1}, {16193, -1, -1, -1}, {16194, -1, -1, -1}, {16195, -1, -1, -1}, {16196, -1, -1, -1}, {16197, -1, -1, -1}, {16198, -1, -1, -1}, {16199, -1, -1, -1}, {16200, -1, -1, -1}, {16201, -1, -1, -1}, {16202, -1, -1, -1}, {16203, -1, -1, -1}, {16204, -1, -1, -1}, {16205, -1, -1, -1}, {16206, -1, -1, -1}, {16207, -1, -1, -1}, {16208, -1, -1, -1}, {16209, -1, -1, -1}, {16210, -1, -1, -1}, {16211, -1, -1, -1}, {16212, -1, -1, -1}, {16213, -1, -1, -1}, {16214, -1, -1, -1}, {16215, -1, -1, -1}, {16216, -1, -1, -1}, {16217, -1, -1, -1}, {16218, -1, -1, -1}, {16219, -1, -1, -1}, {16220, -1, -1, -1}, {16221, -1, -1, -1}, {16222, -1, -1, -1}, {16223, -1, -1, -1}, {16224, -1, -1, -1}, {16225, -1, -1, -1}, {16226, -1, -1, -1}, {16227, -1, -1, -1}, {16228, -1, -1, -1}, {16229, -1, -1, -1}, {16230, -1, -1, -1}, {16231, -1, -1, -1}, {16232, -1, -1, -1}, {16233, -1, -1, -1}, {16234, -1, -1, -1}, {16235, -1, -1, -1}, {16236, -1, -1, -1}, {16237, -1, -1, -1}, {16238, -1, -1, -1}, {16239, -1, -1, -1}, {16240, -1, -1, -1}, {16241, -1, -1, -1}, {16242, -1, -1, -1}, {16243, -1, -1, -1}, {16244, -1, -1, -1}, {16245, -1, -1, -1}, {16246, -1, -1, -1}, {16247, -1, -1, -1}, {16248, -1, -1, -1}, {16249, -1, -1, -1}, {16250, -1, -1, -1}, {16251, -1, -1, -1}, {16252, -1, -1, -1}, {16253, -1, -1, -1}, {16254, -1, -1, -1}, {16255, -1, -1, -1}, {16256, -1, -1, -1}, {16257, -1, -1, -1}, {16258, -1, -1, -1}, {16259, -1, -1, -1}, {16260, -1, -1, -1}, {16261, -1, -1, -1}, {16262, -1, -1, -1}, {16263, -1, -1, -1}, {16264, -1, -1, -1}, {16265, -1, -1, -1}, {16266, -1, -1, -1}, {16267, -1, -1, -1}, {16268, -1, -1, -1}, {16269, -1, -1, -1}, {16270, -1, -1, -1}, {16271, -1, -1, -1}, {16272, -1, -1, -1}, {16273, -1, -1, -1}, {16274, -1, -1, -1}, {16275, -1, -1, -1}, {16276, -1, -1, -1}, {16277, -1, -1, -1}, {16278, -1, -1, -1}, {16279, -1, -1, -1}, {16280, -1, -1, -1}, {16281, -1, -1, -1}, {16282, -1, -1, -1}, {16283, -1, -1, -1}, {16284, -1, -1, -1}, {16285, -1, -1, -1}, {16286, -1, -1, -1}, {16287, -1, -1, -1}, {16288, -1, -1, -1}, {16289, -1, -1, -1}, {16290, -1, -1, -1}, {16291, -1, -1, -1}, {16292, -1, -1, -1}, {16293, -1, -1, -1}, {16294, -1, -1, -1}, {16295, -1, -1, -1}, {16296, -1, -1, -1}, {16297, -1, -1, -1}, {16298, -1, -1, -1}, {16299, -1, -1, -1}, {16300, -1, -1, -1}, {16301, -1, -1, -1}, {16302, -1, -1, -1}, {16303, -1, -1, -1}, {16304, -1, -1, -1}, {16305, -1, -1, -1}, {16306, -1, -1, -1}, {16307, -1, -1, -1}, {16308, -1, -1, -1}, {16309, -1, -1, -1}, {16310, -1, -1, -1}, {16311, -1, -1, -1}, {16312, -1, -1, -1}, {16313, -1, -1, -1}, {16314, -1, -1, -1}, {16315, -1, -1, -1}, {16316, -1, -1, -1}, {16317, -1, -1, -1}, {16318, -1, -1, -1}, {16319, -1, -1, -1}, {16320, -1, -1, -1}, {16321, -1, -1, -1}, {16322, -1, -1, -1}, {16323, -1, -1, -1}, {16324, -1, -1, -1}, {16325, -1, -1, -1}, {16326, -1, -1, -1}, {16327, -1, -1, -1}, {16328, -1, -1, -1}, {16329, -1, -1, -1}, {16330, -1, -1, -1}, {16331, -1, -1, -1}, {16332, -1, -1, -1}, {16333, -1, -1, -1}, {16334, -1, -1, -1}, {16335, -1, -1, -1}, {16336, -1, -1, -1}, {16337, -1, -1, -1}, {16338, -1, -1, -1}, {16339, -1, -1, -1}, {16340, -1, -1, -1}, {16341, -1, -1, -1}, {16342, -1, -1, -1}, {16343, -1, -1, -1}, {16344, -1, -1, -1}, {16345, -1, -1, -1}, {16346, -1, -1, -1}, {16347, -1, -1, -1}, {16348, -1, -1, -1}, {16349, -1, -1, -1}, {16350, -1, -1, -1}, {16351, -1, -1, -1}, {16352, -1, -1, -1}, {16353, -1, -1, -1}, {16354, -1, -1, -1}, {16355, -1, -1, -1}, {16356, -1, -1, -1}, {16357, -1, -1, -1}, {16358, -1, -1, -1}, {16359, -1, -1, -1}, {16360, -1, -1, -1}, {16361, -1, -1, -1}, {16362, -1, -1, -1}, {16363, -1, -1, -1}, {16364, -1, -1, -1}, {16365, -1, -1, -1}, {16366, -1, -1, -1}, {16367, -1, -1, -1}, {16368, -1, -1, -1}, {16369, -1, -1, -1}, {16370, -1, -1, -1}, {16371, -1, -1, -1}, {16372, -1, -1, -1}, {16373, -1, -1, -1}, {16374, -1, -1, -1}, {16375, -1, -1, -1}, {16376, -1, -1, -1}, {16377, -1, -1, -1}, {16378, -1, -1, -1}, {16379, -1, -1, -1}, {16380, -1, -1, -1}, {16381, -1, -1, -1}, {16382, -1, -1, -1}, {16383, -1, -1, -1}, {16384, -1, -1, -1}, {16385, -1, -1, -1}, {16386, -1, -1, -1}, {16387, -1, -1, -1}, {16388, -1, -1, -1}, {16389, -1, -1, -1}, {16390, -1, -1, -1}, {16391, -1, -1, -1}, {16392, -1, -1, -1}, {16393, -1, -1, -1}, {16394, -1, -1, -1}, {16395, -1, -1, -1}, {16396, -1, -1, -1} },
+ {{16397, -1, -1, -1}, {16398, -1, -1, -1}, {16399, -1, -1, -1}, {16400, -1, -1, -1}, {16401, -1, -1, -1}, {16402, -1, -1, -1}, {16403, -1, -1, -1}, {16404, -1, -1, -1}, {16405, -1, -1, -1}, {16406, -1, -1, -1}, {16407, -1, -1, -1}, {16408, -1, -1, -1}, {16409, -1, -1, -1}, {16410, -1, -1, -1}, {16411, -1, -1, -1}, {16412, -1, -1, -1}, {16413, -1, -1, -1}, {16414, -1, -1, -1}, {16415, -1, -1, -1}, {16416, -1, -1, -1}, {16417, -1, -1, -1}, {16418, -1, -1, -1}, {16419, -1, -1, -1}, {16420, -1, -1, -1}, {16421, -1, -1, -1}, {16422, -1, -1, -1}, {16423, -1, -1, -1}, {16424, -1, -1, -1}, {16425, -1, -1, -1}, {16426, -1, -1, -1}, {16427, -1, -1, -1}, {16428, -1, -1, -1}, {16429, -1, -1, -1}, {16430, -1, -1, -1}, {16431, -1, -1, -1}, {16432, -1, -1, -1}, {16433, -1, -1, -1}, {16434, -1, -1, -1}, {16435, -1, -1, -1}, {16436, -1, -1, -1}, {16437, -1, -1, -1}, {16438, -1, -1, -1}, {16439, -1, -1, -1}, {16440, -1, -1, -1}, {16441, -1, -1, -1}, {16442, -1, -1, -1}, {16443, -1, -1, -1}, {16444, -1, -1, -1}, {16445, -1, -1, -1}, {16446, -1, -1, -1}, {16447, -1, -1, -1}, {16448, -1, -1, -1}, {16449, -1, -1, -1}, {16450, -1, -1, -1}, {16451, -1, -1, -1}, {16452, -1, -1, -1}, {16453, -1, -1, -1}, {16454, -1, -1, -1}, {16455, -1, -1, -1}, {16456, -1, -1, -1}, {16457, -1, -1, -1}, {16458, -1, -1, -1}, {16459, -1, -1, -1}, {16460, -1, -1, -1}, {16461, -1, -1, -1}, {16462, -1, -1, -1}, {16463, -1, -1, -1}, {16464, -1, -1, -1}, {16465, -1, -1, -1}, {16466, -1, -1, -1}, {16467, -1, -1, -1}, {16468, -1, -1, -1}, {16469, -1, -1, -1}, {16471, -1, -1, -1}, {16472, -1, -1, -1}, {16473, -1, -1, -1}, {16474, -1, -1, -1}, {16475, -1, -1, -1}, {16476, -1, -1, -1}, {16477, -1, -1, -1}, {16478, -1, -1, -1}, {16479, -1, -1, -1}, {16480, -1, -1, -1}, {16481, -1, -1, -1}, {16482, -1, -1, -1}, {16483, -1, -1, -1}, {16484, -1, -1, -1}, {16485, -1, -1, -1}, {16486, -1, -1, -1}, {16487, -1, -1, -1}, {16488, -1, -1, -1}, {16489, -1, -1, -1}, {16490, -1, -1, -1}, {16491, -1, -1, -1}, {16492, -1, -1, -1}, {16493, -1, -1, -1}, {16494, -1, -1, -1}, {16495, -1, -1, -1}, {16496, -1, -1, -1}, {16497, -1, -1, -1}, {16498, -1, -1, -1}, {16499, -1, -1, -1}, {16500, -1, -1, -1}, {16501, -1, -1, -1}, {16502, -1, -1, -1}, {16503, -1, -1, -1}, {16504, -1, -1, -1}, {16505, -1, -1, -1}, {16506, -1, -1, -1}, {16507, -1, -1, -1}, {16508, -1, -1, -1}, {16509, -1, -1, -1}, {16510, -1, -1, -1}, {16511, -1, -1, -1}, {16512, -1, -1, -1}, {16513, -1, -1, -1}, {16514, -1, -1, -1}, {16515, -1, -1, -1}, {16516, -1, -1, -1}, {16517, -1, -1, -1}, {16518, -1, -1, -1}, {16519, -1, -1, -1}, {16520, -1, -1, -1}, {16521, -1, -1, -1}, {16522, -1, -1, -1}, {16523, -1, -1, -1}, {16524, -1, -1, -1}, {16525, -1, -1, -1}, {16526, -1, -1, -1}, {16527, -1, -1, -1}, {16528, -1, -1, -1}, {16529, -1, -1, -1}, {16530, -1, -1, -1}, {16531, -1, -1, -1}, {16532, -1, -1, -1}, {16533, -1, -1, -1}, {16534, -1, -1, -1}, {16535, -1, -1, -1}, {16536, -1, -1, -1}, {16537, -1, -1, -1}, {16538, -1, -1, -1}, {16539, -1, -1, -1}, {16540, -1, -1, -1}, {16541, -1, -1, -1}, {16542, -1, -1, -1}, {16543, -1, -1, -1}, {16544, -1, -1, -1}, {16545, -1, -1, -1}, {16546, -1, -1, -1}, {16547, -1, -1, -1}, {16548, -1, -1, -1}, {16549, -1, -1, -1}, {16550, -1, -1, -1}, {16551, -1, -1, -1}, {16552, -1, -1, -1}, {16553, -1, -1, -1}, {16554, -1, -1, -1}, {16555, -1, -1, -1}, {16556, -1, -1, -1}, {16557, -1, -1, -1}, {16558, -1, -1, -1}, {16559, -1, -1, -1}, {16560, -1, -1, -1}, {16561, -1, -1, -1}, {16562, -1, -1, -1}, {16563, -1, -1, -1}, {16564, -1, -1, -1}, {16565, -1, -1, -1}, {16566, -1, -1, -1}, {16567, -1, -1, -1}, {16568, -1, -1, -1}, {16569, -1, -1, -1}, {16570, -1, -1, -1}, {16571, -1, -1, -1}, {16572, -1, -1, -1}, {16573, -1, -1, -1}, {16574, -1, -1, -1}, {16575, -1, -1, -1}, {16576, -1, -1, -1}, {16577, -1, -1, -1}, {16578, -1, -1, -1}, {16579, -1, -1, -1}, {16580, -1, -1, -1}, {16581, -1, -1, -1}, {16582, -1, -1, -1}, {16583, -1, -1, -1}, {16584, -1, -1, -1}, {16585, -1, -1, -1}, {16586, -1, -1, -1}, {16587, -1, -1, -1}, {16588, -1, -1, -1}, {16589, -1, -1, -1}, {16590, -1, -1, -1}, {16591, -1, -1, -1}, {16592, -1, -1, -1}, {16593, -1, -1, -1}, {16594, -1, -1, -1}, {16595, -1, -1, -1}, {16596, -1, -1, -1}, {16597, -1, -1, -1}, {16598, -1, -1, -1}, {16599, -1, -1, -1}, {16600, -1, -1, -1}, {16601, -1, -1, -1}, {16602, -1, -1, -1}, {16603, -1, -1, -1}, {16604, -1, -1, -1}, {16605, -1, -1, -1}, {16606, -1, -1, -1}, {16607, -1, -1, -1}, {16608, -1, -1, -1}, {16609, -1, -1, -1}, {16610, -1, -1, -1}, {16611, -1, -1, -1}, {16612, -1, -1, -1}, {16613, -1, -1, -1}, {16614, -1, -1, -1}, {16615, -1, -1, -1}, {16616, -1, -1, -1}, {16617, -1, -1, -1}, {16618, -1, -1, -1}, {16619, -1, -1, -1}, {16620, -1, -1, -1}, {16621, -1, -1, -1}, {16622, -1, -1, -1}, {16623, -1, -1, -1}, {16624, -1, -1, -1}, {16625, -1, -1, -1}, {16626, -1, -1, -1}, {16627, -1, -1, -1}, {16628, -1, -1, -1}, {16629, -1, -1, -1}, {16630, -1, -1, -1}, {16631, -1, -1, -1}, {16632, -1, -1, -1}, {16633, -1, -1, -1}, {16634, -1, -1, -1}, {16635, -1, -1, -1}, {16636, -1, -1, -1}, {16637, -1, -1, -1}, {16638, -1, -1, -1}, {16639, -1, -1, -1}, {16640, -1, -1, -1}, {16641, -1, -1, -1}, {16642, -1, -1, -1}, {16643, -1, -1, -1}, {16644, -1, -1, -1}, {16645, -1, -1, -1}, {16646, -1, -1, -1}, {16647, -1, -1, -1}, {16648, -1, -1, -1}, {16649, -1, -1, -1}, {16650, -1, -1, -1}, {16651, -1, -1, -1}, {16652, -1, -1, -1}, {16653, -1, -1, -1} },
+ {{16654, -1, -1, -1}, {16655, -1, -1, -1}, {16656, -1, -1, -1}, {16657, -1, -1, -1}, {16658, -1, -1, -1}, {16659, -1, -1, -1}, {16660, -1, -1, -1}, {16661, -1, -1, -1}, {16662, -1, -1, -1}, {16663, -1, -1, -1}, {16664, -1, -1, -1}, {16665, -1, -1, -1}, {16666, -1, -1, -1}, {16667, -1, -1, -1}, {16668, -1, -1, -1}, {16669, -1, -1, -1}, {16670, -1, -1, -1}, {16671, -1, -1, -1}, {16672, -1, -1, -1}, {16673, -1, -1, -1}, {16674, -1, -1, -1}, {16675, -1, -1, -1}, {16676, -1, -1, -1}, {16677, -1, -1, -1}, {16678, -1, -1, -1}, {16679, -1, -1, -1}, {16680, -1, -1, -1}, {16681, -1, -1, -1}, {16682, -1, -1, -1}, {16683, -1, -1, -1}, {16684, -1, -1, -1}, {16685, -1, -1, -1}, {16686, -1, -1, -1}, {16687, -1, -1, -1}, {16688, -1, -1, -1}, {16689, -1, -1, -1}, {16690, -1, -1, -1}, {16691, -1, -1, -1}, {16692, -1, -1, -1}, {16693, -1, -1, -1}, {16694, -1, -1, -1}, {16695, -1, -1, -1}, {16696, -1, -1, -1}, {16697, -1, -1, -1}, {16698, -1, -1, -1}, {16699, -1, -1, -1}, {16700, -1, -1, -1}, {16701, -1, -1, -1}, {16702, -1, -1, -1}, {16703, -1, -1, -1}, {16704, -1, -1, -1}, {16705, -1, -1, -1}, {16706, -1, -1, -1}, {16707, -1, -1, -1}, {16708, -1, -1, -1}, {16709, -1, -1, -1}, {16710, -1, -1, -1}, {16711, -1, -1, -1}, {16712, -1, -1, -1}, {16713, -1, -1, -1}, {16714, -1, -1, -1}, {16715, -1, -1, -1}, {16716, -1, -1, -1}, {16717, -1, -1, -1}, {16718, -1, -1, -1}, {16719, -1, -1, -1}, {16720, -1, -1, -1}, {16721, -1, -1, -1}, {16722, -1, -1, -1}, {16723, -1, -1, -1}, {16724, -1, -1, -1}, {16725, -1, -1, -1}, {16726, -1, -1, -1}, {16727, -1, -1, -1}, {16728, -1, -1, -1}, {16729, -1, -1, -1}, {16730, -1, -1, -1}, {16731, -1, -1, -1}, {16732, -1, -1, -1}, {16733, -1, -1, -1}, {16734, -1, -1, -1}, {16736, -1, -1, -1}, {16737, -1, -1, -1}, {16738, -1, -1, -1}, {16739, -1, -1, -1}, {16740, -1, -1, -1}, {16741, -1, -1, -1}, {16742, -1, -1, -1}, {16743, -1, -1, -1}, {16744, -1, -1, -1}, {16745, -1, -1, -1}, {16746, -1, -1, -1}, {16747, -1, -1, -1}, {16748, -1, -1, -1}, {16749, -1, -1, -1}, {16750, -1, -1, -1}, {16751, -1, -1, -1}, {16752, -1, -1, -1}, {16753, -1, -1, -1}, {16754, -1, -1, -1}, {16755, -1, -1, -1}, {16756, -1, -1, -1}, {16757, -1, -1, -1}, {16758, -1, -1, -1}, {16759, -1, -1, -1}, {16760, -1, -1, -1}, {16761, -1, -1, -1}, {16762, -1, -1, -1}, {16763, -1, -1, -1}, {16764, -1, -1, -1}, {16765, -1, -1, -1}, {16766, -1, -1, -1}, {16767, -1, -1, -1}, {16768, -1, -1, -1}, {16769, -1, -1, -1}, {16770, -1, -1, -1}, {16771, -1, -1, -1}, {16772, -1, -1, -1}, {16773, -1, -1, -1}, {16774, -1, -1, -1}, {16775, -1, -1, -1}, {16776, -1, -1, -1}, {16777, -1, -1, -1}, {16778, -1, -1, -1}, {16779, -1, -1, -1}, {16780, -1, -1, -1}, {16781, -1, -1, -1}, {16782, -1, -1, -1}, {16783, -1, -1, -1}, {16784, -1, -1, -1}, {16785, -1, -1, -1}, {16786, -1, -1, -1}, {16787, -1, -1, -1}, {16788, -1, -1, -1}, {16789, -1, -1, -1}, {16790, -1, -1, -1}, {16791, -1, -1, -1}, {16792, -1, -1, -1}, {16793, -1, -1, -1}, {16794, -1, -1, -1}, {16795, -1, -1, -1}, {16796, -1, -1, -1}, {16797, -1, -1, -1}, {16798, -1, -1, -1}, {16799, -1, -1, -1}, {16800, -1, -1, -1}, {16801, -1, -1, -1}, {16802, -1, -1, -1}, {16803, -1, -1, -1}, {16804, -1, -1, -1}, {16805, -1, -1, -1}, {16806, -1, -1, -1}, {16807, -1, -1, -1}, {16808, -1, -1, -1}, {16809, -1, -1, -1}, {16810, -1, -1, -1}, {16811, -1, -1, -1}, {16812, -1, -1, -1}, {16813, -1, -1, -1}, {16814, -1, -1, -1}, {16815, -1, -1, -1}, {16816, -1, -1, -1}, {16817, -1, -1, -1}, {16818, -1, -1, -1}, {16819, -1, -1, -1}, {16820, -1, -1, -1}, {16821, -1, -1, -1}, {16822, -1, -1, -1}, {16823, -1, -1, -1}, {16824, -1, -1, -1}, {16825, -1, -1, -1}, {16826, -1, -1, -1}, {16827, -1, -1, -1}, {16828, -1, -1, -1}, {16829, -1, -1, -1}, {16830, -1, -1, -1}, {16831, -1, -1, -1}, {16832, -1, -1, -1}, {16833, -1, -1, -1}, {16834, -1, -1, -1}, {16835, -1, -1, -1}, {16836, -1, -1, -1}, {16837, -1, -1, -1}, {16838, -1, -1, -1}, {16839, -1, -1, -1}, {16840, -1, -1, -1}, {16841, -1, -1, -1}, {16842, -1, -1, -1}, {16843, -1, -1, -1}, {16844, -1, -1, -1}, {16845, -1, -1, -1}, {16846, -1, -1, -1}, {16847, -1, -1, -1}, {16848, -1, -1, -1}, {16849, -1, -1, -1}, {16850, -1, -1, -1}, {16851, -1, -1, -1}, {16852, -1, -1, -1}, {16853, -1, -1, -1}, {16854, -1, -1, -1}, {16855, -1, -1, -1}, {16856, -1, -1, -1}, {16857, -1, -1, -1}, {16858, -1, -1, -1}, {16859, -1, -1, -1}, {16860, -1, -1, -1}, {16861, -1, -1, -1}, {16862, -1, -1, -1}, {16863, -1, -1, -1}, {16864, -1, -1, -1}, {16865, -1, -1, -1}, {16866, -1, -1, -1}, {16867, -1, -1, -1}, {16868, -1, -1, -1}, {16869, -1, -1, -1}, {16870, -1, -1, -1}, {16871, -1, -1, -1}, {16872, -1, -1, -1}, {16873, -1, -1, -1}, {16874, -1, -1, -1}, {16875, -1, -1, -1}, {16876, -1, -1, -1}, {16877, -1, -1, -1}, {16878, -1, -1, -1}, {16879, -1, -1, -1}, {16880, -1, -1, -1}, {16881, -1, -1, -1}, {16882, -1, -1, -1}, {16883, -1, -1, -1}, {16884, -1, -1, -1}, {16885, -1, -1, -1}, {16886, -1, -1, -1}, {16887, -1, -1, -1}, {16888, -1, -1, -1}, {16889, -1, -1, -1}, {16890, -1, -1, -1}, {16891, -1, -1, -1}, {16892, -1, -1, -1}, {16893, -1, -1, -1}, {16894, -1, -1, -1}, {16895, -1, -1, -1}, {16896, -1, -1, -1}, {16897, -1, -1, -1}, {16898, -1, -1, -1}, {16899, -1, -1, -1}, {16900, -1, -1, -1}, {16901, -1, -1, -1}, {16902, -1, -1, -1}, {16903, -1, -1, -1}, {16904, -1, -1, -1}, {16905, -1, -1, -1}, {16906, -1, -1, -1}, {16907, -1, -1, -1}, {16908, -1, -1, -1}, {16909, -1, -1, -1}, {16910, -1, -1, -1} },
+ {{16911, -1, -1, -1}, {16912, -1, -1, -1}, {16913, -1, -1, -1}, {16914, -1, -1, -1}, {16915, -1, -1, -1}, {16916, -1, -1, -1}, {16917, -1, -1, -1}, {16918, -1, -1, -1}, {16919, -1, -1, -1}, {16920, -1, -1, -1}, {16921, -1, -1, -1}, {16922, -1, -1, -1}, {16923, -1, -1, -1}, {16924, -1, -1, -1}, {16925, -1, -1, -1}, {16926, -1, -1, -1}, {16927, -1, -1, -1}, {16928, -1, -1, -1}, {16929, -1, -1, -1}, {16930, -1, -1, -1}, {16931, -1, -1, -1}, {16932, -1, -1, -1}, {16933, -1, -1, -1}, {16934, -1, -1, -1}, {16935, -1, -1, -1}, {16936, -1, -1, -1}, {16937, -1, -1, -1}, {16938, -1, -1, -1}, {16939, -1, -1, -1}, {16940, -1, -1, -1}, {16941, -1, -1, -1}, {16942, -1, -1, -1}, {16943, -1, -1, -1}, {16944, -1, -1, -1}, {16945, -1, -1, -1}, {16946, -1, -1, -1}, {16947, -1, -1, -1}, {16948, -1, -1, -1}, {16949, -1, -1, -1}, {16950, -1, -1, -1}, {16951, -1, -1, -1}, {16952, -1, -1, -1}, {16953, -1, -1, -1}, {16954, -1, -1, -1}, {16955, -1, -1, -1}, {16956, -1, -1, -1}, {16957, -1, -1, -1}, {16958, -1, -1, -1}, {16959, -1, -1, -1}, {16960, -1, -1, -1}, {16961, -1, -1, -1}, {16962, -1, -1, -1}, {16963, -1, -1, -1}, {16964, -1, -1, -1}, {16965, -1, -1, -1}, {16966, -1, -1, -1}, {16967, -1, -1, -1}, {16968, -1, -1, -1}, {16969, -1, -1, -1}, {16970, -1, -1, -1}, {16971, -1, -1, -1}, {16972, -1, -1, -1}, {16973, -1, -1, -1}, {16974, -1, -1, -1}, {16975, -1, -1, -1}, {16976, -1, -1, -1}, {16977, -1, -1, -1}, {16978, -1, -1, -1}, {16979, -1, -1, -1}, {16980, -1, -1, -1}, {16981, -1, -1, -1}, {16982, -1, -1, -1}, {16983, -1, -1, -1}, {16984, -1, -1, -1}, {16985, -1, -1, -1}, {16986, -1, -1, -1}, {16987, -1, -1, -1}, {16988, -1, -1, -1}, {16989, -1, -1, -1}, {16990, -1, -1, -1}, {16991, -1, -1, -1}, {16992, -1, -1, -1}, {16993, -1, -1, -1}, {16994, -1, -1, -1}, {16995, -1, -1, -1}, {16996, -1, -1, -1}, {16997, -1, -1, -1}, {16998, -1, -1, -1}, {16999, -1, -1, -1}, {17000, -1, -1, -1}, {17001, -1, -1, -1}, {17002, -1, -1, -1}, {17003, -1, -1, -1}, {17004, -1, -1, -1}, {17005, -1, -1, -1}, {17006, -1, -1, -1}, {17007, -1, -1, -1}, {17008, -1, -1, -1}, {17009, -1, -1, -1}, {17010, -1, -1, -1}, {17011, -1, -1, -1}, {17012, -1, -1, -1}, {17013, -1, -1, -1}, {17014, -1, -1, -1}, {17015, -1, -1, -1}, {17016, -1, -1, -1}, {17017, -1, -1, -1}, {17018, -1, -1, -1}, {17019, -1, -1, -1}, {17020, -1, -1, -1}, {17021, -1, -1, -1}, {17022, -1, -1, -1}, {17023, -1, -1, -1}, {17024, -1, -1, -1}, {17025, -1, -1, -1}, {17026, -1, -1, -1}, {17027, -1, -1, -1}, {17028, -1, -1, -1}, {17029, -1, -1, -1}, {17030, -1, -1, -1}, {17031, -1, -1, -1}, {17032, -1, -1, -1}, {17033, -1, -1, -1}, {17034, -1, -1, -1}, {17035, -1, -1, -1}, {17036, -1, -1, -1}, {17037, -1, -1, -1}, {17038, -1, -1, -1}, {17039, -1, -1, -1}, {17040, -1, -1, -1}, {17041, -1, -1, -1}, {17042, -1, -1, -1}, {17043, -1, -1, -1}, {17044, -1, -1, -1}, {17045, -1, -1, -1}, {17046, -1, -1, -1}, {17047, -1, -1, -1}, {17048, -1, -1, -1}, {17049, -1, -1, -1}, {17050, -1, -1, -1}, {17051, -1, -1, -1}, {17052, -1, -1, -1}, {17053, -1, -1, -1}, {17054, -1, -1, -1}, {17055, -1, -1, -1}, {17056, -1, -1, -1}, {17057, -1, -1, -1}, {17058, -1, -1, -1}, {17059, -1, -1, -1}, {17060, -1, -1, -1}, {17061, -1, -1, -1}, {17062, -1, -1, -1}, {17063, -1, -1, -1}, {17064, -1, -1, -1}, {17065, -1, -1, -1}, {17066, -1, -1, -1}, {17067, -1, -1, -1}, {17068, -1, -1, -1}, {17069, -1, -1, -1}, {17070, -1, -1, -1}, {17071, -1, -1, -1}, {17072, -1, -1, -1}, {17073, -1, -1, -1}, {17074, -1, -1, -1}, {17075, -1, -1, -1}, {17076, -1, -1, -1}, {17077, -1, -1, -1}, {17078, -1, -1, -1}, {17079, -1, -1, -1}, {17080, -1, -1, -1}, {17081, -1, -1, -1}, {17082, -1, -1, -1}, {17083, -1, -1, -1}, {17084, -1, -1, -1}, {17085, -1, -1, -1}, {17086, -1, -1, -1}, {17087, -1, -1, -1}, {17088, -1, -1, -1}, {17089, -1, -1, -1}, {17090, -1, -1, -1}, {17091, -1, -1, -1}, {17092, -1, -1, -1}, {17093, -1, -1, -1}, {17094, -1, -1, -1}, {17095, -1, -1, -1}, {17096, -1, -1, -1}, {17097, -1, -1, -1}, {17098, -1, -1, -1}, {17099, -1, -1, -1}, {17100, -1, -1, -1}, {17101, -1, -1, -1}, {17102, -1, -1, -1}, {17103, -1, -1, -1}, {17104, -1, -1, -1}, {17105, -1, -1, -1}, {17106, -1, -1, -1}, {17107, -1, -1, -1}, {17108, -1, -1, -1}, {17109, -1, -1, -1}, {17110, -1, -1, -1}, {17111, -1, -1, -1}, {17112, -1, -1, -1}, {17113, -1, -1, -1}, {17114, -1, -1, -1}, {17115, -1, -1, -1}, {17116, -1, -1, -1}, {17117, -1, -1, -1}, {17118, -1, -1, -1}, {17119, -1, -1, -1}, {17120, -1, -1, -1}, {17121, -1, -1, -1}, {17122, -1, -1, -1}, {17123, -1, -1, -1}, {17124, -1, -1, -1}, {17125, -1, -1, -1}, {17126, -1, -1, -1}, {17127, -1, -1, -1}, {17128, -1, -1, -1}, {17129, -1, -1, -1}, {17130, -1, -1, -1}, {17131, -1, -1, -1}, {17132, -1, -1, -1}, {17133, -1, -1, -1}, {17134, -1, -1, -1}, {17135, -1, -1, -1}, {17136, -1, -1, -1}, {17137, -1, -1, -1}, {17138, -1, -1, -1}, {17139, -1, -1, -1}, {17140, -1, -1, -1}, {17141, -1, -1, -1}, {17142, -1, -1, -1}, {17143, -1, -1, -1}, {17144, -1, -1, -1}, {17145, -1, -1, -1}, {17146, -1, -1, -1}, {17147, -1, -1, -1}, {17148, -1, -1, -1}, {17149, -1, -1, -1}, {17150, -1, -1, -1}, {17151, -1, -1, -1}, {17152, -1, -1, -1}, {17153, -1, -1, -1}, {17154, -1, -1, -1}, {17155, -1, -1, -1}, {17156, -1, -1, -1}, {17157, -1, -1, -1}, {17158, -1, -1, -1}, {17159, -1, -1, -1}, {17160, -1, -1, -1}, {17161, -1, -1, -1}, {17162, -1, -1, -1}, {17163, -1, -1, -1}, {17164, -1, -1, -1}, {17165, -1, -1, -1}, {17166, -1, -1, -1} },
+ {{17167, -1, -1, -1}, {17168, -1, -1, -1}, {17169, -1, -1, -1}, {17170, -1, -1, -1}, {17171, -1, -1, -1}, {17172, -1, -1, -1}, {17173, -1, -1, -1}, {17174, -1, -1, -1}, {17175, -1, -1, -1}, {17176, -1, -1, -1}, {17177, -1, -1, -1}, {17178, -1, -1, -1}, {17179, -1, -1, -1}, {17180, -1, -1, -1}, {17181, -1, -1, -1}, {17182, -1, -1, -1}, {17183, -1, -1, -1}, {17184, -1, -1, -1}, {17185, -1, -1, -1}, {17186, -1, -1, -1}, {17187, -1, -1, -1}, {17188, -1, -1, -1}, {17189, -1, -1, -1}, {17190, -1, -1, -1}, {17191, -1, -1, -1}, {17192, -1, -1, -1}, {17193, -1, -1, -1}, {17194, -1, -1, -1}, {17195, -1, -1, -1}, {17196, -1, -1, -1}, {17197, -1, -1, -1}, {17198, -1, -1, -1}, {17199, -1, -1, -1}, {17200, -1, -1, -1}, {17201, -1, -1, -1}, {17202, -1, -1, -1}, {17203, -1, -1, -1}, {17204, -1, -1, -1}, {17205, -1, -1, -1}, {17206, -1, -1, -1}, {17208, -1, -1, -1}, {17209, -1, -1, -1}, {17210, -1, -1, -1}, {17211, -1, -1, -1}, {17212, -1, -1, -1}, {17213, -1, -1, -1}, {17214, -1, -1, -1}, {17215, -1, -1, -1}, {17216, -1, -1, -1}, {17217, -1, -1, -1}, {17218, -1, -1, -1}, {17219, -1, -1, -1}, {17220, -1, -1, -1}, {17221, -1, -1, -1}, {17222, -1, -1, -1}, {17223, -1, -1, -1}, {17224, -1, -1, -1}, {17225, -1, -1, -1}, {17226, -1, -1, -1}, {17227, -1, -1, -1}, {17228, -1, -1, -1}, {17229, -1, -1, -1}, {17230, -1, -1, -1}, {17231, -1, -1, -1}, {17232, -1, -1, -1}, {17233, -1, -1, -1}, {17234, -1, -1, -1}, {17235, -1, -1, -1}, {17236, -1, -1, -1}, {17237, -1, -1, -1}, {17238, -1, -1, -1}, {17239, -1, -1, -1}, {17240, -1, -1, -1}, {17241, -1, -1, -1}, {17242, -1, -1, -1}, {17243, -1, -1, -1}, {17244, -1, -1, -1}, {17245, -1, -1, -1}, {17246, -1, -1, -1}, {17247, -1, -1, -1}, {17248, -1, -1, -1}, {17249, -1, -1, -1}, {17250, -1, -1, -1}, {17251, -1, -1, -1}, {17252, -1, -1, -1}, {17253, -1, -1, -1}, {17254, -1, -1, -1}, {17255, -1, -1, -1}, {17256, -1, -1, -1}, {17257, -1, -1, -1}, {17258, -1, -1, -1}, {17259, -1, -1, -1}, {17260, -1, -1, -1}, {17261, -1, -1, -1}, {17262, -1, -1, -1}, {17263, -1, -1, -1}, {17264, -1, -1, -1}, {17265, -1, -1, -1}, {17266, -1, -1, -1}, {17267, -1, -1, -1}, {17268, -1, -1, -1}, {17269, -1, -1, -1}, {17270, -1, -1, -1}, {17271, -1, -1, -1}, {17272, -1, -1, -1}, {17273, -1, -1, -1}, {17274, -1, -1, -1}, {17275, -1, -1, -1}, {17276, -1, -1, -1}, {17277, -1, -1, -1}, {17278, -1, -1, -1}, {17279, -1, -1, -1}, {17280, -1, -1, -1}, {17281, -1, -1, -1}, {17282, -1, -1, -1}, {17283, -1, -1, -1}, {17284, -1, -1, -1}, {17285, -1, -1, -1}, {17286, -1, -1, -1}, {17287, -1, -1, -1}, {17288, -1, -1, -1}, {17289, -1, -1, -1}, {17290, -1, -1, -1}, {17291, -1, -1, -1}, {17292, -1, -1, -1}, {17293, -1, -1, -1}, {17294, -1, -1, -1}, {17295, -1, -1, -1}, {17296, -1, -1, -1}, {17297, -1, -1, -1}, {17298, -1, -1, -1}, {17299, -1, -1, -1}, {17300, -1, -1, -1}, {17301, -1, -1, -1}, {17302, -1, -1, -1}, {17303, -1, -1, -1}, {17304, -1, -1, -1}, {17305, -1, -1, -1}, {17306, -1, -1, -1}, {17307, -1, -1, -1}, {17308, -1, -1, -1}, {17309, -1, -1, -1}, {17310, -1, -1, -1}, {17311, -1, -1, -1}, {17312, -1, -1, -1}, {17313, -1, -1, -1}, {17314, -1, -1, -1}, {17315, -1, -1, -1}, {17316, -1, -1, -1}, {17317, -1, -1, -1}, {17318, -1, -1, -1}, {17319, -1, -1, -1}, {17320, -1, -1, -1}, {17321, -1, -1, -1}, {17322, -1, -1, -1}, {17323, -1, -1, -1}, {17325, -1, -1, -1}, {17326, -1, -1, -1}, {17327, -1, -1, -1}, {17328, -1, -1, -1}, {17330, -1, -1, -1}, {17331, -1, -1, -1}, {17332, -1, -1, -1}, {17333, -1, -1, -1}, {17334, -1, -1, -1}, {17335, -1, -1, -1}, {17336, -1, -1, -1}, {17337, -1, -1, -1}, {17338, -1, -1, -1}, {17339, -1, -1, -1}, {17340, -1, -1, -1}, {17341, -1, -1, -1}, {17342, -1, -1, -1}, {17343, -1, -1, -1}, {17344, -1, -1, -1}, {17345, -1, -1, -1}, {17346, -1, -1, -1}, {17347, -1, -1, -1}, {17348, -1, -1, -1}, {17349, -1, -1, -1}, {17350, -1, -1, -1}, {17351, -1, -1, -1}, {17352, -1, -1, -1}, {17353, -1, -1, -1}, {17354, -1, -1, -1}, {17355, -1, -1, -1}, {17356, -1, -1, -1}, {17357, -1, -1, -1}, {17358, -1, -1, -1}, {17359, -1, -1, -1}, {17360, -1, -1, -1}, {17361, -1, -1, -1}, {17362, -1, -1, -1}, {17363, -1, -1, -1}, {17364, -1, -1, -1}, {17365, -1, -1, -1}, {17366, -1, -1, -1}, {17367, -1, -1, -1}, {17368, -1, -1, -1}, {17369, -1, -1, -1}, {17370, -1, -1, -1}, {17371, -1, -1, -1}, {17372, -1, -1, -1}, {17374, -1, -1, -1}, {17375, -1, -1, -1}, {17376, -1, -1, -1}, {17377, -1, -1, -1}, {17378, -1, -1, -1}, {17379, -1, -1, -1}, {17380, -1, -1, -1}, {17381, -1, -1, -1}, {17382, -1, -1, -1}, {17383, -1, -1, -1}, {17384, -1, -1, -1}, {17385, -1, -1, -1}, {17386, -1, -1, -1}, {17387, -1, -1, -1}, {17388, -1, -1, -1}, {17389, -1, -1, -1}, {17390, -1, -1, -1}, {17391, -1, -1, -1}, {17392, -1, -1, -1}, {17393, -1, -1, -1}, {17394, -1, -1, -1}, {17395, -1, -1, -1}, {17396, -1, -1, -1}, {17397, -1, -1, -1}, {17398, -1, -1, -1}, {17399, -1, -1, -1}, {17400, -1, -1, -1}, {17401, -1, -1, -1}, {17402, -1, -1, -1}, {17403, -1, -1, -1}, {17404, -1, -1, -1}, {17405, -1, -1, -1}, {17406, -1, -1, -1}, {17407, -1, -1, -1}, {17408, -1, -1, -1}, {17409, -1, -1, -1}, {17410, -1, -1, -1}, {17411, -1, -1, -1}, {17412, -1, -1, -1}, {17413, -1, -1, -1}, {17414, -1, -1, -1}, {17415, -1, -1, -1}, {17416, -1, -1, -1}, {17417, -1, -1, -1}, {17418, -1, -1, -1}, {17419, -1, -1, -1}, {17420, -1, -1, -1}, {17421, -1, -1, -1}, {17422, -1, -1, -1}, {17423, -1, -1, -1}, {17424, -1, -1, -1}, {17425, -1, -1, -1}, {17426, -1, -1, -1} },
+ {{17427, -1, -1, -1}, {17428, -1, -1, -1}, {17429, -1, -1, -1}, {17430, -1, -1, -1}, {17431, -1, -1, -1}, {17432, -1, -1, -1}, {17433, -1, -1, -1}, {17434, -1, -1, -1}, {17435, -1, -1, -1}, {17436, -1, -1, -1}, {17437, -1, -1, -1}, {17438, -1, -1, -1}, {17439, -1, -1, -1}, {17440, -1, -1, -1}, {17441, -1, -1, -1}, {17442, -1, -1, -1}, {17443, -1, -1, -1}, {17444, -1, -1, -1}, {17445, -1, -1, -1}, {17446, -1, -1, -1}, {17447, -1, -1, -1}, {17448, -1, -1, -1}, {17449, -1, -1, -1}, {17450, -1, -1, -1}, {17451, -1, -1, -1}, {17452, -1, -1, -1}, {17453, -1, -1, -1}, {17454, -1, -1, -1}, {17455, -1, -1, -1}, {17456, -1, -1, -1}, {17457, -1, -1, -1}, {17458, -1, -1, -1}, {17459, -1, -1, -1}, {17460, -1, -1, -1}, {17461, -1, -1, -1}, {17462, -1, -1, -1}, {17463, -1, -1, -1}, {17464, -1, -1, -1}, {17465, -1, -1, -1}, {17466, -1, -1, -1}, {17467, -1, -1, -1}, {17468, -1, -1, -1}, {17469, -1, -1, -1}, {17470, -1, -1, -1}, {17471, -1, -1, -1}, {17472, -1, -1, -1}, {17473, -1, -1, -1}, {17474, -1, -1, -1}, {17475, -1, -1, -1}, {17476, -1, -1, -1}, {17477, -1, -1, -1}, {17478, -1, -1, -1}, {17479, -1, -1, -1}, {17480, -1, -1, -1}, {17481, -1, -1, -1}, {17482, -1, -1, -1}, {17483, -1, -1, -1}, {17484, -1, -1, -1}, {17485, -1, -1, -1}, {17486, -1, -1, -1}, {17487, -1, -1, -1}, {17488, -1, -1, -1}, {17489, -1, -1, -1}, {17490, -1, -1, -1}, {17491, -1, -1, -1}, {17492, -1, -1, -1}, {17493, -1, -1, -1}, {17494, -1, -1, -1}, {17495, -1, -1, -1}, {17496, -1, -1, -1}, {17497, -1, -1, -1}, {17498, -1, -1, -1}, {17499, -1, -1, -1}, {17500, -1, -1, -1}, {17501, -1, -1, -1}, {17502, -1, -1, -1}, {17503, -1, -1, -1}, {17504, -1, -1, -1}, {17505, -1, -1, -1}, {17506, -1, -1, -1}, {17507, -1, -1, -1}, {17508, -1, -1, -1}, {17509, -1, -1, -1}, {17510, -1, -1, -1}, {17511, -1, -1, -1}, {17512, -1, -1, -1}, {17513, -1, -1, -1}, {17514, -1, -1, -1}, {17515, -1, -1, -1}, {17516, -1, -1, -1}, {17517, -1, -1, -1}, {17518, -1, -1, -1}, {17519, -1, -1, -1}, {17520, -1, -1, -1}, {17521, -1, -1, -1}, {17522, -1, -1, -1}, {17523, -1, -1, -1}, {17524, -1, -1, -1}, {17525, -1, -1, -1}, {17526, -1, -1, -1}, {17527, -1, -1, -1}, {17528, -1, -1, -1}, {17529, -1, -1, -1}, {17530, -1, -1, -1}, {17531, -1, -1, -1}, {17532, -1, -1, -1}, {17533, -1, -1, -1}, {17534, -1, -1, -1}, {17535, -1, -1, -1}, {17536, -1, -1, -1}, {17537, -1, -1, -1}, {17538, -1, -1, -1}, {17539, -1, -1, -1}, {17540, -1, -1, -1}, {17541, -1, -1, -1}, {17542, -1, -1, -1}, {17543, -1, -1, -1}, {17544, -1, -1, -1}, {17545, -1, -1, -1}, {17546, -1, -1, -1}, {17547, -1, -1, -1}, {17548, -1, -1, -1}, {17549, -1, -1, -1}, {17550, -1, -1, -1}, {17551, -1, -1, -1}, {17552, -1, -1, -1}, {17553, -1, -1, -1}, {17554, -1, -1, -1}, {17555, -1, -1, -1}, {17556, -1, -1, -1}, {17557, -1, -1, -1}, {17558, -1, -1, -1}, {17559, -1, -1, -1}, {17560, -1, -1, -1}, {17561, -1, -1, -1}, {17562, -1, -1, -1}, {17563, -1, -1, -1}, {17564, -1, -1, -1}, {17565, -1, -1, -1}, {17566, -1, -1, -1}, {17567, -1, -1, -1}, {17568, -1, -1, -1}, {17569, -1, -1, -1}, {17570, -1, -1, -1}, {17571, -1, -1, -1}, {17572, -1, -1, -1}, {17573, -1, -1, -1}, {17574, -1, -1, -1}, {17575, -1, -1, -1}, {17576, -1, -1, -1}, {17577, -1, -1, -1}, {17578, -1, -1, -1}, {17579, -1, -1, -1}, {17580, -1, -1, -1}, {17581, -1, -1, -1}, {17582, -1, -1, -1}, {17583, -1, -1, -1}, {17584, -1, -1, -1}, {17585, -1, -1, -1}, {17586, -1, -1, -1}, {17587, -1, -1, -1}, {17588, -1, -1, -1}, {17589, -1, -1, -1}, {17590, -1, -1, -1}, {17591, -1, -1, -1}, {17592, -1, -1, -1}, {17593, -1, -1, -1}, {17594, -1, -1, -1}, {17595, -1, -1, -1}, {17596, -1, -1, -1}, {17597, -1, -1, -1}, {17598, -1, -1, -1}, {17599, -1, -1, -1}, {17600, -1, -1, -1}, {17601, -1, -1, -1}, {17602, -1, -1, -1}, {17603, -1, -1, -1}, {17604, -1, -1, -1}, {17605, -1, -1, -1}, {17606, -1, -1, -1}, {17607, -1, -1, -1}, {17608, -1, -1, -1}, {17609, -1, -1, -1}, {17610, -1, -1, -1}, {17611, -1, -1, -1}, {17612, -1, -1, -1}, {17613, -1, -1, -1}, {17614, -1, -1, -1}, {17615, -1, -1, -1}, {17616, -1, -1, -1}, {17617, -1, -1, -1}, {17618, -1, -1, -1}, {17619, -1, -1, -1}, {17620, -1, -1, -1}, {17621, -1, -1, -1}, {17623, -1, -1, -1}, {17624, -1, -1, -1}, {17625, -1, -1, -1}, {17626, -1, -1, -1}, {17627, -1, -1, -1}, {17628, -1, -1, -1}, {17629, -1, -1, -1}, {17630, -1, -1, -1}, {17631, -1, -1, -1}, {17632, -1, -1, -1}, {17633, -1, -1, -1}, {17634, -1, -1, -1}, {17635, -1, -1, -1}, {17636, -1, -1, -1}, {17637, -1, -1, -1}, {17638, -1, -1, -1}, {17639, -1, -1, -1}, {17640, -1, -1, -1}, {17641, -1, -1, -1}, {17642, -1, -1, -1}, {17643, -1, -1, -1}, {17644, -1, -1, -1}, {17645, -1, -1, -1}, {17646, -1, -1, -1}, {17647, -1, -1, -1}, {17648, -1, -1, -1}, {17649, -1, -1, -1}, {17650, -1, -1, -1}, {17651, -1, -1, -1}, {17652, -1, -1, -1}, {17653, -1, -1, -1}, {17654, -1, -1, -1}, {17655, -1, -1, -1}, {17656, -1, -1, -1}, {17657, -1, -1, -1}, {17658, -1, -1, -1}, {17659, -1, -1, -1}, {17660, -1, -1, -1}, {17661, -1, -1, -1}, {17662, -1, -1, -1}, {17663, -1, -1, -1}, {17664, -1, -1, -1}, {17665, -1, -1, -1}, {17666, -1, -1, -1}, {17667, -1, -1, -1}, {17668, -1, -1, -1}, {17669, -1, -1, -1}, {17670, -1, -1, -1}, {17671, -1, -1, -1}, {17672, -1, -1, -1}, {17673, -1, -1, -1}, {17674, -1, -1, -1}, {17675, -1, -1, -1}, {17676, -1, -1, -1}, {17677, -1, -1, -1}, {17678, -1, -1, -1}, {17679, -1, -1, -1}, {17680, -1, -1, -1}, {17681, -1, -1, -1}, {17682, -1, -1, -1}, {17683, -1, -1, -1} },
+ {{17684, -1, -1, -1}, {17685, -1, -1, -1}, {17686, -1, -1, -1}, {17687, -1, -1, -1}, {17688, -1, -1, -1}, {17689, -1, -1, -1}, {17690, -1, -1, -1}, {17691, -1, -1, -1}, {17692, -1, -1, -1}, {17693, -1, -1, -1}, {17694, -1, -1, -1}, {17695, -1, -1, -1}, {17696, -1, -1, -1}, {17697, -1, -1, -1}, {17698, -1, -1, -1}, {17699, -1, -1, -1}, {17700, -1, -1, -1}, {17701, -1, -1, -1}, {17702, -1, -1, -1}, {17703, -1, -1, -1}, {17704, -1, -1, -1}, {17705, -1, -1, -1}, {17706, -1, -1, -1}, {17707, -1, -1, -1}, {17708, -1, -1, -1}, {17709, -1, -1, -1}, {17710, -1, -1, -1}, {17711, -1, -1, -1}, {17712, -1, -1, -1}, {17713, -1, -1, -1}, {17714, -1, -1, -1}, {17715, -1, -1, -1}, {17716, -1, -1, -1}, {17717, -1, -1, -1}, {17718, -1, -1, -1}, {17719, -1, -1, -1}, {17720, -1, -1, -1}, {17721, -1, -1, -1}, {17722, -1, -1, -1}, {17723, -1, -1, -1}, {17724, -1, -1, -1}, {17725, -1, -1, -1}, {17726, -1, -1, -1}, {17727, -1, -1, -1}, {17728, -1, -1, -1}, {17729, -1, -1, -1}, {17730, -1, -1, -1}, {17731, -1, -1, -1}, {17732, -1, -1, -1}, {17733, -1, -1, -1}, {17734, -1, -1, -1}, {17735, -1, -1, -1}, {17736, -1, -1, -1}, {17737, -1, -1, -1}, {17738, -1, -1, -1}, {17739, -1, -1, -1}, {17740, -1, -1, -1}, {17741, -1, -1, -1}, {17742, -1, -1, -1}, {17743, -1, -1, -1}, {17744, -1, -1, -1}, {17745, -1, -1, -1}, {17746, -1, -1, -1}, {17747, -1, -1, -1}, {17748, -1, -1, -1}, {17749, -1, -1, -1}, {17750, -1, -1, -1}, {17751, -1, -1, -1}, {17752, -1, -1, -1}, {17753, -1, -1, -1}, {17754, -1, -1, -1}, {17755, -1, -1, -1}, {17756, -1, -1, -1}, {17757, -1, -1, -1}, {17758, -1, -1, -1}, {17759, -1, -1, -1}, {17760, -1, -1, -1}, {17761, -1, -1, -1}, {17762, -1, -1, -1}, {17763, -1, -1, -1}, {17764, -1, -1, -1}, {17765, -1, -1, -1}, {17766, -1, -1, -1}, {17767, -1, -1, -1}, {17768, -1, -1, -1}, {17769, -1, -1, -1}, {17770, -1, -1, -1}, {17771, -1, -1, -1}, {17772, -1, -1, -1}, {17773, -1, -1, -1}, {17774, -1, -1, -1}, {17775, -1, -1, -1}, {17776, -1, -1, -1}, {17777, -1, -1, -1}, {17778, -1, -1, -1}, {17779, -1, -1, -1}, {17780, -1, -1, -1}, {17781, -1, -1, -1}, {17782, -1, -1, -1}, {17783, -1, -1, -1}, {17784, -1, -1, -1}, {17785, -1, -1, -1}, {17786, -1, -1, -1}, {17787, -1, -1, -1}, {17788, -1, -1, -1}, {17789, -1, -1, -1}, {17790, -1, -1, -1}, {17791, -1, -1, -1}, {17792, -1, -1, -1}, {17793, -1, -1, -1}, {17794, -1, -1, -1}, {17795, -1, -1, -1}, {17796, -1, -1, -1}, {17797, -1, -1, -1}, {17798, -1, -1, -1}, {17799, -1, -1, -1}, {17800, -1, -1, -1}, {17801, -1, -1, -1}, {17802, -1, -1, -1}, {17803, -1, -1, -1}, {17804, -1, -1, -1}, {17805, -1, -1, -1}, {17806, -1, -1, -1}, {17807, -1, -1, -1}, {17808, -1, -1, -1}, {17809, -1, -1, -1}, {17810, -1, -1, -1}, {17811, -1, -1, -1}, {17812, -1, -1, -1}, {17813, -1, -1, -1}, {17814, -1, -1, -1}, {17815, -1, -1, -1}, {17816, -1, -1, -1}, {17817, -1, -1, -1}, {17818, -1, -1, -1}, {17819, -1, -1, -1}, {17820, -1, -1, -1}, {17821, -1, -1, -1}, {17822, -1, -1, -1}, {17823, -1, -1, -1}, {17824, -1, -1, -1}, {17825, -1, -1, -1}, {17826, -1, -1, -1}, {17827, -1, -1, -1}, {17828, -1, -1, -1}, {17829, -1, -1, -1}, {17830, -1, -1, -1}, {17831, -1, -1, -1}, {17832, -1, -1, -1}, {17833, -1, -1, -1}, {17834, -1, -1, -1}, {17835, -1, -1, -1}, {17836, -1, -1, -1}, {17837, -1, -1, -1}, {17838, -1, -1, -1}, {17839, -1, -1, -1}, {17840, -1, -1, -1}, {17841, -1, -1, -1}, {17842, -1, -1, -1}, {17843, -1, -1, -1}, {17844, -1, -1, -1}, {17845, -1, -1, -1}, {17846, -1, -1, -1}, {17847, -1, -1, -1}, {17848, -1, -1, -1}, {17849, -1, -1, -1}, {17850, -1, -1, -1}, {17851, -1, -1, -1}, {17852, -1, -1, -1}, {17853, -1, -1, -1}, {17854, -1, -1, -1}, {17855, -1, -1, -1}, {17856, -1, -1, -1}, {17857, -1, -1, -1}, {17858, -1, -1, -1}, {17859, -1, -1, -1}, {17860, -1, -1, -1}, {17861, -1, -1, -1}, {17862, -1, -1, -1}, {17863, -1, -1, -1}, {17864, -1, -1, -1}, {17865, -1, -1, -1}, {17866, -1, -1, -1}, {17867, -1, -1, -1}, {17868, -1, -1, -1}, {17869, -1, -1, -1}, {17870, -1, -1, -1}, {17871, -1, -1, -1}, {17872, -1, -1, -1}, {17873, -1, -1, -1}, {17874, -1, -1, -1}, {17875, -1, -1, -1}, {17876, -1, -1, -1}, {17877, -1, -1, -1}, {17878, -1, -1, -1}, {17879, -1, -1, -1}, {17880, -1, -1, -1}, {17881, -1, -1, -1}, {17882, -1, -1, -1}, {17883, -1, -1, -1}, {17884, -1, -1, -1}, {17885, -1, -1, -1}, {17886, -1, -1, -1}, {17887, -1, -1, -1}, {17888, -1, -1, -1}, {17889, -1, -1, -1}, {17890, -1, -1, -1}, {17891, -1, -1, -1}, {17892, -1, -1, -1}, {17893, -1, -1, -1}, {17894, -1, -1, -1}, {17895, -1, -1, -1}, {17896, -1, -1, -1}, {17897, -1, -1, -1}, {17898, -1, -1, -1}, {17899, -1, -1, -1}, {17900, -1, -1, -1}, {17901, -1, -1, -1}, {17902, -1, -1, -1}, {17903, -1, -1, -1}, {17904, -1, -1, -1}, {17905, -1, -1, -1}, {17906, -1, -1, -1}, {17907, -1, -1, -1}, {17908, -1, -1, -1}, {17909, -1, -1, -1}, {17910, -1, -1, -1}, {17911, -1, -1, -1}, {17912, -1, -1, -1}, {17913, -1, -1, -1}, {17914, -1, -1, -1}, {17915, -1, -1, -1}, {17916, -1, -1, -1}, {17917, -1, -1, -1}, {17918, -1, -1, -1}, {17919, -1, -1, -1}, {17920, -1, -1, -1}, {17921, -1, -1, -1}, {17922, -1, -1, -1}, {17923, -1, -1, -1}, {17924, -1, -1, -1}, {17925, -1, -1, -1}, {17926, -1, -1, -1}, {17927, -1, -1, -1}, {17928, -1, -1, -1}, {17929, -1, -1, -1}, {17930, -1, -1, -1}, {17931, -1, -1, -1}, {17932, -1, -1, -1}, {17933, -1, -1, -1}, {17934, -1, -1, -1}, {17935, -1, -1, -1}, {17936, -1, -1, -1}, {17937, -1, -1, -1}, {17938, -1, -1, -1}, {17939, -1, -1, -1} },
+ {{17940, -1, -1, -1}, {17941, -1, -1, -1}, {17942, -1, -1, -1}, {17943, -1, -1, -1}, {17944, -1, -1, -1}, {17945, -1, -1, -1}, {17946, -1, -1, -1}, {17947, -1, -1, -1}, {17948, -1, -1, -1}, {17949, -1, -1, -1}, {17950, -1, -1, -1}, {17951, -1, -1, -1}, {17952, -1, -1, -1}, {17953, -1, -1, -1}, {17954, -1, -1, -1}, {17955, -1, -1, -1}, {17956, -1, -1, -1}, {17957, -1, -1, -1}, {17958, -1, -1, -1}, {17959, -1, -1, -1}, {17960, -1, -1, -1}, {17961, -1, -1, -1}, {17962, -1, -1, -1}, {17963, -1, -1, -1}, {17964, -1, -1, -1}, {17965, -1, -1, -1}, {17966, -1, -1, -1}, {17967, -1, -1, -1}, {17968, -1, -1, -1}, {17969, -1, -1, -1}, {17970, -1, -1, -1}, {17971, -1, -1, -1}, {17972, -1, -1, -1}, {17973, -1, -1, -1}, {17974, -1, -1, -1}, {17975, -1, -1, -1}, {17976, -1, -1, -1}, {17977, -1, -1, -1}, {17978, -1, -1, -1}, {17979, -1, -1, -1}, {17980, -1, -1, -1}, {17981, -1, -1, -1}, {17982, -1, -1, -1}, {17983, -1, -1, -1}, {17984, -1, -1, -1}, {17985, -1, -1, -1}, {17986, -1, -1, -1}, {17987, -1, -1, -1}, {17988, -1, -1, -1}, {17989, -1, -1, -1}, {17990, -1, -1, -1}, {17991, -1, -1, -1}, {17992, -1, -1, -1}, {17993, -1, -1, -1}, {17994, -1, -1, -1}, {17995, -1, -1, -1}, {17997, -1, -1, -1}, {17998, -1, -1, -1}, {17999, -1, -1, -1}, {18000, -1, -1, -1}, {18001, -1, -1, -1}, {18002, -1, -1, -1}, {18003, -1, -1, -1}, {18004, -1, -1, -1}, {18005, -1, -1, -1}, {18006, -1, -1, -1}, {18007, -1, -1, -1}, {18008, -1, -1, -1}, {18009, -1, -1, -1}, {18010, -1, -1, -1}, {18011, -1, -1, -1}, {18012, -1, -1, -1}, {18013, -1, -1, -1}, {18014, -1, -1, -1}, {18015, -1, -1, -1}, {18016, -1, -1, -1}, {18018, -1, -1, -1}, {18019, -1, -1, -1}, {18020, -1, -1, -1}, {18021, -1, -1, -1}, {18022, -1, -1, -1}, {18023, -1, -1, -1}, {18024, -1, -1, -1}, {18025, -1, -1, -1}, {18026, -1, -1, -1}, {18027, -1, -1, -1}, {18028, -1, -1, -1}, {18029, -1, -1, -1}, {18030, -1, -1, -1}, {18031, -1, -1, -1}, {18032, -1, -1, -1}, {18033, -1, -1, -1}, {18034, -1, -1, -1}, {18035, -1, -1, -1}, {18036, -1, -1, -1}, {18037, -1, -1, -1}, {18038, -1, -1, -1}, {18039, -1, -1, -1}, {18040, -1, -1, -1}, {18041, -1, -1, -1}, {18042, -1, -1, -1}, {18043, -1, -1, -1}, {18044, -1, -1, -1}, {18045, -1, -1, -1}, {18046, -1, -1, -1}, {18047, -1, -1, -1}, {18048, -1, -1, -1}, {18049, -1, -1, -1}, {18050, -1, -1, -1}, {18051, -1, -1, -1}, {18052, -1, -1, -1}, {18053, -1, -1, -1}, {18054, -1, -1, -1}, {18055, -1, -1, -1}, {18056, -1, -1, -1}, {18057, -1, -1, -1}, {18058, -1, -1, -1}, {18059, -1, -1, -1}, {18060, -1, -1, -1}, {18061, -1, -1, -1}, {18062, -1, -1, -1}, {18063, -1, -1, -1}, {18064, -1, -1, -1}, {18065, -1, -1, -1}, {18066, -1, -1, -1}, {18067, -1, -1, -1}, {18068, -1, -1, -1}, {18069, -1, -1, -1}, {18070, -1, -1, -1}, {18071, -1, -1, -1}, {18072, -1, -1, -1}, {18073, -1, -1, -1}, {18074, -1, -1, -1}, {18075, -1, -1, -1}, {18076, -1, -1, -1}, {18077, -1, -1, -1}, {18078, -1, -1, -1}, {18079, -1, -1, -1}, {18080, -1, -1, -1}, {18081, -1, -1, -1}, {18082, -1, -1, -1}, {18083, -1, -1, -1}, {18084, -1, -1, -1}, {18085, -1, -1, -1}, {18086, -1, -1, -1}, {18087, -1, -1, -1}, {18088, -1, -1, -1}, {18089, -1, -1, -1}, {18090, -1, -1, -1}, {18091, -1, -1, -1}, {18092, -1, -1, -1}, {18093, -1, -1, -1}, {18094, -1, -1, -1}, {18095, -1, -1, -1}, {18096, -1, -1, -1}, {18097, -1, -1, -1}, {18098, -1, -1, -1}, {18099, -1, -1, -1}, {18100, -1, -1, -1}, {18101, -1, -1, -1}, {18102, -1, -1, -1}, {18103, -1, -1, -1}, {18104, -1, -1, -1}, {18105, -1, -1, -1}, {18106, -1, -1, -1}, {18107, -1, -1, -1}, {18108, -1, -1, -1}, {18109, -1, -1, -1}, {18110, -1, -1, -1}, {18111, -1, -1, -1}, {18112, -1, -1, -1}, {18113, -1, -1, -1}, {18114, -1, -1, -1}, {18115, -1, -1, -1}, {18116, -1, -1, -1}, {18117, -1, -1, -1}, {18118, -1, -1, -1}, {18119, -1, -1, -1}, {18120, -1, -1, -1}, {18121, -1, -1, -1}, {18122, -1, -1, -1}, {18123, -1, -1, -1}, {18124, -1, -1, -1}, {18125, -1, -1, -1}, {18126, -1, -1, -1}, {18127, -1, -1, -1}, {18128, -1, -1, -1}, {18129, -1, -1, -1}, {18130, -1, -1, -1}, {18131, -1, -1, -1}, {18132, -1, -1, -1}, {18133, -1, -1, -1}, {18134, -1, -1, -1}, {18135, -1, -1, -1}, {18136, -1, -1, -1}, {18137, -1, -1, -1}, {18138, -1, -1, -1}, {18139, -1, -1, -1}, {18140, -1, -1, -1}, {18141, -1, -1, -1}, {18142, -1, -1, -1}, {18143, -1, -1, -1}, {18144, -1, -1, -1}, {18145, -1, -1, -1}, {18146, -1, -1, -1}, {18147, -1, -1, -1}, {18148, -1, -1, -1}, {18149, -1, -1, -1}, {18150, -1, -1, -1}, {18151, -1, -1, -1}, {18152, -1, -1, -1}, {18153, -1, -1, -1}, {18154, -1, -1, -1}, {18155, -1, -1, -1}, {18156, -1, -1, -1}, {18157, -1, -1, -1}, {18158, -1, -1, -1}, {18159, -1, -1, -1}, {18160, -1, -1, -1}, {18161, -1, -1, -1}, {18162, -1, -1, -1}, {18163, -1, -1, -1}, {18164, -1, -1, -1}, {18165, -1, -1, -1}, {18166, -1, -1, -1}, {18167, -1, -1, -1}, {18168, -1, -1, -1}, {18169, -1, -1, -1}, {18170, -1, -1, -1}, {18171, -1, -1, -1}, {18172, -1, -1, -1}, {18173, -1, -1, -1}, {18174, -1, -1, -1}, {18175, -1, -1, -1}, {18176, -1, -1, -1}, {18177, -1, -1, -1}, {18178, -1, -1, -1}, {18179, -1, -1, -1}, {18180, -1, -1, -1}, {18181, -1, -1, -1}, {18182, -1, -1, -1}, {18183, -1, -1, -1}, {18184, -1, -1, -1}, {18185, -1, -1, -1}, {18186, -1, -1, -1}, {18187, -1, -1, -1}, {18188, -1, -1, -1}, {18189, -1, -1, -1}, {18190, -1, -1, -1}, {18191, -1, -1, -1}, {18192, -1, -1, -1}, {18193, -1, -1, -1}, {18194, -1, -1, -1}, {18195, -1, -1, -1}, {18196, -1, -1, -1}, {18197, -1, -1, -1} },
+ {{18198, -1, -1, -1}, {18199, -1, -1, -1}, {18200, -1, -1, -1}, {18201, -1, -1, -1}, {18202, -1, -1, -1}, {18203, -1, -1, -1}, {18204, -1, -1, -1}, {18205, -1, -1, -1}, {18206, -1, -1, -1}, {18207, -1, -1, -1}, {18208, -1, -1, -1}, {18209, -1, -1, -1}, {18210, -1, -1, -1}, {18212, -1, -1, -1}, {18213, -1, -1, -1}, {18214, -1, -1, -1}, {18215, -1, -1, -1}, {18216, -1, -1, -1}, {18218, -1, -1, -1}, {18219, -1, -1, -1}, {18220, -1, -1, -1}, {18221, -1, -1, -1}, {18222, -1, -1, -1}, {18223, -1, -1, -1}, {18224, -1, -1, -1}, {18225, -1, -1, -1}, {18226, -1, -1, -1}, {18227, -1, -1, -1}, {18228, -1, -1, -1}, {18229, -1, -1, -1}, {18230, -1, -1, -1}, {18231, -1, -1, -1}, {18232, -1, -1, -1}, {18233, -1, -1, -1}, {18234, -1, -1, -1}, {18235, -1, -1, -1}, {18236, -1, -1, -1}, {18237, -1, -1, -1}, {18238, -1, -1, -1}, {18239, -1, -1, -1}, {18240, -1, -1, -1}, {18241, -1, -1, -1}, {18242, -1, -1, -1}, {18243, -1, -1, -1}, {18244, -1, -1, -1}, {18245, -1, -1, -1}, {18246, -1, -1, -1}, {18247, -1, -1, -1}, {18248, -1, -1, -1}, {18249, -1, -1, -1}, {18250, -1, -1, -1}, {18251, -1, -1, -1}, {18252, -1, -1, -1}, {18253, -1, -1, -1}, {18254, -1, -1, -1}, {18255, -1, -1, -1}, {18256, -1, -1, -1}, {18257, -1, -1, -1}, {18258, -1, -1, -1}, {18259, -1, -1, -1}, {18260, -1, -1, -1}, {18261, -1, -1, -1}, {18262, -1, -1, -1}, {18263, -1, -1, -1}, {18264, -1, -1, -1}, {18265, -1, -1, -1}, {18266, -1, -1, -1}, {18267, -1, -1, -1}, {18268, -1, -1, -1}, {18269, -1, -1, -1}, {18270, -1, -1, -1}, {18271, -1, -1, -1}, {18272, -1, -1, -1}, {18273, -1, -1, -1}, {18274, -1, -1, -1}, {18275, -1, -1, -1}, {18276, -1, -1, -1}, {18277, -1, -1, -1}, {18278, -1, -1, -1}, {18279, -1, -1, -1}, {18280, -1, -1, -1}, {18281, -1, -1, -1}, {18282, -1, -1, -1}, {18283, -1, -1, -1}, {18284, -1, -1, -1}, {18285, -1, -1, -1}, {18286, -1, -1, -1}, {18287, -1, -1, -1}, {18288, -1, -1, -1}, {18289, -1, -1, -1}, {18290, -1, -1, -1}, {18291, -1, -1, -1}, {18292, -1, -1, -1}, {18293, -1, -1, -1}, {18294, -1, -1, -1}, {18295, -1, -1, -1}, {18296, -1, -1, -1}, {18297, -1, -1, -1}, {18298, -1, -1, -1}, {18299, -1, -1, -1}, {18301, -1, -1, -1}, {18302, -1, -1, -1}, {18303, -1, -1, -1}, {18304, -1, -1, -1}, {18305, -1, -1, -1}, {18306, -1, -1, -1}, {18307, -1, -1, -1}, {18308, -1, -1, -1}, {18309, -1, -1, -1}, {18310, -1, -1, -1}, {18311, -1, -1, -1}, {18312, -1, -1, -1}, {18313, -1, -1, -1}, {18314, -1, -1, -1}, {18315, -1, -1, -1}, {18316, -1, -1, -1}, {18318, -1, -1, -1}, {18319, -1, -1, -1}, {18320, -1, -1, -1}, {18321, -1, -1, -1}, {18322, -1, -1, -1}, {18323, -1, -1, -1}, {18324, -1, -1, -1}, {18325, -1, -1, -1}, {18326, -1, -1, -1}, {18327, -1, -1, -1}, {18328, -1, -1, -1}, {18329, -1, -1, -1}, {18330, -1, -1, -1}, {18331, -1, -1, -1}, {18332, -1, -1, -1}, {18333, -1, -1, -1}, {18334, -1, -1, -1}, {18335, -1, -1, -1}, {18336, -1, -1, -1}, {18337, -1, -1, -1}, {18338, -1, -1, -1}, {18339, -1, -1, -1}, {18340, -1, -1, -1}, {18341, -1, -1, -1}, {18342, -1, -1, -1}, {18343, -1, -1, -1}, {18344, -1, -1, -1}, {18345, -1, -1, -1}, {18346, -1, -1, -1}, {18347, -1, -1, -1}, {18348, -1, -1, -1}, {18349, -1, -1, -1}, {18350, -1, -1, -1}, {18351, -1, -1, -1}, {18352, -1, -1, -1}, {18353, -1, -1, -1}, {18354, -1, -1, -1}, {18355, -1, -1, -1}, {18356, -1, -1, -1}, {18357, -1, -1, -1}, {18358, -1, -1, -1}, {18359, -1, -1, -1}, {18360, -1, -1, -1}, {18361, -1, -1, -1}, {18362, -1, -1, -1}, {18363, -1, -1, -1}, {18364, -1, -1, -1}, {18365, -1, -1, -1}, {18366, -1, -1, -1}, {18367, -1, -1, -1}, {18368, -1, -1, -1}, {18369, -1, -1, -1}, {18370, -1, -1, -1}, {18371, -1, -1, -1}, {18372, -1, -1, -1}, {18373, -1, -1, -1}, {18374, -1, -1, -1}, {18375, -1, -1, -1}, {18376, -1, -1, -1}, {18377, -1, -1, -1}, {18378, -1, -1, -1}, {18379, -1, -1, -1}, {18380, -1, -1, -1}, {18381, -1, -1, -1}, {18382, -1, -1, -1}, {18383, -1, -1, -1}, {18384, -1, -1, -1}, {18385, -1, -1, -1}, {18386, -1, -1, -1}, {18387, -1, -1, -1}, {18388, -1, -1, -1}, {18389, -1, -1, -1}, {18390, -1, -1, -1}, {18391, -1, -1, -1}, {18392, -1, -1, -1}, {18393, -1, -1, -1}, {18394, -1, -1, -1}, {18395, -1, -1, -1}, {18396, -1, -1, -1}, {18397, -1, -1, -1}, {18398, -1, -1, -1}, {18399, -1, -1, -1}, {18400, -1, -1, -1}, {18401, -1, -1, -1}, {18402, -1, -1, -1}, {18403, -1, -1, -1}, {18404, -1, -1, -1}, {18405, -1, -1, -1}, {18406, -1, -1, -1}, {18407, -1, -1, -1}, {18408, -1, -1, -1}, {18409, -1, -1, -1}, {18410, -1, -1, -1}, {18411, -1, -1, -1}, {18412, -1, -1, -1}, {18413, -1, -1, -1}, {18414, -1, -1, -1}, {18415, -1, -1, -1}, {18416, -1, -1, -1}, {18417, -1, -1, -1}, {18418, -1, -1, -1}, {18419, -1, -1, -1}, {18420, -1, -1, -1}, {18421, -1, -1, -1}, {18422, -1, -1, -1}, {18423, -1, -1, -1}, {18424, -1, -1, -1}, {18425, -1, -1, -1}, {18426, -1, -1, -1}, {18427, -1, -1, -1}, {18428, -1, -1, -1}, {18429, -1, -1, -1}, {18430, -1, -1, -1}, {18431, -1, -1, -1}, {18432, -1, -1, -1}, {18433, -1, -1, -1}, {18434, -1, -1, -1}, {18435, -1, -1, -1}, {18436, -1, -1, -1}, {18437, -1, -1, -1}, {18438, -1, -1, -1}, {18439, -1, -1, -1}, {18440, -1, -1, -1}, {18441, -1, -1, -1}, {18442, -1, -1, -1}, {18443, -1, -1, -1}, {18444, -1, -1, -1}, {18445, -1, -1, -1}, {18446, -1, -1, -1}, {18447, -1, -1, -1}, {18448, -1, -1, -1}, {18449, -1, -1, -1}, {18450, -1, -1, -1}, {18451, -1, -1, -1}, {18452, -1, -1, -1}, {18453, -1, -1, -1}, {18454, -1, -1, -1}, {18455, -1, -1, -1}, {18456, -1, -1, -1}, {18457, -1, -1, -1} },
+ {{18458, -1, -1, -1}, {18459, -1, -1, -1}, {18460, -1, -1, -1}, {18461, -1, -1, -1}, {18462, -1, -1, -1}, {18463, -1, -1, -1}, {18464, -1, -1, -1}, {18465, -1, -1, -1}, {18466, -1, -1, -1}, {18467, -1, -1, -1}, {18468, -1, -1, -1}, {18469, -1, -1, -1}, {18470, -1, -1, -1}, {18471, -1, -1, -1}, {18472, -1, -1, -1}, {18473, -1, -1, -1}, {18474, -1, -1, -1}, {18475, -1, -1, -1}, {18476, -1, -1, -1}, {18477, -1, -1, -1}, {18478, -1, -1, -1}, {18479, -1, -1, -1}, {18480, -1, -1, -1}, {18481, -1, -1, -1}, {18482, -1, -1, -1}, {18483, -1, -1, -1}, {18484, -1, -1, -1}, {18485, -1, -1, -1}, {18486, -1, -1, -1}, {18487, -1, -1, -1}, {18488, -1, -1, -1}, {18489, -1, -1, -1}, {18490, -1, -1, -1}, {18491, -1, -1, -1}, {18492, -1, -1, -1}, {18493, -1, -1, -1}, {18494, -1, -1, -1}, {18495, -1, -1, -1}, {18496, -1, -1, -1}, {18497, -1, -1, -1}, {18498, -1, -1, -1}, {18499, -1, -1, -1}, {18500, -1, -1, -1}, {18501, -1, -1, -1}, {18502, -1, -1, -1}, {18503, -1, -1, -1}, {18504, -1, -1, -1}, {18505, -1, -1, -1}, {18506, -1, -1, -1}, {18507, -1, -1, -1}, {18508, -1, -1, -1}, {18509, -1, -1, -1}, {18510, -1, -1, -1}, {18511, -1, -1, -1}, {18512, -1, -1, -1}, {18513, -1, -1, -1}, {18514, -1, -1, -1}, {18515, -1, -1, -1}, {18516, -1, -1, -1}, {18517, -1, -1, -1}, {18518, -1, -1, -1}, {18519, -1, -1, -1}, {18520, -1, -1, -1}, {18521, -1, -1, -1}, {18522, -1, -1, -1}, {18523, -1, -1, -1}, {18524, -1, -1, -1}, {18525, -1, -1, -1}, {18526, -1, -1, -1}, {18527, -1, -1, -1}, {18528, -1, -1, -1}, {18529, -1, -1, -1}, {18530, -1, -1, -1}, {18531, -1, -1, -1}, {18532, -1, -1, -1}, {18533, -1, -1, -1}, {18534, -1, -1, -1}, {18535, -1, -1, -1}, {18536, -1, -1, -1}, {18537, -1, -1, -1}, {18538, -1, -1, -1}, {18539, -1, -1, -1}, {18540, -1, -1, -1}, {18541, -1, -1, -1}, {18542, -1, -1, -1}, {18543, -1, -1, -1}, {18544, -1, -1, -1}, {18545, -1, -1, -1}, {18546, -1, -1, -1}, {18547, -1, -1, -1}, {18548, -1, -1, -1}, {18549, -1, -1, -1}, {18550, -1, -1, -1}, {18551, -1, -1, -1}, {18552, -1, -1, -1}, {18553, -1, -1, -1}, {18554, -1, -1, -1}, {18555, -1, -1, -1}, {18556, -1, -1, -1}, {18557, -1, -1, -1}, {18558, -1, -1, -1}, {18559, -1, -1, -1}, {18560, -1, -1, -1}, {18561, -1, -1, -1}, {18562, -1, -1, -1}, {18563, -1, -1, -1}, {18564, -1, -1, -1}, {18565, -1, -1, -1}, {18566, -1, -1, -1}, {18567, -1, -1, -1}, {18568, -1, -1, -1}, {18569, -1, -1, -1}, {18570, -1, -1, -1}, {18571, -1, -1, -1}, {18572, -1, -1, -1}, {18573, -1, -1, -1}, {18574, -1, -1, -1}, {18575, -1, -1, -1}, {18576, -1, -1, -1}, {18577, -1, -1, -1}, {18578, -1, -1, -1}, {18579, -1, -1, -1}, {18580, -1, -1, -1}, {18581, -1, -1, -1}, {18582, -1, -1, -1}, {18583, -1, -1, -1}, {18584, -1, -1, -1}, {18585, -1, -1, -1}, {18586, -1, -1, -1}, {18587, -1, -1, -1}, {18588, -1, -1, -1}, {18589, -1, -1, -1}, {18590, -1, -1, -1}, {18591, -1, -1, -1}, {18592, -1, -1, -1}, {18593, -1, -1, -1}, {18594, -1, -1, -1}, {18595, -1, -1, -1}, {18596, -1, -1, -1}, {18597, -1, -1, -1}, {18598, -1, -1, -1}, {18599, -1, -1, -1}, {18600, -1, -1, -1}, {18601, -1, -1, -1}, {18602, -1, -1, -1}, {18603, -1, -1, -1}, {18604, -1, -1, -1}, {18605, -1, -1, -1}, {18606, -1, -1, -1}, {18607, -1, -1, -1}, {18608, -1, -1, -1}, {18609, -1, -1, -1}, {18610, -1, -1, -1}, {18611, -1, -1, -1}, {18612, -1, -1, -1}, {18613, -1, -1, -1}, {18614, -1, -1, -1}, {18615, -1, -1, -1}, {18616, -1, -1, -1}, {18617, -1, -1, -1}, {18618, -1, -1, -1}, {18619, -1, -1, -1}, {18620, -1, -1, -1}, {18621, -1, -1, -1}, {18622, -1, -1, -1}, {18623, -1, -1, -1}, {18624, -1, -1, -1}, {18625, -1, -1, -1}, {18626, -1, -1, -1}, {18627, -1, -1, -1}, {18628, -1, -1, -1}, {18629, -1, -1, -1}, {18630, -1, -1, -1}, {18631, -1, -1, -1}, {18632, -1, -1, -1}, {18633, -1, -1, -1}, {18634, -1, -1, -1}, {18635, -1, -1, -1}, {18636, -1, -1, -1}, {18637, -1, -1, -1}, {18638, -1, -1, -1}, {18639, -1, -1, -1}, {18640, -1, -1, -1}, {18641, -1, -1, -1}, {18642, -1, -1, -1}, {18643, -1, -1, -1}, {18644, -1, -1, -1}, {18645, -1, -1, -1}, {18646, -1, -1, -1}, {18647, -1, -1, -1}, {18648, -1, -1, -1}, {18649, -1, -1, -1}, {18650, -1, -1, -1}, {18651, -1, -1, -1}, {18652, -1, -1, -1}, {18653, -1, -1, -1}, {18654, -1, -1, -1}, {18655, -1, -1, -1}, {18656, -1, -1, -1}, {18657, -1, -1, -1}, {18658, -1, -1, -1}, {18659, -1, -1, -1}, {18660, -1, -1, -1}, {18661, -1, -1, -1}, {18662, -1, -1, -1}, {18663, -1, -1, -1}, {18664, -1, -1, -1}, {18665, -1, -1, -1}, {18666, -1, -1, -1}, {18667, -1, -1, -1}, {18668, -1, -1, -1}, {18669, -1, -1, -1}, {18670, -1, -1, -1}, {18671, -1, -1, -1}, {18672, -1, -1, -1}, {18673, -1, -1, -1}, {18674, -1, -1, -1}, {18675, -1, -1, -1}, {18676, -1, -1, -1}, {18677, -1, -1, -1}, {18678, -1, -1, -1}, {18679, -1, -1, -1}, {18680, -1, -1, -1}, {18681, -1, -1, -1}, {18682, -1, -1, -1}, {18683, -1, -1, -1}, {18684, -1, -1, -1}, {18685, -1, -1, -1}, {18686, -1, -1, -1}, {18687, -1, -1, -1}, {18688, -1, -1, -1}, {18689, -1, -1, -1}, {18690, -1, -1, -1}, {18691, -1, -1, -1}, {18692, -1, -1, -1}, {18693, -1, -1, -1}, {18694, -1, -1, -1}, {18695, -1, -1, -1}, {18696, -1, -1, -1}, {18697, -1, -1, -1}, {18698, -1, -1, -1}, {18699, -1, -1, -1}, {18700, -1, -1, -1}, {18701, -1, -1, -1}, {18702, -1, -1, -1}, {18703, -1, -1, -1}, {18704, -1, -1, -1}, {18705, -1, -1, -1}, {18706, -1, -1, -1}, {18707, -1, -1, -1}, {18708, -1, -1, -1}, {18709, -1, -1, -1}, {18710, -1, -1, -1}, {18711, -1, -1, -1}, {18712, -1, -1, -1}, {18713, -1, -1, -1} },
+ {{18714, -1, -1, -1}, {18715, -1, -1, -1}, {18716, -1, -1, -1}, {18717, -1, -1, -1}, {18718, -1, -1, -1}, {18719, -1, -1, -1}, {18720, -1, -1, -1}, {18721, -1, -1, -1}, {18722, -1, -1, -1}, {18723, -1, -1, -1}, {18724, -1, -1, -1}, {18725, -1, -1, -1}, {18726, -1, -1, -1}, {18727, -1, -1, -1}, {18728, -1, -1, -1}, {18729, -1, -1, -1}, {18730, -1, -1, -1}, {18731, -1, -1, -1}, {18732, -1, -1, -1}, {18733, -1, -1, -1}, {18734, -1, -1, -1}, {18735, -1, -1, -1}, {18736, -1, -1, -1}, {18737, -1, -1, -1}, {18738, -1, -1, -1}, {18739, -1, -1, -1}, {18740, -1, -1, -1}, {18741, -1, -1, -1}, {18742, -1, -1, -1}, {18743, -1, -1, -1}, {18744, -1, -1, -1}, {18745, -1, -1, -1}, {18746, -1, -1, -1}, {18747, -1, -1, -1}, {18748, -1, -1, -1}, {18749, -1, -1, -1}, {18750, -1, -1, -1}, {18751, -1, -1, -1}, {18752, -1, -1, -1}, {18753, -1, -1, -1}, {18754, -1, -1, -1}, {18755, -1, -1, -1}, {18756, -1, -1, -1}, {18757, -1, -1, -1}, {18758, -1, -1, -1}, {18760, -1, -1, -1}, {18761, -1, -1, -1}, {18762, -1, -1, -1}, {18763, -1, -1, -1}, {18764, -1, -1, -1}, {18765, -1, -1, -1}, {18766, -1, -1, -1}, {18767, -1, -1, -1}, {18768, -1, -1, -1}, {18769, -1, -1, -1}, {18770, -1, -1, -1}, {18771, -1, -1, -1}, {18772, -1, -1, -1}, {18773, -1, -1, -1}, {18774, -1, -1, -1}, {18775, -1, -1, -1}, {18776, -1, -1, -1}, {18777, -1, -1, -1}, {18778, -1, -1, -1}, {18779, -1, -1, -1}, {18780, -1, -1, -1}, {18781, -1, -1, -1}, {18782, -1, -1, -1}, {18783, -1, -1, -1}, {18784, -1, -1, -1}, {18785, -1, -1, -1}, {18786, -1, -1, -1}, {18787, -1, -1, -1}, {18788, -1, -1, -1}, {18789, -1, -1, -1}, {18790, -1, -1, -1}, {18791, -1, -1, -1}, {18792, -1, -1, -1}, {18793, -1, -1, -1}, {18794, -1, -1, -1}, {18795, -1, -1, -1}, {18796, -1, -1, -1}, {18797, -1, -1, -1}, {18798, -1, -1, -1}, {18799, -1, -1, -1}, {18800, -1, -1, -1}, {18801, -1, -1, -1}, {18802, -1, -1, -1}, {18803, -1, -1, -1}, {18804, -1, -1, -1}, {18805, -1, -1, -1}, {18806, -1, -1, -1}, {18807, -1, -1, -1}, {18808, -1, -1, -1}, {18809, -1, -1, -1}, {18811, -1, -1, -1}, {18812, -1, -1, -1}, {18814, -1, -1, -1}, {18815, -1, -1, -1}, {18816, -1, -1, -1}, {18817, -1, -1, -1}, {18820, -1, -1, -1}, {18823, -1, -1, -1}, {18824, -1, -1, -1}, {18825, -1, -1, -1}, {18826, -1, -1, -1}, {18827, -1, -1, -1}, {18828, -1, -1, -1}, {18829, -1, -1, -1}, {18830, -1, -1, -1}, {18831, -1, -1, -1}, {18832, -1, -1, -1}, {18833, -1, -1, -1}, {18834, -1, -1, -1}, {18835, -1, -1, -1}, {18836, -1, -1, -1}, {18837, -1, -1, -1}, {18838, -1, -1, -1}, {18839, -1, -1, -1}, {18840, -1, -1, -1}, {18841, -1, -1, -1}, {18842, -1, -1, -1}, {18844, -1, -1, -1}, {18845, -1, -1, -1}, {18846, -1, -1, -1}, {18848, -1, -1, -1}, {18849, -1, -1, -1}, {18850, -1, -1, -1}, {18851, -1, -1, -1}, {18852, -1, -1, -1}, {18853, -1, -1, -1}, {18854, -1, -1, -1}, {18855, -1, -1, -1}, {18856, -1, -1, -1}, {18857, -1, -1, -1}, {18858, -1, -1, -1}, {18859, -1, -1, -1}, {18860, -1, -1, -1}, {18861, -1, -1, -1}, {18862, -1, -1, -1}, {18863, -1, -1, -1}, {18864, -1, -1, -1}, {18865, -1, -1, -1}, {18866, -1, -1, -1}, {18867, -1, -1, -1}, {18868, -1, -1, -1}, {18869, -1, -1, -1}, {18872, -1, -1, -1}, {18873, -1, -1, -1}, {18874, -1, -1, -1}, {18875, -1, -1, -1}, {18876, -1, -1, -1}, {18877, -1, -1, -1}, {18878, -1, -1, -1}, {18879, -1, -1, -1}, {18880, -1, -1, -1}, {18881, -1, -1, -1}, {18882, -1, -1, -1}, {18883, -1, -1, -1}, {18884, -1, -1, -1}, {18885, -1, -1, -1}, {18886, -1, -1, -1}, {18887, -1, -1, -1}, {18888, -1, -1, -1}, {18889, -1, -1, -1}, {18890, -1, -1, -1}, {18891, -1, -1, -1}, {18892, -1, -1, -1}, {18893, -1, -1, -1}, {18894, -1, -1, -1}, {18895, -1, -1, -1}, {18896, -1, -1, -1}, {18897, -1, -1, -1}, {18898, -1, -1, -1}, {18899, -1, -1, -1}, {18900, -1, -1, -1}, {18901, -1, -1, -1}, {18902, -1, -1, -1}, {18903, -1, -1, -1}, {18904, -1, -1, -1}, {18905, -1, -1, -1}, {18906, -1, -1, -1}, {18907, -1, -1, -1}, {18908, -1, -1, -1}, {18909, -1, -1, -1}, {18910, -1, -1, -1}, {18911, -1, -1, -1}, {18912, -1, -1, -1}, {18913, -1, -1, -1}, {18914, -1, -1, -1}, {18915, -1, -1, -1}, {18916, -1, -1, -1}, {18917, -1, -1, -1}, {18918, -1, -1, -1}, {18919, -1, -1, -1}, {18920, -1, -1, -1}, {18921, -1, -1, -1}, {18922, -1, -1, -1}, {18923, -1, -1, -1}, {18924, -1, -1, -1}, {18925, -1, -1, -1}, {18926, -1, -1, -1}, {18927, -1, -1, -1}, {18928, -1, -1, -1}, {18929, -1, -1, -1}, {18930, -1, -1, -1}, {18931, -1, -1, -1}, {18932, -1, -1, -1}, {18933, -1, -1, -1}, {18934, -1, -1, -1}, {18935, -1, -1, -1}, {18936, -1, -1, -1}, {18937, -1, -1, -1}, {18938, -1, -1, -1}, {18939, -1, -1, -1}, {18940, -1, -1, -1}, {18941, -1, -1, -1}, {18942, -1, -1, -1}, {18943, -1, -1, -1}, {18944, -1, -1, -1}, {18945, -1, -1, -1}, {18946, -1, -1, -1}, {18947, -1, -1, -1}, {18948, -1, -1, -1}, {18949, -1, -1, -1}, {18950, -1, -1, -1}, {18951, -1, -1, -1}, {18952, -1, -1, -1}, {18953, -1, -1, -1}, {18954, -1, -1, -1}, {18955, -1, -1, -1}, {18956, -1, -1, -1}, {18957, -1, -1, -1}, {18958, -1, -1, -1}, {18959, -1, -1, -1}, {18960, -1, -1, -1}, {18961, -1, -1, -1}, {18962, -1, -1, -1}, {18963, -1, -1, -1}, {18964, -1, -1, -1}, {18965, -1, -1, -1}, {18966, -1, -1, -1}, {18967, -1, -1, -1}, {18968, -1, -1, -1}, {18969, -1, -1, -1}, {18970, -1, -1, -1}, {18971, -1, -1, -1}, {18972, -1, -1, -1}, {18973, -1, -1, -1}, {18974, -1, -1, -1}, {18975, -1, -1, -1}, {18976, -1, -1, -1}, {18977, -1, -1, -1}, {18978, -1, -1, -1}, {18979, -1, -1, -1}, {18980, -1, -1, -1} },
+ {{18981, -1, -1, -1}, {18982, -1, -1, -1}, {18983, -1, -1, -1}, {18984, -1, -1, -1}, {18985, -1, -1, -1}, {18986, -1, -1, -1}, {18987, -1, -1, -1}, {18988, -1, -1, -1}, {18989, -1, -1, -1}, {18990, -1, -1, -1}, {18991, -1, -1, -1}, {18992, -1, -1, -1}, {18993, -1, -1, -1}, {18994, -1, -1, -1}, {18995, -1, -1, -1}, {18996, -1, -1, -1}, {18997, -1, -1, -1}, {18998, -1, -1, -1}, {18999, -1, -1, -1}, {19000, -1, -1, -1}, {19001, -1, -1, -1}, {19002, -1, -1, -1}, {19003, -1, -1, -1}, {19004, -1, -1, -1}, {19005, -1, -1, -1}, {19006, -1, -1, -1}, {19007, -1, -1, -1}, {19008, -1, -1, -1}, {19009, -1, -1, -1}, {19010, -1, -1, -1}, {19011, -1, -1, -1}, {19012, -1, -1, -1}, {19013, -1, -1, -1}, {19014, -1, -1, -1}, {19015, -1, -1, -1}, {19016, -1, -1, -1}, {19017, -1, -1, -1}, {19018, -1, -1, -1}, {19019, -1, -1, -1}, {19020, -1, -1, -1}, {19021, -1, -1, -1}, {19022, -1, -1, -1}, {19023, -1, -1, -1}, {19024, -1, -1, -1}, {19025, -1, -1, -1}, {19026, -1, -1, -1}, {19027, -1, -1, -1}, {19028, -1, -1, -1}, {19029, -1, -1, -1}, {19030, -1, -1, -1}, {19031, -1, -1, -1}, {19032, -1, -1, -1}, {19033, -1, -1, -1}, {19034, -1, -1, -1}, {19035, -1, -1, -1}, {19036, -1, -1, -1}, {19037, -1, -1, -1}, {19038, -1, -1, -1}, {19039, -1, -1, -1}, {19040, -1, -1, -1}, {19041, -1, -1, -1}, {19042, -1, -1, -1}, {19043, -1, -1, -1}, {19044, -1, -1, -1}, {19045, -1, -1, -1}, {19046, -1, -1, -1}, {19047, -1, -1, -1}, {19048, -1, -1, -1}, {19049, -1, -1, -1}, {19050, -1, -1, -1}, {19051, -1, -1, -1}, {19052, -1, -1, -1}, {19053, -1, -1, -1}, {19054, -1, -1, -1}, {19055, -1, -1, -1}, {19056, -1, -1, -1}, {19057, -1, -1, -1}, {19058, -1, -1, -1}, {19059, -1, -1, -1}, {19060, -1, -1, -1}, {19061, -1, -1, -1}, {19062, -1, -1, -1}, {19063, -1, -1, -1}, {19064, -1, -1, -1}, {19065, -1, -1, -1}, {19066, -1, -1, -1}, {19067, -1, -1, -1}, {19068, -1, -1, -1}, {19069, -1, -1, -1}, {19070, -1, -1, -1}, {19071, -1, -1, -1}, {19072, -1, -1, -1}, {19073, -1, -1, -1}, {19074, -1, -1, -1}, {19075, -1, -1, -1}, {19076, -1, -1, -1}, {19077, -1, -1, -1}, {19078, -1, -1, -1}, {19079, -1, -1, -1}, {19080, -1, -1, -1}, {19081, -1, -1, -1}, {19082, -1, -1, -1}, {19083, -1, -1, -1}, {19084, -1, -1, -1}, {19085, -1, -1, -1}, {19086, -1, -1, -1}, {19087, -1, -1, -1}, {19088, -1, -1, -1}, {19089, -1, -1, -1}, {19090, -1, -1, -1}, {19091, -1, -1, -1}, {19092, -1, -1, -1}, {19093, -1, -1, -1}, {19094, -1, -1, -1}, {19095, -1, -1, -1}, {19096, -1, -1, -1}, {19097, -1, -1, -1}, {19098, -1, -1, -1}, {19099, -1, -1, -1}, {19100, -1, -1, -1}, {19101, -1, -1, -1}, {19102, -1, -1, -1}, {19103, -1, -1, -1}, {19104, -1, -1, -1}, {19105, -1, -1, -1}, {19106, -1, -1, -1}, {19107, -1, -1, -1}, {19108, -1, -1, -1}, {19109, -1, -1, -1}, {19110, -1, -1, -1}, {19111, -1, -1, -1}, {19112, -1, -1, -1}, {19113, -1, -1, -1}, {19114, -1, -1, -1}, {19115, -1, -1, -1}, {19116, -1, -1, -1}, {19117, -1, -1, -1}, {19118, -1, -1, -1}, {19119, -1, -1, -1}, {19120, -1, -1, -1}, {19121, -1, -1, -1}, {19122, -1, -1, -1}, {19123, -1, -1, -1}, {19124, -1, -1, -1}, {19125, -1, -1, -1}, {19126, -1, -1, -1}, {19127, -1, -1, -1}, {19128, -1, -1, -1}, {19129, -1, -1, -1}, {19130, -1, -1, -1}, {19131, -1, -1, -1}, {19132, -1, -1, -1}, {19133, -1, -1, -1}, {19134, -1, -1, -1}, {19135, -1, -1, -1}, {19136, -1, -1, -1}, {19137, -1, -1, -1}, {19138, -1, -1, -1}, {19139, -1, -1, -1}, {19140, -1, -1, -1}, {19141, -1, -1, -1}, {19142, -1, -1, -1}, {19143, -1, -1, -1}, {19144, -1, -1, -1}, {19145, -1, -1, -1}, {19146, -1, -1, -1}, {19147, -1, -1, -1}, {19148, -1, -1, -1}, {19149, -1, -1, -1}, {19150, -1, -1, -1}, {19151, -1, -1, -1}, {19152, -1, -1, -1}, {19153, -1, -1, -1}, {19154, -1, -1, -1}, {19155, -1, -1, -1}, {19156, -1, -1, -1}, {19157, -1, -1, -1}, {19158, -1, -1, -1}, {19159, -1, -1, -1}, {19160, -1, -1, -1}, {19161, -1, -1, -1}, {19162, -1, -1, -1}, {19163, -1, -1, -1}, {19164, -1, -1, -1}, {19165, -1, -1, -1}, {19166, -1, -1, -1}, {19167, -1, -1, -1}, {19168, -1, -1, -1}, {19169, -1, -1, -1}, {19170, -1, -1, -1}, {19171, -1, -1, -1}, {19172, -1, -1, -1}, {19173, -1, -1, -1}, {19174, -1, -1, -1}, {19175, -1, -1, -1}, {19176, -1, -1, -1}, {19177, -1, -1, -1}, {19178, -1, -1, -1}, {19179, -1, -1, -1}, {19180, -1, -1, -1}, {19181, -1, -1, -1}, {19182, -1, -1, -1}, {19183, -1, -1, -1}, {19184, -1, -1, -1}, {19185, -1, -1, -1}, {19186, -1, -1, -1}, {19187, -1, -1, -1}, {19188, -1, -1, -1}, {19189, -1, -1, -1}, {19190, -1, -1, -1}, {19191, -1, -1, -1}, {19192, -1, -1, -1}, {19193, -1, -1, -1}, {19194, -1, -1, -1}, {19195, -1, -1, -1}, {19196, -1, -1, -1}, {19197, -1, -1, -1}, {19198, -1, -1, -1}, {19199, -1, -1, -1}, {19200, -1, -1, -1}, {19201, -1, -1, -1}, {19202, -1, -1, -1}, {19203, -1, -1, -1}, {19204, -1, -1, -1}, {19205, -1, -1, -1}, {19206, -1, -1, -1}, {19207, -1, -1, -1}, {19208, -1, -1, -1}, {19209, -1, -1, -1}, {19210, -1, -1, -1}, {19211, -1, -1, -1}, {19212, -1, -1, -1}, {19213, -1, -1, -1}, {19214, -1, -1, -1}, {19215, -1, -1, -1}, {19216, -1, -1, -1}, {19217, -1, -1, -1}, {19218, -1, -1, -1}, {19219, -1, -1, -1}, {19220, -1, -1, -1}, {19221, -1, -1, -1}, {19222, -1, -1, -1}, {19223, -1, -1, -1}, {19224, -1, -1, -1}, {19225, -1, -1, -1}, {19226, -1, -1, -1}, {19227, -1, -1, -1}, {19228, -1, -1, -1}, {19229, -1, -1, -1}, {19230, -1, -1, -1}, {19231, -1, -1, -1}, {19232, -1, -1, -1}, {19233, -1, -1, -1}, {19234, -1, -1, -1}, {19235, -1, -1, -1}, {19236, -1, -1, -1} },
+ {{19237, -1, -1, -1}, {19238, -1, -1, -1}, {19239, -1, -1, -1}, {19240, -1, -1, -1}, {19241, -1, -1, -1}, {19242, -1, -1, -1}, {19243, -1, -1, -1}, {19244, -1, -1, -1}, {19245, -1, -1, -1}, {19246, -1, -1, -1}, {19247, -1, -1, -1}, {19248, -1, -1, -1}, {19249, -1, -1, -1}, {19250, -1, -1, -1}, {19251, -1, -1, -1}, {19252, -1, -1, -1}, {19253, -1, -1, -1}, {19254, -1, -1, -1}, {19255, -1, -1, -1}, {19256, -1, -1, -1}, {19257, -1, -1, -1}, {19258, -1, -1, -1}, {19259, -1, -1, -1}, {19260, -1, -1, -1}, {19261, -1, -1, -1}, {19262, -1, -1, -1}, {19263, -1, -1, -1}, {19264, -1, -1, -1}, {19265, -1, -1, -1}, {19266, -1, -1, -1}, {19267, -1, -1, -1}, {19268, -1, -1, -1}, {19269, -1, -1, -1}, {19270, -1, -1, -1}, {19271, -1, -1, -1}, {19272, -1, -1, -1}, {19273, -1, -1, -1}, {19274, -1, -1, -1}, {19275, -1, -1, -1}, {19276, -1, -1, -1}, {19277, -1, -1, -1}, {19278, -1, -1, -1}, {19279, -1, -1, -1}, {19280, -1, -1, -1}, {19281, -1, -1, -1}, {19282, -1, -1, -1}, {19283, -1, -1, -1}, {19284, -1, -1, -1}, {19285, -1, -1, -1}, {19286, -1, -1, -1}, {19287, -1, -1, -1}, {19288, -1, -1, -1}, {19289, -1, -1, -1}, {19290, -1, -1, -1}, {19291, -1, -1, -1}, {19292, -1, -1, -1}, {19293, -1, -1, -1}, {19294, -1, -1, -1}, {19295, -1, -1, -1}, {19296, -1, -1, -1}, {19297, -1, -1, -1}, {19298, -1, -1, -1}, {19299, -1, -1, -1}, {19300, -1, -1, -1}, {19301, -1, -1, -1}, {19302, -1, -1, -1}, {19303, -1, -1, -1}, {19304, -1, -1, -1}, {19305, -1, -1, -1}, {19306, -1, -1, -1}, {19307, -1, -1, -1}, {19308, -1, -1, -1}, {19309, -1, -1, -1}, {19310, -1, -1, -1}, {19311, -1, -1, -1}, {19312, -1, -1, -1}, {19313, -1, -1, -1}, {19314, -1, -1, -1}, {19315, -1, -1, -1}, {19316, -1, -1, -1}, {19317, -1, -1, -1}, {19318, -1, -1, -1}, {19319, -1, -1, -1}, {19320, -1, -1, -1}, {19321, -1, -1, -1}, {19322, -1, -1, -1}, {19323, -1, -1, -1}, {19324, -1, -1, -1}, {19325, -1, -1, -1}, {19326, -1, -1, -1}, {19327, -1, -1, -1}, {19328, -1, -1, -1}, {19329, -1, -1, -1}, {19330, -1, -1, -1}, {19331, -1, -1, -1}, {19332, -1, -1, -1}, {19333, -1, -1, -1}, {19334, -1, -1, -1}, {19335, -1, -1, -1}, {19336, -1, -1, -1}, {19337, -1, -1, -1}, {19338, -1, -1, -1}, {19339, -1, -1, -1}, {19340, -1, -1, -1}, {19341, -1, -1, -1}, {19342, -1, -1, -1}, {19343, -1, -1, -1}, {19344, -1, -1, -1}, {19345, -1, -1, -1}, {19346, -1, -1, -1}, {19347, -1, -1, -1}, {19348, -1, -1, -1}, {19349, -1, -1, -1}, {19350, -1, -1, -1}, {19351, -1, -1, -1}, {19352, -1, -1, -1}, {19353, -1, -1, -1}, {19354, -1, -1, -1}, {19355, -1, -1, -1}, {19356, -1, -1, -1}, {19357, -1, -1, -1}, {19358, -1, -1, -1}, {19359, -1, -1, -1}, {19360, -1, -1, -1}, {19361, -1, -1, -1}, {19362, -1, -1, -1}, {19363, -1, -1, -1}, {19364, -1, -1, -1}, {19365, -1, -1, -1}, {19366, -1, -1, -1}, {19367, -1, -1, -1}, {19368, -1, -1, -1}, {19369, -1, -1, -1}, {19370, -1, -1, -1}, {19371, -1, -1, -1}, {19372, -1, -1, -1}, {19373, -1, -1, -1}, {19374, -1, -1, -1}, {19375, -1, -1, -1}, {19376, -1, -1, -1}, {19377, -1, -1, -1}, {19378, -1, -1, -1}, {19379, -1, -1, -1}, {19380, -1, -1, -1}, {19381, -1, -1, -1}, {19382, -1, -1, -1}, {19383, -1, -1, -1}, {19384, -1, -1, -1}, {19385, -1, -1, -1}, {19386, -1, -1, -1}, {19387, -1, -1, -1}, {19388, -1, -1, -1}, {19389, -1, -1, -1}, {19390, -1, -1, -1}, {19391, -1, -1, -1}, {19392, -1, -1, -1}, {19393, -1, -1, -1}, {19394, -1, -1, -1}, {19395, -1, -1, -1}, {19396, -1, -1, -1}, {19397, -1, -1, -1}, {19398, -1, -1, -1}, {19399, -1, -1, -1}, {19400, -1, -1, -1}, {19401, -1, -1, -1}, {19402, -1, -1, -1}, {19403, -1, -1, -1}, {19404, -1, -1, -1}, {19405, -1, -1, -1}, {19406, -1, -1, -1}, {19407, -1, -1, -1}, {19408, -1, -1, -1}, {19409, -1, -1, -1}, {19410, -1, -1, -1}, {19411, -1, -1, -1}, {19412, -1, -1, -1}, {19413, -1, -1, -1}, {19414, -1, -1, -1}, {19415, -1, -1, -1}, {19416, -1, -1, -1}, {19417, -1, -1, -1}, {19418, -1, -1, -1}, {19419, -1, -1, -1}, {19420, -1, -1, -1}, {19421, -1, -1, -1}, {19422, -1, -1, -1}, {19423, -1, -1, -1}, {19424, -1, -1, -1}, {19425, -1, -1, -1}, {19426, -1, -1, -1}, {19427, -1, -1, -1}, {19428, -1, -1, -1}, {19429, -1, -1, -1}, {19430, -1, -1, -1}, {19431, -1, -1, -1}, {19432, -1, -1, -1}, {19433, -1, -1, -1}, {19434, -1, -1, -1}, {19435, -1, -1, -1}, {19436, -1, -1, -1}, {19437, -1, -1, -1}, {19438, -1, -1, -1}, {19439, -1, -1, -1}, {19440, -1, -1, -1}, {19441, -1, -1, -1}, {19442, -1, -1, -1}, {19443, -1, -1, -1}, {19444, -1, -1, -1}, {19445, -1, -1, -1}, {19446, -1, -1, -1}, {19447, -1, -1, -1}, {19448, -1, -1, -1}, {19449, -1, -1, -1}, {19450, -1, -1, -1}, {19451, -1, -1, -1}, {19452, -1, -1, -1}, {19453, -1, -1, -1}, {19454, -1, -1, -1}, {19455, -1, -1, -1}, {19456, -1, -1, -1}, {19457, -1, -1, -1}, {19458, -1, -1, -1}, {19459, -1, -1, -1}, {19460, -1, -1, -1}, {19461, -1, -1, -1}, {19462, -1, -1, -1}, {19463, -1, -1, -1}, {19464, -1, -1, -1}, {19465, -1, -1, -1}, {19466, -1, -1, -1}, {19467, -1, -1, -1}, {19468, -1, -1, -1}, {19469, -1, -1, -1}, {19470, -1, -1, -1}, {19471, -1, -1, -1}, {19472, -1, -1, -1}, {19473, -1, -1, -1}, {19474, -1, -1, -1}, {19475, -1, -1, -1}, {19476, -1, -1, -1}, {19477, -1, -1, -1}, {19478, -1, -1, -1}, {19479, -1, -1, -1}, {19480, -1, -1, -1}, {19481, -1, -1, -1}, {19482, -1, -1, -1}, {19483, -1, -1, -1}, {19484, -1, -1, -1}, {19485, -1, -1, -1}, {19486, -1, -1, -1}, {19487, -1, -1, -1}, {19488, -1, -1, -1}, {19489, -1, -1, -1}, {19490, -1, -1, -1}, {19491, -1, -1, -1}, {19492, -1, -1, -1} },
+ {{19493, -1, -1, -1}, {19494, -1, -1, -1}, {19495, -1, -1, -1}, {19496, -1, -1, -1}, {19497, -1, -1, -1}, {19498, -1, -1, -1}, {19499, -1, -1, -1}, {19500, -1, -1, -1}, {19501, -1, -1, -1}, {19502, -1, -1, -1}, {19503, -1, -1, -1}, {19504, -1, -1, -1}, {19505, -1, -1, -1}, {19506, -1, -1, -1}, {19507, -1, -1, -1}, {19508, -1, -1, -1}, {19509, -1, -1, -1}, {19510, -1, -1, -1}, {19511, -1, -1, -1}, {19512, -1, -1, -1}, {19513, -1, -1, -1}, {19514, -1, -1, -1}, {19515, -1, -1, -1}, {19516, -1, -1, -1}, {19517, -1, -1, -1}, {19518, -1, -1, -1}, {19519, -1, -1, -1}, {19520, -1, -1, -1}, {19521, -1, -1, -1}, {19522, -1, -1, -1}, {19523, -1, -1, -1}, {19524, -1, -1, -1}, {19525, -1, -1, -1}, {19526, -1, -1, -1}, {19527, -1, -1, -1}, {19528, -1, -1, -1}, {19529, -1, -1, -1}, {19530, -1, -1, -1}, {19531, -1, -1, -1}, {19532, -1, -1, -1}, {19533, -1, -1, -1}, {19534, -1, -1, -1}, {19535, -1, -1, -1}, {19536, -1, -1, -1}, {19537, -1, -1, -1}, {19538, -1, -1, -1}, {19539, -1, -1, -1}, {19540, -1, -1, -1}, {19541, -1, -1, -1}, {19542, -1, -1, -1}, {19543, -1, -1, -1}, {19544, -1, -1, -1}, {19545, -1, -1, -1}, {19546, -1, -1, -1}, {19547, -1, -1, -1}, {19548, -1, -1, -1}, {19549, -1, -1, -1}, {19550, -1, -1, -1}, {19551, -1, -1, -1}, {19552, -1, -1, -1}, {19553, -1, -1, -1}, {19554, -1, -1, -1}, {19555, -1, -1, -1}, {19556, -1, -1, -1}, {19557, -1, -1, -1}, {19558, -1, -1, -1}, {19559, -1, -1, -1}, {19560, -1, -1, -1}, {19561, -1, -1, -1}, {19562, -1, -1, -1}, {19563, -1, -1, -1}, {19564, -1, -1, -1}, {19565, -1, -1, -1}, {19566, -1, -1, -1}, {19567, -1, -1, -1}, {19568, -1, -1, -1}, {19569, -1, -1, -1}, {19570, -1, -1, -1}, {19571, -1, -1, -1}, {19572, -1, -1, -1}, {19573, -1, -1, -1}, {19574, -1, -1, -1}, {19576, -1, -1, -1}, {19577, -1, -1, -1}, {19578, -1, -1, -1}, {19579, -1, -1, -1}, {19580, -1, -1, -1}, {19581, -1, -1, -1}, {19582, -1, -1, -1}, {19583, -1, -1, -1}, {19584, -1, -1, -1}, {19585, -1, -1, -1}, {19586, -1, -1, -1}, {19587, -1, -1, -1}, {19588, -1, -1, -1}, {19589, -1, -1, -1}, {19590, -1, -1, -1}, {19591, -1, -1, -1}, {19592, -1, -1, -1}, {19593, -1, -1, -1}, {19594, -1, -1, -1}, {19595, -1, -1, -1}, {19596, -1, -1, -1}, {19597, -1, -1, -1}, {19598, -1, -1, -1}, {19599, -1, -1, -1}, {19600, -1, -1, -1}, {19601, -1, -1, -1}, {19602, -1, -1, -1}, {19603, -1, -1, -1}, {19604, -1, -1, -1}, {19605, -1, -1, -1}, {19606, -1, -1, -1}, {19607, -1, -1, -1}, {19608, -1, -1, -1}, {19609, -1, -1, -1}, {19610, -1, -1, -1}, {19611, -1, -1, -1}, {19612, -1, -1, -1}, {19613, -1, -1, -1}, {19614, -1, -1, -1}, {19620, -1, -1, -1}, {19621, -1, -1, -1}, {19622, -1, -1, -1}, {19623, -1, -1, -1}, {19624, -1, -1, -1}, {19625, -1, -1, -1}, {19626, -1, -1, -1}, {19627, -1, -1, -1}, {19628, -1, -1, -1}, {19629, -1, -1, -1}, {19630, -1, -1, -1}, {19631, -1, -1, -1}, {19632, -1, -1, -1}, {19633, -1, -1, -1}, {19634, -1, -1, -1}, {19635, -1, -1, -1}, {19636, -1, -1, -1}, {19637, -1, -1, -1}, {19638, -1, -1, -1}, {19639, -1, -1, -1}, {19640, -1, -1, -1}, {19641, -1, -1, -1}, {19642, -1, -1, -1}, {19643, -1, -1, -1}, {19644, -1, -1, -1}, {19645, -1, -1, -1}, {19646, -1, -1, -1}, {19647, -1, -1, -1}, {19648, -1, -1, -1}, {19649, -1, -1, -1}, {19650, -1, -1, -1}, {19651, -1, -1, -1}, {19652, -1, -1, -1}, {19653, -1, -1, -1}, {19654, -1, -1, -1}, {19655, -1, -1, -1}, {19656, -1, -1, -1}, {19657, -1, -1, -1}, {19658, -1, -1, -1}, {19659, -1, -1, -1}, {19660, -1, -1, -1}, {19661, -1, -1, -1}, {19662, -1, -1, -1}, {19663, -1, -1, -1}, {19664, -1, -1, -1}, {19665, -1, -1, -1}, {19666, -1, -1, -1}, {19667, -1, -1, -1}, {19668, -1, -1, -1}, {19669, -1, -1, -1}, {19670, -1, -1, -1}, {19671, -1, -1, -1}, {19672, -1, -1, -1}, {19673, -1, -1, -1}, {19674, -1, -1, -1}, {19675, -1, -1, -1}, {19676, -1, -1, -1}, {19677, -1, -1, -1}, {19678, -1, -1, -1}, {19679, -1, -1, -1}, {19680, -1, -1, -1}, {19681, -1, -1, -1}, {19682, -1, -1, -1}, {19683, -1, -1, -1}, {19684, -1, -1, -1}, {19685, -1, -1, -1}, {19686, -1, -1, -1}, {19687, -1, -1, -1}, {19688, -1, -1, -1}, {19689, -1, -1, -1}, {19690, -1, -1, -1}, {19691, -1, -1, -1}, {19692, -1, -1, -1}, {19693, -1, -1, -1}, {19694, -1, -1, -1}, {19695, -1, -1, -1}, {19696, -1, -1, -1}, {19697, -1, -1, -1}, {19698, -1, -1, -1}, {19699, -1, -1, -1}, {19700, -1, -1, -1}, {19701, -1, -1, -1}, {19702, -1, -1, -1}, {19703, -1, -1, -1}, {19704, -1, -1, -1}, {19705, -1, -1, -1}, {19706, -1, -1, -1}, {19707, -1, -1, -1}, {19708, -1, -1, -1}, {19709, -1, -1, -1}, {19710, -1, -1, -1}, {19711, -1, -1, -1}, {19712, -1, -1, -1}, {19713, -1, -1, -1}, {19714, -1, -1, -1}, {19715, -1, -1, -1}, {19716, -1, -1, -1}, {19717, -1, -1, -1}, {19718, -1, -1, -1}, {19719, -1, -1, -1}, {19720, -1, -1, -1}, {19721, -1, -1, -1}, {19722, -1, -1, -1}, {19723, -1, -1, -1}, {19724, -1, -1, -1}, {19725, -1, -1, -1}, {19726, -1, -1, -1}, {19727, -1, -1, -1}, {19728, -1, -1, -1}, {19729, -1, -1, -1}, {19730, -1, -1, -1}, {19738, -1, -1, -1}, {19739, -1, -1, -1}, {19740, -1, -1, -1}, {19741, -1, -1, -1}, {19742, -1, -1, -1}, {19743, -1, -1, -1}, {19744, -1, -1, -1}, {19745, -1, -1, -1}, {19746, -1, -1, -1}, {19747, -1, -1, -1}, {19748, -1, -1, -1}, {19749, -1, -1, -1}, {19750, -1, -1, -1}, {19751, -1, -1, -1}, {19752, -1, -1, -1}, {19753, -1, -1, -1}, {19754, -1, -1, -1}, {19755, -1, -1, -1}, {19756, -1, -1, -1}, {19757, -1, -1, -1}, {19758, -1, -1, -1}, {19759, -1, -1, -1}, {19760, -1, -1, -1}, {19761, -1, -1, -1} },
+ {{19762, -1, -1, -1}, {19763, -1, -1, -1}, {19764, -1, -1, -1}, {19765, -1, -1, -1}, {19766, -1, -1, -1}, {19767, -1, -1, -1}, {19768, -1, -1, -1}, {19769, -1, -1, -1}, {19770, -1, -1, -1}, {19771, -1, -1, -1}, {19772, -1, -1, -1}, {19773, -1, -1, -1}, {19774, -1, -1, -1}, {19775, -1, -1, -1}, {19776, -1, -1, -1}, {19777, -1, -1, -1}, {19778, -1, -1, -1}, {19779, -1, -1, -1}, {19780, -1, -1, -1}, {19781, -1, -1, -1}, {19782, -1, -1, -1}, {19783, -1, -1, -1}, {19784, -1, -1, -1}, {19785, -1, -1, -1}, {19786, -1, -1, -1}, {19787, -1, -1, -1}, {19788, -1, -1, -1}, {19789, -1, -1, -1}, {19790, -1, -1, -1}, {19791, -1, -1, -1}, {19792, -1, -1, -1}, {19793, -1, -1, -1}, {19794, -1, -1, -1}, {19795, -1, -1, -1}, {19796, -1, -1, -1}, {19797, -1, -1, -1}, {19798, -1, -1, -1}, {19799, -1, -1, -1}, {19800, -1, -1, -1}, {19801, -1, -1, -1}, {19802, -1, -1, -1}, {19803, -1, -1, -1}, {19804, -1, -1, -1}, {19805, -1, -1, -1}, {19806, -1, -1, -1}, {19807, -1, -1, -1}, {19808, -1, -1, -1}, {19809, -1, -1, -1}, {19810, -1, -1, -1}, {19811, -1, -1, -1}, {19812, -1, -1, -1}, {19813, -1, -1, -1}, {19814, -1, -1, -1}, {19815, -1, -1, -1}, {19816, -1, -1, -1}, {19817, -1, -1, -1}, {19818, -1, -1, -1}, {19819, -1, -1, -1}, {19820, -1, -1, -1}, {19821, -1, -1, -1}, {19822, -1, -1, -1}, {19823, -1, -1, -1}, {19824, -1, -1, -1}, {19825, -1, -1, -1}, {19826, -1, -1, -1}, {19827, -1, -1, -1}, {19828, -1, -1, -1}, {19829, -1, -1, -1}, {19830, -1, -1, -1}, {19831, -1, -1, -1}, {19832, -1, -1, -1}, {19833, -1, -1, -1}, {19834, -1, -1, -1}, {19835, -1, -1, -1}, {19836, -1, -1, -1}, {19837, -1, -1, -1}, {19838, -1, -1, -1}, {19839, -1, -1, -1}, {19840, -1, -1, -1}, {19841, -1, -1, -1}, {19842, -1, -1, -1}, {19843, -1, -1, -1}, {19844, -1, -1, -1}, {19845, -1, -1, -1}, {19846, -1, -1, -1}, {19847, -1, -1, -1}, {19848, -1, -1, -1}, {19849, -1, -1, -1}, {19850, -1, -1, -1}, {19851, -1, -1, -1}, {19852, -1, -1, -1}, {19853, -1, -1, -1}, {19854, -1, -1, -1}, {19855, -1, -1, -1}, {19856, -1, -1, -1}, {19857, -1, -1, -1}, {19858, -1, -1, -1}, {19859, -1, -1, -1}, {19860, -1, -1, -1}, {19861, -1, -1, -1}, {19862, -1, -1, -1}, {19863, -1, -1, -1}, {19864, -1, -1, -1}, {19865, -1, -1, -1}, {19866, -1, -1, -1}, {19867, -1, -1, -1}, {19868, -1, -1, -1}, {19869, -1, -1, -1}, {19870, -1, -1, -1}, {19871, -1, -1, -1}, {19872, -1, -1, -1}, {19873, -1, -1, -1}, {19874, -1, -1, -1}, {19875, -1, -1, -1}, {19876, -1, -1, -1}, {19877, -1, -1, -1}, {19878, -1, -1, -1}, {19879, -1, -1, -1}, {19880, -1, -1, -1}, {19881, -1, -1, -1}, {19882, -1, -1, -1}, {19883, -1, -1, -1}, {19884, -1, -1, -1}, {19885, -1, -1, -1}, {19887, -1, -1, -1}, {19888, -1, -1, -1}, {19889, -1, -1, -1}, {19890, -1, -1, -1}, {19891, -1, -1, -1}, {19892, -1, -1, -1}, {19893, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ }
+};
+
+static const pdfi_cid_decoding_t japan1_unicode = {
+ "Japan1", "Unicode",
+ 61,
+ 4,
+ {
+ {{-1, -1, -1, -1}, {32, -1, -1, -1}, {33, -1, -1, -1}, {34, -1, -1, -1}, {35, -1, -1, -1}, {36, -1, -1, -1}, {37, -1, -1, -1}, {38, -1, -1, -1}, {39, -1, -1, -1}, {40, -1, -1, -1}, {41, -1, -1, -1}, {42, -1, -1, -1}, {43, -1, -1, -1}, {44, -1, -1, -1}, {45, 8209, -1, -1}, {46, -1, -1, -1}, {47, -1, -1, -1}, {48, -1, -1, -1}, {49, -1, -1, -1}, {50, -1, -1, -1}, {51, -1, -1, -1}, {52, -1, -1, -1}, {53, -1, -1, -1}, {54, -1, -1, -1}, {55, -1, -1, -1}, {56, -1, -1, -1}, {57, -1, -1, -1}, {58, -1, -1, -1}, {59, -1, -1, -1}, {60, -1, -1, -1}, {61, -1, -1, -1}, {62, -1, -1, -1}, {63, -1, -1, -1}, {64, -1, -1, -1}, {65, -1, -1, -1}, {66, -1, -1, -1}, {67, -1, -1, -1}, {68, -1, -1, -1}, {69, -1, -1, -1}, {70, -1, -1, -1}, {71, -1, -1, -1}, {72, -1, -1, -1}, {73, -1, -1, -1}, {74, -1, -1, -1}, {75, -1, -1, -1}, {76, -1, -1, -1}, {77, -1, -1, -1}, {78, -1, -1, -1}, {79, -1, -1, -1}, {80, -1, -1, -1}, {81, -1, -1, -1}, {82, -1, -1, -1}, {83, -1, -1, -1}, {84, -1, -1, -1}, {85, -1, -1, -1}, {86, -1, -1, -1}, {87, -1, -1, -1}, {88, -1, -1, -1}, {89, -1, -1, -1}, {90, -1, -1, -1}, {91, -1, -1, -1}, {165, -1, -1, -1}, {93, -1, -1, -1}, {94, -1, -1, -1}, {95, 818, -1, -1}, {768, 96, -1, -1}, {97, -1, -1, -1}, {98, -1, -1, -1}, {99, -1, -1, -1}, {100, -1, -1, -1}, {101, -1, -1, -1}, {102, -1, -1, -1}, {103, -1, -1, -1}, {104, -1, -1, -1}, {105, -1, -1, -1}, {106, -1, -1, -1}, {107, -1, -1, -1}, {108, -1, -1, -1}, {109, -1, -1, -1}, {110, -1, -1, -1}, {111, -1, -1, -1}, {112, -1, -1, -1}, {113, -1, -1, -1}, {114, -1, -1, -1}, {115, -1, -1, -1}, {116, -1, -1, -1}, {117, -1, -1, -1}, {118, -1, -1, -1}, {119, -1, -1, -1}, {120, -1, -1, -1}, {121, -1, -1, -1}, {122, -1, -1, -1}, {123, -1, -1, -1}, {124, -1, -1, -1}, {125, -1, -1, -1}, {771, 126, -1, -1}, {-1, -1, -1, -1}, {92, -1, -1, -1}, {-1, -1, -1, -1}, {448, 166, -1, -1}, {-1, -1, -1, -1}, {161, -1, -1, -1}, {162, -1, -1, -1}, {163, -1, -1, -1}, {8260, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {164, -1, -1, -1}, {-1, -1, -1, -1}, {171, -1, -1, -1}, {8249, -1, -1, -1}, {8250, -1, -1, -1}, {64257, -1, -1, -1}, {64258, -1, -1, -1}, {8211, 8210, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {183, -1, -1, -1}, {-1, -1, -1, -1}, {8226, -1, -1, -1}, {8218, -1, -1, -1}, {8222, -1, -1, -1}, {-1, -1, -1, -1}, {187, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {191, -1, -1, -1}, {769, -1, -1, -1}, {770, -1, -1, -1}, {772, 175, -1, -1}, {774, -1, -1, -1}, {775, -1, -1, -1}, {776, -1, -1, -1}, {778, -1, -1, -1}, {184, 807, -1, -1}, {779, -1, -1, -1}, {808, -1, -1, -1}, {780, -1, -1, -1}, {8212, 822, -1, -1}, {198, -1, -1, -1}, {170, -1, -1, -1}, {321, -1, -1, -1}, {216, -1, -1, -1}, {338, -1, -1, -1}, {186, -1, -1, -1}, {230, -1, -1, -1}, {305, -1, -1, -1}, {322, -1, -1, -1}, {248, -1, -1, -1}, {339, -1, -1, -1}, {223, -1, -1, -1}, {173, -1, -1, -1}, {169, -1, -1, -1}, {172, -1, -1, -1}, {174, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {178, -1, -1, -1}, {179, -1, -1, -1}, {181, -1, -1, -1}, {185, -1, -1, -1}, {188, -1, -1, -1}, {189, -1, -1, -1}, {190, -1, -1, -1}, {192, -1, -1, -1}, {193, -1, -1, -1}, {194, -1, -1, -1}, {195, -1, -1, -1}, {196, -1, -1, -1}, {197, -1, -1, -1}, {199, -1, -1, -1}, {200, -1, -1, -1}, {201, -1, -1, -1}, {202, -1, -1, -1}, {203, -1, -1, -1}, {204, -1, -1, -1}, {205, -1, -1, -1}, {206, -1, -1, -1}, {207, -1, -1, -1}, {208, -1, -1, -1}, {209, -1, -1, -1}, {210, -1, -1, -1}, {211, -1, -1, -1}, {212, -1, -1, -1}, {213, -1, -1, -1}, {214, -1, -1, -1}, {-1, -1, -1, -1}, {217, -1, -1, -1}, {218, -1, -1, -1}, {219, -1, -1, -1}, {220, -1, -1, -1}, {221, -1, -1, -1}, {222, -1, -1, -1}, {224, -1, -1, -1}, {225, -1, -1, -1}, {226, -1, -1, -1}, {227, -1, -1, -1}, {228, -1, -1, -1}, {229, -1, -1, -1}, {231, -1, -1, -1}, {232, -1, -1, -1}, {233, -1, -1, -1}, {234, -1, -1, -1}, {235, -1, -1, -1}, {236, -1, -1, -1}, {237, -1, -1, -1}, {238, -1, -1, -1}, {239, -1, -1, -1}, {240, -1, -1, -1}, {241, -1, -1, -1}, {242, -1, -1, -1}, {243, -1, -1, -1}, {244, -1, -1, -1}, {245, -1, -1, -1}, {246, -1, -1, -1}, {-1, -1, -1, -1}, {249, -1, -1, -1}, {250, -1, -1, -1}, {251, -1, -1, -1}, {252, -1, -1, -1}, {253, -1, -1, -1}, {254, -1, -1, -1}, {255, -1, -1, -1}, {352, -1, -1, -1}, {376, -1, -1, -1}, {381, -1, -1, -1}, {773, -1, -1, -1}, {353, -1, -1, -1}, {8482, -1, -1, -1}, {382, -1, -1, -1}, {-1, -1, -1, -1}, {8194, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {65512, -1, -1, -1}, {-1, -1, -1, -1}, {8254, -1, -1, -1}, {-1, -1, -1, -1}, {65377, -1, -1, -1}, {65378, -1, -1, -1}, {65379, -1, -1, -1}, {65380, -1, -1, -1}, {65381, -1, -1, -1}, {65382, -1, -1, -1}, {65383, -1, -1, -1}, {65384, -1, -1, -1}, {65385, -1, -1, -1}, {65386, -1, -1, -1}, {65387, -1, -1, -1}, {65388, -1, -1, -1}, {65389, -1, -1, -1}, {65390, -1, -1, -1}, {65391, -1, -1, -1}, {65392, -1, -1, -1}, {65393, -1, -1, -1}, {65394, -1, -1, -1}, {65395, -1, -1, -1}, {65396, -1, -1, -1}, {65397, -1, -1, -1}, {65398, -1, -1, -1}, {65399, -1, -1, -1}, {65400, -1, -1, -1}, {65401, -1, -1, -1}, {65402, -1, -1, -1}, {65403, -1, -1, -1}, {65404, -1, -1, -1}, {65405, -1, -1, -1}, {65406, -1, -1, -1}, {65407, -1, -1, -1}, {65408, -1, -1, -1}, {65409, -1, -1, -1}, {65410, -1, -1, -1}, {65411, -1, -1, -1}, {65412, -1, -1, -1}, {65413, -1, -1, -1}, {65414, -1, -1, -1}, {65415, -1, -1, -1}, {65416, -1, -1, -1}, {65417, -1, -1, -1}, {65418, -1, -1, -1}, {65419, -1, -1, -1}, {65420, -1, -1, -1}, {65421, -1, -1, -1}, {65422, -1, -1, -1}, {65423, -1, -1, -1}, {65424, -1, -1, -1}, {65425, -1, -1, -1}, {65426, -1, -1, -1}, {65427, -1, -1, -1}, {65428, -1, -1, -1}, {65429, -1, -1, -1}, {65430, -1, -1, -1}, {65431, -1, -1, -1}, {65432, -1, -1, -1}, {65433, -1, -1, -1}, {65434, -1, -1, -1}, {65435, -1, -1, -1}, {65436, -1, -1, -1}, {65437, -1, -1, -1}, {65438, -1, -1, -1}, {65439, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8195, 12288, -1, -1}, {12289, -1, -1, -1}, {12290, -1, -1, -1}, {65292, -1, -1, -1}, {65294, -1, -1, -1}, {12539, -1, -1, -1}, {65306, -1, -1, -1}, {65307, -1, -1, -1}, {65311, -1, -1, -1}, {65281, -1, -1, -1}, {12443, -1, -1, -1}, {12444, -1, -1, -1}, {180, -1, -1, -1}, {65344, -1, -1, -1}, {168, -1, -1, -1}, {65342, -1, -1, -1}, {65507, -1, -1, -1}, {65343, -1, -1, -1}, {12541, -1, -1, -1}, {12542, -1, -1, -1}, {12445, -1, -1, -1}, {12446, -1, -1, -1}, {12291, -1, -1, -1}, {20189, -1, -1, -1}, {12293, -1, -1, -1}, {12294, -1, -1, -1}, {12295, -1, -1, -1}, {12540, -1, -1, -1}, {8213, -1, -1, -1}, {8208, -1, -1, -1}, {65295, -1, -1, -1}, {65340, -1, -1, -1}, {8764, 12316, 65374, -1}, {8214, 8741, -1, -1}, {65372, -1, -1, -1}, {8230, 8943, -1, -1}, {8229, -1, -1, -1}, {8216, -1, -1, -1}, {8217, -1, -1, -1}, {8220, -1, -1, -1}, {8221, -1, -1, -1}, {65288, -1, -1, -1}, {65289, -1, -1, -1}, {12308, -1, -1, -1}, {12309, -1, -1, -1}, {65339, -1, -1, -1}, {65341, -1, -1, -1}, {65371, -1, -1, -1}, {65373, -1, -1, -1}, {12296, -1, -1, -1}, {12297, -1, -1, -1}, {12298, -1, -1, -1}, {12299, -1, -1, -1}, {12300, -1, -1, -1}, {12301, -1, -1, -1}, {12302, -1, -1, -1}, {12303, -1, -1, -1}, {12304, -1, -1, -1}, {12305, -1, -1, -1}, {65291, -1, -1, -1}, {8722, 65293, -1, -1}, {177, -1, -1, -1}, {215, -1, -1, -1}, {247, -1, -1, -1}, {65309, -1, -1, -1}, {8800, -1, -1, -1}, {65308, -1, -1, -1}, {65310, -1, -1, -1}, {8806, -1, -1, -1}, {8807, -1, -1, -1}, {8734, -1, -1, -1}, {8756, -1, -1, -1}, {9794, -1, -1, -1}, {9792, -1, -1, -1}, {176, -1, -1, -1}, {8242, -1, -1, -1}, {8243, -1, -1, -1}, {8451, -1, -1, -1}, {65509, -1, -1, -1}, {65284, -1, -1, -1}, {65504, -1, -1, -1}, {65505, -1, -1, -1}, {65285, -1, -1, -1}, {65283, -1, -1, -1}, {65286, -1, -1, -1}, {65290, -1, -1, -1}, {65312, -1, -1, -1}, {167, -1, -1, -1}, {9734, -1, -1, -1}, {9733, -1, -1, -1}, {9675, -1, -1, -1}, {9679, -1, -1, -1}, {9678, -1, -1, -1}, {9671, -1, -1, -1}, {9670, -1, -1, -1}, {9633, -1, -1, -1}, {9632, -1, -1, -1}, {9651, -1, -1, -1}, {9650, -1, -1, -1}, {9661, -1, -1, -1}, {9660, -1, -1, -1}, {8251, -1, -1, -1}, {12306, -1, -1, -1}, {8594, 8593, -1, -1}, {8592, 8595, -1, -1}, {8593, 8592, -1, -1}, {8595, 8594, -1, -1}, {12307, -1, -1, -1}, {8712, -1, -1, -1}, {8715, -1, -1, -1}, {8838, -1, -1, -1}, {8839, -1, -1, -1}, {8834, -1, -1, -1}, {8835, -1, -1, -1}, {8746, -1, -1, -1}, {8745, -1, -1, -1}, {8743, -1, -1, -1}, {8744, -1, -1, -1}, {65506, -1, -1, -1}, {8658, -1, -1, -1}, {8660, -1, -1, -1}, {8704, -1, -1, -1}, {8707, -1, -1, -1}, {8736, -1, -1, -1}, {8869, -1, -1, -1}, {865, 8978, -1, -1}, {8706, -1, -1, -1}, {8711, -1, -1, -1}, {8801, -1, -1, -1}, {8786, -1, -1, -1}, {8810, -1, -1, -1}, {8811, -1, -1, -1}, {8730, -1, -1, -1}, {8765, -1, -1, -1}, {8733, -1, -1, -1} },
+ {{8757, -1, -1, -1}, {8747, -1, -1, -1}, {8748, -1, -1, -1}, {8491, -1, -1, -1}, {8240, -1, -1, -1}, {9839, -1, -1, -1}, {9837, -1, -1, -1}, {9834, -1, -1, -1}, {8224, -1, -1, -1}, {8225, -1, -1, -1}, {182, -1, -1, -1}, {8413, 9711, -1, -1}, {65296, -1, -1, -1}, {65297, -1, -1, -1}, {65298, -1, -1, -1}, {65299, -1, -1, -1}, {65300, -1, -1, -1}, {65301, -1, -1, -1}, {65302, -1, -1, -1}, {65303, -1, -1, -1}, {65304, -1, -1, -1}, {65305, -1, -1, -1}, {65313, -1, -1, -1}, {65314, -1, -1, -1}, {65315, -1, -1, -1}, {65316, -1, -1, -1}, {65317, -1, -1, -1}, {65318, -1, -1, -1}, {65319, -1, -1, -1}, {65320, -1, -1, -1}, {65321, -1, -1, -1}, {65322, -1, -1, -1}, {65323, -1, -1, -1}, {65324, -1, -1, -1}, {65325, -1, -1, -1}, {65326, -1, -1, -1}, {65327, -1, -1, -1}, {65328, -1, -1, -1}, {65329, -1, -1, -1}, {65330, -1, -1, -1}, {65331, -1, -1, -1}, {65332, -1, -1, -1}, {65333, -1, -1, -1}, {65334, -1, -1, -1}, {65335, -1, -1, -1}, {65336, -1, -1, -1}, {65337, -1, -1, -1}, {65338, -1, -1, -1}, {65345, -1, -1, -1}, {65346, -1, -1, -1}, {65347, -1, -1, -1}, {65348, -1, -1, -1}, {65349, -1, -1, -1}, {65350, -1, -1, -1}, {65351, -1, -1, -1}, {65352, -1, -1, -1}, {65353, -1, -1, -1}, {65354, -1, -1, -1}, {65355, -1, -1, -1}, {65356, -1, -1, -1}, {65357, -1, -1, -1}, {65358, -1, -1, -1}, {65359, -1, -1, -1}, {65360, -1, -1, -1}, {65361, -1, -1, -1}, {65362, -1, -1, -1}, {65363, -1, -1, -1}, {65364, -1, -1, -1}, {65365, -1, -1, -1}, {65366, -1, -1, -1}, {65367, -1, -1, -1}, {65368, -1, -1, -1}, {65369, -1, -1, -1}, {65370, -1, -1, -1}, {12353, -1, -1, -1}, {12354, -1, -1, -1}, {12355, -1, -1, -1}, {12356, -1, -1, -1}, {12357, -1, -1, -1}, {12358, -1, -1, -1}, {12359, -1, -1, -1}, {12360, -1, -1, -1}, {12361, -1, -1, -1}, {12362, -1, -1, -1}, {12363, -1, -1, -1}, {12364, -1, -1, -1}, {12365, -1, -1, -1}, {12366, -1, -1, -1}, {12367, -1, -1, -1}, {12368, -1, -1, -1}, {12369, -1, -1, -1}, {12370, -1, -1, -1}, {12371, -1, -1, -1}, {12372, -1, -1, -1}, {12373, -1, -1, -1}, {12374, -1, -1, -1}, {12375, -1, -1, -1}, {12376, -1, -1, -1}, {12377, -1, -1, -1}, {12378, -1, -1, -1}, {12379, -1, -1, -1}, {12380, -1, -1, -1}, {12381, -1, -1, -1}, {12382, -1, -1, -1}, {12383, -1, -1, -1}, {12384, -1, -1, -1}, {12385, -1, -1, -1}, {12386, -1, -1, -1}, {12387, -1, -1, -1}, {12388, -1, -1, -1}, {12389, -1, -1, -1}, {12390, -1, -1, -1}, {12391, -1, -1, -1}, {12392, -1, -1, -1}, {12393, -1, -1, -1}, {12394, -1, -1, -1}, {12395, -1, -1, -1}, {12396, -1, -1, -1}, {12397, -1, -1, -1}, {12398, -1, -1, -1}, {12399, -1, -1, -1}, {12400, -1, -1, -1}, {12401, -1, -1, -1}, {12402, -1, -1, -1}, {12403, -1, -1, -1}, {12404, -1, -1, -1}, {12405, -1, -1, -1}, {12406, -1, -1, -1}, {12407, -1, -1, -1}, {12408, -1, -1, -1}, {12409, -1, -1, -1}, {12410, -1, -1, -1}, {12411, -1, -1, -1}, {12412, -1, -1, -1}, {12413, -1, -1, -1}, {12414, -1, -1, -1}, {12415, -1, -1, -1}, {12416, -1, -1, -1}, {12417, -1, -1, -1}, {12418, -1, -1, -1}, {12419, -1, -1, -1}, {12420, -1, -1, -1}, {12421, -1, -1, -1}, {12422, -1, -1, -1}, {12423, -1, -1, -1}, {12424, -1, -1, -1}, {12425, -1, -1, -1}, {12426, -1, -1, -1}, {12427, -1, -1, -1}, {12428, -1, -1, -1}, {12429, -1, -1, -1}, {12430, -1, -1, -1}, {12431, -1, -1, -1}, {12432, -1, -1, -1}, {12433, -1, -1, -1}, {12434, -1, -1, -1}, {12435, -1, -1, -1}, {12449, -1, -1, -1}, {12450, -1, -1, -1}, {12451, -1, -1, -1}, {12452, -1, -1, -1}, {12453, -1, -1, -1}, {12454, -1, -1, -1}, {12455, -1, -1, -1}, {12456, -1, -1, -1}, {12457, -1, -1, -1}, {12458, -1, -1, -1}, {12459, -1, -1, -1}, {12460, -1, -1, -1}, {12461, -1, -1, -1}, {12462, -1, -1, -1}, {12463, -1, -1, -1}, {12464, -1, -1, -1}, {12465, -1, -1, -1}, {12466, -1, -1, -1}, {12467, -1, -1, -1}, {12468, -1, -1, -1}, {12469, -1, -1, -1}, {12470, -1, -1, -1}, {12471, -1, -1, -1}, {12472, -1, -1, -1}, {12473, -1, -1, -1}, {12474, -1, -1, -1}, {12475, -1, -1, -1}, {12476, -1, -1, -1}, {12477, -1, -1, -1}, {12478, -1, -1, -1}, {12479, -1, -1, -1}, {12480, -1, -1, -1}, {12481, -1, -1, -1}, {12482, -1, -1, -1}, {12483, -1, -1, -1}, {12484, -1, -1, -1}, {12485, -1, -1, -1}, {12486, -1, -1, -1}, {12487, -1, -1, -1}, {12488, -1, -1, -1}, {12489, -1, -1, -1}, {12490, -1, -1, -1}, {12491, -1, -1, -1}, {12492, -1, -1, -1}, {12493, -1, -1, -1}, {12494, -1, -1, -1}, {12495, -1, -1, -1}, {12496, -1, -1, -1}, {12497, -1, -1, -1}, {12498, -1, -1, -1}, {12499, -1, -1, -1}, {12500, -1, -1, -1}, {12501, -1, -1, -1}, {12502, -1, -1, -1}, {12503, -1, -1, -1}, {12504, -1, -1, -1}, {12505, -1, -1, -1}, {12506, -1, -1, -1}, {12507, -1, -1, -1}, {12508, -1, -1, -1}, {12509, -1, -1, -1}, {12510, -1, -1, -1}, {12511, -1, -1, -1}, {12512, -1, -1, -1}, {12513, -1, -1, -1}, {12514, -1, -1, -1}, {12515, -1, -1, -1}, {12516, -1, -1, -1}, {12517, -1, -1, -1}, {12518, -1, -1, -1}, {12519, -1, -1, -1}, {12520, -1, -1, -1}, {12521, -1, -1, -1}, {12522, -1, -1, -1}, {12523, -1, -1, -1}, {12524, -1, -1, -1}, {12525, -1, -1, -1}, {12526, -1, -1, -1}, {12527, -1, -1, -1}, {12528, -1, -1, -1}, {12529, -1, -1, -1}, {12530, -1, -1, -1}, {12531, -1, -1, -1}, {12532, -1, -1, -1}, {12533, -1, -1, -1}, {12534, -1, -1, -1}, {913, -1, -1, -1}, {914, -1, -1, -1}, {915, -1, -1, -1}, {916, -1, -1, -1}, {917, -1, -1, -1}, {918, -1, -1, -1}, {919, -1, -1, -1}, {920, -1, -1, -1}, {921, -1, -1, -1}, {922, -1, -1, -1}, {923, -1, -1, -1}, {924, -1, -1, -1}, {925, -1, -1, -1} },
+ {{926, -1, -1, -1}, {927, -1, -1, -1}, {928, -1, -1, -1}, {929, -1, -1, -1}, {931, -1, -1, -1}, {932, -1, -1, -1}, {933, -1, -1, -1}, {934, -1, -1, -1}, {935, -1, -1, -1}, {936, -1, -1, -1}, {937, -1, -1, -1}, {945, -1, -1, -1}, {946, -1, -1, -1}, {947, -1, -1, -1}, {948, -1, -1, -1}, {949, -1, -1, -1}, {950, -1, -1, -1}, {951, -1, -1, -1}, {952, -1, -1, -1}, {953, -1, -1, -1}, {954, -1, -1, -1}, {955, -1, -1, -1}, {956, -1, -1, -1}, {957, -1, -1, -1}, {958, -1, -1, -1}, {959, -1, -1, -1}, {960, -1, -1, -1}, {961, -1, -1, -1}, {963, -1, -1, -1}, {964, -1, -1, -1}, {965, -1, -1, -1}, {966, -1, -1, -1}, {967, -1, -1, -1}, {968, -1, -1, -1}, {969, -1, -1, -1}, {1040, -1, -1, -1}, {1041, -1, -1, -1}, {1042, -1, -1, -1}, {1043, -1, -1, -1}, {1044, -1, -1, -1}, {1045, -1, -1, -1}, {1025, -1, -1, -1}, {1046, -1, -1, -1}, {1047, -1, -1, -1}, {1048, -1, -1, -1}, {1049, -1, -1, -1}, {1050, -1, -1, -1}, {1051, -1, -1, -1}, {1052, -1, -1, -1}, {1053, -1, -1, -1}, {1054, -1, -1, -1}, {1055, -1, -1, -1}, {1056, -1, -1, -1}, {1057, -1, -1, -1}, {1058, -1, -1, -1}, {1059, -1, -1, -1}, {1060, -1, -1, -1}, {1061, -1, -1, -1}, {1062, -1, -1, -1}, {1063, -1, -1, -1}, {1064, -1, -1, -1}, {1065, -1, -1, -1}, {1066, -1, -1, -1}, {1067, -1, -1, -1}, {1068, -1, -1, -1}, {1069, -1, -1, -1}, {1070, -1, -1, -1}, {1071, -1, -1, -1}, {1072, -1, -1, -1}, {1073, -1, -1, -1}, {1074, -1, -1, -1}, {1075, -1, -1, -1}, {1076, -1, -1, -1}, {1077, -1, -1, -1}, {1105, -1, -1, -1}, {1078, -1, -1, -1}, {1079, -1, -1, -1}, {1080, -1, -1, -1}, {1081, -1, -1, -1}, {1082, -1, -1, -1}, {1083, -1, -1, -1}, {1084, -1, -1, -1}, {1085, -1, -1, -1}, {1086, -1, -1, -1}, {1087, -1, -1, -1}, {1088, -1, -1, -1}, {1089, -1, -1, -1}, {1090, -1, -1, -1}, {1091, -1, -1, -1}, {1092, -1, -1, -1}, {1093, -1, -1, -1}, {1094, -1, -1, -1}, {1095, -1, -1, -1}, {1096, -1, -1, -1}, {1097, -1, -1, -1}, {1098, -1, -1, -1}, {1099, -1, -1, -1}, {1100, -1, -1, -1}, {1101, -1, -1, -1}, {1102, -1, -1, -1}, {1103, -1, -1, -1}, {20124, -1, -1, -1}, {21782, -1, -1, -1}, {23043, -1, -1, -1}, {38463, -1, -1, -1}, {21696, -1, -1, -1}, {24859, -1, -1, -1}, {25384, -1, -1, -1}, {23030, -1, -1, -1}, {36898, -1, -1, -1}, {33909, -1, -1, -1}, {33564, -1, -1, -1}, {31312, -1, -1, -1}, {24746, -1, -1, -1}, {25569, -1, -1, -1}, {28197, -1, -1, -1}, {26093, -1, -1, -1}, {33894, -1, -1, -1}, {33446, -1, -1, -1}, {39925, -1, -1, -1}, {26771, -1, -1, -1}, {22311, -1, -1, -1}, {26017, -1, -1, -1}, {25201, -1, -1, -1}, {23451, -1, -1, -1}, {22992, -1, -1, -1}, {34427, -1, -1, -1}, {39156, -1, -1, -1}, {32098, -1, -1, -1}, {32190, -1, -1, -1}, {39822, -1, -1, -1}, {25110, -1, -1, -1}, {31903, -1, -1, -1}, {34999, -1, -1, -1}, {23433, -1, -1, -1}, {24245, -1, -1, -1}, {25353, -1, -1, -1}, {26263, -1, -1, -1}, {26696, -1, -1, -1}, {38343, -1, -1, -1}, {38797, -1, -1, -1}, {26447, -1, -1, -1}, {20197, -1, -1, -1}, {20234, -1, -1, -1}, {20301, -1, -1, -1}, {20381, -1, -1, -1}, {20553, -1, -1, -1}, {22258, -1, -1, -1}, {22839, -1, -1, -1}, {22996, -1, -1, -1}, {23041, -1, -1, -1}, {23561, -1, -1, -1}, {24799, -1, -1, -1}, {24847, -1, -1, -1}, {24944, -1, -1, -1}, {26131, -1, -1, -1}, {26885, -1, -1, -1}, {28858, -1, -1, -1}, {30031, -1, -1, -1}, {30064, -1, -1, -1}, {31227, -1, -1, -1}, {32173, -1, -1, -1}, {32239, -1, -1, -1}, {32963, -1, -1, -1}, {33806, -1, -1, -1}, {12176, 34915, -1, -1}, {35586, -1, -1, -1}, {36949, -1, -1, -1}, {36986, -1, -1, -1}, {21307, -1, -1, -1}, {20117, -1, -1, -1}, {20133, -1, -1, -1}, {22495, -1, -1, -1}, {32946, -1, -1, -1}, {37057, -1, -1, -1}, {30959, -1, -1, -1}, {12032, 19968, -1, -1}, {22769, -1, -1, -1}, {28322, -1, -1, -1}, {36920, -1, -1, -1}, {31282, -1, -1, -1}, {33576, -1, -1, -1}, {33419, -1, -1, -1}, {39983, -1, -1, -1}, {20801, -1, -1, -1}, {21360, -1, -1, -1}, {21693, -1, -1, -1}, {21729, -1, -1, -1}, {22240, -1, -1, -1}, {23035, -1, -1, -1}, {24341, -1, -1, -1}, {39154, -1, -1, -1}, {28139, -1, -1, -1}, {32996, -1, -1, -1}, {34093, -1, -1, -1}, {38498, -1, -1, -1}, {38512, -1, -1, -1}, {38560, -1, -1, -1}, {38907, -1, -1, -1}, {21515, -1, -1, -1}, {21491, -1, -1, -1}, {23431, -1, -1, -1}, {28879, -1, -1, -1}, {12155, 32701, -1, -1}, {36802, -1, -1, -1}, {12204, 38632, -1, -1}, {21359, -1, -1, -1}, {40284, -1, -1, -1}, {31418, -1, -1, -1}, {19985, -1, -1, -1}, {30867, -1, -1, -1}, {12165, 33276, -1, -1}, {28198, -1, -1, -1}, {22040, -1, -1, -1}, {21764, -1, -1, -1}, {27421, -1, -1, -1}, {34074, -1, -1, -1}, {39995, -1, -1, -1}, {23013, -1, -1, -1}, {21417, -1, -1, -1}, {28006, -1, -1, -1}, {12128, 29916, -1, -1}, {38287, -1, -1, -1}, {22082, -1, -1, -1}, {20113, -1, -1, -1}, {36939, -1, -1, -1}, {38642, -1, -1, -1}, {33615, -1, -1, -1}, {39180, -1, -1, -1}, {21473, -1, -1, -1}, {21942, -1, -1, -1}, {23344, -1, -1, -1}, {24433, -1, -1, -1}, {26144, -1, -1, -1}, {26355, -1, -1, -1}, {26628, -1, -1, -1}, {27704, -1, -1, -1}, {27891, -1, -1, -1}, {27945, -1, -1, -1}, {29787, -1, -1, -1}, {30408, -1, -1, -1}, {31310, -1, -1, -1}, {38964, -1, -1, -1}, {33521, -1, -1, -1}, {34907, -1, -1, -1}, {35424, -1, -1, -1}, {37613, -1, -1, -1}, {28082, -1, -1, -1}, {30123, -1, -1, -1}, {30410, -1, -1, -1}, {39365, -1, -1, -1}, {24742, -1, -1, -1}, {35585, -1, -1, -1}, {36234, -1, -1, -1}, {38322, -1, -1, -1}, {27022, -1, -1, -1} },
+ {{21421, -1, -1, -1}, {20870, -1, -1, -1}, {22290, -1, -1, -1}, {22576, -1, -1, -1}, {22852, -1, -1, -1}, {23476, -1, -1, -1}, {24310, -1, -1, -1}, {24616, -1, -1, -1}, {25513, -1, -1, -1}, {25588, -1, -1, -1}, {27839, -1, -1, -1}, {28436, -1, -1, -1}, {28814, -1, -1, -1}, {28948, -1, -1, -1}, {29017, -1, -1, -1}, {29141, -1, -1, -1}, {29503, -1, -1, -1}, {32257, -1, -1, -1}, {33398, -1, -1, -1}, {33489, -1, -1, -1}, {34199, -1, -1, -1}, {36960, -1, -1, -1}, {37467, -1, -1, -1}, {40219, -1, -1, -1}, {22633, -1, -1, -1}, {26044, -1, -1, -1}, {27738, -1, -1, -1}, {29989, -1, -1, -1}, {20985, -1, -1, -1}, {22830, -1, -1, -1}, {22885, -1, -1, -1}, {24448, -1, -1, -1}, {24540, -1, -1, -1}, {25276, -1, -1, -1}, {26106, -1, -1, -1}, {27178, -1, -1, -1}, {27431, -1, -1, -1}, {27572, -1, -1, -1}, {29579, -1, -1, -1}, {32705, -1, -1, -1}, {35158, -1, -1, -1}, {40236, -1, -1, -1}, {40206, -1, -1, -1}, {12009, 40644, -1, -1}, {23713, -1, -1, -1}, {27798, -1, -1, -1}, {33659, -1, -1, -1}, {20740, -1, -1, -1}, {23627, -1, -1, -1}, {25014, -1, -1, -1}, {33222, -1, -1, -1}, {26742, -1, -1, -1}, {29281, -1, -1, -1}, {12036, 20057, -1, -1}, {20474, -1, -1, -1}, {21368, -1, -1, -1}, {24681, -1, -1, -1}, {28201, -1, -1, -1}, {31311, -1, -1, -1}, {12211, 38899, -1, -1}, {19979, -1, -1, -1}, {21270, -1, -1, -1}, {20206, -1, -1, -1}, {20309, -1, -1, -1}, {20285, -1, -1, -1}, {20385, -1, -1, -1}, {20339, -1, -1, -1}, {21152, -1, -1, -1}, {21487, -1, -1, -1}, {22025, -1, -1, -1}, {22799, -1, -1, -1}, {23233, -1, -1, -1}, {23478, -1, -1, -1}, {23521, -1, -1, -1}, {31185, -1, -1, -1}, {26247, -1, -1, -1}, {26524, -1, -1, -1}, {26550, -1, -1, -1}, {27468, -1, -1, -1}, {27827, -1, -1, -1}, {12117, 28779, -1, -1}, {29634, -1, -1, -1}, {31117, -1, -1, -1}, {12146, 31166, -1, -1}, {31292, -1, -1, -1}, {31623, -1, -1, -1}, {33457, -1, -1, -1}, {33499, -1, -1, -1}, {33540, -1, -1, -1}, {33655, -1, -1, -1}, {33775, -1, -1, -1}, {33747, -1, -1, -1}, {34662, -1, -1, -1}, {35506, -1, -1, -1}, {22057, -1, -1, -1}, {36008, -1, -1, -1}, {36838, -1, -1, -1}, {36942, -1, -1, -1}, {38686, -1, -1, -1}, {34442, -1, -1, -1}, {20420, -1, -1, -1}, {23784, -1, -1, -1}, {25105, -1, -1, -1}, {12123, 29273, -1, -1}, {30011, -1, -1, -1}, {33253, -1, -1, -1}, {33469, -1, -1, -1}, {34558, -1, -1, -1}, {36032, -1, -1, -1}, {38597, -1, -1, -1}, {39187, -1, -1, -1}, {39381, -1, -1, -1}, {20171, -1, -1, -1}, {20250, -1, -1, -1}, {35299, -1, -1, -1}, {22238, -1, -1, -1}, {22602, -1, -1, -1}, {22730, -1, -1, -1}, {24315, -1, -1, -1}, {24555, -1, -1, -1}, {24618, -1, -1, -1}, {24724, -1, -1, -1}, {24674, -1, -1, -1}, {25040, -1, -1, -1}, {25106, -1, -1, -1}, {25296, -1, -1, -1}, {25913, -1, -1, -1}, {39745, -1, -1, -1}, {26214, -1, -1, -1}, {26800, -1, -1, -1}, {28023, -1, -1, -1}, {28784, -1, -1, -1}, {30028, -1, -1, -1}, {30342, -1, -1, -1}, {32117, -1, -1, -1}, {33445, -1, -1, -1}, {34809, -1, -1, -1}, {38283, -1, -1, -1}, {38542, -1, -1, -1}, {12185, 35997, -1, -1}, {20977, -1, -1, -1}, {21182, -1, -1, -1}, {22806, -1, -1, -1}, {21683, -1, -1, -1}, {23475, -1, -1, -1}, {23830, -1, -1, -1}, {24936, -1, -1, -1}, {27010, -1, -1, -1}, {28079, -1, -1, -1}, {30861, -1, -1, -1}, {33995, -1, -1, -1}, {34903, -1, -1, -1}, {35442, -1, -1, -1}, {37799, -1, -1, -1}, {39608, -1, -1, -1}, {28012, -1, -1, -1}, {39336, -1, -1, -1}, {34521, -1, -1, -1}, {22435, -1, -1, -1}, {26623, -1, -1, -1}, {34510, -1, -1, -1}, {37390, -1, -1, -1}, {21123, -1, -1, -1}, {22151, -1, -1, -1}, {21508, -1, -1, -1}, {24275, -1, -1, -1}, {25313, -1, -1, -1}, {25785, -1, -1, -1}, {26684, -1, -1, -1}, {26680, -1, -1, -1}, {27579, -1, -1, -1}, {29554, -1, -1, -1}, {30906, -1, -1, -1}, {31339, -1, -1, -1}, {35226, -1, -1, -1}, {12179, 35282, -1, -1}, {36203, -1, -1, -1}, {36611, -1, -1, -1}, {37101, -1, -1, -1}, {38307, -1, -1, -1}, {38548, -1, -1, -1}, {12208, 38761, -1, -1}, {23398, -1, -1, -1}, {23731, -1, -1, -1}, {27005, -1, -1, -1}, {38989, -1, -1, -1}, {38990, -1, -1, -1}, {25499, -1, -1, -1}, {31520, -1, -1, -1}, {27179, -1, -1, -1}, {27263, -1, -1, -1}, {26806, -1, -1, -1}, {39949, -1, -1, -1}, {28511, -1, -1, -1}, {21106, -1, -1, -1}, {21917, -1, -1, -1}, {24688, -1, -1, -1}, {25324, -1, -1, -1}, {27963, -1, -1, -1}, {28167, -1, -1, -1}, {28369, -1, -1, -1}, {33883, -1, -1, -1}, {35088, -1, -1, -1}, {36676, -1, -1, -1}, {19988, -1, -1, -1}, {39993, -1, -1, -1}, {21494, -1, -1, -1}, {26907, -1, -1, -1}, {27194, -1, -1, -1}, {38788, -1, -1, -1}, {26666, -1, -1, -1}, {20828, -1, -1, -1}, {31427, -1, -1, -1}, {33970, -1, -1, -1}, {37340, -1, -1, -1}, {37772, -1, -1, -1}, {22107, -1, -1, -1}, {40232, -1, -1, -1}, {26658, -1, -1, -1}, {33541, -1, -1, -1}, {33841, -1, -1, -1}, {31909, -1, -1, -1}, {21000, -1, -1, -1}, {33477, -1, -1, -1}, {12129, 29926, -1, -1}, {20094, -1, -1, -1}, {20355, -1, -1, -1}, {20896, -1, -1, -1}, {23506, -1, -1, -1}, {21002, -1, -1, -1}, {21208, -1, -1, -1}, {21223, -1, -1, -1}, {24059, -1, -1, -1}, {21914, -1, -1, -1}, {22570, -1, -1, -1}, {23014, -1, -1, -1}, {23436, -1, -1, -1}, {23448, -1, -1, -1}, {23515, -1, -1, -1}, {12082, 24178, -1, -1}, {24185, -1, -1, -1}, {24739, -1, -1, -1}, {24863, -1, -1, -1}, {24931, -1, -1, -1}, {25022, -1, -1, -1}, {25563, -1, -1, -1}, {25954, -1, -1, -1}, {26577, -1, -1, -1}, {26707, -1, -1, -1}, {26874, -1, -1, -1}, {27454, -1, -1, -1}, {27475, -1, -1, -1}, {27735, -1, -1, -1}, {28450, -1, -1, -1}, {28567, -1, -1, -1}, {28485, -1, -1, -1} },
+ {{29872, -1, -1, -1}, {12130, 29976, -1, -1}, {30435, -1, -1, -1}, {30475, -1, -1, -1}, {31487, -1, -1, -1}, {31649, -1, -1, -1}, {31777, -1, -1, -1}, {32233, -1, -1, -1}, {12152, 32566, -1, -1}, {32752, -1, -1, -1}, {32925, -1, -1, -1}, {33382, -1, -1, -1}, {33694, -1, -1, -1}, {35251, -1, -1, -1}, {35532, -1, -1, -1}, {36011, -1, -1, -1}, {36996, -1, -1, -1}, {37969, -1, -1, -1}, {38291, -1, -1, -1}, {38289, -1, -1, -1}, {38306, -1, -1, -1}, {38501, -1, -1, -1}, {38867, -1, -1, -1}, {39208, -1, -1, -1}, {33304, -1, -1, -1}, {20024, -1, -1, -1}, {21547, -1, -1, -1}, {23736, -1, -1, -1}, {24012, -1, -1, -1}, {29609, -1, -1, -1}, {30284, -1, -1, -1}, {30524, -1, -1, -1}, {23721, -1, -1, -1}, {32747, -1, -1, -1}, {36107, -1, -1, -1}, {38593, -1, -1, -1}, {38929, -1, -1, -1}, {38996, -1, -1, -1}, {39000, -1, -1, -1}, {20225, -1, -1, -1}, {20238, -1, -1, -1}, {21361, -1, -1, -1}, {21916, -1, -1, -1}, {22120, -1, -1, -1}, {22522, -1, -1, -1}, {22855, -1, -1, -1}, {23305, -1, -1, -1}, {23492, -1, -1, -1}, {23696, -1, -1, -1}, {24076, -1, -1, -1}, {24190, -1, -1, -1}, {24524, -1, -1, -1}, {25582, -1, -1, -1}, {26426, -1, -1, -1}, {26071, -1, -1, -1}, {26082, -1, -1, -1}, {26399, -1, -1, -1}, {26827, -1, -1, -1}, {26820, -1, -1, -1}, {27231, -1, -1, -1}, {24112, -1, -1, -1}, {27589, -1, -1, -1}, {27671, -1, -1, -1}, {27773, -1, -1, -1}, {30079, -1, -1, -1}, {31048, -1, -1, -1}, {23395, -1, -1, -1}, {31232, -1, -1, -1}, {32000, -1, -1, -1}, {24509, -1, -1, -1}, {35215, -1, -1, -1}, {35352, -1, -1, -1}, {36020, -1, -1, -1}, {36215, -1, -1, -1}, {36556, -1, -1, -1}, {36637, -1, -1, -1}, {39138, -1, -1, -1}, {39438, -1, -1, -1}, {12004, 12225, 39740, -1}, {12018, 20096, -1, -1}, {20605, -1, -1, -1}, {20736, -1, -1, -1}, {22931, -1, -1, -1}, {23452, -1, -1, -1}, {25135, -1, -1, -1}, {25216, -1, -1, -1}, {25836, -1, -1, -1}, {27450, -1, -1, -1}, {29344, -1, -1, -1}, {30097, -1, -1, -1}, {31047, -1, -1, -1}, {32681, -1, -1, -1}, {34811, -1, -1, -1}, {35516, -1, -1, -1}, {35696, -1, -1, -1}, {25516, -1, -1, -1}, {33738, -1, -1, -1}, {38816, -1, -1, -1}, {21513, -1, -1, -1}, {21507, -1, -1, -1}, {21931, -1, -1, -1}, {26708, -1, -1, -1}, {27224, -1, -1, -1}, {35440, -1, -1, -1}, {30759, -1, -1, -1}, {26485, -1, -1, -1}, {12233, 40653, -1, -1}, {21364, -1, -1, -1}, {23458, -1, -1, -1}, {33050, -1, -1, -1}, {34384, -1, -1, -1}, {36870, -1, -1, -1}, {19992, -1, -1, -1}, {20037, -1, -1, -1}, {20167, -1, -1, -1}, {20241, -1, -1, -1}, {21450, -1, -1, -1}, {21560, -1, -1, -1}, {23470, -1, -1, -1}, {12088, 24339, -1, -1}, {24613, -1, -1, -1}, {25937, -1, -1, -1}, {26429, -1, -1, -1}, {27714, -1, -1, -1}, {27762, -1, -1, -1}, {27875, -1, -1, -1}, {28792, -1, -1, -1}, {29699, -1, -1, -1}, {31350, -1, -1, -1}, {31406, -1, -1, -1}, {31496, -1, -1, -1}, {32026, -1, -1, -1}, {31998, -1, -1, -1}, {32102, -1, -1, -1}, {26087, -1, -1, -1}, {12124, 29275, -1, -1}, {21435, -1, -1, -1}, {23621, -1, -1, -1}, {24040, -1, -1, -1}, {25298, -1, -1, -1}, {25312, -1, -1, -1}, {25369, -1, -1, -1}, {28192, -1, -1, -1}, {34394, -1, -1, -1}, {35377, -1, -1, -1}, {36317, -1, -1, -1}, {37624, -1, -1, -1}, {28417, -1, -1, -1}, {31142, -1, -1, -1}, {12226, 39770, -1, -1}, {20136, -1, -1, -1}, {20139, -1, -1, -1}, {20140, -1, -1, -1}, {20379, -1, -1, -1}, {20384, -1, -1, -1}, {20689, -1, -1, -1}, {20807, -1, -1, -1}, {31478, -1, -1, -1}, {20849, -1, -1, -1}, {20982, -1, -1, -1}, {21332, -1, -1, -1}, {21281, -1, -1, -1}, {21375, -1, -1, -1}, {21483, -1, -1, -1}, {21932, -1, -1, -1}, {22659, -1, -1, -1}, {23777, -1, -1, -1}, {24375, -1, -1, -1}, {24394, -1, -1, -1}, {24623, -1, -1, -1}, {24656, -1, -1, -1}, {24685, -1, -1, -1}, {25375, -1, -1, -1}, {25945, -1, -1, -1}, {27211, -1, -1, -1}, {27841, -1, -1, -1}, {29378, -1, -1, -1}, {29421, -1, -1, -1}, {30703, -1, -1, -1}, {33016, -1, -1, -1}, {33029, -1, -1, -1}, {33288, -1, -1, -1}, {34126, -1, -1, -1}, {37111, -1, -1, -1}, {37857, -1, -1, -1}, {38911, -1, -1, -1}, {39255, -1, -1, -1}, {39514, -1, -1, -1}, {20208, -1, -1, -1}, {20957, -1, -1, -1}, {23597, -1, -1, -1}, {26241, -1, -1, -1}, {26989, -1, -1, -1}, {23616, -1, -1, -1}, {26354, -1, -1, -1}, {26997, -1, -1, -1}, {12127, 29577, -1, -1}, {26704, -1, -1, -1}, {31873, -1, -1, -1}, {20677, -1, -1, -1}, {21220, -1, -1, -1}, {22343, -1, -1, -1}, {12081, 24062, -1, -1}, {37670, -1, -1, -1}, {12100, 26020, -1, -1}, {27427, -1, -1, -1}, {27453, -1, -1, -1}, {29748, -1, -1, -1}, {31105, -1, -1, -1}, {31165, -1, -1, -1}, {31563, -1, -1, -1}, {32202, -1, -1, -1}, {33465, -1, -1, -1}, {33740, -1, -1, -1}, {34943, -1, -1, -1}, {35167, -1, -1, -1}, {35641, -1, -1, -1}, {36817, -1, -1, -1}, {12198, 37329, -1, -1}, {21535, -1, -1, -1}, {37504, -1, -1, -1}, {20061, -1, -1, -1}, {20534, -1, -1, -1}, {21477, -1, -1, -1}, {21306, -1, -1, -1}, {29399, -1, -1, -1}, {29590, -1, -1, -1}, {30697, -1, -1, -1}, {33510, -1, -1, -1}, {36527, -1, -1, -1}, {39366, -1, -1, -1}, {39368, -1, -1, -1}, {39378, -1, -1, -1}, {20855, -1, -1, -1}, {24858, -1, -1, -1}, {34398, -1, -1, -1}, {21936, -1, -1, -1}, {31354, -1, -1, -1}, {20598, -1, -1, -1}, {23507, -1, -1, -1}, {36935, -1, -1, -1}, {38533, -1, -1, -1}, {20018, -1, -1, -1}, {27355, -1, -1, -1}, {37351, -1, -1, -1}, {23633, -1, -1, -1}, {23624, -1, -1, -1}, {25496, -1, -1, -1}, {31391, -1, -1, -1}, {27795, -1, -1, -1}, {38772, -1, -1, -1}, {36705, -1, -1, -1}, {31402, -1, -1, -1}, {29066, -1, -1, -1}, {38536, -1, -1, -1}, {31874, -1, -1, -1} },
+ {{26647, -1, -1, -1}, {32368, -1, -1, -1}, {26705, -1, -1, -1}, {37740, -1, -1, -1}, {21234, -1, -1, -1}, {21531, -1, -1, -1}, {34219, -1, -1, -1}, {35347, -1, -1, -1}, {32676, -1, -1, -1}, {36557, -1, -1, -1}, {37089, -1, -1, -1}, {21350, -1, -1, -1}, {34952, -1, -1, -1}, {31041, -1, -1, -1}, {20418, -1, -1, -1}, {20670, -1, -1, -1}, {21009, -1, -1, -1}, {20804, -1, -1, -1}, {21843, -1, -1, -1}, {22317, -1, -1, -1}, {29674, -1, -1, -1}, {22411, -1, -1, -1}, {22865, -1, -1, -1}, {24418, -1, -1, -1}, {24452, -1, -1, -1}, {24693, -1, -1, -1}, {24950, -1, -1, -1}, {24935, -1, -1, -1}, {25001, -1, -1, -1}, {25522, -1, -1, -1}, {25658, -1, -1, -1}, {25964, -1, -1, -1}, {26223, -1, -1, -1}, {26690, -1, -1, -1}, {28179, -1, -1, -1}, {30054, -1, -1, -1}, {31293, -1, -1, -1}, {31995, -1, -1, -1}, {32076, -1, -1, -1}, {32153, -1, -1, -1}, {32331, -1, -1, -1}, {32619, -1, -1, -1}, {33550, -1, -1, -1}, {33610, -1, -1, -1}, {34509, -1, -1, -1}, {35336, -1, -1, -1}, {35427, -1, -1, -1}, {35686, -1, -1, -1}, {36605, -1, -1, -1}, {38938, -1, -1, -1}, {40335, -1, -1, -1}, {33464, -1, -1, -1}, {36814, -1, -1, -1}, {39912, -1, -1, -1}, {21127, -1, -1, -1}, {25119, -1, -1, -1}, {25731, -1, -1, -1}, {28608, -1, -1, -1}, {38553, -1, -1, -1}, {26689, -1, -1, -1}, {20625, -1, -1, -1}, {12107, 27424, -1, -1}, {27770, -1, -1, -1}, {28500, -1, -1, -1}, {12147, 31348, -1, -1}, {32080, -1, -1, -1}, {12174, 34880, -1, -1}, {35363, -1, -1, -1}, {12105, 26376, -1, -1}, {20214, -1, -1, -1}, {20537, -1, -1, -1}, {20518, -1, -1, -1}, {20581, -1, -1, -1}, {20860, -1, -1, -1}, {21048, -1, -1, -1}, {21091, -1, -1, -1}, {21927, -1, -1, -1}, {22287, -1, -1, -1}, {22533, -1, -1, -1}, {23244, -1, -1, -1}, {24314, -1, -1, -1}, {25010, -1, -1, -1}, {25080, -1, -1, -1}, {25331, -1, -1, -1}, {25458, -1, -1, -1}, {26908, -1, -1, -1}, {27177, -1, -1, -1}, {29309, -1, -1, -1}, {12125, 29356, -1, -1}, {29486, -1, -1, -1}, {30740, -1, -1, -1}, {30831, -1, -1, -1}, {32121, -1, -1, -1}, {30476, -1, -1, -1}, {32937, -1, -1, -1}, {12178, 35211, -1, -1}, {35609, -1, -1, -1}, {36066, -1, -1, -1}, {36562, -1, -1, -1}, {36963, -1, -1, -1}, {37749, -1, -1, -1}, {38522, -1, -1, -1}, {38997, -1, -1, -1}, {39443, -1, -1, -1}, {40568, -1, -1, -1}, {20803, -1, -1, -1}, {21407, -1, -1, -1}, {21427, -1, -1, -1}, {24187, -1, -1, -1}, {24358, -1, -1, -1}, {28187, -1, -1, -1}, {28304, -1, -1, -1}, {12126, 29572, -1, -1}, {29694, -1, -1, -1}, {32067, -1, -1, -1}, {33335, -1, -1, -1}, {12180, 35328, -1, -1}, {35578, -1, -1, -1}, {38480, -1, -1, -1}, {20046, -1, -1, -1}, {20491, -1, -1, -1}, {21476, -1, -1, -1}, {21628, -1, -1, -1}, {22266, -1, -1, -1}, {22993, -1, -1, -1}, {23396, -1, -1, -1}, {12080, 24049, -1, -1}, {24235, -1, -1, -1}, {24359, -1, -1, -1}, {12094, 25144, -1, -1}, {25925, -1, -1, -1}, {26543, -1, -1, -1}, {28246, -1, -1, -1}, {29392, -1, -1, -1}, {31946, -1, -1, -1}, {34996, -1, -1, -1}, {32929, -1, -1, -1}, {32993, -1, -1, -1}, {33776, -1, -1, -1}, {11969, 34382, -1, -1}, {35463, -1, -1, -1}, {36328, -1, -1, -1}, {37431, -1, -1, -1}, {38599, -1, -1, -1}, {39015, -1, -1, -1}, {12238, 40723, -1, -1}, {20116, -1, -1, -1}, {20114, -1, -1, -1}, {20237, -1, -1, -1}, {21320, -1, -1, -1}, {21577, -1, -1, -1}, {21566, -1, -1, -1}, {23087, -1, -1, -1}, {24460, -1, -1, -1}, {24481, -1, -1, -1}, {24735, -1, -1, -1}, {26791, -1, -1, -1}, {27278, -1, -1, -1}, {29786, -1, -1, -1}, {30849, -1, -1, -1}, {35486, -1, -1, -1}, {35492, -1, -1, -1}, {35703, -1, -1, -1}, {37264, -1, -1, -1}, {20062, -1, -1, -1}, {39881, -1, -1, -1}, {20132, -1, -1, -1}, {20348, -1, -1, -1}, {20399, -1, -1, -1}, {20505, -1, -1, -1}, {20502, -1, -1, -1}, {20809, -1, -1, -1}, {20844, -1, -1, -1}, {21151, -1, -1, -1}, {21177, -1, -1, -1}, {21246, -1, -1, -1}, {21402, -1, -1, -1}, {12061, 21475, -1, -1}, {21521, -1, -1, -1}, {21518, -1, -1, -1}, {21897, -1, -1, -1}, {22353, -1, -1, -1}, {22434, -1, -1, -1}, {22909, -1, -1, -1}, {23380, -1, -1, -1}, {23389, -1, -1, -1}, {23439, -1, -1, -1}, {12079, 24037, -1, -1}, {24039, -1, -1, -1}, {24055, -1, -1, -1}, {24184, -1, -1, -1}, {24195, -1, -1, -1}, {24218, -1, -1, -1}, {24247, -1, -1, -1}, {24344, -1, -1, -1}, {24658, -1, -1, -1}, {24908, -1, -1, -1}, {25239, -1, -1, -1}, {25304, -1, -1, -1}, {25511, -1, -1, -1}, {25915, -1, -1, -1}, {26114, -1, -1, -1}, {26179, -1, -1, -1}, {26356, -1, -1, -1}, {26477, -1, -1, -1}, {26657, -1, -1, -1}, {26775, -1, -1, -1}, {27083, -1, -1, -1}, {27743, -1, -1, -1}, {27946, -1, -1, -1}, {28009, -1, -1, -1}, {28207, -1, -1, -1}, {28317, -1, -1, -1}, {30002, -1, -1, -1}, {30343, -1, -1, -1}, {30828, -1, -1, -1}, {31295, -1, -1, -1}, {31968, -1, -1, -1}, {32005, -1, -1, -1}, {32024, -1, -1, -1}, {32094, -1, -1, -1}, {32177, -1, -1, -1}, {32789, -1, -1, -1}, {32771, -1, -1, -1}, {32943, -1, -1, -1}, {32945, -1, -1, -1}, {33108, -1, -1, -1}, {33167, -1, -1, -1}, {33322, -1, -1, -1}, {33618, -1, -1, -1}, {12175, 34892, -1, -1}, {34913, -1, -1, -1}, {35611, -1, -1, -1}, {36002, -1, -1, -1}, {36092, -1, -1, -1}, {37066, -1, -1, -1}, {37237, -1, -1, -1}, {37489, -1, -1, -1}, {30783, -1, -1, -1}, {37628, -1, -1, -1}, {38308, -1, -1, -1}, {38477, -1, -1, -1}, {38917, -1, -1, -1}, {12217, 39321, -1, -1}, {12220, 39640, -1, -1}, {40251, -1, -1, -1}, {21083, -1, -1, -1}, {21163, -1, -1, -1}, {21495, -1, -1, -1}, {21512, -1, -1, -1}, {22741, -1, -1, -1}, {25335, -1, -1, -1}, {28640, -1, -1, -1}, {35946, -1, -1, -1}, {36703, -1, -1, -1}, {40633, -1, -1, -1} },
+ {{20811, -1, -1, -1}, {21051, -1, -1, -1}, {21578, -1, -1, -1}, {22269, -1, -1, -1}, {31296, -1, -1, -1}, {37239, -1, -1, -1}, {40288, -1, -1, -1}, {12234, 40658, -1, -1}, {29508, -1, -1, -1}, {28425, -1, -1, -1}, {33136, -1, -1, -1}, {29969, -1, -1, -1}, {24573, -1, -1, -1}, {24794, -1, -1, -1}, {12219, 39592, -1, -1}, {29403, -1, -1, -1}, {36796, -1, -1, -1}, {27492, -1, -1, -1}, {38915, -1, -1, -1}, {20170, -1, -1, -1}, {22256, -1, -1, -1}, {22372, -1, -1, -1}, {22718, -1, -1, -1}, {23130, -1, -1, -1}, {24680, -1, -1, -1}, {25031, -1, -1, -1}, {26127, -1, -1, -1}, {26118, -1, -1, -1}, {26681, -1, -1, -1}, {26801, -1, -1, -1}, {28151, -1, -1, -1}, {30165, -1, -1, -1}, {32058, -1, -1, -1}, {12169, 33390, -1, -1}, {39746, -1, -1, -1}, {20123, -1, -1, -1}, {20304, -1, -1, -1}, {21449, -1, -1, -1}, {21766, -1, -1, -1}, {23919, -1, -1, -1}, {24038, -1, -1, -1}, {24046, -1, -1, -1}, {26619, -1, -1, -1}, {27801, -1, -1, -1}, {29811, -1, -1, -1}, {30722, -1, -1, -1}, {35408, -1, -1, -1}, {37782, -1, -1, -1}, {35039, -1, -1, -1}, {22352, -1, -1, -1}, {24231, -1, -1, -1}, {25387, -1, -1, -1}, {20661, -1, -1, -1}, {20652, -1, -1, -1}, {20877, -1, -1, -1}, {26368, -1, -1, -1}, {21705, -1, -1, -1}, {22622, -1, -1, -1}, {22971, -1, -1, -1}, {23472, -1, -1, -1}, {24425, -1, -1, -1}, {25165, -1, -1, -1}, {25505, -1, -1, -1}, {26685, -1, -1, -1}, {27507, -1, -1, -1}, {28168, -1, -1, -1}, {28797, -1, -1, -1}, {37319, -1, -1, -1}, {29312, -1, -1, -1}, {30741, -1, -1, -1}, {30758, -1, -1, -1}, {31085, -1, -1, -1}, {25998, -1, -1, -1}, {32048, -1, -1, -1}, {33756, -1, -1, -1}, {35009, -1, -1, -1}, {36617, -1, -1, -1}, {38555, -1, -1, -1}, {21092, -1, -1, -1}, {22312, -1, -1, -1}, {26448, -1, -1, -1}, {32618, -1, -1, -1}, {36001, -1, -1, -1}, {20916, -1, -1, -1}, {22338, -1, -1, -1}, {38442, -1, -1, -1}, {22586, -1, -1, -1}, {27018, -1, -1, -1}, {32948, -1, -1, -1}, {21682, -1, -1, -1}, {23822, -1, -1, -1}, {22524, -1, -1, -1}, {30869, -1, -1, -1}, {40442, -1, -1, -1}, {20316, -1, -1, -1}, {21066, -1, -1, -1}, {21643, -1, -1, -1}, {25662, -1, -1, -1}, {26152, -1, -1, -1}, {26388, -1, -1, -1}, {26613, -1, -1, -1}, {31364, -1, -1, -1}, {31574, -1, -1, -1}, {32034, -1, -1, -1}, {37679, -1, -1, -1}, {26716, -1, -1, -1}, {39853, -1, -1, -1}, {31545, -1, -1, -1}, {21273, -1, -1, -1}, {20874, -1, -1, -1}, {21047, -1, -1, -1}, {23519, -1, -1, -1}, {25334, -1, -1, -1}, {25774, -1, -1, -1}, {25830, -1, -1, -1}, {26413, -1, -1, -1}, {27578, -1, -1, -1}, {34217, -1, -1, -1}, {38609, -1, -1, -1}, {30352, -1, -1, -1}, {39894, -1, -1, -1}, {25420, -1, -1, -1}, {37638, -1, -1, -1}, {39851, -1, -1, -1}, {12139, 30399, -1, -1}, {26194, -1, -1, -1}, {19977, -1, -1, -1}, {20632, -1, -1, -1}, {21442, -1, -1, -1}, {12077, 23665, -1, -1}, {24808, -1, -1, -1}, {25746, -1, -1, -1}, {25955, -1, -1, -1}, {26719, -1, -1, -1}, {29158, -1, -1, -1}, {29642, -1, -1, -1}, {29987, -1, -1, -1}, {31639, -1, -1, -1}, {32386, -1, -1, -1}, {34453, -1, -1, -1}, {35715, -1, -1, -1}, {36059, -1, -1, -1}, {37240, -1, -1, -1}, {39184, -1, -1, -1}, {26028, -1, -1, -1}, {26283, -1, -1, -1}, {27531, -1, -1, -1}, {20181, -1, -1, -1}, {20180, -1, -1, -1}, {20282, -1, -1, -1}, {20351, -1, -1, -1}, {21050, -1, -1, -1}, {21496, -1, -1, -1}, {21490, -1, -1, -1}, {21987, -1, -1, -1}, {22235, -1, -1, -1}, {12064, 22763, -1, -1}, {22987, -1, -1, -1}, {22985, -1, -1, -1}, {23039, -1, -1, -1}, {12070, 23376, -1, -1}, {23629, -1, -1, -1}, {24066, -1, -1, -1}, {24107, -1, -1, -1}, {24535, -1, -1, -1}, {24605, -1, -1, -1}, {25351, -1, -1, -1}, {12096, 25903, -1, -1}, {23388, -1, -1, -1}, {26031, -1, -1, -1}, {26045, -1, -1, -1}, {26088, -1, -1, -1}, {26525, -1, -1, -1}, {12108, 27490, -1, -1}, {27515, -1, -1, -1}, {12114, 27663, -1, -1}, {29509, -1, -1, -1}, {31049, -1, -1, -1}, {31169, -1, -1, -1}, {12151, 31992, -1, -1}, {32025, -1, -1, -1}, {32043, -1, -1, -1}, {32930, -1, -1, -1}, {33026, -1, -1, -1}, {12164, 33267, -1, -1}, {35222, -1, -1, -1}, {35422, -1, -1, -1}, {35433, -1, -1, -1}, {35430, -1, -1, -1}, {35468, -1, -1, -1}, {35566, -1, -1, -1}, {36039, -1, -1, -1}, {36060, -1, -1, -1}, {38604, -1, -1, -1}, {39164, -1, -1, -1}, {12013, 27503, -1, -1}, {20107, -1, -1, -1}, {20284, -1, -1, -1}, {20365, -1, -1, -1}, {20816, -1, -1, -1}, {23383, -1, -1, -1}, {23546, -1, -1, -1}, {24904, -1, -1, -1}, {25345, -1, -1, -1}, {26178, -1, -1, -1}, {27425, -1, -1, -1}, {28363, -1, -1, -1}, {27835, -1, -1, -1}, {29246, -1, -1, -1}, {29885, -1, -1, -1}, {30164, -1, -1, -1}, {30913, -1, -1, -1}, {11948, 12144, 31034, -1}, {12157, 32780, -1, -1}, {12159, 32819, -1, -1}, {12163, 33258, -1, -1}, {33940, -1, -1, -1}, {36766, -1, -1, -1}, {27728, -1, -1, -1}, {12229, 40575, -1, -1}, {24335, -1, -1, -1}, {35672, -1, -1, -1}, {40235, -1, -1, -1}, {31482, -1, -1, -1}, {36600, -1, -1, -1}, {23437, -1, -1, -1}, {38635, -1, -1, -1}, {19971, -1, -1, -1}, {21489, -1, -1, -1}, {22519, -1, -1, -1}, {22833, -1, -1, -1}, {23241, -1, -1, -1}, {23460, -1, -1, -1}, {24713, -1, -1, -1}, {28287, -1, -1, -1}, {28422, -1, -1, -1}, {30142, -1, -1, -1}, {36074, -1, -1, -1}, {23455, -1, -1, -1}, {34048, -1, -1, -1}, {31712, -1, -1, -1}, {20594, -1, -1, -1}, {26612, -1, -1, -1}, {33437, -1, -1, -1}, {23649, -1, -1, -1}, {34122, -1, -1, -1}, {32286, -1, -1, -1}, {33294, -1, -1, -1}, {20889, -1, -1, -1}, {23556, -1, -1, -1}, {25448, -1, -1, -1}, {36198, -1, -1, -1}, {26012, -1, -1, -1}, {29038, -1, -1, -1}, {31038, -1, -1, -1}, {32023, -1, -1, -1} },
+ {{32773, -1, -1, -1}, {35613, -1, -1, -1}, {12190, 36554, -1, -1}, {36974, -1, -1, -1}, {34503, -1, -1, -1}, {37034, -1, -1, -1}, {20511, -1, -1, -1}, {21242, -1, -1, -1}, {23610, -1, -1, -1}, {26451, -1, -1, -1}, {28796, -1, -1, -1}, {29237, -1, -1, -1}, {37196, -1, -1, -1}, {37320, -1, -1, -1}, {37675, -1, -1, -1}, {33509, -1, -1, -1}, {23490, -1, -1, -1}, {24369, -1, -1, -1}, {24825, -1, -1, -1}, {20027, -1, -1, -1}, {21462, -1, -1, -1}, {23432, -1, -1, -1}, {12095, 25163, -1, -1}, {26417, -1, -1, -1}, {27530, -1, -1, -1}, {29417, -1, -1, -1}, {29664, -1, -1, -1}, {31278, -1, -1, -1}, {33131, -1, -1, -1}, {36259, -1, -1, -1}, {37202, -1, -1, -1}, {12216, 39318, -1, -1}, {20754, -1, -1, -1}, {21463, -1, -1, -1}, {21610, -1, -1, -1}, {23551, -1, -1, -1}, {25480, -1, -1, -1}, {27193, -1, -1, -1}, {32172, -1, -1, -1}, {38656, -1, -1, -1}, {22234, -1, -1, -1}, {21454, -1, -1, -1}, {21608, -1, -1, -1}, {23447, -1, -1, -1}, {23601, -1, -1, -1}, {24030, -1, -1, -1}, {20462, -1, -1, -1}, {24833, -1, -1, -1}, {25342, -1, -1, -1}, {27954, -1, -1, -1}, {31168, -1, -1, -1}, {31179, -1, -1, -1}, {32066, -1, -1, -1}, {32333, -1, -1, -1}, {32722, -1, -1, -1}, {33261, -1, -1, -1}, {12168, 33311, -1, -1}, {33936, -1, -1, -1}, {34886, -1, -1, -1}, {35186, -1, -1, -1}, {35728, -1, -1, -1}, {36468, -1, -1, -1}, {36655, -1, -1, -1}, {36913, -1, -1, -1}, {37195, -1, -1, -1}, {37228, -1, -1, -1}, {38598, -1, -1, -1}, {37276, -1, -1, -1}, {20160, -1, -1, -1}, {20303, -1, -1, -1}, {20805, -1, -1, -1}, {12055, 21313, -1, -1}, {24467, -1, -1, -1}, {25102, -1, -1, -1}, {26580, -1, -1, -1}, {27713, -1, -1, -1}, {28171, -1, -1, -1}, {29539, -1, -1, -1}, {32294, -1, -1, -1}, {37325, -1, -1, -1}, {37507, -1, -1, -1}, {21460, -1, -1, -1}, {22809, -1, -1, -1}, {23487, -1, -1, -1}, {28113, -1, -1, -1}, {31069, -1, -1, -1}, {32302, -1, -1, -1}, {31899, -1, -1, -1}, {22654, -1, -1, -1}, {29087, -1, -1, -1}, {20986, -1, -1, -1}, {34899, -1, -1, -1}, {36848, -1, -1, -1}, {20426, -1, -1, -1}, {23803, -1, -1, -1}, {26149, -1, -1, -1}, {30636, -1, -1, -1}, {31459, -1, -1, -1}, {33308, -1, -1, -1}, {39423, -1, -1, -1}, {20934, -1, -1, -1}, {24490, -1, -1, -1}, {26092, -1, -1, -1}, {26991, -1, -1, -1}, {27529, -1, -1, -1}, {28147, -1, -1, -1}, {28310, -1, -1, -1}, {28516, -1, -1, -1}, {30462, -1, -1, -1}, {32020, -1, -1, -1}, {24033, -1, -1, -1}, {36981, -1, -1, -1}, {37255, -1, -1, -1}, {38918, -1, -1, -1}, {20966, -1, -1, -1}, {21021, -1, -1, -1}, {25152, -1, -1, -1}, {26257, -1, -1, -1}, {26329, -1, -1, -1}, {28186, -1, -1, -1}, {24246, -1, -1, -1}, {32210, -1, -1, -1}, {32626, -1, -1, -1}, {26360, -1, -1, -1}, {34223, -1, -1, -1}, {34295, -1, -1, -1}, {35576, -1, -1, -1}, {21161, -1, -1, -1}, {21465, -1, -1, -1}, {12069, 22899, -1, -1}, {24207, -1, -1, -1}, {24464, -1, -1, -1}, {24661, -1, -1, -1}, {37604, -1, -1, -1}, {38500, -1, -1, -1}, {20663, -1, -1, -1}, {20767, -1, -1, -1}, {21213, -1, -1, -1}, {21280, -1, -1, -1}, {21319, -1, -1, -1}, {21484, -1, -1, -1}, {21736, -1, -1, -1}, {21830, -1, -1, -1}, {21809, -1, -1, -1}, {22039, -1, -1, -1}, {22888, -1, -1, -1}, {22974, -1, -1, -1}, {23100, -1, -1, -1}, {23477, -1, -1, -1}, {23558, -1, -1, -1}, {12073, 23567, -1, -1}, {23569, -1, -1, -1}, {23578, -1, -1, -1}, {24196, -1, -1, -1}, {24202, -1, -1, -1}, {24288, -1, -1, -1}, {24432, -1, -1, -1}, {25215, -1, -1, -1}, {25220, -1, -1, -1}, {25307, -1, -1, -1}, {25484, -1, -1, -1}, {25463, -1, -1, -1}, {26119, -1, -1, -1}, {26124, -1, -1, -1}, {26157, -1, -1, -1}, {26230, -1, -1, -1}, {26494, -1, -1, -1}, {26786, -1, -1, -1}, {27167, -1, -1, -1}, {27189, -1, -1, -1}, {27836, -1, -1, -1}, {28040, -1, -1, -1}, {28169, -1, -1, -1}, {28248, -1, -1, -1}, {28988, -1, -1, -1}, {28966, -1, -1, -1}, {29031, -1, -1, -1}, {30151, -1, -1, -1}, {30465, -1, -1, -1}, {30813, -1, -1, -1}, {30977, -1, -1, -1}, {31077, -1, -1, -1}, {31216, -1, -1, -1}, {31456, -1, -1, -1}, {31505, -1, -1, -1}, {31911, -1, -1, -1}, {32057, -1, -1, -1}, {32918, -1, -1, -1}, {33750, -1, -1, -1}, {33931, -1, -1, -1}, {34121, -1, -1, -1}, {34909, -1, -1, -1}, {35059, -1, -1, -1}, {35359, -1, -1, -1}, {35388, -1, -1, -1}, {35412, -1, -1, -1}, {35443, -1, -1, -1}, {35937, -1, -1, -1}, {36062, -1, -1, -1}, {37284, -1, -1, -1}, {37478, -1, -1, -1}, {37758, -1, -1, -1}, {37912, -1, -1, -1}, {38556, -1, -1, -1}, {38808, -1, -1, -1}, {19978, -1, -1, -1}, {19976, -1, -1, -1}, {19998, -1, -1, -1}, {20055, -1, -1, -1}, {20887, -1, -1, -1}, {21104, -1, -1, -1}, {22478, -1, -1, -1}, {22580, -1, -1, -1}, {22732, -1, -1, -1}, {23330, -1, -1, -1}, {24120, -1, -1, -1}, {24773, -1, -1, -1}, {25854, -1, -1, -1}, {26465, -1, -1, -1}, {26454, -1, -1, -1}, {27972, -1, -1, -1}, {29366, -1, -1, -1}, {30067, -1, -1, -1}, {31331, -1, -1, -1}, {33976, -1, -1, -1}, {35698, -1, -1, -1}, {37304, -1, -1, -1}, {37664, -1, -1, -1}, {22065, -1, -1, -1}, {22516, -1, -1, -1}, {39166, -1, -1, -1}, {25325, -1, -1, -1}, {26893, -1, -1, -1}, {27542, -1, -1, -1}, {29165, -1, -1, -1}, {32340, -1, -1, -1}, {32887, -1, -1, -1}, {12170, 33394, -1, -1}, {35302, -1, -1, -1}, {12215, 39135, -1, -1}, {34645, -1, -1, -1}, {36785, -1, -1, -1}, {23611, -1, -1, -1}, {20280, -1, -1, -1}, {20449, -1, -1, -1}, {20405, -1, -1, -1}, {21767, -1, -1, -1}, {23072, -1, -1, -1}, {23517, -1, -1, -1}, {23529, -1, -1, -1}, {12092, 24515, -1, -1}, {24910, -1, -1, -1}, {25391, -1, -1, -1}, {26032, -1, -1, -1}, {26187, -1, -1, -1}, {26862, -1, -1, -1} },
+ {{27035, -1, -1, -1}, {28024, -1, -1, -1}, {28145, -1, -1, -1}, {30003, -1, -1, -1}, {30137, -1, -1, -1}, {30495, -1, -1, -1}, {31070, -1, -1, -1}, {31206, -1, -1, -1}, {32051, -1, -1, -1}, {12162, 33251, -1, -1}, {33455, -1, -1, -1}, {34218, -1, -1, -1}, {35242, -1, -1, -1}, {35386, -1, -1, -1}, {12189, 36523, -1, -1}, {12191, 36763, -1, -1}, {36914, -1, -1, -1}, {37341, -1, -1, -1}, {38663, -1, -1, -1}, {12040, 20154, -1, -1}, {20161, -1, -1, -1}, {20995, -1, -1, -1}, {22645, -1, -1, -1}, {22764, -1, -1, -1}, {23563, -1, -1, -1}, {29978, -1, -1, -1}, {23613, -1, -1, -1}, {33102, -1, -1, -1}, {35338, -1, -1, -1}, {36805, -1, -1, -1}, {38499, -1, -1, -1}, {38765, -1, -1, -1}, {31525, -1, -1, -1}, {35535, -1, -1, -1}, {38920, -1, -1, -1}, {37218, -1, -1, -1}, {22259, -1, -1, -1}, {21416, -1, -1, -1}, {36887, -1, -1, -1}, {21561, -1, -1, -1}, {22402, -1, -1, -1}, {24101, -1, -1, -1}, {25512, -1, -1, -1}, {12116, 27700, -1, -1}, {28810, -1, -1, -1}, {30561, -1, -1, -1}, {31883, -1, -1, -1}, {32736, -1, -1, -1}, {34928, -1, -1, -1}, {36930, -1, -1, -1}, {37204, -1, -1, -1}, {37648, -1, -1, -1}, {37656, -1, -1, -1}, {38543, -1, -1, -1}, {29790, -1, -1, -1}, {39620, -1, -1, -1}, {23815, -1, -1, -1}, {23913, -1, -1, -1}, {25968, -1, -1, -1}, {26530, -1, -1, -1}, {36264, -1, -1, -1}, {38619, -1, -1, -1}, {25454, -1, -1, -1}, {26441, -1, -1, -1}, {26905, -1, -1, -1}, {33733, -1, -1, -1}, {38935, -1, -1, -1}, {38592, -1, -1, -1}, {35070, -1, -1, -1}, {28548, -1, -1, -1}, {25722, -1, -1, -1}, {12072, 23544, -1, -1}, {19990, -1, -1, -1}, {28716, -1, -1, -1}, {30045, -1, -1, -1}, {26159, -1, -1, -1}, {20932, -1, -1, -1}, {21046, -1, -1, -1}, {21218, -1, -1, -1}, {22995, -1, -1, -1}, {24449, -1, -1, -1}, {24615, -1, -1, -1}, {25104, -1, -1, -1}, {25919, -1, -1, -1}, {25972, -1, -1, -1}, {26143, -1, -1, -1}, {26228, -1, -1, -1}, {26866, -1, -1, -1}, {26646, -1, -1, -1}, {27491, -1, -1, -1}, {28165, -1, -1, -1}, {29298, -1, -1, -1}, {12131, 29983, -1, -1}, {30427, -1, -1, -1}, {31934, -1, -1, -1}, {32854, -1, -1, -1}, {22768, -1, -1, -1}, {35069, -1, -1, -1}, {11972, 35199, -1, -1}, {35488, -1, -1, -1}, {35475, -1, -1, -1}, {35531, -1, -1, -1}, {36893, -1, -1, -1}, {37266, -1, -1, -1}, {11992, 38738, -1, -1}, {38745, -1, -1, -1}, {12011, 25993, -1, -1}, {31246, -1, -1, -1}, {33030, -1, -1, -1}, {38587, -1, -1, -1}, {24109, -1, -1, -1}, {24796, -1, -1, -1}, {25114, -1, -1, -1}, {26021, -1, -1, -1}, {26132, -1, -1, -1}, {26512, -1, -1, -1}, {12143, 30707, -1, -1}, {31309, -1, -1, -1}, {31821, -1, -1, -1}, {32318, -1, -1, -1}, {33034, -1, -1, -1}, {36012, -1, -1, -1}, {12186, 36196, -1, -1}, {36321, -1, -1, -1}, {36447, -1, -1, -1}, {30889, -1, -1, -1}, {20999, -1, -1, -1}, {25305, -1, -1, -1}, {25509, -1, -1, -1}, {25666, -1, -1, -1}, {25240, -1, -1, -1}, {35373, -1, -1, -1}, {31363, -1, -1, -1}, {31680, -1, -1, -1}, {35500, -1, -1, -1}, {38634, -1, -1, -1}, {32118, -1, -1, -1}, {12166, 33292, -1, -1}, {34633, -1, -1, -1}, {20185, -1, -1, -1}, {20808, -1, -1, -1}, {21315, -1, -1, -1}, {21344, -1, -1, -1}, {23459, -1, -1, -1}, {23554, -1, -1, -1}, {23574, -1, -1, -1}, {24029, -1, -1, -1}, {25126, -1, -1, -1}, {25159, -1, -1, -1}, {25776, -1, -1, -1}, {26643, -1, -1, -1}, {26676, -1, -1, -1}, {27849, -1, -1, -1}, {27973, -1, -1, -1}, {27927, -1, -1, -1}, {26579, -1, -1, -1}, {28508, -1, -1, -1}, {29006, -1, -1, -1}, {29053, -1, -1, -1}, {26059, -1, -1, -1}, {31359, -1, -1, -1}, {31661, -1, -1, -1}, {32218, -1, -1, -1}, {32330, -1, -1, -1}, {32680, -1, -1, -1}, {33146, -1, -1, -1}, {12167, 33307, -1, -1}, {33337, -1, -1, -1}, {34214, -1, -1, -1}, {35438, -1, -1, -1}, {36046, -1, -1, -1}, {36341, -1, -1, -1}, {36984, -1, -1, -1}, {36983, -1, -1, -1}, {37549, -1, -1, -1}, {37521, -1, -1, -1}, {38275, -1, -1, -1}, {39854, -1, -1, -1}, {21069, -1, -1, -1}, {21892, -1, -1, -1}, {28472, -1, -1, -1}, {28982, -1, -1, -1}, {20840, -1, -1, -1}, {31109, -1, -1, -1}, {32341, -1, -1, -1}, {33203, -1, -1, -1}, {31950, -1, -1, -1}, {22092, -1, -1, -1}, {22609, -1, -1, -1}, {23720, -1, -1, -1}, {25514, -1, -1, -1}, {26366, -1, -1, -1}, {26365, -1, -1, -1}, {26970, -1, -1, -1}, {29401, -1, -1, -1}, {30095, -1, -1, -1}, {30094, -1, -1, -1}, {30990, -1, -1, -1}, {31062, -1, -1, -1}, {31199, -1, -1, -1}, {31895, -1, -1, -1}, {32032, -1, -1, -1}, {32068, -1, -1, -1}, {34311, -1, -1, -1}, {35380, -1, -1, -1}, {38459, -1, -1, -1}, {36961, -1, -1, -1}, {12239, 40736, -1, -1}, {20711, -1, -1, -1}, {21109, -1, -1, -1}, {21452, -1, -1, -1}, {21474, -1, -1, -1}, {20489, -1, -1, -1}, {21930, -1, -1, -1}, {22766, -1, -1, -1}, {22863, -1, -1, -1}, {29245, -1, -1, -1}, {23435, -1, -1, -1}, {23652, -1, -1, -1}, {21277, -1, -1, -1}, {24803, -1, -1, -1}, {24819, -1, -1, -1}, {25436, -1, -1, -1}, {25475, -1, -1, -1}, {25407, -1, -1, -1}, {25531, -1, -1, -1}, {25805, -1, -1, -1}, {26089, -1, -1, -1}, {26361, -1, -1, -1}, {24035, -1, -1, -1}, {27085, -1, -1, -1}, {27133, -1, -1, -1}, {28437, -1, -1, -1}, {29157, -1, -1, -1}, {20105, -1, -1, -1}, {30185, -1, -1, -1}, {30456, -1, -1, -1}, {31379, -1, -1, -1}, {31967, -1, -1, -1}, {32207, -1, -1, -1}, {32156, -1, -1, -1}, {32865, -1, -1, -1}, {33609, -1, -1, -1}, {33624, -1, -1, -1}, {33900, -1, -1, -1}, {33980, -1, -1, -1}, {34299, -1, -1, -1}, {35013, -1, -1, -1}, {12187, 36208, -1, -1}, {36865, -1, -1, -1}, {36973, -1, -1, -1}, {37783, -1, -1, -1}, {38684, -1, -1, -1}, {39442, -1, -1, -1}, {20687, -1, -1, -1}, {22679, -1, -1, -1} },
+ {{24974, -1, -1, -1}, {33235, -1, -1, -1}, {34101, -1, -1, -1}, {36104, -1, -1, -1}, {36896, -1, -1, -1}, {20419, -1, -1, -1}, {20596, -1, -1, -1}, {21063, -1, -1, -1}, {21363, -1, -1, -1}, {24687, -1, -1, -1}, {25417, -1, -1, -1}, {26463, -1, -1, -1}, {28204, -1, -1, -1}, {12188, 36275, -1, -1}, {36895, -1, -1, -1}, {20439, -1, -1, -1}, {23646, -1, -1, -1}, {36042, -1, -1, -1}, {26063, -1, -1, -1}, {32154, -1, -1, -1}, {21330, -1, -1, -1}, {34966, -1, -1, -1}, {20854, -1, -1, -1}, {25539, -1, -1, -1}, {23384, -1, -1, -1}, {23403, -1, -1, -1}, {23562, -1, -1, -1}, {25613, -1, -1, -1}, {26449, -1, -1, -1}, {36956, -1, -1, -1}, {20182, -1, -1, -1}, {22810, -1, -1, -1}, {22826, -1, -1, -1}, {27760, -1, -1, -1}, {35409, -1, -1, -1}, {21822, -1, -1, -1}, {22549, -1, -1, -1}, {22949, -1, -1, -1}, {24816, -1, -1, -1}, {25171, -1, -1, -1}, {26561, -1, -1, -1}, {33333, -1, -1, -1}, {26965, -1, -1, -1}, {38464, -1, -1, -1}, {39364, -1, -1, -1}, {39464, -1, -1, -1}, {20307, -1, -1, -1}, {22534, -1, -1, -1}, {23550, -1, -1, -1}, {32784, -1, -1, -1}, {23729, -1, -1, -1}, {24111, -1, -1, -1}, {24453, -1, -1, -1}, {24608, -1, -1, -1}, {24907, -1, -1, -1}, {25140, -1, -1, -1}, {26367, -1, -1, -1}, {27888, -1, -1, -1}, {28382, -1, -1, -1}, {32974, -1, -1, -1}, {33151, -1, -1, -1}, {33492, -1, -1, -1}, {34955, -1, -1, -1}, {36024, -1, -1, -1}, {36864, -1, -1, -1}, {36910, -1, -1, -1}, {38538, -1, -1, -1}, {40667, -1, -1, -1}, {39899, -1, -1, -1}, {20195, -1, -1, -1}, {21488, -1, -1, -1}, {12068, 22823, -1, -1}, {31532, -1, -1, -1}, {37261, -1, -1, -1}, {38988, -1, -1, -1}, {40441, -1, -1, -1}, {28381, -1, -1, -1}, {28711, -1, -1, -1}, {21331, -1, -1, -1}, {21828, -1, -1, -1}, {23429, -1, -1, -1}, {25176, -1, -1, -1}, {25246, -1, -1, -1}, {25299, -1, -1, -1}, {27810, -1, -1, -1}, {28655, -1, -1, -1}, {29730, -1, -1, -1}, {35351, -1, -1, -1}, {37944, -1, -1, -1}, {28609, -1, -1, -1}, {35582, -1, -1, -1}, {33592, -1, -1, -1}, {20967, -1, -1, -1}, {34552, -1, -1, -1}, {21482, -1, -1, -1}, {21481, -1, -1, -1}, {20294, -1, -1, -1}, {36948, -1, -1, -1}, {12192, 36784, -1, -1}, {22890, -1, -1, -1}, {33073, -1, -1, -1}, {24061, -1, -1, -1}, {31466, -1, -1, -1}, {36799, -1, -1, -1}, {26842, -1, -1, -1}, {12181, 35895, -1, -1}, {29432, -1, -1, -1}, {40008, -1, -1, -1}, {27197, -1, -1, -1}, {35504, -1, -1, -1}, {20025, -1, -1, -1}, {21336, -1, -1, -1}, {22022, -1, -1, -1}, {22374, -1, -1, -1}, {25285, -1, -1, -1}, {25506, -1, -1, -1}, {26086, -1, -1, -1}, {27470, -1, -1, -1}, {28129, -1, -1, -1}, {28251, -1, -1, -1}, {28845, -1, -1, -1}, {30701, -1, -1, -1}, {31471, -1, -1, -1}, {31658, -1, -1, -1}, {32187, -1, -1, -1}, {32829, -1, -1, -1}, {32966, -1, -1, -1}, {34507, -1, -1, -1}, {35477, -1, -1, -1}, {37723, -1, -1, -1}, {22243, -1, -1, -1}, {22727, -1, -1, -1}, {24382, -1, -1, -1}, {26029, -1, -1, -1}, {26262, -1, -1, -1}, {27264, -1, -1, -1}, {27573, -1, -1, -1}, {30007, -1, -1, -1}, {35527, -1, -1, -1}, {20516, -1, -1, -1}, {30693, -1, -1, -1}, {22320, -1, -1, -1}, {24347, -1, -1, -1}, {24677, -1, -1, -1}, {26234, -1, -1, -1}, {27744, -1, -1, -1}, {30196, -1, -1, -1}, {31258, -1, -1, -1}, {32622, -1, -1, -1}, {33268, -1, -1, -1}, {34584, -1, -1, -1}, {36933, -1, -1, -1}, {39347, -1, -1, -1}, {31689, -1, -1, -1}, {30044, -1, -1, -1}, {12149, 31481, -1, -1}, {31569, -1, -1, -1}, {33988, -1, -1, -1}, {36880, -1, -1, -1}, {31209, -1, -1, -1}, {31378, -1, -1, -1}, {33590, -1, -1, -1}, {23265, -1, -1, -1}, {30528, -1, -1, -1}, {20013, -1, -1, -1}, {20210, -1, -1, -1}, {23449, -1, -1, -1}, {24544, -1, -1, -1}, {25277, -1, -1, -1}, {26172, -1, -1, -1}, {26609, -1, -1, -1}, {27880, -1, -1, -1}, {12173, 34411, -1, -1}, {34935, -1, -1, -1}, {35387, -1, -1, -1}, {37198, -1, -1, -1}, {37619, -1, -1, -1}, {39376, -1, -1, -1}, {27159, -1, -1, -1}, {28710, -1, -1, -1}, {29482, -1, -1, -1}, {33511, -1, -1, -1}, {33879, -1, -1, -1}, {36015, -1, -1, -1}, {19969, -1, -1, -1}, {20806, -1, -1, -1}, {20939, -1, -1, -1}, {21899, -1, -1, -1}, {23541, -1, -1, -1}, {24086, -1, -1, -1}, {24115, -1, -1, -1}, {24193, -1, -1, -1}, {24340, -1, -1, -1}, {24373, -1, -1, -1}, {24427, -1, -1, -1}, {24500, -1, -1, -1}, {25074, -1, -1, -1}, {25361, -1, -1, -1}, {26274, -1, -1, -1}, {26397, -1, -1, -1}, {28526, -1, -1, -1}, {29266, -1, -1, -1}, {30010, -1, -1, -1}, {30522, -1, -1, -1}, {32884, -1, -1, -1}, {33081, -1, -1, -1}, {33144, -1, -1, -1}, {34678, -1, -1, -1}, {35519, -1, -1, -1}, {35548, -1, -1, -1}, {36229, -1, -1, -1}, {36339, -1, -1, -1}, {37530, -1, -1, -1}, {11985, 12199, 38263, -1}, {38914, -1, -1, -1}, {12227, 40165, -1, -1}, {21189, -1, -1, -1}, {25431, -1, -1, -1}, {30452, -1, -1, -1}, {26389, -1, -1, -1}, {27784, -1, -1, -1}, {29645, -1, -1, -1}, {36035, -1, -1, -1}, {37806, -1, -1, -1}, {38515, -1, -1, -1}, {27941, -1, -1, -1}, {22684, -1, -1, -1}, {26894, -1, -1, -1}, {27084, -1, -1, -1}, {36861, -1, -1, -1}, {37786, -1, -1, -1}, {30171, -1, -1, -1}, {36890, -1, -1, -1}, {22618, -1, -1, -1}, {26626, -1, -1, -1}, {25524, -1, -1, -1}, {27131, -1, -1, -1}, {20291, -1, -1, -1}, {28460, -1, -1, -1}, {26584, -1, -1, -1}, {36795, -1, -1, -1}, {34086, -1, -1, -1}, {32180, -1, -1, -1}, {37716, -1, -1, -1}, {26943, -1, -1, -1}, {28528, -1, -1, -1}, {22378, -1, -1, -1}, {22775, -1, -1, -1}, {23340, -1, -1, -1}, {32044, -1, -1, -1}, {12118, 29226, -1, -1}, {21514, -1, -1, -1}, {37347, -1, -1, -1}, {40372, -1, -1, -1}, {20141, -1, -1, -1}, {20302, -1, -1, -1} },
+ {{20572, -1, -1, -1}, {20597, -1, -1, -1}, {21059, -1, -1, -1}, {35998, -1, -1, -1}, {21576, -1, -1, -1}, {22564, -1, -1, -1}, {23450, -1, -1, -1}, {24093, -1, -1, -1}, {24213, -1, -1, -1}, {24237, -1, -1, -1}, {24311, -1, -1, -1}, {24351, -1, -1, -1}, {24716, -1, -1, -1}, {25269, -1, -1, -1}, {25402, -1, -1, -1}, {25552, -1, -1, -1}, {26799, -1, -1, -1}, {27712, -1, -1, -1}, {30855, -1, -1, -1}, {31118, -1, -1, -1}, {31243, -1, -1, -1}, {32224, -1, -1, -1}, {33351, -1, -1, -1}, {35330, -1, -1, -1}, {35558, -1, -1, -1}, {36420, -1, -1, -1}, {36883, -1, -1, -1}, {37048, -1, -1, -1}, {37165, -1, -1, -1}, {37336, -1, -1, -1}, {12237, 40718, -1, -1}, {27877, -1, -1, -1}, {25688, -1, -1, -1}, {25826, -1, -1, -1}, {25973, -1, -1, -1}, {28404, -1, -1, -1}, {30340, -1, -1, -1}, {31515, -1, -1, -1}, {36969, -1, -1, -1}, {37841, -1, -1, -1}, {28346, -1, -1, -1}, {21746, -1, -1, -1}, {24505, -1, -1, -1}, {25764, -1, -1, -1}, {36685, -1, -1, -1}, {36845, -1, -1, -1}, {37444, -1, -1, -1}, {20856, -1, -1, -1}, {22635, -1, -1, -1}, {22825, -1, -1, -1}, {23637, -1, -1, -1}, {24215, -1, -1, -1}, {28155, -1, -1, -1}, {32399, -1, -1, -1}, {29980, -1, -1, -1}, {36028, -1, -1, -1}, {36578, -1, -1, -1}, {39003, -1, -1, -1}, {28857, -1, -1, -1}, {20253, -1, -1, -1}, {27583, -1, -1, -1}, {28593, -1, -1, -1}, {12133, 30000, -1, -1}, {38651, -1, -1, -1}, {20814, -1, -1, -1}, {21520, -1, -1, -1}, {22581, -1, -1, -1}, {22615, -1, -1, -1}, {22956, -1, -1, -1}, {23648, -1, -1, -1}, {24466, -1, -1, -1}, {12099, 26007, -1, -1}, {26460, -1, -1, -1}, {28193, -1, -1, -1}, {30331, -1, -1, -1}, {33759, -1, -1, -1}, {36077, -1, -1, -1}, {36884, -1, -1, -1}, {37117, -1, -1, -1}, {37709, -1, -1, -1}, {30757, -1, -1, -1}, {30778, -1, -1, -1}, {21162, -1, -1, -1}, {24230, -1, -1, -1}, {12063, 22303, -1, -1}, {22900, -1, -1, -1}, {24594, -1, -1, -1}, {20498, -1, -1, -1}, {20826, -1, -1, -1}, {20908, -1, -1, -1}, {20941, -1, -1, -1}, {12049, 20992, -1, -1}, {21776, -1, -1, -1}, {22612, -1, -1, -1}, {22616, -1, -1, -1}, {22871, -1, -1, -1}, {23445, -1, -1, -1}, {23798, -1, -1, -1}, {23947, -1, -1, -1}, {24764, -1, -1, -1}, {25237, -1, -1, -1}, {25645, -1, -1, -1}, {26481, -1, -1, -1}, {26691, -1, -1, -1}, {26812, -1, -1, -1}, {26847, -1, -1, -1}, {30423, -1, -1, -1}, {28120, -1, -1, -1}, {28271, -1, -1, -1}, {28059, -1, -1, -1}, {28783, -1, -1, -1}, {29128, -1, -1, -1}, {24403, -1, -1, -1}, {30168, -1, -1, -1}, {31095, -1, -1, -1}, {31561, -1, -1, -1}, {31572, -1, -1, -1}, {31570, -1, -1, -1}, {31958, -1, -1, -1}, {32113, -1, -1, -1}, {21040, -1, -1, -1}, {33891, -1, -1, -1}, {34153, -1, -1, -1}, {34276, -1, -1, -1}, {35342, -1, -1, -1}, {35588, -1, -1, -1}, {12182, 35910, -1, -1}, {36367, -1, -1, -1}, {36867, -1, -1, -1}, {36879, -1, -1, -1}, {37913, -1, -1, -1}, {38518, -1, -1, -1}, {38957, -1, -1, -1}, {39472, -1, -1, -1}, {38360, -1, -1, -1}, {20685, -1, -1, -1}, {21205, -1, -1, -1}, {21516, -1, -1, -1}, {22530, -1, -1, -1}, {23566, -1, -1, -1}, {24999, -1, -1, -1}, {25758, -1, -1, -1}, {27934, -1, -1, -1}, {30643, -1, -1, -1}, {31461, -1, -1, -1}, {33012, -1, -1, -1}, {33796, -1, -1, -1}, {36947, -1, -1, -1}, {37509, -1, -1, -1}, {23776, -1, -1, -1}, {40199, -1, -1, -1}, {21311, -1, -1, -1}, {24471, -1, -1, -1}, {24499, -1, -1, -1}, {28060, -1, -1, -1}, {29305, -1, -1, -1}, {30563, -1, -1, -1}, {31167, -1, -1, -1}, {31716, -1, -1, -1}, {27602, -1, -1, -1}, {29420, -1, -1, -1}, {35501, -1, -1, -1}, {26627, -1, -1, -1}, {27233, -1, -1, -1}, {20984, -1, -1, -1}, {31361, -1, -1, -1}, {26932, -1, -1, -1}, {23626, -1, -1, -1}, {40182, -1, -1, -1}, {33515, -1, -1, -1}, {23493, -1, -1, -1}, {12195, 37193, -1, -1}, {28702, -1, -1, -1}, {22136, -1, -1, -1}, {23663, -1, -1, -1}, {24775, -1, -1, -1}, {25958, -1, -1, -1}, {27788, -1, -1, -1}, {35930, -1, -1, -1}, {36929, -1, -1, -1}, {38931, -1, -1, -1}, {21585, -1, -1, -1}, {26311, -1, -1, -1}, {37389, -1, -1, -1}, {22856, -1, -1, -1}, {37027, -1, -1, -1}, {20869, -1, -1, -1}, {20045, -1, -1, -1}, {20970, -1, -1, -1}, {34201, -1, -1, -1}, {35598, -1, -1, -1}, {28760, -1, -1, -1}, {25466, -1, -1, -1}, {37707, -1, -1, -1}, {26978, -1, -1, -1}, {39348, -1, -1, -1}, {32260, -1, -1, -1}, {30071, -1, -1, -1}, {21335, -1, -1, -1}, {26976, -1, -1, -1}, {36575, -1, -1, -1}, {38627, -1, -1, -1}, {27741, -1, -1, -1}, {12038, 20108, -1, -1}, {23612, -1, -1, -1}, {24336, -1, -1, -1}, {36841, -1, -1, -1}, {21250, -1, -1, -1}, {36049, -1, -1, -1}, {12161, 32905, -1, -1}, {34425, -1, -1, -1}, {24319, -1, -1, -1}, {12103, 26085, -1, -1}, {20083, -1, -1, -1}, {12042, 20837, -1, -1}, {22914, -1, -1, -1}, {23615, -1, -1, -1}, {38894, -1, -1, -1}, {20219, -1, -1, -1}, {22922, -1, -1, -1}, {24525, -1, -1, -1}, {35469, -1, -1, -1}, {28641, -1, -1, -1}, {31152, -1, -1, -1}, {31074, -1, -1, -1}, {23527, -1, -1, -1}, {33905, -1, -1, -1}, {29483, -1, -1, -1}, {29105, -1, -1, -1}, {24180, -1, -1, -1}, {24565, -1, -1, -1}, {25467, -1, -1, -1}, {25754, -1, -1, -1}, {29123, -1, -1, -1}, {31896, -1, -1, -1}, {20035, -1, -1, -1}, {24316, -1, -1, -1}, {20043, -1, -1, -1}, {22492, -1, -1, -1}, {22178, -1, -1, -1}, {24745, -1, -1, -1}, {28611, -1, -1, -1}, {32013, -1, -1, -1}, {33021, -1, -1, -1}, {33075, -1, -1, -1}, {33215, -1, -1, -1}, {36786, -1, -1, -1}, {35223, -1, -1, -1}, {34468, -1, -1, -1}, {24052, -1, -1, -1}, {25226, -1, -1, -1}, {25773, -1, -1, -1}, {35207, -1, -1, -1}, {26487, -1, -1, -1}, {27874, -1, -1, -1}, {27966, -1, -1, -1} },
+ {{29750, -1, -1, -1}, {30772, -1, -1, -1}, {23110, -1, -1, -1}, {32629, -1, -1, -1}, {33453, -1, -1, -1}, {12218, 39340, -1, -1}, {20467, -1, -1, -1}, {24259, -1, -1, -1}, {25309, -1, -1, -1}, {25490, -1, -1, -1}, {25943, -1, -1, -1}, {26479, -1, -1, -1}, {30403, -1, -1, -1}, {29260, -1, -1, -1}, {32972, -1, -1, -1}, {32954, -1, -1, -1}, {36649, -1, -1, -1}, {37197, -1, -1, -1}, {20493, -1, -1, -1}, {22521, -1, -1, -1}, {23186, -1, -1, -1}, {26757, -1, -1, -1}, {26995, -1, -1, -1}, {29028, -1, -1, -1}, {29437, -1, -1, -1}, {36023, -1, -1, -1}, {22770, -1, -1, -1}, {36064, -1, -1, -1}, {38506, -1, -1, -1}, {36889, -1, -1, -1}, {34687, -1, -1, -1}, {31204, -1, -1, -1}, {30695, -1, -1, -1}, {33833, -1, -1, -1}, {20271, -1, -1, -1}, {21093, -1, -1, -1}, {21338, -1, -1, -1}, {25293, -1, -1, -1}, {26575, -1, -1, -1}, {27850, -1, -1, -1}, {12137, 30333, -1, -1}, {31636, -1, -1, -1}, {31893, -1, -1, -1}, {33334, -1, -1, -1}, {34180, -1, -1, -1}, {36843, -1, -1, -1}, {26333, -1, -1, -1}, {28448, -1, -1, -1}, {29190, -1, -1, -1}, {32283, -1, -1, -1}, {33707, -1, -1, -1}, {39361, -1, -1, -1}, {12008, 40614, -1, -1}, {20989, -1, -1, -1}, {31665, -1, -1, -1}, {30834, -1, -1, -1}, {31672, -1, -1, -1}, {32903, -1, -1, -1}, {31560, -1, -1, -1}, {27368, -1, -1, -1}, {24161, -1, -1, -1}, {32908, -1, -1, -1}, {30033, -1, -1, -1}, {30048, -1, -1, -1}, {12043, 20843, -1, -1}, {37474, -1, -1, -1}, {28300, -1, -1, -1}, {30330, -1, -1, -1}, {37271, -1, -1, -1}, {39658, -1, -1, -1}, {20240, -1, -1, -1}, {32624, -1, -1, -1}, {25244, -1, -1, -1}, {31567, -1, -1, -1}, {38309, -1, -1, -1}, {40169, -1, -1, -1}, {22138, -1, -1, -1}, {22617, -1, -1, -1}, {34532, -1, -1, -1}, {38588, -1, -1, -1}, {20276, -1, -1, -1}, {21028, -1, -1, -1}, {21322, -1, -1, -1}, {21453, -1, -1, -1}, {21467, -1, -1, -1}, {24070, -1, -1, -1}, {25644, -1, -1, -1}, {26001, -1, -1, -1}, {26495, -1, -1, -1}, {27710, -1, -1, -1}, {27726, -1, -1, -1}, {29256, -1, -1, -1}, {29359, -1, -1, -1}, {29677, -1, -1, -1}, {30036, -1, -1, -1}, {32321, -1, -1, -1}, {33324, -1, -1, -1}, {34281, -1, -1, -1}, {36009, -1, -1, -1}, {31684, -1, -1, -1}, {12196, 37318, -1, -1}, {29033, -1, -1, -1}, {38930, -1, -1, -1}, {39151, -1, -1, -1}, {25405, -1, -1, -1}, {26217, -1, -1, -1}, {30058, -1, -1, -1}, {30436, -1, -1, -1}, {30928, -1, -1, -1}, {34115, -1, -1, -1}, {34542, -1, -1, -1}, {21290, -1, -1, -1}, {21329, -1, -1, -1}, {21542, -1, -1, -1}, {22915, -1, -1, -1}, {24199, -1, -1, -1}, {24444, -1, -1, -1}, {24754, -1, -1, -1}, {25161, -1, -1, -1}, {25209, -1, -1, -1}, {25259, -1, -1, -1}, {26000, -1, -1, -1}, {12112, 27604, -1, -1}, {27852, -1, -1, -1}, {30130, -1, -1, -1}, {12138, 30382, -1, -1}, {30865, -1, -1, -1}, {31192, -1, -1, -1}, {32203, -1, -1, -1}, {32631, -1, -1, -1}, {32933, -1, -1, -1}, {34987, -1, -1, -1}, {35513, -1, -1, -1}, {36027, -1, -1, -1}, {36991, -1, -1, -1}, {12206, 38750, -1, -1}, {12214, 39131, -1, -1}, {27147, -1, -1, -1}, {31800, -1, -1, -1}, {20633, -1, -1, -1}, {23614, -1, -1, -1}, {24494, -1, -1, -1}, {26503, -1, -1, -1}, {27608, -1, -1, -1}, {29749, -1, -1, -1}, {30473, -1, -1, -1}, {32654, -1, -1, -1}, {12240, 40763, -1, -1}, {26570, -1, -1, -1}, {31255, -1, -1, -1}, {21305, -1, -1, -1}, {12134, 30091, -1, -1}, {39661, -1, -1, -1}, {24422, -1, -1, -1}, {33181, -1, -1, -1}, {33777, -1, -1, -1}, {32920, -1, -1, -1}, {24380, -1, -1, -1}, {24517, -1, -1, -1}, {30050, -1, -1, -1}, {31558, -1, -1, -1}, {36924, -1, -1, -1}, {26727, -1, -1, -1}, {23019, -1, -1, -1}, {23195, -1, -1, -1}, {32016, -1, -1, -1}, {30334, -1, -1, -1}, {35628, -1, -1, -1}, {20469, -1, -1, -1}, {24426, -1, -1, -1}, {27161, -1, -1, -1}, {27703, -1, -1, -1}, {28418, -1, -1, -1}, {29922, -1, -1, -1}, {31080, -1, -1, -1}, {34920, -1, -1, -1}, {35413, -1, -1, -1}, {35961, -1, -1, -1}, {24287, -1, -1, -1}, {25551, -1, -1, -1}, {30149, -1, -1, -1}, {31186, -1, -1, -1}, {33495, -1, -1, -1}, {37672, -1, -1, -1}, {37618, -1, -1, -1}, {33948, -1, -1, -1}, {34541, -1, -1, -1}, {39981, -1, -1, -1}, {21697, -1, -1, -1}, {24428, -1, -1, -1}, {25996, -1, -1, -1}, {27996, -1, -1, -1}, {28693, -1, -1, -1}, {36007, -1, -1, -1}, {36051, -1, -1, -1}, {38971, -1, -1, -1}, {25935, -1, -1, -1}, {29942, -1, -1, -1}, {19981, -1, -1, -1}, {20184, -1, -1, -1}, {22496, -1, -1, -1}, {22827, -1, -1, -1}, {23142, -1, -1, -1}, {23500, -1, -1, -1}, {20904, -1, -1, -1}, {24067, -1, -1, -1}, {24220, -1, -1, -1}, {24598, -1, -1, -1}, {25206, -1, -1, -1}, {25975, -1, -1, -1}, {26023, -1, -1, -1}, {26222, -1, -1, -1}, {28014, -1, -1, -1}, {12119, 29238, -1, -1}, {31526, -1, -1, -1}, {33104, -1, -1, -1}, {33178, -1, -1, -1}, {33433, -1, -1, -1}, {35676, -1, -1, -1}, {36000, -1, -1, -1}, {36070, -1, -1, -1}, {36212, -1, -1, -1}, {12201, 38428, -1, -1}, {38468, -1, -1, -1}, {20398, -1, -1, -1}, {25771, -1, -1, -1}, {27494, -1, -1, -1}, {33310, -1, -1, -1}, {33889, -1, -1, -1}, {34154, -1, -1, -1}, {37096, -1, -1, -1}, {23553, -1, -1, -1}, {26963, -1, -1, -1}, {12213, 39080, -1, -1}, {33914, -1, -1, -1}, {34135, -1, -1, -1}, {20239, -1, -1, -1}, {21103, -1, -1, -1}, {24489, -1, -1, -1}, {24133, -1, -1, -1}, {26381, -1, -1, -1}, {31119, -1, -1, -1}, {33145, -1, -1, -1}, {35079, -1, -1, -1}, {35206, -1, -1, -1}, {28149, -1, -1, -1}, {24343, -1, -1, -1}, {25173, -1, -1, -1}, {27832, -1, -1, -1}, {20175, -1, -1, -1}, {29289, -1, -1, -1}, {39826, -1, -1, -1}, {20998, -1, -1, -1}, {21563, -1, -1, -1}, {22132, -1, -1, -1}, {22707, -1, -1, -1} },
+ {{24996, -1, -1, -1}, {25198, -1, -1, -1}, {28954, -1, -1, -1}, {22894, -1, -1, -1}, {31881, -1, -1, -1}, {31966, -1, -1, -1}, {32027, -1, -1, -1}, {38640, -1, -1, -1}, {12098, 25991, -1, -1}, {32862, -1, -1, -1}, {19993, -1, -1, -1}, {20341, -1, -1, -1}, {20853, -1, -1, -1}, {22592, -1, -1, -1}, {24163, -1, -1, -1}, {24179, -1, -1, -1}, {24330, -1, -1, -1}, {26564, -1, -1, -1}, {20006, -1, -1, -1}, {34109, -1, -1, -1}, {38281, -1, -1, -1}, {38491, -1, -1, -1}, {12150, 31859, -1, -1}, {12212, 38913, -1, -1}, {20731, -1, -1, -1}, {22721, -1, -1, -1}, {30294, -1, -1, -1}, {30887, -1, -1, -1}, {21029, -1, -1, -1}, {30629, -1, -1, -1}, {34065, -1, -1, -1}, {31622, -1, -1, -1}, {20559, -1, -1, -1}, {22793, -1, -1, -1}, {12122, 29255, -1, -1}, {31687, -1, -1, -1}, {32232, -1, -1, -1}, {36794, -1, -1, -1}, {36820, -1, -1, -1}, {36941, -1, -1, -1}, {20415, -1, -1, -1}, {21193, -1, -1, -1}, {23081, -1, -1, -1}, {24321, -1, -1, -1}, {38829, -1, -1, -1}, {20445, -1, -1, -1}, {33303, -1, -1, -1}, {37610, -1, -1, -1}, {22275, -1, -1, -1}, {25429, -1, -1, -1}, {27497, -1, -1, -1}, {29995, -1, -1, -1}, {35036, -1, -1, -1}, {36628, -1, -1, -1}, {31298, -1, -1, -1}, {21215, -1, -1, -1}, {22675, -1, -1, -1}, {24917, -1, -1, -1}, {25098, -1, -1, -1}, {26286, -1, -1, -1}, {11935, 27597, -1, -1}, {31807, -1, -1, -1}, {33769, -1, -1, -1}, {20515, -1, -1, -1}, {20472, -1, -1, -1}, {21253, -1, -1, -1}, {21574, -1, -1, -1}, {22577, -1, -1, -1}, {22857, -1, -1, -1}, {23453, -1, -1, -1}, {23792, -1, -1, -1}, {23791, -1, -1, -1}, {23849, -1, -1, -1}, {24214, -1, -1, -1}, {25265, -1, -1, -1}, {25447, -1, -1, -1}, {25918, -1, -1, -1}, {12101, 26041, -1, -1}, {26379, -1, -1, -1}, {27861, -1, -1, -1}, {27873, -1, -1, -1}, {28921, -1, -1, -1}, {30770, -1, -1, -1}, {32299, -1, -1, -1}, {32990, -1, -1, -1}, {33459, -1, -1, -1}, {33804, -1, -1, -1}, {34028, -1, -1, -1}, {34562, -1, -1, -1}, {35090, -1, -1, -1}, {35370, -1, -1, -1}, {35914, -1, -1, -1}, {37030, -1, -1, -1}, {37586, -1, -1, -1}, {39165, -1, -1, -1}, {40179, -1, -1, -1}, {40300, -1, -1, -1}, {20047, -1, -1, -1}, {20129, -1, -1, -1}, {20621, -1, -1, -1}, {21078, -1, -1, -1}, {22346, -1, -1, -1}, {22952, -1, -1, -1}, {24125, -1, -1, -1}, {24536, -1, -1, -1}, {24537, -1, -1, -1}, {25151, -1, -1, -1}, {26292, -1, -1, -1}, {26395, -1, -1, -1}, {26576, -1, -1, -1}, {26834, -1, -1, -1}, {20882, -1, -1, -1}, {32033, -1, -1, -1}, {32938, -1, -1, -1}, {33192, -1, -1, -1}, {35584, -1, -1, -1}, {35980, -1, -1, -1}, {36031, -1, -1, -1}, {37502, -1, -1, -1}, {38450, -1, -1, -1}, {21536, -1, -1, -1}, {38956, -1, -1, -1}, {21271, -1, -1, -1}, {20693, -1, -1, -1}, {12056, 21340, -1, -1}, {22696, -1, -1, -1}, {25778, -1, -1, -1}, {26420, -1, -1, -1}, {29287, -1, -1, -1}, {30566, -1, -1, -1}, {31302, -1, -1, -1}, {37350, -1, -1, -1}, {21187, -1, -1, -1}, {27809, -1, -1, -1}, {27526, -1, -1, -1}, {22528, -1, -1, -1}, {24140, -1, -1, -1}, {22868, -1, -1, -1}, {26412, -1, -1, -1}, {32763, -1, -1, -1}, {20961, -1, -1, -1}, {30406, -1, -1, -1}, {25705, -1, -1, -1}, {30952, -1, -1, -1}, {39764, -1, -1, -1}, {12231, 40635, -1, -1}, {22475, -1, -1, -1}, {22969, -1, -1, -1}, {26151, -1, -1, -1}, {26522, -1, -1, -1}, {27598, -1, -1, -1}, {21737, -1, -1, -1}, {27097, -1, -1, -1}, {24149, -1, -1, -1}, {33180, -1, -1, -1}, {26517, -1, -1, -1}, {39850, -1, -1, -1}, {26622, -1, -1, -1}, {40018, -1, -1, -1}, {26717, -1, -1, -1}, {20134, -1, -1, -1}, {20451, -1, -1, -1}, {12060, 21448, -1, -1}, {25273, -1, -1, -1}, {26411, -1, -1, -1}, {27819, -1, -1, -1}, {36804, -1, -1, -1}, {20397, -1, -1, -1}, {32365, -1, -1, -1}, {40639, -1, -1, -1}, {19975, -1, -1, -1}, {24930, -1, -1, -1}, {28288, -1, -1, -1}, {28459, -1, -1, -1}, {34067, -1, -1, -1}, {21619, -1, -1, -1}, {26410, -1, -1, -1}, {39749, -1, -1, -1}, {11922, 24051, -1, -1}, {31637, -1, -1, -1}, {23724, -1, -1, -1}, {23494, -1, -1, -1}, {34588, -1, -1, -1}, {28234, -1, -1, -1}, {34001, -1, -1, -1}, {31252, -1, -1, -1}, {33032, -1, -1, -1}, {22937, -1, -1, -1}, {31885, -1, -1, -1}, {11936, 27665, -1, -1}, {30496, -1, -1, -1}, {21209, -1, -1, -1}, {22818, -1, -1, -1}, {28961, -1, -1, -1}, {29279, -1, -1, -1}, {12141, 30683, -1, -1}, {38695, -1, -1, -1}, {40289, -1, -1, -1}, {26891, -1, -1, -1}, {23167, -1, -1, -1}, {23064, -1, -1, -1}, {20901, -1, -1, -1}, {21517, -1, -1, -1}, {21629, -1, -1, -1}, {26126, -1, -1, -1}, {30431, -1, -1, -1}, {36855, -1, -1, -1}, {37528, -1, -1, -1}, {40180, -1, -1, -1}, {23018, -1, -1, -1}, {29277, -1, -1, -1}, {28357, -1, -1, -1}, {20813, -1, -1, -1}, {26825, -1, -1, -1}, {32191, -1, -1, -1}, {32236, -1, -1, -1}, {12207, 38754, -1, -1}, {40634, -1, -1, -1}, {25720, -1, -1, -1}, {27169, -1, -1, -1}, {33538, -1, -1, -1}, {22916, -1, -1, -1}, {23391, -1, -1, -1}, {12113, 27611, -1, -1}, {29467, -1, -1, -1}, {30450, -1, -1, -1}, {32178, -1, -1, -1}, {32791, -1, -1, -1}, {33945, -1, -1, -1}, {20786, -1, -1, -1}, {12106, 26408, -1, -1}, {40665, -1, -1, -1}, {12140, 30446, -1, -1}, {26466, -1, -1, -1}, {21247, -1, -1, -1}, {39173, -1, -1, -1}, {23588, -1, -1, -1}, {25147, -1, -1, -1}, {31870, -1, -1, -1}, {36016, -1, -1, -1}, {21839, -1, -1, -1}, {24758, -1, -1, -1}, {32011, -1, -1, -1}, {12200, 38272, -1, -1}, {21249, -1, -1, -1}, {20063, -1, -1, -1}, {20918, -1, -1, -1}, {22812, -1, -1, -1}, {29242, -1, -1, -1}, {32822, -1, -1, -1}, {37326, -1, -1, -1}, {24357, -1, -1, -1}, {12142, 30690, -1, -1}, {21380, -1, -1, -1}, {24441, -1, -1, -1}, {32004, -1, -1, -1} },
+ {{34220, -1, -1, -1}, {35379, -1, -1, -1}, {36493, -1, -1, -1}, {38742, -1, -1, -1}, {26611, -1, -1, -1}, {34222, -1, -1, -1}, {37971, -1, -1, -1}, {24841, -1, -1, -1}, {24840, -1, -1, -1}, {27833, -1, -1, -1}, {30290, -1, -1, -1}, {35565, -1, -1, -1}, {36664, -1, -1, -1}, {21807, -1, -1, -1}, {20305, -1, -1, -1}, {20778, -1, -1, -1}, {21191, -1, -1, -1}, {21451, -1, -1, -1}, {23461, -1, -1, -1}, {24189, -1, -1, -1}, {24736, -1, -1, -1}, {24962, -1, -1, -1}, {25558, -1, -1, -1}, {26377, -1, -1, -1}, {26586, -1, -1, -1}, {28263, -1, -1, -1}, {28044, -1, -1, -1}, {29494, -1, -1, -1}, {29495, -1, -1, -1}, {30001, -1, -1, -1}, {31056, -1, -1, -1}, {35029, -1, -1, -1}, {35480, -1, -1, -1}, {36938, -1, -1, -1}, {12194, 37009, -1, -1}, {37109, -1, -1, -1}, {38596, -1, -1, -1}, {34701, -1, -1, -1}, {12067, 22805, -1, -1}, {20104, -1, -1, -1}, {20313, -1, -1, -1}, {19982, -1, -1, -1}, {35465, -1, -1, -1}, {36671, -1, -1, -1}, {38928, -1, -1, -1}, {20653, -1, -1, -1}, {24188, -1, -1, -1}, {22934, -1, -1, -1}, {23481, -1, -1, -1}, {24248, -1, -1, -1}, {25562, -1, -1, -1}, {25594, -1, -1, -1}, {25793, -1, -1, -1}, {26332, -1, -1, -1}, {26954, -1, -1, -1}, {27096, -1, -1, -1}, {27915, -1, -1, -1}, {28342, -1, -1, -1}, {29076, -1, -1, -1}, {12132, 29992, -1, -1}, {31407, -1, -1, -1}, {12154, 32650, -1, -1}, {32768, -1, -1, -1}, {33865, -1, -1, -1}, {33993, -1, -1, -1}, {35201, -1, -1, -1}, {35617, -1, -1, -1}, {36362, -1, -1, -1}, {36965, -1, -1, -1}, {38525, -1, -1, -1}, {39178, -1, -1, -1}, {24958, -1, -1, -1}, {25233, -1, -1, -1}, {27442, -1, -1, -1}, {27779, -1, -1, -1}, {28020, -1, -1, -1}, {32716, -1, -1, -1}, {32764, -1, -1, -1}, {28096, -1, -1, -1}, {32645, -1, -1, -1}, {34746, -1, -1, -1}, {35064, -1, -1, -1}, {26469, -1, -1, -1}, {33713, -1, -1, -1}, {38972, -1, -1, -1}, {38647, -1, -1, -1}, {27931, -1, -1, -1}, {32097, -1, -1, -1}, {33853, -1, -1, -1}, {37226, -1, -1, -1}, {20081, -1, -1, -1}, {21365, -1, -1, -1}, {23888, -1, -1, -1}, {27396, -1, -1, -1}, {28651, -1, -1, -1}, {34253, -1, -1, -1}, {34349, -1, -1, -1}, {35239, -1, -1, -1}, {21033, -1, -1, -1}, {21519, -1, -1, -1}, {23653, -1, -1, -1}, {26446, -1, -1, -1}, {26792, -1, -1, -1}, {29702, -1, -1, -1}, {29827, -1, -1, -1}, {30178, -1, -1, -1}, {35023, -1, -1, -1}, {35041, -1, -1, -1}, {12197, 37324, -1, -1}, {38626, -1, -1, -1}, {38520, -1, -1, -1}, {24459, -1, -1, -1}, {29575, -1, -1, -1}, {12148, 31435, -1, -1}, {33870, -1, -1, -1}, {25504, -1, -1, -1}, {30053, -1, -1, -1}, {21129, -1, -1, -1}, {27969, -1, -1, -1}, {28316, -1, -1, -1}, {29705, -1, -1, -1}, {30041, -1, -1, -1}, {30827, -1, -1, -1}, {31890, -1, -1, -1}, {38534, -1, -1, -1}, {12015, 31452, -1, -1}, {12243, 40845, -1, -1}, {20406, -1, -1, -1}, {24942, -1, -1, -1}, {26053, -1, -1, -1}, {34396, -1, -1, -1}, {20102, -1, -1, -1}, {20142, -1, -1, -1}, {20698, -1, -1, -1}, {20001, -1, -1, -1}, {20940, -1, -1, -1}, {23534, -1, -1, -1}, {26009, -1, -1, -1}, {26753, -1, -1, -1}, {28092, -1, -1, -1}, {29471, -1, -1, -1}, {30274, -1, -1, -1}, {30637, -1, -1, -1}, {31260, -1, -1, -1}, {31975, -1, -1, -1}, {33391, -1, -1, -1}, {35538, -1, -1, -1}, {36988, -1, -1, -1}, {37327, -1, -1, -1}, {38517, -1, -1, -1}, {38936, -1, -1, -1}, {12050, 21147, -1, -1}, {32209, -1, -1, -1}, {20523, -1, -1, -1}, {21400, -1, -1, -1}, {26519, -1, -1, -1}, {28107, -1, -1, -1}, {29136, -1, -1, -1}, {29747, -1, -1, -1}, {33256, -1, -1, -1}, {36650, -1, -1, -1}, {38563, -1, -1, -1}, {40023, -1, -1, -1}, {40607, -1, -1, -1}, {29792, -1, -1, -1}, {22593, -1, -1, -1}, {28057, -1, -1, -1}, {32047, -1, -1, -1}, {39006, -1, -1, -1}, {20196, -1, -1, -1}, {20278, -1, -1, -1}, {20363, -1, -1, -1}, {20919, -1, -1, -1}, {21169, -1, -1, -1}, {23994, -1, -1, -1}, {24604, -1, -1, -1}, {29618, -1, -1, -1}, {31036, -1, -1, -1}, {33491, -1, -1, -1}, {37428, -1, -1, -1}, {38583, -1, -1, -1}, {38646, -1, -1, -1}, {38666, -1, -1, -1}, {40599, -1, -1, -1}, {40802, -1, -1, -1}, {26278, -1, -1, -1}, {27508, -1, -1, -1}, {21015, -1, -1, -1}, {21155, -1, -1, -1}, {28872, -1, -1, -1}, {35010, -1, -1, -1}, {24265, -1, -1, -1}, {24651, -1, -1, -1}, {24976, -1, -1, -1}, {28451, -1, -1, -1}, {29001, -1, -1, -1}, {31806, -1, -1, -1}, {32244, -1, -1, -1}, {32879, -1, -1, -1}, {34030, -1, -1, -1}, {36899, -1, -1, -1}, {37676, -1, -1, -1}, {21570, -1, -1, -1}, {39791, -1, -1, -1}, {27347, -1, -1, -1}, {28809, -1, -1, -1}, {36034, -1, -1, -1}, {36335, -1, -1, -1}, {38706, -1, -1, -1}, {21172, -1, -1, -1}, {23105, -1, -1, -1}, {24266, -1, -1, -1}, {24324, -1, -1, -1}, {26391, -1, -1, -1}, {27004, -1, -1, -1}, {27028, -1, -1, -1}, {28010, -1, -1, -1}, {28431, -1, -1, -1}, {29282, -1, -1, -1}, {29436, -1, -1, -1}, {31725, -1, -1, -1}, {12156, 32769, -1, -1}, {32894, -1, -1, -1}, {34635, -1, -1, -1}, {37070, -1, -1, -1}, {20845, -1, -1, -1}, {40595, -1, -1, -1}, {31108, -1, -1, -1}, {32907, -1, -1, -1}, {37682, -1, -1, -1}, {35542, -1, -1, -1}, {20525, -1, -1, -1}, {21644, -1, -1, -1}, {35441, -1, -1, -1}, {27498, -1, -1, -1}, {36036, -1, -1, -1}, {33031, -1, -1, -1}, {24785, -1, -1, -1}, {26528, -1, -1, -1}, {40434, -1, -1, -1}, {20121, -1, -1, -1}, {20120, -1, -1, -1}, {39952, -1, -1, -1}, {35435, -1, -1, -1}, {34241, -1, -1, -1}, {34152, -1, -1, -1}, {26880, -1, -1, -1}, {28286, -1, -1, -1}, {30871, -1, -1, -1}, {33109, -1, -1, -1}, {24332, -1, -1, -1}, {19984, -1, -1, -1}, {19989, -1, -1, -1}, {20010, -1, -1, -1}, {20017, -1, -1, -1}, {12034, 20022, -1, -1} },
+ {{20028, -1, -1, -1}, {12035, 20031, -1, -1}, {20034, -1, -1, -1}, {20054, -1, -1, -1}, {20056, -1, -1, -1}, {20098, -1, -1, -1}, {12037, 20101, -1, -1}, {35947, -1, -1, -1}, {20106, -1, -1, -1}, {33298, -1, -1, -1}, {24333, -1, -1, -1}, {20110, -1, -1, -1}, {20126, -1, -1, -1}, {20127, -1, -1, -1}, {12039, 20128, -1, -1}, {20130, -1, -1, -1}, {20144, -1, -1, -1}, {20147, -1, -1, -1}, {20150, -1, -1, -1}, {20174, -1, -1, -1}, {20173, -1, -1, -1}, {20164, -1, -1, -1}, {20166, -1, -1, -1}, {20162, -1, -1, -1}, {20183, -1, -1, -1}, {20190, -1, -1, -1}, {20205, -1, -1, -1}, {20191, -1, -1, -1}, {20215, -1, -1, -1}, {20233, -1, -1, -1}, {20314, -1, -1, -1}, {20272, -1, -1, -1}, {20315, -1, -1, -1}, {20317, -1, -1, -1}, {20311, -1, -1, -1}, {20295, -1, -1, -1}, {20342, -1, -1, -1}, {20360, -1, -1, -1}, {20367, -1, -1, -1}, {20376, -1, -1, -1}, {20347, -1, -1, -1}, {20329, -1, -1, -1}, {20336, -1, -1, -1}, {20369, -1, -1, -1}, {20335, -1, -1, -1}, {20358, -1, -1, -1}, {20374, -1, -1, -1}, {20760, -1, -1, -1}, {20436, -1, -1, -1}, {20447, -1, -1, -1}, {20430, -1, -1, -1}, {20440, -1, -1, -1}, {20443, -1, -1, -1}, {20433, -1, -1, -1}, {20442, -1, -1, -1}, {20432, -1, -1, -1}, {20452, -1, -1, -1}, {20453, -1, -1, -1}, {20506, -1, -1, -1}, {20520, -1, -1, -1}, {20500, -1, -1, -1}, {20522, -1, -1, -1}, {20517, -1, -1, -1}, {20485, -1, -1, -1}, {20252, -1, -1, -1}, {20470, -1, -1, -1}, {20513, -1, -1, -1}, {20521, -1, -1, -1}, {20524, -1, -1, -1}, {20478, -1, -1, -1}, {20463, -1, -1, -1}, {20497, -1, -1, -1}, {20486, -1, -1, -1}, {20547, -1, -1, -1}, {20551, -1, -1, -1}, {26371, -1, -1, -1}, {20565, -1, -1, -1}, {20560, -1, -1, -1}, {20552, -1, -1, -1}, {20570, -1, -1, -1}, {20566, -1, -1, -1}, {20588, -1, -1, -1}, {20600, -1, -1, -1}, {20608, -1, -1, -1}, {20634, -1, -1, -1}, {20613, -1, -1, -1}, {20660, -1, -1, -1}, {20658, -1, -1, -1}, {20681, -1, -1, -1}, {20682, -1, -1, -1}, {20659, -1, -1, -1}, {20674, -1, -1, -1}, {20694, -1, -1, -1}, {20702, -1, -1, -1}, {20709, -1, -1, -1}, {20717, -1, -1, -1}, {20707, -1, -1, -1}, {20718, -1, -1, -1}, {20729, -1, -1, -1}, {20725, -1, -1, -1}, {20745, -1, -1, -1}, {20737, -1, -1, -1}, {20738, -1, -1, -1}, {20758, -1, -1, -1}, {20757, -1, -1, -1}, {20756, -1, -1, -1}, {20762, -1, -1, -1}, {20769, -1, -1, -1}, {20794, -1, -1, -1}, {20791, -1, -1, -1}, {20796, -1, -1, -1}, {20795, -1, -1, -1}, {12041, 20799, -1, -1}, {11918, 20800, -1, -1}, {20818, -1, -1, -1}, {20812, -1, -1, -1}, {20820, -1, -1, -1}, {20834, -1, -1, -1}, {31480, -1, -1, -1}, {20841, -1, -1, -1}, {20842, -1, -1, -1}, {20846, -1, -1, -1}, {20864, -1, -1, -1}, {12044, 20866, -1, -1}, {22232, -1, -1, -1}, {20876, -1, -1, -1}, {20873, -1, -1, -1}, {20879, -1, -1, -1}, {20881, -1, -1, -1}, {20883, -1, -1, -1}, {20885, -1, -1, -1}, {12045, 20886, -1, -1}, {20900, -1, -1, -1}, {20902, -1, -1, -1}, {20898, -1, -1, -1}, {20905, -1, -1, -1}, {20906, -1, -1, -1}, {12046, 20907, -1, -1}, {20915, -1, -1, -1}, {20913, -1, -1, -1}, {20914, -1, -1, -1}, {20912, -1, -1, -1}, {20917, -1, -1, -1}, {20925, -1, -1, -1}, {20933, -1, -1, -1}, {20937, -1, -1, -1}, {20955, -1, -1, -1}, {12047, 20960, -1, -1}, {34389, -1, -1, -1}, {20969, -1, -1, -1}, {20973, -1, -1, -1}, {20976, -1, -1, -1}, {12048, 20981, -1, -1}, {20990, -1, -1, -1}, {20996, -1, -1, -1}, {21003, -1, -1, -1}, {21012, -1, -1, -1}, {21006, -1, -1, -1}, {21031, -1, -1, -1}, {21034, -1, -1, -1}, {21038, -1, -1, -1}, {21043, -1, -1, -1}, {21049, -1, -1, -1}, {21071, -1, -1, -1}, {21060, -1, -1, -1}, {21067, -1, -1, -1}, {21068, -1, -1, -1}, {21086, -1, -1, -1}, {21076, -1, -1, -1}, {21098, -1, -1, -1}, {21108, -1, -1, -1}, {21097, -1, -1, -1}, {21107, -1, -1, -1}, {21119, -1, -1, -1}, {21117, -1, -1, -1}, {21133, -1, -1, -1}, {21140, -1, -1, -1}, {21138, -1, -1, -1}, {21105, -1, -1, -1}, {21128, -1, -1, -1}, {21137, -1, -1, -1}, {36776, -1, -1, -1}, {36775, -1, -1, -1}, {21164, -1, -1, -1}, {21165, -1, -1, -1}, {21180, -1, -1, -1}, {21173, -1, -1, -1}, {21185, -1, -1, -1}, {21197, -1, -1, -1}, {21207, -1, -1, -1}, {21214, -1, -1, -1}, {21219, -1, -1, -1}, {21222, -1, -1, -1}, {39149, -1, -1, -1}, {21216, -1, -1, -1}, {21235, -1, -1, -1}, {21237, -1, -1, -1}, {21240, -1, -1, -1}, {12051, 21241, -1, -1}, {21254, -1, -1, -1}, {21256, -1, -1, -1}, {30008, -1, -1, -1}, {21261, -1, -1, -1}, {21264, -1, -1, -1}, {21263, -1, -1, -1}, {12052, 21269, -1, -1}, {12053, 21274, -1, -1}, {21283, -1, -1, -1}, {21295, -1, -1, -1}, {21297, -1, -1, -1}, {21299, -1, -1, -1}, {12054, 21304, -1, -1}, {21312, -1, -1, -1}, {21318, -1, -1, -1}, {21317, -1, -1, -1}, {19991, -1, -1, -1}, {21321, -1, -1, -1}, {21325, -1, -1, -1}, {20950, -1, -1, -1}, {21342, -1, -1, -1}, {12057, 21353, -1, -1}, {21358, -1, -1, -1}, {22808, -1, -1, -1}, {21371, -1, -1, -1}, {21367, -1, -1, -1}, {12058, 21378, -1, -1}, {21398, -1, -1, -1}, {21408, -1, -1, -1}, {21414, -1, -1, -1}, {21413, -1, -1, -1}, {21422, -1, -1, -1}, {21424, -1, -1, -1}, {12059, 21430, -1, -1}, {21443, -1, -1, -1}, {31762, -1, -1, -1}, {38617, -1, -1, -1}, {21471, -1, -1, -1}, {26364, -1, -1, -1}, {29166, -1, -1, -1}, {21486, -1, -1, -1}, {21480, -1, -1, -1}, {21485, -1, -1, -1}, {21498, -1, -1, -1}, {21505, -1, -1, -1}, {21565, -1, -1, -1}, {21568, -1, -1, -1}, {21548, -1, -1, -1}, {21549, -1, -1, -1}, {21564, -1, -1, -1}, {21550, -1, -1, -1}, {21558, -1, -1, -1}, {21545, -1, -1, -1}, {21533, -1, -1, -1}, {21582, -1, -1, -1}, {21647, -1, -1, -1}, {21621, -1, -1, -1} },
+ {{21646, -1, -1, -1}, {21599, -1, -1, -1}, {21617, -1, -1, -1}, {21623, -1, -1, -1}, {21616, -1, -1, -1}, {21650, -1, -1, -1}, {21627, -1, -1, -1}, {21632, -1, -1, -1}, {21622, -1, -1, -1}, {21636, -1, -1, -1}, {21648, -1, -1, -1}, {21638, -1, -1, -1}, {21703, -1, -1, -1}, {21666, -1, -1, -1}, {21688, -1, -1, -1}, {21669, -1, -1, -1}, {21676, -1, -1, -1}, {21700, -1, -1, -1}, {21704, -1, -1, -1}, {21672, -1, -1, -1}, {21675, -1, -1, -1}, {21698, -1, -1, -1}, {21668, -1, -1, -1}, {21694, -1, -1, -1}, {21692, -1, -1, -1}, {21720, -1, -1, -1}, {21733, -1, -1, -1}, {21734, -1, -1, -1}, {21775, -1, -1, -1}, {21780, -1, -1, -1}, {21757, -1, -1, -1}, {21742, -1, -1, -1}, {21741, -1, -1, -1}, {21754, -1, -1, -1}, {21730, -1, -1, -1}, {21817, -1, -1, -1}, {21824, -1, -1, -1}, {21859, -1, -1, -1}, {21836, -1, -1, -1}, {21806, -1, -1, -1}, {21852, -1, -1, -1}, {21829, -1, -1, -1}, {21846, -1, -1, -1}, {21847, -1, -1, -1}, {21816, -1, -1, -1}, {21811, -1, -1, -1}, {21853, -1, -1, -1}, {21913, -1, -1, -1}, {21888, -1, -1, -1}, {21679, -1, -1, -1}, {21898, -1, -1, -1}, {21919, -1, -1, -1}, {21883, -1, -1, -1}, {21886, -1, -1, -1}, {21912, -1, -1, -1}, {21918, -1, -1, -1}, {21934, -1, -1, -1}, {21884, -1, -1, -1}, {21891, -1, -1, -1}, {21929, -1, -1, -1}, {21895, -1, -1, -1}, {21928, -1, -1, -1}, {21978, -1, -1, -1}, {21957, -1, -1, -1}, {21983, -1, -1, -1}, {21956, -1, -1, -1}, {21980, -1, -1, -1}, {21988, -1, -1, -1}, {21972, -1, -1, -1}, {22036, -1, -1, -1}, {22007, -1, -1, -1}, {22038, -1, -1, -1}, {22014, -1, -1, -1}, {22013, -1, -1, -1}, {22043, -1, -1, -1}, {22009, -1, -1, -1}, {22094, -1, -1, -1}, {22096, -1, -1, -1}, {29151, -1, -1, -1}, {22068, -1, -1, -1}, {22070, -1, -1, -1}, {22066, -1, -1, -1}, {22072, -1, -1, -1}, {22123, -1, -1, -1}, {22116, -1, -1, -1}, {22063, -1, -1, -1}, {22124, -1, -1, -1}, {22122, -1, -1, -1}, {22150, -1, -1, -1}, {22144, -1, -1, -1}, {22154, -1, -1, -1}, {22176, -1, -1, -1}, {22164, -1, -1, -1}, {22159, -1, -1, -1}, {22181, -1, -1, -1}, {22190, -1, -1, -1}, {22198, -1, -1, -1}, {22196, -1, -1, -1}, {22210, -1, -1, -1}, {22204, -1, -1, -1}, {22209, -1, -1, -1}, {22211, -1, -1, -1}, {22208, -1, -1, -1}, {22216, -1, -1, -1}, {22222, -1, -1, -1}, {22225, -1, -1, -1}, {22227, -1, -1, -1}, {12062, 22231, -1, -1}, {22254, -1, -1, -1}, {22265, -1, -1, -1}, {22272, -1, -1, -1}, {22271, -1, -1, -1}, {22276, -1, -1, -1}, {22281, -1, -1, -1}, {22280, -1, -1, -1}, {22283, -1, -1, -1}, {22285, -1, -1, -1}, {22291, -1, -1, -1}, {22296, -1, -1, -1}, {22294, -1, -1, -1}, {21959, -1, -1, -1}, {22300, -1, -1, -1}, {22310, -1, -1, -1}, {22327, -1, -1, -1}, {22328, -1, -1, -1}, {22350, -1, -1, -1}, {22331, -1, -1, -1}, {22336, -1, -1, -1}, {22351, -1, -1, -1}, {22377, -1, -1, -1}, {22464, -1, -1, -1}, {22408, -1, -1, -1}, {22369, -1, -1, -1}, {22399, -1, -1, -1}, {22409, -1, -1, -1}, {22419, -1, -1, -1}, {22432, -1, -1, -1}, {22451, -1, -1, -1}, {22436, -1, -1, -1}, {22442, -1, -1, -1}, {22448, -1, -1, -1}, {22467, -1, -1, -1}, {22470, -1, -1, -1}, {22484, -1, -1, -1}, {22482, -1, -1, -1}, {22483, -1, -1, -1}, {22538, -1, -1, -1}, {22486, -1, -1, -1}, {22499, -1, -1, -1}, {22539, -1, -1, -1}, {22553, -1, -1, -1}, {22557, -1, -1, -1}, {22642, -1, -1, -1}, {22561, -1, -1, -1}, {22626, -1, -1, -1}, {22603, -1, -1, -1}, {22640, -1, -1, -1}, {27584, -1, -1, -1}, {22610, -1, -1, -1}, {22589, -1, -1, -1}, {22649, -1, -1, -1}, {22661, -1, -1, -1}, {22713, -1, -1, -1}, {22687, -1, -1, -1}, {22699, -1, -1, -1}, {22714, -1, -1, -1}, {22750, -1, -1, -1}, {22715, -1, -1, -1}, {22712, -1, -1, -1}, {22702, -1, -1, -1}, {22725, -1, -1, -1}, {22739, -1, -1, -1}, {22737, -1, -1, -1}, {22743, -1, -1, -1}, {22745, -1, -1, -1}, {22744, -1, -1, -1}, {22757, -1, -1, -1}, {22748, -1, -1, -1}, {22756, -1, -1, -1}, {22751, -1, -1, -1}, {22767, -1, -1, -1}, {22778, -1, -1, -1}, {22777, -1, -1, -1}, {22779, -1, -1, -1}, {22780, -1, -1, -1}, {22781, -1, -1, -1}, {12065, 22786, -1, -1}, {12066, 22794, -1, -1}, {22800, -1, -1, -1}, {22811, -1, -1, -1}, {26790, -1, -1, -1}, {22821, -1, -1, -1}, {22828, -1, -1, -1}, {22829, -1, -1, -1}, {22834, -1, -1, -1}, {22840, -1, -1, -1}, {22846, -1, -1, -1}, {31442, -1, -1, -1}, {22869, -1, -1, -1}, {22864, -1, -1, -1}, {22862, -1, -1, -1}, {22874, -1, -1, -1}, {22872, -1, -1, -1}, {22882, -1, -1, -1}, {22880, -1, -1, -1}, {22887, -1, -1, -1}, {22892, -1, -1, -1}, {22889, -1, -1, -1}, {22904, -1, -1, -1}, {22913, -1, -1, -1}, {22941, -1, -1, -1}, {20318, -1, -1, -1}, {20395, -1, -1, -1}, {22947, -1, -1, -1}, {22962, -1, -1, -1}, {22982, -1, -1, -1}, {23016, -1, -1, -1}, {23004, -1, -1, -1}, {22925, -1, -1, -1}, {23001, -1, -1, -1}, {23002, -1, -1, -1}, {23077, -1, -1, -1}, {23071, -1, -1, -1}, {23057, -1, -1, -1}, {23068, -1, -1, -1}, {23049, -1, -1, -1}, {23066, -1, -1, -1}, {23104, -1, -1, -1}, {23148, -1, -1, -1}, {23113, -1, -1, -1}, {23093, -1, -1, -1}, {23094, -1, -1, -1}, {23138, -1, -1, -1}, {23146, -1, -1, -1}, {23194, -1, -1, -1}, {23228, -1, -1, -1}, {23230, -1, -1, -1}, {23243, -1, -1, -1}, {23234, -1, -1, -1}, {23229, -1, -1, -1}, {23267, -1, -1, -1}, {23255, -1, -1, -1}, {23270, -1, -1, -1}, {23273, -1, -1, -1}, {23254, -1, -1, -1}, {23290, -1, -1, -1}, {23291, -1, -1, -1}, {23308, -1, -1, -1}, {23307, -1, -1, -1}, {23318, -1, -1, -1}, {23346, -1, -1, -1}, {23248, -1, -1, -1}, {23338, -1, -1, -1}, {23350, -1, -1, -1}, {23358, -1, -1, -1}, {23363, -1, -1, -1} },
+ {{23365, -1, -1, -1}, {23360, -1, -1, -1}, {23377, -1, -1, -1}, {23381, -1, -1, -1}, {23386, -1, -1, -1}, {23387, -1, -1, -1}, {23397, -1, -1, -1}, {23401, -1, -1, -1}, {23408, -1, -1, -1}, {23411, -1, -1, -1}, {23413, -1, -1, -1}, {23416, -1, -1, -1}, {25992, -1, -1, -1}, {23418, -1, -1, -1}, {12071, 23424, -1, -1}, {23427, -1, -1, -1}, {23462, -1, -1, -1}, {23480, -1, -1, -1}, {23491, -1, -1, -1}, {23495, -1, -1, -1}, {23497, -1, -1, -1}, {23508, -1, -1, -1}, {23504, -1, -1, -1}, {23524, -1, -1, -1}, {23526, -1, -1, -1}, {23522, -1, -1, -1}, {23518, -1, -1, -1}, {23525, -1, -1, -1}, {23531, -1, -1, -1}, {23536, -1, -1, -1}, {23542, -1, -1, -1}, {23539, -1, -1, -1}, {23557, -1, -1, -1}, {23559, -1, -1, -1}, {23560, -1, -1, -1}, {23565, -1, -1, -1}, {23571, -1, -1, -1}, {23584, -1, -1, -1}, {11920, 12074, 23586, -1}, {23592, -1, -1, -1}, {12075, 23608, -1, -1}, {23609, -1, -1, -1}, {23617, -1, -1, -1}, {23622, -1, -1, -1}, {23630, -1, -1, -1}, {23635, -1, -1, -1}, {23632, -1, -1, -1}, {23631, -1, -1, -1}, {23409, -1, -1, -1}, {23660, -1, -1, -1}, {12076, 23662, -1, -1}, {20066, -1, -1, -1}, {23670, -1, -1, -1}, {23673, -1, -1, -1}, {23692, -1, -1, -1}, {23697, -1, -1, -1}, {23700, -1, -1, -1}, {22939, -1, -1, -1}, {23723, -1, -1, -1}, {23739, -1, -1, -1}, {23734, -1, -1, -1}, {23740, -1, -1, -1}, {23735, -1, -1, -1}, {23749, -1, -1, -1}, {23742, -1, -1, -1}, {23751, -1, -1, -1}, {23769, -1, -1, -1}, {23785, -1, -1, -1}, {23805, -1, -1, -1}, {23802, -1, -1, -1}, {23789, -1, -1, -1}, {23948, -1, -1, -1}, {23786, -1, -1, -1}, {23819, -1, -1, -1}, {23829, -1, -1, -1}, {23831, -1, -1, -1}, {23900, -1, -1, -1}, {23839, -1, -1, -1}, {23835, -1, -1, -1}, {23825, -1, -1, -1}, {23828, -1, -1, -1}, {23842, -1, -1, -1}, {23834, -1, -1, -1}, {23833, -1, -1, -1}, {23832, -1, -1, -1}, {23884, -1, -1, -1}, {23890, -1, -1, -1}, {23886, -1, -1, -1}, {23883, -1, -1, -1}, {23916, -1, -1, -1}, {23923, -1, -1, -1}, {23926, -1, -1, -1}, {23943, -1, -1, -1}, {23940, -1, -1, -1}, {23938, -1, -1, -1}, {23970, -1, -1, -1}, {23965, -1, -1, -1}, {23980, -1, -1, -1}, {23982, -1, -1, -1}, {23997, -1, -1, -1}, {23952, -1, -1, -1}, {23991, -1, -1, -1}, {23996, -1, -1, -1}, {24009, -1, -1, -1}, {24013, -1, -1, -1}, {24019, -1, -1, -1}, {24018, -1, -1, -1}, {24022, -1, -1, -1}, {12078, 24027, -1, -1}, {24043, -1, -1, -1}, {24050, -1, -1, -1}, {24053, -1, -1, -1}, {24075, -1, -1, -1}, {24090, -1, -1, -1}, {24089, -1, -1, -1}, {24081, -1, -1, -1}, {24091, -1, -1, -1}, {24118, -1, -1, -1}, {24119, -1, -1, -1}, {24132, -1, -1, -1}, {24131, -1, -1, -1}, {24128, -1, -1, -1}, {24142, -1, -1, -1}, {24151, -1, -1, -1}, {24148, -1, -1, -1}, {24159, -1, -1, -1}, {24162, -1, -1, -1}, {24164, -1, -1, -1}, {24135, -1, -1, -1}, {24181, -1, -1, -1}, {24182, -1, -1, -1}, {11923, 12083, 24186, -1}, {40636, -1, -1, -1}, {12084, 24191, -1, -1}, {24224, -1, -1, -1}, {24257, -1, -1, -1}, {24258, -1, -1, -1}, {24264, -1, -1, -1}, {24272, -1, -1, -1}, {24271, -1, -1, -1}, {24278, -1, -1, -1}, {24291, -1, -1, -1}, {24285, -1, -1, -1}, {24282, -1, -1, -1}, {24283, -1, -1, -1}, {24290, -1, -1, -1}, {24289, -1, -1, -1}, {24296, -1, -1, -1}, {24297, -1, -1, -1}, {24300, -1, -1, -1}, {24305, -1, -1, -1}, {24307, -1, -1, -1}, {24304, -1, -1, -1}, {12085, 24308, -1, -1}, {24312, -1, -1, -1}, {12086, 24318, -1, -1}, {24323, -1, -1, -1}, {24329, -1, -1, -1}, {24413, -1, -1, -1}, {24412, -1, -1, -1}, {12087, 24331, -1, -1}, {24337, -1, -1, -1}, {24342, -1, -1, -1}, {24361, -1, -1, -1}, {24365, -1, -1, -1}, {24376, -1, -1, -1}, {24385, -1, -1, -1}, {24392, -1, -1, -1}, {24396, -1, -1, -1}, {24398, -1, -1, -1}, {24367, -1, -1, -1}, {11924, 24401, -1, -1}, {24406, -1, -1, -1}, {24407, -1, -1, -1}, {24409, -1, -1, -1}, {12090, 24417, -1, -1}, {24429, -1, -1, -1}, {12091, 24435, -1, -1}, {24439, -1, -1, -1}, {24451, -1, -1, -1}, {24450, -1, -1, -1}, {24447, -1, -1, -1}, {24458, -1, -1, -1}, {24456, -1, -1, -1}, {24465, -1, -1, -1}, {24455, -1, -1, -1}, {24478, -1, -1, -1}, {24473, -1, -1, -1}, {24472, -1, -1, -1}, {24480, -1, -1, -1}, {24488, -1, -1, -1}, {24493, -1, -1, -1}, {24508, -1, -1, -1}, {24534, -1, -1, -1}, {24571, -1, -1, -1}, {24548, -1, -1, -1}, {24568, -1, -1, -1}, {24561, -1, -1, -1}, {24541, -1, -1, -1}, {24755, -1, -1, -1}, {24575, -1, -1, -1}, {24609, -1, -1, -1}, {24672, -1, -1, -1}, {24601, -1, -1, -1}, {24592, -1, -1, -1}, {24617, -1, -1, -1}, {24590, -1, -1, -1}, {24625, -1, -1, -1}, {24603, -1, -1, -1}, {24597, -1, -1, -1}, {24619, -1, -1, -1}, {24614, -1, -1, -1}, {24591, -1, -1, -1}, {24634, -1, -1, -1}, {24666, -1, -1, -1}, {24641, -1, -1, -1}, {24682, -1, -1, -1}, {24695, -1, -1, -1}, {24671, -1, -1, -1}, {24650, -1, -1, -1}, {24646, -1, -1, -1}, {24653, -1, -1, -1}, {24675, -1, -1, -1}, {24643, -1, -1, -1}, {24676, -1, -1, -1}, {24642, -1, -1, -1}, {24684, -1, -1, -1}, {24683, -1, -1, -1}, {24665, -1, -1, -1}, {24705, -1, -1, -1}, {24717, -1, -1, -1}, {24807, -1, -1, -1}, {24707, -1, -1, -1}, {24730, -1, -1, -1}, {24708, -1, -1, -1}, {24731, -1, -1, -1}, {24726, -1, -1, -1}, {24727, -1, -1, -1}, {24722, -1, -1, -1}, {24743, -1, -1, -1}, {24715, -1, -1, -1}, {24801, -1, -1, -1}, {24760, -1, -1, -1}, {24800, -1, -1, -1}, {24787, -1, -1, -1}, {24756, -1, -1, -1}, {24560, -1, -1, -1}, {24765, -1, -1, -1}, {24774, -1, -1, -1}, {24757, -1, -1, -1}, {24792, -1, -1, -1}, {24909, -1, -1, -1}, {24853, -1, -1, -1}, {24838, -1, -1, -1}, {24822, -1, -1, -1}, {24823, -1, -1, -1} },
+ {{24832, -1, -1, -1}, {24820, -1, -1, -1}, {24826, -1, -1, -1}, {24835, -1, -1, -1}, {24865, -1, -1, -1}, {24827, -1, -1, -1}, {24817, -1, -1, -1}, {24845, -1, -1, -1}, {24846, -1, -1, -1}, {24903, -1, -1, -1}, {24894, -1, -1, -1}, {24872, -1, -1, -1}, {24871, -1, -1, -1}, {24906, -1, -1, -1}, {24895, -1, -1, -1}, {24892, -1, -1, -1}, {24876, -1, -1, -1}, {24884, -1, -1, -1}, {24893, -1, -1, -1}, {24898, -1, -1, -1}, {24900, -1, -1, -1}, {24947, -1, -1, -1}, {24951, -1, -1, -1}, {24920, -1, -1, -1}, {24921, -1, -1, -1}, {24922, -1, -1, -1}, {24939, -1, -1, -1}, {24948, -1, -1, -1}, {24943, -1, -1, -1}, {24933, -1, -1, -1}, {24945, -1, -1, -1}, {24927, -1, -1, -1}, {24925, -1, -1, -1}, {24915, -1, -1, -1}, {24949, -1, -1, -1}, {24985, -1, -1, -1}, {24982, -1, -1, -1}, {24967, -1, -1, -1}, {25004, -1, -1, -1}, {24980, -1, -1, -1}, {24986, -1, -1, -1}, {24970, -1, -1, -1}, {24977, -1, -1, -1}, {25003, -1, -1, -1}, {25006, -1, -1, -1}, {25036, -1, -1, -1}, {25034, -1, -1, -1}, {25033, -1, -1, -1}, {25079, -1, -1, -1}, {25032, -1, -1, -1}, {25027, -1, -1, -1}, {25030, -1, -1, -1}, {25018, -1, -1, -1}, {25035, -1, -1, -1}, {32633, -1, -1, -1}, {25037, -1, -1, -1}, {25062, -1, -1, -1}, {25059, -1, -1, -1}, {25078, -1, -1, -1}, {25082, -1, -1, -1}, {25076, -1, -1, -1}, {25087, -1, -1, -1}, {25085, -1, -1, -1}, {25084, -1, -1, -1}, {25086, -1, -1, -1}, {25088, -1, -1, -1}, {12093, 25096, -1, -1}, {25097, -1, -1, -1}, {25101, -1, -1, -1}, {25100, -1, -1, -1}, {25108, -1, -1, -1}, {25115, -1, -1, -1}, {25118, -1, -1, -1}, {25121, -1, -1, -1}, {25130, -1, -1, -1}, {25134, -1, -1, -1}, {25136, -1, -1, -1}, {25138, -1, -1, -1}, {25139, -1, -1, -1}, {25153, -1, -1, -1}, {25166, -1, -1, -1}, {25182, -1, -1, -1}, {25187, -1, -1, -1}, {25179, -1, -1, -1}, {25184, -1, -1, -1}, {25192, -1, -1, -1}, {25212, -1, -1, -1}, {25218, -1, -1, -1}, {25225, -1, -1, -1}, {25214, -1, -1, -1}, {25234, -1, -1, -1}, {25235, -1, -1, -1}, {25238, -1, -1, -1}, {25300, -1, -1, -1}, {25219, -1, -1, -1}, {25236, -1, -1, -1}, {25303, -1, -1, -1}, {25297, -1, -1, -1}, {25275, -1, -1, -1}, {25295, -1, -1, -1}, {25343, -1, -1, -1}, {25286, -1, -1, -1}, {25812, -1, -1, -1}, {25288, -1, -1, -1}, {25308, -1, -1, -1}, {25292, -1, -1, -1}, {25290, -1, -1, -1}, {25282, -1, -1, -1}, {25287, -1, -1, -1}, {25243, -1, -1, -1}, {25289, -1, -1, -1}, {25356, -1, -1, -1}, {25326, -1, -1, -1}, {25329, -1, -1, -1}, {25383, -1, -1, -1}, {25346, -1, -1, -1}, {25352, -1, -1, -1}, {25327, -1, -1, -1}, {25333, -1, -1, -1}, {25424, -1, -1, -1}, {25406, -1, -1, -1}, {25421, -1, -1, -1}, {25628, -1, -1, -1}, {25423, -1, -1, -1}, {25494, -1, -1, -1}, {25486, -1, -1, -1}, {25472, -1, -1, -1}, {25515, -1, -1, -1}, {25462, -1, -1, -1}, {25507, -1, -1, -1}, {25487, -1, -1, -1}, {25481, -1, -1, -1}, {25503, -1, -1, -1}, {25525, -1, -1, -1}, {25451, -1, -1, -1}, {25449, -1, -1, -1}, {25534, -1, -1, -1}, {25577, -1, -1, -1}, {25536, -1, -1, -1}, {25542, -1, -1, -1}, {25571, -1, -1, -1}, {25545, -1, -1, -1}, {25554, -1, -1, -1}, {25590, -1, -1, -1}, {25540, -1, -1, -1}, {25622, -1, -1, -1}, {25652, -1, -1, -1}, {25606, -1, -1, -1}, {25619, -1, -1, -1}, {25638, -1, -1, -1}, {25654, -1, -1, -1}, {25885, -1, -1, -1}, {25623, -1, -1, -1}, {25640, -1, -1, -1}, {25615, -1, -1, -1}, {25703, -1, -1, -1}, {25711, -1, -1, -1}, {25718, -1, -1, -1}, {25678, -1, -1, -1}, {25898, -1, -1, -1}, {25749, -1, -1, -1}, {25747, -1, -1, -1}, {25765, -1, -1, -1}, {25769, -1, -1, -1}, {25736, -1, -1, -1}, {25788, -1, -1, -1}, {25818, -1, -1, -1}, {25810, -1, -1, -1}, {25797, -1, -1, -1}, {25799, -1, -1, -1}, {25787, -1, -1, -1}, {25816, -1, -1, -1}, {25794, -1, -1, -1}, {25841, -1, -1, -1}, {25831, -1, -1, -1}, {33289, -1, -1, -1}, {25824, -1, -1, -1}, {25825, -1, -1, -1}, {25260, -1, -1, -1}, {25827, -1, -1, -1}, {25839, -1, -1, -1}, {25900, -1, -1, -1}, {25846, -1, -1, -1}, {25844, -1, -1, -1}, {25842, -1, -1, -1}, {25850, -1, -1, -1}, {25856, -1, -1, -1}, {25853, -1, -1, -1}, {25880, -1, -1, -1}, {25884, -1, -1, -1}, {25861, -1, -1, -1}, {25892, -1, -1, -1}, {25891, -1, -1, -1}, {25899, -1, -1, -1}, {12097, 25908, -1, -1}, {11929, 25909, -1, -1}, {25911, -1, -1, -1}, {25910, -1, -1, -1}, {25912, -1, -1, -1}, {30027, -1, -1, -1}, {25928, -1, -1, -1}, {25942, -1, -1, -1}, {25941, -1, -1, -1}, {25933, -1, -1, -1}, {25944, -1, -1, -1}, {25950, -1, -1, -1}, {25949, -1, -1, -1}, {25970, -1, -1, -1}, {25976, -1, -1, -1}, {25986, -1, -1, -1}, {25987, -1, -1, -1}, {35722, -1, -1, -1}, {26011, -1, -1, -1}, {26015, -1, -1, -1}, {26027, -1, -1, -1}, {26039, -1, -1, -1}, {26051, -1, -1, -1}, {26054, -1, -1, -1}, {26049, -1, -1, -1}, {26052, -1, -1, -1}, {26060, -1, -1, -1}, {26066, -1, -1, -1}, {26075, -1, -1, -1}, {26073, -1, -1, -1}, {12102, 26080, -1, -1}, {11931, 26081, -1, -1}, {26097, -1, -1, -1}, {26482, -1, -1, -1}, {26122, -1, -1, -1}, {26115, -1, -1, -1}, {26107, -1, -1, -1}, {26483, -1, -1, -1}, {26165, -1, -1, -1}, {26166, -1, -1, -1}, {26164, -1, -1, -1}, {26140, -1, -1, -1}, {26191, -1, -1, -1}, {26180, -1, -1, -1}, {26185, -1, -1, -1}, {26177, -1, -1, -1}, {26206, -1, -1, -1}, {26205, -1, -1, -1}, {26212, -1, -1, -1}, {26215, -1, -1, -1}, {26216, -1, -1, -1}, {26207, -1, -1, -1}, {26210, -1, -1, -1}, {26224, -1, -1, -1}, {26243, -1, -1, -1}, {26248, -1, -1, -1}, {26254, -1, -1, -1}, {26249, -1, -1, -1}, {26244, -1, -1, -1}, {26264, -1, -1, -1}, {26269, -1, -1, -1}, {26305, -1, -1, -1} },
+ {{26297, -1, -1, -1}, {26313, -1, -1, -1}, {26302, -1, -1, -1}, {26300, -1, -1, -1}, {26308, -1, -1, -1}, {26296, -1, -1, -1}, {26326, -1, -1, -1}, {26330, -1, -1, -1}, {26336, -1, -1, -1}, {26175, -1, -1, -1}, {26342, -1, -1, -1}, {26345, -1, -1, -1}, {12104, 26352, -1, -1}, {26357, -1, -1, -1}, {26359, -1, -1, -1}, {26383, -1, -1, -1}, {26390, -1, -1, -1}, {26398, -1, -1, -1}, {26406, -1, -1, -1}, {26407, -1, -1, -1}, {38712, -1, -1, -1}, {26414, -1, -1, -1}, {26431, -1, -1, -1}, {26422, -1, -1, -1}, {26433, -1, -1, -1}, {26424, -1, -1, -1}, {26423, -1, -1, -1}, {26438, -1, -1, -1}, {26462, -1, -1, -1}, {26464, -1, -1, -1}, {26457, -1, -1, -1}, {26467, -1, -1, -1}, {26468, -1, -1, -1}, {26505, -1, -1, -1}, {26480, -1, -1, -1}, {26537, -1, -1, -1}, {26492, -1, -1, -1}, {26474, -1, -1, -1}, {26508, -1, -1, -1}, {26507, -1, -1, -1}, {26534, -1, -1, -1}, {26529, -1, -1, -1}, {26501, -1, -1, -1}, {26551, -1, -1, -1}, {26607, -1, -1, -1}, {26548, -1, -1, -1}, {26604, -1, -1, -1}, {26547, -1, -1, -1}, {26601, -1, -1, -1}, {26552, -1, -1, -1}, {26596, -1, -1, -1}, {26590, -1, -1, -1}, {26589, -1, -1, -1}, {26594, -1, -1, -1}, {26606, -1, -1, -1}, {26553, -1, -1, -1}, {26574, -1, -1, -1}, {26566, -1, -1, -1}, {26599, -1, -1, -1}, {27292, -1, -1, -1}, {26654, -1, -1, -1}, {26694, -1, -1, -1}, {26665, -1, -1, -1}, {26688, -1, -1, -1}, {26701, -1, -1, -1}, {26674, -1, -1, -1}, {26702, -1, -1, -1}, {26803, -1, -1, -1}, {26667, -1, -1, -1}, {26713, -1, -1, -1}, {26723, -1, -1, -1}, {26743, -1, -1, -1}, {26751, -1, -1, -1}, {26783, -1, -1, -1}, {26767, -1, -1, -1}, {26797, -1, -1, -1}, {26772, -1, -1, -1}, {26781, -1, -1, -1}, {26779, -1, -1, -1}, {26755, -1, -1, -1}, {27310, -1, -1, -1}, {26809, -1, -1, -1}, {26740, -1, -1, -1}, {26805, -1, -1, -1}, {26784, -1, -1, -1}, {26810, -1, -1, -1}, {26895, -1, -1, -1}, {26765, -1, -1, -1}, {26750, -1, -1, -1}, {26881, -1, -1, -1}, {26826, -1, -1, -1}, {26888, -1, -1, -1}, {26840, -1, -1, -1}, {26914, -1, -1, -1}, {26918, -1, -1, -1}, {26849, -1, -1, -1}, {26892, -1, -1, -1}, {26829, -1, -1, -1}, {26836, -1, -1, -1}, {26855, -1, -1, -1}, {26837, -1, -1, -1}, {26934, -1, -1, -1}, {26898, -1, -1, -1}, {26884, -1, -1, -1}, {26839, -1, -1, -1}, {26851, -1, -1, -1}, {26917, -1, -1, -1}, {26873, -1, -1, -1}, {26848, -1, -1, -1}, {26863, -1, -1, -1}, {26920, -1, -1, -1}, {26922, -1, -1, -1}, {26906, -1, -1, -1}, {26915, -1, -1, -1}, {26913, -1, -1, -1}, {26822, -1, -1, -1}, {27001, -1, -1, -1}, {26999, -1, -1, -1}, {26972, -1, -1, -1}, {27000, -1, -1, -1}, {26987, -1, -1, -1}, {26964, -1, -1, -1}, {27006, -1, -1, -1}, {26990, -1, -1, -1}, {26937, -1, -1, -1}, {26996, -1, -1, -1}, {26941, -1, -1, -1}, {26969, -1, -1, -1}, {26928, -1, -1, -1}, {26977, -1, -1, -1}, {26974, -1, -1, -1}, {26973, -1, -1, -1}, {27009, -1, -1, -1}, {26986, -1, -1, -1}, {27058, -1, -1, -1}, {27054, -1, -1, -1}, {27088, -1, -1, -1}, {27071, -1, -1, -1}, {27073, -1, -1, -1}, {27091, -1, -1, -1}, {27070, -1, -1, -1}, {27086, -1, -1, -1}, {23528, -1, -1, -1}, {27082, -1, -1, -1}, {27101, -1, -1, -1}, {27067, -1, -1, -1}, {27075, -1, -1, -1}, {27047, -1, -1, -1}, {27182, -1, -1, -1}, {27025, -1, -1, -1}, {27040, -1, -1, -1}, {27036, -1, -1, -1}, {27029, -1, -1, -1}, {27060, -1, -1, -1}, {27102, -1, -1, -1}, {27112, -1, -1, -1}, {27138, -1, -1, -1}, {27163, -1, -1, -1}, {27135, -1, -1, -1}, {27402, -1, -1, -1}, {27129, -1, -1, -1}, {27122, -1, -1, -1}, {27111, -1, -1, -1}, {27141, -1, -1, -1}, {27057, -1, -1, -1}, {27166, -1, -1, -1}, {27117, -1, -1, -1}, {27156, -1, -1, -1}, {27115, -1, -1, -1}, {27146, -1, -1, -1}, {27154, -1, -1, -1}, {27329, -1, -1, -1}, {27171, -1, -1, -1}, {27155, -1, -1, -1}, {27204, -1, -1, -1}, {27148, -1, -1, -1}, {27250, -1, -1, -1}, {27190, -1, -1, -1}, {27256, -1, -1, -1}, {27207, -1, -1, -1}, {27234, -1, -1, -1}, {27225, -1, -1, -1}, {27238, -1, -1, -1}, {27208, -1, -1, -1}, {27192, -1, -1, -1}, {27170, -1, -1, -1}, {27280, -1, -1, -1}, {27277, -1, -1, -1}, {27296, -1, -1, -1}, {27268, -1, -1, -1}, {27298, -1, -1, -1}, {27299, -1, -1, -1}, {27287, -1, -1, -1}, {34327, -1, -1, -1}, {27323, -1, -1, -1}, {27331, -1, -1, -1}, {27330, -1, -1, -1}, {27320, -1, -1, -1}, {27315, -1, -1, -1}, {27308, -1, -1, -1}, {27358, -1, -1, -1}, {27345, -1, -1, -1}, {27359, -1, -1, -1}, {27306, -1, -1, -1}, {27354, -1, -1, -1}, {27370, -1, -1, -1}, {27387, -1, -1, -1}, {27397, -1, -1, -1}, {34326, -1, -1, -1}, {27386, -1, -1, -1}, {27410, -1, -1, -1}, {27414, -1, -1, -1}, {39729, -1, -1, -1}, {27423, -1, -1, -1}, {27448, -1, -1, -1}, {27447, -1, -1, -1}, {30428, -1, -1, -1}, {27449, -1, -1, -1}, {39150, -1, -1, -1}, {27463, -1, -1, -1}, {27459, -1, -1, -1}, {27465, -1, -1, -1}, {27472, -1, -1, -1}, {27481, -1, -1, -1}, {27476, -1, -1, -1}, {27483, -1, -1, -1}, {27487, -1, -1, -1}, {27489, -1, -1, -1}, {27512, -1, -1, -1}, {12109, 27513, -1, -1}, {27519, -1, -1, -1}, {27520, -1, -1, -1}, {27524, -1, -1, -1}, {27523, -1, -1, -1}, {27533, -1, -1, -1}, {27544, -1, -1, -1}, {27541, -1, -1, -1}, {27550, -1, -1, -1}, {27556, -1, -1, -1}, {27562, -1, -1, -1}, {27563, -1, -1, -1}, {27567, -1, -1, -1}, {27570, -1, -1, -1}, {27569, -1, -1, -1}, {12110, 27571, -1, -1}, {27575, -1, -1, -1}, {27580, -1, -1, -1}, {27590, -1, -1, -1}, {12111, 27595, -1, -1}, {27603, -1, -1, -1}, {27615, -1, -1, -1}, {27628, -1, -1, -1}, {27627, -1, -1, -1}, {27635, -1, -1, -1}, {27631, -1, -1, -1}, {40638, -1, -1, -1} },
+ {{27656, -1, -1, -1}, {27667, -1, -1, -1}, {12115, 27668, -1, -1}, {27675, -1, -1, -1}, {27684, -1, -1, -1}, {27683, -1, -1, -1}, {27742, -1, -1, -1}, {27733, -1, -1, -1}, {27746, -1, -1, -1}, {27754, -1, -1, -1}, {27778, -1, -1, -1}, {27789, -1, -1, -1}, {27802, -1, -1, -1}, {27777, -1, -1, -1}, {27803, -1, -1, -1}, {27774, -1, -1, -1}, {27752, -1, -1, -1}, {27763, -1, -1, -1}, {27794, -1, -1, -1}, {27792, -1, -1, -1}, {27844, -1, -1, -1}, {27889, -1, -1, -1}, {27859, -1, -1, -1}, {27837, -1, -1, -1}, {27863, -1, -1, -1}, {27845, -1, -1, -1}, {27869, -1, -1, -1}, {27822, -1, -1, -1}, {27825, -1, -1, -1}, {27838, -1, -1, -1}, {27834, -1, -1, -1}, {27867, -1, -1, -1}, {27887, -1, -1, -1}, {27865, -1, -1, -1}, {27882, -1, -1, -1}, {27935, -1, -1, -1}, {34893, -1, -1, -1}, {27958, -1, -1, -1}, {27947, -1, -1, -1}, {27965, -1, -1, -1}, {27960, -1, -1, -1}, {27929, -1, -1, -1}, {27957, -1, -1, -1}, {27955, -1, -1, -1}, {27922, -1, -1, -1}, {27916, -1, -1, -1}, {28003, -1, -1, -1}, {28051, -1, -1, -1}, {28004, -1, -1, -1}, {27994, -1, -1, -1}, {28025, -1, -1, -1}, {27993, -1, -1, -1}, {28046, -1, -1, -1}, {28053, -1, -1, -1}, {28644, -1, -1, -1}, {28037, -1, -1, -1}, {28153, -1, -1, -1}, {28181, -1, -1, -1}, {28170, -1, -1, -1}, {28085, -1, -1, -1}, {28103, -1, -1, -1}, {28134, -1, -1, -1}, {28088, -1, -1, -1}, {28102, -1, -1, -1}, {28140, -1, -1, -1}, {28126, -1, -1, -1}, {28108, -1, -1, -1}, {28136, -1, -1, -1}, {28114, -1, -1, -1}, {28101, -1, -1, -1}, {28154, -1, -1, -1}, {28121, -1, -1, -1}, {28132, -1, -1, -1}, {28117, -1, -1, -1}, {28138, -1, -1, -1}, {28142, -1, -1, -1}, {28205, -1, -1, -1}, {28270, -1, -1, -1}, {28206, -1, -1, -1}, {28185, -1, -1, -1}, {28274, -1, -1, -1}, {28255, -1, -1, -1}, {28222, -1, -1, -1}, {28195, -1, -1, -1}, {28267, -1, -1, -1}, {28203, -1, -1, -1}, {28278, -1, -1, -1}, {28237, -1, -1, -1}, {28191, -1, -1, -1}, {28227, -1, -1, -1}, {28218, -1, -1, -1}, {28238, -1, -1, -1}, {28196, -1, -1, -1}, {28415, -1, -1, -1}, {28189, -1, -1, -1}, {28216, -1, -1, -1}, {28290, -1, -1, -1}, {28330, -1, -1, -1}, {28312, -1, -1, -1}, {28361, -1, -1, -1}, {28343, -1, -1, -1}, {28371, -1, -1, -1}, {28349, -1, -1, -1}, {28335, -1, -1, -1}, {28356, -1, -1, -1}, {28338, -1, -1, -1}, {28372, -1, -1, -1}, {28373, -1, -1, -1}, {28303, -1, -1, -1}, {28325, -1, -1, -1}, {28354, -1, -1, -1}, {28319, -1, -1, -1}, {28481, -1, -1, -1}, {28433, -1, -1, -1}, {28748, -1, -1, -1}, {28396, -1, -1, -1}, {28408, -1, -1, -1}, {28414, -1, -1, -1}, {28479, -1, -1, -1}, {28402, -1, -1, -1}, {28465, -1, -1, -1}, {28399, -1, -1, -1}, {28466, -1, -1, -1}, {28364, -1, -1, -1}, {28478, -1, -1, -1}, {28435, -1, -1, -1}, {28407, -1, -1, -1}, {28550, -1, -1, -1}, {28538, -1, -1, -1}, {28536, -1, -1, -1}, {28545, -1, -1, -1}, {28544, -1, -1, -1}, {28527, -1, -1, -1}, {28507, -1, -1, -1}, {28659, -1, -1, -1}, {28525, -1, -1, -1}, {28546, -1, -1, -1}, {28540, -1, -1, -1}, {28504, -1, -1, -1}, {28558, -1, -1, -1}, {28561, -1, -1, -1}, {28610, -1, -1, -1}, {28518, -1, -1, -1}, {28595, -1, -1, -1}, {28579, -1, -1, -1}, {28577, -1, -1, -1}, {28580, -1, -1, -1}, {28601, -1, -1, -1}, {28614, -1, -1, -1}, {28586, -1, -1, -1}, {28639, -1, -1, -1}, {28629, -1, -1, -1}, {28652, -1, -1, -1}, {28628, -1, -1, -1}, {28632, -1, -1, -1}, {28657, -1, -1, -1}, {28654, -1, -1, -1}, {28635, -1, -1, -1}, {28681, -1, -1, -1}, {28683, -1, -1, -1}, {28666, -1, -1, -1}, {28689, -1, -1, -1}, {28673, -1, -1, -1}, {28687, -1, -1, -1}, {28670, -1, -1, -1}, {28699, -1, -1, -1}, {28698, -1, -1, -1}, {28532, -1, -1, -1}, {28701, -1, -1, -1}, {28696, -1, -1, -1}, {28703, -1, -1, -1}, {28720, -1, -1, -1}, {28734, -1, -1, -1}, {28722, -1, -1, -1}, {28753, -1, -1, -1}, {28771, -1, -1, -1}, {28825, -1, -1, -1}, {28818, -1, -1, -1}, {28847, -1, -1, -1}, {28913, -1, -1, -1}, {28844, -1, -1, -1}, {28856, -1, -1, -1}, {28851, -1, -1, -1}, {28846, -1, -1, -1}, {28895, -1, -1, -1}, {28875, -1, -1, -1}, {28893, -1, -1, -1}, {28889, -1, -1, -1}, {28937, -1, -1, -1}, {28925, -1, -1, -1}, {28956, -1, -1, -1}, {28953, -1, -1, -1}, {29029, -1, -1, -1}, {29013, -1, -1, -1}, {29064, -1, -1, -1}, {29030, -1, -1, -1}, {29026, -1, -1, -1}, {29004, -1, -1, -1}, {29014, -1, -1, -1}, {29036, -1, -1, -1}, {29071, -1, -1, -1}, {29179, -1, -1, -1}, {29060, -1, -1, -1}, {29077, -1, -1, -1}, {29096, -1, -1, -1}, {29100, -1, -1, -1}, {29143, -1, -1, -1}, {29113, -1, -1, -1}, {29118, -1, -1, -1}, {29138, -1, -1, -1}, {29129, -1, -1, -1}, {29140, -1, -1, -1}, {29134, -1, -1, -1}, {29152, -1, -1, -1}, {29164, -1, -1, -1}, {29159, -1, -1, -1}, {29173, -1, -1, -1}, {29180, -1, -1, -1}, {29177, -1, -1, -1}, {29183, -1, -1, -1}, {29197, -1, -1, -1}, {29200, -1, -1, -1}, {29211, -1, -1, -1}, {29224, -1, -1, -1}, {29229, -1, -1, -1}, {29228, -1, -1, -1}, {29232, -1, -1, -1}, {29234, -1, -1, -1}, {12120, 29243, -1, -1}, {29244, -1, -1, -1}, {12121, 29247, -1, -1}, {29248, -1, -1, -1}, {29254, -1, -1, -1}, {29259, -1, -1, -1}, {29272, -1, -1, -1}, {29300, -1, -1, -1}, {29310, -1, -1, -1}, {29314, -1, -1, -1}, {29313, -1, -1, -1}, {29319, -1, -1, -1}, {29330, -1, -1, -1}, {29334, -1, -1, -1}, {29346, -1, -1, -1}, {29351, -1, -1, -1}, {29369, -1, -1, -1}, {29362, -1, -1, -1}, {29379, -1, -1, -1}, {29382, -1, -1, -1}, {29380, -1, -1, -1}, {29390, -1, -1, -1}, {29394, -1, -1, -1}, {29410, -1, -1, -1}, {29408, -1, -1, -1}, {29409, -1, -1, -1}, {29433, -1, -1, -1}, {29431, -1, -1, -1} },
+ {{20495, -1, -1, -1}, {29463, -1, -1, -1}, {29450, -1, -1, -1}, {29468, -1, -1, -1}, {29462, -1, -1, -1}, {29469, -1, -1, -1}, {29492, -1, -1, -1}, {29487, -1, -1, -1}, {29481, -1, -1, -1}, {29477, -1, -1, -1}, {29502, -1, -1, -1}, {29518, -1, -1, -1}, {29519, -1, -1, -1}, {40664, -1, -1, -1}, {29527, -1, -1, -1}, {29546, -1, -1, -1}, {29544, -1, -1, -1}, {29552, -1, -1, -1}, {29560, -1, -1, -1}, {29557, -1, -1, -1}, {29563, -1, -1, -1}, {29562, -1, -1, -1}, {29640, -1, -1, -1}, {29619, -1, -1, -1}, {29646, -1, -1, -1}, {29627, -1, -1, -1}, {29632, -1, -1, -1}, {29669, -1, -1, -1}, {29678, -1, -1, -1}, {29662, -1, -1, -1}, {29858, -1, -1, -1}, {29701, -1, -1, -1}, {29807, -1, -1, -1}, {29733, -1, -1, -1}, {29688, -1, -1, -1}, {29746, -1, -1, -1}, {29754, -1, -1, -1}, {29781, -1, -1, -1}, {29759, -1, -1, -1}, {29791, -1, -1, -1}, {29785, -1, -1, -1}, {29761, -1, -1, -1}, {29788, -1, -1, -1}, {29801, -1, -1, -1}, {29808, -1, -1, -1}, {29795, -1, -1, -1}, {29802, -1, -1, -1}, {29814, -1, -1, -1}, {29822, -1, -1, -1}, {29835, -1, -1, -1}, {29854, -1, -1, -1}, {29863, -1, -1, -1}, {29898, -1, -1, -1}, {29903, -1, -1, -1}, {29908, -1, -1, -1}, {29681, -1, -1, -1}, {29920, -1, -1, -1}, {29923, -1, -1, -1}, {29927, -1, -1, -1}, {29929, -1, -1, -1}, {29934, -1, -1, -1}, {29938, -1, -1, -1}, {29936, -1, -1, -1}, {29937, -1, -1, -1}, {29944, -1, -1, -1}, {29943, -1, -1, -1}, {29956, -1, -1, -1}, {29955, -1, -1, -1}, {29957, -1, -1, -1}, {29964, -1, -1, -1}, {29966, -1, -1, -1}, {29965, -1, -1, -1}, {29973, -1, -1, -1}, {29971, -1, -1, -1}, {29982, -1, -1, -1}, {29990, -1, -1, -1}, {29996, -1, -1, -1}, {30012, -1, -1, -1}, {30020, -1, -1, -1}, {30029, -1, -1, -1}, {30026, -1, -1, -1}, {30025, -1, -1, -1}, {30043, -1, -1, -1}, {30022, -1, -1, -1}, {30042, -1, -1, -1}, {30057, -1, -1, -1}, {30052, -1, -1, -1}, {30055, -1, -1, -1}, {30059, -1, -1, -1}, {30061, -1, -1, -1}, {30072, -1, -1, -1}, {30070, -1, -1, -1}, {30086, -1, -1, -1}, {30087, -1, -1, -1}, {30068, -1, -1, -1}, {30090, -1, -1, -1}, {30089, -1, -1, -1}, {30082, -1, -1, -1}, {30100, -1, -1, -1}, {30106, -1, -1, -1}, {30109, -1, -1, -1}, {30117, -1, -1, -1}, {30115, -1, -1, -1}, {30146, -1, -1, -1}, {30131, -1, -1, -1}, {30147, -1, -1, -1}, {30133, -1, -1, -1}, {30141, -1, -1, -1}, {30136, -1, -1, -1}, {30140, -1, -1, -1}, {30129, -1, -1, -1}, {30157, -1, -1, -1}, {30154, -1, -1, -1}, {30162, -1, -1, -1}, {30169, -1, -1, -1}, {30179, -1, -1, -1}, {30174, -1, -1, -1}, {30206, -1, -1, -1}, {30207, -1, -1, -1}, {30204, -1, -1, -1}, {30209, -1, -1, -1}, {30192, -1, -1, -1}, {30202, -1, -1, -1}, {30194, -1, -1, -1}, {30195, -1, -1, -1}, {30219, -1, -1, -1}, {30221, -1, -1, -1}, {30217, -1, -1, -1}, {30239, -1, -1, -1}, {30247, -1, -1, -1}, {30240, -1, -1, -1}, {30241, -1, -1, -1}, {30242, -1, -1, -1}, {30244, -1, -1, -1}, {30260, -1, -1, -1}, {30256, -1, -1, -1}, {30267, -1, -1, -1}, {30279, -1, -1, -1}, {30280, -1, -1, -1}, {30278, -1, -1, -1}, {30300, -1, -1, -1}, {30296, -1, -1, -1}, {30305, -1, -1, -1}, {30306, -1, -1, -1}, {30312, -1, -1, -1}, {30313, -1, -1, -1}, {30314, -1, -1, -1}, {30311, -1, -1, -1}, {30316, -1, -1, -1}, {30320, -1, -1, -1}, {30322, -1, -1, -1}, {12136, 30326, -1, -1}, {30328, -1, -1, -1}, {30332, -1, -1, -1}, {30336, -1, -1, -1}, {30339, -1, -1, -1}, {30344, -1, -1, -1}, {30347, -1, -1, -1}, {30350, -1, -1, -1}, {30358, -1, -1, -1}, {30355, -1, -1, -1}, {30361, -1, -1, -1}, {30362, -1, -1, -1}, {30384, -1, -1, -1}, {30388, -1, -1, -1}, {30392, -1, -1, -1}, {30393, -1, -1, -1}, {30394, -1, -1, -1}, {30402, -1, -1, -1}, {30413, -1, -1, -1}, {30422, -1, -1, -1}, {30418, -1, -1, -1}, {30430, -1, -1, -1}, {30433, -1, -1, -1}, {30437, -1, -1, -1}, {30439, -1, -1, -1}, {30442, -1, -1, -1}, {34351, -1, -1, -1}, {30459, -1, -1, -1}, {30472, -1, -1, -1}, {30471, -1, -1, -1}, {30468, -1, -1, -1}, {30505, -1, -1, -1}, {30500, -1, -1, -1}, {30494, -1, -1, -1}, {30501, -1, -1, -1}, {30502, -1, -1, -1}, {30491, -1, -1, -1}, {30519, -1, -1, -1}, {30520, -1, -1, -1}, {30535, -1, -1, -1}, {30554, -1, -1, -1}, {30568, -1, -1, -1}, {30571, -1, -1, -1}, {30555, -1, -1, -1}, {30565, -1, -1, -1}, {30591, -1, -1, -1}, {30590, -1, -1, -1}, {30585, -1, -1, -1}, {30606, -1, -1, -1}, {30603, -1, -1, -1}, {30609, -1, -1, -1}, {30624, -1, -1, -1}, {30622, -1, -1, -1}, {30640, -1, -1, -1}, {30646, -1, -1, -1}, {30649, -1, -1, -1}, {30655, -1, -1, -1}, {30652, -1, -1, -1}, {30653, -1, -1, -1}, {30651, -1, -1, -1}, {30663, -1, -1, -1}, {30669, -1, -1, -1}, {30679, -1, -1, -1}, {30682, -1, -1, -1}, {30684, -1, -1, -1}, {30691, -1, -1, -1}, {30702, -1, -1, -1}, {30716, -1, -1, -1}, {30732, -1, -1, -1}, {30738, -1, -1, -1}, {31014, -1, -1, -1}, {30752, -1, -1, -1}, {31018, -1, -1, -1}, {30789, -1, -1, -1}, {30862, -1, -1, -1}, {30836, -1, -1, -1}, {30854, -1, -1, -1}, {30844, -1, -1, -1}, {30874, -1, -1, -1}, {30860, -1, -1, -1}, {30883, -1, -1, -1}, {30901, -1, -1, -1}, {30890, -1, -1, -1}, {30895, -1, -1, -1}, {30929, -1, -1, -1}, {30918, -1, -1, -1}, {30923, -1, -1, -1}, {30932, -1, -1, -1}, {30910, -1, -1, -1}, {30908, -1, -1, -1}, {30917, -1, -1, -1}, {30922, -1, -1, -1}, {30956, -1, -1, -1}, {30951, -1, -1, -1}, {30938, -1, -1, -1}, {30973, -1, -1, -1}, {30964, -1, -1, -1}, {30983, -1, -1, -1}, {30994, -1, -1, -1}, {30993, -1, -1, -1}, {31001, -1, -1, -1}, {31020, -1, -1, -1}, {31019, -1, -1, -1}, {31040, -1, -1, -1}, {31072, -1, -1, -1} },
+ {{31063, -1, -1, -1}, {31071, -1, -1, -1}, {31066, -1, -1, -1}, {31061, -1, -1, -1}, {31059, -1, -1, -1}, {31098, -1, -1, -1}, {31103, -1, -1, -1}, {31114, -1, -1, -1}, {31133, -1, -1, -1}, {31143, -1, -1, -1}, {40779, -1, -1, -1}, {31146, -1, -1, -1}, {31150, -1, -1, -1}, {31155, -1, -1, -1}, {31161, -1, -1, -1}, {31162, -1, -1, -1}, {31177, -1, -1, -1}, {31189, -1, -1, -1}, {31207, -1, -1, -1}, {31212, -1, -1, -1}, {31201, -1, -1, -1}, {31203, -1, -1, -1}, {31240, -1, -1, -1}, {31245, -1, -1, -1}, {31256, -1, -1, -1}, {31257, -1, -1, -1}, {31264, -1, -1, -1}, {31263, -1, -1, -1}, {31104, -1, -1, -1}, {31281, -1, -1, -1}, {31291, -1, -1, -1}, {31294, -1, -1, -1}, {31287, -1, -1, -1}, {31299, -1, -1, -1}, {31319, -1, -1, -1}, {31305, -1, -1, -1}, {31329, -1, -1, -1}, {31330, -1, -1, -1}, {31337, -1, -1, -1}, {40861, -1, -1, -1}, {31344, -1, -1, -1}, {31353, -1, -1, -1}, {31357, -1, -1, -1}, {31368, -1, -1, -1}, {31383, -1, -1, -1}, {31381, -1, -1, -1}, {31384, -1, -1, -1}, {31382, -1, -1, -1}, {31401, -1, -1, -1}, {31432, -1, -1, -1}, {31408, -1, -1, -1}, {31414, -1, -1, -1}, {31429, -1, -1, -1}, {31428, -1, -1, -1}, {31423, -1, -1, -1}, {36995, -1, -1, -1}, {31431, -1, -1, -1}, {31434, -1, -1, -1}, {31437, -1, -1, -1}, {31439, -1, -1, -1}, {31445, -1, -1, -1}, {31443, -1, -1, -1}, {31449, -1, -1, -1}, {31450, -1, -1, -1}, {31453, -1, -1, -1}, {31457, -1, -1, -1}, {31458, -1, -1, -1}, {31462, -1, -1, -1}, {31469, -1, -1, -1}, {31472, -1, -1, -1}, {31490, -1, -1, -1}, {31503, -1, -1, -1}, {31498, -1, -1, -1}, {31494, -1, -1, -1}, {31539, -1, -1, -1}, {31512, -1, -1, -1}, {31513, -1, -1, -1}, {31518, -1, -1, -1}, {31541, -1, -1, -1}, {31528, -1, -1, -1}, {31542, -1, -1, -1}, {31568, -1, -1, -1}, {31610, -1, -1, -1}, {31492, -1, -1, -1}, {31565, -1, -1, -1}, {31499, -1, -1, -1}, {31564, -1, -1, -1}, {31557, -1, -1, -1}, {31605, -1, -1, -1}, {31589, -1, -1, -1}, {31604, -1, -1, -1}, {31591, -1, -1, -1}, {31600, -1, -1, -1}, {31601, -1, -1, -1}, {31596, -1, -1, -1}, {31598, -1, -1, -1}, {31645, -1, -1, -1}, {31640, -1, -1, -1}, {31647, -1, -1, -1}, {31629, -1, -1, -1}, {31644, -1, -1, -1}, {31642, -1, -1, -1}, {31627, -1, -1, -1}, {31634, -1, -1, -1}, {31631, -1, -1, -1}, {31581, -1, -1, -1}, {31641, -1, -1, -1}, {31691, -1, -1, -1}, {31681, -1, -1, -1}, {31692, -1, -1, -1}, {31695, -1, -1, -1}, {31668, -1, -1, -1}, {31686, -1, -1, -1}, {31709, -1, -1, -1}, {31721, -1, -1, -1}, {31761, -1, -1, -1}, {31764, -1, -1, -1}, {31718, -1, -1, -1}, {31717, -1, -1, -1}, {31840, -1, -1, -1}, {31744, -1, -1, -1}, {31751, -1, -1, -1}, {31763, -1, -1, -1}, {31731, -1, -1, -1}, {31735, -1, -1, -1}, {31767, -1, -1, -1}, {31757, -1, -1, -1}, {31734, -1, -1, -1}, {31779, -1, -1, -1}, {31783, -1, -1, -1}, {31786, -1, -1, -1}, {31775, -1, -1, -1}, {31799, -1, -1, -1}, {31787, -1, -1, -1}, {31805, -1, -1, -1}, {31820, -1, -1, -1}, {31811, -1, -1, -1}, {31828, -1, -1, -1}, {31823, -1, -1, -1}, {31808, -1, -1, -1}, {31824, -1, -1, -1}, {31832, -1, -1, -1}, {31839, -1, -1, -1}, {31844, -1, -1, -1}, {31830, -1, -1, -1}, {31845, -1, -1, -1}, {31852, -1, -1, -1}, {31861, -1, -1, -1}, {31875, -1, -1, -1}, {31888, -1, -1, -1}, {31908, -1, -1, -1}, {31917, -1, -1, -1}, {31906, -1, -1, -1}, {31915, -1, -1, -1}, {31905, -1, -1, -1}, {31912, -1, -1, -1}, {31923, -1, -1, -1}, {31922, -1, -1, -1}, {31921, -1, -1, -1}, {31918, -1, -1, -1}, {31929, -1, -1, -1}, {31933, -1, -1, -1}, {31936, -1, -1, -1}, {31941, -1, -1, -1}, {31938, -1, -1, -1}, {31960, -1, -1, -1}, {31954, -1, -1, -1}, {31964, -1, -1, -1}, {31970, -1, -1, -1}, {39739, -1, -1, -1}, {31983, -1, -1, -1}, {31986, -1, -1, -1}, {31988, -1, -1, -1}, {31990, -1, -1, -1}, {31994, -1, -1, -1}, {32006, -1, -1, -1}, {32002, -1, -1, -1}, {32028, -1, -1, -1}, {32021, -1, -1, -1}, {32010, -1, -1, -1}, {32069, -1, -1, -1}, {32075, -1, -1, -1}, {32046, -1, -1, -1}, {32050, -1, -1, -1}, {32063, -1, -1, -1}, {32053, -1, -1, -1}, {32070, -1, -1, -1}, {32115, -1, -1, -1}, {32086, -1, -1, -1}, {32078, -1, -1, -1}, {32114, -1, -1, -1}, {32104, -1, -1, -1}, {32110, -1, -1, -1}, {32079, -1, -1, -1}, {32099, -1, -1, -1}, {32147, -1, -1, -1}, {32137, -1, -1, -1}, {32091, -1, -1, -1}, {32143, -1, -1, -1}, {32125, -1, -1, -1}, {32155, -1, -1, -1}, {32186, -1, -1, -1}, {32174, -1, -1, -1}, {32163, -1, -1, -1}, {32181, -1, -1, -1}, {32199, -1, -1, -1}, {32189, -1, -1, -1}, {32171, -1, -1, -1}, {32317, -1, -1, -1}, {32162, -1, -1, -1}, {32175, -1, -1, -1}, {32220, -1, -1, -1}, {32184, -1, -1, -1}, {32159, -1, -1, -1}, {32176, -1, -1, -1}, {32216, -1, -1, -1}, {32221, -1, -1, -1}, {32228, -1, -1, -1}, {32222, -1, -1, -1}, {32251, -1, -1, -1}, {32242, -1, -1, -1}, {32225, -1, -1, -1}, {32261, -1, -1, -1}, {32266, -1, -1, -1}, {32291, -1, -1, -1}, {32289, -1, -1, -1}, {32274, -1, -1, -1}, {32305, -1, -1, -1}, {32287, -1, -1, -1}, {32265, -1, -1, -1}, {32267, -1, -1, -1}, {32290, -1, -1, -1}, {32326, -1, -1, -1}, {32358, -1, -1, -1}, {32315, -1, -1, -1}, {32309, -1, -1, -1}, {32313, -1, -1, -1}, {32323, -1, -1, -1}, {32311, -1, -1, -1}, {32306, -1, -1, -1}, {32314, -1, -1, -1}, {32359, -1, -1, -1}, {32349, -1, -1, -1}, {32342, -1, -1, -1}, {32350, -1, -1, -1}, {32345, -1, -1, -1}, {32346, -1, -1, -1}, {32377, -1, -1, -1}, {32362, -1, -1, -1}, {32361, -1, -1, -1}, {32380, -1, -1, -1}, {32379, -1, -1, -1}, {32387, -1, -1, -1}, {32213, -1, -1, -1}, {32381, -1, -1, -1}, {36782, -1, -1, -1} },
+ {{32383, -1, -1, -1}, {32392, -1, -1, -1}, {32393, -1, -1, -1}, {32396, -1, -1, -1}, {32402, -1, -1, -1}, {32400, -1, -1, -1}, {32403, -1, -1, -1}, {32404, -1, -1, -1}, {32406, -1, -1, -1}, {32398, -1, -1, -1}, {32411, -1, -1, -1}, {32412, -1, -1, -1}, {32568, -1, -1, -1}, {32570, -1, -1, -1}, {32581, -1, -1, -1}, {32588, -1, -1, -1}, {32589, -1, -1, -1}, {32590, -1, -1, -1}, {32592, -1, -1, -1}, {12153, 32593, -1, -1}, {32597, -1, -1, -1}, {32596, -1, -1, -1}, {32600, -1, -1, -1}, {32607, -1, -1, -1}, {32608, -1, -1, -1}, {32616, -1, -1, -1}, {32617, -1, -1, -1}, {32615, -1, -1, -1}, {32632, -1, -1, -1}, {32642, -1, -1, -1}, {32646, -1, -1, -1}, {32643, -1, -1, -1}, {32648, -1, -1, -1}, {32647, -1, -1, -1}, {32652, -1, -1, -1}, {32660, -1, -1, -1}, {32670, -1, -1, -1}, {32669, -1, -1, -1}, {32666, -1, -1, -1}, {32675, -1, -1, -1}, {32687, -1, -1, -1}, {32690, -1, -1, -1}, {32697, -1, -1, -1}, {32686, -1, -1, -1}, {32694, -1, -1, -1}, {32696, -1, -1, -1}, {35697, -1, -1, -1}, {32709, -1, -1, -1}, {32710, -1, -1, -1}, {32714, -1, -1, -1}, {32725, -1, -1, -1}, {32724, -1, -1, -1}, {32737, -1, -1, -1}, {32742, -1, -1, -1}, {32745, -1, -1, -1}, {32755, -1, -1, -1}, {32761, -1, -1, -1}, {39132, -1, -1, -1}, {32774, -1, -1, -1}, {32772, -1, -1, -1}, {32779, -1, -1, -1}, {12158, 32786, -1, -1}, {32792, -1, -1, -1}, {32793, -1, -1, -1}, {32796, -1, -1, -1}, {32801, -1, -1, -1}, {32808, -1, -1, -1}, {32831, -1, -1, -1}, {32827, -1, -1, -1}, {32842, -1, -1, -1}, {32838, -1, -1, -1}, {32850, -1, -1, -1}, {32856, -1, -1, -1}, {32858, -1, -1, -1}, {32863, -1, -1, -1}, {32866, -1, -1, -1}, {32872, -1, -1, -1}, {32883, -1, -1, -1}, {32882, -1, -1, -1}, {32880, -1, -1, -1}, {32886, -1, -1, -1}, {32889, -1, -1, -1}, {32893, -1, -1, -1}, {12160, 32895, -1, -1}, {32900, -1, -1, -1}, {32902, -1, -1, -1}, {32901, -1, -1, -1}, {32923, -1, -1, -1}, {32915, -1, -1, -1}, {32922, -1, -1, -1}, {32941, -1, -1, -1}, {20880, -1, -1, -1}, {32940, -1, -1, -1}, {32987, -1, -1, -1}, {32997, -1, -1, -1}, {32985, -1, -1, -1}, {32989, -1, -1, -1}, {32964, -1, -1, -1}, {32986, -1, -1, -1}, {32982, -1, -1, -1}, {33033, -1, -1, -1}, {33007, -1, -1, -1}, {33009, -1, -1, -1}, {33051, -1, -1, -1}, {33065, -1, -1, -1}, {33059, -1, -1, -1}, {33071, -1, -1, -1}, {33099, -1, -1, -1}, {38539, -1, -1, -1}, {33094, -1, -1, -1}, {33086, -1, -1, -1}, {33107, -1, -1, -1}, {33105, -1, -1, -1}, {33020, -1, -1, -1}, {33137, -1, -1, -1}, {33134, -1, -1, -1}, {33125, -1, -1, -1}, {33126, -1, -1, -1}, {33140, -1, -1, -1}, {33155, -1, -1, -1}, {33160, -1, -1, -1}, {33162, -1, -1, -1}, {33152, -1, -1, -1}, {33154, -1, -1, -1}, {33184, -1, -1, -1}, {33173, -1, -1, -1}, {33188, -1, -1, -1}, {33187, -1, -1, -1}, {33119, -1, -1, -1}, {33171, -1, -1, -1}, {33193, -1, -1, -1}, {33200, -1, -1, -1}, {33205, -1, -1, -1}, {33214, -1, -1, -1}, {33208, -1, -1, -1}, {33213, -1, -1, -1}, {33216, -1, -1, -1}, {33218, -1, -1, -1}, {33210, -1, -1, -1}, {33225, -1, -1, -1}, {33229, -1, -1, -1}, {33233, -1, -1, -1}, {33241, -1, -1, -1}, {33240, -1, -1, -1}, {33224, -1, -1, -1}, {33242, -1, -1, -1}, {33247, -1, -1, -1}, {33248, -1, -1, -1}, {33255, -1, -1, -1}, {33274, -1, -1, -1}, {33275, -1, -1, -1}, {33278, -1, -1, -1}, {33281, -1, -1, -1}, {33282, -1, -1, -1}, {33285, -1, -1, -1}, {33287, -1, -1, -1}, {33290, -1, -1, -1}, {33293, -1, -1, -1}, {33296, -1, -1, -1}, {33302, -1, -1, -1}, {33321, -1, -1, -1}, {33323, -1, -1, -1}, {33336, -1, -1, -1}, {33331, -1, -1, -1}, {33344, -1, -1, -1}, {33369, -1, -1, -1}, {33368, -1, -1, -1}, {33373, -1, -1, -1}, {33370, -1, -1, -1}, {33375, -1, -1, -1}, {33380, -1, -1, -1}, {33378, -1, -1, -1}, {33384, -1, -1, -1}, {33386, -1, -1, -1}, {33387, -1, -1, -1}, {33326, -1, -1, -1}, {33393, -1, -1, -1}, {33399, -1, -1, -1}, {12171, 33400, -1, -1}, {33406, -1, -1, -1}, {33421, -1, -1, -1}, {33426, -1, -1, -1}, {33451, -1, -1, -1}, {33439, -1, -1, -1}, {33467, -1, -1, -1}, {33452, -1, -1, -1}, {33505, -1, -1, -1}, {33507, -1, -1, -1}, {33503, -1, -1, -1}, {33490, -1, -1, -1}, {33524, -1, -1, -1}, {33523, -1, -1, -1}, {33530, -1, -1, -1}, {33683, -1, -1, -1}, {33539, -1, -1, -1}, {33531, -1, -1, -1}, {33529, -1, -1, -1}, {33502, -1, -1, -1}, {33542, -1, -1, -1}, {33500, -1, -1, -1}, {33545, -1, -1, -1}, {33497, -1, -1, -1}, {33589, -1, -1, -1}, {33588, -1, -1, -1}, {33558, -1, -1, -1}, {33586, -1, -1, -1}, {33585, -1, -1, -1}, {33600, -1, -1, -1}, {33593, -1, -1, -1}, {33616, -1, -1, -1}, {33605, -1, -1, -1}, {33583, -1, -1, -1}, {33579, -1, -1, -1}, {33559, -1, -1, -1}, {33560, -1, -1, -1}, {33669, -1, -1, -1}, {33690, -1, -1, -1}, {33706, -1, -1, -1}, {33695, -1, -1, -1}, {33698, -1, -1, -1}, {33686, -1, -1, -1}, {33571, -1, -1, -1}, {33678, -1, -1, -1}, {33671, -1, -1, -1}, {33674, -1, -1, -1}, {33660, -1, -1, -1}, {33717, -1, -1, -1}, {33651, -1, -1, -1}, {33653, -1, -1, -1}, {33696, -1, -1, -1}, {33673, -1, -1, -1}, {33704, -1, -1, -1}, {33780, -1, -1, -1}, {33811, -1, -1, -1}, {33771, -1, -1, -1}, {33742, -1, -1, -1}, {33789, -1, -1, -1}, {33795, -1, -1, -1}, {33752, -1, -1, -1}, {33803, -1, -1, -1}, {33729, -1, -1, -1}, {33783, -1, -1, -1}, {33799, -1, -1, -1}, {33760, -1, -1, -1}, {33778, -1, -1, -1}, {33805, -1, -1, -1}, {33826, -1, -1, -1}, {33824, -1, -1, -1}, {33725, -1, -1, -1}, {33848, -1, -1, -1}, {34054, -1, -1, -1}, {33787, -1, -1, -1}, {33901, -1, -1, -1}, {33834, -1, -1, -1}, {33852, -1, -1, -1}, {34138, -1, -1, -1} },
+ {{33924, -1, -1, -1}, {33911, -1, -1, -1}, {33899, -1, -1, -1}, {33965, -1, -1, -1}, {33902, -1, -1, -1}, {33922, -1, -1, -1}, {33897, -1, -1, -1}, {33862, -1, -1, -1}, {33836, -1, -1, -1}, {33903, -1, -1, -1}, {33913, -1, -1, -1}, {33845, -1, -1, -1}, {33994, -1, -1, -1}, {33890, -1, -1, -1}, {33977, -1, -1, -1}, {33983, -1, -1, -1}, {33951, -1, -1, -1}, {34009, -1, -1, -1}, {33997, -1, -1, -1}, {33979, -1, -1, -1}, {34010, -1, -1, -1}, {34000, -1, -1, -1}, {33985, -1, -1, -1}, {33990, -1, -1, -1}, {34006, -1, -1, -1}, {33953, -1, -1, -1}, {34081, -1, -1, -1}, {34047, -1, -1, -1}, {34036, -1, -1, -1}, {34071, -1, -1, -1}, {34072, -1, -1, -1}, {34092, -1, -1, -1}, {34079, -1, -1, -1}, {34069, -1, -1, -1}, {34068, -1, -1, -1}, {34044, -1, -1, -1}, {34112, -1, -1, -1}, {34147, -1, -1, -1}, {34136, -1, -1, -1}, {34120, -1, -1, -1}, {34113, -1, -1, -1}, {34306, -1, -1, -1}, {34123, -1, -1, -1}, {34133, -1, -1, -1}, {34176, -1, -1, -1}, {34212, -1, -1, -1}, {34184, -1, -1, -1}, {34193, -1, -1, -1}, {34186, -1, -1, -1}, {34216, -1, -1, -1}, {34157, -1, -1, -1}, {34196, -1, -1, -1}, {34203, -1, -1, -1}, {34282, -1, -1, -1}, {34183, -1, -1, -1}, {34204, -1, -1, -1}, {34167, -1, -1, -1}, {34174, -1, -1, -1}, {34192, -1, -1, -1}, {34249, -1, -1, -1}, {34234, -1, -1, -1}, {34255, -1, -1, -1}, {34233, -1, -1, -1}, {34256, -1, -1, -1}, {34261, -1, -1, -1}, {34269, -1, -1, -1}, {34277, -1, -1, -1}, {34268, -1, -1, -1}, {34297, -1, -1, -1}, {34314, -1, -1, -1}, {34323, -1, -1, -1}, {34315, -1, -1, -1}, {34302, -1, -1, -1}, {34298, -1, -1, -1}, {34310, -1, -1, -1}, {34338, -1, -1, -1}, {34330, -1, -1, -1}, {34352, -1, -1, -1}, {34367, -1, -1, -1}, {12172, 34381, -1, -1}, {20053, -1, -1, -1}, {34388, -1, -1, -1}, {34399, -1, -1, -1}, {34407, -1, -1, -1}, {34417, -1, -1, -1}, {34451, -1, -1, -1}, {34467, -1, -1, -1}, {34473, -1, -1, -1}, {34474, -1, -1, -1}, {34443, -1, -1, -1}, {34444, -1, -1, -1}, {34486, -1, -1, -1}, {34479, -1, -1, -1}, {34500, -1, -1, -1}, {34502, -1, -1, -1}, {34480, -1, -1, -1}, {34505, -1, -1, -1}, {34851, -1, -1, -1}, {34475, -1, -1, -1}, {34516, -1, -1, -1}, {34526, -1, -1, -1}, {34537, -1, -1, -1}, {34540, -1, -1, -1}, {34527, -1, -1, -1}, {34523, -1, -1, -1}, {34543, -1, -1, -1}, {34578, -1, -1, -1}, {34566, -1, -1, -1}, {34568, -1, -1, -1}, {34560, -1, -1, -1}, {34563, -1, -1, -1}, {34555, -1, -1, -1}, {34577, -1, -1, -1}, {34569, -1, -1, -1}, {34573, -1, -1, -1}, {34553, -1, -1, -1}, {34570, -1, -1, -1}, {34612, -1, -1, -1}, {34623, -1, -1, -1}, {34615, -1, -1, -1}, {34619, -1, -1, -1}, {34597, -1, -1, -1}, {34601, -1, -1, -1}, {34586, -1, -1, -1}, {34656, -1, -1, -1}, {34655, -1, -1, -1}, {34680, -1, -1, -1}, {34636, -1, -1, -1}, {34638, -1, -1, -1}, {34676, -1, -1, -1}, {34647, -1, -1, -1}, {34664, -1, -1, -1}, {34670, -1, -1, -1}, {34649, -1, -1, -1}, {34643, -1, -1, -1}, {34659, -1, -1, -1}, {34666, -1, -1, -1}, {34821, -1, -1, -1}, {34722, -1, -1, -1}, {34719, -1, -1, -1}, {34690, -1, -1, -1}, {34735, -1, -1, -1}, {34763, -1, -1, -1}, {34749, -1, -1, -1}, {34752, -1, -1, -1}, {34768, -1, -1, -1}, {38614, -1, -1, -1}, {34731, -1, -1, -1}, {34756, -1, -1, -1}, {34739, -1, -1, -1}, {34759, -1, -1, -1}, {34758, -1, -1, -1}, {34747, -1, -1, -1}, {34799, -1, -1, -1}, {34802, -1, -1, -1}, {34784, -1, -1, -1}, {34831, -1, -1, -1}, {34829, -1, -1, -1}, {34814, -1, -1, -1}, {34806, -1, -1, -1}, {34807, -1, -1, -1}, {34830, -1, -1, -1}, {34770, -1, -1, -1}, {34833, -1, -1, -1}, {34838, -1, -1, -1}, {34837, -1, -1, -1}, {34850, -1, -1, -1}, {34849, -1, -1, -1}, {34865, -1, -1, -1}, {34870, -1, -1, -1}, {34873, -1, -1, -1}, {34855, -1, -1, -1}, {34875, -1, -1, -1}, {34884, -1, -1, -1}, {34882, -1, -1, -1}, {34898, -1, -1, -1}, {34905, -1, -1, -1}, {34910, -1, -1, -1}, {34914, -1, -1, -1}, {34923, -1, -1, -1}, {34945, -1, -1, -1}, {34942, -1, -1, -1}, {34974, -1, -1, -1}, {34933, -1, -1, -1}, {34941, -1, -1, -1}, {34997, -1, -1, -1}, {34930, -1, -1, -1}, {34946, -1, -1, -1}, {34967, -1, -1, -1}, {34962, -1, -1, -1}, {34990, -1, -1, -1}, {34969, -1, -1, -1}, {34978, -1, -1, -1}, {34957, -1, -1, -1}, {34980, -1, -1, -1}, {34992, -1, -1, -1}, {35007, -1, -1, -1}, {34993, -1, -1, -1}, {35011, -1, -1, -1}, {35012, -1, -1, -1}, {35028, -1, -1, -1}, {35032, -1, -1, -1}, {35033, -1, -1, -1}, {35037, -1, -1, -1}, {35065, -1, -1, -1}, {35074, -1, -1, -1}, {35068, -1, -1, -1}, {35060, -1, -1, -1}, {35048, -1, -1, -1}, {35058, -1, -1, -1}, {35076, -1, -1, -1}, {35084, -1, -1, -1}, {35082, -1, -1, -1}, {35091, -1, -1, -1}, {35139, -1, -1, -1}, {35102, -1, -1, -1}, {35109, -1, -1, -1}, {35114, -1, -1, -1}, {35115, -1, -1, -1}, {35137, -1, -1, -1}, {35140, -1, -1, -1}, {35131, -1, -1, -1}, {35126, -1, -1, -1}, {35128, -1, -1, -1}, {35148, -1, -1, -1}, {35101, -1, -1, -1}, {35168, -1, -1, -1}, {35166, -1, -1, -1}, {35174, -1, -1, -1}, {35172, -1, -1, -1}, {35181, -1, -1, -1}, {35178, -1, -1, -1}, {35183, -1, -1, -1}, {35188, -1, -1, -1}, {35191, -1, -1, -1}, {12177, 35198, -1, -1}, {35203, -1, -1, -1}, {35208, -1, -1, -1}, {35210, -1, -1, -1}, {35219, -1, -1, -1}, {35224, -1, -1, -1}, {35233, -1, -1, -1}, {35241, -1, -1, -1}, {35238, -1, -1, -1}, {35244, -1, -1, -1}, {35247, -1, -1, -1}, {35250, -1, -1, -1}, {35258, -1, -1, -1}, {35261, -1, -1, -1}, {35263, -1, -1, -1}, {35264, -1, -1, -1}, {35290, -1, -1, -1}, {35292, -1, -1, -1}, {35293, -1, -1, -1}, {35303, -1, -1, -1}, {35316, -1, -1, -1} },
+ {{35320, -1, -1, -1}, {35331, -1, -1, -1}, {35350, -1, -1, -1}, {35344, -1, -1, -1}, {35340, -1, -1, -1}, {35355, -1, -1, -1}, {35357, -1, -1, -1}, {35365, -1, -1, -1}, {35382, -1, -1, -1}, {35393, -1, -1, -1}, {35419, -1, -1, -1}, {35410, -1, -1, -1}, {35398, -1, -1, -1}, {35400, -1, -1, -1}, {35452, -1, -1, -1}, {35437, -1, -1, -1}, {35436, -1, -1, -1}, {35426, -1, -1, -1}, {35461, -1, -1, -1}, {35458, -1, -1, -1}, {35460, -1, -1, -1}, {35496, -1, -1, -1}, {35489, -1, -1, -1}, {35473, -1, -1, -1}, {35493, -1, -1, -1}, {35494, -1, -1, -1}, {35482, -1, -1, -1}, {35491, -1, -1, -1}, {35524, -1, -1, -1}, {35533, -1, -1, -1}, {35522, -1, -1, -1}, {35546, -1, -1, -1}, {35563, -1, -1, -1}, {35571, -1, -1, -1}, {35559, -1, -1, -1}, {35556, -1, -1, -1}, {35569, -1, -1, -1}, {35604, -1, -1, -1}, {35552, -1, -1, -1}, {35554, -1, -1, -1}, {35575, -1, -1, -1}, {35550, -1, -1, -1}, {35547, -1, -1, -1}, {35596, -1, -1, -1}, {35591, -1, -1, -1}, {35610, -1, -1, -1}, {35553, -1, -1, -1}, {35606, -1, -1, -1}, {35600, -1, -1, -1}, {35607, -1, -1, -1}, {35616, -1, -1, -1}, {35635, -1, -1, -1}, {38827, -1, -1, -1}, {35622, -1, -1, -1}, {35627, -1, -1, -1}, {35646, -1, -1, -1}, {35624, -1, -1, -1}, {35649, -1, -1, -1}, {35660, -1, -1, -1}, {35663, -1, -1, -1}, {35662, -1, -1, -1}, {35657, -1, -1, -1}, {35670, -1, -1, -1}, {35675, -1, -1, -1}, {35674, -1, -1, -1}, {35691, -1, -1, -1}, {35679, -1, -1, -1}, {35692, -1, -1, -1}, {35695, -1, -1, -1}, {35700, -1, -1, -1}, {35709, -1, -1, -1}, {35712, -1, -1, -1}, {35724, -1, -1, -1}, {35726, -1, -1, -1}, {35730, -1, -1, -1}, {35731, -1, -1, -1}, {35734, -1, -1, -1}, {35737, -1, -1, -1}, {35738, -1, -1, -1}, {35898, -1, -1, -1}, {35905, -1, -1, -1}, {35903, -1, -1, -1}, {35912, -1, -1, -1}, {35916, -1, -1, -1}, {35918, -1, -1, -1}, {35920, -1, -1, -1}, {12183, 35925, -1, -1}, {35938, -1, -1, -1}, {35948, -1, -1, -1}, {12184, 35960, -1, -1}, {35962, -1, -1, -1}, {35970, -1, -1, -1}, {35977, -1, -1, -1}, {35973, -1, -1, -1}, {35978, -1, -1, -1}, {35981, -1, -1, -1}, {35982, -1, -1, -1}, {35988, -1, -1, -1}, {35964, -1, -1, -1}, {35992, -1, -1, -1}, {25117, -1, -1, -1}, {36013, -1, -1, -1}, {36010, -1, -1, -1}, {36029, -1, -1, -1}, {36018, -1, -1, -1}, {36019, -1, -1, -1}, {36014, -1, -1, -1}, {36022, -1, -1, -1}, {36040, -1, -1, -1}, {36033, -1, -1, -1}, {36068, -1, -1, -1}, {36067, -1, -1, -1}, {36058, -1, -1, -1}, {36093, -1, -1, -1}, {36090, -1, -1, -1}, {36091, -1, -1, -1}, {36100, -1, -1, -1}, {36101, -1, -1, -1}, {36106, -1, -1, -1}, {36103, -1, -1, -1}, {36111, -1, -1, -1}, {36109, -1, -1, -1}, {36112, -1, -1, -1}, {40782, -1, -1, -1}, {36115, -1, -1, -1}, {36045, -1, -1, -1}, {36116, -1, -1, -1}, {36118, -1, -1, -1}, {36199, -1, -1, -1}, {36205, -1, -1, -1}, {36209, -1, -1, -1}, {36211, -1, -1, -1}, {36225, -1, -1, -1}, {36249, -1, -1, -1}, {36290, -1, -1, -1}, {36286, -1, -1, -1}, {36282, -1, -1, -1}, {36303, -1, -1, -1}, {36314, -1, -1, -1}, {36310, -1, -1, -1}, {36300, -1, -1, -1}, {36315, -1, -1, -1}, {36299, -1, -1, -1}, {36330, -1, -1, -1}, {36331, -1, -1, -1}, {36319, -1, -1, -1}, {36323, -1, -1, -1}, {36348, -1, -1, -1}, {36360, -1, -1, -1}, {36361, -1, -1, -1}, {36351, -1, -1, -1}, {36381, -1, -1, -1}, {36382, -1, -1, -1}, {36368, -1, -1, -1}, {36383, -1, -1, -1}, {36418, -1, -1, -1}, {36405, -1, -1, -1}, {36400, -1, -1, -1}, {36404, -1, -1, -1}, {36426, -1, -1, -1}, {36423, -1, -1, -1}, {36425, -1, -1, -1}, {36428, -1, -1, -1}, {36432, -1, -1, -1}, {36424, -1, -1, -1}, {36441, -1, -1, -1}, {36452, -1, -1, -1}, {36448, -1, -1, -1}, {36394, -1, -1, -1}, {36451, -1, -1, -1}, {36437, -1, -1, -1}, {36470, -1, -1, -1}, {36466, -1, -1, -1}, {36476, -1, -1, -1}, {36481, -1, -1, -1}, {36487, -1, -1, -1}, {36485, -1, -1, -1}, {36484, -1, -1, -1}, {36491, -1, -1, -1}, {36490, -1, -1, -1}, {36499, -1, -1, -1}, {36497, -1, -1, -1}, {36500, -1, -1, -1}, {36505, -1, -1, -1}, {36522, -1, -1, -1}, {36513, -1, -1, -1}, {36524, -1, -1, -1}, {36528, -1, -1, -1}, {36550, -1, -1, -1}, {36529, -1, -1, -1}, {36542, -1, -1, -1}, {36549, -1, -1, -1}, {36552, -1, -1, -1}, {36555, -1, -1, -1}, {36571, -1, -1, -1}, {36579, -1, -1, -1}, {36604, -1, -1, -1}, {36603, -1, -1, -1}, {36587, -1, -1, -1}, {36606, -1, -1, -1}, {36618, -1, -1, -1}, {36613, -1, -1, -1}, {36629, -1, -1, -1}, {36626, -1, -1, -1}, {36633, -1, -1, -1}, {36627, -1, -1, -1}, {36636, -1, -1, -1}, {36639, -1, -1, -1}, {36635, -1, -1, -1}, {36620, -1, -1, -1}, {36646, -1, -1, -1}, {36659, -1, -1, -1}, {36667, -1, -1, -1}, {36665, -1, -1, -1}, {36677, -1, -1, -1}, {36674, -1, -1, -1}, {36670, -1, -1, -1}, {36684, -1, -1, -1}, {36681, -1, -1, -1}, {36678, -1, -1, -1}, {36686, -1, -1, -1}, {36695, -1, -1, -1}, {36700, -1, -1, -1}, {36706, -1, -1, -1}, {36707, -1, -1, -1}, {36708, -1, -1, -1}, {36764, -1, -1, -1}, {36767, -1, -1, -1}, {36771, -1, -1, -1}, {36781, -1, -1, -1}, {36783, -1, -1, -1}, {36791, -1, -1, -1}, {36826, -1, -1, -1}, {36837, -1, -1, -1}, {36834, -1, -1, -1}, {36842, -1, -1, -1}, {36847, -1, -1, -1}, {36999, -1, -1, -1}, {36852, -1, -1, -1}, {36869, -1, -1, -1}, {36857, -1, -1, -1}, {36858, -1, -1, -1}, {36881, -1, -1, -1}, {36885, -1, -1, -1}, {36897, -1, -1, -1}, {36877, -1, -1, -1}, {36894, -1, -1, -1}, {36886, -1, -1, -1}, {36875, -1, -1, -1}, {36903, -1, -1, -1}, {36918, -1, -1, -1}, {36917, -1, -1, -1}, {36921, -1, -1, -1}, {36856, -1, -1, -1}, {36943, -1, -1, -1}, {36944, -1, -1, -1} },
+ {{36945, -1, -1, -1}, {36946, -1, -1, -1}, {36878, -1, -1, -1}, {36937, -1, -1, -1}, {36926, -1, -1, -1}, {36950, -1, -1, -1}, {36952, -1, -1, -1}, {36958, -1, -1, -1}, {36968, -1, -1, -1}, {36975, -1, -1, -1}, {36982, -1, -1, -1}, {38568, -1, -1, -1}, {36978, -1, -1, -1}, {36994, -1, -1, -1}, {36989, -1, -1, -1}, {36993, -1, -1, -1}, {36992, -1, -1, -1}, {37002, -1, -1, -1}, {37001, -1, -1, -1}, {37007, -1, -1, -1}, {37032, -1, -1, -1}, {37039, -1, -1, -1}, {37041, -1, -1, -1}, {37045, -1, -1, -1}, {37090, -1, -1, -1}, {37092, -1, -1, -1}, {25160, -1, -1, -1}, {37083, -1, -1, -1}, {37122, -1, -1, -1}, {37138, -1, -1, -1}, {37145, -1, -1, -1}, {37170, -1, -1, -1}, {37168, -1, -1, -1}, {37194, -1, -1, -1}, {37206, -1, -1, -1}, {37208, -1, -1, -1}, {37219, -1, -1, -1}, {37221, -1, -1, -1}, {37225, -1, -1, -1}, {37235, -1, -1, -1}, {37234, -1, -1, -1}, {37259, -1, -1, -1}, {37257, -1, -1, -1}, {37250, -1, -1, -1}, {37282, -1, -1, -1}, {37291, -1, -1, -1}, {37295, -1, -1, -1}, {37290, -1, -1, -1}, {37301, -1, -1, -1}, {37300, -1, -1, -1}, {37306, -1, -1, -1}, {37312, -1, -1, -1}, {37313, -1, -1, -1}, {37321, -1, -1, -1}, {37323, -1, -1, -1}, {37328, -1, -1, -1}, {37334, -1, -1, -1}, {37343, -1, -1, -1}, {37345, -1, -1, -1}, {37339, -1, -1, -1}, {37372, -1, -1, -1}, {37365, -1, -1, -1}, {37366, -1, -1, -1}, {37406, -1, -1, -1}, {37375, -1, -1, -1}, {37396, -1, -1, -1}, {37420, -1, -1, -1}, {37397, -1, -1, -1}, {37393, -1, -1, -1}, {37470, -1, -1, -1}, {37463, -1, -1, -1}, {37445, -1, -1, -1}, {37449, -1, -1, -1}, {37476, -1, -1, -1}, {37448, -1, -1, -1}, {37525, -1, -1, -1}, {37439, -1, -1, -1}, {37451, -1, -1, -1}, {37456, -1, -1, -1}, {37532, -1, -1, -1}, {37526, -1, -1, -1}, {37523, -1, -1, -1}, {37531, -1, -1, -1}, {37466, -1, -1, -1}, {37583, -1, -1, -1}, {37561, -1, -1, -1}, {37559, -1, -1, -1}, {37609, -1, -1, -1}, {37647, -1, -1, -1}, {37626, -1, -1, -1}, {37700, -1, -1, -1}, {37678, -1, -1, -1}, {37657, -1, -1, -1}, {37666, -1, -1, -1}, {37658, -1, -1, -1}, {37667, -1, -1, -1}, {37690, -1, -1, -1}, {37685, -1, -1, -1}, {37691, -1, -1, -1}, {37724, -1, -1, -1}, {37728, -1, -1, -1}, {37756, -1, -1, -1}, {37742, -1, -1, -1}, {37718, -1, -1, -1}, {37808, -1, -1, -1}, {37804, -1, -1, -1}, {37805, -1, -1, -1}, {37780, -1, -1, -1}, {37817, -1, -1, -1}, {37846, -1, -1, -1}, {37847, -1, -1, -1}, {37864, -1, -1, -1}, {37861, -1, -1, -1}, {37848, -1, -1, -1}, {37827, -1, -1, -1}, {37853, -1, -1, -1}, {37840, -1, -1, -1}, {37832, -1, -1, -1}, {37860, -1, -1, -1}, {37914, -1, -1, -1}, {37908, -1, -1, -1}, {37907, -1, -1, -1}, {37891, -1, -1, -1}, {37895, -1, -1, -1}, {37904, -1, -1, -1}, {37942, -1, -1, -1}, {37931, -1, -1, -1}, {37941, -1, -1, -1}, {37921, -1, -1, -1}, {37946, -1, -1, -1}, {37953, -1, -1, -1}, {37970, -1, -1, -1}, {37956, -1, -1, -1}, {37979, -1, -1, -1}, {37984, -1, -1, -1}, {37986, -1, -1, -1}, {37982, -1, -1, -1}, {37994, -1, -1, -1}, {37417, -1, -1, -1}, {38000, -1, -1, -1}, {38005, -1, -1, -1}, {38007, -1, -1, -1}, {38013, -1, -1, -1}, {37978, -1, -1, -1}, {38012, -1, -1, -1}, {38014, -1, -1, -1}, {38017, -1, -1, -1}, {38015, -1, -1, -1}, {38274, -1, -1, -1}, {38279, -1, -1, -1}, {38282, -1, -1, -1}, {38292, -1, -1, -1}, {38294, -1, -1, -1}, {38296, -1, -1, -1}, {38297, -1, -1, -1}, {38304, -1, -1, -1}, {38312, -1, -1, -1}, {38311, -1, -1, -1}, {38317, -1, -1, -1}, {38332, -1, -1, -1}, {38331, -1, -1, -1}, {38329, -1, -1, -1}, {38334, -1, -1, -1}, {38346, -1, -1, -1}, {28662, -1, -1, -1}, {38339, -1, -1, -1}, {38349, -1, -1, -1}, {38348, -1, -1, -1}, {38357, -1, -1, -1}, {38356, -1, -1, -1}, {38358, -1, -1, -1}, {38364, -1, -1, -1}, {38369, -1, -1, -1}, {38373, -1, -1, -1}, {38370, -1, -1, -1}, {38433, -1, -1, -1}, {38440, -1, -1, -1}, {38446, -1, -1, -1}, {38447, -1, -1, -1}, {38466, -1, -1, -1}, {38476, -1, -1, -1}, {38479, -1, -1, -1}, {38475, -1, -1, -1}, {38519, -1, -1, -1}, {38492, -1, -1, -1}, {38494, -1, -1, -1}, {38493, -1, -1, -1}, {38495, -1, -1, -1}, {38502, -1, -1, -1}, {38514, -1, -1, -1}, {38508, -1, -1, -1}, {38541, -1, -1, -1}, {38552, -1, -1, -1}, {38549, -1, -1, -1}, {38551, -1, -1, -1}, {38570, -1, -1, -1}, {38567, -1, -1, -1}, {38577, -1, -1, -1}, {38578, -1, -1, -1}, {38576, -1, -1, -1}, {38580, -1, -1, -1}, {12202, 38582, -1, -1}, {38584, -1, -1, -1}, {12203, 38585, -1, -1}, {38606, -1, -1, -1}, {38603, -1, -1, -1}, {38601, -1, -1, -1}, {38605, -1, -1, -1}, {35149, -1, -1, -1}, {38620, -1, -1, -1}, {38669, -1, -1, -1}, {38613, -1, -1, -1}, {38649, -1, -1, -1}, {38660, -1, -1, -1}, {38662, -1, -1, -1}, {38664, -1, -1, -1}, {38675, -1, -1, -1}, {38670, -1, -1, -1}, {38673, -1, -1, -1}, {38671, -1, -1, -1}, {38678, -1, -1, -1}, {38681, -1, -1, -1}, {38692, -1, -1, -1}, {38698, -1, -1, -1}, {38704, -1, -1, -1}, {38713, -1, -1, -1}, {38717, -1, -1, -1}, {38718, -1, -1, -1}, {38724, -1, -1, -1}, {38726, -1, -1, -1}, {38728, -1, -1, -1}, {38722, -1, -1, -1}, {38729, -1, -1, -1}, {38748, -1, -1, -1}, {38752, -1, -1, -1}, {38756, -1, -1, -1}, {38758, -1, -1, -1}, {38760, -1, -1, -1}, {21202, -1, -1, -1}, {38763, -1, -1, -1}, {38769, -1, -1, -1}, {38777, -1, -1, -1}, {38789, -1, -1, -1}, {38780, -1, -1, -1}, {38785, -1, -1, -1}, {38778, -1, -1, -1}, {38790, -1, -1, -1}, {38795, -1, -1, -1}, {38799, -1, -1, -1}, {38800, -1, -1, -1}, {38812, -1, -1, -1}, {38824, -1, -1, -1}, {38822, -1, -1, -1}, {38819, -1, -1, -1}, {38835, -1, -1, -1}, {38836, -1, -1, -1} },
+ {{38851, -1, -1, -1}, {38854, -1, -1, -1}, {38856, -1, -1, -1}, {12209, 38859, -1, -1}, {38876, -1, -1, -1}, {12210, 38893, -1, -1}, {40783, -1, -1, -1}, {38898, -1, -1, -1}, {31455, -1, -1, -1}, {38902, -1, -1, -1}, {38901, -1, -1, -1}, {38927, -1, -1, -1}, {38924, -1, -1, -1}, {38968, -1, -1, -1}, {38948, -1, -1, -1}, {38945, -1, -1, -1}, {38967, -1, -1, -1}, {38973, -1, -1, -1}, {38982, -1, -1, -1}, {38991, -1, -1, -1}, {38987, -1, -1, -1}, {39019, -1, -1, -1}, {39023, -1, -1, -1}, {39024, -1, -1, -1}, {39025, -1, -1, -1}, {39028, -1, -1, -1}, {39027, -1, -1, -1}, {39082, -1, -1, -1}, {39087, -1, -1, -1}, {39089, -1, -1, -1}, {39094, -1, -1, -1}, {39108, -1, -1, -1}, {39107, -1, -1, -1}, {39110, -1, -1, -1}, {39145, -1, -1, -1}, {39147, -1, -1, -1}, {39171, -1, -1, -1}, {39177, -1, -1, -1}, {39186, -1, -1, -1}, {39188, -1, -1, -1}, {39192, -1, -1, -1}, {39201, -1, -1, -1}, {39197, -1, -1, -1}, {39198, -1, -1, -1}, {39204, -1, -1, -1}, {39200, -1, -1, -1}, {39212, -1, -1, -1}, {39214, -1, -1, -1}, {39229, -1, -1, -1}, {39230, -1, -1, -1}, {39234, -1, -1, -1}, {39241, -1, -1, -1}, {39237, -1, -1, -1}, {39248, -1, -1, -1}, {39243, -1, -1, -1}, {39249, -1, -1, -1}, {39250, -1, -1, -1}, {39244, -1, -1, -1}, {39253, -1, -1, -1}, {39319, -1, -1, -1}, {39320, -1, -1, -1}, {39333, -1, -1, -1}, {39341, -1, -1, -1}, {39342, -1, -1, -1}, {39356, -1, -1, -1}, {39391, -1, -1, -1}, {39387, -1, -1, -1}, {39389, -1, -1, -1}, {39384, -1, -1, -1}, {39377, -1, -1, -1}, {39405, -1, -1, -1}, {39406, -1, -1, -1}, {39409, -1, -1, -1}, {39410, -1, -1, -1}, {39419, -1, -1, -1}, {39416, -1, -1, -1}, {39425, -1, -1, -1}, {39439, -1, -1, -1}, {39429, -1, -1, -1}, {39394, -1, -1, -1}, {39449, -1, -1, -1}, {39467, -1, -1, -1}, {39479, -1, -1, -1}, {39493, -1, -1, -1}, {39490, -1, -1, -1}, {39488, -1, -1, -1}, {39491, -1, -1, -1}, {39486, -1, -1, -1}, {39509, -1, -1, -1}, {39501, -1, -1, -1}, {39515, -1, -1, -1}, {39511, -1, -1, -1}, {39519, -1, -1, -1}, {39522, -1, -1, -1}, {39525, -1, -1, -1}, {39524, -1, -1, -1}, {39529, -1, -1, -1}, {39531, -1, -1, -1}, {39530, -1, -1, -1}, {39597, -1, -1, -1}, {39600, -1, -1, -1}, {39612, -1, -1, -1}, {39616, -1, -1, -1}, {39631, -1, -1, -1}, {39633, -1, -1, -1}, {39635, -1, -1, -1}, {39636, -1, -1, -1}, {39646, -1, -1, -1}, {12221, 39647, -1, -1}, {39650, -1, -1, -1}, {39651, -1, -1, -1}, {39654, -1, -1, -1}, {39663, -1, -1, -1}, {39659, -1, -1, -1}, {39662, -1, -1, -1}, {39668, -1, -1, -1}, {39665, -1, -1, -1}, {39671, -1, -1, -1}, {39675, -1, -1, -1}, {39686, -1, -1, -1}, {39704, -1, -1, -1}, {39706, -1, -1, -1}, {39711, -1, -1, -1}, {39714, -1, -1, -1}, {39715, -1, -1, -1}, {12222, 39717, -1, -1}, {39719, -1, -1, -1}, {39720, -1, -1, -1}, {39721, -1, -1, -1}, {39722, -1, -1, -1}, {39726, -1, -1, -1}, {12223, 39727, -1, -1}, {12224, 39730, -1, -1}, {39748, -1, -1, -1}, {39747, -1, -1, -1}, {39759, -1, -1, -1}, {39757, -1, -1, -1}, {39758, -1, -1, -1}, {39761, -1, -1, -1}, {39768, -1, -1, -1}, {39796, -1, -1, -1}, {39827, -1, -1, -1}, {39811, -1, -1, -1}, {39825, -1, -1, -1}, {39830, -1, -1, -1}, {39831, -1, -1, -1}, {39839, -1, -1, -1}, {39840, -1, -1, -1}, {39848, -1, -1, -1}, {39860, -1, -1, -1}, {39872, -1, -1, -1}, {39882, -1, -1, -1}, {39865, -1, -1, -1}, {39878, -1, -1, -1}, {39887, -1, -1, -1}, {39889, -1, -1, -1}, {39890, -1, -1, -1}, {39907, -1, -1, -1}, {39906, -1, -1, -1}, {39908, -1, -1, -1}, {39892, -1, -1, -1}, {39905, -1, -1, -1}, {39994, -1, -1, -1}, {39922, -1, -1, -1}, {39921, -1, -1, -1}, {39920, -1, -1, -1}, {39957, -1, -1, -1}, {39956, -1, -1, -1}, {39945, -1, -1, -1}, {39955, -1, -1, -1}, {39948, -1, -1, -1}, {39942, -1, -1, -1}, {39944, -1, -1, -1}, {39954, -1, -1, -1}, {39946, -1, -1, -1}, {39940, -1, -1, -1}, {39982, -1, -1, -1}, {39963, -1, -1, -1}, {39973, -1, -1, -1}, {39972, -1, -1, -1}, {39969, -1, -1, -1}, {39984, -1, -1, -1}, {40007, -1, -1, -1}, {39986, -1, -1, -1}, {40006, -1, -1, -1}, {39998, -1, -1, -1}, {40026, -1, -1, -1}, {40032, -1, -1, -1}, {40039, -1, -1, -1}, {40054, -1, -1, -1}, {40056, -1, -1, -1}, {40167, -1, -1, -1}, {40172, -1, -1, -1}, {40176, -1, -1, -1}, {40201, -1, -1, -1}, {40200, -1, -1, -1}, {40171, -1, -1, -1}, {40195, -1, -1, -1}, {40198, -1, -1, -1}, {40234, -1, -1, -1}, {40230, -1, -1, -1}, {40367, -1, -1, -1}, {40227, -1, -1, -1}, {40223, -1, -1, -1}, {40260, -1, -1, -1}, {40213, -1, -1, -1}, {40210, -1, -1, -1}, {40257, -1, -1, -1}, {40255, -1, -1, -1}, {40254, -1, -1, -1}, {40262, -1, -1, -1}, {40264, -1, -1, -1}, {40285, -1, -1, -1}, {40286, -1, -1, -1}, {40292, -1, -1, -1}, {40273, -1, -1, -1}, {40272, -1, -1, -1}, {40281, -1, -1, -1}, {40306, -1, -1, -1}, {40329, -1, -1, -1}, {40327, -1, -1, -1}, {40363, -1, -1, -1}, {40303, -1, -1, -1}, {40314, -1, -1, -1}, {40346, -1, -1, -1}, {40356, -1, -1, -1}, {40361, -1, -1, -1}, {40370, -1, -1, -1}, {40388, -1, -1, -1}, {40385, -1, -1, -1}, {40379, -1, -1, -1}, {40376, -1, -1, -1}, {40378, -1, -1, -1}, {40390, -1, -1, -1}, {40399, -1, -1, -1}, {40386, -1, -1, -1}, {40409, -1, -1, -1}, {40403, -1, -1, -1}, {40440, -1, -1, -1}, {40422, -1, -1, -1}, {40429, -1, -1, -1}, {40431, -1, -1, -1}, {40445, -1, -1, -1}, {40474, -1, -1, -1}, {40475, -1, -1, -1}, {40478, -1, -1, -1}, {12228, 40565, -1, -1}, {40569, -1, -1, -1}, {40573, -1, -1, -1}, {40577, -1, -1, -1}, {40584, -1, -1, -1}, {40587, -1, -1, -1}, {40588, -1, -1, -1}, {40594, -1, -1, -1}, {40597, -1, -1, -1}, {40593, -1, -1, -1} },
+ {{40605, -1, -1, -1}, {12230, 40613, -1, -1}, {40617, -1, -1, -1}, {40632, -1, -1, -1}, {40618, -1, -1, -1}, {40621, -1, -1, -1}, {38753, -1, -1, -1}, {40652, -1, -1, -1}, {40654, -1, -1, -1}, {40655, -1, -1, -1}, {40656, -1, -1, -1}, {40660, -1, -1, -1}, {40668, -1, -1, -1}, {40670, -1, -1, -1}, {40669, -1, -1, -1}, {40672, -1, -1, -1}, {40677, -1, -1, -1}, {40680, -1, -1, -1}, {40687, -1, -1, -1}, {40692, -1, -1, -1}, {40694, -1, -1, -1}, {40695, -1, -1, -1}, {12235, 40697, -1, -1}, {40699, -1, -1, -1}, {40700, -1, -1, -1}, {12236, 40701, -1, -1}, {40711, -1, -1, -1}, {40712, -1, -1, -1}, {30391, -1, -1, -1}, {40725, -1, -1, -1}, {40737, -1, -1, -1}, {40748, -1, -1, -1}, {40766, -1, -1, -1}, {12241, 40778, -1, -1}, {12242, 40786, -1, -1}, {40788, -1, -1, -1}, {40803, -1, -1, -1}, {40799, -1, -1, -1}, {40800, -1, -1, -1}, {40801, -1, -1, -1}, {40806, -1, -1, -1}, {40807, -1, -1, -1}, {40812, -1, -1, -1}, {40810, -1, -1, -1}, {40823, -1, -1, -1}, {40818, -1, -1, -1}, {40822, -1, -1, -1}, {40853, -1, -1, -1}, {12244, 40860, -1, -1}, {12245, 40864, -1, -1}, {22575, -1, -1, -1}, {27079, -1, -1, -1}, {36953, -1, -1, -1}, {29796, -1, -1, -1}, {-1, -1, -1, -1}, {9472, 9474, -1, -1}, {9473, 9475, -1, -1}, {9474, 9472, -1, -1}, {9475, 9473, -1, -1}, {9476, 9478, -1, -1}, {9477, 9479, -1, -1}, {9478, 9476, -1, -1}, {9479, 9477, -1, -1}, {9480, 9482, -1, -1}, {9481, 9483, -1, -1}, {9482, 9480, -1, -1}, {9483, 9481, -1, -1}, {9484, 9492, -1, -1}, {9485, 9494, -1, -1}, {9486, 9493, -1, -1}, {9487, 9495, -1, -1}, {9488, 9484, -1, -1}, {9489, 9486, -1, -1}, {9490, 9485, -1, -1}, {9491, 9487, -1, -1}, {9492, 9496, -1, -1}, {9493, 9498, -1, -1}, {9494, 9497, -1, -1}, {9495, 9499, -1, -1}, {9496, 9488, -1, -1}, {9497, 9490, -1, -1}, {9498, 9489, -1, -1}, {9499, 9491, -1, -1}, {9500, 9524, -1, -1}, {9501, 9528, -1, -1}, {9502, 9525, -1, -1}, {9503, 9526, -1, -1}, {9504, 9527, -1, -1}, {9505, 9529, -1, -1}, {9506, 9530, -1, -1}, {9507, 9531, -1, -1}, {9508, 9516, -1, -1}, {9509, 9520, -1, -1}, {9510, 9517, -1, -1}, {9511, 9518, -1, -1}, {9512, 9519, -1, -1}, {9513, 9521, -1, -1}, {9514, 9522, -1, -1}, {9515, 9523, -1, -1}, {9516, 9500, -1, -1}, {9517, 9503, -1, -1}, {9518, 9502, -1, -1}, {9519, 9504, -1, -1}, {9520, 9501, -1, -1}, {9521, 9506, -1, -1}, {9522, 9505, -1, -1}, {9523, 9507, -1, -1}, {9524, 9508, -1, -1}, {9525, 9511, -1, -1}, {9526, 9510, -1, -1}, {9527, 9512, -1, -1}, {9528, 9509, -1, -1}, {9529, 9514, -1, -1}, {9530, 9513, -1, -1}, {9531, 9515, -1, -1}, {9532, -1, -1, -1}, {9533, 9537, -1, -1}, {9534, 9536, -1, -1}, {9535, 9538, -1, -1}, {9536, 9533, -1, -1}, {9537, 9534, -1, -1}, {9538, 9535, -1, -1}, {9539, 9541, -1, -1}, {9540, 9539, -1, -1}, {9541, 9542, -1, -1}, {9542, 9540, -1, -1}, {9543, 9545, -1, -1}, {9544, 9546, -1, -1}, {9545, 9544, -1, -1}, {9546, 9543, -1, -1}, {9547, -1, -1, -1}, {9312, -1, -1, -1}, {9313, -1, -1, -1}, {9314, -1, -1, -1}, {9315, -1, -1, -1}, {9316, -1, -1, -1}, {9317, -1, -1, -1}, {9318, -1, -1, -1}, {9319, -1, -1, -1}, {9320, -1, -1, -1}, {9321, -1, -1, -1}, {9322, -1, -1, -1}, {9323, -1, -1, -1}, {9324, -1, -1, -1}, {9325, -1, -1, -1}, {9326, -1, -1, -1}, {9327, -1, -1, -1}, {9328, -1, -1, -1}, {9329, -1, -1, -1}, {9330, -1, -1, -1}, {9331, -1, -1, -1}, {8544, -1, -1, -1}, {8545, -1, -1, -1}, {8546, -1, -1, -1}, {8547, -1, -1, -1}, {8548, -1, -1, -1}, {8549, -1, -1, -1}, {8550, -1, -1, -1}, {8551, -1, -1, -1}, {8552, -1, -1, -1}, {8553, -1, -1, -1}, {13129, -1, -1, -1}, {13076, -1, -1, -1}, {-1, -1, -1, -1}, {13133, -1, -1, -1}, {-1, -1, -1, -1}, {13095, -1, -1, -1}, {-1, -1, -1, -1}, {13110, -1, -1, -1}, {13137, -1, -1, -1}, {-1, -1, -1, -1}, {13069, -1, -1, -1}, {13094, -1, -1, -1}, {-1, -1, -1, -1}, {13099, -1, -1, -1}, {13130, -1, -1, -1}, {-1, -1, -1, -1}, {13212, -1, -1, -1}, {13213, -1, -1, -1}, {13214, -1, -1, -1}, {13198, -1, -1, -1}, {13199, -1, -1, -1}, {13252, -1, -1, -1}, {13217, -1, -1, -1}, {12317, -1, -1, -1}, {12319, -1, -1, -1}, {8470, -1, -1, -1}, {13261, -1, -1, -1}, {-1, -1, -1, -1}, {12964, -1, -1, -1}, {12965, -1, -1, -1}, {12966, -1, -1, -1}, {12967, -1, -1, -1}, {12968, -1, -1, -1}, {12849, -1, -1, -1}, {12850, -1, -1, -1}, {12857, -1, -1, -1}, {13182, -1, -1, -1}, {13181, -1, -1, -1}, {13180, -1, -1, -1}, {8750, -1, -1, -1}, {8721, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8735, -1, -1, -1}, {8895, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {21854, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {28976, -1, -1, -1}, {-1, -1, -1, -1}, {40407, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {22169, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {20448, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {36544, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {32363, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {40572, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{26171, -1, -1, -1}, {-1, -1, -1, -1}, {40628, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {26629, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {23650, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {32353, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {34083, -1, -1, -1}, {37292, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {34796, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {25620, -1, -1, -1}, {30246, -1, -1, -1}, {-1, -1, -1, -1}, {39506, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {31774, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {25681, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {22625, -1, -1, -1}, {39002, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {31153, -1, -1, -1}, {-1, -1, -1, -1}, {28678, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {22218, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {21085, -1, -1, -1}, {-1, -1, -1, -1}, {28497, -1, -1, -1}, {37297, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {38960, -1, -1, -1}, {-1, -1, -1, -1}, {40629, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {33802, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {34847, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {23643, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {25890, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {26766, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {34110, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {30562, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12289, -1, -1, -1}, {12290, -1, -1, -1}, {65507, -1, -1, -1}, {65075, 65343, -1, -1}, {12540, -1, -1, -1}, {65073, 8213, -1, -1}, {65074, 8208, -1, -1}, {12316, 8764, 65374, -1}, {8741, 8214, -1, -1}, {65372, -1, -1, -1}, {8942, 8943, 8230, -1}, {65072, 8229, -1, -1}, {65077, 65288, -1, -1}, {65078, 65289, -1, -1}, {65081, 12308, -1, -1}, {65082, 12309, -1, -1}, {65339, -1, -1, -1}, {65341, -1, -1, -1}, {65079, 65371, -1, -1}, {65080, 65373, -1, -1}, {65087, 12296, -1, -1}, {65088, 12297, -1, -1}, {65085, 12298, -1, -1}, {65086, 12299, -1, -1}, {65089, 12300, -1, -1}, {65090, 12301, -1, -1}, {65091, 12302, -1, -1}, {65092, 12303, -1, -1}, {65083, 12304, -1, -1}, {65084, 12305, -1, -1}, {65309, -1, -1, -1}, {12353, -1, -1, -1}, {12355, -1, -1, -1}, {12357, -1, -1, -1}, {12359, -1, -1, -1}, {12361, -1, -1, -1}, {12387, -1, -1, -1}, {12419, -1, -1, -1}, {12421, -1, -1, -1}, {12423, -1, -1, -1}, {12430, -1, -1, -1}, {12449, -1, -1, -1}, {12451, -1, -1, -1}, {12453, -1, -1, -1}, {12455, -1, -1, -1}, {12457, -1, -1, -1}, {12483, -1, -1, -1}, {12515, -1, -1, -1}, {12517, -1, -1, -1} },
+ {{12519, -1, -1, -1}, {12526, -1, -1, -1}, {12533, -1, -1, -1}, {12534, -1, -1, -1}, {13129, -1, -1, -1}, {13076, -1, -1, -1}, {-1, -1, -1, -1}, {13133, -1, -1, -1}, {-1, -1, -1, -1}, {13095, -1, -1, -1}, {-1, -1, -1, -1}, {13110, -1, -1, -1}, {13137, -1, -1, -1}, {-1, -1, -1, -1}, {13069, -1, -1, -1}, {13094, -1, -1, -1}, {-1, -1, -1, -1}, {13099, -1, -1, -1}, {13130, -1, -1, -1}, {-1, -1, -1, -1}, {12317, -1, -1, -1}, {12319, -1, -1, -1}, {12436, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {22099, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {65508, -1, -1, -1}, {65287, -1, -1, -1}, {65282, -1, -1, -1}, {-1, -1, -1, -1}, {9665, -1, -1, -1}, {9655, -1, -1, -1}, {8681, 8680, -1, -1}, {8679, 8678, -1, -1}, {8678, 8681, -1, -1}, {8680, 8679, -1, -1}, {9634, -1, -1, -1}, {9831, -1, -1, -1}, {9825, -1, -1, -1}, {9828, -1, -1, -1}, {9826, -1, -1, -1}, {13216, -1, -1, -1}, {13218, -1, -1, -1}, {13220, -1, -1, -1}, {13221, -1, -1, -1}, {13207, -1, -1, -1}, {8467, -1, -1, -1}, {13208, -1, -1, -1}, {13235, -1, -1, -1}, {13234, -1, -1, -1}, {13233, -1, -1, -1}, {13232, -1, -1, -1}, {13189, -1, -1, -1}, {13190, -1, -1, -1}, {13191, -1, -1, -1}, {13259, -1, -1, -1}, {13200, -1, -1, -1}, {13268, -1, -1, -1}, {13206, -1, -1, -1}, {13090, -1, -1, -1}, {13078, -1, -1, -1}, {13080, -1, -1, -1}, {13077, -1, -1, -1}, {13059, -1, -1, -1}, {13091, -1, -1, -1}, {13143, -1, -1, -1}, {13122, -1, -1, -1}, {13113, -1, -1, -1}, {13115, -1, -1, -1}, {13056, -1, -1, -1}, {13105, -1, -1, -1}, {13127, -1, -1, -1}, {13086, -1, -1, -1}, {13098, -1, -1, -1}, {-1, -1, -1, -1}, {13183, -1, -1, -1}, {8481, -1, -1, -1}, {9742, -1, -1, -1}, {12342, -1, -1, -1}, {12320, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9352, -1, -1, -1}, {9353, -1, -1, -1}, {9354, -1, -1, -1}, {9355, -1, -1, -1}, {9356, -1, -1, -1}, {9357, -1, -1, -1}, {9358, -1, -1, -1}, {9359, -1, -1, -1}, {9360, -1, -1, -1}, {9332, -1, -1, -1}, {9333, -1, -1, -1}, {9334, -1, -1, -1}, {9335, -1, -1, -1}, {9336, -1, -1, -1}, {9337, -1, -1, -1}, {9338, -1, -1, -1}, {9339, -1, -1, -1}, {9340, -1, -1, -1}, {9341, -1, -1, -1}, {9342, -1, -1, -1}, {9343, -1, -1, -1}, {9344, -1, -1, -1}, {9345, -1, -1, -1}, {9346, -1, -1, -1}, {9347, -1, -1, -1}, {9348, -1, -1, -1}, {9349, -1, -1, -1}, {9350, -1, -1, -1}, {9351, -1, -1, -1}, {-1, -1, -1, -1}, {8560, -1, -1, -1}, {8561, -1, -1, -1}, {8562, -1, -1, -1}, {8563, -1, -1, -1}, {8564, -1, -1, -1}, {8565, -1, -1, -1}, {8566, -1, -1, -1}, {8567, -1, -1, -1}, {8568, -1, -1, -1}, {8569, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9372, -1, -1, -1}, {9373, -1, -1, -1}, {9374, -1, -1, -1}, {9375, -1, -1, -1}, {9376, -1, -1, -1}, {9377, -1, -1, -1}, {9378, -1, -1, -1}, {9379, -1, -1, -1}, {9380, -1, -1, -1}, {9381, -1, -1, -1}, {9382, -1, -1, -1}, {9383, -1, -1, -1}, {9384, -1, -1, -1}, {9385, -1, -1, -1}, {9386, -1, -1, -1}, {9387, -1, -1, -1}, {9388, -1, -1, -1}, {9389, -1, -1, -1}, {9390, -1, -1, -1}, {9391, -1, -1, -1}, {9392, -1, -1, -1}, {9393, -1, -1, -1}, {9394, -1, -1, -1}, {9395, -1, -1, -1}, {9396, -1, -1, -1}, {9397, -1, -1, -1}, {12867, -1, -1, -1}, {12861, -1, -1, -1}, {12863, -1, -1, -1}, {12852, -1, -1, -1}, {12856, -1, -1, -1}, {12851, -1, -1, -1}, {12860, -1, -1, -1}, {12866, -1, -1, -1}, {12862, -1, -1, -1}, {12854, -1, -1, -1}, {12853, -1, -1, -1}, {12859, -1, -1, -1}, {12864, -1, -1, -1}, {12858, -1, -1, -1}, {12976, -1, -1, -1}, {12973, -1, -1, -1}, {12969, -1, -1, -1}, {12975, -1, -1, -1}, {12948, -1, -1, -1}, {12970, -1, -1, -1}, {12952, -1, -1, -1}, {12971, -1, -1, -1}, {12946, -1, -1, -1}, {12945, -1, -1, -1}, {12947, -1, -1, -1}, {12972, -1, -1, -1}, {12974, -1, -1, -1}, {12950, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13260, -1, -1, -1}, {13061, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13215, -1, -1, -1}, {13219, -1, -1, -1}, {13222, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12958, -1, -1, -1} },
+ {{13192, -1, -1, -1}, {13193, -1, -1, -1}, {13256, -1, -1, -1}, {8749, -1, -1, -1}, {-1, -1, -1, -1}, {12848, -1, -1, -1}, {12842, -1, -1, -1}, {12843, -1, -1, -1}, {12844, -1, -1, -1}, {12845, -1, -1, -1}, {12846, -1, -1, -1}, {12847, -1, -1, -1}, {12855, -1, -1, -1}, {12865, -1, -1, -1}, {10145, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {10145, -1, -1, -1}, {9673, -1, -1, -1}, {9824, -1, -1, -1}, {9829, -1, -1, -1}, {9827, -1, -1, -1}, {9830, -1, -1, -1}, {9728, -1, -1, -1}, {9729, -1, -1, -1}, {9730, -1, -1, -1}, {9731, -1, -1, -1}, {9758, 9757, -1, -1}, {9756, 9759, -1, -1}, {9757, 9756, -1, -1}, {9759, 9758, -1, -1}, {12953, -1, -1, -1}, {9450, -1, -1, -1}, {8554, -1, -1, -1}, {8555, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9601, -1, -1, -1}, {9602, -1, -1, -1}, {9603, -1, -1, -1}, {9604, -1, -1, -1}, {9605, -1, -1, -1}, {9606, -1, -1, -1}, {9607, -1, -1, -1}, {9608, -1, -1, -1}, {9615, -1, -1, -1}, {9614, -1, -1, -1}, {9613, -1, -1, -1}, {9612, -1, -1, -1}, {9611, -1, -1, -1}, {9610, -1, -1, -1}, {9609, -1, -1, -1}, {9620, -1, -1, -1}, {9621, -1, -1, -1}, {9581, -1, -1, -1}, {9582, -1, -1, -1}, {9584, -1, -1, -1}, {9583, -1, -1, -1}, {9552, -1, -1, -1}, {9566, -1, -1, -1}, {9578, -1, -1, -1}, {9569, -1, -1, -1}, {9698, -1, -1, -1}, {9699, -1, -1, -1}, {9701, -1, -1, -1}, {9700, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9585, -1, -1, -1}, {9586, -1, -1, -1}, {9587, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {65292, -1, -1, -1}, {176, -1, -1, -1}, {12307, -1, -1, -1}, {12444, -1, -1, -1}, {12443, -1, -1, -1}, {8242, -1, -1, -1}, {65294, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8220, -1, -1, -1}, {8221, -1, -1, -1}, {8216, -1, -1, -1}, {8217, -1, -1, -1}, {8243, -1, -1, -1}, {20956, -1, -1, -1}, {29081, -1, -1, -1}, {10102, -1, -1, -1}, {10103, -1, -1, -1}, {10104, -1, -1, -1}, {10105, -1, -1, -1}, {10106, -1, -1, -1}, {10107, -1, -1, -1}, {10108, -1, -1, -1}, {10109, -1, -1, -1}, {10110, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8570, -1, -1, -1}, {8571, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8575, -1, -1, -1}, {8458, -1, -1, -1}, {8457, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12292, -1, -1, -1}, {8646, -1, -1, -1}, {8644, 8645, -1, -1}, {8645, 8644, -1, -1}, {8646, -1, -1, -1}, {12535, -1, -1, -1}, {12536, -1, -1, -1}, {12537, -1, -1, -1}, {12538, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12957, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13179, -1, -1, -1}, {13183, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13107, -1, -1, -1}, {13134, -1, -1, -1}, {13090, -1, -1, -1}, {13078, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13061, -1, -1, -1}, {13107, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13134, -1, -1, -1}, {13059, -1, -1, -1}, {13080, -1, -1, -1}, {13077, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13113, -1, -1, -1}, {13143, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13122, -1, -1, -1}, {13091, -1, -1, -1}, {13115, -1, -1, -1}, {13056, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13086, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13098, -1, -1, -1}, {13127, -1, -1, -1}, {13105, -1, -1, -1}, {32394, -1, -1, -1}, {35100, -1, -1, -1}, {37704, -1, -1, -1}, {37512, -1, -1, -1}, {34012, -1, -1, -1}, {20425, -1, -1, -1}, {28859, -1, -1, -1}, {26161, -1, -1, -1}, {26824, -1, -1, -1}, {37625, -1, -1, -1}, {26363, -1, -1, -1}, {24389, -1, -1, -1}, {12033, 20008, -1, -1}, {20193, -1, -1, -1}, {20220, -1, -1, -1}, {20224, -1, -1, -1}, {20227, -1, -1, -1}, {20281, -1, -1, -1}, {20310, -1, -1, -1}, {20370, -1, -1, -1}, {20362, -1, -1, -1}, {20378, -1, -1, -1}, {20372, -1, -1, -1}, {20429, -1, -1, -1}, {20544, -1, -1, -1}, {20514, -1, -1, -1}, {20479, -1, -1, -1}, {20510, -1, -1, -1}, {20550, -1, -1, -1}, {20592, -1, -1, -1}, {20546, -1, -1, -1}, {20628, -1, -1, -1}, {20724, -1, -1, -1}, {20696, -1, -1, -1}, {20810, -1, -1, -1}, {20836, -1, -1, -1}, {20893, -1, -1, -1}, {20926, -1, -1, -1}, {20972, -1, -1, -1}, {21013, -1, -1, -1}, {21148, -1, -1, -1}, {21158, -1, -1, -1}, {21184, -1, -1, -1}, {21211, -1, -1, -1}, {21248, -1, -1, -1}, {21255, -1, -1, -1}, {21284, -1, -1, -1}, {21362, -1, -1, -1}, {21395, -1, -1, -1}, {21426, -1, -1, -1}, {21469, -1, -1, -1}, {64014, -1, -1, -1}, {21660, -1, -1, -1}, {21642, -1, -1, -1}, {21673, -1, -1, -1}, {21759, -1, -1, -1}, {21894, -1, -1, -1}, {22361, -1, -1, -1}, {22373, -1, -1, -1}, {22444, -1, -1, -1}, {22472, -1, -1, -1}, {22471, -1, -1, -1}, {64015, -1, -1, -1}, {64016, -1, -1, -1}, {22686, -1, -1, -1}, {22706, -1, -1, -1}, {22795, -1, -1, -1}, {22867, -1, -1, -1}, {22875, -1, -1, -1}, {22877, -1, -1, -1}, {22883, -1, -1, -1}, {22948, -1, -1, -1}, {22970, -1, -1, -1}, {23382, -1, -1, -1}, {23488, -1, -1, -1}, {29999, -1, -1, -1}, {23512, -1, -1, -1}, {23532, -1, -1, -1}, {23582, -1, -1, -1}, {23718, -1, -1, -1}, {23738, -1, -1, -1}, {23797, -1, -1, -1}, {23847, -1, -1, -1}, {23891, -1, -1, -1}, {64017, -1, -1, -1}, {23874, -1, -1, -1}, {23917, -1, -1, -1}, {23992, -1, -1, -1}, {23993, -1, -1, -1} },
+ {{24016, -1, -1, -1}, {24353, -1, -1, -1}, {24372, -1, -1, -1}, {24423, -1, -1, -1}, {24503, -1, -1, -1}, {24542, -1, -1, -1}, {24669, -1, -1, -1}, {24709, -1, -1, -1}, {24714, -1, -1, -1}, {24798, -1, -1, -1}, {24789, -1, -1, -1}, {24864, -1, -1, -1}, {24818, -1, -1, -1}, {24849, -1, -1, -1}, {24887, -1, -1, -1}, {24880, -1, -1, -1}, {24984, -1, -1, -1}, {25107, -1, -1, -1}, {25254, -1, -1, -1}, {25589, -1, -1, -1}, {25696, -1, -1, -1}, {25757, -1, -1, -1}, {25806, -1, -1, -1}, {25934, -1, -1, -1}, {26112, -1, -1, -1}, {26133, -1, -1, -1}, {26121, -1, -1, -1}, {26158, -1, -1, -1}, {26142, -1, -1, -1}, {26148, -1, -1, -1}, {26213, -1, -1, -1}, {26199, -1, -1, -1}, {26201, -1, -1, -1}, {64018, -1, -1, -1}, {26227, -1, -1, -1}, {26265, -1, -1, -1}, {26272, -1, -1, -1}, {26290, -1, -1, -1}, {26303, -1, -1, -1}, {26362, -1, -1, -1}, {26382, -1, -1, -1}, {63785, -1, -1, -1}, {26470, -1, -1, -1}, {26555, -1, -1, -1}, {26706, -1, -1, -1}, {26560, -1, -1, -1}, {26625, -1, -1, -1}, {26692, -1, -1, -1}, {26831, -1, -1, -1}, {64019, -1, -1, -1}, {26984, -1, -1, -1}, {64020, -1, -1, -1}, {27032, -1, -1, -1}, {27106, -1, -1, -1}, {27184, -1, -1, -1}, {27243, -1, -1, -1}, {27206, -1, -1, -1}, {27251, -1, -1, -1}, {27262, -1, -1, -1}, {27362, -1, -1, -1}, {27364, -1, -1, -1}, {27606, -1, -1, -1}, {27711, -1, -1, -1}, {27740, -1, -1, -1}, {27782, -1, -1, -1}, {27759, -1, -1, -1}, {27866, -1, -1, -1}, {27908, -1, -1, -1}, {28039, -1, -1, -1}, {28015, -1, -1, -1}, {28054, -1, -1, -1}, {28076, -1, -1, -1}, {28111, -1, -1, -1}, {28152, -1, -1, -1}, {28146, -1, -1, -1}, {28156, -1, -1, -1}, {28217, -1, -1, -1}, {28252, -1, -1, -1}, {28199, -1, -1, -1}, {28220, -1, -1, -1}, {28351, -1, -1, -1}, {28552, -1, -1, -1}, {28597, -1, -1, -1}, {28661, -1, -1, -1}, {28677, -1, -1, -1}, {28679, -1, -1, -1}, {28712, -1, -1, -1}, {28805, -1, -1, -1}, {28843, -1, -1, -1}, {28943, -1, -1, -1}, {28932, -1, -1, -1}, {29020, -1, -1, -1}, {28998, -1, -1, -1}, {28999, -1, -1, -1}, {64021, -1, -1, -1}, {29121, -1, -1, -1}, {29182, -1, -1, -1}, {29361, -1, -1, -1}, {29374, -1, -1, -1}, {29476, -1, -1, -1}, {64022, -1, -1, -1}, {29559, -1, -1, -1}, {29629, -1, -1, -1}, {29641, -1, -1, -1}, {29654, -1, -1, -1}, {29667, -1, -1, -1}, {29650, -1, -1, -1}, {29703, -1, -1, -1}, {29685, -1, -1, -1}, {29734, -1, -1, -1}, {29738, -1, -1, -1}, {29737, -1, -1, -1}, {29742, -1, -1, -1}, {29794, -1, -1, -1}, {29833, -1, -1, -1}, {29855, -1, -1, -1}, {29953, -1, -1, -1}, {30063, -1, -1, -1}, {30338, -1, -1, -1}, {30364, -1, -1, -1}, {30366, -1, -1, -1}, {30363, -1, -1, -1}, {30374, -1, -1, -1}, {64023, -1, -1, -1}, {30534, -1, -1, -1}, {21167, -1, -1, -1}, {30753, -1, -1, -1}, {30798, -1, -1, -1}, {30820, -1, -1, -1}, {30842, -1, -1, -1}, {31024, -1, -1, -1}, {64024, -1, -1, -1}, {64025, -1, -1, -1}, {64026, -1, -1, -1}, {31124, -1, -1, -1}, {64027, -1, -1, -1}, {31131, -1, -1, -1}, {31441, -1, -1, -1}, {31463, -1, -1, -1}, {64028, -1, -1, -1}, {31467, -1, -1, -1}, {31646, -1, -1, -1}, {64029, -1, -1, -1}, {32072, -1, -1, -1}, {32092, -1, -1, -1}, {32183, -1, -1, -1}, {32160, -1, -1, -1}, {32214, -1, -1, -1}, {32338, -1, -1, -1}, {32583, -1, -1, -1}, {32673, -1, -1, -1}, {64030, -1, -1, -1}, {33537, -1, -1, -1}, {33634, -1, -1, -1}, {33663, -1, -1, -1}, {33735, -1, -1, -1}, {33782, -1, -1, -1}, {33864, -1, -1, -1}, {33972, -1, -1, -1}, {34131, -1, -1, -1}, {34137, -1, -1, -1}, {34155, -1, -1, -1}, {64031, -1, -1, -1}, {34224, -1, -1, -1}, {64032, -1, -1, -1}, {64033, -1, -1, -1}, {34823, -1, -1, -1}, {35061, -1, -1, -1}, {35346, -1, -1, -1}, {35383, -1, -1, -1}, {35449, -1, -1, -1}, {35495, -1, -1, -1}, {35518, -1, -1, -1}, {35551, -1, -1, -1}, {64034, -1, -1, -1}, {35574, -1, -1, -1}, {35667, -1, -1, -1}, {35711, -1, -1, -1}, {36080, -1, -1, -1}, {36084, -1, -1, -1}, {36114, -1, -1, -1}, {36214, -1, -1, -1}, {64035, -1, -1, -1}, {36559, -1, -1, -1}, {64036, -1, -1, -1}, {64037, -1, -1, -1}, {36967, -1, -1, -1}, {37086, -1, -1, -1}, {64038, -1, -1, -1}, {37141, -1, -1, -1}, {37159, -1, -1, -1}, {37338, -1, -1, -1}, {37335, -1, -1, -1}, {37342, -1, -1, -1}, {37357, -1, -1, -1}, {37358, -1, -1, -1}, {37348, -1, -1, -1}, {37349, -1, -1, -1}, {37382, -1, -1, -1}, {37392, -1, -1, -1}, {37386, -1, -1, -1}, {37434, -1, -1, -1}, {37440, -1, -1, -1}, {37436, -1, -1, -1}, {37454, -1, -1, -1}, {37465, -1, -1, -1}, {37457, -1, -1, -1}, {37433, -1, -1, -1}, {37479, -1, -1, -1}, {37543, -1, -1, -1}, {37495, -1, -1, -1}, {37496, -1, -1, -1}, {37607, -1, -1, -1}, {37591, -1, -1, -1}, {37593, -1, -1, -1}, {37584, -1, -1, -1}, {64039, -1, -1, -1}, {37589, -1, -1, -1}, {37600, -1, -1, -1}, {37587, -1, -1, -1}, {37669, -1, -1, -1}, {37665, -1, -1, -1}, {37627, -1, -1, -1}, {64040, -1, -1, -1}, {37662, -1, -1, -1}, {37631, -1, -1, -1}, {37661, -1, -1, -1}, {37634, -1, -1, -1}, {37744, -1, -1, -1}, {37719, -1, -1, -1}, {37796, -1, -1, -1}, {37830, -1, -1, -1}, {37854, -1, -1, -1}, {37880, -1, -1, -1}, {37937, -1, -1, -1}, {37957, -1, -1, -1}, {37960, -1, -1, -1}, {38290, -1, -1, -1}, {63964, -1, -1, -1}, {64041, -1, -1, -1}, {38557, -1, -1, -1}, {38575, -1, -1, -1}, {38707, -1, -1, -1}, {38715, -1, -1, -1}, {38723, -1, -1, -1}, {38733, -1, -1, -1}, {38735, -1, -1, -1}, {12205, 38737, -1, -1}, {38741, -1, -1, -1}, {38999, -1, -1, -1}, {39013, -1, -1, -1}, {64042, -1, -1, -1}, {64043, -1, -1, -1}, {39207, -1, -1, -1}, {64044, -1, -1, -1}, {39326, -1, -1, -1} },
+ {{39502, -1, -1, -1}, {39641, -1, -1, -1}, {39644, -1, -1, -1}, {39797, -1, -1, -1}, {39794, -1, -1, -1}, {39823, -1, -1, -1}, {39857, -1, -1, -1}, {39867, -1, -1, -1}, {39936, -1, -1, -1}, {40304, -1, -1, -1}, {40299, -1, -1, -1}, {64045, -1, -1, -1}, {40473, -1, -1, -1}, {40657, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1}},
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8364, -1, -1, -1}, {8486, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {64256, -1, -1, -1}, {64259, -1, -1, -1}, {64260, -1, -1, -1}, {257, -1, -1, -1}, {299, -1, -1, -1}, {363, -1, -1, -1}, {275, -1, -1, -1}, {333, -1, -1, -1}, {256, -1, -1, -1}, {298, -1, -1, -1}, {362, -1, -1, -1}, {274, -1, -1, -1}, {332, -1, -1, -1}, {8539, -1, -1, -1}, {8540, -1, -1, -1}, {8541, -1, -1, -1}, {8542, -1, -1, -1}, {8531, -1, -1, -1}, {8532, -1, -1, -1}, {8304, -1, -1, -1}, {8308, -1, -1, -1}, {8309, -1, -1, -1}, {8310, -1, -1, -1}, {8311, -1, -1, -1}, {8312, -1, -1, -1}, {8313, -1, -1, -1}, {8320, -1, -1, -1}, {8321, -1, -1, -1}, {8322, -1, -1, -1}, {8323, -1, -1, -1}, {8324, -1, -1, -1}, {8325, -1, -1, -1}, {8326, -1, -1, -1}, {8327, -1, -1, -1}, {8328, -1, -1, -1}, {8329, -1, -1, -1}, {461, -1, -1, -1}, {282, -1, -1, -1}, {-1, -1, -1, -1}, {7868, -1, -1, -1}, {463, -1, -1, -1}, {-1, -1, -1, -1}, {296, -1, -1, -1}, {465, -1, -1, -1}, {-1, -1, -1, -1}, {467, -1, -1, -1}, {366, -1, -1, -1}, {360, -1, -1, -1}, {462, -1, -1, -1}, {283, -1, -1, -1}, {-1, -1, -1, -1}, {7869, -1, -1, -1}, {464, -1, -1, -1}, {-1, -1, -1, -1}, {297, -1, -1, -1}, {466, -1, -1, -1}, {-1, -1, -1, -1}, {468, -1, -1, -1}, {367, -1, -1, -1}, {361, -1, -1, -1}, {593, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {509, -1, -1, -1}, {-1, -1, -1, -1}, {596, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {601, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {602, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {603, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {331, -1, -1, -1}, {629, -1, -1, -1}, {652, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {658, -1, -1, -1}, {643, -1, -1, -1}, {720, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1}},
+ {{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1}},
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12832, -1, -1, -1}, {12833, -1, -1, -1}, {12834, -1, -1, -1}, {12835, -1, -1, -1}, {12836, -1, -1, -1}, {12837, -1, -1, -1}, {12838, -1, -1, -1}, {12839, -1, -1, -1}, {12840, -1, -1, -1}, {12841, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9424, -1, -1, -1}, {9425, -1, -1, -1}, {9426, -1, -1, -1}, {9427, -1, -1, -1}, {9428, -1, -1, -1}, {9429, -1, -1, -1}, {9430, -1, -1, -1}, {9431, -1, -1, -1}, {9432, -1, -1, -1}, {9433, -1, -1, -1}, {9434, -1, -1, -1}, {9435, -1, -1, -1}, {9436, -1, -1, -1}, {9437, -1, -1, -1}, {9438, -1, -1, -1}, {9439, -1, -1, -1}, {9440, -1, -1, -1}, {9441, -1, -1, -1}, {9442, -1, -1, -1}, {9443, -1, -1, -1}, {9444, -1, -1, -1}, {9445, -1, -1, -1}, {9446, -1, -1, -1}, {9447, -1, -1, -1}, {9448, -1, -1, -1}, {9449, -1, -1, -1}, {9398, -1, -1, -1}, {9399, -1, -1, -1}, {9400, -1, -1, -1}, {9401, -1, -1, -1}, {9402, -1, -1, -1}, {9403, -1, -1, -1}, {9404, -1, -1, -1}, {9405, -1, -1, -1}, {9406, -1, -1, -1}, {9407, -1, -1, -1}, {9408, -1, -1, -1}, {9409, -1, -1, -1}, {9410, -1, -1, -1}, {9411, -1, -1, -1}, {9412, -1, -1, -1}, {9413, -1, -1, -1}, {9414, -1, -1, -1}, {9415, -1, -1, -1}, {9416, -1, -1, -1}, {9417, -1, -1, -1}, {9418, -1, -1, -1}, {9419, -1, -1, -1}, {9420, -1, -1, -1}, {9421, -1, -1, -1}, {9422, -1, -1, -1}, {9423, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13008, -1, -1, -1}, {13009, -1, -1, -1}, {13010, -1, -1, -1}, {13011, -1, -1, -1}, {13012, -1, -1, -1}, {13013, -1, -1, -1}, {13014, -1, -1, -1}, {13015, -1, -1, -1}, {13016, -1, -1, -1}, {13017, -1, -1, -1}, {13018, -1, -1, -1}, {13019, -1, -1, -1}, {13020, -1, -1, -1}, {13021, -1, -1, -1}, {13022, -1, -1, -1}, {13023, -1, -1, -1}, {13024, -1, -1, -1}, {13025, -1, -1, -1}, {13026, -1, -1, -1}, {13027, -1, -1, -1}, {13028, -1, -1, -1}, {13029, -1, -1, -1}, {13030, -1, -1, -1}, {13031, -1, -1, -1}, {13032, -1, -1, -1}, {13033, -1, -1, -1}, {13034, -1, -1, -1}, {13035, -1, -1, -1}, {13036, -1, -1, -1}, {13037, -1, -1, -1}, {13038, -1, -1, -1}, {13039, -1, -1, -1}, {13040, -1, -1, -1}, {13041, -1, -1, -1}, {13042, -1, -1, -1}, {13043, -1, -1, -1}, {13044, -1, -1, -1}, {13045, -1, -1, -1}, {13046, -1, -1, -1}, {13047, -1, -1, -1}, {13048, -1, -1, -1}, {13049, -1, -1, -1}, {13050, -1, -1, -1}, {13051, -1, -1, -1}, {13052, -1, -1, -1}, {13053, -1, -1, -1}, {13054, -1, -1, -1}, {-1, -1, -1, -1}, {12928, -1, -1, -1}, {12929, -1, -1, -1}, {12930, -1, -1, -1}, {12931, -1, -1, -1}, {12932, -1, -1, -1}, {12933, -1, -1, -1}, {12934, -1, -1, -1}, {12935, -1, -1, -1}, {12936, -1, -1, -1}, {12937, -1, -1, -1}, {12944, -1, -1, -1}, {12938, -1, -1, -1}, {12939, -1, -1, -1}, {12940, -1, -1, -1}, {12941, -1, -1, -1}, {12942, -1, -1, -1}, {12943, -1, -1, -1}, {-1, -1, -1, -1}, {12959, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12960, -1, -1, -1}, {12961, -1, -1, -1}, {12955, -1, -1, -1}, {12954, -1, -1, -1}, {12963, -1, -1, -1}, {12962, -1, -1, -1}, {12951, -1, -1, -1}, {-1, -1, -1, -1}, {12956, -1, -1, -1}, {12949, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9676, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1}},
+ {{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1}},
+ {{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1}},
+ {{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1}},
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13274, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8448, -1, -1, -1}, {13250, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8453, -1, -1, -1}, {-1, -1, -1, -1}, {13169, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13197, -1, -1, -1}, {13211, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13271, -1, -1, -1}, {13272, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13057, -1, -1, -1}, {13058, -1, -1, -1}, {13060, -1, -1, -1}, {13062, -1, -1, -1}, {-1, -1, -1, -1}, {13064, -1, -1, -1}, {-1, -1, -1, -1}, {13063, -1, -1, -1}, {13066, -1, -1, -1}, {-1, -1, -1, -1}, {13065, -1, -1, -1}, {-1, -1, -1, -1}, {13067, -1, -1, -1}, {-1, -1, -1, -1}, {13068, -1, -1, -1}, {13070, -1, -1, -1}, {13071, -1, -1, -1}, {13072, -1, -1, -1}, {13073, -1, -1, -1}, {13074, -1, -1, -1}, {13075, -1, -1, -1}, {-1, -1, -1, -1}, {13079, -1, -1, -1}, {-1, -1, -1, -1}, {13081, -1, -1, -1}, {-1, -1, -1, -1}, {13082, -1, -1, -1}, {13083, -1, -1, -1}, {13084, -1, -1, -1}, {13085, -1, -1, -1}, {13087, -1, -1, -1}, {13088, -1, -1, -1}, {13089, -1, -1, -1}, {13092, -1, -1, -1}, {-1, -1, -1, -1}, {13093, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13096, -1, -1, -1}, {13097, -1, -1, -1}, {-1, -1, -1, -1}, {13101, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13102, -1, -1, -1}, {13103, -1, -1, -1}, {13104, -1, -1, -1}, {13106, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13108, -1, -1, -1}, {13109, -1, -1, -1}, {13116, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13111, -1, -1, -1}, {-1, -1, -1, -1}, {13112, -1, -1, -1}, {13114, -1, -1, -1}, {13117, -1, -1, -1}, {13121, -1, -1, -1}, {13118, -1, -1, -1}, {13119, -1, -1, -1}, {13120, -1, -1, -1}, {13123, -1, -1, -1}, {13124, -1, -1, -1}, {13125, -1, -1, -1}, {13126, -1, -1, -1}, {13128, -1, -1, -1}, {13131, -1, -1, -1}, {13132, -1, -1, -1}, {13135, -1, -1, -1}, {13136, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13138, -1, -1, -1}, {13140, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13139, -1, -1, -1}, {13141, -1, -1, -1}, {13142, -1, -1, -1}, {-1, -1, -1, -1}, {13057, -1, -1, -1}, {13058, -1, -1, -1}, {13060, -1, -1, -1}, {13062, -1, -1, -1}, {-1, -1, -1, -1}, {13064, -1, -1, -1}, {-1, -1, -1, -1}, {13063, -1, -1, -1}, {13066, -1, -1, -1}, {-1, -1, -1, -1}, {13065, -1, -1, -1}, {-1, -1, -1, -1}, {13067, -1, -1, -1}, {-1, -1, -1, -1}, {13068, -1, -1, -1}, {13070, -1, -1, -1}, {13071, -1, -1, -1}, {13072, -1, -1, -1}, {13073, -1, -1, -1}, {13074, -1, -1, -1}, {13075, -1, -1, -1}, {-1, -1, -1, -1}, {13079, -1, -1, -1}, {-1, -1, -1, -1}, {13081, -1, -1, -1}, {-1, -1, -1, -1}, {13082, -1, -1, -1}, {13083, -1, -1, -1}, {13084, -1, -1, -1}, {13085, -1, -1, -1}, {13087, -1, -1, -1}, {13088, -1, -1, -1}, {13089, -1, -1, -1}, {13092, -1, -1, -1}, {-1, -1, -1, -1}, {13093, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13096, -1, -1, -1}, {13097, -1, -1, -1}, {-1, -1, -1, -1}, {13101, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13102, -1, -1, -1}, {13103, -1, -1, -1}, {13104, -1, -1, -1}, {13106, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13108, -1, -1, -1}, {13109, -1, -1, -1}, {13116, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13111, -1, -1, -1}, {-1, -1, -1, -1}, {13112, -1, -1, -1}, {13114, -1, -1, -1}, {13117, -1, -1, -1}, {13121, -1, -1, -1}, {13118, -1, -1, -1}, {13119, -1, -1, -1}, {13120, -1, -1, -1}, {13123, -1, -1, -1}, {13124, -1, -1, -1}, {13125, -1, -1, -1}, {13126, -1, -1, -1}, {13128, -1, -1, -1}, {13131, -1, -1, -1}, {13132, -1, -1, -1}, {13135, -1, -1, -1}, {13136, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {13138, -1, -1, -1}, {13140, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13139, -1, -1, -1}, {13141, -1, -1, -1}, {13142, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8501, -1, -1, -1}, {976, -1, -1, -1}, {8714, -1, -1, -1}, {295, 8463, 1115, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {987, -1, -1, -1}, {977, -1, -1, -1}, {-1, -1, -1, -1}, {9832, -1, -1, -1}, {9833, -1, -1, -1}, {9836, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12339, -1, -1, -1}, {12340, -1, -1, -1}, {12341, -1, -1, -1}, {8252, -1, -1, -1}, {8265, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9290, -1, -1, -1}, {-1, -1, -1, -1}, {8723, -1, -1, -1}, {-1, -1, -1, -1}, {8771, -1, -1, -1}, {8818, -1, -1, -1}, {8819, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9986, -1, -1, -1}, {-1, -1, -1, -1}, {9986, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8709, 8960, -1, -1}, {9746, 8864, -1, -1}, {8861, 8854, -1, -1}, {8856, -1, -1, -1}, {8853, -1, -1, -1}, {8855, -1, -1, -1}, {8862, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9664, -1, -1, -1}, {9654, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8656, -1, -1, -1}, {8596, -1, -1, -1}, {8600, -1, -1, -1}, {8601, -1, -1, -1}, {8598, -1, -1, -1}, {8599, -1, -1, -1}, {8652, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8597, -1, -1, -1}, {8597, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12336, -1, -1, -1}, {8967, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9643, -1, -1, -1}, {-1, -1, -1, -1}, {9642, -1, -1, -1}, {-1, -1, -1, -1}, {10010, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9702, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {10070, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1}},
+ {{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1}},
+ {{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1}},
+ {{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1},{-1,-1,-1,-1}},
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {32227, -1, -1, -1}, {12232, 40643, -1, -1}, {28331, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {28212, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {34395, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {25581, -1, -1, -1}, {25802, -1, -1, -1}, {30799, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {28041, -1, -1, -1}, {29376, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {24034, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {21373, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {24501, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {39725, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {20482, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {27493, -1, -1, -1}, {-1, -1, -1, -1}, {27599, -1, -1, -1}, {-1, -1, -1, -1}, {25150, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {28122, -1, -1, -1}, {-1, -1, -1, -1}, {26310, -1, -1, -1}, {27511, -1, -1, -1}, {-1, -1, -1, -1}, {37706, -1, -1, -1}, {-1, -1, -1, -1}, {37636, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11991, -1, -1, -1}, {11965, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {37555, -1, -1, -1}, {38321, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {27114, -1, -1, -1}, {-1, -1, -1, -1}, {26478, -1, -1, -1}, {11974, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13314, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {26083, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {24378, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11945, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11964, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {26435, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {35329, -1, -1, -1}, {25142, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {21555, -1, -1, -1}, {23067, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {25221, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {21567, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {27506, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {29986, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {24063, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {29626, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11916, -1, -1, -1}, {11917, -1, -1, -1}, {23577, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {23426, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11997, -1, -1, -1}, {11999, 39136, -1, -1}, {11998, -1, -1, -1}, {14221, -1, -1, -1}, {-1, -1, -1, -1}, {11927, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11909, 20155, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13599, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11971, 35200, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {31237, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {35498, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {28568, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {25591, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11978, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {13351, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {33067, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11950, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {22305, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {15240, -1, -1, -1}, {20839, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {20023, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11946, -1, -1, -1}, {24421, -1, -1, -1}, {23020, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {24217, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {21200, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11959, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {36534, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {31867, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11961, 32770, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11911, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11915, 13630, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {21589, -1, -1, -1}, {-1, -1, -1, -1}, {22841, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {23572, -1, -1, -1}, {14306, -1, -1, -1}, {23782, -1, -1, -1}, {-1, -1, -1, -1}, {20040, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {25371, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {26211, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {27126, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {27596, -1, -1, -1}, {-1, -1, -1, -1}, {28183, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {27818, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11942, 20012, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {29935, -1, -1, -1}, {30069, -1, -1, -1}, {30188, -1, -1, -1}, {30286, -1, -1, -1}, {16305, -1, -1, -1}, {30570, -1, -1, -1}, {30633, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {31571, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {16996, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {32328, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11955, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {33089, -1, -1, -1}, {17491, -1, -1, -1}, {-1, -1, -1, -1}, {11966, 33401, -1, -1}, {11967, -1, -1, -1}, {11968, -1, -1, -1}, {-1, -1, -1, -1}, {20857, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {34292, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {34429, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {35014, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {36808, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {38969, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {39432, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {39903, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {21385, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {19972, -1, -1, -1}, {19973, -1, -1, -1}, {19999, -1, -1, -1}, {20011, -1, -1, -1}, {20015, -1, -1, -1}, {20016, -1, -1, -1}, {20032, -1, -1, -1}, {20033, -1, -1, -1}, {20036, -1, -1, -1}, {11907, 20058, -1, -1}, {20095, -1, -1, -1}, {20109, -1, -1, -1}, {20118, -1, -1, -1}, {20153, -1, -1, -1}, {20176, -1, -1, -1}, {20192, -1, -1, -1}, {20221, -1, -1, -1}, {20223, -1, -1, -1}, {20235, -1, -1, -1}, {20245, -1, -1, -1}, {20320, -1, -1, -1}, {20283, -1, -1, -1}, {20297, -1, -1, -1}, {20308, -1, -1, -1}, {20346, -1, -1, -1}, {20349, -1, -1, -1}, {20350, -1, -1, -1}, {20375, -1, -1, -1}, {20414, -1, -1, -1}, {20431, -1, -1, -1}, {20477, -1, -1, -1}, {20480, -1, -1, -1}, {20481, -1, -1, -1}, {20496, -1, -1, -1}, {20507, -1, -1, -1}, {20519, -1, -1, -1}, {20526, -1, -1, -1}, {20567, -1, -1, -1}, {20582, -1, -1, -1}, {20586, -1, -1, -1} },
+ {{20539, -1, -1, -1}, {20623, -1, -1, -1}, {20630, -1, -1, -1}, {20636, -1, -1, -1}, {20684, -1, -1, -1}, {20710, -1, -1, -1}, {20713, -1, -1, -1}, {20719, -1, -1, -1}, {20744, -1, -1, -1}, {20747, -1, -1, -1}, {20752, -1, -1, -1}, {20763, -1, -1, -1}, {20766, -1, -1, -1}, {20831, -1, -1, -1}, {20897, -1, -1, -1}, {20924, -1, -1, -1}, {20958, -1, -1, -1}, {20974, -1, -1, -1}, {20980, -1, -1, -1}, {20993, -1, -1, -1}, {11913, 20994, -1, -1}, {21011, -1, -1, -1}, {21065, -1, -1, -1}, {21089, -1, -1, -1}, {21094, -1, -1, -1}, {21139, -1, -1, -1}, {21192, -1, -1, -1}, {21232, -1, -1, -1}, {21258, -1, -1, -1}, {21259, -1, -1, -1}, {21310, -1, -1, -1}, {21324, -1, -1, -1}, {21323, -1, -1, -1}, {21345, -1, -1, -1}, {21356, -1, -1, -1}, {21419, -1, -1, -1}, {21466, -1, -1, -1}, {21478, -1, -1, -1}, {21493, -1, -1, -1}, {21543, -1, -1, -1}, {21581, -1, -1, -1}, {21606, -1, -1, -1}, {21611, -1, -1, -1}, {21620, -1, -1, -1}, {21645, -1, -1, -1}, {21654, -1, -1, -1}, {21665, -1, -1, -1}, {21677, -1, -1, -1}, {21689, -1, -1, -1}, {21695, -1, -1, -1}, {21702, -1, -1, -1}, {21709, -1, -1, -1}, {21774, -1, -1, -1}, {21803, -1, -1, -1}, {21813, -1, -1, -1}, {21834, -1, -1, -1}, {21856, -1, -1, -1}, {21857, -1, -1, -1}, {21896, -1, -1, -1}, {21902, -1, -1, -1}, {22024, -1, -1, -1}, {22030, -1, -1, -1}, {22031, -1, -1, -1}, {22071, -1, -1, -1}, {22079, -1, -1, -1}, {22089, -1, -1, -1}, {22091, -1, -1, -1}, {22095, -1, -1, -1}, {22118, -1, -1, -1}, {22121, -1, -1, -1}, {22127, -1, -1, -1}, {22129, -1, -1, -1}, {22130, -1, -1, -1}, {22165, -1, -1, -1}, {22170, -1, -1, -1}, {22188, -1, -1, -1}, {22189, -1, -1, -1}, {22193, -1, -1, -1}, {22217, -1, -1, -1}, {22237, -1, -1, -1}, {22244, -1, -1, -1}, {22282, -1, -1, -1}, {22293, -1, -1, -1}, {22307, -1, -1, -1}, {22319, -1, -1, -1}, {22323, -1, -1, -1}, {22324, -1, -1, -1}, {22348, -1, -1, -1}, {22384, -1, -1, -1}, {22412, -1, -1, -1}, {22428, -1, -1, -1}, {22456, -1, -1, -1}, {22502, -1, -1, -1}, {22509, -1, -1, -1}, {22517, -1, -1, -1}, {22518, -1, -1, -1}, {22527, -1, -1, -1}, {22537, -1, -1, -1}, {22560, -1, -1, -1}, {22578, -1, -1, -1}, {22652, -1, -1, -1}, {22656, -1, -1, -1}, {22697, -1, -1, -1}, {22734, -1, -1, -1}, {22736, -1, -1, -1}, {22740, -1, -1, -1}, {22746, -1, -1, -1}, {22761, -1, -1, -1}, {22796, -1, -1, -1}, {22820, -1, -1, -1}, {22831, -1, -1, -1}, {22881, -1, -1, -1}, {22893, -1, -1, -1}, {22986, -1, -1, -1}, {22994, -1, -1, -1}, {23005, -1, -1, -1}, {23011, -1, -1, -1}, {23012, -1, -1, -1}, {23044, -1, -1, -1}, {23052, -1, -1, -1}, {23075, -1, -1, -1}, {23111, -1, -1, -1}, {23125, -1, -1, -1}, {23139, -1, -1, -1}, {23149, -1, -1, -1}, {23166, -1, -1, -1}, {23198, -1, -1, -1}, {23207, -1, -1, -1}, {23212, -1, -1, -1}, {23219, -1, -1, -1}, {23264, -1, -1, -1}, {23296, -1, -1, -1}, {23321, -1, -1, -1}, {23333, -1, -1, -1}, {23341, -1, -1, -1}, {23361, -1, -1, -1}, {23420, -1, -1, -1}, {23422, -1, -1, -1}, {23423, -1, -1, -1}, {23434, -1, -1, -1}, {11919, 23587, -1, -1}, {23595, -1, -1, -1}, {23600, -1, -1, -1}, {23651, -1, -1, -1}, {23657, -1, -1, -1}, {23676, -1, -1, -1}, {23755, -1, -1, -1}, {23762, -1, -1, -1}, {23796, -1, -1, -1}, {23844, -1, -1, -1}, {23846, -1, -1, -1}, {23875, -1, -1, -1}, {23878, -1, -1, -1}, {23882, -1, -1, -1}, {23954, -1, -1, -1}, {23956, -1, -1, -1}, {23961, -1, -1, -1}, {23968, -1, -1, -1}, {24024, -1, -1, -1}, {24032, -1, -1, -1}, {24056, -1, -1, -1}, {24064, -1, -1, -1}, {24082, -1, -1, -1}, {24084, -1, -1, -1}, {24085, -1, -1, -1}, {24088, -1, -1, -1}, {24110, -1, -1, -1}, {24152, -1, -1, -1}, {24171, -1, -1, -1}, {24172, -1, -1, -1}, {24232, -1, -1, -1}, {24234, -1, -1, -1}, {24254, -1, -1, -1}, {24255, -1, -1, -1}, {24267, -1, -1, -1}, {24274, -1, -1, -1}, {24327, -1, -1, -1}, {24334, -1, -1, -1}, {24348, -1, -1, -1}, {24349, -1, -1, -1}, {24354, -1, -1, -1}, {24360, -1, -1, -1}, {24374, -1, -1, -1}, {24379, -1, -1, -1}, {24384, -1, -1, -1}, {12089, 24400, -1, -1}, {24408, -1, -1, -1}, {24420, -1, -1, -1}, {24457, -1, -1, -1}, {24476, -1, -1, -1}, {24487, -1, -1, -1}, {24484, -1, -1, -1}, {24495, -1, -1, -1}, {24504, -1, -1, -1}, {11926, 24516, -1, -1}, {24521, -1, -1, -1}, {24545, -1, -1, -1}, {24553, -1, -1, -1}, {24557, -1, -1, -1}, {24572, -1, -1, -1}, {24599, -1, -1, -1}, {24602, -1, -1, -1}, {24627, -1, -1, -1}, {24673, -1, -1, -1}, {24703, -1, -1, -1}, {24734, -1, -1, -1}, {24740, -1, -1, -1}, {24752, -1, -1, -1}, {24779, -1, -1, -1}, {24795, -1, -1, -1}, {24824, -1, -1, -1}, {24850, -1, -1, -1}, {24851, -1, -1, -1}, {24852, -1, -1, -1}, {24860, -1, -1, -1}, {24956, -1, -1, -1}, {24973, -1, -1, -1}, {24991, -1, -1, -1}, {25000, -1, -1, -1}, {25026, -1, -1, -1}, {25055, -1, -1, -1}, {25109, -1, -1, -1}, {25129, -1, -1, -1}, {25155, -1, -1, -1}, {25158, -1, -1, -1}, {11928, 25164, -1, -1}, {25169, -1, -1, -1}, {25174, -1, -1, -1}, {25284, -1, -1, -1}, {25340, -1, -1, -1}, {25354, -1, -1, -1}, {25357, -1, -1, -1}, {25368, -1, -1, -1}, {25401, -1, -1, -1}, {25410, -1, -1, -1}, {25411, -1, -1, -1}, {25445, -1, -1, -1}, {25460, -1, -1, -1}, {25469, -1, -1, -1}, {25476, -1, -1, -1}, {25479, -1, -1, -1}, {25488, -1, -1, -1}, {25502, -1, -1, -1}, {25553, -1, -1, -1}, {25564, -1, -1, -1}, {25609, -1, -1, -1}, {25616, -1, -1, -1}, {25634, -1, -1, -1}, {25684, -1, -1, -1}, {25691, -1, -1, -1}, {25709, -1, -1, -1}, {25723, -1, -1, -1}, {25790, -1, -1, -1}, {25791, -1, -1, -1}, {25829, -1, -1, -1}, {25847, -1, -1, -1} },
+ {{25851, -1, -1, -1}, {25860, -1, -1, -1}, {25878, -1, -1, -1}, {25881, -1, -1, -1}, {25927, -1, -1, -1}, {25959, -1, -1, -1}, {25985, -1, -1, -1}, {25989, -1, -1, -1}, {26050, -1, -1, -1}, {26096, -1, -1, -1}, {26098, -1, -1, -1}, {26156, -1, -1, -1}, {26188, -1, -1, -1}, {26203, -1, -1, -1}, {26204, -1, -1, -1}, {26209, -1, -1, -1}, {26219, -1, -1, -1}, {26231, -1, -1, -1}, {26276, -1, -1, -1}, {26312, -1, -1, -1}, {26348, -1, -1, -1}, {26373, -1, -1, -1}, {26387, -1, -1, -1}, {26419, -1, -1, -1}, {26440, -1, -1, -1}, {26444, -1, -1, -1}, {26486, -1, -1, -1}, {26491, -1, -1, -1}, {26544, -1, -1, -1}, {26546, -1, -1, -1}, {26617, -1, -1, -1}, {26583, -1, -1, -1}, {26585, -1, -1, -1}, {26608, -1, -1, -1}, {26668, -1, -1, -1}, {26672, -1, -1, -1}, {26673, -1, -1, -1}, {26715, -1, -1, -1}, {26738, -1, -1, -1}, {26741, -1, -1, -1}, {26746, -1, -1, -1}, {26756, -1, -1, -1}, {26789, -1, -1, -1}, {26802, -1, -1, -1}, {26832, -1, -1, -1}, {26838, -1, -1, -1}, {26856, -1, -1, -1}, {26861, -1, -1, -1}, {26864, -1, -1, -1}, {26865, -1, -1, -1}, {26876, -1, -1, -1}, {26897, -1, -1, -1}, {26899, -1, -1, -1}, {26933, -1, -1, -1}, {26939, -1, -1, -1}, {26967, -1, -1, -1}, {26979, -1, -1, -1}, {26994, -1, -1, -1}, {27007, -1, -1, -1}, {27008, -1, -1, -1}, {27046, -1, -1, -1}, {27053, -1, -1, -1}, {27063, -1, -1, -1}, {27094, -1, -1, -1}, {27095, -1, -1, -1}, {27137, -1, -1, -1}, {27151, -1, -1, -1}, {27157, -1, -1, -1}, {27176, -1, -1, -1}, {27188, -1, -1, -1}, {27198, -1, -1, -1}, {27205, -1, -1, -1}, {27216, -1, -1, -1}, {27217, -1, -1, -1}, {27222, -1, -1, -1}, {27227, -1, -1, -1}, {27267, -1, -1, -1}, {27273, -1, -1, -1}, {27281, -1, -1, -1}, {27293, -1, -1, -1}, {27294, -1, -1, -1}, {27295, -1, -1, -1}, {27356, -1, -1, -1}, {27367, -1, -1, -1}, {27372, -1, -1, -1}, {27422, -1, -1, -1}, {27428, -1, -1, -1}, {27445, -1, -1, -1}, {27462, -1, -1, -1}, {27478, -1, -1, -1}, {27488, -1, -1, -1}, {27522, -1, -1, -1}, {27582, -1, -1, -1}, {27617, -1, -1, -1}, {27633, -1, -1, -1}, {27664, -1, -1, -1}, {27699, -1, -1, -1}, {11937, 27701, -1, -1}, {11938, 27706, -1, -1}, {27737, -1, -1, -1}, {27766, -1, -1, -1}, {27771, -1, -1, -1}, {27781, -1, -1, -1}, {27797, -1, -1, -1}, {27804, -1, -1, -1}, {27856, -1, -1, -1}, {27860, -1, -1, -1}, {27862, -1, -1, -1}, {27872, -1, -1, -1}, {27883, -1, -1, -1}, {27884, -1, -1, -1}, {27886, -1, -1, -1}, {27914, -1, -1, -1}, {27918, -1, -1, -1}, {27921, -1, -1, -1}, {27950, -1, -1, -1}, {27991, -1, -1, -1}, {27998, -1, -1, -1}, {28005, -1, -1, -1}, {28034, -1, -1, -1}, {28095, -1, -1, -1}, {28100, -1, -1, -1}, {28106, -1, -1, -1}, {28118, -1, -1, -1}, {28137, -1, -1, -1}, {28194, -1, -1, -1}, {28241, -1, -1, -1}, {28359, -1, -1, -1}, {28362, -1, -1, -1}, {28366, -1, -1, -1}, {28413, -1, -1, -1}, {28442, -1, -1, -1}, {28458, -1, -1, -1}, {28463, -1, -1, -1}, {28467, -1, -1, -1}, {28506, -1, -1, -1}, {28510, -1, -1, -1}, {28514, -1, -1, -1}, {28541, -1, -1, -1}, {28555, -1, -1, -1}, {28557, -1, -1, -1}, {28562, -1, -1, -1}, {28564, -1, -1, -1}, {28570, -1, -1, -1}, {28583, -1, -1, -1}, {28584, -1, -1, -1}, {28598, -1, -1, -1}, {28634, -1, -1, -1}, {28638, -1, -1, -1}, {28665, -1, -1, -1}, {28729, -1, -1, -1}, {28732, -1, -1, -1}, {28746, -1, -1, -1}, {28756, -1, -1, -1}, {28765, -1, -1, -1}, {28766, -1, -1, -1}, {28772, -1, -1, -1}, {11939, 28780, -1, -1}, {28798, -1, -1, -1}, {28801, -1, -1, -1}, {28821, -1, -1, -1}, {28855, -1, -1, -1}, {28883, -1, -1, -1}, {28884, -1, -1, -1}, {28888, -1, -1, -1}, {28892, -1, -1, -1}, {28935, -1, -1, -1}, {28960, -1, -1, -1}, {28977, -1, -1, -1}, {29002, -1, -1, -1}, {29010, -1, -1, -1}, {29024, -1, -1, -1}, {29049, -1, -1, -1}, {29074, -1, -1, -1}, {29107, -1, -1, -1}, {29131, -1, -1, -1}, {29139, -1, -1, -1}, {29142, -1, -1, -1}, {29184, -1, -1, -1}, {29213, -1, -1, -1}, {29227, -1, -1, -1}, {29240, -1, -1, -1}, {29249, -1, -1, -1}, {29267, -1, -1, -1}, {29269, -1, -1, -1}, {29270, -1, -1, -1}, {29276, -1, -1, -1}, {29325, -1, -1, -1}, {11944, 29357, -1, -1}, {29364, -1, -1, -1}, {29383, -1, -1, -1}, {29435, -1, -1, -1}, {29444, -1, -1, -1}, {29445, -1, -1, -1}, {29480, -1, -1, -1}, {29489, -1, -1, -1}, {29507, -1, -1, -1}, {29548, -1, -1, -1}, {29564, -1, -1, -1}, {29571, -1, -1, -1}, {29573, -1, -1, -1}, {29574, -1, -1, -1}, {29589, -1, -1, -1}, {29598, -1, -1, -1}, {29599, -1, -1, -1}, {29600, -1, -1, -1}, {29606, -1, -1, -1}, {29611, -1, -1, -1}, {29621, -1, -1, -1}, {29623, -1, -1, -1}, {29628, -1, -1, -1}, {29647, -1, -1, -1}, {29657, -1, -1, -1}, {29673, -1, -1, -1}, {29684, -1, -1, -1}, {29693, -1, -1, -1}, {29700, -1, -1, -1}, {29706, -1, -1, -1}, {29722, -1, -1, -1}, {29723, -1, -1, -1}, {29732, -1, -1, -1}, {29736, -1, -1, -1}, {29740, -1, -1, -1}, {29743, -1, -1, -1}, {29744, -1, -1, -1}, {29745, -1, -1, -1}, {29753, -1, -1, -1}, {29764, -1, -1, -1}, {29767, -1, -1, -1}, {29771, -1, -1, -1}, {29773, -1, -1, -1}, {29777, -1, -1, -1}, {29783, -1, -1, -1}, {29798, -1, -1, -1}, {29803, -1, -1, -1}, {29809, -1, -1, -1}, {29824, -1, -1, -1}, {29829, -1, -1, -1}, {29830, -1, -1, -1}, {29831, -1, -1, -1}, {29840, -1, -1, -1}, {29848, -1, -1, -1}, {29852, -1, -1, -1}, {29856, -1, -1, -1}, {29859, -1, -1, -1}, {29864, -1, -1, -1}, {29867, -1, -1, -1}, {29877, -1, -1, -1}, {29887, -1, -1, -1}, {29896, -1, -1, -1}, {29914, -1, -1, -1}, {29918, -1, -1, -1}, {30030, -1, -1, -1}, {30073, -1, -1, -1}, {30081, -1, -1, -1}, {30096, -1, -1, -1} },
+ {{12135, 30098, -1, -1}, {30099, -1, -1, -1}, {30132, -1, -1, -1}, {30180, -1, -1, -1}, {30201, -1, -1, -1}, {30208, -1, -1, -1}, {30218, -1, -1, -1}, {30229, -1, -1, -1}, {30230, -1, -1, -1}, {30233, -1, -1, -1}, {30238, -1, -1, -1}, {30253, -1, -1, -1}, {30261, -1, -1, -1}, {30275, -1, -1, -1}, {30283, -1, -1, -1}, {30309, -1, -1, -1}, {30317, -1, -1, -1}, {30319, -1, -1, -1}, {30321, -1, -1, -1}, {30324, -1, -1, -1}, {30372, -1, -1, -1}, {30373, -1, -1, -1}, {30405, -1, -1, -1}, {30412, -1, -1, -1}, {30444, -1, -1, -1}, {30460, -1, -1, -1}, {30516, -1, -1, -1}, {30518, -1, -1, -1}, {30556, -1, -1, -1}, {30559, -1, -1, -1}, {30560, -1, -1, -1}, {30578, -1, -1, -1}, {30589, -1, -1, -1}, {30613, -1, -1, -1}, {30634, -1, -1, -1}, {30694, -1, -1, -1}, {30704, -1, -1, -1}, {30708, -1, -1, -1}, {30726, -1, -1, -1}, {30754, -1, -1, -1}, {30765, -1, -1, -1}, {30766, -1, -1, -1}, {30768, -1, -1, -1}, {30773, -1, -1, -1}, {30824, -1, -1, -1}, {30878, -1, -1, -1}, {30920, -1, -1, -1}, {30924, -1, -1, -1}, {30926, -1, -1, -1}, {30948, -1, -1, -1}, {30944, -1, -1, -1}, {30945, -1, -1, -1}, {30962, -1, -1, -1}, {30967, -1, -1, -1}, {30971, -1, -1, -1}, {31025, -1, -1, -1}, {31028, -1, -1, -1}, {11949, 31035, -1, -1}, {31037, -1, -1, -1}, {31045, -1, -1, -1}, {31067, -1, -1, -1}, {31068, -1, -1, -1}, {31115, -1, -1, -1}, {31126, -1, -1, -1}, {31128, -1, -1, -1}, {12145, 31160, -1, -1}, {31163, -1, -1, -1}, {31178, -1, -1, -1}, {31194, -1, -1, -1}, {31235, -1, -1, -1}, {31241, -1, -1, -1}, {31249, -1, -1, -1}, {31262, -1, -1, -1}, {31277, -1, -1, -1}, {31289, -1, -1, -1}, {31301, -1, -1, -1}, {31308, -1, -1, -1}, {31325, -1, -1, -1}, {31328, -1, -1, -1}, {31341, -1, -1, -1}, {31352, -1, -1, -1}, {31392, -1, -1, -1}, {31395, -1, -1, -1}, {31411, -1, -1, -1}, {31419, -1, -1, -1}, {31420, -1, -1, -1}, {31430, -1, -1, -1}, {31495, -1, -1, -1}, {31508, -1, -1, -1}, {31527, -1, -1, -1}, {31537, -1, -1, -1}, {31559, -1, -1, -1}, {31566, -1, -1, -1}, {31584, -1, -1, -1}, {31593, -1, -1, -1}, {31597, -1, -1, -1}, {31602, -1, -1, -1}, {31633, -1, -1, -1}, {31663, -1, -1, -1}, {31703, -1, -1, -1}, {31705, -1, -1, -1}, {31755, -1, -1, -1}, {31759, -1, -1, -1}, {31776, -1, -1, -1}, {31782, -1, -1, -1}, {31793, -1, -1, -1}, {31798, -1, -1, -1}, {31825, -1, -1, -1}, {31833, -1, -1, -1}, {31847, -1, -1, -1}, {31854, -1, -1, -1}, {31856, -1, -1, -1}, {31932, -1, -1, -1}, {31935, -1, -1, -1}, {31944, -1, -1, -1}, {31945, -1, -1, -1}, {31959, -1, -1, -1}, {31961, -1, -1, -1}, {31965, -1, -1, -1}, {31979, -1, -1, -1}, {32007, -1, -1, -1}, {32008, -1, -1, -1}, {32009, -1, -1, -1}, {32019, -1, -1, -1}, {32029, -1, -1, -1}, {32035, -1, -1, -1}, {32065, -1, -1, -1}, {32083, -1, -1, -1}, {32089, -1, -1, -1}, {32093, -1, -1, -1}, {32122, -1, -1, -1}, {32134, -1, -1, -1}, {32139, -1, -1, -1}, {32140, -1, -1, -1}, {32204, -1, -1, -1}, {32235, -1, -1, -1}, {32241, -1, -1, -1}, {32249, -1, -1, -1}, {32264, -1, -1, -1}, {32273, -1, -1, -1}, {32277, -1, -1, -1}, {32288, -1, -1, -1}, {32327, -1, -1, -1}, {32354, -1, -1, -1}, {32366, -1, -1, -1}, {32371, -1, -1, -1}, {32397, -1, -1, -1}, {32401, -1, -1, -1}, {32408, -1, -1, -1}, {32580, -1, -1, -1}, {32591, -1, -1, -1}, {11954, 11947, 32594, -1}, {11953, 32595, -1, -1}, {32609, -1, -1, -1}, {32657, -1, -1, -1}, {32703, -1, -1, -1}, {32718, -1, -1, -1}, {32735, -1, -1, -1}, {32741, -1, -1, -1}, {32748, -1, -1, -1}, {32750, -1, -1, -1}, {32751, -1, -1, -1}, {32762, -1, -1, -1}, {32782, -1, -1, -1}, {32785, -1, -1, -1}, {32788, -1, -1, -1}, {32804, -1, -1, -1}, {32806, -1, -1, -1}, {32826, -1, -1, -1}, {32828, -1, -1, -1}, {32864, -1, -1, -1}, {32881, -1, -1, -1}, {32885, -1, -1, -1}, {32926, -1, -1, -1}, {32934, -1, -1, -1}, {32939, -1, -1, -1}, {32983, -1, -1, -1}, {32984, -1, -1, -1}, {33046, -1, -1, -1}, {33048, -1, -1, -1}, {33082, -1, -1, -1}, {33098, -1, -1, -1}, {33100, -1, -1, -1}, {33153, -1, -1, -1}, {33156, -1, -1, -1}, {33204, -1, -1, -1}, {33231, -1, -1, -1}, {33273, -1, -1, -1}, {33283, -1, -1, -1}, {33313, -1, -1, -1}, {33330, -1, -1, -1}, {33332, -1, -1, -1}, {33350, -1, -1, -1}, {33355, -1, -1, -1}, {33359, -1, -1, -1}, {33422, -1, -1, -1}, {33454, -1, -1, -1}, {33463, -1, -1, -1}, {33470, -1, -1, -1}, {33478, -1, -1, -1}, {33534, -1, -1, -1}, {33603, -1, -1, -1}, {33617, -1, -1, -1}, {33621, -1, -1, -1}, {33670, -1, -1, -1}, {33677, -1, -1, -1}, {33682, -1, -1, -1}, {33688, -1, -1, -1}, {33705, -1, -1, -1}, {33727, -1, -1, -1}, {33728, -1, -1, -1}, {33770, -1, -1, -1}, {33807, -1, -1, -1}, {33809, -1, -1, -1}, {33866, -1, -1, -1}, {33910, -1, -1, -1}, {33960, -1, -1, -1}, {33967, -1, -1, -1}, {33984, -1, -1, -1}, {33986, -1, -1, -1}, {34032, -1, -1, -1}, {34045, -1, -1, -1}, {34060, -1, -1, -1}, {34100, -1, -1, -1}, {34142, -1, -1, -1}, {34191, -1, -1, -1}, {34231, -1, -1, -1}, {34254, -1, -1, -1}, {34221, -1, -1, -1}, {34322, -1, -1, -1}, {34345, -1, -1, -1}, {34386, -1, -1, -1}, {34403, -1, -1, -1}, {34412, -1, -1, -1}, {34415, -1, -1, -1}, {34426, -1, -1, -1}, {34445, -1, -1, -1}, {34449, -1, -1, -1}, {34456, -1, -1, -1}, {34471, -1, -1, -1}, {34472, -1, -1, -1}, {34554, -1, -1, -1}, {34557, -1, -1, -1}, {34571, -1, -1, -1}, {34579, -1, -1, -1}, {34585, -1, -1, -1}, {34590, -1, -1, -1}, {34600, -1, -1, -1}, {34622, -1, -1, -1}, {34673, -1, -1, -1}, {34696, -1, -1, -1}, {34713, -1, -1, -1}, {34732, -1, -1, -1}, {34733, -1, -1, -1}, {34741, -1, -1, -1}, {34774, -1, -1, -1} },
+ {{34795, -1, -1, -1}, {34797, -1, -1, -1}, {34817, -1, -1, -1}, {34819, -1, -1, -1}, {34822, -1, -1, -1}, {34827, -1, -1, -1}, {34836, -1, -1, -1}, {34844, -1, -1, -1}, {34902, -1, -1, -1}, {34911, -1, -1, -1}, {11970, 34916, -1, -1}, {34968, -1, -1, -1}, {34986, -1, -1, -1}, {35005, -1, -1, -1}, {35006, -1, -1, -1}, {35018, -1, -1, -1}, {35026, -1, -1, -1}, {35035, -1, -1, -1}, {35056, -1, -1, -1}, {35057, -1, -1, -1}, {35078, -1, -1, -1}, {35096, -1, -1, -1}, {35097, -1, -1, -1}, {35098, -1, -1, -1}, {35111, -1, -1, -1}, {35120, -1, -1, -1}, {35134, -1, -1, -1}, {35195, -1, -1, -1}, {35284, -1, -1, -1}, {35286, -1, -1, -1}, {35301, -1, -1, -1}, {35313, -1, -1, -1}, {35335, -1, -1, -1}, {35343, -1, -1, -1}, {35349, -1, -1, -1}, {35362, -1, -1, -1}, {35406, -1, -1, -1}, {35455, -1, -1, -1}, {35572, -1, -1, -1}, {35615, -1, -1, -1}, {35639, -1, -1, -1}, {35651, -1, -1, -1}, {35652, -1, -1, -1}, {35668, -1, -1, -1}, {35740, -1, -1, -1}, {35742, -1, -1, -1}, {35911, -1, -1, -1}, {35924, -1, -1, -1}, {35955, -1, -1, -1}, {36004, -1, -1, -1}, {36057, -1, -1, -1}, {36065, -1, -1, -1}, {36088, -1, -1, -1}, {36094, -1, -1, -1}, {36123, -1, -1, -1}, {36201, -1, -1, -1}, {36204, -1, -1, -1}, {36228, -1, -1, -1}, {36237, -1, -1, -1}, {36245, -1, -1, -1}, {36262, -1, -1, -1}, {36294, -1, -1, -1}, {36302, -1, -1, -1}, {36324, -1, -1, -1}, {36332, -1, -1, -1}, {36384, -1, -1, -1}, {36427, -1, -1, -1}, {36460, -1, -1, -1}, {36464, -1, -1, -1}, {36474, -1, -1, -1}, {36498, -1, -1, -1}, {36526, -1, -1, -1}, {36531, -1, -1, -1}, {36561, -1, -1, -1}, {36564, -1, -1, -1}, {36601, -1, -1, -1}, {36631, -1, -1, -1}, {36662, -1, -1, -1}, {36774, -1, -1, -1}, {12193, 36789, -1, -1}, {11981, 36790, -1, -1}, {36806, -1, -1, -1}, {36832, -1, -1, -1}, {36836, -1, -1, -1}, {36854, -1, -1, -1}, {36866, -1, -1, -1}, {36908, -1, -1, -1}, {36932, -1, -1, -1}, {37000, -1, -1, -1}, {37013, -1, -1, -1}, {37017, -1, -1, -1}, {37019, -1, -1, -1}, {37026, -1, -1, -1}, {37044, -1, -1, -1}, {37079, -1, -1, -1}, {37085, -1, -1, -1}, {37108, -1, -1, -1}, {37143, -1, -1, -1}, {37148, -1, -1, -1}, {37169, -1, -1, -1}, {37178, -1, -1, -1}, {37181, -1, -1, -1}, {37192, -1, -1, -1}, {37211, -1, -1, -1}, {37217, -1, -1, -1}, {37220, -1, -1, -1}, {37262, -1, -1, -1}, {37278, -1, -1, -1}, {37288, -1, -1, -1}, {37293, -1, -1, -1}, {37294, -1, -1, -1}, {37298, -1, -1, -1}, {37308, -1, -1, -1}, {37360, -1, -1, -1}, {37367, -1, -1, -1}, {37371, -1, -1, -1}, {37383, -1, -1, -1}, {37416, -1, -1, -1}, {37427, -1, -1, -1}, {37432, -1, -1, -1}, {37443, -1, -1, -1}, {37447, -1, -1, -1}, {37455, -1, -1, -1}, {37472, -1, -1, -1}, {37570, -1, -1, -1}, {37579, -1, -1, -1}, {37580, -1, -1, -1}, {37599, -1, -1, -1}, {37645, -1, -1, -1}, {37653, -1, -1, -1}, {37663, -1, -1, -1}, {37671, -1, -1, -1}, {37703, -1, -1, -1}, {37714, -1, -1, -1}, {37733, -1, -1, -1}, {37738, -1, -1, -1}, {37741, -1, -1, -1}, {37787, -1, -1, -1}, {37818, -1, -1, -1}, {37801, -1, -1, -1}, {37825, -1, -1, -1}, {37834, -1, -1, -1}, {37858, -1, -1, -1}, {37882, -1, -1, -1}, {37885, -1, -1, -1}, {37903, -1, -1, -1}, {37940, -1, -1, -1}, {37951, -1, -1, -1}, {37973, -1, -1, -1}, {37995, -1, -1, -1}, {38002, -1, -1, -1}, {11986, 38264, -1, -1}, {38310, -1, -1, -1}, {38313, -1, -1, -1}, {38315, -1, -1, -1}, {38324, -1, -1, -1}, {38333, -1, -1, -1}, {38362, -1, -1, -1}, {11990, 11983, 38429, -1}, {38465, -1, -1, -1}, {38488, -1, -1, -1}, {38532, -1, -1, -1}, {38564, -1, -1, -1}, {38569, -1, -1, -1}, {38610, -1, -1, -1}, {23986, -1, -1, -1}, {38622, -1, -1, -1}, {38633, -1, -1, -1}, {38641, -1, -1, -1}, {38658, -1, -1, -1}, {38665, -1, -1, -1}, {38746, -1, -1, -1}, {38755, -1, -1, -1}, {38766, -1, -1, -1}, {38771, -1, -1, -1}, {38810, -1, -1, -1}, {38818, -1, -1, -1}, {38837, -1, -1, -1}, {38838, -1, -1, -1}, {38873, -1, -1, -1}, {38878, -1, -1, -1}, {38900, -1, -1, -1}, {38922, -1, -1, -1}, {38926, -1, -1, -1}, {38942, -1, -1, -1}, {38947, -1, -1, -1}, {38955, -1, -1, -1}, {38974, -1, -1, -1}, {38994, -1, -1, -1}, {38995, -1, -1, -1}, {39001, -1, -1, -1}, {39020, -1, -1, -1}, {39096, -1, -1, -1}, {39098, -1, -1, -1}, {39103, -1, -1, -1}, {39112, -1, -1, -1}, {39141, -1, -1, -1}, {39218, -1, -1, -1}, {39219, -1, -1, -1}, {39232, -1, -1, -1}, {39245, -1, -1, -1}, {39260, -1, -1, -1}, {39263, -1, -1, -1}, {39345, -1, -1, -1}, {39353, -1, -1, -1}, {39354, -1, -1, -1}, {39369, -1, -1, -1}, {39426, -1, -1, -1}, {39446, -1, -1, -1}, {39460, -1, -1, -1}, {39463, -1, -1, -1}, {39469, -1, -1, -1}, {39470, -1, -1, -1}, {39478, -1, -1, -1}, {39480, -1, -1, -1}, {39498, -1, -1, -1}, {39510, -1, -1, -1}, {39605, -1, -1, -1}, {39606, -1, -1, -1}, {39673, -1, -1, -1}, {39683, -1, -1, -1}, {39712, -1, -1, -1}, {39731, -1, -1, -1}, {39732, -1, -1, -1}, {39795, -1, -1, -1}, {39801, -1, -1, -1}, {39847, -1, -1, -1}, {39873, -1, -1, -1}, {39879, -1, -1, -1}, {39895, -1, -1, -1}, {39911, -1, -1, -1}, {39915, -1, -1, -1}, {39927, -1, -1, -1}, {39930, -1, -1, -1}, {39933, -1, -1, -1}, {39947, -1, -1, -1}, {39975, -1, -1, -1}, {39978, -1, -1, -1}, {39990, -1, -1, -1}, {40001, -1, -1, -1}, {40019, -1, -1, -1}, {40035, -1, -1, -1}, {40042, -1, -1, -1}, {40055, -1, -1, -1}, {40194, -1, -1, -1}, {40258, -1, -1, -1}, {40263, -1, -1, -1}, {40291, -1, -1, -1}, {40297, -1, -1, -1}, {40316, -1, -1, -1}, {40318, -1, -1, -1}, {40333, -1, -1, -1}, {40369, -1, -1, -1}, {40387, -1, -1, -1}, {40391, -1, -1, -1}, {40406, -1, -1, -1} },
+ {{40415, -1, -1, -1}, {40427, -1, -1, -1}, {40436, -1, -1, -1}, {40469, -1, -1, -1}, {40477, -1, -1, -1}, {40612, -1, -1, -1}, {40616, -1, -1, -1}, {40620, -1, -1, -1}, {40679, -1, -1, -1}, {40686, -1, -1, -1}, {40720, -1, -1, -1}, {40722, -1, -1, -1}, {40727, -1, -1, -1}, {40729, -1, -1, -1}, {40751, -1, -1, -1}, {40759, -1, -1, -1}, {40761, -1, -1, -1}, {40769, -1, -1, -1}, {40773, -1, -1, -1}, {40791, -1, -1, -1}, {40808, -1, -1, -1}, {40817, -1, -1, -1}, {40821, -1, -1, -1}, {40848, -1, -1, -1}, {40852, -1, -1, -1}, {40866, -1, -1, -1}, {-1, -1, -1, -1}, {13317, -1, -1, -1}, {-1, -1, -1, -1}, {22048, -1, -1, -1}, {-1, -1, -1, -1}, {11925, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {28390, -1, -1, -1}, {-1, -1, -1, -1}, {11940, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {11980, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {20435, -1, -1, -1}, {20697, -1, -1, -1}, {20720, -1, -1, -1}, {20931, -1, -1, -1}, {22134, -1, -1, -1}, {27220, -1, -1, -1}, {27905, -1, -1, -1}, {28112, -1, -1, -1}, {28226, -1, -1, -1}, {28377, -1, -1, -1}, {29668, -1, -1, -1}, {29729, -1, -1, -1}, {30060, -1, -1, -1}, {30801, -1, -1, -1}, {34805, -1, -1, -1}, {-1, -1, -1, -1}, {29608, -1, -1, -1}, {15091, -1, -1, -1}, {13531, -1, -1, -1}, {17420, -1, -1, -1}, {16010, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {19432, -1, -1, -1}, {-1, -1, -1, -1}, {16090, -1, -1, -1}, {15138, -1, -1, -1}, {-1, -1, -1, -1}, {17786, -1, -1, -1}, {16531, -1, -1, -1}, {-1, -1, -1, -1}, {18021, -1, -1, -1}, {16643, -1, -1, -1}, {17043, -1, -1, -1}, {18094, -1, -1, -1}, {13448, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ }
+};
+
+static const pdfi_cid_decoding_t japan2_unicode = {
+ "Japan2", "Unicode",
+ 24,
+ 4,
+ {
+ {{-1, -1, -1, -1}, {728, -1, -1, -1}, {711, -1, -1, -1}, {184, -1, -1, -1}, {729, -1, -1, -1}, {733, -1, -1, -1}, {175, -1, -1, -1}, {731, -1, -1, -1}, {730, -1, -1, -1}, {126, -1, -1, -1}, {900, -1, -1, -1}, {901, -1, -1, -1}, {161, -1, -1, -1}, {166, -1, -1, -1}, {191, -1, -1, -1}, {186, -1, -1, -1}, {170, -1, -1, -1}, {169, -1, -1, -1}, {174, -1, -1, -1}, {8482, -1, -1, -1}, {164, -1, -1, -1}, {8470, -1, -1, -1}, {902, -1, -1, -1}, {904, -1, -1, -1}, {905, -1, -1, -1}, {906, -1, -1, -1}, {938, -1, -1, -1}, {908, -1, -1, -1}, {910, -1, -1, -1}, {939, -1, -1, -1}, {911, -1, -1, -1}, {940, -1, -1, -1}, {941, -1, -1, -1}, {942, -1, -1, -1}, {943, -1, -1, -1}, {970, -1, -1, -1}, {912, -1, -1, -1}, {972, -1, -1, -1}, {962, -1, -1, -1}, {973, -1, -1, -1}, {971, -1, -1, -1}, {944, -1, -1, -1}, {974, -1, -1, -1}, {1026, -1, -1, -1}, {1027, -1, -1, -1}, {1028, -1, -1, -1}, {1029, -1, -1, -1}, {1030, -1, -1, -1}, {1031, -1, -1, -1}, {1032, -1, -1, -1}, {1033, -1, -1, -1}, {1034, -1, -1, -1}, {1035, -1, -1, -1}, {1036, -1, -1, -1}, {1038, -1, -1, -1}, {1039, -1, -1, -1}, {1106, -1, -1, -1}, {1107, -1, -1, -1}, {1108, -1, -1, -1}, {1109, -1, -1, -1}, {1110, -1, -1, -1}, {1111, -1, -1, -1}, {1112, -1, -1, -1}, {1113, -1, -1, -1}, {1114, -1, -1, -1}, {1115, -1, -1, -1}, {1116, -1, -1, -1}, {1118, -1, -1, -1}, {1119, -1, -1, -1}, {198, -1, -1, -1}, {272, -1, -1, -1}, {294, -1, -1, -1}, {306, -1, -1, -1}, {321, -1, -1, -1}, {319, -1, -1, -1}, {330, -1, -1, -1}, {216, -1, -1, -1}, {338, -1, -1, -1}, {358, -1, -1, -1}, {222, -1, -1, -1}, {230, -1, -1, -1}, {273, -1, -1, -1}, {240, -1, -1, -1}, {295, -1, -1, -1}, {305, -1, -1, -1}, {307, -1, -1, -1}, {312, -1, -1, -1}, {322, -1, -1, -1}, {320, -1, -1, -1}, {329, -1, -1, -1}, {331, -1, -1, -1}, {248, -1, -1, -1}, {339, -1, -1, -1}, {223, -1, -1, -1}, {359, -1, -1, -1}, {254, -1, -1, -1}, {193, -1, -1, -1}, {192, -1, -1, -1}, {196, -1, -1, -1}, {194, -1, -1, -1}, {258, -1, -1, -1}, {461, -1, -1, -1}, {256, -1, -1, -1}, {260, -1, -1, -1}, {197, -1, -1, -1}, {195, -1, -1, -1}, {262, -1, -1, -1}, {264, -1, -1, -1}, {268, -1, -1, -1}, {199, -1, -1, -1}, {266, -1, -1, -1}, {270, -1, -1, -1}, {201, -1, -1, -1}, {200, -1, -1, -1}, {203, -1, -1, -1}, {202, -1, -1, -1}, {282, -1, -1, -1}, {278, -1, -1, -1}, {274, -1, -1, -1}, {280, -1, -1, -1}, {284, -1, -1, -1}, {286, -1, -1, -1}, {290, -1, -1, -1}, {288, -1, -1, -1}, {292, -1, -1, -1}, {205, -1, -1, -1}, {204, -1, -1, -1}, {207, -1, -1, -1}, {206, -1, -1, -1}, {463, -1, -1, -1}, {304, -1, -1, -1}, {298, -1, -1, -1}, {302, -1, -1, -1}, {296, -1, -1, -1}, {308, -1, -1, -1}, {310, -1, -1, -1}, {313, -1, -1, -1}, {317, -1, -1, -1}, {315, -1, -1, -1}, {323, -1, -1, -1}, {327, -1, -1, -1}, {325, -1, -1, -1}, {209, -1, -1, -1}, {211, -1, -1, -1}, {210, -1, -1, -1}, {214, -1, -1, -1}, {212, -1, -1, -1}, {465, -1, -1, -1}, {336, -1, -1, -1}, {332, -1, -1, -1}, {213, -1, -1, -1}, {340, -1, -1, -1}, {344, -1, -1, -1}, {342, -1, -1, -1}, {346, -1, -1, -1}, {348, -1, -1, -1}, {352, -1, -1, -1}, {350, -1, -1, -1}, {356, -1, -1, -1}, {354, -1, -1, -1}, {218, -1, -1, -1}, {217, -1, -1, -1}, {220, -1, -1, -1}, {219, -1, -1, -1}, {364, -1, -1, -1}, {467, -1, -1, -1}, {368, -1, -1, -1}, {362, -1, -1, -1}, {370, -1, -1, -1}, {366, -1, -1, -1}, {360, -1, -1, -1}, {471, -1, -1, -1}, {475, -1, -1, -1}, {473, -1, -1, -1}, {469, -1, -1, -1}, {372, -1, -1, -1}, {221, -1, -1, -1}, {376, -1, -1, -1}, {374, -1, -1, -1}, {377, -1, -1, -1}, {381, -1, -1, -1}, {379, -1, -1, -1}, {225, -1, -1, -1}, {224, -1, -1, -1}, {228, -1, -1, -1}, {226, -1, -1, -1}, {259, -1, -1, -1}, {462, -1, -1, -1}, {257, -1, -1, -1}, {261, -1, -1, -1}, {229, -1, -1, -1}, {227, -1, -1, -1}, {263, -1, -1, -1}, {265, -1, -1, -1}, {269, -1, -1, -1}, {231, -1, -1, -1}, {267, -1, -1, -1}, {271, -1, -1, -1}, {233, -1, -1, -1}, {232, -1, -1, -1}, {235, -1, -1, -1}, {234, -1, -1, -1}, {283, -1, -1, -1}, {279, -1, -1, -1}, {275, -1, -1, -1}, {281, -1, -1, -1}, {501, -1, -1, -1}, {285, -1, -1, -1}, {287, -1, -1, -1}, {289, -1, -1, -1}, {293, -1, -1, -1}, {237, -1, -1, -1}, {236, -1, -1, -1}, {239, -1, -1, -1}, {238, -1, -1, -1}, {464, -1, -1, -1}, {299, -1, -1, -1}, {303, -1, -1, -1}, {297, -1, -1, -1}, {309, -1, -1, -1}, {311, -1, -1, -1}, {314, -1, -1, -1}, {318, -1, -1, -1}, {316, -1, -1, -1}, {324, -1, -1, -1}, {328, -1, -1, -1}, {326, -1, -1, -1}, {241, -1, -1, -1}, {243, -1, -1, -1}, {242, -1, -1, -1}, {246, -1, -1, -1}, {244, -1, -1, -1}, {466, -1, -1, -1}, {337, -1, -1, -1}, {333, -1, -1, -1}, {245, -1, -1, -1}, {341, -1, -1, -1}, {345, -1, -1, -1}, {343, -1, -1, -1}, {347, -1, -1, -1}, {349, -1, -1, -1}, {353, -1, -1, -1}, {351, -1, -1, -1}, {357, -1, -1, -1}, {355, -1, -1, -1}, {250, -1, -1, -1}, {249, -1, -1, -1}, {252, -1, -1, -1}, {251, -1, -1, -1}, {365, -1, -1, -1}, {468, -1, -1, -1}, {369, -1, -1, -1}, {363, -1, -1, -1}, {371, -1, -1, -1}, {367, -1, -1, -1}, {361, -1, -1, -1} },
+ {{472, -1, -1, -1}, {476, -1, -1, -1}, {474, -1, -1, -1}, {470, -1, -1, -1}, {373, -1, -1, -1}, {253, -1, -1, -1}, {255, -1, -1, -1}, {375, -1, -1, -1}, {378, -1, -1, -1}, {382, -1, -1, -1}, {380, -1, -1, -1}, {19970, -1, -1, -1}, {19972, -1, -1, -1}, {19973, -1, -1, -1}, {19980, -1, -1, -1}, {19986, -1, -1, -1}, {19999, -1, -1, -1}, {20003, -1, -1, -1}, {20004, -1, -1, -1}, {20008, -1, -1, -1}, {20011, -1, -1, -1}, {20014, -1, -1, -1}, {20015, -1, -1, -1}, {20016, -1, -1, -1}, {20021, -1, -1, -1}, {20032, -1, -1, -1}, {20033, -1, -1, -1}, {20036, -1, -1, -1}, {20039, -1, -1, -1}, {20049, -1, -1, -1}, {20058, -1, -1, -1}, {20060, -1, -1, -1}, {20067, -1, -1, -1}, {20072, -1, -1, -1}, {20073, -1, -1, -1}, {20084, -1, -1, -1}, {20085, -1, -1, -1}, {20089, -1, -1, -1}, {20095, -1, -1, -1}, {20109, -1, -1, -1}, {20118, -1, -1, -1}, {20119, -1, -1, -1}, {20125, -1, -1, -1}, {20143, -1, -1, -1}, {20153, -1, -1, -1}, {20163, -1, -1, -1}, {20176, -1, -1, -1}, {20186, -1, -1, -1}, {20187, -1, -1, -1}, {20192, -1, -1, -1}, {20193, -1, -1, -1}, {20194, -1, -1, -1}, {20200, -1, -1, -1}, {20207, -1, -1, -1}, {20209, -1, -1, -1}, {20211, -1, -1, -1}, {20213, -1, -1, -1}, {20221, -1, -1, -1}, {20222, -1, -1, -1}, {20223, -1, -1, -1}, {20224, -1, -1, -1}, {20226, -1, -1, -1}, {20227, -1, -1, -1}, {20232, -1, -1, -1}, {20235, -1, -1, -1}, {20236, -1, -1, -1}, {20242, -1, -1, -1}, {20245, -1, -1, -1}, {20246, -1, -1, -1}, {20247, -1, -1, -1}, {20249, -1, -1, -1}, {20270, -1, -1, -1}, {20273, -1, -1, -1}, {20320, -1, -1, -1}, {20275, -1, -1, -1}, {20277, -1, -1, -1}, {20279, -1, -1, -1}, {20281, -1, -1, -1}, {20283, -1, -1, -1}, {20286, -1, -1, -1}, {20288, -1, -1, -1}, {20290, -1, -1, -1}, {20296, -1, -1, -1}, {20297, -1, -1, -1}, {20299, -1, -1, -1}, {20300, -1, -1, -1}, {20306, -1, -1, -1}, {20308, -1, -1, -1}, {20310, -1, -1, -1}, {20312, -1, -1, -1}, {20319, -1, -1, -1}, {20323, -1, -1, -1}, {20330, -1, -1, -1}, {20332, -1, -1, -1}, {20334, -1, -1, -1}, {20337, -1, -1, -1}, {20343, -1, -1, -1}, {20344, -1, -1, -1}, {20345, -1, -1, -1}, {20346, -1, -1, -1}, {20349, -1, -1, -1}, {20350, -1, -1, -1}, {20353, -1, -1, -1}, {20354, -1, -1, -1}, {20356, -1, -1, -1}, {20357, -1, -1, -1}, {20361, -1, -1, -1}, {20362, -1, -1, -1}, {20364, -1, -1, -1}, {20366, -1, -1, -1}, {20368, -1, -1, -1}, {20370, -1, -1, -1}, {20371, -1, -1, -1}, {20372, -1, -1, -1}, {20375, -1, -1, -1}, {20377, -1, -1, -1}, {20378, -1, -1, -1}, {20382, -1, -1, -1}, {20383, -1, -1, -1}, {20402, -1, -1, -1}, {20407, -1, -1, -1}, {20409, -1, -1, -1}, {20411, -1, -1, -1}, {20412, -1, -1, -1}, {20413, -1, -1, -1}, {20414, -1, -1, -1}, {20416, -1, -1, -1}, {20417, -1, -1, -1}, {20421, -1, -1, -1}, {20422, -1, -1, -1}, {20424, -1, -1, -1}, {20425, -1, -1, -1}, {20427, -1, -1, -1}, {20428, -1, -1, -1}, {20429, -1, -1, -1}, {20431, -1, -1, -1}, {20434, -1, -1, -1}, {20444, -1, -1, -1}, {20448, -1, -1, -1}, {20450, -1, -1, -1}, {20464, -1, -1, -1}, {20466, -1, -1, -1}, {20476, -1, -1, -1}, {20477, -1, -1, -1}, {20479, -1, -1, -1}, {20480, -1, -1, -1}, {20481, -1, -1, -1}, {20484, -1, -1, -1}, {20487, -1, -1, -1}, {20490, -1, -1, -1}, {20492, -1, -1, -1}, {20494, -1, -1, -1}, {20496, -1, -1, -1}, {20499, -1, -1, -1}, {20503, -1, -1, -1}, {20504, -1, -1, -1}, {20507, -1, -1, -1}, {20508, -1, -1, -1}, {20509, -1, -1, -1}, {20510, -1, -1, -1}, {20514, -1, -1, -1}, {20519, -1, -1, -1}, {20526, -1, -1, -1}, {20528, -1, -1, -1}, {20530, -1, -1, -1}, {20531, -1, -1, -1}, {20533, -1, -1, -1}, {20544, -1, -1, -1}, {20545, -1, -1, -1}, {20546, -1, -1, -1}, {20549, -1, -1, -1}, {20550, -1, -1, -1}, {20554, -1, -1, -1}, {20556, -1, -1, -1}, {20558, -1, -1, -1}, {20561, -1, -1, -1}, {20562, -1, -1, -1}, {20563, -1, -1, -1}, {20567, -1, -1, -1}, {20569, -1, -1, -1}, {20575, -1, -1, -1}, {20576, -1, -1, -1}, {20578, -1, -1, -1}, {20579, -1, -1, -1}, {20582, -1, -1, -1}, {20583, -1, -1, -1}, {20586, -1, -1, -1}, {20589, -1, -1, -1}, {20592, -1, -1, -1}, {20593, -1, -1, -1}, {20539, -1, -1, -1}, {20609, -1, -1, -1}, {20611, -1, -1, -1}, {20612, -1, -1, -1}, {20614, -1, -1, -1}, {20618, -1, -1, -1}, {20622, -1, -1, -1}, {20623, -1, -1, -1}, {20624, -1, -1, -1}, {20626, -1, -1, -1}, {20627, -1, -1, -1}, {20628, -1, -1, -1}, {20630, -1, -1, -1}, {20635, -1, -1, -1}, {20636, -1, -1, -1}, {20638, -1, -1, -1}, {20639, -1, -1, -1}, {20640, -1, -1, -1}, {20641, -1, -1, -1}, {20642, -1, -1, -1}, {20650, -1, -1, -1}, {20655, -1, -1, -1}, {20656, -1, -1, -1}, {20665, -1, -1, -1}, {20666, -1, -1, -1}, {20669, -1, -1, -1}, {20672, -1, -1, -1}, {20675, -1, -1, -1}, {20676, -1, -1, -1}, {20679, -1, -1, -1}, {20684, -1, -1, -1}, {20686, -1, -1, -1}, {20688, -1, -1, -1}, {20691, -1, -1, -1}, {20692, -1, -1, -1}, {20696, -1, -1, -1}, {20700, -1, -1, -1}, {20701, -1, -1, -1}, {20703, -1, -1, -1}, {20706, -1, -1, -1}, {20708, -1, -1, -1}, {20710, -1, -1, -1}, {20712, -1, -1, -1}, {20713, -1, -1, -1}, {20719, -1, -1, -1}, {20721, -1, -1, -1}, {20726, -1, -1, -1}, {20730, -1, -1, -1}, {20734, -1, -1, -1}, {20739, -1, -1, -1}, {20742, -1, -1, -1}, {20743, -1, -1, -1}, {20744, -1, -1, -1}, {20747, -1, -1, -1}, {20748, -1, -1, -1}, {20749, -1, -1, -1}, {20750, -1, -1, -1}, {20722, -1, -1, -1}, {20752, -1, -1, -1}, {20759, -1, -1, -1}, {20761, -1, -1, -1}, {20763, -1, -1, -1}, {20764, -1, -1, -1}, {20765, -1, -1, -1}, {20766, -1, -1, -1}, {20771, -1, -1, -1} },
+ {{20775, -1, -1, -1}, {20776, -1, -1, -1}, {20780, -1, -1, -1}, {20781, -1, -1, -1}, {20783, -1, -1, -1}, {20785, -1, -1, -1}, {20787, -1, -1, -1}, {20788, -1, -1, -1}, {20789, -1, -1, -1}, {20792, -1, -1, -1}, {20793, -1, -1, -1}, {20802, -1, -1, -1}, {20810, -1, -1, -1}, {20815, -1, -1, -1}, {20819, -1, -1, -1}, {20821, -1, -1, -1}, {20823, -1, -1, -1}, {20824, -1, -1, -1}, {20831, -1, -1, -1}, {20836, -1, -1, -1}, {20838, -1, -1, -1}, {20862, -1, -1, -1}, {20867, -1, -1, -1}, {20868, -1, -1, -1}, {20875, -1, -1, -1}, {20878, -1, -1, -1}, {20888, -1, -1, -1}, {20893, -1, -1, -1}, {20897, -1, -1, -1}, {20899, -1, -1, -1}, {20909, -1, -1, -1}, {20920, -1, -1, -1}, {20922, -1, -1, -1}, {20924, -1, -1, -1}, {20926, -1, -1, -1}, {20927, -1, -1, -1}, {20930, -1, -1, -1}, {20936, -1, -1, -1}, {20943, -1, -1, -1}, {20945, -1, -1, -1}, {20946, -1, -1, -1}, {20947, -1, -1, -1}, {20949, -1, -1, -1}, {20952, -1, -1, -1}, {20958, -1, -1, -1}, {20962, -1, -1, -1}, {20965, -1, -1, -1}, {20974, -1, -1, -1}, {20978, -1, -1, -1}, {20979, -1, -1, -1}, {20980, -1, -1, -1}, {20983, -1, -1, -1}, {20993, -1, -1, -1}, {20994, -1, -1, -1}, {20997, -1, -1, -1}, {21010, -1, -1, -1}, {21011, -1, -1, -1}, {21013, -1, -1, -1}, {21014, -1, -1, -1}, {21016, -1, -1, -1}, {21026, -1, -1, -1}, {21032, -1, -1, -1}, {21041, -1, -1, -1}, {21042, -1, -1, -1}, {21045, -1, -1, -1}, {21052, -1, -1, -1}, {21061, -1, -1, -1}, {21065, -1, -1, -1}, {21077, -1, -1, -1}, {21079, -1, -1, -1}, {21080, -1, -1, -1}, {21082, -1, -1, -1}, {21084, -1, -1, -1}, {21087, -1, -1, -1}, {21088, -1, -1, -1}, {21089, -1, -1, -1}, {21094, -1, -1, -1}, {21102, -1, -1, -1}, {21111, -1, -1, -1}, {21112, -1, -1, -1}, {21113, -1, -1, -1}, {21120, -1, -1, -1}, {21122, -1, -1, -1}, {21125, -1, -1, -1}, {21130, -1, -1, -1}, {21132, -1, -1, -1}, {21139, -1, -1, -1}, {21141, -1, -1, -1}, {21142, -1, -1, -1}, {21143, -1, -1, -1}, {21144, -1, -1, -1}, {21146, -1, -1, -1}, {21148, -1, -1, -1}, {21156, -1, -1, -1}, {21157, -1, -1, -1}, {21158, -1, -1, -1}, {21159, -1, -1, -1}, {21167, -1, -1, -1}, {21168, -1, -1, -1}, {21174, -1, -1, -1}, {21175, -1, -1, -1}, {21176, -1, -1, -1}, {21178, -1, -1, -1}, {21179, -1, -1, -1}, {21181, -1, -1, -1}, {21184, -1, -1, -1}, {21188, -1, -1, -1}, {21190, -1, -1, -1}, {21192, -1, -1, -1}, {21196, -1, -1, -1}, {21199, -1, -1, -1}, {21201, -1, -1, -1}, {21204, -1, -1, -1}, {21206, -1, -1, -1}, {21211, -1, -1, -1}, {21212, -1, -1, -1}, {21217, -1, -1, -1}, {21221, -1, -1, -1}, {21224, -1, -1, -1}, {21225, -1, -1, -1}, {21226, -1, -1, -1}, {21228, -1, -1, -1}, {21232, -1, -1, -1}, {21233, -1, -1, -1}, {21236, -1, -1, -1}, {21238, -1, -1, -1}, {21239, -1, -1, -1}, {21248, -1, -1, -1}, {21251, -1, -1, -1}, {21258, -1, -1, -1}, {21259, -1, -1, -1}, {21260, -1, -1, -1}, {21265, -1, -1, -1}, {21267, -1, -1, -1}, {21272, -1, -1, -1}, {21275, -1, -1, -1}, {21276, -1, -1, -1}, {21278, -1, -1, -1}, {21279, -1, -1, -1}, {21285, -1, -1, -1}, {21287, -1, -1, -1}, {21288, -1, -1, -1}, {21289, -1, -1, -1}, {21291, -1, -1, -1}, {21292, -1, -1, -1}, {21293, -1, -1, -1}, {21296, -1, -1, -1}, {21298, -1, -1, -1}, {21301, -1, -1, -1}, {21308, -1, -1, -1}, {21309, -1, -1, -1}, {21310, -1, -1, -1}, {21314, -1, -1, -1}, {21324, -1, -1, -1}, {21323, -1, -1, -1}, {21337, -1, -1, -1}, {21339, -1, -1, -1}, {21345, -1, -1, -1}, {21347, -1, -1, -1}, {21349, -1, -1, -1}, {21356, -1, -1, -1}, {21357, -1, -1, -1}, {21362, -1, -1, -1}, {21369, -1, -1, -1}, {21374, -1, -1, -1}, {21379, -1, -1, -1}, {21383, -1, -1, -1}, {21384, -1, -1, -1}, {21390, -1, -1, -1}, {21395, -1, -1, -1}, {21396, -1, -1, -1}, {21401, -1, -1, -1}, {21405, -1, -1, -1}, {21409, -1, -1, -1}, {21412, -1, -1, -1}, {21418, -1, -1, -1}, {21419, -1, -1, -1}, {21423, -1, -1, -1}, {21426, -1, -1, -1}, {21428, -1, -1, -1}, {21429, -1, -1, -1}, {21431, -1, -1, -1}, {21432, -1, -1, -1}, {21434, -1, -1, -1}, {21437, -1, -1, -1}, {21440, -1, -1, -1}, {21445, -1, -1, -1}, {21455, -1, -1, -1}, {21458, -1, -1, -1}, {21459, -1, -1, -1}, {21461, -1, -1, -1}, {21466, -1, -1, -1}, {21469, -1, -1, -1}, {21470, -1, -1, -1}, {21472, -1, -1, -1}, {21478, -1, -1, -1}, {21479, -1, -1, -1}, {21493, -1, -1, -1}, {21506, -1, -1, -1}, {21523, -1, -1, -1}, {21530, -1, -1, -1}, {21537, -1, -1, -1}, {21543, -1, -1, -1}, {21544, -1, -1, -1}, {21546, -1, -1, -1}, {21551, -1, -1, -1}, {21553, -1, -1, -1}, {21556, -1, -1, -1}, {21557, -1, -1, -1}, {21571, -1, -1, -1}, {21572, -1, -1, -1}, {21575, -1, -1, -1}, {21581, -1, -1, -1}, {21583, -1, -1, -1}, {21598, -1, -1, -1}, {21602, -1, -1, -1}, {21604, -1, -1, -1}, {21606, -1, -1, -1}, {21607, -1, -1, -1}, {21609, -1, -1, -1}, {21611, -1, -1, -1}, {21613, -1, -1, -1}, {21614, -1, -1, -1}, {21620, -1, -1, -1}, {21631, -1, -1, -1}, {21633, -1, -1, -1}, {21635, -1, -1, -1}, {21637, -1, -1, -1}, {21640, -1, -1, -1}, {21641, -1, -1, -1}, {21645, -1, -1, -1}, {21649, -1, -1, -1}, {21653, -1, -1, -1}, {21654, -1, -1, -1}, {21660, -1, -1, -1}, {21663, -1, -1, -1}, {21665, -1, -1, -1}, {21670, -1, -1, -1}, {21671, -1, -1, -1}, {21673, -1, -1, -1}, {21674, -1, -1, -1}, {21677, -1, -1, -1}, {21678, -1, -1, -1}, {21681, -1, -1, -1}, {21687, -1, -1, -1}, {21689, -1, -1, -1}, {21690, -1, -1, -1}, {21691, -1, -1, -1}, {21695, -1, -1, -1}, {21702, -1, -1, -1}, {21706, -1, -1, -1}, {21709, -1, -1, -1}, {21710, -1, -1, -1}, {21728, -1, -1, -1}, {21738, -1, -1, -1}, {21740, -1, -1, -1} },
+ {{21743, -1, -1, -1}, {21750, -1, -1, -1}, {21756, -1, -1, -1}, {21758, -1, -1, -1}, {21759, -1, -1, -1}, {21760, -1, -1, -1}, {21761, -1, -1, -1}, {21765, -1, -1, -1}, {21768, -1, -1, -1}, {21769, -1, -1, -1}, {21772, -1, -1, -1}, {21773, -1, -1, -1}, {21774, -1, -1, -1}, {21781, -1, -1, -1}, {21802, -1, -1, -1}, {21803, -1, -1, -1}, {21810, -1, -1, -1}, {21813, -1, -1, -1}, {21814, -1, -1, -1}, {21819, -1, -1, -1}, {21820, -1, -1, -1}, {21821, -1, -1, -1}, {21825, -1, -1, -1}, {21831, -1, -1, -1}, {21833, -1, -1, -1}, {21834, -1, -1, -1}, {21837, -1, -1, -1}, {21840, -1, -1, -1}, {21841, -1, -1, -1}, {21848, -1, -1, -1}, {21850, -1, -1, -1}, {21851, -1, -1, -1}, {21854, -1, -1, -1}, {21856, -1, -1, -1}, {21857, -1, -1, -1}, {21860, -1, -1, -1}, {21862, -1, -1, -1}, {21887, -1, -1, -1}, {21889, -1, -1, -1}, {21890, -1, -1, -1}, {21894, -1, -1, -1}, {21896, -1, -1, -1}, {21902, -1, -1, -1}, {21903, -1, -1, -1}, {21905, -1, -1, -1}, {21906, -1, -1, -1}, {21907, -1, -1, -1}, {21908, -1, -1, -1}, {21911, -1, -1, -1}, {21923, -1, -1, -1}, {21924, -1, -1, -1}, {21933, -1, -1, -1}, {21938, -1, -1, -1}, {21951, -1, -1, -1}, {21953, -1, -1, -1}, {21955, -1, -1, -1}, {21958, -1, -1, -1}, {21961, -1, -1, -1}, {21963, -1, -1, -1}, {21964, -1, -1, -1}, {21966, -1, -1, -1}, {21969, -1, -1, -1}, {21970, -1, -1, -1}, {21971, -1, -1, -1}, {21975, -1, -1, -1}, {21976, -1, -1, -1}, {21979, -1, -1, -1}, {21982, -1, -1, -1}, {21986, -1, -1, -1}, {21993, -1, -1, -1}, {22006, -1, -1, -1}, {22015, -1, -1, -1}, {22021, -1, -1, -1}, {22024, -1, -1, -1}, {22026, -1, -1, -1}, {22029, -1, -1, -1}, {22030, -1, -1, -1}, {22031, -1, -1, -1}, {22032, -1, -1, -1}, {22033, -1, -1, -1}, {22034, -1, -1, -1}, {22041, -1, -1, -1}, {22060, -1, -1, -1}, {22064, -1, -1, -1}, {22067, -1, -1, -1}, {22069, -1, -1, -1}, {22071, -1, -1, -1}, {22073, -1, -1, -1}, {22075, -1, -1, -1}, {22076, -1, -1, -1}, {22077, -1, -1, -1}, {22079, -1, -1, -1}, {22080, -1, -1, -1}, {22081, -1, -1, -1}, {22083, -1, -1, -1}, {22084, -1, -1, -1}, {22086, -1, -1, -1}, {22089, -1, -1, -1}, {22091, -1, -1, -1}, {22093, -1, -1, -1}, {22095, -1, -1, -1}, {22100, -1, -1, -1}, {22110, -1, -1, -1}, {22112, -1, -1, -1}, {22113, -1, -1, -1}, {22114, -1, -1, -1}, {22115, -1, -1, -1}, {22118, -1, -1, -1}, {22121, -1, -1, -1}, {22125, -1, -1, -1}, {22127, -1, -1, -1}, {22129, -1, -1, -1}, {22130, -1, -1, -1}, {22133, -1, -1, -1}, {22148, -1, -1, -1}, {22149, -1, -1, -1}, {22152, -1, -1, -1}, {22155, -1, -1, -1}, {22156, -1, -1, -1}, {22165, -1, -1, -1}, {22169, -1, -1, -1}, {22170, -1, -1, -1}, {22173, -1, -1, -1}, {22174, -1, -1, -1}, {22175, -1, -1, -1}, {22182, -1, -1, -1}, {22183, -1, -1, -1}, {22184, -1, -1, -1}, {22185, -1, -1, -1}, {22187, -1, -1, -1}, {22188, -1, -1, -1}, {22189, -1, -1, -1}, {22193, -1, -1, -1}, {22195, -1, -1, -1}, {22199, -1, -1, -1}, {22206, -1, -1, -1}, {22213, -1, -1, -1}, {22217, -1, -1, -1}, {22218, -1, -1, -1}, {22219, -1, -1, -1}, {22223, -1, -1, -1}, {22224, -1, -1, -1}, {22220, -1, -1, -1}, {22221, -1, -1, -1}, {22233, -1, -1, -1}, {22236, -1, -1, -1}, {22237, -1, -1, -1}, {22239, -1, -1, -1}, {22241, -1, -1, -1}, {22244, -1, -1, -1}, {22245, -1, -1, -1}, {22246, -1, -1, -1}, {22247, -1, -1, -1}, {22248, -1, -1, -1}, {22257, -1, -1, -1}, {22251, -1, -1, -1}, {22253, -1, -1, -1}, {22262, -1, -1, -1}, {22263, -1, -1, -1}, {22273, -1, -1, -1}, {22274, -1, -1, -1}, {22279, -1, -1, -1}, {22282, -1, -1, -1}, {22284, -1, -1, -1}, {22289, -1, -1, -1}, {22293, -1, -1, -1}, {22298, -1, -1, -1}, {22299, -1, -1, -1}, {22301, -1, -1, -1}, {22304, -1, -1, -1}, {22306, -1, -1, -1}, {22307, -1, -1, -1}, {22308, -1, -1, -1}, {22309, -1, -1, -1}, {22313, -1, -1, -1}, {22314, -1, -1, -1}, {22316, -1, -1, -1}, {22318, -1, -1, -1}, {22319, -1, -1, -1}, {22323, -1, -1, -1}, {22324, -1, -1, -1}, {22333, -1, -1, -1}, {22334, -1, -1, -1}, {22335, -1, -1, -1}, {22341, -1, -1, -1}, {22342, -1, -1, -1}, {22348, -1, -1, -1}, {22349, -1, -1, -1}, {22354, -1, -1, -1}, {22370, -1, -1, -1}, {22373, -1, -1, -1}, {22375, -1, -1, -1}, {22376, -1, -1, -1}, {22379, -1, -1, -1}, {22381, -1, -1, -1}, {22382, -1, -1, -1}, {22383, -1, -1, -1}, {22384, -1, -1, -1}, {22385, -1, -1, -1}, {22387, -1, -1, -1}, {22388, -1, -1, -1}, {22389, -1, -1, -1}, {22391, -1, -1, -1}, {22393, -1, -1, -1}, {22394, -1, -1, -1}, {22395, -1, -1, -1}, {22396, -1, -1, -1}, {22398, -1, -1, -1}, {22401, -1, -1, -1}, {22403, -1, -1, -1}, {22412, -1, -1, -1}, {22420, -1, -1, -1}, {22423, -1, -1, -1}, {22425, -1, -1, -1}, {22426, -1, -1, -1}, {22428, -1, -1, -1}, {22429, -1, -1, -1}, {22430, -1, -1, -1}, {22431, -1, -1, -1}, {22433, -1, -1, -1}, {22421, -1, -1, -1}, {22439, -1, -1, -1}, {22440, -1, -1, -1}, {22441, -1, -1, -1}, {22444, -1, -1, -1}, {22456, -1, -1, -1}, {22461, -1, -1, -1}, {22471, -1, -1, -1}, {22472, -1, -1, -1}, {22476, -1, -1, -1}, {22479, -1, -1, -1}, {22485, -1, -1, -1}, {22493, -1, -1, -1}, {22494, -1, -1, -1}, {22500, -1, -1, -1}, {22502, -1, -1, -1}, {22503, -1, -1, -1}, {22505, -1, -1, -1}, {22509, -1, -1, -1}, {22512, -1, -1, -1}, {22517, -1, -1, -1}, {22518, -1, -1, -1}, {22520, -1, -1, -1}, {22525, -1, -1, -1}, {22526, -1, -1, -1}, {22527, -1, -1, -1}, {22531, -1, -1, -1}, {22532, -1, -1, -1}, {22536, -1, -1, -1}, {22537, -1, -1, -1}, {22497, -1, -1, -1}, {22540, -1, -1, -1}, {22541, -1, -1, -1}, {22555, -1, -1, -1}, {22558, -1, -1, -1}, {22559, -1, -1, -1} },
+ {{22560, -1, -1, -1}, {22566, -1, -1, -1}, {22567, -1, -1, -1}, {22573, -1, -1, -1}, {22578, -1, -1, -1}, {22585, -1, -1, -1}, {22591, -1, -1, -1}, {22601, -1, -1, -1}, {22604, -1, -1, -1}, {22605, -1, -1, -1}, {22607, -1, -1, -1}, {22608, -1, -1, -1}, {22613, -1, -1, -1}, {22623, -1, -1, -1}, {22625, -1, -1, -1}, {22628, -1, -1, -1}, {22631, -1, -1, -1}, {22632, -1, -1, -1}, {22648, -1, -1, -1}, {22652, -1, -1, -1}, {22655, -1, -1, -1}, {22656, -1, -1, -1}, {22657, -1, -1, -1}, {22663, -1, -1, -1}, {22664, -1, -1, -1}, {22665, -1, -1, -1}, {22666, -1, -1, -1}, {22668, -1, -1, -1}, {22669, -1, -1, -1}, {22671, -1, -1, -1}, {22672, -1, -1, -1}, {22676, -1, -1, -1}, {22678, -1, -1, -1}, {22685, -1, -1, -1}, {22688, -1, -1, -1}, {22689, -1, -1, -1}, {22690, -1, -1, -1}, {22694, -1, -1, -1}, {22697, -1, -1, -1}, {22705, -1, -1, -1}, {22706, -1, -1, -1}, {22724, -1, -1, -1}, {22716, -1, -1, -1}, {22722, -1, -1, -1}, {22728, -1, -1, -1}, {22733, -1, -1, -1}, {22734, -1, -1, -1}, {22736, -1, -1, -1}, {22738, -1, -1, -1}, {22740, -1, -1, -1}, {22742, -1, -1, -1}, {22746, -1, -1, -1}, {22749, -1, -1, -1}, {22753, -1, -1, -1}, {22754, -1, -1, -1}, {22761, -1, -1, -1}, {22771, -1, -1, -1}, {22789, -1, -1, -1}, {22790, -1, -1, -1}, {22795, -1, -1, -1}, {22796, -1, -1, -1}, {22802, -1, -1, -1}, {22803, -1, -1, -1}, {22804, -1, -1, -1}, {34369, -1, -1, -1}, {22813, -1, -1, -1}, {22817, -1, -1, -1}, {22819, -1, -1, -1}, {22820, -1, -1, -1}, {22824, -1, -1, -1}, {22831, -1, -1, -1}, {22832, -1, -1, -1}, {22835, -1, -1, -1}, {22837, -1, -1, -1}, {22838, -1, -1, -1}, {22847, -1, -1, -1}, {22851, -1, -1, -1}, {22854, -1, -1, -1}, {22866, -1, -1, -1}, {22867, -1, -1, -1}, {22873, -1, -1, -1}, {22875, -1, -1, -1}, {22877, -1, -1, -1}, {22878, -1, -1, -1}, {22879, -1, -1, -1}, {22881, -1, -1, -1}, {22883, -1, -1, -1}, {22891, -1, -1, -1}, {22893, -1, -1, -1}, {22895, -1, -1, -1}, {22898, -1, -1, -1}, {22901, -1, -1, -1}, {22902, -1, -1, -1}, {22905, -1, -1, -1}, {22907, -1, -1, -1}, {22908, -1, -1, -1}, {22923, -1, -1, -1}, {22924, -1, -1, -1}, {22926, -1, -1, -1}, {22930, -1, -1, -1}, {22933, -1, -1, -1}, {22935, -1, -1, -1}, {22943, -1, -1, -1}, {22948, -1, -1, -1}, {22951, -1, -1, -1}, {22957, -1, -1, -1}, {22958, -1, -1, -1}, {22959, -1, -1, -1}, {22960, -1, -1, -1}, {22963, -1, -1, -1}, {22967, -1, -1, -1}, {22970, -1, -1, -1}, {22972, -1, -1, -1}, {22977, -1, -1, -1}, {22979, -1, -1, -1}, {22980, -1, -1, -1}, {22984, -1, -1, -1}, {22986, -1, -1, -1}, {22989, -1, -1, -1}, {22994, -1, -1, -1}, {23005, -1, -1, -1}, {23006, -1, -1, -1}, {23007, -1, -1, -1}, {23011, -1, -1, -1}, {23012, -1, -1, -1}, {23015, -1, -1, -1}, {23022, -1, -1, -1}, {23023, -1, -1, -1}, {23025, -1, -1, -1}, {23026, -1, -1, -1}, {23028, -1, -1, -1}, {23031, -1, -1, -1}, {23040, -1, -1, -1}, {23044, -1, -1, -1}, {23052, -1, -1, -1}, {23053, -1, -1, -1}, {23054, -1, -1, -1}, {23058, -1, -1, -1}, {23059, -1, -1, -1}, {23070, -1, -1, -1}, {23075, -1, -1, -1}, {23076, -1, -1, -1}, {23079, -1, -1, -1}, {23080, -1, -1, -1}, {23082, -1, -1, -1}, {23085, -1, -1, -1}, {23088, -1, -1, -1}, {23108, -1, -1, -1}, {23109, -1, -1, -1}, {23111, -1, -1, -1}, {23112, -1, -1, -1}, {23116, -1, -1, -1}, {23120, -1, -1, -1}, {23125, -1, -1, -1}, {23134, -1, -1, -1}, {23139, -1, -1, -1}, {23141, -1, -1, -1}, {23143, -1, -1, -1}, {23149, -1, -1, -1}, {23159, -1, -1, -1}, {23162, -1, -1, -1}, {23163, -1, -1, -1}, {23166, -1, -1, -1}, {23179, -1, -1, -1}, {23184, -1, -1, -1}, {23187, -1, -1, -1}, {23190, -1, -1, -1}, {23193, -1, -1, -1}, {23196, -1, -1, -1}, {23198, -1, -1, -1}, {23199, -1, -1, -1}, {23200, -1, -1, -1}, {23202, -1, -1, -1}, {23207, -1, -1, -1}, {23212, -1, -1, -1}, {23217, -1, -1, -1}, {23218, -1, -1, -1}, {23219, -1, -1, -1}, {23221, -1, -1, -1}, {23224, -1, -1, -1}, {23226, -1, -1, -1}, {23227, -1, -1, -1}, {23231, -1, -1, -1}, {23236, -1, -1, -1}, {23238, -1, -1, -1}, {23240, -1, -1, -1}, {23247, -1, -1, -1}, {23258, -1, -1, -1}, {23260, -1, -1, -1}, {23264, -1, -1, -1}, {23269, -1, -1, -1}, {23274, -1, -1, -1}, {23278, -1, -1, -1}, {23285, -1, -1, -1}, {23286, -1, -1, -1}, {23293, -1, -1, -1}, {23296, -1, -1, -1}, {23297, -1, -1, -1}, {23304, -1, -1, -1}, {23319, -1, -1, -1}, {23348, -1, -1, -1}, {23321, -1, -1, -1}, {23323, -1, -1, -1}, {23325, -1, -1, -1}, {23329, -1, -1, -1}, {23333, -1, -1, -1}, {23341, -1, -1, -1}, {23352, -1, -1, -1}, {23361, -1, -1, -1}, {23371, -1, -1, -1}, {23372, -1, -1, -1}, {23378, -1, -1, -1}, {23382, -1, -1, -1}, {23390, -1, -1, -1}, {23400, -1, -1, -1}, {23406, -1, -1, -1}, {23407, -1, -1, -1}, {23420, -1, -1, -1}, {23421, -1, -1, -1}, {23422, -1, -1, -1}, {23423, -1, -1, -1}, {23425, -1, -1, -1}, {23428, -1, -1, -1}, {23430, -1, -1, -1}, {23434, -1, -1, -1}, {23438, -1, -1, -1}, {23440, -1, -1, -1}, {23441, -1, -1, -1}, {23443, -1, -1, -1}, {23444, -1, -1, -1}, {23446, -1, -1, -1}, {23464, -1, -1, -1}, {23465, -1, -1, -1}, {23468, -1, -1, -1}, {23469, -1, -1, -1}, {23471, -1, -1, -1}, {23473, -1, -1, -1}, {23474, -1, -1, -1}, {23479, -1, -1, -1}, {23482, -1, -1, -1}, {23484, -1, -1, -1}, {23488, -1, -1, -1}, {23489, -1, -1, -1}, {23501, -1, -1, -1}, {23503, -1, -1, -1}, {23510, -1, -1, -1}, {23511, -1, -1, -1}, {23512, -1, -1, -1}, {23513, -1, -1, -1}, {23514, -1, -1, -1}, {23520, -1, -1, -1}, {23535, -1, -1, -1}, {23537, -1, -1, -1}, {23540, -1, -1, -1}, {23549, -1, -1, -1}, {23564, -1, -1, -1} },
+ {{23575, -1, -1, -1}, {23582, -1, -1, -1}, {23583, -1, -1, -1}, {23587, -1, -1, -1}, {23590, -1, -1, -1}, {23593, -1, -1, -1}, {23595, -1, -1, -1}, {23596, -1, -1, -1}, {23598, -1, -1, -1}, {23600, -1, -1, -1}, {23602, -1, -1, -1}, {23605, -1, -1, -1}, {23606, -1, -1, -1}, {23641, -1, -1, -1}, {23642, -1, -1, -1}, {23644, -1, -1, -1}, {23650, -1, -1, -1}, {23651, -1, -1, -1}, {23655, -1, -1, -1}, {23656, -1, -1, -1}, {23657, -1, -1, -1}, {23661, -1, -1, -1}, {23664, -1, -1, -1}, {23668, -1, -1, -1}, {23669, -1, -1, -1}, {23674, -1, -1, -1}, {23675, -1, -1, -1}, {23676, -1, -1, -1}, {23677, -1, -1, -1}, {23687, -1, -1, -1}, {23688, -1, -1, -1}, {23690, -1, -1, -1}, {23695, -1, -1, -1}, {23698, -1, -1, -1}, {23709, -1, -1, -1}, {23711, -1, -1, -1}, {23712, -1, -1, -1}, {23714, -1, -1, -1}, {23715, -1, -1, -1}, {23718, -1, -1, -1}, {23722, -1, -1, -1}, {23730, -1, -1, -1}, {23732, -1, -1, -1}, {23733, -1, -1, -1}, {23738, -1, -1, -1}, {23753, -1, -1, -1}, {23755, -1, -1, -1}, {23762, -1, -1, -1}, {23773, -1, -1, -1}, {23767, -1, -1, -1}, {23790, -1, -1, -1}, {23793, -1, -1, -1}, {23794, -1, -1, -1}, {23796, -1, -1, -1}, {23809, -1, -1, -1}, {23814, -1, -1, -1}, {23821, -1, -1, -1}, {23826, -1, -1, -1}, {23851, -1, -1, -1}, {23843, -1, -1, -1}, {23844, -1, -1, -1}, {23846, -1, -1, -1}, {23847, -1, -1, -1}, {23857, -1, -1, -1}, {23860, -1, -1, -1}, {23865, -1, -1, -1}, {23869, -1, -1, -1}, {23871, -1, -1, -1}, {23874, -1, -1, -1}, {23875, -1, -1, -1}, {23878, -1, -1, -1}, {23880, -1, -1, -1}, {23893, -1, -1, -1}, {23889, -1, -1, -1}, {23897, -1, -1, -1}, {23882, -1, -1, -1}, {23903, -1, -1, -1}, {23904, -1, -1, -1}, {23905, -1, -1, -1}, {23906, -1, -1, -1}, {23908, -1, -1, -1}, {23914, -1, -1, -1}, {23917, -1, -1, -1}, {23920, -1, -1, -1}, {23929, -1, -1, -1}, {23930, -1, -1, -1}, {23934, -1, -1, -1}, {23935, -1, -1, -1}, {23937, -1, -1, -1}, {23939, -1, -1, -1}, {23944, -1, -1, -1}, {23946, -1, -1, -1}, {23954, -1, -1, -1}, {23955, -1, -1, -1}, {23956, -1, -1, -1}, {23957, -1, -1, -1}, {23961, -1, -1, -1}, {23963, -1, -1, -1}, {23967, -1, -1, -1}, {23968, -1, -1, -1}, {23975, -1, -1, -1}, {23979, -1, -1, -1}, {23984, -1, -1, -1}, {23988, -1, -1, -1}, {23992, -1, -1, -1}, {23993, -1, -1, -1}, {24003, -1, -1, -1}, {24007, -1, -1, -1}, {24011, -1, -1, -1}, {24016, -1, -1, -1}, {24014, -1, -1, -1}, {24024, -1, -1, -1}, {24025, -1, -1, -1}, {24032, -1, -1, -1}, {24036, -1, -1, -1}, {24041, -1, -1, -1}, {24056, -1, -1, -1}, {24057, -1, -1, -1}, {24064, -1, -1, -1}, {24071, -1, -1, -1}, {24077, -1, -1, -1}, {24082, -1, -1, -1}, {24084, -1, -1, -1}, {24085, -1, -1, -1}, {24088, -1, -1, -1}, {24095, -1, -1, -1}, {24096, -1, -1, -1}, {24110, -1, -1, -1}, {24104, -1, -1, -1}, {24114, -1, -1, -1}, {24117, -1, -1, -1}, {24126, -1, -1, -1}, {24139, -1, -1, -1}, {24144, -1, -1, -1}, {24137, -1, -1, -1}, {24145, -1, -1, -1}, {24150, -1, -1, -1}, {24152, -1, -1, -1}, {24155, -1, -1, -1}, {24156, -1, -1, -1}, {24158, -1, -1, -1}, {24168, -1, -1, -1}, {24170, -1, -1, -1}, {24171, -1, -1, -1}, {24172, -1, -1, -1}, {24173, -1, -1, -1}, {24174, -1, -1, -1}, {24176, -1, -1, -1}, {24192, -1, -1, -1}, {24203, -1, -1, -1}, {24206, -1, -1, -1}, {24226, -1, -1, -1}, {24228, -1, -1, -1}, {24229, -1, -1, -1}, {24232, -1, -1, -1}, {24234, -1, -1, -1}, {24236, -1, -1, -1}, {24241, -1, -1, -1}, {24243, -1, -1, -1}, {24253, -1, -1, -1}, {24254, -1, -1, -1}, {24255, -1, -1, -1}, {24262, -1, -1, -1}, {24268, -1, -1, -1}, {24267, -1, -1, -1}, {24270, -1, -1, -1}, {24273, -1, -1, -1}, {24274, -1, -1, -1}, {24276, -1, -1, -1}, {24277, -1, -1, -1}, {24284, -1, -1, -1}, {24286, -1, -1, -1}, {24293, -1, -1, -1}, {24299, -1, -1, -1}, {24322, -1, -1, -1}, {24326, -1, -1, -1}, {24327, -1, -1, -1}, {24328, -1, -1, -1}, {24334, -1, -1, -1}, {24345, -1, -1, -1}, {24348, -1, -1, -1}, {24349, -1, -1, -1}, {24353, -1, -1, -1}, {24354, -1, -1, -1}, {24355, -1, -1, -1}, {24356, -1, -1, -1}, {24360, -1, -1, -1}, {24363, -1, -1, -1}, {24364, -1, -1, -1}, {24366, -1, -1, -1}, {24368, -1, -1, -1}, {24372, -1, -1, -1}, {24374, -1, -1, -1}, {24379, -1, -1, -1}, {24381, -1, -1, -1}, {24383, -1, -1, -1}, {24384, -1, -1, -1}, {24388, -1, -1, -1}, {24389, -1, -1, -1}, {24391, -1, -1, -1}, {24397, -1, -1, -1}, {24400, -1, -1, -1}, {24404, -1, -1, -1}, {24408, -1, -1, -1}, {24411, -1, -1, -1}, {24416, -1, -1, -1}, {24419, -1, -1, -1}, {24420, -1, -1, -1}, {24423, -1, -1, -1}, {24431, -1, -1, -1}, {24434, -1, -1, -1}, {24436, -1, -1, -1}, {24437, -1, -1, -1}, {24440, -1, -1, -1}, {24442, -1, -1, -1}, {24445, -1, -1, -1}, {24446, -1, -1, -1}, {24457, -1, -1, -1}, {24461, -1, -1, -1}, {24463, -1, -1, -1}, {24470, -1, -1, -1}, {24476, -1, -1, -1}, {24477, -1, -1, -1}, {24482, -1, -1, -1}, {24487, -1, -1, -1}, {24491, -1, -1, -1}, {24484, -1, -1, -1}, {24492, -1, -1, -1}, {24495, -1, -1, -1}, {24496, -1, -1, -1}, {24497, -1, -1, -1}, {24504, -1, -1, -1}, {24516, -1, -1, -1}, {24519, -1, -1, -1}, {24520, -1, -1, -1}, {24521, -1, -1, -1}, {24523, -1, -1, -1}, {24528, -1, -1, -1}, {24529, -1, -1, -1}, {24530, -1, -1, -1}, {24531, -1, -1, -1}, {24532, -1, -1, -1}, {24542, -1, -1, -1}, {24545, -1, -1, -1}, {24546, -1, -1, -1}, {24552, -1, -1, -1}, {24553, -1, -1, -1}, {24554, -1, -1, -1}, {24556, -1, -1, -1}, {24557, -1, -1, -1}, {24558, -1, -1, -1}, {24559, -1, -1, -1}, {24562, -1, -1, -1}, {24563, -1, -1, -1}, {24566, -1, -1, -1}, {24570, -1, -1, -1} },
+ {{24572, -1, -1, -1}, {24583, -1, -1, -1}, {24586, -1, -1, -1}, {24589, -1, -1, -1}, {24595, -1, -1, -1}, {24596, -1, -1, -1}, {24599, -1, -1, -1}, {24600, -1, -1, -1}, {24602, -1, -1, -1}, {24607, -1, -1, -1}, {24612, -1, -1, -1}, {24621, -1, -1, -1}, {24627, -1, -1, -1}, {24629, -1, -1, -1}, {24640, -1, -1, -1}, {24647, -1, -1, -1}, {24648, -1, -1, -1}, {24649, -1, -1, -1}, {24652, -1, -1, -1}, {24657, -1, -1, -1}, {24660, -1, -1, -1}, {24662, -1, -1, -1}, {24663, -1, -1, -1}, {24669, -1, -1, -1}, {24673, -1, -1, -1}, {24679, -1, -1, -1}, {24689, -1, -1, -1}, {24702, -1, -1, -1}, {24703, -1, -1, -1}, {24706, -1, -1, -1}, {24710, -1, -1, -1}, {24712, -1, -1, -1}, {24714, -1, -1, -1}, {24718, -1, -1, -1}, {24721, -1, -1, -1}, {24723, -1, -1, -1}, {24725, -1, -1, -1}, {24728, -1, -1, -1}, {24733, -1, -1, -1}, {24734, -1, -1, -1}, {24738, -1, -1, -1}, {24740, -1, -1, -1}, {24741, -1, -1, -1}, {24744, -1, -1, -1}, {24752, -1, -1, -1}, {24753, -1, -1, -1}, {24759, -1, -1, -1}, {24763, -1, -1, -1}, {24766, -1, -1, -1}, {24770, -1, -1, -1}, {24772, -1, -1, -1}, {24776, -1, -1, -1}, {24777, -1, -1, -1}, {24778, -1, -1, -1}, {24779, -1, -1, -1}, {24782, -1, -1, -1}, {24783, -1, -1, -1}, {24788, -1, -1, -1}, {24789, -1, -1, -1}, {24793, -1, -1, -1}, {24795, -1, -1, -1}, {24797, -1, -1, -1}, {24798, -1, -1, -1}, {24802, -1, -1, -1}, {24805, -1, -1, -1}, {24818, -1, -1, -1}, {24821, -1, -1, -1}, {24824, -1, -1, -1}, {24828, -1, -1, -1}, {24829, -1, -1, -1}, {24834, -1, -1, -1}, {24839, -1, -1, -1}, {24842, -1, -1, -1}, {24844, -1, -1, -1}, {24848, -1, -1, -1}, {24849, -1, -1, -1}, {24850, -1, -1, -1}, {24851, -1, -1, -1}, {24852, -1, -1, -1}, {24854, -1, -1, -1}, {24855, -1, -1, -1}, {24857, -1, -1, -1}, {24860, -1, -1, -1}, {24862, -1, -1, -1}, {24866, -1, -1, -1}, {24874, -1, -1, -1}, {24875, -1, -1, -1}, {24880, -1, -1, -1}, {24881, -1, -1, -1}, {24885, -1, -1, -1}, {24886, -1, -1, -1}, {24887, -1, -1, -1}, {24889, -1, -1, -1}, {24897, -1, -1, -1}, {24901, -1, -1, -1}, {24902, -1, -1, -1}, {24905, -1, -1, -1}, {24926, -1, -1, -1}, {24928, -1, -1, -1}, {24940, -1, -1, -1}, {24946, -1, -1, -1}, {24952, -1, -1, -1}, {24955, -1, -1, -1}, {24956, -1, -1, -1}, {24959, -1, -1, -1}, {24960, -1, -1, -1}, {24961, -1, -1, -1}, {24963, -1, -1, -1}, {24964, -1, -1, -1}, {24971, -1, -1, -1}, {24973, -1, -1, -1}, {24978, -1, -1, -1}, {24979, -1, -1, -1}, {24983, -1, -1, -1}, {24984, -1, -1, -1}, {24988, -1, -1, -1}, {24989, -1, -1, -1}, {24991, -1, -1, -1}, {24992, -1, -1, -1}, {24997, -1, -1, -1}, {25000, -1, -1, -1}, {25002, -1, -1, -1}, {25005, -1, -1, -1}, {25016, -1, -1, -1}, {25017, -1, -1, -1}, {25020, -1, -1, -1}, {25024, -1, -1, -1}, {25025, -1, -1, -1}, {25026, -1, -1, -1}, {25038, -1, -1, -1}, {25039, -1, -1, -1}, {25045, -1, -1, -1}, {25052, -1, -1, -1}, {25053, -1, -1, -1}, {25054, -1, -1, -1}, {25055, -1, -1, -1}, {25057, -1, -1, -1}, {25058, -1, -1, -1}, {25063, -1, -1, -1}, {25065, -1, -1, -1}, {25061, -1, -1, -1}, {25068, -1, -1, -1}, {25069, -1, -1, -1}, {25071, -1, -1, -1}, {25089, -1, -1, -1}, {25091, -1, -1, -1}, {25092, -1, -1, -1}, {25095, -1, -1, -1}, {25107, -1, -1, -1}, {25109, -1, -1, -1}, {25116, -1, -1, -1}, {25120, -1, -1, -1}, {25122, -1, -1, -1}, {25123, -1, -1, -1}, {25127, -1, -1, -1}, {25129, -1, -1, -1}, {25131, -1, -1, -1}, {25145, -1, -1, -1}, {25149, -1, -1, -1}, {25154, -1, -1, -1}, {25155, -1, -1, -1}, {25156, -1, -1, -1}, {25158, -1, -1, -1}, {25164, -1, -1, -1}, {25168, -1, -1, -1}, {25169, -1, -1, -1}, {25170, -1, -1, -1}, {25172, -1, -1, -1}, {25174, -1, -1, -1}, {25178, -1, -1, -1}, {25180, -1, -1, -1}, {25188, -1, -1, -1}, {25197, -1, -1, -1}, {25199, -1, -1, -1}, {25203, -1, -1, -1}, {25210, -1, -1, -1}, {25213, -1, -1, -1}, {25229, -1, -1, -1}, {25230, -1, -1, -1}, {25231, -1, -1, -1}, {25232, -1, -1, -1}, {25254, -1, -1, -1}, {25256, -1, -1, -1}, {25267, -1, -1, -1}, {25270, -1, -1, -1}, {25271, -1, -1, -1}, {25274, -1, -1, -1}, {25278, -1, -1, -1}, {25279, -1, -1, -1}, {25284, -1, -1, -1}, {25294, -1, -1, -1}, {25301, -1, -1, -1}, {25302, -1, -1, -1}, {25306, -1, -1, -1}, {25322, -1, -1, -1}, {25330, -1, -1, -1}, {25332, -1, -1, -1}, {25340, -1, -1, -1}, {25341, -1, -1, -1}, {25347, -1, -1, -1}, {25348, -1, -1, -1}, {25354, -1, -1, -1}, {25355, -1, -1, -1}, {25357, -1, -1, -1}, {25360, -1, -1, -1}, {25363, -1, -1, -1}, {25366, -1, -1, -1}, {25368, -1, -1, -1}, {25385, -1, -1, -1}, {25386, -1, -1, -1}, {25389, -1, -1, -1}, {25397, -1, -1, -1}, {25398, -1, -1, -1}, {25401, -1, -1, -1}, {25404, -1, -1, -1}, {25409, -1, -1, -1}, {25410, -1, -1, -1}, {25411, -1, -1, -1}, {25412, -1, -1, -1}, {25414, -1, -1, -1}, {25418, -1, -1, -1}, {25419, -1, -1, -1}, {25422, -1, -1, -1}, {25426, -1, -1, -1}, {25427, -1, -1, -1}, {25428, -1, -1, -1}, {25432, -1, -1, -1}, {25435, -1, -1, -1}, {25445, -1, -1, -1}, {25446, -1, -1, -1}, {25452, -1, -1, -1}, {25453, -1, -1, -1}, {25457, -1, -1, -1}, {25460, -1, -1, -1}, {25461, -1, -1, -1}, {25464, -1, -1, -1}, {25468, -1, -1, -1}, {25469, -1, -1, -1}, {25471, -1, -1, -1}, {25474, -1, -1, -1}, {25476, -1, -1, -1}, {25479, -1, -1, -1}, {25482, -1, -1, -1}, {25488, -1, -1, -1}, {25492, -1, -1, -1}, {25493, -1, -1, -1}, {25497, -1, -1, -1}, {25498, -1, -1, -1}, {25502, -1, -1, -1}, {25508, -1, -1, -1}, {25510, -1, -1, -1}, {25517, -1, -1, -1}, {25518, -1, -1, -1}, {25519, -1, -1, -1}, {25533, -1, -1, -1}, {25537, -1, -1, -1} },
+ {{25541, -1, -1, -1}, {25544, -1, -1, -1}, {25550, -1, -1, -1}, {25553, -1, -1, -1}, {25555, -1, -1, -1}, {25556, -1, -1, -1}, {25557, -1, -1, -1}, {25564, -1, -1, -1}, {25568, -1, -1, -1}, {25573, -1, -1, -1}, {25578, -1, -1, -1}, {25580, -1, -1, -1}, {25586, -1, -1, -1}, {25587, -1, -1, -1}, {25589, -1, -1, -1}, {25592, -1, -1, -1}, {25593, -1, -1, -1}, {25609, -1, -1, -1}, {25610, -1, -1, -1}, {25616, -1, -1, -1}, {25618, -1, -1, -1}, {25620, -1, -1, -1}, {25624, -1, -1, -1}, {25630, -1, -1, -1}, {25632, -1, -1, -1}, {25634, -1, -1, -1}, {25636, -1, -1, -1}, {25637, -1, -1, -1}, {25641, -1, -1, -1}, {25642, -1, -1, -1}, {25647, -1, -1, -1}, {25648, -1, -1, -1}, {25653, -1, -1, -1}, {25661, -1, -1, -1}, {25663, -1, -1, -1}, {25675, -1, -1, -1}, {25679, -1, -1, -1}, {25681, -1, -1, -1}, {25682, -1, -1, -1}, {25683, -1, -1, -1}, {25684, -1, -1, -1}, {25690, -1, -1, -1}, {25691, -1, -1, -1}, {25692, -1, -1, -1}, {25693, -1, -1, -1}, {25695, -1, -1, -1}, {25696, -1, -1, -1}, {25697, -1, -1, -1}, {25699, -1, -1, -1}, {25709, -1, -1, -1}, {25715, -1, -1, -1}, {25716, -1, -1, -1}, {25723, -1, -1, -1}, {25725, -1, -1, -1}, {25733, -1, -1, -1}, {25735, -1, -1, -1}, {25743, -1, -1, -1}, {25744, -1, -1, -1}, {25745, -1, -1, -1}, {25752, -1, -1, -1}, {25753, -1, -1, -1}, {25755, -1, -1, -1}, {25757, -1, -1, -1}, {25759, -1, -1, -1}, {25761, -1, -1, -1}, {25763, -1, -1, -1}, {25766, -1, -1, -1}, {25768, -1, -1, -1}, {25772, -1, -1, -1}, {25779, -1, -1, -1}, {25789, -1, -1, -1}, {25790, -1, -1, -1}, {25791, -1, -1, -1}, {25796, -1, -1, -1}, {25801, -1, -1, -1}, {25802, -1, -1, -1}, {25803, -1, -1, -1}, {25804, -1, -1, -1}, {25806, -1, -1, -1}, {25808, -1, -1, -1}, {25809, -1, -1, -1}, {25813, -1, -1, -1}, {25815, -1, -1, -1}, {25828, -1, -1, -1}, {25829, -1, -1, -1}, {25833, -1, -1, -1}, {25834, -1, -1, -1}, {25837, -1, -1, -1}, {25840, -1, -1, -1}, {25845, -1, -1, -1}, {25847, -1, -1, -1}, {25851, -1, -1, -1}, {25855, -1, -1, -1}, {25857, -1, -1, -1}, {25860, -1, -1, -1}, {25864, -1, -1, -1}, {25865, -1, -1, -1}, {25866, -1, -1, -1}, {25871, -1, -1, -1}, {25875, -1, -1, -1}, {25876, -1, -1, -1}, {25878, -1, -1, -1}, {25881, -1, -1, -1}, {25883, -1, -1, -1}, {25886, -1, -1, -1}, {25887, -1, -1, -1}, {25890, -1, -1, -1}, {25894, -1, -1, -1}, {25897, -1, -1, -1}, {25902, -1, -1, -1}, {25905, -1, -1, -1}, {25914, -1, -1, -1}, {25916, -1, -1, -1}, {25917, -1, -1, -1}, {25923, -1, -1, -1}, {25927, -1, -1, -1}, {25929, -1, -1, -1}, {25936, -1, -1, -1}, {25938, -1, -1, -1}, {25940, -1, -1, -1}, {25951, -1, -1, -1}, {25952, -1, -1, -1}, {25959, -1, -1, -1}, {25963, -1, -1, -1}, {25978, -1, -1, -1}, {25981, -1, -1, -1}, {25985, -1, -1, -1}, {25989, -1, -1, -1}, {25994, -1, -1, -1}, {26002, -1, -1, -1}, {26005, -1, -1, -1}, {26008, -1, -1, -1}, {26013, -1, -1, -1}, {26016, -1, -1, -1}, {26019, -1, -1, -1}, {26022, -1, -1, -1}, {26030, -1, -1, -1}, {26034, -1, -1, -1}, {26035, -1, -1, -1}, {26036, -1, -1, -1}, {26047, -1, -1, -1}, {26050, -1, -1, -1}, {26056, -1, -1, -1}, {26057, -1, -1, -1}, {26062, -1, -1, -1}, {26064, -1, -1, -1}, {26068, -1, -1, -1}, {26070, -1, -1, -1}, {26072, -1, -1, -1}, {26079, -1, -1, -1}, {26096, -1, -1, -1}, {26098, -1, -1, -1}, {26100, -1, -1, -1}, {26101, -1, -1, -1}, {26105, -1, -1, -1}, {26110, -1, -1, -1}, {26111, -1, -1, -1}, {26112, -1, -1, -1}, {26116, -1, -1, -1}, {26120, -1, -1, -1}, {26121, -1, -1, -1}, {26125, -1, -1, -1}, {26129, -1, -1, -1}, {26130, -1, -1, -1}, {26133, -1, -1, -1}, {26134, -1, -1, -1}, {26141, -1, -1, -1}, {26142, -1, -1, -1}, {26145, -1, -1, -1}, {26146, -1, -1, -1}, {26147, -1, -1, -1}, {26148, -1, -1, -1}, {26150, -1, -1, -1}, {26153, -1, -1, -1}, {26154, -1, -1, -1}, {26155, -1, -1, -1}, {26156, -1, -1, -1}, {26158, -1, -1, -1}, {26160, -1, -1, -1}, {26161, -1, -1, -1}, {26163, -1, -1, -1}, {26169, -1, -1, -1}, {26167, -1, -1, -1}, {26176, -1, -1, -1}, {26181, -1, -1, -1}, {26182, -1, -1, -1}, {26186, -1, -1, -1}, {26188, -1, -1, -1}, {26193, -1, -1, -1}, {26190, -1, -1, -1}, {26199, -1, -1, -1}, {26200, -1, -1, -1}, {26201, -1, -1, -1}, {26203, -1, -1, -1}, {26204, -1, -1, -1}, {26208, -1, -1, -1}, {26209, -1, -1, -1}, {26363, -1, -1, -1}, {26218, -1, -1, -1}, {26219, -1, -1, -1}, {26220, -1, -1, -1}, {26238, -1, -1, -1}, {26227, -1, -1, -1}, {26229, -1, -1, -1}, {26239, -1, -1, -1}, {26231, -1, -1, -1}, {26232, -1, -1, -1}, {26233, -1, -1, -1}, {26235, -1, -1, -1}, {26240, -1, -1, -1}, {26236, -1, -1, -1}, {26251, -1, -1, -1}, {26252, -1, -1, -1}, {26253, -1, -1, -1}, {26256, -1, -1, -1}, {26258, -1, -1, -1}, {26265, -1, -1, -1}, {26266, -1, -1, -1}, {26267, -1, -1, -1}, {26268, -1, -1, -1}, {26271, -1, -1, -1}, {26272, -1, -1, -1}, {26276, -1, -1, -1}, {26285, -1, -1, -1}, {26289, -1, -1, -1}, {26290, -1, -1, -1}, {26293, -1, -1, -1}, {26299, -1, -1, -1}, {26303, -1, -1, -1}, {26304, -1, -1, -1}, {26306, -1, -1, -1}, {26307, -1, -1, -1}, {26312, -1, -1, -1}, {26316, -1, -1, -1}, {26318, -1, -1, -1}, {26319, -1, -1, -1}, {26324, -1, -1, -1}, {26331, -1, -1, -1}, {26335, -1, -1, -1}, {26344, -1, -1, -1}, {26347, -1, -1, -1}, {26348, -1, -1, -1}, {26350, -1, -1, -1}, {26362, -1, -1, -1}, {26373, -1, -1, -1}, {26375, -1, -1, -1}, {26382, -1, -1, -1}, {26387, -1, -1, -1}, {26393, -1, -1, -1}, {26396, -1, -1, -1}, {26400, -1, -1, -1}, {26402, -1, -1, -1}, {26419, -1, -1, -1}, {26430, -1, -1, -1}, {26437, -1, -1, -1}, {26439, -1, -1, -1} },
+ {{26440, -1, -1, -1}, {26444, -1, -1, -1}, {26452, -1, -1, -1}, {26453, -1, -1, -1}, {26461, -1, -1, -1}, {26470, -1, -1, -1}, {26476, -1, -1, -1}, {26478, -1, -1, -1}, {26484, -1, -1, -1}, {26486, -1, -1, -1}, {26491, -1, -1, -1}, {26497, -1, -1, -1}, {26500, -1, -1, -1}, {26510, -1, -1, -1}, {26511, -1, -1, -1}, {26513, -1, -1, -1}, {26515, -1, -1, -1}, {26518, -1, -1, -1}, {26520, -1, -1, -1}, {26521, -1, -1, -1}, {26523, -1, -1, -1}, {26544, -1, -1, -1}, {26545, -1, -1, -1}, {26546, -1, -1, -1}, {26549, -1, -1, -1}, {26555, -1, -1, -1}, {26556, -1, -1, -1}, {26557, -1, -1, -1}, {26617, -1, -1, -1}, {26560, -1, -1, -1}, {26562, -1, -1, -1}, {26563, -1, -1, -1}, {26565, -1, -1, -1}, {26568, -1, -1, -1}, {26569, -1, -1, -1}, {26578, -1, -1, -1}, {26583, -1, -1, -1}, {26585, -1, -1, -1}, {26588, -1, -1, -1}, {26593, -1, -1, -1}, {26598, -1, -1, -1}, {26608, -1, -1, -1}, {26610, -1, -1, -1}, {26614, -1, -1, -1}, {26615, -1, -1, -1}, {26706, -1, -1, -1}, {26644, -1, -1, -1}, {26649, -1, -1, -1}, {26653, -1, -1, -1}, {26655, -1, -1, -1}, {26664, -1, -1, -1}, {26663, -1, -1, -1}, {26668, -1, -1, -1}, {26669, -1, -1, -1}, {26671, -1, -1, -1}, {26672, -1, -1, -1}, {26673, -1, -1, -1}, {26675, -1, -1, -1}, {26683, -1, -1, -1}, {26687, -1, -1, -1}, {26692, -1, -1, -1}, {26693, -1, -1, -1}, {26698, -1, -1, -1}, {26700, -1, -1, -1}, {26709, -1, -1, -1}, {26711, -1, -1, -1}, {26712, -1, -1, -1}, {26715, -1, -1, -1}, {26731, -1, -1, -1}, {26734, -1, -1, -1}, {26735, -1, -1, -1}, {26736, -1, -1, -1}, {26737, -1, -1, -1}, {26738, -1, -1, -1}, {26741, -1, -1, -1}, {26745, -1, -1, -1}, {26746, -1, -1, -1}, {26747, -1, -1, -1}, {26748, -1, -1, -1}, {26754, -1, -1, -1}, {26756, -1, -1, -1}, {26758, -1, -1, -1}, {26760, -1, -1, -1}, {26774, -1, -1, -1}, {26776, -1, -1, -1}, {26778, -1, -1, -1}, {26780, -1, -1, -1}, {26785, -1, -1, -1}, {26787, -1, -1, -1}, {26789, -1, -1, -1}, {26793, -1, -1, -1}, {26794, -1, -1, -1}, {26798, -1, -1, -1}, {26802, -1, -1, -1}, {26811, -1, -1, -1}, {26821, -1, -1, -1}, {26824, -1, -1, -1}, {26828, -1, -1, -1}, {26831, -1, -1, -1}, {26832, -1, -1, -1}, {26833, -1, -1, -1}, {26835, -1, -1, -1}, {26838, -1, -1, -1}, {26841, -1, -1, -1}, {26844, -1, -1, -1}, {26845, -1, -1, -1}, {26853, -1, -1, -1}, {26856, -1, -1, -1}, {26858, -1, -1, -1}, {26859, -1, -1, -1}, {26860, -1, -1, -1}, {26861, -1, -1, -1}, {26864, -1, -1, -1}, {26865, -1, -1, -1}, {26869, -1, -1, -1}, {26870, -1, -1, -1}, {26875, -1, -1, -1}, {26876, -1, -1, -1}, {26877, -1, -1, -1}, {26886, -1, -1, -1}, {26889, -1, -1, -1}, {26890, -1, -1, -1}, {26896, -1, -1, -1}, {26897, -1, -1, -1}, {26899, -1, -1, -1}, {26902, -1, -1, -1}, {26903, -1, -1, -1}, {26929, -1, -1, -1}, {26931, -1, -1, -1}, {26933, -1, -1, -1}, {26936, -1, -1, -1}, {26939, -1, -1, -1}, {26946, -1, -1, -1}, {26949, -1, -1, -1}, {26953, -1, -1, -1}, {26958, -1, -1, -1}, {26967, -1, -1, -1}, {26971, -1, -1, -1}, {26979, -1, -1, -1}, {26980, -1, -1, -1}, {26981, -1, -1, -1}, {26982, -1, -1, -1}, {26984, -1, -1, -1}, {26985, -1, -1, -1}, {26988, -1, -1, -1}, {26992, -1, -1, -1}, {26993, -1, -1, -1}, {26994, -1, -1, -1}, {27002, -1, -1, -1}, {27003, -1, -1, -1}, {27007, -1, -1, -1}, {27008, -1, -1, -1}, {27021, -1, -1, -1}, {27026, -1, -1, -1}, {27030, -1, -1, -1}, {27032, -1, -1, -1}, {27041, -1, -1, -1}, {27045, -1, -1, -1}, {27046, -1, -1, -1}, {27048, -1, -1, -1}, {27051, -1, -1, -1}, {27053, -1, -1, -1}, {27055, -1, -1, -1}, {27063, -1, -1, -1}, {27064, -1, -1, -1}, {27066, -1, -1, -1}, {27068, -1, -1, -1}, {27077, -1, -1, -1}, {27080, -1, -1, -1}, {27089, -1, -1, -1}, {27094, -1, -1, -1}, {27095, -1, -1, -1}, {27106, -1, -1, -1}, {27109, -1, -1, -1}, {27118, -1, -1, -1}, {27119, -1, -1, -1}, {27121, -1, -1, -1}, {27123, -1, -1, -1}, {27125, -1, -1, -1}, {27134, -1, -1, -1}, {27136, -1, -1, -1}, {27137, -1, -1, -1}, {27139, -1, -1, -1}, {27151, -1, -1, -1}, {27153, -1, -1, -1}, {27157, -1, -1, -1}, {27162, -1, -1, -1}, {27165, -1, -1, -1}, {27168, -1, -1, -1}, {27172, -1, -1, -1}, {27176, -1, -1, -1}, {27184, -1, -1, -1}, {27186, -1, -1, -1}, {27188, -1, -1, -1}, {27191, -1, -1, -1}, {27195, -1, -1, -1}, {27198, -1, -1, -1}, {27199, -1, -1, -1}, {27205, -1, -1, -1}, {27206, -1, -1, -1}, {27209, -1, -1, -1}, {27210, -1, -1, -1}, {27214, -1, -1, -1}, {27216, -1, -1, -1}, {27217, -1, -1, -1}, {27218, -1, -1, -1}, {27221, -1, -1, -1}, {27222, -1, -1, -1}, {27227, -1, -1, -1}, {27236, -1, -1, -1}, {27239, -1, -1, -1}, {27242, -1, -1, -1}, {27249, -1, -1, -1}, {27251, -1, -1, -1}, {27262, -1, -1, -1}, {27265, -1, -1, -1}, {27267, -1, -1, -1}, {27270, -1, -1, -1}, {27271, -1, -1, -1}, {27273, -1, -1, -1}, {27275, -1, -1, -1}, {27281, -1, -1, -1}, {27291, -1, -1, -1}, {27293, -1, -1, -1}, {27294, -1, -1, -1}, {27295, -1, -1, -1}, {27301, -1, -1, -1}, {27307, -1, -1, -1}, {27311, -1, -1, -1}, {27312, -1, -1, -1}, {27313, -1, -1, -1}, {27316, -1, -1, -1}, {27325, -1, -1, -1}, {27326, -1, -1, -1}, {27327, -1, -1, -1}, {27334, -1, -1, -1}, {27337, -1, -1, -1}, {27336, -1, -1, -1}, {27340, -1, -1, -1}, {27344, -1, -1, -1}, {27348, -1, -1, -1}, {27349, -1, -1, -1}, {27350, -1, -1, -1}, {27356, -1, -1, -1}, {27357, -1, -1, -1}, {27364, -1, -1, -1}, {27367, -1, -1, -1}, {27372, -1, -1, -1}, {27376, -1, -1, -1}, {27377, -1, -1, -1}, {27378, -1, -1, -1}, {27388, -1, -1, -1}, {27389, -1, -1, -1}, {27394, -1, -1, -1}, {27395, -1, -1, -1}, {27398, -1, -1, -1} },
+ {{27399, -1, -1, -1}, {27401, -1, -1, -1}, {27407, -1, -1, -1}, {27408, -1, -1, -1}, {27409, -1, -1, -1}, {27415, -1, -1, -1}, {27419, -1, -1, -1}, {27422, -1, -1, -1}, {27428, -1, -1, -1}, {27432, -1, -1, -1}, {27435, -1, -1, -1}, {27436, -1, -1, -1}, {27439, -1, -1, -1}, {27445, -1, -1, -1}, {27446, -1, -1, -1}, {27451, -1, -1, -1}, {27455, -1, -1, -1}, {27462, -1, -1, -1}, {27466, -1, -1, -1}, {27469, -1, -1, -1}, {27474, -1, -1, -1}, {27478, -1, -1, -1}, {27480, -1, -1, -1}, {27485, -1, -1, -1}, {27488, -1, -1, -1}, {27495, -1, -1, -1}, {27499, -1, -1, -1}, {27502, -1, -1, -1}, {27504, -1, -1, -1}, {27509, -1, -1, -1}, {27517, -1, -1, -1}, {27518, -1, -1, -1}, {27522, -1, -1, -1}, {27525, -1, -1, -1}, {27543, -1, -1, -1}, {27547, -1, -1, -1}, {27551, -1, -1, -1}, {27552, -1, -1, -1}, {27554, -1, -1, -1}, {27555, -1, -1, -1}, {27560, -1, -1, -1}, {27561, -1, -1, -1}, {27564, -1, -1, -1}, {27565, -1, -1, -1}, {27566, -1, -1, -1}, {27568, -1, -1, -1}, {27576, -1, -1, -1}, {27577, -1, -1, -1}, {27581, -1, -1, -1}, {27582, -1, -1, -1}, {27587, -1, -1, -1}, {27588, -1, -1, -1}, {27593, -1, -1, -1}, {27596, -1, -1, -1}, {27606, -1, -1, -1}, {27610, -1, -1, -1}, {27617, -1, -1, -1}, {27619, -1, -1, -1}, {27622, -1, -1, -1}, {27623, -1, -1, -1}, {27630, -1, -1, -1}, {27633, -1, -1, -1}, {27639, -1, -1, -1}, {27641, -1, -1, -1}, {27647, -1, -1, -1}, {27650, -1, -1, -1}, {27652, -1, -1, -1}, {27653, -1, -1, -1}, {27657, -1, -1, -1}, {27661, -1, -1, -1}, {27662, -1, -1, -1}, {27664, -1, -1, -1}, {27666, -1, -1, -1}, {27673, -1, -1, -1}, {27679, -1, -1, -1}, {27686, -1, -1, -1}, {27687, -1, -1, -1}, {27688, -1, -1, -1}, {27692, -1, -1, -1}, {27694, -1, -1, -1}, {27699, -1, -1, -1}, {27701, -1, -1, -1}, {27702, -1, -1, -1}, {27706, -1, -1, -1}, {27707, -1, -1, -1}, {27711, -1, -1, -1}, {27722, -1, -1, -1}, {27723, -1, -1, -1}, {27725, -1, -1, -1}, {27727, -1, -1, -1}, {27730, -1, -1, -1}, {27732, -1, -1, -1}, {27737, -1, -1, -1}, {27739, -1, -1, -1}, {27740, -1, -1, -1}, {27755, -1, -1, -1}, {27757, -1, -1, -1}, {27759, -1, -1, -1}, {27764, -1, -1, -1}, {27766, -1, -1, -1}, {27768, -1, -1, -1}, {27769, -1, -1, -1}, {27771, -1, -1, -1}, {27781, -1, -1, -1}, {27782, -1, -1, -1}, {27783, -1, -1, -1}, {27785, -1, -1, -1}, {27796, -1, -1, -1}, {27797, -1, -1, -1}, {27799, -1, -1, -1}, {27800, -1, -1, -1}, {27804, -1, -1, -1}, {27807, -1, -1, -1}, {27824, -1, -1, -1}, {27826, -1, -1, -1}, {27828, -1, -1, -1}, {27842, -1, -1, -1}, {27846, -1, -1, -1}, {27853, -1, -1, -1}, {27855, -1, -1, -1}, {27856, -1, -1, -1}, {27857, -1, -1, -1}, {27858, -1, -1, -1}, {27860, -1, -1, -1}, {27862, -1, -1, -1}, {27866, -1, -1, -1}, {27868, -1, -1, -1}, {27872, -1, -1, -1}, {27879, -1, -1, -1}, {27881, -1, -1, -1}, {27883, -1, -1, -1}, {27884, -1, -1, -1}, {27886, -1, -1, -1}, {27890, -1, -1, -1}, {27892, -1, -1, -1}, {27908, -1, -1, -1}, {27911, -1, -1, -1}, {27914, -1, -1, -1}, {27918, -1, -1, -1}, {27919, -1, -1, -1}, {27921, -1, -1, -1}, {27923, -1, -1, -1}, {27930, -1, -1, -1}, {27942, -1, -1, -1}, {27943, -1, -1, -1}, {27944, -1, -1, -1}, {27751, -1, -1, -1}, {27950, -1, -1, -1}, {27951, -1, -1, -1}, {27953, -1, -1, -1}, {27961, -1, -1, -1}, {27964, -1, -1, -1}, {27967, -1, -1, -1}, {27991, -1, -1, -1}, {27998, -1, -1, -1}, {27999, -1, -1, -1}, {28001, -1, -1, -1}, {28005, -1, -1, -1}, {28007, -1, -1, -1}, {28015, -1, -1, -1}, {28016, -1, -1, -1}, {28028, -1, -1, -1}, {28034, -1, -1, -1}, {28039, -1, -1, -1}, {28049, -1, -1, -1}, {28050, -1, -1, -1}, {28052, -1, -1, -1}, {28054, -1, -1, -1}, {28055, -1, -1, -1}, {28056, -1, -1, -1}, {28074, -1, -1, -1}, {28076, -1, -1, -1}, {28084, -1, -1, -1}, {28087, -1, -1, -1}, {28089, -1, -1, -1}, {28093, -1, -1, -1}, {28095, -1, -1, -1}, {28100, -1, -1, -1}, {28104, -1, -1, -1}, {28106, -1, -1, -1}, {28110, -1, -1, -1}, {28111, -1, -1, -1}, {28118, -1, -1, -1}, {28123, -1, -1, -1}, {28125, -1, -1, -1}, {28127, -1, -1, -1}, {28128, -1, -1, -1}, {28130, -1, -1, -1}, {28133, -1, -1, -1}, {28137, -1, -1, -1}, {28143, -1, -1, -1}, {28144, -1, -1, -1}, {28148, -1, -1, -1}, {28150, -1, -1, -1}, {28156, -1, -1, -1}, {28160, -1, -1, -1}, {28164, -1, -1, -1}, {28190, -1, -1, -1}, {28194, -1, -1, -1}, {28199, -1, -1, -1}, {28210, -1, -1, -1}, {28214, -1, -1, -1}, {28217, -1, -1, -1}, {28219, -1, -1, -1}, {28220, -1, -1, -1}, {28228, -1, -1, -1}, {28229, -1, -1, -1}, {28232, -1, -1, -1}, {28233, -1, -1, -1}, {28235, -1, -1, -1}, {28239, -1, -1, -1}, {28241, -1, -1, -1}, {28242, -1, -1, -1}, {28243, -1, -1, -1}, {28244, -1, -1, -1}, {28247, -1, -1, -1}, {28252, -1, -1, -1}, {28253, -1, -1, -1}, {28254, -1, -1, -1}, {28258, -1, -1, -1}, {28259, -1, -1, -1}, {28264, -1, -1, -1}, {28275, -1, -1, -1}, {28283, -1, -1, -1}, {28285, -1, -1, -1}, {28301, -1, -1, -1}, {28307, -1, -1, -1}, {28313, -1, -1, -1}, {28320, -1, -1, -1}, {28327, -1, -1, -1}, {28333, -1, -1, -1}, {28334, -1, -1, -1}, {28337, -1, -1, -1}, {28339, -1, -1, -1}, {28347, -1, -1, -1}, {28351, -1, -1, -1}, {28352, -1, -1, -1}, {28353, -1, -1, -1}, {28355, -1, -1, -1}, {28359, -1, -1, -1}, {28360, -1, -1, -1}, {28362, -1, -1, -1}, {28365, -1, -1, -1}, {28366, -1, -1, -1}, {28367, -1, -1, -1}, {28395, -1, -1, -1}, {28397, -1, -1, -1}, {28398, -1, -1, -1}, {28409, -1, -1, -1}, {28411, -1, -1, -1}, {28413, -1, -1, -1}, {28420, -1, -1, -1}, {28424, -1, -1, -1}, {28426, -1, -1, -1}, {28428, -1, -1, -1}, {28429, -1, -1, -1} },
+ {{28438, -1, -1, -1}, {28440, -1, -1, -1}, {28442, -1, -1, -1}, {28443, -1, -1, -1}, {28454, -1, -1, -1}, {28457, -1, -1, -1}, {28458, -1, -1, -1}, {28463, -1, -1, -1}, {28464, -1, -1, -1}, {28467, -1, -1, -1}, {28470, -1, -1, -1}, {28475, -1, -1, -1}, {28476, -1, -1, -1}, {28461, -1, -1, -1}, {28495, -1, -1, -1}, {28497, -1, -1, -1}, {28498, -1, -1, -1}, {28499, -1, -1, -1}, {28503, -1, -1, -1}, {28505, -1, -1, -1}, {28506, -1, -1, -1}, {28509, -1, -1, -1}, {28510, -1, -1, -1}, {28513, -1, -1, -1}, {28514, -1, -1, -1}, {28520, -1, -1, -1}, {28524, -1, -1, -1}, {28541, -1, -1, -1}, {28542, -1, -1, -1}, {28547, -1, -1, -1}, {28551, -1, -1, -1}, {28552, -1, -1, -1}, {28555, -1, -1, -1}, {28556, -1, -1, -1}, {28557, -1, -1, -1}, {28560, -1, -1, -1}, {28562, -1, -1, -1}, {28563, -1, -1, -1}, {28564, -1, -1, -1}, {28566, -1, -1, -1}, {28570, -1, -1, -1}, {28575, -1, -1, -1}, {28576, -1, -1, -1}, {28581, -1, -1, -1}, {28582, -1, -1, -1}, {28583, -1, -1, -1}, {28584, -1, -1, -1}, {28590, -1, -1, -1}, {28591, -1, -1, -1}, {28592, -1, -1, -1}, {28597, -1, -1, -1}, {28598, -1, -1, -1}, {28604, -1, -1, -1}, {28613, -1, -1, -1}, {28615, -1, -1, -1}, {28616, -1, -1, -1}, {28618, -1, -1, -1}, {28634, -1, -1, -1}, {28638, -1, -1, -1}, {28648, -1, -1, -1}, {28649, -1, -1, -1}, {28656, -1, -1, -1}, {28661, -1, -1, -1}, {28665, -1, -1, -1}, {28668, -1, -1, -1}, {28669, -1, -1, -1}, {28672, -1, -1, -1}, {28677, -1, -1, -1}, {28678, -1, -1, -1}, {28679, -1, -1, -1}, {28685, -1, -1, -1}, {28695, -1, -1, -1}, {28704, -1, -1, -1}, {28707, -1, -1, -1}, {28719, -1, -1, -1}, {28724, -1, -1, -1}, {28727, -1, -1, -1}, {28729, -1, -1, -1}, {28732, -1, -1, -1}, {28739, -1, -1, -1}, {28740, -1, -1, -1}, {28744, -1, -1, -1}, {28745, -1, -1, -1}, {28746, -1, -1, -1}, {28747, -1, -1, -1}, {28756, -1, -1, -1}, {28757, -1, -1, -1}, {28765, -1, -1, -1}, {28766, -1, -1, -1}, {28750, -1, -1, -1}, {28772, -1, -1, -1}, {28773, -1, -1, -1}, {28780, -1, -1, -1}, {28782, -1, -1, -1}, {28789, -1, -1, -1}, {28790, -1, -1, -1}, {28798, -1, -1, -1}, {28801, -1, -1, -1}, {28805, -1, -1, -1}, {28806, -1, -1, -1}, {28820, -1, -1, -1}, {28821, -1, -1, -1}, {28822, -1, -1, -1}, {28823, -1, -1, -1}, {28824, -1, -1, -1}, {28827, -1, -1, -1}, {28836, -1, -1, -1}, {28843, -1, -1, -1}, {28848, -1, -1, -1}, {28849, -1, -1, -1}, {28852, -1, -1, -1}, {28855, -1, -1, -1}, {28874, -1, -1, -1}, {28881, -1, -1, -1}, {28883, -1, -1, -1}, {28884, -1, -1, -1}, {28885, -1, -1, -1}, {28886, -1, -1, -1}, {28888, -1, -1, -1}, {28892, -1, -1, -1}, {28900, -1, -1, -1}, {28922, -1, -1, -1}, {28931, -1, -1, -1}, {28932, -1, -1, -1}, {28933, -1, -1, -1}, {28934, -1, -1, -1}, {28935, -1, -1, -1}, {28939, -1, -1, -1}, {28940, -1, -1, -1}, {28943, -1, -1, -1}, {28958, -1, -1, -1}, {28960, -1, -1, -1}, {28971, -1, -1, -1}, {28973, -1, -1, -1}, {28975, -1, -1, -1}, {28976, -1, -1, -1}, {28977, -1, -1, -1}, {28984, -1, -1, -1}, {28993, -1, -1, -1}, {28997, -1, -1, -1}, {28998, -1, -1, -1}, {28999, -1, -1, -1}, {29002, -1, -1, -1}, {29003, -1, -1, -1}, {29008, -1, -1, -1}, {29010, -1, -1, -1}, {29015, -1, -1, -1}, {29018, -1, -1, -1}, {29020, -1, -1, -1}, {29022, -1, -1, -1}, {29024, -1, -1, -1}, {29032, -1, -1, -1}, {29049, -1, -1, -1}, {29056, -1, -1, -1}, {29061, -1, -1, -1}, {29063, -1, -1, -1}, {29068, -1, -1, -1}, {29074, -1, -1, -1}, {29082, -1, -1, -1}, {29083, -1, -1, -1}, {29088, -1, -1, -1}, {29090, -1, -1, -1}, {29103, -1, -1, -1}, {29104, -1, -1, -1}, {29106, -1, -1, -1}, {29107, -1, -1, -1}, {29114, -1, -1, -1}, {29119, -1, -1, -1}, {29120, -1, -1, -1}, {29121, -1, -1, -1}, {29124, -1, -1, -1}, {29131, -1, -1, -1}, {29132, -1, -1, -1}, {29139, -1, -1, -1}, {29142, -1, -1, -1}, {29145, -1, -1, -1}, {29146, -1, -1, -1}, {29148, -1, -1, -1}, {29176, -1, -1, -1}, {29182, -1, -1, -1}, {29184, -1, -1, -1}, {29191, -1, -1, -1}, {29192, -1, -1, -1}, {29193, -1, -1, -1}, {29203, -1, -1, -1}, {29207, -1, -1, -1}, {29210, -1, -1, -1}, {29213, -1, -1, -1}, {29215, -1, -1, -1}, {29220, -1, -1, -1}, {29227, -1, -1, -1}, {29231, -1, -1, -1}, {29236, -1, -1, -1}, {29240, -1, -1, -1}, {29241, -1, -1, -1}, {29249, -1, -1, -1}, {29250, -1, -1, -1}, {29251, -1, -1, -1}, {29253, -1, -1, -1}, {29262, -1, -1, -1}, {29263, -1, -1, -1}, {29264, -1, -1, -1}, {29267, -1, -1, -1}, {29269, -1, -1, -1}, {29270, -1, -1, -1}, {29274, -1, -1, -1}, {29276, -1, -1, -1}, {29278, -1, -1, -1}, {29280, -1, -1, -1}, {29283, -1, -1, -1}, {29288, -1, -1, -1}, {29291, -1, -1, -1}, {29294, -1, -1, -1}, {29295, -1, -1, -1}, {29297, -1, -1, -1}, {29303, -1, -1, -1}, {29304, -1, -1, -1}, {29307, -1, -1, -1}, {29308, -1, -1, -1}, {29311, -1, -1, -1}, {29316, -1, -1, -1}, {29321, -1, -1, -1}, {29325, -1, -1, -1}, {29326, -1, -1, -1}, {29331, -1, -1, -1}, {29339, -1, -1, -1}, {29352, -1, -1, -1}, {29357, -1, -1, -1}, {29358, -1, -1, -1}, {29361, -1, -1, -1}, {29364, -1, -1, -1}, {29374, -1, -1, -1}, {29377, -1, -1, -1}, {29383, -1, -1, -1}, {29385, -1, -1, -1}, {29388, -1, -1, -1}, {29397, -1, -1, -1}, {29398, -1, -1, -1}, {29400, -1, -1, -1}, {29407, -1, -1, -1}, {29413, -1, -1, -1}, {29427, -1, -1, -1}, {29428, -1, -1, -1}, {29434, -1, -1, -1}, {29435, -1, -1, -1}, {29438, -1, -1, -1}, {29442, -1, -1, -1}, {29444, -1, -1, -1}, {29445, -1, -1, -1}, {29447, -1, -1, -1}, {29451, -1, -1, -1}, {29453, -1, -1, -1}, {29458, -1, -1, -1}, {29459, -1, -1, -1}, {29464, -1, -1, -1}, {29465, -1, -1, -1} },
+ {{29470, -1, -1, -1}, {29474, -1, -1, -1}, {29476, -1, -1, -1}, {29479, -1, -1, -1}, {29480, -1, -1, -1}, {29484, -1, -1, -1}, {29489, -1, -1, -1}, {29490, -1, -1, -1}, {29493, -1, -1, -1}, {29498, -1, -1, -1}, {29499, -1, -1, -1}, {29501, -1, -1, -1}, {29507, -1, -1, -1}, {29517, -1, -1, -1}, {29520, -1, -1, -1}, {29522, -1, -1, -1}, {29526, -1, -1, -1}, {29528, -1, -1, -1}, {29533, -1, -1, -1}, {29534, -1, -1, -1}, {29535, -1, -1, -1}, {29536, -1, -1, -1}, {29542, -1, -1, -1}, {29543, -1, -1, -1}, {29545, -1, -1, -1}, {29547, -1, -1, -1}, {29548, -1, -1, -1}, {29550, -1, -1, -1}, {29551, -1, -1, -1}, {29553, -1, -1, -1}, {29559, -1, -1, -1}, {29561, -1, -1, -1}, {29564, -1, -1, -1}, {29568, -1, -1, -1}, {29569, -1, -1, -1}, {29571, -1, -1, -1}, {29573, -1, -1, -1}, {29574, -1, -1, -1}, {29582, -1, -1, -1}, {29584, -1, -1, -1}, {29587, -1, -1, -1}, {29589, -1, -1, -1}, {29591, -1, -1, -1}, {29592, -1, -1, -1}, {29596, -1, -1, -1}, {29598, -1, -1, -1}, {29599, -1, -1, -1}, {29600, -1, -1, -1}, {29602, -1, -1, -1}, {29605, -1, -1, -1}, {29606, -1, -1, -1}, {29610, -1, -1, -1}, {29611, -1, -1, -1}, {29613, -1, -1, -1}, {29621, -1, -1, -1}, {29623, -1, -1, -1}, {29625, -1, -1, -1}, {29628, -1, -1, -1}, {29629, -1, -1, -1}, {29631, -1, -1, -1}, {29637, -1, -1, -1}, {29638, -1, -1, -1}, {29641, -1, -1, -1}, {29643, -1, -1, -1}, {29644, -1, -1, -1}, {29647, -1, -1, -1}, {29650, -1, -1, -1}, {29651, -1, -1, -1}, {29654, -1, -1, -1}, {29657, -1, -1, -1}, {29661, -1, -1, -1}, {29665, -1, -1, -1}, {29667, -1, -1, -1}, {29670, -1, -1, -1}, {29671, -1, -1, -1}, {29673, -1, -1, -1}, {29684, -1, -1, -1}, {29685, -1, -1, -1}, {29687, -1, -1, -1}, {29689, -1, -1, -1}, {29690, -1, -1, -1}, {29691, -1, -1, -1}, {29693, -1, -1, -1}, {29695, -1, -1, -1}, {29696, -1, -1, -1}, {29697, -1, -1, -1}, {29700, -1, -1, -1}, {29703, -1, -1, -1}, {29706, -1, -1, -1}, {29713, -1, -1, -1}, {29722, -1, -1, -1}, {29723, -1, -1, -1}, {29732, -1, -1, -1}, {29734, -1, -1, -1}, {29736, -1, -1, -1}, {29737, -1, -1, -1}, {29738, -1, -1, -1}, {29739, -1, -1, -1}, {29740, -1, -1, -1}, {29741, -1, -1, -1}, {29742, -1, -1, -1}, {29743, -1, -1, -1}, {29744, -1, -1, -1}, {29745, -1, -1, -1}, {29753, -1, -1, -1}, {29760, -1, -1, -1}, {29763, -1, -1, -1}, {29764, -1, -1, -1}, {29766, -1, -1, -1}, {29767, -1, -1, -1}, {29771, -1, -1, -1}, {29773, -1, -1, -1}, {29777, -1, -1, -1}, {29778, -1, -1, -1}, {29783, -1, -1, -1}, {29789, -1, -1, -1}, {29794, -1, -1, -1}, {29798, -1, -1, -1}, {29799, -1, -1, -1}, {29800, -1, -1, -1}, {29803, -1, -1, -1}, {29805, -1, -1, -1}, {29806, -1, -1, -1}, {29809, -1, -1, -1}, {29810, -1, -1, -1}, {29824, -1, -1, -1}, {29825, -1, -1, -1}, {29829, -1, -1, -1}, {29830, -1, -1, -1}, {29831, -1, -1, -1}, {29833, -1, -1, -1}, {29839, -1, -1, -1}, {29840, -1, -1, -1}, {29841, -1, -1, -1}, {29842, -1, -1, -1}, {29848, -1, -1, -1}, {29849, -1, -1, -1}, {29850, -1, -1, -1}, {29852, -1, -1, -1}, {29855, -1, -1, -1}, {29856, -1, -1, -1}, {29857, -1, -1, -1}, {29859, -1, -1, -1}, {29862, -1, -1, -1}, {29864, -1, -1, -1}, {29865, -1, -1, -1}, {29866, -1, -1, -1}, {29867, -1, -1, -1}, {29870, -1, -1, -1}, {29871, -1, -1, -1}, {29873, -1, -1, -1}, {29874, -1, -1, -1}, {29877, -1, -1, -1}, {29881, -1, -1, -1}, {29883, -1, -1, -1}, {29887, -1, -1, -1}, {29896, -1, -1, -1}, {29897, -1, -1, -1}, {29900, -1, -1, -1}, {29904, -1, -1, -1}, {29907, -1, -1, -1}, {29912, -1, -1, -1}, {29914, -1, -1, -1}, {29915, -1, -1, -1}, {29918, -1, -1, -1}, {29919, -1, -1, -1}, {29924, -1, -1, -1}, {29928, -1, -1, -1}, {29930, -1, -1, -1}, {29931, -1, -1, -1}, {29935, -1, -1, -1}, {29940, -1, -1, -1}, {29946, -1, -1, -1}, {29947, -1, -1, -1}, {29948, -1, -1, -1}, {29951, -1, -1, -1}, {29958, -1, -1, -1}, {29970, -1, -1, -1}, {29974, -1, -1, -1}, {29975, -1, -1, -1}, {29984, -1, -1, -1}, {29985, -1, -1, -1}, {29988, -1, -1, -1}, {29991, -1, -1, -1}, {29993, -1, -1, -1}, {29994, -1, -1, -1}, {29999, -1, -1, -1}, {30006, -1, -1, -1}, {30009, -1, -1, -1}, {30013, -1, -1, -1}, {30014, -1, -1, -1}, {30015, -1, -1, -1}, {30016, -1, -1, -1}, {30019, -1, -1, -1}, {30023, -1, -1, -1}, {30024, -1, -1, -1}, {30030, -1, -1, -1}, {30032, -1, -1, -1}, {30034, -1, -1, -1}, {30039, -1, -1, -1}, {30046, -1, -1, -1}, {30047, -1, -1, -1}, {30049, -1, -1, -1}, {30063, -1, -1, -1}, {30065, -1, -1, -1}, {30073, -1, -1, -1}, {30074, -1, -1, -1}, {30075, -1, -1, -1}, {30076, -1, -1, -1}, {30077, -1, -1, -1}, {30078, -1, -1, -1}, {30081, -1, -1, -1}, {30085, -1, -1, -1}, {30096, -1, -1, -1}, {30098, -1, -1, -1}, {30099, -1, -1, -1}, {30101, -1, -1, -1}, {30105, -1, -1, -1}, {30108, -1, -1, -1}, {30114, -1, -1, -1}, {30116, -1, -1, -1}, {30132, -1, -1, -1}, {30138, -1, -1, -1}, {30143, -1, -1, -1}, {30144, -1, -1, -1}, {30145, -1, -1, -1}, {30148, -1, -1, -1}, {30150, -1, -1, -1}, {30156, -1, -1, -1}, {30158, -1, -1, -1}, {30159, -1, -1, -1}, {30167, -1, -1, -1}, {30172, -1, -1, -1}, {30175, -1, -1, -1}, {30176, -1, -1, -1}, {30177, -1, -1, -1}, {30180, -1, -1, -1}, {30183, -1, -1, -1}, {30188, -1, -1, -1}, {30190, -1, -1, -1}, {30191, -1, -1, -1}, {30193, -1, -1, -1}, {30201, -1, -1, -1}, {30208, -1, -1, -1}, {30210, -1, -1, -1}, {30211, -1, -1, -1}, {30212, -1, -1, -1}, {30215, -1, -1, -1}, {30216, -1, -1, -1}, {30218, -1, -1, -1}, {30220, -1, -1, -1}, {30223, -1, -1, -1}, {30226, -1, -1, -1}, {30227, -1, -1, -1}, {30229, -1, -1, -1}, {30230, -1, -1, -1} },
+ {{30233, -1, -1, -1}, {30235, -1, -1, -1}, {30236, -1, -1, -1}, {30237, -1, -1, -1}, {30238, -1, -1, -1}, {30243, -1, -1, -1}, {30245, -1, -1, -1}, {30246, -1, -1, -1}, {30249, -1, -1, -1}, {30253, -1, -1, -1}, {30258, -1, -1, -1}, {30259, -1, -1, -1}, {30261, -1, -1, -1}, {30264, -1, -1, -1}, {30265, -1, -1, -1}, {30266, -1, -1, -1}, {30268, -1, -1, -1}, {30282, -1, -1, -1}, {30272, -1, -1, -1}, {30273, -1, -1, -1}, {30275, -1, -1, -1}, {30276, -1, -1, -1}, {30277, -1, -1, -1}, {30281, -1, -1, -1}, {30283, -1, -1, -1}, {30293, -1, -1, -1}, {30297, -1, -1, -1}, {30303, -1, -1, -1}, {30308, -1, -1, -1}, {30309, -1, -1, -1}, {30317, -1, -1, -1}, {30318, -1, -1, -1}, {30319, -1, -1, -1}, {30321, -1, -1, -1}, {30324, -1, -1, -1}, {30337, -1, -1, -1}, {30341, -1, -1, -1}, {30348, -1, -1, -1}, {30349, -1, -1, -1}, {30357, -1, -1, -1}, {30363, -1, -1, -1}, {30364, -1, -1, -1}, {30365, -1, -1, -1}, {30367, -1, -1, -1}, {30368, -1, -1, -1}, {30370, -1, -1, -1}, {30371, -1, -1, -1}, {30372, -1, -1, -1}, {30373, -1, -1, -1}, {30374, -1, -1, -1}, {30375, -1, -1, -1}, {30376, -1, -1, -1}, {30378, -1, -1, -1}, {30381, -1, -1, -1}, {30397, -1, -1, -1}, {30401, -1, -1, -1}, {30405, -1, -1, -1}, {30409, -1, -1, -1}, {30411, -1, -1, -1}, {30412, -1, -1, -1}, {30414, -1, -1, -1}, {30420, -1, -1, -1}, {30425, -1, -1, -1}, {30432, -1, -1, -1}, {30438, -1, -1, -1}, {30440, -1, -1, -1}, {30444, -1, -1, -1}, {30448, -1, -1, -1}, {30449, -1, -1, -1}, {30454, -1, -1, -1}, {30457, -1, -1, -1}, {30460, -1, -1, -1}, {30464, -1, -1, -1}, {30470, -1, -1, -1}, {30474, -1, -1, -1}, {30478, -1, -1, -1}, {30482, -1, -1, -1}, {30484, -1, -1, -1}, {30485, -1, -1, -1}, {30487, -1, -1, -1}, {30489, -1, -1, -1}, {30490, -1, -1, -1}, {30492, -1, -1, -1}, {30498, -1, -1, -1}, {30504, -1, -1, -1}, {30509, -1, -1, -1}, {30510, -1, -1, -1}, {30511, -1, -1, -1}, {30516, -1, -1, -1}, {30517, -1, -1, -1}, {30518, -1, -1, -1}, {30521, -1, -1, -1}, {30525, -1, -1, -1}, {30526, -1, -1, -1}, {30530, -1, -1, -1}, {30533, -1, -1, -1}, {30534, -1, -1, -1}, {30538, -1, -1, -1}, {30541, -1, -1, -1}, {30542, -1, -1, -1}, {30543, -1, -1, -1}, {30546, -1, -1, -1}, {30550, -1, -1, -1}, {30551, -1, -1, -1}, {30556, -1, -1, -1}, {30558, -1, -1, -1}, {30559, -1, -1, -1}, {30560, -1, -1, -1}, {30562, -1, -1, -1}, {30564, -1, -1, -1}, {30567, -1, -1, -1}, {30570, -1, -1, -1}, {30572, -1, -1, -1}, {30576, -1, -1, -1}, {30578, -1, -1, -1}, {30579, -1, -1, -1}, {30580, -1, -1, -1}, {30586, -1, -1, -1}, {30589, -1, -1, -1}, {30592, -1, -1, -1}, {30596, -1, -1, -1}, {30604, -1, -1, -1}, {30605, -1, -1, -1}, {30612, -1, -1, -1}, {30613, -1, -1, -1}, {30614, -1, -1, -1}, {30618, -1, -1, -1}, {30623, -1, -1, -1}, {30626, -1, -1, -1}, {30631, -1, -1, -1}, {30634, -1, -1, -1}, {30638, -1, -1, -1}, {30639, -1, -1, -1}, {30641, -1, -1, -1}, {30645, -1, -1, -1}, {30654, -1, -1, -1}, {30659, -1, -1, -1}, {30665, -1, -1, -1}, {30673, -1, -1, -1}, {30674, -1, -1, -1}, {30677, -1, -1, -1}, {30681, -1, -1, -1}, {30686, -1, -1, -1}, {30687, -1, -1, -1}, {30688, -1, -1, -1}, {30692, -1, -1, -1}, {30694, -1, -1, -1}, {30698, -1, -1, -1}, {30700, -1, -1, -1}, {30704, -1, -1, -1}, {30705, -1, -1, -1}, {30708, -1, -1, -1}, {30712, -1, -1, -1}, {30715, -1, -1, -1}, {30725, -1, -1, -1}, {30726, -1, -1, -1}, {30729, -1, -1, -1}, {30733, -1, -1, -1}, {30734, -1, -1, -1}, {30737, -1, -1, -1}, {30749, -1, -1, -1}, {30753, -1, -1, -1}, {30754, -1, -1, -1}, {30755, -1, -1, -1}, {30765, -1, -1, -1}, {30766, -1, -1, -1}, {30768, -1, -1, -1}, {30773, -1, -1, -1}, {30775, -1, -1, -1}, {30787, -1, -1, -1}, {30788, -1, -1, -1}, {30791, -1, -1, -1}, {30792, -1, -1, -1}, {30796, -1, -1, -1}, {30798, -1, -1, -1}, {30802, -1, -1, -1}, {30812, -1, -1, -1}, {30814, -1, -1, -1}, {30816, -1, -1, -1}, {30817, -1, -1, -1}, {30819, -1, -1, -1}, {30820, -1, -1, -1}, {30824, -1, -1, -1}, {30826, -1, -1, -1}, {30830, -1, -1, -1}, {30842, -1, -1, -1}, {30846, -1, -1, -1}, {30858, -1, -1, -1}, {30863, -1, -1, -1}, {30868, -1, -1, -1}, {30872, -1, -1, -1}, {30881, -1, -1, -1}, {30877, -1, -1, -1}, {30878, -1, -1, -1}, {30879, -1, -1, -1}, {30884, -1, -1, -1}, {30888, -1, -1, -1}, {30892, -1, -1, -1}, {30893, -1, -1, -1}, {30896, -1, -1, -1}, {30897, -1, -1, -1}, {30898, -1, -1, -1}, {30899, -1, -1, -1}, {30907, -1, -1, -1}, {30909, -1, -1, -1}, {30911, -1, -1, -1}, {30919, -1, -1, -1}, {30920, -1, -1, -1}, {30921, -1, -1, -1}, {30924, -1, -1, -1}, {30926, -1, -1, -1}, {30930, -1, -1, -1}, {30931, -1, -1, -1}, {30933, -1, -1, -1}, {30934, -1, -1, -1}, {30948, -1, -1, -1}, {30939, -1, -1, -1}, {30943, -1, -1, -1}, {30944, -1, -1, -1}, {30945, -1, -1, -1}, {30950, -1, -1, -1}, {30954, -1, -1, -1}, {30962, -1, -1, -1}, {30963, -1, -1, -1}, {30976, -1, -1, -1}, {30966, -1, -1, -1}, {30967, -1, -1, -1}, {30970, -1, -1, -1}, {30971, -1, -1, -1}, {30975, -1, -1, -1}, {30982, -1, -1, -1}, {30988, -1, -1, -1}, {30992, -1, -1, -1}, {31002, -1, -1, -1}, {31004, -1, -1, -1}, {31006, -1, -1, -1}, {31007, -1, -1, -1}, {31008, -1, -1, -1}, {31013, -1, -1, -1}, {31015, -1, -1, -1}, {31017, -1, -1, -1}, {31021, -1, -1, -1}, {31025, -1, -1, -1}, {31028, -1, -1, -1}, {31029, -1, -1, -1}, {31035, -1, -1, -1}, {31037, -1, -1, -1}, {31039, -1, -1, -1}, {31044, -1, -1, -1}, {31045, -1, -1, -1}, {31046, -1, -1, -1}, {31050, -1, -1, -1}, {31051, -1, -1, -1}, {31055, -1, -1, -1}, {31057, -1, -1, -1}, {31060, -1, -1, -1} },
+ {{31064, -1, -1, -1}, {31067, -1, -1, -1}, {31068, -1, -1, -1}, {31079, -1, -1, -1}, {31081, -1, -1, -1}, {31083, -1, -1, -1}, {31090, -1, -1, -1}, {31097, -1, -1, -1}, {31099, -1, -1, -1}, {31100, -1, -1, -1}, {31102, -1, -1, -1}, {31115, -1, -1, -1}, {31116, -1, -1, -1}, {31121, -1, -1, -1}, {31123, -1, -1, -1}, {31124, -1, -1, -1}, {31125, -1, -1, -1}, {31126, -1, -1, -1}, {31128, -1, -1, -1}, {31131, -1, -1, -1}, {31132, -1, -1, -1}, {31137, -1, -1, -1}, {31144, -1, -1, -1}, {31145, -1, -1, -1}, {31147, -1, -1, -1}, {31151, -1, -1, -1}, {31153, -1, -1, -1}, {31156, -1, -1, -1}, {31160, -1, -1, -1}, {31163, -1, -1, -1}, {31170, -1, -1, -1}, {31172, -1, -1, -1}, {31175, -1, -1, -1}, {31176, -1, -1, -1}, {31178, -1, -1, -1}, {31183, -1, -1, -1}, {31188, -1, -1, -1}, {31190, -1, -1, -1}, {31194, -1, -1, -1}, {31197, -1, -1, -1}, {31198, -1, -1, -1}, {31200, -1, -1, -1}, {31202, -1, -1, -1}, {31205, -1, -1, -1}, {31210, -1, -1, -1}, {31211, -1, -1, -1}, {31213, -1, -1, -1}, {31217, -1, -1, -1}, {31224, -1, -1, -1}, {31228, -1, -1, -1}, {31234, -1, -1, -1}, {31235, -1, -1, -1}, {31239, -1, -1, -1}, {31241, -1, -1, -1}, {31242, -1, -1, -1}, {31244, -1, -1, -1}, {31249, -1, -1, -1}, {31253, -1, -1, -1}, {31259, -1, -1, -1}, {31262, -1, -1, -1}, {31265, -1, -1, -1}, {31271, -1, -1, -1}, {31275, -1, -1, -1}, {31277, -1, -1, -1}, {31279, -1, -1, -1}, {31280, -1, -1, -1}, {31284, -1, -1, -1}, {31285, -1, -1, -1}, {31288, -1, -1, -1}, {31289, -1, -1, -1}, {31290, -1, -1, -1}, {31300, -1, -1, -1}, {31301, -1, -1, -1}, {31303, -1, -1, -1}, {31304, -1, -1, -1}, {31308, -1, -1, -1}, {31317, -1, -1, -1}, {31318, -1, -1, -1}, {31321, -1, -1, -1}, {31324, -1, -1, -1}, {31325, -1, -1, -1}, {31327, -1, -1, -1}, {31328, -1, -1, -1}, {31333, -1, -1, -1}, {31335, -1, -1, -1}, {31338, -1, -1, -1}, {31341, -1, -1, -1}, {31349, -1, -1, -1}, {31352, -1, -1, -1}, {31358, -1, -1, -1}, {31360, -1, -1, -1}, {31362, -1, -1, -1}, {31365, -1, -1, -1}, {31366, -1, -1, -1}, {31370, -1, -1, -1}, {31371, -1, -1, -1}, {31376, -1, -1, -1}, {31377, -1, -1, -1}, {31380, -1, -1, -1}, {31390, -1, -1, -1}, {31392, -1, -1, -1}, {31395, -1, -1, -1}, {31404, -1, -1, -1}, {31411, -1, -1, -1}, {31413, -1, -1, -1}, {31417, -1, -1, -1}, {31419, -1, -1, -1}, {31420, -1, -1, -1}, {31430, -1, -1, -1}, {31433, -1, -1, -1}, {31436, -1, -1, -1}, {31438, -1, -1, -1}, {31441, -1, -1, -1}, {31451, -1, -1, -1}, {31464, -1, -1, -1}, {31465, -1, -1, -1}, {31467, -1, -1, -1}, {31468, -1, -1, -1}, {31473, -1, -1, -1}, {31476, -1, -1, -1}, {31483, -1, -1, -1}, {31485, -1, -1, -1}, {31486, -1, -1, -1}, {31495, -1, -1, -1}, {31508, -1, -1, -1}, {31519, -1, -1, -1}, {31523, -1, -1, -1}, {31527, -1, -1, -1}, {31529, -1, -1, -1}, {31530, -1, -1, -1}, {31531, -1, -1, -1}, {31533, -1, -1, -1}, {31534, -1, -1, -1}, {31535, -1, -1, -1}, {31536, -1, -1, -1}, {31537, -1, -1, -1}, {31540, -1, -1, -1}, {31549, -1, -1, -1}, {31551, -1, -1, -1}, {31552, -1, -1, -1}, {31553, -1, -1, -1}, {31559, -1, -1, -1}, {31566, -1, -1, -1}, {31573, -1, -1, -1}, {31584, -1, -1, -1}, {31588, -1, -1, -1}, {31590, -1, -1, -1}, {31593, -1, -1, -1}, {31594, -1, -1, -1}, {31597, -1, -1, -1}, {31599, -1, -1, -1}, {31602, -1, -1, -1}, {31603, -1, -1, -1}, {31607, -1, -1, -1}, {31620, -1, -1, -1}, {31625, -1, -1, -1}, {31630, -1, -1, -1}, {31632, -1, -1, -1}, {31633, -1, -1, -1}, {31638, -1, -1, -1}, {31643, -1, -1, -1}, {31646, -1, -1, -1}, {31648, -1, -1, -1}, {31653, -1, -1, -1}, {31660, -1, -1, -1}, {31663, -1, -1, -1}, {31664, -1, -1, -1}, {31666, -1, -1, -1}, {31669, -1, -1, -1}, {31670, -1, -1, -1}, {31674, -1, -1, -1}, {31675, -1, -1, -1}, {31676, -1, -1, -1}, {31677, -1, -1, -1}, {31682, -1, -1, -1}, {31685, -1, -1, -1}, {31688, -1, -1, -1}, {31690, -1, -1, -1}, {31700, -1, -1, -1}, {31702, -1, -1, -1}, {31703, -1, -1, -1}, {31705, -1, -1, -1}, {31706, -1, -1, -1}, {31707, -1, -1, -1}, {31720, -1, -1, -1}, {31722, -1, -1, -1}, {31730, -1, -1, -1}, {31732, -1, -1, -1}, {31733, -1, -1, -1}, {31736, -1, -1, -1}, {31737, -1, -1, -1}, {31738, -1, -1, -1}, {31740, -1, -1, -1}, {31742, -1, -1, -1}, {31745, -1, -1, -1}, {31746, -1, -1, -1}, {31747, -1, -1, -1}, {31748, -1, -1, -1}, {31750, -1, -1, -1}, {31753, -1, -1, -1}, {31755, -1, -1, -1}, {31756, -1, -1, -1}, {31758, -1, -1, -1}, {31759, -1, -1, -1}, {31769, -1, -1, -1}, {31771, -1, -1, -1}, {31776, -1, -1, -1}, {31781, -1, -1, -1}, {31782, -1, -1, -1}, {31784, -1, -1, -1}, {31788, -1, -1, -1}, {31793, -1, -1, -1}, {31795, -1, -1, -1}, {31796, -1, -1, -1}, {31798, -1, -1, -1}, {31801, -1, -1, -1}, {31802, -1, -1, -1}, {31814, -1, -1, -1}, {31818, -1, -1, -1}, {31829, -1, -1, -1}, {31825, -1, -1, -1}, {31826, -1, -1, -1}, {31827, -1, -1, -1}, {31833, -1, -1, -1}, {31834, -1, -1, -1}, {31835, -1, -1, -1}, {31836, -1, -1, -1}, {31837, -1, -1, -1}, {31838, -1, -1, -1}, {31841, -1, -1, -1}, {31843, -1, -1, -1}, {31847, -1, -1, -1}, {31849, -1, -1, -1}, {31853, -1, -1, -1}, {31854, -1, -1, -1}, {31856, -1, -1, -1}, {31858, -1, -1, -1}, {31865, -1, -1, -1}, {31868, -1, -1, -1}, {31869, -1, -1, -1}, {31878, -1, -1, -1}, {31879, -1, -1, -1}, {31887, -1, -1, -1}, {31892, -1, -1, -1}, {31902, -1, -1, -1}, {31904, -1, -1, -1}, {31910, -1, -1, -1}, {31920, -1, -1, -1}, {31926, -1, -1, -1}, {31927, -1, -1, -1}, {31930, -1, -1, -1}, {31931, -1, -1, -1}, {31932, -1, -1, -1}, {31935, -1, -1, -1}, {31940, -1, -1, -1}, {31943, -1, -1, -1} },
+ {{31944, -1, -1, -1}, {31945, -1, -1, -1}, {31949, -1, -1, -1}, {31951, -1, -1, -1}, {31955, -1, -1, -1}, {31956, -1, -1, -1}, {31957, -1, -1, -1}, {31959, -1, -1, -1}, {31961, -1, -1, -1}, {31962, -1, -1, -1}, {31965, -1, -1, -1}, {31974, -1, -1, -1}, {31977, -1, -1, -1}, {31979, -1, -1, -1}, {31989, -1, -1, -1}, {32003, -1, -1, -1}, {32007, -1, -1, -1}, {32008, -1, -1, -1}, {32009, -1, -1, -1}, {32015, -1, -1, -1}, {32017, -1, -1, -1}, {32018, -1, -1, -1}, {32019, -1, -1, -1}, {32022, -1, -1, -1}, {32029, -1, -1, -1}, {32030, -1, -1, -1}, {32035, -1, -1, -1}, {32038, -1, -1, -1}, {32042, -1, -1, -1}, {32045, -1, -1, -1}, {32049, -1, -1, -1}, {32060, -1, -1, -1}, {32061, -1, -1, -1}, {32062, -1, -1, -1}, {32064, -1, -1, -1}, {32065, -1, -1, -1}, {32071, -1, -1, -1}, {32072, -1, -1, -1}, {32077, -1, -1, -1}, {32081, -1, -1, -1}, {32083, -1, -1, -1}, {32087, -1, -1, -1}, {32089, -1, -1, -1}, {32090, -1, -1, -1}, {32092, -1, -1, -1}, {32093, -1, -1, -1}, {32101, -1, -1, -1}, {32103, -1, -1, -1}, {32106, -1, -1, -1}, {32112, -1, -1, -1}, {32120, -1, -1, -1}, {32122, -1, -1, -1}, {32123, -1, -1, -1}, {32127, -1, -1, -1}, {32129, -1, -1, -1}, {32130, -1, -1, -1}, {32131, -1, -1, -1}, {32133, -1, -1, -1}, {32134, -1, -1, -1}, {32136, -1, -1, -1}, {32139, -1, -1, -1}, {32140, -1, -1, -1}, {32141, -1, -1, -1}, {32145, -1, -1, -1}, {32150, -1, -1, -1}, {32151, -1, -1, -1}, {32157, -1, -1, -1}, {32158, -1, -1, -1}, {32166, -1, -1, -1}, {32167, -1, -1, -1}, {32170, -1, -1, -1}, {32179, -1, -1, -1}, {32182, -1, -1, -1}, {32183, -1, -1, -1}, {32185, -1, -1, -1}, {32194, -1, -1, -1}, {32195, -1, -1, -1}, {32196, -1, -1, -1}, {32197, -1, -1, -1}, {32198, -1, -1, -1}, {32204, -1, -1, -1}, {32205, -1, -1, -1}, {32206, -1, -1, -1}, {32215, -1, -1, -1}, {32217, -1, -1, -1}, {32256, -1, -1, -1}, {32226, -1, -1, -1}, {32229, -1, -1, -1}, {32230, -1, -1, -1}, {32234, -1, -1, -1}, {32235, -1, -1, -1}, {32237, -1, -1, -1}, {32241, -1, -1, -1}, {32245, -1, -1, -1}, {32246, -1, -1, -1}, {32249, -1, -1, -1}, {32250, -1, -1, -1}, {32264, -1, -1, -1}, {32272, -1, -1, -1}, {32273, -1, -1, -1}, {32277, -1, -1, -1}, {32279, -1, -1, -1}, {32284, -1, -1, -1}, {32285, -1, -1, -1}, {32288, -1, -1, -1}, {32295, -1, -1, -1}, {32296, -1, -1, -1}, {32300, -1, -1, -1}, {32301, -1, -1, -1}, {32303, -1, -1, -1}, {32307, -1, -1, -1}, {32310, -1, -1, -1}, {32319, -1, -1, -1}, {32324, -1, -1, -1}, {32325, -1, -1, -1}, {32327, -1, -1, -1}, {32334, -1, -1, -1}, {32336, -1, -1, -1}, {32338, -1, -1, -1}, {32344, -1, -1, -1}, {32351, -1, -1, -1}, {32353, -1, -1, -1}, {32354, -1, -1, -1}, {32357, -1, -1, -1}, {32363, -1, -1, -1}, {32366, -1, -1, -1}, {32367, -1, -1, -1}, {32371, -1, -1, -1}, {32376, -1, -1, -1}, {32382, -1, -1, -1}, {32385, -1, -1, -1}, {32390, -1, -1, -1}, {32391, -1, -1, -1}, {32394, -1, -1, -1}, {32397, -1, -1, -1}, {32401, -1, -1, -1}, {32405, -1, -1, -1}, {32408, -1, -1, -1}, {32410, -1, -1, -1}, {32413, -1, -1, -1}, {32414, -1, -1, -1}, {32572, -1, -1, -1}, {32571, -1, -1, -1}, {32573, -1, -1, -1}, {32574, -1, -1, -1}, {32575, -1, -1, -1}, {32579, -1, -1, -1}, {32580, -1, -1, -1}, {32583, -1, -1, -1}, {32591, -1, -1, -1}, {32594, -1, -1, -1}, {32595, -1, -1, -1}, {32603, -1, -1, -1}, {32604, -1, -1, -1}, {32605, -1, -1, -1}, {32609, -1, -1, -1}, {32611, -1, -1, -1}, {32612, -1, -1, -1}, {32613, -1, -1, -1}, {32614, -1, -1, -1}, {32621, -1, -1, -1}, {32625, -1, -1, -1}, {32637, -1, -1, -1}, {32638, -1, -1, -1}, {32639, -1, -1, -1}, {32640, -1, -1, -1}, {32651, -1, -1, -1}, {32653, -1, -1, -1}, {32655, -1, -1, -1}, {32656, -1, -1, -1}, {32657, -1, -1, -1}, {32662, -1, -1, -1}, {32663, -1, -1, -1}, {32668, -1, -1, -1}, {32673, -1, -1, -1}, {32674, -1, -1, -1}, {32678, -1, -1, -1}, {32682, -1, -1, -1}, {32685, -1, -1, -1}, {32692, -1, -1, -1}, {32700, -1, -1, -1}, {32703, -1, -1, -1}, {32704, -1, -1, -1}, {32707, -1, -1, -1}, {32712, -1, -1, -1}, {32718, -1, -1, -1}, {32719, -1, -1, -1}, {32731, -1, -1, -1}, {32735, -1, -1, -1}, {32739, -1, -1, -1}, {32741, -1, -1, -1}, {32744, -1, -1, -1}, {32748, -1, -1, -1}, {32750, -1, -1, -1}, {32751, -1, -1, -1}, {32754, -1, -1, -1}, {32762, -1, -1, -1}, {32765, -1, -1, -1}, {32766, -1, -1, -1}, {32767, -1, -1, -1}, {32775, -1, -1, -1}, {32776, -1, -1, -1}, {32778, -1, -1, -1}, {32781, -1, -1, -1}, {32782, -1, -1, -1}, {32783, -1, -1, -1}, {32785, -1, -1, -1}, {32787, -1, -1, -1}, {32788, -1, -1, -1}, {32790, -1, -1, -1}, {32797, -1, -1, -1}, {32798, -1, -1, -1}, {32799, -1, -1, -1}, {32800, -1, -1, -1}, {32804, -1, -1, -1}, {32806, -1, -1, -1}, {32812, -1, -1, -1}, {32814, -1, -1, -1}, {32816, -1, -1, -1}, {32820, -1, -1, -1}, {32821, -1, -1, -1}, {32823, -1, -1, -1}, {32825, -1, -1, -1}, {32826, -1, -1, -1}, {32828, -1, -1, -1}, {32830, -1, -1, -1}, {32832, -1, -1, -1}, {32836, -1, -1, -1}, {32864, -1, -1, -1}, {32868, -1, -1, -1}, {32870, -1, -1, -1}, {32877, -1, -1, -1}, {32881, -1, -1, -1}, {32885, -1, -1, -1}, {32897, -1, -1, -1}, {32904, -1, -1, -1}, {32910, -1, -1, -1}, {32924, -1, -1, -1}, {32926, -1, -1, -1}, {32934, -1, -1, -1}, {32935, -1, -1, -1}, {32939, -1, -1, -1}, {32952, -1, -1, -1}, {32953, -1, -1, -1}, {32968, -1, -1, -1}, {32973, -1, -1, -1}, {32975, -1, -1, -1}, {32978, -1, -1, -1}, {32980, -1, -1, -1}, {32981, -1, -1, -1}, {32983, -1, -1, -1}, {32984, -1, -1, -1}, {32992, -1, -1, -1}, {33005, -1, -1, -1}, {33006, -1, -1, -1}, {33008, -1, -1, -1} },
+ {{33010, -1, -1, -1}, {33011, -1, -1, -1}, {33014, -1, -1, -1}, {33017, -1, -1, -1}, {33018, -1, -1, -1}, {33022, -1, -1, -1}, {33027, -1, -1, -1}, {33035, -1, -1, -1}, {33046, -1, -1, -1}, {33047, -1, -1, -1}, {33048, -1, -1, -1}, {33052, -1, -1, -1}, {33054, -1, -1, -1}, {33056, -1, -1, -1}, {33060, -1, -1, -1}, {33063, -1, -1, -1}, {33068, -1, -1, -1}, {33072, -1, -1, -1}, {33077, -1, -1, -1}, {33082, -1, -1, -1}, {33084, -1, -1, -1}, {33093, -1, -1, -1}, {33095, -1, -1, -1}, {33098, -1, -1, -1}, {33100, -1, -1, -1}, {33106, -1, -1, -1}, {33111, -1, -1, -1}, {33120, -1, -1, -1}, {33121, -1, -1, -1}, {33127, -1, -1, -1}, {33128, -1, -1, -1}, {33129, -1, -1, -1}, {33133, -1, -1, -1}, {33135, -1, -1, -1}, {33143, -1, -1, -1}, {33153, -1, -1, -1}, {33168, -1, -1, -1}, {33156, -1, -1, -1}, {33157, -1, -1, -1}, {33158, -1, -1, -1}, {33163, -1, -1, -1}, {33166, -1, -1, -1}, {33174, -1, -1, -1}, {33176, -1, -1, -1}, {33179, -1, -1, -1}, {33182, -1, -1, -1}, {33186, -1, -1, -1}, {33198, -1, -1, -1}, {33202, -1, -1, -1}, {33204, -1, -1, -1}, {33211, -1, -1, -1}, {33227, -1, -1, -1}, {33219, -1, -1, -1}, {33221, -1, -1, -1}, {33226, -1, -1, -1}, {33230, -1, -1, -1}, {33231, -1, -1, -1}, {33237, -1, -1, -1}, {33239, -1, -1, -1}, {33243, -1, -1, -1}, {33245, -1, -1, -1}, {33246, -1, -1, -1}, {33249, -1, -1, -1}, {33252, -1, -1, -1}, {33259, -1, -1, -1}, {33260, -1, -1, -1}, {33264, -1, -1, -1}, {33265, -1, -1, -1}, {33266, -1, -1, -1}, {33269, -1, -1, -1}, {33270, -1, -1, -1}, {33272, -1, -1, -1}, {33273, -1, -1, -1}, {33277, -1, -1, -1}, {33279, -1, -1, -1}, {33280, -1, -1, -1}, {33283, -1, -1, -1}, {33295, -1, -1, -1}, {33299, -1, -1, -1}, {33300, -1, -1, -1}, {33305, -1, -1, -1}, {33306, -1, -1, -1}, {33309, -1, -1, -1}, {33313, -1, -1, -1}, {33314, -1, -1, -1}, {33320, -1, -1, -1}, {33330, -1, -1, -1}, {33332, -1, -1, -1}, {33338, -1, -1, -1}, {33347, -1, -1, -1}, {33348, -1, -1, -1}, {33349, -1, -1, -1}, {33350, -1, -1, -1}, {33355, -1, -1, -1}, {33358, -1, -1, -1}, {33359, -1, -1, -1}, {33361, -1, -1, -1}, {33366, -1, -1, -1}, {33372, -1, -1, -1}, {33376, -1, -1, -1}, {33379, -1, -1, -1}, {33383, -1, -1, -1}, {33389, -1, -1, -1}, {33396, -1, -1, -1}, {33403, -1, -1, -1}, {33405, -1, -1, -1}, {33407, -1, -1, -1}, {33408, -1, -1, -1}, {33409, -1, -1, -1}, {33411, -1, -1, -1}, {33412, -1, -1, -1}, {33415, -1, -1, -1}, {33417, -1, -1, -1}, {33418, -1, -1, -1}, {33422, -1, -1, -1}, {33425, -1, -1, -1}, {33428, -1, -1, -1}, {33430, -1, -1, -1}, {33432, -1, -1, -1}, {33434, -1, -1, -1}, {33435, -1, -1, -1}, {33440, -1, -1, -1}, {33441, -1, -1, -1}, {33443, -1, -1, -1}, {33444, -1, -1, -1}, {33447, -1, -1, -1}, {33448, -1, -1, -1}, {33449, -1, -1, -1}, {33450, -1, -1, -1}, {33454, -1, -1, -1}, {33456, -1, -1, -1}, {33458, -1, -1, -1}, {33460, -1, -1, -1}, {33463, -1, -1, -1}, {33466, -1, -1, -1}, {33468, -1, -1, -1}, {33470, -1, -1, -1}, {33471, -1, -1, -1}, {33478, -1, -1, -1}, {33488, -1, -1, -1}, {33493, -1, -1, -1}, {33498, -1, -1, -1}, {33504, -1, -1, -1}, {33506, -1, -1, -1}, {33508, -1, -1, -1}, {33512, -1, -1, -1}, {33514, -1, -1, -1}, {33517, -1, -1, -1}, {33519, -1, -1, -1}, {33526, -1, -1, -1}, {33527, -1, -1, -1}, {33533, -1, -1, -1}, {33534, -1, -1, -1}, {33536, -1, -1, -1}, {33537, -1, -1, -1}, {33543, -1, -1, -1}, {33544, -1, -1, -1}, {33546, -1, -1, -1}, {33547, -1, -1, -1}, {33620, -1, -1, -1}, {33563, -1, -1, -1}, {33565, -1, -1, -1}, {33566, -1, -1, -1}, {33567, -1, -1, -1}, {33569, -1, -1, -1}, {33570, -1, -1, -1}, {33580, -1, -1, -1}, {33581, -1, -1, -1}, {33582, -1, -1, -1}, {33584, -1, -1, -1}, {33587, -1, -1, -1}, {33591, -1, -1, -1}, {33594, -1, -1, -1}, {33596, -1, -1, -1}, {33597, -1, -1, -1}, {33602, -1, -1, -1}, {33603, -1, -1, -1}, {33604, -1, -1, -1}, {33607, -1, -1, -1}, {33613, -1, -1, -1}, {33614, -1, -1, -1}, {33617, -1, -1, -1}, {33621, -1, -1, -1}, {33622, -1, -1, -1}, {33623, -1, -1, -1}, {33648, -1, -1, -1}, {33656, -1, -1, -1}, {33661, -1, -1, -1}, {33663, -1, -1, -1}, {33664, -1, -1, -1}, {33666, -1, -1, -1}, {33668, -1, -1, -1}, {33670, -1, -1, -1}, {33677, -1, -1, -1}, {33682, -1, -1, -1}, {33684, -1, -1, -1}, {33685, -1, -1, -1}, {33688, -1, -1, -1}, {33689, -1, -1, -1}, {33691, -1, -1, -1}, {33692, -1, -1, -1}, {33693, -1, -1, -1}, {33702, -1, -1, -1}, {33703, -1, -1, -1}, {33705, -1, -1, -1}, {33708, -1, -1, -1}, {33726, -1, -1, -1}, {33727, -1, -1, -1}, {33728, -1, -1, -1}, {33735, -1, -1, -1}, {33737, -1, -1, -1}, {33743, -1, -1, -1}, {33744, -1, -1, -1}, {33745, -1, -1, -1}, {33748, -1, -1, -1}, {33757, -1, -1, -1}, {33619, -1, -1, -1}, {33768, -1, -1, -1}, {33770, -1, -1, -1}, {33782, -1, -1, -1}, {33784, -1, -1, -1}, {33785, -1, -1, -1}, {33788, -1, -1, -1}, {33793, -1, -1, -1}, {33798, -1, -1, -1}, {33802, -1, -1, -1}, {33807, -1, -1, -1}, {33809, -1, -1, -1}, {33813, -1, -1, -1}, {33817, -1, -1, -1}, {33709, -1, -1, -1}, {33839, -1, -1, -1}, {33849, -1, -1, -1}, {33861, -1, -1, -1}, {33863, -1, -1, -1}, {33864, -1, -1, -1}, {33866, -1, -1, -1}, {33869, -1, -1, -1}, {33871, -1, -1, -1}, {33873, -1, -1, -1}, {33874, -1, -1, -1}, {33878, -1, -1, -1}, {33880, -1, -1, -1}, {33881, -1, -1, -1}, {33882, -1, -1, -1}, {33884, -1, -1, -1}, {33888, -1, -1, -1}, {33892, -1, -1, -1}, {33893, -1, -1, -1}, {33895, -1, -1, -1}, {33898, -1, -1, -1}, {33904, -1, -1, -1}, {33907, -1, -1, -1}, {33908, -1, -1, -1}, {33910, -1, -1, -1}, {33912, -1, -1, -1} },
+ {{33916, -1, -1, -1}, {33917, -1, -1, -1}, {33921, -1, -1, -1}, {33925, -1, -1, -1}, {33938, -1, -1, -1}, {33939, -1, -1, -1}, {33941, -1, -1, -1}, {33950, -1, -1, -1}, {33958, -1, -1, -1}, {33960, -1, -1, -1}, {33961, -1, -1, -1}, {33962, -1, -1, -1}, {33967, -1, -1, -1}, {33969, -1, -1, -1}, {33972, -1, -1, -1}, {33978, -1, -1, -1}, {33981, -1, -1, -1}, {33982, -1, -1, -1}, {33984, -1, -1, -1}, {33986, -1, -1, -1}, {33991, -1, -1, -1}, {33992, -1, -1, -1}, {33996, -1, -1, -1}, {33999, -1, -1, -1}, {34003, -1, -1, -1}, {34012, -1, -1, -1}, {34023, -1, -1, -1}, {34026, -1, -1, -1}, {34031, -1, -1, -1}, {34032, -1, -1, -1}, {34033, -1, -1, -1}, {34034, -1, -1, -1}, {34039, -1, -1, -1}, {34098, -1, -1, -1}, {34042, -1, -1, -1}, {34043, -1, -1, -1}, {34045, -1, -1, -1}, {34050, -1, -1, -1}, {34051, -1, -1, -1}, {34055, -1, -1, -1}, {34060, -1, -1, -1}, {34062, -1, -1, -1}, {34064, -1, -1, -1}, {34076, -1, -1, -1}, {34078, -1, -1, -1}, {34082, -1, -1, -1}, {34083, -1, -1, -1}, {34084, -1, -1, -1}, {34085, -1, -1, -1}, {34087, -1, -1, -1}, {34090, -1, -1, -1}, {34091, -1, -1, -1}, {34095, -1, -1, -1}, {34099, -1, -1, -1}, {34100, -1, -1, -1}, {34102, -1, -1, -1}, {34111, -1, -1, -1}, {34118, -1, -1, -1}, {34127, -1, -1, -1}, {34128, -1, -1, -1}, {34129, -1, -1, -1}, {34130, -1, -1, -1}, {34131, -1, -1, -1}, {34134, -1, -1, -1}, {34137, -1, -1, -1}, {34140, -1, -1, -1}, {34141, -1, -1, -1}, {34142, -1, -1, -1}, {34143, -1, -1, -1}, {34144, -1, -1, -1}, {34145, -1, -1, -1}, {34146, -1, -1, -1}, {34148, -1, -1, -1}, {34155, -1, -1, -1}, {34159, -1, -1, -1}, {34169, -1, -1, -1}, {34170, -1, -1, -1}, {34171, -1, -1, -1}, {34173, -1, -1, -1}, {34175, -1, -1, -1}, {34177, -1, -1, -1}, {34181, -1, -1, -1}, {34182, -1, -1, -1}, {34185, -1, -1, -1}, {34187, -1, -1, -1}, {34188, -1, -1, -1}, {34191, -1, -1, -1}, {34195, -1, -1, -1}, {34200, -1, -1, -1}, {34205, -1, -1, -1}, {34207, -1, -1, -1}, {34208, -1, -1, -1}, {34210, -1, -1, -1}, {34213, -1, -1, -1}, {34215, -1, -1, -1}, {34228, -1, -1, -1}, {34230, -1, -1, -1}, {34231, -1, -1, -1}, {34232, -1, -1, -1}, {34236, -1, -1, -1}, {34237, -1, -1, -1}, {34238, -1, -1, -1}, {34239, -1, -1, -1}, {34242, -1, -1, -1}, {34247, -1, -1, -1}, {34250, -1, -1, -1}, {34251, -1, -1, -1}, {34254, -1, -1, -1}, {34221, -1, -1, -1}, {34264, -1, -1, -1}, {34266, -1, -1, -1}, {34271, -1, -1, -1}, {34272, -1, -1, -1}, {34278, -1, -1, -1}, {34280, -1, -1, -1}, {34285, -1, -1, -1}, {34291, -1, -1, -1}, {34294, -1, -1, -1}, {34300, -1, -1, -1}, {34303, -1, -1, -1}, {34304, -1, -1, -1}, {34308, -1, -1, -1}, {34309, -1, -1, -1}, {34317, -1, -1, -1}, {34318, -1, -1, -1}, {34320, -1, -1, -1}, {34321, -1, -1, -1}, {34322, -1, -1, -1}, {34328, -1, -1, -1}, {34329, -1, -1, -1}, {34331, -1, -1, -1}, {34334, -1, -1, -1}, {34337, -1, -1, -1}, {34343, -1, -1, -1}, {34345, -1, -1, -1}, {34358, -1, -1, -1}, {34360, -1, -1, -1}, {34362, -1, -1, -1}, {34364, -1, -1, -1}, {34365, -1, -1, -1}, {34368, -1, -1, -1}, {34370, -1, -1, -1}, {34374, -1, -1, -1}, {34386, -1, -1, -1}, {34387, -1, -1, -1}, {34390, -1, -1, -1}, {34391, -1, -1, -1}, {34392, -1, -1, -1}, {34393, -1, -1, -1}, {34397, -1, -1, -1}, {34400, -1, -1, -1}, {34401, -1, -1, -1}, {34402, -1, -1, -1}, {34403, -1, -1, -1}, {34404, -1, -1, -1}, {34409, -1, -1, -1}, {34412, -1, -1, -1}, {34415, -1, -1, -1}, {34421, -1, -1, -1}, {34422, -1, -1, -1}, {34423, -1, -1, -1}, {34426, -1, -1, -1}, {34445, -1, -1, -1}, {34449, -1, -1, -1}, {34454, -1, -1, -1}, {34456, -1, -1, -1}, {34458, -1, -1, -1}, {34460, -1, -1, -1}, {34465, -1, -1, -1}, {34470, -1, -1, -1}, {34471, -1, -1, -1}, {34472, -1, -1, -1}, {34477, -1, -1, -1}, {34481, -1, -1, -1}, {34483, -1, -1, -1}, {34484, -1, -1, -1}, {34485, -1, -1, -1}, {34487, -1, -1, -1}, {34488, -1, -1, -1}, {34489, -1, -1, -1}, {34495, -1, -1, -1}, {34496, -1, -1, -1}, {34497, -1, -1, -1}, {34499, -1, -1, -1}, {34501, -1, -1, -1}, {34513, -1, -1, -1}, {34514, -1, -1, -1}, {34517, -1, -1, -1}, {34519, -1, -1, -1}, {34522, -1, -1, -1}, {34524, -1, -1, -1}, {34528, -1, -1, -1}, {34531, -1, -1, -1}, {34533, -1, -1, -1}, {34535, -1, -1, -1}, {34440, -1, -1, -1}, {34554, -1, -1, -1}, {34556, -1, -1, -1}, {34557, -1, -1, -1}, {34564, -1, -1, -1}, {34565, -1, -1, -1}, {34567, -1, -1, -1}, {34571, -1, -1, -1}, {34574, -1, -1, -1}, {34575, -1, -1, -1}, {34576, -1, -1, -1}, {34579, -1, -1, -1}, {34580, -1, -1, -1}, {34585, -1, -1, -1}, {34590, -1, -1, -1}, {34591, -1, -1, -1}, {34593, -1, -1, -1}, {34595, -1, -1, -1}, {34600, -1, -1, -1}, {34606, -1, -1, -1}, {34607, -1, -1, -1}, {34609, -1, -1, -1}, {34610, -1, -1, -1}, {34617, -1, -1, -1}, {34618, -1, -1, -1}, {34620, -1, -1, -1}, {34621, -1, -1, -1}, {34622, -1, -1, -1}, {34624, -1, -1, -1}, {34627, -1, -1, -1}, {34629, -1, -1, -1}, {34637, -1, -1, -1}, {34648, -1, -1, -1}, {34653, -1, -1, -1}, {34657, -1, -1, -1}, {34660, -1, -1, -1}, {34661, -1, -1, -1}, {34671, -1, -1, -1}, {34673, -1, -1, -1}, {34674, -1, -1, -1}, {34683, -1, -1, -1}, {34691, -1, -1, -1}, {34692, -1, -1, -1}, {34693, -1, -1, -1}, {34694, -1, -1, -1}, {34695, -1, -1, -1}, {34696, -1, -1, -1}, {34697, -1, -1, -1}, {34699, -1, -1, -1}, {34700, -1, -1, -1}, {34704, -1, -1, -1}, {34707, -1, -1, -1}, {34709, -1, -1, -1}, {34711, -1, -1, -1}, {34712, -1, -1, -1}, {34713, -1, -1, -1}, {34718, -1, -1, -1}, {34720, -1, -1, -1}, {34723, -1, -1, -1}, {34727, -1, -1, -1}, {34732, -1, -1, -1} },
+ {{34733, -1, -1, -1}, {34734, -1, -1, -1}, {34737, -1, -1, -1}, {34741, -1, -1, -1}, {34750, -1, -1, -1}, {34751, -1, -1, -1}, {34753, -1, -1, -1}, {34760, -1, -1, -1}, {34761, -1, -1, -1}, {34762, -1, -1, -1}, {34766, -1, -1, -1}, {34773, -1, -1, -1}, {34774, -1, -1, -1}, {34777, -1, -1, -1}, {34778, -1, -1, -1}, {34780, -1, -1, -1}, {34783, -1, -1, -1}, {34786, -1, -1, -1}, {34787, -1, -1, -1}, {34788, -1, -1, -1}, {34794, -1, -1, -1}, {34795, -1, -1, -1}, {34797, -1, -1, -1}, {34801, -1, -1, -1}, {34803, -1, -1, -1}, {34808, -1, -1, -1}, {34810, -1, -1, -1}, {34815, -1, -1, -1}, {34817, -1, -1, -1}, {34819, -1, -1, -1}, {34822, -1, -1, -1}, {34825, -1, -1, -1}, {34826, -1, -1, -1}, {34827, -1, -1, -1}, {34832, -1, -1, -1}, {34841, -1, -1, -1}, {34834, -1, -1, -1}, {34835, -1, -1, -1}, {34836, -1, -1, -1}, {34840, -1, -1, -1}, {34842, -1, -1, -1}, {34843, -1, -1, -1}, {34844, -1, -1, -1}, {34846, -1, -1, -1}, {34847, -1, -1, -1}, {34856, -1, -1, -1}, {34861, -1, -1, -1}, {34862, -1, -1, -1}, {34864, -1, -1, -1}, {34866, -1, -1, -1}, {34869, -1, -1, -1}, {34874, -1, -1, -1}, {34876, -1, -1, -1}, {34881, -1, -1, -1}, {34883, -1, -1, -1}, {34885, -1, -1, -1}, {34888, -1, -1, -1}, {34889, -1, -1, -1}, {34890, -1, -1, -1}, {34891, -1, -1, -1}, {34894, -1, -1, -1}, {34897, -1, -1, -1}, {34901, -1, -1, -1}, {34902, -1, -1, -1}, {34904, -1, -1, -1}, {34906, -1, -1, -1}, {34908, -1, -1, -1}, {34911, -1, -1, -1}, {34912, -1, -1, -1}, {34916, -1, -1, -1}, {34921, -1, -1, -1}, {34929, -1, -1, -1}, {34937, -1, -1, -1}, {34939, -1, -1, -1}, {34944, -1, -1, -1}, {34968, -1, -1, -1}, {34970, -1, -1, -1}, {34971, -1, -1, -1}, {34972, -1, -1, -1}, {34975, -1, -1, -1}, {34976, -1, -1, -1}, {34984, -1, -1, -1}, {34986, -1, -1, -1}, {35002, -1, -1, -1}, {35005, -1, -1, -1}, {35006, -1, -1, -1}, {35008, -1, -1, -1}, {35018, -1, -1, -1}, {35019, -1, -1, -1}, {35020, -1, -1, -1}, {35021, -1, -1, -1}, {35022, -1, -1, -1}, {35025, -1, -1, -1}, {35026, -1, -1, -1}, {35027, -1, -1, -1}, {35035, -1, -1, -1}, {35038, -1, -1, -1}, {35047, -1, -1, -1}, {35055, -1, -1, -1}, {35056, -1, -1, -1}, {35057, -1, -1, -1}, {35061, -1, -1, -1}, {35063, -1, -1, -1}, {35073, -1, -1, -1}, {35078, -1, -1, -1}, {35085, -1, -1, -1}, {35086, -1, -1, -1}, {35087, -1, -1, -1}, {35093, -1, -1, -1}, {35094, -1, -1, -1}, {35096, -1, -1, -1}, {35097, -1, -1, -1}, {35098, -1, -1, -1}, {35100, -1, -1, -1}, {35104, -1, -1, -1}, {35110, -1, -1, -1}, {35111, -1, -1, -1}, {35112, -1, -1, -1}, {35120, -1, -1, -1}, {35121, -1, -1, -1}, {35122, -1, -1, -1}, {35125, -1, -1, -1}, {35129, -1, -1, -1}, {35130, -1, -1, -1}, {35134, -1, -1, -1}, {35136, -1, -1, -1}, {35138, -1, -1, -1}, {35141, -1, -1, -1}, {35142, -1, -1, -1}, {35145, -1, -1, -1}, {35151, -1, -1, -1}, {35154, -1, -1, -1}, {35159, -1, -1, -1}, {35162, -1, -1, -1}, {35163, -1, -1, -1}, {35164, -1, -1, -1}, {35169, -1, -1, -1}, {35170, -1, -1, -1}, {35171, -1, -1, -1}, {35179, -1, -1, -1}, {35182, -1, -1, -1}, {35184, -1, -1, -1}, {35187, -1, -1, -1}, {35189, -1, -1, -1}, {35194, -1, -1, -1}, {35195, -1, -1, -1}, {35196, -1, -1, -1}, {35197, -1, -1, -1}, {35209, -1, -1, -1}, {35213, -1, -1, -1}, {35216, -1, -1, -1}, {35220, -1, -1, -1}, {35221, -1, -1, -1}, {35227, -1, -1, -1}, {35228, -1, -1, -1}, {35231, -1, -1, -1}, {35232, -1, -1, -1}, {35237, -1, -1, -1}, {35248, -1, -1, -1}, {35252, -1, -1, -1}, {35253, -1, -1, -1}, {35254, -1, -1, -1}, {35255, -1, -1, -1}, {35260, -1, -1, -1}, {35284, -1, -1, -1}, {35285, -1, -1, -1}, {35286, -1, -1, -1}, {35287, -1, -1, -1}, {35288, -1, -1, -1}, {35301, -1, -1, -1}, {35305, -1, -1, -1}, {35307, -1, -1, -1}, {35309, -1, -1, -1}, {35313, -1, -1, -1}, {35315, -1, -1, -1}, {35318, -1, -1, -1}, {35321, -1, -1, -1}, {35325, -1, -1, -1}, {35327, -1, -1, -1}, {35332, -1, -1, -1}, {35333, -1, -1, -1}, {35335, -1, -1, -1}, {35343, -1, -1, -1}, {35345, -1, -1, -1}, {35346, -1, -1, -1}, {35348, -1, -1, -1}, {35349, -1, -1, -1}, {35358, -1, -1, -1}, {35360, -1, -1, -1}, {35362, -1, -1, -1}, {35364, -1, -1, -1}, {35366, -1, -1, -1}, {35371, -1, -1, -1}, {35372, -1, -1, -1}, {35375, -1, -1, -1}, {35381, -1, -1, -1}, {35383, -1, -1, -1}, {35389, -1, -1, -1}, {35390, -1, -1, -1}, {35392, -1, -1, -1}, {35395, -1, -1, -1}, {35397, -1, -1, -1}, {35399, -1, -1, -1}, {35401, -1, -1, -1}, {35405, -1, -1, -1}, {35406, -1, -1, -1}, {35411, -1, -1, -1}, {35414, -1, -1, -1}, {35415, -1, -1, -1}, {35416, -1, -1, -1}, {35420, -1, -1, -1}, {35421, -1, -1, -1}, {35425, -1, -1, -1}, {35429, -1, -1, -1}, {35431, -1, -1, -1}, {35445, -1, -1, -1}, {35446, -1, -1, -1}, {35447, -1, -1, -1}, {35449, -1, -1, -1}, {35450, -1, -1, -1}, {35451, -1, -1, -1}, {35454, -1, -1, -1}, {35455, -1, -1, -1}, {35456, -1, -1, -1}, {35459, -1, -1, -1}, {35462, -1, -1, -1}, {35467, -1, -1, -1}, {35471, -1, -1, -1}, {35472, -1, -1, -1}, {35474, -1, -1, -1}, {35478, -1, -1, -1}, {35479, -1, -1, -1}, {35481, -1, -1, -1}, {35487, -1, -1, -1}, {35495, -1, -1, -1}, {35497, -1, -1, -1}, {35502, -1, -1, -1}, {35503, -1, -1, -1}, {35507, -1, -1, -1}, {35510, -1, -1, -1}, {35511, -1, -1, -1}, {35515, -1, -1, -1}, {35518, -1, -1, -1}, {35523, -1, -1, -1}, {35526, -1, -1, -1}, {35528, -1, -1, -1}, {35529, -1, -1, -1}, {35530, -1, -1, -1}, {35537, -1, -1, -1}, {35539, -1, -1, -1}, {35540, -1, -1, -1}, {35541, -1, -1, -1}, {35543, -1, -1, -1}, {35549, -1, -1, -1}, {35551, -1, -1, -1}, {35564, -1, -1, -1} },
+ {{35568, -1, -1, -1}, {35572, -1, -1, -1}, {35573, -1, -1, -1}, {35574, -1, -1, -1}, {35580, -1, -1, -1}, {35583, -1, -1, -1}, {35589, -1, -1, -1}, {35590, -1, -1, -1}, {35595, -1, -1, -1}, {35601, -1, -1, -1}, {35612, -1, -1, -1}, {35614, -1, -1, -1}, {35615, -1, -1, -1}, {35594, -1, -1, -1}, {35629, -1, -1, -1}, {35632, -1, -1, -1}, {35639, -1, -1, -1}, {35644, -1, -1, -1}, {35650, -1, -1, -1}, {35651, -1, -1, -1}, {35652, -1, -1, -1}, {35653, -1, -1, -1}, {35654, -1, -1, -1}, {35656, -1, -1, -1}, {35666, -1, -1, -1}, {35667, -1, -1, -1}, {35668, -1, -1, -1}, {35673, -1, -1, -1}, {35661, -1, -1, -1}, {35678, -1, -1, -1}, {35683, -1, -1, -1}, {35693, -1, -1, -1}, {35702, -1, -1, -1}, {35704, -1, -1, -1}, {35705, -1, -1, -1}, {35708, -1, -1, -1}, {35710, -1, -1, -1}, {35713, -1, -1, -1}, {35716, -1, -1, -1}, {35717, -1, -1, -1}, {35723, -1, -1, -1}, {35725, -1, -1, -1}, {35727, -1, -1, -1}, {35732, -1, -1, -1}, {35733, -1, -1, -1}, {35740, -1, -1, -1}, {35742, -1, -1, -1}, {35743, -1, -1, -1}, {35896, -1, -1, -1}, {35897, -1, -1, -1}, {35901, -1, -1, -1}, {35902, -1, -1, -1}, {35909, -1, -1, -1}, {35911, -1, -1, -1}, {35913, -1, -1, -1}, {35915, -1, -1, -1}, {35919, -1, -1, -1}, {35921, -1, -1, -1}, {35923, -1, -1, -1}, {35924, -1, -1, -1}, {35927, -1, -1, -1}, {35928, -1, -1, -1}, {35931, -1, -1, -1}, {35933, -1, -1, -1}, {35929, -1, -1, -1}, {35939, -1, -1, -1}, {35940, -1, -1, -1}, {35942, -1, -1, -1}, {35944, -1, -1, -1}, {35945, -1, -1, -1}, {35949, -1, -1, -1}, {35955, -1, -1, -1}, {35957, -1, -1, -1}, {35958, -1, -1, -1}, {35963, -1, -1, -1}, {35966, -1, -1, -1}, {35974, -1, -1, -1}, {35975, -1, -1, -1}, {35979, -1, -1, -1}, {35984, -1, -1, -1}, {35986, -1, -1, -1}, {35987, -1, -1, -1}, {35993, -1, -1, -1}, {35995, -1, -1, -1}, {35996, -1, -1, -1}, {36004, -1, -1, -1}, {36025, -1, -1, -1}, {36026, -1, -1, -1}, {36037, -1, -1, -1}, {36038, -1, -1, -1}, {36041, -1, -1, -1}, {36043, -1, -1, -1}, {36047, -1, -1, -1}, {36054, -1, -1, -1}, {36053, -1, -1, -1}, {36057, -1, -1, -1}, {36061, -1, -1, -1}, {36065, -1, -1, -1}, {36072, -1, -1, -1}, {36076, -1, -1, -1}, {36079, -1, -1, -1}, {36080, -1, -1, -1}, {36082, -1, -1, -1}, {36085, -1, -1, -1}, {36087, -1, -1, -1}, {36088, -1, -1, -1}, {36094, -1, -1, -1}, {36095, -1, -1, -1}, {36097, -1, -1, -1}, {36099, -1, -1, -1}, {36105, -1, -1, -1}, {36114, -1, -1, -1}, {36119, -1, -1, -1}, {36123, -1, -1, -1}, {36197, -1, -1, -1}, {36201, -1, -1, -1}, {36204, -1, -1, -1}, {36206, -1, -1, -1}, {36223, -1, -1, -1}, {36226, -1, -1, -1}, {36228, -1, -1, -1}, {36232, -1, -1, -1}, {36237, -1, -1, -1}, {36240, -1, -1, -1}, {36241, -1, -1, -1}, {36245, -1, -1, -1}, {36254, -1, -1, -1}, {36255, -1, -1, -1}, {36256, -1, -1, -1}, {36262, -1, -1, -1}, {36267, -1, -1, -1}, {36268, -1, -1, -1}, {36271, -1, -1, -1}, {36274, -1, -1, -1}, {36277, -1, -1, -1}, {36279, -1, -1, -1}, {36281, -1, -1, -1}, {36283, -1, -1, -1}, {36288, -1, -1, -1}, {36293, -1, -1, -1}, {36294, -1, -1, -1}, {36295, -1, -1, -1}, {36296, -1, -1, -1}, {36298, -1, -1, -1}, {36302, -1, -1, -1}, {36305, -1, -1, -1}, {36308, -1, -1, -1}, {36309, -1, -1, -1}, {36311, -1, -1, -1}, {36313, -1, -1, -1}, {36324, -1, -1, -1}, {36325, -1, -1, -1}, {36327, -1, -1, -1}, {36332, -1, -1, -1}, {36336, -1, -1, -1}, {36284, -1, -1, -1}, {36337, -1, -1, -1}, {36338, -1, -1, -1}, {36340, -1, -1, -1}, {36349, -1, -1, -1}, {36353, -1, -1, -1}, {36356, -1, -1, -1}, {36357, -1, -1, -1}, {36358, -1, -1, -1}, {36363, -1, -1, -1}, {36369, -1, -1, -1}, {36372, -1, -1, -1}, {36374, -1, -1, -1}, {36384, -1, -1, -1}, {36385, -1, -1, -1}, {36386, -1, -1, -1}, {36387, -1, -1, -1}, {36390, -1, -1, -1}, {36391, -1, -1, -1}, {36401, -1, -1, -1}, {36403, -1, -1, -1}, {36406, -1, -1, -1}, {36407, -1, -1, -1}, {36408, -1, -1, -1}, {36409, -1, -1, -1}, {36413, -1, -1, -1}, {36416, -1, -1, -1}, {36417, -1, -1, -1}, {36427, -1, -1, -1}, {36429, -1, -1, -1}, {36430, -1, -1, -1}, {36431, -1, -1, -1}, {36436, -1, -1, -1}, {36443, -1, -1, -1}, {36444, -1, -1, -1}, {36445, -1, -1, -1}, {36446, -1, -1, -1}, {36449, -1, -1, -1}, {36450, -1, -1, -1}, {36457, -1, -1, -1}, {36460, -1, -1, -1}, {36461, -1, -1, -1}, {36463, -1, -1, -1}, {36464, -1, -1, -1}, {36465, -1, -1, -1}, {36473, -1, -1, -1}, {36474, -1, -1, -1}, {36475, -1, -1, -1}, {36482, -1, -1, -1}, {36483, -1, -1, -1}, {36489, -1, -1, -1}, {36496, -1, -1, -1}, {36498, -1, -1, -1}, {36501, -1, -1, -1}, {36506, -1, -1, -1}, {36507, -1, -1, -1}, {36509, -1, -1, -1}, {36510, -1, -1, -1}, {36514, -1, -1, -1}, {36519, -1, -1, -1}, {36521, -1, -1, -1}, {36525, -1, -1, -1}, {36526, -1, -1, -1}, {36531, -1, -1, -1}, {36533, -1, -1, -1}, {36538, -1, -1, -1}, {36539, -1, -1, -1}, {36544, -1, -1, -1}, {36545, -1, -1, -1}, {36547, -1, -1, -1}, {36548, -1, -1, -1}, {36551, -1, -1, -1}, {36559, -1, -1, -1}, {36561, -1, -1, -1}, {36564, -1, -1, -1}, {36572, -1, -1, -1}, {36584, -1, -1, -1}, {36590, -1, -1, -1}, {36592, -1, -1, -1}, {36593, -1, -1, -1}, {36599, -1, -1, -1}, {36601, -1, -1, -1}, {36602, -1, -1, -1}, {36589, -1, -1, -1}, {36608, -1, -1, -1}, {36610, -1, -1, -1}, {36615, -1, -1, -1}, {36616, -1, -1, -1}, {36623, -1, -1, -1}, {36624, -1, -1, -1}, {36630, -1, -1, -1}, {36631, -1, -1, -1}, {36632, -1, -1, -1}, {36638, -1, -1, -1}, {36640, -1, -1, -1}, {36641, -1, -1, -1}, {36643, -1, -1, -1}, {36645, -1, -1, -1}, {36647, -1, -1, -1}, {36648, -1, -1, -1}, {36652, -1, -1, -1} },
+ {{36653, -1, -1, -1}, {36654, -1, -1, -1}, {36660, -1, -1, -1}, {36661, -1, -1, -1}, {36662, -1, -1, -1}, {36663, -1, -1, -1}, {36666, -1, -1, -1}, {36672, -1, -1, -1}, {36673, -1, -1, -1}, {36675, -1, -1, -1}, {36679, -1, -1, -1}, {36687, -1, -1, -1}, {36689, -1, -1, -1}, {36690, -1, -1, -1}, {36691, -1, -1, -1}, {36692, -1, -1, -1}, {36693, -1, -1, -1}, {36696, -1, -1, -1}, {36701, -1, -1, -1}, {36702, -1, -1, -1}, {36709, -1, -1, -1}, {36765, -1, -1, -1}, {36768, -1, -1, -1}, {36769, -1, -1, -1}, {36772, -1, -1, -1}, {36773, -1, -1, -1}, {36774, -1, -1, -1}, {36789, -1, -1, -1}, {36790, -1, -1, -1}, {36792, -1, -1, -1}, {36798, -1, -1, -1}, {36800, -1, -1, -1}, {36801, -1, -1, -1}, {36806, -1, -1, -1}, {36810, -1, -1, -1}, {36811, -1, -1, -1}, {36813, -1, -1, -1}, {36816, -1, -1, -1}, {36818, -1, -1, -1}, {36819, -1, -1, -1}, {36821, -1, -1, -1}, {36832, -1, -1, -1}, {36835, -1, -1, -1}, {36836, -1, -1, -1}, {36840, -1, -1, -1}, {36846, -1, -1, -1}, {36849, -1, -1, -1}, {36853, -1, -1, -1}, {36854, -1, -1, -1}, {36859, -1, -1, -1}, {36862, -1, -1, -1}, {36866, -1, -1, -1}, {36868, -1, -1, -1}, {36872, -1, -1, -1}, {36876, -1, -1, -1}, {36888, -1, -1, -1}, {36891, -1, -1, -1}, {36904, -1, -1, -1}, {36905, -1, -1, -1}, {36911, -1, -1, -1}, {36906, -1, -1, -1}, {36908, -1, -1, -1}, {36909, -1, -1, -1}, {36915, -1, -1, -1}, {36916, -1, -1, -1}, {36919, -1, -1, -1}, {36927, -1, -1, -1}, {36931, -1, -1, -1}, {36932, -1, -1, -1}, {36940, -1, -1, -1}, {36955, -1, -1, -1}, {36957, -1, -1, -1}, {36962, -1, -1, -1}, {36966, -1, -1, -1}, {36967, -1, -1, -1}, {36972, -1, -1, -1}, {36976, -1, -1, -1}, {36980, -1, -1, -1}, {36985, -1, -1, -1}, {36997, -1, -1, -1}, {37000, -1, -1, -1}, {37003, -1, -1, -1}, {37004, -1, -1, -1}, {37006, -1, -1, -1}, {37008, -1, -1, -1}, {37013, -1, -1, -1}, {37015, -1, -1, -1}, {37016, -1, -1, -1}, {37017, -1, -1, -1}, {37019, -1, -1, -1}, {37024, -1, -1, -1}, {37025, -1, -1, -1}, {37026, -1, -1, -1}, {37029, -1, -1, -1}, {37040, -1, -1, -1}, {37042, -1, -1, -1}, {37043, -1, -1, -1}, {37044, -1, -1, -1}, {37046, -1, -1, -1}, {37053, -1, -1, -1}, {37068, -1, -1, -1}, {37054, -1, -1, -1}, {37059, -1, -1, -1}, {37060, -1, -1, -1}, {37061, -1, -1, -1}, {37063, -1, -1, -1}, {37064, -1, -1, -1}, {37077, -1, -1, -1}, {37079, -1, -1, -1}, {37080, -1, -1, -1}, {37081, -1, -1, -1}, {37084, -1, -1, -1}, {37085, -1, -1, -1}, {37087, -1, -1, -1}, {37093, -1, -1, -1}, {37074, -1, -1, -1}, {37110, -1, -1, -1}, {37099, -1, -1, -1}, {37103, -1, -1, -1}, {37104, -1, -1, -1}, {37108, -1, -1, -1}, {37118, -1, -1, -1}, {37119, -1, -1, -1}, {37120, -1, -1, -1}, {37124, -1, -1, -1}, {37125, -1, -1, -1}, {37126, -1, -1, -1}, {37128, -1, -1, -1}, {37133, -1, -1, -1}, {37136, -1, -1, -1}, {37140, -1, -1, -1}, {37142, -1, -1, -1}, {37143, -1, -1, -1}, {37144, -1, -1, -1}, {37146, -1, -1, -1}, {37148, -1, -1, -1}, {37150, -1, -1, -1}, {37152, -1, -1, -1}, {37157, -1, -1, -1}, {37154, -1, -1, -1}, {37155, -1, -1, -1}, {37159, -1, -1, -1}, {37161, -1, -1, -1}, {37166, -1, -1, -1}, {37167, -1, -1, -1}, {37169, -1, -1, -1}, {37172, -1, -1, -1}, {37174, -1, -1, -1}, {37175, -1, -1, -1}, {37177, -1, -1, -1}, {37178, -1, -1, -1}, {37180, -1, -1, -1}, {37181, -1, -1, -1}, {37187, -1, -1, -1}, {37191, -1, -1, -1}, {37192, -1, -1, -1}, {37199, -1, -1, -1}, {37203, -1, -1, -1}, {37207, -1, -1, -1}, {37209, -1, -1, -1}, {37210, -1, -1, -1}, {37211, -1, -1, -1}, {37217, -1, -1, -1}, {37220, -1, -1, -1}, {37223, -1, -1, -1}, {37229, -1, -1, -1}, {37236, -1, -1, -1}, {37241, -1, -1, -1}, {37242, -1, -1, -1}, {37243, -1, -1, -1}, {37249, -1, -1, -1}, {37251, -1, -1, -1}, {37253, -1, -1, -1}, {37254, -1, -1, -1}, {37258, -1, -1, -1}, {37262, -1, -1, -1}, {37265, -1, -1, -1}, {37267, -1, -1, -1}, {37268, -1, -1, -1}, {37269, -1, -1, -1}, {37272, -1, -1, -1}, {37278, -1, -1, -1}, {37281, -1, -1, -1}, {37286, -1, -1, -1}, {37288, -1, -1, -1}, {37292, -1, -1, -1}, {37293, -1, -1, -1}, {37294, -1, -1, -1}, {37296, -1, -1, -1}, {37297, -1, -1, -1}, {37298, -1, -1, -1}, {37299, -1, -1, -1}, {37302, -1, -1, -1}, {37307, -1, -1, -1}, {37308, -1, -1, -1}, {37309, -1, -1, -1}, {37311, -1, -1, -1}, {37314, -1, -1, -1}, {37315, -1, -1, -1}, {37317, -1, -1, -1}, {37331, -1, -1, -1}, {37332, -1, -1, -1}, {37335, -1, -1, -1}, {37337, -1, -1, -1}, {37338, -1, -1, -1}, {37342, -1, -1, -1}, {37348, -1, -1, -1}, {37349, -1, -1, -1}, {37353, -1, -1, -1}, {37354, -1, -1, -1}, {37356, -1, -1, -1}, {37357, -1, -1, -1}, {37358, -1, -1, -1}, {37359, -1, -1, -1}, {37360, -1, -1, -1}, {37361, -1, -1, -1}, {37367, -1, -1, -1}, {37369, -1, -1, -1}, {37371, -1, -1, -1}, {37373, -1, -1, -1}, {37376, -1, -1, -1}, {37377, -1, -1, -1}, {37380, -1, -1, -1}, {37381, -1, -1, -1}, {37382, -1, -1, -1}, {37383, -1, -1, -1}, {37385, -1, -1, -1}, {37386, -1, -1, -1}, {37388, -1, -1, -1}, {37392, -1, -1, -1}, {37394, -1, -1, -1}, {37395, -1, -1, -1}, {37398, -1, -1, -1}, {37400, -1, -1, -1}, {37404, -1, -1, -1}, {37405, -1, -1, -1}, {37411, -1, -1, -1}, {37412, -1, -1, -1}, {37413, -1, -1, -1}, {37414, -1, -1, -1}, {37416, -1, -1, -1}, {37422, -1, -1, -1}, {37423, -1, -1, -1}, {37424, -1, -1, -1}, {37427, -1, -1, -1}, {37429, -1, -1, -1}, {37430, -1, -1, -1}, {37432, -1, -1, -1}, {37433, -1, -1, -1}, {37434, -1, -1, -1}, {37436, -1, -1, -1}, {37438, -1, -1, -1}, {37440, -1, -1, -1}, {37442, -1, -1, -1}, {37443, -1, -1, -1}, {37446, -1, -1, -1} },
+ {{37447, -1, -1, -1}, {37450, -1, -1, -1}, {37453, -1, -1, -1}, {37454, -1, -1, -1}, {37455, -1, -1, -1}, {37457, -1, -1, -1}, {37464, -1, -1, -1}, {37465, -1, -1, -1}, {37468, -1, -1, -1}, {37469, -1, -1, -1}, {37472, -1, -1, -1}, {37473, -1, -1, -1}, {37477, -1, -1, -1}, {37479, -1, -1, -1}, {37480, -1, -1, -1}, {37481, -1, -1, -1}, {37486, -1, -1, -1}, {37487, -1, -1, -1}, {37488, -1, -1, -1}, {37493, -1, -1, -1}, {37494, -1, -1, -1}, {37495, -1, -1, -1}, {37496, -1, -1, -1}, {37497, -1, -1, -1}, {37499, -1, -1, -1}, {37500, -1, -1, -1}, {37501, -1, -1, -1}, {37503, -1, -1, -1}, {37512, -1, -1, -1}, {37513, -1, -1, -1}, {37514, -1, -1, -1}, {37517, -1, -1, -1}, {37518, -1, -1, -1}, {37522, -1, -1, -1}, {37527, -1, -1, -1}, {37529, -1, -1, -1}, {37535, -1, -1, -1}, {37536, -1, -1, -1}, {37540, -1, -1, -1}, {37541, -1, -1, -1}, {37543, -1, -1, -1}, {37544, -1, -1, -1}, {37547, -1, -1, -1}, {37551, -1, -1, -1}, {37554, -1, -1, -1}, {37558, -1, -1, -1}, {37560, -1, -1, -1}, {37562, -1, -1, -1}, {37563, -1, -1, -1}, {37564, -1, -1, -1}, {37565, -1, -1, -1}, {37567, -1, -1, -1}, {37568, -1, -1, -1}, {37569, -1, -1, -1}, {37570, -1, -1, -1}, {37571, -1, -1, -1}, {37573, -1, -1, -1}, {37574, -1, -1, -1}, {37575, -1, -1, -1}, {37576, -1, -1, -1}, {37579, -1, -1, -1}, {37580, -1, -1, -1}, {37581, -1, -1, -1}, {37582, -1, -1, -1}, {37584, -1, -1, -1}, {37587, -1, -1, -1}, {37589, -1, -1, -1}, {37591, -1, -1, -1}, {37592, -1, -1, -1}, {37593, -1, -1, -1}, {37596, -1, -1, -1}, {37597, -1, -1, -1}, {37599, -1, -1, -1}, {37600, -1, -1, -1}, {37601, -1, -1, -1}, {37603, -1, -1, -1}, {37605, -1, -1, -1}, {37607, -1, -1, -1}, {37608, -1, -1, -1}, {37612, -1, -1, -1}, {37614, -1, -1, -1}, {37616, -1, -1, -1}, {37625, -1, -1, -1}, {37627, -1, -1, -1}, {37631, -1, -1, -1}, {37632, -1, -1, -1}, {37634, -1, -1, -1}, {37640, -1, -1, -1}, {37645, -1, -1, -1}, {37649, -1, -1, -1}, {37652, -1, -1, -1}, {37653, -1, -1, -1}, {37660, -1, -1, -1}, {37661, -1, -1, -1}, {37662, -1, -1, -1}, {37663, -1, -1, -1}, {37665, -1, -1, -1}, {37668, -1, -1, -1}, {37669, -1, -1, -1}, {37671, -1, -1, -1}, {37673, -1, -1, -1}, {37674, -1, -1, -1}, {37683, -1, -1, -1}, {37684, -1, -1, -1}, {37686, -1, -1, -1}, {37687, -1, -1, -1}, {37703, -1, -1, -1}, {37704, -1, -1, -1}, {37705, -1, -1, -1}, {37712, -1, -1, -1}, {37713, -1, -1, -1}, {37714, -1, -1, -1}, {37717, -1, -1, -1}, {37719, -1, -1, -1}, {37720, -1, -1, -1}, {37722, -1, -1, -1}, {37726, -1, -1, -1}, {37732, -1, -1, -1}, {37733, -1, -1, -1}, {37735, -1, -1, -1}, {37737, -1, -1, -1}, {37738, -1, -1, -1}, {37741, -1, -1, -1}, {37743, -1, -1, -1}, {37744, -1, -1, -1}, {37745, -1, -1, -1}, {37747, -1, -1, -1}, {37748, -1, -1, -1}, {37750, -1, -1, -1}, {37754, -1, -1, -1}, {37757, -1, -1, -1}, {37759, -1, -1, -1}, {37760, -1, -1, -1}, {37761, -1, -1, -1}, {37762, -1, -1, -1}, {37768, -1, -1, -1}, {37770, -1, -1, -1}, {37771, -1, -1, -1}, {37773, -1, -1, -1}, {37775, -1, -1, -1}, {37778, -1, -1, -1}, {37781, -1, -1, -1}, {37784, -1, -1, -1}, {37787, -1, -1, -1}, {37790, -1, -1, -1}, {37793, -1, -1, -1}, {37795, -1, -1, -1}, {37796, -1, -1, -1}, {37798, -1, -1, -1}, {37800, -1, -1, -1}, {37803, -1, -1, -1}, {37812, -1, -1, -1}, {37813, -1, -1, -1}, {37814, -1, -1, -1}, {37818, -1, -1, -1}, {37801, -1, -1, -1}, {37825, -1, -1, -1}, {37828, -1, -1, -1}, {37829, -1, -1, -1}, {37830, -1, -1, -1}, {37831, -1, -1, -1}, {37833, -1, -1, -1}, {37834, -1, -1, -1}, {37835, -1, -1, -1}, {37836, -1, -1, -1}, {37837, -1, -1, -1}, {37843, -1, -1, -1}, {37849, -1, -1, -1}, {37852, -1, -1, -1}, {37854, -1, -1, -1}, {37855, -1, -1, -1}, {37858, -1, -1, -1}, {37862, -1, -1, -1}, {37863, -1, -1, -1}, {37881, -1, -1, -1}, {37879, -1, -1, -1}, {37880, -1, -1, -1}, {37882, -1, -1, -1}, {37883, -1, -1, -1}, {37885, -1, -1, -1}, {37889, -1, -1, -1}, {37890, -1, -1, -1}, {37892, -1, -1, -1}, {37896, -1, -1, -1}, {37897, -1, -1, -1}, {37901, -1, -1, -1}, {37902, -1, -1, -1}, {37903, -1, -1, -1}, {37909, -1, -1, -1}, {37910, -1, -1, -1}, {37911, -1, -1, -1}, {37919, -1, -1, -1}, {37934, -1, -1, -1}, {37935, -1, -1, -1}, {37937, -1, -1, -1}, {37938, -1, -1, -1}, {37939, -1, -1, -1}, {37940, -1, -1, -1}, {37947, -1, -1, -1}, {37951, -1, -1, -1}, {37949, -1, -1, -1}, {37955, -1, -1, -1}, {37957, -1, -1, -1}, {37960, -1, -1, -1}, {37962, -1, -1, -1}, {37964, -1, -1, -1}, {37973, -1, -1, -1}, {37977, -1, -1, -1}, {37980, -1, -1, -1}, {37983, -1, -1, -1}, {37985, -1, -1, -1}, {37987, -1, -1, -1}, {37992, -1, -1, -1}, {37995, -1, -1, -1}, {37997, -1, -1, -1}, {37998, -1, -1, -1}, {37999, -1, -1, -1}, {38001, -1, -1, -1}, {38002, -1, -1, -1}, {38020, -1, -1, -1}, {38019, -1, -1, -1}, {38264, -1, -1, -1}, {38265, -1, -1, -1}, {38270, -1, -1, -1}, {38276, -1, -1, -1}, {38280, -1, -1, -1}, {38284, -1, -1, -1}, {38285, -1, -1, -1}, {38286, -1, -1, -1}, {38301, -1, -1, -1}, {38302, -1, -1, -1}, {38303, -1, -1, -1}, {38305, -1, -1, -1}, {38310, -1, -1, -1}, {38313, -1, -1, -1}, {38315, -1, -1, -1}, {38316, -1, -1, -1}, {38324, -1, -1, -1}, {38326, -1, -1, -1}, {38330, -1, -1, -1}, {38333, -1, -1, -1}, {38335, -1, -1, -1}, {38342, -1, -1, -1}, {38344, -1, -1, -1}, {38345, -1, -1, -1}, {38347, -1, -1, -1}, {38352, -1, -1, -1}, {38353, -1, -1, -1}, {38354, -1, -1, -1}, {38355, -1, -1, -1}, {38361, -1, -1, -1}, {38362, -1, -1, -1}, {38365, -1, -1, -1}, {38366, -1, -1, -1}, {38367, -1, -1, -1}, {38368, -1, -1, -1} },
+ {{38372, -1, -1, -1}, {38374, -1, -1, -1}, {38429, -1, -1, -1}, {38430, -1, -1, -1}, {38434, -1, -1, -1}, {38436, -1, -1, -1}, {38437, -1, -1, -1}, {38438, -1, -1, -1}, {38444, -1, -1, -1}, {38449, -1, -1, -1}, {38451, -1, -1, -1}, {38455, -1, -1, -1}, {38456, -1, -1, -1}, {38457, -1, -1, -1}, {38458, -1, -1, -1}, {38460, -1, -1, -1}, {38461, -1, -1, -1}, {38465, -1, -1, -1}, {38482, -1, -1, -1}, {38484, -1, -1, -1}, {38486, -1, -1, -1}, {38487, -1, -1, -1}, {38488, -1, -1, -1}, {38497, -1, -1, -1}, {38510, -1, -1, -1}, {38516, -1, -1, -1}, {38523, -1, -1, -1}, {38524, -1, -1, -1}, {38526, -1, -1, -1}, {38527, -1, -1, -1}, {38529, -1, -1, -1}, {38530, -1, -1, -1}, {38531, -1, -1, -1}, {38532, -1, -1, -1}, {38537, -1, -1, -1}, {38545, -1, -1, -1}, {38550, -1, -1, -1}, {38554, -1, -1, -1}, {38557, -1, -1, -1}, {38559, -1, -1, -1}, {38564, -1, -1, -1}, {38565, -1, -1, -1}, {38566, -1, -1, -1}, {38569, -1, -1, -1}, {38574, -1, -1, -1}, {38575, -1, -1, -1}, {38579, -1, -1, -1}, {38586, -1, -1, -1}, {38602, -1, -1, -1}, {38610, -1, -1, -1}, {23986, -1, -1, -1}, {38616, -1, -1, -1}, {38618, -1, -1, -1}, {38621, -1, -1, -1}, {38622, -1, -1, -1}, {38623, -1, -1, -1}, {38633, -1, -1, -1}, {38639, -1, -1, -1}, {38641, -1, -1, -1}, {38650, -1, -1, -1}, {38658, -1, -1, -1}, {38659, -1, -1, -1}, {38661, -1, -1, -1}, {38665, -1, -1, -1}, {38682, -1, -1, -1}, {38683, -1, -1, -1}, {38685, -1, -1, -1}, {38689, -1, -1, -1}, {38690, -1, -1, -1}, {38691, -1, -1, -1}, {38696, -1, -1, -1}, {38705, -1, -1, -1}, {38707, -1, -1, -1}, {38721, -1, -1, -1}, {38723, -1, -1, -1}, {38730, -1, -1, -1}, {38734, -1, -1, -1}, {38735, -1, -1, -1}, {38741, -1, -1, -1}, {38743, -1, -1, -1}, {38744, -1, -1, -1}, {38746, -1, -1, -1}, {38747, -1, -1, -1}, {38755, -1, -1, -1}, {38759, -1, -1, -1}, {38762, -1, -1, -1}, {38766, -1, -1, -1}, {38771, -1, -1, -1}, {38774, -1, -1, -1}, {38775, -1, -1, -1}, {38776, -1, -1, -1}, {38779, -1, -1, -1}, {38781, -1, -1, -1}, {38783, -1, -1, -1}, {38784, -1, -1, -1}, {38793, -1, -1, -1}, {38805, -1, -1, -1}, {38806, -1, -1, -1}, {38807, -1, -1, -1}, {38809, -1, -1, -1}, {38810, -1, -1, -1}, {38814, -1, -1, -1}, {38815, -1, -1, -1}, {38818, -1, -1, -1}, {38828, -1, -1, -1}, {38830, -1, -1, -1}, {38833, -1, -1, -1}, {38834, -1, -1, -1}, {38837, -1, -1, -1}, {38838, -1, -1, -1}, {38840, -1, -1, -1}, {38841, -1, -1, -1}, {38842, -1, -1, -1}, {38844, -1, -1, -1}, {38846, -1, -1, -1}, {38847, -1, -1, -1}, {38849, -1, -1, -1}, {38852, -1, -1, -1}, {38853, -1, -1, -1}, {38855, -1, -1, -1}, {38857, -1, -1, -1}, {38858, -1, -1, -1}, {38860, -1, -1, -1}, {38861, -1, -1, -1}, {38862, -1, -1, -1}, {38864, -1, -1, -1}, {38865, -1, -1, -1}, {38868, -1, -1, -1}, {38871, -1, -1, -1}, {38872, -1, -1, -1}, {38873, -1, -1, -1}, {38877, -1, -1, -1}, {38878, -1, -1, -1}, {38880, -1, -1, -1}, {38875, -1, -1, -1}, {38881, -1, -1, -1}, {38884, -1, -1, -1}, {38895, -1, -1, -1}, {38897, -1, -1, -1}, {38900, -1, -1, -1}, {38903, -1, -1, -1}, {38904, -1, -1, -1}, {38906, -1, -1, -1}, {38919, -1, -1, -1}, {38922, -1, -1, -1}, {38937, -1, -1, -1}, {38925, -1, -1, -1}, {38926, -1, -1, -1}, {38932, -1, -1, -1}, {38934, -1, -1, -1}, {38940, -1, -1, -1}, {38942, -1, -1, -1}, {38944, -1, -1, -1}, {38947, -1, -1, -1}, {38950, -1, -1, -1}, {38955, -1, -1, -1}, {38958, -1, -1, -1}, {38959, -1, -1, -1}, {38960, -1, -1, -1}, {38962, -1, -1, -1}, {38963, -1, -1, -1}, {38965, -1, -1, -1}, {38949, -1, -1, -1}, {38974, -1, -1, -1}, {38980, -1, -1, -1}, {38983, -1, -1, -1}, {38986, -1, -1, -1}, {38993, -1, -1, -1}, {38994, -1, -1, -1}, {38995, -1, -1, -1}, {38998, -1, -1, -1}, {38999, -1, -1, -1}, {39001, -1, -1, -1}, {39002, -1, -1, -1}, {39010, -1, -1, -1}, {39011, -1, -1, -1}, {39013, -1, -1, -1}, {39014, -1, -1, -1}, {39018, -1, -1, -1}, {39020, -1, -1, -1}, {39083, -1, -1, -1}, {39085, -1, -1, -1}, {39086, -1, -1, -1}, {39088, -1, -1, -1}, {39092, -1, -1, -1}, {39095, -1, -1, -1}, {39096, -1, -1, -1}, {39098, -1, -1, -1}, {39099, -1, -1, -1}, {39103, -1, -1, -1}, {39106, -1, -1, -1}, {39109, -1, -1, -1}, {39112, -1, -1, -1}, {39116, -1, -1, -1}, {39137, -1, -1, -1}, {39139, -1, -1, -1}, {39141, -1, -1, -1}, {39142, -1, -1, -1}, {39143, -1, -1, -1}, {39146, -1, -1, -1}, {39155, -1, -1, -1}, {39158, -1, -1, -1}, {39170, -1, -1, -1}, {39175, -1, -1, -1}, {39176, -1, -1, -1}, {39185, -1, -1, -1}, {39189, -1, -1, -1}, {39190, -1, -1, -1}, {39191, -1, -1, -1}, {39194, -1, -1, -1}, {39195, -1, -1, -1}, {39196, -1, -1, -1}, {39199, -1, -1, -1}, {39202, -1, -1, -1}, {39206, -1, -1, -1}, {39207, -1, -1, -1}, {39211, -1, -1, -1}, {39217, -1, -1, -1}, {39218, -1, -1, -1}, {39219, -1, -1, -1}, {39220, -1, -1, -1}, {39221, -1, -1, -1}, {39225, -1, -1, -1}, {39226, -1, -1, -1}, {39227, -1, -1, -1}, {39228, -1, -1, -1}, {39232, -1, -1, -1}, {39233, -1, -1, -1}, {39238, -1, -1, -1}, {39239, -1, -1, -1}, {39240, -1, -1, -1}, {39245, -1, -1, -1}, {39246, -1, -1, -1}, {39252, -1, -1, -1}, {39256, -1, -1, -1}, {39257, -1, -1, -1}, {39259, -1, -1, -1}, {39260, -1, -1, -1}, {39262, -1, -1, -1}, {39263, -1, -1, -1}, {39264, -1, -1, -1}, {39323, -1, -1, -1}, {39325, -1, -1, -1}, {39327, -1, -1, -1}, {39334, -1, -1, -1}, {39344, -1, -1, -1}, {39345, -1, -1, -1}, {39346, -1, -1, -1}, {39349, -1, -1, -1}, {39353, -1, -1, -1}, {39354, -1, -1, -1}, {39357, -1, -1, -1}, {39359, -1, -1, -1}, {39363, -1, -1, -1}, {39369, -1, -1, -1}, {39379, -1, -1, -1} },
+ {{39380, -1, -1, -1}, {39385, -1, -1, -1}, {39386, -1, -1, -1}, {39388, -1, -1, -1}, {39390, -1, -1, -1}, {39399, -1, -1, -1}, {39402, -1, -1, -1}, {39403, -1, -1, -1}, {39404, -1, -1, -1}, {39408, -1, -1, -1}, {39412, -1, -1, -1}, {39413, -1, -1, -1}, {39417, -1, -1, -1}, {39421, -1, -1, -1}, {39422, -1, -1, -1}, {39426, -1, -1, -1}, {39427, -1, -1, -1}, {39428, -1, -1, -1}, {39435, -1, -1, -1}, {39436, -1, -1, -1}, {39440, -1, -1, -1}, {39441, -1, -1, -1}, {39446, -1, -1, -1}, {39454, -1, -1, -1}, {39456, -1, -1, -1}, {39458, -1, -1, -1}, {39459, -1, -1, -1}, {39460, -1, -1, -1}, {39463, -1, -1, -1}, {39469, -1, -1, -1}, {39470, -1, -1, -1}, {39475, -1, -1, -1}, {39477, -1, -1, -1}, {39478, -1, -1, -1}, {39480, -1, -1, -1}, {39495, -1, -1, -1}, {39489, -1, -1, -1}, {39492, -1, -1, -1}, {39498, -1, -1, -1}, {39499, -1, -1, -1}, {39500, -1, -1, -1}, {39502, -1, -1, -1}, {39505, -1, -1, -1}, {39508, -1, -1, -1}, {39510, -1, -1, -1}, {39517, -1, -1, -1}, {39594, -1, -1, -1}, {39596, -1, -1, -1}, {39598, -1, -1, -1}, {39599, -1, -1, -1}, {39602, -1, -1, -1}, {39604, -1, -1, -1}, {39605, -1, -1, -1}, {39606, -1, -1, -1}, {39609, -1, -1, -1}, {39611, -1, -1, -1}, {39614, -1, -1, -1}, {39615, -1, -1, -1}, {39617, -1, -1, -1}, {39619, -1, -1, -1}, {39622, -1, -1, -1}, {39624, -1, -1, -1}, {39630, -1, -1, -1}, {39632, -1, -1, -1}, {39634, -1, -1, -1}, {39637, -1, -1, -1}, {39638, -1, -1, -1}, {39639, -1, -1, -1}, {39643, -1, -1, -1}, {39644, -1, -1, -1}, {39648, -1, -1, -1}, {39652, -1, -1, -1}, {39653, -1, -1, -1}, {39655, -1, -1, -1}, {39657, -1, -1, -1}, {39660, -1, -1, -1}, {39666, -1, -1, -1}, {39667, -1, -1, -1}, {39669, -1, -1, -1}, {39673, -1, -1, -1}, {39674, -1, -1, -1}, {39677, -1, -1, -1}, {39679, -1, -1, -1}, {39680, -1, -1, -1}, {39681, -1, -1, -1}, {39682, -1, -1, -1}, {39683, -1, -1, -1}, {39684, -1, -1, -1}, {39685, -1, -1, -1}, {39688, -1, -1, -1}, {39689, -1, -1, -1}, {39691, -1, -1, -1}, {39692, -1, -1, -1}, {39693, -1, -1, -1}, {39694, -1, -1, -1}, {39696, -1, -1, -1}, {39698, -1, -1, -1}, {39702, -1, -1, -1}, {39705, -1, -1, -1}, {39707, -1, -1, -1}, {39708, -1, -1, -1}, {39712, -1, -1, -1}, {39718, -1, -1, -1}, {39723, -1, -1, -1}, {39725, -1, -1, -1}, {39731, -1, -1, -1}, {39732, -1, -1, -1}, {39733, -1, -1, -1}, {39735, -1, -1, -1}, {39737, -1, -1, -1}, {39738, -1, -1, -1}, {39741, -1, -1, -1}, {39752, -1, -1, -1}, {39755, -1, -1, -1}, {39756, -1, -1, -1}, {39765, -1, -1, -1}, {39766, -1, -1, -1}, {39767, -1, -1, -1}, {39771, -1, -1, -1}, {39774, -1, -1, -1}, {39777, -1, -1, -1}, {39779, -1, -1, -1}, {39781, -1, -1, -1}, {39782, -1, -1, -1}, {39784, -1, -1, -1}, {39786, -1, -1, -1}, {39787, -1, -1, -1}, {39788, -1, -1, -1}, {39789, -1, -1, -1}, {39790, -1, -1, -1}, {39795, -1, -1, -1}, {39797, -1, -1, -1}, {39799, -1, -1, -1}, {39800, -1, -1, -1}, {39801, -1, -1, -1}, {39807, -1, -1, -1}, {39808, -1, -1, -1}, {39812, -1, -1, -1}, {39813, -1, -1, -1}, {39814, -1, -1, -1}, {39815, -1, -1, -1}, {39817, -1, -1, -1}, {39818, -1, -1, -1}, {39819, -1, -1, -1}, {39821, -1, -1, -1}, {39823, -1, -1, -1}, {39824, -1, -1, -1}, {39828, -1, -1, -1}, {39834, -1, -1, -1}, {39837, -1, -1, -1}, {39838, -1, -1, -1}, {39846, -1, -1, -1}, {39847, -1, -1, -1}, {39849, -1, -1, -1}, {39852, -1, -1, -1}, {39856, -1, -1, -1}, {39857, -1, -1, -1}, {39858, -1, -1, -1}, {39863, -1, -1, -1}, {39864, -1, -1, -1}, {39867, -1, -1, -1}, {39868, -1, -1, -1}, {39870, -1, -1, -1}, {39871, -1, -1, -1}, {39873, -1, -1, -1}, {39879, -1, -1, -1}, {39880, -1, -1, -1}, {39886, -1, -1, -1}, {39888, -1, -1, -1}, {39895, -1, -1, -1}, {39896, -1, -1, -1}, {39901, -1, -1, -1}, {39903, -1, -1, -1}, {39909, -1, -1, -1}, {39911, -1, -1, -1}, {39914, -1, -1, -1}, {39915, -1, -1, -1}, {39919, -1, -1, -1}, {39923, -1, -1, -1}, {39927, -1, -1, -1}, {39928, -1, -1, -1}, {39929, -1, -1, -1}, {39930, -1, -1, -1}, {39933, -1, -1, -1}, {39935, -1, -1, -1}, {39936, -1, -1, -1}, {39938, -1, -1, -1}, {39947, -1, -1, -1}, {39951, -1, -1, -1}, {39953, -1, -1, -1}, {39958, -1, -1, -1}, {39960, -1, -1, -1}, {39961, -1, -1, -1}, {39962, -1, -1, -1}, {39964, -1, -1, -1}, {39966, -1, -1, -1}, {39970, -1, -1, -1}, {39971, -1, -1, -1}, {39974, -1, -1, -1}, {39975, -1, -1, -1}, {39976, -1, -1, -1}, {39977, -1, -1, -1}, {39978, -1, -1, -1}, {39985, -1, -1, -1}, {39989, -1, -1, -1}, {39990, -1, -1, -1}, {39991, -1, -1, -1}, {39997, -1, -1, -1}, {40001, -1, -1, -1}, {40003, -1, -1, -1}, {40004, -1, -1, -1}, {40005, -1, -1, -1}, {40009, -1, -1, -1}, {40010, -1, -1, -1}, {40014, -1, -1, -1}, {40015, -1, -1, -1}, {40016, -1, -1, -1}, {40019, -1, -1, -1}, {40020, -1, -1, -1}, {40022, -1, -1, -1}, {40024, -1, -1, -1}, {40027, -1, -1, -1}, {40029, -1, -1, -1}, {40030, -1, -1, -1}, {40031, -1, -1, -1}, {40035, -1, -1, -1}, {40041, -1, -1, -1}, {40042, -1, -1, -1}, {40028, -1, -1, -1}, {40043, -1, -1, -1}, {40040, -1, -1, -1}, {40046, -1, -1, -1}, {40048, -1, -1, -1}, {40050, -1, -1, -1}, {40053, -1, -1, -1}, {40055, -1, -1, -1}, {40059, -1, -1, -1}, {40166, -1, -1, -1}, {40178, -1, -1, -1}, {40183, -1, -1, -1}, {40185, -1, -1, -1}, {40203, -1, -1, -1}, {40194, -1, -1, -1}, {40209, -1, -1, -1}, {40215, -1, -1, -1}, {40216, -1, -1, -1}, {40220, -1, -1, -1}, {40221, -1, -1, -1}, {40222, -1, -1, -1}, {40239, -1, -1, -1}, {40240, -1, -1, -1}, {40242, -1, -1, -1}, {40243, -1, -1, -1}, {40244, -1, -1, -1}, {40250, -1, -1, -1}, {40252, -1, -1, -1} },
+ {{40261, -1, -1, -1}, {40253, -1, -1, -1}, {40258, -1, -1, -1}, {40259, -1, -1, -1}, {40263, -1, -1, -1}, {40266, -1, -1, -1}, {40275, -1, -1, -1}, {40276, -1, -1, -1}, {40287, -1, -1, -1}, {40291, -1, -1, -1}, {40290, -1, -1, -1}, {40293, -1, -1, -1}, {40297, -1, -1, -1}, {40298, -1, -1, -1}, {40299, -1, -1, -1}, {40304, -1, -1, -1}, {40310, -1, -1, -1}, {40311, -1, -1, -1}, {40315, -1, -1, -1}, {40316, -1, -1, -1}, {40318, -1, -1, -1}, {40323, -1, -1, -1}, {40324, -1, -1, -1}, {40326, -1, -1, -1}, {40330, -1, -1, -1}, {40333, -1, -1, -1}, {40334, -1, -1, -1}, {40338, -1, -1, -1}, {40339, -1, -1, -1}, {40341, -1, -1, -1}, {40342, -1, -1, -1}, {40343, -1, -1, -1}, {40344, -1, -1, -1}, {40353, -1, -1, -1}, {40362, -1, -1, -1}, {40364, -1, -1, -1}, {40366, -1, -1, -1}, {40369, -1, -1, -1}, {40373, -1, -1, -1}, {40377, -1, -1, -1}, {40380, -1, -1, -1}, {40383, -1, -1, -1}, {40387, -1, -1, -1}, {40391, -1, -1, -1}, {40393, -1, -1, -1}, {40394, -1, -1, -1}, {40404, -1, -1, -1}, {40405, -1, -1, -1}, {40406, -1, -1, -1}, {40407, -1, -1, -1}, {40410, -1, -1, -1}, {40414, -1, -1, -1}, {40415, -1, -1, -1}, {40416, -1, -1, -1}, {40421, -1, -1, -1}, {40423, -1, -1, -1}, {40425, -1, -1, -1}, {40427, -1, -1, -1}, {40430, -1, -1, -1}, {40432, -1, -1, -1}, {40435, -1, -1, -1}, {40436, -1, -1, -1}, {40446, -1, -1, -1}, {40458, -1, -1, -1}, {40450, -1, -1, -1}, {40455, -1, -1, -1}, {40462, -1, -1, -1}, {40464, -1, -1, -1}, {40465, -1, -1, -1}, {40466, -1, -1, -1}, {40469, -1, -1, -1}, {40470, -1, -1, -1}, {40473, -1, -1, -1}, {40476, -1, -1, -1}, {40477, -1, -1, -1}, {40570, -1, -1, -1}, {40571, -1, -1, -1}, {40572, -1, -1, -1}, {40576, -1, -1, -1}, {40578, -1, -1, -1}, {40579, -1, -1, -1}, {40580, -1, -1, -1}, {40581, -1, -1, -1}, {40583, -1, -1, -1}, {40590, -1, -1, -1}, {40591, -1, -1, -1}, {40598, -1, -1, -1}, {40600, -1, -1, -1}, {40603, -1, -1, -1}, {40606, -1, -1, -1}, {40612, -1, -1, -1}, {40616, -1, -1, -1}, {40620, -1, -1, -1}, {40622, -1, -1, -1}, {40623, -1, -1, -1}, {40624, -1, -1, -1}, {40627, -1, -1, -1}, {40628, -1, -1, -1}, {40629, -1, -1, -1}, {40646, -1, -1, -1}, {40648, -1, -1, -1}, {40651, -1, -1, -1}, {40661, -1, -1, -1}, {40671, -1, -1, -1}, {40676, -1, -1, -1}, {40679, -1, -1, -1}, {40684, -1, -1, -1}, {40685, -1, -1, -1}, {40686, -1, -1, -1}, {40688, -1, -1, -1}, {40689, -1, -1, -1}, {40690, -1, -1, -1}, {40693, -1, -1, -1}, {40696, -1, -1, -1}, {40703, -1, -1, -1}, {40706, -1, -1, -1}, {40707, -1, -1, -1}, {40713, -1, -1, -1}, {40719, -1, -1, -1}, {40720, -1, -1, -1}, {40721, -1, -1, -1}, {40722, -1, -1, -1}, {40724, -1, -1, -1}, {40726, -1, -1, -1}, {40727, -1, -1, -1}, {40729, -1, -1, -1}, {40730, -1, -1, -1}, {40731, -1, -1, -1}, {40735, -1, -1, -1}, {40738, -1, -1, -1}, {40742, -1, -1, -1}, {40746, -1, -1, -1}, {40747, -1, -1, -1}, {40751, -1, -1, -1}, {40753, -1, -1, -1}, {40754, -1, -1, -1}, {40756, -1, -1, -1}, {40759, -1, -1, -1}, {40761, -1, -1, -1}, {40762, -1, -1, -1}, {40764, -1, -1, -1}, {40765, -1, -1, -1}, {40767, -1, -1, -1}, {40769, -1, -1, -1}, {40771, -1, -1, -1}, {40772, -1, -1, -1}, {40773, -1, -1, -1}, {40774, -1, -1, -1}, {40775, -1, -1, -1}, {40787, -1, -1, -1}, {40789, -1, -1, -1}, {40790, -1, -1, -1}, {40791, -1, -1, -1}, {40792, -1, -1, -1}, {40794, -1, -1, -1}, {40797, -1, -1, -1}, {40798, -1, -1, -1}, {40808, -1, -1, -1}, {40809, -1, -1, -1}, {40813, -1, -1, -1}, {40814, -1, -1, -1}, {40815, -1, -1, -1}, {40816, -1, -1, -1}, {40817, -1, -1, -1}, {40819, -1, -1, -1}, {40821, -1, -1, -1}, {40826, -1, -1, -1}, {40829, -1, -1, -1}, {40847, -1, -1, -1}, {40848, -1, -1, -1}, {40849, -1, -1, -1}, {40850, -1, -1, -1}, {40852, -1, -1, -1}, {40854, -1, -1, -1}, {40855, -1, -1, -1}, {40862, -1, -1, -1}, {40865, -1, -1, -1}, {40866, -1, -1, -1}, {40867, -1, -1, -1}, {40869, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ }
+};
+
+static const pdfi_cid_decoding_t korea1_unicode = {
+ "Korea1", "Unicode",
+ 71,
+ 4,
+ {
+ {{-1, -1, -1, -1}, {32, -1, -1, -1}, {33, -1, -1, -1}, {34, -1, -1, -1}, {35, -1, -1, -1}, {36, -1, -1, -1}, {37, -1, -1, -1}, {38, -1, -1, -1}, {39, -1, -1, -1}, {40, -1, -1, -1}, {41, -1, -1, -1}, {42, -1, -1, -1}, {43, -1, -1, -1}, {44, -1, -1, -1}, {45, -1, -1, -1}, {46, -1, -1, -1}, {47, -1, -1, -1}, {48, -1, -1, -1}, {49, -1, -1, -1}, {50, -1, -1, -1}, {51, -1, -1, -1}, {52, -1, -1, -1}, {53, -1, -1, -1}, {54, -1, -1, -1}, {55, -1, -1, -1}, {56, -1, -1, -1}, {57, -1, -1, -1}, {58, -1, -1, -1}, {59, -1, -1, -1}, {60, -1, -1, -1}, {61, -1, -1, -1}, {62, -1, -1, -1}, {63, -1, -1, -1}, {64, -1, -1, -1}, {65, -1, -1, -1}, {66, -1, -1, -1}, {67, -1, -1, -1}, {68, -1, -1, -1}, {69, -1, -1, -1}, {70, -1, -1, -1}, {71, -1, -1, -1}, {72, -1, -1, -1}, {73, -1, -1, -1}, {74, -1, -1, -1}, {75, -1, -1, -1}, {76, -1, -1, -1}, {77, -1, -1, -1}, {78, -1, -1, -1}, {79, -1, -1, -1}, {80, -1, -1, -1}, {81, -1, -1, -1}, {82, -1, -1, -1}, {83, -1, -1, -1}, {84, -1, -1, -1}, {85, -1, -1, -1}, {86, -1, -1, -1}, {87, -1, -1, -1}, {88, -1, -1, -1}, {89, -1, -1, -1}, {90, -1, -1, -1}, {91, -1, -1, -1}, {92, -1, -1, -1}, {93, -1, -1, -1}, {94, -1, -1, -1}, {95, -1, -1, -1}, {96, -1, -1, -1}, {97, -1, -1, -1}, {98, -1, -1, -1}, {99, -1, -1, -1}, {100, -1, -1, -1}, {101, -1, -1, -1}, {102, -1, -1, -1}, {103, -1, -1, -1}, {104, -1, -1, -1}, {105, -1, -1, -1}, {106, -1, -1, -1}, {107, -1, -1, -1}, {108, -1, -1, -1}, {109, -1, -1, -1}, {110, -1, -1, -1}, {111, -1, -1, -1}, {112, -1, -1, -1}, {113, -1, -1, -1}, {114, -1, -1, -1}, {115, -1, -1, -1}, {116, -1, -1, -1}, {117, -1, -1, -1}, {118, -1, -1, -1}, {119, -1, -1, -1}, {120, -1, -1, -1}, {121, -1, -1, -1}, {122, -1, -1, -1}, {123, -1, -1, -1}, {124, -1, -1, -1}, {125, -1, -1, -1}, {126, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12644, 12288, -1, -1}, {12289, -1, -1, -1}, {12290, -1, -1, -1}, {12539, -1, -1, -1}, {8229, -1, -1, -1}, {8230, 8943, -1, -1}, {168, -1, -1, -1}, {12291, -1, -1, -1}, {8211, -1, -1, -1}, {8212, -1, -1, -1}, {8214, -1, -1, -1}, {65340, -1, -1, -1}, {65374, -1, -1, -1}, {8216, -1, -1, -1}, {8217, -1, -1, -1}, {8220, -1, -1, -1}, {8221, -1, -1, -1}, {12308, -1, -1, -1}, {12309, -1, -1, -1}, {12296, -1, -1, -1}, {12297, -1, -1, -1}, {12298, -1, -1, -1}, {12299, -1, -1, -1}, {12300, -1, -1, -1}, {12301, -1, -1, -1}, {12302, -1, -1, -1}, {12303, -1, -1, -1}, {12304, -1, -1, -1}, {12305, -1, -1, -1}, {177, -1, -1, -1}, {215, -1, -1, -1}, {247, -1, -1, -1}, {8800, -1, -1, -1}, {8804, -1, -1, -1}, {8805, -1, -1, -1}, {8734, -1, -1, -1}, {8756, -1, -1, -1}, {176, -1, -1, -1}, {8242, -1, -1, -1}, {8243, -1, -1, -1}, {8451, -1, -1, -1}, {8491, -1, -1, -1}, {65504, -1, -1, -1}, {65505, -1, -1, -1}, {65509, -1, -1, -1}, {9794, -1, -1, -1}, {9792, -1, -1, -1}, {8736, -1, -1, -1}, {8869, -1, -1, -1}, {8978, -1, -1, -1}, {8706, -1, -1, -1}, {8711, -1, -1, -1}, {8801, -1, -1, -1}, {8786, -1, -1, -1}, {167, -1, -1, -1}, {8251, -1, -1, -1}, {9734, -1, -1, -1}, {9733, -1, -1, -1}, {9675, -1, -1, -1}, {9679, -1, -1, -1}, {9678, -1, -1, -1}, {9671, -1, -1, -1}, {9670, -1, -1, -1}, {9633, -1, -1, -1}, {9632, -1, -1, -1}, {9651, -1, -1, -1}, {9650, -1, -1, -1}, {9661, -1, -1, -1}, {9660, -1, -1, -1}, {8594, -1, -1, -1}, {8592, -1, -1, -1}, {8593, -1, -1, -1}, {8595, -1, -1, -1}, {8596, -1, -1, -1}, {12307, -1, -1, -1}, {171, -1, -1, -1}, {187, -1, -1, -1}, {8730, -1, -1, -1}, {8765, -1, -1, -1}, {8733, -1, -1, -1}, {8757, -1, -1, -1}, {8747, -1, -1, -1}, {8748, -1, -1, -1}, {8712, -1, -1, -1}, {8715, -1, -1, -1}, {8838, -1, -1, -1}, {8839, -1, -1, -1}, {8834, -1, -1, -1}, {8835, -1, -1, -1}, {8746, -1, -1, -1}, {8745, -1, -1, -1}, {8743, -1, -1, -1}, {8744, -1, -1, -1}, {65506, -1, -1, -1}, {8658, -1, -1, -1}, {8660, -1, -1, -1}, {8704, -1, -1, -1}, {8707, -1, -1, -1}, {180, -1, -1, -1}, {732, -1, -1, -1}, {711, -1, -1, -1}, {728, -1, -1, -1}, {733, -1, -1, -1}, {730, -1, -1, -1}, {729, -1, -1, -1}, {184, -1, -1, -1}, {731, -1, -1, -1}, {161, -1, -1, -1}, {191, -1, -1, -1}, {8758, -1, -1, -1}, {8750, -1, -1, -1}, {8721, -1, -1, -1}, {8719, -1, -1, -1}, {164, -1, -1, -1}, {8457, -1, -1, -1}, {8240, -1, -1, -1}, {9665, -1, -1, -1}, {9664, -1, -1, -1}, {9655, -1, -1, -1}, {9654, -1, -1, -1}, {9828, -1, -1, -1}, {9824, -1, -1, -1}, {9825, -1, -1, -1}, {9829, -1, -1, -1}, {9831, -1, -1, -1}, {9827, -1, -1, -1}, {9673, -1, -1, -1}, {9672, -1, -1, -1}, {9635, -1, -1, -1}, {9680, -1, -1, -1}, {9681, -1, -1, -1}, {9618, -1, -1, -1}, {9636, -1, -1, -1}, {9637, -1, -1, -1}, {9640, -1, -1, -1}, {9639, -1, -1, -1}, {9638, -1, -1, -1}, {9641, -1, -1, -1}, {9832, -1, -1, -1}, {9743, -1, -1, -1}, {9742, -1, -1, -1}, {9756, -1, -1, -1}, {9758, -1, -1, -1}, {182, -1, -1, -1}, {8224, -1, -1, -1}, {8225, -1, -1, -1}, {8597, -1, -1, -1}, {8599, -1, -1, -1}, {8601, -1, -1, -1}, {8598, -1, -1, -1}, {8600, -1, -1, -1}, {9837, -1, -1, -1}, {9833, -1, -1, -1}, {9834, -1, -1, -1}, {9836, -1, -1, -1} },
+ {{12927, -1, -1, -1}, {12828, -1, -1, -1}, {8470, -1, -1, -1}, {13255, -1, -1, -1}, {8482, -1, -1, -1}, {13250, -1, -1, -1}, {13272, -1, -1, -1}, {8481, -1, -1, -1}, {65281, -1, -1, -1}, {65282, -1, -1, -1}, {65283, -1, -1, -1}, {65284, -1, -1, -1}, {65285, -1, -1, -1}, {65286, -1, -1, -1}, {65287, -1, -1, -1}, {65288, -1, -1, -1}, {65289, -1, -1, -1}, {65290, -1, -1, -1}, {65291, -1, -1, -1}, {65292, -1, -1, -1}, {65293, -1, -1, -1}, {65294, -1, -1, -1}, {65295, -1, -1, -1}, {65296, -1, -1, -1}, {65297, -1, -1, -1}, {65298, -1, -1, -1}, {65299, -1, -1, -1}, {65300, -1, -1, -1}, {65301, -1, -1, -1}, {65302, -1, -1, -1}, {65303, -1, -1, -1}, {65304, -1, -1, -1}, {65305, -1, -1, -1}, {65306, -1, -1, -1}, {65307, -1, -1, -1}, {65308, -1, -1, -1}, {65309, -1, -1, -1}, {65310, -1, -1, -1}, {65311, -1, -1, -1}, {65312, -1, -1, -1}, {65313, -1, -1, -1}, {65314, -1, -1, -1}, {65315, -1, -1, -1}, {65316, -1, -1, -1}, {65317, -1, -1, -1}, {65318, -1, -1, -1}, {65319, -1, -1, -1}, {65320, -1, -1, -1}, {65321, -1, -1, -1}, {65322, -1, -1, -1}, {65323, -1, -1, -1}, {65324, -1, -1, -1}, {65325, -1, -1, -1}, {65326, -1, -1, -1}, {65327, -1, -1, -1}, {65328, -1, -1, -1}, {65329, -1, -1, -1}, {65330, -1, -1, -1}, {65331, -1, -1, -1}, {65332, -1, -1, -1}, {65333, -1, -1, -1}, {65334, -1, -1, -1}, {65335, -1, -1, -1}, {65336, -1, -1, -1}, {65337, -1, -1, -1}, {65338, -1, -1, -1}, {65339, -1, -1, -1}, {65510, -1, -1, -1}, {65341, -1, -1, -1}, {65342, -1, -1, -1}, {65343, -1, -1, -1}, {65344, -1, -1, -1}, {65345, -1, -1, -1}, {65346, -1, -1, -1}, {65347, -1, -1, -1}, {65348, -1, -1, -1}, {65349, -1, -1, -1}, {65350, -1, -1, -1}, {65351, -1, -1, -1}, {65352, -1, -1, -1}, {65353, -1, -1, -1}, {65354, -1, -1, -1}, {65355, -1, -1, -1}, {65356, -1, -1, -1}, {65357, -1, -1, -1}, {65358, -1, -1, -1}, {65359, -1, -1, -1}, {65360, -1, -1, -1}, {65361, -1, -1, -1}, {65362, -1, -1, -1}, {65363, -1, -1, -1}, {65364, -1, -1, -1}, {65365, -1, -1, -1}, {65366, -1, -1, -1}, {65367, -1, -1, -1}, {65368, -1, -1, -1}, {65369, -1, -1, -1}, {65370, -1, -1, -1}, {65371, -1, -1, -1}, {65372, -1, -1, -1}, {65373, -1, -1, -1}, {65507, -1, -1, -1}, {12593, -1, -1, -1}, {12594, -1, -1, -1}, {12595, -1, -1, -1}, {12596, -1, -1, -1}, {12597, -1, -1, -1}, {12598, -1, -1, -1}, {12599, -1, -1, -1}, {12600, -1, -1, -1}, {12601, -1, -1, -1}, {12602, -1, -1, -1}, {12603, -1, -1, -1}, {12604, -1, -1, -1}, {12605, -1, -1, -1}, {12606, -1, -1, -1}, {12607, -1, -1, -1}, {12608, -1, -1, -1}, {12609, -1, -1, -1}, {12610, -1, -1, -1}, {12611, -1, -1, -1}, {12612, -1, -1, -1}, {12613, -1, -1, -1}, {12614, -1, -1, -1}, {12615, -1, -1, -1}, {12616, -1, -1, -1}, {12617, -1, -1, -1}, {12618, -1, -1, -1}, {12619, -1, -1, -1}, {12620, -1, -1, -1}, {12621, -1, -1, -1}, {12622, -1, -1, -1}, {12623, -1, -1, -1}, {12624, -1, -1, -1}, {12625, -1, -1, -1}, {12626, -1, -1, -1}, {12627, -1, -1, -1}, {12628, -1, -1, -1}, {12629, -1, -1, -1}, {12630, -1, -1, -1}, {12631, -1, -1, -1}, {12632, -1, -1, -1}, {12633, -1, -1, -1}, {12634, -1, -1, -1}, {12635, -1, -1, -1}, {12636, -1, -1, -1}, {12637, -1, -1, -1}, {12638, -1, -1, -1}, {12639, -1, -1, -1}, {12640, -1, -1, -1}, {12641, -1, -1, -1}, {12642, -1, -1, -1}, {12643, -1, -1, -1}, {12645, -1, -1, -1}, {12646, -1, -1, -1}, {12647, -1, -1, -1}, {12648, -1, -1, -1}, {12649, -1, -1, -1}, {12650, -1, -1, -1}, {12651, -1, -1, -1}, {12652, -1, -1, -1}, {12653, -1, -1, -1}, {12654, -1, -1, -1}, {12655, -1, -1, -1}, {12656, -1, -1, -1}, {12657, -1, -1, -1}, {12658, -1, -1, -1}, {12659, -1, -1, -1}, {12660, -1, -1, -1}, {12661, -1, -1, -1}, {12662, -1, -1, -1}, {12663, -1, -1, -1}, {12664, -1, -1, -1}, {12665, -1, -1, -1}, {12666, -1, -1, -1}, {12667, -1, -1, -1}, {12668, -1, -1, -1}, {12669, -1, -1, -1}, {12670, -1, -1, -1}, {12671, -1, -1, -1}, {12672, -1, -1, -1}, {12673, -1, -1, -1}, {12674, -1, -1, -1}, {12675, -1, -1, -1}, {12676, -1, -1, -1}, {12677, -1, -1, -1}, {12678, -1, -1, -1}, {12679, -1, -1, -1}, {12680, -1, -1, -1}, {12681, -1, -1, -1}, {12682, -1, -1, -1}, {12683, -1, -1, -1}, {12684, -1, -1, -1}, {12685, -1, -1, -1}, {12686, -1, -1, -1}, {8560, -1, -1, -1}, {8561, -1, -1, -1}, {8562, -1, -1, -1}, {8563, -1, -1, -1}, {8564, -1, -1, -1}, {8565, -1, -1, -1}, {8566, -1, -1, -1}, {8567, -1, -1, -1}, {8568, -1, -1, -1}, {8569, -1, -1, -1}, {8544, -1, -1, -1}, {8545, -1, -1, -1}, {8546, -1, -1, -1}, {8547, -1, -1, -1}, {8548, -1, -1, -1}, {8549, -1, -1, -1}, {8550, -1, -1, -1}, {8551, -1, -1, -1}, {8552, -1, -1, -1}, {8553, -1, -1, -1}, {913, -1, -1, -1}, {914, -1, -1, -1}, {915, -1, -1, -1}, {916, -1, -1, -1}, {917, -1, -1, -1}, {918, -1, -1, -1}, {919, -1, -1, -1}, {920, -1, -1, -1}, {921, -1, -1, -1}, {922, -1, -1, -1}, {923, -1, -1, -1}, {924, -1, -1, -1}, {925, -1, -1, -1}, {926, -1, -1, -1}, {927, -1, -1, -1}, {928, -1, -1, -1}, {929, -1, -1, -1}, {931, -1, -1, -1}, {932, -1, -1, -1}, {933, -1, -1, -1}, {934, -1, -1, -1}, {935, -1, -1, -1}, {936, -1, -1, -1}, {937, -1, -1, -1}, {945, -1, -1, -1}, {946, -1, -1, -1}, {947, -1, -1, -1}, {948, -1, -1, -1}, {949, -1, -1, -1}, {950, -1, -1, -1}, {951, -1, -1, -1}, {952, -1, -1, -1}, {953, -1, -1, -1}, {954, -1, -1, -1}, {955, -1, -1, -1}, {956, -1, -1, -1}, {957, -1, -1, -1}, {958, -1, -1, -1}, {959, -1, -1, -1}, {960, -1, -1, -1}, {961, -1, -1, -1} },
+ {{963, -1, -1, -1}, {964, -1, -1, -1}, {965, -1, -1, -1}, {966, -1, -1, -1}, {967, -1, -1, -1}, {968, -1, -1, -1}, {969, -1, -1, -1}, {9472, -1, -1, -1}, {9474, -1, -1, -1}, {9484, -1, -1, -1}, {9488, -1, -1, -1}, {9496, -1, -1, -1}, {9492, -1, -1, -1}, {9500, -1, -1, -1}, {9516, -1, -1, -1}, {9508, -1, -1, -1}, {9524, -1, -1, -1}, {9532, -1, -1, -1}, {9473, -1, -1, -1}, {9475, -1, -1, -1}, {9487, -1, -1, -1}, {9491, -1, -1, -1}, {9499, -1, -1, -1}, {9495, -1, -1, -1}, {9507, -1, -1, -1}, {9523, -1, -1, -1}, {9515, -1, -1, -1}, {9531, -1, -1, -1}, {9547, -1, -1, -1}, {9504, -1, -1, -1}, {9519, -1, -1, -1}, {9512, -1, -1, -1}, {9527, -1, -1, -1}, {9535, -1, -1, -1}, {9501, -1, -1, -1}, {9520, -1, -1, -1}, {9509, -1, -1, -1}, {9528, -1, -1, -1}, {9538, -1, -1, -1}, {9490, -1, -1, -1}, {9489, -1, -1, -1}, {9498, -1, -1, -1}, {9497, -1, -1, -1}, {9494, -1, -1, -1}, {9493, -1, -1, -1}, {9486, -1, -1, -1}, {9485, -1, -1, -1}, {9502, -1, -1, -1}, {9503, -1, -1, -1}, {9505, -1, -1, -1}, {9506, -1, -1, -1}, {9510, -1, -1, -1}, {9511, -1, -1, -1}, {9513, -1, -1, -1}, {9514, -1, -1, -1}, {9517, -1, -1, -1}, {9518, -1, -1, -1}, {9521, -1, -1, -1}, {9522, -1, -1, -1}, {9525, -1, -1, -1}, {9526, -1, -1, -1}, {9529, -1, -1, -1}, {9530, -1, -1, -1}, {9533, -1, -1, -1}, {9534, -1, -1, -1}, {9536, -1, -1, -1}, {9537, -1, -1, -1}, {9539, -1, -1, -1}, {9540, -1, -1, -1}, {9541, -1, -1, -1}, {9542, -1, -1, -1}, {9543, -1, -1, -1}, {9544, -1, -1, -1}, {9545, -1, -1, -1}, {9546, -1, -1, -1}, {13205, -1, -1, -1}, {13206, -1, -1, -1}, {13207, -1, -1, -1}, {8467, -1, -1, -1}, {13208, -1, -1, -1}, {13252, -1, -1, -1}, {13219, -1, -1, -1}, {13220, -1, -1, -1}, {13221, -1, -1, -1}, {13222, -1, -1, -1}, {13209, -1, -1, -1}, {13210, -1, -1, -1}, {13211, -1, -1, -1}, {13212, -1, -1, -1}, {13213, -1, -1, -1}, {13214, -1, -1, -1}, {13215, -1, -1, -1}, {13216, -1, -1, -1}, {13217, -1, -1, -1}, {13218, -1, -1, -1}, {13258, -1, -1, -1}, {13197, -1, -1, -1}, {13198, -1, -1, -1}, {13199, -1, -1, -1}, {13263, -1, -1, -1}, {13192, -1, -1, -1}, {13193, -1, -1, -1}, {13256, -1, -1, -1}, {13223, -1, -1, -1}, {13224, -1, -1, -1}, {13232, -1, -1, -1}, {13233, -1, -1, -1}, {13234, -1, -1, -1}, {13235, -1, -1, -1}, {13236, -1, -1, -1}, {13237, -1, -1, -1}, {13238, -1, -1, -1}, {13239, -1, -1, -1}, {13240, -1, -1, -1}, {13241, -1, -1, -1}, {13184, -1, -1, -1}, {13185, -1, -1, -1}, {13186, -1, -1, -1}, {13187, -1, -1, -1}, {13188, -1, -1, -1}, {13242, -1, -1, -1}, {13243, -1, -1, -1}, {13244, -1, -1, -1}, {13245, -1, -1, -1}, {13246, -1, -1, -1}, {13247, -1, -1, -1}, {13200, -1, -1, -1}, {13201, -1, -1, -1}, {13202, -1, -1, -1}, {13203, -1, -1, -1}, {13204, -1, -1, -1}, {8486, -1, -1, -1}, {13248, -1, -1, -1}, {13249, -1, -1, -1}, {13194, -1, -1, -1}, {13195, -1, -1, -1}, {13196, -1, -1, -1}, {13270, -1, -1, -1}, {13253, -1, -1, -1}, {13229, -1, -1, -1}, {13230, -1, -1, -1}, {13231, -1, -1, -1}, {13275, -1, -1, -1}, {13225, -1, -1, -1}, {13226, -1, -1, -1}, {13227, -1, -1, -1}, {13228, -1, -1, -1}, {13277, -1, -1, -1}, {13264, -1, -1, -1}, {13267, -1, -1, -1}, {13251, -1, -1, -1}, {13257, -1, -1, -1}, {13276, -1, -1, -1}, {13254, -1, -1, -1}, {198, -1, -1, -1}, {208, -1, -1, -1}, {170, -1, -1, -1}, {294, -1, -1, -1}, {306, -1, -1, -1}, {319, -1, -1, -1}, {321, -1, -1, -1}, {216, -1, -1, -1}, {338, -1, -1, -1}, {186, -1, -1, -1}, {222, -1, -1, -1}, {358, -1, -1, -1}, {330, -1, -1, -1}, {12896, -1, -1, -1}, {12897, -1, -1, -1}, {12898, -1, -1, -1}, {12899, -1, -1, -1}, {12900, -1, -1, -1}, {12901, -1, -1, -1}, {12902, -1, -1, -1}, {12903, -1, -1, -1}, {12904, -1, -1, -1}, {12905, -1, -1, -1}, {12906, -1, -1, -1}, {12907, -1, -1, -1}, {12908, -1, -1, -1}, {12909, -1, -1, -1}, {12910, -1, -1, -1}, {12911, -1, -1, -1}, {12912, -1, -1, -1}, {12913, -1, -1, -1}, {12914, -1, -1, -1}, {12915, -1, -1, -1}, {12916, -1, -1, -1}, {12917, -1, -1, -1}, {12918, -1, -1, -1}, {12919, -1, -1, -1}, {12920, -1, -1, -1}, {12921, -1, -1, -1}, {12922, -1, -1, -1}, {12923, -1, -1, -1}, {9424, -1, -1, -1}, {9425, -1, -1, -1}, {9426, -1, -1, -1}, {9427, -1, -1, -1}, {9428, -1, -1, -1}, {9429, -1, -1, -1}, {9430, -1, -1, -1}, {9431, -1, -1, -1}, {9432, -1, -1, -1}, {9433, -1, -1, -1}, {9434, -1, -1, -1}, {9435, -1, -1, -1}, {9436, -1, -1, -1}, {9437, -1, -1, -1}, {9438, -1, -1, -1}, {9439, -1, -1, -1}, {9440, -1, -1, -1}, {9441, -1, -1, -1}, {9442, -1, -1, -1}, {9443, -1, -1, -1}, {9444, -1, -1, -1}, {9445, -1, -1, -1}, {9446, -1, -1, -1}, {9447, -1, -1, -1}, {9448, -1, -1, -1}, {9449, -1, -1, -1}, {9312, -1, -1, -1}, {9313, -1, -1, -1}, {9314, -1, -1, -1}, {9315, -1, -1, -1}, {9316, -1, -1, -1}, {9317, -1, -1, -1}, {9318, -1, -1, -1}, {9319, -1, -1, -1}, {9320, -1, -1, -1}, {9321, -1, -1, -1}, {9322, -1, -1, -1}, {9323, -1, -1, -1}, {9324, -1, -1, -1}, {9325, -1, -1, -1}, {9326, -1, -1, -1}, {189, -1, -1, -1}, {8531, -1, -1, -1}, {8532, -1, -1, -1}, {188, -1, -1, -1}, {190, -1, -1, -1}, {8539, -1, -1, -1}, {8540, -1, -1, -1}, {8541, -1, -1, -1}, {8542, -1, -1, -1}, {230, -1, -1, -1}, {273, -1, -1, -1}, {240, -1, -1, -1}, {295, -1, -1, -1}, {305, -1, -1, -1}, {307, -1, -1, -1}, {312, -1, -1, -1}, {320, -1, -1, -1}, {322, -1, -1, -1}, {248, -1, -1, -1}, {339, -1, -1, -1} },
+ {{223, -1, -1, -1}, {254, -1, -1, -1}, {359, -1, -1, -1}, {331, -1, -1, -1}, {329, -1, -1, -1}, {12800, -1, -1, -1}, {12801, -1, -1, -1}, {12802, -1, -1, -1}, {12803, -1, -1, -1}, {12804, -1, -1, -1}, {12805, -1, -1, -1}, {12806, -1, -1, -1}, {12807, -1, -1, -1}, {12808, -1, -1, -1}, {12809, -1, -1, -1}, {12810, -1, -1, -1}, {12811, -1, -1, -1}, {12812, -1, -1, -1}, {12813, -1, -1, -1}, {12814, -1, -1, -1}, {12815, -1, -1, -1}, {12816, -1, -1, -1}, {12817, -1, -1, -1}, {12818, -1, -1, -1}, {12819, -1, -1, -1}, {12820, -1, -1, -1}, {12821, -1, -1, -1}, {12822, -1, -1, -1}, {12823, -1, -1, -1}, {12824, -1, -1, -1}, {12825, -1, -1, -1}, {12826, -1, -1, -1}, {12827, -1, -1, -1}, {9372, -1, -1, -1}, {9373, -1, -1, -1}, {9374, -1, -1, -1}, {9375, -1, -1, -1}, {9376, -1, -1, -1}, {9377, -1, -1, -1}, {9378, -1, -1, -1}, {9379, -1, -1, -1}, {9380, -1, -1, -1}, {9381, -1, -1, -1}, {9382, -1, -1, -1}, {9383, -1, -1, -1}, {9384, -1, -1, -1}, {9385, -1, -1, -1}, {9386, -1, -1, -1}, {9387, -1, -1, -1}, {9388, -1, -1, -1}, {9389, -1, -1, -1}, {9390, -1, -1, -1}, {9391, -1, -1, -1}, {9392, -1, -1, -1}, {9393, -1, -1, -1}, {9394, -1, -1, -1}, {9395, -1, -1, -1}, {9396, -1, -1, -1}, {9397, -1, -1, -1}, {9332, -1, -1, -1}, {9333, -1, -1, -1}, {9334, -1, -1, -1}, {9335, -1, -1, -1}, {9336, -1, -1, -1}, {9337, -1, -1, -1}, {9338, -1, -1, -1}, {9339, -1, -1, -1}, {9340, -1, -1, -1}, {9341, -1, -1, -1}, {9342, -1, -1, -1}, {9343, -1, -1, -1}, {9344, -1, -1, -1}, {9345, -1, -1, -1}, {9346, -1, -1, -1}, {185, -1, -1, -1}, {178, -1, -1, -1}, {179, -1, -1, -1}, {8308, -1, -1, -1}, {8319, -1, -1, -1}, {8321, -1, -1, -1}, {8322, -1, -1, -1}, {8323, -1, -1, -1}, {8324, -1, -1, -1}, {12353, -1, -1, -1}, {12354, -1, -1, -1}, {12355, -1, -1, -1}, {12356, -1, -1, -1}, {12357, -1, -1, -1}, {12358, -1, -1, -1}, {12359, -1, -1, -1}, {12360, -1, -1, -1}, {12361, -1, -1, -1}, {12362, -1, -1, -1}, {12363, -1, -1, -1}, {12364, -1, -1, -1}, {12365, -1, -1, -1}, {12366, -1, -1, -1}, {12367, -1, -1, -1}, {12368, -1, -1, -1}, {12369, -1, -1, -1}, {12370, -1, -1, -1}, {12371, -1, -1, -1}, {12372, -1, -1, -1}, {12373, -1, -1, -1}, {12374, -1, -1, -1}, {12375, -1, -1, -1}, {12376, -1, -1, -1}, {12377, -1, -1, -1}, {12378, -1, -1, -1}, {12379, -1, -1, -1}, {12380, -1, -1, -1}, {12381, -1, -1, -1}, {12382, -1, -1, -1}, {12383, -1, -1, -1}, {12384, -1, -1, -1}, {12385, -1, -1, -1}, {12386, -1, -1, -1}, {12387, -1, -1, -1}, {12388, -1, -1, -1}, {12389, -1, -1, -1}, {12390, -1, -1, -1}, {12391, -1, -1, -1}, {12392, -1, -1, -1}, {12393, -1, -1, -1}, {12394, -1, -1, -1}, {12395, -1, -1, -1}, {12396, -1, -1, -1}, {12397, -1, -1, -1}, {12398, -1, -1, -1}, {12399, -1, -1, -1}, {12400, -1, -1, -1}, {12401, -1, -1, -1}, {12402, -1, -1, -1}, {12403, -1, -1, -1}, {12404, -1, -1, -1}, {12405, -1, -1, -1}, {12406, -1, -1, -1}, {12407, -1, -1, -1}, {12408, -1, -1, -1}, {12409, -1, -1, -1}, {12410, -1, -1, -1}, {12411, -1, -1, -1}, {12412, -1, -1, -1}, {12413, -1, -1, -1}, {12414, -1, -1, -1}, {12415, -1, -1, -1}, {12416, -1, -1, -1}, {12417, -1, -1, -1}, {12418, -1, -1, -1}, {12419, -1, -1, -1}, {12420, -1, -1, -1}, {12421, -1, -1, -1}, {12422, -1, -1, -1}, {12423, -1, -1, -1}, {12424, -1, -1, -1}, {12425, -1, -1, -1}, {12426, -1, -1, -1}, {12427, -1, -1, -1}, {12428, -1, -1, -1}, {12429, -1, -1, -1}, {12430, -1, -1, -1}, {12431, -1, -1, -1}, {12432, -1, -1, -1}, {12433, -1, -1, -1}, {12434, -1, -1, -1}, {12435, -1, -1, -1}, {12449, -1, -1, -1}, {12450, -1, -1, -1}, {12451, -1, -1, -1}, {12452, -1, -1, -1}, {12453, -1, -1, -1}, {12454, -1, -1, -1}, {12455, -1, -1, -1}, {12456, -1, -1, -1}, {12457, -1, -1, -1}, {12458, -1, -1, -1}, {12459, -1, -1, -1}, {12460, -1, -1, -1}, {12461, -1, -1, -1}, {12462, -1, -1, -1}, {12463, -1, -1, -1}, {12464, -1, -1, -1}, {12465, -1, -1, -1}, {12466, -1, -1, -1}, {12467, -1, -1, -1}, {12468, -1, -1, -1}, {12469, -1, -1, -1}, {12470, -1, -1, -1}, {12471, -1, -1, -1}, {12472, -1, -1, -1}, {12473, -1, -1, -1}, {12474, -1, -1, -1}, {12475, -1, -1, -1}, {12476, -1, -1, -1}, {12477, -1, -1, -1}, {12478, -1, -1, -1}, {12479, -1, -1, -1}, {12480, -1, -1, -1}, {12481, -1, -1, -1}, {12482, -1, -1, -1}, {12483, -1, -1, -1}, {12484, -1, -1, -1}, {12485, -1, -1, -1}, {12486, -1, -1, -1}, {12487, -1, -1, -1}, {12488, -1, -1, -1}, {12489, -1, -1, -1}, {12490, -1, -1, -1}, {12491, -1, -1, -1}, {12492, -1, -1, -1}, {12493, -1, -1, -1}, {12494, -1, -1, -1}, {12495, -1, -1, -1}, {12496, -1, -1, -1}, {12497, -1, -1, -1}, {12498, -1, -1, -1}, {12499, -1, -1, -1}, {12500, -1, -1, -1}, {12501, -1, -1, -1}, {12502, -1, -1, -1}, {12503, -1, -1, -1}, {12504, -1, -1, -1}, {12505, -1, -1, -1}, {12506, -1, -1, -1}, {12507, -1, -1, -1}, {12508, -1, -1, -1}, {12509, -1, -1, -1}, {12510, -1, -1, -1}, {12511, -1, -1, -1}, {12512, -1, -1, -1}, {12513, -1, -1, -1}, {12514, -1, -1, -1}, {12515, -1, -1, -1}, {12516, -1, -1, -1}, {12517, -1, -1, -1}, {12518, -1, -1, -1}, {12519, -1, -1, -1}, {12520, -1, -1, -1}, {12521, -1, -1, -1}, {12522, -1, -1, -1}, {12523, -1, -1, -1}, {12524, -1, -1, -1}, {12525, -1, -1, -1}, {12526, -1, -1, -1}, {12527, -1, -1, -1}, {12528, -1, -1, -1}, {12529, -1, -1, -1}, {12530, -1, -1, -1}, {12531, -1, -1, -1}, {12532, -1, -1, -1}, {12533, -1, -1, -1}, {12534, -1, -1, -1}, {1040, -1, -1, -1}, {1041, -1, -1, -1}, {1042, -1, -1, -1}, {1043, -1, -1, -1} },
+ {{1044, -1, -1, -1}, {1045, -1, -1, -1}, {1025, -1, -1, -1}, {1046, -1, -1, -1}, {1047, -1, -1, -1}, {1048, -1, -1, -1}, {1049, -1, -1, -1}, {1050, -1, -1, -1}, {1051, -1, -1, -1}, {1052, -1, -1, -1}, {1053, -1, -1, -1}, {1054, -1, -1, -1}, {1055, -1, -1, -1}, {1056, -1, -1, -1}, {1057, -1, -1, -1}, {1058, -1, -1, -1}, {1059, -1, -1, -1}, {1060, -1, -1, -1}, {1061, -1, -1, -1}, {1062, -1, -1, -1}, {1063, -1, -1, -1}, {1064, -1, -1, -1}, {1065, -1, -1, -1}, {1066, -1, -1, -1}, {1067, -1, -1, -1}, {1068, -1, -1, -1}, {1069, -1, -1, -1}, {1070, -1, -1, -1}, {1071, -1, -1, -1}, {1072, -1, -1, -1}, {1073, -1, -1, -1}, {1074, -1, -1, -1}, {1075, -1, -1, -1}, {1076, -1, -1, -1}, {1077, -1, -1, -1}, {1105, -1, -1, -1}, {1078, -1, -1, -1}, {1079, -1, -1, -1}, {1080, -1, -1, -1}, {1081, -1, -1, -1}, {1082, -1, -1, -1}, {1083, -1, -1, -1}, {1084, -1, -1, -1}, {1085, -1, -1, -1}, {1086, -1, -1, -1}, {1087, -1, -1, -1}, {1088, -1, -1, -1}, {1089, -1, -1, -1}, {1090, -1, -1, -1}, {1091, -1, -1, -1}, {1092, -1, -1, -1}, {1093, -1, -1, -1}, {1094, -1, -1, -1}, {1095, -1, -1, -1}, {1096, -1, -1, -1}, {1097, -1, -1, -1}, {1098, -1, -1, -1}, {1099, -1, -1, -1}, {1100, -1, -1, -1}, {1101, -1, -1, -1}, {1102, -1, -1, -1}, {1103, -1, -1, -1}, {44032, -1, -1, -1}, {44033, -1, -1, -1}, {44036, -1, -1, -1}, {44039, -1, -1, -1}, {44040, -1, -1, -1}, {44041, -1, -1, -1}, {44042, -1, -1, -1}, {44048, -1, -1, -1}, {44049, -1, -1, -1}, {44050, -1, -1, -1}, {44051, -1, -1, -1}, {44052, -1, -1, -1}, {44053, -1, -1, -1}, {44054, -1, -1, -1}, {44055, -1, -1, -1}, {44057, -1, -1, -1}, {44058, -1, -1, -1}, {44059, -1, -1, -1}, {44060, -1, -1, -1}, {44061, -1, -1, -1}, {44064, -1, -1, -1}, {44068, -1, -1, -1}, {44076, -1, -1, -1}, {44077, -1, -1, -1}, {44079, -1, -1, -1}, {44080, -1, -1, -1}, {44081, -1, -1, -1}, {44088, -1, -1, -1}, {44089, -1, -1, -1}, {44092, -1, -1, -1}, {44096, -1, -1, -1}, {44107, -1, -1, -1}, {44109, -1, -1, -1}, {44116, -1, -1, -1}, {44120, -1, -1, -1}, {44124, -1, -1, -1}, {44144, -1, -1, -1}, {44145, -1, -1, -1}, {44148, -1, -1, -1}, {44151, -1, -1, -1}, {44152, -1, -1, -1}, {44154, -1, -1, -1}, {44160, -1, -1, -1}, {44161, -1, -1, -1}, {44163, -1, -1, -1}, {44164, -1, -1, -1}, {44165, -1, -1, -1}, {44166, -1, -1, -1}, {44169, -1, -1, -1}, {44170, -1, -1, -1}, {44171, -1, -1, -1}, {44172, -1, -1, -1}, {44176, -1, -1, -1}, {44180, -1, -1, -1}, {44188, -1, -1, -1}, {44189, -1, -1, -1}, {44191, -1, -1, -1}, {44192, -1, -1, -1}, {44193, -1, -1, -1}, {44200, -1, -1, -1}, {44201, -1, -1, -1}, {44202, -1, -1, -1}, {44204, -1, -1, -1}, {44207, -1, -1, -1}, {44208, -1, -1, -1}, {44216, -1, -1, -1}, {44217, -1, -1, -1}, {44219, -1, -1, -1}, {44220, -1, -1, -1}, {44221, -1, -1, -1}, {44225, -1, -1, -1}, {44228, -1, -1, -1}, {44232, -1, -1, -1}, {44236, -1, -1, -1}, {44245, -1, -1, -1}, {44247, -1, -1, -1}, {44256, -1, -1, -1}, {44257, -1, -1, -1}, {44260, -1, -1, -1}, {44263, -1, -1, -1}, {44264, -1, -1, -1}, {44266, -1, -1, -1}, {44268, -1, -1, -1}, {44271, -1, -1, -1}, {44272, -1, -1, -1}, {44273, -1, -1, -1}, {44275, -1, -1, -1}, {44277, -1, -1, -1}, {44278, -1, -1, -1}, {44284, -1, -1, -1}, {44285, -1, -1, -1}, {44288, -1, -1, -1}, {44292, -1, -1, -1}, {44294, -1, -1, -1}, {44300, -1, -1, -1}, {44301, -1, -1, -1}, {44303, -1, -1, -1}, {44305, -1, -1, -1}, {44312, -1, -1, -1}, {44316, -1, -1, -1}, {44320, -1, -1, -1}, {44329, -1, -1, -1}, {44332, -1, -1, -1}, {44333, -1, -1, -1}, {44340, -1, -1, -1}, {44341, -1, -1, -1}, {44344, -1, -1, -1}, {44348, -1, -1, -1}, {44356, -1, -1, -1}, {44357, -1, -1, -1}, {44359, -1, -1, -1}, {44361, -1, -1, -1}, {44368, -1, -1, -1}, {44372, -1, -1, -1}, {44376, -1, -1, -1}, {44385, -1, -1, -1}, {44387, -1, -1, -1}, {44396, -1, -1, -1}, {44397, -1, -1, -1}, {44400, -1, -1, -1}, {44403, -1, -1, -1}, {44404, -1, -1, -1}, {44405, -1, -1, -1}, {44406, -1, -1, -1}, {44411, -1, -1, -1}, {44412, -1, -1, -1}, {44413, -1, -1, -1}, {44415, -1, -1, -1}, {44417, -1, -1, -1}, {44418, -1, -1, -1}, {44424, -1, -1, -1}, {44425, -1, -1, -1}, {44428, -1, -1, -1}, {44432, -1, -1, -1}, {44444, -1, -1, -1}, {44445, -1, -1, -1}, {44452, -1, -1, -1}, {44471, -1, -1, -1}, {44480, -1, -1, -1}, {44481, -1, -1, -1}, {44484, -1, -1, -1}, {44488, -1, -1, -1}, {44496, -1, -1, -1}, {44497, -1, -1, -1}, {44499, -1, -1, -1}, {44508, -1, -1, -1}, {44512, -1, -1, -1}, {44516, -1, -1, -1}, {44536, -1, -1, -1}, {44537, -1, -1, -1}, {44540, -1, -1, -1}, {44543, -1, -1, -1}, {44544, -1, -1, -1}, {44545, -1, -1, -1}, {44552, -1, -1, -1}, {44553, -1, -1, -1}, {44555, -1, -1, -1}, {44557, -1, -1, -1}, {44564, -1, -1, -1}, {44592, -1, -1, -1}, {44593, -1, -1, -1}, {44596, -1, -1, -1}, {44599, -1, -1, -1}, {44600, -1, -1, -1}, {44602, -1, -1, -1}, {44608, -1, -1, -1}, {44609, -1, -1, -1}, {44611, -1, -1, -1}, {44613, -1, -1, -1}, {44614, -1, -1, -1}, {44618, -1, -1, -1}, {44620, -1, -1, -1}, {44621, -1, -1, -1}, {44622, -1, -1, -1}, {44624, -1, -1, -1}, {44628, -1, -1, -1}, {44630, -1, -1, -1}, {44636, -1, -1, -1}, {44637, -1, -1, -1}, {44639, -1, -1, -1}, {44640, -1, -1, -1}, {44641, -1, -1, -1}, {44645, -1, -1, -1}, {44648, -1, -1, -1}, {44649, -1, -1, -1}, {44652, -1, -1, -1}, {44656, -1, -1, -1}, {44664, -1, -1, -1}, {44665, -1, -1, -1}, {44667, -1, -1, -1}, {44668, -1, -1, -1}, {44669, -1, -1, -1}, {44676, -1, -1, -1}, {44677, -1, -1, -1} },
+ {{44684, -1, -1, -1}, {44732, -1, -1, -1}, {44733, -1, -1, -1}, {44734, -1, -1, -1}, {44736, -1, -1, -1}, {44740, -1, -1, -1}, {44748, -1, -1, -1}, {44749, -1, -1, -1}, {44751, -1, -1, -1}, {44752, -1, -1, -1}, {44753, -1, -1, -1}, {44760, -1, -1, -1}, {44761, -1, -1, -1}, {44764, -1, -1, -1}, {44776, -1, -1, -1}, {44779, -1, -1, -1}, {44781, -1, -1, -1}, {44788, -1, -1, -1}, {44792, -1, -1, -1}, {44796, -1, -1, -1}, {44807, -1, -1, -1}, {44808, -1, -1, -1}, {44813, -1, -1, -1}, {44816, -1, -1, -1}, {44844, -1, -1, -1}, {44845, -1, -1, -1}, {44848, -1, -1, -1}, {44850, -1, -1, -1}, {44852, -1, -1, -1}, {44860, -1, -1, -1}, {44861, -1, -1, -1}, {44863, -1, -1, -1}, {44865, -1, -1, -1}, {44866, -1, -1, -1}, {44867, -1, -1, -1}, {44872, -1, -1, -1}, {44873, -1, -1, -1}, {44880, -1, -1, -1}, {44892, -1, -1, -1}, {44893, -1, -1, -1}, {44900, -1, -1, -1}, {44901, -1, -1, -1}, {44921, -1, -1, -1}, {44928, -1, -1, -1}, {44932, -1, -1, -1}, {44936, -1, -1, -1}, {44944, -1, -1, -1}, {44945, -1, -1, -1}, {44949, -1, -1, -1}, {44956, -1, -1, -1}, {44984, -1, -1, -1}, {44985, -1, -1, -1}, {44988, -1, -1, -1}, {44992, -1, -1, -1}, {44999, -1, -1, -1}, {45000, -1, -1, -1}, {45001, -1, -1, -1}, {45003, -1, -1, -1}, {45005, -1, -1, -1}, {45006, -1, -1, -1}, {45012, -1, -1, -1}, {45020, -1, -1, -1}, {45032, -1, -1, -1}, {45033, -1, -1, -1}, {45040, -1, -1, -1}, {45041, -1, -1, -1}, {45044, -1, -1, -1}, {45048, -1, -1, -1}, {45056, -1, -1, -1}, {45057, -1, -1, -1}, {45060, -1, -1, -1}, {45068, -1, -1, -1}, {45072, -1, -1, -1}, {45076, -1, -1, -1}, {45084, -1, -1, -1}, {45085, -1, -1, -1}, {45096, -1, -1, -1}, {45124, -1, -1, -1}, {45125, -1, -1, -1}, {45128, -1, -1, -1}, {45130, -1, -1, -1}, {45132, -1, -1, -1}, {45134, -1, -1, -1}, {45139, -1, -1, -1}, {45140, -1, -1, -1}, {45141, -1, -1, -1}, {45143, -1, -1, -1}, {45145, -1, -1, -1}, {45149, -1, -1, -1}, {45180, -1, -1, -1}, {45181, -1, -1, -1}, {45184, -1, -1, -1}, {45188, -1, -1, -1}, {45196, -1, -1, -1}, {45197, -1, -1, -1}, {45199, -1, -1, -1}, {45201, -1, -1, -1}, {45208, -1, -1, -1}, {45209, -1, -1, -1}, {45210, -1, -1, -1}, {45212, -1, -1, -1}, {45215, -1, -1, -1}, {45216, -1, -1, -1}, {45217, -1, -1, -1}, {45218, -1, -1, -1}, {45224, -1, -1, -1}, {45225, -1, -1, -1}, {45227, -1, -1, -1}, {45228, -1, -1, -1}, {45229, -1, -1, -1}, {45230, -1, -1, -1}, {45231, -1, -1, -1}, {45233, -1, -1, -1}, {45235, -1, -1, -1}, {45236, -1, -1, -1}, {45237, -1, -1, -1}, {45240, -1, -1, -1}, {45244, -1, -1, -1}, {45252, -1, -1, -1}, {45253, -1, -1, -1}, {45255, -1, -1, -1}, {45256, -1, -1, -1}, {45257, -1, -1, -1}, {45264, -1, -1, -1}, {45265, -1, -1, -1}, {45268, -1, -1, -1}, {45272, -1, -1, -1}, {45280, -1, -1, -1}, {45285, -1, -1, -1}, {45320, -1, -1, -1}, {45321, -1, -1, -1}, {45323, -1, -1, -1}, {45324, -1, -1, -1}, {45328, -1, -1, -1}, {45330, -1, -1, -1}, {45331, -1, -1, -1}, {45336, -1, -1, -1}, {45337, -1, -1, -1}, {45339, -1, -1, -1}, {45340, -1, -1, -1}, {45341, -1, -1, -1}, {45347, -1, -1, -1}, {45348, -1, -1, -1}, {45349, -1, -1, -1}, {45352, -1, -1, -1}, {45356, -1, -1, -1}, {45364, -1, -1, -1}, {45365, -1, -1, -1}, {45367, -1, -1, -1}, {45368, -1, -1, -1}, {45369, -1, -1, -1}, {45376, -1, -1, -1}, {45377, -1, -1, -1}, {45380, -1, -1, -1}, {45384, -1, -1, -1}, {45392, -1, -1, -1}, {45393, -1, -1, -1}, {45396, -1, -1, -1}, {45397, -1, -1, -1}, {45400, -1, -1, -1}, {45404, -1, -1, -1}, {45408, -1, -1, -1}, {45432, -1, -1, -1}, {45433, -1, -1, -1}, {45436, -1, -1, -1}, {45440, -1, -1, -1}, {45442, -1, -1, -1}, {45448, -1, -1, -1}, {45449, -1, -1, -1}, {45451, -1, -1, -1}, {45453, -1, -1, -1}, {45458, -1, -1, -1}, {45459, -1, -1, -1}, {45460, -1, -1, -1}, {45464, -1, -1, -1}, {45468, -1, -1, -1}, {45480, -1, -1, -1}, {45516, -1, -1, -1}, {45520, -1, -1, -1}, {45524, -1, -1, -1}, {45532, -1, -1, -1}, {45533, -1, -1, -1}, {45535, -1, -1, -1}, {45544, -1, -1, -1}, {45545, -1, -1, -1}, {45548, -1, -1, -1}, {45552, -1, -1, -1}, {45561, -1, -1, -1}, {45563, -1, -1, -1}, {45565, -1, -1, -1}, {45572, -1, -1, -1}, {45573, -1, -1, -1}, {45576, -1, -1, -1}, {45579, -1, -1, -1}, {45580, -1, -1, -1}, {45588, -1, -1, -1}, {45589, -1, -1, -1}, {45591, -1, -1, -1}, {45593, -1, -1, -1}, {45600, -1, -1, -1}, {45620, -1, -1, -1}, {45628, -1, -1, -1}, {45656, -1, -1, -1}, {45660, -1, -1, -1}, {45664, -1, -1, -1}, {45672, -1, -1, -1}, {45673, -1, -1, -1}, {45684, -1, -1, -1}, {45685, -1, -1, -1}, {45692, -1, -1, -1}, {45700, -1, -1, -1}, {45701, -1, -1, -1}, {45705, -1, -1, -1}, {45712, -1, -1, -1}, {45713, -1, -1, -1}, {45716, -1, -1, -1}, {45720, -1, -1, -1}, {45721, -1, -1, -1}, {45722, -1, -1, -1}, {45728, -1, -1, -1}, {45729, -1, -1, -1}, {45731, -1, -1, -1}, {45733, -1, -1, -1}, {45734, -1, -1, -1}, {45738, -1, -1, -1}, {45740, -1, -1, -1}, {45744, -1, -1, -1}, {45748, -1, -1, -1}, {45768, -1, -1, -1}, {45769, -1, -1, -1}, {45772, -1, -1, -1}, {45776, -1, -1, -1}, {45778, -1, -1, -1}, {45784, -1, -1, -1}, {45785, -1, -1, -1}, {45787, -1, -1, -1}, {45789, -1, -1, -1}, {45794, -1, -1, -1}, {45796, -1, -1, -1}, {45797, -1, -1, -1}, {45798, -1, -1, -1}, {45800, -1, -1, -1}, {45803, -1, -1, -1}, {45804, -1, -1, -1}, {45805, -1, -1, -1}, {45806, -1, -1, -1}, {45807, -1, -1, -1}, {45811, -1, -1, -1}, {45812, -1, -1, -1}, {45813, -1, -1, -1}, {45815, -1, -1, -1}, {45816, -1, -1, -1}, {45817, -1, -1, -1}, {45818, -1, -1, -1}, {45819, -1, -1, -1}, {45823, -1, -1, -1} },
+ {{45824, -1, -1, -1}, {45825, -1, -1, -1}, {45828, -1, -1, -1}, {45832, -1, -1, -1}, {45840, -1, -1, -1}, {45841, -1, -1, -1}, {45843, -1, -1, -1}, {45844, -1, -1, -1}, {45845, -1, -1, -1}, {45852, -1, -1, -1}, {45908, -1, -1, -1}, {45909, -1, -1, -1}, {45910, -1, -1, -1}, {45912, -1, -1, -1}, {45915, -1, -1, -1}, {45916, -1, -1, -1}, {45918, -1, -1, -1}, {45919, -1, -1, -1}, {45924, -1, -1, -1}, {45925, -1, -1, -1}, {45927, -1, -1, -1}, {45929, -1, -1, -1}, {45931, -1, -1, -1}, {45934, -1, -1, -1}, {45936, -1, -1, -1}, {45937, -1, -1, -1}, {45940, -1, -1, -1}, {45944, -1, -1, -1}, {45952, -1, -1, -1}, {45953, -1, -1, -1}, {45955, -1, -1, -1}, {45956, -1, -1, -1}, {45957, -1, -1, -1}, {45964, -1, -1, -1}, {45968, -1, -1, -1}, {45972, -1, -1, -1}, {45984, -1, -1, -1}, {45985, -1, -1, -1}, {45992, -1, -1, -1}, {45996, -1, -1, -1}, {46020, -1, -1, -1}, {46021, -1, -1, -1}, {46024, -1, -1, -1}, {46027, -1, -1, -1}, {46028, -1, -1, -1}, {46030, -1, -1, -1}, {46032, -1, -1, -1}, {46036, -1, -1, -1}, {46037, -1, -1, -1}, {46039, -1, -1, -1}, {46041, -1, -1, -1}, {46043, -1, -1, -1}, {46045, -1, -1, -1}, {46048, -1, -1, -1}, {46052, -1, -1, -1}, {46056, -1, -1, -1}, {46076, -1, -1, -1}, {46096, -1, -1, -1}, {46104, -1, -1, -1}, {46108, -1, -1, -1}, {46112, -1, -1, -1}, {46120, -1, -1, -1}, {46121, -1, -1, -1}, {46123, -1, -1, -1}, {46132, -1, -1, -1}, {46160, -1, -1, -1}, {46161, -1, -1, -1}, {46164, -1, -1, -1}, {46168, -1, -1, -1}, {46176, -1, -1, -1}, {46177, -1, -1, -1}, {46179, -1, -1, -1}, {46181, -1, -1, -1}, {46188, -1, -1, -1}, {46208, -1, -1, -1}, {46216, -1, -1, -1}, {46237, -1, -1, -1}, {46244, -1, -1, -1}, {46248, -1, -1, -1}, {46252, -1, -1, -1}, {46261, -1, -1, -1}, {46263, -1, -1, -1}, {46265, -1, -1, -1}, {46272, -1, -1, -1}, {46276, -1, -1, -1}, {46280, -1, -1, -1}, {46288, -1, -1, -1}, {46293, -1, -1, -1}, {46300, -1, -1, -1}, {46301, -1, -1, -1}, {46304, -1, -1, -1}, {46307, -1, -1, -1}, {46308, -1, -1, -1}, {46310, -1, -1, -1}, {46316, -1, -1, -1}, {46317, -1, -1, -1}, {46319, -1, -1, -1}, {46321, -1, -1, -1}, {46328, -1, -1, -1}, {46356, -1, -1, -1}, {46357, -1, -1, -1}, {46360, -1, -1, -1}, {46363, -1, -1, -1}, {46364, -1, -1, -1}, {46372, -1, -1, -1}, {46373, -1, -1, -1}, {46375, -1, -1, -1}, {46376, -1, -1, -1}, {46377, -1, -1, -1}, {46378, -1, -1, -1}, {46384, -1, -1, -1}, {46385, -1, -1, -1}, {46388, -1, -1, -1}, {46392, -1, -1, -1}, {46400, -1, -1, -1}, {46401, -1, -1, -1}, {46403, -1, -1, -1}, {46404, -1, -1, -1}, {46405, -1, -1, -1}, {46411, -1, -1, -1}, {46412, -1, -1, -1}, {46413, -1, -1, -1}, {46416, -1, -1, -1}, {46420, -1, -1, -1}, {46428, -1, -1, -1}, {46429, -1, -1, -1}, {46431, -1, -1, -1}, {46432, -1, -1, -1}, {46433, -1, -1, -1}, {46496, -1, -1, -1}, {46497, -1, -1, -1}, {46500, -1, -1, -1}, {46504, -1, -1, -1}, {46506, -1, -1, -1}, {46507, -1, -1, -1}, {46512, -1, -1, -1}, {46513, -1, -1, -1}, {46515, -1, -1, -1}, {46516, -1, -1, -1}, {46517, -1, -1, -1}, {46523, -1, -1, -1}, {46524, -1, -1, -1}, {46525, -1, -1, -1}, {46528, -1, -1, -1}, {46532, -1, -1, -1}, {46540, -1, -1, -1}, {46541, -1, -1, -1}, {46543, -1, -1, -1}, {46544, -1, -1, -1}, {46545, -1, -1, -1}, {46552, -1, -1, -1}, {46572, -1, -1, -1}, {46608, -1, -1, -1}, {46609, -1, -1, -1}, {46612, -1, -1, -1}, {46616, -1, -1, -1}, {46629, -1, -1, -1}, {46636, -1, -1, -1}, {46644, -1, -1, -1}, {46664, -1, -1, -1}, {46692, -1, -1, -1}, {46696, -1, -1, -1}, {46748, -1, -1, -1}, {46749, -1, -1, -1}, {46752, -1, -1, -1}, {46756, -1, -1, -1}, {46763, -1, -1, -1}, {46764, -1, -1, -1}, {46769, -1, -1, -1}, {46804, -1, -1, -1}, {46832, -1, -1, -1}, {46836, -1, -1, -1}, {46840, -1, -1, -1}, {46848, -1, -1, -1}, {46849, -1, -1, -1}, {46853, -1, -1, -1}, {46888, -1, -1, -1}, {46889, -1, -1, -1}, {46892, -1, -1, -1}, {46895, -1, -1, -1}, {46896, -1, -1, -1}, {46904, -1, -1, -1}, {46905, -1, -1, -1}, {46907, -1, -1, -1}, {46916, -1, -1, -1}, {46920, -1, -1, -1}, {46924, -1, -1, -1}, {46932, -1, -1, -1}, {46933, -1, -1, -1}, {46944, -1, -1, -1}, {46948, -1, -1, -1}, {46952, -1, -1, -1}, {46960, -1, -1, -1}, {46961, -1, -1, -1}, {46963, -1, -1, -1}, {46965, -1, -1, -1}, {46972, -1, -1, -1}, {46973, -1, -1, -1}, {46976, -1, -1, -1}, {46980, -1, -1, -1}, {46988, -1, -1, -1}, {46989, -1, -1, -1}, {46991, -1, -1, -1}, {46992, -1, -1, -1}, {46993, -1, -1, -1}, {46994, -1, -1, -1}, {46998, -1, -1, -1}, {46999, -1, -1, -1}, {47000, -1, -1, -1}, {47001, -1, -1, -1}, {47004, -1, -1, -1}, {47008, -1, -1, -1}, {47016, -1, -1, -1}, {47017, -1, -1, -1}, {47019, -1, -1, -1}, {47020, -1, -1, -1}, {47021, -1, -1, -1}, {47028, -1, -1, -1}, {47029, -1, -1, -1}, {47032, -1, -1, -1}, {47047, -1, -1, -1}, {47049, -1, -1, -1}, {47084, -1, -1, -1}, {47085, -1, -1, -1}, {47088, -1, -1, -1}, {47092, -1, -1, -1}, {47100, -1, -1, -1}, {47101, -1, -1, -1}, {47103, -1, -1, -1}, {47104, -1, -1, -1}, {47105, -1, -1, -1}, {47111, -1, -1, -1}, {47112, -1, -1, -1}, {47113, -1, -1, -1}, {47116, -1, -1, -1}, {47120, -1, -1, -1}, {47128, -1, -1, -1}, {47129, -1, -1, -1}, {47131, -1, -1, -1}, {47133, -1, -1, -1}, {47140, -1, -1, -1}, {47141, -1, -1, -1}, {47144, -1, -1, -1}, {47148, -1, -1, -1}, {47156, -1, -1, -1}, {47157, -1, -1, -1}, {47159, -1, -1, -1}, {47160, -1, -1, -1}, {47161, -1, -1, -1}, {47168, -1, -1, -1}, {47172, -1, -1, -1}, {47185, -1, -1, -1}, {47187, -1, -1, -1}, {47196, -1, -1, -1}, {47197, -1, -1, -1}, {47200, -1, -1, -1} },
+ {{47204, -1, -1, -1}, {47212, -1, -1, -1}, {47213, -1, -1, -1}, {47215, -1, -1, -1}, {47217, -1, -1, -1}, {47224, -1, -1, -1}, {47228, -1, -1, -1}, {47245, -1, -1, -1}, {47272, -1, -1, -1}, {47280, -1, -1, -1}, {47284, -1, -1, -1}, {47288, -1, -1, -1}, {47296, -1, -1, -1}, {47297, -1, -1, -1}, {47299, -1, -1, -1}, {47301, -1, -1, -1}, {47308, -1, -1, -1}, {47312, -1, -1, -1}, {47316, -1, -1, -1}, {47325, -1, -1, -1}, {47327, -1, -1, -1}, {47329, -1, -1, -1}, {47336, -1, -1, -1}, {47337, -1, -1, -1}, {47340, -1, -1, -1}, {47344, -1, -1, -1}, {47352, -1, -1, -1}, {47353, -1, -1, -1}, {47355, -1, -1, -1}, {47357, -1, -1, -1}, {47364, -1, -1, -1}, {47384, -1, -1, -1}, {47392, -1, -1, -1}, {47420, -1, -1, -1}, {47421, -1, -1, -1}, {47424, -1, -1, -1}, {47428, -1, -1, -1}, {47436, -1, -1, -1}, {47439, -1, -1, -1}, {47441, -1, -1, -1}, {47448, -1, -1, -1}, {47449, -1, -1, -1}, {47452, -1, -1, -1}, {47456, -1, -1, -1}, {47464, -1, -1, -1}, {47465, -1, -1, -1}, {47467, -1, -1, -1}, {47469, -1, -1, -1}, {47476, -1, -1, -1}, {47477, -1, -1, -1}, {47480, -1, -1, -1}, {47484, -1, -1, -1}, {47492, -1, -1, -1}, {47493, -1, -1, -1}, {47495, -1, -1, -1}, {47497, -1, -1, -1}, {47498, -1, -1, -1}, {47501, -1, -1, -1}, {47502, -1, -1, -1}, {47532, -1, -1, -1}, {47533, -1, -1, -1}, {47536, -1, -1, -1}, {47540, -1, -1, -1}, {47548, -1, -1, -1}, {47549, -1, -1, -1}, {47551, -1, -1, -1}, {47553, -1, -1, -1}, {47560, -1, -1, -1}, {47561, -1, -1, -1}, {47564, -1, -1, -1}, {47566, -1, -1, -1}, {47567, -1, -1, -1}, {47568, -1, -1, -1}, {47569, -1, -1, -1}, {47570, -1, -1, -1}, {47576, -1, -1, -1}, {47577, -1, -1, -1}, {47579, -1, -1, -1}, {47581, -1, -1, -1}, {47582, -1, -1, -1}, {47585, -1, -1, -1}, {47587, -1, -1, -1}, {47588, -1, -1, -1}, {47589, -1, -1, -1}, {47592, -1, -1, -1}, {47596, -1, -1, -1}, {47604, -1, -1, -1}, {47605, -1, -1, -1}, {47607, -1, -1, -1}, {47608, -1, -1, -1}, {47609, -1, -1, -1}, {47610, -1, -1, -1}, {47616, -1, -1, -1}, {47617, -1, -1, -1}, {47624, -1, -1, -1}, {47637, -1, -1, -1}, {47672, -1, -1, -1}, {47673, -1, -1, -1}, {47676, -1, -1, -1}, {47680, -1, -1, -1}, {47682, -1, -1, -1}, {47688, -1, -1, -1}, {47689, -1, -1, -1}, {47691, -1, -1, -1}, {47693, -1, -1, -1}, {47694, -1, -1, -1}, {47699, -1, -1, -1}, {47700, -1, -1, -1}, {47701, -1, -1, -1}, {47704, -1, -1, -1}, {47708, -1, -1, -1}, {47716, -1, -1, -1}, {47717, -1, -1, -1}, {47719, -1, -1, -1}, {47720, -1, -1, -1}, {47721, -1, -1, -1}, {47728, -1, -1, -1}, {47729, -1, -1, -1}, {47732, -1, -1, -1}, {47736, -1, -1, -1}, {47747, -1, -1, -1}, {47748, -1, -1, -1}, {47749, -1, -1, -1}, {47751, -1, -1, -1}, {47756, -1, -1, -1}, {47784, -1, -1, -1}, {47785, -1, -1, -1}, {47787, -1, -1, -1}, {47788, -1, -1, -1}, {47792, -1, -1, -1}, {47794, -1, -1, -1}, {47800, -1, -1, -1}, {47801, -1, -1, -1}, {47803, -1, -1, -1}, {47805, -1, -1, -1}, {47812, -1, -1, -1}, {47816, -1, -1, -1}, {47832, -1, -1, -1}, {47833, -1, -1, -1}, {47868, -1, -1, -1}, {47872, -1, -1, -1}, {47876, -1, -1, -1}, {47885, -1, -1, -1}, {47887, -1, -1, -1}, {47889, -1, -1, -1}, {47896, -1, -1, -1}, {47900, -1, -1, -1}, {47904, -1, -1, -1}, {47913, -1, -1, -1}, {47915, -1, -1, -1}, {47924, -1, -1, -1}, {47925, -1, -1, -1}, {47926, -1, -1, -1}, {47928, -1, -1, -1}, {47931, -1, -1, -1}, {47932, -1, -1, -1}, {47933, -1, -1, -1}, {47934, -1, -1, -1}, {47940, -1, -1, -1}, {47941, -1, -1, -1}, {47943, -1, -1, -1}, {47945, -1, -1, -1}, {47949, -1, -1, -1}, {47951, -1, -1, -1}, {47952, -1, -1, -1}, {47956, -1, -1, -1}, {47960, -1, -1, -1}, {47969, -1, -1, -1}, {47971, -1, -1, -1}, {47980, -1, -1, -1}, {48008, -1, -1, -1}, {48012, -1, -1, -1}, {48016, -1, -1, -1}, {48036, -1, -1, -1}, {48040, -1, -1, -1}, {48044, -1, -1, -1}, {48052, -1, -1, -1}, {48055, -1, -1, -1}, {48064, -1, -1, -1}, {48068, -1, -1, -1}, {48072, -1, -1, -1}, {48080, -1, -1, -1}, {48083, -1, -1, -1}, {48120, -1, -1, -1}, {48121, -1, -1, -1}, {48124, -1, -1, -1}, {48127, -1, -1, -1}, {48128, -1, -1, -1}, {48130, -1, -1, -1}, {48136, -1, -1, -1}, {48137, -1, -1, -1}, {48139, -1, -1, -1}, {48140, -1, -1, -1}, {48141, -1, -1, -1}, {48143, -1, -1, -1}, {48145, -1, -1, -1}, {48148, -1, -1, -1}, {48149, -1, -1, -1}, {48150, -1, -1, -1}, {48151, -1, -1, -1}, {48152, -1, -1, -1}, {48155, -1, -1, -1}, {48156, -1, -1, -1}, {48157, -1, -1, -1}, {48158, -1, -1, -1}, {48159, -1, -1, -1}, {48164, -1, -1, -1}, {48165, -1, -1, -1}, {48167, -1, -1, -1}, {48169, -1, -1, -1}, {48173, -1, -1, -1}, {48176, -1, -1, -1}, {48177, -1, -1, -1}, {48180, -1, -1, -1}, {48184, -1, -1, -1}, {48192, -1, -1, -1}, {48193, -1, -1, -1}, {48195, -1, -1, -1}, {48196, -1, -1, -1}, {48197, -1, -1, -1}, {48201, -1, -1, -1}, {48204, -1, -1, -1}, {48205, -1, -1, -1}, {48208, -1, -1, -1}, {48221, -1, -1, -1}, {48260, -1, -1, -1}, {48261, -1, -1, -1}, {48264, -1, -1, -1}, {48267, -1, -1, -1}, {48268, -1, -1, -1}, {48270, -1, -1, -1}, {48276, -1, -1, -1}, {48277, -1, -1, -1}, {48279, -1, -1, -1}, {48281, -1, -1, -1}, {48282, -1, -1, -1}, {48288, -1, -1, -1}, {48289, -1, -1, -1}, {48292, -1, -1, -1}, {48295, -1, -1, -1}, {48296, -1, -1, -1}, {48304, -1, -1, -1}, {48305, -1, -1, -1}, {48307, -1, -1, -1}, {48308, -1, -1, -1}, {48309, -1, -1, -1}, {48316, -1, -1, -1}, {48317, -1, -1, -1}, {48320, -1, -1, -1}, {48324, -1, -1, -1}, {48333, -1, -1, -1}, {48335, -1, -1, -1}, {48336, -1, -1, -1}, {48337, -1, -1, -1}, {48341, -1, -1, -1}, {48344, -1, -1, -1} },
+ {{48348, -1, -1, -1}, {48372, -1, -1, -1}, {48373, -1, -1, -1}, {48374, -1, -1, -1}, {48376, -1, -1, -1}, {48380, -1, -1, -1}, {48388, -1, -1, -1}, {48389, -1, -1, -1}, {48391, -1, -1, -1}, {48393, -1, -1, -1}, {48400, -1, -1, -1}, {48404, -1, -1, -1}, {48420, -1, -1, -1}, {48428, -1, -1, -1}, {48448, -1, -1, -1}, {48456, -1, -1, -1}, {48457, -1, -1, -1}, {48460, -1, -1, -1}, {48464, -1, -1, -1}, {48472, -1, -1, -1}, {48473, -1, -1, -1}, {48484, -1, -1, -1}, {48488, -1, -1, -1}, {48512, -1, -1, -1}, {48513, -1, -1, -1}, {48516, -1, -1, -1}, {48519, -1, -1, -1}, {48520, -1, -1, -1}, {48521, -1, -1, -1}, {48522, -1, -1, -1}, {48528, -1, -1, -1}, {48529, -1, -1, -1}, {48531, -1, -1, -1}, {48533, -1, -1, -1}, {48537, -1, -1, -1}, {48538, -1, -1, -1}, {48540, -1, -1, -1}, {48548, -1, -1, -1}, {48560, -1, -1, -1}, {48568, -1, -1, -1}, {48596, -1, -1, -1}, {48597, -1, -1, -1}, {48600, -1, -1, -1}, {48604, -1, -1, -1}, {48617, -1, -1, -1}, {48624, -1, -1, -1}, {48628, -1, -1, -1}, {48632, -1, -1, -1}, {48640, -1, -1, -1}, {48643, -1, -1, -1}, {48645, -1, -1, -1}, {48652, -1, -1, -1}, {48653, -1, -1, -1}, {48656, -1, -1, -1}, {48660, -1, -1, -1}, {48668, -1, -1, -1}, {48669, -1, -1, -1}, {48671, -1, -1, -1}, {48708, -1, -1, -1}, {48709, -1, -1, -1}, {48712, -1, -1, -1}, {48716, -1, -1, -1}, {48718, -1, -1, -1}, {48724, -1, -1, -1}, {48725, -1, -1, -1}, {48727, -1, -1, -1}, {48729, -1, -1, -1}, {48730, -1, -1, -1}, {48731, -1, -1, -1}, {48736, -1, -1, -1}, {48737, -1, -1, -1}, {48740, -1, -1, -1}, {48744, -1, -1, -1}, {48746, -1, -1, -1}, {48752, -1, -1, -1}, {48753, -1, -1, -1}, {48755, -1, -1, -1}, {48756, -1, -1, -1}, {48757, -1, -1, -1}, {48763, -1, -1, -1}, {48764, -1, -1, -1}, {48765, -1, -1, -1}, {48768, -1, -1, -1}, {48772, -1, -1, -1}, {48780, -1, -1, -1}, {48781, -1, -1, -1}, {48783, -1, -1, -1}, {48784, -1, -1, -1}, {48785, -1, -1, -1}, {48792, -1, -1, -1}, {48793, -1, -1, -1}, {48808, -1, -1, -1}, {48848, -1, -1, -1}, {48849, -1, -1, -1}, {48852, -1, -1, -1}, {48855, -1, -1, -1}, {48856, -1, -1, -1}, {48864, -1, -1, -1}, {48867, -1, -1, -1}, {48868, -1, -1, -1}, {48869, -1, -1, -1}, {48876, -1, -1, -1}, {48897, -1, -1, -1}, {48904, -1, -1, -1}, {48905, -1, -1, -1}, {48920, -1, -1, -1}, {48921, -1, -1, -1}, {48923, -1, -1, -1}, {48924, -1, -1, -1}, {48925, -1, -1, -1}, {48960, -1, -1, -1}, {48961, -1, -1, -1}, {48964, -1, -1, -1}, {48968, -1, -1, -1}, {48976, -1, -1, -1}, {48977, -1, -1, -1}, {48981, -1, -1, -1}, {49044, -1, -1, -1}, {49072, -1, -1, -1}, {49093, -1, -1, -1}, {49100, -1, -1, -1}, {49101, -1, -1, -1}, {49104, -1, -1, -1}, {49108, -1, -1, -1}, {49116, -1, -1, -1}, {49119, -1, -1, -1}, {49121, -1, -1, -1}, {49212, -1, -1, -1}, {49233, -1, -1, -1}, {49240, -1, -1, -1}, {49244, -1, -1, -1}, {49248, -1, -1, -1}, {49256, -1, -1, -1}, {49257, -1, -1, -1}, {49296, -1, -1, -1}, {49297, -1, -1, -1}, {49300, -1, -1, -1}, {49304, -1, -1, -1}, {49312, -1, -1, -1}, {49313, -1, -1, -1}, {49315, -1, -1, -1}, {49317, -1, -1, -1}, {49324, -1, -1, -1}, {49325, -1, -1, -1}, {49327, -1, -1, -1}, {49328, -1, -1, -1}, {49331, -1, -1, -1}, {49332, -1, -1, -1}, {49333, -1, -1, -1}, {49334, -1, -1, -1}, {49340, -1, -1, -1}, {49341, -1, -1, -1}, {49343, -1, -1, -1}, {49344, -1, -1, -1}, {49345, -1, -1, -1}, {49349, -1, -1, -1}, {49352, -1, -1, -1}, {49353, -1, -1, -1}, {49356, -1, -1, -1}, {49360, -1, -1, -1}, {49368, -1, -1, -1}, {49369, -1, -1, -1}, {49371, -1, -1, -1}, {49372, -1, -1, -1}, {49373, -1, -1, -1}, {49380, -1, -1, -1}, {49381, -1, -1, -1}, {49384, -1, -1, -1}, {49388, -1, -1, -1}, {49396, -1, -1, -1}, {49397, -1, -1, -1}, {49399, -1, -1, -1}, {49401, -1, -1, -1}, {49408, -1, -1, -1}, {49412, -1, -1, -1}, {49416, -1, -1, -1}, {49424, -1, -1, -1}, {49429, -1, -1, -1}, {49436, -1, -1, -1}, {49437, -1, -1, -1}, {49438, -1, -1, -1}, {49439, -1, -1, -1}, {49440, -1, -1, -1}, {49443, -1, -1, -1}, {49444, -1, -1, -1}, {49446, -1, -1, -1}, {49447, -1, -1, -1}, {49452, -1, -1, -1}, {49453, -1, -1, -1}, {49455, -1, -1, -1}, {49456, -1, -1, -1}, {49457, -1, -1, -1}, {49462, -1, -1, -1}, {49464, -1, -1, -1}, {49465, -1, -1, -1}, {49468, -1, -1, -1}, {49472, -1, -1, -1}, {49480, -1, -1, -1}, {49481, -1, -1, -1}, {49483, -1, -1, -1}, {49484, -1, -1, -1}, {49485, -1, -1, -1}, {49492, -1, -1, -1}, {49493, -1, -1, -1}, {49496, -1, -1, -1}, {49500, -1, -1, -1}, {49508, -1, -1, -1}, {49509, -1, -1, -1}, {49511, -1, -1, -1}, {49512, -1, -1, -1}, {49513, -1, -1, -1}, {49520, -1, -1, -1}, {49524, -1, -1, -1}, {49528, -1, -1, -1}, {49541, -1, -1, -1}, {49548, -1, -1, -1}, {49549, -1, -1, -1}, {49550, -1, -1, -1}, {49552, -1, -1, -1}, {49556, -1, -1, -1}, {49558, -1, -1, -1}, {49564, -1, -1, -1}, {49565, -1, -1, -1}, {49567, -1, -1, -1}, {49569, -1, -1, -1}, {49573, -1, -1, -1}, {49576, -1, -1, -1}, {49577, -1, -1, -1}, {49580, -1, -1, -1}, {49584, -1, -1, -1}, {49597, -1, -1, -1}, {49604, -1, -1, -1}, {49608, -1, -1, -1}, {49612, -1, -1, -1}, {49620, -1, -1, -1}, {49623, -1, -1, -1}, {49624, -1, -1, -1}, {49632, -1, -1, -1}, {49636, -1, -1, -1}, {49640, -1, -1, -1}, {49648, -1, -1, -1}, {49649, -1, -1, -1}, {49651, -1, -1, -1}, {49660, -1, -1, -1}, {49661, -1, -1, -1}, {49664, -1, -1, -1}, {49668, -1, -1, -1}, {49676, -1, -1, -1}, {49677, -1, -1, -1}, {49679, -1, -1, -1}, {49681, -1, -1, -1}, {49688, -1, -1, -1}, {49689, -1, -1, -1}, {49692, -1, -1, -1}, {49695, -1, -1, -1}, {49696, -1, -1, -1} },
+ {{49704, -1, -1, -1}, {49705, -1, -1, -1}, {49707, -1, -1, -1}, {49709, -1, -1, -1}, {49711, -1, -1, -1}, {49713, -1, -1, -1}, {49714, -1, -1, -1}, {49716, -1, -1, -1}, {49736, -1, -1, -1}, {49744, -1, -1, -1}, {49745, -1, -1, -1}, {49748, -1, -1, -1}, {49752, -1, -1, -1}, {49760, -1, -1, -1}, {49765, -1, -1, -1}, {49772, -1, -1, -1}, {49773, -1, -1, -1}, {49776, -1, -1, -1}, {49780, -1, -1, -1}, {49788, -1, -1, -1}, {49789, -1, -1, -1}, {49791, -1, -1, -1}, {49793, -1, -1, -1}, {49800, -1, -1, -1}, {49801, -1, -1, -1}, {49808, -1, -1, -1}, {49816, -1, -1, -1}, {49819, -1, -1, -1}, {49821, -1, -1, -1}, {49828, -1, -1, -1}, {49829, -1, -1, -1}, {49832, -1, -1, -1}, {49836, -1, -1, -1}, {49837, -1, -1, -1}, {49844, -1, -1, -1}, {49845, -1, -1, -1}, {49847, -1, -1, -1}, {49849, -1, -1, -1}, {49884, -1, -1, -1}, {49885, -1, -1, -1}, {49888, -1, -1, -1}, {49891, -1, -1, -1}, {49892, -1, -1, -1}, {49899, -1, -1, -1}, {49900, -1, -1, -1}, {49901, -1, -1, -1}, {49903, -1, -1, -1}, {49905, -1, -1, -1}, {49910, -1, -1, -1}, {49912, -1, -1, -1}, {49913, -1, -1, -1}, {49915, -1, -1, -1}, {49916, -1, -1, -1}, {49920, -1, -1, -1}, {49928, -1, -1, -1}, {49929, -1, -1, -1}, {49932, -1, -1, -1}, {49933, -1, -1, -1}, {49939, -1, -1, -1}, {49940, -1, -1, -1}, {49941, -1, -1, -1}, {49944, -1, -1, -1}, {49948, -1, -1, -1}, {49956, -1, -1, -1}, {49957, -1, -1, -1}, {49960, -1, -1, -1}, {49961, -1, -1, -1}, {49989, -1, -1, -1}, {50024, -1, -1, -1}, {50025, -1, -1, -1}, {50028, -1, -1, -1}, {50032, -1, -1, -1}, {50034, -1, -1, -1}, {50040, -1, -1, -1}, {50041, -1, -1, -1}, {50044, -1, -1, -1}, {50045, -1, -1, -1}, {50052, -1, -1, -1}, {50056, -1, -1, -1}, {50060, -1, -1, -1}, {50112, -1, -1, -1}, {50136, -1, -1, -1}, {50137, -1, -1, -1}, {50140, -1, -1, -1}, {50143, -1, -1, -1}, {50144, -1, -1, -1}, {50146, -1, -1, -1}, {50152, -1, -1, -1}, {50153, -1, -1, -1}, {50157, -1, -1, -1}, {50164, -1, -1, -1}, {50165, -1, -1, -1}, {50168, -1, -1, -1}, {50184, -1, -1, -1}, {50192, -1, -1, -1}, {50212, -1, -1, -1}, {50220, -1, -1, -1}, {50224, -1, -1, -1}, {50228, -1, -1, -1}, {50236, -1, -1, -1}, {50237, -1, -1, -1}, {50248, -1, -1, -1}, {50276, -1, -1, -1}, {50277, -1, -1, -1}, {50280, -1, -1, -1}, {50284, -1, -1, -1}, {50292, -1, -1, -1}, {50293, -1, -1, -1}, {50297, -1, -1, -1}, {50304, -1, -1, -1}, {50324, -1, -1, -1}, {50332, -1, -1, -1}, {50360, -1, -1, -1}, {50364, -1, -1, -1}, {50409, -1, -1, -1}, {50416, -1, -1, -1}, {50417, -1, -1, -1}, {50420, -1, -1, -1}, {50424, -1, -1, -1}, {50426, -1, -1, -1}, {50431, -1, -1, -1}, {50432, -1, -1, -1}, {50433, -1, -1, -1}, {50444, -1, -1, -1}, {50448, -1, -1, -1}, {50452, -1, -1, -1}, {50460, -1, -1, -1}, {50472, -1, -1, -1}, {50473, -1, -1, -1}, {50476, -1, -1, -1}, {50480, -1, -1, -1}, {50488, -1, -1, -1}, {50489, -1, -1, -1}, {50491, -1, -1, -1}, {50493, -1, -1, -1}, {50500, -1, -1, -1}, {50501, -1, -1, -1}, {50504, -1, -1, -1}, {50505, -1, -1, -1}, {50506, -1, -1, -1}, {50508, -1, -1, -1}, {50509, -1, -1, -1}, {50510, -1, -1, -1}, {50515, -1, -1, -1}, {50516, -1, -1, -1}, {50517, -1, -1, -1}, {50519, -1, -1, -1}, {50520, -1, -1, -1}, {50521, -1, -1, -1}, {50525, -1, -1, -1}, {50526, -1, -1, -1}, {50528, -1, -1, -1}, {50529, -1, -1, -1}, {50532, -1, -1, -1}, {50536, -1, -1, -1}, {50544, -1, -1, -1}, {50545, -1, -1, -1}, {50547, -1, -1, -1}, {50548, -1, -1, -1}, {50549, -1, -1, -1}, {50556, -1, -1, -1}, {50557, -1, -1, -1}, {50560, -1, -1, -1}, {50564, -1, -1, -1}, {50567, -1, -1, -1}, {50572, -1, -1, -1}, {50573, -1, -1, -1}, {50575, -1, -1, -1}, {50577, -1, -1, -1}, {50581, -1, -1, -1}, {50583, -1, -1, -1}, {50584, -1, -1, -1}, {50588, -1, -1, -1}, {50592, -1, -1, -1}, {50601, -1, -1, -1}, {50612, -1, -1, -1}, {50613, -1, -1, -1}, {50616, -1, -1, -1}, {50617, -1, -1, -1}, {50619, -1, -1, -1}, {50620, -1, -1, -1}, {50621, -1, -1, -1}, {50622, -1, -1, -1}, {50628, -1, -1, -1}, {50629, -1, -1, -1}, {50630, -1, -1, -1}, {50631, -1, -1, -1}, {50632, -1, -1, -1}, {50633, -1, -1, -1}, {50634, -1, -1, -1}, {50636, -1, -1, -1}, {50638, -1, -1, -1}, {50640, -1, -1, -1}, {50641, -1, -1, -1}, {50644, -1, -1, -1}, {50648, -1, -1, -1}, {50656, -1, -1, -1}, {50657, -1, -1, -1}, {50659, -1, -1, -1}, {50661, -1, -1, -1}, {50668, -1, -1, -1}, {50669, -1, -1, -1}, {50670, -1, -1, -1}, {50672, -1, -1, -1}, {50676, -1, -1, -1}, {50678, -1, -1, -1}, {50679, -1, -1, -1}, {50684, -1, -1, -1}, {50685, -1, -1, -1}, {50686, -1, -1, -1}, {50687, -1, -1, -1}, {50688, -1, -1, -1}, {50689, -1, -1, -1}, {50693, -1, -1, -1}, {50694, -1, -1, -1}, {50695, -1, -1, -1}, {50696, -1, -1, -1}, {50700, -1, -1, -1}, {50704, -1, -1, -1}, {50712, -1, -1, -1}, {50713, -1, -1, -1}, {50715, -1, -1, -1}, {50716, -1, -1, -1}, {50724, -1, -1, -1}, {50725, -1, -1, -1}, {50728, -1, -1, -1}, {50732, -1, -1, -1}, {50733, -1, -1, -1}, {50734, -1, -1, -1}, {50736, -1, -1, -1}, {50739, -1, -1, -1}, {50740, -1, -1, -1}, {50741, -1, -1, -1}, {50743, -1, -1, -1}, {50745, -1, -1, -1}, {50747, -1, -1, -1}, {50752, -1, -1, -1}, {50753, -1, -1, -1}, {50756, -1, -1, -1}, {50760, -1, -1, -1}, {50768, -1, -1, -1}, {50769, -1, -1, -1}, {50771, -1, -1, -1}, {50772, -1, -1, -1}, {50773, -1, -1, -1}, {50780, -1, -1, -1}, {50781, -1, -1, -1}, {50784, -1, -1, -1}, {50796, -1, -1, -1}, {50799, -1, -1, -1}, {50801, -1, -1, -1}, {50808, -1, -1, -1}, {50809, -1, -1, -1}, {50812, -1, -1, -1}, {50816, -1, -1, -1}, {50824, -1, -1, -1} },
+ {{50825, -1, -1, -1}, {50827, -1, -1, -1}, {50829, -1, -1, -1}, {50836, -1, -1, -1}, {50837, -1, -1, -1}, {50840, -1, -1, -1}, {50844, -1, -1, -1}, {50852, -1, -1, -1}, {50853, -1, -1, -1}, {50855, -1, -1, -1}, {50857, -1, -1, -1}, {50864, -1, -1, -1}, {50865, -1, -1, -1}, {50868, -1, -1, -1}, {50872, -1, -1, -1}, {50873, -1, -1, -1}, {50874, -1, -1, -1}, {50880, -1, -1, -1}, {50881, -1, -1, -1}, {50883, -1, -1, -1}, {50885, -1, -1, -1}, {50892, -1, -1, -1}, {50893, -1, -1, -1}, {50896, -1, -1, -1}, {50900, -1, -1, -1}, {50908, -1, -1, -1}, {50909, -1, -1, -1}, {50912, -1, -1, -1}, {50913, -1, -1, -1}, {50920, -1, -1, -1}, {50921, -1, -1, -1}, {50924, -1, -1, -1}, {50928, -1, -1, -1}, {50936, -1, -1, -1}, {50937, -1, -1, -1}, {50941, -1, -1, -1}, {50948, -1, -1, -1}, {50949, -1, -1, -1}, {50952, -1, -1, -1}, {50956, -1, -1, -1}, {50964, -1, -1, -1}, {50965, -1, -1, -1}, {50967, -1, -1, -1}, {50969, -1, -1, -1}, {50976, -1, -1, -1}, {50977, -1, -1, -1}, {50980, -1, -1, -1}, {50984, -1, -1, -1}, {50992, -1, -1, -1}, {50993, -1, -1, -1}, {50995, -1, -1, -1}, {50997, -1, -1, -1}, {50999, -1, -1, -1}, {51004, -1, -1, -1}, {51005, -1, -1, -1}, {51008, -1, -1, -1}, {51012, -1, -1, -1}, {51018, -1, -1, -1}, {51020, -1, -1, -1}, {51021, -1, -1, -1}, {51023, -1, -1, -1}, {51025, -1, -1, -1}, {51026, -1, -1, -1}, {51027, -1, -1, -1}, {51028, -1, -1, -1}, {51029, -1, -1, -1}, {51030, -1, -1, -1}, {51031, -1, -1, -1}, {51032, -1, -1, -1}, {51036, -1, -1, -1}, {51040, -1, -1, -1}, {51048, -1, -1, -1}, {51051, -1, -1, -1}, {51060, -1, -1, -1}, {51061, -1, -1, -1}, {51064, -1, -1, -1}, {51068, -1, -1, -1}, {51069, -1, -1, -1}, {51070, -1, -1, -1}, {51075, -1, -1, -1}, {51076, -1, -1, -1}, {51077, -1, -1, -1}, {51079, -1, -1, -1}, {51080, -1, -1, -1}, {51081, -1, -1, -1}, {51082, -1, -1, -1}, {51086, -1, -1, -1}, {51088, -1, -1, -1}, {51089, -1, -1, -1}, {51092, -1, -1, -1}, {51094, -1, -1, -1}, {51095, -1, -1, -1}, {51096, -1, -1, -1}, {51098, -1, -1, -1}, {51104, -1, -1, -1}, {51105, -1, -1, -1}, {51107, -1, -1, -1}, {51108, -1, -1, -1}, {51109, -1, -1, -1}, {51110, -1, -1, -1}, {51116, -1, -1, -1}, {51117, -1, -1, -1}, {51120, -1, -1, -1}, {51124, -1, -1, -1}, {51132, -1, -1, -1}, {51133, -1, -1, -1}, {51135, -1, -1, -1}, {51136, -1, -1, -1}, {51137, -1, -1, -1}, {51144, -1, -1, -1}, {51145, -1, -1, -1}, {51148, -1, -1, -1}, {51150, -1, -1, -1}, {51152, -1, -1, -1}, {51160, -1, -1, -1}, {51165, -1, -1, -1}, {51172, -1, -1, -1}, {51176, -1, -1, -1}, {51180, -1, -1, -1}, {51200, -1, -1, -1}, {51201, -1, -1, -1}, {51204, -1, -1, -1}, {51208, -1, -1, -1}, {51210, -1, -1, -1}, {51216, -1, -1, -1}, {51217, -1, -1, -1}, {51219, -1, -1, -1}, {51221, -1, -1, -1}, {51222, -1, -1, -1}, {51228, -1, -1, -1}, {51229, -1, -1, -1}, {51232, -1, -1, -1}, {51236, -1, -1, -1}, {51244, -1, -1, -1}, {51245, -1, -1, -1}, {51247, -1, -1, -1}, {51249, -1, -1, -1}, {51256, -1, -1, -1}, {51260, -1, -1, -1}, {51264, -1, -1, -1}, {51272, -1, -1, -1}, {51273, -1, -1, -1}, {51276, -1, -1, -1}, {51277, -1, -1, -1}, {51284, -1, -1, -1}, {51312, -1, -1, -1}, {51313, -1, -1, -1}, {51316, -1, -1, -1}, {51320, -1, -1, -1}, {51322, -1, -1, -1}, {51328, -1, -1, -1}, {51329, -1, -1, -1}, {51331, -1, -1, -1}, {51333, -1, -1, -1}, {51334, -1, -1, -1}, {51335, -1, -1, -1}, {51339, -1, -1, -1}, {51340, -1, -1, -1}, {51341, -1, -1, -1}, {51348, -1, -1, -1}, {51357, -1, -1, -1}, {51359, -1, -1, -1}, {51361, -1, -1, -1}, {51368, -1, -1, -1}, {51388, -1, -1, -1}, {51389, -1, -1, -1}, {51396, -1, -1, -1}, {51400, -1, -1, -1}, {51404, -1, -1, -1}, {51412, -1, -1, -1}, {51413, -1, -1, -1}, {51415, -1, -1, -1}, {51417, -1, -1, -1}, {51424, -1, -1, -1}, {51425, -1, -1, -1}, {51428, -1, -1, -1}, {51445, -1, -1, -1}, {51452, -1, -1, -1}, {51453, -1, -1, -1}, {51456, -1, -1, -1}, {51460, -1, -1, -1}, {51461, -1, -1, -1}, {51462, -1, -1, -1}, {51468, -1, -1, -1}, {51469, -1, -1, -1}, {51471, -1, -1, -1}, {51473, -1, -1, -1}, {51480, -1, -1, -1}, {51500, -1, -1, -1}, {51508, -1, -1, -1}, {51536, -1, -1, -1}, {51537, -1, -1, -1}, {51540, -1, -1, -1}, {51544, -1, -1, -1}, {51552, -1, -1, -1}, {51553, -1, -1, -1}, {51555, -1, -1, -1}, {51564, -1, -1, -1}, {51568, -1, -1, -1}, {51572, -1, -1, -1}, {51580, -1, -1, -1}, {51592, -1, -1, -1}, {51593, -1, -1, -1}, {51596, -1, -1, -1}, {51600, -1, -1, -1}, {51608, -1, -1, -1}, {51609, -1, -1, -1}, {51611, -1, -1, -1}, {51613, -1, -1, -1}, {51648, -1, -1, -1}, {51649, -1, -1, -1}, {51652, -1, -1, -1}, {51655, -1, -1, -1}, {51656, -1, -1, -1}, {51658, -1, -1, -1}, {51664, -1, -1, -1}, {51665, -1, -1, -1}, {51667, -1, -1, -1}, {51669, -1, -1, -1}, {51670, -1, -1, -1}, {51673, -1, -1, -1}, {51674, -1, -1, -1}, {51676, -1, -1, -1}, {51677, -1, -1, -1}, {51680, -1, -1, -1}, {51682, -1, -1, -1}, {51684, -1, -1, -1}, {51687, -1, -1, -1}, {51692, -1, -1, -1}, {51693, -1, -1, -1}, {51695, -1, -1, -1}, {51696, -1, -1, -1}, {51697, -1, -1, -1}, {51704, -1, -1, -1}, {51705, -1, -1, -1}, {51708, -1, -1, -1}, {51712, -1, -1, -1}, {51720, -1, -1, -1}, {51721, -1, -1, -1}, {51723, -1, -1, -1}, {51724, -1, -1, -1}, {51725, -1, -1, -1}, {51732, -1, -1, -1}, {51736, -1, -1, -1}, {51753, -1, -1, -1}, {51788, -1, -1, -1}, {51789, -1, -1, -1}, {51792, -1, -1, -1}, {51796, -1, -1, -1}, {51804, -1, -1, -1}, {51805, -1, -1, -1}, {51807, -1, -1, -1}, {51808, -1, -1, -1}, {51809, -1, -1, -1}, {51816, -1, -1, -1}, {51837, -1, -1, -1} },
+ {{51844, -1, -1, -1}, {51864, -1, -1, -1}, {51900, -1, -1, -1}, {51901, -1, -1, -1}, {51904, -1, -1, -1}, {51908, -1, -1, -1}, {51916, -1, -1, -1}, {51917, -1, -1, -1}, {51919, -1, -1, -1}, {51921, -1, -1, -1}, {51923, -1, -1, -1}, {51928, -1, -1, -1}, {51929, -1, -1, -1}, {51936, -1, -1, -1}, {51948, -1, -1, -1}, {51956, -1, -1, -1}, {51976, -1, -1, -1}, {51984, -1, -1, -1}, {51988, -1, -1, -1}, {51992, -1, -1, -1}, {52000, -1, -1, -1}, {52001, -1, -1, -1}, {52033, -1, -1, -1}, {52040, -1, -1, -1}, {52041, -1, -1, -1}, {52044, -1, -1, -1}, {52048, -1, -1, -1}, {52056, -1, -1, -1}, {52057, -1, -1, -1}, {52061, -1, -1, -1}, {52068, -1, -1, -1}, {52088, -1, -1, -1}, {52089, -1, -1, -1}, {52124, -1, -1, -1}, {52152, -1, -1, -1}, {52180, -1, -1, -1}, {52196, -1, -1, -1}, {52199, -1, -1, -1}, {52201, -1, -1, -1}, {52236, -1, -1, -1}, {52237, -1, -1, -1}, {52240, -1, -1, -1}, {52244, -1, -1, -1}, {52252, -1, -1, -1}, {52253, -1, -1, -1}, {52257, -1, -1, -1}, {52258, -1, -1, -1}, {52263, -1, -1, -1}, {52264, -1, -1, -1}, {52265, -1, -1, -1}, {52268, -1, -1, -1}, {52270, -1, -1, -1}, {52272, -1, -1, -1}, {52280, -1, -1, -1}, {52281, -1, -1, -1}, {52283, -1, -1, -1}, {52284, -1, -1, -1}, {52285, -1, -1, -1}, {52286, -1, -1, -1}, {52292, -1, -1, -1}, {52293, -1, -1, -1}, {52296, -1, -1, -1}, {52300, -1, -1, -1}, {52308, -1, -1, -1}, {52309, -1, -1, -1}, {52311, -1, -1, -1}, {52312, -1, -1, -1}, {52313, -1, -1, -1}, {52320, -1, -1, -1}, {52324, -1, -1, -1}, {52326, -1, -1, -1}, {52328, -1, -1, -1}, {52336, -1, -1, -1}, {52341, -1, -1, -1}, {52376, -1, -1, -1}, {52377, -1, -1, -1}, {52380, -1, -1, -1}, {52384, -1, -1, -1}, {52392, -1, -1, -1}, {52393, -1, -1, -1}, {52395, -1, -1, -1}, {52396, -1, -1, -1}, {52397, -1, -1, -1}, {52404, -1, -1, -1}, {52405, -1, -1, -1}, {52408, -1, -1, -1}, {52412, -1, -1, -1}, {52420, -1, -1, -1}, {52421, -1, -1, -1}, {52423, -1, -1, -1}, {52425, -1, -1, -1}, {52432, -1, -1, -1}, {52436, -1, -1, -1}, {52452, -1, -1, -1}, {52460, -1, -1, -1}, {52464, -1, -1, -1}, {52481, -1, -1, -1}, {52488, -1, -1, -1}, {52489, -1, -1, -1}, {52492, -1, -1, -1}, {52496, -1, -1, -1}, {52504, -1, -1, -1}, {52505, -1, -1, -1}, {52507, -1, -1, -1}, {52509, -1, -1, -1}, {52516, -1, -1, -1}, {52520, -1, -1, -1}, {52524, -1, -1, -1}, {52537, -1, -1, -1}, {52572, -1, -1, -1}, {52576, -1, -1, -1}, {52580, -1, -1, -1}, {52588, -1, -1, -1}, {52589, -1, -1, -1}, {52591, -1, -1, -1}, {52593, -1, -1, -1}, {52600, -1, -1, -1}, {52616, -1, -1, -1}, {52628, -1, -1, -1}, {52629, -1, -1, -1}, {52632, -1, -1, -1}, {52636, -1, -1, -1}, {52644, -1, -1, -1}, {52645, -1, -1, -1}, {52647, -1, -1, -1}, {52649, -1, -1, -1}, {52656, -1, -1, -1}, {52676, -1, -1, -1}, {52684, -1, -1, -1}, {52688, -1, -1, -1}, {52712, -1, -1, -1}, {52716, -1, -1, -1}, {52720, -1, -1, -1}, {52728, -1, -1, -1}, {52729, -1, -1, -1}, {52731, -1, -1, -1}, {52733, -1, -1, -1}, {52740, -1, -1, -1}, {52744, -1, -1, -1}, {52748, -1, -1, -1}, {52756, -1, -1, -1}, {52761, -1, -1, -1}, {52768, -1, -1, -1}, {52769, -1, -1, -1}, {52772, -1, -1, -1}, {52776, -1, -1, -1}, {52784, -1, -1, -1}, {52785, -1, -1, -1}, {52787, -1, -1, -1}, {52789, -1, -1, -1}, {52824, -1, -1, -1}, {52825, -1, -1, -1}, {52828, -1, -1, -1}, {52831, -1, -1, -1}, {52832, -1, -1, -1}, {52833, -1, -1, -1}, {52840, -1, -1, -1}, {52841, -1, -1, -1}, {52843, -1, -1, -1}, {52845, -1, -1, -1}, {52852, -1, -1, -1}, {52853, -1, -1, -1}, {52856, -1, -1, -1}, {52860, -1, -1, -1}, {52868, -1, -1, -1}, {52869, -1, -1, -1}, {52871, -1, -1, -1}, {52873, -1, -1, -1}, {52880, -1, -1, -1}, {52881, -1, -1, -1}, {52884, -1, -1, -1}, {52888, -1, -1, -1}, {52896, -1, -1, -1}, {52897, -1, -1, -1}, {52899, -1, -1, -1}, {52900, -1, -1, -1}, {52901, -1, -1, -1}, {52908, -1, -1, -1}, {52909, -1, -1, -1}, {52929, -1, -1, -1}, {52964, -1, -1, -1}, {52965, -1, -1, -1}, {52968, -1, -1, -1}, {52971, -1, -1, -1}, {52972, -1, -1, -1}, {52980, -1, -1, -1}, {52981, -1, -1, -1}, {52983, -1, -1, -1}, {52984, -1, -1, -1}, {52985, -1, -1, -1}, {52992, -1, -1, -1}, {52993, -1, -1, -1}, {52996, -1, -1, -1}, {53000, -1, -1, -1}, {53008, -1, -1, -1}, {53009, -1, -1, -1}, {53011, -1, -1, -1}, {53013, -1, -1, -1}, {53020, -1, -1, -1}, {53024, -1, -1, -1}, {53028, -1, -1, -1}, {53036, -1, -1, -1}, {53037, -1, -1, -1}, {53039, -1, -1, -1}, {53040, -1, -1, -1}, {53041, -1, -1, -1}, {53048, -1, -1, -1}, {53076, -1, -1, -1}, {53077, -1, -1, -1}, {53080, -1, -1, -1}, {53084, -1, -1, -1}, {53092, -1, -1, -1}, {53093, -1, -1, -1}, {53095, -1, -1, -1}, {53097, -1, -1, -1}, {53104, -1, -1, -1}, {53105, -1, -1, -1}, {53108, -1, -1, -1}, {53112, -1, -1, -1}, {53120, -1, -1, -1}, {53125, -1, -1, -1}, {53132, -1, -1, -1}, {53153, -1, -1, -1}, {53160, -1, -1, -1}, {53168, -1, -1, -1}, {53188, -1, -1, -1}, {53216, -1, -1, -1}, {53217, -1, -1, -1}, {53220, -1, -1, -1}, {53224, -1, -1, -1}, {53232, -1, -1, -1}, {53233, -1, -1, -1}, {53235, -1, -1, -1}, {53237, -1, -1, -1}, {53244, -1, -1, -1}, {53248, -1, -1, -1}, {53252, -1, -1, -1}, {53265, -1, -1, -1}, {53272, -1, -1, -1}, {53293, -1, -1, -1}, {53300, -1, -1, -1}, {53301, -1, -1, -1}, {53304, -1, -1, -1}, {53308, -1, -1, -1}, {53316, -1, -1, -1}, {53317, -1, -1, -1}, {53319, -1, -1, -1}, {53321, -1, -1, -1}, {53328, -1, -1, -1}, {53332, -1, -1, -1}, {53336, -1, -1, -1}, {53344, -1, -1, -1}, {53356, -1, -1, -1}, {53357, -1, -1, -1}, {53360, -1, -1, -1}, {53364, -1, -1, -1} },
+ {{53372, -1, -1, -1}, {53373, -1, -1, -1}, {53377, -1, -1, -1}, {53412, -1, -1, -1}, {53413, -1, -1, -1}, {53416, -1, -1, -1}, {53420, -1, -1, -1}, {53428, -1, -1, -1}, {53429, -1, -1, -1}, {53431, -1, -1, -1}, {53433, -1, -1, -1}, {53440, -1, -1, -1}, {53441, -1, -1, -1}, {53444, -1, -1, -1}, {53448, -1, -1, -1}, {53449, -1, -1, -1}, {53456, -1, -1, -1}, {53457, -1, -1, -1}, {53459, -1, -1, -1}, {53460, -1, -1, -1}, {53461, -1, -1, -1}, {53468, -1, -1, -1}, {53469, -1, -1, -1}, {53472, -1, -1, -1}, {53476, -1, -1, -1}, {53484, -1, -1, -1}, {53485, -1, -1, -1}, {53487, -1, -1, -1}, {53488, -1, -1, -1}, {53489, -1, -1, -1}, {53496, -1, -1, -1}, {53517, -1, -1, -1}, {53552, -1, -1, -1}, {53553, -1, -1, -1}, {53556, -1, -1, -1}, {53560, -1, -1, -1}, {53562, -1, -1, -1}, {53568, -1, -1, -1}, {53569, -1, -1, -1}, {53571, -1, -1, -1}, {53572, -1, -1, -1}, {53573, -1, -1, -1}, {53580, -1, -1, -1}, {53581, -1, -1, -1}, {53584, -1, -1, -1}, {53588, -1, -1, -1}, {53596, -1, -1, -1}, {53597, -1, -1, -1}, {53599, -1, -1, -1}, {53601, -1, -1, -1}, {53608, -1, -1, -1}, {53612, -1, -1, -1}, {53628, -1, -1, -1}, {53636, -1, -1, -1}, {53640, -1, -1, -1}, {53664, -1, -1, -1}, {53665, -1, -1, -1}, {53668, -1, -1, -1}, {53672, -1, -1, -1}, {53680, -1, -1, -1}, {53681, -1, -1, -1}, {53683, -1, -1, -1}, {53685, -1, -1, -1}, {53690, -1, -1, -1}, {53692, -1, -1, -1}, {53696, -1, -1, -1}, {53720, -1, -1, -1}, {53748, -1, -1, -1}, {53752, -1, -1, -1}, {53767, -1, -1, -1}, {53769, -1, -1, -1}, {53776, -1, -1, -1}, {53804, -1, -1, -1}, {53805, -1, -1, -1}, {53808, -1, -1, -1}, {53812, -1, -1, -1}, {53820, -1, -1, -1}, {53821, -1, -1, -1}, {53823, -1, -1, -1}, {53825, -1, -1, -1}, {53832, -1, -1, -1}, {53852, -1, -1, -1}, {53860, -1, -1, -1}, {53888, -1, -1, -1}, {53889, -1, -1, -1}, {53892, -1, -1, -1}, {53896, -1, -1, -1}, {53904, -1, -1, -1}, {53905, -1, -1, -1}, {53909, -1, -1, -1}, {53916, -1, -1, -1}, {53920, -1, -1, -1}, {53924, -1, -1, -1}, {53932, -1, -1, -1}, {53937, -1, -1, -1}, {53944, -1, -1, -1}, {53945, -1, -1, -1}, {53948, -1, -1, -1}, {53951, -1, -1, -1}, {53952, -1, -1, -1}, {53954, -1, -1, -1}, {53960, -1, -1, -1}, {53961, -1, -1, -1}, {53963, -1, -1, -1}, {53972, -1, -1, -1}, {53976, -1, -1, -1}, {53980, -1, -1, -1}, {53988, -1, -1, -1}, {53989, -1, -1, -1}, {54000, -1, -1, -1}, {54001, -1, -1, -1}, {54004, -1, -1, -1}, {54008, -1, -1, -1}, {54016, -1, -1, -1}, {54017, -1, -1, -1}, {54019, -1, -1, -1}, {54021, -1, -1, -1}, {54028, -1, -1, -1}, {54029, -1, -1, -1}, {54030, -1, -1, -1}, {54032, -1, -1, -1}, {54036, -1, -1, -1}, {54038, -1, -1, -1}, {54044, -1, -1, -1}, {54045, -1, -1, -1}, {54047, -1, -1, -1}, {54048, -1, -1, -1}, {54049, -1, -1, -1}, {54053, -1, -1, -1}, {54056, -1, -1, -1}, {54057, -1, -1, -1}, {54060, -1, -1, -1}, {54064, -1, -1, -1}, {54072, -1, -1, -1}, {54073, -1, -1, -1}, {54075, -1, -1, -1}, {54076, -1, -1, -1}, {54077, -1, -1, -1}, {54084, -1, -1, -1}, {54085, -1, -1, -1}, {54140, -1, -1, -1}, {54141, -1, -1, -1}, {54144, -1, -1, -1}, {54148, -1, -1, -1}, {54156, -1, -1, -1}, {54157, -1, -1, -1}, {54159, -1, -1, -1}, {54160, -1, -1, -1}, {54161, -1, -1, -1}, {54168, -1, -1, -1}, {54169, -1, -1, -1}, {54172, -1, -1, -1}, {54176, -1, -1, -1}, {54184, -1, -1, -1}, {54185, -1, -1, -1}, {54187, -1, -1, -1}, {54189, -1, -1, -1}, {54196, -1, -1, -1}, {54200, -1, -1, -1}, {54204, -1, -1, -1}, {54212, -1, -1, -1}, {54213, -1, -1, -1}, {54216, -1, -1, -1}, {54217, -1, -1, -1}, {54224, -1, -1, -1}, {54232, -1, -1, -1}, {54241, -1, -1, -1}, {54243, -1, -1, -1}, {54252, -1, -1, -1}, {54253, -1, -1, -1}, {54256, -1, -1, -1}, {54260, -1, -1, -1}, {54268, -1, -1, -1}, {54269, -1, -1, -1}, {54271, -1, -1, -1}, {54273, -1, -1, -1}, {54280, -1, -1, -1}, {54301, -1, -1, -1}, {54336, -1, -1, -1}, {54340, -1, -1, -1}, {54364, -1, -1, -1}, {54368, -1, -1, -1}, {54372, -1, -1, -1}, {54381, -1, -1, -1}, {54383, -1, -1, -1}, {54392, -1, -1, -1}, {54393, -1, -1, -1}, {54396, -1, -1, -1}, {54399, -1, -1, -1}, {54400, -1, -1, -1}, {54402, -1, -1, -1}, {54408, -1, -1, -1}, {54409, -1, -1, -1}, {54411, -1, -1, -1}, {54413, -1, -1, -1}, {54420, -1, -1, -1}, {54441, -1, -1, -1}, {54476, -1, -1, -1}, {54480, -1, -1, -1}, {54484, -1, -1, -1}, {54492, -1, -1, -1}, {54495, -1, -1, -1}, {54504, -1, -1, -1}, {54508, -1, -1, -1}, {54512, -1, -1, -1}, {54520, -1, -1, -1}, {54523, -1, -1, -1}, {54525, -1, -1, -1}, {54532, -1, -1, -1}, {54536, -1, -1, -1}, {54540, -1, -1, -1}, {54548, -1, -1, -1}, {54549, -1, -1, -1}, {54551, -1, -1, -1}, {54588, -1, -1, -1}, {54589, -1, -1, -1}, {54592, -1, -1, -1}, {54596, -1, -1, -1}, {54604, -1, -1, -1}, {54605, -1, -1, -1}, {54607, -1, -1, -1}, {54609, -1, -1, -1}, {54616, -1, -1, -1}, {54617, -1, -1, -1}, {54620, -1, -1, -1}, {54624, -1, -1, -1}, {54629, -1, -1, -1}, {54632, -1, -1, -1}, {54633, -1, -1, -1}, {54635, -1, -1, -1}, {54637, -1, -1, -1}, {54644, -1, -1, -1}, {54645, -1, -1, -1}, {54648, -1, -1, -1}, {54652, -1, -1, -1}, {54660, -1, -1, -1}, {54661, -1, -1, -1}, {54663, -1, -1, -1}, {54664, -1, -1, -1}, {54665, -1, -1, -1}, {54672, -1, -1, -1}, {54693, -1, -1, -1}, {54728, -1, -1, -1}, {54729, -1, -1, -1}, {54732, -1, -1, -1}, {54736, -1, -1, -1}, {54738, -1, -1, -1}, {54744, -1, -1, -1}, {54745, -1, -1, -1}, {54747, -1, -1, -1}, {54749, -1, -1, -1}, {54756, -1, -1, -1}, {54757, -1, -1, -1}, {54760, -1, -1, -1}, {54764, -1, -1, -1}, {54772, -1, -1, -1} },
+ {{54773, -1, -1, -1}, {54775, -1, -1, -1}, {54777, -1, -1, -1}, {54784, -1, -1, -1}, {54785, -1, -1, -1}, {54788, -1, -1, -1}, {54792, -1, -1, -1}, {54800, -1, -1, -1}, {54801, -1, -1, -1}, {54803, -1, -1, -1}, {54804, -1, -1, -1}, {54805, -1, -1, -1}, {54812, -1, -1, -1}, {54816, -1, -1, -1}, {54820, -1, -1, -1}, {54829, -1, -1, -1}, {54840, -1, -1, -1}, {54841, -1, -1, -1}, {54844, -1, -1, -1}, {54848, -1, -1, -1}, {54853, -1, -1, -1}, {54856, -1, -1, -1}, {54857, -1, -1, -1}, {54859, -1, -1, -1}, {54861, -1, -1, -1}, {54865, -1, -1, -1}, {54868, -1, -1, -1}, {54869, -1, -1, -1}, {54872, -1, -1, -1}, {54876, -1, -1, -1}, {54887, -1, -1, -1}, {54889, -1, -1, -1}, {54896, -1, -1, -1}, {54897, -1, -1, -1}, {54900, -1, -1, -1}, {54915, -1, -1, -1}, {54917, -1, -1, -1}, {54924, -1, -1, -1}, {54925, -1, -1, -1}, {54928, -1, -1, -1}, {54932, -1, -1, -1}, {54941, -1, -1, -1}, {54943, -1, -1, -1}, {54945, -1, -1, -1}, {54952, -1, -1, -1}, {54956, -1, -1, -1}, {54960, -1, -1, -1}, {54969, -1, -1, -1}, {54971, -1, -1, -1}, {54980, -1, -1, -1}, {54981, -1, -1, -1}, {54984, -1, -1, -1}, {54988, -1, -1, -1}, {54993, -1, -1, -1}, {54996, -1, -1, -1}, {54999, -1, -1, -1}, {55001, -1, -1, -1}, {55008, -1, -1, -1}, {55012, -1, -1, -1}, {55016, -1, -1, -1}, {55024, -1, -1, -1}, {55029, -1, -1, -1}, {55036, -1, -1, -1}, {55037, -1, -1, -1}, {55040, -1, -1, -1}, {55044, -1, -1, -1}, {55057, -1, -1, -1}, {55064, -1, -1, -1}, {55065, -1, -1, -1}, {55068, -1, -1, -1}, {55072, -1, -1, -1}, {55080, -1, -1, -1}, {55081, -1, -1, -1}, {55083, -1, -1, -1}, {55085, -1, -1, -1}, {55092, -1, -1, -1}, {55093, -1, -1, -1}, {55096, -1, -1, -1}, {55100, -1, -1, -1}, {55108, -1, -1, -1}, {55111, -1, -1, -1}, {55113, -1, -1, -1}, {55120, -1, -1, -1}, {55121, -1, -1, -1}, {55124, -1, -1, -1}, {55126, -1, -1, -1}, {55127, -1, -1, -1}, {55128, -1, -1, -1}, {55129, -1, -1, -1}, {55136, -1, -1, -1}, {55137, -1, -1, -1}, {55139, -1, -1, -1}, {55141, -1, -1, -1}, {55145, -1, -1, -1}, {55148, -1, -1, -1}, {55152, -1, -1, -1}, {55156, -1, -1, -1}, {55164, -1, -1, -1}, {55165, -1, -1, -1}, {55169, -1, -1, -1}, {55176, -1, -1, -1}, {55177, -1, -1, -1}, {55180, -1, -1, -1}, {55184, -1, -1, -1}, {55192, -1, -1, -1}, {55193, -1, -1, -1}, {55195, -1, -1, -1}, {55197, -1, -1, -1}, {20285, -1, -1, -1}, {20339, -1, -1, -1}, {20551, -1, -1, -1}, {20729, -1, -1, -1}, {21152, -1, -1, -1}, {21487, -1, -1, -1}, {21621, -1, -1, -1}, {21733, -1, -1, -1}, {22025, -1, -1, -1}, {23233, -1, -1, -1}, {23478, -1, -1, -1}, {26247, -1, -1, -1}, {26550, -1, -1, -1}, {26551, -1, -1, -1}, {26607, -1, -1, -1}, {27468, -1, -1, -1}, {29634, -1, -1, -1}, {30146, -1, -1, -1}, {31292, -1, -1, -1}, {33499, -1, -1, -1}, {33540, -1, -1, -1}, {34903, -1, -1, -1}, {34952, -1, -1, -1}, {35382, -1, -1, -1}, {36040, 63747, -1, -1}, {36303, -1, -1, -1}, {36603, -1, -1, -1}, {36838, -1, -1, -1}, {39381, -1, -1, -1}, {21051, -1, -1, -1}, {21364, -1, -1, -1}, {21508, -1, -1, -1}, {24682, -1, -1, -1}, {24932, -1, -1, -1}, {27580, -1, -1, -1}, {29647, -1, -1, -1}, {33050, -1, -1, -1}, {35258, -1, -1, -1}, {35282, -1, -1, -1}, {38307, -1, -1, -1}, {20355, -1, -1, -1}, {21002, -1, -1, -1}, {22718, -1, -1, -1}, {22904, -1, -1, -1}, {23014, -1, -1, -1}, {24178, -1, -1, -1}, {24185, -1, -1, -1}, {25031, -1, -1, -1}, {25536, -1, -1, -1}, {26438, -1, -1, -1}, {26604, -1, -1, -1}, {26751, -1, -1, -1}, {28567, -1, -1, -1}, {30286, -1, -1, -1}, {30475, -1, -1, -1}, {30965, -1, -1, -1}, {31240, -1, -1, -1}, {31487, -1, -1, -1}, {31777, -1, -1, -1}, {32925, -1, -1, -1}, {33390, -1, -1, -1}, {33393, -1, -1, -1}, {35563, -1, -1, -1}, {38291, -1, -1, -1}, {20075, -1, -1, -1}, {21917, -1, -1, -1}, {26359, -1, -1, -1}, {28212, -1, -1, -1}, {30883, -1, -1, -1}, {31469, -1, -1, -1}, {33883, -1, -1, -1}, {35088, -1, -1, -1}, {34638, -1, -1, -1}, {38824, -1, -1, -1}, {21208, -1, -1, -1}, {22350, -1, -1, -1}, {22570, -1, -1, -1}, {23884, -1, -1, -1}, {24863, -1, -1, -1}, {25022, -1, -1, -1}, {25121, -1, -1, -1}, {25954, -1, -1, -1}, {26577, -1, -1, -1}, {27204, -1, -1, -1}, {28187, -1, -1, -1}, {29976, -1, -1, -1}, {30131, -1, -1, -1}, {30435, -1, -1, -1}, {30640, -1, -1, -1}, {32058, -1, -1, -1}, {37039, -1, -1, -1}, {37969, -1, -1, -1}, {37970, -1, -1, -1}, {40853, -1, -1, -1}, {21283, -1, -1, -1}, {23724, -1, -1, -1}, {30002, -1, -1, -1}, {32987, -1, -1, -1}, {37440, -1, -1, -1}, {38296, -1, -1, -1}, {21083, -1, -1, -1}, {22536, -1, -1, -1}, {23004, -1, -1, -1}, {23713, -1, -1, -1}, {23831, -1, -1, -1}, {24247, -1, -1, -1}, {24378, -1, -1, -1}, {24394, -1, -1, -1}, {24951, -1, -1, -1}, {27743, -1, -1, -1}, {30074, -1, -1, -1}, {30086, -1, -1, -1}, {31968, -1, -1, -1}, {32115, -1, -1, -1}, {32177, -1, -1, -1}, {32652, -1, -1, -1}, {33108, -1, -1, -1}, {33313, -1, -1, -1}, {34193, -1, -1, -1}, {35137, -1, -1, -1}, {35611, -1, -1, -1}, {37628, -1, -1, -1}, {38477, 64009, -1, -1}, {40007, -1, -1, -1}, {20171, -1, -1, -1}, {20215, -1, -1, -1}, {20491, -1, -1, -1}, {20977, -1, -1, -1}, {22607, -1, -1, -1}, {24887, -1, -1, -1}, {24894, -1, -1, -1}, {24936, -1, -1, -1}, {25913, -1, -1, -1}, {27114, -1, -1, -1}, {28433, -1, -1, -1}, {30117, -1, -1, -1}, {30342, -1, -1, -1}, {30422, -1, -1, -1}, {31623, -1, -1, -1}, {33445, -1, -1, -1}, {33995, -1, -1, -1}, {37799, -1, -1, -1}, {38283, -1, -1, -1}, {21888, -1, -1, -1}, {23458, -1, -1, -1}, {22353, -1, -1, -1}, {31923, -1, -1, -1}, {32697, -1, -1, -1} },
+ {{37301, -1, -1, -1}, {20520, -1, -1, -1}, {21435, -1, -1, -1}, {23621, -1, -1, -1}, {24040, -1, -1, -1}, {25298, -1, -1, -1}, {25454, -1, -1, -1}, {25818, -1, -1, -1}, {25831, -1, -1, -1}, {28192, -1, -1, -1}, {28844, -1, -1, -1}, {31067, -1, -1, -1}, {36317, -1, -1, -1}, {36382, -1, -1, -1}, {36989, -1, -1, -1}, {37445, -1, -1, -1}, {37624, -1, -1, -1}, {20094, -1, -1, -1}, {20214, -1, -1, -1}, {20581, -1, -1, -1}, {24062, -1, -1, -1}, {24314, -1, -1, -1}, {24838, -1, -1, -1}, {26967, -1, -1, -1}, {33137, -1, -1, -1}, {34388, -1, -1, -1}, {36423, -1, -1, -1}, {37749, -1, -1, -1}, {39467, -1, -1, -1}, {20062, -1, -1, -1}, {20625, -1, -1, -1}, {26480, -1, -1, -1}, {26688, -1, -1, -1}, {20745, -1, -1, -1}, {21133, -1, -1, -1}, {21138, -1, -1, -1}, {27298, -1, -1, -1}, {30652, -1, -1, -1}, {37392, -1, -1, -1}, {40660, -1, -1, -1}, {21163, -1, -1, -1}, {24623, -1, -1, -1}, {36850, -1, -1, -1}, {20552, -1, -1, -1}, {25001, -1, -1, -1}, {25581, -1, -1, -1}, {25802, -1, -1, -1}, {26684, -1, -1, -1}, {27268, -1, -1, -1}, {28608, -1, -1, -1}, {33160, -1, -1, -1}, {35233, -1, -1, -1}, {38548, -1, -1, -1}, {22533, -1, -1, -1}, {29309, -1, -1, -1}, {29356, -1, -1, -1}, {29956, -1, -1, -1}, {32121, -1, -1, -1}, {32365, -1, -1, -1}, {32937, -1, -1, -1}, {35211, 64010, -1, -1}, {35700, -1, -1, -1}, {36963, -1, -1, -1}, {40273, -1, -1, -1}, {25225, -1, -1, -1}, {27770, -1, -1, -1}, {28500, -1, -1, -1}, {32080, -1, -1, -1}, {32570, -1, -1, -1}, {35363, -1, -1, -1}, {20860, -1, -1, -1}, {24906, -1, -1, -1}, {31645, -1, -1, -1}, {35609, -1, -1, -1}, {37463, -1, -1, -1}, {37772, -1, -1, -1}, {20140, -1, -1, -1}, {20435, -1, -1, -1}, {20510, -1, -1, -1}, {20670, -1, -1, -1}, {20742, -1, -1, -1}, {21185, -1, -1, -1}, {21197, -1, -1, -1}, {21375, -1, -1, -1}, {22384, -1, -1, -1}, {22659, -1, -1, -1}, {24218, -1, -1, -1}, {24465, -1, -1, -1}, {24950, -1, -1, -1}, {25004, -1, -1, -1}, {25806, -1, -1, -1}, {25964, -1, -1, -1}, {26223, -1, -1, -1}, {26299, -1, -1, -1}, {26356, 63745, -1, -1}, {26775, -1, -1, -1}, {28039, -1, -1, -1}, {28805, -1, -1, -1}, {28913, -1, -1, -1}, {29855, -1, -1, -1}, {29861, -1, -1, -1}, {29898, -1, -1, -1}, {30169, -1, -1, -1}, {30828, -1, -1, -1}, {30956, -1, -1, -1}, {31455, -1, -1, -1}, {31478, -1, -1, -1}, {32069, -1, -1, -1}, {32147, -1, -1, -1}, {32789, -1, -1, -1}, {32831, -1, -1, -1}, {33051, -1, -1, -1}, {33686, -1, -1, -1}, {35686, -1, -1, -1}, {36629, -1, -1, -1}, {36885, -1, -1, -1}, {37857, -1, -1, -1}, {38915, -1, -1, -1}, {38968, -1, -1, -1}, {39514, -1, -1, -1}, {39912, -1, -1, -1}, {20418, -1, -1, -1}, {21843, -1, -1, -1}, {22586, -1, -1, -1}, {22865, 63753, -1, -1}, {23395, -1, -1, -1}, {23622, -1, -1, -1}, {24760, -1, -1, -1}, {25106, -1, -1, -1}, {26690, -1, -1, -1}, {26800, -1, -1, -1}, {26856, -1, -1, -1}, {28330, -1, -1, -1}, {30028, -1, -1, -1}, {30328, -1, -1, -1}, {30926, -1, -1, -1}, {31293, -1, -1, -1}, {31995, -1, -1, -1}, {32363, -1, -1, -1}, {32380, -1, -1, -1}, {35336, -1, -1, -1}, {35489, -1, -1, -1}, {35903, -1, -1, -1}, {38542, -1, -1, -1}, {40388, -1, -1, -1}, {21476, -1, -1, -1}, {21481, -1, -1, -1}, {21578, -1, -1, -1}, {21617, -1, -1, -1}, {22266, -1, -1, -1}, {22993, -1, -1, -1}, {23396, -1, -1, -1}, {23611, -1, -1, -1}, {24235, -1, -1, -1}, {25335, -1, -1, -1}, {25911, -1, -1, -1}, {25925, -1, -1, -1}, {25970, -1, -1, -1}, {26272, -1, -1, -1}, {26543, -1, -1, -1}, {27073, -1, -1, -1}, {27837, -1, -1, -1}, {30204, -1, -1, -1}, {30352, -1, -1, -1}, {30590, -1, -1, -1}, {31295, -1, -1, -1}, {32660, -1, -1, -1}, {32771, -1, -1, -1}, {32929, -1, -1, -1}, {33167, -1, -1, -1}, {33510, -1, -1, -1}, {33533, -1, -1, -1}, {33776, -1, -1, -1}, {34241, -1, -1, -1}, {34865, -1, -1, -1}, {34996, -1, -1, -1}, {35493, -1, -1, -1}, {36764, -1, -1, -1}, {37678, -1, -1, -1}, {38599, -1, -1, -1}, {39015, -1, -1, -1}, {39640, -1, -1, -1}, {40723, -1, -1, -1}, {21741, -1, -1, -1}, {26011, -1, -1, -1}, {26354, -1, -1, -1}, {26767, -1, -1, -1}, {31296, -1, -1, -1}, {35895, -1, -1, -1}, {40288, -1, -1, -1}, {22256, -1, -1, -1}, {22372, -1, -1, -1}, {23825, -1, -1, -1}, {26118, -1, -1, -1}, {26801, -1, -1, -1}, {26829, -1, -1, -1}, {28414, -1, -1, -1}, {29736, -1, -1, -1}, {34974, -1, -1, -1}, {39908, -1, -1, -1}, {27752, -1, -1, -1}, {39592, -1, -1, -1}, {20379, -1, -1, -1}, {20844, -1, -1, -1}, {20849, -1, -1, -1}, {21151, -1, -1, -1}, {23380, -1, -1, -1}, {24037, -1, -1, -1}, {24656, -1, -1, -1}, {24685, -1, -1, -1}, {25329, -1, -1, -1}, {25511, -1, -1, -1}, {25915, -1, -1, -1}, {29657, -1, -1, -1}, {31354, -1, -1, -1}, {34467, -1, -1, -1}, {36002, -1, -1, -1}, {38799, -1, -1, -1}, {20018, 63749, -1, -1}, {23521, -1, -1, -1}, {25096, -1, -1, -1}, {26524, -1, -1, -1}, {29916, -1, -1, -1}, {31185, -1, -1, -1}, {33747, -1, -1, -1}, {35463, -1, -1, -1}, {35506, -1, -1, -1}, {36328, -1, -1, -1}, {36942, -1, -1, -1}, {37707, -1, -1, -1}, {38982, -1, -1, -1}, {24275, 64011, -1, -1}, {27112, -1, -1, -1}, {34303, -1, -1, -1}, {37101, -1, -1, -1}, {20896, -1, -1, -1}, {23448, -1, -1, -1}, {23532, -1, -1, -1}, {24931, -1, -1, -1}, {26874, -1, -1, -1}, {27454, -1, -1, -1}, {28748, -1, -1, -1}, {29743, -1, -1, -1}, {29912, -1, -1, -1}, {31649, -1, -1, -1}, {32592, -1, -1, -1}, {33733, -1, -1, -1}, {35264, -1, -1, -1}, {36011, -1, -1, -1}, {38364, -1, -1, -1}, {39208, -1, -1, -1}, {21038, -1, -1, -1}, {24669, -1, -1, -1}, {25324, -1, -1, -1}, {36866, -1, -1, -1}, {20362, -1, -1, -1} },
+ {{20809, -1, -1, -1}, {21281, -1, -1, -1}, {22745, -1, -1, -1}, {24291, -1, -1, -1}, {26336, -1, -1, -1}, {27960, -1, -1, -1}, {28826, -1, -1, -1}, {29378, -1, -1, -1}, {29654, -1, -1, -1}, {31568, -1, -1, -1}, {33009, -1, -1, -1}, {37979, -1, -1, -1}, {21350, -1, -1, -1}, {25499, -1, -1, -1}, {32619, -1, -1, -1}, {20054, -1, -1, -1}, {20608, -1, -1, -1}, {22602, -1, -1, -1}, {22750, -1, -1, -1}, {24618, -1, -1, -1}, {24871, -1, -1, -1}, {25296, -1, -1, -1}, {27088, -1, -1, -1}, {39745, -1, -1, -1}, {23439, -1, -1, -1}, {32024, -1, -1, -1}, {32945, -1, -1, -1}, {36703, -1, -1, -1}, {20132, -1, -1, -1}, {20689, -1, -1, -1}, {21676, -1, -1, -1}, {21932, -1, -1, -1}, {23308, -1, -1, -1}, {23968, -1, -1, -1}, {24039, -1, -1, -1}, {25898, -1, -1, -1}, {25934, -1, -1, -1}, {26657, -1, -1, -1}, {27211, -1, -1, -1}, {29409, -1, -1, -1}, {30350, -1, -1, -1}, {30703, -1, -1, -1}, {32094, -1, -1, -1}, {32761, -1, -1, -1}, {33184, -1, -1, -1}, {34126, -1, -1, -1}, {34527, -1, -1, -1}, {36611, -1, -1, -1}, {36686, -1, -1, -1}, {37066, -1, -1, -1}, {39171, -1, -1, -1}, {39509, -1, -1, -1}, {39851, -1, -1, -1}, {19992, -1, -1, -1}, {20037, -1, -1, -1}, {20061, -1, -1, -1}, {20167, -1, -1, -1}, {20465, -1, -1, -1}, {20855, -1, -1, -1}, {21246, -1, -1, -1}, {21312, -1, -1, -1}, {21475, -1, -1, -1}, {21477, 63750, -1, -1}, {21646, -1, -1, -1}, {22036, -1, -1, -1}, {22389, -1, -1, -1}, {22434, -1, -1, -1}, {23495, -1, -1, -1}, {23943, -1, -1, -1}, {24272, -1, -1, -1}, {25084, -1, -1, -1}, {25304, -1, -1, -1}, {25937, -1, -1, -1}, {26552, -1, -1, -1}, {26601, -1, -1, -1}, {27083, -1, -1, -1}, {27472, -1, -1, -1}, {27590, -1, -1, -1}, {27628, -1, -1, -1}, {27714, -1, -1, -1}, {28317, -1, -1, -1}, {28792, -1, -1, -1}, {29399, -1, -1, -1}, {29590, -1, -1, -1}, {29699, -1, -1, -1}, {30655, -1, -1, -1}, {30697, -1, -1, -1}, {31350, -1, -1, -1}, {32127, -1, -1, -1}, {32777, -1, -1, -1}, {33276, -1, -1, -1}, {33285, -1, -1, -1}, {33290, -1, -1, -1}, {33503, -1, -1, -1}, {34914, -1, -1, -1}, {35635, -1, -1, -1}, {36092, -1, -1, -1}, {36544, -1, -1, -1}, {36881, -1, -1, -1}, {37041, -1, -1, -1}, {37476, -1, -1, -1}, {37558, -1, -1, -1}, {39378, -1, -1, -1}, {39493, -1, -1, -1}, {40169, -1, -1, -1}, {40407, -1, -1, -1}, {40860, 63752, 63751, -1}, {22283, -1, -1, -1}, {23616, -1, -1, -1}, {33738, -1, -1, -1}, {38816, -1, -1, -1}, {38827, -1, -1, -1}, {40628, -1, -1, -1}, {21531, -1, -1, -1}, {31384, -1, -1, -1}, {32676, -1, -1, -1}, {35033, -1, -1, -1}, {36557, -1, -1, -1}, {37089, -1, -1, -1}, {22528, -1, -1, -1}, {23624, -1, -1, -1}, {25496, -1, -1, -1}, {31391, -1, -1, -1}, {23470, -1, -1, -1}, {24339, -1, -1, -1}, {31353, -1, -1, -1}, {31406, -1, -1, -1}, {33422, -1, -1, -1}, {36524, -1, -1, -1}, {20518, -1, -1, -1}, {21048, -1, -1, -1}, {21240, -1, -1, -1}, {21367, -1, -1, -1}, {22280, -1, -1, -1}, {25331, -1, -1, -1}, {25458, -1, -1, -1}, {27402, -1, -1, -1}, {28099, -1, -1, -1}, {30519, -1, -1, -1}, {21413, -1, -1, -1}, {29527, -1, -1, -1}, {34152, -1, -1, -1}, {36470, -1, -1, -1}, {38357, -1, -1, -1}, {26426, -1, -1, -1}, {27331, -1, -1, -1}, {28528, -1, -1, -1}, {35437, -1, -1, -1}, {36556, -1, -1, -1}, {39243, -1, -1, -1}, {26231, -1, -1, -1}, {27512, -1, -1, -1}, {36020, -1, -1, -1}, {39740, -1, -1, -1}, {21483, -1, -1, -1}, {22317, -1, -1, -1}, {22862, -1, -1, -1}, {25542, -1, -1, -1}, {27131, -1, -1, -1}, {29674, -1, -1, -1}, {30789, -1, -1, -1}, {31418, -1, -1, -1}, {31429, -1, -1, -1}, {31998, -1, -1, -1}, {33909, -1, -1, -1}, {35215, -1, -1, -1}, {36211, -1, -1, -1}, {36917, -1, -1, -1}, {38312, -1, -1, -1}, {21243, -1, -1, -1}, {22343, -1, -1, -1}, {30023, -1, -1, -1}, {31584, -1, -1, -1}, {33740, -1, -1, -1}, {37406, -1, -1, -1}, {27224, -1, -1, -1}, {20811, -1, -1, -1}, {21067, -1, -1, -1}, {21127, -1, -1, -1}, {25119, -1, -1, -1}, {26840, -1, -1, -1}, {26997, -1, -1, -1}, {38553, -1, -1, -1}, {20677, -1, -1, -1}, {21156, -1, -1, -1}, {21220, -1, -1, -1}, {25027, -1, -1, -1}, {26020, -1, -1, -1}, {26681, -1, -1, -1}, {27135, -1, -1, -1}, {29822, -1, -1, -1}, {31563, -1, -1, -1}, {33465, -1, -1, -1}, {33771, -1, -1, -1}, {35250, -1, -1, -1}, {35641, -1, -1, -1}, {36817, -1, -1, -1}, {39241, -1, -1, -1}, {20170, -1, -1, -1}, {22935, -1, -1, -1}, {25810, -1, -1, -1}, {26129, -1, -1, -1}, {27278, -1, -1, -1}, {29748, -1, -1, -1}, {31105, -1, -1, -1}, {31165, -1, -1, -1}, {33449, -1, -1, -1}, {34942, -1, -1, -1}, {34943, -1, -1, -1}, {35167, -1, -1, -1}, {37670, -1, -1, -1}, {20235, -1, -1, -1}, {21450, -1, -1, -1}, {24613, -1, -1, -1}, {25201, -1, -1, -1}, {27762, -1, -1, -1}, {32026, -1, -1, -1}, {32102, -1, -1, -1}, {20120, -1, -1, -1}, {20834, -1, -1, -1}, {30684, -1, -1, -1}, {32943, -1, -1, -1}, {20225, -1, -1, -1}, {20238, -1, -1, -1}, {20854, -1, -1, -1}, {20864, -1, -1, -1}, {21980, -1, -1, -1}, {22120, -1, -1, -1}, {22331, -1, -1, -1}, {22522, -1, -1, -1}, {22524, -1, -1, -1}, {22804, -1, -1, -1}, {22855, -1, -1, -1}, {22931, -1, -1, -1}, {23492, -1, -1, -1}, {23696, -1, -1, -1}, {23822, -1, -1, -1}, {24049, -1, -1, -1}, {24190, -1, -1, -1}, {24524, -1, -1, -1}, {25216, -1, -1, -1}, {26071, -1, -1, -1}, {26083, -1, -1, -1}, {26398, -1, -1, -1}, {26399, -1, -1, -1}, {26462, -1, -1, -1}, {26827, -1, -1, -1}, {26820, -1, -1, -1}, {27231, -1, -1, -1}, {27450, -1, -1, -1}, {27683, -1, -1, -1}, {27773, -1, -1, -1}, {27778, -1, -1, -1}, {28103, -1, -1, -1}, {29592, -1, -1, -1}, {29734, -1, -1, -1} },
+ {{29738, -1, -1, -1}, {29826, -1, -1, -1}, {29859, -1, -1, -1}, {30072, -1, -1, -1}, {30079, -1, -1, -1}, {30849, -1, -1, -1}, {30959, -1, -1, -1}, {31041, -1, -1, -1}, {31047, -1, -1, -1}, {31048, -1, -1, -1}, {31098, -1, -1, -1}, {31637, -1, -1, -1}, {32000, -1, -1, -1}, {32186, -1, -1, -1}, {32648, -1, -1, -1}, {32774, -1, -1, -1}, {32813, -1, -1, -1}, {32908, -1, -1, -1}, {35352, -1, -1, -1}, {35663, -1, -1, -1}, {35912, 63744, -1, -1}, {36215, -1, -1, -1}, {37665, -1, -1, -1}, {37668, -1, -1, -1}, {39138, -1, -1, -1}, {39249, -1, -1, -1}, {39438, -1, -1, -1}, {39439, -1, -1, -1}, {39525, -1, -1, -1}, {40594, -1, -1, -1}, {32202, -1, -1, -1}, {20342, -1, -1, -1}, {21513, -1, -1, -1}, {25326, -1, -1, -1}, {26708, -1, -1, -1}, {37329, 63754, -1, -1}, {21931, -1, -1, -1}, {20794, -1, -1, -1}, {23068, -1, -1, -1}, {25062, -1, -1, -1}, {25295, 63835, -1, -1}, {25343, -1, -1, -1}, {37027, -1, -1, -1}, {35582, 63837, -1, -1}, {26262, -1, -1, -1}, {29014, -1, -1, -1}, {38627, -1, -1, -1}, {25423, -1, -1, -1}, {25466, -1, -1, -1}, {21335, -1, -1, -1}, {26511, -1, -1, -1}, {26976, -1, -1, -1}, {28275, -1, -1, -1}, {30007, -1, -1, -1}, {32013, -1, -1, -1}, {34930, -1, -1, -1}, {22218, -1, -1, -1}, {23064, -1, -1, -1}, {20035, -1, -1, -1}, {20839, -1, -1, -1}, {22856, 63756, -1, -1}, {26608, -1, -1, -1}, {32784, -1, -1, -1}, {22899, 63873, -1, -1}, {24180, 63886, -1, -1}, {25754, 63889, -1, -1}, {31178, 63893, -1, -1}, {24565, 63907, -1, -1}, {24684, -1, -1, -1}, {25288, -1, -1, -1}, {25467, 63908, -1, -1}, {23527, 63839, 63914, -1}, {23511, -1, -1, -1}, {21162, -1, -1, -1}, {22900, -1, -1, -1}, {24361, -1, -1, -1}, {24594, 63840, -1, -1}, {29785, -1, -1, -1}, {39377, -1, -1, -1}, {28611, -1, -1, -1}, {33215, -1, -1, -1}, {36786, -1, -1, -1}, {24817, -1, -1, -1}, {33126, -1, -1, -1}, {23615, 63933, -1, -1}, {23273, -1, -1, -1}, {35365, -1, -1, -1}, {26491, 63944, -1, -1}, {32016, 63951, -1, -1}, {33021, -1, -1, -1}, {23612, -1, -1, -1}, {27877, 63971, -1, -1}, {21311, 63979, -1, -1}, {28346, 63980, -1, -1}, {22810, -1, -1, -1}, {33590, 63998, -1, -1}, {20025, 63838, -1, -1}, {20150, -1, -1, -1}, {20294, -1, -1, -1}, {21934, -1, -1, -1}, {22296, -1, -1, -1}, {22727, -1, -1, -1}, {24406, -1, -1, -1}, {26039, -1, -1, -1}, {26086, -1, -1, -1}, {27264, -1, -1, -1}, {27573, -1, -1, -1}, {28237, -1, -1, -1}, {30701, -1, -1, -1}, {31471, -1, -1, -1}, {31774, -1, -1, -1}, {32222, -1, -1, -1}, {34507, -1, -1, -1}, {34962, -1, -1, -1}, {37170, -1, -1, -1}, {37723, -1, -1, -1}, {25787, -1, -1, -1}, {28606, -1, -1, -1}, {29562, -1, -1, -1}, {30136, -1, -1, -1}, {36948, -1, -1, -1}, {21846, -1, -1, -1}, {22349, -1, -1, -1}, {25018, -1, -1, -1}, {25812, -1, -1, -1}, {26311, -1, -1, -1}, {28129, -1, -1, -1}, {28251, -1, -1, -1}, {28525, -1, -1, -1}, {28601, -1, -1, -1}, {30192, -1, -1, -1}, {32835, -1, -1, -1}, {33213, -1, -1, -1}, {34113, -1, -1, -1}, {35203, -1, -1, -1}, {35527, -1, -1, -1}, {35674, -1, -1, -1}, {37663, -1, -1, -1}, {27795, -1, -1, -1}, {30035, -1, -1, -1}, {31572, -1, -1, -1}, {36367, -1, -1, -1}, {36957, -1, -1, -1}, {21776, -1, -1, -1}, {22530, -1, -1, -1}, {22616, -1, -1, -1}, {24162, -1, -1, -1}, {25095, -1, -1, -1}, {25758, -1, -1, -1}, {26848, -1, -1, -1}, {30070, -1, -1, -1}, {31958, 64003, -1, -1}, {34739, -1, -1, -1}, {40680, -1, -1, -1}, {20195, -1, -1, -1}, {22408, -1, -1, -1}, {22382, -1, -1, -1}, {22823, -1, -1, -1}, {23565, -1, -1, -1}, {23729, -1, -1, -1}, {24118, -1, -1, -1}, {24453, -1, -1, -1}, {25140, -1, -1, -1}, {25825, -1, -1, -1}, {29619, -1, -1, -1}, {33274, -1, -1, -1}, {34955, -1, -1, -1}, {36024, -1, -1, -1}, {38538, -1, -1, -1}, {40667, -1, -1, -1}, {23429, 64004, -1, -1}, {24503, -1, -1, -1}, {24755, -1, -1, -1}, {20498, -1, -1, -1}, {20992, -1, -1, -1}, {21040, -1, -1, -1}, {22294, -1, -1, -1}, {22581, -1, -1, -1}, {22615, -1, -1, -1}, {23566, -1, -1, -1}, {23648, -1, -1, -1}, {23798, -1, -1, -1}, {23947, -1, -1, -1}, {24230, 64001, -1, -1}, {24466, -1, -1, -1}, {24764, -1, -1, -1}, {25361, -1, -1, -1}, {25481, -1, -1, -1}, {25623, -1, -1, -1}, {26691, -1, -1, -1}, {26873, -1, -1, -1}, {27330, -1, -1, -1}, {28120, -1, -1, -1}, {28193, -1, -1, -1}, {28372, -1, -1, -1}, {28644, -1, -1, -1}, {29182, -1, -1, -1}, {30428, -1, -1, -1}, {30585, -1, -1, -1}, {31153, -1, -1, -1}, {31291, -1, -1, -1}, {33796, -1, -1, -1}, {35241, -1, -1, -1}, {36077, -1, -1, -1}, {36339, -1, -1, -1}, {36424, -1, -1, -1}, {36867, -1, -1, -1}, {36884, -1, -1, -1}, {36947, -1, -1, -1}, {37117, -1, -1, -1}, {37709, -1, -1, -1}, {38518, -1, -1, -1}, {38876, -1, -1, -1}, {27602, -1, -1, -1}, {28678, -1, -1, -1}, {29272, -1, -1, -1}, {29346, -1, -1, -1}, {29544, -1, -1, -1}, {30563, -1, -1, -1}, {31167, -1, -1, -1}, {31716, -1, -1, -1}, {32411, -1, -1, -1}, {35712, 63834, -1, -1}, {22697, -1, -1, -1}, {24775, -1, -1, -1}, {25958, -1, -1, -1}, {26109, -1, -1, -1}, {26302, -1, -1, -1}, {27788, -1, -1, -1}, {28958, -1, -1, -1}, {29129, -1, -1, -1}, {35930, -1, -1, -1}, {38931, -1, -1, -1}, {20077, -1, -1, -1}, {31361, -1, -1, -1}, {20189, -1, -1, -1}, {20908, -1, -1, -1}, {20941, -1, -1, -1}, {21205, -1, -1, -1}, {21516, -1, -1, -1}, {24999, -1, -1, -1}, {26481, -1, -1, -1}, {26704, -1, -1, -1}, {26847, -1, -1, -1}, {27934, 64005, -1, -1}, {28540, -1, -1, -1}, {30140, -1, -1, -1}, {30643, -1, -1, -1}, {31461, -1, -1, -1}, {33012, -1, -1, -1}, {33891, -1, -1, -1}, {37509, -1, -1, -1}, {20828, -1, -1, -1}, {26007, -1, -1, -1}, {26460, -1, -1, -1}, {26515, -1, -1, -1} },
+ {{30168, -1, -1, -1}, {31431, -1, -1, -1}, {33651, -1, -1, -1}, {35910, -1, -1, -1}, {36887, -1, -1, -1}, {38957, -1, -1, -1}, {23663, -1, -1, -1}, {33216, -1, -1, -1}, {33434, -1, -1, -1}, {36929, -1, -1, -1}, {36975, -1, -1, -1}, {37389, -1, -1, -1}, {24471, -1, -1, -1}, {23965, -1, -1, -1}, {27225, -1, -1, -1}, {29128, -1, -1, -1}, {30331, -1, -1, -1}, {31561, -1, -1, -1}, {34276, -1, -1, -1}, {35588, -1, -1, -1}, {37159, -1, -1, -1}, {39472, -1, -1, -1}, {21895, 63755, -1, -1}, {25078, 63757, -1, -1}, {30313, 63758, -1, -1}, {32645, 63759, -1, -1}, {34367, 63760, -1, -1}, {34746, 63761, -1, -1}, {35064, 63762, -1, -1}, {37007, 63763, -1, -1}, {27931, 63765, -1, -1}, {28889, 63766, -1, -1}, {29662, 63767, -1, -1}, {32097, -1, -1, -1}, {33853, 63768, -1, -1}, {37226, 63769, -1, -1}, {39409, 63770, -1, -1}, {20098, 63771, -1, -1}, {21365, 63772, -1, -1}, {27396, 63773, -1, -1}, {27410, -1, -1, -1}, {28734, -1, -1, -1}, {29211, 63774, -1, -1}, {34349, 63775, -1, -1}, {40478, 63776, -1, -1}, {21068, -1, -1, -1}, {36771, -1, -1, -1}, {23888, 63777, -1, -1}, {25829, -1, -1, -1}, {25900, -1, -1, -1}, {27414, -1, -1, -1}, {28651, 63778, -1, -1}, {31811, -1, -1, -1}, {32412, -1, -1, -1}, {34253, 63779, -1, -1}, {35172, 63780, -1, -1}, {35261, -1, -1, -1}, {25289, 63781, -1, -1}, {33240, 63782, -1, -1}, {34847, 63783, -1, -1}, {24266, 63784, -1, -1}, {26391, 63785, -1, -1}, {28010, 63786, -1, -1}, {29436, 63787, -1, -1}, {29701, -1, -1, -1}, {29807, -1, -1, -1}, {34690, -1, -1, -1}, {37086, 63788, -1, -1}, {20358, 63789, -1, -1}, {23821, -1, -1, -1}, {24480, -1, -1, -1}, {33802, -1, -1, -1}, {20919, 63790, -1, -1}, {25504, 63861, -1, -1}, {30053, 63862, -1, -1}, {20142, 63863, -1, -1}, {20486, -1, -1, -1}, {20841, 63864, -1, -1}, {20937, 63865, -1, -1}, {26753, 63866, -1, -1}, {27153, -1, -1, -1}, {31918, -1, -1, -1}, {31921, -1, -1, -1}, {31975, 63867, -1, -1}, {33391, 63868, -1, -1}, {35538, 63869, -1, -1}, {36635, -1, -1, -1}, {37327, 63870, -1, -1}, {20406, -1, -1, -1}, {20791, -1, -1, -1}, {21237, 63871, -1, -1}, {21570, 63872, -1, -1}, {24300, 63874, -1, -1}, {24942, -1, -1, -1}, {25150, -1, -1, -1}, {26053, 63875, -1, -1}, {27354, -1, -1, -1}, {28670, 63876, -1, -1}, {31018, 63877, -1, -1}, {34268, -1, -1, -1}, {34851, -1, -1, -1}, {38317, 63878, -1, -1}, {39522, -1, -1, -1}, {39530, 63879, -1, -1}, {40599, 63880, -1, -1}, {40654, 63881, -1, -1}, {21147, 63882, -1, -1}, {26310, 63883, -1, -1}, {27511, 63884, -1, -1}, {28701, -1, -1, -1}, {31019, -1, -1, -1}, {36706, 63885, -1, -1}, {38722, -1, -1, -1}, {24976, 63887, -1, -1}, {25088, 63888, -1, -1}, {25891, -1, -1, -1}, {28451, 63890, -1, -1}, {29001, 63891, -1, -1}, {29833, 63892, -1, -1}, {32244, 63894, -1, -1}, {32879, 63895, -1, -1}, {34030, 63897, -1, -1}, {36646, 63896, -1, -1}, {36899, 63898, -1, -1}, {37706, 63899, -1, -1}, {20925, -1, -1, -1}, {21015, 63900, -1, -1}, {21155, 63901, -1, -1}, {27916, -1, -1, -1}, {28872, 63903, -1, -1}, {35010, 63904, -1, -1}, {24265, 63906, -1, -1}, {25986, -1, -1, -1}, {27566, 63909, -1, -1}, {28610, -1, -1, -1}, {31806, 63910, -1, -1}, {29557, 63911, -1, -1}, {20196, 63912, -1, -1}, {20278, -1, -1, -1}, {22265, 63913, -1, -1}, {23738, -1, -1, -1}, {23994, 63915, -1, -1}, {24604, 63916, -1, -1}, {29618, 63917, -1, -1}, {31533, -1, -1, -1}, {32666, 63919, -1, -1}, {32718, -1, -1, -1}, {32838, 63920, -1, -1}, {36894, -1, -1, -1}, {37428, 63921, -1, -1}, {38646, 63922, -1, -1}, {38728, 63923, -1, -1}, {38936, 63924, -1, -1}, {40801, -1, -1, -1}, {20363, 63925, -1, -1}, {28583, -1, -1, -1}, {31150, 63926, -1, -1}, {37300, 63927, -1, -1}, {38583, 63928, -1, -1}, {21214, 63791, -1, -1}, {25736, -1, -1, -1}, {25796, 63792, -1, -1}, {27347, 63793, -1, -1}, {28510, -1, -1, -1}, {28696, -1, -1, -1}, {29200, 63794, -1, -1}, {30439, 63795, -1, -1}, {32769, 63796, -1, -1}, {34310, 63797, -1, -1}, {34396, 63798, -1, -1}, {36335, 63799, -1, -1}, {36613, -1, -1, -1}, {38706, 63800, -1, -1}, {39791, 63801, -1, -1}, {40442, 63802, -1, -1}, {40565, -1, -1, -1}, {30860, 63803, -1, -1}, {31103, 63804, -1, -1}, {32160, 63805, -1, -1}, {33737, 63806, -1, -1}, {37636, 63807, -1, -1}, {40575, 63808, -1, -1}, {40595, -1, -1, -1}, {35542, 63809, -1, -1}, {22751, 63810, -1, -1}, {24324, 63811, -1, -1}, {26407, -1, -1, -1}, {28711, -1, -1, -1}, {29903, -1, -1, -1}, {31840, 63812, -1, -1}, {32894, 63813, -1, -1}, {20769, -1, -1, -1}, {28712, -1, -1, -1}, {29282, 63814, -1, -1}, {30922, 63815, -1, -1}, {36034, 63816, -1, -1}, {36058, -1, -1, -1}, {36084, -1, -1, -1}, {38647, 63817, -1, -1}, {20102, 63930, -1, -1}, {20698, 63931, -1, -1}, {23534, 63932, -1, -1}, {24278, -1, -1, -1}, {26009, 63934, -1, -1}, {29134, 63936, -1, -1}, {30274, 63937, -1, -1}, {30637, -1, -1, -1}, {32842, -1, -1, -1}, {34044, 63938, -1, -1}, {36988, 63939, -1, -1}, {39719, -1, -1, -1}, {40845, 63940, -1, -1}, {22744, 63818, -1, -1}, {23105, -1, -1, -1}, {23650, 63819, -1, -1}, {27155, 63820, -1, -1}, {28122, 63821, -1, -1}, {28431, 63822, -1, -1}, {30267, -1, -1, -1}, {32047, 63823, -1, -1}, {32311, 63824, -1, -1}, {34078, -1, -1, -1}, {35128, -1, -1, -1}, {37860, -1, -1, -1}, {38475, 63825, -1, -1}, {21129, 63943, -1, -1}, {26066, -1, -1, -1}, {26611, 63945, -1, -1}, {27060, -1, -1, -1}, {27969, 63946, -1, -1}, {28316, 63947, -1, -1}, {28687, -1, -1, -1}, {29705, 63948, -1, -1}, {29792, -1, -1, -1}, {30041, 63949, -1, -1}, {30244, -1, -1, -1}, {30827, 63950, -1, -1}, {35628, -1, -1, -1}, {39006, 63952, -1, -1}, {20845, 63953, -1, -1}, {25134, 63954, -1, -1}, {38520, 63955, -1, -1}, {20374, -1, -1, -1}, {20523, 63956, -1, -1}, {23833, 63957, -1, -1}, {28138, 63958, -1, -1}, {32184, -1, -1, -1}, {36650, 63959, -1, -1}, {24459, 63960, -1, -1}, {24900, 63961, -1, -1}, {26647, 63962, -1, -1}, {38534, 63964, -1, -1}, {21202, 63826, -1, -1}, {32907, 63827, -1, -1}, {20956, 63828, -1, -1}, {20940, 63829, -1, -1} },
+ {{26974, -1, -1, -1}, {31260, 63830, -1, -1}, {32190, 63831, -1, -1}, {33777, 63832, -1, -1}, {38517, 63833, -1, -1}, {20442, -1, -1, -1}, {21033, 63965, -1, -1}, {21400, -1, -1, -1}, {21519, 63966, -1, -1}, {21774, -1, -1, -1}, {23653, 63967, -1, -1}, {24743, -1, -1, -1}, {26446, 63969, -1, -1}, {26792, 63970, -1, -1}, {28012, -1, -1, -1}, {29313, -1, -1, -1}, {29432, -1, -1, -1}, {29702, 63972, -1, -1}, {29827, -1, -1, -1}, {30178, 63973, -1, -1}, {31852, -1, -1, -1}, {32633, 63974, -1, -1}, {32696, -1, -1, -1}, {33673, -1, -1, -1}, {35023, 63975, -1, -1}, {35041, 63976, -1, -1}, {37324, 63977, -1, -1}, {37328, -1, -1, -1}, {38626, 63978, -1, -1}, {39881, -1, -1, -1}, {21533, 63981, -1, -1}, {28542, -1, -1, -1}, {29136, 63982, -1, -1}, {29848, 63983, -1, -1}, {34298, 63984, -1, -1}, {36522, -1, -1, -1}, {38563, 63985, -1, -1}, {40023, 63986, -1, -1}, {40607, 63987, -1, -1}, {26519, 63988, -1, -1}, {28107, 63989, -1, -1}, {29747, -1, -1, -1}, {33256, 63990, -1, -1}, {38678, -1, -1, -1}, {30764, -1, -1, -1}, {31435, 63991, -1, -1}, {31520, 63992, -1, -1}, {31890, 63993, -1, -1}, {25705, -1, -1, -1}, {29802, -1, -1, -1}, {30194, -1, -1, -1}, {30908, -1, -1, -1}, {30952, -1, -1, -1}, {39340, -1, -1, -1}, {39764, -1, -1, -1}, {40635, -1, -1, -1}, {23518, -1, -1, -1}, {24149, -1, -1, -1}, {28448, -1, -1, -1}, {33180, -1, -1, -1}, {33707, -1, -1, -1}, {37000, -1, -1, -1}, {19975, -1, -1, -1}, {21325, -1, -1, -1}, {23081, -1, -1, -1}, {24018, -1, -1, -1}, {24398, -1, -1, -1}, {24930, -1, -1, -1}, {25405, -1, -1, -1}, {26217, -1, -1, -1}, {26364, -1, -1, -1}, {28415, -1, -1, -1}, {28459, -1, -1, -1}, {28771, -1, -1, -1}, {30622, -1, -1, -1}, {33836, -1, -1, -1}, {34067, -1, -1, -1}, {34875, -1, -1, -1}, {36627, -1, -1, -1}, {39237, -1, -1, -1}, {39995, -1, -1, -1}, {21788, -1, -1, -1}, {25273, -1, -1, -1}, {26411, -1, -1, -1}, {27819, -1, -1, -1}, {33545, -1, -1, -1}, {35178, -1, -1, -1}, {38778, -1, -1, -1}, {20129, -1, -1, -1}, {22916, -1, -1, -1}, {24536, -1, -1, -1}, {24537, -1, -1, -1}, {26395, -1, -1, -1}, {32178, -1, -1, -1}, {32596, -1, -1, -1}, {33426, -1, -1, -1}, {33579, -1, -1, -1}, {33725, -1, -1, -1}, {36638, -1, -1, -1}, {37017, -1, -1, -1}, {22475, -1, -1, -1}, {22969, -1, -1, -1}, {23186, -1, -1, -1}, {23504, -1, -1, -1}, {26151, -1, -1, -1}, {26522, -1, -1, -1}, {26757, -1, -1, -1}, {27599, -1, -1, -1}, {29028, -1, -1, -1}, {32629, -1, -1, -1}, {36023, -1, -1, -1}, {36067, -1, -1, -1}, {36993, -1, -1, -1}, {39749, -1, -1, -1}, {33032, -1, -1, -1}, {35978, -1, -1, -1}, {38476, -1, -1, -1}, {39488, -1, -1, -1}, {40613, -1, -1, -1}, {23391, -1, -1, -1}, {27667, -1, -1, -1}, {29467, -1, -1, -1}, {30450, -1, -1, -1}, {30431, -1, -1, -1}, {33804, -1, -1, -1}, {20906, -1, -1, -1}, {35219, -1, -1, -1}, {20813, -1, -1, -1}, {20885, -1, -1, -1}, {21193, -1, -1, -1}, {26825, -1, -1, -1}, {27796, -1, -1, -1}, {30468, -1, -1, -1}, {30496, -1, -1, -1}, {32191, -1, -1, -1}, {32236, -1, -1, -1}, {38754, -1, -1, -1}, {40629, -1, -1, -1}, {28357, -1, -1, -1}, {34065, -1, -1, -1}, {20901, -1, -1, -1}, {21517, -1, -1, -1}, {21629, -1, -1, -1}, {26126, -1, -1, -1}, {26269, -1, -1, -1}, {26919, -1, -1, -1}, {28319, -1, -1, -1}, {30399, -1, -1, -1}, {30609, -1, -1, -1}, {33559, -1, -1, -1}, {33986, -1, -1, -1}, {34719, -1, -1, -1}, {37225, -1, -1, -1}, {37528, -1, -1, -1}, {40180, -1, -1, -1}, {34946, -1, -1, -1}, {20398, -1, -1, -1}, {20882, -1, -1, -1}, {21215, -1, -1, -1}, {22982, -1, -1, -1}, {24125, -1, -1, -1}, {24917, -1, -1, -1}, {25720, -1, -1, -1}, {25721, -1, -1, -1}, {26286, -1, -1, -1}, {26576, -1, -1, -1}, {27169, -1, -1, -1}, {27597, -1, -1, -1}, {27611, -1, -1, -1}, {29279, -1, -1, -1}, {29281, -1, -1, -1}, {29761, -1, -1, -1}, {30520, -1, -1, -1}, {30683, -1, -1, -1}, {32791, -1, -1, -1}, {33468, -1, -1, -1}, {33541, -1, -1, -1}, {35584, -1, -1, -1}, {35624, -1, -1, -1}, {35980, -1, -1, -1}, {26408, -1, -1, -1}, {27792, -1, -1, -1}, {29287, -1, -1, -1}, {30446, -1, -1, -1}, {30566, -1, -1, -1}, {31302, -1, -1, -1}, {40361, -1, -1, -1}, {27519, -1, -1, -1}, {27794, -1, -1, -1}, {22818, -1, -1, -1}, {26406, -1, -1, -1}, {33945, -1, -1, -1}, {21359, -1, -1, -1}, {22675, -1, -1, -1}, {22937, -1, -1, -1}, {24287, -1, -1, -1}, {25551, -1, -1, -1}, {26164, -1, -1, -1}, {26483, -1, -1, -1}, {28218, -1, -1, -1}, {29483, -1, -1, -1}, {31447, -1, -1, -1}, {33495, -1, -1, -1}, {37672, -1, -1, -1}, {21209, -1, -1, -1}, {24043, -1, -1, -1}, {25006, -1, -1, -1}, {25035, -1, -1, -1}, {25098, -1, -1, -1}, {25287, -1, -1, -1}, {25771, -1, -1, -1}, {26080, -1, -1, -1}, {26969, -1, -1, -1}, {27494, -1, -1, -1}, {27595, -1, -1, -1}, {28961, -1, -1, -1}, {29687, -1, -1, -1}, {30045, -1, -1, -1}, {32326, -1, -1, -1}, {33310, -1, -1, -1}, {33538, -1, -1, -1}, {34154, -1, -1, -1}, {35491, -1, -1, -1}, {36031, -1, -1, -1}, {38695, -1, -1, -1}, {40289, -1, -1, -1}, {22696, -1, -1, -1}, {40664, -1, -1, -1}, {20497, -1, -1, -1}, {21006, -1, -1, -1}, {21563, -1, -1, -1}, {21839, -1, -1, -1}, {25991, -1, -1, -1}, {27766, -1, -1, -1}, {32010, -1, -1, -1}, {32011, -1, -1, -1}, {32862, -1, -1, -1}, {34442, -1, -1, -1}, {38272, -1, -1, -1}, {38639, -1, -1, -1}, {21247, -1, -1, -1}, {27797, -1, -1, -1}, {29289, -1, -1, -1}, {21619, -1, -1, -1}, {23194, -1, -1, -1}, {23614, -1, -1, -1}, {23883, -1, -1, -1}, {24396, -1, -1, -1}, {24494, -1, -1, -1}, {26410, -1, -1, -1}, {26806, -1, -1, -1}, {26979, -1, -1, -1}, {28220, -1, -1, -1}, {28228, -1, -1, -1}, {30473, -1, -1, -1}, {31859, -1, -1, -1} },
+ {{32654, -1, -1, -1}, {34183, -1, -1, -1}, {35598, -1, -1, -1}, {36855, -1, -1, -1}, {38753, -1, -1, -1}, {40692, -1, -1, -1}, {23735, -1, -1, -1}, {24758, -1, -1, -1}, {24845, -1, -1, -1}, {25003, -1, -1, -1}, {25935, -1, -1, -1}, {26107, -1, -1, -1}, {26108, -1, -1, -1}, {27665, -1, -1, -1}, {27887, -1, -1, -1}, {29599, -1, -1, -1}, {29641, -1, -1, -1}, {32225, -1, -1, -1}, {38292, -1, -1, -1}, {23494, -1, -1, -1}, {34588, -1, -1, -1}, {35600, -1, -1, -1}, {21085, -1, -1, -1}, {21338, -1, -1, -1}, {25293, -1, -1, -1}, {25615, -1, -1, -1}, {25778, -1, -1, -1}, {26420, -1, -1, -1}, {27192, -1, -1, -1}, {27850, -1, -1, -1}, {29632, -1, -1, -1}, {29854, -1, -1, -1}, {31636, -1, -1, -1}, {31893, -1, -1, -1}, {32283, -1, -1, -1}, {33162, -1, -1, -1}, {33334, -1, -1, -1}, {34180, -1, -1, -1}, {36843, -1, -1, -1}, {38649, -1, -1, -1}, {39361, -1, -1, -1}, {20276, -1, -1, -1}, {21322, -1, -1, -1}, {21453, -1, -1, -1}, {21467, -1, -1, -1}, {25292, -1, -1, -1}, {25644, -1, -1, -1}, {25856, -1, -1, -1}, {26001, -1, -1, -1}, {27075, -1, -1, -1}, {27886, -1, -1, -1}, {28504, -1, -1, -1}, {29677, -1, -1, -1}, {30036, -1, -1, -1}, {30242, -1, -1, -1}, {30436, -1, -1, -1}, {30460, -1, -1, -1}, {30928, -1, -1, -1}, {30971, 63844, -1, -1}, {31020, -1, -1, -1}, {32070, -1, -1, -1}, {33324, -1, -1, -1}, {34784, -1, -1, -1}, {36820, -1, -1, -1}, {38930, -1, -1, -1}, {39151, -1, -1, -1}, {21187, -1, -1, -1}, {25300, -1, -1, -1}, {25765, -1, -1, -1}, {28196, -1, -1, -1}, {28497, -1, -1, -1}, {30332, -1, -1, -1}, {36299, -1, -1, -1}, {37297, -1, -1, -1}, {37474, -1, -1, -1}, {39662, -1, -1, -1}, {39747, -1, -1, -1}, {20515, -1, -1, -1}, {20621, -1, -1, -1}, {22346, -1, -1, -1}, {22952, -1, -1, -1}, {23592, -1, -1, -1}, {24135, -1, -1, -1}, {24439, -1, -1, -1}, {25151, -1, -1, -1}, {25918, -1, -1, -1}, {26041, -1, -1, -1}, {26049, -1, -1, -1}, {26121, -1, -1, -1}, {26507, -1, -1, -1}, {27036, -1, -1, -1}, {28354, -1, -1, -1}, {30917, -1, -1, -1}, {32033, -1, -1, -1}, {32938, -1, -1, -1}, {33152, -1, -1, -1}, {33323, -1, -1, -1}, {33459, -1, -1, -1}, {33953, -1, -1, -1}, {34444, -1, -1, -1}, {35370, -1, -1, -1}, {35607, -1, -1, -1}, {37030, -1, -1, -1}, {38450, -1, -1, -1}, {40848, -1, -1, -1}, {20493, -1, -1, -1}, {20467, -1, -1, -1}, {22521, -1, -1, -1}, {24472, -1, -1, -1}, {25308, -1, -1, -1}, {25490, -1, -1, -1}, {26479, -1, -1, -1}, {28227, -1, -1, -1}, {28953, -1, -1, -1}, {30403, -1, -1, -1}, {32972, -1, -1, -1}, {32986, -1, -1, -1}, {35060, -1, -1, -1}, {35061, -1, -1, -1}, {35097, -1, -1, -1}, {36064, -1, -1, -1}, {36649, -1, -1, -1}, {37197, -1, -1, -1}, {38506, -1, -1, -1}, {20271, -1, -1, -1}, {20336, -1, -1, -1}, {24091, -1, -1, -1}, {26575, -1, -1, -1}, {26658, -1, -1, -1}, {30333, -1, -1, -1}, {30334, -1, -1, -1}, {39748, -1, -1, -1}, {24161, -1, -1, -1}, {27146, -1, -1, -1}, {29033, -1, -1, -1}, {29140, -1, -1, -1}, {30058, -1, -1, -1}, {32321, -1, -1, -1}, {34115, -1, -1, -1}, {34281, -1, -1, -1}, {39132, -1, -1, -1}, {20240, -1, -1, -1}, {31567, -1, -1, -1}, {32624, -1, -1, -1}, {38309, -1, -1, -1}, {20961, -1, -1, -1}, {24070, -1, -1, -1}, {26805, -1, -1, -1}, {27710, -1, -1, -1}, {27726, -1, -1, -1}, {27867, -1, -1, -1}, {29359, -1, -1, -1}, {31684, -1, -1, -1}, {33539, -1, -1, -1}, {27861, -1, -1, -1}, {29754, -1, -1, -1}, {20731, -1, -1, -1}, {21128, -1, -1, -1}, {22721, -1, -1, -1}, {25816, -1, -1, -1}, {27287, -1, -1, -1}, {29863, -1, -1, -1}, {30294, -1, -1, -1}, {30887, -1, -1, -1}, {34327, -1, -1, -1}, {38370, -1, -1, -1}, {38713, -1, -1, -1}, {21342, -1, -1, -1}, {24321, -1, -1, -1}, {35722, -1, -1, -1}, {36776, -1, -1, -1}, {36783, -1, -1, -1}, {37002, -1, -1, -1}, {21029, -1, -1, -1}, {30629, -1, -1, -1}, {40009, -1, -1, -1}, {40712, -1, -1, -1}, {19993, -1, -1, -1}, {20482, -1, -1, -1}, {20853, -1, -1, -1}, {23643, -1, -1, -1}, {24183, -1, -1, -1}, {26142, -1, -1, -1}, {26170, -1, -1, -1}, {26564, -1, -1, -1}, {26821, -1, -1, -1}, {28851, -1, -1, -1}, {29953, -1, -1, -1}, {30149, -1, -1, -1}, {31177, -1, -1, -1}, {31453, -1, -1, -1}, {36647, -1, -1, -1}, {39200, -1, -1, -1}, {39432, -1, -1, -1}, {20445, -1, -1, -1}, {22561, -1, -1, -1}, {22577, -1, -1, -1}, {23542, -1, -1, -1}, {26222, -1, -1, -1}, {27493, -1, -1, -1}, {27921, -1, -1, -1}, {28282, -1, -1, -1}, {28541, -1, -1, -1}, {29668, -1, -1, -1}, {29995, -1, -1, -1}, {33769, -1, -1, -1}, {35036, -1, -1, -1}, {35091, -1, -1, -1}, {35676, -1, -1, -1}, {36628, -1, -1, -1}, {20239, -1, -1, -1}, {20693, -1, -1, -1}, {21264, -1, -1, -1}, {21340, -1, -1, -1}, {23443, -1, -1, -1}, {24489, 63846, -1, -1}, {26381, -1, -1, -1}, {31119, -1, -1, -1}, {33145, -1, -1, -1}, {33583, -1, -1, -1}, {34068, -1, -1, -1}, {35079, -1, -1, -1}, {35206, -1, -1, -1}, {36665, -1, -1, -1}, {36667, 64007, -1, -1}, {39333, -1, -1, -1}, {39954, -1, -1, -1}, {26412, -1, -1, -1}, {20086, -1, -1, -1}, {20472, -1, -1, -1}, {22857, -1, -1, -1}, {23553, -1, -1, -1}, {23791, -1, -1, -1}, {23792, -1, -1, -1}, {25447, -1, -1, -1}, {26834, -1, -1, -1}, {28925, -1, -1, -1}, {29090, -1, -1, -1}, {29739, -1, -1, -1}, {32299, -1, -1, -1}, {34028, -1, -1, -1}, {34562, -1, -1, -1}, {36898, -1, -1, -1}, {37586, -1, -1, -1}, {40179, -1, -1, -1}, {19981, 63847, -1, -1}, {20184, -1, -1, -1}, {20463, -1, -1, -1}, {20613, -1, -1, -1}, {21078, -1, -1, -1}, {21103, -1, -1, -1}, {21542, -1, -1, -1}, {21648, -1, -1, -1}, {22496, -1, -1, -1}, {22827, -1, -1, -1}, {23142, -1, -1, -1} },
+ {{23386, -1, -1, -1}, {23413, -1, -1, -1}, {23500, -1, -1, -1}, {24220, -1, -1, -1}, {25206, -1, -1, -1}, {25975, -1, -1, -1}, {26023, -1, -1, -1}, {28014, -1, -1, -1}, {28325, -1, -1, -1}, {29238, -1, -1, -1}, {31526, -1, -1, -1}, {31807, -1, -1, -1}, {32566, -1, -1, -1}, {33104, -1, -1, -1}, {33105, -1, -1, -1}, {33178, -1, -1, -1}, {33344, -1, -1, -1}, {33433, -1, -1, -1}, {33705, -1, -1, -1}, {35331, -1, -1, -1}, {36000, -1, -1, -1}, {36070, -1, -1, -1}, {36091, -1, -1, -1}, {36212, -1, -1, -1}, {36282, -1, -1, -1}, {37096, -1, -1, -1}, {37340, -1, -1, -1}, {38428, -1, -1, -1}, {38468, -1, -1, -1}, {39385, -1, -1, -1}, {40167, -1, -1, -1}, {21271, 63843, -1, -1}, {20998, -1, -1, -1}, {21545, -1, -1, -1}, {22132, -1, -1, -1}, {22707, -1, -1, -1}, {22868, -1, -1, -1}, {22894, -1, -1, -1}, {24575, -1, -1, -1}, {24996, -1, -1, -1}, {25198, -1, -1, -1}, {26128, -1, -1, -1}, {27774, -1, -1, -1}, {28954, -1, -1, -1}, {30406, -1, -1, -1}, {31881, -1, -1, -1}, {31966, -1, -1, -1}, {32027, -1, -1, -1}, {33452, -1, -1, -1}, {36033, -1, -1, -1}, {38640, -1, -1, -1}, {20315, -1, -1, -1}, {24343, -1, -1, -1}, {24447, -1, -1, -1}, {25282, -1, -1, -1}, {23849, -1, -1, -1}, {26379, -1, -1, -1}, {26842, -1, -1, -1}, {30844, -1, -1, -1}, {32323, -1, -1, -1}, {40300, -1, -1, -1}, {19989, -1, -1, -1}, {20633, -1, -1, -1}, {21269, -1, -1, -1}, {21290, -1, -1, -1}, {21329, -1, -1, -1}, {22915, -1, -1, -1}, {23138, -1, -1, -1}, {24199, -1, -1, -1}, {24754, -1, -1, -1}, {24970, -1, -1, -1}, {25161, -1, -1, -1}, {25209, -1, -1, -1}, {26000, -1, -1, -1}, {26503, -1, -1, -1}, {27047, -1, -1, -1}, {27604, -1, -1, -1}, {27606, -1, -1, -1}, {27607, -1, -1, -1}, {27608, -1, -1, -1}, {27832, -1, -1, -1}, {29749, -1, -1, -1}, {30202, -1, -1, -1}, {30738, -1, -1, -1}, {30865, -1, -1, -1}, {31189, -1, -1, -1}, {31192, -1, -1, -1}, {31875, -1, -1, -1}, {32203, -1, -1, -1}, {32737, -1, -1, -1}, {32933, -1, -1, -1}, {33086, -1, -1, -1}, {33218, -1, -1, -1}, {33778, -1, -1, -1}, {34586, -1, -1, -1}, {35048, -1, -1, -1}, {35513, -1, -1, -1}, {35692, -1, -1, -1}, {36027, -1, -1, -1}, {37145, -1, -1, -1}, {38750, -1, -1, -1}, {39131, -1, -1, -1}, {40763, -1, -1, -1}, {22188, -1, -1, -1}, {23338, -1, -1, -1}, {24428, -1, -1, -1}, {25996, -1, -1, -1}, {27315, -1, -1, -1}, {27567, -1, -1, -1}, {27996, -1, -1, -1}, {28657, -1, -1, -1}, {28693, -1, -1, -1}, {29277, -1, -1, -1}, {29613, -1, -1, -1}, {36007, -1, -1, -1}, {36051, -1, -1, -1}, {38971, -1, -1, -1}, {24977, -1, -1, -1}, {27703, -1, -1, -1}, {32856, -1, -1, -1}, {39425, -1, -1, -1}, {20045, -1, -1, -1}, {20107, -1, -1, -1}, {20123, -1, -1, -1}, {20181, -1, -1, -1}, {20282, -1, -1, -1}, {20284, -1, -1, -1}, {20351, -1, -1, -1}, {20447, -1, -1, -1}, {20735, -1, -1, -1}, {21490, -1, -1, -1}, {21496, -1, -1, -1}, {21766, -1, -1, -1}, {21987, -1, -1, -1}, {22235, -1, -1, -1}, {22763, -1, -1, -1}, {22882, -1, -1, -1}, {23057, -1, -1, -1}, {23531, -1, -1, -1}, {23546, -1, -1, -1}, {23556, -1, -1, -1}, {24051, -1, -1, -1}, {24107, -1, -1, -1}, {24473, -1, -1, -1}, {24605, -1, -1, -1}, {25448, -1, -1, -1}, {26012, -1, -1, -1}, {26031, -1, -1, -1}, {26614, -1, -1, -1}, {26619, -1, -1, -1}, {26797, -1, -1, -1}, {27515, -1, -1, -1}, {27801, -1, -1, -1}, {27863, -1, -1, -1}, {28195, -1, -1, -1}, {28681, -1, -1, -1}, {29509, -1, -1, -1}, {30722, -1, -1, -1}, {31038, -1, -1, -1}, {31040, -1, -1, -1}, {31072, -1, -1, -1}, {31169, -1, -1, -1}, {31721, -1, -1, -1}, {32023, -1, -1, -1}, {32114, -1, -1, -1}, {32902, -1, -1, -1}, {33293, -1, -1, -1}, {33678, -1, -1, -1}, {34001, -1, -1, -1}, {34503, -1, -1, -1}, {35039, -1, -1, -1}, {35408, -1, -1, -1}, {35422, -1, -1, -1}, {35613, -1, -1, -1}, {36060, -1, -1, -1}, {36198, -1, -1, -1}, {36781, -1, -1, -1}, {37034, -1, -1, -1}, {39164, -1, -1, -1}, {39391, -1, -1, -1}, {40605, -1, -1, -1}, {21066, -1, -1, -1}, {26388, -1, -1, -1}, {20632, -1, -1, -1}, {21034, -1, -1, -1}, {23665, -1, -1, -1}, {25955, -1, -1, -1}, {27733, -1, -1, -1}, {29642, -1, -1, -1}, {29987, -1, -1, -1}, {30109, -1, -1, -1}, {31639, -1, -1, -1}, {33948, -1, -1, -1}, {37240, -1, -1, -1}, {38704, -1, -1, -1}, {20087, -1, -1, -1}, {25746, -1, -1, -1}, {27578, 63856, -1, -1}, {29022, -1, -1, -1}, {34217, -1, -1, -1}, {19977, -1, -1, -1}, {26441, -1, -1, -1}, {26862, -1, -1, -1}, {28183, -1, -1, -1}, {33439, -1, -1, -1}, {34072, -1, -1, -1}, {34923, -1, -1, -1}, {25591, -1, -1, -1}, {28545, -1, -1, -1}, {37394, -1, -1, -1}, {39087, -1, -1, -1}, {19978, -1, -1, -1}, {20663, -1, -1, -1}, {20687, -1, -1, -1}, {20767, -1, -1, -1}, {21830, -1, -1, -1}, {21930, -1, -1, -1}, {22039, -1, -1, -1}, {23360, -1, -1, -1}, {23577, -1, -1, -1}, {23776, -1, -1, -1}, {24120, -1, -1, -1}, {24202, -1, -1, -1}, {24224, -1, -1, -1}, {24258, -1, -1, -1}, {24819, -1, -1, -1}, {26705, -1, -1, -1}, {27233, -1, -1, -1}, {28248, -1, -1, -1}, {29245, -1, -1, -1}, {29248, -1, -1, -1}, {29376, 63994, -1, -1}, {30456, -1, -1, -1}, {31077, -1, -1, -1}, {31665, -1, -1, -1}, {32724, -1, -1, -1}, {35059, -1, -1, -1}, {35316, -1, -1, -1}, {35443, -1, -1, -1}, {35937, -1, -1, -1}, {36062, -1, -1, -1}, {38684, -1, -1, -1}, {22622, 63852, -1, -1}, {29885, -1, -1, -1}, {36093, -1, -1, -1}, {21959, -1, -1, -1}, {31329, -1, -1, -1}, {32034, 63850, -1, -1}, {33394, -1, -1, -1}, {29298, -1, -1, -1}, {29983, -1, -1, -1}, {29989, -1, -1, -1}, {31513, -1, -1, -1}, {22661, -1, -1, -1}, {22779, -1, -1, -1}, {23996, -1, -1, -1} },
+ {{24207, -1, -1, -1}, {24246, -1, -1, -1}, {24464, -1, -1, -1}, {24661, -1, -1, -1}, {25234, -1, -1, -1}, {25471, -1, -1, -1}, {25933, -1, -1, -1}, {26257, -1, -1, -1}, {26329, -1, -1, -1}, {26360, -1, -1, -1}, {26646, -1, -1, -1}, {26866, -1, -1, -1}, {29312, -1, -1, -1}, {29790, -1, -1, -1}, {31598, -1, -1, -1}, {32110, -1, -1, -1}, {32214, -1, -1, -1}, {32626, -1, -1, -1}, {32997, -1, -1, -1}, {33298, -1, -1, -1}, {34223, -1, -1, -1}, {35199, -1, -1, -1}, {35475, -1, -1, -1}, {36893, -1, -1, -1}, {37604, -1, -1, -1}, {40653, -1, -1, -1}, {40736, -1, -1, -1}, {22805, -1, -1, -1}, {22893, -1, -1, -1}, {24109, -1, -1, -1}, {24796, -1, -1, -1}, {26132, -1, -1, -1}, {26227, -1, -1, -1}, {26512, -1, -1, -1}, {27728, -1, -1, -1}, {28101, -1, -1, -1}, {28511, -1, -1, -1}, {30707, -1, -1, -1}, {30889, -1, -1, -1}, {33990, -1, -1, -1}, {37323, -1, -1, -1}, {37675, -1, -1, -1}, {20185, -1, -1, -1}, {20682, -1, -1, -1}, {20808, -1, -1, -1}, {21892, -1, -1, -1}, {23307, -1, -1, -1}, {23459, -1, -1, -1}, {25159, -1, -1, -1}, {25982, -1, -1, -1}, {26059, -1, -1, -1}, {28210, -1, -1, -1}, {29053, -1, -1, -1}, {29697, -1, -1, -1}, {29764, -1, -1, -1}, {29831, -1, -1, -1}, {29887, -1, -1, -1}, {30316, -1, -1, -1}, {31146, -1, -1, -1}, {32218, -1, -1, -1}, {32341, -1, -1, -1}, {32680, -1, -1, -1}, {33146, -1, -1, -1}, {33203, -1, -1, -1}, {33337, -1, -1, -1}, {34330, -1, -1, -1}, {34796, -1, -1, -1}, {35445, -1, -1, -1}, {36323, -1, -1, -1}, {36984, -1, -1, -1}, {37521, -1, -1, -1}, {37925, -1, -1, -1}, {39245, -1, -1, -1}, {39854, -1, -1, -1}, {21352, -1, -1, -1}, {23633, -1, -1, -1}, {26964, -1, -1, -1}, {27844, -1, -1, -1}, {27945, -1, -1, -1}, {28203, -1, -1, -1}, {33292, -1, -1, -1}, {34203, -1, -1, -1}, {35131, -1, -1, -1}, {35373, -1, -1, -1}, {35498, 63855, 63905, -1}, {38634, -1, -1, -1}, {40807, -1, -1, -1}, {21089, -1, -1, -1}, {26297, -1, -1, -1}, {27570, -1, -1, -1}, {32406, -1, -1, -1}, {34814, -1, -1, -1}, {36109, -1, -1, -1}, {38275, -1, -1, -1}, {38493, -1, -1, -1}, {25885, -1, -1, -1}, {28041, -1, -1, -1}, {29166, -1, -1, -1}, {22478, -1, -1, -1}, {22995, -1, -1, -1}, {23468, -1, -1, -1}, {24615, -1, -1, -1}, {24826, -1, -1, -1}, {25104, -1, -1, -1}, {26143, -1, -1, -1}, {26207, -1, -1, -1}, {29481, -1, -1, -1}, {29689, -1, -1, -1}, {30427, -1, -1, -1}, {30465, 63853, -1, -1}, {31596, -1, -1, -1}, {32854, -1, -1, -1}, {32882, -1, -1, -1}, {33125, -1, -1, -1}, {35488, -1, -1, -1}, {37266, -1, -1, -1}, {19990, -1, -1, -1}, {21218, -1, -1, -1}, {27506, -1, -1, -1}, {27927, -1, -1, -1}, {31237, -1, -1, -1}, {31545, -1, -1, -1}, {32048, -1, -1, -1}, {36016, -1, -1, -1}, {21484, -1, -1, -1}, {22063, -1, -1, -1}, {22609, -1, -1, -1}, {23477, -1, -1, -1}, {23567, -1, -1, -1}, {23569, -1, -1, -1}, {24034, -1, -1, -1}, {25152, -1, -1, -1}, {25475, -1, -1, -1}, {25620, -1, -1, -1}, {26157, -1, -1, -1}, {26803, -1, -1, -1}, {27836, -1, -1, -1}, {28040, -1, -1, -1}, {28335, -1, -1, -1}, {28703, -1, -1, -1}, {28836, -1, -1, -1}, {29138, -1, -1, -1}, {29990, -1, -1, -1}, {30095, -1, -1, -1}, {30094, -1, -1, -1}, {30233, -1, -1, -1}, {31505, -1, -1, -1}, {31712, -1, -1, -1}, {31787, -1, -1, -1}, {32032, -1, -1, -1}, {32057, -1, -1, -1}, {34092, -1, -1, -1}, {34157, -1, -1, -1}, {34311, -1, -1, -1}, {35380, -1, -1, -1}, {36877, -1, -1, -1}, {36961, -1, -1, -1}, {37045, -1, -1, -1}, {37559, -1, -1, -1}, {38902, -1, -1, -1}, {39479, -1, -1, -1}, {20439, -1, -1, -1}, {23660, -1, -1, -1}, {26463, -1, -1, -1}, {28049, -1, -1, -1}, {31903, -1, -1, -1}, {32396, -1, -1, -1}, {35606, -1, -1, -1}, {36118, -1, -1, -1}, {36895, -1, -1, -1}, {23403, -1, -1, -1}, {24061, -1, -1, -1}, {25613, -1, -1, -1}, {33984, -1, -1, -1}, {36956, -1, -1, -1}, {39137, -1, -1, -1}, {29575, 63841, 63963, -1}, {23435, -1, -1, -1}, {24730, -1, -1, -1}, {26494, -1, -1, -1}, {28126, -1, -1, -1}, {35359, -1, -1, -1}, {35494, -1, -1, -1}, {36865, -1, -1, -1}, {38924, -1, -1, -1}, {21047, -1, -1, -1}, {28753, -1, -1, -1}, {30862, -1, -1, -1}, {37782, -1, -1, -1}, {34928, -1, -1, -1}, {37335, -1, -1, -1}, {20462, -1, -1, -1}, {21463, -1, -1, -1}, {22013, -1, -1, -1}, {22234, -1, -1, -1}, {22402, -1, -1, -1}, {22781, -1, -1, -1}, {23234, -1, -1, -1}, {23432, -1, -1, -1}, {23723, -1, -1, -1}, {23744, -1, -1, -1}, {24101, -1, -1, -1}, {24833, -1, -1, -1}, {25101, -1, -1, -1}, {25163, -1, -1, -1}, {25480, -1, -1, -1}, {25628, -1, -1, -1}, {25910, -1, -1, -1}, {25976, 63849, -1, -1}, {27193, -1, -1, -1}, {27530, -1, -1, -1}, {27700, -1, -1, -1}, {27929, -1, -1, -1}, {28465, -1, -1, -1}, {29159, -1, -1, -1}, {29417, -1, -1, -1}, {29560, -1, -1, -1}, {29703, -1, -1, -1}, {29874, -1, -1, -1}, {30246, -1, -1, -1}, {30561, -1, -1, -1}, {31168, -1, -1, -1}, {31319, -1, -1, -1}, {31466, -1, -1, -1}, {31929, -1, -1, -1}, {32143, -1, -1, -1}, {32172, -1, -1, -1}, {32353, -1, -1, -1}, {32670, -1, -1, -1}, {33065, -1, -1, -1}, {33585, -1, -1, -1}, {33936, -1, -1, -1}, {34010, -1, -1, -1}, {34282, -1, -1, -1}, {34966, -1, -1, -1}, {35504, -1, -1, -1}, {35728, -1, -1, -1}, {36664, -1, -1, -1}, {36930, -1, -1, -1}, {36995, -1, -1, -1}, {37228, -1, -1, -1}, {37526, -1, -1, -1}, {37561, -1, -1, -1}, {38539, -1, -1, -1}, {38567, -1, -1, -1}, {38568, -1, -1, -1}, {38614, -1, -1, -1}, {38656, -1, -1, -1}, {38920, -1, -1, -1}, {39318, -1, -1, -1}, {39635, -1, -1, -1}, {39706, -1, -1, -1}, {21460, -1, -1, -1}, {22654, -1, -1, -1}, {22809, -1, -1, -1}, {23408, -1, -1, -1} },
+ {{23487, -1, -1, -1}, {28113, -1, -1, -1}, {28506, -1, -1, -1}, {29087, -1, -1, -1}, {29729, -1, -1, -1}, {29881, -1, -1, -1}, {32901, -1, -1, -1}, {33789, -1, -1, -1}, {24033, -1, -1, -1}, {24455, -1, -1, -1}, {24490, -1, -1, -1}, {24642, -1, -1, -1}, {26092, -1, -1, -1}, {26642, -1, -1, -1}, {26991, -1, -1, -1}, {27219, -1, -1, -1}, {27529, -1, -1, -1}, {27957, -1, -1, -1}, {28147, -1, -1, -1}, {29667, -1, -1, -1}, {30462, -1, -1, -1}, {30636, -1, -1, -1}, {31565, -1, -1, -1}, {32020, -1, -1, -1}, {33059, -1, -1, -1}, {33308, -1, -1, -1}, {33600, -1, -1, -1}, {34036, -1, -1, -1}, {34147, -1, -1, -1}, {35426, -1, -1, -1}, {35524, -1, -1, -1}, {37255, -1, -1, -1}, {37662, -1, -1, -1}, {38918, -1, -1, -1}, {39348, -1, -1, -1}, {25100, -1, -1, -1}, {34899, -1, -1, -1}, {36848, -1, -1, -1}, {37477, -1, -1, -1}, {23815, -1, -1, -1}, {23847, -1, -1, -1}, {23913, -1, -1, -1}, {29791, -1, -1, -1}, {33181, -1, -1, -1}, {34664, -1, -1, -1}, {28629, -1, -1, -1}, {25342, 63859, -1, -1}, {32722, -1, -1, -1}, {35126, -1, -1, -1}, {35186, -1, -1, -1}, {19998, -1, -1, -1}, {20056, -1, -1, -1}, {20711, -1, -1, -1}, {21213, -1, -1, -1}, {21319, -1, -1, -1}, {25215, -1, -1, -1}, {26119, -1, -1, -1}, {32361, -1, -1, -1}, {34821, -1, -1, -1}, {38494, -1, -1, -1}, {20365, -1, -1, -1}, {21273, -1, -1, -1}, {22070, -1, -1, -1}, {22987, -1, -1, -1}, {23204, -1, -1, -1}, {23608, -1, -1, -1}, {23630, -1, -1, -1}, {23629, -1, -1, -1}, {24066, -1, -1, -1}, {24337, -1, -1, -1}, {24643, -1, -1, -1}, {26045, -1, -1, -1}, {26159, -1, -1, -1}, {26178, -1, -1, -1}, {26558, -1, -1, -1}, {26612, -1, -1, -1}, {29468, -1, -1, -1}, {30690, -1, -1, -1}, {31034, -1, -1, -1}, {32709, -1, -1, -1}, {33940, -1, -1, -1}, {33997, -1, -1, -1}, {35222, -1, -1, -1}, {35430, -1, -1, -1}, {35433, -1, -1, -1}, {35553, -1, -1, -1}, {35925, -1, -1, -1}, {35962, -1, -1, -1}, {22516, -1, -1, -1}, {23508, -1, -1, -1}, {24335, -1, -1, -1}, {24687, -1, -1, -1}, {25325, -1, -1, -1}, {26893, -1, -1, -1}, {27542, -1, -1, -1}, {28252, -1, -1, -1}, {29060, -1, -1, -1}, {31698, -1, -1, -1}, {34645, -1, -1, -1}, {35672, 63996, -1, -1}, {36606, -1, -1, -1}, {39135, -1, -1, -1}, {39166, -1, -1, -1}, {20280, -1, -1, -1}, {20353, -1, -1, -1}, {20449, -1, -1, -1}, {21627, -1, -1, -1}, {23072, -1, -1, -1}, {23480, -1, -1, -1}, {24892, -1, -1, -1}, {26032, -1, -1, -1}, {26216, -1, -1, -1}, {29180, -1, -1, -1}, {30003, -1, -1, -1}, {31070, -1, -1, -1}, {32051, -1, -1, -1}, {33102, -1, -1, -1}, {33251, -1, -1, -1}, {33688, -1, -1, -1}, {34218, -1, -1, -1}, {34254, -1, -1, -1}, {34563, -1, -1, -1}, {35338, -1, -1, -1}, {36523, -1, -1, -1}, {36763, -1, -1, -1}, {36805, -1, -1, -1}, {22833, -1, -1, -1}, {23460, -1, -1, -1}, {23526, -1, -1, -1}, {24713, -1, -1, -1}, {23529, -1, -1, -1}, {23563, -1, -1, -1}, {24515, -1, -1, -1}, {27777, -1, -1, -1}, {28145, -1, -1, -1}, {28683, -1, -1, -1}, {29978, -1, -1, -1}, {33455, -1, -1, -1}, {35574, -1, -1, -1}, {20160, 63997, -1, -1}, {21313, -1, -1, -1}, {38617, -1, -1, -1}, {27663, -1, -1, -1}, {20126, -1, -1, -1}, {20420, -1, -1, -1}, {20818, -1, -1, -1}, {21854, -1, -1, -1}, {23077, -1, -1, -1}, {23784, -1, -1, -1}, {25105, -1, -1, -1}, {29273, -1, -1, -1}, {33469, -1, -1, -1}, {33706, -1, -1, -1}, {34558, -1, -1, -1}, {34905, -1, -1, -1}, {35357, -1, -1, -1}, {38463, -1, -1, -1}, {38597, -1, -1, -1}, {39187, -1, -1, -1}, {40201, -1, -1, -1}, {40285, -1, -1, -1}, {22538, -1, -1, -1}, {23731, -1, -1, -1}, {23997, -1, -1, -1}, {24132, -1, -1, -1}, {24801, 63929, -1, -1}, {24853, -1, -1, -1}, {25569, -1, -1, -1}, {27138, 63836, 63764, 63935}, {28197, -1, -1, -1}, {37122, -1, -1, -1}, {37716, -1, -1, -1}, {38990, -1, -1, -1}, {39952, -1, -1, -1}, {40823, -1, -1, -1}, {23433, -1, -1, -1}, {23736, -1, -1, -1}, {25353, -1, -1, -1}, {26191, -1, -1, -1}, {26696, -1, -1, -1}, {30524, -1, -1, -1}, {38593, -1, -1, -1}, {38797, -1, -1, -1}, {38996, -1, -1, -1}, {39839, -1, -1, -1}, {26017, -1, -1, -1}, {35585, -1, -1, -1}, {36555, -1, -1, -1}, {38332, -1, -1, -1}, {21813, -1, -1, -1}, {23721, -1, -1, -1}, {24022, -1, -1, -1}, {24245, -1, -1, -1}, {26263, -1, -1, -1}, {30284, -1, -1, -1}, {33780, -1, -1, -1}, {38343, -1, -1, -1}, {22739, -1, -1, -1}, {25276, -1, -1, -1}, {29390, -1, -1, -1}, {40232, -1, -1, -1}, {20208, -1, -1, -1}, {22830, -1, -1, -1}, {24591, -1, -1, -1}, {26171, -1, -1, -1}, {27523, -1, -1, -1}, {31207, -1, -1, -1}, {40230, -1, -1, -1}, {21395, -1, -1, -1}, {21696, -1, -1, -1}, {22467, -1, -1, -1}, {23830, -1, -1, -1}, {24859, -1, -1, -1}, {26326, -1, -1, -1}, {28079, -1, -1, -1}, {30861, -1, -1, -1}, {33406, -1, -1, -1}, {38552, -1, -1, -1}, {38724, -1, -1, -1}, {21380, -1, -1, -1}, {25212, -1, -1, -1}, {25494, -1, -1, -1}, {28082, -1, -1, -1}, {32266, -1, -1, -1}, {33099, -1, -1, -1}, {38989, -1, -1, -1}, {27387, -1, -1, -1}, {32588, -1, -1, -1}, {40367, -1, -1, -1}, {40474, -1, -1, -1}, {20063, -1, -1, -1}, {20539, -1, -1, -1}, {20918, -1, -1, -1}, {22812, -1, -1, -1}, {24825, -1, -1, -1}, {25590, -1, -1, -1}, {26928, -1, -1, -1}, {29242, -1, -1, -1}, {32822, -1, -1, -1}, {37326, -1, -1, -1}, {24369, -1, -1, -1}, {32004, -1, -1, -1}, {33509, 63860, -1, -1}, {33903, -1, -1, -1}, {33979, -1, -1, -1}, {34277, -1, -1, -1}, {36493, -1, -1, -1}, {20335, -1, -1, -1}, {22756, -1, -1, -1}, {23363, -1, -1, -1}, {24665, -1, -1, -1}, {25562, -1, -1, -1}, {25880, -1, -1, -1}, {25965, -1, -1, -1}, {26264, -1, -1, -1}, {26954, -1, -1, -1} },
+ {{27171, -1, -1, -1}, {27915, -1, -1, -1}, {28673, -1, -1, -1}, {29036, -1, -1, -1}, {30162, -1, -1, -1}, {30221, -1, -1, -1}, {31155, -1, -1, -1}, {31344, -1, -1, -1}, {32650, -1, -1, -1}, {35140, -1, -1, -1}, {35731, -1, -1, -1}, {37312, -1, -1, -1}, {38525, -1, -1, -1}, {39178, -1, -1, -1}, {22276, -1, -1, -1}, {24481, -1, -1, -1}, {26044, -1, -1, -1}, {28417, -1, -1, -1}, {30208, -1, -1, -1}, {31142, -1, -1, -1}, {35486, -1, -1, -1}, {39341, -1, -1, -1}, {39770, -1, -1, -1}, {40812, -1, -1, -1}, {20740, -1, -1, -1}, {25014, -1, -1, -1}, {25233, -1, -1, -1}, {27277, -1, -1, -1}, {33222, -1, -1, -1}, {20547, -1, -1, -1}, {22576, -1, -1, -1}, {24422, -1, -1, -1}, {28937, -1, -1, -1}, {35328, -1, -1, -1}, {35578, -1, -1, -1}, {23420, -1, -1, -1}, {34326, -1, -1, -1}, {20474, -1, -1, -1}, {20796, -1, -1, -1}, {22196, -1, -1, -1}, {22852, -1, -1, -1}, {25513, -1, -1, -1}, {28153, -1, -1, -1}, {23978, -1, -1, -1}, {26989, -1, -1, -1}, {20870, -1, -1, -1}, {20104, -1, -1, -1}, {20313, -1, -1, -1}, {22914, -1, -1, -1}, {27487, -1, -1, -1}, {27741, -1, -1, -1}, {29877, -1, -1, -1}, {30998, -1, -1, -1}, {33287, -1, -1, -1}, {33349, -1, -1, -1}, {33593, -1, -1, -1}, {36671, -1, -1, -1}, {36701, -1, -1, -1}, {39192, -1, -1, -1}, {20134, -1, -1, -1}, {22495, -1, -1, -1}, {24441, -1, -1, -1}, {26131, 63968, -1, -1}, {30123, -1, -1, -1}, {32377, -1, -1, -1}, {35695, -1, -1, -1}, {36870, -1, -1, -1}, {39515, -1, -1, -1}, {22181, -1, -1, -1}, {22567, -1, -1, -1}, {23032, -1, -1, -1}, {23071, -1, -1, -1}, {23476, -1, -1, -1}, {24310, -1, -1, -1}, {25424, -1, -1, -1}, {25403, -1, -1, -1}, {26941, -1, -1, -1}, {27783, -1, -1, -1}, {27839, -1, -1, -1}, {28046, -1, -1, -1}, {28051, -1, -1, -1}, {28149, -1, -1, -1}, {28436, -1, -1, -1}, {28895, -1, -1, -1}, {28982, -1, -1, -1}, {29017, -1, -1, -1}, {29123, -1, -1, -1}, {29141, -1, -1, -1}, {30799, -1, -1, -1}, {30831, -1, -1, -1}, {31605, -1, -1, -1}, {32227, -1, -1, -1}, {32303, -1, -1, -1}, {34893, -1, -1, -1}, {36575, -1, -1, -1}, {37467, -1, -1, -1}, {40182, -1, -1, -1}, {24709, -1, -1, -1}, {28037, -1, -1, -1}, {29105, -1, -1, -1}, {38321, -1, -1, -1}, {21421, -1, -1, -1}, {26579, -1, -1, -1}, {28814, -1, -1, -1}, {28976, -1, -1, -1}, {29744, -1, -1, -1}, {33398, -1, -1, -1}, {33490, -1, -1, -1}, {38331, -1, -1, -1}, {39653, -1, -1, -1}, {40573, -1, -1, -1}, {26308, -1, -1, -1}, {29121, -1, -1, -1}, {33865, 63854, -1, -1}, {22603, -1, -1, -1}, {23992, -1, -1, -1}, {24433, -1, -1, -1}, {26144, -1, -1, -1}, {26254, -1, -1, -1}, {27001, -1, -1, -1}, {27054, -1, -1, -1}, {27704, -1, -1, -1}, {27891, -1, -1, -1}, {28214, -1, -1, -1}, {28481, -1, -1, -1}, {28634, -1, -1, -1}, {28699, -1, -1, -1}, {28719, -1, -1, -1}, {29008, -1, -1, -1}, {29151, -1, -1, -1}, {29552, -1, -1, -1}, {29787, -1, -1, -1}, {29908, -1, -1, -1}, {30408, -1, -1, -1}, {31310, -1, -1, -1}, {32403, -1, -1, -1}, {33521, -1, -1, -1}, {35424, -1, -1, -1}, {36814, -1, -1, -1}, {37704, -1, -1, -1}, {38681, -1, -1, -1}, {20034, -1, -1, -1}, {20522, -1, -1, -1}, {21000, -1, -1, -1}, {21473, -1, -1, -1}, {26355, -1, -1, -1}, {27757, -1, -1, -1}, {28618, -1, -1, -1}, {29450, -1, -1, -1}, {30591, -1, -1, -1}, {31330, -1, -1, -1}, {33454, -1, -1, -1}, {34269, -1, -1, -1}, {34306, -1, -1, -1}, {35028, -1, -1, -1}, {35427, -1, -1, -1}, {35709, -1, -1, -1}, {35947, -1, -1, -1}, {37555, -1, -1, -1}, {38675, -1, -1, -1}, {38928, -1, -1, -1}, {20116, -1, -1, -1}, {20237, -1, -1, -1}, {20425, -1, -1, -1}, {20658, -1, -1, -1}, {21320, -1, -1, -1}, {21566, -1, -1, -1}, {21555, -1, -1, -1}, {21978, -1, -1, -1}, {22626, -1, -1, -1}, {22714, -1, -1, -1}, {22887, -1, -1, -1}, {23067, -1, -1, -1}, {23524, -1, -1, -1}, {24735, -1, -1, -1}, {25034, -1, -1, -1}, {25942, -1, -1, -1}, {26111, -1, -1, -1}, {26212, -1, -1, -1}, {26791, -1, -1, -1}, {27738, -1, -1, -1}, {28595, -1, -1, -1}, {28879, -1, -1, -1}, {29100, -1, -1, -1}, {29522, -1, -1, -1}, {31613, -1, -1, -1}, {34568, -1, -1, -1}, {35492, -1, -1, -1}, {39986, -1, -1, -1}, {40711, -1, -1, -1}, {23627, -1, -1, -1}, {27779, -1, -1, -1}, {29508, -1, -1, -1}, {29577, -1, -1, -1}, {37434, -1, -1, -1}, {28331, -1, -1, -1}, {29797, -1, -1, -1}, {30239, -1, -1, -1}, {31337, -1, -1, -1}, {32277, -1, -1, -1}, {34314, -1, -1, -1}, {20800, -1, -1, -1}, {22725, -1, -1, -1}, {25793, -1, -1, -1}, {29934, -1, -1, -1}, {29973, -1, -1, -1}, {30320, -1, -1, -1}, {32705, -1, -1, -1}, {37013, -1, -1, -1}, {38605, -1, -1, -1}, {39252, -1, -1, -1}, {28198, -1, -1, -1}, {29926, -1, -1, -1}, {31401, -1, -1, -1}, {31402, -1, -1, -1}, {33253, -1, -1, -1}, {34521, -1, -1, -1}, {34680, -1, -1, -1}, {35355, -1, -1, -1}, {23113, -1, -1, -1}, {23436, -1, -1, -1}, {23451, -1, -1, -1}, {26785, -1, -1, -1}, {26880, -1, -1, -1}, {28003, -1, -1, -1}, {29609, -1, -1, -1}, {29715, -1, -1, -1}, {29740, -1, -1, -1}, {30871, -1, -1, -1}, {32233, -1, -1, -1}, {32747, -1, -1, -1}, {33048, -1, -1, -1}, {33109, -1, -1, -1}, {33694, -1, -1, -1}, {35916, -1, -1, -1}, {38446, 63942, -1, -1}, {38929, -1, -1, -1}, {26352, -1, -1, -1}, {24448, -1, -1, -1}, {26106, -1, -1, -1}, {26505, -1, -1, -1}, {27754, -1, -1, -1}, {29579, -1, -1, -1}, {20525, -1, -1, -1}, {23043, -1, -1, -1}, {27498, -1, -1, -1}, {30702, -1, -1, -1}, {22806, -1, -1, -1}, {23916, -1, -1, -1}, {24013, -1, -1, -1}, {29477, -1, -1, -1}, {30031, -1, -1, -1}, {20709, -1, -1, -1}, {20985, -1, -1, -1}, {22575, -1, -1, -1}, {22829, -1, -1, -1} },
+ {{22934, -1, -1, -1}, {23002, -1, -1, -1}, {23525, -1, -1, -1}, {23970, -1, -1, -1}, {25303, -1, -1, -1}, {25622, -1, -1, -1}, {25747, -1, -1, -1}, {25854, -1, -1, -1}, {26332, -1, -1, -1}, {27208, -1, -1, -1}, {29183, -1, -1, -1}, {29796, -1, -1, -1}, {31368, -1, -1, -1}, {31407, -1, -1, -1}, {32327, -1, -1, -1}, {32350, -1, -1, -1}, {32768, -1, -1, -1}, {33136, -1, -1, -1}, {34799, -1, -1, -1}, {35201, -1, -1, -1}, {35616, -1, -1, -1}, {36953, -1, -1, -1}, {36992, -1, -1, -1}, {39250, -1, -1, -1}, {24958, -1, -1, -1}, {27442, -1, -1, -1}, {28020, -1, -1, -1}, {32287, -1, -1, -1}, {35109, -1, -1, -1}, {36785, -1, -1, -1}, {20433, -1, -1, -1}, {20653, -1, -1, -1}, {20887, -1, -1, -1}, {21191, -1, -1, -1}, {22471, -1, -1, -1}, {22665, -1, -1, -1}, {23481, -1, -1, -1}, {24248, -1, -1, -1}, {24898, -1, -1, -1}, {27029, -1, -1, -1}, {28044, -1, -1, -1}, {28263, -1, -1, -1}, {28342, -1, -1, -1}, {29076, -1, -1, -1}, {29794, -1, -1, -1}, {29992, -1, -1, -1}, {29996, -1, -1, -1}, {32883, -1, -1, -1}, {33592, -1, -1, -1}, {33993, -1, -1, -1}, {36362, -1, -1, -1}, {37780, -1, -1, -1}, {37854, -1, -1, -1}, {20110, -1, -1, -1}, {20305, -1, -1, -1}, {20598, -1, -1, -1}, {20778, -1, -1, -1}, {21448, -1, -1, -1}, {21451, -1, -1, -1}, {21491, -1, -1, -1}, {23431, -1, -1, -1}, {23507, -1, -1, -1}, {23588, -1, -1, -1}, {24858, -1, -1, -1}, {24962, -1, -1, -1}, {26100, -1, -1, -1}, {29275, -1, -1, -1}, {29591, -1, -1, -1}, {29760, -1, -1, -1}, {30402, -1, -1, -1}, {31056, -1, -1, -1}, {31121, -1, -1, -1}, {31161, -1, -1, -1}, {32006, -1, -1, -1}, {32701, -1, -1, -1}, {33419, -1, -1, -1}, {34261, -1, -1, -1}, {34398, -1, -1, -1}, {36802, -1, -1, -1}, {36935, -1, -1, -1}, {37109, -1, -1, -1}, {37354, -1, -1, -1}, {38533, -1, -1, -1}, {38632, -1, -1, -1}, {38633, -1, -1, -1}, {21206, -1, -1, -1}, {24423, -1, -1, -1}, {26093, -1, -1, -1}, {26161, -1, -1, -1}, {26671, -1, -1, -1}, {29020, -1, -1, -1}, {31286, -1, -1, -1}, {37057, -1, -1, -1}, {38922, -1, -1, -1}, {20113, -1, -1, -1}, {27218, -1, -1, -1}, {27550, -1, -1, -1}, {28560, -1, -1, -1}, {29065, -1, -1, -1}, {32792, -1, -1, -1}, {33464, -1, -1, -1}, {34131, -1, -1, -1}, {36939, -1, -1, -1}, {38549, -1, -1, -1}, {38642, -1, -1, -1}, {38907, -1, -1, -1}, {34074, -1, -1, -1}, {39729, -1, -1, -1}, {20112, -1, -1, -1}, {29066, -1, -1, -1}, {38596, -1, -1, -1}, {20803, -1, -1, -1}, {21407, -1, -1, -1}, {21729, -1, -1, -1}, {22291, -1, -1, -1}, {22290, -1, -1, -1}, {22435, -1, -1, -1}, {23195, -1, -1, -1}, {23236, -1, -1, -1}, {23491, -1, -1, -1}, {24616, -1, -1, -1}, {24895, -1, -1, -1}, {25588, -1, -1, -1}, {27781, -1, -1, -1}, {27961, -1, -1, -1}, {28274, -1, -1, -1}, {28304, -1, -1, -1}, {29232, -1, -1, -1}, {29503, -1, -1, -1}, {29783, -1, -1, -1}, {33489, -1, -1, -1}, {34945, -1, -1, -1}, {36677, -1, -1, -1}, {36960, -1, -1, -1}, {38498, -1, -1, -1}, {39000, -1, -1, -1}, {40219, -1, -1, -1}, {26376, -1, -1, -1}, {36234, -1, -1, -1}, {37470, -1, -1, -1}, {20301, -1, -1, -1}, {20553, -1, -1, -1}, {20702, -1, -1, -1}, {21361, -1, -1, -1}, {22285, -1, -1, -1}, {22996, -1, -1, -1}, {23041, -1, -1, -1}, {23561, -1, -1, -1}, {24944, -1, -1, -1}, {26256, -1, -1, -1}, {28205, -1, -1, -1}, {29234, -1, -1, -1}, {29771, -1, -1, -1}, {32239, -1, -1, -1}, {32963, -1, -1, -1}, {33806, -1, -1, -1}, {33894, -1, -1, -1}, {34111, -1, -1, -1}, {34655, -1, -1, -1}, {34907, -1, -1, -1}, {35096, -1, -1, -1}, {35586, -1, -1, -1}, {36949, -1, -1, -1}, {38859, -1, -1, -1}, {39759, -1, -1, -1}, {20083, -1, -1, -1}, {20369, -1, -1, -1}, {20754, -1, -1, -1}, {20842, -1, -1, -1}, {21807, -1, -1, -1}, {21929, -1, -1, -1}, {23418, -1, -1, -1}, {23461, -1, -1, -1}, {24188, -1, -1, -1}, {24189, -1, -1, -1}, {24254, -1, -1, -1}, {24736, -1, -1, -1}, {24799, -1, -1, -1}, {24840, -1, -1, -1}, {24841, -1, -1, -1}, {25540, -1, -1, -1}, {25912, -1, -1, -1}, {26377, -1, -1, -1}, {26580, -1, -1, -1}, {26586, -1, -1, -1}, {26977, -1, -1, -1}, {26978, -1, -1, -1}, {27833, -1, -1, -1}, {27943, -1, -1, -1}, {28216, -1, -1, -1}, {28641, -1, -1, -1}, {29494, -1, -1, -1}, {29495, -1, -1, -1}, {29788, -1, -1, -1}, {30001, -1, -1, -1}, {30290, -1, -1, -1}, {32173, -1, -1, -1}, {33278, -1, -1, -1}, {33848, -1, -1, -1}, {35029, -1, -1, -1}, {35480, -1, -1, -1}, {35547, -1, -1, -1}, {35565, -1, -1, -1}, {36400, -1, -1, -1}, {36418, -1, -1, -1}, {36938, -1, -1, -1}, {36926, -1, -1, -1}, {36986, -1, -1, -1}, {37193, -1, -1, -1}, {37321, -1, -1, -1}, {37742, -1, -1, -1}, {22537, -1, -1, -1}, {27603, -1, -1, -1}, {32905, -1, -1, -1}, {32946, -1, -1, -1}, {20801, -1, -1, -1}, {22891, -1, -1, -1}, {23609, -1, -1, -1}, {28516, -1, -1, -1}, {29607, -1, -1, -1}, {32996, -1, -1, -1}, {36103, -1, -1, -1}, {37399, -1, -1, -1}, {38287, -1, -1, -1}, {32895, -1, -1, -1}, {25102, -1, -1, -1}, {28700, -1, -1, -1}, {32104, -1, -1, -1}, {34701, -1, -1, -1}, {22432, -1, -1, -1}, {24681, -1, -1, -1}, {24903, -1, -1, -1}, {27575, -1, -1, -1}, {35518, -1, -1, -1}, {37504, -1, -1, -1}, {38577, -1, -1, -1}, {20057, -1, -1, -1}, {21535, -1, -1, -1}, {28139, -1, -1, -1}, {34093, -1, -1, -1}, {38512, -1, -1, -1}, {38899, -1, -1, -1}, {39150, -1, -1, -1}, {25558, -1, -1, -1}, {27875, -1, -1, -1}, {37009, -1, -1, -1}, {20957, -1, -1, -1}, {25033, -1, -1, -1}, {33210, -1, -1, -1}, {40441, -1, -1, -1}, {20381, -1, -1, -1}, {20506, -1, -1, -1}, {20736, -1, -1, -1}, {23452, -1, -1, -1}, {24847, -1, -1, -1}, {25087, -1, -1, -1} },
+ {{25836, -1, -1, -1}, {26885, -1, -1, -1}, {27589, -1, -1, -1}, {30097, -1, -1, -1}, {30691, -1, -1, -1}, {32681, -1, -1, -1}, {33380, -1, -1, -1}, {34191, -1, -1, -1}, {34811, -1, -1, -1}, {34915, -1, -1, -1}, {35516, -1, -1, -1}, {35696, -1, -1, -1}, {37291, -1, -1, -1}, {20108, -1, -1, -1}, {20197, -1, -1, -1}, {20234, -1, -1, -1}, {22839, -1, -1, -1}, {23016, -1, -1, -1}, {24050, -1, -1, -1}, {24347, -1, -1, -1}, {24411, -1, -1, -1}, {24609, -1, -1, -1}, {29246, -1, -1, -1}, {29669, -1, -1, -1}, {30064, 63842, -1, -1}, {30157, -1, -1, -1}, {31227, -1, -1, -1}, {32780, -1, -1, -1}, {32819, -1, -1, -1}, {32900, -1, -1, -1}, {33505, -1, -1, -1}, {33617, -1, -1, -1}, {36029, -1, -1, -1}, {36019, -1, -1, -1}, {36999, -1, -1, -1}, {39156, -1, -1, -1}, {39180, -1, -1, -1}, {28727, -1, -1, -1}, {30410, -1, -1, -1}, {32714, -1, -1, -1}, {32716, -1, -1, -1}, {32764, -1, -1, -1}, {35610, -1, -1, -1}, {20154, -1, -1, -1}, {20161, -1, -1, -1}, {20995, -1, -1, -1}, {21360, -1, -1, -1}, {21693, 63902, -1, -1}, {22240, -1, -1, -1}, {23035, -1, -1, -1}, {23493, -1, -1, -1}, {24341, -1, -1, -1}, {24525, -1, -1, -1}, {28270, -1, -1, -1}, {32106, -1, -1, -1}, {33589, -1, -1, -1}, {34451, -1, -1, -1}, {35469, -1, -1, -1}, {38765, -1, -1, -1}, {38775, -1, -1, -1}, {19968, -1, -1, -1}, {20314, -1, -1, -1}, {20350, -1, -1, -1}, {22777, -1, -1, -1}, {26085, -1, -1, -1}, {28322, -1, -1, -1}, {36920, -1, -1, -1}, {37808, -1, -1, -1}, {39353, -1, -1, -1}, {20219, -1, -1, -1}, {22764, -1, -1, -1}, {22922, -1, -1, -1}, {23001, -1, -1, -1}, {24641, -1, -1, -1}, {31252, -1, -1, -1}, {33615, -1, -1, -1}, {36035, -1, -1, -1}, {20837, -1, -1, -1}, {21316, -1, -1, -1}, {20173, -1, -1, -1}, {21097, -1, -1, -1}, {23381, -1, -1, -1}, {33471, -1, -1, -1}, {20180, -1, -1, -1}, {21050, 63999, -1, -1}, {21672, -1, -1, -1}, {22985, -1, -1, -1}, {23039, -1, -1, -1}, {23376, -1, -1, -1}, {23383, -1, -1, -1}, {23388, -1, -1, -1}, {24675, -1, -1, -1}, {24904, -1, -1, -1}, {28363, -1, -1, -1}, {28825, 63995, -1, -1}, {29038, -1, -1, -1}, {29574, -1, -1, -1}, {29943, -1, -1, -1}, {30133, -1, -1, -1}, {30913, -1, -1, -1}, {32043, -1, -1, -1}, {32773, -1, -1, -1}, {33258, -1, -1, -1}, {33576, -1, -1, -1}, {34071, -1, -1, -1}, {34249, -1, -1, -1}, {35566, -1, -1, -1}, {36039, -1, -1, -1}, {38604, -1, -1, -1}, {20316, -1, -1, -1}, {21242, -1, -1, -1}, {22204, -1, -1, -1}, {26027, -1, -1, -1}, {26152, -1, -1, -1}, {28796, -1, -1, -1}, {28856, -1, -1, -1}, {29237, -1, -1, -1}, {32189, -1, -1, -1}, {33421, -1, -1, -1}, {37196, -1, -1, -1}, {38592, -1, -1, -1}, {40306, -1, -1, -1}, {23409, -1, -1, -1}, {26855, -1, -1, -1}, {27544, -1, -1, -1}, {28538, -1, -1, -1}, {30430, -1, -1, -1}, {23697, -1, -1, -1}, {26283, -1, -1, -1}, {28507, -1, -1, -1}, {31668, -1, -1, -1}, {31786, -1, -1, -1}, {34870, -1, -1, -1}, {38620, -1, -1, -1}, {19976, -1, -1, -1}, {20183, -1, -1, -1}, {21280, -1, -1, -1}, {22580, -1, -1, -1}, {22715, -1, -1, -1}, {22767, -1, -1, -1}, {22892, -1, -1, -1}, {23559, -1, -1, -1}, {24115, -1, -1, -1}, {24196, -1, -1, -1}, {24373, -1, -1, -1}, {25484, -1, -1, -1}, {26290, -1, -1, -1}, {26454, -1, -1, -1}, {27167, -1, -1, -1}, {27299, -1, -1, -1}, {27404, -1, -1, -1}, {28479, -1, -1, -1}, {29254, -1, -1, -1}, {29520, -1, -1, -1}, {29835, -1, -1, -1}, {31456, -1, -1, -1}, {31911, -1, -1, -1}, {33144, -1, -1, -1}, {33247, -1, -1, -1}, {33255, -1, -1, -1}, {33674, -1, -1, -1}, {33900, -1, -1, -1}, {34083, -1, -1, -1}, {34196, -1, -1, -1}, {34255, -1, -1, -1}, {35037, -1, -1, -1}, {36115, -1, -1, -1}, {37292, -1, -1, -1}, {38263, -1, -1, -1}, {38556, -1, -1, -1}, {20877, -1, -1, -1}, {21705, -1, -1, -1}, {22312, -1, -1, -1}, {23472, -1, -1, -1}, {25165, -1, -1, -1}, {26448, -1, -1, -1}, {26685, -1, -1, -1}, {26771, -1, -1, -1}, {28221, -1, -1, -1}, {28371, -1, -1, -1}, {28797, -1, -1, -1}, {32289, -1, -1, -1}, {35009, -1, -1, -1}, {36001, -1, -1, -1}, {36617, -1, -1, -1}, {40779, -1, -1, -1}, {40782, -1, -1, -1}, {29229, -1, -1, -1}, {31631, -1, -1, -1}, {35533, -1, -1, -1}, {37658, -1, -1, -1}, {20295, -1, -1, -1}, {20302, -1, -1, -1}, {20786, -1, -1, -1}, {21632, -1, -1, -1}, {22992, -1, -1, -1}, {24213, -1, -1, -1}, {25269, -1, -1, -1}, {26485, -1, -1, -1}, {26990, -1, -1, -1}, {27159, -1, -1, -1}, {27822, -1, -1, -1}, {28186, -1, -1, -1}, {29401, -1, -1, -1}, {29482, -1, -1, -1}, {30141, -1, -1, -1}, {31672, -1, -1, -1}, {32053, -1, -1, -1}, {33511, -1, -1, -1}, {33785, -1, -1, -1}, {33879, -1, -1, -1}, {34295, -1, -1, -1}, {35419, -1, -1, -1}, {36015, -1, -1, -1}, {36487, -1, -1, -1}, {36889, -1, -1, -1}, {37048, -1, -1, -1}, {38606, -1, -1, -1}, {40799, -1, -1, -1}, {21219, -1, -1, -1}, {21514, -1, -1, -1}, {23265, -1, -1, -1}, {23490, -1, -1, -1}, {25688, -1, -1, -1}, {25973, -1, -1, -1}, {28404, -1, -1, -1}, {29380, -1, -1, -1}, {30340, -1, -1, -1}, {31309, -1, -1, -1}, {31515, -1, -1, -1}, {31821, -1, -1, -1}, {32318, -1, -1, -1}, {32735, -1, -1, -1}, {33659, -1, -1, -1}, {35627, -1, -1, -1}, {36042, -1, -1, -1}, {36196, -1, -1, -1}, {36321, -1, -1, -1}, {36447, -1, -1, -1}, {36842, -1, -1, -1}, {36857, -1, -1, -1}, {36969, -1, -1, -1}, {37841, -1, -1, -1}, {20291, -1, -1, -1}, {20346, -1, -1, -1}, {20659, -1, -1, -1}, {20840, -1, -1, -1}, {20856, -1, -1, -1}, {21069, -1, -1, -1}, {21098, -1, -1, -1}, {22625, -1, -1, -1}, {22652, -1, -1, -1}, {22880, -1, -1, -1}, {23560, -1, -1, -1}, {23637, -1, -1, -1}, {24283, -1, -1, -1} },
+ {{24731, -1, -1, -1}, {25136, -1, -1, -1}, {26643, -1, -1, -1}, {27583, -1, -1, -1}, {27656, -1, -1, -1}, {28593, -1, -1, -1}, {29006, -1, -1, -1}, {29728, -1, -1, -1}, {30000, -1, -1, -1}, {30008, -1, -1, -1}, {30033, -1, -1, -1}, {30322, -1, -1, -1}, {31564, -1, -1, -1}, {31627, -1, -1, -1}, {31661, -1, -1, -1}, {31686, -1, -1, -1}, {32399, -1, -1, -1}, {35438, -1, -1, -1}, {36670, -1, -1, -1}, {36681, -1, -1, -1}, {37439, -1, -1, -1}, {37523, -1, -1, -1}, {37666, -1, -1, -1}, {37931, -1, -1, -1}, {38651, -1, -1, -1}, {39002, -1, -1, -1}, {39019, -1, -1, -1}, {39198, -1, -1, -1}, {20999, 64000, -1, -1}, {25130, -1, -1, -1}, {25240, -1, -1, -1}, {27993, -1, -1, -1}, {30308, -1, -1, -1}, {31434, -1, -1, -1}, {31680, -1, -1, -1}, {32118, -1, -1, -1}, {21344, -1, -1, -1}, {23742, -1, -1, -1}, {24215, -1, -1, -1}, {28472, -1, -1, -1}, {28857, -1, -1, -1}, {31896, -1, -1, -1}, {38673, -1, -1, -1}, {39822, -1, -1, -1}, {40670, -1, -1, -1}, {25509, -1, -1, -1}, {25722, -1, -1, -1}, {34678, -1, -1, -1}, {19969, -1, -1, -1}, {20117, -1, -1, -1}, {20141, -1, -1, -1}, {20572, -1, -1, -1}, {20597, -1, -1, -1}, {21576, -1, -1, -1}, {22979, -1, -1, -1}, {23450, -1, -1, -1}, {24128, -1, -1, -1}, {24237, -1, -1, -1}, {24311, -1, -1, -1}, {24449, -1, -1, -1}, {24773, -1, -1, -1}, {25402, -1, -1, -1}, {25919, -1, -1, -1}, {25972, -1, -1, -1}, {26060, -1, -1, -1}, {26230, -1, -1, -1}, {26232, -1, -1, -1}, {26622, -1, -1, -1}, {26984, -1, -1, -1}, {27273, -1, -1, -1}, {27491, -1, -1, -1}, {27712, -1, -1, -1}, {28096, -1, -1, -1}, {28136, -1, -1, -1}, {28191, -1, -1, -1}, {28254, -1, -1, -1}, {28702, -1, -1, -1}, {28833, -1, -1, -1}, {29582, -1, -1, -1}, {29693, -1, -1, -1}, {30010, -1, -1, -1}, {30555, -1, -1, -1}, {30855, -1, -1, -1}, {31118, -1, -1, -1}, {31243, -1, -1, -1}, {31357, -1, -1, -1}, {31934, -1, -1, -1}, {32142, -1, -1, -1}, {33351, -1, -1, -1}, {35330, -1, -1, -1}, {35562, -1, -1, -1}, {35998, -1, -1, -1}, {37165, -1, -1, -1}, {37194, -1, -1, -1}, {37336, -1, -1, -1}, {37478, -1, -1, -1}, {37580, -1, -1, -1}, {37664, -1, -1, -1}, {38662, -1, -1, -1}, {38742, -1, -1, -1}, {38748, -1, -1, -1}, {38914, -1, -1, -1}, {40718, -1, -1, -1}, {21046, -1, -1, -1}, {21137, -1, -1, -1}, {21884, -1, -1, -1}, {22564, -1, -1, -1}, {24093, -1, -1, -1}, {24351, -1, -1, -1}, {24716, -1, -1, -1}, {25552, -1, -1, -1}, {26799, -1, -1, -1}, {28639, -1, -1, -1}, {31085, -1, -1, -1}, {31532, -1, -1, -1}, {33229, -1, -1, -1}, {34234, -1, -1, -1}, {35069, -1, -1, -1}, {35576, -1, -1, -1}, {36420, -1, -1, -1}, {37261, -1, -1, -1}, {38500, -1, -1, -1}, {38555, -1, -1, -1}, {38717, -1, -1, -1}, {38988, -1, -1, -1}, {40778, -1, -1, -1}, {20430, -1, -1, -1}, {20806, -1, -1, -1}, {20939, -1, -1, -1}, {21161, -1, -1, -1}, {22066, -1, -1, -1}, {24340, -1, -1, -1}, {24427, -1, -1, -1}, {25514, -1, -1, -1}, {25805, -1, -1, -1}, {26089, -1, -1, -1}, {26177, -1, -1, -1}, {26362, -1, -1, -1}, {26361, -1, -1, -1}, {26397, -1, -1, -1}, {26781, -1, -1, -1}, {26839, -1, -1, -1}, {27133, -1, -1, -1}, {28437, -1, -1, -1}, {28526, -1, -1, -1}, {29031, -1, -1, -1}, {29157, -1, -1, -1}, {29226, -1, -1, -1}, {29866, -1, -1, -1}, {30522, -1, -1, -1}, {31062, -1, -1, -1}, {31066, -1, -1, -1}, {31199, -1, -1, -1}, {31264, -1, -1, -1}, {31381, -1, -1, -1}, {31895, -1, -1, -1}, {31967, -1, -1, -1}, {32068, -1, -1, -1}, {32368, -1, -1, -1}, {32903, -1, -1, -1}, {34299, -1, -1, -1}, {34468, -1, -1, -1}, {35412, -1, -1, -1}, {35519, -1, -1, -1}, {36249, -1, -1, -1}, {36481, -1, -1, -1}, {36896, -1, -1, -1}, {36973, -1, -1, -1}, {37347, -1, -1, -1}, {38459, -1, -1, -1}, {38613, -1, -1, -1}, {40165, -1, -1, -1}, {26063, -1, -1, -1}, {31751, -1, -1, -1}, {36275, -1, -1, -1}, {37827, -1, -1, -1}, {23384, -1, -1, -1}, {23562, -1, -1, -1}, {21330, -1, -1, -1}, {25305, -1, -1, -1}, {29469, -1, -1, -1}, {20519, -1, -1, -1}, {23447, -1, -1, -1}, {24478, -1, -1, -1}, {24752, -1, -1, -1}, {24939, -1, -1, -1}, {26837, -1, -1, -1}, {28121, -1, -1, -1}, {29742, -1, -1, -1}, {31278, -1, -1, -1}, {32066, -1, -1, -1}, {32156, -1, -1, -1}, {32305, -1, -1, -1}, {33131, -1, -1, -1}, {36394, -1, -1, -1}, {36405, -1, -1, -1}, {37758, -1, -1, -1}, {37912, -1, -1, -1}, {20304, -1, -1, -1}, {22352, -1, -1, -1}, {24038, -1, -1, -1}, {24231, -1, -1, -1}, {25387, -1, -1, -1}, {32618, -1, -1, -1}, {20027, -1, -1, -1}, {20303, -1, -1, -1}, {20367, -1, -1, -1}, {20570, -1, -1, -1}, {23005, -1, -1, -1}, {32964, -1, -1, -1}, {21610, -1, -1, -1}, {21608, -1, -1, -1}, {22014, -1, -1, -1}, {22863, -1, -1, -1}, {23449, -1, -1, -1}, {24030, -1, -1, -1}, {24282, -1, -1, -1}, {26205, -1, -1, -1}, {26417, -1, -1, -1}, {26609, -1, -1, -1}, {26666, -1, -1, -1}, {27880, -1, -1, -1}, {27954, -1, -1, -1}, {28234, -1, -1, -1}, {28557, -1, -1, -1}, {28855, -1, -1, -1}, {29664, -1, -1, -1}, {30087, -1, -1, -1}, {31820, -1, -1, -1}, {32002, -1, -1, -1}, {32044, -1, -1, -1}, {32162, -1, -1, -1}, {33311, -1, -1, -1}, {34523, -1, -1, -1}, {35387, -1, -1, -1}, {35461, -1, -1, -1}, {36208, -1, -1, -1}, {36490, -1, -1, -1}, {36659, -1, -1, -1}, {36913, -1, -1, -1}, {37198, -1, -1, -1}, {37202, -1, -1, -1}, {37956, -1, -1, -1}, {39376, -1, -1, -1}, {31481, -1, -1, -1}, {31909, -1, -1, -1}, {20426, -1, -1, -1}, {20737, -1, -1, -1}, {20934, -1, -1, -1}, {22472, -1, -1, -1}, {23535, -1, -1, -1}, {23803, -1, -1, -1}, {26201, -1, -1, -1}, {27197, -1, -1, -1}, {27994, -1, -1, -1}, {28310, -1, -1, -1} },
+ {{28652, -1, -1, -1}, {28940, -1, -1, -1}, {30063, -1, -1, -1}, {31459, -1, -1, -1}, {34850, -1, -1, -1}, {36897, -1, -1, -1}, {36981, -1, -1, -1}, {38603, -1, -1, -1}, {39423, -1, -1, -1}, {33537, -1, -1, -1}, {20013, -1, -1, -1}, {20210, -1, -1, -1}, {34886, -1, -1, -1}, {37325, -1, -1, -1}, {21373, -1, -1, -1}, {27355, -1, -1, -1}, {26987, -1, -1, -1}, {27713, -1, -1, -1}, {33914, -1, -1, -1}, {22686, -1, -1, -1}, {24974, -1, -1, -1}, {26366, -1, -1, -1}, {25327, -1, -1, -1}, {28893, -1, -1, -1}, {29969, -1, -1, -1}, {30151, -1, -1, -1}, {32338, -1, -1, -1}, {33976, -1, -1, -1}, {35657, -1, -1, -1}, {36104, -1, -1, -1}, {20043, -1, -1, -1}, {21482, -1, -1, -1}, {21675, -1, -1, -1}, {22320, -1, -1, -1}, {22336, -1, -1, -1}, {24535, -1, -1, -1}, {25345, -1, -1, -1}, {25351, -1, -1, -1}, {25711, -1, -1, -1}, {25903, -1, -1, -1}, {26088, -1, -1, -1}, {26234, -1, -1, -1}, {26525, -1, -1, -1}, {26547, -1, -1, -1}, {27490, -1, -1, -1}, {27744, -1, -1, -1}, {27802, -1, -1, -1}, {28460, -1, -1, -1}, {30693, -1, -1, -1}, {30757, -1, -1, -1}, {31049, -1, -1, -1}, {31063, -1, -1, -1}, {32025, -1, -1, -1}, {32930, -1, -1, -1}, {33026, -1, -1, -1}, {33267, -1, -1, -1}, {33437, -1, -1, -1}, {33463, -1, -1, -1}, {34584, -1, -1, -1}, {35468, -1, -1, -1}, {36100, -1, -1, -1}, {36286, -1, -1, -1}, {36978, -1, -1, -1}, {30452, -1, -1, -1}, {31257, -1, -1, -1}, {31287, -1, -1, -1}, {32340, -1, -1, -1}, {32887, -1, -1, -1}, {21767, -1, -1, -1}, {21972, -1, -1, -1}, {22645, -1, -1, -1}, {25391, -1, -1, -1}, {25634, -1, -1, -1}, {26185, -1, -1, -1}, {26187, -1, -1, -1}, {26733, -1, -1, -1}, {27035, -1, -1, -1}, {27524, -1, -1, -1}, {27941, -1, -1, -1}, {28337, -1, -1, -1}, {29645, -1, -1, -1}, {29800, -1, -1, -1}, {29857, -1, -1, -1}, {30043, -1, -1, -1}, {30137, -1, -1, -1}, {30433, -1, -1, -1}, {30494, -1, -1, -1}, {30603, -1, -1, -1}, {31206, -1, -1, -1}, {32265, -1, -1, -1}, {32285, -1, -1, -1}, {33275, -1, -1, -1}, {34095, -1, -1, -1}, {34967, -1, -1, -1}, {35386, -1, -1, -1}, {36049, -1, -1, -1}, {36587, -1, -1, -1}, {36784, 63857, -1, -1}, {36914, -1, -1, -1}, {37805, -1, -1, -1}, {38499, -1, -1, -1}, {38515, -1, -1, -1}, {38663, -1, -1, -1}, {20356, -1, -1, -1}, {21489, -1, -1, -1}, {23018, -1, -1, -1}, {23241, -1, -1, -1}, {24089, -1, -1, -1}, {26702, -1, -1, -1}, {29894, -1, -1, -1}, {30142, -1, -1, -1}, {31209, -1, -1, -1}, {31378, -1, -1, -1}, {33187, -1, -1, -1}, {34541, -1, -1, -1}, {36074, -1, -1, -1}, {36300, -1, -1, -1}, {36845, -1, -1, -1}, {26015, -1, -1, -1}, {26389, -1, -1, -1}, {22519, -1, -1, -1}, {28503, -1, -1, -1}, {32221, -1, -1, -1}, {36655, -1, -1, -1}, {37878, -1, -1, -1}, {38598, -1, -1, -1}, {24501, -1, -1, -1}, {25074, -1, -1, -1}, {28548, -1, -1, -1}, {19988, -1, -1, -1}, {20376, -1, -1, -1}, {20511, -1, -1, -1}, {21449, -1, -1, -1}, {21983, -1, -1, -1}, {23919, -1, -1, -1}, {24046, -1, -1, -1}, {27425, -1, -1, -1}, {27492, -1, -1, -1}, {30923, -1, -1, -1}, {31642, -1, -1, -1}, {36425, -1, -1, -1}, {36554, 63746, -1, -1}, {36974, -1, -1, -1}, {25417, -1, -1, -1}, {25662, -1, -1, -1}, {30528, -1, -1, -1}, {31364, -1, -1, -1}, {37679, -1, -1, -1}, {38015, -1, -1, -1}, {40810, -1, -1, -1}, {25776, -1, -1, -1}, {28591, -1, -1, -1}, {29158, -1, -1, -1}, {29864, -1, -1, -1}, {29914, -1, -1, -1}, {31428, -1, -1, -1}, {31762, -1, -1, -1}, {32386, -1, -1, -1}, {31922, -1, -1, -1}, {32408, -1, -1, -1}, {35738, -1, -1, -1}, {36106, -1, -1, -1}, {38013, -1, -1, -1}, {39184, -1, -1, -1}, {39244, -1, -1, -1}, {21049, -1, -1, -1}, {23519, -1, -1, -1}, {25830, -1, -1, -1}, {26413, -1, -1, -1}, {32046, -1, -1, -1}, {20717, -1, -1, -1}, {21443, 63851, -1, -1}, {22649, -1, -1, -1}, {24920, -1, -1, -1}, {24921, -1, -1, -1}, {25082, -1, -1, -1}, {26028, -1, -1, -1}, {31449, -1, -1, -1}, {35730, -1, -1, -1}, {35734, -1, -1, -1}, {20489, -1, -1, -1}, {20513, -1, -1, -1}, {21109, -1, -1, -1}, {21809, -1, -1, -1}, {23100, -1, -1, -1}, {24288, -1, -1, -1}, {24432, -1, -1, -1}, {24884, -1, -1, -1}, {25950, -1, -1, -1}, {26124, -1, -1, -1}, {26166, -1, -1, -1}, {26274, -1, -1, -1}, {27085, -1, -1, -1}, {28356, -1, -1, -1}, {28466, -1, -1, -1}, {29462, -1, -1, -1}, {30241, -1, -1, -1}, {31379, -1, -1, -1}, {33081, -1, -1, -1}, {33369, -1, -1, -1}, {33750, -1, -1, -1}, {33980, -1, -1, -1}, {20661, -1, -1, -1}, {22512, -1, -1, -1}, {23488, -1, -1, -1}, {23528, -1, -1, -1}, {24425, -1, -1, -1}, {25505, -1, -1, -1}, {30758, -1, -1, -1}, {32181, -1, -1, -1}, {33756, -1, -1, -1}, {34081, -1, -1, -1}, {37319, -1, -1, -1}, {37365, -1, -1, -1}, {20874, -1, -1, -1}, {26613, -1, -1, -1}, {31574, -1, -1, -1}, {36012, -1, -1, -1}, {20932, -1, -1, -1}, {22971, -1, -1, -1}, {24765, -1, -1, -1}, {34389, -1, -1, -1}, {20508, -1, -1, -1}, {21076, -1, -1, -1}, {23610, -1, -1, -1}, {24957, -1, -1, -1}, {25114, -1, -1, -1}, {25299, 64002, -1, -1}, {25842, -1, -1, -1}, {26021, -1, -1, -1}, {28364, -1, -1, -1}, {30240, -1, -1, -1}, {33034, -1, -1, -1}, {36448, -1, -1, -1}, {38495, -1, -1, -1}, {38587, -1, -1, -1}, {20191, -1, -1, -1}, {21315, -1, -1, -1}, {21912, -1, -1, -1}, {22825, -1, -1, -1}, {24029, -1, -1, -1}, {25797, -1, -1, -1}, {27849, -1, -1, -1}, {28154, -1, -1, -1}, {29588, -1, -1, -1}, {31359, -1, -1, -1}, {33307, -1, -1, -1}, {34214, -1, -1, -1}, {36068, -1, -1, -1}, {36368, -1, -1, -1}, {36983, -1, -1, -1}, {37351, -1, -1, -1}, {38369, -1, -1, -1}, {38433, -1, -1, -1}, {38854, -1, -1, -1}, {20984, -1, -1, -1} },
+ {{21746, -1, -1, -1}, {21894, -1, -1, -1}, {24505, -1, -1, -1}, {25764, -1, -1, -1}, {28552, -1, -1, -1}, {32180, -1, -1, -1}, {36639, -1, -1, -1}, {36685, -1, -1, -1}, {37941, -1, -1, -1}, {20681, -1, -1, -1}, {23574, -1, -1, -1}, {27838, -1, -1, -1}, {28155, -1, -1, -1}, {29979, -1, -1, -1}, {30651, -1, -1, -1}, {31805, -1, -1, -1}, {31844, -1, -1, -1}, {35449, -1, -1, -1}, {35522, -1, -1, -1}, {22558, -1, -1, -1}, {22974, -1, -1, -1}, {24086, -1, -1, -1}, {25463, -1, -1, -1}, {29266, -1, -1, -1}, {30090, -1, -1, -1}, {30571, -1, -1, -1}, {35548, -1, -1, -1}, {36028, -1, -1, -1}, {36626, -1, -1, -1}, {24307, -1, -1, -1}, {26228, -1, -1, -1}, {28152, -1, -1, -1}, {32893, -1, -1, -1}, {33729, -1, -1, -1}, {35531, -1, -1, -1}, {38737, -1, -1, -1}, {39894, -1, -1, -1}, {21059, -1, -1, -1}, {26367, -1, -1, -1}, {28053, -1, -1, -1}, {28399, -1, -1, -1}, {32224, -1, -1, -1}, {35558, -1, -1, -1}, {36910, -1, -1, -1}, {36958, -1, -1, -1}, {39636, -1, -1, -1}, {21021, -1, -1, -1}, {21119, -1, -1, -1}, {21736, -1, -1, -1}, {24980, -1, -1, -1}, {25220, -1, -1, -1}, {25307, -1, -1, -1}, {26786, -1, -1, -1}, {26898, -1, -1, -1}, {26970, -1, -1, -1}, {27189, -1, -1, -1}, {28818, -1, -1, -1}, {28966, -1, -1, -1}, {30813, -1, -1, -1}, {30977, -1, -1, -1}, {30990, -1, -1, -1}, {31186, -1, -1, -1}, {31245, -1, -1, -1}, {32918, -1, -1, -1}, {33400, -1, -1, -1}, {33493, -1, -1, -1}, {33609, -1, -1, -1}, {34121, -1, -1, -1}, {35970, -1, -1, -1}, {36229, -1, -1, -1}, {37218, -1, -1, -1}, {37259, -1, -1, -1}, {37294, -1, -1, -1}, {20419, -1, -1, -1}, {22225, -1, -1, -1}, {29165, -1, -1, -1}, {30679, -1, -1, -1}, {34560, -1, -1, -1}, {35320, -1, -1, -1}, {23544, -1, -1, -1}, {24534, -1, -1, -1}, {26449, -1, -1, -1}, {37032, -1, -1, -1}, {21474, -1, -1, -1}, {22618, -1, -1, -1}, {23541, -1, -1, -1}, {24740, -1, -1, -1}, {24961, -1, -1, -1}, {25696, -1, -1, -1}, {32317, -1, -1, -1}, {32880, -1, -1, -1}, {34085, -1, -1, -1}, {37507, -1, -1, -1}, {25774, -1, -1, -1}, {20652, -1, -1, -1}, {23828, -1, -1, -1}, {26368, -1, -1, -1}, {22684, -1, -1, -1}, {25277, -1, -1, -1}, {25512, -1, -1, -1}, {26894, -1, -1, -1}, {27000, -1, -1, -1}, {27166, -1, -1, -1}, {28267, -1, -1, -1}, {30394, -1, -1, -1}, {31179, -1, -1, -1}, {33467, -1, -1, -1}, {33833, -1, -1, -1}, {35535, -1, -1, -1}, {36264, -1, -1, -1}, {36861, -1, -1, -1}, {37138, -1, -1, -1}, {37195, -1, -1, -1}, {37276, -1, -1, -1}, {37648, -1, -1, -1}, {37656, -1, -1, -1}, {37786, -1, -1, -1}, {38619, -1, -1, -1}, {39478, -1, -1, -1}, {39949, -1, -1, -1}, {19985, -1, -1, -1}, {30044, -1, -1, -1}, {31069, -1, -1, -1}, {31482, -1, -1, -1}, {31569, -1, -1, -1}, {31689, -1, -1, -1}, {32302, -1, -1, -1}, {33988, -1, -1, -1}, {36441, -1, -1, -1}, {36468, -1, -1, -1}, {36600, -1, -1, -1}, {36880, -1, -1, -1}, {26149, -1, -1, -1}, {26943, -1, -1, -1}, {29763, -1, -1, -1}, {20986, -1, -1, -1}, {26414, -1, -1, -1}, {40668, -1, -1, -1}, {20805, -1, -1, -1}, {24544, -1, -1, -1}, {27798, -1, -1, -1}, {34802, -1, -1, -1}, {34909, -1, -1, -1}, {34935, -1, -1, -1}, {24756, -1, -1, -1}, {33205, -1, -1, -1}, {33795, -1, -1, -1}, {36101, -1, -1, -1}, {21462, -1, -1, -1}, {21561, -1, -1, -1}, {22068, -1, -1, -1}, {23094, -1, -1, -1}, {23601, -1, -1, -1}, {28810, -1, -1, -1}, {32736, -1, -1, -1}, {32858, -1, -1, -1}, {33030, -1, -1, -1}, {33261, -1, -1, -1}, {36259, -1, -1, -1}, {37257, -1, -1, -1}, {39519, -1, -1, -1}, {40434, -1, -1, -1}, {20596, -1, -1, -1}, {20164, -1, -1, -1}, {21408, -1, -1, -1}, {24827, -1, -1, -1}, {28204, -1, -1, -1}, {23652, -1, -1, -1}, {20360, -1, -1, -1}, {20516, -1, -1, -1}, {21988, -1, -1, -1}, {23769, -1, -1, -1}, {24159, -1, -1, -1}, {24677, -1, -1, -1}, {26772, -1, -1, -1}, {27835, -1, -1, -1}, {28100, -1, -1, -1}, {29118, -1, -1, -1}, {30164, -1, -1, -1}, {30196, -1, -1, -1}, {30305, -1, -1, -1}, {31258, -1, -1, -1}, {31305, -1, -1, -1}, {32199, -1, -1, -1}, {32251, -1, -1, -1}, {32622, -1, -1, -1}, {33268, -1, -1, -1}, {34473, -1, -1, -1}, {36636, -1, -1, -1}, {38601, -1, -1, -1}, {39347, -1, -1, -1}, {40786, -1, -1, -1}, {21063, -1, -1, -1}, {21189, -1, -1, -1}, {39149, -1, -1, -1}, {35242, -1, -1, -1}, {19971, -1, -1, -1}, {26578, -1, -1, -1}, {28422, -1, -1, -1}, {20405, -1, -1, -1}, {23522, -1, -1, -1}, {26517, -1, -1, -1}, {27784, 63858, -1, -1}, {28024, -1, -1, -1}, {29723, -1, -1, -1}, {30759, -1, -1, -1}, {37341, -1, -1, -1}, {37756, -1, -1, -1}, {34756, -1, -1, -1}, {31204, -1, -1, -1}, {31281, -1, -1, -1}, {24555, -1, -1, -1}, {20182, -1, -1, -1}, {21668, -1, -1, -1}, {21822, -1, -1, -1}, {22702, -1, -1, -1}, {22949, -1, -1, -1}, {24816, -1, -1, -1}, {25171, -1, -1, -1}, {25302, -1, -1, -1}, {26422, -1, -1, -1}, {26965, -1, -1, -1}, {33333, -1, -1, -1}, {38464, -1, -1, -1}, {39345, -1, -1, -1}, {39389, -1, -1, -1}, {20524, -1, -1, -1}, {21331, -1, -1, -1}, {21828, -1, -1, -1}, {22396, -1, -1, -1}, {25176, -1, -1, -1}, {25826, -1, -1, -1}, {26219, -1, -1, -1}, {26589, -1, -1, -1}, {28609, -1, -1, -1}, {28655, -1, -1, -1}, {29730, -1, -1, -1}, {29752, -1, -1, -1}, {35351, -1, -1, -1}, {37944, -1, -1, -1}, {21585, -1, -1, -1}, {22022, -1, -1, -1}, {22374, -1, -1, -1}, {24392, -1, -1, -1}, {24986, -1, -1, -1}, {27470, -1, -1, -1}, {28760, -1, -1, -1}, {28845, -1, -1, -1}, {32187, -1, -1, -1}, {35477, -1, -1, -1}, {22890, -1, -1, -1}, {33067, -1, -1, -1}, {25506, -1, -1, -1}, {30472, -1, -1, -1}, {32829, -1, -1, -1}, {36010, -1, -1, -1} },
+ {{22612, -1, -1, -1}, {25645, -1, -1, -1}, {27067, -1, -1, -1}, {23445, -1, -1, -1}, {24081, -1, -1, -1}, {28271, -1, -1, -1}, {34153, -1, -1, -1}, {20812, -1, -1, -1}, {21488, -1, -1, -1}, {22826, -1, -1, -1}, {24608, -1, -1, -1}, {24907, -1, -1, -1}, {27526, -1, -1, -1}, {27760, -1, -1, -1}, {27888, -1, -1, -1}, {31518, -1, -1, -1}, {32974, -1, -1, -1}, {33492, -1, -1, -1}, {36294, -1, -1, -1}, {37040, -1, -1, -1}, {39089, -1, -1, -1}, {25799, -1, -1, -1}, {28580, -1, -1, -1}, {25745, -1, -1, -1}, {25860, -1, -1, -1}, {20814, -1, -1, -1}, {21520, -1, -1, -1}, {22303, -1, -1, -1}, {35342, -1, -1, -1}, {24927, -1, -1, -1}, {26742, -1, -1, -1}, {30171, -1, -1, -1}, {31570, -1, -1, -1}, {32113, -1, -1, -1}, {36890, -1, -1, -1}, {22534, -1, -1, -1}, {27084, -1, -1, -1}, {33151, -1, -1, -1}, {35114, -1, -1, -1}, {36864, -1, -1, -1}, {38969, -1, -1, -1}, {20600, -1, -1, -1}, {22871, -1, -1, -1}, {22956, -1, -1, -1}, {25237, -1, -1, -1}, {36879, -1, -1, -1}, {39722, -1, -1, -1}, {24925, -1, -1, -1}, {29305, -1, -1, -1}, {38358, -1, -1, -1}, {22369, -1, -1, -1}, {23110, -1, -1, -1}, {24052, -1, -1, -1}, {25226, -1, -1, -1}, {25773, -1, -1, -1}, {25850, -1, -1, -1}, {26487, -1, -1, -1}, {27874, -1, -1, -1}, {27966, -1, -1, -1}, {29228, -1, -1, -1}, {29750, -1, -1, -1}, {30772, -1, -1, -1}, {32631, -1, -1, -1}, {33453, -1, -1, -1}, {36315, -1, -1, -1}, {38935, -1, -1, -1}, {21028, -1, -1, -1}, {22338, -1, -1, -1}, {26495, -1, -1, -1}, {29256, -1, -1, -1}, {29923, -1, -1, -1}, {36009, -1, -1, -1}, {36774, -1, -1, -1}, {37393, -1, -1, -1}, {38442, -1, -1, -1}, {20843, -1, -1, -1}, {21485, -1, -1, -1}, {25420, -1, -1, -1}, {20329, -1, -1, -1}, {21764, -1, -1, -1}, {24726, -1, -1, -1}, {25943, -1, -1, -1}, {27803, -1, -1, -1}, {28031, -1, -1, -1}, {29260, -1, -1, -1}, {29437, -1, -1, -1}, {31255, -1, -1, -1}, {35207, -1, -1, -1}, {35997, -1, -1, -1}, {24429, -1, -1, -1}, {28558, -1, -1, -1}, {28921, -1, -1, -1}, {33192, -1, -1, -1}, {24846, -1, -1, -1}, {20415, 63845, -1, -1}, {20559, -1, -1, -1}, {25153, -1, -1, -1}, {29255, -1, -1, -1}, {31687, -1, -1, -1}, {32232, -1, -1, -1}, {32745, -1, -1, -1}, {36941, -1, -1, -1}, {38829, -1, -1, -1}, {39449, -1, -1, -1}, {36022, -1, -1, -1}, {22378, -1, -1, -1}, {24179, -1, -1, -1}, {26544, -1, -1, -1}, {33805, -1, -1, -1}, {35413, -1, -1, -1}, {21536, -1, -1, -1}, {23318, -1, -1, -1}, {24163, -1, -1, -1}, {24290, -1, -1, -1}, {24330, -1, -1, -1}, {25987, -1, -1, -1}, {32954, -1, -1, -1}, {34109, -1, -1, -1}, {38281, -1, -1, -1}, {38491, -1, -1, -1}, {20296, -1, -1, -1}, {21253, -1, -1, -1}, {21261, -1, -1, -1}, {21263, -1, -1, -1}, {21638, -1, -1, -1}, {21754, -1, -1, -1}, {22275, -1, -1, -1}, {24067, -1, -1, -1}, {24598, -1, -1, -1}, {25243, -1, -1, -1}, {25265, -1, -1, -1}, {25429, -1, -1, -1}, {27873, -1, -1, -1}, {28006, -1, -1, -1}, {30129, -1, -1, -1}, {30770, -1, -1, -1}, {32990, -1, -1, -1}, {33071, -1, -1, -1}, {33502, -1, -1, -1}, {33889, -1, -1, -1}, {33970, -1, -1, -1}, {34957, -1, -1, -1}, {35090, -1, -1, -1}, {36875, -1, -1, -1}, {37610, -1, -1, -1}, {39165, -1, -1, -1}, {39825, -1, -1, -1}, {24133, -1, -1, -1}, {26292, 64006, -1, -1}, {26333, -1, -1, -1}, {28689, -1, -1, -1}, {29190, -1, -1, -1}, {20469, -1, -1, -1}, {21117, -1, -1, -1}, {24426, -1, -1, -1}, {24915, -1, -1, -1}, {26451, -1, -1, -1}, {27161, -1, -1, -1}, {28418, -1, -1, -1}, {29922, -1, -1, -1}, {31080, -1, -1, -1}, {34920, -1, -1, -1}, {35961, -1, -1, -1}, {39111, -1, -1, -1}, {39108, -1, -1, -1}, {39491, -1, -1, -1}, {21697, -1, -1, -1}, {31263, -1, -1, -1}, {26963, -1, -1, -1}, {35575, -1, -1, -1}, {35914, -1, -1, -1}, {39080, -1, -1, -1}, {39342, -1, -1, -1}, {24444, -1, -1, -1}, {25259, -1, -1, -1}, {30130, -1, -1, -1}, {30382, -1, -1, -1}, {34987, -1, -1, -1}, {36991, -1, -1, -1}, {38466, -1, -1, -1}, {21305, -1, -1, -1}, {24380, -1, -1, -1}, {24517, -1, -1, -1}, {27852, 63848, -1, -1}, {29644, -1, -1, -1}, {30050, -1, -1, -1}, {30091, -1, -1, -1}, {31558, -1, -1, -1}, {33534, -1, -1, -1}, {39325, -1, -1, -1}, {20047, -1, -1, -1}, {36924, -1, -1, -1}, {19979, -1, -1, -1}, {20309, -1, -1, -1}, {21414, -1, -1, -1}, {22799, -1, -1, -1}, {24264, -1, -1, -1}, {26160, -1, -1, -1}, {27827, -1, -1, -1}, {29781, -1, -1, -1}, {33655, -1, -1, -1}, {34662, -1, -1, -1}, {36032, -1, -1, -1}, {36944, -1, -1, -1}, {38686, -1, -1, -1}, {39957, -1, -1, -1}, {22737, -1, -1, -1}, {23416, -1, -1, -1}, {34384, -1, -1, -1}, {35604, -1, -1, -1}, {40372, -1, -1, -1}, {23506, -1, -1, -1}, {24680, -1, -1, -1}, {24717, -1, -1, -1}, {26097, -1, -1, -1}, {27735, -1, -1, -1}, {28450, -1, -1, -1}, {28579, -1, -1, -1}, {28698, -1, -1, -1}, {32597, -1, -1, -1}, {32752, -1, -1, -1}, {38289, -1, -1, -1}, {38290, -1, -1, -1}, {38480, -1, -1, -1}, {38867, -1, -1, -1}, {21106, -1, -1, -1}, {36676, -1, -1, -1}, {20989, -1, -1, -1}, {21547, -1, -1, -1}, {21688, -1, -1, -1}, {21859, -1, -1, -1}, {21898, -1, -1, -1}, {27323, -1, -1, -1}, {28085, -1, -1, -1}, {32216, -1, -1, -1}, {33382, -1, -1, -1}, {37532, -1, -1, -1}, {38519, -1, -1, -1}, {40569, -1, -1, -1}, {21512, -1, -1, -1}, {21704, -1, -1, -1}, {30418, -1, -1, -1}, {34532, -1, -1, -1}, {38308, -1, -1, -1}, {38356, -1, -1, -1}, {38492, -1, -1, -1}, {20130, -1, -1, -1}, {20233, -1, -1, -1}, {23022, -1, -1, -1}, {23270, -1, -1, -1}, {24055, -1, -1, -1}, {24658, -1, -1, -1}, {25239, -1, -1, -1}, {26477, -1, -1, -1}, {26689, -1, -1, -1}, {27782, -1, -1, -1} },
+ {{28207, -1, -1, -1}, {32568, -1, -1, -1}, {32923, -1, -1, -1}, {33322, -1, -1, -1}, {38917, -1, -1, -1}, {20133, -1, -1, -1}, {20565, -1, -1, -1}, {21683, -1, -1, -1}, {22419, -1, -1, -1}, {22874, -1, -1, -1}, {23401, -1, -1, -1}, {23475, -1, -1, -1}, {25032, -1, -1, -1}, {26999, -1, -1, -1}, {28023, -1, -1, -1}, {28707, -1, -1, -1}, {34809, -1, -1, -1}, {35299, -1, -1, -1}, {35442, -1, -1, -1}, {35559, -1, -1, -1}, {36994, -1, -1, -1}, {39405, -1, -1, -1}, {39608, -1, -1, -1}, {21182, -1, -1, -1}, {26680, -1, -1, -1}, {20502, -1, -1, -1}, {24184, -1, -1, -1}, {26447, -1, -1, -1}, {33607, -1, -1, -1}, {34892, 64008, -1, -1}, {20139, -1, -1, -1}, {21521, -1, -1, -1}, {22190, -1, -1, -1}, {29670, -1, -1, -1}, {37141, -1, -1, -1}, {38911, -1, -1, -1}, {39177, -1, -1, -1}, {39255, -1, -1, -1}, {39321, -1, -1, -1}, {22099, -1, -1, -1}, {22687, -1, -1, -1}, {34395, -1, -1, -1}, {35377, -1, -1, -1}, {25010, -1, -1, -1}, {27382, -1, -1, -1}, {29563, -1, -1, -1}, {36562, -1, -1, -1}, {27463, -1, -1, -1}, {38570, -1, -1, -1}, {39511, -1, -1, -1}, {22869, -1, -1, -1}, {29184, -1, -1, -1}, {36203, -1, -1, -1}, {38761, -1, -1, -1}, {20436, -1, -1, -1}, {23796, -1, -1, -1}, {24358, -1, -1, -1}, {25080, -1, -1, -1}, {26203, -1, -1, -1}, {27883, -1, -1, -1}, {28843, -1, -1, -1}, {29572, -1, -1, -1}, {29625, -1, -1, -1}, {29694, -1, -1, -1}, {30505, -1, -1, -1}, {30541, -1, -1, -1}, {32067, -1, -1, -1}, {32098, -1, -1, -1}, {32291, -1, -1, -1}, {33335, -1, -1, -1}, {34898, -1, -1, -1}, {36066, -1, -1, -1}, {37449, -1, -1, -1}, {39023, -1, -1, -1}, {23377, -1, -1, -1}, {31348, -1, -1, -1}, {34880, -1, -1, -1}, {38913, -1, -1, -1}, {23244, -1, -1, -1}, {20448, -1, -1, -1}, {21332, -1, -1, -1}, {22846, -1, -1, -1}, {23805, -1, -1, -1}, {25406, -1, -1, -1}, {28025, -1, -1, -1}, {29433, -1, -1, -1}, {33029, -1, -1, -1}, {33031, -1, -1, -1}, {33698, -1, -1, -1}, {37583, -1, -1, -1}, {38960, -1, -1, -1}, {20136, -1, -1, -1}, {20804, -1, -1, -1}, {21009, -1, -1, -1}, {22411, -1, -1, -1}, {24418, -1, -1, -1}, {27842, -1, -1, -1}, {28366, -1, -1, -1}, {28677, -1, -1, -1}, {28752, -1, -1, -1}, {28847, -1, -1, -1}, {29074, -1, -1, -1}, {29673, -1, -1, -1}, {29801, 63918, -1, -1}, {33610, -1, -1, -1}, {34722, -1, -1, -1}, {34913, -1, -1, -1}, {36872, -1, -1, -1}, {37026, -1, -1, -1}, {37795, -1, -1, -1}, {39336, -1, -1, -1}, {20846, -1, -1, -1}, {24407, -1, -1, -1}, {24800, -1, -1, -1}, {24935, -1, -1, -1}, {26291, -1, -1, -1}, {34137, -1, -1, -1}, {36426, -1, -1, -1}, {37295, -1, -1, -1}, {38795, -1, -1, -1}, {20046, -1, -1, -1}, {20114, -1, -1, -1}, {21628, -1, -1, -1}, {22741, -1, -1, -1}, {22778, -1, -1, -1}, {22909, -1, -1, -1}, {23733, -1, -1, -1}, {24359, -1, -1, -1}, {25142, -1, -1, -1}, {25160, -1, -1, -1}, {26122, -1, -1, -1}, {26215, -1, -1, -1}, {27627, -1, -1, -1}, {28009, -1, -1, -1}, {28111, -1, -1, -1}, {28246, -1, -1, -1}, {28408, -1, -1, -1}, {28564, -1, -1, -1}, {28640, -1, -1, -1}, {28649, -1, -1, -1}, {28765, -1, -1, -1}, {29392, -1, -1, -1}, {29733, -1, -1, -1}, {29786, -1, -1, -1}, {29920, -1, -1, -1}, {30355, -1, -1, -1}, {31068, -1, -1, -1}, {31946, -1, -1, -1}, {32286, -1, -1, -1}, {32993, -1, -1, -1}, {33446, -1, -1, -1}, {33899, -1, -1, -1}, {33983, -1, -1, -1}, {34382, -1, -1, -1}, {34399, -1, -1, -1}, {34676, -1, -1, -1}, {35703, -1, -1, -1}, {35946, -1, -1, -1}, {37804, -1, -1, -1}, {38912, -1, -1, -1}, {39013, -1, -1, -1}, {24785, -1, -1, -1}, {25110, -1, -1, -1}, {37239, -1, -1, -1}, {23130, -1, -1, -1}, {26127, -1, -1, -1}, {28151, -1, -1, -1}, {28222, -1, -1, -1}, {29759, -1, -1, -1}, {39746, -1, -1, -1}, {24573, -1, -1, -1}, {24794, -1, -1, -1}, {31503, -1, -1, -1}, {21700, -1, -1, -1}, {24344, -1, -1, -1}, {27742, -1, -1, -1}, {27859, -1, -1, -1}, {27946, -1, -1, -1}, {28888, -1, -1, -1}, {32005, -1, -1, -1}, {34425, -1, -1, -1}, {35340, -1, -1, -1}, {40251, -1, -1, -1}, {21270, -1, -1, -1}, {21644, -1, -1, -1}, {23301, -1, -1, -1}, {27194, -1, -1, -1}, {28779, -1, -1, -1}, {30069, -1, -1, -1}, {31117, -1, -1, -1}, {31166, -1, -1, -1}, {33457, -1, -1, -1}, {33775, -1, -1, -1}, {35441, -1, -1, -1}, {35649, -1, -1, -1}, {36008, -1, -1, -1}, {38772, -1, -1, -1}, {25844, -1, -1, -1}, {25899, -1, -1, -1}, {30906, -1, -1, -1}, {30907, -1, -1, -1}, {31339, -1, -1, -1}, {20024, -1, -1, -1}, {21914, -1, -1, -1}, {22864, -1, -1, -1}, {23462, -1, -1, -1}, {24187, -1, -1, -1}, {24739, -1, -1, -1}, {25563, -1, -1, -1}, {27489, -1, -1, -1}, {26213, -1, -1, -1}, {26707, -1, -1, -1}, {28185, -1, -1, -1}, {29029, -1, -1, -1}, {29872, -1, -1, -1}, {32008, -1, -1, -1}, {36996, -1, -1, -1}, {39529, -1, -1, -1}, {39973, -1, -1, -1}, {27963, -1, -1, -1}, {28369, 63748, -1, -1}, {29502, -1, -1, -1}, {35905, -1, -1, -1}, {38346, -1, -1, -1}, {20976, -1, -1, -1}, {24140, -1, -1, -1}, {24488, -1, -1, -1}, {24653, -1, -1, -1}, {24822, -1, -1, -1}, {24880, -1, -1, -1}, {24908, -1, -1, -1}, {26179, -1, -1, -1}, {26180, -1, -1, -1}, {27045, -1, -1, -1}, {27841, -1, -1, -1}, {28255, -1, -1, -1}, {28361, -1, -1, -1}, {28514, -1, -1, -1}, {29004, -1, -1, -1}, {29852, -1, -1, -1}, {30343, -1, -1, -1}, {31681, -1, -1, -1}, {31783, -1, -1, -1}, {33618, -1, -1, -1}, {34647, -1, -1, -1}, {36945, -1, -1, -1}, {38541, -1, -1, -1}, {40643, -1, -1, -1}, {21295, -1, -1, -1}, {22238, -1, -1, -1}, {24315, -1, -1, -1}, {24458, -1, -1, -1}, {24674, -1, -1, -1}, {24724, -1, -1, -1}, {25079, -1, -1, -1}, {26214, -1, -1, -1} },
+ {{26371, -1, -1, -1}, {27292, -1, -1, -1}, {28142, -1, -1, -1}, {28590, -1, -1, -1}, {28784, -1, -1, -1}, {29546, -1, -1, -1}, {32362, -1, -1, -1}, {33214, -1, -1, -1}, {33588, -1, -1, -1}, {34516, -1, -1, -1}, {35496, -1, -1, -1}, {36036, -1, -1, -1}, {21123, -1, -1, -1}, {29554, -1, -1, -1}, {23446, -1, -1, -1}, {27243, -1, -1, -1}, {37892, -1, -1, -1}, {21742, -1, -1, -1}, {22150, -1, -1, -1}, {23389, -1, -1, -1}, {25928, -1, -1, -1}, {25989, -1, -1, -1}, {26313, -1, -1, -1}, {26783, -1, -1, -1}, {28045, -1, -1, -1}, {28102, -1, -1, -1}, {29243, -1, -1, -1}, {32948, -1, -1, -1}, {37237, -1, -1, -1}, {39501, -1, -1, -1}, {20399, -1, -1, -1}, {20505, -1, -1, -1}, {21402, -1, -1, -1}, {21518, -1, -1, -1}, {21564, -1, -1, -1}, {21897, -1, -1, -1}, {21957, -1, -1, -1}, {24127, -1, -1, -1}, {24460, -1, -1, -1}, {26429, -1, -1, -1}, {29030, -1, -1, -1}, {29661, -1, -1, -1}, {36869, -1, -1, -1}, {21211, -1, -1, -1}, {21235, -1, -1, -1}, {22628, -1, -1, -1}, {22734, -1, -1, -1}, {28932, -1, -1, -1}, {29071, -1, -1, -1}, {29179, -1, -1, -1}, {34224, -1, -1, -1}, {35347, -1, -1, -1}, {26248, 63941, -1, -1}, {34216, -1, -1, -1}, {21927, -1, -1, -1}, {26244, -1, -1, -1}, {29002, -1, -1, -1}, {33841, -1, -1, -1}, {21321, -1, -1, -1}, {21913, -1, -1, -1}, {27585, -1, -1, -1}, {24409, -1, -1, -1}, {24509, -1, -1, -1}, {25582, -1, -1, -1}, {26249, -1, -1, -1}, {28999, -1, -1, -1}, {35569, -1, -1, -1}, {36637, -1, -1, -1}, {40638, -1, -1, -1}, {20241, -1, -1, -1}, {25658, -1, -1, -1}, {28875, -1, -1, -1}, {30054, -1, -1, -1}, {34407, -1, -1, -1}, {24676, -1, -1, -1}, {35662, -1, -1, -1}, {40440, -1, -1, -1}, {20807, -1, -1, -1}, {20982, -1, -1, -1}, {21256, -1, -1, -1}, {27958, -1, -1, -1}, {33016, -1, -1, -1}, {40657, -1, -1, -1}, {26133, -1, -1, -1}, {27427, -1, -1, -1}, {28824, -1, -1, -1}, {30165, -1, -1, -1}, {21507, -1, -1, -1}, {23673, -1, -1, -1}, {32007, -1, -1, -1}, {35350, -1, -1, -1}, {27424, -1, -1, -1}, {27453, -1, -1, -1}, {27462, -1, -1, -1}, {21560, -1, -1, -1}, {24688, -1, -1, -1}, {27965, -1, -1, -1}, {32725, -1, -1, -1}, {33288, -1, -1, -1}, {20694, -1, -1, -1}, {20958, -1, -1, -1}, {21916, -1, -1, -1}, {22123, -1, -1, -1}, {22221, -1, -1, -1}, {23020, -1, -1, -1}, {23305, -1, -1, -1}, {24076, -1, -1, -1}, {24985, -1, -1, -1}, {24984, -1, -1, -1}, {25137, -1, -1, -1}, {26206, -1, -1, -1}, {26342, -1, -1, -1}, {29081, -1, -1, -1}, {29113, -1, -1, -1}, {29114, -1, -1, -1}, {29351, -1, -1, -1}, {31143, -1, -1, -1}, {31232, -1, -1, -1}, {32690, -1, -1, -1}, {35440, -1, -1, -1}, {12289, -1, -1, -1}, {12290, -1, -1, -1}, {8229, -1, -1, -1}, {8211, -1, -1, -1}, {8212, -1, -1, -1}, {8214, -1, -1, -1}, {65374, -1, -1, -1}, {12308, -1, -1, -1}, {12309, -1, -1, -1}, {12296, -1, -1, -1}, {12297, -1, -1, -1}, {12298, -1, -1, -1}, {12299, -1, -1, -1}, {12300, -1, -1, -1}, {12301, -1, -1, -1}, {12302, -1, -1, -1}, {12303, -1, -1, -1}, {12304, -1, -1, -1}, {12305, -1, -1, -1}, {12307, -1, -1, -1}, {65281, -1, -1, -1}, {65288, -1, -1, -1}, {65289, -1, -1, -1}, {65292, -1, -1, -1}, {65294, -1, -1, -1}, {65306, -1, -1, -1}, {65307, -1, -1, -1}, {65308, -1, -1, -1}, {65309, -1, -1, -1}, {65310, -1, -1, -1}, {65311, -1, -1, -1}, {65339, -1, -1, -1}, {65341, -1, -1, -1}, {65343, -1, -1, -1}, {65371, -1, -1, -1}, {65372, -1, -1, -1}, {65373, -1, -1, -1}, {65507, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12310, -1, -1, -1}, {12311, -1, -1, -1}, {12312, -1, -1, -1}, {12313, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8223, -1, -1, -1}, {8219, -1, -1, -1}, {8314, -1, -1, -1}, {8315, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8316, -1, -1, -1}, {-1, -1, -1, -1}, {8317, -1, -1, -1}, {8318, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {700, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8942, -1, -1, -1}, {8759, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {10122, -1, -1, -1}, {10123, -1, -1, -1}, {10124, -1, -1, -1}, {10125, -1, -1, -1}, {10126, -1, -1, -1}, {10127, -1, -1, -1}, {10128, -1, -1, -1}, {10129, -1, -1, -1}, {10130, -1, -1, -1}, {10131, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9398, -1, -1, -1}, {9399, -1, -1, -1}, {9400, -1, -1, -1}, {9401, -1, -1, -1}, {9402, -1, -1, -1}, {9403, -1, -1, -1}, {9404, -1, -1, -1}, {9405, -1, -1, -1}, {9406, -1, -1, -1}, {9407, -1, -1, -1}, {9408, -1, -1, -1}, {9409, -1, -1, -1}, {9410, -1, -1, -1}, {9411, -1, -1, -1}, {9412, -1, -1, -1}, {9413, -1, -1, -1}, {9414, -1, -1, -1}, {9415, -1, -1, -1}, {9416, -1, -1, -1}, {9417, -1, -1, -1}, {9418, -1, -1, -1}, {9419, -1, -1, -1}, {9420, -1, -1, -1}, {9421, -1, -1, -1}, {9422, -1, -1, -1}, {9423, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8826, -1, -1, -1}, {8827, -1, -1, -1}, {8910, -1, -1, -1}, {8911, -1, -1, -1}, {8832, -1, -1, -1}, {8833, -1, -1, -1}, {8816, -1, -1, -1}, {8817, -1, -1, -1}, {8818, -1, -1, -1}, {8819, -1, -1, -1}, {-1, -1, -1, -1}, {8842, -1, -1, -1}, {-1, -1, -1, -1}, {8843, -1, -1, -1}, {8822, -1, -1, -1}, {8823, -1, -1, -1}, {8825, -1, -1, -1}, {8922, -1, -1, -1}, {8923, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8773, -1, -1, -1}, {8771, -1, -1, -1}, {8776, -1, -1, -1}, {-1, -1, -1, -1}, {8868, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8244, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9839, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8258, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {10045, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8226, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8249, -1, -1, -1}, {8250, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {10010, -1, -1, -1}, {10006, -1, -1, -1}, {-1, -1, -1, -1}, {9711, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {10070, -1, -1, -1}, {-1, -1, -1, -1}, {9676, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9775, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12320, -1, -1, -1}, {-1, -1, -1, -1}, {10102, -1, -1, -1}, {10103, -1, -1, -1}, {10104, -1, -1, -1}, {10105, -1, -1, -1}, {10106, -1, -1, -1}, {10107, -1, -1, -1}, {10108, -1, -1, -1}, {10109, -1, -1, -1}, {10110, -1, -1, -1}, {10111, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12306, -1, -1, -1}, {12342, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8710, -1, -1, -1}, {-1, -1, -1, -1}, {8735, -1, -1, -1}, {-1, -1, -1, -1}, {8741, -1, -1, -1}, {8742, -1, -1, -1}, {-1, -1, -1, -1}, {8787, -1, -1, -1}, {8785, -1, -1, -1}, {8806, -1, -1, -1}, {8807, -1, -1, -1}, {8723, -1, -1, -1}, {8853, -1, -1, -1}, {8854, -1, -1, -1}, {8855, -1, -1, -1}, {-1, -1, -1, -1}, {8980, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8802, -1, -1, -1}, {-1, -1, -1, -1}, {9649, -1, -1, -1}, {-1, -1, -1, -1}, {8738, -1, -1, -1}, {8784, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8867, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8814, -1, -1, -1}, {8815, -1, -1, -1}, {8837, -1, -1, -1}, {8836, -1, -1, -1}, {8713, -1, -1, -1}, {8716, -1, -1, -1}, {8891, -1, -1, -1}, {8892, -1, -1, -1}, {8794, -1, -1, -1}, {8966, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12958, -1, -1, -1}, {-1, -1, -1, -1}, {8252, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9702, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9663, -1, -1, -1}, {9653, -1, -1, -1}, {9657, -1, -1, -1}, {9667, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9674, -1, -1, -1}, {12849, -1, -1, -1}, {12857, -1, -1, -1}, {13259, -1, -1, -1}, {9327, -1, -1, -1}, {9328, -1, -1, -1}, {9329, -1, -1, -1}, {9330, -1, -1, -1}, {9331, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8656, -1, -1, -1}, {8655, -1, -1, -1}, {8653, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8657, -1, -1, -1}, {8659, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8626, -1, -1, -1}, {8625, -1, -1, -1}, {-1, -1, -1, -1}, {8628, -1, -1, -1}, {8624, -1, -1, -1}, {8627, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8636, -1, -1, -1}, {8640, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8644, -1, -1, -1}, {8645, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9347, -1, -1, -1}, {9348, -1, -1, -1}, {9349, -1, -1, -1}, {9350, -1, -1, -1}, {9351, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12948, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12965, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8672, -1, -1, -1}, {8674, -1, -1, -1}, {8673, -1, -1, -1}, {8675, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {8678, -1, -1, -1}, {8680, -1, -1, -1}, {8679, -1, -1, -1}, {8681, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ {{-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {9757, -1, -1, -1}, {9759, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12944, -1, -1, -1}, {12938, -1, -1, -1}, {12939, -1, -1, -1}, {12940, -1, -1, -1}, {12941, -1, -1, -1}, {12942, -1, -1, -1}, {12943, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12318, -1, -1, -1}, {12319, -1, -1, -1}, {8246, -1, -1, -1}, {-1, -1, -1, -1}, {8245, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {12540, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {44034, -1, -1, -1}, {44035, -1, -1, -1}, {44037, -1, -1, -1}, {44038, -1, -1, -1}, {44043, -1, -1, -1}, {44044, -1, -1, -1}, {44045, -1, -1, -1}, {44046, -1, -1, -1}, {44047, -1, -1, -1}, {44056, -1, -1, -1}, {44062, -1, -1, -1}, {44063, -1, -1, -1}, {44065, -1, -1, -1}, {44066, -1, -1, -1}, {44067, -1, -1, -1}, {44069, -1, -1, -1}, {44070, -1, -1, -1}, {44071, -1, -1, -1}, {44072, -1, -1, -1}, {44073, -1, -1, -1}, {44074, -1, -1, -1}, {44075, -1, -1, -1}, {44078, -1, -1, -1}, {44082, -1, -1, -1}, {44083, -1, -1, -1}, {44084, -1, -1, -1}, {44085, -1, -1, -1}, {44086, -1, -1, -1}, {44087, -1, -1, -1}, {44090, -1, -1, -1}, {44091, -1, -1, -1}, {44093, -1, -1, -1}, {44094, -1, -1, -1}, {44095, -1, -1, -1}, {44097, -1, -1, -1}, {44098, -1, -1, -1}, {44099, -1, -1, -1}, {44100, -1, -1, -1}, {44101, -1, -1, -1}, {44102, -1, -1, -1}, {44103, -1, -1, -1}, {44104, -1, -1, -1}, {44105, -1, -1, -1}, {44106, -1, -1, -1}, {44108, -1, -1, -1}, {44110, -1, -1, -1}, {44111, -1, -1, -1}, {44112, -1, -1, -1}, {44113, -1, -1, -1}, {44114, -1, -1, -1}, {44115, -1, -1, -1}, {44117, -1, -1, -1}, {44118, -1, -1, -1}, {44119, -1, -1, -1}, {44121, -1, -1, -1}, {44122, -1, -1, -1}, {44123, -1, -1, -1}, {44125, -1, -1, -1}, {44126, -1, -1, -1}, {44127, -1, -1, -1}, {44128, -1, -1, -1}, {44129, -1, -1, -1}, {44130, -1, -1, -1}, {44131, -1, -1, -1}, {44132, -1, -1, -1}, {44133, -1, -1, -1}, {44134, -1, -1, -1}, {44135, -1, -1, -1}, {44136, -1, -1, -1}, {44137, -1, -1, -1}, {44138, -1, -1, -1}, {44139, -1, -1, -1}, {44140, -1, -1, -1}, {44141, -1, -1, -1}, {44142, -1, -1, -1}, {44143, -1, -1, -1}, {44146, -1, -1, -1}, {44147, -1, -1, -1}, {44149, -1, -1, -1}, {44150, -1, -1, -1}, {44153, -1, -1, -1}, {44155, -1, -1, -1}, {44156, -1, -1, -1}, {44157, -1, -1, -1}, {44158, -1, -1, -1}, {44159, -1, -1, -1}, {44162, -1, -1, -1}, {44167, -1, -1, -1}, {44168, -1, -1, -1}, {44173, -1, -1, -1}, {44174, -1, -1, -1}, {44175, -1, -1, -1}, {44177, -1, -1, -1}, {44178, -1, -1, -1}, {44179, -1, -1, -1}, {44181, -1, -1, -1}, {44182, -1, -1, -1}, {44183, -1, -1, -1}, {44184, -1, -1, -1}, {44185, -1, -1, -1}, {44186, -1, -1, -1}, {44187, -1, -1, -1}, {44190, -1, -1, -1}, {44194, -1, -1, -1}, {44195, -1, -1, -1}, {44196, -1, -1, -1}, {44197, -1, -1, -1}, {44198, -1, -1, -1}, {44199, -1, -1, -1}, {44203, -1, -1, -1}, {44205, -1, -1, -1}, {44206, -1, -1, -1}, {44209, -1, -1, -1}, {44210, -1, -1, -1}, {44211, -1, -1, -1}, {44212, -1, -1, -1}, {44213, -1, -1, -1}, {44214, -1, -1, -1}, {44215, -1, -1, -1}, {44218, -1, -1, -1}, {44222, -1, -1, -1}, {44223, -1, -1, -1}, {44224, -1, -1, -1}, {44226, -1, -1, -1}, {44227, -1, -1, -1}, {44229, -1, -1, -1}, {44230, -1, -1, -1}, {44231, -1, -1, -1}, {44233, -1, -1, -1}, {44234, -1, -1, -1}, {44235, -1, -1, -1}, {44237, -1, -1, -1}, {44238, -1, -1, -1}, {44239, -1, -1, -1}, {44240, -1, -1, -1}, {44241, -1, -1, -1}, {44242, -1, -1, -1}, {44243, -1, -1, -1}, {44244, -1, -1, -1} },
+ {{44246, -1, -1, -1}, {44248, -1, -1, -1}, {44249, -1, -1, -1}, {44250, -1, -1, -1}, {44251, -1, -1, -1}, {44252, -1, -1, -1}, {44253, -1, -1, -1}, {44254, -1, -1, -1}, {44255, -1, -1, -1}, {44258, -1, -1, -1}, {44259, -1, -1, -1}, {44261, -1, -1, -1}, {44262, -1, -1, -1}, {44265, -1, -1, -1}, {44267, -1, -1, -1}, {44269, -1, -1, -1}, {44270, -1, -1, -1}, {44274, -1, -1, -1}, {44276, -1, -1, -1}, {44279, -1, -1, -1}, {44280, -1, -1, -1}, {44281, -1, -1, -1}, {44282, -1, -1, -1}, {44283, -1, -1, -1}, {44286, -1, -1, -1}, {44287, -1, -1, -1}, {44289, -1, -1, -1}, {44290, -1, -1, -1}, {44291, -1, -1, -1}, {44293, -1, -1, -1}, {44295, -1, -1, -1}, {44296, -1, -1, -1}, {44297, -1, -1, -1}, {44298, -1, -1, -1}, {44299, -1, -1, -1}, {44302, -1, -1, -1}, {44304, -1, -1, -1}, {44306, -1, -1, -1}, {44307, -1, -1, -1}, {44308, -1, -1, -1}, {44309, -1, -1, -1}, {44310, -1, -1, -1}, {44311, -1, -1, -1}, {44313, -1, -1, -1}, {44314, -1, -1, -1}, {44315, -1, -1, -1}, {44317, -1, -1, -1}, {44318, -1, -1, -1}, {44319, -1, -1, -1}, {44321, -1, -1, -1}, {44322, -1, -1, -1}, {44323, -1, -1, -1}, {44324, -1, -1, -1}, {44325, -1, -1, -1}, {44326, -1, -1, -1}, {44327, -1, -1, -1}, {44328, -1, -1, -1}, {44330, -1, -1, -1}, {44331, -1, -1, -1}, {44334, -1, -1, -1}, {44335, -1, -1, -1}, {44336, -1, -1, -1}, {44337, -1, -1, -1}, {44338, -1, -1, -1}, {44339, -1, -1, -1}, {44342, -1, -1, -1}, {44343, -1, -1, -1}, {44345, -1, -1, -1}, {44346, -1, -1, -1}, {44347, -1, -1, -1}, {44349, -1, -1, -1}, {44350, -1, -1, -1}, {44351, -1, -1, -1}, {44352, -1, -1, -1}, {44353, -1, -1, -1}, {44354, -1, -1, -1}, {44355, -1, -1, -1}, {44358, -1, -1, -1}, {44360, -1, -1, -1}, {44362, -1, -1, -1}, {44363, -1, -1, -1}, {44364, -1, -1, -1}, {44365, -1, -1, -1}, {44366, -1, -1, -1}, {44367, -1, -1, -1}, {44369, -1, -1, -1}, {44370, -1, -1, -1}, {44371, -1, -1, -1}, {44373, -1, -1, -1}, {44374, -1, -1, -1}, {44375, -1, -1, -1}, {44377, -1, -1, -1}, {44378, -1, -1, -1}, {44379, -1, -1, -1}, {44380, -1, -1, -1}, {44381, -1, -1, -1}, {44382, -1, -1, -1}, {44383, -1, -1, -1}, {44384, -1, -1, -1}, {44386, -1, -1, -1}, {44388, -1, -1, -1}, {44389, -1, -1, -1}, {44390, -1, -1, -1}, {44391, -1, -1, -1}, {44392, -1, -1, -1}, {44393, -1, -1, -1}, {44394, -1, -1, -1}, {44395, -1, -1, -1}, {44398, -1, -1, -1}, {44399, -1, -1, -1}, {44401, -1, -1, -1}, {44402, -1, -1, -1}, {44407, -1, -1, -1}, {44408, -1, -1, -1}, {44409, -1, -1, -1}, {44410, -1, -1, -1}, {44414, -1, -1, -1}, {44416, -1, -1, -1}, {44419, -1, -1, -1}, {44420, -1, -1, -1}, {44421, -1, -1, -1}, {44422, -1, -1, -1}, {44423, -1, -1, -1}, {44426, -1, -1, -1}, {44427, -1, -1, -1}, {44429, -1, -1, -1}, {44430, -1, -1, -1}, {44431, -1, -1, -1}, {44433, -1, -1, -1}, {44434, -1, -1, -1}, {44435, -1, -1, -1}, {44436, -1, -1, -1}, {44437, -1, -1, -1}, {44438, -1, -1, -1}, {44439, -1, -1, -1}, {44440, -1, -1, -1}, {44441, -1, -1, -1}, {44442, -1, -1, -1}, {44443, -1, -1, -1}, {44446, -1, -1, -1}, {44447, -1, -1, -1}, {44448, -1, -1, -1}, {44449, -1, -1, -1}, {44450, -1, -1, -1}, {44451, -1, -1, -1}, {44453, -1, -1, -1}, {44454, -1, -1, -1}, {44455, -1, -1, -1}, {44456, -1, -1, -1}, {44457, -1, -1, -1}, {44458, -1, -1, -1}, {44459, -1, -1, -1}, {44460, -1, -1, -1}, {44461, -1, -1, -1}, {44462, -1, -1, -1}, {44463, -1, -1, -1}, {44464, -1, -1, -1}, {44465, -1, -1, -1}, {44466, -1, -1, -1}, {44467, -1, -1, -1}, {44468, -1, -1, -1}, {44469, -1, -1, -1}, {44470, -1, -1, -1}, {44472, -1, -1, -1}, {44473, -1, -1, -1}, {44474, -1, -1, -1}, {44475, -1, -1, -1}, {44476, -1, -1, -1}, {44477, -1, -1, -1}, {44478, -1, -1, -1}, {44479, -1, -1, -1}, {44482, -1, -1, -1}, {44483, -1, -1, -1}, {44485, -1, -1, -1}, {44486, -1, -1, -1}, {44487, -1, -1, -1}, {44489, -1, -1, -1}, {44490, -1, -1, -1}, {44491, -1, -1, -1}, {44492, -1, -1, -1}, {44493, -1, -1, -1}, {44494, -1, -1, -1}, {44495, -1, -1, -1}, {44498, -1, -1, -1}, {44500, -1, -1, -1}, {44501, -1, -1, -1}, {44502, -1, -1, -1}, {44503, -1, -1, -1}, {44504, -1, -1, -1}, {44505, -1, -1, -1}, {44506, -1, -1, -1}, {44507, -1, -1, -1}, {44509, -1, -1, -1}, {44510, -1, -1, -1}, {44511, -1, -1, -1}, {44513, -1, -1, -1}, {44514, -1, -1, -1}, {44515, -1, -1, -1}, {44517, -1, -1, -1}, {44518, -1, -1, -1}, {44519, -1, -1, -1}, {44520, -1, -1, -1}, {44521, -1, -1, -1}, {44522, -1, -1, -1}, {44523, -1, -1, -1}, {44524, -1, -1, -1}, {44525, -1, -1, -1}, {44526, -1, -1, -1}, {44527, -1, -1, -1}, {44528, -1, -1, -1}, {44529, -1, -1, -1}, {44530, -1, -1, -1}, {44531, -1, -1, -1}, {44532, -1, -1, -1}, {44533, -1, -1, -1}, {44534, -1, -1, -1}, {44535, -1, -1, -1}, {44538, -1, -1, -1}, {44539, -1, -1, -1}, {44541, -1, -1, -1}, {44542, -1, -1, -1}, {44546, -1, -1, -1}, {44547, -1, -1, -1}, {44548, -1, -1, -1}, {44549, -1, -1, -1}, {44550, -1, -1, -1}, {44551, -1, -1, -1}, {44554, -1, -1, -1}, {44556, -1, -1, -1}, {44558, -1, -1, -1}, {44559, -1, -1, -1}, {44560, -1, -1, -1}, {44561, -1, -1, -1}, {44562, -1, -1, -1}, {44563, -1, -1, -1}, {44565, -1, -1, -1}, {44566, -1, -1, -1}, {44567, -1, -1, -1}, {44568, -1, -1, -1}, {44569, -1, -1, -1}, {44570, -1, -1, -1}, {44571, -1, -1, -1}, {44572, -1, -1, -1}, {44573, -1, -1, -1}, {44574, -1, -1, -1}, {44575, -1, -1, -1}, {44576, -1, -1, -1}, {44577, -1, -1, -1}, {44578, -1, -1, -1}, {44579, -1, -1, -1}, {44580, -1, -1, -1}, {44581, -1, -1, -1}, {44582, -1, -1, -1}, {44583, -1, -1, -1}, {44584, -1, -1, -1}, {44585, -1, -1, -1} },
+ {{44586, -1, -1, -1}, {44587, -1, -1, -1}, {44588, -1, -1, -1}, {44589, -1, -1, -1}, {44590, -1, -1, -1}, {44591, -1, -1, -1}, {44594, -1, -1, -1}, {44595, -1, -1, -1}, {44597, -1, -1, -1}, {44598, -1, -1, -1}, {44601, -1, -1, -1}, {44603, -1, -1, -1}, {44604, -1, -1, -1}, {44605, -1, -1, -1}, {44606, -1, -1, -1}, {44607, -1, -1, -1}, {44610, -1, -1, -1}, {44612, -1, -1, -1}, {44615, -1, -1, -1}, {44616, -1, -1, -1}, {44617, -1, -1, -1}, {44619, -1, -1, -1}, {44623, -1, -1, -1}, {44625, -1, -1, -1}, {44626, -1, -1, -1}, {44627, -1, -1, -1}, {44629, -1, -1, -1}, {44631, -1, -1, -1}, {44632, -1, -1, -1}, {44633, -1, -1, -1}, {44634, -1, -1, -1}, {44635, -1, -1, -1}, {44638, -1, -1, -1}, {44642, -1, -1, -1}, {44643, -1, -1, -1}, {44644, -1, -1, -1}, {44646, -1, -1, -1}, {44647, -1, -1, -1}, {44650, -1, -1, -1}, {44651, -1, -1, -1}, {44653, -1, -1, -1}, {44654, -1, -1, -1}, {44655, -1, -1, -1}, {44657, -1, -1, -1}, {44658, -1, -1, -1}, {44659, -1, -1, -1}, {44660, -1, -1, -1}, {44661, -1, -1, -1}, {44662, -1, -1, -1}, {44663, -1, -1, -1}, {44666, -1, -1, -1}, {44670, -1, -1, -1}, {44671, -1, -1, -1}, {44672, -1, -1, -1}, {44673, -1, -1, -1}, {44674, -1, -1, -1}, {44675, -1, -1, -1}, {44678, -1, -1, -1}, {44679, -1, -1, -1}, {44680, -1, -1, -1}, {44681, -1, -1, -1}, {44682, -1, -1, -1}, {44683, -1, -1, -1}, {44685, -1, -1, -1}, {44686, -1, -1, -1}, {44687, -1, -1, -1}, {44688, -1, -1, -1}, {44689, -1, -1, -1}, {44690, -1, -1, -1}, {44691, -1, -1, -1}, {44692, -1, -1, -1}, {44693, -1, -1, -1}, {44694, -1, -1, -1}, {44695, -1, -1, -1}, {44696, -1, -1, -1}, {44697, -1, -1, -1}, {44698, -1, -1, -1}, {44699, -1, -1, -1}, {44700, -1, -1, -1}, {44701, -1, -1, -1}, {44702, -1, -1, -1}, {44703, -1, -1, -1}, {44704, -1, -1, -1}, {44705, -1, -1, -1}, {44706, -1, -1, -1}, {44707, -1, -1, -1}, {44708, -1, -1, -1}, {44709, -1, -1, -1}, {44710, -1, -1, -1}, {44711, -1, -1, -1}, {44712, -1, -1, -1}, {44713, -1, -1, -1}, {44714, -1, -1, -1}, {44715, -1, -1, -1}, {44716, -1, -1, -1}, {44717, -1, -1, -1}, {44718, -1, -1, -1}, {44719, -1, -1, -1}, {44720, -1, -1, -1}, {44721, -1, -1, -1}, {44722, -1, -1, -1}, {44723, -1, -1, -1}, {44724, -1, -1, -1}, {44725, -1, -1, -1}, {44726, -1, -1, -1}, {44727, -1, -1, -1}, {44728, -1, -1, -1}, {44729, -1, -1, -1}, {44730, -1, -1, -1}, {44731, -1, -1, -1}, {44735, -1, -1, -1}, {44737, -1, -1, -1}, {44738, -1, -1, -1}, {44739, -1, -1, -1}, {44741, -1, -1, -1}, {44742, -1, -1, -1}, {44743, -1, -1, -1}, {44744, -1, -1, -1}, {44745, -1, -1, -1}, {44746, -1, -1, -1}, {44747, -1, -1, -1}, {44750, -1, -1, -1}, {44754, -1, -1, -1}, {44755, -1, -1, -1}, {44756, -1, -1, -1}, {44757, -1, -1, -1}, {44758, -1, -1, -1}, {44759, -1, -1, -1}, {44762, -1, -1, -1}, {44763, -1, -1, -1}, {44765, -1, -1, -1}, {44766, -1, -1, -1}, {44767, -1, -1, -1}, {44768, -1, -1, -1}, {44769, -1, -1, -1}, {44770, -1, -1, -1}, {44771, -1, -1, -1}, {44772, -1, -1, -1}, {44773, -1, -1, -1}, {44774, -1, -1, -1}, {44775, -1, -1, -1}, {44777, -1, -1, -1}, {44778, -1, -1, -1}, {44780, -1, -1, -1}, {44782, -1, -1, -1}, {44783, -1, -1, -1}, {44784, -1, -1, -1}, {44785, -1, -1, -1}, {44786, -1, -1, -1}, {44787, -1, -1, -1}, {44789, -1, -1, -1}, {44790, -1, -1, -1}, {44791, -1, -1, -1}, {44793, -1, -1, -1}, {44794, -1, -1, -1}, {44795, -1, -1, -1}, {44797, -1, -1, -1}, {44798, -1, -1, -1}, {44799, -1, -1, -1}, {44800, -1, -1, -1}, {44801, -1, -1, -1}, {44802, -1, -1, -1}, {44803, -1, -1, -1}, {44804, -1, -1, -1}, {44805, -1, -1, -1}, {44806, -1, -1, -1}, {44809, -1, -1, -1}, {44810, -1, -1, -1}, {44811, -1, -1, -1}, {44812, -1, -1, -1}, {44814, -1, -1, -1}, {44815, -1, -1, -1}, {44817, -1, -1, -1}, {44818, -1, -1, -1}, {44819, -1, -1, -1}, {44820, -1, -1, -1}, {44821, -1, -1, -1}, {44822, -1, -1, -1}, {44823, -1, -1, -1}, {44824, -1, -1, -1}, {44825, -1, -1, -1}, {44826, -1, -1, -1}, {44827, -1, -1, -1}, {44828, -1, -1, -1}, {44829, -1, -1, -1}, {44830, -1, -1, -1}, {44831, -1, -1, -1}, {44832, -1, -1, -1}, {44833, -1, -1, -1}, {44834, -1, -1, -1}, {44835, -1, -1, -1}, {44836, -1, -1, -1}, {44837, -1, -1, -1}, {44838, -1, -1, -1}, {44839, -1, -1, -1}, {44840, -1, -1, -1}, {44841, -1, -1, -1}, {44842, -1, -1, -1}, {44843, -1, -1, -1}, {44846, -1, -1, -1}, {44847, -1, -1, -1}, {44849, -1, -1, -1}, {44851, -1, -1, -1}, {44853, -1, -1, -1}, {44854, -1, -1, -1}, {44855, -1, -1, -1}, {44856, -1, -1, -1}, {44857, -1, -1, -1}, {44858, -1, -1, -1}, {44859, -1, -1, -1}, {44862, -1, -1, -1}, {44864, -1, -1, -1}, {44868, -1, -1, -1}, {44869, -1, -1, -1}, {44870, -1, -1, -1}, {44871, -1, -1, -1}, {44874, -1, -1, -1}, {44875, -1, -1, -1}, {44876, -1, -1, -1}, {44877, -1, -1, -1}, {44878, -1, -1, -1}, {44879, -1, -1, -1}, {44881, -1, -1, -1}, {44882, -1, -1, -1}, {44883, -1, -1, -1}, {44884, -1, -1, -1}, {44885, -1, -1, -1}, {44886, -1, -1, -1}, {44887, -1, -1, -1}, {44888, -1, -1, -1}, {44889, -1, -1, -1}, {44890, -1, -1, -1}, {44891, -1, -1, -1}, {44894, -1, -1, -1}, {44895, -1, -1, -1}, {44896, -1, -1, -1}, {44897, -1, -1, -1}, {44898, -1, -1, -1}, {44899, -1, -1, -1}, {44902, -1, -1, -1}, {44903, -1, -1, -1}, {44904, -1, -1, -1}, {44905, -1, -1, -1}, {44906, -1, -1, -1}, {44907, -1, -1, -1}, {44908, -1, -1, -1}, {44909, -1, -1, -1}, {44910, -1, -1, -1}, {44911, -1, -1, -1}, {44912, -1, -1, -1}, {44913, -1, -1, -1}, {44914, -1, -1, -1}, {44915, -1, -1, -1}, {44916, -1, -1, -1}, {44917, -1, -1, -1}, {44918, -1, -1, -1} },
+ {{44919, -1, -1, -1}, {44920, -1, -1, -1}, {44922, -1, -1, -1}, {44923, -1, -1, -1}, {44924, -1, -1, -1}, {44925, -1, -1, -1}, {44926, -1, -1, -1}, {44927, -1, -1, -1}, {44929, -1, -1, -1}, {44930, -1, -1, -1}, {44931, -1, -1, -1}, {44933, -1, -1, -1}, {44934, -1, -1, -1}, {44935, -1, -1, -1}, {44937, -1, -1, -1}, {44938, -1, -1, -1}, {44939, -1, -1, -1}, {44940, -1, -1, -1}, {44941, -1, -1, -1}, {44942, -1, -1, -1}, {44943, -1, -1, -1}, {44946, -1, -1, -1}, {44947, -1, -1, -1}, {44948, -1, -1, -1}, {44950, -1, -1, -1}, {44951, -1, -1, -1}, {44952, -1, -1, -1}, {44953, -1, -1, -1}, {44954, -1, -1, -1}, {44955, -1, -1, -1}, {44957, -1, -1, -1}, {44958, -1, -1, -1}, {44959, -1, -1, -1}, {44960, -1, -1, -1}, {44961, -1, -1, -1}, {44962, -1, -1, -1}, {44963, -1, -1, -1}, {44964, -1, -1, -1}, {44965, -1, -1, -1}, {44966, -1, -1, -1}, {44967, -1, -1, -1}, {44968, -1, -1, -1}, {44969, -1, -1, -1}, {44970, -1, -1, -1}, {44971, -1, -1, -1}, {44972, -1, -1, -1}, {44973, -1, -1, -1}, {44974, -1, -1, -1}, {44975, -1, -1, -1}, {44976, -1, -1, -1}, {44977, -1, -1, -1}, {44978, -1, -1, -1}, {44979, -1, -1, -1}, {44980, -1, -1, -1}, {44981, -1, -1, -1}, {44982, -1, -1, -1}, {44983, -1, -1, -1}, {44986, -1, -1, -1}, {44987, -1, -1, -1}, {44989, -1, -1, -1}, {44990, -1, -1, -1}, {44991, -1, -1, -1}, {44993, -1, -1, -1}, {44994, -1, -1, -1}, {44995, -1, -1, -1}, {44996, -1, -1, -1}, {44997, -1, -1, -1}, {44998, -1, -1, -1}, {45002, -1, -1, -1}, {45004, -1, -1, -1}, {45007, -1, -1, -1}, {45008, -1, -1, -1}, {45009, -1, -1, -1}, {45010, -1, -1, -1}, {45011, -1, -1, -1}, {45013, -1, -1, -1}, {45014, -1, -1, -1}, {45015, -1, -1, -1}, {45016, -1, -1, -1}, {45017, -1, -1, -1}, {45018, -1, -1, -1}, {45019, -1, -1, -1}, {45021, -1, -1, -1}, {45022, -1, -1, -1}, {45023, -1, -1, -1}, {45024, -1, -1, -1}, {45025, -1, -1, -1}, {45026, -1, -1, -1}, {45027, -1, -1, -1}, {45028, -1, -1, -1}, {45029, -1, -1, -1}, {45030, -1, -1, -1}, {45031, -1, -1, -1}, {45034, -1, -1, -1}, {45035, -1, -1, -1}, {45036, -1, -1, -1}, {45037, -1, -1, -1}, {45038, -1, -1, -1}, {45039, -1, -1, -1}, {45042, -1, -1, -1}, {45043, -1, -1, -1}, {45045, -1, -1, -1}, {45046, -1, -1, -1}, {45047, -1, -1, -1}, {45049, -1, -1, -1}, {45050, -1, -1, -1}, {45051, -1, -1, -1}, {45052, -1, -1, -1}, {45053, -1, -1, -1}, {45054, -1, -1, -1}, {45055, -1, -1, -1}, {45058, -1, -1, -1}, {45059, -1, -1, -1}, {45061, -1, -1, -1}, {45062, -1, -1, -1}, {45063, -1, -1, -1}, {45064, -1, -1, -1}, {45065, -1, -1, -1}, {45066, -1, -1, -1}, {45067, -1, -1, -1}, {45069, -1, -1, -1}, {45070, -1, -1, -1}, {45071, -1, -1, -1}, {45073, -1, -1, -1}, {45074, -1, -1, -1}, {45075, -1, -1, -1}, {45077, -1, -1, -1}, {45078, -1, -1, -1}, {45079, -1, -1, -1}, {45080, -1, -1, -1}, {45081, -1, -1, -1}, {45082, -1, -1, -1}, {45083, -1, -1, -1}, {45086, -1, -1, -1}, {45087, -1, -1, -1}, {45088, -1, -1, -1}, {45089, -1, -1, -1}, {45090, -1, -1, -1}, {45091, -1, -1, -1}, {45092, -1, -1, -1}, {45093, -1, -1, -1}, {45094, -1, -1, -1}, {45095, -1, -1, -1}, {45097, -1, -1, -1}, {45098, -1, -1, -1}, {45099, -1, -1, -1}, {45100, -1, -1, -1}, {45101, -1, -1, -1}, {45102, -1, -1, -1}, {45103, -1, -1, -1}, {45104, -1, -1, -1}, {45105, -1, -1, -1}, {45106, -1, -1, -1}, {45107, -1, -1, -1}, {45108, -1, -1, -1}, {45109, -1, -1, -1}, {45110, -1, -1, -1}, {45111, -1, -1, -1}, {45112, -1, -1, -1}, {45113, -1, -1, -1}, {45114, -1, -1, -1}, {45115, -1, -1, -1}, {45116, -1, -1, -1}, {45117, -1, -1, -1}, {45118, -1, -1, -1}, {45119, -1, -1, -1}, {45120, -1, -1, -1}, {45121, -1, -1, -1}, {45122, -1, -1, -1}, {45123, -1, -1, -1}, {45126, -1, -1, -1}, {45127, -1, -1, -1}, {45129, -1, -1, -1}, {45131, -1, -1, -1}, {45133, -1, -1, -1}, {45135, -1, -1, -1}, {45136, -1, -1, -1}, {45137, -1, -1, -1}, {45138, -1, -1, -1}, {45142, -1, -1, -1}, {45144, -1, -1, -1}, {45146, -1, -1, -1}, {45147, -1, -1, -1}, {45148, -1, -1, -1}, {45150, -1, -1, -1}, {45151, -1, -1, -1}, {45152, -1, -1, -1}, {45153, -1, -1, -1}, {45154, -1, -1, -1}, {45155, -1, -1, -1}, {45156, -1, -1, -1}, {45157, -1, -1, -1}, {45158, -1, -1, -1}, {45159, -1, -1, -1}, {45160, -1, -1, -1}, {45161, -1, -1, -1}, {45162, -1, -1, -1}, {45163, -1, -1, -1}, {45164, -1, -1, -1}, {45165, -1, -1, -1}, {45166, -1, -1, -1}, {45167, -1, -1, -1}, {45168, -1, -1, -1}, {45169, -1, -1, -1}, {45170, -1, -1, -1}, {45171, -1, -1, -1}, {45172, -1, -1, -1}, {45173, -1, -1, -1}, {45174, -1, -1, -1}, {45175, -1, -1, -1}, {45176, -1, -1, -1}, {45177, -1, -1, -1}, {45178, -1, -1, -1}, {45179, -1, -1, -1}, {45182, -1, -1, -1}, {45183, -1, -1, -1}, {45185, -1, -1, -1}, {45186, -1, -1, -1}, {45187, -1, -1, -1}, {45189, -1, -1, -1}, {45190, -1, -1, -1}, {45191, -1, -1, -1}, {45192, -1, -1, -1}, {45193, -1, -1, -1}, {45194, -1, -1, -1}, {45195, -1, -1, -1}, {45198, -1, -1, -1}, {45200, -1, -1, -1}, {45202, -1, -1, -1}, {45203, -1, -1, -1}, {45204, -1, -1, -1}, {45205, -1, -1, -1}, {45206, -1, -1, -1}, {45207, -1, -1, -1}, {45211, -1, -1, -1}, {45213, -1, -1, -1}, {45214, -1, -1, -1}, {45219, -1, -1, -1}, {45220, -1, -1, -1}, {45221, -1, -1, -1}, {45222, -1, -1, -1}, {45223, -1, -1, -1}, {45226, -1, -1, -1}, {45232, -1, -1, -1}, {45234, -1, -1, -1}, {45238, -1, -1, -1}, {45239, -1, -1, -1}, {45241, -1, -1, -1}, {45242, -1, -1, -1}, {45243, -1, -1, -1}, {45245, -1, -1, -1}, {45246, -1, -1, -1}, {45247, -1, -1, -1}, {45248, -1, -1, -1}, {45249, -1, -1, -1}, {45250, -1, -1, -1} },
+ {{45251, -1, -1, -1}, {45254, -1, -1, -1}, {45258, -1, -1, -1}, {45259, -1, -1, -1}, {45260, -1, -1, -1}, {45261, -1, -1, -1}, {45262, -1, -1, -1}, {45263, -1, -1, -1}, {45266, -1, -1, -1}, {45267, -1, -1, -1}, {45269, -1, -1, -1}, {45270, -1, -1, -1}, {45271, -1, -1, -1}, {45273, -1, -1, -1}, {45274, -1, -1, -1}, {45275, -1, -1, -1}, {45276, -1, -1, -1}, {45277, -1, -1, -1}, {45278, -1, -1, -1}, {45279, -1, -1, -1}, {45281, -1, -1, -1}, {45282, -1, -1, -1}, {45283, -1, -1, -1}, {45284, -1, -1, -1}, {45286, -1, -1, -1}, {45287, -1, -1, -1}, {45288, -1, -1, -1}, {45289, -1, -1, -1}, {45290, -1, -1, -1}, {45291, -1, -1, -1}, {45292, -1, -1, -1}, {45293, -1, -1, -1}, {45294, -1, -1, -1}, {45295, -1, -1, -1}, {45296, -1, -1, -1}, {45297, -1, -1, -1}, {45298, -1, -1, -1}, {45299, -1, -1, -1}, {45300, -1, -1, -1}, {45301, -1, -1, -1}, {45302, -1, -1, -1}, {45303, -1, -1, -1}, {45304, -1, -1, -1}, {45305, -1, -1, -1}, {45306, -1, -1, -1}, {45307, -1, -1, -1}, {45308, -1, -1, -1}, {45309, -1, -1, -1}, {45310, -1, -1, -1}, {45311, -1, -1, -1}, {45312, -1, -1, -1}, {45313, -1, -1, -1}, {45314, -1, -1, -1}, {45315, -1, -1, -1}, {45316, -1, -1, -1}, {45317, -1, -1, -1}, {45318, -1, -1, -1}, {45319, -1, -1, -1}, {45322, -1, -1, -1}, {45325, -1, -1, -1}, {45326, -1, -1, -1}, {45327, -1, -1, -1}, {45329, -1, -1, -1}, {45332, -1, -1, -1}, {45333, -1, -1, -1}, {45334, -1, -1, -1}, {45335, -1, -1, -1}, {45338, -1, -1, -1}, {45342, -1, -1, -1}, {45343, -1, -1, -1}, {45344, -1, -1, -1}, {45345, -1, -1, -1}, {45346, -1, -1, -1}, {45350, -1, -1, -1}, {45351, -1, -1, -1}, {45353, -1, -1, -1}, {45354, -1, -1, -1}, {45355, -1, -1, -1}, {45357, -1, -1, -1}, {45358, -1, -1, -1}, {45359, -1, -1, -1}, {45360, -1, -1, -1}, {45361, -1, -1, -1}, {45362, -1, -1, -1}, {45363, -1, -1, -1}, {45366, -1, -1, -1}, {45370, -1, -1, -1}, {45371, -1, -1, -1}, {45372, -1, -1, -1}, {45373, -1, -1, -1}, {45374, -1, -1, -1}, {45375, -1, -1, -1}, {45378, -1, -1, -1}, {45379, -1, -1, -1}, {45381, -1, -1, -1}, {45382, -1, -1, -1}, {45383, -1, -1, -1}, {45385, -1, -1, -1}, {45386, -1, -1, -1}, {45387, -1, -1, -1}, {45388, -1, -1, -1}, {45389, -1, -1, -1}, {45390, -1, -1, -1}, {45391, -1, -1, -1}, {45394, -1, -1, -1}, {45395, -1, -1, -1}, {45398, -1, -1, -1}, {45399, -1, -1, -1}, {45401, -1, -1, -1}, {45402, -1, -1, -1}, {45403, -1, -1, -1}, {45405, -1, -1, -1}, {45406, -1, -1, -1}, {45407, -1, -1, -1}, {45409, -1, -1, -1}, {45410, -1, -1, -1}, {45411, -1, -1, -1}, {45412, -1, -1, -1}, {45413, -1, -1, -1}, {45414, -1, -1, -1}, {45415, -1, -1, -1}, {45416, -1, -1, -1}, {45417, -1, -1, -1}, {45418, -1, -1, -1}, {45419, -1, -1, -1}, {45420, -1, -1, -1}, {45421, -1, -1, -1}, {45422, -1, -1, -1}, {45423, -1, -1, -1}, {45424, -1, -1, -1}, {45425, -1, -1, -1}, {45426, -1, -1, -1}, {45427, -1, -1, -1}, {45428, -1, -1, -1}, {45429, -1, -1, -1}, {45430, -1, -1, -1}, {45431, -1, -1, -1}, {45434, -1, -1, -1}, {45435, -1, -1, -1}, {45437, -1, -1, -1}, {45438, -1, -1, -1}, {45439, -1, -1, -1}, {45441, -1, -1, -1}, {45443, -1, -1, -1}, {45444, -1, -1, -1}, {45445, -1, -1, -1}, {45446, -1, -1, -1}, {45447, -1, -1, -1}, {45450, -1, -1, -1}, {45452, -1, -1, -1}, {45454, -1, -1, -1}, {45455, -1, -1, -1}, {45456, -1, -1, -1}, {45457, -1, -1, -1}, {45461, -1, -1, -1}, {45462, -1, -1, -1}, {45463, -1, -1, -1}, {45465, -1, -1, -1}, {45466, -1, -1, -1}, {45467, -1, -1, -1}, {45469, -1, -1, -1}, {45470, -1, -1, -1}, {45471, -1, -1, -1}, {45472, -1, -1, -1}, {45473, -1, -1, -1}, {45474, -1, -1, -1}, {45475, -1, -1, -1}, {45476, -1, -1, -1}, {45477, -1, -1, -1}, {45478, -1, -1, -1}, {45479, -1, -1, -1}, {45481, -1, -1, -1}, {45482, -1, -1, -1}, {45483, -1, -1, -1}, {45484, -1, -1, -1}, {45485, -1, -1, -1}, {45486, -1, -1, -1}, {45487, -1, -1, -1}, {45488, -1, -1, -1}, {45489, -1, -1, -1}, {45490, -1, -1, -1}, {45491, -1, -1, -1}, {45492, -1, -1, -1}, {45493, -1, -1, -1}, {45494, -1, -1, -1}, {45495, -1, -1, -1}, {45496, -1, -1, -1}, {45497, -1, -1, -1}, {45498, -1, -1, -1}, {45499, -1, -1, -1}, {45500, -1, -1, -1}, {45501, -1, -1, -1}, {45502, -1, -1, -1}, {45503, -1, -1, -1}, {45504, -1, -1, -1}, {45505, -1, -1, -1}, {45506, -1, -1, -1}, {45507, -1, -1, -1}, {45508, -1, -1, -1}, {45509, -1, -1, -1}, {45510, -1, -1, -1}, {45511, -1, -1, -1}, {45512, -1, -1, -1}, {45513, -1, -1, -1}, {45514, -1, -1, -1}, {45515, -1, -1, -1}, {45517, -1, -1, -1}, {45518, -1, -1, -1}, {45519, -1, -1, -1}, {45521, -1, -1, -1}, {45522, -1, -1, -1}, {45523, -1, -1, -1}, {45525, -1, -1, -1}, {45526, -1, -1, -1}, {45527, -1, -1, -1}, {45528, -1, -1, -1}, {45529, -1, -1, -1}, {45530, -1, -1, -1}, {45531, -1, -1, -1}, {45534, -1, -1, -1}, {45536, -1, -1, -1}, {45537, -1, -1, -1}, {45538, -1, -1, -1}, {45539, -1, -1, -1}, {45540, -1, -1, -1}, {45541, -1, -1, -1}, {45542, -1, -1, -1}, {45543, -1, -1, -1}, {45546, -1, -1, -1}, {45547, -1, -1, -1}, {45549, -1, -1, -1}, {45550, -1, -1, -1}, {45551, -1, -1, -1}, {45553, -1, -1, -1}, {45554, -1, -1, -1}, {45555, -1, -1, -1}, {45556, -1, -1, -1}, {45557, -1, -1, -1}, {45558, -1, -1, -1}, {45559, -1, -1, -1}, {45560, -1, -1, -1}, {45562, -1, -1, -1}, {45564, -1, -1, -1}, {45566, -1, -1, -1}, {45567, -1, -1, -1}, {45568, -1, -1, -1}, {45569, -1, -1, -1}, {45570, -1, -1, -1}, {45571, -1, -1, -1}, {45574, -1, -1, -1}, {45575, -1, -1, -1}, {45577, -1, -1, -1}, {45578, -1, -1, -1}, {45581, -1, -1, -1}, {45582, -1, -1, -1}, {45583, -1, -1, -1} },
+ {{45584, -1, -1, -1}, {45585, -1, -1, -1}, {45586, -1, -1, -1}, {45587, -1, -1, -1}, {45590, -1, -1, -1}, {45592, -1, -1, -1}, {45594, -1, -1, -1}, {45595, -1, -1, -1}, {45596, -1, -1, -1}, {45597, -1, -1, -1}, {45598, -1, -1, -1}, {45599, -1, -1, -1}, {45601, -1, -1, -1}, {45602, -1, -1, -1}, {45603, -1, -1, -1}, {45604, -1, -1, -1}, {45605, -1, -1, -1}, {45606, -1, -1, -1}, {45607, -1, -1, -1}, {45608, -1, -1, -1}, {45609, -1, -1, -1}, {45610, -1, -1, -1}, {45611, -1, -1, -1}, {45612, -1, -1, -1}, {45613, -1, -1, -1}, {45614, -1, -1, -1}, {45615, -1, -1, -1}, {45616, -1, -1, -1}, {45617, -1, -1, -1}, {45618, -1, -1, -1}, {45619, -1, -1, -1}, {45621, -1, -1, -1}, {45622, -1, -1, -1}, {45623, -1, -1, -1}, {45624, -1, -1, -1}, {45625, -1, -1, -1}, {45626, -1, -1, -1}, {45627, -1, -1, -1}, {45629, -1, -1, -1}, {45630, -1, -1, -1}, {45631, -1, -1, -1}, {45632, -1, -1, -1}, {45633, -1, -1, -1}, {45634, -1, -1, -1}, {45635, -1, -1, -1}, {45636, -1, -1, -1}, {45637, -1, -1, -1}, {45638, -1, -1, -1}, {45639, -1, -1, -1}, {45640, -1, -1, -1}, {45641, -1, -1, -1}, {45642, -1, -1, -1}, {45643, -1, -1, -1}, {45644, -1, -1, -1}, {45645, -1, -1, -1}, {45646, -1, -1, -1}, {45647, -1, -1, -1}, {45648, -1, -1, -1}, {45649, -1, -1, -1}, {45650, -1, -1, -1}, {45651, -1, -1, -1}, {45652, -1, -1, -1}, {45653, -1, -1, -1}, {45654, -1, -1, -1}, {45655, -1, -1, -1}, {45657, -1, -1, -1}, {45658, -1, -1, -1}, {45659, -1, -1, -1}, {45661, -1, -1, -1}, {45662, -1, -1, -1}, {45663, -1, -1, -1}, {45665, -1, -1, -1}, {45666, -1, -1, -1}, {45667, -1, -1, -1}, {45668, -1, -1, -1}, {45669, -1, -1, -1}, {45670, -1, -1, -1}, {45671, -1, -1, -1}, {45674, -1, -1, -1}, {45675, -1, -1, -1}, {45676, -1, -1, -1}, {45677, -1, -1, -1}, {45678, -1, -1, -1}, {45679, -1, -1, -1}, {45680, -1, -1, -1}, {45681, -1, -1, -1}, {45682, -1, -1, -1}, {45683, -1, -1, -1}, {45686, -1, -1, -1}, {45687, -1, -1, -1}, {45688, -1, -1, -1}, {45689, -1, -1, -1}, {45690, -1, -1, -1}, {45691, -1, -1, -1}, {45693, -1, -1, -1}, {45694, -1, -1, -1}, {45695, -1, -1, -1}, {45696, -1, -1, -1}, {45697, -1, -1, -1}, {45698, -1, -1, -1}, {45699, -1, -1, -1}, {45702, -1, -1, -1}, {45703, -1, -1, -1}, {45704, -1, -1, -1}, {45706, -1, -1, -1}, {45707, -1, -1, -1}, {45708, -1, -1, -1}, {45709, -1, -1, -1}, {45710, -1, -1, -1}, {45711, -1, -1, -1}, {45714, -1, -1, -1}, {45715, -1, -1, -1}, {45717, -1, -1, -1}, {45718, -1, -1, -1}, {45719, -1, -1, -1}, {45723, -1, -1, -1}, {45724, -1, -1, -1}, {45725, -1, -1, -1}, {45726, -1, -1, -1}, {45727, -1, -1, -1}, {45730, -1, -1, -1}, {45732, -1, -1, -1}, {45735, -1, -1, -1}, {45736, -1, -1, -1}, {45737, -1, -1, -1}, {45739, -1, -1, -1}, {45741, -1, -1, -1}, {45742, -1, -1, -1}, {45743, -1, -1, -1}, {45745, -1, -1, -1}, {45746, -1, -1, -1}, {45747, -1, -1, -1}, {45749, -1, -1, -1}, {45750, -1, -1, -1}, {45751, -1, -1, -1}, {45752, -1, -1, -1}, {45753, -1, -1, -1}, {45754, -1, -1, -1}, {45755, -1, -1, -1}, {45756, -1, -1, -1}, {45757, -1, -1, -1}, {45758, -1, -1, -1}, {45759, -1, -1, -1}, {45760, -1, -1, -1}, {45761, -1, -1, -1}, {45762, -1, -1, -1}, {45763, -1, -1, -1}, {45764, -1, -1, -1}, {45765, -1, -1, -1}, {45766, -1, -1, -1}, {45767, -1, -1, -1}, {45770, -1, -1, -1}, {45771, -1, -1, -1}, {45773, -1, -1, -1}, {45774, -1, -1, -1}, {45775, -1, -1, -1}, {45777, -1, -1, -1}, {45779, -1, -1, -1}, {45780, -1, -1, -1}, {45781, -1, -1, -1}, {45782, -1, -1, -1}, {45783, -1, -1, -1}, {45786, -1, -1, -1}, {45788, -1, -1, -1}, {45790, -1, -1, -1}, {45791, -1, -1, -1}, {45792, -1, -1, -1}, {45793, -1, -1, -1}, {45795, -1, -1, -1}, {45799, -1, -1, -1}, {45801, -1, -1, -1}, {45802, -1, -1, -1}, {45808, -1, -1, -1}, {45809, -1, -1, -1}, {45810, -1, -1, -1}, {45814, -1, -1, -1}, {45820, -1, -1, -1}, {45821, -1, -1, -1}, {45822, -1, -1, -1}, {45826, -1, -1, -1}, {45827, -1, -1, -1}, {45829, -1, -1, -1}, {45830, -1, -1, -1}, {45831, -1, -1, -1}, {45833, -1, -1, -1}, {45834, -1, -1, -1}, {45835, -1, -1, -1}, {45836, -1, -1, -1}, {45837, -1, -1, -1}, {45838, -1, -1, -1}, {45839, -1, -1, -1}, {45842, -1, -1, -1}, {45846, -1, -1, -1}, {45847, -1, -1, -1}, {45848, -1, -1, -1}, {45849, -1, -1, -1}, {45850, -1, -1, -1}, {45851, -1, -1, -1}, {45853, -1, -1, -1}, {45854, -1, -1, -1}, {45855, -1, -1, -1}, {45856, -1, -1, -1}, {45857, -1, -1, -1}, {45858, -1, -1, -1}, {45859, -1, -1, -1}, {45860, -1, -1, -1}, {45861, -1, -1, -1}, {45862, -1, -1, -1}, {45863, -1, -1, -1}, {45864, -1, -1, -1}, {45865, -1, -1, -1}, {45866, -1, -1, -1}, {45867, -1, -1, -1}, {45868, -1, -1, -1}, {45869, -1, -1, -1}, {45870, -1, -1, -1}, {45871, -1, -1, -1}, {45872, -1, -1, -1}, {45873, -1, -1, -1}, {45874, -1, -1, -1}, {45875, -1, -1, -1}, {45876, -1, -1, -1}, {45877, -1, -1, -1}, {45878, -1, -1, -1}, {45879, -1, -1, -1}, {45880, -1, -1, -1}, {45881, -1, -1, -1}, {45882, -1, -1, -1}, {45883, -1, -1, -1}, {45884, -1, -1, -1}, {45885, -1, -1, -1}, {45886, -1, -1, -1}, {45887, -1, -1, -1}, {45888, -1, -1, -1}, {45889, -1, -1, -1}, {45890, -1, -1, -1}, {45891, -1, -1, -1}, {45892, -1, -1, -1}, {45893, -1, -1, -1}, {45894, -1, -1, -1}, {45895, -1, -1, -1}, {45896, -1, -1, -1}, {45897, -1, -1, -1}, {45898, -1, -1, -1}, {45899, -1, -1, -1}, {45900, -1, -1, -1}, {45901, -1, -1, -1}, {45902, -1, -1, -1}, {45903, -1, -1, -1}, {45904, -1, -1, -1}, {45905, -1, -1, -1}, {45906, -1, -1, -1}, {45907, -1, -1, -1}, {45911, -1, -1, -1}, {45913, -1, -1, -1}, {45914, -1, -1, -1} },
+ {{45917, -1, -1, -1}, {45920, -1, -1, -1}, {45921, -1, -1, -1}, {45922, -1, -1, -1}, {45923, -1, -1, -1}, {45926, -1, -1, -1}, {45928, -1, -1, -1}, {45930, -1, -1, -1}, {45932, -1, -1, -1}, {45933, -1, -1, -1}, {45935, -1, -1, -1}, {45938, -1, -1, -1}, {45939, -1, -1, -1}, {45941, -1, -1, -1}, {45942, -1, -1, -1}, {45943, -1, -1, -1}, {45945, -1, -1, -1}, {45946, -1, -1, -1}, {45947, -1, -1, -1}, {45948, -1, -1, -1}, {45949, -1, -1, -1}, {45950, -1, -1, -1}, {45951, -1, -1, -1}, {45954, -1, -1, -1}, {45958, -1, -1, -1}, {45959, -1, -1, -1}, {45960, -1, -1, -1}, {45961, -1, -1, -1}, {45962, -1, -1, -1}, {45963, -1, -1, -1}, {45965, -1, -1, -1}, {45966, -1, -1, -1}, {45967, -1, -1, -1}, {45969, -1, -1, -1}, {45970, -1, -1, -1}, {45971, -1, -1, -1}, {45973, -1, -1, -1}, {45974, -1, -1, -1}, {45975, -1, -1, -1}, {45976, -1, -1, -1}, {45977, -1, -1, -1}, {45978, -1, -1, -1}, {45979, -1, -1, -1}, {45980, -1, -1, -1}, {45981, -1, -1, -1}, {45982, -1, -1, -1}, {45983, -1, -1, -1}, {45986, -1, -1, -1}, {45987, -1, -1, -1}, {45988, -1, -1, -1}, {45989, -1, -1, -1}, {45990, -1, -1, -1}, {45991, -1, -1, -1}, {45993, -1, -1, -1}, {45994, -1, -1, -1}, {45995, -1, -1, -1}, {45997, -1, -1, -1}, {45998, -1, -1, -1}, {45999, -1, -1, -1}, {46000, -1, -1, -1}, {46001, -1, -1, -1}, {46002, -1, -1, -1}, {46003, -1, -1, -1}, {46004, -1, -1, -1}, {46005, -1, -1, -1}, {46006, -1, -1, -1}, {46007, -1, -1, -1}, {46008, -1, -1, -1}, {46009, -1, -1, -1}, {46010, -1, -1, -1}, {46011, -1, -1, -1}, {46012, -1, -1, -1}, {46013, -1, -1, -1}, {46014, -1, -1, -1}, {46015, -1, -1, -1}, {46016, -1, -1, -1}, {46017, -1, -1, -1}, {46018, -1, -1, -1}, {46019, -1, -1, -1}, {46022, -1, -1, -1}, {46023, -1, -1, -1}, {46025, -1, -1, -1}, {46026, -1, -1, -1}, {46029, -1, -1, -1}, {46031, -1, -1, -1}, {46033, -1, -1, -1}, {46034, -1, -1, -1}, {46035, -1, -1, -1}, {46038, -1, -1, -1}, {46040, -1, -1, -1}, {46042, -1, -1, -1}, {46044, -1, -1, -1}, {46046, -1, -1, -1}, {46047, -1, -1, -1}, {46049, -1, -1, -1}, {46050, -1, -1, -1}, {46051, -1, -1, -1}, {46053, -1, -1, -1}, {46054, -1, -1, -1}, {46055, -1, -1, -1}, {46057, -1, -1, -1}, {46058, -1, -1, -1}, {46059, -1, -1, -1}, {46060, -1, -1, -1}, {46061, -1, -1, -1}, {46062, -1, -1, -1}, {46063, -1, -1, -1}, {46064, -1, -1, -1}, {46065, -1, -1, -1}, {46066, -1, -1, -1}, {46067, -1, -1, -1}, {46068, -1, -1, -1}, {46069, -1, -1, -1}, {46070, -1, -1, -1}, {46071, -1, -1, -1}, {46072, -1, -1, -1}, {46073, -1, -1, -1}, {46074, -1, -1, -1}, {46075, -1, -1, -1}, {46077, -1, -1, -1}, {46078, -1, -1, -1}, {46079, -1, -1, -1}, {46080, -1, -1, -1}, {46081, -1, -1, -1}, {46082, -1, -1, -1}, {46083, -1, -1, -1}, {46084, -1, -1, -1}, {46085, -1, -1, -1}, {46086, -1, -1, -1}, {46087, -1, -1, -1}, {46088, -1, -1, -1}, {46089, -1, -1, -1}, {46090, -1, -1, -1}, {46091, -1, -1, -1}, {46092, -1, -1, -1}, {46093, -1, -1, -1}, {46094, -1, -1, -1}, {46095, -1, -1, -1}, {46097, -1, -1, -1}, {46098, -1, -1, -1}, {46099, -1, -1, -1}, {46100, -1, -1, -1}, {46101, -1, -1, -1}, {46102, -1, -1, -1}, {46103, -1, -1, -1}, {46105, -1, -1, -1}, {46106, -1, -1, -1}, {46107, -1, -1, -1}, {46109, -1, -1, -1}, {46110, -1, -1, -1}, {46111, -1, -1, -1}, {46113, -1, -1, -1}, {46114, -1, -1, -1}, {46115, -1, -1, -1}, {46116, -1, -1, -1}, {46117, -1, -1, -1}, {46118, -1, -1, -1}, {46119, -1, -1, -1}, {46122, -1, -1, -1}, {46124, -1, -1, -1}, {46125, -1, -1, -1}, {46126, -1, -1, -1}, {46127, -1, -1, -1}, {46128, -1, -1, -1}, {46129, -1, -1, -1}, {46130, -1, -1, -1}, {46131, -1, -1, -1}, {46133, -1, -1, -1}, {46134, -1, -1, -1}, {46135, -1, -1, -1}, {46136, -1, -1, -1}, {46137, -1, -1, -1}, {46138, -1, -1, -1}, {46139, -1, -1, -1}, {46140, -1, -1, -1}, {46141, -1, -1, -1}, {46142, -1, -1, -1}, {46143, -1, -1, -1}, {46144, -1, -1, -1}, {46145, -1, -1, -1}, {46146, -1, -1, -1}, {46147, -1, -1, -1}, {46148, -1, -1, -1}, {46149, -1, -1, -1}, {46150, -1, -1, -1}, {46151, -1, -1, -1}, {46152, -1, -1, -1}, {46153, -1, -1, -1}, {46154, -1, -1, -1}, {46155, -1, -1, -1}, {46156, -1, -1, -1}, {46157, -1, -1, -1}, {46158, -1, -1, -1}, {46159, -1, -1, -1}, {46162, -1, -1, -1}, {46163, -1, -1, -1}, {46165, -1, -1, -1}, {46166, -1, -1, -1}, {46167, -1, -1, -1}, {46169, -1, -1, -1}, {46170, -1, -1, -1}, {46171, -1, -1, -1}, {46172, -1, -1, -1}, {46173, -1, -1, -1}, {46174, -1, -1, -1}, {46175, -1, -1, -1}, {46178, -1, -1, -1}, {46180, -1, -1, -1}, {46182, -1, -1, -1}, {46183, -1, -1, -1}, {46184, -1, -1, -1}, {46185, -1, -1, -1}, {46186, -1, -1, -1}, {46187, -1, -1, -1}, {46189, -1, -1, -1}, {46190, -1, -1, -1}, {46191, -1, -1, -1}, {46192, -1, -1, -1}, {46193, -1, -1, -1}, {46194, -1, -1, -1}, {46195, -1, -1, -1}, {46196, -1, -1, -1}, {46197, -1, -1, -1}, {46198, -1, -1, -1}, {46199, -1, -1, -1}, {46200, -1, -1, -1}, {46201, -1, -1, -1}, {46202, -1, -1, -1}, {46203, -1, -1, -1}, {46204, -1, -1, -1}, {46205, -1, -1, -1}, {46206, -1, -1, -1}, {46207, -1, -1, -1}, {46209, -1, -1, -1}, {46210, -1, -1, -1}, {46211, -1, -1, -1}, {46212, -1, -1, -1}, {46213, -1, -1, -1}, {46214, -1, -1, -1}, {46215, -1, -1, -1}, {46217, -1, -1, -1}, {46218, -1, -1, -1}, {46219, -1, -1, -1}, {46220, -1, -1, -1}, {46221, -1, -1, -1}, {46222, -1, -1, -1}, {46223, -1, -1, -1}, {46224, -1, -1, -1}, {46225, -1, -1, -1}, {46226, -1, -1, -1}, {46227, -1, -1, -1}, {46228, -1, -1, -1}, {46229, -1, -1, -1}, {46230, -1, -1, -1}, {46231, -1, -1, -1}, {46232, -1, -1, -1} },
+ {{46233, -1, -1, -1}, {46234, -1, -1, -1}, {46235, -1, -1, -1}, {46236, -1, -1, -1}, {46238, -1, -1, -1}, {46239, -1, -1, -1}, {46240, -1, -1, -1}, {46241, -1, -1, -1}, {46242, -1, -1, -1}, {46243, -1, -1, -1}, {46245, -1, -1, -1}, {46246, -1, -1, -1}, {46247, -1, -1, -1}, {46249, -1, -1, -1}, {46250, -1, -1, -1}, {46251, -1, -1, -1}, {46253, -1, -1, -1}, {46254, -1, -1, -1}, {46255, -1, -1, -1}, {46256, -1, -1, -1}, {46257, -1, -1, -1}, {46258, -1, -1, -1}, {46259, -1, -1, -1}, {46260, -1, -1, -1}, {46262, -1, -1, -1}, {46264, -1, -1, -1}, {46266, -1, -1, -1}, {46267, -1, -1, -1}, {46268, -1, -1, -1}, {46269, -1, -1, -1}, {46270, -1, -1, -1}, {46271, -1, -1, -1}, {46273, -1, -1, -1}, {46274, -1, -1, -1}, {46275, -1, -1, -1}, {46277, -1, -1, -1}, {46278, -1, -1, -1}, {46279, -1, -1, -1}, {46281, -1, -1, -1}, {46282, -1, -1, -1}, {46283, -1, -1, -1}, {46284, -1, -1, -1}, {46285, -1, -1, -1}, {46286, -1, -1, -1}, {46287, -1, -1, -1}, {46289, -1, -1, -1}, {46290, -1, -1, -1}, {46291, -1, -1, -1}, {46292, -1, -1, -1}, {46294, -1, -1, -1}, {46295, -1, -1, -1}, {46296, -1, -1, -1}, {46297, -1, -1, -1}, {46298, -1, -1, -1}, {46299, -1, -1, -1}, {46302, -1, -1, -1}, {46303, -1, -1, -1}, {46305, -1, -1, -1}, {46306, -1, -1, -1}, {46309, -1, -1, -1}, {46311, -1, -1, -1}, {46312, -1, -1, -1}, {46313, -1, -1, -1}, {46314, -1, -1, -1}, {46315, -1, -1, -1}, {46318, -1, -1, -1}, {46320, -1, -1, -1}, {46322, -1, -1, -1}, {46323, -1, -1, -1}, {46324, -1, -1, -1}, {46325, -1, -1, -1}, {46326, -1, -1, -1}, {46327, -1, -1, -1}, {46329, -1, -1, -1}, {46330, -1, -1, -1}, {46331, -1, -1, -1}, {46332, -1, -1, -1}, {46333, -1, -1, -1}, {46334, -1, -1, -1}, {46335, -1, -1, -1}, {46336, -1, -1, -1}, {46337, -1, -1, -1}, {46338, -1, -1, -1}, {46339, -1, -1, -1}, {46340, -1, -1, -1}, {46341, -1, -1, -1}, {46342, -1, -1, -1}, {46343, -1, -1, -1}, {46344, -1, -1, -1}, {46345, -1, -1, -1}, {46346, -1, -1, -1}, {46347, -1, -1, -1}, {46348, -1, -1, -1}, {46349, -1, -1, -1}, {46350, -1, -1, -1}, {46351, -1, -1, -1}, {46352, -1, -1, -1}, {46353, -1, -1, -1}, {46354, -1, -1, -1}, {46355, -1, -1, -1}, {46358, -1, -1, -1}, {46359, -1, -1, -1}, {46361, -1, -1, -1}, {46362, -1, -1, -1}, {46365, -1, -1, -1}, {46366, -1, -1, -1}, {46367, -1, -1, -1}, {46368, -1, -1, -1}, {46369, -1, -1, -1}, {46370, -1, -1, -1}, {46371, -1, -1, -1}, {46374, -1, -1, -1}, {46379, -1, -1, -1}, {46380, -1, -1, -1}, {46381, -1, -1, -1}, {46382, -1, -1, -1}, {46383, -1, -1, -1}, {46386, -1, -1, -1}, {46387, -1, -1, -1}, {46389, -1, -1, -1}, {46390, -1, -1, -1}, {46391, -1, -1, -1}, {46393, -1, -1, -1}, {46394, -1, -1, -1}, {46395, -1, -1, -1}, {46396, -1, -1, -1}, {46397, -1, -1, -1}, {46398, -1, -1, -1}, {46399, -1, -1, -1}, {46402, -1, -1, -1}, {46406, -1, -1, -1}, {46407, -1, -1, -1}, {46408, -1, -1, -1}, {46409, -1, -1, -1}, {46410, -1, -1, -1}, {46414, -1, -1, -1}, {46415, -1, -1, -1}, {46417, -1, -1, -1}, {46418, -1, -1, -1}, {46419, -1, -1, -1}, {46421, -1, -1, -1}, {46422, -1, -1, -1}, {46423, -1, -1, -1}, {46424, -1, -1, -1}, {46425, -1, -1, -1}, {46426, -1, -1, -1}, {46427, -1, -1, -1}, {46430, -1, -1, -1}, {46434, -1, -1, -1}, {46435, -1, -1, -1}, {46436, -1, -1, -1}, {46437, -1, -1, -1}, {46438, -1, -1, -1}, {46439, -1, -1, -1}, {46440, -1, -1, -1}, {46441, -1, -1, -1}, {46442, -1, -1, -1}, {46443, -1, -1, -1}, {46444, -1, -1, -1}, {46445, -1, -1, -1}, {46446, -1, -1, -1}, {46447, -1, -1, -1}, {46448, -1, -1, -1}, {46449, -1, -1, -1}, {46450, -1, -1, -1}, {46451, -1, -1, -1}, {46452, -1, -1, -1}, {46453, -1, -1, -1}, {46454, -1, -1, -1}, {46455, -1, -1, -1}, {46456, -1, -1, -1}, {46457, -1, -1, -1}, {46458, -1, -1, -1}, {46459, -1, -1, -1}, {46460, -1, -1, -1}, {46461, -1, -1, -1}, {46462, -1, -1, -1}, {46463, -1, -1, -1}, {46464, -1, -1, -1}, {46465, -1, -1, -1}, {46466, -1, -1, -1}, {46467, -1, -1, -1}, {46468, -1, -1, -1}, {46469, -1, -1, -1}, {46470, -1, -1, -1}, {46471, -1, -1, -1}, {46472, -1, -1, -1}, {46473, -1, -1, -1}, {46474, -1, -1, -1}, {46475, -1, -1, -1}, {46476, -1, -1, -1}, {46477, -1, -1, -1}, {46478, -1, -1, -1}, {46479, -1, -1, -1}, {46480, -1, -1, -1}, {46481, -1, -1, -1}, {46482, -1, -1, -1}, {46483, -1, -1, -1}, {46484, -1, -1, -1}, {46485, -1, -1, -1}, {46486, -1, -1, -1}, {46487, -1, -1, -1}, {46488, -1, -1, -1}, {46489, -1, -1, -1}, {46490, -1, -1, -1}, {46491, -1, -1, -1}, {46492, -1, -1, -1}, {46493, -1, -1, -1}, {46494, -1, -1, -1}, {46495, -1, -1, -1}, {46498, -1, -1, -1}, {46499, -1, -1, -1}, {46501, -1, -1, -1}, {46502, -1, -1, -1}, {46503, -1, -1, -1}, {46505, -1, -1, -1}, {46508, -1, -1, -1}, {46509, -1, -1, -1}, {46510, -1, -1, -1}, {46511, -1, -1, -1}, {46514, -1, -1, -1}, {46518, -1, -1, -1}, {46519, -1, -1, -1}, {46520, -1, -1, -1}, {46521, -1, -1, -1}, {46522, -1, -1, -1}, {46526, -1, -1, -1}, {46527, -1, -1, -1}, {46529, -1, -1, -1}, {46530, -1, -1, -1}, {46531, -1, -1, -1}, {46533, -1, -1, -1}, {46534, -1, -1, -1}, {46535, -1, -1, -1}, {46536, -1, -1, -1}, {46537, -1, -1, -1}, {46538, -1, -1, -1}, {46539, -1, -1, -1}, {46542, -1, -1, -1}, {46546, -1, -1, -1}, {46547, -1, -1, -1}, {46548, -1, -1, -1}, {46549, -1, -1, -1}, {46550, -1, -1, -1}, {46551, -1, -1, -1}, {46553, -1, -1, -1}, {46554, -1, -1, -1}, {46555, -1, -1, -1}, {46556, -1, -1, -1}, {46557, -1, -1, -1}, {46558, -1, -1, -1}, {46559, -1, -1, -1}, {46560, -1, -1, -1}, {46561, -1, -1, -1}, {46562, -1, -1, -1}, {46563, -1, -1, -1} },
+ {{46564, -1, -1, -1}, {46565, -1, -1, -1}, {46566, -1, -1, -1}, {46567, -1, -1, -1}, {46568, -1, -1, -1}, {46569, -1, -1, -1}, {46570, -1, -1, -1}, {46571, -1, -1, -1}, {46573, -1, -1, -1}, {46574, -1, -1, -1}, {46575, -1, -1, -1}, {46576, -1, -1, -1}, {46577, -1, -1, -1}, {46578, -1, -1, -1}, {46579, -1, -1, -1}, {46580, -1, -1, -1}, {46581, -1, -1, -1}, {46582, -1, -1, -1}, {46583, -1, -1, -1}, {46584, -1, -1, -1}, {46585, -1, -1, -1}, {46586, -1, -1, -1}, {46587, -1, -1, -1}, {46588, -1, -1, -1}, {46589, -1, -1, -1}, {46590, -1, -1, -1}, {46591, -1, -1, -1}, {46592, -1, -1, -1}, {46593, -1, -1, -1}, {46594, -1, -1, -1}, {46595, -1, -1, -1}, {46596, -1, -1, -1}, {46597, -1, -1, -1}, {46598, -1, -1, -1}, {46599, -1, -1, -1}, {46600, -1, -1, -1}, {46601, -1, -1, -1}, {46602, -1, -1, -1}, {46603, -1, -1, -1}, {46604, -1, -1, -1}, {46605, -1, -1, -1}, {46606, -1, -1, -1}, {46607, -1, -1, -1}, {46610, -1, -1, -1}, {46611, -1, -1, -1}, {46613, -1, -1, -1}, {46614, -1, -1, -1}, {46615, -1, -1, -1}, {46617, -1, -1, -1}, {46618, -1, -1, -1}, {46619, -1, -1, -1}, {46620, -1, -1, -1}, {46621, -1, -1, -1}, {46622, -1, -1, -1}, {46623, -1, -1, -1}, {46624, -1, -1, -1}, {46625, -1, -1, -1}, {46626, -1, -1, -1}, {46627, -1, -1, -1}, {46628, -1, -1, -1}, {46630, -1, -1, -1}, {46631, -1, -1, -1}, {46632, -1, -1, -1}, {46633, -1, -1, -1}, {46634, -1, -1, -1}, {46635, -1, -1, -1}, {46637, -1, -1, -1}, {46638, -1, -1, -1}, {46639, -1, -1, -1}, {46640, -1, -1, -1}, {46641, -1, -1, -1}, {46642, -1, -1, -1}, {46643, -1, -1, -1}, {46645, -1, -1, -1}, {46646, -1, -1, -1}, {46647, -1, -1, -1}, {46648, -1, -1, -1}, {46649, -1, -1, -1}, {46650, -1, -1, -1}, {46651, -1, -1, -1}, {46652, -1, -1, -1}, {46653, -1, -1, -1}, {46654, -1, -1, -1}, {46655, -1, -1, -1}, {46656, -1, -1, -1}, {46657, -1, -1, -1}, {46658, -1, -1, -1}, {46659, -1, -1, -1}, {46660, -1, -1, -1}, {46661, -1, -1, -1}, {46662, -1, -1, -1}, {46663, -1, -1, -1}, {46665, -1, -1, -1}, {46666, -1, -1, -1}, {46667, -1, -1, -1}, {46668, -1, -1, -1}, {46669, -1, -1, -1}, {46670, -1, -1, -1}, {46671, -1, -1, -1}, {46672, -1, -1, -1}, {46673, -1, -1, -1}, {46674, -1, -1, -1}, {46675, -1, -1, -1}, {46676, -1, -1, -1}, {46677, -1, -1, -1}, {46678, -1, -1, -1}, {46679, -1, -1, -1}, {46680, -1, -1, -1}, {46681, -1, -1, -1}, {46682, -1, -1, -1}, {46683, -1, -1, -1}, {46684, -1, -1, -1}, {46685, -1, -1, -1}, {46686, -1, -1, -1}, {46687, -1, -1, -1}, {46688, -1, -1, -1}, {46689, -1, -1, -1}, {46690, -1, -1, -1}, {46691, -1, -1, -1}, {46693, -1, -1, -1}, {46694, -1, -1, -1}, {46695, -1, -1, -1}, {46697, -1, -1, -1}, {46698, -1, -1, -1}, {46699, -1, -1, -1}, {46700, -1, -1, -1}, {46701, -1, -1, -1}, {46702, -1, -1, -1}, {46703, -1, -1, -1}, {46704, -1, -1, -1}, {46705, -1, -1, -1}, {46706, -1, -1, -1}, {46707, -1, -1, -1}, {46708, -1, -1, -1}, {46709, -1, -1, -1}, {46710, -1, -1, -1}, {46711, -1, -1, -1}, {46712, -1, -1, -1}, {46713, -1, -1, -1}, {46714, -1, -1, -1}, {46715, -1, -1, -1}, {46716, -1, -1, -1}, {46717, -1, -1, -1}, {46718, -1, -1, -1}, {46719, -1, -1, -1}, {46720, -1, -1, -1}, {46721, -1, -1, -1}, {46722, -1, -1, -1}, {46723, -1, -1, -1}, {46724, -1, -1, -1}, {46725, -1, -1, -1}, {46726, -1, -1, -1}, {46727, -1, -1, -1}, {46728, -1, -1, -1}, {46729, -1, -1, -1}, {46730, -1, -1, -1}, {46731, -1, -1, -1}, {46732, -1, -1, -1}, {46733, -1, -1, -1}, {46734, -1, -1, -1}, {46735, -1, -1, -1}, {46736, -1, -1, -1}, {46737, -1, -1, -1}, {46738, -1, -1, -1}, {46739, -1, -1, -1}, {46740, -1, -1, -1}, {46741, -1, -1, -1}, {46742, -1, -1, -1}, {46743, -1, -1, -1}, {46744, -1, -1, -1}, {46745, -1, -1, -1}, {46746, -1, -1, -1}, {46747, -1, -1, -1}, {46750, -1, -1, -1}, {46751, -1, -1, -1}, {46753, -1, -1, -1}, {46754, -1, -1, -1}, {46755, -1, -1, -1}, {46757, -1, -1, -1}, {46758, -1, -1, -1}, {46759, -1, -1, -1}, {46760, -1, -1, -1}, {46761, -1, -1, -1}, {46762, -1, -1, -1}, {46765, -1, -1, -1}, {46766, -1, -1, -1}, {46767, -1, -1, -1}, {46768, -1, -1, -1}, {46770, -1, -1, -1}, {46771, -1, -1, -1}, {46772, -1, -1, -1}, {46773, -1, -1, -1}, {46774, -1, -1, -1}, {46775, -1, -1, -1}, {46776, -1, -1, -1}, {46777, -1, -1, -1}, {46778, -1, -1, -1}, {46779, -1, -1, -1}, {46780, -1, -1, -1}, {46781, -1, -1, -1}, {46782, -1, -1, -1}, {46783, -1, -1, -1}, {46784, -1, -1, -1}, {46785, -1, -1, -1}, {46786, -1, -1, -1}, {46787, -1, -1, -1}, {46788, -1, -1, -1}, {46789, -1, -1, -1}, {46790, -1, -1, -1}, {46791, -1, -1, -1}, {46792, -1, -1, -1}, {46793, -1, -1, -1}, {46794, -1, -1, -1}, {46795, -1, -1, -1}, {46796, -1, -1, -1}, {46797, -1, -1, -1}, {46798, -1, -1, -1}, {46799, -1, -1, -1}, {46800, -1, -1, -1}, {46801, -1, -1, -1}, {46802, -1, -1, -1}, {46803, -1, -1, -1}, {46805, -1, -1, -1}, {46806, -1, -1, -1}, {46807, -1, -1, -1}, {46808, -1, -1, -1}, {46809, -1, -1, -1}, {46810, -1, -1, -1}, {46811, -1, -1, -1}, {46812, -1, -1, -1}, {46813, -1, -1, -1}, {46814, -1, -1, -1}, {46815, -1, -1, -1}, {46816, -1, -1, -1}, {46817, -1, -1, -1}, {46818, -1, -1, -1}, {46819, -1, -1, -1}, {46820, -1, -1, -1}, {46821, -1, -1, -1}, {46822, -1, -1, -1}, {46823, -1, -1, -1}, {46824, -1, -1, -1}, {46825, -1, -1, -1}, {46826, -1, -1, -1}, {46827, -1, -1, -1}, {46828, -1, -1, -1}, {46829, -1, -1, -1}, {46830, -1, -1, -1}, {46831, -1, -1, -1}, {46833, -1, -1, -1}, {46834, -1, -1, -1}, {46835, -1, -1, -1}, {46837, -1, -1, -1}, {46838, -1, -1, -1}, {46839, -1, -1, -1}, {46841, -1, -1, -1} },
+ {{46842, -1, -1, -1}, {46843, -1, -1, -1}, {46844, -1, -1, -1}, {46845, -1, -1, -1}, {46846, -1, -1, -1}, {46847, -1, -1, -1}, {46850, -1, -1, -1}, {46851, -1, -1, -1}, {46852, -1, -1, -1}, {46854, -1, -1, -1}, {46855, -1, -1, -1}, {46856, -1, -1, -1}, {46857, -1, -1, -1}, {46858, -1, -1, -1}, {46859, -1, -1, -1}, {46860, -1, -1, -1}, {46861, -1, -1, -1}, {46862, -1, -1, -1}, {46863, -1, -1, -1}, {46864, -1, -1, -1}, {46865, -1, -1, -1}, {46866, -1, -1, -1}, {46867, -1, -1, -1}, {46868, -1, -1, -1}, {46869, -1, -1, -1}, {46870, -1, -1, -1}, {46871, -1, -1, -1}, {46872, -1, -1, -1}, {46873, -1, -1, -1}, {46874, -1, -1, -1}, {46875, -1, -1, -1}, {46876, -1, -1, -1}, {46877, -1, -1, -1}, {46878, -1, -1, -1}, {46879, -1, -1, -1}, {46880, -1, -1, -1}, {46881, -1, -1, -1}, {46882, -1, -1, -1}, {46883, -1, -1, -1}, {46884, -1, -1, -1}, {46885, -1, -1, -1}, {46886, -1, -1, -1}, {46887, -1, -1, -1}, {46890, -1, -1, -1}, {46891, -1, -1, -1}, {46893, -1, -1, -1}, {46894, -1, -1, -1}, {46897, -1, -1, -1}, {46898, -1, -1, -1}, {46899, -1, -1, -1}, {46900, -1, -1, -1}, {46901, -1, -1, -1}, {46902, -1, -1, -1}, {46903, -1, -1, -1}, {46906, -1, -1, -1}, {46908, -1, -1, -1}, {46909, -1, -1, -1}, {46910, -1, -1, -1}, {46911, -1, -1, -1}, {46912, -1, -1, -1}, {46913, -1, -1, -1}, {46914, -1, -1, -1}, {46915, -1, -1, -1}, {46917, -1, -1, -1}, {46918, -1, -1, -1}, {46919, -1, -1, -1}, {46921, -1, -1, -1}, {46922, -1, -1, -1}, {46923, -1, -1, -1}, {46925, -1, -1, -1}, {46926, -1, -1, -1}, {46927, -1, -1, -1}, {46928, -1, -1, -1}, {46929, -1, -1, -1}, {46930, -1, -1, -1}, {46931, -1, -1, -1}, {46934, -1, -1, -1}, {46935, -1, -1, -1}, {46936, -1, -1, -1}, {46937, -1, -1, -1}, {46938, -1, -1, -1}, {46939, -1, -1, -1}, {46940, -1, -1, -1}, {46941, -1, -1, -1}, {46942, -1, -1, -1}, {46943, -1, -1, -1}, {46945, -1, -1, -1}, {46946, -1, -1, -1}, {46947, -1, -1, -1}, {46949, -1, -1, -1}, {46950, -1, -1, -1}, {46951, -1, -1, -1}, {46953, -1, -1, -1}, {46954, -1, -1, -1}, {46955, -1, -1, -1}, {46956, -1, -1, -1}, {46957, -1, -1, -1}, {46958, -1, -1, -1}, {46959, -1, -1, -1}, {46962, -1, -1, -1}, {46964, -1, -1, -1}, {46966, -1, -1, -1}, {46967, -1, -1, -1}, {46968, -1, -1, -1}, {46969, -1, -1, -1}, {46970, -1, -1, -1}, {46971, -1, -1, -1}, {46974, -1, -1, -1}, {46975, -1, -1, -1}, {46977, -1, -1, -1}, {46978, -1, -1, -1}, {46979, -1, -1, -1}, {46981, -1, -1, -1}, {46982, -1, -1, -1}, {46983, -1, -1, -1}, {46984, -1, -1, -1}, {46985, -1, -1, -1}, {46986, -1, -1, -1}, {46987, -1, -1, -1}, {46990, -1, -1, -1}, {46995, -1, -1, -1}, {46996, -1, -1, -1}, {46997, -1, -1, -1}, {47002, -1, -1, -1}, {47003, -1, -1, -1}, {47005, -1, -1, -1}, {47006, -1, -1, -1}, {47007, -1, -1, -1}, {47009, -1, -1, -1}, {47010, -1, -1, -1}, {47011, -1, -1, -1}, {47012, -1, -1, -1}, {47013, -1, -1, -1}, {47014, -1, -1, -1}, {47015, -1, -1, -1}, {47018, -1, -1, -1}, {47022, -1, -1, -1}, {47023, -1, -1, -1}, {47024, -1, -1, -1}, {47025, -1, -1, -1}, {47026, -1, -1, -1}, {47027, -1, -1, -1}, {47030, -1, -1, -1}, {47031, -1, -1, -1}, {47033, -1, -1, -1}, {47034, -1, -1, -1}, {47035, -1, -1, -1}, {47036, -1, -1, -1}, {47037, -1, -1, -1}, {47038, -1, -1, -1}, {47039, -1, -1, -1}, {47040, -1, -1, -1}, {47041, -1, -1, -1}, {47042, -1, -1, -1}, {47043, -1, -1, -1}, {47044, -1, -1, -1}, {47045, -1, -1, -1}, {47046, -1, -1, -1}, {47048, -1, -1, -1}, {47050, -1, -1, -1}, {47051, -1, -1, -1}, {47052, -1, -1, -1}, {47053, -1, -1, -1}, {47054, -1, -1, -1}, {47055, -1, -1, -1}, {47056, -1, -1, -1}, {47057, -1, -1, -1}, {47058, -1, -1, -1}, {47059, -1, -1, -1}, {47060, -1, -1, -1}, {47061, -1, -1, -1}, {47062, -1, -1, -1}, {47063, -1, -1, -1}, {47064, -1, -1, -1}, {47065, -1, -1, -1}, {47066, -1, -1, -1}, {47067, -1, -1, -1}, {47068, -1, -1, -1}, {47069, -1, -1, -1}, {47070, -1, -1, -1}, {47071, -1, -1, -1}, {47072, -1, -1, -1}, {47073, -1, -1, -1}, {47074, -1, -1, -1}, {47075, -1, -1, -1}, {47076, -1, -1, -1}, {47077, -1, -1, -1}, {47078, -1, -1, -1}, {47079, -1, -1, -1}, {47080, -1, -1, -1}, {47081, -1, -1, -1}, {47082, -1, -1, -1}, {47083, -1, -1, -1}, {47086, -1, -1, -1}, {47087, -1, -1, -1}, {47089, -1, -1, -1}, {47090, -1, -1, -1}, {47091, -1, -1, -1}, {47093, -1, -1, -1}, {47094, -1, -1, -1}, {47095, -1, -1, -1}, {47096, -1, -1, -1}, {47097, -1, -1, -1}, {47098, -1, -1, -1}, {47099, -1, -1, -1}, {47102, -1, -1, -1}, {47106, -1, -1, -1}, {47107, -1, -1, -1}, {47108, -1, -1, -1}, {47109, -1, -1, -1}, {47110, -1, -1, -1}, {47114, -1, -1, -1}, {47115, -1, -1, -1}, {47117, -1, -1, -1}, {47118, -1, -1, -1}, {47119, -1, -1, -1}, {47121, -1, -1, -1}, {47122, -1, -1, -1}, {47123, -1, -1, -1}, {47124, -1, -1, -1}, {47125, -1, -1, -1}, {47126, -1, -1, -1}, {47127, -1, -1, -1}, {47130, -1, -1, -1}, {47132, -1, -1, -1}, {47134, -1, -1, -1}, {47135, -1, -1, -1}, {47136, -1, -1, -1}, {47137, -1, -1, -1}, {47138, -1, -1, -1}, {47139, -1, -1, -1}, {47142, -1, -1, -1}, {47143, -1, -1, -1}, {47145, -1, -1, -1}, {47146, -1, -1, -1}, {47147, -1, -1, -1}, {47149, -1, -1, -1}, {47150, -1, -1, -1}, {47151, -1, -1, -1}, {47152, -1, -1, -1}, {47153, -1, -1, -1}, {47154, -1, -1, -1}, {47155, -1, -1, -1}, {47158, -1, -1, -1}, {47162, -1, -1, -1}, {47163, -1, -1, -1}, {47164, -1, -1, -1}, {47165, -1, -1, -1}, {47166, -1, -1, -1}, {47167, -1, -1, -1}, {47169, -1, -1, -1}, {47170, -1, -1, -1}, {47171, -1, -1, -1}, {47173, -1, -1, -1}, {47174, -1, -1, -1}, {47175, -1, -1, -1} },
+ {{47176, -1, -1, -1}, {47177, -1, -1, -1}, {47178, -1, -1, -1}, {47179, -1, -1, -1}, {47180, -1, -1, -1}, {47181, -1, -1, -1}, {47182, -1, -1, -1}, {47183, -1, -1, -1}, {47184, -1, -1, -1}, {47186, -1, -1, -1}, {47188, -1, -1, -1}, {47189, -1, -1, -1}, {47190, -1, -1, -1}, {47191, -1, -1, -1}, {47192, -1, -1, -1}, {47193, -1, -1, -1}, {47194, -1, -1, -1}, {47195, -1, -1, -1}, {47198, -1, -1, -1}, {47199, -1, -1, -1}, {47201, -1, -1, -1}, {47202, -1, -1, -1}, {47203, -1, -1, -1}, {47205, -1, -1, -1}, {47206, -1, -1, -1}, {47207, -1, -1, -1}, {47208, -1, -1, -1}, {47209, -1, -1, -1}, {47210, -1, -1, -1}, {47211, -1, -1, -1}, {47214, -1, -1, -1}, {47216, -1, -1, -1}, {47218, -1, -1, -1}, {47219, -1, -1, -1}, {47220, -1, -1, -1}, {47221, -1, -1, -1}, {47222, -1, -1, -1}, {47223, -1, -1, -1}, {47225, -1, -1, -1}, {47226, -1, -1, -1}, {47227, -1, -1, -1}, {47229, -1, -1, -1}, {47230, -1, -1, -1}, {47231, -1, -1, -1}, {47232, -1, -1, -1}, {47233, -1, -1, -1}, {47234, -1, -1, -1}, {47235, -1, -1, -1}, {47236, -1, -1, -1}, {47237, -1, -1, -1}, {47238, -1, -1, -1}, {47239, -1, -1, -1}, {47240, -1, -1, -1}, {47241, -1, -1, -1}, {47242, -1, -1, -1}, {47243, -1, -1, -1}, {47244, -1, -1, -1}, {47246, -1, -1, -1}, {47247, -1, -1, -1}, {47248, -1, -1, -1}, {47249, -1, -1, -1}, {47250, -1, -1, -1}, {47251, -1, -1, -1}, {47252, -1, -1, -1}, {47253, -1, -1, -1}, {47254, -1, -1, -1}, {47255, -1, -1, -1}, {47256, -1, -1, -1}, {47257, -1, -1, -1}, {47258, -1, -1, -1}, {47259, -1, -1, -1}, {47260, -1, -1, -1}, {47261, -1, -1, -1}, {47262, -1, -1, -1}, {47263, -1, -1, -1}, {47264, -1, -1, -1}, {47265, -1, -1, -1}, {47266, -1, -1, -1}, {47267, -1, -1, -1}, {47268, -1, -1, -1}, {47269, -1, -1, -1}, {47270, -1, -1, -1}, {47271, -1, -1, -1}, {47273, -1, -1, -1}, {47274, -1, -1, -1}, {47275, -1, -1, -1}, {47276, -1, -1, -1}, {47277, -1, -1, -1}, {47278, -1, -1, -1}, {47279, -1, -1, -1}, {47281, -1, -1, -1}, {47282, -1, -1, -1}, {47283, -1, -1, -1}, {47285, -1, -1, -1}, {47286, -1, -1, -1}, {47287, -1, -1, -1}, {47289, -1, -1, -1}, {47290, -1, -1, -1}, {47291, -1, -1, -1}, {47292, -1, -1, -1}, {47293, -1, -1, -1}, {47294, -1, -1, -1}, {47295, -1, -1, -1}, {47298, -1, -1, -1}, {47300, -1, -1, -1}, {47302, -1, -1, -1}, {47303, -1, -1, -1}, {47304, -1, -1, -1}, {47305, -1, -1, -1}, {47306, -1, -1, -1}, {47307, -1, -1, -1}, {47309, -1, -1, -1}, {47310, -1, -1, -1}, {47311, -1, -1, -1}, {47313, -1, -1, -1}, {47314, -1, -1, -1}, {47315, -1, -1, -1}, {47317, -1, -1, -1}, {47318, -1, -1, -1}, {47319, -1, -1, -1}, {47320, -1, -1, -1}, {47321, -1, -1, -1}, {47322, -1, -1, -1}, {47323, -1, -1, -1}, {47324, -1, -1, -1}, {47326, -1, -1, -1}, {47328, -1, -1, -1}, {47330, -1, -1, -1}, {47331, -1, -1, -1}, {47332, -1, -1, -1}, {47333, -1, -1, -1}, {47334, -1, -1, -1}, {47335, -1, -1, -1}, {47338, -1, -1, -1}, {47339, -1, -1, -1}, {47341, -1, -1, -1}, {47342, -1, -1, -1}, {47343, -1, -1, -1}, {47345, -1, -1, -1}, {47346, -1, -1, -1}, {47347, -1, -1, -1}, {47348, -1, -1, -1}, {47349, -1, -1, -1}, {47350, -1, -1, -1}, {47351, -1, -1, -1}, {47354, -1, -1, -1}, {47356, -1, -1, -1}, {47358, -1, -1, -1}, {47359, -1, -1, -1}, {47360, -1, -1, -1}, {47361, -1, -1, -1}, {47362, -1, -1, -1}, {47363, -1, -1, -1}, {47365, -1, -1, -1}, {47366, -1, -1, -1}, {47367, -1, -1, -1}, {47368, -1, -1, -1}, {47369, -1, -1, -1}, {47370, -1, -1, -1}, {47371, -1, -1, -1}, {47372, -1, -1, -1}, {47373, -1, -1, -1}, {47374, -1, -1, -1}, {47375, -1, -1, -1}, {47376, -1, -1, -1}, {47377, -1, -1, -1}, {47378, -1, -1, -1}, {47379, -1, -1, -1}, {47380, -1, -1, -1}, {47381, -1, -1, -1}, {47382, -1, -1, -1}, {47383, -1, -1, -1}, {47385, -1, -1, -1}, {47386, -1, -1, -1}, {47387, -1, -1, -1}, {47388, -1, -1, -1}, {47389, -1, -1, -1}, {47390, -1, -1, -1}, {47391, -1, -1, -1}, {47393, -1, -1, -1}, {47394, -1, -1, -1}, {47395, -1, -1, -1}, {47396, -1, -1, -1}, {47397, -1, -1, -1}, {47398, -1, -1, -1}, {47399, -1, -1, -1}, {47400, -1, -1, -1}, {47401, -1, -1, -1}, {47402, -1, -1, -1}, {47403, -1, -1, -1}, {47404, -1, -1, -1}, {47405, -1, -1, -1}, {47406, -1, -1, -1}, {47407, -1, -1, -1}, {47408, -1, -1, -1}, {47409, -1, -1, -1}, {47410, -1, -1, -1}, {47411, -1, -1, -1}, {47412, -1, -1, -1}, {47413, -1, -1, -1}, {47414, -1, -1, -1}, {47415, -1, -1, -1}, {47416, -1, -1, -1}, {47417, -1, -1, -1}, {47418, -1, -1, -1}, {47419, -1, -1, -1}, {47422, -1, -1, -1}, {47423, -1, -1, -1}, {47425, -1, -1, -1}, {47426, -1, -1, -1}, {47427, -1, -1, -1}, {47429, -1, -1, -1}, {47430, -1, -1, -1}, {47431, -1, -1, -1}, {47432, -1, -1, -1}, {47433, -1, -1, -1}, {47434, -1, -1, -1}, {47435, -1, -1, -1}, {47437, -1, -1, -1}, {47438, -1, -1, -1}, {47440, -1, -1, -1}, {47442, -1, -1, -1}, {47443, -1, -1, -1}, {47444, -1, -1, -1}, {47445, -1, -1, -1}, {47446, -1, -1, -1}, {47447, -1, -1, -1}, {47450, -1, -1, -1}, {47451, -1, -1, -1}, {47453, -1, -1, -1}, {47454, -1, -1, -1}, {47455, -1, -1, -1}, {47457, -1, -1, -1}, {47458, -1, -1, -1}, {47459, -1, -1, -1}, {47460, -1, -1, -1}, {47461, -1, -1, -1}, {47462, -1, -1, -1}, {47463, -1, -1, -1}, {47466, -1, -1, -1}, {47468, -1, -1, -1}, {47470, -1, -1, -1}, {47471, -1, -1, -1}, {47472, -1, -1, -1}, {47473, -1, -1, -1}, {47474, -1, -1, -1}, {47475, -1, -1, -1}, {47478, -1, -1, -1}, {47479, -1, -1, -1}, {47481, -1, -1, -1}, {47482, -1, -1, -1}, {47483, -1, -1, -1}, {47485, -1, -1, -1}, {47486, -1, -1, -1}, {47487, -1, -1, -1}, {47488, -1, -1, -1} },
+ {{47489, -1, -1, -1}, {47490, -1, -1, -1}, {47491, -1, -1, -1}, {47494, -1, -1, -1}, {47496, -1, -1, -1}, {47499, -1, -1, -1}, {47500, -1, -1, -1}, {47503, -1, -1, -1}, {47504, -1, -1, -1}, {47505, -1, -1, -1}, {47506, -1, -1, -1}, {47507, -1, -1, -1}, {47508, -1, -1, -1}, {47509, -1, -1, -1}, {47510, -1, -1, -1}, {47511, -1, -1, -1}, {47512, -1, -1, -1}, {47513, -1, -1, -1}, {47514, -1, -1, -1}, {47515, -1, -1, -1}, {47516, -1, -1, -1}, {47517, -1, -1, -1}, {47518, -1, -1, -1}, {47519, -1, -1, -1}, {47520, -1, -1, -1}, {47521, -1, -1, -1}, {47522, -1, -1, -1}, {47523, -1, -1, -1}, {47524, -1, -1, -1}, {47525, -1, -1, -1}, {47526, -1, -1, -1}, {47527, -1, -1, -1}, {47528, -1, -1, -1}, {47529, -1, -1, -1}, {47530, -1, -1, -1}, {47531, -1, -1, -1}, {47534, -1, -1, -1}, {47535, -1, -1, -1}, {47537, -1, -1, -1}, {47538, -1, -1, -1}, {47539, -1, -1, -1}, {47541, -1, -1, -1}, {47542, -1, -1, -1}, {47543, -1, -1, -1}, {47544, -1, -1, -1}, {47545, -1, -1, -1}, {47546, -1, -1, -1}, {47547, -1, -1, -1}, {47550, -1, -1, -1}, {47552, -1, -1, -1}, {47554, -1, -1, -1}, {47555, -1, -1, -1}, {47556, -1, -1, -1}, {47557, -1, -1, -1}, {47558, -1, -1, -1}, {47559, -1, -1, -1}, {47562, -1, -1, -1}, {47563, -1, -1, -1}, {47565, -1, -1, -1}, {47571, -1, -1, -1}, {47572, -1, -1, -1}, {47573, -1, -1, -1}, {47574, -1, -1, -1}, {47575, -1, -1, -1}, {47578, -1, -1, -1}, {47580, -1, -1, -1}, {47583, -1, -1, -1}, {47584, -1, -1, -1}, {47586, -1, -1, -1}, {47590, -1, -1, -1}, {47591, -1, -1, -1}, {47593, -1, -1, -1}, {47594, -1, -1, -1}, {47595, -1, -1, -1}, {47597, -1, -1, -1}, {47598, -1, -1, -1}, {47599, -1, -1, -1}, {47600, -1, -1, -1}, {47601, -1, -1, -1}, {47602, -1, -1, -1}, {47603, -1, -1, -1}, {47606, -1, -1, -1}, {47611, -1, -1, -1}, {47612, -1, -1, -1}, {47613, -1, -1, -1}, {47614, -1, -1, -1}, {47615, -1, -1, -1}, {47618, -1, -1, -1}, {47619, -1, -1, -1}, {47620, -1, -1, -1}, {47621, -1, -1, -1}, {47622, -1, -1, -1}, {47623, -1, -1, -1}, {47625, -1, -1, -1}, {47626, -1, -1, -1}, {47627, -1, -1, -1}, {47628, -1, -1, -1}, {47629, -1, -1, -1}, {47630, -1, -1, -1}, {47631, -1, -1, -1}, {47632, -1, -1, -1}, {47633, -1, -1, -1}, {47634, -1, -1, -1}, {47635, -1, -1, -1}, {47636, -1, -1, -1}, {47638, -1, -1, -1}, {47639, -1, -1, -1}, {47640, -1, -1, -1}, {47641, -1, -1, -1}, {47642, -1, -1, -1}, {47643, -1, -1, -1}, {47644, -1, -1, -1}, {47645, -1, -1, -1}, {47646, -1, -1, -1}, {47647, -1, -1, -1}, {47648, -1, -1, -1}, {47649, -1, -1, -1}, {47650, -1, -1, -1}, {47651, -1, -1, -1}, {47652, -1, -1, -1}, {47653, -1, -1, -1}, {47654, -1, -1, -1}, {47655, -1, -1, -1}, {47656, -1, -1, -1}, {47657, -1, -1, -1}, {47658, -1, -1, -1}, {47659, -1, -1, -1}, {47660, -1, -1, -1}, {47661, -1, -1, -1}, {47662, -1, -1, -1}, {47663, -1, -1, -1}, {47664, -1, -1, -1}, {47665, -1, -1, -1}, {47666, -1, -1, -1}, {47667, -1, -1, -1}, {47668, -1, -1, -1}, {47669, -1, -1, -1}, {47670, -1, -1, -1}, {47671, -1, -1, -1}, {47674, -1, -1, -1}, {47675, -1, -1, -1}, {47677, -1, -1, -1}, {47678, -1, -1, -1}, {47679, -1, -1, -1}, {47681, -1, -1, -1}, {47683, -1, -1, -1}, {47684, -1, -1, -1}, {47685, -1, -1, -1}, {47686, -1, -1, -1}, {47687, -1, -1, -1}, {47690, -1, -1, -1}, {47692, -1, -1, -1}, {47695, -1, -1, -1}, {47696, -1, -1, -1}, {47697, -1, -1, -1}, {47698, -1, -1, -1}, {47702, -1, -1, -1}, {47703, -1, -1, -1}, {47705, -1, -1, -1}, {47706, -1, -1, -1}, {47707, -1, -1, -1}, {47709, -1, -1, -1}, {47710, -1, -1, -1}, {47711, -1, -1, -1}, {47712, -1, -1, -1}, {47713, -1, -1, -1}, {47714, -1, -1, -1}, {47715, -1, -1, -1}, {47718, -1, -1, -1}, {47722, -1, -1, -1}, {47723, -1, -1, -1}, {47724, -1, -1, -1}, {47725, -1, -1, -1}, {47726, -1, -1, -1}, {47727, -1, -1, -1}, {47730, -1, -1, -1}, {47731, -1, -1, -1}, {47733, -1, -1, -1}, {47734, -1, -1, -1}, {47735, -1, -1, -1}, {47737, -1, -1, -1}, {47738, -1, -1, -1}, {47739, -1, -1, -1}, {47740, -1, -1, -1}, {47741, -1, -1, -1}, {47742, -1, -1, -1}, {47743, -1, -1, -1}, {47744, -1, -1, -1}, {47745, -1, -1, -1}, {47746, -1, -1, -1}, {47750, -1, -1, -1}, {47752, -1, -1, -1}, {47753, -1, -1, -1}, {47754, -1, -1, -1}, {47755, -1, -1, -1}, {47757, -1, -1, -1}, {47758, -1, -1, -1}, {47759, -1, -1, -1}, {47760, -1, -1, -1}, {47761, -1, -1, -1}, {47762, -1, -1, -1}, {47763, -1, -1, -1}, {47764, -1, -1, -1}, {47765, -1, -1, -1}, {47766, -1, -1, -1}, {47767, -1, -1, -1}, {47768, -1, -1, -1}, {47769, -1, -1, -1}, {47770, -1, -1, -1}, {47771, -1, -1, -1}, {47772, -1, -1, -1}, {47773, -1, -1, -1}, {47774, -1, -1, -1}, {47775, -1, -1, -1}, {47776, -1, -1, -1}, {47777, -1, -1, -1}, {47778, -1, -1, -1}, {47779, -1, -1, -1}, {47780, -1, -1, -1}, {47781, -1, -1, -1}, {47782, -1, -1, -1}, {47783, -1, -1, -1}, {47786, -1, -1, -1}, {47789, -1, -1, -1}, {47790, -1, -1, -1}, {47791, -1, -1, -1}, {47793, -1, -1, -1}, {47795, -1, -1, -1}, {47796, -1, -1, -1}, {47797, -1, -1, -1}, {47798, -1, -1, -1}, {47799, -1, -1, -1}, {47802, -1, -1, -1}, {47804, -1, -1, -1}, {47806, -1, -1, -1}, {47807, -1, -1, -1}, {47808, -1, -1, -1}, {47809, -1, -1, -1}, {47810, -1, -1, -1}, {47811, -1, -1, -1}, {47813, -1, -1, -1}, {47814, -1, -1, -1}, {47815, -1, -1, -1}, {47817, -1, -1, -1}, {47818, -1, -1, -1}, {47819, -1, -1, -1}, {47820, -1, -1, -1}, {47821, -1, -1, -1}, {47822, -1, -1, -1}, {47823, -1, -1, -1}, {47824, -1, -1, -1}, {47825, -1, -1, -1}, {47826, -1, -1, -1}, {47827, -1, -1, -1}, {47828, -1, -1, -1}, {47829, -1, -1, -1} },
+ {{47830, -1, -1, -1}, {47831, -1, -1, -1}, {47834, -1, -1, -1}, {47835, -1, -1, -1}, {47836, -1, -1, -1}, {47837, -1, -1, -1}, {47838, -1, -1, -1}, {47839, -1, -1, -1}, {47840, -1, -1, -1}, {47841, -1, -1, -1}, {47842, -1, -1, -1}, {47843, -1, -1, -1}, {47844, -1, -1, -1}, {47845, -1, -1, -1}, {47846, -1, -1, -1}, {47847, -1, -1, -1}, {47848, -1, -1, -1}, {47849, -1, -1, -1}, {47850, -1, -1, -1}, {47851, -1, -1, -1}, {47852, -1, -1, -1}, {47853, -1, -1, -1}, {47854, -1, -1, -1}, {47855, -1, -1, -1}, {47856, -1, -1, -1}, {47857, -1, -1, -1}, {47858, -1, -1, -1}, {47859, -1, -1, -1}, {47860, -1, -1, -1}, {47861, -1, -1, -1}, {47862, -1, -1, -1}, {47863, -1, -1, -1}, {47864, -1, -1, -1}, {47865, -1, -1, -1}, {47866, -1, -1, -1}, {47867, -1, -1, -1}, {47869, -1, -1, -1}, {47870, -1, -1, -1}, {47871, -1, -1, -1}, {47873, -1, -1, -1}, {47874, -1, -1, -1}, {47875, -1, -1, -1}, {47877, -1, -1, -1}, {47878, -1, -1, -1}, {47879, -1, -1, -1}, {47880, -1, -1, -1}, {47881, -1, -1, -1}, {47882, -1, -1, -1}, {47883, -1, -1, -1}, {47884, -1, -1, -1}, {47886, -1, -1, -1}, {47888, -1, -1, -1}, {47890, -1, -1, -1}, {47891, -1, -1, -1}, {47892, -1, -1, -1}, {47893, -1, -1, -1}, {47894, -1, -1, -1}, {47895, -1, -1, -1}, {47897, -1, -1, -1}, {47898, -1, -1, -1}, {47899, -1, -1, -1}, {47901, -1, -1, -1}, {47902, -1, -1, -1}, {47903, -1, -1, -1}, {47905, -1, -1, -1}, {47906, -1, -1, -1}, {47907, -1, -1, -1}, {47908, -1, -1, -1}, {47909, -1, -1, -1}, {47910, -1, -1, -1}, {47911, -1, -1, -1}, {47912, -1, -1, -1}, {47914, -1, -1, -1}, {47916, -1, -1, -1}, {47917, -1, -1, -1}, {47918, -1, -1, -1}, {47919, -1, -1, -1}, {47920, -1, -1, -1}, {47921, -1, -1, -1}, {47922, -1, -1, -1}, {47923, -1, -1, -1}, {47927, -1, -1, -1}, {47929, -1, -1, -1}, {47930, -1, -1, -1}, {47935, -1, -1, -1}, {47936, -1, -1, -1}, {47937, -1, -1, -1}, {47938, -1, -1, -1}, {47939, -1, -1, -1}, {47942, -1, -1, -1}, {47944, -1, -1, -1}, {47946, -1, -1, -1}, {47947, -1, -1, -1}, {47948, -1, -1, -1}, {47950, -1, -1, -1}, {47953, -1, -1, -1}, {47954, -1, -1, -1}, {47955, -1, -1, -1}, {47957, -1, -1, -1}, {47958, -1, -1, -1}, {47959, -1, -1, -1}, {47961, -1, -1, -1}, {47962, -1, -1, -1}, {47963, -1, -1, -1}, {47964, -1, -1, -1}, {47965, -1, -1, -1}, {47966, -1, -1, -1}, {47967, -1, -1, -1}, {47968, -1, -1, -1}, {47970, -1, -1, -1}, {47972, -1, -1, -1}, {47973, -1, -1, -1}, {47974, -1, -1, -1}, {47975, -1, -1, -1}, {47976, -1, -1, -1}, {47977, -1, -1, -1}, {47978, -1, -1, -1}, {47979, -1, -1, -1}, {47981, -1, -1, -1}, {47982, -1, -1, -1}, {47983, -1, -1, -1}, {47984, -1, -1, -1}, {47985, -1, -1, -1}, {47986, -1, -1, -1}, {47987, -1, -1, -1}, {47988, -1, -1, -1}, {47989, -1, -1, -1}, {47990, -1, -1, -1}, {47991, -1, -1, -1}, {47992, -1, -1, -1}, {47993, -1, -1, -1}, {47994, -1, -1, -1}, {47995, -1, -1, -1}, {47996, -1, -1, -1}, {47997, -1, -1, -1}, {47998, -1, -1, -1}, {47999, -1, -1, -1}, {48000, -1, -1, -1}, {48001, -1, -1, -1}, {48002, -1, -1, -1}, {48003, -1, -1, -1}, {48004, -1, -1, -1}, {48005, -1, -1, -1}, {48006, -1, -1, -1}, {48007, -1, -1, -1}, {48009, -1, -1, -1}, {48010, -1, -1, -1}, {48011, -1, -1, -1}, {48013, -1, -1, -1}, {48014, -1, -1, -1}, {48015, -1, -1, -1}, {48017, -1, -1, -1}, {48018, -1, -1, -1}, {48019, -1, -1, -1}, {48020, -1, -1, -1}, {48021, -1, -1, -1}, {48022, -1, -1, -1}, {48023, -1, -1, -1}, {48024, -1, -1, -1}, {48025, -1, -1, -1}, {48026, -1, -1, -1}, {48027, -1, -1, -1}, {48028, -1, -1, -1}, {48029, -1, -1, -1}, {48030, -1, -1, -1}, {48031, -1, -1, -1}, {48032, -1, -1, -1}, {48033, -1, -1, -1}, {48034, -1, -1, -1}, {48035, -1, -1, -1}, {48037, -1, -1, -1}, {48038, -1, -1, -1}, {48039, -1, -1, -1}, {48041, -1, -1, -1}, {48042, -1, -1, -1}, {48043, -1, -1, -1}, {48045, -1, -1, -1}, {48046, -1, -1, -1}, {48047, -1, -1, -1}, {48048, -1, -1, -1}, {48049, -1, -1, -1}, {48050, -1, -1, -1}, {48051, -1, -1, -1}, {48053, -1, -1, -1}, {48054, -1, -1, -1}, {48056, -1, -1, -1}, {48057, -1, -1, -1}, {48058, -1, -1, -1}, {48059, -1, -1, -1}, {48060, -1, -1, -1}, {48061, -1, -1, -1}, {48062, -1, -1, -1}, {48063, -1, -1, -1}, {48065, -1, -1, -1}, {48066, -1, -1, -1}, {48067, -1, -1, -1}, {48069, -1, -1, -1}, {48070, -1, -1, -1}, {48071, -1, -1, -1}, {48073, -1, -1, -1}, {48074, -1, -1, -1}, {48075, -1, -1, -1}, {48076, -1, -1, -1}, {48077, -1, -1, -1}, {48078, -1, -1, -1}, {48079, -1, -1, -1}, {48081, -1, -1, -1}, {48082, -1, -1, -1}, {48084, -1, -1, -1}, {48085, -1, -1, -1}, {48086, -1, -1, -1}, {48087, -1, -1, -1}, {48088, -1, -1, -1}, {48089, -1, -1, -1}, {48090, -1, -1, -1}, {48091, -1, -1, -1}, {48092, -1, -1, -1}, {48093, -1, -1, -1}, {48094, -1, -1, -1}, {48095, -1, -1, -1}, {48096, -1, -1, -1}, {48097, -1, -1, -1}, {48098, -1, -1, -1}, {48099, -1, -1, -1}, {48100, -1, -1, -1}, {48101, -1, -1, -1}, {48102, -1, -1, -1}, {48103, -1, -1, -1}, {48104, -1, -1, -1}, {48105, -1, -1, -1}, {48106, -1, -1, -1}, {48107, -1, -1, -1}, {48108, -1, -1, -1}, {48109, -1, -1, -1}, {48110, -1, -1, -1}, {48111, -1, -1, -1}, {48112, -1, -1, -1}, {48113, -1, -1, -1}, {48114, -1, -1, -1}, {48115, -1, -1, -1}, {48116, -1, -1, -1}, {48117, -1, -1, -1}, {48118, -1, -1, -1}, {48119, -1, -1, -1}, {48122, -1, -1, -1}, {48123, -1, -1, -1}, {48125, -1, -1, -1}, {48126, -1, -1, -1}, {48129, -1, -1, -1}, {48131, -1, -1, -1}, {48132, -1, -1, -1}, {48133, -1, -1, -1}, {48134, -1, -1, -1}, {48135, -1, -1, -1}, {48138, -1, -1, -1}, {48142, -1, -1, -1} },
+ {{48144, -1, -1, -1}, {48146, -1, -1, -1}, {48147, -1, -1, -1}, {48153, -1, -1, -1}, {48154, -1, -1, -1}, {48160, -1, -1, -1}, {48161, -1, -1, -1}, {48162, -1, -1, -1}, {48163, -1, -1, -1}, {48166, -1, -1, -1}, {48168, -1, -1, -1}, {48170, -1, -1, -1}, {48171, -1, -1, -1}, {48172, -1, -1, -1}, {48174, -1, -1, -1}, {48175, -1, -1, -1}, {48178, -1, -1, -1}, {48179, -1, -1, -1}, {48181, -1, -1, -1}, {48182, -1, -1, -1}, {48183, -1, -1, -1}, {48185, -1, -1, -1}, {48186, -1, -1, -1}, {48187, -1, -1, -1}, {48188, -1, -1, -1}, {48189, -1, -1, -1}, {48190, -1, -1, -1}, {48191, -1, -1, -1}, {48194, -1, -1, -1}, {48198, -1, -1, -1}, {48199, -1, -1, -1}, {48200, -1, -1, -1}, {48202, -1, -1, -1}, {48203, -1, -1, -1}, {48206, -1, -1, -1}, {48207, -1, -1, -1}, {48209, -1, -1, -1}, {48210, -1, -1, -1}, {48211, -1, -1, -1}, {48212, -1, -1, -1}, {48213, -1, -1, -1}, {48214, -1, -1, -1}, {48215, -1, -1, -1}, {48216, -1, -1, -1}, {48217, -1, -1, -1}, {48218, -1, -1, -1}, {48219, -1, -1, -1}, {48220, -1, -1, -1}, {48222, -1, -1, -1}, {48223, -1, -1, -1}, {48224, -1, -1, -1}, {48225, -1, -1, -1}, {48226, -1, -1, -1}, {48227, -1, -1, -1}, {48228, -1, -1, -1}, {48229, -1, -1, -1}, {48230, -1, -1, -1}, {48231, -1, -1, -1}, {48232, -1, -1, -1}, {48233, -1, -1, -1}, {48234, -1, -1, -1}, {48235, -1, -1, -1}, {48236, -1, -1, -1}, {48237, -1, -1, -1}, {48238, -1, -1, -1}, {48239, -1, -1, -1}, {48240, -1, -1, -1}, {48241, -1, -1, -1}, {48242, -1, -1, -1}, {48243, -1, -1, -1}, {48244, -1, -1, -1}, {48245, -1, -1, -1}, {48246, -1, -1, -1}, {48247, -1, -1, -1}, {48248, -1, -1, -1}, {48249, -1, -1, -1}, {48250, -1, -1, -1}, {48251, -1, -1, -1}, {48252, -1, -1, -1}, {48253, -1, -1, -1}, {48254, -1, -1, -1}, {48255, -1, -1, -1}, {48256, -1, -1, -1}, {48257, -1, -1, -1}, {48258, -1, -1, -1}, {48259, -1, -1, -1}, {48262, -1, -1, -1}, {48263, -1, -1, -1}, {48265, -1, -1, -1}, {48266, -1, -1, -1}, {48269, -1, -1, -1}, {48271, -1, -1, -1}, {48272, -1, -1, -1}, {48273, -1, -1, -1}, {48274, -1, -1, -1}, {48275, -1, -1, -1}, {48278, -1, -1, -1}, {48280, -1, -1, -1}, {48283, -1, -1, -1}, {48284, -1, -1, -1}, {48285, -1, -1, -1}, {48286, -1, -1, -1}, {48287, -1, -1, -1}, {48290, -1, -1, -1}, {48291, -1, -1, -1}, {48293, -1, -1, -1}, {48294, -1, -1, -1}, {48297, -1, -1, -1}, {48298, -1, -1, -1}, {48299, -1, -1, -1}, {48300, -1, -1, -1}, {48301, -1, -1, -1}, {48302, -1, -1, -1}, {48303, -1, -1, -1}, {48306, -1, -1, -1}, {48310, -1, -1, -1}, {48311, -1, -1, -1}, {48312, -1, -1, -1}, {48313, -1, -1, -1}, {48314, -1, -1, -1}, {48315, -1, -1, -1}, {48318, -1, -1, -1}, {48319, -1, -1, -1}, {48321, -1, -1, -1}, {48322, -1, -1, -1}, {48323, -1, -1, -1}, {48325, -1, -1, -1}, {48326, -1, -1, -1}, {48327, -1, -1, -1}, {48328, -1, -1, -1}, {48329, -1, -1, -1}, {48330, -1, -1, -1}, {48331, -1, -1, -1}, {48332, -1, -1, -1}, {48334, -1, -1, -1}, {48338, -1, -1, -1}, {48339, -1, -1, -1}, {48340, -1, -1, -1}, {48342, -1, -1, -1}, {48343, -1, -1, -1}, {48345, -1, -1, -1}, {48346, -1, -1, -1}, {48347, -1, -1, -1}, {48349, -1, -1, -1}, {48350, -1, -1, -1}, {48351, -1, -1, -1}, {48352, -1, -1, -1}, {48353, -1, -1, -1}, {48354, -1, -1, -1}, {48355, -1, -1, -1}, {48356, -1, -1, -1}, {48357, -1, -1, -1}, {48358, -1, -1, -1}, {48359, -1, -1, -1}, {48360, -1, -1, -1}, {48361, -1, -1, -1}, {48362, -1, -1, -1}, {48363, -1, -1, -1}, {48364, -1, -1, -1}, {48365, -1, -1, -1}, {48366, -1, -1, -1}, {48367, -1, -1, -1}, {48368, -1, -1, -1}, {48369, -1, -1, -1}, {48370, -1, -1, -1}, {48371, -1, -1, -1}, {48375, -1, -1, -1}, {48377, -1, -1, -1}, {48378, -1, -1, -1}, {48379, -1, -1, -1}, {48381, -1, -1, -1}, {48382, -1, -1, -1}, {48383, -1, -1, -1}, {48384, -1, -1, -1}, {48385, -1, -1, -1}, {48386, -1, -1, -1}, {48387, -1, -1, -1}, {48390, -1, -1, -1}, {48392, -1, -1, -1}, {48394, -1, -1, -1}, {48395, -1, -1, -1}, {48396, -1, -1, -1}, {48397, -1, -1, -1}, {48398, -1, -1, -1}, {48399, -1, -1, -1}, {48401, -1, -1, -1}, {48402, -1, -1, -1}, {48403, -1, -1, -1}, {48405, -1, -1, -1}, {48406, -1, -1, -1}, {48407, -1, -1, -1}, {48408, -1, -1, -1}, {48409, -1, -1, -1}, {48410, -1, -1, -1}, {48411, -1, -1, -1}, {48412, -1, -1, -1}, {48413, -1, -1, -1}, {48414, -1, -1, -1}, {48415, -1, -1, -1}, {48416, -1, -1, -1}, {48417, -1, -1, -1}, {48418, -1, -1, -1}, {48419, -1, -1, -1}, {48421, -1, -1, -1}, {48422, -1, -1, -1}, {48423, -1, -1, -1}, {48424, -1, -1, -1}, {48425, -1, -1, -1}, {48426, -1, -1, -1}, {48427, -1, -1, -1}, {48429, -1, -1, -1}, {48430, -1, -1, -1}, {48431, -1, -1, -1}, {48432, -1, -1, -1}, {48433, -1, -1, -1}, {48434, -1, -1, -1}, {48435, -1, -1, -1}, {48436, -1, -1, -1}, {48437, -1, -1, -1}, {48438, -1, -1, -1}, {48439, -1, -1, -1}, {48440, -1, -1, -1}, {48441, -1, -1, -1}, {48442, -1, -1, -1}, {48443, -1, -1, -1}, {48444, -1, -1, -1}, {48445, -1, -1, -1}, {48446, -1, -1, -1}, {48447, -1, -1, -1}, {48449, -1, -1, -1}, {48450, -1, -1, -1}, {48451, -1, -1, -1}, {48452, -1, -1, -1}, {48453, -1, -1, -1}, {48454, -1, -1, -1}, {48455, -1, -1, -1}, {48458, -1, -1, -1}, {48459, -1, -1, -1}, {48461, -1, -1, -1}, {48462, -1, -1, -1}, {48463, -1, -1, -1}, {48465, -1, -1, -1}, {48466, -1, -1, -1}, {48467, -1, -1, -1}, {48468, -1, -1, -1}, {48469, -1, -1, -1}, {48470, -1, -1, -1}, {48471, -1, -1, -1}, {48474, -1, -1, -1}, {48475, -1, -1, -1}, {48476, -1, -1, -1}, {48477, -1, -1, -1}, {48478, -1, -1, -1}, {48479, -1, -1, -1}, {48480, -1, -1, -1}, {48481, -1, -1, -1} },
+ {{48482, -1, -1, -1}, {48483, -1, -1, -1}, {48485, -1, -1, -1}, {48486, -1, -1, -1}, {48487, -1, -1, -1}, {48489, -1, -1, -1}, {48490, -1, -1, -1}, {48491, -1, -1, -1}, {48492, -1, -1, -1}, {48493, -1, -1, -1}, {48494, -1, -1, -1}, {48495, -1, -1, -1}, {48496, -1, -1, -1}, {48497, -1, -1, -1}, {48498, -1, -1, -1}, {48499, -1, -1, -1}, {48500, -1, -1, -1}, {48501, -1, -1, -1}, {48502, -1, -1, -1}, {48503, -1, -1, -1}, {48504, -1, -1, -1}, {48505, -1, -1, -1}, {48506, -1, -1, -1}, {48507, -1, -1, -1}, {48508, -1, -1, -1}, {48509, -1, -1, -1}, {48510, -1, -1, -1}, {48511, -1, -1, -1}, {48514, -1, -1, -1}, {48515, -1, -1, -1}, {48517, -1, -1, -1}, {48518, -1, -1, -1}, {48523, -1, -1, -1}, {48524, -1, -1, -1}, {48525, -1, -1, -1}, {48526, -1, -1, -1}, {48527, -1, -1, -1}, {48530, -1, -1, -1}, {48532, -1, -1, -1}, {48534, -1, -1, -1}, {48535, -1, -1, -1}, {48536, -1, -1, -1}, {48539, -1, -1, -1}, {48541, -1, -1, -1}, {48542, -1, -1, -1}, {48543, -1, -1, -1}, {48544, -1, -1, -1}, {48545, -1, -1, -1}, {48546, -1, -1, -1}, {48547, -1, -1, -1}, {48549, -1, -1, -1}, {48550, -1, -1, -1}, {48551, -1, -1, -1}, {48552, -1, -1, -1}, {48553, -1, -1, -1}, {48554, -1, -1, -1}, {48555, -1, -1, -1}, {48556, -1, -1, -1}, {48557, -1, -1, -1}, {48558, -1, -1, -1}, {48559, -1, -1, -1}, {48561, -1, -1, -1}, {48562, -1, -1, -1}, {48563, -1, -1, -1}, {48564, -1, -1, -1}, {48565, -1, -1, -1}, {48566, -1, -1, -1}, {48567, -1, -1, -1}, {48569, -1, -1, -1}, {48570, -1, -1, -1}, {48571, -1, -1, -1}, {48572, -1, -1, -1}, {48573, -1, -1, -1}, {48574, -1, -1, -1}, {48575, -1, -1, -1}, {48576, -1, -1, -1}, {48577, -1, -1, -1}, {48578, -1, -1, -1}, {48579, -1, -1, -1}, {48580, -1, -1, -1}, {48581, -1, -1, -1}, {48582, -1, -1, -1}, {48583, -1, -1, -1}, {48584, -1, -1, -1}, {48585, -1, -1, -1}, {48586, -1, -1, -1}, {48587, -1, -1, -1}, {48588, -1, -1, -1}, {48589, -1, -1, -1}, {48590, -1, -1, -1}, {48591, -1, -1, -1}, {48592, -1, -1, -1}, {48593, -1, -1, -1}, {48594, -1, -1, -1}, {48595, -1, -1, -1}, {48598, -1, -1, -1}, {48599, -1, -1, -1}, {48601, -1, -1, -1}, {48602, -1, -1, -1}, {48603, -1, -1, -1}, {48605, -1, -1, -1}, {48606, -1, -1, -1}, {48607, -1, -1, -1}, {48608, -1, -1, -1}, {48609, -1, -1, -1}, {48610, -1, -1, -1}, {48611, -1, -1, -1}, {48612, -1, -1, -1}, {48613, -1, -1, -1}, {48614, -1, -1, -1}, {48615, -1, -1, -1}, {48616, -1, -1, -1}, {48618, -1, -1, -1}, {48619, -1, -1, -1}, {48620, -1, -1, -1}, {48621, -1, -1, -1}, {48622, -1, -1, -1}, {48623, -1, -1, -1}, {48625, -1, -1, -1}, {48626, -1, -1, -1}, {48627, -1, -1, -1}, {48629, -1, -1, -1}, {48630, -1, -1, -1}, {48631, -1, -1, -1}, {48633, -1, -1, -1}, {48634, -1, -1, -1}, {48635, -1, -1, -1}, {48636, -1, -1, -1}, {48637, -1, -1, -1}, {48638, -1, -1, -1}, {48639, -1, -1, -1}, {48641, -1, -1, -1}, {48642, -1, -1, -1}, {48644, -1, -1, -1}, {48646, -1, -1, -1}, {48647, -1, -1, -1}, {48648, -1, -1, -1}, {48649, -1, -1, -1}, {48650, -1, -1, -1}, {48651, -1, -1, -1}, {48654, -1, -1, -1}, {48655, -1, -1, -1}, {48657, -1, -1, -1}, {48658, -1, -1, -1}, {48659, -1, -1, -1}, {48661, -1, -1, -1}, {48662, -1, -1, -1}, {48663, -1, -1, -1}, {48664, -1, -1, -1}, {48665, -1, -1, -1}, {48666, -1, -1, -1}, {48667, -1, -1, -1}, {48670, -1, -1, -1}, {48672, -1, -1, -1}, {48673, -1, -1, -1}, {48674, -1, -1, -1}, {48675, -1, -1, -1}, {48676, -1, -1, -1}, {48677, -1, -1, -1}, {48678, -1, -1, -1}, {48679, -1, -1, -1}, {48680, -1, -1, -1}, {48681, -1, -1, -1}, {48682, -1, -1, -1}, {48683, -1, -1, -1}, {48684, -1, -1, -1}, {48685, -1, -1, -1}, {48686, -1, -1, -1}, {48687, -1, -1, -1}, {48688, -1, -1, -1}, {48689, -1, -1, -1}, {48690, -1, -1, -1}, {48691, -1, -1, -1}, {48692, -1, -1, -1}, {48693, -1, -1, -1}, {48694, -1, -1, -1}, {48695, -1, -1, -1}, {48696, -1, -1, -1}, {48697, -1, -1, -1}, {48698, -1, -1, -1}, {48699, -1, -1, -1}, {48700, -1, -1, -1}, {48701, -1, -1, -1}, {48702, -1, -1, -1}, {48703, -1, -1, -1}, {48704, -1, -1, -1}, {48705, -1, -1, -1}, {48706, -1, -1, -1}, {48707, -1, -1, -1}, {48710, -1, -1, -1}, {48711, -1, -1, -1}, {48713, -1, -1, -1}, {48714, -1, -1, -1}, {48715, -1, -1, -1}, {48717, -1, -1, -1}, {48719, -1, -1, -1}, {48720, -1, -1, -1}, {48721, -1, -1, -1}, {48722, -1, -1, -1}, {48723, -1, -1, -1}, {48726, -1, -1, -1}, {48728, -1, -1, -1}, {48732, -1, -1, -1}, {48733, -1, -1, -1}, {48734, -1, -1, -1}, {48735, -1, -1, -1}, {48738, -1, -1, -1}, {48739, -1, -1, -1}, {48741, -1, -1, -1}, {48742, -1, -1, -1}, {48743, -1, -1, -1}, {48745, -1, -1, -1}, {48747, -1, -1, -1}, {48748, -1, -1, -1}, {48749, -1, -1, -1}, {48750, -1, -1, -1}, {48751, -1, -1, -1}, {48754, -1, -1, -1}, {48758, -1, -1, -1}, {48759, -1, -1, -1}, {48760, -1, -1, -1}, {48761, -1, -1, -1}, {48762, -1, -1, -1}, {48766, -1, -1, -1}, {48767, -1, -1, -1}, {48769, -1, -1, -1}, {48770, -1, -1, -1}, {48771, -1, -1, -1}, {48773, -1, -1, -1}, {48774, -1, -1, -1}, {48775, -1, -1, -1}, {48776, -1, -1, -1}, {48777, -1, -1, -1}, {48778, -1, -1, -1}, {48779, -1, -1, -1}, {48782, -1, -1, -1}, {48786, -1, -1, -1}, {48787, -1, -1, -1}, {48788, -1, -1, -1}, {48789, -1, -1, -1}, {48790, -1, -1, -1}, {48791, -1, -1, -1}, {48794, -1, -1, -1}, {48795, -1, -1, -1}, {48796, -1, -1, -1}, {48797, -1, -1, -1}, {48798, -1, -1, -1}, {48799, -1, -1, -1}, {48800, -1, -1, -1}, {48801, -1, -1, -1}, {48802, -1, -1, -1}, {48803, -1, -1, -1}, {48804, -1, -1, -1}, {48805, -1, -1, -1}, {48806, -1, -1, -1}, {48807, -1, -1, -1} },
+ {{48809, -1, -1, -1}, {48810, -1, -1, -1}, {48811, -1, -1, -1}, {48812, -1, -1, -1}, {48813, -1, -1, -1}, {48814, -1, -1, -1}, {48815, -1, -1, -1}, {48816, -1, -1, -1}, {48817, -1, -1, -1}, {48818, -1, -1, -1}, {48819, -1, -1, -1}, {48820, -1, -1, -1}, {48821, -1, -1, -1}, {48822, -1, -1, -1}, {48823, -1, -1, -1}, {48824, -1, -1, -1}, {48825, -1, -1, -1}, {48826, -1, -1, -1}, {48827, -1, -1, -1}, {48828, -1, -1, -1}, {48829, -1, -1, -1}, {48830, -1, -1, -1}, {48831, -1, -1, -1}, {48832, -1, -1, -1}, {48833, -1, -1, -1}, {48834, -1, -1, -1}, {48835, -1, -1, -1}, {48836, -1, -1, -1}, {48837, -1, -1, -1}, {48838, -1, -1, -1}, {48839, -1, -1, -1}, {48840, -1, -1, -1}, {48841, -1, -1, -1}, {48842, -1, -1, -1}, {48843, -1, -1, -1}, {48844, -1, -1, -1}, {48845, -1, -1, -1}, {48846, -1, -1, -1}, {48847, -1, -1, -1}, {48850, -1, -1, -1}, {48851, -1, -1, -1}, {48853, -1, -1, -1}, {48854, -1, -1, -1}, {48857, -1, -1, -1}, {48858, -1, -1, -1}, {48859, -1, -1, -1}, {48860, -1, -1, -1}, {48861, -1, -1, -1}, {48862, -1, -1, -1}, {48863, -1, -1, -1}, {48865, -1, -1, -1}, {48866, -1, -1, -1}, {48870, -1, -1, -1}, {48871, -1, -1, -1}, {48872, -1, -1, -1}, {48873, -1, -1, -1}, {48874, -1, -1, -1}, {48875, -1, -1, -1}, {48877, -1, -1, -1}, {48878, -1, -1, -1}, {48879, -1, -1, -1}, {48880, -1, -1, -1}, {48881, -1, -1, -1}, {48882, -1, -1, -1}, {48883, -1, -1, -1}, {48884, -1, -1, -1}, {48885, -1, -1, -1}, {48886, -1, -1, -1}, {48887, -1, -1, -1}, {48888, -1, -1, -1}, {48889, -1, -1, -1}, {48890, -1, -1, -1}, {48891, -1, -1, -1}, {48892, -1, -1, -1}, {48893, -1, -1, -1}, {48894, -1, -1, -1}, {48895, -1, -1, -1}, {48896, -1, -1, -1}, {48898, -1, -1, -1}, {48899, -1, -1, -1}, {48900, -1, -1, -1}, {48901, -1, -1, -1}, {48902, -1, -1, -1}, {48903, -1, -1, -1}, {48906, -1, -1, -1}, {48907, -1, -1, -1}, {48908, -1, -1, -1}, {48909, -1, -1, -1}, {48910, -1, -1, -1}, {48911, -1, -1, -1}, {48912, -1, -1, -1}, {48913, -1, -1, -1}, {48914, -1, -1, -1}, {48915, -1, -1, -1}, {48916, -1, -1, -1}, {48917, -1, -1, -1}, {48918, -1, -1, -1}, {48919, -1, -1, -1}, {48922, -1, -1, -1}, {48926, -1, -1, -1}, {48927, -1, -1, -1}, {48928, -1, -1, -1}, {48929, -1, -1, -1}, {48930, -1, -1, -1}, {48931, -1, -1, -1}, {48932, -1, -1, -1}, {48933, -1, -1, -1}, {48934, -1, -1, -1}, {48935, -1, -1, -1}, {48936, -1, -1, -1}, {48937, -1, -1, -1}, {48938, -1, -1, -1}, {48939, -1, -1, -1}, {48940, -1, -1, -1}, {48941, -1, -1, -1}, {48942, -1, -1, -1}, {48943, -1, -1, -1}, {48944, -1, -1, -1}, {48945, -1, -1, -1}, {48946, -1, -1, -1}, {48947, -1, -1, -1}, {48948, -1, -1, -1}, {48949, -1, -1, -1}, {48950, -1, -1, -1}, {48951, -1, -1, -1}, {48952, -1, -1, -1}, {48953, -1, -1, -1}, {48954, -1, -1, -1}, {48955, -1, -1, -1}, {48956, -1, -1, -1}, {48957, -1, -1, -1}, {48958, -1, -1, -1}, {48959, -1, -1, -1}, {48962, -1, -1, -1}, {48963, -1, -1, -1}, {48965, -1, -1, -1}, {48966, -1, -1, -1}, {48967, -1, -1, -1}, {48969, -1, -1, -1}, {48970, -1, -1, -1}, {48971, -1, -1, -1}, {48972, -1, -1, -1}, {48973, -1, -1, -1}, {48974, -1, -1, -1}, {48975, -1, -1, -1}, {48978, -1, -1, -1}, {48979, -1, -1, -1}, {48980, -1, -1, -1}, {48982, -1, -1, -1}, {48983, -1, -1, -1}, {48984, -1, -1, -1}, {48985, -1, -1, -1}, {48986, -1, -1, -1}, {48987, -1, -1, -1}, {48988, -1, -1, -1}, {48989, -1, -1, -1}, {48990, -1, -1, -1}, {48991, -1, -1, -1}, {48992, -1, -1, -1}, {48993, -1, -1, -1}, {48994, -1, -1, -1}, {48995, -1, -1, -1}, {48996, -1, -1, -1}, {48997, -1, -1, -1}, {48998, -1, -1, -1}, {48999, -1, -1, -1}, {49000, -1, -1, -1}, {49001, -1, -1, -1}, {49002, -1, -1, -1}, {49003, -1, -1, -1}, {49004, -1, -1, -1}, {49005, -1, -1, -1}, {49006, -1, -1, -1}, {49007, -1, -1, -1}, {49008, -1, -1, -1}, {49009, -1, -1, -1}, {49010, -1, -1, -1}, {49011, -1, -1, -1}, {49012, -1, -1, -1}, {49013, -1, -1, -1}, {49014, -1, -1, -1}, {49015, -1, -1, -1}, {49016, -1, -1, -1}, {49017, -1, -1, -1}, {49018, -1, -1, -1}, {49019, -1, -1, -1}, {49020, -1, -1, -1}, {49021, -1, -1, -1}, {49022, -1, -1, -1}, {49023, -1, -1, -1}, {49024, -1, -1, -1}, {49025, -1, -1, -1}, {49026, -1, -1, -1}, {49027, -1, -1, -1}, {49028, -1, -1, -1}, {49029, -1, -1, -1}, {49030, -1, -1, -1}, {49031, -1, -1, -1}, {49032, -1, -1, -1}, {49033, -1, -1, -1}, {49034, -1, -1, -1}, {49035, -1, -1, -1}, {49036, -1, -1, -1}, {49037, -1, -1, -1}, {49038, -1, -1, -1}, {49039, -1, -1, -1}, {49040, -1, -1, -1}, {49041, -1, -1, -1}, {49042, -1, -1, -1}, {49043, -1, -1, -1}, {49045, -1, -1, -1}, {49046, -1, -1, -1}, {49047, -1, -1, -1}, {49048, -1, -1, -1}, {49049, -1, -1, -1}, {49050, -1, -1, -1}, {49051, -1, -1, -1}, {49052, -1, -1, -1}, {49053, -1, -1, -1}, {49054, -1, -1, -1}, {49055, -1, -1, -1}, {49056, -1, -1, -1}, {49057, -1, -1, -1}, {49058, -1, -1, -1}, {49059, -1, -1, -1}, {49060, -1, -1, -1}, {49061, -1, -1, -1}, {49062, -1, -1, -1}, {49063, -1, -1, -1}, {49064, -1, -1, -1}, {49065, -1, -1, -1}, {49066, -1, -1, -1}, {49067, -1, -1, -1}, {49068, -1, -1, -1}, {49069, -1, -1, -1}, {49070, -1, -1, -1}, {49071, -1, -1, -1}, {49073, -1, -1, -1}, {49074, -1, -1, -1}, {49075, -1, -1, -1}, {49076, -1, -1, -1}, {49077, -1, -1, -1}, {49078, -1, -1, -1}, {49079, -1, -1, -1}, {49080, -1, -1, -1}, {49081, -1, -1, -1}, {49082, -1, -1, -1}, {49083, -1, -1, -1}, {49084, -1, -1, -1}, {49085, -1, -1, -1}, {49086, -1, -1, -1}, {49087, -1, -1, -1}, {49088, -1, -1, -1}, {49089, -1, -1, -1}, {49090, -1, -1, -1}, {49091, -1, -1, -1} },
+ {{49092, -1, -1, -1}, {49094, -1, -1, -1}, {49095, -1, -1, -1}, {49096, -1, -1, -1}, {49097, -1, -1, -1}, {49098, -1, -1, -1}, {49099, -1, -1, -1}, {49102, -1, -1, -1}, {49103, -1, -1, -1}, {49105, -1, -1, -1}, {49106, -1, -1, -1}, {49107, -1, -1, -1}, {49109, -1, -1, -1}, {49110, -1, -1, -1}, {49111, -1, -1, -1}, {49112, -1, -1, -1}, {49113, -1, -1, -1}, {49114, -1, -1, -1}, {49115, -1, -1, -1}, {49117, -1, -1, -1}, {49118, -1, -1, -1}, {49120, -1, -1, -1}, {49122, -1, -1, -1}, {49123, -1, -1, -1}, {49124, -1, -1, -1}, {49125, -1, -1, -1}, {49126, -1, -1, -1}, {49127, -1, -1, -1}, {49128, -1, -1, -1}, {49129, -1, -1, -1}, {49130, -1, -1, -1}, {49131, -1, -1, -1}, {49132, -1, -1, -1}, {49133, -1, -1, -1}, {49134, -1, -1, -1}, {49135, -1, -1, -1}, {49136, -1, -1, -1}, {49137, -1, -1, -1}, {49138, -1, -1, -1}, {49139, -1, -1, -1}, {49140, -1, -1, -1}, {49141, -1, -1, -1}, {49142, -1, -1, -1}, {49143, -1, -1, -1}, {49144, -1, -1, -1}, {49145, -1, -1, -1}, {49146, -1, -1, -1}, {49147, -1, -1, -1}, {49148, -1, -1, -1}, {49149, -1, -1, -1}, {49150, -1, -1, -1}, {49151, -1, -1, -1}, {49152, -1, -1, -1}, {49153, -1, -1, -1}, {49154, -1, -1, -1}, {49155, -1, -1, -1}, {49156, -1, -1, -1}, {49157, -1, -1, -1}, {49158, -1, -1, -1}, {49159, -1, -1, -1}, {49160, -1, -1, -1}, {49161, -1, -1, -1}, {49162, -1, -1, -1}, {49163, -1, -1, -1}, {49164, -1, -1, -1}, {49165, -1, -1, -1}, {49166, -1, -1, -1}, {49167, -1, -1, -1}, {49168, -1, -1, -1}, {49169, -1, -1, -1}, {49170, -1, -1, -1}, {49171, -1, -1, -1}, {49172, -1, -1, -1}, {49173, -1, -1, -1}, {49174, -1, -1, -1}, {49175, -1, -1, -1}, {49176, -1, -1, -1}, {49177, -1, -1, -1}, {49178, -1, -1, -1}, {49179, -1, -1, -1}, {49180, -1, -1, -1}, {49181, -1, -1, -1}, {49182, -1, -1, -1}, {49183, -1, -1, -1}, {49184, -1, -1, -1}, {49185, -1, -1, -1}, {49186, -1, -1, -1}, {49187, -1, -1, -1}, {49188, -1, -1, -1}, {49189, -1, -1, -1}, {49190, -1, -1, -1}, {49191, -1, -1, -1}, {49192, -1, -1, -1}, {49193, -1, -1, -1}, {49194, -1, -1, -1}, {49195, -1, -1, -1}, {49196, -1, -1, -1}, {49197, -1, -1, -1}, {49198, -1, -1, -1}, {49199, -1, -1, -1}, {49200, -1, -1, -1}, {49201, -1, -1, -1}, {49202, -1, -1, -1}, {49203, -1, -1, -1}, {49204, -1, -1, -1}, {49205, -1, -1, -1}, {49206, -1, -1, -1}, {49207, -1, -1, -1}, {49208, -1, -1, -1}, {49209, -1, -1, -1}, {49210, -1, -1, -1}, {49211, -1, -1, -1}, {49213, -1, -1, -1}, {49214, -1, -1, -1}, {49215, -1, -1, -1}, {49216, -1, -1, -1}, {49217, -1, -1, -1}, {49218, -1, -1, -1}, {49219, -1, -1, -1}, {49220, -1, -1, -1}, {49221, -1, -1, -1}, {49222, -1, -1, -1}, {49223, -1, -1, -1}, {49224, -1, -1, -1}, {49225, -1, -1, -1}, {49226, -1, -1, -1}, {49227, -1, -1, -1}, {49228, -1, -1, -1}, {49229, -1, -1, -1}, {49230, -1, -1, -1}, {49231, -1, -1, -1}, {49232, -1, -1, -1}, {49234, -1, -1, -1}, {49235, -1, -1, -1}, {49236, -1, -1, -1}, {49237, -1, -1, -1}, {49238, -1, -1, -1}, {49239, -1, -1, -1}, {49241, -1, -1, -1}, {49242, -1, -1, -1}, {49243, -1, -1, -1}, {49245, -1, -1, -1}, {49246, -1, -1, -1}, {49247, -1, -1, -1}, {49249, -1, -1, -1}, {49250, -1, -1, -1}, {49251, -1, -1, -1}, {49252, -1, -1, -1}, {49253, -1, -1, -1}, {49254, -1, -1, -1}, {49255, -1, -1, -1}, {49258, -1, -1, -1}, {49259, -1, -1, -1}, {49260, -1, -1, -1}, {49261, -1, -1, -1}, {49262, -1, -1, -1}, {49263, -1, -1, -1}, {49264, -1, -1, -1}, {49265, -1, -1, -1}, {49266, -1, -1, -1}, {49267, -1, -1, -1}, {49268, -1, -1, -1}, {49269, -1, -1, -1}, {49270, -1, -1, -1}, {49271, -1, -1, -1}, {49272, -1, -1, -1}, {49273, -1, -1, -1}, {49274, -1, -1, -1}, {49275, -1, -1, -1}, {49276, -1, -1, -1}, {49277, -1, -1, -1}, {49278, -1, -1, -1}, {49279, -1, -1, -1}, {49280, -1, -1, -1}, {49281, -1, -1, -1}, {49282, -1, -1, -1}, {49283, -1, -1, -1}, {49284, -1, -1, -1}, {49285, -1, -1, -1}, {49286, -1, -1, -1}, {49287, -1, -1, -1}, {49288, -1, -1, -1}, {49289, -1, -1, -1}, {49290, -1, -1, -1}, {49291, -1, -1, -1}, {49292, -1, -1, -1}, {49293, -1, -1, -1}, {49294, -1, -1, -1}, {49295, -1, -1, -1}, {49298, -1, -1, -1}, {49299, -1, -1, -1}, {49301, -1, -1, -1}, {49302, -1, -1, -1}, {49303, -1, -1, -1}, {49305, -1, -1, -1}, {49306, -1, -1, -1}, {49307, -1, -1, -1}, {49308, -1, -1, -1}, {49309, -1, -1, -1}, {49310, -1, -1, -1}, {49311, -1, -1, -1}, {49314, -1, -1, -1}, {49316, -1, -1, -1}, {49318, -1, -1, -1}, {49319, -1, -1, -1}, {49320, -1, -1, -1}, {49321, -1, -1, -1}, {49322, -1, -1, -1}, {49323, -1, -1, -1}, {49326, -1, -1, -1}, {49329, -1, -1, -1}, {49330, -1, -1, -1}, {49335, -1, -1, -1}, {49336, -1, -1, -1}, {49337, -1, -1, -1}, {49338, -1, -1, -1}, {49339, -1, -1, -1}, {49342, -1, -1, -1}, {49346, -1, -1, -1}, {49347, -1, -1, -1}, {49348, -1, -1, -1}, {49350, -1, -1, -1}, {49351, -1, -1, -1}, {49354, -1, -1, -1}, {49355, -1, -1, -1}, {49357, -1, -1, -1}, {49358, -1, -1, -1}, {49359, -1, -1, -1}, {49361, -1, -1, -1}, {49362, -1, -1, -1}, {49363, -1, -1, -1}, {49364, -1, -1, -1}, {49365, -1, -1, -1}, {49366, -1, -1, -1}, {49367, -1, -1, -1}, {49370, -1, -1, -1}, {49374, -1, -1, -1}, {49375, -1, -1, -1}, {49376, -1, -1, -1}, {49377, -1, -1, -1}, {49378, -1, -1, -1}, {49379, -1, -1, -1}, {49382, -1, -1, -1}, {49383, -1, -1, -1}, {49385, -1, -1, -1}, {49386, -1, -1, -1}, {49387, -1, -1, -1}, {49389, -1, -1, -1}, {49390, -1, -1, -1}, {49391, -1, -1, -1}, {49392, -1, -1, -1}, {49393, -1, -1, -1}, {49394, -1, -1, -1}, {49395, -1, -1, -1}, {49398, -1, -1, -1}, {49400, -1, -1, -1} },
+ {{49402, -1, -1, -1}, {49403, -1, -1, -1}, {49404, -1, -1, -1}, {49405, -1, -1, -1}, {49406, -1, -1, -1}, {49407, -1, -1, -1}, {49409, -1, -1, -1}, {49410, -1, -1, -1}, {49411, -1, -1, -1}, {49413, -1, -1, -1}, {49414, -1, -1, -1}, {49415, -1, -1, -1}, {49417, -1, -1, -1}, {49418, -1, -1, -1}, {49419, -1, -1, -1}, {49420, -1, -1, -1}, {49421, -1, -1, -1}, {49422, -1, -1, -1}, {49423, -1, -1, -1}, {49425, -1, -1, -1}, {49426, -1, -1, -1}, {49427, -1, -1, -1}, {49428, -1, -1, -1}, {49430, -1, -1, -1}, {49431, -1, -1, -1}, {49432, -1, -1, -1}, {49433, -1, -1, -1}, {49434, -1, -1, -1}, {49435, -1, -1, -1}, {49441, -1, -1, -1}, {49442, -1, -1, -1}, {49445, -1, -1, -1}, {49448, -1, -1, -1}, {49449, -1, -1, -1}, {49450, -1, -1, -1}, {49451, -1, -1, -1}, {49454, -1, -1, -1}, {49458, -1, -1, -1}, {49459, -1, -1, -1}, {49460, -1, -1, -1}, {49461, -1, -1, -1}, {49463, -1, -1, -1}, {49466, -1, -1, -1}, {49467, -1, -1, -1}, {49469, -1, -1, -1}, {49470, -1, -1, -1}, {49471, -1, -1, -1}, {49473, -1, -1, -1}, {49474, -1, -1, -1}, {49475, -1, -1, -1}, {49476, -1, -1, -1}, {49477, -1, -1, -1}, {49478, -1, -1, -1}, {49479, -1, -1, -1}, {49482, -1, -1, -1}, {49486, -1, -1, -1}, {49487, -1, -1, -1}, {49488, -1, -1, -1}, {49489, -1, -1, -1}, {49490, -1, -1, -1}, {49491, -1, -1, -1}, {49494, -1, -1, -1}, {49495, -1, -1, -1}, {49497, -1, -1, -1}, {49498, -1, -1, -1}, {49499, -1, -1, -1}, {49501, -1, -1, -1}, {49502, -1, -1, -1}, {49503, -1, -1, -1}, {49504, -1, -1, -1}, {49505, -1, -1, -1}, {49506, -1, -1, -1}, {49507, -1, -1, -1}, {49510, -1, -1, -1}, {49514, -1, -1, -1}, {49515, -1, -1, -1}, {49516, -1, -1, -1}, {49517, -1, -1, -1}, {49518, -1, -1, -1}, {49519, -1, -1, -1}, {49521, -1, -1, -1}, {49522, -1, -1, -1}, {49523, -1, -1, -1}, {49525, -1, -1, -1}, {49526, -1, -1, -1}, {49527, -1, -1, -1}, {49529, -1, -1, -1}, {49530, -1, -1, -1}, {49531, -1, -1, -1}, {49532, -1, -1, -1}, {49533, -1, -1, -1}, {49534, -1, -1, -1}, {49535, -1, -1, -1}, {49536, -1, -1, -1}, {49537, -1, -1, -1}, {49538, -1, -1, -1}, {49539, -1, -1, -1}, {49540, -1, -1, -1}, {49542, -1, -1, -1}, {49543, -1, -1, -1}, {49544, -1, -1, -1}, {49545, -1, -1, -1}, {49546, -1, -1, -1}, {49547, -1, -1, -1}, {49551, -1, -1, -1}, {49553, -1, -1, -1}, {49554, -1, -1, -1}, {49555, -1, -1, -1}, {49557, -1, -1, -1}, {49559, -1, -1, -1}, {49560, -1, -1, -1}, {49561, -1, -1, -1}, {49562, -1, -1, -1}, {49563, -1, -1, -1}, {49566, -1, -1, -1}, {49568, -1, -1, -1}, {49570, -1, -1, -1}, {49571, -1, -1, -1}, {49572, -1, -1, -1}, {49574, -1, -1, -1}, {49575, -1, -1, -1}, {49578, -1, -1, -1}, {49579, -1, -1, -1}, {49581, -1, -1, -1}, {49582, -1, -1, -1}, {49583, -1, -1, -1}, {49585, -1, -1, -1}, {49586, -1, -1, -1}, {49587, -1, -1, -1}, {49588, -1, -1, -1}, {49589, -1, -1, -1}, {49590, -1, -1, -1}, {49591, -1, -1, -1}, {49592, -1, -1, -1}, {49593, -1, -1, -1}, {49594, -1, -1, -1}, {49595, -1, -1, -1}, {49596, -1, -1, -1}, {49598, -1, -1, -1}, {49599, -1, -1, -1}, {49600, -1, -1, -1}, {49601, -1, -1, -1}, {49602, -1, -1, -1}, {49603, -1, -1, -1}, {49605, -1, -1, -1}, {49606, -1, -1, -1}, {49607, -1, -1, -1}, {49609, -1, -1, -1}, {49610, -1, -1, -1}, {49611, -1, -1, -1}, {49613, -1, -1, -1}, {49614, -1, -1, -1}, {49615, -1, -1, -1}, {49616, -1, -1, -1}, {49617, -1, -1, -1}, {49618, -1, -1, -1}, {49619, -1, -1, -1}, {49621, -1, -1, -1}, {49622, -1, -1, -1}, {49625, -1, -1, -1}, {49626, -1, -1, -1}, {49627, -1, -1, -1}, {49628, -1, -1, -1}, {49629, -1, -1, -1}, {49630, -1, -1, -1}, {49631, -1, -1, -1}, {49633, -1, -1, -1}, {49634, -1, -1, -1}, {49635, -1, -1, -1}, {49637, -1, -1, -1}, {49638, -1, -1, -1}, {49639, -1, -1, -1}, {49641, -1, -1, -1}, {49642, -1, -1, -1}, {49643, -1, -1, -1}, {49644, -1, -1, -1}, {49645, -1, -1, -1}, {49646, -1, -1, -1}, {49647, -1, -1, -1}, {49650, -1, -1, -1}, {49652, -1, -1, -1}, {49653, -1, -1, -1}, {49654, -1, -1, -1}, {49655, -1, -1, -1}, {49656, -1, -1, -1}, {49657, -1, -1, -1}, {49658, -1, -1, -1}, {49659, -1, -1, -1}, {49662, -1, -1, -1}, {49663, -1, -1, -1}, {49665, -1, -1, -1}, {49666, -1, -1, -1}, {49667, -1, -1, -1}, {49669, -1, -1, -1}, {49670, -1, -1, -1}, {49671, -1, -1, -1}, {49672, -1, -1, -1}, {49673, -1, -1, -1}, {49674, -1, -1, -1}, {49675, -1, -1, -1}, {49678, -1, -1, -1}, {49680, -1, -1, -1}, {49682, -1, -1, -1}, {49683, -1, -1, -1}, {49684, -1, -1, -1}, {49685, -1, -1, -1}, {49686, -1, -1, -1}, {49687, -1, -1, -1}, {49690, -1, -1, -1}, {49691, -1, -1, -1}, {49693, -1, -1, -1}, {49694, -1, -1, -1}, {49697, -1, -1, -1}, {49698, -1, -1, -1}, {49699, -1, -1, -1}, {49700, -1, -1, -1}, {49701, -1, -1, -1}, {49702, -1, -1, -1}, {49703, -1, -1, -1}, {49706, -1, -1, -1}, {49708, -1, -1, -1}, {49710, -1, -1, -1}, {49712, -1, -1, -1}, {49715, -1, -1, -1}, {49717, -1, -1, -1}, {49718, -1, -1, -1}, {49719, -1, -1, -1}, {49720, -1, -1, -1}, {49721, -1, -1, -1}, {49722, -1, -1, -1}, {49723, -1, -1, -1}, {49724, -1, -1, -1}, {49725, -1, -1, -1}, {49726, -1, -1, -1}, {49727, -1, -1, -1}, {49728, -1, -1, -1}, {49729, -1, -1, -1}, {49730, -1, -1, -1}, {49731, -1, -1, -1}, {49732, -1, -1, -1}, {49733, -1, -1, -1}, {49734, -1, -1, -1}, {49735, -1, -1, -1}, {49737, -1, -1, -1}, {49738, -1, -1, -1}, {49739, -1, -1, -1}, {49740, -1, -1, -1}, {49741, -1, -1, -1}, {49742, -1, -1, -1}, {49743, -1, -1, -1}, {49746, -1, -1, -1}, {49747, -1, -1, -1}, {49749, -1, -1, -1}, {49750, -1, -1, -1}, {49751, -1, -1, -1}, {49753, -1, -1, -1} },
+ {{49754, -1, -1, -1}, {49755, -1, -1, -1}, {49756, -1, -1, -1}, {49757, -1, -1, -1}, {49758, -1, -1, -1}, {49759, -1, -1, -1}, {49761, -1, -1, -1}, {49762, -1, -1, -1}, {49763, -1, -1, -1}, {49764, -1, -1, -1}, {49766, -1, -1, -1}, {49767, -1, -1, -1}, {49768, -1, -1, -1}, {49769, -1, -1, -1}, {49770, -1, -1, -1}, {49771, -1, -1, -1}, {49774, -1, -1, -1}, {49775, -1, -1, -1}, {49777, -1, -1, -1}, {49778, -1, -1, -1}, {49779, -1, -1, -1}, {49781, -1, -1, -1}, {49782, -1, -1, -1}, {49783, -1, -1, -1}, {49784, -1, -1, -1}, {49785, -1, -1, -1}, {49786, -1, -1, -1}, {49787, -1, -1, -1}, {49790, -1, -1, -1}, {49792, -1, -1, -1}, {49794, -1, -1, -1}, {49795, -1, -1, -1}, {49796, -1, -1, -1}, {49797, -1, -1, -1}, {49798, -1, -1, -1}, {49799, -1, -1, -1}, {49802, -1, -1, -1}, {49803, -1, -1, -1}, {49804, -1, -1, -1}, {49805, -1, -1, -1}, {49806, -1, -1, -1}, {49807, -1, -1, -1}, {49809, -1, -1, -1}, {49810, -1, -1, -1}, {49811, -1, -1, -1}, {49812, -1, -1, -1}, {49813, -1, -1, -1}, {49814, -1, -1, -1}, {49815, -1, -1, -1}, {49817, -1, -1, -1}, {49818, -1, -1, -1}, {49820, -1, -1, -1}, {49822, -1, -1, -1}, {49823, -1, -1, -1}, {49824, -1, -1, -1}, {49825, -1, -1, -1}, {49826, -1, -1, -1}, {49827, -1, -1, -1}, {49830, -1, -1, -1}, {49831, -1, -1, -1}, {49833, -1, -1, -1}, {49834, -1, -1, -1}, {49835, -1, -1, -1}, {49838, -1, -1, -1}, {49839, -1, -1, -1}, {49840, -1, -1, -1}, {49841, -1, -1, -1}, {49842, -1, -1, -1}, {49843, -1, -1, -1}, {49846, -1, -1, -1}, {49848, -1, -1, -1}, {49850, -1, -1, -1}, {49851, -1, -1, -1}, {49852, -1, -1, -1}, {49853, -1, -1, -1}, {49854, -1, -1, -1}, {49855, -1, -1, -1}, {49856, -1, -1, -1}, {49857, -1, -1, -1}, {49858, -1, -1, -1}, {49859, -1, -1, -1}, {49860, -1, -1, -1}, {49861, -1, -1, -1}, {49862, -1, -1, -1}, {49863, -1, -1, -1}, {49864, -1, -1, -1}, {49865, -1, -1, -1}, {49866, -1, -1, -1}, {49867, -1, -1, -1}, {49868, -1, -1, -1}, {49869, -1, -1, -1}, {49870, -1, -1, -1}, {49871, -1, -1, -1}, {49872, -1, -1, -1}, {49873, -1, -1, -1}, {49874, -1, -1, -1}, {49875, -1, -1, -1}, {49876, -1, -1, -1}, {49877, -1, -1, -1}, {49878, -1, -1, -1}, {49879, -1, -1, -1}, {49880, -1, -1, -1}, {49881, -1, -1, -1}, {49882, -1, -1, -1}, {49883, -1, -1, -1}, {49886, -1, -1, -1}, {49887, -1, -1, -1}, {49889, -1, -1, -1}, {49890, -1, -1, -1}, {49893, -1, -1, -1}, {49894, -1, -1, -1}, {49895, -1, -1, -1}, {49896, -1, -1, -1}, {49897, -1, -1, -1}, {49898, -1, -1, -1}, {49902, -1, -1, -1}, {49904, -1, -1, -1}, {49906, -1, -1, -1}, {49907, -1, -1, -1}, {49908, -1, -1, -1}, {49909, -1, -1, -1}, {49911, -1, -1, -1}, {49914, -1, -1, -1}, {49917, -1, -1, -1}, {49918, -1, -1, -1}, {49919, -1, -1, -1}, {49921, -1, -1, -1}, {49922, -1, -1, -1}, {49923, -1, -1, -1}, {49924, -1, -1, -1}, {49925, -1, -1, -1}, {49926, -1, -1, -1}, {49927, -1, -1, -1}, {49930, -1, -1, -1}, {49931, -1, -1, -1}, {49934, -1, -1, -1}, {49935, -1, -1, -1}, {49936, -1, -1, -1}, {49937, -1, -1, -1}, {49938, -1, -1, -1}, {49942, -1, -1, -1}, {49943, -1, -1, -1}, {49945, -1, -1, -1}, {49946, -1, -1, -1}, {49947, -1, -1, -1}, {49949, -1, -1, -1}, {49950, -1, -1, -1}, {49951, -1, -1, -1}, {49952, -1, -1, -1}, {49953, -1, -1, -1}, {49954, -1, -1, -1}, {49955, -1, -1, -1}, {49958, -1, -1, -1}, {49959, -1, -1, -1}, {49962, -1, -1, -1}, {49963, -1, -1, -1}, {49964, -1, -1, -1}, {49965, -1, -1, -1}, {49966, -1, -1, -1}, {49967, -1, -1, -1}, {49968, -1, -1, -1}, {49969, -1, -1, -1}, {49970, -1, -1, -1}, {49971, -1, -1, -1}, {49972, -1, -1, -1}, {49973, -1, -1, -1}, {49974, -1, -1, -1}, {49975, -1, -1, -1}, {49976, -1, -1, -1}, {49977, -1, -1, -1}, {49978, -1, -1, -1}, {49979, -1, -1, -1}, {49980, -1, -1, -1}, {49981, -1, -1, -1}, {49982, -1, -1, -1}, {49983, -1, -1, -1}, {49984, -1, -1, -1}, {49985, -1, -1, -1}, {49986, -1, -1, -1}, {49987, -1, -1, -1}, {49988, -1, -1, -1}, {49990, -1, -1, -1}, {49991, -1, -1, -1}, {49992, -1, -1, -1}, {49993, -1, -1, -1}, {49994, -1, -1, -1}, {49995, -1, -1, -1}, {49996, -1, -1, -1}, {49997, -1, -1, -1}, {49998, -1, -1, -1}, {49999, -1, -1, -1}, {50000, -1, -1, -1}, {50001, -1, -1, -1}, {50002, -1, -1, -1}, {50003, -1, -1, -1}, {50004, -1, -1, -1}, {50005, -1, -1, -1}, {50006, -1, -1, -1}, {50007, -1, -1, -1}, {50008, -1, -1, -1}, {50009, -1, -1, -1}, {50010, -1, -1, -1}, {50011, -1, -1, -1}, {50012, -1, -1, -1}, {50013, -1, -1, -1}, {50014, -1, -1, -1}, {50015, -1, -1, -1}, {50016, -1, -1, -1}, {50017, -1, -1, -1}, {50018, -1, -1, -1}, {50019, -1, -1, -1}, {50020, -1, -1, -1}, {50021, -1, -1, -1}, {50022, -1, -1, -1}, {50023, -1, -1, -1}, {50026, -1, -1, -1}, {50027, -1, -1, -1}, {50029, -1, -1, -1}, {50030, -1, -1, -1}, {50031, -1, -1, -1}, {50033, -1, -1, -1}, {50035, -1, -1, -1}, {50036, -1, -1, -1}, {50037, -1, -1, -1}, {50038, -1, -1, -1}, {50039, -1, -1, -1}, {50042, -1, -1, -1}, {50043, -1, -1, -1}, {50046, -1, -1, -1}, {50047, -1, -1, -1}, {50048, -1, -1, -1}, {50049, -1, -1, -1}, {50050, -1, -1, -1}, {50051, -1, -1, -1}, {50053, -1, -1, -1}, {50054, -1, -1, -1}, {50055, -1, -1, -1}, {50057, -1, -1, -1}, {50058, -1, -1, -1}, {50059, -1, -1, -1}, {50061, -1, -1, -1}, {50062, -1, -1, -1}, {50063, -1, -1, -1}, {50064, -1, -1, -1}, {50065, -1, -1, -1}, {50066, -1, -1, -1}, {50067, -1, -1, -1}, {50068, -1, -1, -1}, {50069, -1, -1, -1}, {50070, -1, -1, -1}, {50071, -1, -1, -1}, {50072, -1, -1, -1}, {50073, -1, -1, -1}, {50074, -1, -1, -1}, {50075, -1, -1, -1}, {50076, -1, -1, -1} },
+ {{50077, -1, -1, -1}, {50078, -1, -1, -1}, {50079, -1, -1, -1}, {50080, -1, -1, -1}, {50081, -1, -1, -1}, {50082, -1, -1, -1}, {50083, -1, -1, -1}, {50084, -1, -1, -1}, {50085, -1, -1, -1}, {50086, -1, -1, -1}, {50087, -1, -1, -1}, {50088, -1, -1, -1}, {50089, -1, -1, -1}, {50090, -1, -1, -1}, {50091, -1, -1, -1}, {50092, -1, -1, -1}, {50093, -1, -1, -1}, {50094, -1, -1, -1}, {50095, -1, -1, -1}, {50096, -1, -1, -1}, {50097, -1, -1, -1}, {50098, -1, -1, -1}, {50099, -1, -1, -1}, {50100, -1, -1, -1}, {50101, -1, -1, -1}, {50102, -1, -1, -1}, {50103, -1, -1, -1}, {50104, -1, -1, -1}, {50105, -1, -1, -1}, {50106, -1, -1, -1}, {50107, -1, -1, -1}, {50108, -1, -1, -1}, {50109, -1, -1, -1}, {50110, -1, -1, -1}, {50111, -1, -1, -1}, {50113, -1, -1, -1}, {50114, -1, -1, -1}, {50115, -1, -1, -1}, {50116, -1, -1, -1}, {50117, -1, -1, -1}, {50118, -1, -1, -1}, {50119, -1, -1, -1}, {50120, -1, -1, -1}, {50121, -1, -1, -1}, {50122, -1, -1, -1}, {50123, -1, -1, -1}, {50124, -1, -1, -1}, {50125, -1, -1, -1}, {50126, -1, -1, -1}, {50127, -1, -1, -1}, {50128, -1, -1, -1}, {50129, -1, -1, -1}, {50130, -1, -1, -1}, {50131, -1, -1, -1}, {50132, -1, -1, -1}, {50133, -1, -1, -1}, {50134, -1, -1, -1}, {50135, -1, -1, -1}, {50138, -1, -1, -1}, {50139, -1, -1, -1}, {50141, -1, -1, -1}, {50142, -1, -1, -1}, {50145, -1, -1, -1}, {50147, -1, -1, -1}, {50148, -1, -1, -1}, {50149, -1, -1, -1}, {50150, -1, -1, -1}, {50151, -1, -1, -1}, {50154, -1, -1, -1}, {50155, -1, -1, -1}, {50156, -1, -1, -1}, {50158, -1, -1, -1}, {50159, -1, -1, -1}, {50160, -1, -1, -1}, {50161, -1, -1, -1}, {50162, -1, -1, -1}, {50163, -1, -1, -1}, {50166, -1, -1, -1}, {50167, -1, -1, -1}, {50169, -1, -1, -1}, {50170, -1, -1, -1}, {50171, -1, -1, -1}, {50172, -1, -1, -1}, {50173, -1, -1, -1}, {50174, -1, -1, -1}, {50175, -1, -1, -1}, {50176, -1, -1, -1}, {50177, -1, -1, -1}, {50178, -1, -1, -1}, {50179, -1, -1, -1}, {50180, -1, -1, -1}, {50181, -1, -1, -1}, {50182, -1, -1, -1}, {50183, -1, -1, -1}, {50185, -1, -1, -1}, {50186, -1, -1, -1}, {50187, -1, -1, -1}, {50188, -1, -1, -1}, {50189, -1, -1, -1}, {50190, -1, -1, -1}, {50191, -1, -1, -1}, {50193, -1, -1, -1}, {50194, -1, -1, -1}, {50195, -1, -1, -1}, {50196, -1, -1, -1}, {50197, -1, -1, -1}, {50198, -1, -1, -1}, {50199, -1, -1, -1}, {50200, -1, -1, -1}, {50201, -1, -1, -1}, {50202, -1, -1, -1}, {50203, -1, -1, -1}, {50204, -1, -1, -1}, {50205, -1, -1, -1}, {50206, -1, -1, -1}, {50207, -1, -1, -1}, {50208, -1, -1, -1}, {50209, -1, -1, -1}, {50210, -1, -1, -1}, {50211, -1, -1, -1}, {50213, -1, -1, -1}, {50214, -1, -1, -1}, {50215, -1, -1, -1}, {50216, -1, -1, -1}, {50217, -1, -1, -1}, {50218, -1, -1, -1}, {50219, -1, -1, -1}, {50221, -1, -1, -1}, {50222, -1, -1, -1}, {50223, -1, -1, -1}, {50225, -1, -1, -1}, {50226, -1, -1, -1}, {50227, -1, -1, -1}, {50229, -1, -1, -1}, {50230, -1, -1, -1}, {50231, -1, -1, -1}, {50232, -1, -1, -1}, {50233, -1, -1, -1}, {50234, -1, -1, -1}, {50235, -1, -1, -1}, {50238, -1, -1, -1}, {50239, -1, -1, -1}, {50240, -1, -1, -1}, {50241, -1, -1, -1}, {50242, -1, -1, -1}, {50243, -1, -1, -1}, {50244, -1, -1, -1}, {50245, -1, -1, -1}, {50246, -1, -1, -1}, {50247, -1, -1, -1}, {50249, -1, -1, -1}, {50250, -1, -1, -1}, {50251, -1, -1, -1}, {50252, -1, -1, -1}, {50253, -1, -1, -1}, {50254, -1, -1, -1}, {50255, -1, -1, -1}, {50256, -1, -1, -1}, {50257, -1, -1, -1}, {50258, -1, -1, -1}, {50259, -1, -1, -1}, {50260, -1, -1, -1}, {50261, -1, -1, -1}, {50262, -1, -1, -1}, {50263, -1, -1, -1}, {50264, -1, -1, -1}, {50265, -1, -1, -1}, {50266, -1, -1, -1}, {50267, -1, -1, -1}, {50268, -1, -1, -1}, {50269, -1, -1, -1}, {50270, -1, -1, -1}, {50271, -1, -1, -1}, {50272, -1, -1, -1}, {50273, -1, -1, -1}, {50274, -1, -1, -1}, {50275, -1, -1, -1}, {50278, -1, -1, -1}, {50279, -1, -1, -1}, {50281, -1, -1, -1}, {50282, -1, -1, -1}, {50283, -1, -1, -1}, {50285, -1, -1, -1}, {50286, -1, -1, -1}, {50287, -1, -1, -1}, {50288, -1, -1, -1}, {50289, -1, -1, -1}, {50290, -1, -1, -1}, {50291, -1, -1, -1}, {50294, -1, -1, -1}, {50295, -1, -1, -1}, {50296, -1, -1, -1}, {50298, -1, -1, -1}, {50299, -1, -1, -1}, {50300, -1, -1, -1}, {50301, -1, -1, -1}, {50302, -1, -1, -1}, {50303, -1, -1, -1}, {50305, -1, -1, -1}, {50306, -1, -1, -1}, {50307, -1, -1, -1}, {50308, -1, -1, -1}, {50309, -1, -1, -1}, {50310, -1, -1, -1}, {50311, -1, -1, -1}, {50312, -1, -1, -1}, {50313, -1, -1, -1}, {50314, -1, -1, -1}, {50315, -1, -1, -1}, {50316, -1, -1, -1}, {50317, -1, -1, -1}, {50318, -1, -1, -1}, {50319, -1, -1, -1}, {50320, -1, -1, -1}, {50321, -1, -1, -1}, {50322, -1, -1, -1}, {50323, -1, -1, -1}, {50325, -1, -1, -1}, {50326, -1, -1, -1}, {50327, -1, -1, -1}, {50328, -1, -1, -1}, {50329, -1, -1, -1}, {50330, -1, -1, -1}, {50331, -1, -1, -1}, {50333, -1, -1, -1}, {50334, -1, -1, -1}, {50335, -1, -1, -1}, {50336, -1, -1, -1}, {50337, -1, -1, -1}, {50338, -1, -1, -1}, {50339, -1, -1, -1}, {50340, -1, -1, -1}, {50341, -1, -1, -1}, {50342, -1, -1, -1}, {50343, -1, -1, -1}, {50344, -1, -1, -1}, {50345, -1, -1, -1}, {50346, -1, -1, -1}, {50347, -1, -1, -1}, {50348, -1, -1, -1}, {50349, -1, -1, -1}, {50350, -1, -1, -1}, {50351, -1, -1, -1}, {50352, -1, -1, -1}, {50353, -1, -1, -1}, {50354, -1, -1, -1}, {50355, -1, -1, -1}, {50356, -1, -1, -1}, {50357, -1, -1, -1}, {50358, -1, -1, -1}, {50359, -1, -1, -1}, {50361, -1, -1, -1}, {50362, -1, -1, -1}, {50363, -1, -1, -1}, {50365, -1, -1, -1}, {50366, -1, -1, -1} },
+ {{50367, -1, -1, -1}, {50368, -1, -1, -1}, {50369, -1, -1, -1}, {50370, -1, -1, -1}, {50371, -1, -1, -1}, {50372, -1, -1, -1}, {50373, -1, -1, -1}, {50374, -1, -1, -1}, {50375, -1, -1, -1}, {50376, -1, -1, -1}, {50377, -1, -1, -1}, {50378, -1, -1, -1}, {50379, -1, -1, -1}, {50380, -1, -1, -1}, {50381, -1, -1, -1}, {50382, -1, -1, -1}, {50383, -1, -1, -1}, {50384, -1, -1, -1}, {50385, -1, -1, -1}, {50386, -1, -1, -1}, {50387, -1, -1, -1}, {50388, -1, -1, -1}, {50389, -1, -1, -1}, {50390, -1, -1, -1}, {50391, -1, -1, -1}, {50392, -1, -1, -1}, {50393, -1, -1, -1}, {50394, -1, -1, -1}, {50395, -1, -1, -1}, {50396, -1, -1, -1}, {50397, -1, -1, -1}, {50398, -1, -1, -1}, {50399, -1, -1, -1}, {50400, -1, -1, -1}, {50401, -1, -1, -1}, {50402, -1, -1, -1}, {50403, -1, -1, -1}, {50404, -1, -1, -1}, {50405, -1, -1, -1}, {50406, -1, -1, -1}, {50407, -1, -1, -1}, {50408, -1, -1, -1}, {50410, -1, -1, -1}, {50411, -1, -1, -1}, {50412, -1, -1, -1}, {50413, -1, -1, -1}, {50414, -1, -1, -1}, {50415, -1, -1, -1}, {50418, -1, -1, -1}, {50419, -1, -1, -1}, {50421, -1, -1, -1}, {50422, -1, -1, -1}, {50423, -1, -1, -1}, {50425, -1, -1, -1}, {50427, -1, -1, -1}, {50428, -1, -1, -1}, {50429, -1, -1, -1}, {50430, -1, -1, -1}, {50434, -1, -1, -1}, {50435, -1, -1, -1}, {50436, -1, -1, -1}, {50437, -1, -1, -1}, {50438, -1, -1, -1}, {50439, -1, -1, -1}, {50440, -1, -1, -1}, {50441, -1, -1, -1}, {50442, -1, -1, -1}, {50443, -1, -1, -1}, {50445, -1, -1, -1}, {50446, -1, -1, -1}, {50447, -1, -1, -1}, {50449, -1, -1, -1}, {50450, -1, -1, -1}, {50451, -1, -1, -1}, {50453, -1, -1, -1}, {50454, -1, -1, -1}, {50455, -1, -1, -1}, {50456, -1, -1, -1}, {50457, -1, -1, -1}, {50458, -1, -1, -1}, {50459, -1, -1, -1}, {50461, -1, -1, -1}, {50462, -1, -1, -1}, {50463, -1, -1, -1}, {50464, -1, -1, -1}, {50465, -1, -1, -1}, {50466, -1, -1, -1}, {50467, -1, -1, -1}, {50468, -1, -1, -1}, {50469, -1, -1, -1}, {50470, -1, -1, -1}, {50471, -1, -1, -1}, {50474, -1, -1, -1}, {50475, -1, -1, -1}, {50477, -1, -1, -1}, {50478, -1, -1, -1}, {50479, -1, -1, -1}, {50481, -1, -1, -1}, {50482, -1, -1, -1}, {50483, -1, -1, -1}, {50484, -1, -1, -1}, {50485, -1, -1, -1}, {50486, -1, -1, -1}, {50487, -1, -1, -1}, {50490, -1, -1, -1}, {50492, -1, -1, -1}, {50494, -1, -1, -1}, {50495, -1, -1, -1}, {50496, -1, -1, -1}, {50497, -1, -1, -1}, {50498, -1, -1, -1}, {50499, -1, -1, -1}, {50502, -1, -1, -1}, {50503, -1, -1, -1}, {50507, -1, -1, -1}, {50511, -1, -1, -1}, {50512, -1, -1, -1}, {50513, -1, -1, -1}, {50514, -1, -1, -1}, {50518, -1, -1, -1}, {50522, -1, -1, -1}, {50523, -1, -1, -1}, {50524, -1, -1, -1}, {50527, -1, -1, -1}, {50530, -1, -1, -1}, {50531, -1, -1, -1}, {50533, -1, -1, -1}, {50534, -1, -1, -1}, {50535, -1, -1, -1}, {50537, -1, -1, -1}, {50538, -1, -1, -1}, {50539, -1, -1, -1}, {50540, -1, -1, -1}, {50541, -1, -1, -1}, {50542, -1, -1, -1}, {50543, -1, -1, -1}, {50546, -1, -1, -1}, {50550, -1, -1, -1}, {50551, -1, -1, -1}, {50552, -1, -1, -1}, {50553, -1, -1, -1}, {50554, -1, -1, -1}, {50555, -1, -1, -1}, {50558, -1, -1, -1}, {50559, -1, -1, -1}, {50561, -1, -1, -1}, {50562, -1, -1, -1}, {50563, -1, -1, -1}, {50565, -1, -1, -1}, {50566, -1, -1, -1}, {50568, -1, -1, -1}, {50569, -1, -1, -1}, {50570, -1, -1, -1}, {50571, -1, -1, -1}, {50574, -1, -1, -1}, {50576, -1, -1, -1}, {50578, -1, -1, -1}, {50579, -1, -1, -1}, {50580, -1, -1, -1}, {50582, -1, -1, -1}, {50585, -1, -1, -1}, {50586, -1, -1, -1}, {50587, -1, -1, -1}, {50589, -1, -1, -1}, {50590, -1, -1, -1}, {50591, -1, -1, -1}, {50593, -1, -1, -1}, {50594, -1, -1, -1}, {50595, -1, -1, -1}, {50596, -1, -1, -1}, {50597, -1, -1, -1}, {50598, -1, -1, -1}, {50599, -1, -1, -1}, {50600, -1, -1, -1}, {50602, -1, -1, -1}, {50603, -1, -1, -1}, {50604, -1, -1, -1}, {50605, -1, -1, -1}, {50606, -1, -1, -1}, {50607, -1, -1, -1}, {50608, -1, -1, -1}, {50609, -1, -1, -1}, {50610, -1, -1, -1}, {50611, -1, -1, -1}, {50614, -1, -1, -1}, {50615, -1, -1, -1}, {50618, -1, -1, -1}, {50623, -1, -1, -1}, {50624, -1, -1, -1}, {50625, -1, -1, -1}, {50626, -1, -1, -1}, {50627, -1, -1, -1}, {50635, -1, -1, -1}, {50637, -1, -1, -1}, {50639, -1, -1, -1}, {50642, -1, -1, -1}, {50643, -1, -1, -1}, {50645, -1, -1, -1}, {50646, -1, -1, -1}, {50647, -1, -1, -1}, {50649, -1, -1, -1}, {50650, -1, -1, -1}, {50651, -1, -1, -1}, {50652, -1, -1, -1}, {50653, -1, -1, -1}, {50654, -1, -1, -1}, {50655, -1, -1, -1}, {50658, -1, -1, -1}, {50660, -1, -1, -1}, {50662, -1, -1, -1}, {50663, -1, -1, -1}, {50664, -1, -1, -1}, {50665, -1, -1, -1}, {50666, -1, -1, -1}, {50667, -1, -1, -1}, {50671, -1, -1, -1}, {50673, -1, -1, -1}, {50674, -1, -1, -1}, {50675, -1, -1, -1}, {50677, -1, -1, -1}, {50680, -1, -1, -1}, {50681, -1, -1, -1}, {50682, -1, -1, -1}, {50683, -1, -1, -1}, {50690, -1, -1, -1}, {50691, -1, -1, -1}, {50692, -1, -1, -1}, {50697, -1, -1, -1}, {50698, -1, -1, -1}, {50699, -1, -1, -1}, {50701, -1, -1, -1}, {50702, -1, -1, -1}, {50703, -1, -1, -1}, {50705, -1, -1, -1}, {50706, -1, -1, -1}, {50707, -1, -1, -1}, {50708, -1, -1, -1}, {50709, -1, -1, -1}, {50710, -1, -1, -1}, {50711, -1, -1, -1}, {50714, -1, -1, -1}, {50717, -1, -1, -1}, {50718, -1, -1, -1}, {50719, -1, -1, -1}, {50720, -1, -1, -1}, {50721, -1, -1, -1}, {50722, -1, -1, -1}, {50723, -1, -1, -1}, {50726, -1, -1, -1}, {50727, -1, -1, -1}, {50729, -1, -1, -1}, {50730, -1, -1, -1}, {50731, -1, -1, -1}, {50735, -1, -1, -1}, {50737, -1, -1, -1}, {50738, -1, -1, -1} },
+ {{50742, -1, -1, -1}, {50744, -1, -1, -1}, {50746, -1, -1, -1}, {50748, -1, -1, -1}, {50749, -1, -1, -1}, {50750, -1, -1, -1}, {50751, -1, -1, -1}, {50754, -1, -1, -1}, {50755, -1, -1, -1}, {50757, -1, -1, -1}, {50758, -1, -1, -1}, {50759, -1, -1, -1}, {50761, -1, -1, -1}, {50762, -1, -1, -1}, {50763, -1, -1, -1}, {50764, -1, -1, -1}, {50765, -1, -1, -1}, {50766, -1, -1, -1}, {50767, -1, -1, -1}, {50770, -1, -1, -1}, {50774, -1, -1, -1}, {50775, -1, -1, -1}, {50776, -1, -1, -1}, {50777, -1, -1, -1}, {50778, -1, -1, -1}, {50779, -1, -1, -1}, {50782, -1, -1, -1}, {50783, -1, -1, -1}, {50785, -1, -1, -1}, {50786, -1, -1, -1}, {50787, -1, -1, -1}, {50788, -1, -1, -1}, {50789, -1, -1, -1}, {50790, -1, -1, -1}, {50791, -1, -1, -1}, {50792, -1, -1, -1}, {50793, -1, -1, -1}, {50794, -1, -1, -1}, {50795, -1, -1, -1}, {50797, -1, -1, -1}, {50798, -1, -1, -1}, {50800, -1, -1, -1}, {50802, -1, -1, -1}, {50803, -1, -1, -1}, {50804, -1, -1, -1}, {50805, -1, -1, -1}, {50806, -1, -1, -1}, {50807, -1, -1, -1}, {50810, -1, -1, -1}, {50811, -1, -1, -1}, {50813, -1, -1, -1}, {50814, -1, -1, -1}, {50815, -1, -1, -1}, {50817, -1, -1, -1}, {50818, -1, -1, -1}, {50819, -1, -1, -1}, {50820, -1, -1, -1}, {50821, -1, -1, -1}, {50822, -1, -1, -1}, {50823, -1, -1, -1}, {50826, -1, -1, -1}, {50828, -1, -1, -1}, {50830, -1, -1, -1}, {50831, -1, -1, -1}, {50832, -1, -1, -1}, {50833, -1, -1, -1}, {50834, -1, -1, -1}, {50835, -1, -1, -1}, {50838, -1, -1, -1}, {50839, -1, -1, -1}, {50841, -1, -1, -1}, {50842, -1, -1, -1}, {50843, -1, -1, -1}, {50845, -1, -1, -1}, {50846, -1, -1, -1}, {50847, -1, -1, -1}, {50848, -1, -1, -1}, {50849, -1, -1, -1}, {50850, -1, -1, -1}, {50851, -1, -1, -1}, {50854, -1, -1, -1}, {50856, -1, -1, -1}, {50858, -1, -1, -1}, {50859, -1, -1, -1}, {50860, -1, -1, -1}, {50861, -1, -1, -1}, {50862, -1, -1, -1}, {50863, -1, -1, -1}, {50866, -1, -1, -1}, {50867, -1, -1, -1}, {50869, -1, -1, -1}, {50870, -1, -1, -1}, {50871, -1, -1, -1}, {50875, -1, -1, -1}, {50876, -1, -1, -1}, {50877, -1, -1, -1}, {50878, -1, -1, -1}, {50879, -1, -1, -1}, {50882, -1, -1, -1}, {50884, -1, -1, -1}, {50886, -1, -1, -1}, {50887, -1, -1, -1}, {50888, -1, -1, -1}, {50889, -1, -1, -1}, {50890, -1, -1, -1}, {50891, -1, -1, -1}, {50894, -1, -1, -1}, {50895, -1, -1, -1}, {50897, -1, -1, -1}, {50898, -1, -1, -1}, {50899, -1, -1, -1}, {50901, -1, -1, -1}, {50902, -1, -1, -1}, {50903, -1, -1, -1}, {50904, -1, -1, -1}, {50905, -1, -1, -1}, {50906, -1, -1, -1}, {50907, -1, -1, -1}, {50910, -1, -1, -1}, {50911, -1, -1, -1}, {50914, -1, -1, -1}, {50915, -1, -1, -1}, {50916, -1, -1, -1}, {50917, -1, -1, -1}, {50918, -1, -1, -1}, {50919, -1, -1, -1}, {50922, -1, -1, -1}, {50923, -1, -1, -1}, {50925, -1, -1, -1}, {50926, -1, -1, -1}, {50927, -1, -1, -1}, {50929, -1, -1, -1}, {50930, -1, -1, -1}, {50931, -1, -1, -1}, {50932, -1, -1, -1}, {50933, -1, -1, -1}, {50934, -1, -1, -1}, {50935, -1, -1, -1}, {50938, -1, -1, -1}, {50939, -1, -1, -1}, {50940, -1, -1, -1}, {50942, -1, -1, -1}, {50943, -1, -1, -1}, {50944, -1, -1, -1}, {50945, -1, -1, -1}, {50946, -1, -1, -1}, {50947, -1, -1, -1}, {50950, -1, -1, -1}, {50951, -1, -1, -1}, {50953, -1, -1, -1}, {50954, -1, -1, -1}, {50955, -1, -1, -1}, {50957, -1, -1, -1}, {50958, -1, -1, -1}, {50959, -1, -1, -1}, {50960, -1, -1, -1}, {50961, -1, -1, -1}, {50962, -1, -1, -1}, {50963, -1, -1, -1}, {50966, -1, -1, -1}, {50968, -1, -1, -1}, {50970, -1, -1, -1}, {50971, -1, -1, -1}, {50972, -1, -1, -1}, {50973, -1, -1, -1}, {50974, -1, -1, -1}, {50975, -1, -1, -1}, {50978, -1, -1, -1}, {50979, -1, -1, -1}, {50981, -1, -1, -1}, {50982, -1, -1, -1}, {50983, -1, -1, -1}, {50985, -1, -1, -1}, {50986, -1, -1, -1}, {50987, -1, -1, -1}, {50988, -1, -1, -1}, {50989, -1, -1, -1}, {50990, -1, -1, -1}, {50991, -1, -1, -1}, {50994, -1, -1, -1}, {50996, -1, -1, -1}, {50998, -1, -1, -1}, {51000, -1, -1, -1}, {51001, -1, -1, -1}, {51002, -1, -1, -1}, {51003, -1, -1, -1}, {51006, -1, -1, -1}, {51007, -1, -1, -1}, {51009, -1, -1, -1}, {51010, -1, -1, -1}, {51011, -1, -1, -1}, {51013, -1, -1, -1}, {51014, -1, -1, -1}, {51015, -1, -1, -1}, {51016, -1, -1, -1}, {51017, -1, -1, -1}, {51019, -1, -1, -1}, {51022, -1, -1, -1}, {51024, -1, -1, -1}, {51033, -1, -1, -1}, {51034, -1, -1, -1}, {51035, -1, -1, -1}, {51037, -1, -1, -1}, {51038, -1, -1, -1}, {51039, -1, -1, -1}, {51041, -1, -1, -1}, {51042, -1, -1, -1}, {51043, -1, -1, -1}, {51044, -1, -1, -1}, {51045, -1, -1, -1}, {51046, -1, -1, -1}, {51047, -1, -1, -1}, {51049, -1, -1, -1}, {51050, -1, -1, -1}, {51052, -1, -1, -1}, {51053, -1, -1, -1}, {51054, -1, -1, -1}, {51055, -1, -1, -1}, {51056, -1, -1, -1}, {51057, -1, -1, -1}, {51058, -1, -1, -1}, {51059, -1, -1, -1}, {51062, -1, -1, -1}, {51063, -1, -1, -1}, {51065, -1, -1, -1}, {51066, -1, -1, -1}, {51067, -1, -1, -1}, {51071, -1, -1, -1}, {51072, -1, -1, -1}, {51073, -1, -1, -1}, {51074, -1, -1, -1}, {51078, -1, -1, -1}, {51083, -1, -1, -1}, {51084, -1, -1, -1}, {51085, -1, -1, -1}, {51087, -1, -1, -1}, {51090, -1, -1, -1}, {51091, -1, -1, -1}, {51093, -1, -1, -1}, {51097, -1, -1, -1}, {51099, -1, -1, -1}, {51100, -1, -1, -1}, {51101, -1, -1, -1}, {51102, -1, -1, -1}, {51103, -1, -1, -1}, {51106, -1, -1, -1}, {51111, -1, -1, -1}, {51112, -1, -1, -1}, {51113, -1, -1, -1}, {51114, -1, -1, -1}, {51115, -1, -1, -1}, {51118, -1, -1, -1}, {51119, -1, -1, -1}, {51121, -1, -1, -1}, {51122, -1, -1, -1}, {51123, -1, -1, -1} },
+ {{51125, -1, -1, -1}, {51126, -1, -1, -1}, {51127, -1, -1, -1}, {51128, -1, -1, -1}, {51129, -1, -1, -1}, {51130, -1, -1, -1}, {51131, -1, -1, -1}, {51134, -1, -1, -1}, {51138, -1, -1, -1}, {51139, -1, -1, -1}, {51140, -1, -1, -1}, {51141, -1, -1, -1}, {51142, -1, -1, -1}, {51143, -1, -1, -1}, {51146, -1, -1, -1}, {51147, -1, -1, -1}, {51149, -1, -1, -1}, {51151, -1, -1, -1}, {51153, -1, -1, -1}, {51154, -1, -1, -1}, {51155, -1, -1, -1}, {51156, -1, -1, -1}, {51157, -1, -1, -1}, {51158, -1, -1, -1}, {51159, -1, -1, -1}, {51161, -1, -1, -1}, {51162, -1, -1, -1}, {51163, -1, -1, -1}, {51164, -1, -1, -1}, {51166, -1, -1, -1}, {51167, -1, -1, -1}, {51168, -1, -1, -1}, {51169, -1, -1, -1}, {51170, -1, -1, -1}, {51171, -1, -1, -1}, {51173, -1, -1, -1}, {51174, -1, -1, -1}, {51175, -1, -1, -1}, {51177, -1, -1, -1}, {51178, -1, -1, -1}, {51179, -1, -1, -1}, {51181, -1, -1, -1}, {51182, -1, -1, -1}, {51183, -1, -1, -1}, {51184, -1, -1, -1}, {51185, -1, -1, -1}, {51186, -1, -1, -1}, {51187, -1, -1, -1}, {51188, -1, -1, -1}, {51189, -1, -1, -1}, {51190, -1, -1, -1}, {51191, -1, -1, -1}, {51192, -1, -1, -1}, {51193, -1, -1, -1}, {51194, -1, -1, -1}, {51195, -1, -1, -1}, {51196, -1, -1, -1}, {51197, -1, -1, -1}, {51198, -1, -1, -1}, {51199, -1, -1, -1}, {51202, -1, -1, -1}, {51203, -1, -1, -1}, {51205, -1, -1, -1}, {51206, -1, -1, -1}, {51207, -1, -1, -1}, {51209, -1, -1, -1}, {51211, -1, -1, -1}, {51212, -1, -1, -1}, {51213, -1, -1, -1}, {51214, -1, -1, -1}, {51215, -1, -1, -1}, {51218, -1, -1, -1}, {51220, -1, -1, -1}, {51223, -1, -1, -1}, {51224, -1, -1, -1}, {51225, -1, -1, -1}, {51226, -1, -1, -1}, {51227, -1, -1, -1}, {51230, -1, -1, -1}, {51231, -1, -1, -1}, {51233, -1, -1, -1}, {51234, -1, -1, -1}, {51235, -1, -1, -1}, {51237, -1, -1, -1}, {51238, -1, -1, -1}, {51239, -1, -1, -1}, {51240, -1, -1, -1}, {51241, -1, -1, -1}, {51242, -1, -1, -1}, {51243, -1, -1, -1}, {51246, -1, -1, -1}, {51248, -1, -1, -1}, {51250, -1, -1, -1}, {51251, -1, -1, -1}, {51252, -1, -1, -1}, {51253, -1, -1, -1}, {51254, -1, -1, -1}, {51255, -1, -1, -1}, {51257, -1, -1, -1}, {51258, -1, -1, -1}, {51259, -1, -1, -1}, {51261, -1, -1, -1}, {51262, -1, -1, -1}, {51263, -1, -1, -1}, {51265, -1, -1, -1}, {51266, -1, -1, -1}, {51267, -1, -1, -1}, {51268, -1, -1, -1}, {51269, -1, -1, -1}, {51270, -1, -1, -1}, {51271, -1, -1, -1}, {51274, -1, -1, -1}, {51275, -1, -1, -1}, {51278, -1, -1, -1}, {51279, -1, -1, -1}, {51280, -1, -1, -1}, {51281, -1, -1, -1}, {51282, -1, -1, -1}, {51283, -1, -1, -1}, {51285, -1, -1, -1}, {51286, -1, -1, -1}, {51287, -1, -1, -1}, {51288, -1, -1, -1}, {51289, -1, -1, -1}, {51290, -1, -1, -1}, {51291, -1, -1, -1}, {51292, -1, -1, -1}, {51293, -1, -1, -1}, {51294, -1, -1, -1}, {51295, -1, -1, -1}, {51296, -1, -1, -1}, {51297, -1, -1, -1}, {51298, -1, -1, -1}, {51299, -1, -1, -1}, {51300, -1, -1, -1}, {51301, -1, -1, -1}, {51302, -1, -1, -1}, {51303, -1, -1, -1}, {51304, -1, -1, -1}, {51305, -1, -1, -1}, {51306, -1, -1, -1}, {51307, -1, -1, -1}, {51308, -1, -1, -1}, {51309, -1, -1, -1}, {51310, -1, -1, -1}, {51311, -1, -1, -1}, {51314, -1, -1, -1}, {51315, -1, -1, -1}, {51317, -1, -1, -1}, {51318, -1, -1, -1}, {51319, -1, -1, -1}, {51321, -1, -1, -1}, {51323, -1, -1, -1}, {51324, -1, -1, -1}, {51325, -1, -1, -1}, {51326, -1, -1, -1}, {51327, -1, -1, -1}, {51330, -1, -1, -1}, {51332, -1, -1, -1}, {51336, -1, -1, -1}, {51337, -1, -1, -1}, {51338, -1, -1, -1}, {51342, -1, -1, -1}, {51343, -1, -1, -1}, {51344, -1, -1, -1}, {51345, -1, -1, -1}, {51346, -1, -1, -1}, {51347, -1, -1, -1}, {51349, -1, -1, -1}, {51350, -1, -1, -1}, {51351, -1, -1, -1}, {51352, -1, -1, -1}, {51353, -1, -1, -1}, {51354, -1, -1, -1}, {51355, -1, -1, -1}, {51356, -1, -1, -1}, {51358, -1, -1, -1}, {51360, -1, -1, -1}, {51362, -1, -1, -1}, {51363, -1, -1, -1}, {51364, -1, -1, -1}, {51365, -1, -1, -1}, {51366, -1, -1, -1}, {51367, -1, -1, -1}, {51369, -1, -1, -1}, {51370, -1, -1, -1}, {51371, -1, -1, -1}, {51372, -1, -1, -1}, {51373, -1, -1, -1}, {51374, -1, -1, -1}, {51375, -1, -1, -1}, {51376, -1, -1, -1}, {51377, -1, -1, -1}, {51378, -1, -1, -1}, {51379, -1, -1, -1}, {51380, -1, -1, -1}, {51381, -1, -1, -1}, {51382, -1, -1, -1}, {51383, -1, -1, -1}, {51384, -1, -1, -1}, {51385, -1, -1, -1}, {51386, -1, -1, -1}, {51387, -1, -1, -1}, {51390, -1, -1, -1}, {51391, -1, -1, -1}, {51392, -1, -1, -1}, {51393, -1, -1, -1}, {51394, -1, -1, -1}, {51395, -1, -1, -1}, {51397, -1, -1, -1}, {51398, -1, -1, -1}, {51399, -1, -1, -1}, {51401, -1, -1, -1}, {51402, -1, -1, -1}, {51403, -1, -1, -1}, {51405, -1, -1, -1}, {51406, -1, -1, -1}, {51407, -1, -1, -1}, {51408, -1, -1, -1}, {51409, -1, -1, -1}, {51410, -1, -1, -1}, {51411, -1, -1, -1}, {51414, -1, -1, -1}, {51416, -1, -1, -1}, {51418, -1, -1, -1}, {51419, -1, -1, -1}, {51420, -1, -1, -1}, {51421, -1, -1, -1}, {51422, -1, -1, -1}, {51423, -1, -1, -1}, {51426, -1, -1, -1}, {51427, -1, -1, -1}, {51429, -1, -1, -1}, {51430, -1, -1, -1}, {51431, -1, -1, -1}, {51432, -1, -1, -1}, {51433, -1, -1, -1}, {51434, -1, -1, -1}, {51435, -1, -1, -1}, {51436, -1, -1, -1}, {51437, -1, -1, -1}, {51438, -1, -1, -1}, {51439, -1, -1, -1}, {51440, -1, -1, -1}, {51441, -1, -1, -1}, {51442, -1, -1, -1}, {51443, -1, -1, -1}, {51444, -1, -1, -1}, {51446, -1, -1, -1}, {51447, -1, -1, -1}, {51448, -1, -1, -1}, {51449, -1, -1, -1}, {51450, -1, -1, -1}, {51451, -1, -1, -1}, {51454, -1, -1, -1}, {51455, -1, -1, -1} },
+ {{51457, -1, -1, -1}, {51458, -1, -1, -1}, {51459, -1, -1, -1}, {51463, -1, -1, -1}, {51464, -1, -1, -1}, {51465, -1, -1, -1}, {51466, -1, -1, -1}, {51467, -1, -1, -1}, {51470, -1, -1, -1}, {51472, -1, -1, -1}, {51474, -1, -1, -1}, {51475, -1, -1, -1}, {51476, -1, -1, -1}, {51477, -1, -1, -1}, {51478, -1, -1, -1}, {51479, -1, -1, -1}, {51481, -1, -1, -1}, {51482, -1, -1, -1}, {51483, -1, -1, -1}, {51484, -1, -1, -1}, {51485, -1, -1, -1}, {51486, -1, -1, -1}, {51487, -1, -1, -1}, {51488, -1, -1, -1}, {51489, -1, -1, -1}, {51490, -1, -1, -1}, {51491, -1, -1, -1}, {51492, -1, -1, -1}, {51493, -1, -1, -1}, {51494, -1, -1, -1}, {51495, -1, -1, -1}, {51496, -1, -1, -1}, {51497, -1, -1, -1}, {51498, -1, -1, -1}, {51499, -1, -1, -1}, {51501, -1, -1, -1}, {51502, -1, -1, -1}, {51503, -1, -1, -1}, {51504, -1, -1, -1}, {51505, -1, -1, -1}, {51506, -1, -1, -1}, {51507, -1, -1, -1}, {51509, -1, -1, -1}, {51510, -1, -1, -1}, {51511, -1, -1, -1}, {51512, -1, -1, -1}, {51513, -1, -1, -1}, {51514, -1, -1, -1}, {51515, -1, -1, -1}, {51516, -1, -1, -1}, {51517, -1, -1, -1}, {51518, -1, -1, -1}, {51519, -1, -1, -1}, {51520, -1, -1, -1}, {51521, -1, -1, -1}, {51522, -1, -1, -1}, {51523, -1, -1, -1}, {51524, -1, -1, -1}, {51525, -1, -1, -1}, {51526, -1, -1, -1}, {51527, -1, -1, -1}, {51528, -1, -1, -1}, {51529, -1, -1, -1}, {51530, -1, -1, -1}, {51531, -1, -1, -1}, {51532, -1, -1, -1}, {51533, -1, -1, -1}, {51534, -1, -1, -1}, {51535, -1, -1, -1}, {51538, -1, -1, -1}, {51539, -1, -1, -1}, {51541, -1, -1, -1}, {51542, -1, -1, -1}, {51543, -1, -1, -1}, {51545, -1, -1, -1}, {51546, -1, -1, -1}, {51547, -1, -1, -1}, {51548, -1, -1, -1}, {51549, -1, -1, -1}, {51550, -1, -1, -1}, {51551, -1, -1, -1}, {51554, -1, -1, -1}, {51556, -1, -1, -1}, {51557, -1, -1, -1}, {51558, -1, -1, -1}, {51559, -1, -1, -1}, {51560, -1, -1, -1}, {51561, -1, -1, -1}, {51562, -1, -1, -1}, {51563, -1, -1, -1}, {51565, -1, -1, -1}, {51566, -1, -1, -1}, {51567, -1, -1, -1}, {51569, -1, -1, -1}, {51570, -1, -1, -1}, {51571, -1, -1, -1}, {51573, -1, -1, -1}, {51574, -1, -1, -1}, {51575, -1, -1, -1}, {51576, -1, -1, -1}, {51577, -1, -1, -1}, {51578, -1, -1, -1}, {51579, -1, -1, -1}, {51581, -1, -1, -1}, {51582, -1, -1, -1}, {51583, -1, -1, -1}, {51584, -1, -1, -1}, {51585, -1, -1, -1}, {51586, -1, -1, -1}, {51587, -1, -1, -1}, {51588, -1, -1, -1}, {51589, -1, -1, -1}, {51590, -1, -1, -1}, {51591, -1, -1, -1}, {51594, -1, -1, -1}, {51595, -1, -1, -1}, {51597, -1, -1, -1}, {51598, -1, -1, -1}, {51599, -1, -1, -1}, {51601, -1, -1, -1}, {51602, -1, -1, -1}, {51603, -1, -1, -1}, {51604, -1, -1, -1}, {51605, -1, -1, -1}, {51606, -1, -1, -1}, {51607, -1, -1, -1}, {51610, -1, -1, -1}, {51612, -1, -1, -1}, {51614, -1, -1, -1}, {51615, -1, -1, -1}, {51616, -1, -1, -1}, {51617, -1, -1, -1}, {51618, -1, -1, -1}, {51619, -1, -1, -1}, {51620, -1, -1, -1}, {51621, -1, -1, -1}, {51622, -1, -1, -1}, {51623, -1, -1, -1}, {51624, -1, -1, -1}, {51625, -1, -1, -1}, {51626, -1, -1, -1}, {51627, -1, -1, -1}, {51628, -1, -1, -1}, {51629, -1, -1, -1}, {51630, -1, -1, -1}, {51631, -1, -1, -1}, {51632, -1, -1, -1}, {51633, -1, -1, -1}, {51634, -1, -1, -1}, {51635, -1, -1, -1}, {51636, -1, -1, -1}, {51637, -1, -1, -1}, {51638, -1, -1, -1}, {51639, -1, -1, -1}, {51640, -1, -1, -1}, {51641, -1, -1, -1}, {51642, -1, -1, -1}, {51643, -1, -1, -1}, {51644, -1, -1, -1}, {51645, -1, -1, -1}, {51646, -1, -1, -1}, {51647, -1, -1, -1}, {51650, -1, -1, -1}, {51651, -1, -1, -1}, {51653, -1, -1, -1}, {51654, -1, -1, -1}, {51657, -1, -1, -1}, {51659, -1, -1, -1}, {51660, -1, -1, -1}, {51661, -1, -1, -1}, {51662, -1, -1, -1}, {51663, -1, -1, -1}, {51666, -1, -1, -1}, {51668, -1, -1, -1}, {51671, -1, -1, -1}, {51672, -1, -1, -1}, {51675, -1, -1, -1}, {51678, -1, -1, -1}, {51679, -1, -1, -1}, {51681, -1, -1, -1}, {51683, -1, -1, -1}, {51685, -1, -1, -1}, {51686, -1, -1, -1}, {51688, -1, -1, -1}, {51689, -1, -1, -1}, {51690, -1, -1, -1}, {51691, -1, -1, -1}, {51694, -1, -1, -1}, {51698, -1, -1, -1}, {51699, -1, -1, -1}, {51700, -1, -1, -1}, {51701, -1, -1, -1}, {51702, -1, -1, -1}, {51703, -1, -1, -1}, {51706, -1, -1, -1}, {51707, -1, -1, -1}, {51709, -1, -1, -1}, {51710, -1, -1, -1}, {51711, -1, -1, -1}, {51713, -1, -1, -1}, {51714, -1, -1, -1}, {51715, -1, -1, -1}, {51716, -1, -1, -1}, {51717, -1, -1, -1}, {51718, -1, -1, -1}, {51719, -1, -1, -1}, {51722, -1, -1, -1}, {51726, -1, -1, -1}, {51727, -1, -1, -1}, {51728, -1, -1, -1}, {51729, -1, -1, -1}, {51730, -1, -1, -1}, {51731, -1, -1, -1}, {51733, -1, -1, -1}, {51734, -1, -1, -1}, {51735, -1, -1, -1}, {51737, -1, -1, -1}, {51738, -1, -1, -1}, {51739, -1, -1, -1}, {51740, -1, -1, -1}, {51741, -1, -1, -1}, {51742, -1, -1, -1}, {51743, -1, -1, -1}, {51744, -1, -1, -1}, {51745, -1, -1, -1}, {51746, -1, -1, -1}, {51747, -1, -1, -1}, {51748, -1, -1, -1}, {51749, -1, -1, -1}, {51750, -1, -1, -1}, {51751, -1, -1, -1}, {51752, -1, -1, -1}, {51754, -1, -1, -1}, {51755, -1, -1, -1}, {51756, -1, -1, -1}, {51757, -1, -1, -1}, {51758, -1, -1, -1}, {51759, -1, -1, -1}, {51760, -1, -1, -1}, {51761, -1, -1, -1}, {51762, -1, -1, -1}, {51763, -1, -1, -1}, {51764, -1, -1, -1}, {51765, -1, -1, -1}, {51766, -1, -1, -1}, {51767, -1, -1, -1}, {51768, -1, -1, -1}, {51769, -1, -1, -1}, {51770, -1, -1, -1}, {51771, -1, -1, -1}, {51772, -1, -1, -1}, {51773, -1, -1, -1}, {51774, -1, -1, -1}, {51775, -1, -1, -1}, {51776, -1, -1, -1}, {51777, -1, -1, -1} },
+ {{51778, -1, -1, -1}, {51779, -1, -1, -1}, {51780, -1, -1, -1}, {51781, -1, -1, -1}, {51782, -1, -1, -1}, {51783, -1, -1, -1}, {51784, -1, -1, -1}, {51785, -1, -1, -1}, {51786, -1, -1, -1}, {51787, -1, -1, -1}, {51790, -1, -1, -1}, {51791, -1, -1, -1}, {51793, -1, -1, -1}, {51794, -1, -1, -1}, {51795, -1, -1, -1}, {51797, -1, -1, -1}, {51798, -1, -1, -1}, {51799, -1, -1, -1}, {51800, -1, -1, -1}, {51801, -1, -1, -1}, {51802, -1, -1, -1}, {51803, -1, -1, -1}, {51806, -1, -1, -1}, {51810, -1, -1, -1}, {51811, -1, -1, -1}, {51812, -1, -1, -1}, {51813, -1, -1, -1}, {51814, -1, -1, -1}, {51815, -1, -1, -1}, {51817, -1, -1, -1}, {51818, -1, -1, -1}, {51819, -1, -1, -1}, {51820, -1, -1, -1}, {51821, -1, -1, -1}, {51822, -1, -1, -1}, {51823, -1, -1, -1}, {51824, -1, -1, -1}, {51825, -1, -1, -1}, {51826, -1, -1, -1}, {51827, -1, -1, -1}, {51828, -1, -1, -1}, {51829, -1, -1, -1}, {51830, -1, -1, -1}, {51831, -1, -1, -1}, {51832, -1, -1, -1}, {51833, -1, -1, -1}, {51834, -1, -1, -1}, {51835, -1, -1, -1}, {51836, -1, -1, -1}, {51838, -1, -1, -1}, {51839, -1, -1, -1}, {51840, -1, -1, -1}, {51841, -1, -1, -1}, {51842, -1, -1, -1}, {51843, -1, -1, -1}, {51845, -1, -1, -1}, {51846, -1, -1, -1}, {51847, -1, -1, -1}, {51848, -1, -1, -1}, {51849, -1, -1, -1}, {51850, -1, -1, -1}, {51851, -1, -1, -1}, {51852, -1, -1, -1}, {51853, -1, -1, -1}, {51854, -1, -1, -1}, {51855, -1, -1, -1}, {51856, -1, -1, -1}, {51857, -1, -1, -1}, {51858, -1, -1, -1}, {51859, -1, -1, -1}, {51860, -1, -1, -1}, {51861, -1, -1, -1}, {51862, -1, -1, -1}, {51863, -1, -1, -1}, {51865, -1, -1, -1}, {51866, -1, -1, -1}, {51867, -1, -1, -1}, {51868, -1, -1, -1}, {51869, -1, -1, -1}, {51870, -1, -1, -1}, {51871, -1, -1, -1}, {51872, -1, -1, -1}, {51873, -1, -1, -1}, {51874, -1, -1, -1}, {51875, -1, -1, -1}, {51876, -1, -1, -1}, {51877, -1, -1, -1}, {51878, -1, -1, -1}, {51879, -1, -1, -1}, {51880, -1, -1, -1}, {51881, -1, -1, -1}, {51882, -1, -1, -1}, {51883, -1, -1, -1}, {51884, -1, -1, -1}, {51885, -1, -1, -1}, {51886, -1, -1, -1}, {51887, -1, -1, -1}, {51888, -1, -1, -1}, {51889, -1, -1, -1}, {51890, -1, -1, -1}, {51891, -1, -1, -1}, {51892, -1, -1, -1}, {51893, -1, -1, -1}, {51894, -1, -1, -1}, {51895, -1, -1, -1}, {51896, -1, -1, -1}, {51897, -1, -1, -1}, {51898, -1, -1, -1}, {51899, -1, -1, -1}, {51902, -1, -1, -1}, {51903, -1, -1, -1}, {51905, -1, -1, -1}, {51906, -1, -1, -1}, {51907, -1, -1, -1}, {51909, -1, -1, -1}, {51910, -1, -1, -1}, {51911, -1, -1, -1}, {51912, -1, -1, -1}, {51913, -1, -1, -1}, {51914, -1, -1, -1}, {51915, -1, -1, -1}, {51918, -1, -1, -1}, {51920, -1, -1, -1}, {51922, -1, -1, -1}, {51924, -1, -1, -1}, {51925, -1, -1, -1}, {51926, -1, -1, -1}, {51927, -1, -1, -1}, {51930, -1, -1, -1}, {51931, -1, -1, -1}, {51932, -1, -1, -1}, {51933, -1, -1, -1}, {51934, -1, -1, -1}, {51935, -1, -1, -1}, {51937, -1, -1, -1}, {51938, -1, -1, -1}, {51939, -1, -1, -1}, {51940, -1, -1, -1}, {51941, -1, -1, -1}, {51942, -1, -1, -1}, {51943, -1, -1, -1}, {51944, -1, -1, -1}, {51945, -1, -1, -1}, {51946, -1, -1, -1}, {51947, -1, -1, -1}, {51949, -1, -1, -1}, {51950, -1, -1, -1}, {51951, -1, -1, -1}, {51952, -1, -1, -1}, {51953, -1, -1, -1}, {51954, -1, -1, -1}, {51955, -1, -1, -1}, {51957, -1, -1, -1}, {51958, -1, -1, -1}, {51959, -1, -1, -1}, {51960, -1, -1, -1}, {51961, -1, -1, -1}, {51962, -1, -1, -1}, {51963, -1, -1, -1}, {51964, -1, -1, -1}, {51965, -1, -1, -1}, {51966, -1, -1, -1}, {51967, -1, -1, -1}, {51968, -1, -1, -1}, {51969, -1, -1, -1}, {51970, -1, -1, -1}, {51971, -1, -1, -1}, {51972, -1, -1, -1}, {51973, -1, -1, -1}, {51974, -1, -1, -1}, {51975, -1, -1, -1}, {51977, -1, -1, -1}, {51978, -1, -1, -1}, {51979, -1, -1, -1}, {51980, -1, -1, -1}, {51981, -1, -1, -1}, {51982, -1, -1, -1}, {51983, -1, -1, -1}, {51985, -1, -1, -1}, {51986, -1, -1, -1}, {51987, -1, -1, -1}, {51989, -1, -1, -1}, {51990, -1, -1, -1}, {51991, -1, -1, -1}, {51993, -1, -1, -1}, {51994, -1, -1, -1}, {51995, -1, -1, -1}, {51996, -1, -1, -1}, {51997, -1, -1, -1}, {51998, -1, -1, -1}, {51999, -1, -1, -1}, {52002, -1, -1, -1}, {52003, -1, -1, -1}, {52004, -1, -1, -1}, {52005, -1, -1, -1}, {52006, -1, -1, -1}, {52007, -1, -1, -1}, {52008, -1, -1, -1}, {52009, -1, -1, -1}, {52010, -1, -1, -1}, {52011, -1, -1, -1}, {52012, -1, -1, -1}, {52013, -1, -1, -1}, {52014, -1, -1, -1}, {52015, -1, -1, -1}, {52016, -1, -1, -1}, {52017, -1, -1, -1}, {52018, -1, -1, -1}, {52019, -1, -1, -1}, {52020, -1, -1, -1}, {52021, -1, -1, -1}, {52022, -1, -1, -1}, {52023, -1, -1, -1}, {52024, -1, -1, -1}, {52025, -1, -1, -1}, {52026, -1, -1, -1}, {52027, -1, -1, -1}, {52028, -1, -1, -1}, {52029, -1, -1, -1}, {52030, -1, -1, -1}, {52031, -1, -1, -1}, {52032, -1, -1, -1}, {52034, -1, -1, -1}, {52035, -1, -1, -1}, {52036, -1, -1, -1}, {52037, -1, -1, -1}, {52038, -1, -1, -1}, {52039, -1, -1, -1}, {52042, -1, -1, -1}, {52043, -1, -1, -1}, {52045, -1, -1, -1}, {52046, -1, -1, -1}, {52047, -1, -1, -1}, {52049, -1, -1, -1}, {52050, -1, -1, -1}, {52051, -1, -1, -1}, {52052, -1, -1, -1}, {52053, -1, -1, -1}, {52054, -1, -1, -1}, {52055, -1, -1, -1}, {52058, -1, -1, -1}, {52059, -1, -1, -1}, {52060, -1, -1, -1}, {52062, -1, -1, -1}, {52063, -1, -1, -1}, {52064, -1, -1, -1}, {52065, -1, -1, -1}, {52066, -1, -1, -1}, {52067, -1, -1, -1}, {52069, -1, -1, -1}, {52070, -1, -1, -1}, {52071, -1, -1, -1}, {52072, -1, -1, -1}, {52073, -1, -1, -1}, {52074, -1, -1, -1}, {52075, -1, -1, -1} },
+ {{52076, -1, -1, -1}, {52077, -1, -1, -1}, {52078, -1, -1, -1}, {52079, -1, -1, -1}, {52080, -1, -1, -1}, {52081, -1, -1, -1}, {52082, -1, -1, -1}, {52083, -1, -1, -1}, {52084, -1, -1, -1}, {52085, -1, -1, -1}, {52086, -1, -1, -1}, {52087, -1, -1, -1}, {52090, -1, -1, -1}, {52091, -1, -1, -1}, {52092, -1, -1, -1}, {52093, -1, -1, -1}, {52094, -1, -1, -1}, {52095, -1, -1, -1}, {52096, -1, -1, -1}, {52097, -1, -1, -1}, {52098, -1, -1, -1}, {52099, -1, -1, -1}, {52100, -1, -1, -1}, {52101, -1, -1, -1}, {52102, -1, -1, -1}, {52103, -1, -1, -1}, {52104, -1, -1, -1}, {52105, -1, -1, -1}, {52106, -1, -1, -1}, {52107, -1, -1, -1}, {52108, -1, -1, -1}, {52109, -1, -1, -1}, {52110, -1, -1, -1}, {52111, -1, -1, -1}, {52112, -1, -1, -1}, {52113, -1, -1, -1}, {52114, -1, -1, -1}, {52115, -1, -1, -1}, {52116, -1, -1, -1}, {52117, -1, -1, -1}, {52118, -1, -1, -1}, {52119, -1, -1, -1}, {52120, -1, -1, -1}, {52121, -1, -1, -1}, {52122, -1, -1, -1}, {52123, -1, -1, -1}, {52125, -1, -1, -1}, {52126, -1, -1, -1}, {52127, -1, -1, -1}, {52128, -1, -1, -1}, {52129, -1, -1, -1}, {52130, -1, -1, -1}, {52131, -1, -1, -1}, {52132, -1, -1, -1}, {52133, -1, -1, -1}, {52134, -1, -1, -1}, {52135, -1, -1, -1}, {52136, -1, -1, -1}, {52137, -1, -1, -1}, {52138, -1, -1, -1}, {52139, -1, -1, -1}, {52140, -1, -1, -1}, {52141, -1, -1, -1}, {52142, -1, -1, -1}, {52143, -1, -1, -1}, {52144, -1, -1, -1}, {52145, -1, -1, -1}, {52146, -1, -1, -1}, {52147, -1, -1, -1}, {52148, -1, -1, -1}, {52149, -1, -1, -1}, {52150, -1, -1, -1}, {52151, -1, -1, -1}, {52153, -1, -1, -1}, {52154, -1, -1, -1}, {52155, -1, -1, -1}, {52156, -1, -1, -1}, {52157, -1, -1, -1}, {52158, -1, -1, -1}, {52159, -1, -1, -1}, {52160, -1, -1, -1}, {52161, -1, -1, -1}, {52162, -1, -1, -1}, {52163, -1, -1, -1}, {52164, -1, -1, -1}, {52165, -1, -1, -1}, {52166, -1, -1, -1}, {52167, -1, -1, -1}, {52168, -1, -1, -1}, {52169, -1, -1, -1}, {52170, -1, -1, -1}, {52171, -1, -1, -1}, {52172, -1, -1, -1}, {52173, -1, -1, -1}, {52174, -1, -1, -1}, {52175, -1, -1, -1}, {52176, -1, -1, -1}, {52177, -1, -1, -1}, {52178, -1, -1, -1}, {52179, -1, -1, -1}, {52181, -1, -1, -1}, {52182, -1, -1, -1}, {52183, -1, -1, -1}, {52184, -1, -1, -1}, {52185, -1, -1, -1}, {52186, -1, -1, -1}, {52187, -1, -1, -1}, {52188, -1, -1, -1}, {52189, -1, -1, -1}, {52190, -1, -1, -1}, {52191, -1, -1, -1}, {52192, -1, -1, -1}, {52193, -1, -1, -1}, {52194, -1, -1, -1}, {52195, -1, -1, -1}, {52197, -1, -1, -1}, {52198, -1, -1, -1}, {52200, -1, -1, -1}, {52202, -1, -1, -1}, {52203, -1, -1, -1}, {52204, -1, -1, -1}, {52205, -1, -1, -1}, {52206, -1, -1, -1}, {52207, -1, -1, -1}, {52208, -1, -1, -1}, {52209, -1, -1, -1}, {52210, -1, -1, -1}, {52211, -1, -1, -1}, {52212, -1, -1, -1}, {52213, -1, -1, -1}, {52214, -1, -1, -1}, {52215, -1, -1, -1}, {52216, -1, -1, -1}, {52217, -1, -1, -1}, {52218, -1, -1, -1}, {52219, -1, -1, -1}, {52220, -1, -1, -1}, {52221, -1, -1, -1}, {52222, -1, -1, -1}, {52223, -1, -1, -1}, {52224, -1, -1, -1}, {52225, -1, -1, -1}, {52226, -1, -1, -1}, {52227, -1, -1, -1}, {52228, -1, -1, -1}, {52229, -1, -1, -1}, {52230, -1, -1, -1}, {52231, -1, -1, -1}, {52232, -1, -1, -1}, {52233, -1, -1, -1}, {52234, -1, -1, -1}, {52235, -1, -1, -1}, {52238, -1, -1, -1}, {52239, -1, -1, -1}, {52241, -1, -1, -1}, {52242, -1, -1, -1}, {52243, -1, -1, -1}, {52245, -1, -1, -1}, {52246, -1, -1, -1}, {52247, -1, -1, -1}, {52248, -1, -1, -1}, {52249, -1, -1, -1}, {52250, -1, -1, -1}, {52251, -1, -1, -1}, {52254, -1, -1, -1}, {52255, -1, -1, -1}, {52256, -1, -1, -1}, {52259, -1, -1, -1}, {52260, -1, -1, -1}, {52261, -1, -1, -1}, {52262, -1, -1, -1}, {52266, -1, -1, -1}, {52267, -1, -1, -1}, {52269, -1, -1, -1}, {52271, -1, -1, -1}, {52273, -1, -1, -1}, {52274, -1, -1, -1}, {52275, -1, -1, -1}, {52276, -1, -1, -1}, {52277, -1, -1, -1}, {52278, -1, -1, -1}, {52279, -1, -1, -1}, {52282, -1, -1, -1}, {52287, -1, -1, -1}, {52288, -1, -1, -1}, {52289, -1, -1, -1}, {52290, -1, -1, -1}, {52291, -1, -1, -1}, {52294, -1, -1, -1}, {52295, -1, -1, -1}, {52297, -1, -1, -1}, {52298, -1, -1, -1}, {52299, -1, -1, -1}, {52301, -1, -1, -1}, {52302, -1, -1, -1}, {52303, -1, -1, -1}, {52304, -1, -1, -1}, {52305, -1, -1, -1}, {52306, -1, -1, -1}, {52307, -1, -1, -1}, {52310, -1, -1, -1}, {52314, -1, -1, -1}, {52315, -1, -1, -1}, {52316, -1, -1, -1}, {52317, -1, -1, -1}, {52318, -1, -1, -1}, {52319, -1, -1, -1}, {52321, -1, -1, -1}, {52322, -1, -1, -1}, {52323, -1, -1, -1}, {52325, -1, -1, -1}, {52327, -1, -1, -1}, {52329, -1, -1, -1}, {52330, -1, -1, -1}, {52331, -1, -1, -1}, {52332, -1, -1, -1}, {52333, -1, -1, -1}, {52334, -1, -1, -1}, {52335, -1, -1, -1}, {52337, -1, -1, -1}, {52338, -1, -1, -1}, {52339, -1, -1, -1}, {52340, -1, -1, -1}, {52342, -1, -1, -1}, {52343, -1, -1, -1}, {52344, -1, -1, -1}, {52345, -1, -1, -1}, {52346, -1, -1, -1}, {52347, -1, -1, -1}, {52348, -1, -1, -1}, {52349, -1, -1, -1}, {52350, -1, -1, -1}, {52351, -1, -1, -1}, {52352, -1, -1, -1}, {52353, -1, -1, -1}, {52354, -1, -1, -1}, {52355, -1, -1, -1}, {52356, -1, -1, -1}, {52357, -1, -1, -1}, {52358, -1, -1, -1}, {52359, -1, -1, -1}, {52360, -1, -1, -1}, {52361, -1, -1, -1}, {52362, -1, -1, -1}, {52363, -1, -1, -1}, {52364, -1, -1, -1}, {52365, -1, -1, -1}, {52366, -1, -1, -1}, {52367, -1, -1, -1}, {52368, -1, -1, -1}, {52369, -1, -1, -1}, {52370, -1, -1, -1}, {52371, -1, -1, -1}, {52372, -1, -1, -1}, {52373, -1, -1, -1}, {52374, -1, -1, -1} },
+ {{52375, -1, -1, -1}, {52378, -1, -1, -1}, {52379, -1, -1, -1}, {52381, -1, -1, -1}, {52382, -1, -1, -1}, {52383, -1, -1, -1}, {52385, -1, -1, -1}, {52386, -1, -1, -1}, {52387, -1, -1, -1}, {52388, -1, -1, -1}, {52389, -1, -1, -1}, {52390, -1, -1, -1}, {52391, -1, -1, -1}, {52394, -1, -1, -1}, {52398, -1, -1, -1}, {52399, -1, -1, -1}, {52400, -1, -1, -1}, {52401, -1, -1, -1}, {52402, -1, -1, -1}, {52403, -1, -1, -1}, {52406, -1, -1, -1}, {52407, -1, -1, -1}, {52409, -1, -1, -1}, {52410, -1, -1, -1}, {52411, -1, -1, -1}, {52413, -1, -1, -1}, {52414, -1, -1, -1}, {52415, -1, -1, -1}, {52416, -1, -1, -1}, {52417, -1, -1, -1}, {52418, -1, -1, -1}, {52419, -1, -1, -1}, {52422, -1, -1, -1}, {52424, -1, -1, -1}, {52426, -1, -1, -1}, {52427, -1, -1, -1}, {52428, -1, -1, -1}, {52429, -1, -1, -1}, {52430, -1, -1, -1}, {52431, -1, -1, -1}, {52433, -1, -1, -1}, {52434, -1, -1, -1}, {52435, -1, -1, -1}, {52437, -1, -1, -1}, {52438, -1, -1, -1}, {52439, -1, -1, -1}, {52440, -1, -1, -1}, {52441, -1, -1, -1}, {52442, -1, -1, -1}, {52443, -1, -1, -1}, {52444, -1, -1, -1}, {52445, -1, -1, -1}, {52446, -1, -1, -1}, {52447, -1, -1, -1}, {52448, -1, -1, -1}, {52449, -1, -1, -1}, {52450, -1, -1, -1}, {52451, -1, -1, -1}, {52453, -1, -1, -1}, {52454, -1, -1, -1}, {52455, -1, -1, -1}, {52456, -1, -1, -1}, {52457, -1, -1, -1}, {52458, -1, -1, -1}, {52459, -1, -1, -1}, {52461, -1, -1, -1}, {52462, -1, -1, -1}, {52463, -1, -1, -1}, {52465, -1, -1, -1}, {52466, -1, -1, -1}, {52467, -1, -1, -1}, {52468, -1, -1, -1}, {52469, -1, -1, -1}, {52470, -1, -1, -1}, {52471, -1, -1, -1}, {52472, -1, -1, -1}, {52473, -1, -1, -1}, {52474, -1, -1, -1}, {52475, -1, -1, -1}, {52476, -1, -1, -1}, {52477, -1, -1, -1}, {52478, -1, -1, -1}, {52479, -1, -1, -1}, {52480, -1, -1, -1}, {52482, -1, -1, -1}, {52483, -1, -1, -1}, {52484, -1, -1, -1}, {52485, -1, -1, -1}, {52486, -1, -1, -1}, {52487, -1, -1, -1}, {52490, -1, -1, -1}, {52491, -1, -1, -1}, {52493, -1, -1, -1}, {52494, -1, -1, -1}, {52495, -1, -1, -1}, {52497, -1, -1, -1}, {52498, -1, -1, -1}, {52499, -1, -1, -1}, {52500, -1, -1, -1}, {52501, -1, -1, -1}, {52502, -1, -1, -1}, {52503, -1, -1, -1}, {52506, -1, -1, -1}, {52508, -1, -1, -1}, {52510, -1, -1, -1}, {52511, -1, -1, -1}, {52512, -1, -1, -1}, {52513, -1, -1, -1}, {52514, -1, -1, -1}, {52515, -1, -1, -1}, {52517, -1, -1, -1}, {52518, -1, -1, -1}, {52519, -1, -1, -1}, {52521, -1, -1, -1}, {52522, -1, -1, -1}, {52523, -1, -1, -1}, {52525, -1, -1, -1}, {52526, -1, -1, -1}, {52527, -1, -1, -1}, {52528, -1, -1, -1}, {52529, -1, -1, -1}, {52530, -1, -1, -1}, {52531, -1, -1, -1}, {52532, -1, -1, -1}, {52533, -1, -1, -1}, {52534, -1, -1, -1}, {52535, -1, -1, -1}, {52536, -1, -1, -1}, {52538, -1, -1, -1}, {52539, -1, -1, -1}, {52540, -1, -1, -1}, {52541, -1, -1, -1}, {52542, -1, -1, -1}, {52543, -1, -1, -1}, {52544, -1, -1, -1}, {52545, -1, -1, -1}, {52546, -1, -1, -1}, {52547, -1, -1, -1}, {52548, -1, -1, -1}, {52549, -1, -1, -1}, {52550, -1, -1, -1}, {52551, -1, -1, -1}, {52552, -1, -1, -1}, {52553, -1, -1, -1}, {52554, -1, -1, -1}, {52555, -1, -1, -1}, {52556, -1, -1, -1}, {52557, -1, -1, -1}, {52558, -1, -1, -1}, {52559, -1, -1, -1}, {52560, -1, -1, -1}, {52561, -1, -1, -1}, {52562, -1, -1, -1}, {52563, -1, -1, -1}, {52564, -1, -1, -1}, {52565, -1, -1, -1}, {52566, -1, -1, -1}, {52567, -1, -1, -1}, {52568, -1, -1, -1}, {52569, -1, -1, -1}, {52570, -1, -1, -1}, {52571, -1, -1, -1}, {52573, -1, -1, -1}, {52574, -1, -1, -1}, {52575, -1, -1, -1}, {52577, -1, -1, -1}, {52578, -1, -1, -1}, {52579, -1, -1, -1}, {52581, -1, -1, -1}, {52582, -1, -1, -1}, {52583, -1, -1, -1}, {52584, -1, -1, -1}, {52585, -1, -1, -1}, {52586, -1, -1, -1}, {52587, -1, -1, -1}, {52590, -1, -1, -1}, {52592, -1, -1, -1}, {52594, -1, -1, -1}, {52595, -1, -1, -1}, {52596, -1, -1, -1}, {52597, -1, -1, -1}, {52598, -1, -1, -1}, {52599, -1, -1, -1}, {52601, -1, -1, -1}, {52602, -1, -1, -1}, {52603, -1, -1, -1}, {52604, -1, -1, -1}, {52605, -1, -1, -1}, {52606, -1, -1, -1}, {52607, -1, -1, -1}, {52608, -1, -1, -1}, {52609, -1, -1, -1}, {52610, -1, -1, -1}, {52611, -1, -1, -1}, {52612, -1, -1, -1}, {52613, -1, -1, -1}, {52614, -1, -1, -1}, {52615, -1, -1, -1}, {52617, -1, -1, -1}, {52618, -1, -1, -1}, {52619, -1, -1, -1}, {52620, -1, -1, -1}, {52621, -1, -1, -1}, {52622, -1, -1, -1}, {52623, -1, -1, -1}, {52624, -1, -1, -1}, {52625, -1, -1, -1}, {52626, -1, -1, -1}, {52627, -1, -1, -1}, {52630, -1, -1, -1}, {52631, -1, -1, -1}, {52633, -1, -1, -1}, {52634, -1, -1, -1}, {52635, -1, -1, -1}, {52637, -1, -1, -1}, {52638, -1, -1, -1}, {52639, -1, -1, -1}, {52640, -1, -1, -1}, {52641, -1, -1, -1}, {52642, -1, -1, -1}, {52643, -1, -1, -1}, {52646, -1, -1, -1}, {52648, -1, -1, -1}, {52650, -1, -1, -1}, {52651, -1, -1, -1}, {52652, -1, -1, -1}, {52653, -1, -1, -1}, {52654, -1, -1, -1}, {52655, -1, -1, -1}, {52657, -1, -1, -1}, {52658, -1, -1, -1}, {52659, -1, -1, -1}, {52660, -1, -1, -1}, {52661, -1, -1, -1}, {52662, -1, -1, -1}, {52663, -1, -1, -1}, {52664, -1, -1, -1}, {52665, -1, -1, -1}, {52666, -1, -1, -1}, {52667, -1, -1, -1}, {52668, -1, -1, -1}, {52669, -1, -1, -1}, {52670, -1, -1, -1}, {52671, -1, -1, -1}, {52672, -1, -1, -1}, {52673, -1, -1, -1}, {52674, -1, -1, -1}, {52675, -1, -1, -1}, {52677, -1, -1, -1}, {52678, -1, -1, -1}, {52679, -1, -1, -1}, {52680, -1, -1, -1}, {52681, -1, -1, -1}, {52682, -1, -1, -1}, {52683, -1, -1, -1}, {52685, -1, -1, -1} },
+ {{52686, -1, -1, -1}, {52687, -1, -1, -1}, {52689, -1, -1, -1}, {52690, -1, -1, -1}, {52691, -1, -1, -1}, {52692, -1, -1, -1}, {52693, -1, -1, -1}, {52694, -1, -1, -1}, {52695, -1, -1, -1}, {52696, -1, -1, -1}, {52697, -1, -1, -1}, {52698, -1, -1, -1}, {52699, -1, -1, -1}, {52700, -1, -1, -1}, {52701, -1, -1, -1}, {52702, -1, -1, -1}, {52703, -1, -1, -1}, {52704, -1, -1, -1}, {52705, -1, -1, -1}, {52706, -1, -1, -1}, {52707, -1, -1, -1}, {52708, -1, -1, -1}, {52709, -1, -1, -1}, {52710, -1, -1, -1}, {52711, -1, -1, -1}, {52713, -1, -1, -1}, {52714, -1, -1, -1}, {52715, -1, -1, -1}, {52717, -1, -1, -1}, {52718, -1, -1, -1}, {52719, -1, -1, -1}, {52721, -1, -1, -1}, {52722, -1, -1, -1}, {52723, -1, -1, -1}, {52724, -1, -1, -1}, {52725, -1, -1, -1}, {52726, -1, -1, -1}, {52727, -1, -1, -1}, {52730, -1, -1, -1}, {52732, -1, -1, -1}, {52734, -1, -1, -1}, {52735, -1, -1, -1}, {52736, -1, -1, -1}, {52737, -1, -1, -1}, {52738, -1, -1, -1}, {52739, -1, -1, -1}, {52741, -1, -1, -1}, {52742, -1, -1, -1}, {52743, -1, -1, -1}, {52745, -1, -1, -1}, {52746, -1, -1, -1}, {52747, -1, -1, -1}, {52749, -1, -1, -1}, {52750, -1, -1, -1}, {52751, -1, -1, -1}, {52752, -1, -1, -1}, {52753, -1, -1, -1}, {52754, -1, -1, -1}, {52755, -1, -1, -1}, {52757, -1, -1, -1}, {52758, -1, -1, -1}, {52759, -1, -1, -1}, {52760, -1, -1, -1}, {52762, -1, -1, -1}, {52763, -1, -1, -1}, {52764, -1, -1, -1}, {52765, -1, -1, -1}, {52766, -1, -1, -1}, {52767, -1, -1, -1}, {52770, -1, -1, -1}, {52771, -1, -1, -1}, {52773, -1, -1, -1}, {52774, -1, -1, -1}, {52775, -1, -1, -1}, {52777, -1, -1, -1}, {52778, -1, -1, -1}, {52779, -1, -1, -1}, {52780, -1, -1, -1}, {52781, -1, -1, -1}, {52782, -1, -1, -1}, {52783, -1, -1, -1}, {52786, -1, -1, -1}, {52788, -1, -1, -1}, {52790, -1, -1, -1}, {52791, -1, -1, -1}, {52792, -1, -1, -1}, {52793, -1, -1, -1}, {52794, -1, -1, -1}, {52795, -1, -1, -1}, {52796, -1, -1, -1}, {52797, -1, -1, -1}, {52798, -1, -1, -1}, {52799, -1, -1, -1}, {52800, -1, -1, -1}, {52801, -1, -1, -1}, {52802, -1, -1, -1}, {52803, -1, -1, -1}, {52804, -1, -1, -1}, {52805, -1, -1, -1}, {52806, -1, -1, -1}, {52807, -1, -1, -1}, {52808, -1, -1, -1}, {52809, -1, -1, -1}, {52810, -1, -1, -1}, {52811, -1, -1, -1}, {52812, -1, -1, -1}, {52813, -1, -1, -1}, {52814, -1, -1, -1}, {52815, -1, -1, -1}, {52816, -1, -1, -1}, {52817, -1, -1, -1}, {52818, -1, -1, -1}, {52819, -1, -1, -1}, {52820, -1, -1, -1}, {52821, -1, -1, -1}, {52822, -1, -1, -1}, {52823, -1, -1, -1}, {52826, -1, -1, -1}, {52827, -1, -1, -1}, {52829, -1, -1, -1}, {52830, -1, -1, -1}, {52834, -1, -1, -1}, {52835, -1, -1, -1}, {52836, -1, -1, -1}, {52837, -1, -1, -1}, {52838, -1, -1, -1}, {52839, -1, -1, -1}, {52842, -1, -1, -1}, {52844, -1, -1, -1}, {52846, -1, -1, -1}, {52847, -1, -1, -1}, {52848, -1, -1, -1}, {52849, -1, -1, -1}, {52850, -1, -1, -1}, {52851, -1, -1, -1}, {52854, -1, -1, -1}, {52855, -1, -1, -1}, {52857, -1, -1, -1}, {52858, -1, -1, -1}, {52859, -1, -1, -1}, {52861, -1, -1, -1}, {52862, -1, -1, -1}, {52863, -1, -1, -1}, {52864, -1, -1, -1}, {52865, -1, -1, -1}, {52866, -1, -1, -1}, {52867, -1, -1, -1}, {52870, -1, -1, -1}, {52872, -1, -1, -1}, {52874, -1, -1, -1}, {52875, -1, -1, -1}, {52876, -1, -1, -1}, {52877, -1, -1, -1}, {52878, -1, -1, -1}, {52879, -1, -1, -1}, {52882, -1, -1, -1}, {52883, -1, -1, -1}, {52885, -1, -1, -1}, {52886, -1, -1, -1}, {52887, -1, -1, -1}, {52889, -1, -1, -1}, {52890, -1, -1, -1}, {52891, -1, -1, -1}, {52892, -1, -1, -1}, {52893, -1, -1, -1}, {52894, -1, -1, -1}, {52895, -1, -1, -1}, {52898, -1, -1, -1}, {52902, -1, -1, -1}, {52903, -1, -1, -1}, {52904, -1, -1, -1}, {52905, -1, -1, -1}, {52906, -1, -1, -1}, {52907, -1, -1, -1}, {52910, -1, -1, -1}, {52911, -1, -1, -1}, {52912, -1, -1, -1}, {52913, -1, -1, -1}, {52914, -1, -1, -1}, {52915, -1, -1, -1}, {52916, -1, -1, -1}, {52917, -1, -1, -1}, {52918, -1, -1, -1}, {52919, -1, -1, -1}, {52920, -1, -1, -1}, {52921, -1, -1, -1}, {52922, -1, -1, -1}, {52923, -1, -1, -1}, {52924, -1, -1, -1}, {52925, -1, -1, -1}, {52926, -1, -1, -1}, {52927, -1, -1, -1}, {52928, -1, -1, -1}, {52930, -1, -1, -1}, {52931, -1, -1, -1}, {52932, -1, -1, -1}, {52933, -1, -1, -1}, {52934, -1, -1, -1}, {52935, -1, -1, -1}, {52936, -1, -1, -1}, {52937, -1, -1, -1}, {52938, -1, -1, -1}, {52939, -1, -1, -1}, {52940, -1, -1, -1}, {52941, -1, -1, -1}, {52942, -1, -1, -1}, {52943, -1, -1, -1}, {52944, -1, -1, -1}, {52945, -1, -1, -1}, {52946, -1, -1, -1}, {52947, -1, -1, -1}, {52948, -1, -1, -1}, {52949, -1, -1, -1}, {52950, -1, -1, -1}, {52951, -1, -1, -1}, {52952, -1, -1, -1}, {52953, -1, -1, -1}, {52954, -1, -1, -1}, {52955, -1, -1, -1}, {52956, -1, -1, -1}, {52957, -1, -1, -1}, {52958, -1, -1, -1}, {52959, -1, -1, -1}, {52960, -1, -1, -1}, {52961, -1, -1, -1}, {52962, -1, -1, -1}, {52963, -1, -1, -1}, {52966, -1, -1, -1}, {52967, -1, -1, -1}, {52969, -1, -1, -1}, {52970, -1, -1, -1}, {52973, -1, -1, -1}, {52974, -1, -1, -1}, {52975, -1, -1, -1}, {52976, -1, -1, -1}, {52977, -1, -1, -1}, {52978, -1, -1, -1}, {52979, -1, -1, -1}, {52982, -1, -1, -1}, {52986, -1, -1, -1}, {52987, -1, -1, -1}, {52988, -1, -1, -1}, {52989, -1, -1, -1}, {52990, -1, -1, -1}, {52991, -1, -1, -1}, {52994, -1, -1, -1}, {52995, -1, -1, -1}, {52997, -1, -1, -1}, {52998, -1, -1, -1}, {52999, -1, -1, -1}, {53001, -1, -1, -1}, {53002, -1, -1, -1}, {53003, -1, -1, -1}, {53004, -1, -1, -1}, {53005, -1, -1, -1}, {53006, -1, -1, -1} },
+ {{53007, -1, -1, -1}, {53010, -1, -1, -1}, {53012, -1, -1, -1}, {53014, -1, -1, -1}, {53015, -1, -1, -1}, {53016, -1, -1, -1}, {53017, -1, -1, -1}, {53018, -1, -1, -1}, {53019, -1, -1, -1}, {53021, -1, -1, -1}, {53022, -1, -1, -1}, {53023, -1, -1, -1}, {53025, -1, -1, -1}, {53026, -1, -1, -1}, {53027, -1, -1, -1}, {53029, -1, -1, -1}, {53030, -1, -1, -1}, {53031, -1, -1, -1}, {53032, -1, -1, -1}, {53033, -1, -1, -1}, {53034, -1, -1, -1}, {53035, -1, -1, -1}, {53038, -1, -1, -1}, {53042, -1, -1, -1}, {53043, -1, -1, -1}, {53044, -1, -1, -1}, {53045, -1, -1, -1}, {53046, -1, -1, -1}, {53047, -1, -1, -1}, {53049, -1, -1, -1}, {53050, -1, -1, -1}, {53051, -1, -1, -1}, {53052, -1, -1, -1}, {53053, -1, -1, -1}, {53054, -1, -1, -1}, {53055, -1, -1, -1}, {53056, -1, -1, -1}, {53057, -1, -1, -1}, {53058, -1, -1, -1}, {53059, -1, -1, -1}, {53060, -1, -1, -1}, {53061, -1, -1, -1}, {53062, -1, -1, -1}, {53063, -1, -1, -1}, {53064, -1, -1, -1}, {53065, -1, -1, -1}, {53066, -1, -1, -1}, {53067, -1, -1, -1}, {53068, -1, -1, -1}, {53069, -1, -1, -1}, {53070, -1, -1, -1}, {53071, -1, -1, -1}, {53072, -1, -1, -1}, {53073, -1, -1, -1}, {53074, -1, -1, -1}, {53075, -1, -1, -1}, {53078, -1, -1, -1}, {53079, -1, -1, -1}, {53081, -1, -1, -1}, {53082, -1, -1, -1}, {53083, -1, -1, -1}, {53085, -1, -1, -1}, {53086, -1, -1, -1}, {53087, -1, -1, -1}, {53088, -1, -1, -1}, {53089, -1, -1, -1}, {53090, -1, -1, -1}, {53091, -1, -1, -1}, {53094, -1, -1, -1}, {53096, -1, -1, -1}, {53098, -1, -1, -1}, {53099, -1, -1, -1}, {53100, -1, -1, -1}, {53101, -1, -1, -1}, {53102, -1, -1, -1}, {53103, -1, -1, -1}, {53106, -1, -1, -1}, {53107, -1, -1, -1}, {53109, -1, -1, -1}, {53110, -1, -1, -1}, {53111, -1, -1, -1}, {53113, -1, -1, -1}, {53114, -1, -1, -1}, {53115, -1, -1, -1}, {53116, -1, -1, -1}, {53117, -1, -1, -1}, {53118, -1, -1, -1}, {53119, -1, -1, -1}, {53121, -1, -1, -1}, {53122, -1, -1, -1}, {53123, -1, -1, -1}, {53124, -1, -1, -1}, {53126, -1, -1, -1}, {53127, -1, -1, -1}, {53128, -1, -1, -1}, {53129, -1, -1, -1}, {53130, -1, -1, -1}, {53131, -1, -1, -1}, {53133, -1, -1, -1}, {53134, -1, -1, -1}, {53135, -1, -1, -1}, {53136, -1, -1, -1}, {53137, -1, -1, -1}, {53138, -1, -1, -1}, {53139, -1, -1, -1}, {53140, -1, -1, -1}, {53141, -1, -1, -1}, {53142, -1, -1, -1}, {53143, -1, -1, -1}, {53144, -1, -1, -1}, {53145, -1, -1, -1}, {53146, -1, -1, -1}, {53147, -1, -1, -1}, {53148, -1, -1, -1}, {53149, -1, -1, -1}, {53150, -1, -1, -1}, {53151, -1, -1, -1}, {53152, -1, -1, -1}, {53154, -1, -1, -1}, {53155, -1, -1, -1}, {53156, -1, -1, -1}, {53157, -1, -1, -1}, {53158, -1, -1, -1}, {53159, -1, -1, -1}, {53161, -1, -1, -1}, {53162, -1, -1, -1}, {53163, -1, -1, -1}, {53164, -1, -1, -1}, {53165, -1, -1, -1}, {53166, -1, -1, -1}, {53167, -1, -1, -1}, {53169, -1, -1, -1}, {53170, -1, -1, -1}, {53171, -1, -1, -1}, {53172, -1, -1, -1}, {53173, -1, -1, -1}, {53174, -1, -1, -1}, {53175, -1, -1, -1}, {53176, -1, -1, -1}, {53177, -1, -1, -1}, {53178, -1, -1, -1}, {53179, -1, -1, -1}, {53180, -1, -1, -1}, {53181, -1, -1, -1}, {53182, -1, -1, -1}, {53183, -1, -1, -1}, {53184, -1, -1, -1}, {53185, -1, -1, -1}, {53186, -1, -1, -1}, {53187, -1, -1, -1}, {53189, -1, -1, -1}, {53190, -1, -1, -1}, {53191, -1, -1, -1}, {53192, -1, -1, -1}, {53193, -1, -1, -1}, {53194, -1, -1, -1}, {53195, -1, -1, -1}, {53196, -1, -1, -1}, {53197, -1, -1, -1}, {53198, -1, -1, -1}, {53199, -1, -1, -1}, {53200, -1, -1, -1}, {53201, -1, -1, -1}, {53202, -1, -1, -1}, {53203, -1, -1, -1}, {53204, -1, -1, -1}, {53205, -1, -1, -1}, {53206, -1, -1, -1}, {53207, -1, -1, -1}, {53208, -1, -1, -1}, {53209, -1, -1, -1}, {53210, -1, -1, -1}, {53211, -1, -1, -1}, {53212, -1, -1, -1}, {53213, -1, -1, -1}, {53214, -1, -1, -1}, {53215, -1, -1, -1}, {53218, -1, -1, -1}, {53219, -1, -1, -1}, {53221, -1, -1, -1}, {53222, -1, -1, -1}, {53223, -1, -1, -1}, {53225, -1, -1, -1}, {53226, -1, -1, -1}, {53227, -1, -1, -1}, {53228, -1, -1, -1}, {53229, -1, -1, -1}, {53230, -1, -1, -1}, {53231, -1, -1, -1}, {53234, -1, -1, -1}, {53236, -1, -1, -1}, {53238, -1, -1, -1}, {53239, -1, -1, -1}, {53240, -1, -1, -1}, {53241, -1, -1, -1}, {53242, -1, -1, -1}, {53243, -1, -1, -1}, {53245, -1, -1, -1}, {53246, -1, -1, -1}, {53247, -1, -1, -1}, {53249, -1, -1, -1}, {53250, -1, -1, -1}, {53251, -1, -1, -1}, {53253, -1, -1, -1}, {53254, -1, -1, -1}, {53255, -1, -1, -1}, {53256, -1, -1, -1}, {53257, -1, -1, -1}, {53258, -1, -1, -1}, {53259, -1, -1, -1}, {53260, -1, -1, -1}, {53261, -1, -1, -1}, {53262, -1, -1, -1}, {53263, -1, -1, -1}, {53264, -1, -1, -1}, {53266, -1, -1, -1}, {53267, -1, -1, -1}, {53268, -1, -1, -1}, {53269, -1, -1, -1}, {53270, -1, -1, -1}, {53271, -1, -1, -1}, {53273, -1, -1, -1}, {53274, -1, -1, -1}, {53275, -1, -1, -1}, {53276, -1, -1, -1}, {53277, -1, -1, -1}, {53278, -1, -1, -1}, {53279, -1, -1, -1}, {53280, -1, -1, -1}, {53281, -1, -1, -1}, {53282, -1, -1, -1}, {53283, -1, -1, -1}, {53284, -1, -1, -1}, {53285, -1, -1, -1}, {53286, -1, -1, -1}, {53287, -1, -1, -1}, {53288, -1, -1, -1}, {53289, -1, -1, -1}, {53290, -1, -1, -1}, {53291, -1, -1, -1}, {53292, -1, -1, -1}, {53294, -1, -1, -1}, {53295, -1, -1, -1}, {53296, -1, -1, -1}, {53297, -1, -1, -1}, {53298, -1, -1, -1}, {53299, -1, -1, -1}, {53302, -1, -1, -1}, {53303, -1, -1, -1}, {53305, -1, -1, -1}, {53306, -1, -1, -1}, {53307, -1, -1, -1}, {53309, -1, -1, -1}, {53310, -1, -1, -1}, {53311, -1, -1, -1}, {53312, -1, -1, -1} },
+ {{53313, -1, -1, -1}, {53314, -1, -1, -1}, {53315, -1, -1, -1}, {53318, -1, -1, -1}, {53320, -1, -1, -1}, {53322, -1, -1, -1}, {53323, -1, -1, -1}, {53324, -1, -1, -1}, {53325, -1, -1, -1}, {53326, -1, -1, -1}, {53327, -1, -1, -1}, {53329, -1, -1, -1}, {53330, -1, -1, -1}, {53331, -1, -1, -1}, {53333, -1, -1, -1}, {53334, -1, -1, -1}, {53335, -1, -1, -1}, {53337, -1, -1, -1}, {53338, -1, -1, -1}, {53339, -1, -1, -1}, {53340, -1, -1, -1}, {53341, -1, -1, -1}, {53342, -1, -1, -1}, {53343, -1, -1, -1}, {53345, -1, -1, -1}, {53346, -1, -1, -1}, {53347, -1, -1, -1}, {53348, -1, -1, -1}, {53349, -1, -1, -1}, {53350, -1, -1, -1}, {53351, -1, -1, -1}, {53352, -1, -1, -1}, {53353, -1, -1, -1}, {53354, -1, -1, -1}, {53355, -1, -1, -1}, {53358, -1, -1, -1}, {53359, -1, -1, -1}, {53361, -1, -1, -1}, {53362, -1, -1, -1}, {53363, -1, -1, -1}, {53365, -1, -1, -1}, {53366, -1, -1, -1}, {53367, -1, -1, -1}, {53368, -1, -1, -1}, {53369, -1, -1, -1}, {53370, -1, -1, -1}, {53371, -1, -1, -1}, {53374, -1, -1, -1}, {53375, -1, -1, -1}, {53376, -1, -1, -1}, {53378, -1, -1, -1}, {53379, -1, -1, -1}, {53380, -1, -1, -1}, {53381, -1, -1, -1}, {53382, -1, -1, -1}, {53383, -1, -1, -1}, {53384, -1, -1, -1}, {53385, -1, -1, -1}, {53386, -1, -1, -1}, {53387, -1, -1, -1}, {53388, -1, -1, -1}, {53389, -1, -1, -1}, {53390, -1, -1, -1}, {53391, -1, -1, -1}, {53392, -1, -1, -1}, {53393, -1, -1, -1}, {53394, -1, -1, -1}, {53395, -1, -1, -1}, {53396, -1, -1, -1}, {53397, -1, -1, -1}, {53398, -1, -1, -1}, {53399, -1, -1, -1}, {53400, -1, -1, -1}, {53401, -1, -1, -1}, {53402, -1, -1, -1}, {53403, -1, -1, -1}, {53404, -1, -1, -1}, {53405, -1, -1, -1}, {53406, -1, -1, -1}, {53407, -1, -1, -1}, {53408, -1, -1, -1}, {53409, -1, -1, -1}, {53410, -1, -1, -1}, {53411, -1, -1, -1}, {53414, -1, -1, -1}, {53415, -1, -1, -1}, {53417, -1, -1, -1}, {53418, -1, -1, -1}, {53419, -1, -1, -1}, {53421, -1, -1, -1}, {53422, -1, -1, -1}, {53423, -1, -1, -1}, {53424, -1, -1, -1}, {53425, -1, -1, -1}, {53426, -1, -1, -1}, {53427, -1, -1, -1}, {53430, -1, -1, -1}, {53432, -1, -1, -1}, {53434, -1, -1, -1}, {53435, -1, -1, -1}, {53436, -1, -1, -1}, {53437, -1, -1, -1}, {53438, -1, -1, -1}, {53439, -1, -1, -1}, {53442, -1, -1, -1}, {53443, -1, -1, -1}, {53445, -1, -1, -1}, {53446, -1, -1, -1}, {53447, -1, -1, -1}, {53450, -1, -1, -1}, {53451, -1, -1, -1}, {53452, -1, -1, -1}, {53453, -1, -1, -1}, {53454, -1, -1, -1}, {53455, -1, -1, -1}, {53458, -1, -1, -1}, {53462, -1, -1, -1}, {53463, -1, -1, -1}, {53464, -1, -1, -1}, {53465, -1, -1, -1}, {53466, -1, -1, -1}, {53467, -1, -1, -1}, {53470, -1, -1, -1}, {53471, -1, -1, -1}, {53473, -1, -1, -1}, {53474, -1, -1, -1}, {53475, -1, -1, -1}, {53477, -1, -1, -1}, {53478, -1, -1, -1}, {53479, -1, -1, -1}, {53480, -1, -1, -1}, {53481, -1, -1, -1}, {53482, -1, -1, -1}, {53483, -1, -1, -1}, {53486, -1, -1, -1}, {53490, -1, -1, -1}, {53491, -1, -1, -1}, {53492, -1, -1, -1}, {53493, -1, -1, -1}, {53494, -1, -1, -1}, {53495, -1, -1, -1}, {53497, -1, -1, -1}, {53498, -1, -1, -1}, {53499, -1, -1, -1}, {53500, -1, -1, -1}, {53501, -1, -1, -1}, {53502, -1, -1, -1}, {53503, -1, -1, -1}, {53504, -1, -1, -1}, {53505, -1, -1, -1}, {53506, -1, -1, -1}, {53507, -1, -1, -1}, {53508, -1, -1, -1}, {53509, -1, -1, -1}, {53510, -1, -1, -1}, {53511, -1, -1, -1}, {53512, -1, -1, -1}, {53513, -1, -1, -1}, {53514, -1, -1, -1}, {53515, -1, -1, -1}, {53516, -1, -1, -1}, {53518, -1, -1, -1}, {53519, -1, -1, -1}, {53520, -1, -1, -1}, {53521, -1, -1, -1}, {53522, -1, -1, -1}, {53523, -1, -1, -1}, {53524, -1, -1, -1}, {53525, -1, -1, -1}, {53526, -1, -1, -1}, {53527, -1, -1, -1}, {53528, -1, -1, -1}, {53529, -1, -1, -1}, {53530, -1, -1, -1}, {53531, -1, -1, -1}, {53532, -1, -1, -1}, {53533, -1, -1, -1}, {53534, -1, -1, -1}, {53535, -1, -1, -1}, {53536, -1, -1, -1}, {53537, -1, -1, -1}, {53538, -1, -1, -1}, {53539, -1, -1, -1}, {53540, -1, -1, -1}, {53541, -1, -1, -1}, {53542, -1, -1, -1}, {53543, -1, -1, -1}, {53544, -1, -1, -1}, {53545, -1, -1, -1}, {53546, -1, -1, -1}, {53547, -1, -1, -1}, {53548, -1, -1, -1}, {53549, -1, -1, -1}, {53550, -1, -1, -1}, {53551, -1, -1, -1}, {53554, -1, -1, -1}, {53555, -1, -1, -1}, {53557, -1, -1, -1}, {53558, -1, -1, -1}, {53559, -1, -1, -1}, {53561, -1, -1, -1}, {53563, -1, -1, -1}, {53564, -1, -1, -1}, {53565, -1, -1, -1}, {53566, -1, -1, -1}, {53567, -1, -1, -1}, {53570, -1, -1, -1}, {53574, -1, -1, -1}, {53575, -1, -1, -1}, {53576, -1, -1, -1}, {53577, -1, -1, -1}, {53578, -1, -1, -1}, {53579, -1, -1, -1}, {53582, -1, -1, -1}, {53583, -1, -1, -1}, {53585, -1, -1, -1}, {53586, -1, -1, -1}, {53587, -1, -1, -1}, {53589, -1, -1, -1}, {53590, -1, -1, -1}, {53591, -1, -1, -1}, {53592, -1, -1, -1}, {53593, -1, -1, -1}, {53594, -1, -1, -1}, {53595, -1, -1, -1}, {53598, -1, -1, -1}, {53600, -1, -1, -1}, {53602, -1, -1, -1}, {53603, -1, -1, -1}, {53604, -1, -1, -1}, {53605, -1, -1, -1}, {53606, -1, -1, -1}, {53607, -1, -1, -1}, {53609, -1, -1, -1}, {53610, -1, -1, -1}, {53611, -1, -1, -1}, {53613, -1, -1, -1}, {53614, -1, -1, -1}, {53615, -1, -1, -1}, {53616, -1, -1, -1}, {53617, -1, -1, -1}, {53618, -1, -1, -1}, {53619, -1, -1, -1}, {53620, -1, -1, -1}, {53621, -1, -1, -1}, {53622, -1, -1, -1}, {53623, -1, -1, -1}, {53624, -1, -1, -1}, {53625, -1, -1, -1}, {53626, -1, -1, -1}, {53627, -1, -1, -1}, {53629, -1, -1, -1}, {53630, -1, -1, -1}, {53631, -1, -1, -1}, {53632, -1, -1, -1}, {53633, -1, -1, -1} },
+ {{53634, -1, -1, -1}, {53635, -1, -1, -1}, {53637, -1, -1, -1}, {53638, -1, -1, -1}, {53639, -1, -1, -1}, {53641, -1, -1, -1}, {53642, -1, -1, -1}, {53643, -1, -1, -1}, {53644, -1, -1, -1}, {53645, -1, -1, -1}, {53646, -1, -1, -1}, {53647, -1, -1, -1}, {53648, -1, -1, -1}, {53649, -1, -1, -1}, {53650, -1, -1, -1}, {53651, -1, -1, -1}, {53652, -1, -1, -1}, {53653, -1, -1, -1}, {53654, -1, -1, -1}, {53655, -1, -1, -1}, {53656, -1, -1, -1}, {53657, -1, -1, -1}, {53658, -1, -1, -1}, {53659, -1, -1, -1}, {53660, -1, -1, -1}, {53661, -1, -1, -1}, {53662, -1, -1, -1}, {53663, -1, -1, -1}, {53666, -1, -1, -1}, {53667, -1, -1, -1}, {53669, -1, -1, -1}, {53670, -1, -1, -1}, {53671, -1, -1, -1}, {53673, -1, -1, -1}, {53674, -1, -1, -1}, {53675, -1, -1, -1}, {53676, -1, -1, -1}, {53677, -1, -1, -1}, {53678, -1, -1, -1}, {53679, -1, -1, -1}, {53682, -1, -1, -1}, {53684, -1, -1, -1}, {53686, -1, -1, -1}, {53687, -1, -1, -1}, {53688, -1, -1, -1}, {53689, -1, -1, -1}, {53691, -1, -1, -1}, {53693, -1, -1, -1}, {53694, -1, -1, -1}, {53695, -1, -1, -1}, {53697, -1, -1, -1}, {53698, -1, -1, -1}, {53699, -1, -1, -1}, {53700, -1, -1, -1}, {53701, -1, -1, -1}, {53702, -1, -1, -1}, {53703, -1, -1, -1}, {53704, -1, -1, -1}, {53705, -1, -1, -1}, {53706, -1, -1, -1}, {53707, -1, -1, -1}, {53708, -1, -1, -1}, {53709, -1, -1, -1}, {53710, -1, -1, -1}, {53711, -1, -1, -1}, {53712, -1, -1, -1}, {53713, -1, -1, -1}, {53714, -1, -1, -1}, {53715, -1, -1, -1}, {53716, -1, -1, -1}, {53717, -1, -1, -1}, {53718, -1, -1, -1}, {53719, -1, -1, -1}, {53721, -1, -1, -1}, {53722, -1, -1, -1}, {53723, -1, -1, -1}, {53724, -1, -1, -1}, {53725, -1, -1, -1}, {53726, -1, -1, -1}, {53727, -1, -1, -1}, {53728, -1, -1, -1}, {53729, -1, -1, -1}, {53730, -1, -1, -1}, {53731, -1, -1, -1}, {53732, -1, -1, -1}, {53733, -1, -1, -1}, {53734, -1, -1, -1}, {53735, -1, -1, -1}, {53736, -1, -1, -1}, {53737, -1, -1, -1}, {53738, -1, -1, -1}, {53739, -1, -1, -1}, {53740, -1, -1, -1}, {53741, -1, -1, -1}, {53742, -1, -1, -1}, {53743, -1, -1, -1}, {53744, -1, -1, -1}, {53745, -1, -1, -1}, {53746, -1, -1, -1}, {53747, -1, -1, -1}, {53749, -1, -1, -1}, {53750, -1, -1, -1}, {53751, -1, -1, -1}, {53753, -1, -1, -1}, {53754, -1, -1, -1}, {53755, -1, -1, -1}, {53756, -1, -1, -1}, {53757, -1, -1, -1}, {53758, -1, -1, -1}, {53759, -1, -1, -1}, {53760, -1, -1, -1}, {53761, -1, -1, -1}, {53762, -1, -1, -1}, {53763, -1, -1, -1}, {53764, -1, -1, -1}, {53765, -1, -1, -1}, {53766, -1, -1, -1}, {53768, -1, -1, -1}, {53770, -1, -1, -1}, {53771, -1, -1, -1}, {53772, -1, -1, -1}, {53773, -1, -1, -1}, {53774, -1, -1, -1}, {53775, -1, -1, -1}, {53777, -1, -1, -1}, {53778, -1, -1, -1}, {53779, -1, -1, -1}, {53780, -1, -1, -1}, {53781, -1, -1, -1}, {53782, -1, -1, -1}, {53783, -1, -1, -1}, {53784, -1, -1, -1}, {53785, -1, -1, -1}, {53786, -1, -1, -1}, {53787, -1, -1, -1}, {53788, -1, -1, -1}, {53789, -1, -1, -1}, {53790, -1, -1, -1}, {53791, -1, -1, -1}, {53792, -1, -1, -1}, {53793, -1, -1, -1}, {53794, -1, -1, -1}, {53795, -1, -1, -1}, {53796, -1, -1, -1}, {53797, -1, -1, -1}, {53798, -1, -1, -1}, {53799, -1, -1, -1}, {53800, -1, -1, -1}, {53801, -1, -1, -1}, {53802, -1, -1, -1}, {53803, -1, -1, -1}, {53806, -1, -1, -1}, {53807, -1, -1, -1}, {53809, -1, -1, -1}, {53810, -1, -1, -1}, {53811, -1, -1, -1}, {53813, -1, -1, -1}, {53814, -1, -1, -1}, {53815, -1, -1, -1}, {53816, -1, -1, -1}, {53817, -1, -1, -1}, {53818, -1, -1, -1}, {53819, -1, -1, -1}, {53822, -1, -1, -1}, {53824, -1, -1, -1}, {53826, -1, -1, -1}, {53827, -1, -1, -1}, {53828, -1, -1, -1}, {53829, -1, -1, -1}, {53830, -1, -1, -1}, {53831, -1, -1, -1}, {53833, -1, -1, -1}, {53834, -1, -1, -1}, {53835, -1, -1, -1}, {53836, -1, -1, -1}, {53837, -1, -1, -1}, {53838, -1, -1, -1}, {53839, -1, -1, -1}, {53840, -1, -1, -1}, {53841, -1, -1, -1}, {53842, -1, -1, -1}, {53843, -1, -1, -1}, {53844, -1, -1, -1}, {53845, -1, -1, -1}, {53846, -1, -1, -1}, {53847, -1, -1, -1}, {53848, -1, -1, -1}, {53849, -1, -1, -1}, {53850, -1, -1, -1}, {53851, -1, -1, -1}, {53853, -1, -1, -1}, {53854, -1, -1, -1}, {53855, -1, -1, -1}, {53856, -1, -1, -1}, {53857, -1, -1, -1}, {53858, -1, -1, -1}, {53859, -1, -1, -1}, {53861, -1, -1, -1}, {53862, -1, -1, -1}, {53863, -1, -1, -1}, {53864, -1, -1, -1}, {53865, -1, -1, -1}, {53866, -1, -1, -1}, {53867, -1, -1, -1}, {53868, -1, -1, -1}, {53869, -1, -1, -1}, {53870, -1, -1, -1}, {53871, -1, -1, -1}, {53872, -1, -1, -1}, {53873, -1, -1, -1}, {53874, -1, -1, -1}, {53875, -1, -1, -1}, {53876, -1, -1, -1}, {53877, -1, -1, -1}, {53878, -1, -1, -1}, {53879, -1, -1, -1}, {53880, -1, -1, -1}, {53881, -1, -1, -1}, {53882, -1, -1, -1}, {53883, -1, -1, -1}, {53884, -1, -1, -1}, {53885, -1, -1, -1}, {53886, -1, -1, -1}, {53887, -1, -1, -1}, {53890, -1, -1, -1}, {53891, -1, -1, -1}, {53893, -1, -1, -1}, {53894, -1, -1, -1}, {53895, -1, -1, -1}, {53897, -1, -1, -1}, {53898, -1, -1, -1}, {53899, -1, -1, -1}, {53900, -1, -1, -1}, {53901, -1, -1, -1}, {53902, -1, -1, -1}, {53903, -1, -1, -1}, {53906, -1, -1, -1}, {53907, -1, -1, -1}, {53908, -1, -1, -1}, {53910, -1, -1, -1}, {53911, -1, -1, -1}, {53912, -1, -1, -1}, {53913, -1, -1, -1}, {53914, -1, -1, -1}, {53915, -1, -1, -1}, {53917, -1, -1, -1}, {53918, -1, -1, -1}, {53919, -1, -1, -1}, {53921, -1, -1, -1}, {53922, -1, -1, -1}, {53923, -1, -1, -1}, {53925, -1, -1, -1}, {53926, -1, -1, -1}, {53927, -1, -1, -1}, {53928, -1, -1, -1}, {53929, -1, -1, -1} },
+ {{53930, -1, -1, -1}, {53931, -1, -1, -1}, {53933, -1, -1, -1}, {53934, -1, -1, -1}, {53935, -1, -1, -1}, {53936, -1, -1, -1}, {53938, -1, -1, -1}, {53939, -1, -1, -1}, {53940, -1, -1, -1}, {53941, -1, -1, -1}, {53942, -1, -1, -1}, {53943, -1, -1, -1}, {53946, -1, -1, -1}, {53947, -1, -1, -1}, {53949, -1, -1, -1}, {53950, -1, -1, -1}, {53953, -1, -1, -1}, {53955, -1, -1, -1}, {53956, -1, -1, -1}, {53957, -1, -1, -1}, {53958, -1, -1, -1}, {53959, -1, -1, -1}, {53962, -1, -1, -1}, {53964, -1, -1, -1}, {53965, -1, -1, -1}, {53966, -1, -1, -1}, {53967, -1, -1, -1}, {53968, -1, -1, -1}, {53969, -1, -1, -1}, {53970, -1, -1, -1}, {53971, -1, -1, -1}, {53973, -1, -1, -1}, {53974, -1, -1, -1}, {53975, -1, -1, -1}, {53977, -1, -1, -1}, {53978, -1, -1, -1}, {53979, -1, -1, -1}, {53981, -1, -1, -1}, {53982, -1, -1, -1}, {53983, -1, -1, -1}, {53984, -1, -1, -1}, {53985, -1, -1, -1}, {53986, -1, -1, -1}, {53987, -1, -1, -1}, {53990, -1, -1, -1}, {53991, -1, -1, -1}, {53992, -1, -1, -1}, {53993, -1, -1, -1}, {53994, -1, -1, -1}, {53995, -1, -1, -1}, {53996, -1, -1, -1}, {53997, -1, -1, -1}, {53998, -1, -1, -1}, {53999, -1, -1, -1}, {54002, -1, -1, -1}, {54003, -1, -1, -1}, {54005, -1, -1, -1}, {54006, -1, -1, -1}, {54007, -1, -1, -1}, {54009, -1, -1, -1}, {54010, -1, -1, -1}, {54011, -1, -1, -1}, {54012, -1, -1, -1}, {54013, -1, -1, -1}, {54014, -1, -1, -1}, {54015, -1, -1, -1}, {54018, -1, -1, -1}, {54020, -1, -1, -1}, {54022, -1, -1, -1}, {54023, -1, -1, -1}, {54024, -1, -1, -1}, {54025, -1, -1, -1}, {54026, -1, -1, -1}, {54027, -1, -1, -1}, {54031, -1, -1, -1}, {54033, -1, -1, -1}, {54034, -1, -1, -1}, {54035, -1, -1, -1}, {54037, -1, -1, -1}, {54039, -1, -1, -1}, {54040, -1, -1, -1}, {54041, -1, -1, -1}, {54042, -1, -1, -1}, {54043, -1, -1, -1}, {54046, -1, -1, -1}, {54050, -1, -1, -1}, {54051, -1, -1, -1}, {54052, -1, -1, -1}, {54054, -1, -1, -1}, {54055, -1, -1, -1}, {54058, -1, -1, -1}, {54059, -1, -1, -1}, {54061, -1, -1, -1}, {54062, -1, -1, -1}, {54063, -1, -1, -1}, {54065, -1, -1, -1}, {54066, -1, -1, -1}, {54067, -1, -1, -1}, {54068, -1, -1, -1}, {54069, -1, -1, -1}, {54070, -1, -1, -1}, {54071, -1, -1, -1}, {54074, -1, -1, -1}, {54078, -1, -1, -1}, {54079, -1, -1, -1}, {54080, -1, -1, -1}, {54081, -1, -1, -1}, {54082, -1, -1, -1}, {54083, -1, -1, -1}, {54086, -1, -1, -1}, {54087, -1, -1, -1}, {54088, -1, -1, -1}, {54089, -1, -1, -1}, {54090, -1, -1, -1}, {54091, -1, -1, -1}, {54092, -1, -1, -1}, {54093, -1, -1, -1}, {54094, -1, -1, -1}, {54095, -1, -1, -1}, {54096, -1, -1, -1}, {54097, -1, -1, -1}, {54098, -1, -1, -1}, {54099, -1, -1, -1}, {54100, -1, -1, -1}, {54101, -1, -1, -1}, {54102, -1, -1, -1}, {54103, -1, -1, -1}, {54104, -1, -1, -1}, {54105, -1, -1, -1}, {54106, -1, -1, -1}, {54107, -1, -1, -1}, {54108, -1, -1, -1}, {54109, -1, -1, -1}, {54110, -1, -1, -1}, {54111, -1, -1, -1}, {54112, -1, -1, -1}, {54113, -1, -1, -1}, {54114, -1, -1, -1}, {54115, -1, -1, -1}, {54116, -1, -1, -1}, {54117, -1, -1, -1}, {54118, -1, -1, -1}, {54119, -1, -1, -1}, {54120, -1, -1, -1}, {54121, -1, -1, -1}, {54122, -1, -1, -1}, {54123, -1, -1, -1}, {54124, -1, -1, -1}, {54125, -1, -1, -1}, {54126, -1, -1, -1}, {54127, -1, -1, -1}, {54128, -1, -1, -1}, {54129, -1, -1, -1}, {54130, -1, -1, -1}, {54131, -1, -1, -1}, {54132, -1, -1, -1}, {54133, -1, -1, -1}, {54134, -1, -1, -1}, {54135, -1, -1, -1}, {54136, -1, -1, -1}, {54137, -1, -1, -1}, {54138, -1, -1, -1}, {54139, -1, -1, -1}, {54142, -1, -1, -1}, {54143, -1, -1, -1}, {54145, -1, -1, -1}, {54146, -1, -1, -1}, {54147, -1, -1, -1}, {54149, -1, -1, -1}, {54150, -1, -1, -1}, {54151, -1, -1, -1}, {54152, -1, -1, -1}, {54153, -1, -1, -1}, {54154, -1, -1, -1}, {54155, -1, -1, -1}, {54158, -1, -1, -1}, {54162, -1, -1, -1}, {54163, -1, -1, -1}, {54164, -1, -1, -1}, {54165, -1, -1, -1}, {54166, -1, -1, -1}, {54167, -1, -1, -1}, {54170, -1, -1, -1}, {54171, -1, -1, -1}, {54173, -1, -1, -1}, {54174, -1, -1, -1}, {54175, -1, -1, -1}, {54177, -1, -1, -1}, {54178, -1, -1, -1}, {54179, -1, -1, -1}, {54180, -1, -1, -1}, {54181, -1, -1, -1}, {54182, -1, -1, -1}, {54183, -1, -1, -1}, {54186, -1, -1, -1}, {54188, -1, -1, -1}, {54190, -1, -1, -1}, {54191, -1, -1, -1}, {54192, -1, -1, -1}, {54193, -1, -1, -1}, {54194, -1, -1, -1}, {54195, -1, -1, -1}, {54197, -1, -1, -1}, {54198, -1, -1, -1}, {54199, -1, -1, -1}, {54201, -1, -1, -1}, {54202, -1, -1, -1}, {54203, -1, -1, -1}, {54205, -1, -1, -1}, {54206, -1, -1, -1}, {54207, -1, -1, -1}, {54208, -1, -1, -1}, {54209, -1, -1, -1}, {54210, -1, -1, -1}, {54211, -1, -1, -1}, {54214, -1, -1, -1}, {54215, -1, -1, -1}, {54218, -1, -1, -1}, {54219, -1, -1, -1}, {54220, -1, -1, -1}, {54221, -1, -1, -1}, {54222, -1, -1, -1}, {54223, -1, -1, -1}, {54225, -1, -1, -1}, {54226, -1, -1, -1}, {54227, -1, -1, -1}, {54228, -1, -1, -1}, {54229, -1, -1, -1}, {54230, -1, -1, -1}, {54231, -1, -1, -1}, {54233, -1, -1, -1}, {54234, -1, -1, -1}, {54235, -1, -1, -1}, {54236, -1, -1, -1}, {54237, -1, -1, -1}, {54238, -1, -1, -1}, {54239, -1, -1, -1}, {54240, -1, -1, -1}, {54242, -1, -1, -1}, {54244, -1, -1, -1}, {54245, -1, -1, -1}, {54246, -1, -1, -1}, {54247, -1, -1, -1}, {54248, -1, -1, -1}, {54249, -1, -1, -1}, {54250, -1, -1, -1}, {54251, -1, -1, -1}, {54254, -1, -1, -1}, {54255, -1, -1, -1}, {54257, -1, -1, -1}, {54258, -1, -1, -1}, {54259, -1, -1, -1}, {54261, -1, -1, -1}, {54262, -1, -1, -1}, {54263, -1, -1, -1}, {54264, -1, -1, -1} },
+ {{54265, -1, -1, -1}, {54266, -1, -1, -1}, {54267, -1, -1, -1}, {54270, -1, -1, -1}, {54272, -1, -1, -1}, {54274, -1, -1, -1}, {54275, -1, -1, -1}, {54276, -1, -1, -1}, {54277, -1, -1, -1}, {54278, -1, -1, -1}, {54279, -1, -1, -1}, {54281, -1, -1, -1}, {54282, -1, -1, -1}, {54283, -1, -1, -1}, {54284, -1, -1, -1}, {54285, -1, -1, -1}, {54286, -1, -1, -1}, {54287, -1, -1, -1}, {54288, -1, -1, -1}, {54289, -1, -1, -1}, {54290, -1, -1, -1}, {54291, -1, -1, -1}, {54292, -1, -1, -1}, {54293, -1, -1, -1}, {54294, -1, -1, -1}, {54295, -1, -1, -1}, {54296, -1, -1, -1}, {54297, -1, -1, -1}, {54298, -1, -1, -1}, {54299, -1, -1, -1}, {54300, -1, -1, -1}, {54302, -1, -1, -1}, {54303, -1, -1, -1}, {54304, -1, -1, -1}, {54305, -1, -1, -1}, {54306, -1, -1, -1}, {54307, -1, -1, -1}, {54308, -1, -1, -1}, {54309, -1, -1, -1}, {54310, -1, -1, -1}, {54311, -1, -1, -1}, {54312, -1, -1, -1}, {54313, -1, -1, -1}, {54314, -1, -1, -1}, {54315, -1, -1, -1}, {54316, -1, -1, -1}, {54317, -1, -1, -1}, {54318, -1, -1, -1}, {54319, -1, -1, -1}, {54320, -1, -1, -1}, {54321, -1, -1, -1}, {54322, -1, -1, -1}, {54323, -1, -1, -1}, {54324, -1, -1, -1}, {54325, -1, -1, -1}, {54326, -1, -1, -1}, {54327, -1, -1, -1}, {54328, -1, -1, -1}, {54329, -1, -1, -1}, {54330, -1, -1, -1}, {54331, -1, -1, -1}, {54332, -1, -1, -1}, {54333, -1, -1, -1}, {54334, -1, -1, -1}, {54335, -1, -1, -1}, {54337, -1, -1, -1}, {54338, -1, -1, -1}, {54339, -1, -1, -1}, {54341, -1, -1, -1}, {54342, -1, -1, -1}, {54343, -1, -1, -1}, {54344, -1, -1, -1}, {54345, -1, -1, -1}, {54346, -1, -1, -1}, {54347, -1, -1, -1}, {54348, -1, -1, -1}, {54349, -1, -1, -1}, {54350, -1, -1, -1}, {54351, -1, -1, -1}, {54352, -1, -1, -1}, {54353, -1, -1, -1}, {54354, -1, -1, -1}, {54355, -1, -1, -1}, {54356, -1, -1, -1}, {54357, -1, -1, -1}, {54358, -1, -1, -1}, {54359, -1, -1, -1}, {54360, -1, -1, -1}, {54361, -1, -1, -1}, {54362, -1, -1, -1}, {54363, -1, -1, -1}, {54365, -1, -1, -1}, {54366, -1, -1, -1}, {54367, -1, -1, -1}, {54369, -1, -1, -1}, {54370, -1, -1, -1}, {54371, -1, -1, -1}, {54373, -1, -1, -1}, {54374, -1, -1, -1}, {54375, -1, -1, -1}, {54376, -1, -1, -1}, {54377, -1, -1, -1}, {54378, -1, -1, -1}, {54379, -1, -1, -1}, {54380, -1, -1, -1}, {54382, -1, -1, -1}, {54384, -1, -1, -1}, {54385, -1, -1, -1}, {54386, -1, -1, -1}, {54387, -1, -1, -1}, {54388, -1, -1, -1}, {54389, -1, -1, -1}, {54390, -1, -1, -1}, {54391, -1, -1, -1}, {54394, -1, -1, -1}, {54395, -1, -1, -1}, {54397, -1, -1, -1}, {54398, -1, -1, -1}, {54401, -1, -1, -1}, {54403, -1, -1, -1}, {54404, -1, -1, -1}, {54405, -1, -1, -1}, {54406, -1, -1, -1}, {54407, -1, -1, -1}, {54410, -1, -1, -1}, {54412, -1, -1, -1}, {54414, -1, -1, -1}, {54415, -1, -1, -1}, {54416, -1, -1, -1}, {54417, -1, -1, -1}, {54418, -1, -1, -1}, {54419, -1, -1, -1}, {54421, -1, -1, -1}, {54422, -1, -1, -1}, {54423, -1, -1, -1}, {54424, -1, -1, -1}, {54425, -1, -1, -1}, {54426, -1, -1, -1}, {54427, -1, -1, -1}, {54428, -1, -1, -1}, {54429, -1, -1, -1}, {54430, -1, -1, -1}, {54431, -1, -1, -1}, {54432, -1, -1, -1}, {54433, -1, -1, -1}, {54434, -1, -1, -1}, {54435, -1, -1, -1}, {54436, -1, -1, -1}, {54437, -1, -1, -1}, {54438, -1, -1, -1}, {54439, -1, -1, -1}, {54440, -1, -1, -1}, {54442, -1, -1, -1}, {54443, -1, -1, -1}, {54444, -1, -1, -1}, {54445, -1, -1, -1}, {54446, -1, -1, -1}, {54447, -1, -1, -1}, {54448, -1, -1, -1}, {54449, -1, -1, -1}, {54450, -1, -1, -1}, {54451, -1, -1, -1}, {54452, -1, -1, -1}, {54453, -1, -1, -1}, {54454, -1, -1, -1}, {54455, -1, -1, -1}, {54456, -1, -1, -1}, {54457, -1, -1, -1}, {54458, -1, -1, -1}, {54459, -1, -1, -1}, {54460, -1, -1, -1}, {54461, -1, -1, -1}, {54462, -1, -1, -1}, {54463, -1, -1, -1}, {54464, -1, -1, -1}, {54465, -1, -1, -1}, {54466, -1, -1, -1}, {54467, -1, -1, -1}, {54468, -1, -1, -1}, {54469, -1, -1, -1}, {54470, -1, -1, -1}, {54471, -1, -1, -1}, {54472, -1, -1, -1}, {54473, -1, -1, -1}, {54474, -1, -1, -1}, {54475, -1, -1, -1}, {54477, -1, -1, -1}, {54478, -1, -1, -1}, {54479, -1, -1, -1}, {54481, -1, -1, -1}, {54482, -1, -1, -1}, {54483, -1, -1, -1}, {54485, -1, -1, -1}, {54486, -1, -1, -1}, {54487, -1, -1, -1}, {54488, -1, -1, -1}, {54489, -1, -1, -1}, {54490, -1, -1, -1}, {54491, -1, -1, -1}, {54493, -1, -1, -1}, {54494, -1, -1, -1}, {54496, -1, -1, -1}, {54497, -1, -1, -1}, {54498, -1, -1, -1}, {54499, -1, -1, -1}, {54500, -1, -1, -1}, {54501, -1, -1, -1}, {54502, -1, -1, -1}, {54503, -1, -1, -1}, {54505, -1, -1, -1}, {54506, -1, -1, -1}, {54507, -1, -1, -1}, {54509, -1, -1, -1}, {54510, -1, -1, -1}, {54511, -1, -1, -1}, {54513, -1, -1, -1}, {54514, -1, -1, -1}, {54515, -1, -1, -1}, {54516, -1, -1, -1}, {54517, -1, -1, -1}, {54518, -1, -1, -1}, {54519, -1, -1, -1}, {54521, -1, -1, -1}, {54522, -1, -1, -1}, {54524, -1, -1, -1}, {54526, -1, -1, -1}, {54527, -1, -1, -1}, {54528, -1, -1, -1}, {54529, -1, -1, -1}, {54530, -1, -1, -1}, {54531, -1, -1, -1}, {54533, -1, -1, -1}, {54534, -1, -1, -1}, {54535, -1, -1, -1}, {54537, -1, -1, -1}, {54538, -1, -1, -1}, {54539, -1, -1, -1}, {54541, -1, -1, -1}, {54542, -1, -1, -1}, {54543, -1, -1, -1}, {54544, -1, -1, -1}, {54545, -1, -1, -1}, {54546, -1, -1, -1}, {54547, -1, -1, -1}, {54550, -1, -1, -1}, {54552, -1, -1, -1}, {54553, -1, -1, -1}, {54554, -1, -1, -1}, {54555, -1, -1, -1}, {54556, -1, -1, -1}, {54557, -1, -1, -1}, {54558, -1, -1, -1}, {54559, -1, -1, -1}, {54560, -1, -1, -1}, {54561, -1, -1, -1}, {54562, -1, -1, -1} },
+ {{54563, -1, -1, -1}, {54564, -1, -1, -1}, {54565, -1, -1, -1}, {54566, -1, -1, -1}, {54567, -1, -1, -1}, {54568, -1, -1, -1}, {54569, -1, -1, -1}, {54570, -1, -1, -1}, {54571, -1, -1, -1}, {54572, -1, -1, -1}, {54573, -1, -1, -1}, {54574, -1, -1, -1}, {54575, -1, -1, -1}, {54576, -1, -1, -1}, {54577, -1, -1, -1}, {54578, -1, -1, -1}, {54579, -1, -1, -1}, {54580, -1, -1, -1}, {54581, -1, -1, -1}, {54582, -1, -1, -1}, {54583, -1, -1, -1}, {54584, -1, -1, -1}, {54585, -1, -1, -1}, {54586, -1, -1, -1}, {54587, -1, -1, -1}, {54590, -1, -1, -1}, {54591, -1, -1, -1}, {54593, -1, -1, -1}, {54594, -1, -1, -1}, {54595, -1, -1, -1}, {54597, -1, -1, -1}, {54598, -1, -1, -1}, {54599, -1, -1, -1}, {54600, -1, -1, -1}, {54601, -1, -1, -1}, {54602, -1, -1, -1}, {54603, -1, -1, -1}, {54606, -1, -1, -1}, {54608, -1, -1, -1}, {54610, -1, -1, -1}, {54611, -1, -1, -1}, {54612, -1, -1, -1}, {54613, -1, -1, -1}, {54614, -1, -1, -1}, {54615, -1, -1, -1}, {54618, -1, -1, -1}, {54619, -1, -1, -1}, {54621, -1, -1, -1}, {54622, -1, -1, -1}, {54623, -1, -1, -1}, {54625, -1, -1, -1}, {54626, -1, -1, -1}, {54627, -1, -1, -1}, {54628, -1, -1, -1}, {54630, -1, -1, -1}, {54631, -1, -1, -1}, {54634, -1, -1, -1}, {54636, -1, -1, -1}, {54638, -1, -1, -1}, {54639, -1, -1, -1}, {54640, -1, -1, -1}, {54641, -1, -1, -1}, {54642, -1, -1, -1}, {54643, -1, -1, -1}, {54646, -1, -1, -1}, {54647, -1, -1, -1}, {54649, -1, -1, -1}, {54650, -1, -1, -1}, {54651, -1, -1, -1}, {54653, -1, -1, -1}, {54654, -1, -1, -1}, {54655, -1, -1, -1}, {54656, -1, -1, -1}, {54657, -1, -1, -1}, {54658, -1, -1, -1}, {54659, -1, -1, -1}, {54662, -1, -1, -1}, {54666, -1, -1, -1}, {54667, -1, -1, -1}, {54668, -1, -1, -1}, {54669, -1, -1, -1}, {54670, -1, -1, -1}, {54671, -1, -1, -1}, {54673, -1, -1, -1}, {54674, -1, -1, -1}, {54675, -1, -1, -1}, {54676, -1, -1, -1}, {54677, -1, -1, -1}, {54678, -1, -1, -1}, {54679, -1, -1, -1}, {54680, -1, -1, -1}, {54681, -1, -1, -1}, {54682, -1, -1, -1}, {54683, -1, -1, -1}, {54684, -1, -1, -1}, {54685, -1, -1, -1}, {54686, -1, -1, -1}, {54687, -1, -1, -1}, {54688, -1, -1, -1}, {54689, -1, -1, -1}, {54690, -1, -1, -1}, {54691, -1, -1, -1}, {54692, -1, -1, -1}, {54694, -1, -1, -1}, {54695, -1, -1, -1}, {54696, -1, -1, -1}, {54697, -1, -1, -1}, {54698, -1, -1, -1}, {54699, -1, -1, -1}, {54700, -1, -1, -1}, {54701, -1, -1, -1}, {54702, -1, -1, -1}, {54703, -1, -1, -1}, {54704, -1, -1, -1}, {54705, -1, -1, -1}, {54706, -1, -1, -1}, {54707, -1, -1, -1}, {54708, -1, -1, -1}, {54709, -1, -1, -1}, {54710, -1, -1, -1}, {54711, -1, -1, -1}, {54712, -1, -1, -1}, {54713, -1, -1, -1}, {54714, -1, -1, -1}, {54715, -1, -1, -1}, {54716, -1, -1, -1}, {54717, -1, -1, -1}, {54718, -1, -1, -1}, {54719, -1, -1, -1}, {54720, -1, -1, -1}, {54721, -1, -1, -1}, {54722, -1, -1, -1}, {54723, -1, -1, -1}, {54724, -1, -1, -1}, {54725, -1, -1, -1}, {54726, -1, -1, -1}, {54727, -1, -1, -1}, {54730, -1, -1, -1}, {54731, -1, -1, -1}, {54733, -1, -1, -1}, {54734, -1, -1, -1}, {54735, -1, -1, -1}, {54737, -1, -1, -1}, {54739, -1, -1, -1}, {54740, -1, -1, -1}, {54741, -1, -1, -1}, {54742, -1, -1, -1}, {54743, -1, -1, -1}, {54746, -1, -1, -1}, {54748, -1, -1, -1}, {54750, -1, -1, -1}, {54751, -1, -1, -1}, {54752, -1, -1, -1}, {54753, -1, -1, -1}, {54754, -1, -1, -1}, {54755, -1, -1, -1}, {54758, -1, -1, -1}, {54759, -1, -1, -1}, {54761, -1, -1, -1}, {54762, -1, -1, -1}, {54763, -1, -1, -1}, {54765, -1, -1, -1}, {54766, -1, -1, -1}, {54767, -1, -1, -1}, {54768, -1, -1, -1}, {54769, -1, -1, -1}, {54770, -1, -1, -1}, {54771, -1, -1, -1}, {54774, -1, -1, -1}, {54776, -1, -1, -1}, {54778, -1, -1, -1}, {54779, -1, -1, -1}, {54780, -1, -1, -1}, {54781, -1, -1, -1}, {54782, -1, -1, -1}, {54783, -1, -1, -1}, {54786, -1, -1, -1}, {54787, -1, -1, -1}, {54789, -1, -1, -1}, {54790, -1, -1, -1}, {54791, -1, -1, -1}, {54793, -1, -1, -1}, {54794, -1, -1, -1}, {54795, -1, -1, -1}, {54796, -1, -1, -1}, {54797, -1, -1, -1}, {54798, -1, -1, -1}, {54799, -1, -1, -1}, {54802, -1, -1, -1}, {54806, -1, -1, -1}, {54807, -1, -1, -1}, {54808, -1, -1, -1}, {54809, -1, -1, -1}, {54810, -1, -1, -1}, {54811, -1, -1, -1}, {54813, -1, -1, -1}, {54814, -1, -1, -1}, {54815, -1, -1, -1}, {54817, -1, -1, -1}, {54818, -1, -1, -1}, {54819, -1, -1, -1}, {54821, -1, -1, -1}, {54822, -1, -1, -1}, {54823, -1, -1, -1}, {54824, -1, -1, -1}, {54825, -1, -1, -1}, {54826, -1, -1, -1}, {54827, -1, -1, -1}, {54828, -1, -1, -1}, {54830, -1, -1, -1}, {54831, -1, -1, -1}, {54832, -1, -1, -1}, {54833, -1, -1, -1}, {54834, -1, -1, -1}, {54835, -1, -1, -1}, {54836, -1, -1, -1}, {54837, -1, -1, -1}, {54838, -1, -1, -1}, {54839, -1, -1, -1}, {54842, -1, -1, -1}, {54843, -1, -1, -1}, {54845, -1, -1, -1}, {54846, -1, -1, -1}, {54847, -1, -1, -1}, {54849, -1, -1, -1}, {54850, -1, -1, -1}, {54851, -1, -1, -1}, {54852, -1, -1, -1}, {54854, -1, -1, -1}, {54855, -1, -1, -1}, {54858, -1, -1, -1}, {54860, -1, -1, -1}, {54862, -1, -1, -1}, {54863, -1, -1, -1}, {54864, -1, -1, -1}, {54866, -1, -1, -1}, {54867, -1, -1, -1}, {54870, -1, -1, -1}, {54871, -1, -1, -1}, {54873, -1, -1, -1}, {54874, -1, -1, -1}, {54875, -1, -1, -1}, {54877, -1, -1, -1}, {54878, -1, -1, -1}, {54879, -1, -1, -1}, {54880, -1, -1, -1}, {54881, -1, -1, -1}, {54882, -1, -1, -1}, {54883, -1, -1, -1}, {54884, -1, -1, -1}, {54885, -1, -1, -1}, {54886, -1, -1, -1}, {54888, -1, -1, -1}, {54890, -1, -1, -1}, {54891, -1, -1, -1}, {54892, -1, -1, -1} },
+ {{54893, -1, -1, -1}, {54894, -1, -1, -1}, {54895, -1, -1, -1}, {54898, -1, -1, -1}, {54899, -1, -1, -1}, {54901, -1, -1, -1}, {54902, -1, -1, -1}, {54903, -1, -1, -1}, {54904, -1, -1, -1}, {54905, -1, -1, -1}, {54906, -1, -1, -1}, {54907, -1, -1, -1}, {54908, -1, -1, -1}, {54909, -1, -1, -1}, {54910, -1, -1, -1}, {54911, -1, -1, -1}, {54912, -1, -1, -1}, {54913, -1, -1, -1}, {54914, -1, -1, -1}, {54916, -1, -1, -1}, {54918, -1, -1, -1}, {54919, -1, -1, -1}, {54920, -1, -1, -1}, {54921, -1, -1, -1}, {54922, -1, -1, -1}, {54923, -1, -1, -1}, {54926, -1, -1, -1}, {54927, -1, -1, -1}, {54929, -1, -1, -1}, {54930, -1, -1, -1}, {54931, -1, -1, -1}, {54933, -1, -1, -1}, {54934, -1, -1, -1}, {54935, -1, -1, -1}, {54936, -1, -1, -1}, {54937, -1, -1, -1}, {54938, -1, -1, -1}, {54939, -1, -1, -1}, {54940, -1, -1, -1}, {54942, -1, -1, -1}, {54944, -1, -1, -1}, {54946, -1, -1, -1}, {54947, -1, -1, -1}, {54948, -1, -1, -1}, {54949, -1, -1, -1}, {54950, -1, -1, -1}, {54951, -1, -1, -1}, {54953, -1, -1, -1}, {54954, -1, -1, -1}, {54955, -1, -1, -1}, {54957, -1, -1, -1}, {54958, -1, -1, -1}, {54959, -1, -1, -1}, {54961, -1, -1, -1}, {54962, -1, -1, -1}, {54963, -1, -1, -1}, {54964, -1, -1, -1}, {54965, -1, -1, -1}, {54966, -1, -1, -1}, {54967, -1, -1, -1}, {54968, -1, -1, -1}, {54970, -1, -1, -1}, {54972, -1, -1, -1}, {54973, -1, -1, -1}, {54974, -1, -1, -1}, {54975, -1, -1, -1}, {54976, -1, -1, -1}, {54977, -1, -1, -1}, {54978, -1, -1, -1}, {54979, -1, -1, -1}, {54982, -1, -1, -1}, {54983, -1, -1, -1}, {54985, -1, -1, -1}, {54986, -1, -1, -1}, {54987, -1, -1, -1}, {54989, -1, -1, -1}, {54990, -1, -1, -1}, {54991, -1, -1, -1}, {54992, -1, -1, -1}, {54994, -1, -1, -1}, {54995, -1, -1, -1}, {54997, -1, -1, -1}, {54998, -1, -1, -1}, {55000, -1, -1, -1}, {55002, -1, -1, -1}, {55003, -1, -1, -1}, {55004, -1, -1, -1}, {55005, -1, -1, -1}, {55006, -1, -1, -1}, {55007, -1, -1, -1}, {55009, -1, -1, -1}, {55010, -1, -1, -1}, {55011, -1, -1, -1}, {55013, -1, -1, -1}, {55014, -1, -1, -1}, {55015, -1, -1, -1}, {55017, -1, -1, -1}, {55018, -1, -1, -1}, {55019, -1, -1, -1}, {55020, -1, -1, -1}, {55021, -1, -1, -1}, {55022, -1, -1, -1}, {55023, -1, -1, -1}, {55025, -1, -1, -1}, {55026, -1, -1, -1}, {55027, -1, -1, -1}, {55028, -1, -1, -1}, {55030, -1, -1, -1}, {55031, -1, -1, -1}, {55032, -1, -1, -1}, {55033, -1, -1, -1}, {55034, -1, -1, -1}, {55035, -1, -1, -1}, {55038, -1, -1, -1}, {55039, -1, -1, -1}, {55041, -1, -1, -1}, {55042, -1, -1, -1}, {55043, -1, -1, -1}, {55045, -1, -1, -1}, {55046, -1, -1, -1}, {55047, -1, -1, -1}, {55048, -1, -1, -1}, {55049, -1, -1, -1}, {55050, -1, -1, -1}, {55051, -1, -1, -1}, {55052, -1, -1, -1}, {55053, -1, -1, -1}, {55054, -1, -1, -1}, {55055, -1, -1, -1}, {55056, -1, -1, -1}, {55058, -1, -1, -1}, {55059, -1, -1, -1}, {55060, -1, -1, -1}, {55061, -1, -1, -1}, {55062, -1, -1, -1}, {55063, -1, -1, -1}, {55066, -1, -1, -1}, {55067, -1, -1, -1}, {55069, -1, -1, -1}, {55070, -1, -1, -1}, {55071, -1, -1, -1}, {55073, -1, -1, -1}, {55074, -1, -1, -1}, {55075, -1, -1, -1}, {55076, -1, -1, -1}, {55077, -1, -1, -1}, {55078, -1, -1, -1}, {55079, -1, -1, -1}, {55082, -1, -1, -1}, {55084, -1, -1, -1}, {55086, -1, -1, -1}, {55087, -1, -1, -1}, {55088, -1, -1, -1}, {55089, -1, -1, -1}, {55090, -1, -1, -1}, {55091, -1, -1, -1}, {55094, -1, -1, -1}, {55095, -1, -1, -1}, {55097, -1, -1, -1}, {55098, -1, -1, -1}, {55099, -1, -1, -1}, {55101, -1, -1, -1}, {55102, -1, -1, -1}, {55103, -1, -1, -1}, {55104, -1, -1, -1}, {55105, -1, -1, -1}, {55106, -1, -1, -1}, {55107, -1, -1, -1}, {55109, -1, -1, -1}, {55110, -1, -1, -1}, {55112, -1, -1, -1}, {55114, -1, -1, -1}, {55115, -1, -1, -1}, {55116, -1, -1, -1}, {55117, -1, -1, -1}, {55118, -1, -1, -1}, {55119, -1, -1, -1}, {55122, -1, -1, -1}, {55123, -1, -1, -1}, {55125, -1, -1, -1}, {55130, -1, -1, -1}, {55131, -1, -1, -1}, {55132, -1, -1, -1}, {55133, -1, -1, -1}, {55134, -1, -1, -1}, {55135, -1, -1, -1}, {55138, -1, -1, -1}, {55140, -1, -1, -1}, {55142, -1, -1, -1}, {55143, -1, -1, -1}, {55144, -1, -1, -1}, {55146, -1, -1, -1}, {55147, -1, -1, -1}, {55149, -1, -1, -1}, {55150, -1, -1, -1}, {55151, -1, -1, -1}, {55153, -1, -1, -1}, {55154, -1, -1, -1}, {55155, -1, -1, -1}, {55157, -1, -1, -1}, {55158, -1, -1, -1}, {55159, -1, -1, -1}, {55160, -1, -1, -1}, {55161, -1, -1, -1}, {55162, -1, -1, -1}, {55163, -1, -1, -1}, {55166, -1, -1, -1}, {55167, -1, -1, -1}, {55168, -1, -1, -1}, {55170, -1, -1, -1}, {55171, -1, -1, -1}, {55172, -1, -1, -1}, {55173, -1, -1, -1}, {55174, -1, -1, -1}, {55175, -1, -1, -1}, {55178, -1, -1, -1}, {55179, -1, -1, -1}, {55181, -1, -1, -1}, {55182, -1, -1, -1}, {55183, -1, -1, -1}, {55185, -1, -1, -1}, {55186, -1, -1, -1}, {55187, -1, -1, -1}, {55188, -1, -1, -1}, {55189, -1, -1, -1}, {55190, -1, -1, -1}, {55191, -1, -1, -1}, {55194, -1, -1, -1}, {55196, -1, -1, -1}, {55198, -1, -1, -1}, {55199, -1, -1, -1}, {55200, -1, -1, -1}, {55201, -1, -1, -1}, {55202, -1, -1, -1}, {55203, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1}, {-1, -1, -1, -1} },
+ }
+};
+
+const pdfi_cid_decoding_t *pdfi_cid_decoding_list[] = {
+ &cns1_unicode,
+ &gb1_unicode,
+ &japan1_unicode,
+ &japan2_unicode,
+ &korea1_unicode,
+ NULL
+};
+
+/* The following values are pulled from Ghostscript's SubstNWP dictionary.
+ Defined in Resource/Init/gs_fntem.ps - as far as I can tell, there is
+ no record from where these mappings were sourced.
+ We do nothing with the source and destination types (the leading and
+ trailing char values. But in case they end up being required, they are
+ here:
+ n==narrow, w==wide, p==proportional
+ The form is: source type, <Source Start CID>, <Source End CID>, <Destination Start CID>, <Destination type>
+ */
+static const pdfi_cid_subst_nwp_table_t japan1_subst_nwp = {
+ "Japan1",
+ {
+ {'p', 1, 94, 231, 'n'},
+ {'p', 17, 26, 780, 'w'},
+ {'p', 34, 59, 790, 'w'},
+ {'p', 66, 91, 816, 'w'},
+ {'w', 842, 842, 7918, 'w'},
+ {'w', 844, 844, 7919, 'w'},
+ {'w', 846, 846, 7920, 'w'},
+ {'w', 848, 848, 7921, 'w'},
+ {'w', 850, 850, 7922, 'w'},
+ {'w', 876, 876, 7923, 'w'},
+ {'w', 908, 908, 7924, 'w'},
+ {'w', 910, 910, 7925, 'w'},
+ {'w', 912, 912, 7926, 'w'},
+ {'w', 914, 914, 7927, 'w'},
+ {'w', 925, 925, 7928, 'w'},
+ {'w', 927, 927, 7929, 'w'},
+ {'w', 929, 929, 7930, 'w'},
+ {'w', 931, 931, 7931, 'w'},
+ {'w', 933, 933, 7932, 'w'},
+ {'w', 959, 959, 7933, 'w'},
+ {'w', 991, 991, 7934, 'w'},
+ {'w', 993, 993, 7935, 'w'},
+ {'w', 995, 995, 7936, 'w'},
+ {'w', 1002, 1002, 7937, 'w'},
+ {'w', 1009, 1009, 7938, 'w'},
+ {'w', 1010, 1010, 7939, 'w'},
+ {(char)0, 0, 0, (char)0}
+ }
+};
+
+static const pdfi_cid_subst_nwp_table_t japan2_subst_nwp = {
+ "Japan2", /* Same mappings as above */
+ {
+ {'p', 1, 94, 231, 'n'},
+ {'p', 17, 26, 780, 'w'},
+ {'p', 34, 59, 790, 'w'},
+ {'p', 66, 91, 816, 'w'},
+ {'w', 842, 842, 7918, 'w'},
+ {'w', 844, 844, 7919, 'w'},
+ {'w', 846, 846, 7920, 'w'},
+ {'w', 848, 848, 7921, 'w'},
+ {'w', 850, 850, 7922, 'w'},
+ {'w', 876, 876, 7923, 'w'},
+ {'w', 908, 908, 7924, 'w'},
+ {'w', 910, 910, 7925, 'w'},
+ {'w', 912, 912, 7926, 'w'},
+ {'w', 914, 914, 7927, 'w'},
+ {'w', 925, 925, 7928, 'w'},
+ {'w', 927, 927, 7929, 'w'},
+ {'w', 929, 929, 7930, 'w'},
+ {'w', 931, 931, 7931, 'w'},
+ {'w', 933, 933, 7932, 'w'},
+ {'w', 959, 959, 7933, 'w'},
+ {'w', 991, 991, 7934, 'w'},
+ {'w', 993, 993, 7935, 'w'},
+ {'w', 995, 995, 7936, 'w'},
+ {'w', 1002, 1002, 7937, 'w'},
+ {'w', 1009, 1009, 7938, 'w'},
+ {'w', 1010, 1010, 7939, 'w'},
+ {(char)0, 0, 0, (char)0}
+ }
+};
+
+static const pdfi_cid_subst_nwp_table_t cns1_subst_nwp = {
+ "CNS1",
+ {
+ {'p', 1, 94, 13648, 'n'},
+ {'p', 17, 26, 333, 'w'},
+ {'p', 34, 59, 365, 'w'},
+ {'p', 66, 91, 391, 'w'},
+ {(char)0, 0, 0, (char)0}
+ }
+};
+
+static const pdfi_cid_subst_nwp_table_t gb1_subst_nwp = {
+ "GB1",
+ {
+ {'p', 2, 94, 814, 'n'},
+ {'p', 2, 94, 262, 'w'},
+ {'p', 1, 1, 7716, 'n'},
+ {(char)0, 0, 0, (char)0}
+ }
+};
+
+static const pdfi_cid_subst_nwp_table_t korea1_subst_nwp = {
+ "Korea1",
+ {
+ {'p', 1, 60, 8094, 'n'},
+ {'p', 62, 94, 8155, 'n'},
+ {'p', 2, 59, 264, 'w'},
+ {'p', 63, 94, 325, 'w'},
+ {(char)0, 0, 0, (char)0}
+ }
+};
+
+const pdfi_cid_subst_nwp_table_t *pdfi_cid_substnwp_list[] = {
+ &japan1_subst_nwp,
+ &japan2_subst_nwp,
+ &cns1_subst_nwp,
+ &gb1_subst_nwp,
+ &korea1_subst_nwp,
+ NULL
+};
diff --git a/pdf/pdf_cmap.c b/pdf/pdf_cmap.c
new file mode 100644
index 00000000..fcf363ff
--- /dev/null
+++ b/pdf/pdf_cmap.c
@@ -0,0 +1,900 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+#include "strmio.h"
+#include "stream.h"
+#include "scanchar.h"
+
+#include "pdf_int.h"
+#include "pdf_cmap.h"
+
+#include "pdf_stack.h"
+#include "pdf_dict.h"
+#include "pdf_file.h"
+#include "pdf_fontps.h"
+#include "pdf_deref.h"
+
+static int pdfi_free_cmap_contents(pdf_cmap *cmap);
+
+static int cmap_usecmap_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ pdf_cmap *pdficmap = (pdf_cmap *)s->client_data;
+ pdf_name *n = NULL;
+ pdf_cmap *upcmap = NULL;
+
+ if (pdf_ps_stack_count(s) < 1)
+ return_error(gs_error_stackunderflow);
+
+ /* If we've already got some definitions, ignore the usecmap op */
+ if (pdficmap->code_space.num_ranges == 0) {
+ byte *nstr = NULL;
+ int code, len = s->cur[0].size;
+
+ if (pdf_ps_obj_has_type(&(s->cur[0]), PDF_PS_OBJ_NAME)) {
+ nstr = s->cur[0].val.name;
+ }
+ else if (pdf_ps_obj_has_type(&(s->cur[0]), PDF_PS_OBJ_STRING)) {
+ nstr = s->cur[0].val.string;
+ }
+ else {
+ return_error(gs_error_typecheck);
+ }
+ code = pdfi_name_alloc(pdficmap->ctx, nstr, len, (pdf_obj **)&n);
+ if (code >= 0) {
+ pdfi_countup(n);
+ code = pdfi_read_cmap(pdficmap->ctx, (pdf_obj *)n, &upcmap);
+ if (code >= 0) {
+ gx_code_space_range_t * ranges =
+ (gx_code_space_range_t *)gs_alloc_byte_array(mem, upcmap->code_space.num_ranges,
+ sizeof(gx_code_space_range_t), "cmap_usecmap_func(ranges)");
+ if (ranges != NULL) {
+ int i;
+ memcpy(&pdficmap->code_space, &upcmap->code_space, sizeof(pdficmap->code_space));
+ for (i = 0; i < upcmap->code_space.num_ranges; i++) {
+ memcpy(&(ranges[i]), &(upcmap->code_space.ranges[i]), sizeof(ranges[i]));
+ }
+ pdficmap->code_space.ranges = ranges;
+ memcpy(&pdficmap->cmap_range, &upcmap->cmap_range, sizeof(pdficmap->cmap_range));
+ memcpy(&pdficmap->notdef_cmap_range, &upcmap->notdef_cmap_range, sizeof(pdficmap->notdef_cmap_range));
+ /* Once we've assumed control of these, NULL out entries for the sub-cmap. */
+ upcmap->cmap_range.ranges = NULL;
+ upcmap->notdef_cmap_range.ranges = NULL;
+ /* But we keep the subcmap itself because we rely on its storage */
+ pdficmap->next = upcmap;
+ pdfi_countup(upcmap);
+ }
+ }
+ }
+
+ }
+ pdfi_countdown(upcmap);
+ pdfi_countdown(n);
+ return pdf_ps_stack_pop(s, 1);
+}
+
+#if 0 /* no longer used */
+static int cmap_pushmark_func(gs_memory_t *mem, pdf_ps_ctx_t *stack, pdf_cmap *pdficmap)
+{
+ return pdf_ps_stack_push_mark(stack);
+}
+#endif
+
+
+static int cmap_endcodespacerange_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ pdf_cmap *pdficmap = (pdf_cmap *)s->client_data;
+ int i, numranges, to_pop = pdf_ps_stack_count_to_mark(s, PDF_PS_OBJ_MARK);
+ gx_code_space_t *code_space = &pdficmap->code_space;
+ int nr = code_space->num_ranges;
+ gx_code_space_range_t *gcsr = code_space->ranges;
+
+ /* increment to_pop to cover the mark object */
+ numranges = to_pop++;
+ while (numranges % 2) numranges--;
+
+ if (numranges > 0 && pdf_ps_obj_has_type(&(s->cur[0]), PDF_PS_OBJ_STRING) &&
+ pdf_ps_obj_has_type(&(s->cur[-1]), PDF_PS_OBJ_STRING)) {
+
+ code_space->num_ranges += numranges >> 1;
+
+ code_space->ranges = (gx_code_space_range_t *)gs_alloc_byte_array(mem, code_space->num_ranges,
+ sizeof(gx_code_space_range_t), "cmap_endcodespacerange_func(ranges)");
+ if (nr > 0) {
+ memcpy(code_space->ranges, gcsr, nr);
+ gs_free_object(mem, gcsr, "cmap_endcodespacerange_func(gcsr");
+ }
+
+ for (i = nr; i < code_space->num_ranges; i++) {
+ memcpy(code_space->ranges[i].first, s->cur[-((i * 2) + 1)].val.string, s->cur[-((i * 2) + 1)].size);
+ memcpy(code_space->ranges[i].last, s->cur[-(i * 2)].val.string, s->cur[-(i * 2)].size);
+ code_space->ranges[i].size = s->cur[-(i * 2)].size;
+ }
+ }
+ return pdf_ps_stack_pop(s, to_pop);
+}
+
+static int cmap_insert_map(pdfi_cmap_range_t *cmap_range, pdfi_cmap_range_map_t *pdfir)
+{
+ if (cmap_range->ranges == NULL) {
+ cmap_range->ranges = cmap_range->ranges_tail = pdfir;
+ }
+ else {
+ cmap_range->ranges_tail->next = pdfir;
+ cmap_range->ranges_tail = pdfir;
+ }
+ cmap_range->numrangemaps++;
+ return 0;
+}
+
+static int general_endcidrange_func(gs_memory_t *mem, pdf_ps_ctx_t *s, pdf_cmap *pdficmap, pdfi_cmap_range_t *cmap_range)
+{
+ int ncodemaps, to_pop = pdf_ps_stack_count_to_mark(s, PDF_PS_OBJ_MARK);
+ int i, j;
+ pdfi_cmap_range_map_t *pdfir;
+ pdf_ps_stack_object_t *stobj;
+
+ /* increment to_pop to cover the mark object */
+ ncodemaps = to_pop++;
+ /* mapping should have 3 objects on the stack:
+ * startcode, endcode and basecid
+ */
+ while (ncodemaps % 3) ncodemaps--;
+
+ stobj = &s->cur[-ncodemaps] + 1;
+
+ for (i = 0; i < ncodemaps; i += 3) {
+ int preflen, valuelen;
+
+ if (pdf_ps_obj_has_type(&(stobj[i + 2]), PDF_PS_OBJ_INTEGER)
+ && pdf_ps_obj_has_type(&(stobj[i + 1]), PDF_PS_OBJ_STRING)
+ && pdf_ps_obj_has_type(&(stobj[i]), PDF_PS_OBJ_STRING)){
+ uint cidbase = stobj[i + 2].val.i;
+
+ /* First, find the length of the prefix */
+ for (preflen = 0; preflen < stobj[i].size; preflen++) {
+ if(stobj[i].val.string[preflen] != stobj[i + 1].val.string[preflen]) {
+ break;
+ }
+ }
+
+ if (preflen == stobj[i].size) {
+ preflen = 1;
+ }
+
+ /* Find how many bytes we need for the cidbase value */
+ /* We always store at least two bytes for the cidbase value */
+ for (valuelen = 16; valuelen < 32 && (cidbase >> valuelen) > 0; valuelen += 1)
+ DO_NOTHING;
+
+ valuelen = ((valuelen + 7) & ~7) >> 3;
+
+ /* The prefix is already directly in the gx_cmap_lookup_range_t
+ * We need to store the lower and upper character codes, after lopping the prefix
+ * off them. The upper and lower codes must be the same number of bytes.
+ */
+ j = sizeof(pdfi_cmap_range_map_t) + 2 * (stobj[i].size - preflen) + valuelen;
+
+ pdfir = (pdfi_cmap_range_map_t *)gs_alloc_bytes(mem, j, "cmap_endcidrange_func(pdfi_cmap_range_map_t)");
+ if (pdfir != NULL) {
+ gx_cmap_lookup_range_t *gxr = &pdfir->range;
+ pdfir->next = NULL;
+ gxr->num_entries = 1;
+ gxr->keys.data = (byte *)&(pdfir[1]);
+ gxr->values.data = gxr->keys.data + 2 * (stobj[i].size - preflen);
+
+ gxr->cmap = NULL;
+ gxr->font_index = 0;
+ gxr->key_is_range = true;
+ gxr->value_type = cmap_range == &(pdficmap->cmap_range) ? CODE_VALUE_CID : CODE_VALUE_NOTDEF;
+ gxr->key_prefix_size = preflen;
+ gxr->key_size = stobj[i].size - gxr->key_prefix_size;
+ memcpy(gxr->key_prefix, stobj[i].val.string, gxr->key_prefix_size);
+
+ memcpy(gxr->keys.data, stobj[i].val.string + gxr->key_prefix_size, stobj[i].size - gxr->key_prefix_size);
+ memcpy(gxr->keys.data + (stobj[i].size - gxr->key_prefix_size), stobj[i + 1].val.string + gxr->key_prefix_size, stobj[i + 1].size - gxr->key_prefix_size);
+
+ gxr->keys.size = (stobj[i].size - gxr->key_prefix_size) + (stobj[i + 1].size - gxr->key_prefix_size);
+ for (j = 0; j < valuelen; j++) {
+ gxr->values.data[j] = (cidbase >> ((valuelen - 1 - j) * 8)) & 255;
+ }
+ gxr->value_size = valuelen; /* I'm not sure.... */
+ gxr->values.size = valuelen;
+ if (cmap_insert_map(cmap_range, pdfir) < 0) break;
+ }
+ else {
+ break;
+ }
+ }
+ }
+ return pdf_ps_stack_pop(s, to_pop);
+}
+
+static int cmap_endcidrange_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ pdf_cmap *pdficmap = (pdf_cmap *)s->client_data;
+ return general_endcidrange_func(mem, s, pdficmap, &pdficmap->cmap_range);
+}
+
+static int cmap_endnotdefrange_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ pdf_cmap *pdficmap = (pdf_cmap *)s->client_data;
+ return general_endcidrange_func(mem, s, pdficmap, &pdficmap->notdef_cmap_range);
+}
+
+static int cmap_endfbrange_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ pdf_cmap *pdficmap = (pdf_cmap *)s->client_data;
+ int ncodemaps, to_pop = pdf_ps_stack_count_to_mark(s, PDF_PS_OBJ_MARK);
+ int i, j, k;
+ pdfi_cmap_range_map_t *pdfir;
+ pdf_ps_stack_object_t *stobj;
+
+ /* increment to_pop to cover the mark object */
+ ncodemaps = to_pop++;
+ /* mapping should have 3 objects on the stack
+ */
+ while (ncodemaps % 3) ncodemaps--;
+
+ stobj = &s->cur[-ncodemaps] + 1;
+ for (i = 0; i < ncodemaps; i += 3) {
+ /* Lazy: to make the loop below simpler, put single
+ values into a one element array
+ */
+ if (pdf_ps_obj_has_type(&(stobj[i + 2]), PDF_PS_OBJ_STRING)) {
+ pdf_ps_stack_object_t *arr;
+ arr = (pdf_ps_stack_object_t *) gs_alloc_bytes(mem, sizeof(pdf_ps_stack_object_t), "cmap_endfbrange_func(pdf_ps_stack_object_t");
+ if (arr == NULL) {
+ return_error(gs_error_VMerror);
+ }
+ else {
+ memcpy(arr, &(stobj[i + 2]), sizeof(pdf_ps_stack_object_t));
+ pdf_ps_make_array(&(stobj[i + 2]), arr, 1);
+ }
+ }
+ }
+
+ stobj = &s->cur[-ncodemaps] + 1;
+
+ for (i = 0; i < ncodemaps; i += 3) {
+ int preflen, valuelen;
+
+ if (pdf_ps_obj_has_type(&(stobj[i + 2]), PDF_PS_OBJ_ARRAY)
+ && pdf_ps_obj_has_type(&(stobj[i + 1]), PDF_PS_OBJ_STRING)
+ && pdf_ps_obj_has_type(&(stobj[i]), PDF_PS_OBJ_STRING)){
+
+ uint cidbase = 0;
+ int srcs = 0, srce = 0;
+ int kslen = stobj[i].size;
+
+ if (kslen > 4) {
+ dprintf("CMap: value out of range\n");
+ continue;
+ }
+
+ for (k = 0; k < stobj[i].size; k++) {
+ srcs |= stobj[i].val.string[stobj[i].size - k - 1] << (8 * k);
+ }
+ for (k = 0; k < stobj[i + 1].size; k++) {
+ srce |= stobj[i + 1].val.string[stobj[i + 1].size - k - 1] << (8 * k);
+ }
+
+ for (k = srcs; k < srce + 1; k++) {
+ int m, size;
+ char srccode[4]; /* we only deal with up to 4 bytes */
+ char *psrccode = &(srccode[4 - kslen]);
+
+ if ((k - srcs) < stobj[i + 2].size) {
+ if (stobj[i + 2].val.arr[k - srcs].type != PDF_PS_OBJ_STRING)
+ continue;
+ size = stobj[i + 2].val.arr[k - srcs].size;
+
+ cidbase = 0;
+ for (m = 0; m < size; m++) {
+ cidbase |= stobj[i + 2].val.arr[k - srcs].val.string[size - m - 1];
+ }
+ }
+ else {
+ cidbase++;
+ }
+
+ for (m = 0; m < kslen; m++) {
+ psrccode[m] = (k >> (8 * (kslen - m - 1))) & 0xff;
+ }
+
+ /* Find how many bytes we need for the cidbase value */
+ /* We always store at least two bytes for the cidbase value */
+ for (valuelen = 16; valuelen < 32 && (cidbase >> valuelen) > 0; valuelen += 1)
+ DO_NOTHING;
+
+ preflen = kslen > 4 ? 4 : kslen;
+
+ valuelen = ((valuelen + 7) & ~7) >> 3;
+
+ /* The prefix is already directly in the gx_cmap_lookup_range_t
+ * We need to store the lower and upper character codes, after lopping the prefix
+ * off them. The upper and lower codes must be the same number of bytes.
+ */
+ j = sizeof(pdfi_cmap_range_map_t) + (kslen - preflen) + valuelen;
+
+ pdfir = (pdfi_cmap_range_map_t *)gs_alloc_bytes(mem, j, "cmap_endcidrange_func(pdfi_cmap_range_map_t)");
+ if (pdfir != NULL) {
+ gx_cmap_lookup_range_t *gxr = &pdfir->range;
+ pdfir->next = NULL;
+ gxr->num_entries = 1;
+ gxr->keys.data = (byte *)&(pdfir[1]);
+ gxr->values.data = gxr->keys.data + (kslen - preflen);
+
+ gxr->cmap = NULL;
+ gxr->font_index = 0;
+ gxr->key_is_range = false;
+ gxr->value_type = CODE_VALUE_CID;
+ gxr->key_prefix_size = preflen;
+ gxr->key_size = kslen - gxr->key_prefix_size;
+ memcpy(gxr->key_prefix, psrccode, gxr->key_prefix_size);
+
+ memcpy(gxr->keys.data, psrccode + gxr->key_prefix_size, kslen - gxr->key_prefix_size);
+
+ gxr->keys.size = kslen - gxr->key_prefix_size;
+ for (j = 0; j < valuelen; j++) {
+ gxr->values.data[j] = (cidbase >> ((valuelen - 1 - j) * 8)) & 255;
+ }
+ gxr->value_size = valuelen; /* I'm not sure.... */
+ gxr->values.size = valuelen;
+ if (cmap_insert_map(&(pdficmap->cmap_range), pdfir) < 0) break;
+ }
+ else {
+ break;
+ }
+ }
+ }
+ }
+ return pdf_ps_stack_pop(s, to_pop);
+}
+
+static int general_endcidchar_func(gs_memory_t *mem, pdf_ps_ctx_t *s, pdf_cmap *pdficmap, pdfi_cmap_range_t *cmap_range)
+{
+ int ncodemaps, to_pop = pdf_ps_stack_count_to_mark(s, PDF_PS_OBJ_MARK);
+ int i, j;
+ pdfi_cmap_range_map_t *pdfir;
+ pdf_ps_stack_object_t *stobj;
+
+ /* increment to_pop to cover the mark object */
+ ncodemaps = to_pop++;
+ /* mapping should have 2 objects on the stack:
+ * startcode, endcode and basecid
+ */
+ while (ncodemaps % 2) ncodemaps--;
+
+ stobj = &s->cur[-ncodemaps] + 1;
+
+ for (i = 0; i < ncodemaps; i += 2) {
+ int preflen = 1, valuelen;
+
+ if (pdf_ps_obj_has_type(&(stobj[i + 1]), PDF_PS_OBJ_INTEGER)
+ && pdf_ps_obj_has_type(&(stobj[i]), PDF_PS_OBJ_STRING)) {
+ uint cidbase = stobj[i + 1].val.i;
+
+ /* Find how many bytes we need for the cidbase value */
+ /* We always store at least two bytes for the cidbase value */
+ for (valuelen = 16; valuelen < 32 && (cidbase >> valuelen) > 0; valuelen += 1)
+ DO_NOTHING;
+
+ preflen = stobj[i].size > 4 ? 4 : stobj[i].size;
+
+ valuelen = ((valuelen + 7) & ~7) >> 3;
+
+ /* The prefix is already directly in the gx_cmap_lookup_range_t
+ * We need to store the lower and upper character codes, after lopping the prefix
+ * off them. The upper and lower codes must be the same number of bytes.
+ */
+ j = sizeof(pdfi_cmap_range_map_t) + (stobj[i].size - preflen) + valuelen;
+
+ pdfir = (pdfi_cmap_range_map_t *)gs_alloc_bytes(mem, j, "cmap_endcidrange_func(pdfi_cmap_range_map_t)");
+ if (pdfir != NULL) {
+ gx_cmap_lookup_range_t *gxr = &pdfir->range;
+ pdfir->next = NULL;
+ gxr->num_entries = 1;
+ gxr->keys.data = (byte *)&(pdfir[1]);
+ gxr->values.data = gxr->keys.data + (stobj[i].size - preflen);
+
+ gxr->cmap = NULL;
+ gxr->font_index = 0;
+ gxr->key_is_range = false;
+ gxr->value_type = cmap_range == &(pdficmap->cmap_range) ? CODE_VALUE_CID : CODE_VALUE_NOTDEF;
+ gxr->key_prefix_size = preflen;
+ gxr->key_size = stobj[i].size - gxr->key_prefix_size;
+ memcpy(gxr->key_prefix, stobj[i].val.string, gxr->key_prefix_size);
+
+ memcpy(gxr->keys.data, stobj[i].val.string + gxr->key_prefix_size, stobj[i].size - gxr->key_prefix_size);
+
+ gxr->keys.size = stobj[i].size - gxr->key_prefix_size;
+ for (j = 0; j < valuelen; j++) {
+ gxr->values.data[j] = (cidbase >> ((valuelen - 1 - j) * 8)) & 255;
+ }
+ gxr->value_size = valuelen; /* I'm not sure.... */
+ gxr->values.size = valuelen;
+ if (cmap_insert_map(cmap_range, pdfir) < 0) break;
+ }
+ else {
+ break;
+ }
+ }
+ }
+ return pdf_ps_stack_pop(s, to_pop);
+}
+
+static int cmap_endcidchar_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ pdf_cmap *pdficmap = (pdf_cmap *)s->client_data;
+ return general_endcidchar_func(mem, s, pdficmap, &pdficmap->cmap_range);
+}
+
+static int cmap_endnotdefchar_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ pdf_cmap *pdficmap = (pdf_cmap *)s->client_data;
+ return general_endcidchar_func(mem, s, pdficmap, &pdficmap->notdef_cmap_range);
+}
+
+static int cmap_endbfchar_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ pdf_cmap *pdficmap = (pdf_cmap *)s->client_data;
+ int ncodemaps = pdf_ps_stack_count_to_mark(s, PDF_PS_OBJ_MARK);
+ pdf_ps_stack_object_t *stobj;
+ int i, j;
+
+ stobj = &s->cur[-ncodemaps] + 1;
+
+ for (i = 0; i < ncodemaps; i += 2) {
+ if (pdf_ps_obj_has_type(&(stobj[i + 1]), PDF_PS_OBJ_STRING)) {
+ byte *c = stobj[i + 1].val.string;
+ int l = stobj[i + 1].size;
+ unsigned int v = 0;
+
+ for (j = 0; j < l; j++) {
+ v += c[l - j - 1] << (8 * j);
+ }
+ pdf_ps_make_int(&(stobj[i + 1]), v);
+ }
+ else {
+ continue;
+ }
+ }
+ return general_endcidchar_func(mem, s, pdficmap, &pdficmap->cmap_range);
+}
+
+#define CMAP_NAME_AND_LEN(s) PDF_PS_OPER_NAME_AND_LEN(s)
+
+static int cmap_def_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ int code = 0, code2 = 0;
+ pdf_cmap *pdficmap = (pdf_cmap *)s->client_data;
+
+ if (pdf_ps_stack_count(s) < 2) {
+ return pdf_ps_stack_pop(s, 1);
+ }
+
+ if (pdf_ps_obj_has_type(&s->cur[-1], PDF_PS_OBJ_NAME)) {
+ if (!memcmp(s->cur[-1].val.name, CMAP_NAME_AND_LEN("Registry"))) {
+ pdficmap->csi_reg.data = gs_alloc_bytes(mem, s->cur[0].size + 1, "cmap_def_func(Registry)");
+ if (pdficmap->csi_reg.data != NULL) {
+ pdficmap->csi_reg.size = s->cur[0].size;
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_STRING)) {
+ memcpy(pdficmap->csi_reg.data, s->cur[0].val.string, s->cur[0].size);
+ }
+ else {
+ memcpy(pdficmap->csi_reg.data, s->cur[0].val.name, s->cur[0].size);
+ }
+ pdficmap->csi_reg.data[pdficmap->csi_reg.size] = '\0';
+ }
+ else {
+ code = gs_note_error(gs_error_VMerror);
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, CMAP_NAME_AND_LEN("Ordering"))) {
+ pdficmap->csi_ord.data = gs_alloc_bytes(mem, s->cur[0].size + 1, "cmap_def_func(Ordering)");
+ if (pdficmap->csi_ord.data != NULL) {
+ pdficmap->csi_ord.size = s->cur[0].size;
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_STRING))
+ memcpy(pdficmap->csi_ord.data, s->cur[0].val.string, s->cur[0].size);
+ else
+ memcpy(pdficmap->csi_ord.data, s->cur[0].val.name, s->cur[0].size);
+ pdficmap->csi_ord.data[pdficmap->csi_ord.size] = '\0';
+ }
+ else {
+ code = gs_note_error(gs_error_VMerror);
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, CMAP_NAME_AND_LEN("Supplement"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_INTEGER)) {
+ pdficmap->csi_supplement = s->cur[0].val.i;
+ }
+ else {
+ pdficmap->csi_supplement = 0;
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, CMAP_NAME_AND_LEN("CMapName"))) {
+ pdficmap->name.data = gs_alloc_bytes(mem, s->cur[0].size + 1, "cmap_def_func(CMapName)");
+ if (pdficmap->name.data != NULL) {
+ pdficmap->name.size = s->cur[0].size;
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_STRING))
+ memcpy(pdficmap->name.data, s->cur[0].val.string, s->cur[0].size);
+ else
+ memcpy(pdficmap->name.data, s->cur[0].val.name, s->cur[0].size);
+ pdficmap->name.data[pdficmap->name.size] = '\0';
+ }
+ else {
+ code = gs_note_error(gs_error_VMerror);
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, CMAP_NAME_AND_LEN("CMapVersion"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_INTEGER)) {
+ pdficmap->vers = (float)s->cur[0].val.i;
+ }
+ else if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_FLOAT)){
+ pdficmap->vers = s->cur[0].val.f;
+ }
+ else {
+ pdficmap->vers = (float)0;
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, CMAP_NAME_AND_LEN("CMapType"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_INTEGER)) {
+ pdficmap->cmaptype = s->cur[0].val.i;
+ }
+ else {
+ pdficmap->type = 1;
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, CMAP_NAME_AND_LEN("XUID"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_ARRAY)) {
+ int len = s->cur->size;
+ pdficmap->uid.xvalues = (long *)gs_alloc_bytes(mem, len * sizeof(*pdficmap->uid.xvalues), "cmap_def_func(XUID)");
+ if (pdficmap->uid.xvalues != NULL) {
+ int i;
+ pdf_ps_stack_object_t *a = s->cur->val.arr;
+ pdficmap->uid.id = -len;
+ for (i = 0; i < len; i++) {
+ if (pdf_ps_obj_has_type(&a[i], PDF_PS_OBJ_INTEGER)) {
+ pdficmap->uid.xvalues[i] = (long)a[i].val.i;
+ }
+ else {
+ pdficmap->uid.xvalues[i] = 0;
+ }
+ }
+ }
+ else {
+ code = gs_note_error(gs_error_VMerror);
+ }
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, CMAP_NAME_AND_LEN("WMode"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_INTEGER)) {
+ pdficmap->wmode = s->cur[0].val.i;
+ }
+ else {
+ pdficmap->wmode = 0;
+ }
+ }
+ }
+
+ code2 = pdf_ps_stack_pop(s, 2);
+ if (code < 0)
+ return code;
+ else
+ return code2;
+}
+
+static pdf_ps_oper_list_t cmap_oper_list[] =
+{
+ {PDF_PS_OPER_NAME_AND_LEN("usecmap"), cmap_usecmap_func},
+ {PDF_PS_OPER_NAME_AND_LEN("usefont"), ps_pdf_null_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("beginusematrix"), ps_pdf_null_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("endusematrix"), ps_pdf_null_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("begincodespacerange"), pdf_ps_pop_and_pushmark_func},
+ {PDF_PS_OPER_NAME_AND_LEN("endcodespacerange"), cmap_endcodespacerange_func},
+ {PDF_PS_OPER_NAME_AND_LEN("begincmap"), ps_pdf_null_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("beginbfchar"), pdf_ps_pop_and_pushmark_func},
+ {PDF_PS_OPER_NAME_AND_LEN("endbfchar"), cmap_endbfchar_func},
+ {PDF_PS_OPER_NAME_AND_LEN("beginbfrange"), pdf_ps_pop_and_pushmark_func},
+ {PDF_PS_OPER_NAME_AND_LEN("endbfrange"), cmap_endfbrange_func},
+ {PDF_PS_OPER_NAME_AND_LEN("begincidchar"), pdf_ps_pop_and_pushmark_func},
+ {PDF_PS_OPER_NAME_AND_LEN("endcidchar"), cmap_endcidchar_func},
+ {PDF_PS_OPER_NAME_AND_LEN("begincidrange"), pdf_ps_pop_and_pushmark_func},
+ {PDF_PS_OPER_NAME_AND_LEN("endcidrange"), cmap_endcidrange_func},
+ {PDF_PS_OPER_NAME_AND_LEN("beginnotdefchar"), pdf_ps_pop_and_pushmark_func},
+ {PDF_PS_OPER_NAME_AND_LEN("endnotdefchar"), cmap_endnotdefchar_func},
+ {PDF_PS_OPER_NAME_AND_LEN("beginnotdefrange"), pdf_ps_pop_and_pushmark_func},
+ {PDF_PS_OPER_NAME_AND_LEN("endnotdefrange"), cmap_endnotdefrange_func},
+ {PDF_PS_OPER_NAME_AND_LEN("findresource"), clear_stack_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("dict"), pdf_ps_pop_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("begin"), ps_pdf_null_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("end"), ps_pdf_null_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("pop"), ps_pdf_null_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("def"), cmap_def_func},
+ {PDF_PS_OPER_NAME_AND_LEN("dup"), ps_pdf_null_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("defineresource"), clear_stack_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("beginrearrangedfont"), clear_stack_oper_func}, /* we should never see this */
+ {NULL, 0, NULL}
+};
+
+static int
+pdf_cmap_open_file(pdf_context *ctx, gs_string *cmap_name, byte **buf, int64_t *buflen)
+{
+ int code = 0;
+ stream *s;
+ char fname[gp_file_name_sizeof];
+ const char *path_pfx = "CMap/";
+ fname[0] = '\0';
+
+ strncat(fname, path_pfx, strlen(path_pfx));
+ strncat(fname, (char *)cmap_name->data, cmap_name->size);
+ code = pdfi_open_resource_file(ctx, (const char *)fname, (const int)strlen(fname), &s);
+ if (code >= 0) {
+ sfseek(s, 0, SEEK_END);
+ *buflen = sftell(s);
+ sfseek(s, 0, SEEK_SET);
+ *buf = gs_alloc_bytes(ctx->memory, *buflen, "pdf_cmap_open_file(buf)");
+ if (*buf != NULL) {
+ sfread(*buf, 1, *buflen, s);
+ }
+ else {
+ code = gs_note_error(gs_error_VMerror);
+ }
+ sfclose(s);
+ }
+ return code;
+}
+
+static int
+pdfi_make_gs_cmap(gs_memory_t *mem, pdf_cmap *pdficmap)
+{
+ int code = 0, i;
+ gs_cmap_adobe1_t *pgscmap = 0;
+ gx_cmap_lookup_range_t *lookups, *ndlookups = NULL;
+ pdfi_cmap_range_map_t *l;
+ /* FIXME: We have to use gs_cmap_adobe1_alloc() to get the cmap procs
+ but even if it gets passed num_ranges = 0 it still allocates
+ a zero length array. Change gs_cmap_adobe1_alloc to work better
+ */
+ if ((code = gs_cmap_adobe1_alloc(&pgscmap, pdficmap->wmode,
+ pdficmap->name.data,
+ pdficmap->name.size,
+ 1,
+ 0, 0, 0, 0, 0, mem)) >= 0) {
+ gs_free_object(mem, pgscmap->code_space.ranges, "empty ranges");
+
+ lookups = gs_alloc_struct_array(mem, pdficmap->cmap_range.numrangemaps,
+ gx_cmap_lookup_range_t,
+ &st_cmap_lookup_range_element,
+ "pdfi_make_gs_cmap(lookup ranges)");
+ if (lookups == NULL) {
+ gs_free_object(mem, pgscmap, "pdfi_make_gs_cmap(pgscmap)");
+ code = gs_note_error(gs_error_VMerror);
+ goto done;
+ }
+ if (pdficmap->notdef_cmap_range.numrangemaps > 0){
+ ndlookups = gs_alloc_struct_array(mem, pdficmap->notdef_cmap_range.numrangemaps,
+ gx_cmap_lookup_range_t,
+ &st_cmap_lookup_range_element,
+ "pdfi_make_gs_cmap(notdef lookup ranges)");
+ if (ndlookups == NULL) {
+ gs_free_object(mem, lookups, "pdfi_make_gs_cmap(lookups)");
+ gs_free_object(mem, pgscmap, "pdfi_make_gs_cmap(pgscmap)");
+ code = gs_note_error(gs_error_VMerror);
+ goto done;
+ }
+ }
+ pgscmap->def.lookup = lookups;
+ pgscmap->def.num_lookup = pdficmap->cmap_range.numrangemaps;
+ pgscmap->notdef.lookup = ndlookups;
+ pgscmap->notdef.num_lookup = pdficmap->notdef_cmap_range.numrangemaps;
+
+ pgscmap->CIDSystemInfo[0].Registry.data = pdficmap->csi_reg.data;
+ pgscmap->CIDSystemInfo[0].Registry.size = pdficmap->csi_reg.size;
+ pgscmap->CIDSystemInfo[0].Ordering.data = pdficmap->csi_ord.data;
+ pgscmap->CIDSystemInfo[0].Ordering.size = pdficmap->csi_ord.size;
+ pgscmap->CIDSystemInfo[0].Supplement = pdficmap->csi_supplement;
+ memcpy(&pgscmap->code_space, &pdficmap->code_space, sizeof(pgscmap->code_space));
+ memcpy(&pgscmap->uid, &pdficmap->uid, sizeof(pdficmap->uid));
+ l = pdficmap->cmap_range.ranges;
+ for (i = 0; i < pdficmap->cmap_range.numrangemaps && l != NULL; i++) {
+ memcpy(&lookups[i], &l->range, sizeof(gx_cmap_lookup_range_t));
+ l = l->next;
+ }
+
+ l = pdficmap->notdef_cmap_range.ranges;
+ for (i = 0; i < pdficmap->notdef_cmap_range.numrangemaps && l != NULL; i++) {
+ memcpy(&ndlookups[i], &l->range, sizeof(gx_cmap_lookup_range_t));
+ l = l->next;
+ }
+
+ pdficmap->gscmap = pgscmap;
+ }
+
+done:
+ return code;
+}
+
+int
+pdfi_read_cmap(pdf_context *ctx, pdf_obj *cmap, pdf_cmap **pcmap)
+{
+ int code = 0;
+ pdf_cmap pdficm[3] = {0};
+ pdf_cmap *pdfi_cmap = &(pdficm[1]);
+ byte *buf = NULL;
+ int64_t buflen;
+ pdf_ps_ctx_t cmap_ctx;
+
+ pdfi_cmap->ctx = ctx;
+ if (cmap->type == PDF_NAME) {
+ gs_string cmname;
+ pdf_name *cmapn = (pdf_name *)cmap;
+ cmname.data = cmapn->data;
+ cmname.size = cmapn->length;
+ code = pdf_cmap_open_file(ctx, &cmname, &buf, &buflen);
+ if (code < 0)
+ goto error_out;
+ }
+ else {
+ if (cmap->type == PDF_STREAM) {
+ pdf_obj *ucmap;
+ pdf_cmap *upcmap = NULL;
+ pdf_dict *cmap_dict = NULL;
+
+ code = pdfi_dict_from_obj(ctx, cmap, &cmap_dict);
+ if (code < 0)
+ goto error_out;
+
+ code = pdfi_dict_knownget(ctx, cmap_dict, "UseCMap", &ucmap);
+ if (code > 0) {
+ code = pdfi_read_cmap(ctx, ucmap, &upcmap);
+ pdfi_countdown(ucmap);
+ if (code >= 0) {
+ gx_code_space_range_t * ranges =
+ (gx_code_space_range_t *)gs_alloc_byte_array(ctx->memory, upcmap->code_space.num_ranges,
+ sizeof(gx_code_space_range_t), "cmap_usecmap_func(ranges)");
+ if (ranges != NULL) {
+ int i;
+ memcpy(&pdfi_cmap->code_space, &upcmap->code_space, sizeof(pdfi_cmap->code_space));
+ for (i = 0; i < upcmap->code_space.num_ranges; i++) {
+ memcpy(&(ranges[i]), &(upcmap->code_space.ranges[i]), sizeof(ranges[i]));
+ }
+ pdfi_cmap->code_space.ranges = ranges;
+ memcpy(&pdfi_cmap->cmap_range, &upcmap->cmap_range, sizeof(pdfi_cmap->cmap_range));
+ memcpy(&pdfi_cmap->notdef_cmap_range, &upcmap->notdef_cmap_range, sizeof(pdfi_cmap->notdef_cmap_range));
+ /* Once we've assumed control of these, NULL out entries for the sub-cmap. */
+ upcmap->cmap_range.ranges = NULL;
+ upcmap->notdef_cmap_range.ranges = NULL;
+ /* But we keep the subcmap itself because we rely on its storage */
+ pdfi_cmap->next = upcmap;
+ }
+ }
+ else {
+ pdfi_countdown(upcmap);
+ }
+ }
+
+ code = pdfi_stream_to_buffer(ctx, (pdf_stream *)cmap, &buf, &buflen);
+ if (code < 0) {
+ goto error_out;
+ }
+ }
+ else {
+ code = gs_note_error(gs_error_typecheck);
+ goto error_out;
+ }
+ }
+ pdfi_cmap->ctx = ctx;
+ pdfi_cmap->buf = buf;
+ pdfi_cmap->buflen = buflen;
+
+ /* In case of technically invalid CMap files which do not contain a CMapType, See Bug #690737.
+ * This makes sure we clean up the CMap contents in pdfi_free_cmap() below.
+ */
+ pdfi_cmap->cmaptype = 1;
+
+ pdfi_pscript_stack_init(ctx, cmap_oper_list, (void *)pdfi_cmap, &cmap_ctx);
+
+ code = pdfi_pscript_interpret(&cmap_ctx, buf, buflen);
+ pdfi_pscript_stack_finit(&cmap_ctx);
+ if (code < 0) goto error_out;
+
+ code = pdfi_make_gs_cmap(ctx->memory, pdfi_cmap);
+
+ if (code >= 0) {
+ *pcmap = (pdf_cmap *)gs_alloc_bytes(ctx->memory, sizeof(pdf_cmap), "pdfi_read_cmap(*pcmap)");
+ if (*pcmap != NULL) {
+ pdfi_cmap->type = PDF_CMAP;
+ pdfi_cmap->ctx = ctx;
+ pdfi_cmap->refcnt = 1;
+ pdfi_cmap->object_num = cmap->object_num;
+ pdfi_cmap->generation_num = cmap->generation_num;
+ pdfi_cmap->indirect_num = cmap->indirect_num;
+ pdfi_cmap->indirect_gen = cmap->indirect_gen;
+ memcpy(*pcmap, pdfi_cmap, sizeof(pdf_cmap));
+ pdfi_cmap = *pcmap;
+ /* object_num can be zero if the dictionary was defined inline */
+ if (pdfi_cmap->object_num != 0) {
+ code = replace_cache_entry(ctx, (pdf_obj *)pdfi_cmap);
+ }
+ }
+ }
+ return 0;
+
+error_out:
+ pdfi_free_cmap_contents(pdfi_cmap);
+ memset(pdfi_cmap, 0x00, sizeof(pdf_cmap));
+ return code;
+}
+
+static int pdfi_free_cmap_contents(pdf_cmap *cmap)
+{
+ pdfi_cmap_range_map_t *pdfir;
+ gs_cmap_adobe1_t *pgscmap = cmap->gscmap;
+
+ if (pgscmap != NULL) {
+ gs_free_object(OBJ_MEMORY(cmap), pgscmap->def.lookup, "pdfi_free_cmap(def.lookup)");
+ gs_free_object(OBJ_MEMORY(cmap), pgscmap->notdef.lookup, "pdfi_free_cmap(notdef.lookup)");
+ (void)gs_cmap_free((gs_cmap_t *)pgscmap, OBJ_MEMORY(cmap));
+ }
+ gs_free_object(OBJ_MEMORY(cmap), cmap->code_space.ranges, "pdfi_free_cmap(code_space.ranges");
+ pdfir = cmap->cmap_range.ranges;
+ while (pdfir != NULL) {
+ pdfi_cmap_range_map_t *pdfir2 = pdfir->next;
+ gs_free_object(OBJ_MEMORY(cmap), pdfir, "pdfi_free_cmap(cmap_range.ranges");
+ pdfir = pdfir2;
+ }
+ pdfir = cmap->notdef_cmap_range.ranges;
+ while (pdfir != NULL) {
+ pdfi_cmap_range_map_t *pdfir2 = pdfir->next;
+ gs_free_object(OBJ_MEMORY(cmap), pdfir, "pdfi_free_cmap(cmap_range.ranges");
+ pdfir = pdfir2;
+ }
+ gs_free_object(OBJ_MEMORY(cmap), cmap->csi_reg.data, "pdfi_free_cmap(csi_reg.data");
+ gs_free_object(OBJ_MEMORY(cmap), cmap->csi_ord.data, "pdfi_free_cmap(csi_ord.data");
+ gs_free_object(OBJ_MEMORY(cmap), cmap->name.data, "pdfi_free_cmap(name.data");
+ gs_free_object(OBJ_MEMORY(cmap), cmap->uid.xvalues, "pdfi_free_cmap(xuid.xvalues");
+ pdfi_countdown(cmap->next);
+ gs_free_object(OBJ_MEMORY(cmap), cmap->buf, "pdfi_free_cmap(cmap->buf");
+
+ return 0;
+}
+
+int pdfi_free_cmap(pdf_obj *cmapo)
+{
+ pdf_cmap *cmap = (pdf_cmap *)cmapo;
+ /*
+ * Note there is some inconsistency in the various specifications regarding CMapType; the
+ * Adobe tech note 5014 specifically says it only documents CMaps with a CmapType of 0, the
+ * PLRM says that CMapType can be 0 or 1, and the two are equivalent, the PDF Reference Manual
+ * doesn't say, it just refers to tech note 5014 but the example has a CMapType of 1. The PDF
+ * Reference does describe ToUnicode CMaps which have a CMapType of 2.
+ */
+ /* Well it seems we have PDF files which use CMapType 2 CMaps as values for a /Encoding, which is
+ * I believe incorrect, as these are ToUnicode CMaps....
+ * There's nothing for it, we'll just haev to free all CMaps for now. Note for Chris when implementing
+ * ToUnicode CMaps, we'll obviously have to rely on the context to know whether a CMap is an Encoding
+ * or a ToUnicode, we cna't use the CmMapType, just as you suspected. :-(
+ * See bug #696449 633_R00728_E.pdf
+ */
+ /*
+ * For now, we represent ToUnicode CMaps (CMapType 2) in the same data structures as regular CMaps
+ * (CMapType 0/1) so there is no reason (yet!) to differentiate between the two.
+ */
+
+ pdfi_free_cmap_contents(cmap);
+ gs_free_object(OBJ_MEMORY(cmap), cmap, "pdfi_free_cmap(cmap");
+ return 0;
+}
diff --git a/pdf/pdf_cmap.h b/pdf/pdf_cmap.h
new file mode 100644
index 00000000..c7de588f
--- /dev/null
+++ b/pdf/pdf_cmap.h
@@ -0,0 +1,70 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+#ifndef PDF_CMAP_H
+#define PDF_CMAP_H
+
+#include "gxfcmap1.h"
+#include "pdf_font_types.h"
+
+/* Each pdfi_cmap_range_map_t allocations should include the
+ * space required for the key and value strings, thus is
+ * self contained, and avoids allocating lots of 1/2 byte
+ * blocks
+ */
+typedef struct pdfi_cmap_range_map_s pdfi_cmap_range_map_t;
+
+struct pdfi_cmap_range_map_s {
+ gx_cmap_lookup_range_t range;
+ pdfi_cmap_range_map_t *next;
+};
+
+typedef struct pdfi_cmap_range_s pdfi_cmap_range_t;
+
+struct pdfi_cmap_range_s {
+ pdfi_cmap_range_map_t *ranges;
+ pdfi_cmap_range_map_t *ranges_tail;
+ int numrangemaps;
+};
+
+typedef struct pdf_cmap_s pdf_cmap;
+
+struct pdf_cmap_s
+{
+ pdf_obj_common;
+ byte *buf;
+ int buflen;
+ int cmaptype;
+ gs_string name;
+ gs_string csi_reg;
+ gs_string csi_ord;
+ int csi_supplement;
+ float vers;
+ gs_uid uid;
+ int wmode;
+ gx_code_space_t code_space;
+ pdfi_cmap_range_t cmap_range;
+ pdfi_cmap_range_t notdef_cmap_range;
+ gs_cmap_adobe1_t *gscmap;
+
+ pdf_cmap *next;
+};
+
+
+int
+pdfi_read_cmap(pdf_context *ctx, pdf_obj *cmap, pdf_cmap **pcmap);
+int
+pdfi_free_cmap(pdf_obj *cmapo);
+
+#endif /* PDF_CMAP_H */
diff --git a/pdf/pdf_colour.c b/pdf/pdf_colour.c
new file mode 100644
index 00000000..e6061db1
--- /dev/null
+++ b/pdf/pdf_colour.c
@@ -0,0 +1,2676 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* colour operations for the PDF interpreter */
+
+#include "pdf_int.h"
+#include "pdf_doc.h"
+#include "pdf_colour.h"
+#include "pdf_pattern.h"
+#include "pdf_stack.h"
+#include "pdf_array.h"
+#include "pdf_misc.h"
+#include "gsicc_manage.h"
+#include "gsicc_profilecache.h"
+#include "gsicc_create.h"
+#include "gsptype2.h"
+
+#include "pdf_file.h"
+#include "pdf_dict.h"
+#include "pdf_loop_detect.h"
+#include "pdf_func.h"
+#include "pdf_shading.h"
+#include "gscsepr.h"
+#include "stream.h"
+#include "strmio.h"
+#include "gscdevn.h"
+#include "gxcdevn.h"
+#include "gscolor.h" /* For gs_setgray() and friends */
+#include "gsicc.h" /* For gs_cspace_build_ICC() */
+#include "gsstate.h" /* For gs_gdsvae() and gs_grestore() */
+
+/* Forward definitions for a routine we need */
+static int pdfi_create_colorspace_by_array(pdf_context *ctx, pdf_array *color_array, int index,
+ pdf_dict *stream_dict, pdf_dict *page_dict,
+ gs_color_space **ppcs, bool inline_image);
+static int pdfi_create_colorspace_by_name(pdf_context *ctx, pdf_name *name,
+ pdf_dict *stream_dict, pdf_dict *page_dict,
+ gs_color_space **ppcs, bool inline_image);
+
+/* This is used only from the page level interpreter code, we need to know the number
+ * of spot colours in a PDF file, which we have to pass to the device for spot colour
+ * rendering. We deal with it here because its colour related.
+ * The PDF context has a page-level object which maintains a list of the spot colour
+ * names seen so far, so we can ensure we don't end up with duplictaes.
+ */
+static int pdfi_check_for_spots_by_name(pdf_context *ctx, pdf_name *name,
+ pdf_dict *parent_dict, pdf_dict *page_dict, pdf_dict *spot_dict)
+{
+ pdf_obj *ref_space;
+ int code;
+
+ if (pdfi_name_is(name, "G")) {
+ return 0;
+ } else if (pdfi_name_is(name, "RGB")) {
+ return 0;
+ } else if (pdfi_name_is(name, "CMYK")) {
+ return 0;
+ } else if (pdfi_name_is(name, "DeviceRGB")) {
+ return 0;
+ } else if (pdfi_name_is(name, "DeviceGray")) {
+ return 0;
+ } else if (pdfi_name_is(name, "DeviceCMYK")) {
+ return 0;
+ } else if (pdfi_name_is(name, "Pattern")) {
+ /* TODO: I think this is fine... */
+ return 0;
+ } else {
+ code = pdfi_find_resource(ctx, (unsigned char *)"ColorSpace", name, parent_dict, page_dict, &ref_space);
+ if (code < 0)
+ return code;
+
+ /* recursion */
+ return pdfi_check_ColorSpace_for_spots(ctx, ref_space, parent_dict, page_dict, spot_dict);
+ }
+ return 0;
+}
+
+static int pdfi_check_for_spots_by_array(pdf_context *ctx, pdf_array *color_array,
+ pdf_dict *parent_dict, pdf_dict *page_dict, pdf_dict *spot_dict)
+{
+ pdf_name *space = NULL;
+ pdf_array *a = NULL;
+ int code = 0;
+
+ if (!spot_dict)
+ return 0;
+
+ code = pdfi_array_get_type(ctx, color_array, 0, PDF_NAME, (pdf_obj **)&space);
+ if (code != 0)
+ goto exit;
+
+ code = 0;
+ if (pdfi_name_is(space, "G")) {
+ goto exit;
+ } else if (pdfi_name_is(space, "I") || pdfi_name_is(space, "Indexed")) {
+ pdf_obj *base_space;
+
+ code = pdfi_array_get(ctx, color_array, 1, &base_space);
+ if (code == 0) {
+ code = pdfi_check_ColorSpace_for_spots(ctx, base_space, parent_dict, page_dict, spot_dict);
+ (void)pdfi_countdown(base_space);
+ }
+ goto exit;
+ } else if (pdfi_name_is(space, "Pattern")) {
+ pdf_obj *base_space = NULL;
+ uint64_t size = pdfi_array_size(color_array);
+
+ /* Array of size 1 "[ /Pattern ]" is okay, just do nothing. */
+ if (size == 1)
+ goto exit;
+ /* Array of size > 2 we don't handle (shouldn't happen?) */
+ if (size != 2) {
+ dbgmprintf1(ctx->memory,
+ "WARNING: checking Pattern for spots, expected array size 2, got %lu\n",
+ size);
+ goto exit;
+ }
+ /* "[/Pattern base_space]" */
+ code = pdfi_array_get(ctx, color_array, 1, &base_space);
+ if (code == 0) {
+ code = pdfi_check_ColorSpace_for_spots(ctx, base_space, parent_dict, page_dict, spot_dict);
+ (void)pdfi_countdown(base_space);
+ }
+ goto exit;
+ } else if (pdfi_name_is(space, "Lab")) {
+ goto exit;
+ } else if (pdfi_name_is(space, "RGB")) {
+ goto exit;
+ } else if (pdfi_name_is(space, "CMYK")) {
+ goto exit;
+ } else if (pdfi_name_is(space, "CalRGB")) {
+ goto exit;
+ } else if (pdfi_name_is(space, "CalGray")) {
+ goto exit;
+ } else if (pdfi_name_is(space, "ICCBased")) {
+ goto exit;
+ } else if (pdfi_name_is(space, "DeviceRGB")) {
+ goto exit;
+ } else if (pdfi_name_is(space, "DeviceGray")) {
+ goto exit;
+ } else if (pdfi_name_is(space, "DeviceCMYK")) {
+ goto exit;
+ } else if (pdfi_name_is(space, "DeviceN")) {
+ bool known = false;
+ pdf_obj *dummy, *name;
+ int i;
+
+ pdfi_countdown(space);
+ code = pdfi_array_get_type(ctx, color_array, 1, PDF_ARRAY, (pdf_obj **)&space);
+ if (code != 0)
+ goto exit;
+
+ for (i=0;i < pdfi_array_size((pdf_array *)space); i++) {
+ code = pdfi_array_get_type(ctx, (pdf_array *)space, (uint64_t)i, PDF_NAME, &name);
+ if (code < 0)
+ goto exit;
+
+ if (pdfi_name_is((const pdf_name *)name, "Cyan") || pdfi_name_is((const pdf_name *)name, "Magenta") ||
+ pdfi_name_is((const pdf_name *)name, "Yellow") || pdfi_name_is((const pdf_name *)name, "Black") ||
+ pdfi_name_is((const pdf_name *)name, "None") || pdfi_name_is((const pdf_name *)name, "All")) {
+
+ pdfi_countdown(name);
+ continue;
+ }
+
+ code = pdfi_dict_known_by_key(ctx, spot_dict, (pdf_name *)name, &known);
+ if (code < 0) {
+ pdfi_countdown(name);
+ goto exit;
+ }
+ if (known) {
+ pdfi_countdown(name);
+ continue;
+ }
+
+ code = pdfi_object_alloc(ctx, PDF_INT, 0, &dummy);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_dict_put_obj(ctx, spot_dict, name, dummy);
+ pdfi_countdown(name);
+ if (code < 0)
+ break;
+ }
+ goto exit;
+ } else if (pdfi_name_is(space, "Separation")) {
+ bool known = false;
+ pdf_obj *dummy;
+
+ pdfi_countdown(space);
+ code = pdfi_array_get_type(ctx, color_array, 1, PDF_NAME, (pdf_obj **)&space);
+ if (code != 0)
+ goto exit;
+
+ if (pdfi_name_is((const pdf_name *)space, "Cyan") || pdfi_name_is((const pdf_name *)space, "Magenta") ||
+ pdfi_name_is((const pdf_name *)space, "Yellow") || pdfi_name_is((const pdf_name *)space, "Black") ||
+ pdfi_name_is((const pdf_name *)space, "None") || pdfi_name_is((const pdf_name *)space, "All"))
+ goto exit;
+ code = pdfi_dict_known_by_key(ctx, spot_dict, space, &known);
+ if (code < 0 || known)
+ goto exit;
+
+ code = pdfi_object_alloc(ctx, PDF_INT, 0, &dummy);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_dict_put_obj(ctx, spot_dict, (pdf_obj *)space, dummy);
+ goto exit;
+ } else {
+ code = pdfi_find_resource(ctx, (unsigned char *)"ColorSpace",
+ space, parent_dict, page_dict, (pdf_obj **)&a);
+ if (code < 0)
+ goto exit;
+
+ if (a->type != PDF_ARRAY) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+
+ /* recursion */
+ code = pdfi_check_for_spots_by_array(ctx, a, parent_dict, page_dict, spot_dict);
+ }
+
+ exit:
+ if (space)
+ pdfi_countdown(space);
+ if (a)
+ pdfi_countdown(a);
+ return code;
+}
+
+int pdfi_check_ColorSpace_for_spots(pdf_context *ctx, pdf_obj *space, pdf_dict *parent_dict,
+ pdf_dict *page_dict, pdf_dict *spot_dict)
+{
+ int code;
+
+ if (!spot_dict)
+ return 0;
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ return code;
+
+ if (space->type == PDF_NAME) {
+ code = pdfi_check_for_spots_by_name(ctx, (pdf_name *)space, parent_dict, page_dict, spot_dict);
+ } else {
+ if (space->type == PDF_ARRAY) {
+ code = pdfi_check_for_spots_by_array(ctx, (pdf_array *)space, parent_dict, page_dict, spot_dict);
+ } else {
+ pdfi_loop_detector_cleartomark(ctx);
+ return 0;
+ }
+ }
+
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ return code;
+}
+
+/* Rendering intent is a bit of an oddity, but its clearly colour related, so we
+ * deal with it here. Cover it first to get it out of the way.
+ */
+int pdfi_ri(pdf_context *ctx)
+{
+ pdf_name *n;
+ int code;
+
+ if (pdfi_count_stack(ctx) < 1)
+ return_error(gs_error_stackunderflow);
+
+ if (ctx->stack_top[-1]->type != PDF_NAME) {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_typecheck);
+ }
+ n = (pdf_name *)ctx->stack_top[-1];
+ code = pdfi_setrenderingintent(ctx, n);
+ pdfi_pop(ctx, 1);
+ return code;
+}
+
+/*
+ * Pattern lifetime management turns out to be more complex than we would ideally like. Although
+ * Patterns are reference counted, and contain a client_data pointer, they don't have a gs_notify
+ * setup. This means that there's no simlpe way for us to be informed when a Pattern is released
+ * We could patch up the Pattern finalize() method, replacing it with one of our own which calls
+ * the original finalize() but that seems like a really nasty hack.
+ * For the time being we put code in pdfi_grestore() to check for Pattern colour spaces being
+ * restored away, but we also need to check for Pattern spaces being replaced in the current
+ * graphics state. We define 'pdfi' variants of several graphics library colour management
+ * functions to 'wrap' these with code to check for replacement of Patterns.
+ * This comment is duplicated in pdf_pattern.c
+ */
+
+static void pdfi_cspace_free_callback(gs_memory_t * mem, void *cs)
+{
+ gs_color_space *pcs = (gs_color_space *)cs;
+ pdf_context *ctx = (pdf_context *)pcs->interpreter_data;
+ gs_function_t *pfn;
+
+ if (gs_color_space_get_index(pcs) == gs_color_space_index_Separation) {
+ /* Handle cleanup of Separation functions if applicable */
+ pfn = gs_cspace_get_sepr_function(pcs);
+ if (pfn)
+ pdfi_free_function(ctx, pfn);
+ }
+
+ if (gs_color_space_get_index(pcs) == gs_color_space_index_DeviceN) {
+ /* Handle cleanup of DeviceN functions if applicable */
+ pfn = gs_cspace_get_devn_function(pcs);
+ if (pfn)
+ pdfi_free_function(ctx, pfn);
+ }
+}
+
+int pdfi_gs_setgray(pdf_context *ctx, double d)
+{
+ int code = 0;
+
+ /* PDF Reference 1.7 p423, any colour operators in a CharProc, following a d1, should be ignored */
+ if (ctx->text.inside_CharProc && ctx->text.CharProc_is_d1)
+ return 0;
+
+ if (ctx->page.DefaultGray_cs != NULL) {
+ gs_client_color cc;
+
+ code = gs_setcolorspace(ctx->pgs, ctx->page.DefaultGray_cs);
+ if (code < 0)
+ return code;
+ pdfi_set_colour_callback(ctx->pgs->color[0].color_space, ctx, NULL);
+ cc.paint.values[0] = d;
+ return gs_setcolor(ctx->pgs, &cc);
+ } else {
+ code = gs_setgray(ctx->pgs, d);
+ if (code < 0)
+ return code;
+ pdfi_set_colour_callback(ctx->pgs->color[0].color_space, ctx, pdfi_cspace_free_callback);
+ }
+ return 0;
+}
+
+int pdfi_gs_setrgbcolor(pdf_context *ctx, double r, double g, double b)
+{
+ int code = 0;
+
+ /* PDF Reference 1.7 p423, any colour operators in a CharProc, following a d1, should be ignored */
+ if (ctx->text.inside_CharProc && ctx->text.CharProc_is_d1)
+ return 0;
+
+ if (ctx->page.DefaultRGB_cs != NULL) {
+ gs_client_color cc;
+
+ code = gs_setcolorspace(ctx->pgs, ctx->page.DefaultRGB_cs);
+ if (code < 0)
+ return code;
+ pdfi_set_colour_callback(ctx->pgs->color[0].color_space, ctx, NULL);
+ cc.paint.values[0] = r;
+ cc.paint.values[1] = g;
+ cc.paint.values[2] = b;
+ return gs_setcolor(ctx->pgs, &cc);
+ } else {
+ code = gs_setrgbcolor(ctx->pgs, r, g, b);
+ if (code < 0)
+ return code;
+ pdfi_set_colour_callback(ctx->pgs->color[0].color_space, ctx, pdfi_cspace_free_callback);
+ }
+ return 0;
+}
+
+static int pdfi_gs_setcmykcolor(pdf_context *ctx, double c, double m, double y, double k)
+{
+ int code = 0;
+
+ /* PDF Reference 1.7 p423, any colour operators in a CharProc, following a d1, should be ignored */
+ if (ctx->text.inside_CharProc && ctx->text.CharProc_is_d1)
+ return 0;
+
+ if (ctx->page.DefaultCMYK_cs != NULL) {
+ gs_client_color cc;
+
+ code = gs_setcolorspace(ctx->pgs, ctx->page.DefaultCMYK_cs);
+ if (code < 0)
+ return code;
+ pdfi_set_colour_callback(ctx->pgs->color[0].color_space, ctx, NULL);
+ cc.paint.values[0] = c;
+ cc.paint.values[1] = m;
+ cc.paint.values[2] = y;
+ cc.paint.values[3] = k;
+ return gs_setcolor(ctx->pgs, &cc);
+ } else {
+ code = gs_setcmykcolor(ctx->pgs, c, m, y, k);
+ if (code < 0)
+ return code;
+ pdfi_set_colour_callback(ctx->pgs->color[0].color_space, ctx, pdfi_cspace_free_callback);
+ }
+ return 0;
+}
+
+int pdfi_gs_setcolorspace(pdf_context *ctx, gs_color_space *pcs)
+{
+ /* If the target colour space is already the current colour space, don't
+ * bother to do anything.
+ */
+ if (ctx->pgs->color[0].color_space->id != pcs->id) {
+ /* PDF Reference 1.7 p423, any colour operators in a CharProc, following a d1, should be ignored */
+ if (ctx->text.inside_CharProc && ctx->text.CharProc_is_d1)
+ return 0;
+
+ pdfi_set_colour_callback(pcs, ctx, pdfi_cspace_free_callback);
+ return gs_setcolorspace(ctx->pgs, pcs);
+ }
+ return 0;
+}
+
+/* Start with the simple cases, where we set the colour space and colour in a single operation */
+int pdfi_setgraystroke(pdf_context *ctx)
+{
+ pdf_num *n1;
+ int code;
+ double d1;
+
+ if (pdfi_count_stack(ctx) < 1)
+ return_error(gs_error_stackunderflow);
+
+ n1 = (pdf_num *)ctx->stack_top[-1];
+ if (n1->type == PDF_INT){
+ d1 = (double)n1->value.i;
+ } else{
+ if (n1->type == PDF_REAL) {
+ d1 = n1->value.d;
+ } else {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_typecheck);
+ }
+ }
+ gs_swapcolors_quick(ctx->pgs);
+ code = pdfi_gs_setgray(ctx, d1);
+ gs_swapcolors_quick(ctx->pgs);
+ pdfi_pop(ctx, 1);
+ return code;
+}
+
+int pdfi_setgrayfill(pdf_context *ctx)
+{
+ pdf_num *n1;
+ int code;
+ double d1;
+
+ if (pdfi_count_stack(ctx) < 1)
+ return_error(gs_error_stackunderflow);
+
+ n1 = (pdf_num *)ctx->stack_top[-1];
+ if (n1->type == PDF_INT){
+ d1 = (double)n1->value.i;
+ } else{
+ if (n1->type == PDF_REAL) {
+ d1 = n1->value.d;
+ } else {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_typecheck);
+ }
+ }
+ code = pdfi_gs_setgray(ctx, d1);
+ pdfi_pop(ctx, 1);
+ return code;
+}
+
+int pdfi_setrgbstroke(pdf_context *ctx)
+{
+ pdf_num *num;
+ double Values[3];
+ int i, code;
+
+ if (pdfi_count_stack(ctx) < 3) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ for (i=0;i < 3;i++){
+ num = (pdf_num *)ctx->stack_top[i - 3];
+ if (num->type != PDF_INT) {
+ if(num->type != PDF_REAL) {
+ pdfi_pop(ctx, 3);
+ return_error(gs_error_typecheck);
+ }
+ else
+ Values[i] = num->value.d;
+ } else {
+ Values[i] = (double)num->value.i;
+ }
+ }
+ gs_swapcolors_quick(ctx->pgs);
+ code = pdfi_gs_setrgbcolor(ctx, Values[0], Values[1], Values[2]);
+ gs_swapcolors_quick(ctx->pgs);
+ pdfi_pop(ctx, 3);
+ return code;
+}
+
+/* Non-standard operator that is used in some annotation /DA
+ * Expects stack to be [r g b]
+ */
+int pdfi_setrgbfill_array(pdf_context *ctx)
+{
+ int code;
+ pdf_array *array = NULL;
+
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_NONSTANDARD_OP, "pdfi_setrgbfill_array", (char *)"WARNING: Non-standard 'r' operator");
+
+ if (pdfi_count_stack(ctx) < 1)
+ return_error(gs_error_stackunderflow);
+
+ array = (pdf_array *)ctx->stack_top[-1];
+ if (array->type != PDF_ARRAY) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+
+ code = pdfi_setcolor_from_array(ctx, array);
+ exit:
+ pdfi_pop(ctx, 1);
+ return code;
+}
+
+int pdfi_setrgbfill(pdf_context *ctx)
+{
+ pdf_num *num;
+ double Values[3];
+ int i, code;
+
+ if (pdfi_count_stack(ctx) < 3) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ for (i=0;i < 3;i++){
+ num = (pdf_num *)ctx->stack_top[i - 3];
+ if (num->type != PDF_INT) {
+ if(num->type != PDF_REAL) {
+ pdfi_pop(ctx, 3);
+ return_error(gs_error_typecheck);
+ }
+ else
+ Values[i] = num->value.d;
+ } else {
+ Values[i] = (double)num->value.i;
+ }
+ }
+ code = pdfi_gs_setrgbcolor(ctx, Values[0], Values[1], Values[2]);
+ pdfi_pop(ctx, 3);
+ return code;
+}
+
+int pdfi_setcmykstroke(pdf_context *ctx)
+{
+ pdf_num *num;
+ double Values[4];
+ int i, code;
+
+ if (pdfi_count_stack(ctx) < 4) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ for (i=0;i < 4;i++){
+ num = (pdf_num *)ctx->stack_top[i - 4];
+ if (num->type != PDF_INT) {
+ if(num->type != PDF_REAL) {
+ pdfi_pop(ctx, 4);
+ return_error(gs_error_typecheck);
+ }
+ else
+ Values[i] = num->value.d;
+ } else {
+ Values[i] = (double)num->value.i;
+ }
+ }
+ gs_swapcolors_quick(ctx->pgs);
+ code = pdfi_gs_setcmykcolor(ctx, Values[0], Values[1], Values[2], Values[3]);
+ gs_swapcolors_quick(ctx->pgs);
+ pdfi_pop(ctx, 4);
+ return code;
+}
+
+int pdfi_setcmykfill(pdf_context *ctx)
+{
+ pdf_num *num;
+ double Values[4];
+ int i, code;
+
+ if (pdfi_count_stack(ctx) < 4) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ for (i=0;i < 4;i++){
+ num = (pdf_num *)ctx->stack_top[i - 4];
+ if (num->type != PDF_INT) {
+ if(num->type != PDF_REAL) {
+ pdfi_pop(ctx, 4);
+ return_error(gs_error_typecheck);
+ }
+ else
+ Values[i] = num->value.d;
+ } else {
+ Values[i] = (double)num->value.i;
+ }
+ }
+ code = pdfi_gs_setcmykcolor(ctx, Values[0], Values[1], Values[2], Values[3]);
+ pdfi_pop(ctx, 4);
+ return code;
+}
+
+/* Do a setcolor using values in an array
+ * Will do gray, rgb, cmyk for sizes 1,3,4
+ * Anything else is an error
+ */
+int pdfi_setcolor_from_array(pdf_context *ctx, pdf_array *array)
+{
+ int code = 0;
+ uint64_t size;
+ double values[4];
+
+ size = pdfi_array_size(array);
+ if (size != 1 && size != 3 && size != 4) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+
+ code = pdfi_array_to_num_array(ctx, array, values, 0, size);
+ if (code < 0) goto exit;
+
+ switch (size) {
+ case 1:
+ code = pdfi_gs_setgray(ctx, values[0]);
+ break;
+ case 3:
+ code = pdfi_gs_setrgbcolor(ctx, values[0], values[1], values[2]);
+ break;
+ case 4:
+ code = pdfi_gs_setcmykcolor(ctx, values[0], values[1], values[2], values[3]);
+ break;
+ default:
+ break;
+ }
+
+ exit:
+ return code;
+}
+
+/* Get colors from top of stack into a client color */
+static int
+pdfi_get_color_from_stack(pdf_context *ctx, gs_client_color *cc, int ncomps)
+{
+ int i;
+ pdf_num *n;
+
+ if (pdfi_count_stack(ctx) < ncomps) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+ for (i=0;i<ncomps;i++){
+ n = (pdf_num *)ctx->stack_top[i - ncomps];
+ if (n->type == PDF_INT) {
+ cc->paint.values[i] = (float)n->value.i;
+ } else {
+ if (n->type == PDF_REAL) {
+ cc->paint.values[i] = n->value.d;
+ } else {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_typecheck);
+ }
+ }
+ }
+ pdfi_pop(ctx, ncomps);
+ return 0;
+}
+
+/* Now deal with the case where we have to set the colour space separately from the
+ * colour values. We'll start with the routines to set the colour, because setting
+ * colour components is relatively easy.
+ */
+
+/* First up, the SC and sc operators. These set the colour for all spaces *except*
+ * ICCBased, Pattern, Separation and DeviceN
+ */
+int pdfi_setstrokecolor(pdf_context *ctx)
+{
+ const gs_color_space * pcs;
+ int ncomps, code;
+ gs_client_color cc;
+
+ gs_swapcolors_quick(ctx->pgs);
+ pcs = gs_currentcolorspace(ctx->pgs);
+ ncomps = cs_num_components(pcs);
+ code = pdfi_get_color_from_stack(ctx, &cc, ncomps);
+ if (code == 0) {
+ code = gs_setcolor(ctx->pgs, &cc);
+ }
+ gs_swapcolors_quick(ctx->pgs);
+ return code;
+}
+
+int pdfi_setfillcolor(pdf_context *ctx)
+{
+ const gs_color_space * pcs = gs_currentcolorspace(ctx->pgs);
+ int ncomps, code;
+ gs_client_color cc;
+
+ ncomps = cs_num_components(pcs);
+ code = pdfi_get_color_from_stack(ctx, &cc, ncomps);
+ if (code == 0) {
+ code = gs_setcolor(ctx->pgs, &cc);
+ }
+ return code;
+}
+
+static inline bool
+pattern_instance_uses_base_space(const gs_pattern_instance_t * pinst)
+{
+ return pinst->type->procs.uses_base_space(
+ pinst->type->procs.get_pattern(pinst) );
+}
+
+/* Now the SCN and scn operators. These set the colour for special spaces;
+ * ICCBased, Pattern, Separation and DeviceN
+ */
+int
+pdfi_setcolorN(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict, bool is_fill)
+{
+ gs_color_space *pcs;
+ gs_color_space *base_space = NULL;
+ int ncomps=0, code = 0;
+ gs_client_color cc;
+ bool is_pattern = false;
+
+ if (!is_fill) {
+ gs_swapcolors_quick(ctx->pgs);
+ }
+ pcs = gs_currentcolorspace(ctx->pgs);
+
+ if (pdfi_count_stack(ctx) < 1) {
+ code = gs_note_error(gs_error_stackunderflow);
+ goto cleanupExit;
+ }
+
+ if (pcs->type == &gs_color_space_type_Pattern)
+ is_pattern = true;
+ if (is_pattern) {
+ if (ctx->stack_top[-1]->type != PDF_NAME) {
+ pdfi_clearstack(ctx);
+ code = gs_note_error(gs_error_syntaxerror);
+ goto cleanupExit;
+ }
+ base_space = pcs->base_space;
+ code = pdfi_pattern_set(ctx, stream_dict, page_dict, (pdf_name *)ctx->stack_top[-1], &cc);
+ pdfi_pop(ctx, 1);
+ if (code < 0) {
+ /* Ignore the pattern if we failed to set it */
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BADPATTERN, "pdfi_setcolorN", (char *)"PATTERN: Error setting pattern");
+ code = 0;
+ goto cleanupExit;
+ }
+ if (base_space && pattern_instance_uses_base_space(cc.pattern))
+ ncomps = cs_num_components(base_space);
+ else
+ ncomps = 0;
+ } else {
+ ncomps = cs_num_components(pcs);
+ cc.pattern = NULL;
+ }
+
+ if (ncomps > 0)
+ code = pdfi_get_color_from_stack(ctx, &cc, ncomps);
+ if (code < 0)
+ goto cleanupExit;
+
+ if (pcs->type == &gs_color_space_type_Indexed) {
+ if (cc.paint.values[0] < 0)
+ cc.paint.values[0] = 0.0;
+ else
+ {
+ if (cc.paint.values[0] > pcs->params.indexed.hival)
+ cc.paint.values[0] = (float)pcs->params.indexed.hival;
+ else
+ {
+ if (cc.paint.values[0] != floor(cc.paint.values[0]))
+ {
+ if (cc.paint.values[0] - floor(cc.paint.values[0]) < 0.5)
+ cc.paint.values[0] = floor(cc.paint.values[0]);
+ else
+ cc.paint.values[0] = ceil(cc.paint.values[0]);
+ }
+ }
+ }
+ }
+
+ code = gs_setcolor(ctx->pgs, &cc);
+
+ if (is_pattern)
+ /* cc is a local scope variable, holding a reference to a pattern.
+ * We need to count the refrence down before the variable goes out of scope
+ * in order to prevent the pattern leaking.
+ */
+ rc_decrement(cc.pattern, "pdfi_setcolorN");
+
+cleanupExit:
+ if (!is_fill)
+ gs_swapcolors_quick(ctx->pgs);
+ return code;
+}
+
+/* And now, the routines to set the colour space on its own. */
+
+/* Starting with the ICCBased colour space */
+
+/* This routine is mostly a copy of seticc() in zicc.c */
+static int pdfi_create_icc(pdf_context *ctx, char *Name, stream *s, int ncomps, int *icc_N, float *range_buff, gs_color_space **ppcs)
+{
+ int code, k;
+ gs_color_space * pcs;
+ cmm_profile_t *picc_profile = NULL;
+ int i, expected = 0;
+
+ static const char *const icc_std_profile_names[] = {
+ GSICC_STANDARD_PROFILES
+ };
+ static const char *const icc_std_profile_keys[] = {
+ GSICC_STANDARD_PROFILES_KEYS
+ };
+
+ if (ppcs!= NULL)
+ *ppcs = NULL;
+
+ /* We need to use the graphics state memory, and beyond that we need to use stable memory, because the
+ * ICC cache can persist until the end of job, and so the profile (which is stored in teh cache)
+ * must likewise persist.
+ */
+ code = gs_cspace_build_ICC(&pcs, NULL, (gs_gstate_memory(ctx->pgs))->stable_memory);
+ if (code < 0)
+ return code;
+
+ if (Name != NULL){
+ /* Compare this to the standard profile names */
+ for (k = 0; k < GSICC_NUMBER_STANDARD_PROFILES; k++) {
+ if ( strcmp( Name, icc_std_profile_keys[k] ) == 0 ) {
+ picc_profile = gsicc_get_profile_handle_file(icc_std_profile_names[k],
+ strlen(icc_std_profile_names[k]), gs_gstate_memory(ctx->pgs));
+ break;
+ }
+ }
+ } else {
+ if (s == NULL)
+ return_error(gs_error_undefined);
+
+ picc_profile = gsicc_profile_new(s, gs_gstate_memory(ctx->pgs), NULL, 0);
+ if (picc_profile == NULL) {
+ rc_decrement(pcs,"pdfi_create_icc");
+ return gs_throw(gs_error_VMerror, "pdfi_create_icc Creation of ICC profile failed");
+ }
+ /* We have to get the profile handle due to the fact that we need to know
+ if it has a data space that is CIELAB */
+ picc_profile->profile_handle =
+ gsicc_get_profile_handle_buffer(picc_profile->buffer,
+ picc_profile->buffer_size,
+ gs_gstate_memory(ctx->pgs));
+ }
+
+ if (picc_profile == NULL || picc_profile->profile_handle == NULL) {
+ /* Free up everything, the profile is not valid. We will end up going
+ ahead and using a default based upon the number of components */
+ rc_decrement(picc_profile,"pdfi_create_icc");
+ rc_decrement(pcs,"pdfi_create_icc");
+ return -1;
+ }
+ code = gsicc_set_gscs_profile(pcs, picc_profile, gs_gstate_memory(ctx->pgs));
+ if (code < 0) {
+ rc_decrement(picc_profile,"pdfi_create_icc");
+ rc_decrement(pcs,"pdfi_create_icc");
+ return code;
+ }
+
+ picc_profile->data_cs =
+ gscms_get_profile_data_space(picc_profile->profile_handle,
+ picc_profile->memory);
+ switch (picc_profile->data_cs) {
+ case gsCIEXYZ:
+ case gsCIELAB:
+ case gsRGB:
+ expected = 3;
+ break;
+ case gsGRAY:
+ expected = 1;
+ break;
+ case gsCMYK:
+ expected = 4;
+ break;
+ case gsNCHANNEL:
+ case gsNAMED: /* Silence warnings */
+ case gsUNDEFINED: /* Silence warnings */
+ break;
+ }
+ /* Return the number of components the ICC profile has */
+ *icc_N = expected;
+ if (expected != ncomps)
+ ncomps = expected;
+
+#if 0
+ if (!expected || ncomps != expected) {
+ rc_decrement(picc_profile,"pdfi_create_icc");
+ rc_decrement(pcs,"pdfi_create_icc");
+ return_error(gs_error_rangecheck);
+ }
+#endif
+
+ picc_profile->num_comps = ncomps;
+ /* Lets go ahead and get the hash code and check if we match one of the default spaces */
+ /* Later we may want to delay this, but for now lets go ahead and do it */
+ gsicc_init_hash_cs(picc_profile, ctx->pgs);
+
+ /* Set the range according to the data type that is associated with the
+ ICC input color type. Occasionally, we will run into CIELAB to CIELAB
+ profiles for spot colors in PDF documents. These spot colors are typically described
+ as separation colors with tint transforms that go from a tint value
+ to a linear mapping between the CIELAB white point and the CIELAB tint
+ color. This results in a CIELAB value that we need to use to fill. We
+ need to detect this to make sure we do the proper scaling of the data. For
+ CIELAB images in PDF, the source is always normal 8 or 16 bit encoded data
+ in the range from 0 to 255 or 0 to 65535. In that case, there should not
+ be any encoding and decoding to CIELAB. The PDF content will not include
+ an ICC profile but will set the color space to \Lab. In this case, we use
+ our seticc_lab operation to install the LAB to LAB profile, but we detect
+ that we did that through the use of the is_lab flag in the profile descriptor.
+ When then avoid the CIELAB encode and decode */
+ if (picc_profile->data_cs == gsCIELAB) {
+ /* If the input space to this profile is CIELAB, then we need to adjust the limits */
+ /* See ICC spec ICC.1:2004-10 Section 6.3.4.2 and 6.4. I don't believe we need to
+ worry about CIEXYZ profiles or any of the other odds ones. Need to check that though
+ at some point. */
+ picc_profile->Range.ranges[0].rmin = 0.0;
+ picc_profile->Range.ranges[0].rmax = 100.0;
+ picc_profile->Range.ranges[1].rmin = -128.0;
+ picc_profile->Range.ranges[1].rmax = 127.0;
+ picc_profile->Range.ranges[2].rmin = -128.0;
+ picc_profile->Range.ranges[2].rmax = 127.0;
+ picc_profile->islab = true;
+ } else {
+ for (i = 0; i < ncomps; i++) {
+ picc_profile->Range.ranges[i].rmin = range_buff[2 * i];
+ picc_profile->Range.ranges[i].rmax = range_buff[2 * i + 1];
+ }
+ }
+ /* Now see if we are in an overide situation. We have to wait until now
+ in case this is an LAB profile which we will not overide */
+ if (gs_currentoverrideicc(ctx->pgs) && picc_profile->data_cs != gsCIELAB) {
+ /* Free up the profile structure */
+ switch( picc_profile->data_cs ) {
+ case gsRGB:
+ pcs->cmm_icc_profile_data = ctx->pgs->icc_manager->default_rgb;
+ break;
+ case gsGRAY:
+ pcs->cmm_icc_profile_data = ctx->pgs->icc_manager->default_gray;
+ break;
+ case gsCMYK:
+ pcs->cmm_icc_profile_data = ctx->pgs->icc_manager->default_cmyk;
+ break;
+ default:
+ break;
+ }
+ /* Have one increment from the color space. Having these tied
+ together is not really correct. Need to fix that. ToDo. MJV */
+ rc_adjust(picc_profile, -2, "pdfi_create_icc");
+ rc_increment(pcs->cmm_icc_profile_data);
+ }
+
+ if (ppcs!= NULL){
+ *ppcs = pcs;
+ pdfi_set_colour_callback(pcs, ctx, pdfi_cspace_free_callback);
+ } else {
+ code = pdfi_gs_setcolorspace(ctx, pcs);
+ rc_decrement_only_cs(pcs, "pdfi_seticc_cal");
+ }
+
+ /* The context has taken a reference to the colorspace. We no longer need
+ * ours, so drop it. */
+ rc_decrement(picc_profile, "pdfi_create_icc");
+ return code;
+}
+
+static int pdfi_create_iccprofile(pdf_context *ctx, pdf_stream *ICC_obj, char *cname,
+ int64_t Length, int N, int *icc_N, float *range, gs_color_space **ppcs)
+{
+ pdf_c_stream *profile_stream = NULL;
+ byte *profile_buffer;
+ gs_offset_t savedoffset;
+ int code, code1;
+
+ /* Save the current stream position, and move to the start of the profile stream */
+ savedoffset = pdfi_tell(ctx->main_stream);
+ pdfi_seek(ctx, ctx->main_stream, pdfi_stream_offset(ctx, ICC_obj), SEEK_SET);
+
+ /* The ICC profile reading code (irritatingly) requires a seekable stream, because it
+ * rewinds it to the start, then seeks to the end to find the size, then rewinds the
+ * stream again.
+ * Ideally we would use a ReusableStreamDecode filter here, but that is largely
+ * implemented in PostScript (!) so we can't use it. What we can do is create a
+ * string sourced stream in memory, which is at least seekable.
+ */
+ code = pdfi_open_memory_stream_from_filtered_stream(ctx, ICC_obj, Length, &profile_buffer, ctx->main_stream, &profile_stream, true);
+ if (code < 0) {
+ pdfi_seek(ctx, ctx->main_stream, savedoffset, SEEK_SET);
+ return code;
+ }
+
+ /* Now, finally, we can call the code to create and set the profile */
+ code = pdfi_create_icc(ctx, cname, profile_stream->s, (int)N, icc_N, range, ppcs);
+
+ code1 = pdfi_close_memory_stream(ctx, profile_buffer, profile_stream);
+
+ if (code == 0)
+ code = code1;
+
+ pdfi_seek(ctx, ctx->main_stream, savedoffset, SEEK_SET);
+
+ return code;
+}
+
+static int pdfi_create_iccbased(pdf_context *ctx, pdf_array *color_array, int index, pdf_dict *stream_dict, pdf_dict *page_dict, gs_color_space **ppcs, bool inline_image)
+{
+ pdf_stream *ICC_obj = NULL;
+ pdf_dict *dict; /* Alias to avoid tons of casting */
+ pdf_array *a;
+ int64_t Length, N;
+ pdf_obj *Name = NULL;
+ char *cname = NULL;
+ int code;
+ bool known = true;
+ float range[8];
+ int icc_N;
+ gs_color_space *pcs = NULL;
+
+ code = pdfi_array_get_type(ctx, color_array, index + 1, PDF_STREAM, (pdf_obj **)&ICC_obj);
+ if (code < 0)
+ return code;
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)ICC_obj, &dict);
+ if (code < 0)
+ return code;
+
+ Length = pdfi_stream_length(ctx, ICC_obj);
+ code = pdfi_dict_get_int(ctx, dict, "N", &N);
+ if (code < 0)
+ goto done;
+ code = pdfi_dict_knownget(ctx, dict, "Name", &Name);
+ if (code > 0) {
+ if(Name->type == PDF_STRING || Name->type == PDF_NAME) {
+ cname = (char *)gs_alloc_bytes(ctx->memory, ((pdf_name *)Name)->length + 1, "pdfi_create_iccbased (profile name)");
+ if (cname == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto done;
+ }
+ memset(cname, 0x00, ((pdf_name *)Name)->length + 1);
+ memcpy(cname, ((pdf_name *)Name)->data, ((pdf_name *)Name)->length);
+ }
+ }
+ if (code < 0)
+ goto done;
+
+ code = pdfi_dict_knownget_type(ctx, dict, "Range", PDF_ARRAY, (pdf_obj **)&a);
+ if (code < 0)
+ goto done;
+ if (code > 0) {
+ double dbl;
+ int i;
+
+ if (pdfi_array_size(a) >= N * 2) {
+ for (i = 0; i < pdfi_array_size(a);i++) {
+ code = pdfi_array_get_number(ctx, a, i, &dbl);
+ if (code < 0) {
+ known = false;
+ break;
+ }
+ range[i] = (float)dbl;
+ }
+ } else {
+ known = false;
+ }
+ pdfi_countdown(a);
+ } else
+ known = false;
+
+ /* We don't just use the final else clause above for setting the defaults
+ * because we also want to use these if there's a problem with the
+ * supplied data. In this case we also want to overwrite any partial
+ * data we might have read
+ */
+ if (!known) {
+ int i;
+ for (i = 0;i < N; i++) {
+ range[i * 2] = 0;
+ range[(i * 2) + 1] = 1;
+ }
+ }
+
+ code = pdfi_create_iccprofile(ctx, ICC_obj, cname, Length, N, &icc_N, range, &pcs);
+
+ /* This is just plain hackery for the benefit of Bug696690.pdf. The old PostScript PDF interpreter says:
+ * %% This section is to deal with the horrible pair of files in Bug #696690 and Bug #696120
+ * %% These files have ICCBased spaces where the value of /N and the number of components
+ * %% in the profile differ. In addition the profile in Bug #696690 is invalid. In the
+ * %% case of Bug #696690 the /N value is correct, and the profile is wrong, in the case
+ * %% of Bug #696120 the /N value is incorrect and the profile is correct.
+ * %% We 'suspect' that Acrobat uses the fact that Bug #696120 is a pure image to detect
+ * %% that the /N is incorrect, we can't be sure whether it uses the profile or just uses
+ * %% the /N to decide on a device space.
+ * We can't precisely duplicate the PostScript approach, but we now set the actual ICC profile
+ * and therefore use the number of components in the profile. However, we pass back the number
+ * of components in icc_N. We then check to see if N and icc_N are the same, if they are not we
+ * try to set a devcie colour using the profile. If that fails (bad profile) then we enter the fallback
+ * just as if we had failed to set the profile.
+ */
+ if (code >= 0 && N != icc_N) {
+ gs_client_color cc;
+ int i;
+
+ gs_gsave(ctx->pgs);
+ code = gs_setcolorspace(ctx->pgs, pcs);
+ if (code == 0) {
+ cc.pattern = 0;
+ for (i = 0;i < icc_N; i++)
+ cc.paint.values[i] = 0;
+ code = gs_setcolor(ctx->pgs, &cc);
+ if (code == 0)
+ code = gx_set_dev_color(ctx->pgs);
+ }
+ gs_grestore(ctx->pgs);
+ }
+
+ if (code < 0) {
+ pdf_obj *Alternate = NULL;
+
+ if (pcs != NULL)
+ rc_decrement(pcs,"pdfi_create_iccbased");
+
+ /* Failed to set the ICCBased space, attempt to use the Alternate */
+ code = pdfi_dict_knownget(ctx, dict, "Alternate", &Alternate);
+ if (code > 0) {
+ /* The Alternate should be one of the device spaces, therefore a Name object. If its not, fallback to using /N */
+ if (Alternate->type == PDF_NAME)
+ code = pdfi_create_colorspace_by_name(ctx, (pdf_name *)Alternate, stream_dict,
+ page_dict, ppcs, inline_image);
+ pdfi_countdown(Alternate);
+ if (code == 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BADICC_USE_ALT, "pdfi_create_iccbased", NULL);
+ goto done;
+ }
+ }
+ /* Use the number of components *from the profile* to set a space.... */
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BADICC_USECOMPS, "pdfi_create_iccbased", NULL);
+ switch(N) {
+ case 1:
+ pcs = gs_cspace_new_DeviceGray(ctx->memory);
+ if (pcs == NULL)
+ code = gs_note_error(gs_error_VMerror);
+ break;
+ case 3:
+ pcs = gs_cspace_new_DeviceRGB(ctx->memory);
+ if (pcs == NULL)
+ code = gs_note_error(gs_error_VMerror);
+ break;
+ case 4:
+ pcs = gs_cspace_new_DeviceCMYK(ctx->memory);
+ if (pcs == NULL)
+ code = gs_note_error(gs_error_VMerror);
+ break;
+ default:
+ code = gs_note_error(gs_error_undefined);
+ break;
+ }
+ }
+ if (ppcs!= NULL)
+ *ppcs = pcs;
+ else {
+ if (pcs != NULL) {
+ code = pdfi_gs_setcolorspace(ctx, pcs);
+ /* release reference from construction */
+ rc_decrement_only_cs(pcs, "setseparationspace");
+ }
+ }
+
+
+done:
+ if (cname)
+ gs_free_object(ctx->memory, cname, "pdfi_create_iccbased (profile name)");
+ pdfi_countdown(Name);
+ pdfi_countdown(ICC_obj);
+ return code;
+}
+
+/*
+ * This, and pdfi_set_cal() below are copied from the similarly named routines
+ * in zicc.c
+ */
+/* Install a ICC type color space and use the ICC LABLUT profile. */
+static int
+pdfi_seticc_lab(pdf_context *ctx, float *range_buff, gs_color_space **ppcs)
+{
+ int code;
+ gs_color_space * pcs;
+ int i;
+
+ /* build the color space object */
+ /* We need to use the graphics state memory, and beyond that we need to use stable memory, because the
+ * ICC cache can persist until the end of job, and so the profile (which is stored in teh cache)
+ * must likewise persist.
+ */
+ code = gs_cspace_build_ICC(&pcs, NULL, (gs_gstate_memory(ctx->pgs))->stable_memory);
+ if (code < 0)
+ return code;
+
+ /* record the current space as the alternative color space */
+ /* Get the lab profile. It may already be set in the icc manager.
+ If not then lets populate it. */
+ if (ctx->pgs->icc_manager->lab_profile == NULL ) {
+ /* This can't happen as the profile
+ should be initialized during the
+ setting of the user params */
+ return_error(gs_error_unknownerror);
+ }
+ /* Assign the LAB to LAB profile to this color space */
+ code = gsicc_set_gscs_profile(pcs, ctx->pgs->icc_manager->lab_profile, gs_gstate_memory(ctx->pgs));
+ if (code < 0)
+ return code;
+
+ pcs->cmm_icc_profile_data->Range.ranges[0].rmin = 0.0;
+ pcs->cmm_icc_profile_data->Range.ranges[0].rmax = 100.0;
+ for (i = 1; i < 3; i++) {
+ pcs->cmm_icc_profile_data->Range.ranges[i].rmin =
+ range_buff[2 * (i-1)];
+ pcs->cmm_icc_profile_data->Range.ranges[i].rmax =
+ range_buff[2 * (i-1) + 1];
+ }
+ if (ppcs!= NULL){
+ *ppcs = pcs;
+ pdfi_set_colour_callback(pcs, ctx, pdfi_cspace_free_callback);
+ } else {
+ code = pdfi_gs_setcolorspace(ctx, pcs);
+ rc_decrement_only_cs(pcs, "pdfi_seticc_lab");
+ }
+
+ return code;
+}
+
+static int pdfi_create_Lab(pdf_context *ctx, pdf_array *color_array, int index, pdf_dict *stream_dict, pdf_dict *page_dict, gs_color_space **ppcs)
+{
+ int code = 0, i;
+ pdf_dict *Lab_dict = NULL;
+ pdf_array *Range = NULL;
+ float RangeBuf[4];
+ double f;
+
+ code = pdfi_array_get_type(ctx, color_array, index + 1, PDF_DICT, (pdf_obj **)&Lab_dict);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_get_type(ctx, Lab_dict, "Range", PDF_ARRAY, (pdf_obj **)&Range);
+ if (code < 0) {
+ goto exit;
+ }
+ if (pdfi_array_size(Range) != 4){
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+
+ for (i=0; i < 4; i++) {
+ code = pdfi_array_get_number(ctx, Range, (uint64_t)i, &f);
+ if (code < 0)
+ goto exit;
+ RangeBuf[i] = (float)f;
+ }
+
+ code = pdfi_seticc_lab(ctx, RangeBuf, ppcs);
+
+exit:
+ pdfi_countdown(Lab_dict);
+ pdfi_countdown(Range);
+ return code;
+}
+
+/* Install an ICC space from the PDF CalRGB or CalGray types */
+static int
+pdfi_seticc_cal(pdf_context *ctx, float *white, float *black, float *gamma,
+ float *matrix, int num_colorants, ulong dictkey, gs_color_space **ppcs)
+{
+ int code = 0;
+ gs_color_space * pcs;
+ int i;
+ cmm_profile_t *cal_profile;
+
+ /* See if the color space is in the profile cache */
+ pcs = gsicc_find_cs(dictkey, ctx->pgs);
+ if (pcs == NULL ) {
+ /* build the color space object. Since this is cached
+ in the profile cache which is a member variable
+ of the graphic state, we will want to use stable
+ memory here */
+ code = gs_cspace_build_ICC(&pcs, NULL, ctx->pgs->memory->stable_memory);
+ if (code < 0)
+ return code;
+ /* There is no alternate for this. Perhaps we should set DeviceRGB? */
+ pcs->base_space = NULL;
+ /* Create the ICC profile from the CalRGB or CalGray parameters */
+ /* We need to use the graphics state memory, in case we are running under Ghostscript. */
+ cal_profile = gsicc_create_from_cal(white, black, gamma, matrix,
+ ctx->pgs->memory->stable_memory, num_colorants);
+ if (cal_profile == NULL) {
+ rc_decrement(pcs, "seticc_cal");
+ return_error(gs_error_VMerror);
+ }
+ /* Assign the profile to this color space */
+ /* Apparently the memory pointer passed here here is not actually used, but we will supply
+ * the graphics state memory allocator, because that's what the colour space should be using.
+ */
+ code = gsicc_set_gscs_profile(pcs, cal_profile, ctx->pgs->memory);
+ /* profile is created with ref count of 1, gsicc_set_gscs_profile()
+ * increments the ref count, so we need to decrement it here.
+ */
+ rc_decrement(cal_profile, "seticc_cal");
+ if (code < 0) {
+ rc_decrement(pcs, "seticc_cal");
+ return code;
+ }
+ for (i = 0; i < num_colorants; i++) {
+ pcs->cmm_icc_profile_data->Range.ranges[i].rmin = 0;
+ pcs->cmm_icc_profile_data->Range.ranges[i].rmax = 1;
+ }
+ /* Add the color space to the profile cache */
+ gsicc_add_cs(ctx->pgs, pcs, dictkey);
+ } else {
+ /* We're passing back a new reference, increment the count */
+ rc_adjust_only(pcs, 1, "pdfi_seticc_cal, return cached ICC profile");
+ }
+
+ if (ppcs!= NULL){
+ *ppcs = pcs;
+ } else {
+ code = pdfi_gs_setcolorspace(ctx, pcs);
+ rc_decrement_only_cs(pcs, "pdfi_seticc_cal");
+ }
+
+ return code;
+}
+
+static int pdfi_create_CalGray(pdf_context *ctx, pdf_array *color_array, int index, pdf_dict *stream_dict, pdf_dict *page_dict, gs_color_space **ppcs)
+{
+ int code = 0, i;
+ pdf_dict *CalGray_dict = NULL;
+ pdf_array *PDFArray = NULL;
+ /* The default values here are as per the PDF 1.7 specification, there is
+ * no default for the WhitePoint as it is a required entry. The Matrix is
+ * not specified for CalGray, but we need it for the general 'pdfi_set_icc'
+ * routine, so we use the same default as CalRGB.
+ */
+ float WhitePoint[3], BlackPoint[3] = {0.0f, 0.0f, 0.0f}, Gamma = 1.0f;
+ float Matrix[9] = {1.0f, 0.0f, 0.0f, 0.0f, 1.0f, 0.0f, 0.0f, 0.0f, 1.0f};
+ double f;
+
+ code = pdfi_array_get_type(ctx, color_array, index + 1, PDF_DICT, (pdf_obj **)&CalGray_dict);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_get_type(ctx, CalGray_dict, "WhitePoint", PDF_ARRAY, (pdf_obj **)&PDFArray);
+ if (code < 0) {
+ pdfi_countdown(PDFArray);
+ goto exit;
+ }
+ if (pdfi_array_size(PDFArray) != 3){
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+
+ for (i=0; i < 3; i++) {
+ code = pdfi_array_get_number(ctx, PDFArray, (uint64_t)i, &f);
+ if (code < 0)
+ goto exit;
+ WhitePoint[i] = (float)f;
+ }
+ pdfi_countdown(PDFArray);
+ PDFArray = NULL;
+
+ /* Check the WhitePoint values, the PDF 1.7 reference states that
+ * Xw ad Zw must be positive and Yw must be 1.0
+ */
+ if (WhitePoint[0] < 0 || WhitePoint[2] < 0 || WhitePoint[1] != 1.0f) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+
+ if (pdfi_dict_knownget_type(ctx, CalGray_dict, "BlackPoint", PDF_ARRAY, (pdf_obj **)&PDFArray)) {
+ if (pdfi_array_size(PDFArray) != 3){
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ for (i=0; i < 3; i++) {
+ code = pdfi_array_get_number(ctx, PDFArray, (uint64_t)i, &f);
+ if (code < 0)
+ goto exit;
+ /* The PDF 1.7 reference states that all three components of the BlackPoint
+ * (if present) must be positive.
+ */
+ if (f < 0) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ BlackPoint[i] = (float)f;
+ }
+ pdfi_countdown(PDFArray);
+ PDFArray = NULL;
+ }
+
+ if (pdfi_dict_knownget_number(ctx, CalGray_dict, "Gamma", &f))
+ Gamma = (float)f;
+ /* The PDF 1.7 reference states that Gamma
+ * (if present) must be positive.
+ */
+ if (Gamma < 0) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+
+ code = pdfi_seticc_cal(ctx, WhitePoint, BlackPoint, &Gamma, Matrix, 1, color_array->object_num, ppcs);
+
+exit:
+ pdfi_countdown(PDFArray);
+ pdfi_countdown(CalGray_dict);
+ return code;
+}
+
+static int pdfi_create_CalRGB(pdf_context *ctx, pdf_array *color_array, int index, pdf_dict *stream_dict, pdf_dict *page_dict, gs_color_space **ppcs)
+{
+ int code = 0, i;
+ pdf_dict *CalRGB_dict = NULL;
+ pdf_array *PDFArray = NULL;
+ /* The default values here are as per the PDF 1.7 specification, there is
+ * no default for the WhitePoint as it is a required entry
+ */
+ float WhitePoint[3], BlackPoint[3] = {0.0f, 0.0f, 0.0f}, Gamma[3] = {1.0f, 1.0f, 1.0f};
+ float Matrix[9] = {1.0f, 0.0f, 0.0f, 0.0f, 1.0f, 0.0f, 0.0f, 0.0f, 1.0f};
+ double f;
+
+ code = pdfi_array_get_type(ctx, color_array, index + 1, PDF_DICT, (pdf_obj **)&CalRGB_dict);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_get_type(ctx, CalRGB_dict, "WhitePoint", PDF_ARRAY, (pdf_obj **)&PDFArray);
+ if (code < 0) {
+ pdfi_countdown(PDFArray);
+ goto exit;
+ }
+ if (pdfi_array_size(PDFArray) != 3){
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+
+ for (i=0; i < 3; i++) {
+ code = pdfi_array_get_number(ctx, PDFArray, (uint64_t)i, &f);
+ if (code < 0)
+ goto exit;
+ WhitePoint[i] = (float)f;
+ }
+ pdfi_countdown(PDFArray);
+ PDFArray = NULL;
+
+ /* Check the WhitePoint values, the PDF 1.7 reference states that
+ * Xw ad Zw must be positive and Yw must be 1.0
+ */
+ if (WhitePoint[0] < 0 || WhitePoint[2] < 0 || WhitePoint[1] != 1.0f) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+
+ if (pdfi_dict_knownget_type(ctx, CalRGB_dict, "BlackPoint", PDF_ARRAY, (pdf_obj **)&PDFArray)) {
+ if (pdfi_array_size(PDFArray) != 3){
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ for (i=0; i < 3; i++) {
+ code = pdfi_array_get_number(ctx, PDFArray, (uint64_t)i, &f);
+ if (code < 0)
+ goto exit;
+ /* The PDF 1.7 reference states that all three components of the BlackPoint
+ * (if present) must be positive.
+ */
+ if (f < 0) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ BlackPoint[i] = (float)f;
+ }
+ pdfi_countdown(PDFArray);
+ PDFArray = NULL;
+ }
+
+ if (pdfi_dict_knownget_type(ctx, CalRGB_dict, "Gamma", PDF_ARRAY, (pdf_obj **)&PDFArray)) {
+ if (pdfi_array_size(PDFArray) != 3){
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ for (i=0; i < 3; i++) {
+ code = pdfi_array_get_number(ctx, PDFArray, (uint64_t)i, &f);
+ if (code < 0)
+ goto exit;
+ Gamma[i] = (float)f;
+ }
+ pdfi_countdown(PDFArray);
+ PDFArray = NULL;
+ }
+
+ if (pdfi_dict_knownget_type(ctx, CalRGB_dict, "Matrix", PDF_ARRAY, (pdf_obj **)&PDFArray)) {
+ if (pdfi_array_size(PDFArray) != 9){
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ for (i=0; i < 9; i++) {
+ code = pdfi_array_get_number(ctx, PDFArray, (uint64_t)i, &f);
+ if (code < 0)
+ goto exit;
+ Matrix[i] = (float)f;
+ }
+ pdfi_countdown(PDFArray);
+ PDFArray = NULL;
+ }
+ code = pdfi_seticc_cal(ctx, WhitePoint, BlackPoint, Gamma, Matrix, 3, color_array->object_num, ppcs);
+
+exit:
+ pdfi_countdown(PDFArray);
+ pdfi_countdown(CalRGB_dict);
+ return code;
+}
+
+static int pdfi_create_Separation(pdf_context *ctx, pdf_array *color_array, int index, pdf_dict *stream_dict, pdf_dict *page_dict, gs_color_space **ppcs, bool inline_image)
+{
+ pdf_obj *o = NULL;
+ pdf_name *name = NULL, *NamedAlternate = NULL;
+ pdf_array *ArrayAlternate = NULL;
+ pdf_obj *transform = NULL;
+ int code;
+ gs_color_space *pcs = NULL, *pcs_alt = NULL;
+ gs_function_t * pfn = NULL;
+ separation_type sep_type;
+
+ code = pdfi_array_get_type(ctx, color_array, index + 1, PDF_NAME, (pdf_obj **)&name);
+ if (code < 0)
+ goto pdfi_separation_error;
+
+ sep_type = SEP_OTHER;
+ if (name->length == 4 && memcmp(name->data, "None", 4) == 0)
+ sep_type = SEP_NONE;
+ if (name->length == 3 && memcmp(name->data, "All", 3) == 0)
+ sep_type = SEP_ALL;
+
+ code = pdfi_array_get(ctx, color_array, index + 2, &o);
+ if (code < 0)
+ goto pdfi_separation_error;
+
+ if (o->type == PDF_NAME) {
+ NamedAlternate = (pdf_name *)o;
+ code = pdfi_create_colorspace_by_name(ctx, NamedAlternate, stream_dict, page_dict, &pcs_alt, inline_image);
+ if (code < 0)
+ goto pdfi_separation_error;
+
+ } else {
+ if (o->type == PDF_ARRAY) {
+ ArrayAlternate = (pdf_array *)o;
+ code = pdfi_create_colorspace_by_array(ctx, ArrayAlternate, 0, stream_dict, page_dict, &pcs_alt, inline_image);
+ if (code < 0)
+ goto pdfi_separation_error;
+ }
+ else {
+ code = gs_error_typecheck;
+ goto pdfi_separation_error;
+ }
+ }
+
+ code = pdfi_array_get(ctx, color_array, index + 3, &transform);
+ if (code < 0)
+ goto pdfi_separation_error;
+
+ code = pdfi_build_function(ctx, &pfn, NULL, 1, transform, page_dict);
+ if (code < 0)
+ goto pdfi_separation_error;
+
+ code = gs_cspace_new_Separation(&pcs, pcs_alt, ctx->memory);
+ if (code < 0)
+ goto pdfi_separation_error;
+
+ rc_decrement(pcs_alt, "pdfi_create_Separation");
+ pcs->params.separation.mem = ctx->memory;
+ pcs->params.separation.sep_type = sep_type;
+ pcs->params.separation.sep_name = (char *)gs_alloc_bytes(ctx->memory->non_gc_memory, name->length + 1, "pdfi_setseparationspace(ink)");
+ memcpy(pcs->params.separation.sep_name, name->data, name->length);
+ pcs->params.separation.sep_name[name->length] = 0x00;
+
+ code = gs_cspace_set_sepr_function(pcs, pfn);
+ if (code < 0)
+ goto pdfi_separation_error;
+
+ if (ppcs!= NULL){
+ /* FIXME
+ * I can see no justification for this whatever, but if I don't do this then some
+ * files with images in a /Separation colour space come out incorrectly. Even surrounding
+ * this with a gsave/grestore pair causes differences.
+ */
+ code = pdfi_gs_setcolorspace(ctx, pcs);
+ *ppcs = pcs;
+ } else {
+ code = pdfi_gs_setcolorspace(ctx, pcs);
+ /* release reference from construction */
+ rc_decrement_only_cs(pcs, "setseparationspace");
+ }
+
+ pdfi_countdown(name);
+ pdfi_countdown(NamedAlternate);
+ pdfi_countdown(ArrayAlternate);
+ pdfi_countdown(transform);
+ return_error(0);
+
+pdfi_separation_error:
+ pdfi_free_function(ctx, pfn);
+ if (pcs_alt != NULL)
+ rc_decrement_only_cs(pcs_alt, "setseparationspace");
+ if(pcs != NULL)
+ rc_decrement_only_cs(pcs, "setseparationspace");
+ pdfi_countdown(name);
+ pdfi_countdown(NamedAlternate);
+ pdfi_countdown(ArrayAlternate);
+ pdfi_countdown(transform);
+ return code;
+}
+
+static int pdfi_create_DeviceN(pdf_context *ctx, pdf_array *color_array, int index, pdf_dict *stream_dict, pdf_dict *page_dict, gs_color_space **ppcs, bool inline_image)
+{
+ pdf_obj *o = NULL;
+ pdf_name *NamedAlternate = NULL;
+ pdf_array *ArrayAlternate = NULL, *inks = NULL;
+ pdf_obj *transform = NULL;
+ pdf_dict *attributes = NULL;
+ pdf_dict *Colorants = NULL, *Process = NULL;
+ gs_color_space *process_space = NULL;
+ int code;
+ uint64_t ix;
+ gs_color_space *pcs = NULL, *pcs_alt = NULL;
+ gs_function_t * pfn = NULL;
+
+ /* Start with the array of inks */
+ code = pdfi_array_get_type(ctx, color_array, index + 1, PDF_ARRAY, (pdf_obj **)&inks);
+ if (code < 0)
+ goto pdfi_devicen_error;
+
+ for (ix = 0;ix < pdfi_array_size(inks);ix++) {
+ pdf_name *ink_name = NULL;
+
+ code = pdfi_array_get_type(ctx, inks, ix, PDF_NAME, (pdf_obj **)&ink_name);
+ if (code < 0)
+ return code;
+
+ if (ink_name->length == 3 && memcmp(ink_name->data, "All", 3) == 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_DEVICEN_USES_ALL, "pdfi_create_DeviceN", (char *)"WARNING: DeviceN space using /All ink name");
+ }
+ pdfi_countdown(ink_name);
+ ink_name = NULL;
+ }
+
+ /* Sigh, Acrobat allows this, even though its contra the spec. Convert to
+ * a /Separation space, and then return. Actually Acrobat does not always permit this, see
+ * tests_private/comparefiles/Testform.v1.0.2.pdf.
+ */
+ if (pdfi_array_size(inks) == 1) {
+ pdf_name *ink_name = NULL;
+ pdf_array *sep_color_array = NULL;
+ pdf_obj *obj = NULL;
+
+ code = pdfi_array_get_type(ctx, inks, 0, PDF_NAME, (pdf_obj **)&ink_name);
+ if (code < 0)
+ goto pdfi_devicen_error;
+
+ if (ink_name->length == 3 && memcmp(ink_name->data, "All", 3) == 0) {
+ code = pdfi_array_alloc(ctx, 4, &sep_color_array);
+ if (code < 0)
+ goto all_error;
+ pdfi_countup(sep_color_array);
+ code = pdfi_name_alloc(ctx, (byte *)"Separation", 10, &obj);
+ if (code < 0)
+ goto all_error;
+ pdfi_countup(obj);
+ code = pdfi_array_put(ctx, sep_color_array, 0, obj);
+ if (code < 0)
+ goto all_error;
+ pdfi_countdown(obj);
+ obj = NULL;
+ code = pdfi_array_put(ctx, sep_color_array, 1, (pdf_obj *)ink_name);
+ if (code < 0)
+ goto all_error;
+ code = pdfi_array_get(ctx, color_array, index + 2, &obj);
+ if (code < 0)
+ goto all_error;
+ code = pdfi_array_put(ctx, sep_color_array, 2, obj);
+ if (code < 0)
+ goto all_error;
+ pdfi_countdown(obj);
+ obj = NULL;
+ code = pdfi_array_get(ctx, color_array, index + 3, &obj);
+ if (code < 0)
+ goto all_error;
+ code = pdfi_array_put(ctx, sep_color_array, 3, obj);
+ if (code < 0)
+ goto all_error;
+ pdfi_countdown(obj);
+ obj = NULL;
+
+ code = pdfi_create_Separation(ctx, sep_color_array, 0, stream_dict, page_dict, ppcs, inline_image);
+ if (code < 0)
+ goto all_error;
+all_error:
+ pdfi_countdown(ink_name);
+ pdfi_countdown(sep_color_array);
+ pdfi_countdown(obj);
+ pdfi_countdown(inks);
+ return code;
+ } else
+ pdfi_countdown(ink_name);
+ }
+
+ /* Deal with alternate space */
+ code = pdfi_array_get(ctx, color_array, index + 2, &o);
+ if (code < 0)
+ goto pdfi_devicen_error;
+
+ if (o->type == PDF_NAME) {
+ NamedAlternate = (pdf_name *)o;
+ code = pdfi_create_colorspace_by_name(ctx, NamedAlternate, stream_dict, page_dict, &pcs_alt, inline_image);
+ if (code < 0)
+ goto pdfi_devicen_error;
+
+ } else {
+ if (o->type == PDF_ARRAY) {
+ ArrayAlternate = (pdf_array *)o;
+ code = pdfi_create_colorspace_by_array(ctx, ArrayAlternate, 0, stream_dict, page_dict, &pcs_alt, inline_image);
+ if (code < 0) {
+ pdfi_countdown(o);
+ goto pdfi_devicen_error;
+ }
+ }
+ else {
+ code = gs_error_typecheck;
+ pdfi_countdown(o);
+ goto pdfi_devicen_error;
+ }
+ }
+
+ /* Now the tint transform */
+ code = pdfi_array_get(ctx, color_array, index + 3, &transform);
+ if (code < 0)
+ goto pdfi_devicen_error;
+
+ code = pdfi_build_function(ctx, &pfn, NULL, 1, transform, page_dict);
+ if (code < 0)
+ goto pdfi_devicen_error;
+
+ code = gs_cspace_new_DeviceN(&pcs, pdfi_array_size(inks), pcs_alt, ctx->memory);
+ if (code < 0)
+ return code;
+
+ rc_decrement(pcs_alt, "pdfi_create_DeviceN");
+ pcs_alt = NULL;
+ pcs->params.device_n.mem = ctx->memory;
+
+ for (ix = 0;ix < pdfi_array_size(inks);ix++) {
+ pdf_name *ink_name;
+
+ ink_name = NULL;
+ code = pdfi_array_get_type(ctx, inks, ix, PDF_NAME, (pdf_obj **)&ink_name);
+ if (code < 0)
+ goto pdfi_devicen_error;
+
+ pcs->params.device_n.names[ix] = (char *)gs_alloc_bytes(ctx->memory->non_gc_memory, ink_name->length + 1, "pdfi_setdevicenspace(ink)");
+ memcpy(pcs->params.device_n.names[ix], ink_name->data, ink_name->length);
+ pcs->params.device_n.names[ix][ink_name->length] = 0x00;
+ pdfi_countdown(ink_name);
+ }
+
+ code = gs_cspace_set_devn_function(pcs, pfn);
+ if (code < 0)
+ goto pdfi_devicen_error;
+
+ if (pdfi_array_size(color_array) >= index + 5) {
+ pdf_obj *ColorSpace = NULL;
+ pdf_array *Components = NULL;
+ pdf_obj *subtype = NULL;
+
+ code = pdfi_array_get_type(ctx, color_array, index + 4, PDF_DICT, (pdf_obj **)&attributes);
+ if (code < 0)
+ goto pdfi_devicen_error;
+
+ code = pdfi_dict_knownget(ctx, attributes, "Subtype", (pdf_obj **)&subtype);
+ if (code < 0)
+ goto pdfi_devicen_error;
+
+ if (code == 0) {
+ pcs->params.device_n.subtype = gs_devicen_DeviceN;
+ } else {
+ if (subtype->type == PDF_NAME || subtype->type == PDF_STRING) {
+ if (memcmp(((pdf_name *)subtype)->data, "DeviceN", 7) == 0) {
+ pcs->params.device_n.subtype = gs_devicen_DeviceN;
+ } else {
+ if (memcmp(((pdf_name *)subtype)->data, "NChannel", 8) == 0) {
+ pcs->params.device_n.subtype = gs_devicen_NChannel;
+ } else {
+ pdfi_countdown(subtype);
+ goto pdfi_devicen_error;
+ }
+ }
+ pdfi_countdown(subtype);
+ } else {
+ pdfi_countdown(subtype);
+ goto pdfi_devicen_error;
+ }
+ }
+
+ code = pdfi_dict_knownget_type(ctx, attributes, "Process", PDF_DICT, (pdf_obj **)&Process);
+ if (code < 0)
+ goto pdfi_devicen_error;
+
+ if (Process != NULL && pdfi_dict_entries(Process) != 0) {
+ int ix = 0;
+ pdf_obj *name;
+
+ code = pdfi_dict_get(ctx, Process, "ColorSpace", (pdf_obj **)&ColorSpace);
+ if (code < 0)
+ goto pdfi_devicen_error;
+
+ code = pdfi_create_colorspace(ctx, ColorSpace, stream_dict, page_dict, &process_space, inline_image);
+ pdfi_countdown(ColorSpace);
+ if (code < 0)
+ goto pdfi_devicen_error;
+
+ pcs->params.device_n.devn_process_space = process_space;
+
+ code = pdfi_dict_get_type(ctx, Process, "Components", PDF_ARRAY, (pdf_obj **)&Components);
+ if (code < 0)
+ goto pdfi_devicen_error;
+
+ pcs->params.device_n.num_process_names = pdfi_array_size(Components);
+ pcs->params.device_n.process_names = (char **)gs_alloc_bytes(pcs->params.device_n.mem->non_gc_memory, pdfi_array_size(Components) * sizeof(char *), "pdfi_devicen(Processnames)");
+ if (pcs->params.device_n.process_names == NULL) {
+ code = gs_error_VMerror;
+ goto pdfi_devicen_error;
+ }
+
+ for (ix = 0; ix < pcs->params.device_n.num_process_names; ix++) {
+ code = pdfi_array_get(ctx, Components, ix, &name);
+ if (code < 0) {
+ pdfi_countdown(Components);
+ goto pdfi_devicen_error;
+ }
+
+ if (name->type == PDF_NAME || name->type == PDF_STRING) {
+ pcs->params.device_n.process_names[ix] = (char *)gs_alloc_bytes(pcs->params.device_n.mem->non_gc_memory, ((pdf_name *)name)->length + 1, "pdfi_devicen(Processnames)");
+ if (pcs->params.device_n.process_names[ix] == NULL) {
+ pdfi_countdown(Components);
+ pdfi_countdown(name);
+ code = gs_error_VMerror;
+ goto pdfi_devicen_error;
+ }
+ memcpy(pcs->params.device_n.process_names[ix], ((pdf_name *)name)->data, ((pdf_name *)name)->length);
+ pcs->params.device_n.process_names[ix][((pdf_name *)name)->length] = 0x00;
+ pdfi_countdown(name);
+ } else {
+ pdfi_countdown(Components);
+ pdfi_countdown(name);
+ goto pdfi_devicen_error;
+ }
+ }
+ pdfi_countdown(Components);
+ }
+
+ code = pdfi_dict_knownget_type(ctx, attributes, "Colorants", PDF_DICT, (pdf_obj **)&Colorants);
+ if (code < 0)
+ goto pdfi_devicen_error;
+
+ if (Colorants != NULL && pdfi_dict_entries(Colorants) != 0) {
+ uint64_t ix = 0;
+ pdf_obj *Colorant = NULL, *Space = NULL;
+ char *colorant_name;
+ gs_color_space *colorant_space = NULL;
+
+ code = pdfi_dict_first(ctx, Colorants, &Colorant, &Space, &ix);
+ if (code < 0)
+ goto pdfi_devicen_error;
+
+ do {
+ if (Space->type != PDF_STRING && Space->type != PDF_NAME && Space->type != PDF_ARRAY) {
+ pdfi_countdown(Space);
+ pdfi_countdown(Colorant);
+ code = gs_note_error(gs_error_typecheck);
+ goto pdfi_devicen_error;
+ }
+ if (Colorant->type != PDF_STRING && Colorant->type != PDF_NAME) {
+ pdfi_countdown(Space);
+ pdfi_countdown(Colorant);
+ code = gs_note_error(gs_error_typecheck);
+ goto pdfi_devicen_error;
+ }
+
+ code = pdfi_create_colorspace(ctx, Space, stream_dict, page_dict, &colorant_space, inline_image);
+ if (code < 0) {
+ pdfi_countdown(Space);
+ pdfi_countdown(Colorant);
+ goto pdfi_devicen_error;
+ }
+
+ colorant_name = (char *)gs_alloc_bytes(pcs->params.device_n.mem->non_gc_memory, ((pdf_name *)Colorant)->length + 1, "pdfi_devicen(colorant)");
+ if (colorant_name == NULL) {
+ rc_decrement_cs(colorant_space, "pdfi_devicen(colorant)");
+ pdfi_countdown(Space);
+ pdfi_countdown(Colorant);
+ code = gs_note_error(gs_error_VMerror);
+ goto pdfi_devicen_error;
+ }
+ memcpy(colorant_name, ((pdf_name *)Colorant)->data, ((pdf_name *)Colorant)->length);
+ colorant_name[((pdf_name *)Colorant)->length] = 0x00;
+
+ code = gs_attach_colorant_to_space(colorant_name, pcs, colorant_space, pcs->params.device_n.mem->non_gc_memory);
+ if (code < 0) {
+ gs_free_object(pcs->params.device_n.mem->non_gc_memory, colorant_name, "pdfi_devicen(colorant)");
+ rc_decrement_cs(colorant_space, "pdfi_devicen(colorant)");
+ pdfi_countdown(Space);
+ pdfi_countdown(Colorant);
+ code = gs_note_error(gs_error_VMerror);
+ goto pdfi_devicen_error;
+ }
+
+ /* We've attached the colorant colour space to the DeviceN space, we no longer need this
+ * reference to it, so discard it.
+ */
+ rc_decrement_cs(colorant_space, "pdfi_devicen(colorant)");
+ pdfi_countdown(Space);
+ pdfi_countdown(Colorant);
+ Space = Colorant = NULL;
+
+ code = pdfi_dict_next(ctx, Colorants, &Colorant, &Space, &ix);
+ if (code == gs_error_undefined)
+ break;
+
+ if (code < 0) {
+ pdfi_countdown(Space);
+ pdfi_countdown(Colorant);
+ goto pdfi_devicen_error;
+ }
+ }while (1);
+ }
+ }
+
+ if (ppcs!= NULL){
+ *ppcs = pcs;
+ pdfi_set_colour_callback(pcs, ctx, pdfi_cspace_free_callback);
+ } else {
+ code = pdfi_gs_setcolorspace(ctx, pcs);
+ /* release reference from construction */
+ rc_decrement_only_cs(pcs, "setdevicenspace");
+ }
+ pdfi_countdown(Process);
+ pdfi_countdown(Colorants);
+ pdfi_countdown(attributes);
+ pdfi_countdown(inks);
+ pdfi_countdown(NamedAlternate);
+ pdfi_countdown(ArrayAlternate);
+ pdfi_countdown(transform);
+ return_error(0);
+
+pdfi_devicen_error:
+ pdfi_free_function(ctx, pfn);
+ if (pcs_alt != NULL)
+ rc_decrement_only_cs(pcs_alt, "setseparationspace");
+ if(pcs != NULL)
+ rc_decrement_only_cs(pcs, "setseparationspace");
+ pdfi_countdown(Process);
+ pdfi_countdown(Colorants);
+ pdfi_countdown(attributes);
+ pdfi_countdown(inks);
+ pdfi_countdown(NamedAlternate);
+ pdfi_countdown(ArrayAlternate);
+ pdfi_countdown(transform);
+ return code;
+}
+
+/* Now /Indexed spaces, essentially we just need to set the underlying space(s) and then set
+ * /Indexed.
+ */
+static int
+pdfi_create_indexed(pdf_context *ctx, pdf_array *color_array, int index,
+ pdf_dict *stream_dict, pdf_dict *page_dict, gs_color_space **ppcs, bool inline_image)
+{
+ pdf_obj *space=NULL, *lookup=NULL;
+ int code;
+ int64_t hival, lookup_length = 0;
+ int num_values;
+ gs_color_space *pcs=NULL, *pcs_base=NULL;
+ gs_color_space_index base_type;
+ byte *Buffer = NULL;
+
+ if (index != 0)
+ return_error(gs_error_syntaxerror);
+
+ code = pdfi_array_get_int(ctx, color_array, index + 2, &hival);
+ if (code < 0)
+ return code;
+
+ if (hival > 255 || hival < 0)
+ return_error(gs_error_syntaxerror);
+
+ code = pdfi_array_get(ctx, color_array, index + 1, &space);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_create_colorspace(ctx, space, stream_dict, page_dict, &pcs_base, inline_image);
+ if (code < 0)
+ goto exit;
+
+ (void)pcs_base->type->install_cspace(pcs_base, ctx->pgs);
+
+ base_type = gs_color_space_get_index(pcs_base);
+
+ code = pdfi_array_get(ctx, color_array, index + 3, &lookup);
+ if (code < 0)
+ goto exit;
+
+ if (lookup->type == PDF_STREAM) {
+ code = pdfi_stream_to_buffer(ctx, (pdf_stream *)lookup, &Buffer, &lookup_length);
+ if (code < 0)
+ goto exit;
+ } else if (lookup->type == PDF_STRING) {
+ /* This is not legal, but Acrobat seems to accept it */
+ pdf_string *lookup_string = (pdf_string *)lookup; /* alias */
+
+ Buffer = gs_alloc_bytes(ctx->memory, lookup_string->length, "pdfi_create_indexed (lookup buffer)");
+ if (Buffer == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto exit;
+ }
+
+ memcpy(Buffer, lookup_string->data, lookup_string->length);
+ lookup_length = lookup_string->length;
+ } else {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+
+ num_values = (hival+1) * cs_num_components(pcs_base);
+ if (num_values > lookup_length) {
+ dmprintf2(ctx->memory, "WARNING: pdfi_create_indexed() got %ld values, expected at least %d values\n",
+ lookup_length, num_values);
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+
+ /* If we have a named color profile and the base space is DeviceN or
+ Separation use a different set of procedures to ensure the named
+ color remapping code is used */
+ if (ctx->pgs->icc_manager->device_named != NULL &&
+ (base_type == gs_color_space_index_Separation ||
+ base_type == gs_color_space_index_DeviceN))
+ pcs = gs_cspace_alloc(ctx->memory, &gs_color_space_type_Indexed_Named);
+ else
+ pcs = gs_cspace_alloc(ctx->memory, &gs_color_space_type_Indexed);
+
+ /* NOTE: we don't need to increment the reference to pcs_base, since it is already 1 */
+ pcs->base_space = pcs_base;
+
+ pcs->params.indexed.lookup.table.size = num_values;
+ pcs->params.indexed.use_proc = 0;
+ pcs->params.indexed.hival = hival;
+ pcs->params.indexed.n_comps = cs_num_components(pcs_base);
+ pcs->params.indexed.lookup.table.data = Buffer;
+ Buffer = NULL;
+
+ if (ppcs != NULL) {
+ *ppcs = pcs;
+ pdfi_set_colour_callback(pcs, ctx, pdfi_cspace_free_callback);
+ }
+ else {
+ code = pdfi_gs_setcolorspace(ctx, pcs);
+ /* release reference from construction */
+ rc_decrement_only_cs(pcs, "setindexedspace");
+ }
+
+ exit:
+ if (code != 0)
+ rc_decrement(pcs_base, "pdfi_create_indexed(pcs_base) error");
+ if (Buffer)
+ gs_free_object(ctx->memory, Buffer, "pdfi_create_indexed (decompression buffer)");
+ pdfi_countdown(space);
+ pdfi_countdown(lookup);
+ return code;
+}
+
+static int pdfi_create_DeviceGray(pdf_context *ctx, gs_color_space **ppcs)
+{
+ int code = 0;
+
+ if (ppcs != NULL) {
+ if (ctx->page.DefaultGray_cs != NULL) {
+ *ppcs = ctx->page.DefaultGray_cs;
+ rc_increment(*ppcs);
+ } else {
+ *ppcs = gs_cspace_new_DeviceGray(ctx->memory);
+ if (*ppcs == NULL)
+ code = gs_note_error(gs_error_VMerror);
+ else {
+ code = ((gs_color_space *)*ppcs)->type->install_cspace(*ppcs, ctx->pgs);
+ if (code < 0) {
+ rc_decrement_only_cs(*ppcs, "pdfi_create_DeviceGray");
+ *ppcs = NULL;
+ }
+ }
+ if (*ppcs != NULL)
+ pdfi_set_colour_callback(*ppcs, ctx, pdfi_cspace_free_callback);
+ }
+ } else {
+ code = pdfi_gs_setgray(ctx, 0);
+ }
+ return code;
+}
+
+static int pdfi_create_DeviceRGB(pdf_context *ctx, gs_color_space **ppcs)
+{
+ int code = 0;
+
+ if (ppcs != NULL) {
+ if (ctx->page.DefaultRGB_cs != NULL) {
+ *ppcs = ctx->page.DefaultRGB_cs;
+ rc_increment(*ppcs);
+ } else {
+ *ppcs = gs_cspace_new_DeviceRGB(ctx->memory);
+ if (*ppcs == NULL)
+ code = gs_note_error(gs_error_VMerror);
+ else {
+ code = ((gs_color_space *)*ppcs)->type->install_cspace(*ppcs, ctx->pgs);
+ if (code < 0) {
+ rc_decrement_only_cs(*ppcs, "pdfi_create_DeviceRGB");
+ *ppcs = NULL;
+ }
+ }
+ if (*ppcs != NULL)
+ pdfi_set_colour_callback(*ppcs, ctx, pdfi_cspace_free_callback);
+ }
+ } else {
+ code = pdfi_gs_setrgbcolor(ctx, 0, 0, 0);
+ }
+ return code;
+}
+
+static int pdfi_create_DeviceCMYK(pdf_context *ctx, gs_color_space **ppcs)
+{
+ int code = 0;
+
+ if (ppcs != NULL) {
+ if (ctx->page.DefaultCMYK_cs != NULL) {
+ *ppcs = ctx->page.DefaultCMYK_cs;
+ rc_increment(*ppcs);
+ } else {
+ *ppcs = gs_cspace_new_DeviceCMYK(ctx->memory);
+ if (*ppcs == NULL)
+ code = gs_note_error(gs_error_VMerror);
+ else {
+ code = ((gs_color_space *)*ppcs)->type->install_cspace(*ppcs, ctx->pgs);
+ if (code < 0) {
+ rc_decrement_only_cs(*ppcs, "pdfi_create_DeviceCMYK");
+ *ppcs = NULL;
+ }
+ }
+ if (*ppcs != NULL)
+ pdfi_set_colour_callback(*ppcs, ctx, pdfi_cspace_free_callback);
+ }
+ } else {
+ code = pdfi_gs_setcmykcolor(ctx, 0, 0, 0, 1);
+ }
+ return code;
+}
+
+static int pdfi_create_JPX_space(pdf_context *ctx, const char *name, int num_components, gs_color_space **ppcs)
+{
+ int code, icc_N;
+ float range_buff[6] = {0.0f, 1.0f, 0.0f, 1.0f, 0.0f, 1.0f};
+
+ code = pdfi_create_icc(ctx, (char *)name, NULL, num_components, &icc_N, range_buff, ppcs);
+ return code;
+}
+
+/* These next routines allow us to use recursion to set up colour spaces. We can set
+ * colour space starting from a name (which can be a named resource) or an array.
+ * If we get a name, and its a named resource we dereference it and go round again.
+ * If its an array we select the correct handler (above) for that space. The space
+ * handler will call pdfi_create_colorspace() to set the underlying space(s) which
+ * may mean calling pdfi_create_colorspace again....
+ */
+static int
+pdfi_create_colorspace_by_array(pdf_context *ctx, pdf_array *color_array, int index,
+ pdf_dict *stream_dict, pdf_dict *page_dict, gs_color_space **ppcs,
+ bool inline_image)
+{
+ int code;
+ pdf_name *space = NULL;
+ pdf_array *a = NULL;
+
+ code = pdfi_array_get_type(ctx, color_array, index, PDF_NAME, (pdf_obj **)&space);
+ if (code != 0)
+ goto exit;
+
+ code = 0;
+ if (pdfi_name_is(space, "G") || pdfi_name_is(space, "DeviceGray")) {
+ if (pdfi_name_is(space, "G") && !inline_image) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_INLINECOLORSPACE, "pdfi_create_colorspace_by_array", NULL);
+ if (ctx->args.pdfstoponwarning)
+ return_error(gs_error_syntaxerror);
+ }
+ code = pdfi_create_DeviceGray(ctx, ppcs);
+ } else if (pdfi_name_is(space, "I") || pdfi_name_is(space, "Indexed")) {
+ if (pdfi_name_is(space, "I") && !inline_image) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_INLINECOLORSPACE, "pdfi_create_colorspace_by_array", NULL);
+ if (ctx->args.pdfstoponwarning)
+ return_error(gs_error_syntaxerror);
+ }
+ code = pdfi_create_indexed(ctx, color_array, index, stream_dict, page_dict, ppcs, inline_image);
+ } else if (pdfi_name_is(space, "Lab")) {
+ code = pdfi_create_Lab(ctx, color_array, index, stream_dict, page_dict, ppcs);
+ } else if (pdfi_name_is(space, "RGB") || pdfi_name_is(space, "DeviceRGB")) {
+ if (pdfi_name_is(space, "RGB") && !inline_image) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_INLINECOLORSPACE, "pdfi_create_colorspace_by_array", NULL);
+ if (ctx->args.pdfstoponwarning)
+ return_error(gs_error_syntaxerror);
+ }
+ code = pdfi_create_DeviceRGB(ctx, ppcs);
+ } else if (pdfi_name_is(space, "CMYK") || pdfi_name_is(space, "DeviceCMYK")) {
+ if (pdfi_name_is(space, "CMYK") && !inline_image) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_INLINECOLORSPACE, "pdfi_create_colorspace_by_array", NULL);
+ if (ctx->args.pdfstoponwarning)
+ return_error(gs_error_syntaxerror);
+ }
+ code = pdfi_create_DeviceCMYK(ctx, ppcs);
+ } else if (pdfi_name_is(space, "CalRGB")) {
+ code = pdfi_create_CalRGB(ctx, color_array, index, stream_dict, page_dict, ppcs);
+ } else if (pdfi_name_is(space, "CalGray")) {
+ code = pdfi_create_CalGray(ctx, color_array, index, stream_dict, page_dict, ppcs);
+ } else if (pdfi_name_is(space, "Pattern")) {
+ if (index != 0)
+ code = gs_note_error(gs_error_syntaxerror);
+ else
+ code = pdfi_pattern_create(ctx, color_array, stream_dict, page_dict, ppcs);
+ } else if (pdfi_name_is(space, "DeviceN")) {
+ code = pdfi_create_DeviceN(ctx, color_array, index, stream_dict, page_dict, ppcs, inline_image);
+ } else if (pdfi_name_is(space, "ICCBased")) {
+ code = pdfi_create_iccbased(ctx, color_array, index, stream_dict, page_dict, ppcs, inline_image);
+ } else if (pdfi_name_is(space, "Separation")) {
+ code = pdfi_create_Separation(ctx, color_array, index, stream_dict, page_dict, ppcs, inline_image);
+ } else {
+ code = pdfi_find_resource(ctx, (unsigned char *)"ColorSpace",
+ space, (pdf_dict *)stream_dict, page_dict, (pdf_obj **)&a);
+ if (code < 0)
+ goto exit;
+
+ if (a->type != PDF_ARRAY) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+
+ /* recursion */
+ code = pdfi_create_colorspace_by_array(ctx, a, 0, stream_dict, page_dict, ppcs, inline_image);
+ }
+
+ exit:
+ pdfi_countdown(space);
+ pdfi_countdown(a);
+ return code;
+}
+
+static int
+pdfi_create_colorspace_by_name(pdf_context *ctx, pdf_name *name,
+ pdf_dict *stream_dict, pdf_dict *page_dict,
+ gs_color_space **ppcs, bool inline_image)
+{
+ int code = 0;
+
+ if (pdfi_name_is(name, "G") || pdfi_name_is(name, "DeviceGray")) {
+ if (pdfi_name_is(name, "G") && !inline_image) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_INLINECOLORSPACE, "pdfi_create_colorspace_by_name", NULL);
+ if (ctx->args.pdfstoponwarning)
+ return_error(gs_error_syntaxerror);
+ }
+ code = pdfi_create_DeviceGray(ctx, ppcs);
+ } else if (pdfi_name_is(name, "RGB") || pdfi_name_is(name, "DeviceRGB")) {
+ if (pdfi_name_is(name, "RGB") && !inline_image) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_INLINECOLORSPACE, "pdfi_create_colorspace_by_name", NULL);
+ if (ctx->args.pdfstoponwarning)
+ return_error(gs_error_syntaxerror);
+ }
+ code = pdfi_create_DeviceRGB(ctx, ppcs);
+ } else if (pdfi_name_is(name, "CMYK") || pdfi_name_is(name, "DeviceCMYK")) {
+ if (pdfi_name_is(name, "CMYK") && !inline_image) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_INLINECOLORSPACE, "pdfi_create_colorspace_by_name", NULL);
+ if (ctx->args.pdfstoponwarning)
+ return_error(gs_error_syntaxerror);
+ }
+ code = pdfi_create_DeviceCMYK(ctx, ppcs);
+ } else if (pdfi_name_is(name, "Pattern")) {
+ code = pdfi_pattern_create(ctx, NULL, stream_dict, page_dict, ppcs);
+ } else if (pdfi_name_is(name, "esRGBICC")) { /* These 4 spaces are 'special' for JPX images */
+ code = pdfi_create_JPX_space(ctx, "esrgb", 3, ppcs); /* the names are non-standad and must match those in */
+ } else if (pdfi_name_is(name, "rommRGBICC")) { /* pdfi_image_get_color() in pdf_image.c */
+ code = pdfi_create_JPX_space(ctx, "rommrgb", 3, ppcs); /* Note that the Lab space for JPX images does not use */
+ } else if (pdfi_name_is(name, "sRGBICC")) { /* a special space but simply constructs an appropriate */
+ code = pdfi_create_JPX_space(ctx, "srgb", 3, ppcs); /* pdf_array object with the corerct contents for an */
+ } else if (pdfi_name_is(name, "sGrayICC")) { /* Lab space with a D65 white point. */
+ code = pdfi_create_JPX_space(ctx, "sgray", 1, ppcs);
+ } else {
+ pdf_obj *ref_space = NULL;
+ code = pdfi_find_resource(ctx, (unsigned char *)"ColorSpace", name, (pdf_dict *)stream_dict,
+ page_dict, &ref_space);
+ if (code < 0)
+ return code;
+
+ /* recursion */
+ code = pdfi_create_colorspace(ctx, ref_space, stream_dict, page_dict, ppcs, inline_image);
+ pdfi_countdown(ref_space);
+ return code;
+ }
+
+ /* If we got here, it's a recursion base case, and ppcs should have been set if requested */
+ if (ppcs != NULL && *ppcs == NULL)
+ code = gs_note_error(gs_error_VMerror);
+ return code;
+}
+
+/*
+ * Gets icc profile data from the provided stream.
+ * Position in the stream is NOT preserved.
+ * This is raw data, not filtered, so no need to worry about compression.
+ * (Used for JPXDecode images)
+ */
+int
+pdfi_create_icc_colorspace_from_stream(pdf_context *ctx, pdf_c_stream *stream, gs_offset_t offset,
+ unsigned int length, int comps, int *icc_N, gs_color_space **ppcs)
+{
+ pdf_c_stream *profile_stream = NULL;
+ byte *profile_buffer;
+ int code, code1;
+ float range[8] = {0,1,0,1,0,1,0,1};
+
+ /* Move to the start of the profile data */
+ pdfi_seek(ctx, stream, offset, SEEK_SET);
+
+ /* The ICC profile reading code (irritatingly) requires a seekable stream, because it
+ * rewinds it to the start, then seeks to the end to find the size, then rewinds the
+ * stream again.
+ * Ideally we would use a ReusableStreamDecode filter here, but that is largely
+ * implemented in PostScript (!) so we can't use it. What we can do is create a
+ * string sourced stream in memory, which is at least seekable.
+ */
+ code = pdfi_open_memory_stream_from_stream(ctx, length, &profile_buffer, stream, &profile_stream, true);
+ if (code < 0) {
+ return code;
+ }
+
+ /* Now, finally, we can call the code to create and set the profile */
+ code = pdfi_create_icc(ctx, NULL, profile_stream->s, comps, icc_N, range, ppcs);
+
+ code1 = pdfi_close_memory_stream(ctx, profile_buffer, profile_stream);
+
+ if (code == 0)
+ code = code1;
+
+ return code;
+}
+
+int pdfi_create_colorspace(pdf_context *ctx, pdf_obj *space, pdf_dict *stream_dict, pdf_dict *page_dict, gs_color_space **ppcs, bool inline_image)
+{
+ int code;
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ return code;
+
+ if (space->type == PDF_NAME) {
+ code = pdfi_create_colorspace_by_name(ctx, (pdf_name *)space, stream_dict, page_dict, ppcs, inline_image);
+ } else {
+ if (space->type == PDF_ARRAY) {
+ code = pdfi_create_colorspace_by_array(ctx, (pdf_array *)space, 0, stream_dict, page_dict, ppcs, inline_image);
+ } else {
+ pdfi_loop_detector_cleartomark(ctx);
+ return_error(gs_error_typecheck);
+ }
+ }
+ if (ppcs && *ppcs && code >= 0)
+ (void)(*ppcs)->type->install_cspace(*ppcs, ctx->pgs);
+
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ return code;
+}
+
+int pdfi_setcolorspace(pdf_context *ctx, pdf_obj *space, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ return pdfi_create_colorspace(ctx, space, stream_dict, page_dict, NULL, false);
+}
+
+/* And finally, the implementation of the actual PDF operators CS and cs */
+int pdfi_setstrokecolor_space(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code;
+
+ if (pdfi_count_stack(ctx) < 1)
+ return_error(gs_error_stackunderflow);
+
+ if (ctx->stack_top[-1]->type != PDF_NAME) {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_stackunderflow);
+ }
+ gs_swapcolors_quick(ctx->pgs);
+ code = pdfi_setcolorspace(ctx, ctx->stack_top[-1], stream_dict, page_dict);
+ gs_swapcolors_quick(ctx->pgs);
+ pdfi_pop(ctx, 1);
+
+ return code;
+}
+
+int pdfi_setfillcolor_space(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code;
+
+ if (pdfi_count_stack(ctx) < 1)
+ return_error(gs_error_stackunderflow);
+
+ if (ctx->stack_top[-1]->type != PDF_NAME) {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_stackunderflow);
+ }
+ code = pdfi_setcolorspace(ctx, ctx->stack_top[-1], stream_dict, page_dict);
+ pdfi_pop(ctx, 1);
+
+ return code;
+}
+
+
+/*
+ * Set device outputintent from stream
+ * see zicc.c/zset_outputintent()
+ */
+static int pdfi_device_setoutputintent(pdf_context *ctx, pdf_dict *profile_dict, stream *stream)
+{
+ int code = 0;
+ gs_gstate *pgs = ctx->pgs;
+ gx_device *dev = gs_currentdevice(pgs);
+ cmm_dev_profile_t *dev_profile;
+ int64_t N;
+ int ncomps, dev_comps;
+ int expected = 0;
+ cmm_profile_t *picc_profile = NULL;
+ cmm_profile_t *source_profile = NULL;
+ gsicc_manager_t *icc_manager = pgs->icc_manager;
+ gs_color_space_index index;
+
+ if_debug0m(gs_debug_flag_icc, ctx->memory, "[icc] Using OutputIntent\n");
+
+ /* get dev_profile and try initing it if fail first time */
+ code = dev_proc(dev, get_profile)(dev, &dev_profile);
+ if (code < 0)
+ return code;
+
+ if (dev_profile == NULL) {
+ code = gsicc_init_device_profile_struct(dev, NULL, 0);
+ if (code < 0)
+ return code;
+ code = dev_proc(dev, get_profile)(dev, &dev_profile);
+ if (code < 0)
+ return code;
+ }
+ if (dev_profile->oi_profile != NULL) {
+ return 0; /* Allow only one setting of this object */
+ }
+
+ code = pdfi_dict_get_int(ctx, profile_dict, "N", &N);
+ if (code < 0)
+ goto exit;
+ ncomps = (int)N;
+
+ picc_profile = gsicc_profile_new(stream, gs_gstate_memory(pgs), NULL, 0);
+ if (picc_profile == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto exit;
+ }
+ picc_profile->num_comps = ncomps;
+ picc_profile->profile_handle =
+ gsicc_get_profile_handle_buffer(picc_profile->buffer,
+ picc_profile->buffer_size,
+ gs_gstate_memory(pgs));
+ if (picc_profile->profile_handle == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto exit;
+ }
+
+ picc_profile->data_cs =
+ gscms_get_profile_data_space(picc_profile->profile_handle,
+ picc_profile->memory);
+ switch (picc_profile->data_cs) {
+ case gsCIEXYZ:
+ case gsCIELAB:
+ case gsRGB:
+ expected = 3;
+ source_profile = icc_manager->default_rgb;
+ break;
+ case gsGRAY:
+ expected = 1;
+ source_profile = icc_manager->default_gray;
+ break;
+ case gsCMYK:
+ expected = 4;
+ source_profile = icc_manager->default_cmyk;
+ break;
+ case gsNCHANNEL:
+ expected = 0;
+ break;
+ case gsNAMED:
+ case gsUNDEFINED:
+ break;
+ }
+ if (expected && ncomps != expected) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ gsicc_init_hash_cs(picc_profile, pgs);
+
+ /* All is well with the profile. Lets set the stuff that needs to be set */
+ dev_profile->oi_profile = picc_profile;
+ rc_increment(picc_profile);
+ picc_profile->name = (char *) gs_alloc_bytes(picc_profile->memory,
+ MAX_DEFAULT_ICC_LENGTH,
+ "pdfi_color_setoutputintent");
+ strncpy(picc_profile->name, OI_PROFILE, strlen(OI_PROFILE));
+ picc_profile->name[strlen(OI_PROFILE)] = 0;
+ picc_profile->name_length = strlen(OI_PROFILE);
+ /* Set the range of the profile */
+ gsicc_set_icc_range(&picc_profile);
+
+ /* If the output device has a different number of components, then we are
+ going to set the output intent as the proofing profile, unless the
+ proofing profile has already been set.
+
+ If the device has the same number of components (and color model) then as
+ the profile we will use this as the output profile, unless someone has
+ explicitly set the output profile.
+
+ Finally, we will use the output intent profile for the default profile
+ of the proper Device profile in the icc manager, again, unless someone
+ has explicitly set this default profile.
+ */
+ dev_comps = dev_profile->device_profile[GS_DEFAULT_DEVICE_PROFILE]->num_comps;
+ index = gsicc_get_default_type(dev_profile->device_profile[GS_DEFAULT_DEVICE_PROFILE]);
+ if (ncomps == dev_comps && index < gs_color_space_index_DevicePixel) {
+ /* The OI profile is the same type as the profile for the device and a
+ "default" profile for the device was not externally set. So we go
+ ahead and use the OI profile as the device profile. Care needs to be
+ taken here to keep from screwing up any device parameters. We will
+ use a keyword of OIProfile for the user/device parameter to indicate
+ its usage. Also, note conflicts if one is setting object dependent
+ color management */
+ dev_profile->device_profile[GS_DEFAULT_DEVICE_PROFILE] = picc_profile;
+ rc_increment(picc_profile);
+ if_debug0m(gs_debug_flag_icc, ctx->memory, "[icc] OutputIntent used for device profile\n");
+ } else {
+ if (dev_profile->proof_profile == NULL) {
+ /* This means that we should use the OI profile as the proofing
+ profile. Note that if someone already has specified a
+ proofing profile it is unclear what they are trying to do
+ with the output intent. In this case, we will use it
+ just for the source data below */
+ dev_profile->proof_profile = picc_profile;
+ rc_increment(picc_profile);
+ if_debug0m(gs_debug_flag_icc, ctx->memory, "[icc] OutputIntent used for proof profile\n");
+ }
+ }
+ /* Now the source colors. See which source color space needs to use the
+ output intent ICC profile */
+ index = gsicc_get_default_type(source_profile);
+ if (index < gs_color_space_index_DevicePixel) {
+ /* source_profile is currently the default. Set it to the OI profile */
+ switch (picc_profile->data_cs) {
+ case gsGRAY:
+ if_debug0m(gs_debug_flag_icc, ctx->memory, "[icc] OutputIntent used source Gray\n");
+ icc_manager->default_gray = picc_profile;
+ rc_increment(picc_profile);
+ break;
+ case gsRGB:
+ if_debug0m(gs_debug_flag_icc, ctx->memory, "[icc] OutputIntent used source RGB\n");
+ icc_manager->default_rgb = picc_profile;
+ rc_increment(picc_profile);
+ break;
+ case gsCMYK:
+ if_debug0m(gs_debug_flag_icc, ctx->memory, "[icc] OutputIntent used source CMYK\n");
+ icc_manager->default_cmyk = picc_profile;
+ rc_increment(picc_profile);
+ break;
+ default:
+ break;
+ }
+ }
+
+ exit:
+ if (picc_profile != NULL)
+ rc_decrement(picc_profile, "pdfi_color_setoutputintent");
+ return code;
+}
+
+/*
+ * intent_dict -- the outputintent dictionary
+ * profile -- the color profile (a stream)
+ *
+ */
+int pdfi_color_setoutputintent(pdf_context *ctx, pdf_dict *intent_dict, pdf_stream *profile)
+{
+ pdf_c_stream *profile_stream = NULL;
+ byte *profile_buffer;
+ gs_offset_t savedoffset;
+ int code, code1;
+ int64_t Length;
+ pdf_dict *profile_dict;
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)profile, &profile_dict);
+ if (code < 0)
+ return code;
+
+ /* Save the current stream position, and move to the start of the profile stream */
+ savedoffset = pdfi_tell(ctx->main_stream);
+ pdfi_seek(ctx, ctx->main_stream, pdfi_stream_offset(ctx, profile), SEEK_SET);
+
+ Length = pdfi_stream_length(ctx, profile);
+
+ /* The ICC profile reading code (irritatingly) requires a seekable stream, because it
+ * rewinds it to the start, then seeks to the end to find the size, then rewinds the
+ * stream again.
+ * Ideally we would use a ReusableStreamDecode filter here, but that is largely
+ * implemented in PostScript (!) so we can't use it. What we can do is create a
+ * string sourced stream in memory, which is at least seekable.
+ */
+ code = pdfi_open_memory_stream_from_filtered_stream(ctx, profile, Length, &profile_buffer, ctx->main_stream, &profile_stream, true);
+ if (code < 0)
+ goto exit;
+
+ /* Create and set the device profile */
+ code = pdfi_device_setoutputintent(ctx, profile_dict, profile_stream->s);
+
+ code1 = pdfi_close_memory_stream(ctx, profile_buffer, profile_stream);
+
+ if (code == 0)
+ code = code1;
+
+ exit:
+ pdfi_seek(ctx, ctx->main_stream, savedoffset, SEEK_SET);
+ return code;
+}
diff --git a/pdf/pdf_colour.h b/pdf/pdf_colour.h
new file mode 100644
index 00000000..5cc9f0eb
--- /dev/null
+++ b/pdf/pdf_colour.h
@@ -0,0 +1,60 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* colour operations for the PDF interpreter */
+
+#ifndef PDF_COLOUR_OPERATORS
+#define PDF_COLOUR_OPERATORS
+
+#include "gscolor1.h"
+#include "gscspace.h"
+
+static inline void pdfi_set_colour_callback(gs_color_space *pcs, pdf_context *ctx, gs_cspace_free_proc_t pdfi_cspace_free_callback)
+{
+ pcs->interpreter_data = ctx;
+ pcs->interpreter_free_cspace_proc = pdfi_cspace_free_callback;
+}
+
+int pdfi_setgraystroke(pdf_context *ctx);
+int pdfi_setgrayfill(pdf_context *ctx);
+int pdfi_setrgbstroke(pdf_context *ctx);
+int pdfi_setrgbfill(pdf_context *ctx);
+int pdfi_setrgbfill_array(pdf_context *ctx);
+int pdfi_setcmykstroke(pdf_context *ctx);
+int pdfi_setcmykfill(pdf_context *ctx);
+int pdfi_setstrokecolor_space(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict);
+int pdfi_setfillcolor_space(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict);
+int pdfi_setstrokecolor(pdf_context *ctx);
+int pdfi_setfillcolor(pdf_context *ctx);
+int pdfi_setcolorN(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict, bool is_fill);
+int pdfi_ri(pdf_context *ctx);
+
+int pdfi_setcolor_from_array(pdf_context *ctx, pdf_array *array);
+int pdfi_gs_setgray(pdf_context *ctx, double d);
+int pdfi_gs_setrgbcolor(pdf_context *ctx, double r, double g, double b);
+
+/* For potential use by other types of object (images etc) */
+int pdfi_gs_setcolorspace(pdf_context *ctx, gs_color_space *pcs);
+int pdfi_setcolorspace(pdf_context *ctx, pdf_obj *space, pdf_dict *stream_dict, pdf_dict *page_dict);
+int pdfi_create_colorspace(pdf_context *ctx, pdf_obj *space, pdf_dict *stream_dict, pdf_dict *page_dict, gs_color_space **ppcs, bool inline_image);
+int pdfi_create_icc_colorspace_from_stream(pdf_context *ctx, pdf_c_stream *stream, gs_offset_t offset,
+ unsigned int length, int comps, int *icc_N, gs_color_space **ppcs);
+
+/* Page level spot colour detection and enumeration */
+int pdfi_check_ColorSpace_for_spots(pdf_context *ctx, pdf_obj *space, pdf_dict *parent_dict, pdf_dict *page_dict, pdf_dict *spot_dict);
+
+int pdfi_color_setoutputintent(pdf_context *ctx, pdf_dict *intent_dict, pdf_stream *profile);
+
+#endif
diff --git a/pdf/pdf_deref.c b/pdf/pdf_deref.c
new file mode 100644
index 00000000..fb3ce67b
--- /dev/null
+++ b/pdf/pdf_deref.c
@@ -0,0 +1,1028 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Functions to deal with dereferencing indirect objects
+ * for the PDF interpreter. In here we also keep the code
+ * for dealing with the object cache, because the dereferencing
+ * functions are currently the only place that deals with it.
+ */
+
+#include "pdf_int.h"
+#include "pdf_stack.h"
+#include "pdf_loop_detect.h"
+#include "strmio.h"
+#include "stream.h"
+#include "pdf_file.h"
+#include "pdf_misc.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_deref.h"
+#include "pdf_repair.h"
+
+/* Start with the object caching functions */
+
+/* given an object, create a cache entry for it. If we have too many entries
+ * then delete the leat-recently-used cache entry. Make the new entry be the
+ * most-recently-used entry. The actual entries are attached to the xref table
+ * (as well as being a double-linked list), because we detect an existing
+ * cache entry by seeing that the xref table for the object number has a non-NULL
+ * 'cache' member.
+ * So we need to update the xref as well if we add or delete cache entries.
+ */
+static int pdfi_add_to_cache(pdf_context *ctx, pdf_obj *o)
+{
+ pdf_obj_cache_entry *entry;
+
+ if (ctx->xref_table->xref[o->object_num].cache != NULL) {
+#if DEBUG_CACHE
+ dmprintf1(ctx->memory, "Attempting to add object %d to cache when the object is already cached!\n", o->object_num);
+#endif
+ return_error(gs_error_unknownerror);
+ }
+
+ if (o->object_num > ctx->xref_table->xref_size)
+ return_error(gs_error_rangecheck);
+
+ if (ctx->cache_entries == MAX_OBJECT_CACHE_SIZE)
+ {
+#if DEBUG_CACHE
+ dbgmprintf(ctx->memory, "Cache full, evicting LRU\n");
+#endif
+ if (ctx->cache_LRU) {
+ entry = ctx->cache_LRU;
+ ctx->cache_LRU = entry->next;
+ if (entry->next)
+ ((pdf_obj_cache_entry *)entry->next)->previous = NULL;
+ ctx->xref_table->xref[entry->o->object_num].cache = NULL;
+ pdfi_countdown(entry->o);
+ ctx->cache_entries--;
+ gs_free_object(ctx->memory, entry, "pdfi_add_to_cache, free LRU");
+ } else
+ return_error(gs_error_unknownerror);
+ }
+ entry = (pdf_obj_cache_entry *)gs_alloc_bytes(ctx->memory, sizeof(pdf_obj_cache_entry), "pdfi_add_to_cache");
+ if (entry == NULL)
+ return_error(gs_error_VMerror);
+
+ memset(entry, 0x00, sizeof(pdf_obj_cache_entry));
+
+ entry->o = o;
+ pdfi_countup(o);
+ if (ctx->cache_MRU) {
+ entry->previous = ctx->cache_MRU;
+ ctx->cache_MRU->next = entry;
+ }
+ ctx->cache_MRU = entry;
+ if (ctx->cache_LRU == NULL)
+ ctx->cache_LRU = entry;
+
+ ctx->cache_entries++;
+ ctx->xref_table->xref[o->object_num].cache = entry;
+ return 0;
+}
+
+/* Given an existing cache entry, promote it to be the most-recently-used
+ * cache entry.
+ */
+static void pdfi_promote_cache_entry(pdf_context *ctx, pdf_obj_cache_entry *cache_entry)
+{
+ if (ctx->cache_MRU && cache_entry != ctx->cache_MRU) {
+ if ((pdf_obj_cache_entry *)cache_entry->next != NULL)
+ ((pdf_obj_cache_entry *)cache_entry->next)->previous = cache_entry->previous;
+ if ((pdf_obj_cache_entry *)cache_entry->previous != NULL)
+ ((pdf_obj_cache_entry *)cache_entry->previous)->next = cache_entry->next;
+ else {
+ /* the existing entry is the current least recently used, we need to make the 'next'
+ * cache entry into the LRU.
+ */
+ ctx->cache_LRU = cache_entry->next;
+ }
+ cache_entry->next = NULL;
+ cache_entry->previous = ctx->cache_MRU;
+ ctx->cache_MRU->next = cache_entry;
+ ctx->cache_MRU = cache_entry;
+ }
+ return;
+}
+
+/* This one's a bit of an oddity, its used for fonts. When we build a PDF font object
+ * we want the object cache to reference *that* object, not the dictionary which was
+ * read out of the PDF file, so this allows us to replace the font dictionary in the
+ * cache with the actual font object, so that later dereferences will get this font
+ * object.
+ */
+int replace_cache_entry(pdf_context *ctx, pdf_obj *o)
+{
+ xref_entry *entry;
+ pdf_obj_cache_entry *cache_entry;
+ pdf_obj *old_cached_obj = NULL;
+
+ /* Limited error checking here, we assume that things like the
+ * validity of the object (eg not a free oobject) have already been handled.
+ */
+
+ entry = &ctx->xref_table->xref[o->object_num];
+ cache_entry = entry->cache;
+
+ if (cache_entry == NULL) {
+ return(pdfi_add_to_cache(ctx, o));
+ } else {
+ /* NOTE: We grab the object without decrementing, to avoid triggering
+ * a warning message for freeing an object that's in the cache
+ */
+ if (cache_entry->o != NULL)
+ old_cached_obj = cache_entry->o;
+
+ /* Put new entry in the cache */
+ cache_entry->o = o;
+ pdfi_countup(o);
+ pdfi_promote_cache_entry(ctx, cache_entry);
+
+ /* Now decrement the old cache entry, if any */
+ pdfi_countdown(old_cached_obj);
+ }
+ return 0;
+}
+
+/* Now the dereferencing functions */
+
+/*
+ * Technically we can accept a stream other than the main PDF file stream here. This is
+ * really for the case of compressed objects where we read tokens from the compressed
+ * stream, but it also (with some judicious tinkering) allows us to layer a SubFileDecode
+ * on top of the main file stream, which may be useful. Note that this cannot work with
+ * objects in compressed object streams! They should always pass a value of 0 for the stream_offset.
+ * The stream_offset is the offset from the start of the underlying uncompressed PDF file of
+ * the stream we are using. See the comments below when keyword is PDF_STREAM.
+ */
+
+/* Determine if a PDF object is in a compressed ObjStm. Returns < 0
+ * for an error, 0 if it is not in a compressed ObjStm and 1 if it is.
+ * Currently errors are inmpossible. This is only used by the decryption code
+ * to determine if a string is in a compressed object stream, if it is then
+ * it can't be used for decryption.
+ */
+int is_compressed_object(pdf_context *ctx, uint32_t obj, uint32_t gen)
+{
+ xref_entry *entry;
+
+ /* Can't possibly be a compressed object before we have finished reading
+ * the xref.
+ */
+ if (ctx->xref_table == NULL)
+ return 0;
+
+ entry = &ctx->xref_table->xref[obj];
+
+ if (entry->compressed)
+ return 1;
+
+ return 0;
+}
+
+/* We should never read a 'stream' keyword from a compressed object stream
+ * so this case should never end up here.
+ */
+static int pdfi_read_stream_object(pdf_context *ctx, pdf_c_stream *s, gs_offset_t stream_offset,
+ uint32_t objnum, uint32_t gen)
+{
+ int code = 0;
+ int64_t i;
+ pdf_keyword *keyword = NULL;
+ pdf_dict *dict = NULL;
+ gs_offset_t offset;
+ pdf_stream *stream_obj = NULL;
+
+ /* Strange code time....
+ * If we are using a stream which is *not* the PDF uncompressed main file stream
+ * then doing stell on it will only tell us how many bytes have been read from
+ * that stream, it won't tell us the underlying file position. So we add on the
+ * 'unread' bytes, *and* we add on the position of the start of the stream in
+ * the actual main file. This is all done so that we can check the /Length
+ * of the object. Note that this will *only* work for regular objects it can
+ * not be used for compressed object streams, but those don't need checking anyway
+ * they have a different mechanism altogether and should never get here.
+ */
+ offset = stell(s->s) - s->unread_size + stream_offset;
+ code = pdfi_seek(ctx, ctx->main_stream, offset, SEEK_SET);
+
+ if (pdfi_count_stack(ctx) < 1)
+ return_error(gs_error_stackunderflow);
+
+ dict = (pdf_dict *)ctx->stack_top[-1];
+ dict->indirect_num = dict->object_num = objnum;
+ dict->indirect_gen = dict->generation_num = gen;
+
+ if (dict->type != PDF_DICT) {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_syntaxerror);
+ }
+
+ /* Convert the dict into a stream */
+ code = pdfi_obj_dict_to_stream(ctx, dict, &stream_obj, true);
+ if (code < 0) {
+ pdfi_pop(ctx, 1);
+ return code;
+ }
+ /* Pop off the dict and push the stream */
+ pdfi_pop(ctx, 1);
+ dict = NULL;
+ pdfi_push(ctx, (pdf_obj *)stream_obj);
+ pdfi_countdown(stream_obj); /* get rid of extra ref */
+
+ stream_obj->stream_dict->indirect_num = stream_obj->stream_dict->object_num = objnum;
+ stream_obj->stream_dict->indirect_gen = stream_obj->stream_dict->generation_num = gen;
+ stream_obj->stream_offset = offset;
+
+ /* This code may be a performance overhead, it simply skips over the stream contents
+ * and checks that the stream ends with a 'endstream endobj' pair. We could add a
+ * 'go faster' flag for users who are certain their PDF files are well-formed. This
+ * could also allow us to skip all kinds of other checking.....
+ */
+
+ code = pdfi_dict_get_int(ctx, (pdf_dict *)stream_obj->stream_dict, "Length", &i);
+ if (code < 0) {
+ char extra_info[gp_file_name_sizeof];
+
+ gs_sprintf(extra_info, "Stream object %u missing mandatory keyword /Length, unable to verify the stream length.\n", objnum);
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADSTREAM, "pdfi_read_stream_object", extra_info);
+ return 0;
+ }
+
+ if (i < 0 || (i + offset)> ctx->main_stream_length) {
+ char extra_info[gp_file_name_sizeof];
+
+ gs_sprintf(extra_info, "Stream object %u has /Length which, when added to offset of object, exceeds file size.\n", objnum);
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADSTREAM, "pdfi_read_stream_object", extra_info);
+ } else {
+ code = pdfi_seek(ctx, ctx->main_stream, i, SEEK_CUR);
+ if (code < 0) {
+ pdfi_pop(ctx, 1);
+ return code;
+ }
+
+ stream_obj->Length = 0;
+ stream_obj->length_valid = false;
+
+ code = pdfi_read_token(ctx, ctx->main_stream, objnum, gen);
+ if (code < 0 || pdfi_count_stack(ctx) < 2) {
+ char extra_info[gp_file_name_sizeof];
+
+ gs_sprintf(extra_info, "Failed to find a valid object at end of stream object %u.\n", objnum);
+ pdfi_log_info(ctx, "pdfi_read_stream_object", extra_info);
+ }
+ else {
+ if (((pdf_obj *)ctx->stack_top[-1])->type != PDF_KEYWORD) {
+ char extra_info[gp_file_name_sizeof];
+
+ gs_sprintf(extra_info, "Failed to find 'endstream' keyword at end of stream object %u.\n", objnum);
+ pdfi_set_error(ctx, 0, NULL, E_PDF_MISSINGENDOBJ, "pdfi_read_stream_object", extra_info);
+ } else {
+ keyword = ((pdf_keyword *)ctx->stack_top[-1]);
+ if (keyword->key != TOKEN_ENDSTREAM) {
+ char extra_info[gp_file_name_sizeof];
+
+ gs_sprintf(extra_info, "Stream object %u has an incorrect /Length of %"PRIu64"\n", objnum, i);
+ pdfi_log_info(ctx, "pdfi_read_stream_object", extra_info);
+ } else {
+ /* Cache the Length in the stream object and mark it valid */
+ stream_obj->Length = i;
+ stream_obj->length_valid = true;
+ }
+ }
+ pdfi_pop(ctx, 1);
+ }
+ }
+
+ /* If we failed to find a valid object, or the object wasn't a keyword, or the
+ * keywrod wasn't 'endstream' then the Length is wrong. We need to have the correct
+ * Length for streams if we have encrypted files, because we must install a
+ * SubFileDecode filter iwth a Length (EODString is incompatible with AES encryption)
+ * Rather than mess about checking for encryption, we'll choose to just correctly
+ * calculate the Length of all streams. Although this takes time, it will only
+ * happen for files which are invalid.
+ */
+ if (stream_obj->length_valid != true) {
+ char Buffer[10];
+ unsigned int loop, bytes, total = 0;
+
+ code = pdfi_seek(ctx, ctx->main_stream, stream_obj->stream_offset, SEEK_SET);
+ if (code < 0) {
+ pdfi_pop(ctx, 1);
+ return code;
+ }
+ memset(Buffer, 0x00, 10);
+ bytes = pdfi_read_bytes(ctx, (byte *)Buffer, 1, 9, ctx->main_stream);
+ if (bytes < 9)
+ return_error(gs_error_ioerror);
+
+ total = bytes;
+ do {
+ if (memcmp(Buffer, "endstream", 9) == 0) {
+ stream_obj->Length = total - 9;
+ stream_obj->length_valid = true;
+ break;
+ }
+ if (memcmp(Buffer, "endobj", 6) == 0) {
+ stream_obj->Length = total - 6;
+ stream_obj->length_valid = true;
+ break;
+ }
+ for (loop = 0;loop < 9;loop++){
+ Buffer[loop] = Buffer[loop + 1];
+ }
+ bytes = pdfi_read_bytes(ctx, (byte *)&Buffer[9], 1, 1, ctx->main_stream);
+ total += bytes;
+ } while(bytes);
+ if (bytes <= 0)
+ return_error(gs_error_ioerror);
+ return 0;
+ }
+
+ code = pdfi_read_token(ctx, ctx->main_stream, objnum, gen);
+ if (code < 0) {
+ if (ctx->args.pdfstoponerror)
+ return code;
+ else
+ /* Something went wrong looking for endobj, but we found endstream, so assume
+ * for now that will suffice.
+ */
+ pdfi_set_error(ctx, 0, NULL, E_PDF_MISSINGENDOBJ, "pdfi_read_stream_object", NULL);
+ return 0;
+ }
+
+ if (pdfi_count_stack(ctx) < 2)
+ return_error(gs_error_stackunderflow);
+
+ if (((pdf_obj *)ctx->stack_top[-1])->type != PDF_KEYWORD) {
+ pdfi_pop(ctx, 1);
+ if (ctx->args.pdfstoponerror)
+ return_error(gs_error_typecheck);
+ pdfi_set_error(ctx, 0, NULL, E_PDF_MISSINGENDOBJ, "pdfi_read_stream_object", NULL);
+ /* Didn't find an endobj, but we have an endstream, so assume
+ * for now that will suffice
+ */
+ return 0;
+ }
+ keyword = ((pdf_keyword *)ctx->stack_top[-1]);
+ if (keyword->key != TOKEN_ENDOBJ) {
+ pdfi_pop(ctx, 2);
+ return_error(gs_error_typecheck);
+ }
+ pdfi_pop(ctx, 1);
+ return 0;
+}
+
+/* This reads an object *after* the x y obj keyword has been found. Its broken out
+ * separately for the benefit of the repair code when reading the dictionary following
+ * the 'trailer' keyword, which does not have a 'obj' keyword. Note that it also does
+ * not have an 'endobj', we rely on the error handling to take care of that for us.
+ */
+int pdfi_read_bare_object(pdf_context *ctx, pdf_c_stream *s, gs_offset_t stream_offset, uint32_t objnum, uint32_t gen)
+{
+ int code = 0;
+ pdf_keyword *keyword = NULL;
+ gs_offset_t saved_offset[3];
+
+ saved_offset[0] = saved_offset[1] = saved_offset[2] = 0;
+
+ code = pdfi_read_token(ctx, s, objnum, gen);
+ if (code < 0)
+ return code;
+
+ do {
+ /* move all the saved offsets up by one */
+ saved_offset[0] = saved_offset[1];
+ saved_offset[1] = saved_offset[2];
+ saved_offset[2] = pdfi_unread_tell(ctx);;
+
+ code = pdfi_read_token(ctx, s, objnum, gen);
+ if (code < 0) {
+ pdfi_clearstack(ctx);
+ return code;
+ }
+ if (s->eof)
+ return_error(gs_error_syntaxerror);
+ }while (ctx->stack_top[-1]->type != PDF_KEYWORD);
+
+ keyword = ((pdf_keyword *)ctx->stack_top[-1]);
+ if (keyword->key == TOKEN_ENDOBJ) {
+ pdf_obj *o;
+
+ if (pdfi_count_stack(ctx) < 2) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ o = ctx->stack_top[-2];
+
+ pdfi_pop(ctx, 1);
+
+ o->indirect_num = o->object_num = objnum;
+ o->indirect_gen = o->generation_num = gen;
+ return code;
+ }
+ if (keyword->key == TOKEN_STREAM) {
+ pdfi_pop(ctx, 1);
+ return pdfi_read_stream_object(ctx, s, stream_offset, objnum, gen);
+ }
+ if (keyword->key == TOKEN_OBJ) {
+ pdf_obj *o;
+
+ pdfi_set_error(ctx, 0, NULL, E_PDF_MISSINGENDOBJ, "pdfi_read_bare_object", NULL);
+
+ /* 4 for; the object we want, the object number, generation number and 'obj' keyword */
+ if (pdfi_count_stack(ctx) < 4)
+ return_error(gs_error_stackunderflow);
+
+ /* If we have that many objects, assume that we can throw away the x y obj and just use the remaining object */
+ o = ctx->stack_top[-4];
+
+ pdfi_pop(ctx, 3);
+
+ o->indirect_num = o->object_num = objnum;
+ o->indirect_gen = o->generation_num = gen;
+ if (saved_offset[0] > 0)
+ (void)pdfi_seek(ctx, s, saved_offset[0], SEEK_SET);
+ return 0;
+ }
+
+ /* Assume that any other keyword means a missing 'endobj' */
+ if (!ctx->args.pdfstoponerror) {
+ pdf_obj *o;
+
+ pdfi_set_error(ctx, 0, NULL, E_PDF_MISSINGENDOBJ, "pdfi_read_bare_object", NULL);
+
+ if (pdfi_count_stack(ctx) < 2)
+ return_error(gs_error_stackunderflow);
+
+ o = ctx->stack_top[-2];
+
+ pdfi_pop(ctx, 1);
+
+ o->indirect_num = o->object_num = objnum;
+ o->indirect_gen = o->generation_num = gen;
+ return code;
+ }
+ pdfi_pop(ctx, 2);
+ return_error(gs_error_syntaxerror);
+}
+
+static int pdfi_read_object(pdf_context *ctx, pdf_c_stream *s, gs_offset_t stream_offset)
+{
+ int code = 0, stack_size = pdfi_count_stack(ctx);
+ uint64_t objnum = 0, gen = 0;
+ pdf_keyword *keyword = NULL;
+
+ /* An object consists of 'num gen obj' followed by a token, follwed by an endobj
+ * A stream dictionary might have a 'stream' instead of an 'endobj', in which case we
+ * want to deal with it specially by getting the Length, jumping to the end and checking
+ * for an endobj. Or not, possibly, because it would be slow.
+ */
+ code = pdfi_read_token(ctx, s, 0, 0);
+ if (code < 0)
+ return code;
+ if (stack_size >= pdfi_count_stack(ctx))
+ return gs_note_error(gs_error_ioerror);
+ if (((pdf_obj *)ctx->stack_top[-1])->type != PDF_INT) {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_typecheck);
+ }
+ objnum = ((pdf_num *)ctx->stack_top[-1])->value.i;
+ pdfi_pop(ctx, 1);
+
+ code = pdfi_read_token(ctx, s, 0, 0);
+ if (code < 0)
+ return code;
+ if (stack_size >= pdfi_count_stack(ctx))
+ return gs_note_error(gs_error_ioerror);
+ if (((pdf_obj *)ctx->stack_top[-1])->type != PDF_INT) {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_typecheck);
+ }
+ gen = ((pdf_num *)ctx->stack_top[-1])->value.i;
+ pdfi_pop(ctx, 1);
+
+ code = pdfi_read_token(ctx, s, 0, 0);
+ if (code < 0)
+ return code;
+ if (stack_size >= pdfi_count_stack(ctx))
+ return gs_note_error(gs_error_ioerror);
+ if (((pdf_obj *)ctx->stack_top[-1])->type != PDF_KEYWORD) {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_typecheck);
+ }
+ keyword = ((pdf_keyword *)ctx->stack_top[-1]);
+ if (keyword->key != TOKEN_OBJ) {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_syntaxerror);
+ }
+ pdfi_pop(ctx, 1);
+
+ return pdfi_read_bare_object(ctx, s, stream_offset, objnum, gen);
+}
+
+static int pdfi_deref_compressed(pdf_context *ctx, uint64_t obj, uint64_t gen, pdf_obj **object,
+ const xref_entry *entry)
+{
+ int code = 0;
+ xref_entry *compressed_entry = &ctx->xref_table->xref[entry->u.compressed.compressed_stream_num];
+ pdf_c_stream *compressed_stream = NULL;
+ pdf_c_stream *SubFile_stream = NULL;
+ pdf_c_stream *Object_stream = NULL;
+ char Buffer[256];
+ int i = 0, object_length = 0;
+ int64_t num_entries, found_object;
+ int64_t Length;
+ gs_offset_t offset = 0;
+ pdf_stream *compressed_object = NULL;
+ pdf_dict *compressed_sdict = NULL; /* alias */
+ pdf_name *Type = NULL;
+ pdf_obj *temp_obj;
+
+ if (ctx->args.pdfdebug) {
+ dmprintf1(ctx->memory, "%% Reading compressed object (%"PRIi64" 0 obj)", obj);
+ dmprintf1(ctx->memory, " from ObjStm with object number %"PRIi64"\n", compressed_entry->object_num);
+ }
+
+ if (compressed_entry->cache == NULL) {
+#if CACHE_STATISTICS
+ ctx->compressed_misses++;
+#endif
+ code = pdfi_seek(ctx, ctx->main_stream, compressed_entry->u.uncompressed.offset, SEEK_SET);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_read_object(ctx, ctx->main_stream, 0);
+ if (code < 0)
+ goto exit;
+
+ if ((ctx->stack_top[-1])->type != PDF_STREAM) {
+ pdfi_pop(ctx, 1);
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+ if (ctx->stack_top[-1]->object_num != compressed_entry->object_num) {
+ pdfi_pop(ctx, 1);
+ /* Same error (undefined) as when we read an uncompressed object with the wrong number */
+ code = gs_note_error(gs_error_undefined);
+ goto exit;
+ }
+ compressed_object = (pdf_stream *)ctx->stack_top[-1];
+ pdfi_countup(compressed_object);
+ pdfi_pop(ctx, 1);
+ code = pdfi_add_to_cache(ctx, (pdf_obj *)compressed_object);
+ if (code < 0)
+ goto exit;
+ } else {
+#if CACHE_STATISTICS
+ ctx->compressed_hits++;
+#endif
+ compressed_object = (pdf_stream *)compressed_entry->cache->o;
+ pdfi_countup(compressed_object);
+ pdfi_promote_cache_entry(ctx, compressed_entry->cache);
+ }
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)compressed_object, &compressed_sdict);
+ if (code < 0)
+ return code;
+
+ /* Check its an ObjStm ! */
+ code = pdfi_dict_get_type(ctx, compressed_sdict, "Type", PDF_NAME, (pdf_obj **)&Type);
+ if (code < 0)
+ goto exit;
+
+ if (!pdfi_name_is(Type, "ObjStm")){
+ code = gs_note_error(gs_error_syntaxerror);
+ goto exit;
+ }
+
+ /* Need to check the /N entry to see if the object is actually in this stream! */
+ code = pdfi_dict_get_int(ctx, compressed_sdict, "N", &num_entries);
+ if (code < 0)
+ goto exit;
+
+ if (num_entries < 0 || num_entries > ctx->xref_table->xref_size) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+
+ code = pdfi_seek(ctx, ctx->main_stream, pdfi_stream_offset(ctx, compressed_object), SEEK_SET);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_dict_get_int(ctx, compressed_sdict, "Length", &Length);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_apply_SubFileDecode_filter(ctx, Length, NULL, ctx->main_stream, &SubFile_stream, false);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_filter(ctx, compressed_object, SubFile_stream, &compressed_stream, false);
+ if (code < 0)
+ goto exit;
+
+ for (i=0;i < num_entries;i++)
+ {
+ code = pdfi_read_token(ctx, compressed_stream, obj, gen);
+ if (code < 0)
+ goto exit;
+ temp_obj = ctx->stack_top[-1];
+ if (temp_obj->type != PDF_INT) {
+ code = gs_note_error(gs_error_typecheck);
+ pdfi_pop(ctx, 1);
+ goto exit;
+ }
+ found_object = ((pdf_num *)temp_obj)->value.i;
+ pdfi_pop(ctx, 1);
+ code = pdfi_read_token(ctx, compressed_stream, obj, gen);
+ if (code < 0)
+ goto exit;
+ temp_obj = ctx->stack_top[-1];
+ if (temp_obj->type != PDF_INT) {
+ pdfi_pop(ctx, 1);
+ goto exit;
+ }
+ if (i == entry->u.compressed.object_index) {
+ if (found_object != obj) {
+ pdfi_pop(ctx, 1);
+ code = gs_note_error(gs_error_undefined);
+ goto exit;
+ }
+ offset = ((pdf_num *)temp_obj)->value.i;
+ }
+ if (i == entry->u.compressed.object_index + 1)
+ object_length = ((pdf_num *)temp_obj)->value.i - offset;
+ pdfi_pop(ctx, 1);
+ }
+
+ /* Skip to the offset of the object we want to read */
+ for (i=0;i < offset;i++)
+ {
+ code = pdfi_read_bytes(ctx, (byte *)&Buffer[0], 1, 1, compressed_stream);
+ if (code <= 0) {
+ code = gs_note_error(gs_error_ioerror);
+ goto exit;
+ }
+ }
+
+ /* If object_length is not 0, then we want to apply a SubFileDecode filter to limit
+ * the number of bytes we read to the declared size of the object (difference between
+ * the offsets of the object we want to read, and the next object). If it is 0 then
+ * we're reading the last object in the stream, so we just rely on the SubFileDecode
+ * we set up when we created compressed_stream to limit the bytes to the length of
+ * that stream.
+ */
+ if (object_length > 0) {
+ code = pdfi_apply_SubFileDecode_filter(ctx, object_length, NULL, compressed_stream, &Object_stream, false);
+ if (code < 0)
+ goto exit;
+ } else {
+ Object_stream = compressed_stream;
+ }
+
+ code = pdfi_read_token(ctx, Object_stream, obj, gen);
+ if (code < 0)
+ goto exit;
+ if (ctx->stack_top[-1]->type == PDF_ARRAY_MARK || ctx->stack_top[-1]->type == PDF_DICT_MARK) {
+ int start_depth = pdfi_count_stack(ctx);
+
+ /* Need to read all the elements from COS objects */
+ do {
+ code = pdfi_read_token(ctx, Object_stream, obj, gen);
+ if (code < 0)
+ goto exit;
+ if (compressed_stream->eof == true) {
+ code = gs_note_error(gs_error_ioerror);
+ goto exit;
+ }
+ }while ((ctx->stack_top[-1]->type != PDF_ARRAY && ctx->stack_top[-1]->type != PDF_DICT) || pdfi_count_stack(ctx) > start_depth);
+ }
+
+ *object = ctx->stack_top[-1];
+ /* For compressed objects we don't get a 'obj gen obj' sequence which is what sets
+ * the object number for uncompressed objects. So we need to do that here.
+ */
+ (*object)->indirect_num = (*object)->object_num = obj;
+ (*object)->indirect_gen = (*object)->generation_num = gen;
+ pdfi_countup(*object);
+ pdfi_pop(ctx, 1);
+
+ code = pdfi_add_to_cache(ctx, *object);
+ if (code < 0) {
+ pdfi_countdown(*object);
+ goto exit;
+ }
+
+ exit:
+ if (Object_stream)
+ pdfi_close_file(ctx, Object_stream);
+ if (Object_stream != compressed_stream)
+ if (compressed_stream)
+ pdfi_close_file(ctx, compressed_stream);
+ if (SubFile_stream)
+ pdfi_close_file(ctx, SubFile_stream);
+ pdfi_countdown(compressed_object);
+ pdfi_countdown(Type);
+ return code;
+}
+
+/* pdf_dereference returns an object with a reference count of at least 1, this represents the
+ * reference being held by the caller (in **object) when we return from this function.
+ */
+int pdfi_dereference(pdf_context *ctx, uint64_t obj, uint64_t gen, pdf_obj **object)
+{
+ xref_entry *entry;
+ int code, stack_depth = pdfi_count_stack(ctx);
+ gs_offset_t saved_stream_offset;
+ bool saved_decrypt_strings = ctx->encryption.decrypt_strings;
+
+ *object = NULL;
+
+ if (ctx->xref_table == NULL)
+ return_error(gs_error_typecheck);
+
+ if (obj >= ctx->xref_table->xref_size) {
+ char extra_info[gp_file_name_sizeof];
+
+ gs_sprintf(extra_info, "Error, attempted to dereference object %"PRIu64", which is not present in the xref table\n", obj);
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADOBJNUMBER, "pdfi_dereference", extra_info);
+
+ if(ctx->args.pdfstoponerror)
+ return_error(gs_error_rangecheck);
+
+ code = pdfi_object_alloc(ctx, PDF_NULL, 0, object);
+ if (code == 0)
+ pdfi_countup(*object);
+ return code;
+ }
+
+ entry = &ctx->xref_table->xref[obj];
+
+ if(entry->object_num == 0)
+ return_error(gs_error_undefined);
+
+ if (entry->free) {
+ char extra_info[gp_file_name_sizeof];
+
+ gs_sprintf(extra_info, "Attempt to dereference free object %"PRIu64", trying next object number as offset.\n", entry->object_num);
+ pdfi_set_error(ctx, 0, NULL, E_PDF_DEREF_FREE_OBJ, "pdfi_dereference", extra_info);
+ }
+
+ if (ctx->loop_detection) {
+ if (pdfi_loop_detector_check_object(ctx, obj) == true)
+ return_error(gs_error_circular_reference);
+ }
+ if (entry->cache != NULL){
+ pdf_obj_cache_entry *cache_entry = entry->cache;
+
+#if CACHE_STATISTICS
+ ctx->hits++;
+#endif
+ *object = cache_entry->o;
+ pdfi_countup(*object);
+
+ pdfi_promote_cache_entry(ctx, cache_entry);
+ } else {
+ saved_stream_offset = pdfi_unread_tell(ctx);
+
+ if (entry->compressed) {
+ /* This is an object in a compressed object stream */
+ ctx->encryption.decrypt_strings = false;
+
+ code = pdfi_deref_compressed(ctx, obj, gen, object, entry);
+ if (code < 0 || *object == NULL)
+ goto error;
+ } else {
+ pdf_c_stream *SubFile_stream = NULL;
+ pdf_string *EODString;
+#if CACHE_STATISTICS
+ ctx->misses++;
+#endif
+ ctx->encryption.decrypt_strings = true;
+
+ code = pdfi_seek(ctx, ctx->main_stream, entry->u.uncompressed.offset, SEEK_SET);
+ if (code < 0)
+ goto error;
+
+ code = pdfi_name_alloc(ctx, (byte *)"trailer", 6, (pdf_obj **)&EODString);
+ if (code < 0)
+ goto error;
+ pdfi_countup(EODString);
+
+ code = pdfi_apply_SubFileDecode_filter(ctx, 0, EODString, ctx->main_stream, &SubFile_stream, false);
+ if (code < 0) {
+ pdfi_countdown(EODString);
+ goto error;
+ }
+
+ code = pdfi_read_object(ctx, SubFile_stream, entry->u.uncompressed.offset);
+
+ pdfi_countdown(EODString);
+ pdfi_close_file(ctx, SubFile_stream);
+ if (code < 0) {
+ int code1 = 0;
+ if (entry->free) {
+ dmprintf2(ctx->memory, "Dereference of free object %"PRIu64", next object number as offset failed (code = %d), returning NULL object.\n", entry->object_num, code);
+ code = pdfi_object_alloc(ctx, PDF_NULL, 1, object);
+ if (code >= 0) {
+ pdfi_countup(*object);
+ goto free_obj;
+ }
+ }
+ ctx->encryption.decrypt_strings = saved_decrypt_strings;
+ (void)pdfi_seek(ctx, ctx->main_stream, saved_stream_offset, SEEK_SET);
+ pdfi_pop(ctx, pdfi_count_stack(ctx) - stack_depth);
+
+ code1 = pdfi_repair_file(ctx);
+ if (code1 == 0)
+ return pdfi_dereference(ctx, obj, gen, object);
+ /* Repair failed, just give up and return an error */
+ return code;
+ }
+
+ if (pdfi_count_stack(ctx) > 0 && (ctx->stack_top[-1])->object_num == obj) {
+ *object = ctx->stack_top[-1];
+ pdfi_countup(*object);
+ pdfi_pop(ctx, 1);
+ code = pdfi_add_to_cache(ctx, *object);
+ if (code < 0) {
+ pdfi_countdown(*object);
+ goto error;
+ }
+ } else {
+ pdfi_pop(ctx, 1);
+ if (entry->free) {
+ dmprintf1(ctx->memory, "Dereference of free object %"PRIu64", next object number as offset failed, returning NULL object.\n", entry->object_num);
+ code = pdfi_object_alloc(ctx, PDF_NULL, 1, object);
+ if (code >= 0)
+ pdfi_countup(*object);
+ return code;
+ }
+ code = gs_note_error(gs_error_undefined);
+ goto error;
+ }
+ }
+free_obj:
+ (void)pdfi_seek(ctx, ctx->main_stream, saved_stream_offset, SEEK_SET);
+ }
+
+ if (ctx->loop_detection && (*object)->object_num != 0) {
+ code = pdfi_loop_detector_add_object(ctx, (*object)->object_num);
+ if (code < 0) {
+ ctx->encryption.decrypt_strings = saved_decrypt_strings;
+ return code;
+ }
+ }
+ ctx->encryption.decrypt_strings = saved_decrypt_strings;
+ return 0;
+
+error:
+ ctx->encryption.decrypt_strings = saved_decrypt_strings;
+ (void)pdfi_seek(ctx, ctx->main_stream, saved_stream_offset, SEEK_SET);
+ /* Return the stack to the state at entry */
+ pdfi_pop(ctx, pdfi_count_stack(ctx) - stack_depth);
+ return code;
+}
+
+/* do a derefence with loop detection */
+int pdfi_deref_loop_detect(pdf_context *ctx, uint64_t obj, uint64_t gen, pdf_obj **object)
+{
+ int code;
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dereference(ctx, obj, gen, object);
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ return code;
+}
+
+
+static int pdfi_resolve_indirect_array(pdf_context *ctx, pdf_obj *obj, bool recurse)
+{
+ int code = 0;
+ uint64_t index, arraysize;
+ pdf_obj *object = NULL;
+ pdf_array *array = (pdf_array *)obj;
+
+ arraysize = pdfi_array_size(array);
+ for (index = 0; index < arraysize; index++) {
+ code = pdfi_array_get_no_store_R(ctx, array, index, &object);
+ if (code == gs_error_circular_reference) {
+ /* Just leave as an indirect ref */
+ code = 0;
+ } else {
+ if (code < 0) goto exit;
+ /* don't store the object if it's a stream (leave as a ref) */
+ if (object->type != PDF_STREAM)
+ code = pdfi_array_put(ctx, array, index, object);
+ if (recurse)
+ code = pdfi_resolve_indirect(ctx, object, recurse);
+ }
+ if (code < 0) goto exit;
+
+ pdfi_countdown(object);
+ object = NULL;
+ }
+
+ exit:
+ pdfi_countdown(object);
+ return code;
+}
+
+static int pdfi_resolve_indirect_dict(pdf_context *ctx, pdf_obj *obj, bool recurse)
+{
+ int code = 0;
+ pdf_dict *dict = (pdf_dict *)obj;
+ pdf_name *Key = NULL;
+ pdf_obj *Value = NULL;
+ uint64_t index, dictsize;
+
+ dictsize = pdfi_dict_entries(dict);
+
+ /* Note: I am not using pdfi_dict_first/next because of needing to handle
+ * circular references.
+ */
+ for (index=0; index<dictsize; index ++) {
+ Key = (pdf_name *)dict->keys[index];
+ code = pdfi_dict_get_no_store_R_key(ctx, dict, Key, &Value);
+ if (code == gs_error_circular_reference) {
+ /* Just leave as an indirect ref */
+ code = 0;
+ } else {
+ if (code < 0) goto exit;
+ /* don't store the object if it's a stream (leave as a ref) */
+ if (Value->type != PDF_STREAM)
+ pdfi_dict_put_obj(ctx, dict, (pdf_obj *)Key, Value);
+ if (recurse)
+ code = pdfi_resolve_indirect(ctx, Value, recurse);
+ }
+ if (code < 0) goto exit;
+
+ pdfi_countdown(Value);
+ Value = NULL;
+ }
+
+ exit:
+ pdfi_countdown(Value);
+ return code;
+}
+
+/* Resolve all the indirect references for an object
+ * Note: This can be recursive
+ */
+int pdfi_resolve_indirect(pdf_context *ctx, pdf_obj *value, bool recurse)
+{
+ int code = 0;
+
+ switch(value->type) {
+ case PDF_ARRAY:
+ code = pdfi_resolve_indirect_array(ctx, value, recurse);
+ break;
+ case PDF_DICT:
+ code = pdfi_resolve_indirect_dict(ctx, value, recurse);
+ break;
+ default:
+ break;
+ }
+ return code;
+}
+
+/* Resolve all the indirect references for an object
+ * Resolve indirect references, either one level or recursively, with loop detect on
+ * the parent (can by NULL) and the value.
+ */
+int pdfi_resolve_indirect_loop_detect(pdf_context *ctx, pdf_obj *parent, pdf_obj *value, bool recurse)
+{
+ int code = 0;
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0) goto exit;
+ if (parent && parent->object_num != 0) {
+ code = pdfi_loop_detector_add_object(ctx, parent->object_num);
+ if (code < 0) goto exit;
+ }
+ if (value->object_num != 0) {
+ code = pdfi_loop_detector_add_object(ctx, value->object_num);
+ if (code < 0) goto exit;
+ }
+ code = pdfi_resolve_indirect(ctx, value, false);
+
+ exit:
+ (void)pdfi_loop_detector_cleartomark(ctx); /* Clear to the mark for the current loop */
+ return code;
+}
diff --git a/pdf/pdf_deref.h b/pdf/pdf_deref.h
new file mode 100644
index 00000000..132be7dd
--- /dev/null
+++ b/pdf/pdf_deref.h
@@ -0,0 +1,26 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+#ifndef PDF_DEREFERENCE
+#define PDF_DEREFERENCE
+
+int replace_cache_entry(pdf_context *ctx, pdf_obj *o);
+int is_compressed_object(pdf_context *ctx, uint32_t obj, uint32_t gen);
+int pdfi_dereference(pdf_context *ctx, uint64_t obj, uint64_t gen, pdf_obj **object);
+int pdfi_deref_loop_detect(pdf_context *ctx, uint64_t obj, uint64_t gen, pdf_obj **object);
+int pdfi_read_bare_object(pdf_context *ctx, pdf_c_stream *s, gs_offset_t stream_offset, uint32_t objnum, uint32_t gen);
+int pdfi_resolve_indirect(pdf_context *ctx, pdf_obj *value, bool recurse);
+int pdfi_resolve_indirect_loop_detect(pdf_context *ctx, pdf_obj *parent, pdf_obj *value, bool recurse);
+#endif
diff --git a/pdf/pdf_device.c b/pdf/pdf_device.c
new file mode 100644
index 00000000..6d7547e2
--- /dev/null
+++ b/pdf/pdf_device.c
@@ -0,0 +1,184 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Routines for dealing with devices */
+
+#include "pdf_int.h"
+#include "pdf_stack.h"
+#include "pdf_device.h"
+#include "gdevvec.h" /* for gs_device_vector */
+#include "gxdevsop.h" /* For special ops : dev_param_req_t */
+
+int pdfi_device_check_param(gx_device *dev, const char *param, gs_c_param_list *list)
+{
+ dev_param_req_t request;
+ int code;
+
+ gs_c_param_list_write(list, dev->memory);
+ /* Stuff the data into a structure for passing to the spec_op */
+ request.Param = (char *)param;
+ request.list = list;
+ code = dev_proc(dev, dev_spec_op)(dev, gxdso_get_dev_param, &request, sizeof(dev_param_req_t));
+ if (code < 0) {
+ gs_c_param_list_release(list);
+ return code;
+ }
+ return 0;
+}
+
+/* Check value of boolean device parameter */
+bool pdfi_device_check_param_bool(gx_device *dev, const char *param)
+{
+ int code;
+ gs_c_param_list list;
+ int value;
+
+ code = pdfi_device_check_param(dev, param, &list);
+ if (code < 0)
+ return false;
+ gs_c_param_list_read(&list);
+ code = param_read_bool((gs_param_list *)&list,
+ param,
+ &value);
+ if (code < 0)
+ value = false;
+ gs_c_param_list_release(&list);
+ return (bool)value;
+}
+
+/* Set value of string device parameter */
+int pdfi_device_set_param_string(gx_device *dev, const char *paramname, const char *value)
+{
+ int code;
+ gs_c_param_list list;
+ gs_param_string paramstring;
+
+ paramstring.data = (byte *)value;
+ paramstring.size = strlen(value);
+ paramstring.persistent = 0;
+
+ gs_c_param_list_write(&list, dev->memory);
+
+ gs_param_list_set_persistent_keys((gs_param_list *) &list, false);
+ code = param_write_string((gs_param_list *)&list, paramname, &paramstring);
+ if (code < 0) goto exit;
+ gs_c_param_list_read(&list);
+ code = gs_putdeviceparams(dev, (gs_param_list *)&list);
+
+ exit:
+ gs_c_param_list_release(&list);
+ return code;
+}
+
+/* Set value of boolean device parameter */
+int pdfi_device_set_param_bool(gx_device *dev, const char *param, bool value)
+{
+ int code;
+ gs_c_param_list list;
+ bool paramval = value;
+
+ gs_c_param_list_write(&list, dev->memory);
+
+ code = param_write_bool((gs_param_list *)&list, param, &paramval);
+ if (code < 0) goto exit;
+ gs_c_param_list_read(&list);
+ code = gs_putdeviceparams(dev, (gs_param_list *)&list);
+
+ exit:
+ gs_c_param_list_release(&list);
+ return code;
+}
+
+/* Checks whether a parameter exists for the device */
+bool pdfi_device_check_param_exists(gx_device *dev, const char *param)
+{
+ int code;
+ gs_c_param_list list;
+
+ code = pdfi_device_check_param(dev, param, &list);
+ if (code < 0)
+ return false;
+ gs_c_param_list_release(&list);
+ return true;
+}
+
+/* Config some device-related variables */
+void pdfi_device_set_flags(pdf_context *ctx)
+{
+ bool has_pdfmark;
+ bool has_ForOPDFRead;
+ gx_device *dev = ctx->pgs->device;
+
+ has_pdfmark = pdfi_device_check_param_exists(dev, "pdfmark");
+ has_ForOPDFRead = pdfi_device_check_param_bool(dev, "ForOPDFRead");
+
+ /* Cache these so they don't have to constantly be calculated */
+ ctx->device_state.writepdfmarks = has_pdfmark || ctx->args.dopdfmarks;
+ ctx->device_state.annotations_preserved = ctx->device_state.writepdfmarks && !has_ForOPDFRead;
+
+ /* PreserveTrMode is for pdfwrite device */
+ ctx->device_state.preserve_tr_mode = pdfi_device_check_param_bool(dev, "PreserveTrMode");
+ ctx->device_state.preserve_smask = pdfi_device_check_param_bool(dev, "PreserveSMask");
+ ctx->device_state.HighLevelDevice = pdfi_device_check_param_bool(dev, "HighLevelDevice");
+
+ /* See if it is a DeviceN (spot capable) */
+ ctx->device_state.spot_capable = dev_proc(dev, dev_spec_op)(dev, gxdso_supports_devn, NULL, 0);
+
+ /* If multi-page output, can't do certain pdfmarks */
+ if (ctx->device_state.writepdfmarks) {
+ if (gx_outputfile_is_separate_pages(((gx_device_vector *)dev)->fname, dev->memory)) {
+ ctx->args.no_pdfmark_outlines = true;
+ ctx->args.no_pdfmark_dests = true;
+ }
+ }
+
+#if DEBUG_DEVICE
+ dbgmprintf2(ctx->memory, "Device writepdfmarks=%s, annotations_preserved=%s\n",
+ ctx->writepdfmarks ? "TRUE" : "FALSE",
+ ctx->annotations_preserved ? "TRUE" : "FALSE");
+#endif
+}
+
+/* Config the output device
+ * This will configure any special device parameters.
+ * Right now it just sets up some stuff for pdfwrite.
+ */
+int pdfi_device_misc_config(pdf_context *ctx)
+{
+ bool has_pdfmark = false;
+ int code;
+ gx_device *dev = ctx->pgs->device;
+
+ if (ctx->args.first_page != 0 || ctx->args.last_page != 0) {
+ code = pdfi_device_set_param_bool(dev, "DisablePageHandler", true);
+ if (code < 0) goto exit;
+ }
+
+ /* I am using pdfmark to identify the pdfwrite device */
+ has_pdfmark = pdfi_device_check_param_bool(dev, "pdfmark");
+ /* (only handling pdfwrite for now) */
+ if (!has_pdfmark)
+ return 0;
+
+ /* TODO: I think the pdfwrite device should have these automatically set to true,
+ * but that doesn't seem to be the case now.
+ * See pdf_document_metadata()
+ */
+ code = pdfi_device_set_param_string(dev, "AutoRotatePages", "PageByPage");
+ if (code < 0) goto exit;
+
+exit:
+ return code;
+}
diff --git a/pdf/pdf_device.h b/pdf/pdf_device.h
new file mode 100644
index 00000000..ca9965a7
--- /dev/null
+++ b/pdf/pdf_device.h
@@ -0,0 +1,27 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+#ifndef PDF_DEVICE
+#define PDF_DEVICE
+
+int pdfi_device_check_param(gx_device *dev, const char *param, gs_c_param_list *list);
+bool pdfi_device_check_param_bool(gx_device *dev, const char *param);
+bool pdfi_device_check_param_exists(gx_device *dev, const char *param);
+int pdfi_device_set_param_string(gx_device *dev, const char *paramname, const char *value);
+int pdfi_device_set_param_bool(gx_device *dev, const char *param, bool value);
+void pdfi_device_set_flags(pdf_context *ctx);
+int pdfi_device_misc_config(pdf_context *ctx);
+
+#endif
diff --git a/pdf/pdf_dict.c b/pdf/pdf_dict.c
new file mode 100644
index 00000000..4b65404e
--- /dev/null
+++ b/pdf/pdf_dict.c
@@ -0,0 +1,1157 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* dictionary handling for the PDF interpreter */
+#include "ghostpdf.h"
+#include "pdf_types.h"
+#include "pdf_deref.h"
+#include "pdf_dict.h"
+#include "pdf_stack.h"
+#include "pdf_array.h"
+#include "pdf_int.h"
+#include "pdf_loop_detect.h"
+#include "pdf_misc.h"
+
+void pdfi_free_dict(pdf_obj *o)
+{
+ pdf_dict *d = (pdf_dict *)o;
+ int i;
+#if DEBUG_DICT
+ pdf_name *name;
+#endif
+
+ for (i=0;i < d->entries;i++) {
+#if DEBUG_DICT
+ name = (pdf_name *)d->keys[i];
+#endif
+ if (d->values[i] != NULL)
+ pdfi_countdown(d->values[i]);
+ if (d->keys[i] != NULL)
+ pdfi_countdown(d->keys[i]);
+ }
+ gs_free_object(OBJ_MEMORY(d), d->keys, "pdf interpreter free dictionary keys");
+ gs_free_object(OBJ_MEMORY(d), d->values, "pdf interpreter free dictioanry values");
+ gs_free_object(OBJ_MEMORY(d), d, "pdf interpreter free dictionary");
+}
+
+/* Delete a key pair, either by specifying a char * or a pdf_name *
+ */
+static int pdfi_dict_delete_inner(pdf_context *ctx, pdf_dict *d, pdf_name *n, const char *str)
+{
+ int i = 0;
+#if DEBUG_DICT
+ pdf_name *name;
+#endif
+
+ for (i=0;i < d->entries;i++) {
+#if DEBUG_DICT
+ name = (pdf_name *)d->keys[i];
+#endif
+ if (n != NULL) {
+ if (pdfi_name_cmp(n, (pdf_name *)d->keys[i]) == 0)
+ break;
+ } else {
+ if (pdfi_name_is((pdf_name *)d->keys[i], str))
+ break;
+ }
+
+ }
+ if (i >= d->entries)
+ return_error(gs_error_undefined);
+
+ pdfi_countdown(d->keys[i]);
+ pdfi_countdown(d->values[i]);
+ for( ;i < d->entries - 1;i++) {
+ d->keys[i] = d->keys[i + 1];
+ d->values[i] = d->values[i + 1];
+ }
+ d->keys[i] = NULL;
+ d->values[i] = NULL;
+ d->entries--;
+ return 0;
+}
+
+int pdfi_dict_delete_pair(pdf_context *ctx, pdf_dict *d, pdf_name *n)
+{
+ return pdfi_dict_delete_inner(ctx, d, n, NULL);
+}
+
+int pdfi_dict_delete(pdf_context *ctx, pdf_dict *d, const char *str)
+{
+ return pdfi_dict_delete_inner(ctx, d, NULL, str);
+}
+
+/* This function is provided for symmetry with arrays, and in case we ever
+ * want to change the behaviour of pdfi_dict_from_stack() and pdfi_dict_alloc()
+ * similarly to the array behaviour, where we always have null PDF objects
+ * rather than NULL pointers stored in the dictionary.
+ */
+int pdfi_dict_alloc(pdf_context *ctx, uint64_t size, pdf_dict **d)
+{
+ *d = NULL;
+ return pdfi_object_alloc(ctx, PDF_DICT, size, (pdf_obj **)d);
+}
+
+int pdfi_dict_from_stack(pdf_context *ctx, uint32_t indirect_num, uint32_t indirect_gen)
+{
+ uint64_t index = 0;
+ pdf_dict *d = NULL;
+ uint64_t i = 0;
+ int code;
+#if DEBUG_DICT
+ pdf_name *key;
+#endif
+
+ code = pdfi_count_to_mark(ctx, &index);
+ if (code < 0) {
+ pdfi_clear_to_mark(ctx);
+ return code;
+ }
+
+ if (index & 1) {
+ pdfi_clear_to_mark(ctx);
+ return_error(gs_error_rangecheck);
+ }
+
+ code = pdfi_dict_alloc(ctx, index >> 1, &d);
+ if (code < 0) {
+ pdfi_clear_to_mark(ctx);
+ return code;
+ }
+
+ d->entries = d->size;
+
+ while (index) {
+ i = (index / 2) - 1;
+
+ /* In PDF keys are *required* to be names, so we ought to check that here */
+ if (((pdf_obj *)ctx->stack_top[-2])->type == PDF_NAME) {
+ d->keys[i] = ctx->stack_top[-2];
+ pdfi_countup(d->keys[i]);
+#if DEBUG_DICT
+ key = (pdf_name *)d->keys[i];
+#endif
+ d->values[i] = ctx->stack_top[-1];
+ pdfi_countup(d->values[i]);
+ } else {
+ pdfi_free_dict((pdf_obj *)d);
+ pdfi_clear_to_mark(ctx);
+ return_error(gs_error_typecheck);
+ }
+
+ pdfi_pop(ctx, 2);
+ index -= 2;
+ }
+
+ code = pdfi_clear_to_mark(ctx);
+ if (code < 0) {
+ pdfi_free_dict((pdf_obj *)d);
+ return code;
+ }
+
+ if (ctx->args.pdfdebug)
+ dmprintf (ctx->memory, "\n >>\n");
+
+ d->indirect_num = indirect_num;
+ d->indirect_gen = indirect_gen;
+
+ code = pdfi_push(ctx, (pdf_obj *)d);
+ if (code < 0)
+ pdfi_free_dict((pdf_obj *)d);
+
+ return code;
+}
+
+/* Convenience routine for common case where there are two possible keys */
+int
+pdfi_dict_get2(pdf_context *ctx, pdf_dict *d, const char *Key1,
+ const char *Key2, pdf_obj **o)
+{
+ int code;
+
+ code = pdfi_dict_get(ctx, d, Key1, o);
+ if (code == gs_error_undefined)
+ code = pdfi_dict_get(ctx, d, Key2, o);
+ return code;
+}
+
+/* The object returned by pdfi_dict_get has its reference count incremented by 1 to
+ * indicate the reference now held by the caller, in **o.
+ */
+int pdfi_dict_get(pdf_context *ctx, pdf_dict *d, const char *Key, pdf_obj **o)
+{
+ int i=0, code;
+ pdf_name *t;
+
+ *o = NULL;
+
+ if (d->type != PDF_DICT)
+ return_error(gs_error_typecheck);
+
+ for (i=0;i< d->entries;i++) {
+ t = (pdf_name *)d->keys[i];
+
+ if (t && t->type == PDF_NAME) {
+ if (pdfi_name_is((pdf_name *)t, Key)) {
+ if (d->values[i]->type == PDF_INDIRECT) {
+ pdf_indirect_ref *r = (pdf_indirect_ref *)d->values[i];
+
+ code = pdfi_deref_loop_detect(ctx, r->ref_object_num, r->ref_generation_num, o);
+ if (code < 0)
+ return code;
+ pdfi_countdown(d->values[i]);
+ d->values[i] = *o;
+ }
+ *o = d->values[i];
+ pdfi_countup(*o);
+ return 0;
+ }
+ }
+ }
+ return_error(gs_error_undefined);
+}
+
+/* Get object from dict without resolving indirect references
+ * Will inc refcnt by 1
+ */
+int pdfi_dict_get_no_deref(pdf_context *ctx, pdf_dict *d, const pdf_name *Key, pdf_obj **o)
+{
+ int i=0;
+ pdf_name *t;
+
+ *o = NULL;
+
+ if (d->type != PDF_DICT)
+ return_error(gs_error_typecheck);
+
+ for (i=0;i< d->entries;i++) {
+ t = (pdf_name *)d->keys[i];
+
+ if (t && t->type == PDF_NAME) {
+ if (pdfi_name_cmp((pdf_name *)t, Key)== 0) {
+ *o = d->values[i];
+ pdfi_countup(*o);
+ return 0;
+ }
+ }
+ }
+ return_error(gs_error_undefined);
+}
+
+/* Get by pdf_name rather than by char *
+ * The object returned by pdfi_dict_get has its reference count incremented by 1 to
+ * indicate the reference now held by the caller, in **o.
+ */
+int pdfi_dict_get_by_key(pdf_context *ctx, pdf_dict *d, const pdf_name *Key, pdf_obj **o)
+{
+ int i=0, code;
+ pdf_name *t;
+
+ *o = NULL;
+
+ if (d->type != PDF_DICT)
+ return_error(gs_error_typecheck);
+
+ for (i=0;i< d->entries;i++) {
+ t = (pdf_name *)d->keys[i];
+
+ if (t && t->type == PDF_NAME) {
+ if (pdfi_name_cmp((pdf_name *)t, Key)== 0) {
+ if (d->values[i]->type == PDF_INDIRECT) {
+ pdf_indirect_ref *r = (pdf_indirect_ref *)d->values[i];
+
+ code = pdfi_deref_loop_detect(ctx, r->ref_object_num, r->ref_generation_num, o);
+ if (code < 0)
+ return code;
+ pdfi_countdown(d->values[i]);
+ d->values[i] = *o;
+ }
+ *o = d->values[i];
+ pdfi_countup(*o);
+ return 0;
+ }
+ }
+ }
+ return_error(gs_error_undefined);
+}
+
+/* Get indirect reference without de-referencing it */
+int pdfi_dict_get_ref(pdf_context *ctx, pdf_dict *d, const char *Key, pdf_indirect_ref **o)
+{
+ int i=0;
+ pdf_name *t;
+
+ *o = NULL;
+
+ if (d->type != PDF_DICT)
+ return_error(gs_error_typecheck);
+
+ for (i=0;i< d->entries;i++) {
+ t = (pdf_name *)d->keys[i];
+
+ if (t && t->type == PDF_NAME) {
+ if (pdfi_name_is((pdf_name *)t, Key)) {
+ if (d->values[i]->type == PDF_INDIRECT) {
+ *o = (pdf_indirect_ref *)d->values[i];
+ pdfi_countup(*o);
+ return 0;
+ } else {
+ return_error(gs_error_typecheck);
+ }
+ }
+ }
+ }
+ return_error(gs_error_undefined);
+}
+
+/* As per pdfi_dict_get(), but doesn't replace an indirect reference in a dictionary with a
+ * new object. This is for Resources following, such as Do, where we will have to seek and
+ * read the indirect object anyway, and we need to ensure that Form XObjects (for example)
+ * don't have circular calls.
+ *
+ * Takes either strKey or nameKey param. Other will be NULL.
+ */
+static int pdfi_dict_get_no_store_R_inner(pdf_context *ctx, pdf_dict *d, const char *strKey,
+ const pdf_name *nameKey, pdf_obj **o)
+{
+ int i=0, code;
+ pdf_name *t;
+ bool match = false;
+
+ *o = NULL;
+
+ if (d->type != PDF_DICT)
+ return_error(gs_error_typecheck);
+
+ for (i=0;i< d->entries;i++) {
+ t = (pdf_name *)d->keys[i];
+
+ if (t && t->type == PDF_NAME) {
+ if (strKey != NULL) {
+ if (pdfi_name_is(t, strKey))
+ match = true;
+ } else {
+ if (!pdfi_name_cmp(t, nameKey))
+ match = true;
+ }
+ if (match) {
+ if (d->values[i]->type == PDF_INDIRECT) {
+ pdf_indirect_ref *r = (pdf_indirect_ref *)d->values[i];
+
+ code = pdfi_dereference(ctx, r->ref_object_num, r->ref_generation_num, o);
+ if (code < 0)
+ return code;
+ } else {
+ *o = d->values[i];
+ pdfi_countup(*o);
+ }
+ return 0;
+ }
+ }
+ }
+ return_error(gs_error_undefined);
+}
+
+/* Wrapper to pdfi_dict_no_store_R_inner(), takes a char * as Key */
+int pdfi_dict_get_no_store_R(pdf_context *ctx, pdf_dict *d, const char *Key, pdf_obj **o)
+{
+ return pdfi_dict_get_no_store_R_inner(ctx, d, Key, NULL, o);
+}
+
+/* Wrapper to pdfi_dict_no_store_R_inner(), takes a pdf_name * as Key */
+int pdfi_dict_get_no_store_R_key(pdf_context *ctx, pdf_dict *d, const pdf_name *Key, pdf_obj **o)
+{
+ return pdfi_dict_get_no_store_R_inner(ctx, d, NULL, Key, o);
+}
+
+/* Convenience routine for common case where there are two possible keys */
+int
+pdfi_dict_get_type2(pdf_context *ctx, pdf_dict *d, const char *Key1, const char *Key2, pdf_obj_type type, pdf_obj **o)
+{
+ int code;
+
+ code = pdfi_dict_get_type(ctx, d, Key1, type, o);
+ if (code == gs_error_undefined)
+ code = pdfi_dict_get_type(ctx, d, Key2, type, o);
+ return code;
+}
+
+int pdfi_dict_get_type(pdf_context *ctx, pdf_dict *d, const char *Key, pdf_obj_type type, pdf_obj **o)
+{
+ int code;
+
+ code = pdfi_dict_get(ctx, d, Key, o);
+ if (code < 0)
+ return code;
+
+ if ((*o)->type != type) {
+ pdfi_countdown(*o);
+ *o = NULL;
+ return_error(gs_error_typecheck);
+ }
+ return 0;
+}
+
+/* Convenience routine for common case where value has two possible keys */
+int
+pdfi_dict_get_int2(pdf_context *ctx, pdf_dict *d, const char *Key1,
+ const char *Key2, int64_t *i)
+{
+ int code;
+
+ code = pdfi_dict_get_int(ctx, d, Key1, i);
+ if (code == gs_error_undefined)
+ code = pdfi_dict_get_int(ctx, d, Key2, i);
+ return code;
+}
+
+int pdfi_dict_get_int(pdf_context *ctx, pdf_dict *d, const char *Key, int64_t *i)
+{
+ int code;
+ pdf_num *n;
+
+ code = pdfi_dict_get_type(ctx, d, Key, PDF_INT, (pdf_obj **)&n);
+ if (code < 0)
+ return code;
+
+ *i = n->value.i;
+ pdfi_countdown(n);
+ return 0;
+}
+
+/* Get an int from dict, and if undefined, return provided default */
+int pdfi_dict_get_int_def(pdf_context *ctx, pdf_dict *d, const char *Key, int64_t *i,
+ int64_t def_val)
+{
+ int code;
+
+ code = pdfi_dict_get_int(ctx, d, Key, i);
+ if (code == gs_error_undefined) {
+ *i = def_val;
+ code = 0;
+ }
+
+ return code;
+}
+
+/* Convenience routine for common case where value has two possible keys */
+int
+pdfi_dict_get_bool2(pdf_context *ctx, pdf_dict *d, const char *Key1,
+ const char *Key2, bool *val)
+{
+ int code;
+
+ code = pdfi_dict_get_bool(ctx, d, Key1, val);
+ if (code == gs_error_undefined)
+ code = pdfi_dict_get_bool(ctx, d, Key2, val);
+ return code;
+}
+
+int pdfi_dict_get_bool(pdf_context *ctx, pdf_dict *d, const char *Key, bool *val)
+{
+ int code;
+ pdf_bool *b;
+
+ code = pdfi_dict_get_type(ctx, d, Key, PDF_BOOL, (pdf_obj **)&b);
+ if (code < 0)
+ return code;
+
+ *val = b->value;
+ pdfi_countdown(b);
+ return 0;
+}
+
+int pdfi_dict_get_number2(pdf_context *ctx, pdf_dict *d, const char *Key1, const char *Key2, double *f)
+{
+ int code;
+
+ code = pdfi_dict_get_number(ctx, d, Key1, f);
+ if (code == gs_error_undefined)
+ code = pdfi_dict_get_number(ctx, d, Key2, f);
+ return code;
+}
+
+int pdfi_dict_get_number(pdf_context *ctx, pdf_dict *d, const char *Key, double *f)
+{
+ int code;
+ pdf_num *o;
+
+ code = pdfi_dict_get(ctx, d, Key, (pdf_obj **)&o);
+ if (code < 0)
+ return code;
+ if (o->type == PDF_INT) {
+ *f = (double)(o->value.i);
+ } else {
+ if (o->type == PDF_REAL){
+ *f = o->value.d;
+ } else {
+ pdfi_countdown(o);
+ return_error(gs_error_typecheck);
+ }
+ }
+ pdfi_countdown(o);
+ return 0;
+}
+
+/* convenience functions for retrieving arrys, see shadings and functions */
+
+/* The 'fill' versions fill existing arrays, and need a size,
+ * the 'make' versions allocate memory and fill it. Both varieties return the
+ * number of entries on success. The fill Matrix utility expects to always
+ * receive 6 values. The Domain function expects to receive an even number of
+ * entries and each pair must have the second element larger than the first.
+ */
+int fill_domain_from_dict(pdf_context *ctx, float *parray, int size, pdf_dict *dict)
+{
+ int code, i;
+ pdf_array *a = NULL;
+ double f;
+ uint64_t array_size;
+
+ code = pdfi_dict_get(ctx, dict, "Domain", (pdf_obj **)&a);
+ if (code < 0)
+ return code;
+ if (a->type != PDF_ARRAY) {
+ pdfi_countdown(a);
+ return_error(gs_error_typecheck);
+ }
+ array_size = pdfi_array_size(a);
+ if (array_size & 1 || array_size > size) {
+ pdfi_countdown(a);
+ return_error(gs_error_rangecheck);
+ }
+
+ for (i=0;i< array_size;i++) {
+ code = pdfi_array_get_number(ctx, a, (uint64_t)i, &f);
+ if (code < 0) {
+ pdfi_countdown(a);
+ return_error(code);
+ }
+ parray[i] = (float)f;
+ }
+ pdfi_countdown(a);
+ return array_size;
+}
+
+int fill_float_array_from_dict(pdf_context *ctx, float *parray, int size, pdf_dict *dict, const char *Key)
+{
+ int code, i;
+ pdf_array *a = NULL;
+ double f;
+ uint64_t array_size;
+
+ code = pdfi_dict_get(ctx, dict, Key, (pdf_obj **)&a);
+ if (code < 0)
+ return code;
+ if (a->type != PDF_ARRAY) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+ array_size = pdfi_array_size(a);
+ if (array_size > size) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+
+ for (i=0; i< array_size; i++) {
+ code = pdfi_array_get_number(ctx, a, (uint64_t)i, &f);
+ if (code < 0)
+ goto exit;
+ parray[i] = (float)f;
+ }
+ code = array_size;
+ exit:
+ pdfi_countdown(a);
+ return code;
+}
+
+int fill_bool_array_from_dict(pdf_context *ctx, bool *parray, int size, pdf_dict *dict, const char *Key)
+{
+ int code, i;
+ pdf_array *a = NULL;
+ pdf_bool *o;
+ uint64_t array_size;
+
+ code = pdfi_dict_get(ctx, dict, Key, (pdf_obj **)&a);
+ if (code < 0)
+ return code;
+ if (a->type != PDF_ARRAY) {
+ pdfi_countdown(a);
+ return_error(gs_error_typecheck);
+ }
+ array_size = pdfi_array_size(a);
+ if (array_size > size)
+ return_error(gs_error_rangecheck);
+
+ for (i=0;i< array_size;i++) {
+ code = pdfi_array_get_type(ctx, a, (uint64_t)i, PDF_BOOL, (pdf_obj **)&o);
+ if (code < 0) {
+ pdfi_countdown(a);
+ return_error(code);
+ }
+ parray[i] = o->value;
+ pdfi_countdown(o);
+ }
+ pdfi_countdown(a);
+ return array_size;
+}
+
+int fill_matrix_from_dict(pdf_context *ctx, float *parray, pdf_dict *dict)
+{
+ int code, i;
+ pdf_array *a = NULL;
+ double f;
+ uint64_t array_size;
+
+ code = pdfi_dict_get(ctx, dict, "Matrix", (pdf_obj **)&a);
+ if (code < 0)
+ return code;
+ if (a->type != PDF_ARRAY) {
+ pdfi_countdown(a);
+ return_error(gs_error_typecheck);
+ }
+ array_size = pdfi_array_size(a);
+ if (array_size != 6) {
+ pdfi_countdown(a);
+ return_error(gs_error_rangecheck);
+ }
+
+ for (i=0; i< array_size; i++) {
+ code = pdfi_array_get_number(ctx, a, (uint64_t)i, &f);
+ if (code < 0) {
+ pdfi_countdown(a);
+ return_error(code);
+ }
+ parray[i] = (float)f;
+ }
+ pdfi_countdown(a);
+ return array_size;
+}
+
+/* Returns < 0 for error or the number of entries allocated */
+int pdfi_make_float_array_from_dict(pdf_context *ctx, float **parray, pdf_dict *dict, const char *Key)
+{
+ int code, i;
+ pdf_array *a = NULL;
+ float *arr = NULL;
+ double f;
+ uint64_t array_size;
+
+ *parray = NULL;
+
+ code = pdfi_dict_get(ctx, dict, Key, (pdf_obj **)&a);
+ if (code < 0)
+ return code;
+ if (a->type != PDF_ARRAY) {
+ pdfi_countdown(a);
+ return_error(gs_error_typecheck);
+ }
+ array_size = pdfi_array_size(a);
+
+ arr = (float *)gs_alloc_byte_array(ctx->memory, array_size,
+ sizeof(float), "array_from_dict_key");
+ *parray = arr;
+
+ for (i=0;i< array_size;i++) {
+ code = pdfi_array_get_number(ctx, a, (uint64_t)i, &f);
+ if (code < 0) {
+ gs_free_const_object(ctx->memory, arr, "float_array");
+ *parray = NULL;
+ pdfi_countdown(a);
+ return_error(code);
+ }
+ (*parray)[i] = (float)f;
+ }
+ pdfi_countdown(a);
+ return array_size;
+}
+
+int pdfi_make_int_array_from_dict(pdf_context *ctx, int **parray, pdf_dict *dict, const char *Key)
+{
+ int code, i;
+ pdf_array *a = NULL;
+ int *arr = NULL;
+ pdf_num *o;
+ uint64_t array_size;
+
+ *parray = NULL;
+
+ code = pdfi_dict_get(ctx, dict, Key, (pdf_obj **)&a);
+ if (code < 0)
+ return code;
+ if (a->type != PDF_ARRAY) {
+ pdfi_countdown(a);
+ return_error(gs_error_typecheck);
+ }
+ array_size = pdfi_array_size(a);
+ arr = (int *)gs_alloc_byte_array(ctx->memory, array_size,
+ sizeof(int), "array_from_dict_key");
+ *parray = arr;
+
+ for (i=0;i< array_size;i++) {
+ code = pdfi_array_get_type(ctx, a, (uint64_t)i, PDF_INT, (pdf_obj **)&o);
+ if (code < 0) {
+ gs_free_const_object(ctx->memory, arr, "int_array");
+ *parray = NULL;
+ pdfi_countdown(a);
+ return_error(code);
+ }
+ (*parray)[i] = (int)o->value.i;
+ pdfi_countdown(o);
+ }
+ pdfi_countdown(a);
+ return array_size;
+}
+
+/* Put into dictionary with key as object */
+int pdfi_dict_put_obj(pdf_context *ctx, pdf_dict *d, pdf_obj *Key, pdf_obj *value)
+{
+ uint64_t i;
+ pdf_obj **new_keys, **new_values;
+ pdf_name *n;
+
+ if (d->type != PDF_DICT)
+ return_error(gs_error_typecheck);
+
+ if (Key->type != PDF_NAME)
+ return_error(gs_error_typecheck);
+
+ /* First, do we have a Key/value pair already ? */
+ for (i=0;i< d->entries;i++) {
+ n = (pdf_name *)d->keys[i];
+ if (n && n->type == PDF_NAME) {
+ if (pdfi_name_cmp((pdf_name *)Key, n) == 0) {
+ if (d->values[i] == value)
+ /* We already have this value stored with this key.... */
+ return 0;
+ pdfi_countdown(d->values[i]);
+ d->values[i] = value;
+ pdfi_countup(value);
+ return 0;
+ }
+ }
+ }
+
+ /* Nope, its a new Key */
+ if (d->size > d->entries) {
+ /* We have a hole, find and use it */
+ for (i=0;i< d->size;i++) {
+ if (d->keys[i] == NULL) {
+ d->keys[i] = Key;
+ pdfi_countup(Key);
+ d->values[i] = value;
+ pdfi_countup(value);
+ d->entries++;
+ return 0;
+ }
+ }
+ }
+
+ new_keys = (pdf_obj **)gs_alloc_bytes(ctx->memory, (d->size + 1) * sizeof(pdf_obj *), "pdfi_dict_put reallocate dictionary keys");
+ new_values = (pdf_obj **)gs_alloc_bytes(ctx->memory, (d->size + 1) * sizeof(pdf_obj *), "pdfi_dict_put reallocate dictionary values");
+ if (new_keys == NULL || new_values == NULL){
+ gs_free_object(ctx->memory, new_keys, "pdfi_dict_put memory allocation failure");
+ gs_free_object(ctx->memory, new_values, "pdfi_dict_put memory allocation failure");
+ return_error(gs_error_VMerror);
+ }
+ memcpy(new_keys, d->keys, d->size * sizeof(pdf_obj *));
+ memcpy(new_values, d->values, d->size * sizeof(pdf_obj *));
+
+ gs_free_object(ctx->memory, d->keys, "pdfi_dict_put key reallocation");
+ gs_free_object(ctx->memory, d->values, "pdfi_dict_put value reallocation");
+
+ d->keys = new_keys;
+ d->values = new_values;
+
+ d->keys[d->size] = Key;
+ d->values[d->size] = value;
+ d->size++;
+ d->entries++;
+ pdfi_countup(Key);
+ pdfi_countup(value);
+
+ return 0;
+}
+
+/* Put into dictionary with key as string */
+int pdfi_dict_put(pdf_context *ctx, pdf_dict *d, const char *Key, pdf_obj *value)
+{
+ int code;
+ pdf_obj *key = NULL;
+
+ code = pdfi_name_alloc(ctx, (byte *)Key, strlen(Key), &key);
+ if (code < 0)
+ return code;
+ pdfi_countup(key);
+
+ code = pdfi_dict_put_obj(ctx, d, key, value);
+ pdfi_countdown(key); /* get rid of extra ref */
+ return code;
+}
+
+int pdfi_dict_put_int(pdf_context *ctx, pdf_dict *d, const char *key, int64_t value)
+{
+ int code;
+ pdf_num *obj;
+
+ code = pdfi_object_alloc(ctx, PDF_INT, 0, (pdf_obj **)&obj);
+ obj->value.i = value;
+ if (code < 0)
+ return code;
+
+ return pdfi_dict_put(ctx, d, key, (pdf_obj *)obj);
+}
+
+int pdfi_dict_put_bool(pdf_context *ctx, pdf_dict *d, const char *key, bool value)
+{
+ int code;
+ pdf_bool *obj = NULL;
+
+ code = pdfi_object_alloc(ctx, PDF_BOOL, 0, (pdf_obj **)&obj);
+ if (code < 0)
+ return code;
+
+ obj->value = value;
+ return pdfi_dict_put(ctx, d, key, (pdf_obj *)obj);
+}
+
+int pdfi_dict_put_name(pdf_context *ctx, pdf_dict *d, const char *key, const char *name)
+{
+ int code;
+ pdf_obj *obj = NULL;
+
+ code = pdfi_name_alloc(ctx, (byte *)name, strlen(name), &obj);
+ if (code < 0)
+ return code;
+ pdfi_countup(obj);
+
+ code = pdfi_dict_put(ctx, d, key, obj);
+ pdfi_countdown(obj); /* get rid of extra ref */
+ return code;
+}
+
+int pdfi_dict_copy(pdf_context *ctx, pdf_dict *target, pdf_dict *source)
+{
+ int i=0, code = 0;
+
+ for (i=0;i< source->entries;i++) {
+ code = pdfi_dict_put_obj(ctx, target, source->keys[i], source->values[i]);
+ if (code < 0)
+ return code;
+ }
+ return 0;
+}
+
+int pdfi_dict_known(pdf_context *ctx, pdf_dict *d, const char *Key, bool *known)
+{
+ int i;
+ pdf_name *t;
+
+ if (d->type != PDF_DICT)
+ return_error(gs_error_typecheck);
+
+ *known = false;
+ for (i=0;i< d->entries;i++) {
+ t = (pdf_name *)d->keys[i];
+
+ if (t && t->type == PDF_NAME) {
+ if (pdfi_name_is(t, Key)) {
+ *known = true;
+ break;
+ }
+ }
+ }
+ return 0;
+}
+
+/* Tests if a Key is present in the dictionary, if it is, retrieves the value associted with the
+ * key. Returns < 0 for error, 0 if the key is not found > 0 if the key is present, and initialises
+ * the value in the arguments. Since this uses pdf_dict_get(), the returned value has its
+ * reference count incremented by 1, just like pdfi_dict_get().
+ */
+int pdfi_dict_knownget(pdf_context *ctx, pdf_dict *d, const char *Key, pdf_obj **o)
+{
+ bool known = false;
+ int code;
+
+ code = pdfi_dict_known(ctx, d, Key, &known);
+ if (code < 0)
+ return code;
+
+ if (known == false)
+ return 0;
+
+ code = pdfi_dict_get(ctx, d, Key, o);
+ if (code < 0)
+ return code;
+
+ return 1;
+}
+
+/* Like pdfi_dict_knownget() but allows the user to specify a type for the object that we get.
+ * returns < 0 for error (including typecheck if the object is not the requested type)
+ * 0 if the key is not found, or > 0 if the key was found and returned.
+ */
+int pdfi_dict_knownget_type(pdf_context *ctx, pdf_dict *d, const char *Key, pdf_obj_type type, pdf_obj **o)
+{
+ bool known = false;
+ int code;
+
+ code = pdfi_dict_known(ctx, d, Key, &known);
+ if (code < 0)
+ return code;
+
+ if (known == false)
+ return 0;
+
+ code = pdfi_dict_get_type(ctx, d, Key, type, o);
+ if (code < 0)
+ return code;
+
+ return 1;
+}
+
+/* Like pdfi_dict_knownget_type() but retrieves numbers (two possible types)
+ */
+int pdfi_dict_knownget_number(pdf_context *ctx, pdf_dict *d, const char *Key, double *f)
+{
+ bool known = false;
+ int code;
+
+ code = pdfi_dict_known(ctx, d, Key, &known);
+ if (code < 0)
+ return code;
+
+ if (known == false)
+ return 0;
+
+ code = pdfi_dict_get_number(ctx, d, Key, f);
+ if (code < 0)
+ return code;
+
+ return 1;
+}
+
+int pdfi_dict_known_by_key(pdf_context *ctx, pdf_dict *d, pdf_name *Key, bool *known)
+{
+ int i;
+ pdf_obj *t;
+
+ if (d->type != PDF_DICT)
+ return_error(gs_error_typecheck);
+
+ *known = false;
+ for (i=0;i< d->entries;i++) {
+ t = d->keys[i];
+
+ if (t && t->type == PDF_NAME) {
+ if (pdfi_name_cmp((pdf_name *)t, Key) == 0) {
+ *known = true;
+ break;
+ }
+ }
+ }
+ return 0;
+}
+
+int pdfi_dict_next(pdf_context *ctx, pdf_dict *d, pdf_obj **Key, pdf_obj **Value, uint64_t *index)
+{
+ int code;
+
+ if (d->type != PDF_DICT)
+ return_error(gs_error_typecheck);
+
+ while (1) {
+ if (*index >= d->entries) {
+ *Key = NULL;
+ *Value= NULL;
+ return gs_error_undefined;
+ }
+
+ /* If we find NULL keys skip over them. This should never
+ * happen as we check the number of entries above, and we
+ * compact dictionaries on deletion of key/value pairs.
+ * This is a belt and braces check in case creation of the
+ * dictionary somehow ends up with NULL keys in the allocated
+ * section.
+ */
+ *Key = d->keys[*index];
+ if (*Key == NULL) {
+ (*index)++;
+ continue;
+ }
+
+ if (d->values[*index]->type == PDF_INDIRECT) {
+ pdf_indirect_ref *r = (pdf_indirect_ref *)d->values[*index];
+ pdf_obj *o;
+
+ code = pdfi_dereference(ctx, r->ref_object_num, r->ref_generation_num, &o);
+ if (code < 0) {
+ *Key = *Value = NULL;
+ return code;
+ }
+ *Value = o;
+ break;
+ } else {
+ *Value = d->values[*index];
+ pdfi_countup(*Value);
+ break;
+ }
+ }
+
+ pdfi_countup(*Key);
+ (*index)++;
+ return 0;
+}
+
+int pdfi_dict_first(pdf_context *ctx, pdf_dict *d, pdf_obj **Key, pdf_obj **Value, uint64_t *index)
+{
+ uint64_t *i = index;
+
+ *i = 0;
+ return pdfi_dict_next(ctx, d, Key, Value, index);
+}
+
+int pdfi_dict_key_next(pdf_context *ctx, pdf_dict *d, pdf_obj **Key, uint64_t *index)
+{
+ uint64_t *i = index;
+
+ if (d->type != PDF_DICT)
+ return_error(gs_error_typecheck);
+
+ while (1) {
+ if (*i >= d->entries) {
+ *Key = NULL;
+ return gs_error_undefined;
+ }
+
+ *Key = d->keys[*i];
+ if (*Key == NULL) {
+ (*i)++;
+ continue;
+ }
+ pdfi_countup(*Key);
+ (*i)++;
+ break;
+ }
+ return 0;
+}
+
+int pdfi_dict_key_first(pdf_context *ctx, pdf_dict *d, pdf_obj **Key, uint64_t *index)
+{
+ uint64_t *i = index;
+
+ *i = 0;
+ return pdfi_dict_key_next(ctx, d, Key, index);
+}
+
+int pdfi_merge_dicts(pdf_context *ctx, pdf_dict *target, pdf_dict *source)
+{
+ int i, code;
+ bool known = false;
+
+ for (i=0;i< source->entries;i++) {
+ code = pdfi_dict_known_by_key(ctx, target, (pdf_name *)source->keys[i], &known);
+ if (code < 0)
+ return code;
+ if (!known) {
+ code = pdfi_dict_put_obj(ctx, target, source->keys[i], source->values[i]);
+ if (code < 0)
+ return code;
+ }
+ }
+ return 0;
+}
+
+/* Return Length of a stream, or 0 if it's not a stream
+ * Caches the Length
+ */
+int64_t pdfi_stream_length(pdf_context *ctx, pdf_stream *stream)
+{
+ int64_t Length = 0;
+ int code;
+
+ if (stream->type != PDF_STREAM)
+ return 0;
+
+ if (stream->length_valid)
+ return stream->Length;
+
+ code = pdfi_dict_get_int(ctx, stream->stream_dict, "Length", &Length);
+ if (code < 0)
+ Length = 0;
+
+ /* Make sure Length is not negative... */
+ if (Length < 0)
+ Length = 0;
+
+ /* Cache it */
+ stream->Length = Length;
+ stream->length_valid = true;
+
+ return 0;
+}
+
+/* Safely get offset from a stream object.
+ * If it's not actually a stream, just return 0.
+ */
+gs_offset_t pdfi_stream_offset(pdf_context *ctx, pdf_stream *stream)
+{
+ if (stream->type != PDF_STREAM)
+ return 0;
+ return stream->stream_offset;
+}
+
+pdf_stream *pdfi_stream_parent(pdf_context *ctx, pdf_stream *stream)
+{
+ if (stream->type != PDF_STREAM)
+ return 0;
+ return (pdf_stream *)stream->parent_obj;
+}
+
+void pdfi_set_stream_parent(pdf_context *ctx, pdf_stream *stream, pdf_stream *parent)
+{
+ /* Ordinarily we would increment the reference count of the parent object here,
+ * because we are taking a new reference to it. But if we do that we will end up
+ * with circular references and will never count down and release the objects.
+ * This is because the parent object must have a Resources dictionary which
+ * references this stream, when we dereference the stream we store it in the
+ * Parent's Resources dictionary. So the parent points to the child, the child
+ * points to the parent and we always end up with a refcnt for each of 1. Since we
+ * only ever consult parent_obj in an illegal case we deal with this by not
+ * incrementing the reference count. To try and avoid any dangling references
+ * we clear the parent_obj when we finish executing the stream in
+ * pdfi_interpret_content_stream.
+ */
+ stream->parent_obj = (pdf_obj *)parent;
+}
+
+void pdfi_clear_stream_parent(pdf_context *ctx, pdf_stream *stream)
+{
+ stream->parent_obj = NULL;
+}
+
+/* Get the dict from a pdf_obj, returns typecheck if it doesn't have one */
+int pdfi_dict_from_obj(pdf_context *ctx, pdf_obj *obj, pdf_dict **dict)
+{
+ *dict = NULL;
+ if (obj->type == PDF_DICT)
+ *dict = (pdf_dict *)obj;
+ else if (obj->type == PDF_STREAM)
+ *dict = ((pdf_stream *)obj)->stream_dict;
+ else
+ return_error(gs_error_typecheck);
+ return 0;
+}
diff --git a/pdf/pdf_dict.h b/pdf/pdf_dict.h
new file mode 100644
index 00000000..269f6be5
--- /dev/null
+++ b/pdf/pdf_dict.h
@@ -0,0 +1,73 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* dictionary handling for the PDF interpreter */
+
+#ifndef PDF_DICTIONARY_FUNCTIONS
+#define PDF_DICTIONARY_FUNCTIONS
+
+static inline uint64_t pdfi_dict_entries(pdf_dict *d) { return d->entries; }
+
+void pdfi_free_dict(pdf_obj *o);
+int pdfi_dict_delete_pair(pdf_context *ctx, pdf_dict *d, pdf_name *n);
+int pdfi_dict_delete(pdf_context *ctx, pdf_dict *d, const char *str);
+int pdfi_dict_alloc(pdf_context *ctx, uint64_t size, pdf_dict **d);
+int pdfi_dict_from_stack(pdf_context *ctx, uint32_t indirect_num, uint32_t indirect_gen);
+int pdfi_dict_known(pdf_context *ctx, pdf_dict *d, const char *Key, bool *known);
+int pdfi_dict_known_by_key(pdf_context *ctx, pdf_dict *d, pdf_name *Key, bool *known);
+int pdfi_dict_knownget(pdf_context *ctx, pdf_dict *d, const char *Key, pdf_obj **o);
+int pdfi_dict_knownget_type(pdf_context *ctx, pdf_dict *d, const char *Key, pdf_obj_type type, pdf_obj **o);
+int pdfi_dict_knownget_number(pdf_context *ctx, pdf_dict *d, const char *Key, double *f);
+int pdfi_merge_dicts(pdf_context *ctx, pdf_dict *target, pdf_dict *source);
+int pdfi_dict_put_obj(pdf_context *ctx, pdf_dict *d, pdf_obj *Key, pdf_obj *value);
+int pdfi_dict_put(pdf_context *ctx, pdf_dict *d, const char *Key, pdf_obj *value);
+int pdfi_dict_put_int(pdf_context *ctx, pdf_dict *d, const char *Key, int64_t value);
+int pdfi_dict_put_bool(pdf_context *ctx, pdf_dict *d, const char *Key, bool value);
+int pdfi_dict_put_name(pdf_context *ctx, pdf_dict *d, const char *Key, const char *name);
+int pdfi_dict_get2(pdf_context *ctx, pdf_dict *d, const char *Key1, const char *Key2, pdf_obj **o);
+int pdfi_dict_get(pdf_context *ctx, pdf_dict *d, const char *Key, pdf_obj **o);
+int pdfi_dict_get_no_deref(pdf_context *ctx, pdf_dict *d, const pdf_name *Key, pdf_obj **o);
+int pdfi_dict_get_by_key(pdf_context *ctx, pdf_dict *d, const pdf_name *Key, pdf_obj **o);
+int pdfi_dict_get_no_store_R_key(pdf_context *ctx, pdf_dict *d, const pdf_name *Key, pdf_obj **o);
+int pdfi_dict_get_no_store_R(pdf_context *ctx, pdf_dict *d, const char *Key, pdf_obj **o);
+int pdfi_dict_get_type2(pdf_context *ctx, pdf_dict *d, const char *Key1, const char *Key2, pdf_obj_type type, pdf_obj **o);
+int pdfi_dict_get_type(pdf_context *ctx, pdf_dict *d, const char *Key, pdf_obj_type t, pdf_obj **o);
+int pdfi_dict_get_ref(pdf_context *ctx, pdf_dict *d, const char *Key, pdf_indirect_ref **o);
+int pdfi_dict_get_int2(pdf_context *ctx, pdf_dict *d, const char *Key1, const char *Key2, int64_t *i);
+int pdfi_dict_get_int(pdf_context *ctx, pdf_dict *d, const char *Key, int64_t *i);
+int pdfi_dict_get_int_def(pdf_context *ctx, pdf_dict *d, const char *Key, int64_t *i, int64_t def_val);
+int pdfi_dict_get_bool2(pdf_context *ctx, pdf_dict *d, const char *Key1, const char *Key2, bool *val);
+int pdfi_dict_get_bool(pdf_context *ctx, pdf_dict *d, const char *Key, bool *val);
+int pdfi_dict_get_number(pdf_context *ctx, pdf_dict *d, const char *Key, double *f);
+int pdfi_dict_get_number2(pdf_context *ctx, pdf_dict *d, const char *Key1, const char *Key2, double *f);
+int fill_domain_from_dict(pdf_context *ctx, float *parray, int size, pdf_dict *dict);
+int fill_float_array_from_dict(pdf_context *ctx, float *parray, int size, pdf_dict *dict, const char *Key);
+int fill_bool_array_from_dict(pdf_context *ctx, bool *parray, int size, pdf_dict *dict, const char *Key);
+int fill_matrix_from_dict(pdf_context *ctx, float *parray, pdf_dict *dict);
+int pdfi_make_float_array_from_dict(pdf_context *ctx, float **parray, pdf_dict *dict, const char *Key);
+int pdfi_make_int_array_from_dict(pdf_context *ctx, int **parray, pdf_dict *dict, const char *Key);
+int pdfi_dict_copy(pdf_context *ctx, pdf_dict *target, pdf_dict *source);
+int pdfi_dict_next(pdf_context *ctx, pdf_dict *d, pdf_obj **Key, pdf_obj **Value, uint64_t *index);
+int pdfi_dict_first(pdf_context *ctx, pdf_dict *d, pdf_obj **Key, pdf_obj **Value, uint64_t *index);
+int pdfi_dict_key_next(pdf_context *ctx, pdf_dict *d, pdf_obj **Key, uint64_t *index);
+int pdfi_dict_key_first(pdf_context *ctx, pdf_dict *d, pdf_obj **Key, uint64_t *index);
+
+int pdfi_dict_from_obj(pdf_context *ctx, pdf_obj *obj, pdf_dict **dict);
+int64_t pdfi_stream_length(pdf_context *ctx, pdf_stream *stream);
+gs_offset_t pdfi_stream_offset(pdf_context *ctx, pdf_stream *stream);
+pdf_stream *pdfi_stream_parent(pdf_context *ctx, pdf_stream *stream);
+void pdfi_set_stream_parent(pdf_context *ctx, pdf_stream *stream, pdf_stream *parent);
+void pdfi_clear_stream_parent(pdf_context *ctx, pdf_stream *stream);
+#endif
diff --git a/pdf/pdf_doc.c b/pdf/pdf_doc.c
new file mode 100644
index 00000000..5f87d079
--- /dev/null
+++ b/pdf/pdf_doc.c
@@ -0,0 +1,1345 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Functions to deal with PDF structure, such as retrieving
+ * the Info, Catalog, Root dictionaries, and finding resources
+ * and page dictionaries.
+ */
+
+#include "ghostpdf.h"
+#include "pdf_stack.h"
+#include "pdf_deref.h"
+#include "pdf_array.h"
+#include "pdf_dict.h"
+#include "pdf_loop_detect.h"
+#include "pdf_misc.h"
+#include "pdf_repair.h"
+#include "pdf_doc.h"
+#include "pdf_mark.h"
+#include "pdf_colour.h"
+#include "pdf_device.h"
+
+int pdfi_read_Root(pdf_context *ctx)
+{
+ pdf_obj *o, *o1;
+ pdf_dict *d;
+ int code;
+
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "%% Reading Root dictionary\n");
+
+ /* Unusual code. This is because if the entry in the trailer dictionary causes
+ * us to repair the file, the Trailer dictionary in the context can be replaced.
+ * This counts it down and frees it, potentially while pdfi_dict_get is still
+ * using it! Rather than countup and down in the dict_get routine, which is
+ * normally unnecessary, count it up and down round the access here.
+ */
+ d = ctx->Trailer;
+ pdfi_countup(d);
+ code = pdfi_dict_get(ctx, d, "Root", &o1);
+ if (code < 0) {
+ pdfi_countdown(d);
+ return code;
+ }
+ pdfi_countdown(d);
+
+ if (o1->type == PDF_INDIRECT) {
+ code = pdfi_dereference(ctx, ((pdf_indirect_ref *)o1)->ref_object_num, ((pdf_indirect_ref *)o1)->ref_generation_num, &o);
+ pdfi_countdown(o1);
+ if (code < 0)
+ return code;
+
+ if (o->type != PDF_DICT) {
+ pdfi_countdown(o);
+ return_error(gs_error_typecheck);
+ }
+
+ code = pdfi_dict_put(ctx, ctx->Trailer, "Root", o);
+ if (code < 0) {
+ pdfi_countdown(o);
+ return code;
+ }
+ o1 = o;
+ } else {
+ if (o1->type != PDF_DICT) {
+ pdfi_countdown(o1);
+ return_error(gs_error_typecheck);
+ }
+ }
+
+ code = pdfi_dict_get_type(ctx, (pdf_dict *)o1, "Type", PDF_NAME, &o);
+ if (code < 0) {
+ pdfi_countdown(o1);
+ return code;
+ }
+ if (pdfi_name_strcmp((pdf_name *)o, "Catalog") != 0){
+ pdfi_countdown(o);
+ pdfi_countdown(o1);
+ return_error(gs_error_syntaxerror);
+ }
+ pdfi_countdown(o);
+
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "\n");
+ /* We don't pdfi_countdown(o1) now, because we've transferred our
+ * reference to the pointer in the pdf_context structure.
+ */
+ pdfi_countdown(ctx->Root); /* If file was repaired it might be set already */
+ ctx->Root = (pdf_dict *)o1;
+ return 0;
+}
+
+int pdfi_read_Info(pdf_context *ctx)
+{
+ pdf_dict *Info;
+ int code;
+
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "%% Reading Info dictionary\n");
+
+ code = pdfi_dict_get_type(ctx, ctx->Trailer, "Info", PDF_DICT, (pdf_obj **)&Info);
+ if (code < 0)
+ return code;
+
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "\n");
+
+ pdfi_device_set_flags(ctx);
+ pdfi_write_docinfo_pdfmark(ctx, Info);
+
+ /* We don't pdfi_countdown(Info) now, because we've transferred our
+ * reference to the pointer in the pdf_context structure.
+ */
+ ctx->Info = Info;
+ return 0;
+}
+
+int pdfi_read_Pages(pdf_context *ctx)
+{
+ pdf_obj *o, *o1;
+ int code;
+ double d;
+
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "%% Reading Pages dictionary\n");
+
+ code = pdfi_dict_get(ctx, ctx->Root, "Pages", &o1);
+ if (code < 0)
+ return code;
+
+ if (o1->type == PDF_INDIRECT) {
+ code = pdfi_dereference(ctx, ((pdf_indirect_ref *)o1)->ref_object_num, ((pdf_indirect_ref *)o1)->ref_generation_num, &o);
+ pdfi_countdown(o1);
+ if (code < 0)
+ return code;
+
+ if (o->type != PDF_DICT) {
+ pdfi_countdown(o);
+ if (o->type == PDF_INDIRECT)
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADPAGEDICT, "pdfi_read_Pages", (char *)"*** Error: Something is wrong with the Pages dictionary. Giving up.");
+ else
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADPAGEDICT, "pdfi_read_Pages", (char *)"*** Error: Something is wrong with the Pages dictionary. Giving up.\n Double indirect reference. Loop in Pages tree?");
+ return_error(gs_error_typecheck);
+ }
+
+ code = pdfi_dict_put(ctx, ctx->Root, "Pages", o);
+ if (code < 0) {
+ pdfi_countdown(o);
+ return code;
+ }
+ o1 = o;
+ } else {
+ if (o1->type != PDF_DICT) {
+ pdfi_countdown(o1);
+ return_error(gs_error_typecheck);
+ }
+ }
+
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "\n");
+
+ /* Acrobat allows the Pages Count to be a floating point number (!) */
+ /* sample w_a.PDF from Bug688419 (not on the cluster, maybe it should be?) has no /Count entry because
+ * The Root dictionary Pages key points directly to a single dictionary of type /Page. This is plainly
+ * illegal but Acrobat can deal with it. We do so by ignoring the error her, and adding logic in
+ * pdfi_get_page_dict() which notes that ctx->PagesTree is NULL and tries to get the single Page
+ * dictionary from the Root instead of using the PagesTree.
+ */
+ code = pdfi_dict_get_number(ctx, (pdf_dict *)o1, "Count", &d);
+ if (code < 0) {
+ if (code == gs_error_undefined) {
+ pdf_name *n = NULL;
+ /* It may be that the Root dictionary Pages entry points directly to a sinlge Page dictionary
+ * See if the dictionary has a Type of /Page, if so don't throw an error and the pdf_page.c
+ * logic in pdfi_get_page_dict() logic will take care of it.
+ */
+ code = pdfi_dict_get_type(ctx, (pdf_dict *)o1, "Type", PDF_NAME, (pdf_obj **)&n);
+ if (code == 0) {
+ if(pdfi_name_is(n, "Page")) {
+ ctx->num_pages = 1;
+ code = 0;
+ }
+ else
+ code = gs_error_undefined;
+ pdfi_countdown(n);
+ }
+ }
+ pdfi_countdown(o1);
+ return code;
+ }
+
+ if (floor(d) != d) {
+ pdfi_countdown(o1);
+ return_error(gs_error_rangecheck);
+ } else {
+ ctx->num_pages = (int)floor(d);
+ }
+
+ /* We don't pdfi_countdown(o1) now, because we've transferred our
+ * reference to the pointer in the pdf_context structure.
+ */
+ ctx->PagesTree = (pdf_dict *)o1;
+ return 0;
+}
+
+/* Read optional things in from Root */
+void pdfi_read_OptionalRoot(pdf_context *ctx)
+{
+ pdf_obj *obj = NULL;
+ int code;
+ bool known;
+
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "%% Reading other Root contents\n");
+
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "%% OCProperties\n");
+ code = pdfi_dict_get_type(ctx, ctx->Root, "OCProperties", PDF_DICT, &obj);
+ if (code == 0) {
+ ctx->OCProperties = (pdf_dict *)obj;
+ } else {
+ ctx->OCProperties = NULL;
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "%% (None)\n");
+ }
+
+ (void)pdfi_dict_known(ctx, ctx->Root, "Collection", &known);
+
+ if (known) {
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "%% Collection\n");
+ code = pdfi_dict_get(ctx, ctx->Root, "Collection", (pdf_obj **)&ctx->Collection);
+ if (code < 0)
+ dmprintf(ctx->memory, "\n **** Warning: Failed to read Collection information.\n");
+ }
+
+}
+
+void pdfi_free_OptionalRoot(pdf_context *ctx)
+{
+ if (ctx->OCProperties) {
+ pdfi_countdown(ctx->OCProperties);
+ ctx->OCProperties = NULL;
+ }
+ if (ctx->Collection) {
+ pdfi_countdown(ctx->Collection);
+ ctx->Collection = NULL;
+ }
+}
+
+/* Handle child node processing for page_dict */
+static int pdfi_get_child(pdf_context *ctx, pdf_array *Kids, int i, pdf_dict **pchild)
+{
+ pdf_indirect_ref *node = NULL;
+ pdf_dict *child = NULL;
+ pdf_name *Type = NULL;
+ pdf_dict *leaf_dict = NULL;
+ pdf_name *Key = NULL;
+ int code = 0;
+
+ code = pdfi_array_get_no_deref(ctx, Kids, i, (pdf_obj **)&node);
+ if (code < 0)
+ goto errorExit;
+
+ if (node->type != PDF_INDIRECT && node->type != PDF_DICT) {
+ code = gs_note_error(gs_error_typecheck);
+ goto errorExit;
+ }
+
+ if (node->type == PDF_INDIRECT) {
+ code = pdfi_dereference(ctx, node->ref_object_num, node->ref_generation_num,
+ (pdf_obj **)&child);
+ if (code < 0) {
+ int code1 = pdfi_repair_file(ctx);
+ if (code1 < 0)
+ goto errorExit;
+ code = pdfi_dereference(ctx, node->ref_object_num,
+ node->ref_generation_num, (pdf_obj **)&child);
+ if (code < 0)
+ goto errorExit;
+ }
+ if (child->type != PDF_DICT) {
+ code = gs_note_error(gs_error_typecheck);
+ goto errorExit;
+ }
+ /* If its an intermediate node, store it in the page_table, if its a leaf node
+ * then don't store it. Instead we create a special dictionary of our own which
+ * has a /Type of /PageRef and a /PageRef key which is the indirect reference
+ * to the page. However in this case we pass on the actual page dictionary to
+ * the Kids processing below. If we didn't then we'd fall foul of the loop
+ * detection by dereferencing the same object twice.
+ * This is tedious, but it means we don't store all the page dictionaries in
+ * the Pages tree, because page dictionaries can be large and we generally
+ * only use them once. If processed in order we only dereference each page
+ * dictionary once, any other order will dereference each page twice. (or more
+ * if we render the same page multiple times).
+ */
+ code = pdfi_dict_get_type(ctx, child, "Type", PDF_NAME, (pdf_obj **)&Type);
+ if (code < 0)
+ goto errorExit;
+ if (pdfi_name_is(Type, "Pages")) {
+ code = pdfi_array_put(ctx, Kids, i, (pdf_obj *)child);
+ if (code < 0)
+ goto errorExit;
+ } else {
+ /* Bizarrely, one of the QL FTS files (FTS_07_0704.pdf) has a page diciotnary with a /Type of /Template */
+ if (!pdfi_name_is(Type, "Page"))
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADPAGETYPE, "pdfi_get_child", NULL);
+ /* Make a 'PageRef' entry (just stores an indirect reference to the actual page)
+ * and store that in the Kids array for future reference. But pass on the
+ * dereferenced Page dictionary, in case this is the target page.
+ */
+
+ code = pdfi_dict_alloc(ctx, 0, &leaf_dict);
+ if (code < 0)
+ goto errorExit;
+ code = pdfi_name_alloc(ctx, (byte *)"PageRef", 7, (pdf_obj **)&Key);
+ if (code < 0)
+ goto errorExit;
+ pdfi_countup(Key);
+
+ code = pdfi_dict_put_obj(ctx, leaf_dict, (pdf_obj *)Key, (pdf_obj *)node);
+ if (code < 0)
+ goto errorExit;
+ code = pdfi_dict_put(ctx, leaf_dict, "Type", (pdf_obj *)Key);
+ if (code < 0)
+ goto errorExit;
+ code = pdfi_array_put(ctx, Kids, i, (pdf_obj *)leaf_dict);
+ if (code < 0)
+ goto errorExit;
+ }
+ } else {
+ child = (pdf_dict *)node;
+ pdfi_countup(child);
+ }
+
+ *pchild = child;
+ child = NULL;
+
+ errorExit:
+ pdfi_countdown(child);
+ pdfi_countdown(node);
+ pdfi_countdown(Type);
+ pdfi_countdown(Key);
+ return code;
+}
+
+/* Check if key is in the dictionary, and if so, copy it into the inheritable dict.
+ */
+static int pdfi_check_inherited_key(pdf_context *ctx, pdf_dict *d, const char *keyname, pdf_dict *inheritable)
+{
+ int code = 0;
+ pdf_obj *object = NULL;
+ bool known;
+
+ /* Check for inheritable keys, if we find any copy them to the 'inheritable' dictionary at this level */
+ code = pdfi_dict_known(ctx, d, keyname, &known);
+ if (code < 0)
+ goto exit;
+ if (known) {
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0){
+ goto exit;
+ }
+ code = pdfi_dict_get(ctx, d, keyname, &object);
+ if (code < 0) {
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ goto exit;
+ }
+ code = pdfi_loop_detector_cleartomark(ctx);
+ if (code < 0) {
+ goto exit;
+ }
+ code = pdfi_dict_put(ctx, inheritable, keyname, object);
+ }
+
+ exit:
+ pdfi_countdown(object);
+ return code;
+}
+
+int pdfi_get_page_dict(pdf_context *ctx, pdf_dict *d, uint64_t page_num, uint64_t *page_offset,
+ pdf_dict **target, pdf_dict *inherited)
+{
+ int i, code = 0;
+ pdf_array *Kids = NULL;
+ pdf_dict *child = NULL;
+ pdf_name *Type = NULL;
+ pdf_dict *inheritable = NULL;
+ int64_t num;
+ double dbl;
+
+ if (ctx->args.pdfdebug)
+ dmprintf1(ctx->memory, "%% Finding page dictionary for page %"PRIi64"\n", page_num + 1);
+
+ /* Allocated inheritable dict (it might stay empty) */
+ code = pdfi_dict_alloc(ctx, 0, &inheritable);
+ if (code < 0)
+ return code;
+ pdfi_countup(inheritable);
+
+ /* if we are being passed any inherited values from our parent, copy them now */
+ if (inherited != NULL) {
+ code = pdfi_dict_copy(ctx, inheritable, inherited);
+ if (code < 0)
+ goto exit;
+ }
+
+ code = pdfi_dict_get_number(ctx, d, "Count", &dbl);
+ if (code < 0)
+ goto exit;
+ if (dbl != floor(dbl)) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ num = (int)dbl;
+
+ if (num < 0 || (num + *page_offset) > ctx->num_pages) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ if (num + *page_offset < page_num) {
+ *page_offset += num;
+ code = 1;
+ goto exit;
+ }
+ /* The requested page is a descendant of this node */
+
+ /* Check for inheritable keys, if we find any copy them to the 'inheritable' dictionary at this level */
+ code = pdfi_check_inherited_key(ctx, d, "Resources", inheritable);
+ if (code < 0)
+ goto exit;
+ code = pdfi_check_inherited_key(ctx, d, "MediaBox", inheritable);
+ if (code < 0)
+ goto exit;
+ code = pdfi_check_inherited_key(ctx, d, "CropBox", inheritable);
+ if (code < 0)
+ goto exit;
+ code = pdfi_check_inherited_key(ctx, d, "Rotate", inheritable);
+ if (code < 0) {
+ goto exit;
+ }
+
+ /* Get the Kids array */
+ code = pdfi_dict_get_type(ctx, d, "Kids", PDF_ARRAY, (pdf_obj **)&Kids);
+ if (code < 0) {
+ goto exit;
+ }
+
+ /* Check each entry in the Kids array */
+ for (i = 0;i < pdfi_array_size(Kids);i++) {
+ pdfi_countdown(child);
+ child = NULL;
+ pdfi_countdown(Type);
+ Type = NULL;
+
+ code = pdfi_get_child(ctx, Kids, i, &child);
+ if (code < 0) {
+ goto exit;
+ }
+
+ /* Check the type, if its a Pages entry, then recurse. If its a Page entry, is it the one we want */
+ code = pdfi_dict_get_type(ctx, child, "Type", PDF_NAME, (pdf_obj **)&Type);
+ if (code == 0) {
+ if (pdfi_name_is(Type, "Pages")) {
+ code = pdfi_dict_get_number(ctx, child, "Count", &dbl);
+ if (code == 0) {
+ if (dbl != floor(dbl)) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ num = (int)dbl;
+ if (num < 0 || (num + *page_offset) > ctx->num_pages) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ } else {
+ if (num + *page_offset <= page_num) {
+ *page_offset += num;
+ } else {
+ code = pdfi_get_page_dict(ctx, child, page_num, page_offset, target, inheritable);
+ goto exit;
+ }
+ }
+ }
+ } else {
+ if (pdfi_name_is(Type, "PageRef")) {
+ if ((*page_offset) == page_num) {
+ pdf_dict *d = NULL;
+
+ code = pdfi_dict_get(ctx, child, "PageRef", (pdf_obj **)&d);
+ if (code < 0)
+ goto exit;
+ code = pdfi_merge_dicts(ctx, d, inheritable);
+ *target = d;
+ pdfi_countup(*target);
+ pdfi_countdown(d);
+ goto exit;
+ } else {
+ *page_offset += 1;
+ }
+ } else {
+ if (!pdfi_name_is(Type, "Page"))
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADPAGETYPE, "pdfi_get_page_dict", NULL);
+ if ((*page_offset) == page_num) {
+ code = pdfi_merge_dicts(ctx, child, inheritable);
+ *target = child;
+ pdfi_countup(*target);
+ goto exit;
+ } else {
+ *page_offset += 1;
+ }
+ }
+ }
+ }
+ if (code < 0)
+ goto exit;
+ }
+ /* Positive return value indicates we did not find the target below this node, try the next one */
+ code = 1;
+
+ exit:
+ pdfi_countdown(inheritable);
+ pdfi_countdown(Kids);
+ pdfi_countdown(child);
+ pdfi_countdown(Type);
+ return code;
+}
+
+int pdfi_doc_page_array_init(pdf_context *ctx)
+{
+ size_t size = ctx->num_pages*sizeof(uint32_t);
+
+ ctx->page_array = (uint32_t *)gs_alloc_bytes(ctx->memory, size,
+ "pdfi_doc_page_array_init(page_array)");
+ if (ctx->page_array == NULL)
+ return_error(gs_error_VMerror);
+
+ memset(ctx->page_array, 0, size);
+ return 0;
+}
+
+void pdfi_doc_page_array_free(pdf_context *ctx)
+{
+ if (!ctx->page_array)
+ return;
+ gs_free_object(ctx->memory, ctx->page_array, "pdfi_doc_page_array_free(page_array)");
+ ctx->page_array = NULL;
+}
+
+/*
+ * Checks for both "Resource" and "RD" in the specified dict.
+ * And then gets the typedict of Type (e.g. Font or XObject).
+ * Returns 0 if undefined, >0 if found, <0 if error
+ */
+static int pdfi_resource_knownget_typedict(pdf_context *ctx, unsigned char *Type,
+ pdf_dict *dict, pdf_dict **typedict)
+{
+ int code;
+ pdf_dict *Resources = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, dict, "Resources", PDF_DICT, (pdf_obj **)&Resources);
+ if (code == 0)
+ code = pdfi_dict_knownget_type(ctx, dict, "DR", PDF_DICT, (pdf_obj **)&Resources);
+ if (code < 0)
+ goto exit;
+ if (code > 0)
+ code = pdfi_dict_knownget_type(ctx, Resources, (const char *)Type, PDF_DICT, (pdf_obj **)typedict);
+ exit:
+ pdfi_countdown(Resources);
+ return code;
+}
+
+int pdfi_find_resource(pdf_context *ctx, unsigned char *Type, pdf_name *name,
+ pdf_dict *dict, pdf_dict *page_dict, pdf_obj **o)
+{
+ pdf_dict *typedict = NULL;
+ pdf_dict *Parent = NULL;
+ int code;
+
+ *o = NULL;
+
+ /* Check the provided dict */
+ code = pdfi_resource_knownget_typedict(ctx, Type, dict, &typedict);
+ if (code < 0)
+ goto exit;
+ if (code > 0) {
+ code = pdfi_dict_get_no_store_R_key(ctx, typedict, name, o);
+ if (code != gs_error_undefined)
+ goto exit;
+ }
+
+ /* Check the Parents, if any */
+ code = pdfi_dict_knownget_type(ctx, dict, "Parent", PDF_DICT, (pdf_obj **)&Parent);
+ if (code < 0)
+ goto exit;
+ if (code > 0) {
+ if (Parent->object_num != ctx->page.CurrentPageDict->object_num) {
+ code = pdfi_find_resource(ctx, Type, name, Parent, page_dict, o);
+ if (code != gs_error_undefined)
+ goto exit;
+ }
+ }
+
+ pdfi_countdown(typedict);
+ typedict = NULL;
+
+ /* Normally page_dict can't be (or shouldn't be) NULL. However, if we are processing
+ * a TYpe 3 font, then the 'page dict' is the Resources dictionary of that font. If
+ * the font inherits Resources from its page (which it should not) then its possible
+ * that the 'page dict' could be NULL here. We need to guard against that. Its possible
+ * there may be other, similar, cases (eg Patterns within Patterns). In addition we
+ * do need to be able to check the real page dictionary for inhereited resources, and
+ * in the case of a type 3 font BuildChar at least there is no easy way to do that.
+ * So we'll store the page dictionary for the current page in the context as a
+ * last-ditch resource to check.
+ */
+ if (page_dict != NULL) {
+ code = pdfi_resource_knownget_typedict(ctx, Type, page_dict, &typedict);
+ if (code < 0)
+ goto exit;
+
+ if (code > 0) {
+ code = pdfi_dict_get_no_store_R_key(ctx, typedict, name, o);
+ goto exit;
+ }
+ }
+
+ pdfi_countdown(typedict);
+ typedict = NULL;
+
+ if (ctx->page.CurrentPageDict != NULL) {
+ code = pdfi_resource_knownget_typedict(ctx, Type, ctx->page.CurrentPageDict, &typedict);
+ if (code < 0)
+ goto exit;
+
+ if (code > 0) {
+ code = pdfi_dict_get_no_store_R_key(ctx, typedict, name, o);
+ goto exit;
+ }
+ }
+
+ if (ctx->current_stream != NULL) {
+ pdf_dict *stream_dict = NULL;
+ pdf_stream *stream = ctx->current_stream;
+
+ do {
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)stream, &stream_dict);
+ if (code < 0)
+ goto exit;
+ code = pdfi_resource_knownget_typedict(ctx, Type, stream_dict, &typedict);
+ if (code < 0)
+ goto exit;
+ if (code > 0) {
+ code = pdfi_dict_get_no_store_R_key(ctx, typedict, name, o);
+ pdfi_set_error(ctx, 0, NULL, E_PDF_INHERITED_STREAM_RESOURCE, "pdfi_find_resource", (char *)"Couldn't find named resource in suppled dictionary, or Parents, or Pages, matching name located in earlier stream Resource");
+ goto exit;
+ }
+ pdfi_countdown(typedict);
+ typedict = NULL;
+ stream = pdfi_stream_parent(ctx, stream);
+ }while(stream != NULL);
+ }
+
+ /* If we got all the way down there, we didn't find it */
+ dmprintf(ctx->memory, "Couldn't find named resource\n");
+ code = gs_error_undefined;
+
+exit:
+ pdfi_countdown(typedict);
+ pdfi_countdown(Parent);
+ return code;
+}
+
+/* Count how many children an outline entry has
+ * This is separate just to keep the code from getting cluttered.
+ */
+static int pdfi_doc_outline_count(pdf_context *ctx, pdf_dict *outline, int64_t *count)
+{
+ int code = 0;
+ pdf_dict *child = NULL;
+ pdf_dict *Next = NULL;
+
+ /* Handle this outline entry */
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ goto exit1;
+
+ /* Count the children (don't deref them, we don't want to leave them hanging around) */
+ code = pdfi_dict_get_no_store_R(ctx, outline, "First", (pdf_obj **)&child);
+ if (code < 0 || child->type != PDF_DICT) {
+ /* TODO: flag a warning? */
+ code = 0;
+ goto exit;
+ }
+
+ if (child->object_num != 0) {
+ code = pdfi_loop_detector_add_object(ctx, child->object_num);
+ if (code < 0)
+ goto exit;
+ }
+
+ do {
+ (*count) ++;
+
+ code = pdfi_dict_get_no_store_R(ctx, child, "Next", (pdf_obj **)&Next);
+ if (code == gs_error_circular_reference) {
+ code = 0;
+ goto exit;
+ }
+ if (code == gs_error_undefined) {
+ code = 0;
+ break;
+ }
+
+ if (code < 0 || Next->type != PDF_DICT)
+ goto exit;
+
+ pdfi_countdown(child);
+ child = Next;
+ } while (true);
+
+ exit:
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ exit1:
+ pdfi_countdown(child);
+ pdfi_countdown(Next);
+ return code;
+}
+
+/* Mark the actual outline */
+static int pdfi_doc_mark_the_outline(pdf_context *ctx, pdf_dict *outline)
+{
+ int code = 0;
+ int64_t count = 0;
+ int64_t numkids = 0;
+ pdf_dict *tempdict = NULL;
+ uint64_t dictsize;
+ uint64_t index;
+ pdf_name *Key = NULL;
+
+ /* Basically we only do /Count, /Title, /A, /C, /F
+ * The /First, /Last, /Next, /Parent get written magically by pdfwrite
+ */
+ /* Count how many kids there are */
+ code = pdfi_doc_outline_count(ctx, outline, &numkids);
+
+ /* If no kids, see if there is a Count */
+ if (numkids == 0) {
+ code = pdfi_dict_get_int(ctx, outline, "Count", &count);
+ if (code < 0 && code != gs_error_undefined)
+ goto exit;
+ if (count < 0)
+ count = -count;
+ } else {
+ count = numkids;
+ }
+
+ /* Make a temporary copy of the outline dict */
+ dictsize = pdfi_dict_entries(outline);
+ code = pdfi_dict_alloc(ctx, dictsize, &tempdict);
+ if (code < 0) goto exit;
+ pdfi_countup(tempdict);
+ code = pdfi_dict_copy(ctx, tempdict, outline);
+ if (code < 0) goto exit;
+
+ /* Go through the dict, removing some keys and doing special handling for others.
+ */
+ code = pdfi_dict_key_first(ctx, outline, (pdf_obj **)&Key, &index);
+ while (code >= 0) {
+ if (pdfi_name_is(Key, "Last") || pdfi_name_is(Key, "Next") || pdfi_name_is(Key, "First") ||
+ pdfi_name_is(Key, "Prev") || pdfi_name_is(Key, "Parent")) {
+ /* Delete some keys
+ * These are handled in pdfwrite and can lead to circular refs
+ */
+ code = pdfi_dict_delete_pair(ctx, tempdict, Key);
+ } else if (pdfi_name_is(Key, "SE")) {
+ /* TODO: Not sure what to do with SE, delete for now */
+ /* Seems to be okay to just delete it, since there should also be a /Dest
+ * See sample fts_29_2903.pdf
+ * Currently we are same as gs
+ */
+ code = pdfi_dict_delete_pair(ctx, tempdict, Key);
+ } else if (pdfi_name_is(Key, "A")) {
+ code = pdfi_mark_modA(ctx, tempdict);
+ } else if (pdfi_name_is(Key, "Dest")) {
+ code = pdfi_mark_modDest(ctx, tempdict);
+ } else if (pdfi_name_is(Key, "Count")) {
+ /* Delete any count we find in the dict
+ * We will use our value below
+ */
+ code = pdfi_dict_delete_pair(ctx, tempdict, Key);
+ }
+ if (code < 0)
+ goto exit;
+
+ pdfi_countdown(Key);
+ Key = NULL;
+
+ code = pdfi_dict_key_next(ctx, outline, (pdf_obj **)&Key, &index);
+ if (code == gs_error_undefined) {
+ code = 0;
+ break;
+ }
+ }
+ if (code < 0) goto exit;
+
+ /* If count is non-zero, put in dictionary */
+ if (count != 0) {
+ code = pdfi_dict_put_int(ctx, tempdict, "Count", count);
+ if (code < 0)
+ goto exit;
+ }
+
+ /* Write the pdfmark */
+ code = pdfi_mark_from_dict(ctx, tempdict, NULL, "OUT");
+ if (code < 0)
+ goto exit;
+
+ exit:
+ pdfi_countdown(tempdict);
+ pdfi_countdown(Key);
+ return code;
+}
+
+/* Do pdfmark on an outline entry (recursive)
+ * Note: the logic here is wonky. It is relying on the behavior of the pdfwrite driver.
+ * See pdf_main.ps/writeoutline()
+ */
+static int pdfi_doc_mark_outline(pdf_context *ctx, pdf_dict *outline)
+{
+ int code = 0;
+ pdf_dict *child = NULL;
+ pdf_dict *Next = NULL;
+
+ /* Mark the outline */
+ /* NOTE: I think the pdfmark for this needs to be written before the children
+ * because I think pdfwrite relies on the order of things.
+ */
+ code = pdfi_doc_mark_the_outline(ctx, outline);
+ if (code < 0)
+ goto exit1;
+
+ /* Handle the children */
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ goto exit1;
+
+ /* Handle any children (don't deref them, we don't want to leave them hanging around) */
+ code = pdfi_dict_get_no_store_R(ctx, outline, "First", (pdf_obj **)&child);
+ if (code < 0 || child->type != PDF_DICT) {
+ /* TODO: flag a warning? */
+ code = 0;
+ goto exit;
+ }
+
+ if (child->object_num != 0) {
+ code = pdfi_loop_detector_add_object(ctx, child->object_num);
+ if (code < 0)
+ goto exit;
+ }
+
+ do {
+ code = pdfi_doc_mark_outline(ctx, child);
+ if (code < 0) goto exit;
+
+
+ code = pdfi_dict_get_no_store_R(ctx, child, "Next", (pdf_obj **)&Next);
+ if (code == gs_error_undefined) {
+ code = 0;
+ break;
+ }
+ if (code == gs_error_circular_reference) {
+ code = 0;
+ goto exit;
+ }
+ if (code < 0 || Next->type != PDF_DICT)
+ goto exit;
+
+ pdfi_countdown(child);
+ child = Next;
+ Next = NULL;
+ } while (true);
+
+ exit:
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ exit1:
+ pdfi_countdown(child);
+ pdfi_countdown(Next);
+ return code;
+}
+
+/* Do pdfmark for Outlines */
+static int pdfi_doc_Outlines(pdf_context *ctx)
+{
+ int code = 0;
+ pdf_dict *Outlines = NULL;
+ pdf_dict *outline = NULL;
+ pdf_dict *Next = NULL;
+
+ if (ctx->args.no_pdfmark_outlines)
+ goto exit1;
+
+ code = pdfi_dict_knownget_type(ctx, ctx->Root, "Outlines", PDF_DICT, (pdf_obj **)&Outlines);
+ if (code <= 0) {
+ /* TODO: flag a warning */
+ code = 0;
+ goto exit1;
+ }
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ goto exit1;
+
+ /* Handle any children (don't deref them, we don't want to leave them hanging around) */
+ code = pdfi_dict_get_no_store_R(ctx, Outlines, "First", (pdf_obj **)&outline);
+ if (code < 0 || outline->type != PDF_DICT) {
+ /* TODO: flag a warning? */
+ code = 0;
+ goto exit;
+ }
+
+ if (outline->object_num != 0) {
+ code = pdfi_loop_detector_add_object(ctx, outline->object_num);
+ if (code < 0)
+ goto exit;
+ }
+
+ /* Loop through all the top-level outline entries
+ * First one is in Outlines, and if there are more, they are the Next of the
+ * current outline item. (see spec)
+ * (basically we are walking a linked list)
+ */
+ do {
+ code = pdfi_doc_mark_outline(ctx, outline);
+ if (code < 0) goto exit;
+
+
+ code = pdfi_dict_get_no_store_R(ctx, outline, "Next", (pdf_obj **)&Next);
+ if (code == gs_error_undefined) {
+ code = 0;
+ break;
+ }
+ if (code == gs_error_circular_reference) {
+ code = 0;
+ goto exit;
+ }
+ if (code < 0 || outline->type != PDF_DICT)
+ goto exit;
+
+ pdfi_countdown(outline);
+ outline = Next;
+ Next = NULL;
+ } while (true);
+
+ exit:
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ exit1:
+ pdfi_countdown(Outlines);
+ pdfi_countdown(outline);
+ pdfi_countdown(Next);
+ return code;
+}
+
+/* Do pdfmark for Info */
+static int pdfi_doc_Info(pdf_context *ctx)
+{
+ int code = 0;
+ pdf_dict *Info = NULL;
+ pdf_dict *tempdict = NULL;
+ uint64_t dictsize;
+ uint64_t index;
+ pdf_name *Key = NULL;
+ pdf_obj *Value = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, ctx->Trailer, "Info", PDF_DICT, (pdf_obj **)&Info);
+ if (code <= 0) {
+ /* TODO: flag a warning */
+ goto exit;
+ }
+
+ /* Make a temporary copy of the Info dict */
+ dictsize = pdfi_dict_entries(Info);
+ code = pdfi_dict_alloc(ctx, dictsize, &tempdict);
+ if (code < 0) goto exit;
+ pdfi_countup(tempdict);
+
+ /* Copy only certain keys from Info to tempdict
+ * NOTE: pdfwrite will set /Producer, /CreationDate and /ModDate
+ */
+ code = pdfi_dict_first(ctx, Info, (pdf_obj **)&Key, &Value, &index);
+ while (code >= 0) {
+ if (pdfi_name_is(Key, "Author") || pdfi_name_is(Key, "Creator") ||
+ pdfi_name_is(Key, "Title") || pdfi_name_is(Key, "Subject") ||
+ pdfi_name_is(Key, "Keywords")) {
+ code = pdfi_dict_put_obj(ctx, tempdict, (pdf_obj *)Key, Value);
+ if (code < 0)
+ goto exit;
+ }
+ pdfi_countdown(Key);
+ Key = NULL;
+ pdfi_countdown(Value);
+ Value = NULL;
+
+ code = pdfi_dict_next(ctx, Info, (pdf_obj **)&Key, &Value, &index);
+ if (code == gs_error_undefined) {
+ code = 0;
+ break;
+ }
+ }
+ if (code < 0) goto exit;
+
+ /* Write the pdfmark */
+ code = pdfi_mark_from_dict(ctx, tempdict, NULL, "DOCINFO");
+
+ exit:
+ pdfi_countdown(Key);
+ pdfi_countdown(Value);
+ pdfi_countdown(Info);
+ pdfi_countdown(tempdict);
+ return code;
+}
+
+/* Handle PageLabels for pdfwrite device */
+static int pdfi_doc_PageLabels(pdf_context *ctx)
+{
+ int code;
+ pdf_dict *PageLabels = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, ctx->Root, "PageLabels", PDF_DICT, (pdf_obj **)&PageLabels);
+ if (code <= 0) {
+ /* TODO: flag a warning */
+ goto exit;
+ }
+
+ /* This will send the PageLabels object as a 'pdfpagelabels' setdeviceparams */
+ code = pdfi_mark_object(ctx, (pdf_obj *)PageLabels, "pdfpagelabels");
+ if (code < 0)
+ goto exit;
+
+ exit:
+ pdfi_countdown(PageLabels);
+ return code;
+}
+
+/* Handle OutputIntents stuff
+ * (bottom of pdf_main.ps/process_trailer_attrs)
+ */
+static int pdfi_doc_OutputIntents(pdf_context *ctx)
+{
+ int code;
+ pdf_array *OutputIntents = NULL;
+ pdf_dict *intent = NULL;
+ pdf_string *name = NULL;
+ pdf_stream *DestOutputProfile = NULL;
+ uint64_t index;
+
+ /* NOTE: subtle difference in error handling -- we are checking for OutputIntents first,
+ * so this will just ignore UsePDFX3Profile or UseOutputIntent params without warning,
+ * if OutputIntents doesn't exist. Seems fine to me.
+ */
+ code = pdfi_dict_knownget_type(ctx, ctx->Root, "OutputIntents", PDF_ARRAY,
+ (pdf_obj **)&OutputIntents);
+ if (code <= 0) {
+ goto exit;
+ }
+
+ /* TODO: Implement writeoutputintents if somebody ever complains...
+ * See pdf_main.ps/writeoutputintents
+ * I am not aware of a device that supports "/OutputIntent" so
+ * couldn't figure out what to do for this.
+ */
+
+ /* Handle UsePDFX3Profile and UseOutputIntent command line options */
+ if (ctx->args.UsePDFX3Profile) {
+ /* This is an index into the array */
+ code = pdfi_array_get_type(ctx, OutputIntents, ctx->args.PDFX3Profile_num,
+ PDF_DICT, (pdf_obj **)&intent);
+ if (code < 0) {
+ dmprintf1(ctx->memory,
+ "*** WARNING UsePDFX3Profile specified invalid index %d for OutputIntents\n",
+ ctx->args.PDFX3Profile_num);
+ goto exit;
+ }
+ } else if (ctx->args.UseOutputIntent != NULL) {
+ /* This is a name to look up in the array */
+ for (index=0; index<pdfi_array_size(OutputIntents); index ++) {
+ code = pdfi_array_get_type(ctx, OutputIntents, index, PDF_DICT, (pdf_obj **)&intent);
+ if (code < 0) goto exit;
+
+ code = pdfi_dict_knownget_type(ctx, intent, "OutputConditionIdentifier", PDF_STRING,
+ (pdf_obj **)&name);
+ if (code < 0) goto exit;
+ if (code == 0)
+ continue;
+
+ /* If the ID is "Custom" then check "Info" instead */
+ if (pdfi_string_is(name, "Custom")) {
+ pdfi_countdown(name);
+ name = NULL;
+ code = pdfi_dict_knownget_type(ctx, intent, "Info", PDF_STRING, (pdf_obj **)&name);
+ if (code < 0) goto exit;
+ if (code == 0)
+ continue;
+ }
+
+ /* Check for a match */
+ if (pdfi_string_is(name, ctx->args.UseOutputIntent))
+ break;
+
+ pdfi_countdown(intent);
+ intent = NULL;
+ pdfi_countdown(name);
+ name = NULL;
+ }
+ code = 0;
+ } else {
+ /* No command line arg was specified, so nothing to do */
+ code = 0;
+ goto exit;
+ }
+
+ /* Now if intent is non-null, we found the selected intent dictionary */
+ if (intent == NULL)
+ goto exit;
+
+ /* Load the profile, if it exists */
+ code = pdfi_dict_knownget_type(ctx, intent, "DestOutputProfile", PDF_STREAM, (pdf_obj **)&DestOutputProfile);
+ /* TODO: Flag an error if it doesn't exist? Only required in some cases */
+ if (code <= 0) goto exit;
+
+ /* Set the intent to the profile */
+ code = pdfi_color_setoutputintent(ctx, intent, DestOutputProfile);
+
+ exit:
+ pdfi_countdown(OutputIntents);
+ pdfi_countdown(intent);
+ pdfi_countdown(name);
+ pdfi_countdown(DestOutputProfile);
+ return code;
+}
+
+/* Handled an embedded files Names array for pdfwrite device */
+static int pdfi_doc_EmbeddedFiles_Names(pdf_context *ctx, pdf_array *names)
+{
+ int code;
+ uint64_t arraysize;
+ uint64_t index;
+ pdf_string *name = NULL;
+ pdf_dict *filespec = NULL;
+
+ arraysize = pdfi_array_size(names);
+ if ((arraysize % 2) != 0) {
+ code = gs_note_error(gs_error_syntaxerror);
+ goto exit;
+ }
+
+ /* This is supposed to be an array of
+ * [ (filename1) (filespec1) (filename2) (filespec2) ... ]
+ */
+ for (index = 0; index < arraysize; index += 2) {
+ code = pdfi_array_get_type(ctx, names, index, PDF_STRING, (pdf_obj **)&name);
+ if (code < 0) goto exit;
+
+ code = pdfi_array_get_type(ctx, names, index+1, PDF_DICT, (pdf_obj **)&filespec);
+ if (code < 0) goto exit;
+
+ code = pdfi_mark_embed_filespec(ctx, name, filespec);
+ if (code < 0) goto exit;
+
+ pdfi_countdown(name);
+ name = NULL;
+ pdfi_countdown(filespec);
+ filespec = NULL;
+ }
+
+
+ exit:
+ pdfi_countdown(name);
+ pdfi_countdown(filespec);
+ return code;
+}
+
+/* Handle PageLabels for pdfwrite device */
+static int pdfi_doc_EmbeddedFiles(pdf_context *ctx)
+{
+ int code;
+ pdf_dict *Names = NULL;
+ pdf_dict *EmbeddedFiles = NULL;
+ pdf_array *Names_array = NULL;
+ pdf_array *Kids = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, ctx->Root, "Names", PDF_DICT, (pdf_obj **)&Names);
+ if (code <= 0) goto exit;
+
+ code = pdfi_dict_knownget_type(ctx, Names, "EmbeddedFiles", PDF_DICT, (pdf_obj **)&EmbeddedFiles);
+ if (code <= 0) goto exit;
+
+ code = pdfi_dict_knownget_type(ctx, Names, "Kids", PDF_ARRAY, (pdf_obj **)&Kids);
+ if (code < 0) goto exit;
+ if (code > 0) {
+ /* TODO: Need to implement */
+ dmprintf(ctx->memory, "*** WARNING Kids array in EmbeddedFiles not implemented\n");
+ }
+
+ /* TODO: This is a name tree.
+ * Can contain a Names array, or some complicated Kids.
+ * Just handling Names array for now
+ */
+ code = pdfi_dict_knownget_type(ctx, EmbeddedFiles, "Names", PDF_ARRAY, (pdf_obj **)&Names_array);
+ if (code <= 0) goto exit;
+
+ code = pdfi_doc_EmbeddedFiles_Names(ctx, Names_array);
+ if (code <= 0) goto exit;
+
+ exit:
+ pdfi_countdown(Kids);
+ pdfi_countdown(Names);
+ pdfi_countdown(EmbeddedFiles);
+ pdfi_countdown(Names_array);
+ return code;
+}
+
+/* Handle some bookkeeping related to AcroForm (and annotations)
+ * See pdf_main.ps/process_trailer_attrs/AcroForm
+ *
+ * Mainly we preload AcroForm and NeedAppearances in the context
+ *
+ * TODO: gs code also seems to do something to link up parents in fields/annotations (ParentField)
+ * We are going to avoid doing that for now.
+ */
+static int pdfi_doc_AcroForm(pdf_context *ctx)
+{
+ int code = 0;
+ pdf_dict *AcroForm = NULL;
+ bool boolval = false;
+
+ code = pdfi_dict_knownget_type(ctx, ctx->Root, "AcroForm", PDF_DICT, (pdf_obj **)&AcroForm);
+ if (code <= 0) goto exit;
+
+ code = pdfi_dict_get_bool(ctx, AcroForm, "NeedAppearances", &boolval);
+ if (code < 0) {
+ if (code == gs_error_undefined) {
+ boolval = true;
+ code = 0;
+ }
+ else
+ goto exit;
+ }
+ ctx->NeedAppearances = boolval;
+
+ /* Save this for efficiency later */
+ ctx->AcroForm = AcroForm;
+ pdfi_countup(AcroForm);
+
+ /* TODO: Link up ParentField (but hopefully we can avoid doing this hacky mess).
+ * Also: Something to do with Bug692447.pdf?
+ */
+
+
+ exit:
+ pdfi_countdown(AcroForm);
+ return code;
+}
+
+
+/* See pdf_main.ps/process_trailer_attrs()
+ * Some of this stuff is about pdfmarks, and some of it is just handling
+ * random things in the trailer.
+ */
+int pdfi_doc_trailer(pdf_context *ctx)
+{
+ int code = 0;
+
+ /* Can't do this stuff with no Trailer */
+ if (!ctx->Trailer)
+ goto exit;
+
+ if (ctx->device_state.writepdfmarks) {
+ /* Handle Outlines */
+ code = pdfi_doc_Outlines(ctx);
+ if (code < 0) {
+ pdfi_set_warning(ctx, code, NULL, W_PDF_BAD_TRAILER, "pdfi_doc_trailer", NULL);
+ if (ctx->args.pdfstoponerror)
+ goto exit;
+ }
+
+ /* Handle Info */
+ code = pdfi_doc_Info(ctx);
+ if (code < 0) {
+ pdfi_set_warning(ctx, code, NULL, W_PDF_BAD_TRAILER, "pdfi_doc_trailer", NULL);
+ if (ctx->args.pdfstoponerror)
+ goto exit;
+ }
+
+ /* Handle EmbeddedFiles */
+ /* TODO: add a configuration option to embed or omit */
+ code = pdfi_doc_EmbeddedFiles(ctx);
+ if (code < 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_TRAILER, "pdfi_doc_trailer", NULL);
+ if (ctx->args.pdfstoponerror)
+ goto exit;
+ }
+ }
+
+ /* Handle OCProperties */
+ /* NOTE: Apparently already handled by pdfi_read_OptionalRoot() */
+
+ /* Handle AcroForm -- this is some bookkeeping once per doc, not rendering them yet */
+ code = pdfi_doc_AcroForm(ctx);
+ if (code < 0) {
+ pdfi_set_warning(ctx, code, NULL, W_PDF_BAD_TRAILER, "pdfi_doc_trailer", NULL);
+ if (ctx->args.pdfstoponerror)
+ goto exit;
+ }
+
+ /* Handle OutputIntent ICC Profile */
+ code = pdfi_doc_OutputIntents(ctx);
+ if (code < 0) {
+ pdfi_set_warning(ctx, code, NULL, W_PDF_BAD_TRAILER, "pdfi_doc_trailer", NULL);
+ if (ctx->args.pdfstoponerror)
+ goto exit;
+ }
+
+ /* Handle PageLabels */
+ code = pdfi_doc_PageLabels(ctx);
+ if (code < 0) {
+ pdfi_set_warning(ctx, code, NULL, W_PDF_BAD_TRAILER, "pdfi_doc_trailer", NULL);
+ if (ctx->args.pdfstoponerror)
+ goto exit;
+ }
+
+ exit:
+ return code;
+}
diff --git a/pdf/pdf_doc.h b/pdf/pdf_doc.h
new file mode 100644
index 00000000..ed3deb80
--- /dev/null
+++ b/pdf/pdf_doc.h
@@ -0,0 +1,33 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+#ifndef PDF_DOC
+#define PDF_DOC
+
+int pdfi_read_Info(pdf_context *ctx);
+
+int pdfi_read_Root(pdf_context *ctx);
+void pdfi_read_OptionalRoot(pdf_context *ctx);
+void pdfi_free_OptionalRoot(pdf_context *ctx);
+
+int pdfi_read_Pages(pdf_context *ctx);
+int pdfi_get_page_dict(pdf_context *ctx, pdf_dict *d, uint64_t page_num, uint64_t *page_offset, pdf_dict **target, pdf_dict *inherited);
+int pdfi_find_resource(pdf_context *ctx, unsigned char *Type, pdf_name *name, pdf_dict *dict,
+ pdf_dict *page_dict, pdf_obj **o);
+int pdfi_doc_page_array_init(pdf_context *ctx);
+void pdfi_doc_page_array_free(pdf_context *ctx);
+int pdfi_doc_trailer(pdf_context *ctx);
+
+#endif
diff --git a/pdf/pdf_fapi.c b/pdf/pdf_fapi.c
new file mode 100644
index 00000000..df92acc4
--- /dev/null
+++ b/pdf/pdf_fapi.c
@@ -0,0 +1,1514 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Interface to FAPI for the PDF interpreter */
+
+/* Include this first so that we don't get a macro redefnition of 'offsetof' */
+#include "pdf_int.h"
+
+#include "memory_.h"
+#include "gsmemory.h"
+#include "gserrors.h"
+#include "gxdevice.h"
+#include "gxfont.h"
+#include "gxfont0.h"
+#include "gxfcid.h"
+
+#include "gzstate.h"
+#include "gxchar.h" /* for st_gs_show_enum */
+#include "gdebug.h"
+#include "gxfapi.h"
+#include "gscoord.h"
+#include "gspath.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_font.h"
+#include "pdf_font.h"
+#include "gscencs.h"
+#include "gsagl.h"
+#include "gxfont1.h" /* for gs_font_type1_s */
+#include "gscrypt1.h" /* for crypt_c1 */
+
+/* forward declarations for the pdfi_ff_stub definition */
+static int
+pdfi_fapi_get_word(gs_fapi_font *ff, gs_fapi_font_feature var_id, int index, unsigned short *ret);
+
+static int
+pdfi_fapi_get_long(gs_fapi_font * ff, gs_fapi_font_feature var_id, int index, unsigned long *ret);
+
+static int
+pdfi_fapi_get_float(gs_fapi_font *ff, gs_fapi_font_feature var_id, int index, float *ret);
+
+static int
+pdfi_fapi_get_name(gs_fapi_font *ff, gs_fapi_font_feature var_id, int index, char *buffer, int len);
+
+static int
+pdfi_fapi_get_proc(gs_fapi_font *ff, gs_fapi_font_feature var_id, int index, char *buffer);
+
+static int
+pdfi_fapi_get_gsubr(gs_fapi_font *ff, int index, byte *buf, int buf_length);
+
+static int
+pdfi_fapi_get_subr(gs_fapi_font *ff, int index, byte *buf, int buf_length);
+
+static int
+pdfi_fapi_get_raw_subr(gs_fapi_font *ff, int index, byte *buf, int buf_length);
+
+static int
+pdfi_fapi_serialize_tt_font(gs_fapi_font * ff, void *buf, int buf_size);
+
+static int
+pdfi_fapi_get_charstring(gs_fapi_font *ff, int index, byte *buf, ushort buf_length);
+
+static int
+pdfi_fapi_get_charstring_name(gs_fapi_font *ff, int index, byte *buf, ushort buf_length);
+
+
+static int
+pdfi_fapi_get_glyphname_or_cid(gs_text_enum_t *penum, gs_font_base * pbfont, gs_string * charstring,
+ gs_string * name, gs_glyph ccode, gs_string * enc_char_name,
+ char *font_file_path, gs_fapi_char_ref * cr, bool bCID);
+
+static int
+pdfi_fapi_get_glyph(gs_fapi_font * ff, gs_glyph char_code, byte * buf, int buf_length);
+
+
+static int
+pdfi_get_glyphdirectory_data(gs_fapi_font * ff, int char_code,
+ const byte ** ptr);
+
+static int
+pdfi_fapi_set_cache(gs_text_enum_t * penum, const gs_font_base * pbfont,
+ const gs_string * char_name, gs_glyph cid,
+ const double pwidth[2], const gs_rect * pbbox,
+ const double Metrics2_sbw_default[4], bool * imagenow);
+
+static int
+pdfi_fapi_get_metrics(gs_fapi_font * ff, gs_string * char_name, gs_glyph cid, double *m, bool vertical);
+
+static const gs_fapi_font pdfi_ff_stub = {
+ 0, /* server_font_data */
+ 0, /* need_decrypt */
+ NULL, /* const gs_memory_t */
+ 0, /* font_file_path */
+ 0, /* full_font_buf */
+ 0, /* full_font_buf_len */
+ 0, /* subfont */
+ false, /* is_type1 */
+ false, /* is_cid */
+ false, /* is_outline_font */
+ false, /* is_mtx_skipped */
+ false, /* is_vertical */
+ false, /* metrics_only */
+ {{3, 1}, {1, 0}, {3, 0}, {3, 10}, {-1, -1}}, /* ttf_cmap_req */
+ {-1, -1}, /* ttf_cmap_selected */
+ 0, /* client_ctx_p */
+ 0, /* client_font_data */
+ 0, /* client_font_data2 */
+ 0, /* char_data */
+ 0, /* char_data_len */
+ 0, /* embolden */
+ pdfi_fapi_get_word, /* get_word */
+ pdfi_fapi_get_long, /* get_long */
+ pdfi_fapi_get_float, /* get_float */
+ pdfi_fapi_get_name, /* get_name */
+ pdfi_fapi_get_proc, /* get_proc */
+ pdfi_fapi_get_gsubr, /* get_gsubr */
+ pdfi_fapi_get_subr, /* get_subr */
+ pdfi_fapi_get_raw_subr, /* get_raw_subr */
+ pdfi_fapi_get_glyph, /* get_glyph */
+ pdfi_fapi_serialize_tt_font, /* serialize_tt_font */
+ pdfi_fapi_get_charstring, /* get_charstring */
+ pdfi_fapi_get_charstring_name, /* get_charstring_name */
+ pdfi_get_glyphdirectory_data, /* get_GlyphDirectory_data_ptr */
+ pdfi_fapi_get_glyphname_or_cid, /* get_glyphname_or_cid */
+ pdfi_fapi_get_metrics, /* fapi_get_metrics */
+ pdfi_fapi_set_cache /* fapi_set_cache */
+};
+
+static inline ushort
+float_to_ushort(float v)
+{
+ return ((ushort) (v * 16)); /* fixme : the scale may depend on renderer */
+}
+
+static int
+pdfi_fapi_get_word(gs_fapi_font *ff, gs_fapi_font_feature var_id, int index, unsigned short *ret)
+{
+ int code = 0;
+ gs_font_type1 *pfont = (gs_font_type1 *) ff->client_font_data;
+
+ switch ((int)var_id) {
+ case gs_fapi_font_feature_Weight:
+ *ret = 0; /* wrong */
+ break;
+ case gs_fapi_font_feature_ItalicAngle:
+ *ret = 0; /* wrong */
+ break;
+ case gs_fapi_font_feature_IsFixedPitch:
+ *ret = 0; /* wrong */
+ break;
+ case gs_fapi_font_feature_UnderLinePosition:
+ *ret = 0; /* wrong */
+ break;
+ case gs_fapi_font_feature_UnderlineThickness:
+ *ret = 0; /* wrong */
+ break;
+ case gs_fapi_font_feature_FontType:
+ *ret = (pfont->FontType == 2 ? 2 : 1);
+ break;
+ case gs_fapi_font_feature_FontBBox:
+ switch (index) {
+ case 0:
+ *ret = ((ushort) pfont->FontBBox.p.x);
+ break;
+ case 1:
+ *ret = ((ushort) pfont->FontBBox.p.y);
+ break;
+ case 2:
+ *ret = ((ushort) pfont->FontBBox.q.x);
+ break;
+ case 3:
+ *ret = ((ushort) pfont->FontBBox.q.y);
+ break;
+ default:
+ code = gs_note_error(gs_error_rangecheck);
+ }
+ break;
+ case gs_fapi_font_feature_BlueValues_count:
+ *ret = pfont->data.BlueValues.count;
+ break;
+ case gs_fapi_font_feature_BlueValues:
+ *ret = (float_to_ushort(pfont->data.BlueValues.values[index]));
+ break;
+ case gs_fapi_font_feature_OtherBlues_count:
+ *ret = pfont->data.OtherBlues.count;
+ break;
+ case gs_fapi_font_feature_OtherBlues:
+ *ret = (float_to_ushort(pfont->data.OtherBlues.values[index]));
+ break;
+ case gs_fapi_font_feature_FamilyBlues_count:
+ *ret = pfont->data.FamilyBlues.count;
+ break;
+ case gs_fapi_font_feature_FamilyBlues:
+ *ret = (float_to_ushort(pfont->data.FamilyBlues.values[index]));
+ break;
+ case gs_fapi_font_feature_FamilyOtherBlues_count:
+ *ret = pfont->data.FamilyOtherBlues.count;
+ break;
+ case gs_fapi_font_feature_FamilyOtherBlues:
+ *ret = (float_to_ushort(pfont->data.FamilyOtherBlues.values[index]));
+ break;
+ case gs_fapi_font_feature_BlueShift:
+ *ret = float_to_ushort(pfont->data.BlueShift);
+ break;
+ case gs_fapi_font_feature_BlueFuzz:
+ *ret = float_to_ushort(pfont->data.BlueShift);
+ break;
+ case gs_fapi_font_feature_StdHW:
+ *ret = (pfont->data.StdHW.count == 0 ? 0 : float_to_ushort(pfont->data.StdHW.values[0])); /* UFST bug ? */
+ break;
+ case gs_fapi_font_feature_StdVW:
+ *ret = (pfont->data.StdVW.count == 0 ? 0 : float_to_ushort(pfont->data.StdVW.values[0])); /* UFST bug ? */
+ break;
+ case gs_fapi_font_feature_StemSnapH_count:
+ *ret = pfont->data.StemSnapH.count;
+ break;
+ case gs_fapi_font_feature_StemSnapH:
+ *ret = float_to_ushort(pfont->data.StemSnapH.values[index]);
+ break;
+ case gs_fapi_font_feature_StemSnapV_count:
+ *ret = pfont->data.StemSnapV.count;
+ break;
+ case gs_fapi_font_feature_StemSnapV:
+ *ret = float_to_ushort(pfont->data.StemSnapV.values[index]);
+ break;
+ case gs_fapi_font_feature_ForceBold:
+ *ret = pfont->data.ForceBold;
+ break;
+ case gs_fapi_font_feature_LanguageGroup:
+ *ret = pfont->data.LanguageGroup;
+ break;
+ case gs_fapi_font_feature_lenIV:
+ *ret = ff->need_decrypt ? 0 : pfont->data.lenIV;
+ break;
+ case gs_fapi_font_feature_GlobalSubrs_count:
+ {
+ if (pfont->FontType == ft_encrypted2) {
+ pdf_font_cff *pdffont2 = (pdf_font_cff *)pfont->client_data;
+ *ret = pdffont2->NumGlobalSubrs;
+ }
+ else {
+ *ret = 0;
+ code = gs_note_error(gs_error_invalidaccess);
+ }
+ break;
+ }
+ case gs_fapi_font_feature_Subrs_count:
+ {
+ if (pfont->FontType == ft_encrypted) {
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *)pfont->client_data;
+ *ret = pdffont1->NumSubrs;
+ }
+ else if (pfont->FontType == ft_encrypted2) {
+ pdf_font_cff *pdffont2 = (pdf_font_cff *)pfont->client_data;
+ *ret = pdffont2->NumSubrs;
+ }
+ else {
+ *ret = 0;
+ code = gs_note_error(gs_error_invalidaccess);
+ }
+ break;
+ }
+ case gs_fapi_font_feature_CharStrings_count:
+ {
+ if (pfont->FontType == ft_encrypted) {
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *)pfont->client_data;
+ *ret = pdffont1->CharStrings->entries;
+ }
+ break;
+ }
+ case gs_fapi_font_feature_BlendBlueValues_length:
+ case gs_fapi_font_feature_BlendOtherBlues_length:
+ case gs_fapi_font_feature_BlendOtherBlues_count:
+ case gs_fapi_font_feature_BlendBlueScale_count:
+ case gs_fapi_font_feature_BlendBlueShift_count:
+ case gs_fapi_font_feature_BlendBlueShift:
+ case gs_fapi_font_feature_BlendBlueFuzz_count:
+ case gs_fapi_font_feature_BlendBlueFuzz:
+ case gs_fapi_font_feature_BlendForceBold_count:
+ case gs_fapi_font_feature_BlendForceBold:
+ case gs_fapi_font_feature_BlendStdHW_length:
+ case gs_fapi_font_feature_BlendStdHW_count:
+ case gs_fapi_font_feature_BlendStdHW:
+ case gs_fapi_font_feature_BlendStdVW_length:
+ case gs_fapi_font_feature_BlendStdVW_count:
+ case gs_fapi_font_feature_BlendStdVW:
+ case gs_fapi_font_feature_BlendStemSnapH_length:
+ case gs_fapi_font_feature_BlendStemSnapH_count:
+ case gs_fapi_font_feature_BlendStemSnapH:
+ case gs_fapi_font_feature_BlendStemSnapV_length:
+ case gs_fapi_font_feature_BlendStemSnapV_count:
+ case gs_fapi_font_feature_BlendStemSnapV:
+ {
+ code = 0;
+ *ret = 0;
+ }
+ break;
+ case gs_fapi_font_feature_DollarBlend:
+ {
+ if (pfont->data.WeightVector.count > 0) { /* If count > 0, it's MM font, and we "have" a $Blend */
+ *ret = 1;
+ }
+ else {
+ *ret = 0;
+ }
+ }
+ break;
+ case gs_fapi_font_feature_DollarBlend_length:
+ {
+ /* Use the built-in boiler plate */
+ *ret = 0;
+ }
+ break;
+ case gs_fapi_font_feature_BlendAxisTypes_count:
+ {
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *)pfont->client_data;
+ if (pdffont1->blendaxistypes != NULL) {
+ *ret = (unsigned short)pdffont1->blendaxistypes->size;
+ }
+ else {
+ *ret = 0;
+ }
+ }
+ break;
+ case gs_fapi_font_feature_WeightVector_count:
+ {
+ *ret = (unsigned short)pfont->data.WeightVector.count;
+ }
+ break;
+ case gs_fapi_font_feature_BlendDesignPositionsArrays_count:
+ {
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *)pfont->client_data;
+ if (pdffont1->blenddesignpositions != NULL) {
+ *ret = (unsigned short)pdffont1->blenddesignpositions->size;
+ }
+ else {
+ *ret = 0;
+ }
+ }
+ break;
+ case gs_fapi_font_feature_BlendDesignMapArrays_count:
+ {
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *)pfont->client_data;
+ if (pdffont1->blenddesignmap != NULL) {
+ *ret = (unsigned short)pdffont1->blenddesignmap->size;
+ }
+ else {
+ *ret = 0;
+ }
+ }
+ break;
+ case gs_fapi_font_feature_BlendDesignMapSubArrays_count:
+ {
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *)pfont->client_data;
+ if (pdffont1->blenddesignmap != NULL) {
+ pdf_array *suba;
+ code = pdfi_array_get(pdffont1->ctx, pdffont1->blenddesignmap, index, (pdf_obj **)&suba);
+ if (code < 0) {
+ *ret = 0;
+ break;
+ }
+ *ret = (unsigned short)suba->size;
+ pdfi_countdown(suba);
+ }
+ else {
+ *ret = 0;
+ }
+ }
+ break;
+ case gs_fapi_font_feature_BlendFontBBox_length:
+ {
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *)pfont->client_data;
+ if (pdffont1->blendfontbbox != NULL) {
+ *ret = (unsigned short)pdffont1->blendfontbbox->size;
+ }
+ else {
+ *ret = 0;
+ }
+ }
+ break;
+ case gs_fapi_font_feature_BlendFontBBox:
+ {
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *)pfont->client_data;
+ if (pdffont1->blendfontbbox != NULL) {
+ pdf_array *suba;
+ pdf_num *v;
+ int ind, aind;
+ ind = index % 4;
+ aind = (index - ind) / 4;
+ code = pdfi_array_get(pdffont1->ctx, pdffont1->blendfontbbox, aind, (pdf_obj **)&suba);
+ if (code < 0) {
+ *ret = 0;
+ break;
+ }
+ code = pdfi_array_get(pdffont1->ctx, suba, ind, (pdf_obj **)&v);
+ pdfi_countdown(suba);
+ if (code < 0) {
+ *ret = 0;
+ break;
+ }
+ if (v->type == PDF_INT)
+ *ret = (unsigned short)v->value.i;
+ else
+ *ret = (unsigned short)v->value.d;
+ pdfi_countdown(v);
+ }
+ else {
+ *ret = 0;
+ }
+ }
+ break;
+ default:
+ code = gs_error_undefined;
+ *ret = -1;
+ }
+ return code;
+}
+
+static int
+pdfi_fapi_get_long(gs_fapi_font * ff, gs_fapi_font_feature var_id, int index, unsigned long *ret)
+{
+ gs_font_type1 *pfont = (gs_font_type1 *) ff->client_font_data;
+ int code = 0;
+
+ switch ((int)var_id) {
+ case gs_fapi_font_feature_UniqueID:
+ *ret = pfont->UID.id;
+ break;
+ case gs_fapi_font_feature_BlueScale:
+ *ret = (ulong) (pfont->data.BlueScale * 65536);
+ break;
+ case gs_fapi_font_feature_Subrs_total_size:
+ {
+ if (pfont->FontType == ft_encrypted) {
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *)pfont->client_data;
+ int i;
+ *ret = 0;
+ for (i = 0; i < pdffont1->NumSubrs; i++) {
+ *ret += pdffont1->Subrs[i].size;
+ }
+ }
+ }
+ break;
+ default:
+ code = gs_error_undefined;
+ break;
+ }
+ return code;
+}
+
+static int
+pdfi_fapi_get_float(gs_fapi_font *ff, gs_fapi_font_feature var_id, int index, float *ret)
+{
+ gs_font_base *pbfont = (gs_font_base *) ff->client_font_data2;
+ int code = 0;
+ gs_fapi_server *I = pbfont->FAPI;
+
+ switch ((int)var_id) {
+ case gs_fapi_font_feature_FontMatrix:
+ {
+ double FontMatrix_div;
+ gs_matrix m, *mptr;
+
+ if (I && I->get_fontmatrix) {
+ FontMatrix_div = 1;
+ mptr = &m;
+ I->get_fontmatrix(I, mptr);
+ }
+ else {
+ FontMatrix_div = ((ff->is_cid && (!FAPI_ISCIDFONT(pbfont))) ? 1000 : 1);
+ mptr = &(pbfont->base->FontMatrix);
+ }
+ switch (index) {
+ case 0:
+ default:
+ *ret = (mptr->xx / FontMatrix_div);
+ break;
+ case 1:
+ *ret = (mptr->xy / FontMatrix_div);
+ break;
+ case 2:
+ *ret = (mptr->yx / FontMatrix_div);
+ break;
+ case 3:
+ *ret = (mptr->yy / FontMatrix_div);
+ break;
+ case 4:
+ *ret = (mptr->tx / FontMatrix_div);
+ break;
+ case 5:
+ *ret = (mptr->ty / FontMatrix_div);
+ break;
+ }
+ break;
+ }
+ case gs_fapi_font_feature_WeightVector:
+ {
+ gs_font_type1 *pfont1 = (gs_font_type1 *) pbfont;
+ if (index < pfont1->data.WeightVector.count) {
+ *ret = pfont1->data.WeightVector.values[index];
+ }
+ else {
+ *ret = 0;
+ }
+ }
+ break;
+ case gs_fapi_font_feature_BlendDesignPositionsArrayValue:
+ {
+ int array_index, subind;
+ pdf_array *suba;
+ pdf_num *v;
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *)pbfont->client_data;
+ *ret = 0;
+
+ code = pdfi_array_get(pdffont1->ctx, pdffont1->blenddesignpositions, 0, (pdf_obj **)&suba);
+ if (code < 0)
+ break;
+
+ /* The FAPI code assumes gs style storage - i.e. it allocates the maximum number of entries
+ permissable by the spec, and fills in only those required.
+ pdfi doesn't, so we unpick that here
+ */
+ index = (index % 8) + (suba->size * index / 8);
+
+ array_index = index / suba->size;
+ subind = index % suba->size;
+ pdfi_countdown(suba);
+ code = pdfi_array_get(pdffont1->ctx, pdffont1->blenddesignpositions, array_index, (pdf_obj**)&suba);
+ if (code < 0) {
+ code = 0;
+ break;
+ }
+
+ code = pdfi_array_get(pdffont1->ctx, suba, subind, (pdf_obj**)&v);
+ pdfi_countdown(suba);
+ if (code < 0) {
+ code = 0;
+ break;
+ }
+ if (v->type == PDF_INT) {
+ *ret = v->value.i;
+ }
+ else {
+ *ret = (float)v->value.d;
+ }
+ pdfi_countdown(v);
+ }
+ break;
+ case gs_fapi_font_feature_BlendDesignMapArrayValue:
+ {
+ int i, j, k;
+ pdf_array *suba, *subsuba;
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *)pbfont->client_data;
+ *ret = (float)0;
+ code = 0;
+
+ for (i = 0; i < pdffont1->blenddesignmap->size && code >= 0; i++) {
+ code = pdfi_array_get(pdffont1->ctx, pdffont1->blenddesignmap, i, (pdf_obj **)&suba);
+ if (code < 0)
+ continue;
+ for (j = 0; j < suba->size && code >= 0; j++) {
+ code = pdfi_array_get(pdffont1->ctx, suba, i, (pdf_obj **)&subsuba);
+ if (code < 0)
+ continue;
+ for (k = 0; k < subsuba->size && code >= 0; k++) {
+ /* The FAPI code assumes gs style storage - i.e. it allocates the maximum number of entries
+ permissable by the spec, and fills in only those required.
+ pdfi doesn't, hence the multiplications by 64.
+ */
+ if ((i * 64) + (j * 64) + k == index) {
+ pdf_num *n;
+ code = pdfi_array_get(pdffont1->ctx, suba, i, (pdf_obj **)&n);
+ if (code < 0)
+ continue;
+ if (n->type == PDF_INT)
+ *ret = (float)n->value.i;
+ else
+ *ret = (float)n->value.d;
+ pdfi_countdown(n);
+ pdfi_countdown(subsuba);
+ pdfi_countdown(suba);
+ goto gotit;
+ }
+ }
+ pdfi_countdown(subsuba);
+ }
+ pdfi_countdown(suba);
+ }
+ code = 0;
+ }
+gotit:
+ break;
+
+ default:
+ code = gs_error_undefined;
+ }
+
+ return code;
+}
+
+/* Only required for multiple masters, I believe. Buffer is guaranteed to exist */
+static int
+pdfi_fapi_get_name(gs_fapi_font *ff, gs_fapi_font_feature var_id, int index, char *buffer, int len)
+{
+ gs_font_base *pbfont = (gs_font_base *) ff->client_font_data2;
+ int code = 0;
+
+ switch ((int)var_id) {
+ case gs_fapi_font_feature_BlendAxisTypes:
+ {
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *)pbfont->client_data;
+ pdf_name *n;
+ code = pdfi_array_get(pdffont1->ctx, pdffont1->blendaxistypes, index, (pdf_obj **)&n);
+ if (code < 0)
+ break;
+ if (n->length <= len - 1) {
+ memcpy(buffer, n->data, n->length);
+ buffer[n->length] = '\0';
+ }
+ else
+ code = gs_error_limitcheck;
+ pdfi_countdown(n);
+ }
+ break;
+ default:
+ code = gs_error_undefined;
+ }
+ return code;
+}
+
+/* Only required for multiple masters, I believe */
+static int
+pdfi_fapi_get_proc(gs_fapi_font *ff, gs_fapi_font_feature var_id, int index, char *buffer)
+{
+ int code = 0;
+
+ (void)index;
+ (void)buffer;
+
+ switch ((int)var_id) {
+ case gs_fapi_font_feature_DollarBlend:
+ break;
+ default:
+ code = gs_error_undefined;
+ }
+ return code;
+}
+
+static inline void
+decode_bytes(byte *p, const byte *s, int l, int lenIV)
+{
+ ushort state = 4330;
+
+ for (; l; s++, l--) {
+ uchar c = (*s ^ (state >> 8));
+
+ state = (*s + state) * crypt_c1 + crypt_c2;
+ if (lenIV > 0)
+ lenIV--;
+ else {
+ *p = c;
+ p++;
+ }
+ }
+}
+
+static int
+pdfi_fapi_get_gsubr(gs_fapi_font *ff, int index, byte *buf, int buf_length)
+{
+ gs_font_type1 *pfont = (gs_font_type1 *) ff->client_font_data;
+ int code = 0;
+ if (pfont->FontType == ft_encrypted2) {
+ pdf_font_cff *pdffont2 = (pdf_font_cff *)pfont->client_data;
+ if (index > pdffont2->NumGlobalSubrs) {
+ code = gs_error_rangecheck;
+ }
+ else {
+ int leniv = (pfont->data.lenIV > 0 ? pfont->data.lenIV : 0);
+ pdf_string *subrstring;
+
+ code = pdfi_array_get(pdffont2->ctx, pdffont2->GlobalSubrs, index, (pdf_obj **)&subrstring);
+ if (code >= 0) {
+ code = subrstring->length - leniv;
+ if (buf && buf_length >= code) {
+ if (ff->need_decrypt && pfont->data.lenIV >= 0) {
+ decode_bytes(buf, subrstring->data, code + leniv, pfont->data.lenIV);
+ }
+ else {
+ memcpy(buf, subrstring->data, code);
+ }
+ }
+ pdfi_countdown(subrstring);
+ }
+ }
+ }
+ else {
+ code = gs_note_error(gs_error_invalidfont);
+ }
+ return code;
+}
+
+static int
+pdfi_fapi_get_subr(gs_fapi_font *ff, int index, byte *buf, int buf_length)
+{
+ gs_font_type1 *pfont = (gs_font_type1 *) ff->client_font_data;
+ int code = 0;
+
+ if (pfont->FontType == ft_encrypted) {
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *)pfont->client_data;
+ if (index > pdffont1->NumSubrs) {
+ code = gs_note_error(gs_error_rangecheck);
+ }
+ else {
+ int leniv = (pfont->data.lenIV > 0 ? pfont->data.lenIV : 0);
+ if (pdffont1->Subrs[index].size > 0) {
+ code = pdffont1->Subrs[index].size - leniv;
+ if (buf && buf_length >= code) {
+ if (ff->need_decrypt && pfont->data.lenIV >= 0) {
+ decode_bytes(buf, pdffont1->Subrs[index].data, code + leniv, pfont->data.lenIV);
+ }
+ else {
+ memcpy(buf, pdffont1->Subrs[index].data, code);
+ }
+ }
+ }
+ }
+ }
+ else if (pfont->FontType == ft_encrypted2) {
+ pdf_font_cff *pdffont2 = (pdf_font_cff *)pfont->client_data;
+ if (index > pdffont2->NumSubrs) {
+ code = gs_error_rangecheck;
+ }
+ else {
+ int leniv = (pfont->data.lenIV > 0 ? pfont->data.lenIV : 0);
+ pdf_string *subrstring;
+
+ code = pdfi_array_get(pdffont2->ctx, pdffont2->Subrs, index, (pdf_obj **)&subrstring);
+ if (code >= 0) {
+ if (subrstring->length > 0) {
+ code = subrstring->length - leniv;
+ if (buf && buf_length >= code) {
+ if (ff->need_decrypt && pfont->data.lenIV >= 0) {
+ decode_bytes(buf, subrstring->data, code + leniv, pfont->data.lenIV);
+ }
+ else {
+ memcpy(buf, subrstring->data, code);
+ }
+ }
+ }
+ pdfi_countdown(subrstring);
+ }
+ }
+ }
+ else {
+ code = gs_note_error(gs_error_invalidfont);
+ }
+ return code;
+}
+
+static int
+pdfi_fapi_get_raw_subr(gs_fapi_font *ff, int index, byte *buf, int buf_length)
+{
+ gs_font_type1 *pfont = (gs_font_type1 *) ff->client_font_data;
+ int code = 0;
+
+ if (pfont->FontType == ft_encrypted) {
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *)pfont->client_data;
+ if (index > pdffont1->NumSubrs) {
+ code = gs_error_rangecheck;
+ }
+ else {
+ code = pdffont1->Subrs[index].size;
+ if (buf && buf_length >= code) {
+ memcpy(buf, pdffont1->Subrs[index].data, code);
+ }
+ }
+ }
+ return code;
+}
+
+static int
+pdfi_fapi_get_charstring(gs_fapi_font *ff, int index, byte *buf, ushort buf_length)
+{
+ return 0;
+}
+
+static int
+pdfi_fapi_get_charstring_name(gs_fapi_font *ff, int index, byte *buf, ushort buf_length)
+{
+ return 0;
+}
+
+extern single_glyph_list_t SingleGlyphList[];
+
+static int
+pdfi_fapi_get_glyphname_or_cid(gs_text_enum_t *penum, gs_font_base * pbfont, gs_string * charstring,
+ gs_string * name, gs_glyph ccode, gs_string * enc_char_name,
+ char *font_file_path, gs_fapi_char_ref * cr, bool bCID)
+{
+ gs_fapi_server *I = pbfont->FAPI;
+ int code = 0;
+ pdf_context *ctx = (pdf_context *) ((pdf_font *)pbfont->client_data)->ctx;
+
+ if (pbfont->FontType == ft_CID_TrueType) {
+ pdf_cidfont_type2 *pttfont = (pdf_cidfont_type2 *)pbfont->client_data;
+ gs_glyph gid;
+
+ if (ccode >= GS_MIN_CID_GLYPH)
+ ccode = ccode - GS_MIN_CID_GLYPH;
+
+ if (pttfont->substitute == false) {
+ gid = ccode;
+ if (pttfont->cidtogidmap.size > (ccode << 1) + 1) {
+ gid = pttfont->cidtogidmap.data[ccode << 1] << 8 | pttfont->cidtogidmap.data[(ccode << 1) + 1];
+ }
+ cr->client_char_code = ccode;
+ cr->char_codes[0] = gid;
+ cr->is_glyph_index = true;
+ }
+ else { /* If the composite font has a decoding, then this is a subsituted CIDFont with a "known" ordering */
+ unsigned int gc = 0, cc = (unsigned int)ccode;
+ byte uc[4];
+ int l;
+
+ if (penum->text.operation & TEXT_FROM_SINGLE_CHAR) {
+ cc = penum->text.data.d_char;
+ } else if (penum->text.operation & TEXT_FROM_SINGLE_GLYPH) {
+ cc = penum->text.data.d_glyph - GS_MIN_CID_GLYPH;
+ }
+ else {
+ byte *c = (byte *)&penum->text.data.bytes[penum->index - penum->bytes_decoded];
+ int i;
+ cc = 0;
+ for (i = 0; i < penum->bytes_decoded ; i++) {
+ cc |= c[i] << ((penum->bytes_decoded - 1) - i) * 8;
+ }
+ }
+
+ l = penum->orig_font->procs.decode_glyph((gs_font *)penum->orig_font, ccode, (gs_char)cc, (ushort *)uc, 4);
+ if (l == 2) {
+ cc = uc[1] | uc[0] << 8;
+ }
+ else if (l == 4) {
+ cc = uc[3] | uc[2] << 8 | uc[2] << 16 | uc[2] << 24;
+ }
+ else
+ cc = ccode;
+ /* All known cmap tables map 32 to the space glyph, so if it looks like
+ we're going to use a notdef, then substitute the glyph for the code point 32
+ */
+ if (l != 0) {
+ code = pdfi_fapi_check_cmap_for_GID((gs_font *)pbfont, cc, &gc);
+ if (code < 0 || gc == 0)
+ (void)pdfi_fapi_check_cmap_for_GID((gs_font *)pbfont, 32, &gc);
+ }
+ else {
+ if (ccode == 0) {
+ (void)pdfi_fapi_check_cmap_for_GID((gs_font *)pbfont, 32, &gc);
+ }
+ else {
+ gc = ccode;
+ }
+ }
+
+ cr->client_char_code = ccode;
+ cr->char_codes[0] = gc;
+ cr->is_glyph_index = true;
+ }
+ return 0;
+ }
+ /* For cff based CIDFonts (and thus "Type 1" based CIDFonts, since the code
+ * is common to both) and cff fonts we only claim to the FAPI server that
+ * we have one (or two?) glyphs, because it makes the "stub" font simpler.
+ * But Freetype bounds checks the character code (or gid) against the number
+ * of glyphs in the font *before* asking us for the glyph data. So we need
+ * to extract the charstring here, store it in the fapi font, and unpack it
+ * in pdfi_fapi_get_glyph(), so we can then claim we're always rendering glyph
+ * index zero, and thus pass the bounds check.
+ */
+ else if (penum->current_font->FontType == ft_CID_encrypted) {
+ gs_font_cid0 *pfont9 = (gs_font_cid0 *)penum->current_font;
+ gs_glyph_data_t gd;
+ int f_ind;
+
+ code = (*pfont9->cidata.glyph_data)((gs_font_base *)pfont9, ccode, &gd, &f_ind);
+ if (code < 0) {
+ code = (*pfont9->cidata.glyph_data)((gs_font_base *)pfont9, 0, &gd, &f_ind);
+ }
+ if (code < 0)
+ return_error(gs_error_invalidfont);
+
+ I->ff.char_data = (void *)gd.bits.data;
+ I->ff.char_data_len = gd.bits.size;
+
+ cr->client_char_code = 0;
+ cr->char_codes[0] = 0;
+ cr->is_glyph_index = true;
+ I->ff.client_font_data2 = penum->fstack.items[penum->fstack.depth].font;
+
+ return 0;
+ }
+ else if (pbfont->FontType == ft_encrypted2) {
+ pdf_font_cff *cfffont = (pdf_font_cff *)pbfont->client_data;
+ pdf_name *glyphname = NULL;
+ pdf_string *charstring = NULL;
+ gs_const_string gname;
+
+ code = (*ctx->get_glyph_name)((gs_font *)pbfont, ccode, &gname);
+ if (code >= 0) {
+ code = pdfi_name_alloc(ctx, (byte *) gname.data, gname.size, (pdf_obj **) &glyphname);
+ if (code >= 0)
+ pdfi_countup(glyphname);
+ }
+
+ if (code < 0) {
+ pdfi_countdown(glyphname);
+ return code;
+ }
+ code = pdfi_dict_get_by_key(cfffont->ctx, cfffont->CharStrings, glyphname, (pdf_obj **)&charstring);
+ pdfi_countdown(glyphname);
+ if (code < 0) {
+ code = pdfi_dict_get(cfffont->ctx, cfffont->CharStrings, ".notdef", (pdf_obj **)&charstring);
+ }
+ if (code < 0)
+ return code;
+
+ I->ff.char_data = charstring->data;
+ I->ff.char_data_len = charstring->length;
+
+ cr->client_char_code = 0;
+ cr->char_codes[0] = 0;
+ cr->is_glyph_index = true;
+
+ pdfi_countdown(charstring);
+ return code;
+ }
+ else if (pbfont->FontType == ft_TrueType) {
+ /* I'm not clear if the heavy lifting should be here or in pdfi_tt_encode_char() */
+ pdf_font_truetype *ttfont = (pdf_font_truetype *)pbfont->client_data;
+ pdf_name *GlyphName = NULL;
+ gs_const_string gname;
+ int i;
+ uint cc = 0;
+ if ((ttfont->descflags & 4) != 0) {
+ if (ttfont->cmap == pdfi_truetype_cmap_30) {
+
+ ccode = cr->client_char_code;
+ code = pdfi_fapi_check_cmap_for_GID((gs_font *)pbfont, (uint)ccode, &cc);
+ if (code < 0 || cc == 0)
+ cr->char_codes[0] = ccode | 0xf0 << 8;
+ else
+ cr->char_codes[0] = ccode;
+ cr->is_glyph_index = false;
+ }
+ else {
+ cr->char_codes[0] = cr->client_char_code;
+ cr->is_glyph_index = false;
+ }
+ }
+ else {
+
+ code = (*ctx->get_glyph_name)((gs_font *)pbfont, ccode, &gname);
+ if (code >= 0) {
+ code = pdfi_name_alloc(ctx, (byte *) gname.data, gname.size, (pdf_obj **) &GlyphName);
+ if (code >= 0)
+ pdfi_countup(GlyphName);
+ }
+
+ cr->char_codes[0] = cr->client_char_code;
+ cr->is_glyph_index = false;
+ if (code < 0)
+ return 0;
+
+ if (ttfont->cmap == pdfi_truetype_cmap_10) {
+ gs_glyph g;
+
+ g = gs_c_name_glyph((const byte *)GlyphName->data, GlyphName->length);
+ if (g != GS_NO_GLYPH) {
+ g = (gs_glyph)gs_c_decode(g, ENCODING_INDEX_MACROMAN);
+ }
+ else {
+ g = GS_NO_CHAR;
+ }
+
+ if (g != GS_NO_CHAR) {
+ code = pdfi_fapi_check_cmap_for_GID((gs_font *)pbfont, (uint)g, &cc);
+ }
+
+ if (code < 0 || cc == 0) {
+ gs_font_type42 *pfonttt = (gs_font_type42 *)pbfont;
+ gs_string gname = {0};
+
+ /* This is a very slow implementation, we may benefit from creating a
+ * a reverse post table upfront */
+ for (i = 0; i < pfonttt->data.numGlyphs; i++) {
+ code = gs_type42_find_post_name(pfonttt, (gs_glyph)i, &gname);
+ if (code >= 0) {
+ if (gname.data[0] == GlyphName->data[0]
+ && gname.size == GlyphName->length
+ && !strncmp((char *)gname.data, (char *)GlyphName->data, GlyphName->length))
+ {
+ cr->char_codes[0] = i;
+ cr->is_glyph_index = true;
+ break;
+ }
+ }
+ }
+ }
+ else {
+ cr->char_codes[0] = g;
+ cr->is_glyph_index = false;
+ }
+ }
+ else if (ttfont->cmap == pdfi_truetype_cmap_31) {
+ unsigned int cc;
+ single_glyph_list_t *sgl = (single_glyph_list_t *)&(SingleGlyphList);
+ /* Not to spec, but... if we get a "uni..." formatted name, use
+ the hex value from that.
+ */
+ if (GlyphName->length > 5 && !strncmp((char *)GlyphName->data, "uni", 3)) {
+ char gnbuf[64];
+ int l = (GlyphName->length - 3) > 63 ? 63 : GlyphName->length - 3;
+
+ memcpy(gnbuf, GlyphName->data + 3, l);
+ gnbuf[l] = '\0';
+ l = sscanf(gnbuf, "%x", &cc);
+ if (l > 0)
+ cr->char_codes[0] = cc;
+ else
+ cr->char_codes[0] = 0;
+ }
+ else {
+ /* Slow linear search, we could binary chop it */
+ for (i = 0; sgl[i].Glyph != 0x00; i++) {
+ if (sgl[i].Glyph[0] == GlyphName->data[0]
+ && strlen(sgl[i].Glyph) == GlyphName->length
+ && !strncmp((char *)sgl[i].Glyph, (char *)GlyphName->data, GlyphName->length))
+ break;
+ }
+ if (sgl[i].Glyph != NULL) {
+ code = pdfi_fapi_check_cmap_for_GID((gs_font *)pbfont, (uint)sgl[i].Unicode, &cc);
+ if (code < 0 || cc == 0)
+ cc = 0;
+ else
+ cc = sgl[i].Unicode;
+ }
+ else
+ cc = 0;
+
+ if (cc == 0) {
+ gs_font_type42 *pfonttt = (gs_font_type42 *)pbfont;
+ gs_string gname = {0};
+
+ /* This is a very slow implementation, we may benefit from creating a
+ * a reverse post table upfront */
+ for (i = 0; i < pfonttt->data.numGlyphs; i++) {
+ code = gs_type42_find_post_name(pfonttt, (gs_glyph)i, &gname);
+ if (code >= 0) {
+ if (gname.data[0] == GlyphName->data[0]
+ && gname.size == GlyphName->length
+ && !strncmp((char *)gname.data, (char *)GlyphName->data, GlyphName->length))
+ {
+ cr->char_codes[0] = i;
+ cr->is_glyph_index = true;
+ break;
+ }
+ }
+ }
+ }
+ else {
+ cr->char_codes[0] = cc;
+ cr->is_glyph_index = false;
+ }
+ }
+ }
+ pdfi_countdown(GlyphName);
+ return 0;
+ }
+ }
+ else if (pbfont->FontType == ft_encrypted) {
+ gs_const_string gname;
+ code = (*ctx->get_glyph_name)((gs_font *)pbfont, ccode, &gname);
+ I->ff.char_data = enc_char_name->data = (byte *)gname.data;
+ I->ff.char_data_len = enc_char_name->size = gname.size;
+ cr->is_glyph_index = false;
+ }
+ return code;
+}
+
+static int
+pdfi_fapi_get_glyph(gs_fapi_font * ff, gs_glyph char_code, byte * buf, int buf_length)
+{
+ gs_font_base *pbfont = (gs_font_base *) ff->client_font_data2;
+ gs_fapi_server *I = pbfont->FAPI;
+ int code = 0;
+ pdf_name *encn;
+ int cstrlen = 0;
+
+ /* This should only get called for Postscript-type fonts */
+ if (ff->is_type1) {
+
+ if (pbfont->FontType == ft_encrypted) {
+ gs_font_type1 *pfont1 = (gs_font_type1 *) pbfont;
+ pdf_name *glyphname = NULL;
+ pdf_string *charstring = NULL;
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *)pbfont->client_data;
+ int leniv = pfont1->data.lenIV > 0 ? pfont1->data.lenIV : 0;
+
+ if (I->ff.char_data != NULL) {
+ code = pdfi_name_alloc(pdffont1->ctx, (byte *)I->ff.char_data, I->ff.char_data_len, (pdf_obj **)&glyphname);
+ if (code < 0)
+ return code;
+ pdfi_countup(glyphname);
+ code = pdfi_dict_get_by_key(pdffont1->ctx, pdffont1->CharStrings, glyphname, (pdf_obj **)&charstring);
+ pdfi_countdown(glyphname);
+ if (code < 0) {
+ code = pdfi_dict_get(pdffont1->ctx, pdffont1->CharStrings, ".notdef", (pdf_obj **)&charstring);
+ if (code < 0) {
+ code = gs_note_error(gs_error_invalidfont);
+ goto done;
+ }
+ }
+ cstrlen = charstring->length - leniv;
+ if (buf != NULL && cstrlen <= buf_length) {
+ if (ff->need_decrypt && pfont1->data.lenIV >= 0)
+ decode_bytes(buf, charstring->data, cstrlen + leniv, leniv);
+ else
+ memcpy(buf, charstring->data, charstring->length);
+ }
+ pdfi_countdown(charstring);
+ /* Trigger the seac case below - we can do this safely
+ because I->ff.char_data points to a string managed
+ by the Encoding array in the pdf_font object
+ */
+ if (buf != NULL)
+ I->ff.char_data = NULL;
+ }
+ else { /* SEAC */
+ gs_const_string encstr;
+ gs_glyph enc_ind = gs_c_known_encode(char_code, ENCODING_INDEX_STANDARD);
+
+ if (enc_ind == GS_NO_GLYPH) {
+ code = gs_error_invalidfont;
+ }
+ else {
+ gs_c_glyph_name(enc_ind, &encstr);
+ code = pdfi_name_alloc(pdffont1->ctx, (byte *)encstr.data, encstr.size, (pdf_obj **)&encn);
+ if (code < 0)
+ goto done;
+
+ pdfi_countup(encn);
+ code = pdfi_dict_get_by_key(pdffont1->ctx, pdffont1->CharStrings, encn, (pdf_obj **)&charstring);
+ pdfi_countdown(encn);
+ if (code < 0)
+ goto done;
+ cstrlen = charstring->length - leniv;
+ if (buf != NULL && code <= buf_length) {
+ if (ff->need_decrypt && leniv >= 0)
+ decode_bytes(buf, charstring->data, cstrlen + leniv, leniv);
+ else
+ memcpy(buf, charstring->data, charstring->length);
+ }
+ pdfi_countdown(charstring);
+ }
+ }
+ }
+ else if (pbfont->FontType == ft_CID_encrypted || pbfont->FontType == ft_encrypted2) {
+ gs_font_type1 *pfont = (gs_font_type1 *) (gs_font_base *) ff->client_font_data;
+ int leniv = pfont->data.lenIV > 0 ? pfont->data.lenIV : 0;
+
+ if (I->ff.char_data_len > 0 && I->ff.char_data != NULL) {
+ cstrlen = I->ff.char_data_len - leniv;
+
+ if (buf && buf_length >= cstrlen) {
+ memcpy(buf, I->ff.char_data, I->ff.char_data_len);
+
+ if (ff->need_decrypt && pfont->data.lenIV >= 0)
+ decode_bytes(buf, I->ff.char_data, cstrlen + leniv, leniv);
+ else
+ memcpy(buf, I->ff.char_data, cstrlen);
+
+ /* Trigger the seac case below - we can do this safely
+ because I->ff.char_data points to a string managed
+ by the charstrings dict in the pdf_font object
+ */
+ I->ff.char_data = NULL;
+ }
+ }
+ else {
+ pdf_font_cff *pdffont = (pdf_font_cff *)pfont->client_data;
+ pdf_name *encn;
+ pdf_string *charstring;
+
+ if (pbfont->FontType == ft_CID_encrypted) {
+ /* we're dealing with a font that's an entry in a CIDFont FDArray
+ so don't try to use an Encoding
+ */
+ char indstring[33];
+ int l;
+ l = gs_snprintf(indstring, 32, "%u", (unsigned int)char_code);
+ code = pdfi_name_alloc(pdffont->ctx, (byte *)indstring, l, (pdf_obj **)&encn);
+ }
+ else {
+ gs_const_string encstr;
+ gs_glyph enc_ind = gs_c_known_encode(char_code, ENCODING_INDEX_STANDARD);
+
+ /* Nonsense values for char_code should probably trigger an error (as above)
+ but other consumers seem tolerant, so....
+ */
+ if (enc_ind == GS_NO_GLYPH)
+ enc_ind = gs_c_known_encode(0, ENCODING_INDEX_STANDARD);
+
+ code = gs_c_glyph_name(enc_ind, &encstr);
+
+ if (code < 0)
+ code = pdfi_name_alloc(pdffont->ctx, (byte *)".notdef", 7, (pdf_obj **)&encn);
+ else
+ code = pdfi_name_alloc(pdffont->ctx, (byte *)encstr.data, encstr.size, (pdf_obj **)&encn);
+ }
+ if (code < 0)
+ goto done;
+
+ pdfi_countup(encn);
+ code = pdfi_dict_get_by_key(pdffont->ctx, pdffont->CharStrings, encn, (pdf_obj **)&charstring);
+ pdfi_countdown(encn);
+ if (code < 0)
+ goto done;
+ cstrlen = charstring->length - leniv;
+ if (buf != NULL && cstrlen <= buf_length) {
+ if (ff->need_decrypt && pfont->data.lenIV >= 0)
+ decode_bytes(buf, charstring->data, cstrlen + leniv, leniv);
+ else
+ memcpy(buf, charstring->data, charstring->length);
+ }
+ pdfi_countdown(charstring);
+ }
+
+ }
+ }
+ else {
+ code = gs_error_invalidaccess;
+ }
+done:
+ if (code < 0)
+ return code;
+
+ return cstrlen;
+}
+
+static int
+pdfi_fapi_serialize_tt_font(gs_fapi_font * ff, void *buf, int buf_size)
+{
+ return 0;
+}
+
+static int
+pdfi_get_glyphdirectory_data(gs_fapi_font * ff, int char_code,
+ const byte ** ptr)
+{
+ return (0);
+}
+
+static int
+pdfi_fapi_get_metrics(gs_fapi_font * ff, gs_string * char_name, gs_glyph cid, double *m, bool vertical)
+{
+ return 0;
+}
+
+static int
+pdfi_fapi_set_cache(gs_text_enum_t * penum, const gs_font_base * pbfont,
+ const gs_string * char_name, gs_glyph cid,
+ const double pwidth[2], const gs_rect * pbbox,
+ const double Metrics2_sbw_default[4], bool * imagenow)
+{
+ int code = 0;
+ int code2;
+ gs_gstate *pgs = penum->pgs;
+ float w2[10];
+ double widths[6] = {0};
+ gs_point pt;
+ gs_font_base *pbfont1 = (gs_font_base *)pbfont;
+ gs_matrix imat;
+ gs_matrix mat1;
+
+ mat1 = pbfont1->FontMatrix;
+
+ if (penum->orig_font->FontType == ft_composite) {
+
+ if (cid >= GS_MIN_CID_GLYPH) {
+ cid = cid - GS_MIN_CID_GLYPH;
+ }
+
+ if (pbfont->FontType == ft_encrypted || pbfont->FontType == ft_encrypted2) {
+ gs_fapi_server *I = (gs_fapi_server *)pbfont1->FAPI;
+ pbfont1 = (gs_font_base *)I->ff.client_font_data2;
+ /* The following cannot fail - if the matrix multiplication didn't work
+ we'd have errored out at a higher level
+ */
+ (void)gs_matrix_multiply(&pbfont->FontMatrix, &pbfont1->FontMatrix, &mat1);
+ }
+
+ code = pdfi_get_cidfont_glyph_metrics((gs_font *)pbfont1, cid, widths, true);
+ if (code < 0) {
+ /* Insert warning here! */
+ code = 0; /* Using the defaults */
+ }
+ }
+ else {
+ code = -1;
+ }
+
+ /* Since we have to tranverse a few things by the inverse font matrix,
+ invert the matrix once upfront.
+ */
+ code2 = gs_matrix_invert(&mat1, &imat);
+ if (code2 < 0)
+ return code2; /* By this stage, this is basically impossible */
+
+ if (code < 0) {
+ w2[0] = (float)pwidth[0];
+ w2[1] = (float)pwidth[1];
+ }
+ else {
+ /* gs_distance_transform() cannot return an error */
+ (void)gs_distance_transform(widths[GLYPH_W0_WIDTH_INDEX], widths[GLYPH_W0_HEIGHT_INDEX], &imat, &pt);
+
+ w2[0] = pt.x / 1000.0;
+ w2[1] = pt.y / 1000.0;
+ }
+ w2[2] = pbbox->p.x;
+ w2[3] = pbbox->p.y;
+ w2[4] = pbbox->q.x;
+ w2[5] = pbbox->q.y;
+
+ (void)gs_distance_transform(widths[GLYPH_W1_WIDTH_INDEX], widths[GLYPH_W1_HEIGHT_INDEX], &imat, &pt);
+ w2[6] = pt.x / 1000.0;
+ w2[7] = pt.y / 1000.0;
+ (void)gs_distance_transform(widths[GLYPH_W1_V_X_INDEX], widths[GLYPH_W1_V_Y_INDEX], &imat, &pt);
+ w2[8] = pt.x / 1000.0;
+ w2[9] = pt.y / 1000.0;
+
+ if ((code = gs_setcachedevice2((gs_show_enum *) penum, pgs, w2)) < 0) {
+ return (code);
+ }
+
+ *imagenow = true;
+ return (code);
+}
+
+
+static int
+pdfi_fapi_build_char(gs_show_enum * penum, gs_gstate * pgs, gs_font * pfont,
+ gs_char chr, gs_glyph glyph)
+{
+ int code;
+ gs_font_base *pbfont1;
+ gs_fapi_server *I;
+
+ /* gs_fapi_do_char() expects the "natural" glyph, not the offset value */
+ if (glyph >= GS_MIN_CID_GLYPH)
+ glyph -= GS_MIN_CID_GLYPH;
+
+ pbfont1 = (gs_font_base *)pfont;
+
+ if (penum->fstack.depth >= 0) {
+ gs_font_cid0 *cidpfont = (gs_font_cid0 *)penum->fstack.items[penum->fstack.depth].font;
+ if (cidpfont->FontType == ft_CID_encrypted) {
+ pbfont1 = (gs_font_base *)cidpfont->cidata.FDArray[penum->fstack.items[penum->fstack.depth].index];
+ I = (gs_fapi_server *)pbfont1->FAPI;
+ I->ff.client_font_data2 = cidpfont;
+ }
+ }
+
+ code = gs_fapi_do_char((gs_font *)pbfont1, pgs, (gs_text_enum_t *) penum, NULL, false,
+ NULL, NULL, chr, glyph, 0);
+
+ return (code);
+}
+
+static void
+pdfi_get_server_param(gs_fapi_server * I, const char *subtype,
+ char **server_param, int *server_param_size)
+{
+ return;
+}
+
+#if 0
+static int
+pdfi_fapi_set_cache_metrics(gs_text_enum_t * penum, const gs_font_base * pbfont,
+ const gs_string * char_name, int cid,
+ const double pwidth[2], const gs_rect * pbbox,
+ const double Metrics2_sbw_default[4],
+ bool * imagenow)
+{
+ return (gs_error_unknownerror);
+}
+
+static gs_glyph
+pdfi_fapi_encode_char(gs_font * pfont, gs_char pchr, gs_glyph_space_t not_used)
+{
+ return (gs_glyph) pchr;
+}
+#endif
+
+int
+pdfi_fapi_passfont(pdf_font *font, int subfont, char *fapi_request,
+ char *file_name, byte * font_data, int font_data_len)
+{
+ char *fapi_id = NULL;
+ int code = 0;
+ gs_string fdata;
+ gs_font_base *pbfont = (gs_font_base *)font->pfont;
+ gs_fapi_font local_pdf_ff_stub = pdfi_ff_stub;
+ gs_fapi_ttf_cmap_request symbolic_req[GS_FAPI_NUM_TTF_CMAP_REQ] = {{3, 0}, {1, 0}, {3, 1}, {3, 10}, {-1, -1}};
+ gs_fapi_ttf_cmap_request nonsymbolic_req[GS_FAPI_NUM_TTF_CMAP_REQ] = {{3, 1}, {1, 0}, {3, 0}, {-1, -1}, {-1, -1}};
+ int plat, enc;
+
+ if (!gs_fapi_available(pbfont->memory, NULL)) {
+ return (code);
+ }
+
+ if (font->pdfi_font_type == e_pdf_font_truetype) {
+ fdata.data = ((pdf_font_truetype *)font)->sfnt.data;
+ fdata.size = ((pdf_font_truetype *)font)->sfnt.size;
+ }
+ else if (font->pdfi_font_type == e_pdf_cidfont_type2) {
+ fdata.data = ((pdf_cidfont_type2 *)font)->sfnt.data;
+ fdata.size = ((pdf_cidfont_type2 *)font)->sfnt.size;
+ }
+ else {
+ fdata.data = font_data;
+ fdata.size = font_data_len;
+ }
+
+ if (font->pdfi_font_type == e_pdf_font_truetype) {
+ pdf_font_truetype *ttfont = (pdf_font_truetype *)font;
+ *local_pdf_ff_stub.ttf_cmap_req = (ttfont->descflags & 4) ? *symbolic_req : *nonsymbolic_req;
+ }
+ else {
+ /* doesn't really matter for non-ttf */
+ *local_pdf_ff_stub.ttf_cmap_req = *nonsymbolic_req;
+ }
+ /* The plfont should contain everything we need, but setting the client data for the server
+ * to pbfont makes as much sense as setting it to NULL.
+ */
+ gs_fapi_set_servers_client_data(pbfont->memory,
+ (const gs_fapi_font *)&local_pdf_ff_stub,
+ (gs_font *)pbfont);
+
+ code =
+ gs_fapi_passfont((gs_font *)pbfont, subfont, (char *)file_name, &fdata,
+ (char *)fapi_request, NULL, (char **)&fapi_id,
+ (gs_fapi_get_server_param_callback)
+ pdfi_get_server_param);
+
+ if (code < 0 || fapi_id == NULL) {
+ return code;
+ }
+
+ if (font->pdfi_font_type == e_pdf_font_truetype) {
+ pdf_font_truetype *ttfont = (pdf_font_truetype *)font;
+ plat = pbfont->FAPI->ff.ttf_cmap_selected.platform_id;
+ enc = pbfont->FAPI->ff.ttf_cmap_selected.encoding_id;
+ ttfont->cmap = pdfi_truetype_cmap_none;
+
+ if (plat == 1 && enc == 0) {
+ ttfont->cmap = pdfi_truetype_cmap_10;
+ }
+ else if (plat == 3 && enc == 0) {
+ ttfont->cmap = pdfi_truetype_cmap_30;
+ }
+ else if (plat == 3 && enc == 1) {
+ ttfont->cmap = pdfi_truetype_cmap_31;
+ }
+ else if (plat == 3 && enc == 10) { /* Currently shouldn't arise */
+ ttfont->cmap = pdfi_truetype_cmap_310;
+ }
+ }
+
+ pbfont->procs.build_char = pdfi_fapi_build_char;
+
+ return (code);
+}
+
+int
+pdfi_fapi_check_cmap_for_GID(gs_font *pfont, uint cid, uint *gid)
+{
+ if (pfont->FontType == ft_TrueType
+ || pfont->FontType == ft_CID_TrueType) {
+ gs_font_base *pbfont = (gs_font_base *)pfont;
+ gs_fapi_server *I = pbfont->FAPI;
+
+ if (I) {
+ uint c = cid;
+ I->ff.server_font_data = pbfont->FAPI_font_data;
+ I->check_cmap_for_GID(I, &c);
+ *gid = c;
+ return 0;
+ }
+ }
+ return_error(gs_error_invalidfont);
+}
diff --git a/pdf/pdf_file.c b/pdf/pdf_file.c
new file mode 100644
index 00000000..214d448d
--- /dev/null
+++ b/pdf/pdf_file.c
@@ -0,0 +1,1700 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+#include "ghostpdf.h"
+#include "pdf_types.h"
+#include "pdf_stack.h"
+#include "pdf_dict.h"
+#include "pdf_file.h"
+#include "pdf_int.h"
+#include "pdf_array.h"
+#include "pdf_misc.h"
+#include "pdf_sec.h"
+#include "stream.h"
+#include "strimpl.h"
+#include "strmio.h"
+#include "gpmisc.h"
+#include "simscale.h" /* SIMScaleDecode */
+#include "szlibx.h" /* Flate */
+#include "spngpx.h" /* PNG Predictor */
+#include "spdiffx.h" /* Horizontal differencing predictor */
+#include "slzwx.h" /* LZW ZLib */
+#include "sstring.h" /* ASCIIHexDecode */
+#include "sa85d.h" /* ASCII85Decode */
+#include "scfx.h" /* CCITTFaxDecode */
+#include "srlx.h" /* RunLengthDecode */
+#include "jpeglib_.h"
+#include "sdct.h" /* DCTDecode */
+#include "sjpeg.h"
+#include "sfilter.h" /* SubFileDecode and PFBDecode */
+#include "sarc4.h" /* Arc4Decode */
+#include "saes.h" /* AESDecode */
+#include "ssha2.h" /* SHA256Encode */
+#include "gxdevsop.h" /* For special ops */
+
+#ifdef USE_LDF_JB2
+#include "sjbig2_luratech.h"
+#else
+#include "sjbig2.h"
+#endif
+#if defined(USE_LWF_JP2)
+# include "sjpx_luratech.h"
+#elif defined(USE_OPENJPEG_JP2)
+# include "sjpx_openjpeg.h"
+#else
+# include "sjpx.h"
+#endif
+
+static void pdfi_close_filter_chain(pdf_context *ctx, stream *s, stream *target);
+
+/* Utility routine to create a pdf_c_stream object */
+static int pdfi_alloc_stream(pdf_context *ctx, stream *source, stream *original, pdf_c_stream **new_stream)
+{
+ *new_stream = NULL;
+ *new_stream = (pdf_c_stream *)gs_alloc_bytes(ctx->memory, sizeof(pdf_c_stream), "pdfi_alloc_stream");
+ if (*new_stream == NULL)
+ return_error(gs_error_VMerror);
+ memset(*new_stream, 0x00, sizeof(pdf_c_stream));
+ (*new_stream)->eof = false;
+ ((pdf_c_stream *)(*new_stream))->s = source;
+ ((pdf_c_stream *)(*new_stream))->original = original;
+ return 0;
+}
+
+/***********************************************************************************/
+/* Decompression filters. */
+
+static int
+pdfi_filter_report_error(stream_state * st, const char *str)
+{
+ if_debug1m('s', st->memory, "[s]stream error: %s\n", str);
+ strncpy(st->error_string, str, STREAM_MAX_ERROR_STRING);
+ /* Ensure null termination. */
+ st->error_string[STREAM_MAX_ERROR_STRING] = 0;
+ return 0;
+}
+
+/* Open a file stream for a filter. */
+static int
+pdfi_filter_open(uint buffer_size,
+ const stream_procs * procs, const stream_template * templat,
+ const stream_state * st, gs_memory_t *mem, stream **new_stream)
+{
+ stream *s;
+ uint ssize = gs_struct_type_size(templat->stype);
+ stream_state *sst = NULL;
+ int code;
+
+ if (templat->stype != &st_stream_state) {
+ sst = s_alloc_state(mem, templat->stype, "pdfi_filter_open(stream_state)");
+ if (sst == NULL)
+ return_error(gs_error_VMerror);
+ }
+ code = file_open_stream((char *)0, 0, "r", buffer_size, &s,
+ (gx_io_device *)0, (iodev_proc_fopen_t)0, mem);
+ if (code < 0) {
+ gs_free_object(mem, sst, "pdfi_filter_open(stream_state)");
+ return code;
+ }
+ s_std_init(s, s->cbuf, s->bsize, procs, s_mode_read);
+ s->procs.process = templat->process;
+ s->save_close = s->procs.close;
+ s->procs.close = file_close_file;
+ s->close_at_eod = 0;
+ if (sst == NULL) {
+ /* This stream doesn't have any state of its own. */
+ /* Hack: use the stream itself as the state. */
+ sst = (stream_state *) s;
+ } else if (st != NULL) /* might not have client parameters */
+ memcpy(sst, st, ssize);
+ s->state = sst;
+ s_init_state(sst, templat, mem);
+ sst->report_error = pdfi_filter_report_error;
+
+ if (templat->init != NULL) {
+ code = (*templat->init)(sst);
+ if (code < 0) {
+ gs_free_object(mem, sst, "filter_open(stream_state)");
+ gs_free_object(mem, s->cbuf, "filter_open(buffer)");
+ gs_free_object(mem, s, "filter_open(stream)");
+ return code;
+ }
+ }
+ *new_stream = s;
+ return 0;
+}
+
+static int pdfi_Predictor_filter(pdf_context *ctx, pdf_dict *d, stream *source, stream **new_stream)
+{
+ int code;
+ int64_t Predictor, Colors, BPC, Columns;
+ uint min_size;
+ stream_PNGP_state pps;
+ stream_PDiff_state ppds;
+ /* NOTE: 'max_min_left=1' is a horribly named definition from stream.h */
+
+ code = pdfi_dict_get_int_def(ctx, d, "Predictor", &Predictor, 1);
+ if (code < 0)
+ return code;
+
+ /* Predictor values 0,1 are identity (use the existing stream).
+ * The other values need to be cascaded.
+ */
+ switch(Predictor) {
+ case 0:
+ Predictor = 1;
+ break;
+ case 1:
+ break;
+ case 2:
+ case 10:
+ case 11:
+ case 12:
+ case 13:
+ case 14:
+ case 15:
+ /* grab values common to both kinds of predictors */
+ min_size = s_zlibD_template.min_out_size + max_min_left;
+ code = pdfi_dict_get_int_def(ctx, d, "Colors", &Colors, 1);
+ if (code < 0)
+ return code;
+ if (Colors < 1 || Colors > s_PNG_max_Colors)
+ return_error(gs_error_rangecheck);
+
+ code = pdfi_dict_get_int_def(ctx, d, "BitsPerComponent", &BPC, 8);
+ if (code < 0)
+ return code;
+ /* tests for 1-16, powers of 2 */
+ if (BPC < 1 || BPC > 16 || (BPC & (BPC - 1)) != 0)
+ return_error(gs_error_rangecheck);
+
+ code = pdfi_dict_get_int_def(ctx, d, "Columns", &Columns, 1);
+ if (code < 0)
+ return code;
+ if (Columns < 1)
+ return_error(gs_error_rangecheck);
+ break;
+ default:
+ return_error(gs_error_rangecheck);
+ }
+
+ switch(Predictor) {
+ case 1:
+ *new_stream = source;
+ break;
+ case 2:
+ /* zpd_setup, componentwise horizontal differencing */
+ ppds.Colors = (int)Colors;
+ ppds.BitsPerComponent = (int)BPC;
+ ppds.Columns = (int)Columns;
+ code = pdfi_filter_open(min_size, &s_filter_read_procs,
+ (const stream_template *)&s_PDiffD_template,
+ (const stream_state *)&ppds, ctx->memory->non_gc_memory, new_stream);
+ if (code < 0)
+ return code;
+
+ (*new_stream)->strm = source;
+ break;
+ default:
+ /* zpp_setup, PNG predictor */
+ pps.Colors = (int)Colors;
+ pps.BitsPerComponent = (int)BPC;
+ pps.Columns = (uint)Columns;
+ pps.Predictor = Predictor;
+ code = pdfi_filter_open(min_size, &s_filter_read_procs,
+ (const stream_template *)&s_PNGPD_template,
+ (const stream_state *)&pps, ctx->memory->non_gc_memory, new_stream);
+ if (code < 0)
+ return code;
+
+ (*new_stream)->strm = source;
+ break;
+ }
+ return 0;
+}
+
+int pdfi_apply_Arc4_filter(pdf_context *ctx, pdf_string *Key, pdf_c_stream *source, pdf_c_stream **new_stream)
+{
+ int code = 0;
+ stream_arcfour_state state;
+ stream *new_s;
+ int min_size = 2048;
+
+ s_arcfour_set_key(&state, (const unsigned char *)Key->data, Key->length);
+
+ code = pdfi_filter_open(min_size, &s_filter_read_procs, (const stream_template *)&s_arcfour_template, (const stream_state *)&state, ctx->memory->non_gc_memory, &new_s);
+ if (code < 0)
+ return code;
+
+ code = pdfi_alloc_stream(ctx, new_s, source->s, new_stream);
+ new_s->strm = source->s;
+ return code;
+}
+
+int pdfi_apply_AES_filter(pdf_context *ctx, pdf_string *Key, bool use_padding, pdf_c_stream *source, pdf_c_stream **new_stream)
+{
+ stream_aes_state state;
+ uint min_size = 2048;
+ int code = 0;
+ stream *new_s;
+
+ s_aes_set_key(&state, Key->data, Key->length);
+ s_aes_set_padding(&state, use_padding);
+
+ code = pdfi_filter_open(min_size, &s_filter_read_procs, (const stream_template *)&s_aes_template, (const stream_state *)&state, ctx->memory->non_gc_memory, &new_s);
+
+ if (code < 0)
+ return code;
+
+ code = pdfi_alloc_stream(ctx, new_s, source->s, new_stream);
+ new_s->strm = source->s;
+ return code;
+}
+
+#ifdef UNUSED_FILTER
+int pdfi_apply_SHA256_filter(pdf_context *ctx, pdf_c_stream *source, pdf_c_stream **new_stream)
+{
+ stream_SHA256E_state state;
+ uint min_size = 2048;
+ int code = 0;
+ stream *new_s;
+
+ pSHA256_Init(&state.sha256);
+ code = pdfi_filter_open(min_size, &s_filter_read_procs, (const stream_template *)&s_SHA256E_template, (const stream_state *)&state, ctx->memory->non_gc_memory, &new_s);
+
+ if (code < 0)
+ return code;
+
+ code = pdfi_alloc_stream(ctx, new_s, source->s, new_stream);
+ new_s->strm = source->s;
+ return code;
+}
+#endif
+
+int pdfi_apply_imscale_filter(pdf_context *ctx, pdf_string *Key, int width, int height, pdf_c_stream *source, pdf_c_stream **new_stream)
+{
+ int code = 0;
+ stream_imscale_state state;
+ stream *new_s;
+
+ state.params.spp_decode = 1;
+ state.params.spp_interp = 1;
+ state.params.BitsPerComponentIn = 1;
+ state.params.MaxValueIn = 1;
+ state.params.WidthIn = width;
+ state.params.HeightIn = height;
+ state.params.BitsPerComponentOut = 1;
+ state.params.MaxValueOut = 1;
+ state.params.WidthOut = width << 2;
+ state.params.HeightOut = height << 2;
+
+ code = pdfi_filter_open(2048, &s_filter_read_procs, (const stream_template *)&s_imscale_template, (const stream_state *)&state, ctx->memory->non_gc_memory, &new_s);
+
+ if (code < 0)
+ return code;
+
+ code = pdfi_alloc_stream(ctx, new_s, source->s, new_stream);
+ new_s->strm = source->s;
+ return code;
+}
+
+static int pdfi_Flate_filter(pdf_context *ctx, pdf_dict *d, stream *source, stream **new_stream)
+{
+ stream_zlib_state zls;
+ uint min_size = 2048;
+ int code;
+
+ memset(&zls, 0, sizeof(zls));
+
+ /* s_zlibD_template defined in base/szlibd.c */
+ (*s_zlibD_template.set_defaults)((stream_state *)&zls);
+
+ code = pdfi_filter_open(min_size, &s_filter_read_procs, (const stream_template *)&s_zlibD_template, (const stream_state *)&zls, ctx->memory->non_gc_memory, new_stream);
+ if (code < 0)
+ return code;
+
+ (*new_stream)->strm = source;
+ source = *new_stream;
+
+ if (d && d->type == PDF_DICT) {
+ code = pdfi_Predictor_filter(ctx, d, source, new_stream);
+ if (code < 0)
+ pdfi_close_filter_chain(ctx, source, NULL);
+ }
+ return code;
+}
+
+static int
+pdfi_JBIG2Decode_filter(pdf_context *ctx, pdf_dict *dict, pdf_dict *decode,
+ stream *source, stream **new_stream)
+{
+ stream_jbig2decode_state state;
+ uint min_size = s_jbig2decode_template.min_out_size;
+ int code;
+ pdf_stream *Globals = NULL;
+ byte *buf;
+ int64_t buflen;
+ void *globalctx;
+
+ s_jbig2decode_set_global_data((stream_state*)&state, NULL, NULL);
+
+ if (decode) {
+ code = pdfi_dict_knownget_type(ctx, decode, "JBIG2Globals", PDF_STREAM,
+ (pdf_obj **)&Globals);
+ if (code < 0) {
+ goto cleanupExit;
+ }
+
+ /* read in the globals from stream */
+ if (code > 0) {
+ code = pdfi_stream_to_buffer(ctx, Globals, &buf, &buflen);
+ if (code == 0) {
+ code = s_jbig2decode_make_global_data(ctx->memory->non_gc_memory,
+ buf, buflen, &globalctx);
+ if (code < 0)
+ goto cleanupExit;
+
+ s_jbig2decode_set_global_data((stream_state*)&state, NULL, globalctx);
+
+ gs_free_object(ctx->memory, buf, "pdfi_JBIG2Decode_filter (Globals buf)");
+ }
+ }
+ }
+
+ code = pdfi_filter_open(min_size, &s_filter_read_procs,
+ (const stream_template *)&s_jbig2decode_template,
+ (const stream_state *)&state, ctx->memory->non_gc_memory, new_stream);
+ if (code < 0)
+ goto cleanupExit;
+
+ (*new_stream)->strm = source;
+ code = 0;
+
+ cleanupExit:
+ pdfi_countdown(Globals);
+ return code;
+}
+
+static int pdfi_LZW_filter(pdf_context *ctx, pdf_dict *d, stream *source, stream **new_stream)
+{
+ stream_LZW_state lzs;
+ uint min_size = 2048;
+ int code;
+ int64_t i;
+
+ /* s_zlibD_template defined in base/szlibd.c */
+ s_LZW_set_defaults_inline(&lzs);
+
+ if (d && d->type == PDF_DICT) {
+ code = pdfi_dict_get_int(ctx, d, "EarlyChange", &i);
+ if (code < 0 && code != gs_error_undefined)
+ return code;
+ if (code == 0) {
+ if (i == 0)
+ lzs.EarlyChange = false;
+ else
+ lzs.EarlyChange = true;
+ }
+ }
+
+ code = pdfi_filter_open(min_size, &s_filter_read_procs, (const stream_template *)&s_LZWD_template, (const stream_state *)&lzs, ctx->memory->non_gc_memory, new_stream);
+ if (code < 0)
+ return code;
+ (*new_stream)->strm = source;
+ source = *new_stream;
+
+ if (d && d->type == PDF_DICT)
+ pdfi_Predictor_filter(ctx, d, source, new_stream);
+ return 0;
+}
+
+static int PS_JPXD_PassThrough(void *d, byte *Buffer, int Size)
+{
+ gx_device *dev = (gx_device *)d;
+
+ if (Buffer == NULL) {
+ if (Size == 0)
+ dev_proc(dev, dev_spec_op)(dev, gxdso_JPX_passthrough_end, NULL, 0);
+ else
+ dev_proc(dev, dev_spec_op)(dev, gxdso_JPX_passthrough_begin, NULL, 0);
+ } else {
+ dev_proc(dev, dev_spec_op)(dev, gxdso_JPX_passthrough_data, Buffer, Size);
+ }
+ return 0;
+}
+
+/*
+ * dict -- the dict that contained the decoder (i.e. the image dict)
+ * decode -- the decoder dict
+ */
+static int
+pdfi_JPX_filter(pdf_context *ctx, pdf_dict *dict, pdf_dict *decode,
+ stream *source, stream **new_stream)
+{
+ stream_jpxd_state state;
+ uint min_size = s_jpxd_template.min_out_size;
+ int code;
+ pdf_obj *csobj = NULL;
+ pdf_name *csname = NULL;
+ bool alpha;
+ gx_device *dev = gs_currentdevice(ctx->pgs);
+
+ state.memory = ctx->memory->non_gc_memory;
+ if (s_jpxd_template.set_defaults)
+ (*s_jpxd_template.set_defaults)((stream_state *)&state);
+
+ /* Pull some extra params out of the image dict */
+ if (dict) {
+ /* This Alpha is a thing that gs code uses to tell that we
+ * are doing an SMask. It's a bit of a hack, but
+ * I guess we can do the same.
+ */
+ code = pdfi_dict_get_bool(ctx, dict, "Alpha", &alpha);
+ if (code == 0)
+ state.alpha = alpha;
+ }
+ if (dict && pdfi_dict_get(ctx, dict, "ColorSpace", &csobj) == 0) {
+ /* parse the value */
+ if (csobj->type == PDF_ARRAY) {
+ /* assume it's the first array element */
+ code = pdfi_array_get(ctx, (pdf_array *)csobj, (uint64_t)0, (pdf_obj **)&csname);
+ if (code < 0) {
+ pdfi_countdown(csobj);
+ return code;
+ }
+ } else if (csobj->type == PDF_NAME) {
+ /* use the name directly */
+ csname = (pdf_name *)csobj;
+ csobj = NULL; /* To keep ref counting straight */
+ } else {
+ dmprintf(ctx->memory, "warning: JPX ColorSpace value is an unhandled type!\n");
+ }
+ if (csname != NULL && csname->type == PDF_NAME) {
+ /* request raw index values if the colorspace is /Indexed */
+ if (pdfi_name_is(csname, "Indexed"))
+ state.colorspace = gs_jpx_cs_indexed;
+ /* tell the filter what output we want for other spaces */
+ else if (pdfi_name_is(csname, "DeviceGray"))
+ state.colorspace = gs_jpx_cs_gray;
+ else if (pdfi_name_is(csname, "DeviceRGB"))
+ state.colorspace = gs_jpx_cs_rgb;
+ else if (pdfi_name_is(csname, "DeviceCMYK"))
+ state.colorspace = gs_jpx_cs_cmyk;
+ else if (pdfi_name_is(csname, "ICCBased")) {
+ /* TODO: I don't think this even happens without PS wrapper code? */
+#if 0
+ /* The second array element should be the profile's
+ stream dict */
+ ref *csdict = csobj->value.refs + 1;
+ ref *nref;
+ ref altname;
+ if (r_is_array(csobj) && (r_size(csobj) > 1) &&
+ r_has_type(csdict, t_dictionary)) {
+ check_dict_read(*csdict);
+ /* try to look up the alternate space */
+ if (dict_find_string(csdict, "Alternate", &nref) > 0) {
+ name_string_ref(imemory, csname, &altname);
+ if (pdfi_name_is(&altname, "DeviceGray"))
+ state.colorspace = gs_jpx_cs_gray;
+ else if (pdfi_name_is(&altname, "DeviceRGB"))
+ state.colorspace = gs_jpx_cs_rgb;
+ else if (pdfi_name_is(&altname, "DeviceCMYK"))
+ state.colorspace = gs_jpx_cs_cmyk;
+ }
+ /* else guess based on the number of components */
+ if (state.colorspace == gs_jpx_cs_unset &&
+ dict_find_string(csdict, "N", &nref) > 0) {
+ if_debug1m('w', imemory, "[w] JPX image has an external %"PRIpsint
+ " channel colorspace\n", nref->value.intval);
+ switch (nref->value.intval) {
+ case 1: state.colorspace = gs_jpx_cs_gray;
+ break;
+ case 3: state.colorspace = gs_jpx_cs_rgb;
+ break;
+ case 4: state.colorspace = gs_jpx_cs_cmyk;
+ break;
+ }
+ }
+ }
+#endif
+ }
+ }
+ }
+
+ if (csobj)
+ pdfi_countdown(csobj);
+ if (csname)
+ pdfi_countdown(csname);
+
+
+ if (dev_proc(dev, dev_spec_op)(dev, gxdso_JPX_passthrough_query, NULL, 0) > 0) {
+ state.StartedPassThrough = 0;
+ state.PassThrough = 1;
+ state.PassThroughfn = (PS_JPXD_PassThrough);
+ state.device = (void *)dev;
+ }
+ else {
+ state.PassThrough = 0;
+ state.device = (void *)NULL;
+ }
+
+ code = pdfi_filter_open(min_size, &s_filter_read_procs, (const stream_template *)&s_jpxd_template,
+ (const stream_state *)&state, ctx->memory->non_gc_memory, new_stream);
+ if (code < 0)
+ return code;
+ (*new_stream)->strm = source;
+ source = *new_stream;
+
+ return 0;
+}
+
+private_st_jpeg_decompress_data();
+
+static int PDF_DCTD_PassThrough(void *d, byte *Buffer, int Size)
+{
+ gx_device *dev = (gx_device *)d;
+
+ if (Buffer == NULL) {
+ if (Size == 0)
+ dev_proc(dev, dev_spec_op)(dev, gxdso_JPEG_passthrough_end, NULL, 0);
+ else
+ dev_proc(dev, dev_spec_op)(dev, gxdso_JPEG_passthrough_begin, NULL, 0);
+ } else {
+ dev_proc(dev, dev_spec_op)(dev, gxdso_JPEG_passthrough_data, Buffer, Size);
+ }
+ return 0;
+}
+
+static int pdfi_DCT_filter(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *decode,
+ stream *source, stream **new_stream)
+{
+ stream_DCT_state dcts;
+ uint min_size = s_DCTD_template.min_out_size;
+ int code;
+ int64_t i;
+ jpeg_decompress_data *jddp;
+ gx_device *dev = gs_currentdevice_inline(ctx->pgs);
+ double Height = 0;
+
+ dcts.memory = ctx->memory;
+ /* First allocate space for IJG parameters. */
+ jddp = gs_alloc_struct_immovable(ctx->memory, jpeg_decompress_data,
+ &st_jpeg_decompress_data, "pdfi_DCT");
+ if (jddp == 0)
+ return_error(gs_error_VMerror);
+ if (s_DCTD_template.set_defaults)
+ (*s_DCTD_template.set_defaults) ((stream_state *) & dcts);
+
+ dcts.data.decompress = jddp;
+ jddp->memory = dcts.jpeg_memory = ctx->memory; /* set now for allocation */
+ jddp->scanline_buffer = NULL; /* set this early for safe error exit */
+ dcts.report_error = pdfi_filter_report_error; /* in case create fails */
+ if ((code = gs_jpeg_create_decompress(&dcts)) < 0) {
+ gs_jpeg_destroy(&dcts);
+ gs_free_object(ctx->memory, jddp, "zDCTD fail");
+ return code;
+ }
+
+ if (decode && decode->type == PDF_DICT) {
+ /* TODO: Why is this here? 'i' never gets used? */
+ code = pdfi_dict_get_int(ctx, decode, "ColorTransform", &i);
+ if (code < 0 && code != gs_error_undefined)
+ return code;
+ }
+
+ if (dev_proc(dev, dev_spec_op)(dev, gxdso_JPEG_passthrough_query, NULL, 0) > 0) {
+ jddp->StartedPassThrough = 0;
+ jddp->PassThrough = 1;
+ jddp->PassThroughfn = (PDF_DCTD_PassThrough);
+ jddp->device = (void *)dev;
+ }
+ else {
+ jddp->PassThrough = 0;
+ jddp->device = (void *)NULL;
+ }
+
+ /* Hack for Bug695112.pdf to grab a height in case it is missing from the JPEG data */
+ code = pdfi_dict_knownget_number(ctx, stream_dict, "Height", &Height);
+ if (code < 0)
+ return code;
+ jddp->Height = (int)floor(Height);
+
+ jddp->templat = s_DCTD_template;
+
+ code = pdfi_filter_open(min_size, &s_filter_read_procs, (const stream_template *)&jddp->templat, (const stream_state *)&dcts, ctx->memory->non_gc_memory, new_stream);
+ if (code < 0)
+ return code;
+ (*new_stream)->strm = source;
+ source = *new_stream;
+
+ return 0;
+}
+
+static int pdfi_ASCII85_filter(pdf_context *ctx, pdf_dict *d, stream *source, stream **new_stream)
+{
+ stream_A85D_state ss;
+ uint min_size = 2048;
+ int code;
+
+ ss.pdf_rules = true;
+
+ code = pdfi_filter_open(min_size, &s_filter_read_procs, (const stream_template *)&s_A85D_template, (const stream_state *)&ss, ctx->memory->non_gc_memory, new_stream);
+ if (code < 0)
+ return code;
+
+ (*new_stream)->strm = source;
+ return 0;
+}
+
+static int pdfi_CCITTFax_filter(pdf_context *ctx, pdf_dict *d, stream *source, stream **new_stream)
+{
+ stream_CFD_state ss;
+ uint min_size = 2048;
+ bool bval;
+ int code;
+ int64_t i;
+
+ s_CF_set_defaults_inline(&ss);
+
+ if (d && d->type == PDF_DICT) {
+ code = pdfi_dict_get_int(ctx, d, "K", &i);
+ if (code < 0 && code != gs_error_undefined)
+ return code;
+ if (code == 0)
+ ss.K = i;
+
+ code = pdfi_dict_get_bool(ctx, d, "EndOfLine", &bval);
+ if (code < 0 && code != gs_error_undefined)
+ return code;
+ if (code == 0)
+ ss.EndOfLine = bval ? 1 : 0;
+
+ code = pdfi_dict_get_bool(ctx, d, "EncodedByteAlign", &bval);
+ if (code < 0 && code != gs_error_undefined)
+ return code;
+ if (code == 0)
+ ss.EncodedByteAlign = bval ? 1 : 0;
+
+ code = pdfi_dict_get_bool(ctx, d, "EndOfBlock", &bval);
+ if (code < 0 && code != gs_error_undefined)
+ return code;
+ if (code == 0)
+ ss.EndOfBlock = bval ? 1 : 0;
+
+ code = pdfi_dict_get_bool(ctx, d, "BlackIs1", &bval);
+ if (code < 0 && code != gs_error_undefined)
+ return code;
+ if (code == 0)
+ ss.BlackIs1 = bval ? 1 : 0;
+
+ code = pdfi_dict_get_int(ctx, d, "Columns", &i);
+ if (code < 0 && code != gs_error_undefined)
+ return code;
+ if (code == 0)
+ ss.Columns = i;
+
+ code = pdfi_dict_get_int(ctx, d, "Rows", &i);
+ if (code < 0 && code != gs_error_undefined)
+ return code;
+ if (code == 0)
+ ss.Rows = i;
+
+ code = pdfi_dict_get_int(ctx, d, "DamagedRowsBeforeError", &i);
+ if (code < 0 && code != gs_error_undefined)
+ return code;
+ if (code == 0)
+ ss.DamagedRowsBeforeError = i;
+
+ }
+
+ code = pdfi_filter_open(min_size, &s_filter_read_procs,
+ (const stream_template *)&s_CFD_template,
+ (const stream_state *)&ss,
+ ctx->memory->non_gc_memory, new_stream);
+ if (code < 0)
+ return code;
+
+ (*new_stream)->strm = source;
+ return 0;
+}
+
+static int pdfi_RunLength_filter(pdf_context *ctx, pdf_dict *d, stream *source, stream **new_stream)
+{
+ stream_RLD_state ss;
+ uint min_size = 2048;
+ int code;
+
+ if (s_RLD_template.set_defaults)
+ (*s_RLD_template.set_defaults) ((stream_state *) & ss);
+
+ code = pdfi_filter_open(min_size, &s_filter_read_procs, (const stream_template *)&s_RLD_template, (const stream_state *)&ss, ctx->memory->non_gc_memory, new_stream);
+ if (code < 0)
+ return code;
+
+ (*new_stream)->strm = source;
+ return 0;
+}
+
+static int pdfi_simple_filter(pdf_context *ctx, const stream_template *tmplate, stream *source, stream **new_stream)
+{
+ uint min_size = 2048;
+ int code;
+
+ code = pdfi_filter_open(min_size, &s_filter_read_procs, tmplate, NULL, ctx->memory->non_gc_memory, new_stream);
+ if (code < 0)
+ return code;
+
+ (*new_stream)->strm = source;
+ return 0;
+}
+
+static int pdfi_apply_filter(pdf_context *ctx, pdf_dict *dict, pdf_name *n, pdf_dict *decode,
+ stream *source, stream **new_stream, bool inline_image)
+{
+ int code;
+
+ if (ctx->args.pdfdebug)
+ {
+ char str[100];
+ memcpy(str, (const char *)n->data, n->length);
+ str[n->length] = '\0';
+ dmprintf1(ctx->memory, "FILTER NAME:%s\n", str);
+ }
+
+ if (pdfi_name_is(n, "RunLengthDecode")) {
+ code = pdfi_RunLength_filter(ctx, decode, source, new_stream);
+ return code;
+ }
+ if (pdfi_name_is(n, "CCITTFaxDecode")) {
+ code = pdfi_CCITTFax_filter(ctx, decode, source, new_stream);
+ return code;
+ }
+ if (pdfi_name_is(n, "ASCIIHexDecode")) {
+ code = pdfi_simple_filter(ctx, &s_AXD_template, source, new_stream);
+ return code;
+ }
+ if (pdfi_name_is(n, "ASCII85Decode")) {
+ code = pdfi_ASCII85_filter(ctx, decode, source, new_stream);
+ return code;
+ }
+ if (pdfi_name_is(n, "SubFileDecode")) {
+ code = pdfi_simple_filter(ctx, &s_SFD_template, source, new_stream);
+ return code;
+ }
+ if (pdfi_name_is(n, "FlateDecode")) {
+ code = pdfi_Flate_filter(ctx, decode, source, new_stream);
+ return code;
+ }
+ if (pdfi_name_is(n, "JBIG2Decode")) {
+ code = pdfi_JBIG2Decode_filter(ctx, dict, decode, source, new_stream);
+ return code;
+ }
+ if (pdfi_name_is(n, "LZWDecode")) {
+ code = pdfi_LZW_filter(ctx, decode, source, new_stream);
+ return code;
+ }
+ if (pdfi_name_is(n, "DCTDecode")) {
+ code = pdfi_DCT_filter(ctx, dict, decode, source, new_stream);
+ return code;
+ }
+ if (pdfi_name_is(n, "JPXDecode")) {
+ code = pdfi_JPX_filter(ctx, dict, decode, source, new_stream);
+ return code;
+ }
+
+ if (pdfi_name_is(n, "AHx")) {
+ if (!inline_image) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_INLINEFILTER, "pdfi_apply_filter", NULL);
+ if (ctx->args.pdfstoponwarning)
+ return_error(gs_error_syntaxerror);
+ }
+ code = pdfi_simple_filter(ctx, &s_AXD_template, source, new_stream);
+ return code;
+ }
+ if (pdfi_name_is(n, "A85")) {
+ if (!inline_image) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_INLINEFILTER, "pdfi_apply_filter", NULL);
+ if (ctx->args.pdfstoponwarning)
+ return_error(gs_error_syntaxerror);
+ }
+ code = pdfi_ASCII85_filter(ctx, decode, source, new_stream);
+ return code;
+ }
+ if (pdfi_name_is(n, "LZW")) {
+ if (!inline_image) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_INLINEFILTER, "pdfi_apply_filter", NULL);
+ if (ctx->args.pdfstoponwarning)
+ return_error(gs_error_syntaxerror);
+ }
+ code = pdfi_LZW_filter(ctx, decode, source, new_stream);
+ return code;
+ }
+ if (pdfi_name_is(n, "CCF")) {
+ if (!inline_image) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_INLINEFILTER, "pdfi_apply_filter", NULL);
+ if (ctx->args.pdfstoponwarning)
+ return_error(gs_error_syntaxerror);
+ }
+ code = pdfi_CCITTFax_filter(ctx, decode, source, new_stream);
+ return code;
+ }
+ if (pdfi_name_is(n, "DCT")) {
+ if (!inline_image) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_INLINEFILTER, "pdfi_apply_filter", NULL);
+ if (ctx->args.pdfstoponwarning)
+ return_error(gs_error_syntaxerror);
+ }
+ code = pdfi_DCT_filter(ctx, dict, decode, source, new_stream);
+ return code;
+ }
+ if (pdfi_name_is(n, "Fl")) {
+ if (!inline_image) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_INLINEFILTER, "pdfi_apply_filter", NULL);
+ if (ctx->args.pdfstoponwarning)
+ return_error(gs_error_syntaxerror);
+ }
+ code = pdfi_Flate_filter(ctx, decode, source, new_stream);
+ return code;
+ }
+ if (pdfi_name_is(n, "RL")) {
+ if (!inline_image) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_INLINEFILTER, "pdfi_apply_filter", NULL);
+ if (ctx->args.pdfstoponwarning)
+ return_error(gs_error_syntaxerror);
+ }
+ code = pdfi_RunLength_filter(ctx, decode, source, new_stream);
+ return code;
+ }
+
+ pdfi_set_error(ctx, 0, NULL, E_PDF_UNKNOWNFILTER, "pdfi_apply_filter", NULL);
+ return_error(gs_error_undefined);
+}
+
+int pdfi_filter_no_decryption(pdf_context *ctx, pdf_stream *stream_obj,
+ pdf_c_stream *source, pdf_c_stream **new_stream, bool inline_image)
+{
+ pdf_obj *o = NULL, *o1 = NULL;
+ pdf_obj *decode = NULL;
+ pdf_obj *Filter = NULL;
+ pdf_dict *stream_dict = NULL;
+ pdf_array *DecodeParams = NULL;
+ int code;
+ int64_t i, j, duplicates;
+ stream *s = source->s, *new_s = NULL;
+
+ *new_stream = NULL;
+
+ if (ctx->args.pdfdebug) {
+ gs_offset_t stream_offset = pdfi_stream_offset(ctx, stream_obj);
+ dmprintf2(ctx->memory, "Filter: offset %ld(0x%lx)\n", stream_offset, stream_offset);
+ }
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)stream_obj, &stream_dict);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_dict_knownget(ctx, stream_dict, "Filter", &Filter);
+ if (code == 0 && inline_image)
+ code = pdfi_dict_knownget(ctx, stream_dict, "F", &Filter);
+ if (code < 0)
+ goto exit;
+ if (code == 0) {
+ /* No filter, just open the stream */
+ code = pdfi_alloc_stream(ctx, s, source->s, new_stream);
+ goto exit;
+ }
+
+ if (Filter->type != PDF_ARRAY && Filter->type != PDF_NAME) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+
+ if (Filter->type == PDF_NAME) {
+ code = pdfi_dict_knownget(ctx, stream_dict, "DecodeParms", &decode);
+ if (code == 0 && inline_image)
+ code = pdfi_dict_knownget(ctx, stream_dict, "DP", &decode);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_apply_filter(ctx, stream_dict, (pdf_name *)Filter,
+ (pdf_dict *)decode, s, &new_s, inline_image);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_alloc_stream(ctx, new_s, source->s, new_stream);
+ } else {
+ pdf_array *filter_array = (pdf_array *)Filter;
+
+ code = pdfi_dict_knownget_type(ctx, stream_dict, "DecodeParms", PDF_ARRAY, (pdf_obj **)&DecodeParams);
+ if (code == 0 && inline_image)
+ code = pdfi_dict_knownget_type(ctx, stream_dict, "DP", PDF_ARRAY, (pdf_obj **)&DecodeParams);
+ if (code < 0)
+ goto exit;
+
+ if (DecodeParams != NULL) {
+ if (pdfi_array_size(DecodeParams) == 0 || pdfi_array_size(DecodeParams) != pdfi_array_size(filter_array)) {
+ pdfi_countdown(DecodeParams);
+ DecodeParams = NULL;
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_STREAM_BAD_DECODEPARMS, "pdfi_filter_no_decryption", NULL);
+ } else {
+ if (pdfi_array_size(DecodeParams) != pdfi_array_size(filter_array)) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+ }
+ }
+
+ /* Check the Filter array to see if we have any duplicates (to prevent filter bombs)
+ * For now we will allow one duplicate (in case people do stupid things like ASCIIEncode
+ * and Flate and ASCIIEncode again or something).
+ */
+ for (i = 0; i < (int)pdfi_array_size(filter_array) - 1;i++) {
+ code = pdfi_array_get_type(ctx, filter_array, i, PDF_NAME, &o);
+ if (code < 0)
+ goto exit;
+ duplicates = 0;
+
+ for (j = i + 1; j < pdfi_array_size(filter_array);j++) {
+ code = pdfi_array_get_type(ctx, filter_array, j, PDF_NAME, &o1);
+ if (code < 0) {
+ goto exit;
+ }
+ if (((pdf_name *)o)->length == ((pdf_name *)o1)->length) {
+ if (memcmp(((pdf_name *)o)->data, ((pdf_name *)o1)->data, ((pdf_name *)o)->length) == 0)
+ duplicates++;
+ }
+ pdfi_countdown(o1);
+ o1 = NULL;
+ }
+ pdfi_countdown(o);
+ o = NULL;
+ if (duplicates > 2) {
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADSTREAM, "pdfi_filter_nodecryption", (char *)"**** ERROR Detected possible filter bomb (duplicate Filters). Aborting processing");
+ code = gs_note_error(gs_error_syntaxerror);
+ goto exit;
+ }
+ }
+
+ for (i = 0; i < pdfi_array_size(filter_array);i++) {
+ code = pdfi_array_get_type(ctx, filter_array, i, PDF_NAME, &o);
+ if (code < 0)
+ goto error;
+ if (DecodeParams != NULL) {
+ code = pdfi_array_get(ctx, DecodeParams, i, &decode);
+ if (code < 0) {
+ goto error;
+ }
+ }
+ if (decode && decode->type != PDF_NULL && decode->type != PDF_DICT) {
+ pdfi_countdown(decode);
+ decode = NULL;
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_STREAM_BAD_DECODEPARMS, "pdfi_filter_no_decryption", NULL);
+ }
+
+ code = pdfi_apply_filter(ctx, stream_dict, (pdf_name *)o,
+ (pdf_dict *)decode, s, &new_s, inline_image);
+ pdfi_countdown(decode);
+ decode = NULL;
+ pdfi_countdown(o);
+ o = NULL;
+ if (code < 0)
+ goto error;
+
+ s = new_s;
+ }
+ code = pdfi_alloc_stream(ctx, s, source->s, new_stream);
+ }
+
+ exit:
+ pdfi_countdown(o);
+ pdfi_countdown(o1);
+ pdfi_countdown(DecodeParams);
+ pdfi_countdown(decode);
+ pdfi_countdown(Filter);
+ return code;
+
+ error:
+ if (s)
+ pdfi_close_filter_chain(ctx, s, source->s);
+ *new_stream = NULL;
+ pdfi_countdown(o);
+ pdfi_countdown(o1);
+ pdfi_countdown(DecodeParams);
+ pdfi_countdown(decode);
+ pdfi_countdown(Filter);
+ return code;
+}
+
+int pdfi_filter(pdf_context *ctx, pdf_stream *stream_obj, pdf_c_stream *source,
+ pdf_c_stream **new_stream, bool inline_image)
+{
+ int code;
+ pdf_c_stream *crypt_stream = NULL, *SubFile_stream = NULL;
+ pdf_string *StreamKey = NULL;
+ pdf_dict *stream_dict = NULL;
+
+ *new_stream = NULL;
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)stream_obj, &stream_dict);
+ if (code < 0)
+ goto error;
+
+ /* If the file isn't encrypted, don't apply encryption. If this is an inline
+ * image then its in a content stream and will already be decrypted, so don't
+ * apply decryption again.
+ */
+ if (ctx->encryption.is_encrypted && !inline_image) {
+ int64_t Length;
+
+ code = pdfi_dict_get_type(ctx, stream_dict, "StreamKey", PDF_STRING, (pdf_obj **)&StreamKey);
+ if (code == gs_error_undefined) {
+ code = pdfi_compute_objkey(ctx, (pdf_obj *)stream_dict, &StreamKey);
+ if (code < 0)
+ return code;
+ code = pdfi_dict_put(ctx, stream_dict, "StreamKey", (pdf_obj *)StreamKey);
+ if (code < 0)
+ goto error;
+ }
+ if (code < 0)
+ return code;
+
+ /* If we are applying a decryption filter we must also apply a SubFileDecode filter.
+ * This is because the underlying stream may not have a compression filter, if it doesn't
+ * then we have no way of detecting the end of the data. Normally we would get an 'endstream'
+ * token but if we have applied a decryption filter then we'll 'decrypt' that token
+ * and that will corrupt it. So make sure we can't read past the end of the stream
+ * by applying a SubFileDecode.
+ * NB applying a SubFileDecode filter with an EODString seems to limit the amount of data
+ * that the decode filter is prepared to return at any time to the size of the EODString.
+ * This doesn't play well with other filters (eg the AESDecode filter) which require a
+ * larger minimum to be returned (16 bytes for AESDecode). So I'm using the filter
+ * Length here, even though I'd prefer not to.....
+ */
+ Length = pdfi_stream_length(ctx, stream_obj);
+
+ if (Length <= 0 || ctx->encryption.StrF == CRYPT_IDENTITY) {
+ /* Don't treat as an encrypted stream if Length is 0 */
+ pdfi_countdown(StreamKey);
+ return pdfi_filter_no_decryption(ctx, stream_obj, source, new_stream, inline_image);
+ }
+
+ code = pdfi_apply_SubFileDecode_filter(ctx, Length, NULL, source, &SubFile_stream, false);
+ if (code < 0)
+ goto error;
+
+ SubFile_stream->original = source->s;
+
+ switch(ctx->encryption.StrF) {
+ case CRYPT_IDENTITY:
+ /* Can't happen, handled above */
+ break;
+ /* There are only two possible filters, RC4 or AES, we take care
+ * of the number of bits in the key by using ctx->Length.
+ */
+ case CRYPT_V1:
+ case CRYPT_V2:
+ code = pdfi_apply_Arc4_filter(ctx, StreamKey, SubFile_stream, &crypt_stream);
+ break;
+ case CRYPT_AESV2:
+ case CRYPT_AESV3:
+ code = pdfi_apply_AES_filter(ctx, StreamKey, 1, SubFile_stream, &crypt_stream);
+ break;
+ default:
+ code = gs_error_rangecheck;
+ }
+ if (code < 0) {
+ pdfi_close_file(ctx, SubFile_stream);
+ goto error;
+ }
+
+ crypt_stream->original = SubFile_stream->original;
+ gs_free_object(ctx->memory, SubFile_stream, "pdfi_filter");
+
+ code = pdfi_filter_no_decryption(ctx, stream_obj, crypt_stream, new_stream, false);
+ if (code < 0) {
+ pdfi_close_file(ctx, crypt_stream);
+ goto error;
+ }
+
+ (*new_stream)->original = source->s;
+ gs_free_object(ctx->memory, crypt_stream, "pdfi_filter");
+ } else {
+ code = pdfi_filter_no_decryption(ctx, stream_obj, source, new_stream, inline_image);
+ }
+error:
+ pdfi_countdown(StreamKey);
+ return code;
+}
+
+/* This is just a convenience routine. We could use pdfi_filter() above, but because PDF
+ * doesn't support the SubFileDecode filter that would mean callers having to manufacture
+ * a dictionary in order to use it. That's excessively convoluted, so just supply a simple
+ * means to instantiate a SubFileDecode filter.
+ *
+ * NB! The EODString can't be tracked by the stream code. The caller is responsible for
+ * managing the lifetime of this object. It must remain valid until the filter is closed.
+ */
+int pdfi_apply_SubFileDecode_filter(pdf_context *ctx, int EODCount, pdf_string *EODString, pdf_c_stream *source, pdf_c_stream **new_stream, bool inline_image)
+{
+ int code;
+ stream_SFD_state state;
+ stream *new_s = NULL;
+ int min_size = 2048;
+
+ *new_stream = NULL;
+
+ memset(&state, 0, sizeof(state));
+
+ if (s_SFD_template.set_defaults)
+ s_SFD_template.set_defaults((stream_state *)&state);
+
+ if (EODString != NULL) {
+ state.eod.data = EODString->data;
+ state.eod.size = EODString->length;
+ min_size = EODString->length;
+ }
+
+ if (EODCount > 0)
+ state.count = EODCount - source->unread_size;
+ else
+ state.count = EODCount;
+
+ code = pdfi_filter_open(min_size, &s_filter_read_procs, (const stream_template *)&s_SFD_template, (const stream_state *)&state, ctx->memory->non_gc_memory, &new_s);
+ if (code < 0)
+ return code;
+
+ code = pdfi_alloc_stream(ctx, new_s, source->s, new_stream);
+ new_s->strm = source->s;
+ if (source->unread_size != 0) {
+ (*new_stream)->unread_size = source->unread_size;
+ memcpy((*new_stream)->unget_buffer, source->unget_buffer, source->unread_size);
+ source->unread_size = 0;
+ }
+ return code;
+}
+
+/* We would really like to use a ReusableStreamDecode filter here, but that filter is defined
+ * purely in the PostScript interpreter. So instead we make a temporary stream from a
+ * memory buffer. Its icky (we can end up with the same data in memory multiple times)
+ * but it works, and is used elsewhere in Ghostscript.
+ * If retain_ownership is true then the calling function is responsible for buffer pointer lifetime.
+ * Otherwise the buffer will be freed when the stream is closed.
+ */
+int pdfi_open_memory_stream_from_stream(pdf_context *ctx, unsigned int size, byte **Buffer, pdf_c_stream *source, pdf_c_stream **new_pdf_stream, bool retain_ownership)
+{
+ stream *new_stream;
+ int code;
+
+ new_stream = file_alloc_stream(ctx->memory, "open memory stream(stream)");
+ if (new_stream == NULL)
+ return_error(gs_error_VMerror);
+
+ *Buffer = gs_alloc_bytes(ctx->memory, size, "open memory stream (buffer)");
+ if (*Buffer == NULL) {
+ gs_free_object(ctx->memory, new_stream, "open memory stream(stream)");
+ return_error(gs_error_VMerror);
+ }
+ code = pdfi_read_bytes(ctx, *Buffer, 1, size, source);
+ if (code < 0) {
+ gs_free_object(ctx->memory, *Buffer, "open memory stream(buffer)");
+ gs_free_object(ctx->memory, new_stream, "open memory stream(stream)");
+ return code;
+ }
+
+ if (retain_ownership)
+ sread_string_reusable(new_stream, *Buffer, size);
+ else
+ sread_transient_string_reusable(new_stream, ctx->memory, *Buffer, size);
+
+ code = pdfi_alloc_stream(ctx, new_stream, source->s, new_pdf_stream);
+ if (code < 0) {
+ sclose(new_stream);
+ gs_free_object(ctx->memory, *Buffer, "open memory stream(buffer)");
+ gs_free_object(ctx->memory, new_stream, "open memory stream(stream)");
+ }
+
+ return code;
+}
+
+/*
+ * Like pdfi_open_memory_stream_from_stream (and makes use of it) this is a way to read from a stream into
+ * memory, and return a stream which reads from that memory. The difference is that this function takes
+ * any filters into account, decompressing them. We could layer a decompression stream onto the memory
+ * stream returned by open_memory_stream_from_stream above instead.
+ *
+ * This function returns < 0 for an error, and the length of the uncompressed data on success.
+ */
+int pdfi_open_memory_stream_from_filtered_stream(pdf_context *ctx, pdf_stream *stream_obj,
+ unsigned int size, byte **Buffer, pdf_c_stream *source,
+ pdf_c_stream **new_pdf_stream, bool retain_ownership)
+{
+ int code;
+ pdf_dict *dict = NULL;
+ int decompressed_length = 0;
+ byte *decompressed_Buffer = NULL;
+ pdf_c_stream *compressed_stream = NULL, *decompressed_stream = NULL;
+ bool known = false;
+
+ code = pdfi_open_memory_stream_from_stream(ctx, (unsigned int)size, Buffer, source, new_pdf_stream, retain_ownership);
+ if (code < 0) {
+ pdfi_close_memory_stream(ctx, *Buffer, *new_pdf_stream);
+ *Buffer = NULL;
+ *new_pdf_stream = NULL;
+ return code;
+ }
+
+ if (stream_obj == NULL)
+ return size;
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)stream_obj, &dict);
+ if (code < 0)
+ return code;
+
+ pdfi_dict_known(ctx, dict, "F", &known);
+ if (!known)
+ pdfi_dict_known(ctx, dict, "Filter", &known);
+
+ if (!known)
+ return size;
+
+ compressed_stream = *new_pdf_stream;
+ /* This is again complicated by requiring a seekable stream, and the fact that,
+ * unlike fonts, there is no Length2 key to tell us how large the uncompressed
+ * stream is.
+ */
+ code = pdfi_filter(ctx, stream_obj, compressed_stream, &decompressed_stream, false);
+ if (code < 0) {
+ pdfi_close_memory_stream(ctx, *Buffer, *new_pdf_stream);
+ gs_free_object(ctx->memory, *Buffer, "pdfi_open_memory_stream_from_filtered_stream");
+ *Buffer = NULL;
+ *new_pdf_stream = NULL;
+ return code;
+ }
+ do {
+ byte b;
+ code = pdfi_read_bytes(ctx, &b, 1, 1, decompressed_stream);
+ if (code <= 0)
+ break;
+ decompressed_length++;
+ } while (true);
+ pdfi_close_file(ctx, decompressed_stream);
+
+ decompressed_Buffer = gs_alloc_bytes(ctx->memory, decompressed_length, "pdfi_open_memory_stream_from_filtered_stream (decompression buffer)");
+ if (decompressed_Buffer != NULL) {
+ code = srewind(compressed_stream->s);
+ if (code >= 0) {
+ code = pdfi_filter(ctx, stream_obj, compressed_stream,
+ &decompressed_stream, false);
+ if (code >= 0) {
+ code = pdfi_read_bytes(ctx, decompressed_Buffer, 1, decompressed_length, decompressed_stream);
+ pdfi_close_file(ctx, decompressed_stream);
+ code = pdfi_close_memory_stream(ctx, *Buffer, *new_pdf_stream);
+ if (code >= 0) {
+ *Buffer = decompressed_Buffer;
+ code = pdfi_open_memory_stream_from_memory(ctx, (unsigned int)decompressed_length,
+ *Buffer, new_pdf_stream, retain_ownership);
+ } else {
+ *Buffer = NULL;
+ *new_pdf_stream = NULL;
+ }
+ }
+ } else {
+ pdfi_close_memory_stream(ctx, *Buffer, *new_pdf_stream);
+ gs_free_object(ctx->memory, decompressed_Buffer, "pdfi_open_memory_stream_from_filtered_stream");
+ gs_free_object(ctx->memory, Buffer, "pdfi_open_memory_stream_from_filtered_stream");
+ *Buffer = NULL;
+ *new_pdf_stream = NULL;
+ return code;
+ }
+ } else {
+ pdfi_close_memory_stream(ctx, *Buffer, *new_pdf_stream);
+ gs_free_object(ctx->memory, Buffer, "pdfi_open_memory_stream_from_filtered_stream");
+ *Buffer = NULL;
+ *new_pdf_stream = NULL;
+ return_error(gs_error_VMerror);
+ }
+ if (code < 0) {
+ gs_free_object(ctx->memory, Buffer, "pdfi_build_function_4");
+ *Buffer = NULL;
+ *new_pdf_stream = NULL;
+ return code;
+ }
+ return decompressed_length;
+}
+
+int pdfi_open_memory_stream_from_memory(pdf_context *ctx, unsigned int size, byte *Buffer, pdf_c_stream **new_pdf_stream, bool retain_ownership)
+{
+ int code;
+ stream *new_stream;
+
+ new_stream = file_alloc_stream(ctx->memory, "open memory stream from memory(stream)");
+ if (new_stream == NULL)
+ return_error(gs_error_VMerror);
+ new_stream->close_at_eod = false;
+ if (retain_ownership)
+ sread_string(new_stream, Buffer, size);
+ else
+ sread_transient_string(new_stream, ctx->memory, Buffer, size);
+
+ code = pdfi_alloc_stream(ctx, new_stream, NULL, new_pdf_stream);
+ if (code < 0) {
+ sclose(new_stream);
+ gs_free_object(ctx->memory, new_stream, "open memory stream from memory(stream)");
+ }
+
+ return code;
+}
+
+int pdfi_close_memory_stream(pdf_context *ctx, byte *Buffer, pdf_c_stream *source)
+{
+ sclose(source->s);
+ gs_free_object(ctx->memory, Buffer, "open memory stream(buffer)");
+ gs_free_object(ctx->memory, source->s, "open memory stream(stream)");
+ gs_free_object(ctx->memory, source, "open memory stream(pdf_stream)");
+ return 0;
+}
+
+/***********************************************************************************/
+/* Basic 'file' operations. Because of the need to 'unread' bytes we need our own */
+
+static void pdfi_close_filter_chain(pdf_context *ctx, stream *s, stream *target)
+{
+ stream *next_s = s;
+
+ while(next_s && next_s != target){
+ stream *curr_s = next_s;
+ next_s = next_s->strm;
+ if (curr_s != ctx->main_stream->s)
+ sfclose(curr_s);
+ }
+}
+
+void pdfi_close_file(pdf_context *ctx, pdf_c_stream *s)
+{
+ pdfi_close_filter_chain(ctx, s->s, s->original);
+
+ gs_free_object(ctx->memory, s, "closing pdf_file");
+}
+
+int pdfi_seek(pdf_context *ctx, pdf_c_stream *s, gs_offset_t offset, uint32_t origin)
+{
+ if (origin == SEEK_CUR && s->unread_size != 0)
+ offset -= s->unread_size;
+
+ s->unread_size = 0;;
+
+ return (sfseek(s->s, offset, origin));
+}
+
+/* We use 'stell' sometimes to save the position of the underlying file
+ * when reading a compressed stream, so that we can return to the same
+ * point in the underlying file after performing some other operation. This
+ * allows us (for instance) to load a font while interpreting a content stream.
+ * However, if we've 'unread' any bytes we need to take that into account.
+ * NOTE! this is only going to be valid when performed on the main stream
+ * the original PDF file, not any compressed stream!
+ */
+gs_offset_t pdfi_unread_tell(pdf_context *ctx)
+{
+ gs_offset_t off = stell(ctx->main_stream->s);
+
+ return (off - ctx->main_stream->unread_size);
+}
+
+gs_offset_t pdfi_tell(pdf_c_stream *s)
+{
+ return stell(s->s);
+}
+
+int pdfi_unread(pdf_context *ctx, pdf_c_stream *s, byte *Buffer, uint32_t size)
+{
+ if (size + s->unread_size > UNREAD_BUFFER_SIZE)
+ return_error(gs_error_ioerror);
+
+ if (s->unread_size) {
+ uint32_t index = s->unread_size - 1;
+
+ do {
+ s->unget_buffer[size + index] = s->unget_buffer[index];
+ } while(index--);
+ }
+
+ memcpy(s->unget_buffer, Buffer, size);
+ s->unread_size += size;
+
+ return 0;
+}
+
+int pdfi_read_bytes(pdf_context *ctx, byte *Buffer, uint32_t size, uint32_t count, pdf_c_stream *s)
+{
+ uint32_t i = 0, total = size * count;
+ uint32_t bytes = 0;
+ int32_t code;
+
+ if (s->eof && s->unread_size == 0)
+ return 0;
+
+ if (s->unread_size) {
+ if (s->unread_size >= total) {
+ memcpy(Buffer, s->unget_buffer, total);
+ for(i=0;i < s->unread_size - total;i++) {
+ s->unget_buffer[i] = s->unget_buffer[i + total];
+ }
+ s->unread_size -= total;
+ return total;
+ } else {
+ memcpy(Buffer, s->unget_buffer, s->unread_size);
+ total -= s->unread_size;
+ Buffer += s->unread_size;
+ i = s->unread_size;
+ s->unread_size = 0;
+ if (s->eof)
+ return i;
+ }
+ }
+ if (total) {
+ /* TODO the Ghostscript code uses sbufptr(s) to avoid a memcpy
+ * at some point we should modify this code to do so as well.
+ */
+ code = sgets(s->s, Buffer, total, &bytes);
+ if (code == EOFC) {
+ s->eof = true;
+ } else if (code == gs_error_ioerror) {
+ pdfi_set_error(ctx, code, "sgets", E_PDF_BADSTREAM, "pdfi_read_bytes", NULL);
+ s->eof = true;
+ } else if(code == ERRC) {
+ bytes = ERRC;
+ } else {
+ bytes = bytes + i;
+ }
+ }
+
+ return bytes;
+}
+
+/* Read bytes from stream object into buffer.
+ * Handles both plain streams and filtered streams.
+ * Buffer gets allocated here, and must be freed by caller.
+ * Preserves the location of the current stream file position.
+ */
+int
+pdfi_stream_to_buffer(pdf_context *ctx, pdf_stream *stream_obj, byte **buf, int64_t *bufferlen)
+{
+ byte *Buffer = NULL;
+ int code = 0;
+ int64_t buflen = 0;
+ int bytes;
+ char c;
+ gs_offset_t savedoffset;
+ pdf_c_stream *stream;
+ bool filtered;
+ pdf_dict *stream_dict = NULL;
+
+ savedoffset = pdfi_tell(ctx->main_stream);
+
+ pdfi_seek(ctx, ctx->main_stream, pdfi_stream_offset(ctx, stream_obj), SEEK_SET);
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)stream_obj, &stream_dict);
+ if (code < 0)
+ goto exit;
+
+ /* See if this is a filtered stream */
+ code = pdfi_dict_known(ctx, stream_dict, "Filter", &filtered);
+ if (code < 0)
+ goto exit;
+
+ if (!filtered) {
+ code = pdfi_dict_known(ctx, stream_dict, "F", &filtered);
+ if (code < 0)
+ goto exit;
+ }
+
+ if (filtered || ctx->encryption.is_encrypted) {
+ code = pdfi_filter(ctx, stream_obj, ctx->main_stream, &stream, false);
+ if (code < 0) {
+ goto exit;
+ }
+ /* Find out how big it is */
+ do {
+ bytes = sfread(&c, 1, 1, stream->s);
+ if (bytes > 0)
+ buflen++;
+ } while (bytes >= 0);
+ pdfi_close_file(ctx, stream);
+ } else {
+ buflen = pdfi_stream_length(ctx, stream_obj);
+ }
+
+ /* Alloc buffer */
+ Buffer = gs_alloc_bytes(ctx->memory, buflen, "pdfi_stream_to_buffer (Buffer)");
+ if (!Buffer) {
+ code = gs_note_error(gs_error_VMerror);
+ goto exit;
+ }
+ code = pdfi_seek(ctx, ctx->main_stream, pdfi_stream_offset(ctx, stream_obj), SEEK_SET);
+ if (code < 0)
+ goto exit;
+ if (filtered || ctx->encryption.is_encrypted) {
+ code = pdfi_filter(ctx, stream_obj, ctx->main_stream, &stream, false);
+ sfread(Buffer, 1, buflen, stream->s);
+ pdfi_close_file(ctx, stream);
+ } else {
+ sfread(Buffer, 1, buflen, ctx->main_stream->s);
+ }
+
+ exit:
+ pdfi_seek(ctx, ctx->main_stream, savedoffset, SEEK_SET);
+ if (Buffer && code < 0)
+ gs_free_object(ctx->memory, Buffer, "pdfi_stream_to_buffer (Buffer)");
+ *buf = Buffer;
+ *bufferlen = buflen;
+ return code;
+}
+
+int pdfi_open_resource_file(pdf_context *ctx, const char *fname, const int fnamelen, stream **s)
+{
+ int code = 0;
+ if (fname == NULL || fnamelen == 0)
+ *s = NULL;
+ else if (gp_file_name_is_absolute(fname, fnamelen) || fname[0] == '%') {
+ /* If it's an absolute path or an explicit PS style device, just try to open it */
+ *s = sfopen(fname, "r", ctx->memory);
+ }
+ else {
+ char fnametotry[gp_file_name_sizeof];
+ uint fnlen;
+ gs_parsed_file_name_t pname;
+ gp_file_name_combine_result r;
+ int i, total;
+
+ *s = NULL;
+ i = 0;
+ total = ctx->search_paths.num_resource_paths - ctx->search_paths.num_init_resource_paths - 1;
+retry:
+ for (; i < total; i++) {
+ gs_param_string *ss = &ctx->search_paths.resource_paths[i];
+
+ if (ss->data[0] == '%') {
+ code = gs_parse_file_name(&pname, (char *)ss->data, ss->size, ctx->memory);
+ if (code < 0 || (pname.len + fnamelen >= gp_file_name_sizeof)) {
+ continue;
+ }
+ memcpy(fnametotry, pname.fname, pname.len);
+ memcpy(fnametotry + pname.len, fname, fnamelen);
+ code = pname.iodev->procs.open_file(pname.iodev, fnametotry, pname.len + fnamelen, "r", s, ctx->memory);
+ if (code < 0) {
+ continue;
+ }
+ break;
+ }
+ else {
+ fnlen = gp_file_name_sizeof;
+ r = gp_file_name_combine((char *)ss->data, ss->size, fname, fnamelen, false, fnametotry, &fnlen);
+ if (r != gp_combine_success || fnlen > gp_file_name_sizeof - 1)
+ continue;
+ fnametotry[fnlen] = '\0';
+ *s = sfopen(fnametotry, "r", ctx->memory);
+ if (*s != NULL)
+ break;
+ }
+ }
+ if (*s == NULL && i < ctx->search_paths.num_resource_paths) {
+ gs_param_string *ss = &ctx->search_paths.genericresourcedir;
+ fnlen = gp_file_name_sizeof;
+ r = gp_file_name_combine((char *)ss->data, ss->size, fname, fnamelen, false, fnametotry, &fnlen);
+ if (r == gp_combine_success || fnlen < gp_file_name_sizeof) {
+ fnametotry[fnlen] = '\0';
+ *s = sfopen(fnametotry, "r", ctx->memory);
+ }
+ }
+ if (*s == NULL && i < ctx->search_paths.num_resource_paths) {
+ total = ctx->search_paths.num_resource_paths;
+ goto retry;
+ }
+ }
+ if (*s == NULL)
+ return_error(gs_error_invalidfileaccess);
+
+ return 0;
+}
+
+int pdfi_open_font_file(pdf_context *ctx, const char *fname, const int fnamelen, stream **s)
+{
+ int code = 0;
+ const char *fontdirstr = "Font/";
+ const int fontdirstrlen = strlen(fontdirstr);
+
+ if (fname == NULL || fnamelen == 0)
+ *s = NULL;
+ else if (gp_file_name_is_absolute(fname, fnamelen) || fname[0] == '%') {
+ /* If it's an absolute path or an explicit PS style device, just try to open it */
+ *s = sfopen(fname, "r", ctx->memory);
+ }
+ else {
+ char fnametotry[gp_file_name_sizeof];
+ uint fnlen;
+ gs_parsed_file_name_t pname;
+ gp_file_name_combine_result r;
+ int i;
+
+ *s = NULL;
+ for (i = 0; i < ctx->search_paths.num_font_paths; i++) {
+ gs_param_string *ss = &ctx->search_paths.font_paths[i];
+
+ if (ss->data[0] == '%') {
+ code = gs_parse_file_name(&pname, (char *)ss->data, ss->size, ctx->memory);
+ if (code < 0 || (pname.len + fnamelen >= gp_file_name_sizeof)) {
+ continue;
+ }
+ memcpy(fnametotry, pname.fname, pname.len);
+ memcpy(fnametotry + pname.len, fname, fnamelen);
+ code = pname.iodev->procs.open_file(pname.iodev, fnametotry, pname.len + fnamelen, "r", s, ctx->memory);
+ if (code < 0) {
+ continue;
+ }
+ break;
+ }
+ else {
+ fnlen = gp_file_name_sizeof;
+ r = gp_file_name_combine((char *)ss->data, ss->size, fname, fnamelen, false, fnametotry, &fnlen);
+ if (r != gp_combine_success || fnlen > gp_file_name_sizeof - 1)
+ continue;
+ fnametotry[fnlen] = '\0';
+ *s = sfopen(fnametotry, "r", ctx->memory);
+ if (*s != NULL)
+ break;
+ }
+ }
+ if (*s == NULL && i < ctx->search_paths.num_resource_paths) {
+ gs_param_string *ss = &ctx->search_paths.genericresourcedir;
+ char fstr[gp_file_name_sizeof];
+
+ fnlen = gp_file_name_sizeof;
+
+ memcpy(fstr, fontdirstr, fontdirstrlen);
+ memcpy(fstr + fontdirstrlen, fname, fnamelen);
+
+ r = gp_file_name_combine((char *)ss->data, ss->size, fstr, fontdirstrlen + fnamelen, false, fnametotry, &fnlen);
+ if (r == gp_combine_success || fnlen < gp_file_name_sizeof) {
+ fnametotry[fnlen] = '\0';
+ *s = sfopen(fnametotry, "r", ctx->memory);
+ }
+ }
+ }
+ if (*s == NULL)
+ return pdfi_open_resource_file(ctx, fname, fnamelen, s);
+
+ return 0;
+}
diff --git a/pdf/pdf_file.h b/pdf/pdf_file.h
new file mode 100644
index 00000000..a02d7f75
--- /dev/null
+++ b/pdf/pdf_file.h
@@ -0,0 +1,112 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* File and decompression filter code */
+
+/*
+ * Note: file and stream handling means using the Ghostscript graphics library stream code
+ * for the decompression filters (and some others not strictly decompression).
+ *
+ * We can think of three 'layers' of access to the raw PDF file and to streams. The
+ * PDF 'parser' is responsible for all the file format access, such as finding the xref,
+ * reading the xref table, dereferencing objects etc. The basic file opening and consistency
+ * checks are in ghostpdf.c, the xref table and object dereferencing is in pdf_xref.c, this includes
+ * handling compressed object streams and compressed xref streams. Currently all this code operates on the
+ * raw file, we always read the xref up front so compressed xrefs aren't a problem, compressed object
+ * streams are read from the start of the stream every time we need an uncached object.
+ *
+ * The next level down is the PDF 'interpreter', which parses content streams, this code is in
+ * pdf_int.c and operates on one of our PDF stream objects, this may include chained compression
+ * (and possibly decryption) filters. This code reads PDF tokens, such as strings, numbers and
+ * PDF operators and stores them on our stack. This always works with a stream, because content
+ * streams are usually compressed. If there are no compression filters then it will be the main
+ * file stream but we absolutely must never rely on that.
+ *
+ * Finally there are the PDF operators themselves, in general thse do not access the stream at all
+ * because all operands are presented on the stack. External content streams such as image XObjects
+ * and Patterns are handled as a genuinely separate stream. The sole exception is inline images.
+ *
+ * So generally speakinc the 'parser' operates on the raw file, the 'interpreter' operates on a
+ * PDF stream, and the individual operators don't need to access either.
+ *
+ * When we want to execute another stream we store the current file position, and then move the
+ * underlying file pointer. When the substream is completed we move the file pointer back. Because we
+ * haven't read any bytes from the original filter chain in the interim its state wil be undisturbed,
+ * so as long as the file pointer is properly restored we can pick up exactly where we left off. This
+ * neatly allows us to execute substreams without having to decompress the entire parent stream.
+ * (see below)
+ *
+ * Our own PDF stream is defined mainly so that we can 'unread' a few bytes in the PDF interpreter.
+ * While scanning for tokens we often read a byte which terminates an object, but also starts a new one,
+ * its convenient to be able to 'rewind' the stream to handle this. If the PDF file were uncompressed
+ * that wouldn't be a problem, we could use fseek(), but we can't go backwards in a compressed stream
+ * without returning to the start of the stream, resetting the decompression filter, and reading up
+ * to the point where we wanted to seek. This is because decompression filters generally have 'state'
+ * which is modified by the data as it is read. Once some data has been decompressed the state has
+ * been altered, and there is generally no way to reverse that change.
+ * Rewinding the stream to the start and re-decompressing would of course be terribly slow. Instead we define
+ * a buffer and when we want to rewind the stream a little we 'unread' bytes (we need to supply the
+ * decompressed byte(s) back to the stream via a 'pdfi_unread' call, it doesn't keep track of these). Currently this has a
+ * fixed buffer of 256 bytes, attempting to unread a total of more than that will result in an ioerror.
+ *
+ * The implication of this is that the PDF interpreter, and the operators, can only progress forwards through
+ * a stream. There is limited support for rewinding a stream, provided the code buffers up the data it wants
+ * to 'unread', and it doesn't exceed 256 bytes.
+ */
+
+#ifndef PDF_FILES
+#define PDF_FILES
+/*
+ * A pdf_c_stream object maintains an 'original' stream memeber. This is only used when closing a file/filter.
+ * When we apply filters to a file we supply the stream that we use as the basis for the new stream, this is
+ * then stored as the 'original' member. When we close the file, we close all the chained streams until we
+ * reach the 'original' member and then exit.
+ *
+ * This allows us to close filters applied to the PDF file without closing the underlying file/filter which was
+ * in effect at the time we created the new stream.
+ */
+
+int pdfi_filter(pdf_context *ctx, pdf_stream *stream_obj, pdf_c_stream *source, pdf_c_stream **new_stream, bool inline_image);
+/* pdfi_filter_no_decryption is a special function used by the xref parsing when dealing with XRefStms and should not be used
+ * for anything else. The pdfi_filter routine will apply decryption as required.
+ */
+int pdfi_filter_no_decryption(pdf_context *ctx, pdf_stream *d, pdf_c_stream *source, pdf_c_stream **new_stream, bool inline_image);
+void pdfi_close_file(pdf_context *ctx, pdf_c_stream *s);
+int pdfi_read_bytes(pdf_context *ctx, byte *Buffer, uint32_t size, uint32_t count, pdf_c_stream *s);
+int pdfi_unread(pdf_context *ctx, pdf_c_stream *s, byte *Buffer, uint32_t size);
+int pdfi_seek(pdf_context *ctx, pdf_c_stream *s, gs_offset_t offset, uint32_t origin);
+gs_offset_t pdfi_unread_tell(pdf_context *ctx);
+gs_offset_t pdfi_tell(pdf_c_stream *s);
+
+int pdfi_apply_SubFileDecode_filter(pdf_context *ctx, int EODCount, pdf_string *EODString, pdf_c_stream *source, pdf_c_stream **new_stream, bool inline_image);
+int pdfi_open_memory_stream(pdf_context *ctx, unsigned int size, byte **Buffer, pdf_c_stream *source, pdf_c_stream **new_stream);
+int pdfi_close_memory_stream(pdf_context *ctx, byte *Buffer, pdf_c_stream *source);
+int pdfi_open_memory_stream_from_stream(pdf_context *ctx, unsigned int size, byte **Buffer, pdf_c_stream *source, pdf_c_stream **new_pdf_stream, bool retain_ownership);
+int pdfi_open_memory_stream_from_filtered_stream(pdf_context *ctx, pdf_stream *stream_dict, unsigned int size, byte **Buffer, pdf_c_stream *source, pdf_c_stream **new_pdf_stream, bool retain_ownership);
+int pdfi_open_memory_stream_from_memory(pdf_context *ctx, unsigned int size, byte *Buffer, pdf_c_stream **new_pdf_stream, bool retain_ownership);
+int pdfi_stream_to_buffer(pdf_context *ctx, pdf_stream *stream_dict, byte **buf, int64_t *bufferlen);
+
+int pdfi_apply_Arc4_filter(pdf_context *ctx, pdf_string *Key, pdf_c_stream *source, pdf_c_stream **new_stream);
+int pdfi_apply_AES_filter(pdf_context *ctx, pdf_string *Key, bool use_padding, pdf_c_stream *source, pdf_c_stream **new_stream);
+int pdfi_apply_imscale_filter(pdf_context *ctx, pdf_string *Key, int width, int height, pdf_c_stream *source, pdf_c_stream **new_stream);
+
+#ifdef UNUSED_FILTER
+int pdfi_apply_SHA256_filter(pdf_context *ctx, pdf_c_stream *source, pdf_c_stream **new_stream);
+#endif
+
+int pdfi_open_resource_file(pdf_context *ctx, const char *fname, const int fnamelen, stream **s);
+int pdfi_open_font_file(pdf_context *ctx, const char *fname, const int fnamelen, stream **s);
+
+#endif /* PDF_FILES */
diff --git a/pdf/pdf_fmap.c b/pdf/pdf_fmap.c
new file mode 100644
index 00000000..8fabb757
--- /dev/null
+++ b/pdf/pdf_fmap.c
@@ -0,0 +1,181 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+/* Font re-mapping */
+
+#include "strmio.h"
+#include "stream.h"
+#include "scanchar.h"
+
+#include "pdf_int.h"
+#include "pdf_types.h"
+#include "pdf_dict.h"
+#include "pdf_stack.h"
+#include "pdf_file.h"
+#include "pdf_fmap.h"
+
+typedef struct
+{
+ const char *keyname;
+ const char *mappedname;
+} pdfi_custom_fmap_entry;
+
+pdfi_custom_fmap_entry pdfi_custom_fmap_enties[] =
+{
+ {"Helv", "Helvetica"},
+ {NULL, NULL}
+};
+
+static int
+pdf_fontmap_open_file(pdf_context *ctx, byte **buf, int *buflen)
+{
+ int code = 0;
+ stream *s;
+ char fname[gp_file_name_sizeof];
+ const char *path_pfx = "Init/";
+ const char *fmap_default = "Fontmap.GS";
+ const char *prestring = "<<\n";
+ const char *poststring = ">>\nendstream\n";
+ const int prestringlen = strlen(prestring);
+ const int poststringlen = strlen(poststring);
+ fname[0] = '\0';
+
+ if (strlen(path_pfx) + strlen(fmap_default) + 1 > gp_file_name_sizeof)
+ return_error(gs_error_invalidfileaccess);
+
+ code = pdfi_open_resource_file(ctx, fmap_default, strlen(fmap_default), &s);
+ if (code < 0) {
+ strncat(fname, path_pfx, strlen(path_pfx));
+ strncat(fname, (char *)fmap_default, strlen(fmap_default));
+ code = pdfi_open_resource_file(ctx, fname, strlen(fname), &s);
+ }
+
+ if (code >= 0) {
+ int i;
+ sfseek(s, 0, SEEK_END);
+ *buflen = sftell(s);
+ sfseek(s, 0, SEEK_SET);
+ *buf = gs_alloc_bytes(ctx->memory, *buflen + prestringlen + poststringlen, "pdf_cmap_open_file(buf)");
+ if (*buf != NULL) {
+ memcpy(*buf, prestring, prestringlen);
+ sfread((*buf) + prestringlen, 1, *buflen, s);
+ memcpy((*buf) + *buflen + prestringlen, poststring, poststringlen);
+ *buflen += prestringlen + poststringlen;
+ /* This is naff, but works for now
+ When parsing Fontmap in PS, ";" is defined as "def"
+ */
+ for (i = 0; i < *buflen - 1; i++) {
+ if ((*buf)[i] == ';') {
+ (*buf)[i] = ' ';
+ }
+ }
+ }
+ else {
+ code = gs_note_error(gs_error_VMerror);
+ }
+ sfclose(s);
+ }
+ return code;
+}
+
+static int
+pdf_make_fontmap(pdf_context *ctx)
+{
+ byte *fmapbuf = NULL;
+ int code, fmapbuflen;
+ pdf_c_stream *fmapstr = NULL;
+ pdf_stream fakedict = {0};
+ pdfi_custom_fmap_entry *pcfe = pdfi_custom_fmap_enties;
+ int i;
+
+ pdf_c_stream fakemainstream = {0};
+
+ code = pdf_fontmap_open_file(ctx, &fmapbuf, &fmapbuflen);
+ if (code < 0)
+ return code;
+
+ code = pdfi_open_memory_stream_from_memory(ctx, fmapbuflen, fmapbuf, &fmapstr, true);
+ if (code >= 0) {
+ int stacksize = pdfi_count_stack(ctx);
+
+ if (ctx->main_stream == NULL) {
+ ctx->main_stream = &fakemainstream;
+ }
+ code = pdfi_interpret_content_stream(ctx, fmapstr, &fakedict, NULL);
+ if (ctx->main_stream == &fakemainstream) {
+ ctx->main_stream = NULL;
+ }
+ if (pdfi_count_stack(ctx) > stacksize && ctx->stack_top[-1]->type == PDF_DICT) {
+ ctx->pdffontmap = (pdf_dict *)ctx->stack_top[-1];
+ pdfi_countup(ctx->pdffontmap);
+ pdfi_pop(ctx, 1);
+ code = 0;
+
+ /* Add our internal aliases to the fontmap. */
+ for (i = 0; pcfe[i].keyname != NULL; i++) {
+ pdf_obj *value;
+ bool k;
+
+ /* We don't want to *replace* entries */
+ if (pdfi_dict_known(ctx, ctx->pdffontmap, pcfe[i].keyname, &k) >= 0
+ && k != true) {
+ code = pdfi_name_alloc(ctx, (byte *)pcfe[i].mappedname, strlen(pcfe[i].mappedname), &value);
+ if (code < 0)
+ continue;
+ pdfi_countup(value);
+ /* If dict_put throws an error, we just carry on - hence the (void) */
+ (void)pdfi_dict_put(ctx, ctx->pdffontmap, pcfe[i].keyname, value);
+ pdfi_countdown(value);
+ }
+ }
+ }
+ else {
+ code = gs_note_error(gs_error_syntaxerror);
+ }
+ }
+ gs_free_object(ctx->memory, fmapbuf, "pdf_make_fontmap(fmapbuf)");
+ return code;
+}
+
+
+int
+pdf_fontmap_lookup_font(pdf_context *ctx, pdf_name *fname, pdf_obj **mapname)
+{
+ int code = 0;
+ pdf_obj *mname;
+
+ if (ctx->pdffontmap == NULL) {
+ code = pdf_make_fontmap(ctx);
+ if (code < 0) {
+ return code;
+ }
+ }
+ code = pdfi_dict_get_by_key(ctx, ctx->pdffontmap, fname, &mname);
+ if (code < 0)
+ return code;
+ /* Fontmap can map in multiple "jump" i.e.
+ name -> substitute name
+ subsitute name -> file name
+ So we want to loop until we no more hits.
+ */
+ while(1) {
+ pdf_obj *mname2;
+ code = pdfi_dict_get_by_key(ctx, ctx->pdffontmap, (pdf_name *)mname, &mname2);
+ if (code < 0) break;
+ pdfi_countdown(mname);
+ mname = mname2;
+ }
+ *mapname = mname;
+ return 0;
+}
diff --git a/pdf/pdf_fmap.h b/pdf/pdf_fmap.h
new file mode 100644
index 00000000..602bb0cf
--- /dev/null
+++ b/pdf/pdf_fmap.h
@@ -0,0 +1,20 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* We expect to lookup a name, but what we get back might be a name,
+ or might be a string.
+ */
+int
+pdf_fontmap_lookup_font(pdf_context *ctx, pdf_name *fname, pdf_obj **mapname);
diff --git a/pdf/pdf_font.c b/pdf/pdf_font.c
new file mode 100644
index 00000000..7fa8a427
--- /dev/null
+++ b/pdf/pdf_font.c
@@ -0,0 +1,1581 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Font operations for the PDF interpreter */
+
+#include "pdf_int.h"
+#include "pdf_file.h"
+#include "pdf_dict.h"
+#include "pdf_loop_detect.h"
+#include "pdf_array.h"
+#include "pdf_font.h"
+#include "pdf_stack.h"
+#include "pdf_misc.h"
+#include "pdf_doc.h"
+#include "pdf_font_types.h"
+#include "pdf_font0.h"
+#include "pdf_font1.h"
+#include "pdf_font1C.h"
+#include "pdf_font3.h"
+#include "pdf_fontTT.h"
+#include "pdf_font0.h"
+#include "pdf_fmap.h"
+#include "gscencs.h" /* For gs_c_known_encode and gs_c_glyph_name */
+
+#include "strmio.h"
+#include "stream.h"
+#include "gsstate.h" /* For gs_setPDFfontsize() */
+
+static int pdfi_gs_setfont(pdf_context *ctx, gs_font *pfont)
+{
+ int code = 0;
+ pdf_font *old_font = pdfi_get_current_pdf_font(ctx);
+
+ code = gs_setfont(ctx->pgs, pfont);
+ if (code >= 0)
+ pdfi_countdown(old_font);
+
+ return code;
+}
+
+/* These are fonts for which we have to ignore "named" encodings */
+typedef struct known_symbolic_font_name_s
+{
+ const char *name;
+ const int namelen;
+} known_symbolic_font_name_t;
+
+#define DEFINE_NAME_LEN(s) #s, sizeof(#s) - 1
+static const known_symbolic_font_name_t known_symbolic_font_names[] =
+{
+ {DEFINE_NAME_LEN(Symbol)},
+ {DEFINE_NAME_LEN(Wingdings2)},
+ {DEFINE_NAME_LEN(Wingdings)},
+ {DEFINE_NAME_LEN(ZapfDingbats)},
+ {NULL , 0}
+};
+#undef DEFINE_NAME_LEN
+
+bool pdfi_font_known_symbolic(pdf_obj *basefont)
+{
+ bool ignore = false;
+ int i;
+ pdf_name *nm = (pdf_name *)basefont;
+
+ if (basefont != NULL && basefont->type == PDF_NAME) {
+ for (i = 0; known_symbolic_font_names[i].name != NULL; i++) {
+ if (nm->length == known_symbolic_font_names[i].namelen
+ && !strncmp((char *)nm->data, known_symbolic_font_names[i].name, nm->length)) {
+ ignore = true;
+ break;
+ }
+ }
+ }
+ return ignore;
+}
+
+static int
+pdfi_font_match_glyph_widths(pdf_font *pdfont)
+{
+ int code = 0;
+ int i;
+ int sindex, lindex;
+ gs_font_base *pbfont = pdfont->pfont;
+ double fw = 0.0, ww = 0.0;
+
+ if (pdfont->LastChar < pdfont->FirstChar || pdfont->Widths == NULL)
+ return 0; /* Technically invalid - carry on, hope for the best */
+
+ /* For "best" results, restrict to what we *hope* are A-Z,a-z */
+ sindex = pdfont->FirstChar < 96 ? 96 : pdfont->FirstChar;
+ lindex = pdfont->LastChar > 122 ? 122 : pdfont->LastChar;
+
+ for (i = sindex; i < lindex; i++) {
+ gs_glyph_info_t ginfo = {0};
+ gs_glyph g;
+ g = pbfont->procs.encode_char((gs_font *)pbfont, i, GLYPH_SPACE_NAME);
+
+ /* We're only interested in non-zero Widths entries for glyphs that actually exist in the font */
+ if (g != GS_NO_GLYPH && pdfont->Widths[i - pdfont->FirstChar] != 0.0
+ && (*pbfont->procs.glyph_info)((gs_font *)pbfont, g, NULL, GLYPH_INFO_WIDTH0, &ginfo) >= 0) {
+ fw += hypot(ginfo.width[0].x, ginfo.width[0].y);
+ ww += pdfont->Widths[i - pdfont->FirstChar];
+ }
+ }
+ /* Only reduce font width, don't expand */
+ if (ww != 0.0 && fw != 0.0 && ww / fw < 1.0) {
+ gs_matrix nmat, smat = {1.0, 0.0, 0.0, 1.0, 0.0, 0.0};
+ double wscale;
+ smat.xx = smat.yy = ww/fw;
+ wscale = 1.0 / smat.xx;
+
+ gs_matrix_multiply(&pbfont->FontMatrix, &smat, &nmat);
+ memcpy(&pbfont->FontMatrix, &nmat, sizeof(pbfont->FontMatrix));
+
+ for (i = pdfont->FirstChar; i <= pdfont->LastChar; i++) {
+ pdfont->Widths[i - pdfont->FirstChar] *= wscale;
+ }
+
+ /* Purging a font can be expensive, but in this case, we know
+ we have no scaled instances (pdfi doesn't work that way)
+ and we know we have no fm pairs, nor glyphs to purge (we
+ *just* created the font!).
+ So "purging" the font is really just removing it from the
+ doubly linked list of font objects in the font directory
+ */
+ code = gs_purge_font((gs_font *)pbfont);
+ if (code >= 0)
+ code = gs_definefont(pbfont->dir, (gs_font *)pbfont);
+ if (code >= 0)
+ code = pdfi_fapi_passfont((pdf_font *)pdfont, 0, NULL, NULL, NULL, 0);
+ }
+
+ return code;
+}
+
+
+/* Call with a CIDFont name to try to find the CIDFont on disk
+ call if with ffname NULL to load the default fallback CIDFont
+ substitue
+ Currently only loads subsitute - DroidSansFallback
+ */
+static int
+pdfi_open_CIDFont_substitute_file(pdf_context * ctx, pdf_dict *font_dict, pdf_dict *fontdesc, bool fallback, byte ** buf, int64_t * buflen)
+{
+ int code = gs_error_invalidfont;
+
+ if (fallback == true) {
+ char fontfname[gp_file_name_sizeof];
+ const char *fsprefix = "CIDFSubst/";
+ const int fsprefixlen = strlen(fsprefix);
+ const char *defcidfallack = "DroidSansFallback.ttf";
+ const int defcidfallacklen = strlen(defcidfallack);
+ stream *s;
+ code = 0;
+
+ memcpy(fontfname, fsprefix, fsprefixlen);
+ memcpy(fontfname + fsprefixlen, defcidfallack, defcidfallacklen);
+ fontfname[fsprefixlen + defcidfallacklen] = '\0';
+
+ code = pdfi_open_resource_file(ctx, fontfname, strlen(fontfname), &s);
+ if (code >= 0) {
+ sfseek(s, 0, SEEK_END);
+ *buflen = sftell(s);
+ sfseek(s, 0, SEEK_SET);
+ *buf = gs_alloc_bytes(ctx->memory, *buflen, "pdfi_open_CIDFont_file(buf)");
+ if (*buf != NULL) {
+ sfread(*buf, 1, *buflen, s);
+ }
+ else {
+ code = gs_note_error(gs_error_VMerror);
+ }
+ sfclose(s);
+ }
+ }
+ else {
+ code = gs_error_invalidfont;
+ }
+
+ return code;
+}
+
+enum
+{
+ pdfi_font_flag_none = 0x00000,
+ pdfi_font_flag_fixed = 0x00001,
+ pdfi_font_flag_serif = 0x00002,
+ pdfi_font_flag_symbolic = 0x00004,
+ pdfi_font_flag_script = 0x00008,
+ pdfi_font_flag_nonsymbolic = 0x00020,
+ pdfi_font_flag_italic = 0x00040,
+ pdfi_font_flag_allcap = 0x10000,
+ pdfi_font_flag_smallcap = 0x20000,
+ pdfi_font_flag_forcebold = 0x40000
+};
+
+/* Barefaced theft from mupdf! */
+static const char *pdfi_base_font_names[][10] =
+{
+ { "Courier", "CourierNew", "CourierNewPSMT", "CourierStd", NULL },
+ { "Courier-Bold", "CourierNew,Bold", "Courier,Bold", "CourierNewPS-BoldMT", "CourierNew-Bold", NULL },
+ { "Courier-Oblique", "CourierNew,Italic", "Courier,Italic", "CourierNewPS-ItalicMT", "CourierNew-Italic", NULL },
+ { "Courier-BoldOblique", "CourierNew,BoldItalic", "Courier,BoldItalic", "CourierNewPS-BoldItalicMT", "CourierNew-BoldItalic", NULL },
+ { "Helvetica", "ArialMT", "Arial", NULL },
+ { "Helvetica-Bold", "Arial-BoldMT", "Arial,Bold", "Arial-Bold", "Helvetica,Bold", NULL },
+ { "Helvetica-Oblique", "Arial-ItalicMT", "Arial,Italic", "Arial-Italic", "Helvetica,Italic", "Helvetica-Italic", NULL },
+ { "Helvetica-BoldOblique", "Arial-BoldItalicMT", "Arial,BoldItalic", "Arial-BoldItalic", "Helvetica,BoldItalic", "Helvetica-BoldItalic", NULL },
+ { "Times-Roman", "TimesNewRomanPSMT", "TimesNewRoman", "TimesNewRomanPS", NULL },
+ { "Times-Bold", "TimesNewRomanPS-BoldMT", "TimesNewRoman,Bold", "TimesNewRomanPS-Bold", "TimesNewRoman-Bold", NULL },
+ { "Times-Italic", "TimesNewRomanPS-ItalicMT", "TimesNewRoman,Italic", "TimesNewRomanPS-Italic", "TimesNewRoman-Italic", NULL },
+ { "Times-BoldItalic", "TimesNewRomanPS-BoldItalicMT", "TimesNewRoman,BoldItalic", "TimesNewRomanPS-BoldItalic", "TimesNewRoman-BoldItalic", NULL },
+ { "Symbol", "Symbol,Italic", "Symbol,Bold", "Symbol,BoldItalic", "SymbolMT", "SymbolMT,Italic", "SymbolMT,Bold", "SymbolMT,BoldItalic", NULL },
+ { "ZapfDingbats", NULL }
+};
+
+static int strncmp_ignore_space(const char *a, const char *b)
+{
+ while (1)
+ {
+ while (*a == ' ')
+ a++;
+ while (*b == ' ')
+ b++;
+ if (*a != *b)
+ return 1;
+ if (*a == 0)
+ return *a != *b;
+ if (*b == 0)
+ return *a != *b;
+ a++;
+ b++;
+ }
+ return 0; /* Shouldn't happen */
+}
+
+static const char *pdfi_clean_font_name(const char *fontname)
+{
+ int i, k;
+ for (i = 0; i < (sizeof(pdfi_base_font_names)/sizeof(pdfi_base_font_names[0])); i++) {
+ for (k = 0; pdfi_base_font_names[i][k]; k++) {
+ if (!strncmp_ignore_space(pdfi_base_font_names[i][k], (const char *)fontname))
+ return pdfi_base_font_names[i][0];
+ }
+ }
+ return NULL;
+}
+
+static const char *pdfi_font_substitute_by_flags(unsigned int flags)
+{
+ bool fixed = ((flags & pdfi_font_flag_fixed) != 0);
+ bool serif = ((flags & pdfi_font_flag_serif) != 0);
+ bool italic = ((flags & pdfi_font_flag_italic) != 0);
+ bool bold = ((flags & pdfi_font_flag_forcebold) != 0);
+
+ if (fixed) {
+ if (bold) {
+ if (italic) {
+ return "Courier-BoldOblique";
+ }
+ else {
+ return "Courier-Bold";
+ }
+ }
+ else {
+ if (italic) {
+ return "Courier-Oblique";
+ }
+ else {
+ return "Courier";
+ }
+ }
+ }
+ else if (serif) {
+ if (bold) {
+ if (italic) {
+ return "Times-BoldItalic";
+ }
+ else {
+ return "Times-Bold";
+ }
+ }
+ else {
+ if (italic) {
+ return "Times-Italic";
+ }
+ else {
+ return "Times-Roman";
+ }
+ }
+ } else {
+ if (bold) {
+ if (italic) {
+ return "Helvetica-BoldOblique";
+ }
+ else {
+ return "Helvetica-Bold";
+ }
+ }
+ else {
+ if (italic) {
+ return "Helvetica-Oblique";
+ }
+ }
+ }
+ return "Helvetica"; /* Really shouldn't ever happen */
+}
+
+static void pdfi_emprint_font_name(pdf_context *ctx, pdf_name *n)
+{
+ int i;
+ for (i = 0; i < n->length; i++) {
+ dmprintf1(ctx->memory, "%c", n->data[i]);
+ }
+}
+
+static int
+pdfi_open_font_substitute_file(pdf_context *ctx, pdf_dict *font_dict, pdf_dict *fontdesc, bool fallback, byte **buf, int64_t *buflen)
+{
+ int code;
+ char fontfname[gp_file_name_sizeof];
+ pdf_obj *basefont = NULL, *mapname;
+ pdf_obj *fontname = NULL;
+ stream *s;
+ const char *fn;
+
+ code = pdfi_dict_knownget_type(ctx, font_dict, "BaseFont", PDF_NAME, &basefont);
+ if (code < 0 || ((pdf_name *)basefont)->length == 0)
+ fallback = true;
+
+ if (fallback == true) {
+ const char *fbname;
+ int64_t flags = 0;
+ if (fontdesc != NULL) {
+ (void)pdfi_dict_get_int(ctx, fontdesc, "Flags", &flags);
+ }
+ fbname = pdfi_font_substitute_by_flags((int)flags);
+ code = pdfi_name_alloc(ctx, (byte *)fbname, strlen(fbname), (pdf_obj **) &fontname);
+ if (code < 0)
+ return code;
+ pdfi_countup(fontname);
+ }
+ else {
+ fontname = basefont;
+ pdfi_countup(fontname);
+ }
+
+ if (((pdf_name *)fontname)->length < gp_file_name_sizeof) {
+ memcpy(fontfname, ((pdf_name *)fontname)->data, ((pdf_name *)fontname)->length);
+ fontfname[((pdf_name *)fontname)->length] = '\0';
+ fn = pdfi_clean_font_name(fontfname);
+ if (fn != NULL) {
+ pdfi_countdown(fontname);
+
+ code = pdfi_name_alloc(ctx, (byte *)fn, strlen(fn), (pdf_obj **) &fontname);
+ if (code < 0)
+ return code;
+ pdfi_countup(fontname);
+ }
+ }
+ code = pdf_fontmap_lookup_font(ctx, (pdf_name *) fontname, &mapname);
+ if (code < 0) {
+ mapname = fontname;
+ pdfi_countup(mapname);
+ code = 0;
+ }
+ if (mapname->type == PDF_NAME) {
+ pdf_name *mname = (pdf_name *) mapname;
+ if (mname->length + 1 < gp_file_name_sizeof) {
+ memcpy(fontfname, mname->data, mname->length);
+ fontfname[mname->length] = '\0';
+ }
+ else {
+ return_error(gs_error_invalidfileaccess);
+ }
+ }
+
+ code = pdfi_open_font_file(ctx, fontfname, strlen(fontfname), &s);
+ if (code >= 0) {
+ gs_const_string fname;
+ if (basefont) {
+ dmprintf(ctx->memory, "Loading font ");
+ pdfi_emprint_font_name(ctx, (pdf_name *)basefont);
+ dmprintf(ctx->memory, " (or substitute) from ");
+ }
+ else {
+ dmprintf(ctx->memory, "Loading nameless font from ");
+ }
+ sfilename(s, &fname);
+ if (fname.size < gp_file_name_sizeof) {
+ memcpy(fontfname, fname.data, fname.size);
+ fontfname[fname.size] = '\0';
+ }
+ dmprintf1(ctx->memory, "%s.\n", fontfname);
+
+ sfseek(s, 0, SEEK_END);
+ *buflen = sftell(s);
+ sfseek(s, 0, SEEK_SET);
+ *buf = gs_alloc_bytes(ctx->memory, *buflen, "pdfi_open_t1_font_file(buf)");
+ if (*buf != NULL) {
+ sfread(*buf, 1, *buflen, s);
+ }
+ else {
+ code = gs_note_error(gs_error_VMerror);
+ }
+ sfclose(s);
+ }
+
+ pdfi_countdown(basefont);
+ pdfi_countdown(mapname);
+ pdfi_countdown(fontname);
+ return code;
+}
+
+enum {
+ no_type_font = -1,
+ type0_font = 0,
+ type1_font = 1,
+ cff_font = 2,
+ type3_font = 3,
+ tt_font = 42
+};
+
+static int pdfi_fonttype_picker(byte *buf, int64_t buflen)
+{
+#define MAKEMAGIC(a, b, c, d) (((a) << 24) | ((b) << 16) | ((c) << 8) | (d))
+
+ if (buflen >= 4) {
+ if (MAKEMAGIC(buf[0], buf[1], buf[2], buf[3]) == MAKEMAGIC(0, 1, 0, 0)
+ || MAKEMAGIC(buf[0], buf[1], buf[2], buf[3]) == MAKEMAGIC('t', 'r', 'u', 'e')
+ || MAKEMAGIC(buf[0], buf[1], buf[2], buf[3]) == MAKEMAGIC('t', 't', 'c', 'f')) {
+ return tt_font;
+ }
+ else if (MAKEMAGIC(buf[0], buf[1], buf[2], buf[3]) == MAKEMAGIC('O', 'T', 'T', 'O')) {
+ return cff_font; /* OTTO will end up as CFF */
+ }
+ else if (MAKEMAGIC(buf[0], buf[1], buf[2], 0) == MAKEMAGIC('%', '!', 'P', 0)) {
+ return type1_font; /* pfa */
+ }
+ else if (MAKEMAGIC(buf[0], buf[1], buf[2], 0) == MAKEMAGIC(1, 0, 4, 0)) {
+ return cff_font; /* 1C/CFF */
+ }
+ else if (MAKEMAGIC(buf[0], buf[1], 0, 0) == MAKEMAGIC(128, 1, 0, 0)) {
+ return type1_font; /* pfb */
+ }
+ }
+ return no_type_font;
+#undef MAKEMAGIC
+}
+
+enum {
+ font_embedded = 0,
+ font_from_file = 1,
+ font_substitute = 2
+};
+
+int pdfi_load_font(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict, pdf_dict *font_dict, gs_font **ppfont, bool cidfont)
+{
+ int code;
+ pdf_font *ppdffont = NULL;
+ pdf_name *Type = NULL;
+ pdf_name *Subtype = NULL;
+ pdf_dict *fontdesc = NULL;
+ pdf_stream *fontfile = NULL;
+ pdf_name *ffsubtype = NULL;
+ int fftype = no_type_font;
+ byte *fbuf = NULL;
+ int64_t fbuflen;
+ int substitute = font_embedded;
+
+ code = pdfi_dict_get_type(ctx, font_dict, "Type", PDF_NAME, (pdf_obj **)&Type);
+ if (code < 0)
+ goto exit;
+ if (!pdfi_name_is(Type, "Font")){
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+ code = pdfi_dict_get_type(ctx, font_dict, "Subtype", PDF_NAME, (pdf_obj **)&Subtype);
+
+ /* Beyond Type 0 and Type 3, there is no point trusting the Subtype key */
+ if (code >= 0 && pdfi_name_is(Subtype, "Type0")) {
+ code = pdfi_read_type0_font(ctx, (pdf_dict *)font_dict, stream_dict, page_dict, &ppdffont);
+ }
+ else if (code >= 0 && pdfi_name_is(Subtype, "Type3")) {
+ code = pdfi_read_type3_font(ctx, (pdf_dict *)font_dict, stream_dict, page_dict, &ppdffont);
+ if (code < 0)
+ goto exit;
+ }
+ else {
+ /* We should always have a font descriptor here, but we have to carry on
+ even if we don't
+ */
+ code = pdfi_dict_get_type(ctx, font_dict, "FontDescriptor", PDF_DICT, (pdf_obj**)&fontdesc);
+ if (fontdesc != NULL && fontdesc->type == PDF_DICT) {
+ code = pdfi_dict_get_type(ctx, (pdf_dict *) fontdesc, "FontFile", PDF_STREAM, (pdf_obj**)&fontfile);
+ if (code >= 0)
+ fftype = type1_font;
+ else {
+ code = pdfi_dict_get_type(ctx, (pdf_dict *) fontdesc, "FontFile2", PDF_STREAM, (pdf_obj**)&fontfile);
+ fftype = tt_font;
+ }
+ if (code < 0) {
+ code = pdfi_dict_get_type(ctx, (pdf_dict *) fontdesc, "FontFile3", PDF_STREAM, (pdf_obj**)&fontfile);
+ if (fontfile != NULL) {
+ code = pdfi_dict_get_type(ctx, fontfile->stream_dict, "Subtype", PDF_NAME, (pdf_obj **)&ffsubtype);
+ if (code >= 0) {
+ if (pdfi_name_is(ffsubtype, "Type1"))
+ fftype = type1_font;
+ else if (pdfi_name_is(ffsubtype, "Type1C"))
+ fftype = cff_font;
+ else if (pdfi_name_is(ffsubtype, "OpenType"))
+ fftype = cff_font;
+ else if (pdfi_name_is(ffsubtype, "CIDFontType0C"))
+ fftype = cff_font;
+ else if (pdfi_name_is(ffsubtype, "TrueType"))
+ fftype = tt_font;
+ else
+ fftype = no_type_font;
+ }
+ }
+ }
+ }
+
+ if (fontfile != NULL) {
+ code = pdfi_stream_to_buffer(ctx, (pdf_stream *) fontfile, &fbuf, &fbuflen);
+ pdfi_countdown(fontfile);
+ if (fbuflen == 0) {
+ gs_free_object(ctx->memory, fbuf, "pdfi_load_font(fbuf)");
+ fbuf = NULL;
+ code = gs_note_error(gs_error_invalidfont);
+ }
+ }
+
+ while (1) {
+ if (fbuf != NULL) {
+ /* First, see if we can glean the type from the magic number */
+ int sftype = pdfi_fonttype_picker(fbuf, fbuflen);
+ if (sftype == no_type_font) {
+ if (fftype != no_type_font)
+ sftype = fftype;
+ else {
+ if (pdfi_name_is(Subtype, "Type1") || pdfi_name_is(Subtype, "MMType1"))
+ sftype = type1_font;
+ else if (pdfi_name_is(Subtype, "Type1C"))
+ sftype = cff_font;
+ else if (pdfi_name_is(Subtype, "TrueType"))
+ sftype = tt_font;
+ }
+ }
+ /* fbuf ownership passes to the font loader */
+ switch (sftype) {
+ case type1_font:
+ code = pdfi_read_type1_font(ctx, (pdf_dict *)font_dict, stream_dict, page_dict, fbuf, fbuflen, &ppdffont);
+ fbuf = NULL;
+ break;
+ case cff_font:
+ code = pdfi_read_cff_font(ctx, (pdf_dict *)font_dict, stream_dict, page_dict, fbuf, fbuflen, cidfont, &ppdffont);
+ fbuf = NULL;
+ break;
+ case tt_font:
+ {
+ if (cidfont)
+ code = pdfi_read_cidtype2_font(ctx, font_dict, stream_dict, page_dict, fbuf, fbuflen, &ppdffont);
+ else
+ code = pdfi_read_truetype_font(ctx, font_dict, stream_dict, page_dict, fbuf, fbuflen, &ppdffont);
+ fbuf = NULL;
+ }
+ break;
+ default:
+ code = gs_note_error(gs_error_invalidfont);
+ }
+ if (code < 0 && substitute == font_embedded) {
+ dmprintf2(ctx->memory, "**** Error: can't process embedded stream for font object %d %d.\n", font_dict->object_num, font_dict->generation_num);
+ dmprintf(ctx->memory, "**** Attempting to load substitute font.\n");
+ }
+ }
+
+ if (code < 0 && code != gs_error_VMerror && substitute == font_embedded) {
+ /* Font not embedded, or embedded font not usable - use a substitute */
+ if (fbuf != NULL) {
+ gs_free_object(ctx->memory, fbuf, "pdfi_load_font(fbuf)");
+ }
+
+ substitute = font_from_file;
+
+ if (cidfont == true) {
+ code = pdfi_open_CIDFont_substitute_file(ctx, font_dict, fontdesc, false, &fbuf, &fbuflen);
+ if (code < 0) {
+ code = pdfi_open_CIDFont_substitute_file(ctx, font_dict, fontdesc, true, &fbuf, &fbuflen);
+ substitute |= font_substitute;
+ }
+
+ if (code < 0)
+ goto exit;
+ }
+ else {
+ code = pdfi_open_font_substitute_file(ctx, font_dict, fontdesc, false, &fbuf, &fbuflen);
+ if (code < 0) {
+ code = pdfi_open_font_substitute_file(ctx, font_dict, fontdesc, true, &fbuf, &fbuflen);
+ substitute |= font_substitute;
+ }
+
+ if (code < 0)
+ goto exit;
+ }
+ continue;
+ }
+ break;
+ }
+ }
+
+ if (ppdffont == NULL || code < 0) {
+ *ppfont = NULL;
+ code = gs_note_error(gs_error_invalidfont);
+ }
+ else {
+ if (cidfont) {
+ ((pdf_cidfont_t *)ppdffont)->substitute = (substitute != font_embedded);
+ }
+ else {
+ if ((substitute & font_substitute) == font_substitute)
+ code = pdfi_font_match_glyph_widths(ppdffont);
+ }
+ *ppfont = (gs_font *)ppdffont->pfont;
+ }
+
+exit:
+ pdfi_countdown(fontdesc);
+ pdfi_countdown(Type);
+ pdfi_countdown(Subtype);
+ pdfi_countdown(ffsubtype);
+ return code;
+}
+
+int pdfi_load_dict_font(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict, pdf_dict *font_dict, double point_size)
+{
+ int code;
+ gs_font *pfont;
+
+ if (font_dict->type == PDF_FONT) {
+ pdfi_countup(font_dict);
+ pfont = (gs_font *)((pdf_font *)font_dict)->pfont;
+ code = 0;
+ }
+ else {
+ if (font_dict->type != PDF_DICT) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+ code = pdfi_load_font(ctx, stream_dict, page_dict, font_dict, &pfont, false);
+ }
+ if (code < 0)
+ goto exit;
+
+ /* Everything looks good, set the font, unless it's the current font */
+ if (pfont != ctx->pgs->font) {
+ code = pdfi_gs_setfont(ctx, pfont);
+ }
+ else {
+ pdf_font *pdfif = (pdf_font *)pfont->client_data;
+ pdfi_countdown(pdfif);
+ }
+
+ if (code < 0)
+ goto exit;
+
+ code = gs_setPDFfontsize(ctx->pgs, point_size);
+exit:
+ return code;
+}
+
+static int pdfi_load_resource_font(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict, pdf_name *fontname, double point_size)
+{
+ int code;
+ pdf_dict *font_dict = NULL;
+
+ if (fontname->type != PDF_NAME) {
+ /* Passing empty string here should fall back to a default font */
+ return pdfi_font_set_internal_string(ctx, "", point_size);
+ }
+
+ /* Look fontname up in the resources */
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ goto exit;
+ code = pdfi_find_resource(ctx, (unsigned char *)"Font", fontname, stream_dict, page_dict, (pdf_obj **)&font_dict);
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ if (code < 0)
+ goto exit;
+ code = pdfi_load_dict_font(ctx, stream_dict, page_dict, font_dict, point_size);
+
+exit:
+ pdfi_countdown(font_dict);
+ return code;
+}
+
+int pdfi_get_cidfont_glyph_metrics(gs_font *pfont, gs_glyph cid, double *widths, bool vertical)
+{
+ pdf_font *pdffont = (pdf_font *)pfont->client_data;
+ int i, code = 0;
+ pdf_num *c = NULL, *c2 = NULL;
+ pdf_obj *o = NULL;
+ pdf_array *W = NULL, *W2 = NULL, *DW2 = NULL;
+ double DW;
+
+ if (pdffont->pdfi_font_type == e_pdf_cidfont_type0) {
+ pdf_cidfont_type0 *cidfont = (pdf_cidfont_type0 *)pdffont;
+ DW = (double)cidfont->DW;
+ DW2 = cidfont->DW2;
+ W = cidfont->W;
+ W2 = cidfont->W2;
+ }
+ else if (pdffont->pdfi_font_type == e_pdf_cidfont_type2) {
+ pdf_cidfont_type2 *cidfont = (pdf_cidfont_type2 *)pdffont;
+ DW = (double)cidfont->DW;
+ DW2 = cidfont->DW2;
+ W = cidfont->W;
+ W2 = cidfont->W2;
+ }
+ else {
+ return_error(gs_error_invalidfont);
+ }
+
+ widths[GLYPH_W0_WIDTH_INDEX] = DW;
+ widths[GLYPH_W0_HEIGHT_INDEX] = 0;
+ if (W != NULL) {
+ i = 0;
+
+ while(1) {
+ if (i + 1>= W->size) break;
+ code = pdfi_array_get_type(pdffont->ctx, W, i, PDF_INT, (pdf_obj **)&c);
+ if (code < 0) goto cleanup;
+
+ code = pdfi_array_get(pdffont->ctx, W, i + 1, &o);
+ if (code < 0) goto cleanup;
+
+ if (o->type == PDF_INT) {
+ c2 = (pdf_num *)o;
+ o = NULL;
+ if (i + 2 >= W->size){
+ /* We countdown and NULL c, c2 and o after exit from the loop
+ * in order to avoid doing so in the break statements
+ */
+ break;
+ }
+
+ code = pdfi_array_get(pdffont->ctx, W, i + 2, (pdf_obj **)&o);
+ if (code < 0) goto cleanup;
+ if (o->type != PDF_INT && o->type != PDF_REAL) {
+ code = gs_note_error(gs_error_typecheck);
+ goto cleanup;
+ }
+ if (cid >= c->value.i && cid <= c2->value.i) {
+ if (o->type == PDF_INT)
+ widths[GLYPH_W0_WIDTH_INDEX] = (double)((pdf_num *)o)->value.i;
+ else
+ widths[GLYPH_W0_WIDTH_INDEX] = ((pdf_num *)o)->value.d;
+
+ widths[GLYPH_W0_HEIGHT_INDEX] = 0.0;
+ /* We countdown and NULL c, c2 and o after exit from the loop
+ * in order to avoid doing so in the break statements
+ */
+ break;
+ }
+ else {
+ i += 3;
+ pdfi_countdown(c2);
+ pdfi_countdown(c);
+ pdfi_countdown(o);
+ c = c2 = NULL;
+ o = NULL;
+ continue;
+ }
+ }
+ else if (o->type == PDF_ARRAY) {
+ pdf_array *a = (pdf_array *)o;
+ o = NULL;
+ if (cid >= c->value.i && cid < c->value.i + a->size) {
+ code = pdfi_array_get(pdffont->ctx, a, cid - c->value.i, (pdf_obj **)&o);
+ if (code >= 0) {
+ pdfi_countdown(a);
+ if (o->type == PDF_INT)
+ widths[GLYPH_W0_WIDTH_INDEX] = (double)((pdf_num *)o)->value.i;
+ else if (o->type == PDF_REAL)
+ widths[GLYPH_W0_WIDTH_INDEX] = ((pdf_num *)o)->value.d;
+ else {
+ code = gs_note_error(gs_error_typecheck);
+ goto cleanup;
+ }
+ widths[GLYPH_W0_HEIGHT_INDEX] = 0.0;
+ /* We countdown and NULL c, c2 and o on exit from the loop
+ * in order to avoid doing so in the break statements
+ */
+ break;
+ }
+ }
+ pdfi_countdown(a);
+ pdfi_countdown(c);
+ pdfi_countdown(o);
+ o = NULL;
+ c = NULL;
+ i += 2;
+ continue;
+ }
+ else {
+ code = gs_note_error(gs_error_typecheck);
+ goto cleanup;
+ }
+ }
+ pdfi_countdown(c2);
+ pdfi_countdown(c);
+ pdfi_countdown(o);
+ c = c2 = NULL;
+ o = NULL;
+ }
+
+ if (vertical) {
+ /* Default default <sigh>! */
+ widths[GLYPH_W1_WIDTH_INDEX] = 0;
+ widths[GLYPH_W1_HEIGHT_INDEX] = -1000.0;
+ widths[GLYPH_W1_V_X_INDEX] = (widths[GLYPH_W0_WIDTH_INDEX] / 2.0);
+ widths[GLYPH_W1_V_Y_INDEX] = 880.0;
+
+ if (DW2 != NULL && DW2->type == PDF_ARRAY
+ && DW2->size >= 2) {
+ pdf_num *w2_0 = NULL, *w2_1 = NULL;
+
+ code = pdfi_array_get(pdffont->ctx, (pdf_array *)DW2, 0, (pdf_obj **)&w2_0);
+ if (code >= 0 && (w2_0->type == PDF_INT || w2_0->type == PDF_REAL)) {
+ code = pdfi_array_get(pdffont->ctx, (pdf_array *)DW2, 1, (pdf_obj **)&w2_1);
+ if (code >= 0 && (w2_1->type == PDF_INT || w2_1->type == PDF_REAL)) {
+ widths[GLYPH_W1_V_X_INDEX] = widths[GLYPH_W0_WIDTH_INDEX] / 2.0;
+ if (w2_0->type == PDF_INT)
+ widths[GLYPH_W1_V_Y_INDEX] = (double)w2_0->value.i;
+ else
+ widths[GLYPH_W1_V_Y_INDEX] = (double)w2_0->value.d;
+
+ widths[GLYPH_W1_WIDTH_INDEX] = 0.0;
+ if (w2_1->type == PDF_INT)
+ widths[GLYPH_W1_HEIGHT_INDEX] = (double)w2_1->value.i;
+ else
+ widths[GLYPH_W1_HEIGHT_INDEX] = (double)w2_1->value.d;
+ }
+ }
+ pdfi_countdown(w2_0);
+ pdfi_countdown(w2_1);
+ }
+ if (W2 != NULL && W2->type == PDF_ARRAY) {
+ i = 0;
+ while(1) {
+ if (i + 1 >= W2->size) break;
+ (void)pdfi_array_get(pdffont->ctx, W2, i, (pdf_obj **)&c);
+ if (c->type != PDF_INT) {
+ code = gs_note_error(gs_error_typecheck);
+ goto cleanup;
+ }
+ code = pdfi_array_get(pdffont->ctx, W2, i + 1, (pdf_obj **)&o);
+ if (code < 0) goto cleanup;
+ if (o->type == PDF_INT) {
+ if (cid >= c->value.i && cid <= ((pdf_num *)o)->value.i) {
+ pdf_num *w1y, *v1x, *v1y;
+ if (i + 4 >= W2->size) {
+ /* We countdown and NULL c, and o on exit from the function
+ * so we don't need to do so in the break statements
+ */
+ break;
+ }
+ (void)pdfi_array_get(pdffont->ctx, W2, i + 1, (pdf_obj **)&w1y);
+ (void)pdfi_array_get(pdffont->ctx, W2, i + 1, (pdf_obj **)&v1x);
+ (void)pdfi_array_get(pdffont->ctx, W2, i + 1, (pdf_obj **)&v1y);
+ if (w1y != NULL && (w1y->type == PDF_INT || w1y->type == PDF_REAL)
+ && v1x != NULL && (v1x->type == PDF_INT || v1x->type == PDF_REAL)
+ && v1y != NULL && (v1y->type == PDF_INT || v1y->type == PDF_REAL)) {
+ widths[GLYPH_W1_WIDTH_INDEX] = 0;
+ if (w1y->type == PDF_INT)
+ widths[GLYPH_W1_HEIGHT_INDEX] = (double)w1y->value.i;
+ else
+ widths[GLYPH_W1_HEIGHT_INDEX] = w1y->value.d;
+
+ if (v1x->type == PDF_INT)
+ widths[GLYPH_W1_V_X_INDEX] = (double)v1x->value.i;
+ else
+ widths[GLYPH_W1_V_X_INDEX] = v1x->value.d;
+
+ if (v1y->type == PDF_INT)
+ widths[GLYPH_W1_V_Y_INDEX] = (double)v1y->value.i;
+ else
+ widths[GLYPH_W1_V_Y_INDEX] = v1y->value.d;
+ }
+ else
+ code = gs_note_error(gs_error_typecheck);
+
+ pdfi_countdown(w1y);
+ pdfi_countdown(v1x);
+ pdfi_countdown(v1y);
+ if (code < 0) goto cleanup;
+ /* We countdown and NULL c, and o on exit from the function
+ * so we don't need to do so in the break statements
+ */
+ break;
+ }
+ i += 5;
+ }
+ else if (o->type == PDF_ARRAY) {
+ pdf_array *a = (pdf_array *)o;
+ int l = a->size - (a->size % 3);
+ o = NULL;
+ if (cid >= c->value.i && cid < c->value.i + (l / 3)) {
+ pdf_num *w1y = NULL, *v1x = NULL, *v1y = NULL;
+ int index = (cid - c->value.i) * 3;
+ (void)pdfi_array_get(pdffont->ctx, a, index, (pdf_obj **)&w1y);
+ (void)pdfi_array_get(pdffont->ctx, a, index + 1, (pdf_obj **)&v1x);
+ (void)pdfi_array_get(pdffont->ctx, a, index + 2, (pdf_obj **)&v1y);
+ pdfi_countdown(a);
+
+ if (w1y != NULL && (w1y->type == PDF_INT || w1y->type == PDF_REAL)
+ && v1x != NULL && (v1x->type == PDF_INT || v1x->type == PDF_REAL)
+ && v1y != NULL && (v1y->type == PDF_INT || v1y->type == PDF_REAL)) {
+ widths[GLYPH_W1_WIDTH_INDEX] = 0.0;
+ if (w1y->type == PDF_INT)
+ widths[GLYPH_W1_HEIGHT_INDEX] = (double)w1y->value.i;
+ else
+ widths[GLYPH_W1_HEIGHT_INDEX] = w1y->value.d;
+
+ if (v1x->type == PDF_INT)
+ widths[GLYPH_W1_V_X_INDEX] = (double)v1x->value.i;
+ else
+ widths[GLYPH_W1_V_X_INDEX] = v1x->value.d;
+
+ if (v1y->type == PDF_INT)
+ widths[GLYPH_W1_V_Y_INDEX] = (double)v1y->value.i;
+ else
+ widths[GLYPH_W1_V_Y_INDEX] = v1y->value.d;
+ }
+ else
+ code = gs_note_error(gs_error_typecheck);
+ pdfi_countdown(w1y);
+ pdfi_countdown(v1x);
+ pdfi_countdown(v1y);
+ if (code < 0) goto cleanup;
+ /* We countdown and NULL c, and o on exit from the function
+ * so we don't need to do so in the break statements
+ */
+ break;
+ } else
+ pdfi_countdown(a);
+ i += 2;
+ }
+ else {
+ code = gs_note_error(gs_error_typecheck);
+ goto cleanup;
+ }
+ pdfi_countdown(o);
+ pdfi_countdown(c);
+ o = NULL;
+ c = NULL;
+ }
+ }
+ }
+
+cleanup:
+ pdfi_countdown(c2);
+ pdfi_countdown(c);
+ pdfi_countdown(o);
+
+ return code;
+}
+
+int pdfi_d0(pdf_context *ctx)
+{
+ int code = 0, gsave_level = 0;
+ double width[2];
+
+ if (ctx->text.inside_CharProc == false)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_NOTINCHARPROC, "pdfi_d0", NULL);
+
+ if (pdfi_count_stack(ctx) < 2) {
+ code = gs_note_error(gs_error_stackunderflow);
+ goto d0_error;
+ }
+
+ if (ctx->stack_top[-1]->type != PDF_INT && ctx->stack_top[-1]->type != PDF_REAL) {
+ code = gs_note_error(gs_error_typecheck);
+ goto d0_error;
+ }
+ if (ctx->stack_top[-2]->type != PDF_INT && ctx->stack_top[-2]->type != PDF_REAL) {
+ code = gs_note_error(gs_error_typecheck);
+ goto d0_error;
+ }
+ if(ctx->text.current_enum == NULL) {
+ code = gs_note_error(gs_error_undefined);
+ goto d0_error;
+ }
+
+ if (ctx->stack_top[-1]->type == PDF_INT)
+ width[0] = (double)((pdf_num *)ctx->stack_top[-1])->value.i;
+ else
+ width[0] = ((pdf_num *)ctx->stack_top[-1])->value.d;
+ if (ctx->stack_top[-2]->type == PDF_INT)
+ width[1] = (double)((pdf_num *)ctx->stack_top[-1])->value.i;
+ else
+ width[1] = ((pdf_num *)ctx->stack_top[-1])->value.d;
+
+ gsave_level = ctx->pgs->level;
+
+ /*
+ * We don't intend to retain this, instead we will use (effectively) xyshow to apply
+ * width overrides at the text level.
+ if (font && font->Widths && ctx->current_chr >= font->FirstChar && ctx->current_chr <= font->LastChar)
+ width[0] = font->Widths[font->ctx->current_chr - font->FirstChar];
+ */
+
+ if (ctx->text.current_enum == NULL) {
+ code = gs_note_error(gs_error_unknownerror);
+ goto d0_error;
+ }
+
+ code = gs_text_setcharwidth(ctx->text.current_enum, width);
+
+ /* Nasty hackery. setcachedevice potentially pushes a new device into the graphics state
+ * and there's no way to remove that device again without grestore'ing back to a point
+ * before the device was loaded. To facilitate this, setcachedevice will do a gs_gsave()
+ * before changing the device. Note, the grestore for this is done back in show_update()
+ * which is not reached until after the CharProc has been executed.
+ *
+ * This is a problem for us when running a PDF content stream, because after running the
+ * stream we check the gsave level and, if its not the same as it was when we started
+ * the stream, we pdfi_grestore() back until it is. This mismatch of the gsave levels
+ * causes all sorts of trouble with the font and we can end up counting the pdf_font
+ * object down and discarding the font we're tryign to use.
+ *
+ * The solution (ugly though it is) is to patch up the saved gsave_level in the
+ * context to expect that we have one more gsave level on exit. That wasy we won't
+ * try and pdf_grestore() back to an earlier point.
+ */
+ if (ctx->pgs->level > gsave_level)
+ ctx->current_stream_save.gsave_level += ctx->pgs->level - gsave_level;
+
+ if (code < 0)
+ goto d0_error;
+ pdfi_pop(ctx, 2);
+ return 0;
+
+d0_error:
+ pdfi_clearstack(ctx);
+ return code;
+}
+
+int pdfi_d1(pdf_context *ctx)
+{
+ int code = 0, i, gsave_level;
+ double wbox[6];
+
+ if (ctx->text.inside_CharProc == false)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_NOTINCHARPROC, "pdfi_d1", NULL);
+
+ ctx->text.CharProc_is_d1 = true;
+
+ if (pdfi_count_stack(ctx) < 2) {
+ code = gs_note_error(gs_error_stackunderflow);
+ goto d1_error;
+ }
+
+ for (i=-6;i < 0;i++) {
+ if (ctx->stack_top[i]->type != PDF_INT && ctx->stack_top[i]->type != PDF_REAL) {
+ code = gs_note_error(gs_error_typecheck);
+ goto d1_error;
+ }
+ if (ctx->stack_top[i]->type == PDF_INT)
+ wbox[i + 6] = (double)((pdf_num *)ctx->stack_top[i])->value.i;
+ else
+ wbox[i + 6] = ((pdf_num *)ctx->stack_top[i])->value.d;
+ }
+
+ /*
+ * We don't intend to retain this, instead we will use (effectively) xyshow to apply
+ * width overrides at the text level.
+ if (font && font->Widths && ctx->current_chr >= font->FirstChar && ctx->current_chr <= font->LastChar)
+ wbox[0] = font->Widths[font->ctx->current_chr - font->FirstChar];
+ */
+
+ gsave_level = ctx->pgs->level;
+
+ if (ctx->text.current_enum == NULL) {
+ code = gs_note_error(gs_error_unknownerror);
+ goto d1_error;
+ }
+
+ code = gs_text_setcachedevice(ctx->text.current_enum, wbox);
+
+ /* See the comment immediately after gs_text_setcachedvice() in pdfi_d0 above */
+ if (ctx->pgs->level > gsave_level)
+ ctx->current_stream_save.gsave_level += ctx->pgs->level - gsave_level;
+
+ if (code < 0)
+ goto d1_error;
+ pdfi_pop(ctx, 6);
+ return 0;
+
+d1_error:
+ pdfi_clearstack(ctx);
+ return code;
+}
+
+int pdfi_Tf(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ double point_size = 0;
+ pdf_obj *point_arg = NULL;
+ int code = 0;
+ pdf_name *fontname = NULL;
+
+ if (pdfi_count_stack(ctx) < 2) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ /* Get refs to the args and pop them */
+ point_arg = ctx->stack_top[-1];
+ pdfi_countup(point_arg);
+ fontname = (pdf_name *)ctx->stack_top[-2];
+ pdfi_countup(fontname);
+ pdfi_pop(ctx, 2);
+
+ /* Get the point_size */
+ if (point_arg->type == PDF_INT)
+ point_size = (double)((pdf_num *)point_arg)->value.i;
+ else {
+ if (point_arg->type == PDF_REAL)
+ point_size = ((pdf_num *)point_arg)->value.d;
+ else {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit0;
+ }
+ }
+
+ code = pdfi_load_resource_font(ctx, stream_dict, page_dict, fontname, point_size);
+
+ /* If we failed to load font, try to load an internal one */
+ if (code < 0)
+ code = pdfi_font_set_internal_name(ctx, fontname, point_size);
+ exit0:
+ pdfi_countdown(fontname);
+ pdfi_countdown(point_arg);
+ return code;
+}
+
+int pdfi_free_font(pdf_obj *font)
+{
+ pdf_font *f = (pdf_font *)font;
+
+ switch (f->pdfi_font_type) {
+ case e_pdf_font_type0:
+ return pdfi_free_font_type0((pdf_obj *)font);
+ break;
+ case e_pdf_font_type1:
+ return pdfi_free_font_type1((pdf_obj *)font);
+ break;
+ case e_pdf_font_cff:
+ return pdfi_free_font_cff((pdf_obj *)font);
+ case e_pdf_font_type3:
+ return pdfi_free_font_type3((pdf_obj *)font);
+ break;
+ case e_pdf_font_truetype:
+ return pdfi_free_font_truetype((pdf_obj *)font);
+ break;
+ case e_pdf_cidfont_type2:
+ return pdfi_free_font_cidtype2((pdf_obj *)font);
+ break;
+ case e_pdf_cidfont_type0:
+ return pdfi_free_font_cidtype0((pdf_obj *)font);
+ break;
+ case e_pdf_cidfont_type1:
+ case e_pdf_cidfont_type4:
+ default:
+ return gs_note_error(gs_error_typecheck);
+ break;
+ }
+ return 0;
+}
+
+/*
+ * Routine to fill in an array with each of the glyph names from a given
+ * 'standard' Encoding.
+ */
+static int pdfi_build_Encoding(pdf_context *ctx, pdf_name *name, pdf_array *Encoding)
+{
+ int i, code = 0;
+ unsigned char gs_encoding;
+ gs_glyph temp;
+ gs_const_string str;
+ pdf_name *n = NULL;
+
+ if (pdfi_array_size(Encoding) < 256)
+ return gs_note_error(gs_error_rangecheck);
+
+ if (pdfi_name_is(name, "StandardEncoding")) {
+ gs_encoding = ENCODING_INDEX_STANDARD;
+ } else {
+ if (pdfi_name_is(name, "WinAnsiEncoding")){
+ gs_encoding = ENCODING_INDEX_WINANSI;
+ } else {
+ if (pdfi_name_is(name, "MacRomanEncoding")){
+ gs_encoding = ENCODING_INDEX_MACROMAN;
+ } else {
+ if (pdfi_name_is(name, "MacExpertEncoding")){
+ gs_encoding = ENCODING_INDEX_MACEXPERT;
+ } else {
+ return_error(gs_error_undefined);
+ }
+ }
+ }
+ }
+ i = 0;
+ for (i=0;i<256;i++) {
+ temp = gs_c_known_encode(i, gs_encoding);
+ gs_c_glyph_name(temp, &str);
+ code = pdfi_name_alloc(ctx, (byte *)str.data, str.size, (pdf_obj **)&n);
+ if (code < 0)
+ return code;
+ pdfi_countup(n);
+ code = pdfi_array_put(ctx, Encoding, (uint64_t)i, (pdf_obj *)n);
+ pdfi_countdown(n);
+ if (code < 0)
+ return code;
+ }
+ return 0;
+}
+
+/*
+ * Create and fill in a pdf_array with an Encoding for a font. pdf_Encoding must be either
+ * a name (eg StandardEncoding) or a dictionary. If its a name we use that to create the
+ * entries, if its a dictionary we start by getting the BaseEncoding and using that to
+ * create an array of glyph names as above, *or* for a symbolic font, we use the "predef_Encoding"
+ * which is the encoding from the font description itself (i.e. the /Encoding array
+ * from a Type 1 font. We then get the Differences array from the dictionary and use that to
+ * refine the Encoding.
+ */
+int pdfi_create_Encoding(pdf_context *ctx, pdf_obj *pdf_Encoding, pdf_obj *font_Encoding, pdf_obj **Encoding)
+{
+ int code = 0, i;
+
+ code = pdfi_array_alloc(ctx, 256, (pdf_array **)Encoding);
+ if (code < 0)
+ return code;
+ pdfi_countup(*Encoding);
+
+ if (pdf_Encoding->type == PDF_NAME) {
+ code = pdfi_build_Encoding(ctx, (pdf_name *)pdf_Encoding, (pdf_array *)*Encoding);
+ if (code < 0) {
+ pdfi_countdown(*Encoding);
+ *Encoding = NULL;
+ return code;
+ }
+ } else {
+ if (pdf_Encoding->type == PDF_DICT) {
+ pdf_name *n = NULL;
+ pdf_array *a = NULL;
+ pdf_obj *o = NULL;
+ int offset = 0;
+
+ if (font_Encoding != NULL && font_Encoding->type == PDF_ARRAY) {
+ pdf_array *fenc = (pdf_array *)font_Encoding;
+ for (i = 0; i < pdfi_array_size(fenc) && code >= 0; i++) {
+ code = pdfi_array_get(ctx, fenc, (uint64_t)i, &o);
+ if (code >= 0)
+ code = pdfi_array_put(ctx, (pdf_array *)*Encoding, (uint64_t)i, o);
+ pdfi_countdown(o);
+ }
+ if (code < 0) {
+ pdfi_countdown(*Encoding);
+ *Encoding = NULL;
+ return code;
+ }
+ }
+ else {
+ code = pdfi_dict_get(ctx, (pdf_dict *)pdf_Encoding, "BaseEncoding", (pdf_obj **)&n);
+ if (code < 0) {
+ code = pdfi_name_alloc(ctx, (byte *)"StandardEncoding", 16, (pdf_obj **)&n);
+ if (code < 0) {
+ pdfi_countdown(*Encoding);
+ *Encoding = NULL;
+ return code;
+ }
+ pdfi_countup(n);
+ }
+ code = pdfi_build_Encoding(ctx, n, (pdf_array *)*Encoding);
+ if (code < 0) {
+ pdfi_countdown(*Encoding);
+ *Encoding = NULL;
+ pdfi_countdown(n);
+ return code;
+ }
+ pdfi_countdown(n);
+ }
+ code = pdfi_dict_knownget_type(ctx, (pdf_dict *)pdf_Encoding, "Differences", PDF_ARRAY, (pdf_obj **)&a);
+ if (code <= 0) {
+ if (code < 0) {
+ pdfi_countdown(*Encoding);
+ *Encoding = NULL;
+ }
+ return code;
+ }
+
+ for (i=0;i < pdfi_array_size(a);i++) {
+ code = pdfi_array_get(ctx, a, (uint64_t)i, &o);
+ if (code < 0)
+ break;
+ if (o->type == PDF_NAME) {
+ if (offset < pdfi_array_size((pdf_array *)*Encoding))
+ code = pdfi_array_put(ctx, (pdf_array *)*Encoding, (uint64_t)offset, o);
+ pdfi_countdown(o);
+ offset++;
+ if (code < 0)
+ break;
+ } else {
+ if (o->type == PDF_INT) {
+ offset = ((pdf_num *)o)->value.i;
+ pdfi_countdown(o);
+ } else {
+ code = gs_note_error(gs_error_typecheck);
+ pdfi_countdown(o);
+ break;
+ }
+ }
+ }
+ pdfi_countdown(a);
+ if (code < 0) {
+ pdfi_countdown(*Encoding);
+ *Encoding = NULL;
+ return code;
+ }
+ } else {
+ pdfi_countdown(*Encoding);
+ *Encoding = NULL;
+ return gs_note_error(gs_error_typecheck);
+ }
+ }
+ return 0;
+}
+
+gs_glyph pdfi_encode_char(gs_font * pfont, gs_char chr, gs_glyph_space_t not_used)
+{
+ int code;
+ unsigned int nindex = 0;
+ gs_glyph g = GS_NO_GLYPH;
+
+ if (pfont->FontType == ft_encrypted || pfont->FontType == ft_encrypted2
+ || pfont->FontType == ft_user_defined || pfont->FontType == ft_TrueType
+ || pfont->FontType == ft_PDF_user_defined) {
+ pdf_font *font = (pdf_font *)pfont->client_data;
+ pdf_context *ctx = (pdf_context *)font->ctx;
+
+ if (font->Encoding != NULL) { /* safety */
+ pdf_name *GlyphName = NULL;
+ code = pdfi_array_get(ctx, font->Encoding, (uint64_t)chr, (pdf_obj **)&GlyphName);
+ if (code >= 0) {
+ code = (*ctx->get_glyph_index)(pfont, (byte *)GlyphName->data, GlyphName->length, &nindex);
+ pdfi_countdown(GlyphName);
+ if (code >= 0)
+ g = (gs_glyph)nindex;
+ }
+ }
+ }
+
+ return g;
+}
+
+/* Get the unicode valude for a glyph FIXME - not written yet
+ */
+int pdfi_decode_glyph(gs_font * font, gs_glyph glyph, int ch, ushort *unicode_return, unsigned int length)
+{
+ return 0;
+}
+
+int pdfi_glyph_index(gs_font *pfont, byte *str, uint size, uint *glyph)
+{
+ int code = 0;
+ pdf_font *font = (pdf_font *)pfont->client_data;
+
+ code = pdfi_get_name_index(font->ctx, (char *)str, size, glyph);
+
+ return code;
+}
+
+int pdfi_glyph_name(gs_font * pfont, gs_glyph glyph, gs_const_string * pstr)
+{
+ int code = gs_error_invalidfont;
+
+ if (pfont->FontType == ft_encrypted || pfont->FontType == ft_encrypted2
+ || pfont->FontType == ft_user_defined || pfont->FontType == ft_TrueType
+ || pfont->FontType == ft_PDF_user_defined) {
+ pdf_font *font = (pdf_font *)pfont->client_data;
+
+ code = pdfi_name_from_index(font->ctx, glyph, (unsigned char **)&pstr->data, &pstr->size);
+ }
+
+ return code;
+}
+
+
+static int pdfi_global_glyph_code(const gs_font *pfont, gs_const_string *gstr, gs_glyph *pglyph)
+{
+ int code = 0;
+ if (pfont->FontType == ft_encrypted) {
+ code = pdfi_t1_global_glyph_code(pfont, gstr, pglyph);
+ }
+ else if (pfont->FontType == ft_encrypted2) {
+ code = pdfi_cff_global_glyph_code(pfont, gstr, pglyph);
+ }
+ else {
+ code = gs_note_error(gs_error_invalidaccess);
+ }
+ return code;
+}
+
+int pdfi_init_font_directory(pdf_context *ctx)
+{
+ ctx->font_dir = gs_font_dir_alloc2(ctx->memory, ctx->memory);
+ if (ctx->font_dir == NULL) {
+ return_error(gs_error_VMerror);
+ }
+ ctx->font_dir->global_glyph_code = pdfi_global_glyph_code;
+ return 0;
+}
+
+/* Loads a (should be!) non-embedded font by name
+ Only currently works for Type 1 fonts set.
+ */
+int pdfi_load_font_by_name_string(pdf_context *ctx, const byte *fontname, size_t length,
+ pdf_obj **ppdffont)
+{
+ pdf_obj *fname = NULL;
+ pdf_obj *fontobjtype = NULL;
+ pdf_dict *fdict = NULL;
+ int code;
+ gs_font *pgsfont = NULL;
+ const char *fs = "Font";
+
+ code = pdfi_name_alloc(ctx, (byte *)fontname, length, &fname);
+ if (code < 0)
+ return code;
+ pdfi_countup(fname);
+
+ code = pdfi_name_alloc(ctx, (byte *)fs, strlen(fs), &fontobjtype);
+ if (code < 0)
+ goto exit;
+ pdfi_countup(fontobjtype);
+
+ code = pdfi_dict_alloc(ctx, 1, &fdict);
+ if (code < 0)
+ goto exit;
+ pdfi_countup(fdict);
+
+ code = pdfi_dict_put(ctx, fdict, "BaseFont", fname);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_dict_put(ctx, fdict, "Type", fontobjtype);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_load_font(ctx, NULL, NULL, fdict, &pgsfont, false);
+ if (code < 0)
+ goto exit;
+
+ *ppdffont = (pdf_obj *)pgsfont->client_data;
+
+ exit:
+ pdfi_countdown(fontobjtype);
+ pdfi_countdown(fname);
+ pdfi_countdown(fdict);
+ return code;
+}
+
+/* Patch or create a new XUID based on the existing UID/XUID, a simple hash
+ of the input file name and the font dictionary object number.
+ This allows improved glyph cache efficiency, also ensures pdfwrite understands
+ which fonts are repetitions, and which are different.
+ Currently cannot return an error - if we can't allocate the new XUID values array,
+ we just skip it, and assume the font is compliant.
+ */
+int pdfi_font_generate_pseudo_XUID(pdf_context *ctx, pdf_dict *fontdict, gs_font_base *pfont)
+{
+ gs_const_string fn;
+ int i;
+ uint32_t hash = 0;
+ long *xvalues;
+ int xuidlen = 2;
+
+ sfilename(ctx->main_stream->s, &fn);
+ if (fn.size > 0 && fontdict->object_num != 0) {
+ for (i = 0; i < fn.size; i++) {
+ hash = ((((hash & 0xf8000000) >> 27) ^ (hash << 5)) & 0x7ffffffff) ^ fn.data[i];
+ }
+ hash = ((((hash & 0xf8000000) >> 27) ^ (hash << 5)) & 0x7ffffffff) ^ fontdict->object_num;
+ if (uid_is_XUID(&pfont->UID))
+ xuidlen += uid_XUID_size(&pfont->UID);
+ else if (uid_is_valid(&pfont->UID))
+ xuidlen++;
+
+ xvalues = (long *)gs_alloc_bytes(pfont->memory, xuidlen * sizeof(long), "pdfi_font_generate_pseudo_XUID");
+ if (xvalues == NULL) {
+ return 0;
+ }
+ xvalues[0] = 1000000; /* "Private" value */
+ xvalues[1] = hash;
+ if (uid_is_XUID(&pfont->UID)) {
+ for (i = 0; i < uid_XUID_size(&pfont->UID); i++) {
+ xvalues[i + 2] = uid_XUID_values(&pfont->UID)[i];
+ }
+ uid_free(&pfont->UID, pfont->memory, "pdfi_font_generate_pseudo_XUID");
+ }
+ else if (uid_is_valid(&pfont->UID))
+ xvalues[2] = pfont->UID.id;
+
+ uid_set_XUID(&pfont->UID, xvalues, xuidlen);
+ }
+ return 0;
+}
+
+/* Convenience function for using fonts created by
+ pdfi_load_font_by_name_string
+ */
+int pdfi_set_font_internal(pdf_context *ctx, pdf_obj *fontobj, double point_size)
+{
+ int code;
+ pdf_font *pdffont = (pdf_font *)fontobj;
+
+ if (pdffont->type != PDF_FONT || pdffont->pfont == NULL)
+ return_error(gs_error_invalidfont);
+
+ code = gs_setPDFfontsize(ctx->pgs, point_size);
+ if (code < 0)
+ return code;
+
+ return pdfi_gs_setfont(ctx, (gs_font *)pdffont->pfont);
+}
+
+/* Convenience function for setting font by name
+ * Keeps one ref to the font, which will be in the graphics state font ->client_data
+ */
+static int pdfi_font_set_internal_inner(pdf_context *ctx, const byte *fontname, size_t length,
+ double point_size)
+{
+ int code = 0;
+ pdf_obj *font = NULL;
+
+
+ code = pdfi_load_font_by_name_string(ctx, fontname, length, &font);
+ if (code < 0) goto exit;
+
+ code = pdfi_set_font_internal(ctx, font, point_size);
+
+ exit:
+ if (code < 0)
+ pdfi_countdown(font); /* Keep the ref if succeeded */
+ return code;
+}
+
+int pdfi_font_set_internal_string(pdf_context *ctx, const char *fontname, double point_size)
+{
+ return pdfi_font_set_internal_inner(ctx, (const byte *)fontname, strlen(fontname), point_size);
+}
+
+int pdfi_font_set_internal_name(pdf_context *ctx, pdf_name *fontname, double point_size)
+{
+ if (fontname->type != PDF_NAME)
+ return_error(gs_error_typecheck);
+ else
+ return pdfi_font_set_internal_inner(ctx, fontname->data, fontname->length, point_size);
+}
diff --git a/pdf/pdf_font.h b/pdf/pdf_font.h
new file mode 100644
index 00000000..381ba729
--- /dev/null
+++ b/pdf/pdf_font.h
@@ -0,0 +1,106 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Font operations for the PDF interpreter */
+
+#include "pdf_font_types.h"
+#include "pdf_stack.h"
+
+#ifndef PDF_FONT_OPERATORS
+#define PDF_FONT_OPERATORS
+
+int pdfi_d0(pdf_context *ctx);
+int pdfi_d1(pdf_context *ctx);
+int pdfi_Tf(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict);
+int pdfi_free_font(pdf_obj *font);
+
+static inline void pdfi_countup_current_font(pdf_context *ctx)
+{
+ pdf_font *font;
+
+ if (ctx->pgs->font != NULL) {
+ font = (pdf_font *)ctx->pgs->font->client_data;
+ pdfi_countup(font);
+ }
+}
+
+static inline void pdfi_countdown_current_font(pdf_context *ctx)
+{
+ pdf_font *font;
+
+ if (ctx->pgs->font != NULL) {
+ font = (pdf_font *)ctx->pgs->font->client_data;
+ pdfi_countdown(font);
+ }
+}
+
+static inline pdf_font *pdfi_get_current_pdf_font(pdf_context *ctx)
+{
+ pdf_font *font;
+
+ if (ctx->pgs->font != NULL) {
+ font = (pdf_font *)ctx->pgs->font->client_data;
+ return(font);
+ }
+ return NULL;
+}
+
+int pdfi_create_Encoding(pdf_context *ctx, pdf_obj *pdf_Encoding, pdf_obj *font_Encoding, pdf_obj **Encoding);
+gs_glyph pdfi_encode_char(gs_font * pfont, gs_char chr, gs_glyph_space_t not_used);
+int pdfi_glyph_index(gs_font *pfont, byte *str, uint size, uint *glyph);
+int pdfi_glyph_name(gs_font * pfont, gs_glyph glyph, gs_const_string * pstr);
+int pdfi_decode_glyph(gs_font * font, gs_glyph glyph, int ch, ushort *unicode_return, unsigned int length);
+
+/* This is in pdf_fapi.c, but since it is the only exported function
+ from that module (so far) it doesn't seem worth a new header
+ */
+int pdfi_fapi_passfont(pdf_font *font, int subfont, char *fapi_request,
+ char *file_name, byte * font_data, int font_data_len);
+
+int pdfi_fapi_check_cmap_for_GID(gs_font *pfont, uint c, uint *g);
+
+int pdfi_init_font_directory(pdf_context *ctx);
+
+int pdfi_load_font(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict, pdf_dict *font_dict, gs_font **ppfont, bool cidfont);
+
+int pdfi_load_dict_font(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict, pdf_dict *font_dict, double point_size);
+
+/* Loads a (should be!) non-embedded font by name
+ Only currently works for the Type 1 font set from romfs.
+ */
+int pdfi_load_font_by_name_string(pdf_context *ctx, const byte *fontname, size_t length, pdf_obj **ppdffont);
+
+/* Convenience function for using fonts created by
+ pdfi_load_font_by_name_string
+ */
+int pdfi_set_font_internal(pdf_context *ctx, pdf_obj *fontobj, double point_size);
+
+int pdfi_font_set_internal_string(pdf_context *ctx, const char *fontname, double point_size);
+int pdfi_font_set_internal_name(pdf_context *ctx, pdf_name *fontname, double point_size);
+bool pdfi_font_known_symbolic(pdf_obj *basefont);
+
+
+enum {
+ GLYPH_W0_WIDTH_INDEX = 0,
+ GLYPH_W0_HEIGHT_INDEX = 1,
+ GLYPH_W1_WIDTH_INDEX = 2,
+ GLYPH_W1_HEIGHT_INDEX = 3,
+ GLYPH_W1_V_X_INDEX = 4,
+ GLYPH_W1_V_Y_INDEX = 5
+};
+
+int pdfi_get_cidfont_glyph_metrics(gs_font *pfont, gs_glyph cid, double *widths, bool vertical);
+int pdfi_font_generate_pseudo_XUID(pdf_context *ctx, pdf_dict *fontdict, gs_font_base *pfont);
+#endif
diff --git a/pdf/pdf_font0.c b/pdf/pdf_font0.c
new file mode 100644
index 00000000..86baec8d
--- /dev/null
+++ b/pdf/pdf_font0.c
@@ -0,0 +1,586 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Include this first so that we don't get a macro redefnition of 'offsetof' */
+#include "pdf_int.h"
+
+/* code for type 0 (CID) font handling */
+#include "gxfont.h"
+#include "gxfont0.h"
+
+#include "pdf_int.h"
+#include "pdf_font.h"
+#include "pdf_font0.h"
+#include "pdf_font1C.h"
+#include "pdf_font_types.h"
+#include "pdf_stack.h"
+#include "pdf_array.h"
+#include "pdf_dict.h"
+#include "pdf_file.h"
+#include "pdf_cmap.h"
+#include "pdf_deref.h"
+
+#include "gsutil.h" /* For gs_next_ids() */
+
+extern const pdfi_cid_decoding_t *pdfi_cid_decoding_list[];
+extern const pdfi_cid_subst_nwp_table_t *pdfi_cid_substnwp_list[];
+
+static void pdfi_font0_cid_subst_tables(const char *reg, const int reglen, const char *ord,
+ const int ordlen, pdfi_cid_decoding_t **decoding, pdfi_cid_subst_nwp_table_t **substnwp)
+{
+ int i;
+ *decoding = NULL;
+ *substnwp = NULL;
+ /* This only makes sense for Adobe orderings */
+ if (reglen == 5 && !memcmp(reg, "Adobe", 5)) {
+ for (i = 0; pdfi_cid_decoding_list[i] != NULL; i++) {
+ if (strlen(pdfi_cid_decoding_list[i]->s_order) == ordlen &&
+ !memcmp(pdfi_cid_decoding_list[i]->s_order, ord, ordlen)) {
+ *decoding = (pdfi_cid_decoding_t *)pdfi_cid_decoding_list[i];
+ break;
+ }
+ }
+ /* For now, also only for Adobe orderings */
+ for (i = 0; pdfi_cid_substnwp_list[i] != NULL; i++) {
+ if (strlen(pdfi_cid_substnwp_list[i]->ordering) == ordlen &&
+ !memcmp(pdfi_cid_substnwp_list[i]->ordering, ord, ordlen)) {
+ *substnwp = (pdfi_cid_subst_nwp_table_t *)pdfi_cid_substnwp_list[i];
+ break;
+ }
+ }
+ }
+}
+
+static int
+pdfi_font0_glyph_name(gs_font *font, gs_glyph index, gs_const_string *pstr)
+{
+ return_error(gs_error_rangecheck);
+}
+
+static int
+pdfi_font0_map_glyph_to_unicode(gs_font *font, gs_glyph glyph, int ch, ushort *u, unsigned int length)
+{
+ gs_glyph cc = glyph < GS_MIN_CID_GLYPH ? glyph : glyph - GS_MIN_CID_GLYPH;
+ pdf_font_type0 *pt0font = (pdf_font_type0 *)font->client_data;
+ int code = gs_error_undefined, i;
+ uchar *unicode_return = (uchar *)u;
+ pdf_cidfont_type2 *decfont = NULL;
+ pdf_cmap *tounicode = (pdf_cmap *)pt0font->ToUnicode;
+ pdfi_cid_subst_nwp_table_t *substnwp = pt0font->substnwp;
+
+ code = pdfi_array_get(pt0font->ctx, pt0font->DescendantFonts, 0, (pdf_obj **)&decfont);
+ if (code < 0 || decfont->type != PDF_FONT) {
+ pdfi_countdown(decfont);
+ return gs_error_undefined;
+ }
+
+ code = gs_error_undefined;
+ while (1) { /* Loop to make retrying with a substitute CID easier */
+ /* Favour the ToUnicode if one exists */
+ if (tounicode) {
+ int l = 0;
+ gs_cmap_lookups_enum_t lenum;
+ gs_cmap_lookups_enum_init((const gs_cmap_t *)tounicode->gscmap, 0, &lenum);
+ while (l == 0 && (code = gs_cmap_enum_next_lookup(font->memory, &lenum)) == 0) {
+ gs_cmap_lookups_enum_t counter = lenum;
+ while (l == 0 && (code = gs_cmap_enum_next_entry(&counter) == 0)) {
+ if (counter.entry.value_type == CODE_VALUE_CID) {
+ unsigned int v = 0;
+ for (i = 0; i < counter.entry.key_size; i++) {
+ v |= (counter.entry.key[0][counter.entry.key_size - i - 1]) << (i * 8);
+ }
+ if (ch == v) {
+ if (counter.entry.value.size == 1) {
+ l = 2;
+ if (unicode_return != NULL && length >= l) {
+ unicode_return[0] = counter.entry.value.data[0];
+ unicode_return[1] = counter.entry.value.data[1];
+ }
+ }
+ else if (counter.entry.value.size == 2) {
+ l = 2;
+ if (unicode_return != NULL && length >= l) {
+ unicode_return[0] = counter.entry.value.data[0];
+ unicode_return[1] = counter.entry.value.data[1];
+ }
+ }
+ else if (counter.entry.value.size == 3) {
+ l = 4;
+ if (unicode_return != NULL && length >= l) {
+ unicode_return[0] = counter.entry.value.data[0];
+ unicode_return[1] = counter.entry.value.data[1];
+ unicode_return[2] = counter.entry.value.data[2];
+ unicode_return[3] = 0;
+ }
+ }
+ else {
+ l = 4;
+ if (unicode_return != NULL && length >= l) {
+ unicode_return[0] = counter.entry.value.data[0];
+ unicode_return[1] = counter.entry.value.data[1];
+ unicode_return[2] = counter.entry.value.data[1];
+ unicode_return[3] = counter.entry.value.data[3];
+ }
+ }
+ }
+ }
+ else {
+ l = 0;
+ }
+ }
+ }
+ if (l > 0)
+ code = l;
+ else
+ code = gs_error_undefined;
+ }
+
+ if (code == gs_error_undefined && pt0font->decoding) {
+ const int *n;
+
+ if (cc / 256 < pt0font->decoding->nranges) {
+ n = (const int *)pt0font->decoding->ranges[cc / 256][cc % 256];
+ for (i = 0; i < pt0font->decoding->val_sizes; i++) {
+ unsigned int cmapcc;
+ if (n[i] == -1)
+ break;
+ cc = n[i];
+ cmapcc = (unsigned int)cc;
+ if (decfont->pdfi_font_type == e_pdf_cidfont_type2)
+ code = pdfi_fapi_check_cmap_for_GID((gs_font *)decfont->pfont, (unsigned int)cc, &cmapcc);
+ else
+ code = 0;
+ if (code >= 0 && cmapcc != 0){
+ code = 0;
+ break;
+ }
+ }
+ /* If it's a TTF derived CIDFont, we prefer a code point supported by the cmap table
+ but if not, use the first available one
+ */
+ if (code < 0 && n[0] != -1) {
+ cc = n[0];
+ code = 0;
+ }
+ }
+ if (code >= 0) {
+ if (cc > 65535) {
+ code = 4;
+ if (unicode_return != NULL && length >= code) {
+ unicode_return[0] = (cc & 0xFF000000)>> 24;
+ unicode_return[1] = (cc & 0x00FF0000) >> 16;
+ unicode_return[2] = (cc & 0x0000FF00) >> 8;
+ unicode_return[3] = (cc & 0x000000FF);
+ }
+ }
+ else {
+ code = 2;
+ if (unicode_return != NULL && length >= code) {
+ unicode_return[0] = (cc & 0x0000FF00) >> 8;
+ unicode_return[1] = (cc & 0x000000FF);
+ }
+ }
+ }
+ }
+ /* If we get here, and still don't have a usable code point, check for a
+ pre-defined CID substitution, and if there's one, jump back to the start
+ and try again.
+ */
+ if (code == gs_error_undefined && substnwp) {
+ for (i = 0; substnwp->subst[i].s_type != 0; i++ ) {
+ if (cc >= substnwp->subst[i].s_scid && cc <= substnwp->subst[i].e_scid) {
+ cc = substnwp->subst[i].s_dcid + (cc - substnwp->subst[i].s_scid);
+ substnwp = NULL;
+ break;
+ }
+ if (cc >= substnwp->subst[i].s_dcid
+ && cc <= substnwp->subst[i].s_dcid + (substnwp->subst[i].e_scid - substnwp->subst[i].s_scid)) {
+ cc = substnwp->subst[i].s_scid + (cc - substnwp->subst[i].s_dcid);
+ substnwp = NULL;
+ break;
+ }
+ }
+ if (substnwp == NULL)
+ continue;
+ }
+ break;
+ }
+ pdfi_countdown(decfont);
+ return (code < 0 ? 0 : code);
+}
+
+int pdfi_read_type0_font(pdf_context *ctx, pdf_dict *font_dict, pdf_dict *stream_dict, pdf_dict *page_dict, pdf_font **ppdffont)
+{
+ int code, nlen;
+ pdf_obj *cmap = NULL;
+ pdf_cmap *pcmap = NULL;
+ pdf_array *arr = NULL;
+ pdf_dict *decfontdict = NULL; /* there can only be one */
+ pdf_name *n = NULL;
+ pdf_obj *basefont = NULL;
+ pdf_obj *tounicode = NULL;
+ pdf_dict *dfontdesc = NULL;
+ pdf_dict *fontdesc = NULL;
+ pdf_stream *ffile = NULL;
+ pdf_font *descpfont = NULL;
+ pdf_font_type0 *pdft0 = NULL;
+ gs_font_type0 *pfont0 = NULL;
+ pdfi_cid_decoding_t *dec = NULL;
+ pdfi_cid_subst_nwp_table_t *substnwp = NULL;
+
+ /* We're supposed to have a FontDescriptor, it can be missing, and we have to carry on */
+ (void)pdfi_dict_get(ctx, font_dict, "FontDescriptor", (pdf_obj **)&fontdesc);
+
+ code = pdfi_dict_get(ctx, font_dict, "Encoding", &cmap);
+ if (code < 0) goto error;
+
+ if (cmap->type == PDF_CMAP) {
+ pcmap = (pdf_cmap *)cmap;
+ cmap = NULL;
+ }
+ else {
+ code = pdfi_read_cmap(ctx, cmap, &pcmap);
+ pdfi_countdown(cmap);
+ cmap = NULL;
+ if (code < 0) goto error;
+ }
+
+ code = pdfi_dict_get(ctx, font_dict, "DescendantFonts", (pdf_obj **)&arr);
+ if (code < 0) goto error;
+
+ if (arr->type != PDF_ARRAY || arr->size != 1) {
+ code = gs_note_error(gs_error_invalidfont);
+ goto error;
+ }
+ code = pdfi_array_get(ctx, arr, 0, (pdf_obj **)&decfontdict);
+ pdfi_countdown(arr);
+ arr = NULL;
+ if (code < 0) goto error;
+ if (decfontdict->type == PDF_FONT) {
+ descpfont = (pdf_font *)decfontdict;
+ decfontdict = descpfont->PDF_font;
+ pdfi_countup(decfontdict);
+ }
+ else {
+ if (decfontdict->type != PDF_DICT) {
+ code = gs_note_error(gs_error_invalidfont);
+ goto error;
+ }
+ code = pdfi_dict_get(ctx, (pdf_dict *)decfontdict, "Type", (pdf_obj **)&n);
+ if (code < 0) goto error;
+ if (n->type != PDF_NAME || n->length != 4 || memcmp(n->data, "Font", 4) != 0) {
+ pdfi_countdown(n);
+ code = gs_note_error(gs_error_invalidfont);
+ goto error;
+ }
+ pdfi_countdown(n);
+ }
+#if 0
+ code = pdfi_dict_get(ctx, (pdf_dict *)decfontdict, "Subtype", (pdf_obj **)&n);
+ if (code < 0)
+ goto error;
+
+ if (n->type != PDF_NAME || n->length != 12 || memcmp(n->data, "CIDFontType", 11) != 0) {
+ pdfi_countdown(n);
+ code = gs_note_error(gs_error_invalidfont);
+ goto error;
+ }
+ /* cidftype is ignored for now, but we may need to know it when
+ subsitutions are allowed
+ */
+ cidftype = n->data[11] - 48;
+
+ pdfi_countdown(n);
+#endif
+
+ code = pdfi_dict_get(ctx, font_dict, "BaseFont", (pdf_obj **)&basefont);
+ if (code < 0) {
+ basefont = NULL;
+ }
+
+ code = pdfi_dict_get(ctx, font_dict, "ToUnicode", (pdf_obj **)&tounicode);
+ if (code >= 0 && tounicode->type == PDF_STREAM) {
+ pdf_cmap *tu = NULL;
+ code = pdfi_read_cmap(ctx, tounicode, &tu);
+ pdfi_countdown(tounicode);
+ tounicode = (pdf_obj *)tu;
+ }
+ if (code < 0 || (tounicode != NULL && tounicode->type != PDF_CMAP)) {
+ pdfi_countdown(tounicode);
+ tounicode = NULL;
+ code = 0;
+ }
+
+ if (descpfont == NULL) {
+ gs_font *pf;
+
+ code = pdfi_load_font(ctx, stream_dict, page_dict, decfontdict, &pf, true);
+ if (code < 0)
+ goto error;
+ descpfont = (pdf_font *)pf->client_data;
+ }
+
+ if (descpfont != NULL && ((pdf_cidfont_t *)descpfont)->substitute) {
+ pdf_obj *csi = NULL;
+ pdf_string *reg = NULL, *ord = NULL;
+ char *r = NULL, *o = NULL;
+ int rlen = 0, olen = 0;
+
+ code = pdfi_dict_get(ctx, decfontdict, "CIDSystemInfo", (pdf_obj **)&csi);
+ if (code >= 0) {
+ (void)pdfi_dict_get(ctx, (pdf_dict *)csi, "Registry", (pdf_obj **)&reg);
+ (void)pdfi_dict_get(ctx, (pdf_dict *)csi, "Ordering", (pdf_obj **)&ord);
+ if (reg != NULL && ord != NULL) {
+ r = (char *)reg->data;
+ rlen = reg->length;
+ o = (char *)ord->data;
+ olen = ord->length;
+ }
+ pdfi_countdown(csi);
+ pdfi_countdown(reg);
+ pdfi_countdown(ord);
+ }
+ if (r == NULL || o == NULL) {
+ r = (char *)pcmap->csi_reg.data;
+ rlen = pcmap->csi_reg.size;
+ o = (char *)pcmap->csi_ord.data;
+ olen = pcmap->csi_ord.size;
+ }
+ if (rlen > 0 && olen > 0)
+ pdfi_font0_cid_subst_tables(r, rlen, o, olen, &dec, &substnwp);
+ else {
+ dec = NULL;
+ substnwp = NULL;
+ }
+ }
+ /* reference is now owned by the descendent font created above */
+ pdfi_countdown(decfontdict);
+ decfontdict = NULL;
+ if (code < 0) {
+ code = gs_note_error(gs_error_invalidfont);
+ goto error;
+ }
+ /* If we're got this far, we have a CMap and a descendant font, let's make the Type 0 */
+ pdft0 = (pdf_font_type0 *)gs_alloc_bytes(ctx->memory, sizeof(pdf_font_type0), "pdfi (type0 pdf_font)");
+ if (pdft0 == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+ code = pdfi_array_alloc(ctx, 1, &arr);
+ if (code < 0) {
+ gs_free_object(ctx->memory, pdft0, "pdfi_read_type0_font(pdft0)");
+ goto error;
+ }
+ arr->refcnt = 1;
+ code = pdfi_array_put(ctx, arr, 0, (pdf_obj *)descpfont);
+ if (code < 0) {
+ gs_free_object(ctx->memory, pdft0, "pdfi_read_type0_font(pdft0)");
+ goto error;
+ }
+
+ pdft0->type = PDF_FONT;
+ pdft0->pdfi_font_type = e_pdf_font_type0;
+ pdft0->ctx = ctx;
+#if REFCNT_DEBUG
+ pdft0->UID = ctx->UID++;
+ dmprintf2(ctx->memory, "Allocated object of type %c with UID %"PRIi64"\n", pdft0->type, pdft0->UID);
+#endif
+ pdft0->refcnt = 1;
+ pdft0->object_num = font_dict->object_num;
+ pdft0->generation_num = font_dict->generation_num;
+ pdft0->indirect_num = font_dict->indirect_num;
+ pdft0->indirect_gen = font_dict->indirect_gen;
+ pdft0->Encoding = (pdf_obj *)pcmap;
+ pdft0->ToUnicode = tounicode;
+ pdft0->DescendantFonts = arr;
+ pdft0->PDF_font = font_dict;
+ pdfi_countup(font_dict);
+ pdft0->FontDescriptor = fontdesc;
+ fontdesc = NULL;
+ pdft0->BaseFont = basefont;
+ pdft0->decoding = dec;
+ pdft0->substnwp = substnwp;
+
+ /* Ownership transferred to pdft0, if we jump to error
+ * these will now be freed by counting down pdft0.
+ */
+ tounicode = NULL;
+ arr = NULL;
+ basefont = NULL;
+
+ pdft0->pfont = NULL; /* In case we error out */
+
+ pfont0 = (gs_font_type0 *)gs_alloc_struct(ctx->memory, gs_font, &st_gs_font_type0, "pdfi gs type 0 font");
+ if (pfont0 == NULL) {
+ gs_free_object(ctx->memory, pdft0, "pdfi_read_type0_font(pdft0)");
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+ gs_make_identity(&pfont0->orig_FontMatrix);
+ gs_make_identity(&pfont0->FontMatrix);
+ pfont0->next = pfont0->prev = 0;
+ pfont0->memory = ctx->memory;
+ pfont0->dir = ctx->font_dir;
+ pfont0->is_resource = false;
+ gs_notify_init(&pfont0->notify_list, ctx->memory);
+ pfont0->id = gs_next_ids(ctx->memory, 1);
+ pfont0->base = (gs_font *) pfont0;
+ pfont0->client_data = pdft0;
+ pfont0->WMode = pcmap->wmode;
+ pfont0->FontType = ft_composite;
+ pfont0->PaintType = 0;
+ pfont0->StrokeWidth = 0;
+ pfont0->is_cached = 0;
+ if (pdft0->BaseFont != NULL) {
+ pdf_name *nobj = (pdf_name *)pdft0->BaseFont;
+ nlen = nobj->length > gs_font_name_max ? gs_font_name_max : nobj->length;
+
+ memcpy(pfont0->key_name.chars, nobj->data, nlen);
+ pfont0->key_name.size = nlen;
+ memcpy(pfont0->font_name.chars, nobj->data, nlen);
+ pfont0->font_name.size = nlen;
+ }
+ else {
+ nlen = descpfont->pfont->key_name.size > gs_font_name_max ? gs_font_name_max : descpfont->pfont->key_name.size;
+
+ memcpy(pfont0->key_name.chars, descpfont->pfont->key_name.chars, nlen);
+ pfont0->key_name.size = nlen;
+ memcpy(pfont0->font_name.chars, descpfont->pfont->font_name.chars, nlen);
+ pfont0->font_name.size = nlen;
+ }
+
+ if (pcmap->name.size > 0) {
+ if (pfont0->key_name.size + pcmap->name.size + 1 < gs_font_name_max) {
+ memcpy(pfont0->key_name.chars + pfont0->key_name.size, "-", 1);
+ memcpy(pfont0->key_name.chars + pfont0->key_name.size + 1, pcmap->name.data, pcmap->name.size);
+ pfont0->key_name.size += pcmap->name.size + 1;
+ }
+ if (pfont0->font_name.size + pcmap->name.size + 1 < gs_font_name_max) {
+ memcpy(pfont0->font_name.chars + pfont0->font_name.size, "-", 1);
+ memcpy(pfont0->font_name.chars + pfont0->font_name.size + 1, pcmap->name.data, pcmap->name.size);
+ pfont0->font_name.size += pcmap->name.size + 1;
+ }
+ }
+ pfont0->procs.define_font = gs_no_define_font;
+ pfont0->procs.make_font = gs_no_make_font;
+ pfont0->procs.font_info = gs_default_font_info;
+ pfont0->procs.same_font = gs_default_same_font;
+ pfont0->procs.encode_char = pdfi_encode_char;
+ pfont0->procs.decode_glyph = pdfi_font0_map_glyph_to_unicode;
+ pfont0->procs.enumerate_glyph = gs_no_enumerate_glyph;
+ pfont0->procs.glyph_info = gs_default_glyph_info;
+ pfont0->procs.glyph_outline = gs_no_glyph_outline;
+ pfont0->procs.glyph_name = pdfi_font0_glyph_name;
+ pfont0->procs.init_fstack = gs_type0_init_fstack;
+ pfont0->procs.next_char_glyph = gs_type0_next_char_glyph;
+ pfont0->procs.build_char = gs_no_build_char;
+
+ pfont0->data.FMapType = fmap_CMap;
+ pfont0->data.EscChar = 0xff;
+ pfont0->data.ShiftIn = 0x0f;
+ pfont0->data.SubsVector.data = NULL;
+ pfont0->data.SubsVector.size = 0;
+ pfont0->data.subs_size = pfont0->data.subs_width = 0;
+
+ pfont0->data.Encoding = (uint *)gs_alloc_bytes(ctx->memory, sizeof(uint), "pdfi_read_type0_font Encoding");
+ if (pfont0->data.Encoding == NULL) {
+ gs_free_object(ctx->memory, pfont0, "pdfi_read_type0_font(pfont0)");
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+ *pfont0->data.Encoding = 0;
+
+ pfont0->data.encoding_size = 1;
+ pfont0->data.FDepVector = (gs_font **)gs_alloc_bytes(ctx->memory, sizeof(gs_font *), "pdfi_read_type0_font FDepVector");
+ if (pfont0->data.FDepVector == NULL) {
+ /* We transferred ownership of pcmap to pfont0 above, but we didn't null the pointer
+ * so we could keep using it. We must NULL it out before returning an error to prevent
+ * reference counting problems.
+ */
+ pcmap = NULL;
+ gs_free_object(ctx->memory, pfont0, "pdfi_read_type0_font(pfont0)");
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+ *pfont0->data.FDepVector = (gs_font *)descpfont->pfont;
+ pdfi_countdown(descpfont);
+ descpfont = NULL;
+ pfont0->data.fdep_size = 1;
+ pfont0->data.CMap = (gs_cmap_t *)pcmap->gscmap;
+
+ /* NULL he pointer to prevent any reference counting problems, ownership was
+ * transferred to pfont0, but we maintained the pointer for easy access until this
+ * point.
+ */
+ pcmap = NULL;
+
+ pdft0->pfont = (gs_font_base *)pfont0;
+
+ code = gs_definefont(ctx->font_dir, (gs_font *)pdft0->pfont);
+ if (code < 0) {
+ gs_free_object(ctx->memory, pfont0, "pdfi_read_type0_font(pfont0)");
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+
+ /* object_num can be zero if the dictionary was defined inline */
+ if (pdft0->object_num != 0) {
+ code = replace_cache_entry(ctx, (pdf_obj *)pdft0);
+ if (code < 0) {
+ gs_free_object(ctx->memory, pfont0, "pdfi_read_type0_font(pfont0)");
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+ }
+
+ *ppdffont = (pdf_font *)pdft0;
+ return 0;
+
+error:
+ pdfi_countdown(arr);
+ pdfi_countdown(pcmap);
+ pdfi_countdown(tounicode);
+ pdfi_countdown(basefont);
+ pdfi_countdown(decfontdict);
+ pdfi_countdown(dfontdesc);
+ pdfi_countdown(fontdesc);
+ pdfi_countdown(ffile);
+ pdfi_countdown(descpfont);
+ pdfi_countdown(pdft0);
+
+ return code;
+}
+
+int
+pdfi_free_font_type0(pdf_obj *font)
+{
+ pdf_font_type0 *pdft0 = (pdf_font_type0 *)font;
+ gs_font_type0 *pfont0 = (gs_font_type0 *)pdft0->pfont;
+ pdfi_countdown(pdft0->PDF_font);
+ pdfi_countdown(pdft0->BaseFont);
+ pdfi_countdown(pdft0->FontDescriptor);
+ pdfi_countdown(pdft0->Encoding);
+ pdfi_countdown(pdft0->DescendantFonts);
+ pdfi_countdown(pdft0->ToUnicode);
+ gs_free_object(OBJ_MEMORY(pdft0), pfont0->data.Encoding, "pdfi_free_font_type0(data.Encoding)");
+ /* We shouldn't need to free the fonts in the FDepVector, that should happen
+ with DescendantFonts above.
+ */
+ gs_free_object(OBJ_MEMORY(pdft0), pfont0->data.FDepVector, "pdfi_free_font_type0(data.FDepVector)");
+ gs_free_object(OBJ_MEMORY(pdft0), pfont0, "pdfi_free_font_type0(pfont0)");
+ gs_free_object(OBJ_MEMORY(pdft0), pdft0, "pdfi_free_font_type0(pdft0)");
+
+ return 0;
+}
diff --git a/pdf/pdf_font0.h b/pdf/pdf_font0.h
new file mode 100644
index 00000000..a8a76c60
--- /dev/null
+++ b/pdf/pdf_font0.h
@@ -0,0 +1,35 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Type 0 (CID) font handling routines */
+/* Also CIDFontType0 and CIDFontType0 handling */
+
+#ifndef PDF_TYPE0_FONT
+#define PDF_TYPE0_FONT
+
+#include "ghostpdf.h"
+#include "pdf_types.h"
+#include "pdf_font_types.h"
+
+int pdfi_read_type0_font(pdf_context *ctx, pdf_dict *font_dict, pdf_dict *stream_dict, pdf_dict *page_dict, pdf_font **ppdffont);
+int pdfi_free_font_type0(pdf_obj *font);
+
+int pdfi_read_cidtype2_font(pdf_context *ctx, pdf_dict *font_dict, pdf_dict *stream_dict, pdf_dict *page_dict, byte *buf, int64_t buflen, pdf_font **ppfont);
+
+int pdfi_free_font_cidtype2(pdf_obj *font);
+
+int pdfi_read_cidtype0_font(pdf_context *ctx, pdf_dict *font_dict, byte *fbuf, int fbuflen, pdf_font **ppfont);
+
+#endif
diff --git a/pdf/pdf_font1.c b/pdf/pdf_font1.c
new file mode 100644
index 00000000..6586d891
--- /dev/null
+++ b/pdf/pdf_font1.c
@@ -0,0 +1,797 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* code for type 1 font handling */
+#include "pdf_int.h"
+
+#include "gsgdata.h"
+#include "gstype1.h"
+#include "gscencs.h"
+
+#include "strmio.h"
+#include "strimpl.h"
+#include "stream.h"
+#include "sfilter.h"
+
+#include "pdf_deref.h"
+#include "pdf_types.h"
+#include "pdf_array.h"
+#include "pdf_dict.h"
+#include "pdf_file.h"
+#include "pdf_font_types.h"
+#include "pdf_font.h"
+#include "pdf_fmap.h"
+#include "pdf_font1.h"
+#include "pdf_font1C.h"
+#include "pdf_fontps.h"
+#include "pdf_fontTT.h"
+
+#include "gxtype1.h" /* for gs_type1_state_s */
+#include "gsutil.h" /* For gs_next_ids() */
+
+/* These are fonts for which we have to ignore "named" encodings */
+typedef struct pdfi_t1_glyph_name_equivalents_s
+{
+ const char *name;
+ const char *altname;
+} pdfi_t1_glyph_name_equivalents_t;
+
+static const pdfi_t1_glyph_name_equivalents_t pdfi_t1_glyph_name_equivalents[] =
+{
+ {"Ohungarumlaut", "Odblacute"},
+ {"Uhungarumlaut", "Udblacute"},
+ {"ohungarumlaut", "odblacute"},
+ {"uhungarumlaut", "udblacute"},
+ {NULL , NULL}
+};
+
+/* The Postscript code trawls the AGL to find all the equivalents.
+ let's hope we can avoid that...
+ Since none of the following show be required for a remotely valid
+ Type 1, we just ignore errors (at least for now).
+ */
+static void pdfi_patch_charstrings_dict(pdf_dict *cstrings)
+{
+ int code = 0;
+ pdf_obj *o;
+ const pdfi_t1_glyph_name_equivalents_t *gne = pdfi_t1_glyph_name_equivalents;
+ while(gne->name != NULL && code >= 0) {
+ code = pdfi_dict_get(cstrings->ctx, cstrings, gne->name, &o);
+ if (code >= 0) {
+ code = pdfi_dict_put(cstrings->ctx, cstrings, gne->altname, o);
+ pdfi_countdown(o);
+ }
+ if (code == gs_error_undefined)
+ code = 0;
+ gne++;
+ }
+
+ if (code >= 0) {
+ bool key_known;
+ pdf_string *pstr;
+ byte notdefstr[] = { 0x9E, 0x35, 0xCE, 0xD7, 0xFF, 0xD3, 0x62, 0x2F, 0x09 };
+
+ code = pdfi_dict_known(cstrings->ctx, cstrings, ".notdef", &key_known);
+ if (code >=0 && key_known != true) {
+ /* Seems there are plently of invalid Type 1 fonts without a .notdef,
+ so make a fake one - a valid font will end up replacing this.
+ */
+ code = pdfi_object_alloc(cstrings->ctx, PDF_STRING, sizeof(notdefstr), (pdf_obj **) &pstr);
+ if (code >= 0) {
+ memcpy(pstr->data, notdefstr, sizeof(notdefstr));
+ (void)pdfi_dict_put(cstrings->ctx, cstrings, ".notdef", (pdf_obj *) pstr);
+ }
+ }
+ }
+}
+
+/* CALLBACKS */
+static int
+pdfi_t1_glyph_data(gs_font_type1 *pfont, gs_glyph glyph, gs_glyph_data_t *pgd)
+{
+ int code = 0;
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *) pfont->client_data;
+ pdf_context *ctx = (pdf_context *) pdffont1->ctx;
+ pdf_name *glyphname = NULL;
+ pdf_string *charstring = NULL;
+ gs_const_string gname;
+
+ code = (*ctx->get_glyph_name)((gs_font *)pfont, glyph, &gname);
+ if (code >= 0) {
+ code = pdfi_name_alloc(ctx, (byte *) gname.data, gname.size, (pdf_obj **)&glyphname);
+ if (code >= 0)
+ pdfi_countup(glyphname);
+ }
+
+ if (code >= 0) {
+ code = pdfi_dict_get_by_key(ctx, pdffont1->CharStrings, glyphname, (pdf_obj **)&charstring);
+ if (code >= 0)
+ gs_glyph_data_from_bytes(pgd, charstring->data, 0, charstring->length, NULL);
+ }
+ pdfi_countdown(charstring);
+ pdfi_countdown(glyphname);
+
+ return code;
+}
+
+static int
+pdfi_t1_subr_data(gs_font_type1 *pfont, int index, bool global, gs_glyph_data_t *pgd)
+{
+ int code = 0;
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *) pfont->client_data;
+
+ if (global == true || index < 0 || index >= pdffont1->NumSubrs) {
+ code = gs_note_error(gs_error_rangecheck);
+ }
+ else {
+ gs_glyph_data_from_bytes(pgd, pdffont1->Subrs[index].data, 0, pdffont1->Subrs[index].size, NULL);
+ }
+ return code;
+}
+
+static int
+pdfi_t1_seac_data(gs_font_type1 *pfont, int ccode, gs_glyph *pglyph, gs_const_string *gstr, gs_glyph_data_t *pgd)
+{
+ int code = 0;
+ pdf_font_type1 *pdffont1 = (pdf_font_type1 *) pfont->client_data;
+ pdf_context *ctx = (pdf_context *) pdffont1->ctx;
+ gs_glyph glyph = gs_c_known_encode((gs_char)ccode, ENCODING_INDEX_STANDARD);
+
+ if (glyph == GS_NO_GLYPH)
+ return_error(gs_error_rangecheck);
+
+ code = gs_c_glyph_name(glyph, gstr);
+ if (code >= 0) {
+ unsigned int nindex;
+ code = (*ctx->get_glyph_index)((gs_font *)pfont, (byte *)gstr->data, gstr->size, &nindex);
+ if (pglyph != NULL)
+ *pglyph = (gs_glyph)nindex;
+ }
+
+ if (code >= 0) {
+ pdf_name *glyphname = NULL;
+ pdf_string *charstring = NULL;
+ code = pdfi_name_alloc(ctx, (byte *) gstr->data, gstr->size, (pdf_obj **) &glyphname);
+ if (code >= 0) {
+ pdfi_countup(glyphname);
+ code = pdfi_dict_get_by_key(ctx, pdffont1->CharStrings, glyphname, (pdf_obj **)&charstring);
+ pdfi_countdown(glyphname);
+ if (code >= 0)
+ if (pgd != NULL)
+ gs_glyph_data_from_bytes(pgd, charstring->data, 0, charstring->length, NULL);
+ pdfi_countdown(charstring);
+ }
+ }
+
+ return code;
+}
+
+/* push/pop are null ops here */
+static int
+pdfi_t1_push(void *callback_data, const fixed *pf, int count)
+{
+ (void)callback_data;
+ (void)pf;
+ (void)count;
+ return 0;
+}
+static int
+pdfi_t1_pop(void *callback_data, fixed *pf)
+{
+ (void)callback_data;
+ (void)pf;
+ return 0;
+}
+
+static int
+pdfi_t1_enumerate_glyph(gs_font *pfont, int *pindex,
+ gs_glyph_space_t glyph_space, gs_glyph *pglyph)
+{
+ int code;
+ pdf_font_type1 *t1font = (pdf_font_type1 *) pfont->client_data;
+ pdf_context *ctx = (pdf_context *) t1font->ctx;
+ pdf_name *key;
+ uint64_t i = (uint64_t) *pindex;
+
+ (void)glyph_space;
+
+ if (*pindex <= 0)
+ code = pdfi_dict_key_first(ctx, t1font->CharStrings, (pdf_obj **) & key, &i);
+ else
+ code = pdfi_dict_key_next(ctx, t1font->CharStrings, (pdf_obj **) & key, &i);
+ if (code < 0) {
+ *pindex = 0;
+ code = 0;
+ }
+ else {
+ uint dummy = GS_NO_GLYPH;
+
+ code = (*ctx->get_glyph_index)(pfont, key->data, key->length, &dummy);
+ if (code < 0) {
+ *pglyph = (gs_glyph) *pindex;
+ goto exit;
+ }
+ *pglyph = dummy;
+ if (*pglyph == GS_NO_GLYPH)
+ *pglyph = (gs_glyph) *pindex;
+ *pindex = (int)i;
+ }
+ exit:
+ pdfi_countdown(key);
+ return code;
+}
+
+/* This *should* only get called for SEAC lookups, which have to come from StandardEncoding
+ so just try to lookup the string in the standard encodings
+ */
+int
+pdfi_t1_global_glyph_code(const gs_font *pfont, gs_const_string *gstr, gs_glyph *pglyph)
+{
+ *pglyph = gs_c_name_glyph(gstr->data, gstr->size);
+ return 0;
+}
+
+static int
+pdfi_t1_glyph_outline(gs_font *pfont, int WMode, gs_glyph glyph,
+ const gs_matrix *pmat, gx_path *ppath, double sbw[4])
+{
+ gs_glyph_data_t gd;
+ gs_glyph_data_t *pgd = &gd;
+ gs_font_type1 *pfont1 = (gs_font_type1 *) pfont;
+ int code = pdfi_t1_glyph_data(pfont1, glyph, pgd);
+
+ if (code >= 0) {
+ gs_type1_state cis = { 0 };
+ gs_type1_state *pcis = &cis;
+ gs_gstate gs;
+ int value;
+
+ if (pmat)
+ gs_matrix_fixed_from_matrix(&gs.ctm, pmat);
+ else {
+ gs_matrix imat;
+
+ gs_make_identity(&imat);
+ gs_matrix_fixed_from_matrix(&gs.ctm, &imat);
+ }
+ gs.flatness = 0;
+ code = gs_type1_interp_init(pcis, &gs, ppath, NULL, NULL, true, 0, pfont1);
+ if (code < 0)
+ return code;
+
+ pcis->no_grid_fitting = true;
+ gs_type1_set_callback_data(pcis, NULL);
+ /* Continue interpreting. */
+ icont:
+ code = pfont1->data.interpret(pcis, pgd, &value);
+ switch (code) {
+ case 0: /* all done */
+ /* falls through */
+ default: /* code < 0, error */
+ return code;
+ case type1_result_callothersubr: /* unknown OtherSubr */
+ return_error(gs_error_rangecheck); /* can't handle it */
+ case type1_result_sbw: /* [h]sbw, just continue */
+ type1_cis_get_metrics(pcis, sbw);
+ pgd = 0;
+ goto icont;
+ }
+ }
+ return code;
+}
+
+static int
+pdfi_t1_glyph_info(gs_font *font, gs_glyph glyph, const gs_matrix *pmat, int members, gs_glyph_info_t *info)
+{
+ if ((members & GLYPH_INFO_OUTLINE_WIDTHS) == 0)
+ return gs_type1_glyph_info(font, glyph, pmat, members, info);
+
+ return gs_default_glyph_info(font, glyph, pmat, members, info);
+}
+
+/* END CALLBACKS */
+
+static stream *
+push_pfb_filter(gs_memory_t *mem, byte *buf, byte *bufend)
+{
+ stream *fs, *ffs = NULL;
+ stream *sstrm;
+ stream_PFBD_state *st;
+ byte *strbuf;
+
+ sstrm = file_alloc_stream(mem, "push_pfb_filter(buf stream)");
+ if (sstrm == NULL)
+ return NULL;
+
+ sread_string(sstrm, buf, bufend - buf);
+ sstrm->close_at_eod = false;
+
+ fs = s_alloc(mem, "push_pfb_filter(fs)");
+ strbuf = gs_alloc_bytes(mem, 4096, "push_pfb_filter(buf)");
+ st = gs_alloc_struct(mem, stream_PFBD_state, s_PFBD_template.stype, "push_pfb_filter(st)");
+ if (fs == NULL || st == NULL || strbuf == NULL) {
+ sclose(sstrm);
+ gs_free_object(mem, sstrm, "push_pfb_filter(buf stream)");
+ gs_free_object(mem, fs, "push_pfb_filter(fs)");
+ gs_free_object(mem, st, "push_pfb_filter(st)");
+ goto done;
+ }
+ memset(st, 0x00, sizeof(stream_PFBD_state));
+ (*s_PFBD_template.init)((stream_state *)st);
+ st->binary_to_hex = true;
+ s_std_init(fs, strbuf, 4096, &s_filter_read_procs, s_mode_read);
+ st->memory = mem;
+ st->templat = &s_PFBD_template;
+ fs->state = (stream_state *) st;
+ fs->procs.process = s_PFBD_template.process;
+ fs->strm = sstrm;
+ fs->close_at_eod = false;
+ ffs = fs;
+ done:
+ return ffs;
+}
+
+static void
+pop_pfb_filter(gs_memory_t *mem, stream *s)
+{
+ stream *src = s->strm;
+ byte *b = s->cbuf;
+
+ sclose(s);
+ gs_free_object(mem, s, "push_pfb_filter(s)");
+ gs_free_object(mem, b, "push_pfb_filter(b)");
+ if (src)
+ sclose(src);
+ gs_free_object(mem, src, "push_pfb_filter(strm)");
+}
+
+static int
+pdfi_t1_decode_pfb(pdf_context *ctx, byte *inbuf, int inlen, byte **outbuf, int *outlen)
+{
+ stream *strm;
+ int c, code = 0;
+ int decodelen = 0;
+ byte *d, *decodebuf = NULL;
+
+ *outbuf = NULL;
+ *outlen = 0;
+
+ strm = push_pfb_filter(ctx->memory, inbuf, inbuf + inlen + 1);
+ if (strm == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ }
+ else {
+ while (1) {
+ c = sgetc(strm);
+ if (c < 0)
+ break;
+ decodelen++;
+ }
+ pop_pfb_filter(ctx->memory, strm);
+ decodebuf = gs_alloc_bytes(ctx->memory, decodelen, "pdfi_t1_decode_pfb(decodebuf)");
+ if (decodebuf == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ }
+ else {
+ d = decodebuf;
+ strm = push_pfb_filter(ctx->memory, inbuf, inbuf + inlen + 1);
+ while (1) {
+ c = sgetc(strm);
+ if (c < 0)
+ break;
+ *d = c;
+ d++;
+ }
+ pop_pfb_filter(ctx->memory, strm);
+ *outbuf = decodebuf;
+ *outlen = decodelen;
+ }
+ }
+ return code;
+}
+
+static int
+pdfi_alloc_t1_font(pdf_context *ctx, pdf_font_type1 **font, uint32_t obj_num)
+{
+ pdf_font_type1 *t1font = NULL;
+ gs_font_type1 *pfont = NULL;
+
+ t1font = (pdf_font_type1 *) gs_alloc_bytes(ctx->memory, sizeof(pdf_font_type1), "pdfi (type 1 pdf_font)");
+ if (t1font == NULL)
+ return_error(gs_error_VMerror);
+
+ memset(t1font, 0x00, sizeof(pdf_font_type1));
+ t1font->ctx = ctx;
+ t1font->type = PDF_FONT;
+ t1font->ctx = ctx;
+ t1font->pdfi_font_type = e_pdf_font_type1;
+
+#if REFCNT_DEBUG
+ t1font->UID = ctx->UID++;
+ dmprintf2(ctx->memory,
+ "Allocated object of type %c with UID %" PRIi64 "\n", t1font->type, t1font->UID);
+#endif
+
+ pdfi_countup(t1font);
+
+ pfont = (gs_font_type1 *) gs_alloc_struct(ctx->memory, gs_font_type1, &st_gs_font_type1, "pdfi (Type 1 pfont)");
+ if (pfont == NULL) {
+ pdfi_countdown(t1font);
+ return_error(gs_error_VMerror);
+ }
+ memset(pfont, 0x00, sizeof(gs_font_type1));
+
+ t1font->pfont = (gs_font_base *) pfont;
+
+ gs_make_identity(&pfont->orig_FontMatrix);
+ gs_make_identity(&pfont->FontMatrix);
+ pfont->next = pfont->prev = 0;
+ pfont->memory = ctx->memory;
+ pfont->dir = ctx->font_dir;
+ pfont->is_resource = false;
+ gs_notify_init(&pfont->notify_list, ctx->memory);
+ pfont->base = (gs_font *) t1font->pfont;
+ pfont->client_data = t1font;
+ pfont->WMode = 0;
+ pfont->PaintType = 0;
+ pfont->StrokeWidth = 0;
+ pfont->is_cached = 0;
+ pfont->FAPI = NULL;
+ pfont->FAPI_font_data = NULL;
+ pfont->procs.init_fstack = gs_default_init_fstack;
+ pfont->procs.next_char_glyph = gs_default_next_char_glyph;
+ pfont->FontType = ft_encrypted;
+ pfont->ExactSize = fbit_use_outlines;
+ pfont->InBetweenSize = fbit_use_outlines;
+ pfont->TransformedChar = fbit_use_outlines;
+ /* We may want to do something clever with an XUID here */
+ pfont->id = gs_next_ids(ctx->memory, 1);
+ uid_set_UniqueID(&pfont->UID, pfont->id);
+
+ pfont->encoding_index = 1; /****** WRONG ******/
+ pfont->nearest_encoding_index = 1; /****** WRONG ******/
+
+ pfont->client_data = (void *)t1font;
+
+ *font = t1font;
+ return 0;
+}
+
+static void
+pdfi_t1_font_set_procs(pdf_context *ctx, pdf_font_type1 *font)
+{
+ gs_font_type1 *pfont = (gs_font_type1 *) font->pfont;
+
+ /* The build_char proc will be filled in by FAPI -
+ we won't worry about working without FAPI */
+ pfont->procs.build_char = NULL;
+
+ pfont->procs.encode_char = pdfi_encode_char;
+ pfont->procs.glyph_name = ctx->get_glyph_name;
+ pfont->procs.decode_glyph = pdfi_decode_glyph;
+ pfont->procs.define_font = gs_no_define_font;
+ pfont->procs.make_font = gs_no_make_font;
+ pfont->procs.font_info = gs_default_font_info;
+ pfont->procs.glyph_info = pdfi_t1_glyph_info;
+ pfont->procs.glyph_outline = pdfi_t1_glyph_outline;
+ pfont->procs.same_font = gs_default_same_font;
+ pfont->procs.enumerate_glyph = pdfi_t1_enumerate_glyph;
+
+ pfont->data.procs.glyph_data = pdfi_t1_glyph_data;
+ pfont->data.procs.subr_data = pdfi_t1_subr_data;
+ pfont->data.procs.seac_data = pdfi_t1_seac_data;
+ pfont->data.procs.push_values = pdfi_t1_push;
+ pfont->data.procs.pop_value = pdfi_t1_pop;
+ pfont->data.interpret = gs_type1_interpret;
+}
+
+int
+pdfi_read_type1_font(pdf_context *ctx, pdf_dict *font_dict, pdf_dict *stream_dict, pdf_dict *page_dict, byte *fbuf, int64_t fbuflen, pdf_font **ppdffont)
+{
+ int code = 0;
+ pdf_obj *fontdesc = NULL;
+ pdf_obj *basefont = NULL;
+ pdf_obj *mapname = NULL;
+ pdf_obj *tmp = NULL;
+ pdf_font_type1 *t1f = NULL;
+ ps_font_interp_private fpriv = { 0 };
+
+ (void)pdfi_dict_knownget_type(ctx, font_dict, "FontDescriptor", PDF_DICT, &fontdesc);
+
+ if (fbuf[0] == 128 && fbuf[1] == 1) {
+ byte *decodebuf = NULL;
+ int decodelen;
+
+ code = pdfi_t1_decode_pfb(ctx, fbuf, fbuflen, &decodebuf, &decodelen);
+ gs_free_object(ctx->memory, fbuf, "pdfi_read_type1_font");
+ if (code < 0) {
+ gs_free_object(ctx->memory, decodebuf, "pdfi_read_type1_font");
+ }
+ fbuf = decodebuf;
+ fbuflen = decodelen;
+ }
+
+ if (code >= 0) {
+ fpriv.gsu.gst1.data.lenIV = 4;
+ code = pdfi_read_ps_font(ctx, font_dict, fbuf, fbuflen, &fpriv);
+ gs_free_object(ctx->memory, fbuf, "pdfi_read_type1_font");
+
+ /* If we have a full CharStrings dictionary, we probably have enough to make a font */
+ if (code < 0 || (fpriv.u.t1.CharStrings == NULL || fpriv.u.t1.CharStrings->type != PDF_DICT
+ || fpriv.u.t1.CharStrings->entries == 0)) {
+ code = gs_note_error(gs_error_invalidfont);
+ goto error;
+ }
+ code = pdfi_alloc_t1_font(ctx, &t1f, font_dict->object_num);
+ if (code >= 0) {
+ gs_font_type1 *pfont1 = (gs_font_type1 *) t1f->pfont;
+
+ memcpy(&pfont1->data, &fpriv.gsu.gst1.data, sizeof(pfont1->data));
+
+ pdfi_t1_font_set_procs(ctx, t1f);
+
+ memcpy(&pfont1->FontMatrix, &fpriv.gsu.gst1.FontMatrix, sizeof(pfont1->FontMatrix));
+ memcpy(&pfont1->orig_FontMatrix, &fpriv.gsu.gst1.orig_FontMatrix, sizeof(pfont1->orig_FontMatrix));
+ memcpy(&pfont1->FontBBox, &fpriv.gsu.gst1.FontBBox, sizeof(pfont1->FontBBox));
+ memcpy(&pfont1->key_name, &fpriv.gsu.gst1.key_name, sizeof(pfont1->key_name));
+ memcpy(&pfont1->font_name, &fpriv.gsu.gst1.font_name, sizeof(pfont1->font_name));
+ if (fpriv.gsu.gst1.UID.id != 0)
+ memcpy(&pfont1->UID, &fpriv.gsu.gst1.UID, sizeof(pfont1->UID));
+ fpriv.gsu.gst1.UID.xvalues = NULL; /* In case of error */
+ pfont1->WMode = fpriv.gsu.gst1.WMode;
+ pfont1->PaintType = fpriv.gsu.gst1.PaintType;
+ pfont1->StrokeWidth = fpriv.gsu.gst1.StrokeWidth;
+
+ t1f->object_num = font_dict->object_num;
+ t1f->generation_num = font_dict->generation_num;
+ t1f->PDF_font = font_dict;
+ pdfi_countup(font_dict);
+ t1f->BaseFont = basefont;
+ pdfi_countup(basefont);
+ t1f->FontDescriptor = (pdf_dict *) fontdesc;
+ pdfi_countup(fontdesc);
+ t1f->Name = mapname;
+ pdfi_countup(mapname);
+
+ /* We want basefont, but we can live without it */
+ (void)pdfi_dict_knownget_type(ctx, font_dict, "BaseFont", PDF_NAME, &basefont);
+
+ t1f->descflags = 0;
+ if (t1f->FontDescriptor != NULL) {
+ code = pdfi_dict_get_int(ctx, t1f->FontDescriptor, "Flags", &t1f->descflags);
+ if (code >= 0) {
+ /* If both the symbolic and non-symbolic flag are set,
+ believe that latter.
+ */
+ if ((t1f->descflags & 32) != 0)
+ t1f->descflags = (t1f->descflags & ~4);
+ }
+ }
+
+ if (pdfi_font_known_symbolic(basefont)) {
+ t1f->descflags |= 4;
+ }
+
+ code = pdfi_dict_knownget_type(ctx, font_dict, "FirstChar", PDF_INT, &tmp);
+ if (code == 1) {
+ t1f->FirstChar = ((pdf_num *) tmp)->value.i;
+ pdfi_countdown(tmp);
+ tmp = NULL;
+ }
+ else {
+ t1f->FirstChar = 0;
+ }
+ code = pdfi_dict_knownget_type(ctx, font_dict, "LastChar", PDF_INT, &tmp);
+ if (code == 1) {
+ t1f->LastChar = ((pdf_num *) tmp)->value.i;
+ pdfi_countdown(tmp);
+ tmp = NULL;
+ }
+ else {
+ t1f->LastChar = 255;
+ }
+
+ t1f->fake_glyph_names = (gs_string *) gs_alloc_bytes(ctx->memory, t1f->LastChar * sizeof(gs_string), "pdfi_read_type1_font: fake_glyph_names");
+ if (!t1f->fake_glyph_names) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+ memset(t1f->fake_glyph_names, 0x00, t1f->LastChar * sizeof(gs_string));
+
+ code = pdfi_dict_knownget_type(ctx, font_dict, "Widths", PDF_ARRAY, &tmp);
+ if (code > 0) {
+ int i;
+ double x_scale;
+ int num_chars = t1f->LastChar - t1f->FirstChar + 1;
+
+ if (num_chars == pdfi_array_size((pdf_array *) tmp)) {
+ t1f->Widths = (double *)gs_alloc_bytes(ctx->memory, sizeof(double) * num_chars, "Type 1 font Widths array");
+ if (t1f->Widths == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+
+ /* Widths are defined assuming a 1000x1000 design grid, but we apply
+ * them in font space - so undo the 1000x1000 scaling, and apply
+ * the inverse of the font's x scaling
+ */
+ x_scale = 0.001 / hypot(pfont1->FontMatrix.xx, pfont1->FontMatrix.xy);
+
+ memset(t1f->Widths, 0x00, sizeof(double) * num_chars);
+ for (i = 0; i < num_chars; i++) {
+ code = pdfi_array_get_number(ctx, (pdf_array *) tmp, (uint64_t) i, &t1f->Widths[i]);
+ if (code < 0)
+ goto error;
+ t1f->Widths[i] *= x_scale;
+ }
+ }
+ else {
+ t1f->Widths = NULL;
+ }
+ }
+ pdfi_countdown(tmp);
+ tmp = NULL;
+
+ code = pdfi_dict_knownget(ctx, font_dict, "Encoding", &tmp);
+ if (code == 1) {
+ if ((tmp->type == PDF_NAME || tmp->type == PDF_DICT) && (t1f->descflags & 4) == 0) {
+ code = pdfi_create_Encoding(ctx, tmp, NULL, (pdf_obj **) & t1f->Encoding);
+ if (code >= 0)
+ code = 1;
+ }
+ else if (tmp->type == PDF_DICT && (t1f->descflags & 4) != 0) {
+ code = pdfi_create_Encoding(ctx, tmp, (pdf_obj *)fpriv.u.t1.Encoding, (pdf_obj **) & t1f->Encoding);
+ if (code >= 0)
+ code = 1;
+ }
+ else
+ code = gs_error_undefined;
+ pdfi_countdown(tmp);
+ tmp = NULL;
+ if (code == 1) {
+ /* Since the underlying font stream can be shared between font descriptors,
+ and the font descriptors can be shared between font objects, if we change
+ the encoding, we can't share cached glyphs with other instances of this
+ underlying font, so invalidate the UniqueID/XUID so the glyph cache won't
+ try.
+ */
+ if (uid_is_XUID(&t1f->pfont->UID))
+ uid_free(&t1f->pfont->UID, t1f->pfont->memory, "pdfi_read_type1_font");
+ uid_set_invalid(&t1f->pfont->UID);
+ }
+ }
+ else {
+ pdfi_countdown(tmp);
+ tmp = NULL;
+ code = 0;
+ }
+
+ if (code <= 0) {
+ t1f->Encoding = fpriv.u.t1.Encoding;
+ pdfi_countup(t1f->Encoding);
+ }
+
+ code = pdfi_dict_knownget(ctx, font_dict, "ToUnicode", &tmp);
+ if (code == 1) {
+ t1f->ToUnicode = tmp;
+ tmp = NULL;
+ }
+ else {
+ t1f->ToUnicode = NULL;
+ }
+ t1f->CharStrings = fpriv.u.t1.CharStrings;
+ pdfi_countup(t1f->CharStrings);
+ pdfi_patch_charstrings_dict(t1f->CharStrings);
+
+ t1f->Subrs = fpriv.u.t1.Subrs;
+ fpriv.u.t1.Subrs = NULL;
+ t1f->NumSubrs = fpriv.u.t1.NumSubrs;
+
+ t1f->blenddesignpositions = fpriv.u.t1.blenddesignpositions;
+ pdfi_countup(t1f->blenddesignpositions);
+ t1f->blenddesignmap = fpriv.u.t1.blenddesignmap;
+ pdfi_countup(t1f->blenddesignmap);
+ t1f->blendfontbbox = fpriv.u.t1.blendfontbbox;
+ pdfi_countup(t1f->blendfontbbox);
+ t1f->blendaxistypes = fpriv.u.t1.blendaxistypes;
+ pdfi_countup(t1f->blendaxistypes);
+
+ code = gs_definefont(ctx->font_dir, (gs_font *) t1f->pfont);
+ if (code < 0) {
+ goto error;
+ }
+
+ code = pdfi_fapi_passfont((pdf_font *) t1f, 0, NULL, NULL, NULL, 0);
+ if (code < 0) {
+ goto error;
+ }
+ /* object_num can be zero if the dictionary was defined inline */
+ if (t1f->object_num != 0) {
+ code = replace_cache_entry(ctx, (pdf_obj *) t1f);
+ if (code < 0)
+ goto error;
+ }
+ *ppdffont = (pdf_font *) t1f;
+ }
+ }
+
+ error:
+ pdfi_countdown(fontdesc);
+ pdfi_countdown(basefont);
+ pdfi_countdown(mapname);
+ pdfi_countdown(tmp);
+ pdfi_countdown(fpriv.u.t1.Encoding);
+ pdfi_countdown(fpriv.u.t1.CharStrings);
+ pdfi_countdown(fpriv.u.t1.blenddesignpositions);
+ pdfi_countdown(fpriv.u.t1.blenddesignmap);
+ pdfi_countdown(fpriv.u.t1.blendfontbbox);
+ pdfi_countdown(fpriv.u.t1.blendaxistypes);
+ if (fpriv.gsu.gst1.UID.xvalues != NULL) {
+ gs_free_object(ctx->memory, fpriv.gsu.gst1.UID.xvalues, "pdfi_read_type1_font(xuid)");
+ }
+ if (fpriv.u.t1.Subrs) {
+ int i;
+
+ for (i = 0; i < fpriv.u.t1.NumSubrs; i++) {
+ gs_free_object(ctx->memory, fpriv.u.t1.Subrs[i].data, "Subrs[i]");
+ }
+ gs_free_object(ctx->memory, fpriv.u.t1.Subrs, "Subrs");
+ }
+ if (code < 0) {
+ pdfi_countdown(t1f);
+ }
+ return code;
+}
+
+int
+pdfi_free_font_type1(pdf_obj *font)
+{
+ pdf_font_type1 *t1f = (pdf_font_type1 *) font;
+ int i;
+
+ if (t1f->pfont->UID.xvalues != NULL) {
+ gs_free_object(OBJ_MEMORY(font), t1f->pfont->UID.xvalues, "pdfi_free_font_type1(xuid)");
+ }
+ gs_free_object(OBJ_MEMORY(font), t1f->pfont, "Free Type 1 gs_font");
+
+ pdfi_countdown(t1f->PDF_font);
+ pdfi_countdown(t1f->BaseFont);
+ pdfi_countdown(t1f->FontDescriptor);
+ pdfi_countdown(t1f->Name);
+ pdfi_countdown(t1f->Encoding);
+ pdfi_countdown(t1f->ToUnicode);
+ pdfi_countdown(t1f->CharStrings);
+ pdfi_countdown(t1f->blenddesignpositions);
+ pdfi_countdown(t1f->blenddesignmap);
+ pdfi_countdown(t1f->blendfontbbox);
+ pdfi_countdown(t1f->blendaxistypes);
+
+ if (t1f->fake_glyph_names != NULL) {
+ for (i = 0; i < t1f->LastChar; i++) {
+ if (t1f->fake_glyph_names[i].data != NULL)
+ gs_free_object(OBJ_MEMORY(font), t1f->fake_glyph_names[i].data, "Type 1 fake_glyph_name");
+ }
+ gs_free_object(OBJ_MEMORY(font), t1f->fake_glyph_names, "Type 1 fake_glyph_names");
+ }
+ if (t1f->NumSubrs > 0 && t1f->Subrs != NULL) {
+ for (i = 0; i < t1f->NumSubrs; i++) {
+ gs_free_object(OBJ_MEMORY(font), t1f->Subrs[i].data, "Type 1 Subr");
+ }
+ gs_free_object(OBJ_MEMORY(font), t1f->Subrs, "Type 1 Subrs");
+ }
+ gs_free_object(OBJ_MEMORY(font), t1f->Widths, "Free Type 1 fontWidths");
+ gs_free_object(OBJ_MEMORY(font), t1f, "Free Type 1 font");
+ return 0;
+}
diff --git a/pdf/pdf_font1.h b/pdf/pdf_font1.h
new file mode 100644
index 00000000..0385aafd
--- /dev/null
+++ b/pdf/pdf_font1.h
@@ -0,0 +1,26 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Type 1 font handling routines */
+
+#ifndef PDF_TYPE1_FONT
+#define PDF_TYPE1_FONT
+
+int pdfi_read_type1_font(pdf_context *ctx, pdf_dict *font_dict, pdf_dict *stream_dict, pdf_dict *page_dict, byte *fbuf, int64_t fbuflen, pdf_font **ppdffont);
+
+int pdfi_free_font_type1(pdf_obj *font);
+int pdfi_t1_global_glyph_code(const gs_font *pfont, gs_const_string *gstr, gs_glyph *pglyph);
+
+#endif
diff --git a/pdf/pdf_font11.c b/pdf/pdf_font11.c
new file mode 100644
index 00000000..ebe0cd21
--- /dev/null
+++ b/pdf/pdf_font11.c
@@ -0,0 +1,462 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* code for CIDFontType2/Type 9 font handling */
+/* CIDFonts with Truetype outlines */
+
+#include "pdf_int.h"
+#include "pdf_font.h"
+#include "pdf_font0.h"
+#include "pdf_fontTT.h"
+#include "pdf_font_types.h"
+#include "pdf_stack.h"
+#include "pdf_file.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_deref.h"
+#include "gxfont42.h"
+#include "gxfcid.h"
+#include "gsutil.h" /* For gs_next_ids() */
+
+static int pdfi_cidtype2_string_proc(gs_font_type42 * pfont, ulong offset, uint length,
+ const byte ** pdata)
+{
+ pdf_cidfont_type2 *ttfont = (pdf_cidfont_type2 *)pfont->client_data;
+ int code = 0;
+
+ if (offset + length > ttfont->sfnt.size) {
+ *pdata = NULL;
+ code = gs_note_error(gs_error_invalidfont);
+ }
+ else {
+ *pdata = ttfont->sfnt.data + offset;
+ }
+ return code;
+}
+
+static int pdfi_cidtype2_CIDMap_proc(gs_font_cid2 *pfont, gs_glyph glyph)
+{
+ pdf_cidfont_type2 *pdffont11 = (pdf_cidfont_type2 *)pfont->client_data;
+ uint gid = glyph - GS_MIN_CID_GLYPH;
+
+ if (pdffont11->cidtogidmap.size > (gid << 1) + 1) {
+ gid = pdffont11->cidtogidmap.data[gid << 1] << 8 | pdffont11->cidtogidmap.data[(gid << 1) + 1];
+ }
+
+ return (int)gid;
+}
+
+static uint pdfi_cidtype2_get_glyph_index(gs_font_type42 *pfont, gs_glyph glyph)
+{
+ pdf_cidfont_type2 *pdffont11 = (pdf_cidfont_type2 *)pfont->client_data;
+ uint gid;
+
+ if (glyph < GS_MIN_CID_GLYPH) {
+ gid = 0;
+ }
+ else {
+ if (glyph < GS_MIN_GLYPH_INDEX) {
+ gid = glyph - GS_MIN_CID_GLYPH;
+ if (pdffont11->cidtogidmap.size > 0) {
+ gid = pdffont11->cidtogidmap.data[gid << 1] << 8 | pdffont11->cidtogidmap.data[(gid << 1) + 1];
+ }
+ }
+ else {
+ gid = (uint)(glyph - GS_MIN_GLYPH_INDEX);
+ }
+ }
+
+ return gid;
+}
+
+static int
+pdfi_cidtype2_glyph_info(gs_font *font, gs_glyph glyph, const gs_matrix *pmat,
+ int members, gs_glyph_info_t *info)
+{
+ int code;
+ pdf_cidfont_type2 *pdffont11 = (pdf_cidfont_type2 *)font->client_data;
+ code = (*pdffont11->orig_glyph_info)(font, glyph, pmat, members, info);
+ if (code < 0)
+ return code;
+
+ if ((members & GLYPH_INFO_WIDTHS) != 0
+ && glyph > GS_MIN_CID_GLYPH
+ && glyph < GS_MIN_GLYPH_INDEX) {
+ double widths[6] = {0};
+ code = pdfi_get_cidfont_glyph_metrics(font, (glyph - GS_MIN_CID_GLYPH), widths, true);
+ if (code >= 0) {
+ if (pmat == NULL) {
+ info->width[0].x = widths[GLYPH_W0_WIDTH_INDEX] / 1000.0;
+ info->width[0].y = widths[GLYPH_W0_HEIGHT_INDEX] / 1000.0;
+ }
+ else {
+ code = gs_point_transform(widths[GLYPH_W0_WIDTH_INDEX] / 1000.0, widths[GLYPH_W0_HEIGHT_INDEX] / 1000.0, pmat, &info->width[0]);
+ if (code < 0)
+ return code;
+ }
+ info->members |= GLYPH_INFO_WIDTH0;
+
+ if ((members & GLYPH_INFO_WIDTH1) != 0
+ && (widths[GLYPH_W1_WIDTH_INDEX] != 0
+ || widths[GLYPH_W1_HEIGHT_INDEX] != 0)) {
+ if (pmat == NULL) {
+ info->width[1].x = widths[GLYPH_W1_WIDTH_INDEX] / 1000.0;
+ info->width[1].y = widths[GLYPH_W1_HEIGHT_INDEX] / 1000.0;
+ }
+ else {
+ code = gs_point_transform(widths[GLYPH_W1_WIDTH_INDEX] / 1000.0, widths[GLYPH_W1_HEIGHT_INDEX] / 1000.0, pmat, &info->width[1]);
+ if (code < 0)
+ return code;
+ }
+ info->members |= GLYPH_INFO_WIDTH1;
+ }
+ if ((members & GLYPH_INFO_VVECTOR1) != 0) {
+ if (pmat == NULL) {
+ info->v.x = widths[GLYPH_W1_V_X_INDEX] / 1000.0;
+ info->v.y = widths[GLYPH_W1_V_Y_INDEX] / 1000.0;
+ }
+ else {
+ code = gs_point_transform(widths[GLYPH_W1_V_X_INDEX] / 1000.0, widths[GLYPH_W1_V_Y_INDEX] / 1000.0, pmat, &info->v);
+ if (code < 0)
+ return code;
+ }
+ info->members |= GLYPH_INFO_VVECTOR1;
+ }
+ }
+ }
+ return code;
+}
+
+static int
+pdfi_cidtype2_enumerate_glyph(gs_font *font, int *pindex,
+ gs_glyph_space_t glyph_space, gs_glyph *pglyph)
+{
+ int code = 0;
+ gs_font_cid2 *cid2 = (gs_font_cid2 *)font;
+ pdf_cidfont_type2 *pdffont11 = (pdf_cidfont_type2 *)font->client_data;
+ *pglyph = 0;
+
+ if (*pindex <= 0)
+ *pindex = 0;
+
+ if (pdffont11->cidtogidmap.size > 0) {
+ do {
+ *pglyph = pdffont11->cidtogidmap.data[(*pindex) << 1] << 8 | pdffont11->cidtogidmap.data[((*pindex) << 1) + 1];
+ (*pindex)++;
+ if (*pglyph == 0 && *pindex == 1) /* notdef - special case */
+ break;
+ } while (*pglyph == 0 && ((*pindex) << 1) < pdffont11->cidtogidmap.size);
+
+ if (((*pindex) << 1) >= pdffont11->cidtogidmap.size) {
+ *pindex = 0;
+ }
+ else {
+ if (*pglyph != 0 || (*pglyph == 0 && *pindex == 1)) {
+ if (glyph_space == GLYPH_SPACE_INDEX) {
+ *pglyph += GS_MIN_GLYPH_INDEX;
+ }
+ else {
+ *pglyph = (*pindex) + GS_MIN_CID_GLYPH;
+ }
+ }
+ }
+ }
+ else {
+ if (*pindex < cid2->cidata.common.CIDCount) {
+ if (glyph_space == GLYPH_SPACE_INDEX) {
+ *pglyph = *pindex + GS_MIN_GLYPH_INDEX;
+ }
+ else {
+ *pglyph = (*pindex) + GS_MIN_CID_GLYPH;
+ }
+ }
+ else {
+ *pindex = 0;
+ }
+ }
+
+ return code;
+}
+
+static int
+pdfi_alloc_cidtype2_font(pdf_context *ctx, pdf_cidfont_type2 **font, bool is_cid)
+{
+ pdf_cidfont_type2 *ttfont = NULL;
+ gs_font_cid2 *pfont = NULL;
+
+ ttfont = (pdf_cidfont_type2 *)gs_alloc_bytes(ctx->memory, sizeof(pdf_cidfont_type2), "pdfi (cidtype2 pdf_font)");
+ if (ttfont == NULL)
+ return_error(gs_error_VMerror);
+
+ memset(ttfont, 0x00, sizeof(pdf_cidfont_type2));
+ ttfont->type = PDF_FONT;
+ ttfont->ctx = ctx;
+ ttfont->pdfi_font_type = e_pdf_cidfont_type2;
+
+#if REFCNT_DEBUG
+ ttfont->UID = ctx->UID++;
+ dmprintf2(ctx->memory, "Allocated object of type %c with UID %"PRIi64"\n", ttfont->type, ttfont->UID);
+#endif
+
+ pdfi_countup(ttfont);
+
+ pfont = (gs_font_cid2 *)gs_alloc_struct(ctx->memory, gs_font_cid2, &st_gs_font_cid2,
+ "pdfi (cidtype2 pfont)");
+ if (pfont == NULL) {
+ pdfi_countdown(ttfont);
+ return_error(gs_error_VMerror);
+ }
+ memset(pfont, 0x00, sizeof(gs_font_cid2));
+
+ ttfont->pfont = (gs_font_base *)pfont;
+
+ gs_make_identity(&pfont->orig_FontMatrix);
+ gs_make_identity(&pfont->FontMatrix);
+ pfont->next = pfont->prev = 0;
+ pfont->memory = ctx->memory;
+ pfont->dir = ctx->font_dir;
+ pfont->is_resource = false;
+ gs_notify_init(&pfont->notify_list, ctx->memory);
+ pfont->base = (gs_font *) ttfont->pfont;
+ pfont->client_data = ttfont;
+ pfont->WMode = 0;
+ pfont->PaintType = 0;
+ pfont->StrokeWidth = 0;
+ pfont->is_cached = 0;
+ pfont->FAPI = NULL;
+ pfont->FAPI_font_data = NULL;
+ pfont->procs.init_fstack = gs_default_init_fstack;
+ pfont->procs.next_char_glyph = gs_default_next_char_glyph;
+ pfont->FontType = ft_CID_TrueType;
+ pfont->ExactSize = fbit_use_outlines;
+ pfont->InBetweenSize = fbit_use_outlines;
+ pfont->TransformedChar = fbit_use_outlines;
+ /* We may want to do something clever with an XUID here */
+ pfont->id = gs_next_ids(ctx->memory, 1);
+ uid_set_UniqueID(&pfont->UID, pfont->id);
+ /* The buildchar proc will be filled in by FAPI -
+ we won't worry about working without FAPI */
+ pfont->procs.encode_char = pdfi_encode_char;
+ pfont->data.string_proc = pdfi_cidtype2_string_proc;
+ pfont->procs.glyph_name = ctx->get_glyph_name;
+ pfont->procs.decode_glyph = pdfi_decode_glyph;
+ pfont->procs.define_font = gs_no_define_font;
+ pfont->procs.make_font = gs_no_make_font;
+ pfont->procs.font_info = gs_default_font_info;
+ pfont->procs.glyph_info = gs_default_glyph_info;
+ pfont->procs.glyph_outline = gs_no_glyph_outline;
+ pfont->procs.build_char = NULL;
+ pfont->procs.same_font = gs_default_same_font;
+ pfont->procs.enumerate_glyph = gs_no_enumerate_glyph;
+
+ pfont->encoding_index = 1; /****** WRONG ******/
+ pfont->nearest_encoding_index = 1; /****** WRONG ******/
+
+ cid_system_info_set_null(&pfont->cidata.common.CIDSystemInfo);
+ pfont->cidata.common.CIDCount = 0; /* set later */
+ pfont->cidata.common.GDBytes = 2; /* not used */
+ pfont->cidata.MetricsCount = 0;
+ pfont->cidata.CIDMap_proc = pdfi_cidtype2_CIDMap_proc;
+
+ pfont->client_data = (void *)ttfont;
+
+ *font = ttfont;
+ return 0;
+}
+
+int pdfi_read_cidtype2_font(pdf_context *ctx, pdf_dict *font_dict, pdf_dict *stream_dict, pdf_dict *page_dict, byte *buf, int64_t buflen, pdf_font **ppfont)
+{
+ pdf_cidfont_type2 *font;
+ int code = 0;
+ pdf_obj *fontdesc = NULL;
+ pdf_obj *obj = NULL;
+ gs_font_cid2 *cid2;
+
+ if (ppfont == NULL)
+ return_error(gs_error_invalidaccess);
+
+ *ppfont = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, font_dict, "FontDescriptor", PDF_DICT, &fontdesc);
+ if (code <= 0) {
+ /* We own the buffer now, so we must free it on error */
+ gs_free_object(ctx->memory, buf, "pdfi_read_cidtype2_font");
+ return_error(gs_error_invalidfont);
+ }
+
+ if ((code = pdfi_alloc_cidtype2_font(ctx, &font, false)) < 0) {
+ /* We own the buffer now, so we must free it on error */
+ gs_free_object(ctx->memory, buf, "pdfi_read_cidtype2_font");
+ pdfi_countdown(fontdesc);
+ return code;
+ }
+ font->PDF_font = font_dict;
+ pdfi_countup(font_dict);
+ font->object_num = font_dict->object_num;
+ font->generation_num = font_dict->generation_num;
+ font->FontDescriptor = (pdf_dict *)fontdesc;
+ fontdesc = NULL;
+
+ /* Ownership of buf is now part of the font and managed via its lifetime */
+ font->sfnt.data = buf;
+ font->sfnt.size = buflen;
+
+ /* Strictly speaking BaseFont is required, but we can continue without one */
+ code = pdfi_dict_knownget_type(ctx, font_dict, "BaseFont", PDF_NAME, (pdf_obj **)&obj);
+ if (code > 0) {
+ pdf_name *nobj = (pdf_name *)obj;
+ int nlen = nobj->length > gs_font_name_max ? gs_font_name_max : nobj->length;
+
+ memcpy(font->pfont->key_name.chars, nobj->data, nlen);
+ font->pfont->key_name.chars[nlen] = 0;
+ font->pfont->key_name.size = nlen;
+ memcpy(font->pfont->font_name.chars, nobj->data, nlen);
+ font->pfont->font_name.chars[nlen] = 0;
+ font->pfont->font_name.size = nlen;
+ pdfi_countdown(obj);
+ obj = NULL;
+ }
+
+ code = pdfi_dict_knownget_type(ctx, font_dict, "DW", PDF_INT, (pdf_obj **)&obj);
+ if (code > 0) {
+ font->DW = ((pdf_num *)obj)->value.i;
+ pdfi_countdown(obj);
+ obj = NULL;
+ }
+ else {
+ font->DW = 1000;
+ }
+ code = pdfi_dict_knownget_type(ctx, font_dict, "DW2", PDF_ARRAY, (pdf_obj **)&obj);
+ if (code > 0) {
+ font->DW2 = (pdf_array *)obj;
+ obj = NULL;
+ }
+ else {
+ font->DW2 = NULL;
+ }
+ code = pdfi_dict_knownget_type(ctx, font_dict, "W", PDF_ARRAY, (pdf_obj **)&obj);
+ if (code > 0) {
+ font->W = (pdf_array *)obj;
+ obj = NULL;
+ }
+ else {
+ font->W = NULL;
+ }
+ code = pdfi_dict_knownget_type(ctx, font_dict, "W2", PDF_ARRAY, (pdf_obj **)&obj);
+ if (code > 0) {
+ font->W2 = (pdf_array *)obj;
+ obj = NULL;
+ }
+ else {
+ font->W2 = NULL;
+ }
+
+ code = pdfi_dict_knownget(ctx, font_dict, "CIDToGIDMap", (pdf_obj **)&obj);
+ if (code > 0) {
+ font->cidtogidmap.data = NULL;
+ font->cidtogidmap.size = 0;
+ /* CIDToGIDMap can only be a stream or a name, and if it's a name
+ it's only permitted to be "/Identity", so ignore it
+ */
+ if (obj->type == PDF_STREAM) {
+ int64_t sz;
+ code = pdfi_stream_to_buffer(ctx, (pdf_stream *)obj, &(font->cidtogidmap.data), &sz);
+ if (code < 0) {
+ goto error;
+ }
+ font->cidtogidmap.size = (uint)sz;
+ }
+ pdfi_countdown(obj);
+ obj = NULL;
+ }
+
+ code = gs_type42_font_init((gs_font_type42 *)font->pfont, 0);
+ if (code < 0) {
+ goto error;
+ }
+ font->orig_glyph_info = font->pfont->procs.glyph_info;
+ font->pfont->procs.glyph_info = pdfi_cidtype2_glyph_info;
+ font->pfont->procs.enumerate_glyph = pdfi_cidtype2_enumerate_glyph;
+
+ cid2 = (gs_font_cid2 *)font->pfont;
+ if (font->cidtogidmap.size > 0) {
+ gs_font_cid2 *cid2 = (gs_font_cid2 *)font->pfont;
+ if (cid2->data.numGlyphs > font->cidtogidmap.size >> 1)
+ cid2->cidata.common.CIDCount = cid2->data.numGlyphs;
+ else {
+ cid2->cidata.common.CIDCount = font->cidtogidmap.size >> 1;
+ }
+ cid2->cidata.common.MaxCID = cid2->cidata.common.CIDCount;
+ }
+ else {
+ gs_font_cid2 *cid2 = (gs_font_cid2 *)font->pfont;
+ cid2->cidata.common.CIDCount = cid2->data.numGlyphs;
+ cid2->cidata.common.MaxCID = cid2->cidata.common.CIDCount;
+ }
+ cid2->data.substitute_glyph_index_vertical = gs_type42_substitute_glyph_index_vertical;
+ cid2->cidata.orig_procs.get_outline = cid2->data.get_outline;
+ cid2->data.get_glyph_index = pdfi_cidtype2_get_glyph_index;
+
+ code = pdfi_font_generate_pseudo_XUID(ctx, font->PDF_font, font->pfont);
+ if (code < 0)
+ goto error;
+
+ code = gs_definefont(ctx->font_dir, (gs_font *)font->pfont);
+ if (code < 0) {
+ goto error;
+ }
+
+ code = pdfi_fapi_passfont((pdf_font *)font, 0, NULL, NULL, font->sfnt.data, font->sfnt.size);
+ if (code < 0) {
+ goto error;
+ }
+
+ /* object_num can be zero if the dictionary was defined inline */
+ if (font->object_num != 0) {
+ code = replace_cache_entry(ctx, (pdf_obj *)font);
+ if (code < 0)
+ goto error;
+ }
+
+ *ppfont = (pdf_font *)font;
+ return code;
+error:
+
+ pdfi_countdown(obj);
+ pdfi_countdown(font);
+ return code;
+}
+
+int pdfi_free_font_cidtype2(pdf_obj *font)
+{
+ pdf_cidfont_type2 *pdfcidf = (pdf_cidfont_type2 *)font;
+ gs_font_cid2 *pfont = (gs_font_cid2 *)pdfcidf->pfont;
+ gs_free_object(OBJ_MEMORY(pdfcidf), pfont, "pdfi_free_font_cidtype2(pfont)");
+
+ gs_free_object(OBJ_MEMORY(pdfcidf), pdfcidf->cidtogidmap.data, "pdfi_free_font_cidtype2(cidtogidmap.data)");
+ gs_free_object(OBJ_MEMORY(pdfcidf), pdfcidf->sfnt.data, "pdfi_free_font_cidtype2(sfnt.data)");
+
+ pdfi_countdown(pdfcidf->PDF_font);
+ pdfi_countdown(pdfcidf->BaseFont);
+ pdfi_countdown(pdfcidf->FontDescriptor);
+ pdfi_countdown(pdfcidf->W);
+ pdfi_countdown(pdfcidf->DW2);
+ pdfi_countdown(pdfcidf->W2);
+
+ gs_free_object(OBJ_MEMORY(pdfcidf), pdfcidf, "pdfi_free_font_cidtype2(pdfcidf)");
+return 0;
+
+ return 0;
+}
diff --git a/pdf/pdf_font1C.c b/pdf/pdf_font1C.c
new file mode 100644
index 00000000..10570912
--- /dev/null
+++ b/pdf/pdf_font1C.c
@@ -0,0 +1,2762 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* code for CFF (type 1C) font handling */
+
+#include "pdf_int.h"
+
+#include "gscedata.h"
+#include "gscencs.h"
+#include "gxfont0.h"
+#include "gxfcid.h"
+
+#include "pdf_types.h"
+#include "pdf_font_types.h"
+#include "pdf_font.h"
+#include "pdf_font1C.h"
+#include "pdf_fontps.h"
+#include "pdf_dict.h"
+#include "pdf_deref.h"
+#include "pdf_file.h"
+#include "pdf_array.h"
+
+#include "gxtype1.h" /* for gs_type1_state_s */
+#include "gsutil.h" /* For gs_next_ids() */
+
+static byte *
+pdfi_find_cff_index(byte *p, byte *e, int idx, byte **pp, byte **ep);
+
+/* This is a super set of the contents of a pdfi Type 1C font/CIDFont.
+ Meaning we can store everying as we interpret, and not worry
+ about the actual font type until the end
+ */
+typedef struct pdfi_cff_font_priv_s {
+ pdf_font_common;
+ pdf_array *Subrs;
+ int NumSubrs;
+ pdf_array *GlobalSubrs;
+ int NumGlobalSubrs;
+ pdf_dict *CharStrings;
+ byte *cffdata;
+ byte *cffend;
+ byte *gsubrs;
+ byte *subrs;
+ byte *charstrings;
+ int ncharstrings;
+ pdf_dict *CIDSystemInfo;
+ int64_t DW;
+ pdf_array *W;
+ pdf_array *DW2;
+ pdf_array *W2;
+ gs_string cidtogidmap;
+ pdf_array *FDArray;
+ /* The registry and ordering strings in gs_font_cid0_data are just references to
+ strings assumed to be managed be managed by the interpreter - so we have to stash
+ them in the pdfi font, too.
+ */
+ pdf_string *registry;
+ pdf_string *ordering;
+ int supplement;
+ int cidcount;
+ int uidbase;
+ font_proc_glyph_info((*orig_glyph_info));
+} pdfi_cff_font_priv;
+
+/* Same thing for the Ghostscript font
+ */
+typedef struct pdfi_gs_cff_font_priv_s {
+ gs_font_base_common;
+ gs_type1_data type1data;
+ gs_font_cid0_data cidata;
+ bool forcecid;
+ pdfi_cff_font_priv pdfcffpriv;
+} pdfi_gs_cff_font_priv;
+
+typedef struct pdfi_gs_cff_font_common_priv_s {
+ gs_font_base_common;
+} pdfi_gs_cff_font_common_priv;
+
+typedef struct cff_font_offsets_s
+{
+ unsigned int fdarray_off;
+ unsigned int fdselect_off;
+ unsigned int charset_off;
+ unsigned int encoding_off;
+ unsigned int strings_off;
+ unsigned int strings_size;
+ unsigned int private_off;
+ unsigned int private_size;
+ bool have_ros;
+ bool have_matrix;
+} cff_font_offsets;
+
+static int
+pdfi_make_string_from_sid(pdf_context *ctx, pdf_obj **str,
+ pdfi_cff_font_priv *font, cff_font_offsets *offsets, unsigned int sid);
+
+static void
+pdfi_init_cff_font_priv(pdf_context *ctx, pdfi_gs_cff_font_priv *cffpriv,
+ byte *buf, int buflen, bool for_fdarray);
+
+static int
+pdfi_alloc_cff_font(pdf_context *ctx, pdf_font_cff ** font, uint32_t obj_num, bool for_fdarray);
+
+/* CALLBACKS */
+static int
+pdfi_cff_glyph_data(gs_font_type1 *pfont, gs_glyph glyph, gs_glyph_data_t *pgd)
+{
+ int code = 0;
+ pdf_font_cff *cfffont = (pdf_font_cff *) pfont->client_data;
+ pdf_context *ctx = (pdf_context *) cfffont->ctx;
+ pdf_name *glyphname = NULL;
+ pdf_string *charstring = NULL;
+
+ /* Getting here with Encoding == NULL means it's a subfont from an FDArray
+ so we index directly by gid
+ */
+ if (cfffont->Encoding == NULL) {
+ char indstring[33];
+ int l = gs_snprintf(indstring, 32, "%u", (unsigned int)glyph);
+
+ code = pdfi_name_alloc(ctx, (byte *) indstring, l, (pdf_obj **) &glyphname);
+ if (code >= 0)
+ pdfi_countup(glyphname);
+ }
+ else {
+ gs_const_string gname;
+ code = (*ctx->get_glyph_name)((gs_font *)pfont, glyph, &gname);
+ if (code >= 0) {
+ code = pdfi_name_alloc(ctx, (byte *) gname.data, gname.size, (pdf_obj **) &glyphname);
+ if (code >= 0)
+ pdfi_countup(glyphname);
+ }
+ }
+ if (code >= 0) {
+ code = pdfi_dict_get_by_key(ctx, cfffont->CharStrings, glyphname, (pdf_obj **) &charstring);
+ if (code >= 0)
+ gs_glyph_data_from_bytes(pgd, charstring->data, 0, charstring->length, NULL);
+ }
+
+ pdfi_countdown(glyphname);
+ pdfi_countdown(charstring);
+
+ return code;
+}
+
+static int
+pdfi_cff_subr_data(gs_font_type1 *pfont, int index, bool global, gs_glyph_data_t *pgd)
+{
+ int code = 0;
+ pdf_font_cff *cfffont = (pdf_font_cff *) pfont->client_data;
+
+ if ((global &&index >= cfffont->NumGlobalSubrs)||(!global &&index >= cfffont->NumSubrs)) {
+ code = gs_note_error(gs_error_rangecheck);
+ }
+ else {
+ pdf_string *subrstring;
+ pdf_array *s = global ? cfffont->GlobalSubrs : cfffont->Subrs;
+
+ code = pdfi_array_get(cfffont->ctx, s, (uint64_t) index, (pdf_obj **) &subrstring);
+ if (code >= 0) {
+ gs_glyph_data_from_bytes(pgd, subrstring->data, 0, subrstring->length, NULL);
+ pdfi_countdown(subrstring);
+ }
+ }
+ return code;
+}
+
+static int
+pdfi_cff_seac_data(gs_font_type1 *pfont, int ccode, gs_glyph *pglyph, gs_const_string *gstr, gs_glyph_data_t *pgd)
+{
+ int code = 0;
+ pdf_font_cff *cfffont = (pdf_font_cff *) pfont->client_data;
+ pdf_context *ctx = (pdf_context *) cfffont->ctx;
+ gs_glyph glyph = gs_c_known_encode((gs_char)ccode, ENCODING_INDEX_STANDARD);
+
+ if (glyph == GS_NO_GLYPH)
+ return_error(gs_error_rangecheck);
+
+ code = gs_c_glyph_name(glyph, gstr);
+
+ if (code >= 0) {
+ unsigned int nindex;
+ code = (*ctx->get_glyph_index)((gs_font *)pfont, (byte *)gstr->data, gstr->size, &nindex);
+ if (pglyph != NULL)
+ *pglyph = (gs_glyph)nindex;
+ }
+
+ if (code >= 0) {
+ pdf_name *glyphname = NULL;
+ pdf_string *charstring = NULL;
+ code = pdfi_name_alloc(ctx, (byte *) gstr->data, gstr->size, (pdf_obj **) &glyphname);
+ if (code >= 0) {
+ pdfi_countup(glyphname);
+ code = pdfi_dict_get_by_key(ctx, cfffont->CharStrings, glyphname, (pdf_obj **)&charstring);
+ pdfi_countdown(glyphname);
+ if (code >= 0)
+ if (pgd != NULL)
+ gs_glyph_data_from_bytes(pgd, charstring->data, 0, charstring->length, NULL);
+ pdfi_countdown(charstring);
+ }
+ }
+
+ return code;
+}
+
+/* push/pop are null ops here */
+static int
+pdfi_cff_push(void *callback_data, const fixed *pf, int count)
+{
+ (void)callback_data;
+ (void)pf;
+ (void)count;
+ return 0;
+}
+static int
+pdfi_cff_pop(void *callback_data, fixed *pf)
+{
+ (void)callback_data;
+ (void)pf;
+ return 0;
+}
+
+static int
+pdfi_cff_enumerate_glyph(gs_font *pfont, int *pindex,
+ gs_glyph_space_t glyph_space, gs_glyph *pglyph)
+{
+ int code, j;
+ pdf_name *key = NULL;
+ uint64_t i = (uint64_t) *pindex;
+ pdf_dict *cstrings;
+ pdf_font *pdffont = (pdf_font *) pfont->client_data;
+ pdf_context *ctx = (pdf_context *) pdffont->ctx;
+
+ (void)glyph_space;
+
+ /* Slightly naff: if build_char is NULL, this is an FDArray subfont */
+ if (pfont->procs.build_char == NULL) {
+ *pindex = 0;
+ *pglyph = GS_NO_GLYPH;
+ return 0;
+ }
+ else if (pdffont->pdfi_font_type == e_pdf_cidfont_type0) {
+ pdf_cidfont_type0 *cffcidfont = (pdf_cidfont_type0 *) pdffont;
+ cstrings = cffcidfont->CharStrings;
+ }
+ else {
+ pdf_font_cff *cfffont = (pdf_font_cff *) pdffont;
+
+ cstrings = cfffont->CharStrings;
+ }
+ if (*pindex <= 0)
+ code = pdfi_dict_key_first(pdffont->ctx, cstrings, (pdf_obj **) &key, &i);
+ else
+ code = pdfi_dict_key_next(pdffont->ctx, cstrings, (pdf_obj **) &key, &i);
+ if (code < 0) {
+ i = 0;
+ code = gs_note_error(gs_error_undefined);
+ }
+ /* If Encoding == NULL, it's an FDArray subfont */
+ else if (pdffont->pdfi_font_type != e_pdf_cidfont_type0 && pdffont->Encoding != NULL) {
+ unsigned int nindex;
+ code = (*ctx->get_glyph_index)(pfont, key->data, key->length, &nindex);
+ if (code < 0)
+ *pglyph = GS_NO_GLYPH;
+ else
+ *pglyph = (gs_glyph)nindex;
+ }
+ else {
+ char kbuf[32];
+ int l;
+ unsigned int val;
+ /* If this font started life as a CFF font that we've force to
+ act like a CIDFont, we can end up with a ".notdef" glyph name
+ */
+ if (key->length == 7 && memcmp(key->data, ".notdef", 7) == 0) {
+ val = 0;
+ l = 1;
+ }
+ else {
+ memcpy(kbuf, key->data, key->length);
+ kbuf[key->length] = 0;
+
+ l = sscanf(kbuf, "%ud", &val);
+ }
+ if (l > 0) {
+ pdf_cidfont_type0 *cffcidfont = (pdf_cidfont_type0 *) pdffont;
+ if (cffcidfont->cidtogidmap.size > 0) {
+ for (j = (cffcidfont->cidtogidmap.size >> 1) - 1; j >= 0; j--) {
+ if (val == (cffcidfont->cidtogidmap.data[j << 1] << 8 | cffcidfont->cidtogidmap.data[(j << 1) + 1])) {
+ val = j;
+ break;
+ }
+ }
+ }
+ *pglyph = (gs_glyph) (val) + GS_MIN_CID_GLYPH;
+ }
+ }
+ *pindex = (int)i;
+ pdfi_countdown(key);
+ return code;
+}
+
+/* This *should* only get called for SEAC lookups, which have to come from StandardEncoding
+ so just try to lookup the string in the standard encodings
+ */
+int
+pdfi_cff_global_glyph_code(const gs_font *pfont, gs_const_string *gstr, gs_glyph *pglyph)
+{
+ *pglyph = gs_c_name_glyph(gstr->data, gstr->size);
+ return 0;
+}
+
+static int
+pdfi_cff_glyph_outline(gs_font *pfont, int WMode, gs_glyph glyph,
+ const gs_matrix *pmat, gx_path *ppath, double sbw[4])
+{
+ gs_glyph_data_t gd;
+ gs_glyph_data_t *pgd = &gd;
+ gs_font_type1 *pfont1;
+ int code;
+
+ if (pfont->FontType == ft_CID_encrypted) {
+ gs_font_cid0 *pfcid0 = (gs_font_cid0 *) pfont;
+ int fididx = 0;
+
+ code = (*pfcid0->cidata.glyph_data) ((gs_font_base *) pfont, glyph, pgd, &fididx);
+ if (fididx < pfcid0->cidata.FDArray_size)
+ pfont1 = pfcid0->cidata.FDArray[fididx];
+ else
+ code = gs_note_error(gs_error_invalidaccess);
+ }
+ else {
+ pfont1 = (gs_font_type1 *) pfont;
+ code = (*pfont1->data.procs.glyph_data) ((gs_font_type1 *) pfont, glyph, pgd);
+ }
+
+ if (code >= 0) {
+ gs_type1_state cis = { 0 };
+ gs_type1_state *pcis = &cis;
+ gs_gstate gs;
+ int value;
+
+ if (pmat)
+ gs_matrix_fixed_from_matrix(&gs.ctm, pmat);
+ else {
+ gs_matrix imat;
+
+ gs_make_identity(&imat);
+ gs_matrix_fixed_from_matrix(&gs.ctm, &imat);
+ }
+ gs.flatness = 0;
+ code = gs_type1_interp_init(pcis, &gs, ppath, NULL, NULL, true, 0, pfont1);
+ if (code < 0)
+ return code;
+
+ pcis->no_grid_fitting = true;
+ gs_type1_set_callback_data(pcis, NULL);
+ /* Continue interpreting. */
+ icont:
+ code = pfont1->data.interpret(pcis, pgd, &value);
+ switch (code) {
+ case 0: /* all done */
+ /* falls through */
+ default: /* code < 0, error */
+ return code;
+ case type1_result_callothersubr: /* unknown OtherSubr */
+ return_error(gs_error_rangecheck); /* can't handle it */
+ case type1_result_sbw: /* [h]sbw, just continue */
+ type1_cis_get_metrics(pcis, sbw);
+ pgd = 0;
+ goto icont;
+ }
+ }
+ return code;
+}
+static int
+pdfi_cff_glyph_info(gs_font *font, gs_glyph glyph, const gs_matrix *pmat, int members, gs_glyph_info_t *info)
+{
+ if ((members & GLYPH_INFO_OUTLINE_WIDTHS) == 0)
+ return gs_type1_glyph_info(font, glyph, pmat, members, info);
+
+ return gs_default_glyph_info(font, glyph, pmat, members, info);
+}
+
+static int
+pdfi_cff_fdarray_glyph_data(gs_font_type1 *pfont, gs_glyph glyph, gs_glyph_data_t *pgd)
+{
+ return_error(gs_error_invalidfont);
+}
+
+static int
+pdfi_cff_fdarray_seac_data(gs_font_type1 *pfont, int ccode,
+ gs_glyph *pglyph, gs_const_string *gstr, gs_glyph_data_t *pgd)
+{
+ return_error(gs_error_invalidfont);
+}
+
+/* Note that pgd may be NULL - so only retrieve the fidx */
+static int
+pdfi_cff_cid_glyph_data(gs_font_base *pbfont, gs_glyph glyph, gs_glyph_data_t *pgd, int *pfidx)
+{
+ int code = 0;
+ pdf_cidfont_type0 *pdffont9 = (pdf_cidfont_type0 *) pbfont->client_data;
+ gs_font_cid0 *gscidfont = (gs_font_cid0 *) pbfont;
+ pdf_name *glyphname = NULL;
+ pdf_string *charstring = NULL;
+ char nbuf[64];
+ uint32_t l;
+ gs_glyph gid;
+
+ *pfidx = 0;
+
+ if (glyph < GS_MIN_CID_GLYPH)
+ gid = glyph;
+ else
+ gid = glyph - GS_MIN_CID_GLYPH;
+
+ if (pdffont9->cidtogidmap.size > (gid << 1) + 1) {
+ gid = pdffont9->cidtogidmap.data[gid << 1] << 8 | pdffont9->cidtogidmap.data[(gid << 1) + 1];
+ }
+
+ l = snprintf(nbuf, 64, "%" PRId64, gid);
+
+ code = pdfi_name_alloc(pdffont9->ctx, (byte *) nbuf, l, (pdf_obj **) &glyphname);
+ if (code >= 0) {
+ pdfi_countup(glyphname);
+ code = pdfi_dict_get_by_key(pdffont9->ctx, pdffont9->CharStrings, glyphname, (pdf_obj **) &charstring);
+ if (code >= 0 && charstring->length > 1) {
+ if (gscidfont->cidata.FDBytes == 0)
+ *pfidx = 0;
+ else
+ *pfidx = (int)charstring->data[0];
+ if (pgd)
+ gs_glyph_data_from_bytes(pgd, charstring->data + gscidfont->cidata.FDBytes, 0, charstring->length - gscidfont->cidata.FDBytes, NULL);
+ }
+ }
+ pdfi_countdown(charstring);
+ pdfi_countdown(glyphname);
+
+ return code;
+}
+
+static int
+pdfi_cff_cidfont_glyph_info(gs_font *font, gs_glyph glyph, const gs_matrix *pmat,
+ int members, gs_glyph_info_t *info)
+{
+ int code;
+ gs_font_cid0 *pcidfont = (gs_font_cid0 *)font;
+ pdf_cidfont_type0 *pdffont9 = (pdf_cidfont_type0 *)font->client_data;
+ code = (*pdffont9->orig_glyph_info)(font, glyph, pmat, members, info);
+ if (code < 0)
+ return code;
+
+ if ((members & GLYPH_INFO_WIDTHS) != 0
+ && glyph > GS_MIN_CID_GLYPH
+ && glyph < GS_MIN_GLYPH_INDEX) {
+ double widths[6] = {0};
+ int fidx;
+ gs_matrix imat;
+ gs_matrix mat1 = font->FontMatrix;
+ gs_glyph g = glyph - GS_MIN_CID_GLYPH;
+
+ code = (*pcidfont->cidata.glyph_data) ((gs_font_base *)font, g + GS_MIN_CID_GLYPH, NULL, &fidx);
+ if (code < 0)
+ return code;
+ if (fidx < pcidfont->cidata.FDArray_size) {
+ gs_font_type1 *pfdfont = pcidfont->cidata.FDArray[fidx];
+ /* The following cannot fail - if the matrix multiplication didn't work
+ we'd have errored out at a higher level
+ */
+ (void)gs_matrix_multiply(&font->FontMatrix, &pfdfont->FontMatrix, &mat1);
+ }
+ code = gs_matrix_invert(&mat1, &imat);
+ if (code < 0)
+ return code; /* By this stage, this should be impossible */
+ if (pmat) {
+ gs_matrix_multiply(&imat, pmat, &mat1);
+ }
+ else {
+ mat1 = imat;
+ }
+
+ code = pdfi_get_cidfont_glyph_metrics(font, g, widths, true);
+ if (code >= 0) {
+ code = gs_point_transform(widths[GLYPH_W0_WIDTH_INDEX] / 1000.0, widths[GLYPH_W0_HEIGHT_INDEX] / 1000.0, &mat1, &info->width[0]);
+ if (code < 0)
+ return code;
+ info->members |= GLYPH_INFO_WIDTH0;
+
+ if ((members & GLYPH_INFO_WIDTH1) != 0 && (widths[GLYPH_W1_WIDTH_INDEX] != 0 || widths[GLYPH_W1_HEIGHT_INDEX] != 0)) {
+ code = gs_point_transform(widths[GLYPH_W1_WIDTH_INDEX] / 1000.0, widths[GLYPH_W1_HEIGHT_INDEX] / 1000.0, &mat1, &info->width[1]);
+ info->members |= GLYPH_INFO_WIDTH1;
+ }
+ if ((members & GLYPH_INFO_VVECTOR1) != 0) {
+ code = gs_point_transform(widths[GLYPH_W1_V_X_INDEX] / 1000.0, widths[GLYPH_W1_V_Y_INDEX] / 1000.0, &mat1, &info->v);
+ info->members |= GLYPH_INFO_VVECTOR1;
+ }
+ }
+ }
+ return code;
+}
+
+/* END CALLBACKS */
+
+#if 0 /* not currently used */
+static inline int
+s16(const byte *p)
+{
+ return (signed short)((p[0] << 8) | p[1]);
+}
+#endif /* not currently used */
+
+static inline int
+u16(const byte *p)
+{
+ return (p[0] << 8) | p[1];
+}
+
+static inline int
+u24(const byte *p)
+{
+ return (p[0] << 16) | (p[1] << 8) | p[2];
+}
+
+static inline int
+u32(const byte *p)
+{
+ return (p[0] << 24) | (p[1] << 16) | (p[2] << 8) | p[3];
+}
+
+
+
+static int
+subrbias(int count)
+{
+ return count < 1240 ? 107 : count < 33900 ? 1131 : 32768;
+}
+
+static int
+uofs(const byte *p, int offsize)
+{
+ if (offsize == 1)
+ return p[0];
+ if (offsize == 2)
+ return u16(p);
+ if (offsize == 3)
+ return u24(p);
+ if (offsize == 4)
+ return u32(p);
+ return 0;
+}
+
+static int
+iso_adobe_charset_proc(const byte *p, const byte *pe, unsigned i)
+{
+ if (i < 228)
+ return i + 1;
+ else
+ return_error(gs_error_rangecheck);
+}
+
+static int
+expert_charset_proc(const byte *p, const byte *pe, unsigned i)
+{
+ if (i < gs_c_known_encoding_lengths[6])
+ return gs_c_known_encodings[6][i];
+
+ return_error(gs_error_rangecheck);
+}
+
+static int
+expert_subset_charset_proc(const byte *p, const byte *pe, unsigned int i)
+{
+#if 0
+ if (i < sizeof(expert_subset_charset) / sizeof(*expert_subset_charset))
+ return expert_subset_charset[i];
+#endif
+ return_error(gs_error_rangecheck);
+}
+
+static int
+format0_charset_proc(const byte *p, const byte *pe, unsigned int i)
+{
+ if (p + 2 * i > pe)
+ return gs_error_rangecheck;
+
+ return u16(p + 2 * i);
+}
+
+static int
+format1_charset_proc(const byte *p, const byte *pe, unsigned int i)
+{
+ int code = gs_error_rangecheck;
+ unsigned int cid = 0;
+
+ while (p < pe - 3) {
+ unsigned int first, count;
+
+ first = (unsigned int)u16(p);
+ count = (unsigned int)p[2] + 1;
+
+ if (i < cid + count) {
+ code = first + i - cid;
+ break;
+ }
+ p += 3;
+ cid += count;
+ }
+ return code;
+}
+
+static int
+format2_charset_proc(const byte *p, const byte *pe, unsigned int i)
+{
+ int code = gs_error_rangecheck;
+ unsigned int cid = 0;
+
+ while (p < pe - 4) {
+ unsigned int first, count;
+
+ first = u16(p);
+ count = u16(p + 2) + 1;
+
+ if (i < cid + count) {
+ code = first + i - cid;
+ break;
+ }
+ p += 4;
+ cid += count;
+ }
+ return code;
+}
+
+static int
+format0_fdselect_proc(const byte *p, const byte *pe, unsigned int i)
+{
+ return (int)(*(p + i));
+}
+
+static int
+format3_fdselect_proc(const byte *p, const byte *pe, unsigned int i)
+{
+ unsigned int n_ranges;
+
+ n_ranges = u16(p);
+ p += 2;
+
+ while (n_ranges-- && p + 5 <= pe) {
+ unsigned int first, last;
+
+ first = u16(p);
+ last = u16(p + 3);
+
+ if (i >= first && i < last) {
+ return (int)(*(p + 2));
+ }
+ p += 3;
+ }
+ return_error(gs_error_rangecheck);
+}
+
+
+static byte *
+pdfi_read_cff_real(byte *p, byte *e, float *val)
+{
+ char buf[64];
+ char *txt = buf;
+
+ /* b0 was 30 */
+
+ while (txt < buf + (sizeof buf) - 3 && p < e) {
+ int b, n;
+
+ b = *p++;
+
+ n = (b >> 4) &0xf;
+ if (n < 0xA) {
+ *txt++ = n + '0';
+ }
+ else if (n == 0xA) {
+ *txt++ = '.';
+ }
+ else if (n == 0xB) {
+ *txt++ = 'E';
+ }
+ else if (n == 0xC) {
+ *txt++ = 'E';
+ *txt++ = '-';
+ }
+ else if (n == 0xE) {
+ *txt++ = '-';
+ }
+ else if (n == 0xF) {
+ break;
+ }
+
+ n = b &0xf;
+ if (n < 0xA) {
+ *txt++ = n + '0';
+ }
+ else if (n == 0xA) {
+ *txt++ = '.';
+ }
+ else if (n == 0xB) {
+ *txt++ = 'E';
+ }
+ else if (n == 0xC) {
+ *txt++ = 'E';
+ *txt++ = '-';
+ }
+ else if (n == 0xE) {
+ *txt++ = '-';
+ }
+ else if (n == 0xF) {
+ break;
+ }
+ }
+
+ *txt = 0;
+
+ *val = atof(buf);
+
+ return p;
+}
+
+static byte *
+pdfi_read_cff_integer(byte *p, byte *e, int b0, int *val)
+{
+ int b1, b2, b3, b4;
+
+ if (b0 == 28) {
+ if (p + 2 > e) {
+ gs_throw(-1, "corrupt dictionary (integer)");
+ return 0;
+ }
+ b1 = *p++;
+ b2 = *p++;
+ *val = (b1 << 8) | b2;
+ }
+
+ else if (b0 == 29) {
+ if (p + 4 > e) {
+ gs_throw(-1, "corrupt dictionary (integer)");
+ return 0;
+ }
+ b1 = *p++;
+ b2 = *p++;
+ b3 = *p++;
+ b4 = *p++;
+ *val = (b1 << 24) | (b2 << 16) | (b3 << 8) | b4;
+ }
+
+ else if (b0 < 247) {
+ *val = b0 - 139;
+ }
+
+ else if (b0 < 251) {
+ if (p + 1 > e) {
+ gs_throw(-1, "corrupt dictionary (integer)");
+ return 0;
+ }
+ b1 = *p++;
+ *val = (b0 - 247) * 256 + b1 + 108;
+ }
+
+ else {
+ if (p + 1 > e) {
+ gs_throw(-1, "corrupt dictionary (integer)");
+ return 0;
+ }
+ b1 = *p++;
+ *val = -(b0 - 251) * 256 - b1 - 108;
+ }
+
+ return p;
+}
+
+static int
+pdfi_read_cff_dict(byte *p, byte *e, pdfi_gs_cff_font_priv *ptpriv, cff_font_offsets *offsets)
+{
+ pdfi_cff_font_priv *font = &ptpriv->pdfcffpriv;
+ struct
+ {
+ int ival;
+ float fval;
+ } args[48];
+ int offset;
+ int b0, n;
+ double f;
+ int i;
+ int code = 0;
+ bool do_priv = false;
+
+ memset(args, 0x00, sizeof(args));
+
+ offset = p - font->cffdata;
+
+ n = 0;
+ while (p < e) {
+ b0 = *p++;
+
+ switch (b0) {
+ case 22:
+ case 23:
+ case 24:
+ case 25:
+ case 26:
+ case 27:
+ case 31:
+ case 255:
+ continue;
+ default:
+ break;
+ }
+
+ if (b0 < 22) {
+ if (b0 == 12) {
+ if (p + 1 > e) {
+ return gs_throw(-1, "corrupt dictionary (operator)");
+ }
+ b0 = 0x100 | *p++;
+ }
+ if (b0 == 13) { /* UniqueID */
+ }
+
+ if (b0 == 14) { /* XUID */
+ }
+
+ if (b0 == 15) {
+ offsets->charset_off = args[0].ival;
+ }
+
+ if (b0 == 16) {
+ offsets->encoding_off = args[0].ival;
+ }
+
+ /* some CFF file offsets */
+
+ if (b0 == 17) {
+ font->charstrings = font->cffdata + args[0].ival;
+ }
+
+ if (b0 == 18) {
+ offsets->private_size = args[0].ival;
+ offsets->private_off = args[1].ival;
+ do_priv = offsets->private_size > 0 ? true : false;
+ }
+
+ if (b0 == 19) {
+ font->subrs = font->cffdata + offset + args[0].ival;
+ }
+
+ if (b0 == (256 | 30)) {
+ code = pdfi_make_string_from_sid(font->ctx, (pdf_obj **) &font->registry, font, offsets, args[0].ival);
+ if (code < 0)
+ return code;
+ code = pdfi_make_string_from_sid(font->ctx, (pdf_obj **) &font->ordering, font, offsets, args[1].ival);
+ if (code < 0)
+ return code;
+ font->supplement = args[2].ival;
+ offsets->have_ros = true;
+ ptpriv->FontType = ft_CID_encrypted;
+ }
+
+ if (b0 == (256 | 34)) {
+ font->cidcount = args[0].ival;
+ }
+
+ if (b0 == (256 | 35)) {
+ font->uidbase = args[0].ival;
+ }
+
+ if (b0 == (256 | 36)) {
+ offsets->fdarray_off = args[0].ival;
+ }
+
+ if (b0 == (256 | 37)) {
+ offsets->fdselect_off = args[0].ival;
+ }
+
+ if (b0 == (256 | 38)) {
+ pdf_string *fnamestr = NULL;
+
+ code = pdfi_make_string_from_sid(font->ctx, (pdf_obj **) &fnamestr, font, offsets, args[0].ival);
+ if (code >= 0) {
+ memcpy(ptpriv->font_name.chars, fnamestr->data, fnamestr->length);
+ memcpy(ptpriv->key_name.chars, fnamestr->data, fnamestr->length);
+ ptpriv->font_name.size = ptpriv->key_name.size = fnamestr->length;
+ pdfi_countdown(fnamestr);
+ }
+ }
+
+ /* Type1 stuff that need to be set for the ptpriv struct */
+
+ if (b0 == (256 | 6)) {
+ if (args[0].ival == 1) {
+ ptpriv->type1data.interpret = gs_type1_interpret;
+ ptpriv->type1data.lenIV = -1; /* FIXME */
+ }
+ }
+
+ if (b0 == (256 | 7)) {
+ ptpriv->FontMatrix.xx = args[0].fval;
+ ptpriv->FontMatrix.xy = args[1].fval;
+ ptpriv->FontMatrix.yx = args[2].fval;
+ ptpriv->FontMatrix.yy = args[3].fval;
+ ptpriv->FontMatrix.tx = args[4].fval;
+ ptpriv->FontMatrix.ty = args[5].fval;
+ offsets->have_matrix = true;
+ }
+
+ if (b0 == 5) {
+ ptpriv->FontBBox.p.x = args[0].fval;
+ ptpriv->FontBBox.p.y = args[1].fval;
+ ptpriv->FontBBox.q.x = args[2].fval;
+ ptpriv->FontBBox.q.y = args[3].fval;
+ }
+
+ if (b0 == 20)
+ ptpriv->type1data.defaultWidthX = float2fixed(args[0].fval);
+
+ if (b0 == 21)
+ ptpriv->type1data.nominalWidthX = float2fixed(args[0].fval);
+
+ if (b0 == (256 | 19))
+ ptpriv->type1data.initialRandomSeed = args[0].ival;
+
+ if (b0 == 6) {
+ ptpriv->type1data.BlueValues.count = n;
+ ptpriv->type1data.BlueValues.values[0] = args[0].fval;
+ for (i = 1; i < n; i++) {
+ ptpriv->type1data.BlueValues.values[i] = ptpriv->type1data.BlueValues.values[i - 1] + args[i].fval;
+ }
+ }
+
+ if (b0 == 7) {
+ ptpriv->type1data.OtherBlues.count = n;
+ ptpriv->type1data.OtherBlues.values[0] = args[0].fval;
+ for (i = 1; i < n; i++) {
+ ptpriv->type1data.OtherBlues.values[i] = ptpriv->type1data.OtherBlues.values[i - 1] + args[i].fval;
+ }
+ }
+
+ if (b0 == 8) {
+ ptpriv->type1data.FamilyBlues.count = n;
+ ptpriv->type1data.FamilyBlues.values[0] = args[0].fval;
+ for (i = 1; i < n; i++) {
+ ptpriv->type1data.FamilyBlues.values[i] = ptpriv->type1data.FamilyBlues.values[i - 1] + args[i].fval;
+ }
+ }
+
+ if (b0 == 9) {
+ ptpriv->type1data.FamilyOtherBlues.count = n;
+ ptpriv->type1data.FamilyOtherBlues.values[0] = args[0].fval;
+ for (i = 1; i < n; i++) {
+ ptpriv->type1data.FamilyOtherBlues.values[i] = ptpriv->type1data.FamilyOtherBlues.values[i - 1] + args[i].fval;
+ }
+ }
+
+ if (b0 == 10) {
+ ptpriv->type1data.StdHW.count = 1;
+ ptpriv->type1data.StdHW.values[0] = args[0].fval;
+ }
+
+ if (b0 == 11) {
+ ptpriv->type1data.StdVW.count = 1;
+ ptpriv->type1data.StdVW.values[0] = args[0].fval;
+ }
+
+ if (b0 == (256 | 9))
+ ptpriv->type1data.BlueScale = args[0].fval;
+
+ if (b0 == (256 | 10))
+ ptpriv->type1data.BlueShift = args[0].fval;
+
+ if (b0 == (256 | 11))
+ ptpriv->type1data.BlueFuzz = (int)args[0].fval;
+
+ if (b0 == (256 | 12)) {
+ ptpriv->type1data.StemSnapH.count = n;
+ for (f = 0, i = 0; i < n; f += args[i].fval, i++)
+ ptpriv->type1data.StemSnapH.values[i] = f;
+ }
+
+ if (b0 == (256 | 13)) {
+ ptpriv->type1data.StemSnapV.count = n;
+ for (f = 0, i = 0; i < n; f += args[i].fval, i++)
+ ptpriv->type1data.StemSnapV.values[i] = f;
+ }
+
+ if (b0 == (256 | 14))
+ ptpriv->type1data.ForceBold = args[0].ival;
+
+ if (b0 == (256 | 17))
+ ptpriv->type1data.LanguageGroup = args[0].ival;
+
+ if (b0 == (256 | 18))
+ ptpriv->type1data.ExpansionFactor = args[0].fval;
+
+ n = 0;
+ }
+
+ else {
+ if (b0 == 30) {
+ p = pdfi_read_cff_real(p, e, &args[n].fval);
+ if (!p) {
+ dmprintf(ptpriv->memory, "\nCFF: corrupt dictionary operand\n");
+ break;
+ }
+ args[n].ival = (int)args[n].fval;
+ n++;
+ }
+ else if (b0 == 28 || b0 == 29 || (b0 >= 32 && b0 <= 254)) {
+ /* If we run out of data reading an integer at the very end of the stream, don't throw an error
+ just return.
+ */
+ bool near_end = ((e - p) <= 4);
+ p = pdfi_read_cff_integer(p, e, b0, &args[n].ival);
+ if (!p) {
+ if (!near_end)
+ code = gs_note_error(gs_error_invalidfont);
+ dmprintf(ptpriv->memory, "\nCFF: corrupt dictionary operand\n");
+ break;
+ }
+ args[n].fval = (float)args[n].ival;
+ n++;
+ }
+ else {
+ dmprintf1(ptpriv->memory, "CFF: corrupt dictionary operand (b0 = %d)", b0);
+ }
+ }
+ }
+
+ /* recurse for the private dictionary */
+ if (do_priv && code >= 0) {
+ byte *dend = font->cffdata + offsets->private_off + offsets->private_size;
+
+ if (dend > font->cffend)
+ dend = font->cffend;
+
+ if (p == NULL)
+ code = gs_error_invalidfont;
+ else
+ code = pdfi_read_cff_dict(font->cffdata + offsets->private_off, dend, ptpriv, offsets);
+
+ if (code < 0)
+ dmprintf(ptpriv->memory, "CFF: cannot read private dictionary");
+ }
+
+ return code;
+}
+
+/*
+ * Get the number of items in an INDEX, and return
+ * a pointer to the end of the INDEX or NULL on
+ * failure.
+ */
+static byte *
+pdfi_count_cff_index(byte *p, byte *e, int *countp)
+{
+ int count, offsize, last;
+
+ if (p + 3 > e) {
+ gs_throw(-1, "not enough data for index header");
+ return 0;
+ }
+
+ count = u16(p);
+ p += 2;
+ *countp = count;
+
+ if (count == 0)
+ return p;
+
+ offsize = *p++;
+
+ if (offsize < 1 || offsize > 4) {
+ gs_throw(-1, "corrupt index header");
+ return 0;
+ }
+
+ if (p + count * offsize > e) {
+ gs_throw(-1, "not enough data for index offset table");
+ return 0;
+ }
+
+ p += count * offsize;
+ last = uofs(p, offsize);
+ p += offsize;
+ p--; /* stupid offsets */
+
+ if (p + last > e) {
+ gs_throw(-1, "not enough data for index data");
+ return 0;
+ }
+
+ p += last;
+
+ return p;
+}
+
+/*
+ * Locate and store pointers to the data of an
+ * item in the index that starts at 'p'.
+ * Return pointer to the end of the index,
+ * or NULL on failure.
+ */
+static byte *
+pdfi_find_cff_index(byte *p, byte *e, int idx, byte ** pp, byte ** ep)
+{
+ int count, offsize, sofs, eofs, last;
+
+ if (p == NULL)
+ return 0;
+
+ if (p + 3 > e) {
+ gs_throw(-1, "not enough data for index header");
+ return 0;
+ }
+
+ count = u16(p);
+ p += 2;
+ if (count == 0)
+ return 0;
+
+ offsize = *p++;
+
+ if (offsize < 1 || offsize > 4) {
+ gs_throw(-1, "corrupt index header");
+ return 0;
+ }
+
+ if (p + count * offsize > e) {
+ gs_throw(-1, "not enough data for index offset table");
+ return 0;
+ }
+
+ if (idx < 0 || idx >= count) {
+ gs_throw(-1, "tried to access non-existing index item");
+ return 0;
+ }
+
+ sofs = uofs(p + idx * offsize, offsize);
+ eofs = uofs(p + (idx + 1) * offsize, offsize);
+ last = uofs(p + count * offsize, offsize);
+
+ p += count * offsize;
+ p += offsize;
+ p--; /* stupid offsets */
+
+ if (p + last > e) {
+ gs_throw(-1, "not enough data for index data");
+ return 0;
+ }
+
+ if (sofs < 0 || eofs < 0 || sofs > eofs || eofs > last) {
+ gs_throw(-1, "corrupt index offset table");
+ return 0;
+ }
+
+ *pp = p + sofs;
+ *ep = p + eofs;
+
+ return p + last;
+}
+
+static int
+pdfi_make_name_from_sid(pdf_context *ctx, pdf_obj ** nm, pdfi_cff_font_priv *font, cff_font_offsets *offsets, unsigned int sid)
+{
+ gs_string str;
+ byte *p;
+
+ if (sid < gs_c_known_encoding_lengths[10]) {
+ gs_glyph gl = gs_c_known_encode(sid, 10);
+
+ (void)gs_c_glyph_name(gl, (gs_const_string *) &str);
+ }
+ else {
+ byte *strp, *stre;
+
+ p = pdfi_find_cff_index(font->cffdata + offsets->strings_off, font->cffend, sid - gs_c_known_encoding_lengths[10], &strp, &stre);
+ if (p == NULL)
+ return_error(gs_error_rangecheck);
+ str.data = strp;
+ str.size = stre - strp;
+ }
+ return pdfi_name_alloc(ctx, str.data, str.size, nm);
+}
+
+static int
+pdfi_make_string_from_sid(pdf_context *ctx, pdf_obj ** s0, pdfi_cff_font_priv *font, cff_font_offsets *offsets, unsigned int sid)
+{
+ byte *p;
+ int code;
+ gs_string str;
+ pdf_string *s = NULL;
+
+ if (sid < gs_c_known_encoding_lengths[10]) {
+ gs_glyph gl = gs_c_known_encode(sid, 10);
+
+ (void)gs_c_glyph_name(gl, (gs_const_string *) &str);
+ }
+ else {
+ byte *strp, *stre;
+
+ p = pdfi_find_cff_index(font->cffdata + offsets->strings_off, font->cffend,
+ sid - gs_c_known_encoding_lengths[10], &strp, &stre);
+ if (p == NULL)
+ return_error(gs_error_rangecheck);
+ str.data = strp;
+ str.size = stre - strp;
+ }
+ code = pdfi_object_alloc(ctx, PDF_STRING, str.size, (pdf_obj **) &s);
+ if (code < 0)
+ return code;
+ pdfi_countup(s);
+ memcpy(s->data, str.data, str.size);
+ s->length = str.size;
+
+ *s0 = (pdf_obj *) s;
+ return 0;
+}
+
+static int
+pdfi_cff_build_encoding(pdf_context *ctx, pdfi_gs_cff_font_priv *ptpriv, cff_font_offsets *offsets,
+ int (*charset_proc)(const byte *p, const byte *pe, unsigned int i))
+{
+ pdfi_cff_font_priv *font = &ptpriv->pdfcffpriv;
+ int code = 0;
+ byte *s, *e, *lp;
+ pdf_string *pstr;
+ unsigned int i, gid, enc_format = 0;
+ int sid;
+ pdf_name *ndname = NULL;
+ unsigned char gid2char[256];
+ unsigned supp_enc_offset = 0;
+
+ if (offsets->encoding_off <= 1) {
+ /* Either standard or expert encoding */
+ pdf_name *enm = NULL;
+ const char *const stdenc = "StandardEncoding";
+ const char *const expenc = "MacExpertEncoding";
+ char const *enctouse;
+
+ if (offsets->encoding_off < 1) {
+ enctouse = stdenc;
+ }
+ else {
+ enctouse = expenc;
+ }
+ code = pdfi_name_alloc(ctx, (byte *) enctouse, strlen(enctouse), (pdf_obj **) &enm);
+ if (code >= 0) {
+ pdfi_countup(enm);
+ code = pdfi_create_Encoding(ctx, (pdf_obj *) enm, NULL, (pdf_obj **) &font->Encoding);
+ pdfi_countdown(enm);
+ }
+ }
+ else {
+ code = pdfi_object_alloc(ctx, PDF_ARRAY, 256, (pdf_obj **) &font->Encoding);
+ if (code < 0)
+ return code;
+
+ code = pdfi_name_alloc(ctx, (byte *) ".notdef", 7, (pdf_obj **) &ndname);
+ if (code < 0)
+ return code;
+
+
+ pdfi_countup(font->Encoding);
+ pdfi_countup(ndname);
+ code = 0;
+ /* Prepopulate with notdefs */
+ for (i = 0; i < 256 && code >= 0; i++) {
+ code = pdfi_array_put(ctx, font->Encoding, (uint64_t) i, (pdf_obj *) ndname);
+ }
+
+ if (code >= 0) {
+ byte *p = font->cffdata + offsets->encoding_off;
+
+ enc_format = p[0];
+
+ lp = pdfi_find_cff_index(font->charstrings, font->cffend, 0, &s, &e);
+ if (lp == NULL) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto done;
+ }
+ code = pdfi_object_alloc(ctx, PDF_STRING, e - s, (pdf_obj **) &pstr);
+ if (code < 0)
+ goto done;
+ memcpy(pstr->data, s, e - s);
+ pdfi_countup(pstr);
+ code =
+ pdfi_dict_put_obj(ctx, font->CharStrings, (pdf_obj *) ndname, (pdf_obj *) pstr);
+ pdfi_countdown(pstr);
+ if (code < 0) {
+ goto done;
+ }
+ pdfi_countdown(ndname);
+ ndname = NULL; /* just to avoid bad things! */
+
+ if ((enc_format &0x7f) == 0) {
+ unsigned int n_codes = p[1];
+
+ if (p + 2 + n_codes > font->cffend) {
+ return_error(gs_error_invalidfont);
+ }
+ gid2char[0] = 0;
+ for (i = 0; i < n_codes; i++) {
+ gid2char[i + 1] = p[2 + i];
+ }
+ memset(gid2char + n_codes + 1, 0, sizeof(gid2char) - n_codes - 1);
+ supp_enc_offset = 2 + n_codes;
+ }
+ else if ((enc_format &0x7f) == 1) {
+ unsigned int n_ranges = p[1];
+ unsigned int first, left, j, k = 1;
+
+ if (p + 2 + 2 * n_ranges > font->cffend) {
+ return_error(gs_error_invalidfont);
+ }
+ gid2char[0] = 0;
+ for (i = 0; i < n_ranges; i++) {
+ first = p[2 + 2 * i];
+ left = p[3 + 2 * i];
+ for (j = 0; j <= left && k < 256; j++)
+ gid2char[k++] = first + j;
+ }
+ memset(gid2char + k, 0, sizeof(gid2char) - k);
+ supp_enc_offset = 2 * n_ranges + 2;
+ }
+ else {
+ return_error(gs_error_rangecheck);
+ }
+ }
+ }
+ if (code >= 0) {
+ pdf_obj *gname;
+
+ code = 0;
+
+ lp = pdfi_find_cff_index(font->charstrings, font->cffend, 0, &s, &e);
+ if (lp == NULL) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto done;
+ }
+ code = pdfi_object_alloc(ctx, PDF_STRING, e - s, (pdf_obj **) &pstr);
+ if (code < 0)
+ goto done;
+ memcpy(pstr->data, s, e - s);
+ pdfi_countup(pstr);
+ if (ptpriv->forcecid) {
+ char buf[40];
+ int len = gs_sprintf(buf, "%d", 0);
+
+ code = pdfi_name_alloc(ctx, (byte *) buf, len, &gname);
+ if (code < 0) {
+ pdfi_countdown(pstr);
+ return code;
+ }
+ pdfi_countup(gname);
+ }
+ else {
+ code = pdfi_name_alloc(ctx, (byte *) ".notdef", 7, &gname);
+ if (code < 0) {
+ pdfi_countdown(pstr);
+ goto done;
+ }
+ pdfi_countup(gname);
+ }
+ code = pdfi_dict_put_obj(ctx, font->CharStrings, gname, (pdf_obj *) pstr);
+ pdfi_countdown(pstr);
+ pdfi_countdown(gname);
+ if (code < 0)
+ goto done;
+
+ for (gid = 1; gid < font->ncharstrings && code >= 0; gid++) {
+
+ lp = pdfi_find_cff_index(font->charstrings, font->cffend, gid, &s, &e);
+ if (lp == NULL) {
+ code = gs_note_error(gs_error_rangecheck);
+ continue;
+ }
+ code = pdfi_object_alloc(ctx, PDF_STRING, e - s, (pdf_obj **) &pstr);
+ if (code < 0)
+ return code;
+ memcpy(pstr->data, s, e - s);
+ pdfi_countup(pstr);
+
+ if (ptpriv->forcecid) {
+ char buf[40];
+ int len = gs_sprintf(buf, "%d", gid);
+
+ code = pdfi_name_alloc(ctx, (byte *) buf, len, &gname);
+ if (code < 0) {
+ pdfi_countdown(pstr);
+ return code;
+ }
+ }
+ else {
+ sid = (*charset_proc) (font->cffdata + offsets->charset_off + 1, font->cffend, gid - 1);
+ if (sid < 0) {
+ pdfi_countdown(pstr);
+ return sid;
+ }
+ if ((code = pdfi_make_name_from_sid(ctx, &gname, font, offsets, sid)) < 0) {
+ char buf[40];
+ int len = gs_sprintf(buf, "sid-%d", sid);
+
+ code = pdfi_name_alloc(ctx, (byte *) buf, len, &gname);
+ if (code < 0) {
+ pdfi_countdown(pstr);
+ return code;
+ }
+ }
+ }
+ pdfi_countup(gname);
+ code = pdfi_dict_put_obj(ctx, font->CharStrings, gname, (pdf_obj *) pstr);
+ pdfi_countdown(pstr);
+ if (code < 0) {
+ pdfi_countdown(gname);
+ return code;
+ }
+ if (offsets->encoding_off > 1 && gid < 256) {
+ code = pdfi_array_put(ctx, font->Encoding, (int64_t) gid2char[gid], gname);
+ }
+ pdfi_countdown(gname);
+ }
+
+ if (offsets->encoding_off > 1 && (enc_format &0x80)) {
+ unsigned int n_supp, charcode, sid;
+ byte *p = font->cffdata + offsets->encoding_off + supp_enc_offset;
+ pdf_obj *gname;
+
+ n_supp = p[0];
+
+ for (i = 0; i < n_supp && code >= 0; i++) {
+ charcode = p[1 + 3 * i];
+ sid = u16(p + 2 + 3 * i);
+
+ if ((code = pdfi_make_name_from_sid(ctx, &gname, font, offsets, sid)) < 0) {
+ char buf[40];
+ int len = gs_sprintf(buf, "sid-%d", sid);
+
+ if (len > 0)
+ code = pdfi_name_alloc(ctx, (byte *) buf, len, &gname);
+ else
+ code = 0;
+
+ if (code < 0)
+ continue;
+ }
+ pdfi_countup(gname);
+ code = pdfi_array_put(ctx, font->Encoding, (int64_t) charcode, gname);
+ pdfi_countdown(gname);
+ }
+ }
+ }
+ done:
+ if (code < 0) {
+ pdfi_countdown(ndname);
+ }
+ return code;
+}
+
+
+/*
+ * Scan the CFF file structure and extract important data.
+ */
+
+static int
+pdfi_read_cff(pdf_context *ctx, pdfi_gs_cff_font_priv *ptpriv)
+{
+ pdfi_cff_font_priv *font = &ptpriv->pdfcffpriv;
+ byte *pstore, *p = font->cffdata;
+ byte *e = font->cffend;
+ byte *dictp, *dicte;
+ byte *strp, *stre;
+ byte *nms, *nmp, *nme;
+ int count;
+ int i, code = 0;
+ cff_font_offsets offsets = { 0 };
+ int (*charset_proc)(const byte *p, const byte *pe, unsigned int i);
+ int major, minor, hdrsize;
+
+ /* CFF header */
+ if (p + 4 > e)
+ return gs_throw(gs_error_invalidfont, "not enough data for header");
+
+ major = *p;
+ minor = *(p + 1);
+ hdrsize = *(p + 2);
+
+ if (major != 1 || minor != 0)
+ return gs_throw(gs_error_invalidfont, "not a CFF 1.0 file");
+
+ if (p + hdrsize > e)
+ return gs_throw(gs_error_invalidfont, "not enough data for extended header");
+ p += hdrsize;
+
+ /* Name INDEX */
+ nms = p;
+ p = pdfi_count_cff_index(p, e, &count);
+ if (p == NULL)
+ return gs_throw(gs_error_invalidfont, "cannot read name index");
+ if (count != 1)
+ return gs_throw(gs_error_invalidfont, "file did not contain exactly one font");
+
+ nms = pdfi_find_cff_index(nms, e, 0, &nmp, &nme);
+ if (!nms)
+ return gs_throw(gs_error_invalidfont, "cannot read names index");
+ else {
+ int len = nme - nmp < sizeof(ptpriv->key_name.chars) ? nme - nmp : sizeof(ptpriv->key_name.chars);
+ memcpy(ptpriv->key_name.chars, nmp, len);
+ memcpy(ptpriv->font_name.chars, nmp, len);
+ ptpriv->key_name.size = ptpriv->font_name.size = len;
+ }
+
+ /* Top Dict INDEX */
+ p = pdfi_find_cff_index(p, e, 0, &dictp, &dicte);
+ if (p == NULL)
+ return gs_throw(gs_error_invalidfont, "cannot read top dict index");
+
+ /* String index */
+ pstore = p;
+ p = pdfi_find_cff_index(p, e, 0, &strp, &stre);
+ offsets.strings_off = pstore - font->cffdata;
+
+ p = pdfi_count_cff_index(pstore, e, &count);
+ if (p == NULL)
+ return_error(gs_error_invalidfont);
+
+ offsets.strings_size = (unsigned int)count;
+
+ /* Global Subr INDEX */
+ font->gsubrs = p;
+ p = pdfi_count_cff_index(p, e, &font->NumGlobalSubrs);
+ if (p == NULL) {
+ font->GlobalSubrs = NULL;
+ font->NumGlobalSubrs = 0;
+ }
+ /* Read the top and private dictionaries */
+ code = pdfi_read_cff_dict(dictp, dicte, ptpriv, &offsets);
+ if (code < 0)
+ return gs_rethrow(code, "cannot read top dictionary");
+
+ /* Check the subrs index */
+ font->NumSubrs = 0;
+ if (font->subrs) {
+ p = pdfi_count_cff_index(font->subrs, e, &font->NumSubrs);
+ if (p == NULL || font->NumSubrs > 65536) {
+ font->Subrs = NULL;
+ font->NumSubrs = 0;
+ }
+ else {
+ ptpriv->type1data.subroutineNumberBias = subrbias(font->NumSubrs);
+ }
+ }
+
+
+ font->GlobalSubrs = NULL;
+ if (font->NumGlobalSubrs > 0 && font->NumGlobalSubrs <= 65536) {
+ ptpriv->type1data.gsubrNumberBias = subrbias(font->NumGlobalSubrs);
+ code = pdfi_object_alloc(ctx, PDF_ARRAY, font->NumGlobalSubrs, (pdf_obj **) &font->GlobalSubrs);
+ if (code >= 0) {
+ font->GlobalSubrs->refcnt = 1;
+ for (i = 0; i < font->NumGlobalSubrs; i++) {
+ pdf_string *gsubrstr;
+
+ p = pdfi_find_cff_index(font->gsubrs, font->cffend, i, &strp, &stre);
+ if (p) {
+ code = pdfi_object_alloc(ctx, PDF_STRING, stre - strp, (pdf_obj **) &gsubrstr);
+ if (code >= 0) {
+ memcpy(gsubrstr->data, strp, gsubrstr->length);
+ code =
+ pdfi_array_put(ctx, font->GlobalSubrs, (uint64_t) i,
+ (pdf_obj *) gsubrstr);
+ if (code < 0) {
+ gsubrstr->refcnt = 1;
+ pdfi_countdown(gsubrstr);
+ }
+ }
+ }
+ }
+ }
+ }
+
+ font->Subrs = NULL;
+ if (font->NumSubrs > 0) {
+ code = pdfi_object_alloc(ctx, PDF_ARRAY, font->NumSubrs, (pdf_obj **) &font->Subrs);
+ if (code >= 0) {
+ font->Subrs->refcnt = 1;
+ for (i = 0; i < font->NumSubrs; i++) {
+ pdf_string *subrstr;
+
+ p = pdfi_find_cff_index(font->subrs, font->cffend, i, &strp, &stre);
+ if (p) {
+ code = pdfi_object_alloc(ctx, PDF_STRING, stre - strp, (pdf_obj **) &subrstr);
+ if (code >= 0) {
+ memcpy(subrstr->data, strp, subrstr->length);
+ code = pdfi_array_put(ctx, font->Subrs, (uint64_t) i, (pdf_obj *) subrstr);
+ if (code < 0) {
+ subrstr->refcnt = 1;
+ pdfi_countdown(subrstr);
+ }
+ }
+ }
+ }
+ }
+ }
+
+ /* Check the charstrings index */
+ if (font->charstrings) {
+ p = pdfi_count_cff_index(font->charstrings, e, &font->ncharstrings);
+ if (!p || font->ncharstrings > 65535)
+ return gs_rethrow(-1, "cannot read charstrings index");
+ }
+ code = pdfi_object_alloc(ctx, PDF_DICT, font->ncharstrings, (pdf_obj **) &font->CharStrings);
+ if (code < 0)
+ return code;
+ pdfi_countup(font->CharStrings);
+
+ switch (offsets.charset_off) {
+ case 0:
+ charset_proc = iso_adobe_charset_proc;
+ break;
+ case 1:
+ charset_proc = expert_charset_proc;
+ break;
+ case 2:
+ charset_proc = expert_subset_charset_proc;
+ break;
+ default:{
+ switch ((int)font->cffdata[offsets.charset_off]) {
+ case 0:
+ charset_proc = format0_charset_proc;
+ break;
+ case 1:
+ charset_proc = format1_charset_proc;
+ break;
+ case 2:
+ charset_proc = format2_charset_proc;
+ break;
+ default:
+ return_error(gs_error_rangecheck);
+ }
+ }
+ }
+
+ if (offsets.have_ros) { /* CIDFont */
+ int fdarray_size;
+ bool topdict_matrix = offsets.have_matrix;
+ int (*fdselect_proc)(const byte *p, const byte *pe, unsigned int i);
+
+ p = pdfi_count_cff_index(font->cffdata + offsets.fdarray_off, e, &fdarray_size);
+ if (!p)
+ return gs_rethrow(-1, "cannot read charstrings index");
+
+ ptpriv->cidata.FDBytes = 1; /* Basically, always 1 just now */
+
+ ptpriv->cidata.FDArray = (gs_font_type1 **) gs_alloc_bytes(ctx->memory, fdarray_size * sizeof(gs_font_type1 *), "pdfi_read_cff(fdarray)");
+ if (!ptpriv->cidata.FDArray)
+ return_error(gs_error_VMerror);
+ ptpriv->cidata.FDArray_size = fdarray_size;
+
+ code = pdfi_object_alloc(ctx, PDF_ARRAY, fdarray_size, (pdf_obj **) &font->FDArray);
+ if (code < 0) {
+ gs_free_object(ctx->memory, ptpriv->cidata.FDArray, "pdfi_read_cff(fdarray)");
+ ptpriv->cidata.FDArray = NULL;
+ }
+ else {
+ pdfi_countup(font->FDArray);
+ code = 0;
+ for (i = 0; i < fdarray_size && code == 0; i++) {
+ byte *fddictp, *fddicte;
+ pdfi_gs_cff_font_priv fdptpriv = { 0 };
+ pdf_font_cff *pdffont = NULL;
+ gs_font_type1 *pt1font;
+
+ pdfi_init_cff_font_priv(ctx, &fdptpriv, font->cffdata, (font->cffend - font->cffdata) + 1, true);
+
+ offsets.private_off = 0;
+
+ p = pdfi_find_cff_index(font->cffdata + offsets.fdarray_off, e, i, &fddictp, &fddicte);
+ if (!p) {
+ ptpriv->cidata.FDArray[i] = NULL;
+ code = gs_note_error(gs_error_invalidfont);
+ continue;
+ }
+ if (fddicte > font->cffend)
+ fddicte = font->cffend;
+
+ code = pdfi_read_cff_dict(fddictp, fddicte, &fdptpriv, &offsets);
+ if (code < 0) {
+ ptpriv->cidata.FDArray[i] = NULL;
+ code = gs_note_error(gs_error_invalidfont);
+ continue;
+ }
+ code = pdfi_alloc_cff_font(ctx, &pdffont, 0, true);
+ if (code < 0) {
+ ptpriv->cidata.FDArray[i] = NULL;
+ code = gs_note_error(gs_error_invalidfont);
+ continue;
+ }
+ pt1font = (gs_font_type1 *) pdffont->pfont;
+ memcpy(pt1font, &fdptpriv, sizeof(pdfi_gs_cff_font_common_priv));
+ memcpy(&pt1font->data, &fdptpriv.type1data, sizeof(fdptpriv.type1data));
+ pt1font->base = (gs_font *) pdffont->pfont;
+
+ if (!topdict_matrix && offsets.have_matrix) {
+ gs_matrix newfmat, onekmat = { 1000, 0, 0, 1000, 0, 0 };
+ code = gs_matrix_multiply(&onekmat, &pt1font->FontMatrix, &newfmat);
+ memcpy(&pt1font->FontMatrix, &newfmat, sizeof(newfmat));
+ }
+
+ pt1font->FAPI = NULL;
+ pt1font->client_data = pdffont;
+
+ /* Check the subrs index */
+ pdffont->Subrs = NULL;
+ pdffont->subrs = fdptpriv.pdfcffpriv.subrs;
+ if (pdffont->subrs) {
+ p = pdfi_count_cff_index(pdffont->subrs, e, &pdffont->NumSubrs);
+ if (!p) {
+ pdffont->Subrs = NULL;
+ pdffont->NumSubrs = 0;
+ }
+ }
+
+ if (pdffont->NumSubrs > 0) {
+ code = pdfi_object_alloc(ctx, PDF_ARRAY, pdffont->NumSubrs, (pdf_obj **) &pdffont->Subrs);
+ if (code >= 0) {
+ int j;
+
+ pdffont->Subrs->refcnt = 1;
+ for (j = 0; j < pdffont->NumSubrs; j++) {
+ pdf_string *subrstr;
+
+ p = pdfi_find_cff_index(pdffont->subrs, e, j, &strp, &stre);
+ if (p) {
+ code = pdfi_object_alloc(ctx, PDF_STRING, stre - strp, (pdf_obj **) &subrstr);
+ if (code >= 0) {
+ memcpy(subrstr->data, strp, subrstr->length);
+ code = pdfi_array_put(ctx, pdffont->Subrs, (uint64_t) j, (pdf_obj *) subrstr);
+ if (code < 0) {
+ subrstr->refcnt = 1;
+ pdfi_countdown(subrstr);
+ }
+ }
+ }
+ }
+ }
+ }
+
+ pdffont->GlobalSubrs = font->GlobalSubrs;
+ pdffont->NumGlobalSubrs = font->NumGlobalSubrs;
+ pdfi_countup(pdffont->GlobalSubrs);
+ pdffont->CharStrings = font->CharStrings;
+ pdfi_countup(pdffont->CharStrings);
+ pt1font->data.subroutineNumberBias = subrbias(pdffont->NumSubrs);
+ pt1font->data.gsubrNumberBias = subrbias(pdffont->NumGlobalSubrs);
+
+ ptpriv->cidata.FDArray[i] = pt1font;
+ (void)pdfi_array_put(ctx, font->FDArray, i, (pdf_obj *) pdffont);
+ pdfi_countdown(pdffont);
+ }
+ if (code < 0) {
+ pdfi_countdown(font->FDArray);
+ font->FDArray = NULL;
+ for (i = 0; i < ptpriv->cidata.FDArray_size; i++) {
+ ptpriv->cidata.FDArray[i] = NULL;
+ }
+ }
+ else {
+ switch ((int)font->cffdata[offsets.fdselect_off]) {
+ case 0:
+ fdselect_proc = format0_fdselect_proc;
+ break;
+ case 3:
+ fdselect_proc = format3_fdselect_proc;
+ break;
+ default:
+ return_error(gs_error_rangecheck);
+ }
+
+ if (font->ncharstrings > 0) {
+ int maxcid = 0;
+ for (i = 0; i < font->ncharstrings; i++) {
+ int fd, g;
+ char gkey[64];
+ pdf_string *charstr;
+
+ fd = fdarray_size <= 1 ? 0 : (*fdselect_proc) (font->cffdata + offsets.fdselect_off + 1, font->cffend, i);
+
+ p = pdfi_find_cff_index(font->charstrings, font->cffend, i, &strp, &stre);
+ if (!p)
+ continue;
+
+ code = pdfi_object_alloc(ctx, PDF_STRING, (stre - strp) + 1, (pdf_obj **) &charstr);
+ if (code < 0)
+ continue;
+ charstr->data[0] = (byte) fd;
+ memcpy(charstr->data + 1, strp, charstr->length - 1);
+
+ if (i == 0) {
+ g = 0;
+ }
+ else {
+ g = (*charset_proc) (font->cffdata + offsets.charset_off + 1, font->cffend, i - 1);
+ }
+
+ if (g > maxcid) maxcid = g;
+ gs_snprintf(gkey, sizeof(gkey), "%d", g);
+ code = pdfi_dict_put(ctx, font->CharStrings, gkey, (pdf_obj *) charstr);
+ }
+ if (maxcid > ptpriv->pdfcffpriv.cidcount - 1)
+ ptpriv->pdfcffpriv.cidcount = maxcid + 1;
+ }
+ }
+ }
+ }
+ else {
+ code = pdfi_cff_build_encoding(ctx, ptpriv, &offsets, charset_proc);
+ }
+ return code;
+}
+
+static int
+pdfi_alloc_cff_cidfont(pdf_context *ctx, pdf_cidfont_type0 ** font, uint32_t obj_num)
+{
+ pdf_cidfont_type0 *cffcidfont = NULL;
+ gs_font_cid0 *pfont = NULL;
+ gs_matrix defmat = { 0.001f, 0.0f, 0.0f, 0.001f, 0.0f, 0.0f };
+
+ cffcidfont = (pdf_cidfont_type0 *) gs_alloc_bytes(ctx->memory, sizeof(pdf_cidfont_type0), "pdfi (cff pdf_cidfont_type0)");
+ if (cffcidfont == NULL)
+ return_error(gs_error_VMerror);
+
+ memset(cffcidfont, 0x00, sizeof(pdf_cidfont_type0));
+ cffcidfont->ctx = ctx;
+ cffcidfont->type = PDF_FONT;
+ cffcidfont->pdfi_font_type = e_pdf_cidfont_type0;
+
+#if REFCNT_DEBUG
+ cffcidfont->UID = ctx->UID++;
+ dmprintf2(ctx->memory, "Allocated object of type %c with UID %" PRIi64 "\n", cffcidfont->type,
+ cffcidfont->UID);
+#endif
+
+ pdfi_countup(cffcidfont);
+
+ pfont = (gs_font_cid0 *) gs_alloc_struct(ctx->memory, gs_font_cid0, &st_gs_font_cid0, "pdfi (cff cid pfont)");
+ if (pfont == NULL) {
+ pdfi_countdown(cffcidfont);
+ return_error(gs_error_VMerror);
+ }
+ memset(pfont, 0x00, sizeof(gs_font_cid0));
+
+ cffcidfont->pfont = (gs_font_base *) pfont;
+ memcpy(&pfont->orig_FontMatrix, &defmat, sizeof(defmat));
+ memcpy(&pfont->FontMatrix, &defmat, sizeof(defmat));
+ pfont->next = pfont->prev = 0;
+ pfont->memory = ctx->memory;
+ pfont->dir = ctx->font_dir;
+ pfont->is_resource = false;
+ gs_notify_init(&pfont->notify_list, ctx->memory);
+ pfont->base = (gs_font *) cffcidfont->pfont;
+ pfont->client_data = cffcidfont;
+ pfont->WMode = 0;
+ pfont->PaintType = 0;
+ pfont->StrokeWidth = 0;
+ pfont->is_cached = 0;
+ pfont->FAPI = NULL;
+ pfont->FAPI_font_data = NULL;
+ pfont->procs.init_fstack = gs_type0_init_fstack;
+ pfont->procs.next_char_glyph = gs_default_next_char_glyph;
+ pfont->FontType = ft_CID_encrypted;
+ pfont->ExactSize = fbit_use_outlines;
+ pfont->InBetweenSize = fbit_use_outlines;
+ pfont->TransformedChar = fbit_use_outlines;
+ /* We may want to do something clever with an XUID here */
+ pfont->id = gs_next_ids(ctx->memory, 1);
+ uid_set_invalid(&pfont->UID);
+
+ /* The buildchar proc will be filled in by FAPI -
+ we won't worry about working without FAPI */
+ pfont->procs.encode_char = pdfi_encode_char;
+ pfont->procs.glyph_name = ctx->get_glyph_name;
+ pfont->procs.decode_glyph = pdfi_decode_glyph;
+ pfont->procs.define_font = gs_no_define_font;
+ pfont->procs.make_font = gs_no_make_font;
+ pfont->procs.font_info = gs_default_font_info;
+ pfont->procs.glyph_info = gs_default_glyph_info;
+ pfont->procs.glyph_outline = pdfi_cff_glyph_outline;
+ pfont->procs.build_char = NULL;
+ pfont->procs.same_font = gs_default_same_font;
+ pfont->procs.enumerate_glyph = pdfi_cff_enumerate_glyph;
+
+ pfont->cidata.glyph_data = pdfi_cff_cid_glyph_data;
+
+ pfont->encoding_index = 1; /****** WRONG ******/
+ pfont->nearest_encoding_index = 1; /****** WRONG ******/
+
+ pfont->client_data = (void *)cffcidfont;
+
+ *font = cffcidfont;
+ return 0;
+}
+
+static int
+pdfi_alloc_cff_font(pdf_context *ctx, pdf_font_cff ** font, uint32_t obj_num, bool for_fdarray)
+{
+ pdf_font_cff *cfffont = NULL;
+ gs_font_type1 *pfont = NULL;
+ gs_matrix defmat_font = { 0.001f, 0.0f, 0.0f, 0.001f, 0.0f, 0.0f };
+ gs_matrix defmat_fd = { 1.00f, 0.0f, 0.0f, 1.000f, 0.0f, 0.0f };
+ gs_matrix *defmat = (for_fdarray ? &defmat_fd : &defmat_font);
+
+ cfffont = (pdf_font_cff *) gs_alloc_bytes(ctx->memory, sizeof(pdf_font_cff), "pdfi (cff pdf_font)");
+ if (cfffont == NULL)
+ return_error(gs_error_VMerror);
+
+ memset(cfffont, 0x00, sizeof(pdf_font_cff));
+ cfffont->ctx = ctx;
+ cfffont->type = PDF_FONT;
+ cfffont->pdfi_font_type = e_pdf_font_cff;
+
+#if REFCNT_DEBUG
+ cfffont->UID = ctx->UID++;
+ dmprintf2(ctx->memory, "Allocated object of type %c with UID %" PRIi64 "\n", cfffont->type,
+ cfffont->UID);
+#endif
+
+ pdfi_countup(cfffont);
+
+ pfont = (gs_font_type1 *) gs_alloc_struct(ctx->memory, gs_font_type1, &st_gs_font_type1, "pdfi (truetype pfont)");
+ if (pfont == NULL) {
+ pdfi_countdown(cfffont);
+ return_error(gs_error_VMerror);
+ }
+ memset(pfont, 0x00, sizeof(gs_font_type1));
+
+ cfffont->pfont = (gs_font_base *) pfont;
+ memcpy(&pfont->orig_FontMatrix, defmat, sizeof(*defmat));
+ memcpy(&pfont->FontMatrix, defmat, sizeof(*defmat));
+ pfont->next = pfont->prev = 0;
+ pfont->memory = ctx->memory;
+ pfont->dir = ctx->font_dir;
+ pfont->is_resource = false;
+ gs_notify_init(&pfont->notify_list, ctx->memory);
+ pfont->base = (gs_font *) cfffont->pfont;
+ pfont->client_data = cfffont;
+ pfont->WMode = 0;
+ pfont->PaintType = 0;
+ pfont->StrokeWidth = 0;
+ pfont->is_cached = 0;
+ pfont->FAPI = NULL;
+ pfont->FAPI_font_data = NULL;
+ pfont->procs.init_fstack = gs_default_init_fstack;
+ pfont->procs.next_char_glyph = gs_default_next_char_glyph;
+ pfont->FontType = ft_encrypted2;
+ pfont->ExactSize = fbit_use_outlines;
+ pfont->InBetweenSize = fbit_use_outlines;
+ pfont->TransformedChar = fbit_use_outlines;
+ /* We may want to do something clever with an XUID here */
+ pfont->id = gs_next_ids(ctx->memory, 1);
+ uid_set_invalid(&pfont->UID);
+
+ /* The buildchar proc will be filled in by FAPI -
+ we won't worry about working without FAPI */
+ pfont->procs.encode_char = pdfi_encode_char;
+ pfont->procs.glyph_name = ctx->get_glyph_name;
+ pfont->procs.decode_glyph = pdfi_decode_glyph;
+ pfont->procs.define_font = gs_no_define_font;
+ pfont->procs.make_font = gs_no_make_font;
+ pfont->procs.font_info = gs_default_font_info;
+ pfont->procs.glyph_info = gs_default_glyph_info;
+ pfont->procs.glyph_outline = pdfi_cff_glyph_outline;
+ pfont->procs.build_char = NULL;
+ pfont->procs.same_font = gs_default_same_font;
+ pfont->procs.enumerate_glyph = pdfi_cff_enumerate_glyph;
+
+ pfont->data.procs.glyph_data = for_fdarray ? pdfi_cff_fdarray_glyph_data : pdfi_cff_glyph_data;
+ pfont->data.procs.subr_data = pdfi_cff_subr_data;
+ pfont->data.procs.seac_data = for_fdarray ? pdfi_cff_fdarray_seac_data : pdfi_cff_seac_data;
+ pfont->data.procs.push_values = pdfi_cff_push;
+ pfont->data.procs.pop_value = pdfi_cff_pop;
+ pfont->data.interpret = gs_type2_interpret;
+ pfont->data.lenIV = -1;
+
+ pfont->encoding_index = 1; /****** WRONG ******/
+ pfont->nearest_encoding_index = 1; /****** WRONG ******/
+
+ pfont->client_data = (void *)cfffont;
+
+ *font = cfffont;
+ return 0;
+}
+
+static void
+pdfi_init_cff_font_priv(pdf_context *ctx, pdfi_gs_cff_font_priv *cffpriv,
+ byte *buf, int buflen, bool for_fdarray)
+{
+ gs_matrix defmat_font = { 0.001f, 0.0f, 0.0f, 0.001f, 0.0f, 0.0f };
+ gs_matrix defmat_fd = { 1.00f, 0.0f, 0.0f, 1.000f, 0.0f, 0.0f };
+ gs_matrix *defmat = (for_fdarray ? &defmat_fd : &defmat_font);
+
+ memset(cffpriv, 0x00, sizeof(pdfi_gs_cff_font_priv));
+
+ cffpriv->pdfcffpriv.ctx = ctx;
+ cffpriv->pdfcffpriv.type = PDF_FONT;
+ cffpriv->pdfcffpriv.pdfi_font_type = e_pdf_font_cff;
+ /* Dummy value for dummy object */
+ cffpriv->pdfcffpriv.refcnt = 0xf0f0f0f0;
+ cffpriv->pdfcffpriv.cffdata = buf;
+ cffpriv->pdfcffpriv.cffend = buf + buflen;
+ cffpriv->pdfcffpriv.cidcount = 8720;
+
+ memcpy(&cffpriv->orig_FontMatrix, defmat, sizeof(*defmat));
+ memcpy(&cffpriv->FontMatrix, defmat, sizeof(*defmat));
+ cffpriv->next = cffpriv->prev = 0;
+ cffpriv->memory = ctx->memory;
+ cffpriv->dir = ctx->font_dir;
+ cffpriv->is_resource = false;
+ gs_notify_init(&cffpriv->notify_list, ctx->memory);
+ cffpriv->WMode = 0;
+ cffpriv->PaintType = 0;
+ cffpriv->StrokeWidth = 0;
+ cffpriv->is_cached = 0;
+ cffpriv->FAPI = NULL;
+ cffpriv->FAPI_font_data = NULL;
+ cffpriv->procs.init_fstack = gs_default_init_fstack;
+ cffpriv->procs.next_char_glyph = gs_default_next_char_glyph;
+ cffpriv->FontType = ft_encrypted2;
+ cffpriv->ExactSize = fbit_use_outlines;
+ cffpriv->InBetweenSize = fbit_use_outlines;
+ cffpriv->TransformedChar = fbit_use_outlines;
+ /* We may want to do something clever with an XUID here */
+ cffpriv->id = gs_next_ids(ctx->memory, 1);
+ uid_set_invalid(&cffpriv->UID);
+
+
+ /* The buildchar proc will be filled in by FAPI -
+ we won't worry about working without FAPI */
+ cffpriv->procs.encode_char = pdfi_encode_char;
+ cffpriv->procs.glyph_name = ctx->get_glyph_name;
+ cffpriv->procs.decode_glyph = pdfi_decode_glyph;
+ cffpriv->procs.define_font = gs_no_define_font;
+ cffpriv->procs.make_font = gs_no_make_font;
+ cffpriv->procs.font_info = gs_default_font_info;
+ cffpriv->procs.glyph_info = gs_default_glyph_info;
+ cffpriv->procs.glyph_outline = pdfi_cff_glyph_outline;
+ cffpriv->procs.build_char = NULL;
+ cffpriv->procs.same_font = gs_default_same_font;
+ cffpriv->procs.enumerate_glyph = pdfi_cff_enumerate_glyph;
+
+ cffpriv->type1data.procs.glyph_data = pdfi_cff_glyph_data;
+ cffpriv->type1data.procs.subr_data = pdfi_cff_subr_data;
+ cffpriv->type1data.procs.seac_data = pdfi_cff_seac_data;
+ cffpriv->type1data.procs.push_values = pdfi_cff_push;
+ cffpriv->type1data.procs.pop_value = pdfi_cff_pop;
+ cffpriv->type1data.interpret = gs_type2_interpret;
+ cffpriv->type1data.lenIV = -1;
+
+ cffpriv->encoding_index = 1; /****** WRONG ******/
+ cffpriv->nearest_encoding_index = 1; /****** WRONG ******/
+}
+
+int
+pdfi_read_cff_font(pdf_context *ctx, pdf_dict *font_dict, pdf_dict *stream_dict, pdf_dict *page_dict, byte *pfbuf, int64_t fbuflen, bool forcecid, pdf_font **ppdffont)
+{
+ int code = 0;
+
+ pdf_font *ppdfont = NULL;
+ pdf_obj *basefont = NULL;
+ pdf_obj *tmp = NULL;
+ pdf_obj *fontdesc = NULL;
+ pdf_string *registry = NULL;
+ pdf_string *ordering = NULL;
+ byte *fbuf = pfbuf;
+
+ if (!memcmp(fbuf, "OTTO", 4)) {
+ int i, ntables = u16(fbuf + 4);
+ byte *p;
+ uint32_t toffs = 0, tlen = 0;
+
+ if (ntables > 64)
+ return_error(gs_error_invalidfont);
+
+ for (i = 0; i < ntables; i++) {
+ p = fbuf + 12 + i * 16;
+ if (p >= fbuf + fbuflen)
+ break;
+
+ if (!memcmp(p, "CFF ", 4)) {
+ toffs = u32(p + 8);
+ tlen = u32(p + 12);
+ break;
+ }
+ }
+ if (toffs == 0 || tlen == 0 || toffs + tlen > fbuflen) {
+ gs_free_object(ctx->memory, pfbuf, "pdfi_read_cff_font(fbuf)");
+ return_error(gs_error_invalidfont);
+ }
+ fbuf += toffs;
+ fbuflen = tlen;
+ }
+
+ code = pdfi_dict_knownget_type(ctx, font_dict, "FontDescriptor", PDF_DICT, &fontdesc);
+ if (code < 0) {
+ fontdesc = NULL;
+ }
+
+ /* Vestigial magic number check - we can't check the third byte, as we have out of
+ spec fonts that have a head size > 4
+ */
+ if (fbuf[0] == 1 && fbuf[1] == 0) {
+ pdfi_gs_cff_font_priv cffpriv;
+
+ if (code >= 0) {
+ pdfi_init_cff_font_priv(ctx, &cffpriv, fbuf, fbuflen, false);
+ cffpriv.forcecid = forcecid;
+ code = pdfi_read_cff(ctx, &cffpriv);
+ }
+ if (code >= 0) {
+ if (cffpriv.FontType == ft_CID_encrypted) {
+ pdf_obj *obj;
+ pdf_cidfont_type0 *cffcid;
+ gs_font_cid0 *pfont;
+
+ code = pdfi_alloc_cff_cidfont(ctx, &cffcid, font_dict->object_num);
+ pfont = (gs_font_cid0 *) cffcid->pfont;
+ ppdfont = (pdf_font *) cffcid;
+
+ memcpy(pfont, &cffpriv, sizeof(pdfi_gs_cff_font_common_priv));
+ memcpy(&pfont->cidata, &cffpriv.cidata, sizeof(pfont->cidata));
+
+ pfont->procs.glyph_outline = pdfi_cff_glyph_outline;
+ pfont->cidata.glyph_data = pdfi_cff_cid_glyph_data;
+
+ cffcid->orig_glyph_info = pfont->procs.glyph_info;
+ pfont->procs.glyph_info = pdfi_cff_cidfont_glyph_info;
+
+ pfont->cidata.proc_data = NULL;
+ pfont->FAPI = NULL;
+ pfont->base = (gs_font *) cffcid->pfont;
+
+ cffcid->registry = cffpriv.pdfcffpriv.registry;
+ cffcid->ordering = cffpriv.pdfcffpriv.ordering;
+ cffcid->supplement = cffpriv.pdfcffpriv.supplement;
+ cffcid->FontDescriptor = (pdf_dict *) fontdesc;
+ fontdesc = NULL;
+
+ cffcid->PDF_font = font_dict;
+ pdfi_countup(font_dict);
+
+ cffcid->cidtogidmap.data = NULL;
+ cffcid->cidtogidmap.size = 0;
+
+ pfont->cidata.common.CIDSystemInfo.Registry.data = cffcid->registry->data;
+ pfont->cidata.common.CIDSystemInfo.Registry.size = cffcid->registry->length;
+ pfont->cidata.common.CIDSystemInfo.Ordering.data = cffcid->ordering->data;
+ pfont->cidata.common.CIDSystemInfo.Ordering.size = cffcid->ordering->length;
+ pfont->cidata.common.CIDSystemInfo.Supplement = cffcid->supplement;
+ pfont->client_data = cffcid;
+
+ cffcid->object_num = font_dict->object_num;
+ cffcid->generation_num = font_dict->generation_num;
+ cffcid->indirect_num = font_dict->indirect_num;
+ cffcid->indirect_gen = font_dict->indirect_gen;
+ cffcid->PDF_font = font_dict;
+ pdfi_countup(font_dict);
+ cffcid->CharStrings = cffpriv.pdfcffpriv.CharStrings;
+ cffpriv.pdfcffpriv.CharStrings = NULL;
+
+ cffcid->Subrs = cffpriv.pdfcffpriv.Subrs;
+ cffcid->NumSubrs = cffpriv.pdfcffpriv.NumSubrs;
+ cffpriv.pdfcffpriv.Subrs = NULL;
+
+ cffcid->GlobalSubrs = cffpriv.pdfcffpriv.GlobalSubrs;
+ cffcid->NumGlobalSubrs = cffpriv.pdfcffpriv.NumGlobalSubrs;
+ cffpriv.pdfcffpriv.GlobalSubrs = NULL;
+
+ cffcid->FDArray = cffpriv.pdfcffpriv.FDArray;
+ cffpriv.pdfcffpriv.FDArray = NULL;
+
+ pfont->cidata.common.CIDCount = cffpriv.pdfcffpriv.cidcount;
+
+ cffcid->cidtogidmap.data = NULL;
+ cffcid->cidtogidmap.size = 0;
+ code = pdfi_dict_knownget(ctx, font_dict, "CIDToGIDMap", (pdf_obj **) &obj);
+ if (code > 0) {
+ /* CIDToGIDMap can only be a stream or a name, and if it's a name
+ it's only permitted to be "/Identity", so ignore it
+ */
+ int64_t size = 0;
+ if (obj->type == PDF_STREAM) {
+ code = pdfi_stream_to_buffer(ctx, (pdf_stream *) obj, &(cffcid->cidtogidmap.data), &size);
+ }
+ pdfi_countdown(obj);
+ obj = NULL;
+ cffcid->cidtogidmap.size = size;
+
+ if (size > 0) {
+ pfont->cidata.common.CIDCount = size >> 1;
+ }
+ }
+ pfont->cidata.common.MaxCID = pfont->cidata.common.CIDCount - 1;
+
+ code = pdfi_dict_knownget_type(ctx, font_dict, "DW", PDF_INT, (pdf_obj **) &obj);
+ if (code > 0) {
+ cffcid->DW = ((pdf_num *) obj)->value.i;
+ pdfi_countdown(obj);
+ obj = NULL;
+ }
+ else {
+ cffcid->DW = 1000;
+ }
+ code = pdfi_dict_knownget_type(ctx, font_dict, "DW2", PDF_ARRAY, (pdf_obj **) &obj);
+ if (code > 0) {
+ cffcid->DW2 = (pdf_array *) obj;
+ obj = NULL;
+ }
+ else {
+ cffcid->DW2 = NULL;
+ }
+ code = pdfi_dict_knownget_type(ctx, font_dict, "W", PDF_ARRAY, (pdf_obj **) &obj);
+ if (code > 0) {
+ cffcid->W = (pdf_array *) obj;
+ obj = NULL;
+ }
+ else {
+ cffcid->W = NULL;
+ }
+ code = pdfi_dict_knownget_type(ctx, font_dict, "W2", PDF_ARRAY, (pdf_obj **) &obj);
+ if (code > 0) {
+ cffcid->W2 = (pdf_array *) obj;
+ obj = NULL;
+ }
+ else {
+ cffcid->W2 = NULL;
+ }
+ code = pdfi_font_generate_pseudo_XUID(ctx, font_dict, (gs_font_base *)cffcid->pfont);
+ if (code < 0)
+ uid_set_invalid(&cffcid->pfont->UID);
+ }
+ else if (forcecid) {
+ pdf_obj *obj;
+ pdf_cidfont_type0 *cffcid;
+ gs_font_cid0 *pfont;
+ pdf_font_cff *fdcfffont;
+ gs_font_type1 *pfdfont = NULL;
+ static const char *const reg = "Adobe";
+ static const char *const ord = "Identity";
+
+ code = pdfi_object_alloc(ctx, PDF_STRING, strlen(reg), (pdf_obj **) &registry);
+ if (code < 0)
+ goto error;
+ pdfi_countup(registry);
+
+ code = pdfi_object_alloc(ctx, PDF_STRING, strlen(ord), (pdf_obj **) &ordering);
+ if (code < 0) {
+ goto error;
+ }
+ pdfi_countup(ordering);
+
+ memcpy(registry->data, reg, strlen(reg));
+ registry->length = strlen(reg);
+ memcpy(ordering->data, ord, strlen(ord));
+ ordering->length = strlen(ord);
+
+ code = pdfi_alloc_cff_font(ctx, &fdcfffont, 0, true);
+ if (code < 0)
+ goto error;
+
+ pfdfont = (gs_font_type1 *) fdcfffont->pfont;
+
+ code = pdfi_alloc_cff_cidfont(ctx, &cffcid, 0);
+ if (code < 0) {
+ gs_free_object(ctx->memory, fdcfffont, "pdfi_read_cff_font");
+ gs_free_object(ctx->memory, pfdfont, "pdfi_read_cff_font");
+ goto error;
+ }
+ ppdfont = (pdf_font *) cffcid;
+
+ code = pdfi_object_alloc(ctx, PDF_ARRAY, 1, (pdf_obj **) &cffcid->FDArray);
+ if (code < 0)
+ goto error;
+ pdfi_countup(cffcid->FDArray);
+
+ pfont = (gs_font_cid0 *) cffcid->pfont;
+ pfont->cidata.FDArray = (gs_font_type1 **) gs_alloc_bytes(ctx->memory, sizeof(gs_font_type1 *), "pdfi_read_cff_font");
+ pfont->base = (gs_font *)pfont;
+ if (!pfont->cidata.FDArray) {
+ pdfi_countdown(cffcid->FDArray);
+ gs_free_object(ctx->memory, fdcfffont, "pdfi_read_cff_font");
+ gs_free_object(ctx->memory, pfdfont, "pdfi_read_cff_font");
+ gs_free_object(ctx->memory, cffcid, "pdfi_read_cff_font");
+ gs_free_object(ctx->memory, pfont, "pdfi_read_cff_font");
+ goto error;
+ }
+
+ memcpy(pfdfont, &cffpriv, sizeof(pdfi_gs_cff_font_common_priv));
+ memcpy(&pfdfont->data, &cffpriv.type1data, sizeof(pfdfont->data));
+
+
+ pfont->procs.glyph_outline = pdfi_cff_glyph_outline;
+ pfont->cidata.glyph_data = pdfi_cff_cid_glyph_data;
+ pfont->cidata.common.CIDCount = cffpriv.pdfcffpriv.CharStrings->entries;
+ pfont->cidata.common.MaxCID = pfont->cidata.common.CIDCount - 1;
+
+ cffcid->orig_glyph_info = pfont->procs.glyph_info;
+ pfont->procs.glyph_info = pdfi_cff_cidfont_glyph_info;
+
+ pfdfont->FAPI = NULL;
+ pfdfont->base = (gs_font *)pfdfont;
+ pfdfont->client_data = fdcfffont;
+ pdfi_array_put(ctx, cffcid->FDArray, 0, (pdf_obj *) fdcfffont);
+
+ fdcfffont->object_num = 0;
+ fdcfffont->generation_num = 0;
+ fdcfffont->PDF_font = font_dict;
+ pdfi_countup(font_dict);
+ (void)pdfi_dict_knownget_type(ctx, font_dict, "BaseFont", PDF_NAME, &basefont);
+ fdcfffont->BaseFont = basefont;
+ fdcfffont->Name = basefont;
+ pdfi_countup(basefont);
+
+ pdfi_countdown(cffpriv.pdfcffpriv.Encoding);
+ cffpriv.pdfcffpriv.Encoding = NULL;
+
+ fdcfffont->CharStrings = cffpriv.pdfcffpriv.CharStrings;
+ fdcfffont->Subrs = cffpriv.pdfcffpriv.Subrs;
+ fdcfffont->NumSubrs = cffpriv.pdfcffpriv.NumSubrs;
+ fdcfffont->GlobalSubrs = cffpriv.pdfcffpriv.GlobalSubrs;
+ fdcfffont->NumGlobalSubrs = cffpriv.pdfcffpriv.NumGlobalSubrs;
+
+ cffcid->CharStrings = fdcfffont->CharStrings;
+ pdfi_countup(cffcid->CharStrings);
+ cffcid->Subrs = fdcfffont->Subrs;
+ pdfi_countup(cffcid->Subrs);
+ cffcid->GlobalSubrs = fdcfffont->GlobalSubrs;
+ pdfi_countup(cffcid->GlobalSubrs);
+ pdfi_countdown(fdcfffont);
+
+ cffcid->FontDescriptor = (pdf_dict *) fontdesc;
+ fontdesc = NULL;
+
+ cffcid->PDF_font = font_dict;
+ pdfi_countup(font_dict);
+
+ cffcid->registry = registry;
+ cffcid->ordering = ordering;
+ registry = ordering = NULL;
+ cffcid->supplement = 0;
+
+ /* Because we're faking a CIDFont, we want to move the scaling to the "parent" fake
+ CIDFont, and make the FDArrray use identity scaling
+ */
+ memcpy(&pfont->FontMatrix, &pfdfont->FontMatrix, sizeof(pfdfont->FontMatrix));
+ memcpy(&pfont->orig_FontMatrix, &pfdfont->orig_FontMatrix, sizeof(pfdfont->orig_FontMatrix));
+
+ gs_make_identity(&pfdfont->FontMatrix);
+ gs_make_identity(&pfdfont->orig_FontMatrix);
+
+ pfont->cidata.CIDMapOffset = 0;
+ pfont->cidata.FDArray_size = 1;
+ pfont->cidata.FDBytes = 0;
+ pfont->cidata.glyph_data = pdfi_cff_cid_glyph_data;
+ pfont->cidata.FDArray[0] = pfdfont;
+ pfont->cidata.common.CIDSystemInfo.Registry.data = cffcid->registry->data;
+ pfont->cidata.common.CIDSystemInfo.Registry.size = cffcid->registry->length;
+ pfont->cidata.common.CIDSystemInfo.Ordering.data = cffcid->ordering->data;
+ pfont->cidata.common.CIDSystemInfo.Ordering.size = cffcid->ordering->length;
+ pfont->cidata.common.CIDSystemInfo.Supplement = cffcid->supplement;
+ pfont->client_data = cffcid;
+
+ cffcid->object_num = font_dict->object_num;
+ cffcid->generation_num = font_dict->generation_num;
+ cffcid->indirect_num = font_dict->indirect_num;
+ cffcid->indirect_gen = font_dict->indirect_gen;
+ cffcid->PDF_font = font_dict;
+ pdfi_countup(font_dict);
+ cffcid->CharStrings = cffpriv.pdfcffpriv.CharStrings;
+ cffcid->Subrs = cffpriv.pdfcffpriv.Subrs;
+ cffcid->GlobalSubrs = cffpriv.pdfcffpriv.GlobalSubrs;
+
+ cffcid->cidtogidmap.data = NULL;
+ cffcid->cidtogidmap.size = 0;
+ code = pdfi_dict_knownget(ctx, font_dict, "CIDToGIDMap", (pdf_obj **) &obj);
+ if (code > 0) {
+ /* CIDToGIDMap can only be a stream or a name, and if it's a name
+ it's only permitted to be "/Identity", so ignore it
+ */
+ int64_t size = 0;
+ if (obj->type == PDF_STREAM) {
+ code = pdfi_stream_to_buffer(ctx, (pdf_stream *) obj, &(cffcid->cidtogidmap.data), (int64_t *) &size);
+ }
+ pdfi_countdown(obj);
+ obj = NULL;
+ cffcid->cidtogidmap.size = size;
+ if (size > 0) {
+ pfont->cidata.common.CIDCount = size >> 1;
+ }
+ }
+ pfont->cidata.common.MaxCID = pfont->cidata.common.CIDCount - 1;
+
+ code = pdfi_dict_knownget_type(ctx, font_dict, "DW", PDF_INT, (pdf_obj **) &obj);
+ if (code > 0) {
+ cffcid->DW = ((pdf_num *) obj)->value.i;
+ pdfi_countdown(obj);
+ obj = NULL;
+ }
+ else {
+ cffcid->DW = 1000;
+ }
+ code = pdfi_dict_knownget_type(ctx, font_dict, "DW2", PDF_ARRAY, (pdf_obj **) &obj);
+ if (code > 0) {
+ cffcid->DW2 = (pdf_array *) obj;
+ obj = NULL;
+ }
+ else {
+ cffcid->DW2 = NULL;
+ }
+ code = pdfi_dict_knownget_type(ctx, font_dict, "W", PDF_ARRAY, (pdf_obj **) &obj);
+ if (code > 0) {
+ cffcid->W = (pdf_array *) obj;
+ obj = NULL;
+ }
+ else {
+ cffcid->W = NULL;
+ }
+ code = pdfi_dict_knownget_type(ctx, font_dict, "W2", PDF_ARRAY, (pdf_obj **) &obj);
+ if (code > 0) {
+ cffcid->W2 = (pdf_array *) obj;
+ obj = NULL;
+ }
+ else {
+ cffcid->W2 = NULL;
+ }
+
+ code = pdfi_font_generate_pseudo_XUID(ctx, cffcid->PDF_font, ppdfont->pfont);
+ if (code < 0)
+ goto error;
+
+ }
+ else {
+ pdf_font_cff *cfffont;
+ gs_font_type1 *pfont = NULL;
+
+ code = pdfi_alloc_cff_font(ctx, &cfffont, font_dict->object_num, false);
+ pfont = (gs_font_type1 *) cfffont->pfont;
+ ppdfont = (pdf_font *) cfffont;
+
+ memcpy(pfont, &cffpriv, sizeof(pdfi_gs_cff_font_common_priv));
+ memcpy(&pfont->data, &cffpriv.type1data, sizeof(pfont->data));
+ pfont->FAPI = NULL;
+ pfont->client_data = cfffont;
+ pfont->base = (gs_font *) cfffont->pfont;
+
+ pfont->procs.glyph_info = pdfi_cff_glyph_info;
+
+ cfffont->object_num = font_dict->object_num;
+ cfffont->generation_num = font_dict->generation_num;
+ cfffont->PDF_font = font_dict;
+ pdfi_countup(font_dict);
+ (void)pdfi_dict_knownget_type(ctx, font_dict, "BaseFont", PDF_NAME, &basefont);
+ cfffont->BaseFont = basefont;
+ cfffont->Name = basefont;
+ pdfi_countup(basefont);
+
+ cfffont->CharStrings = cffpriv.pdfcffpriv.CharStrings;
+ cffpriv.pdfcffpriv.CharStrings = NULL;
+
+ cfffont->Subrs = cffpriv.pdfcffpriv.Subrs;
+ cfffont->NumSubrs = cffpriv.pdfcffpriv.NumSubrs;
+ cffpriv.pdfcffpriv.Subrs = NULL;
+
+ cfffont->GlobalSubrs = cffpriv.pdfcffpriv.GlobalSubrs;
+ cfffont->NumGlobalSubrs = cffpriv.pdfcffpriv.NumGlobalSubrs;
+ cffpriv.pdfcffpriv.GlobalSubrs = NULL;
+
+ cfffont->FontDescriptor = (pdf_dict *) fontdesc;
+ fontdesc = NULL;
+
+ cfffont->PDF_font = font_dict;
+ pdfi_countup(font_dict);
+
+ cfffont->descflags = 0;
+ if (cfffont->FontDescriptor != NULL) {
+ code = pdfi_dict_get_int(ctx, cfffont->FontDescriptor, "Flags", &cfffont->descflags);
+ if (code >= 0) {
+ /* If both the symbolic and non-symbolic flag are set,
+ believe that latter.
+ */
+ if ((cfffont->descflags & 32) != 0)
+ cfffont->descflags = (cfffont->descflags & ~4);
+ }
+ }
+ /* ZapfDingbats and Symbol we just have to know are symbolic */
+ if (pdfi_font_known_symbolic(basefont)) {
+ cfffont->descflags |= 4;
+ }
+
+ code = pdfi_dict_knownget_type(ctx, font_dict, "FirstChar", PDF_INT, &tmp);
+ if (code == 1) {
+ cfffont->FirstChar = ((pdf_num *) tmp)->value.i;
+ pdfi_countdown(tmp);
+ tmp = NULL;
+ }
+ else {
+ cfffont->FirstChar = 0;
+ }
+ code = pdfi_dict_knownget_type(ctx, font_dict, "LastChar", PDF_INT, &tmp);
+ if (code == 1) {
+ cfffont->LastChar = ((pdf_num *) tmp)->value.i;
+ pdfi_countdown(tmp);
+ tmp = NULL;
+ }
+ else {
+ cfffont->LastChar = 255;
+ }
+
+ cfffont->fake_glyph_names = (gs_string *) gs_alloc_bytes(ctx->memory, cfffont->LastChar * sizeof(gs_string), "pdfi_read_cff_font: fake_glyph_names");
+ if (!cfffont->fake_glyph_names) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+ memset(cfffont->fake_glyph_names, 0x00, cfffont->LastChar * sizeof(gs_string));
+ code = pdfi_dict_knownget_type(ctx, font_dict, "Widths", PDF_ARRAY, &tmp);
+ if (code > 0) {
+ int i;
+ double x_scale;
+ int num_chars = cfffont->LastChar - cfffont->FirstChar + 1;
+
+ if (num_chars != pdfi_array_size((pdf_array *) tmp)) {
+ pdfi_countdown(tmp);
+ code = gs_note_error(gs_error_rangecheck);
+ goto error;
+ }
+
+ cfffont->Widths = (double *)gs_alloc_bytes(ctx->memory, sizeof(double) * num_chars, "Type 1C font Widths array");
+ if (cfffont->Widths == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+ memset(cfffont->Widths, 0x00, sizeof(double) * num_chars);
+
+ /* Widths are defined assuming a 1000x1000 design grid, but we apply
+ * them in font space - so undo the 1000x1000 scaling, and apply
+ * the inverse of the font's x scaling
+ */
+ x_scale = 0.001 / hypot(pfont->FontMatrix.xx, pfont->FontMatrix.xy);
+
+ for (i = 0; i < num_chars; i++) {
+ code = pdfi_array_get_number(ctx, (pdf_array *) tmp, (uint64_t) i, &cfffont->Widths[i]);
+ if (code < 0)
+ goto error;
+ cfffont->Widths[i] *= x_scale;
+ }
+ }
+ pdfi_countdown(tmp);
+
+ tmp = NULL;
+ code = pdfi_dict_knownget(ctx, font_dict, "Encoding", &tmp);
+ if (code == 1) {
+ if ((cfffont->descflags & 4) != 0 && tmp->type == PDF_DICT) {
+ code = pdfi_create_Encoding(ctx, tmp, (pdf_obj *)cffpriv.pdfcffpriv.Encoding, (pdf_obj **) &cfffont->Encoding);
+ if (code >= 0) {
+ pdfi_countdown(cffpriv.pdfcffpriv.Encoding);
+ cffpriv.pdfcffpriv.Encoding = NULL;
+ code = 1;
+ }
+ }
+ else if ((tmp->type == PDF_NAME || tmp->type == PDF_DICT)) {
+ code = pdfi_create_Encoding(ctx, tmp, NULL, (pdf_obj **) &cfffont->Encoding);
+ if (code >= 0) {
+ pdfi_countdown(cffpriv.pdfcffpriv.Encoding);
+ cffpriv.pdfcffpriv.Encoding = NULL;
+ code = 1;
+ }
+ }
+ else
+ code = gs_error_undefined;
+ pdfi_countdown(tmp);
+ tmp = NULL;
+ }
+ else {
+ pdfi_countdown(tmp);
+ tmp = NULL;
+ code = 0;
+ }
+ if (code <= 0) {
+ cfffont->Encoding = cffpriv.pdfcffpriv.Encoding;
+ cffpriv.pdfcffpriv.Encoding = NULL;
+ }
+
+ code = pdfi_dict_knownget(ctx, font_dict, "ToUnicode", &tmp);
+ if (code == 1) {
+ cfffont->ToUnicode = tmp;
+ tmp = NULL;
+ }
+ else {
+ cfffont->ToUnicode = NULL;
+ }
+ }
+ }
+ error:
+ if (code < 0) {
+ pdfi_countdown(cffpriv.pdfcffpriv.Subrs);
+ pdfi_countdown(cffpriv.pdfcffpriv.GlobalSubrs);
+ pdfi_countdown(cffpriv.pdfcffpriv.CharStrings);
+ pdfi_countdown(cffpriv.pdfcffpriv.CIDSystemInfo);
+ pdfi_countdown(cffpriv.pdfcffpriv.W);
+ pdfi_countdown(cffpriv.pdfcffpriv.DW2);
+ pdfi_countdown(cffpriv.pdfcffpriv.W2);
+ pdfi_countdown(cffpriv.pdfcffpriv.FDArray);
+ pdfi_countdown(cffpriv.pdfcffpriv.registry);
+ pdfi_countdown(cffpriv.pdfcffpriv.ordering);
+ pdfi_countdown(cffpriv.pdfcffpriv.Encoding);
+ if (cffpriv.FontType == ft_CID_encrypted) {
+ gs_free_object(ctx->memory, cffpriv.cidata.FDArray, "pdfi_read_cff_font(gs_font FDArray, error)");
+ }
+ }
+ if (code >= 0) {
+ code = gs_definefont(ctx->font_dir, (gs_font *) ppdfont->pfont);
+ if (code < 0) {
+ goto error;
+ }
+
+ code = pdfi_fapi_passfont((pdf_font *) ppdfont, 0, NULL, NULL, NULL, 0);
+ if (code < 0) {
+ goto error;
+ }
+ /* object_num can be zero if the dictionary was defined inline */
+ if (ppdfont->object_num != 0) {
+ code = replace_cache_entry(ctx, (pdf_obj *) ppdfont);
+ if (code < 0)
+ goto error;
+ }
+ *ppdffont = (pdf_font *) ppdfont;
+ ppdfont = NULL;
+ }
+ }
+ gs_free_object(ctx->memory, pfbuf, "pdfi_read_cff_font(fbuf)");
+ pdfi_countdown(ppdfont);
+ pdfi_countdown(fontdesc);
+ pdfi_countdown(ordering);
+ pdfi_countdown(registry);
+
+ if (code < 0) {
+ *ppdffont = NULL;
+ return_error(gs_error_invalidfont);
+ }
+
+ return code;
+}
+
+int
+pdfi_read_type1C_font(pdf_context *ctx, pdf_dict *font_dict,
+ pdf_dict *stream_dict, pdf_dict *page_dict, pdf_font **ppdffont)
+{
+ int code;
+ pdf_obj *fontdesc = NULL;
+ pdf_obj *fontfile = NULL;
+ byte *fbuf;
+ int64_t fbuflen;
+
+ code = pdfi_dict_knownget_type(ctx, font_dict, "FontDescriptor", PDF_DICT, &fontdesc);
+
+ if (code >=0 && fontdesc != NULL) {
+ code = pdfi_dict_get_type(ctx, (pdf_dict *) fontdesc, "FontFile", PDF_STREAM, &fontfile);
+
+ if (code < 0)
+ code = pdfi_dict_get_type(ctx, (pdf_dict *) fontdesc, "FontFile2", PDF_STREAM, &fontfile);
+
+ if (code < 0)
+ code = pdfi_dict_get_type(ctx, (pdf_dict *) fontdesc, "FontFile3", PDF_STREAM, &fontfile);
+ }
+ pdfi_countdown(fontdesc);
+
+ if (code >= 0 && fontfile != NULL) {
+ code = pdfi_stream_to_buffer(ctx, (pdf_stream *) fontfile, &fbuf, &fbuflen);
+ pdfi_countdown(fontfile);
+ }
+ else {
+ /* TODO - handle non-emebedded case */
+ return_error(gs_error_invalidfont);
+ }
+
+ code = pdfi_read_cff_font(ctx, stream_dict, page_dict, font_dict, fbuf, fbuflen, false, ppdffont);
+
+ return code;
+}
+
+int
+pdfi_free_font_cff(pdf_obj *font)
+{
+ pdf_font_cff *pdfontcff = (pdf_font_cff *) font;
+
+ gs_free_object(OBJ_MEMORY(font), pdfontcff->pfont, "pdfi_free_font_cff(pfont)");
+
+ pdfi_countdown(pdfontcff->PDF_font);
+ pdfi_countdown(pdfontcff->BaseFont);
+ pdfi_countdown(pdfontcff->Name);
+ pdfi_countdown(pdfontcff->FontDescriptor);
+ pdfi_countdown(pdfontcff->CharStrings);
+ pdfi_countdown(pdfontcff->Subrs);
+ pdfi_countdown(pdfontcff->GlobalSubrs);
+ pdfi_countdown(pdfontcff->Encoding);
+ pdfi_countdown(pdfontcff->ToUnicode);
+
+ gs_free_object(OBJ_MEMORY(font), pdfontcff->fake_glyph_names, "Type 2 fake_glyph_names");
+ gs_free_object(OBJ_MEMORY(font), pdfontcff->Widths, "Type 2 fontWidths");
+ gs_free_object(OBJ_MEMORY(font), pdfontcff, "pdfi_free_font_cff(pbfont)");
+
+ return 0;
+}
+
+int
+pdfi_free_font_cidtype0(pdf_obj *font)
+{
+ pdf_cidfont_type0 *pdfont0 = (pdf_cidfont_type0 *) font;
+ gs_font_cid0 *pfont = (gs_font_cid0 *) pdfont0->pfont;
+
+ /* Only have to free the FDArray memory here. Each gs_font in the array is
+ referenced by a pdfi font, reference by pdfont0->FDArray. Freeing that
+ array will free each pdfi font, freeing the pdfi font will free the gs_font.
+ gs_fonts are not reference counted
+ */
+ gs_free_object(OBJ_MEMORY(font), pfont->cidata.FDArray, "pdfi_free_font_cidtype0(pfont->fdarray)");
+ gs_free_object(OBJ_MEMORY(font), pdfont0->pfont, "pdfi_free_font_cff(pfont)");
+
+ pdfi_countdown(pdfont0->PDF_font);
+ pdfi_countdown(pdfont0->BaseFont);
+ pdfi_countdown(pdfont0->FontDescriptor);
+ pdfi_countdown(pdfont0->CharStrings);
+ pdfi_countdown(pdfont0->Subrs);
+ pdfi_countdown(pdfont0->GlobalSubrs);
+ pdfi_countdown(pdfont0->CIDSystemInfo);
+ pdfi_countdown(pdfont0->W);
+ pdfi_countdown(pdfont0->DW2);
+ pdfi_countdown(pdfont0->W2);
+ pdfi_countdown(pdfont0->FDArray);
+ pdfi_countdown(pdfont0->registry);
+ pdfi_countdown(pdfont0->ordering);
+
+ gs_free_object(OBJ_MEMORY(font), pdfont0->cidtogidmap.data, "pdfi_free_font_cff(cidtogidmap.data)");
+ gs_free_object(OBJ_MEMORY(font), pdfont0, "pdfi_free_font_cff(pbfont)");
+
+ return 0;
+}
diff --git a/pdf/pdf_font1C.h b/pdf/pdf_font1C.h
new file mode 100644
index 00000000..e02b6342
--- /dev/null
+++ b/pdf/pdf_font1C.h
@@ -0,0 +1,28 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* CFF (Type 1C) font handling routines */
+
+#ifndef PDF_TYPE1C_FONT
+#define PDF_TYPE1C_FONT
+int pdfi_read_type1C_font(pdf_context *ctx, pdf_dict *font_dict, pdf_dict *stream_dict, pdf_dict *page_dict, pdf_font **ppdffont);
+int pdfi_cff_global_glyph_code(const gs_font *pfont, gs_const_string *gstr, gs_glyph *pglyph);
+int pdfi_free_font_cff(pdf_obj *font);
+
+int pdfi_read_cff_font(pdf_context *ctx, pdf_dict *font_dict, pdf_dict *stream_dict, pdf_dict *page_dict, byte *pfbuf, int64_t fbuflen, bool forcecid, pdf_font **ppdffont);
+
+int pdfi_free_font_cidtype0(pdf_obj *font);
+
+#endif
diff --git a/pdf/pdf_font3.c b/pdf/pdf_font3.c
new file mode 100644
index 00000000..155d8be5
--- /dev/null
+++ b/pdf/pdf_font3.c
@@ -0,0 +1,334 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* code for type 3 font handling */
+
+#include "pdf_int.h"
+#include "pdf_stack.h"
+#include "pdf_array.h"
+#include "pdf_dict.h"
+#include "pdf_gstate.h"
+#include "pdf_font.h"
+#include "pdf_font3.h"
+#include "pdf_font_types.h"
+#include "pdf_deref.h"
+#include "gscencs.h"
+#include "gscedata.h" /* For the encoding arrays */
+#include "gsccode.h" /* For the Encoding indices */
+#include "gsuid.h" /* For no_UniqueID */
+#include "gsutil.h" /* For gs_next_ids() */
+
+static void pdfi_type3_copy_color(gs_gstate_color *src, gs_gstate_color *dest)
+{
+ *dest->ccolor = *src->ccolor;
+ *dest->dev_color = *src->dev_color;
+ dest->color_space = src->color_space;
+ dest->effective_opm = src->effective_opm;
+}
+
+static int
+pdfi_type3_build_char(gs_show_enum * penum, gs_gstate * pgs, gs_font * pfont,
+ gs_char chr, gs_glyph glyph)
+{
+ int code = 0;
+ pdf_font_type3 *font;
+ pdf_name *GlyphName = NULL;
+ pdf_stream *CharProc = NULL;
+ int SavedTextBlockDepth = 0;
+ char Notdef[8] = {".notdef"};
+
+ font = (pdf_font_type3 *)pfont->client_data;
+
+ SavedTextBlockDepth = OBJ_CTX(font)->text.BlockDepth;
+ code = pdfi_array_get(OBJ_CTX(font), font->Encoding, (uint64_t)chr, (pdf_obj **)&GlyphName);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_get_by_key(OBJ_CTX(font), font->CharProcs, GlyphName, (pdf_obj **)&CharProc);
+ if (code == gs_error_undefined) {
+ byte *Key = NULL;
+ /* Can't find the named glyph, try to find a /.notdef as a substitute */
+ Key = gs_alloc_bytes(OBJ_MEMORY(font), 8, "working buffer for BuildChar");
+ if (Key == NULL)
+ goto build_char_error;
+ memset(Key, 0x00, 8);
+ memcpy(Key, Notdef, 8);
+ code = pdfi_dict_get(OBJ_CTX(font), font->CharProcs, (const char *)Key, (pdf_obj **)&CharProc);
+ gs_free_object(OBJ_MEMORY(font), Key, "working buffer for BuildChar");
+ if (code == gs_error_undefined) {
+ code = 0;
+ goto build_char_error;
+ }
+ }
+ if (code < 0)
+ goto build_char_error;
+ if (CharProc->type != PDF_STREAM) {
+ code = gs_note_error(gs_error_typecheck);
+ goto build_char_error;
+ }
+
+ OBJ_CTX(font)->text.BlockDepth = 0;
+ OBJ_CTX(font)->text.inside_CharProc = true;
+ OBJ_CTX(font)->text.CharProc_is_d1 = false;
+
+ {
+ /* It turns out that if a type 3 font uses a stroke to draw, and does not
+ * acrually set the stroke colour, then we must use the fill colour instead.
+ * In effect we start a type 3 BuildChar with stroke colour = fill colour.
+ * That is annoyingly difficult to set up. We need to copy the existing
+ * colour values from the structures in the gs_gstate_color structures into
+ * temporary copies and copy the colour space pointer (and keep its reference
+ * count correct). Then copy the fill colour values and ponter to the stroke
+ * structures. Finally, after drawing the character, copy the temporary
+ * saved copies back again.
+ */
+ gs_gstate_color tmp_color;
+ gs_client_color tmp_cc;
+ gx_device_color tmp_dc;
+
+ /* Set up the pointers in the gs_gstate_color structure to point to
+ * the temporary structures we have on the stack.
+ */
+ tmp_color.ccolor = &tmp_cc;
+ tmp_color.dev_color = &tmp_dc;
+
+ /* Use the utility routine above to copy the stroke colour to the temporary copy */
+ pdfi_type3_copy_color(&OBJ_CTX(font)->pgs->color[1], &tmp_color);
+ rc_increment_cs(tmp_color.color_space);
+ /* Use the utility routine above to copy the fill colour to the stroke colour */
+ pdfi_type3_copy_color(&OBJ_CTX(font)->pgs->color[0], &OBJ_CTX(font)->pgs->color[1]);
+
+ pdfi_gsave(OBJ_CTX(font));
+ pdfi_run_context(OBJ_CTX(font), CharProc, font->PDF_font, true, "CharProc");
+ pdfi_grestore(OBJ_CTX(font));
+
+ /* Use the utility routine above to copy the temporary copy to the stroke colour */
+ pdfi_type3_copy_color(&tmp_color, &OBJ_CTX(font)->pgs->color[1]);
+ rc_decrement_cs(tmp_color.color_space, "pdfi_type3_build_char");
+ }
+
+ OBJ_CTX(font)->text.inside_CharProc = false;
+ OBJ_CTX(font)->text.CharProc_is_d1 = false;
+ OBJ_CTX(font)->text.BlockDepth = SavedTextBlockDepth;
+
+build_char_error:
+ pdfi_countdown(GlyphName);
+ pdfi_countdown(CharProc);
+ return code;
+}
+
+static int alloc_type3_font(pdf_context *ctx, pdf_font_type3 **font)
+{
+ pdf_font_type3 *t3font = NULL;
+
+ t3font = (pdf_font_type3 *)gs_alloc_bytes(ctx->memory, sizeof(pdf_font_type3), "pdfi_alloc_type3_font");
+ if (t3font == NULL)
+ return_error(gs_error_VMerror);
+
+ memset(t3font, 0x00, sizeof(pdf_font_type3));
+ (t3font)->ctx = ctx;
+ (t3font)->type = PDF_FONT;
+
+#if REFCNT_DEBUG
+ (t3font)->UID = ctx->UID++;
+ dmprintf2(ctx->memory, "Allocated object of type %c with UID %"PRIi64"\n", t3font->type, t3font->UID);
+#endif
+
+
+ pdfi_countup(t3font);
+
+ t3font->pfont = gs_alloc_struct(ctx->memory, gs_font_base, &st_gs_font_base,
+ "pdfi (type 3 font)");
+ if (t3font->pfont == NULL) {
+ pdfi_countdown(t3font);
+ return_error(gs_error_VMerror);
+ }
+
+ memset(t3font->pfont, 0x00, sizeof(gs_font_base));
+ t3font->ctx = ctx;
+ t3font->pdfi_font_type = e_pdf_font_type3;
+
+ gs_make_identity(&t3font->pfont->orig_FontMatrix);
+ gs_make_identity(&t3font->pfont->FontMatrix);
+ t3font->pfont->next = t3font->pfont->prev = 0;
+ t3font->pfont->memory = ctx->memory;
+ t3font->pfont->dir = ctx->font_dir;
+ t3font->pfont->is_resource = false;
+ gs_notify_init(&t3font->pfont->notify_list, ctx->memory);
+ t3font->pfont->base = (gs_font *) t3font->pfont;
+ t3font->pfont->client_data = t3font;
+ t3font->pfont->WMode = 0;
+ t3font->pfont->PaintType = 0;
+ t3font->pfont->StrokeWidth = 0;
+ t3font->pfont->is_cached = 0;
+ t3font->pfont->procs.init_fstack = gs_default_init_fstack;
+ t3font->pfont->procs.next_char_glyph = gs_default_next_char_glyph;
+ t3font->pfont->FAPI = NULL;
+ t3font->pfont->FAPI_font_data = NULL;
+ t3font->pfont->procs.glyph_name = ctx->get_glyph_name;
+ t3font->pfont->procs.decode_glyph = pdfi_decode_glyph;
+ t3font->pfont->procs.define_font = gs_no_define_font;
+ t3font->pfont->procs.make_font = gs_no_make_font;
+ t3font->pfont->procs.font_info = gs_default_font_info;
+ t3font->pfont->procs.glyph_info = gs_default_glyph_info;
+ t3font->pfont->procs.glyph_outline = gs_no_glyph_outline;
+ t3font->pfont->procs.encode_char = pdfi_encode_char;
+ t3font->pfont->procs.build_char = pdfi_type3_build_char;
+ t3font->pfont->procs.same_font = gs_default_same_font;
+ t3font->pfont->procs.enumerate_glyph = gs_no_enumerate_glyph;
+
+ t3font->pfont->FontType = ft_PDF_user_defined;
+ /* outlines ? Bitmaps ? */
+ t3font->pfont->ExactSize = fbit_use_bitmaps;
+ t3font->pfont->InBetweenSize = fbit_use_bitmaps;
+ t3font->pfont->TransformedChar = fbit_transform_bitmaps;
+
+ t3font->pfont->encoding_index = 1; /****** WRONG ******/
+ t3font->pfont->nearest_encoding_index = 1; /****** WRONG ******/
+
+ t3font->pfont->client_data = (void *)t3font;
+ t3font->pfont->id = gs_next_ids(ctx->memory, 1);
+ uid_set_UniqueID(&t3font->pfont->UID, no_UniqueID);
+
+ *font = (pdf_font_type3 *)t3font;
+ return 0;
+}
+
+int pdfi_free_font_type3(pdf_obj *font)
+{
+ pdf_font_type3 *t3font = (pdf_font_type3 *)font;
+
+ if (t3font->pfont)
+ gs_free_object(OBJ_MEMORY(t3font), t3font->pfont, "Free type 3 font");
+
+ if (t3font->Widths)
+ gs_free_object(OBJ_MEMORY(t3font), t3font->Widths, "Free type 3 font Widths array");
+
+ pdfi_countdown(t3font->PDF_font);
+ pdfi_countdown(t3font->FontDescriptor);
+ pdfi_countdown(t3font->CharProcs);
+ pdfi_countdown(t3font->Encoding);
+ gs_free_object(OBJ_MEMORY(font), font, "Free type 3 font");
+ return 0;
+}
+
+
+int pdfi_read_type3_font(pdf_context *ctx, pdf_dict *font_dict, pdf_dict *stream_dict, pdf_dict *page_dict, pdf_font **ppdffont)
+{
+ int code = 0, i, num_chars = 0;
+ pdf_font_type3 *font = NULL;
+ pdf_obj *obj = NULL;
+ double f;
+
+ *ppdffont = NULL;
+ code = alloc_type3_font(ctx, &font);
+ if (code < 0)
+ return code;
+
+ font->object_num = font_dict->object_num;
+
+ code = pdfi_dict_get_type(ctx, font_dict, "FontBBox", PDF_ARRAY, &obj);
+ if (code < 0)
+ goto font3_error;
+ code = pdfi_array_to_gs_rect(ctx, (pdf_array *)obj, &font->pfont->FontBBox);
+ if (code < 0)
+ goto font3_error;
+ pdfi_countdown(obj);
+ obj = NULL;
+
+ code = pdfi_dict_get_type(ctx, font_dict, "FontMatrix", PDF_ARRAY, &obj);
+ if (code < 0)
+ goto font3_error;
+ code = pdfi_array_to_gs_matrix(ctx, (pdf_array *)obj, &font->pfont->orig_FontMatrix);
+ if (code < 0)
+ goto font3_error;
+ code = pdfi_array_to_gs_matrix(ctx, (pdf_array *)obj, &font->pfont->FontMatrix);
+ if (code < 0)
+ goto font3_error;
+ pdfi_countdown(obj);
+ obj = NULL;
+
+ code = pdfi_dict_get(ctx, font_dict, "CharProcs", (pdf_obj **)&font->CharProcs);
+ if (code < 0)
+ goto font3_error;
+
+ code = pdfi_dict_get_number(ctx, font_dict, "FirstChar", &f);
+ if (code < 0)
+ goto font3_error;
+ font->FirstChar = (int)f;
+
+ code = pdfi_dict_get_number(ctx, font_dict, "LastChar", &f);
+ if (code < 0)
+ goto font3_error;
+ font->LastChar = (int)f;
+
+ num_chars = (font->LastChar - font->FirstChar) + 1;
+ code = pdfi_dict_knownget_type(ctx, font_dict, "FontDescriptor", PDF_DICT, (pdf_obj **)&font->FontDescriptor);
+ if (code < 0)
+ goto font3_error;
+
+ code = pdfi_dict_knownget_type(ctx, font_dict, "Widths", PDF_ARRAY, (pdf_obj **)&obj);
+ if (code < 0)
+ goto font3_error;
+ if (code > 0) {
+ if (num_chars != pdfi_array_size((pdf_array *)obj)) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto font3_error;
+ }
+
+ font->Widths = (double *)gs_alloc_bytes(ctx->memory, sizeof(double) * num_chars, "type 3 font Widths array");
+ if (font->Widths == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto font3_error;
+ }
+ memset(font->Widths, 0x00, sizeof(double) * num_chars);
+ for (i = 0; i < num_chars; i++) {
+ code = pdfi_array_get_number(ctx, (pdf_array *)obj, (uint64_t)i, &font->Widths[i]);
+ if (code < 0)
+ goto font3_error;
+ }
+ }
+ pdfi_countdown(obj);
+ obj = NULL;
+
+ code = pdfi_dict_get(ctx, font_dict, "Encoding", &obj);
+ if (code < 0)
+ goto font3_error;
+
+ code = pdfi_create_Encoding(ctx, obj, NULL, (pdf_obj **)&font->Encoding);
+ if (code < 0)
+ goto font3_error;
+ pdfi_countdown(obj);
+
+ font->PDF_font = font_dict;
+ pdfi_countup(font_dict);
+
+ code = replace_cache_entry(ctx, (pdf_obj *)font);
+ if (code < 0)
+ goto font3_error;
+
+ code = gs_definefont(ctx->font_dir, (gs_font *)font->pfont);
+ if (code < 0)
+ goto font3_error;
+
+ *ppdffont = (pdf_font *)font;
+
+ return code;
+
+font3_error:
+ pdfi_countdown(obj);
+ pdfi_countdown(font);
+ return code;
+}
diff --git a/pdf/pdf_font3.h b/pdf/pdf_font3.h
new file mode 100644
index 00000000..5ded6ea3
--- /dev/null
+++ b/pdf/pdf_font3.h
@@ -0,0 +1,24 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Type 3 font handling routines */
+
+#ifndef PDF_TYPE3_FONT
+#define PDF_TYPE3_FONT
+
+int pdfi_read_type3_font(pdf_context *ctx, pdf_dict *font_dict, pdf_dict *stream_dict, pdf_dict *page_dict, pdf_font **ppdffont);
+int pdfi_free_font_type3(pdf_obj *font);
+
+#endif
diff --git a/pdf/pdf_font9.c b/pdf/pdf_font9.c
new file mode 100644
index 00000000..cc741127
--- /dev/null
+++ b/pdf/pdf_font9.c
@@ -0,0 +1,44 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* code for CIDFontType0/Type 9 font handling */
+/* CIDFonts with PS outlines
+ This will have to cope with Type 1, Type 1C
+ and CFF from OTF.
+*/
+
+#include "pdf_int.h"
+#include "pdf_font.h"
+#include "pdf_font0.h"
+#include "pdf_fontps.h"
+#include "pdf_font_types.h"
+#include "pdf_stack.h"
+#include "pdf_file.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+
+int pdfi_read_cidtype0_font(pdf_context *ctx, pdf_dict *font_dict, byte *fbuf, int fbuflen, pdf_font **ppdffont)
+{
+#if 0
+ int code;
+
+ code = pdfi_read_ps_font(ctx, font_dict, fbuf, fbuflen, ppfont);
+ if (code < 0) return code;
+#else
+ gs_free_object(ctx->memory, fbuf, "pdfi_read_cidtype0_font");
+#endif
+
+ return_error(gs_error_invalidfont);
+}
diff --git a/pdf/pdf_fontTT.c b/pdf/pdf_fontTT.c
new file mode 100644
index 00000000..44f3799e
--- /dev/null
+++ b/pdf/pdf_fontTT.c
@@ -0,0 +1,621 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* code for TrueType font handling */
+
+#include "pdf_int.h"
+#include "pdf_font.h"
+#include "pdf_fontTT.h"
+#include "pdf_font1C.h" /* OTTO support */
+#include "pdf_font_types.h"
+#include "pdf_stack.h"
+#include "pdf_file.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_deref.h"
+#include "gxfont42.h"
+#include "gscencs.h"
+#include "gsagl.h"
+#include "gsutil.h" /* For gs_next_ids() */
+
+enum {
+ CMAP_TABLE_NONE = 0,
+ CMAP_TABLE_10_PRESENT = 1,
+ CMAP_TABLE_30_PRESENT = 2,
+ CMAP_TABLE_31_PRESENT = 4,
+ CMAP_TABLE_310_PRESENT = 8
+};
+
+static int
+pdfi_ttf_string_proc(gs_font_type42 * pfont, ulong offset, uint length, const byte ** pdata)
+{
+ pdf_font_truetype *ttfont = (pdf_font_truetype *)pfont->client_data;
+ int code = 0;
+
+ if ((uint64_t)offset + length > ttfont->sfnt.size) {
+ *pdata = NULL;
+ code = gs_note_error(gs_error_invalidfont);
+ }
+ else {
+ *pdata = ttfont->sfnt.data + offset;
+ }
+ return code;
+}
+
+static gs_glyph pdfi_ttf_encode_char(gs_font *pfont, gs_char chr, gs_glyph_space_t sp)
+{
+ pdf_font_truetype *ttfont = (pdf_font_truetype *)pfont->client_data;
+ gs_glyph g = GS_NO_GLYPH;
+ uint ID;
+ int code;
+
+ if ((ttfont->descflags & 4) != 0) {
+ int code = pdfi_fapi_check_cmap_for_GID(pfont, (uint)chr, &ID);
+ if (code < 0 || ID == 0)
+ code = pdfi_fapi_check_cmap_for_GID(pfont, (uint)(chr | 0xf0 << 8), &ID);
+ g = (gs_glyph)ID;
+ }
+ else {
+ pdf_context *ctx = (pdf_context *)ttfont->ctx;
+
+ if (ttfont->Encoding != NULL) { /* safety */
+ pdf_name *GlyphName = NULL;
+ code = pdfi_array_get(ctx, ttfont->Encoding, (uint64_t)chr, (pdf_obj **)&GlyphName);
+ if (code >= 0) {
+ code = (*ctx->get_glyph_index)(pfont, (byte *)GlyphName->data, GlyphName->length, &ID);
+ pdfi_countdown(GlyphName);
+ if (code >= 0)
+ g = (gs_glyph)ID;
+ }
+ }
+ }
+
+ return g;
+}
+
+extern single_glyph_list_t SingleGlyphList[];
+
+static uint pdfi_type42_get_glyph_index(gs_font_type42 *pfont, gs_glyph glyph)
+{
+ pdf_font_truetype *ttfont = (pdf_font_truetype *)pfont->client_data;
+ uint gind = 0;
+ uint cc = 0;
+ int i, code = 0;
+
+ if (glyph >= GS_MIN_GLYPH_INDEX)
+ glyph -= GS_MIN_GLYPH_INDEX;
+
+ if ((ttfont->descflags & 4) != 0) {
+ gind = (uint)glyph;
+ }
+ else {
+ pdf_context *ctx = (pdf_context *)ttfont->ctx;
+ gs_const_string gname;
+
+ code = (*ctx->get_glyph_name)((gs_font *)pfont, glyph, &gname);
+ if (code < 0 || gname.data == NULL) {
+ return (uint)glyph;
+ }
+ if (gname.size == 7 && gname.data[0] == '.' && strncmp((char *)gname.data, ".notdef", 7) == 0) {
+ return 0; /* .notdef is GID 0, so short cut the rest of the function */
+ }
+
+ if (ttfont->cmap == pdfi_truetype_cmap_10) {
+ gs_string postname = {0};
+ gs_glyph g;
+
+ g = gs_c_name_glyph((const byte *)gname.data, gname.size);
+ if (g != GS_NO_GLYPH) {
+ g = (gs_glyph)gs_c_decode(g, ENCODING_INDEX_MACROMAN);
+ }
+ else {
+ g = GS_NO_CHAR;
+ }
+
+ if (g != GS_NO_CHAR) {
+ code = pdfi_fapi_check_cmap_for_GID((gs_font *)pfont, (uint)g, &cc);
+ }
+
+ if (code < 0 || cc == 0) {
+ /* This is a very slow implementation, we may benefit from creating a
+ * a reverse post table upfront */
+ for (i = 0; i < pfont->data.numGlyphs; i++) {
+ code = gs_type42_find_post_name(pfont, (gs_glyph)i, &postname);
+ if (code >= 0) {
+ if (gname.data[0] == postname.data[0]
+ && gname.size == postname.size
+ && !strncmp((char *)gname.data, (char *)postname.data, postname.size))
+ {
+ cc = i;
+ break;
+ }
+ }
+ }
+ }
+ }
+ else {
+ /* In theory, this should be 3,1 cmap, but we have examples that use 0,1 or other
+ Unicode "platform" cmap tables, so "hail mary" just try it
+ */
+ single_glyph_list_t *sgl = (single_glyph_list_t *)&(SingleGlyphList);
+ /* Not to spec, but... if we get a "uni..." formatted name, use
+ the hex value from that.
+ */
+ if (gname.size > 5 && !strncmp((char *)gname.data, "uni", 3)) {
+ char gnbuf[64];
+ int l = (gname.size - 3) > 63 ? 63 : gname.size - 3;
+
+ memcpy(gnbuf, gname.data + 3, l);
+ gnbuf[l] = '\0';
+ l = sscanf(gnbuf, "%x", &gind);
+ if (l > 0)
+ (void)pdfi_fapi_check_cmap_for_GID((gs_font *)pfont, (uint)gind, &cc);
+ else
+ cc = 0;
+ }
+ else {
+ /* Slow linear search */
+ for (i = 0; sgl->Glyph != 0x00; i++) {
+ if (sgl->Glyph[0] == gname.data[0]
+ && strlen(sgl->Glyph) == gname.size
+ && !strncmp((char *)sgl->Glyph, (char *)gname.data, gname.size))
+ break;
+ sgl++;
+ }
+ if (sgl->Glyph != NULL) {
+ code = pdfi_fapi_check_cmap_for_GID((gs_font *)pfont, (uint)sgl->Unicode, &cc);
+ if (code < 0 || cc == 0)
+ cc = 0;
+ }
+ else
+ cc = 0;
+
+ if (cc == 0) {
+ gs_string postname = {0};
+
+ /* This is a very slow implementation, we may benefit from creating a
+ * a reverse post table upfront */
+ for (i = 0; i < pfont->data.numGlyphs; i++) {
+ code = gs_type42_find_post_name(pfont, (gs_glyph)i, &postname);
+ if (code >= 0) {
+ if (postname.data[0] == gname.data[0]
+ && postname.size == gname.size
+ && !strncmp((char *)postname.data, (char *)gname.data, gname.size))
+ {
+ cc = i;
+ break;
+ }
+ }
+ }
+ }
+ }
+ }
+ gind = cc;
+ }
+ return gind;
+}
+
+static int
+pdfi_ttf_enumerate_glyph(gs_font *font, int *pindex, gs_glyph_space_t glyph_space, gs_glyph *pglyph)
+{
+ if (glyph_space == GLYPH_SPACE_INDEX) {
+ return gs_type42_enumerate_glyph(font, pindex, glyph_space, pglyph);
+ }
+ else if (glyph_space == GLYPH_SPACE_NAME) {
+ pdf_font_truetype *ttfont = (pdf_font_truetype *)font->client_data;
+
+ if ((ttfont->descflags & 4) == 0) {
+ if (*pindex <= 0) {
+ *pindex = 0;
+ }
+ *pglyph = (*font->procs.encode_char)(font, (gs_char)*pindex, glyph_space);
+ if (*pglyph == GS_NO_GLYPH)
+ *pindex = 0;
+ else
+ (*pindex)++;
+ }
+ }
+ else
+ *pindex = 0;
+ return 0;
+}
+
+static int pdfi_ttf_glyph_name(gs_font *pfont, gs_glyph glyph, gs_const_string * pstr)
+{
+ pdf_font_truetype *ttfont = (pdf_font_truetype *)pfont->client_data;
+ pdf_context *ctx = (pdf_context *)ttfont->ctx;
+ uint ID = 0;
+ int code = -1;
+
+ if (glyph >= GS_MIN_GLYPH_INDEX)
+ glyph -= GS_MIN_GLYPH_INDEX;
+
+ if ((ttfont->descflags & 4) != 0) {
+ code = gs_type42_find_post_name((gs_font_type42 *)pfont, glyph, (gs_string *)pstr);
+ if (code < 0) {
+ char buf[64];
+ int l;
+ l = gs_sprintf(buf, "~gs~gName~%04x", (uint)glyph);
+ code = (*ctx->get_glyph_index)(pfont, (byte *)buf, l, &ID);
+ }
+ else {
+ code = (*ctx->get_glyph_index)(pfont, (byte *)pstr->data, pstr->size, &ID);
+ }
+ if (code < 0)
+ return -1; /* No name, trigger pdfwrite Type 3 fallback */
+
+ code = (*ctx->get_glyph_name)(pfont, (gs_glyph)ID, pstr);
+ if (code < 0)
+ return -1; /* No name, trigger pdfwrite Type 3 fallback */
+ }
+ else {
+ code = (*ctx->get_glyph_name)(pfont, glyph, pstr);
+ if (code < 0)
+ return -1; /* No name, trigger pdfwrite Type 3 fallback */
+ }
+ return code;
+
+}
+
+static int
+pdfi_alloc_tt_font(pdf_context *ctx, pdf_font_truetype **font, bool is_cid)
+{
+ pdf_font_truetype *ttfont = NULL;
+ gs_font_type42 *pfont = NULL;
+
+ ttfont = (pdf_font_truetype *)gs_alloc_bytes(ctx->memory, sizeof(pdf_font_truetype), "pdfi (truetype pdf_font)");
+ if (ttfont == NULL)
+ return_error(gs_error_VMerror);
+
+ memset(ttfont, 0x00, sizeof(pdf_font_truetype));
+ ttfont->type = PDF_FONT;
+ ttfont->ctx = ctx;
+ ttfont->pdfi_font_type = e_pdf_font_truetype;
+
+#if REFCNT_DEBUG
+ ttfont->UID = ctx->UID++;
+ dmprintf2(ctx->memory, "Allocated object of type %c with UID %"PRIi64"\n", ttfont->type, ttfont->UID);
+#endif
+
+ pdfi_countup(ttfont);
+
+ pfont = (gs_font_type42 *)gs_alloc_struct(ctx->memory, gs_font_type42, &st_gs_font_type42,
+ "pdfi (truetype pfont)");
+ if (pfont == NULL) {
+ pdfi_countdown(ttfont);
+ return_error(gs_error_VMerror);
+ }
+ memset(pfont, 0x00, sizeof(gs_font_type42));
+
+ ttfont->pfont = (gs_font_base *)pfont;
+
+ gs_make_identity(&pfont->orig_FontMatrix);
+ gs_make_identity(&pfont->FontMatrix);
+ pfont->next = pfont->prev = 0;
+ pfont->memory = ctx->memory;
+ pfont->dir = ctx->font_dir;
+ pfont->is_resource = false;
+ gs_notify_init(&pfont->notify_list, ctx->memory);
+ pfont->base = (gs_font *) ttfont->pfont;
+ pfont->client_data = ttfont;
+ pfont->WMode = 0;
+ pfont->PaintType = 0;
+ pfont->StrokeWidth = 0;
+ pfont->is_cached = 0;
+ pfont->FAPI = NULL;
+ pfont->FAPI_font_data = NULL;
+ pfont->procs.init_fstack = gs_default_init_fstack;
+ pfont->procs.next_char_glyph = gs_default_next_char_glyph;
+ pfont->FontType = ft_TrueType;
+ pfont->ExactSize = fbit_use_outlines;
+ pfont->InBetweenSize = fbit_use_outlines;
+ pfont->TransformedChar = fbit_use_outlines;
+ /* We may want to do something clever with an XUID here */
+ pfont->id = gs_next_ids(ctx->memory, 1);
+ uid_set_UniqueID(&pfont->UID, pfont->id);
+ /* The buildchar proc will be filled in by FAPI -
+ we won't worry about working without FAPI */
+ pfont->procs.encode_char = pdfi_ttf_encode_char;
+ pfont->data.string_proc = pdfi_ttf_string_proc;
+ pfont->procs.glyph_name = pdfi_ttf_glyph_name;
+ pfont->procs.decode_glyph = pdfi_decode_glyph;
+ pfont->procs.define_font = gs_no_define_font;
+ pfont->procs.make_font = gs_no_make_font;
+ pfont->procs.font_info = gs_default_font_info;
+ pfont->procs.glyph_info = gs_default_glyph_info;
+ pfont->procs.glyph_outline = gs_no_glyph_outline;
+ pfont->procs.build_char = NULL;
+ pfont->procs.same_font = gs_default_same_font;
+ pfont->procs.enumerate_glyph = gs_no_enumerate_glyph;
+
+ pfont->encoding_index = -1; /****** WRONG ******/
+ pfont->nearest_encoding_index = -1; /****** WRONG ******/
+
+ pfont->client_data = (void *)ttfont;
+
+ *font = ttfont;
+ return 0;
+}
+
+static int pdfi_set_type42_data_procs(gs_font_type42 *pfont)
+{
+ pfont->data.get_glyph_index = pdfi_type42_get_glyph_index;
+ pfont->procs.enumerate_glyph = pdfi_ttf_enumerate_glyph;
+ return 0;
+}
+
+int pdfi_read_truetype_font(pdf_context *ctx, pdf_dict *font_dict, pdf_dict *stream_dict, pdf_dict *page_dict, byte *buf, int64_t buflen, pdf_font **ppdffont)
+{
+ pdf_font_truetype *font = NULL;
+ int code = 0, num_chars = 0, i;
+ pdf_obj *fontdesc = NULL;
+ pdf_obj *obj = NULL;
+ pdf_obj *basefont = NULL;
+ double f;
+ int64_t descflags;
+ bool encoding_known = false;
+ bool forced_symbolic = false;
+
+ if (ppdffont == NULL)
+ return_error(gs_error_invalidaccess);
+
+ *ppdffont = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, font_dict, "FontDescriptor", PDF_DICT, &fontdesc);
+ if (code <= 0) {
+ code = gs_note_error(gs_error_invalidfont);
+ goto error;
+ }
+
+ if ((code = pdfi_alloc_tt_font(ctx, &font, false)) < 0) {
+ code = gs_note_error(gs_error_invalidfont);
+ goto error;
+ }
+
+ font->FontDescriptor = (pdf_dict *)fontdesc;
+ fontdesc = NULL;
+
+ code = pdfi_dict_get_number(ctx, font_dict, "FirstChar", &f);
+ if (code < 0) {
+ goto error;
+ }
+ font->FirstChar = (int)f;
+
+ code = pdfi_dict_get_number(ctx, font_dict, "LastChar", &f);
+ if (code < 0) {
+ goto error;
+ }
+ font->LastChar = (int)f;
+
+ num_chars = font->LastChar - font->FirstChar + 1;
+
+ font->sfnt.data = buf;
+ font->sfnt.size = buflen;
+ buf = NULL;
+
+ /* Strictly speaking BaseFont is required, but we can continue without one */
+ code = pdfi_dict_knownget_type(ctx, font_dict, "BaseFont", PDF_NAME, (pdf_obj **)&basefont);
+ if (code > 0) {
+ pdf_name *nobj = (pdf_name *)basefont;
+ int nlen = nobj->length > gs_font_name_max ? gs_font_name_max : nobj->length;
+
+ memcpy(font->pfont->key_name.chars, nobj->data, nlen);
+ font->pfont->key_name.chars[nlen] = 0;
+ font->pfont->key_name.size = nlen;
+ memcpy(font->pfont->font_name.chars, nobj->data, nlen);
+ font->pfont->font_name.chars[nlen] = 0;
+ font->pfont->font_name.size = nlen;
+ pdfi_countdown(obj);
+ obj = NULL;
+ }
+ font->BaseFont = basefont;
+ basefont = NULL;
+ font->PDF_font = font_dict;
+ pdfi_countup(font_dict);
+
+ code = pdfi_dict_knownget_type(ctx, font_dict, "Widths", PDF_ARRAY, (pdf_obj **)&obj);
+ if (code < 0)
+ goto error;
+ if (code > 0) {
+ if (num_chars != pdfi_array_size((pdf_array *)obj)) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto error;
+ }
+
+ font->Widths = (double *)gs_alloc_bytes(ctx->memory, sizeof(double) * num_chars, "truetype font Widths array");
+ if (font->Widths == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+ memset(font->Widths, 0x00, sizeof(double) * num_chars);
+ for (i = 0; i < num_chars; i++) {
+ code = pdfi_array_get_number(ctx, (pdf_array *)obj, (uint64_t)i, &font->Widths[i]);
+ if (code < 0)
+ goto error;
+ font->Widths[i] /= 1000;
+ }
+ }
+ pdfi_countdown(obj);
+ obj = NULL;
+
+ code = pdfi_dict_get_int(ctx, font->FontDescriptor, "Flags", &descflags);
+ if (code < 0)
+ descflags = 0;
+
+ code = pdfi_dict_get(ctx, font_dict, "Encoding", &obj);
+ if (code < 0) {
+ static const char encstr[] = "WinAnsiEncoding";
+ code = pdfi_name_alloc(ctx, (byte *)encstr, strlen(encstr), (pdf_obj **)&obj);
+ if (code >= 0)
+ pdfi_countup(obj);
+ else
+ goto error;
+ }
+ else {
+ encoding_known = true;
+ /* If we have and encoding, and both the symbolic and non-symbolic flag are set,
+ believe that latter.
+ */
+ if ((descflags & 32) != 0)
+ descflags = (descflags & ~4);
+ }
+
+ if ((forced_symbolic = pdfi_font_known_symbolic(font->BaseFont)) == true) {
+ descflags |= 4;
+ }
+
+ code = pdfi_create_Encoding(ctx, obj, NULL, (pdf_obj **)&font->Encoding);
+ /* If we get an error, and the font is non-symbolic, return the error */
+ if (code < 0 && (descflags & 4) == 0)
+ goto error;
+ /* If we get an error, and the font is symbolic, pretend we never saw an /Encoding */
+ if (code < 0)
+ encoding_known = false;
+ pdfi_countdown(obj);
+ obj = NULL;
+
+ font->fake_glyph_names = (gs_string *)gs_alloc_bytes(OBJ_MEMORY(font), font->LastChar * sizeof(gs_string), "pdfi_read_truetype_font: fake_glyph_names");
+ if (!font->fake_glyph_names) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+ memset(font->fake_glyph_names, 0x00, font->LastChar * sizeof(gs_string));
+
+ code = gs_type42_font_init((gs_font_type42 *)font->pfont, 0);
+ if (code < 0) {
+ goto error;
+ }
+
+ code = pdfi_set_type42_data_procs((gs_font_type42 *)font->pfont);
+ if (code < 0) {
+ goto error;
+ }
+
+ /* We're probably dead in the water without cmap tables, but make sure, for safety */
+ /* This is a horrendous morass of guesses at what Acrobat does with files that contravene
+ what the spec says about symbolic fonts, cmap tables and encodings.
+ */
+ if (forced_symbolic != true && (descflags & 4) != 0 && ((gs_font_type42 *)font->pfont)->data.cmap != 0) {
+ gs_font_type42 *t42f = (gs_font_type42 *)font->pfont;
+ int numcmaps;
+ int cmaps_available = CMAP_TABLE_NONE;
+ const byte *d;
+ code = (*t42f->data.string_proc)(t42f, t42f->data.cmap + 2, 2, &d);
+ if (code < 0)
+ goto error;
+ numcmaps = d[1] | d[0] << 8;
+ for (i = 0; i < numcmaps; i++) {
+ code = (*t42f->data.string_proc)(t42f, t42f->data.cmap + 4 + i * 8, 4, &d);
+ if (code < 0)
+ goto error;
+#define CMAP_PLAT_ENC_ID(a,b,c,d) (a << 24 | b << 16 | c << 8 | d)
+ switch(CMAP_PLAT_ENC_ID(d[0], d[1], d[2], d[3])) {
+ case CMAP_PLAT_ENC_ID(0, 1, 0, 0):
+ cmaps_available |= CMAP_TABLE_10_PRESENT;
+ break;
+ case CMAP_PLAT_ENC_ID(0, 3, 0, 0):
+ cmaps_available |= CMAP_TABLE_30_PRESENT;
+ break;
+ case CMAP_PLAT_ENC_ID(0, 3, 0, 1):
+ cmaps_available |= CMAP_TABLE_31_PRESENT;
+ break;
+ case CMAP_PLAT_ENC_ID(0, 3, 1, 0):
+ cmaps_available |= CMAP_TABLE_310_PRESENT;
+ break;
+ default: /* Not one we're interested in */
+ break;
+ }
+ }
+#undef CMAP_PLAT_ENC_ID
+ if ((cmaps_available & CMAP_TABLE_30_PRESENT) == CMAP_TABLE_30_PRESENT) {
+ font->descflags = descflags;
+ }
+ else if (encoding_known == true) {
+ static const char encstr[] = "WinAnsiEncoding";
+ font->descflags = descflags & ~4;
+ code = pdfi_name_alloc(ctx, (byte *)encstr, strlen(encstr), (pdf_obj **)&obj);
+ if (code >= 0)
+ pdfi_countup(obj);
+ else
+ goto error;
+ pdfi_countdown(font->Encoding);
+ code = pdfi_create_Encoding(ctx, obj, NULL, (pdf_obj **)&font->Encoding);
+ if (code < 0)
+ goto error;
+ pdfi_countdown(obj);
+ obj = NULL;
+ }
+ else
+ font->descflags = descflags;
+ }
+ else {
+ font->descflags = descflags;
+ }
+
+ code = gs_definefont(ctx->font_dir, (gs_font *)font->pfont);
+ if (code < 0) {
+ goto error;
+ }
+
+ code = pdfi_fapi_passfont((pdf_font *)font, 0, NULL, NULL, font->sfnt.data, font->sfnt.size);
+ if (code < 0) {
+ goto error;
+ }
+
+ /* object_num can be zero if the dictionary was defined inline */
+ if (font->object_num != 0) {
+ code = replace_cache_entry(ctx, (pdf_obj *)font);
+ if (code < 0)
+ goto error;
+ }
+
+ *ppdffont = (pdf_font *)font;
+ return code;
+error:
+ if (buf != NULL)
+ gs_free_object(ctx->memory, buf, "pdfi_read_truetype_font(buf)");
+ pdfi_countdown(fontdesc);
+ pdfi_countdown(basefont);
+ pdfi_countdown(obj);
+ pdfi_countdown(font);
+ return code;
+}
+
+int pdfi_free_font_truetype(pdf_obj *font)
+{
+ pdf_font_truetype *ttfont = (pdf_font_truetype *)font;
+ int i;
+ if (ttfont->pfont)
+ gs_free_object(OBJ_MEMORY(ttfont), ttfont->pfont, "Free TrueType gs_font");
+
+ if (ttfont->Widths)
+ gs_free_object(OBJ_MEMORY(ttfont), ttfont->Widths, "Free TrueType font Widths array");
+
+ if (ttfont->fake_glyph_names != NULL) {
+ for (i = 0; i < ttfont->LastChar; i++) {
+ if (ttfont->fake_glyph_names[i].data != NULL)
+ gs_free_object(OBJ_MEMORY(ttfont), ttfont->fake_glyph_names[i].data, "Free TrueType fake_glyph_name");
+ }
+ }
+ gs_free_object(OBJ_MEMORY(ttfont), ttfont->fake_glyph_names, "Free TrueType fake_glyph_names");
+ gs_free_object(OBJ_MEMORY(ttfont), ttfont->sfnt.data, "Free TrueType font sfnt buffer");
+
+ pdfi_countdown(ttfont->FontDescriptor);
+ pdfi_countdown(ttfont->Encoding);
+ pdfi_countdown(ttfont->BaseFont);
+ gs_free_object(OBJ_MEMORY(ttfont), ttfont, "Free TrueType font");
+
+ return 0;
+}
diff --git a/pdf/pdf_fontTT.h b/pdf/pdf_fontTT.h
new file mode 100644
index 00000000..1ce4cf8b
--- /dev/null
+++ b/pdf/pdf_fontTT.h
@@ -0,0 +1,24 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* TrueType font handling routines */
+
+#ifndef PDF_TRUETYPE_FONT
+#define PDF_TRUETYPE_FONT
+
+int pdfi_read_truetype_font(pdf_context *ctx, pdf_dict *font_dict, pdf_dict *stream_dict, pdf_dict *page_dict, byte *buf, int64_t buflen, pdf_font **ppdffont);
+int pdfi_free_font_truetype(pdf_obj *font);
+
+#endif
diff --git a/pdf/pdf_font_types.h b/pdf/pdf_font_types.h
new file mode 100644
index 00000000..f83a0851
--- /dev/null
+++ b/pdf/pdf_font_types.h
@@ -0,0 +1,231 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* font structures for the PDF interpreter */
+
+/* Fonts are, unfortunately, complicated by the fact that the graphics state font object
+ * the 'gs_font' structure is not reference counted. The PostScript interpreter relies upon
+ * the garbage collector to clean these up, but since we aren't using a garbage collector
+ * we have to manage the lifetime of these ourselves.
+ *
+ * The complication is that the gs_font pointer is stored in the graphics state and there
+ * is no simple mechanism to know when a font in a graphics state is no longer being used
+ * (in the absence of a garbage collector). So what we do is use the 'client_data' member
+ * of the gs_font structure to point to our font object, a pdf_font *, which itself
+ * contains a pointer to the gs_font structure.
+ *
+ * On each pdfi_gsave() we look at the gs_font in the current graphics state (if any) and
+ * use the client_data to find the corresponding pdf_font, we then cout that object up. On
+ * each pdfi_grestore we again use the client_data to find our pdf_font object, and count
+ * it down. The Tf operator replaces the gs_font in the current graphics state, and we count
+ * the current one down, and the new one up, before replacing it.
+ *
+ * When the pdf_font object's reference count reaches 0 we can safely free the associated
+ * gs_font structure. Note that the cache may still contain a reference to the pdf_font
+ * object, so it may not be freed immediately it is no longer in use. This helps us avoid
+ * too much redefinition of fonts.
+ *
+ * When we create a pdf_font object, we replace the cached object, which is a dictionary,
+ * with the pdf_font object. So when we call pdfi_dereference() if we get back a pdf_font
+ * object we know that this is an existing font (keyed by object number) and don't need to
+ * rebuild it. If we get a pdf_dict object then we do need to build the graphics library
+ * font.
+ *
+ * This still does leave the (admittedly remote) possibility of using a font in one graphics
+ * state, gsave'ing, setting a new font, and then dereferencing enough objects to force the
+ * original font out of the cache, then using that same font again. While there is no
+ * obvious problem with that, it is inefficient. I think we can evade the problem by using
+ * the next and prev pointers in the gs_fotn structure. If we keep the linked list correct
+ * when creating and freeing fonts, we can walk the list of 'active' fonts, following
+ * the clien_data pointer to get the pdf_font object, and checking its object number against
+ * the one we are looking for. We only need to do this if the result of pdfi_derference()
+ * Is a pdf_dict object. Obviously if we don't find an active font then we need to go
+ * through the effort of creating one.
+ *
+ * FIXME - none of the above is yet implemented!
+ */
+
+#ifndef PDF_FONT_DATA
+#define PDF_FONT_DATA
+
+#include "pdf_types.h"
+#include "pdf_cmap.h"
+#include "gxfont.h"
+#include "gsfont.h"
+
+typedef enum pdf_font_type_e {
+ e_pdf_font_type0, /* Somewhat special a font type 0 is a placeholder for a CIDFont */
+ e_pdf_font_type1,
+ e_pdf_font_cff,
+ e_pdf_font_type3,
+ e_pdf_cidfont_type0 = 9,
+ e_pdf_cidfont_type1,
+ e_pdf_cidfont_type2,
+ e_pdf_cidfont_type4 = 32,
+ e_pdf_font_truetype = 42,
+} pdf_font_type;
+
+#define pdf_font_base \
+ pdf_obj_common;\
+ gs_font_base *pfont; /* Graphics library font structure */\
+ pdf_font_type pdfi_font_type; /* See above */\
+ pdf_dict *PDF_font; /* The original font dictionary from the PDF file */\
+ pdf_obj *BaseFont; /* Should be a name object, but best allow for strings as well */\
+ pdf_dict *FontDescriptor; /* For PDF up to 1.4 this may be absent for the base 14 */ \
+ int64_t descflags
+
+
+#define pdf_font_common \
+ pdf_font_base;\
+ pdf_obj *Name; /* Should be a name object, but best allow for strings as well */\
+ unsigned int FirstChar; /* For PDF up to 1.4 this may be absent for the base 14 */\
+ unsigned int LastChar; /* For PDF up to 1.4 this may be absent for the base 14 */\
+ double *Widths; /* For PDF up to 1.4 this may be absent for the base 14 */\
+ pdf_array *Encoding; /* Array built from name or dictionary */\
+ pdf_obj *ToUnicode; /* Name or stream (technically should be a stream, but we've seen Identity names */ \
+ gs_string *fake_glyph_names /* For when we encounter a glyph not in the Encoding */
+
+
+/* The registry and ordering strings in gs_font_cid0_data are just references to
+ strings assumed to be managed be managed by the interpreter - so we have to stash
+ them in the pdfi font, too.
+ */
+#define pdf_cid_font_common \
+ pdf_font_base;\
+ pdf_dict *CIDSystemInfo; \
+ int64_t DW; \
+ pdf_array *W; \
+ pdf_array *DW2; \
+ pdf_array *W2; \
+ pdf_string *registry; \
+ pdf_string *ordering; \
+ int supplement; \
+ gs_string cidtogidmap; \
+ bool substitute; /* We need to know what a CIDFont is a substitute */ \
+ font_proc_glyph_info((*orig_glyph_info))
+
+typedef struct pdf_font_s {
+ pdf_font_common;
+}pdf_font;
+
+/* Decoding tables are statically defined, so require no memory management */
+typedef struct pdfi_cid_decoding_s {
+ const char *s_order;
+ const char *d_order;
+ const int nranges;
+ const int val_sizes;
+ const int ranges[114][256][4];
+} pdfi_cid_decoding_t;
+
+struct pdfi_cid_subst_nwp_rec_s {
+ const char s_type; /* Orig type: n==narrow, w==wide, p==proportional */
+ const unsigned int s_scid; /* Start source CID */
+ const unsigned int e_scid; /* End source CID */
+ const unsigned int s_dcid; /* Start destination CID */
+ const char d_type; /* Destination type */
+};
+
+typedef struct pdfi_cid_subst_nwp_table_s {
+ const char *ordering;
+ struct pdfi_cid_subst_nwp_rec_s subst[32];
+} pdfi_cid_subst_nwp_table_t;
+
+typedef struct pdf_font_type0_s {
+ pdf_font_base; /* For this font type, the FontDescriptor will be NULL, as will the pfont, (we use the DescendantFont) */
+
+ pdf_obj *Encoding; /* CMap */
+ pdf_array *DescendantFonts; /* A single element array specifying the CIDFont dictionary */
+ pdf_obj *ToUnicode; /* Name or stream (technically shoudl be a stream, but we've seen Identity names */
+ pdfi_cid_decoding_t *decoding; /* Used when substituting a non-Identity CIDFont */
+ pdfi_cid_subst_nwp_table_t *substnwp; /* Also used for CIDFont substitions */
+} pdf_font_type0;
+
+typedef struct pdf_font_type1_s {
+ pdf_font_common;
+ gs_string *Subrs;
+ pdf_dict *CharStrings;
+ int NumSubrs;
+ /* Multiple Master Support - weightvector is stored in gs_font_type1 */
+ pdf_array *blenddesignpositions;
+ pdf_array *blenddesignmap;
+ pdf_array *blendfontbbox;
+ pdf_array *blendaxistypes;
+} pdf_font_type1;
+
+typedef struct pdf_font_cff_s {
+ pdf_font_common;
+ pdf_array *Subrs;
+ int NumSubrs;
+ pdf_array *GlobalSubrs;
+ int NumGlobalSubrs;
+ pdf_dict *CharStrings;
+ byte *cffdata;
+ byte *cffend;
+ byte *gsubrs;
+ byte *subrs;
+ byte *charstrings;
+ int ncharstrings;
+} pdf_font_cff;
+
+typedef struct pdf_font_type3_s {
+ pdf_font_common;
+
+ pdf_array *FontBBox;
+ pdf_array *FontMatrix;
+ pdf_dict *CharProcs;
+} pdf_font_type3;
+
+typedef enum {
+ pdfi_truetype_cmap_none,
+ pdfi_truetype_cmap_10,
+ pdfi_truetype_cmap_30,
+ pdfi_truetype_cmap_31,
+ pdfi_truetype_cmap_310
+} pdfi_truetype_cmap;
+
+typedef struct pdf_font_truetype_s {
+ pdf_font_common;
+ gs_string sfnt;
+ pdfi_truetype_cmap cmap;
+} pdf_font_truetype;
+
+typedef struct pdf_cidfont_s {
+ pdf_cid_font_common;
+} pdf_cidfont_t;
+
+typedef struct pdf_cidfont_type0_s {
+ pdf_cid_font_common;
+ pdf_array *Subrs;
+ int NumSubrs;
+ pdf_array *GlobalSubrs;
+ int NumGlobalSubrs;
+ pdf_dict *CharStrings;
+ byte *cffdata;
+ byte *cffend;
+ byte *gsubrs;
+ byte *subrs;
+ byte *charstrings;
+ int ncharstrings;
+ pdf_array *FDArray;
+ int cidcount;
+ int uidbase;
+} pdf_cidfont_type0;
+
+typedef struct pdf_cidfont_type2_s {
+ pdf_cid_font_common;
+ gs_string sfnt;
+} pdf_cidfont_type2;
+
+#endif
diff --git a/pdf/pdf_fontps.c b/pdf/pdf_fontps.c
new file mode 100644
index 00000000..7ee9d2f0
--- /dev/null
+++ b/pdf/pdf_fontps.c
@@ -0,0 +1,1239 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* common code for Postscript-type font handling */
+#include "scanchar.h"
+#include "sfilter.h"
+#include "stream.h"
+#include "strimpl.h"
+
+#include "pdf_int.h"
+#include "pdf_types.h"
+#include "pdf_array.h"
+#include "pdf_dict.h"
+#include "pdf_font.h"
+#include "pdf_font_types.h"
+#include "pdf_fontps.h"
+
+static const char *const notdefnamestr = ".notdef";
+
+int
+pdfi_pscript_stack_init(pdf_context *pdfi_ctx, pdf_ps_oper_list_t *ops, void *client_data,
+ pdf_ps_ctx_t *s)
+{
+ int i, size = PDF_PS_STACK_SIZE;
+ int initsizebytes = sizeof(pdf_ps_stack_object_t) * PDF_PS_STACK_SIZE;
+ s->pdfi_ctx = pdfi_ctx;
+ s->ops = ops;
+ s->client_data = client_data;
+
+ s->stack = (pdf_ps_stack_object_t *)gs_alloc_bytes(pdfi_ctx->memory, initsizebytes, "pdfi_pscript_stack_init(stack)");
+ if (s->stack == NULL)
+ return_error(gs_error_VMerror);
+
+ s->cur = s->stack + 1;
+ s->toplim = s->cur + size;
+
+ for (i = 0; i < PDF_PS_STACK_GUARDS; i++)
+ s->stack[i].type = PDF_PS_OBJ_STACK_BOTTOM;
+
+ for (i = 0; i < PDF_PS_STACK_GUARDS; i++)
+ s->stack[size - 1 + i].type = PDF_PS_OBJ_STACK_TOP;
+
+ for (i = 0; i < size - 1; i++) {
+ pdf_ps_make_null(&(s->cur[i]));
+ }
+ return 0;
+}
+
+void
+pdfi_pscript_stack_finit(pdf_ps_ctx_t *s)
+{
+ int stackdepth;
+
+ if ((stackdepth = pdf_ps_stack_count(s)) > 0) {
+ pdf_ps_stack_pop(s, stackdepth);
+ }
+ gs_free_object(s->pdfi_ctx->memory, s->stack, "pdfi_pscript_stack_finit(stack)");
+}
+
+int
+ps_pdf_null_oper_func(gs_memory_t *mem, pdf_ps_ctx_t *stack, byte *buf, byte *bufend)
+{
+ return 0;
+}
+
+int
+clear_stack_oper_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ int depth = s->cur - &(s->stack[1]);
+
+ return pdf_ps_stack_pop(s, depth);
+}
+
+int
+pdf_ps_pop_oper_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ return pdf_ps_stack_pop(s, 1);
+}
+
+int
+pdf_ps_pop_and_pushmark_func(gs_memory_t *mem, pdf_ps_ctx_t *stack, byte *buf, byte *bufend)
+{
+ int code = pdf_ps_stack_pop(stack, 1);
+
+ if (code >= 0)
+ code = pdf_ps_stack_push_mark(stack);
+ return code;
+}
+
+static inline int
+pdf_ps_is_whitespace(int c)
+{
+ return (c == 0x20) || (c == 0x9) || (c == 0xD) || (c == 0xA);
+}
+
+static inline int
+pdf_ps_end_object(int c)
+{
+ return pdf_ps_is_whitespace(c) || (c == '/') || (c == '[') || (c == ']') || c == '{' || c == '}' || (c == '(') || (c == '<');
+}
+
+static inline int
+pdf_ps_end_number_object(int c)
+{
+ return (c != '.' && c != 'e' && c != '-' && (c < '0' || c > '9'));
+}
+
+static inline bool
+ishex(char c)
+{
+ if (c < 0x30)
+ return false;
+
+ if (c > 0x39) {
+ if (c > 'F') {
+ if (c < 'a')
+ return false;
+ if (c > 'f')
+ return false;
+ return true;
+ }
+ else {
+ if (c < 'A')
+ return false;
+ return true;
+ }
+ }
+ else
+ return true;
+}
+
+static inline int
+decodehex(char c)
+{
+ int retval = 0;
+
+ if (ishex(c)) {
+ if (c > 0x39) {
+ if (c > 'F') {
+ retval = c - 0x57;
+ }
+ else {
+ retval = c - 0x37;
+ }
+ }
+ else {
+ retval = c - 0x30;
+ }
+ }
+ return retval;
+}
+
+int
+pdfi_pscript_interpret(pdf_ps_ctx_t *cs, byte *pdfpsbuf, int64_t buflen)
+{
+ int code = 0;
+ byte *buflim = pdfpsbuf + buflen;
+ int arraydepth = 0;
+ int stackdepth;
+
+ while (pdfpsbuf < buflim && code >= 0) {
+ switch (*pdfpsbuf++) {
+ case '%': /* Comment */
+ {
+ while (pdfpsbuf < buflim && *pdfpsbuf != char_EOL && *pdfpsbuf != '\f' &&
+ *pdfpsbuf != char_CR)
+ pdfpsbuf++;
+
+ if (*pdfpsbuf == char_EOL)
+ pdfpsbuf++;
+ }
+ break;
+ case '/': /* name */
+ {
+ byte *n = pdfpsbuf;
+ int len;
+
+ while (pdfpsbuf < buflim && !pdf_ps_end_object((int)*pdfpsbuf))
+ pdfpsbuf++;
+ len = pdfpsbuf - n;
+ code = pdf_ps_stack_push_name(cs, n, len);
+ } break;
+ case '(': /* string */
+ {
+ byte *s = pdfpsbuf;
+ int len;
+ int depth = 1;
+
+ while (pdfpsbuf < buflim && depth > 0) {
+ if (*pdfpsbuf == '(') {
+ depth++;
+ }
+ else if (*pdfpsbuf == ')') {
+ depth--;
+ }
+ pdfpsbuf++;
+ }
+ len = (pdfpsbuf - s) - 1;
+ code = pdf_ps_stack_push_string(cs, s, len);
+ }
+ break;
+ case '<': /* hex string */
+ {
+ byte *s = pdfpsbuf;
+ byte *s2 = s;
+ int len, i;
+ byte hbuf[2];
+
+ if (pdfpsbuf < buflim && *pdfpsbuf == '<') { /* Dict opening "<<" - we don't care */
+ pdfpsbuf++;
+ continue;
+ }
+ while (pdfpsbuf < buflim && *pdfpsbuf != '>')
+ pdfpsbuf++;
+ len = pdfpsbuf - s;
+ while (len % 2)
+ len--;
+ for (i = 0; i < len; i += 2) {
+ hbuf[0] = s[i];
+ hbuf[1] = s[i + 1];
+ *s2++ = (decodehex(hbuf[0]) << 4) | decodehex(hbuf[1]);
+ }
+ pdfpsbuf++; /* move past the trailing '>' */
+ code = pdf_ps_stack_push_string(cs, s, len >> 1);
+ }
+ break;
+ case '>': /* For hex strings, this should be handled above */
+ {
+ if (pdfpsbuf < buflim && *pdfpsbuf == '>') { /* Dict closing "<<" - we still don't care */
+ pdfpsbuf++;
+ }
+ }
+ break;
+ case '[':; /* begin array */
+ case '{':; /* begin executable array (mainly, FontBBox) */
+ arraydepth++;
+ code = pdf_ps_stack_push_arr_mark(cs);
+ break;
+ case ']': /* end array */
+ case '}': /* end executable array */
+ {
+ pdf_ps_stack_object_t *arr = NULL;
+ int i, size = pdf_ps_stack_count_to_mark(cs, PDF_PS_OBJ_ARR_MARK);
+
+ if (size > 0 && arraydepth > 0) {
+ arr = (pdf_ps_stack_object_t *) gs_alloc_bytes(cs->pdfi_ctx->memory, size * sizeof(pdf_ps_stack_object_t), "pdfi_pscript_interpret(pdf_ps_stack_object_t");
+ if (arr == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ /* clean up the stack, including the mark object */
+ (void)pdf_ps_stack_pop(cs, size + 1);
+ size = 0;
+ }
+ else {
+ for (i = 0; i < size; i++) {
+ memcpy(&(arr[(size - 1) - i]), cs->cur, sizeof(*cs->cur));
+ if (pdf_ps_obj_has_type(cs->cur, PDF_PS_OBJ_ARRAY)) {
+ pdf_ps_make_null(cs->cur);
+ }
+ (void)pdf_ps_stack_pop(cs, 1);
+ }
+ /* And pop the array mark */
+ (void)pdf_ps_stack_pop(cs, 1);
+ }
+ }
+ else {
+ /* And pop the array mark for an emtpy array */
+ (void)pdf_ps_stack_pop(cs, 1);
+ }
+ code = pdf_ps_stack_push_array(cs, arr, size > 0 ? size : 0);
+ arraydepth--;
+ if (arraydepth < 0)
+ arraydepth = 0;
+ }
+ break;
+ case '.':
+ case '-':
+ case '+':
+ case '0':
+ case '1':
+ case '2':
+ case '3':
+ case '4':
+ case '5':
+ case '6':
+ case '7':
+ case '8':
+ case '9':{
+ bool is_float = false;
+ int len;
+ byte *n = --pdfpsbuf, *numbuf;
+
+ while (pdfpsbuf < buflim && !pdf_ps_end_number_object((int)*pdfpsbuf)) {
+ if (*pdfpsbuf == '.' || *pdfpsbuf == 'e')
+ is_float = true;
+ pdfpsbuf++;
+ }
+ len = pdfpsbuf - n;
+ if (len == 1 && *n == '-') {
+ /* Not a number, might be an operator */
+ pdfpsbuf = n + 1;
+ goto retry_as_oper;
+ }
+ numbuf = gs_alloc_bytes(cs->pdfi_ctx->memory, len + 1, "ps pdf number buffer");
+ if (numbuf == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ }
+ else {
+ memcpy(numbuf, n, len);
+ numbuf[len] = '\0';
+ if (is_float) {
+ float f = (float)atof((const char *)numbuf);
+
+ code = pdf_ps_stack_push_float(cs, f);
+ }
+ else {
+ int i = atoi((const char *)numbuf);
+
+ code = pdf_ps_stack_push_int(cs, i);
+ }
+ gs_free_object(cs->pdfi_ctx->memory, numbuf, "ps pdf number buffer");
+ }
+ } break;
+ case ' ':
+ case '\f':
+ case '\t':
+ case char_CR:
+ case char_EOL:
+ case char_NULL:
+ break;
+ default:
+ retry_as_oper:{
+ byte *n = --pdfpsbuf;
+ int len, i;
+ int (*opfunc)(gs_memory_t *mem, pdf_ps_ctx_t *stack, byte *buf, byte *bufend) = NULL;
+ pdf_ps_oper_list_t *ops = cs->ops;
+
+ while (pdfpsbuf < buflim && !pdf_ps_end_object((int)*pdfpsbuf))
+ pdfpsbuf++;
+
+ if (arraydepth == 0) {
+ len = pdfpsbuf - n;
+ for (i = 0; ops[i].opname != NULL; i++) {
+ if (len == ops[i].opnamelen && !memcmp(n, ops[i].opname, len)) {
+ opfunc = ops[i].oper;
+ break;
+ }
+ }
+
+ if (opfunc) {
+ code = (*opfunc) (cs->pdfi_ctx->memory, cs, pdfpsbuf, buflim);
+ if (code > 0) {
+ pdfpsbuf += code;
+ code = 0;
+ }
+ }
+ }
+ }
+ break;
+ }
+ }
+ if ((stackdepth = pdf_ps_stack_count(cs)) > 0) {
+ pdf_ps_stack_pop(cs, stackdepth);
+ }
+ return code;
+}
+
+static int
+ps_font_def_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ int code = 0, code2 = 0;
+ ps_font_interp_private *priv = (ps_font_interp_private *) s->client_data;
+
+ if ((code = pdf_ps_stack_count(s)) < 2) {
+ return pdf_ps_stack_pop(s, code);
+ }
+
+ if (pdf_ps_obj_has_type(&s->cur[-1], PDF_PS_OBJ_NAME)) {
+ if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("FontName"))) {
+ int fnlen = 0;
+ char *pname = NULL;
+
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_NAME)) {
+ fnlen = s->cur[0].size > gs_font_name_max ? gs_font_name_max : s->cur[0].size;
+ pname = (char *)s->cur[0].val.name;
+ }
+ else if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_STRING)) {
+ fnlen = s->cur[0].size > gs_font_name_max ? gs_font_name_max : s->cur[0].size;
+ pname = (char *)s->cur[0].val.string;
+ }
+ if (pname) {
+ memcpy(priv->gsu.gst1.key_name.chars, pname, fnlen);
+ priv->gsu.gst1.key_name.chars[fnlen] = '\0';
+ priv->gsu.gst1.key_name.size = fnlen;
+
+ memcpy(priv->gsu.gst1.font_name.chars, pname, fnlen);
+ priv->gsu.gst1.font_name.chars[fnlen] = '\0';
+ priv->gsu.gst1.font_name.size = fnlen;
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("PaintType"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_INTEGER)) {
+ priv->gsu.gst1.PaintType = s->cur[0].val.i;
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("StrokeWidth"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_FLOAT)) {
+ priv->gsu.gst1.StrokeWidth = s->cur[0].val.f;
+ }
+ else if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_INTEGER)) {
+ priv->gsu.gst1.StrokeWidth = (float)s->cur[0].val.i;
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("WMode"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_INTEGER)) {
+ priv->gsu.gst1.WMode = s->cur[0].val.i;
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("lenIV"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_INTEGER)) {
+ priv->gsu.gst1.data.lenIV = s->cur[0].val.i;
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("UniqueID"))) {
+ /* Ignore UniqueID if we already have a XUID */
+ if (priv->gsu.gst1.UID.id >= 0) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_INTEGER)) {
+ uid_set_UniqueID(&priv->gsu.gst1.UID, s->cur[0].val.i);
+ }
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("XUID"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_ARRAY)) {
+ int i, size = s->cur[0].size;
+ long *xvals = (long *)gs_alloc_bytes(mem, size *sizeof(long), "ps_font_def_func(xuid vals)");
+
+ if (xvals != NULL) {
+ for (i = 0; i < size; i++) {
+ if (pdf_ps_obj_has_type(&s->cur[0].val.arr[i], PDF_PS_OBJ_INTEGER)) {
+ xvals[i] = s->cur[0].val.arr[i].val.i;
+ }
+ else {
+ gs_free_object(mem, xvals, "ps_font_def_func(xuid vals)");
+ xvals = NULL;
+ break;
+ }
+ }
+ }
+ if (xvals != NULL) {
+ if (priv->gsu.gst1.UID.xvalues != NULL)
+ gs_free_object(mem, priv->gsu.gst1.UID.xvalues, "ps_font_def_func(old xuid vals)");
+ uid_set_XUID(&priv->gsu.gst1.UID, xvals, size);
+ }
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("FontBBox"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_ARRAY)) {
+ int i, j;
+ double bbox[4] = { 0, 0, 1000, 1000 };
+ if (pdf_ps_obj_has_type(&s->cur[0].val.arr[0], PDF_PS_OBJ_ARRAY)) { /* This is (probably) a Blend/FontBBox entry */
+ code = pdfi_array_alloc(s->pdfi_ctx, s->cur[0].size, &priv->u.t1.blendfontbbox);
+ if (code >= 0) {
+ pdfi_countup(priv->u.t1.blendfontbbox);
+ for (i = 0; i < s->cur[0].size; i++) {
+ pdf_ps_stack_object_t *arr = &s->cur[0].val.arr[i];
+ pdf_array *parr;
+ pdf_num *n;
+ if (pdf_ps_obj_has_type(arr, PDF_PS_OBJ_ARRAY)) {
+ code = pdfi_array_alloc(s->pdfi_ctx, arr->size, &parr);
+ if (code < 0)
+ break;
+ pdfi_countup(parr);
+
+ for (j = 0; j < arr->size; j++) {
+ if (pdf_ps_obj_has_type(&arr->val.arr[j], PDF_PS_OBJ_INTEGER)) {
+ code = pdfi_object_alloc(s->pdfi_ctx, PDF_INT, 0, (pdf_obj **)&n);
+ if (code >= 0)
+ n->value.i = arr->val.arr[j].val.i;
+ }
+ else if (pdf_ps_obj_has_type(&arr->val.arr[j], PDF_PS_OBJ_FLOAT)) {
+ code = pdfi_object_alloc(s->pdfi_ctx, PDF_REAL, 0, (pdf_obj **)&n);
+ if (code >= 0)
+ n->value.d = arr->val.arr[j].val.f;
+ }
+ else {
+ code = pdfi_object_alloc(s->pdfi_ctx, PDF_INT, 0, (pdf_obj **)&n);
+ if (code >= 0)
+ n->value.i = 0;
+ }
+ if (code < 0)
+ break;
+ pdfi_countup(n);
+ code = pdfi_array_put(s->pdfi_ctx, parr, j, (pdf_obj *)n);
+ pdfi_countdown(n);
+ if (code < 0) break;
+ }
+ }
+ if (code >= 0)
+ code = pdfi_array_put(s->pdfi_ctx, priv->u.t1.blendfontbbox, i, (pdf_obj *)parr);
+ pdfi_countdown(parr);
+ }
+ }
+ }
+ else if (s->cur[0].size >= 4) {
+ for (i = 0; i < 4; i++) {
+ if (pdf_ps_obj_has_type(&s->cur[0].val.arr[i], PDF_PS_OBJ_INTEGER)) {
+ bbox[i] = (double)s->cur[0].val.arr[i].val.i;
+ }
+ else if (pdf_ps_obj_has_type(&s->cur[0].val.arr[i], PDF_PS_OBJ_FLOAT)) {
+ bbox[i] = (double)s->cur[0].val.arr[i].val.f;
+ }
+ }
+ priv->gsu.gst1.FontBBox.p.x = bbox[0];
+ priv->gsu.gst1.FontBBox.p.y = bbox[1];
+ priv->gsu.gst1.FontBBox.q.x = bbox[2];
+ priv->gsu.gst1.FontBBox.q.y = bbox[3];
+ }
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("FontType"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_INTEGER)) {
+ priv->gsu.gst1.FontType = s->cur[0].val.i;
+ priv->u.t1.pdfi_font_type = s->cur[0].val.i == 1 ? e_pdf_font_type1 : e_pdf_cidfont_type0;
+ }
+ else {
+ priv->gsu.gst1.FontType = 1;
+ priv->u.t1.pdfi_font_type = e_pdf_font_type1;
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("FontMatrix"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_ARRAY) && s->cur[0].size >= 6) {
+ int i;
+ double fmat[6] = { 0.001, 0, 0, 0.001, 0, 0 };
+ for (i = 0; i < 6; i++) {
+ if (pdf_ps_obj_has_type(&s->cur[0].val.arr[i], PDF_PS_OBJ_INTEGER)) {
+ fmat[i] = (double)s->cur[0].val.arr[i].val.i;
+ }
+ else if (pdf_ps_obj_has_type(&s->cur[0].val.arr[i], PDF_PS_OBJ_FLOAT)) {
+ fmat[i] = (double)s->cur[0].val.arr[i].val.f;
+ }
+ }
+ priv->gsu.gst1.FontMatrix.xx = fmat[0];
+ priv->gsu.gst1.FontMatrix.xy = fmat[1];
+ priv->gsu.gst1.FontMatrix.yx = fmat[2];
+ priv->gsu.gst1.FontMatrix.yy = fmat[3];
+ priv->gsu.gst1.FontMatrix.tx = fmat[4];
+ priv->gsu.gst1.FontMatrix.ty = fmat[5];
+ priv->gsu.gst1.orig_FontMatrix = priv->gsu.gst1.FontMatrix;
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("BlueValues"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_ARRAY)) {
+ int i, size = s->cur[0].size < 14 ? s->cur[0].size : 14;
+
+ for (i = 0; i < size; i++) {
+ if (pdf_ps_obj_has_type(&s->cur[0].val.arr[i], PDF_PS_OBJ_INTEGER)) {
+ priv->gsu.gst1.data.BlueValues.values[i] =
+ (float)s->cur[0].val.arr[i].val.i;
+ }
+ else if (pdf_ps_obj_has_type(&s->cur[0].val.arr[i], PDF_PS_OBJ_FLOAT)) {
+ priv->gsu.gst1.data.BlueValues.values[i] = s->cur[0].val.arr[i].val.f;
+ }
+ else {
+ if (i == 0)
+ priv->gsu.gst1.data.BlueValues.values[i] = 0;
+ else
+ priv->gsu.gst1.data.BlueValues.values[i] = priv->gsu.gst1.data.BlueValues.values[i - 1] + 1;
+ }
+ }
+ priv->gsu.gst1.data.BlueValues.count = size;
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("BlueScale"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_INTEGER)) {
+ priv->gsu.gst1.data.BlueScale = (float)s->cur[0].val.i;
+ }
+ else if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_FLOAT)) {
+ priv->gsu.gst1.data.BlueScale = (float)s->cur[0].val.f;
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("StdHW"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_ARRAY)) {
+ if (pdf_ps_obj_has_type(&s->cur[0].val.arr[0], PDF_PS_OBJ_INTEGER)) {
+ priv->gsu.gst1.data.StdHW.values[0] = (float)s->cur[0].val.arr[0].val.i;
+ priv->gsu.gst1.data.StdHW.count = 1;
+ }
+ else if (pdf_ps_obj_has_type(&s->cur[0].val.arr[0], PDF_PS_OBJ_FLOAT)) {
+ priv->gsu.gst1.data.StdHW.values[0] = s->cur[0].val.arr[0].val.f;
+ priv->gsu.gst1.data.StdHW.count = 1;
+ }
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("StdVW"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_ARRAY)) {
+ if (pdf_ps_obj_has_type(&s->cur[0].val.arr[0], PDF_PS_OBJ_INTEGER)) {
+ priv->gsu.gst1.data.StdVW.values[0] = (float)s->cur[0].val.arr[0].val.i;
+ priv->gsu.gst1.data.StdVW.count = 1;
+ }
+ else if (pdf_ps_obj_has_type(&s->cur[0].val.arr[0], PDF_PS_OBJ_FLOAT)) {
+ priv->gsu.gst1.data.StdVW.values[0] = s->cur[0].val.arr[0].val.f;
+ priv->gsu.gst1.data.StdVW.count = 1;
+ }
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("StemSnapH"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_ARRAY)) {
+ int i, size = s->cur[0].size > 12 ? 12 : s->cur[0].size;
+
+ for (i = 0; i < size; i++) {
+ if (pdf_ps_obj_has_type(&s->cur[0].val.arr[i], PDF_PS_OBJ_INTEGER)) {
+ priv->gsu.gst1.data.StemSnapH.values[i] = (float)s->cur[0].val.arr[i].val.i;
+ }
+ else if (pdf_ps_obj_has_type(&s->cur[0].val.arr[i], PDF_PS_OBJ_FLOAT)) {
+ priv->gsu.gst1.data.StemSnapH.values[i] = s->cur[0].val.arr[i].val.f;
+ }
+ }
+ priv->gsu.gst1.data.StemSnapH.count = size;
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("StemSnapV"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_ARRAY)) {
+ int i, size = s->cur[0].size > 12 ? 12 : s->cur[0].size;
+
+ for (i = 0; i < size; i++) {
+ if (pdf_ps_obj_has_type(&s->cur[0].val.arr[i], PDF_PS_OBJ_INTEGER)) {
+ priv->gsu.gst1.data.StemSnapV.values[i] = (float)s->cur[0].val.arr[i].val.i;
+ }
+ else if (pdf_ps_obj_has_type(&s->cur[0].val.arr[i], PDF_PS_OBJ_FLOAT)) {
+ priv->gsu.gst1.data.StemSnapV.values[i] = s->cur[0].val.arr[i].val.f;
+ }
+ }
+ priv->gsu.gst1.data.StemSnapH.count = size;
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("Encoding"))) {
+ pdf_array *new_enc = NULL;
+
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_NAME)) {
+ pdf_name *pname;
+
+ code = pdfi_name_alloc(s->pdfi_ctx, (byte *) s->cur[0].val.name, s->cur[0].size, (pdf_obj **) &pname);
+ if (code >= 0) {
+ pdfi_countup(pname);
+
+ code = pdfi_create_Encoding(s->pdfi_ctx, (pdf_obj *) pname, NULL, (pdf_obj **) &new_enc);
+ if (code >= 0) {
+ pdfi_countdown(priv->u.t1.Encoding);
+ priv->u.t1.Encoding = new_enc;
+ }
+ pdfi_countdown(pname);
+ }
+ }
+ else if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_ARRAY)) {
+ int i;
+
+ code = pdfi_array_alloc(s->pdfi_ctx, s->cur[0].size, &new_enc);
+ if (code >= 0) {
+ pdfi_countup(new_enc);
+ for (i = 0; i < s->cur[0].size; i++) {
+ pdf_name *n = NULL;
+ byte *nm = (byte *) s->cur[0].val.arr[i].val.name;
+ int nlen = s->cur[0].val.arr[i].size;
+
+ code = pdfi_name_alloc(s->pdfi_ctx, (byte *) nm, nlen, (pdf_obj **) &n);
+ if (code < 0)
+ break;
+ pdfi_countup(n);
+ code = pdfi_array_put(s->pdfi_ctx, new_enc, (uint64_t) i, (pdf_obj *) n);
+ pdfi_countdown(n);
+ if (code < 0)
+ break;
+ }
+ if (code < 0) {
+ pdfi_countdown(new_enc);
+ }
+ else {
+ pdfi_countdown(priv->u.t1.Encoding);
+ priv->u.t1.Encoding = new_enc;
+ new_enc = NULL;
+ }
+ }
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("BlendDesignPositions"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_ARRAY)) {
+ code = pdfi_array_alloc(s->pdfi_ctx, s->cur[0].size, &priv->u.t1.blenddesignpositions);
+ if (code >= 0) {
+ int i, j;
+ pdfi_countup(priv->u.t1.blenddesignpositions);
+
+ for (i = 0; i < s->cur[0].size && code >= 0; i++) {
+ pdf_ps_stack_object_t *so = &s->cur[0].val.arr[i];
+
+ if (pdf_ps_obj_has_type(so, PDF_PS_OBJ_ARRAY)) {
+ pdf_array *sa;
+ code = pdfi_array_alloc(s->pdfi_ctx, so->size, &sa);
+ if (code >= 0) {
+ pdfi_countup(sa);
+ for (j = 0; j < so->size; j++) {
+ pdf_num *n;
+ if (pdf_ps_obj_has_type(&so->val.arr[j], PDF_PS_OBJ_INTEGER)) {
+ code = pdfi_object_alloc(s->pdfi_ctx, PDF_INT, 0, (pdf_obj **)&n);
+ if (code >= 0)
+ n->value.i = so->val.arr[j].val.i;
+ }
+ else if (pdf_ps_obj_has_type(&so->val.arr[j], PDF_PS_OBJ_FLOAT)) {
+ code = pdfi_object_alloc(s->pdfi_ctx, PDF_REAL, 0, (pdf_obj **)&n);
+ if (code >= 0)
+ n->value.d = so->val.arr[j].val.f;
+ }
+ else {
+ code = pdfi_object_alloc(s->pdfi_ctx, PDF_INT, 0, (pdf_obj **)&n);
+ if (code >= 0)
+ n->value.i = 0;
+ }
+ if (code < 0)
+ break;
+ pdfi_countup(n);
+ code = pdfi_array_put(s->pdfi_ctx, sa, j, (pdf_obj *)n);
+ pdfi_countdown(n);
+ if (code < 0) break;
+ }
+ }
+ if (code >= 0) {
+ pdfi_array_put(s->pdfi_ctx, priv->u.t1.blenddesignpositions, i, (pdf_obj *)sa);
+ }
+ pdfi_countdown(sa);
+ }
+ }
+ }
+
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("BlendAxisTypes"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_ARRAY)) {
+ int i;
+ code = pdfi_array_alloc(s->pdfi_ctx, s->cur[0].size, &priv->u.t1.blendaxistypes);
+ if (code >= 0) {
+ pdfi_countup(priv->u.t1.blendaxistypes);
+ for (i = 0; i < s->cur[0].size; i++) {
+ pdf_ps_stack_object_t *so = &s->cur[0].val.arr[i];
+ pdf_name *n;
+ if (pdf_ps_obj_has_type(so, PDF_PS_OBJ_NAME)) {
+ code = pdfi_object_alloc(s->pdfi_ctx, PDF_NAME, so->size, (pdf_obj **)&n);
+ if (code >= 0) {
+ pdfi_countup(n);
+ memcpy(n->data, so->val.name, so->size);
+ n->length = so->size;
+ code = pdfi_array_put(s->pdfi_ctx, priv->u.t1.blendaxistypes, i, (pdf_obj *)n);
+ pdfi_countdown(n);
+ }
+ }
+ if (code < 0)
+ break;
+ }
+ }
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("BlendDesignMap"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_ARRAY)) {
+ int i, j, k;
+ pdf_ps_stack_object_t *arr1 = &s->cur[0], *arr2, *arr3;
+ pdf_array *parr2, *parr3;
+ code = pdfi_array_alloc(s->pdfi_ctx, arr1->size, &priv->u.t1.blenddesignmap);
+ if (code >= 0) {
+ pdfi_countup(priv->u.t1.blenddesignmap);
+ for (i = 0; i < arr1->size && code >= 0; i++) {
+ if (pdf_ps_obj_has_type(&arr1->val.arr[i], PDF_PS_OBJ_ARRAY)) {
+ arr2 = &arr1->val.arr[i];
+ code = pdfi_array_alloc(s->pdfi_ctx, arr2->size, &parr2);
+ if (code < 0)
+ break;
+ for (j = 0; j < arr2->size; j++) {
+ pdf_num *n;
+
+ arr3 = &arr2->val.arr[j];
+ code = pdfi_array_alloc(s->pdfi_ctx, arr3->size, &parr3);
+ if (code < 0)
+ break;
+
+ for (k = 0; k < arr3->size; k++) {
+ if (pdf_ps_obj_has_type(&arr3->val.arr[k], PDF_PS_OBJ_INTEGER)) {
+ code = pdfi_object_alloc(s->pdfi_ctx, PDF_INT, 0, (pdf_obj **)&n);
+ if (code >= 0)
+ n->value.i = arr3->val.arr[k].val.i;
+ }
+ else if (pdf_ps_obj_has_type(&arr1->val.arr[i], PDF_PS_OBJ_FLOAT)) {
+ code = pdfi_object_alloc(s->pdfi_ctx, PDF_REAL, 0, (pdf_obj **)&n);
+ if (code >= 0)
+ n->value.d = arr3->val.arr[k].val.f;
+ }
+ else {
+ code = pdfi_object_alloc(s->pdfi_ctx, PDF_INT, 0, (pdf_obj **)&n);
+ if (code >= 0)
+ n->value.i = 0;
+ }
+ if (code < 0)
+ break;
+ pdfi_countup(n);
+ code = pdfi_array_put(s->pdfi_ctx, parr3, k, (pdf_obj *)n);
+ pdfi_countdown(n);
+ if (code < 0)
+ break;
+ }
+ if (code < 0)
+ break;
+ pdfi_countup(parr3);
+ code = pdfi_array_put(s->pdfi_ctx, parr2, j, (pdf_obj *)parr3);
+ pdfi_countdown(parr3);
+ }
+ if (code < 0)
+ break;
+ pdfi_countup(parr2);
+ code = pdfi_array_put(s->pdfi_ctx, priv->u.t1.blenddesignmap, i, (pdf_obj *)parr2);
+ pdfi_countdown(parr2);
+ }
+ }
+ }
+ }
+ }
+ else if (!memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("WeightVector"))) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_ARRAY)) {
+ int i;
+ for (i = 0; i < s->cur[0].size; i++) {
+ if (pdf_ps_obj_has_type(&s->cur[0].val.arr[i], PDF_PS_OBJ_INTEGER)) {
+ priv->gsu.gst1.data.WeightVector.values[i] = s->cur[0].val.arr[i].val.i;
+ }
+ else if (pdf_ps_obj_has_type(&s->cur[0].val.arr[i], PDF_PS_OBJ_FLOAT)) {
+ priv->gsu.gst1.data.WeightVector.values[i] = s->cur[0].val.arr[i].val.f;
+ }
+ else {
+ priv->gsu.gst1.data.WeightVector.values[i] = 0;
+ }
+ }
+ priv->gsu.gst1.data.WeightVector.count = s->cur[0].size;
+ }
+ }
+ }
+
+ code2 = pdf_ps_stack_pop(s, 2);
+ if (code < 0)
+ return code;
+ else
+ return code2;
+}
+
+static int
+ps_font_true_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ (void)mem;
+ return pdf_ps_stack_push_boolean(s, true);
+}
+
+static int
+ps_font_false_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ (void)mem;
+ return pdf_ps_stack_push_boolean(s, false);
+}
+
+static int
+ps_font_dict_begin_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ (void)mem;
+ return pdf_ps_stack_push_dict_mark(s);
+}
+
+static int
+ps_font_dict_end_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ int dsize = pdf_ps_stack_count_to_mark(s, PDF_PS_OBJ_DICT_MARK);
+
+ (void)mem;
+ if (dsize >= 0)
+ return pdf_ps_stack_pop(s, dsize + 1); /* Add one for the mark object */
+ else
+ return 0;
+}
+
+static stream *
+push_eexec_filter(gs_memory_t *mem, byte *buf, byte *bufend)
+{
+ stream *fs, *ffs = NULL;
+ stream *sstrm;
+ stream_exD_state *st;
+ byte *strbuf;
+
+ sstrm = file_alloc_stream(mem, "push_eexec_filter(buf stream)");
+ if (sstrm == NULL)
+ return NULL;
+
+ /* Because of streams <shrug!> we advance the buffer one byte */
+ buf++;
+ sread_string(sstrm, buf, bufend - buf);
+ sstrm->close_at_eod = false;
+
+ fs = s_alloc(mem, "push_eexec_filter(fs)");
+ strbuf = gs_alloc_bytes(mem, 4096, "push_eexec_filter(buf)");
+ st = gs_alloc_struct(mem, stream_exD_state, s_exD_template.stype, "push_eexec_filter(st)");
+ if (fs == NULL || st == NULL || strbuf == NULL) {
+ sclose(sstrm);
+ gs_free_object(mem, sstrm, "push_eexec_filter(buf stream)");
+ gs_free_object(mem, fs, "push_eexec_filter(fs)");
+ gs_free_object(mem, st, "push_eexec_filter(st)");
+ goto done;
+ }
+ memset(st, 0x00, sizeof(stream_exD_state));
+
+ s_std_init(fs, strbuf, 69, &s_filter_read_procs, s_mode_read);
+ st->memory = mem;
+ st->templat = &s_exD_template;
+ fs->state = (stream_state *) st;
+ fs->procs.process = s_exD_template.process;
+ fs->strm = sstrm;
+ (*s_exD_template.set_defaults) ((stream_state *) st);
+ st->cstate = 55665;
+ st->binary = -1;
+ st->lenIV = 4;
+ st->keep_spaces = true;
+ (*s_exD_template.init) ((stream_state *) st);
+ fs->close_at_eod = false;
+ ffs = fs;
+ done:
+ return ffs;
+}
+
+static void
+pop_eexec_filter(gs_memory_t *mem, stream *s)
+{
+ stream *src = s->strm;
+ byte *b = s->cbuf;
+
+ sclose(s);
+ gs_free_object(mem, s, "pop_eexec_filter(s)");
+ gs_free_object(mem, b, "pop_eexec_filter(b)");
+ if (src)
+ sclose(src);
+ gs_free_object(mem, src, "pop_eexec_filter(strm)");
+}
+
+/* We decode the eexec data in place */
+static int
+ps_font_eexec_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ stream *strm;
+ int c;
+
+ strm = push_eexec_filter(mem, buf, bufend);
+ while (1) {
+ c = sgetc(strm);
+ if (c < 0)
+ break;
+ *buf = (byte) c;
+ buf++;
+ }
+ pop_eexec_filter(mem, strm);
+
+ return 0;
+}
+
+/* Normally, for us, "array" is a NULL op.
+ *The exception is when the name /Subrs is two objects
+ *down from the top of the stack, then we can use this call
+ *to record how many subrs we expect, and allocate space for them
+ */
+static int
+ps_font_array_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ ps_font_interp_private *priv = (ps_font_interp_private *) s->client_data;
+ int code = 0;
+
+ if (pdf_ps_stack_count(s) < 2) {
+ return pdf_ps_stack_pop(s, 1);
+ }
+ if (pdf_ps_obj_has_type(&s->cur[-1], PDF_PS_OBJ_NAME) &&
+ pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_INTEGER) &&
+ !memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("Subrs"))) {
+
+ if (s->cur[0].val.i > 0) {
+ if (priv->u.t1.Subrs != NULL) {
+ int i;
+ for (i = 0; i < priv->u.t1.NumSubrs; i++) {
+ gs_free_object(mem, priv->u.t1.Subrs[i].data, "ps_font_array_func(Subrs[i])");
+ }
+ gs_free_object(mem, priv->u.t1.Subrs, "ps_font_array_func(Subrs)");
+ }
+
+ priv->u.t1.Subrs = (gs_string *) gs_alloc_bytes(mem, s->cur[0].val.i *sizeof(gs_string), "ps_font_array_func(Subrs)");
+ if (priv->u.t1.Subrs == NULL) {
+ return_error(gs_error_VMerror);
+ }
+ memset(priv->u.t1.Subrs, 0x00, s->cur[0].val.i * sizeof(gs_string));
+ }
+ priv->u.t1.NumSubrs = s->cur[0].val.i;
+ code = pdf_ps_stack_pop(s, 1);
+ }
+ else if (pdf_ps_obj_has_type(&s->cur[-1], PDF_PS_OBJ_NAME) &&
+ pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_INTEGER) &&
+ !memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("Encoding"))) {
+ /* We're defining a custom encoding array */
+ pdf_ps_stack_object_t *arr = NULL;
+ int size = s->cur[0].val.i;
+
+ if (size > 0) {
+ arr = (pdf_ps_stack_object_t *) gs_alloc_bytes(mem, size *sizeof(pdf_ps_stack_object_t), "ps_font_array_func(encoding array)");
+ if (arr != NULL) {
+ code = pdf_ps_stack_pop(s, 1);
+ if (code < 0) {
+ gs_free_object(mem, arr, "ps_font_array_func(encoding array)");
+ }
+ else {
+ int i;
+
+ for (i = 0; i < size; i++) {
+ pdf_ps_make_name(&arr[i], (byte *) notdefnamestr, strlen(notdefnamestr));
+ }
+ code = pdf_ps_stack_push_array(s, arr, size);
+ }
+ }
+ else {
+ code = gs_note_error(gs_error_VMerror);
+ }
+ }
+ }
+ return code;
+}
+
+/* Normally, for us, "dict" is a NULL op.
+ *The exception is when the name /CharStrings is two objects
+ *down from the top of the stack, then we can use this call
+ *to record how many charstrings we expect, and allocate space for them
+ */
+static int
+ps_font_dict_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ ps_font_interp_private *priv = (ps_font_interp_private *) s->client_data;
+
+ if (pdf_ps_stack_count(s) < 2) {
+ return pdf_ps_stack_pop(s, 1);
+ }
+ if (pdf_ps_obj_has_type(&s->cur[-1], PDF_PS_OBJ_NAME) &&
+ pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_INTEGER) &&
+ !memcmp(s->cur[-1].val.name, PDF_PS_OPER_NAME_AND_LEN("CharStrings"))) {
+ int code;
+ pdf_dict *d = NULL;
+
+ if (priv->u.t1.CharStrings == NULL) {
+ code = pdfi_dict_alloc(s->pdfi_ctx, s->cur[0].val.i, &d);
+ if (code < 0) {
+ priv->u.t1.CharStrings = NULL;
+ (void)pdf_ps_stack_pop(s, 1);
+ return code;
+ }
+
+ priv->u.t1.CharStrings = d;
+ pdfi_countup(priv->u.t1.CharStrings);
+ }
+ }
+ return pdf_ps_stack_pop(s, 1);
+}
+
+static int
+pdf_ps_pop2_oper_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ return pdf_ps_stack_pop(s, 2);
+}
+
+static int
+pdf_ps_pop4_oper_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ return pdf_ps_stack_pop(s, 4);
+}
+
+static int
+pdf_ps_standardencoding_oper_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ return pdf_ps_stack_push_name(s, (byte *) "StandardEncoding", 16);
+}
+
+/* { string currentfile exch readstring pop } */
+static int
+pdf_ps_RD_oper_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ ps_font_interp_private *priv = (ps_font_interp_private *) s->client_data;
+ int code;
+ int size = 0;
+
+ if (pdf_ps_stack_count(s) >= 1) {
+ if (priv->u.t1.Subrs != NULL && priv->u.t1.CharStrings == NULL) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_INTEGER) &&
+ pdf_ps_obj_has_type(&s->cur[-1], PDF_PS_OBJ_INTEGER)) {
+ int inx = s->cur[-1].val.i;
+
+ size = s->cur[0].val.i;
+ buf++;
+ if (buf + size < bufend) {
+ priv->u.t1.Subrs[inx].data =
+ gs_alloc_bytes(mem, size, "pdf_ps_RD_oper_func(subr string)");
+ if (priv->u.t1.Subrs[inx].data == NULL) {
+ (void)pdf_ps_stack_pop(s, 2);
+ return_error(gs_error_VMerror);
+ }
+ memcpy(priv->u.t1.Subrs[inx].data, buf, size);
+ priv->u.t1.Subrs[inx].size = size;
+ }
+ }
+ }
+ else if (priv->u.t1.CharStrings != NULL) {
+ if (pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_INTEGER) &&
+ pdf_ps_obj_has_type(&s->cur[-1], PDF_PS_OBJ_NAME)) {
+ pdf_string *str = NULL;
+ pdf_obj *key = NULL;
+ bool key_known;
+
+ size = s->cur[0].val.i;
+ buf++;
+ code = pdfi_name_alloc(s->pdfi_ctx, (byte *) s->cur[-1].val.name, s->cur[-1].size, &key);
+ if (code < 0) {
+ (void)pdf_ps_stack_pop(s, 2);
+ return code;
+ }
+ pdfi_countup(key);
+
+ if (buf + size < bufend) {
+ code = pdfi_dict_known_by_key(s->pdfi_ctx, priv->u.t1.CharStrings, (pdf_name *)key, &key_known);
+ if (code >=0 && key_known != true) {
+ code = pdfi_object_alloc(s->pdfi_ctx, PDF_STRING, size, (pdf_obj **) &str);
+ if (code < 0) {
+ pdfi_countdown(key);
+ (void)pdf_ps_stack_pop(s, 2);
+ return code;
+ }
+ pdfi_countup(str);
+ memcpy(str->data, buf, size);
+
+ code = pdfi_dict_put_obj(s->pdfi_ctx, priv->u.t1.CharStrings, key, (pdf_obj *) str);
+ if (code < 0) {
+ pdfi_countdown(str);
+ pdfi_countdown(key);
+ (void)pdf_ps_stack_pop(s, 2);
+ return code;
+ }
+ }
+ }
+ pdfi_countdown(str);
+ pdfi_countdown(key);
+ }
+ }
+ code = pdf_ps_stack_pop(s, 2);
+ return code < 0 ? code : size + 1;
+ }
+ return 0;
+}
+
+static int
+pdf_ps_put_oper_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend)
+{
+ int code;
+
+ if ((code = pdf_ps_stack_count(s)) < 4) {
+ return 0;
+ }
+
+ if (pdf_ps_obj_has_type(&s->cur[-3], PDF_PS_OBJ_NAME) &&
+ !memcmp(s->cur[-3].val.name, PDF_PS_OPER_NAME_AND_LEN("Encoding")) &&
+ pdf_ps_obj_has_type(&s->cur[-2], PDF_PS_OBJ_ARRAY) &&
+ pdf_ps_obj_has_type(&s->cur[-1], PDF_PS_OBJ_INTEGER) &&
+ pdf_ps_obj_has_type(&s->cur[0], PDF_PS_OBJ_NAME)) {
+ if (s->cur[-1].val.i < s->cur[-2].size) {
+ pdf_ps_make_name(&s->cur[-2].val.arr[s->cur[-1].val.i], s->cur[0].val.name, s->cur[0].size);
+ }
+ }
+
+ code = pdf_ps_stack_pop(s, 2);
+ return code;
+}
+
+static pdf_ps_oper_list_t ps_font_oper_list[] = {
+ {PDF_PS_OPER_NAME_AND_LEN("RD"), pdf_ps_RD_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("-|"), pdf_ps_RD_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("|"), pdf_ps_put_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("findresource"), clear_stack_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("dict"), ps_font_dict_func},
+ {PDF_PS_OPER_NAME_AND_LEN("begin"), ps_font_dict_begin_func},
+ {PDF_PS_OPER_NAME_AND_LEN("end"), ps_font_dict_end_func},
+ {PDF_PS_OPER_NAME_AND_LEN("pop"), ps_pdf_null_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("def"), ps_font_def_func},
+ {PDF_PS_OPER_NAME_AND_LEN("dup"), ps_pdf_null_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("defineresource"), clear_stack_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("definefont"), clear_stack_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("readonly"), ps_pdf_null_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("true"), ps_font_true_func},
+ {PDF_PS_OPER_NAME_AND_LEN("false"), ps_font_false_func},
+ {PDF_PS_OPER_NAME_AND_LEN("eexec"), ps_font_eexec_func},
+ {PDF_PS_OPER_NAME_AND_LEN("array"), ps_font_array_func},
+ {PDF_PS_OPER_NAME_AND_LEN("known"), pdf_ps_pop_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("if"), pdf_ps_pop_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("ifelse"), pdf_ps_pop2_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("for"), pdf_ps_pop4_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("put"), pdf_ps_put_oper_func},
+ {PDF_PS_OPER_NAME_AND_LEN("StandardEncoding"), pdf_ps_standardencoding_oper_func},
+ {NULL, 0, NULL}
+};
+
+int
+pdfi_read_ps_font(pdf_context *ctx, pdf_dict *font_dict, byte *fbuf, int fbuflen, ps_font_interp_private *ps_font_priv)
+{
+ int code = 0;
+ pdf_ps_ctx_t ps_font_ctx;
+
+ code = pdfi_pscript_stack_init(ctx, ps_font_oper_list, ps_font_priv, &ps_font_ctx);
+ if (code < 0)
+ goto error_out;
+
+ code = pdfi_pscript_interpret(&ps_font_ctx, fbuf, fbuflen);
+ pdfi_pscript_stack_finit(&ps_font_ctx);
+ /* We have several files that have a load of garbage data in the stream after the font is defined,
+ and that can end up in a stackoverflow error, even though we have a complete font. Override it
+ and let the Type 1 specific code decide for itself if it can use the font.
+ */
+ if (code == gs_error_stackoverflow)
+ code = 0;
+
+ return code;
+ error_out:
+ code = gs_error_invalidfont;
+ return code;
+}
diff --git a/pdf/pdf_fontps.h b/pdf/pdf_fontps.h
new file mode 100644
index 00000000..45810a28
--- /dev/null
+++ b/pdf/pdf_fontps.h
@@ -0,0 +1,351 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* common code for Postscript-type font handling */
+
+#ifndef PDF_FONTPS_H
+#define PDF_FONTPS_H
+
+#include "gxfont1.h" /* for gs_font_type1_s */
+
+typedef enum
+{
+ PDF_PS_OBJ_NULL,
+ PDF_PS_OBJ_INTEGER,
+ PDF_PS_OBJ_FLOAT,
+ PDF_PS_OBJ_STRING,
+ PDF_PS_OBJ_NAME,
+ PDF_PS_OBJ_ARRAY,
+ PDF_PS_OBJ_MARK,
+ PDF_PS_OBJ_TRUE,
+ PDF_PS_OBJ_FALSE,
+ PDF_PS_OBJ_ARR_MARK,
+ PDF_PS_OBJ_DICT_MARK,
+ PDF_PS_OBJ_STACK_TOP,
+ PDF_PS_OBJ_STACK_BOTTOM
+} pdf_ps_obj_type;
+
+typedef struct pdf_ps_stack_object_s pdf_ps_stack_object_t;
+
+struct pdf_ps_stack_object_s
+{
+ pdf_ps_obj_type type;
+ int size;
+ union v {
+ int i;
+ float f;
+ byte *string;
+ byte *name;
+ pdf_ps_stack_object_t *arr;
+ } val;
+};
+
+/* The maximum size of a set of a single "block" is 100 "items"
+ the worst of which is cid ranges which take three objects
+ (lo character code, hi character, low cid) for each item.
+ Thus we need an available stack depth of up to 300 objects.
+ Allowing for possible bad behaviour, 350 seems like a safe
+ size. There are stack limit guard entries at the top and bottom
+ */
+typedef struct pdf_ps_ctx_s pdf_ps_ctx_t;
+
+#define PDF_PS_OPER_NAME_AND_LEN(s) (const byte *)s, sizeof(s) - 1
+
+typedef struct {
+ const byte *opname;
+ const int opnamelen;
+ int (*oper)(gs_memory_t *mem, pdf_ps_ctx_t *stack, byte *buf, byte *bufend);
+} pdf_ps_oper_list_t;
+
+#define PDF_PS_STACK_SIZE 360
+#define PDF_PS_STACK_GUARDS 1
+#define PDF_PS_STACK_GROW_SIZE PDF_PS_STACK_SIZE + 2 * PDF_PS_STACK_GUARDS
+#define PDF_PS_STACK_MAX PDF_PS_STACK_SIZE * 16 /* Arbitrary value.... */
+struct pdf_ps_ctx_s
+{
+ pdf_context *pdfi_ctx;
+ pdf_ps_stack_object_t *cur; /* current top of the stack */
+ pdf_ps_stack_object_t *toplim; /* the upper limit of the stack */
+ pdf_ps_stack_object_t *stack;
+ pdf_ps_oper_list_t *ops;
+ void *client_data;
+};
+
+
+typedef struct {
+ union {
+ pdf_font_type1 t1;
+ pdf_cidfont_type0 cidt0;
+ } u;
+ union {
+ gs_font_type1 gst1;
+ } gsu;
+} ps_font_interp_private;
+
+
+int pdfi_read_ps_font(pdf_context *ctx, pdf_dict *font_dict, byte *fbuf, int fbuflen, ps_font_interp_private *ps_font_priv);
+
+int pdfi_pscript_stack_init(pdf_context *pdfi_ctx, pdf_ps_oper_list_t *ops, void *client_data, pdf_ps_ctx_t *s);
+void pdfi_pscript_stack_finit(pdf_ps_ctx_t *s);
+int pdfi_pscript_interpret(pdf_ps_ctx_t *cs, byte *pspdfbuf, int64_t buflen);
+
+/* Begin default operator functions */
+int ps_pdf_null_oper_func(gs_memory_t *mem, pdf_ps_ctx_t *stack, byte *buf, byte *bufend);
+int clear_stack_oper_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend);
+int pdf_ps_pop_oper_func(gs_memory_t *mem, pdf_ps_ctx_t *s, byte *buf, byte *bufend);
+int pdf_ps_pop_and_pushmark_func(gs_memory_t *mem, pdf_ps_ctx_t *stack, byte *buf, byte *bufend);
+/* End default operator functions */
+
+static inline void pdf_ps_make_null(pdf_ps_stack_object_t *obj)
+{
+ obj->type = PDF_PS_OBJ_NULL;
+ obj->size = 0;
+ memset(&obj->val, 0x00, sizeof(obj->val));
+}
+static inline void pdf_ps_make_array_mark(pdf_ps_stack_object_t *obj)
+{
+ obj->type = PDF_PS_OBJ_ARR_MARK;
+ obj->size = 0;
+}
+static inline void pdf_ps_make_dict_mark(pdf_ps_stack_object_t *obj)
+{
+ obj->type = PDF_PS_OBJ_DICT_MARK;
+ obj->size = 0;
+}
+static inline void pdf_ps_make_mark(pdf_ps_stack_object_t *obj)
+{
+ obj->type = PDF_PS_OBJ_MARK;
+ obj->size = 0;
+}
+static inline void pdf_ps_make_int(pdf_ps_stack_object_t *obj, int val)
+{
+ obj->type = PDF_PS_OBJ_INTEGER;
+ obj->size = 0;
+ obj->val.i = val;
+}
+static inline void pdf_ps_make_float(pdf_ps_stack_object_t *obj, float fval)
+{
+ obj->type = PDF_PS_OBJ_FLOAT;
+ obj->size = 0;
+ obj->val.f = fval;
+}
+static inline void pdf_ps_make_string(pdf_ps_stack_object_t *obj, byte *str, int len)
+{
+ obj->type = PDF_PS_OBJ_STRING;
+ obj->size = len;
+ obj->val.string = str;
+}
+static inline void pdf_ps_make_name(pdf_ps_stack_object_t *obj, byte *nm, int len)
+{
+ obj->type = PDF_PS_OBJ_NAME;
+ obj->size = len;
+ obj->val.name = nm;
+}
+static inline void pdf_ps_make_array(pdf_ps_stack_object_t *obj, pdf_ps_stack_object_t *obj2, int len)
+{
+ obj->type = PDF_PS_OBJ_ARRAY;
+ obj->size = len;
+ obj->val.arr = obj2;
+}
+static inline void pdf_ps_make_boolean(pdf_ps_stack_object_t *obj, bool b)
+{
+ obj->type = b ? PDF_PS_OBJ_TRUE : PDF_PS_OBJ_FALSE;
+ obj->size = 0;
+}
+
+static inline bool pdf_ps_obj_has_type(pdf_ps_stack_object_t *o, pdf_ps_obj_type t)
+{
+ return o->type == t;
+}
+
+/* The stack can grow, but doesn't shrink, just gets destroyed
+ when we're done interpreting
+ */
+static inline int pdf_ps_stack_push(pdf_ps_ctx_t *s)
+{
+ /* Extending the stack pretty inefficient, but it shouldn't happen often
+ for valid files
+ */
+ if (s->cur + 1 >= s->toplim - 1) {
+ int i, currsize = s->toplim - s->stack;
+ int newsize = currsize + PDF_PS_STACK_GROW_SIZE;
+ int newsizebytes = newsize * sizeof(pdf_ps_stack_object_t);
+ pdf_ps_stack_object_t *nstack;
+
+ if (newsize < PDF_PS_STACK_MAX) {
+ nstack = (pdf_ps_stack_object_t *)gs_alloc_bytes(s->pdfi_ctx->memory, newsizebytes, "pdf_ps_stack_push(nstack)");
+ if (nstack != NULL) {
+ memcpy(nstack, s->stack, (currsize - 1) * sizeof(pdf_ps_stack_object_t));
+
+ for (i = 0; i < PDF_PS_STACK_GUARDS; i++)
+ nstack[newsize - PDF_PS_STACK_GUARDS + i].type = PDF_PS_OBJ_STACK_TOP;
+
+ for (i = currsize - 2; i < newsize - PDF_PS_STACK_GUARDS; i++) {
+ pdf_ps_make_null(&(nstack[i]));
+ }
+
+ gs_free_object(s->pdfi_ctx->memory, s->stack, "pdf_ps_stack_push(s->stack)");
+ s->stack = nstack;
+ s->cur = s->stack + currsize - 1;
+ s->toplim = s->stack + newsize - PDF_PS_STACK_GROW_SIZE;
+ }
+ }
+ }
+ s->cur++;
+ if (pdf_ps_obj_has_type(s->cur, PDF_PS_OBJ_STACK_TOP))
+ return_error(gs_error_stackoverflow);
+ if (pdf_ps_obj_has_type(s->cur, PDF_PS_OBJ_STACK_BOTTOM))
+ return_error(gs_error_stackunderflow);
+ return 0;
+}
+
+static inline void pdf_ps_free_array_contents(pdf_ps_ctx_t *s, pdf_ps_stack_object_t *o)
+{
+ int i;
+ for (i = 0; i < o->size; i++) {
+ if (pdf_ps_obj_has_type(&o->val.arr[i], PDF_PS_OBJ_ARRAY)) {
+ pdf_ps_stack_object_t *po = o->val.arr[i].val.arr;
+ pdf_ps_free_array_contents(s, &o->val.arr[i]);
+ gs_free_object(s->pdfi_ctx->memory, po, "pdf_ps_free_array_contents");
+ }
+ pdf_ps_make_null(&o->val.arr[i]);
+ }
+}
+
+static inline int pdf_ps_stack_pop(pdf_ps_ctx_t *s, unsigned int n)
+{
+ int n2 = n > s->cur - &(s->stack[0]) ? s->cur - &(s->stack[0]) : n;
+ while(n2--) {
+ /* We only have one dimensional arrays to worry about */
+ if (pdf_ps_obj_has_type(s->cur, PDF_PS_OBJ_ARRAY)) {
+ pdf_ps_free_array_contents(s, s->cur);
+ gs_free_object(s->pdfi_ctx->memory, s->cur->val.arr, "pdf_ps_stack_pop(s->cur->val.arr)");
+ }
+ pdf_ps_make_null(s->cur);
+ s->cur--;
+ if (pdf_ps_obj_has_type(s->cur, PDF_PS_OBJ_STACK_TOP))
+ return_error(gs_error_stackoverflow);
+ if (pdf_ps_obj_has_type(s->cur, PDF_PS_OBJ_STACK_BOTTOM))
+ return_error(gs_error_stackunderflow);
+ }
+ return 0;
+}
+
+static inline int pdf_ps_stack_push_arr_mark(pdf_ps_ctx_t *s)
+{
+ int code = pdf_ps_stack_push(s);
+ if (code < 0) return code;
+
+ pdf_ps_make_array_mark(s->cur);
+ return 0;
+}
+
+static inline int pdf_ps_stack_push_dict_mark(pdf_ps_ctx_t *s)
+{
+ int code = pdf_ps_stack_push(s);
+ if (code < 0) return code;
+
+ pdf_ps_make_dict_mark(s->cur);
+ return 0;
+}
+
+static inline int pdf_ps_stack_push_mark(pdf_ps_ctx_t *s)
+{
+ int code = pdf_ps_stack_push(s);
+ if (code < 0) return code;
+
+ pdf_ps_make_mark(s->cur);
+ return 0;
+}
+
+static inline int pdf_ps_stack_push_int(pdf_ps_ctx_t *s, int i)
+{
+ int code = pdf_ps_stack_push(s);
+ if (code < 0) return code;
+
+ pdf_ps_make_int(s->cur, i);
+ return 0;
+}
+
+static inline int pdf_ps_stack_push_float(pdf_ps_ctx_t *s, float f)
+{
+ int code = pdf_ps_stack_push(s);
+ if (code < 0) return code;
+
+ pdf_ps_make_float(s->cur, f);
+ return 0;
+}
+
+static inline int pdf_ps_stack_push_string(pdf_ps_ctx_t *s, byte *str, int len)
+{
+ int code = pdf_ps_stack_push(s);
+ if (code < 0) return code;
+
+ pdf_ps_make_string(s->cur, str, len);
+ return 0;
+}
+
+static inline int pdf_ps_stack_push_name(pdf_ps_ctx_t *s, byte *nm, int len)
+{
+ int code = pdf_ps_stack_push(s);
+ if (code < 0) return code;
+
+ pdf_ps_make_name(s->cur, nm, len);
+ return 0;
+}
+
+static inline int pdf_ps_stack_push_array(pdf_ps_ctx_t *s, pdf_ps_stack_object_t *a, int len)
+{
+ int code = pdf_ps_stack_push(s);
+ if (code < 0) return code;
+
+ pdf_ps_make_array(s->cur, a, len);
+ return 0;
+}
+
+static inline int pdf_ps_stack_push_boolean(pdf_ps_ctx_t *s, bool b)
+{
+ int code = pdf_ps_stack_push(s);
+ if (code < 0) return code;
+
+ pdf_ps_make_boolean(s->cur, b);
+ return 0;
+}
+
+static inline pdf_ps_obj_type pdf_ps_stack_obj_type(pdf_ps_ctx_t *s)
+{
+ return s->cur->type;
+}
+
+static inline int pdf_ps_stack_count_to_mark(pdf_ps_ctx_t *s, pdf_ps_obj_type mtype)
+{
+ int i = gs_error_stackunderflow, depth = s->cur - &(s->stack[0]) + 1;
+ for (i = 0; i < depth; i++) {
+ if (s->cur[-i].type == PDF_PS_OBJ_STACK_BOTTOM) {
+ i = gs_note_error(gs_error_unmatchedmark);
+ break;
+ }
+ if (s->cur[-i].type == mtype)
+ break;
+ }
+ return i;
+}
+
+static inline int pdf_ps_stack_count(pdf_ps_ctx_t *s)
+{
+ return s->cur - &(s->stack[1]);
+}
+
+#endif
diff --git a/pdf/pdf_func.c b/pdf/pdf_func.c
new file mode 100644
index 00000000..9b7d5bb7
--- /dev/null
+++ b/pdf/pdf_func.c
@@ -0,0 +1,878 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* function creation for the PDF interpreter */
+
+#include "pdf_int.h"
+#include "pdf_stack.h"
+#include "pdf_func.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_file.h"
+#include "pdf_loop_detect.h"
+
+#include "gsdsrc.h"
+#include "gsfunc0.h"
+#include "gsfunc3.h"
+#include "gsfunc4.h"
+#include "stream.h"
+
+static int pdfi_build_sub_function(pdf_context *ctx, gs_function_t ** ppfn, const float *shading_domain, int num_inputs, pdf_obj *stream_obj, pdf_dict *page_dict);
+
+#define NUMBERTOKENSIZE 16
+#define OPTOKENSIZE 9
+#define TOKENBUFFERSIZE NUMBERTOKENSIZE + 1
+#define NUMOPS 42
+
+typedef struct op_struct {
+ unsigned char length;
+ gs_PtCr_opcode_t code;
+ unsigned char op[8];
+}op_struct_t;
+
+static const op_struct_t ops_table[] = {
+ {(unsigned char)2, PtCr_eq, "eq"},
+ {(unsigned char)2, PtCr_ge, "ge"},
+ {(unsigned char)2, PtCr_gt, "gt"},
+ {(unsigned char)2, PtCr_if, "if"},
+ {(unsigned char)2, PtCr_le, "le"},
+ {(unsigned char)2, PtCr_ln, "ln"},
+ {(unsigned char)2, PtCr_lt, "lt"},
+ {(unsigned char)2, PtCr_ne, "ne"},
+ {(unsigned char)2, PtCr_or, "or"},
+
+ {(unsigned char)3, PtCr_abs, "abs"},
+ {(unsigned char)3, PtCr_add, "add"},
+ {(unsigned char)3, PtCr_and, "and"},
+ {(unsigned char)3, PtCr_cos, "cos"},
+ {(unsigned char)3, PtCr_cvi, "cvi"},
+ {(unsigned char)3, PtCr_cvr, "cvr"},
+ {(unsigned char)3, PtCr_div, "div"},
+ {(unsigned char)3, PtCr_dup, "dup"},
+ {(unsigned char)3, PtCr_exp, "exp"},
+ {(unsigned char)3, PtCr_log, "log"},
+ {(unsigned char)3, PtCr_mul, "mul"},
+ {(unsigned char)3, PtCr_mod, "mod"},
+ {(unsigned char)3, PtCr_neg, "neg"},
+ {(unsigned char)3, PtCr_not, "not"},
+ {(unsigned char)3, PtCr_pop, "pop"},
+ {(unsigned char)3, PtCr_sin, "sin"},
+ {(unsigned char)3, PtCr_sub, "sub"},
+ {(unsigned char)3, PtCr_xor, "xor"},
+
+ {(unsigned char)4, PtCr_atan, "atan"},
+ {(unsigned char)4, PtCr_copy, "copy"},
+ {(unsigned char)4, PtCr_exch, "exch"},
+ {(unsigned char)4, PtCr_idiv, "idiv"},
+ {(unsigned char)4, PtCr_roll, "roll"},
+ {(unsigned char)4, PtCr_sqrt, "sqrt"},
+ {(unsigned char)4, PtCr_true, "true"},
+
+ {(unsigned char)5, PtCr_false, "false"},
+ {(unsigned char)5, PtCr_floor, "floor"},
+ {(unsigned char)5, PtCr_index, "index"},
+ {(unsigned char)5, PtCr_round, "round"},
+
+ {(unsigned char)6, PtCr_else, "ifelse"},
+
+ {(unsigned char)7, PtCr_ceiling, "ceiling"},
+
+ {(unsigned char)8, PtCr_bitshift, "bitshift"},
+ {(unsigned char)8, PtCr_truncate, "truncate"},
+};
+
+/* Fix up an if or ifelse forward reference. */
+static void
+psc_fixup(byte *p, byte *to)
+{
+ int skip = to - (p + 3);
+
+ p[1] = (byte)(skip >> 8);
+ p[2] = (byte)skip;
+}
+static void psc_fixup_ifelse(byte *p)
+{
+ int iflen = (p[0] << 8) + p[1];
+
+ iflen += 3; /* To skip past the 'if' body and the 'else' header */
+ p[0] = (byte)(iflen >> 8);
+ p[1] = (byte)iflen;
+}
+
+/* Store an int in the buffer */
+static int
+put_int(byte **p, int n) {
+ if (n == (byte)n) {
+ if (*p) {
+ (*p)[0] = PtCr_byte;
+ (*p)[1] = (byte)n;
+ *p += 2;
+ }
+ return 2;
+ } else {
+ if (*p) {
+ **p = PtCr_int;
+ memcpy(*p + 1, &n, sizeof(int));
+ *p += sizeof(int) + 1;
+ }
+ return (sizeof(int) + 1);
+ }
+}
+
+/* Store a float in the buffer */
+static int
+put_float(byte **p, float n) {
+ if (*p) {
+ **p = PtCr_float;
+ memcpy(*p + 1, &n, sizeof(float));
+ *p += sizeof(float) + 1;
+ }
+ return (sizeof(float) + 1);
+}
+
+static int
+pdfi_parse_type4_func_stream(pdf_context *ctx, pdf_c_stream *function_stream, int depth, byte *ops, unsigned int *size)
+{
+ int code;
+ byte c;
+ char TokenBuffer[17];
+ unsigned int Size, IsReal;
+ byte *clause = NULL;
+ byte *p = (ops ? ops + *size : NULL);
+
+ do {
+ code = pdfi_read_bytes(ctx, &c, 1, 1, function_stream);
+ if (code < 0)
+ break;
+ switch(c) {
+ case 0x20:
+ case 0x0a:
+ case 0x0d:
+ case 0x09:
+ continue;
+ case '{':
+ if (depth == 0) {
+ depth++;
+ } else {
+ /* recursion, move on 3 bytes, and parse the sub level */
+ if (depth++ == MAX_PSC_FUNCTION_NESTING)
+ return_error (gs_error_syntaxerror);
+ *size += 3;
+ code = pdfi_parse_type4_func_stream(ctx, function_stream, depth + 1, ops, size);
+ depth --;
+ if (code < 0)
+ return code;
+ if (p) {
+ if (clause == NULL) {
+ clause = p;
+ *p = (byte)PtCr_if;
+ psc_fixup(p, ops + *size);
+ } else {
+ *p = (byte)PtCr_else;
+ psc_fixup(p, ops + *size);
+ psc_fixup_ifelse(clause + 1);
+ clause = NULL;
+ }
+ p = ops + *size;
+ }
+ }
+ break;
+ case '}':
+ return *size;
+ break;
+ default:
+ if (clause != NULL)
+ clause = NULL;
+ if ((c >= '0' && c <= '9') || c == '-' || c == '.') {
+ /* parse a number */
+ Size = 1;
+ if (c == '.')
+ IsReal = 1;
+ else
+ IsReal = 0;
+ TokenBuffer[0] = c;
+ do {
+ code = pdfi_read_bytes(ctx, &c, 1, 1, function_stream);
+ if (code < 0)
+ return code;
+ if (code == 0)
+ return_error(gs_error_syntaxerror);
+
+ if (c == '.'){
+ if (IsReal == 1)
+ code = gs_error_syntaxerror;
+ else {
+ TokenBuffer[Size++] = c;
+ IsReal = 1;
+ }
+ } else {
+ if (c >= '0' && c <= '9') {
+ TokenBuffer[Size++] = c;
+ } else
+ break;
+ }
+ if (Size > NUMBERTOKENSIZE)
+ return_error(gs_error_syntaxerror);
+ } while (code >= 0);
+ TokenBuffer[Size] = 0x00;
+ pdfi_unread(ctx, function_stream, &c, 1);
+ if (IsReal == 1) {
+ *size += put_float(&p, atof(TokenBuffer));
+ } else {
+ *size += put_int(&p, atoi(TokenBuffer));
+ }
+ } else {
+ int i, NumOps = sizeof(ops_table) / sizeof(op_struct_t);
+ op_struct_t *Op;
+
+ /* parse an operator */
+ Size = 1;
+ TokenBuffer[0] = c;
+ do {
+ code = pdfi_read_bytes(ctx, &c, 1, 1, function_stream);
+ if (code < 0)
+ return code;
+ if (code == 0)
+ return_error(gs_error_syntaxerror);
+ if (c == 0x20 || c == 0x09 || c == 0x0a || c == 0x0d || c == '{' || c == '}')
+ break;
+ TokenBuffer[Size++] = c;
+ if (Size > OPTOKENSIZE)
+ return_error(gs_error_syntaxerror);
+ } while(code >= 0);
+ TokenBuffer[Size] = 0x00;
+ pdfi_unread(ctx, function_stream, &c, 1);
+ for (i=0;i < NumOps;i++) {
+ Op = (op_struct_t *)&ops_table[i];
+ if (Op->length < Size)
+ continue;
+
+ if (Op->length > Size)
+ return_error(gs_error_undefined);
+
+ if (memcmp(Op->op, TokenBuffer, Size - 1) == 0)
+ break;
+ }
+ if (i > NumOps)
+ return_error(gs_error_syntaxerror);
+ if (p == NULL)
+ (*size)++;
+ else {
+ if (Op->code != PtCr_else && Op->code != PtCr_if) {
+ (*size)++;
+ *p++ = Op->code;
+ }
+ }
+ }
+ break;
+ }
+ } while (code >= 0);
+
+ return code;
+}
+
+static int
+pdfi_build_function_4(pdf_context *ctx, gs_function_params_t * mnDR,
+ pdf_stream *function_obj, int depth, gs_function_t ** ppfn)
+{
+ gs_function_PtCr_params_t params;
+ pdf_c_stream *function_stream = NULL;
+ int code;
+ int64_t Length;
+ byte *data_source_buffer;
+ byte *ops = NULL;
+ unsigned int size;
+ gs_offset_t savedoffset;
+ memset(&params, 0x00, sizeof(gs_function_PtCr_params_t));
+ *(gs_function_params_t *)&params = *mnDR;
+ params.ops.data = 0; /* in case of failure */
+ params.ops.size = 0; /* ditto */
+
+ if (function_obj->type != PDF_STREAM)
+ return_error(gs_error_undefined);
+ Length = pdfi_stream_length(ctx, (pdf_stream *)function_obj);
+
+ savedoffset = pdfi_tell(ctx->main_stream);
+ code = pdfi_seek(ctx, ctx->main_stream, pdfi_stream_offset(ctx, function_obj), SEEK_SET);
+ if (code < 0)
+ return code;
+
+ code = pdfi_open_memory_stream_from_filtered_stream(ctx, function_obj, (unsigned int)Length, &data_source_buffer, ctx->main_stream, &function_stream, false);
+ if (code < 0)
+ goto function_4_error;
+
+ size = 0;
+ code = pdfi_parse_type4_func_stream(ctx, function_stream, 0, NULL, &size);
+ if (code < 0)
+ goto function_4_error;
+
+ ops = gs_alloc_string(ctx->memory, size + 1, "pdfi_build_function_4(ops)");
+ if (ops == NULL) {
+ code = gs_error_VMerror;
+ goto function_4_error;
+ }
+
+ code = pdfi_seek(ctx, function_stream, 0, SEEK_SET);
+ if (code < 0)
+ goto function_4_error;
+
+ size = 0;
+ code = pdfi_parse_type4_func_stream(ctx, function_stream, 0, ops, &size);
+ if (code < 0)
+ goto function_4_error;
+ ops[size] = PtCr_return;
+
+ code = pdfi_close_memory_stream(ctx, data_source_buffer, function_stream);
+ if (code < 0) {
+ function_stream = NULL;
+ goto function_4_error;
+ }
+
+ params.ops.data = (const byte *)ops;
+ params.ops.size = size + 1;
+ code = gs_function_PtCr_init(ppfn, &params, ctx->memory);
+ if (code < 0)
+ goto function_4_error;
+
+ pdfi_seek(ctx, ctx->main_stream, savedoffset, SEEK_SET);
+ return 0;
+
+function_4_error:
+ if (function_stream)
+ (void)pdfi_close_memory_stream(ctx, data_source_buffer, function_stream);
+ (void)pdfi_seek(ctx, ctx->main_stream, savedoffset, SEEK_SET);
+
+ gs_function_PtCr_free_params(&params, ctx->memory);
+ if (ops)
+ gs_free_const_string(ctx->memory, ops, size, "pdfi_build_function_4(ops)");
+ mnDR->Range = NULL;
+ mnDR->Domain = NULL;
+ return code;
+}
+
+static int
+pdfi_build_function_0(pdf_context *ctx, gs_function_params_t * mnDR,
+ pdf_stream *function_obj, int depth, gs_function_t ** ppfn)
+{
+ gs_function_Sd_params_t params;
+ pdf_c_stream *function_stream = NULL;
+ int code = 0;
+ int64_t Length, temp;
+ byte *data_source_buffer;
+ gs_offset_t savedoffset;
+ pdf_dict *function_dict = NULL;
+
+ memset(&params, 0x00, sizeof(gs_function_params_t));
+ *(gs_function_params_t *) & params = *mnDR;
+ params.Encode = params.Decode = NULL;
+ params.pole = NULL;
+ params.Size = params.array_step = params.stream_step = NULL;
+ params.Order = 0;
+
+ if (function_obj->type != PDF_STREAM)
+ return_error(gs_error_undefined);
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)function_obj, &function_dict);
+ if (code < 0)
+ return code;
+
+ Length = pdfi_stream_length(ctx, (pdf_stream *)function_obj);
+
+ savedoffset = pdfi_tell(ctx->main_stream);
+ pdfi_seek(ctx, ctx->main_stream, pdfi_stream_offset(ctx, function_obj), SEEK_SET);
+
+ Length = pdfi_open_memory_stream_from_filtered_stream(ctx, function_obj, (unsigned int)Length, &data_source_buffer, ctx->main_stream, &function_stream, false);
+ if (Length < 0) {
+ pdfi_seek(ctx, ctx->main_stream, savedoffset, SEEK_SET);
+ return Length;
+ }
+
+ data_source_init_stream(&params.DataSource, function_stream->s);
+
+ pdfi_seek(ctx, ctx->main_stream, savedoffset, SEEK_SET);
+
+ /* We need to clear up the PDF stream, but leave the underlying stream alone, that's now
+ * pointed to by the params.DataSource member.
+ */
+ gs_free_object(ctx->memory, function_stream, "discard memory stream(pdf_stream)");
+
+ code = pdfi_dict_get_int(ctx, function_dict, "Order", &temp);
+ if (code < 0 && code != gs_error_undefined)
+ goto function_0_error;
+ if (code == gs_error_undefined)
+ params.Order = 1;
+ else
+ params.Order = (int)temp;
+
+ code = pdfi_dict_get_int(ctx, function_dict, "BitsPerSample", &temp);
+ if (code < 0)
+ goto function_0_error;
+ params.BitsPerSample = temp;
+
+ code = pdfi_make_float_array_from_dict(ctx, (float **)&params.Encode, function_dict, "Encode");
+ if (code < 0) {
+ if (code == gs_error_undefined)
+ code = 2 * params.m;
+ else
+ goto function_0_error;
+ }
+ if (code != 2 * params.m) {
+ code = gs_error_rangecheck;
+ goto function_0_error;
+ }
+
+ code = pdfi_make_float_array_from_dict(ctx, (float **)&params.Decode, function_dict, "Decode");
+ if (code < 0) {
+ if (code == gs_error_undefined)
+ code = 2 * params.n;
+ else
+ goto function_0_error;
+ }
+ if (code != 2 * params.n) {
+ code = gs_error_rangecheck;
+ goto function_0_error;
+ }
+
+ code = pdfi_make_int_array_from_dict(ctx, (int **)&params.Size, function_dict, "Size");
+ if (code != params.m) {
+ if (code > 0)
+ code = gs_error_rangecheck;
+ goto function_0_error;
+ }
+ /* check the stream has enough data */
+ {
+ unsigned int i;
+ uint64_t inputs = 1, samples = 0;
+
+ for (i=0;i<params.m;i++) {
+ inputs *= params.Size[i];
+ }
+ samples = params.n * params.BitsPerSample;
+ samples *= inputs;
+ samples = samples >> 3;
+ if (samples > Length) {
+ code = gs_error_rangecheck;
+ goto function_0_error;
+ }
+ }
+
+ code = gs_function_Sd_init(ppfn, &params, ctx->memory);
+ if (code < 0)
+ goto function_0_error;
+ return 0;
+
+function_0_error:
+ s_close_filters(&params.DataSource.data.strm, params.DataSource.data.strm->strm);
+ params.DataSource.data.strm = NULL;
+ gs_function_Sd_free_params(&params, ctx->memory);
+ /* These are freed by gs_function_Sd_free_params, since we copied
+ * the poitners, we must NULL the originals, so that we don't double free.
+ */
+ mnDR->Range = NULL;
+ mnDR->Domain = NULL;
+ return code;
+}
+
+static int
+pdfi_build_function_2(pdf_context *ctx, gs_function_params_t * mnDR,
+ pdf_dict *function_dict, int depth, gs_function_t ** ppfn)
+{
+ gs_function_ElIn_params_t params;
+ int code, n0, n1;
+ double temp = 0.0;
+
+ memset(&params, 0x00, sizeof(gs_function_params_t));
+ *(gs_function_params_t *)&params = *mnDR;
+ params.C0 = 0;
+ params.C1 = 0;
+
+ code = pdfi_dict_get_number(ctx, function_dict, "N", &temp);
+ if (code < 0 && code != gs_error_undefined)
+ return code;
+ params.N = (float)temp;
+
+ code = pdfi_make_float_array_from_dict(ctx, (float **)&params.C0, function_dict, "C0");
+ if (code < 0 && code != gs_error_undefined)
+ return code;
+ n0 = code;
+
+ code = pdfi_make_float_array_from_dict(ctx, (float **)&params.C1, function_dict, "C1");
+ if (code < 0 && code != gs_error_undefined)
+ goto function_2_error;
+
+ n1 = code;
+ if (params.C0 == NULL)
+ n0 = 1;
+ if (params.C1 == NULL)
+ n1 = 1;
+ if (params.Range == 0)
+ params.n = n0; /* either one will do */
+ if (n0 != n1 || n0 != params.n) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto function_2_error;
+ }
+
+ code = gs_function_ElIn_init(ppfn, &params, ctx->memory);
+ if (code < 0)
+ goto function_2_error;
+
+ return 0;
+
+function_2_error:
+ gs_function_ElIn_free_params(&params, ctx->memory);
+ mnDR->Range = NULL;
+ mnDR->Domain = NULL;
+ return code;
+}
+
+static int
+pdfi_build_function_3(pdf_context *ctx, gs_function_params_t * mnDR,
+ pdf_dict *function_dict, const float *shading_domain, int num_inputs, pdf_dict *page_dict, int depth, gs_function_t ** ppfn)
+{
+ gs_function_1ItSg_params_t params;
+ int code, i;
+ pdf_array *Functions = NULL;
+ gs_function_t **ptr = NULL;
+
+ memset(&params, 0x00, sizeof(gs_function_params_t));
+ *(gs_function_params_t *) &params = *mnDR;
+ params.Functions = 0;
+ params.Bounds = 0;
+ params.Encode = 0;
+
+ code = pdfi_dict_get_type(ctx, function_dict, "Functions", PDF_ARRAY, (pdf_obj **)&Functions);
+ if (code < 0)
+ return code;
+
+ params.k = pdfi_array_size(Functions);
+ code = alloc_function_array(params.k, &ptr, ctx->memory);
+ if (code < 0)
+ goto function_3_error;
+
+ params.Functions = (const gs_function_t * const *)ptr;
+
+ for (i = 0; i < params.k; ++i) {
+ pdf_obj * rsubfn = NULL;
+
+ code = pdfi_array_get(ctx, (pdf_array *)Functions, (int64_t)i, &rsubfn);
+ if (code < 0)
+ goto function_3_error;
+
+ code = pdfi_build_sub_function(ctx, &ptr[i], shading_domain, num_inputs, rsubfn, page_dict);
+ pdfi_countdown(rsubfn);
+ if (code < 0)
+ goto function_3_error;
+ }
+
+ code = pdfi_make_float_array_from_dict(ctx, (float **)&params.Bounds, function_dict, "Bounds");
+ if (code < 0)
+ goto function_3_error;
+
+ code = pdfi_make_float_array_from_dict(ctx, (float **)&params.Encode, function_dict, "Encode");
+ if (code < 0)
+ goto function_3_error;
+
+ if (code != 2 * params.k)
+ goto function_3_error;
+
+ if (params.Range == 0)
+ params.n = params.Functions[0]->params.n;
+
+ code = gs_function_1ItSg_init(ppfn, &params, ctx->memory);
+ if (code < 0)
+ goto function_3_error;
+
+ pdfi_countdown(Functions);
+ return 0;
+
+function_3_error:
+ pdfi_countdown(Functions);
+ gs_function_1ItSg_free_params(&params, ctx->memory);
+ mnDR->Range = NULL;
+ mnDR->Domain = NULL;
+ return code;
+}
+
+static int pdfi_build_sub_function(pdf_context *ctx, gs_function_t ** ppfn, const float *shading_domain, int num_inputs, pdf_obj *stream_obj, pdf_dict *page_dict)
+{
+ int code, i;
+ int64_t Type;
+ gs_function_params_t params;
+ pdf_dict *stream_dict;
+
+ params.Range = params.Domain = NULL;
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ return code;
+
+ if (stream_obj->object_num != 0) {
+ if (pdfi_loop_detector_check_object(ctx, stream_obj->object_num))
+ return gs_note_error(gs_error_circular_reference);
+ code = pdfi_loop_detector_add_object(ctx, stream_obj->object_num);
+ if (code < 0)
+ goto sub_function_error;
+ }
+
+ code = pdfi_dict_from_obj(ctx, stream_obj, &stream_dict);
+ if (code < 0)
+ goto sub_function_error;
+
+ code = pdfi_dict_get_int(ctx, stream_dict, "FunctionType", &Type);
+ if (code < 0)
+ goto sub_function_error;
+
+ if (Type < 0 || Type > 4 || Type == 1) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto sub_function_error;
+ }
+
+ memset(&params, 0x00, sizeof(gs_function_params_t));
+
+ /* First gather all the entries common to all functions */
+ code = pdfi_make_float_array_from_dict(ctx, (float **)&params.Domain, stream_dict, "Domain");
+ if (code < 0)
+ goto sub_function_error;
+
+ if (code & 1) {
+ code = gs_error_rangecheck;
+ goto sub_function_error;
+ }
+
+ for (i=0;i<code;i+=2) {
+ if (params.Domain[i] > params.Domain[i+1]) {
+ code = gs_error_rangecheck;
+ goto sub_function_error;
+ }
+ }
+ if (shading_domain) {
+ if (num_inputs != code >> 1) {
+ code = gs_error_rangecheck;
+ goto sub_function_error;
+ }
+
+ for (i=0;i<2*num_inputs;i+=2) {
+ if (params.Domain[i] > shading_domain[i] || params.Domain[i+1] < shading_domain[i+1]) {
+ code = gs_error_rangecheck;
+ goto sub_function_error;
+ }
+ }
+ }
+
+ params.m = code >> 1;
+
+ code = pdfi_make_float_array_from_dict(ctx, (float **)&params.Range, stream_dict, "Range");
+ if (code < 0 && code != gs_error_undefined)
+ goto sub_function_error;
+ else {
+ if (code > 0)
+ params.n = code >> 1;
+ else
+ params.n = 0;
+ }
+ switch(Type) {
+ case 0:
+ code = pdfi_build_function_0(ctx, &params, (pdf_stream *)stream_obj, 0, ppfn);
+ if (code < 0)
+ goto sub_function_error;
+ break;
+ case 2:
+ code = pdfi_build_function_2(ctx, &params, stream_dict, 0, ppfn);
+ if (code < 0)
+ goto sub_function_error;
+ break;
+ case 3:
+ code = pdfi_build_function_3(ctx, &params, stream_dict, shading_domain, num_inputs, page_dict, 0, ppfn);
+ if (code < 0)
+ goto sub_function_error;
+ break;
+ case 4:
+ code = pdfi_build_function_4(ctx, &params, (pdf_stream *)stream_obj, 0, ppfn);
+ if (code < 0)
+ goto sub_function_error;
+ break;
+ default:
+ break;
+ }
+ pdfi_loop_detector_cleartomark(ctx);
+ return 0;
+
+sub_function_error:
+ gs_free_const_object(ctx->memory, params.Domain, "pdfi_build_sub_function (Domain) error exit\n");
+ gs_free_const_object(ctx->memory, params.Range, "pdfi_build_sub_function(Range) error exit\n");
+ pdfi_loop_detector_cleartomark(ctx);
+ return code;
+}
+
+
+static int pdfi_free_function_special(pdf_context *ctx, gs_function_t *pfn);
+
+#if 0
+/* For type 0 functions, need to free up the data associated with the stream
+ * that it was using. This doesn't get freed in the gs_function_free() code.
+ */
+static int pdfi_free_function_0(pdf_context *ctx, gs_function_t *pfn)
+{
+ gs_function_Sd_params_t *params = (gs_function_Sd_params_t *)&pfn->params;
+
+ s_close_filters(&params->DataSource.data.strm, params->DataSource.data.strm->strm);
+ gs_free_object(ctx->memory, params->DataSource.data.strm, "pdfi_free_function");
+ return 0;
+}
+#endif
+
+/* For type 3 functions, it has an array of functions that might need special handling.
+ */
+static int pdfi_free_function_3(pdf_context *ctx, gs_function_t *pfn)
+{
+ gs_function_1ItSg_params_t *params = (gs_function_1ItSg_params_t *)&pfn->params;
+ int i;
+
+ for (i=0; i<params->k; i++) {
+ pdfi_free_function_special(ctx, (gs_function_t *)params->Functions[i]);
+ }
+ return 0;
+}
+
+/* Free any special stuff associated with a function */
+static int pdfi_free_function_special(pdf_context *ctx, gs_function_t *pfn)
+{
+ switch(pfn->head.type) {
+#if 0
+ /* Before commit 3f2408d5ac786ac1c0a837b600f4ef3be9be0332
+ * https://git.ghostscript.com/?p=ghostpdl.git;a=commit;h=3f2408d5ac786ac1c0a837b600f4ef3be9be0332
+ * we needed to close the data stream and free the memory. That is now
+ * performed by the graphics library so we don't need to do this any more.
+ */
+ case 0:
+ pdfi_free_function_0(ctx, pfn);
+ break;
+#endif
+ case 3:
+ pdfi_free_function_3(ctx, pfn);
+ break;
+ default:
+ break;
+ }
+ return 0;
+}
+
+int pdfi_free_function(pdf_context *ctx, gs_function_t *pfn)
+{
+ if (pfn == NULL)
+ return 0;
+
+ /* Free any special stuff for the function */
+ pdfi_free_function_special(ctx, pfn);
+
+ /* Free the standard stuff handled by the gs library */
+ gs_function_free(pfn, true, ctx->memory);
+ return 0;
+}
+
+int pdfi_build_function(pdf_context *ctx, gs_function_t ** ppfn, const float *shading_domain, int num_inputs, pdf_obj *stream_obj, pdf_dict *page_dict)
+{
+ return pdfi_build_sub_function(ctx, ppfn, shading_domain, num_inputs, stream_obj, page_dict);
+}
+
+int pdfi_build_halftone_function(pdf_context *ctx, gs_function_t ** ppfn, byte *Buffer, int64_t Length)
+{
+ gs_function_PtCr_params_t params;
+ pdf_c_stream *function_stream = NULL;
+ int code=0;
+ byte *ops = NULL;
+ unsigned int size;
+ float *pfloat;
+ byte *stream_buffer = NULL;
+
+ memset(&params, 0x00, sizeof(gs_function_PtCr_params_t));
+ params.ops.data = 0; /* in case of failure */
+ params.ops.size = 0; /* ditto */
+
+ stream_buffer = gs_alloc_bytes(ctx->memory, Length, "pdfi_build_halftone_function(stream_buffer))");
+ if (stream_buffer == NULL)
+ goto halftone_function_error;
+
+ memcpy(stream_buffer, Buffer, Length);
+
+ code = pdfi_open_memory_stream_from_memory(ctx, Length, stream_buffer, &function_stream, true);
+ if (code < 0)
+ goto halftone_function_error;
+
+ size = 0;
+ code = pdfi_parse_type4_func_stream(ctx, function_stream, 0, NULL, &size);
+ if (code < 0)
+ goto halftone_function_error;
+
+ ops = gs_alloc_string(ctx->memory, size + 1, "pdfi_build_halftone_function(ops)");
+ if (ops == NULL) {
+ code = gs_error_VMerror;
+ goto halftone_function_error;
+ }
+
+ code = pdfi_seek(ctx, function_stream, 0, SEEK_SET);
+ if (code < 0)
+ goto halftone_function_error;
+
+ size = 0;
+ code = pdfi_parse_type4_func_stream(ctx, function_stream, 0, ops, &size);
+ if (code < 0)
+ goto halftone_function_error;
+ ops[size] = PtCr_return;
+
+ code = pdfi_close_memory_stream(ctx, stream_buffer, function_stream);
+ if (code < 0) {
+ function_stream = NULL;
+ goto halftone_function_error;
+ }
+
+ params.ops.data = (const byte *)ops;
+ params.ops.size = size + 1;
+ params.m = 2;
+ params.n = 1;
+ pfloat = (float *)gs_alloc_byte_array(ctx->memory, 4, sizeof(float), "pdfi_build_halftone_function(Domain)");
+ if (pfloat == NULL) {
+ code = gs_error_VMerror;
+ goto halftone_function_error;
+ }
+ pfloat[0] = -1;
+ pfloat[1] = 1;
+ pfloat[2] = -1;
+ pfloat[3] = 1;
+ params.Domain = (const float *)pfloat;
+ pfloat = (float *)gs_alloc_byte_array(ctx->memory, 2, sizeof(float), "pdfi_build_halftone_function(Domain)");
+ if (pfloat == NULL) {
+ code = gs_error_VMerror;
+ goto halftone_function_error;
+ }
+ pfloat[0] = -1;
+ pfloat[1] = 1;
+ params.Range = (const float *)pfloat;
+
+ code = gs_function_PtCr_init(ppfn, &params, ctx->memory);
+ if (code < 0)
+ goto halftone_function_error;
+
+ return 0;
+
+halftone_function_error:
+ if (function_stream)
+ (void)pdfi_close_memory_stream(ctx, stream_buffer, function_stream);
+
+ gs_function_PtCr_free_params(&params, ctx->memory);
+ if (ops)
+ gs_free_const_string(ctx->memory, ops, size, "pdfi_build_function_4(ops)");
+ return code;
+}
diff --git a/pdf/pdf_func.h b/pdf/pdf_func.h
new file mode 100644
index 00000000..1432248a
--- /dev/null
+++ b/pdf/pdf_func.h
@@ -0,0 +1,25 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* function creation for the PDF interpreter */
+
+#ifndef PDF_FUNCTIONS
+#define PDF_FUNCTIONS
+
+int pdfi_free_function(pdf_context *ctx, gs_function_t *pfn);
+int pdfi_build_function(pdf_context *ctx, gs_function_t ** ppfn, const float *shading_domain, int num_inputs, pdf_obj *stream_obj, pdf_dict *page_dict);
+int pdfi_build_halftone_function(pdf_context *ctx, gs_function_t ** ppfn, byte *Buffer, int64_t Length);
+
+#endif
diff --git a/pdf/pdf_gstate.c b/pdf/pdf_gstate.c
new file mode 100644
index 00000000..7544aa48
--- /dev/null
+++ b/pdf/pdf_gstate.c
@@ -0,0 +1,2389 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Graphics state operations for the PDF interpreter */
+
+#include "pdf_int.h"
+#include "pdf_doc.h"
+#include "pdf_gstate.h"
+#include "pdf_stack.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_func.h"
+#include "pdf_file.h"
+#include "pdf_misc.h"
+#include "pdf_loop_detect.h"
+#include "pdf_image.h"
+#include "pdf_pattern.h"
+#include "pdf_font.h"
+#include "pdf_colour.h"
+#include "pdf_trans.h"
+
+#include "gsstate.h" /* For gs_gstate */
+#include "gsmatrix.h"
+#include "gslparam.h"
+#include "gstparam.h"
+
+#include "gxdht.h"
+#include "gxht.h"
+#include "gzht.h"
+#include "gsht.h"
+#include "gscoord.h" /* For gs_concat() */
+#include "gsutil.h" /* For gs_next_ids() */
+#include "gscolor3.h" /* For gs_setsmoothness() */
+
+static const char *blend_mode_names[] = {
+ GS_BLEND_MODE_NAMES, 0
+};
+
+int pdfi_get_blend_mode(pdf_context *ctx, pdf_name *name, gs_blend_mode_t *mode)
+{
+ const char **p;
+
+ for (p = blend_mode_names; *p; ++p) {
+ if (pdfi_name_is(name, *p)) {
+ *mode = p - blend_mode_names;
+ return 0;
+ }
+ }
+ return -1;
+}
+
+void pdfi_gstate_smask_install(pdfi_int_gstate *igs, gs_memory_t *memory, pdf_dict *SMask, gs_gstate *gstate)
+{
+ void *client_data_save;
+
+ if (!SMask)
+ return;
+ igs->memory = memory;
+ igs->SMask = SMask;
+ pdfi_countup(SMask);
+ client_data_save = gstate->client_data;
+ gstate->client_data = NULL;
+ igs->GroupGState = gs_gstate_copy(gstate, memory);
+ gstate->client_data = client_data_save;
+}
+
+void pdfi_gstate_smask_free(pdfi_int_gstate *igs)
+{
+ if (!igs->SMask)
+ return;
+ pdfi_countdown(igs->SMask);
+ igs->SMask = NULL;
+ if (igs->GroupGState)
+ gs_gstate_free(igs->GroupGState);
+ igs->GroupGState = NULL;
+}
+
+
+/* Allocate the interpreter's part of a graphics state. */
+static void *
+pdfi_gstate_alloc_cb(gs_memory_t * mem)
+{
+ pdfi_int_gstate *igs;
+
+ igs = (pdfi_int_gstate *)gs_alloc_bytes(mem, sizeof(pdfi_int_gstate), "pdfi_gstate_alloc");
+ if (igs == NULL)
+ return NULL;
+ memset(igs, 0, sizeof(pdfi_int_gstate));
+ return igs;
+}
+
+/* Copy the interpreter's part of a graphics state. */
+static int
+pdfi_gstate_copy_cb(void *to, const void *from)
+{
+ const pdfi_int_gstate *igs_from = (const pdfi_int_gstate *)from;
+ pdfi_int_gstate *igs_to = (pdfi_int_gstate *)to;
+
+ /* Need to free destination contents before overwriting.
+ * On grestore, they might be non-empty.
+ */
+ if (igs_to != NULL) {
+ pdfi_gstate_smask_free(igs_to);
+ *(pdfi_int_gstate *) igs_to = *igs_from;
+ pdfi_gstate_smask_install(igs_to, igs_from->memory, igs_from->SMask, igs_from->GroupGState);
+ }
+ return 0;
+}
+
+/* Free the interpreter's part of a graphics state. */
+static void
+pdfi_gstate_free_cb(void *old, gs_memory_t * mem, gs_gstate *pgs)
+{
+ pdfi_int_gstate *igs = (pdfi_int_gstate *)old;
+ if (old == NULL)
+ return;
+ pdfi_gstate_smask_free(igs);
+ /* We need to use the graphics state memory, in case we are running under Ghostscript. */
+ gs_free_object(pgs->memory, igs, "pdfi_gstate_free");
+}
+
+static const gs_gstate_client_procs pdfi_gstate_procs = {
+ pdfi_gstate_alloc_cb,
+ pdfi_gstate_copy_cb,
+ pdfi_gstate_free_cb,
+ NULL, /* copy_for */
+};
+
+int
+pdfi_gstate_set_client(pdf_context *ctx, gs_gstate *pgs)
+{
+ pdfi_int_gstate *igs;
+
+ /* We need to use the graphics state memory, in case we are running under Ghostscript. */
+ igs = pdfi_gstate_alloc_cb(pgs->memory);
+ igs->ctx = ctx;
+ gs_gstate_set_client(pgs, igs, &pdfi_gstate_procs, true /* TODO: client_has_pattern_streams ? */);
+ return 0;
+}
+
+int pdfi_concat(pdf_context *ctx)
+{
+ int i, code;
+ pdf_num *num;
+ double Values[6];
+ gs_matrix m;
+
+ if (pdfi_count_stack(ctx) < 6) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_concat", NULL);
+
+ for (i=0;i < 6;i++){
+ num = (pdf_num *)ctx->stack_top[i - 6];
+ if (num->type != PDF_INT) {
+ if(num->type != PDF_REAL) {
+ pdfi_pop(ctx, 6);
+ return_error(gs_error_typecheck);
+ }
+ else
+ Values[i] = num->value.d;
+ } else {
+ Values[i] = (double)num->value.i;
+ }
+ }
+ m.xx = (float)Values[0];
+ m.xy = (float)Values[1];
+ m.yx = (float)Values[2];
+ m.yy = (float)Values[3];
+ m.tx = (float)Values[4];
+ m.ty = (float)Values[5];
+ code = gs_concat(ctx->pgs, (const gs_matrix *)&m);
+ pdfi_pop(ctx, 6);
+ return code;
+}
+
+int pdfi_op_q(pdf_context *ctx)
+{
+ int code;
+
+#if DEBUG_GSAVE
+ dbgmprintf(ctx->memory, "(doing q)\n"); /* TODO: Spammy, delete me at some point */
+#endif
+ code = pdfi_gsave(ctx);
+
+ if (code < 0)
+ return code;
+ else {
+ if (ctx->page.has_transparency)
+ return gs_push_transparency_state(ctx->pgs);
+ }
+ return 0;
+}
+
+int pdfi_op_Q(pdf_context *ctx)
+{
+ int code = 0;
+ gx_path *ppath = NULL;
+
+#if DEBUG_GSAVE
+ dbgmprintf(ctx->memory, "(doing Q)\n"); /* TODO: Spammy, delete me at some point */
+#endif
+ if (ctx->pgs->level <= ctx->current_stream_save.gsave_level) {
+ /* We don't throw an error here, we just ignore it and continue */
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_TOOMANYQ, "pdfi_op_Q", (char *)"ignoring Q");
+ return 0;
+ }
+ if (ctx->page.has_transparency) {
+ code = gs_pop_transparency_state(ctx->pgs, false);
+ if (code < 0)
+ return code;
+ }
+
+ /* Section 4.4.1 of the 3rd Edition PDF_Refrence Manual, p226 of the 1.7 version
+ * states that the current path is **NOT** part of the graphics state and is not
+ * saved and restored along with the other graphics state parameters. So here
+ * we need to indulge in some ugliness. We take a copy of the current path
+ * before we do a grestore, and below we assign the copy to the graphics state
+ * after the grestore, thus preserving it unchanged. This is still better than
+ * the 'PDF interpreter written in PostScript' method.
+ */
+ ppath = gx_path_alloc_shared(ctx->pgs->path, ctx->memory, "temporary current path copy for Q");
+ if (ppath == NULL)
+ return_error(gs_error_VMerror);
+
+ code = pdfi_grestore(ctx);
+
+ if (code >= 0) {
+ /* Put the path back, and make sure current point is properly set */
+ code = gx_path_assign_preserve(ctx->pgs->path, ppath);
+ if (gx_path_position_valid(ctx->pgs->path))
+ gx_setcurrentpoint_from_path(ctx->pgs, ctx->pgs->path);
+ }
+
+ gx_path_free(ppath, "temporary current path copy for Q");
+
+ return code;
+}
+
+int pdfi_gsave(pdf_context *ctx)
+{
+ int code;
+
+ code = gs_gsave(ctx->pgs);
+
+ if(code < 0)
+ return code;
+ else {
+ pdfi_countup_current_font(ctx);
+ return 0;
+ }
+}
+
+int pdfi_grestore(pdf_context *ctx)
+{
+ int code;
+ pdf_font *font = NULL, *font1 = NULL;
+
+ /* Make sure we have encountered as many gsave operations in this
+ * stream as grestores. If not, log an error
+ */
+ if (ctx->pgs->level > ctx->current_stream_save.gsave_level) {
+ font = pdfi_get_current_pdf_font(ctx);
+
+ code = gs_grestore(ctx->pgs);
+
+ font1 = pdfi_get_current_pdf_font(ctx);
+ if (font != NULL && (font != font1 || ((pdf_obj *)font)->refcnt > 1)) {
+ /* TODO: This countdown might have been causing memory corruption (dangling pointer)
+ * but seems to be okay now. Maybe was fixed by other memory issue. 8-28-19
+ * If you come upon this comment in the future and it all seems fine, feel free to
+ * clean this up... (delete comment, remove the commented out warning message, etc)
+ */
+#if REFCNT_DEBUG
+ dbgmprintf2(ctx->memory, "pdfi_grestore() counting down font UID %ld, refcnt %d\n",
+ font->UID, font->refcnt);
+#endif
+ // dbgmprintf(ctx->memory, "WARNING pdfi_grestore() DISABLED pdfi_countdown (FIXME!)\n");
+ pdfi_countdown(font);
+ }
+
+ return code;
+ } else {
+ /* We don't throw an error here, we just ignore it and continue */
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_TOOMANYQ, "pdfi_grestore", (char *)"ignoring q");
+ }
+ return 0;
+}
+
+/* gs_setgstate is somewhat unpleasant from our point of view, because it replaces
+ * the content of the graphics state, without going through our pdfi_gsave/pdfi_grestore
+ * functionaltiy. In particular we replace the current font in the graphics state when
+ * we call it, and this means we *don't* count down the PDF_font object reference count
+ * which leads to an incorrect count and either memory leaks or early freeing.
+ * This function *requires* that the calling function will do a pdfi_gsave *before*
+ * calling pdfi_setgstate, and a pdfi_grestore *after* calling pdfi_gs_setgstate.
+ * it correctly increments/decrements the font reference counts for that condition
+ * and no other.
+ */
+int pdfi_gs_setgstate(gs_gstate * pgs, const gs_gstate * pfrom)
+{
+ pdf_font *font = NULL;
+ int code = 0;
+
+ /* We are going to release a reference to the font from the graphics state
+ * (if there is one) so count it down to keep things straight.
+ */
+ if (pgs->font) {
+ font = (pdf_font *)pgs->font->client_data;
+ if (font)
+ pdfi_countdown(font);
+ }
+
+ code = gs_setgstate(pgs, pfrom);
+ if (code < 0)
+ return code;
+
+ /* The copied gstate may have contained a font, and we expect to do a
+ * pdfi_grestore on exit from here, which will count down the font
+ * so count it up now in preparation.
+ */
+ if (pgs->font) {
+ font = (pdf_font *)pgs->font->client_data;
+ if (font)
+ pdfi_countup(font);
+ }
+ return code;
+}
+
+int pdfi_setlinewidth(pdf_context *ctx)
+{
+ int code;
+ pdf_num *n1;
+ double d1;
+
+ if (pdfi_count_stack(ctx) < 1)
+ return_error(gs_error_stackunderflow);
+
+ n1 = (pdf_num *)ctx->stack_top[-1];
+ if (n1->type == PDF_INT){
+ d1 = (double)n1->value.i;
+ } else{
+ if (n1->type == PDF_REAL) {
+ d1 = n1->value.d;
+ } else {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_typecheck);
+ }
+ }
+ code = gs_setlinewidth(ctx->pgs, d1);
+ pdfi_pop(ctx, 1);
+ return code;
+}
+
+int pdfi_setlinejoin(pdf_context *ctx)
+{
+ int code;
+ pdf_num *n1;
+
+ if (pdfi_count_stack(ctx) < 1)
+ return_error(gs_error_stackunderflow);
+
+ n1 = (pdf_num *)ctx->stack_top[-1];
+ if (n1->type == PDF_INT){
+ code = gs_setlinejoin(ctx->pgs, n1->value.i);
+ } else {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_typecheck);
+ }
+ pdfi_pop(ctx, 1);
+ return code;
+}
+
+int pdfi_setlinecap(pdf_context *ctx)
+{
+ int code;
+ pdf_num *n1;
+
+ if (pdfi_count_stack(ctx) < 1)
+ return_error(gs_error_stackunderflow);
+
+ n1 = (pdf_num *)ctx->stack_top[-1];
+ if (n1->type == PDF_INT){
+ code = gs_setlinecap(ctx->pgs, n1->value.i);
+ } else {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_typecheck);
+ }
+ pdfi_pop(ctx, 1);
+ return code;
+}
+
+int pdfi_setflat(pdf_context *ctx)
+{
+ int code;
+ pdf_num *n1;
+ double d1;
+
+ if (pdfi_count_stack(ctx) < 1)
+ return_error(gs_error_stackunderflow);
+
+ n1 = (pdf_num *)ctx->stack_top[-1];
+ if (n1->type == PDF_INT){
+ d1 = (double)n1->value.i;
+ } else{
+ if (n1->type == PDF_REAL) {
+ d1 = n1->value.d;
+ } else {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_typecheck);
+ }
+ }
+ /* PDF spec says the value is 1-100, with 0 meaning "use the default"
+ * But gs code (and now our code) forces the value to be <= 1
+ * This matches what Adobe and evince seem to do (see Bug 555657).
+ * Apparently mupdf implements this as a no-op, which is essentially
+ * what this does now.
+ */
+ if (d1 > 1.0)
+ d1 = 1.0;
+ code = gs_setflat(ctx->pgs, d1);
+ pdfi_pop(ctx, 1);
+ return code;
+}
+
+int pdfi_setdash_impl(pdf_context *ctx, pdf_array *a, double phase_d)
+{
+ float *dash_array;
+ double temp;
+ int i, code;
+
+ dash_array = (float *)gs_alloc_bytes(ctx->memory, pdfi_array_size(a) * sizeof (float),
+ "temporary float array for setdash");
+ if (dash_array == NULL)
+ return_error(gs_error_VMerror);
+
+ for (i=0;i < pdfi_array_size(a);i++){
+ code = pdfi_array_get_number(ctx, a, (uint64_t)i, &temp);
+ if (code < 0) {
+ gs_free_object(ctx->memory, dash_array, "error in setdash");
+ return code;
+ }
+ dash_array[i] = (float)temp;
+ }
+ code = gs_setdash(ctx->pgs, dash_array, pdfi_array_size(a), phase_d);
+ gs_free_object(ctx->memory, dash_array, "error in setdash");
+ return code;
+}
+int pdfi_setdash(pdf_context *ctx)
+{
+ pdf_num *phase;
+ pdf_array *a;
+ double phase_d;
+ int code;
+
+ if (pdfi_count_stack(ctx) < 2) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ phase = (pdf_num *)ctx->stack_top[-1];
+ if (phase->type == PDF_INT){
+ phase_d = (double)phase->value.i;
+ } else{
+ if (phase->type == PDF_REAL) {
+ phase_d = phase->value.d;
+ } else {
+ pdfi_pop(ctx, 2);
+ return_error(gs_error_typecheck);
+ }
+ }
+
+ a = (pdf_array *)ctx->stack_top[-2];
+ if (a->type != PDF_ARRAY) {
+ pdfi_pop(ctx, 2);
+ return_error(gs_error_typecheck);
+ }
+
+ code = pdfi_setdash_impl(ctx, a, phase_d);
+ pdfi_pop(ctx, 2);
+ return code;
+}
+
+int pdfi_setmiterlimit(pdf_context *ctx)
+{
+ int code;
+ pdf_num *n1;
+ double d1;
+
+ if (pdfi_count_stack(ctx) < 1)
+ return_error(gs_error_stackunderflow);
+
+ n1 = (pdf_num *)ctx->stack_top[-1];
+ if (n1->type == PDF_INT){
+ d1 = (double)n1->value.i;
+ } else{
+ if (n1->type == PDF_REAL) {
+ d1 = n1->value.d;
+ } else {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_typecheck);
+ }
+ }
+ code = gs_setmiterlimit(ctx->pgs, d1);
+ pdfi_pop(ctx, 1);
+ return code;
+}
+
+static int GS_LW(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ double d1;
+ int code;
+
+ code = pdfi_dict_get_number(ctx, GS, "LW", &d1);
+ if (code < 0)
+ return code;
+
+ code = gs_setlinewidth(ctx->pgs, d1);
+ return code;
+}
+
+static int GS_LC(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int64_t i;
+ int code;
+
+ code = pdfi_dict_get_int(ctx, GS, "LC", &i);
+ if (code < 0)
+ return code;
+
+ code = gs_setlinecap(ctx->pgs, i);
+ return code;
+}
+
+static int GS_LJ(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int64_t i;
+ int code;
+
+ code = pdfi_dict_get_int(ctx, GS, "LJ", &i);
+ if (code < 0)
+ return code;
+
+ code = gs_setlinejoin(ctx->pgs, i);
+ return code;
+}
+
+static int GS_ML(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code;
+ double d1;
+
+ code = pdfi_dict_get_number(ctx, GS, "ML", &d1);
+ if (code < 0)
+ return code;
+
+ code = gs_setmiterlimit(ctx->pgs, d1);
+ return code;
+}
+
+static int GS_D(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ pdf_array *a, *a1;
+ double d;
+ int code;
+
+ code = pdfi_dict_get_type(ctx, GS, "D", PDF_ARRAY, (pdf_obj **)&a);
+ if (code < 0)
+ return code;
+
+ code = pdfi_array_get_type(ctx, a, (int64_t)0, PDF_ARRAY, (pdf_obj **)&a1);
+ if (code < 0) {
+ pdfi_countdown(a);
+ return code;
+ }
+
+ code = pdfi_array_get_number(ctx, a, (int64_t)1, &d);
+ if (code < 0) {
+ pdfi_countdown(a1);
+ pdfi_countdown(a);
+ return code;
+ }
+
+ code = pdfi_setdash_impl(ctx, a1, d);
+ pdfi_countdown(a1);
+ pdfi_countdown(a);
+ return code;
+}
+
+static int GS_RI(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ pdf_name *n;
+ int code;
+
+ code = pdfi_dict_get_type(ctx, GS, "RI", PDF_NAME, (pdf_obj **)&n);
+ if (code < 0)
+ return code;
+
+ code = pdfi_setrenderingintent(ctx, n);
+ pdfi_countdown(n);
+ return code;
+}
+
+static int GS_OP(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ pdf_bool *b = NULL;
+ int code;
+ bool known=false;
+
+ code = pdfi_dict_get_type(ctx, GS, "OP", PDF_BOOL, (pdf_obj **)&b);
+ if (code < 0)
+ return code;
+
+ gs_setstrokeoverprint(ctx->pgs, b->value);
+
+ /* If op not in the dict, then also set it with OP
+ * Because that's what gs does pdf_draw.ps/gsparamdict/OP
+ */
+ code = pdfi_dict_known(ctx, GS, "op", &known);
+ if (!known)
+ gs_setfilloverprint(ctx->pgs, b->value);
+
+ pdfi_countdown(b);
+ return 0;
+}
+
+static int GS_op(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ pdf_bool *b;
+ int code;
+
+ code = pdfi_dict_get_type(ctx, GS, "op", PDF_BOOL, (pdf_obj **)&b);
+ if (code < 0)
+ return code;
+
+ gs_setfilloverprint(ctx->pgs, b->value);
+ pdfi_countdown(b);
+ return 0;
+}
+
+static int GS_OPM(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int64_t i;
+ int code;
+
+ code = pdfi_dict_get_int(ctx, GS, "OPM", &i);
+ if (code < 0)
+ return code;
+
+ code = gs_setoverprintmode(ctx->pgs, i);
+ return code;
+}
+
+static int GS_Font(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ pdf_array *font_array = NULL;
+ pdf_dict *font_dict = NULL;
+ int code = 0;
+ double point_size = 0.0;
+
+ code = pdfi_dict_get_type(ctx, GS, "Font", PDF_ARRAY, (pdf_obj **)&font_array);
+ if (code < 0)
+ return code;
+
+ if (pdfi_array_size(font_array) != 2)
+ return_error(gs_error_rangecheck);
+
+ code = pdfi_array_get(ctx, font_array, 0, (pdf_obj **)&font_dict);
+ if (code < 0)
+ goto GS_Font_error;
+
+ code = pdfi_array_get_number(ctx, font_array, 1, &point_size);
+ if (code < 0)
+ goto GS_Font_error;
+
+ code = pdfi_load_dict_font(ctx, stream_dict, page_dict, font_dict, point_size);
+
+GS_Font_error:
+ pdfi_countdown(font_array);
+ pdfi_countdown(font_dict);
+ return code;
+}
+
+static int pdfi_set_blackgeneration(pdf_context *ctx, pdf_obj *obj, pdf_dict *page_dict, bool is_BG)
+{
+ int code = 0, i;
+ gs_function_t *pfn;
+
+ if (obj->type == PDF_NAME) {
+ if (pdfi_name_is((const pdf_name *)obj, "Identity")) {
+ code = gs_setblackgeneration_remap(ctx->pgs, gs_identity_transfer, false);
+ goto exit;
+ } else {
+ if (!is_BG && pdfi_name_is((const pdf_name *)obj, "Default")) {
+ code = gs_setblackgeneration_remap(ctx->pgs, ctx->page.DefaultBG.proc, false);
+ memcpy(ctx->pgs->black_generation->values, ctx->page.DefaultBG.values, transfer_map_size * sizeof(frac));
+ goto exit;
+ } else {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ }
+ } else {
+ if (obj->type != PDF_DICT && obj->type != PDF_STREAM)
+ return_error(gs_error_typecheck);
+
+ code = pdfi_build_function(ctx, &pfn, NULL, 1, obj, page_dict);
+ if (code < 0)
+ return code;
+
+ gs_setblackgeneration_remap(ctx->pgs, gs_mapped_transfer, false);
+ for (i = 0; i < transfer_map_size; i++) {
+ float v, f;
+
+ f = (1.0f / (transfer_map_size - 1)) * i;
+
+ code = gs_function_evaluate(pfn, (const float *)&f, &v);
+ if (code < 0) {
+ pdfi_free_function(ctx, pfn);
+ return code;
+ }
+
+ ctx->pgs->black_generation->values[i] =
+ (v < 0.0 ? float2frac(0.0) :
+ v >= 1.0 ? frac_1 :
+ float2frac(v));
+ }
+ code = pdfi_free_function(ctx, pfn);
+ }
+exit:
+ return code;
+}
+
+static int GS_BG(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code;
+ pdf_obj *obj = NULL;
+
+ /* If the dictionary also has a BG2, then we must use that */
+ code = pdfi_dict_get(ctx, GS, "BG2", &obj);
+ if (code == 0) {
+ pdfi_countdown(obj);
+ return 0;
+ }
+
+ code = pdfi_dict_get(ctx, GS, "BG", &obj);
+ if (code < 0)
+ return code;
+
+ code = pdfi_set_blackgeneration(ctx, obj, page_dict, true);
+
+ pdfi_countdown(obj);
+
+ return code;
+}
+
+static int GS_BG2(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code;
+ pdf_obj *obj = NULL;
+
+ code = pdfi_dict_get(ctx, GS, "BG2", &obj);
+ if (code < 0)
+ return code;
+
+ code = pdfi_set_blackgeneration(ctx, obj, page_dict, false);
+
+ pdfi_countdown(obj);
+
+ return code;
+}
+
+static int pdfi_set_undercolorremoval(pdf_context *ctx, pdf_obj *obj, pdf_dict *page_dict, bool is_BG)
+{
+ int code = 0, i;
+ gs_function_t *pfn;
+
+ if (obj->type == PDF_NAME) {
+ if (pdfi_name_is((const pdf_name *)obj, "Identity")) {
+ code = gs_setundercolorremoval_remap(ctx->pgs, gs_identity_transfer, false);
+ goto exit;
+ } else {
+ if (!is_BG && pdfi_name_is((const pdf_name *)obj, "Default")) {
+ code = gs_setundercolorremoval_remap(ctx->pgs, ctx->page.DefaultUCR.proc, false);
+ memcpy(ctx->pgs->undercolor_removal->values, ctx->page.DefaultUCR.values, transfer_map_size * sizeof(frac));
+ goto exit;
+ } else {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ }
+ } else {
+ if (obj->type != PDF_DICT && obj->type != PDF_STREAM)
+ return_error(gs_error_typecheck);
+
+ code = pdfi_build_function(ctx, &pfn, NULL, 1, obj, page_dict);
+ if (code < 0)
+ return code;
+
+ gs_setundercolorremoval_remap(ctx->pgs, gs_mapped_transfer, false);
+ for (i = 0; i < transfer_map_size; i++) {
+ float v, f;
+
+ f = (1.0f / (transfer_map_size - 1)) * i;
+
+ code = gs_function_evaluate(pfn, (const float *)&f, &v);
+ if (code < 0) {
+ pdfi_free_function(ctx, pfn);
+ return code;
+ }
+
+ ctx->pgs->undercolor_removal->values[i] =
+ (v < 0.0 ? float2frac(0.0) :
+ v >= 1.0 ? frac_1 :
+ float2frac(v));
+ }
+ code = pdfi_free_function(ctx, pfn);
+ }
+exit:
+ return code;
+}
+
+static int GS_UCR(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code;
+ pdf_obj *obj = NULL;
+
+ /* If the dictionary also has a UCR2, then we must use that and ignore the UCR */
+ code = pdfi_dict_get(ctx, GS, "UCR2", &obj);
+ if (code == 0) {
+ pdfi_countdown(obj);
+ return 0;
+ }
+
+ code = pdfi_dict_get(ctx, GS, "UCR", &obj);
+ if (code < 0)
+ return code;
+
+ code = pdfi_set_undercolorremoval(ctx, obj, page_dict, true);
+
+ pdfi_countdown(obj);
+
+ return code;
+}
+
+static int GS_UCR2(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code;
+ pdf_obj *obj = NULL;
+
+ code = pdfi_dict_get(ctx, GS, "UCR2", &obj);
+ if (code < 0)
+ return code;
+
+ code = pdfi_set_undercolorremoval(ctx, obj, page_dict, false);
+
+ pdfi_countdown(obj);
+
+ return code;
+}
+
+typedef enum {
+ E_IDENTITY,
+ E_DEFAULT,
+ E_FUNCTION
+} pdf_transfer_function_type_e;
+
+/* We use this for both TR and TR2, is_TR is true if this is a TR, in which case we don't want
+ * to permit /Default names for fucntions.
+ */
+static int pdfi_set_all_transfers(pdf_context *ctx, pdf_array *a, pdf_dict *page_dict, bool is_TR)
+{
+ int code = 0, i, j;
+ pdf_obj *o = NULL;
+ int proc_types[4];
+ gs_mapping_proc map_procs[4];
+ gs_function_t *pfn[4];
+
+ memset(pfn, 0x00, 4 * sizeof(gs_function_t *));
+ memset(map_procs, 0x00, 4 * sizeof(gs_mapping_proc *));
+
+ /* Two passes, the first one is to find the appropriate transfer procedures
+ * and do the majorty of the error checking;
+ */
+ for (i = 0; i < 4; i++) {
+ code = pdfi_array_get(ctx, a, (uint64_t)i, &o);
+ if (code < 0)
+ goto exit;
+ if (o->type == PDF_NAME) {
+ if (pdfi_name_is((const pdf_name *)o, "Identity")) {
+ proc_types[i] = E_IDENTITY;
+ map_procs[i] = gs_identity_transfer;
+ } else {
+ if (!is_TR && pdfi_name_is((const pdf_name *)o, "Default")) {
+ proc_types[i] = E_DEFAULT;
+ map_procs[i] = ctx->page.DefaultTransfers[i].proc;
+ } else {
+ pdfi_countdown(o);
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+ }
+ } else {
+ if (o->type == PDF_STREAM || o->type == PDF_DICT) {
+ proc_types[i] = E_FUNCTION;
+ map_procs[i] = gs_mapped_transfer;
+ code = pdfi_build_function(ctx, &pfn[i], NULL, 1, o, page_dict);
+ if (code < 0) {
+ pdfi_countdown(o);
+ goto exit;
+ }
+ } else {
+ pdfi_countdown(o);
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+ }
+ pdfi_countdown(o);
+ }
+ code = gs_setcolortransfer_remap(ctx->pgs, map_procs[0], map_procs[1], map_procs[2], map_procs[3], false);
+ if (code < 0)
+ goto exit;
+
+ /* Second pass is to evaluate and set the transfer maps */
+ for (j = 0; j < 4; j++) {
+ if (proc_types[j] == E_DEFAULT) {
+ switch(j) {
+ case 0:
+ memcpy(ctx->pgs->set_transfer.red->values, ctx->page.DefaultTransfers[j].values, transfer_map_size * sizeof(frac));
+ break;
+ case 1:
+ memcpy(ctx->pgs->set_transfer.green->values, ctx->page.DefaultTransfers[j].values, transfer_map_size * sizeof(frac));
+ break;
+ case 2:
+ memcpy(ctx->pgs->set_transfer.blue->values, ctx->page.DefaultTransfers[j].values, transfer_map_size * sizeof(frac));
+ break;
+ case 3:
+ memcpy(ctx->pgs->set_transfer.gray->values, ctx->page.DefaultTransfers[j].values, transfer_map_size * sizeof(frac));
+ break;
+ }
+ }
+ if (proc_types[j] == E_FUNCTION) {
+ for (i = 0; i < transfer_map_size; i++) {
+ float v, f;
+ frac value;
+
+ f = (1.0f / (transfer_map_size - 1)) * i;
+
+ code = gs_function_evaluate(pfn[j], (const float *)&f, &v);
+ if (code < 0)
+ goto exit;
+
+ value =
+ (v < 0.0 ? float2frac(0.0) :
+ v >= 1.0 ? frac_1 :
+ float2frac(v));
+ switch(j) {
+ case 0:
+ ctx->pgs->set_transfer.red->values[i] = value;
+ break;
+ case 1:
+ ctx->pgs->set_transfer.green->values[i] = value;
+ break;
+ case 2:
+ ctx->pgs->set_transfer.blue->values[i] = value;
+ break;
+ case 3:
+ ctx->pgs->set_transfer.gray->values[i] = value;
+ break;
+ }
+ }
+ }
+ }
+ exit:
+// (void)pdfi_seek(ctx, ctx->main_stream, saved_stream_offset, SEEK_SET);
+ for (i = 0; i < 4; i++) {
+ pdfi_free_function(ctx, pfn[i]);
+ }
+ return code;
+}
+
+static int pdfi_set_gray_transfer(pdf_context *ctx, pdf_obj *tr_obj, pdf_dict *page_dict)
+{
+ int code = 0, i;
+ gs_function_t *pfn;
+
+ if (tr_obj->type != PDF_DICT && tr_obj->type != PDF_STREAM)
+ return_error(gs_error_typecheck);
+
+ code = pdfi_build_function(ctx, &pfn, NULL, 1, tr_obj, page_dict);
+ if (code < 0)
+ return code;
+
+ gs_settransfer_remap(ctx->pgs, gs_mapped_transfer, false);
+ for (i = 0; i < transfer_map_size; i++) {
+ float v, f;
+
+ f = (1.0f / (transfer_map_size - 1)) * i;
+
+ code = gs_function_evaluate(pfn, (const float *)&f, &v);
+ if (code < 0) {
+ pdfi_free_function(ctx, pfn);
+ return code;
+ }
+
+ ctx->pgs->set_transfer.gray->values[i] =
+ (v < 0.0 ? float2frac(0.0) :
+ v >= 1.0 ? frac_1 :
+ float2frac(v));
+ }
+ return pdfi_free_function(ctx, pfn);
+}
+
+static int pdfi_set_transfer(pdf_context *ctx, pdf_obj *obj, pdf_dict *page_dict, bool is_TR)
+{
+ int code = 0;
+
+ if (obj->type == PDF_NAME) {
+ if (pdfi_name_is((const pdf_name *)obj, "Identity")) {
+ code = gs_settransfer_remap(ctx->pgs, gs_identity_transfer, false);
+ goto exit;
+ } else {
+ if (!is_TR && pdfi_name_is((const pdf_name *)obj, "Default")) {
+ code = gs_settransfer_remap(ctx->pgs, ctx->page.DefaultTransfers[3].proc, false);
+ memcpy(ctx->pgs->set_transfer.gray->values, ctx->page.DefaultTransfers[3].values, transfer_map_size * sizeof(frac));
+ goto exit;
+ } else {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ }
+ }
+
+ if (obj->type == PDF_ARRAY) {
+ if (pdfi_array_size((pdf_array *)obj) != 4) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ } else {
+ code = pdfi_set_all_transfers(ctx, (pdf_array *)obj, page_dict, false);
+ }
+ } else
+ code = pdfi_set_gray_transfer(ctx, obj, page_dict);
+
+exit:
+ return code;
+}
+
+static int GS_TR(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code;
+ pdf_obj *obj = NULL;
+
+ code = pdfi_dict_get(ctx, GS, "TR", &obj);
+ if (code < 0)
+ return code;
+
+ code = pdfi_set_transfer(ctx, obj, page_dict, true);
+
+ pdfi_countdown(obj);
+
+ return code;
+}
+
+static int GS_TR2(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code;
+ pdf_obj *obj = NULL;
+ code = pdfi_dict_get(ctx, GS, "TR2", &obj);
+ if (code < 0)
+ return code;
+
+ code = pdfi_set_transfer(ctx, obj, page_dict, false);
+
+ pdfi_countdown(obj);
+
+ return code;
+}
+
+static const char *spot_functions[] = {
+ "{dup mul exch dup mul add 1 exch sub}", /* SimpleDot */
+ "{dup mul exch dup mul add 1 sub}", /* InvertedSimpleDot */
+ "{360 mul sin 2 div exch 360 mul sin 2 div add",/* DoubleDot */
+ "360 mul sin 2 div exch 360 mul\
+ sin 2 div add neg}", /* InvertedDoubleDot */
+ "{180 mul cos exch 180 mul cos add 2 div}", /* CosineDot */
+ "{360 mul sin 2 div exch 2 div \
+ 360 mul sin 2 div add}", /* Double */
+ "{360 mul sin 2 div exch 2 div \
+ 360 mul sin 2 div add neg}", /* InvertedDouble */
+ "{exch pop abs neg}", /* Line */
+ "{pop}", /* LineX */
+ "{exch pop}", /* LineY */
+ "{abs exch abs 2 copy add 1.0 le\
+ {dup mul exch dup mul add 1 exch sub}\
+ {1 sub dup mul exch 1 sub dup mul add 1 sub}\
+ ifelse}", /* Round */
+ "{abs exch abs 2 copy 3 mul exch 4 mul\
+ add 3 sub dup 0 lt\
+ {pop dup mul exch 0.75 div dup mul add\
+ 4 div 1 exch sub}\
+ {dup 1 gt\
+ {pop 1 exch sub dup mul exch 1 exch sub\
+ 0.75 div dup mul add 4 div 1 sub}\
+ {0.5 exch sub exch pop exch pop}}\
+ ifelse}ifelse}}", /* Ellipse */
+ "{dup mul 0.9 mul exch dup mul add 1 exch sub}",/* EllipseA */
+ "{dup mul 0.9 mul exch dup mul add 1 sub}", /* InvertedEllipseA */
+ "{dup 5 mul 8 div mul exch dup mul exch add\
+ sqrt 1 exch sub}", /* EllipseB */
+ "{dup mul exch dup mul 0.9 mul add 1 exch sub}",/* EllipseC */
+ "{dup mul exch dup mul 0.9 mul add 1 sub}", /* InvertedEllipseC */
+ "{abs exch abs 2 copy lt {exch} if pop neg}", /* Square */
+ "{abs exch abs 2 copy gt {exch} if pop neg}", /* Cross */
+ "{abs exch abs 0.9 mul add 2 div}", /* Rhomboid */
+ "{abs exch abs 2 copy add 0.75 le\
+ {dup mul exch dup mul add 1 exch sub}\
+ {2 copy add 1.23 le\
+ {0.85 mul add 1 exch sub}\
+ {1 sub dup mul exch 1 sub dup mul add 1 sub}\
+ ifelse} ifelse}" /* Diamond */
+};
+
+static const char *spot_table[] = {
+ "SimpleDot",
+ "InvertedSimpleDot",
+ "DoubleDot",
+ "InvertedDoubleDot",
+ "CosineDot",
+ "Double",
+ "InvertedDouble",
+ "Line",
+ "LineX",
+ "LineY",
+ "Round",
+ "Ellipse",
+ "EllipseA",
+ "InvertedEllipseA",
+ "EllipseB",
+ "EllipseC",
+ "InvertedEllipseC",
+ "Square",
+ "Cross",
+ "Rhomboid",
+ "Diamond"
+};
+
+/* Dummy spot function */
+static float
+pdfi_spot1_dummy(double x, double y)
+{
+ return (x + y) / 2;
+}
+
+static int pdfi_evaluate_transfer(pdf_context *ctx, pdf_obj *transfer, pdf_dict *page_dict, gx_transfer_map **pmap)
+{
+ int t_ix = 0, code = 0;
+ float value, out;
+ gs_function_t *transfer_fn = NULL;
+
+ rc_alloc_struct_1(*pmap, gx_transfer_map, &st_transfer_map, ctx->memory,
+ return_error(gs_error_VMerror),
+ "pdfi process_transfer");
+ (*pmap)->proc = gs_mapped_transfer; /* 0 => use closure */
+ (*pmap)->closure.proc = NULL;
+ (*pmap)->closure.data = NULL;
+ (*pmap)->id = gs_next_ids(ctx->memory, 1);
+
+ code = pdfi_build_function(ctx, &transfer_fn, (const float *)NULL, 1, transfer, page_dict);
+ if (code >= 0) {
+ for (t_ix = 0;t_ix < 256;t_ix++) {
+ value = (float)t_ix * 1.0f / 255.0f;
+ code = gs_function_evaluate(transfer_fn, (const float *)&value, &out);
+ if (code < 0)
+ goto error;
+ (*pmap)->values[t_ix] = float2frac(out);
+ }
+ }
+error:
+ pdfi_free_function(ctx, transfer_fn);
+ return code;
+}
+
+static int build_type1_halftone(pdf_context *ctx, pdf_dict *halftone_dict, pdf_dict *page_dict, gx_ht_order *porder, gs_halftone_component *phtc, char *name, int len, int comp_num)
+{
+ int code;
+ pdf_obj *obj = NULL, *transfer = NULL;
+ double f, a;
+ float values[2] = {0, 0}, domain[4] = {-1, 1, -1, 1}, out;
+ gs_function_t *pfn = NULL;
+ gx_ht_order *order = NULL;
+ gs_screen_enum *penum = NULL;
+ gs_point pt;
+ gx_transfer_map *pmap = NULL;
+
+ code = pdfi_dict_get_number(ctx, halftone_dict, "Frequency", &f);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_get_number(ctx, halftone_dict, "Angle", &a);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_get(ctx, halftone_dict, "SpotFunction", &obj);
+ if (code < 0)
+ return code;
+
+ order = (gx_ht_order *)gs_alloc_bytes(ctx->memory, sizeof(gx_ht_order), "build_type1_halftone");
+ if (order == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+ memset(order, 0x00, sizeof(gx_ht_order));
+
+ if (obj->type == PDF_NAME) {
+ int i;
+
+ if (pdfi_name_is((pdf_name *)obj, "Default")) {
+ i = 0;
+ } else {
+ for (i = 0; i < (sizeof(spot_table) / sizeof (char *)); i++){
+ if (pdfi_name_is((pdf_name *)obj, spot_table[i]))
+ break;
+ }
+ if (i >= (sizeof(spot_table) / sizeof (char *)))
+ return gs_note_error(gs_error_rangecheck);
+ }
+ code = pdfi_build_halftone_function(ctx, &pfn, (byte *)spot_functions[i], strlen(spot_functions[i]));
+ if (code < 0)
+ goto error;
+ } else {
+ if (obj->type == PDF_DICT || obj->type == PDF_STREAM) {
+ code = pdfi_build_function(ctx, &pfn, (const float *)domain, 2, obj, page_dict);
+ if (code < 0)
+ goto error;
+ } else {
+ code = gs_note_error(gs_error_typecheck);
+ goto error;
+ }
+ }
+
+ if (pdfi_dict_knownget(ctx, halftone_dict, "TransferFunction", &transfer) > 0) {
+ if (transfer->type == PDF_NAME) {
+ /* As far as I can tell, only /Identity is valid as a name, so we can just ignore
+ * names, if it's not Identity it would be an error (which we would ignore) and if
+ * it is, it has no effect. So what's the point ?
+ */
+ } else {
+ if (transfer->type == PDF_STREAM) {
+ pdfi_evaluate_transfer(ctx, transfer, page_dict, &pmap);
+ } else {
+ /* should be an error, but we can just ignore it */
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_TYPECHECK, "build_type1_halftone", NULL);
+ }
+ }
+ }
+
+ phtc->params.spot.screen.frequency = f;
+ phtc->params.spot.screen.angle = a;
+ phtc->params.spot.screen.spot_function = pdfi_spot1_dummy;
+ phtc->params.spot.transfer = (code > 0 ? (gs_mapping_proc) 0 : gs_mapped_transfer);
+ phtc->params.spot.transfer_closure.proc = 0;
+ phtc->params.spot.transfer_closure.data = 0;
+ phtc->type = ht_type_spot;
+ code = pdfi_get_name_index(ctx, name, len, (unsigned int *)&phtc->cname);
+ if (code < 0)
+ goto error;
+
+ if (comp_num == -1)
+ phtc->comp_number = gs_cname_to_colorant_number(ctx->pgs, (byte *)name, len, 1);
+ else
+ phtc->comp_number = comp_num;
+
+ code = gs_screen_order_init_memory(order, ctx->pgs, &phtc->params.spot.screen,
+ gs_currentaccuratescreens(ctx->memory), ctx->memory);
+ if (code < 0)
+ goto error;
+
+ penum = gs_screen_enum_alloc(ctx->memory, "build_type1_halftone");
+ if (penum == 0) {
+ code = gs_error_VMerror;
+ goto error;
+ }
+
+ code = gs_screen_enum_init_memory(penum, order, ctx->pgs, &phtc->params.spot.screen, ctx->memory);
+ if (code < 0)
+ goto error;
+
+ do {
+ /* Generate x and y, the parameteric variables */
+ code = gs_screen_currentpoint(penum, &pt);
+ if (code < 0)
+ goto error;
+
+ if (code == 1)
+ break;
+
+ /* Process sample */
+ values[0] = pt.x, values[1] = pt.y;
+ code = gs_function_evaluate(pfn, (const float *)&values, &out);
+ if (code < 0)
+ goto error;
+
+ /* Store the sample */
+ code = gs_screen_next(penum, out);
+ if (code < 0)
+ goto error;
+
+ } while (1);
+ code = 0;
+ *porder = penum->order;
+ (*porder).transfer = pmap;
+
+error:
+ pdfi_countdown(transfer);
+ pdfi_countdown(obj);
+ pdfi_free_function(ctx, pfn);
+ if (code < 0 && order != NULL) {
+ gs_free_object(ctx->memory, order->bit_data, "build_type1_halftone error");
+ gs_free_object(ctx->memory, order->levels, "build_type1_halftone error");
+ }
+ if (code < 0 && pmap != NULL)
+ rc_decrement(pmap, "pdfi process_transfer");
+ gs_free_object(ctx->memory, order, "build_type1_halftone");
+ gs_free_object(ctx->memory, penum, "build_type1_halftone");
+ return code;
+}
+
+static int build_type6_halftone(pdf_context *ctx, pdf_stream *halftone_stream, pdf_dict *page_dict,
+ gx_ht_order *porder, gs_halftone_component *phtc, char *name, int len)
+{
+ int code;
+ int64_t w, h, length;
+ gs_threshold2_halftone *ptp = &phtc->params.threshold2;
+ pdf_dict *halftone_dict = NULL;
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)halftone_stream, &halftone_dict);
+ if (code < 0)
+ return code;
+
+ ptp->thresholds.data = NULL;
+ ptp->thresholds.size = 0;
+
+ code = pdfi_dict_get_int(ctx, halftone_dict, "Width", &w);
+ if (code < 0)
+ return code;
+ ptp->width = w;
+ ptp->width2 = 0;
+
+ code = pdfi_dict_get_int(ctx, halftone_dict, "Height", &h);
+ if (code < 0)
+ return code;
+ ptp->height = h;
+ ptp->height2 = 0;
+
+ ptp->bytes_per_sample = 1;
+ ptp->transfer = 0;
+ ptp->transfer_closure.proc = 0;
+ ptp->transfer_closure.data = 0;
+
+ code = pdfi_get_name_index(ctx, name, len, (unsigned int *)&phtc->cname);
+ if (code < 0)
+ goto error;
+
+ phtc->comp_number = gs_cname_to_colorant_number(ctx->pgs, (byte *)name, len, 1);
+
+ code = pdfi_stream_to_buffer(ctx, halftone_stream,
+ (byte **)&ptp->thresholds.data, &length);
+ if (code < 0)
+ goto error;
+
+ /* Guard against a returned buffer larger than a gs_const_bytestring can hold */
+ if (length > max_uint) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto error;
+ }
+
+ ptp->thresholds.size = length;
+ phtc->type = ht_type_threshold2;
+ return code;
+
+error:
+ gs_free_object(ctx->memory, (byte *)ptp->thresholds.data, "build_type6_halftone");
+ return code;
+}
+
+static int build_type10_halftone(pdf_context *ctx, pdf_stream *halftone_stream, pdf_dict *page_dict, gx_ht_order *porder, gs_halftone_component *phtc, char *name, int len)
+{
+ int code;
+ int64_t w, h, length;
+ gs_threshold2_halftone *ptp = &phtc->params.threshold2;
+ pdf_dict *halftone_dict = NULL;
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)halftone_stream, &halftone_dict);
+
+ ptp->thresholds.data = NULL;
+ ptp->thresholds.size = 0;
+
+ code = pdfi_dict_get_int(ctx, halftone_dict, "Xsquare", &w);
+ if (code < 0)
+ return code;
+ ptp->width = ptp->height = w;
+
+ code = pdfi_dict_get_int(ctx, halftone_dict, "Ysquare", &h);
+ if (code < 0)
+ return code;
+ ptp->width2 = ptp->height2 = h;
+
+ ptp->bytes_per_sample = 1;
+ ptp->transfer = 0;
+ ptp->transfer_closure.proc = 0;
+ ptp->transfer_closure.data = 0;
+
+ code = pdfi_get_name_index(ctx, name, len, (unsigned int *)&phtc->cname);
+ if (code < 0)
+ goto error;
+
+ phtc->comp_number = gs_cname_to_colorant_number(ctx->pgs, (byte *)name, len, 1);
+
+ code = pdfi_stream_to_buffer(ctx, halftone_stream,
+ (byte **)&ptp->thresholds.data, &length);
+ if (code < 0)
+ goto error;
+
+ /* Guard against a returned buffer larger than a gs_const_bytestring can hold */
+ if (length > max_uint) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto error;
+ }
+
+ ptp->thresholds.size = length;
+ phtc->type = ht_type_threshold2;
+ return code;
+
+error:
+ gs_free_object(ctx->memory, (byte *)ptp->thresholds.data, "build_type10_halftone");
+ return code;
+}
+
+static int build_type16_halftone(pdf_context *ctx, pdf_stream *halftone_stream, pdf_dict *page_dict, gx_ht_order *porder, gs_halftone_component *phtc, char *name, int len)
+{
+ int code;
+ int64_t w, h, length;
+ gs_threshold2_halftone *ptp = &phtc->params.threshold2;
+ pdf_dict *halftone_dict = NULL;
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)halftone_stream, &halftone_dict);
+ if (code < 0)
+ return code;
+
+ ptp->thresholds.data = NULL;
+ ptp->thresholds.size = 0;
+
+ code = pdfi_dict_get_int(ctx, halftone_dict, "Width", &w);
+ if (code < 0)
+ return code;
+ ptp->width = w;
+
+ code = pdfi_dict_get_int(ctx, halftone_dict, "Height", &h);
+ if (code < 0)
+ return code;
+ ptp->height = h;
+
+ w = 0;
+ code = pdfi_dict_get_int(ctx, halftone_dict, "Width2", &w);
+ if (code < 0 && code != gs_error_undefined)
+ return code;
+ ptp->width2 = w;
+
+ h = 0;
+ code = pdfi_dict_get_int(ctx, halftone_dict, "Height2", &h);
+ if (code < 0 && code != gs_error_undefined)
+ return code;
+ ptp->height2 = h;
+
+ ptp->bytes_per_sample = 2;
+ ptp->transfer = 0;
+ ptp->transfer_closure.proc = 0;
+ ptp->transfer_closure.data = 0;
+
+ code = pdfi_get_name_index(ctx, name, len, (unsigned int *)&phtc->cname);
+ if (code < 0)
+ goto error;
+
+ phtc->comp_number = gs_cname_to_colorant_number(ctx->pgs, (byte *)name, len, 1);
+
+ code = pdfi_stream_to_buffer(ctx, halftone_stream,
+ (byte **)&ptp->thresholds.data, &length);
+ if (code < 0)
+ goto error;
+
+ /* Guard against a returned buffer larger than a gs_const_bytestring can hold */
+ if (length > max_uint) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto error;
+ }
+
+ ptp->thresholds.size = length;
+ phtc->type = ht_type_threshold2;
+ return code;
+
+error:
+ gs_free_object(ctx->memory, (byte *)ptp->thresholds.data, "build_type16_halftone");
+ return code;
+}
+
+static void pdfi_free_halftone(gs_memory_t *memory, void *data, client_name_t cname)
+{
+ int i=0;
+ gs_halftone *pht = (gs_halftone *)data;
+ gs_halftone_component comp;
+
+ for (i=0;i< pht->params.multiple.num_comp;i++) {
+ comp = pht->params.multiple.components[i];
+ switch(comp.type) {
+ case ht_type_threshold:
+ if (comp.params.threshold.thresholds.data != NULL)
+ gs_free_object(memory, (byte *)comp.params.threshold.thresholds.data, "pdfi_free_halftone - thresholds");
+ break;
+ case ht_type_threshold2:
+ if (comp.params.threshold2.thresholds.data != NULL)
+ gs_free_object(memory, (byte *)comp.params.threshold2.thresholds.data, "pdfi_free_halftone - thresholds");
+ break;
+ default:
+ break;
+ }
+ }
+ gs_free_object(memory, pht->params.multiple.components, "pdfi_free_halftone");
+ gs_free_object(memory, pht, "pdfi_free_halftone");
+}
+
+static int build_type5_halftone(pdf_context *ctx, pdf_dict *halftone_dict, pdf_dict *page_dict, gx_device_halftone *pdht, gs_halftone *pht)
+{
+ int code, code1, str_len, comp_number;
+ int64_t type;
+ char *str = NULL;
+ bool known = false;
+ gs_halftone_component *phtc = NULL, *phtc1;
+ gx_ht_order_component *pocs = 0;
+ pdf_obj *Key = NULL, *Value = NULL;
+ uint64_t index = 0, ix = 0;
+ int NumComponents = 0;
+ gx_ht_order *porder1 = NULL;
+ pdf_dict *subdict = NULL;
+
+ /* The only case involving multiple halftones, we need to enumerate each entry
+ * in the dictionary
+ */
+ /* Type 5 halftone dictionaries are required to have a Default */
+ code = pdfi_dict_known(ctx, halftone_dict, "Default", &known);
+ if (code < 0)
+ return code;
+ if (!known) {
+ code = gs_note_error(gs_error_undefined);
+ return code;
+ }
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ goto error;
+ code = pdfi_dict_first(ctx, halftone_dict, &Key, &Value, &index);
+ code1 = pdfi_loop_detector_cleartomark(ctx);
+ if (code < 0)
+ goto error;
+ if (code1 < 0) {
+ code = code1;
+ goto error;
+ }
+
+ /* First establish the number of components from the halftone which we will use.
+ * If the component number is GX_DEVICE_COLOR_MAX_COMPONENTS then its the default,
+ * if its < 0 then its not available in the device. Otherwise its a colorant which is
+ * being rendered, so we need to set that halftone component. The Default will be
+ * stored in the device halftone order rather than in the component array order
+ * members.
+ */
+ do {
+ if (Key->type != PDF_NAME) {
+ code = gs_note_error(gs_error_typecheck);
+ goto error;
+ }
+ if (!pdfi_name_is((const pdf_name *)Key, "HalftoneName") && !pdfi_name_is((const pdf_name *)Key, "HalftoneType") && !pdfi_name_is((const pdf_name *)Key, "Type")) {
+ code = pdfi_string_from_name(ctx, (pdf_name *)Key, &str, &str_len);
+ if (code < 0)
+ goto error;
+
+ comp_number = gs_cname_to_colorant_number(ctx->pgs, (byte *)str, str_len,
+ ht_type_multiple);
+ if (comp_number >= 0)
+ NumComponents++;
+ gs_free_object(ctx->memory, str, "pdfi_string_from_name");
+ str = NULL;
+ }
+
+ pdfi_countdown(Key);
+ pdfi_countdown(Value);
+ Key = Value = NULL;
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ goto error;
+ code = pdfi_dict_next(ctx, halftone_dict, &Key, &Value, &index);
+ code1 = pdfi_loop_detector_cleartomark(ctx);
+ if (code < 0 && code != gs_error_undefined)
+ goto error;
+ else if (code1 < 0) {
+ code = code1;
+ goto error;
+ }
+ } while (code >= 0);
+
+ if (NumComponents == 0) {
+ code = gs_note_error(gs_error_syntaxerror);
+ goto error;
+ }
+
+ pocs = gs_alloc_struct_array(ctx->memory, NumComponents,
+ gx_ht_order_component,
+ &st_ht_order_component_element,
+ "gs_sethalftone");
+ if (pocs == NULL)
+ goto error;
+
+ memset(pocs, 0x00, NumComponents * sizeof(gx_ht_order_component));
+ pdht->components = pocs;
+ pdht->num_comp = NumComponents;
+ phtc = (gs_halftone_component *)gs_alloc_bytes(ctx->memory, sizeof(gs_halftone_component) * NumComponents, "pdfi_do_halftone");
+ if (phtc == 0) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ goto error;
+ code = pdfi_dict_first(ctx, halftone_dict, &Key, &Value, &index);
+ code1 = pdfi_loop_detector_cleartomark(ctx);
+ if (code < 0)
+ goto error;
+ else if (code1 < 0) {
+ code = code1;
+ goto error;
+ }
+
+ /* index 0 in the component array is reserved for the Default, we can't get here without
+ * having a /Default, so we just leave room for it and start filing the other inks from
+ * index 1.
+ */
+ ix = 1;
+ do {
+ if (Key->type != PDF_NAME) {
+ code = gs_note_error(gs_error_typecheck);
+ goto error;
+ }
+ if (!pdfi_name_is((const pdf_name *)Key, "HalftoneName") && !pdfi_name_is((const pdf_name *)Key, "HalftoneType") && !pdfi_name_is((const pdf_name *)Key, "Type")) {
+ if (!pdfi_name_is((const pdf_name *)Key, "HalftoneName") && !pdfi_name_is((const pdf_name *)Key, "HalftoneType") && !pdfi_name_is((const pdf_name *)Key, "Type")) {
+ code = pdfi_dict_from_obj(ctx, Value, &subdict);
+ if (code < 0)
+ goto error;
+
+ code = pdfi_string_from_name(ctx, (pdf_name *)Key, &str, &str_len);
+ if (code < 0)
+ goto error;
+
+ comp_number = gs_cname_to_colorant_number(ctx->pgs, (byte *)str, str_len,
+ ht_type_multiple);
+ if (comp_number >= 0) {
+ /* If comp_number == GX_DEVICE_COLOR_MAX_COMPONENTS then it is the /Default
+ * In that case we want to store it in index 0 of the halftone components array
+ */
+ if (comp_number == GX_DEVICE_COLOR_MAX_COMPONENTS) {
+ phtc[0].comp_number = comp_number;
+ porder1 = &(pdht->components[0].corder);
+ pdht->components[0].comp_number = comp_number;
+ phtc1 = &phtc[0];
+ } else {
+ phtc[ix].comp_number = comp_number;
+ porder1 = &(pdht->components[ix].corder);
+ pdht->components[ix].comp_number = phtc[ix].comp_number;
+ phtc1 = &phtc[ix++];
+ }
+
+ code = pdfi_dict_get_int(ctx, subdict, "HalftoneType", &type);
+ if (code < 0)
+ goto error;
+
+ switch(type) {
+ case 1:
+ code = build_type1_halftone(ctx, (pdf_dict *)Value, page_dict, porder1, phtc1, str, str_len, comp_number);
+ if (code < 0)
+ goto error;
+ break;
+ case 6:
+ if (Value->type != PDF_STREAM) {
+ code = gs_note_error(gs_error_typecheck);
+ goto error;
+ }
+ code = build_type6_halftone(ctx, (pdf_stream *)Value, page_dict, porder1, phtc1, str, str_len);
+ if (code < 0)
+ goto error;
+ break;
+ case 10:
+ if (Value->type != PDF_STREAM) {
+ code = gs_note_error(gs_error_typecheck);
+ goto error;
+ }
+ code = build_type10_halftone(ctx, (pdf_stream *)Value, page_dict, porder1, phtc1, str, str_len);
+ if (code < 0)
+ goto error;
+ break;
+ case 16:
+ if (Value->type != PDF_STREAM) {
+ code = gs_note_error(gs_error_typecheck);
+ goto error;
+ }
+ code = build_type16_halftone(ctx, (pdf_stream *)Value, page_dict, porder1, phtc1, str, str_len);
+ if (code < 0)
+ goto error;
+ break;
+ default:
+ code = gs_note_error(gs_error_rangecheck);
+ goto error;
+ break;
+
+ }
+ gs_free_object(ctx->memory, str, "pdfi_string_from_name");
+ str = NULL;
+ } else {
+ gs_free_object(ctx->memory, str, "pdfi_string_from_name");
+ str = NULL;
+ }
+ }
+ }
+
+ pdfi_countdown(Key);
+ pdfi_countdown(Value);
+ Key = Value = NULL;
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ goto error;
+ code = pdfi_dict_next(ctx, halftone_dict, &Key, &Value, &index);
+ code1 = pdfi_loop_detector_cleartomark(ctx);
+ if (code < 0 && code != gs_error_undefined)
+ goto error;
+ else if (code1 < 0) {
+ code = code1;
+ goto error;
+ }
+ } while (code >= 0);
+ code = 0;
+
+ /* If we only had one component, it must be the Default, in which case we
+ * do not need the components array. So we can copy the order from the 0th
+ * index of the components array (Default is stored at index 0) to the
+ * device halftone order, and free the components array.
+ */
+ pdht->order = pdht->components[0].corder;
+ if (ix == 1) {
+ gs_free_object(ctx->memory, pocs, "pdfi_build_type5_halftone");
+ pdht->components = 0;
+ pdht->num_comp = 0;
+ } else {
+ pdht->components = pocs;
+ pdht->num_comp = ix;
+ }
+
+ pht->type = ht_type_multiple;
+ pht->params.multiple.components = phtc;
+ pht->params.multiple.num_comp = NumComponents;
+ pht->params.multiple.get_colorname_string = pdfi_separation_name_from_index;
+
+ return 0;
+
+error:
+ pdfi_countdown(Key);
+ pdfi_countdown(Value);
+ gs_free_object(ctx->memory, str, "pdfi_string_from_name");
+ gs_free_object(ctx->memory, pocs, "pdfi_build_type5_halftone");
+ gs_free_object(ctx->memory, phtc, "pdfi_build_type5_halftone");
+ pht->params.multiple.components = NULL;
+ pht->params.multiple.num_comp = 0;
+ pdht->components = NULL;
+ pdht->num_comp = 0;
+ return code;
+}
+
+static int pdfi_do_halftone(pdf_context *ctx, pdf_obj *halftone_obj, pdf_dict *page_dict)
+{
+ int code;
+ char *str = NULL;
+ int64_t type;
+ gs_halftone *pht = NULL;
+ gx_device_halftone *pdht = NULL;
+ gs_halftone_component *phtc = NULL;
+ pdf_obj *Key = NULL, *Value = NULL, *transfer = NULL;
+ pdf_dict *halftone_dict = NULL;
+ gx_transfer_map *pmap = NULL;
+
+ code = pdfi_dict_from_obj(ctx, halftone_obj, &halftone_dict);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_get_int(ctx, halftone_dict, "HalftoneType", &type);
+ if (code < 0)
+ return code;
+
+ pht = (gs_halftone *)gs_alloc_bytes(ctx->memory, sizeof(gs_halftone), "pdfi_do_halftone");
+ if (pht == 0) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+ memset(pht, 0x00, sizeof(gs_halftone));
+ pht->rc.memory = ctx->memory;
+ pht->rc.free = pdfi_free_halftone;
+
+ pdht = (gx_device_halftone *)gs_alloc_bytes(ctx->memory, sizeof(gx_device_halftone), "pdfi_do_halftone");
+ if (pdht == 0) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+ memset(pdht, 0x00, sizeof(gx_device_halftone));
+ pdht->num_dev_comp = ctx->pgs->device->color_info.num_components;
+ pdht->rc.memory = ctx->memory;
+
+ switch(type) {
+ case 1:
+ phtc = (gs_halftone_component *)gs_alloc_bytes(ctx->memory, sizeof(gs_halftone_component), "pdfi_do_halftone");
+ if (phtc == 0) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+
+ code = build_type1_halftone(ctx, halftone_dict, page_dict, &pdht->order, phtc, (char *)"Default", 7, -1);
+ if (code < 0)
+ goto error;
+
+ pht->type = ht_type_multiple;
+ pht->params.multiple.components = phtc;
+ pht->params.multiple.num_comp = 1;
+ pht->params.multiple.get_colorname_string = pdfi_separation_name_from_index;
+ code = gx_gstate_dev_ht_install(ctx->pgs, pdht, pht->type, gs_currentdevice_inline(ctx->pgs), HT_OBJTYPE_DEFAULT);
+ if (code < 0)
+ goto error;
+
+ gx_device_halftone_release(pdht, pdht->rc.memory);
+ rc_decrement(ctx->pgs->halftone, "pdfi_do_halftone(halftone)");
+ ctx->pgs->halftone = pht;
+ rc_increment(ctx->pgs->halftone);
+ gx_unset_both_dev_colors(ctx->pgs);
+ break;
+
+ case 5:
+ code = build_type5_halftone(ctx, halftone_dict, page_dict, pdht, pht);
+ if (code < 0)
+ goto error;
+
+ code = gx_gstate_dev_ht_install(ctx->pgs, pdht, pht->type, gs_currentdevice_inline(ctx->pgs), HT_OBJTYPE_DEFAULT);
+ if (code < 0)
+ goto error;
+
+ gx_device_halftone_release(pdht, pdht->rc.memory);
+ rc_decrement(ctx->pgs->halftone, "");
+ ctx->pgs->halftone = pht;
+ rc_increment(ctx->pgs->halftone);
+ gx_unset_both_dev_colors(ctx->pgs);
+ break;
+
+ case 6:
+ if (halftone_obj->type != PDF_STREAM)
+ return_error(gs_error_typecheck);
+ phtc = (gs_halftone_component *)gs_alloc_bytes(ctx->memory, sizeof(gs_halftone_component), "pdfi_do_halftone");
+ if (phtc == 0) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+
+ code = build_type6_halftone(ctx, (pdf_stream *)halftone_obj, page_dict, &pdht->order, phtc, (char *)"Default", 7);
+ if (code < 0)
+ goto error;
+
+ pht->type = ht_type_multiple;
+ pht->params.multiple.components = phtc;
+ pht->params.multiple.num_comp = 1;
+ pht->params.multiple.get_colorname_string = pdfi_separation_name_from_index;
+
+ code = gs_sethalftone_prepare(ctx->pgs, pht, pdht);
+
+ /* Transfer function pdht->order->transfer */
+ if (pdfi_dict_knownget(ctx, ((pdf_stream *)halftone_obj)->stream_dict, "TransferFunction", &transfer) > 0) {
+ if (transfer->type == PDF_NAME) {
+ /* As far as I can tell, only /Identity is valid as a name, so we can just ignore
+ * names, if it's not Identity it would be an error (which we would ignore) and if
+ * it is, it has no effect. So what's the point ?
+ */
+ } else {
+ if (transfer->type == PDF_STREAM) {
+ /* If we get an error here, we can just ignore it, and not apply the transfer */
+ code = pdfi_evaluate_transfer(ctx, transfer, page_dict, &pmap);
+ if (code >= 0) {
+ pdht->order.transfer = pmap;
+ }
+ } else {
+ /* should be an error, but we can just ignore it */
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_TYPECHECK, "do_halftone", NULL);
+ }
+ }
+ pdfi_countdown(transfer);
+ }
+
+ code = gx_gstate_dev_ht_install(ctx->pgs, pdht, pht->type, gs_currentdevice_inline(ctx->pgs), HT_OBJTYPE_DEFAULT);
+ if (code < 0)
+ goto error;
+
+ gx_device_halftone_release(pdht, pdht->rc.memory);
+ rc_decrement(ctx->pgs->halftone, "pdfi_do_halftone(halftone)");
+ ctx->pgs->halftone = pht;
+ rc_increment(ctx->pgs->halftone);
+ gx_unset_both_dev_colors(ctx->pgs);
+ break;
+ case 10:
+ if (halftone_obj->type != PDF_STREAM)
+ return_error(gs_error_typecheck);
+ phtc = (gs_halftone_component *)gs_alloc_bytes(ctx->memory, sizeof(gs_halftone_component), "pdfi_do_halftone");
+ if (phtc == 0) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+
+ code = build_type10_halftone(ctx, (pdf_stream *)halftone_obj, page_dict, &pdht->order, phtc, (char *)"Default", 7);
+ if (code < 0)
+ goto error;
+
+ pht->type = ht_type_multiple;
+ pht->params.multiple.components = phtc;
+ pht->params.multiple.num_comp = 1;
+ pht->params.multiple.get_colorname_string = pdfi_separation_name_from_index;
+
+ code = gs_sethalftone_prepare(ctx->pgs, pht, pdht);
+
+ /* Transfer function pdht->order->transfer */
+ if (pdfi_dict_knownget(ctx, ((pdf_stream *)halftone_obj)->stream_dict, "TransferFunction", &transfer) > 0) {
+ if (transfer->type == PDF_NAME) {
+ /* As far as I can tell, only /Identity is valid as a name, so we can just ignore
+ * names, if it's not Identity it would be an error (which we would ignore) and if
+ * it is, it has no effect. So what's the point ?
+ */
+ } else {
+ if (transfer->type == PDF_STREAM) {
+ /* If we get an error here, we can just ignore it, and not apply the transfer */
+ code = pdfi_evaluate_transfer(ctx, transfer, page_dict, &pmap);
+ if (code >= 0) {
+ pdht->order.transfer = pmap;
+ }
+ } else {
+ /* should be an error, but we can just ignore it */
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_TYPECHECK, "do_halftone", NULL);
+ }
+ }
+ pdfi_countdown(transfer);
+ }
+
+ code = gx_gstate_dev_ht_install(ctx->pgs, pdht, pht->type, gs_currentdevice_inline(ctx->pgs), HT_OBJTYPE_DEFAULT);
+ if (code < 0)
+ goto error;
+
+ gx_device_halftone_release(pdht, pdht->rc.memory);
+ rc_decrement(ctx->pgs->halftone, "pdfi_do_halftone(halftone)");
+ ctx->pgs->halftone = pht;
+ rc_increment(ctx->pgs->halftone);
+ gx_unset_both_dev_colors(ctx->pgs);
+ break;
+ case 16:
+ if (halftone_obj->type != PDF_STREAM)
+ return_error(gs_error_typecheck);
+ phtc = (gs_halftone_component *)gs_alloc_bytes(ctx->memory, sizeof(gs_halftone_component), "pdfi_do_halftone");
+ if (phtc == 0) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+
+ code = build_type16_halftone(ctx, (pdf_stream *)halftone_obj, page_dict, &pdht->order, phtc, (char *)"Default", 7);
+ if (code < 0)
+ goto error;
+
+ pht->type = ht_type_multiple;
+ pht->params.multiple.components = phtc;
+ pht->params.multiple.num_comp = 1;
+ pht->params.multiple.get_colorname_string = pdfi_separation_name_from_index;
+
+ code = gs_sethalftone_prepare(ctx->pgs, pht, pdht);
+
+ /* Transfer function pdht->order->transfer */
+ if (pdfi_dict_knownget(ctx, ((pdf_stream *)halftone_obj)->stream_dict, "TransferFunction", &transfer) > 0) {
+ if (transfer->type == PDF_NAME) {
+ /* As far as I can tell, only /Identity is valid as a name, so we can just ignore
+ * names, if it's not Identity it would be an error (which we would ignore) and if
+ * it is, it has no effect. So what's the point ?
+ */
+ } else {
+ if (transfer->type == PDF_STREAM) {
+ /* If we get an error here, we can just ignore it, and not apply the transfer */
+ code = pdfi_evaluate_transfer(ctx, transfer, page_dict, &pmap);
+ if (code >= 0) {
+ pdht->order.transfer = pmap;
+ }
+ } else {
+ /* should be an error, but we can just ignore it */
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_TYPECHECK, "do_halftone", NULL);
+ }
+ }
+ pdfi_countdown(transfer);
+ }
+
+ code = gx_gstate_dev_ht_install(ctx->pgs, pdht, pht->type, gs_currentdevice_inline(ctx->pgs), HT_OBJTYPE_DEFAULT);
+ if (code < 0)
+ goto error;
+
+ gx_device_halftone_release(pdht, pdht->rc.memory);
+ rc_decrement(ctx->pgs->halftone, "pdfi_do_halftone(halftone)");
+ ctx->pgs->halftone = pht;
+ rc_increment(ctx->pgs->halftone);
+ gx_unset_both_dev_colors(ctx->pgs);
+ break;
+ default:
+ code = gs_note_error(gs_error_rangecheck);
+ goto error;
+ break;
+ }
+ gs_free_object(ctx->memory, pdht, "pdfi_do_halftone");
+ return 0;
+
+error:
+ if (pdht != NULL)
+ gx_device_halftone_release(pdht, pdht->rc.memory);
+ gs_free_object(ctx->memory, str, "pdfi_string_from_name");
+ pdfi_countdown(Key);
+ pdfi_countdown(Value);
+ gs_free_object(ctx->memory, pht, "pdfi_do_halftone");
+ gs_free_object(ctx->memory, phtc, "pdfi_do_halftone");
+ gs_free_object(ctx->memory, pdht, "pdfi_do_halftone");
+ return code;
+}
+
+static int GS_HT(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code;
+ pdf_obj *obj = NULL;
+
+ code = pdfi_dict_get(ctx, GS, "HT", &obj);
+ if (code < 0)
+ return code;
+
+
+ if (obj->type == PDF_NAME) {
+ if (pdfi_name_is((const pdf_name *)obj, "Default")) {
+ goto exit;
+ } else {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ } else {
+ code = pdfi_do_halftone(ctx, obj, page_dict);
+ }
+
+exit:
+ pdfi_countdown(obj);
+ return code;
+}
+
+static int GS_FL(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code;
+ double d1;
+
+ code = pdfi_dict_get_number(ctx, GS, "FL", &d1);
+ if (code < 0)
+ return code;
+
+ code = gs_setflat(ctx->pgs, d1);
+ return code;
+}
+
+static int GS_SM(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code;
+ double d1;
+
+ code = pdfi_dict_get_number(ctx, GS, "SM", &d1);
+ if (code < 0)
+ return code;
+
+ code = gs_setsmoothness(ctx->pgs, d1);
+ return code;
+}
+
+static int GS_SA(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ pdf_bool *b;
+ int code;
+
+ code = pdfi_dict_get_type(ctx, GS, "SA", PDF_BOOL, (pdf_obj **)&b);
+ if (code < 0)
+ return code;
+
+ code = gs_setstrokeadjust(ctx->pgs, b->value);
+ pdfi_countdown(b);
+ return 0;
+}
+
+static int GS_BM(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ pdf_name *n;
+ int code;
+ gs_blend_mode_t mode;
+
+ code = pdfi_dict_get_type(ctx, GS, "BM", PDF_NAME, (pdf_obj **)&n);
+ if (code < 0)
+ return code;
+
+ code = pdfi_get_blend_mode(ctx, n, &mode);
+ pdfi_countdown(n);
+ if (code == 0)
+ return gs_setblendmode(ctx->pgs, mode);
+ return_error(gs_error_undefined);
+}
+
+static int GS_SMask(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ pdf_obj *o = NULL;
+ pdfi_int_gstate *igs = (pdfi_int_gstate *)ctx->pgs->client_data;
+ int code;
+ pdf_bool *Processed = NULL;
+
+ if (ctx->page.has_transparency == false || ctx->args.notransparency == true)
+ return 0;
+
+ code = pdfi_dict_get(ctx, GS, "SMask", (pdf_obj **)&o);
+ if (code < 0)
+ return code;
+
+ if (o->type == PDF_NAME) {
+ pdf_name *n = (pdf_name *)o;
+
+ if (pdfi_name_is(n, "None")) {
+ if (igs->SMask) {
+ pdfi_gstate_smask_free(igs);
+ code = pdfi_trans_end_smask_notify(ctx);
+ }
+ goto exit;
+ }
+ code = pdfi_find_resource(ctx, (unsigned char *)"ExtGState", n, stream_dict, page_dict, &o);
+ pdfi_countdown(n);
+ if (code < 0)
+ return code;
+ }
+
+ if (o->type == PDF_DICT) {
+ code = pdfi_dict_knownget_type(ctx, (pdf_dict *)o, "Processed", PDF_BOOL, (pdf_obj **)&Processed);
+ /* Need to clear the Processed flag in the SMask if another value is set
+ * (even if it's the same SMask?)
+ * TODO: I think there is a better way to do this that doesn't require sticking this
+ * flag in the SMask dictionary. But for now, let's get correct behavior.
+ */
+ if (code > 0 && Processed->value)
+ Processed->value = false;
+ if (igs->SMask)
+ pdfi_gstate_smask_free(igs);
+ /* We need to use the graphics state memory, in case we are running under Ghostscript. */
+ pdfi_gstate_smask_install(igs, ctx->pgs->memory, (pdf_dict *)o, ctx->pgs);
+ }
+
+ exit:
+ pdfi_countdown(o);
+ pdfi_countdown(Processed);
+ return 0;
+}
+
+static int GS_CA(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code;
+ double d1;
+
+ code = pdfi_dict_get_number(ctx, GS, "CA", &d1);
+ if (code < 0)
+ return code;
+
+ code = gs_setstrokeconstantalpha(ctx->pgs, d1);
+ return code;
+}
+
+static int GS_ca(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code;
+ double d1;
+
+ code = pdfi_dict_get_number(ctx, GS, "ca", &d1);
+ if (code < 0)
+ return code;
+
+ code = gs_setfillconstantalpha(ctx->pgs, d1);
+ return code;
+}
+
+static int GS_AIS(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ pdf_bool *b;
+ int code;
+
+ code = pdfi_dict_get_type(ctx, GS, "AIS", PDF_BOOL, (pdf_obj **)&b);
+ if (code < 0)
+ return code;
+
+ code = gs_setalphaisshape(ctx->pgs, b->value);
+ pdfi_countdown(b);
+ return 0;
+}
+
+static int GS_TK(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ pdf_bool *b;
+ int code;
+
+ code = pdfi_dict_get_type(ctx, GS, "TK", PDF_BOOL, (pdf_obj **)&b);
+ if (code < 0)
+ return code;
+
+ code = gs_settextknockout(ctx->pgs, b->value);
+ pdfi_countdown(b);
+ return 0;
+}
+
+typedef int (*GS_proc)(pdf_context *ctx, pdf_dict *GS, pdf_dict *stream_dict, pdf_dict *page_dict);
+
+typedef struct GS_Func {
+ const char *Name;
+ GS_proc proc;
+} GS_Func_t;
+
+GS_Func_t ExtGStateTable[] = {
+ {"LW", GS_LW},
+ {"LC", GS_LC},
+ {"LJ", GS_LJ},
+ {"ML", GS_ML},
+ {"D", GS_D},
+ {"RI", GS_RI},
+ {"OP", GS_OP},
+ {"op", GS_op},
+ {"OPM", GS_OPM},
+ {"Font", GS_Font},
+ {"BG", GS_BG},
+ {"BG2", GS_BG2},
+ {"UCR", GS_UCR},
+ {"UCR2", GS_UCR2},
+ {"TR", GS_TR},
+ {"TR2", GS_TR2},
+ {"HT", GS_HT},
+ {"FL", GS_FL},
+ {"SM", GS_SM},
+ {"SA", GS_SA},
+ {"BM", GS_BM},
+ {"SMask", GS_SMask},
+ {"CA", GS_CA},
+ {"ca", GS_ca},
+ {"AIS", GS_AIS},
+ {"TK", GS_TK},
+};
+
+/* Set gstate from dictionary
+ * NOTE: stream_dict may not be needed and can currently be NULL.
+ * If we decide it can't be NULL, check Patterns implementation to refactor it to pass that param.
+ */
+int pdfi_set_ExtGState(pdf_context *ctx, pdf_dict *stream_dict,
+ pdf_dict *page_dict, pdf_dict *gstate_dict)
+{
+ int code, i, limit = sizeof(ExtGStateTable) / sizeof (GS_Func_t);
+ bool known;
+
+ for (i=0;i < limit; i++) {
+ code = pdfi_dict_known(ctx, gstate_dict, ExtGStateTable[i].Name, &known);
+ if (code < 0)
+ break;
+ if (known) {
+ code = ExtGStateTable[i].proc(ctx, gstate_dict, NULL, page_dict);
+ if (code < 0)
+ break;
+ }
+ }
+ return code;
+}
+
+int pdfi_setgstate(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ pdf_name *n;
+ pdf_obj *o = NULL;
+ int code=0, code1 = 0;
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ return code;
+
+ if (pdfi_count_stack(ctx) < 1) {
+ code = gs_note_error(gs_error_stackunderflow);
+ goto setgstate_error;
+ }
+ n = (pdf_name *)ctx->stack_top[-1];
+ if (n->type != PDF_NAME) {
+ pdfi_pop(ctx, 1);
+ code = gs_note_error(gs_error_typecheck);
+ goto setgstate_error;
+ }
+
+ code = pdfi_find_resource(ctx, (unsigned char *)"ExtGState", n, (pdf_dict *)stream_dict,
+ page_dict, &o);
+ pdfi_pop(ctx, 1);
+ if (code < 0)
+ goto setgstate_error;
+
+ if (o->type != PDF_DICT) {
+ code = gs_note_error(gs_error_typecheck);
+ goto setgstate_error;
+ }
+
+ code = pdfi_set_ExtGState(ctx, stream_dict, page_dict, (pdf_dict *)o);
+
+setgstate_error:
+ code1 = pdfi_loop_detector_cleartomark(ctx);
+ if (code == 0) code = code1;
+
+ pdfi_countdown(o);
+ return code;
+}
+
+
+int pdfi_free_DefaultQState(pdf_context *ctx)
+{
+ if (ctx->DefaultQState)
+ gs_gstate_free(ctx->DefaultQState);
+ ctx->DefaultQState = NULL;
+ return 0;
+}
+
+int pdfi_set_DefaultQState(pdf_context *ctx, gs_gstate *pgs)
+{
+ pdfi_free_DefaultQState(ctx);
+ /* We need to use the graphics state memory, in case we are running under Ghostscript. */
+ ctx->DefaultQState = gs_gstate_copy(pgs, ctx->pgs->memory);
+ if (ctx->DefaultQState == NULL)
+ return_error(gs_error_VMerror);
+ return 0;
+}
+
+gs_gstate *pdfi_get_DefaultQState(pdf_context *ctx)
+{
+ return ctx->DefaultQState;
+}
+
+int pdfi_copy_DefaultQState(pdf_context *ctx, gs_gstate **pgs)
+{
+ /* We need to use the graphics state memory, in case we are running under Ghostscript. */
+ *pgs = gs_gstate_copy(ctx->DefaultQState, ctx->pgs->memory);
+ if (*pgs == NULL)
+ return_error(gs_error_VMerror);
+ return 0;
+}
+
+int pdfi_restore_DefaultQState(pdf_context *ctx, gs_gstate **pgs)
+{
+ int code;
+
+ code = pdfi_set_DefaultQState(ctx, *pgs);
+ gs_gstate_free(*pgs);
+ *pgs = NULL;
+ return code;
+}
diff --git a/pdf/pdf_gstate.h b/pdf/pdf_gstate.h
new file mode 100644
index 00000000..37bc55a9
--- /dev/null
+++ b/pdf/pdf_gstate.h
@@ -0,0 +1,57 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Graphics state operations for the PDF interpreter */
+
+#ifndef PDF_GSTATE_OPERATORS
+#define PDF_GSTATE_OPERATORS
+
+/* Interpreter graphics state things (see igstate.h/int_gstate) */
+typedef struct int_gstate_s {
+ pdf_context *ctx;
+ pdf_dict *SMask; /* PDF only, null | dictionary | true */
+ gs_gstate *GroupGState; /* gstate associated with the SMask */
+ gs_memory_t *memory;
+} pdfi_int_gstate;
+
+int pdfi_gstate_set_client(pdf_context *ctx, gs_gstate *pgs);
+void pdfi_gstate_smask_install(pdfi_int_gstate *igs, gs_memory_t *memory, pdf_dict *SMask, gs_gstate *gstate);
+void pdfi_gstate_smask_free(pdfi_int_gstate *igs);
+
+int pdfi_get_blend_mode(pdf_context *ctx, pdf_name *name, gs_blend_mode_t *mode);
+
+int pdfi_concat(pdf_context *ctx);
+int pdfi_gsave(pdf_context *ctx);
+int pdfi_grestore(pdf_context *ctx);
+int pdfi_gs_setgstate(gs_gstate * pgs, const gs_gstate * pfrom);
+int pdfi_op_q(pdf_context *ctx);
+int pdfi_op_Q(pdf_context *ctx);
+int pdfi_setlinewidth(pdf_context *ctx);
+int pdfi_setlinejoin(pdf_context *ctx);
+int pdfi_setlinecap(pdf_context *ctx);
+int pdfi_setflat(pdf_context *ctx);
+int pdfi_setdash(pdf_context *ctx);
+int pdfi_setmiterlimit(pdf_context *ctx);
+int pdfi_setgstate(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict);
+int pdfi_setdash_impl(pdf_context *ctx, pdf_array *a, double phase_d);
+int pdfi_set_ExtGState(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict, pdf_dict *gstate_dict);
+
+int pdfi_free_DefaultQState(pdf_context *ctx);
+int pdfi_set_DefaultQState(pdf_context *ctx, gs_gstate *pgs);
+gs_gstate *pdfi_get_DefaultQState(pdf_context *ctx);
+int pdfi_copy_DefaultQState(pdf_context *ctx, gs_gstate **pgs);
+int pdfi_restore_DefaultQState(pdf_context *ctx, gs_gstate **pgs);
+
+#endif
diff --git a/pdf/pdf_image.c b/pdf/pdf_image.c
new file mode 100644
index 00000000..a52e5e8e
--- /dev/null
+++ b/pdf/pdf_image.c
@@ -0,0 +1,2510 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Image operations for the PDF interpreter */
+
+#include "pdf_int.h"
+#include "pdf_stack.h"
+#include "pdf_gstate.h"
+#include "pdf_doc.h"
+#include "pdf_page.h"
+#include "pdf_image.h"
+#include "pdf_file.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_loop_detect.h"
+#include "pdf_colour.h"
+#include "pdf_trans.h"
+#include "pdf_misc.h"
+#include "pdf_optcontent.h"
+#include "stream.h" /* for stell() */
+#include "gsicc_cache.h"
+
+#include "gspath2.h"
+#include "gsiparm4.h"
+#include "gsiparm3.h"
+#include "gsipar3x.h"
+#include "gsform1.h"
+#include "gstrans.h"
+#include "gxdevsop.h" /* For special ops */
+#include "gspath.h" /* For gs_moveto() and friends */
+#include "gsstate.h" /* For gs_setoverprintmode() */
+#include "gscoord.h" /* for gs_concat() and others */
+
+int pdfi_BI(pdf_context *ctx)
+{
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_BI", NULL);
+
+ return pdfi_mark_stack(ctx, PDF_DICT_MARK);
+}
+
+typedef struct {
+ int comps;
+ int bpc;
+ uint32_t cs_enum;
+ bool iccbased;
+ bool no_data;
+ bool is_valid;
+ uint32_t icc_offset;
+ uint32_t icc_length;
+} pdfi_jpx_info_t;
+
+typedef struct {
+ /* Type and SubType were already checked by caller */
+ /* OPI, Metadata -- do we care? */
+ bool ImageMask;
+ bool Interpolate;
+ int64_t Length;
+ int64_t Height;
+ int64_t Width;
+ int64_t BPC;
+ int64_t StructParent;
+ int64_t SMaskInData;
+ pdf_obj *Mask;
+ pdf_obj *SMask;
+ pdf_obj *ColorSpace;
+ pdf_name *Intent;
+ pdf_obj *Alternates;
+ pdf_obj *Name; /* obsolete, do we still support? */
+ pdf_obj *Decode;
+ pdf_dict *OC; /* Optional Content */
+ /* Filter and DecodeParms handled by pdfi_filter() (can probably remove, but I like the info while debugging) */
+ bool is_JPXDecode;
+ pdf_obj *Filter;
+ pdf_obj *DecodeParms;
+
+ /* Convenience variables (save these here instead of passing around as params) */
+ pdf_dict *page_dict;
+ pdf_dict *stream_dict;
+ bool inline_image;
+ pdfi_jpx_info_t jpx_info;
+} pdfi_image_info_t;
+
+static void
+pdfi_free_image_info_components(pdfi_image_info_t *info)
+{
+ if (info->Mask)
+ pdfi_countdown(info->Mask);
+ if (info->SMask)
+ pdfi_countdown(info->SMask);
+ if (info->ColorSpace)
+ pdfi_countdown(info->ColorSpace);
+ if (info->Intent)
+ pdfi_countdown(info->Intent);
+ if (info->Alternates)
+ pdfi_countdown(info->Alternates);
+ if (info->Name)
+ pdfi_countdown(info->Name);
+ if (info->Decode)
+ pdfi_countdown(info->Decode);
+ if (info->OC)
+ pdfi_countdown(info->OC);
+ if (info->Filter)
+ pdfi_countdown(info->Filter);
+ if (info->DecodeParms)
+ pdfi_countdown(info->DecodeParms);
+ memset(info, 0, sizeof(*info));
+}
+
+
+static inline uint64_t
+pdfi_get_image_data_size(gs_data_image_t *pim, int comps)
+{
+ int size;
+ int64_t H, W, B;
+
+ H = pim->Height;
+ W = pim->Width;
+ B = pim->BitsPerComponent;
+
+ size = (((W * comps * B) + 7) / 8) * H;
+ return size;
+}
+
+static inline uint64_t
+pdfi_data_size_from_image_info(pdfi_image_info_t *info, int comps)
+{
+ int size;
+ int64_t H, W, B;
+
+ H = info->Height;
+ W = info->Width;
+ B = info->BPC;
+
+ size = (((W * comps * B) + 7) / 8) * H;
+ return size;
+}
+
+static inline uint64_t
+pdfi_get_image_line_size(gs_data_image_t *pim, int comps)
+{
+ int size;
+ int64_t W, B;
+
+ W = pim->Width;
+ B = pim->BitsPerComponent;
+
+ size = (((W * comps * B) + 7) / 8);
+ return size;
+}
+
+/* Find first dictionary in array that contains "/DefaultForPrinting true" */
+static pdf_stream *
+pdfi_find_alternate(pdf_context *ctx, pdf_obj *alt)
+{
+ pdf_array *array = NULL;
+ pdf_obj *item = NULL;
+ pdf_stream *alt_stream = NULL;
+ int i;
+ int code;
+ bool flag;
+
+ if (alt->type != PDF_ARRAY)
+ return NULL;
+
+ array = (pdf_array *)alt;
+ for (i=0; i<pdfi_array_size(array);i++) {
+ code = pdfi_array_get_type(ctx, array, (uint64_t)i, PDF_DICT, &item);
+ if (code != 0)
+ continue;
+ code = pdfi_dict_get_bool(ctx, (pdf_dict *)item, "DefaultForPrinting", &flag);
+ if (code != 0 || !flag) {
+ pdfi_countdown(item);
+ item = NULL;
+ continue;
+ }
+ code = pdfi_dict_get_type(ctx, (pdf_dict *)item, "Image", PDF_STREAM, (pdf_obj **)&alt_stream);
+ pdfi_countdown(item);
+ item = NULL;
+ if (code != 0)
+ continue;
+ return alt_stream;
+ }
+ return NULL;
+}
+
+#define READ32BE(i) (((i)[0] << 24) | ((i)[1] << 16) | ((i)[2] << 8) | (i)[3])
+#define READ16BE(i) (((i)[0] << 8) | (i)[1])
+#define K4(a, b, c, d) ((a << 24) + (b << 16) + (c << 8) + d)
+#define LEN_IHDR 14
+#define LEN_DATA 2048
+
+/* Returns either < 0, or exactly 8 */
+static int
+get_box(pdf_context *ctx, pdf_c_stream *source, int length, uint32_t *box_len, uint32_t *box_val)
+{
+ int code;
+ byte blob[4];
+
+ if (length < 8)
+ return_error(gs_error_limitcheck);
+ code = pdfi_read_bytes(ctx, blob, 1, 4, source);
+ if (code < 0)
+ return code;
+ *box_len = READ32BE(blob);
+ if (*box_len < 8)
+ return_error(gs_error_limitcheck);
+ code = pdfi_read_bytes(ctx, blob, 1, 4, source);
+ if (code < 0)
+ return code;
+ *box_val = READ32BE(blob);
+
+ if(ctx->args.pdfdebug)
+ dbgmprintf3(ctx->memory, "JPXFilter: BOX: l:%d, v:%x (%4.4s)\n", *box_len, *box_val, blob);
+ return 8;
+}
+
+/* Scan JPX image for header info */
+static int
+pdfi_scan_jpxfilter(pdf_context *ctx, pdf_c_stream *source, int length, pdfi_jpx_info_t *info)
+{
+ uint32_t box_len = 0;
+ uint32_t box_val = 0;
+ int code;
+ byte ihdr_data[LEN_IHDR];
+ byte *data = NULL;
+ int data_buf_len = 0;
+ int avail = length;
+ int bpc = 0;
+ int comps = 0;
+ int cs_meth = 0;
+ uint32_t cs_enum = 0;
+ bool got_color = false;
+
+ if (ctx->args.pdfdebug)
+ dbgmprintf1(ctx->memory, "JPXFilter: Image length %d\n", length);
+
+ /* Clear out the info param */
+ memset(info, 0, sizeof(pdfi_jpx_info_t));
+
+ info->no_data = false;
+
+ /* Allocate a data buffer that hopefully is big enough */
+ data_buf_len = LEN_DATA;
+ data = gs_alloc_bytes(ctx->memory, data_buf_len, "pdfi_scan_jpxfilter (data)");
+ if (!data) {
+ code = gs_note_error(gs_error_VMerror);
+ goto exit;
+ }
+
+ /* Find the 'jp2h' box, skipping over everything else */
+ while (avail > 0) {
+ code = get_box(ctx, source, avail, &box_len, &box_val);
+ if (code < 0)
+ goto exit;
+ avail -= 8;
+ box_len -= 8;
+ if (box_len <= 0 || box_len > avail) {
+ dmprintf1(ctx->memory, "WARNING: invalid JPX header, box_len=0x%x\n", box_len+8);
+ code = gs_note_error(gs_error_syntaxerror);
+ goto exit;
+ }
+ if (box_val == K4('j','p','2','h')) {
+ break;
+ }
+ pdfi_seek(ctx, source, box_len, SEEK_CUR);
+ avail -= box_len;
+ }
+ if (avail <= 0) {
+ info->no_data = true;
+ code = gs_note_error(gs_error_ioerror);
+ goto exit;
+ }
+
+ /* Now we are only looking inside the jp2h box */
+ avail = box_len;
+
+ /* The first thing in the 'jp2h' box is an 'ihdr', get that */
+ code = get_box(ctx, source, avail, &box_len, &box_val);
+ if (code < 0)
+ goto exit;
+ avail -= 8;
+ box_len -= 8;
+ if (box_val != K4('i','h','d','r')) {
+ code = gs_note_error(gs_error_syntaxerror);
+ goto exit;
+ }
+ if (box_len != LEN_IHDR) {
+ code = gs_note_error(gs_error_syntaxerror);
+ goto exit;
+ }
+
+ /* Get things we care about from ihdr */
+ code = pdfi_read_bytes(ctx, ihdr_data, 1, LEN_IHDR, source);
+ if (code < 0)
+ goto exit;
+ avail -= LEN_IHDR;
+ comps = READ16BE(ihdr_data+8);
+ if (ctx->args.pdfdebug)
+ dbgmprintf1(ctx->memory, " COMPS: %d\n", comps);
+ bpc = ihdr_data[10];
+ if (bpc != 255)
+ bpc += 1;
+ if (ctx->args.pdfdebug)
+ dbgmprintf1(ctx->memory, " BPC: %d\n", bpc);
+
+ /* Parse the rest of the things */
+ while (avail > 0) {
+ code = get_box(ctx, source, avail, &box_len, &box_val);
+ if (code < 0)
+ goto exit;
+ avail -= 8;
+ box_len -= 8;
+ if (box_len <= 0) {
+ code = gs_note_error(gs_error_syntaxerror);
+ goto exit;
+ }
+ /* Re-alloc buffer if it wasn't big enough (unlikely) */
+ if (box_len > data_buf_len) {
+ if (ctx->args.pdfdebug)
+ dbgmprintf2(ctx->memory, "data buffer (size %d) was too small, reallocing to size %d\n",
+ data_buf_len, box_len);
+ gs_free_object(ctx->memory, data, "pdfi_scan_jpxfilter (data)");
+ data_buf_len = box_len;
+ data = gs_alloc_bytes(ctx->memory, data_buf_len, "pdfi_scan_jpxfilter (data)");
+ if (!data) {
+ code = gs_note_error(gs_error_VMerror);
+ goto exit;
+ }
+ }
+ code = pdfi_read_bytes(ctx, data, 1, box_len, source);
+ if (code < 0)
+ goto exit;
+ avail -= box_len;
+ switch(box_val) {
+ case K4('b','p','c','c'):
+ {
+ int i;
+ int bpc2;
+
+ bpc2 = data[0];
+ for (i=1;i<comps;i++) {
+ if (bpc2 != data[i]) {
+ emprintf(ctx->memory,
+ "*** Error: JPX image colour channels do not all have the same colour depth\n");
+ emprintf(ctx->memory,
+ " Output may be incorrect.\n");
+ }
+ }
+ bpc = bpc2+1;
+ if (ctx->args.pdfdebug)
+ dbgmprintf1(ctx->memory, " BPCC: %d\n", bpc);
+ }
+ break;
+ case K4('c','o','l','r'):
+ if (got_color) {
+ if (ctx->args.pdfdebug)
+ dbgmprintf(ctx->memory, "JPXFilter: Ignore extra COLR specs\n");
+ break;
+ }
+ cs_meth = data[0];
+ if (cs_meth == 1)
+ cs_enum = READ32BE(data+3);
+ else if (cs_meth == 2 || cs_meth == 3) {
+ /* This is an ICCBased color space just sitting there in the buffer.
+ * TODO: I could create the colorspace now while I have the buffer,
+ * but code flow is more consistent if I do it later. Could change this.
+ *
+ * NOTE: cs_meth == 3 is apparently treated the same as 2.
+ * No idea why... it's really not documented anywhere.
+ */
+ info->iccbased = true;
+ info->icc_offset = pdfi_tell(source) - (box_len-3);
+ info->icc_length = box_len - 3;
+ if (ctx->args.pdfdebug)
+ dbgmprintf5(ctx->memory, "JPXDecode: COLR Meth %d at offset %d(0x%x), length %d(0x%x)\n",
+ cs_meth, info->icc_offset, info->icc_offset,
+ info->icc_length, info->icc_length);
+ cs_enum = 0;
+ } else {
+ if (ctx->args.pdfdebug)
+ dbgmprintf1(ctx->memory, "JPXDecode: COLR unexpected method %d\n", cs_meth);
+ cs_enum = 0;
+ }
+ if (ctx->args.pdfdebug)
+ dbgmprintf2(ctx->memory, " COLR: M:%d, ENUM:%d\n", cs_meth, cs_enum);
+ got_color = true;
+ break;
+ case K4('p','c','l','r'):
+ /* Apparently we just grab the BPC out of this */
+ if (ctx->args.pdfdebug)
+ dbgmprintf7(ctx->memory, " PCLR Data: %x %x %x %x %x %x %x\n",
+ data[0], data[1], data[2], data[3], data[4], data[5], data[6]);
+ bpc = data[3];
+ bpc = (bpc & 0x7) + 1;
+ if (ctx->args.pdfdebug)
+ dbgmprintf1(ctx->memory, " PCLR BPC: %d\n", bpc);
+ break;
+ case K4('c','d','e','f'):
+ dbgmprintf(ctx->memory, "JPXDecode: CDEF not supported yet\n");
+ break;
+ default:
+ break;
+ }
+
+ }
+
+ info->comps = comps;
+ info->bpc = bpc;
+ info->cs_enum = cs_enum;
+ info->is_valid = true;
+
+ exit:
+ if (data)
+ gs_free_object(ctx->memory, data, "pdfi_scan_jpxfilter (data)");
+ /* Always return 0 -- there are cases where this no image header at all, and just ignoring
+ * the header seems to work. In this case is_valid will be false, so we know not to rely on
+ * the data from it.
+ * Sample: tests_private/comparefiles/Bug694873.pdf
+ */
+ return 0;
+}
+
+/* Get image info out of dict into more convenient form, enforcing some requirements from the spec */
+static int
+pdfi_get_image_info(pdf_context *ctx, pdf_stream *image_obj,
+ pdf_dict *page_dict, pdf_dict *stream_dict, bool inline_image,
+ pdfi_image_info_t *info)
+{
+ int code;
+ double temp_f;
+ pdf_dict *image_dict = NULL;
+
+ memset(info, 0, sizeof(*info));
+ info->page_dict = page_dict;
+ info->stream_dict = stream_dict;
+ info->inline_image = inline_image;
+
+ /* Not Handled: "ID", "OPI" */
+
+ /* Length if it's in a stream dict */
+ info->Length = pdfi_stream_length(ctx, image_obj);
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)image_obj, &image_dict);
+ if (code < 0)
+ goto errorExit;
+
+ /* Required */
+ code = pdfi_dict_get_number2(ctx, image_dict, "Height", "H", &temp_f);
+ if (code < 0)
+ goto errorExit;
+ /* This is bonkers, but... Bug695872.pdf has /W and /H which are real numbers */
+ info->Height = (int)temp_f;
+ if ((int)temp_f != (int)(temp_f+.5)) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_IMAGEDICT, "pdfi_get_image_info", NULL);
+ if (ctx->args.pdfstoponwarning) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto errorExit;
+ }
+ }
+
+ /* Required */
+ code = pdfi_dict_get_number2(ctx, image_dict, "Width", "W", &temp_f);
+ if (code < 0)
+ goto errorExit;
+ info->Width = (int)temp_f;
+ if ((int)temp_f != (int)(temp_f+.5)) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_IMAGEDICT, "pdfi_get_image_info", NULL);
+ if (ctx->args.pdfstoponwarning) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto errorExit;
+ }
+ }
+
+ /* Optional, default false */
+ code = pdfi_dict_get_bool2(ctx, image_dict, "ImageMask", "IM", &info->ImageMask);
+ if (code != 0) {
+ if (code != gs_error_undefined)
+ goto errorExit;
+ info->ImageMask = false;
+ }
+
+ /* Optional, default false */
+ code = pdfi_dict_get_bool2(ctx, image_dict, "Interpolate", "I", &info->Interpolate);
+ if (code != 0) {
+ if (code != gs_error_undefined)
+ goto errorExit;
+ info->Interpolate = false;
+ }
+
+ /* Optional (Required, unless ImageMask is true)
+ * But apparently for JPXDecode filter, this can be omitted.
+ * Let's try a default of 1 for now...
+ */
+ code = pdfi_dict_get_int2(ctx, image_dict, "BitsPerComponent", "BPC", &info->BPC);
+ if (code < 0) {
+ if (code != gs_error_undefined) {
+ goto errorExit;
+ }
+ info->BPC = 1;
+ }
+ /* TODO: spec says if ImageMask is specified, and BPC is specified, then BPC must be 1
+ Should we flag an error if this is violated?
+ */
+
+ /* Optional (apparently there is no "M" abbreviation for "Mask"? */
+ code = pdfi_dict_get(ctx, image_dict, "Mask", &info->Mask);
+ if (code < 0) {
+ /* A lack of a Mask is not an error. If there is a genuine error reading
+ * the Mask, ignore it unless PDFSTOPONWARNING is set. We can still render
+ * the image. Arguably we should not, and Acrobat doesn't, but the current
+ * GS implementation does.
+ */
+ if (code != gs_error_undefined) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_IMAGEDICT, "pdfi_get_image_info", NULL);
+ if (ctx->args.pdfstoponwarning)
+ goto errorExit;
+ }
+ }
+
+ /* Optional (apparently there is no abbreviation for "SMask"? */
+ code = pdfi_dict_get(ctx, image_dict, "SMask", &info->SMask);
+ if (code < 0) {
+ if (code != gs_error_undefined) {
+ /* Broken SMask, Warn, and ignore the SMask */
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_IMAGEDICT, "pdfi_get_image_info", (char *)"*** Warning: Image has invalid SMask. Ignoring it");
+ if (ctx->args.pdfstoponwarning)
+ goto errorExit;
+ code = 0;
+ }
+ } else {
+ if (info->SMask->type == PDF_NAME) {
+ pdf_obj *o = NULL;
+
+ code = pdfi_find_resource(ctx, (unsigned char *)"ExtGState", (pdf_name *)info->SMask, image_dict, page_dict, &o);
+ if (code >= 0) {
+ pdfi_countdown(info->SMask);
+ info->SMask = o;
+ }
+ }
+
+ if (info->SMask->type != PDF_STREAM){
+ pdfi_countdown(info->SMask);
+ info->SMask = NULL;
+ }
+ }
+
+ /* Optional, for JPXDecode filter images
+ * (If non-zero, then SMask shouldn't be specified)
+ * Default: 0
+ */
+ code = pdfi_dict_get_int(ctx, image_dict, "SMaskInData", &info->SMaskInData);
+ if (code < 0) {
+ if (code != gs_error_undefined)
+ goto errorExit;
+ info->SMaskInData = 0;
+ }
+
+ /* Optional (Required except for ImageMask, not allowed for ImageMask)*/
+ /* TODO: Should we enforce this required/not allowed thing? */
+ code = pdfi_dict_get2(ctx, image_dict, "ColorSpace", "CS", &info->ColorSpace);
+ if (code < 0) {
+ if (code != gs_error_undefined)
+ goto errorExit;
+ }
+
+ /* Optional (default is to use from graphics state) */
+ /* (no abbreviation for inline) */
+ code = pdfi_dict_get_type(ctx, image_dict, "Intent", PDF_NAME, (pdf_obj **)&info->Intent);
+ if (code < 0) {
+ if (code != gs_error_undefined)
+ goto errorExit;
+ }
+
+ /* Optional (array of alternate image dicts, can't be nested) */
+ code = pdfi_dict_get(ctx, image_dict, "Alternates", &info->Alternates);
+ if (code < 0) {
+ if (code != gs_error_undefined)
+ goto errorExit;
+ }
+
+ /* Optional (required in PDF1.0, obsolete, do we support?) */
+ code = pdfi_dict_get(ctx, image_dict, "Name", &info->Name);
+ if (code < 0) {
+ if (code != gs_error_undefined)
+ goto errorExit;
+ }
+
+ /* Required "if image is structural content item" */
+ /* TODO: Figure out what to do here */
+ code = pdfi_dict_get_int(ctx, image_dict, "StructParent", &info->StructParent);
+ if (code < 0) {
+ if (code != gs_error_undefined)
+ goto errorExit;
+ }
+
+ /* Optional (default is probably [0,1] per component) */
+ code = pdfi_dict_get2(ctx, image_dict, "Decode", "D", &info->Decode);
+ if (code < 0) {
+ if (code != gs_error_undefined)
+ goto errorExit;
+ }
+
+ /* Optional "Optional Content" */
+ code = pdfi_dict_get_type(ctx, image_dict, "OC", PDF_DICT, (pdf_obj **)&info->OC);
+ if (code < 0) {
+ if (code != gs_error_undefined)
+ goto errorExit;
+ }
+
+ /* Optional */
+ code = pdfi_dict_get2(ctx, image_dict, "Filter", "F", &info->Filter);
+ if (code < 0) {
+ if (code != gs_error_undefined)
+ goto errorExit;
+ }
+
+ /* Check and set JPXDecode flag for later */
+ info->is_JPXDecode = false;
+ if (info->Filter && info->Filter->type == PDF_NAME) {
+ if (pdfi_name_is((pdf_name *)info->Filter, "JPXDecode"))
+ info->is_JPXDecode = true;
+ }
+
+ /* Optional */
+ code = pdfi_dict_get2(ctx, image_dict, "DecodeParms", "DP", &info->DecodeParms);
+ if (code < 0) {
+ if (code != gs_error_undefined)
+ goto errorExit;
+ }
+
+ return 0;
+
+ errorExit:
+ pdfi_free_image_info_components(info);
+ return code;
+}
+
+static int pdfi_check_inline_image_keys(pdf_context *ctx, pdf_dict *image_dict)
+{
+ bool known = false;
+
+ pdfi_dict_known(ctx, image_dict, "BPC", &known);
+ if (known)
+ goto error_inline_check;
+ pdfi_dict_known(ctx, image_dict, "CS", &known);
+ if (known)
+ goto error_inline_check;
+ pdfi_dict_known(ctx, image_dict, "D", &known);
+ if (known)
+ goto error_inline_check;
+ pdfi_dict_known(ctx, image_dict, "DP", &known);
+ if (known)
+ goto error_inline_check;
+ pdfi_dict_known(ctx, image_dict, "F", &known);
+ if (known)
+ goto error_inline_check;
+ pdfi_dict_known(ctx, image_dict, "H", &known);
+ if (known)
+ goto error_inline_check;
+ pdfi_dict_known(ctx, image_dict, "IM", &known);
+ if (known)
+ goto error_inline_check;
+ pdfi_dict_known(ctx, image_dict, "I", &known);
+ if (known)
+ goto error_inline_check;
+ pdfi_dict_known(ctx, image_dict, "W", &known);
+ if (known)
+ goto error_inline_check;
+
+ return 0;
+
+error_inline_check:
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_INLINEIMAGEKEY, "pdfi_check_inline_image_keys", NULL);
+ if (ctx->args.pdfstoponwarning)
+ return_error(gs_error_syntaxerror);
+ return 0;
+}
+
+/* Render a PDF image
+ * pim can be type1 (or imagemask), type3, type4
+ */
+static int
+pdfi_render_image(pdf_context *ctx, gs_pixel_image_t *pim, pdf_c_stream *image_stream,
+ unsigned char *mask_buffer, uint64_t mask_size,
+ int comps, bool ImageMask)
+{
+ int code;
+ gs_image_enum *penum = NULL;
+ byte *buffer = NULL;
+ uint64_t linelen, bytes_left;
+ uint64_t bytes_used = 0;
+ uint64_t bytes_avail = 0;
+ gs_const_string plane_data[GS_IMAGE_MAX_COMPONENTS];
+ int main_plane=0, mask_plane=0;
+ bool no_progress = false;
+
+#if DEBUG_IMAGES
+ dbgmprintf(ctx->memory, "pdfi_render_image BEGIN\n");
+#endif
+
+ code = pdfi_gsave(ctx);
+ if (code < 0)
+ return code;
+
+ /* Disable overprint mode for images */
+ gs_setoverprintmode(ctx->pgs, 0);
+
+ penum = gs_image_enum_alloc(ctx->memory, "pdfi_render_image (gs_image_enum_alloc)");
+ if (!penum) {
+ code = gs_note_error(gs_error_VMerror);
+ goto cleanupExit;
+ }
+
+ /* Took this logic from gs_image_init()
+ * (the other tests in there have already been handled elsewhere)
+ */
+ {
+ gx_image_enum_common_t *pie;
+
+ if (!ImageMask) {
+ /* TODO: Can in_cachedevice ever be set in PDF? */
+ if (ctx->pgs->in_cachedevice != CACHE_DEVICE_NONE) {
+ code = gs_note_error(gs_error_undefined);
+ goto cleanupExit;
+ }
+ }
+
+ code = gs_image_begin_typed((const gs_image_common_t *)pim, ctx->pgs, ImageMask, false, &pie);
+ if (code < 0)
+ goto cleanupExit;
+
+ code = gs_image_enum_init(penum, pie, (const gs_data_image_t *)pim, ctx->pgs);
+ if (code < 0)
+ goto cleanupExit;
+ }
+
+ /* NOTE: I used image_file_continue() as my template for this code.
+ * But this case is (hopefully) much much simpler.
+ * We only handle two situations -- if there is mask_data, then we assume there are two planes.
+ * If no mask_data, then there is one plane.
+ */
+ if (mask_buffer) {
+ main_plane = 1;
+ mask_plane = 0;
+ plane_data[mask_plane].data = mask_buffer;
+ plane_data[mask_plane].size = mask_size;
+ } else {
+ main_plane = 0;
+ }
+
+ /* Going to feed the data one line at a time.
+ * This isn't required by gs_image_next_planes(), but it might make things simpler.
+ */
+ linelen = pdfi_get_image_line_size((gs_data_image_t *)pim, comps);
+ bytes_left = pdfi_get_image_data_size((gs_data_image_t *)pim, comps);
+ buffer = gs_alloc_bytes(ctx->memory, linelen, "pdfi_render_image (buffer)");
+ if (!buffer) {
+ code = gs_note_error(gs_error_VMerror);
+ goto cleanupExit;
+ }
+ while (bytes_left > 0) {
+ uint used[GS_IMAGE_MAX_COMPONENTS];
+
+ if (bytes_avail == 0) {
+ code = pdfi_read_bytes(ctx, buffer, 1, linelen, image_stream);
+ if (code < 0) {
+ dmprintf3(ctx->memory,
+ "WARNING: Image data error (pdfi_read_bytes) bytes_left=%ld, linelen=%ld, code=%d\n",
+ bytes_left, linelen, code);
+ goto cleanupExit;
+ }
+ if (code != linelen) {
+ dmprintf3(ctx->memory, "WARNING: Image data mismatch, bytes_left=%ld, linelen=%ld, code=%d\n",
+ bytes_left, linelen, code);
+ code = gs_note_error(gs_error_limitcheck);
+ goto cleanupExit;
+ }
+ }
+
+ plane_data[main_plane].data = buffer + bytes_used;
+ plane_data[main_plane].size = linelen - bytes_used;
+
+ code = gs_image_next_planes(penum, plane_data, used);
+ if (code < 0) {
+ goto cleanupExit;
+ }
+ /* If no data was consumed twice in a row, then there must be some kind of error,
+ * even if the error code was not < 0. Saw this with pdfwrite device.
+ */
+ if (used[main_plane] == 0 && used[mask_plane] == 0) {
+ if (no_progress) {
+ code = gs_note_error(gs_error_unknownerror);
+ goto cleanupExit;
+ }
+ no_progress = true;
+ } else {
+ no_progress = false;
+ }
+
+ /* It might not always consume all the data, but so far the only case
+ * I have seen with that was one that had mask data.
+ * In that case, it used all of plane 0, and none of plane 1 on the first pass.
+ * (image_2bpp.pdf)
+ *
+ * Anyway, this math should handle that case (as well as a case where it consumed only
+ * part of the data, if that can actually happen).
+ */
+ bytes_used = used[main_plane];
+ bytes_left -= bytes_used;
+ bytes_avail = linelen - bytes_used;
+ }
+
+ code = 0;
+
+ cleanupExit:
+ if (buffer)
+ gs_free_object(ctx->memory, buffer, "pdfi_render_image (buffer)");
+ if (penum)
+ gs_image_cleanup_and_free_enum(penum, ctx->pgs);
+ pdfi_grestore(ctx);
+#if DEBUG_IMAGES
+ dbgmprintf(ctx->memory, "pdfi_render_image END\n");
+#endif
+ return code;
+}
+
+/* Load up params common to the different image types */
+static int
+pdfi_data_image_params(pdf_context *ctx, pdfi_image_info_t *info,
+ gs_data_image_t *pim, int comps, gs_color_space *pcs)
+{
+ int code;
+
+ pim->BitsPerComponent = info->BPC;
+ pim->Width = info->Width;
+ pim->Height = info->Height;
+ pim->ImageMatrix.xx = (float)info->Width;
+ pim->ImageMatrix.yy = (float)(info->Height * -1);
+ pim->ImageMatrix.ty = (float)info->Height;
+
+ pim->Interpolate = info->Interpolate;
+
+ /* Get the decode array (required for ImageMask, probably for everything) */
+ if (info->Decode) {
+ pdf_array *decode_array = (pdf_array *)info->Decode;
+ int i;
+ double num;
+
+ if (pdfi_array_size(decode_array) > GS_IMAGE_MAX_COMPONENTS * 2) {
+ code = gs_note_error(gs_error_limitcheck);
+ goto cleanupExit;
+ }
+
+ for (i=0; i<pdfi_array_size(decode_array); i++) {
+ code = pdfi_array_get_number(ctx, decode_array, i, &num);
+ if (code < 0)
+ goto cleanupExit;
+ pim->Decode[i] = (float)num;
+ }
+ } else {
+ /* Provide a default if not specified [0 1 ...] per component */
+ int i;
+ float minval, maxval;
+
+ /* TODO: Is there a less hacky way to identify Indexed case? */
+ if (pcs && pcs->type == &gs_color_space_type_Indexed) {
+ /* Default value is [0,N], where N=2^n-1, our hival (which depends on BPC)*/
+ minval = 0.0;
+ maxval = (float)((1 << info->BPC) - 1);
+ } else {
+ bool islab = false;
+
+ if (pcs && pcs->cmm_icc_profile_data != NULL)
+ islab = pcs->cmm_icc_profile_data->islab;
+
+ if(islab) {
+ pim->Decode[0] = 0.0;
+ pim->Decode[1] = 100.0;
+ pim->Decode[2] = pcs->cmm_icc_profile_data->Range.ranges[1].rmin;
+ pim->Decode[3] = pcs->cmm_icc_profile_data->Range.ranges[1].rmax;
+ pim->Decode[4] = pcs->cmm_icc_profile_data->Range.ranges[2].rmin;
+ pim->Decode[5] = pcs->cmm_icc_profile_data->Range.ranges[2].rmax;
+ return 0;
+ } else {
+ minval = 0.0;
+ maxval = 1.0;
+ }
+ }
+ for (i=0; i<comps*2; i+=2) {
+ pim->Decode[i] = minval;
+ pim->Decode[i+1] = maxval;
+ }
+ }
+ code = 0;
+
+ cleanupExit:
+ return code;
+}
+
+/* Returns number of components in Matte array or 0 if not found, <0 if error */
+static int
+pdfi_image_get_matte(pdf_context *ctx, pdf_obj *smask_obj, float *vals, int size, bool *has_Matte)
+{
+ int i;
+ pdf_array *Matte = NULL;
+ int code;
+ double f;
+ pdf_dict *smask_dict = NULL;
+
+ *has_Matte = false;
+ code = pdfi_dict_from_obj(ctx, smask_obj, &smask_dict);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_dict_knownget_type(ctx, smask_dict, "Matte",
+ PDF_ARRAY, (pdf_obj **)&Matte);
+ if (code <= 0)
+ goto exit;
+
+ *has_Matte = true;
+ if (pdfi_array_size(Matte) > size) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+
+ for (i = 0; i < pdfi_array_size(Matte); i++) {
+ code = pdfi_array_get_number(ctx, Matte, (uint64_t)i, &f);
+ if (code < 0)
+ goto exit;
+ vals[i] = (float)f;
+ }
+ if (i == pdfi_array_size(Matte))
+ code = i;
+
+ exit:
+ pdfi_countdown(Matte);
+ return code;
+}
+
+/* See ztrans.c/zbegintransparencymaskimage() and pdf_draw.ps/doimagesmask */
+static int
+pdfi_do_image_smask(pdf_context *ctx, pdf_c_stream *source, pdfi_image_info_t *image_info, bool *has_Matte)
+{
+ gs_rect bbox = { { 0, 0} , { 1, 1} };
+ gs_transparency_mask_params_t params;
+ gs_offset_t savedoffset = 0;
+ int code, code1;
+ pdfi_int_gstate *igs = (pdfi_int_gstate *)ctx->pgs->client_data;
+ pdf_stream *stream_obj = NULL;
+
+#if DEBUG_IMAGES
+ dbgmprintf(ctx->memory, "pdfi_do_image_smask BEGIN\n");
+#endif
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ return code;
+
+ if (image_info->SMask->object_num != 0) {
+ if (pdfi_loop_detector_check_object(ctx, image_info->SMask->object_num))
+ return gs_note_error(gs_error_circular_reference);
+ code = pdfi_loop_detector_add_object(ctx, image_info->SMask->object_num);
+ if (code < 0)
+ goto exit;
+ }
+
+ gs_trans_mask_params_init(&params, TRANSPARENCY_MASK_Luminosity);
+
+ code = pdfi_image_get_matte(ctx, image_info->SMask, params.Matte, GS_CLIENT_COLOR_MAX_COMPONENTS, has_Matte);
+
+ if (code >= 0)
+ params.Matte_components = code;
+
+ code = gs_begin_transparency_mask(ctx->pgs, &params, &bbox, true);
+ if (code < 0)
+ goto exit;
+ savedoffset = pdfi_tell(ctx->main_stream);
+ code = pdfi_gsave(ctx);
+
+ /* Disable SMask for inner image */
+ pdfi_gstate_smask_free(igs);
+
+ gs_setstrokeconstantalpha(ctx->pgs, 1.0);
+ gs_setfillconstantalpha(ctx->pgs, 1.0);
+ gs_setblendmode(ctx->pgs, BLEND_MODE_Compatible);
+
+ pdfi_seek(ctx, ctx->main_stream,
+ pdfi_stream_offset(ctx, (pdf_stream *)image_info->SMask), SEEK_SET);
+
+ if (image_info->SMask->type == PDF_DICT) {
+ code = pdfi_obj_dict_to_stream(ctx, (pdf_dict *)image_info->SMask, &stream_obj, false);
+ if (code == 0) {
+ code = pdfi_do_image_or_form(ctx, image_info->stream_dict,
+ image_info->page_dict, (pdf_obj *)stream_obj);
+
+ pdfi_countdown(stream_obj);
+ }
+ } else {
+ if (image_info->SMask->type == PDF_STREAM)
+ code = pdfi_do_image_or_form(ctx, image_info->stream_dict,
+ image_info->page_dict, image_info->SMask);
+ else {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+ }
+
+ pdfi_seek(ctx, ctx->main_stream, savedoffset, SEEK_SET);
+
+ code1 = pdfi_grestore(ctx);
+ if (code < 0)
+ code = code1;
+ code1 = gs_end_transparency_mask(ctx->pgs, TRANSPARENCY_CHANNEL_Opacity);
+ if (code < 0)
+ code = code1;
+
+ exit:
+#if DEBUG_IMAGES
+ dbgmprintf(ctx->memory, "pdfi_do_image_smask END\n");
+#endif
+ pdfi_loop_detector_cleartomark(ctx);
+ return code;
+}
+
+
+/* Setup for transparency (see pdf_draw.ps/doimage) */
+static int
+pdfi_image_setup_trans(pdf_context *ctx, pdfi_trans_state_t *state)
+{
+ int code;
+ gs_rect bbox;
+
+ /* We need to create a bbox in order to pass it to the transparency setup,
+ * which (potentially, at least, uses it to set up a transparency group.
+ * Setting up a 1x1 path, and establishing it's BBox will work, because
+ * the image scaling is already in place. We don't want to disturb the
+ * graphics state, so do this inside a gsave/grestore pair.
+ */
+ code = pdfi_gsave(ctx);
+ if (code < 0)
+ return code;
+
+ code = gs_newpath(ctx->pgs);
+ if (code < 0)
+ goto exit;
+ code = gs_moveto(ctx->pgs, 1.0, 1.0);
+ if (code < 0)
+ goto exit;
+ code = gs_lineto(ctx->pgs, 0., 0.);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_get_current_bbox(ctx, &bbox, false);
+ if (code < 0)
+ goto exit;
+
+ pdfi_grestore(ctx);
+
+ code = pdfi_trans_setup(ctx, state, &bbox, TRANSPARENCY_Caller_Image);
+ exit:
+ return code;
+}
+
+
+/* Setup a type 4 image, particularly the MaskColor array.
+ * Handles error situations like pdf_draw.ps/makemaskimage
+ */
+static int
+pdfi_image_setup_type4(pdf_context *ctx, pdfi_image_info_t *image_info,
+ gs_image4_t *t4image,
+ pdf_array *mask_array, gs_color_space *pcs)
+{
+ int i;
+ double num;
+ int code = 0;
+ int bpc = image_info->BPC;
+ uint mask = (1 << bpc) - 1;
+ uint maxval = mask;
+ int64_t intval;
+ bool had_range_error = false;
+ bool had_float_error = false;
+ /* Check for special case of Indexed and BPC=1 (to match AR)
+ * See bugs: 692852, 697919, 689717
+ */
+ bool indexed_case = (pcs && pcs->type == &gs_color_space_type_Indexed && bpc == 1);
+
+ memset(t4image, 0, sizeof(gs_image4_t));
+ gs_image4_t_init(t4image, NULL);
+
+ if (pdfi_array_size(mask_array) > GS_IMAGE_MAX_COMPONENTS * 2) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+
+ for (i=0; i<pdfi_array_size(mask_array); i++) {
+ code = pdfi_array_get_int(ctx, mask_array, i, &intval);
+ if (code == gs_error_typecheck) {
+ code = pdfi_array_get_number(ctx, mask_array, i, &num);
+ if (code == 0) {
+ intval = (int64_t)(num + 0.5);
+ had_float_error = true;
+ }
+ }
+ if (code < 0)
+ goto exit;
+ if (intval > maxval) {
+ had_range_error = true;
+ if (indexed_case) {
+ if (i == 0) {
+ /* If first component is invalid, AR9 ignores the mask. */
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ } else {
+ /* If second component is invalid, AR9 replace it with 1. */
+ intval = 1;
+ }
+ } else {
+ if (bpc != 1) {
+ /* If not special handling, just mask it off to be in range */
+ intval &= mask;
+ }
+ }
+ }
+ t4image->MaskColor[i] = intval;
+ }
+ t4image->MaskColor_is_range = true;
+
+ /* Another special handling (see Bug701468)
+ * If 1 BPC and the two entries are not the same, ignore the mask
+ */
+ if (!indexed_case && bpc == 1 && had_range_error) {
+ if (t4image->MaskColor[0] != t4image->MaskColor[1]) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ } else {
+ t4image->MaskColor[0] &= mask;
+ t4image->MaskColor[1] &= mask;
+ }
+ }
+
+ code = 0;
+
+ exit:
+ if (had_float_error) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_IMAGE_ERROR, "pdfi_image_setup_type4", (char *)"*** Error: Some elements of Mask array are not integers");
+ }
+ if (had_range_error) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_IMAGE_ERROR, "pdfi_image_setup_type4", (char *)"*** Error: Some elements of Mask array are out of range");
+ }
+ return code;
+}
+
+/* Setup a type 3x image
+ */
+static int
+pdfi_image_setup_type3x(pdf_context *ctx, pdfi_image_info_t *image_info,
+ gs_image3x_t *t3ximage, pdfi_image_info_t *smask_info, int comps)
+{
+ int code = 0;
+ gs_image3x_mask_t *mask;
+
+ memset(t3ximage, 0, sizeof(*t3ximage));
+ gs_image3x_t_init(t3ximage, NULL);
+ if (gs_getalphaisshape(ctx->pgs))
+ mask = &t3ximage->Shape;
+ else
+ mask = &t3ximage->Opacity;
+ mask->InterleaveType = 3;
+
+ code = pdfi_image_get_matte(ctx, image_info->SMask, mask->Matte, GS_CLIENT_COLOR_MAX_COMPONENTS, &mask->has_Matte);
+ if (code < 0)
+ return code;
+
+ code = pdfi_data_image_params(ctx, smask_info, &mask->MaskDict, comps, NULL);
+ return code;
+}
+
+static int pdfi_create_JPX_Lab(pdf_context *ctx, pdf_obj **ColorSpace)
+{
+ int code, i;
+ pdf_name *SpaceName = NULL, *WhitePointName = NULL;
+ pdf_dict *Params = NULL;
+ pdf_array *WhitePoint = NULL;
+ double WP[3] = {0.9505, 1.0, 1.0890};
+ pdf_num *num = NULL;
+
+ *ColorSpace = NULL;
+ code = pdfi_name_alloc(ctx, (byte *)"Lab", 3, (pdf_obj **)&SpaceName);
+ if (code < 0)
+ goto cleanupExit;
+ pdfi_countup(SpaceName);
+
+ code = pdfi_dict_alloc(ctx, 1, &Params);
+ if (code < 0)
+ goto cleanupExit;
+ pdfi_countup(Params);
+
+ code = pdfi_name_alloc(ctx, (byte *)"WhitePoint", 3, (pdf_obj **)&WhitePointName);
+ if (code < 0)
+ goto cleanupExit;
+ pdfi_countup(WhitePointName);
+
+ code = pdfi_array_alloc(ctx, 3, &WhitePoint);
+ if (code < 0)
+ goto cleanupExit;
+
+ for (i = 0; i < 3; i++) {
+ code = pdfi_object_alloc(ctx, PDF_REAL, 0, (pdf_obj **)&num);
+ if (code < 0)
+ goto cleanupExit;
+ num->value.d = WP[i];
+ pdfi_countup(num);
+ code = pdfi_array_put(ctx, WhitePoint, i, (pdf_obj *)num);
+ if (code < 0)
+ goto cleanupExit;
+ pdfi_countdown(num);
+ }
+ num = NULL;
+
+ code = pdfi_dict_put_obj(ctx, Params, (pdf_obj *)WhitePointName, (pdf_obj *)WhitePoint);
+ if (code < 0)
+ goto cleanupExit;
+
+ pdfi_countdown(WhitePointName);
+ WhitePointName = NULL;
+ pdfi_countdown(WhitePoint);
+ WhitePoint = NULL;
+
+ code = pdfi_array_alloc(ctx, 2, (pdf_array **)ColorSpace);
+ if (code < 0)
+ goto cleanupExit;
+
+ code = pdfi_array_put(ctx, (pdf_array *)ColorSpace, 0, (pdf_obj *)SpaceName);
+ if (code < 0)
+ goto cleanupExit;
+ pdfi_countdown(SpaceName);
+ SpaceName = NULL;
+
+ code = pdfi_array_put(ctx, (pdf_array *)ColorSpace, 1, (pdf_obj *)Params);
+ if (code < 0)
+ goto cleanupExit;
+ pdfi_countdown(Params);
+
+ return 0;
+
+cleanupExit:
+ pdfi_countdown(*ColorSpace);
+ pdfi_countdown(SpaceName);
+ pdfi_countdown(Params);
+ pdfi_countdown(WhitePointName);
+ pdfi_countdown(WhitePoint);
+ pdfi_countdown(num);
+ return code;
+}
+
+static int
+pdfi_image_get_color(pdf_context *ctx, pdf_c_stream *source, pdfi_image_info_t *image_info,
+ int *comps, gs_color_space **pcs)
+{
+ int code = 0;
+ pdfi_jpx_info_t *jpx_info = &image_info->jpx_info;
+ pdf_obj *ColorSpace = NULL;
+ char *backup_color_name = NULL;
+ bool using_enum_cs = false;
+
+ /* NOTE: Spec says ImageMask and ColorSpace mutually exclusive */
+ if (image_info->ImageMask) {
+ *comps = 1;
+ *pcs = NULL;
+ return 0;
+ }
+
+ ColorSpace = image_info->ColorSpace;
+ if (ColorSpace)
+ pdfi_countup(ColorSpace);
+ if (ColorSpace == NULL) {
+ if (image_info->is_JPXDecode) {
+ /* The graphics library doesn't support 12-bit images, so the openjpeg layer
+ * (see sjpx_openjpeg.c/decode_image()) is going to translate the 12-bits up to 16-bits.
+ * That means we just treat it as 16-bit when rendering, so force the value
+ * to 16 here.
+ */
+ if (jpx_info->bpc == 12) {
+ jpx_info->bpc = 16;
+ }
+ image_info->BPC = jpx_info->bpc;
+
+ if (jpx_info->iccbased) {
+ int dummy; /* Holds number of components read from the ICC profile, we ignore this here */
+
+ code = pdfi_create_icc_colorspace_from_stream(ctx, source, jpx_info->icc_offset,
+ jpx_info->icc_length, jpx_info->comps, &dummy,
+ pcs);
+ if (code < 0) {
+ dmprintf2(ctx->memory,
+ "WARNING JPXDecode: Error setting icc colorspace (offset=%d,len=%d)\n",
+ jpx_info->icc_offset, jpx_info->icc_length);
+ goto cleanupExit;
+ }
+ *comps = gs_color_space_num_components(*pcs);
+ goto cleanupExit;
+ } else {
+ char *color_str = NULL;
+
+ /* TODO: These colorspace names are pulled from the gs code (jp2_csp_dict), but need
+ * to be implemented to actually work.
+ */
+ backup_color_name = (char *)"DeviceRGB";
+ switch(jpx_info->cs_enum) {
+ case 12:
+ color_str = (char *)"DeviceCMYK";
+ break;
+ case 14:
+ /* All the other colour spaces are set by name, either a device name or a
+ * 'special' internal name (same as Ghostscript) which is picked up in
+ * pdfi_create_colorspace_by_name() in pdf_colour.c. These names must
+ * match!
+ * However for Lab we need to set a White Point and its simplest just
+ * to create an appropriate color space array here.
+ */
+ code = pdfi_create_JPX_Lab(ctx, &ColorSpace);
+ if (code < 0)
+ goto cleanupExit;
+ break;
+ case 16:
+ color_str = (char *)"sRGBICC";
+ break;
+ case 17:
+ color_str = (char *)"sGrayICC";
+ backup_color_name = (char *)"DeviceGray";
+ break;
+ case 18:
+ color_str = (char *)"DeviceRGB";
+ break;
+ case 20:
+ case 24:
+ color_str = (char *)"esRGBICC";
+ break;
+ case 21:
+ color_str = (char *)"rommRGBICC";
+ break;
+ default:
+ {
+ char extra_info[gp_file_name_sizeof];
+ /* TODO: Could try DeviceRGB instead of erroring out? */
+ gs_sprintf(extra_info, "**** Error: JPXDecode: Unsupported EnumCS %d\n", jpx_info->cs_enum);
+ pdfi_set_error(ctx, 0, NULL, E_PDF_IMAGECOLOR_ERROR, "pdfi_image_get_color", extra_info);
+ goto cleanupExit;
+ }
+ }
+
+ /* Make a ColorSpace for the name */
+ if (color_str != NULL) {
+ code = pdfi_name_alloc(ctx, (byte *)color_str, strlen(color_str), &ColorSpace);
+ if (code < 0)
+ goto cleanupExit;
+ pdfi_countup(ColorSpace);
+ using_enum_cs = true;
+ }
+ }
+ } else {
+ /* Assume DeviceRGB colorspace */
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_IMAGEDICT, "pdfi_image_get_color", (char *)"**** Error: image has no /ColorSpace key; assuming /DeviceRGB");
+ code = pdfi_name_alloc(ctx, (byte *)"DeviceRGB", strlen("DeviceRGB"), &ColorSpace);
+ if (code < 0)
+ goto cleanupExit;
+ pdfi_countup(ColorSpace);
+ }
+ } else {
+ /* Override BPC from JPXDecode if applicable
+ * Sample: tests_private/comparefiles/Bug695387.pdf
+ */
+ if (image_info->is_JPXDecode && jpx_info->is_valid)
+ image_info->BPC = jpx_info->bpc;
+ }
+
+ /* At this point ColorSpace is either a string we just made, or the one from the Image */
+ code = pdfi_create_colorspace(ctx, ColorSpace,
+ image_info->stream_dict, image_info->page_dict,
+ pcs, image_info->inline_image);
+ if (code < 0) {
+ dmprintf(ctx->memory, "WARNING: Image has unsupported ColorSpace ");
+ if (ColorSpace->type == PDF_NAME) {
+ pdf_name *name = (pdf_name *)ColorSpace;
+ char str[100];
+ memcpy(str, (const char *)name->data, name->length);
+ str[name->length] = '\0';
+ dmprintf1(ctx->memory, "NAME:%s\n", str);
+ } else {
+ dmprintf(ctx->memory, "(not a name)\n");
+ }
+
+ /* If we were trying an enum_cs, attempt to use backup_color_name instead */
+ if (using_enum_cs) {
+ pdfi_countdown(ColorSpace);
+ code = pdfi_name_alloc(ctx, (byte *)backup_color_name, strlen(backup_color_name), &ColorSpace);
+ if (code < 0)
+ goto cleanupExit;
+ pdfi_countup(ColorSpace);
+ /* Try to set the backup name */
+ code = pdfi_create_colorspace(ctx, ColorSpace,
+ image_info->stream_dict, image_info->page_dict,
+ pcs, image_info->inline_image);
+
+ if (code < 0) {
+ pdfi_set_error(ctx, 0, NULL, E_PDF_IMAGECOLOR_ERROR, "pdfi_image_get_color", NULL);
+ goto cleanupExit;
+ }
+ } else {
+ pdfi_set_error(ctx, 0, NULL, E_PDF_IMAGECOLOR_ERROR, "pdfi_image_get_color", NULL);
+ goto cleanupExit;
+ }
+ }
+ *comps = gs_color_space_num_components(*pcs);
+
+ cleanupExit:
+ pdfi_countdown(ColorSpace);
+ return code;
+}
+
+/* Make a fake SMask dict from a JPX SMaskInData */
+static int
+pdfi_make_smask_dict(pdf_context *ctx, pdf_stream *image_stream, pdfi_image_info_t *image_info,
+ int comps)
+{
+ int code = 0;
+ pdf_dict *smask_dict = NULL;
+ pdf_stream *fake_smask = NULL;
+ pdf_array *array = NULL;
+ pdf_array *matte = NULL;
+ pdf_dict *image_dict = NULL, *dict = NULL; /* alias */
+
+ if (image_info->SMask != NULL) {
+ dmprintf(ctx->memory, "ERROR SMaskInData when there is already an SMask?\n");
+ goto exit;
+ }
+
+ if (image_stream->type != PDF_STREAM) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)image_stream, &image_dict);
+ if (code < 0) goto exit;
+
+ /* Make a new stream object and a dict for it */
+ code = pdfi_object_alloc(ctx, PDF_STREAM, 0, (pdf_obj **)&fake_smask);
+ if (code < 0) goto exit;
+ pdfi_countup(fake_smask);
+
+ code = pdfi_dict_alloc(ctx, 32, &smask_dict);
+ if (code < 0) goto exit;
+
+ fake_smask->stream_dict = smask_dict;
+ pdfi_countup(smask_dict);
+ smask_dict = NULL;
+ dict = fake_smask->stream_dict; /* alias */
+
+ /* Copy everything from the image_dict */
+ code = pdfi_dict_copy(ctx, dict, image_dict);
+ fake_smask->stream_offset = image_stream->stream_offset;
+
+ code = pdfi_dict_put_int(ctx, dict, "SMaskInData", 0);
+ if (code < 0) goto exit;
+
+ code = pdfi_dict_put_name(ctx, dict, "ColorSpace", "DeviceGray");
+ if (code < 0) goto exit;
+
+ /* BPC needs to come from the jpxinfo */
+ code = pdfi_dict_put_int(ctx, dict, "BitsPerComponent", image_info->jpx_info.bpc);
+ if (code < 0) goto exit;
+
+ /* "Alpha" is a non-standard thing that gs code uses to tell
+ * the jpxfilter that it is doing an SMask. I guess we can do
+ * the same, since we're making this dictionary anyway.
+ */
+ code = pdfi_dict_put_bool(ctx, dict, "Alpha", true);
+ if (code < 0) goto exit;
+
+ /* Make an array [0,1] */
+ code = pdfi_array_alloc(ctx, 2, &array);
+ if (code < 0) goto exit;
+ pdfi_countup(array);
+ code = pdfi_array_put_int(ctx, array, 0, 0);
+ if (code < 0) goto exit;
+ code = pdfi_array_put_int(ctx, array, 1, 1);
+ if (code < 0) goto exit;
+ code = pdfi_dict_put(ctx, dict, "Decode", (pdf_obj *)array);
+ if (code < 0) goto exit;
+
+ /* Make Matte array if needed */
+ /* This just makes an array [0,0,0...] of size 'comps'
+ * See pdf_draw.ps/makeimagekeys
+ * TODO: The only sample in our test suite that triggers this path is fts_17_1718.pdf
+ * and this code being there or not makes no difference on that sample, so.. ???
+ */
+ if (image_info->SMaskInData == 2) {
+ int i;
+ code = pdfi_array_alloc(ctx, comps, &matte);
+ if (code < 0) goto exit;
+ pdfi_countup(matte);
+ for (i=0; i<comps; i++) {
+ code = pdfi_array_put_int(ctx, matte, i, 0);
+ if (code < 0) goto exit;
+ }
+ code = pdfi_dict_put(ctx, dict, "Matte", (pdf_obj *)matte);
+ if (code < 0) goto exit;
+ }
+
+ image_info->SMask = (pdf_obj *)fake_smask;
+
+ exit:
+ if (code < 0) {
+ pdfi_countdown(fake_smask);
+ pdfi_countdown(smask_dict);
+ }
+ pdfi_countdown(array);
+ pdfi_countdown(matte);
+ return code;
+}
+
+/* NOTE: "source" is the current input stream.
+ * on exit:
+ * inline_image = TRUE, stream it will point to after the image data.
+ * inline_image = FALSE, stream position undefined.
+ */
+static int
+pdfi_do_image(pdf_context *ctx, pdf_dict *page_dict, pdf_dict *stream_dict, pdf_stream *image_stream,
+ pdf_c_stream *source, bool inline_image)
+{
+ pdf_c_stream *new_stream = NULL;
+ int code = 0, code1 = 0;
+ int comps = 0;
+ gs_color_space *pcs = NULL;
+ gs_image1_t t1image;
+ gs_image4_t t4image;
+ gs_image3_t t3image;
+ gs_image3x_t t3ximage;
+ gs_pixel_image_t *pim = NULL;
+ pdf_stream *alt_stream = NULL;
+ pdfi_image_info_t image_info, mask_info, smask_info;
+ pdf_stream *mask_stream = NULL;
+ pdf_stream *smask_stream = NULL; /* only non-null for imagetype 3x (PreserveSMask) */
+ pdf_array *mask_array = NULL;
+ unsigned char *mask_buffer = NULL;
+ uint64_t mask_size = 0;
+ pdfi_int_gstate *igs = (pdfi_int_gstate *)ctx->pgs->client_data;
+ bool transparency_group = false;
+ bool need_smask_cleanup = false;
+ bool maybe_jpxdecode = false;
+ pdfi_trans_state_t trans_state;
+ int saved_intent;
+ gs_offset_t stream_offset;
+ float save_strokeconstantalpha = 0.0f, save_fillconstantalpha = 0.0f;
+
+#if DEBUG_IMAGES
+ dbgmprintf(ctx->memory, "pdfi_do_image BEGIN\n");
+#endif
+ memset(&mask_info, 0, sizeof(mask_info));
+ memset(&smask_info, 0, sizeof(mask_info));
+
+ /* Make sure the image is a stream (which we will assume in later code) */
+ if (image_stream->type != PDF_STREAM)
+ return_error(gs_error_typecheck);
+
+ if (!inline_image) {
+ pdf_dict *image_dict = NULL;
+
+ /* If we are not processing an inline image, check to see if any of the abbreviated
+ * keys are present in the image dictionary. If they are, and we need to abort, we'll
+ * get an error return, otherwise we can continue.
+ */
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)image_stream, &image_dict);
+ if (code < 0)
+ return code;
+
+ code = pdfi_check_inline_image_keys(ctx, image_dict);
+ if (code < 0)
+ return code;
+ }
+
+ /* Save current rendering intent so we can put it back if it is modified */
+ saved_intent = gs_currentrenderingintent(ctx->pgs);
+
+ code = pdfi_get_image_info(ctx, image_stream, page_dict, stream_dict, inline_image, &image_info);
+ if (code < 0)
+ goto cleanupExit;
+
+ /* Don't render this if turned off */
+ if (pdfi_oc_is_off(ctx))
+ goto cleanupExit;
+ /* If there is an OC dictionary, see if we even need to render this */
+ if (image_info.OC) {
+ if (!pdfi_oc_is_ocg_visible(ctx, image_info.OC))
+ goto cleanupExit;
+ }
+
+ /* If there is an alternate, swap it in */
+ /* If image_info.Alternates, look in the array, see if any of them are flagged as "DefaultForPrinting"
+ * and if so, substitute that one for the image we are processing.
+ * (it can probably be either an array, or a reference to an array, need an example to test/implement)
+ * see p.274 of PDFReference.pdf
+ */
+
+ if (image_info.Alternates != NULL) {
+ alt_stream = pdfi_find_alternate(ctx, image_info.Alternates);
+ if (alt_stream != NULL) {
+ image_stream = alt_stream;
+ pdfi_free_image_info_components(&image_info);
+ code = pdfi_get_image_info(ctx, image_stream, page_dict, stream_dict, inline_image, &image_info);
+ if (code < 0)
+ goto cleanupExit;
+ }
+ }
+
+ /* Grab stream_offset after alternate has (possibly) set */
+ stream_offset = pdfi_stream_offset(ctx, image_stream);
+
+ /* See if it might be a JPXDecode image even though not in the header */
+ if (image_info.ColorSpace == NULL && !image_info.ImageMask)
+ maybe_jpxdecode = true;
+
+ /* Handle JPXDecode filter pre-scan of header */
+ if ((maybe_jpxdecode || image_info.is_JPXDecode) && !inline_image) {
+ pdfi_seek(ctx, source, stream_offset, SEEK_SET);
+ code = pdfi_scan_jpxfilter(ctx, source, image_info.Length, &image_info.jpx_info);
+ if (code < 0 && image_info.is_JPXDecode)
+ goto cleanupExit;
+
+ /* I saw this JPXDecode images that have SMaskInData */
+ if (image_info.jpx_info.no_data)
+ image_info.is_JPXDecode = false;
+
+ if (code == 0 && maybe_jpxdecode)
+ image_info.is_JPXDecode = true;
+ }
+
+ /* Set the rendering intent if applicable */
+ if (image_info.Intent) {
+ code = pdfi_setrenderingintent(ctx, image_info.Intent);
+ if (code < 0) {
+ /* TODO: Flag a warning on this? Sample fts_17_1706.pdf has misspelled Intent
+ which gs renders without flagging an error */
+#if DEBUG_IMAGES
+ dbgmprintf(ctx->memory, "WARNING: Image with unexpected Intent\n");
+#endif
+ }
+ }
+
+ /* Get the color for this image */
+ code = pdfi_image_get_color(ctx, source, &image_info, &comps, &pcs);
+ if (code < 0)
+ goto cleanupExit;
+
+ /* Set the colorspace */
+ if (pcs) {
+ gs_color_space *pcs1 = pcs;
+
+ code = pdfi_gs_setcolorspace(ctx, pcs);
+ if (code < 0)
+ goto cleanupExit;
+
+ if (pcs->type->index == gs_color_space_index_Indexed)
+ pcs1 = pcs->base_space;
+
+ /* It is possible that we get no error returned from setting an
+ * ICC space, but that we are not able when rendering to create a link
+ * between the ICC space and the output device profile.
+ * The PostScript PDF interpreter sets the colour after setting the space, which
+ * (eventually) causes us to set the device colour, and that actually creates the
+ * link. This is apparntly the only way we can detect this error. Otherwise we
+ * would carry on until we tried to render the image, and that would fail with
+ * a not terribly useful error of -1. So here we try to set the device colour,
+ * for images in an ICC profile space. If that fails then we try to manufacture
+ * a Device space from the number of components in the profile.
+ * I do feel this is something we should be able to handle better!
+ */
+ if (pcs1->type->index == gs_color_space_index_ICC)
+ {
+ gs_client_color cc;
+ int comp = 0;
+ pdf_obj *ColorSpace = NULL;
+
+ cc.pattern = 0;
+ for (comp = 0; comp < pcs1->cmm_icc_profile_data->num_comps;comp++)
+ cc.paint.values[comp] = 0;
+
+ code = gs_setcolor(ctx->pgs, &cc);
+ if (code < 0)
+ goto cleanupExit;
+
+ code = gx_set_dev_color(ctx->pgs);
+ if (code < 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_ICC_PROFILE_LINK, "pdfi_do_image", "Attempting to use profile /N to create a device colour space");
+ /* Possibly we couldn't create a link profile, soemthing wrong with the ICC profile, try to use a device space */
+ switch(pcs1->cmm_icc_profile_data->num_comps) {
+ case 1:
+ code = pdfi_name_alloc(ctx, (byte *)"DeviceGray", 10, &ColorSpace);
+ if (code < 0)
+ goto cleanupExit;
+ pdfi_countup(ColorSpace);
+ break;
+ case 3:
+ code = pdfi_name_alloc(ctx, (byte *)"DeviceRGB", 9, &ColorSpace);
+ if (code < 0)
+ goto cleanupExit;
+ pdfi_countup(ColorSpace);
+ break;
+ case 4:
+ code = pdfi_name_alloc(ctx, (byte *)"DeviceCMYK", 10, &ColorSpace);
+ if (code < 0)
+ goto cleanupExit;
+ pdfi_countup(ColorSpace);
+ break;
+ default:
+ code = gs_error_unknownerror;
+ goto cleanupExit;
+ break;
+ }
+ if (pcs != NULL)
+ rc_decrement_only_cs(pcs, "pdfi_do_image");
+ /* At this point ColorSpace is either a string we just made, or the one from the Image */
+ code = pdfi_create_colorspace(ctx, ColorSpace,
+ image_info.stream_dict, image_info.page_dict,
+ &pcs, image_info.inline_image);
+ pdfi_countdown(ColorSpace);
+ if (code < 0)
+ goto cleanupExit;
+
+ code = pdfi_gs_setcolorspace(ctx, pcs);
+ if (code < 0)
+ goto cleanupExit;
+ }
+ }
+ }
+
+ /* Make a fake SMask dict if needed for JPXDecode */
+ if (ctx->page.has_transparency && image_info.is_JPXDecode && image_info.SMaskInData != 0) {
+ code = pdfi_make_smask_dict(ctx, image_stream, &image_info, comps);
+ if (code < 0)
+ goto cleanupExit;
+ }
+
+ if (ctx->page.has_transparency == true && image_info.SMask != NULL) {
+ bool has_Matte = false;
+
+ /* If this flag is set, then device will process the SMask and we need do nothing
+ * here (e.g. pdfwrite).
+ */
+ if (!ctx->device_state.preserve_smask) {
+ code = pdfi_do_image_smask(ctx, source, &image_info, &has_Matte);
+ if (code < 0)
+ goto cleanupExit;
+ need_smask_cleanup = true;
+ }
+ if (has_Matte)
+ code = pdfi_trans_begin_isolated_group(ctx, true, pcs);
+ else
+ code = pdfi_trans_begin_isolated_group(ctx, true, NULL);
+ if (code < 0)
+ goto cleanupExit;
+ transparency_group = true;
+ } else if (igs->SMask) {
+ code = pdfi_trans_begin_isolated_group(ctx, false, NULL);
+ if (code < 0)
+ goto cleanupExit;
+ transparency_group = true;
+ }
+
+ if (transparency_group && !ctx->device_state.preserve_smask) {
+ save_strokeconstantalpha = gs_getstrokeconstantalpha(ctx->pgs);
+ save_fillconstantalpha = gs_getfillconstantalpha(ctx->pgs);
+ gs_setstrokeconstantalpha(ctx->pgs, 1.0);
+ gs_setfillconstantalpha(ctx->pgs, 1.0);
+ }
+
+ /* Get the Mask data either as an array or a dict, if present */
+ if (image_info.Mask != NULL) {
+ if (image_info.Mask->type == PDF_ARRAY) {
+ mask_array = (pdf_array *)image_info.Mask;
+ } else if (image_info.Mask->type == PDF_STREAM) {
+ mask_stream = (pdf_stream *)image_info.Mask;
+ code = pdfi_get_image_info(ctx, mask_stream, page_dict,
+ stream_dict, inline_image, &mask_info);
+ if (code < 0)
+ goto cleanupExit;
+ } else {
+ pdfi_countdown(image_info.Mask);
+ image_info.Mask = NULL;
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_MASK_ERROR, "pdfi_do_image", NULL);
+ }
+ }
+
+ /* Get the SMask info if we will need it (Type 3x images) */
+ if (image_info.SMask && image_info.SMask->type == PDF_STREAM && ctx->device_state.preserve_smask) {
+ /* smask_dict non-NULL is used to flag a Type 3x image below */
+ smask_stream = (pdf_stream *)image_info.SMask;
+ code = pdfi_get_image_info(ctx, smask_stream, page_dict, stream_dict,
+ inline_image, &smask_info);
+ if (code < 0)
+ goto cleanupExit;
+ }
+
+ /* Get the image into a supported gs type (type1, type3, type4, type3x) */
+ if (!image_info.Mask && !smask_stream) { /* Type 1 and ImageMask */
+ memset(&t1image, 0, sizeof(t1image));
+ pim = (gs_pixel_image_t *)&t1image;
+
+ if (image_info.ImageMask) {
+ /* Sets up timage.ImageMask, amongst other things */
+ gs_image_t_init_adjust(&t1image, NULL, false);
+ } else {
+ gs_image_t_init_adjust(&t1image, pcs, true);
+ }
+ } else if (smask_stream) { /* Type 3x */
+ code = pdfi_image_setup_type3x(ctx, &image_info, &t3ximage, &smask_info, comps);
+ if (code < 0) {
+ /* If this got an error, setup as a Type 1 image */
+ /* NOTE: I did this error-handling the same as for Type 4 image below.
+ * Dunno if it's better to do this or to just abort the whole image?
+ */
+ memset(&t1image, 0, sizeof(t1image));
+ pim = (gs_pixel_image_t *)&t1image;
+ gs_image_t_init_adjust(&t1image, pcs, true);
+ } else {
+ pim = (gs_pixel_image_t *)&t3ximage;
+ }
+ } else {
+ if (mask_array) { /* Type 4 */
+ code = pdfi_image_setup_type4(ctx, &image_info, &t4image, mask_array, pcs);
+ if (code < 0) {
+ /* If this got an error, setup as a Type 1 image */
+ memset(&t1image, 0, sizeof(t1image));
+ pim = (gs_pixel_image_t *)&t1image;
+ gs_image_t_init_adjust(&t1image, pcs, true);
+ } else {
+ pim = (gs_pixel_image_t *)&t4image;
+ }
+ } else { /* Type 3 */
+ memset(&t3image, 0, sizeof(t3image));
+ pim = (gs_pixel_image_t *)&t3image;
+ gs_image3_t_init(&t3image, NULL, interleave_separate_source);
+ code = pdfi_data_image_params(ctx, &mask_info, &t3image.MaskDict, 1, NULL);
+ if (code < 0)
+ goto cleanupExit;
+ }
+ }
+
+
+ /* At this point pim points to a structure containing the specific type
+ * of image, and then we can handle it generically from here.
+ * The underlying gs image functions will do different things for different
+ * types of images.
+ */
+
+ /* Setup the common params */
+ pim->ColorSpace = pcs;
+ code = pdfi_data_image_params(ctx, &image_info, (gs_data_image_t *)pim, comps, pcs);
+ if (code < 0)
+ goto cleanupExit;
+
+ /* Grab the mask_image data buffer in advance.
+ * Doing it this way because I don't want to muck with reading from
+ * two streams simultaneously -- not even sure that is feasible?
+ */
+ if (mask_stream) {
+ code = pdfi_stream_to_buffer(ctx, mask_stream, &mask_buffer, (int64_t *)&mask_size);
+ if (code < 0)
+ goto cleanupExit;
+ } else if (smask_stream) {
+ /* This will happen only in case of PreserveSMask (Type 3x) */
+ code = pdfi_stream_to_buffer(ctx, smask_stream, &mask_buffer, (int64_t *)&mask_size);
+ if (code < 0)
+ goto cleanupExit;
+ }
+
+ /* Setup the data stream for the image data */
+ if (!inline_image)
+ pdfi_seek(ctx, source, stream_offset, SEEK_SET);
+ code = pdfi_filter(ctx, image_stream, source, &new_stream, inline_image);
+ if (code < 0)
+ goto cleanupExit;
+
+ /* This duplicates the code in gs_img.ps; if we have an imagemask, with 1 bit per component (is there any other kind ?)
+ * and the image is to be interpolated, and we are nto sending it to a high level device. Then check the scaling.
+ * If we are scaling up (in device space) by afactor of more than 2, then we install the ImScaleDecode filter,
+ * which interpolates the input data by a factor of 4.
+ * The scaling of 2 is arbitrary (says so in gs_img.ps) but we use it for consistency. The scaling of the input
+ * by 4 is just a magic number, the scaling is always by 4, and we need to know it so we can adjust the Image Matrix
+ * and Width and Height values.
+ */
+ if (image_info.ImageMask == 1 && image_info.BPC == 1 && image_info.Interpolate == 1 && !ctx->device_state.HighLevelDevice)
+ {
+ pdf_c_stream *s = new_stream;
+ gs_matrix mat4 = {4, 0, 0, 4, 0, 0}, inverseIM;
+ gs_point pt, pt1;
+ float s1, s2;
+
+ code = gs_matrix_invert(&pim->ImageMatrix, &inverseIM);
+ if (code < 0)
+ goto cleanupExit;
+
+ code = gs_distance_transform(0, 1, &inverseIM, &pt);
+ if (code < 0)
+ goto cleanupExit;
+
+ code = gs_distance_transform(pt.x, pt.y, &ctm_only(ctx->pgs), &pt1);
+ if (code < 0)
+ goto cleanupExit;
+
+ s1 = sqrt(pt1.x * pt1.x + pt1.y * pt1.y);
+
+ code = gs_distance_transform(1, 0, &inverseIM, &pt);
+ if (code < 0)
+ goto cleanupExit;
+
+ code = gs_distance_transform(pt.x, pt.y, &ctm_only(ctx->pgs), &pt1);
+ if (code < 0)
+ goto cleanupExit;
+
+ s2 = sqrt(pt1.x * pt1.x + pt1.y * pt1.y);
+
+ if (s1 > 2.0 || s2 > 2.0) {
+ code = pdfi_apply_imscale_filter(ctx, 0, image_info.Width, image_info.Height, s, &new_stream);
+ if (code < 0)
+ goto cleanupExit;
+
+ image_info.Width *= 4;
+ image_info.Height *= 4;
+ pim->Width *= 4;
+ pim->Height *= 4;
+ code = gs_matrix_multiply(&pim->ImageMatrix, &mat4, &pim->ImageMatrix);
+ if (code < 0)
+ goto cleanupExit;
+ }
+ }
+
+ code = pdfi_image_setup_trans(ctx, &trans_state);
+ if (code < 0)
+ goto cleanupExit;
+
+ /* Render the image */
+ code = pdfi_render_image(ctx, pim, new_stream,
+ mask_buffer, mask_size,
+ comps, image_info.ImageMask);
+ if (code < 0) {
+ if (ctx->args.pdfdebug)
+ dmprintf1(ctx->memory, "WARNING: pdfi_do_image: error %d from pdfi_render_image\n", code);
+ }
+
+ code1 = pdfi_trans_teardown(ctx, &trans_state);
+ if (code == 0)
+ code = code1;
+
+ cleanupExit:
+ if (code < 0)
+ pdfi_set_warning(ctx, code, NULL, W_PDF_IMAGE_ERROR, "pdfi_do_image", NULL);
+
+ code = 0; /* suppress errors */
+
+ if (transparency_group) {
+ if (!ctx->device_state.preserve_smask) {
+ gs_setstrokeconstantalpha(ctx->pgs, save_strokeconstantalpha);
+ gs_setfillconstantalpha(ctx->pgs, save_fillconstantalpha);
+ }
+ pdfi_trans_end_isolated_group(ctx);
+ if (need_smask_cleanup)
+ pdfi_trans_end_smask_notify(ctx);
+ }
+
+ if (new_stream)
+ pdfi_close_file(ctx, new_stream);
+ if (mask_buffer)
+ gs_free_object(ctx->memory, mask_buffer, "pdfi_do_image (mask_buffer)");
+
+ pdfi_countdown(alt_stream);
+
+ pdfi_free_image_info_components(&image_info);
+ pdfi_free_image_info_components(&mask_info);
+ pdfi_free_image_info_components(&smask_info);
+
+ if (pcs != NULL)
+ rc_decrement_only_cs(pcs, "pdfi_do_image");
+
+ /* Restore the rendering intent */
+ gs_setrenderingintent(ctx->pgs, saved_intent);
+
+#if DEBUG_IMAGES
+ dbgmprintf(ctx->memory, "pdfi_do_image END\n");
+#endif
+ return code;
+}
+
+int pdfi_ID(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict, pdf_c_stream *source)
+{
+ pdf_dict *d = NULL;
+ int code;
+ pdf_stream *image_stream;
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_ID", NULL);
+
+ /* we want to have the indirect_num and indirect_gen of the created dictionary
+ * be 0, because we are reading from a stream, and the stream has already
+ * been decrypted, we don't need to decrypt any strings contained in the
+ * inline dictionary.
+ */
+ code = pdfi_dict_from_stack(ctx, 0, 0);
+ if (code < 0)
+ /* pdfi_dict_from_stack cleans up the stack so we don't need to in case of an error */
+ return code;
+
+ d = (pdf_dict *)ctx->stack_top[-1];
+ pdfi_countup(d);
+ pdfi_pop(ctx, 1);
+
+ code = pdfi_obj_dict_to_stream(ctx, d, &image_stream, true);
+ if (code < 0)
+ goto error;
+
+ code = pdfi_do_image(ctx, page_dict, stream_dict, image_stream, source, true);
+error:
+ pdfi_countdown(image_stream);
+ pdfi_countdown(d);
+ return code;
+}
+
+int pdfi_EI(pdf_context *ctx)
+{
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_EI", NULL);
+
+/* pdfi_clearstack(ctx);*/
+ return 0;
+}
+
+/* see .execgroup */
+int pdfi_form_execgroup(pdf_context *ctx, pdf_dict *page_dict, pdf_stream *xobject_obj,
+ gs_gstate *GroupGState, gs_color_space *pcs, gs_matrix *matrix)
+{
+ int code;
+ pdfi_int_gstate *igs = (pdfi_int_gstate *)ctx->pgs->client_data;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0)
+ goto exit;
+
+ if (GroupGState) {
+ code = pdfi_gs_setgstate(ctx->pgs, GroupGState);
+ if (code < 0)
+ goto exit2;
+ }
+
+ /* Override the colorspace if specified */
+ if (pcs) {
+ code = pdfi_gs_setcolorspace(ctx, pcs);
+ if (code < 0)
+ goto exit2;
+ }
+
+ /* Disable the SMask */
+ pdfi_gstate_smask_free(igs);
+
+ gs_setblendmode(ctx->pgs, BLEND_MODE_Compatible);
+ gs_setstrokeconstantalpha(ctx->pgs, 1.0);
+ gs_setfillconstantalpha(ctx->pgs, 1.0);
+
+ if (matrix)
+ code = gs_concat(ctx->pgs, matrix);
+ if (code < 0) {
+ goto exit2;
+ }
+ code = pdfi_run_context(ctx, xobject_obj, page_dict, false, "FORM");
+
+ exit2:
+ if (code != 0)
+ (void)pdfi_grestore(ctx);
+ else
+ code = pdfi_grestore(ctx);
+ exit:
+ return code;
+}
+
+/* See zbeginform() */
+static int pdfi_form_highlevel_begin(pdf_context *ctx, pdf_dict *form_dict, gs_matrix *CTM,
+ gs_rect *BBox, gs_matrix *form_matrix)
+{
+ int code = 0;
+ gx_device *cdev = gs_currentdevice_inline(ctx->pgs);
+ gs_form_template_t template;
+ gs_point ll, ur;
+ gs_fixed_rect box;
+
+ memset(&template, 0, sizeof(template));
+
+ template.CTM = *CTM; /* (structure copy) */
+ template.BBox = *BBox; /* (structure copy) */
+ template.form_matrix = *form_matrix; /* (structure copy) */
+ template.FormID = -1;
+ template.pcpath = ctx->pgs->clip_path;
+ template.pgs = ctx->pgs;
+
+ code = dev_proc(cdev, dev_spec_op)(cdev, gxdso_form_begin, &template, 0);
+ /* return value > 0 means the device sent us back a matrix
+ * and wants the CTM set to that.
+ * TODO: No idea if we need this nonsense. See zbeginform()
+ */
+ if (code > 0)
+ {
+ gs_setmatrix(ctx->pgs, &template.CTM);
+ gs_distance_transform(template.BBox.p.x, template.BBox.p.y, &template.CTM, &ll);
+ gs_distance_transform(template.BBox.q.x, template.BBox.q.y, &template.CTM, &ur);
+
+ /* A form can legitimately have negative co-ordinates in paths
+ * because it can be translated. But we always clip paths to the
+ * page which (clearly) can't have negative co-ordinates. NB this
+ * wouldn't be a problem if we didn't reset the CTM, but that would
+ * break the form capture.
+ * So here we temporarily set the clip to permit negative values,
+ * fortunately this works.....
+ */
+ /* We choose to permit negative values of the same magnitude as the
+ * positive ones.
+ */
+
+ box.p.x = float2fixed(ll.x);
+ box.p.y = float2fixed(ll.y);
+ box.q.x = float2fixed(ur.x);
+ box.q.y = float2fixed(ur.y);
+
+ if (box.p.x < 0) {
+ if(box.p.x * -1 > box.q.x)
+ box.q.x = box.p.x * -1;
+ } else {
+ if (fabs(ur.x) > fabs(ll.x))
+ box.p.x = box.q.x * -1;
+ else {
+ box.p.x = float2fixed(ll.x * -1);
+ box.q.x = float2fixed(ll.x);
+ }
+ }
+ if (box.p.y < 0) {
+ if(box.p.y * -1 > box.q.y)
+ box.q.y = box.p.y * -1;
+ } else {
+ if (fabs(ur.y) > fabs(ll.y))
+ box.p.y = box.q.y * -1;
+ else {
+ box.p.y = float2fixed(ll.y * -1);
+ box.q.y = float2fixed(ll.y);
+ }
+ }
+ /* This gets undone when we grestore after the form is executed */
+ code = gx_clip_to_rectangle(ctx->pgs, &box);
+ }
+
+ return code;
+}
+
+/* See zendform() */
+static int pdfi_form_highlevel_end(pdf_context *ctx)
+{
+ int code = 0;
+ gx_device *cdev = gs_currentdevice_inline(ctx->pgs);
+
+ code = dev_proc(cdev, dev_spec_op)(cdev, gxdso_form_end, 0, 0);
+ return code;
+}
+
+/* See bug #702560. The original file has a Form XObject which is not a stream. Instead
+ * the Form XObject has a /Contents key which points to a stream dictionary. This is plainly
+ * illegal but, as always, Acrobat can open it....
+ * If PDFSTOPONERROR is true then we just exit. Otherwise we look for a /Contents key in the stream
+ * dictionary. If we find one we dereference the object to get a stream dictionary, then merge the
+ * two dictionaries, ensuring the stream offset is correct, and proceed as if that's what we'd
+ * always had. If we don't have a /Contents key then exit with a typecheck error.
+ *
+ * Sets *hacked_stream to the /Contents stream if it found one.
+ */
+static int pdfi_form_stream_hack(pdf_context *ctx, pdf_dict *form_dict, pdf_stream **hacked_stream)
+{
+ int code = 0;
+ pdf_stream *stream_obj = NULL;
+
+ *hacked_stream = NULL;
+
+ if (form_dict->type == PDF_STREAM)
+ return 0;
+
+ if (!ctx->args.pdfstoponerror) {
+ pdf_dict *stream_dict = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, form_dict, "Contents", PDF_STREAM,
+ (pdf_obj **)&stream_obj);
+ if (code < 0 || stream_obj == NULL) {
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADSTREAMDICT, "pdfi_form_stream_hack", NULL);
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)stream_obj, &stream_dict);
+ if (code < 0) {
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADSTREAMDICT, "pdfi_form_stream_hack", NULL);
+ goto exit;
+ }
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_STREAM_HAS_CONTENTS, "pdfi_form_stream_hack", NULL);
+ code = pdfi_merge_dicts(ctx, stream_dict, form_dict);
+ /* Having merged the dictionaries, we don't want the Contents key in the stream dict.
+ * We do want to leave it in the form dictionary, in case we use this form again.
+ * Leaving the reference in the stream dicttionary leads to a reference counting problem
+ * because stream_dict is contained in stream_obj so stream_obj becomes self-referencing.
+ */
+ pdfi_dict_delete(ctx, stream_dict, "Contents");
+ } else {
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADSTREAMDICT, "pdfi_form_stream_hack", NULL);
+ code = gs_note_error(gs_error_typecheck);
+ }
+ if (code == 0) {
+ *hacked_stream = stream_obj;
+ pdfi_countup(stream_obj);
+ }
+
+ exit:
+ pdfi_countdown(stream_obj);
+ return code;
+}
+
+static int pdfi_do_form(pdf_context *ctx, pdf_dict *page_dict, pdf_stream *form_obj)
+{
+ int code, code1 = 0;
+ bool group_known = false;
+ bool do_group = false;
+ pdf_array *FormMatrix = NULL;
+ gs_matrix formmatrix, CTM;
+ gs_rect bbox;
+ pdf_array *BBox = NULL;
+ bool save_PreservePDFForm;
+ pdf_stream *form_stream = NULL; /* Alias */
+ pdf_stream *hacked_stream = NULL;
+ pdf_dict *form_dict;
+ gs_color_space *pcs = NULL;
+
+#if DEBUG_IMAGES
+ dbgmprintf(ctx->memory, "pdfi_do_form BEGIN\n");
+#endif
+ if (form_obj->type != PDF_STREAM) {
+ code = pdfi_form_stream_hack(ctx, (pdf_dict *)form_obj, &hacked_stream);
+ if (code < 0)
+ return code;
+ form_stream = hacked_stream;
+ } else
+ form_stream = (pdf_stream *)form_obj;
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)form_stream, &form_dict);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_dict_known(ctx, form_dict, "Group", &group_known);
+ if (code < 0)
+ goto exit;
+ if (group_known && ctx->page.has_transparency)
+ do_group = true;
+
+ /* Grab the CTM before it gets modified */
+ code = gs_currentmatrix(ctx->pgs, &CTM);
+ if (code < 0) goto exit1;
+
+ code = pdfi_op_q(ctx);
+ if (code < 0) goto exit1;
+
+ code = pdfi_dict_knownget_type(ctx, form_dict, "Matrix", PDF_ARRAY, (pdf_obj **)&FormMatrix);
+ if (code < 0) goto exit1;
+
+ code = pdfi_array_to_gs_matrix(ctx, FormMatrix, &formmatrix);
+ if (code < 0) goto exit1;
+
+ code = pdfi_dict_knownget_type(ctx, form_dict, "BBox", PDF_ARRAY, (pdf_obj **)&BBox);
+ if (code < 0) goto exit1;
+
+ code = pdfi_array_to_gs_rect(ctx, BBox, &bbox);
+ if (code < 0) goto exit1;
+
+ code = gs_concat(ctx->pgs, &formmatrix);
+ if (code < 0) goto exit1;
+
+ code = gs_rectclip(ctx->pgs, &bbox, 1);
+ if (code < 0) goto exit1;
+
+ if (ctx->PreservePDFForm) {
+ code = pdfi_form_highlevel_begin(ctx, form_dict, &CTM, &bbox, &formmatrix);
+ if (code < 0) goto exit1;
+ }
+ save_PreservePDFForm = ctx->PreservePDFForm;
+ ctx->PreservePDFForm = false; /* Turn off in case there are any sub-forms */
+
+ if (do_group) {
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0) goto exit1;
+
+ /* Save the current color space in case it gets changed */
+ pcs = gs_currentcolorspace(ctx->pgs);
+ rc_increment(pcs);
+
+ code = pdfi_trans_begin_form_group(ctx, page_dict, form_dict);
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ if (code < 0) goto exit1;
+
+ code = pdfi_form_execgroup(ctx, page_dict, form_stream, NULL, pcs, NULL);
+ code1 = pdfi_trans_end_group(ctx);
+ if (code == 0) code = code1;
+ } else {
+ bool saved_decrypt_strings = ctx->encryption.decrypt_strings;
+
+ /* We can run a Form even when we aren't running a page content stresm,
+ * eg for an annotation, and we need to *not* decrypt strings in that
+ * case (the content stream will be decrypted and strings in content
+ * streams are not additionally encrypted).
+ */
+ ctx->encryption.decrypt_strings = false;
+ code = pdfi_run_context(ctx, form_stream, page_dict, false, "FORM");
+ ctx->encryption.decrypt_strings = saved_decrypt_strings;
+ }
+
+ ctx->PreservePDFForm = save_PreservePDFForm;
+ if (ctx->PreservePDFForm) {
+ code = pdfi_form_highlevel_end(ctx);
+ }
+
+ exit1:
+ code1 = pdfi_op_Q(ctx);
+ if (code == 0) code = code1;
+
+ exit:
+ pdfi_countdown(FormMatrix);
+ pdfi_countdown(BBox);
+ pdfi_countdown(hacked_stream);
+ if (pcs)
+ rc_decrement_only_cs(pcs, "pdfi_do_form(pcs)");
+#if DEBUG_IMAGES
+ dbgmprintf(ctx->memory, "pdfi_do_form END\n");
+#endif
+ if (code < 0)
+ return code;
+ return 0;
+}
+
+int pdfi_do_highlevel_form(pdf_context *ctx, pdf_dict *page_dict, pdf_stream *form_stream)
+{
+ int code = 0;
+
+ ctx->PreservePDFForm = true;
+ code = pdfi_do_form(ctx, page_dict, form_stream);
+ ctx->PreservePDFForm = false;
+
+ return code;
+}
+
+int pdfi_do_image_or_form(pdf_context *ctx, pdf_dict *stream_dict,
+ pdf_dict *page_dict, pdf_obj *xobject_obj)
+{
+ int code;
+ pdf_name *n = NULL;
+ pdf_dict *xobject_dict;
+
+ code = pdfi_dict_from_obj(ctx, xobject_obj, &xobject_dict);
+ if (code < 0)
+ return code;
+
+#if DEBUG_IMAGES
+ dbgmprintf1(ctx->memory, "pdfi_do_image_or_form BEGIN (OBJ = %d)\n", xobject_obj->object_num);
+#endif
+ code = pdfi_trans_set_params(ctx);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_get(ctx, xobject_dict, "Subtype", (pdf_obj **)&n);
+ if (code < 0) {
+ if (code == gs_error_undefined) {
+ /* This is illegal, because we have no way to tell is an XObject is a Form
+ * or Image object. However it seems Acrobat just assumes that it's a Form!
+ * See test file /tests_private/pdf/PDFIA1.7_SUBSET/CATX2063.pdf
+ */
+ code = pdfi_name_alloc(ctx, (byte *)"Form", 4, (pdf_obj **)&n);
+ pdfi_countup(n);
+ pdfi_set_error(ctx, 0, NULL, E_PDF_NO_SUBTYPE, "pdfi_do_image_or_form", NULL);
+ }
+ else
+ goto exit;
+ }
+ if (pdfi_name_is(n, "Image")) {
+ gs_offset_t savedoffset;
+
+ if (xobject_obj->type != PDF_STREAM) {
+ gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+ savedoffset = pdfi_tell(ctx->main_stream);
+ code = pdfi_do_image(ctx, page_dict, stream_dict, (pdf_stream *)xobject_obj,
+ ctx->main_stream, false);
+ pdfi_seek(ctx, ctx->main_stream, savedoffset, SEEK_SET);
+ } else if (pdfi_name_is(n, "Form")) {
+ /* In theory a Form must be a stream, but we don't check that here
+ * because there is a broken case where it can be a dict.
+ * So pdfi_do_form() will handle that crazy case if it's not actually a stream.
+ */
+ code = pdfi_do_form(ctx, page_dict, (pdf_stream *)xobject_obj);
+ } else if (pdfi_name_is(n, "PS")) {
+ dmprintf(ctx->memory, "*** WARNING: PostScript XObjects are deprecated (SubType 'PS')\n");
+ code = 0; /* Swallow silently */
+ } else {
+ code = gs_error_typecheck;
+ }
+
+ exit:
+ pdfi_countdown(n);
+#if DEBUG_IMAGES
+ dbgmprintf(ctx->memory, "pdfi_do_image_or_form END\n");
+#endif
+ return code;
+}
+
+int pdfi_Do(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code = 0;
+ pdf_name *n = NULL;
+ pdf_obj *o = NULL;
+ pdf_dict *sdict = NULL;
+ bool known = false;
+
+ if (pdfi_count_stack(ctx) < 1) {
+ code = gs_note_error(gs_error_stackunderflow);
+ goto exit1;
+ }
+ n = (pdf_name *)ctx->stack_top[-1];
+ if (n->type != PDF_NAME) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit1;
+ }
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_Do", NULL);
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ goto exit1;
+ code = pdfi_find_resource(ctx, (unsigned char *)"XObject", n, (pdf_dict *)stream_dict, page_dict, &o);
+ if (code < 0)
+ goto exit;
+
+ if (o->type != PDF_STREAM && o->type != PDF_DICT) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+
+ /* This doesn't count up the stream dictionary, so we don't need to count it down later */
+ code = pdfi_dict_from_obj(ctx, o, &sdict);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_dict_known(ctx, sdict, "Parent", &known);
+ if (code < 0)
+ goto exit;
+ /* Add a Parent ref, unless it happens to be a circular reference
+ * (sample Bug298226.pdf -- has a circular ref and adding the Parent caused memory leak)
+ */
+ if (!known && sdict->object_num != stream_dict->object_num) {
+ code = pdfi_dict_put(ctx, sdict, "Parent", (pdf_obj *)stream_dict);
+ if (code < 0)
+ goto exit;
+ }
+
+ /* NOTE: Used to have a pdfi_gsave/pdfi_grestore around this, but it actually makes
+ * things render incorrectly (and isn't in the PS code).
+ * It also causes demo.ai.pdf to crash.
+ * I don't really understand... (all transparency related, though, so nothing surprises me...)
+ * (there are some q/Q and gsave/grestore in the code under this)
+ *
+ * Original Comment:
+ * The image or form might change the colour space (or indeed other aspects
+ * of the graphics state, if its a Form XObject. So gsave/grestore round it
+ * to prevent unexpected changes.
+ */
+ // pdfi_gsave(ctx);
+ code = pdfi_do_image_or_form(ctx, stream_dict, page_dict, o);
+ // pdfi_grestore(ctx);
+ if (code < 0)
+ goto exit;
+
+ exit:
+ if (code < 0)
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ else
+ code = pdfi_loop_detector_cleartomark(ctx);
+exit1:
+ /* No need to countdown 'n' because that points to the stack object, and we're going to pop that */
+ pdfi_countdown(o);
+ pdfi_pop(ctx, 1);
+ return code;
+}
diff --git a/pdf/pdf_image.h b/pdf/pdf_image.h
new file mode 100644
index 00000000..449e90ef
--- /dev/null
+++ b/pdf/pdf_image.h
@@ -0,0 +1,30 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Image operations for the PDF interpreter */
+
+#ifndef PDF_IMAGE_OPERATORS
+#define PDF_IMAGE_OPERATORS
+
+int pdfi_BI(pdf_context *ctx);
+int pdfi_EI(pdf_context *ctx);
+int pdfi_ID(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict, pdf_c_stream *source);
+int pdfi_Do(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict);
+int pdfi_do_highlevel_form(pdf_context *ctx, pdf_dict *page_dict, pdf_stream *form_stream);
+int pdfi_do_image_or_form(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict, pdf_obj *xobject_obj);
+int pdfi_form_execgroup(pdf_context *ctx, pdf_dict *page_dict, pdf_stream *xobject_dict,
+ gs_gstate *GroupGState, gs_color_space *pcs, gs_matrix *matrix);
+
+#endif
diff --git a/pdf/pdf_int.c b/pdf/pdf_int.c
new file mode 100644
index 00000000..555653b6
--- /dev/null
+++ b/pdf/pdf_int.c
@@ -0,0 +1,2125 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* The PDF interpreter written in C */
+
+#include "pdf_int.h"
+#include "pdf_file.h"
+#include "strmio.h"
+#include "stream.h"
+#include "pdf_misc.h"
+#include "pdf_path.h"
+#include "pdf_colour.h"
+#include "pdf_image.h"
+#include "pdf_shading.h"
+#include "pdf_font.h"
+#include "pdf_font.h"
+#include "pdf_cmap.h"
+#include "pdf_text.h"
+#include "pdf_gstate.h"
+#include "pdf_stack.h"
+#include "pdf_xref.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_trans.h"
+#include "pdf_optcontent.h"
+#include "pdf_sec.h"
+
+/* we use -ve returns for error, 0 for success and +ve for 'take an action' */
+/* Defining tis return so we do not need to define a new error */
+#define REPAIRED_KEYWORD 1
+
+/***********************************************************************************/
+/* 'token' reading functions. Tokens in this sense are PDF logical objects and the */
+/* related keywords. So that's numbers, booleans, names, strings, dictionaries, */
+/* arrays, the null object and indirect references. The keywords are obj/endobj */
+/* stream/endstream, xref, startxref and trailer. */
+
+/***********************************************************************************/
+/* Some simple functions to find white space, delimiters and hex bytes */
+static bool iswhite(char c)
+{
+ if (c == 0x00 || c == 0x09 || c == 0x0a || c == 0x0c || c == 0x0d || c == 0x20)
+ return true;
+ else
+ return false;
+}
+
+static bool isdelimiter(char c)
+{
+ if (c == '/' || c == '(' || c == ')' || c == '[' || c == ']' || c == '<' || c == '>' || c == '{' || c == '}' || c == '%')
+ return true;
+ else
+ return false;
+}
+
+static bool ishex(char c)
+{
+ if (c < 0x30)
+ return false;
+
+ if (c > 0x39) {
+ if (c > 'F') {
+ if (c < 'a')
+ return false;
+ if (c > 'f')
+ return false;
+ return true;
+ } else {
+ if (c < 'A')
+ return false;
+ return true;
+ }
+ } else
+ return true;
+}
+
+/* You must ensure the character is a hex character before calling this, no error trapping here */
+static int fromhex(char c)
+{
+ if (c > 0x39) {
+ if (c > 'F') {
+ return c - 0x57;
+ } else {
+ return c - 0x37;
+ }
+ } else
+ return c - 0x30;
+}
+
+/* The 'read' functions all return the newly created object on the context's stack
+ * which means these objects are created with a reference count of 0, and only when
+ * pushed onto the stack does the reference count become 1, indicating the stack is
+ * the only reference.
+ */
+int pdfi_skip_white(pdf_context *ctx, pdf_c_stream *s)
+{
+ uint32_t read = 0;
+ int32_t bytes = 0;
+ byte c;
+
+ do {
+ bytes = pdfi_read_bytes(ctx, &c, 1, 1, s);
+ if (bytes < 0)
+ return_error(gs_error_ioerror);
+ if (bytes == 0)
+ return 0;
+ read += bytes;
+ } while (bytes != 0 && iswhite(c));
+
+ if (read > 0)
+ pdfi_unread(ctx, s, &c, 1);
+ return 0;
+}
+
+int pdfi_skip_eol(pdf_context *ctx, pdf_c_stream *s)
+{
+ uint32_t read = 0;
+ int32_t bytes = 0;
+ byte c;
+
+ do {
+ bytes = pdfi_read_bytes(ctx, &c, 1, 1, s);
+ if (bytes == 0)
+ return 0;
+ if (read) {
+ if (c == 0x0A)
+ return 0;
+ pdfi_unread(ctx, s, &c, 1);
+ return 0;
+ }
+ if (c == 0x0D)
+ read++;
+ } while (c != 0x0A);
+ return 0;
+}
+
+static int pdfi_read_num(pdf_context *ctx, pdf_c_stream *s, uint32_t indirect_num, uint32_t indirect_gen)
+{
+ byte Buffer[256];
+ char Max[256];
+ int MaxLen = 0;
+ unsigned short index = 0;
+ short bytes;
+ bool real = false;
+ bool has_decimal_point = false;
+ bool has_exponent = false;
+ unsigned short exponent_index = 0;
+ pdf_num *num;
+ int code = 0, malformed = false, doubleneg = false, recovered = false;
+
+ pdfi_skip_white(ctx, s);
+
+ do {
+ bytes = pdfi_read_bytes(ctx, (byte *)&Buffer[index], 1, 1, s);
+ if (bytes == 0 && s->eof) {
+ Buffer[index] = 0x00;
+ break;
+ }
+
+ if (bytes <= 0)
+ return_error(gs_error_ioerror);
+
+ if (iswhite((char)Buffer[index])) {
+ Buffer[index] = 0x00;
+ break;
+ } else {
+ if (isdelimiter((char)Buffer[index])) {
+ pdfi_unread(ctx, s, (byte *)&Buffer[index], 1);
+ Buffer[index] = 0x00;
+ break;
+ }
+ }
+ if (Buffer[index] == '.') {
+ if (has_decimal_point == true) {
+ if (ctx->args.pdfstoponerror)
+ return_error(gs_error_syntaxerror);
+ malformed = true;
+ } else {
+ has_decimal_point = true;
+ real = true;
+ }
+ } else if (Buffer[index] == 'e' || Buffer[index] == 'E') {
+ /* TODO: technically scientific notation isn't in PDF spec,
+ * but gs seems to accept it, so we should also?
+ */
+ if (has_exponent == true) {
+ if (ctx->args.pdfstoponerror)
+ return_error(gs_error_syntaxerror);
+ malformed = true;
+ } else {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_NUM_EXPONENT, "pdfi_read_num", NULL);
+ has_exponent = true;
+ exponent_index = index;
+ real = true;
+ }
+ } else if (Buffer[index] == '-' || Buffer[index] == '+') {
+ if (!(index == 0 || (has_exponent && index == exponent_index+1))) {
+ if (ctx->args.pdfstoponerror)
+ return_error(gs_error_syntaxerror);
+ /* Acrobat weirdness. We need to know if a number starts with two - signs
+ * because Acrobat treats real and integers defined this way differently!
+ * Double-negated integers are treated as 0, and reals are treated as if
+ * they had one negative sign. We can't tell whether the number is a real
+ * or not yet, we do that below.
+ */
+ pdfi_set_error(ctx, 0, NULL, E_PDF_MALFORMEDNUMBER, "pdfi_read_num", NULL);
+ if (Buffer[index - 1] == '-') {
+ doubleneg = true;
+ index -= 1;
+ }
+ else {
+ malformed = true;
+ Buffer[index] = 0x00;
+ recovered = true;
+ }
+ }
+ } else if (Buffer[index] < 0x30 || Buffer[index] > 0x39) {
+ pdfi_set_error(ctx, 0, NULL, E_PDF_MISSINGWHITESPACE, "pdfi_read_num", (char *)"Ignoring missing white space while parsing number");
+ if (ctx->args.pdfstoponerror)
+ return_error(gs_error_syntaxerror);
+ pdfi_unread(ctx, s, (byte *)&Buffer[index], 1);
+ Buffer[index] = 0x00;
+ break;
+ }
+ if (++index > 255)
+ return_error(gs_error_syntaxerror);
+ } while(1);
+
+ if (!real && index > 7) {
+ /* Check for integer overflow, represent as real if so */
+ gs_sprintf(Max, "%d", (max_uint >> 1));
+ MaxLen = strlen((const char *)Max);
+
+ if (index >= MaxLen) {
+ int j = 0;
+
+ if (Buffer[j] == '-')
+ j++;
+
+ while (Buffer[j] == '0')
+ j++;
+
+ if (index - j > MaxLen)
+ real = true;
+
+ if (index - j == MaxLen)
+ {
+ real = false;
+
+ for (;j< MaxLen; j++) {
+ if (Buffer[j] == Max[j])
+ continue;
+ if (Buffer[j] > Max[j])
+ real=true;
+ break;
+ }
+ }
+ }
+ }
+
+ if (real && (!malformed || (malformed && recovered)))
+ code = pdfi_object_alloc(ctx, PDF_REAL, 0, (pdf_obj **)&num);
+ else
+ code = pdfi_object_alloc(ctx, PDF_INT, 0, (pdf_obj **)&num);
+ if (code < 0)
+ return code;
+
+ if ((malformed && !recovered) || (!real && doubleneg)) {
+ char extra_info[gp_file_name_sizeof];
+
+ gs_sprintf(extra_info, "Treating malformed number %s as 0", Buffer);
+ pdfi_set_error(ctx, 0, NULL, E_PDF_MALFORMEDNUMBER, "pdfi_read_num", extra_info);
+ num->value.i = 0;
+ } else {
+ if (real) {
+ float tempf;
+ char *dot = NULL, mfloat[256]; /* We limit numbers to 255 above so it can't exceed this */
+
+ /* Check for overflow */
+ gs_sprintf(mfloat, "%f", MAX_FLOAT);
+ dot = strstr(mfloat, ".");
+ *dot = 0x00;
+
+ dot = strstr((char *)Buffer, ".");
+ if (dot != NULL)
+ *dot = 0x00;
+ if (strlen((char *)Buffer) > strlen(mfloat)) {
+ if (dot != NULL)
+ *dot = '.';
+ if (ctx->args.pdfdebug)
+ dmprintf1(ctx->memory, "overflow reading real number : %s\n", Buffer);
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OVERFLOW_REAL, "pdfi_read_num", NULL);
+ num->value.d = 0.0;
+ }
+ else {
+ if (strlen((char *)Buffer) == strlen(mfloat)) {
+ int fi = 0;
+
+ for (fi = 0;fi < strlen((const char *)Buffer);fi++) {
+ if (Buffer[fi] > mfloat[fi]) {
+ if (dot != NULL)
+ *dot = '.';
+ if (ctx->args.pdfdebug)
+ dmprintf1(ctx->memory, "overflow reading real number : %s\n", Buffer);
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OVERFLOW_REAL, "pdfi_read_num", NULL);
+ num->value.d = 0.0;
+ }
+ }
+ }
+ if (dot != NULL)
+ *dot = '.';
+ if (sscanf((const char *)Buffer, "%f", &tempf) == 0) {
+ if (ctx->args.pdfdebug)
+ dmprintf1(ctx->memory, "failed to read real number : %s\n", Buffer);
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_INVALID_REAL, "pdfi_read_num", NULL);
+ num->value.d = 0.0;
+ }
+ num->value.d = tempf;
+ }
+ } else {
+ int tempi;
+ if (sscanf((const char *)Buffer, "%d", &tempi) == 0) {
+ if (ctx->args.pdfdebug)
+ dmprintf1(ctx->memory, "failed to read integer : %s\n", Buffer);
+ gs_free_object(OBJ_MEMORY(num), num, "pdfi_read_num error");
+ return_error(gs_error_syntaxerror);
+ }
+ num->value.i = tempi;
+ }
+ }
+ if (ctx->args.pdfdebug) {
+ if (real)
+ dmprintf1(ctx->memory, " %f", num->value.d);
+ else
+ dmprintf1(ctx->memory, " %"PRIi64, num->value.i);
+ }
+ num->indirect_num = indirect_num;
+ num->indirect_gen = indirect_gen;
+
+ code = pdfi_push(ctx, (pdf_obj *)num);
+
+ if (code < 0)
+ pdfi_free_object((pdf_obj *)num);
+
+ return code;
+}
+
+static int pdfi_read_name(pdf_context *ctx, pdf_c_stream *s, uint32_t indirect_num, uint32_t indirect_gen)
+{
+ char *Buffer, *NewBuf = NULL;
+ unsigned short index = 0;
+ short bytes = 0;
+ uint32_t size = 256;
+ pdf_name *name = NULL;
+ int code;
+
+ Buffer = (char *)gs_alloc_bytes(ctx->memory, size, "pdfi_read_name");
+ if (Buffer == NULL)
+ return_error(gs_error_VMerror);
+
+ do {
+ bytes = pdfi_read_bytes(ctx, (byte *)&Buffer[index], 1, 1, s);
+ if (bytes == 0 && s->eof)
+ break;
+ if (bytes <= 0)
+ return_error(gs_error_ioerror);
+
+ if (iswhite((char)Buffer[index])) {
+ Buffer[index] = 0x00;
+ break;
+ } else {
+ if (isdelimiter((char)Buffer[index])) {
+ pdfi_unread(ctx, s, (byte *)&Buffer[index], 1);
+ Buffer[index] = 0x00;
+ break;
+ }
+ }
+
+ /* Check for and convert escaped name characters */
+ if (Buffer[index] == '#') {
+ byte NumBuf[2];
+
+ bytes = pdfi_read_bytes(ctx, (byte *)&NumBuf, 1, 2, s);
+ if (bytes < 2 || (!ishex(NumBuf[0]) || !ishex(NumBuf[1]))) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_NAME_ESCAPE, "pdfi_read_name", NULL);
+ pdfi_unread(ctx, s, (byte *)NumBuf, bytes);
+ }
+ else
+ Buffer[index] = (fromhex(NumBuf[0]) << 4) + fromhex(NumBuf[1]);
+ }
+
+ /* If we ran out of memory, increase the buffer size */
+ if (index++ >= size - 1) {
+ NewBuf = (char *)gs_alloc_bytes(ctx->memory, size + 256, "pdfi_read_name");
+ if (NewBuf == NULL) {
+ gs_free_object(ctx->memory, Buffer, "pdfi_read_name error");
+ return_error(gs_error_VMerror);
+ }
+ memcpy(NewBuf, Buffer, size);
+ gs_free_object(ctx->memory, Buffer, "pdfi_read_name");
+ Buffer = NewBuf;
+ size += 256;
+ }
+ } while(1);
+
+ code = pdfi_object_alloc(ctx, PDF_NAME, index, (pdf_obj **)&name);
+ if (code < 0) {
+ gs_free_object(ctx->memory, Buffer, "pdfi_read_name error");
+ return code;
+ }
+ memcpy(name->data, Buffer, index);
+ name->indirect_num = indirect_num;
+ name->indirect_gen = indirect_gen;
+
+ if (ctx->args.pdfdebug)
+ dmprintf1(ctx->memory, " /%s", Buffer);
+
+ gs_free_object(ctx->memory, Buffer, "pdfi_read_name");
+
+ code = pdfi_push(ctx, (pdf_obj *)name);
+
+ if (code < 0)
+ pdfi_free_object((pdf_obj *)name);
+
+ return code;
+}
+
+static int pdfi_read_hexstring(pdf_context *ctx, pdf_c_stream *s, uint32_t indirect_num, uint32_t indirect_gen)
+{
+ char *Buffer, *NewBuf = NULL, HexBuf[2];
+ unsigned short index = 0;
+ short bytes = 0;
+ uint32_t size = 256;
+ pdf_string *string = NULL;
+ int code;
+
+ Buffer = (char *)gs_alloc_bytes(ctx->memory, size, "pdfi_read_hexstring");
+ if (Buffer == NULL)
+ return_error(gs_error_VMerror);
+
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, " <");
+
+ do {
+ do {
+ bytes = pdfi_read_bytes(ctx, (byte *)HexBuf, 1, 1, s);
+ if (bytes == 0 && s->eof)
+ break;
+ if (bytes <= 0) {
+ code = gs_note_error(gs_error_ioerror);
+ goto exit;
+ }
+ } while(iswhite(HexBuf[0]));
+ if (bytes == 0 && s->eof)
+ break;
+
+ if (HexBuf[0] == '>')
+ break;
+
+ if (ctx->args.pdfdebug)
+ dmprintf1(ctx->memory, "%c", HexBuf[0]);
+
+ do {
+ bytes = pdfi_read_bytes(ctx, (byte *)&HexBuf[1], 1, 1, s);
+ if (bytes == 0 && s->eof)
+ break;
+ if (bytes <= 0) {
+ code = gs_note_error(gs_error_ioerror);
+ goto exit;
+ }
+ } while(iswhite(HexBuf[1]));
+ if (bytes == 0 && s->eof)
+ break;
+
+ if (!ishex(HexBuf[0]) || !ishex(HexBuf[1])) {
+ code = gs_note_error(gs_error_syntaxerror);
+ goto exit;
+ }
+
+ if (ctx->args.pdfdebug)
+ dmprintf1(ctx->memory, "%c", HexBuf[1]);
+
+ Buffer[index] = (fromhex(HexBuf[0]) << 4) + fromhex(HexBuf[1]);
+
+ if (index++ >= size - 1) {
+ NewBuf = (char *)gs_alloc_bytes(ctx->memory, size + 256, "pdfi_read_hexstring");
+ if (NewBuf == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto exit;
+ }
+ memcpy(NewBuf, Buffer, size);
+ gs_free_object(ctx->memory, Buffer, "pdfi_read_hexstring");
+ Buffer = NewBuf;
+ size += 256;
+ }
+ } while(1);
+
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, ">");
+
+ code = pdfi_object_alloc(ctx, PDF_STRING, index, (pdf_obj **)&string);
+ if (code < 0)
+ goto exit;
+ memcpy(string->data, Buffer, index);
+ string->indirect_num = indirect_num;
+ string->indirect_gen = indirect_gen;
+
+ if (ctx->encryption.is_encrypted && ctx->encryption.decrypt_strings) {
+ code = pdfi_decrypt_string(ctx, string);
+ if (code < 0)
+ return code;
+ }
+
+ code = pdfi_push(ctx, (pdf_obj *)string);
+ if (code < 0)
+ pdfi_free_object((pdf_obj *)string);
+
+ exit:
+ gs_free_object(ctx->memory, Buffer, "pdfi_read_hexstring");
+ return code;
+}
+
+static int pdfi_read_string(pdf_context *ctx, pdf_c_stream *s, uint32_t indirect_num, uint32_t indirect_gen)
+{
+ char *Buffer, *NewBuf = NULL, octal[3];
+ unsigned short index = 0;
+ short bytes = 0;
+ uint32_t size = 256;
+ pdf_string *string = NULL;
+ int code, octal_index = 0, nesting = 0;
+ bool escape = false, skip_eol = false, exit_loop = false;
+
+ Buffer = (char *)gs_alloc_bytes(ctx->memory, size, "pdfi_read_string");
+ if (Buffer == NULL)
+ return_error(gs_error_VMerror);
+
+ do {
+ if (index >= size - 1) {
+ NewBuf = (char *)gs_alloc_bytes(ctx->memory, size + 256, "pdfi_read_string");
+ if (NewBuf == NULL) {
+ gs_free_object(ctx->memory, Buffer, "pdfi_read_string error");
+ return_error(gs_error_VMerror);
+ }
+ memcpy(NewBuf, Buffer, size);
+ gs_free_object(ctx->memory, Buffer, "pdfi_read_string");
+ Buffer = NewBuf;
+ size += 256;
+ }
+
+ bytes = pdfi_read_bytes(ctx, (byte *)&Buffer[index], 1, 1, s);
+
+ if (bytes == 0 && s->eof)
+ break;
+ if (bytes <= 0) {
+ Buffer[index] = 0x00;
+ break;
+ }
+
+ if (skip_eol) {
+ if (Buffer[index] == 0x0a || Buffer[index] == 0x0d)
+ continue;
+ skip_eol = false;
+ }
+
+ if (escape) {
+ escape = false;
+ if (Buffer[index] == 0x0a || Buffer[index] == 0x0d) {
+ skip_eol = true;
+ continue;
+ }
+ if (octal_index) {
+ byte dummy[2];
+ dummy[0] = '\\';
+ dummy[1] = Buffer[index];
+ code = pdfi_unread(ctx, s, dummy, 2);
+ if (code < 0) {
+ gs_free_object(ctx->memory, Buffer, "pdfi_read_string");
+ return code;
+ }
+ Buffer[index] = octal[0];
+ if (octal_index == 2)
+ Buffer[index] = (Buffer[index] * 8) + octal[1];
+ octal_index = 0;
+ } else {
+ switch (Buffer[index]) {
+ case 'n':
+ Buffer[index] = 0x0a;
+ break;
+ case 'r':
+ Buffer[index] = 0x0d;
+ break;
+ case 't':
+ Buffer[index] = 0x09;
+ break;
+ case 'b':
+ Buffer[index] = 0x08;
+ break;
+ case 'f':
+ Buffer[index] = 0x0c;
+ break;
+ case '(':
+ case ')':
+ case '\\':
+ break;
+ default:
+ if (Buffer[index] >= 0x30 && Buffer[index] <= 0x37) {
+ octal[octal_index] = Buffer[index] - 0x30;
+ octal_index++;
+ continue;
+ }
+ /* PDF Reference, literal strings, if the character following a
+ * escape \ character is not recognised, then it is ignored.
+ */
+ escape = false;
+ index++;
+ continue;
+ }
+ }
+ } else {
+ switch(Buffer[index]) {
+ case 0x0a:
+ case 0x0d:
+ if (octal_index != 0) {
+ code = pdfi_unread(ctx, s, (byte *)&Buffer[index], 1);
+ if (code < 0) {
+ gs_free_object(ctx->memory, Buffer, "pdfi_read_string");
+ return code;
+ }
+ Buffer[index] = octal[0];
+ if (octal_index == 2)
+ Buffer[index] = (Buffer[index] * 8) + octal[1];
+ octal_index = 0;
+ } else {
+ Buffer[index] = 0x0a;
+ skip_eol = true;
+ }
+ break;
+ case ')':
+ if (octal_index != 0) {
+ code = pdfi_unread(ctx, s, (byte *)&Buffer[index], 1);
+ if (code < 0) {
+ gs_free_object(ctx->memory, Buffer, "pdfi_read_string");
+ return code;
+ }
+ Buffer[index] = octal[0];
+ if (octal_index == 2)
+ Buffer[index] = (Buffer[index] * 8) + octal[1];
+ octal_index = 0;
+ } else {
+ if (nesting == 0) {
+ Buffer[index] = 0x00;
+ exit_loop = true;
+ } else
+ nesting--;
+ }
+ break;
+ case '\\':
+ escape = true;
+ continue;
+ case '(':
+ pdfi_set_error(ctx, 0, NULL, E_PDF_UNESCAPEDSTRING, "pdfi_read_string", NULL);
+ nesting++;
+ break;
+ default:
+ if (octal_index) {
+ if (Buffer[index] >= 0x30 && Buffer[index] <= 0x37) {
+ octal[octal_index] = Buffer[index] - 0x30;
+ if (++octal_index < 3)
+ continue;
+ Buffer[index] = (octal[0] * 64) + (octal[1] * 8) + octal[2];
+ octal_index = 0;
+ } else {
+ code = pdfi_unread(ctx, s, (byte *)&Buffer[index], 1);
+ if (code < 0) {
+ gs_free_object(ctx->memory, Buffer, "pdfi_read_string");
+ return code;
+ }
+ Buffer[index] = octal[0];
+ if (octal_index == 2)
+ Buffer[index] = (Buffer[index] * 8) + octal[1];
+ octal_index = 0;
+ }
+ }
+ break;
+ }
+ }
+
+ if (exit_loop)
+ break;
+
+ index++;
+ } while(1);
+
+ code = pdfi_object_alloc(ctx, PDF_STRING, index, (pdf_obj **)&string);
+ if (code < 0) {
+ gs_free_object(ctx->memory, Buffer, "pdfi_read_name error");
+ return code;
+ }
+ memcpy(string->data, Buffer, index);
+ string->indirect_num = indirect_num;
+ string->indirect_gen = indirect_gen;
+
+ gs_free_object(ctx->memory, Buffer, "pdfi_read_string");
+
+ if (ctx->encryption.is_encrypted && ctx->encryption.decrypt_strings) {
+ code = pdfi_decrypt_string(ctx, string);
+ if (code < 0)
+ return code;
+ }
+
+ if (ctx->args.pdfdebug) {
+ int i;
+ dmprintf(ctx->memory, " (");
+ for (i=0;i<string->length;i++)
+ dmprintf1(ctx->memory, "%c", string->data[i]);
+ dmprintf(ctx->memory, ")");
+ }
+
+ code = pdfi_push(ctx, (pdf_obj *)string);
+ if (code < 0) {
+ pdfi_free_object((pdf_obj *)string);
+ pdfi_set_error(ctx, code, NULL, 0, "pdfi_read_string", NULL);
+ }
+
+ return code;
+}
+
+int pdfi_read_dict(pdf_context *ctx, pdf_c_stream *s, uint32_t indirect_num, uint32_t indirect_gen)
+{
+ int code, depth;
+
+ code = pdfi_read_token(ctx, s, indirect_num, indirect_gen);
+ if (code < 0)
+ return code;
+ if (ctx->stack_top[-1]->type != PDF_DICT_MARK)
+ return_error(gs_error_typecheck);
+ depth = pdfi_count_stack(ctx);
+
+ do {
+ code = pdfi_read_token(ctx, s, indirect_num, indirect_gen);
+ if (code < 0)
+ return code;
+ } while(pdfi_count_stack(ctx) > depth);
+ return 0;
+}
+
+int pdfi_skip_comment(pdf_context *ctx, pdf_c_stream *s)
+{
+ byte Buffer;
+ short bytes = 0;
+
+ if (ctx->args.pdfdebug)
+ dmprintf (ctx->memory, " %%");
+
+ do {
+ bytes = pdfi_read_bytes(ctx, (byte *)&Buffer, 1, 1, s);
+ if (bytes < 0)
+ return_error(gs_error_ioerror);
+
+ if (bytes > 0) {
+ if (ctx->args.pdfdebug)
+ dmprintf1 (ctx->memory, " %c", Buffer);
+
+ if ((Buffer == 0x0A) || (Buffer == 0x0D)) {
+ break;
+ }
+ }
+ } while (bytes);
+ return 0;
+}
+
+/* This function is slightly misnamed, for some keywords we do
+ * indeed read the keyword and return a PDF_KEYWORD object, but
+ * for null, true, false and R we create an appropriate object
+ * of that type (PDF_NULL, PDF_BOOL or PDF_INDIRECT_REF)
+ * and return it instead.
+ */
+static int pdfi_read_keyword(pdf_context *ctx, pdf_c_stream *s, uint32_t indirect_num, uint32_t indirect_gen)
+{
+ byte Buffer[256];
+ unsigned short index = 0;
+ short bytes = 0;
+ int code;
+ pdf_keyword *keyword;
+
+ pdfi_skip_white(ctx, s);
+
+ do {
+ bytes = pdfi_read_bytes(ctx, (byte *)&Buffer[index], 1, 1, s);
+ if (bytes < 0)
+ return_error(gs_error_ioerror);
+
+ if (bytes > 0) {
+ if (iswhite(Buffer[index])) {
+ pdfi_unread(ctx, s, (byte *)&Buffer[index], 1);
+ break;
+ } else {
+ if (isdelimiter(Buffer[index])) {
+ pdfi_unread(ctx, s, (byte *)&Buffer[index], 1);
+ break;
+ }
+ }
+ index++;
+ }
+ } while (bytes && index < 255);
+
+ if (index >= 255 || index == 0) {
+ if (ctx->args.pdfstoponerror)
+ return_error(gs_error_syntaxerror);
+ strcpy((char *)Buffer, "KEYWORD_TOO_LONG");
+ index = 16;
+ }
+
+ /* NB The code below uses 'Buffer', not the data stored in keyword->data to compare strings */
+ Buffer[index] = 0x00;
+
+ code = pdfi_object_alloc(ctx, PDF_KEYWORD, index, (pdf_obj **)&keyword);
+ if (code < 0)
+ return code;
+
+ memcpy(keyword->data, Buffer, index);
+ pdfi_countup(keyword);
+
+ keyword->indirect_num = indirect_num;
+ keyword->indirect_gen = indirect_gen;
+
+ if (ctx->args.pdfdebug)
+ dmprintf1(ctx->memory, " %s\n", Buffer);
+
+ switch(Buffer[0]) {
+ case 'K':
+ if (keyword->length == 16 && memcmp(keyword->data, "KEYWORD_TOO_LONG", 16) == 0) {
+ keyword->key = TOKEN_INVALID_KEY;
+ }
+ break;
+ case 'R':
+ if (keyword->length == 1){
+ pdf_indirect_ref *o;
+ uint64_t obj_num;
+ uint32_t gen_num;
+
+ pdfi_countdown(keyword);
+
+ if(pdfi_count_stack(ctx) < 2) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ if(((pdf_obj *)ctx->stack_top[-1])->type != PDF_INT || ((pdf_obj *)ctx->stack_top[-2])->type != PDF_INT) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_typecheck);
+ }
+
+ gen_num = ((pdf_num *)ctx->stack_top[-1])->value.i;
+ pdfi_pop(ctx, 1);
+ obj_num = ((pdf_num *)ctx->stack_top[-1])->value.i;
+ pdfi_pop(ctx, 1);
+
+ code = pdfi_object_alloc(ctx, PDF_INDIRECT, 0, (pdf_obj **)&o);
+ if (code < 0)
+ return code;
+
+ o->ref_generation_num = gen_num;
+ o->ref_object_num = obj_num;
+ o->indirect_num = indirect_num;
+ o->indirect_gen = indirect_gen;
+
+ code = pdfi_push(ctx, (pdf_obj *)o);
+ if (code < 0)
+ pdfi_free_object((pdf_obj *)o);
+
+ return code;
+ }
+ break;
+ case 'e':
+ if (keyword->length == 9 && memcmp((const char *)Buffer, "endstream", 9) == 0)
+ keyword->key = TOKEN_ENDSTREAM;
+ else {
+ if (keyword->length == 6 && memcmp((const char *)Buffer, "endobj", 6) == 0)
+ keyword->key = TOKEN_ENDOBJ;
+ }
+ break;
+ case 'o':
+ if (keyword->length == 3 && memcmp((const char *)Buffer, "obj", 3) == 0)
+ keyword->key = TOKEN_OBJ;
+ break;
+ case 's':
+ if (keyword->length == 6 && memcmp((const char *)Buffer, "stream", 6) == 0){
+ keyword->key = TOKEN_STREAM;
+ code = pdfi_skip_eol(ctx, s);
+ if (code < 0) {
+ pdfi_countdown(keyword);
+ return code;
+ }
+ }
+ else {
+ if (keyword->length == 9 && memcmp((const char *)Buffer, "startxref", 9) == 0)
+ keyword->key = TOKEN_STARTXREF;
+ }
+ break;
+ case 't':
+ if (keyword->length == 4 && memcmp((const char *)Buffer, "true", 4) == 0) {
+ pdf_bool *o;
+
+ pdfi_countdown(keyword);
+
+ code = pdfi_object_alloc(ctx, PDF_BOOL, 0, (pdf_obj **)&o);
+ if (code < 0)
+ return code;
+
+ o->value = true;
+ o->indirect_num = indirect_num;
+ o->indirect_gen = indirect_gen;
+
+ code = pdfi_push(ctx, (pdf_obj *)o);
+ if (code < 0)
+ pdfi_free_object((pdf_obj *)o);
+ return code;
+ }
+ else {
+ if (keyword->length == 7 && memcmp((const char *)Buffer, "trailer", 7) == 0)
+ keyword->key = TOKEN_TRAILER;
+ }
+ break;
+ case 'f':
+ if (keyword->length == 5 && memcmp((const char *)Buffer, "false", 5) == 0)
+ {
+ pdf_bool *o;
+
+ pdfi_countdown(keyword);
+
+ code = pdfi_object_alloc(ctx, PDF_BOOL, 0, (pdf_obj **)&o);
+ if (code < 0)
+ return code;
+
+ o->value = false;
+ o->indirect_num = indirect_num;
+ o->indirect_gen = indirect_gen;
+
+ code = pdfi_push(ctx, (pdf_obj *)o);
+ if (code < 0)
+ pdfi_free_object((pdf_obj *)o);
+ return code;
+ }
+ break;
+ case 'n':
+ if (keyword->length == 4 && memcmp((const char *)Buffer, "null", 4) == 0){
+ pdf_obj *o;
+
+ pdfi_countdown(keyword);
+
+ code = pdfi_object_alloc(ctx, PDF_NULL, 0, &o);
+ if (code < 0)
+ return code;
+ o->indirect_num = indirect_num;
+ o->indirect_gen = indirect_gen;
+
+ code = pdfi_push(ctx, o);
+ if (code < 0)
+ pdfi_free_object((pdf_obj *)o);
+ return code;
+ }
+ break;
+ case 'x':
+ if (keyword->length == 4 && memcmp((const char *)Buffer, "xref", 4) == 0)
+ keyword->key = TOKEN_XREF;
+ break;
+ }
+
+ code = pdfi_push(ctx, (pdf_obj *)keyword);
+ pdfi_countdown(keyword);
+
+ return code;
+}
+
+/* This function reads from the given stream, at the current offset in the stream,
+ * a single PDF 'token' and returns it on the stack.
+ */
+int pdfi_read_token(pdf_context *ctx, pdf_c_stream *s, uint32_t indirect_num, uint32_t indirect_gen)
+{
+ int32_t bytes = 0;
+ char Buffer[256];
+ int code;
+
+ pdfi_skip_white(ctx, s);
+
+ bytes = pdfi_read_bytes(ctx, (byte *)Buffer, 1, 1, s);
+ if (bytes < 0)
+ return (gs_error_ioerror);
+ if (bytes == 0 && s->eof)
+ return 0;
+
+ switch(Buffer[0]) {
+ case 0x30:
+ case 0x31:
+ case 0x32:
+ case 0x33:
+ case 0x34:
+ case 0x35:
+ case 0x36:
+ case 0x37:
+ case 0x38:
+ case 0x39:
+ case '+':
+ case '-':
+ case '.':
+ pdfi_unread(ctx, s, (byte *)&Buffer[0], 1);
+ code = pdfi_read_num(ctx, s, indirect_num, indirect_gen);
+ if (code < 0)
+ return code;
+ break;
+ case '/':
+ return pdfi_read_name(ctx, s, indirect_num, indirect_gen);
+ break;
+ case '<':
+ bytes = pdfi_read_bytes(ctx, (byte *)&Buffer[1], 1, 1, s);
+ if (bytes <= 0)
+ return (gs_error_ioerror);
+ if (iswhite(Buffer[1])) {
+ code = pdfi_skip_white(ctx, s);
+ if (code < 0)
+ return code;
+ bytes = pdfi_read_bytes(ctx, (byte *)&Buffer[1], 1, 1, s);
+ }
+ if (Buffer[1] == '<') {
+ if (ctx->args.pdfdebug)
+ dmprintf (ctx->memory, " <<\n");
+ return pdfi_mark_stack(ctx, PDF_DICT_MARK);
+ } else {
+ if (Buffer[1] == '>') {
+ pdfi_unread(ctx, s, (byte *)&Buffer[1], 1);
+ return pdfi_read_hexstring(ctx, s, indirect_num, indirect_gen);
+ } else {
+ if (ishex(Buffer[1])) {
+ pdfi_unread(ctx, s, (byte *)&Buffer[1], 1);
+ return pdfi_read_hexstring(ctx, s, indirect_num, indirect_gen);
+ }
+ else
+ return_error(gs_error_syntaxerror);
+ }
+ }
+ break;
+ case '>':
+ bytes = pdfi_read_bytes(ctx, (byte *)&Buffer[1], 1, 1, s);
+ if (bytes <= 0)
+ return (gs_error_ioerror);
+ if (Buffer[1] == '>')
+ return pdfi_dict_from_stack(ctx, indirect_num, indirect_gen);
+ else {
+ pdfi_unread(ctx, s, (byte *)&Buffer[1], 1);
+ return_error(gs_error_syntaxerror);
+ }
+ break;
+ case '(':
+ return pdfi_read_string(ctx, s, indirect_num, indirect_gen);
+ break;
+ case '[':
+ if (ctx->args.pdfdebug)
+ dmprintf (ctx->memory, "[");
+ return pdfi_mark_stack(ctx, PDF_ARRAY_MARK);
+ break;
+ case ']':
+ code = pdfi_array_from_stack(ctx, indirect_num, indirect_gen);
+ if (code < 0) {
+ if (code == gs_error_VMerror || code == gs_error_ioerror || ctx->args.pdfstoponerror)
+ return code;
+ pdfi_clearstack(ctx);
+ return pdfi_read_token(ctx, s, indirect_num, indirect_gen);
+ }
+ break;
+ case '{':
+ if (ctx->args.pdfdebug)
+ dmprintf (ctx->memory, "{");
+ return pdfi_mark_stack(ctx, PDF_PROC_MARK);
+ break;
+ case '}':
+ pdfi_clear_to_mark(ctx);
+ return pdfi_read_token(ctx, s, indirect_num, indirect_gen);
+ break;
+ case '%':
+ pdfi_skip_comment(ctx, s);
+ return pdfi_read_token(ctx, s, indirect_num, indirect_gen);
+ break;
+ default:
+ if (isdelimiter(Buffer[0])) {
+ if (ctx->args.pdfstoponerror)
+ return_error(gs_error_syntaxerror);
+ return pdfi_read_token(ctx, s, indirect_num, indirect_gen);
+ }
+ pdfi_unread(ctx, s, (byte *)&Buffer[0], 1);
+ return pdfi_read_keyword(ctx, s, indirect_num, indirect_gen);
+ break;
+ }
+ return 0;
+}
+
+/* In contrast to the 'read' functions, the 'make' functions create an object with a
+ * reference count of 1. This indicates that the caller holds the reference. Thus the
+ * caller need not increment the reference count to the object, but must decrement
+ * it (pdf_countdown) before exiting.
+ */
+int pdfi_name_alloc(pdf_context *ctx, byte *n, uint32_t size, pdf_obj **o)
+{
+ int code;
+ *o = NULL;
+
+ code = pdfi_object_alloc(ctx, PDF_NAME, size, o);
+ if (code < 0)
+ return code;
+
+ memcpy(((pdf_name *)*o)->data, n, size);
+
+ return 0;
+}
+
+static char op_table_3[5][3] = {
+ "BDC", "BMC", "EMC", "SCN", "scn"
+};
+
+static char op_table_2[39][2] = {
+ "b*", "BI", "BT", "BX", "cm", "CS", "cs", "EI", "d0", "d1", "Do", "DP", "ET", "EX", "f*", "gs", "ID", "MP", "re", "RG",
+ "rg", "ri", "SC", "sc", "sh", "T*", "Tc", "Td", "TD", "Tf", "Tj", "TJ", "TL", "Tm", "Tr", "Ts", "Tw", "Tz", "W*",
+};
+
+static char op_table_1[27][1] = {
+ "b", "B", "c", "d", "f", "F", "G", "g", "h", "i", "j", "J", "K", "k", "l", "m", "n", "q", "Q", "s", "S", "v", "w", "W",
+ "y", "'", "\""
+};
+
+/* forward definition for the 'split_bogus_operator' function to use */
+static int pdfi_interpret_stream_operator(pdf_context *ctx, pdf_c_stream *source,
+ pdf_dict *stream_dict, pdf_dict *page_dict);
+
+static int search_table_3(pdf_context *ctx, unsigned char *str, pdf_keyword **key)
+{
+ int i, code = 0;
+
+ for (i = 0; i < 5; i++) {
+ if (memcmp(str, op_table_3[i], 3) == 0) {
+ code = pdfi_object_alloc(ctx, PDF_KEYWORD, 3, (pdf_obj **)key);
+ if (code < 0)
+ return code;
+ memcpy((*key)->data, str, 3);
+ (*key)->key = TOKEN_NOT_A_KEYWORD;
+ pdfi_countup(*key);
+ return 1;
+ }
+ }
+ return 0;
+}
+
+static int search_table_2(pdf_context *ctx, unsigned char *str, pdf_keyword **key)
+{
+ int i, code = 0;
+
+ for (i = 0; i < 39; i++) {
+ if (memcmp(str, op_table_2[i], 2) == 0) {
+ code = pdfi_object_alloc(ctx, PDF_KEYWORD, 2, (pdf_obj **)key);
+ if (code < 0)
+ return code;
+ memcpy((*key)->data, str, 2);
+ (*key)->key = TOKEN_NOT_A_KEYWORD;
+ pdfi_countup(*key);
+ return 1;
+ }
+ }
+ return 0;
+}
+
+static int search_table_1(pdf_context *ctx, unsigned char *str, pdf_keyword **key)
+{
+ int i, code = 0;
+
+ for (i = 0; i < 39; i++) {
+ if (memcmp(str, op_table_1[i], 1) == 0) {
+ code = pdfi_object_alloc(ctx, PDF_KEYWORD, 1, (pdf_obj **)key);
+ if (code < 0)
+ return code;
+ memcpy((*key)->data, str, 1);
+ (*key)->key = TOKEN_NOT_A_KEYWORD;
+ pdfi_countup(*key);
+ return 1;
+ }
+ }
+ return 0;
+}
+
+static int split_bogus_operator(pdf_context *ctx, pdf_c_stream *source, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code = 0;
+ pdf_keyword *keyword = (pdf_keyword *)ctx->stack_top[-1], *key1 = NULL, *key2 = NULL;
+
+ if (keyword->length > 6) {
+ /* Longer than 2 3-character operators, we only allow for up to two
+ * operators. Check to see if it includes an endstream or endobj.
+ */
+ if (memcmp(&keyword->data[keyword->length - 6], "endobj", 6) == 0) {
+ code = pdfi_object_alloc(ctx, PDF_KEYWORD, keyword->length - 6, (pdf_obj **)&key1);
+ if (code < 0)
+ goto error_exit;
+ memcpy(key1->data, keyword->data, key1->length);
+ pdfi_pop(ctx, 1);
+ pdfi_push(ctx, (pdf_obj *)key1);
+ code = pdfi_interpret_stream_operator(ctx, source, stream_dict, page_dict);
+ if (code < 0)
+ goto error_exit;
+ code = pdfi_object_alloc(ctx, PDF_KEYWORD, 6, (pdf_obj **)&key1);
+ if (code < 0)
+ goto error_exit;
+ memcpy(key1->data, "endobj", 6);
+ key1->key = TOKEN_ENDOBJ;
+ pdfi_push(ctx, (pdf_obj *)key1);
+ return 0;
+ } else {
+ if (keyword->length > 9 && memcmp(&keyword->data[keyword->length - 9], "endstream", 9) == 0) {
+ code = pdfi_object_alloc(ctx, PDF_KEYWORD, keyword->length - 9, (pdf_obj **)&key1);
+ if (code < 0)
+ goto error_exit;
+ memcpy(key1->data, keyword->data, key1->length);
+ pdfi_pop(ctx, 1);
+ pdfi_push(ctx, (pdf_obj *)key1);
+ code = pdfi_interpret_stream_operator(ctx, source, stream_dict, page_dict);
+ if (code < 0)
+ goto error_exit;
+ code = pdfi_object_alloc(ctx, PDF_KEYWORD, 9, (pdf_obj **)&key1);
+ if (code < 0)
+ goto error_exit;
+ memcpy(key1->data, "endstream", 9);
+ key1->key = TOKEN_ENDSTREAM;
+ pdfi_push(ctx, (pdf_obj *)key1);
+ return 0;
+ } else {
+ pdfi_clearstack(ctx);
+ return 0;
+ }
+ }
+ }
+
+ if (keyword->length > 3) {
+ code = search_table_3(ctx, keyword->data, &key1);
+ if (code < 0)
+ goto error_exit;
+
+ if (code > 0) {
+ switch(keyword->length - 3) {
+ case 1:
+ code = search_table_1(ctx, &keyword->data[key1->length], &key2);
+ break;
+ case 2:
+ code = search_table_1(ctx, &keyword->data[key1->length], &key2);
+ break;
+ case 3:
+ code = search_table_1(ctx, &keyword->data[key1->length], &key2);
+ break;
+ default:
+ goto error_exit;
+ }
+ }
+ if (code < 0)
+ goto error_exit;
+ if (code > 0)
+ goto match;
+ }
+ pdfi_countdown(key1);
+ pdfi_countdown(key2);
+ key1 = NULL;
+ key2 = NULL;
+
+ if (keyword->length > 5 || keyword->length < 2)
+ goto error_exit;
+
+ code = search_table_2(ctx, keyword->data, &key1);
+ if (code < 0)
+ goto error_exit;
+
+ if (code > 0) {
+ switch(keyword->length - 2) {
+ case 1:
+ code = search_table_1(ctx, &keyword->data[key1->length], &key2);
+ break;
+ case 2:
+ code = search_table_1(ctx, &keyword->data[key1->length], &key2);
+ break;
+ case 3:
+ code = search_table_1(ctx, &keyword->data[key1->length], &key2);
+ break;
+ default:
+ goto error_exit;
+ }
+ if (code < 0)
+ goto error_exit;
+ if (code > 0)
+ goto match;
+ }
+ pdfi_countdown(key1);
+ pdfi_countdown(key2);
+ key1 = NULL;
+ key2 = NULL;
+
+ if (keyword->length > 4)
+ goto error_exit;
+
+ code = search_table_1(ctx, keyword->data, &key1);
+ if (code <= 0)
+ goto error_exit;
+
+ if (code > 0) {
+ switch(keyword->length - 1) {
+ case 1:
+ code = search_table_1(ctx, &keyword->data[key1->length], &key2);
+ break;
+ case 2:
+ code = search_table_1(ctx, &keyword->data[key1->length], &key2);
+ break;
+ case 3:
+ code = search_table_1(ctx, &keyword->data[key1->length], &key2);
+ break;
+ default:
+ goto error_exit;
+ }
+ if (code <= 0)
+ goto error_exit;
+ if (code > 0)
+ goto match;
+ }
+ pdfi_countdown(key1);
+ pdfi_countdown(key2);
+ key1 = NULL;
+ key2 = NULL;
+
+match:
+ /* If we get here, we have two PDF_KEYWORD objects. We push them on the stack
+ * one at a time, and execute them.
+ */
+ pdfi_push(ctx, (pdf_obj *)key1);
+ code = pdfi_interpret_stream_operator(ctx, source, stream_dict, page_dict);
+ if (code < 0)
+ goto error_exit;
+
+ pdfi_push(ctx, (pdf_obj *)key2);
+ code = pdfi_interpret_stream_operator(ctx, source, stream_dict, page_dict);
+
+error_exit:
+ pdfi_set_error(ctx, 0, NULL, E_PDF_TOKENERROR, "split_bogus_operator", NULL);
+ pdfi_countdown(key1);
+ pdfi_countdown(key2);
+ pdfi_clearstack(ctx);
+ return code;
+}
+
+#define K1(a) (a)
+#define K2(a, b) ((a << 8) + b)
+#define K3(a, b, c) ((a << 16) + (b << 8) + c)
+
+static int pdfi_interpret_stream_operator(pdf_context *ctx, pdf_c_stream *source,
+ pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ pdf_keyword *keyword = (pdf_keyword *)ctx->stack_top[-1];
+ uint32_t op = 0;
+ int i, code = 0;
+
+ if (keyword->length > 3) {
+ /* This means we either have a corrupted or illegal operator. The most
+ * usual corruption is two concatented operators (eg QBT instead of Q BT)
+ * I plan to tackle this by trying to see if I can make two or more operators
+ * out of the mangled one. Note this will also be done below in the 'default'
+ * case where we don't recognise a keyword with 3 or fewer characters.
+ */
+ code = split_bogus_operator(ctx, source, stream_dict, page_dict);
+ if (code < 0)
+ return code;
+ if (pdfi_count_stack(ctx) > 0) {
+ keyword = (pdf_keyword *)ctx->stack_top[-1];
+ if (keyword->key != TOKEN_NOT_A_KEYWORD)
+ return REPAIRED_KEYWORD;
+ } else
+ return 0;
+ } else {
+ for (i=0;i < keyword->length;i++) {
+ op = (op << 8) + keyword->data[i];
+ }
+ switch(op) {
+ case K1('b'): /* closepath, fill, stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_b(ctx);
+ break;
+ case K1('B'): /* fill, stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_B(ctx);
+ break;
+ case K2('b','*'): /* closepath, eofill, stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_b_star(ctx);
+ break;
+ case K2('B','*'): /* eofill, stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_B_star(ctx);
+ break;
+ case K2('B','I'): /* begin inline image */
+ pdfi_pop(ctx, 1);
+ code = pdfi_BI(ctx);
+ break;
+ case K3('B','D','C'): /* begin marked content sequence with property list */
+ pdfi_pop(ctx, 1);
+ code = pdfi_op_BDC(ctx, stream_dict, page_dict);
+ break;
+ case K3('B','M','C'): /* begin marked content sequence */
+ pdfi_pop(ctx, 1);
+ code = pdfi_op_BMC(ctx);
+ break;
+ case K2('B','T'): /* begin text */
+ pdfi_pop(ctx, 1);
+ code = pdfi_BT(ctx);
+ break;
+ case K2('B','X'): /* begin compatibility section */
+ pdfi_pop(ctx, 1);
+ break;
+ case K1('c'): /* curveto */
+ pdfi_pop(ctx, 1);
+ code = pdfi_curveto(ctx);
+ break;
+ case K2('c','m'): /* concat */
+ pdfi_pop(ctx, 1);
+ code = pdfi_concat(ctx);
+ break;
+ case K2('C','S'): /* set stroke colour space */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setstrokecolor_space(ctx, stream_dict, page_dict);
+ break;
+ case K2('c','s'): /* set non-stroke colour space */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setfillcolor_space(ctx, stream_dict, page_dict);
+ break;
+ break;
+ case K1('d'): /* set dash params */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setdash(ctx);
+ break;
+ case K2('E','I'): /* end inline image */
+ pdfi_pop(ctx, 1);
+ code = pdfi_EI(ctx);
+ break;
+ case K2('d','0'): /* set type 3 font glyph width */
+ pdfi_pop(ctx, 1);
+ code = pdfi_d0(ctx);
+ break;
+ case K2('d','1'): /* set type 3 font glyph width and bounding box */
+ pdfi_pop(ctx, 1);
+ code = pdfi_d1(ctx);
+ break;
+ case K2('D','o'): /* invoke named XObject */
+ pdfi_pop(ctx, 1);
+ code = pdfi_Do(ctx, stream_dict, page_dict);
+ break;
+ case K2('D','P'): /* define marked content point with property list */
+ pdfi_pop(ctx, 1);
+ if (pdfi_count_stack(ctx) >= 2) {
+ pdfi_pop(ctx, 2);
+ } else
+ pdfi_clearstack(ctx);
+ break;
+ case K2('E','T'): /* end text */
+ pdfi_pop(ctx, 1);
+ code = pdfi_ET(ctx);
+ break;
+ case K3('E','M','C'): /* end marked content sequence */
+ pdfi_pop(ctx, 1);
+ code = pdfi_op_EMC(ctx);
+ break;
+ case K2('E','X'): /* end compatibility section */
+ pdfi_pop(ctx, 1);
+ break;
+ case K1('f'): /* fill */
+ pdfi_pop(ctx, 1);
+ code = pdfi_fill(ctx);
+ break;
+ case K1('F'): /* fill (obselete operator) */
+ pdfi_pop(ctx, 1);
+ code = pdfi_fill(ctx);
+ break;
+ case K2('f','*'): /* eofill */
+ pdfi_pop(ctx, 1);
+ code = pdfi_eofill(ctx);
+ break;
+ case K1('G'): /* setgray for stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setgraystroke(ctx);
+ break;
+ case K1('g'): /* setgray for non-stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setgrayfill(ctx);
+ break;
+ case K2('g','s'): /* set graphics state from dictionary */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setgstate(ctx, stream_dict, page_dict);
+ break;
+ case K1('h'): /* closepath */
+ pdfi_pop(ctx, 1);
+ code = pdfi_closepath(ctx);
+ break;
+ case K1('i'): /* setflat */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setflat(ctx);
+ break;
+ case K2('I','D'): /* begin inline image data */
+ pdfi_pop(ctx, 1);
+ code = pdfi_ID(ctx, stream_dict, page_dict, source);
+ break;
+ case K1('j'): /* setlinejoin */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setlinejoin(ctx);
+ break;
+ case K1('J'): /* setlinecap */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setlinecap(ctx);
+ break;
+ case K1('K'): /* setcmyk for non-stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setcmykstroke(ctx);
+ break;
+ case K1('k'): /* setcmyk for non-stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setcmykfill(ctx);
+ break;
+ case K1('l'): /* lineto */
+ pdfi_pop(ctx, 1);
+ code = pdfi_lineto(ctx);
+ break;
+ case K1('m'): /* moveto */
+ pdfi_pop(ctx, 1);
+ code = pdfi_moveto(ctx);
+ break;
+ case K1('M'): /* setmiterlimit */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setmiterlimit(ctx);
+ break;
+ case K2('M','P'): /* define marked content point */
+ pdfi_pop(ctx, 1);
+ if (pdfi_count_stack(ctx) >= 1)
+ pdfi_pop(ctx, 1);
+ break;
+ case K1('n'): /* newpath */
+ pdfi_pop(ctx, 1);
+ code = pdfi_newpath(ctx);
+ break;
+ case K1('q'): /* gsave */
+ pdfi_pop(ctx, 1);
+ code = pdfi_op_q(ctx);
+ break;
+ case K1('Q'): /* grestore */
+ pdfi_pop(ctx, 1);
+ code = pdfi_op_Q(ctx);
+ break;
+ case K1('r'): /* non-standard set rgb colour for non-stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setrgbfill_array(ctx);
+ break;
+ case K2('r','e'): /* append rectangle */
+ pdfi_pop(ctx, 1);
+ code = pdfi_rectpath(ctx);
+ break;
+ case K2('R','G'): /* set rgb colour for stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setrgbstroke(ctx);
+ break;
+ case K2('r','g'): /* set rgb colour for non-stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setrgbfill(ctx);
+ break;
+ case K2('r','i'): /* set rendering intent */
+ pdfi_pop(ctx, 1);
+ code = pdfi_ri(ctx);
+ break;
+ case K1('s'): /* closepath, stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_closepath_stroke(ctx);
+ break;
+ case K1('S'): /* stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_stroke(ctx);
+ break;
+ case K2('S','C'): /* set colour for stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setstrokecolor(ctx);
+ break;
+ case K2('s','c'): /* set colour for non-stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setfillcolor(ctx);
+ break;
+ case K3('S','C','N'): /* set special colour for stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setcolorN(ctx, stream_dict, page_dict, false);
+ break;
+ case K3('s','c','n'): /* set special colour for non-stroke */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setcolorN(ctx, stream_dict, page_dict, true);
+ break;
+ case K2('s','h'): /* fill with sahding pattern */
+ pdfi_pop(ctx, 1);
+ code = pdfi_shading(ctx, stream_dict, page_dict);
+ break;
+ case K2('T','*'): /* Move to start of next text line */
+ pdfi_pop(ctx, 1);
+ code = pdfi_T_star(ctx);
+ break;
+ case K2('T','c'): /* set character spacing */
+ pdfi_pop(ctx, 1);
+ code = pdfi_Tc(ctx);
+ break;
+ case K2('T','d'): /* move text position */
+ pdfi_pop(ctx, 1);
+ code = pdfi_Td(ctx);
+ break;
+ case K2('T','D'): /* Move text position, set leading */
+ pdfi_pop(ctx, 1);
+ code = pdfi_TD(ctx);
+ break;
+ case K2('T','f'): /* set font and size */
+ pdfi_pop(ctx, 1);
+ code = pdfi_Tf(ctx, stream_dict, page_dict);
+ break;
+ case K2('T','j'): /* show text */
+ pdfi_pop(ctx, 1);
+ code = pdfi_Tj(ctx);
+ break;
+ case K2('T','J'): /* show text with individual glyph positioning */
+ pdfi_pop(ctx, 1);
+ code = pdfi_TJ(ctx);
+ break;
+ case K2('T','L'): /* set text leading */
+ pdfi_pop(ctx, 1);
+ code = pdfi_TL(ctx);
+ break;
+ case K2('T','m'): /* set text matrix */
+ pdfi_pop(ctx, 1);
+ code = pdfi_Tm(ctx);
+ break;
+ case K2('T','r'): /* set text rendering mode */
+ pdfi_pop(ctx, 1);
+ code = pdfi_Tr(ctx);
+ break;
+ case K2('T','s'): /* set text rise */
+ pdfi_pop(ctx, 1);
+ code = pdfi_Ts(ctx);
+ break;
+ case K2('T','w'): /* set word spacing */
+ pdfi_pop(ctx, 1);
+ code = pdfi_Tw(ctx);
+ break;
+ case K2('T','z'): /* set text matrix */
+ pdfi_pop(ctx, 1);
+ code = pdfi_Tz(ctx);
+ break;
+ case K1('v'): /* append curve (initial point replicated) */
+ pdfi_pop(ctx, 1);
+ code = pdfi_v_curveto(ctx);
+ break;
+ case K1('w'): /* setlinewidth */
+ pdfi_pop(ctx, 1);
+ code = pdfi_setlinewidth(ctx);
+ break;
+ case K1('W'): /* clip */
+ pdfi_pop(ctx, 1);
+ ctx->clip_active = true;
+ ctx->do_eoclip = false;
+ break;
+ case K2('W','*'): /* eoclip */
+ pdfi_pop(ctx, 1);
+ ctx->clip_active = true;
+ ctx->do_eoclip = true;
+ break;
+ case K1('y'): /* append curve (final point replicated) */
+ pdfi_pop(ctx, 1);
+ code = pdfi_y_curveto(ctx);
+ break;
+ case K1('\''): /* move to next line and show text */
+ pdfi_pop(ctx, 1);
+ code = pdfi_singlequote(ctx);
+ break;
+ case K1('"'): /* set word and character spacing, move to next line, show text */
+ pdfi_pop(ctx, 1);
+ code = pdfi_doublequote(ctx);
+ break;
+ default:
+ code = split_bogus_operator(ctx, source, stream_dict, page_dict);
+ if (code < 0)
+ return code;
+ if (pdfi_count_stack(ctx) > 0) {
+ keyword = (pdf_keyword *)ctx->stack_top[-1];
+ if (keyword->key != TOKEN_NOT_A_KEYWORD)
+ return REPAIRED_KEYWORD;
+ }
+ break;
+ }
+ }
+ /* We use a return value of 1 to indicate a repaired keyword (a pair of operators
+ * was concatenated, and we split them up). We must not return a value > 0 from here
+ * to avoid tripping that test.
+ */
+ if (code > 0)
+ code = 0;
+ return code;
+}
+
+void local_save_stream_state(pdf_context *ctx, stream_save *local_save)
+{
+ /* copy the 'save_stream' data from the context to a local structure */
+ local_save->stream_offset = ctx->current_stream_save.stream_offset;
+ local_save->gsave_level = ctx->current_stream_save.gsave_level;
+ local_save->stack_count = ctx->current_stream_save.stack_count;
+ local_save->group_depth = ctx->current_stream_save.group_depth;
+}
+
+void cleanup_context_interpretation(pdf_context *ctx, stream_save *local_save)
+{
+ pdfi_seek(ctx, ctx->main_stream, ctx->current_stream_save.stream_offset, SEEK_SET);
+ /* The transparency group implenetation does a gsave, so the end group does a
+ * grestore. Therefore we need to do this before we check the saved gstate depth
+ */
+ if (ctx->current_stream_save.group_depth != local_save->group_depth) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_GROUPERROR, "pdfi_cleanup_context_interpretation", NULL);
+ while (ctx->current_stream_save.group_depth > local_save->group_depth)
+ pdfi_trans_end_group(ctx);
+ }
+ if (ctx->pgs->level > ctx->current_stream_save.gsave_level)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_TOOMANYq, "pdfi_cleanup_context_interpretation", NULL);
+ if (pdfi_count_stack(ctx) > ctx->current_stream_save.stack_count)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_STACKGARBAGE, "pdfi_cleanup_context_interpretation", NULL);
+ while (ctx->pgs->level > ctx->current_stream_save.gsave_level)
+ pdfi_grestore(ctx);
+ pdfi_clearstack(ctx);
+}
+
+void local_restore_stream_state(pdf_context *ctx, stream_save *local_save)
+{
+ /* Put the entries stored in the context back to what they were on entry
+ * We shouldn't really need to do this, the cleanup above should mean all the
+ * entries are properly reset.
+ */
+ ctx->current_stream_save.stream_offset = local_save->stream_offset;
+ ctx->current_stream_save.gsave_level = local_save->gsave_level;
+ ctx->current_stream_save.stack_count = local_save->stack_count;
+ ctx->current_stream_save.group_depth = local_save->group_depth;
+}
+
+void initialise_stream_save(pdf_context *ctx)
+{
+ /* Set up the values in the context to the current values */
+ ctx->current_stream_save.stream_offset = pdfi_tell(ctx->main_stream);
+ ctx->current_stream_save.gsave_level = ctx->pgs->level;
+ ctx->current_stream_save.stack_count = pdfi_count_total_stack(ctx);
+}
+
+static int setup_stream_DefaultSpaces(pdf_context *ctx, pdf_dict *stream_dict)
+{
+ int code = 0;
+ pdf_dict *resources_dict = NULL, *colorspaces_dict = NULL;
+ pdf_obj *DefaultSpace = NULL;
+
+ /* Create any required DefaultGray, DefaultRGB or DefaultCMYK
+ * spaces.
+ */
+
+ if (ctx->args.NOSUBSTDEVICECOLORS)
+ return 0;
+
+ code = pdfi_dict_knownget(ctx, stream_dict, "Resources", (pdf_obj **)&resources_dict);
+ if (code > 0) {
+ code = pdfi_dict_knownget(ctx, resources_dict, "ColorSpace", (pdf_obj **)&colorspaces_dict);
+ if (code > 0) {
+ code = pdfi_dict_knownget(ctx, colorspaces_dict, "DefaultGray", &DefaultSpace);
+ if (code > 0) {
+ gs_color_space *pcs;
+ code = pdfi_create_colorspace(ctx, DefaultSpace, NULL, stream_dict, &pcs, false);
+ /* If any given Default* space fails simply ignore it, we wil then use the Device
+ * space (or page level Default) instead, this is as per the spec.
+ */
+ if (code >= 0) {
+ if (ctx->page.DefaultGray_cs)
+ rc_decrement_only(ctx->page.DefaultGray_cs, "setup_stream_DefaultSpaces");
+ ctx->page.DefaultGray_cs = pcs;
+ pdfi_set_colour_callback(pcs, ctx, NULL);
+ }
+ }
+ pdfi_countdown(DefaultSpace);
+ DefaultSpace = NULL;
+ code = pdfi_dict_knownget(ctx, colorspaces_dict, "DefaultRGB", &DefaultSpace);
+ if (code > 0) {
+ gs_color_space *pcs;
+ code = pdfi_create_colorspace(ctx, DefaultSpace, NULL, stream_dict, &pcs, false);
+ /* If any given Default* space fails simply ignore it, we wil then use the Device
+ * space (or page level Default) instead, this is as per the spec.
+ */
+ if (code >= 0) {
+ if (ctx->page.DefaultRGB_cs)
+ rc_decrement_only(ctx->page.DefaultRGB_cs, "setup_stream_DefaultSpaces");
+ ctx->page.DefaultRGB_cs = pcs;
+ pdfi_set_colour_callback(pcs, ctx, NULL);
+ }
+ }
+ pdfi_countdown(DefaultSpace);
+ DefaultSpace = NULL;
+ code = pdfi_dict_knownget(ctx, colorspaces_dict, "DefaultCMYK", &DefaultSpace);
+ if (code > 0) {
+ gs_color_space *pcs;
+ code = pdfi_create_colorspace(ctx, DefaultSpace, NULL, stream_dict, &pcs, false);
+ /* If any given Default* space fails simply ignore it, we wil then use the Device
+ * space (or page level Default) instead, this is as per the spec.
+ */
+ if (code >= 0) {
+ if (ctx->page.DefaultCMYK_cs)
+ rc_decrement_only(ctx->page.DefaultCMYK_cs, "setup_stream_DefaultSpaces");
+ ctx->page.DefaultCMYK_cs = pcs;
+ pdfi_set_colour_callback(pcs, ctx, NULL);
+ }
+ }
+ pdfi_countdown(DefaultSpace);
+ DefaultSpace = NULL;
+ }
+ }
+
+ pdfi_countdown(DefaultSpace);
+ pdfi_countdown(resources_dict);
+ pdfi_countdown(colorspaces_dict);
+ return 0;
+}
+
+/* Run a stream in a sub-context (saves/restores DefaultQState) */
+int pdfi_run_context(pdf_context *ctx, pdf_stream *stream_obj,
+ pdf_dict *page_dict, bool stoponerror, const char *desc)
+{
+ int code;
+ gs_gstate *DefaultQState;
+ /* Save any existing Default* colour spaces */
+ gs_color_space *PageDefaultGray = ctx->page.DefaultGray_cs;
+ gs_color_space *PageDefaultRGB = ctx->page.DefaultRGB_cs;
+ gs_color_space *PageDefaultCMYK = ctx->page.DefaultCMYK_cs;
+
+ /* increment their reference counts because we took a new reference to each */
+ rc_increment(ctx->page.DefaultGray_cs);
+ rc_increment(ctx->page.DefaultRGB_cs);
+ rc_increment(ctx->page.DefaultCMYK_cs);
+
+#if DEBUG_CONTEXT
+ dbgmprintf(ctx->memory, "pdfi_run_context BEGIN\n");
+#endif
+ /* If the stream has any Default* colour spaces, replace the page level ones.
+ * This will derement the reference counts to the current spaces if they are replaced.
+ */
+ setup_stream_DefaultSpaces(ctx, stream_obj->stream_dict);
+
+ pdfi_copy_DefaultQState(ctx, &DefaultQState);
+ pdfi_set_DefaultQState(ctx, ctx->pgs);
+ code = pdfi_interpret_inner_content_stream(ctx, stream_obj, page_dict, stoponerror, desc);
+ pdfi_restore_DefaultQState(ctx, &DefaultQState);
+
+ /* Count down any Default* colour spaces */
+ rc_decrement(ctx->page.DefaultGray_cs, "pdfi_run_context");
+ rc_decrement(ctx->page.DefaultRGB_cs, "pdfi_run_context");
+ rc_decrement(ctx->page.DefaultCMYK_cs, "pdfi_run_context");
+
+ /* And restore the page level ones (if any) */
+ ctx->page.DefaultGray_cs = PageDefaultGray;
+ ctx->page.DefaultRGB_cs = PageDefaultRGB;
+ ctx->page.DefaultCMYK_cs = PageDefaultCMYK;
+#if DEBUG_CONTEXT
+ dbgmprintf(ctx->memory, "pdfi_run_context END\n");
+#endif
+ return code;
+}
+
+
+/* Interpret a sub-content stream, with some handling of error recovery, clearing stack, etc.
+ * This temporarily turns on pdfstoponerror if requested.
+ * It will make sure the stack is cleared and the gstate is matched.
+ */
+static int
+pdfi_interpret_inner_content(pdf_context *ctx, pdf_c_stream *content_stream, pdf_stream *stream_obj,
+ pdf_dict *page_dict, bool stoponerror, const char *desc)
+{
+ int code = 0;
+ bool saved_stoponerror = ctx->args.pdfstoponerror;
+ stream_save local_entry_save;
+
+ local_save_stream_state(ctx, &local_entry_save);
+ initialise_stream_save(ctx);
+
+ /* This causes several files to render 'incorrectly', even though they are in some sense
+ * invalid. It doesn't seem to provide any benefits so I have, for now, removed it. If
+ * there is a good reason for it we can put it back again.
+ * FIXME - either restore or remove these lines
+ * /tests_private/pdf/PDF_2.0_FTS/fts_23_2310.pdf
+ * /tests_private/pdf/PDF_2.0_FTS/fts_23_2311.pdf
+ * /tests_private/pdf/PDF_2.0_FTS/fts_23_2312.pdf
+ * /tests_private/pdf/sumatra/recursive_colorspace.pdf
+ * /tests_private/pdf/uploads/Bug696410.pdf
+ * /tests_private/pdf/sumatra/1900_-_cairo_transparency_inefficiency.pdf (with pdfwrite)
+ */
+#if 0
+ /* Stop on error in substream, and also be prepared to clean up the stack */
+ if (stoponerror)
+ ctx->args.pdfstoponerror = true;
+#endif
+
+#if DEBUG_CONTEXT
+ dbgmprintf1(ctx->memory, "BEGIN %s stream\n", desc);
+#endif
+ code = pdfi_interpret_content_stream(ctx, content_stream, stream_obj, page_dict);
+#if DEBUG_CONTEXT
+ dbgmprintf1(ctx->memory, "END %s stream\n", desc);
+#endif
+
+ if (code < 0)
+ dbgmprintf1(ctx->memory, "ERROR: inner_stream: code %d when rendering stream\n", code);
+
+ ctx->args.pdfstoponerror = saved_stoponerror;
+
+ /* Put our state back the way it was on entry */
+#if PROBE_STREAMS
+ if (ctx->pgs->level > ctx->current_stream_save.gsave_level ||
+ pdfi_count_stack(ctx) > ctx->current_stream_save.stack_count)
+ code = ((pdf_context *)0)->first_page;
+#endif
+
+ cleanup_context_interpretation(ctx, &local_entry_save);
+ local_restore_stream_state(ctx, &local_entry_save);
+ if (!ctx->args.pdfstoponerror)
+ code = 0;
+ return code;
+}
+
+/* Interpret inner content from a buffer
+ */
+int
+pdfi_interpret_inner_content_buffer(pdf_context *ctx, byte *content_data,
+ uint32_t content_length,
+ pdf_dict *stream_dict, pdf_dict *page_dict,
+ bool stoponerror, const char *desc)
+{
+ int code = 0;
+ pdf_c_stream *stream = NULL;
+ pdf_stream *stream_obj = NULL;
+
+ code = pdfi_open_memory_stream_from_memory(ctx, content_length,
+ content_data, &stream, true);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_obj_dict_to_stream(ctx, stream_dict, &stream_obj, false);
+ if (code < 0)
+ return code;
+
+ /* NOTE: stream gets closed in here */
+ code = pdfi_interpret_inner_content(ctx, stream, stream_obj, page_dict, stoponerror, desc);
+ pdfi_countdown(stream_obj);
+ exit:
+ return code;
+}
+
+/* Interpret inner content from a C string
+ */
+int
+pdfi_interpret_inner_content_c_string(pdf_context *ctx, char *content_string,
+ pdf_dict *stream_dict, pdf_dict *page_dict,
+ bool stoponerror, const char *desc)
+{
+ uint32_t length = (uint32_t)strlen(content_string);
+ bool decrypt_strings;
+ int code;
+
+
+ /* Underlying buffer limit is uint32, so handle the extremely unlikely case that
+ * our string is too big.
+ */
+ if (length != strlen(content_string))
+ return_error(gs_error_limitcheck);
+
+ /* Since this is a constructed string content, not part of the file, it can never
+ * be encrypted. So disable decryption during this call.
+ */
+ decrypt_strings = ctx->encryption.decrypt_strings;
+ ctx->encryption.decrypt_strings = false;
+ code = pdfi_interpret_inner_content_buffer(ctx, (byte *)content_string, length,
+ stream_dict, page_dict, stoponerror, desc);
+ ctx->encryption.decrypt_strings = decrypt_strings;
+
+ return code;
+}
+
+/* Interpret inner content from a string
+ */
+int
+pdfi_interpret_inner_content_string(pdf_context *ctx, pdf_string *content_string,
+ pdf_dict *stream_dict, pdf_dict *page_dict,
+ bool stoponerror, const char *desc)
+{
+ return pdfi_interpret_inner_content_buffer(ctx, content_string->data, content_string->length,
+ stream_dict, page_dict, stoponerror, desc);
+}
+
+/* Interpret inner content from a stream_dict
+ */
+int
+pdfi_interpret_inner_content_stream(pdf_context *ctx, pdf_stream *stream_obj,
+ pdf_dict *page_dict, bool stoponerror, const char *desc)
+{
+ return pdfi_interpret_inner_content(ctx, NULL, stream_obj, page_dict, stoponerror, desc);
+}
+
+/*
+ * Interpret a content stream.
+ * content_stream -- content to parse. If NULL, get it from the stream_dict
+ * stream_dict -- dict containing the stream
+ */
+int
+pdfi_interpret_content_stream(pdf_context *ctx, pdf_c_stream *content_stream,
+ pdf_stream *stream_obj, pdf_dict *page_dict)
+{
+ int code;
+ pdf_c_stream *stream;
+ pdf_keyword *keyword;
+
+ if (content_stream != NULL) {
+ stream = content_stream;
+ } else {
+ code = pdfi_seek(ctx, ctx->main_stream, pdfi_stream_offset(ctx, stream_obj), SEEK_SET);
+ if (code < 0)
+ return code;
+
+ code = pdfi_filter(ctx, stream_obj, ctx->main_stream, &stream, false);
+ if (code < 0)
+ return code;
+ }
+
+ pdfi_set_stream_parent(ctx, stream_obj, ctx->current_stream);
+ ctx->current_stream = stream_obj;
+
+ do {
+ code = pdfi_read_token(ctx, stream, stream_obj->object_num, stream_obj->generation_num);
+ if (code < 0) {
+ if (code == gs_error_ioerror || code == gs_error_VMerror || ctx->args.pdfstoponerror) {
+ if (code == gs_error_ioerror) {
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADSTREAM, "pdfi_interpret_content_stream", (char *)"**** Error reading a content stream. The page may be incomplete");
+ } else if (code == gs_error_VMerror) {
+ pdfi_set_error(ctx, 0, NULL, E_PDF_OUTOFMEMORY, "pdfi_interpret_content_stream", (char *)"**** Error ran out of memory reading a content stream. The page may be incomplete");
+ }
+ goto exit;
+ }
+ continue;
+ }
+
+ if (pdfi_count_stack(ctx) <= 0) {
+ if(stream->eof == true)
+ break;
+ }
+
+ if (ctx->stack_top[-1]->type == PDF_KEYWORD) {
+repaired_keyword:
+ keyword = (pdf_keyword *)ctx->stack_top[-1];
+
+ switch(keyword->key) {
+ case TOKEN_ENDSTREAM:
+ pdfi_pop(ctx,1);
+ goto exit;
+ break;
+ case TOKEN_ENDOBJ:
+ pdfi_clearstack(ctx);
+ pdfi_set_error(ctx, 0, NULL, E_PDF_MISSINGENDSTREAM, "pdfi_interpret_content_stream", NULL);
+ if (ctx->args.pdfstoponerror)
+ code = gs_note_error(gs_error_syntaxerror);
+ goto exit;
+ break;
+ case TOKEN_NOT_A_KEYWORD:
+ {
+ pdf_dict *stream_dict = NULL;
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)stream_obj, &stream_dict);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_interpret_stream_operator(ctx, stream, stream_dict, page_dict);
+ if (code == REPAIRED_KEYWORD)
+ goto repaired_keyword;
+
+ if (code < 0) {
+ pdfi_set_error(ctx, code, NULL, E_PDF_TOKENERROR, "pdf_interpret_content_stream", NULL);
+ if (ctx->args.pdfstoponerror) {
+ pdfi_clearstack(ctx);
+ goto exit;
+ }
+ }
+ }
+ break;
+ case TOKEN_INVALID_KEY:
+ pdfi_set_error(ctx, 0, NULL, E_PDF_KEYWORDTOOLONG, "pdfi_interpret_content_stream", NULL);
+ pdfi_clearstack(ctx);
+ break;
+ default:
+ pdfi_set_error(ctx, 0, NULL, E_PDF_MISSINGENDSTREAM, "pdfi_interpret_content_stream", NULL);
+ pdfi_clearstack(ctx);
+ break;
+ }
+ }
+ if(stream->eof == true)
+ break;
+ }while(1);
+
+exit:
+ ctx->current_stream = pdfi_stream_parent(ctx, stream_obj);
+ pdfi_clear_stream_parent(ctx, stream_obj);
+ pdfi_close_file(ctx, stream);
+ return code;
+}
diff --git a/pdf/pdf_int.h b/pdf/pdf_int.h
new file mode 100644
index 00000000..c841fc9f
--- /dev/null
+++ b/pdf/pdf_int.h
@@ -0,0 +1,49 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+#ifndef PDF_INTERPRETER
+#define PDF_INTERPRETER
+
+#include "ghostpdf.h"
+#include "pdf_types.h"
+
+
+int pdfi_skip_white(pdf_context *ctx, pdf_c_stream *s);
+int pdfi_skip_eol(pdf_context *ctx, pdf_c_stream *s);
+int pdfi_skip_comment(pdf_context *ctx, pdf_c_stream *s);
+int pdfi_read_token(pdf_context *ctx, pdf_c_stream *s, uint32_t indirect_num, uint32_t indirect_gen);
+
+int pdfi_name_alloc(pdf_context *ctx, byte *key, uint32_t size, pdf_obj **o);
+
+int pdfi_read_dict(pdf_context *ctx, pdf_c_stream *s, uint32_t indirect_num, uint32_t indirect_gen);
+
+void local_save_stream_state(pdf_context *ctx, stream_save *local_save);
+void local_restore_stream_state(pdf_context *ctx, stream_save *local_save);
+void cleanup_context_interpretation(pdf_context *ctx, stream_save *local_save);
+void initialise_stream_save(pdf_context *ctx);
+int pdfi_run_context(pdf_context *ctx, pdf_stream *stream_obj, pdf_dict *page_dict, bool stoponerror, const char *desc);
+int pdfi_interpret_inner_content_buffer(pdf_context *ctx, byte *content_data, uint32_t content_length,
+ pdf_dict *stream_dict, pdf_dict *page_dict,
+ bool stoponerror, const char *desc);
+int pdfi_interpret_inner_content_c_string(pdf_context *ctx, char *content_string,
+ pdf_dict *stream_dict, pdf_dict *page_dict,
+ bool stoponerror, const char *desc);
+int pdfi_interpret_inner_content_string(pdf_context *ctx, pdf_string *content_string,
+ pdf_dict *stream_dict, pdf_dict *page_dict,
+ bool stoponerror, const char *desc);
+int pdfi_interpret_inner_content_stream(pdf_context *ctx, pdf_stream *stream_obj, pdf_dict *page_dict, bool stoponerror, const char *desc);
+int pdfi_interpret_content_stream(pdf_context *ctx, pdf_c_stream *content_stream, pdf_stream *stream_obj, pdf_dict *page_dict);
+
+#endif
diff --git a/pdf/pdf_loop_detect.c b/pdf/pdf_loop_detect.c
new file mode 100644
index 00000000..7d08b182
--- /dev/null
+++ b/pdf/pdf_loop_detect.c
@@ -0,0 +1,127 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* code for handling circular references */
+
+#include "pdf_int.h"
+#include "pdf_loop_detect.h"
+
+static int pdfi_init_loop_detector(pdf_context *ctx)
+{
+ if (ctx->loop_detection) {
+ dbgmprintf(ctx->memory, "Attempt to initialise loop detector while one is in operation\n");
+ return_error(gs_error_unknownerror);
+ }
+
+ ctx->loop_detection = (uint64_t *)gs_alloc_bytes(ctx->memory, INITIAL_LOOP_TRACKER_SIZE * sizeof (uint64_t), "allocate loop tracking array");
+ if (ctx->loop_detection == NULL)
+ return_error(gs_error_VMerror);
+
+ ctx->loop_detection_entries = 0;
+ ctx->loop_detection_size = INITIAL_LOOP_TRACKER_SIZE;
+ return 0;
+}
+
+static int pdfi_free_loop_detector(pdf_context *ctx)
+{
+ if (ctx->loop_detection == NULL) {
+ dbgmprintf(ctx->memory, "Attempt to free loop detector without initialising it\n");
+ return 0;
+ }
+ if (ctx->loop_detection != NULL)
+ gs_free_object(ctx->memory, ctx->loop_detection, "Free array for loop tracking");
+ ctx->loop_detection_entries = 0;
+ ctx->loop_detection_size = 0;
+ ctx->loop_detection = NULL;
+
+ return 0;
+}
+
+int pdfi_loop_detector_add_object(pdf_context *ctx, uint64_t object)
+{
+ if (ctx->loop_detection == NULL) {
+ dbgmprintf(ctx->memory, "Attempt to use loop detector without initialising it\n");
+ return 0;
+ }
+
+ if (ctx->loop_detection_entries == ctx->loop_detection_size) {
+ uint64_t *New;
+
+ New = (uint64_t *)gs_alloc_bytes(ctx->memory, (ctx->loop_detection_size + INITIAL_LOOP_TRACKER_SIZE) * sizeof (uint64_t), "re-allocate loop tracking array");
+ if (New == NULL) {
+ return_error(gs_error_VMerror);
+ }
+ memcpy(New, ctx->loop_detection, ctx->loop_detection_entries * sizeof(uint64_t));
+ gs_free_object(ctx->memory, ctx->loop_detection, "Free array for loop tracking");
+ ctx->loop_detection_size += INITIAL_LOOP_TRACKER_SIZE;
+ ctx->loop_detection = New;
+ }
+ ctx->loop_detection[ctx->loop_detection_entries++] = object;
+ return 0;
+}
+
+bool pdfi_loop_detector_check_object(pdf_context *ctx, uint64_t object)
+{
+ int i = 0;
+
+ if (ctx->loop_detection == NULL) {
+ dbgmprintf(ctx->memory, "Attempt to use loop detector without initialising it\n");
+ return 0;
+ }
+
+ for (i=0;i < ctx->loop_detection_entries;i++) {
+ if (ctx->loop_detection[i] == object) {
+ char info_string[256];
+ gs_sprintf(info_string, "Error! circular reference to object %"PRIu64" detected.\n", object);
+ pdfi_set_error(ctx, 0, NULL, E_PDF_CIRCULARREF, "pdfi_loop_detector_check_object", info_string);
+ return true;
+ }
+ }
+ return false;
+}
+
+int pdfi_loop_detector_mark(pdf_context *ctx)
+{
+ int code = 0;
+
+ if (ctx->loop_detection == NULL) {
+ code = pdfi_init_loop_detector(ctx);
+ if (code < 0)
+ return code;
+ }
+
+ return pdfi_loop_detector_add_object(ctx, 0);
+}
+
+int pdfi_loop_detector_cleartomark(pdf_context *ctx)
+{
+ if (ctx->loop_detection == NULL) {
+ dbgmprintf(ctx->memory, "Attempt to use loop detector without initialising it\n");
+ return 0;
+ }
+
+ while (ctx->loop_detection[--ctx->loop_detection_entries] != 0) {
+ ctx->loop_detection[ctx->loop_detection_entries] = 0;
+ }
+ /* FIXME - potential optimisation
+ * Instead of freeing the loop detection array every tiome we are done with it
+ * and then reallocating a new one next time we need one, we could just keep
+ * the existing (empty) array. I suspect this would provide a small performance
+ * improvement.
+ */
+ if (ctx->loop_detection_entries == 0)
+ pdfi_free_loop_detector(ctx);
+ return 0;
+}
diff --git a/pdf/pdf_loop_detect.h b/pdf/pdf_loop_detect.h
new file mode 100644
index 00000000..1b727c92
--- /dev/null
+++ b/pdf/pdf_loop_detect.h
@@ -0,0 +1,38 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* We handle circular references (loops) in the Pages tree or Resources as follows;
+ * When we want to check for loops, we start up the loop detector
+ * This stores an array of object numbers in the context
+ * Every time we dereference an object, if the loop detector is present, pdf_dereference_object
+ * checks to see if the object its asked to dereference is in the array. If it is,
+ * we return an error. Ohterwise, when we finish creating the dereferenced object,
+ * we add its number to the array.
+ * Now its possible for the same object to be referenced in different branches of a tree
+ * and this simple detection would cause a problem. So we define a 'mark' in the array.
+ * We use object number 0 for this since that is, by definition, always free.
+ * When we start checking a branch, we 'mark' the array, and when we've finished the branch
+ * we 'cleartomark'. Then if we find we are dereferencing the same object again we won't
+ * produce a spurious error.
+ */
+#ifndef PDF_LOOP_DETECTOR
+#define PDF_LOOP_DETECTOR
+
+int pdfi_loop_detector_add_object(pdf_context *ctx, uint64_t object);
+bool pdfi_loop_detector_check_object(pdf_context *ctx, uint64_t object);
+int pdfi_loop_detector_mark(pdf_context *ctx);
+int pdfi_loop_detector_cleartomark(pdf_context *ctx);
+
+#endif
diff --git a/pdf/pdf_mark.c b/pdf/pdf_mark.c
new file mode 100644
index 00000000..4f678f10
--- /dev/null
+++ b/pdf/pdf_mark.c
@@ -0,0 +1,1084 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* pdfmark handling for the PDF interpreter */
+
+#include "pdf_int.h"
+#include "pdf_stack.h"
+#include "pdf_file.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_loop_detect.h"
+#include "pdf_mark.h"
+#include "pdf_obj.h"
+#include "pdf_misc.h"
+#include "pdf_page.h"
+#include "pdf_deref.h"
+
+#include "gscoord.h" /* For gs_currentmatrix */
+
+static int pdfi_mark_setparam_obj(pdf_context *ctx, pdf_obj *obj, gs_param_string *entry)
+{
+ int code = 0;
+ byte *data = NULL;
+ int size = 0;
+
+ code = pdfi_obj_to_string(ctx, obj, &data, &size);
+ if (code < 0)
+ return code;
+ entry->data = data;
+ entry->size = size;
+ entry->persistent = false;
+ return 0;
+}
+
+static int pdfi_mark_setparam_pair(pdf_context *ctx, pdf_name *Key, pdf_obj *Value,
+ gs_param_string *entry)
+{
+ int code = 0;
+
+ /* Handle the Key */
+ if (Key->type != PDF_NAME) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+
+ code = pdfi_mark_setparam_obj(ctx, (pdf_obj *)Key, entry);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_mark_setparam_obj(ctx, Value, entry+1);
+ if (code < 0)
+ goto exit;
+
+ exit:
+ return code;
+}
+
+
+/* Note: this isn't part of the obj_to_string() stuff */
+static int pdfi_mark_ctm_str(pdf_context *ctx, gs_matrix *ctm, byte **data, int *len)
+{
+ int size = 100;
+ char *buf;
+
+ buf = (char *)gs_alloc_bytes(ctx->memory, size, "pdfi_mark_ctm_str(data)");
+ if (buf == NULL)
+ return_error(gs_error_VMerror);
+ snprintf(buf, size, "[%.4f %.4f %.4f %.4f %.4f %.4f]",
+ ctm->xx, ctm->xy, ctm->yx, ctm->yy, ctm->tx, ctm->ty);
+ *data = (byte *)buf;
+ *len = strlen(buf);
+ return 0;
+}
+
+/* Write an string array command to the device (e.g. pdfmark) */
+static int pdfi_mark_write_array(pdf_context *ctx, gs_param_string_array *array_list, const char *command)
+{
+ gs_c_param_list list;
+ int code;
+
+ /* Set the list to writeable, and initialise it */
+ gs_c_param_list_write(&list, ctx->memory);
+ /* We don't want keys to be persistent, as we are going to throw
+ * away our array, force them to be copied
+ */
+ gs_param_list_set_persistent_keys((gs_param_list *) &list, false);
+
+ /* Make really sure the list is writable, but don't initialise it */
+ gs_c_param_list_write_more(&list);
+
+ /* Add the param string array to the list */
+ code = param_write_string_array((gs_param_list *)&list, command, array_list);
+ if (code < 0)
+ return code;
+
+ /* Set the param list back to readable, so putceviceparams can readit (mad...) */
+ gs_c_param_list_read(&list);
+
+ /* and set the actual device parameters */
+ code = gs_putdeviceparams(ctx->pgs->device, (gs_param_list *)&list);
+
+ gs_c_param_list_release(&list);
+
+ return code;
+}
+
+/* Write an string array command to the device (e.g. pdfmark) */
+static int pdfi_mark_write_string(pdf_context *ctx, gs_param_string *param_string, const char *command)
+{
+ gs_c_param_list list;
+ int code;
+
+ /* Set the list to writeable, and initialise it */
+ gs_c_param_list_write(&list, ctx->memory);
+ /* We don't want keys to be persistent, as we are going to throw
+ * away our array, force them to be copied
+ */
+ gs_param_list_set_persistent_keys((gs_param_list *) &list, false);
+
+ /* Make really sure the list is writable, but don't initialise it */
+ gs_c_param_list_write_more(&list);
+
+ /* Add the param string array to the list */
+ code = param_write_string((gs_param_list *)&list, command, param_string);
+ if (code < 0)
+ return code;
+
+ /* Set the param list back to readable, so putceviceparams can readit (mad...) */
+ gs_c_param_list_read(&list);
+
+ /* and set the actual device parameters */
+ code = gs_putdeviceparams(ctx->pgs->device, (gs_param_list *)&list);
+
+ gs_c_param_list_release(&list);
+
+ return code;
+}
+
+/* Apparently the strings to pass to the device are:
+ key1 val1 .... keyN valN CTM "ANN"
+ CTM is (for example) "[1.0 0 0 1.0 0 0]"
+
+ This takes an optional 'label' argument which can be NULL.
+
+ the /pdfmark command has this array of strings as a parameter, i.e.
+ [ 'label' key1 val1 .... keyN valN CTM "ANN" ] /pdfmark
+
+ Apparently the "type" doesn't have a leading "/" but the other names in the
+ keys do need the "/"
+
+ See plparams.c/process_pdfmark()
+*/
+static int pdfi_mark_from_dict_withlabel(pdf_context *ctx, pdf_indirect_ref *label,
+ pdf_dict *dict, gs_matrix *ctm, const char *type)
+{
+ int code = 0;
+ int size;
+ uint64_t dictsize;
+ uint64_t index;
+ uint64_t keynum = 0;
+ int i;
+ pdf_name *Key = NULL;
+ pdf_obj *Value = NULL;
+ pdf_obj *tempobj = NULL;
+ gs_param_string *parray = NULL;
+ gs_param_string_array array_list;
+ byte *ctm_data = NULL;
+ int ctm_len;
+ gs_matrix ctm_placeholder;
+ int offset = 0;
+
+ /* If ctm not provided, make a placeholder */
+ if (!ctm) {
+ gs_currentmatrix(ctx->pgs, &ctm_placeholder);
+ ctm = &ctm_placeholder;
+ }
+
+ dictsize = pdfi_dict_entries(dict);
+ size = dictsize*2 + 2; /* pairs + CTM + type */
+ if (label)
+ size += 1;
+
+ parray = (gs_param_string *)gs_alloc_bytes(ctx->memory, size*sizeof(gs_param_string),
+ "pdfi_mark_from_dict(parray)");
+ if (parray == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto exit;
+ }
+ memset(parray, 0, size*sizeof(gs_param_string));
+
+ if (label) {
+ code = pdfi_mark_setparam_obj(ctx, (pdf_obj *)label, parray+0);
+ offset += 1;
+ }
+
+ /* Get each (key,val) pair from dict and setup param for it */
+ if (dictsize > 0) {
+ code = pdfi_dict_key_first(ctx, dict, (pdf_obj **)&Key, &index);
+ while (code >= 0) {
+ code = pdfi_dict_get_no_deref(ctx, dict, Key, &Value);
+ if (code < 0) goto exit;
+
+ code = pdfi_mark_setparam_pair(ctx, Key, Value, parray+offset+(keynum*2));
+ if (code < 0) goto exit;
+
+ pdfi_countdown(Key);
+ Key = NULL;
+ pdfi_countdown(Value);
+ Value = NULL;
+ pdfi_countdown(tempobj);
+ tempobj = NULL;
+
+ code = pdfi_dict_key_next(ctx, dict, (pdf_obj **)&Key, &index);
+ if (code == gs_error_undefined) {
+ code = 0;
+ break;
+ }
+ keynum ++;
+ }
+ }
+ if (code < 0) goto exit;
+
+ /* CTM */
+ code = pdfi_mark_ctm_str(ctx, ctm, &ctm_data, &ctm_len);
+ if (code < 0) goto exit;
+ parray[size-2].data = ctm_data;
+ parray[size-2].size = ctm_len;
+
+ /* Type (e.g. ANN, DOCINFO) */
+ parray[size-1].data = (const byte *)type;
+ parray[size-1].size = strlen(type);
+
+ array_list.data = parray;
+ array_list.persistent = false;
+ array_list.size = size;
+
+ code = pdfi_mark_write_array(ctx, &array_list, "pdfmark");
+
+ exit:
+ pdfi_countdown(Key);
+ pdfi_countdown(Value);
+ pdfi_countdown(tempobj);
+ if (parray != NULL) {
+ /* Free the param data except the last two which are handled separately */
+ for (i=0; i<size-2; i++) {
+ if (parray[i].data)
+ gs_free_object(ctx->memory, (byte *)parray[i].data, "pdfi_mark_from_dict(parray)");
+ }
+ }
+ if (ctm_data)
+ gs_free_object(ctx->memory, ctm_data, "pdfi_mark_from_dict(ctm_data)");
+ gs_free_object(ctx->memory, parray, "pdfi_mark_from_dict(parray)");
+ return code;
+}
+
+/* Do a pdfmark from a dictionary */
+int pdfi_mark_from_dict(pdf_context *ctx, pdf_dict *dict, gs_matrix *ctm, const char *type)
+{
+ return pdfi_mark_from_dict_withlabel(ctx, NULL, dict, ctm, type);
+}
+
+/* Does a pdfmark, from a c-array of pdf_obj's
+ * This will put in a dummy ctm if none provided
+ */
+static int pdfi_mark_from_objarray(pdf_context *ctx, pdf_obj **objarray, int len,
+ gs_matrix *ctm, const char *type)
+{
+ int code = 0;
+ int size;
+ gs_param_string *parray = NULL;
+ gs_param_string_array array_list;
+ byte *ctm_data = NULL;
+ int ctm_len;
+ gs_matrix ctm_placeholder;
+ int i;
+
+ /* If ctm not provided, make a placeholder */
+ if (!ctm) {
+ gs_currentmatrix(ctx->pgs, &ctm_placeholder);
+ ctm = &ctm_placeholder;
+ }
+
+ size = len + 2; /* data + CTM + type */
+
+ parray = (gs_param_string *)gs_alloc_bytes(ctx->memory, size*sizeof(gs_param_string),
+ "pdfi_mark_from_objarray(parray)");
+ if (parray == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto exit;
+ }
+ memset(parray, 0, size *sizeof(gs_param_string));
+
+ for (i=0; i<len; i++) {
+ code = pdfi_mark_setparam_obj(ctx, objarray[i], parray+i);
+ if (code < 0) goto exit;
+ }
+
+ /* CTM */
+ code = pdfi_mark_ctm_str(ctx, ctm, &ctm_data, &ctm_len);
+ if (code < 0) goto exit;
+ parray[len].data = ctm_data;
+ parray[len].size = ctm_len;
+
+ /* Type (e.g. ANN, DOCINFO) */
+ parray[len+1].data = (const byte *)type;
+ parray[len+1].size = strlen(type);
+
+ array_list.data = parray;
+ array_list.persistent = false;
+ array_list.size = size;
+
+ code = pdfi_mark_write_array(ctx, &array_list, "pdfmark");
+
+ exit:
+ if (parray != NULL) {
+ for (i=0; i<len; i++) {
+ gs_free_object(ctx->memory, (byte *)parray[i].data, "pdfi_mark_from_objarray(parray)");
+ }
+ }
+ if (ctm_data)
+ gs_free_object(ctx->memory, ctm_data, "pdfi_mark_from_objarray(ctm_data)");
+ gs_free_object(ctx->memory, parray, "pdfi_mark_from_objarray(parray)");
+ return code;
+}
+
+/* Send an arbitrary object as a string, with command 'cmd'
+ * This is not a pdfmark, has no ctm.
+ */
+int pdfi_mark_object(pdf_context *ctx, pdf_obj *object, const char *cmd)
+{
+ gs_param_string param_string;
+ int code = 0;
+
+ param_string.data = NULL;
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ goto exit;
+ if (object->object_num != 0) {
+ code = pdfi_loop_detector_add_object(ctx, object->object_num);
+ if (code < 0) {
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ goto exit;
+ }
+ }
+ code = pdfi_resolve_indirect(ctx, object, true);
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_mark_setparam_obj(ctx, object, &param_string);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_mark_write_string(ctx, &param_string, cmd);
+
+exit:
+ if (param_string.data != NULL)
+ gs_free_object(ctx->memory, (byte *)param_string.data, "free data transferred to param_string in pdfi_mark_object\n");
+ return code;
+}
+
+/* Convert a Dest array to the hacky Page and View keys that pdfwrite expects
+ * dest_array: [<page_ref> <view_info>]
+ * page_ref: indirect ref to a page dict
+ * view_info: see table 8.2 in PDF 1.7, for example "/Fit"
+ *
+ * Removes /Dest and inserts two key pairs: /Page N and /View <view_info>
+ * N is the page number, which starts at 1, not 0.
+ */
+static int pdfi_mark_add_Page_View(pdf_context *ctx, pdf_dict *link_dict, pdf_array *dest_array)
+{
+ int code = 0;
+ int i;
+ uint64_t page_num;
+ pdf_dict *page_dict = NULL;
+ pdf_array *view_array = NULL;
+ uint64_t array_size;
+ pdf_obj *temp_obj = NULL;
+
+ /* Get the page_dict, without storing the deref in the array.
+ * (This is needed because otherwise there could be a circular ref that will
+ * lead to a memory leak)
+ */
+ code = pdfi_array_get_no_store_R(ctx, dest_array, 0, (pdf_obj **)&page_dict);
+ if (code < 0) goto exit;
+
+ if (page_dict->type != PDF_DICT) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+
+ /* Find out which page number this is */
+ code = pdfi_page_get_number(ctx, page_dict, &page_num);
+ if (code < 0) goto exit;
+
+ /* Add /Page key to the link_dict
+ * Of course pdfwrite is numbering its pages starting at 1, because... of course :(
+ */
+ code = pdfi_dict_put_int(ctx, link_dict, "Page", page_num+1);
+
+ /* Build an array for /View, out of the remainder of the Dest entry */
+ array_size = pdfi_array_size(dest_array) - 1;
+ code = pdfi_array_alloc(ctx, array_size, &view_array);
+ if (code < 0) goto exit;
+ pdfi_countup(view_array);
+ for (i=0; i<array_size; i++) {
+ code = pdfi_array_get(ctx, dest_array, i+1, &temp_obj);
+ if (code < 0) goto exit;
+ code = pdfi_array_put(ctx, view_array, i, temp_obj);
+ if (code < 0) goto exit;
+
+ pdfi_countdown(temp_obj);
+ temp_obj = NULL;
+ }
+ /* Add /View key to the link_dict */
+ code = pdfi_dict_put(ctx, link_dict, "View", (pdf_obj *)view_array);
+ if (code < 0) goto exit;
+
+ exit:
+ pdfi_countdown(temp_obj);
+ pdfi_countdown(page_dict);
+ pdfi_countdown(view_array);
+ return code;
+}
+
+/* Lookup a Dest string(or name) in the Names array and try to resolve it */
+static int pdfi_mark_handle_dest_names(pdf_context *ctx, pdf_dict *link_dict,
+ pdf_obj *dest, pdf_array *Names)
+{
+ int code = 0;
+ int i;
+ uint64_t array_size;
+ pdf_obj *name = NULL;
+ pdf_dict *D_dict = NULL;
+ bool found = false;
+ pdf_array *dest_array = NULL;
+
+ array_size = pdfi_array_size(Names);
+
+ /* Needs to be an even number - pairs of [name, obj] */
+ if (array_size % 2 != 0) {
+ /* TODO: flag an error? */
+ /* Let's just ignore the last unpaired item for now */
+ array_size -= 1;
+ }
+
+ for (i=0; i<array_size; i+=2) {
+ code = pdfi_array_get(ctx, Names, i, (pdf_obj **)&name);
+ if (code < 0) goto exit;
+ /* Note: in current implementation, PDF_STRING and PDF_NAME have all the same
+ * fields, but just in case that changes I treat them separately here.
+ */
+ if (name->type == PDF_STRING && dest->type == PDF_STRING) {
+ if (!pdfi_string_cmp((pdf_string *)name, (pdf_string *)dest)) {
+ found = true;
+ break;
+ }
+ } else if (name->type == PDF_NAME && dest->type == PDF_NAME) {
+ if (!pdfi_name_cmp((pdf_name *)name, (pdf_name *)dest)) {
+ found = true;
+ break;
+ }
+ }
+ pdfi_countdown(name);
+ name = NULL;
+ }
+
+ if (!found) {
+ /* TODO: flag a warning? */
+ code = 0;
+ goto exit;
+ }
+
+ /* Next entry is supposed to be a dict */
+ code = pdfi_array_get(ctx, Names, i+1, (pdf_obj **)&D_dict);
+ if (code < 0) goto exit;
+ if (D_dict->type != PDF_DICT) {
+ /* TODO: flag a warning? */
+ code = 0;
+ goto exit;
+ }
+
+ /* Dict is supposed to contain key "D" with Dest array */
+ code = pdfi_dict_knownget_type(ctx, D_dict, "D", PDF_ARRAY, (pdf_obj **)&dest_array);
+ if (code <= 0) goto exit;
+
+ /* Process the dest_array to replace with /Page /View */
+ code = pdfi_mark_add_Page_View(ctx, link_dict, dest_array);
+ if (code < 0) goto exit;
+
+ exit:
+ pdfi_countdown(name);
+ pdfi_countdown(D_dict);
+ pdfi_countdown(dest_array);
+ return code;
+}
+
+/* Special handling for "Dest" in Links
+ * Will replace /Dest with /Page /View in link_dict (for pdfwrite)
+ */
+int pdfi_mark_modDest(pdf_context *ctx, pdf_dict *link_dict)
+{
+ int code = 0;
+ pdf_dict *Dests = NULL;
+ pdf_obj *Dest = NULL;
+ bool delete_Dest = true;
+ pdf_array *dest_array = NULL;
+ pdf_array *Names = NULL;
+ pdf_dict *Names_dict = NULL;
+
+ code = pdfi_dict_get(ctx, link_dict, "Dest", (pdf_obj **)&Dest);
+ if (code < 0) goto exit;
+
+ code = pdfi_dict_knownget_type(ctx, ctx->Root, "Dests", PDF_DICT, (pdf_obj **)&Dests);
+ if (code < 0) goto exit;
+
+ code = pdfi_dict_knownget_type(ctx, ctx->Root, "Names", PDF_DICT, (pdf_obj **)&Names_dict);
+ if (code < 0) goto exit;
+
+ switch (Dest->type) {
+ case PDF_ARRAY:
+ code = pdfi_mark_add_Page_View(ctx, link_dict, (pdf_array *)Dest);
+ if (code < 0) goto exit;
+ break;
+ case PDF_NAME:
+ case PDF_STRING:
+ if (Dest->type == PDF_NAME && Dests != NULL) {
+ /* Case where it's a name to look up in Contents(Root) /Dests */
+ code = pdfi_dict_get_by_key(ctx, Dests, (const pdf_name *)Dest, (pdf_obj **)&dest_array);
+ if (code == gs_error_undefined) {
+ /* TODO: Not found, should flag a warning */
+ code = 0;
+ goto exit;
+ }
+ if (code < 0) goto exit;
+ if (dest_array->type != PDF_ARRAY) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+ code = pdfi_mark_add_Page_View(ctx, link_dict, dest_array);
+ if (code < 0) goto exit;
+ } else if (Names_dict != NULL) {
+ /* Looking in Catalog(Root) for /Names<</Dests<</Names [name dict array]>>>> */
+ code = pdfi_dict_knownget_type(ctx, Names_dict, "Dests", PDF_DICT, (pdf_obj **)&Dests);
+ if (code < 0) goto exit;
+ if (code == 0) {
+ /* TODO: Not found -- not sure if there is another case here or not */
+ goto exit;
+ }
+
+ code = pdfi_dict_knownget_type(ctx, Dests, "Names", PDF_ARRAY, (pdf_obj **)&Names);
+ if (code < 0) goto exit;
+ if (code == 0) {
+ /* TODO: Not found -- not sure if there is another case here or not */
+ goto exit;
+ }
+ code = pdfi_mark_handle_dest_names(ctx, link_dict, Dest, Names);
+ if (code < 0) goto exit;
+ } else {
+ /* TODO: Ignore it -- flag a warning? */
+ }
+ break;
+ default:
+ /* TODO: Ignore it -- flag a warning? */
+ break;
+ }
+
+ exit:
+ if (delete_Dest) {
+ /* Delete the Dest key */
+ code = pdfi_dict_delete(ctx, link_dict, "Dest");
+ if (code < 0) goto exit;
+ }
+ pdfi_countdown(Dest);
+ pdfi_countdown(Dests);
+ pdfi_countdown(Names);
+ pdfi_countdown(Names_dict);
+ pdfi_countdown(dest_array);
+ return code;
+}
+
+/* Special handling for "A" in Link annotations and Outlines
+ * Will delete A if handled and if A_key is provided.
+ */
+int pdfi_mark_modA(pdf_context *ctx, pdf_dict *dict)
+{
+ int code = 0;
+ pdf_dict *A_dict = NULL;
+ bool known;
+ pdf_name *S_name = NULL;
+ pdf_array *D_array = NULL;
+ bool delete_A = false;
+ bool deref_A = true;
+
+ code = pdfi_dict_get_no_store_R(ctx, dict, "A", (pdf_obj **)&A_dict);
+ if (code < 0) goto exit;
+
+ if (A_dict->type != PDF_DICT) {
+ /* Invalid AP, just delete it because I dunno what to do...
+ * TODO: Should flag a warning here
+ */
+ delete_A = true;
+ goto exit;
+ }
+
+ /* Handle URI */
+ code = pdfi_dict_known(ctx, A_dict, "URI", &known);
+ if (code < 0) goto exit;
+ if (known) {
+ code = pdfi_resolve_indirect_loop_detect(ctx, (pdf_obj *)NULL, (pdf_obj *)dict, true);
+ goto exit;
+ }
+
+ /* Handle S = GoTo */
+ /* TODO: this handles <</S /GoTo /D [dest array]>>
+ * Not sure if there are other cases to handle?
+ */
+ code = pdfi_dict_knownget_type(ctx, A_dict, "S", PDF_NAME, (pdf_obj **)&S_name);
+ if (code <= 0) goto exit;
+ /* We only handle GoTo for now */
+ if (pdfi_name_is(S_name, "GoTo")) {
+ code = pdfi_dict_knownget_type(ctx, A_dict, "D", PDF_ARRAY, (pdf_obj **)&D_array);
+ if (code == 0) goto exit;
+ if (code < 0) {
+ if (code == gs_error_typecheck) {
+ /* TODO: Are there other cases to handle?
+ * Sample tests_private/pdf/sumatra/recursive_action_destinations.pdf
+ * has a recursive destination that has an indirect ref here. We return a
+ * typecheck and that causes us to omit the whole thing, but is that
+ * really the best treatment?
+ */
+ }
+ goto exit;
+ }
+ /* Process the D array to replace with /Page /View */
+ code = pdfi_mark_add_Page_View(ctx, dict, D_array);
+ if (code < 0) goto exit;
+ delete_A = true;
+ } else if (pdfi_name_is(S_name, "GoToR") || pdfi_name_is(S_name, "Launch")) {
+ /* These point out of the document.
+ * Flatten out the reference, but otherwise leave it alone.
+ * gs does some wack stuff here.
+ *
+ * Currently this is same behavior as gs, but it is not correct behavior.
+ * In at least some cases we could do better, for example if the doc
+ * pointed to happens to be the same file.
+ * Sample: fts_28_2808.pdf
+ * Sample: ~/work/samples/tests_private/pdf/sumatra/1874_-_clicking_ToC_link_crashes.pdf
+ */
+ code = pdfi_resolve_indirect_loop_detect(ctx, (pdf_obj *)dict, (pdf_obj *)A_dict, true);
+ delete_A = false;
+ code = 0;
+ } else if (pdfi_name_is(S_name, "Named")) {
+ /* We can just pass this through and it will work fine
+ * This should be a name like "FirstPage" or "LastPage".
+ * Note: gs implementation translates into page numbers and also has some bugs...
+ * Sample: fts_33_3310.pdf
+ */
+ delete_A = false;
+ code = 0;
+ } else if (pdfi_name_is(S_name, "GoToE")) {
+ /* TODO: ??
+ * File: fts_33_3303.pdf
+ */
+ } else if (pdfi_name_is(S_name, "Thread")) {
+ /* TODO: For basically all of these below, I think just need to preserve
+ * any references and streams and pass it all through.
+ * File: fts_33_3305.pdf fts_33_3317.pdf
+ */
+ deref_A = false;
+ } else if (pdfi_name_is(S_name, "Sound")) {
+ /* TODO: ??
+ * File: fts_33_3307.pdf
+ */
+ deref_A = false;
+ } else if (pdfi_name_is(S_name, "Movie")) {
+ /* TODO: ??
+ * File: fts_33_3308.pdf
+ */
+ deref_A = false;
+ } else if (pdfi_name_is(S_name, "GoTo3DView")) {
+ /* TODO: ??
+ * File: fts_33_3318.pdf
+ */
+ } else if (pdfi_name_is(S_name, "RichMediaExecute")) {
+ /* TODO: ??
+ * File: fts_33_3319.pdf
+ */
+ } else if (pdfi_name_is(S_name, "Rendition")) {
+ /* TODO: make sure to pass through accurately?
+ * File: fts_07_0709.pdf fts_33_3316.pdf
+ */
+ } else {
+ /* TODO: flag warning? */
+ }
+
+ exit:
+ if (delete_A) {
+ code = pdfi_dict_delete(ctx, dict, "A");
+ } else if (deref_A) {
+ pdfi_countdown(A_dict);
+ A_dict = NULL;
+ code = pdfi_dict_get(ctx, dict, "A", (pdf_obj **)&A_dict);
+ }
+ pdfi_countdown(A_dict);
+ pdfi_countdown(S_name);
+ pdfi_countdown(D_array);
+ return code;
+}
+
+/* Begin defining an object
+ * Send an OBJ (_objdef) command
+ * (_objdef) (<label>) (/type) (/<type>) OBJ
+ */
+static int pdfi_mark_objdef_begin(pdf_context *ctx, pdf_indirect_ref *label, const char *type)
+{
+ int code;
+ pdf_obj *objarray[4];
+ int num_objects = 4;
+ int i;
+
+ memset(objarray, 0, sizeof(objarray));
+
+ code = pdfi_obj_charstr_to_name(ctx, "_objdef", (pdf_name **)&objarray[0]);
+ if (code < 0) goto exit;
+
+ objarray[1] = (pdf_obj *)label;
+ pdfi_countup(label);
+
+ code = pdfi_obj_charstr_to_name(ctx, "type", (pdf_name **)&objarray[2]);
+ if (code < 0) goto exit;
+
+ code = pdfi_obj_charstr_to_name(ctx, type, (pdf_name **)&objarray[3]);
+ if (code < 0) goto exit;
+
+ code = pdfi_mark_from_objarray(ctx, objarray, num_objects, NULL, "OBJ");
+ if (code < 0) goto exit;
+
+ exit:
+ for (i=0; i<num_objects; i++)
+ pdfi_countdown(objarray[i]);
+ return code;
+}
+
+/* Close an object
+ * Send a CLOSE command
+ * (<label>) CLOSE
+ */
+static int pdfi_mark_objdef_close(pdf_context *ctx, pdf_indirect_ref *label)
+{
+ int code;
+ pdf_obj *objarray[1];
+ int num_objects = 1;
+ int i;
+
+ memset(objarray, 0, sizeof(objarray));
+
+ objarray[0] = (pdf_obj *)label;
+ pdfi_countup(label);
+
+ code = pdfi_mark_from_objarray(ctx, objarray, num_objects, NULL, "CLOSE");
+ if (code < 0) goto exit;
+
+ exit:
+ for (i=0; i<num_objects; i++)
+ pdfi_countdown(objarray[i]);
+ return code;
+}
+
+static int pdfi_mark_stream_contents(pdf_context *ctx, pdf_indirect_ref *label, pdf_stream *stream)
+{
+ int code;
+ pdf_obj *objarray[2];
+ int num_objects = 2;
+ int i;
+
+ objarray[0] = (pdf_obj *)label;
+ pdfi_countup(label);
+
+ objarray[1] = (pdf_obj *)stream;
+ pdfi_countup(stream);
+ stream->is_marking = true;
+
+ code = pdfi_mark_from_objarray(ctx, objarray, num_objects, NULL, ".PUTSTREAM");
+ if (code < 0) goto exit;
+
+ exit:
+ stream->is_marking = false;
+ for (i=0; i<num_objects; i++)
+ pdfi_countdown(objarray[i]);
+ return code;
+}
+
+/* Mark a stream object */
+int pdfi_mark_stream(pdf_context *ctx, pdf_stream *stream)
+{
+ int code;
+ pdf_dict *streamdict = NULL;
+ pdf_indirect_ref *streamref = NULL;
+ pdf_dict *tempdict = NULL;
+ uint64_t dictsize;
+ uint64_t index;
+ pdf_name *Key = NULL;
+
+ if (stream->stream_written)
+ return 0;
+
+ stream->stream_written = true;
+
+ if (!ctx->device_state.writepdfmarks)
+ return 0;
+
+ /* Create an indirect ref for the stream */
+ code = pdfi_object_alloc(ctx, PDF_INDIRECT, 0, (pdf_obj **)&streamref);
+ if (code < 0) goto exit;
+ pdfi_countup(streamref);
+ streamref->ref_object_num = stream->object_num;
+ streamref->ref_generation_num = stream->generation_num;
+ streamref->is_marking = true;
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)stream, &streamdict);
+ if (code < 0) goto exit;
+
+ /* Make a copy of the dict and remove Filter keyword */
+ dictsize = pdfi_dict_entries(streamdict);
+ code = pdfi_dict_alloc(ctx, dictsize, &tempdict);
+ if (code < 0) goto exit;
+ pdfi_countup(tempdict);
+ code = pdfi_dict_copy(ctx, tempdict, streamdict);
+ if (code < 0) goto exit;
+ code = pdfi_dict_key_first(ctx, streamdict, (pdf_obj **)&Key, &index);
+ while (code >= 0) {
+ if (pdfi_name_is(Key, "Filter") || pdfi_name_is(Key, "Length")) {
+ code = pdfi_dict_delete_pair(ctx, tempdict, Key);
+ if (code < 0) goto exit;
+ }
+ pdfi_countdown(Key);
+ Key = NULL;
+
+ code = pdfi_dict_key_next(ctx, streamdict, (pdf_obj **)&Key, &index);
+ if (code == gs_error_undefined) {
+ code = 0;
+ break;
+ }
+ }
+ if (code < 0) goto exit;
+
+ code = pdfi_mark_objdef_begin(ctx, streamref, "stream");
+ if (code < 0) goto exit;
+
+ code = pdfi_mark_from_dict_withlabel(ctx, streamref, tempdict, NULL, ".PUTDICT");
+ if (code < 0) goto exit;
+
+ code = pdfi_mark_stream_contents(ctx, streamref, stream);
+ if (code < 0) goto exit;
+
+ code = pdfi_mark_objdef_close(ctx, streamref);
+ if (code < 0) goto exit;
+
+ exit:
+ pdfi_countdown(tempdict);
+ pdfi_countdown(streamref);
+ return code;
+}
+
+/* Mark a dict object */
+int pdfi_mark_dict(pdf_context *ctx, pdf_dict *dict)
+{
+ int code;
+ pdf_indirect_ref *dictref = NULL;
+
+ if (dict->dict_written)
+ return 0;
+
+ dict->dict_written = true;
+
+ if (!ctx->device_state.writepdfmarks)
+ return 0;
+
+ /* Create an indirect ref for the dict */
+ code = pdfi_object_alloc(ctx, PDF_INDIRECT, 0, (pdf_obj **)&dictref);
+ if (code < 0) goto exit;
+ pdfi_countup(dictref);
+ dictref->ref_object_num = dict->object_num;
+ dictref->ref_generation_num = dict->generation_num;
+ dictref->is_marking = true;
+
+ code = pdfi_mark_objdef_begin(ctx, dictref, "dict");
+ if (code < 0) goto exit;
+
+ code = pdfi_mark_from_dict_withlabel(ctx, dictref, dict, NULL, ".PUTDICT");
+ if (code < 0) goto exit;
+
+ exit:
+ pdfi_countdown(dictref);
+ return code;
+}
+
+static int pdfi_mark_filespec(pdf_context *ctx, pdf_string *name, pdf_dict *filespec)
+{
+ int code;
+ pdf_dict *tempdict = NULL;
+
+ code = pdfi_dict_alloc(ctx, 40, &tempdict);
+ if (code < 0) goto exit;
+ pdfi_countup(tempdict);
+
+ code = pdfi_dict_put(ctx, tempdict, "Name", (pdf_obj *)name);
+ if (code < 0) goto exit;
+
+ /* Flatten the filespec */
+ code = pdfi_resolve_indirect(ctx, (pdf_obj *)filespec, true);
+ if (code < 0) goto exit;
+
+ code = pdfi_dict_put(ctx, tempdict, "FS", (pdf_obj *)filespec);
+ if (code < 0) goto exit;
+
+ code = pdfi_mark_from_dict(ctx, tempdict, NULL, "EMBED");
+ if (code < 0) goto exit;
+
+ exit:
+ pdfi_countdown(tempdict);
+ return code;
+}
+
+/* embed a file */
+int pdfi_mark_embed_filespec(pdf_context *ctx, pdf_string *name, pdf_dict *filespec)
+{
+ int code;
+
+ code = pdfi_mark_filespec(ctx, name, filespec);
+ if (code < 0) goto exit;
+
+ exit:
+ return code;
+}
+
+/*
+ * Create and emit a /DOCINFO pdfmark for any and all of Title,
+ * Author, Subject, Keywords and Creator
+ */
+void pdfi_write_docinfo_pdfmark(pdf_context *ctx, pdf_dict *info_dict)
+{
+ int i, code = 0;
+ pdf_dict *Info = NULL;
+ pdf_obj *o = NULL;
+ /* We don't preserve the Producer, we are the Producer */
+ const char *KeyNames[] = {
+ "Title", "Author", "Subject", "Keywords", "Creator"
+ };
+
+ if (!ctx->device_state.writepdfmarks)
+ return;
+
+ code = pdfi_dict_alloc(ctx, 5, &Info);
+ if (code < 0)
+ goto exit;
+ pdfi_countup(Info);
+
+ for (i=0;i<5;i++)
+ {
+ if (pdfi_dict_knownget(ctx, info_dict, KeyNames[i], &o))
+ {
+ (void)pdfi_dict_put(ctx, Info, KeyNames[i], (pdf_obj *)o);
+ pdfi_countdown(o);
+ }
+ }
+
+ code = pdfi_mark_from_dict(ctx, Info, NULL, "DOCINFO");
+exit:
+ pdfi_countdown(Info);
+ return;
+}
+
+/*
+ * Create and emit a /PAGE pdfmark for any and all of
+ * CropBox, TrimBox, Artbox and BleedBox. If the interpreter
+ * has used something other than the MediaBox as the media size, then
+ * we don't send these, they are almost certainly incorrect.
+ *
+ * Because we will have used the MediaBox to create the media size, and
+ * will have accounted for any rotation or scaling, we can use the CTM
+ * to adjust the various Box entries (note this routine must be called
+ * early!).
+ */
+void pdfi_write_boxes_pdfmark(pdf_context *ctx, pdf_dict *page_dict)
+{
+ int i, code = 0;
+ pdf_dict *BoxDict = NULL;
+ pdf_obj *o = NULL;
+ gx_device *device = gs_currentdevice(ctx->pgs);
+ gs_matrix scale, m, ctm;
+ const char *BoxNames[] = {
+ "CropBox", "BleedBox", "TrimBox", "ArtBox"
+ };
+
+ /* If the device doesn't support pdfmar, exit now */
+ if (!ctx->device_state.writepdfmarks)
+ return;
+
+ /* If we are using somethign other than the MediaBox, don't send these */
+ if (ctx->args.usecropbox || ctx->args.usebleedbox ||
+ ctx->args.usetrimbox || ctx->args.useartbox)
+ return;
+
+ code = pdfi_dict_alloc(ctx, 4, &BoxDict);
+ if (code < 0)
+ goto exit;
+
+ pdfi_countup(BoxDict);
+
+ /* Undo the resolution scaling from the CTM, we don't want to apply that */
+ scale.xx = 72.0 / device->HWResolution[0];
+ scale.xy = 0;
+ scale.yx = 0;
+ scale.yy = 72.0 / device->HWResolution[1];
+ scale.tx = 0;
+ scale.ty = 0;
+
+ /* And multiply that by the CTM to get a matrix which represents the
+ * scaling/rotation used to set the conetnt to the media.
+ */
+ gs_currentmatrix(ctx->pgs, &ctm);
+ code = gs_matrix_multiply(&ctm, &scale, &m);
+ if (code < 0) goto exit;
+
+ for (i=0;i<4;i++)
+ {
+ /* Check each Bos name in turn */
+ if (pdfi_dict_knownget(ctx, page_dict, BoxNames[i], &o)){
+ gs_rect box;
+ pdf_array *new_array = NULL;
+
+ /* Box is present in page dicitonayr, check it's an array */
+ if (o->type != PDF_ARRAY) {
+ pdfi_countdown(o);
+ continue;
+ }
+
+ /* Turn the contents into a gs_rect */
+ code = pdfi_array_to_gs_rect(ctx, (pdf_array *)o, &box);
+ pdfi_countdown(o);
+ if (code < 0)
+ continue;
+
+ /* Rectangles in PDF need not be llx,lly,urx,ury, they can be any
+ * two opposite corners. Turn that into the usual format.
+ */
+ pdfi_normalize_rect(ctx, &box);
+
+ /* Transform the resulting box by the calculated matrix */
+ pdfi_bbox_transform(ctx, &box, &m);
+
+ /* Get a new array created from the box values */
+ code = pdfi_gs_rect_to_array(ctx, &box, &new_array);
+ if (code < 0)
+ continue;
+
+ /* And store it in the working dictionary */
+ (void)pdfi_dict_put(ctx, BoxDict, BoxNames[i], (pdf_obj *)new_array);
+ pdfi_countdown(new_array);
+ }
+ }
+
+ /* Send all the Box entries to the device */
+ (void)pdfi_mark_from_dict(ctx, BoxDict, NULL, "PAGE");
+
+exit:
+ pdfi_countdown(BoxDict);
+ return;
+}
diff --git a/pdf/pdf_mark.h b/pdf/pdf_mark.h
new file mode 100644
index 00000000..b732d190
--- /dev/null
+++ b/pdf/pdf_mark.h
@@ -0,0 +1,32 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* pdfmark handling for the PDF interpreter */
+
+#ifndef PDF_MARK
+#define PDF_MARK
+
+int pdfi_mark_from_dict(pdf_context *ctx, pdf_dict *dict, gs_matrix *ctm, const char *type);
+int pdfi_mark_object(pdf_context *ctx, pdf_obj *object, const char *label);
+int pdfi_mark_modDest(pdf_context *ctx, pdf_dict *dict);
+int pdfi_mark_modA(pdf_context *ctx, pdf_dict *dict);
+int pdfi_mark_stream(pdf_context *ctx, pdf_stream *stream);
+int pdfi_mark_dict(pdf_context *ctx, pdf_dict *dict);
+int pdfi_mark_embed_filespec(pdf_context *ctx, pdf_string *name, pdf_dict *filespec);
+int pdfi_mark_get_objlabel(pdf_context *ctx, pdf_obj *obj, char **label);
+void pdfi_write_boxes_pdfmark(pdf_context *ctx, pdf_dict *page_dict);
+void pdfi_write_docinfo_pdfmark(pdf_context *ctx, pdf_dict *info_dict);
+
+#endif
diff --git a/pdf/pdf_misc.c b/pdf/pdf_misc.c
new file mode 100644
index 00000000..1240d5bc
--- /dev/null
+++ b/pdf/pdf_misc.c
@@ -0,0 +1,305 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Miscellaneous routines */
+
+#include "pdf_int.h"
+#include "pdf_stack.h"
+#include "pdf_misc.h"
+#include "pdf_gstate.h"
+#include "gspath.h" /* For gs_strokepath() */
+#include "gsicc_manage.h" /* For gsicc_get_default_type() */
+#include "gsstate.h" /* for gs_setrenderingintent() */
+
+/* Get current bbox, possibly from stroking current path (utility function) */
+int pdfi_get_current_bbox(pdf_context *ctx, gs_rect *bbox, bool stroked)
+{
+ int code, code1;
+
+ if (stroked) {
+ code = pdfi_gsave(ctx);
+ if (code < 0)
+ return code;
+ code = gs_strokepath(ctx->pgs);
+ if (code < 0)
+ goto exit;
+ }
+ code = gs_upathbbox(ctx->pgs, bbox, false);
+
+ exit:
+ if (stroked) {
+ code1 = pdfi_grestore(ctx);
+ if (code == 0)
+ code = code1;
+ }
+ return code;
+}
+
+/* Get the current color space (the base one) from a color space
+ */
+gs_color_space_index pdfi_get_color_space_index(pdf_context *ctx, const gs_color_space *pcs)
+{
+ gs_color_space_index csi;
+
+ /* Get the color space index */
+ csi = gs_color_space_get_index(pcs);
+
+ /* If its an Indexed space, then use the base space */
+ if (csi == gs_color_space_index_Indexed)
+ csi = gs_color_space_get_index(pcs->base_space);
+
+ /* If its ICC, see if its a substitution for one of the device
+ * spaces. If so then we will want to behave as if we were using the
+ * device space.
+ */
+ if (csi == gs_color_space_index_ICC && pcs->cmm_icc_profile_data)
+ csi = gsicc_get_default_type(pcs->cmm_icc_profile_data);
+
+ return csi;
+}
+
+/* Get the current color space (the base one) from current graphics state.
+ * index -- tells whether to pull from 0 or 1 (probably 0)
+ */
+gs_color_space_index pdfi_currentcolorspace(pdf_context *ctx, int index)
+{
+ const gs_color_space *pcs;
+
+ pcs = ctx->pgs->color[index].color_space;
+
+ return pdfi_get_color_space_index(ctx, pcs);
+}
+
+
+int
+pdfi_name_strcmp(const pdf_name *n, const char *s)
+{
+ int len = strlen(s);
+ if (n->length == len)
+ return memcmp(n->data, s, len);
+ return -1;
+}
+
+bool
+pdfi_string_is(const pdf_string *n, const char *s)
+{
+ int len = strlen(s);
+ if (n->length == len)
+ return (memcmp(n->data, s, len) == 0);
+ return false;
+}
+
+bool
+pdfi_name_is(const pdf_name *n, const char *s)
+{
+ int len = strlen(s);
+ if (n->length == len)
+ return (memcmp(n->data, s, len) == 0);
+ return false;
+}
+
+int
+pdfi_name_cmp(const pdf_name *n1, const pdf_name *n2)
+{
+ if (n1->length != n2->length)
+ return -1;
+ return memcmp(n1->data, n2->data, n1->length);
+}
+
+int
+pdfi_string_cmp(const pdf_string *n1, const pdf_string *n2)
+{
+ if (n1->length != n2->length)
+ return -1;
+ return memcmp(n1->data, n2->data, n1->length);
+}
+
+/* Set rendering intent, translating from name to number */
+int pdfi_setrenderingintent(pdf_context *ctx, pdf_name *n)
+{
+ int code = 0;
+
+ if (pdfi_name_is(n, "Perceptual")) {
+ code = gs_setrenderingintent(ctx->pgs, 0);
+ } else if (pdfi_name_is(n, "Saturation")) {
+ code = gs_setrenderingintent(ctx->pgs, 2);
+ } else if (pdfi_name_is(n, "RelativeColorimetric")) {
+ code = gs_setrenderingintent(ctx->pgs, 1);
+ } else if (pdfi_name_is(n, "AbsoluteColorimetric")) {
+ code = gs_setrenderingintent(ctx->pgs, 3);
+ } else {
+ code = gs_error_undefined;
+ }
+ return code;
+}
+
+int pdfi_string_from_name(pdf_context *ctx, pdf_name *n, char **str, int *len)
+{
+ if (n->type != PDF_NAME)
+ return gs_note_error(gs_error_typecheck);
+
+ *str = NULL;
+ *len = 0;
+
+ *str = (char *)gs_alloc_bytes(ctx->memory, n->length + 1, "pdfi_string_from_name");
+ if (*str == NULL)
+ return gs_note_error(gs_error_VMerror);
+
+ memcpy(*str, n->data, n->length);
+ (*str)[n->length] = 0x00;
+ *len = n->length;
+
+ return 0;
+}
+
+void normalize_rectangle(double *d)
+{
+ double d1[4];
+ int i;
+
+ if (d[0] < d[2]) {
+ d1[0] = d[0];
+ d1[2] = d[2];
+ } else {
+ d1[0] = d[2];
+ d1[2] = d[0];
+ }
+ if (d[1] < d[3]) {
+ d1[1] = d[1];
+ d1[3] = d[3];
+ } else {
+ d1[1] = d[3];
+ d1[3] = d[1];
+ }
+ for (i=0;i<=3;i++){
+ d[i] = d1[i];
+ }
+}
+
+/* Free an array of cstrings, sets the pointer to null */
+void pdfi_free_cstring_array(pdf_context *ctx, char ***pstrlist)
+{
+ char **ptr = *pstrlist;
+
+ if (ptr == NULL)
+ return;
+
+ while (*ptr) {
+ gs_free_object(ctx->memory, *ptr, "pdfi_free_cstring_array(item)");
+ ptr ++;
+ }
+ gs_free_object(ctx->memory, *pstrlist, "pdfi_free_cstring_array(array)");
+ *pstrlist = NULL;
+}
+
+/* Parse an argument string of names into an array of cstrings */
+/* Format: /Item1,/Item2,/Item3 (no white space) */
+int pdfi_parse_name_cstring_array(pdf_context *ctx, char *data, uint64_t size, char ***pstrlist)
+{
+ char **strlist = NULL;
+ char **templist = NULL;
+ int numitems = 0, item;
+ int strnum;
+ uint64_t i;
+ char *strptr;
+ int code = 0;
+
+ /* Free it if it already exists */
+ if (*pstrlist != NULL)
+ pdfi_free_cstring_array(ctx, pstrlist);
+
+ /* find out how many '/' characters there are -- this is the max possible number
+ * of items in the list
+ */
+ for (i=0, strptr = data; i<size; i++,strptr++) {
+ if (*strptr == '/')
+ numitems ++;
+ /* early exit if we hit a null */
+ if (*strptr == 0)
+ break;
+ }
+
+ /* Allocate space for the array of char * (plus one extra for null termination) */
+ strlist = (char **)gs_alloc_bytes(ctx->memory, (numitems+1)*sizeof(char *),
+ "pdfi_parse_cstring_array(strlist)");
+ if (strlist == NULL)
+ return_error(gs_error_VMerror);
+
+ memset(strlist, 0, (numitems+1)*sizeof(char *));
+
+ /* Allocate a temp array */
+ templist = (char **)gs_alloc_bytes(ctx->memory, (numitems+1)*sizeof(char *),
+ "pdfi_parse_cstring_array(templist)");
+ if (templist == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto exit;
+ }
+
+ memset(templist, 0, (numitems+1)*sizeof(char *));
+
+ /* Find start ptr of each string */
+ item = 0;
+ for (i=0, strptr = data; i<size; i++,strptr++) {
+ if (*strptr == '/') {
+ templist[item] = strptr+1;
+ item++;
+ }
+ }
+
+ /* Find each substring, alloc, copy into string array */
+ strnum = 0;
+ for (i=0; i<numitems; i++) {
+ char *curstr, *nextstr;
+ int length;
+ char *newstr;
+
+ curstr = templist[i];
+ nextstr = templist[i+1];
+ if (!curstr)
+ break;
+ if (*curstr == '/' || *curstr == ',') {
+ /* Empty string, skip it */
+ continue;
+ }
+ if (nextstr == NULL) {
+ length = size-(curstr-data);
+ } else {
+ length = nextstr - curstr - 1;
+ }
+ if (curstr[length-1] == ',')
+ length --;
+
+ /* Allocate the string and copy it */
+ newstr = (char *)gs_alloc_bytes(ctx->memory, length+1,
+ "pdfi_parse_cstring_array(newstr)");
+ if (newstr == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto exit;
+ }
+ memcpy(newstr, curstr, length);
+ newstr[length+1] = 0; /* Null terminate */
+ strlist[strnum] = newstr;
+ strnum ++;
+ }
+
+ *pstrlist = strlist;
+
+ exit:
+ if (code < 0)
+ pdfi_free_cstring_array(ctx, &strlist);
+ if (templist)
+ gs_free_object(ctx->memory, templist, "pdfi_parse_cstring_array(templist(array))");
+ return code;
+}
diff --git a/pdf/pdf_misc.h b/pdf/pdf_misc.h
new file mode 100644
index 00000000..8642b088
--- /dev/null
+++ b/pdf/pdf_misc.h
@@ -0,0 +1,37 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+#ifndef PDF_MISC
+#define PDF_MISC
+
+int pdfi_get_current_bbox(pdf_context *ctx, gs_rect *bbox, bool stroked);
+int pdfi_name_strcmp(const pdf_name *n, const char *s);
+bool pdfi_string_is(const pdf_string *n, const char *s);
+bool pdfi_name_is(const pdf_name *n, const char *s);
+int pdfi_name_cmp(const pdf_name *n1, const pdf_name *n2);
+int pdfi_string_cmp(const pdf_string *n1, const pdf_string *n2);
+int pdfi_string_from_name(pdf_context *ctx, pdf_name *n, char **str, int *len);
+
+gs_color_space_index pdfi_get_color_space_index(pdf_context *ctx, const gs_color_space *pcs);
+gs_color_space_index pdfi_currentcolorspace(pdf_context *ctx, int index);
+int pdfi_setrenderingintent(pdf_context *ctx, pdf_name *n);
+
+void normalize_rectangle(double *d);
+
+void pdfi_free_cstring_array(pdf_context *ctx, char ***pstrlist);
+int pdfi_parse_name_cstring_array(pdf_context *ctx, char *data, uint64_t size, char ***pstrlist);
+
+
+#endif
diff --git a/pdf/pdf_obj.c b/pdf/pdf_obj.c
new file mode 100644
index 00000000..931f2137
--- /dev/null
+++ b/pdf/pdf_obj.c
@@ -0,0 +1,955 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+#include "ghostpdf.h"
+#include "pdf_stack.h"
+#include "pdf_array.h"
+#include "pdf_dict.h"
+#include "pdf_obj.h"
+#include "pdf_cmap.h"
+#include "pdf_font.h"
+#include "pdf_deref.h" /* for replace_cache_entry() */
+#include "pdf_mark.h"
+#include "pdf_file.h" /* for pdfi_stream_to_buffer() */
+
+/***********************************************************************************/
+/* Functions to create the various kinds of 'PDF objects', Created objects have a */
+/* reference count of 0. Composite objects (dictionaries, arrays, strings) use the */
+/* 'size' argument to create an object with the correct numbr of entries or of the */
+/* requested size. Simple objects (integers etc) ignore this parameter. */
+/* Objects do not get their data assigned, that's up to the caller, but we do */
+/* set the length or size fields for composite objects. */
+
+int pdfi_object_alloc(pdf_context *ctx, pdf_obj_type type, unsigned int size, pdf_obj **obj)
+{
+ int bytes = 0;
+
+ switch(type) {
+ case PDF_ARRAY_MARK:
+ case PDF_DICT_MARK:
+ case PDF_PROC_MARK:
+ case PDF_NULL:
+ bytes = sizeof(pdf_obj);
+ break;
+ case PDF_INT:
+ case PDF_REAL:
+ bytes = sizeof(pdf_num);
+ break;
+ case PDF_STRING:
+ case PDF_NAME:
+ bytes = sizeof(pdf_string);
+ break;
+ case PDF_ARRAY:
+ bytes = sizeof(pdf_array);
+ break;
+ case PDF_DICT:
+ bytes = sizeof(pdf_dict);
+ break;
+ case PDF_INDIRECT:
+ bytes = sizeof(pdf_indirect_ref);
+ break;
+ case PDF_BOOL:
+ bytes = sizeof(pdf_bool);
+ break;
+ case PDF_KEYWORD:
+ bytes = sizeof(pdf_keyword);
+ break;
+ /* The following aren't PDF object types, but are objects we either want to
+ * reference count, or store on the stack.
+ */
+ case PDF_XREF_TABLE:
+ bytes = sizeof(xref_table_t);
+ break;
+ case PDF_STREAM:
+ bytes = sizeof(pdf_stream);
+ break;
+ default:
+ return_error(gs_error_typecheck);
+ }
+ *obj = (pdf_obj *)gs_alloc_bytes(ctx->memory, bytes, "pdfi_object_alloc");
+ if (*obj == NULL)
+ return_error(gs_error_VMerror);
+
+ memset(*obj, 0x00, bytes);
+ (*obj)->ctx = ctx;
+ (*obj)->type = type;
+
+ switch(type) {
+ case PDF_NULL:
+ case PDF_INT:
+ case PDF_REAL:
+ case PDF_INDIRECT:
+ case PDF_BOOL:
+ case PDF_ARRAY_MARK:
+ case PDF_DICT_MARK:
+ case PDF_PROC_MARK:
+ break;
+ case PDF_KEYWORD:
+ case PDF_STRING:
+ case PDF_NAME:
+ {
+ unsigned char *data = NULL;
+ data = (unsigned char *)gs_alloc_bytes(ctx->memory, size, "pdfi_object_alloc");
+ if (data == NULL) {
+ gs_free_object(ctx->memory, *obj, "pdfi_object_alloc");
+ *obj = NULL;
+ return_error(gs_error_VMerror);
+ }
+ ((pdf_string *)*obj)->data = data;
+ ((pdf_string *)*obj)->length = size;
+ }
+ break;
+ case PDF_ARRAY:
+ {
+ pdf_obj **values = NULL;
+
+ ((pdf_array *)*obj)->size = size;
+ if (size > 0) {
+ values = (pdf_obj **)gs_alloc_bytes(ctx->memory, size * sizeof(pdf_obj *), "pdfi_object_alloc");
+ if (values == NULL) {
+ gs_free_object(ctx->memory, *obj, "pdfi_object_alloc");
+ gs_free_object(ctx->memory, values, "pdfi_object_alloc");
+ *obj = NULL;
+ return_error(gs_error_VMerror);
+ }
+ ((pdf_array *)*obj)->values = values;
+ memset(((pdf_array *)*obj)->values, 0x00, size * sizeof(pdf_obj *));
+ }
+ }
+ break;
+ case PDF_DICT:
+ {
+ pdf_obj **keys = NULL, **values = NULL;
+
+ ((pdf_dict *)*obj)->size = size;
+ if (size > 0) {
+ keys = (pdf_obj **)gs_alloc_bytes(ctx->memory, size * sizeof(pdf_obj *), "pdfi_object_alloc");
+ values = (pdf_obj **)gs_alloc_bytes(ctx->memory, size * sizeof(pdf_obj *), "pdfi_object_alloc");
+ if (keys == NULL || values == NULL) {
+ gs_free_object(ctx->memory, *obj, "pdfi_object_alloc");
+ gs_free_object(ctx->memory, keys, "pdfi_object_alloc");
+ gs_free_object(ctx->memory, values, "pdfi_object_alloc");
+ *obj = NULL;
+ return_error(gs_error_VMerror);
+ }
+ ((pdf_dict *)*obj)->values = values;
+ ((pdf_dict *)*obj)->keys = keys;
+ memset(((pdf_dict *)*obj)->values, 0x00, size * sizeof(pdf_obj *));
+ memset(((pdf_dict *)*obj)->keys, 0x00, size * sizeof(pdf_obj *));
+ }
+ }
+ break;
+ /* The following aren't PDF object types, but are objects we either want to
+ * reference count, or store on the stack.
+ */
+ case PDF_XREF_TABLE:
+ break;
+ default:
+ break;
+ }
+#if REFCNT_DEBUG
+ (*obj)->UID = ctx->UID++;
+ dmprintf2(ctx->memory, "Allocated object of type %c with UID %"PRIi64"\n", (*obj)->type, (*obj)->UID);
+#endif
+ return 0;
+}
+
+/* Create a PDF number object from a numeric value. Attempts to create
+ * either a REAL or INT as appropriate. As usual for the alloc functions
+ * this returns an object with a reference count of 0.
+ */
+int pdfi_num_alloc(pdf_context *ctx, double d, pdf_num **num)
+{
+ uint64_t test = 0;
+ int code = 0;
+
+ test = (uint64_t)floor(d);
+ if (d == test) {
+ code = pdfi_object_alloc(ctx, PDF_INT, 0, (pdf_obj **)num);
+ if (code < 0)
+ return code;
+ (*num)->value.i = test;
+ }
+ else {
+ code = pdfi_object_alloc(ctx, PDF_REAL, 0, (pdf_obj **)num);
+ if (code < 0)
+ return code;
+ (*num)->value.d = d;
+ }
+
+ return 0;
+}
+
+/***********************************************************************************/
+/* Functions to free the various kinds of 'PDF objects'. */
+/* All objects are reference counted, newly allocated objects, as noted above have */
+/* a reference count of 0. Pushing an object onto the stack increments */
+/* its reference count, popping it from the stack decrements its reference count. */
+/* When an object's reference count is decremented to 0, pdfi_countdown calls */
+/* pdfi_free_object() to free it. */
+
+static void pdfi_free_namestring(pdf_obj *o)
+{
+ /* Currently names and strings are the same, so a single cast is OK */
+ pdf_name *n = (pdf_name *)o;
+
+ if (n->data != NULL)
+ gs_free_object(OBJ_MEMORY(n), n->data, "pdf interpreter free name or string data");
+ gs_free_object(OBJ_MEMORY(n), n, "pdf interpreter free name or string");
+}
+
+static void pdfi_free_keyword(pdf_obj *o)
+{
+ /* Currently names and strings are the same, so a single cast is OK */
+ pdf_keyword *k = (pdf_keyword *)o;
+
+ if (k->data != NULL)
+ gs_free_object(OBJ_MEMORY(k), k->data, "pdf interpreter free keyword data");
+ gs_free_object(OBJ_MEMORY(k), k, "pdf interpreter free keyword");
+}
+
+static void pdfi_free_xref_table(pdf_obj *o)
+{
+ xref_table_t *xref = (xref_table_t *)o;
+
+ gs_free_object(OBJ_MEMORY(xref), xref->xref, "pdfi_free_xref_table");
+ gs_free_object(OBJ_MEMORY(xref), xref, "pdfi_free_xref_table");
+}
+
+static void pdfi_free_stream(pdf_obj *o)
+{
+ pdf_stream *stream = (pdf_stream *)o;
+
+ pdfi_countdown(stream->stream_dict);
+ gs_free_object(OBJ_MEMORY(o), o, "pdfi_free_stream");
+}
+
+void pdfi_free_object(pdf_obj *o)
+{
+ switch(o->type) {
+ case PDF_ARRAY_MARK:
+ case PDF_DICT_MARK:
+ case PDF_PROC_MARK:
+ case PDF_NULL:
+ case PDF_INT:
+ case PDF_REAL:
+ case PDF_INDIRECT:
+ case PDF_BOOL:
+ gs_free_object(OBJ_MEMORY(o), o, "pdf interpreter object refcount to 0");
+ break;
+ case PDF_STRING:
+ case PDF_NAME:
+ pdfi_free_namestring(o);
+ break;
+ case PDF_ARRAY:
+ pdfi_free_array(o);
+ break;
+ case PDF_DICT:
+ pdfi_free_dict(o);
+ break;
+ case PDF_STREAM:
+ pdfi_free_stream(o);
+ break;
+ case PDF_KEYWORD:
+ pdfi_free_keyword(o);
+ break;
+ case PDF_XREF_TABLE:
+ pdfi_free_xref_table(o);
+ break;
+ case PDF_FONT:
+ pdfi_free_font(o);
+ break;
+ case PDF_CMAP:
+ pdfi_free_cmap(o);
+ break;
+ default:
+ dbgmprintf(OBJ_MEMORY(o), "!!! Attempting to free unknown obect type !!!\n");
+ break;
+ }
+}
+
+
+/* Convert a pdf_dict to a pdf_stream.
+ * do_convert -- convert the stream to use same object num as dict
+ * (This assumes the dict has not been cached.)
+ * The stream will come with 1 refcnt, dict refcnt will be incremented by 1.
+ */
+int pdfi_obj_dict_to_stream(pdf_context *ctx, pdf_dict *dict, pdf_stream **stream, bool do_convert)
+{
+ int code = 0;
+ pdf_stream *new_stream = NULL;
+
+ if (dict->type != PDF_DICT)
+ return_error(gs_error_typecheck);
+
+ code = pdfi_object_alloc(ctx, PDF_STREAM, 0, (pdf_obj **)&new_stream);
+ if (code < 0)
+ goto error_exit;
+
+ new_stream->ctx = ctx;
+ pdfi_countup(new_stream);
+
+ new_stream->stream_dict = dict;
+ pdfi_countup(dict);
+
+ /* this replaces the dict with the stream.
+ * assumes it's not cached
+ */
+ if (do_convert) {
+ new_stream->object_num = dict->object_num;
+ new_stream->generation_num = dict->generation_num;
+ dict->object_num = 0;
+ dict->generation_num = 0;
+ }
+ *stream = new_stream;
+ return 0;
+
+ error_exit:
+ pdfi_countdown(new_stream);
+ return code;
+}
+
+/* Create a pdf_string from a c char * */
+int pdfi_obj_charstr_to_string(pdf_context *ctx, const char *charstr, pdf_string **string)
+{
+ int code;
+ int length = strlen(charstr);
+ pdf_string *newstr = NULL;
+
+ *string = NULL;
+
+ code = pdfi_object_alloc(ctx, PDF_STRING, length, (pdf_obj **)&newstr);
+ if (code < 0) goto exit;
+
+ memcpy(newstr->data, (byte *)charstr, length);
+
+ *string = newstr;
+ pdfi_countup(newstr);
+ exit:
+ return code;
+}
+
+/* Create a pdf_name from a c char * */
+int pdfi_obj_charstr_to_name(pdf_context *ctx, const char *charstr, pdf_name **name)
+{
+ int code;
+ int length = strlen(charstr);
+ pdf_name *newname = NULL;
+
+ *name = NULL;
+
+ code = pdfi_object_alloc(ctx, PDF_NAME, length, (pdf_obj **)&newname);
+ if (code < 0) goto exit;
+
+ memcpy(newname->data, (byte *)charstr, length);
+
+ *name = newname;
+ pdfi_countup(newname);
+ exit:
+ return code;
+}
+
+/************ bufstream module BEGIN **************/
+#define INIT_BUF_SIZE 256
+
+typedef struct {
+ int len; /* Length of buffer */
+ int cur; /* Current position */
+ byte *data;
+} pdfi_bufstream_t;
+
+
+static int pdfi_bufstream_init(pdf_context *ctx, pdfi_bufstream_t *stream)
+{
+ stream->len = INIT_BUF_SIZE;
+ stream->cur = 0;
+ stream->data = gs_alloc_bytes(ctx->memory, stream->len, "pdfi_bufstream_init(data)");
+
+ if (!stream->data)
+ return_error(gs_error_VMerror);
+ return 0;
+}
+
+static int pdfi_bufstream_free(pdf_context *ctx, pdfi_bufstream_t *stream)
+{
+ if (stream->data)
+ gs_free_object(ctx->memory, stream->data, "pdfi_bufstream_free(data)");
+ stream->len = 0;
+ stream->cur = 0;
+ stream->data = NULL;
+ return 0;
+}
+
+/* Grab a copy of the stream's buffer */
+static int pdfi_bufstream_copy(pdf_context *ctx, pdfi_bufstream_t *stream, byte **buf, int *len)
+{
+ *buf = stream->data;
+ *len = stream->cur;
+ stream->len = 0;
+ stream->cur = 0;
+ stream->data = NULL;
+ return 0;
+}
+
+/* Increase the size of the buffer by doubling and added the known needed amount */
+static int pdfi_bufstream_increase(pdf_context *ctx, pdfi_bufstream_t *stream, uint64_t needed)
+{
+ byte *data = NULL;
+ uint64_t newsize;
+
+ newsize = stream->len * 2 + needed;
+ data = gs_alloc_bytes(ctx->memory, newsize, "pdfi_bufstream_increase(data)");
+ if (!data)
+ return_error(gs_error_VMerror);
+
+ memcpy(data, stream->data, stream->len);
+ gs_free_object(ctx->memory, stream->data, "pdfi_bufstream_increase(data)");
+ stream->data = data;
+ stream->len = newsize;
+
+ return 0;
+}
+
+static int pdfi_bufstream_write(pdf_context *ctx, pdfi_bufstream_t *stream, byte *data, uint64_t len)
+{
+ int code = 0;
+
+ if (stream->cur + len > stream->len) {
+ code = pdfi_bufstream_increase(ctx, stream, len);
+ if (code < 0)
+ goto exit;
+ }
+ memcpy(stream->data + stream->cur, data, len);
+ stream->cur += len;
+
+ exit:
+ return code;
+}
+
+/************ bufstream module END **************/
+
+
+/* Create a c-string to use as object label
+ * Uses the object_num to make it unique
+ * (don't call this for objects with object_num=0, though I am not going to check that here)
+ */
+int pdfi_obj_get_label(pdf_context *ctx, pdf_obj *obj, char **label)
+{
+ int code = 0;
+ int length;
+ const char *template = "{Obj%dG%d}"; /* The '{' and '}' are special to pdfmark/pdfwrite driver */
+ char *string = NULL;
+ pdf_indirect_ref *ref = (pdf_indirect_ref *)obj;
+
+ *label = NULL;
+ length = strlen(template)+20;
+
+ string = (char *)gs_alloc_bytes(ctx->memory, length, "pdf_obj_get_label(label)");
+ if (string == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto exit;
+ }
+
+ if (obj->type == PDF_INDIRECT)
+ snprintf(string, length, template, ref->ref_object_num, ref->ref_generation_num);
+ else
+ snprintf(string, length, template, obj->object_num, obj->generation_num);
+
+ *label = string;
+ exit:
+ return code;
+}
+
+/*********** BEGIN obj_to_string module ************/
+
+typedef int (*str_func)(pdf_context *ctx, pdf_obj *obj, byte **data, int *len);
+
+/* Dispatch to get string representation of an object */
+typedef struct {
+ pdf_obj_type type;
+ str_func func;
+} obj_str_dispatch_t;
+
+static int pdfi_obj_default_str(pdf_context *ctx, pdf_obj *obj, byte **data, int *len)
+{
+ int code = 0;
+ int size = 12;
+ byte *buf;
+
+ buf = gs_alloc_bytes(ctx->memory, size, "pdfi_obj_default_str(data)");
+ if (buf == NULL)
+ return_error(gs_error_VMerror);
+ memcpy(buf, "/placeholder", size);
+ *data = buf;
+ *len = size;
+ return code;
+}
+
+static int pdfi_obj_name_str(pdf_context *ctx, pdf_obj *obj, byte **data, int *len)
+{
+ int code = 0;
+ pdf_name *name = (pdf_name *)obj;
+ int size = name->length + 1;
+ byte *buf;
+
+ buf = gs_alloc_bytes(ctx->memory, size, "pdfi_obj_name_str(data)");
+ if (buf == NULL)
+ return_error(gs_error_VMerror);
+ buf[0] = '/';
+ memcpy(buf+1, name->data, name->length);
+ *data = buf;
+ *len = size;
+ return code;
+}
+
+static int pdfi_obj_real_str(pdf_context *ctx, pdf_obj *obj, byte **data, int *len)
+{
+ int code = 0;
+ int size = 15;
+ pdf_num *number = (pdf_num *)obj;
+ char *buf;
+
+ buf = (char *)gs_alloc_bytes(ctx->memory, size, "pdfi_obj_real_str(data)");
+ if (buf == NULL)
+ return_error(gs_error_VMerror);
+ snprintf(buf, size, "%.4f", number->value.d);
+ *data = (byte *)buf;
+ *len = strlen(buf);
+ return code;
+}
+
+static int pdfi_obj_int_str(pdf_context *ctx, pdf_obj *obj, byte **data, int *len)
+{
+ int code = 0;
+ int size = 15;
+ pdf_num *number = (pdf_num *)obj;
+ char *buf;
+
+ buf = (char *)gs_alloc_bytes(ctx->memory, size, "pdfi_obj_int_str(data)");
+ if (buf == NULL)
+ return_error(gs_error_VMerror);
+ snprintf(buf, size, "%ld", number->value.i);
+ *data = (byte *)buf;
+ *len = strlen(buf);
+ return code;
+}
+
+static int pdfi_obj_getrefstr(pdf_context *ctx, uint64_t object_num, uint32_t generation, byte **data, int *len)
+{
+ int size = 100;
+ char *buf;
+
+ buf = (char *)gs_alloc_bytes(ctx->memory, size, "pdfi_obj_getrefstr(data)");
+ if (buf == NULL)
+ return_error(gs_error_VMerror);
+ snprintf(buf, size, "%ld %d R", object_num, generation);
+ *data = (byte *)buf;
+ *len = strlen(buf);
+ return 0;
+}
+
+static int pdfi_obj_indirect_str(pdf_context *ctx, pdf_obj *obj, byte **data, int *len)
+{
+ int code = 0;
+ pdf_indirect_ref *ref = (pdf_indirect_ref *)obj;
+ char *buf;
+ pdf_obj *object = NULL;
+ bool use_label = true;
+
+ if (ref->is_highlevelform) {
+ code = pdfi_obj_getrefstr(ctx, ref->highlevel_object_num, 0, data, len);
+ ref->is_highlevelform = false;
+ } else {
+ if (!ref->is_marking) {
+ code = pdfi_dereference(ctx, ref->ref_object_num, ref->ref_generation_num, &object);
+ if (code == gs_error_undefined) {
+ /* Do something sensible for undefined reference (this would be a broken file) */
+ /* TODO: Flag an error? */
+ code = pdfi_obj_getrefstr(ctx, ref->ref_object_num, ref->ref_generation_num, data, len);
+ goto exit;
+ }
+ if (code < 0 && code != gs_error_circular_reference)
+ goto exit;
+ if (code == 0) {
+ if (object->type == PDF_STREAM) {
+ code = pdfi_mark_stream(ctx, (pdf_stream *)object);
+ if (code < 0) goto exit;
+ } else if (object->type == PDF_DICT) {
+ code = pdfi_mark_dict(ctx, (pdf_dict *)object);
+ if (code < 0) goto exit;
+ } else {
+ code = pdfi_obj_to_string(ctx, object, data, len);
+ if (code < 0) goto exit;
+ use_label = false;
+ }
+ }
+ }
+ if (use_label) {
+ code = pdfi_obj_get_label(ctx, (pdf_obj *)ref, &buf);
+ if (code < 0) goto exit;
+ *data = (byte *)buf;
+ *len = strlen(buf);
+ }
+ }
+
+ exit:
+ pdfi_countdown(object);
+ return code;
+}
+
+static int pdfi_obj_bool_str(pdf_context *ctx, pdf_obj *obj, byte **data, int *len)
+{
+ int code = 0;
+ int size = 5;
+ pdf_bool *bool = (pdf_bool *)obj;
+ char *buf;
+
+ buf = (char *)gs_alloc_bytes(ctx->memory, size, "pdfi_obj_bool_str(data)");
+ if (buf == NULL)
+ return_error(gs_error_VMerror);
+ if (bool->value) {
+ memcpy(buf, (byte *)"true", 4);
+ *len = 4;
+ } else {
+ memcpy(buf, (byte *)"false", 5);
+ *len = 5;
+ }
+ *data = (byte *)buf;
+ return code;
+}
+
+static int pdfi_obj_null_str(pdf_context *ctx, pdf_obj *obj, byte **data, int *len)
+{
+ int code = 0;
+ int size = 4;
+ char *buf;
+
+ buf = (char *)gs_alloc_bytes(ctx->memory, size, "pdfi_obj_null_str(data)");
+ if (buf == NULL)
+ return_error(gs_error_VMerror);
+ memcpy(buf, (byte *)"null", 4);
+ *len = 4;
+ *data = (byte *)buf;
+ return code;
+}
+
+static int pdfi_obj_string_str(pdf_context *ctx, pdf_obj *obj, byte **data, int *len)
+{
+ int code = 0;
+ pdf_string *string = (pdf_string *)obj;
+ int size;
+ int string_len;
+ char *buf;
+ char *bufptr;
+ bool non_ascii = false;
+ int num_esc = 0;
+ int i;
+ byte *ptr;
+
+ string_len = string->length;
+ /* See if there are any non-ascii chars */
+ for (i=0,ptr=string->data;i<string_len;i++,ptr++) {
+ /* TODO: I wanted to convert non-ascii to hex strings, but there
+ * are cases (such as /Author field) where the non-ascii is not really binary
+ * and then pdfwrite barfs on it later.
+ * see gdevpdfu.c/pdf_put_encoded_hex_string(), which is not implemented
+ * and causes crashes...
+ * See sample: tests_private/pdf/sumatra/1532_-_Freetype_crash.pdf
+ *
+ * For now, just disabling the generation of hex strings, which will match
+ * what gs does. Seems lame.
+ */
+#if 0
+ if (*ptr > 127) {
+ non_ascii = true;
+ break;
+ }
+#endif
+ /* TODO: I was going to just turn special chars into hexstrings, but it turns out
+ * that the pdfwrite driver expects to be able to parse URI strings, and these
+ * can have special characters. So I will handle the minimum that seems needed for that.
+ */
+ switch (*ptr) {
+ case '(':
+ case ')':
+ case '\\':
+ num_esc ++;
+ break;
+ default:
+ break;
+ }
+ }
+
+ if (non_ascii) {
+ size = string->length * 2 + 2;
+ buf = (char *)gs_alloc_bytes(ctx->memory, size, "pdfi_obj_string_str(data)");
+ if (buf == NULL)
+ return_error(gs_error_VMerror);
+ buf[0] = '<';
+ for (i=0,ptr=string->data;i<string_len;i++,ptr++) {
+ snprintf(buf+2*i+1, 3, "%02X", *ptr);
+ }
+ buf[size-1] = '>';
+ } else {
+ size = string->length + 2 + num_esc;
+ buf = (char *)gs_alloc_bytes(ctx->memory, size, "pdfi_obj_string_str(data)");
+ if (buf == NULL)
+ return_error(gs_error_VMerror);
+ buf[0] = '(';
+ bufptr = buf + 1;
+ for (i=0,ptr=string->data;i<string_len;i++) {
+ switch (*ptr) {
+ case '(':
+ case ')':
+ case '\\':
+ *bufptr++ = '\\';
+ break;
+ default:
+ break;
+ }
+ *bufptr++ = *ptr++;
+ }
+ buf[size-1] = ')';
+ }
+
+
+ *len = size;
+ *data = (byte *)buf;
+ return code;
+}
+
+static int pdfi_obj_array_str(pdf_context *ctx, pdf_obj *obj, byte **data, int *len)
+{
+ int code = 0;
+ pdf_array *array = (pdf_array *)obj;
+ pdf_obj *object = NULL;
+ byte *itembuf = NULL;
+ int itemsize;
+ pdfi_bufstream_t bufstream;
+ uint64_t index, arraysize;
+
+ code = pdfi_bufstream_init(ctx, &bufstream);
+ if (code < 0) goto exit;
+
+ code = pdfi_bufstream_write(ctx, &bufstream, (byte *)"[", 1);
+ if (code < 0) goto exit;
+
+ arraysize = pdfi_array_size(array);
+ for (index = 0; index < arraysize; index++) {
+ code = pdfi_array_get_no_deref(ctx, array, index, &object);
+ if (code < 0) goto exit;
+
+ code = pdfi_obj_to_string(ctx, object, &itembuf, &itemsize);
+ if (code < 0) goto exit;
+
+ code = pdfi_bufstream_write(ctx, &bufstream, itembuf, itemsize);
+ if (code < 0) goto exit;
+
+ gs_free_object(ctx->memory, itembuf, "pdfi_obj_array_str(itembuf)");
+ itembuf = NULL;
+ itemsize = 0;
+ pdfi_countdown(object);
+ object = NULL;
+
+ /* Put a space between elements unless last item */
+ if (index+1 != arraysize) {
+ code = pdfi_bufstream_write(ctx, &bufstream, (byte *)" ", 1);
+ if (code < 0) goto exit;
+ }
+ }
+
+ code = pdfi_bufstream_write(ctx, &bufstream, (byte *)"]", 1);
+ if (code < 0) goto exit;
+
+ /* Now copy the results out into the string we can keep */
+ code = pdfi_bufstream_copy(ctx, &bufstream, data, len);
+
+ exit:
+ if (itembuf)
+ gs_free_object(ctx->memory, itembuf, "pdfi_obj_array_str(itembuf)");
+ pdfi_bufstream_free(ctx, &bufstream);
+ pdfi_countdown(object);
+ return code;
+}
+
+static int pdfi_obj_stream_str(pdf_context *ctx, pdf_obj *obj, byte **data, int *len)
+{
+ int code = 0;
+ byte *buf;
+ pdf_stream *stream = (pdf_stream *)obj;
+ int64_t bufsize;
+ pdf_indirect_ref *streamref = NULL;
+
+ /* TODO: How to deal with stream dictionaries?
+ * /AP is one example that has special handling (up in pdf_annot.c), but there are others.
+ * See 'pushpin' annotation in annotations-galore_II.ps
+ *
+ * This will just literally grab the stream data.
+ */
+ if (stream->is_marking) {
+ code = pdfi_stream_to_buffer(ctx, stream, &buf, &bufsize);
+ if (code < 0) goto exit;
+ *data = buf;
+ *len = (int)bufsize;
+ } else {
+ /* Create an indirect ref for the stream */
+ code = pdfi_object_alloc(ctx, PDF_INDIRECT, 0, (pdf_obj **)&streamref);
+ if (code < 0) goto exit;
+ pdfi_countup(streamref);
+ streamref->ref_object_num = stream->object_num;
+ streamref->ref_generation_num = stream->generation_num;
+ code = pdfi_obj_indirect_str(ctx, (pdf_obj *)streamref, data, len);
+ }
+
+ exit:
+ pdfi_countdown(streamref);
+ return code;
+}
+
+/* This fetches without dereferencing. If you want to see the references inline,
+ * then you need to pre-resolve them. See pdfi_resolve_indirect().
+ */
+static int pdfi_obj_dict_str(pdf_context *ctx, pdf_obj *obj, byte **data, int *len)
+{
+ int code = 0;
+ pdf_dict *dict = (pdf_dict *)obj;
+ pdf_name *Key = NULL;
+ pdf_obj *Value = NULL;
+ byte *itembuf = NULL;
+ int itemsize;
+ pdfi_bufstream_t bufstream;
+ uint64_t index, dictsize;
+ uint64_t itemnum = 0;
+
+ code = pdfi_bufstream_init(ctx, &bufstream);
+ if (code < 0) goto exit;
+
+ dictsize = pdfi_dict_entries(dict);
+ /* Handle empty dict specially */
+ if (dictsize == 0) {
+ code = pdfi_bufstream_write(ctx, &bufstream, (byte *)"<< >>", 5);
+ if (code < 0)
+ goto exit;
+ goto exit_copy;
+ }
+
+ code = pdfi_bufstream_write(ctx, &bufstream, (byte *)"<<\n", 3);
+ if (code < 0) goto exit;
+
+ /* Note: We specifically fetch without dereferencing, so there will be no circular
+ * references to handle here.
+ */
+ /* Get each (key,val) pair from dict and setup param for it */
+ code = pdfi_dict_key_first(ctx, dict, (pdf_obj **)&Key, &index);
+ while (code >= 0) {
+ code = pdfi_obj_to_string(ctx, (pdf_obj *)Key, &itembuf, &itemsize);
+ if (code < 0) goto exit;
+
+ code = pdfi_bufstream_write(ctx, &bufstream, itembuf, itemsize);
+ if (code < 0) goto exit;
+
+ gs_free_object(ctx->memory, itembuf, "pdfi_obj_dict_str(itembuf)");
+ itembuf = NULL;
+ itemsize = 0;
+
+ /* Put a space between elements */
+ code = pdfi_bufstream_write(ctx, &bufstream, (byte *)" ", 1);
+ if (code < 0) goto exit;
+
+ /* No dereference */
+ code = pdfi_dict_get_no_deref(ctx, dict, (const pdf_name *)Key, &Value);
+ if (code < 0) goto exit;
+ code = pdfi_obj_to_string(ctx, Value, &itembuf, &itemsize);
+ if (code < 0) goto exit;
+
+ code = pdfi_bufstream_write(ctx, &bufstream, itembuf, itemsize);
+ if (code < 0) goto exit;
+
+ gs_free_object(ctx->memory, itembuf, "pdfi_obj_dict_str(itembuf)");
+ itembuf = NULL;
+ itemsize = 0;
+
+ pdfi_countdown(Value);
+ Value = NULL;
+ pdfi_countdown(Key);
+ Key = NULL;
+
+ code = pdfi_dict_key_next(ctx, dict, (pdf_obj **)&Key, &index);
+ if (code == gs_error_undefined) {
+ code = 0;
+ break;
+ }
+ if (code < 0) goto exit;
+
+ /* Put a space between elements */
+ if (++itemnum != dictsize) {
+ code = pdfi_bufstream_write(ctx, &bufstream, (byte *)" ", 1);
+ if (code < 0) goto exit;
+ }
+ }
+ if (code < 0) goto exit;
+
+ code = pdfi_bufstream_write(ctx, &bufstream, (byte *)"\n>>", 3);
+ if (code < 0) goto exit;
+
+ exit_copy:
+ /* Now copy the results out into the string we can keep */
+ code = pdfi_bufstream_copy(ctx, &bufstream, data, len);
+
+ exit:
+ if (itembuf)
+ gs_free_object(ctx->memory, itembuf, "pdfi_obj_dict_str(itembuf)");
+ pdfi_countdown(Key);
+ pdfi_countdown(Value);
+ pdfi_bufstream_free(ctx, &bufstream);
+ return code;
+}
+
+obj_str_dispatch_t obj_str_dispatch[] = {
+ {PDF_NAME, pdfi_obj_name_str},
+ {PDF_ARRAY, pdfi_obj_array_str},
+ {PDF_REAL, pdfi_obj_real_str},
+ {PDF_INT, pdfi_obj_int_str},
+ {PDF_BOOL, pdfi_obj_bool_str},
+ {PDF_STRING, pdfi_obj_string_str},
+ {PDF_DICT, pdfi_obj_dict_str},
+ {PDF_STREAM, pdfi_obj_stream_str},
+ {PDF_INDIRECT, pdfi_obj_indirect_str},
+ {PDF_NULL, pdfi_obj_null_str},
+ {0, NULL}
+};
+
+/* Recursive function to build a string from an object
+ */
+int pdfi_obj_to_string(pdf_context *ctx, pdf_obj *obj, byte **data, int *len)
+{
+ obj_str_dispatch_t *dispatch_ptr;
+ int code = 0;
+
+ *data = NULL;
+ *len = 0;
+ for (dispatch_ptr = obj_str_dispatch; dispatch_ptr->func; dispatch_ptr ++) {
+ if (obj->type == dispatch_ptr->type) {
+ code = dispatch_ptr->func(ctx, obj, data, len);
+ goto exit;
+ }
+ }
+ /* Not implemented, use default */
+ code = pdfi_obj_default_str(ctx, obj, data, len);
+ exit:
+ return code;
+}
+
+/*********** END obj_to_string module ************/
diff --git a/pdf/pdf_obj.h b/pdf/pdf_obj.h
new file mode 100644
index 00000000..99c9a178
--- /dev/null
+++ b/pdf/pdf_obj.h
@@ -0,0 +1,28 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+#ifndef PDF_OBJECTS
+#define PDF_OBJECTS
+
+int pdfi_object_alloc(pdf_context *ctx, pdf_obj_type type, unsigned int size, pdf_obj **obj);
+void pdfi_free_object(pdf_obj *o);
+int pdfi_obj_to_string(pdf_context *ctx, pdf_obj *obj, byte **data, int *len);
+int pdfi_obj_dict_to_stream(pdf_context *ctx, pdf_dict *dict, pdf_stream **stream, bool do_convert);
+int pdfi_obj_charstr_to_string(pdf_context *ctx, const char *charstr, pdf_string **string);
+int pdfi_obj_charstr_to_name(pdf_context *ctx, const char *charstr, pdf_name **name);
+int pdfi_obj_get_label(pdf_context *ctx, pdf_obj *obj, char **label);
+int pdfi_num_alloc(pdf_context *ctx, double d, pdf_num **num);
+
+#endif
diff --git a/pdf/pdf_optcontent.c b/pdf/pdf_optcontent.c
new file mode 100644
index 00000000..d0dab6c6
--- /dev/null
+++ b/pdf/pdf_optcontent.c
@@ -0,0 +1,510 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Optional Content routines */
+
+#include "pdf_int.h"
+#include "pdf_stack.h"
+#include "pdf_misc.h"
+#include "pdf_gstate.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_doc.h"
+#include "pdf_optcontent.h"
+
+
+/* Find the default value for an ocdict, based on contents of OCProperties */
+/* NOTE: the spec says that if BaseState is present, it won't be set to "OFF",
+ * but this doesn't seem to be the case (Bug 691491). Also, the spec
+ * says the ON and OFF arrays are redundant in certain cases. We just
+ * look at everything anyway.
+ * Default is going to be visible unless anything here indicates that it
+ * should be turned off.
+ */
+static bool
+pdfi_get_default_OCG_val(pdf_context *ctx, pdf_dict *ocdict)
+{
+ bool is_visible = true;
+ pdf_dict *D = NULL;
+ pdf_obj *BaseState = NULL;
+ pdf_array *OFF = NULL;
+ pdf_array *ON = NULL;
+ int code;
+
+ if (ctx->OCProperties == NULL)
+ return is_visible;
+
+ code = pdfi_dict_knownget_type(ctx, ctx->OCProperties, "D", PDF_DICT, (pdf_obj **)&D);
+ if (code <= 0)
+ goto cleanup;
+
+ code = pdfi_dict_knownget_type(ctx, D, "BaseState", PDF_NAME, &BaseState);
+ if (code < 0) {
+ goto cleanup;
+ }
+ if (code > 0) {
+ if (pdfi_name_is((pdf_name *)BaseState, "OFF")) {
+ is_visible = false;
+ }
+ }
+
+ if (!is_visible) {
+ code = pdfi_dict_knownget_type(ctx, D, "ON", PDF_ARRAY, (pdf_obj **)&ON);
+ if (code < 0)
+ goto cleanup;
+ if (code > 0) {
+ if (pdfi_array_known(ctx, ON, (pdf_obj *)ocdict, NULL))
+ is_visible = true;
+ }
+ }
+
+ if (is_visible) {
+ code = pdfi_dict_knownget_type(ctx, D, "OFF", PDF_ARRAY, (pdf_obj **)&OFF);
+ if (code < 0)
+ goto cleanup;
+ if (code > 0) {
+ if (pdfi_array_known(ctx, OFF, (pdf_obj *)ocdict, NULL))
+ is_visible = false;
+ }
+ }
+
+
+ cleanup:
+ pdfi_countdown(BaseState);
+ pdfi_countdown(D);
+ pdfi_countdown(OFF);
+ pdfi_countdown(ON);
+ return is_visible;
+}
+
+/* Check Usage for an OCG */
+static bool
+pdfi_oc_check_OCG_usage(pdf_context *ctx, pdf_dict *ocdict)
+{
+ bool is_visible = true;
+ int code;
+ pdf_dict *Usage = NULL;
+ pdf_dict *dict = NULL;
+ pdf_obj *name = NULL;
+
+ /* Check Usage to see if it has additional info */
+ code = pdfi_dict_knownget_type(ctx, ocdict, "Usage", PDF_DICT, (pdf_obj **)&Usage);
+ if (code <= 0) {
+ /* No Usage, so we're done */
+ goto cleanup;
+ }
+
+ if (ctx->args.printed) {
+ code = pdfi_dict_knownget_type(ctx, ocdict, "Print", PDF_DICT, (pdf_obj **)&dict);
+ if (code <= 0)
+ goto cleanup;
+ code = pdfi_dict_knownget_type(ctx, dict, "PrintState", PDF_NAME, &name);
+ if (code <= 0)
+ goto cleanup;
+ } else {
+ code = pdfi_dict_knownget_type(ctx, ocdict, "View", PDF_DICT, (pdf_obj **)&dict);
+ if (code <= 0)
+ goto cleanup;
+ code = pdfi_dict_knownget_type(ctx, dict, "ViewState", PDF_NAME, &name);
+ if (code <= 0)
+ goto cleanup;
+ }
+ if (pdfi_name_strcmp((pdf_name *)name, "OFF")) {
+ is_visible = false;
+ }
+
+ cleanup:
+ pdfi_countdown(Usage);
+ pdfi_countdown(dict);
+ pdfi_countdown(name);
+
+ return is_visible;
+}
+
+typedef enum {
+ P_AnyOn,
+ P_AllOn,
+ P_AllOff,
+ P_AnyOff
+} ocmd_p_type;
+
+static bool
+pdfi_oc_check_OCMD_array(pdf_context *ctx, pdf_array *array, ocmd_p_type type)
+{
+ bool is_visible;
+ uint64_t i;
+ int code;
+ pdf_obj *val = NULL;
+
+ /* Setup default */
+ switch (type) {
+ case P_AnyOn:
+ case P_AnyOff:
+ is_visible = false;
+ break;
+ case P_AllOn:
+ case P_AllOff:
+ is_visible = true;
+ break;
+ }
+
+ for (i=0; i<pdfi_array_size(array); i++) {
+ bool vis;
+
+ code = pdfi_array_get(ctx, array, i, &val);
+ if (code < 0) continue;
+ if (val->type != PDF_DICT) {
+ dmprintf1(ctx->memory, "WARNING: OCMD array contains item type %d, expected PDF_DICT or PDF_NULL\n", val->type);
+ pdfi_countdown(val);
+ val = NULL;
+ continue;
+ }
+
+ vis = pdfi_get_default_OCG_val(ctx, (pdf_dict *)val);
+ switch (type) {
+ case P_AnyOn:
+ /* visible if any is on */
+ if (vis) {
+ is_visible = true;
+ goto cleanup;
+ }
+ break;
+ case P_AllOn:
+ /* visible if all on */
+ if (!vis) {
+ is_visible = false;
+ goto cleanup;
+ }
+ break;
+ case P_AllOff:
+ /* visible if all are off */
+ if (vis) {
+ is_visible = false;
+ goto cleanup;
+ }
+ break;
+ case P_AnyOff:
+ /* visible if any is off */
+ if (!vis) {
+ is_visible = true;
+ goto cleanup;
+ }
+ break;
+ }
+ pdfi_countdown(val);
+ val = NULL;
+ }
+
+ cleanup:
+ pdfi_countdown(val);
+ return is_visible;
+}
+
+static bool
+pdfi_oc_check_OCMD(pdf_context *ctx, pdf_dict *ocdict)
+{
+ bool is_visible = true;
+ int code;
+ pdf_obj *VE = NULL;
+ pdf_obj *obj = NULL;
+ pdf_obj *Pname = NULL;
+ pdf_dict *OCGs_dict = NULL; /* alias, don't need to free */
+ pdf_array *OCGs_array = NULL; /* alias, don't need to free */
+ ocmd_p_type Ptype = P_AnyOn;
+
+ /* TODO: We don't support this, so log a warning and ignore */
+ code = pdfi_dict_knownget_type(ctx, ocdict, "VE", PDF_ARRAY, &VE);
+ if (code > 0) {
+ dmprintf(ctx->memory, "WARNING: OCMD contains VE, which is not supported (ignoring)\n");
+ }
+
+ code = pdfi_dict_knownget(ctx, ocdict, "OCGs", &obj);
+ if (code <= 0)
+ goto cleanup;
+ if (obj->type == PDF_ARRAY) {
+ OCGs_array = (pdf_array *)obj;
+ } else if (obj->type == PDF_DICT) {
+ OCGs_dict = (pdf_dict *)obj;
+ } else {
+ goto cleanup;
+ }
+
+ code = pdfi_dict_knownget_type(ctx, ocdict, "P", PDF_NAME, &Pname);
+ if (code < 0)
+ goto cleanup;
+ if (code == 0 || pdfi_name_is((pdf_name *)Pname, "AnyOn")) {
+ Ptype = P_AnyOn;
+ } else if (pdfi_name_is((pdf_name *)Pname, "AllOn")) {
+ Ptype = P_AllOn;
+ } else if (pdfi_name_is((pdf_name *)Pname, "AnyOff")) {
+ Ptype = P_AnyOff;
+ } else if (pdfi_name_is((pdf_name *)Pname, "AllOff")) {
+ Ptype = P_AllOff;
+ } else {
+ Ptype = P_AnyOn;
+ }
+
+ if (OCGs_dict) {
+ switch (Ptype) {
+ case P_AnyOn:
+ case P_AllOn:
+ is_visible = pdfi_get_default_OCG_val(ctx, OCGs_dict);
+ break;
+ case P_AllOff:
+ case P_AnyOff:
+ is_visible = !pdfi_get_default_OCG_val(ctx, OCGs_dict);
+ break;
+ }
+ } else {
+ is_visible = pdfi_oc_check_OCMD_array(ctx, OCGs_array, Ptype);
+ }
+
+ cleanup:
+ pdfi_countdown(VE);
+ pdfi_countdown(obj);
+ pdfi_countdown(Pname);
+
+ return is_visible;
+}
+
+/* Check if an OCG or OCMD is visible, passing in OC dict */
+bool
+pdfi_oc_is_ocg_visible(pdf_context *ctx, pdf_dict *ocdict)
+{
+ pdf_name *type = NULL;
+ bool is_visible = true;
+ int code;
+
+ /* Type can be either OCMD or OCG.
+ */
+ code = pdfi_dict_knownget_type(ctx, ocdict, "Type", PDF_NAME, (pdf_obj **)&type);
+ if (code <= 0)
+ goto cleanup;
+
+ if (pdfi_name_is(type, "OCMD")) {
+ is_visible = pdfi_oc_check_OCMD(ctx, ocdict);
+ } else if (pdfi_name_is(type, "OCG")) {
+ is_visible = pdfi_get_default_OCG_val(ctx, ocdict);
+ if (is_visible)
+ is_visible = pdfi_oc_check_OCG_usage(ctx, ocdict);
+ } else {
+ char str[100];
+ memcpy(str, (const char *)type->data, type->length);
+ str[type->length] = '\0';
+ dmprintf1(ctx->memory, "WARNING: OC dict type is %s, expected OCG or OCMD\n", str);
+ }
+
+ cleanup:
+ pdfi_countdown(type);
+
+ if (ctx->args.pdfdebug) {
+ dmprintf2(ctx->memory, "OCG: OC Dict %d %s visible\n", ocdict->object_num,
+ is_visible ? "IS" : "IS NOT");
+ }
+ return is_visible;
+}
+
+#define NUM_CONTENT_LEVELS 100
+typedef struct {
+ byte *flags;
+ uint64_t num_off;
+ uint64_t max_flags;
+} pdfi_oc_levels_t;
+
+static int pdfi_oc_levels_init(pdf_context *ctx, pdfi_oc_levels_t **levels)
+{
+ byte *data;
+ pdfi_oc_levels_t *new;
+
+ *levels = NULL;
+
+ new = (pdfi_oc_levels_t *)gs_alloc_bytes(ctx->memory, sizeof(pdfi_oc_levels_t),
+ "pdfi_oc_levels_init (levels)");
+ if (!new)
+ return_error(gs_error_VMerror);
+
+ data = (byte *)gs_alloc_bytes(ctx->memory, NUM_CONTENT_LEVELS, "pdfi_oc_levels_init (data)");
+ if (!data) {
+ gs_free_object(ctx->memory, new, "pdfi_oc_levels_init (levels (error))");
+ return_error(gs_error_VMerror);
+ }
+ memset(data, 0, NUM_CONTENT_LEVELS);
+
+ new->flags = data;
+ new->num_off = 0;
+ new->max_flags = NUM_CONTENT_LEVELS;
+ *levels = new;
+
+ return 0;
+}
+
+static int pdfi_oc_levels_free(pdf_context *ctx, pdfi_oc_levels_t *levels)
+{
+ if (!levels)
+ return 0;
+ gs_free_object(ctx->memory, levels->flags, "pdfi_oc_levels_free (flags)");
+ gs_free_object(ctx->memory, levels, "pdfi_oc_levels_free (levels)");
+
+ return 0;
+}
+
+static int pdfi_oc_levels_set(pdf_context *ctx, pdfi_oc_levels_t *levels, uint64_t index)
+{
+ byte *new = NULL;
+ uint64_t newmax;
+
+ if (index > levels->max_flags) {
+ /* Expand the flags buffer */
+ newmax = levels->max_flags + NUM_CONTENT_LEVELS;
+ if (index > newmax)
+ return_error(gs_error_Fatal); /* shouldn't happen */
+ new = gs_alloc_bytes(ctx->memory, newmax, "pdfi_oc_levels_set (new data)");
+ if (!new)
+ return_error(gs_error_VMerror);
+ memset(new, 0, newmax);
+ memcpy(new, levels->flags, levels->max_flags);
+ gs_free_object(ctx->memory, levels->flags, "pdfi_oc_levels_set (old data)");
+ levels->flags = new;
+ levels->max_flags += NUM_CONTENT_LEVELS;
+ }
+
+ if (levels->flags[index] == 0)
+ levels->num_off ++;
+ levels->flags[index] = 1;
+ return 0;
+}
+
+static int pdfi_oc_levels_clear(pdf_context *ctx, pdfi_oc_levels_t *levels, uint64_t index)
+{
+ if (index > levels->max_flags)
+ return -1;
+ if (levels->flags[index] != 0)
+ levels->num_off --;
+ levels->flags[index] = 0;
+ return 0;
+}
+
+
+/* Test if content is turned off for this element.
+ */
+bool pdfi_oc_is_off(pdf_context *ctx)
+{
+ pdfi_oc_levels_t *levels = (pdfi_oc_levels_t *)ctx->OFFlevels;
+ uint64_t num_off = levels->num_off;
+
+ return (num_off != 0);
+}
+
+int pdfi_oc_init(pdf_context *ctx)
+{
+ int code;
+
+ ctx->BMClevel = 0;
+ if (ctx->OFFlevels) {
+ pdfi_oc_levels_free(ctx, ctx->OFFlevels);
+ ctx->OFFlevels = NULL;
+ }
+ code = pdfi_oc_levels_init(ctx, (pdfi_oc_levels_t **)&ctx->OFFlevels);
+ if (code < 0)
+ return code;
+
+ return 0;
+}
+
+int pdfi_oc_free(pdf_context *ctx)
+{
+ int code;
+
+ code = pdfi_oc_levels_free(ctx, (pdfi_oc_levels_t *)ctx->OFFlevels);
+ ctx->OFFlevels = NULL;
+ return code;
+}
+
+/* begin marked content sequence */
+/* TODO: Incomplete implementation, it is ignoring the argument */
+int pdfi_op_BMC(pdf_context *ctx)
+{
+ if (pdfi_count_stack(ctx) >= 1) {
+ pdfi_pop(ctx, 1);
+ } else
+ pdfi_clearstack(ctx);
+ ctx->BMClevel ++;
+ return 0;
+}
+
+/* begin marked content sequence with property list */
+/* TODO: Incomplete implementation, only tries to do something sensible for OC */
+int pdfi_op_BDC(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ pdf_name *tag = NULL;
+ pdf_name *properties = NULL;
+ pdf_dict *oc_dict = NULL;
+ int code = 0;
+ bool ocg_is_visible;
+
+ if (pdfi_count_stack(ctx) < 2) {
+ /* TODO: Flag error? */
+ pdfi_clearstack(ctx);
+ return 0;
+ }
+
+ ctx->BMClevel ++;
+
+ /* Check if second arg is OC and handle it if so */
+ tag = (pdf_name *)ctx->stack_top[-2];
+ if (tag->type != PDF_NAME)
+ goto exit;
+ if (!pdfi_name_is(tag, "OC"))
+ goto exit;
+
+ /* Check if first arg is a name and handle it if so */
+ /* TODO: spec says it could also be an inline dict that we should be able to handle,
+ * but I am just matching what gs does for now, and it doesn't handle that case.
+ */
+ properties = (pdf_name *)ctx->stack_top[-1];
+ if (tag->type != PDF_NAME)
+ goto exit;
+
+ /* If it's a name, look it up in Properties */
+ code = pdfi_find_resource(ctx, (unsigned char *)"Properties", properties,
+ (pdf_dict *)stream_dict, page_dict, (pdf_obj **)&oc_dict);
+ if (code != 0)
+ goto exit;
+ if (oc_dict->type != PDF_DICT)
+ goto exit;
+
+ /* Now we have an OC dict, see if it's visible */
+ ocg_is_visible = pdfi_oc_is_ocg_visible(ctx, oc_dict);
+ if (!ocg_is_visible)
+ code = pdfi_oc_levels_set(ctx, ctx->OFFlevels, ctx->BMClevel);
+
+ exit:
+ pdfi_pop(ctx, 2); /* pop args */
+ pdfi_countdown(oc_dict);
+ return code;
+}
+
+/* end marked content sequence */
+int pdfi_op_EMC(pdf_context *ctx)
+{
+ int code;
+
+ code = pdfi_oc_levels_clear(ctx, ctx->OFFlevels, ctx->BMClevel);
+
+ /* TODO: Should we flag error on too many EMC? */
+ if (ctx->BMClevel > 0)
+ ctx->BMClevel --;
+ return code;
+}
diff --git a/pdf/pdf_optcontent.h b/pdf/pdf_optcontent.h
new file mode 100644
index 00000000..aa25b017
--- /dev/null
+++ b/pdf/pdf_optcontent.h
@@ -0,0 +1,28 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+#ifndef PDF_OPTCONTENT
+#define PDF_OPTCONTENT
+
+bool pdfi_oc_is_ocg_visible(pdf_context *ctx, pdf_dict *ocdict);
+
+int pdfi_oc_init(pdf_context *ctx);
+int pdfi_oc_free(pdf_context *ctx);
+bool pdfi_oc_is_off(pdf_context *ctx);
+int pdfi_op_BMC(pdf_context *ctx);
+int pdfi_op_BDC(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict);
+int pdfi_op_EMC(pdf_context *ctx);
+
+#endif
diff --git a/pdf/pdf_page.c b/pdf/pdf_page.c
new file mode 100644
index 00000000..58833076
--- /dev/null
+++ b/pdf/pdf_page.c
@@ -0,0 +1,926 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Page-level operations for the PDF interpreter */
+
+#include "pdf_int.h"
+#include "pdf_stack.h"
+#include "pdf_doc.h"
+#include "pdf_deref.h"
+#include "pdf_page.h"
+#include "pdf_file.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_loop_detect.h"
+#include "pdf_colour.h"
+#include "pdf_trans.h"
+#include "pdf_gstate.h"
+#include "pdf_misc.h"
+#include "pdf_optcontent.h"
+#include "pdf_device.h"
+#include "pdf_annot.h"
+#include "pdf_check.h"
+#include "pdf_mark.h"
+
+#include "gscoord.h" /* for gs_concat() and others */
+#include "gspaint.h" /* For gs_erasepage() */
+#include "gsstate.h" /* For gs_initgraphics() */
+#include "gspath2.h" /* For gs_rectclip() */
+
+static int pdfi_process_page_contents(pdf_context *ctx, pdf_dict *page_dict)
+{
+ int i, code = 0;
+ pdf_obj *o, *o1;
+
+#if PURGE_CACHE_PER_PAGE
+ pdfi_purge_obj_cache(ctx);
+#endif
+
+ code = pdfi_dict_get(ctx, page_dict, "Contents", &o);
+ if (code == gs_error_undefined)
+ /* Don't throw an error if there are no contents, just render nothing.... */
+ return 0;
+ if (code < 0)
+ return code;
+
+ if (o->type == PDF_INDIRECT) {
+ if (((pdf_indirect_ref *)o)->ref_object_num == page_dict->object_num)
+ return_error(gs_error_circular_reference);
+
+ code = pdfi_dereference(ctx, ((pdf_indirect_ref *)o)->ref_object_num, ((pdf_indirect_ref *)o)->ref_generation_num, &o1);
+ pdfi_countdown(o);
+ if (code < 0) {
+ if (code == gs_error_VMerror)
+ return code;
+ return 0;
+ }
+ o = o1;
+ }
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) {
+ pdfi_countdown(o);
+ return code;
+ }
+
+ ctx->encryption.decrypt_strings = false;
+ if (o->type == PDF_ARRAY) {
+ pdf_array *a = (pdf_array *)o;
+
+ for (i=0;i < pdfi_array_size(a); i++) {
+ pdf_indirect_ref *r;
+ code = pdfi_array_get_no_deref(ctx, a, i, (pdf_obj **)&r);
+ if (code < 0)
+ goto page_error;
+ if (r->type == PDF_STREAM) {
+ code = pdfi_interpret_content_stream(ctx, NULL, (pdf_stream *)r, page_dict);
+ pdfi_countdown(r);
+ if (code < 0)
+ goto page_error;
+ } else {
+ if (r->type != PDF_INDIRECT) {
+ pdfi_countdown(r);
+ code = gs_note_error(gs_error_typecheck);
+ goto page_error;
+ } else {
+ if (r->ref_object_num == page_dict->object_num) {
+ pdfi_countdown(r);
+ code = gs_note_error(gs_error_circular_reference);
+ goto page_error;
+ }
+ code = pdfi_dereference(ctx, r->ref_object_num, r->ref_generation_num, &o1);
+ pdfi_countdown(r);
+ if (code < 0) {
+ if (code != gs_error_VMerror || ctx->args.pdfstoponerror == false)
+ code = 0;
+ goto page_error;
+ }
+ if (o1->type != PDF_STREAM) {
+ pdfi_countdown(o1);
+ code = gs_note_error(gs_error_typecheck);
+ goto page_error;
+ }
+ code = pdfi_interpret_content_stream(ctx, NULL, (pdf_stream *)o1, page_dict);
+ pdfi_countdown(o1);
+ if (code < 0) {
+ if (code == gs_error_VMerror || ctx->args.pdfstoponerror == true)
+ goto page_error;
+ }
+ }
+ }
+ }
+ } else {
+ if (o->type == PDF_STREAM) {
+ code = pdfi_interpret_content_stream(ctx, NULL, (pdf_stream *)o, page_dict);
+ } else {
+ pdfi_countdown(o);
+ ctx->encryption.decrypt_strings = true;
+ return_error(gs_error_typecheck);
+ }
+ }
+page_error:
+ ctx->encryption.decrypt_strings = true;
+ pdfi_clearstack(ctx);
+ pdfi_grestore(ctx);
+ pdfi_countdown(o);
+ return code;
+}
+
+/* Render one page (including annotations) (see pdf_main.ps/showpagecontents) */
+static int pdfi_process_one_page(pdf_context *ctx, pdf_dict *page_dict)
+{
+ stream_save local_entry_save;
+ int code, code1;
+
+ /* Save the current stream state, for later cleanup, in a local variable */
+ local_save_stream_state(ctx, &local_entry_save);
+ initialise_stream_save(ctx);
+
+ code = pdfi_process_page_contents(ctx, page_dict);
+
+ /* Put our state back the way it was before we ran the contents
+ * and check if the stream had problems
+ */
+#if PROBE_STREAMS
+ if (ctx->pgs->level > ctx->current_stream_save.gsave_level ||
+ pdfi_count_stack(ctx) > ctx->current_stream_save.stack_count)
+ code = ((pdf_context *)0)->first_page;
+#endif
+
+ cleanup_context_interpretation(ctx, &local_entry_save);
+ local_restore_stream_state(ctx, &local_entry_save);
+
+ code1 = pdfi_do_annotations(ctx, page_dict);
+ if (code > 0) code = code1;
+
+ code1 = pdfi_do_acroform(ctx, page_dict);
+ if (code > 0) code = code1;
+
+ return code;
+}
+
+/* See pdf_PDF2PS_matrix and .pdfshowpage_Install */
+static void pdfi_set_ctm(pdf_context *ctx)
+{
+ gs_matrix mat;
+
+ /* Adjust for page.UserUnits */
+ mat.xx = ctx->page.UserUnit;
+ mat.xy = 0;
+ mat.yx = 0;
+ mat.yy = ctx->page.UserUnit;
+ mat.tx = 0;
+ mat.ty = 0;
+ gs_concat(ctx->pgs, &mat);
+
+ /* We need to make sure the default matrix is properly set.
+ * If we do gs_initgraphics() later (such as for annotations)
+ * then it uses this default matrix if it is set.
+ * Needed for page rotations to work correctly with Annotations.
+ */
+ gs_setdefaultmatrix(ctx->pgs, &ctm_only(ctx->pgs));
+
+}
+
+/* Get .MediaSize from the device to setup page.Size in context */
+static int pdfi_get_media_size(pdf_context *ctx, pdf_dict *page_dict)
+{
+ pdf_array *a = NULL, *default_media = NULL;
+ double d[4];
+ int code = 0;
+ uint64_t i;
+ double userunit = 1.0;
+
+ code = pdfi_dict_get_type(ctx, page_dict, "MediaBox", PDF_ARRAY, (pdf_obj **)&default_media);
+ if (code < 0) {
+ pdfi_set_warning(ctx, code, NULL, W_PDF_BAD_MEDIABOX, "pdfi_get_media_size", NULL);
+ code = gs_erasepage(ctx->pgs);
+ return 0;
+ }
+
+ if (ctx->args.usecropbox) {
+ if (a != NULL)
+ pdfi_countdown(a);
+ (void)pdfi_dict_get_type(ctx, page_dict, "CropBox", PDF_ARRAY, (pdf_obj **)&a);
+ }
+ if (ctx->args.useartbox) {
+ if (a != NULL)
+ pdfi_countdown(a);
+ (void)pdfi_dict_get_type(ctx, page_dict, "ArtBox", PDF_ARRAY, (pdf_obj **)&a);
+ }
+ if (ctx->args.usebleedbox) {
+ if (a != NULL)
+ pdfi_countdown(a);
+ (void)pdfi_dict_get_type(ctx, page_dict, "BleedBox", PDF_ARRAY, (pdf_obj **)&a);
+ }
+ if (ctx->args.usetrimbox) {
+ if (a != NULL)
+ pdfi_countdown(a);
+ (void)pdfi_dict_get_type(ctx, page_dict, "TrimBox", PDF_ARRAY, (pdf_obj **)&a);
+ }
+ if (a == NULL) {
+ a = default_media;
+ }
+
+ if (!ctx->args.nouserunit) {
+ (void)pdfi_dict_knownget_number(ctx, page_dict, "UserUnit", &userunit);
+ }
+ ctx->page.UserUnit = userunit;
+
+ for (i=0;i<4;i++) {
+ code = pdfi_array_get_number(ctx, a, i, &d[i]);
+ d[i] *= userunit;
+ }
+ pdfi_countdown(a);
+
+ normalize_rectangle(d);
+ memcpy(ctx->page.Size, d, 4 * sizeof(double));
+
+ return code;
+}
+
+static int pdfi_set_media_size(pdf_context *ctx, pdf_dict *page_dict)
+{
+ gs_c_param_list list;
+ gs_param_float_array fa;
+ pdf_array *a = NULL, *default_media = NULL;
+ float fv[2];
+ double d[4], d_crop[4];
+ gs_rect bbox;
+ int code, do_crop = false;
+ uint64_t i;
+ int64_t rotate = 0;
+ double userunit = 1.0;
+
+ code = pdfi_dict_get_type(ctx, page_dict, "MediaBox", PDF_ARRAY, (pdf_obj **)&default_media);
+ if (code < 0) {
+ pdfi_set_warning(ctx, code, NULL, W_PDF_BAD_MEDIABOX, "pdfi_get_media_size", NULL);
+ code = gs_erasepage(ctx->pgs);
+ return 0;
+ }
+
+ if (ctx->args.usecropbox) {
+ if (a != NULL)
+ pdfi_countdown(a);
+ (void)pdfi_dict_get_type(ctx, page_dict, "CropBox", PDF_ARRAY, (pdf_obj **)&a);
+ }
+ if (ctx->args.useartbox) {
+ if (a != NULL)
+ pdfi_countdown(a);
+ (void)pdfi_dict_get_type(ctx, page_dict, "ArtBox", PDF_ARRAY, (pdf_obj **)&a);
+ }
+ if (ctx->args.usebleedbox) {
+ if (a != NULL)
+ pdfi_countdown(a);
+ (void)pdfi_dict_get_type(ctx, page_dict, "BleedBox", PDF_ARRAY, (pdf_obj **)&a);
+ }
+ if (ctx->args.usetrimbox) {
+ if (a != NULL)
+ pdfi_countdown(a);
+ (void)pdfi_dict_get_type(ctx, page_dict, "TrimBox", PDF_ARRAY, (pdf_obj **)&a);
+ }
+ if (a == NULL) {
+ code = pdfi_dict_get_type(ctx, page_dict, "CropBox", PDF_ARRAY, (pdf_obj **)&a);
+ if (code >= 0 && pdfi_array_size(a) >= 4) {
+ for (i=0;i<4;i++) {
+ code = pdfi_array_get_number(ctx, a, i, &d_crop[i]);
+ d_crop[i] *= userunit;
+ }
+ pdfi_countdown(a);
+ normalize_rectangle(d_crop);
+ memcpy(ctx->page.Crop, d_crop, 4 * sizeof(double));
+ do_crop = true;
+ }
+ a = default_media;
+ }
+
+ if (!ctx->args.nouserunit) {
+ (void)pdfi_dict_knownget_number(ctx, page_dict, "UserUnit", &userunit);
+ }
+ ctx->page.UserUnit = userunit;
+
+ for (i=0;i<4;i++) {
+ code = pdfi_array_get_number(ctx, a, i, &d[i]);
+ d[i] *= userunit;
+ }
+ pdfi_countdown(a);
+
+ normalize_rectangle(d);
+ memcpy(ctx->page.Size, d, 4 * sizeof(double));
+
+ code = pdfi_dict_get_int(ctx, page_dict, "Rotate", &rotate);
+
+ rotate = rotate % 360;
+
+ switch(rotate) {
+ default:
+ case 0:
+ case 360:
+ case -180:
+ case 180:
+ fv[0] = (float)(d[2] - d[0]);
+ fv[1] = (float)(d[3] - d[1]);
+ break;
+ case -90:
+ case 90:
+ case -270:
+ case 270:
+ fv[1] = (float)(d[2] - d[0]);
+ fv[0] = (float)(d[3] - d[1]);
+ break;
+ }
+
+ fa.persistent = false;
+ fa.data = fv;
+ fa.size = 2;
+
+ /* ----- setup specific device parameters ----- */
+ gs_c_param_list_write(&list, ctx->memory);
+
+ code = param_write_float_array((gs_param_list *)&list, ".MediaSize", &fa);
+ if (code >= 0)
+ {
+ gx_device *dev = gs_currentdevice(ctx->pgs);
+
+ gs_c_param_list_read(&list);
+ code = gs_putdeviceparams(dev, (gs_param_list *)&list);
+ if (code < 0) {
+ gs_c_param_list_release(&list);
+ return code;
+ }
+ }
+ gs_c_param_list_release(&list);
+ /* ----- end setup specific device parameters ----- */
+
+ /* Resets the default matrix to NULL before doing initgraphics, because
+ * otherwise initgraphics would keep old matrix.
+ * (see pdfi_set_ctm())
+ */
+ gs_setdefaultmatrix(ctx->pgs, NULL);
+ gs_initgraphics(ctx->pgs);
+
+ switch(rotate) {
+ case 0:
+ break;
+ case -270:
+ case 90:
+ gs_translate(ctx->pgs, 0, fv[1]);
+ gs_rotate(ctx->pgs, -90);
+ break;
+ case -180:
+ case 180:
+ gs_translate(ctx->pgs, fv[0], fv[1]);
+ gs_rotate(ctx->pgs, 180);
+ break;
+ case -90:
+ case 270:
+ gs_translate(ctx->pgs, fv[0], 0);
+ gs_rotate(ctx->pgs, 90);
+ break;
+ default:
+ break;
+ }
+
+ if (do_crop) {
+ bbox.p.x = d_crop[0] - d[0];
+ bbox.p.y = d_crop[1] - d[1];
+ bbox.q.x = d_crop[2] - d[0];
+ bbox.q.y = d_crop[3] - d[1];
+
+ code = gs_rectclip(ctx->pgs, &bbox, 1);
+ if (code < 0)
+ return code;
+ }
+
+ gs_translate(ctx->pgs, d[0] * -1, d[1] * -1);
+
+ code = gs_erasepage(ctx->pgs);
+ return 0;
+}
+
+/* Setup default transfer functions */
+static void pdfi_setup_transfers(pdf_context *ctx)
+{
+ if (ctx->pgs->set_transfer.red == 0x00) {
+ ctx->page.DefaultTransfers[0].proc = gs_identity_transfer;
+ memset(ctx->page.DefaultTransfers[0].values, 0x00, transfer_map_size * sizeof(frac));
+ } else {
+ ctx->page.DefaultTransfers[0].proc = ctx->pgs->set_transfer.red->proc;
+ memcpy(ctx->page.DefaultTransfers[0].values, ctx->pgs->set_transfer.red->values, transfer_map_size * sizeof(frac));
+ }
+ if (ctx->pgs->set_transfer.green == 0x00) {
+ ctx->page.DefaultTransfers[1].proc = gs_identity_transfer;
+ memset(ctx->page.DefaultTransfers[1].values, 0x00, transfer_map_size * sizeof(frac));
+ } else {
+ ctx->page.DefaultTransfers[1].proc = ctx->pgs->set_transfer.green->proc;
+ memcpy(ctx->page.DefaultTransfers[1].values, ctx->pgs->set_transfer.green->values, transfer_map_size * sizeof(frac));
+ }
+ if (ctx->pgs->set_transfer.blue == 0x00) {
+ ctx->page.DefaultTransfers[2].proc = gs_identity_transfer;
+ memset(ctx->page.DefaultTransfers[2].values, 0x00, transfer_map_size * sizeof(frac));
+ } else {
+ ctx->page.DefaultTransfers[2].proc = ctx->pgs->set_transfer.blue->proc;
+ memcpy(ctx->page.DefaultTransfers[2].values, ctx->pgs->set_transfer.blue->values, transfer_map_size * sizeof(frac));
+ }
+ if (ctx->pgs->set_transfer.gray == 0x00) {
+ ctx->page.DefaultTransfers[3].proc = gs_identity_transfer;
+ memset(ctx->page.DefaultTransfers[3].values, 0x00, transfer_map_size * sizeof(frac));
+ } else {
+ ctx->page.DefaultTransfers[3].proc = ctx->pgs->set_transfer.gray->proc;
+ memcpy(ctx->page.DefaultTransfers[3].values, ctx->pgs->set_transfer.gray->values, transfer_map_size * sizeof(frac));
+ }
+ if (ctx->pgs->black_generation == 0x00) {
+ ctx->page.DefaultBG.proc = gs_identity_transfer;
+ memset(ctx->page.DefaultBG.values, 0x00, transfer_map_size * sizeof(frac));
+ } else {
+ ctx->page.DefaultBG.proc = ctx->pgs->black_generation->proc;
+ memcpy(ctx->page.DefaultBG.values, ctx->pgs->black_generation->values, transfer_map_size * sizeof(frac));
+ }
+ if (ctx->pgs->undercolor_removal == 0x00) {
+ ctx->page.DefaultUCR.proc = gs_identity_transfer;
+ memset(ctx->page.DefaultUCR.values, 0x00, transfer_map_size * sizeof(frac));
+ } else {
+ ctx->page.DefaultUCR.proc = ctx->pgs->undercolor_removal->proc;
+ memcpy(ctx->page.DefaultUCR.values, ctx->pgs->undercolor_removal->values, transfer_map_size * sizeof(frac));
+ }
+}
+
+static int store_box(pdf_context *ctx, float *box, pdf_array *a)
+{
+ double f;
+ int code = 0, i;
+
+ for (i=0;i < 4;i++) {
+ code = pdfi_array_get_number(ctx, a, (uint64_t)i, &f);
+ if (code < 0)
+ return code;
+ box[i] = (float)f;
+ }
+ return 0;
+}
+
+int pdfi_page_info(pdf_context *ctx, uint64_t page_num, pdf_info_t *info)
+{
+ int code = 0;
+ pdf_dict *page_dict = NULL;
+ pdf_array *a = NULL;
+ double dbl = 0.0;
+
+ code = pdfi_page_get_dict(ctx, page_num, &page_dict);
+ if (code < 0)
+ return code;
+
+ if (code > 0) {
+ code = gs_note_error(gs_error_unknownerror);
+ goto done;
+ }
+
+ code = pdfi_check_page(ctx, page_dict, false);
+ if (code < 0)
+ goto done;
+
+ info->boxes = BOX_NONE;
+ code = pdfi_dict_get_type(ctx, page_dict, "MediaBox", PDF_ARRAY, (pdf_obj **)&a);
+ if (code < 0)
+ pdfi_set_warning(ctx, code, NULL, W_PDF_BAD_MEDIABOX, "pdfi_page_info", NULL);
+
+ if (code >= 0) {
+ code = store_box(ctx, (float *)&info->MediaBox, a);
+ if (code < 0)
+ goto done;
+ info->boxes |= MEDIA_BOX;
+ pdfi_countdown(a);
+ a = NULL;
+ }
+
+ code = pdfi_dict_get_type(ctx, page_dict, "ArtBox", PDF_ARRAY, (pdf_obj **)&a);
+ if (code >= 0) {
+ code = store_box(ctx, (float *)&info->ArtBox, a);
+ if (code < 0)
+ goto done;
+ info->boxes |= ART_BOX;
+ pdfi_countdown(a);
+ a = NULL;
+ }
+
+ code = pdfi_dict_get_type(ctx, page_dict, "CropBox", PDF_ARRAY, (pdf_obj **)&a);
+ if (code >= 0) {
+ code = store_box(ctx, (float *)&info->CropBox, a);
+ if (code < 0)
+ goto done;
+ info->boxes |= CROP_BOX;
+ pdfi_countdown(a);
+ a = NULL;
+ }
+
+ code = pdfi_dict_get_type(ctx, page_dict, "TrimBox", PDF_ARRAY, (pdf_obj **)&a);
+ if (code >= 0) {
+ code = store_box(ctx, (float *)&info->TrimBox, a);
+ if (code < 0)
+ goto done;
+ info->boxes |= TRIM_BOX;
+ pdfi_countdown(a);
+ a = NULL;
+ }
+
+ code = pdfi_dict_get_type(ctx, page_dict, "BleedBox", PDF_ARRAY, (pdf_obj **)&a);
+ if (code >= 0) {
+ code = store_box(ctx, (float *)&info->BleedBox, a);
+ if (code < 0)
+ goto done;
+ info->boxes |= BLEED_BOX;
+ pdfi_countdown(a);
+ a = NULL;
+ }
+ code = 0;
+
+ dbl = info->Rotate = 0;
+ code = pdfi_dict_get_number(ctx, page_dict, "Rotate", &dbl);
+ code = 0;
+ info->Rotate = dbl;
+
+ dbl = info->UserUnit = 1;
+ code = pdfi_dict_get_number(ctx, page_dict, "UserUnit", &dbl);
+ code = 0;
+ info->UserUnit = dbl;
+
+ info->HasTransparency = ctx->page.has_transparency;
+ info->NumSpots = ctx->page.num_spots;
+
+done:
+ pdfi_countdown(a);
+ pdfi_countdown(page_dict);
+ return code;
+}
+
+int pdfi_page_get_dict(pdf_context *ctx, uint64_t page_num, pdf_dict **dict)
+{
+ int code = 0;
+ uint64_t page_offset = 0;
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ return code;
+
+ if (ctx->PagesTree == NULL) {
+ pdf_obj *o = NULL;
+ pdf_name *n = NULL;
+ /* The only way this should be true is if the Pages entry in the Root dictionary
+ * points to a single instance of a Page dictionary, instead of to a Pages dictionary.
+ * in which case, simply retrieve that dictionary and return.
+ */
+ code = pdfi_dict_get(ctx, ctx->Root, "Pages", &o);
+ if (code < 0)
+ goto page_error;
+ if (o->type != PDF_DICT) {
+ code = gs_note_error(gs_error_typecheck);
+ goto page_error;
+ }
+ code = pdfi_dict_get_type(ctx, (pdf_dict *)o, "Type", PDF_NAME, (pdf_obj **)&n);
+ if (code == 0) {
+ if(pdfi_name_is(n, "Page")) {
+ *dict = (pdf_dict *)o;
+ pdfi_countup(*dict);
+ } else
+ code = gs_note_error(gs_error_undefined);
+ }
+page_error:
+ pdfi_loop_detector_cleartomark(ctx);
+ pdfi_countdown(o);
+ pdfi_countdown(n);
+ return code;
+ }
+
+ code = pdfi_loop_detector_add_object(ctx, ctx->PagesTree->object_num);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_get_page_dict(ctx, ctx->PagesTree, page_num, &page_offset, dict, NULL);
+ if (code > 0)
+ code = gs_error_unknownerror;
+
+ /* Cache the page_dict number in page_array */
+ if (*dict)
+ ctx->page_array[page_num] = (*dict)->object_num;
+
+ exit:
+ pdfi_loop_detector_cleartomark(ctx);
+ return code;
+}
+
+/* Find the page number that corresponds to a page dictionary
+ * Uses page_array cache to minimize the number of times a page_dict needs to
+ * be fetched, because this is expensive.
+ */
+int pdfi_page_get_number(pdf_context *ctx, pdf_dict *target_dict, uint64_t *page_num)
+{
+ uint64_t i;
+ int code = 0;
+ pdf_dict *page_dict = NULL;
+ uint32_t object_num;
+
+ for (i=0; i<ctx->num_pages; i++) {
+ /* If the page has been processed before, then its object_num should already
+ * be cached in the page_array, so check that first
+ */
+ object_num = ctx->page_array[i];
+ if (object_num == 0) {
+ /* It wasn't cached, so this will cache it */
+ code = pdfi_page_get_dict(ctx, i, &page_dict);
+ if (code < 0)
+ continue;
+ object_num = ctx->page_array[i];
+ }
+ if (target_dict->object_num == object_num) {
+ *page_num = i;
+ goto exit;
+ }
+
+ pdfi_countdown(page_dict);
+ page_dict = NULL;
+ }
+
+ code = gs_note_error(gs_error_undefined);
+
+ exit:
+ pdfi_countdown(page_dict);
+ return code;
+}
+
+static void release_page_DefaultSpaces(pdf_context *ctx)
+{
+ if (ctx->page.DefaultGray_cs != NULL) {
+ rc_decrement(ctx->page.DefaultGray_cs, "pdfi_page_render");
+ ctx->page.DefaultGray_cs = NULL;
+ }
+ if (ctx->page.DefaultRGB_cs != NULL) {
+ rc_decrement(ctx->page.DefaultRGB_cs, "pdfi_page_render");
+ ctx->page.DefaultRGB_cs = NULL;
+ }
+ if (ctx->page.DefaultCMYK_cs != NULL) {
+ rc_decrement(ctx->page.DefaultCMYK_cs, "pdfi_page_render");
+ ctx->page.DefaultCMYK_cs = NULL;
+ }
+}
+
+static int setup_page_DefaultSpaces(pdf_context *ctx, pdf_dict *page_dict)
+{
+ int code = 0;
+ pdf_dict *resources_dict = NULL, *colorspaces_dict = NULL;
+ pdf_obj *DefaultSpace = NULL;
+
+ /* First off, discard any dangling Default* colour spaces, just in case. */
+ release_page_DefaultSpaces(ctx);
+
+ if (ctx->args.NOSUBSTDEVICECOLORS)
+ return 0;
+
+ /* Create any required DefaultGray, DefaultRGB or DefaultCMYK
+ * spaces.
+ */
+ code = pdfi_dict_knownget(ctx, page_dict, "Resources", (pdf_obj **)&resources_dict);
+ if (code > 0) {
+ code = pdfi_dict_knownget(ctx, resources_dict, "ColorSpace", (pdf_obj **)&colorspaces_dict);
+ if (code > 0) {
+ code = pdfi_dict_knownget(ctx, colorspaces_dict, "DefaultGray", &DefaultSpace);
+ if (code > 0) {
+ gs_color_space *pcs;
+ code = pdfi_create_colorspace(ctx, DefaultSpace, NULL, page_dict, &pcs, false);
+ /* If any given Default* space fails simply ignore it, we wil then use the Device
+ * space instead, this is as per the spec.
+ */
+ if (code >= 0) {
+ ctx->page.DefaultGray_cs = pcs;
+ pdfi_set_colour_callback(pcs, ctx, NULL);
+ }
+ }
+ pdfi_countdown(DefaultSpace);
+ DefaultSpace = NULL;
+ code = pdfi_dict_knownget(ctx, colorspaces_dict, "DefaultRGB", &DefaultSpace);
+ if (code > 0) {
+ gs_color_space *pcs;
+ code = pdfi_create_colorspace(ctx, DefaultSpace, NULL, page_dict, &pcs, false);
+ /* If any given Default* space fails simply ignore it, we wil then use the Device
+ * space instead, this is as per the spec.
+ */
+ if (code >= 0) {
+ ctx->page.DefaultRGB_cs = pcs;
+ pdfi_set_colour_callback(pcs, ctx, NULL);
+ }
+ }
+ pdfi_countdown(DefaultSpace);
+ DefaultSpace = NULL;
+ code = pdfi_dict_knownget(ctx, colorspaces_dict, "DefaultCMYK", &DefaultSpace);
+ if (code > 0) {
+ gs_color_space *pcs;
+ code = pdfi_create_colorspace(ctx, DefaultSpace, NULL, page_dict, &pcs, false);
+ /* If any given Default* space fails simply ignore it, we wil then use the Device
+ * space instead, this is as per the spec.
+ */
+ if (code >= 0) {
+ ctx->page.DefaultCMYK_cs = pcs;
+ pdfi_set_colour_callback(pcs, ctx, NULL);
+ }
+ }
+ pdfi_countdown(DefaultSpace);
+ DefaultSpace = NULL;
+ }
+ }
+
+ pdfi_countdown(DefaultSpace);
+ pdfi_countdown(resources_dict);
+ pdfi_countdown(colorspaces_dict);
+ return 0;
+}
+
+int pdfi_page_render(pdf_context *ctx, uint64_t page_num, bool init_graphics)
+{
+ int code, code1=0;
+ pdf_dict *page_dict = NULL;
+ bool page_group_known = false;
+ pdf_dict *group_dict = NULL;
+ bool page_dict_error = false;
+ bool need_pdf14 = false; /* true if the device is needed and was successfully pushed */
+ int trans_depth = 0; /* -1 means special mode for transparency simulation */
+
+ if (page_num > ctx->num_pages)
+ return_error(gs_error_rangecheck);
+
+ if (ctx->args.pdfdebug)
+ dmprintf1(ctx->memory, "%% Processing Page %"PRIi64" content stream\n", page_num + 1);
+
+ code = pdfi_page_get_dict(ctx, page_num, &page_dict);
+ if (code < 0) {
+ char extra_info[256];
+
+ page_dict_error = true;
+ gs_sprintf(extra_info, "*** ERROR: Page %ld has invalid Page dict, skipping\n", page_num+1);
+ pdfi_set_error(ctx, 0, NULL, E_PDF_PAGEDICTERROR, "pdfi_page_render", extra_info);
+ if (code != gs_error_VMerror && !ctx->args.pdfstoponerror)
+ code = 0;
+ goto exit2;
+ }
+
+ pdfi_device_set_flags(ctx);
+
+ code = pdfi_check_page(ctx, page_dict, init_graphics);
+ if (code < 0)
+ goto exit2;
+
+ if (ctx->args.pdfdebug) {
+ dbgmprintf2(ctx->memory, "Current page %ld transparency setting is %d", page_num+1,
+ ctx->page.has_transparency);
+
+ if (ctx->device_state.spot_capable)
+ dbgmprintf1(ctx->memory, ", spots=%d\n", ctx->page.num_spots);
+ else
+ dbgmprintf(ctx->memory, "\n");
+ }
+
+ code = pdfi_dict_knownget_type(ctx, page_dict, "Group", PDF_DICT, (pdf_obj **)&group_dict);
+ if (code < 0)
+ goto exit2;
+ if (group_dict != NULL)
+ page_group_known = true;
+
+ pdfi_countdown(ctx->page.CurrentPageDict);
+ ctx->page.CurrentPageDict = page_dict;
+ pdfi_countup(ctx->page.CurrentPageDict);
+
+ /* In case we don't call pdfi_set_media_size, which sets this up.
+ * We shouldn't ever use it in that case, but best to be safe.
+ */
+ ctx->page.UserUnit = 1.0f;
+ /* If we are being called from the PDF interpreter then
+ * we need to set up the page and the default graphics state
+ * but if we are being called from PostScript we do *not*
+ * want to alter any of the graphics state or the media size.
+ */
+ /* TODO: I think this is a mix of things we might need to
+ * still be setting up.
+ * (for example, I noticed the blendmode and moved it outside the if)
+ */
+ if (init_graphics) {
+ code = pdfi_set_media_size(ctx, page_dict);
+ if (code < 0)
+ goto exit2;
+
+ pdfi_set_ctm(ctx);
+
+ } else {
+ /* Gets ctx->page.Size setup correctly
+ * TODO: Probably not right if the page is rotated?
+ * page.Size is needed by the transparency code,
+ * not sure where else it might be used, if anywhere.
+ */
+ pdfi_get_media_size(ctx, page_dict);
+ }
+
+ /* Write the various CropBox, TrimBox etc to the device */
+ pdfi_write_boxes_pdfmark(ctx, page_dict);
+
+ code = setup_page_DefaultSpaces(ctx, page_dict);
+ if (code < 0)
+ goto exit2;
+
+ pdfi_setup_transfers(ctx);
+
+ /* Set whether device needs OP support
+ * This needs to be before transparency device is pushed, if applicable
+ */
+ pdfi_trans_set_needs_OP(ctx);
+ pdfi_oc_init(ctx);
+
+ code = pdfi_gsave(ctx);
+ if (code < 0)
+ goto exit2;
+
+ /* Figure out if pdf14 device is needed.
+ * This can be either for normal transparency deviceN, or because we are using
+ * Overprint=/simulate for other devices
+ */
+ if (ctx->page.has_transparency) {
+ need_pdf14 = true;
+ if (ctx->page.simulate_op)
+ trans_depth = -1;
+ } else {
+ /* This is the case where we are simulating overprint without transparency */
+ if (ctx->page.simulate_op) {
+ need_pdf14 = true;
+ trans_depth = -1;
+ }
+ }
+ if (need_pdf14) {
+ /* We don't retain the PDF14 device */
+ code = gs_push_pdf14trans_device(ctx->pgs, false, false, trans_depth, ctx->page.num_spots);
+ if (code >= 0) {
+ if (page_group_known) {
+ code = pdfi_trans_begin_page_group(ctx, page_dict, group_dict);
+ /* If setting the page group failed for some reason, abandon the page group,
+ * but continue with the page
+ */
+ if (code < 0)
+ page_group_known = false;
+ }
+ } else {
+ /* Couldn't push the transparency compositor.
+ * This is probably fatal, but attempt to recover by abandoning transparency
+ */
+ ctx->page.has_transparency = false;
+ need_pdf14 = false;
+ }
+ }
+
+ /* Init a base_pgs graphics state for Patterns
+ * (this has to be after transparency device pushed, if applicable)
+ */
+ pdfi_set_DefaultQState(ctx, ctx->pgs);
+
+ /* Render one page (including annotations) */
+ code = pdfi_process_one_page(ctx, page_dict);
+
+ if (ctx->page.has_transparency && page_group_known) {
+ code1 = pdfi_trans_end_group(ctx);
+ }
+
+ pdfi_countdown(ctx->page.CurrentPageDict);
+ ctx->page.CurrentPageDict = NULL;
+
+ if (need_pdf14) {
+ if (code1 < 0) {
+ (void)gs_abort_pdf14trans_device(ctx->pgs);
+ goto exit1;
+ }
+
+ code = gs_pop_pdf14trans_device(ctx->pgs, false);
+ if (code < 0) {
+ goto exit1;
+ }
+ }
+
+ exit1:
+ pdfi_free_DefaultQState(ctx);
+ pdfi_grestore(ctx);
+ exit2:
+ pdfi_countdown(page_dict);
+ pdfi_countdown(group_dict);
+
+ release_page_DefaultSpaces(ctx);
+
+ if (code == 0 || (!ctx->args.pdfstoponerror && code != gs_error_stackoverflow))
+ if (!page_dict_error && ctx->finish_page != NULL)
+ code = ctx->finish_page(ctx);
+ return code;
+}
diff --git a/pdf/pdf_page.h b/pdf/pdf_page.h
new file mode 100644
index 00000000..b5fd3e2a
--- /dev/null
+++ b/pdf/pdf_page.h
@@ -0,0 +1,49 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Page-level operations for the PDF interpreter */
+
+#ifndef PDF_PAGE_OPERATORS
+#define PDF_PAGE_OPERATORS
+
+typedef enum pdfi_box_enum_e {
+ BOX_NONE = 0,
+ MEDIA_BOX = 1,
+ CROP_BOX = 2,
+ TRIM_BOX = 4,
+ ART_BOX = 8,
+ BLEED_BOX = 16
+}pdfi_box_enum;
+
+typedef struct {
+ bool HasTransparency;
+ int NumSpots;
+ pdfi_box_enum boxes;
+ float MediaBox[4];
+ float CropBox[4];
+ float ArtBox[4];
+ float BleedBox[4];
+ float TrimBox[4];
+ float Rotate;
+ float UserUnit;
+} pdf_info_t;
+
+int pdfi_page_render(pdf_context *ctx, uint64_t page_num, bool init_graphics);
+int pdfi_page_info(pdf_context *ctx, uint64_t page_num, pdf_info_t *info);
+int pdfi_page_graphics_begin(pdf_context *ctx);
+int pdfi_page_get_dict(pdf_context *ctx, uint64_t page_num, pdf_dict **dict);
+int pdfi_page_get_number(pdf_context *ctx, pdf_dict *target_dict, uint64_t *page_num);
+
+#endif
diff --git a/pdf/pdf_path.c b/pdf/pdf_path.c
new file mode 100644
index 00000000..ef6f1328
--- /dev/null
+++ b/pdf/pdf_path.c
@@ -0,0 +1,477 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Path operations for the PDF interpreter */
+
+#include "pdf_int.h"
+#include "pdf_gstate.h"
+#include "pdf_path.h"
+#include "pdf_stack.h"
+#include "pdf_trans.h"
+#include "gstypes.h"
+#include "pdf_optcontent.h"
+#include "gspath.h" /* For gs_moveto() and friends */
+#include "gspaint.h" /* For gs_fill() and friends */
+
+int pdfi_moveto (pdf_context *ctx)
+{
+ pdf_num *n1, *n2;
+ int code;
+ double x, y;
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_moveto", NULL);
+
+ if (pdfi_count_stack(ctx) < 2) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ n1 = (pdf_num *)ctx->stack_top[-1];
+ n2 = (pdf_num *)ctx->stack_top[-2];
+ if (n1->type == PDF_INT){
+ y = (double)n1->value.i;
+ } else{
+ if (n1->type == PDF_REAL) {
+ y = n1->value.d;
+ } else {
+ pdfi_pop(ctx, 2);
+ return_error(gs_error_typecheck);
+ }
+ }
+ if (n2->type == PDF_INT){
+ x = (double)n2->value.i;
+ } else{
+ if (n2->type == PDF_REAL) {
+ x = n2->value.d;
+ } else {
+ pdfi_pop(ctx, 2);
+ return_error(gs_error_typecheck);
+ }
+ }
+
+ code = gs_moveto(ctx->pgs, x, y);
+ pdfi_pop(ctx, 2);
+ return code;
+}
+
+int pdfi_lineto (pdf_context *ctx)
+{
+ pdf_num *n1, *n2;
+ int code;
+ double x, y;
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_lineto", NULL);
+
+ if (pdfi_count_stack(ctx) < 2) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ n1 = (pdf_num *)ctx->stack_top[-1];
+ n2 = (pdf_num *)ctx->stack_top[-2];
+ if (n1->type == PDF_INT){
+ y = (double)n1->value.i;
+ } else{
+ if (n1->type == PDF_REAL) {
+ y = n1->value.d;
+ } else {
+ pdfi_pop(ctx, 2);
+ return_error(gs_error_typecheck);
+ }
+ }
+ if (n2->type == PDF_INT){
+ x = (double)n2->value.i;
+ } else{
+ if (n2->type == PDF_REAL) {
+ x = n2->value.d;
+ } else {
+ pdfi_pop(ctx, 2);
+ return_error(gs_error_typecheck);
+ }
+ }
+
+ code = gs_lineto(ctx->pgs, x, y);
+ pdfi_pop(ctx, 2);
+ return code;
+}
+
+static int pdfi_fill_inner(pdf_context *ctx, bool use_eofill)
+{
+ int code=0, code1;
+ pdfi_trans_state_t state;
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_fill_inner", NULL);
+
+ if (pdfi_oc_is_off(ctx))
+ goto exit;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) goto exit;
+
+ code = pdfi_trans_setup(ctx, &state, NULL, TRANSPARENCY_Caller_Fill);
+ if (code == 0) {
+ if (use_eofill)
+ code = gs_eofill(ctx->pgs);
+ else
+ code = gs_fill(ctx->pgs);
+ code1 = pdfi_trans_teardown(ctx, &state);
+ if (code == 0) code = code1;
+ }
+
+ code1 = pdfi_grestore(ctx);
+ if (code == 0) code = code1;
+
+ exit:
+ code1 = pdfi_newpath(ctx);
+ if (code == 0) code = code1;
+
+ return code;
+}
+
+int pdfi_fill(pdf_context *ctx)
+{
+ return pdfi_fill_inner(ctx, false);
+}
+
+int pdfi_eofill(pdf_context *ctx)
+{
+ return pdfi_fill_inner(ctx, true);
+}
+
+int pdfi_stroke(pdf_context *ctx)
+{
+ int code=0, code1;
+ pdfi_trans_state_t state;
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_stroke", NULL);
+
+ if (pdfi_oc_is_off(ctx))
+ goto exit;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) goto exit;
+
+ gs_swapcolors_quick(ctx->pgs);
+ code = pdfi_trans_setup(ctx, &state, NULL, TRANSPARENCY_Caller_Stroke);
+ if (code == 0) {
+ code = gs_stroke(ctx->pgs);
+ code1 = pdfi_trans_teardown(ctx, &state);
+ if (code == 0) code = code1;
+ }
+ gs_swapcolors_quick(ctx->pgs);
+
+ code1 = pdfi_grestore(ctx);
+ if (code == 0) code = code1;
+
+ exit:
+ code1 = pdfi_newpath(ctx);
+ if (code == 0) code = code1;
+
+ return code;
+}
+
+int pdfi_closepath_stroke(pdf_context *ctx)
+{
+ int code;
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_closepath_stroke", NULL);
+
+ code = gs_closepath(ctx->pgs);
+ if (code == 0)
+ code = pdfi_stroke(ctx);
+ return code;
+}
+
+int pdfi_curveto(pdf_context *ctx)
+{
+ int i, code;
+ pdf_num *num;
+ double Values[6];
+
+ if (pdfi_count_stack(ctx) < 6) {
+ pdfi_clearstack(ctx);
+ pdfi_set_error(ctx, 0, NULL, E_PDF_STACKUNDERFLOWERROR, "pdfi_curveto", NULL);
+ return_error(gs_error_stackunderflow);
+ }
+
+ for (i=0;i < 6;i++){
+ num = (pdf_num *)ctx->stack_top[i - 6];
+ if (num->type != PDF_INT) {
+ if(num->type != PDF_REAL) {
+ pdfi_pop(ctx, 6);
+ return_error(gs_error_typecheck);
+ }
+ else
+ Values[i] = num->value.d;
+ } else {
+ Values[i] = (double)num->value.i;
+ }
+ }
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_curveto", NULL);
+
+ code = gs_curveto(ctx->pgs, Values[0], Values[1], Values[2], Values[3], Values[4], Values[5]);
+ pdfi_pop(ctx, 6);
+ return code;
+}
+
+int pdfi_v_curveto(pdf_context *ctx)
+{
+ int i, code;
+ pdf_num *num;
+ double Values[4];
+ gs_point pt;
+
+ if (pdfi_count_stack(ctx) < 4) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ for (i=0;i < 4;i++){
+ num = (pdf_num *)ctx->stack_top[i - 4];
+ if (num->type != PDF_INT) {
+ if(num->type != PDF_REAL) {
+ pdfi_pop(ctx, 4);
+ return_error(gs_error_typecheck);
+ }
+ else
+ Values[i] = num->value.d;
+ } else {
+ Values[i] = (double)num->value.i;
+ }
+ }
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_v_curveto", NULL);
+
+ code = gs_currentpoint(ctx->pgs, &pt);
+ if (code < 0) {
+ pdfi_pop(ctx, 4);
+ return code;
+ }
+
+ code = gs_curveto(ctx->pgs, pt.x, pt.y, Values[0], Values[1], Values[2], Values[3]);
+ pdfi_pop(ctx, 4);
+ return code;
+}
+
+int pdfi_y_curveto(pdf_context *ctx)
+{
+ int i, code;
+ pdf_num *num;
+ double Values[4];
+
+ if (pdfi_count_stack(ctx) < 4) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ for (i=0;i < 4;i++){
+ num = (pdf_num *)ctx->stack_top[i - 4];
+ if (num->type != PDF_INT) {
+ if(num->type != PDF_REAL) {
+ pdfi_pop(ctx, 4);
+ return_error(gs_error_typecheck);
+ }
+ else
+ Values[i] = num->value.d;
+ } else {
+ Values[i] = (double)num->value.i;
+ }
+ }
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_y_curveto", NULL);
+
+ code = gs_curveto(ctx->pgs, Values[0], Values[1], Values[2], Values[3], Values[2], Values[3]);
+ pdfi_pop(ctx, 4);
+ return code;
+}
+
+int pdfi_closepath(pdf_context *ctx)
+{
+ int code = gs_closepath(ctx->pgs);
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_closepath", NULL);
+
+ return code;
+}
+
+int pdfi_newpath(pdf_context *ctx)
+{
+ int code = 0, code1;
+
+ /* This code is to deal with the wacky W and W* operators */
+ if (ctx->pgs->current_point_valid) {
+ if (ctx->clip_active) {
+ if (ctx->do_eoclip)
+ code = gs_eoclip(ctx->pgs);
+ else
+ code = gs_clip(ctx->pgs);
+ }
+ }
+ ctx->clip_active = false;
+
+ code1 = gs_newpath(ctx->pgs);
+ if (code == 0) code = code1;
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_newpath", NULL);
+
+ return code;
+}
+
+int pdfi_b(pdf_context *ctx)
+{
+ int code;
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_b", NULL);
+
+ code = gs_closepath(ctx->pgs);
+ if (code >= 0)
+ code = pdfi_B(ctx);
+ return code;
+}
+
+int pdfi_b_star(pdf_context *ctx)
+{
+ int code;
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_b_star", NULL);
+
+ code = gs_closepath(ctx->pgs);
+ if (code >= 0)
+ code = pdfi_B_star(ctx);
+ return code;
+}
+
+/* common code for B and B* */
+static int pdfi_B_inner(pdf_context *ctx, bool use_eofill)
+{
+ int code=0, code1=0;
+ pdfi_trans_state_t state;
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_B_inner", NULL);
+
+ if (pdfi_oc_is_off(ctx))
+ goto exit;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) goto exit;
+
+ code = pdfi_trans_setup(ctx, &state, NULL, TRANSPARENCY_Caller_FillStroke);
+ if (code == 0) {
+ if (use_eofill)
+ code = gs_eofillstroke(ctx->pgs, &code1);
+ else
+ code = gs_fillstroke(ctx->pgs, &code1);
+ code1 = pdfi_trans_teardown(ctx, &state);
+ if (code >= 0) code = code1;
+ }
+
+ code1 = pdfi_grestore(ctx);
+ if (code == 0) code = code1;
+
+ exit:
+ code1 = pdfi_newpath(ctx);
+ if (code == 0) code = code1;
+
+ return code;
+}
+
+int pdfi_B(pdf_context *ctx)
+{
+ return pdfi_B_inner(ctx, false);
+}
+
+int pdfi_B_star(pdf_context *ctx)
+{
+ return pdfi_B_inner(ctx, true);
+}
+
+int pdfi_clip(pdf_context *ctx)
+{
+ int code = gs_clip(ctx->pgs);
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_B_clip", NULL);
+
+ return code;
+}
+
+int pdfi_eoclip(pdf_context *ctx)
+{
+ int code = gs_eoclip(ctx->pgs);
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_eoclip", NULL);
+
+ return code;
+}
+
+int pdfi_rectpath(pdf_context *ctx)
+{
+ int i, code;
+ pdf_num *num;
+ double Values[4];
+
+ if (pdfi_count_stack(ctx) < 4) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ for (i=0;i < 4;i++){
+ num = (pdf_num *)ctx->stack_top[i - 4];
+ if (num->type != PDF_INT) {
+ if(num->type != PDF_REAL) {
+ pdfi_pop(ctx, 4);
+ return_error(gs_error_typecheck);
+ }
+ else
+ Values[i] = num->value.d;
+ } else {
+ Values[i] = (double)num->value.i;
+ }
+ }
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_rectpath", NULL);
+
+ code = gs_moveto(ctx->pgs, Values[0], Values[1]);
+ if (code == 0) {
+ code = gs_rlineto(ctx->pgs, Values[2], 0);
+ if (code == 0){
+ code = gs_rlineto(ctx->pgs, 0, Values[3]);
+ if (code == 0) {
+ code = gs_rlineto(ctx->pgs, -Values[2], 0);
+ if (code == 0){
+ code = gs_closepath(ctx->pgs);
+ }
+ }
+ }
+ }
+ pdfi_pop(ctx, 4);
+ return code;
+}
diff --git a/pdf/pdf_path.h b/pdf/pdf_path.h
new file mode 100644
index 00000000..3db560d3
--- /dev/null
+++ b/pdf/pdf_path.h
@@ -0,0 +1,40 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Path operations for the PDF interpreter */
+
+#ifndef PDF_PATH_OPERATORS
+#define PDF_PATH_OPERATORS
+
+int pdfi_moveto (pdf_context *ctx);
+int pdfi_lineto (pdf_context *ctx);
+int pdfi_fill (pdf_context *ctx);
+int pdfi_eofill(pdf_context *ctx);
+int pdfi_stroke(pdf_context *ctx);
+int pdfi_closepath_stroke(pdf_context *ctx);
+int pdfi_curveto(pdf_context *ctx);
+int pdfi_v_curveto(pdf_context *ctx);
+int pdfi_y_curveto(pdf_context *ctx);
+int pdfi_closepath(pdf_context *ctx);
+int pdfi_newpath(pdf_context *ctx);
+int pdfi_b(pdf_context *ctx);
+int pdfi_b_star(pdf_context *ctx);
+int pdfi_B(pdf_context *ctx);
+int pdfi_B_star(pdf_context *ctx);
+int pdfi_clip(pdf_context *ctx);
+int pdfi_eoclip(pdf_context *ctx);
+int pdfi_rectpath(pdf_context *ctx);
+
+#endif
diff --git a/pdf/pdf_pattern.c b/pdf/pdf_pattern.c
new file mode 100644
index 00000000..9d4f9eaa
--- /dev/null
+++ b/pdf/pdf_pattern.c
@@ -0,0 +1,744 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Pattern operations for the PDF interpreter */
+
+#include "pdf_int.h"
+#include "pdf_doc.h"
+#include "pdf_colour.h"
+#include "pdf_pattern.h"
+#include "pdf_stack.h"
+#include "pdf_array.h"
+#include "pdf_gstate.h"
+#include "pdf_file.h"
+#include "pdf_dict.h"
+#include "pdf_loop_detect.h"
+#include "pdf_func.h"
+#include "pdf_shading.h"
+#include "pdf_check.h"
+
+#include "gsicc_manage.h"
+#include "gsicc_profilecache.h"
+#include "gsicc_create.h"
+#include "gsptype2.h"
+#include "gxdevsop.h" /* For special ops : pattern_accum_param_s */
+#include "gscsepr.h"
+#include "stream.h"
+#include "strmio.h"
+#include "gscdevn.h"
+#include "gscoord.h" /* For gs_setmatrix() */
+
+typedef struct {
+ pdf_context *ctx;
+ pdf_dict *page_dict;
+ pdf_obj *pat_obj;
+ gs_shading_t *shading;
+} pdf_pattern_context_t;
+
+/* See pdf_draw.ps, FixPatternBox
+ * A BBox where width or height (or both) is 0 should still paint one pixel
+ * See the ISO 32000-2:2017 spec, section 8.7.4.3, p228 'BBox' and 8.7.3.1
+ */
+static void
+pdfi_pattern_fix_bbox(pdf_context *ctx, gs_rect *rect)
+{
+ if (rect->p.x - rect->q.x == 0)
+ rect->q.x += .00000001;
+ if (rect->p.y - rect->q.y == 0)
+ rect->q.y += .00000001;
+}
+
+/* Get rect from array, normalize and adjust it */
+static int
+pdfi_pattern_get_rect(pdf_context *ctx, pdf_array *array, gs_rect *rect)
+{
+ int code;
+
+ code = pdfi_array_to_gs_rect(ctx, array, rect);
+ if (code != 0)
+ return code;
+
+ pdfi_normalize_rect(ctx, rect);
+ pdfi_pattern_fix_bbox(ctx, rect);
+
+ return code;
+}
+
+#if 0 /* Not currently using, not sure if needed (and it didn't work anyway) */
+/* NULL Pattern */
+static int
+pdfi_setpattern_null(pdf_context *ctx, gs_client_color *cc)
+{
+ int code = 0;
+ gs_client_pattern templat;
+ gs_matrix mat;
+ gs_rect rect;
+
+ gs_pattern1_init(&templat);
+
+ /* Init identity matrix */
+ pdfi_array_to_gs_matrix(ctx, NULL, &mat);
+ pdfi_pattern_get_rect(ctx, NULL, &rect);
+ templat.BBox = rect;
+ templat.PaintProc = NULL;
+ templat.PaintType = 1;
+ templat.TilingType = 3;
+ templat.XStep = 1;
+ templat.YStep = 1;
+
+ code = gs_makepattern(cc, &templat, &mat, ctx->pgs, ctx->memory);
+
+ return code;
+}
+#endif
+
+static void pdfi_free_pattern_context(pdf_pattern_context_t *context)
+{
+ pdfi_countdown(context->page_dict);
+ pdfi_countdown(context->pat_obj);
+ if (context->shading)
+ pdfi_shading_free(context->ctx, context->shading);
+ gs_free_object(context->ctx->memory, context, "Free pattern context");
+}
+
+static bool
+pdfi_pattern_purge_proc(gx_color_tile * ctile, void *proc_data)
+{
+ gs_id id = (gs_id)proc_data;
+ if (ctile->id == id)
+ return true;
+ return false;
+}
+
+void pdfi_pattern_cleanup(gs_memory_t * mem, void *p)
+{
+ gs_pattern1_instance_t *pinst = (gs_pattern1_instance_t *)p;
+ pdf_pattern_context_t *context;
+ gx_color_tile *pctile = NULL;
+
+ context = (pdf_pattern_context_t *)pinst->client_data;
+
+ /* If are being called from Ghostscript, the clist pattern accumulator device (in
+ the tile cache) *can* outlast outlast our pattern instance, so if the pattern
+ instance is being freed, also remove the entry from the cache
+ */
+ if (context != NULL && context->ctx != NULL && context->ctx->pgs != NULL &&
+ context->shading == NULL && context->ctx->pgs->pattern_cache != NULL
+ && gx_pattern_cache_get_entry(context->ctx->pgs, pinst->id, &pctile) == 0
+ && gx_pattern_tile_is_clist(pctile)) {
+ gx_pattern_cache_winnow(gstate_pattern_cache(context->ctx->pgs), pdfi_pattern_purge_proc, (void *)(pctile->id));
+ }
+
+ if (context != NULL) {
+ pdfi_free_pattern_context(context);
+ pinst->client_data = NULL;
+ pinst->notify_free = NULL;
+ }
+}
+
+/* See px_paint_pattern() */
+static int
+pdfi_pattern_paint_stream(pdf_context *ctx, const gs_client_color *pcc)
+{
+ gs_pattern1_instance_t *pinst = (gs_pattern1_instance_t *)pcc->pattern;
+ pdf_pattern_context_t *context = (pdf_pattern_context_t *)pinst->client_data;
+ pdf_dict *page_dict = context->page_dict;
+ pdf_stream *pat_stream = (pdf_stream *)context->pat_obj;
+ int code = 0;
+ int SavedBlockDepth = 0;
+
+ /* In case we are setting up a pattern for filling or stroking text, we need
+ * to reset the BlockDepth so that we don't detect the Pattern content as being
+ * 'inside' a text block, where some operations (eg path contstruction) are
+ * not permitted.
+ */
+ SavedBlockDepth = ctx->text.BlockDepth;
+ ctx->text.BlockDepth = 0;
+
+ /* Interpret inner stream */
+ code = pdfi_run_context(ctx, pat_stream, page_dict, true, "PATTERN");
+
+ ctx->text.BlockDepth = SavedBlockDepth;
+
+ return code;
+}
+
+/* See px_paint_pattern() */
+static int
+pdfi_pattern_paint(const gs_client_color *pcc, gs_gstate *pgs)
+{
+ gs_pattern1_instance_t *pinst = (gs_pattern1_instance_t *)pcc->pattern;
+ pdf_pattern_context_t *context = (pdf_pattern_context_t *)pinst->client_data;
+ pdf_context *ctx = context->ctx;
+ int code = 0;
+
+#if DEBUG_PATTERN
+ dbgmprintf(ctx->memory, "BEGIN PATTERN PaintProc\n");
+#endif
+ code = pdfi_gsave(ctx); /* TODO: This might be redundant? */
+ if (code < 0)
+ return code;
+ code = pdfi_gs_setgstate(ctx->pgs, pgs);
+ if (code < 0)
+ goto exit;
+
+ /* TODO: This hack here is to emulate some stuff that happens in the PS code.
+ * Basically gx_pattern_load() gets called twice in PS code path, which causes this
+ * flag to end up being set, which changes some transparency stuff that might matter, to happen.
+ * By forcing this flag here, it makes the trace more closely follow what the PS code
+ * does. It could turn out to be a meaningless side-effect, or it might be important.
+ * (sometime in the future, try taking this out and see what happens :)
+ */
+ if (pinst->templat.uses_transparency) {
+ dbgmprintf(ctx->memory, "pdfi_pattern_paint forcing trans_flags.xtate_change = TRUE\n");
+ ctx->pgs->trans_flags.xstate_change = true;
+ }
+ code = pdfi_op_q(ctx);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_pattern_paint_stream(ctx, pcc);
+ pdfi_op_Q(ctx);
+ if (code < 0) {
+ dbgmprintf1(ctx->memory, "ERROR: pdfi_pattern_paint: code %d when rendering pattern\n", code);
+ goto exit;
+ }
+
+ exit:
+ pdfi_grestore(ctx);
+#if DEBUG_PATTERN
+ dbgmprintf(ctx->memory, "END PATTERN PaintProc\n");
+#endif
+ return code;
+}
+
+/* See px_high_level_pattern(), pattern_paint_prepare() */
+static int
+pdfi_pattern_paint_high_level(const gs_client_color *pcc, gs_gstate *pgs_ignore)
+{
+ gs_pattern1_instance_t *pinst = (gs_pattern1_instance_t *)pcc->pattern;
+ const gs_pattern1_template_t *templat = &pinst->templat;
+ pdf_pattern_context_t *context = (pdf_pattern_context_t *)pinst->client_data;
+ pdf_context *ctx = context->ctx;
+ gs_gstate *pgs = ctx->pgs;
+ gs_matrix m;
+ gs_rect bbox;
+ gs_fixed_rect clip_box;
+ int code;
+ gx_device_color *pdc = gs_currentdevicecolor_inline(pgs);
+ pattern_accum_param_s param;
+
+ code = gx_pattern_cache_add_dummy_entry(pgs, pinst, pgs->device->color_info.depth);
+ if (code < 0)
+ return code;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0)
+ return code;
+ code = pdfi_gs_setgstate(ctx->pgs, pinst->saved);
+ if (code < 0)
+ goto errorExit;
+
+ dev_proc(pgs->device, get_initial_matrix)(pgs->device, &m);
+ gs_setmatrix(pgs, &m);
+ code = gs_bbox_transform(&templat->BBox, &ctm_only(pgs), &bbox);
+ if (code < 0)
+ goto errorExit;
+ clip_box.p.x = float2fixed(bbox.p.x);
+ clip_box.p.y = float2fixed(bbox.p.y);
+ clip_box.q.x = float2fixed(bbox.q.x);
+ clip_box.q.y = float2fixed(bbox.q.y);
+ code = gx_clip_to_rectangle(pgs, &clip_box);
+ if (code < 0)
+ goto errorExit;
+
+ param.pinst = (void *)pinst;
+ param.interpreter_memory = ctx->memory;
+ param.graphics_state = (void *)pgs;
+ param.pinst_id = pinst->id;
+
+ code = (*dev_proc(pgs->device, dev_spec_op))
+ ((gx_device *)pgs->device, gxdso_pattern_start_accum, &param, sizeof(pattern_accum_param_s));
+
+ if (code < 0)
+ goto errorExit;
+
+#if DEBUG_PATTERN
+ dbgmprintf(ctx->memory, "PATTERN: BEGIN high level pattern stream\n");
+#endif
+ code = pdfi_pattern_paint_stream(ctx, &pdc->ccolor);
+#if DEBUG_PATTERN
+ dbgmprintf(ctx->memory, "PATTERN: END high level pattern stream\n");
+#endif
+ if (code < 0)
+ goto errorExit;
+
+ code = dev_proc(pgs->device, dev_spec_op)
+ (pgs->device, gxdso_pattern_finish_accum, &param, sizeof(pattern_accum_param_s));
+ if (code < 0)
+ goto errorExit;
+
+ code = pdfi_grestore(ctx);
+ if (code < 0)
+ return code;
+ return gs_error_handled;
+
+ errorExit:
+ pdfi_grestore(ctx);
+ return code;
+}
+
+/* Called from gx_pattern_load(), see px_remap_pattern() */
+static int
+pdfi_pattern_paintproc(const gs_client_color *pcc, gs_gstate *pgs)
+{
+ const gs_client_pattern *pinst = gs_getpattern(pcc);
+ int code = 0;
+
+ /* pgs->device is the newly created pattern accumulator, but we want to test the device
+ * that is 'behind' that, the actual output device, so we use the one from
+ * the saved graphics state.
+ */
+ if (pgs->have_pattern_streams) {
+ code = dev_proc(pcc->pattern->saved->device, dev_spec_op)(pcc->pattern->saved->device,
+ gxdso_pattern_can_accum, (void *)pinst, pinst->uid.id);
+ }
+
+ if (code == 1) {
+ return pdfi_pattern_paint_high_level(pcc, pgs);
+ } else {
+ return pdfi_pattern_paint(pcc, pgs);
+ }
+}
+
+
+
+/* Setup the correct gstate for a pattern */
+static int
+pdfi_pattern_gset(pdf_context *ctx, pdf_dict *page_dict, pdf_dict *ExtGState)
+{
+ int code;
+ float strokealpha, fillalpha;
+
+ strokealpha = gs_getstrokeconstantalpha(ctx->pgs);
+ fillalpha = gs_getfillconstantalpha(ctx->pgs);
+
+ /* This will preserve the ->level and a couple other things */
+#if DEBUG_PATTERN
+ dbgmprintf2(ctx->memory, "PATTERN: setting DefaultQState, old device=%s, new device=%s\n",
+ ctx->pgs->device->dname, ctx->DefaultQState->device->dname);
+#endif
+ code = pdfi_gs_setgstate(ctx->pgs, pdfi_get_DefaultQState(ctx));
+ if (code < 0) goto exit;
+ code = gs_setstrokeconstantalpha(ctx->pgs, strokealpha);
+ if (code < 0) goto exit;
+ code = gs_setfillconstantalpha(ctx->pgs, fillalpha);
+ if (code < 0) goto exit;
+
+ /* Set ExtGState if one is provided */
+ if (ExtGState)
+ code = pdfi_set_ExtGState(ctx, NULL, page_dict, ExtGState);
+ exit:
+ return code;
+}
+
+/* Setup the pattern gstate and other context */
+static int
+pdfi_pattern_setup(pdf_context *ctx, pdf_pattern_context_t **ppcontext,
+ pdf_dict *page_dict, pdf_obj *pat_obj, pdf_dict *ExtGState)
+{
+ int code = 0;
+ pdf_pattern_context_t *context = NULL;
+
+ code = pdfi_pattern_gset(ctx, page_dict, ExtGState);
+ if (code < 0)
+ goto errorExit;
+
+ context = (pdf_pattern_context_t *) gs_alloc_bytes(ctx->memory, sizeof(*context),
+ "pdfi_pattern_setup(context)");
+ if (!context) {
+ code = gs_note_error(gs_error_VMerror);
+ goto errorExit;
+ }
+ context->ctx = ctx;
+ context->page_dict = page_dict;
+ context->pat_obj = pat_obj;
+ context->shading = NULL;
+ pdfi_countup(page_dict);
+ pdfi_countup(pat_obj);
+ *ppcontext = context;
+
+ return 0;
+ errorExit:
+ gs_free_object(ctx->memory, context, "pdfi_pattern_setup(context)");
+ return code;
+}
+
+
+/* Type 1 (tiled) Pattern */
+static int
+pdfi_setpattern_type1(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict,
+ pdf_obj *stream, gs_client_color *cc)
+{
+ int code = 0;
+ gs_client_pattern templat;
+ gs_matrix mat;
+ gs_rect rect;
+ int64_t PaintType, TilingType;
+ pdf_array *BBox = NULL;
+ double XStep, YStep;
+ pdf_dict *Resources = NULL, *pdict = NULL;
+ pdf_array *Matrix = NULL;
+ bool transparency = false;
+ pdf_pattern_context_t *context = NULL;
+
+#if DEBUG_PATTERN
+ dbgmprintf(ctx->memory, "PATTERN: Type 1 pattern\n");
+#endif
+
+ gs_pattern1_init(&templat);
+
+ /* Must be a stream */
+ if (stream->type != PDF_STREAM) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit;
+ }
+ code = pdfi_dict_from_obj(ctx, stream, &pdict);
+ if (code < 0)
+ return code;
+
+ /* Required */
+ code = pdfi_dict_get_int(ctx, pdict, "PaintType", &PaintType);
+ if (code < 0)
+ goto exit;
+ code = pdfi_dict_get_int(ctx, pdict, "TilingType", &TilingType);
+ if (code < 0)
+ goto exit;
+ code = pdfi_dict_get_type(ctx, pdict, "BBox", PDF_ARRAY, (pdf_obj **)&BBox);
+ if (code < 0)
+ goto exit;
+ code = pdfi_pattern_get_rect(ctx, BBox, &rect);
+ if (code < 0)
+ goto exit;
+ code = pdfi_dict_get_number(ctx, pdict, "XStep", &XStep);
+ if (code < 0)
+ goto exit;
+ code = pdfi_dict_get_number(ctx, pdict, "YStep", &YStep);
+ if (code < 0)
+ goto exit;
+
+ /* The spec says Resources are required, but in fact this doesn't seem to be true.
+ * (tests_private/pdf/sumatra/infinite_pattern_recursion.pdf)
+ */
+ code = pdfi_dict_get_type(ctx, pdict, "Resources", PDF_DICT, (pdf_obj **)&Resources);
+ if (code < 0) {
+#if DEBUG_PATTERN
+ dbgmprintf(ctx->memory, "PATTERN: Missing Resources in Pattern dict\n");
+#endif
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BADPATTERN, "pdfi_setpattern_type1", NULL);
+ code = 0;
+ }
+
+ /* (optional Matrix) */
+ code = pdfi_dict_knownget_type(ctx, pdict, "Matrix", PDF_ARRAY, (pdf_obj **)&Matrix);
+ if (code < 0)
+ goto exit;
+ code = pdfi_array_to_gs_matrix(ctx, Matrix, &mat);
+ if (code < 0)
+ goto exit;
+
+ if (PaintType != 1 && PaintType != 2) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ if (TilingType != 1 && TilingType != 2 && TilingType != 3) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+
+ /* See if pattern uses transparency */
+ if (ctx->page.has_transparency) {
+ code = pdfi_check_Pattern_transparency(ctx, pdict, page_dict, &transparency);
+ if (code < 0)
+ goto exit;
+ }
+
+ /* TODO: Resources? Maybe I should check that they are all valid before proceeding, or something? */
+
+ templat.BBox = rect;
+ /* (see zPaintProc or px_remap_pattern) */
+ templat.PaintProc = pdfi_pattern_paintproc;
+ templat.PaintType = PaintType;
+ templat.TilingType = TilingType;
+ templat.XStep = XStep;
+ templat.YStep = YStep;
+ templat.uses_transparency = transparency;
+ //templat.uses_transparency = false; /* disable */
+
+ code = pdfi_gsave(ctx);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_pattern_setup(ctx, &context, page_dict, stream, NULL);
+ if (code < 0) {
+ (void) pdfi_grestore(ctx);
+ goto exit;
+ }
+
+ /* We need to use the graphics state memory, in case we are running under Ghostscript. */
+ code = gs_make_pattern(cc, (const gs_pattern_template_t *)&templat, &mat, ctx->pgs, ctx->pgs->memory);
+ if (code < 0) {
+ (void) pdfi_grestore(ctx);
+ goto exit;
+ }
+
+ cc->pattern->client_data = context;
+ cc->pattern->notify_free = pdfi_pattern_cleanup;
+ context = NULL;
+
+ code = pdfi_grestore(ctx);
+ if (code < 0)
+ goto exit;
+ exit:
+ pdfi_countdown(context);
+ pdfi_countdown(Resources);
+ pdfi_countdown(Matrix);
+ pdfi_countdown(BBox);
+ return code;
+}
+
+/* Type 2 (shading) Pattern */
+static int
+pdfi_setpattern_type2(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict,
+ pdf_obj *pattern_obj, gs_client_color *cc)
+{
+ int code = 0;
+ pdf_obj *Shading = NULL;
+ pdf_dict *ExtGState = NULL, *pattern_dict = NULL;
+ pdf_array *Matrix = NULL;
+ gs_matrix mat;
+ gs_shading_t *shading;
+ gs_pattern2_template_t templat;
+ pdf_pattern_context_t *context = NULL;
+
+ /* See zbuildshadingpattern() */
+
+ code = pdfi_dict_from_obj(ctx, pattern_obj, &pattern_dict);
+ if (code < 0)
+ return code;
+
+#if DEBUG_PATTERN
+ dbgmprintf(ctx->memory, "PATTERN: Type 2 pattern\n");
+#endif
+
+ /* (optional Matrix) */
+ code = pdfi_dict_knownget_type(ctx, pattern_dict, "Matrix", PDF_ARRAY, (pdf_obj **)&Matrix);
+ if (code < 0)
+ goto exit;
+ code = pdfi_array_to_gs_matrix(ctx, Matrix, &mat);
+ if (code < 0)
+ goto exit;
+
+ /* Required Shading, can be stream or dict (but a stream is also a dict..) */
+ code = pdfi_dict_knownget(ctx, pattern_dict, "Shading", &Shading);
+ if (code < 0)
+ goto exit;
+ if (code == 0) {
+ dbgmprintf(ctx->memory, "ERROR: Shading not found in Pattern Type 2\n");
+ code = gs_note_error(gs_error_syntaxerror);
+ goto exit;
+ }
+
+ /* Optional ExtGState */
+ code = pdfi_dict_knownget_type(ctx, pattern_dict, "ExtGState", PDF_DICT, (pdf_obj **)&ExtGState);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_gsave(ctx);
+ if (code < 0)
+ goto exit;
+
+ gs_pattern2_init(&templat);
+
+ code = pdfi_pattern_setup(ctx, &context, NULL, NULL, ExtGState);
+ if (code < 0) {
+ (void) pdfi_grestore(ctx);
+ goto exit;
+ }
+
+ code = pdfi_shading_build(ctx, stream_dict, page_dict, Shading, &shading);
+ if (code != 0) {
+ (void) pdfi_grestore(ctx);
+ dbgmprintf(ctx->memory, "ERROR: can't build shading structure\n");
+ goto exit;
+ }
+
+ context->shading = shading;
+
+ templat.Shading = shading;
+ code = gs_make_pattern(cc, (const gs_pattern_template_t *)&templat, &mat, ctx->pgs, ctx->memory);
+ if (code < 0) {
+ (void) pdfi_grestore(ctx);
+ goto exit;
+ }
+ cc->pattern->client_data = context;
+ cc->pattern->notify_free = pdfi_pattern_cleanup;
+ context = NULL;
+
+ code = pdfi_grestore(ctx);
+ if (code < 0)
+ goto exit;
+
+ exit:
+ if (context != NULL)
+ pdfi_free_pattern_context(context);
+ pdfi_countdown(Shading);
+ pdfi_countdown(Matrix);
+ pdfi_countdown(ExtGState);
+ return code;
+}
+
+int
+pdfi_pattern_set(pdf_context *ctx, pdf_dict *stream_dict,
+ pdf_dict *page_dict, pdf_name *pname,
+ gs_client_color *cc)
+{
+ pdf_dict *pattern_dict = NULL;
+ pdf_obj *pattern_obj = NULL;
+ int code;
+ int64_t patternType;
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ return code;
+
+ memset(cc, 0, sizeof(*cc));
+ code = pdfi_find_resource(ctx, (unsigned char *)"Pattern", pname, (pdf_dict *)stream_dict,
+ page_dict, (pdf_obj **)&pattern_obj);
+ if (code < 0) {
+ dbgmprintf(ctx->memory, "WARNING: Pattern object not found in resources\n");
+ goto exit;
+ }
+
+ code = pdfi_dict_from_obj(ctx, pattern_obj, &pattern_dict);
+ if (code < 0) {
+ /* NOTE: Bug696410.pdf gets a bogus pattern while trying to process pattern.
+ * Seems like a corrupted file, but this prevents crash
+ */
+ dbgmprintf(ctx->memory, "ERROR: Pattern found in resources is neither a stream or dict\n");
+ goto exit;
+ }
+
+#if DEBUG_PATTERN
+ dbgmprintf1(ctx->memory, "PATTERN: pdfi_setpattern: found pattern object %d\n", pdict->object_num);
+#endif
+
+ code = pdfi_dict_get_int(ctx, pattern_dict, "PatternType", &patternType);
+ if (code < 0)
+ goto exit;
+ if (patternType == 1) {
+ code = pdfi_setpattern_type1(ctx, stream_dict, page_dict, (pdf_obj *)pattern_obj, cc);
+ if (code < 0)
+ goto exit;
+ } else if (patternType == 2) {
+ code = pdfi_setpattern_type2(ctx, stream_dict, page_dict, pattern_obj, cc);
+ if (code < 0)
+ goto exit;
+ } else {
+ code = gs_note_error(gs_error_syntaxerror);
+ goto exit;
+ }
+
+ exit:
+ pdfi_countdown(pattern_obj);
+ if (code < 0)
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ else
+ code = pdfi_loop_detector_cleartomark(ctx);
+ return code;
+}
+
+/* Create a Pattern colorspace.
+ * If ppcs is NULL, then we will set the colorspace
+ * If ppcs not NULL, point the new colorspace to it
+ *
+ * If color_array is NULL, then this is a simple "Pattern" colorspace, e.g. "/Pattern cs".
+ * If it is an array, then first element is "Pattern" and second element should be the base colorspace.
+ * e.g. "/CS1 cs" where /CS1 is a ColorSpace Resource containing "[/Pattern /DeviceRGB]"
+ *
+ */
+int
+pdfi_pattern_create(pdf_context *ctx, pdf_array *color_array, pdf_dict *stream_dict,
+ pdf_dict *page_dict, gs_color_space **ppcs)
+{
+ gs_color_space *pcs = NULL;
+ gs_color_space *base_space;
+ pdf_obj *base_obj = NULL;
+ int code = 0;
+
+ /* TODO: should set to "the initial color is a pattern object that causes nothing to be painted."
+ * (see page 288 of PDF 1.7)
+ * Need to make a "nullpattern" (see pdf_ops.c, /nullpattern)
+ */
+ /* NOTE: See zcolor.c/setpatternspace */
+#if DEBUG_PATTERN
+ dbgmprintf(ctx->memory, "PATTERN: pdfi_create_Pattern\n");
+#endif
+ // return 0;
+
+ pcs = gs_cspace_alloc(ctx->memory, &gs_color_space_type_Pattern);
+ if (pcs == NULL) {
+ return_error(gs_error_VMerror);
+ }
+ if (color_array == NULL || pdfi_array_size(color_array) == 1) {
+ pcs->base_space = NULL;
+ pcs->params.pattern.has_base_space = false;
+ } else {
+#if DEBUG_PATTERN
+ dbgmprintf(ctx->memory, "PATTERN: with base space! pdfi_create_Pattern\n");
+#endif
+ code = pdfi_array_get(ctx, color_array, 1, &base_obj);
+ if (code < 0)
+ goto exit;
+ code = pdfi_create_colorspace(ctx, base_obj, stream_dict, page_dict, &base_space, false);
+ if (code < 0)
+ goto exit;
+ pcs->base_space = base_space;
+ pcs->params.pattern.has_base_space = true;
+ }
+ if (ppcs != NULL) {
+ *ppcs = pcs;
+ rc_increment_cs(pcs);
+ } else {
+ code = pdfi_gs_setcolorspace(ctx, pcs);
+
+#if 0
+ /* An attempt to init a "Null" pattern, causes crashes on cluster */
+ {
+ gs_client_color cc;
+ memset(&cc, 0, sizeof(cc));
+ code = pdfi_setpattern_null(ctx, &cc);
+ code = gs_setcolor(ctx->pgs, &cc);
+ }
+#endif
+ }
+
+
+ exit:
+ /* release reference from construction */
+ rc_decrement_only_cs(pcs, "create_Pattern");
+ pdfi_countdown(base_obj);
+ return code;
+}
diff --git a/pdf/pdf_pattern.h b/pdf/pdf_pattern.h
new file mode 100644
index 00000000..3482e0bb
--- /dev/null
+++ b/pdf/pdf_pattern.h
@@ -0,0 +1,28 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* pattern operations for the PDF interpreter */
+
+#ifndef PDF_PATTERN_OPERATORS
+#define PDF_PATTERN_OPERATORS
+
+#include "gscolor1.h"
+
+void pdfi_pattern_cleanup(gs_memory_t * mem, void *p);
+int pdfi_pattern_set(pdf_context *ctx, pdf_dict *stream_dict,
+ pdf_dict *page_dict, pdf_name *pname, gs_client_color *cc);
+int pdfi_pattern_create(pdf_context *ctx, pdf_array *color_array,
+ pdf_dict *stream_dict, pdf_dict *page_dict, gs_color_space **ppcs);
+#endif
diff --git a/pdf/pdf_repair.c b/pdf/pdf_repair.c
new file mode 100644
index 00000000..dafcd4c0
--- /dev/null
+++ b/pdf/pdf_repair.c
@@ -0,0 +1,473 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Routines to attempt repair of PDF files in the event of an error */
+
+#include "pdf_int.h"
+#include "pdf_stack.h"
+#include "strmio.h"
+#include "stream.h"
+#include "pdf_deref.h"
+#include "pdf_dict.h"
+#include "pdf_file.h"
+#include "pdf_misc.h"
+#include "pdf_repair.h"
+
+static int pdfi_repair_add_object(pdf_context *ctx, uint64_t obj, uint64_t gen, gs_offset_t offset)
+{
+ /* Although we can handle object numbers larger than this, on some systems (32-bit Windows)
+ * memset is limited to a (signed!) integer for the size of memory to clear. We could deal
+ * with this by clearing the memory in blocks, but really, this is almost certainly a
+ * corrupted file or something.
+ */
+ if (obj >= 0x7ffffff / sizeof(xref_entry))
+ return_error(gs_error_rangecheck);
+
+ if (ctx->xref_table == NULL) {
+ ctx->xref_table = (xref_table_t *)gs_alloc_bytes(ctx->memory, sizeof(xref_table_t), "repair xref table");
+ if (ctx->xref_table == NULL) {
+ return_error(gs_error_VMerror);
+ }
+ memset(ctx->xref_table, 0x00, sizeof(xref_table_t));
+ ctx->xref_table->xref = (xref_entry *)gs_alloc_bytes(ctx->memory, (obj + 1) * sizeof(xref_entry), "repair xref table");
+ if (ctx->xref_table->xref == NULL){
+ gs_free_object(ctx->memory, ctx->xref_table, "failed to allocate xref table entries for repair");
+ ctx->xref_table = NULL;
+ return_error(gs_error_VMerror);
+ }
+ memset(ctx->xref_table->xref, 0x00, (obj + 1) * sizeof(xref_entry));
+ ctx->xref_table->ctx = ctx;
+ ctx->xref_table->type = PDF_XREF_TABLE;
+ ctx->xref_table->xref_size = obj + 1;
+#if REFCNT_DEBUG
+ ctx->xref_table->UID = ctx->UID++;
+ dmprintf1(ctx->memory, "Allocated xref table with UID %"PRIi64"\n", ctx->xref_table->UID);
+#endif
+ pdfi_countup(ctx->xref_table);
+ } else {
+ if (ctx->xref_table->xref_size < (obj + 1)) {
+ xref_entry *new_xrefs;
+
+ new_xrefs = (xref_entry *)gs_alloc_bytes(ctx->memory, (obj + 1) * sizeof(xref_entry), "read_xref_stream allocate xref table entries");
+ if (new_xrefs == NULL){
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ return_error(gs_error_VMerror);
+ }
+ memset(new_xrefs, 0x00, (obj + 1) * sizeof(xref_entry));
+ memcpy(new_xrefs, ctx->xref_table->xref, ctx->xref_table->xref_size * sizeof(xref_entry));
+ gs_free_object(ctx->memory, ctx->xref_table->xref, "reallocated xref entries");
+ ctx->xref_table->xref = new_xrefs;
+ ctx->xref_table->xref_size = obj + 1;
+ }
+ }
+ ctx->xref_table->xref[obj].compressed = false;
+ ctx->xref_table->xref[obj].free = false;
+ ctx->xref_table->xref[obj].object_num = obj;
+ ctx->xref_table->xref[obj].u.uncompressed.generation_num = gen;
+ ctx->xref_table->xref[obj].u.uncompressed.offset = offset;
+ return 0;
+}
+
+int pdfi_repair_file(pdf_context *ctx)
+{
+ int code = 0;
+ gs_offset_t offset, saved_offset;
+ uint64_t object_num = 0, generation_num = 0;
+ int i;
+ gs_offset_t outer_saved_offset[3];
+
+ if (ctx->repaired) {
+ pdfi_set_error(ctx, 0, NULL, E_PDF_UNREPAIRABLE, "pdfi_repair_file", (char *)"%% Trying to repair file for second time -- unrepairable");
+ return_error(gs_error_undefined);
+ }
+
+ saved_offset = pdfi_unread_tell(ctx);
+
+ ctx->repaired = true;
+ pdfi_set_error(ctx, 0, NULL, E_PDF_REPAIRED, "pdfi_repair_file", NULL);
+
+ pdfi_clearstack(ctx);
+
+ if(ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "%% Error encountered in opening PDF file, attempting repair\n");
+
+ /* First try to locate a %PDF header. If we can't find one, abort this, the file is too broken
+ * and may not even be a PDF file.
+ */
+ pdfi_seek(ctx, ctx->main_stream, 0, SEEK_SET);
+ {
+ char Buffer[10], test[] = "%PDF";
+ int index = 0;
+
+ do {
+ code = pdfi_read_bytes(ctx, (byte *)&Buffer[index], 1, 1, ctx->main_stream);
+ if (code < 0)
+ goto exit;
+
+ if (Buffer[index] == test[index])
+ index++;
+ else
+ index = 0;
+ } while (index < 4 && ctx->main_stream->eof == false);
+ if (memcmp(Buffer, test, 4) != 0) {
+ code = gs_note_error(gs_error_undefined);
+ goto exit;
+ }
+ pdfi_unread(ctx, ctx->main_stream, (byte *)Buffer, 4);
+ pdfi_skip_comment(ctx, ctx->main_stream);
+ }
+ if (ctx->main_stream->eof == true) {
+ code = gs_note_error(gs_error_ioerror);
+ goto exit;
+ }
+
+ /* First pass, identify all the objects of the form x y obj */
+
+ do {
+ code = pdfi_skip_white(ctx, ctx->main_stream);
+ if (code < 0) {
+ if (code != gs_error_VMerror && code != gs_error_ioerror) {
+ pdfi_clearstack(ctx);
+ continue;
+ } else
+ goto exit;
+ }
+ offset = pdfi_unread_tell(ctx);
+ outer_saved_offset[0] = outer_saved_offset[1] = outer_saved_offset[2] = 0;
+ do {
+ outer_saved_offset[0] = outer_saved_offset[1];
+ outer_saved_offset[1] = outer_saved_offset[2];
+ outer_saved_offset[2] = pdfi_unread_tell(ctx);
+
+ object_num = 0;
+
+ code = pdfi_read_token(ctx, ctx->main_stream, 0, 0);
+ if (code < 0) {
+ if (code != gs_error_VMerror && code != gs_error_ioerror) {
+ pdfi_clearstack(ctx);
+ continue;
+ } else
+ goto exit;
+ }
+ if (pdfi_count_stack(ctx) > 0) {
+ if (ctx->stack_top[-1]->type == PDF_KEYWORD) {
+ pdf_keyword *k = (pdf_keyword *)ctx->stack_top[-1];
+ pdf_num *n;
+
+ if (k->key == TOKEN_OBJ) {
+ gs_offset_t saved_offset[3];
+
+ offset = outer_saved_offset[0];
+
+ saved_offset[0] = saved_offset[1] = saved_offset[2] = 0;
+
+ if (pdfi_count_stack(ctx) < 3 || ctx->stack_top[-2]->type != PDF_INT || ctx->stack_top[-2]->type != PDF_INT) {
+ pdfi_clearstack(ctx);
+ continue;
+ }
+ n = (pdf_num *)ctx->stack_top[-3];
+ object_num = n->value.i;
+ n = (pdf_num *)ctx->stack_top[-2];
+ generation_num = n->value.i;
+ pdfi_clearstack(ctx);
+
+ do {
+ /* move all the saved offsets up by one */
+ saved_offset[0] = saved_offset[1];
+ saved_offset[1] = saved_offset[2];
+ saved_offset[2] = pdfi_unread_tell(ctx);;
+
+ code = pdfi_read_token(ctx, ctx->main_stream, 0, 0);
+ if (code < 0) {
+ if (code != gs_error_VMerror && code != gs_error_ioerror)
+ continue;
+ goto exit;
+ }
+ if (code == 0 && ctx->main_stream->eof)
+ break;
+
+ if (ctx->stack_top[-1]->type == PDF_KEYWORD){
+ pdf_keyword *k = (pdf_keyword *)ctx->stack_top[-1];
+
+ if (k->key == TOKEN_OBJ) {
+ /* Found obj while looking for endobj, store the existing 'obj'
+ * and start afresh.
+ */
+ code = pdfi_repair_add_object(ctx, object_num, generation_num, offset);
+ if (pdfi_count_stack(ctx) < 3 || ctx->stack_top[-2]->type != PDF_INT || ctx->stack_top[-2]->type != PDF_INT) {
+ pdfi_clearstack(ctx);
+ break;
+ }
+ n = (pdf_num *)ctx->stack_top[-3];
+ object_num = n->value.i;
+ n = (pdf_num *)ctx->stack_top[-2];
+ generation_num = n->value.i;
+ pdfi_clearstack(ctx);
+ offset = saved_offset[0];
+ continue;
+ }
+
+ if (k->key == TOKEN_ENDOBJ) {
+ code = pdfi_repair_add_object(ctx, object_num, generation_num, offset);
+ if (code < 0)
+ goto exit;
+ pdfi_clearstack(ctx);
+ break;
+ } else {
+ if (k->key == TOKEN_STREAM) {
+ char Buffer[10], test[] = "endstream";
+ int index = 0;
+
+ do {
+ code = pdfi_read_bytes(ctx, (byte *)&Buffer[index], 1, 1, ctx->main_stream);
+ if (code < 0) {
+ if (code != gs_error_VMerror && code != gs_error_ioerror)
+ continue;
+ goto exit;
+ }
+ if (Buffer[index] == test[index])
+ index++;
+ else
+ index = 0;
+ } while (index < 9 && ctx->main_stream->eof == false);
+ do {
+ code = pdfi_read_token(ctx, ctx->main_stream, 0, 0);
+ if (code < 0) {
+ if (code != gs_error_VMerror && code != gs_error_ioerror)
+ continue;
+ goto exit;
+ }
+ if (ctx->stack_top[-1]->type == PDF_KEYWORD){
+ pdf_keyword *k = (pdf_keyword *)ctx->stack_top[-1];
+ if (k->key == TOKEN_ENDOBJ) {
+ code = pdfi_repair_add_object(ctx, object_num, generation_num, offset);
+ if (code < 0) {
+ if (code != gs_error_VMerror && code != gs_error_ioerror)
+ break;
+ goto exit;
+ }
+ break;
+ }
+ }
+ }while(ctx->main_stream->eof == false);
+
+ pdfi_clearstack(ctx);
+ break;
+ } else {
+ pdfi_clearstack(ctx);
+ }
+ }
+ }
+ } while(1);
+ break;
+ } else {
+ if (k->key == TOKEN_ENDOBJ) {
+ pdfi_clearstack(ctx);
+ } else
+ if (k->key == TOKEN_STARTXREF) {
+ code = pdfi_read_token(ctx, ctx->main_stream, 0, 0);
+ if (code < 0 && code != gs_error_VMerror && code != gs_error_ioerror)
+ continue;
+ if (code < 0)
+ goto exit;
+ pdfi_clearstack(ctx);
+ } else {
+ if (k->key == TOKEN_TRAILER) {
+ code = pdfi_read_bare_object(ctx, ctx->main_stream, 0, 0, 0);
+ if (code == 0 && ctx->stack_top[-1]->type == PDF_DICT) {
+ if (ctx->Trailer) {
+ pdf_dict *d = (pdf_dict *)ctx->stack_top[-1];
+ bool known = false;
+
+ code = pdfi_dict_known(ctx, d, "Root", &known);
+ if (code == 0 && known) {
+ pdfi_countdown(ctx->Trailer);
+ ctx->Trailer = (pdf_dict *)ctx->stack_top[-1];
+ pdfi_countup(ctx->Trailer);
+ }
+ } else {
+ ctx->Trailer = (pdf_dict *)ctx->stack_top[-1];
+ pdfi_countup(ctx->Trailer);
+ }
+ }
+ }
+ pdfi_clearstack(ctx);
+ }
+ }
+ code = pdfi_skip_white(ctx, ctx->main_stream);
+ if (code < 0) {
+ if (code != gs_error_VMerror && code != gs_error_ioerror) {
+ pdfi_clearstack(ctx);
+ continue;
+ } else
+ goto exit;
+ }
+ }
+ if (pdfi_count_stack(ctx) > 0 && ctx->stack_top[-1]->type != PDF_INT)
+ pdfi_clearstack(ctx);
+ }
+ } while (ctx->main_stream->eof == false);
+ } while(ctx->main_stream->eof == false);
+
+ pdfi_seek(ctx, ctx->main_stream, 0, SEEK_SET);
+ ctx->main_stream->eof = false;
+
+ /* Second pass, examine every object we have located to see if its an ObjStm */
+ if (ctx->xref_table == NULL || ctx->xref_table->xref_size < 1) {
+ code = gs_note_error(gs_error_syntaxerror);
+ goto exit;
+ }
+
+ for (i=1;i < ctx->xref_table->xref_size;i++) {
+ if (ctx->xref_table->xref[i].object_num != 0) {
+ /* At this stage, all the objects we've found must be uncompressed */
+ if (ctx->xref_table->xref[i].u.uncompressed.offset > ctx->main_stream_length) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+
+ pdfi_seek(ctx, ctx->main_stream, ctx->xref_table->xref[i].u.uncompressed.offset, SEEK_SET);
+ do {
+ code = pdfi_read_token(ctx, ctx->main_stream, 0, 0);
+ if (ctx->main_stream->eof == true || (code < 0 && code != gs_error_ioerror && code != gs_error_VMerror))
+ break;
+ if (code < 0)
+ goto exit;
+ if (ctx->stack_top[-1]->type == PDF_KEYWORD) {
+ pdf_keyword *k = (pdf_keyword *)ctx->stack_top[-1];
+
+ if (k->key == TOKEN_OBJ){
+ continue;
+ }
+ if (k->key == TOKEN_ENDOBJ) {
+ if (pdfi_count_stack(ctx) > 1) {
+ if (ctx->stack_top[-2]->type == PDF_DICT) {
+ pdf_dict *d = (pdf_dict *)ctx->stack_top[-2];
+ pdf_obj *o = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, d, "Type", PDF_NAME, &o);
+ if (code < 0) {
+ pdfi_clearstack(ctx);
+ goto exit;
+ }
+ if (code > 0) {
+ pdf_name *n = (pdf_name *)o;
+
+ if (pdfi_name_is(n, "Catalog")) {
+ pdfi_countdown(ctx->Root); /* In case it was already set */
+ ctx->Root = (pdf_dict *)ctx->stack_top[-2];
+ pdfi_countup(ctx->Root);
+ }
+ }
+ pdfi_countdown(o);
+ }
+ }
+ pdfi_clearstack(ctx);
+ break;
+ }
+ if (k->key == TOKEN_STREAM) {
+ pdf_dict *d;
+ pdf_name *n = NULL;
+
+ if (pdfi_count_stack(ctx) <= 1) {
+ pdfi_clearstack(ctx);
+ break;;
+ }
+ d = (pdf_dict *)ctx->stack_top[-2];
+ if (d->type != PDF_DICT) {
+ pdfi_clearstack(ctx);
+ break;;
+ }
+ code = pdfi_dict_knownget_type(ctx, d, "Type", PDF_NAME, (pdf_obj **)&n);
+ if (code < 0) {
+ if (ctx->args.pdfstoponerror || code == gs_error_VMerror) {
+ pdfi_clearstack(ctx);
+ goto exit;
+ }
+ }
+ if (code > 0) {
+ if (pdfi_name_is(n, "ObjStm")) {
+ int64_t N, obj_num, offset;
+ int j;
+ pdf_c_stream *compressed_stream;
+ pdf_obj *o;
+ pdf_stream *stream;
+
+ offset = pdfi_unread_tell(ctx);
+ pdfi_seek(ctx, ctx->main_stream, offset, SEEK_SET);
+
+ code = pdfi_obj_dict_to_stream(ctx, d, &stream, true);
+ if (code == 0)
+ code = pdfi_filter(ctx, stream, ctx->main_stream, &compressed_stream, false);
+
+ pdfi_countdown(stream);
+
+ if (code == 0) {
+ code = pdfi_dict_get_int(ctx, d, "N", &N);
+ if (code == 0) {
+ for (j=0;j < N; j++) {
+ code = pdfi_read_token(ctx, compressed_stream, 0, 0);
+ if (code == 0) {
+ o = ctx->stack_top[-1];
+ if (((pdf_obj *)o)->type == PDF_INT) {
+ obj_num = ((pdf_num *)o)->value.i;
+ pdfi_pop(ctx, 1);
+ code = pdfi_read_token(ctx, compressed_stream, 0, 0);
+ if (code == 0) {
+ o = ctx->stack_top[-1];
+ if (((pdf_obj *)o)->type == PDF_INT) {
+ offset = ((pdf_num *)o)->value.i;
+ if (obj_num < 1) {
+ pdfi_close_file(ctx, compressed_stream);
+ pdfi_clearstack(ctx);
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ ctx->xref_table->xref[obj_num].compressed = true;
+ ctx->xref_table->xref[obj_num].free = false;
+ ctx->xref_table->xref[obj_num].object_num = obj_num;
+ ctx->xref_table->xref[obj_num].u.compressed.compressed_stream_num = i;
+ ctx->xref_table->xref[obj_num].u.compressed.object_index = j;
+ }
+ }
+ }
+ }
+ }
+ }
+ pdfi_close_file(ctx, compressed_stream);
+ }
+ if (code < 0) {
+ if (ctx->args.pdfstoponerror || code == gs_error_VMerror) {
+ pdfi_clearstack(ctx);
+ goto exit;
+ }
+ }
+ }
+ }
+ pdfi_countdown(n);
+ pdfi_clearstack(ctx);
+ break;
+ }
+ }
+ } while (1);
+ }
+ }
+
+exit:
+ pdfi_seek(ctx, ctx->main_stream, saved_offset, SEEK_SET);
+ ctx->main_stream->eof = false;
+ return code;
+}
diff --git a/pdf/pdf_repair.h b/pdf/pdf_repair.h
new file mode 100644
index 00000000..b5fc73f9
--- /dev/null
+++ b/pdf/pdf_repair.h
@@ -0,0 +1,21 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+#ifndef PDF_REPAIR
+#define PDF_REPAIR
+
+int pdfi_repair_file(pdf_context *ctx);
+
+#endif
diff --git a/pdf/pdf_sec.c b/pdf/pdf_sec.c
new file mode 100644
index 00000000..ff608052
--- /dev/null
+++ b/pdf/pdf_sec.c
@@ -0,0 +1,1418 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* PDF decryption routines */
+
+#include "pdf_stack.h"
+#include "pdf_file.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_sec.h"
+#include "pdf_misc.h"
+#include "strmio.h"
+#include "smd5.h"
+#include "sarc4.h"
+#include "aes.h"
+#include "sha2.h"
+#include "pdf_utf8.h"
+#include "pdf_deref.h"
+
+/* The padding string as defined in step 1 of Algorithm 3.2 */
+static char PadString[32] = {
+ 0x28, 0xbf, 0x4e, 0x5e, 0x4e, 0x75, 0x8a, 0x41, 0x64, 0x00, 0x4e, 0x56, 0xff, 0xfa, 0x01, 0x08,
+ 0x2e, 0x2e, 0x00, 0xb6, 0xd0, 0x68, 0x3e, 0x80, 0x2f, 0x0c, 0xa9, 0xfe, 0x64, 0x53, 0x69, 0x7a
+};
+
+/* If EncryptMetadata is true we need to add 4 bytes of 0xFF to the MD5 hash
+ * when computing an encryption key (Algorithm 3.2, step 6 when R is 4 or more)
+ */
+static char R4String[4] = {
+ 0xFF, 0xFF, 0xFF, 0xFF
+};
+
+/* If using the AES filter, we need to add this to the encryption
+ * key when creating the key for decrypting objects (streams or strings)
+ */
+static char sAlTString[4] = {
+ 0x73, 0x41, 0x6c, 0x54
+};
+
+static int pdf_compute_encryption_key_preR5(pdf_context *ctx, char *Password, int PasswordLen, int KeyLen, pdf_string **EKey, int R)
+{
+ char Key[32];
+ int code = 0, KeyLenBytes = KeyLen / 8, i;
+ char P[4];
+ gs_md5_state_t md5;
+ pdf_array *a = NULL;
+ pdf_string *s = NULL;
+
+ *EKey = NULL;
+ /* Algorithm 3.2 */
+ /* Step 1. Pad or truncate the password string to exactly 32 bytes
+ * using the defined padding string.
+ */
+ if (PasswordLen > 32)
+ PasswordLen = 32;
+
+ memcpy(Key, Password, PasswordLen);
+
+ if (PasswordLen < 32)
+ memcpy(&Key[PasswordLen], PadString, 32 - PasswordLen);
+
+ /* 2. Initialise the MD5 hash function and pass the result of step 1 to this function */
+ gs_md5_init(&md5);
+ gs_md5_append(&md5, (gs_md5_byte_t *)&Key, 32);
+
+ /* 3. Pass the value of the encryption dictionary's O entry to the MD5 hash */
+ gs_md5_append(&md5, (gs_md5_byte_t *)ctx->encryption.O, 32);
+
+ /* 4. Treat the value of P as an unsigned 4 byte integer and pass those bytes to the MD5 */
+ P[3] = ((uint32_t)ctx->encryption.P) >> 24;
+ P[2] = ((uint32_t)ctx->encryption.P & 0x00ff0000) >> 16;
+ P[1] = ((uint32_t)ctx->encryption.P & 0x0000ff00) >> 8;
+ P[0] = ((uint32_t)ctx->encryption.P & 0xff);
+ gs_md5_append(&md5, (gs_md5_byte_t *)P, 4);
+
+ /* 5. Pass the first element of the file's file identifier array */
+ code = pdfi_dict_get_type(ctx, ctx->Trailer, "ID", PDF_ARRAY, (pdf_obj **)&a);
+ if (code < 0) {
+ if (code == gs_error_undefined) {
+ emprintf(ctx->memory, "\n **** Error: ID key in the trailer is required for encrypted files.\n");
+ emprintf(ctx->memory, " File may not be possible to decrypt.\n");
+ } else
+ return code;
+ }
+ /* If the file ID was missing, just ignore the error */
+ if (code == 0) {
+ code = pdfi_array_get_type(ctx, a, (uint64_t)0, PDF_STRING, (pdf_obj **)&s);
+ if (code < 0)
+ goto done;
+ gs_md5_append(&md5, s->data, s->length);
+ }
+
+ /* Step 6
+ * (revision 4 or greater) If document Metadata is not being encrypted
+ * pass 4 bytes with the value 0xFFFFFFFF to the MD5 hash function.
+ */
+ if (R > 3 && !ctx->encryption.EncryptMetadata) {
+ gs_md5_append(&md5, (const gs_md5_byte_t *)R4String, 4);
+ }
+
+ /* 7. Finish the hash */
+ gs_md5_finish(&md5, (gs_md5_byte_t *)&Key);
+
+ code = pdfi_object_alloc(ctx, PDF_STRING, KeyLenBytes, (pdf_obj **)EKey);
+ if (code < 0)
+ goto done;
+ pdfi_countup((pdf_obj *)*EKey);
+
+ /* Step 8
+ * (revision 3 or greater) Do the following 50 times. Take the output from the
+ * previous MD5 hash and pass hte first n bytes of the output as input to a new
+ * MD5 hash, where n is the number of bytes of the encryption key as defined by
+ * the value of the encryption dictionary's Length entry. (NB Length is in bits)
+ */
+ if (R > 2) {
+ for (i=0;i < 50; i++) {
+ memcpy((*EKey)->data, Key, KeyLenBytes);
+ gs_md5_init(&md5);
+ gs_md5_append(&md5, (gs_md5_byte_t *)(*EKey)->data, KeyLenBytes);
+ gs_md5_finish(&md5, (gs_md5_byte_t *)&Key);
+ }
+ }
+
+ /* Step 9
+ * Set the encryption key to the first n bytes of the output from the final MD5 hash
+ * where n is always 5 for revision 2 but, for revision 3 or greater, depends on the
+ * value of the encryption dictionary's Length entry.
+ */
+ memcpy((*EKey)->data, Key, KeyLenBytes);
+
+done:
+ pdfi_countdown(s);
+ pdfi_countdown(a);
+ return code;
+}
+
+#ifdef HAVE_LIBIDN
+# include <stringprep.h>
+
+static int apply_sasl(pdf_context *ctx, char *Password, int Len, char **NewPassword, int *NewLen)
+{
+ byte *buffer;
+ uint buffer_size;
+ Stringprep_rc err;
+
+ buffer_size = Len * 11 + 1;
+ buffer = (byte *)gs_alloc_bytes(ctx->memory, buffer_size, "saslprep result");
+ if (buffer == NULL)
+ return_error(gs_error_VMerror);
+
+ err = stringprep((char *)buffer, buffer_size, 0, stringprep_saslprep);
+ if (err != STRINGPREP_OK) {
+ gs_free_object(ctx->memory, buffer, "saslprep result");
+
+ /* Since we're just verifying the password to an existing
+ * document here, we don't care about "invalid input" errors
+ * like STRINGPREP_CONTAINS_PROHIBITED. In these cases, we
+ * ignore the error and return the original string unchanged --
+ * chances are it's not the right password anyway, and if it
+ * is we shouldn't gratuitously fail to decrypt the document.
+ *
+ * On the other hand, errors like STRINGPREP_NFKC_FAILED are
+ * real errors, and should be returned to the user.
+ *
+ * Fortunately, the stringprep error codes are sorted to make
+ * this easy: the errors we want to ignore are the ones with
+ * codes less than 100. */
+ if ((int)err < 100)
+ return 0;
+
+ return_error(gs_error_ioerror);
+ }
+
+ *NewLen = strlen((char *)buffer);
+ *NewPassword = (char *)buffer;
+
+ return 0;
+
+}
+#endif
+
+static int check_user_password_R5(pdf_context *ctx, char *Password, int Len, int KeyLen)
+{
+ char *UTF8_Password, *Test = NULL, Buffer[32], UEPadded[48];
+ int NewLen;
+ int code = 0;
+ pdf_c_stream *stream = NULL, *filter_stream = NULL;
+ pdf_string *Key = NULL;
+ SHA256_CTX sha256;
+
+ /* Algorithm 3.11 from the Adobe extensions to the ISO 32000 specification (Extension Level 3) */
+ /* Step 1 convert the password to UTF-8 */
+
+ /* From the original code in Resource/Init/pdf_sec.ps:
+ * Step 1.
+ * If the .saslprep operator isn't available (because ghostscript
+ * wasn't built with libidn support), just skip this step. ASCII
+ * passwords will still work fine, and even most non-ASCII passwords
+ * will be okay; any non-ASCII passwords that fail will produce a
+ * warning from pdf_process_Encrypt.
+ */
+#ifdef HAVE_LIBIDN
+ code = apply_sasl(ctx, Password, Len, &UTF8_Password, &NewLen);
+ if (code < 0)
+ return code;
+#else
+ UTF8_Password = Password;
+ NewLen = Len;
+#endif
+ if (NewLen > 127)
+ NewLen = 127;
+
+ Test = (char *)gs_alloc_bytes(ctx->memory, NewLen + 8, "R5 password test");
+ if (Test == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+
+ /* Try to validate the password as the user password */
+ /* concatenate the password */
+ memcpy(Test, UTF8_Password, NewLen);
+ /* With the 'User Validation Salt' (stored as part of the /O string */
+ memcpy(&Test[NewLen], &ctx->encryption.U[32], 8);
+
+ pSHA256_Init(&sha256);
+ pSHA256_Update(&sha256, (uint8_t *)Test, NewLen + 8);
+ pSHA256_Final((uint8_t *)Buffer, &sha256);
+
+ if (memcmp(Buffer, ctx->encryption.U, 32) != 0) {
+ code = gs_note_error(gs_error_unknownerror);
+ goto error;
+ }
+
+ /* Password matched */
+ /* Finally calculate the decryption key */
+ gs_free_object(ctx->memory, Test, "R5 password test");
+
+ /* Password + last 8 bytes of /U */
+ Test = (char *)gs_alloc_bytes(ctx->memory, NewLen + 8, "R5 password test");
+ if (Test == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+
+ memcpy(Test, UTF8_Password, NewLen);
+ /* The 'User Key Salt' (stored as part of the /O string */
+ memcpy(&Test[NewLen], &ctx->encryption.U[40], 8);
+
+ pSHA256_Init(&sha256);
+ pSHA256_Update(&sha256, (uint8_t *)Test, NewLen + 8);
+ pSHA256_Final((uint8_t *)Buffer, &sha256);
+
+ memset(UEPadded, 0x00, 16);
+ memcpy(&UEPadded[16], ctx->encryption.UE, 32);
+
+ code = pdfi_object_alloc(ctx, PDF_STRING, 32, (pdf_obj **)&Key);
+ if (code < 0)
+ goto error;
+ /* pdfi_object_alloc() creates objects with a refrence count of 0 */
+ pdfi_countup(Key);
+ memcpy(Key->data, Buffer, 32);
+
+ /* Now apply AESDecode to the padded UE string, using the SHA from above as the key */
+ code = pdfi_open_memory_stream_from_memory(ctx, 48, (byte *)UEPadded, &stream, true);
+ if (code < 0)
+ goto error;
+
+ code = pdfi_apply_AES_filter(ctx, Key, false, stream, &filter_stream);
+ if (code < 0) {
+ pdfi_close_memory_stream(ctx, NULL, stream);
+ goto error;
+ }
+
+ sfread(Buffer, 1, 32, filter_stream->s);
+ pdfi_close_file(ctx, filter_stream);
+ pdfi_close_memory_stream(ctx, NULL, stream);
+ pdfi_object_alloc(ctx, PDF_STRING, 32, (pdf_obj **)&ctx->encryption.EKey);
+ if (ctx->encryption.EKey == NULL)
+ goto error;
+ memcpy(ctx->encryption.EKey->data, Buffer, 32);
+ pdfi_countup(ctx->encryption.EKey);
+
+error:
+ pdfi_countdown(Key);
+ gs_free_object(ctx->memory, Test, "R5 password test");
+#ifdef HAVE_LIBIDN
+ gs_free_object(ctx->memory, UTF8_Password, "free sasl result");
+#endif
+ return code;
+}
+
+/* Implementation of the PDF security handler revision6 (PDF 1.7 ExtensionLevel 8 algorithm)
+ *
+ * Adobe/ISO has not yet released the details, so the algorithm reference is:
+ * http://esec-lab.sogeti.com/post/The-undocumented-password-validation-algorithm-of-Adobe-Reader-X
+ *
+ * The code below is the same as (and copied from) the MuPDF implementation. And copied from the
+ * Ghostscript implementation in zpdf_r6.c. The ISO specification is now released and the algorithms
+ * used here are documented in the PDF 2.0 specification ISO 32000-2:2017
+ */
+
+static void
+pdf_compute_hardened_hash_r6(unsigned char *password, int pwlen, unsigned char salt[16], unsigned char *ownerkey, unsigned char hash[32])
+{
+ unsigned char data[(128 + 64 + 48) * 64];
+ unsigned char block[64];
+ int block_size = 32;
+ int data_len = 0;
+ int i, j, sum;
+
+ SHA256_CTX sha256;
+ SHA384_CTX sha384;
+ SHA512_CTX sha512;
+ aes_context aes;
+
+ pSHA256_Init(&sha256);
+ pSHA256_Update(&sha256, password, pwlen);
+ pSHA256_Update(&sha256, salt, 8);
+ if (ownerkey)
+ pSHA256_Update(&sha256, ownerkey, 48);
+ pSHA256_Final((uint8_t *)block, &sha256);
+
+ for (i = 0; i < 64 || i < data[data_len * 64 - 1] + 32; i++)
+ {
+ /* Step 2: repeat password and data block 64 times */
+ memcpy(data, password, pwlen);
+ memcpy(data + pwlen, block, block_size);
+ if (ownerkey)
+ memcpy(data + pwlen + block_size, ownerkey, 48);
+ data_len = pwlen + block_size + (ownerkey ? 48 : 0);
+ for (j = 1; j < 64; j++)
+ memcpy(data + j * data_len, data, data_len);
+
+ /* Step 3: encrypt data using data block as key and iv */
+ aes_setkey_enc(&aes, block, 128);
+ aes_crypt_cbc(&aes, AES_ENCRYPT, data_len * 64, block + 16, data, data);
+
+ /* Step 4: determine SHA-2 hash size for this round */
+ for (j = 0, sum = 0; j < 16; j++)
+ sum += data[j];
+
+ /* Step 5: calculate data block for next round */
+ block_size = 32 + (sum % 3) * 16;
+ switch (block_size)
+ {
+ case 32:
+ pSHA256_Init(&sha256);
+ pSHA256_Update(&sha256, data, data_len * 64);
+ pSHA256_Final((uint8_t *)block, &sha256);
+ break;
+ case 48:
+ pSHA384_Init(&sha384);
+ pSHA384_Update(&sha384, data, data_len * 64);
+ pSHA384_Final((uint8_t *)block, &sha384);
+ break;
+ case 64:
+ pSHA512_Init(&sha512);
+ pSHA512_Update(&sha512, data, data_len * 64);
+ pSHA512_Final((uint8_t *)block, &sha512);
+ break;
+ }
+ }
+
+ memset(data, 0, sizeof(data));
+ memcpy(hash, block, 32);
+}
+
+static void
+pdf_compute_encryption_key_r6(unsigned char *password, int pwlen, unsigned char *O, unsigned char *OE, unsigned char *U, unsigned char *UE, int ownerkey, unsigned char *validationkey, unsigned char *output)
+{
+ unsigned char hash[32];
+ unsigned char iv[16];
+ aes_context aes;
+
+ if (pwlen > 127)
+ pwlen = 127;
+
+ pdf_compute_hardened_hash_r6(password, pwlen,
+ (ownerkey ? O : U) + 32,
+ ownerkey ? U : NULL, validationkey);
+ pdf_compute_hardened_hash_r6(password, pwlen,
+ (ownerkey ? O : U) + 40,
+ (ownerkey ? U : NULL), hash);
+
+ memset(iv, 0, sizeof(iv));
+ aes_setkey_dec(&aes, hash, 256);
+ aes_crypt_cbc(&aes, AES_DECRYPT, 32, iv,
+ ownerkey ? OE : UE, output);
+}
+
+static int check_user_password_R6(pdf_context *ctx, char *Password, int Len, int KeyLen)
+{
+ unsigned char validation[32];
+ unsigned char output[32];
+
+ pdf_compute_encryption_key_r6((unsigned char *)Password, Len, (unsigned char *)ctx->encryption.O, (unsigned char *)ctx->encryption.OE,
+ (unsigned char *)ctx->encryption.U, (unsigned char *)ctx->encryption.UE, 0, validation, output);
+
+ if (memcmp(validation, ctx->encryption.U, 32) != 0)
+ return_error(gs_error_unknownerror);
+
+ pdfi_object_alloc(ctx, PDF_STRING, 32, (pdf_obj **)&ctx->encryption.EKey);
+ if (ctx->encryption.EKey == NULL)
+ return_error(gs_error_VMerror);;
+ memcpy(ctx->encryption.EKey->data, output, 32);
+ pdfi_countup(ctx->encryption.EKey);
+
+ return 0;
+}
+
+static int check_user_password_preR5(pdf_context *ctx, char *Password, int Len, int KeyLen, int R)
+{
+ pdf_string *Key = NULL, *XORKey = NULL;
+ int code = 0, i, j, KeyLenBytes = KeyLen / 8;
+ pdf_c_stream *stream, *arc4_stream;
+ char Buffer[32];
+ char Hash[16];
+ gs_md5_state_t md5;
+ pdf_string *s = NULL;
+ pdf_array *a = NULL;
+
+ /* Algorithm 3.6, step 1
+ * perform all but the last step of Algorithm 3,4 (Revision 2)
+ * or Algorithm 3.5 (revision 3 or greater).
+ */
+
+ /* Algorithm 3.4 step 1
+ * Create an encryption key based on the user password string as described in Algorithm 3.2
+ */
+ code = pdf_compute_encryption_key_preR5(ctx, Password, Len, KeyLen, &Key, R);
+ if (code < 0)
+ return code;
+
+ switch (R) {
+ case 2:
+ /* Algorithm 3.4, step 2
+ * Encrypt the 32 byte padding string from step 1 of Algorithm 3.2, with an RC4
+ * encryption function, using the key from the preceding step.
+ */
+
+ code = pdfi_open_memory_stream_from_memory(ctx, 32, (byte *)PadString, &stream, true);
+ if (code < 0)
+ goto error;
+
+ code = pdfi_apply_Arc4_filter(ctx, Key, stream, &arc4_stream);
+ if (code < 0) {
+ pdfi_close_memory_stream(ctx, NULL, stream);
+ goto error;
+ }
+
+ sfread(Buffer, 1, 32, arc4_stream->s);
+ pdfi_close_file(ctx, arc4_stream);
+ pdfi_close_memory_stream(ctx, NULL, stream);
+
+ /* Algorithm 3.6 step 2
+ * If the result of the step above is equal to the value of the encryption dictionary
+ * U entry the password supplied is the correct user password.
+ */
+ if (memcmp(Buffer, ctx->encryption.U, 32) != 0) {
+ code = gs_error_unknownerror;
+ goto error;
+ } else {
+ /* Password authenticated, we can now use the calculated encryption key to decrypt the file */
+ ctx->encryption.EKey = Key;
+ }
+ break;
+ case 3:
+ case 4:
+ /* Algorithm 3.5 step 2
+ * Pass the 32 byte padding string from step 1 of Algorithm 3.2 to an MD5 hash */
+ gs_md5_init(&md5);
+ gs_md5_append(&md5, (gs_md5_byte_t *)PadString, 32);
+ code = pdfi_dict_get_type(ctx, ctx->Trailer, "ID", PDF_ARRAY, (pdf_obj **)&a);
+ if (code < 0) {
+ if (code == gs_error_undefined) {
+ emprintf(ctx->memory, "\n **** Error: ID key in the trailer is required for encrypted files.\n");
+ emprintf(ctx->memory, " File may not be possible to decrypt.\n");
+ } else
+ return code;
+ }
+ if (code == 0) {
+ /* Step 3
+ * Pass the first element of the file's file identifier array to the hash function
+ * and finish the hash
+ */
+ code = pdfi_array_get_type(ctx, a, (uint64_t)0, PDF_STRING, (pdf_obj **)&s);
+ if (code < 0)
+ goto error;
+ gs_md5_append(&md5, s->data, s->length);
+ }
+ gs_md5_finish(&md5, (gs_md5_byte_t *)&Hash);
+
+ /* Step 4
+ * Encrypt the 16-byte result of the hash using an RC4 encryption function with
+ * the encryption key from step 1 (of Algorithm 3.5).
+ */
+ code = pdfi_open_memory_stream_from_memory(ctx, 16, (byte *)Hash, &stream, true);
+ if (code < 0)
+ goto error;
+
+ code = pdfi_apply_Arc4_filter(ctx, Key, stream, &arc4_stream);
+ if (code < 0) {
+ pdfi_close_memory_stream(ctx, NULL, stream);
+ goto error;
+ }
+
+ sfread(Buffer, 1, 16, arc4_stream->s);
+ pdfi_close_file(ctx, arc4_stream);
+ pdfi_close_memory_stream(ctx, NULL, stream);
+
+ code = pdfi_object_alloc(ctx, PDF_STRING, KeyLenBytes, (pdf_obj **)&XORKey);
+ if (code < 0)
+ goto error;
+ /* pdfi_object_alloc() creates objects with a reference count of 0 */
+ pdfi_countup(XORKey);
+
+ /* Step 5
+ * Do the following 19 times. Take the output from the previous invocation of the RC4
+ * function and pas it as input to a new invocation of the function; use an encryption key
+ * generated by taking each byte of the original encyption key (obtained in step 1 of
+ * algorithm 3.5) and performing an XOR operation between that byte and the single byte
+ * value of the iteration counter (from 1 to 19).
+ */
+ for (i=1;i < 20;i++) {
+ memcpy(Hash, Buffer, 16);
+ code = pdfi_open_memory_stream_from_memory(ctx, 16, (byte *)Hash, &stream, true);
+ if (code < 0)
+ goto error;
+
+ for (j=0;j < KeyLenBytes;j++) {
+ XORKey->data[j] = Key->data[j] ^ i;
+ }
+
+ code = pdfi_apply_Arc4_filter(ctx, XORKey, stream, &arc4_stream);
+ if (code < 0) {
+ pdfi_close_memory_stream(ctx, NULL, stream);
+ goto error;
+ }
+ sfread(Buffer, 1, 16, arc4_stream->s);
+ pdfi_close_file(ctx, arc4_stream);
+ pdfi_close_memory_stream(ctx, NULL, stream);
+ }
+
+ /* Algorithm 3.6 step 2
+ * If the result of the step above is equal to the value of the encryption dictionary U entry
+ * (comparing on the first 16 bytes in the case of revision 3 of greater)
+ * the password supplied is the correct user password.
+ */
+ if (memcmp(Buffer, ctx->encryption.U, 16) != 0) {
+ code = gs_error_unknownerror;
+ goto error;
+ } else {
+ /* Password authenticated, we can now use the calculated encryption key to decrypt the file */
+ ctx->encryption.EKey = Key;
+ }
+ break;
+ default:
+ code = gs_note_error(gs_error_rangecheck);
+ goto error;
+ break;
+ }
+
+ /* We deliberately don't countdown Key here, if we created it and there were no
+ * errors then we will have stored it in the global context for future use. It
+ * will be counted down when the context is destroyed.
+ */
+ pdfi_countdown(XORKey);
+ pdfi_countdown(s);
+ pdfi_countdown(a);
+ return 0;
+
+error:
+ pdfi_countdown(XORKey);
+ pdfi_countdown(Key);
+ pdfi_countdown(s);
+ pdfi_countdown(a);
+ return code;
+}
+
+static int check_owner_password_R5(pdf_context *ctx, char *Password, int Len, int KeyLen)
+{
+ char *UTF8_Password, *Test = NULL, Buffer[32], OEPadded[48];
+ int NewLen;
+ int code = 0;
+ pdf_c_stream *stream = NULL, *filter_stream = NULL;
+ pdf_string *Key = NULL;
+ SHA256_CTX sha256;
+
+ /* From the original code in Resource/Init/pdf_sec.ps:
+ * Step 1.
+ * If the .saslprep operator isn't available (because ghostscript
+ * wasn't built with libidn support), just skip this step. ASCII
+ * passwords will still work fine, and even most non-ASCII passwords
+ * will be okay; any non-ASCII passwords that fail will produce a
+ * warning from pdf_process_Encrypt.
+ */
+#ifdef HAVE_LIBIDN
+ code = apply_sasl(ctx, Password, Len, &UTF8_Password, &NewLen);
+ if (code < 0)
+ return code;
+#else
+ UTF8_Password = Password;
+ NewLen = Len;
+#endif
+ if (NewLen > 127)
+ NewLen = 127;
+
+ Test = (char *)gs_alloc_bytes(ctx->memory, NewLen + 8 + 48, "r5 password test");
+ if (Test == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+
+ /* concatenate the password */
+ memcpy(Test, UTF8_Password, NewLen);
+ /* With the 'Owner Validation Salt' (stored as part of the /O string */
+ memcpy(&Test[NewLen], &ctx->encryption.O[32], 8);
+ /* and also concatenated with the /U string, which is defined to be 48 bytes for revision 5 */
+ memcpy(&Test[NewLen + 8], &ctx->encryption.U, 48);
+
+ /* Now calculate the SHA256 hash */
+ pSHA256_Init(&sha256);
+ pSHA256_Update(&sha256, (const uint8_t *)Test, NewLen + 8 + 48);
+ pSHA256_Final((uint8_t *)Buffer, &sha256);
+
+ if (memcmp(Buffer, ctx->encryption.O, 32) != 0) {
+ code = gs_note_error(gs_error_unknownerror);
+ goto error;
+ }
+
+ /* Password matched */
+ /* Finally calculate the decryption key */
+ gs_free_object(ctx->memory, Test, "R5 password test");
+
+ /* Password + last 8 bytes of /O */
+ Test = (char *)gs_alloc_bytes(ctx->memory, NewLen + 8 + 48, "R5 password test");
+ if (Test == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+
+ memcpy(Test, UTF8_Password, NewLen);
+ /* The 'User Key Salt' (stored as part of the /O string */
+ memcpy(&Test[NewLen], &ctx->encryption.O[40], 8);
+ memcpy(&Test[NewLen + 8], ctx->encryption.U, 48);
+
+ /* Now calculate the SHA256 hash */
+ pSHA256_Init(&sha256);
+ pSHA256_Update(&sha256, (const uint8_t *)Test, NewLen + 8 + 48);
+ pSHA256_Final((uint8_t *)Buffer, &sha256);
+
+ memset(OEPadded, 0x00, 16);
+ memcpy(&OEPadded[16], ctx->encryption.OE, 32);
+
+ code = pdfi_object_alloc(ctx, PDF_STRING, 32, (pdf_obj **)&Key);
+ if (code < 0)
+ goto error;
+ /* pdfi_object_alloc() creates objects with a refrence count of 0 */
+ pdfi_countup(Key);
+ memcpy(Key->data, Buffer, 32);
+
+ /* Now apply AESDecode to the padded UE string, using the SHA from above as the key */
+ code = pdfi_open_memory_stream_from_memory(ctx, 48, (byte *)OEPadded, &stream, true);
+ if (code < 0)
+ goto error;
+
+ code = pdfi_apply_AES_filter(ctx, Key, false, stream, &filter_stream);
+ if (code < 0) {
+ pdfi_close_memory_stream(ctx, NULL, stream);
+ goto error;
+ }
+
+ sfread(Buffer, 1, 32, filter_stream->s);
+ pdfi_close_file(ctx, filter_stream);
+ pdfi_close_memory_stream(ctx, NULL, stream);
+ pdfi_object_alloc(ctx, PDF_STRING, 32, (pdf_obj **)&ctx->encryption.EKey);
+ if (ctx->encryption.EKey == NULL)
+ goto error;
+ memcpy(ctx->encryption.EKey->data, Buffer, 32);
+ pdfi_countup(ctx->encryption.EKey);
+
+error:
+ pdfi_countdown(Key);
+ gs_free_object(ctx->memory, Test, "R5 password test");
+#ifdef HAVE_LIBIDN
+ gs_free_object(ctx->memory, UTF8_Password, "free sasl result");
+#endif
+ return code;
+}
+
+static int check_owner_password_R6(pdf_context *ctx, char *Password, int Len, int KeyLen)
+{
+ unsigned char validation[32];
+ unsigned char output[32];
+
+ pdf_compute_encryption_key_r6((unsigned char *)Password, Len, (unsigned char *)ctx->encryption.O, (unsigned char *)ctx->encryption.OE,
+ (unsigned char *)ctx->encryption.U, (unsigned char *)ctx->encryption.UE, 1, validation, output);
+
+ if (memcmp(validation, ctx->encryption.O, 32) != 0)
+ return_error(gs_error_unknownerror);
+
+ pdfi_object_alloc(ctx, PDF_STRING, 32, (pdf_obj **)&ctx->encryption.EKey);
+ if (ctx->encryption.EKey == NULL)
+ return_error(gs_error_VMerror);;
+ memcpy(ctx->encryption.EKey->data, output, 32);
+ pdfi_countup(ctx->encryption.EKey);
+
+ return 0;
+}
+
+static int check_owner_password_preR5(pdf_context *ctx, char *Password, int Len, int KeyLen, int R)
+{
+ char Key[32];
+ int code = 0, i, j, KeyLenBytes = KeyLen / 8;
+ pdf_string *EKey = NULL;
+ gs_md5_state_t md5;
+ pdf_c_stream *stream, *arc4_stream;
+ char Buffer[32], Arc4Source[32];
+
+ /* Algorithm 3.7 */
+ /* Step 1, Compute an encryption key from steps 1-4 of Algorithm 3.3 */
+
+ /* Algorithm 3.3, step 1. Pad or truncate the password string to exactly 32 bytes */
+ if (Len > 32)
+ Len = 32;
+
+ memcpy(Key, Password, Len);
+
+ if (Len < 32)
+ memcpy(&Key[Len], PadString, 32 - Len);
+
+ /* Algorithm 3.3, step 2. Initialise the MD5 hash function and pass the result of step 1 to this function */
+ gs_md5_init(&md5);
+ gs_md5_append(&md5, (gs_md5_byte_t *)&Key, 32);
+ gs_md5_finish(&md5, (gs_md5_byte_t *)&Key);
+
+ /* Algorithm 3.3, step 3. Only for R3 or greater */
+ if (R > 2) {
+ code = pdfi_object_alloc(ctx, PDF_STRING, KeyLenBytes, (pdf_obj **)&EKey);
+ if (code < 0)
+ goto error;
+ /* pdfi_object_alloc() creates objects with a refrence count of 0 */
+ pdfi_countup(EKey);
+
+ for (i = 0; i < 50; i++) {
+ gs_md5_init(&md5);
+ gs_md5_append(&md5, (gs_md5_byte_t *)&Key, KeyLenBytes);
+ gs_md5_finish(&md5, (gs_md5_byte_t *)&Key);
+ }
+ /* Algorithm 3.3, step 4. Use KeyLen bytes of the final hash as an RC$ key */
+ /* Algorithm 3.7, step 2 (R >= 3) */
+ memcpy(Buffer, ctx->encryption.O, 32);
+
+ /* Algorithm 3.7 states (at the end):
+ * "performing an XOR (exclusive or) operation between each byte of the key and the single-byte value of the iteration counter (from 19 to 0)."
+ * which implies that the loop should run 20 times couting down from 19 to 0. For decryption at least this is completely
+ * incorrect. Doing that results in completely garbage output.
+ * By using 0 as the first index we get the correct Key when XOR'ing that with the
+ * key computed above, and continuing until the loop counter reaches 19 gives us the correct
+ * result.
+ */
+ for (i=0; i<20; i++) {
+ memcpy(Arc4Source, Buffer, 32);
+ code = pdfi_open_memory_stream_from_memory(ctx, 32, (byte *)Arc4Source, &stream, true);
+ if (code < 0)
+ goto error;
+ for(j=0;j< KeyLenBytes;j++){
+ EKey->data[j] = Key[j] ^ i;
+ }
+ code = pdfi_apply_Arc4_filter(ctx, EKey, stream, &arc4_stream);
+ sfread(Buffer, 1, 32, arc4_stream->s);
+ pdfi_close_file(ctx, arc4_stream);
+ pdfi_close_memory_stream(ctx, NULL, stream);
+ }
+
+ } else {
+ /* Algorithm 3.3, step 4. For revision 2 always use 5 bytes of the final hash as an RC4 key */
+ code = pdfi_object_alloc(ctx, PDF_STRING, 5, (pdf_obj **)&EKey);
+ if (code < 0)
+ goto error;
+ pdfi_countup(EKey);
+ memcpy(EKey->data, Key, 5);
+
+ /* Algorithm 3.7, step 2 (R == 2) Use RC4 with the computed key to decrypt the O entry of the crypt dict */
+ code = pdfi_open_memory_stream_from_memory(ctx, 32, (byte *)ctx->encryption.O, &stream, true);
+ if (code < 0)
+ goto error;
+
+ code = pdfi_apply_Arc4_filter(ctx, EKey, stream, &arc4_stream);
+ pdfi_countdown(EKey);
+ EKey = NULL;
+
+ sfread(Buffer, 1, 32, arc4_stream->s);
+
+ pdfi_close_file(ctx, arc4_stream);
+ pdfi_close_memory_stream(ctx, NULL, stream);
+ }
+
+ /* Algorithm 3.7, step 3, the result of step 2 purports to be the user password, check it */
+ code = check_user_password_preR5(ctx, Buffer, 32, KeyLen, R);
+
+error:
+ pdfi_countdown(EKey);
+ return code;
+}
+
+/* Compute a decryption key for an 'object'. The decryption key for a string or stream is
+ * calculated by algorithm 3.1.
+ */
+int pdfi_compute_objkey(pdf_context *ctx, pdf_obj *obj, pdf_string **Key)
+{
+ char *Buffer;
+ int idx, ELength, code = 0, md5_length = 0;
+ gs_md5_state_t md5;
+ int64_t object_num;
+ uint32_t generation_num;
+
+ if (ctx->encryption.R < 5) {
+ if (obj->object_num == 0) {
+ /* The object is a direct object, use the object number of the container instead */
+ object_num = obj->indirect_num;
+ generation_num = obj->indirect_gen;
+ } else {
+ object_num = obj->object_num;
+ generation_num = obj->generation_num;
+ }
+
+ /* Step 1, obtain the object and generation numbers (see arguments). If the string is
+ * a direct object, use the identifier of the indirect object containing it.
+ * Buffer length is a maximum of the Encryption key + 3 bytes from the object number
+ * + 2 bytes from the generation number and (for AES filters) 4 bytes of sALT.
+ * But... We must make sure the buffer is large enough for the 128 bits of an MD5 hash.
+ */
+ md5_length = ctx->encryption.EKey->length + 9;
+ if (md5_length < 16)
+ md5_length = 16;
+
+ Buffer = (char *)gs_alloc_bytes(ctx->memory, md5_length, "");
+ if (Buffer == NULL)
+ return gs_note_error(gs_error_VMerror);
+
+ /* Step 2, Treating the object number and generation number as binary integers, extend
+ * the original n-byte encryption key (calculated in pdfi_read_Encryption) to n+5 bytes
+ * by appending the low order 3 bytes of the object number and the low order 2 bytes of
+ * the generation number in that order, low-order byte first. (n is 5 unless the value
+ * of V in the encryption dictionary is greater than 1 in which case n is the value of
+ * Length divided by 8). Because we store the encryption key is as a PDF string object,
+ * we can just use the length of the string data, we calculated the length as part of
+ * creating the key.
+ */
+ memcpy(Buffer, ctx->encryption.EKey->data, ctx->encryption.EKey->length);
+ idx = ctx->encryption.EKey->length;
+ Buffer[idx] = object_num & 0xff;
+ Buffer[++idx] = (object_num & 0xff00) >> 8;
+ Buffer[++idx] = (object_num & 0xff0000) >> 16;
+ Buffer[++idx] = generation_num & 0xff;
+ Buffer[++idx] = (generation_num & 0xff00) >> 8;
+
+ md5_length = ctx->encryption.EKey->length + 5;
+
+ /* If using the AES algorithm, extend the encryption key an additional 4 bytes
+ * by adding the value "sAlT" which corresponds to the hexadecimal 0x73416c54
+ * (This addition is done for backward compatibility and is not intended to
+ * provide addtional security).
+ */
+ if (ctx->encryption.StmF == CRYPT_AESV2 || ctx->encryption.StmF == CRYPT_AESV3){
+ memcpy(&Buffer[++idx], sAlTString, 4);
+ md5_length += 4;
+ }
+
+ /* Step 3
+ * Initialise the MD5 function and pass the result of step 2 as input to this function
+ */
+ gs_md5_init(&md5);
+ gs_md5_append(&md5, (gs_md5_byte_t *)Buffer, md5_length);
+ gs_md5_finish(&md5, (gs_md5_byte_t *)Buffer);
+
+ /* Step 4
+ * Use the first n+5 bytes, up to a maximum of 16, of the output from the MD5
+ * hash as the key for the RC4 or AES symmetric key algorithms, along with the
+ * string or stream data to be encrypted.
+ */
+ ELength = ctx->encryption.EKey->length + 5;
+ if (ELength > 16)
+ ELength = 16;
+
+ code = pdfi_object_alloc(ctx, PDF_STRING, (uint64_t)ELength, (pdf_obj **)Key);
+ if (code >= 0)
+ memcpy((*Key)->data, Buffer, ELength);
+ /* pdfi_object_alloc() creates objects with a refrence count of 0 */
+ pdfi_countup(*Key);
+
+ gs_free_object(ctx->memory, Buffer, "");
+ } else {
+ /* Revision 5 & 6 don't use the object number and generation, just return the pre-calculated key */
+ *Key = ctx->encryption.EKey;
+ pdfi_countup(*Key);
+ }
+ return code;
+}
+
+int pdfi_decrypt_string(pdf_context *ctx, pdf_string *string)
+{
+ int code = 0;
+ pdf_c_stream *stream = NULL, *crypt_stream = NULL;
+ pdf_string *EKey = NULL;
+ char *Buffer = NULL;
+
+ if (!is_compressed_object(ctx, string->indirect_num, string->indirect_gen)) {
+ Buffer = (char *)gs_alloc_bytes(ctx->memory, string->length, "pdfi_decrypt_string");
+ if (Buffer == NULL)
+ return_error(gs_error_VMerror);
+
+ code = pdfi_compute_objkey(ctx, (pdf_obj *)string, &EKey);
+ if (code < 0)
+ goto error;
+
+ code = pdfi_open_memory_stream_from_memory(ctx, string->length, (byte *)string->data, &stream, true);
+ if (code < 0)
+ goto error;
+
+ switch(ctx->encryption.StrF) {
+ /* There are only two possible filters, RC4 or AES, we take care
+ * of the number of bits in the key by using ctx->Length.
+ */
+ case CRYPT_IDENTITY:
+ pdfi_close_memory_stream(ctx, NULL, stream);
+ code = 0;
+ goto error;
+ break;
+ case CRYPT_V1:
+ case CRYPT_V2:
+ code = pdfi_apply_Arc4_filter(ctx, EKey, stream, &crypt_stream);
+ break;
+ case CRYPT_AESV2:
+ case CRYPT_AESV3:
+ code = pdfi_apply_AES_filter(ctx, EKey, 1, stream, &crypt_stream);
+ break;
+ default:
+ code = gs_error_rangecheck;
+ }
+ if (code < 0) {
+ pdfi_close_memory_stream(ctx, NULL, stream);
+ goto error;
+ }
+
+ sfread(Buffer, 1, string->length, crypt_stream->s);
+
+ pdfi_close_file(ctx, crypt_stream);
+ pdfi_close_memory_stream(ctx, NULL, stream);
+
+ memcpy(string->data, Buffer, string->length);
+ }
+
+error:
+ gs_free_object(ctx->memory, Buffer, "pdfi_decrypt_string");
+ pdfi_countdown(EKey);
+ return code;
+}
+
+/* Read the Encrypt dictionary entries and store the relevant ones
+ * in the PDF context for easy access. Return < 0 = error, 0 = encrypted
+ * and read the encryption details, 1 = not encrypted.
+ */
+static int pdfi_read_Encrypt_dict(pdf_context *ctx, int *KeyLen)
+{
+ int code = 0;
+ pdf_dict *CF_dict = NULL, *StdCF_dict = NULL;
+ pdf_dict *d = NULL;
+ pdf_obj *o = NULL;
+ pdf_string *s = NULL;
+ int64_t i64;
+ double f;
+
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "%% Checking for Encrypt dictionary\n");
+
+ code = pdfi_dict_get(ctx, ctx->Trailer, "Encrypt", (pdf_obj **)&d);
+
+ /* Undefined is acceptable here, it just means the PDF file is not ostensibly encrypted */
+ /* NB pdfi_process_pdf_file() always checks for the Encrypt dictionary before we
+ * get here, so there shouldn't be a problem.....
+ */
+ if (code == gs_error_undefined)
+ return 1;
+ else
+ if (code < 0)
+ goto done;
+
+ code = pdfi_dict_get_type(ctx, d, "Filter", PDF_NAME, &o);
+ if (code < 0)
+ goto done;
+
+ if (!pdfi_name_is((pdf_name *)o, "Standard")) {
+ char *Str = NULL;
+
+ Str = (char *)gs_alloc_bytes(ctx->memory, ((pdf_name *)o)->length + 1, "temp string for warning");
+ if (Str == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto done;
+ }
+ memset(Str, 0x00, ((pdf_name *)o)->length + 1);
+ memcpy(Str, ((pdf_name *)o)->data, ((pdf_name *)o)->length);
+ emprintf1(ctx->memory, "\n **** Warning: This file uses an unknown security handler %s\n", Str);
+ gs_free_object(ctx->memory, Str, "temp string for warning");
+ code = gs_note_error(gs_error_typecheck);
+ goto done;
+ }
+ pdfi_countdown(o);
+ o = NULL;
+
+ code = pdfi_dict_knownget_number(ctx, d, "Length", &f);
+ if (code < 0)
+ goto done;
+
+ if (code > 0)
+ *KeyLen = (int)f;
+ else
+ *KeyLen = 0;
+
+ code = pdfi_dict_get_int(ctx, d, "V", &i64);
+ if (code < 0)
+ goto done;
+
+ if (i64 < 1 || i64 > 5) {
+ code = gs_error_rangecheck;
+ goto done;
+ }
+
+ ctx->encryption.V = (int)i64;
+
+ code = pdfi_dict_get_int(ctx, d, "R", &i64);
+ if (code < 0)
+ goto done;
+ ctx->encryption.R = (int)i64;
+
+ code = pdfi_dict_get_int(ctx, d, "P", &i64);
+ if (code < 0)
+ goto done;
+ ctx->encryption.P = (int)i64;
+
+ code = pdfi_dict_get_type(ctx, d, "O", PDF_STRING, (pdf_obj **)&s);
+ if (code < 0)
+ goto done;
+
+ if (ctx->encryption.R < 5) {
+ if (s->length < 32) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto done;
+ }
+ memcpy(ctx->encryption.O, s->data, 32);
+ } else {
+ if (s->length < 48) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto done;
+ }
+ memcpy(ctx->encryption.O, s->data, 48);
+ }
+ pdfi_countdown(s);
+ s = NULL;
+
+ code = pdfi_dict_get_type(ctx, d, "U", PDF_STRING, (pdf_obj **)&s);
+ if (code < 0)
+ goto done;
+
+ if (ctx->encryption.R < 5) {
+ if (s->length < 32) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto done;
+ }
+ memcpy(ctx->encryption.U, s->data, 32);
+ } else {
+ if (s->length < 48) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto done;
+ }
+ memcpy(ctx->encryption.U, s->data, 48);
+ }
+ pdfi_countdown(s);
+ s = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, d, "EncryptMetadata", PDF_BOOL, &o);
+ if (code < 0)
+ goto done;
+ if (code > 0) {
+ ctx->encryption.EncryptMetadata = ((pdf_bool *)o)->value;
+ pdfi_countdown(o);
+ }
+ else
+ ctx->encryption.EncryptMetadata = true;
+
+ if (ctx->encryption.R > 3) {
+ /* Check the Encrypt dictionary has default values for Stmf and StrF
+ * and that they have the names /StdCF. We don't support anything else.
+ */
+ code = pdfi_dict_get_type(ctx, d, "StmF", PDF_NAME, &o);
+ if (code < 0)
+ goto done;
+ if (!pdfi_name_is((pdf_name *)o, "StdCF")) {
+ if (pdfi_name_is((pdf_name *)o, "Identity")) {
+ ctx->encryption.StmF = CRYPT_IDENTITY;
+ } else {
+ code = gs_note_error(gs_error_undefined);
+ goto done;
+ }
+ }
+ pdfi_countdown(o);
+ o = NULL;
+
+ code = pdfi_dict_knownget_type(ctx, d, "StrF", PDF_NAME, &o);
+ if (code < 0)
+ goto done;
+ if (!pdfi_name_is((pdf_name *)o, "StdCF")) {
+ if (pdfi_name_is((pdf_name *)o, "Identity")) {
+ ctx->encryption.StrF = CRYPT_IDENTITY;
+ } else {
+ code = gs_note_error(gs_error_undefined);
+ goto done;
+ }
+ }
+ pdfi_countdown(o);
+ o = NULL;
+
+ /* Validated StmF and StrF, now check the Encrypt dictionary for the definition of
+ * the Crypt Filter dictionary and ensure it has a /StdCF dictionary.
+ */
+ code = pdfi_dict_get_type(ctx, d, "CF", PDF_DICT, (pdf_obj **)&CF_dict);
+ if (code < 0)
+ goto done;
+
+ code = pdfi_dict_get_type(ctx, CF_dict, "StdCF", PDF_DICT, (pdf_obj **)&StdCF_dict);
+ if (code < 0)
+ goto done;
+
+ code = pdfi_dict_get_type(ctx, StdCF_dict, "CFM", PDF_NAME, &o);
+ if (code < 0)
+ goto done;
+
+ if (pdfi_name_is((pdf_name *)o, "V2")) {
+ if (ctx->encryption.StmF == CRYPT_NONE)
+ ctx->encryption.StmF = CRYPT_V2;
+ if (ctx->encryption.StrF == CRYPT_NONE)
+ ctx->encryption.StrF = CRYPT_V2;
+ } else {
+ if (pdfi_name_is((pdf_name *)o, "AESV2")) {
+ if (ctx->encryption.StmF == CRYPT_NONE)
+ ctx->encryption.StmF = CRYPT_AESV2;
+ if (ctx->encryption.StrF == CRYPT_NONE)
+ ctx->encryption.StrF = CRYPT_AESV2;
+ } else {
+ if (pdfi_name_is((pdf_name *)o, "AESV3")) {
+ if (ctx->encryption.StmF == CRYPT_NONE)
+ ctx->encryption.StmF = CRYPT_AESV3;
+ if (ctx->encryption.StrF == CRYPT_NONE)
+ ctx->encryption.StrF = CRYPT_AESV3;
+ } else {
+ emprintf(ctx->memory, "\n **** Error: Unknown default encryption method in crypt filter.\n");
+ code = gs_error_rangecheck;
+ goto done;
+ }
+ }
+ }
+ pdfi_countdown(o);
+ o = NULL;
+
+ if (ctx->encryption.R > 4) {
+ code = pdfi_dict_get_type(ctx, d, "OE", PDF_STRING, (pdf_obj **)&s);
+ if (code < 0)
+ goto done;
+
+ if (s->length != 32) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto done;
+ }
+ memcpy(ctx->encryption.OE, s->data, 32);
+ pdfi_countdown(s);
+ s = NULL;
+
+ code = pdfi_dict_get_type(ctx, d, "UE", PDF_STRING, (pdf_obj **)&s);
+ if (code < 0)
+ goto done;
+
+ if (s->length != 32) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto done;
+ }
+ memcpy(ctx->encryption.UE, s->data, 32);
+ pdfi_countdown(s);
+ s = NULL;
+ }
+ }
+
+done:
+ pdfi_countdown(StdCF_dict);
+ pdfi_countdown(CF_dict);
+ pdfi_countdown(s);
+ pdfi_countdown(o);
+ pdfi_countdown(d);
+ return code;
+}
+
+static int check_password_preR5(pdf_context *ctx, char *Password, int PasswordLen, int KeyLen, int Revision)
+{
+ int code;
+
+ if (PasswordLen != 0) {
+ code = check_user_password_preR5(ctx, Password, PasswordLen, KeyLen, Revision);
+ if (code >= 0)
+ return 0;
+
+ code = check_owner_password_preR5(ctx, Password, PasswordLen, KeyLen, Revision);
+ if (code >= 0)
+ return 0;
+ }
+ code = check_user_password_preR5(ctx, (char *)"", 0, KeyLen, Revision);
+ if (code >= 0)
+ return 0;
+
+ return check_owner_password_preR5(ctx, (char *)"", 0, KeyLen, Revision);
+}
+
+static int check_password_R5(pdf_context *ctx, char *Password, int PasswordLen, int KeyLen)
+{
+ int code;
+
+ if (PasswordLen != 0) {
+ code = check_user_password_R5(ctx, Password, PasswordLen, KeyLen);
+ if (code >= 0)
+ return 0;
+
+ code = check_owner_password_R5(ctx, Password, PasswordLen, KeyLen);
+ if (code >= 0)
+ return 0;
+
+ /* If the supplied Password fails as the user *and* owner password, maybe its in
+ * the locale, not UTF-8, try converting to UTF-8
+ */
+ if (code < 0) {
+ pdf_string *P = NULL, *P_UTF8 = NULL;
+
+ code = pdfi_object_alloc(ctx, PDF_STRING, strlen(ctx->encryption.Password), (pdf_obj **)&P);
+ if (code < 0) {
+ return code;
+ }
+ memcpy(P->data, Password, PasswordLen);
+ pdfi_countup(P);
+ code = locale_to_utf8(ctx, P, &P_UTF8);
+ if (code < 0) {
+ pdfi_countdown(P);
+ return code;
+ }
+ code = check_user_password_R5(ctx, (char *)P_UTF8->data, P_UTF8->length, KeyLen);
+ if (code >= 0) {
+ pdfi_countdown(P);
+ pdfi_countdown(P_UTF8);
+ return code;
+ }
+
+ code = check_owner_password_R5(ctx, (char *)P_UTF8->data, P_UTF8->length, KeyLen);
+ pdfi_countdown(P);
+ pdfi_countdown(P_UTF8);
+ if (code >= 0)
+ return code;
+ }
+ }
+ code = check_user_password_R5(ctx, (char *)"", 0, KeyLen);
+ if (code >= 0)
+ return 0;
+
+ return check_owner_password_R5(ctx, (char *)"", 0, KeyLen);
+}
+
+static int check_password_R6(pdf_context *ctx, char *Password, int PasswordLen, int KeyLen)
+{
+ int code;
+
+ if (PasswordLen != 0) {
+ code = check_user_password_R6(ctx, Password, PasswordLen, KeyLen);
+ if (code >= 0)
+ return 0;
+
+ code = check_owner_password_R6(ctx, Password, PasswordLen, KeyLen);
+ if (code >= 0)
+ return 0;
+ /* If the supplied Password fails as the user *and* owner password, maybe its in
+ * the locale, not UTF-8, try converting to UTF-8
+ */
+ if (code < 0) {
+ pdf_string *P = NULL, *P_UTF8 = NULL;
+
+ code = pdfi_object_alloc(ctx, PDF_STRING, strlen(ctx->encryption.Password), (pdf_obj **)&P);
+ if (code < 0)
+ return code;
+ memcpy(P->data, Password, PasswordLen);
+ pdfi_countup(P);
+ code = locale_to_utf8(ctx, P, &P_UTF8);
+ if (code < 0) {
+ pdfi_countdown(P);
+ return code;
+ }
+ code = check_user_password_R5(ctx, (char *)P_UTF8->data, P_UTF8->length, KeyLen);
+ if (code >= 0) {
+ pdfi_countdown(P);
+ pdfi_countdown(P_UTF8);
+ return code;
+ }
+
+ code = check_owner_password_R5(ctx, (char *)P_UTF8->data, P_UTF8->length, KeyLen);
+ pdfi_countdown(P);
+ pdfi_countdown(P_UTF8);
+ if (code >= 0)
+ return code;
+ }
+ }
+ code = check_user_password_R6(ctx, (char *)"", 0, KeyLen);
+ if (code >= 0)
+ return 0;
+
+ return check_owner_password_R6(ctx, (char *)"", 0, KeyLen);
+}
+
+/* Read the Encrypt dictionary entries and store the relevant ones
+ * in the PDF context for easy access. Check whether the file is
+ * readable without a password and if not, check to see if we've been
+ * supplied a password. If we have try the password as the user password
+ * and if that fails as the owner password. Store the calculated decryption key
+ * for later use decrypting objects.
+ */
+int pdfi_initialise_Decryption(pdf_context *ctx)
+{
+ int code = 0, KeyLen = 0;
+
+ code = pdfi_read_Encrypt_dict(ctx, &KeyLen);
+ if (code > 0)
+ return 0;
+ if (code < 0)
+ return code;
+
+ switch(ctx->encryption.R) {
+ case 2:
+ /* Set up the defaults if not already set */
+ /* Revision 2 is always 40-bit RC4 */
+ if (KeyLen == 0)
+ KeyLen = 40;
+ if (ctx->encryption.StmF == CRYPT_NONE)
+ ctx->encryption.StmF = CRYPT_V1;
+ if (ctx->encryption.StrF == CRYPT_NONE)
+ ctx->encryption.StrF = CRYPT_V1;
+ code = check_password_preR5(ctx, ctx->encryption.Password, ctx->encryption.PasswordLen, KeyLen, 2);
+ break;
+ case 3:
+ /* Set up the defaults if not already set */
+ /* Revision 3 is always 128-bit RC4 */
+ if (KeyLen == 0)
+ KeyLen = 128;
+ if (ctx->encryption.StmF == CRYPT_NONE)
+ ctx->encryption.StmF = CRYPT_V2;
+ if (ctx->encryption.StrF == CRYPT_NONE)
+ ctx->encryption.StrF = CRYPT_V2;
+ code = check_password_preR5(ctx, ctx->encryption.Password, ctx->encryption.PasswordLen, KeyLen, 3);
+ break;
+ case 4:
+ /* Revision 4 is either AES or RC4, but its always 128-bits */
+ if (KeyLen == 0)
+ KeyLen = 128;
+ /* We can't set the encryption filter, so we have to hope the PDF file did */
+ code = check_password_preR5(ctx, ctx->encryption.Password, ctx->encryption.PasswordLen, KeyLen, 4);
+ break;
+ case 5:
+ /* Set up the defaults if not already set */
+ if (KeyLen == 0)
+ KeyLen = 256;
+ if (ctx->encryption.StmF == CRYPT_NONE)
+ ctx->encryption.StmF = CRYPT_AESV2;
+ if (ctx->encryption.StrF == CRYPT_NONE)
+ ctx->encryption.StrF = CRYPT_AESV2;
+ code = check_password_R5(ctx, ctx->encryption.Password, ctx->encryption.PasswordLen, KeyLen);
+ break;
+ case 6:
+ /* Set up the defaults if not already set */
+ /* Revision 6 is always 256-bit AES */
+ if (KeyLen == 0)
+ KeyLen = 256;
+ if (ctx->encryption.StmF == CRYPT_NONE)
+ ctx->encryption.StmF = CRYPT_AESV3;
+ if (ctx->encryption.StrF == CRYPT_NONE)
+ ctx->encryption.StrF = CRYPT_AESV3;
+ code = check_password_R6(ctx, ctx->encryption.Password, ctx->encryption.PasswordLen, KeyLen);
+ break;
+ default:
+ emprintf1(ctx->memory, "\n **** Warning: This file uses an unknown standard security handler revision: %d\n", ctx->encryption.R);
+ code = gs_error_rangecheck;
+ goto done;
+ }
+ if (code < 0) {
+ if(ctx->encryption.Password) {
+ emprintf(ctx->memory, "\n **** Error: Password did not work.\n");
+ emprintf(ctx->memory, " Cannot decrypt PDF file.\n");
+ } else
+ emprintf(ctx->memory, "\n **** This file requires a password for access.\n");
+ } else
+ ctx->encryption.is_encrypted = true;
+
+done:
+ return code;
+}
diff --git a/pdf/pdf_sec.h b/pdf/pdf_sec.h
new file mode 100644
index 00000000..465d31f7
--- /dev/null
+++ b/pdf/pdf_sec.h
@@ -0,0 +1,23 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+#ifndef PDF_SECURITY
+#define PDF_SECURITY
+
+int pdfi_compute_objkey(pdf_context *ctx, pdf_obj *obj, pdf_string **Key);
+int pdfi_decrypt_string(pdf_context *ctx, pdf_string *string);
+int pdfi_initialise_Decryption(pdf_context *ctx);
+
+#endif
diff --git a/pdf/pdf_shading.c b/pdf/pdf_shading.c
new file mode 100644
index 00000000..01a2d0e1
--- /dev/null
+++ b/pdf/pdf_shading.c
@@ -0,0 +1,927 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Shading operations for the PDF interpreter */
+
+#include "pdf_int.h"
+#include "pdf_stack.h"
+#include "pdf_gstate.h"
+#include "pdf_shading.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_func.h"
+#include "pdf_file.h"
+#include "pdf_loop_detect.h"
+#include "pdf_colour.h"
+#include "pdf_trans.h"
+#include "pdf_optcontent.h"
+#include "pdf_doc.h"
+#include "pdf_misc.h"
+
+#include "gsfunc3.h" /* for gs_function_Ad0t_params_t */
+#include "gxshade.h"
+#include "gsptype2.h"
+#include "gsfunc0.h" /* For gs_function */
+#include "gscolor3.h" /* For gs_shfill() */
+
+static int pdfi_build_shading_function(pdf_context *ctx, gs_function_t **ppfn, const float *shading_domain, int num_inputs, pdf_dict *shading_dict, pdf_dict *page_dict)
+{
+ int code;
+ pdf_obj *o = NULL;
+ pdf_obj * rsubfn = NULL;
+ gs_function_AdOt_params_t params;
+
+ memset(&params, 0x00, sizeof(params));
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_get(ctx, shading_dict, "Function", &o);
+ if (code < 0)
+ goto build_shading_function_error;
+
+ if (o->type != PDF_DICT && o->type != PDF_STREAM) {
+ uint size;
+ pdf_obj *rsubfn;
+ gs_function_t **Functions;
+ int64_t i;
+
+ if (o->type != PDF_ARRAY) {
+ code = gs_error_typecheck;
+ goto build_shading_function_error;
+ }
+ size = pdfi_array_size(((pdf_array *)o));
+
+ if (size == 0) {
+ code = gs_error_rangecheck;
+ goto build_shading_function_error;
+ }
+ code = alloc_function_array(size, &Functions, ctx->memory);
+ if (code < 0)
+ goto build_shading_function_error;
+
+ for (i = 0; i < size; ++i) {
+ code = pdfi_array_get(ctx, (pdf_array *)o, i, &rsubfn);
+ if (code == 0) {
+ if (rsubfn->type != PDF_DICT && rsubfn->type != PDF_STREAM)
+ code = gs_note_error(gs_error_typecheck);
+ }
+ if (code < 0) {
+ int j;
+
+ for (j = 0;j < i; j++) {
+ pdfi_free_function(ctx, Functions[j]);
+ Functions[j] = NULL;
+ }
+ gs_free_object(ctx->memory, Functions, "function array error, freeing functions");
+ goto build_shading_function_error;
+ }
+ code = pdfi_build_function(ctx, &Functions[i], shading_domain, num_inputs, rsubfn, page_dict);
+ if (code < 0)
+ goto build_shading_function_error;
+ pdfi_countdown(rsubfn);
+ rsubfn = NULL;
+ }
+ params.m = num_inputs;
+ params.Domain = 0;
+ params.n = size;
+ params.Range = 0;
+ params.Functions = (const gs_function_t * const *)Functions;
+ code = gs_function_AdOt_init(ppfn, &params, ctx->memory);
+ if (code < 0)
+ goto build_shading_function_error;
+ } else {
+ code = pdfi_build_function(ctx, ppfn, shading_domain, num_inputs, o, page_dict);
+ if (code < 0)
+ goto build_shading_function_error;
+ }
+
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ pdfi_countdown(o);
+ return code;
+
+build_shading_function_error:
+ gs_function_AdOt_free_params(&params, ctx->memory);
+ pdfi_countdown(rsubfn);
+ pdfi_countdown(o);
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ return code;
+}
+
+static int pdfi_shading1(pdf_context *ctx, gs_shading_params_t *pcommon,
+ gs_shading_t **ppsh,
+ pdf_obj *Shading, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ pdf_obj *o = NULL;
+ int code, i;
+ gs_shading_Fb_params_t params;
+ static const float default_Domain[4] = {0, 1, 0, 1};
+ pdf_dict *shading_dict;
+
+ if (Shading->type != PDF_DICT)
+ return_error(gs_error_typecheck);
+ shading_dict = (pdf_dict *)Shading;
+
+ memset(&params, 0, sizeof(params));
+ *(gs_shading_params_t *)&params = *pcommon;
+ gs_make_identity(&params.Matrix);
+ params.Function = 0;
+
+ code = fill_domain_from_dict(ctx, (float *)&params.Domain, 4, shading_dict);
+ if (code < 0) {
+ if (code == gs_error_undefined) {
+ for (i = 0; i < 4; i++) {
+ params.Domain[i] = default_Domain[i];
+ }
+ } else
+ return code;
+ }
+
+ code = fill_matrix_from_dict(ctx, (float *)&params.Matrix, shading_dict);
+ if (code < 0)
+ return code;
+
+ code = pdfi_build_shading_function(ctx, &params.Function, (const float *)&params.Domain, 2, (pdf_dict *)shading_dict, page_dict);
+ if (code < 0){
+ pdfi_countdown(o);
+ return code;
+ }
+ code = gs_shading_Fb_init(ppsh, &params, ctx->memory);
+ if (code < 0) {
+ gs_free_object(ctx->memory, params.Function, "Function");
+ pdfi_countdown(o);
+ }
+ return code;
+}
+
+static int pdfi_shading2(pdf_context *ctx, gs_shading_params_t *pcommon,
+ gs_shading_t **ppsh,
+ pdf_obj *Shading, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ pdf_obj *o = NULL;
+ gs_shading_A_params_t params;
+ static const float default_Domain[2] = {0, 1};
+ int code, i;
+ pdf_dict *shading_dict;
+
+ if (Shading->type != PDF_DICT)
+ return_error(gs_error_typecheck);
+ shading_dict = (pdf_dict *)Shading;
+
+ memset(&params, 0, sizeof(params));
+ *(gs_shading_params_t *)&params = *pcommon;
+
+ code = fill_float_array_from_dict(ctx, (float *)&params.Coords, 4, shading_dict, "Coords");
+ if (code < 0)
+ return code;
+ code = fill_domain_from_dict(ctx, (float *)&params.Domain, 2, shading_dict);
+ if (code < 0) {
+ if (code == gs_error_undefined) {
+ for (i = 0; i < 2; i++) {
+ params.Domain[i] = default_Domain[i];
+ }
+ } else
+ return code;
+ }
+
+ code = fill_bool_array_from_dict(ctx, (bool *)&params.Extend, 2, shading_dict, "Extend");
+ if (code < 0) {
+ if (code == gs_error_undefined) {
+ params.Extend[0] = params.Extend[1] = false;
+ } else
+ return code;
+ }
+
+ code = pdfi_build_shading_function(ctx, &params.Function, (const float *)&params.Domain, 1, (pdf_dict *)shading_dict, page_dict);
+ if (code < 0){
+ pdfi_countdown(o);
+ return code;
+ }
+ code = gs_shading_A_init(ppsh, &params, ctx->memory);
+ if (code < 0){
+ pdfi_countdown(o);
+ return code;
+ }
+
+ return 0;
+}
+
+static int pdfi_shading3(pdf_context *ctx, gs_shading_params_t *pcommon,
+ gs_shading_t **ppsh,
+ pdf_obj *Shading, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ pdf_obj *o = NULL;
+ gs_shading_R_params_t params;
+ static const float default_Domain[2] = {0, 1};
+ int code, i;
+ pdf_dict *shading_dict;
+
+ if (Shading->type != PDF_DICT)
+ return_error(gs_error_typecheck);
+ shading_dict = (pdf_dict *)Shading;
+
+ memset(&params, 0, sizeof(params));
+ *(gs_shading_params_t *)&params = *pcommon;
+
+ code = fill_float_array_from_dict(ctx, (float *)&params.Coords, 6, shading_dict, "Coords");
+ if (code < 0)
+ return code;
+ code = fill_domain_from_dict(ctx, (float *)&params.Domain, 4, shading_dict);
+ if (code < 0) {
+ if (code == gs_error_undefined) {
+ for (i = 0; i < 2; i++) {
+ params.Domain[i] = default_Domain[i];
+ }
+ } else
+ return code;
+ }
+
+ code = fill_bool_array_from_dict(ctx, (bool *)&params.Extend, 2, shading_dict, "Extend");
+ if (code < 0) {
+ if (code == gs_error_undefined) {
+ params.Extend[0] = params.Extend[1] = false;
+ } else
+ return code;
+ }
+
+ code = pdfi_build_shading_function(ctx, &params.Function, (const float *)&params.Domain, 1, (pdf_dict *)shading_dict, page_dict);
+ if (code < 0){
+ pdfi_countdown(o);
+ return code;
+ }
+ code = gs_shading_R_init(ppsh, &params, ctx->memory);
+ if (code < 0){
+ pdfi_countdown(o);
+ return code;
+ }
+
+ return 0;
+}
+
+static int pdfi_build_mesh_shading(pdf_context *ctx, gs_shading_mesh_params_t *params,
+ pdf_obj *Shading, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int num_decode = 4, code;
+ gs_offset_t savedoffset;
+ gs_offset_t stream_offset;
+ int64_t Length;
+ byte *data_source_buffer = NULL;
+ pdf_c_stream *shading_stream = NULL;
+ int64_t i;
+ pdf_dict *shading_dict;
+
+ if (Shading->type != PDF_STREAM)
+ return_error(gs_error_typecheck);
+
+ code = pdfi_dict_from_obj(ctx, Shading, &shading_dict);
+ if (code < 0)
+ return code;
+
+ params->Function = NULL;
+ params->Decode = NULL;
+
+ stream_offset = pdfi_stream_offset(ctx, (pdf_stream *)Shading);
+ if (stream_offset == 0)
+ return_error(gs_error_typecheck);
+
+ Length = pdfi_stream_length(ctx, (pdf_stream *)Shading);
+
+ savedoffset = pdfi_tell(ctx->main_stream);
+ code = pdfi_seek(ctx, ctx->main_stream, stream_offset, SEEK_SET);
+ if (code < 0)
+ return code;
+
+ code = pdfi_open_memory_stream_from_filtered_stream(ctx, (pdf_stream *)Shading, Length, &data_source_buffer, ctx->main_stream, &shading_stream, false);
+ if (code < 0) {
+ pdfi_seek(ctx, ctx->main_stream, savedoffset, SEEK_SET);
+ return code;
+ }
+
+ data_source_init_stream(&params->DataSource, shading_stream->s);
+
+ /* We need to clear up the PDF stream, but leave the underlying stream alone, that's now
+ * pointed to by the params.DataSource member.
+ */
+ gs_free_object(ctx->memory, shading_stream, "discard memory stream(pdf_stream)");
+
+ code = pdfi_seek(ctx, ctx->main_stream, savedoffset, SEEK_SET);
+ if (code < 0)
+ goto build_mesh_shading_error;
+
+ code = pdfi_build_shading_function(ctx, &params->Function, (const float *)NULL, 1,
+ shading_dict, page_dict);
+ if (code < 0 && code != gs_error_undefined)
+ goto build_mesh_shading_error;
+
+ code = pdfi_dict_get_int(ctx, shading_dict, "BitsPerCoordinate", &i);
+ if (code < 0)
+ goto build_mesh_shading_error;
+
+ if (i != 1 && i != 2 && i != 4 && i != 8 && i != 12 && i != 16 && i != 24 && i != 32) {
+ code = gs_error_rangecheck;
+ goto build_mesh_shading_error;
+ }
+
+ params->BitsPerCoordinate = i;
+
+ code = pdfi_dict_get_int(ctx, shading_dict, "BitsPerComponent", &i);
+ if (code < 0)
+ goto build_mesh_shading_error;
+
+ if (i != 1 && i != 2 && i != 4 && i != 8 && i != 12 && i != 16) {
+ code = gs_error_rangecheck;
+ goto build_mesh_shading_error;
+ }
+
+ params->BitsPerComponent = i;
+
+ if (params->Function != NULL)
+ num_decode += 2;
+ else
+ num_decode += gs_color_space_num_components(params->ColorSpace) * 2;
+
+ params->Decode = (float *) gs_alloc_byte_array(ctx->memory, num_decode, sizeof(float),
+ "build_mesh_shading");
+ if (params->Decode == NULL) {
+ code = gs_error_VMerror;
+ goto build_mesh_shading_error;
+ }
+
+ code = fill_float_array_from_dict(ctx, (float *)params->Decode, num_decode, shading_dict, "Decode");
+ if (code < 0)
+ goto build_mesh_shading_error;
+
+ return 0;
+
+build_mesh_shading_error:
+ if (params->Function)
+ pdfi_free_function(ctx, params->Function);
+ if (params->DataSource.data.strm != NULL) {
+ s_close_filters(&params->DataSource.data.strm, params->DataSource.data.strm->strm);
+ gs_free_object(ctx->memory, params->DataSource.data.strm, "release mesh shading Data Source");
+ }
+ gs_free_object(ctx->memory, params->Decode, "Decode");
+ return code;
+}
+
+static int pdfi_shading4(pdf_context *ctx, gs_shading_params_t *pcommon,
+ gs_shading_t **ppsh,
+ pdf_obj *Shading, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ gs_shading_FfGt_params_t params;
+ int code;
+ int64_t i;
+ pdf_dict *shading_dict;
+
+ memset(&params, 0, sizeof(params));
+ *(gs_shading_params_t *)&params = *pcommon;
+
+ code = pdfi_build_mesh_shading(ctx, (gs_shading_mesh_params_t *)&params, Shading, stream_dict, page_dict);
+ if (code < 0)
+ return code;
+
+ /* pdfi_build_mesh_shading checks the type of the Shading object, so we don't need to here */
+ code = pdfi_dict_from_obj(ctx, Shading, &shading_dict);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_get_int(ctx, shading_dict, "BitsPerFlag", &i);
+ if (code < 0)
+ return code;
+
+ if (i != 2 && i != 4 && i != 8)
+ return_error(gs_error_rangecheck);
+
+ params.BitsPerFlag = i;
+
+ code = gs_shading_FfGt_init(ppsh, &params, ctx->memory);
+ if (code < 0) {
+ gs_free_object(ctx->memory, params.Function, "Function");
+ gs_free_object(ctx->memory, params.Decode, "Decode");
+ return code;
+ }
+ return 0;
+}
+
+static int pdfi_shading5(pdf_context *ctx, gs_shading_params_t *pcommon,
+ gs_shading_t **ppsh,
+ pdf_obj *Shading, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ gs_shading_LfGt_params_t params;
+ int code;
+ int64_t i;
+ pdf_dict *shading_dict;
+
+ memset(&params, 0, sizeof(params));
+ *(gs_shading_params_t *)&params = *pcommon;
+
+ code = pdfi_build_mesh_shading(ctx, (gs_shading_mesh_params_t *)&params, Shading, stream_dict, page_dict);
+ if (code < 0)
+ return code;
+
+ /* pdfi_build_mesh_shading checks the type of the Shading object, so we don't need to here */
+ code = pdfi_dict_from_obj(ctx, Shading, &shading_dict);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_get_int(ctx, shading_dict, "VerticesPerRow", &i);
+ if (code < 0)
+ return code;
+
+ if (i < 2)
+ return_error(gs_error_rangecheck);
+
+ params.VerticesPerRow = i;
+
+ code = gs_shading_LfGt_init(ppsh, &params, ctx->memory);
+ if (code < 0) {
+ gs_free_object(ctx->memory, params.Function, "Function");
+ gs_free_object(ctx->memory, params.Decode, "Decode");
+ return code;
+ }
+ return 0;
+}
+
+static int pdfi_shading6(pdf_context *ctx, gs_shading_params_t *pcommon,
+ gs_shading_t **ppsh,
+ pdf_obj *Shading, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ gs_shading_Cp_params_t params;
+ int code;
+ int64_t i;
+ pdf_dict *shading_dict;
+
+ memset(&params, 0, sizeof(params));
+ *(gs_shading_params_t *)&params = *pcommon;
+
+ code = pdfi_build_mesh_shading(ctx, (gs_shading_mesh_params_t *)&params, Shading, stream_dict, page_dict);
+ if (code < 0)
+ return code;
+
+ /* pdfi_build_mesh_shading checks the type of the Shading object, so we don't need to here */
+ code = pdfi_dict_from_obj(ctx, Shading, &shading_dict);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_get_int(ctx, shading_dict, "BitsPerFlag", &i);
+ if (code < 0)
+ return code;
+
+ if (i != 2 && i != 4 && i != 8)
+ return_error(gs_error_rangecheck);
+
+ params.BitsPerFlag = i;
+
+ code = gs_shading_Cp_init(ppsh, &params, ctx->memory);
+ if (code < 0) {
+ gs_free_object(ctx->memory, params.Function, "Function");
+ gs_free_object(ctx->memory, params.Decode, "Decode");
+ return code;
+ }
+ return 0;
+}
+
+static int pdfi_shading7(pdf_context *ctx, gs_shading_params_t *pcommon,
+ gs_shading_t **ppsh,
+ pdf_obj *Shading, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ gs_shading_Tpp_params_t params;
+ int code;
+ int64_t i;
+ pdf_dict *shading_dict;
+
+ memset(&params, 0, sizeof(params));
+ *(gs_shading_params_t *)&params = *pcommon;
+
+ code = pdfi_build_mesh_shading(ctx, (gs_shading_mesh_params_t *)&params, Shading, stream_dict, page_dict);
+ if (code < 0)
+ return code;
+
+ /* pdfi_build_mesh_shading checks the type of the Shading object, so we don't need to here */
+ code = pdfi_dict_from_obj(ctx, Shading, &shading_dict);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_get_int(ctx, shading_dict, "BitsPerFlag", &i);
+ if (code < 0)
+ return code;
+
+ if (i != 2 && i != 4 && i != 8)
+ return_error(gs_error_rangecheck);
+
+ params.BitsPerFlag = i;
+
+ code = gs_shading_Tpp_init(ppsh, &params, ctx->memory);
+ if (code < 0) {
+ gs_free_object(ctx->memory, params.Function, "Function");
+ gs_free_object(ctx->memory, params.Decode, "Decode");
+ return code;
+ }
+ return 0;
+}
+
+static int get_shading_common(pdf_context *ctx, pdf_dict *shading_dict, gs_shading_params_t *params)
+{
+ gs_color_space *pcs = gs_currentcolorspace(ctx->pgs);
+ int code, num_comp = gs_color_space_num_components(pcs);
+ pdf_array *a = NULL;
+ double *temp;
+
+ if (num_comp < 0) /* Pattern color space */
+ return_error(gs_error_typecheck);
+
+ params->ColorSpace = pcs;
+ params->Background = NULL;
+ rc_increment_cs(pcs);
+
+ code = pdfi_dict_get_type(ctx, shading_dict, "Background", PDF_ARRAY, (pdf_obj **)&a);
+ if (code < 0 && code != gs_error_undefined)
+ return code;
+
+ if (code >= 0) {
+ uint64_t i;
+ gs_client_color *pcc = NULL;
+
+ if (pdfi_array_size(a) < num_comp) {
+ code = gs_error_rangecheck;
+ goto get_shading_common_error;
+ }
+
+ pcc = gs_alloc_struct(ctx->memory, gs_client_color, &st_client_color, "get_shading_common");
+ if (pcc == 0) {
+ code = gs_error_VMerror;
+ goto get_shading_common_error;
+ }
+
+ pcc->pattern = 0;
+ params->Background = pcc;
+
+ temp = (double *)gs_alloc_bytes(ctx->memory, num_comp * sizeof(double), "temporary array of doubles");
+ for(i=0;i<num_comp;i++) {
+ code = pdfi_array_get_number(ctx, a, i, &temp[i]);
+ if (code < 0) {
+ gs_free_object(ctx->memory, temp, "free workign array (error)");
+ goto get_shading_common_error;
+ }
+ pcc->paint.values[i] = temp[i];
+ }
+ pdfi_countdown((pdf_obj *)a);
+ a = NULL;
+ gs_free_object(ctx->memory, temp, "free workign array (done)");
+ }
+
+
+ code = pdfi_dict_get_type(ctx, shading_dict, "BBox", PDF_ARRAY, (pdf_obj **)&a);
+ if (code < 0 && code != gs_error_undefined)
+ goto get_shading_common_error;
+
+ if (code >= 0) {
+ double box[4];
+ uint64_t i;
+
+ if (pdfi_array_size(a) < 4) {
+ code = gs_error_rangecheck;
+ goto get_shading_common_error;
+ }
+
+ for(i=0;i<4;i++) {
+ code = pdfi_array_get_number(ctx, a, i, &box[i]);
+ if (code < 0)
+ goto get_shading_common_error;
+ }
+ /* Adobe Interpreters accept denormalised BBox - bug 688937 */
+ if (box[0] <= box[2]) {
+ params->BBox.p.x = box[0];
+ params->BBox.q.x = box[2];
+ } else {
+ params->BBox.p.x = box[2];
+ params->BBox.q.x = box[0];
+ }
+ if (box[1] <= box[3]) {
+ params->BBox.p.y = box[1];
+ params->BBox.q.y = box[3];
+ } else {
+ params->BBox.p.y = box[3];
+ params->BBox.q.y = box[1];
+ }
+ params->have_BBox = true;
+ } else {
+ params->have_BBox = false;
+ }
+ pdfi_countdown(a);
+ a = NULL;
+
+ code = pdfi_dict_get_bool(ctx, shading_dict, "AntiAlias", &params->AntiAlias);
+ if (code < 0 && code != gs_error_undefined)
+ goto get_shading_common_error;
+
+ return 0;
+get_shading_common_error:
+ pdfi_countdown((pdf_obj *)a);
+ gs_free_object(ctx->memory, params->Background, "Background (common_shading_error)");
+ return code;
+}
+
+/* Build gs_shading_t object from a Shading Dict */
+int
+pdfi_shading_build(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict,
+ pdf_obj *Shading, gs_shading_t **ppsh)
+{
+ gs_shading_params_t params;
+ gs_shading_t *psh = NULL;
+ pdf_obj *cspace = NULL;
+ int64_t type = 0;
+ int code = 0;
+ pdf_dict *sdict = NULL;
+
+ memset(&params, 0, sizeof(params));
+
+ params.ColorSpace = 0;
+ params.cie_joint_caches = 0;
+ params.Background = 0;
+ params.have_BBox = 0;
+ params.AntiAlias = 0;
+
+ code = pdfi_dict_from_obj(ctx, Shading, &sdict);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_get(ctx, sdict, "ColorSpace", &cspace);
+ if (code < 0)
+ goto shading_error;
+
+ code = pdfi_setcolorspace(ctx, cspace, stream_dict, page_dict);
+ if (code < 0)
+ goto shading_error;
+
+ code = get_shading_common(ctx, sdict, &params);
+ if (code < 0)
+ goto shading_error;
+
+ code = pdfi_dict_get_int(ctx, sdict, "ShadingType", &type);
+ if (code < 0)
+ goto shading_error;
+
+ switch(type){
+ case 1:
+ code = pdfi_shading1(ctx, &params, &psh, Shading, stream_dict, page_dict);
+ break;
+ case 2:
+ code = pdfi_shading2(ctx, &params, &psh, Shading, stream_dict, page_dict);
+ break;
+ case 3:
+ code = pdfi_shading3(ctx, &params, &psh, Shading, stream_dict, page_dict);
+ break;
+ case 4:
+ code = pdfi_shading4(ctx, &params, &psh, Shading, stream_dict, page_dict);
+ break;
+ case 5:
+ code = pdfi_shading5(ctx, &params, &psh, Shading, stream_dict, page_dict);
+ break;
+ case 6:
+ code = pdfi_shading6(ctx, &params, &psh, Shading, stream_dict, page_dict);
+ break;
+ case 7:
+ code = pdfi_shading7(ctx, &params, &psh, Shading, stream_dict, page_dict);
+ break;
+ default:
+ code = gs_note_error(gs_error_rangecheck);
+ break;
+ }
+ if (code < 0)
+ goto shading_error;
+
+ pdfi_countdown(cspace);
+ if (code >= 0)
+ *ppsh = psh;
+ return code;
+
+ shading_error:
+ if (cspace != NULL)
+ pdfi_countdown(cspace);
+ if (params.ColorSpace != NULL) {
+ rc_decrement_only(params.ColorSpace, "ColorSpace (shading_build_error)");
+ params.ColorSpace = NULL;
+ }
+ if (params.Background != NULL) {
+ gs_free_object(ctx->memory, params.Background, "Background (shading_build_error)");
+ params.Background = NULL;
+ }
+ return code;
+}
+
+/* Free stuff associated with a gs_shading_t.
+ */
+void
+pdfi_shading_free(pdf_context *ctx, gs_shading_t *psh)
+{
+ gs_shading_params_t *params = &psh->params;
+
+ rc_decrement_cs(params->ColorSpace, "pdfi_shading_free(ColorSpace)");
+ params->ColorSpace = NULL;
+
+ if (params->Background != NULL) {
+ gs_free_object(ctx->memory, params->Background, "pdfi_shading_free(Background)");
+ params->Background = NULL;
+ }
+
+ if (psh->head.type > 3) {
+ gs_shading_mesh_params_t *mesh_params = (gs_shading_mesh_params_t *)params;
+
+ if (mesh_params->Decode != NULL)
+ gs_free_object(ctx->memory, mesh_params->Decode, "release mesh shading Decode array");
+ if (mesh_params->DataSource.data.strm != NULL) {
+ s_close_filters(&mesh_params->DataSource.data.strm, mesh_params->DataSource.data.strm->strm);
+ gs_free_object(ctx->memory, mesh_params->DataSource.data.strm, "release mesh shading Data Source");
+ }
+ }
+
+ switch(psh->head.type) {
+ case 1:
+ if (((gs_shading_Fb_params_t *)&psh->params)->Function != NULL)
+ pdfi_free_function(ctx, ((gs_shading_Fb_params_t *)&psh->params)->Function);
+ break;
+ case 2:
+ if (((gs_shading_A_params_t *)&psh->params)->Function != NULL)
+ pdfi_free_function(ctx, ((gs_shading_A_params_t *)&psh->params)->Function);
+ break;
+ case 3:
+ if (((gs_shading_R_params_t *)&psh->params)->Function != NULL)
+ pdfi_free_function(ctx, ((gs_shading_R_params_t *)&psh->params)->Function);
+ break;
+ case 4:
+ if (((gs_shading_FfGt_params_t *)&psh->params)->Function != NULL)
+ pdfi_free_function(ctx, ((gs_shading_FfGt_params_t *)&psh->params)->Function);
+ break;
+ case 5:
+ if (((gs_shading_LfGt_params_t *)&psh->params)->Function != NULL)
+ pdfi_free_function(ctx, ((gs_shading_LfGt_params_t *)&psh->params)->Function);
+ break;
+ case 6:
+ if (((gs_shading_Cp_params_t *)&psh->params)->Function != NULL)
+ pdfi_free_function(ctx, ((gs_shading_Cp_params_t *)&psh->params)->Function);
+ break;
+ case 7:
+ if (((gs_shading_Tpp_params_t *)&psh->params)->Function != NULL)
+ pdfi_free_function(ctx, ((gs_shading_Tpp_params_t *)&psh->params)->Function);
+ break;
+ default:
+ break;
+ }
+ gs_free_object(ctx->memory, psh, "Free shading, finished");
+}
+
+/* Setup for transparency (see pdf_draw.ps/sh) */
+static int
+pdfi_shading_setup_trans(pdf_context *ctx, pdfi_trans_state_t *state, pdf_obj *Shading)
+{
+ int code;
+ gs_rect bbox, *box = NULL;
+ pdf_array *BBox = NULL;
+ pdf_dict *shading_dict;
+
+ code = pdfi_dict_from_obj(ctx, Shading, &shading_dict);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_knownget_type(ctx, shading_dict, "BBox", PDF_ARRAY, (pdf_obj **)&BBox);
+ if (code < 0)
+ goto exit;
+
+ if (code > 0) {
+ code = pdfi_array_to_gs_rect(ctx, BBox, &bbox);
+ if (code >= 0)
+ box = &bbox;
+ }
+
+ /* If we didn't get a BBox for the shading, then we need to create one, in order to
+ * pass it to the transparency setup, which (potentially, at least, uses it to set
+ * up a transparency group.
+ * In the basence of anything better, we take the currnet clip, turn that into a path
+ * and then get the bounding box of that path. Obviously we don't want to disturb the
+ * current path in the graphics state, so we do a gsave/grestore round it.
+ */
+ if (box == NULL) {
+ code = pdfi_gsave(ctx);
+ if (code < 0)
+ goto exit;
+
+ code = gs_newpath(ctx->pgs);
+ if (code < 0)
+ goto bbox_error;
+
+ code = gs_clippath(ctx->pgs);
+ if (code < 0)
+ goto bbox_error;
+
+ code = pdfi_get_current_bbox(ctx, &bbox, false);
+
+bbox_error:
+ pdfi_grestore(ctx);
+
+ if (code < 0)
+ goto exit;
+
+ box = &bbox;
+ }
+ code = pdfi_trans_setup(ctx, state, box, TRANSPARENCY_Caller_Other);
+
+ exit:
+ pdfi_countdown(BBox);
+ return code;
+}
+
+int pdfi_shading(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict)
+{
+ int code, code1;
+ pdf_name *n = NULL;
+ pdf_obj *Shading = NULL;
+ gs_shading_t *psh = NULL;
+ gs_offset_t savedoffset;
+ pdfi_trans_state_t trans_state;
+
+ if (pdfi_count_stack(ctx) < 1)
+ return_error(gs_error_stackunderflow);
+
+ if (ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_OPINVALIDINTEXT, "pdfi_shading", NULL);
+
+ if (pdfi_oc_is_off(ctx))
+ return 0;
+
+ n = (pdf_name *)ctx->stack_top[-1];
+ if (n->type != PDF_NAME)
+ return_error(gs_error_typecheck);
+
+ savedoffset = pdfi_tell(ctx->main_stream);
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ return code;
+
+ code = pdfi_op_q(ctx);
+ if (code < 0)
+ goto exit1;
+
+ code = pdfi_find_resource(ctx, (unsigned char *)"Shading", n, (pdf_dict *)stream_dict, page_dict,
+ &Shading);
+ if (code < 0)
+ goto exit2;
+
+ if (Shading->type != PDF_DICT && Shading->type != PDF_STREAM) {
+ code = gs_note_error(gs_error_typecheck);
+ goto exit2;
+ }
+
+ code = pdfi_trans_set_params(ctx);
+ if (code < 0)
+ goto exit2;
+
+ code = pdfi_shading_build(ctx, stream_dict, page_dict, Shading, &psh);
+ if (code < 0)
+ goto exit2;
+
+ if (ctx->page.has_transparency) {
+ code = pdfi_shading_setup_trans(ctx, &trans_state, Shading);
+ if (code < 0)
+ goto exit2;
+ }
+
+ code = gs_shfill(ctx->pgs, psh);
+ if (code < 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BADSHADING, "pdfi_rectpath", (char *)"ERROR: ignoring invalid smooth shading object, output may be incorrect");
+ code = 0;
+ }
+
+ if (ctx->page.has_transparency) {
+ code1 = pdfi_trans_teardown(ctx, &trans_state);
+ if (code == 0)
+ code = code1;
+ }
+
+ exit2:
+ if (psh)
+ pdfi_shading_free(ctx, psh);
+
+ pdfi_countdown(Shading);
+ code1 = pdfi_op_Q(ctx);
+ if (code == 0)
+ code = code1;
+ exit1:
+ pdfi_pop(ctx, 1);
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ pdfi_seek(ctx, ctx->main_stream, savedoffset, SEEK_SET);
+ return code;
+}
diff --git a/pdf/pdf_shading.h b/pdf/pdf_shading.h
new file mode 100644
index 00000000..c55d9296
--- /dev/null
+++ b/pdf/pdf_shading.h
@@ -0,0 +1,28 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Shading operations for the PDF interpreter */
+
+#ifndef PDF_SHADING_OPERATORS
+#define PDF_SHADING_OPERATORS
+
+#include "gsshade.h" /* for gs_shading_t */
+
+int pdfi_shading_build(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict,
+ pdf_obj *Shading, gs_shading_t **ppsh);
+void pdfi_shading_free(pdf_context *ctx, gs_shading_t *psh);
+int pdfi_shading(pdf_context *ctx, pdf_dict *stream_dict, pdf_dict *page_dict);
+
+#endif
diff --git a/pdf/pdf_stack.c b/pdf/pdf_stack.c
new file mode 100644
index 00000000..d2644fbb
--- /dev/null
+++ b/pdf/pdf_stack.c
@@ -0,0 +1,126 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Stack operations for the PDF interpreter */
+
+#include "ghostpdf.h"
+#include "pdf_types.h"
+#include "pdf_int.h"
+#include "pdf_stack.h"
+
+int pdfi_pop(pdf_context *ctx, int num)
+{
+ int code = 0;
+ if (num < 0)
+ return_error(gs_error_rangecheck);
+
+ if (pdfi_count_stack(ctx) < num) {
+ code = gs_note_error(gs_error_stackunderflow);
+ num = pdfi_count_stack(ctx);
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_STACKUNDERFLOW, "pdfi_pop", NULL);
+ }
+ while(num) {
+ pdfi_countdown(ctx->stack_top[-1]);
+ ctx->stack_top--;
+ num--;
+ }
+ return code;
+}
+
+int pdfi_push(pdf_context *ctx, pdf_obj *o)
+{
+ pdf_obj **new_stack;
+ uint32_t entries = 0;
+
+ if (ctx->stack_top < ctx->stack_bot)
+ ctx->stack_top = ctx->stack_bot;
+
+ if (ctx->stack_top >= ctx->stack_limit) {
+ if (ctx->stack_size >= MAX_STACK_SIZE)
+ return_error(gs_error_stackoverflow);
+
+ new_stack = (pdf_obj **)gs_alloc_bytes(ctx->memory, (ctx->stack_size + INITIAL_STACK_SIZE) * sizeof (pdf_obj *), "pdfi_push_increase_interp_stack");
+ if (new_stack == NULL)
+ return_error(gs_error_VMerror);
+
+ memcpy(new_stack, ctx->stack_bot, ctx->stack_size * sizeof(pdf_obj *));
+ gs_free_object(ctx->memory, ctx->stack_bot, "pdfi_push_increase_interp_stack");
+
+ entries = pdfi_count_total_stack(ctx);
+
+ ctx->stack_bot = new_stack;
+ ctx->stack_top = ctx->stack_bot + entries;
+ ctx->stack_size += INITIAL_STACK_SIZE;
+ ctx->stack_limit = ctx->stack_bot + ctx->stack_size;
+ }
+
+ *ctx->stack_top = o;
+ ctx->stack_top++;
+ pdfi_countup(o);
+
+ return 0;
+}
+
+int pdfi_mark_stack(pdf_context *ctx, pdf_obj_type type)
+{
+ pdf_obj *o;
+ int code;
+
+ if (type != PDF_ARRAY_MARK && type != PDF_DICT_MARK && type != PDF_PROC_MARK)
+ return_error(gs_error_typecheck);
+
+ code = pdfi_object_alloc(ctx, type, 0, &o);
+ if (code < 0)
+ return code;
+
+ code = pdfi_push(ctx, o);
+ if (code < 0)
+ pdfi_free_object(o);
+ return code;
+}
+
+void pdfi_clearstack(pdf_context *ctx)
+{
+ pdfi_pop(ctx, pdfi_count_stack(ctx));
+}
+
+int pdfi_count_to_mark(pdf_context *ctx, uint64_t *count)
+{
+ pdf_obj *o = ctx->stack_top[- 1];
+ int index = -1;
+ pdf_obj **save_bot = NULL;
+
+ save_bot = ctx->stack_bot + ctx->current_stream_save.stack_count;
+
+ *count = 0;
+ while (&ctx->stack_top[index] >= save_bot) {
+ if (o->type == PDF_ARRAY_MARK || o->type == PDF_DICT_MARK)
+ return 0;
+ o = ctx->stack_top[--index];
+ (*count)++;
+ }
+ return_error(gs_error_unmatchedmark);
+}
+
+int pdfi_clear_to_mark(pdf_context *ctx)
+{
+ int code;
+ uint64_t count;
+
+ code = pdfi_count_to_mark(ctx, &count);
+ if (code < 0)
+ return code;
+ return pdfi_pop(ctx, count + 1);
+}
diff --git a/pdf/pdf_stack.h b/pdf/pdf_stack.h
new file mode 100644
index 00000000..982cfab1
--- /dev/null
+++ b/pdf/pdf_stack.h
@@ -0,0 +1,125 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Stack operations for the PDF interpreter */
+
+#ifndef PDF_STACK_OPERATIONS
+#define PDF_STACK_OPERATIONS
+
+#include "pdf_int.h"
+#include "pdf_types.h"
+#include "ghostpdf.h"
+#include "pdf_obj.h"
+
+int pdfi_pop(pdf_context *ctx, int num);
+int pdfi_push(pdf_context *ctx, pdf_obj *o);
+int pdfi_mark_stack(pdf_context *ctx, pdf_obj_type type);
+void pdfi_clearstack(pdf_context *ctx);
+int pdfi_count_to_mark(pdf_context *ctx, uint64_t *count);
+int pdfi_clear_to_mark(pdf_context *ctx);
+
+static inline void pdfi_countup_impl(pdf_obj *o)
+{
+ if (o != NULL) {
+ o->refcnt++;
+#if REFCNT_DEBUG
+ dmprintf3(OBJ_MEMORY(o), "Incrementing reference count of object %d, UID %lu, to %d\n", o->object_num, o->UID, o->refcnt);
+#endif
+ }
+#if REFCNT_DEBUG
+ else {
+ dprintf("Incrementing reference count of NULL pointer\n");
+ }
+#endif
+}
+
+static inline void pdfi_countdown_impl(pdf_obj *o)
+{
+ if (o != NULL) {
+#ifdef DEBUG
+ pdf_context *ctx1 = (pdf_context *)o->ctx;
+ if (o->refcnt == 0)
+ emprintf(OBJ_MEMORY(o), "Decrementing object with refcount at 0!\n");
+#endif
+ o->refcnt--;
+#if REFCNT_DEBUG
+ dmprintf3(OBJ_MEMORY(o), "Decrementing reference count of object %d, UID %lu, to %d\n", o->object_num, o->UID, o->refcnt);
+#endif
+ if (o->refcnt == 0) {
+#if REFCNT_DEBUG
+ pdf_context *ctx = (pdf_context *)o->ctx;
+ if (ctx != NULL && ctx->cache_entries != 0) {
+ pdf_obj_cache_entry *entry = ctx->cache_LRU, *next;
+
+ while(entry) {
+ next = entry->next;
+ if (entry->o->object_num != 0 && entry->o->object_num == o->object_num)
+ dmprintf2(OBJ_MEMORY(o), "Freeing object %d, UID %lu, but there is still a cache entry!\n", o->object_num, o->UID);
+ entry = next;
+ }
+ }
+ dmprintf2(OBJ_MEMORY(o), "Freeing object %d, UID %lu\n", o->object_num, o->UID);
+#endif
+#ifdef DEBUG
+ if (ctx1->xref_table != NULL && o->object_num > 0 &&
+ o->object_num < ctx1->xref_table->xref_size &&
+ ctx1->xref_table->xref[o->object_num].cache != NULL &&
+ ctx1->xref_table->xref[o->object_num].cache->o == o) {
+ dmprintf1(OBJ_MEMORY(o), "Freeing object %d while it is still in the object cache!\n", o->object_num);
+ }
+#endif
+ pdfi_free_object(o);
+ }
+ }
+}
+
+/* These two macros are present simply to add a cast to the generic object type, so that
+ * we don't get warnings in the implementation routines, the alternative would be to use
+ * a cast everywhere we use the inline functions above, or to have them take a void *
+ *
+ * Ordinarily we would capitalise the name of a macro to differentiate it from a function
+ * we make an exception in this case because hte macro descends to an inline function which
+ * can be debugged without expanding macros.
+ */
+#define pdfi_countup(x) pdfi_countup_impl((pdf_obj *)x)
+
+#define pdfi_countdown(x) pdfi_countdown_impl((pdf_obj *)x)
+
+/* Why two functions ? The difference is that when interpreting 'sub' streams
+ * such as the content stream for a Form XObject, we may have entries on the
+ * stack at the start of the stream interpretation, and we don't want to
+ * pop any of those off during the course of the stream. The stack depth stored in
+ * the context is used to prevent this in pdfi_pop().
+ * This means that, during the course of a stream, the stack top - bottom may
+ * not be an accurate reflection of the number of available items on the stack.
+ *
+ * So pdfi_count_stack() returns the number of available items, and
+ * pdfi_count_stack_total() returns the entire size of the stack, and is used to
+ * record the saved stack depth when we start a stream.
+ *
+ * Although these are currently simple calculations, they are abstracted in order
+ * to facilitate later replacement if required.
+ */
+static inline int pdfi_count_total_stack(pdf_context *ctx)
+{
+ return (ctx->stack_top - ctx->stack_bot);
+}
+
+static inline int pdfi_count_stack(pdf_context *ctx)
+{
+ return (pdfi_count_total_stack(ctx)) - ctx->current_stream_save.stack_count;
+}
+
+#endif
diff --git a/pdf/pdf_text.c b/pdf/pdf_text.c
new file mode 100644
index 00000000..4bc6d907
--- /dev/null
+++ b/pdf/pdf_text.c
@@ -0,0 +1,1618 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Text operations for the PDF interpreter */
+
+#include "pdf_int.h"
+#include "pdf_array.h"
+#include "pdf_text.h"
+#include "pdf_image.h"
+#include "pdf_colour.h"
+#include "pdf_stack.h"
+#include "pdf_gstate.h"
+#include "pdf_font.h"
+#include "pdf_font_types.h"
+#include "pdf_trans.h"
+#include "pdf_optcontent.h"
+
+#include "gsstate.h"
+#include "gsmatrix.h"
+#include "gdevbbox.h"
+#include "gspaint.h" /* For gs_fill() and friends */
+#include "gscoord.h" /* For gs_setmatrix() */
+
+static int pdfi_set_TL(pdf_context *ctx, double TL);
+
+int pdfi_BT(pdf_context *ctx)
+{
+ int code;
+ gs_matrix m;
+ bool illegal_BT = false;
+
+ if (ctx->text.BlockDepth != 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_NESTEDTEXTBLOCK, "pdfi_BT", NULL);
+ illegal_BT = true;
+ }
+
+ gs_make_identity(&m);
+ code = gs_settextmatrix(ctx->pgs, &m);
+ if (code < 0)
+ return code;
+
+ code = gs_settextlinematrix(ctx->pgs, &m);
+ if (code < 0)
+ return code;
+
+ /* In theory we should not perform the clip (for text rendering modes involving a clip)
+ * when preserving the text rendering mode. However the pdfwrite device requires us to do
+ * so. The reason is that it wraps all text operations in a sequence like 'q BT...ET Q'
+ * and the grestore obviously restores away the clip before any following operation can use it.
+ * The reason pdfwrite does this is historical; originally the PDF graphics state was not
+ * part of the graphics library graphics state, so the only information available to
+ * the device was the CTM, after the text rendering matrix and text line matrix had been
+ * applied. Obviously that had to be undone at the end of the text to avoid polluting
+ * the CTM for following operations.
+ * Now that we track the Trm and Tlm in the graphics state it would be possible to
+ * modify pdfwrite so that it emits those instead of modifying the CTM, which would avoid
+ * the q/Q pair round the text, which would mean we could do away with the separate
+ * clip for text rendering. However this would mean modifying both the pdfwrite device
+ * and the existing PDF interpreter, which would be awkward to do. I will open an
+ * enhancement bug for this, but won't begin work on it until we have completely
+ * deprecated and removed the old PDF interpreter.
+ * In the meantime we have to persist with this kludge.
+ */
+ if (gs_currenttextrenderingmode(ctx->pgs) >= 4 && ctx->text.BlockDepth == 0 /* && !ctx->device_state.preserve_tr_mode*/) {
+ /* Whenever we are doing a 'clip' text rendering mode we need to
+ * accumulate a path until we reach ET, and then we need to turn that
+ * path into a clip and apply it (along with any existing clip). But
+ * we must not disturb any existing path in the current graphics
+ * state, so we need an extra gsave which we will undo when we get
+ * an ET.
+ */
+ pdfi_gsave(ctx);
+ /* Capture the current position */
+ /* Start a new path (so our clip doesn't include any
+ * already extant path in the graphics state)
+ */
+ gs_newpath(ctx->pgs);
+ }
+
+ ctx->text.initial_current_point_valid = ctx->pgs->current_point_valid;
+ if (!ctx->pgs->current_point_valid)
+ code = gs_moveto(ctx->pgs, 0, 0);
+
+ ctx->text.BlockDepth++;
+
+ if (ctx->page.has_transparency && gs_currenttextknockout(ctx->pgs) && !illegal_BT)
+ gs_begin_transparency_text_group(ctx->pgs);
+
+ return code;
+}
+
+int pdfi_ET(pdf_context *ctx)
+{
+ int code = 0;
+ gx_clip_path *copy = NULL;
+
+ if (ctx->text.BlockDepth == 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_ETNOTEXTBLOCK, "pdfi_ET", NULL);
+ return_error(gs_error_syntaxerror);
+ }
+
+ ctx->text.BlockDepth--;
+ /* If we have reached the end of a text block (or the outermost block
+ * if we have illegally nested text blocks) and we are using a 'clip'
+ * text rendering mode, then we need to apply the clip. We also need
+ * to grestore back one level as we will have pushed a gsave either in
+ * pdfi_BT or in pdfi_Tr. The extra gsave is so we can accumulate a
+ * clipping path separately to any path already existing in the
+ * graphics state.
+ */
+
+ /* See the note on text rendering modes with clip in pdfi_BT() above */
+ if (ctx->text.BlockDepth == 0 && gs_currenttextrenderingmode(ctx->pgs) >= 4 /*&& !ctx->device_state.preserve_tr_mode*/) {
+ gs_point initial_point;
+
+ /* Capture the current position */
+ code = gs_currentpoint(ctx->pgs, &initial_point);
+ if (code >= 0) {
+ gs_point adjust;
+
+ gs_currentfilladjust(ctx->pgs, &adjust);
+ code = gs_setfilladjust(ctx->pgs, (double)0.0, (double)0.0);
+ if (code < 0)
+ return code;
+
+ code = gs_clip(ctx->pgs);
+ if (code >= 0)
+ copy = gx_cpath_alloc_shared(ctx->pgs->clip_path, ctx->memory, "save clip path");
+
+ code = gs_setfilladjust(ctx->pgs, adjust.x, adjust.y);
+ if (code < 0)
+ return code;
+
+ pdfi_grestore(ctx);
+ if (copy != NULL)
+ (void)gx_cpath_assign_free(ctx->pgs->clip_path, copy);
+ code = gs_moveto(ctx->pgs, initial_point.x, initial_point.y);
+ }
+ }
+ if (ctx->page.has_transparency && gs_currenttextknockout(ctx->pgs))
+ gs_end_transparency_text_group(ctx->pgs);
+
+ if (!ctx->text.initial_current_point_valid)
+ gs_newpath(ctx->pgs);
+ return code;
+}
+
+int pdfi_T_star(pdf_context *ctx)
+{
+ int code;
+ gs_matrix m, mat;
+
+ if (ctx->text.BlockDepth == 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_TEXTOPNOBT, "pdfi_T_star", NULL);
+ }
+
+ gs_make_identity(&m);
+ m.ty += ctx->pgs->textleading;
+
+ code = gs_matrix_multiply(&m, &ctx->pgs->textlinematrix, &mat);
+ if (code < 0)
+ return code;
+
+ code = gs_settextmatrix(ctx->pgs, (gs_matrix *)&mat);
+ if (code < 0)
+ return code;
+
+ code = gs_settextlinematrix(ctx->pgs, (gs_matrix *)&mat);
+ return code;
+}
+
+static int pdfi_set_Tc(pdf_context *ctx, double Tc)
+{
+ return gs_settextspacing(ctx->pgs, Tc);
+}
+
+int pdfi_Tc(pdf_context *ctx)
+{
+ int code = 0;
+ pdf_num *n = NULL;
+
+ if (pdfi_count_stack(ctx) < 1) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ n = (pdf_num *)ctx->stack_top[-1];
+
+ if (n->type == PDF_INT)
+ code = pdfi_set_Tc(ctx, (double)n->value.i);
+ else {
+ if (n->type == PDF_REAL)
+ code = pdfi_set_Tc(ctx, n->value.d);
+ else
+ code = gs_note_error(gs_error_typecheck);
+ }
+ pdfi_pop(ctx, 1);
+ return code;
+}
+
+int pdfi_Td(pdf_context *ctx)
+{
+ int code;
+ pdf_num *Tx = NULL, *Ty = NULL;
+ gs_matrix m, mat;
+
+ if (pdfi_count_stack(ctx) < 2) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ gs_make_identity(&m);
+
+ Ty = (pdf_num *)ctx->stack_top[-1];
+ Tx = (pdf_num *)ctx->stack_top[-2];
+
+ if (Tx->type == PDF_INT) {
+ m.tx = (float)Tx->value.i;
+ } else {
+ if (Tx->type == PDF_REAL) {
+ m.tx = (float)Tx->value.d;
+ } else {
+ code = gs_note_error(gs_error_typecheck);
+ goto Td_error;
+ }
+ }
+
+ if (Ty->type == PDF_INT) {
+ m.ty = (float)Ty->value.i;
+ } else {
+ if (Ty->type == PDF_REAL) {
+ m.ty = (float)Ty->value.d;
+ } else {
+ code = gs_note_error(gs_error_typecheck);
+ goto Td_error;
+ }
+ }
+
+ if (ctx->text.BlockDepth == 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_TEXTOPNOBT, "pdfi_Td", NULL);
+
+ gs_make_identity(&mat);
+ code = gs_settextmatrix(ctx->pgs, &mat);
+ if (code < 0)
+ goto Td_error;
+
+ code = gs_settextlinematrix(ctx->pgs, &mat);
+ if (code < 0)
+ goto Td_error;
+ }
+
+ code = gs_matrix_multiply(&m, &ctx->pgs->textlinematrix, &mat);
+ if (code < 0)
+ goto Td_error;
+
+ code = gs_settextmatrix(ctx->pgs, (gs_matrix *)&mat);
+ if (code < 0)
+ goto Td_error;
+
+ code = gs_settextlinematrix(ctx->pgs, (gs_matrix *)&mat);
+ if (code < 0)
+ goto Td_error;
+
+ pdfi_pop(ctx, 2);
+ return code;
+
+Td_error:
+ pdfi_pop(ctx, 2);
+ return code;
+}
+
+int pdfi_TD(pdf_context *ctx)
+{
+ int code;
+ pdf_num *Tx = NULL, *Ty = NULL;
+ gs_matrix m, mat;
+
+ if (pdfi_count_stack(ctx) < 2) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ gs_make_identity(&m);
+
+ Ty = (pdf_num *)ctx->stack_top[-1];
+ Tx = (pdf_num *)ctx->stack_top[-2];
+
+ if (Tx->type == PDF_INT) {
+ m.tx = (float)Tx->value.i;
+ } else {
+ if (Tx->type == PDF_REAL) {
+ m.tx = (float)Tx->value.d;
+ } else {
+ code = gs_note_error(gs_error_typecheck);
+ goto TD_error;
+ }
+ }
+
+ if (Ty->type == PDF_INT) {
+ m.ty = (float)Ty->value.i;
+ } else {
+ if (Ty->type == PDF_REAL) {
+ m.ty = (float)Ty->value.d;
+ } else {
+ code = gs_note_error(gs_error_typecheck);
+ goto TD_error;
+ }
+ }
+
+ if (ctx->text.BlockDepth == 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_TEXTOPNOBT, "pdfi_TD", NULL);
+
+ gs_make_identity(&mat);
+ code = gs_settextmatrix(ctx->pgs, &mat);
+ if (code < 0)
+ goto TD_error;
+
+ code = gs_settextlinematrix(ctx->pgs, &mat);
+ if (code < 0)
+ goto TD_error;
+ }
+
+ code = pdfi_set_TL(ctx, m.ty * 1.0f);
+ if (code < 0)
+ goto TD_error;
+
+ code = gs_matrix_multiply(&m, &ctx->pgs->textlinematrix, &mat);
+ if (code < 0)
+ goto TD_error;
+
+ code = gs_settextmatrix(ctx->pgs, (gs_matrix *)&mat);
+ if (code < 0)
+ goto TD_error;
+
+ code = gs_settextlinematrix(ctx->pgs, (gs_matrix *)&mat);
+ if (code < 0)
+ goto TD_error;
+
+ pdfi_pop(ctx, 2);
+ return code;
+
+TD_error:
+ pdfi_pop(ctx, 2);
+ return code;
+}
+
+/* This routine sets up most of the text params structure. In particular it
+ * creates and initialises the x and y widths arrays, and for type 3 fonts
+ * it creates and populates the 'chars' member.
+ * It also sets the delta_sace member and partially set sup the 'operation'
+ * bitfield. It does not set any of the TEXT_DO_* fields because we intend
+ * to use this routine to set up the 'common' parts of the structure and
+ * then we will twiddle the 'TEXT_DO_*' fields as required for the type of
+ * operation we are doing (fill, create path for stroke, create path for fill)
+ */
+static int pdfi_show_set_params(pdf_context *ctx, pdf_string *s, gs_text_params_t *text)
+{
+ pdf_font *current_font = NULL;
+ gs_matrix mat;
+ float *x_widths = NULL, *y_widths = NULL, width;
+ double Tw = 0, Tc = 0;
+ int i, code;
+
+ text->data.chars = NULL;
+ text->x_widths = NULL;
+ text->y_widths = NULL;
+
+ /* NOTE: we don't scale the FontMatrix we leave it as the default
+ * and do all our scaling with the textmatrix/ctm. This saves having
+ * to create multiple instances of the same font, and simplifies
+ * composite fonts significantly.
+ */
+ current_font = pdfi_get_current_pdf_font(ctx);
+
+ if (current_font == NULL)
+ return_error(gs_error_invalidfont);
+
+ /* Division by PDFfontsize because these are in unscaled font units,
+ and the font scale is now pickled into the text matrix, so we have to
+ undo that.
+ */
+ Tc = gs_currenttextspacing(ctx->pgs) / ctx->pgs->PDFfontsize;
+
+ if (current_font->pdfi_font_type == e_pdf_font_type1 ||
+ current_font->pdfi_font_type == e_pdf_font_cff ||
+ current_font->pdfi_font_type == e_pdf_font_type3 ||
+ current_font->pdfi_font_type == e_pdf_font_cff ||
+ current_font->pdfi_font_type == e_pdf_font_truetype ||
+ current_font->pdfi_font_type == e_pdf_font_type0)
+ {
+ /* For Type 0 fonts, we apply the DW/W/DW2/W2 values when we retrieve the metrics for
+ setcachedevice - see pdfi_fapi_set_cache()
+ */
+ if (current_font->pdfi_font_type == e_pdf_font_type0 || current_font->Widths == NULL) {
+ text->operation = TEXT_RETURN_WIDTH;
+ if (Tc != 0) {
+ text->operation |= TEXT_ADD_TO_ALL_WIDTHS;
+ if (current_font->pfont && current_font->pfont->WMode == 0) {
+ text->delta_all.x = Tc;
+ text->delta_all.y = 0;
+ } else {
+ text->delta_all.y = Tc;
+ text->delta_all.x = 0;
+ }
+ }
+ } else {
+ gs_point pt;
+
+ x_widths = (float *)gs_alloc_bytes(ctx->memory, s->length * sizeof(float), "X widths array for text");
+ y_widths = (float *)gs_alloc_bytes(ctx->memory, s->length * sizeof(float), "Y widths array for text");
+ if (x_widths == NULL || y_widths == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto text_params_error;
+ }
+
+ memset(x_widths, 0x00, s->length * sizeof(float));
+ memset(y_widths, 0x00, s->length * sizeof(float));
+
+ /* To calculate the Width (which is defined in unscaled text units) as a value in user
+ * space we need to transform it by the FontMatrix
+ */
+ mat = current_font->pfont->FontMatrix;
+
+ for (i = 0;i < s->length; i++) {
+ /* Get the width (in unscaled text units) */
+ if (s->data[i] < current_font->FirstChar || s->data[i] > current_font->LastChar)
+ width = 0;
+ else
+ width = current_font->Widths[s->data[i] - current_font->FirstChar];
+ /* And convert the width into an appropriate value for the current environment */
+ gs_distance_transform(width, 0, &mat, &pt);
+ x_widths[i] = hypot(pt.x, pt.y) * (width < 0 ? -1.0 : 1.0);
+ /* Add any Tc value */
+ x_widths[i] += Tc;
+ }
+ text->operation = TEXT_RETURN_WIDTH | TEXT_REPLACE_WIDTHS;
+ text->x_widths = x_widths;
+ text->y_widths = y_widths;
+ text->widths_size = s->length * 2;
+ }
+
+ Tw = gs_currentwordspacing(ctx->pgs);
+ if (Tw != 0) {
+ text->operation |= TEXT_ADD_TO_SPACE_WIDTH;
+ /* Division by PDFfontsize because these are in unscaled font units,
+ and the font scale is now pickled into the text matrix, so we have to
+ undo that.
+ */
+ if (current_font->pfont && current_font->pfont->WMode == 0) {
+ text->delta_space.x = Tw / ctx->pgs->PDFfontsize;
+ text->delta_space.y = 0;
+ } else {
+ text->delta_space.y = Tw / ctx->pgs->PDFfontsize;
+ text->delta_space.x = 0;
+ }
+ text->space.s_char = 0x20;
+ }
+
+ if (current_font->pdfi_font_type == e_pdf_font_type3) {
+ text->operation |= TEXT_FROM_CHARS;
+ text->data.chars = (const gs_char *)gs_alloc_bytes(ctx->memory, s->length * sizeof(gs_char), "string gs_chars");
+ if (!text->data.chars) {
+ code = gs_note_error(gs_error_VMerror);
+ goto text_params_error;
+ }
+
+ for (i = 0; i < s->length; i++) {
+ ((gs_char *)text->data.chars)[i] = (gs_char)s->data[i];
+ }
+ }
+ else {
+ text->operation |= TEXT_FROM_BYTES;
+ text->data.bytes = (const byte *)s->data;
+ }
+ text->size = s->length;
+ }
+ return 0;
+
+text_params_error:
+ gs_free_object(ctx->memory, x_widths, "X widths array for text");
+ text->x_widths = NULL;
+ gs_free_object(ctx->memory, y_widths, "Y widths array for text");
+ text->y_widths = NULL;
+ gs_free_object(ctx->memory, (void *)text->data.chars, "string gs_chars");
+ text->data.chars = NULL;
+ return code;
+}
+
+/* These routines actually perform the fill/stroke/clip of the text.
+ * We build up the compound cases by reusing the basic cases which
+ * is why we reset the TEXT_DO_ fields after use.
+ */
+
+static int pdfi_show_simple(pdf_context *ctx, gs_text_params_t *text)
+{
+ int code = 0;
+ gs_text_enum_t *penum=NULL, *saved_penum=NULL;
+
+ code = gs_text_begin(ctx->pgs, text, ctx->memory, &penum);
+ if (code >= 0) {
+ penum->single_byte_space = true;
+ saved_penum = ctx->text.current_enum;
+ ctx->text.current_enum = penum;
+ code = gs_text_process(penum);
+ gs_text_release(ctx->pgs, penum, "pdfi_Tj");
+ ctx->text.current_enum = saved_penum;
+ }
+ return code;
+}
+
+/* Mode 0 - fill */
+static int pdfi_show_Tr_0(pdf_context *ctx, gs_text_params_t *text)
+{
+ int code;
+
+ /* just draw the text */
+ text->operation |= TEXT_DO_DRAW;
+
+ code = pdfi_show_simple(ctx, text);
+
+ text->operation &= ~TEXT_DO_DRAW;
+ return code;
+}
+
+/* Mode 1 - stroke */
+static int pdfi_show_Tr_1(pdf_context *ctx, gs_text_params_t *text)
+{
+ int code;
+ gs_text_enum_t *penum=NULL, *saved_penum=NULL;
+ gs_point end_point, initial_point;
+
+ end_point.x = end_point.y = initial_point.x = initial_point.y = 0;
+
+ /* Capture the current position */
+ code = gs_currentpoint(ctx->pgs, &initial_point);
+ if (code < 0)
+ return code;
+
+ /* We don't want to disturb the current path, so do a gsave now
+ * We will grestore back to this point after we have stroked the
+ * text, which will leave any current path unchanged.
+ */
+ pdfi_gsave(ctx);
+
+ /* Start a new path (so our stroke doesn't include any
+ * already extant path in the graphics state)
+ */
+ code = gs_newpath(ctx->pgs);
+ if (code < 0)
+ goto Tr1_error;
+ code = gs_moveto(ctx->pgs, initial_point.x, initial_point.y);
+ if (code < 0)
+ goto Tr1_error;
+
+ /* Don't draw the text, create a path suitable for stroking */
+ text->operation |= TEXT_DO_FALSE_CHARPATH;
+
+ /* Run the text methods to create the path */
+ code = gs_text_begin(ctx->pgs, text, ctx->memory, &penum);
+ if (code < 0)
+ goto Tr1_error;
+
+ penum->single_byte_space = true;
+ saved_penum = ctx->text.current_enum;
+ ctx->text.current_enum = penum;
+ code = gs_text_process(penum);
+ gs_text_release(ctx->pgs, penum, "pdfi_Tj");
+ ctx->text.current_enum = saved_penum;
+ if (code < 0)
+ goto Tr1_error;
+
+ /* After a stroke operation there is no current point and we need
+ * it to be set as if we had drawn the text. So capture it now
+ * and we will append a 'move' to the current point when we have
+ * finished the stroke.
+ */
+ code = gs_currentpoint(ctx->pgs, &end_point);
+ if (code < 0)
+ goto Tr1_error;
+ /* Change to the current stroking colour */
+ gs_swapcolors_quick(ctx->pgs);
+ /* Finally, stroke the actual path */
+ code = gs_stroke(ctx->pgs);
+ /* Switch back to the non-stroke colour */
+ gs_swapcolors_quick(ctx->pgs);
+
+Tr1_error:
+ /* And grestore back to where we started */
+ pdfi_grestore(ctx);
+ /* If everything went well, then move the current point to the
+ * position we captured at the end of the path creation */
+ if (code >= 0)
+ code = gs_moveto(ctx->pgs, end_point.x, end_point.y);
+
+ text->operation &= ~TEXT_DO_FALSE_CHARPATH;
+ return code;
+}
+
+/* Mode 2 - fill then stroke */
+static int pdfi_show_Tr_2(pdf_context *ctx, gs_text_params_t *text)
+{
+ int code, restart = 0;
+ gs_text_enum_t *penum=NULL, *saved_penum=NULL;
+ gs_point end_point, initial_point;
+
+ end_point.x = end_point.y = initial_point.x = initial_point.y = 0;
+
+ /* Capture the current position */
+ code = gs_currentpoint(ctx->pgs, &initial_point);
+ if (code < 0)
+ return code;
+
+ /* We don't want to disturb the current path, so do a gsave now
+ * We will grestore back to this point after we have stroked the
+ * text, which will leave any current path unchanged.
+ */
+ pdfi_gsave(ctx);
+
+ /* Start a new path (so our stroke doesn't include any
+ * already extant path in the graphics state)
+ */
+ code = gs_newpath(ctx->pgs);
+ if (code < 0)
+ goto Tr1_error;
+ code = gs_moveto(ctx->pgs, initial_point.x, initial_point.y);
+ if (code < 0)
+ goto Tr1_error;
+
+ /* Don't draw the text, create a path suitable for stroking */
+ text->operation |= TEXT_DO_FALSE_CHARPATH;
+
+ /* Run the text methods to create the path */
+ code = gs_text_begin(ctx->pgs, text, ctx->memory, &penum);
+ if (code < 0)
+ goto Tr1_error;
+
+ penum->single_byte_space = true;
+ saved_penum = ctx->text.current_enum;
+ ctx->text.current_enum = penum;
+ code = gs_text_process(penum);
+ gs_text_release(ctx->pgs, penum, "pdfi_Tj");
+ ctx->text.current_enum = saved_penum;
+ if (code < 0)
+ goto Tr1_error;
+
+ /* After a stroke operation there is no current point and we need
+ * it to be set as if we had drawn the text. So capture it now
+ * and we will append a 'move' to the current point when we have
+ * finished the stroke.
+ */
+ code = gs_currentpoint(ctx->pgs, &end_point);
+ if (code < 0)
+ goto Tr1_error;
+ code = gs_fillstroke(ctx->pgs, &restart);
+
+Tr1_error:
+ /* And grestore back to where we started */
+ pdfi_grestore(ctx);
+ /* If everything went well, then move the current point to the
+ * position we captured at the end of the path creation */
+ if (code >= 0)
+ code = gs_moveto(ctx->pgs, end_point.x, end_point.y);
+
+ text->operation &= ~TEXT_DO_FALSE_CHARPATH;
+ return code;
+}
+
+static int pdfi_show_Tr_3(pdf_context *ctx, gs_text_params_t *text)
+{
+ int code;
+ gs_text_enum_t *penum=NULL, *saved_penum=NULL;
+
+ /* Don't draw the text */
+ text->operation |= TEXT_DO_NONE | TEXT_RENDER_MODE_3;
+
+ /* Run the text methods to create the path */
+ code = gs_text_begin(ctx->pgs, text, ctx->memory, &penum);
+ if (code < 0)
+ return code;
+
+ penum->single_byte_space = true;
+ saved_penum = ctx->text.current_enum;
+ ctx->text.current_enum = penum;
+ code = gs_text_process(penum);
+ gs_text_release(ctx->pgs, penum, "pdfi_Tj");
+ ctx->text.current_enum = saved_penum;
+
+ return code;
+}
+
+/* Prototype the basic 'clip' function, as the following routines will all use it */
+static int pdfi_show_Tr_7(pdf_context *ctx, gs_text_params_t *text);
+
+static int pdfi_show_Tr_4(pdf_context *ctx, gs_text_params_t *text)
+{
+ int code;
+ gs_point initial_point;
+
+ /* Capture the current position */
+ code = gs_currentpoint(ctx->pgs, &initial_point);
+ if (code < 0)
+ return code;
+
+ /* First fill the text */
+ code = pdfi_show_Tr_0(ctx, text);
+ if (code < 0)
+ return code;
+
+ /* Return the current point to the initial point */
+ code = gs_moveto(ctx->pgs, initial_point.x, initial_point.y);
+ if (code >= 0)
+ /* And add the text to the acumulated path for clipping */
+ code = pdfi_show_Tr_7(ctx, text);
+
+ return code;
+}
+
+static int pdfi_show_Tr_5(pdf_context *ctx, gs_text_params_t *text)
+{
+ int code;
+ gs_point initial_point;
+
+ /* Capture the current position */
+ code = gs_currentpoint(ctx->pgs, &initial_point);
+ if (code < 0)
+ return code;
+
+ /* First stroke the text */
+ code = pdfi_show_Tr_1(ctx, text);
+ if (code < 0)
+ return code;
+
+ /* Return the current point to the initial point */
+ code = gs_moveto(ctx->pgs, initial_point.x, initial_point.y);
+ if (code >= 0)
+ /* And add the text to the acumulated path for clipping */
+ code = pdfi_show_Tr_7(ctx, text);
+
+ return code;
+}
+
+static int pdfi_show_Tr_6(pdf_context *ctx, gs_text_params_t *text)
+{
+ int code;
+ gs_point initial_point;
+
+ /* Capture the current position */
+ code = gs_currentpoint(ctx->pgs, &initial_point);
+ if (code < 0)
+ return code;
+
+ /* First fill and stroke the text */
+ code = pdfi_show_Tr_2(ctx, text);
+ if (code < 0)
+ return code;
+
+ /* Return the current point to the initial point */
+ code = gs_moveto(ctx->pgs, initial_point.x, initial_point.y);
+ if (code >= 0)
+ /* And add the text to the acumulated path for clipping */
+ code = pdfi_show_Tr_7(ctx, text);
+
+ return code;
+}
+
+static int pdfi_show_Tr_7(pdf_context *ctx, gs_text_params_t *text)
+{
+ int code;
+ gs_text_enum_t *penum=NULL, *saved_penum=NULL;
+
+ /* Don't draw the text, create a path suitable for filling */
+ text->operation |= TEXT_DO_TRUE_CHARPATH;
+
+ /* Run the text methods to create the path */
+ code = gs_text_begin(ctx->pgs, text, ctx->memory, &penum);
+ if (code < 0)
+ goto Tr7_error;
+
+ penum->single_byte_space = true;
+ saved_penum = ctx->text.current_enum;
+ ctx->text.current_enum = penum;
+ code = gs_text_process(penum);
+ gs_text_release(ctx->pgs, penum, "pdfi_Tj");
+ ctx->text.current_enum = saved_penum;
+
+Tr7_error:
+ text->operation &= ~TEXT_DO_TRUE_CHARPATH;
+ return code;
+}
+
+static int pdfi_show_Tr_preserve(pdf_context *ctx, gs_text_params_t *text)
+{
+ int Trmode = 0, code;
+ pdf_font *current_font = NULL;
+ gs_point initial_point;
+
+ current_font = pdfi_get_current_pdf_font(ctx);
+ if (current_font == NULL)
+ return_error(gs_error_invalidfont);
+
+ /* Capture the current position, in case we need it for clipping */
+ code = gs_currentpoint(ctx->pgs, &initial_point);
+
+ Trmode = gs_currenttextrenderingmode(ctx->pgs);
+ if (Trmode == 3) {
+ if (current_font->pdfi_font_type == e_pdf_font_type3)
+ text->operation = TEXT_FROM_CHARS | TEXT_DO_NONE | TEXT_RENDER_MODE_3;
+ else
+ text->operation = TEXT_FROM_BYTES | TEXT_DO_NONE | TEXT_RENDER_MODE_3;
+ }
+ else
+ text->operation |= TEXT_DO_DRAW;
+
+ /* If we're preserving the text rendering mode, then we don't run a separate
+ * stroke operation, we do effectively run a fill. The fill setup loads the
+ * fill device colour whch, for patterns, creates the pattern tile.
+ * But, because we never load the stroke colour into a device colour, the
+ * pattern tile never gets loaded, so we get an error trying to draw the
+ * text.
+ * We could load the stroke colour in gs_text_begin, but that's potentially
+ * wasteful given that most of the time we won't be using the stroke colour
+ * os I've chosen to load the stroke device colour explicitly here.
+ * But, obviously, only when preserving a stroking text rendering mode.
+ */
+ if (Trmode == 1 || Trmode == 2 || Trmode == 5 || Trmode == 6) {
+ gs_swapcolors_quick(ctx->pgs);
+
+ code = gx_set_dev_color(ctx->pgs);
+ if (code != 0)
+ return code;
+
+ code = gs_gstate_color_load(ctx->pgs);
+ if (code < 0)
+ return code;
+
+ gs_swapcolors_quick(ctx->pgs);
+ }
+
+ code = pdfi_show_simple(ctx, text);
+ if (code < 0)
+ return code;
+
+ /* See the comment in pdfi_BT() aboe regarding text rendering modes and clipping.
+ * NB regardless of the device, we never apply clipping modes to text in a type 3 font.
+ */
+ if (Trmode >= 4 && current_font->pdfi_font_type != e_pdf_font_type3) {
+ text->operation &= ~TEXT_DO_DRAW;
+
+ gs_moveto(ctx->pgs, initial_point.x, initial_point.y);
+ code = pdfi_show_Tr_7(ctx, text);
+ }
+ return code;
+}
+
+static int pdfi_show(pdf_context *ctx, pdf_string *s)
+{
+ int code = 0;
+ int code1 = 0;
+ gs_text_params_t text;
+ pdf_font *current_font = NULL;
+ int Trmode = 0;
+ int initial_gsave_level = ctx->pgs->level;
+ pdfi_trans_state_t state;
+
+ if (ctx->text.BlockDepth == 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_TEXTOPNOBT, "pdfi_show", NULL);
+ }
+
+ if (hypot(ctx->pgs->ctm.xx, ctx->pgs->ctm.xy) == 0.0
+ || hypot(ctx->pgs->ctm.yy, ctx->pgs->ctm.yx) == 0.0) {
+ /* This can mean a font scaled to 0, which appears to be valid, or a degenerate
+ * ctm/text matrix, which isn't. A degenrate matrix will have triggered a warning
+ * before, so we just skip the operation here.
+ */
+ return 0;
+ }
+
+ current_font = pdfi_get_current_pdf_font(ctx);
+ if (current_font == NULL)
+ return_error(gs_error_invalidfont);
+
+ code = pdfi_show_set_params(ctx, s, &text);
+ if (code < 0)
+ goto show_error;
+
+ code = pdfi_trans_setup_text(ctx, &state, true);
+ if (code >= 0) {
+ if (ctx->device_state.preserve_tr_mode) {
+ code = pdfi_show_Tr_preserve(ctx, &text);
+ } else {
+ Trmode = gs_currenttextrenderingmode(ctx->pgs);
+
+ /* The spec says that we ignore text rendering modes other than 0 for
+ * type 3 fonts, but Acrobat also honours mode 3 (do nothing)
+ */
+ if (current_font->pdfi_font_type == e_pdf_font_type3 && Trmode != 0 && Trmode != 3)
+ Trmode = 0;
+
+ switch(Trmode) {
+ case 0:
+ code = pdfi_show_Tr_0(ctx, &text);
+ break;
+ case 1:
+ code = pdfi_show_Tr_1(ctx, &text);
+ break;
+ case 2:
+ code = pdfi_show_Tr_2(ctx, &text);
+ break;
+ case 3:
+ code = pdfi_show_Tr_3(ctx, &text);
+ break;
+ case 4:
+ code = pdfi_show_Tr_4(ctx, &text);
+ break;
+ case 5:
+ code = pdfi_show_Tr_5(ctx, &text);
+ break;
+ case 6:
+ code = pdfi_show_Tr_6(ctx, &text);
+ break;
+ case 7:
+ code = pdfi_show_Tr_7(ctx, &text);
+ break;
+ default:
+ break;
+ }
+ }
+ code1 = pdfi_trans_teardown_text(ctx, &state);
+ if (code == 0)
+ code = code1;
+ }
+
+ /* We shouldn't need to do this, but..... It turns out that if we have text rendering mode 3 set
+ * then gs_text_begin will execute a gsave, push the nulldevice and alter the saved gsave level.
+ * If we then get an error while processing the text we don't gs_restore enough times which
+ * leaves the nulldevice as the current device, and eats all the following content!
+ * To avoid that, we save the gsave depth at the start of this routine, and grestore enough
+ * times to get back to the same level. I think this is actually a bug in the graphics library
+ * but it doesn't get exposed in normal usage so we'll just work around it here.
+ */
+ while(ctx->pgs->level > initial_gsave_level)
+ gs_grestore(ctx->pgs);
+
+show_error:
+ if ((void *)text.data.chars != (void *)s->data)
+ gs_free_object(ctx->memory, (void *)text.data.chars, "string gs_chars");
+
+ gs_free_object(ctx->memory, (void *)text.x_widths, "Free X widths array on error");
+ gs_free_object(ctx->memory, (void *)text.y_widths, "Free Y widths array on error");
+ return code;
+}
+
+/* NOTE: the bounding box this generates has llx and lly at 0,0,
+ so is arguably not a "real" bounding box
+ */
+int pdfi_string_bbox(pdf_context *ctx, pdf_string *s, gs_rect *bboxout, gs_point *advance_width, bool for_stroke)
+{
+ int code = 0;
+ gx_device_bbox *bbdev;
+ pdf_font *current_font = pdfi_get_current_pdf_font(ctx);
+ gs_matrix tmpmat, Trm, Trm_ctm;
+ gs_point cppt, startpt;
+
+ if (current_font == NULL)
+ return_error(gs_error_invalidfont);
+
+
+ for_stroke = current_font->pdfi_font_type == e_pdf_font_type3 ? false : for_stroke;
+
+ bbdev = gs_alloc_struct_immovable(ctx->memory, gx_device_bbox, &st_device_bbox, "pdfi_string_bbox(bbdev)");
+ if (bbdev == NULL)
+ return_error(gs_error_VMerror);
+
+ gx_device_bbox_init(bbdev, NULL, ctx->memory);
+ gx_device_retain((gx_device *)bbdev, true);
+ gx_device_bbox_set_white_opaque(bbdev, true);
+
+ code = pdfi_gsave(ctx);
+ if (code < 0) {
+ gx_device_retain((gx_device *)bbdev, false);
+ return code;
+ }
+ /* The bbox device needs a fairly high resolution to get accurate results */
+ gx_device_set_resolution((gx_device *)bbdev, 720.0, 720.0);
+
+ code = gs_setdevice_no_erase(ctx->pgs, (gx_device *)bbdev);
+ if (code < 0)
+ goto out;
+
+ Trm.xx = ctx->pgs->PDFfontsize * (ctx->pgs->texthscaling / 100);
+ Trm.xy = 0;
+ Trm.yx = 0;
+ Trm.yy = ctx->pgs->PDFfontsize;
+ Trm.tx = 0;
+ Trm.ty = ctx->pgs->textrise;
+
+ memcpy(&tmpmat, &ctx->pgs->textmatrix, sizeof(tmpmat));
+ /* We want to avoid any translations unrelated to the extents of the text */
+ tmpmat.tx = tmpmat.ty = 0;
+ gs_matrix_multiply(&Trm, &tmpmat, &Trm);
+
+ memcpy(&tmpmat, &ctm_only(ctx->pgs), sizeof(tmpmat));
+ /* As above */
+ tmpmat.tx = tmpmat.ty = 0;
+ gs_matrix_multiply(&Trm, &tmpmat, &Trm_ctm);
+ gs_setmatrix(ctx->pgs, &Trm_ctm);
+
+ gs_settextrenderingmode(ctx->pgs, for_stroke ? 2 : 0);
+
+ code = pdfi_gs_setgray(ctx, 1.0);
+ if (code < 0)
+ goto out;
+
+ /* The bbox device (not surprisingly) clips to the device width/height
+ so we have to offset our initial point to cope with glyphs that include
+ negative coordinates. Most significantly, descender features - hence the
+ larger y offset.
+ The offsets are guesses.
+ */
+ startpt.x = ctx->pgs->PDFfontsize;
+ startpt.y = ctx->pgs->PDFfontsize * 16.0 * (ctx->pgs->textrise >= 0 ? 1 : -ctx->pgs->textrise);
+ code = gs_moveto(ctx->pgs, startpt.x, startpt.y);
+ if (code < 0)
+ goto out;
+
+ code = pdfi_show(ctx, s);
+ if (code < 0)
+ goto out;
+
+ code = gx_device_bbox_bbox(bbdev, bboxout);
+ if (code < 0)
+ goto out;
+
+ bboxout->q.x -= bboxout->p.x;
+ bboxout->q.y -= bboxout->p.y;
+ bboxout->p.x = bboxout->p.y = 0;
+
+ code = gs_currentpoint(ctx->pgs, &cppt);
+ if (code >= 0) {
+ code = gs_point_transform(startpt.x, startpt.y, &ctm_only(ctx->pgs), &startpt);
+ if (code < 0)
+ goto out;
+ advance_width->x = ctx->pgs->current_point.x - startpt.x;
+ advance_width->y = ctx->pgs->current_point.y - startpt.y;
+ code = gs_point_transform_inverse(advance_width->x, advance_width->y, &tmpmat, advance_width);
+ }
+out:
+ pdfi_grestore(ctx);
+ gx_device_retain((gx_device *)bbdev, false);
+
+ return code;
+}
+
+int pdfi_Tj(pdf_context *ctx)
+{
+ int code = 0;
+ pdf_string *s = NULL;
+ gs_matrix saved, Trm;
+ gs_point initial_point, current_point, pt;
+ double linewidth = ctx->pgs->line_params.half_width;
+
+ if (pdfi_count_stack(ctx) < 1)
+ return_error(gs_error_stackunderflow);
+
+ if (pdfi_oc_is_off(ctx))
+ goto exit;
+
+ s = (pdf_string *)ctx->stack_top[-1];
+ if (s->type != PDF_STRING)
+ return_error(gs_error_typecheck);
+
+ /* Save the CTM for later restoration */
+ saved = ctm_only(ctx->pgs);
+ gs_currentpoint(ctx->pgs, &initial_point);
+
+ Trm.xx = ctx->pgs->PDFfontsize * (ctx->pgs->texthscaling / 100);
+ Trm.xy = 0;
+ Trm.yx = 0;
+ Trm.yy = ctx->pgs->PDFfontsize;
+ Trm.tx = 0;
+ Trm.ty = ctx->pgs->textrise;
+
+ gs_matrix_multiply(&Trm, &ctx->pgs->textmatrix, &Trm);
+
+ if (!ctx->device_state.preserve_tr_mode) {
+ gs_distance_transform_inverse(ctx->pgs->line_params.half_width, 0, &Trm, &pt);
+ ctx->pgs->line_params.half_width = sqrt((pt.x * pt.x) + (pt.y * pt.y));
+ } else {
+ /* We have to adjust the stroke width for pdfwrite so that we take into
+ * account the CTM, but we do not spply the font scaling. Because of
+ * the disconnect between pdfwrite and the interpreter, we also have to
+ * remove the scaling due to the resolution.
+ */
+ gs_matrix devmatrix, matrix;
+ gx_device *device = gs_currentdevice(ctx->pgs);
+
+ devmatrix.xx = 72.0 / device->HWResolution[0];
+ devmatrix.xy = 0;
+ devmatrix.yx = 0;
+ devmatrix.yy = 72.0 / device->HWResolution[1];
+ devmatrix.tx = 0;
+ devmatrix.ty = 0;
+
+ code = gs_matrix_multiply(&saved, &devmatrix, &matrix);
+ if (code < 0)
+ goto exit;
+
+ gs_distance_transform(ctx->pgs->line_params.half_width, 0, &matrix, &pt);
+ ctx->pgs->line_params.half_width = sqrt((pt.x * pt.x) + (pt.y * pt.y));
+ }
+
+ gs_matrix_multiply(&Trm, &ctm_only(ctx->pgs), &Trm);
+ gs_setmatrix(ctx->pgs, &Trm);
+
+ code = gs_moveto(ctx->pgs, 0, 0);
+ if (code < 0)
+ goto Tj_error;
+
+ code = pdfi_show(ctx, s);
+
+ ctx->pgs->line_params.half_width = linewidth;
+ /* Update the Text matrix with the current point, for the next operation
+ */
+ gs_currentpoint(ctx->pgs, &current_point);
+ Trm.xx = ctx->pgs->PDFfontsize * (ctx->pgs->texthscaling / 100);
+ Trm.xy = 0;
+ Trm.yx = 0;
+ Trm.yy = ctx->pgs->PDFfontsize;
+ Trm.tx = 0;
+ Trm.ty = 0;
+ gs_matrix_multiply(&Trm, &ctx->pgs->textmatrix, &Trm);
+
+ gs_distance_transform(current_point.x, current_point.y, &Trm, &pt);
+ ctx->pgs->textmatrix.tx += pt.x;
+ ctx->pgs->textmatrix.ty += pt.y;
+
+Tj_error:
+ /* Restore the CTM to the saved value */
+ gs_setmatrix(ctx->pgs, &saved);
+ /* And restore the currentpoint */
+ gs_moveto(ctx->pgs, initial_point.x, initial_point.y);
+ /* And the line width */
+ ctx->pgs->line_params.half_width = linewidth;
+
+ exit:
+ pdfi_pop(ctx, 1);
+ return code;
+}
+
+int pdfi_TJ(pdf_context *ctx)
+{
+ int code = 0, i;
+ pdf_array *a = NULL;
+ pdf_obj *o = NULL;
+ double dx = 0;
+ gs_point pt;
+ gs_matrix saved, Trm;
+ gs_point initial_point, current_point;
+ double linewidth = ctx->pgs->line_params.half_width;
+ pdf_font *current_font = NULL;
+
+ current_font = pdfi_get_current_pdf_font(ctx);
+ if (current_font == NULL)
+ return_error(gs_error_invalidfont);
+
+ if (ctx->text.BlockDepth == 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_TEXTOPNOBT, "pdfi_TJ", NULL);
+ }
+
+ if (pdfi_count_stack(ctx) < 1)
+ return_error(gs_error_stackunderflow);
+
+ if (pdfi_oc_is_off(ctx))
+ goto exit;
+
+ a = (pdf_array *)ctx->stack_top[-1];
+ if (a->type != PDF_ARRAY) {
+ pdfi_pop(ctx, 1);
+ return gs_note_error(gs_error_typecheck);
+ }
+
+ /* Save the CTM for later restoration */
+ saved = ctm_only(ctx->pgs);
+ gs_currentpoint(ctx->pgs, &initial_point);
+
+ /* Calculate the text rendering matrix, see section 1.7 PDF Reference
+ * page 409, section 5.3.3 Text Space details.
+ */
+ Trm.xx = ctx->pgs->PDFfontsize * (ctx->pgs->texthscaling / 100);
+ Trm.xy = 0;
+ Trm.yx = 0;
+ Trm.yy = ctx->pgs->PDFfontsize;
+ Trm.tx = 0;
+ Trm.ty = ctx->pgs->textrise;
+
+ gs_matrix_multiply(&Trm, &ctx->pgs->textmatrix, &Trm);
+
+ if (!ctx->device_state.preserve_tr_mode) {
+ gs_distance_transform_inverse(ctx->pgs->line_params.half_width, 0, &Trm, &pt);
+ ctx->pgs->line_params.half_width = sqrt((pt.x * pt.x) + (pt.y * pt.y));
+ } else {
+ /* We have to adjust the stroke width for pdfwrite so that we take into
+ * account the CTM, but we do not spply the font scaling. Because of
+ * the disconnect between pdfwrite and the interpreter, we also have to
+ * remove the scaling due to the resolution.
+ */
+ gs_matrix devmatrix, matrix;
+ gx_device *device = gs_currentdevice(ctx->pgs);
+
+ devmatrix.xx = 72.0 / device->HWResolution[0];
+ devmatrix.xy = 0;
+ devmatrix.yx = 0;
+ devmatrix.yy = 72.0 / device->HWResolution[1];
+ devmatrix.tx = 0;
+ devmatrix.ty = 0;
+
+ code = gs_matrix_multiply(&saved, &devmatrix, &matrix);
+ if (code < 0)
+ goto exit;
+
+ gs_distance_transform(ctx->pgs->line_params.half_width, 0, &matrix, &pt);
+ ctx->pgs->line_params.half_width = sqrt((pt.x * pt.x) + (pt.y * pt.y));
+ }
+
+ gs_matrix_multiply(&Trm, &ctm_only(ctx->pgs), &Trm);
+ gs_setmatrix(ctx->pgs, &Trm);
+
+ code = gs_moveto(ctx->pgs, 0, 0);
+ if (code < 0)
+ goto TJ_error;
+
+ for (i = 0; i < pdfi_array_size(a); i++) {
+ code = pdfi_array_get(ctx, a, (uint64_t)i, &o);
+ if (code < 0)
+ goto TJ_error;
+
+ if (o->type == PDF_INT) {
+ dx = (double)((pdf_num *)o)->value.i / -1000;
+ if (current_font->pfont && current_font->pfont->WMode == 0)
+ code = gs_rmoveto(ctx->pgs, dx, 0);
+ else
+ code = gs_rmoveto(ctx->pgs, 0, dx);
+ if (code < 0)
+ goto TJ_error;
+ } else {
+ if (o->type == PDF_REAL) {
+ dx = ((pdf_num *)o)->value.d / -1000;
+ if (current_font->pfont && current_font->pfont->WMode == 0)
+ code = gs_rmoveto(ctx->pgs, dx, 0);
+ else
+ code = gs_rmoveto(ctx->pgs, 0, dx);
+ if (code < 0)
+ goto TJ_error;
+ } else {
+ if (o->type == PDF_STRING)
+ code = pdfi_show(ctx, (pdf_string *)o);
+ else
+ code = gs_note_error(gs_error_typecheck);
+ }
+ }
+ pdfi_countdown(o);
+ o = NULL;
+ if (code < 0)
+ goto TJ_error;
+ }
+
+ /* Update the Text matrix with the current point, for the next operation
+ */
+ gs_currentpoint(ctx->pgs, &current_point);
+ Trm.xx = ctx->pgs->PDFfontsize * (ctx->pgs->texthscaling / 100);
+ Trm.xy = 0;
+ Trm.yx = 0;
+ Trm.yy = ctx->pgs->PDFfontsize;
+ Trm.tx = 0;
+ Trm.ty = 0;
+ gs_matrix_multiply(&Trm, &ctx->pgs->textmatrix, &Trm);
+
+ gs_distance_transform(current_point.x, current_point.y, &Trm, &pt);
+ ctx->pgs->textmatrix.tx += pt.x;
+ ctx->pgs->textmatrix.ty += pt.y;
+
+TJ_error:
+ pdfi_countdown(o);
+ /* Restore the CTM to the saved value */
+ gs_setmatrix(ctx->pgs, &saved);
+ /* And restore the currentpoint */
+ gs_moveto(ctx->pgs, initial_point.x, initial_point.y);
+ /* And the line width */
+ ctx->pgs->line_params.half_width = linewidth;
+
+ exit:
+ pdfi_pop(ctx, 1);
+ return code;
+}
+
+static int pdfi_set_TL(pdf_context *ctx, double TL)
+{
+ return gs_settextleading(ctx->pgs, TL);
+}
+
+int pdfi_TL(pdf_context *ctx)
+{
+ int code = 0;
+ pdf_num *n = NULL;
+
+ if (pdfi_count_stack(ctx) < 1) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ n = (pdf_num *)ctx->stack_top[-1];
+
+ if (n->type == PDF_INT)
+ code = pdfi_set_TL(ctx, (double)(n->value.i * -1));
+ else {
+ if (n->type == PDF_REAL)
+ code = pdfi_set_TL(ctx, n->value.d * -1.0);
+ else
+ code = gs_note_error(gs_error_typecheck);
+ }
+ pdfi_pop(ctx, 1);
+ return code;
+}
+
+int pdfi_Tm(pdf_context *ctx)
+{
+ int code = 0, i;
+ float m[6];
+ pdf_num *n = NULL;
+ gs_matrix mat;
+
+ if (pdfi_count_stack(ctx) < 6) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+ for (i = 1;i < 7;i++) {
+ n = (pdf_num *)ctx->stack_top[-1 * i];
+ if (n->type == PDF_INT)
+ m[6 - i] = (float)n->value.i;
+ else {
+ if (n->type == PDF_REAL)
+ m[6 - i] = (float)n->value.d;
+ else {
+ pdfi_pop(ctx, 6);
+ return_error(gs_error_typecheck);
+ }
+ }
+ }
+ pdfi_pop(ctx, 6);
+
+ if (ctx->text.BlockDepth == 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_TEXTOPNOBT, "pdfi_Tm", NULL);
+
+ gs_make_identity(&mat);
+ code = gs_settextmatrix(ctx->pgs, &mat);
+ if (code < 0)
+ return code;
+
+ code = gs_settextlinematrix(ctx->pgs, &mat);
+ if (code < 0)
+ return code;
+ }
+
+ if (hypot(m[0], m[1]) == 0.0 || hypot(m[3], m[2]) == 0.0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_DEGENERATETM, "pdfi_Tm", NULL);
+
+ code = gs_settextmatrix(ctx->pgs, (gs_matrix *)&m);
+ if (code < 0)
+ return code;
+
+ code = gs_settextlinematrix(ctx->pgs, (gs_matrix *)&m);
+
+ return code;
+}
+
+int pdfi_Tr(pdf_context *ctx)
+{
+ int code = 0, mode = 0;
+ pdf_num *n = NULL;
+
+ if (pdfi_count_stack(ctx) < 1) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ n = (pdf_num *)ctx->stack_top[-1];
+
+ if (n->type == PDF_INT)
+ mode = n->value.i;
+ else {
+ if (n->type == PDF_REAL)
+ mode = (int)n->value.d;
+ else {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_typecheck);
+ }
+ }
+ pdfi_pop(ctx, 1);
+
+ if (mode < 0 || mode > 7)
+ code = gs_note_error(gs_error_rangecheck);
+ else {
+/* See comment regarding text rendering modes involving clip in pdfi_BT() above.
+ * The commented out code here will be needed when we enhance pdfwrite so that
+ * we don't need to do the clip separately.
+ */
+/* if (!ctx->device_state.preserve_tr_mode) {*/
+ gs_point initial_point;
+
+ /* Detect attempts to switch from a clipping mode to a non-clipping
+ * mode, this is defined as invalid in the spec.
+ */
+ if (gs_currenttextrenderingmode(ctx->pgs) > 3 && mode < 4 && ctx->text.BlockDepth != 0)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BADTRSWITCH, "pdfi_Tr", NULL);
+
+ if (gs_currenttextrenderingmode(ctx->pgs) < 4 && mode >= 4 && ctx->text.BlockDepth != 0) {
+ /* If we are switching from a non-clip text rendering mode to a
+ * mode involving a cip, and we are already inside a text block,
+ * put a gsave in place so that we can accumulate a path for
+ * clipping without disturbing any existing path in the
+ * graphics state.
+ */
+ gs_settextrenderingmode(ctx->pgs, mode);
+ pdfi_gsave(ctx);
+ /* Capture the current position */
+ code = gs_currentpoint(ctx->pgs, &initial_point);
+ /* Start a new path (so our clip doesn't include any
+ * already extant path in the graphics state)
+ */
+ gs_newpath(ctx->pgs);
+ gs_moveto(ctx->pgs, initial_point.x, initial_point.y);
+ }
+ else {
+ if (gs_currenttextrenderingmode(ctx->pgs) >= 4 && mode < 4 && ctx->text.BlockDepth != 0) {
+ /* If we are switching from a clipping mode to a non-clipping
+ * mode then behave as if we had an implicit ET to flush the
+ * accumulated text to a clip, then set the text rendering mode
+ * to the non-clip mode, and perform an implicit BT.
+ */
+ pdfi_ET(ctx);
+ gs_settextrenderingmode(ctx->pgs, mode);
+ pdfi_BT(ctx);
+ }
+ else
+ gs_settextrenderingmode(ctx->pgs, mode);
+ }
+/* }
+ else
+ gs_settextrenderingmode(ctx->pgs, mode);*/
+ }
+
+ return code;
+}
+
+static int pdfi_set_Ts(pdf_context *ctx, double Ts)
+{
+ return gs_settextrise(ctx->pgs, Ts);
+}
+
+int pdfi_Ts(pdf_context *ctx)
+{
+ int code = 0;
+ pdf_num *n = NULL;
+
+ if (pdfi_count_stack(ctx) < 1) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ n = (pdf_num *)ctx->stack_top[-1];
+
+ if (n->type == PDF_INT)
+ code = pdfi_set_Ts(ctx, (double)n->value.i);
+ else {
+ if (n->type == PDF_REAL)
+ code = pdfi_set_Ts(ctx, n->value.d);
+ else
+ code = gs_note_error(gs_error_typecheck);
+ }
+ pdfi_pop(ctx, 1);
+ return code;
+}
+
+static int pdfi_set_Tw(pdf_context *ctx, double Tw)
+{
+ return gs_setwordspacing(ctx->pgs, Tw);
+}
+
+int pdfi_Tw(pdf_context *ctx)
+{
+ int code = 0;
+ pdf_num *n = NULL;
+
+ if (pdfi_count_stack(ctx) < 1) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ n = (pdf_num *)ctx->stack_top[-1];
+
+ if (n->type == PDF_INT)
+ code = pdfi_set_Tw(ctx, (double)n->value.i);
+ else {
+ if (n->type == PDF_REAL)
+ code = pdfi_set_Tw(ctx, n->value.d);
+ else
+ code = gs_note_error(gs_error_typecheck);
+ }
+ pdfi_pop(ctx, 1);
+ return code;
+}
+
+int pdfi_Tz(pdf_context *ctx)
+{
+ int code = 0;
+ pdf_num *n = NULL;
+
+ if (pdfi_count_stack(ctx) < 1) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ n = (pdf_num *)ctx->stack_top[-1];
+
+ if (n->type == PDF_INT)
+ code = gs_settexthscaling(ctx->pgs, (double)n->value.i);
+ else {
+ if (n->type == PDF_REAL)
+ code = gs_settexthscaling(ctx->pgs, n->value.d);
+ else
+ code = gs_note_error(gs_error_typecheck);
+ }
+ pdfi_pop(ctx, 1);
+ return code;
+}
+
+int pdfi_singlequote(pdf_context *ctx)
+{
+ int code;
+
+ if (ctx->text.BlockDepth == 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_TEXTOPNOBT, "pdfi_singlequote", NULL);
+ }
+
+ if (pdfi_count_stack(ctx) < 1) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ code = pdfi_T_star(ctx);
+ if (code < 0)
+ return code;
+
+ return pdfi_Tj(ctx);
+}
+
+int pdfi_doublequote(pdf_context *ctx)
+{
+ int code;
+ pdf_string *s;
+ pdf_num *Tw, *Tc;
+
+ if (ctx->text.BlockDepth == 0) {
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_TEXTOPNOBT, "pdfi_T_doublequote", NULL);
+ }
+
+ if (pdfi_count_stack(ctx) < 3) {
+ pdfi_clearstack(ctx);
+ return_error(gs_error_stackunderflow);
+ }
+
+ s = (pdf_string *)ctx->stack_top[-1];
+ Tc = (pdf_num *)ctx->stack_top[-2];
+ Tw = (pdf_num *)ctx->stack_top[-3];
+ if (s->type != PDF_STRING || (Tc->type != PDF_INT && Tc->type != PDF_REAL) ||
+ (Tw->type != PDF_INT && Tw->type != PDF_REAL)) {
+ pdfi_pop(ctx, 3);
+ return gs_note_error(gs_error_typecheck);
+ }
+
+ if (Tc->type == PDF_INT)
+ code = pdfi_set_Tc(ctx, (double)Tc->value.i);
+ else
+ code = pdfi_set_Tc(ctx, Tc->value.d);
+ if (code < 0) {
+ pdfi_pop(ctx, 3);
+ return code;
+ }
+
+ if (Tw->type == PDF_INT)
+ code = pdfi_set_Tw(ctx, (double)Tw->value.i);
+ else
+ code = pdfi_set_Tw(ctx, Tw->value.d);
+ if (code < 0) {
+ pdfi_pop(ctx, 3);
+ return code;
+ }
+
+ code = pdfi_T_star(ctx);
+ if (code < 0)
+ return code;
+
+ code = pdfi_Tj(ctx);
+ pdfi_pop(ctx, 3);
+ return code;
+}
diff --git a/pdf/pdf_text.h b/pdf/pdf_text.h
new file mode 100644
index 00000000..bd62d38e
--- /dev/null
+++ b/pdf/pdf_text.h
@@ -0,0 +1,59 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Text operations for the PDF interpreter */
+
+#ifndef PDF_TEXT_OPERATORS
+#define PDF_TEXT_OPERATORS
+
+typedef struct pdf_text_tracking_s
+{
+ int text_block_depth;
+ gs_matrix initial_CTM;
+ gs_matrix saved_Tm;
+ gs_matrix saved_Tl;
+ int initial_gsave_depth;
+ void *next_block;
+} pdf_text_tracking;
+
+int pdfi_BT(pdf_context *ctx);
+int pdfi_ET(pdf_context *ctx);
+int pdfi_T_star(pdf_context *ctx);
+int pdfi_Tc(pdf_context *ctx);
+int pdfi_Td(pdf_context *ctx);
+int pdfi_TD(pdf_context *ctx);
+int pdfi_Tj(pdf_context *ctx);
+int pdfi_TJ(pdf_context *ctx);
+int pdfi_TL(pdf_context *ctx);
+int pdfi_Tm(pdf_context *ctx);
+int pdfi_Tr(pdf_context *ctx);
+int pdfi_Ts(pdf_context *ctx);
+int pdfi_Tw(pdf_context *ctx);
+int pdfi_Tz(pdf_context *ctx);
+int pdfi_backslash(pdf_context *ctx);
+int pdfi_singlequote(pdf_context *ctx);
+int pdfi_doublequote(pdf_context *ctx);
+
+/* Returns the bounding box of a string drawn with the current graphics state.
+ Stroking implies a slightly larger bounding box - the parameter is ignored
+ for Type 3 fonts. Also returns the accumlated "advance width" of all the glyphs
+ in the string.
+ This can be an expensive operation, so should be used sparingly, with care.
+ NOTE: the bounding box this generates has llx and lly at 0,0,
+ so is arguably not a "real" bounding box
+ */
+int pdfi_string_bbox(pdf_context *ctx, pdf_string *s, gs_rect *bboxout, gs_point *advance_width, bool for_stroke);
+
+#endif
diff --git a/pdf/pdf_trans.c b/pdf/pdf_trans.c
new file mode 100644
index 00000000..93ab8a6c
--- /dev/null
+++ b/pdf/pdf_trans.c
@@ -0,0 +1,811 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Transparency support */
+
+#include "pdf_int.h"
+#include "pdf_stack.h"
+#include "pdf_trans.h"
+#include "pdf_dict.h"
+#include "pdf_colour.h"
+#include "pdf_gstate.h"
+#include "pdf_array.h"
+#include "pdf_image.h"
+#include "pdf_device.h"
+#include "pdf_misc.h"
+#include "pdf_func.h"
+
+#include "gstparam.h"
+#include "gsicc_manage.h" /* For gs_currentoverrideicc() */
+#include "gscoord.h" /* For gs_setmatrix()*/
+#include "gsstate.h" /* For gs_currentstrokeoverprint() and others */
+#include "gspath.h" /* For gs_clippath() */
+
+/* Implement the TransferFunction using a Function. */
+static int
+pdfi_tf_using_function(double in_val, float *out, void *proc_data)
+{
+ float in = in_val;
+ gs_function_t *const pfn = proc_data;
+
+ return gs_function_evaluate(pfn, &in, out);
+}
+
+static void
+pdfi_set_GrayBackground(gs_transparency_mask_params_t *params)
+{
+ float num;
+
+ /* This uses definition from PLRM2 6.2.1 and 6.2.2 */
+ /* TODO: We are assuming 3 components is RGB and 4 components is CMYK,
+ which might not strictly be true? But it provides a better
+ estimated value than doing nothing.
+ */
+ switch(params->Background_components) {
+ case 3:
+ /* RGB: currentgray = 0.3*R + 0.59*G + 0.11*B */
+ params->GrayBackground = (0.3 * params->Background[0] +
+ 0.59 * params->Background[1] +
+ 0.11 * params->Background[2]);
+ break;
+ case 4:
+ /* CMYK: currentgray = 1.0 – min (1.0, .3*C + .59*M + .11*Y + K)
+ */
+ num = 0.3*params->Background[0] + 0.59*params->Background[1] +
+ 0.11*params->Background[2] + params->Background[3];
+ if (num > 1)
+ num = 1;
+ params->GrayBackground = 1 - num;
+ break;
+ case 1:
+ params->GrayBackground = params->Background[0];
+ break;
+ default:
+ /* No clue... */
+ params->GrayBackground = 0;
+ }
+}
+
+/* (see pdf_draw.ps/execmaskgroup) */
+static int pdfi_trans_set_mask(pdf_context *ctx, pdfi_int_gstate *igs, int colorindex)
+{
+ int code = 0, code1 = 0;
+ pdf_dict *SMask = igs->SMask;
+ gs_color_space *pcs = NULL;
+ gs_rect bbox;
+ gs_transparency_mask_params_t params;
+ pdf_array *BBox = NULL;
+ pdf_array *Matrix = NULL;
+ pdf_array *a = NULL;
+ pdf_array *BC = NULL;
+ pdf_stream *G_stream = NULL;
+ pdf_dict *G_stream_dict = NULL;
+ pdf_dict *Group = NULL;
+ pdf_obj *TR = NULL;
+ gs_function_t *gsfunc = NULL;
+ pdf_name *n = NULL;
+ pdf_name *S = NULL;
+ pdf_obj *CS = NULL;
+ double f;
+ gs_matrix save_matrix, GroupMat, group_Matrix;
+ gs_transparency_mask_subtype_t subtype = TRANSPARENCY_MASK_Luminosity;
+ pdf_bool *Processed = NULL;
+ bool save_OverrideICC = gs_currentoverrideicc(ctx->pgs);
+
+#if DEBUG_TRANSPARENCY
+ dbgmprintf(ctx->memory, "pdfi_trans_set_mask (.execmaskgroup) BEGIN\n");
+#endif
+ memset(&params, 0, sizeof(params));
+
+ /* Following the logic of the ps code, cram a /Processed key in the SMask dict to
+ * track whether it's already been processed.
+ */
+ code = pdfi_dict_knownget_type(ctx, SMask, "Processed", PDF_BOOL, (pdf_obj **)&Processed);
+ if (code > 0 && Processed->value) {
+#if DEBUG_TRANSPARENCY
+ dbgmprintf(ctx->memory, "SMask already built, skipping\n");
+#endif
+ goto exit;
+ }
+
+ gs_setoverrideicc(ctx->pgs, true);
+
+ /* If /Processed not in the dict, put it there */
+ if (code == 0) {
+ /* the cleanup at end of this routine assumes Processed has a ref */
+ code = pdfi_object_alloc(ctx, PDF_BOOL, 0, (pdf_obj **)&Processed);
+ if (code < 0)
+ goto exit;
+ Processed->value = false;
+ /* pdfi_object_alloc() doesn't grab a ref */
+ pdfi_countup(Processed);
+ code = pdfi_dict_put(ctx, SMask, "Processed", (pdf_obj *)Processed);
+ if (code < 0)
+ goto exit;
+ }
+
+ /* See pdf1.7 pg 553 (pain in the butt to find this!) */
+ code = pdfi_dict_knownget_type(ctx, SMask, "Type", PDF_NAME, (pdf_obj **)&n);
+ if (code == 0 || (code > 0 && pdfi_name_is(n, "Mask"))) {
+ /* G is transparency group XObject (required) */
+ code = pdfi_dict_knownget_type(ctx, SMask, "G", PDF_STREAM, (pdf_obj **)&G_stream);
+ if (code <= 0) {
+ dmprintf(ctx->memory, "WARNING: Missing 'G' in SMask, ignoring.\n");
+ pdfi_trans_end_smask_notify(ctx);
+ code = 0;
+ goto exit;
+ }
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)G_stream, &G_stream_dict);
+ if (code < 0)
+ goto exit;
+
+ /* S is a subtype name (required) */
+ code = pdfi_dict_knownget_type(ctx, SMask, "S", PDF_NAME, (pdf_obj **)&S);
+ if (code <= 0) {
+ dmprintf(ctx->memory, "WARNING: Missing 'S' in SMask (defaulting to Luminosity)\n");
+ }
+ if (pdfi_name_is(S, "Luminosity")) {
+ subtype = TRANSPARENCY_MASK_Luminosity;
+ } else if (pdfi_name_is(S, "Alpha")) {
+ subtype = TRANSPARENCY_MASK_Alpha;
+ } else {
+ dmprintf(ctx->memory, "WARNING: Unknown subtype 'S' in SMask (defaulting to Luminosity)\n");
+ }
+
+ /* TR is transfer function (Optional) */
+ code = pdfi_dict_knownget(ctx, SMask, "TR", (pdf_obj **)&TR);
+ if (code > 0) {
+ if (TR->type == PDF_DICT || TR->type == PDF_STREAM) {
+ code = pdfi_build_function(ctx, &gsfunc, NULL, 1, TR, NULL);
+ if (code < 0)
+ goto exit;
+ } else if (TR->type == PDF_NAME) {
+ if (!pdfi_name_is((pdf_name *)TR, "Identity")) {
+ dmprintf(ctx->memory, "WARNING: Unknown TR in SMask\n");
+ }
+ } else {
+ dmprintf(ctx->memory, "WARNING: Ignoring invalid TR in SMask\n");
+ }
+ }
+
+ /* BC is Background Color array (Optional) */
+ code = pdfi_dict_knownget_type(ctx, SMask, "BC", PDF_ARRAY, (pdf_obj **)&BC);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_dict_knownget_type(ctx, G_stream_dict, "Matte", PDF_ARRAY, (pdf_obj **)&a);
+ if (code > 0) {
+ int ix;
+
+ for (ix = 0; ix < pdfi_array_size(a); ix++) {
+ code = pdfi_array_get_number(ctx, a, (uint64_t)ix, &f);
+ if (code < 0)
+ break;
+ params.Matte[ix] = f;
+ }
+ if (ix >= pdfi_array_size(a))
+ params.Matte_components = pdfi_array_size(a);
+ else
+ params.Matte_components = 0;
+ }
+
+ code = pdfi_dict_knownget_type(ctx, G_stream_dict, "BBox", PDF_ARRAY, (pdf_obj **)&BBox);
+ if (code < 0)
+ goto exit;
+ code = pdfi_array_to_gs_rect(ctx, BBox, &bbox);
+ if (code < 0)
+ goto exit;
+
+ gs_trans_mask_params_init(&params, subtype);
+ params.replacing = true;
+ if (gsfunc) {
+ params.TransferFunction = pdfi_tf_using_function;
+ params.TransferFunction_data = gsfunc;
+ }
+
+ /* Need to set just the ctm (GroupMat) from the saved GroupGState, to
+ have gs_begin_transparency_mask work correctly. Or at least that's
+ what the PS code comments claim (see pdf_draw.ps/.execmaskgroup)
+ */
+ gs_currentmatrix(ctx->pgs, &save_matrix);
+ gs_currentmatrix(igs->GroupGState, &GroupMat);
+ gs_setmatrix(ctx->pgs, &GroupMat);
+
+ code = pdfi_dict_knownget_type(ctx, G_stream_dict, "Matrix", PDF_ARRAY, (pdf_obj **)&Matrix);
+ if (code < 0)
+ goto exit;
+ code = pdfi_array_to_gs_matrix(ctx, Matrix, &group_Matrix);
+ if (code < 0)
+ goto exit;
+
+ /* Transform the BBox by the Matrix */
+ pdfi_bbox_transform(ctx, &bbox, &group_Matrix);
+
+ /* CS is in the dict "Group" inside the dict "G" */
+ /* TODO: Not sure if this is a required thing or just one possibility */
+ code = pdfi_dict_knownget_type(ctx, G_stream_dict, "Group", PDF_DICT, (pdf_obj **)&Group);
+ if (code < 0)
+ goto exit;
+ if (code > 0) {
+ /* TODO: Stuff with colorspace, see .execmaskgroup */
+ code = pdfi_dict_knownget(ctx, Group, "CS", &CS);
+ if (code < 0)
+ goto exit;
+ if (code > 0) {
+ code = pdfi_create_colorspace(ctx, CS, (pdf_dict *)ctx->main_stream,
+ ctx->page.CurrentPageDict, &pcs, false);
+ params.ColorSpace = pcs;
+ if (code < 0)
+ goto exit;
+ } else {
+ /* Inherit current colorspace */
+ params.ColorSpace = ctx->pgs->color[colorindex].color_space;
+ }
+ } else {
+ /* GS and Adobe will ignore the whole mask in this case, so we do the same.
+ */
+ pdfi_set_error(ctx, 0, NULL, E_PDF_INVALID_TRANS_XOBJECT, "pdfi_trans_set_mask", (char *)"*** Error: Ignoring a transparency group XObject without /Group attribute");
+ goto exit;
+ }
+
+ /* If there's a BC, put it in the params */
+ if (BC) {
+ int i;
+ double num;
+ for (i=0; i<pdfi_array_size(BC); i++) {
+ if (i > GS_CLIENT_COLOR_MAX_COMPONENTS)
+ break;
+ code = pdfi_array_get_number(ctx, BC, i, &num);
+ if (code < 0)
+ break;
+ params.Background[i] = (float)num;
+ }
+ params.Background_components = pdfi_array_size(BC);
+
+ /* TODO: Not sure how to handle this... recheck PS code (pdf_draw.ps/gssmask) */
+ /* This should be "currentgray" for the color that we put in params.ColorSpace,
+ * It looks super-convoluted to actually get this value. Really?
+ * (see zcurrentgray())
+ * For now, use simple definition from PLRM2 and assume it is RGB or CMYK
+ */
+ pdfi_set_GrayBackground(&params);
+ }
+
+ code = gs_begin_transparency_mask(ctx->pgs, &params, &bbox, false);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_form_execgroup(ctx, ctx->page.CurrentPageDict, G_stream,
+ igs->GroupGState, NULL, &group_Matrix);
+ code1 = gs_end_transparency_mask(ctx->pgs, colorindex);
+ if (code != 0)
+ code = code1;
+
+ /* Put back the matrix (we couldn't just rely on gsave/grestore for whatever reason,
+ * according to PS code anyway...
+ */
+ gs_setmatrix(ctx->pgs, &save_matrix);
+
+ /* Set Processed flag */
+ if (code == 0 && Processed)
+ Processed->value = true;
+ } else {
+ /* take action on a non-/Mask entry. What does this mean ? What do we need to do */
+ dmprintf(ctx->memory, "Warning: Type is not /Mask, entry ignored in pdfi_set_trans_mask\n");
+ }
+
+ exit:
+ gs_setoverrideicc(ctx->pgs, save_OverrideICC);
+ if (gsfunc)
+ pdfi_free_function(ctx, gsfunc);
+ if (pcs)
+ rc_decrement_cs(pcs, "pdfi_trans_set_mask");
+ pdfi_countdown(n);
+ pdfi_countdown(S);
+ pdfi_countdown(Group);
+ pdfi_countdown(G_stream);
+ pdfi_countdown(a);
+ pdfi_countdown(BC);
+ pdfi_countdown(TR);
+ pdfi_countdown(BBox);
+ pdfi_countdown(Matrix);
+ pdfi_countdown(CS);
+ pdfi_countdown(Processed);
+#if DEBUG_TRANSPARENCY
+ dbgmprintf(ctx->memory, "pdfi_trans_set_mask (.execmaskgroup) END\n");
+#endif
+ return code;
+}
+
+/* Wrapper around gs call to setup the transparency params correctly */
+static int pdfi_gs_begin_transparency_group(gs_gstate * pgs,
+ gs_transparency_group_params_t *params,
+ const gs_rect *pbbox, pdf14_compositor_operations group_type)
+{
+ if (gs_getalphaisshape(pgs)) {
+ params->group_shape = gs_getfillconstantalpha(pgs);
+ params->group_opacity = 1.0;
+ } else {
+ params->group_opacity = gs_getfillconstantalpha(pgs);
+ params->group_shape = 1.0;
+ }
+
+ return gs_begin_transparency_group(pgs, params, pbbox, group_type);
+}
+
+static int pdfi_transparency_group_common(pdf_context *ctx, pdf_dict *page_dict,
+ pdf_dict *group_dict,
+ gs_rect *bbox, pdf14_compositor_operations group_type)
+{
+ gs_transparency_group_params_t params;
+ pdf_obj *CS = NULL;
+ bool b;
+ int code;
+
+ gs_trans_group_params_init(&params, 1.0);
+ // gs_setopacityalpha(ctx->pgs, ctx->pgs->fillconstantalpha);
+
+ /* It seems the flag for Isolated is /I */
+ code = pdfi_dict_get_bool(ctx, group_dict, "I", &b);
+ if (code < 0 && code != gs_error_undefined)
+ return_error(code);
+ if (code == gs_error_undefined)
+ params.Isolated = false;
+ else
+ params.Isolated = b;
+
+ /* It seems the flag for Knockout is /K */
+ code = pdfi_dict_get_bool(ctx, group_dict, "K", &b);
+ if (code < 0 && code != gs_error_undefined)
+ goto exit;
+ if (code == gs_error_undefined)
+ params.Knockout = false;
+ else
+ params.Knockout = b;
+
+ params.image_with_SMask = false;
+ params.ColorSpace = NULL;
+
+ code = pdfi_dict_knownget(ctx, group_dict, "CS", &CS);
+ if (code == 0) {
+ /* Didn't find a /CS key, try again using /ColorSpace */
+ code = pdfi_dict_knownget(ctx, group_dict, "ColorSpace", &CS);
+ }
+ if (code > 0 && CS->type != PDF_NULL) {
+ code = pdfi_setcolorspace(ctx, CS, group_dict, page_dict);
+ if (code < 0)
+ goto exit;
+ params.ColorSpace = gs_currentcolorspace(ctx->pgs);
+ } else {
+ params.ColorSpace = NULL;
+ }
+
+ exit:
+ pdfi_countdown(CS);
+ if (code < 0)
+ return_error(code);
+
+ return pdfi_gs_begin_transparency_group(ctx->pgs, &params, (const gs_rect *)bbox, group_type);
+}
+
+/* Begin a simple group
+ * pathbbox -- bbox to use, but can be NULL
+ */
+int pdfi_trans_begin_simple_group(pdf_context *ctx, gs_rect *pathbbox,
+ bool stroked_bbox, bool isolated, bool knockout)
+{
+ gs_transparency_group_params_t params;
+ gs_rect bbox;
+ int code;
+
+ gs_trans_group_params_init(&params, 1.0);
+ params.Isolated = isolated;
+ params.Knockout = knockout;
+
+ if (!pathbbox) {
+ code = pdfi_get_current_bbox(ctx, &bbox, stroked_bbox);
+ if (code < 0)
+ return code;
+ pathbbox = &bbox;
+ }
+
+ code = pdfi_gs_begin_transparency_group(ctx->pgs, &params, pathbbox, PDF14_BEGIN_TRANS_GROUP);
+ if (code >= 0)
+ ctx->current_stream_save.group_depth++;
+ return code;
+}
+
+int pdfi_trans_begin_page_group(pdf_context *ctx, pdf_dict *page_dict, pdf_dict *group_dict)
+{
+ gs_rect bbox;
+ int code;
+
+ if (group_dict == NULL)
+ return_error(gs_error_undefined);
+
+ code = pdfi_gsave(ctx);
+ bbox.p.x = ctx->page.Size[0];
+ bbox.p.y = ctx->page.Size[1];
+ bbox.q.x = ctx->page.Size[2];
+ bbox.q.y = ctx->page.Size[3];
+
+ code = pdfi_transparency_group_common(ctx, page_dict, group_dict, &bbox, PDF14_BEGIN_TRANS_PAGE_GROUP);
+ if (code < 0)
+ pdfi_grestore(ctx);
+ else
+ ctx->current_stream_save.group_depth++;
+
+ return code;
+}
+
+int pdfi_trans_begin_form_group(pdf_context *ctx, pdf_dict *page_dict, pdf_dict *form_dict)
+{
+ pdf_obj *group_obj = NULL;
+ gs_rect bbox;
+ pdf_array *BBox = NULL;
+ int code;
+ pdf_dict *group_dict = NULL;
+
+ /* TODO: Maybe sometimes this is actually a stream?
+ * Otherwise should just fetch it as a dict.
+ * Anyway this will work for either dict or stream
+ */
+ code = pdfi_dict_get(ctx, form_dict, "Group", &group_obj);
+ if (code < 0)
+ return_error(code);
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)group_obj, &group_dict);
+ if (code < 0)
+ goto exit;
+
+ code = pdfi_gsave(ctx);
+ code = pdfi_dict_knownget_type(ctx, form_dict, "BBox", PDF_ARRAY, (pdf_obj **)&BBox);
+ if (code < 0)
+ goto exit;
+ if (code > 0) {
+ code = pdfi_array_to_gs_rect(ctx, BBox, &bbox);
+ if (code < 0)
+ goto exit;
+ } else {
+ bbox.p.x = 0;
+ bbox.p.y = 0;
+ bbox.q.x = 0;
+ bbox.q.y = 0;
+ }
+
+ code = pdfi_transparency_group_common(ctx, page_dict, group_dict, &bbox, PDF14_BEGIN_TRANS_GROUP);
+ if (code < 0)
+ pdfi_grestore(ctx);
+ else
+ ctx->current_stream_save.group_depth++;
+
+ exit:
+ pdfi_countdown(BBox);
+ pdfi_countdown(group_obj);
+ return code;
+}
+
+
+int pdfi_trans_end_group(pdf_context *ctx)
+{
+ int code;
+
+ code = gs_end_transparency_group(ctx->pgs);
+ if (code < 0)
+ pdfi_grestore(ctx);
+ else
+ code = pdfi_grestore(ctx);
+
+ ctx->current_stream_save.group_depth--;
+
+ return code;
+}
+
+/* Ends group with no grestore */
+int pdfi_trans_end_simple_group(pdf_context *ctx)
+{
+ int code;
+
+ code = gs_end_transparency_group(ctx->pgs);
+ ctx->current_stream_save.group_depth--;
+
+ return code;
+}
+
+
+int pdfi_trans_begin_isolated_group(pdf_context *ctx, bool image_with_SMask, gs_color_space *pcs)
+{
+ gs_transparency_group_params_t params;
+ gs_rect bbox;
+
+ gs_trans_group_params_init(&params, 1.0);
+
+ params.ColorSpace = pcs;
+ params.Isolated = true;
+ params.Knockout = false;
+ params.image_with_SMask = image_with_SMask;
+ bbox.p.x = 0;
+ bbox.p.y = 0;
+ bbox.q.x = 1;
+ bbox.q.y = 1;
+
+ return pdfi_gs_begin_transparency_group(ctx->pgs, &params, &bbox, PDF14_BEGIN_TRANS_GROUP);
+}
+
+int pdfi_trans_end_isolated_group(pdf_context *ctx)
+{
+ return gs_end_transparency_group(ctx->pgs);
+}
+
+
+/* This notifies the compositor that we're done with an smask. Seems hacky.
+ * See pdf_draw.ps/doimagesmask.
+ */
+int pdfi_trans_end_smask_notify(pdf_context *ctx)
+{
+ gs_transparency_mask_params_t params;
+ gs_rect bbox;
+
+ gs_trans_mask_params_init(&params, TRANSPARENCY_MASK_None);
+ params.replacing = true;
+
+ bbox.p.x = 0;
+ bbox.p.y = 0;
+ bbox.q.x = 0;
+ bbox.q.y = 0;
+
+ return gs_begin_transparency_mask(ctx->pgs, &params, &bbox, false);
+}
+
+/* Setup whether or not we need to support overprint (for device)
+ * Check for:
+ * 1) how many components the device has (CMYK or other)
+ * 2) whether it is a device that has transparency support
+ * 3) Overprint mode (enable, disable, simulate)
+ * Based on pdf_main.ps/pdfshowpage_finish
+ * Test file (run with -dOverprint=/simulate)
+ * tests_private/pdf/uploads/op_trans_spot_testing.pdf
+ */
+void pdfi_trans_set_needs_OP(pdf_context *ctx)
+{
+ bool is_cmyk;
+ bool device_transparency = false;
+
+ /* PS code checks for >= 4 components... */
+ is_cmyk = ctx->pgs->device->color_info.num_components >= 4;
+
+ device_transparency = pdfi_device_check_param_bool(ctx->pgs->device, "HaveTransparency");
+
+ ctx->page.needs_OP = false;
+ ctx->page.simulate_op = false;
+ switch(ctx->args.overprint_control) {
+ case PDF_OVERPRINT_DISABLE:
+ /* Use defaults */
+ break;
+ case PDF_OVERPRINT_SIMULATE:
+ if (!device_transparency && ctx->page.has_OP) {
+ if (is_cmyk) {
+ if (ctx->page.num_spots > 0) {
+ ctx->page.needs_OP = true;
+ ctx->page.simulate_op = true;
+ }
+ } else {
+ ctx->page.needs_OP = true;
+ ctx->page.simulate_op = true;
+ }
+ }
+ break;
+ case PDF_OVERPRINT_ENABLE:
+ default:
+ if (!is_cmyk || device_transparency)
+ ctx->page.needs_OP = false;
+ else
+ ctx->page.needs_OP = true;
+ break;
+ }
+
+ if(ctx->args.pdfdebug)
+ dbgmprintf2(ctx->memory, "Page %s Overprint, Simulate is %s\n",
+ ctx->page.needs_OP ? "NEEDS" : "does NOT NEED",
+ ctx->page.simulate_op ? "TRUE" : "FALSE");
+}
+
+/* Figures out if current colorspace is okay for Overprint (see pdf_ops.ps/okOPcs and setupOPtrans) */
+static bool pdfi_trans_okOPcs(pdf_context *ctx)
+{
+ gs_color_space_index csi;
+
+ csi = pdfi_currentcolorspace(ctx, 0);
+
+ switch (csi) {
+ case gs_color_space_index_DeviceGray:
+ case gs_color_space_index_DeviceCMYK:
+ case gs_color_space_index_DeviceN:
+ case gs_color_space_index_Separation:
+ /* These are colorspaces that don't require special handling for overprint.
+ * (pdf1.7 pg 259,578 may apply)
+ * According to mvrhel, DeviceGray should also be included (see comment in gx_set_overprint_ICC()).
+ * Sample: 030_Gray_K_black_OP_x1a.pdf (??)
+ */
+#if DEBUG_TRANSPARENCY
+ dbgmprintf1(ctx->memory, "Colorspace is %d, OKAY for OVERPRINT\n", csi);
+#endif
+ return true;
+ default:
+#if DEBUG_TRANSPARENCY
+ dbgmprintf1(ctx->memory, "Colorspace is %d, NOT OKAY for OVERPRINT\n", csi);
+#endif
+ return false;
+ }
+
+ return false;
+}
+
+int pdfi_trans_setup(pdf_context *ctx, pdfi_trans_state_t *state, gs_rect *bbox,
+ pdfi_transparency_caller_t caller)
+{
+ pdfi_int_gstate *igs = (pdfi_int_gstate *)ctx->pgs->client_data;
+ int code;
+ bool stroked_bbox;
+ bool current_overprint;
+ bool okOPcs = false;
+ bool ChangeBM = false;
+ gs_blend_mode_t mode;
+ bool need_group = false;
+
+ memset(state, 0, sizeof(*state));
+
+ if (!ctx->page.has_transparency)
+ return 0;
+
+ if (ctx->page.needs_OP) {
+ okOPcs = pdfi_trans_okOPcs(ctx);
+ if (okOPcs) {
+ if (caller == TRANSPARENCY_Caller_Stroke)
+ current_overprint = gs_currentstrokeoverprint(ctx->pgs);
+ else {
+ current_overprint = gs_currentfilloverprint(ctx->pgs);
+ if (caller == TRANSPARENCY_Caller_FillStroke)
+ current_overprint |= gs_currentstrokeoverprint(ctx->pgs);
+ }
+ ChangeBM = current_overprint;
+ mode = gs_currentblendmode(ctx->pgs);
+ if (mode != BLEND_MODE_Normal && mode != BLEND_MODE_Compatible)
+ need_group = ChangeBM;
+ else
+ need_group = false;
+ } else {
+ need_group = false;
+ }
+ need_group = need_group || (igs->SMask != NULL);
+ } else {
+ if (caller == TRANSPARENCY_Caller_Image || igs->SMask == NULL)
+ need_group = false;
+ else
+ need_group = true;
+ }
+
+ code = pdfi_trans_set_params(ctx);
+ if (code != 0)
+ return 0;
+
+ if (!need_group && !ChangeBM)
+ return 0;
+
+ /* TODO: error handling... */
+ if (need_group) {
+ stroked_bbox = (caller == TRANSPARENCY_Caller_Stroke || caller == TRANSPARENCY_Caller_FillStroke);
+ /* When changing to compatible overprint bm, the group pushed must be non-isolated. The exception
+ is if we have a softmask. See /setupOPtrans in pdf_ops.ps */
+ code = pdfi_trans_begin_simple_group(ctx, bbox, stroked_bbox, igs->SMask != NULL, false);
+ state->GroupPushed = true;
+ state->saveStrokeAlpha = gs_getstrokeconstantalpha(ctx->pgs);
+ state->saveFillAlpha = gs_getfillconstantalpha(ctx->pgs);
+ code = gs_setfillconstantalpha(ctx->pgs, 1.0);
+ code = gs_setstrokeconstantalpha(ctx->pgs, 1.0);
+ }
+ if (ChangeBM) {
+ state->saveBM = mode;
+ state->ChangeBM = true;
+ code = gs_setblendmode(ctx->pgs, BLEND_MODE_CompatibleOverprint);
+ }
+ return code;
+}
+
+int pdfi_trans_setup_text(pdf_context *ctx, pdfi_trans_state_t *state, bool is_show)
+{
+ int Trmode = gs_currenttextrenderingmode(ctx->pgs);
+ int code, code1;
+ gs_rect bbox;
+
+ code = gs_gsave(ctx->pgs);
+ if (code < 0) goto exit;
+
+ if (is_show) {
+ code = gs_clippath(ctx->pgs);
+ } else {
+ code = gs_strokepath(ctx->pgs);
+ }
+ if (code >= 0)
+ code = gs_upathbbox(ctx->pgs, &bbox, false);
+ if (code < 0) {
+ /* Just set bbox to [0,0,0,0] */
+ bbox.p.x = bbox.p.y = bbox.q.x = bbox.q.y = 0.0;
+ code = 0;
+ }
+ code1 = gs_grestore(ctx->pgs);
+ if (code == 0) code = code1;
+ if (code < 0) goto exit;
+
+ switch (Trmode) {
+ case 0:
+ code = pdfi_trans_setup(ctx, state, &bbox, TRANSPARENCY_Caller_Fill);
+ break;
+ default:
+ /* TODO: All the others */
+ code = pdfi_trans_setup(ctx, state, &bbox, TRANSPARENCY_Caller_Fill);
+ break;
+ }
+
+ exit:
+ return code;
+}
+
+int pdfi_trans_teardown_text(pdf_context *ctx, pdfi_trans_state_t *state)
+{
+ int code = 0;
+
+ code = pdfi_trans_teardown(ctx, state);
+
+ return code;
+}
+
+int pdfi_trans_teardown(pdf_context *ctx, pdfi_trans_state_t *state)
+{
+ int code = 0;
+
+ if (!ctx->page.has_transparency)
+ return 0;
+
+ if (state->GroupPushed) {
+ code = pdfi_trans_end_simple_group(ctx);
+ code = gs_setstrokeconstantalpha(ctx->pgs, state->saveStrokeAlpha);
+ code = gs_setfillconstantalpha(ctx->pgs, state->saveFillAlpha);
+ }
+
+ if (gs_currentblendmode(ctx->pgs) == BLEND_MODE_CompatibleOverprint)
+ code = gs_setblendmode(ctx->pgs, state->saveBM);
+
+ return code;
+}
+
+int pdfi_trans_set_params(pdf_context *ctx)
+{
+ pdfi_int_gstate *igs = (pdfi_int_gstate *)ctx->pgs->client_data;
+ gs_transparency_channel_selector_t csel;
+
+ if (ctx->page.has_transparency) {
+ if (gs_getalphaisshape(ctx->pgs))
+ csel = TRANSPARENCY_CHANNEL_Shape;
+ else
+ csel = TRANSPARENCY_CHANNEL_Opacity;
+ if (igs->SMask) {
+ pdfi_trans_set_mask(ctx, igs, csel);
+ }
+ }
+
+ return 0;
+}
diff --git a/pdf/pdf_trans.h b/pdf/pdf_trans.h
new file mode 100644
index 00000000..e0057b74
--- /dev/null
+++ b/pdf/pdf_trans.h
@@ -0,0 +1,53 @@
+/* Copyright (C) 2019-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+#ifndef PDF_TRANSPARENCY_OPERATORS
+#define PDF_TRANSPARENCY_OPERATORS
+
+/* these names are to match the PS code (pdf_ops.ps/OPSaveDstack, setup_trans, teardown_trans) */
+typedef struct {
+ bool GroupPushed;
+ bool ChangeBM;
+ float saveStrokeAlpha;
+ float saveFillAlpha;
+ gs_blend_mode_t saveBM;
+} pdfi_trans_state_t;
+
+typedef enum {
+ TRANSPARENCY_Caller_Other,
+ TRANSPARENCY_Caller_Image,
+ TRANSPARENCY_Caller_Stroke,
+ TRANSPARENCY_Caller_Fill, /* Also includes EOFill */
+ TRANSPARENCY_Caller_FillStroke /* Also includes EOFillStroke */
+} pdfi_transparency_caller_t;
+
+int pdfi_trans_setup_text(pdf_context *ctx, pdfi_trans_state_t *state, bool is_show);
+int pdfi_trans_teardown_text(pdf_context *ctx, pdfi_trans_state_t *state);
+int pdfi_trans_setup(pdf_context *ctx, pdfi_trans_state_t *state, gs_rect *bbox, pdfi_transparency_caller_t caller);
+
+int pdfi_trans_teardown(pdf_context *ctx, pdfi_trans_state_t *state);
+
+int pdfi_trans_begin_simple_group(pdf_context *ctx, gs_rect *bbox, bool stroked_bbox, bool isolated, bool knockout);
+int pdfi_trans_begin_page_group(pdf_context *ctx, pdf_dict *page_dict, pdf_dict *group_dict);
+int pdfi_trans_begin_form_group(pdf_context *ctx, pdf_dict *page_dict, pdf_dict *form_dict);
+int pdfi_trans_end_group(pdf_context *ctx);
+int pdfi_trans_end_simple_group(pdf_context *ctx);
+int pdfi_trans_set_params(pdf_context *ctx);
+int pdfi_trans_begin_isolated_group(pdf_context *ctx, bool image_with_SMask, gs_color_space *pcs);
+int pdfi_trans_end_isolated_group(pdf_context *ctx);
+int pdfi_trans_end_smask_notify(pdf_context *ctx);
+void pdfi_trans_set_needs_OP(pdf_context *ctx);
+
+#endif
diff --git a/pdf/pdf_types.h b/pdf/pdf_types.h
new file mode 100644
index 00000000..9b4a9519
--- /dev/null
+++ b/pdf/pdf_types.h
@@ -0,0 +1,241 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+#ifndef PDF_OBJ_TYPES
+#define PDF_OBJ_TYPES
+
+/* defines for various compile-time debugging flags.
+ * These only emit any text on a debug build and when the relevant
+ * flag is set and compiled.
+ */
+#define DEBUG_PATTERN 0
+#define DEBUG_CONTEXT 0
+#define DEBUG_GSAVE 0
+#define DEBUG_IMAGES 0
+#define DEBUG_TRANSPARENCY 0
+#define DEBUG_DEVICE 0
+#define DEBUG_CACHE 0
+#define DEBUG_CACHE_FREE 0
+#define PROBE_STREAMS 0
+#define REFCNT_DEBUG 0
+#define CACHE_STATISTICS 0
+#define DEBUG_DICT 0
+
+#include "stdint_.h" /* Various data types */
+#include "scommon.h" /* for gs_offset_t */
+
+typedef enum pdf_obj_type_e {
+ PDF_NULL = 'n',
+ PDF_INT = 'i',
+ PDF_REAL = 'f',
+ PDF_STRING = 's',
+ PDF_NAME = '/',
+ PDF_ARRAY = 'a',
+ PDF_DICT = 'd',
+ PDF_INDIRECT = 'R',
+ PDF_BOOL = 'b',
+ PDF_KEYWORD = 'K',
+ PDF_FONT = 'F',
+ PDF_STREAM = 'S',
+ /* The following aren't PDF object types, but are objects we either want to
+ * reference count, or store on the stack.
+ */
+ PDF_XREF_TABLE = 'X',
+ PDF_ARRAY_MARK = '[',
+ PDF_DICT_MARK = '<',
+ PDF_PROC_MARK = '{',
+ PDF_CMAP = 'C'
+} pdf_obj_type;
+
+#if REFCNT_DEBUG
+#define pdf_obj_common \
+ pdf_obj_type type;\
+ char flags;\
+ unsigned int refcnt;\
+ void *ctx;\
+ uint32_t object_num;\
+ uint32_t generation_num;\
+ uint32_t indirect_num;\
+ uint16_t indirect_gen; \
+ uint64_t UID
+#else
+#define pdf_obj_common \
+ pdf_obj_type type;\
+ char flags;\
+ unsigned int refcnt;\
+ /* We have to define ctx as a void * and cast it, because the pdf_context structure\
+ * contains pdf_object members, so there's a circular dependency\
+ */\
+ void *ctx;\
+ /* Technically object numbers can be any integer. The only documented limit\
+ * architecturally is the fact that the linked list of free objects (ab)uses\
+ * the 'offset' field of the xref to hold the object number of the next free\
+ * object, this means object numbers can't be larger than 10 decimal digits.\
+ * Unfortunately, that's 34 bits, so we use the Implementation Limits in\
+ * Appendix H (Annexe C of the 2.0 spec) which limits object numbers to 23 bits.\
+ * But we use 32 bits instead.\
+ */\
+ uint32_t object_num;\
+ uint32_t generation_num;\
+ /* We only use the indirect object number for creating decryption keys for strings\
+ * for which we (currently at least) only need the bottom 3 bytes, but we keep\
+ * a full 32-bits. For the generation number we only need the bottom 2 bytes\
+ * so we keep that as a 16-bit value and truncate it on storage. If storage\
+ * becomes a problem we could use 5 bytes to store the 2 values but to save one\
+ * byte it does not seem worthwhile. Note! the indirect num is the object number\
+ * of the object if it is an indirect object (so indirect_num == object_num) or,\
+ * if the object is defined directly, its the object number of the enclosing\
+ * indirect object. This is not the same thing as the /Parent entry in some dictionaries.\
+ */\
+ uint32_t indirect_num;\
+ uint16_t indirect_gen
+#endif
+
+typedef struct pdf_obj_s {
+ pdf_obj_common;
+} pdf_obj;
+
+typedef struct pdf_bool_s {
+ pdf_obj_common;
+ bool value;
+} pdf_bool;
+
+typedef struct pdf_num_s {
+ pdf_obj_common;
+ union {
+ /* Acrobat (up to PDF version 1.7) limits ints to 32-bits, we choose to use 64 */
+ int64_t i;
+ double d;
+ }value;
+} pdf_num;
+
+typedef struct pdf_string_s {
+ pdf_obj_common;
+ uint32_t length;
+ unsigned char *data;
+} pdf_string;
+
+typedef struct pdf_name_s {
+ pdf_obj_common;
+ uint32_t length;
+ unsigned char *data;
+} pdf_name;
+
+typedef enum pdf_key_e {
+ TOKEN_NOT_A_KEYWORD,
+ TOKEN_OBJ,
+ TOKEN_ENDOBJ,
+ TOKEN_STREAM,
+ TOKEN_ENDSTREAM,
+ TOKEN_XREF,
+ TOKEN_STARTXREF,
+ TOKEN_TRAILER,
+ TOKEN_INVALID_KEY,
+}pdf_key;
+
+typedef struct pdf_keyword_s {
+ pdf_obj_common;
+ uint32_t length;
+ unsigned char *data;
+ pdf_key key;
+} pdf_keyword;
+
+typedef struct pdf_array_s {
+ pdf_obj_common;
+ uint64_t size;
+ pdf_obj **values;
+} pdf_array;
+
+typedef struct pdf_dict_s {
+ pdf_obj_common;
+ uint64_t size;
+ uint64_t entries;
+ pdf_obj **keys;
+ pdf_obj **values;
+ bool dict_written; /* Has dict been written (for pdfwrite) */
+} pdf_dict;
+
+typedef struct pdf_stream_s {
+ pdf_obj_common;
+ pdf_dict *stream_dict;
+ /* This is plain ugly. In order to deal with the (illegal) case where a stream
+ * uses named objects which are not defined in the stream's Resources dictionary,
+ * but *are* defined in one of the enclosing stream's Resources dictionary, we need
+ * to be able to walk back up the chain of nested streams. We set/reset the parent_obj
+ * in pdfi_interpret_stream_context, the value is only ever non-NULL if we are executing
+ * the stream, and the stream has a parent context.
+ */
+ pdf_obj *parent_obj;
+ gs_offset_t stream_offset;
+ int64_t Length; /* Value of Length in dict, 0 if undefined. non-zero means it's a stream */
+ bool length_valid; /* True if Length and is_stream have been cached above */
+ bool stream_written; /* Has stream been written (for pdfwrite) */
+ bool is_marking;
+} pdf_stream;
+
+typedef struct pdf_indirect_ref_s {
+ pdf_obj_common;
+ uint64_t ref_object_num;
+ uint32_t ref_generation_num;
+ uint64_t highlevel_object_num;
+ bool is_highlevelform; /* Used to tell that it's a high level form for pdfmark */
+ bool is_marking; /* Are we in the middle of marking this? */
+} pdf_indirect_ref;
+
+typedef struct pdf_obj_cache_entry_s {
+ void *next;
+ void *previous;
+ pdf_obj *o;
+}pdf_obj_cache_entry;
+
+/* The compressed and uncompressed xref entries are identical, they only differ
+ * in the names used for the variables. Its simply less confusing not to overload
+ * the names.
+ */
+typedef struct xref_entry_s {
+ bool compressed; /* true if object is in a compressed object stream */
+ bool free; /* true if this is a free entry */
+ uint64_t object_num; /* Object number */
+
+ union u_s {
+ struct uncompressed_s {
+ uint32_t generation_num; /* Generation number. */
+ gs_offset_t offset; /* File offset. */
+ }uncompressed;
+ struct compressed_s {
+ uint64_t compressed_stream_num; /* compressed stream object number if compressed */
+ uint32_t object_index; /* Index of object in compressed stream */
+ }compressed;
+ }u;
+ pdf_obj_cache_entry *cache; /* Pointer to cache entry if cached, or NULL if not */
+} xref_entry;
+
+typedef struct xref_s {
+ pdf_obj_common;
+ uint64_t xref_size;
+ xref_entry *xref;
+} xref_table_t;
+
+#define UNREAD_BUFFER_SIZE 256
+
+typedef struct pdf_c_stream_s {
+ bool eof;
+ stream *original;
+ stream *s;
+ uint32_t unread_size;
+ char unget_buffer[UNREAD_BUFFER_SIZE];
+} pdf_c_stream;
+
+#endif
diff --git a/pdf/pdf_utf8.c b/pdf/pdf_utf8.c
new file mode 100644
index 00000000..4e51b9b7
--- /dev/null
+++ b/pdf/pdf_utf8.c
@@ -0,0 +1,128 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* platform-specific string to UTF8 conversion routines */
+
+/* This code is in its own file because it needs to be compiled with
+ * a different set of complier flags to normal when built for MS Windows.
+ * We can't use the /Za flag with a file whcih includes windows.h, disabling
+ * the language extensions breaks the compilation. See pdf/pdf.mak for the
+ * build-specifics.
+ */
+
+#include "ghostpdf.h"
+#include "pdf_utf8.h"
+#include "pdf_types.h"
+#include "pdf_stack.h"
+
+#ifdef HAVE_LIBIDN
+# include <stringprep.h>
+# include <errno.h>
+/* Convert a string from the current locale's character set to UTF-8.
+ * <string> .locale_to_utf8 <string> */
+int
+locale_to_utf8(pdf_context *ctx, pdf_string *input, pdf_string **output)
+{
+ char *out = NULL;
+ int code;
+
+ out = stringprep_locale_to_utf8((const char *)input->data);
+ if (out == NULL) {
+ /* This function is intended to be used on strings whose
+ * character set is unknown, so it's not an error if the
+ * input contains invalid characters. Just return the input
+ * string unchanged.
+ *
+ * Sadly, EINVAL from stringprep_locale_to_utf8 can mean
+ * either an invalid character set conversion (which we care
+ * about), or an incomplete input string (which we don't).
+ * For now, we ignore EINVAL; the right solution is probably
+ * to not use stringprep_locale_to_utf8, and just call iconv
+ * by hand. */
+ if (errno == EILSEQ || errno == EINVAL)
+ return 0;
+
+ /* Other errors (like ENFILE) are real errors, which we
+ * want to return to the user. */
+ return_error(gs_error_ioerror);
+ }
+
+ code = pdfi_object_alloc(ctx, PDF_STRING, strlen(out), (pdf_obj **)output);
+ if (code < 0)
+ return code;
+ pdfi_countup(*output);
+ memcpy((*output)->data, out, strlen(out));
+
+ free(out);
+ return 0;
+}
+#else
+#ifdef _MSC_VER
+#include "windows_.h"
+/* Convert a string from the current locale's character set to UTF-8.
+ * Unfortunately, "current locale" can mean a few different things on
+ * Windows -- we use the default ANSI code page, which does the right
+ * thing for command-line arguments (like "-sPDFPassword=foo") and
+ * for strings typed as input to gswin32.exe. It doesn't work for
+ * strings typed as input to gswin32c.exe, which are normally in the
+ * default OEM code page instead.
+ * <string> .locale_to_utf8 <string> */
+int
+locale_to_utf8(pdf_context *ctx, pdf_string *input, pdf_string **output)
+{
+#define LOCALE_TO_UTF8_BUFFER_SIZE 1024
+ WCHAR wide_buffer[LOCALE_TO_UTF8_BUFFER_SIZE];
+ char utf8_buffer[LOCALE_TO_UTF8_BUFFER_SIZE];
+ int code, BytesWritten;
+
+ *output = NULL;
+
+ BytesWritten = MultiByteToWideChar(CP_ACP, 0, input->data, input->length,
+ wide_buffer, LOCALE_TO_UTF8_BUFFER_SIZE);
+ if (BytesWritten == 0)
+ return_error(gs_error_ioerror);
+
+ BytesWritten = WideCharToMultiByte(CP_UTF8, 0, wide_buffer, BytesWritten,
+ utf8_buffer, LOCALE_TO_UTF8_BUFFER_SIZE, NULL, NULL);
+ if (BytesWritten == 0)
+ return_error(gs_error_ioerror);
+
+ code = pdfi_object_alloc(ctx, PDF_STRING, BytesWritten, (pdf_obj **)output);
+ if (code < 0)
+ return code;
+ pdfi_countup(*output);
+ memcpy((*output)->data, utf8_buffer, BytesWritten);
+
+ return 0;
+#undef LOCALE_TO_UTF8_BUFFER_SIZE
+}
+#else
+/* We have no known method to create a UTF-8 string. Just copy the input and pretend.
+ */
+int
+locale_to_utf8(pdf_context *ctx, pdf_string *input, pdf_string **output)
+{
+ int code = 0;
+
+ code = pdfi_object_alloc(ctx, PDF_STRING, input->length, (pdf_obj **)output);
+ if (code < 0)
+ return code;
+ pdfi_countup(*output);
+ memcpy((*output)->data, input->data, input->length);
+
+ return 0;
+}
+#endif /* _WINDOWS_ */
+#endif /* HAVE_LIBIDN */
diff --git a/pdf/pdf_utf8.h b/pdf/pdf_utf8.h
new file mode 100644
index 00000000..225d1c94
--- /dev/null
+++ b/pdf/pdf_utf8.h
@@ -0,0 +1,25 @@
+/* Copyright (C) 2020-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+#ifndef PDF_UTF8
+#define PDF_UTF8
+
+#include "ghostpdf.h"
+#include "pdf_types.h"
+#include "pdf_stack.h"
+
+int locale_to_utf8(pdf_context *ctx, pdf_string *input, pdf_string **output);
+
+#endif
diff --git a/pdf/pdf_xref.c b/pdf/pdf_xref.c
new file mode 100644
index 00000000..27c1501e
--- /dev/null
+++ b/pdf/pdf_xref.c
@@ -0,0 +1,1123 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* xref parsing */
+
+#include "pdf_int.h"
+#include "pdf_stack.h"
+#include "pdf_xref.h"
+#include "pdf_file.h"
+#include "pdf_loop_detect.h"
+#include "pdf_dict.h"
+#include "pdf_array.h"
+#include "pdf_repair.h"
+
+static int resize_xref(pdf_context *ctx, uint64_t new_size)
+{
+ xref_entry *new_xrefs;
+
+ /* Although we can technically handle object numbers larger than this, on some systems (32-bit Windows)
+ * memset is limited to a (signed!) integer for the size of memory to clear. We could deal
+ * with this by clearing the memory in blocks, but really, this is almost certainly a
+ * corrupted file or something.
+ */
+ if (new_size >= (0x7ffffff / sizeof(xref_entry)))
+ return_error(gs_error_rangecheck);
+
+ new_xrefs = (xref_entry *)gs_alloc_bytes(ctx->memory, (new_size) * sizeof(xref_entry), "read_xref_stream allocate xref table entries");
+ if (new_xrefs == NULL){
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ return_error(gs_error_VMerror);
+ }
+ memset(new_xrefs, 0x00, (new_size) * sizeof(xref_entry));
+ memcpy(new_xrefs, ctx->xref_table->xref, ctx->xref_table->xref_size * sizeof(xref_entry));
+ gs_free_object(ctx->memory, ctx->xref_table->xref, "reallocated xref entries");
+ ctx->xref_table->xref = new_xrefs;
+ ctx->xref_table->xref_size = new_size;
+ return 0;
+}
+
+static int read_xref_stream_entries(pdf_context *ctx, pdf_c_stream *s, uint64_t first, uint64_t last, uint64_t *W)
+{
+ uint i, j;
+ uint field_width = 0;
+ uint32_t type = 0;
+ uint64_t objnum = 0, gen = 0;
+ byte *Buffer;
+ int64_t bytes = 0;
+ xref_entry *entry;
+
+ /* Find max number of bytes to be read */
+ field_width = W[0];
+ if (W[1] > field_width)
+ field_width = W[1];
+ if (W[2] > field_width)
+ field_width = W[2];
+
+ Buffer = gs_alloc_bytes(ctx->memory, field_width, "read_xref_stream_entry working buffer");
+ for (i=first;i<=last; i++){
+ /* Defaults if W[n] = 0 */
+ type = 1;
+ objnum = gen = 0;
+
+ if (W[0] != 0) {
+ type = 0;
+ bytes = pdfi_read_bytes(ctx, Buffer, 1, W[0], s);
+ if (bytes < W[0]){
+ gs_free_object(ctx->memory, Buffer, "read_xref_stream_entry, free working buffer (error)");
+ return_error(gs_error_ioerror);
+ }
+ for (j=0;j<W[0];j++)
+ type = (type << 8) + Buffer[j];
+ }
+
+ if (W[1] != 0) {
+ bytes = pdfi_read_bytes(ctx, Buffer, 1, W[1], s);
+ if (bytes < W[1]){
+ gs_free_object(ctx->memory, Buffer, "read_xref_stream_entry free working buffer (error)");
+ return_error(gs_error_ioerror);
+ }
+ for (j=0;j<W[1];j++)
+ objnum = (objnum << 8) + Buffer[j];
+ }
+
+ if (W[2] != 0) {
+ bytes = pdfi_read_bytes(ctx, Buffer, 1, W[2], s);
+ if (bytes < W[2]){
+ gs_free_object(ctx->memory, Buffer, "read_xref_stream_entry, free working buffer (error)");
+ return_error(gs_error_ioerror);
+ }
+ for (j=0;j<W[2];j++)
+ gen = (gen << 8) + Buffer[j];
+ }
+
+ entry = &ctx->xref_table->xref[i];
+ if (entry->object_num != 0)
+ continue;
+
+ entry->compressed = false;
+ entry->free = false;
+ entry->object_num = i;
+ entry->cache = NULL;
+
+ switch(type) {
+ case 0:
+ entry->free = true;
+ entry->u.uncompressed.offset = objnum; /* For free objects we use the offset to store the object number of the next free object */
+ entry->u.uncompressed.generation_num = gen; /* And the generation number is the numebr to use if this object is used again */
+ break;
+ case 1:
+ entry->u.uncompressed.offset = objnum;
+ entry->u.uncompressed.generation_num = gen;
+ break;
+ case 2:
+ entry->compressed = true;
+ entry->u.compressed.compressed_stream_num = objnum; /* The object number of the compressed stream */
+ entry->u.compressed.object_index = gen; /* And the index of the object within the stream */
+ break;
+ default:
+ gs_free_object(ctx->memory, Buffer, "read_xref_stream_entry, free working buffer");
+ return_error(gs_error_rangecheck);
+ break;
+ }
+ }
+ gs_free_object(ctx->memory, Buffer, "read_xref_stream_entry, free working buffer");
+ return 0;
+}
+
+/* Forward definition */
+static int read_xref(pdf_context *ctx, pdf_c_stream *s);
+/* These two routines are recursive.... */
+static int pdfi_read_xref_stream_dict(pdf_context *ctx, pdf_c_stream *s);
+
+static int pdfi_process_xref_stream(pdf_context *ctx, pdf_stream *stream_obj, pdf_c_stream *s)
+{
+ pdf_c_stream *XRefStrm;
+ int code, i;
+ pdf_dict *sdict = NULL;
+ pdf_name *n;
+ pdf_array *a;
+ int64_t size;
+ int64_t num;
+ int64_t W[3];
+ bool known = false;
+
+ if (stream_obj->type != PDF_STREAM)
+ return_error(gs_error_typecheck);
+
+ code = pdfi_dict_from_obj(ctx, (pdf_obj *)stream_obj, &sdict);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_get_type(ctx, sdict, "Type", PDF_NAME, (pdf_obj **)&n);
+ if (code < 0)
+ return code;
+
+ if (n->length != 4 || memcmp(n->data, "XRef", 4) != 0) {
+ pdfi_countdown(n);
+ return_error(gs_error_syntaxerror);
+ }
+ pdfi_countdown(n);
+
+ code = pdfi_dict_get_int(ctx, sdict, "Size", &size);
+ if (code < 0)
+ return code;
+
+ if (size < 0)
+ return_error(gs_error_rangecheck);
+
+ /* If this is the first xref stream then allocate the xref table and store the trailer */
+ if (ctx->xref_table == NULL) {
+ ctx->xref_table = (xref_table_t *)gs_alloc_bytes(ctx->memory, sizeof(xref_table_t), "read_xref_stream allocate xref table");
+ if (ctx->xref_table == NULL) {
+ return_error(gs_error_VMerror);
+ }
+ memset(ctx->xref_table, 0x00, sizeof(xref_table_t));
+ ctx->xref_table->xref = (xref_entry *)gs_alloc_bytes(ctx->memory, size * sizeof(xref_entry), "read_xref_stream allocate xref table entries");
+ if (ctx->xref_table->xref == NULL){
+ gs_free_object(ctx->memory, ctx->xref_table, "failed to allocate xref table entries");
+ ctx->xref_table = NULL;
+ return_error(gs_error_VMerror);
+ }
+ memset(ctx->xref_table->xref, 0x00, size * sizeof(xref_entry));
+ ctx->xref_table->ctx = ctx;
+ ctx->xref_table->type = PDF_XREF_TABLE;
+ ctx->xref_table->xref_size = size;
+#if REFCNT_DEBUG
+ ctx->xref_table->UID = ctx->UID++;
+ dmprintf1(ctx->memory, "Allocated xref table with UID %"PRIi64"\n", ctx->xref_table->UID);
+#endif
+ pdfi_countup(ctx->xref_table);
+
+ ctx->Trailer = sdict;
+ pdfi_countup(sdict);
+ } else {
+ code = pdfi_merge_dicts(ctx, ctx->Trailer, sdict);
+ if (code < 0) {
+ if (code == gs_error_VMerror || ctx->args.pdfstoponerror)
+ return code;
+ }
+ }
+
+ pdfi_seek(ctx, ctx->main_stream, pdfi_stream_offset(ctx, stream_obj), SEEK_SET);
+
+ /* Bug #691220 has a PDF file with a compressed XRef, the stream dictionary has
+ * a /DecodeParms entry for the stream, which has a /Colors value of 5, which makes
+ * *no* sense whatever. If we try to apply a Predictor then we end up in a loop trying
+ * to read 5 colour samples. Rather than meddles with more parameters to the filter
+ * code, we'll just remove the Colors entry from the DecodeParms dictionary,
+ * because it is nonsense. This means we'll get the (sensible) default value of 1.
+ */
+ code = pdfi_dict_known(ctx, sdict, "DecodeParms", &known);
+ if (code < 0)
+ return code;
+
+ if (known) {
+ pdf_dict *DP;
+ double f;
+ pdf_obj *name;
+
+ code = pdfi_dict_get_type(ctx, sdict, "DecodeParms", PDF_DICT, (pdf_obj **)&DP);
+ if (code < 0)
+ return code;
+
+ code = pdfi_dict_knownget_number(ctx, DP, "Colors", &f);
+ if (code < 0) {
+ pdfi_countdown(DP);
+ return code;
+ }
+ if (code > 0 && f != (double)1)
+ {
+ code = pdfi_name_alloc(ctx, (byte *)"Colors", 6, &name);
+ if (code < 0) {
+ pdfi_countdown(DP);
+ return code;
+ }
+ pdfi_countup(name);
+
+ code = pdfi_dict_delete_pair(ctx, DP, (pdf_name *)name);
+ pdfi_countdown(name);
+ if (code < 0) {
+ pdfi_countdown(DP);
+ return code;
+ }
+ }
+ pdfi_countdown(DP);
+ }
+
+ code = pdfi_filter_no_decryption(ctx, stream_obj, s, &XRefStrm, false);
+ if (code < 0) {
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ return code;
+ }
+
+ code = pdfi_dict_get_type(ctx, sdict, "W", PDF_ARRAY, (pdf_obj **)&a);
+ if (code < 0) {
+ pdfi_close_file(ctx, XRefStrm);
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ return code;
+ }
+
+ if (pdfi_array_size(a) != 3) {
+ pdfi_countdown(a);
+ pdfi_close_file(ctx, XRefStrm);
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ return_error(gs_error_rangecheck);
+ }
+ for (i=0;i<3;i++) {
+ code = pdfi_array_get_int(ctx, a, (uint64_t)i, (int64_t *)&W[i]);
+ if (code < 0) {
+ pdfi_countdown(a);
+ pdfi_close_file(ctx, XRefStrm);
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ return code;
+ }
+ }
+ pdfi_countdown(a);
+
+ code = pdfi_dict_get_type(ctx, sdict, "Index", PDF_ARRAY, (pdf_obj **)&a);
+ if (code == gs_error_undefined) {
+ code = read_xref_stream_entries(ctx, XRefStrm, 0, size - 1, (uint64_t *)W);
+ if (code < 0) {
+ pdfi_close_file(ctx, XRefStrm);
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ return code;
+ }
+ } else {
+ int64_t start, end;
+
+ if (code < 0) {
+ pdfi_close_file(ctx, XRefStrm);
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ return code;
+ }
+
+ if (pdfi_array_size(a) & 1) {
+ pdfi_countdown(a);
+ pdfi_close_file(ctx, XRefStrm);
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ return_error(gs_error_rangecheck);
+ }
+
+ for (i=0;i < pdfi_array_size(a);i+=2){
+ code = pdfi_array_get_int(ctx, a, (uint64_t)i, &start);
+ if (code < 0) {
+ pdfi_countdown(a);
+ pdfi_close_file(ctx, XRefStrm);
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ return code;
+ }
+
+ code = pdfi_array_get_int(ctx, a, (uint64_t)i+1, &end);
+ if (code < 0) {
+ pdfi_countdown(a);
+ pdfi_countdown(start);
+ pdfi_close_file(ctx, XRefStrm);
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ return code;
+ }
+
+ if (start + end >= ctx->xref_table->xref_size) {
+ code = resize_xref(ctx, start + end);
+ if (code < 0) {
+ pdfi_countdown(a);
+ pdfi_close_file(ctx, XRefStrm);
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ return code;
+ }
+ }
+
+ code = read_xref_stream_entries(ctx, XRefStrm, start, start + end - 1, (uint64_t *)W);
+ if (code < 0) {
+ pdfi_countdown(a);
+ pdfi_close_file(ctx, XRefStrm);
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ return code;
+ }
+ }
+ }
+ pdfi_countdown(a);
+
+ pdfi_close_file(ctx, XRefStrm);
+
+ code = pdfi_dict_get_int(ctx, sdict, "Prev", &num);
+ if (code == gs_error_undefined)
+ return 0;
+
+ if (code < 0)
+ return code;
+
+ if (num < 0 || num > ctx->main_stream_length)
+ return_error(gs_error_rangecheck);
+
+ if (pdfi_loop_detector_check_object(ctx, num) == true)
+ return_error(gs_error_circular_reference);
+ else {
+ code = pdfi_loop_detector_add_object(ctx, num);
+ if (code < 0)
+ return code;
+ }
+
+ if(ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "%% Reading /Prev xref\n");
+
+ pdfi_seek(ctx, s, num, SEEK_SET);
+
+ code = pdfi_read_token(ctx, ctx->main_stream, 0, 0);
+ if (code < 0)
+ return code;
+
+ if (((pdf_obj *)ctx->stack_top[-1])->type == PDF_KEYWORD && ((pdf_keyword *)ctx->stack_top[-1])->key == TOKEN_XREF) {
+ /* Read old-style xref table */
+ pdfi_pop(ctx, 1);
+ return(read_xref(ctx, ctx->main_stream));
+ } else
+ code = pdfi_read_xref_stream_dict(ctx, s);
+
+ return code;
+}
+
+static int pdfi_read_xref_stream_dict(pdf_context *ctx, pdf_c_stream *s)
+{
+ int code;
+
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "\n%% Reading PDF 1.5+ xref stream\n");
+
+ if (((pdf_obj *)ctx->stack_top[-1])->type == PDF_INT) {
+ /* Its an integer, lets try for index gen obj as a XRef stream */
+ code = pdfi_read_token(ctx, ctx->main_stream, 0, 0);
+
+ if (code < 0)
+ return(pdfi_repair_file(ctx));
+
+ if (((pdf_obj *)ctx->stack_top[-1])->type != PDF_INT) {
+ /* Second element is not an integer, not a valid xref */
+ pdfi_pop(ctx, 1);
+ return(pdfi_repair_file(ctx));
+ }
+
+ code = pdfi_read_token(ctx, ctx->main_stream, 0, 0);
+ if (code < 0) {
+ pdfi_pop(ctx, 1);
+ return code;
+ }
+
+ if (((pdf_obj *)ctx->stack_top[-1])->type != PDF_KEYWORD) {
+ /* Second element is not an integer, not a valid xref */
+ pdfi_pop(ctx, 2);
+ return(pdfi_repair_file(ctx));
+ } else {
+ int obj_num, gen_num;
+
+ pdf_keyword *keyword = (pdf_keyword *)ctx->stack_top[-1];
+
+ if (keyword->key != TOKEN_OBJ) {
+ pdfi_pop(ctx, 3);
+ return(pdfi_repair_file(ctx));
+ }
+ /* pop the 'obj', generation and object numbers */
+ pdfi_pop(ctx, 1);
+ gen_num = ((pdf_num *)ctx->stack_top[-1])->value.i;
+ pdfi_pop(ctx, 1);
+ obj_num = ((pdf_num *)ctx->stack_top[-1])->value.i;
+ pdfi_pop(ctx, 1);
+
+ do {
+ code = pdfi_read_token(ctx, ctx->main_stream, obj_num, gen_num);
+ if (code < 0)
+ return pdfi_repair_file(ctx);
+
+ if (((pdf_obj *)ctx->stack_top[-1])->type == PDF_KEYWORD) {
+ keyword = (pdf_keyword *)ctx->stack_top[-1];
+ if (keyword->key == TOKEN_STREAM) {
+ pdf_dict *dict;
+ pdf_stream *sdict = NULL;
+ int64_t Length;
+
+ /* Remove the 'stream' token from the stack, should leave a dictionary object on the stack */
+ pdfi_pop(ctx, 1);
+ if (((pdf_obj *)ctx->stack_top[-1])->type != PDF_DICT) {
+ pdfi_pop(ctx, 1);
+ return pdfi_repair_file(ctx);
+ }
+ dict = (pdf_dict *)ctx->stack_top[-1];
+
+ /* Convert the dict into a stream (sdict comes back with at least one ref) */
+ code = pdfi_obj_dict_to_stream(ctx, dict, &sdict, true);
+ if (code < 0) {
+ pdfi_pop(ctx, 1);
+ /* TODO: should I return code instead of trying to repair?
+ * Normally the above routine should not fail so something is
+ * probably seriously fubar.
+ */
+ return pdfi_repair_file(ctx);
+ }
+ /* Pop off the dict */
+ pdfi_pop(ctx, 1);
+ dict = NULL;
+
+ /* Init the stuff for the stream */
+ sdict->stream_offset = pdfi_unread_tell(ctx);
+ sdict->object_num = obj_num;
+ sdict->generation_num = gen_num;
+
+ code = pdfi_dict_get_int(ctx, sdict->stream_dict, "Length", &Length);
+ if (code < 0) {
+ /* TODO: Not positive this will actually have a length -- just use 0 */
+ char extra_info[gp_file_name_sizeof];
+
+ gs_sprintf(extra_info, "Xref Stream object %u missing mandatory keyword /Length\n", obj_num);
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADSTREAM, "pdfi_read_xref_stream_dict", extra_info);
+ code = 0;
+ Length = 0;
+ }
+ sdict->Length = Length;
+ sdict->length_valid = true;
+
+ code = pdfi_process_xref_stream(ctx, sdict, ctx->main_stream);
+ if (code < 0) {
+ pdfi_countdown(sdict);
+ return (pdfi_repair_file(ctx));
+ }
+ pdfi_countdown(sdict);
+ break;
+ }
+ if (keyword->key == TOKEN_ENDOBJ) {
+ /* Something went wrong, this is not a stream dictionary */
+ pdfi_pop(ctx, 3);
+ return(pdfi_repair_file(ctx));
+ break;
+ }
+ }
+ } while(1);
+ }
+ } else {
+ /* Not an 'xref' and not an integer, so not a valid xref */
+ return(pdfi_repair_file(ctx));
+ }
+ return 0;
+}
+
+static int skip_to_digit(pdf_context *ctx, pdf_c_stream *s, unsigned int limit)
+{
+ byte c;
+ int bytes, read = 0;
+
+ do {
+ bytes = pdfi_read_bytes(ctx, &c, 1, 1, s);
+ if (bytes == 0)
+ return_error(gs_error_ioerror);
+ if (c >= 0x30 && c <= 0x39) {
+ pdfi_unread(ctx, s, &c, 1);
+ break;
+ }
+ read += bytes;
+ }while (read < limit);
+ return read;
+}
+
+static int read_digits(pdf_context *ctx, pdf_c_stream *s, byte *Buffer, unsigned int limit)
+{
+ int bytes, read = 0;
+
+ do {
+ bytes = pdfi_read_bytes(ctx, &Buffer[read], 1, 1, s);
+ if (bytes == 0)
+ return_error(gs_error_ioerror);
+ if (Buffer[read] < 0x30 || Buffer[read] > 0x39) {
+ pdfi_unread(ctx, s, &Buffer[read], 1);
+ break;
+ }
+ read += bytes;
+ }while (read < limit);
+ return read;
+}
+
+
+static int read_xref_entry_slow(pdf_context *ctx, pdf_c_stream *s, gs_offset_t *offset, uint32_t *generation_num, unsigned char *free)
+{
+ byte Buffer[20];
+ int code, read = 0, bytes;
+
+ memset(Buffer, 0x00, 20);
+ /* First off, find a number. If we don't find one, and read 20 bytes, throw an error */
+ code = skip_to_digit(ctx, s, 20);
+ if (code < 0)
+ return code;
+ read += code;
+
+ /* Now read a number */
+ code = read_digits(ctx, s, (byte *)&Buffer, (read > 10 ? 20 - read : 10));
+ if (code < 0)
+ return code;
+ Buffer[code] = 0x00;
+ read += code;
+
+ *offset = atol((const char *)Buffer);
+
+ /* find next number */
+ code = skip_to_digit(ctx, s, 20 - read);
+ if (code < 0)
+ return code;
+ read += code;
+
+ /* and read it */
+ code = read_digits(ctx, s, (byte *)&Buffer, (read > 15 ? 20 - read : 5));
+ if (code < 0)
+ return code;
+ Buffer[code] = 0x00;
+ read += code;
+
+ *generation_num = atol((const char *)Buffer);
+
+ do {
+ bytes = pdfi_read_bytes(ctx, &Buffer[0], 1, 1, s);
+ if (bytes == 0)
+ return_error(gs_error_ioerror);
+ read += bytes;
+ if (Buffer[0] == 0x09 || Buffer[0] == 0x20)
+ continue;
+ if (Buffer[0] == 'n' || Buffer[0] == 'f') {
+ *free = Buffer[0];
+ break;
+ } else {
+ return_error(gs_error_syntaxerror);
+ }
+ } while (read < 20);
+ if (read >= 20)
+ return_error(gs_error_syntaxerror);
+
+ do {
+ bytes = pdfi_read_bytes(ctx, &Buffer[0], 1, 1, s);
+ read += bytes;
+ if (Buffer[0] == 0x20 || Buffer[0] == 0x09 || Buffer[0] == 0x0d || Buffer[0] == 0x0a)
+ continue;
+ } while (read < 20);
+ return 0;
+}
+
+static int write_offset(byte *B, gs_offset_t o, unsigned int g, unsigned char free)
+{
+ byte b[20], *ptr = B;
+ int index = 0;
+
+ gs_sprintf((char *)b, "%"PRId64"", o);
+ if (strlen((const char *)b) > 10)
+ return_error(gs_error_rangecheck);
+ for(index=0;index < 10 - strlen((const char *)b); index++) {
+ *ptr++ = 0x30;
+ }
+ memcpy(ptr, b, strlen((const char *)b));
+ ptr += strlen((const char *)b);
+ *ptr++ = 0x20;
+
+ gs_sprintf((char *)b, "%d", g);
+ if (strlen((const char *)b) > 5)
+ return_error(gs_error_rangecheck);
+ for(index=0;index < 5 - strlen((const char *)b);index++) {
+ *ptr++ = 0x30;
+ }
+ memcpy(ptr, b, strlen((const char *)b));
+ ptr += strlen((const char *)b);
+ *ptr++ = 0x20;
+ *ptr++ = free;
+ *ptr++ = 0x20;
+ *ptr++ = 0x0d;
+ return 0;
+}
+
+static int read_xref_section(pdf_context *ctx, pdf_c_stream *s, uint64_t *section_start, uint64_t *section_size)
+{
+ int code = 0, i, j;
+ pdf_obj *o = NULL;
+ uint64_t start = 0, size = 0;
+ int64_t bytes = 0;
+ char Buffer[21];
+
+ *section_start = *section_size = 0;
+
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "\n%% Reading xref section\n");
+
+ code = pdfi_read_token(ctx, ctx->main_stream, 0, 0);
+
+ if (code < 0)
+ return code;
+
+ if (pdfi_count_stack(ctx) < 1)
+ return_error(gs_error_stackunderflow);
+
+ o = ctx->stack_top[-1];
+ if (o->type == PDF_KEYWORD)
+ return 0;
+
+ if (o->type != PDF_INT) {
+ /* element is not an integer, not a valid xref */
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_typecheck);
+ }
+
+ *section_start = start = ((pdf_num *)o)->value.i;
+
+ code = pdfi_read_token(ctx, ctx->main_stream, 0, 0);
+ if (code < 0) {
+ pdfi_pop(ctx, 1);
+ return code;
+ }
+
+ o = ctx->stack_top[-1];
+ if (o->type != PDF_INT) {
+ /* element is not an integer, not a valid xref */
+ pdfi_pop(ctx, 2);
+ return_error(gs_error_typecheck);
+ }
+ *section_size = size = ((pdf_num *)o)->value.i;
+ pdfi_pop(ctx, 2);
+
+ if (ctx->args.pdfdebug)
+ dmprintf2(ctx->memory, "\n%% Section starts at %d and has %d entries\n", (unsigned int) start, (unsigned int)size);
+
+ if (size > 0) {
+ if (ctx->xref_table == NULL) {
+ ctx->xref_table = (xref_table_t *)gs_alloc_bytes(ctx->memory, sizeof(xref_table_t), "read_xref_stream allocate xref table");
+ if (ctx->xref_table == NULL)
+ return_error(gs_error_VMerror);
+ memset(ctx->xref_table, 0x00, sizeof(xref_table_t));
+
+ ctx->xref_table->xref = (xref_entry *)gs_alloc_bytes(ctx->memory, (start + size) * sizeof(xref_entry), "read_xref_stream allocate xref table entries");
+ if (ctx->xref_table->xref == NULL){
+ gs_free_object(ctx->memory, ctx->xref_table, "free xref table on error allocating entries");
+ ctx->xref_table = NULL;
+ return_error(gs_error_VMerror);
+ }
+#if REFCNT_DEBUG
+ ctx->xref_table->UID = ctx->UID++;
+ dmprintf1(ctx->memory, "Allocated xref table with UID %"PRIi64"\n", ctx->xref_table->UID);
+#endif
+
+ memset(ctx->xref_table->xref, 0x00, (start + size) * sizeof(xref_entry));
+ ctx->xref_table->ctx = ctx;
+ ctx->xref_table->type = PDF_XREF_TABLE;
+ ctx->xref_table->xref_size = start + size;
+ pdfi_countup(ctx->xref_table);
+ } else {
+ if (start + size > ctx->xref_table->xref_size) {
+ code = resize_xref(ctx, start + size);
+ if (code < 0)
+ return code;
+ }
+ }
+ }
+
+ pdfi_skip_white(ctx, s);
+ for (i=0;i< size;i++){
+ xref_entry *entry = &ctx->xref_table->xref[i + start];
+ unsigned char free;
+ gs_offset_t off;
+ unsigned int gen;
+
+ bytes = pdfi_read_bytes(ctx, (byte *)Buffer, 1, 20, s);
+ if (bytes < 20)
+ return_error(gs_error_ioerror);
+ j = 19;
+ while (Buffer[j] != 0x0D && Buffer[j] != 0x0A) {
+ pdfi_unread(ctx, s, (byte *)&Buffer[j], 1);
+ if (--j < 0) {
+ dmprintf(ctx->memory, "Invalid xref entry, line terminator missing.\n");
+ code = read_xref_entry_slow(ctx, s, &off, &gen, &free);
+ if (code < 0)
+ return code;
+ code = write_offset((byte *)Buffer, off, gen, free);
+ if (code < 0)
+ return code;
+ break;
+ }
+ }
+ Buffer[j] = 0x00;
+ if (entry->object_num != 0)
+ continue;
+
+ if (sscanf(Buffer, "%ld %d %c", &entry->u.uncompressed.offset, &entry->u.uncompressed.generation_num, &free) != 3) {
+ dmprintf(ctx->memory, "Invalid xref entry, incorrect format.\n");
+ pdfi_unread(ctx, s, (byte *)Buffer, 20);
+ code = read_xref_entry_slow(ctx, s, &off, &gen, &free);
+ if (code < 0)
+ return code;
+ code = write_offset((byte *)Buffer, off, gen, free);
+ if (code < 0)
+ return code;
+ }
+
+ entry->compressed = false;
+ entry->object_num = i + start;
+ if (free == 'f')
+ entry->free = true;
+ if(free == 'n')
+ entry->free = false;
+ }
+
+ return 0;
+}
+
+static int read_xref(pdf_context *ctx, pdf_c_stream *s)
+{
+ int code = 0;
+ pdf_obj **o = NULL;
+ pdf_keyword *k;
+ pdf_dict *d = NULL;
+ uint64_t size = 0, max_obj = 0;
+ int64_t num;
+
+ do {
+ uint64_t section_start, section_size;
+
+ o = ctx->stack_top;
+ code = read_xref_section(ctx, s, &section_start, &section_size);
+ if (code < 0)
+ return code;
+
+ if (section_start + section_size > max_obj)
+ max_obj = section_start + section_size;
+
+ if (ctx->stack_top - o > 0) {
+ k = (pdf_keyword *)ctx->stack_top[-1];
+ if(k->type != PDF_KEYWORD || k->key != TOKEN_TRAILER)
+ return_error(gs_error_syntaxerror);
+ else {
+ pdfi_pop(ctx, 1);
+ break;
+ }
+ }
+ } while (1);
+
+ code = pdfi_read_dict(ctx, ctx->main_stream, 0, 0);
+ if (code < 0)
+ return code;
+
+ d = (pdf_dict *)ctx->stack_top[-1];
+ if (d->type != PDF_DICT) {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_typecheck);
+ }
+
+ if (ctx->Trailer == NULL) {
+ ctx->Trailer = d;
+ pdfi_countup(d);
+ } else {
+ code = pdfi_merge_dicts(ctx, ctx->Trailer, d);
+ if (code < 0) {
+ if (code == gs_error_VMerror || ctx->args.pdfstoponerror) {
+ pdfi_pop(ctx, 1);
+ return code;
+ }
+ }
+ }
+
+ /* We have the Trailer dictionary. First up check for hybrid files. These have the initial
+ * xref starting at 0 and size of 0. In this case the /Size entry in the trailer dictionary
+ * must tell us how large the xref is, and we need to allocate our xref table anyway.
+ */
+ if (ctx->xref_table == NULL && size == 0) {
+ int64_t size;
+
+ code = pdfi_dict_get_int(ctx, d, "Size", &size);
+ if (code < 0) {
+ pdfi_pop(ctx, 1);
+ return code;
+ }
+ if (size < 0) {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_rangecheck);
+ }
+
+ ctx->xref_table = (xref_table_t *)gs_alloc_bytes(ctx->memory, sizeof(xref_table_t), "read_xref_stream allocate xref table");
+ if (ctx->xref_table == NULL) {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_VMerror);
+ }
+ memset(ctx->xref_table, 0x00, sizeof(xref_table_t));
+#if REFCNT_DEBUG
+ ctx->xref_table->UID = ctx->UID++;
+ dmprintf1(ctx->memory, "Allocated xref table with UID %"PRIi64"\n", ctx->xref_table->UID);
+#endif
+
+ ctx->xref_table->xref = (xref_entry *)gs_alloc_bytes(ctx->memory, size * sizeof(xref_entry), "read_xref_stream allocate xref table entries");
+ if (ctx->xref_table->xref == NULL){
+ pdfi_pop(ctx, 1);
+ pdfi_countdown(ctx->xref_table);
+ ctx->xref_table = NULL;
+ return_error(gs_error_VMerror);
+ }
+
+ memset(ctx->xref_table->xref, 0x00, size * sizeof(xref_entry));
+ ctx->xref_table->ctx = ctx;
+ ctx->xref_table->type = PDF_XREF_TABLE;
+ ctx->xref_table->xref_size = size;
+ pdfi_countup(ctx->xref_table);
+ }
+
+ /* Now check if this is a hybrid file. */
+ if (ctx->Trailer == d) {
+ code = pdfi_dict_get_int(ctx, d, "XRefStm", &num);
+ if (code < 0 && code != gs_error_undefined) {
+ pdfi_pop(ctx, 1);
+ return code;
+ }
+ if (code == 0)
+ ctx->is_hybrid = true;
+ } else
+ code = gs_error_undefined;
+
+ if (code == 0 && ctx->prefer_xrefstm) {
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "%% File is a hybrid, containing xref table and xref stream. Using the stream.\n");
+
+
+ if (pdfi_loop_detector_check_object(ctx, num) == true) {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_circular_reference);
+ }
+ else {
+ code = pdfi_loop_detector_add_object(ctx, num);
+ if (code < 0) {
+ pdfi_pop(ctx, 1);
+ return code;
+ }
+ }
+
+ pdfi_loop_detector_mark(ctx);
+ /* Because of the way the code works when we read a file which is a pure
+ * xref stream file, we need to read the first integer of 'x y obj'
+ * because the xref stream decoding code expects that to be on the stack.
+ */
+ pdfi_seek(ctx, s, num, SEEK_SET);
+
+ code = pdfi_read_token(ctx, ctx->main_stream, 0, 0);
+ if (code < 0) {
+ pdfi_loop_detector_cleartomark(ctx);
+ pdfi_pop(ctx, 1);
+ return code;
+ }
+
+ code = pdfi_read_xref_stream_dict(ctx, ctx->main_stream);
+ if (code < 0) {
+ pdfi_loop_detector_cleartomark(ctx);
+ pdfi_pop(ctx, 1);
+ return code;
+ }
+
+ pdfi_loop_detector_cleartomark(ctx);
+ }
+
+ /* Not a hybrid file, so now check if this is a modified file and has
+ * previous xref entries.
+ */
+ /* But first, check if the highest subsection + size exceeds the /Size in the
+ * trailer dictionary and set a warning flag if it does
+ */
+ code = pdfi_dict_get_int(ctx, d, "Size", &num);
+ if (code < 0) {
+ pdfi_pop(ctx, 1);
+ return code;
+ }
+ if (max_obj > num)
+ pdfi_set_warning(ctx, 0, NULL, W_PDF_BAD_XREF_SIZE, "read_xref", NULL);
+
+ code = pdfi_dict_get_int(ctx, d, "Prev", &num);
+ if (code < 0) {
+ pdfi_pop(ctx, 1);
+ if (code == gs_error_undefined)
+ return 0;
+ else
+ return code;
+ }
+ pdfi_pop(ctx, 1);
+
+ if (num < 0 || num > ctx->main_stream_length)
+ return_error(gs_error_rangecheck);
+
+ if (pdfi_loop_detector_check_object(ctx, num) == true)
+ return_error(gs_error_circular_reference);
+ else {
+ code = pdfi_loop_detector_add_object(ctx, num);
+ if (code < 0)
+ return code;
+ }
+
+ code = pdfi_seek(ctx, s, num, SEEK_SET);
+ if (code < 0)
+ return code;
+
+ code = pdfi_read_token(ctx, ctx->main_stream, 0, 0);
+ if (code < 0)
+ return(code);
+
+ if (((pdf_obj *)ctx->stack_top[-1])->type == PDF_KEYWORD && ((pdf_keyword *)ctx->stack_top[-1])->key == TOKEN_XREF) {
+ /* Read old-style xref table */
+ pdfi_pop(ctx, 1);
+ return(read_xref(ctx, ctx->main_stream));
+ } else {
+ pdfi_pop(ctx, 1);
+ return_error(gs_error_typecheck);
+ }
+}
+
+int pdfi_read_xref(pdf_context *ctx)
+{
+ int code = 0;
+ bool do_repair = false;
+
+ code = pdfi_loop_detector_mark(ctx);
+ if (code < 0)
+ return code;
+
+ if (ctx->startxref != 0) {
+ code = pdfi_loop_detector_add_object(ctx, ctx->startxref);
+ if (code < 0)
+ goto exit;
+
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "%% Trying to read 'xref' token for xref table, or 'int int obj' for an xref stream\n");
+
+ if (ctx->startxref > ctx->main_stream_length - 5) {
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADSTARTXREF, "pdfi_read_xref", (char *)"startxref offset is beyond end of file");
+ do_repair = true;
+ goto exit;
+ }
+
+
+ /* Read the xref(s) */
+ pdfi_seek(ctx, ctx->main_stream, ctx->startxref, SEEK_SET);
+
+ code = pdfi_read_token(ctx, ctx->main_stream, 0, 0);
+ if (code < 0) {
+ pdfi_set_error(ctx, 0, NULL, E_PDF_BADSTARTXREF, "pdfi_read_xref", (char *)"Failed to read any token at the startxref location");
+ do_repair = true;
+ goto exit;
+ }
+
+ if (pdfi_count_stack(ctx) < 1) {
+ code = gs_note_error(gs_error_undefined);
+ goto exit;
+ }
+
+ if (((pdf_obj *)ctx->stack_top[-1])->type == PDF_KEYWORD && ((pdf_keyword *)ctx->stack_top[-1])->key == TOKEN_XREF) {
+ /* Read old-style xref table */
+ pdfi_pop(ctx, 1);
+ code = read_xref(ctx, ctx->main_stream);
+ if (code < 0) {
+ do_repair = true;
+ goto exit;
+ }
+ } else {
+ code = pdfi_read_xref_stream_dict(ctx, ctx->main_stream);
+ if (code < 0){
+ do_repair = true;
+ goto exit;
+ }
+ }
+ } else {
+ /* Attempt to repair PDF file */
+ do_repair = true;
+ goto exit;
+ }
+
+ if(ctx->args.pdfdebug && ctx->xref_table) {
+ int i, j;
+ xref_entry *entry;
+ char Buffer[32];
+
+ dmprintf(ctx->memory, "\n%% Dumping xref table\n");
+ for (i=0;i < ctx->xref_table->xref_size;i++) {
+ entry = &ctx->xref_table->xref[i];
+ if(entry->compressed) {
+ dmprintf(ctx->memory, "*");
+ gs_sprintf(Buffer, "%ld", entry->object_num);
+ j = 10 - strlen(Buffer);
+ while(j--) {
+ dmprintf(ctx->memory, " ");
+ }
+ dmprintf1(ctx->memory, "%s ", Buffer);
+
+ gs_sprintf(Buffer, "%ld", entry->u.compressed.compressed_stream_num);
+ j = 10 - strlen(Buffer);
+ while(j--) {
+ dmprintf(ctx->memory, " ");
+ }
+ dmprintf1(ctx->memory, "%s ", Buffer);
+
+ gs_sprintf(Buffer, "%ld", entry->u.compressed.object_index);
+ j = 10 - strlen(Buffer);
+ while(j--) {
+ dmprintf(ctx->memory, " ");
+ }
+ dmprintf1(ctx->memory, "%s ", Buffer);
+ }
+ else {
+ dmprintf(ctx->memory, " ");
+
+ gs_sprintf(Buffer, "%ld", entry->object_num);
+ j = 10 - strlen(Buffer);
+ while(j--) {
+ dmprintf(ctx->memory, " ");
+ }
+ dmprintf1(ctx->memory, "%s ", Buffer);
+
+ gs_sprintf(Buffer, "%ld", entry->u.uncompressed.offset);
+ j = 10 - strlen(Buffer);
+ while(j--) {
+ dmprintf(ctx->memory, " ");
+ }
+ dmprintf1(ctx->memory, "%s ", Buffer);
+
+ gs_sprintf(Buffer, "%ld", entry->u.uncompressed.generation_num);
+ j = 10 - strlen(Buffer);
+ while(j--) {
+ dmprintf(ctx->memory, " ");
+ }
+ dmprintf1(ctx->memory, "%s ", Buffer);
+ }
+ if (entry->free)
+ dmprintf(ctx->memory, "f\n");
+ else
+ dmprintf(ctx->memory, "n\n");
+ }
+ }
+ if (ctx->args.pdfdebug)
+ dmprintf(ctx->memory, "\n");
+
+ exit:
+ (void)pdfi_loop_detector_cleartomark(ctx);
+ if (do_repair)
+ return(pdfi_repair_file(ctx));
+
+ if (code < 0)
+ return code;
+
+ return 0;
+}
diff --git a/pdf/pdf_xref.h b/pdf/pdf_xref.h
new file mode 100644
index 00000000..6e42fa69
--- /dev/null
+++ b/pdf/pdf_xref.h
@@ -0,0 +1,22 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* xref parsing */
+#ifndef PDF_XREF_PARSER
+#define PDF_XREF_PARSER
+
+int pdfi_read_xref(pdf_context *ctx);
+
+#endif
diff --git a/pdf/pdfromfs.mak b/pdf/pdfromfs.mak
new file mode 100644
index 00000000..bc01a590
--- /dev/null
+++ b/pdf/pdfromfs.mak
@@ -0,0 +1,23 @@
+# Copyright (C) 2018-2021 Artifex Software, Inc.
+# All Rights Reserved.
+#
+# This software is provided AS-IS with no warranty, either express or
+# implied.
+#
+# This software is distributed under license and may not be copied,
+# modified or distributed except as expressly authorized under the terms
+# of the license contained in the file LICENSE in this distribution.
+#
+# Refer to licensing information at http://www.artifex.com or contact
+# Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+# CA 94945, U.S.A., +1(415)492-9861, for further information.
+#
+# This needs a file on its own due to the required include ordering
+# in the top level makefiles. Being empty, it's here purely for symmetry
+
+PDF_FONT_ROMFS_ARGS=
+
+# The -C turns "compaction" on, -B off. For debugging convenience
+# it's off just now.
+# PDF_ROMFS_ARGS=-d Resource/ -P $(PSRESDIR)$(D) -C CMap$(D)*
+PDF_ROMFS_ARGS=-d Resource/ -P $(PSRESDIR)$(D) -C CMap$(D)* -B Font$(D)* CIDFSubst$(D)* -C Init$(D)Fontmap.GS
diff --git a/pdf/pdftop.c b/pdf/pdftop.c
new file mode 100644
index 00000000..6dbe1817
--- /dev/null
+++ b/pdf/pdftop.c
@@ -0,0 +1,867 @@
+/* Copyright (C) 2018-2021 Artifex Software, Inc.
+ All Rights Reserved.
+
+ This software is provided AS-IS with no warranty, either express or
+ implied.
+
+ This software is distributed under license and may not be copied,
+ modified or distributed except as expressly authorized under the terms
+ of the license contained in the file LICENSE in this distribution.
+
+ Refer to licensing information at http://www.artifex.com or contact
+ Artifex Software, Inc., 1305 Grant Avenue - Suite 200, Novato,
+ CA 94945, U.S.A., +1(415)492-9861, for further information.
+*/
+
+/* Top-level API implementation of PDF */
+
+/* Language wrapper implementation (see pltop.h) */
+
+#include "ghostpdf.h"
+
+#include "pltop.h"
+#include "plmain.h"
+
+#include "plparse.h" /* for e_ExitLanguage */
+#include "gxdevice.h" /* so we can include gxht.h below */
+#include "gxht.h" /* gsht1.h is incomplete, we need storage size of gs_halftone */
+#include "gsht1.h"
+#include "pdf_device.h"
+#include "pdf_misc.h"
+
+#include "gsstate.h" /* For gs_sethalftonephase() */
+#include "gspaint.h" /* For gs_erasepage() */
+#include "gscolor3.h" /* For gs_setsmoothness() */
+
+extern const char gp_file_name_list_separator;
+
+static int pdfi_install_halftone(pdf_context *ctx, gx_device *pdevice);
+static int pdf_impl_add_path(pl_interp_implementation_t *impl, const char *path);
+
+/*
+ * The PDF interpreter instance is derived from pl_interp_implementation_t.
+ */
+
+typedef struct pdf_interp_instance_s
+{
+ gs_memory_t *memory; /* memory allocator to use */
+
+ pdf_context *ctx;
+ gp_file *scratch_file;
+ char scratch_name[gp_file_name_sizeof];
+}pdf_interp_instance_t;
+
+extern const char gp_file_name_list_separator;
+
+#define _PDFI_STRING_IT(s) #s
+#define PDFI_STRING_IT(s) _PDFI_STRING_IT(s)
+#define GS_LIB_DEFAULT_STRING PDFI_STRING_IT(GS_LIB_DEFAULT)
+
+static int
+pdf_detect_language(const char *s, int len)
+{
+ if (len < 5)
+ return 1;
+ return memcmp(s, "%!PDF", 2);
+}
+
+static const pl_interp_characteristics_t *
+pdf_impl_characteristics(const pl_interp_implementation_t *pimpl)
+{
+ static pl_interp_characteristics_t pdf_characteristics =
+ {
+ "PDF",
+ pdf_detect_language,
+ };
+ return &pdf_characteristics;
+}
+
+#if 0 /* the following are not currently used */
+static void
+pdf_set_nocache(pl_interp_implementation_t *impl, gs_font_dir *font_dir)
+{
+ bool nocache;
+ pdf_interp_instance_t *pdfi = impl->interp_client_data;
+ nocache = pl_main_get_nocache(pdfi->memory);
+ if (nocache)
+ gs_setcachelimit(font_dir, 0);
+ return;
+}
+
+
+static int
+pdf_set_icc_user_params(pl_interp_implementation_t *impl, gs_gstate *pgs)
+{
+ pdf_interp_instance_t *pdfi = impl->interp_client_data;
+ return pl_set_icc_params(pdfi->memory, pgs);
+}
+
+#endif
+
+static int
+pdf_impl_finish_page(pdf_context *ctx)
+{
+ return pl_finish_page(ctx->memory->gs_lib_ctx->top_of_system, ctx->pgs, 1, true);
+}
+
+/* Do per-instance interpreter allocation/init. No device is set yet */
+static int
+pdf_impl_allocate_interp_instance(pl_interp_implementation_t *impl,
+ gs_memory_t *pmem)
+{
+ pdf_interp_instance_t *instance;
+ pdf_context *ctx;
+ int code;
+ const char *rompathstr = "%rom%Resource/Init";
+ const char *deflibstr = GS_LIB_DEFAULT_STRING;
+ char *newpathsstr = (char *)deflibstr;
+
+ instance = (pdf_interp_instance_t *) gs_alloc_bytes(pmem,
+ sizeof(pdf_interp_instance_t), "pdf_impl_allocate_interp_instance");
+
+ if (!instance)
+ return gs_error_VMerror;
+
+ ctx = pdfi_create_context(pmem);
+
+ if (ctx == NULL) {
+ gs_free_object(pmem, instance, "pdf_impl_allocate_interp_instance");
+ return gs_error_VMerror;
+ }
+
+ ctx->finish_page = pdf_impl_finish_page;
+
+ ctx->instance = instance;
+ instance->ctx = ctx;
+ instance->scratch_file = NULL;
+ instance->scratch_name[0] = 0;
+ instance->memory = pmem;
+
+ impl->interp_client_data = instance;
+ if (COMPILE_INITS == 1) {
+ newpathsstr = (char *)gs_alloc_bytes(ctx->memory, strlen(rompathstr) + strlen(GS_LIB_DEFAULT_STRING) + 2, "temp paths string");
+ if (newpathsstr == NULL) {
+ newpathsstr = (char *)rompathstr;
+ }
+ else {
+ char sepstr[2];
+
+ sepstr[0] = gp_file_name_list_separator;
+ sepstr[1] = '\0';
+
+ memcpy(newpathsstr, rompathstr, strlen(rompathstr) + 1);
+ strncat(newpathsstr, sepstr, strlen(sepstr));
+ strncat(newpathsstr, GS_LIB_DEFAULT_STRING, strlen(GS_LIB_DEFAULT_STRING));
+ }
+ }
+
+ code = pdfi_add_initial_paths_to_search_paths(ctx, newpathsstr, strlen(newpathsstr));
+ if (newpathsstr != deflibstr && newpathsstr != rompathstr) {
+ gs_free_object(ctx->memory, newpathsstr, "temp paths string");
+ }
+ return code;
+}
+
+static int
+pdf_impl_set_device(pl_interp_implementation_t *impl, gx_device *pdevice)
+{
+ pdf_interp_instance_t *instance = impl->interp_client_data;
+ pdf_context *ctx = instance->ctx;
+ int code;
+
+#if 0
+ gx_device_fill_in_procs(pmi->device);
+ code = gs_opendevice(pdevice);
+ if (code < 0)
+ goto cleanup_setdevice;
+#endif
+
+ /* gsave and grestore (among other places) assume that */
+ /* there are at least 2 gstates on the graphics stack. */
+ /* Ensure that now. */
+ code = gs_gsave(ctx->pgs);
+ if (code < 0)
+ goto cleanup_gsave;
+
+ code = gs_setdevice_no_erase(ctx->pgs, pdevice);
+ if (code < 0)
+ goto cleanup_setdevice;
+
+ /* TODO: See stuff with init_graphics in pdfi_page_render -- I think this
+ * should be collected in one place?
+ * This is essentially doing it one time, and the other is doing it per page.
+ * The main thing seems to be doing it here is before the pdfwrite device
+ * gets setup, and doing it in pdf_page.c is after the pdfwrite device gets
+ * setup. It can cause spurious 'gs' state entries if there are discrepencies.
+ */
+ /* Doing this here to avoid having a ".02 /SM" entry showing up in ExtGState
+ * of pdfwrite output.
+ */
+ code = gs_setsmoothness(ctx->pgs, 0.02); /* Match gs code */
+
+ /* NOTE: Not sure what this is or when it matters, but it should match gs, which sets it to true */
+ /* TODO: Commented out because it caused a seemingly random incorrect pdfwrite output.
+ * Will try putting it back in when pdfwrite is more stable.
+ */
+ //gs_setlimitclamp(ctx->pgs, true); /* Match gs code */
+
+ /* We need to setup strokeadjust the same way gs does, which is currently based on
+ * the device resolution and the DITHERPPI arg.
+ *
+ * TODO: Ken thinks 150 dpi is too low for the cutoff, but if so it should
+ * change in both gs and here, so they match. See gs_init.ps/.useloresscreen
+ *
+ * TODO: Currently pdfi-in-gs is not inheriting the graphics state from gs, so it
+ * will have the wrong setting at 300dpi. That needs to be fixed.
+ * (but pdfi-in-gs never actually calls this function, it is supposed to inherit
+ * the device and graphics state from gs. Remove this comment when that is fixed :)
+ */
+ if (pdevice->HWResolution[0] >= 150 || pdevice->HWResolution[1] >= 150 || ctx->args.ditherppi) {
+ /* false for "high resolution" devices */
+ gs_setstrokeadjust(ctx->pgs, false);
+ } else {
+ /* true for "low resolution" devices */
+ gs_setstrokeadjust(ctx->pgs, true);
+ }
+
+ gs_setscanconverter(ctx->pgs, pl_main_get_scanconverter(ctx->memory));
+
+ code = gs_erasepage(ctx->pgs);
+ if (code < 0)
+ goto cleanup_erase;
+
+ code = pdfi_install_halftone(ctx, pdevice);
+ if (code < 0)
+ goto cleanup_halftone;
+
+ /* TODO: Hack to do what is in the bottom of gs_pdfwr.ps
+ * This basically causes the pdfwrite device to be initialized.
+ * Not sure if this is the correct place to do this.
+ * Note that if running gs/pdfi, it will happen in the gs interpreter.
+ * Putting it here means it only runs in gpdf, which seems correct.
+ */
+ if (pdfi_device_check_param_exists(pdevice, "ForOPDFRead")) {
+ gs_newpath(ctx->pgs);
+ gs_fill(ctx->pgs);
+ }
+
+ ctx->job_gstate_level = ctx->pgs->level;
+ return 0;
+
+cleanup_halftone:
+cleanup_erase:
+ /* undo gsave */
+ gs_grestore_only(ctx->pgs); /* destroys gs_save stack */
+
+cleanup_gsave:
+ /* undo setdevice */
+ gs_nulldevice(ctx->pgs);
+
+cleanup_setdevice:
+ /* nothing to undo */
+ return code;
+}
+
+/* Parse an entire random access file */
+static int
+pdf_impl_process_file(pl_interp_implementation_t *impl, const char *filename)
+{
+ pdf_interp_instance_t *instance = impl->interp_client_data;
+ pdf_context *ctx = instance->ctx;
+ int code;
+
+ code = pdfi_process_pdf_file(ctx, (char *)filename);
+ if (code)
+ return code;
+
+ return 0;
+}
+
+static int
+pdf_impl_process_begin(pl_interp_implementation_t * impl)
+{
+ return 0;
+}
+
+/* Parse a cursor-full of data */
+static int
+pdf_impl_process(pl_interp_implementation_t *impl, stream_cursor_read *cursor)
+{
+ pdf_interp_instance_t *instance = impl->interp_client_data;
+ pdf_context *ctx = instance->ctx;
+ int avail, n;
+
+ if (!instance->scratch_file)
+ {
+ instance->scratch_file = gp_open_scratch_file(ctx->memory,
+ "ghostpdf-scratch-", instance->scratch_name, "wb");
+ if (!instance->scratch_file)
+ {
+ gs_catch(gs_error_invalidfileaccess, "cannot open scratch file");
+ return e_ExitLanguage;
+ }
+ if_debug1m('|', ctx->memory, "pdf: open scratch file '%s'\n", instance->scratch_name);
+ }
+
+ avail = cursor->limit - cursor->ptr;
+ n = gp_fwrite(cursor->ptr + 1, 1, avail, instance->scratch_file);
+ if (n != avail)
+ {
+ gs_catch(gs_error_invalidfileaccess, "cannot write to scratch file");
+ return e_ExitLanguage;
+ }
+ cursor->ptr = cursor->limit;
+
+ return 0;
+}
+
+static int /* ret 0 or +ve if ok, else -ve error code */
+pdf_impl_process_end(pl_interp_implementation_t * impl)
+{
+ return 0;
+}
+
+/* Skip to end of job.
+ * Return 1 if done, 0 ok but EOJ not found, else negative error code.
+ */
+static int
+pdf_impl_flush_to_eoj(pl_interp_implementation_t *impl, stream_cursor_read *pcursor)
+{
+ /* assume PDF cannot be pjl embedded */
+ pcursor->ptr = pcursor->limit;
+ return 0;
+}
+
+/* Parser action for end-of-file */
+static int
+pdf_impl_process_eof(pl_interp_implementation_t *impl)
+{
+ pdf_interp_instance_t *instance = impl->interp_client_data;
+ pdf_context *ctx = instance->ctx;
+ int code;
+
+ if (instance->scratch_file)
+ {
+ if_debug0m('|', ctx->memory, "pdf: executing scratch file\n");
+ gp_fclose(instance->scratch_file);
+ instance->scratch_file = NULL;
+ code = pdfi_process_pdf_file(ctx, instance->scratch_name);
+ unlink(instance->scratch_name);
+ if (code < 0)
+ {
+ gs_catch(code, "cannot process PDF file");
+ return e_ExitLanguage;
+ }
+ }
+
+ return 0;
+}
+
+/* Report any errors after running a job */
+static int
+pdf_impl_report_errors(pl_interp_implementation_t *impl,
+ int code, /* prev termination status */
+ long file_position, /* file position of error, -1 if unknown */
+ bool force_to_cout /* force errors to cout */
+ )
+{
+ return 0;
+}
+
+/*
+ * Get the allocator with which to allocate a device
+ */
+static gs_memory_t *
+pdf_impl_get_device_memory(pl_interp_implementation_t *impl)
+{
+ pdf_interp_instance_t *instance = impl->interp_client_data;
+ pdf_context *ctx = instance->ctx;
+
+ return ctx->memory;
+}
+
+static int plist_value_get_int64(gs_param_typed_value *pvalue, int64_t *pint)
+{
+ if (pvalue->type == gs_param_type_i64) {
+ *pint = pvalue->value.i64;
+ return 0;
+ }
+ return_error(gs_error_typecheck);
+}
+
+/* Get the value for a string or a name (null terminated) */
+static int plist_value_get_string_or_name(pdf_context *ctx, gs_param_typed_value *pvalue,
+ char **pstr, int *plen)
+{
+ const byte *data;
+ uint size;
+
+ if (pvalue->type == gs_param_type_string) {
+ data = pvalue->value.s.data;
+ size = pvalue->value.s.size;
+ } else if (pvalue->type == gs_param_type_name) {
+ data = pvalue->value.n.data;
+ size = pvalue->value.n.size;
+ } else {
+ return_error(gs_error_typecheck);
+ }
+
+ /* Free any previous value, for example if param appears more than once */
+ if (*pstr)
+ gs_free_object(ctx->memory, *pstr, "plist_value_get_string_or_name()");
+
+ *pstr = (char *)gs_alloc_bytes(ctx->memory, size + 1, "plist_value_get_string_or_name()");
+ if (*pstr == NULL)
+ return_error(gs_error_VMerror);
+
+ memcpy(*pstr, data, size);
+ *((*pstr)+size) = 0; /* Null terminate */
+ *plen = size;
+ return 0;
+}
+
+/* Get the value for a list of names as c-strings, (null terminated) */
+/* Format: -s/Item1,/Item2,/Item3 (no white space) */
+static int plist_value_get_namelist(pdf_context *ctx, gs_param_typed_value *pvalue,
+ char ***pstrlist)
+{
+ char *data;
+ uint size;
+
+ if (pvalue->type != gs_param_type_string)
+ return_error(gs_error_typecheck);
+
+ data = (char *)pvalue->value.s.data;
+ size = pvalue->value.s.size;
+
+ return pdfi_parse_name_cstring_array(ctx, data, size, pstrlist);
+}
+
+static int plist_value_get_int(gs_param_typed_value *pvalue, int *pint)
+{
+ if (pvalue->type == gs_param_type_int) {
+ *pint = (int64_t)pvalue->value.i;
+ return 0;
+ }
+ if (pvalue->type == gs_param_type_i64) {
+ int64_t i64;
+ int code;
+
+ code = plist_value_get_int64(pvalue, &i64);
+ if (code < 0)
+ return code;
+
+ if (i64 > ((int64_t)1 << 32))
+ return_error(gs_error_rangecheck);
+
+ *pint = (int)i64;
+ return 0;
+ }
+ return_error(gs_error_typecheck);
+}
+
+static int plist_value_get_bool(gs_param_typed_value *pvalue, bool *pbool)
+{
+ if (pvalue->type == gs_param_type_bool) {
+ *pbool = pvalue->value.b;
+ return 0;
+ }
+ return_error(gs_error_typecheck);
+}
+
+/* Get the Overprint value and translate it to a numeric value */
+static int
+pdfi_get_overprint_param(pdf_context *ctx, gs_param_typed_value *pvalue)
+{
+ char *val = NULL;
+ int len;
+ int code;
+
+ code = plist_value_get_string_or_name(ctx, pvalue, &val, &len);
+ if (code < 0)
+ return code;
+
+ ctx->args.overprint_control = PDF_OVERPRINT_ENABLE;
+ if (val != NULL && !strncmp(val, "disable", len)) {
+ ctx->args.overprint_control = PDF_OVERPRINT_DISABLE;
+ }
+ if (val != NULL && !strncmp(val, "simulate", len)) {
+ ctx->args.overprint_control = PDF_OVERPRINT_SIMULATE;
+ }
+
+ if (val)
+ gs_free_object(ctx->memory, val, "Transparency param");
+ return code;
+}
+
+static int
+pdf_impl_set_param(pl_interp_implementation_t *impl,
+ gs_param_list *plist)
+{
+ pdf_interp_instance_t *instance = impl->interp_client_data;
+ pdf_context *ctx = instance->ctx;
+ gs_param_enumerator_t enumerator;
+ gs_param_key_t key;
+ int code;
+ int len;
+
+ param_init_enumerator(&enumerator);
+ if ((code = param_get_next_key(plist, &enumerator, &key)) == 0) {
+ char param[256]; /* big enough for any reasonable key */
+ gs_param_typed_value pvalue;
+
+ if (key.size > sizeof(param) - 1) {
+ code = gs_note_error(gs_error_rangecheck);
+ goto exit;
+ }
+ memcpy(param, key.data, key.size);
+ param[key.size] = 0;
+ if ((code = param_read_typed(plist, param, &pvalue)) != 0) {
+ code = (code > 0 ? gs_note_error(gs_error_unknownerror) : code);
+ goto exit;
+ }
+
+ if (!strncmp(param, "QUIET", 5)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.QUIET);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "FirstPage", 9)) {
+ code = plist_value_get_int(&pvalue, &ctx->args.first_page);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "LastPage", 8)) {
+ code = plist_value_get_int(&pvalue, &ctx->args.last_page);
+ if (code < 0)
+ return code;
+ }
+ /* PDF interpreter flags */
+ if (!strncmp(param, "VerboseErrors", 13)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.verbose_errors);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "VerboseWarnings", 15)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.verbose_warnings);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "PDFDEBUG", 8)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.pdfdebug);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "PDFSTOPONERROR", 14)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.pdfstoponerror);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "PDFSTOPONWARNING", 16)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.pdfstoponwarning);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "NOTRANSPARENCY", 14)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.notransparency);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "NOCIDFALLBACK", 13)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.nocidfallback);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "NO_PDFMARK_OUTLINES", 19)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.no_pdfmark_outlines);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "NO_PDFMARK_DESTS", 16)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.no_pdfmark_dests);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "PDFFitPage", 10)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.pdffitpage);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "UseCropBox", 10)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.usecropbox);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "UseArtBox", 9)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.useartbox);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "UseBleedBox", 11)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.usebleedbox);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "UseTrimBox", 10)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.usetrimbox);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "Printed", 7)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.printed);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "DITHERPPI", 9)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.ditherppi);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "ShowAcroForm", 12)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.showacroform);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "ShowAnnots", 10)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.showannots);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "SHOWANNOTTYPES", 14)) {
+ code = plist_value_get_namelist(ctx, &pvalue, &ctx->args.showannottypes);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "PreserveAnnots", 14)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.preserveannots);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "PRESERVEANNOTTYPES", 18)) {
+ code = plist_value_get_namelist(ctx, &pvalue, &ctx->args.preserveannottypes);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "NoUserUnit", 10)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.nouserunit);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "RENDERTTNOTDEF", 13)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.renderttnotdef);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "PDFINFO", 7)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.pdfinfo);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "DOPDFMARKS", 10)) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.dopdfmarks);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "PDFPassword", 11)) {
+ code = plist_value_get_string_or_name(ctx, &pvalue, &ctx->encryption.Password , &ctx->encryption.PasswordLen);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "Overprint", 9)) {
+ code = pdfi_get_overprint_param(ctx, &pvalue);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "UsePDFX3Profile", strlen("UsePDFX3Profile"))) {
+ /* This is a weird one because it can be either a bool or an int.
+ * If it's a bool=true, then it defaults to PDFX3Profile_num = 0
+ * If it's an int, then we set the flag to true and use the
+ * specified number.
+ * PS: Yuck!
+ */
+ code = plist_value_get_bool(&pvalue, &ctx->args.UsePDFX3Profile);
+ if (code == gs_error_typecheck) {
+ code = plist_value_get_int(&pvalue, &ctx->args.PDFX3Profile_num);
+ if (code == 0)
+ ctx->args.UsePDFX3Profile = true;
+ }
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "NOSUBSTDEVICECOLORS", strlen("NOSUBSTDEVICECOLORS"))) {
+ code = plist_value_get_bool(&pvalue, &ctx->args.NOSUBSTDEVICECOLORS);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "UseOutputIntent", strlen("UseOutputIntent"))) {
+ code = plist_value_get_string_or_name(ctx, &pvalue, &ctx->args.UseOutputIntent, &len);
+ if (code < 0)
+ return code;
+ }
+ if (!strncmp(param, "FONTPATH", 11)) {
+ char *s = NULL;
+ int slen;
+ code = plist_value_get_string_or_name(ctx, &pvalue, &s , &slen);
+ if (code < 0)
+ return code;
+ code = pdfi_add_paths_to_search_paths(ctx, (const char *)s, slen, true);
+ }
+ }
+
+ exit:
+ return code;
+}
+
+static int
+pdf_impl_add_path(pl_interp_implementation_t *impl, const char *path)
+{
+ pdf_interp_instance_t *instance = impl->interp_client_data;
+ pdf_context *ctx = instance->ctx;
+
+ return pdfi_add_paths_to_search_paths(ctx, path, strlen(path), false);
+}
+
+static int
+pdf_impl_post_args_init(pl_interp_implementation_t *impl)
+{
+ return 0;
+}
+
+/* Prepare interp instance for the next "job" */
+static int
+pdf_impl_init_job(pl_interp_implementation_t *impl,
+ gx_device *device)
+{
+ pdf_interp_instance_t *instance = impl->interp_client_data;
+ pdf_context *ctx = instance->ctx;
+
+ if (getenv("PDF_DISABLE_TRANSPARENCY"))
+ ctx->args.notransparency = true;
+
+ return pdf_impl_set_device(impl, device);
+}
+
+/* Wrap up interp instance after a "job" */
+static int
+pdf_impl_dnit_job(pl_interp_implementation_t *impl)
+{
+ pdf_interp_instance_t *instance = impl->interp_client_data;
+ pdf_context *ctx = instance->ctx;
+
+ return gs_grestoreall(ctx->pgs); /* pdf_impl_set_device does a gsave which we need to restore now.
+ * Using grestoreall will restore any dangling gstates back to the last restore.
+ * This should ensure we don't have dangling references to the device created by the
+ * top level code.
+ */
+}
+
+/* Deallocate a interpreter instance */
+static int
+pdf_impl_deallocate_interp_instance(pl_interp_implementation_t *impl)
+{
+ pdf_interp_instance_t *instance = impl->interp_client_data;
+ pdf_context *ctx = instance->ctx;
+ gs_memory_t *mem = instance->memory;
+ int code = 0;
+
+ code = pdfi_free_context(ctx);
+
+ gs_free_object(mem, instance, "pdf_impl_deallocate_interp_instance");
+
+ return code;
+}
+
+/* Parser implementation descriptor */
+pl_interp_implementation_t pdf_implementation =
+{
+ pdf_impl_characteristics,
+ pdf_impl_allocate_interp_instance,
+ pdf_impl_get_device_memory,
+ pdf_impl_set_param,
+ pdf_impl_add_path,
+ pdf_impl_post_args_init,
+ pdf_impl_init_job,
+ NULL, /* run_prefix_commands */
+ pdf_impl_process_file,
+ pdf_impl_process_begin,
+ pdf_impl_process,
+ pdf_impl_process_end,
+ pdf_impl_flush_to_eoj,
+ pdf_impl_process_eof,
+ pdf_impl_report_errors,
+ pdf_impl_dnit_job,
+ pdf_impl_deallocate_interp_instance,
+ NULL, /* interp_client_data */
+};
+
+/*
+ * We need to install a halftone ourselves, this is not
+ * done automatically.
+ */
+
+static float
+identity_transfer(double tint, const gx_transfer_map *ignore_map)
+{
+ return tint;
+}
+
+/* The following is a 45 degree spot screen with the spots enumerated
+ * in a defined order. */
+static byte order16x16[256] = {
+ 38, 11, 14, 32, 165, 105, 90, 171, 38, 12, 14, 33, 161, 101, 88, 167,
+ 30, 6, 0, 16, 61, 225, 231, 125, 30, 6, 1, 17, 63, 222, 227, 122,
+ 27, 3, 8, 19, 71, 242, 205, 110, 28, 4, 9, 20, 74, 246, 208, 106,
+ 35, 24, 22, 40, 182, 46, 56, 144, 36, 25, 22, 41, 186, 48, 58, 148,
+ 152, 91, 81, 174, 39, 12, 15, 34, 156, 95, 84, 178, 40, 13, 16, 34,
+ 69, 212, 235, 129, 31, 7, 2, 18, 66, 216, 239, 133, 32, 8, 2, 18,
+ 79, 254, 203, 114, 28, 4, 10, 20, 76, 250, 199, 118, 29, 5, 10, 21,
+ 193, 44, 54, 142, 36, 26, 23, 42, 189, 43, 52, 139, 37, 26, 24, 42,
+ 39, 12, 15, 33, 159, 99, 87, 169, 38, 11, 14, 33, 163, 103, 89, 172,
+ 31, 7, 1, 17, 65, 220, 229, 123, 30, 6, 1, 17, 62, 223, 233, 127,
+ 28, 4, 9, 20, 75, 248, 210, 108, 27, 3, 9, 19, 72, 244, 206, 112,
+ 36, 25, 23, 41, 188, 49, 60, 150, 35, 25, 22, 41, 184, 47, 57, 146,
+ 157, 97, 85, 180, 40, 13, 16, 35, 154, 93, 83, 176, 39, 13, 15, 34,
+ 67, 218, 240, 135, 32, 8, 3, 19, 70, 214, 237, 131, 31, 7, 2, 18,
+ 78, 252, 197, 120, 29, 5, 11, 21, 80, 255, 201, 116, 29, 5, 10, 21,
+ 191, 43, 51, 137, 37, 27, 24, 43, 195, 44, 53, 140, 37, 26, 23, 42
+};
+
+#define source_phase_x 4
+#define source_phase_y 0
+
+static int
+pdfi_install_halftone(pdf_context *ctx, gx_device *pdevice)
+{
+ gs_halftone ht;
+ gs_string thresh;
+ int code;
+
+ int width = 16;
+ int height = 16;
+ thresh.data = order16x16;
+ thresh.size = width * height;
+
+ if (gx_device_must_halftone(pdevice))
+ {
+ ht.type = ht_type_threshold;
+ ht.objtype = HT_OBJTYPE_DEFAULT;
+ ht.params.threshold.width = width;
+ ht.params.threshold.height = height;
+ ht.params.threshold.thresholds.data = thresh.data;
+ ht.params.threshold.thresholds.size = thresh.size;
+ ht.params.threshold.transfer = 0;
+ ht.params.threshold.transfer_closure.proc = 0;
+
+ gs_settransfer(ctx->pgs, identity_transfer);
+
+ code = gs_sethalftone(ctx->pgs, &ht);
+ if (code < 0)
+ return gs_throw(code, "could not install halftone");
+
+ code = gs_sethalftonephase(ctx->pgs, 0, 0);
+ if (code < 0)
+ return gs_throw(code, "could not set halftone phase");
+ }
+
+ return 0;
+}
diff --git a/psi/bfont.h b/psi/bfont.h
index 06110f47..184c11f7 100644
--- a/psi/bfont.h
+++ b/psi/bfont.h
@@ -85,5 +85,6 @@ gs_glyph zfont_encode_char(gs_font *pfont, gs_char chr, gs_glyph_space_t ignored
int gs_font_map_glyph_to_unicode(gs_font *font, gs_glyph glyph, int ch, unsigned short *unicode_return, unsigned int length);
const ref *zfont_get_to_unicode_map(gs_font_dir *dir);
void get_GlyphNames2Unicode(i_ctx_t *i_ctx_p, gs_font *pfont, ref *pdref);
+void get_zfont_glyph_name( void **proc);
#endif /* bfont_INCLUDED */
diff --git a/psi/icie.h b/psi/icie.h
index 9bcfbfec..eef0b8e1 100644
--- a/psi/icie.h
+++ b/psi/icie.h
@@ -53,7 +53,7 @@ int dict_proc_array_param(const gs_memory_t *mem, const ref *pdict,
/* Get 3 procedures from a dictionary. */
int dict_proc3_param(const gs_memory_t *mem, const ref *pdref,
- const char *kstr, ref proc3[3]);
+ const char *kstr, ref *proc3);
/* Get WhitePoint and BlackPoint values. */
int cie_points_param(const gs_memory_t *mem,
diff --git a/psi/idebug.c b/psi/idebug.c
index fb6ce0c7..796b5371 100644
--- a/psi/idebug.c
+++ b/psi/idebug.c
@@ -132,6 +132,7 @@ debug_print_full_ref(const gs_memory_t *mem, const ref * pref)
case t_string:
dmprintf2(mem, "string(%u)"PRI_INTPTR"", size, (intptr_t)pref->value.bytes);
break;
+ case t_pdfctx:
case t_struct:
strct:{
obj_header_t *obj = (obj_header_t *) pref->value.pstruct;
diff --git a/psi/igc.c b/psi/igc.c
index 5a841ebd..420a013a 100644
--- a/psi/igc.c
+++ b/psi/igc.c
@@ -958,6 +958,7 @@ gc_trace(gs_gc_root_t * rp, gc_state_t * pstate, gc_mark_stack * pmstack)
case t_fontID:
case t_struct:
case t_astruct:
+ case t_pdfctx:
nptr = rptr->value.pstruct;
goto rs;
/* Non-trivial non-struct cases */
diff --git a/psi/igcref.c b/psi/igcref.c
index 35fdc758..a18bcfb7 100644
--- a/psi/igcref.c
+++ b/psi/igcref.c
@@ -431,6 +431,7 @@ igc_reloc_refs(ref_packed * from, ref_packed * to, gc_state_t * gcst)
case t_fontID:
case t_struct:
case t_astruct:
+ case t_pdfctx:
DO_RELOC(pref->value.pstruct,
RELOC_VAR(pref->value.pstruct));
break;
diff --git a/psi/int.mak b/psi/int.mak
index 4efdc768..db0e5c2d 100644
--- a/psi/int.mak
+++ b/psi/int.mak
@@ -542,7 +542,7 @@ INT2=$(PSOBJ)idict.$(OBJ) $(PSOBJ)idparam.$(OBJ) $(PSOBJ)idstack.$(OBJ)
INT3=$(PSOBJ)iinit.$(OBJ) $(PSOBJ)interp.$(OBJ)
INT4=$(PSOBJ)iparam.$(OBJ) $(PSOBJ)ireclaim.$(OBJ) $(PSOBJ)iplugin.$(OBJ)
INT5=$(PSOBJ)iscan.$(OBJ) $(PSOBJ)iscannum.$(OBJ) $(PSOBJ)istack.$(OBJ)
-INT6=$(PSOBJ)iutil.$(OBJ) $(GLOBJ)sa85d.$(OBJ) $(GLOBJ)scantab.$(OBJ)
+INT6=$(PSOBJ)iutil.$(OBJ) $(GLOBJ)scantab.$(OBJ)
INT7=$(GLOBJ)sstring.$(OBJ) $(GLOBJ)stream.$(OBJ)
Z1=$(PSOBJ)zarith.$(OBJ) $(PSOBJ)zarray.$(OBJ) $(PSOBJ)zcontrol.$(OBJ)
Z2=$(PSOBJ)zdict.$(OBJ) $(PSOBJ)zfile.$(OBJ) $(PSOBJ)zfile1.$(OBJ) $(PSOBJ)zfileio.$(OBJ)
@@ -1810,8 +1810,9 @@ $(PSD)pdfops.dev : $(ECHOGS_XE) $(zpdfops_) $(INT_MAK) $(MAKEDIRS)
$(ADDMOD) $(PSD)pdfops -oper zpdfops
$(PSOBJ)zpdfops.$(OBJ) : $(PSSRC)zpdfops.c $(OP) $(MAKEFILE)\
+ $(ghost_h) $(gsmchunk_h) $(oper_h) \
$(igstate_h) $(istack_h) $(iutil_h) $(gspath_h) $(math__h) $(ialloc_h)\
- $(string__h) $(store_h) $(INT_MAK) $(MAKEDIRS)
+ $(string__h) $(store_h) $(iminst_h) $(idstack_h) $(INT_MAK) $(MAKEDIRS)
$(PSCC) $(PSO_)zpdfops.$(OBJ) $(C_) $(PSSRC)zpdfops.c
zutf8_=$(PSOBJ)zutf8.$(OBJ)
diff --git a/psi/interp.c b/psi/interp.c
index 40f94fe9..2cf9d4a6 100644
--- a/psi/interp.c
+++ b/psi/interp.c
@@ -1158,7 +1158,8 @@ interp(i_ctx_t **pi_ctx_p /* context for execution, updated if resched */,
case lit(t_shortarray): case nox(t_shortarray):\
case plain(t_device): case plain_exec(t_device):\
case plain(t_struct): case plain_exec(t_struct):\
- case plain(t_astruct): case plain_exec(t_astruct)
+ case plain(t_astruct): case plain_exec(t_astruct):\
+ case plain(t_pdfctx): case plain_exec(t_pdfctx)
/* Executable arrays are treated as literals in direct execution. */
#define cases_lit_array()\
case exec(t_array): case exec(t_mixedarray): case exec(t_shortarray)
diff --git a/psi/iparam.c b/psi/iparam.c
index 269b6661..7fe1cb0d 100644
--- a/psi/iparam.c
+++ b/psi/iparam.c
@@ -406,11 +406,14 @@ stack_param_enumerate(iparam_list * plist, gs_param_enumerator_t * penum,
ref *stack_element;
do {
+ if (index >= splist->count*2)
+ return 1;
stack_element =
ref_stack_index(splist->pstack, index + 1 + splist->skip);
if (!stack_element)
return 1;
- } while (index += 2, !r_has_type(stack_element, t_name));
+ index += 2;
+ } while (!r_has_type(stack_element, t_name));
*type = r_type(stack_element);
code = ref_to_key(stack_element, key, plist);
penum->intval = index;
@@ -454,7 +457,7 @@ dict_param_enumerate(iparam_list * plist, gs_param_enumerator_t * penum,
index = dict_next(&pdlist->dict, index, elt);
if (index < 0)
return 1;
- *type = r_type(&elt[1]);
+ *type = r_type(&elt[0]);
code = ref_to_key(&elt[0], key, plist);
penum->intval = index;
return code;
@@ -526,7 +529,8 @@ static const gs_param_list_procs ref_read_procs =
NULL, /* requested */
ref_param_read_get_policy,
ref_param_read_signal_error,
- ref_param_read_commit
+ ref_param_read_commit,
+ NULL
};
static int ref_param_read(iparam_list *, gs_param_name,
iparam_loc *, int);
diff --git a/psi/iref.h b/psi/iref.h
index 955cff31..099ff93b 100644
--- a/psi/iref.h
+++ b/psi/iref.h
@@ -204,6 +204,7 @@ typedef enum {
t_device, /* @ + value.pdevice */
t_oparray, /* @! # value.const_refs, uses size */
/* for index */
+ t_pdfctx, /* @ value.pstruct */
t_next_index /*** first available index ***/
} ref_type;
@@ -247,11 +248,12 @@ extern const byte ref_type_properties[1 << 6]; /* r_type_bits */
_REF_TYPE_USES_ACCESS | _REF_TYPE_USES_SIZE, /* t_string */\
_REF_TYPE_USES_ACCESS, /* t_device */\
_REF_TYPE_USES_SIZE, /* t_oparray */\
+ 0, /* t_pdfctx */\
/*\
* The remaining types are the extended pseudo-types used by the\
* interpreter for operators. We need to fill up the table.\
*/\
- _REF_TYPE_USES_SIZE,_REF_TYPE_USES_SIZE,_REF_TYPE_USES_SIZE, /*24*/\
+ _REF_TYPE_USES_SIZE,_REF_TYPE_USES_SIZE, /*24*/\
_REF_TYPE_USES_SIZE,_REF_TYPE_USES_SIZE,_REF_TYPE_USES_SIZE,_REF_TYPE_USES_SIZE, /*28*/\
_REF_TYPE_USES_SIZE,_REF_TYPE_USES_SIZE,_REF_TYPE_USES_SIZE,_REF_TYPE_USES_SIZE, /*32*/\
_REF_TYPE_USES_SIZE,_REF_TYPE_USES_SIZE,_REF_TYPE_USES_SIZE,_REF_TYPE_USES_SIZE, /*36*/\
@@ -280,7 +282,7 @@ extern const byte ref_type_properties[1 << 6]; /* r_type_bits */
"STRC","ASTR",\
"int ","real","font","mark","name","null",\
"oper","save","str ",\
- "devc","opry"
+ "devc","opry","pdfctx"
/*
* Define the type names for the type operator.
*/
@@ -290,7 +292,7 @@ extern const byte ref_type_properties[1 << 6]; /* r_type_bits */
0,0,\
"integertype","realtype","fonttype","marktype","nametype","nulltype",\
"operatortype","savetype","stringtype",\
- "devicetype","operatortype"
+ "devicetype","operatortype","pdfctxtype"
/*
* Define the type names for obj_cvp (the == operator). We only need these
* for types that obj_cvp and obj_cvs don't handle specially.
@@ -301,7 +303,7 @@ extern const byte ref_type_properties[1 << 6]; /* r_type_bits */
0,0,0,0,\
"-fontID-","-mark-",0,\
0,0,"-save-","-string-",\
- "-device-",0
+ "-device-",0,"-pdfcontext-"
/*
* The following factors affect the encoding of attributes:
diff --git a/psi/istack.c b/psi/istack.c
index f10ff25f..0519b078 100644
--- a/psi/istack.c
+++ b/psi/istack.c
@@ -453,7 +453,8 @@ ref_stack_pop(ref_stack_t *pstack, uint count)
{
uint used;
- while ((used = pstack->p + 1 - pstack->bot) < count) {
+ while ((used = pstack->p + 1 - pstack->bot) <= count &&
+ pstack->extension_used > 0) {
count -= used;
pstack->p = pstack->bot - 1;
ref_stack_pop_block(pstack);
diff --git a/psi/iutil.c b/psi/iutil.c
index b51abbc9..ea582e6e 100644
--- a/psi/iutil.c
+++ b/psi/iutil.c
@@ -179,6 +179,7 @@ obj_eq(const gs_memory_t *mem, const ref * pref1, const ref * pref2)
return (pref1->value.pdevice == pref2->value.pdevice);
case t_struct:
case t_astruct:
+ case t_pdfctx:
return (pref1->value.pstruct == pref2->value.pstruct);
case t_fontID:
/* This is complicated enough to deserve a separate procedure. */
@@ -478,6 +479,9 @@ obj_cvp(const ref * op, byte * str, uint len, uint * prlen,
size += 2;
data = (const byte *)buf;
goto nl;
+ case t_pdfctx:
+ data = (const byte *)"-pdfcontext-";
+ goto rs;
default:
other:
{
diff --git a/psi/msvc.mak b/psi/msvc.mak
index 8697b76f..478972b2 100644
--- a/psi/msvc.mak
+++ b/psi/msvc.mak
@@ -236,6 +236,18 @@ XPSGENDIR=$(GLGENDIR)
XPSOBJDIR=$(GLOBJDIR)
!endif
+!ifndef PDFSRCDIR
+PDFSRCDIR=.\pdf
+!endif
+
+!ifndef PDFGENDIR
+PDFGENDIR=$(GLGENDIR)
+!endif
+
+!ifndef PDFOBJDIR
+PDFOBJDIR=$(GLOBJDIR)
+!endif
+
!ifndef GPDLSRCDIR
GPDLSRCDIR=.\gpdl
!endif
@@ -268,7 +280,7 @@ IMGOBJDIR=$(GLOBJDIR)
CONTRIBDIR=.\contrib
-# Can we build PCL and XPS
+# Can we build PCL and XPS and PDF
!ifndef BUILD_PCL
BUILD_PCL=0
!if exist ("$(PLSRCDIR)\pl.mak")
@@ -283,6 +295,15 @@ BUILD_XPS=1
!endif
!endif
+!ifndef BUILD_PDF
+BUILD_PDF=0
+GPDF_DEV=
+!if exist ("$(PDFSRCDIR)\pdf.mak")
+BUILD_PDF=1
+GPDF_DEV=$(PDFOBJDIR)\pdfi.dev
+!endif
+!endif
+
!ifndef BUILD_GPDL
BUILD_GPDL=0
!if exist ("$(GPDLSRCDIR)\gpdl.mak")
@@ -292,6 +313,7 @@ BUILD_GPDL=1
PCL_TARGET=
XPS_TARGET=
+PDF_TARGET=
!if $(BUILD_PCL)
PCL_TARGET=gpcl6
@@ -301,11 +323,17 @@ PCL_TARGET=gpcl6
XPS_TARGET=gxps
!endif
+!if $(BUILD_PDF)
+!if exist ("$(PLSRCDIR)\pl.mak")
+PDF_TARGET=gpdf
+!endif
+!endif
+
!if $(BUILD_GPDL)
GPDL_TARGET=gpdl
!endif
-PCL_XPS_PDL_TARGETS=$(PCL_TARGET) $(XPS_TARGET) $(GPDL_TARGET)
+PCL_XPS_PDL_TARGETS=$(PCL_TARGET) $(XPS_TARGET) $(GPDL_TARGET) $(PDF_TARGET)
# Define the root directory for Ghostscript installation.
@@ -471,17 +499,20 @@ GS=gswin64
PCL=gpcl6win64
XPS=gxpswin64
GPDL=gpdlwin64
+PDF=gpdfwin64
!else
!ifdef ARM
GS=gswinARM
PCL=gpcl6winARM
XPS=gxpswinARM
GPDL=gpdlwinARM
+PDF=gpdfwinARM
!else
GS=gswin32
PCL=gpcl6win32
XPS=gxpswin32
GPDL=gpdlwin32
+PDF=gpdfwin32
!endif
!endif
!endif
@@ -549,6 +580,26 @@ GXPSDLL=gxpsdll32
!endif
!endif
+!ifndef GPDFDLL
+!ifdef METRO
+!ifdef WIN64
+GPDFDLL=gpdfdll64metro
+!else
+!ifdef ARM
+GPDFDLL=gpfddllARM32metro
+!else
+GPDFDLL=gpdfdll32metro
+!endif
+!endif
+!else
+!ifdef WIN64
+GPDFDLL=gpdfdll64
+!else
+GPDFDLL=gpdfdll32
+!endif
+!endif
+!endif
+
!ifndef GPDLDLL
!ifdef METRO
!ifdef WIN64
@@ -692,10 +743,14 @@ ZSRCDIR=.\zlib
!if exist("leptonica")
LEPTONICADIR=leptonica
+# /wd4244 = Suppress casting warnings on initialisation
+LEPTSUPPRESS=/wd4244
!endif
!if exist("tesseract")
TESSERACTDIR=tesseract
-TESSCXXFLAGS=-DHAVE_AVX -DHAVE_AVX2 -DHAVE_SSE4_1 -DHAVE_FMA -D__AVX__ -D__AVX2__ -D__FMA__ -D__SSE4_1__ /EHsc /std:c++17 /utf-8
+# /wd4244 = Suppress casting warnings on initialisation
+# /wd4305 = Suppress double->float truncation warnings
+TESSCXXFLAGS=-DHAVE_AVX -DHAVE_AVX2 -DHAVE_SSE4_1 -DHAVE_FMA -D__AVX__ -D__AVX2__ -D__FMA__ -D__SSE4_1__ /EHsc /std:c++17 /utf-8 /wd4244 /wd4305
!endif
!if defined(TESSERACTDIR) && defined(LEPTONICADIR)
OCR_VERSION=1
@@ -846,6 +901,10 @@ CFLAGS=$(CFLAGS) -DMETRO -DWINAPI_FAMILY=WINAPI_PARTITION_APP -DTIF_PLATFORM_CON
PNG_CFLAGS=/DExitProcess=exit
!endif
+!if $(BUILD_PDF)
+CFLAGS=/DBUILD_PDF=1 /I$(PDFSRCDIR) /I$(ZSRCDIR) $(CFLAGS)
+!endif
+
CFLAGS=$(CFLAGS) $(XCFLAGS)
# 1 --> Use 64 bits for gx_color_index. This is required only for
@@ -1037,6 +1096,31 @@ MS_TOOLSET_VERSION=14.28.29333
MSVC_VERSION=16
MS_TOOLSET_VERSION=14.28.29333
!endif
+!if "$(_NMAKE_VER)" == "14.28.29913.0"
+# VS2019 (Toolset v142)
+MSVC_VERSION=16
+MS_TOOLSET_VERSION=14.28.29333
+!endif
+!if "$(_NMAKE_VER)" == "14.28.29914.0"
+# VS2019 (Toolset v142)
+MSVC_VERSION=16
+MS_TOOLSET_VERSION=14.28.29333
+!endif
+!if "$(_NMAKE_VER)" == "14.28.29915.0"
+# VS2019 (Toolset v142)
+MSVC_VERSION=16
+MS_TOOLSET_VERSION=14.28.29333
+!endif
+!if "$(_NMAKE_VER)" == "14.29.30038.1"
+# VS2019 (Toolset v142)
+MSVC_VERSION=16
+MS_TOOLSET_VERSION=14.29.30037
+!endif
+!if "$(_NMAKE_VER)" == "14.29.30133.0"
+# VS2019 (Toolset v142)
+MSVC_VERSION=16
+MS_TOOLSET_VERSION=14.29.30133
+!endif
!endif
!ifndef MSVC_VERSION
@@ -1599,7 +1683,7 @@ JPX_CFLAGS = $JPX_CFLAGS -DUSE_JPIP -DUSE_OPENJPEG_JP2 -DOPJ_STATIC
# Choose the language feature(s) to include. See gs.mak for details.
# if it's included, $(PSD)gs_pdfwr.dev should always be one of the last in the list
-PSI_FEATURE_DEVS=$(PSD)psl3.dev $(PSD)pdf.dev $(PSD)epsf.dev $(PSD)ttfont.dev \
+PSI_FEATURE_DEVS=$(PSD)psl3.dev $(PSD)pdf.dev $(GPDF_DEV) $(PSD)epsf.dev $(PSD)ttfont.dev \
$(PSD)jbig2.dev $(PSD)jpx.dev $(PSD)fapi_ps.dev $(GLD)winutf8.dev $(PSD)gs_pdfwr.dev
@@ -1608,6 +1692,8 @@ PCL_FEATURE_DEVS=$(PLOBJDIR)/pl.dev $(PLOBJDIR)/pjl.dev $(PXLOBJDIR)/pxl.dev $(P
XPS_FEATURE_DEVS=$(XPSOBJDIR)/pl.dev $(XPSOBJDIR)/xps.dev
+PDF_FEATURE_DEVS=$(PDFOBJDIR)/pl.dev $(PDFOBJDIR)/gpdf.dev
+
FEATURE_DEVS=$(GLD)pipe.dev $(GLD)gsnogc.dev $(GLD)htxlib.dev $(GLD)psl3lib.dev $(GLD)psl2lib.dev \
$(GLD)dps2lib.dev $(GLD)path1lib.dev $(GLD)patlib.dev $(GLD)psl2cs.dev $(GLD)rld.dev $(GLD)gxfapiu$(UFST_BRIDGE).dev\
$(GLD)ttflib.dev $(GLD)cielib.dev $(GLD)pipe.dev $(GLD)htxlib.dev $(GLD)sdct.dev $(GLD)libpng.dev\
@@ -1660,9 +1746,9 @@ DEVICE_DEVS=
DEVICE_DEVS=$(DD)display.dev $(DD)mswinpr2.dev $(DD)ijs.dev
!endif
DEVICE_DEVS2=$(DD)epson.dev $(DD)eps9high.dev $(DD)eps9mid.dev $(DD)epsonc.dev $(DD)ibmpro.dev
-DEVICE_DEVS3=$(DD)deskjet.dev $(DD)djet500.dev $(DD)laserjet.dev $(DD)ljetplus.dev $(DD)ljet2p.dev
-DEVICE_DEVS4=$(DD)cdeskjet.dev $(DD)cdjcolor.dev $(DD)cdjmono.dev $(DD)cdj550.dev
-DEVICE_DEVS5=$(DD)uniprint.dev $(DD)djet500c.dev $(DD)declj250.dev $(DD)lj250.dev
+DEVICE_DEVS3=$(DD)deskjet.dev $(DD)djet500.dev $(DD)laserjet.dev $(DD)ljetplus.dev $(DD)ljet2p.dev $(DD)fs600.dev
+DEVICE_DEVS4=$(DD)cdeskjet.dev $(DD)cdjcolor.dev $(DD)cdjmono.dev $(DD)cdj500.dev $(DD)cdj550.dev $(DD)lj4dith.dev $(DD)lj4dithp.dev $(DD)lj5gray.dev $(DD)dj505j.dev $(DD)picty180.dev
+DEVICE_DEVS5=$(DD)uniprint.dev $(DD)djet500c.dev $(DD)dnj650c.dev $(DD)cljet5.dev $(DD)cljet5pr.dev $(DD)cljet5c.dev $(DD)declj250.dev $(DD)lj250.dev
DEVICE_DEVS6=$(DD)st800.dev $(DD)stcolor.dev $(DD)bj10e.dev $(DD)bj200.dev
DEVICE_DEVS7=$(DD)t4693d2.dev $(DD)t4693d4.dev $(DD)t4693d8.dev $(DD)tek4696.dev
DEVICE_DEVS8=$(DD)pcxmono.dev $(DD)pcxgray.dev $(DD)pcx16.dev $(DD)pcx256.dev $(DD)pcx24b.dev $(DD)pcxcmyk.dev
@@ -1670,8 +1756,8 @@ DEVICE_DEVS9=$(DD)pbm.dev $(DD)pbmraw.dev $(DD)pgm.dev $(DD)pgmraw.dev $(DD)pgnm
DEVICE_DEVS10=$(DD)tiffcrle.dev $(DD)tiffg3.dev $(DD)tiffg32d.dev $(DD)tiffg4.dev $(DD)tifflzw.dev $(DD)tiffpack.dev
DEVICE_DEVS11=$(DD)bmpmono.dev $(DD)bmpgray.dev $(DD)bmp16.dev $(DD)bmp256.dev $(DD)bmp16m.dev $(DD)tiff12nc.dev $(DD)tiff24nc.dev $(DD)tiff48nc.dev $(DD)tiffgray.dev $(DD)tiff32nc.dev $(DD)tiff64nc.dev $(DD)tiffsep.dev $(DD)tiffsep1.dev $(DD)tiffscaled.dev $(DD)tiffscaled8.dev $(DD)tiffscaled24.dev $(DD)tiffscaled32.dev $(DD)tiffscaled4.dev
DEVICE_DEVS12=$(DD)bit.dev $(DD)bitrgb.dev $(DD)bitcmyk.dev $(DD)bitrgbtags.dev $(DD)chameleon.dev
-DEVICE_DEVS13=$(DD)pngmono.dev $(DD)pngmonod.dev $(DD)pnggray.dev $(DD)png16.dev $(DD)png256.dev $(DD)png16m.dev $(DD)pngalpha.dev $(DD)fpng.dev $(DD)psdcmykog.dev
-DEVICE_DEVS14=$(DD)jpeg.dev $(DD)jpeggray.dev $(DD)jpegcmyk.dev $(DD)pdfimage8.dev $(DD)pdfimage24.dev $(DD)pdfimage32.dev $(DD)PCLm.dev
+DEVICE_DEVS13=$(DD)pngmono.dev $(DD)pngmonod.dev $(DD)pnggray.dev $(DD)png16.dev $(DD)png256.dev $(DD)png48.dev $(DD)png16m.dev $(DD)pngalpha.dev $(DD)fpng.dev $(DD)psdcmykog.dev
+DEVICE_DEVS14=$(DD)jpeg.dev $(DD)jpeggray.dev $(DD)jpegcmyk.dev $(DD)pdfimage8.dev $(DD)pdfimage24.dev $(DD)pdfimage32.dev $(DD)PCLm.dev $(DD)imagen.dev
DEVICE_DEVS15=$(DD)pdfwrite.dev $(DD)ps2write.dev $(DD)eps2write.dev $(DD)txtwrite.dev $(DD)pxlmono.dev $(DD)pxlcolor.dev $(DD)xpswrite.dev $(DD)inkcov.dev $(DD)ink_cov.dev $(EXTRACT_DEVS)
DEVICE_DEVS16=$(DD)bbox.dev $(DD)plib.dev $(DD)plibg.dev $(DD)plibm.dev $(DD)plibc.dev $(DD)plibk.dev $(DD)plan.dev $(DD)plang.dev $(DD)planm.dev $(DD)planc.dev $(DD)plank.dev $(DD)planr.dev
!if "$(WITH_CUPS)" == "1"
@@ -1685,13 +1771,13 @@ DEVICE_DEVS16=$(DEVICE_DEVS16) $(DD)urfgray.dev $(DD)urfrgb.dev $(DD)urfcmyk.dev
DEVICE_DEVS16=$(DEVICE_DEVS16) $(DD)ocr.dev $(DD)hocr.dev $(DD)pdfocr8.dev $(DD)pdfocr24.dev $(DD)pdfocr32.dev
!endif
# Overflow for DEVS3,4,5,6,9
-DEVICE_DEVS17=$(DD)ljet3.dev $(DD)ljet3d.dev $(DD)ljet4.dev $(DD)ljet4d.dev
+DEVICE_DEVS17=$(DD)ljet3.dev $(DD)ljet3d.dev $(DD)ljet4pjl.dev $(DD)ljet4.dev $(DD)ljet4d.dev $(DD)lp2563.dev $(DD)paintjet.dev $(DD)pjetxl.dev $(DD)lj3100sw.dev $(DD)oce9050.dev $(DD)r4081.dev $(DD)sj48.dev
DEVICE_DEVS18=$(DD)pj.dev $(DD)pjxl.dev $(DD)pjxl300.dev $(DD)jetp3852.dev $(DD)r4081.dev
DEVICE_DEVS19=$(DD)lbp8.dev $(DD)m8510.dev $(DD)necp6.dev $(DD)bjc600.dev $(DD)bjc800.dev
DEVICE_DEVS20=$(DD)pnm.dev $(DD)pnmraw.dev $(DD)ppm.dev $(DD)ppmraw.dev $(DD)pamcmyk32.dev $(DD)pamcmyk4.dev $(DD)pnmcmyk.dev $(DD)pam.dev
DEVICE_DEVS21=$(DD)spotcmyk.dev $(DD)devicen.dev $(DD)bmpsep1.dev $(DD)bmpsep8.dev $(DD)bmp16m.dev $(DD)bmp32b.dev $(DD)psdcmyk.dev $(DD)psdrgb.dev $(DD)psdcmyk16.dev $(DD)psdrgb16.dev
!endif
-CONTRIB_DEVS=$(DD)pcl3.dev $(DD)hpdjplus.dev $(DD)hpdjportable.dev $(DD)hpdj310.dev $(DD)hpdj320.dev $(DD)hpdj340.dev $(DD)hpdj400.dev $(DD)hpdj500.dev $(DD)hpdj500c.dev $(DD)hpdj510.dev $(DD)hpdj520.dev $(DD)hpdj540.dev $(DD)hpdj550c.dev $(DD)hpdj560c.dev $(DD)hpdj600.dev $(DD)hpdj660c.dev $(DD)hpdj670c.dev $(DD)hpdj680c.dev $(DD)hpdj690c.dev $(DD)hpdj850c.dev $(DD)hpdj855c.dev $(DD)hpdj870c.dev $(DD)hpdj890c.dev $(DD)hpdj1120c.dev $(DD)cdj670.dev $(DD)cdj850.dev $(DD)cdj880.dev $(DD)cdj890.dev $(DD)cdj970.dev $(DD)cdj1600.dev $(DD)cdnj500.dev $(DD)chp2200.dev $(DD)lips3.dev $(DD)lxm3200.dev $(DD)lex2050.dev $(DD)lxm3200.dev $(DD)lex5700.dev $(DD)lex7000.dev $(DD)oki4w.dev $(DD)gdi.dev $(DD)samsunggdi.dev $(DD)dl2100.dev $(DD)la50.dev $(DD)la70.dev $(DD)la75.dev $(DD)la75plus.dev $(DD)ln03.dev $(DD)xes.dev $(DD)md2k.dev $(DD)md5k.dev $(DD)lips4.dev $(DD)bj10v.dev $(DD)bj10vh.dev $(DD)md50Mono.dev $(DD)md50Eco.dev $(DD)md1xMono.dev $(DD)lp2000.dev $(DD)escpage.dev $(DD)npdl.dev $(DD)rpdl.dev $(DD)fmpr.dev $(DD)fmlbp.dev $(DD)jj100.dev $(DD)lbp310.dev $(DD)lbp320.dev $(DD)mj700v2c.dev $(DD)mj500c.dev $(DD)mj6000c.dev $(DD)mj8000c.dev $(DD)pr201.dev $(DD)pr150.dev $(DD)pr1000.dev $(DD)pr1000_4.dev $(DD)lips2p.dev $(DD)bjc880j.dev $(DD)bjcmono.dev $(DD)bjcgray.dev $(DD)bjccmyk.dev $(DD)bjccolor.dev
+CONTRIB_DEVS=$(DD)pcl3.dev $(DD)hpdjplus.dev $(DD)hpdjportable.dev $(DD)hpdj310.dev $(DD)hpdj320.dev $(DD)hpdj340.dev $(DD)hpdj400.dev $(DD)hpdj500.dev $(DD)hpdj500c.dev $(DD)hpdj510.dev $(DD)hpdj520.dev $(DD)hpdj540.dev $(DD)hpdj550c.dev $(DD)hpdj560c.dev $(DD)hpdj600.dev $(DD)hpdj660c.dev $(DD)hpdj670c.dev $(DD)hpdj680c.dev $(DD)hpdj690c.dev $(DD)hpdj850c.dev $(DD)hpdj855c.dev $(DD)hpdj870c.dev $(DD)hpdj890c.dev $(DD)hpdj1120c.dev $(DD)cdj670.dev $(DD)cdj850.dev $(DD)cdj880.dev $(DD)cdj890.dev $(DD)cdj970.dev $(DD)cdj1600.dev $(DD)cdnj500.dev $(DD)chp2200.dev $(DD)lips3.dev $(DD)lxm5700m.dev $(DD)lxm3200.dev $(DD)lex2050.dev $(DD)lxm3200.dev $(DD)lex5700.dev $(DD)lex7000.dev $(DD)okiibm.dev $(DD)oki182.dev $(DD)oki4w.dev $(DD)gdi.dev $(DD)samsunggdi.dev $(DD)dl2100.dev $(DD)la50.dev $(DD)la70.dev $(DD)la75.dev $(DD)la75plus.dev $(DD)ln03.dev $(DD)xes.dev $(DD)md2k.dev $(DD)md5k.dev $(DD)lips4.dev $(DD)lips4v.dev $(DD)bj10v.dev $(DD)bj10vh.dev $(DD)md50Mono.dev $(DD)md50Eco.dev $(DD)md1xMono.dev $(DD)lp2000.dev $(DD)escpage.dev $(DD)ap3250.dev $(DD)npdl.dev $(DD)rpdl.dev $(DD)fmpr.dev $(DD)fmlbp.dev $(DD)ml600.dev $(DD)jj100.dev $(DD)lbp310.dev $(DD)lbp320.dev $(DD)mj700v2c.dev $(DD)mj500c.dev $(DD)mj6000c.dev $(DD)mj8000c.dev $(DD)pr201.dev $(DD)pr150.dev $(DD)pr1000.dev $(DD)pr1000_4.dev $(DD)lips2p.dev $(DD)bjc880j.dev $(DD)bjcmono.dev $(DD)bjcgray.dev $(DD)bjccmyk.dev $(DD)bjccolor.dev $(DD)escp.dev $(DD)lp8000.dev $(DD)lq850.dev $(DD)photoex.dev $(DD)st800.dev $(DD)stcolor.dev $(DD)alc1900.dev $(DD)alc2000.dev $(DD)alc4000.dev $(DD)alc4100.dev $(DD)alc8500.dev $(DD)alc8600.dev $(DD)alc9100.dev $(DD)lp3000c.dev $(DD)lp8000c.dev $(DD)lp8200c.dev $(DD)lp8300c.dev $(DD)lp8500c.dev $(DD)lp8800c.dev $(DD)lp9000c.dev $(DD)lp9200c.dev $(DD)lp9500c.dev $(DD)lp9800c.dev $(DD)lps6500.dev $(DD)epl2050.dev $(DD)epl2050p.dev $(DD)epl2120.dev $(DD)epl2500.dev $(DD)epl2750.dev $(DD)epl5800.dev $(DD)epl5900.dev $(DD)epl6100.dev $(DD)epl6200.dev $(DD)lp1800.dev $(DD)lp1900.dev $(DD)lp2200.dev $(DD)lp2400.dev $(DD)lp2500.dev $(DD)lp7500.dev $(DD)lp7700.dev $(DD)lp7900.dev $(DD)lp8100.dev $(DD)lp8300f.dev $(DD)lp8400f.dev $(DD)lp8600.dev $(DD)lp8600f.dev $(DD)lp8700.dev $(DD)lp8900.dev $(DD)lp9000b.dev $(DD)lp9100.dev $(DD)lp9200b.dev $(DD)lp9300.dev $(DD)lp9400.dev $(DD)lp9600.dev $(DD)lp9600s.dev $(DD)lps4500.dev $(DD)eplcolor.dev $(DD)eplmono.dev $(DD)hl7x0.dev $(DD)hl1240.dev $(DD)hl1250.dev $(DD)appledmp.dev $(DD)iwhi.dev $(DD)iwlo.dev $(DD)iwlq.dev $(DD)atx23.dev $(DD)atx24.dev $(DD)atx38.dev $(DD)itk24i.dev $(DD)itk38.dev $(DD)coslw2p.dev $(DD)coslwxl.dev $(DD)ccr.dev $(DD)cif.dev $(DD)inferno.dev $(DD)mgr4.dev $(DD)mgr8.dev $(DD)mgrgray2.dev $(DD)mgrgray4.dev $(DD)mgrgray8.dev $(DD)mgrmono.dev $(DD)miff24.dev $(DD)plan9bm.dev $(DD)xcf.dev
!if "$(WITH_CONTRIB)" == "1"
DEVICE_DEVS16=$(DEVICE_DEVS16) $(CONTRIB_DEVS)
@@ -1733,6 +1819,10 @@ BEGINFILES2=$(BEGINFILES2) $(BSCFILE)
!include $(XPSSRCDIR)\xpsromfs.mak
!endif
+!if $(BUILD_PDF)
+!include $(PDFSRCDIR)\pdfromfs.mak
+!endif
+
!include $(GLSRCDIR)\winlib.mak
!if $(BUILD_PCL)
@@ -1746,6 +1836,10 @@ BEGINFILES2=$(BEGINFILES2) $(BSCFILE)
!include $(XPSSRCDIR)\xps.mak
!endif
+!if $(BUILD_PDF)
+!include $(PDFSRCDIR)\pdf.mak
+!endif
+
!if $(BUILD_GPDL)
!include $(GPDLSRCDIR)\gpdl.mak
!endif
@@ -1761,6 +1855,7 @@ GSDLL_OBJS=$(PSOBJ)gsdll.$(OBJ) $(GLOBJ)gp_msdll.$(OBJ)
GPCL6DLL_DLL=$(BINDIR)\$(GPCL6DLL).dll
GXPSDLL_DLL=$(BINDIR)\$(GXPSDLL).dll
+GPDFDLL_DLL=$(BINDIR)\$(GPDFDLL).dll
GPDLDLL_DLL=$(BINDIR)\$(GPDLDLL).dll
INT_ARCHIVE_SOME=$(GLOBJ)gconfig.$(OBJ) $(GLOBJ)gscdefs.$(OBJ)
@@ -1831,6 +1926,27 @@ $(XPSGEN)xpslib.rsp: $(TOP_MAKEFILES)
!if $(TDEBUG) != 0
+$(PDFGEN)pdflib.rsp: $(TOP_MAKEFILES)
+ echo /NODEFAULTLIB:LIBC.lib > $(PDFGEN)pdflib.rsp
+ echo /NODEFAULTLIB:LIBCMT.lib >> $(PDFGEN)pdflib.rsp
+!ifdef METRO
+ echo kernel32.lib runtimeobject.lib rpcrt4.lib >> $(PDFGEN)pdflib.rsp
+!else
+ echo LIBCMTD.lib >> $(PDFGEN)pdflib.rsp
+!endif
+!else
+$(PDFGEN)pdflib.rsp: $(TOP_MAKEFILES)
+ echo /NODEFAULTLIB:LIBC.lib > $(PDFGEN)pdflib.rsp
+ echo /NODEFAULTLIB:LIBCMTD.lib >> $(PDFGEN)pdflib.rsp
+!ifdef METRO
+ echo kernel32.lib runtimeobject.lib rpcrt4.lib >> $(PDFGEN)pdflib.rsp
+!else
+ echo LIBCMT.lib >> $(PDFGEN)pdflib.rsp
+!endif
+!endif
+
+!if $(TDEBUG) != 0
+
$(GPDLGEN)gpdllib.rsp: $(TOP_MAKEFILES)
echo /NODEFAULTLIB:LIBC.lib > $(XPSGEN)gpdllib.rsp
echo /NODEFAULTLIB:LIBCMT.lib >> $(XPSGEN)gpdllib.rsp
@@ -1976,6 +2092,32 @@ $(GXPS_XE): $(GXPSDLL_DLL) $(DWMAINOBJS) $(GS_OBJ).res $(TOP_MAKEFILES)
$(LINK) $(LCT) @$(XPSGEN)gxpswin.rsp $(DWMAINOBJS) $(BINDIR)\$(GXPSDLL).lib $(LINKLIBPATH) @$(LIBCTR) $(GS_OBJ).res
del $(XPSGEN)gxpswin.rsp
+$(GPDFDLL_DLL): $(ECHOGS_XE) $(GSDLL_OBJ).res $(LIBCTR) $(LIB_ALL) $(PDF_DEVS_ALL) $(PDFGEN)pdflib.rsp \
+ $(PDFOBJ)pdfromfs$(COMPILE_INITS).$(OBJ) $(ld_tr) $(pdf_tr) $(MAIN_OBJ) $(PDF_TOP_OBJS) \
+ $(XOBJS) $(INT_ARCHIVE_SOME) $(TOP_MAKEFILES)
+ echo Linking $(GPDFDLL) $(GPDFDLL_DLL) $(METRO)
+ copy $(pdfld_tr) $(PDFGEN)gpdfwin.tr
+ echo $(MAIN_OBJ) $(PDF_TOP_OBJS) $(INT_ARCHIVE_SOME) $(XOBJS) >> $(PDFGEN)gpdfwin.tr
+ echo $(PCLOBJ)pdfromfs$(COMPILE_INITS).$(OBJ) >> $(PDFGEN)gpdfwin.tr
+ echo /DLL /DEF:$(PLSRCDIR)\$(GPDFDLL).def /OUT:$(GPDFDLL_DLL) > $(PDFGEN)gpdfwin.rsp
+!if "$(PROFILE)"=="1"
+ echo /PROFILE >> $(PDFGEN)gpdfwin.rsp
+!endif
+ $(LINK) $(LCT) @$(PDFGEN)gpdfwin.rsp $(GPDFDLL_OBJS) @$(PDFGEN)gpdfwin.tr @$(PDFGEN)pdflib.rsp $(LINKLIBPATH) @$(LIBCTR) $(GSDLL_OBJ).res
+ del $(PCLGEN)gpdfwin.rsp
+
+$(GPDF_XE): $(GPDFDLL_DLL) $(DWMAINOBJS) $(GS_OBJ).res $(TOP_MAKEFILES)
+ echo /SUBSYSTEM:CONSOLE > $(PDFGEN)gpdfwin.rsp
+!if "$(PROFILE)"=="1"
+ echo /PROFILE >> $(PDFGEN)gpdfwin.rsp
+!endif
+!ifdef WIN64
+ echo /OUT:$(GPDF_XE) >> $(PDFGEN)gpdfwin.rsp
+!else
+ echo /OUT:$(GPDF_XE) >> $(PDFGEN)gpdfwin.rsp
+!endif
+ $(LINK) $(LCT) @$(PDFGEN)gpdfwin.rsp $(DWMAINOBJS) $(BINDIR)\$(GPDFDLL).lib $(LINKLIBPATH) @$(LIBCTR) $(GS_OBJ).res
+ del $(PDFGEN)gpdfwin.rsp
$(GPDLDLL_DLL): $(ECHOGS_XE) $(GSDLL_OBJ).res $(LIBCTR) $(LIB_ALL) $(PCL_DEVS_ALL) $(XPS_DEVS_ALL) $(GS_ALL) \
@@ -2108,6 +2250,19 @@ $(GXPS_XE): $(ECHOGS_XE) $(LIBCTR) $(LIB_ALL) $(WINMAINOBJS) $(XPS_DEVS_ALL) $(X
del $(XPSGEN)xpswin.rsp
del $(XPSGEN)gxpswin.tr
+$(GPDF_XE): $(ECHOGS_XE) $(LIBCTR) $(LIB_ALL) $(WINMAINOBJS) $(PDF_DEVS_ALL) $(PDFGEN)pdflib.rsp \
+ $(PDF_TOP_OBJS) $(PDFOBJ)pdfromfs$(COMPILE_INITS).$(OBJ) \
+ $(ld_tr) $(pdf_tr) $(MAIN_OBJ) $(XOBJS) $(INT_ARCHIVE_SOME) \
+ $(TOP_MAKEFILES)
+ copy $(pdfld_tr) $(PDFGEN)gpdfwin.tr
+ echo $(WINMAINOBJS) $(MAIN_OBJ) $(PDF_TOP_OBJS) $(INT_ARCHIVE_SOME) $(XOBJS) >> $(PDFGEN)gpdfwin.tr
+ echo $(PCLOBJ)pdfromfs$(COMPILE_INITS).$(OBJ) >> $(PDFGEN)gpdfwin.tr
+ echo /SUBSYSTEM:CONSOLE > $(PDFGEN)pdfwin.rsp
+ echo /OUT:$(GPDF_XE) >> $(XPSGEN)pdfwin.rsp
+ $(LINK) $(LCT) @$(PDFGEN)pdfwin.rsp @$(PDFGEN)gpdfwin.tr $(LINKLIBPATH) @$(LIBCTR) @$(PDFGEN)pdflib.rsp
+ del $(XPSGEN)pdfwin.rsp
+ del $(XPSGEN)gpdfwin.tr
+
$(GPDL_XE): $(ECHOGS_XE) $(ld_tr) $(gpdl_tr) $(LIBCTR) $(LIB_ALL) $(WINMAINOBJS) $(XPS_DEVS_ALL) $(PCL_DEVS_ALL) $(GS_ALL) \
$(GPDLGEN)gpdllib.rsp $(GPDLOBJ)pdlromfs$(COMPILE_INITS).$(OBJ) \
$(GPDL_PSI_TOP_OBJS) $(PCL_PXL_TOP_OBJS) $(PSI_TOP_OBJ) $(XPS_TOP_OBJ) \
@@ -2161,6 +2316,9 @@ gpcl6debug:
gxpsdebug:
nmake -f $(MAKEFILE) $(DEBUGDEFS) FT_BRIDGE=$(FT_BRIDGE) gxps
+gpdfdebug:
+ nmake -f $(MAKEFILE) DEVSTUDIO="$(DEVSTUDIO)" FT_BRIDGE=$(FT_BRIDGE) $(DEBUGDEFS) $(WINDEFS) gpdf
+
gpdldebug:
nmake -f $(MAKEFILE) $(DEBUGDEFS) FT_BRIDGE=$(FT_BRIDGE) gpdl
@@ -2187,6 +2345,9 @@ gpcl6memento:
gxpsmemento:
nmake -f $(MAKEFILE) $(MEMENTODEFS) FT_BRIDGE=$(FT_BRIDGE) gxps
+gpdfmemento:
+ nmake -f $(MAKEFILE) DEVSTUDIO="$(DEVSTUDIO)" FT_BRIDGE=$(FT_BRIDGE) $(MEMENTODEFS) $(WINDEFS) gpdf
+
gpdlmemento:
nmake -f $(MAKEFILE) $(MEMENTODEFS) FT_BRIDGE=$(FT_BRIDGE) gpdl
@@ -2214,6 +2375,9 @@ gpcl6profile:
gxpsprofile:
nmake -f $(MAKEFILE) $(PROFILEDEFS) FT_BRIDGE=$(FT_BRIDGE) gxps
+gpdfprofile:
+ nmake -f $(MAKEFILE) DEVSTUDIO="$(DEVSTUDIO)" FT_BRIDGE=$(FT_BRIDGE) $(PROFILEDEFS) $(WINDEFS) gpdf
+
gpdlprofile:
nmake -f $(MAKEFILE) $(PROFILEDEFS) FT_BRIDGE=$(FT_BRIDGE) gpdl
@@ -2286,8 +2450,8 @@ ufst-lib:
ufst-debug: ufst-lib
nmake -f $(MAKEFILE) $(RECURSIVEDEFS) $(UFSTBASEDEFS) $(UFSTDEBUGDEFS) UFST_CFLAGS="$(UFST_CFLAGS)"
-gpcl6-ufst-debug: ufst-lib
- nmake -f $(MAKEFILE) $(RECURSIVEDEFS) $(UFSTBASEDEFS) $(UFSTDEBUGDEFS) UFST_CFLAGS="$(UFST_CFLAGS)" gpcl6
+ufst-debug-pcl: ufst-lib
+ nmake -f $(MAKEFILE) $(RECURSIVEDEFS) $(UFSTBASEDEFS) $(UFSTDEBUGDEFS) UFST_CFLAGS="$(UFST_CFLAGS)" pcl
ufst-debugclean: ufst-lib
nmake -f $(MAKEFILE) $(RECURSIVEDEFS) $(UFSTBASEDEFS) $(UFSTDEBUGDEFS) UFST_CFLAGS="$(UFST_CFLAGS)" clean
@@ -2298,8 +2462,8 @@ ufst-debugbsc: ufst-lib
ufst: ufst-lib
nmake -f $(MAKEFILE) $(RECURSIVEDEFS) $(UFSTBASEDEFS) $(UFSTDEFS) UFST_CFLAGS="$(UFST_CFLAGS)"
-gpcl6-ufst: ufst-lib
- nmake -f $(MAKEFILE) $(RECURSIVEDEFS) $(UFSTBASEDEFS) $(UFSTDEFS) UFST_CFLAGS="$(UFST_CFLAGS)" gpcl6
+ufst-pcl: ufst-lib
+ nmake -f $(MAKEFILE) $(RECURSIVEDEFS) $(UFSTBASEDEFS) $(UFSTDEFS) UFST_CFLAGS="$(UFST_CFLAGS)" pcl
ufst-clean: ufst-lib
nmake -f $(MAKEFILE) $(RECURSIVEDEFS) $(UFSTBASEDEFS) $(UFSTDEFS) UFST_CFLAGS="$(UFST_CFLAGS)" clean
@@ -2317,6 +2481,9 @@ gpcl6:$(GPCL_XE)
gxps:$(GXPS_XE)
$(NO_OP)
+gpdf:$(GPDF_XE)
+ $(NO_OP)
+
gpdl:$(GPDL_XE)
$(NO_OP)
diff --git a/psi/nsisinst.nsi b/psi/nsisinst.nsi
index dd9266ae..cd983927 100644
--- a/psi/nsisinst.nsi
+++ b/psi/nsisinst.nsi
@@ -30,6 +30,9 @@
; hand, it removes the short-cuts on Uninstall (which the Winzipse-based
; installer doesn't do) and also does not leave behind empty directories.
+; Newer nsis releases deprecate ansi encoding, require Unicode
+Unicode True
+
; the following is from: http://nsis.sourceforge.net/StrRep
!define StrRep "!insertmacro StrRep"
!macro StrRep output string old new
diff --git a/psi/zbfont.c b/psi/zbfont.c
index fa2597d7..09589159 100644
--- a/psi/zbfont.c
+++ b/psi/zbfont.c
@@ -144,6 +144,14 @@ zfont_glyph_name(gs_font *font, gs_glyph index, gs_const_string *pstr)
return 0;
}
+#define font_proc_glyph_name1\
+ int (gs_font *font, gs_glyph glyph, gs_const_string *pstr)
+
+void get_zfont_glyph_name( void **proc)
+{
+ *proc = zfont_glyph_name;
+}
+
static gs_char
gs_font_map_glyph_by_dict(const gs_memory_t *mem, const ref *map, gs_glyph glyph, ushort *u, unsigned int length)
{
diff --git a/psi/zcfont.c b/psi/zcfont.c
index 1ef99e36..e1758261 100644
--- a/psi/zcfont.c
+++ b/psi/zcfont.c
@@ -64,7 +64,7 @@ zcshow(i_ctx_t *i_ctx_p)
return code;
}
sslot = *proc_op; /* save kerning proc */
- pop(2);
+ ref_stack_pop(&o_stack, 2);
return cshow_continue(i_ctx_p);
}
static int
diff --git a/psi/zchar1.c b/psi/zchar1.c
index c289b3e2..064b909a 100644
--- a/psi/zchar1.c
+++ b/psi/zchar1.c
@@ -557,7 +557,7 @@ bbox_finish(i_ctx_t *i_ctx_p, op_proc_t cont, op_proc_t *exec_cont)
case 0: /* all done */
/* Call the continuation now. */
if (psbpt)
- pop(2);
+ ref_stack_pop(&o_stack, 2);
*exec_cont = cont;
return 0;
case type1_result_callothersubr: /* unknown OtherSubr */
diff --git a/psi/zcharout.c b/psi/zcharout.c
index 42f8ebbb..c204a956 100644
--- a/psi/zcharout.c
+++ b/psi/zcharout.c
@@ -326,8 +326,26 @@ zchar_charstring_data(gs_font *font, const ref *pgref, gs_glyph_data_t *pgd)
charstring_is_notdef_proc(font->memory, pcstr)
)
return charstring_make_notdef(pgd, font);
- else
+ else {
+ /* Bug #703779. It seems that other tools can modify type 1 fonts, using
+ * a procedure in place of a CharString for the /.notdef. In this case the
+ * culprit is "Polylogics DIAD White Pages Pagination". Doing this prevents
+ * pdfwrite from being able to write the font. Obviously we cannot have a
+ * PostScript procedure in a PDF file. Adobe Acrobat Distiller replaces
+ * the procedure with a simple 'endchar' CharString, so we now do the
+ * same. I've chosen to leave the specific ADOBEPS4 test above unchanged, rather
+ * than roll it in here, because I can't find an example file for it and
+ * can't be certain that 'pgref' will be a name in that case.
+ */
+ ref namestr;
+
+ if (r_has_type(pgref, t_name)) {
+ name_string_ref(pgd->memory, pgref, &namestr);
+ if (r_size(&namestr) == 7 && !memcmp(namestr.value.bytes, ".notdef", 7))
+ return charstring_make_notdef(pgd, font);
+ }
return_error(gs_error_typecheck);
+ }
}
gs_glyph_data_from_string(pgd, pcstr->value.const_bytes, r_size(pcstr),
NULL);
diff --git a/psi/zcie.c b/psi/zcie.c
index 616b4b71..93284186 100644
--- a/psi/zcie.c
+++ b/psi/zcie.c
@@ -144,7 +144,7 @@ dict_matrix3_param(const gs_memory_t *mem,
/* Get 3 procedures from a dictionary. */
int
-dict_proc3_param(const gs_memory_t *mem, const ref *pdref, const char *kstr, ref proc3[3])
+dict_proc3_param(const gs_memory_t *mem, const ref *pdref, const char *kstr, ref *proc3)
{
return dict_proc_array_param(mem, pdref, kstr, 3, proc3);
}
@@ -448,8 +448,11 @@ ciedefgspace(i_ctx_t *i_ctx_p, ref *CIEDict, uint64_t dictkey)
bool has_defg_procs, has_abc_procs, has_lmn_procs;
gs_ref_memory_t *imem = (gs_ref_memory_t *)mem;
- if (dictkey != 0)
+ if (dictkey != 0) {
pcs = gsicc_find_cs(dictkey, igs);
+ if (pcs && gs_color_space_num_components(pcs) != 4)
+ pcs = NULL;
+ }
else
pcs = NULL;
push(1); /* Sacrificial */
@@ -558,8 +561,11 @@ ciedefspace(i_ctx_t *i_ctx_p, ref *CIEDict, uint64_t dictkey)
bool has_def_procs, has_lmn_procs, has_abc_procs;
gs_ref_memory_t *imem = (gs_ref_memory_t *)mem;
- if (dictkey != 0)
+ if (dictkey != 0) {
pcs = gsicc_find_cs(dictkey, igs);
+ if (pcs && gs_color_space_num_components(pcs) != 3)
+ pcs = NULL;
+ }
else
pcs = NULL;
push(1); /* Sacrificial */
@@ -626,8 +632,11 @@ cieabcspace(i_ctx_t *i_ctx_p, ref *CIEDict, uint64_t dictkey)
gs_ref_memory_t *imem = (gs_ref_memory_t *)mem;
/* See if the color space is in the profile cache */
- if (dictkey != 0)
+ if (dictkey != 0) {
pcs = gsicc_find_cs(dictkey, igs);
+ if (pcs && gs_color_space_num_components(pcs) != 3)
+ pcs = NULL;
+ }
else
pcs = NULL;
@@ -690,8 +699,11 @@ cieaspace(i_ctx_t *i_ctx_p, ref *CIEdict, uint64_t dictkey)
bool has_lmn_procs;
/* See if the color space is in the profile cache */
- if (dictkey != 0)
+ if (dictkey != 0) {
pcs = gsicc_find_cs(dictkey, igs);
+ if (pcs && gs_color_space_num_components(pcs) != 1)
+ pcs = NULL;
+ }
else
pcs = NULL;
push(1); /* Sacrificial */
diff --git a/psi/zcolor.c b/psi/zcolor.c
index 34a9326f..64e0b8d0 100644
--- a/psi/zcolor.c
+++ b/psi/zcolor.c
@@ -688,7 +688,7 @@ zsettransfer(i_ctx_t * i_ctx_p)
if ((code = gs_settransfer_remap(igs, gs_mapped_transfer, false)) < 0)
return code;
push_op_estack(zcolor_reset_transfer);
- pop(1);
+ ref_stack_pop(&o_stack, 1);
return zcolor_remap_one( i_ctx_p,
&istate->transfer_procs.gray,
igs->set_transfer.gray,
@@ -1051,7 +1051,7 @@ static int setgrayspace(i_ctx_t * i_ctx_p, ref *r, int *stage, int *cont, int CI
*stage = 1;
break;
}
- pop(1);
+ ref_stack_pop(&o_stack, 1);
*cont = 1;
*stage = 3;
code = setcolorspace_nosubst(i_ctx_p);
@@ -1075,7 +1075,7 @@ static int setgrayspace(i_ctx_t * i_ctx_p, ref *r, int *stage, int *cont, int CI
*/
if (!r_has_type(op, t_boolean))
return_error(gs_error_typecheck);
- pop(1);
+ ref_stack_pop(&o_stack, 1);
*stage = 1;
*cont = 1;
if (op->value.boolval) {
@@ -1276,7 +1276,7 @@ static int setrgbspace(i_ctx_t * i_ctx_p, ref *r, int *stage, int *cont, int CIE
*stage = 1;
break;
}
- pop(1);
+ ref_stack_pop(&o_stack, 1);
*stage = 3;
code = setcolorspace_nosubst(i_ctx_p);
if (code != 0)
@@ -1299,7 +1299,7 @@ static int setrgbspace(i_ctx_t * i_ctx_p, ref *r, int *stage, int *cont, int CIE
*/
if (!r_has_type(op, t_boolean))
return_error(gs_error_typecheck);
- pop(1);
+ ref_stack_pop(&o_stack, 1);
*stage = 1;
*cont = 1;
if (op->value.boolval) {
@@ -1391,7 +1391,7 @@ static int rgbbasecolor(i_ctx_t * i_ctx_p, ref *space, int base, int *stage, int
switch (base) {
case 0:
- pop(2);
+ ref_stack_pop(&o_stack, 2);
op = osp;
/* If R == G == B, then this is gray, so just use it. Avoids
* rounding errors.
@@ -1500,7 +1500,7 @@ static int rgbbasecolor(i_ctx_t * i_ctx_p, ref *space, int base, int *stage, int
return_error(gs_error_typecheck);
} else
BG = (float)op->value.intval;
- pop(1);
+ ref_stack_pop(&o_stack, 1);
op = osp;
if (BG < 0)
BG = 0;
@@ -1628,7 +1628,7 @@ static int setcmykspace(i_ctx_t * i_ctx_p, ref *r, int *stage, int *cont, int CI
*stage = 1;
break;
}
- pop(1);
+ ref_stack_pop(&o_stack, 1);
*stage = 3;
code = setcolorspace_nosubst(i_ctx_p);
if (code != 0)
@@ -1651,7 +1651,7 @@ static int setcmykspace(i_ctx_t * i_ctx_p, ref *r, int *stage, int *cont, int CI
*/
if (!r_has_type(op, t_boolean))
return_error(gs_error_typecheck);
- pop(1);
+ ref_stack_pop(&o_stack, 1);
*stage = 1;
*cont = 1;
if (op->value.boolval) {
@@ -1741,7 +1741,7 @@ static int cmykbasecolor(i_ctx_t * i_ctx_p, ref *space, int base, int *stage, in
switch (base) {
case 0:
- pop(3);
+ ref_stack_pop(&o_stack, 3);
op = osp;
Gray = (0.3 * CMYK[0]) + (0.59 * CMYK[1]) + (0.11 * CMYK[2]) + CMYK[3];
if (Gray > 1.0)
@@ -1752,7 +1752,7 @@ static int cmykbasecolor(i_ctx_t * i_ctx_p, ref *space, int base, int *stage, in
break;
case 1:
case 2:
- pop(1);
+ ref_stack_pop(&o_stack, 1);
op = osp;
RGB[0] = 1.0 - (CMYK[0] + CMYK[3]);
if (RGB[0] < 0)
@@ -3320,7 +3320,7 @@ static int ciebasecolor(i_ctx_t * i_ctx_p, ref *space, int base, int *stage, int
break;
}
/* Remove teh requisite number of values */
- pop(components);
+ ref_stack_pop(&o_stack, components);
op = osp;
/* Find out how many values we need to return, which
* depends on the requested space.
@@ -3645,7 +3645,7 @@ static int sepbasecolor(i_ctx_t * i_ctx_p, ref *space, int base, int *stage, int
if (!use) {
*stage = 0;
*cont = 0;
- pop(1);
+ ref_stack_pop(&o_stack, 1);
op = osp;
switch(base) {
case 0:
@@ -4475,7 +4475,7 @@ static int devicenbasecolor(i_ctx_t * i_ctx_p, ref *space, int base, int *stage,
if (code < 0)
return code;
n_comp = r_size(&narray);
- pop(n_comp);
+ ref_stack_pop(&o_stack, n_comp);
op = osp;
switch(base) {
case 0:
@@ -4618,7 +4618,7 @@ indexed_cont(i_ctx_t *i_ctx_p)
esp -= num_csme;
return code;
}
- pop(m);
+ ref_stack_pop(&o_stack, m);
op -= m;
if (i == (int)ep[csme_hival].value.intval) { /* All done. */
esp -= num_csme;
@@ -4878,7 +4878,7 @@ static int indexedbasecolor(i_ctx_t * i_ctx_p, ref *space, int base, int *stage,
return_error (gs_error_typecheck);
index = op->value.intval;
/* And remove it from the stack. */
- pop(1);
+ ref_stack_pop(&o_stack, 1);
op = osp;
/* Make sure we have enough space on the op stack to hold
@@ -5094,7 +5094,7 @@ static int patternbasecolor(i_ctx_t * i_ctx_p, ref *space, int base, int *stage,
*/
}
- pop(1);
+ ref_stack_pop(&o_stack, 1);
op = osp;
switch(base) {
case 0:
@@ -5428,7 +5428,7 @@ static int labbasecolor(i_ctx_t * i_ctx_p, ref *space, int base, int *stage, int
int i, components=1;
components = 3;
- pop(components);
+ ref_stack_pop(&o_stack, components);
op = osp;
components = 3;
push(components);
@@ -5519,6 +5519,60 @@ static int checkGamma(i_ctx_t * i_ctx_p, ref *CIEdict, int numvalues)
return 0;
}
+static int hashcalgrayspace(i_ctx_t *i_ctx_p, ref *space, gs_md5_state_t *md5)
+{
+ int code = 0;
+ ref cgdict1, spacename, *tempref;
+ static const int ncomps = 1;
+ float g = 1.0;
+ int i;
+
+ code = array_get(imemory, space, 0, &spacename);
+ if (code < 0)
+ return 0;
+ gs_md5_append(md5, (const gs_md5_byte_t *)&spacename.value.pname, sizeof(spacename.value.pname));
+
+ code = array_get(imemory, space, 1, &cgdict1);
+ if (code < 0)
+ return 0;
+ check_read_type(cgdict1, t_dictionary);
+
+ code = dict_find_string(&cgdict1, "WhitePoint", &tempref);
+ if (code > 0) {
+ code = hasharray(i_ctx_p, tempref, md5);
+ }
+ if (code <= 0) {
+ float WP = 0.0;
+ for (i = 0; i < 3; i++) {
+ gs_md5_append(md5, (const gs_md5_byte_t *)&WP, sizeof(WP));
+ }
+ }
+
+ code = dict_find_string(&cgdict1, "BlackPoint", &tempref);
+ if (code > 0) {
+ code = hasharray(i_ctx_p, tempref, md5);
+ }
+ if (code <= 0) {
+ float BP = 0.0;
+ for (i = 0; i < 3; i++) {
+ gs_md5_append(md5, (const gs_md5_byte_t *)&BP, sizeof(BP));
+ }
+ }
+
+ code = dict_find_string(&cgdict1, "Gamma", &tempref);
+ if (code > 0) {
+ if (r_has_type(tempref, t_real))
+ g = tempref->value.realval;
+ else if (r_has_type(tempref, t_integer))
+ g = (float)tempref->value.intval;
+ }
+
+ gs_md5_append(md5, (const gs_md5_byte_t *)&g, sizeof(g));
+
+ gs_md5_append(md5, (const gs_md5_byte_t *)&ncomps, sizeof(ncomps));
+ return 1;
+}
+
/* Here we set up an equivalent ICC form for the CalGray color space */
static int setcalgrayspace(i_ctx_t * i_ctx_p, ref *r, int *stage, int *cont, int CIESubst)
{
@@ -5528,6 +5582,9 @@ static int setcalgrayspace(i_ctx_t * i_ctx_p, ref *r, int *stage, int *cont, int
double dflt_gamma = 1.0;
static const float dflt_black[3] = {0,0,0}, dflt_white[3] = {0,0,0};
gs_client_color cc;
+ uint64_t dictkey = 0;
+ gs_md5_state_t md5;
+ byte key[16];
*cont = 0;
code = array_get(imemory, r, 1, &graydict);
@@ -5558,8 +5615,15 @@ static int setcalgrayspace(i_ctx_t * i_ctx_p, ref *r, int *stage, int *cont, int
return code;
if (white[0] <= 0 || white[1] != 1.0 || white[2] <= 0)
return_error(gs_error_rangecheck);
- code = seticc_cal(i_ctx_p, white, black, &gamma, NULL, 1,
- graydict.value.saveid);
+
+ gs_md5_init(&md5);
+ hashcalgrayspace(i_ctx_p, r, &md5);
+ gs_md5_finish(&md5, key);
+ if (code > 0) {
+ dictkey = *(uint64_t *)&key[sizeof(key) - sizeof(uint64_t)];
+ }
+
+ code = seticc_cal(i_ctx_p, white, black, &gamma, NULL, 1, dictkey);
if ( code < 0)
return gs_rethrow(code, "setting CalGray color space");
cc.pattern = 0x00;
@@ -5601,6 +5665,72 @@ static int validatecalgrayspace(i_ctx_t * i_ctx_p, ref **r)
return 0;
}
+static int hashcalrgbspace(i_ctx_t *i_ctx_p, ref *space, gs_md5_state_t *md5)
+{
+ int code = 0;
+ ref crgbdict1, spacename, *tempref;
+ static const int ncomps = 3;
+ int i;
+
+ code = array_get(imemory, space, 0, &spacename);
+ if (code < 0)
+ return 0;
+ gs_md5_append(md5, (const gs_md5_byte_t *)&spacename.value.pname, sizeof(spacename.value.pname));
+
+ code = array_get(imemory, space, 1, &crgbdict1);
+ if (code < 0)
+ return 0;
+ check_read_type(crgbdict1, t_dictionary);
+
+ code = dict_find_string(&crgbdict1, "WhitePoint", &tempref);
+ if (code > 0) {
+ code = hasharray(i_ctx_p, tempref, md5);
+ }
+ if (code <= 0) {
+ float WP = 0.0;
+ for (i = 0; i < 3; i++) {
+ gs_md5_append(md5, (const gs_md5_byte_t *)&WP, sizeof(WP));
+ }
+ }
+
+ code = dict_find_string(&crgbdict1, "BlackPoint", &tempref);
+ if (code > 0) {
+ code = hasharray(i_ctx_p, tempref, md5);
+ }
+ if (code <= 0) {
+ float BP = 0.0;
+ for (i = 0; i < 3; i++) {
+ gs_md5_append(md5, (const gs_md5_byte_t *)&BP, sizeof(BP));
+ }
+ }
+
+ code = dict_find_string(&crgbdict1, "Matrix", &tempref);
+ if (code > 0) {
+ code = hasharray(i_ctx_p, tempref, md5);
+ }
+ if (code <= 0) {
+ static const float mt[9] = {1,0,0,0,1,0,0,0,1};
+
+ for (i = 0; i < 9; i++) {
+ gs_md5_append(md5, (const gs_md5_byte_t *)&(mt[i]), sizeof(mt[i]));
+ }
+ }
+
+ code = dict_find_string(&crgbdict1, "Gamma", &tempref);
+ if (code > 0) {
+ code = hasharray(i_ctx_p, tempref, md5);
+ }
+ if (code <= 0) {
+ static const float g[3] = { 1.0, 1.0, 1.0 };
+ for (i = 0; i < 3; i++) {
+ gs_md5_append(md5, (const gs_md5_byte_t *)&(g[i]), sizeof(g[i]));
+ }
+ }
+
+ gs_md5_append(md5, (const gs_md5_byte_t *)&ncomps, sizeof(ncomps));
+ return 1;
+}
+
/* Here we set up an equivalent ICC form for the CalRGB color space */
static int setcalrgbspace(i_ctx_t * i_ctx_p, ref *r, int *stage, int *cont, int CIESubst)
{
@@ -5612,6 +5742,9 @@ static int setcalrgbspace(i_ctx_t * i_ctx_p, ref *r, int *stage, int *cont, int
static const float dflt_matrix[9] = {1,0,0,0,1,0,0,0,1};
int i;
gs_client_color cc;
+ uint64_t dictkey = 0;
+ gs_md5_state_t md5;
+ byte key[16];
*cont = 0;
code = array_get(imemory, r, 1, &rgbdict);
@@ -5654,7 +5787,13 @@ static int setcalrgbspace(i_ctx_t * i_ctx_p, ref *r, int *stage, int *cont, int
dflt_matrix );
if (code < 0)
return code;
- code = seticc_cal(i_ctx_p, white, black, gamma, matrix, 3, rgbdict.value.saveid);
+ gs_md5_init(&md5);
+ hashcalrgbspace(i_ctx_p, r, &md5);
+ gs_md5_finish(&md5, key);
+ if (code > 0) {
+ dictkey = *(uint64_t *)&key[sizeof(key) - sizeof(uint64_t)];
+ }
+ code = seticc_cal(i_ctx_p, white, black, gamma, matrix, 3, dictkey);
if ( code < 0)
return gs_rethrow(code, "setting CalRGB color space");
cc.pattern = 0x00;
@@ -5814,7 +5953,7 @@ static int seticcspace(i_ctx_t * i_ctx_p, ref *r, int *stage, int *cont, int CIE
return code;
*stage = 0;
}
- pop(1);
+ ref_stack_pop(&o_stack, 1);
}
if (code != 0)
return code;
diff --git a/psi/zcolor1.c b/psi/zcolor1.c
index e33c4377..8c6c2bf8 100644
--- a/psi/zcolor1.c
+++ b/psi/zcolor1.c
@@ -82,7 +82,7 @@ zsetblackgeneration(i_ctx_t *i_ctx_p)
if (code < 0)
return code;
istate->black_generation = *op;
- pop(1);
+ ref_stack_pop(&o_stack, 1);
push_op_estack(zcolor_remap_color);
return zcolor_remap_one(i_ctx_p, &istate->black_generation,
igs->black_generation, igs,
@@ -114,7 +114,7 @@ zsetcolortransfer(i_ctx_t *i_ctx_p)
)
return code;
/* Use osp rather than op here, because zcolor_remap_one pushes. */
- pop(4);
+ ref_stack_pop(&o_stack, 4);
push_op_estack(zcolor_reset_transfer);
if ((code = zcolor_remap_one(i_ctx_p,
&istate->transfer_procs.red,
@@ -156,7 +156,7 @@ zsetundercolorremoval(i_ctx_t *i_ctx_p)
if (code < 0)
return code;
istate->undercolor_removal = *op;
- pop(1);
+ ref_stack_pop(&o_stack, 1);
push_op_estack(zcolor_remap_color);
return zcolor_remap_one(i_ctx_p, &istate->undercolor_removal,
igs->undercolor_removal, igs,
diff --git a/psi/zdevice.c b/psi/zdevice.c
index a9d4e8a1..b119a768 100644
--- a/psi/zdevice.c
+++ b/psi/zdevice.c
@@ -222,7 +222,7 @@ zgetbitsrect(i_ctx_t *i_ctx_p)
rect.q.y = rect.p.y + h;
params.options = options;
params.data[0] = op->value.bytes;
- code = (*dev_proc(dev, get_bits_rectangle))(dev, &rect, &params, NULL);
+ code = (*dev_proc(dev, get_bits_rectangle))(dev, &rect, &params);
if (code < 0)
return code;
make_int(op - 7, h);
@@ -289,7 +289,7 @@ zget_device_params(i_ctx_t *i_ctx_p, bool is_hardware)
if (op[-1].value.pdevice == NULL)
/* This can happen if we invalidated devices on the stack by calling nulldevice after they were pushed */
return_error(gs_error_undefined);
- pop(1);
+ ref_stack_pop(&o_stack, 1);
stack_param_list_write(&list, &o_stack, &rkeys, iimemory);
code = gs_get_device_or_hardware_params(dev, (gs_param_list *) & list,
is_hardware);
@@ -628,7 +628,7 @@ zspec_op(i_ctx_t *i_ctx_p)
if (proc < 0)
return_error(gs_error_undefined);
- pop(1); /* We don't need the name of the spec_op any more */
+ ref_stack_pop(&o_stack, 1); /* We don't need the name of the spec_op any more */
op = osp;
switch(proc) {
diff --git a/psi/zfile.c b/psi/zfile.c
index 11fd6f8e..46040701 100644
--- a/psi/zfile.c
+++ b/psi/zfile.c
@@ -412,7 +412,7 @@ zfilenameforall(i_ctx_t *i_ctx_p)
++esp;
make_istruct(esp, 0, pfen);
*++esp = op[-1];
- pop(3);
+ ref_stack_pop(&o_stack, 3);
code = file_continue(i_ctx_p);
return (code == o_pop_estack ? o_push_estack : code);
}
diff --git a/psi/zfjpx.c b/psi/zfjpx.c
index 0428c3ae..174eb59b 100644
--- a/psi/zfjpx.c
+++ b/psi/zfjpx.c
@@ -33,6 +33,10 @@
#include "iname.h"
#include "gdebug.h"
+#include "igstate.h" /* For igs macro */
+#include "gxdevcli.h" /* for dev_spec_op */
+#include "gxdevsop.h" /* For spec_op enumerated types */
+
#if defined(USE_OPENJPEG_JP2)
# include "sjpx_openjpeg.h"
#else
@@ -43,6 +47,21 @@
# define ISTRCMP(ref, string) (memcmp((ref)->value.const_bytes, string, \
min(strlen(string), r_size(ref))))
+static int PS_JPXD_PassThrough(void *d, byte *Buffer, int Size)
+{
+ gx_device *dev = (gx_device *)d;
+
+ if (Buffer == NULL) {
+ if (Size == 0)
+ dev_proc(dev, dev_spec_op)(dev, gxdso_JPX_passthrough_end, NULL, 0);
+ else
+ dev_proc(dev, dev_spec_op)(dev, gxdso_JPX_passthrough_begin, NULL, 0);
+ } else {
+ dev_proc(dev, dev_spec_op)(dev, gxdso_JPX_passthrough_data, Buffer, Size);
+ }
+ return 0;
+}
+
/* <source> /JPXDecode <file> */
/* <source> <dict> /JPXDecode <file> */
static int
@@ -52,6 +71,7 @@ z_jpx_decode(i_ctx_t * i_ctx_p)
ref *sop = NULL;
ref *csname = NULL;
stream_jpxd_state state;
+ gx_device *dev = gs_currentdevice(igs);
/* it's our responsibility to call set_defaults() */
state.memory = imemory->non_gc_memory;
@@ -132,6 +152,17 @@ z_jpx_decode(i_ctx_t * i_ctx_p)
}
}
+ if (dev_proc(dev, dev_spec_op)(dev, gxdso_JPX_passthrough_query, NULL, 0) > 0) {
+ state.StartedPassThrough = 0;
+ state.PassThrough = 1;
+ state.PassThroughfn = (PS_JPXD_PassThrough);
+ state.device = (void *)dev;
+ }
+ else {
+ state.PassThrough = 0;
+ state.device = (void *)NULL;
+ }
+
/* we pass npop=0, since we've no arguments left to consume */
/* we pass 0 instead of the usual rspace(sop) which will allocate storage
for filter state from the same memory pool as the stream it's coding.
diff --git a/psi/zfsample.c b/psi/zfsample.c
index 0e8e4bc8..00cd0cfd 100644
--- a/psi/zfsample.c
+++ b/psi/zfsample.c
@@ -533,15 +533,19 @@ sampled_data_continue(i_ctx_t *i_ctx_p)
for (j = 0; j < bps; j++)
data_ptr[bps * i + j] = (byte)(cv >> ((bps - 1 - j) * 8)); /* MSB first */
}
- pop(num_out); /* Move op to base of result values */
- /* Check if we are done collecting data. */
+ pop(num_out); /* Move op to base of result values */
+ /* From here on, we have to use ref_stack_pop() rather than pop()
+ so that it handles stack extension blocks properly, before calling
+ sampled_data_sample() which also uses the op stack.
+ */
+ /* Check if we are done collecting data. */
if (increment_cube_indexes(params, penum->indexes)) {
if (stack_depth_adjust == 0)
- pop(O_STACK_PAD); /* Remove spare stack space */
+ ref_stack_pop(&o_stack, O_STACK_PAD); /* Remove spare stack space */
else
- pop(stack_depth_adjust - num_out);
+ ref_stack_pop(&o_stack, stack_depth_adjust - num_out);
/* Execute the closing procedure, if given */
code = 0;
if (esp_finish_proc != 0)
@@ -554,11 +558,11 @@ sampled_data_continue(i_ctx_t *i_ctx_p)
if ((O_STACK_PAD - stack_depth_adjust) < 0) {
stack_depth_adjust = -(O_STACK_PAD - stack_depth_adjust);
check_op(stack_depth_adjust);
- pop(stack_depth_adjust);
+ ref_stack_pop(&o_stack, stack_depth_adjust);
}
else {
check_ostack(O_STACK_PAD - stack_depth_adjust);
- push(O_STACK_PAD - stack_depth_adjust);
+ ref_stack_push(&o_stack, O_STACK_PAD - stack_depth_adjust);
for (i=0;i<O_STACK_PAD - stack_depth_adjust;i++)
make_null(op - i);
}
diff --git a/psi/zfunc.c b/psi/zfunc.c
index 97d57656..2a289f10 100644
--- a/psi/zfunc.c
+++ b/psi/zfunc.c
@@ -140,7 +140,7 @@ zexecfunction(i_ctx_t *i_ctx_p)
if (diff > 0)
push(diff); /* can't fail */
else if (diff < 0) {
- pop(-diff);
+ ref_stack_pop(&o_stack, -diff);
op = osp;
}
code = make_floats(op + 1 - n, out, n);
diff --git a/psi/zgeneric.c b/psi/zgeneric.c
index 26d9fa22..098df52d 100644
--- a/psi/zgeneric.c
+++ b/psi/zgeneric.c
@@ -450,7 +450,7 @@ zforall(i_ctx_t *i_ctx_p)
ep[2] = *obj;
ep[3] = *op;
esp = cproc - 1;
- pop(2);
+ ref_stack_pop(&o_stack, 2);
return (*real_opproc(cproc))(i_ctx_p);
}
/* Continuation operator for arrays */
diff --git a/psi/zht.c b/psi/zht.c
index 6f707a3f..f1cc8d94 100644
--- a/psi/zht.c
+++ b/psi/zht.c
@@ -221,7 +221,7 @@ set_screen_continue(i_ctx_t *i_ctx_p)
code = gs_screen_next(senum, value);
if (code < 0)
return code;
- pop(1);
+ ref_stack_pop(&o_stack, 1);
return screen_sample(i_ctx_p);
}
/* Finish setscreen. */
diff --git a/psi/zht1.c b/psi/zht1.c
index 65dee490..eb462fd5 100644
--- a/psi/zht1.c
+++ b/psi/zht1.c
@@ -73,6 +73,7 @@ zsetcolorscreen(i_ctx_t *i_ctx_p)
code = gs_note_error(gs_error_VMerror);
else {
pht->type = ht_type_colorscreen;
+ pht->objtype = HT_OBJTYPE_DEFAULT;
pht->params.colorscreen = cscreen;
code = gs_sethalftone_prepare(igs, pht, pdht);
}
diff --git a/psi/zht2.c b/psi/zht2.c
index 88389b1e..f42a0821 100644
--- a/psi/zht2.c
+++ b/psi/zht2.c
@@ -66,6 +66,46 @@ spot1_dummy(double x, double y)
return (x + y) / 2;
}
+static int
+ht_object_type_from_name(gs_ref_memory_t *mem, ref *pname, gs_HT_objtype_t *HTobjtype)
+{
+ ref sref;
+
+ *HTobjtype = HT_OBJTYPE_DEFAULT;
+ name_string_ref(mem, pname, &sref);
+ if (r_size(&sref) <= 1)
+ return_error(gs_error_undefined); /* PDF allows zero length strings, but it can't match */
+
+ switch (sref.value.const_bytes[0]) {
+ case 'D':
+ if (r_size(&sref) == 7 && strncmp((const char *)sref.value.const_bytes, "Default", 7) == 0) {
+ *HTobjtype = HT_OBJTYPE_DEFAULT;
+ break;
+ }
+ return_error(gs_error_undefined);
+ case 'V':
+ if (r_size(&sref) == 6 && strncmp((const char *)sref.value.const_bytes, "Vector", 6) == 0) {
+ *HTobjtype = HT_OBJTYPE_VECTOR;
+ break;
+ }
+ return_error(gs_error_undefined);
+ case 'I':
+ if (r_size(&sref) == 5 && strncmp((const char *)sref.value.const_bytes, "Image", 5) == 0) {
+ *HTobjtype = HT_OBJTYPE_IMAGE;
+ break;
+ }
+ return_error(gs_error_undefined);
+ case 'T':
+ if (r_size(&sref) == 4 && strncmp((const char *)sref.value.const_bytes, "Text", 4) == 0) {
+ *HTobjtype = HT_OBJTYPE_TEXT;
+ break;
+ } /* falls through to default if no match */
+ default:
+ return_error(gs_error_undefined);
+ }
+ return 0;
+}
+
/* <dict> <dict5> .sethalftone5 - */
static int sethalftone_finish(i_ctx_t *);
static int sethalftone_cleanup(i_ctx_t *);
@@ -92,6 +132,8 @@ zsethalftone5(i_ctx_t *i_ctx_p)
byte * pname;
uint name_size;
int halftonetype, type = 0;
+ gs_HT_objtype_t objtype = HT_OBJTYPE_DEFAULT;
+ ref *pdval;
gs_gstate *pgs = igs;
int space_index;
@@ -123,6 +165,13 @@ zsethalftone5(i_ctx_t *i_ctx_p)
? ht_type_multiple_colorscreen
: ht_type_multiple;
+ /* Check if this dict has the optional ObjectType parameter */
+ if (dict_find_string(op - 1, "ObjectType", &pdval) > 0 &&
+ r_has_type(pdval, t_name)) {
+ if ((code = ht_object_type_from_name(iimemory, pdval, &objtype)) < 0)
+ return code;
+ }
+
/* Count how many components that we will actually use. */
have_default = false;
@@ -251,6 +300,7 @@ zsethalftone5(i_ctx_t *i_ctx_p)
}
if (code >= 0) {
pht->type = halftonetype;
+ pht->objtype = objtype;
pht->params.multiple.components = phtc;
pht->params.multiple.num_comp = j;
pht->params.multiple.get_colorname_string = gs_get_colorname_string;
@@ -301,7 +351,7 @@ zsethalftone5(i_ctx_t *i_ctx_p)
odict = op[-1];
odict5 = *op;
- pop(2);
+ ref_stack_pop(&o_stack, 2);
op = osp;
esp += 5;
make_mark_estack(esp - 4, es_other, sethalftone_cleanup);
@@ -602,6 +652,30 @@ sethalftone_cleanup(i_ctx_t *i_ctx_p)
return 0;
}
+static int
+zsetobjtypeHT(i_ctx_t *i_ctx_p) /* <name> .setobjtypeHT - */
+ /* name is one of /Vector, /Image, or /Text */
+{
+ os_ptr op = osp;
+ int code = 0;
+ gs_HT_objtype_t HTobjtype = HT_OBJTYPE_DEFAULT;
+
+ if (ref_stack_count(&o_stack) < 1)
+ return_error(gs_error_stackunderflow);
+ check_type(*op, t_name);
+
+ if ((code = ht_object_type_from_name(iimemory, op, &HTobjtype)) < 0)
+ return code;
+
+ /* If we made it this far, HTobjtype is valid */
+ code = gx_gstate_dev_ht_copy_to_objtype(i_ctx_p->pgs, HTobjtype);
+ if (code < 0)
+ return code;
+
+ pop(1);
+ return 0;
+}
+
/* ------ Initialization procedure ------ */
const op_def zht2_l2_op_defs[] =
@@ -609,6 +683,7 @@ const op_def zht2_l2_op_defs[] =
op_def_begin_level2(),
{"2.sethalftone5", zsethalftone5},
{"1.genordered", zgenordered},
+ {"1.setobjtypeHT", zsetobjtypeHT},
/* Internal operators */
{"0%sethalftone_finish", sethalftone_finish},
op_def_end(0)
diff --git a/psi/zicc.c b/psi/zicc.c
index e01913eb..2eda1c98 100644
--- a/psi/zicc.c
+++ b/psi/zicc.c
@@ -64,11 +64,11 @@ int seticc(i_ctx_t * i_ctx_p, int ncomps, ref *ICCdict, float *range_buff)
dict_find_string(ICCdict, ".hash", &phashval) == 1 &&
r_has_type(phashval, t_integer)) {
pcs = gsicc_find_cs(phashval->value.intval, igs);
- if (pcs != NULL) {
+ if (pcs != NULL && gs_color_space_num_components(pcs) == ncomps) {
/* Set the color space. We are done. */
code = gs_setcolorspace(igs, pcs);
/* Remove the ICC dict from the stack */
- pop(1);
+ ref_stack_pop(&o_stack, 1);
return code;
}
}
@@ -235,7 +235,7 @@ int seticc(i_ctx_t * i_ctx_p, int ncomps, ref *ICCdict, float *range_buff)
}
}
/* Remove the ICC dict from the stack */
- pop(1);
+ ref_stack_pop(&o_stack, 1);
return code;
}
@@ -468,6 +468,10 @@ seticc_cal(i_ctx_t * i_ctx_p, float *white, float *black, float *gamma,
/* See if the color space is in the profile cache */
pcs = gsicc_find_cs(dictkey, igs);
+ if (pcs != NULL && gs_color_space_num_components(pcs) != num_colorants) {
+ pcs = NULL;
+ dictkey = 0;
+ }
if (pcs == NULL ) {
/* build the color space object. Since this is cached
in the profile cache which is a member variable
diff --git a/psi/ziodev.c b/psi/ziodev.c
index c75ecc62..9d30f962 100644
--- a/psi/ziodev.c
+++ b/psi/ziodev.c
@@ -293,7 +293,7 @@ sc:
return_error(gs_error_VMerror);
}
- pop(3);
+ ref_stack_pop(&o_stack, 3);
make_stream_file(osp, s, "r");
return code;
diff --git a/psi/ziodev2.c b/psi/ziodev2.c
index 3e8198d8..fa827d8e 100644
--- a/psi/ziodev2.c
+++ b/psi/ziodev2.c
@@ -75,7 +75,7 @@ zgetdevparams(i_ctx_t *i_ctx_p)
return_error(gs_error_undefined);
stack_param_list_write(&list, &o_stack, NULL, iimemory);
if ((code = gs_getdevparams(iodev, plist)) < 0) {
- ref_stack_pop(&o_stack, list.count * 2);
+ pop(list.count * 2);
return code;
}
pmark = ref_stack_index(&o_stack, list.count * 2);
@@ -114,7 +114,7 @@ zputdevparams(i_ctx_t *i_ctx_p)
iparam_list_release(&list);
if (code < 0)
return code;
- ref_stack_pop(&o_stack, list.count * 2 + 2);
+ pop(list.count * 2 + 2);
return 0;
}
diff --git a/psi/zmatrix.c b/psi/zmatrix.c
index 94f1a85f..88196b08 100644
--- a/psi/zmatrix.c
+++ b/psi/zmatrix.c
@@ -467,6 +467,12 @@ zsettextmatrix(i_ctx_t *i_ctx_p)
return 0;
}
+static int
+zupdatematrices(i_ctx_t *i_ctx_p)
+{
+ return gs_updatematrices(igs);
+}
+
/* ------ Initialization procedure ------ */
const op_def zmatrix_op_defs[] =
@@ -496,5 +502,6 @@ const op_def zmatrix2_op_defs[] =
{"1.settextlinematrix", zsettextlinematrix},
{"1.currenttextmatrix", zcurrenttextmatrix},
{"1.settextmatrix", zsettextmatrix},
+ {"1.updatematrices", zupdatematrices},
op_def_end(0)
};
diff --git a/psi/zpath.c b/psi/zpath.c
index 4a84358d..59d0f7a1 100644
--- a/psi/zpath.c
+++ b/psi/zpath.c
@@ -52,6 +52,19 @@ zcurrentpoint(i_ctx_t *i_ctx_p)
return 0;
}
+/* - .currentpoint_valid <bool> */
+static int
+zcurrentpoint_valid(i_ctx_t *i_ctx_p)
+{
+ os_ptr op = osp;
+ gs_point pt;
+ int code = gs_currentpoint(igs, &pt);
+
+ push(1);
+ make_bool(op, code == 0);
+ return 0;
+}
+
/* <x> <y> moveto - */
int
zmoveto(i_ctx_t *i_ctx_p)
@@ -163,6 +176,7 @@ const op_def zpath_op_defs[] =
{"0clip", zclip},
{"0closepath", zclosepath},
{"0currentpoint", zcurrentpoint},
+ {"0.currentpoint_valid", zcurrentpoint_valid},
{"6curveto", zcurveto},
{"0eoclip", zeoclip},
{"0initclip", zinitclip},
diff --git a/psi/zpcolor.c b/psi/zpcolor.c
index 26e15dd2..81a94ddf 100644
--- a/psi/zpcolor.c
+++ b/psi/zpcolor.c
@@ -184,6 +184,7 @@ const op_def zpcolor_l2_op_defs[] =
/* Render the pattern by calling the PaintProc. */
static int pattern_paint_cleanup(i_ctx_t *);
+static int pattern_paint_cleanup_core(i_ctx_t *, bool);
static int
zPaintProc(const gs_client_color * pcc, gs_gstate * pgs)
{
@@ -387,10 +388,13 @@ pattern_paint_finish(i_ctx_t *i_ctx_p)
#if 0
dmlprintf1(imemory, "PaintProc left %d extra on operator stack!\n", o_stack_adjust);
#endif
+ /* Take care here: if anything is added after this that may access the op stack,
+ this needs to be ref_stack_pop() rather than pop().
+ */
pop(o_stack_adjust);
}
esp -= 5;
- pattern_paint_cleanup(i_ctx_p);
+ pattern_paint_cleanup_core(i_ctx_p, 0);
return o_pop_estack;
}
/* Clean up after rendering a pattern. Note that iff the rendering */
@@ -398,6 +402,12 @@ pattern_paint_finish(i_ctx_t *i_ctx_p)
static int
pattern_paint_cleanup(i_ctx_t *i_ctx_p)
{
+ return pattern_paint_cleanup_core(i_ctx_p, 1);
+}
+
+static int
+pattern_paint_cleanup_core(i_ctx_t *i_ctx_p, bool is_error)
+{
gx_device_pattern_accum *const pdev =
r_ptr(esp + 4, gx_device_pattern_accum);
gs_pattern1_instance_t *pinst = (gs_pattern1_instance_t *)gs_currentcolor(igs->saved)->pattern;
@@ -423,6 +433,16 @@ pattern_paint_cleanup(i_ctx_t *i_ctx_p)
if (pdev != NULL) {
/* grestore will free the device, so close it first. */
(*dev_proc(pdev, close_device)) ((gx_device *) pdev);
+ /* The accumulator device is allocated in "system" memory
+ but the target device may be allocated in the prevailing
+ VM mode (local/global) of the input file, and thus potentially
+ subject to save/restore - which may cause bad things if the
+ accumator hangs around until the end of job restore, which can
+ happen in the even of an error during the PaintProc, so
+ null that pointer for that case.
+ */
+ if (is_error)
+ pdev->target = NULL;
}
if (pdev == NULL) {
gx_device *cdev = r_ptr(esp + 2, gx_device);
diff --git a/psi/zpdf_r6.c b/psi/zpdf_r6.c
index 218e4540..6da5007f 100644
--- a/psi/zpdf_r6.c
+++ b/psi/zpdf_r6.c
@@ -185,7 +185,7 @@ zcheck_r6_password(i_ctx_t * i_ctx_p)
if (r_size(UEref) < 32)
return_error(gs_error_invalidaccess);
- pop(2);
+ ref_stack_pop(&o_stack, 2);
op = osp;
PWlen = r_size(Pref);
diff --git a/psi/zpdfops.c b/psi/zpdfops.c
index e60cf97f..4c01de03 100644
--- a/psi/zpdfops.c
+++ b/psi/zpdfops.c
@@ -16,7 +16,19 @@
/* Custom operators for PDF interpreter */
+#if defined(BUILD_PDF) && BUILD_PDF == 1
+#include "ghostpdf.h"
+#include "pdf_page.h"
+#include "gzht.h"
+#include "gsrefct.h"
+#include "pdf_misc.h"
+
+#include "iminst.h"
+#include "dstack.h"
+#endif
+
#include "ghost.h"
+#include "gsmchunk.h"
#include "oper.h"
#include "igstate.h"
#include "istack.h"
@@ -29,6 +41,9 @@
#include "store.h"
#include "gxgstate.h"
#include "gxdevsop.h"
+#include "idict.h"
+#include "iname.h"
+#include "bfont.h"
#ifdef HAVE_LIBIDN
# include <stringprep.h>
@@ -68,38 +83,47 @@ zsetscreenphase(i_ctx_t *i_ctx_p)
static int
zpdfinkpath(i_ctx_t *i_ctx_p)
{
- os_ptr optr, op = osp;
- uint count = ref_stack_counttomark(&o_stack);
-
- uint i, ocount;
+ os_ptr op = osp;
+ uint i, count;
int code;
double x0, y0, x1, y1, x2, y2, x3, y3, xc1, yc1, xc2, yc2, xc3, yc3;
double len1, len2, len3, k1, k2, xm1, ym1, xm2, ym2;
double ctrl1_x, ctrl1_y, ctrl2_x, ctrl2_y;
const double smooth_value = 1; /* from 0..1 range */
+ ref lval;
- if (count == 0)
- return_error(gs_error_unmatchedmark);
- if ((count & 1) == 0 || count < 3)
+ check_read_type(*op, t_array);
+ count = r_size(op);
+
+ if ((count & 1) != 0 || count < 2)
return_error(gs_error_rangecheck);
- ocount = count - 1;
- optr = op - ocount + 1;
+ if ((code = array_get(imemory, op, 0, &lval)) < 0)
+ return code;
+ if ((code = real_param(&lval, &x1)) < 0)
+ return code;
- if ((code = real_param(optr, &x1)) < 0)
+ if ((code = array_get(imemory, op, 1, &lval)) < 0)
return code;
- if ((code = real_param(optr + 1, &y1)) < 0)
+ if ((code = real_param(&lval, &y1)) < 0)
return code;
+
if ((code = gs_moveto(igs, x1, y1)) < 0)
return code;
- if (ocount == 2)
+ if (count == 2)
goto pop;
- if ((code = real_param(optr + 2, &x2)) < 0)
+ if ((code = array_get(imemory, op, 2, &lval)) < 0)
+ return code;
+ if ((code = real_param(&lval, &x2)) < 0)
+ return code;
+
+ if ((code = array_get(imemory, op, 3, &lval)) < 0)
return code;
- if ((code = real_param(optr + 3, &y2)) < 0)
+ if ((code = real_param(&lval, &y2)) < 0)
return code;
- if (ocount == 4) {
+
+ if (count == 4) {
if((code = gs_lineto(igs, x2, y2)) < 0)
return code;
goto pop;
@@ -107,11 +131,15 @@ zpdfinkpath(i_ctx_t *i_ctx_p)
x0 = 2*x1 - x2;
y0 = 2*y1 - y2;
- for (i = 4; i <= ocount; i += 2) {
- if (i < ocount) {
- if ((code = real_param(optr + i, &x3)) < 0)
+ for (i = 4; i <= count; i += 2) {
+ if (i < count) {
+ if ((code = array_get(imemory, op, i, &lval)) < 0)
return code;
- if ((code = real_param(optr + i + 1, &y3)) < 0)
+ if ((code = real_param(&lval, &x3)) < 0)
+ return code;
+ if ((code = array_get(imemory, op, i + 1, &lval)) < 0)
+ return code;
+ if ((code = real_param(&lval, &y3)) < 0)
return code;
} else {
x3 = 2*x2 - x1;
@@ -151,7 +179,7 @@ zpdfinkpath(i_ctx_t *i_ctx_p)
y0 = y1, y1 = y2, y2 = y3;
}
pop:
- ref_stack_pop(&o_stack, count);
+ pop(1);
return 0;
}
@@ -172,7 +200,7 @@ zpdfFormName(i_ctx_t *i_ctx_p)
if (code < 0)
return code;
- ref_stack_pop(&o_stack, 1);
+ pop(1);
return 0;
}
@@ -242,6 +270,895 @@ zsaslprep(i_ctx_t *i_ctx_p)
}
#endif
+#if defined(BUILD_PDF) && BUILD_PDF == 1
+
+/*
+ This cannot fail. If gs doesn't have these settings it will never reach here.
+ Because the lives of the string values here are all tied to the Postscript
+ context, and the Postscript context *must* outlast the pdfi context, we can
+ safely just take references, marking the strings as "persistent" so destroying
+ the pdfi context doesn't try to free the string bodies.
+ */
+static void zpdfi_populate_search_paths(i_ctx_t *i_ctx_p, pdf_context *ctx)
+{
+ /* This should only be called once per pdfi context
+ if the paths are already populated, just skip it.
+ */
+ if (ctx->search_paths.resource_paths == NULL) {
+ ref *l2dictref, *grdref, *fpathref;
+ int code, i;
+ const gs_file_path *pfpath = i_ctx_p->lib_path;
+ gs_main_instance *minst = get_minst_from_memory(imemory);
+ code = dict_find_string(systemdict, "pssystemparams", &l2dictref);
+ if (code >= 0 && r_has_type(l2dictref, t_dictionary)) {
+ code = dict_find_string(l2dictref, "GenericResourceDir", &grdref);
+ if (code >= 0 && r_has_type(grdref, t_string)) {
+ ctx->search_paths.genericresourcedir.data = grdref->value.const_bytes;
+ ctx->search_paths.genericresourcedir.size = r_size(grdref);
+ ctx->search_paths.genericresourcedir.persistent = true;
+ }
+ }
+ ctx->search_paths.resource_paths = (gs_param_string *)gs_alloc_bytes(ctx->memory, sizeof(gs_param_string) * r_size(&pfpath->list), "array of paths");
+ ctx->search_paths.num_resource_paths = r_size(&pfpath->list);
+ for (i = 0; i < r_size(&pfpath->list); i++) {
+ const ref *prdir = pfpath->list.value.refs + i; /* By nature, this cannot be a short/mixed array, only a "normal" array */
+ ctx->search_paths.resource_paths[i].data = prdir->value.const_bytes;
+ ctx->search_paths.resource_paths[i].size = r_size(prdir);
+ ctx->search_paths.resource_paths[i].persistent = true;
+ }
+ code = dict_find_string(systemdict, "FONTPATH", &fpathref);
+ ctx->search_paths.font_paths = (gs_param_string *)gs_alloc_bytes(ctx->memory, sizeof(gs_param_string) * r_size(fpathref), "array of font paths");
+ ctx->search_paths.num_font_paths = r_size(fpathref);
+ for (i = 0; i < r_size(fpathref); i++) {
+ const ref *prdir = pfpath->list.value.refs + i; /* By nature, this cannot be a short/mixed array, only a "normal" array */
+ ctx->search_paths.resource_paths[i].data = prdir->value.const_bytes;
+ ctx->search_paths.resource_paths[i].size = r_size(prdir);
+ ctx->search_paths.resource_paths[i].persistent = true;
+ }
+ ctx->search_paths.search_here_first = minst->search_here_first;
+ }
+}
+
+/*
+ * Declare the structure we use to represent an instance of the PDF parser
+ * as a t_struct.
+ */
+typedef struct pdfctx_s {
+ pdf_context *ctx; /* Not exposed to garbager */
+ stream *ps_stream;
+ gs_memory_t *pdf_memory; /* The 'wrapped' memory allocator used by the PDF interpreter. Not exposed to garbager */
+ gs_memory_t *pdf_stream_memory; /* The memory allocator used to copy the PostScript stream to pdf_stream. Not exposed to garbager */
+ stream *pdf_stream;
+} pdfctx_t;
+
+/* Structure descriptors */
+static void pdfctx_finalize(const gs_memory_t *cmem, void *vptr);
+
+gs_private_st_composite_final(st_pdfctx_t, pdfctx_t, "pdfctx_struct",\
+ pdfctx_enum_ptrs, pdfctx_reloc_ptrs, pdfctx_finalize);
+
+static
+ENUM_PTRS_BEGIN(pdfctx_enum_ptrs) return 0;
+ENUM_PTR2(0, pdfctx_t, ps_stream, pdf_stream);
+ENUM_PTRS_END
+
+static RELOC_PTRS_BEGIN(pdfctx_reloc_ptrs);
+RELOC_PTR2(pdfctx_t, ps_stream, pdf_stream);
+RELOC_PTRS_END
+
+static void
+pdfctx_finalize(const gs_memory_t *cmem, void *vptr)
+{
+ pdfctx_t *pdfctx = vptr;
+ /* Finalize methods have to cope with the possibility of being called multiple times
+ * on the same object - hence we null the entries.
+ */
+
+ if (cmem != NULL) {
+ if (pdfctx->ctx != NULL) {
+ if (pdfctx->pdf_stream) {
+ memset(pdfctx->pdf_stream, 0x00, sizeof(stream));
+ gs_free_object(pdfctx->pdf_stream_memory, pdfctx->pdf_stream, "free PDF copy of stream");
+ pdfctx->pdf_stream = NULL;
+ }
+
+ if (pdfctx->ps_stream) {
+ /* Detach the PostScript stream from the PDF context, otherwise the
+ * free_context code will close the main stream.
+ */
+ pdfctx->ctx->main_stream = NULL;
+ }
+ (void)pdfi_free_context(pdfctx->ctx);
+ pdfctx->ctx = NULL;
+ }
+ if (pdfctx->pdf_memory != NULL) {
+ /* gs_memory_chunk_unwrap() returns the "wrapped" allocator, which we don't need */
+ (void)gs_memory_chunk_unwrap(pdfctx->pdf_memory);
+ pdfctx->pdf_memory = NULL;
+ }
+ }
+}
+
+static int zPDFstream(i_ctx_t *i_ctx_p)
+{
+ os_ptr op = osp;
+ int code = 0;
+ stream *s;
+ pdfctx_t *pdfctx;
+ gs_gstate *pgs = NULL;
+ gs_gstate_client_procs procs;
+ void *client_data;
+
+ check_op(2);
+
+ check_read_file(i_ctx_p, s, op - 1);
+
+ check_type(*op, t_pdfctx);
+ pdfctx = r_ptr(op, pdfctx_t);
+
+ /* If the supplied context already has a file open, signal an error */
+ if (pdfctx->ps_stream != NULL)
+ return_error(gs_error_ioerror);
+
+ s->close_at_eod = false;
+ pdfctx->ps_stream = s;
+ pdfctx->pdf_stream = s_alloc_immovable(imemory, "PDFstream copy of PS stream");
+ pdfctx->pdf_stream_memory = imemory;
+ if (pdfctx->pdf_stream == NULL)
+ return_error(gs_error_VMerror);
+
+ *(pdfctx->pdf_stream) = *(pdfctx->ps_stream);
+
+ pgs = pdfctx->ctx->pgs;
+ procs = igs->client_procs;
+ client_data = igs->client_data;
+ pdfi_gstate_from_PS(pdfctx->ctx, igs, &client_data, &procs);
+ pdfctx->ctx->pgs = igs;
+
+ code = pdfi_set_input_stream(pdfctx->ctx, pdfctx->pdf_stream);
+
+ pdfi_gstate_to_PS(pdfctx->ctx, igs, client_data, &procs);
+ if (code == 0)
+ code = gs_grestore(igs);
+ else
+ (void)gs_grestore(igs);
+ pdfctx->ctx->pgs = pgs;
+
+ if (code < 0) {
+ memset(pdfctx->pdf_stream, 0x00, sizeof(stream));
+ gs_free_object(imemory, pdfctx->pdf_stream, "PDFstream copy of PS stream");
+ pdfctx->pdf_stream = NULL;
+ pdfctx->ps_stream = NULL;
+ return code;
+ }
+
+ pdfctx->ctx->finish_page = NULL;
+ make_tav(op, t_pdfctx, icurrent_space | a_all, pstruct, (obj_header_t *)(pdfctx));
+
+ pop(2);
+ return 0;
+}
+
+static int zPDFfile(i_ctx_t *i_ctx_p)
+{
+ os_ptr op = osp;
+ pdfctx_t *pdfctx;
+ char pdffilename[gp_file_name_sizeof];
+ int code = 0;
+ gs_gstate *pgs = NULL;
+ gs_gstate_client_procs procs;
+ void *client_data;
+
+ check_op(2);
+
+ check_type(*op, t_pdfctx);
+ pdfctx = r_ptr(op, pdfctx_t);
+
+ check_read_type(*(op - 1), t_string);
+ if (r_size(op - 1) > gp_file_name_sizeof - 2)
+ return_error(gs_error_limitcheck);
+
+ /* If the supplied context already has a file open, signal an error */
+ if (pdfctx->ps_stream != NULL)
+ return_error(gs_error_ioerror);
+
+ pdfctx->ps_stream = NULL;
+
+ memcpy(pdffilename, (op - 1)->value.bytes, r_size(op - 1));
+ pdffilename[r_size(op - 1)] = 0;
+
+ pgs = pdfctx->ctx->pgs;
+ procs = igs->client_procs;
+ client_data = igs->client_data;
+ pdfi_gstate_from_PS(pdfctx->ctx, igs, &client_data, &procs);
+ pdfctx->ctx->pgs = igs;
+
+ code = pdfi_open_pdf_file(pdfctx->ctx, pdffilename);
+
+ pdfi_gstate_to_PS(pdfctx->ctx, igs, client_data, &procs);
+ if (code == 0)
+ code = gs_grestore(igs);
+ else
+ (void)gs_grestore(igs);
+ pdfctx->ctx->pgs = pgs;
+
+ if (code < 0)
+ return code;
+
+ pdfctx->ctx->finish_page = NULL;
+
+ pop(2);
+ return 0;
+}
+
+static int zPDFclose(i_ctx_t *i_ctx_p)
+{
+ os_ptr op = osp;
+ int code = 0;
+ pdfctx_t *pdfctx;
+
+ check_type(*op, t_pdfctx);
+ pdfctx = r_ptr(op, pdfctx_t);
+
+ if (pdfctx->ctx != NULL) {
+ if (pdfctx->ps_stream) {
+ /* Detach the PostScript stream from the PDF context, otherwise the
+ * close code will close the main stream
+ */
+ pdfctx->ctx->main_stream = NULL;
+ }
+ code = pdfi_free_context(pdfctx->ctx);
+ pdfctx->ctx = NULL;
+ }
+ if (pdfctx->pdf_stream) {
+ memset(pdfctx->pdf_stream, 0x00, sizeof(stream));
+ gs_free_object(imemory, pdfctx->pdf_stream, "free copy of PostScript stream");
+ pdfctx->pdf_stream = NULL;
+ }
+ if (pdfctx->ps_stream)
+ pdfctx->ps_stream = NULL;
+ pop(1);
+ return code;
+}
+
+static int zPDFinfo(i_ctx_t *i_ctx_p)
+{
+ os_ptr op = osp;
+ pdfctx_t *pdfctx;
+ int code = 0;
+ ref intref, nameref;
+ uint64_t TotalFiles = 0, ix = 0;
+ char **names_array = NULL;
+
+ check_type(*(op), t_pdfctx);
+ pdfctx = r_ptr(op, pdfctx_t);
+
+ code = dict_create(4, op);
+ if (code < 0)
+ return code;
+
+ code = names_ref(imemory->gs_lib_ctx->gs_name_table, (const byte *)"NumPages", 8, &nameref, 1);
+ if (code < 0)
+ return code;
+
+ make_int(&intref, pdfctx->ctx->num_pages);
+
+ code = dict_put(op, &nameref, &intref, &i_ctx_p->dict_stack);
+ if (code < 0)
+ return code;
+
+ /* Code to process Collections. The pdfi_prep_collection() function returns an
+ * array of descriptions and filenames. Because the descriptions can contain
+ * UTF16-BE encoded data we can't sue a NULL terminated string, so the description
+ * strings are terminated with a triple-NULL sequence of bytes.
+ * We copy the contents into a PostScript array, which we store in the info
+ * dictionary using the /Collection key.
+ */
+ if (pdfctx->ctx->Collection != NULL) {
+ code = pdfi_prep_collection(pdfctx->ctx, &TotalFiles, &names_array);
+ if (code >= 0 && TotalFiles > 0) {
+ uint size;
+ ref collection, stringref;
+
+ code = ialloc_ref_array(&collection, a_all, TotalFiles * 2, "names array");
+ if (code < 0)
+ goto error;
+
+ code = names_ref(imemory->gs_lib_ctx->gs_name_table, (const byte *)"Collection", 10, &nameref, 1);
+ if (code < 0)
+ goto error;
+
+ code = dict_put(op, &nameref, &collection, &i_ctx_p->dict_stack);
+ if (code < 0)
+ goto error;
+
+ for (ix=0; ix < TotalFiles * 2; ix++) {
+ char *ptr = names_array[ix];
+ byte *sbody;
+ ref *pelement;
+
+ size = 0;
+ do {
+ if (ptr[0] == 0x00 && ptr[1] == 0x00 && ptr[2] == 0x00)
+ break;
+ ptr++;
+ size++;
+ } while (1);
+ sbody = ialloc_string(size, "string");
+ if (sbody == 0) {
+ code = gs_error_VMerror;
+ goto error;
+ }
+ make_string(&stringref, a_all | icurrent_space, size, sbody);
+ memset(sbody, 0x00, size);
+ memcpy(sbody, names_array[ix], size);
+ gs_free_object(pdfctx->ctx->memory, names_array[ix], "free collection temporary filenames");
+ names_array[ix] = NULL;
+ pelement = collection.value.refs + ix;
+ ref_assign_old(&collection, pelement, &stringref, "put names string");
+ }
+ }
+ gs_free_object(pdfctx->ctx->memory, names_array, "free collection temporary filenames");
+ code = 0;
+ }
+
+ return code;
+
+error:
+ for (ix=0; ix < TotalFiles * 2; ix++)
+ gs_free_object(pdfctx->ctx->memory, names_array[ix], "free collection temporary filenames");
+ gs_free_object(pdfctx->ctx->memory, names_array, "free collection temporary filenames");
+ return code;
+}
+
+static int zPDFpageinfo(i_ctx_t *i_ctx_p)
+{
+ os_ptr op = osp;
+ ref aref, boolref, nameref, numref, *eltp;
+ int page = 0, code = 0, i;
+ pdfctx_t *pdfctx;
+ pdf_info_t info;
+ gs_gstate *pgs = NULL;
+ gs_gstate_client_procs procs;
+ void *client_data;
+
+ check_op(2);
+
+ check_type(*op, t_integer);
+ page = op->value.intval;
+
+ check_type(*(op - 1), t_pdfctx);
+ pdfctx = r_ptr(op - 1, pdfctx_t);
+
+ pgs = pdfctx->ctx->pgs;
+ procs = igs->client_procs;
+ client_data = igs->client_data;
+ pdfi_gstate_from_PS(pdfctx->ctx, igs, &client_data, &procs);
+ pdfctx->ctx->pgs = igs;
+
+ code = pdfi_page_info(pdfctx->ctx, (uint64_t)page, &info);
+
+ pdfi_gstate_to_PS(pdfctx->ctx, igs, client_data, &procs);
+ if (code == 0)
+ code = gs_grestore(igs);
+ else
+ (void)gs_grestore(igs);
+ pdfctx->ctx->pgs = pgs;
+
+ if (code < 0)
+ return code;
+
+ pop(1);
+ op = osp;
+
+ code = dict_create(4, op);
+ if (code < 0)
+ return code;
+
+ code = names_ref(imemory->gs_lib_ctx->gs_name_table, (const byte *)"HasAnnots", 9, &nameref, 1);
+ if (code < 0)
+ return code;
+ make_bool(&boolref, false);
+ code = dict_put(op, &nameref, &boolref, &i_ctx_p->dict_stack);
+ if (code < 0)
+ return code;
+
+ code = names_ref(imemory->gs_lib_ctx->gs_name_table, (const byte *)"UsesTransparency", 16, &nameref, 1);
+ if (code < 0)
+ return code;
+ make_bool(&boolref, info.HasTransparency);
+ code = dict_put(op, &nameref, &boolref, &i_ctx_p->dict_stack);
+ if (code < 0)
+ return code;
+
+ code = names_ref(imemory->gs_lib_ctx->gs_name_table, (const byte *)"NumSpots", 8, &nameref, 1);
+ if (code < 0)
+ return code;
+ make_int(&numref, info.NumSpots);
+ code = dict_put(op, &nameref, &numref, &i_ctx_p->dict_stack);
+ if (code < 0)
+ return code;
+
+ if (info.boxes & MEDIA_BOX) {
+ code = names_ref(imemory->gs_lib_ctx->gs_name_table, (const byte *)"MediaBox", 8, &nameref, 1);
+ if (code < 0)
+ return code;
+ code = ialloc_ref_array(&aref, a_all, 4, "array");
+ if (code < 0)
+ return code;
+ refset_null(aref.value.refs, 4);
+ for (i=0;i < 4;i++) {
+ make_real(&numref, info.MediaBox[i]);
+ eltp = aref.value.refs + i;
+ ref_assign_old(&aref, eltp, &numref, "put");
+ }
+ code = dict_put(op, &nameref, &aref, &i_ctx_p->dict_stack);
+ if (code < 0)
+ return code;
+ }
+
+ if (info.boxes & CROP_BOX) {
+ code = names_ref(imemory->gs_lib_ctx->gs_name_table, (const byte *)"CropBox", 7, &nameref, 1);
+ if (code < 0)
+ return code;
+ code = ialloc_ref_array(&aref, a_all, 4, "array");
+ if (code < 0)
+ return code;
+ refset_null(aref.value.refs, 4);
+ for (i=0;i < 4;i++) {
+ make_real(&numref, info.CropBox[i]);
+ eltp = aref.value.refs + i;
+ ref_assign_old(&aref, eltp, &numref, "put");
+ }
+ code = dict_put(op, &nameref, &aref, &i_ctx_p->dict_stack);
+ if (code < 0)
+ return code;
+ }
+
+ if (info.boxes & TRIM_BOX) {
+ code = names_ref(imemory->gs_lib_ctx->gs_name_table, (const byte *)"TrimBox", 7, &nameref, 1);
+ if (code < 0)
+ return code;
+ code = ialloc_ref_array(&aref, a_all, 4, "array");
+ if (code < 0)
+ return code;
+ refset_null(aref.value.refs, 4);
+ for (i=0;i < 4;i++) {
+ make_real(&numref, info.TrimBox[i]);
+ eltp = aref.value.refs + i;
+ ref_assign_old(&aref, eltp, &numref, "put");
+ }
+ code = dict_put(op, &nameref, &aref, &i_ctx_p->dict_stack);
+ if (code < 0)
+ return code;
+ }
+
+ if (info.boxes & ART_BOX) {
+ code = names_ref(imemory->gs_lib_ctx->gs_name_table, (const byte *)"ArtBox", 6, &nameref, 1);
+ if (code < 0)
+ return code;
+ code = ialloc_ref_array(&aref, a_all, 4, "array");
+ if (code < 0)
+ return code;
+ refset_null(aref.value.refs, 4);
+ for (i=0;i < 4;i++) {
+ make_real(&numref, info.ArtBox[i]);
+ eltp = aref.value.refs + i;
+ ref_assign_old(&aref, eltp, &numref, "put");
+ }
+ code = dict_put(op, &nameref, &aref, &i_ctx_p->dict_stack);
+ if (code < 0)
+ return code;
+ }
+
+ if (info.boxes & BLEED_BOX) {
+ code = names_ref(imemory->gs_lib_ctx->gs_name_table, (const byte *)"BleedBox", 8, &nameref, 1);
+ if (code < 0)
+ return code;
+ code = ialloc_ref_array(&aref, a_all, 4, "array");
+ if (code < 0)
+ return code;
+ refset_null(aref.value.refs, 4);
+ for (i=0;i < 4;i++) {
+ make_real(&numref, info.BleedBox[i]);
+ eltp = aref.value.refs + i;
+ ref_assign_old(&aref, eltp, &numref, "put");
+ }
+ code = dict_put(op, &nameref, &aref, &i_ctx_p->dict_stack);
+ if (code < 0)
+ return code;
+ }
+
+ code = names_ref(imemory->gs_lib_ctx->gs_name_table, (const byte *)"Rotate", 6, &nameref, 1);
+ if (code < 0)
+ return code;
+ make_real(&numref, info.Rotate);
+ code = dict_put(op, &nameref, &numref, &i_ctx_p->dict_stack);
+ if (code < 0)
+ return code;
+
+ if (info.UserUnit != 1) {
+ code = names_ref(imemory->gs_lib_ctx->gs_name_table, (const byte *)"UserUnit", 8, &nameref, 1);
+ if (code < 0)
+ return code;
+ make_real(&numref, info.UserUnit);
+ code = dict_put(op, &nameref, &numref, &i_ctx_p->dict_stack);
+ if (code < 0)
+ return code;
+ }
+
+ return 0;
+}
+
+static int zPDFmetadata(i_ctx_t *i_ctx_p)
+{
+#if 0
+ os_ptr op = osp;
+ pdfctx_t *pdfctx;
+
+ check_type(*op, t_pdfctx);
+ pdfctx = r_ptr(op, pdfctx_t);
+#endif
+
+ return_error(gs_error_undefined);
+}
+
+static int zPDFdrawpage(i_ctx_t *i_ctx_p)
+{
+ os_ptr op = osp;
+ int code = 0;
+ uint64_t page = 0;
+ pdfctx_t *pdfctx;
+ gs_gstate *pgs = NULL;
+ gs_gstate_client_procs procs;
+ void *client_data;
+
+ check_op(2);
+
+ check_type(*op, t_integer);
+ page = op->value.intval;
+
+ check_type(*(op - 1), t_pdfctx);
+ pdfctx = r_ptr(op - 1, pdfctx_t);
+
+ code = gs_gsave(igs);
+ if (code < 0)
+ return code;
+
+ pgs = pdfctx->ctx->pgs;
+ procs = igs->client_procs;
+ client_data = igs->client_data;
+ pdfi_gstate_from_PS(pdfctx->ctx, igs, &client_data, &procs);
+ pdfctx->ctx->pgs = igs;
+
+ code = pdfi_page_render(pdfctx->ctx, page, false);
+ if (code >= 0)
+ pop(2);
+
+ pdfi_gstate_to_PS(pdfctx->ctx, igs, client_data, &procs);
+ if (code == 0)
+ code = gs_grestore(igs);
+ else
+ (void)gs_grestore(igs);
+ pdfctx->ctx->pgs = pgs;
+
+ return code;
+}
+
+static int zPDFdrawannots(i_ctx_t *i_ctx_p)
+{
+#if 0
+ os_ptr op = osp;
+ pdfctx_t *pdfctx;
+
+ check_type(*op, t_pdfctx);
+ pdfctx = r_ptr(op, pdfctx_t);
+#endif
+
+ return_error(gs_error_undefined);
+}
+
+static int zpdfi_glyph_index(gs_font *pfont, byte *str, uint size, uint *glyph)
+{
+ int code = 0;
+ ref nref;
+ code = name_ref(pfont->memory, str, size, &nref, true);
+ if (code < 0)
+ return code;
+ *glyph = name_index(pfont->memory, &nref);
+ return 0;
+}
+
+static int param_value_get_namelist(pdf_context *ctx, ref *pvalueref, char ***pstrlist)
+{
+ char *data;
+ uint size;
+
+ if (!r_has_type(pvalueref, t_string))
+ return_error(gs_error_typecheck);
+
+ data = (char *)pvalueref->value.bytes;
+ size = pvalueref->tas.rsize;
+
+ return pdfi_parse_name_cstring_array(ctx, data, size, pstrlist);
+}
+
+static int zPDFInit(i_ctx_t *i_ctx_p)
+{
+ os_ptr op = osp;
+ ref *pdictref = NULL, *pvalueref;
+ pdfctx_t *pdfctx = NULL;
+ pdf_context *ctx = NULL;
+ int code = 0;
+ gs_memory_t *cmem;
+
+ code = gs_memory_chunk_wrap(&cmem, imemory->non_gc_memory);
+ if (code < 0)
+ return_error(gs_error_VMerror);
+
+ pdfctx = gs_alloc_struct(imemory, pdfctx_t, &st_pdfctx_t, "PDFcontext");
+ if (!pdfctx) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+ pdfctx->pdf_memory = cmem;
+ pdfctx->ctx = NULL;
+ pdfctx->ps_stream = NULL;
+ pdfctx->pdf_stream = NULL;
+ pdfctx->pdf_stream_memory = NULL;
+
+ ctx = pdfi_create_context(cmem);
+ if (ctx == NULL) {
+ code = gs_note_error(gs_error_VMerror);
+ goto error;
+ }
+
+ pdfctx->ctx = ctx;
+ get_zfont_glyph_name((void **)&pdfctx->ctx->get_glyph_name);
+ pdfctx->ctx->get_glyph_index = zpdfi_glyph_index;
+
+ if (ref_stack_count(&o_stack) > 0 && r_has_type(op, t_dictionary)) {
+ pdictref = op;
+
+ code = gs_error_typecheck;
+ if (dict_find_string(pdictref, "PDFDEBUG", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.pdfdebug = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "PDFSTOPONERROR", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.pdfstoponerror = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "PDFSTOPONWARNING", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.pdfstoponwarning = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "NOTRANSPARENCY", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.notransparency = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "QUIET", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.QUIET = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "VerboseErrors", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.verbose_errors = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "VerboseWarnings", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.verbose_warnings = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "PDFPassword", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_string))
+ goto error;
+ pdfctx->ctx->encryption.Password = (char *)gs_alloc_bytes(pdfctx->ctx->memory, r_size(pvalueref) + 1, "PDF Password from zpdfops");
+ memset(pdfctx->ctx->encryption.Password, 0x00, r_size(pvalueref) + 1);
+ memcpy(pdfctx->ctx->encryption.Password, pvalueref->value.const_bytes, r_size(pvalueref));
+ pdfctx->ctx->encryption.PasswordLen = r_size(pvalueref);
+ }
+
+ if (dict_find_string(pdictref, "FirstPage", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_integer))
+ goto error;
+ pdfctx->ctx->args.first_page = pvalueref->value.intval;
+ }
+
+ if (dict_find_string(pdictref, "LastPage", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_integer))
+ goto error;
+ pdfctx->ctx->args.last_page = pvalueref->value.intval;
+ }
+
+ if (dict_find_string(pdictref, "NOCIDFALLBACK", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.nocidfallback = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "NO_PDFMARK_OUTLINES", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.no_pdfmark_outlines = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "NO_PDFMARK_DESTS", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.no_pdfmark_dests = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "PDFFitPage", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.pdffitpage = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "Printed", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.printed = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "UseBleedBox", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.usebleedbox = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "UseCropBox", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.usecropbox = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "UseArtBox", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.useartbox = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "UseTrimBox", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.usetrimbox = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "ShowAcroForm", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.showacroform = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "ShowAnnots", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.showannots = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "PreserveAnnots", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.preserveannots = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "NoUserUnit", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.nouserunit = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "RENDERTTNOTDEF", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.renderttnotdef = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "DOPDFMARKS", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.dopdfmarks = pvalueref->value.boolval;
+ }
+
+ if (dict_find_string(pdictref, "PDFINFO", &pvalueref) > 0) {
+ if (!r_has_type(pvalueref, t_boolean))
+ goto error;
+ pdfctx->ctx->args.pdfinfo = pvalueref->value.boolval;
+ }
+ if (dict_find_string(pdictref, "SHOWANNOTTYPES", &pvalueref) > 0) {
+ code = param_value_get_namelist(pdfctx->ctx, pvalueref,
+ &pdfctx->ctx->args.showannottypes);
+ if (code < 0)
+ goto error;
+ }
+ if (dict_find_string(pdictref, "PRESERVEANNOTTYPES", &pvalueref) > 0) {
+ code = param_value_get_namelist(pdfctx->ctx, pvalueref,
+ &pdfctx->ctx->args.preserveannottypes);
+ if (code < 0)
+ goto error;
+ }
+ code = 0;
+ pop(1);
+ }
+ zpdfi_populate_search_paths(i_ctx_p, ctx);
+ op = osp;
+ push(1);
+ make_tav(op, t_pdfctx, icurrent_space | a_all, pstruct, (obj_header_t *)(pdfctx));
+ return 0;
+
+error:
+ if (ctx)
+ pdfi_free_context(ctx);
+ /* gs_memory_chunk_unwrap() returns the "wrapped" allocator, which we don't need */
+ (void)gs_memory_chunk_unwrap(cmem);
+ if (pdfctx) {
+ pdfctx->pdf_memory = NULL;
+ gs_free_object(imemory, pdfctx, "PDFcontext");
+ }
+ return code;
+}
+#else
+
+static int zPDFfile(i_ctx_t *i_ctx_p)
+{
+ return_error(gs_error_undefined);
+}
+
+static int zPDFstream(i_ctx_t *i_ctx_p)
+{
+ return_error(gs_error_undefined);
+}
+
+static int zPDFclose(i_ctx_t *i_ctx_p)
+{
+ return_error(gs_error_undefined);
+}
+
+static int zPDFinfo(i_ctx_t *i_ctx_p)
+{
+ return_error(gs_error_undefined);
+}
+
+static int zPDFpageinfo(i_ctx_t *i_ctx_p)
+{
+ return_error(gs_error_undefined);
+}
+
+static int zPDFmetadata(i_ctx_t *i_ctx_p)
+{
+ return_error(gs_error_undefined);
+}
+
+static int zPDFdrawpage(i_ctx_t *i_ctx_p)
+{
+ return_error(gs_error_undefined);
+}
+
+static int zPDFdrawannots(i_ctx_t *i_ctx_p)
+{
+ return_error(gs_error_undefined);
+}
+
+static int zPDFInit(i_ctx_t *i_ctx_p)
+{
+ return_error(gs_error_undefined);
+}
+#endif
+
/* ------ Initialization procedure ------ */
const op_def zpdfops_op_defs[] =
@@ -249,6 +1166,15 @@ const op_def zpdfops_op_defs[] =
{"0.pdfinkpath", zpdfinkpath},
{"1.pdfFormName", zpdfFormName},
{"3.setscreenphase", zsetscreenphase},
+ {"0.PDFFile", zPDFfile},
+ {"1.PDFStream", zPDFstream},
+ {"1.PDFClose", zPDFclose},
+ {"1.PDFInfo", zPDFinfo},
+ {"1.PDFPageInfo", zPDFpageinfo},
+ {"1.PDFMetadata", zPDFmetadata},
+ {"1.PDFDrawPage", zPDFdrawpage},
+ {"1.PDFDrawAnnots", zPDFdrawannots},
+ {"1.PDFInit", zPDFInit},
#ifdef HAVE_LIBIDN
{"1.saslprep", zsaslprep},
#endif
diff --git a/psi/zupath.c b/psi/zupath.c
index 49f2c45d..fb60443d 100644
--- a/psi/zupath.c
+++ b/psi/zupath.c
@@ -131,7 +131,7 @@ zinustroke(i_ctx_t *i_ctx_p)
if (npop > 1) /* matrix was supplied */
code = gs_concat(igs, &mat);
if (code >= 0) {
- dev_proc(&hdev, set_graphics_type_tag)(&hdev, GS_PATH_TAG); /* so that fills don't unset dev_color */
+ dev_proc(&hdev, set_graphics_type_tag)(&hdev, GS_VECTOR_TAG); /* so that fills don't unset dev_color */
code = gs_stroke(igs);
}
return in_upath_result(i_ctx_p, npop + spop, code);
@@ -150,7 +150,7 @@ in_test(i_ctx_t *i_ctx_p, int (*paintproc)(gs_gstate *))
if (npop < 0)
return npop;
- dev_proc(&hdev, set_graphics_type_tag)(&hdev, GS_PATH_TAG); /* so that fills don't unset dev_color */
+ dev_proc(&hdev, set_graphics_type_tag)(&hdev, GS_VECTOR_TAG); /* so that fills don't unset dev_color */
code = (*paintproc)(igs);
return in_path_result(i_ctx_p, npop, code);
}
@@ -228,7 +228,7 @@ in_path_result(i_ctx_t *i_ctx_p, int npop, int code)
else /* error */
return code;
npop--;
- pop(npop);
+ ref_stack_pop(&o_stack, npop);
op -= npop;
make_bool(op, result);
return 0;
@@ -245,7 +245,7 @@ in_utest(i_ctx_t *i_ctx_p, int (*paintproc)(gs_gstate *))
if (npop < 0)
return npop;
- dev_proc(&hdev, set_graphics_type_tag)(&hdev, GS_PATH_TAG); /* so that fills don't unset dev_color */
+ dev_proc(&hdev, set_graphics_type_tag)(&hdev, GS_VECTOR_TAG); /* so that fills don't unset dev_color */
code = (*paintproc)(igs);
return in_upath_result(i_ctx_p, npop, code);
}
diff --git a/psi/zvmem.c b/psi/zvmem.c
index 0a1f5bdf..637ac46c 100644
--- a/psi/zvmem.c
+++ b/psi/zvmem.c
@@ -324,6 +324,7 @@ restore_check_stack(const i_ctx_t *i_ctx_p, const ref_stack_t * pstack,
case t_fontID:
case t_struct:
case t_astruct:
+ case t_pdfctx:
ptr = stkp->value.pstruct;
break;
case t_save:
diff --git a/tesseract/src/ccutil/strngs.h b/tesseract/src/ccutil/strngs.h
index 2812e570..b81c3733 100644
--- a/tesseract/src/ccutil/strngs.h
+++ b/tesseract/src/ccutil/strngs.h
@@ -37,6 +37,7 @@ class STRING : public std::string {
using std::string::string;
STRING(const std::string &s) : std::string(s) {}
STRING(const char *s) : std::string(s ? s : "") {}
+ STRING() : std::string("") {}
// Writes to the given file. Returns false in case of error.
TESS_API
diff --git a/toolbin/bmpcmp.c b/toolbin/bmpcmp.c
index 78b7ef7b..6bd905bf 100644
--- a/toolbin/bmpcmp.c
+++ b/toolbin/bmpcmp.c
@@ -97,17 +97,30 @@ typedef struct
int lab;
} Params;
+typedef struct
+{
+ int width;
+ int height;
+ int span;
+ int bpp;
+ int cmyk;
+ void *lab;
+ /* Below are the entries for handling spot colors and the */
+ /* CMYK equivalents (only used for PSD images currently). */
+ int *num_spots;
+ unsigned char *spots;
+ /* used to map the second file colors to the same colorants */
+ /* as the first and issue a warning if they did not match. */
+ int *color_map;
+} Image;
+
+
typedef struct ImageReader
{
FILE *file;
const char* file_name;
void *(*read)(struct ImageReader *,
- int *w,
- int *h,
- int *s,
- int *bpp,
- int *cmyk,
- void **lab);
+ Image *);
} ImageReader;
/*
@@ -121,10 +134,6 @@ typedef void (DiffFn)(unsigned char *bmp,
BBox *bbox,
Params *params);
-/* Nasty (as if the rest of this code isn't!) global variables for holding
- * spot color details. */
-static unsigned char spots[256*4];
-static int spotfill = 0;
static void *Malloc(size_t size) {
void *block;
@@ -384,12 +393,7 @@ static unsigned char *bmp_load_sub(unsigned char *bmp,
}
static void *bmp_read(ImageReader *im,
- int *width,
- int *height,
- int *span,
- int *bpp,
- int *cmyk,
- void **lab)
+ Image *img)
{
int offset;
long filelen, filepos;
@@ -397,8 +401,8 @@ static void *bmp_read(ImageReader *im,
unsigned char *bmp;
/* No CMYK bmp support */
- *cmyk = 0;
- *lab = NULL;
+ img->cmyk = 0;
+ img->lab = NULL;
filepos = ftell(im->file);
fseek(im->file, 0, SEEK_END);
@@ -415,7 +419,7 @@ static void *bmp_read(ImageReader *im,
fread(bmp, 1, filelen, im->file);
offset = getdword(bmp+10);
- data = bmp_load_sub(bmp+14, width, height, span, bpp, offset-14, filelen);
+ data = bmp_load_sub(bmp+14, &img->width, &img->height, &img->span, &img->bpp, offset-14, filelen);
free(bmp);
return data;
}
@@ -465,24 +469,19 @@ static int get_short(FILE *file, int rev)
}
static void *cups_read(ImageReader *im,
- int *width,
- int *height,
- int *span,
- int *bpp,
- int *cmyk,
- int rev,
- void **lab)
+ Image *img,
+ int rev)
{
unsigned char *data, *d;
int c, x, y, b, bpc, bpl;
int colspace;
- *lab = NULL;
+ img->lab = NULL;
if (skip_bytes(im->file, 372) == EOF)
return NULL;
- *width = get_int(im->file, rev);
- *height = get_int(im->file, rev);
+ img->width = get_int(im->file, rev);
+ img->height = get_int(im->file, rev);
if (skip_bytes(im->file, 4) == EOF)
return NULL;
bpc = get_int(im->file, rev);
@@ -513,14 +512,14 @@ static void *cups_read(ImageReader *im,
if (skip_bytes(im->file, 1796-424) == EOF)
return NULL;
- data = Malloc(*width * *height * 4);
- *span = *width * 4;
- *bpp = 32;
- for (y = *height; y > 0; y--) {
+ data = Malloc(img->width * img->height * 4);
+ img->span = img->width * 4;
+ img->bpp = 32;
+ for (y = img->height; y > 0; y--) {
b = 0;
c = 0;
- d = data + (y - 1) * *span;
- for (x = *width; x > 0; x--) {
+ d = data + (y - 1) * img->span;
+ for (x = img->width; x > 0; x--) {
b >>= 1;
if (b == 0) {
c = fgetc(im->file);
@@ -540,35 +539,25 @@ static void *cups_read(ImageReader *im,
*d++ = 0;
}
}
- skip_bytes(im->file, bpl-((*width+7)>>3));
+ skip_bytes(im->file, bpl-((img->width+7)>>3));
}
/* No CMYK cups support */
- *cmyk = 0;
+ img->cmyk = 0;
return data;
}
static void *cups_read_le(ImageReader *im,
- int *width,
- int *height,
- int *span,
- int *bpp,
- int *cmyk,
- void **lab)
+ Image *img)
{
- return cups_read(im, width, height, span, bpp, cmyk, 0, lab);
+ return cups_read(im, img, 0);
}
static void *cups_read_be(ImageReader *im,
- int *width,
- int *height,
- int *span,
- int *bpp,
- int *cmyk,
- void **lab)
+ Image *img)
{
- return cups_read(im, width, height, span, bpp, cmyk, 1, lab);
+ return cups_read(im, img, 1);
}
static void skip_to_eol(FILE *file)
@@ -981,18 +970,13 @@ static int pam_header_read(FILE *file,
}
static void *pnm_read(ImageReader *im,
- int *width,
- int *height,
- int *span,
- int *bpp,
- int *cmyk,
- void **lab)
+ Image *img)
{
unsigned char *bmp;
int c, maxval;
void (*read)(FILE *, int, int, int, unsigned char *);
- *lab = NULL;
+ img->lab = NULL;
c = fgetc(im->file);
/* Skip over any white space before the P */
@@ -1001,7 +985,7 @@ static void *pnm_read(ImageReader *im,
}
if (c == EOF)
return NULL;
- *cmyk = 0;
+ img->cmyk = 0;
switch (get_pnm_num(im->file))
{
case 1:
@@ -1031,22 +1015,22 @@ static void *pnm_read(ImageReader *im,
return NULL;
}
if (read == pam_read) {
- *cmyk = pam_header_read(im->file, width, height, &maxval);
+ img->cmyk = pam_header_read(im->file, &img->width, &img->height, &maxval);
} else {
- *width = get_pnm_num(im->file);
- *height = get_pnm_num(im->file);
+ img->width = get_pnm_num(im->file);
+ img->height = get_pnm_num(im->file);
if (read != pbm_read)
maxval = get_pnm_num(im->file);
else
maxval = 1;
}
- *span = *width * 4;
- *bpp = 32; /* We always convert to 32bpp */
+ img->span = img->width * 4;
+ img->bpp = 32; /* We always convert to 32bpp */
- bmp = Malloc(*width * *height * 4);
+ bmp = Malloc(img->width * img->height * 4);
- read(im->file, *width, *height, maxval, bmp);
+ read(im->file, img->width, img->height, maxval, bmp);
return bmp;
}
@@ -1093,12 +1077,7 @@ static toff_t tiff_csize(thandle_t im_)
}
static void* tif_read(ImageReader* im,
- int* im_width,
- int* im_height,
- int* span,
- int* bpp,
- int* cmyk,
- void **lab)
+ Image *img)
{
TIFF* tif;
uint16 compression;
@@ -1118,7 +1097,7 @@ static void* tif_read(ImageReader* im,
cmsContext ctx;
#endif
- *lab = NULL;
+ img->lab = NULL;
/* There is only one image in each file */
if (ftell(im->file) != 0)
@@ -1222,7 +1201,7 @@ static void* tif_read(ImageReader* im,
/* Do calloc just to make sure alpha value is known */
data_lab = Calloc(height * width * 4);
- *lab = data_lab;
+ img->lab = data_lab;
}
#endif
@@ -1287,11 +1266,11 @@ static void* tif_read(ImageReader* im,
_TIFFfree(buf);
TIFFClose(tif);
- *im_width = width;
- *im_height = height;
- *span = width * 4;
- *bpp = 32;
- *cmyk = num_comps == 4;
+ img->width = width;
+ img->height = height;
+ img->span = width * 4;
+ img->bpp = 32;
+ img->cmyk = num_comps == 4;
return data;
}
@@ -1299,12 +1278,7 @@ static void* tif_read(ImageReader* im,
#ifdef HAVE_LIBPNG
static void *png_read(ImageReader *im,
- int *width,
- int *height,
- int *span,
- int *bpp,
- int *cmyk,
- void **lab)
+ Image *img)
{
png_structp png;
png_infop info;
@@ -1313,7 +1287,7 @@ static void *png_read(ImageReader *im,
unsigned char *data;
int expand = 0;
- *lab = NULL;
+ img->lab = NULL;
/* There is only one image in each file */
if (ftell(im->file) != 0)
@@ -1370,28 +1344,23 @@ static void *png_read(ImageReader *im,
png_read_end(png, NULL);
png_destroy_read_struct(&png, &info, NULL);
- *width = w;
- *height = h;
- *span = (int) stride;
- *bpp = (int) (stride * 8) / w;
- *cmyk = 0;
+ img->width = w;
+ img->height = h;
+ img->span = (int) stride;
+ img->bpp = (int) (stride * 8) / w;
+ img->cmyk = 0;
return data;
}
#endif
static void *psd_read(ImageReader *im,
- int *width,
- int *height,
- int *span,
- int *bpp,
- int *cmyk,
- void **lab)
-{
- int c, ir_len, w, h, n, x, y, z, N;
+ Image *img)
+{
+ int c, ir_len, w, h, span, n, x, y, z, N;
unsigned char *bmp, *line, *ptr;
int bpc;
- *lab = NULL;
+ img->lab = NULL;
if (feof(im->file))
return NULL;
@@ -1404,14 +1373,14 @@ static void *psd_read(ImageReader *im,
}
/* Skip zeros */
- c = get_short(im->file, 1);
- c = get_int(im->file, 1);
+ (void)get_short(im->file, 1);
+ (void)get_int(im->file, 1);
n = get_short(im->file, 1);
- *bpp = n * 8;
+ img->bpp = n * 8;
- h = *height = get_int(im->file, 1);
- w = *width = get_int(im->file, 1);
+ h = img->height = get_int(im->file, 1);
+ w = img->width = get_int(im->file, 1);
bpc = get_short(im->file, 1);
if (bpc != 8 && bpc != 16) {
fprintf(stderr, "bmpcmp: We only support 8bpp or 16bpp psd files!\n");
@@ -1419,19 +1388,19 @@ static void *psd_read(ImageReader *im,
}
c = get_short(im->file, 1);
if (c == 4) {
- *cmyk = 1;
+ img->cmyk = 1;
if (n < 4) {
fprintf(stderr, "bmpcmp: Unexpected number of components (%d) in a CMYK (+spots) PSD file!\n", n);
exit(1);
}
} else if (c == 3) {
- *cmyk = 0; /* RGB */
+ img->cmyk = 0; /* RGB */
if (n != 3) {
fprintf(stderr, "bmpcmp: Unexpected number of components (%d) in a RGB PSD file!\n", n);
exit(1);
}
} else if (c == 1) {
- *cmyk = 0; /* Greyscale */
+ img->cmyk = 0; /* Greyscale */
if (n != 1) {
fprintf(stderr, "bmpcmp: Unexpected number of components (%d) in a Greyscale PSD file!\n", n);
exit(1);
@@ -1449,64 +1418,100 @@ static void *psd_read(ImageReader *im,
}
/* Image Resources section */
- spotfill = 0;
ir_len = get_int(im->file, 1);
while (ir_len > 0)
{
- int data_len, pad;
- c = fgetc(im->file)<<24; if (--ir_len == 0) break;
- c |= fgetc(im->file)<<16; if (--ir_len == 0) break;
- c |= fgetc(im->file)<<8; if (--ir_len == 0) break;
- c |= fgetc(im->file); if (--ir_len == 0) break;
+ int data_len;
+
+ if (ir_len < 12) /* enough for "8BIM", short data_type (0x3ef), 2-byte pad, int data_len */
+ break; /* not enough data */
+ c = get_int(im->file, 1);
/* c == 8BIM */
- c = fgetc(im->file)<<8; if (--ir_len == 0) break;
- c |= fgetc(im->file); if (--ir_len == 0) break;
+ c = get_short(im->file, 1);
/* Skip the padded id (which will always be 00 00) */
- pad = fgetc(im->file); if (--ir_len == 0) break;
- pad |= fgetc(im->file)<<8; if (--ir_len == 0) break;
- /* Get the data len */
- data_len = fgetc(im->file)<<24; if (--ir_len == 0) break;
- data_len |= fgetc(im->file)<<16; if (--ir_len == 0) break;
- data_len |= fgetc(im->file)<<8; if (--ir_len == 0) break;
- data_len |= fgetc(im->file); if (--ir_len == 0) break;
+ (void)get_short(im->file, 1);
+ data_len = get_int(im->file, 1);
+ ir_len -= 12;
if (c == 0x3ef) {
- while (data_len > 0) {
+ int spotnum = 0;
+ int i;
+
+ while (data_len > 0) {
+ unsigned char spot[4];
+
+ if (ir_len < 14) /* enough for short colorspace, and CMYK data */
+ break;
/* Read the colorspace */
- c = fgetc(im->file)<<8; if (--ir_len == 0) break;
- c |= fgetc(im->file); if (--ir_len == 0) break;
+ c = get_short(im->file, 1);
/* We only support CMYK spots! */
if (c != 2) {
fprintf(stderr, "bmpcmp: Spot color equivalent not CMYK! (%d)\n", c);
exit(EXIT_FAILURE);
}
/* c == 2 = COLORSPACE = CMYK */
- /* 16 bits C, 16 bits M, 16 bits Y, 16 bits K */
- spots[spotfill++] = 0xff - fgetc(im->file); if (--ir_len == 0) break;
- c = fgetc(im->file); if (--ir_len == 0) break;
- spots[spotfill++] = 0xff - fgetc(im->file); if (--ir_len == 0) break;
- c = fgetc(im->file); if (--ir_len == 0) break;
- spots[spotfill++] = 0xff - fgetc(im->file); if (--ir_len == 0) break;
- c = fgetc(im->file); if (--ir_len == 0) break;
- spots[spotfill++] = 0xff - fgetc(im->file); if (--ir_len == 0) break;
- c = fgetc(im->file); if (--ir_len == 0) break;
+ /* 16 bits C, 16 bits M, 16 bits Y, 16 bits K, ignore the low byte */
+ spot[0] = 0xff - fgetc(im->file); /* high byte of Cyan */
+ (void)fgetc(im->file); /* ignore low byte */
+ spot[1] = 0xff - fgetc(im->file); /* high byte of Magenta */
+ (void)fgetc(im->file); /* ignore low byte */
+ spot[2] = 0xff - fgetc(im->file); /* high byte of Yellow */
+ (void)fgetc(im->file); /* ignore low byte */
+ spot[3] = 0xff - fgetc(im->file); /* high byte of Black */
+ (void)fgetc(im->file); /* ignore low byte */
/* 2 bytes opacity (always seems to be 0) */
- c = fgetc(im->file); if (--ir_len == 0) break;
- c = fgetc(im->file); if (--ir_len == 0) break;
+ (void)get_short(im->file, 1);
/* 1 byte 'kind' (0 = selected, 1 = protected) */
- c = fgetc(im->file); if (--ir_len == 0) break;
+ (void)fgetc(im->file);
/* 1 byte padding */
- c = fgetc(im->file); if (--ir_len == 0) break;
+ (void)fgetc(im->file);
data_len -= 14;
- }
- }
- if (ir_len > 0)
- {
- while (data_len > 0)
- {
- c = fgetc(im->file); if (--ir_len == 0) break;
- data_len--;
- }
+ ir_len -= 14;
+
+ /* Check if the spot colorants were filled in by the first image and */
+ /* if so, fill in the color_map with the matching spot number. */
+ if (*(img->num_spots) == 0) { /* num_spots not updated until finished with this file */
+ /* Spots not seen, this must be the first image */
+ img->spots[spotnum*4 + 0] = spot[0];
+ img->spots[spotnum*4 + 1] = spot[1];
+ img->spots[spotnum*4 + 2] = spot[2];
+ img->spots[spotnum*4 + 3] = spot[3];
+ img->color_map[spotnum + 4] = spotnum + 4; /* default, map to self */
+ } else {
+ /* spots were set by the first file. See if the colorant order matches */
+ if (img->spots[spotnum*4 + 0] != spot[0] || img->spots[spotnum*4 + 1] != spot[1] ||
+ img->spots[spotnum*4 + 2] != spot[2] || img->spots[spotnum*4 + 3] != spot[3] ) {
+ /* This spot didn't match, issue a warning and see if we can map */
+ fprintf(stderr, "bmpcmp: spot colorant number %d did not match.\n", spotnum);
+ for (i=(*(img->num_spots)-1); i >= 0 ; --i) {
+ if (img->spots[i*4 + 0] == spot[0] && img->spots[i*4 + 1] == spot[1] &&
+ img->spots[i*4 + 2] == spot[2] && img->spots[i*4 + 3] == spot[3]) {
+ img->color_map[spotnum + 4] = i + 4;
+ fprintf(stderr, "bmpcmp: spot colorant %d in file 2 matches colorant %d.\n",
+ spotnum, i);
+ break;
+ }
+ }
+ if (i < 0) {
+ /* a match was not found. stop */
+ fprintf(stderr, "bmpcmp: no matching colorant found for color_map\n");
+ exit(1);
+ }
+ }
+ }
+ spotnum++;
+ }
+ *(img->num_spots) = spotnum; /* save for the next image file */
+#ifdef VERBOSE
+ fprintf(stderr, "color map:");
+ for (i=0; i < 4+nimg->um_spots; i++)
+ fprintf(stderr, " %d->%d,", i, color_map[i]);
+ fprintf(stderr, "\n");
+#endif
}
+ /* skip any remaining data */
+ ir_len -= data_len;
+ while (data_len-- > 0)
+ (void)fgetc(im->file);
}
/* Skip Layer and Mask section */
@@ -1526,10 +1531,10 @@ static void *psd_read(ImageReader *im,
N = n;
if (N < 4)
N = 4;
- *span = (w * N + 3) & ~3;
- bmp = Malloc(*span * h);
+ img->span = span = (w * N + 3) & ~3;
+ bmp = Malloc(span * h);
line = Malloc(w * (bpc>>3));
- ptr = bmp + *span * (h-1);
+ ptr = bmp + span * (h-1);
if (bpc == 8) {
if (n == 1) {
/* Greyscale */
@@ -1544,10 +1549,10 @@ static void *psd_read(ImageReader *im,
*ptr++ = val;
*ptr++ = 0;
}
- ptr -= w*N + *span;
+ ptr -= w*N + span;
line -= w;
}
- ptr += *span * h + 1;
+ ptr += span * h + 1;
} else if (n == 3) {
/* RGB (reverse to get BGR) */
ptr += 2;
@@ -1561,10 +1566,10 @@ static void *psd_read(ImageReader *im,
*ptr = *line++;
ptr += N;
}
- ptr -= w*N + *span;
+ ptr -= w*N + span;
line -= w;
}
- ptr += *span * h - 1;
+ ptr += span * h - 1;
}
ptr += 4;
for (y = 0; y < h; y++)
@@ -1574,13 +1579,14 @@ static void *psd_read(ImageReader *im,
*ptr = 0;
ptr += N;
}
- ptr -= w*N + *span;
+ ptr -= w*N + span;
}
- ptr += *span * h + 1;
+ ptr += span * h + 1;
} else {
/* CMYK + (maybe) spots */
for (z = 0; z < n; z++)
{
+ ptr = bmp + img->color_map[z] + span * (h-1);
for (y = 0; y < h; y++)
{
fread(line, 1, w, im->file);
@@ -1589,10 +1595,9 @@ static void *psd_read(ImageReader *im,
*ptr = 255 - *line++;
ptr += n;
}
- ptr -= w*n + *span;
+ ptr -= w*n + span;
line -= w;
}
- ptr += *span * h + 1;
}
}
} else {
@@ -1611,10 +1616,10 @@ static void *psd_read(ImageReader *im,
*ptr++ = val;
*ptr++ = 0;
}
- ptr -= w*N + *span;
+ ptr -= w*N + span;
line -= w*2;
}
- ptr += *span * h + 1;
+ ptr += span * h + 1;
} else if (n == 3) {
/* RGB (reverse to get BGR) */
ptr += 2;
@@ -1629,10 +1634,10 @@ static void *psd_read(ImageReader *im,
line++;
ptr += N;
}
- ptr -= w*N + *span;
+ ptr -= w*N + span;
line -= w*2;
}
- ptr += *span * h - 1;
+ ptr += span * h - 1;
}
ptr += 4;
for (y = 0; y < h; y++)
@@ -1642,26 +1647,26 @@ static void *psd_read(ImageReader *im,
*ptr = 0;
ptr += N;
}
- ptr -= w*N + *span;
+ ptr -= w*N + span;
}
- ptr += *span * h + 1;
+ ptr += span * h + 1;
} else {
/* CMYK + (maybe) spots */
for (z = 0; z < n; z++)
{
+ ptr = bmp + img->color_map[z] + span * (h-1);
for (y = 0; y < h; y++)
{
fread(line, 2, w, im->file);
for (x = 0; x < w; x++)
{
*ptr = 255 - *line++;
- line++;
+ line++; /* skip the low byte of data */
ptr += n;
}
- ptr -= w*n + *span;
+ ptr -= w*n + span;
line -= 2*w;
}
- ptr += *span * h + 1;
}
}
}
@@ -1669,13 +1674,13 @@ static void *psd_read(ImageReader *im,
/* Skip over any following header */
if (!feof(im->file))
- c = fgetc(im->file);
+ (void)fgetc(im->file);
if (!feof(im->file))
- c = fgetc(im->file);
+ (void)fgetc(im->file);
if (!feof(im->file))
- c = fgetc(im->file);
+ (void)fgetc(im->file);
if (!feof(im->file))
- c = fgetc(im->file);
+ (void)fgetc(im->file);
return bmp;
}
@@ -3631,8 +3636,13 @@ static void rediff(unsigned char *map,
*global = local;
}
-static void unspot(unsigned char *bmp, int w, int h, int span, int bpp)
+static void unspot(unsigned char *bmp, Image *img)
{
+ int w = img->width;
+ int h = img->height;
+ int span = img->span;
+ int bpp = img->bpp;
+ unsigned char *spots = img->spots;
int x, y, z, n = bpp>>3;
unsigned char *p = bmp;
@@ -3668,13 +3678,26 @@ static void unspot(unsigned char *bmp, int w, int h, int span, int bpp)
}
}
+static int
+is_eof(FILE *file)
+{
+ int c = fgetc(file);
+
+ if (c == EOF)
+ return 1;
+ ungetc(c, file);
+ return 0;
+}
+
int main(int argc, char *argv[])
{
int w, h, s, bpp, cmyk;
- int w2, h2, s2, bpp2, cmyk2;
+ int w2, h2;
int nx, ny, n;
int xstep, ystep;
int imagecount;
+ Image im1 = { 0 };
+ Image im2 = { 0 };
unsigned char *bmp;
unsigned char *bmp2;
unsigned char *map;
@@ -3691,6 +3714,19 @@ int main(int argc, char *argv[])
int can_compare = 1;
void *lab1, *lab2;
+ /* The following is for CMYK+spots (currently only PSD */
+ int num_spots = 0;
+ unsigned char spots[256*4] = { 0 }; /* shared between both images */
+ int color_map[256] = { 0, 1, 2, 3, 0 };
+
+ im1.spots = (unsigned char *)&spots;
+ im2.spots = (unsigned char *)&spots;
+ im1.num_spots = &num_spots;
+ im2.num_spots = &num_spots;
+ im1.color_map = (int *)&color_map;
+ im2.color_map = (int *)&color_map;
+ /* end CMYK+spots section */
+
parseArgs(argc, argv, &params);
if (params.window <= 1 && params.threshold == 0) {
diffFn = simple_diff;
@@ -3711,22 +3747,48 @@ int main(int argc, char *argv[])
image_open(&image2, params.filename2);
imagecount = 0;
- while (((bmp2 = NULL,
- bmp = image1.read(&image1, &w, &h, &s, &bpp, &cmyk, &lab1)) != NULL) &&
- ((bmp2 = image2.read(&image2, &w2, &h2, &s2, &bpp2, &cmyk2, &lab2)) != NULL))
- {
+ while (!is_eof(image1.file) && !is_eof(image2.file)) {
+ /* Reset CMYK+spots values for next image (page) in file */
+ /* NB: Probably not needed since PSD only supports one image==page */
+ num_spots = 0;
+ memset(spots, 0, sizeof(spots));
+ memset(color_map, 0, sizeof(color_map));
+ for (n=0; n < 4; n++)
+ color_map[n] = n;
+
+ bmp2 = NULL;
+ if ((bmp = image1.read(&image1, &im1)) == NULL) {
+ fprintf(stderr, "Unable to read image 1, %s, image #%d\n", params.filename1, imagecount+1);
+ break;
+ }
+
+ if ((bmp2 = image2.read(&image2, &im2)) == NULL) {
+ fprintf(stderr, "Unable to read image 2, %s, image #%d\n", params.filename2, imagecount+1);
+ break;
+ }
imagecount++;
/* Check images are compatible */
- if ((w != w2) || (h != h2) || (s != s2) || (bpp != bpp2) ||
- (cmyk != cmyk2))
+ if ((im1.width != im2.width) ||
+ (im1.height != im2.height) ||
+ (im1.span != im2.span) ||
+ (im1.bpp != im2.bpp) ||
+ (im1.cmyk != im2.cmyk))
{
fprintf(stderr,
"bmpcmp: Page %d: Can't compare images "
"(w=%d,%d) (h=%d,%d) (s=%d,%d) (bpp=%d,%d) (cmyk=%d,%d)!\n",
- imagecount, w, w2, h, h2, s, s2, bpp, bpp2, cmyk, cmyk2);
+ imagecount, im1.width, im2.width, im1.height, im2.height,
+ im1.span, im2.span, im1.bpp, im2.bpp, im1.cmyk, im2.cmyk);
can_compare = 0;
continue;
}
+ w = im1.width;
+ h = im1.height;
+ s = im1.span;
+ bpp = im1.bpp;
+ cmyk = im1.cmyk;
+ lab1 = im1.lab;
+ lab2 = im2.lab;
if (params.lab && (lab1 == NULL || lab2 == NULL)) {
fprintf(stderr, "bmpcmp: Lab compare failed (only valid for tiffs with icc profiles)\n");
@@ -3821,10 +3883,10 @@ int main(int argc, char *argv[])
/* bbox */
boxlist = Malloc(sizeof(*boxlist) * nx * ny);
- if (bpp >= 32)
+ if (bpp > 32)
{
- unspot(bmp, w, h, s, bpp);
- unspot(bmp2, w, h, s, bpp);
+ unspot(bmp, &im1);
+ unspot(bmp2, &im2);
}
/* Now save the changed bmps */
@@ -3866,25 +3928,25 @@ int main(int argc, char *argv[])
default:
break;
}
-#ifdef HAVE_LIBPNG
+ #ifdef HAVE_LIBPNG
sprintf(str1, "%s.%05d.png", params.outroot, n);
sprintf(str2, "%s.%05d.png", params.outroot, n+1);
sprintf(str3, "%s.%05d.png", params.outroot, n+2);
save_png(bmp, boxlist, s, bpp, str1);
save_png(bmp2, boxlist, s, bpp, str2);
-#else
+ #else
sprintf(str1, "%s.%05d.bmp", params.outroot, n);
sprintf(str2, "%s.%05d.bmp", params.outroot, n+1);
sprintf(str3, "%s.%05d.bmp", params.outroot, n+2);
save_bmp(bmp, boxlist, s, bpp, str1);
save_bmp(bmp2, boxlist, s, bpp, str2);
-#endif
+ #endif
diff_bmp(bmp, map, boxlist, s, w);
-#ifdef HAVE_LIBPNG
+ #ifdef HAVE_LIBPNG
save_png(bmp, boxlist, s, bpp, str3);
-#else
+ #else
save_bmp(bmp, boxlist, s, bpp, str3);
-#endif
+ #endif
sprintf(str4, "%s.%05d.meta", params.outroot, n);
save_meta(boxlist, str4, w, h, imagecount, params.threshold, params.window);
n += 3;
diff --git a/toolbin/color/icc_creator/nclr/Artifex_6CLR.icc b/toolbin/color/icc_creator/nclr/Artifex_6CLR.icc
new file mode 100644
index 00000000..11013260
--- /dev/null
+++ b/toolbin/color/icc_creator/nclr/Artifex_6CLR.icc
Binary files differ
diff --git a/toolbin/color/src_color/objsrc_profiles_example.txt b/toolbin/color/src_color/objsrc_profiles_example.txt
index 336d9ed0..b3400e42 100644
--- a/toolbin/color/src_color/objsrc_profiles_example.txt
+++ b/toolbin/color/src_color/objsrc_profiles_example.txt
@@ -1,6 +1,6 @@
-Graphic_CMYK cmyk_src_cyan.icc 0 1 0 0
-Image_CMYK cmyk_src_magenta.icc 0 1 0 0
+Vector_CMYK cmyk_src_cyan.icc 0 1 0 0
+Image_CMYK cmyk_src_magenta.icc 0 1 0 0
Text_CMYK cmyk_src_yellow.icc 0 1 0 0
-Graphic_RGB rgb_source_red.icc 0 1 0
+Vector_RGB rgb_source_red.icc 0 1 0
Image_RGB rgb_source_green.icc 0 1 0
-Text_RGB rgb_source_blue.icc 0 1 0
+Text_RGB rgb_source_blue.icc 0 1 0 \ No newline at end of file
diff --git a/toolbin/headercompile.pl b/toolbin/headercompile.pl
index 2b3a95b3..2b9c3220 100755
--- a/toolbin/headercompile.pl
+++ b/toolbin/headercompile.pl
@@ -99,7 +99,7 @@ sub pcompare($$)
return $v;
}
-# main: Work starts here
+# main: Work starts here
readdeps("base");
readdeps("psi");
@@ -267,7 +267,7 @@ for (my $ui=$mx-1; $ui >= 0; $ui--) {
if (!exists $dirs{$f}) {
next;
}
-
+
$h = $dirs{$f}."/".$f;
my $ret = system("cc -DHAVE_INTTYPES_H -Ibase -Ipsi -Ilcms2mt -Ilcms2 -Iopenjpeg/src/lib/openjp2 -Ijpeg -Ijbig2dec -Iobj -o tmp.o $h > tmp.err 2>&1");
@@ -385,9 +385,9 @@ sub rewrite_make($)
open(F, "$f") || die "WTF?";
while (<F>) {
$_ =~ s/[\r\n]*$//;
- if ($_ =~ m/^\# Dependencies:/) {
- last;
- }
+ if ($_ =~ m/^\# Dependencies:/) {
+ last;
+ }
if ($_ =~ m/^([a-z0-9_\-]+_h)=/) {
my $f = $1;
# Gather up the line, allowing for continuations
@@ -406,7 +406,7 @@ sub rewrite_make($)
}
$_ = $block;
}
-
+
my $makefile = 0;
if ($_ =~ m/\$\(MAKEFILE\)/) {
$makefile = 1;
diff --git a/toolbin/localcluster/clusterpush.pl b/toolbin/localcluster/clusterpush.pl
index a7d9cb57..2f251551 100755
--- a/toolbin/localcluster/clusterpush.pl
+++ b/toolbin/localcluster/clusterpush.pl
@@ -28,6 +28,7 @@ my %products=('abort' =>1,
'runtests'=>1,
'extract'=>1,
'extractmu'=>1,
+ 'muwasm'=>1,
'extractgs'=>1);
my $user;
@@ -174,7 +175,7 @@ if (!$product) {
} elsif ($directory eq 'extract') {
$product='extract';
} else {
- $product='gs pcl xps gpdl'
+ $product='gs pcl xps gpdl gpdf'
}
}
diff --git a/toolbin/tif_config.h.for.bmpcmp b/toolbin/tif_config.h.for.bmpcmp
new file mode 100644
index 00000000..50159808
--- /dev/null
+++ b/toolbin/tif_config.h.for.bmpcmp
@@ -0,0 +1,371 @@
+/* libtiff/tif_config.h. Hand edited version for bmpcmp in the cluster. */
+
+/* Define if building universal (internal helper macro) */
+/* #undef AC_APPLE_UNIVERSAL_BUILD */
+
+/* Support CCITT Group 3 & 4 algorithms */
+#define CCITT_SUPPORT 1
+
+/* Pick up YCbCr subsampling info from the JPEG data stream to support files
+ lacking the tag (default enabled). */
+#define CHECK_JPEG_YCBCR_SUBSAMPLING 1
+
+/* enable partial strip reading for large strips (experimental) */
+/* #undef CHUNKY_STRIP_READ_SUPPORT */
+
+/* Support C++ stream API (requires C++ compiler) */
+#define CXX_SUPPORT 1
+
+/* Treat extra sample as alpha (default enabled). The RGBA interface will
+ treat a fourth sample with no EXTRASAMPLE_ value as being ASSOCALPHA. Many
+ packages produce RGBA files but don't mark the alpha properly. */
+#define DEFAULT_EXTRASAMPLE_AS_ALPHA 1
+
+/* enable deferred strip/tile offset/size loading */
+/* #undef DEFER_STRILE_LOAD */
+
+/* Define to 1 if you have the <assert.h> header file. */
+#define HAVE_ASSERT_H 1
+
+/* Define to 1 if you have the declaration of `optarg', and to 0 if you don't.
+ */
+#define HAVE_DECL_OPTARG 1
+
+/* Define to 1 if you have the <dlfcn.h> header file. */
+#define HAVE_DLFCN_H 1
+
+/* Define to 1 if you have the <fcntl.h> header file. */
+#define HAVE_FCNTL_H 1
+
+/* Define to 1 if fseeko (and presumably ftello) exists and is declared. */
+#define HAVE_FSEEKO 1
+
+/* Define to 1 if you have the `getopt' function. */
+#define HAVE_GETOPT 1
+
+/* Define to 1 if you have the <GLUT/glut.h> header file. */
+/* #undef HAVE_GLUT_GLUT_H */
+
+/* Define to 1 if you have the <GL/glut.h> header file. */
+/* #undef HAVE_GL_GLUT_H */
+
+/* Define to 1 if you have the <GL/glu.h> header file. */
+/* #undef HAVE_GL_GLU_H */
+
+/* Define to 1 if you have the <GL/gl.h> header file. */
+#define HAVE_GL_GL_H 1
+
+/* Define as 0 or 1 according to the floating point format suported by the
+ machine */
+#define HAVE_IEEEFP 1
+
+/* Define to 1 if you have the <inttypes.h> header file. */
+#define HAVE_INTTYPES_H 1
+
+/* Define to 1 if you have the <io.h> header file. */
+/* #undef HAVE_IO_H */
+
+/* Define to 1 if you have the `jbg_newlen' function. */
+/* #undef HAVE_JBG_NEWLEN */
+
+/* Define to 1 if you have the `lfind' function. */
+#define HAVE_LFIND 1
+
+/* Define to 1 if you have the <memory.h> header file. */
+#define HAVE_MEMORY_H 1
+
+/* Define to 1 if you have the `mmap' function. */
+#define HAVE_MMAP 1
+
+/* Define to 1 if you have the <OpenGL/glu.h> header file. */
+/* #undef HAVE_OPENGL_GLU_H */
+
+/* Define to 1 if you have the <OpenGL/gl.h> header file. */
+/* #undef HAVE_OPENGL_GL_H */
+
+/* Define if you have POSIX threads libraries and header files. */
+#define HAVE_PTHREAD 1
+
+/* Define to 1 if you have the <search.h> header file. */
+#define HAVE_SEARCH_H 1
+
+/* Define to 1 if you have the `setmode' function. */
+/* #undef HAVE_SETMODE */
+
+/* Define to 1 if you have the `snprintf' function. */
+#define HAVE_SNPRINTF 1
+
+/* Define to 1 if you have the <stdint.h> header file. */
+#define HAVE_STDINT_H 1
+
+/* Define to 1 if you have the <stdlib.h> header file. */
+#define HAVE_STDLIB_H 1
+
+/* Define to 1 if you have the `strcasecmp' function. */
+#define HAVE_STRCASECMP 1
+
+/* Define to 1 if you have the <strings.h> header file. */
+#define HAVE_STRINGS_H 1
+
+/* Define to 1 if you have the <string.h> header file. */
+#define HAVE_STRING_H 1
+
+/* Define to 1 if you have the `strtol' function. */
+#define HAVE_STRTOL 1
+
+/* Define to 1 if you have the `strtoll' function. */
+#define HAVE_STRTOLL 1
+
+/* Define to 1 if you have the `strtoul' function. */
+#define HAVE_STRTOUL 1
+
+/* Define to 1 if you have the `strtoull' function. */
+#define HAVE_STRTOULL 1
+
+/* Define to 1 if you have the <sys/stat.h> header file. */
+#define HAVE_SYS_STAT_H 1
+
+/* Define to 1 if you have the <sys/types.h> header file. */
+#define HAVE_SYS_TYPES_H 1
+
+/* Define to 1 if you have the <unistd.h> header file. */
+#define HAVE_UNISTD_H 1
+
+/* Use nonstandard varargs form for the GLU tesselator callback */
+/* #undef HAVE_VARARGS_GLU_TESSCB */
+
+/* Define to 1 if you have the <windows.h> header file. */
+/* #undef HAVE_WINDOWS_H */
+
+/* Native cpu byte order: 1 if big-endian (Motorola) or 0 if little-endian
+ (Intel) */
+#define HOST_BIGENDIAN 0
+
+/* Set the native cpu bit order (FILLORDER_LSB2MSB or FILLORDER_MSB2LSB) */
+#define HOST_FILLORDER FILLORDER_LSB2MSB
+
+/* Support ISO JBIG compression (requires JBIG-KIT library) */
+#undef JBIG_SUPPORT
+
+/* 8/12 bit libjpeg dual mode enabled */
+#undef JPEG_DUAL_MODE_8_12
+
+/* Support JPEG compression (requires IJG JPEG library) */
+#undef JPEG_SUPPORT
+
+/* Support libdeflate enhanced compression */
+#undef LIBDEFLATE_SUPPORT
+
+/* 12bit libjpeg primary include file with path */
+#undef LIBJPEG_12_PATH
+
+/* Support LogLuv high dynamic range encoding */
+#define LOGLUV_SUPPORT 1
+
+/* Define to the sub-directory where libtool stores uninstalled libraries. */
+#define LT_OBJDIR ".libs/"
+
+/* Support LZMA2 compression */
+/* #undef LZMA_SUPPORT */
+
+/* Support LZW algorithm */
+#define LZW_SUPPORT 1
+
+/* Support Microsoft Document Imaging format */
+#define MDI_SUPPORT 1
+
+/* Support NeXT 2-bit RLE algorithm */
+#define NEXT_SUPPORT 1
+
+/* Support Old JPEG compresson (read-only) */
+#undef OJPEG_SUPPORT
+
+/* Name of package */
+#define PACKAGE "tiff"
+
+/* Define to the address where bug reports for this package should be sent. */
+#define PACKAGE_BUGREPORT "tiff@lists.maptools.org"
+
+/* Define to the full name of this package. */
+#define PACKAGE_NAME "LibTIFF Software"
+
+/* Define to the full name and version of this package. */
+#define PACKAGE_STRING "LibTIFF Software 4.2.0"
+
+/* Define to the one symbol short name of this package. */
+#define PACKAGE_TARNAME "tiff"
+
+/* Define to the home page for this package. */
+#define PACKAGE_URL ""
+
+/* Define to the version of this package. */
+#define PACKAGE_VERSION "4.2.0"
+
+/* Support Macintosh PackBits algorithm */
+#define PACKBITS_SUPPORT 1
+
+/* Support Pixar log-format algorithm (requires Zlib) */
+#define PIXARLOG_SUPPORT 1
+
+/* Define to necessary symbol if this constant uses a non-standard name on
+ your system. */
+/* #undef PTHREAD_CREATE_JOINABLE */
+
+/* The size of `signed int', as computed by sizeof. */
+#define SIZEOF_SIGNED_INT 4
+
+/* The size of `signed long', as computed by sizeof. */
+#define SIZEOF_SIGNED_LONG 8
+
+/* The size of `signed long long', as computed by sizeof. */
+#define SIZEOF_SIGNED_LONG_LONG 8
+
+/* The size of `size_t', as computed by sizeof. */
+#define SIZEOF_SIZE_T 8
+
+/* The size of `unsigned char *', as computed by sizeof. */
+#define SIZEOF_UNSIGNED_CHAR_P 8
+
+/* The size of `unsigned int', as computed by sizeof. */
+#define SIZEOF_UNSIGNED_INT 4
+
+/* The size of `unsigned long', as computed by sizeof. */
+#define SIZEOF_UNSIGNED_LONG 8
+
+/* The size of `unsigned long long', as computed by sizeof. */
+#define SIZEOF_UNSIGNED_LONG_LONG 8
+
+/* Define to 1 if you have the ANSI C header files. */
+#define STDC_HEADERS 1
+
+/* Support strip chopping (whether or not to convert single-strip uncompressed
+ images to mutiple strips of specified size to reduce memory usage) */
+#define STRIPCHOP_DEFAULT TIFF_STRIPCHOP
+
+/* Default size of the strip in bytes (when strip chopping enabled) */
+#define STRIP_SIZE_DEFAULT 8192
+
+/* Enable SubIFD tag (330) support */
+#define SUBIFD_SUPPORT 1
+
+/* Support ThunderScan 4-bit RLE algorithm */
+#define THUNDER_SUPPORT 1
+
+/* Signed 16-bit type */
+#define TIFF_INT16_T signed short
+
+/* Signed 32-bit type formatter */
+#define TIFF_INT32_FORMAT "%d"
+
+/* Signed 32-bit type */
+#define TIFF_INT32_T signed int
+
+/* Signed 64-bit type formatter */
+#define TIFF_INT64_FORMAT "%ld"
+
+/* Signed 64-bit type */
+#define TIFF_INT64_T signed long
+
+/* Signed 8-bit type */
+#define TIFF_INT8_T signed char
+
+/* Pointer difference type formatter */
+#define TIFF_PTRDIFF_FORMAT "%ld"
+
+/* Pointer difference type */
+#define TIFF_PTRDIFF_T ptrdiff_t
+
+/* Size type formatter */
+#define TIFF_SIZE_FORMAT "%lu"
+
+/* Unsigned size type */
+#define TIFF_SIZE_T unsigned long
+
+/* Signed size type formatter */
+#define TIFF_SSIZE_FORMAT "%ld"
+
+/* Signed size type */
+#define TIFF_SSIZE_T signed long
+
+/* Unsigned 16-bit type */
+#define TIFF_UINT16_T unsigned short
+
+/* Unsigned 32-bit type formatter */
+#define TIFF_UINT32_FORMAT "%u"
+
+/* Unsigned 32-bit type */
+#define TIFF_UINT32_T unsigned int
+
+/* Unsigned 64-bit type formatter */
+#define TIFF_UINT64_FORMAT "%lu"
+
+/* Unsigned 64-bit type */
+#define TIFF_UINT64_T unsigned long
+
+/* Unsigned 8-bit type */
+#define TIFF_UINT8_T unsigned char
+
+/* Define to 1 if you can safely include both <sys/time.h> and <time.h>. */
+#define TIME_WITH_SYS_TIME 1
+
+/* Define to 1 if your <sys/time.h> declares `struct tm'. */
+/* #undef TM_IN_SYS_TIME */
+
+/* define to use win32 IO system */
+/* #undef USE_WIN32_FILEIO */
+
+/* Version number of package */
+#define VERSION "4.2.0"
+
+/* Support webp compression */
+/* #undef WEBP_SUPPORT */
+
+/* Define WORDS_BIGENDIAN to 1 if your processor stores words with the most
+ significant byte first (like Motorola and SPARC, unlike Intel). */
+#if defined AC_APPLE_UNIVERSAL_BUILD
+# if defined __BIG_ENDIAN__
+# define WORDS_BIGENDIAN 1
+# endif
+#else
+# ifndef WORDS_BIGENDIAN
+/* # undef WORDS_BIGENDIAN */
+# endif
+#endif
+
+/* Define to 1 if the X Window System is missing or not being used. */
+/* #undef X_DISPLAY_MISSING */
+
+/* Support Deflate compression */
+#define ZIP_SUPPORT 1
+
+/* Support zstd compression */
+/* #undef ZSTD_SUPPORT */
+
+/* Enable large inode numbers on Mac OS X 10.5. */
+#ifndef _DARWIN_USE_64_BIT_INODE
+# define _DARWIN_USE_64_BIT_INODE 1
+#endif
+
+/* Number of bits in a file offset, on hosts where this is settable. */
+/* #undef _FILE_OFFSET_BITS */
+
+/* Define to 1 to make fseeko visible on some hosts (e.g. glibc 2.2). */
+/* #undef _LARGEFILE_SOURCE */
+
+/* Define for large files, on AIX-style hosts. */
+/* #undef _LARGE_FILES */
+
+/* Define to empty if `const' does not conform to ANSI C. */
+/* #undef const */
+
+/* Define to `__inline__' or `__inline' if that's what the C compiler
+ calls it, or to nothing if 'inline' is not supported under any name. */
+#ifndef __cplusplus
+/* #undef inline */
+#endif
+
+/* Define to `long int' if <sys/types.h> does not define. */
+/* #undef off_t */
+
+/* Define to `unsigned int' if <sys/types.h> does not define. */
+/* #undef size_t */
diff --git a/toolbin/tiffconf.h.for.bmpcmp b/toolbin/tiffconf.h.for.bmpcmp
new file mode 100644
index 00000000..5827d2ab
--- /dev/null
+++ b/toolbin/tiffconf.h.for.bmpcmp
@@ -0,0 +1,122 @@
+/* libtiff/tiffconf.h. Hand edited version for bmpcmp in the cluster. */
+/*
+ Configuration defines for installed libtiff.
+ This file maintained for backward compatibility. Do not use definitions
+ from this file in your programs.
+*/
+
+#ifndef _TIFFCONF_
+#define _TIFFCONF_
+
+/* Signed 16-bit type */
+#define TIFF_INT16_T signed short
+
+/* Signed 32-bit type */
+#define TIFF_INT32_T signed int
+
+/* Signed 64-bit type */
+#define TIFF_INT64_T signed long
+
+/* Signed 8-bit type */
+#define TIFF_INT8_T signed char
+
+/* Unsigned 16-bit type */
+#define TIFF_UINT16_T unsigned short
+
+/* Unsigned 32-bit type */
+#define TIFF_UINT32_T unsigned int
+
+/* Unsigned 64-bit type */
+#define TIFF_UINT64_T unsigned long
+
+/* Unsigned 8-bit type */
+#define TIFF_UINT8_T unsigned char
+
+/* Signed size type */
+#define TIFF_SSIZE_T signed long
+
+/* Pointer difference type */
+#define TIFF_PTRDIFF_T ptrdiff_t
+
+/* Compatibility stuff. */
+
+/* Define as 0 or 1 according to the floating point format suported by the
+ machine */
+#define HAVE_IEEEFP 1
+
+/* Set the native cpu bit order (FILLORDER_LSB2MSB or FILLORDER_MSB2LSB) */
+#define HOST_FILLORDER FILLORDER_LSB2MSB
+
+/* Native cpu byte order: 1 if big-endian (Motorola) or 0 if little-endian
+ (Intel) */
+#define HOST_BIGENDIAN 0
+
+/* Support CCITT Group 3 & 4 algorithms */
+#define CCITT_SUPPORT 1
+
+/* Support JPEG compression (requires IJG JPEG library) */
+/* #define JPEG_SUPPORT 1 */
+
+/* Support JBIG compression (requires JBIG-KIT library) */
+/* #undef JBIG_SUPPORT */
+
+/* Support LogLuv high dynamic range encoding */
+#define LOGLUV_SUPPORT 1
+
+/* Support LZW algorithm */
+#define LZW_SUPPORT 1
+
+/* Support NeXT 2-bit RLE algorithm */
+#define NEXT_SUPPORT 1
+
+/* Support Old JPEG compresson (read contrib/ojpeg/README first! Compilation
+ fails with unpatched IJG JPEG library) */
+/*#define OJPEG_SUPPORT 1*/
+
+/* Support Macintosh PackBits algorithm */
+#define PACKBITS_SUPPORT 1
+
+/* Support Pixar log-format algorithm (requires Zlib) */
+#define PIXARLOG_SUPPORT 1
+
+/* Support ThunderScan 4-bit RLE algorithm */
+#define THUNDER_SUPPORT 1
+
+/* Support Deflate compression */
+#define ZIP_SUPPORT 1
+
+/* Support libdeflate enhanced compression */
+/* #undef LIBDEFLATE_SUPPORT */
+
+/* Support strip chopping (whether or not to convert single-strip uncompressed
+ images to mutiple strips of ~8Kb to reduce memory usage) */
+#define STRIPCHOP_DEFAULT TIFF_STRIPCHOP
+
+/* Enable SubIFD tag (330) support */
+#define SUBIFD_SUPPORT 1
+
+/* Treat extra sample as alpha (default enabled). The RGBA interface will
+ treat a fourth sample with no EXTRASAMPLE_ value as being ASSOCALPHA. Many
+ packages produce RGBA files but don't mark the alpha properly. */
+#define DEFAULT_EXTRASAMPLE_AS_ALPHA 1
+
+/* Pick up YCbCr subsampling info from the JPEG data stream to support files
+ lacking the tag (default enabled). */
+#define CHECK_JPEG_YCBCR_SUBSAMPLING 1
+
+/* Support MS MDI magic number files as TIFF */
+#define MDI_SUPPORT 1
+
+/*
+ * Feature support definitions.
+ * XXX: These macros are obsoleted. Don't use them in your apps!
+ * Macros stays here for backward compatibility and should be always defined.
+ */
+#define COLORIMETRY_SUPPORT
+#define YCBCR_SUPPORT
+#define CMYK_SUPPORT
+#define ICC_SUPPORT
+#define PHOTOSHOP_SUPPORT
+#define IPTC_SUPPORT
+
+#endif /* _TIFFCONF_ */
diff --git a/windows/GhostPDL.sln b/windows/GhostPDL.sln
index 4137febe..408e8473 100644
--- a/windows/GhostPDL.sln
+++ b/windows/GhostPDL.sln
@@ -11,6 +11,8 @@ Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "ghostxps", "ghostxps.vcxpro
EndProject
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "ghostpdl", "ghostpdl.vcxproj", "{C4038125-61B9-4147-9EA8-39690BA3A599}"
EndProject
+Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "ghostpdf", "ghostpdf.vcxproj", "{4C038125-61B9-4147-9EA8-39690BA3A599}"
+EndProject
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "All", "All.vcxproj", "{98351FEF-0032-457C-B9D9-D6B68A829386}"
EndProject
Global
@@ -127,6 +129,50 @@ Global
{C4038125-61B9-4147-9EA8-39690BA3A599}.ReleaseXP|x64.ActiveCfg = ReleaseXP|x64
{C4038125-61B9-4147-9EA8-39690BA3A599}.Sanitize|Win32.ActiveCfg = Sanitize|Win32
{C4038125-61B9-4147-9EA8-39690BA3A599}.Sanitize|x64.ActiveCfg = Sanitize|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Debug|Win32.ActiveCfg = Debug|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Debug|Win32.Build.0 = Debug|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Debug|x64.ActiveCfg = Debug|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Debug|x64.Build.0 = Debug|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Debug-contrib|Win32.ActiveCfg = Debug-contrib|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Debug-contrib|Win32.Build.0 = Debug-contrib|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Debug-contrib|x64.ActiveCfg = Debug-contrib|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Debug-contrib|x64.Build.0 = Debug-contrib|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Debug-cups|Win32.ActiveCfg = Debug-cups|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Debug-cups|Win32.Build.0 = Debug-cups|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Debug-cups|x64.ActiveCfg = Debug-cups|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Debug-cups|x64.Build.0 = Debug-cups|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.DebugXP|Win32.ActiveCfg = Debug|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.DebugXP|Win32.Build.0 = Debug|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.DebugXP|x64.ActiveCfg = Debug-cups|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.DebugXP|x64.Build.0 = Debug-cups|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Memento|Win32.ActiveCfg = Memento|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Memento|Win32.Build.0 = Memento|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Memento|x64.ActiveCfg = Memento|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Memento|x64.Build.0 = Memento|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.MementoXP|Win32.ActiveCfg = Memento|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.MementoXP|Win32.Build.0 = Memento|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.MementoXP|x64.ActiveCfg = Memento|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.MementoXP|x64.Build.0 = Memento|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Profile|Win32.ActiveCfg = Profile|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Profile|Win32.Build.0 = Profile|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Profile|x64.ActiveCfg = Profile|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Profile|x64.Build.0 = Profile|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Release|Win32.ActiveCfg = Release|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Release|Win32.Build.0 = Release|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Release|x64.ActiveCfg = Release|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Release|x64.Build.0 = Release|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Release-contrib|Win32.ActiveCfg = Release-contrib|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Release-contrib|Win32.Build.0 = Release-contrib|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Release-contrib|x64.ActiveCfg = Release-contrib|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Release-contrib|x64.Build.0 = Release-contrib|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.ReleaseXP|Win32.ActiveCfg = Release|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.ReleaseXP|Win32.Build.0 = Release|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.ReleaseXP|x64.ActiveCfg = Release|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.ReleaseXP|x64.Build.0 = Release|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Sanitize|Win32.ActiveCfg = Debug|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Sanitize|Win32.Build.0 = Debug|Win32
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Sanitize|x64.ActiveCfg = Profile|x64
+ {4C038125-61B9-4147-9EA8-39690BA3A599}.Sanitize|x64.Build.0 = Profile|x64
{98351FEF-0032-457C-B9D9-D6B68A829386}.Debug|Win32.ActiveCfg = Debug|Win32
{98351FEF-0032-457C-B9D9-D6B68A829386}.Debug|Win32.Build.0 = Debug|Win32
{98351FEF-0032-457C-B9D9-D6B68A829386}.Debug|x64.ActiveCfg = Debug|x64
diff --git a/windows/ghostpcl-ufst.vcproj b/windows/ghostpcl-ufst.vcproj
index bb7093e3..9be329b7 100644
--- a/windows/ghostpcl-ufst.vcproj
+++ b/windows/ghostpcl-ufst.vcproj
@@ -26,7 +26,7 @@
>
<Tool
Name="VCNMakeTool"
- BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak UFST_ROOT=.\ufst SBR=1 DEVSTUDIO= gpcl6-ufst-debug &amp;&amp; nmake -f psi\msvc32.mak UFST_ROOT=.\ufst DEVSTUDIO= ufst-debugbsc"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak UFST_ROOT=.\ufst SBR=1 DEVSTUDIO= ufst-debug-pcl &amp;&amp; nmake -f psi\msvc32.mak UFST_ROOT=.\ufst DEVSTUDIO= ufst-debugbsc"
ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak UFST_ROOT=.\ufst DEVSTUDIO= ufst-debugclean &amp;&amp; nmake -f psi\msvc32.mak UFST_ROOT=.\ufst SBR=1 DEVSTUDIO= ufst-debug &amp;&amp; nmake -f psi\msvc32.mak UFST_ROOT=.\ufst DEVSTUDIO= ufst-debugbsc"
CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak UFST_ROOT=.\ufst DEVSTUDIO= ufst-debugclean"
Output="$(ProjectDir)\..\ufstdebugbin\gswin32c.exe"
@@ -46,7 +46,7 @@
>
<Tool
Name="VCNMakeTool"
- BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= UFST_ROOT=.\ufst SBR=1 DEVSTUDIO= gpcl6-ufst-debug &amp;&amp; nmake -f psi\msvc32.mak WIN64= UFST_ROOT=.\ufst DEVSTUDIO= ufst-debugbsc"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= UFST_ROOT=.\ufst SBR=1 DEVSTUDIO= ufst-debug-pcl &amp;&amp; nmake -f psi\msvc32.mak WIN64= UFST_ROOT=.\ufst DEVSTUDIO= ufst-debugbsc"
ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= UFST_ROOT=.\ufst DEVSTUDIO= ufst-debugclean &amp;&amp; nmake -f psi\msvc32.mak WIN64= UFST_ROOT=.\ufst SBR=1 DEVSTUDIO= ufst-debug &amp;&amp; nmake -f psi\msvc32.mak WIN64= UFST_ROOT=.\ufst DEVSTUDIO= ufst-debugbsc"
CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= UFST_ROOT=.\ufst DEVSTUDIO= ufst-debugclean"
Output="$(ProjectDir)\..\ufstdebugbin\gswin64c.exe"
@@ -66,7 +66,7 @@
>
<Tool
Name="VCNMakeTool"
- BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak UFST_ROOT=.\ufst SBR=1 DEVSTUDIO= gpcl6-ufst &amp;&amp; nmake -f psi\msvc32.mak UFST_ROOT=.\ufst DEVSTUDIO= ufst-bsc"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak UFST_ROOT=.\ufst SBR=1 DEVSTUDIO= ufst-pcl &amp;&amp; nmake -f psi\msvc32.mak UFST_ROOT=.\ufst DEVSTUDIO= ufst-bsc"
ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak UFST_ROOT=.\ufst DEVSTUDIO= ufst-clean &amp;&amp; nmake -f psi\msvc32.mak UFST_ROOT=.\ufst SBR=1 DEVSTUDIO= ufst &amp;&amp; nmake -f psi\msvc32.mak UFST_ROOT=.\ufst DEVSTUDIO= ufst-bsc"
CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak UFST_ROOT=.\ufst DEVSTUDIO= ufst-clean"
Output="$(ProjectDir)\..\ufstbin\gswin32c.exe"
@@ -86,7 +86,7 @@
>
<Tool
Name="VCNMakeTool"
- BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= UFST_ROOT=.\ufst SBR=1 DEVSTUDIO= gpcl6-ufst &amp;&amp; nmake -f psi\msvc32.mak WIN64= UFST_ROOT=.\ufst DEVSTUDIO= ufst-bsc"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= UFST_ROOT=.\ufst SBR=1 DEVSTUDIO= ufst-pcl &amp;&amp; nmake -f psi\msvc32.mak WIN64= UFST_ROOT=.\ufst DEVSTUDIO= ufst-bsc"
ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= UFST_ROOT=.\ufst DEVSTUDIO= ufst-clean &amp;&amp; nmake -f psi\msvc32.mak WIN64= UFST_ROOT=.\ufst SBR=1 DEVSTUDIO= ufst &amp;&amp; nmake -f psi\msvc32.mak WIN64= UFST_ROOT=.\ufst DEVSTUDIO= ufst-bsc"
CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= UFST_ROOT=.\ufst DEVSTUDIO= ufst-clean"
Output="$(ProjectDir)\..\ufstbin\gswin64c.exe"
diff --git a/windows/ghostpdf.vcproj b/windows/ghostpdf.vcproj
new file mode 100644
index 00000000..23c0c3a5
--- /dev/null
+++ b/windows/ghostpdf.vcproj
@@ -0,0 +1,664 @@
+<?xml version="1.0" encoding="utf-8"?>
+<VisualStudioProject
+ ProjectType="Visual C++"
+ Version="8.00"
+ Name="ghostpdf"
+ ProjectGUID="{4C038125-61B9-4147-9EA8-39690BA3A599}"
+ RootNamespace="ghostpdf"
+ Keyword="MakeFileProj"
+ >
+ <Platforms>
+ <Platform
+ Name="Win32"
+ />
+ <Platform
+ Name="x64"
+ />
+ </Platforms>
+ <ToolFiles>
+ </ToolFiles>
+ <Configurations>
+ <Configuration
+ Name="Debug|Win32"
+ OutputDirectory="debugobj"
+ IntermediateDirectory="debugobj"
+ ConfigurationType="0"
+ >
+ <Tool
+ Name="VCNMakeTool"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= debugbsc"
+ ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= debugclean &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= debugbsc"
+ CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= debugclean"
+ Output="$(ProjectDir)\..\debugbin\gpdfwin32c.exe"
+ PreprocessorDefinitions="WIN32;_DEBUG;DEBUG=1;TDEBUG=1;HAVE_SSE2=1"
+ IncludeSearchPath=""
+ ForcedIncludes=""
+ AssemblySearchPath=""
+ ForcedUsingAssemblies=""
+ CompileAsManaged=""
+ />
+ </Configuration>
+ <Configuration
+ Name="Debug|x64"
+ OutputDirectory="debugobj64"
+ IntermediateDirectory="debugobj64"
+ ConfigurationType="0"
+ >
+ <Tool
+ Name="VCNMakeTool"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= debugbsc"
+ ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= debugclean &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= debugbsc"
+ CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= debugclean"
+ Output="$(ProjectDir)\..\debugbin\gpdfwin64c.exe"
+ PreprocessorDefinitions="WIN64;_DEBUG;DEBUG=1;TDEBUG=1"
+ IncludeSearchPath=""
+ ForcedIncludes=""
+ AssemblySearchPath=""
+ ForcedUsingAssemblies=""
+ CompileAsManaged=""
+ />
+ </Configuration>
+ <Configuration
+ Name="Release|Win32"
+ OutputDirectory="obj"
+ IntermediateDirectory="obj"
+ ConfigurationType="0"
+ >
+ <Tool
+ Name="VCNMakeTool"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdf &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= bsc"
+ ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= clean &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdf &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= bsc"
+ CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= clean"
+ Output="$(ProjectDir)\..\bin\gpdfwin32c.exe"
+ PreprocessorDefinitions="WIN32;NDEBUG;HAVE_SSE2=1"
+ IncludeSearchPath=""
+ ForcedIncludes=""
+ AssemblySearchPath=""
+ ForcedUsingAssemblies=""
+ CompileAsManaged=""
+ />
+ </Configuration>
+ <Configuration
+ Name="Release|x64"
+ OutputDirectory="obj64"
+ IntermediateDirectory="obj64"
+ ConfigurationType="0"
+ >
+ <Tool
+ Name="VCNMakeTool"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= gpdf &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= bsc"
+ ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= clean &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= gpdf &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= bsc"
+ CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= clean"
+ Output="$(ProjectDir)\..\bin\gpdfwin64c.exe"
+ PreprocessorDefinitions="WIN32;NDEBUG;"
+ IncludeSearchPath=""
+ ForcedIncludes=""
+ AssemblySearchPath=""
+ ForcedUsingAssemblies=""
+ CompileAsManaged=""
+ />
+ </Configuration>
+ <Configuration
+ Name="Profile|Win32"
+ OutputDirectory="profobj"
+ IntermediateDirectory="profobj"
+ ConfigurationType="0"
+ >
+ <Tool
+ Name="VCNMakeTool"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdfprofile &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= profilebsc"
+ ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= profileclean &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdfprofile &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= profilebsc"
+ CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= profileclean"
+ Output="$(ProjectDir)\..\profbin\gpdfwin32c.exe"
+ PreprocessorDefinitions="WIN32;NDEBUG;DEBUG=0;TDEBUG=0;DEBUGSYM=1;HAVE_SSE2=1"
+ IncludeSearchPath=""
+ ForcedIncludes=""
+ AssemblySearchPath=""
+ ForcedUsingAssemblies=""
+ CompileAsManaged=""
+ />
+ </Configuration>
+ <Configuration
+ Name="Profile|x64"
+ OutputDirectory="profobj64"
+ IntermediateDirectory="profobj64"
+ ConfigurationType="0"
+ >
+ <Tool
+ Name="VCNMakeTool"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= gpdfprofile &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= profilebsc"
+ ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= profileclean &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= gpdfprofile &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= profilebsc"
+ CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= profileclean"
+ Output="$(ProjectDir)\..\profbin\gpdfwin64c.exe"
+ PreprocessorDefinitions="WIN64;_DEBUG;DEBUG=1;TDEBUG=1"
+ IncludeSearchPath=""
+ ForcedIncludes=""
+ AssemblySearchPath=""
+ ForcedUsingAssemblies=""
+ CompileAsManaged=""
+ />
+ </Configuration>
+ <Configuration
+ Name="Memento|Win32"
+ OutputDirectory="memobj"
+ IntermediateDirectory="memobj"
+ ConfigurationType="0"
+ >
+ <Tool
+ Name="VCNMakeTool"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdfmemento &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= mementobsc"
+ ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= mementoclean &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdfmemento &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= mementobsc"
+ CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= mementoclean"
+ Output="$(ProjectDir)\..\membin\gpdfwin32c.exe"
+ PreprocessorDefinitions="WIN32;_DEBUG;DEBUG=1;TDEBUG=1;HAVE_SSE2=1;MEMENTO=1"
+ IncludeSearchPath=""
+ ForcedIncludes=""
+ AssemblySearchPath=""
+ ForcedUsingAssemblies=""
+ CompileAsManaged=""
+ />
+ </Configuration>
+ <Configuration
+ Name="Memento|x64"
+ OutputDirectory="memobj64"
+ IntermediateDirectory="memobj64"
+ ConfigurationType="0"
+ >
+ <Tool
+ Name="VCNMakeTool"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= gpdfmemento &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= mementobsc"
+ ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= mementoclean &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= gpdfmemento &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= mementobsc"
+ CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= mementoclean"
+ Output="$(ProjectDir)\..\membin\gpdfwin64c.exe"
+ PreprocessorDefinitions="WIN64;_DEBUG;DEBUG=1;TDEBUG=1"
+ IncludeSearchPath=""
+ ForcedIncludes=""
+ AssemblySearchPath=""
+ ForcedUsingAssemblies=""
+ CompileAsManaged=""
+ />
+ </Configuration>
+ <Configuration
+ Name="Debug-cups|Win32"
+ OutputDirectory="$(ConfigurationName)"
+ IntermediateDirectory="$(ConfigurationName)"
+ ConfigurationType="0"
+ >
+ <Tool
+ Name="VCNMakeTool"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= WITH_CUPS=1 gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CUPS=1 debugbsc"
+ ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CUPS=1 debugclean &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= WITH_CUPS=1 gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CUPS=1 debugbsc"
+ CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CUPS=1 debugclean"
+ Output="$(ProjectDir)\..\debugbin\gpdfwin32c.exe"
+ PreprocessorDefinitions="WIN32;_DEBUG;DEBUG=1;TDEBUG=1;HAVE_SSE2=1"
+ IncludeSearchPath=""
+ ForcedIncludes=""
+ AssemblySearchPath=""
+ ForcedUsingAssemblies=""
+ CompileAsManaged=""
+ />
+ </Configuration>
+ <Configuration
+ Name="Debug-cups|x64"
+ OutputDirectory="$(PlatformName)\$(ConfigurationName)"
+ IntermediateDirectory="$(PlatformName)\$(ConfigurationName)"
+ ConfigurationType="0"
+ >
+ <Tool
+ Name="VCNMakeTool"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= WITH_CUPS=1 gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= WITH_CUPS=1 debugbsc"
+ ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= WITH_CUPS=1 debugclean &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= WITH_CUPS=1 gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= WITH_CUPS=1 debugbsc"
+ CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= debugclean"
+ Output="$(ProjectDir)\..\debugbin\gpdfwin64c.exe"
+ PreprocessorDefinitions="WIN64;_DEBUG;DEBUG=1;TDEBUG=1"
+ IncludeSearchPath=""
+ ForcedIncludes=""
+ AssemblySearchPath=""
+ ForcedUsingAssemblies=""
+ CompileAsManaged=""
+ />
+ </Configuration>
+ <Configuration
+ Name="Debug-contrib|Win32"
+ OutputDirectory="$(ConfigurationName)"
+ IntermediateDirectory="$(ConfigurationName)"
+ ConfigurationType="0"
+ >
+ <Tool
+ Name="VCNMakeTool"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= WITH_CONTRIB=1 gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CONTRIB=1 debugbsc"
+ ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CONTRIB=1 debugclean &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= WITH_CUPS=1 gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CONTRIB=1 debugbsc"
+ CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CONTRIB=1 debugclean"
+ Output="$(ProjectDir)\..\debugbin\gpdfwin32c.exe"
+ PreprocessorDefinitions="WIN32;_DEBUG;DEBUG=1;TDEBUG=1;HAVE_SSE2=1"
+ IncludeSearchPath=""
+ ForcedIncludes=""
+ AssemblySearchPath=""
+ ForcedUsingAssemblies=""
+ CompileAsManaged=""
+ />
+ </Configuration>
+ <Configuration
+ Name="Debug-contrib|x64"
+ OutputDirectory="$(PlatformName)\$(ConfigurationName)"
+ IntermediateDirectory="$(PlatformName)\$(ConfigurationName)"
+ ConfigurationType="0"
+ >
+ <Tool
+ Name="VCNMakeTool"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= WITH_CUPS=1 gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= WITH_CUPS=1 debugbsc"
+ ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= WITH_CUPS=1 debugclean &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= WITH_CUPS=1 gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= WITH_CUPS=1 debugbsc"
+ CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= debugclean"
+ Output="$(ProjectDir)\..\debugbin\gpdfwin64c.exe"
+ PreprocessorDefinitions="WIN64;_DEBUG;DEBUG=1;TDEBUG=1"
+ IncludeSearchPath=""
+ ForcedIncludes=""
+ AssemblySearchPath=""
+ ForcedUsingAssemblies=""
+ CompileAsManaged=""
+ />
+ </Configuration>
+ <Configuration
+ Name="Release-contrib|Win32"
+ OutputDirectory="$(ConfigurationName)"
+ IntermediateDirectory="$(ConfigurationName)"
+ ConfigurationType="0"
+ >
+ <Tool
+ Name="VCNMakeTool"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdf &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= bsc"
+ ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= clean &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdf &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= bsc"
+ CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= clean"
+ Output="$(ProjectDir)\..\bin\gpdfwin32c.exe"
+ PreprocessorDefinitions="WIN32;NDEBUG;HAVE_SSE2=1"
+ IncludeSearchPath=""
+ ForcedIncludes=""
+ AssemblySearchPath=""
+ ForcedUsingAssemblies=""
+ CompileAsManaged=""
+ />
+ </Configuration>
+ <Configuration
+ Name="Release-contrib|x64"
+ OutputDirectory="$(PlatformName)\$(ConfigurationName)"
+ IntermediateDirectory="$(PlatformName)\$(ConfigurationName)"
+ ConfigurationType="0"
+ >
+ <Tool
+ Name="VCNMakeTool"
+ BuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= WITH_CONTRIB=1 SBR=1 DEVSTUDIO= WITH_CONTRIB=1 gpdf &amp;&amp; nmake -f psi\msvc32.mak WIN64= WITH_CONTRIB=1 DEVSTUDIO= bsc"
+ ReBuildCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= WITH_CONTRIB=1 DEVSTUDIO= clean &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 WITH_CONTRIB=1 DEVSTUDIO= gpdf &amp;&amp; nmake -f psi\msvc32.mak WIN64= WITH_CONTRIB=1 DEVSTUDIO= bsc"
+ CleanCommandLine="cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= WITH_CONTRIB=1 DEVSTUDIO= clean"
+ Output="$(ProjectDir)\..\bin\gpdfwin64c.exe"
+ PreprocessorDefinitions="WIN32;NDEBUG;"
+ IncludeSearchPath=""
+ ForcedIncludes=""
+ AssemblySearchPath=""
+ ForcedUsingAssemblies=""
+ CompileAsManaged=""
+ />
+ </Configuration>
+ </Configurations>
+ <References>
+ </References>
+ <Files>
+ <Filter
+ Name="pdf (*.c)"
+ >
+ <File
+ RelativePath="..\pdf\ghostpdf.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdftop.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_agl.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_annot.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_array.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_check.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_ciddec.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_cidcmap.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_colour.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_deref.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_device.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_dict.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_doc.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_fapi.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_file.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_fmap.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_font.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_font0.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_font1.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_font11.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_font1C.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_font3.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_font9.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_fontps.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_fontTT.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_func.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_gstate.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_image.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_int.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_loop_detect.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_mark.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_misc.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_obj.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_optcontent.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_page.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_path.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_pattern.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_repair.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_sec.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_shading.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_stack.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_text.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_trans.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_utf8.c"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_xref.c"
+ >
+ </File>
+ </Filter>
+ <Filter
+ Name="pdf (*.h)"
+ >
+ <File
+ RelativePath="..\pdf\ghostpdf.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_agl.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_annot.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_array.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_check.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_cmap.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_colour.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_deref.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_device.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_dict.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_doc.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_file.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_fmap.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_font.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_font0.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_font1.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_font1C.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_font3.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_fontTT.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_fontps.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_font_types.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_func.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_gstate.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_image.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_int.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_loop_detect.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_mark.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_misc.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_obj.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_optcontent.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_page.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_path.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_pattern.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_repair.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_sec.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_shading.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_stack.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_text.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_trans.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_types.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_utf8.h"
+ >
+ </File>
+ <File
+ RelativePath="..\pdf\pdf_xref.h"
+ >
+ </File>
+ </Filter>
+ </Files>
+ <Globals>
+ </Globals>
+</VisualStudioProject>
diff --git a/windows/ghostpdf.vcxproj b/windows/ghostpdf.vcxproj
new file mode 100644
index 00000000..cfcce87e
--- /dev/null
+++ b/windows/ghostpdf.vcxproj
@@ -0,0 +1,394 @@
+<?xml version="1.0" encoding="utf-8"?>
+<Project DefaultTargets="Build" ToolsVersion="15.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
+ <ItemGroup Label="ProjectConfigurations">
+ <ProjectConfiguration Include="Debug-contrib|Win32">
+ <Configuration>Debug-contrib</Configuration>
+ <Platform>Win32</Platform>
+ </ProjectConfiguration>
+ <ProjectConfiguration Include="Debug-contrib|x64">
+ <Configuration>Debug-contrib</Configuration>
+ <Platform>x64</Platform>
+ </ProjectConfiguration>
+ <ProjectConfiguration Include="Debug-cups|Win32">
+ <Configuration>Debug-cups</Configuration>
+ <Platform>Win32</Platform>
+ </ProjectConfiguration>
+ <ProjectConfiguration Include="Debug-cups|x64">
+ <Configuration>Debug-cups</Configuration>
+ <Platform>x64</Platform>
+ </ProjectConfiguration>
+ <ProjectConfiguration Include="Debug|Win32">
+ <Configuration>Debug</Configuration>
+ <Platform>Win32</Platform>
+ </ProjectConfiguration>
+ <ProjectConfiguration Include="Debug|x64">
+ <Configuration>Debug</Configuration>
+ <Platform>x64</Platform>
+ </ProjectConfiguration>
+ <ProjectConfiguration Include="Memento|Win32">
+ <Configuration>Memento</Configuration>
+ <Platform>Win32</Platform>
+ </ProjectConfiguration>
+ <ProjectConfiguration Include="Memento|x64">
+ <Configuration>Memento</Configuration>
+ <Platform>x64</Platform>
+ </ProjectConfiguration>
+ <ProjectConfiguration Include="Profile|Win32">
+ <Configuration>Profile</Configuration>
+ <Platform>Win32</Platform>
+ </ProjectConfiguration>
+ <ProjectConfiguration Include="Profile|x64">
+ <Configuration>Profile</Configuration>
+ <Platform>x64</Platform>
+ </ProjectConfiguration>
+ <ProjectConfiguration Include="Release-contrib|Win32">
+ <Configuration>Release-contrib</Configuration>
+ <Platform>Win32</Platform>
+ </ProjectConfiguration>
+ <ProjectConfiguration Include="Release-contrib|x64">
+ <Configuration>Release-contrib</Configuration>
+ <Platform>x64</Platform>
+ </ProjectConfiguration>
+ <ProjectConfiguration Include="Release|Win32">
+ <Configuration>Release</Configuration>
+ <Platform>Win32</Platform>
+ </ProjectConfiguration>
+ <ProjectConfiguration Include="Release|x64">
+ <Configuration>Release</Configuration>
+ <Platform>x64</Platform>
+ </ProjectConfiguration>
+ </ItemGroup>
+ <PropertyGroup Label="Globals">
+ <ProjectGuid>{4C038125-61B9-4147-9EA8-39690BA3A599}</ProjectGuid>
+ <RootNamespace>ghostpdf</RootNamespace>
+ <Keyword>MakeFileProj</Keyword>
+ </PropertyGroup>
+ <Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release-contrib|Win32'" Label="Configuration">
+ <ConfigurationType>Makefile</ConfigurationType>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug-contrib|Win32'" Label="Configuration">
+ <ConfigurationType>Makefile</ConfigurationType>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug-cups|Win32'" Label="Configuration">
+ <ConfigurationType>Makefile</ConfigurationType>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Memento|Win32'" Label="Configuration">
+ <ConfigurationType>Makefile</ConfigurationType>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Profile|Win32'" Label="Configuration">
+ <ConfigurationType>Makefile</ConfigurationType>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="Configuration">
+ <ConfigurationType>Makefile</ConfigurationType>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">
+ <ConfigurationType>Makefile</ConfigurationType>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release-contrib|x64'" Label="Configuration">
+ <ConfigurationType>Makefile</ConfigurationType>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug-contrib|x64'" Label="Configuration">
+ <ConfigurationType>Makefile</ConfigurationType>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug-cups|x64'" Label="Configuration">
+ <ConfigurationType>Makefile</ConfigurationType>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Memento|x64'" Label="Configuration">
+ <ConfigurationType>Makefile</ConfigurationType>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Profile|x64'" Label="Configuration">
+ <ConfigurationType>Makefile</ConfigurationType>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="Configuration">
+ <ConfigurationType>Makefile</ConfigurationType>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="Configuration">
+ <ConfigurationType>Makefile</ConfigurationType>
+ <PlatformToolset>v142</PlatformToolset>
+ </PropertyGroup>
+ <Import Project="$(VCTargetsPath)\Microsoft.Cpp.props" />
+ <ImportGroup Label="ExtensionSettings">
+ </ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release-contrib|Win32'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug-contrib|Win32'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug-cups|Win32'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Memento|Win32'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Profile|Win32'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release-contrib|x64'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug-contrib|x64'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug-cups|x64'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Memento|x64'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Profile|x64'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
+ <ImportGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'" Label="PropertySheets">
+ <Import Project="$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props" Condition="exists('$(UserRootDir)\Microsoft.Cpp.$(Platform).user.props')" Label="LocalAppDataPlatform" />
+ </ImportGroup>
+ <PropertyGroup Label="UserMacros" />
+ <PropertyGroup>
+ <_ProjectFileVersion>16.0.29511.113</_ProjectFileVersion>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
+ <OutDir>debugobj\</OutDir>
+ <IntDir>debugobj\</IntDir>
+ <NMakeBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= debugbsc</NMakeBuildCommandLine>
+ <NMakeReBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= debugclean &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= debugbsc</NMakeReBuildCommandLine>
+ <NMakeCleanCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= debugclean</NMakeCleanCommandLine>
+ <NMakeOutput>$(ProjectDir)\..\debugbin\gpdfwin32c.exe</NMakeOutput>
+ <NMakePreprocessorDefinitions>WIN32;_DEBUG;DEBUG=1;TDEBUG=1;HAVE_SSE2=1;$(NMakePreprocessorDefinitions)</NMakePreprocessorDefinitions>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|x64'">
+ <OutDir>debugobj64\</OutDir>
+ <IntDir>debugobj64\</IntDir>
+ <NMakeBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= debugbsc</NMakeBuildCommandLine>
+ <NMakeReBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= debugclean &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= debugbsc</NMakeReBuildCommandLine>
+ <NMakeCleanCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= debugclean</NMakeCleanCommandLine>
+ <NMakeOutput>$(ProjectDir)\..\debugbin\gpdfwin64c.exe</NMakeOutput>
+ <NMakePreprocessorDefinitions>WIN64;_DEBUG;DEBUG=1;TDEBUG=1;$(NMakePreprocessorDefinitions)</NMakePreprocessorDefinitions>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|Win32'">
+ <OutDir>obj\</OutDir>
+ <IntDir>obj\</IntDir>
+ <NMakeBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdf &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= bsc</NMakeBuildCommandLine>
+ <NMakeReBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= clean &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdf &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= bsc</NMakeReBuildCommandLine>
+ <NMakeCleanCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= clean</NMakeCleanCommandLine>
+ <NMakeOutput>$(ProjectDir)\..\bin\gpdfwin32c.exe</NMakeOutput>
+ <NMakePreprocessorDefinitions>WIN32;NDEBUG;HAVE_SSE2=1;$(NMakePreprocessorDefinitions)</NMakePreprocessorDefinitions>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
+ <OutDir>obj64\</OutDir>
+ <IntDir>obj64\</IntDir>
+ <NMakeBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= gpdf &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= bsc</NMakeBuildCommandLine>
+ <NMakeReBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= clean &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= gpdf &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= bsc</NMakeReBuildCommandLine>
+ <NMakeCleanCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= clean</NMakeCleanCommandLine>
+ <NMakeOutput>$(ProjectDir)\..\bin\gpdfwin64c.exe</NMakeOutput>
+ <NMakePreprocessorDefinitions>WIN32;NDEBUG;$(NMakePreprocessorDefinitions)</NMakePreprocessorDefinitions>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Profile|Win32'">
+ <OutDir>profobj\</OutDir>
+ <IntDir>profobj\</IntDir>
+ <NMakeBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdfprofile &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= profilebsc</NMakeBuildCommandLine>
+ <NMakeReBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= profileclean &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdfprofile &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= profilebsc</NMakeReBuildCommandLine>
+ <NMakeCleanCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= profileclean</NMakeCleanCommandLine>
+ <NMakeOutput>$(ProjectDir)\..\profbin\gpdfwin32c.exe</NMakeOutput>
+ <NMakePreprocessorDefinitions>WIN32;NDEBUG;DEBUG=0;TDEBUG=0;DEBUGSYM=1;HAVE_SSE2=1;$(NMakePreprocessorDefinitions)</NMakePreprocessorDefinitions>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Profile|x64'">
+ <OutDir>profobj64\</OutDir>
+ <IntDir>profobj64\</IntDir>
+ <NMakeBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= gpdfprofile &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= profilebsc</NMakeBuildCommandLine>
+ <NMakeReBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= profileclean &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= gpdfprofile &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= profilebsc</NMakeReBuildCommandLine>
+ <NMakeCleanCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= profileclean</NMakeCleanCommandLine>
+ <NMakeOutput>$(ProjectDir)\..\profbin\gpdfwin64c.exe</NMakeOutput>
+ <NMakePreprocessorDefinitions>WIN64;_DEBUG;DEBUG=1;TDEBUG=1;$(NMakePreprocessorDefinitions)</NMakePreprocessorDefinitions>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Memento|Win32'">
+ <OutDir>memobj\</OutDir>
+ <IntDir>memobj\</IntDir>
+ <NMakeBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdfmemento &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= mementobsc</NMakeBuildCommandLine>
+ <NMakeReBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= mementoclean &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdfmemento &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= mementobsc</NMakeReBuildCommandLine>
+ <NMakeCleanCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= mementoclean</NMakeCleanCommandLine>
+ <NMakeOutput>$(ProjectDir)\..\membin\gpdfwin32c.exe</NMakeOutput>
+ <NMakePreprocessorDefinitions>WIN32;_DEBUG;DEBUG=1;TDEBUG=1;HAVE_SSE2=1;MEMENTO=1;$(NMakePreprocessorDefinitions)</NMakePreprocessorDefinitions>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Memento|x64'">
+ <OutDir>memobj64\</OutDir>
+ <IntDir>memobj64\</IntDir>
+ <NMakeBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= gpdfmemento &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= mementobsc</NMakeBuildCommandLine>
+ <NMakeReBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= mementoclean &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= gpdfmemento &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= mementobsc</NMakeReBuildCommandLine>
+ <NMakeCleanCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= mementoclean</NMakeCleanCommandLine>
+ <NMakeOutput>$(ProjectDir)\..\membin\gpdfwin64c.exe</NMakeOutput>
+ <NMakePreprocessorDefinitions>WIN64;_DEBUG;DEBUG=1;TDEBUG=1;$(NMakePreprocessorDefinitions)</NMakePreprocessorDefinitions>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug-cups|Win32'">
+ <OutDir>$(Configuration)\</OutDir>
+ <IntDir>$(Configuration)\</IntDir>
+ <NMakeBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= WITH_CUPS=1 gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CUPS=1 debugbsc</NMakeBuildCommandLine>
+ <NMakeReBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CUPS=1 debugclean &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= WITH_CUPS=1 gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CUPS=1 debugbsc</NMakeReBuildCommandLine>
+ <NMakeCleanCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CUPS=1 debugclean</NMakeCleanCommandLine>
+ <NMakeOutput>$(ProjectDir)\..\debugbin\gpdfwin32c.exe</NMakeOutput>
+ <NMakePreprocessorDefinitions>WIN32;_DEBUG;DEBUG=1;TDEBUG=1;HAVE_SSE2=1;$(NMakePreprocessorDefinitions)</NMakePreprocessorDefinitions>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug-cups|x64'">
+ <OutDir>$(Platform)\$(Configuration)\</OutDir>
+ <IntDir>$(Platform)\$(Configuration)\</IntDir>
+ <NMakeBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= WITH_CUPS=1 gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= WITH_CUPS=1 debugbsc</NMakeBuildCommandLine>
+ <NMakeReBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= WITH_CUPS=1 debugclean &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= WITH_CUPS=1 gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= WITH_CUPS=1 debugbsc</NMakeReBuildCommandLine>
+ <NMakeCleanCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= debugclean</NMakeCleanCommandLine>
+ <NMakeOutput>$(ProjectDir)\..\debugbin\gpdfwin64c.exe</NMakeOutput>
+ <NMakePreprocessorDefinitions>WIN64;_DEBUG;DEBUG=1;TDEBUG=1;$(NMakePreprocessorDefinitions)</NMakePreprocessorDefinitions>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug-contrib|Win32'">
+ <OutDir>$(Configuration)\</OutDir>
+ <IntDir>$(Configuration)\</IntDir>
+ <NMakeBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= WITH_CONTRIB=1 gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CONTRIB=1 debugbsc</NMakeBuildCommandLine>
+ <NMakeReBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CONTRIB=1 debugclean &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= WITH_CUPS=1 gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CONTRIB=1 debugbsc</NMakeReBuildCommandLine>
+ <NMakeCleanCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CONTRIB=1 debugclean</NMakeCleanCommandLine>
+ <NMakeOutput>$(ProjectDir)\..\debugbin\gpdfwin32c.exe</NMakeOutput>
+ <NMakePreprocessorDefinitions>WIN32;_DEBUG;DEBUG=1;TDEBUG=1;HAVE_SSE2=1;$(NMakePreprocessorDefinitions)</NMakePreprocessorDefinitions>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug-contrib|x64'">
+ <OutDir>$(Platform)\$(Configuration)\</OutDir>
+ <IntDir>$(Platform)\$(Configuration)\</IntDir>
+ <NMakeBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= WITH_CUPS=1 gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= WITH_CUPS=1 debugbsc</NMakeBuildCommandLine>
+ <NMakeReBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= WITH_CUPS=1 debugclean &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 DEVSTUDIO= WITH_CUPS=1 gpdfdebug &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= WITH_CUPS=1 debugbsc</NMakeReBuildCommandLine>
+ <NMakeCleanCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= DEVSTUDIO= debugclean</NMakeCleanCommandLine>
+ <NMakeOutput>$(ProjectDir)\..\debugbin\gpdfwin64c.exe</NMakeOutput>
+ <NMakePreprocessorDefinitions>WIN64;_DEBUG;DEBUG=1;TDEBUG=1;$(NMakePreprocessorDefinitions)</NMakePreprocessorDefinitions>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release-contrib|Win32'">
+ <OutDir>$(Configuration)\</OutDir>
+ <IntDir>$(Configuration)\</IntDir>
+ <NMakeBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdf &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= bsc</NMakeBuildCommandLine>
+ <NMakeReBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= clean &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= gpdf &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= bsc</NMakeReBuildCommandLine>
+ <NMakeCleanCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= clean</NMakeCleanCommandLine>
+ <NMakeOutput>$(ProjectDir)\..\bin\gpdfwin32c.exe</NMakeOutput>
+ <NMakePreprocessorDefinitions>WIN32;NDEBUG;HAVE_SSE2=1;$(NMakePreprocessorDefinitions)</NMakePreprocessorDefinitions>
+ </PropertyGroup>
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Release-contrib|x64'">
+ <OutDir>$(Platform)\$(Configuration)\</OutDir>
+ <IntDir>$(Platform)\$(Configuration)\</IntDir>
+ <NMakeBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= WITH_CONTRIB=1 SBR=1 DEVSTUDIO= WITH_CONTRIB=1 gpdf &amp;&amp; nmake -f psi\msvc32.mak WIN64= WITH_CONTRIB=1 DEVSTUDIO= bsc</NMakeBuildCommandLine>
+ <NMakeReBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= WITH_CONTRIB=1 DEVSTUDIO= clean &amp;&amp; nmake -f psi\msvc32.mak WIN64= SBR=1 WITH_CONTRIB=1 DEVSTUDIO= gpdf &amp;&amp; nmake -f psi\msvc32.mak WIN64= WITH_CONTRIB=1 DEVSTUDIO= bsc</NMakeReBuildCommandLine>
+ <NMakeCleanCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak WIN64= WITH_CONTRIB=1 DEVSTUDIO= clean</NMakeCleanCommandLine>
+ <NMakeOutput>$(ProjectDir)\..\bin\gpdfwin64c.exe</NMakeOutput>
+ <NMakePreprocessorDefinitions>WIN32;NDEBUG;$(NMakePreprocessorDefinitions)</NMakePreprocessorDefinitions>
+ </PropertyGroup>
+ <ItemDefinitionGroup>
+ </ItemDefinitionGroup>
+ <ItemGroup>
+ <ClCompile Include="..\pdf\ghostpdf.c" />
+ <ClCompile Include="..\pdf\pdftop.c" />
+ <ClCompile Include="..\pdf\pdf_agl.c" />
+ <ClCompile Include="..\pdf\pdf_annot.c" />
+ <ClCompile Include="..\pdf\pdf_array.c" />
+ <ClCompile Include="..\pdf\pdf_check.c" />
+ <ClCompile Include="..\pdf\pdf_ciddec.c" />
+ <ClCompile Include="..\pdf\pdf_cmap.c" />
+ <ClCompile Include="..\pdf\pdf_colour.c" />
+ <ClCompile Include="..\pdf\pdf_deref.c" />
+ <ClCompile Include="..\pdf\pdf_device.c" />
+ <ClCompile Include="..\pdf\pdf_dict.c" />
+ <ClCompile Include="..\pdf\pdf_doc.c" />
+ <ClCompile Include="..\pdf\pdf_fapi.c" />
+ <ClCompile Include="..\pdf\pdf_file.c" />
+ <ClCompile Include="..\pdf\pdf_fmap.c" />
+ <ClCompile Include="..\pdf\pdf_font.c" />
+ <ClCompile Include="..\pdf\pdf_font0.c" />
+ <ClCompile Include="..\pdf\pdf_font1.c" />
+ <ClCompile Include="..\pdf\pdf_font11.c" />
+ <ClCompile Include="..\pdf\pdf_font1C.c" />
+ <ClCompile Include="..\pdf\pdf_font3.c" />
+ <ClCompile Include="..\pdf\pdf_font9.c" />
+ <ClCompile Include="..\pdf\pdf_fontps.c" />
+ <ClCompile Include="..\pdf\pdf_fontTT.c" />
+ <ClCompile Include="..\pdf\pdf_func.c" />
+ <ClCompile Include="..\pdf\pdf_gstate.c" />
+ <ClCompile Include="..\pdf\pdf_image.c" />
+ <ClCompile Include="..\pdf\pdf_int.c" />
+ <ClCompile Include="..\pdf\pdf_loop_detect.c" />
+ <ClCompile Include="..\pdf\pdf_mark.c" />
+ <ClCompile Include="..\pdf\pdf_misc.c" />
+ <ClCompile Include="..\pdf\pdf_obj.c" />
+ <ClCompile Include="..\pdf\pdf_optcontent.c" />
+ <ClCompile Include="..\pdf\pdf_page.c" />
+ <ClCompile Include="..\pdf\pdf_path.c" />
+ <ClCompile Include="..\pdf\pdf_pattern.c" />
+ <ClCompile Include="..\pdf\pdf_repair.c" />
+ <ClCompile Include="..\pdf\pdf_sec.c" />
+ <ClCompile Include="..\pdf\pdf_shading.c" />
+ <ClCompile Include="..\pdf\pdf_stack.c" />
+ <ClCompile Include="..\pdf\pdf_text.c" />
+ <ClCompile Include="..\pdf\pdf_trans.c" />
+ <ClCompile Include="..\pdf\pdf_utf8.c" />
+ <ClCompile Include="..\pdf\pdf_xref.c" />
+ </ItemGroup>
+ <ItemGroup>
+ <ClInclude Include="..\pdf\ghostpdf.h" />
+ <ClInclude Include="..\pdf\pdf_agl.h" />
+ <ClInclude Include="..\pdf\pdf_annot.h" />
+ <ClInclude Include="..\pdf\pdf_array.h" />
+ <ClInclude Include="..\pdf\pdf_check.h" />
+ <ClInclude Include="..\pdf\pdf_cmap.h" />
+ <ClInclude Include="..\pdf\pdf_colour.h" />
+ <ClInclude Include="..\pdf\pdf_deref.h" />
+ <ClInclude Include="..\pdf\pdf_device.h" />
+ <ClInclude Include="..\pdf\pdf_dict.h" />
+ <ClInclude Include="..\pdf\pdf_doc.h" />
+ <ClInclude Include="..\pdf\pdf_file.h" />
+ <ClInclude Include="..\pdf\pdf_fmap.h" />
+ <ClInclude Include="..\pdf\pdf_font.h" />
+ <ClInclude Include="..\pdf\pdf_font0.h" />
+ <ClInclude Include="..\pdf\pdf_font1.h" />
+ <ClInclude Include="..\pdf\pdf_font1C.h" />
+ <ClInclude Include="..\pdf\pdf_font3.h" />
+ <ClInclude Include="..\pdf\pdf_fontTT.h" />
+ <ClInclude Include="..\pdf\pdf_fontps.h" />
+ <ClInclude Include="..\pdf\pdf_font_types.h" />
+ <ClInclude Include="..\pdf\pdf_func.h" />
+ <ClInclude Include="..\pdf\pdf_gstate.h" />
+ <ClInclude Include="..\pdf\pdf_image.h" />
+ <ClInclude Include="..\pdf\pdf_int.h" />
+ <ClInclude Include="..\pdf\pdf_loop_detect.h" />
+ <ClInclude Include="..\pdf\pdf_mark.h" />
+ <ClInclude Include="..\pdf\pdf_misc.h" />
+ <ClInclude Include="..\pdf\pdf_obj.h" />
+ <ClInclude Include="..\pdf\pdf_optcontent.h" />
+ <ClInclude Include="..\pdf\pdf_page.h" />
+ <ClInclude Include="..\pdf\pdf_path.h" />
+ <ClInclude Include="..\pdf\pdf_pattern.h" />
+ <ClInclude Include="..\pdf\pdf_repair.h" />
+ <ClInclude Include="..\pdf\pdf_sec.h" />
+ <ClInclude Include="..\pdf\pdf_shading.h" />
+ <ClInclude Include="..\pdf\pdf_stack.h" />
+ <ClInclude Include="..\pdf\pdf_text.h" />
+ <ClInclude Include="..\pdf\pdf_trans.h" />
+ <ClInclude Include="..\pdf\pdf_types.h" />
+ <ClInclude Include="..\pdf\pdf_utf8.h" />
+ <ClInclude Include="..\pdf\pdf_xref.h" />
+ </ItemGroup>
+ <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
+ <ImportGroup Label="ExtensionTargets">
+ </ImportGroup>
+</Project> \ No newline at end of file
diff --git a/windows/ghostpdf.vcxproj.filters b/windows/ghostpdf.vcxproj.filters
new file mode 100644
index 00000000..3a43e928
--- /dev/null
+++ b/windows/ghostpdf.vcxproj.filters
@@ -0,0 +1,276 @@
+<?xml version="1.0" encoding="utf-8"?>
+<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
+ <ItemGroup>
+ <Filter Include="pdf %28%2a.c%29">
+ <UniqueIdentifier>{d24cdec9-c0b8-420c-95cc-57a65ea6a8f6}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="pdf %28%2a.h%29">
+ <UniqueIdentifier>{2979d80e-156d-413a-88a9-a4704eff2539}</UniqueIdentifier>
+ </Filter>
+ </ItemGroup>
+ <ItemGroup>
+ <ClCompile Include="..\pdf\ghostpdf.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_array.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_colour.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_dict.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_file.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_font.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_font0.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_font1.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_font11.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_font1C.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_font3.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_font9.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_fontps.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_fontTT.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_func.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_gstate.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_image.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_int.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_loop_detect.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_path.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_pattern.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_shading.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_stack.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_text.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_trans.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_xref.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdftop.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_agl.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_annot.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_check.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_ciddec.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_cmap.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_deref.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_device.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_doc.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_fapi.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_fmap.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_mark.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_misc.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_obj.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_optcontent.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_page.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_repair.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_sec.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ <ClCompile Include="..\pdf\pdf_utf8.c">
+ <Filter>pdf %28%2a.c%29</Filter>
+ </ClCompile>
+ </ItemGroup>
+ <ItemGroup>
+ <ClInclude Include="..\pdf\ghostpdf.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_array.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_colour.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_dict.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_file.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_fmap.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_font.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_font0.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_font1.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_font1C.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_font3.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_fontps.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_fontTT.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_func.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_gstate.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_image.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_int.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_loop_detect.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_path.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_pattern.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_shading.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_stack.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_text.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_trans.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_types.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_xref.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_agl.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_annot.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_check.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_cmap.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_deref.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_device.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_doc.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_font_types.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_mark.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_misc.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_obj.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_optcontent.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_page.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_repair.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_sec.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\pdf\pdf_utf8.h">
+ <Filter>pdf %28%2a.h%29</Filter>
+ </ClInclude>
+ </ItemGroup>
+</Project> \ No newline at end of file
diff --git a/windows/ghostpdl.vcproj b/windows/ghostpdl.vcproj
index 908db316..6d8e7456 100644
--- a/windows/ghostpdl.vcproj
+++ b/windows/ghostpdl.vcproj
@@ -334,6 +334,30 @@
>
</File>
</Filter>
+ <Filter
+ Name="urf"
+ >
+ <File
+ RelativePath="..\gpdl\urf\urftop.c"
+ >
+ </File>
+ </Filter>
+ <Filter
+ Name="image"
+ >
+ <File
+ RelativePath="..\gpdl\image\imagetop.c"
+ >
+ </File>
+ </Filter>
+ <Filter
+ Name="pwg"
+ >
+ <File
+ RelativePath="..\gpdl\pwg\pwgtop.c"
+ >
+ </File>
+ </Filter>
</Files>
<Globals>
</Globals>
diff --git a/windows/ghostscript.vcproj b/windows/ghostscript.vcproj
index 2a30c559..d2d5b0ed 100644
--- a/windows/ghostscript.vcproj
+++ b/windows/ghostscript.vcproj
@@ -1994,6 +1994,10 @@
>
</File>
<File
+ RelativePath="..\base\gsagl.c"
+ >
+ </File>
+ <File
RelativePath="..\base\gsalloc.c"
>
</File>
@@ -2146,10 +2150,10 @@
>
</File>
<File
- RelativePath="..\base\gsgstate.c"
- >
- </File>
- <File
+ RelativePath="..\base\gsgstate.c"
+ >
+ </File>
+ <File
RelativePath="..\base\gshsb.c"
>
</File>
@@ -2157,7 +2161,7 @@
RelativePath="..\base\gsht.c"
>
</File>
- <File
+ <File
RelativePath="..\base\gsht1.c"
>
</File>
@@ -2314,18 +2318,18 @@
>
</File>
<File
- RelativePath="..\base\gsstrl.c"
- >
- </File>
- <File
+ RelativePath="..\base\gsstrl.c"
+ >
+ </File>
+ <File
RelativePath="..\base\gstext.c"
>
</File>
<File
- RelativePath="..\base\gstiffio.c"
- >
- </File>
- <File
+ RelativePath="..\base\gstiffio.c"
+ >
+ </File>
+ <File
RelativePath="..\base\gstrap.c"
>
</File>
@@ -3374,11 +3378,11 @@
>
</File>
<File
- RelativePath="..\base\gen_ordered.h"
+ RelativePath="..\base\gen_ordered.h"
>
</File>
<File
- RelativePath="..\base\gp.h"
+ RelativePath="..\base\gp.h"
>
</File>
<File
@@ -3418,6 +3422,10 @@
>
</File>
<File
+ RelativePath="..\base\gsagl.h"
+ >
+ </File>
+ <File
RelativePath="..\base\gsalloc.h"
>
</File>
@@ -3598,10 +3606,10 @@
>
</File>
<File
- RelativePath="..\base\gsform1.h"
- >
- </File>
- <File
+ RelativePath="..\base\gsform1.h"
+ >
+ </File>
+ <File
RelativePath="..\base\gsfunc.h"
>
</File>
@@ -3609,11 +3617,11 @@
RelativePath="..\base\gsfunc0.h"
>
</File>
- <File
- RelativePath="..\base\gsfunc3.h"
- >
- </File>
- <File
+ <File
+ RelativePath="..\base\gsfunc3.h"
+ >
+ </File>
+ <File
RelativePath="..\base\gsfunc4.h"
>
</File>
@@ -3629,11 +3637,11 @@
RelativePath="..\base\gsgdata.h"
>
</File>
- <File
- RelativePath="..\base\gsgstate.h"
- >
- </File>
- <File
+ <File
+ RelativePath="..\base\gsgstate.h"
+ >
+ </File>
+ <File
RelativePath="..\base\gshsb.h"
>
</File>
@@ -3842,10 +3850,10 @@
>
</File>
<File
- RelativePath="..\base\gsstrl.h"
- >
- </File>
- <File
+ RelativePath="..\base\gsstrl.h"
+ >
+ </File>
+ <File
RelativePath="..\base\gsstruct.h"
>
</File>
@@ -3858,10 +3866,10 @@
>
</File>
<File
- RelativePath="..\base\gstiffio.h"
- >
- </File>
- <File
+ RelativePath="..\base\gstiffio.h"
+ >
+ </File>
+ <File
RelativePath="..\base\gstparam.h"
>
</File>
@@ -5670,10 +5678,10 @@
>
</File>
<File
- RelativePath="..\devices\gdevchameleon.c"
- >
- </File>
- <File
+ RelativePath="..\devices\gdevchameleon.c"
+ >
+ </File>
+ <File
RelativePath="..\devices\gdevcif.c"
>
</File>
@@ -5993,10 +6001,6 @@
Name="vector"
>
<File
- RelativePath="..\devices\vector\gdevagl.c"
- >
- </File>
- <File
RelativePath="..\devices\vector\gdevlj56.c"
>
</File>
@@ -6282,14 +6286,14 @@
>
</File>
<File
- RelativePath="..\devices\gdevpsd.h"
- >
- </File>
- <File
- RelativePath="..\devices\gdevpxut.h"
- >
- </File>
- <File
+ RelativePath="..\devices\gdevpsd.h"
+ >
+ </File>
+ <File
+ RelativePath="..\devices\gdevpxut.h"
+ >
+ </File>
+ <File
RelativePath="..\devices\gdevstc.h"
>
</File>
@@ -6325,10 +6329,6 @@
>
</File>
<File
- RelativePath="..\devices\vector\gdevagl.h"
- >
- </File>
- <File
RelativePath="..\devices\vector\gdevpdfb.h"
>
</File>
@@ -8024,14 +8024,14 @@
>
</File>
<File
- RelativePath="..\psi\psapi.c"
- >
- </File>
- <File
- RelativePath="..\psi\psapi.h"
- >
- </File>
- <File
+ RelativePath="..\psi\psapi.c"
+ >
+ </File>
+ <File
+ RelativePath="..\psi\psapi.h"
+ >
+ </File>
+ <File
RelativePath="..\psi\sfilter1.c"
>
</File>
@@ -8915,11 +8915,11 @@
RelativePath="..\psi\zfile.h"
>
</File>
- <File
- RelativePath="..\psi\zfrsd.h"
- >
- </File>
- <File
+ <File
+ RelativePath="..\psi\zfrsd.h"
+ >
+ </File>
+ <File
RelativePath="..\psi\zfunc.h"
>
</File>
diff --git a/windows/ghostscript.vcxproj b/windows/ghostscript.vcxproj
index df7a63ae..1f274ccc 100644
--- a/windows/ghostscript.vcxproj
+++ b/windows/ghostscript.vcxproj
@@ -423,7 +423,7 @@
<OutDir>$(Configuration)\</OutDir>
<IntDir>$(Configuration)\</IntDir>
<NMakeBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= WITH_CONTRIB=1 gsdebug &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CONTRIB=1 debugbsc</NMakeBuildCommandLine>
- <NMakeReBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CONTRIB=1 debugclean &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= WITH_CUPS=1 gsdebug &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CONTRIB=1 debugbsc</NMakeReBuildCommandLine>
+ <NMakeReBuildCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CONTRIB=1 debugclean &amp;&amp; nmake -f psi\msvc32.mak SBR=1 DEVSTUDIO= WITH_CONTRIB=1 gsdebug &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CONTRIB=1 debugbsc</NMakeReBuildCommandLine>
<NMakeCleanCommandLine>cd .. &amp;&amp; nmake -f psi\msvc32.mak DEVSTUDIO= WITH_CONTRIB=1 debugclean</NMakeCleanCommandLine>
<NMakeOutput>$(ProjectDir)\..\debugbin\gswin32c.exe</NMakeOutput>
<NMakePreprocessorDefinitions>WIN32;_DEBUG;DEBUG=1;TDEBUG=1;HAVE_SSE2=1;$(NMakePreprocessorDefinitions)</NMakePreprocessorDefinitions>
@@ -995,6 +995,7 @@
<ClCompile Include="..\base\gdevmrun.c" />
<ClCompile Include="..\base\gdevmx.c" />
<ClCompile Include="..\base\gdevnfwd.c" />
+ <ClCompile Include="..\base\gdevnup.c" />
<ClCompile Include="..\base\gdevoflt.c" />
<ClCompile Include="..\base\gdevp14.c" />
<ClCompile Include="..\base\gdevpccm.c" />
@@ -1050,6 +1051,7 @@
<ClCompile Include="..\base\gp_wpapr.c" />
<ClCompile Include="..\base\gp_wsync.c" />
<ClCompile Include="..\base\gp_wutf8.c" />
+ <ClCompile Include="..\base\gsagl.c" />
<ClCompile Include="..\base\gsalloc.c" />
<ClCompile Include="..\base\gsargs.c" />
<ClCompile Include="..\base\gsbitcom.c" />
@@ -1330,6 +1332,7 @@
<ClCompile Include="..\base\ttobjs.c" />
<ClCompile Include="..\base\vdtrace.c" />
<ClCompile Include="..\contrib\eplaser\gdevescv.c" />
+ <ClCompile Include="..\contrib\gdevadmp.c" />
<ClCompile Include="..\contrib\gdevbjca.c" />
<ClCompile Include="..\contrib\gdevbjc_.c" />
<ClCompile Include="..\contrib\gdevcd8.c" />
@@ -1498,6 +1501,7 @@
<ClCompile Include="..\devices\gdevjpx.c" />
<ClCompile Include="..\devices\gdevl31s.c" />
<ClCompile Include="..\devices\gdevlbp8.c" />
+ <ClCompile Include="..\devices\gdevlj56.c" />
<ClCompile Include="..\devices\gdevlp8k.c" />
<ClCompile Include="..\devices\gdevlxm.c" />
<ClCompile Include="..\devices\gdevmeds.c" />
@@ -1558,7 +1562,6 @@
<ClCompile Include="..\devices\rinkj\rinkj-dither.c" />
<ClCompile Include="..\devices\rinkj\rinkj-epson870.c" />
<ClCompile Include="..\devices\rinkj\rinkj-screen-eb.c" />
- <ClCompile Include="..\devices\vector\gdevagl.c" />
<ClCompile Include="..\devices\vector\gdevlj56.c" />
<ClCompile Include="..\devices\vector\gdevpdf.c" />
<ClCompile Include="..\devices\vector\gdevpdfb.c" />
@@ -1626,12 +1629,181 @@
<ClCompile Include="..\extract\src\extract.c" />
<ClCompile Include="..\extract\src\join.c" />
<ClCompile Include="..\extract\src\mem.c" />
+ <ClCompile Include="..\extract\src\odt.c" />
+ <ClCompile Include="..\extract\src\odt_template.c" />
<ClCompile Include="..\extract\src\memento.c" />
<ClCompile Include="..\extract\src\misc-test.c" />
<ClCompile Include="..\extract\src\outf.c" />
+ <ClCompile Include="..\extract\src\sys.c" />
+ <ClCompile Include="..\extract\src\text.c" />
<ClCompile Include="..\extract\src\xml.c" />
<ClCompile Include="..\extract\src\zip-test.c" />
<ClCompile Include="..\extract\src\zip.c" />
+ <ClCompile Include="..\freetype\src\autofit\afangles.c" />
+ <ClCompile Include="..\freetype\src\autofit\afblue.c" />
+ <ClCompile Include="..\freetype\src\autofit\afcjk.c" />
+ <ClCompile Include="..\freetype\src\autofit\afdummy.c" />
+ <ClCompile Include="..\freetype\src\autofit\afglobal.c" />
+ <ClCompile Include="..\freetype\src\autofit\afhints.c" />
+ <ClCompile Include="..\freetype\src\autofit\afindic.c" />
+ <ClCompile Include="..\freetype\src\autofit\aflatin.c" />
+ <ClCompile Include="..\freetype\src\autofit\aflatin2.c" />
+ <ClCompile Include="..\freetype\src\autofit\afloader.c" />
+ <ClCompile Include="..\freetype\src\autofit\afmodule.c" />
+ <ClCompile Include="..\freetype\src\autofit\afranges.c" />
+ <ClCompile Include="..\freetype\src\autofit\afshaper.c" />
+ <ClCompile Include="..\freetype\src\autofit\afwarp.c" />
+ <ClCompile Include="..\freetype\src\autofit\autofit.c" />
+ <ClCompile Include="..\freetype\src\base\ftadvanc.c" />
+ <ClCompile Include="..\freetype\src\base\ftbase.c" />
+ <ClCompile Include="..\freetype\src\base\ftbbox.c" />
+ <ClCompile Include="..\freetype\src\base\ftbdf.c" />
+ <ClCompile Include="..\freetype\src\base\ftbitmap.c" />
+ <ClCompile Include="..\freetype\src\base\ftcalc.c" />
+ <ClCompile Include="..\freetype\src\base\ftcid.c" />
+ <ClCompile Include="..\freetype\src\base\ftcolor.c" />
+ <ClCompile Include="..\freetype\src\base\ftdbgmem.c" />
+ <ClCompile Include="..\freetype\src\base\ftdebug.c" />
+ <ClCompile Include="..\freetype\src\base\fterrors.c" />
+ <ClCompile Include="..\freetype\src\base\ftfntfmt.c" />
+ <ClCompile Include="..\freetype\src\base\ftfstype.c" />
+ <ClCompile Include="..\freetype\src\base\ftgasp.c" />
+ <ClCompile Include="..\freetype\src\base\ftgloadr.c" />
+ <ClCompile Include="..\freetype\src\base\ftglyph.c" />
+ <ClCompile Include="..\freetype\src\base\ftgxval.c" />
+ <ClCompile Include="..\freetype\src\base\fthash.c" />
+ <ClCompile Include="..\freetype\src\base\ftinit.c" />
+ <ClCompile Include="..\freetype\src\base\ftlcdfil.c" />
+ <ClCompile Include="..\freetype\src\base\ftmac.c" />
+ <ClCompile Include="..\freetype\src\base\ftmm.c" />
+ <ClCompile Include="..\freetype\src\base\ftobjs.c" />
+ <ClCompile Include="..\freetype\src\base\ftotval.c" />
+ <ClCompile Include="..\freetype\src\base\ftoutln.c" />
+ <ClCompile Include="..\freetype\src\base\ftpatent.c" />
+ <ClCompile Include="..\freetype\src\base\ftpfr.c" />
+ <ClCompile Include="..\freetype\src\base\ftpsprop.c" />
+ <ClCompile Include="..\freetype\src\base\ftrfork.c" />
+ <ClCompile Include="..\freetype\src\base\ftsnames.c" />
+ <ClCompile Include="..\freetype\src\base\ftstream.c" />
+ <ClCompile Include="..\freetype\src\base\ftstroke.c" />
+ <ClCompile Include="..\freetype\src\base\ftsynth.c" />
+ <ClCompile Include="..\freetype\src\base\ftsystem.c" />
+ <ClCompile Include="..\freetype\src\base\fttrigon.c" />
+ <ClCompile Include="..\freetype\src\base\fttype1.c" />
+ <ClCompile Include="..\freetype\src\base\ftutil.c" />
+ <ClCompile Include="..\freetype\src\base\ftwinfnt.c" />
+ <ClCompile Include="..\freetype\src\base\md5.c" />
+ <ClCompile Include="..\freetype\src\bdf\bdf.c" />
+ <ClCompile Include="..\freetype\src\bdf\bdfdrivr.c" />
+ <ClCompile Include="..\freetype\src\bdf\bdflib.c" />
+ <ClCompile Include="..\freetype\src\cache\ftcache.c" />
+ <ClCompile Include="..\freetype\src\cache\ftcbasic.c" />
+ <ClCompile Include="..\freetype\src\cache\ftccache.c" />
+ <ClCompile Include="..\freetype\src\cache\ftccmap.c" />
+ <ClCompile Include="..\freetype\src\cache\ftcglyph.c" />
+ <ClCompile Include="..\freetype\src\cache\ftcimage.c" />
+ <ClCompile Include="..\freetype\src\cache\ftcmanag.c" />
+ <ClCompile Include="..\freetype\src\cache\ftcmru.c" />
+ <ClCompile Include="..\freetype\src\cache\ftcsbits.c" />
+ <ClCompile Include="..\freetype\src\cff\cff.c" />
+ <ClCompile Include="..\freetype\src\cff\cffcmap.c" />
+ <ClCompile Include="..\freetype\src\cff\cffdrivr.c" />
+ <ClCompile Include="..\freetype\src\cff\cffgload.c" />
+ <ClCompile Include="..\freetype\src\cff\cffload.c" />
+ <ClCompile Include="..\freetype\src\cff\cffobjs.c" />
+ <ClCompile Include="..\freetype\src\cff\cffparse.c" />
+ <ClCompile Include="..\freetype\src\cid\cidgload.c" />
+ <ClCompile Include="..\freetype\src\cid\cidload.c" />
+ <ClCompile Include="..\freetype\src\cid\cidobjs.c" />
+ <ClCompile Include="..\freetype\src\cid\cidparse.c" />
+ <ClCompile Include="..\freetype\src\cid\cidriver.c" />
+ <ClCompile Include="..\freetype\src\cid\type1cid.c" />
+ <ClCompile Include="..\freetype\src\gzip\adler32.c" />
+ <ClCompile Include="..\freetype\src\gzip\ftgzip.c" />
+ <ClCompile Include="..\freetype\src\gzip\infblock.c" />
+ <ClCompile Include="..\freetype\src\gzip\infcodes.c" />
+ <ClCompile Include="..\freetype\src\gzip\inflate.c" />
+ <ClCompile Include="..\freetype\src\gzip\inftrees.c" />
+ <ClCompile Include="..\freetype\src\gzip\infutil.c" />
+ <ClCompile Include="..\freetype\src\gzip\zutil.c" />
+ <ClCompile Include="..\freetype\src\lzw\ftlzw.c" />
+ <ClCompile Include="..\freetype\src\lzw\ftzopen.c" />
+ <ClCompile Include="..\freetype\src\pcf\pcf.c" />
+ <ClCompile Include="..\freetype\src\pcf\pcfdrivr.c" />
+ <ClCompile Include="..\freetype\src\pcf\pcfread.c" />
+ <ClCompile Include="..\freetype\src\pcf\pcfutil.c" />
+ <ClCompile Include="..\freetype\src\pfr\pfr.c" />
+ <ClCompile Include="..\freetype\src\pfr\pfrcmap.c" />
+ <ClCompile Include="..\freetype\src\pfr\pfrdrivr.c" />
+ <ClCompile Include="..\freetype\src\pfr\pfrgload.c" />
+ <ClCompile Include="..\freetype\src\pfr\pfrload.c" />
+ <ClCompile Include="..\freetype\src\pfr\pfrobjs.c" />
+ <ClCompile Include="..\freetype\src\pfr\pfrsbit.c" />
+ <ClCompile Include="..\freetype\src\psaux\afmparse.c" />
+ <ClCompile Include="..\freetype\src\psaux\cffdecode.c" />
+ <ClCompile Include="..\freetype\src\psaux\psarrst.c" />
+ <ClCompile Include="..\freetype\src\psaux\psaux.c" />
+ <ClCompile Include="..\freetype\src\psaux\psauxmod.c" />
+ <ClCompile Include="..\freetype\src\psaux\psblues.c" />
+ <ClCompile Include="..\freetype\src\psaux\psconv.c" />
+ <ClCompile Include="..\freetype\src\psaux\pserror.c" />
+ <ClCompile Include="..\freetype\src\psaux\psfont.c" />
+ <ClCompile Include="..\freetype\src\psaux\psft.c" />
+ <ClCompile Include="..\freetype\src\psaux\pshints.c" />
+ <ClCompile Include="..\freetype\src\psaux\psintrp.c" />
+ <ClCompile Include="..\freetype\src\psaux\psobjs.c" />
+ <ClCompile Include="..\freetype\src\psaux\psread.c" />
+ <ClCompile Include="..\freetype\src\psaux\psstack.c" />
+ <ClCompile Include="..\freetype\src\psaux\t1cmap.c" />
+ <ClCompile Include="..\freetype\src\psaux\t1decode.c" />
+ <ClCompile Include="..\freetype\src\pshinter\pshalgo.c" />
+ <ClCompile Include="..\freetype\src\pshinter\pshglob.c" />
+ <ClCompile Include="..\freetype\src\pshinter\pshinter.c" />
+ <ClCompile Include="..\freetype\src\pshinter\pshmod.c" />
+ <ClCompile Include="..\freetype\src\pshinter\pshrec.c" />
+ <ClCompile Include="..\freetype\src\psnames\psmodule.c" />
+ <ClCompile Include="..\freetype\src\psnames\psnames.c" />
+ <ClCompile Include="..\freetype\src\raster\ftraster.c" />
+ <ClCompile Include="..\freetype\src\raster\ftrend1.c" />
+ <ClCompile Include="..\freetype\src\raster\raster.c" />
+ <ClCompile Include="..\freetype\src\sfnt\pngshim.c" />
+ <ClCompile Include="..\freetype\src\sfnt\sfdriver.c" />
+ <ClCompile Include="..\freetype\src\sfnt\sfnt.c" />
+ <ClCompile Include="..\freetype\src\sfnt\sfobjs.c" />
+ <ClCompile Include="..\freetype\src\sfnt\sfwoff.c" />
+ <ClCompile Include="..\freetype\src\sfnt\sfwoff2.c" />
+ <ClCompile Include="..\freetype\src\sfnt\ttbdf.c" />
+ <ClCompile Include="..\freetype\src\sfnt\ttcmap.c" />
+ <ClCompile Include="..\freetype\src\sfnt\ttcolr.c" />
+ <ClCompile Include="..\freetype\src\sfnt\ttcpal.c" />
+ <ClCompile Include="..\freetype\src\sfnt\ttkern.c" />
+ <ClCompile Include="..\freetype\src\sfnt\ttload.c" />
+ <ClCompile Include="..\freetype\src\sfnt\ttmtx.c" />
+ <ClCompile Include="..\freetype\src\sfnt\ttpost.c" />
+ <ClCompile Include="..\freetype\src\sfnt\ttsbit.c" />
+ <ClCompile Include="..\freetype\src\sfnt\woff2tags.c" />
+ <ClCompile Include="..\freetype\src\smooth\ftgrays.c" />
+ <ClCompile Include="..\freetype\src\smooth\ftsmooth.c" />
+ <ClCompile Include="..\freetype\src\smooth\smooth.c" />
+ <ClCompile Include="..\freetype\src\truetype\truetype.c" />
+ <ClCompile Include="..\freetype\src\truetype\ttdriver.c" />
+ <ClCompile Include="..\freetype\src\truetype\ttgload.c" />
+ <ClCompile Include="..\freetype\src\truetype\ttgxvar.c" />
+ <ClCompile Include="..\freetype\src\truetype\ttinterp.c" />
+ <ClCompile Include="..\freetype\src\truetype\ttobjs.c" />
+ <ClCompile Include="..\freetype\src\truetype\ttpload.c" />
+ <ClCompile Include="..\freetype\src\truetype\ttsubpix.c" />
+ <ClCompile Include="..\freetype\src\type1\t1afm.c" />
+ <ClCompile Include="..\freetype\src\type1\t1driver.c" />
+ <ClCompile Include="..\freetype\src\type1\t1gload.c" />
+ <ClCompile Include="..\freetype\src\type1\t1load.c" />
+ <ClCompile Include="..\freetype\src\type1\t1objs.c" />
+ <ClCompile Include="..\freetype\src\type1\t1parse.c" />
+ <ClCompile Include="..\freetype\src\type1\type1.c" />
+ <ClCompile Include="..\freetype\src\type42\t42drivr.c" />
+ <ClCompile Include="..\freetype\src\type42\t42objs.c" />
+ <ClCompile Include="..\freetype\src\type42\t42parse.c" />
+ <ClCompile Include="..\freetype\src\type42\type42.c" />
<ClCompile Include="..\ijs\ijs.c" />
<ClCompile Include="..\ijs\ijs_client.c" />
<ClCompile Include="..\ijs\ijs_client_example.c" />
@@ -2521,6 +2693,7 @@
<ClInclude Include="..\base\gdevmplt.h" />
<ClInclude Include="..\base\gdevmrop.h" />
<ClInclude Include="..\base\gdevmrun.h" />
+ <ClInclude Include="..\base\gdevnup.h" />
<ClInclude Include="..\base\gdevoflt.h" />
<ClInclude Include="..\base\gdevp14.h" />
<ClInclude Include="..\base\gdevpccm.h" />
@@ -2540,6 +2713,7 @@
<ClInclude Include="..\base\gpsync.h" />
<ClInclude Include="..\base\gp_mswin.h" />
<ClInclude Include="..\base\gp_os2.h" />
+ <ClInclude Include="..\base\gsagl.h" />
<ClInclude Include="..\base\gsalloc.h" />
<ClInclude Include="..\base\gsargs.h" />
<ClInclude Include="..\base\gsbitmap.h" />
@@ -2959,7 +3133,6 @@
<ClInclude Include="..\devices\rinkj\rinkj-epson870.h" />
<ClInclude Include="..\devices\rinkj\rinkj-screen-eb.h" />
<ClInclude Include="..\devices\vector\doc_common.h" />
- <ClInclude Include="..\devices\vector\gdevagl.h" />
<ClInclude Include="..\devices\vector\gdevpdfb.h" />
<ClInclude Include="..\devices\vector\gdevpdfc.h" />
<ClInclude Include="..\devices\vector\gdevpdfg.h" />
@@ -2997,6 +3170,149 @@
<ClInclude Include="..\expat\lib\xmltok_impl.h" />
<ClInclude Include="..\expat\tests\chardata.h" />
<ClInclude Include="..\expat\tests\minicheck.h" />
+ <ClInclude Include="..\freetype\src\autofit\afangles.h" />
+ <ClInclude Include="..\freetype\src\autofit\afblue.h" />
+ <ClInclude Include="..\freetype\src\autofit\afcjk.h" />
+ <ClInclude Include="..\freetype\src\autofit\afcover.h" />
+ <ClInclude Include="..\freetype\src\autofit\afdummy.h" />
+ <ClInclude Include="..\freetype\src\autofit\aferrors.h" />
+ <ClInclude Include="..\freetype\src\autofit\afglobal.h" />
+ <ClInclude Include="..\freetype\src\autofit\afhints.h" />
+ <ClInclude Include="..\freetype\src\autofit\afindic.h" />
+ <ClInclude Include="..\freetype\src\autofit\aflatin.h" />
+ <ClInclude Include="..\freetype\src\autofit\aflatin2.h" />
+ <ClInclude Include="..\freetype\src\autofit\afloader.h" />
+ <ClInclude Include="..\freetype\src\autofit\afmodule.h" />
+ <ClInclude Include="..\freetype\src\autofit\afranges.h" />
+ <ClInclude Include="..\freetype\src\autofit\afscript.h" />
+ <ClInclude Include="..\freetype\src\autofit\afshaper.h" />
+ <ClInclude Include="..\freetype\src\autofit\afstyles.h" />
+ <ClInclude Include="..\freetype\src\autofit\aftypes.h" />
+ <ClInclude Include="..\freetype\src\autofit\afwarp.h" />
+ <ClInclude Include="..\freetype\src\autofit\afwrtsys.h" />
+ <ClInclude Include="..\freetype\src\base\ftbase.h" />
+ <ClInclude Include="..\freetype\src\base\md5.h" />
+ <ClInclude Include="..\freetype\src\bdf\bdf.h" />
+ <ClInclude Include="..\freetype\src\bdf\bdfdrivr.h" />
+ <ClInclude Include="..\freetype\src\bdf\bdferror.h" />
+ <ClInclude Include="..\freetype\src\cache\ftccache.h" />
+ <ClInclude Include="..\freetype\src\cache\ftccback.h" />
+ <ClInclude Include="..\freetype\src\cache\ftcerror.h" />
+ <ClInclude Include="..\freetype\src\cache\ftcglyph.h" />
+ <ClInclude Include="..\freetype\src\cache\ftcimage.h" />
+ <ClInclude Include="..\freetype\src\cache\ftcmanag.h" />
+ <ClInclude Include="..\freetype\src\cache\ftcmru.h" />
+ <ClInclude Include="..\freetype\src\cache\ftcsbits.h" />
+ <ClInclude Include="..\freetype\src\cff\cffcmap.h" />
+ <ClInclude Include="..\freetype\src\cff\cffdrivr.h" />
+ <ClInclude Include="..\freetype\src\cff\cfferrs.h" />
+ <ClInclude Include="..\freetype\src\cff\cffgload.h" />
+ <ClInclude Include="..\freetype\src\cff\cffload.h" />
+ <ClInclude Include="..\freetype\src\cff\cffobjs.h" />
+ <ClInclude Include="..\freetype\src\cff\cffparse.h" />
+ <ClInclude Include="..\freetype\src\cff\cfftoken.h" />
+ <ClInclude Include="..\freetype\src\cid\ciderrs.h" />
+ <ClInclude Include="..\freetype\src\cid\cidgload.h" />
+ <ClInclude Include="..\freetype\src\cid\cidload.h" />
+ <ClInclude Include="..\freetype\src\cid\cidobjs.h" />
+ <ClInclude Include="..\freetype\src\cid\cidparse.h" />
+ <ClInclude Include="..\freetype\src\cid\cidriver.h" />
+ <ClInclude Include="..\freetype\src\cid\cidtoken.h" />
+ <ClInclude Include="..\freetype\src\gzip\ftzconf.h" />
+ <ClInclude Include="..\freetype\src\gzip\infblock.h" />
+ <ClInclude Include="..\freetype\src\gzip\infcodes.h" />
+ <ClInclude Include="..\freetype\src\gzip\inffixed.h" />
+ <ClInclude Include="..\freetype\src\gzip\inftrees.h" />
+ <ClInclude Include="..\freetype\src\gzip\infutil.h" />
+ <ClInclude Include="..\freetype\src\gzip\zlib.h" />
+ <ClInclude Include="..\freetype\src\gzip\zutil.h" />
+ <ClInclude Include="..\freetype\src\lzw\ftzopen.h" />
+ <ClInclude Include="..\freetype\src\pcf\pcf.h" />
+ <ClInclude Include="..\freetype\src\pcf\pcfdrivr.h" />
+ <ClInclude Include="..\freetype\src\pcf\pcferror.h" />
+ <ClInclude Include="..\freetype\src\pcf\pcfread.h" />
+ <ClInclude Include="..\freetype\src\pcf\pcfutil.h" />
+ <ClInclude Include="..\freetype\src\pfr\pfrcmap.h" />
+ <ClInclude Include="..\freetype\src\pfr\pfrdrivr.h" />
+ <ClInclude Include="..\freetype\src\pfr\pfrerror.h" />
+ <ClInclude Include="..\freetype\src\pfr\pfrgload.h" />
+ <ClInclude Include="..\freetype\src\pfr\pfrload.h" />
+ <ClInclude Include="..\freetype\src\pfr\pfrobjs.h" />
+ <ClInclude Include="..\freetype\src\pfr\pfrsbit.h" />
+ <ClInclude Include="..\freetype\src\pfr\pfrtypes.h" />
+ <ClInclude Include="..\freetype\src\psaux\afmparse.h" />
+ <ClInclude Include="..\freetype\src\psaux\cffdecode.h" />
+ <ClInclude Include="..\freetype\src\psaux\psarrst.h" />
+ <ClInclude Include="..\freetype\src\psaux\psauxerr.h" />
+ <ClInclude Include="..\freetype\src\psaux\psauxmod.h" />
+ <ClInclude Include="..\freetype\src\psaux\psblues.h" />
+ <ClInclude Include="..\freetype\src\psaux\psconv.h" />
+ <ClInclude Include="..\freetype\src\psaux\pserror.h" />
+ <ClInclude Include="..\freetype\src\psaux\psfixed.h" />
+ <ClInclude Include="..\freetype\src\psaux\psfont.h" />
+ <ClInclude Include="..\freetype\src\psaux\psft.h" />
+ <ClInclude Include="..\freetype\src\psaux\psglue.h" />
+ <ClInclude Include="..\freetype\src\psaux\pshints.h" />
+ <ClInclude Include="..\freetype\src\psaux\psintrp.h" />
+ <ClInclude Include="..\freetype\src\psaux\psobjs.h" />
+ <ClInclude Include="..\freetype\src\psaux\psread.h" />
+ <ClInclude Include="..\freetype\src\psaux\psstack.h" />
+ <ClInclude Include="..\freetype\src\psaux\pstypes.h" />
+ <ClInclude Include="..\freetype\src\psaux\t1cmap.h" />
+ <ClInclude Include="..\freetype\src\psaux\t1decode.h" />
+ <ClInclude Include="..\freetype\src\pshinter\pshalgo.h" />
+ <ClInclude Include="..\freetype\src\pshinter\pshglob.h" />
+ <ClInclude Include="..\freetype\src\pshinter\pshmod.h" />
+ <ClInclude Include="..\freetype\src\pshinter\pshnterr.h" />
+ <ClInclude Include="..\freetype\src\pshinter\pshrec.h" />
+ <ClInclude Include="..\freetype\src\psnames\psmodule.h" />
+ <ClInclude Include="..\freetype\src\psnames\psnamerr.h" />
+ <ClInclude Include="..\freetype\src\psnames\pstables.h" />
+ <ClInclude Include="..\freetype\src\raster\ftmisc.h" />
+ <ClInclude Include="..\freetype\src\raster\ftraster.h" />
+ <ClInclude Include="..\freetype\src\raster\ftrend1.h" />
+ <ClInclude Include="..\freetype\src\raster\rasterrs.h" />
+ <ClInclude Include="..\freetype\src\sfnt\pngshim.h" />
+ <ClInclude Include="..\freetype\src\sfnt\sfdriver.h" />
+ <ClInclude Include="..\freetype\src\sfnt\sferrors.h" />
+ <ClInclude Include="..\freetype\src\sfnt\sfobjs.h" />
+ <ClInclude Include="..\freetype\src\sfnt\sfwoff.h" />
+ <ClInclude Include="..\freetype\src\sfnt\sfwoff2.h" />
+ <ClInclude Include="..\freetype\src\sfnt\ttbdf.h" />
+ <ClInclude Include="..\freetype\src\sfnt\ttcmap.h" />
+ <ClInclude Include="..\freetype\src\sfnt\ttcmapc.h" />
+ <ClInclude Include="..\freetype\src\sfnt\ttcolr.h" />
+ <ClInclude Include="..\freetype\src\sfnt\ttcpal.h" />
+ <ClInclude Include="..\freetype\src\sfnt\ttkern.h" />
+ <ClInclude Include="..\freetype\src\sfnt\ttload.h" />
+ <ClInclude Include="..\freetype\src\sfnt\ttmtx.h" />
+ <ClInclude Include="..\freetype\src\sfnt\ttpost.h" />
+ <ClInclude Include="..\freetype\src\sfnt\ttsbit.h" />
+ <ClInclude Include="..\freetype\src\sfnt\woff2tags.h" />
+ <ClInclude Include="..\freetype\src\smooth\ftgrays.h" />
+ <ClInclude Include="..\freetype\src\smooth\ftsmerrs.h" />
+ <ClInclude Include="..\freetype\src\smooth\ftsmooth.h" />
+ <ClInclude Include="..\freetype\src\truetype\ttdriver.h" />
+ <ClInclude Include="..\freetype\src\truetype\tterrors.h" />
+ <ClInclude Include="..\freetype\src\truetype\ttgload.h" />
+ <ClInclude Include="..\freetype\src\truetype\ttgxvar.h" />
+ <ClInclude Include="..\freetype\src\truetype\ttinterp.h" />
+ <ClInclude Include="..\freetype\src\truetype\ttobjs.h" />
+ <ClInclude Include="..\freetype\src\truetype\ttpload.h" />
+ <ClInclude Include="..\freetype\src\truetype\ttsubpix.h" />
+ <ClInclude Include="..\freetype\src\type1\t1afm.h" />
+ <ClInclude Include="..\freetype\src\type1\t1driver.h" />
+ <ClInclude Include="..\freetype\src\type1\t1errors.h" />
+ <ClInclude Include="..\freetype\src\type1\t1gload.h" />
+ <ClInclude Include="..\freetype\src\type1\t1load.h" />
+ <ClInclude Include="..\freetype\src\type1\t1objs.h" />
+ <ClInclude Include="..\freetype\src\type1\t1parse.h" />
+ <ClInclude Include="..\freetype\src\type1\t1tokens.h" />
+ <ClInclude Include="..\freetype\src\type42\t42drivr.h" />
+ <ClInclude Include="..\freetype\src\type42\t42error.h" />
+ <ClInclude Include="..\freetype\src\type42\t42objs.h" />
+ <ClInclude Include="..\freetype\src\type42\t42parse.h" />
+ <ClInclude Include="..\freetype\src\type42\t42types.h" />
<ClInclude Include="..\ijs\ijs.h" />
<ClInclude Include="..\ijs\ijs_client.h" />
<ClInclude Include="..\ijs\ijs_server.h" />
@@ -3478,6 +3794,7 @@
<ResourceCompile Include="..\base\gspmdrv.rc" />
<ResourceCompile Include="..\base\gswin.rc" />
<ResourceCompile Include="..\base\gswin32.rc" />
+ <ResourceCompile Include="..\freetype\src\base\ftver.rc" />
<ResourceCompile Include="..\psi\dwmain.rc" />
<ResourceCompile Include="..\psi\dwsetup.rc" />
<ResourceCompile Include="..\psi\dwuninst.rc" />
diff --git a/windows/ghostscript.vcxproj.filters b/windows/ghostscript.vcxproj.filters
index 5b7da7a0..9dfe0583 100644
--- a/windows/ghostscript.vcxproj.filters
+++ b/windows/ghostscript.vcxproj.filters
@@ -1,4 +1,4 @@
-<?xml version="1.0" encoding="utf-8"?>
+<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<ItemGroup>
<Filter Include="Resource">
@@ -229,6 +229,69 @@
<Filter Include="tesseract\wordrec">
<UniqueIdentifier>{d5ba0dd7-f585-494f-a5a3-eca161773d74}</UniqueIdentifier>
</Filter>
+ <Filter Include="freetype">
+ <UniqueIdentifier>{8483224e-138f-409e-bdee-264bab640a9a}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\autofit">
+ <UniqueIdentifier>{7a86b47f-6138-4102-b924-72527d495254}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\base">
+ <UniqueIdentifier>{b2fb475c-3735-4545-9b5a-e91d4739696e}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\bdf">
+ <UniqueIdentifier>{763cff1c-753d-4686-8096-3d62c1582bd9}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\cache">
+ <UniqueIdentifier>{3eeecc85-0fa1-4b72-818f-6a3f3bd3c017}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\cff">
+ <UniqueIdentifier>{2635a5c0-b0e2-4d88-a217-36958666120f}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\cid">
+ <UniqueIdentifier>{fa41ea84-9a89-4b1b-91f9-12f1df7ec4e0}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\gzip">
+ <UniqueIdentifier>{e88ca4b9-9428-48fe-a522-5326a952ddaa}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\lzw">
+ <UniqueIdentifier>{603c10ae-72d9-42b8-a6ab-eaa02e450c24}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\psaux">
+ <UniqueIdentifier>{97afe2ef-3b99-4c22-b3ac-6ecfbaef1978}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\type42">
+ <UniqueIdentifier>{033efe11-f9ab-42b9-8b1c-68a38b2753b3}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\type1">
+ <UniqueIdentifier>{d7a64fe8-e406-4d41-a602-386efd8f352b}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\truetype">
+ <UniqueIdentifier>{da387d01-2d64-4090-926f-c309c9d4c2df}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\smooth">
+ <UniqueIdentifier>{5bf15f08-8ad1-4bab-8e49-ea1a9ff24af3}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\sfnt">
+ <UniqueIdentifier>{9b142666-79d3-464b-b89e-e095db913ccd}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\raster">
+ <UniqueIdentifier>{d81a9abc-0566-449b-b18e-b34d39487622}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\pcf">
+ <UniqueIdentifier>{d1d84f20-6e6f-45f9-97d2-5474ca2dc42e}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\pfr">
+ <UniqueIdentifier>{436212f4-d378-494d-9c25-1367e69bdf90}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\pshinter">
+ <UniqueIdentifier>{f664b15d-d9da-4851-a97e-46cf2d633a5d}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="freetype\psnames">
+ <UniqueIdentifier>{b1b6220f-bf2e-453d-aa42-86455301f13a}</UniqueIdentifier>
+ </Filter>
+ <Filter Include="extract">
+ <UniqueIdentifier>{8fa68d87-7860-4400-b23e-9b05198b3f52}</UniqueIdentifier>
+ </Filter>
</ItemGroup>
<ItemGroup>
<None Include="..\Resource\CMap\78-EUC-H">
@@ -1625,6 +1688,9 @@
<ClCompile Include="..\base\gpmisc.c">
<Filter>base</Filter>
</ClCompile>
+ <ClCompile Include="..\base\gsagl.c">
+ <Filter>base</Filter>
+ </ClCompile>
<ClCompile Include="..\base\gsalloc.c">
<Filter>base</Filter>
</ClCompile>
@@ -2135,9 +2201,6 @@
<ClCompile Include="..\base\sjpx.c">
<Filter>base</Filter>
</ClCompile>
- <ClCompile Include="..\base\sjpx_openjpeg.c">
- <Filter>base</Filter>
- </ClCompile>
<ClCompile Include="..\base\slzwc.c">
<Filter>base</Filter>
</ClCompile>
@@ -2324,6 +2387,9 @@
<ClCompile Include="..\base\gdevnfwd.c">
<Filter>base\gldevices</Filter>
</ClCompile>
+ <ClCompile Include="..\base\gdevnup.c">
+ <Filter>base\gldevices</Filter>
+ </ClCompile>
<ClCompile Include="..\base\gdevpccm.c">
<Filter>base\gldevices</Filter>
</ClCompile>
@@ -2375,6 +2441,7 @@
<ClCompile Include="..\base\gdevdevn.c">
<Filter>base\color</Filter>
</ClCompile>
+
<ClCompile Include="..\base\gscdevn.c">
<Filter>base\color</Filter>
</ClCompile>
@@ -3239,9 +3306,6 @@
<ClCompile Include="..\devices\minftrsz.c">
<Filter>devices</Filter>
</ClCompile>
- <ClCompile Include="..\devices\vector\gdevagl.c">
- <Filter>devices\vector</Filter>
- </ClCompile>
<ClCompile Include="..\devices\vector\gdevlj56.c">
<Filter>devices\vector</Filter>
</ClCompile>
@@ -6029,6 +6093,567 @@
<ClCompile Include="..\base\gsicc_blacktext.c">
<Filter>base\color\icc</Filter>
</ClCompile>
+ <ClCompile Include="..\contrib\gdevadmp.c">
+ <Filter>contrib</Filter>
+ </ClCompile>
+ <ClCompile Include="..\devices\gdevlj56.c">
+ <Filter>devices</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\autofit\afangles.c">
+ <Filter>freetype\autofit</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\autofit\afblue.c">
+ <Filter>freetype\autofit</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\autofit\afcjk.c">
+ <Filter>freetype\autofit</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\autofit\afdummy.c">
+ <Filter>freetype\autofit</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\autofit\afglobal.c">
+ <Filter>freetype\autofit</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\autofit\afhints.c">
+ <Filter>freetype\autofit</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\autofit\afindic.c">
+ <Filter>freetype\autofit</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\autofit\aflatin.c">
+ <Filter>freetype\autofit</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\autofit\aflatin2.c">
+ <Filter>freetype\autofit</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\autofit\afloader.c">
+ <Filter>freetype\autofit</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\autofit\afmodule.c">
+ <Filter>freetype\autofit</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\autofit\afranges.c">
+ <Filter>freetype\autofit</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\autofit\afshaper.c">
+ <Filter>freetype\autofit</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\autofit\afwarp.c">
+ <Filter>freetype\autofit</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\autofit\autofit.c">
+ <Filter>freetype\autofit</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftadvanc.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftbase.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftbbox.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftbdf.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftbitmap.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftcalc.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftcid.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftcolor.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftdbgmem.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftdebug.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\fterrors.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftfntfmt.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftfstype.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftgasp.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftgloadr.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftglyph.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftgxval.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\fthash.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftinit.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftlcdfil.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftmac.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftmm.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftobjs.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftotval.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftoutln.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftpatent.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftpfr.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftpsprop.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftrfork.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftsnames.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftstream.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftstroke.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftsynth.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftsystem.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\fttrigon.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\fttype1.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftutil.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\ftwinfnt.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\base\md5.c">
+ <Filter>freetype\base</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\bdf\bdf.c">
+ <Filter>freetype\bdf</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\bdf\bdfdrivr.c">
+ <Filter>freetype\bdf</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\bdf\bdflib.c">
+ <Filter>freetype\bdf</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cache\ftcache.c">
+ <Filter>freetype\cache</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cache\ftcbasic.c">
+ <Filter>freetype\cache</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cache\ftccache.c">
+ <Filter>freetype\cache</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cache\ftccmap.c">
+ <Filter>freetype\cache</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cache\ftcglyph.c">
+ <Filter>freetype\cache</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cache\ftcimage.c">
+ <Filter>freetype\cache</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cache\ftcmanag.c">
+ <Filter>freetype\cache</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cache\ftcmru.c">
+ <Filter>freetype\cache</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cache\ftcsbits.c">
+ <Filter>freetype\cache</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cff\cff.c">
+ <Filter>freetype\cff</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cff\cffcmap.c">
+ <Filter>freetype\cff</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cff\cffdrivr.c">
+ <Filter>freetype\cff</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cff\cffgload.c">
+ <Filter>freetype\cff</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cff\cffload.c">
+ <Filter>freetype\cff</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cff\cffobjs.c">
+ <Filter>freetype\cff</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cff\cffparse.c">
+ <Filter>freetype\cff</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cid\cidgload.c">
+ <Filter>freetype\cid</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cid\cidload.c">
+ <Filter>freetype\cid</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cid\cidobjs.c">
+ <Filter>freetype\cid</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cid\cidparse.c">
+ <Filter>freetype\cid</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cid\cidriver.c">
+ <Filter>freetype\cid</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\cid\type1cid.c">
+ <Filter>freetype\cid</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\gzip\adler32.c">
+ <Filter>freetype\gzip</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\gzip\ftgzip.c">
+ <Filter>freetype\gzip</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\gzip\infblock.c">
+ <Filter>freetype\gzip</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\gzip\infcodes.c">
+ <Filter>freetype\gzip</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\gzip\inflate.c">
+ <Filter>freetype\gzip</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\gzip\inftrees.c">
+ <Filter>freetype\gzip</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\gzip\infutil.c">
+ <Filter>freetype\gzip</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\gzip\zutil.c">
+ <Filter>freetype\gzip</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\lzw\ftlzw.c">
+ <Filter>freetype\lzw</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\lzw\ftzopen.c">
+ <Filter>freetype\lzw</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\pcf\pcf.c">
+ <Filter>freetype\pcf</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\pcf\pcfdrivr.c">
+ <Filter>freetype\pcf</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\pcf\pcfread.c">
+ <Filter>freetype\pcf</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\pcf\pcfutil.c">
+ <Filter>freetype\pcf</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\pfr\pfr.c">
+ <Filter>freetype\pfr</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\pfr\pfrcmap.c">
+ <Filter>freetype\pfr</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\pfr\pfrdrivr.c">
+ <Filter>freetype\pfr</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\pfr\pfrgload.c">
+ <Filter>freetype\pfr</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\pfr\pfrload.c">
+ <Filter>freetype\pfr</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\pfr\pfrobjs.c">
+ <Filter>freetype\pfr</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\pfr\pfrsbit.c">
+ <Filter>freetype\pfr</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\afmparse.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\cffdecode.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\psarrst.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\psaux.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\psauxmod.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\psblues.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\psconv.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\pserror.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\psfont.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\psft.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\pshints.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\psintrp.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\psobjs.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\psread.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\psstack.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\t1cmap.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psaux\t1decode.c">
+ <Filter>freetype\psaux</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\pshinter\pshalgo.c">
+ <Filter>freetype\pshinter</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\pshinter\pshglob.c">
+ <Filter>freetype\pshinter</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\pshinter\pshinter.c">
+ <Filter>freetype\pshinter</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\pshinter\pshmod.c">
+ <Filter>freetype\pshinter</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\pshinter\pshrec.c">
+ <Filter>freetype\pshinter</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psnames\psmodule.c">
+ <Filter>freetype\psnames</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\psnames\psnames.c">
+ <Filter>freetype\psnames</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\raster\ftraster.c">
+ <Filter>freetype\raster</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\raster\ftrend1.c">
+ <Filter>freetype\raster</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\raster\raster.c">
+ <Filter>freetype\raster</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\smooth\ftgrays.c">
+ <Filter>freetype\smooth</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\smooth\ftsmooth.c">
+ <Filter>freetype\smooth</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\smooth\smooth.c">
+ <Filter>freetype\smooth</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\sfnt\pngshim.c">
+ <Filter>freetype\sfnt</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\sfnt\sfdriver.c">
+ <Filter>freetype\sfnt</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\sfnt\sfnt.c">
+ <Filter>freetype\sfnt</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\sfnt\sfobjs.c">
+ <Filter>freetype\sfnt</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\sfnt\sfwoff.c">
+ <Filter>freetype\sfnt</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\sfnt\sfwoff2.c">
+ <Filter>freetype\sfnt</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\sfnt\ttbdf.c">
+ <Filter>freetype\sfnt</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\sfnt\ttcmap.c">
+ <Filter>freetype\sfnt</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\sfnt\ttcolr.c">
+ <Filter>freetype\sfnt</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\sfnt\ttcpal.c">
+ <Filter>freetype\sfnt</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\sfnt\ttkern.c">
+ <Filter>freetype\sfnt</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\sfnt\ttload.c">
+ <Filter>freetype\sfnt</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\sfnt\ttmtx.c">
+ <Filter>freetype\sfnt</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\sfnt\ttpost.c">
+ <Filter>freetype\sfnt</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\sfnt\ttsbit.c">
+ <Filter>freetype\sfnt</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\sfnt\woff2tags.c">
+ <Filter>freetype\sfnt</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\truetype\truetype.c">
+ <Filter>freetype\truetype</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\truetype\ttdriver.c">
+ <Filter>freetype\truetype</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\truetype\ttgload.c">
+ <Filter>freetype\truetype</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\truetype\ttgxvar.c">
+ <Filter>freetype\truetype</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\truetype\ttinterp.c">
+ <Filter>freetype\truetype</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\truetype\ttobjs.c">
+ <Filter>freetype\truetype</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\truetype\ttpload.c">
+ <Filter>freetype\truetype</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\truetype\ttsubpix.c">
+ <Filter>freetype\truetype</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\type1\t1afm.c">
+ <Filter>freetype\type1</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\type1\t1driver.c">
+ <Filter>freetype\type1</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\type1\t1gload.c">
+ <Filter>freetype\type1</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\type1\t1load.c">
+ <Filter>freetype\type1</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\type1\t1objs.c">
+ <Filter>freetype\type1</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\type1\t1parse.c">
+ <Filter>freetype\type1</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\type1\type1.c">
+ <Filter>freetype\type1</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\type42\t42drivr.c">
+ <Filter>freetype\type42</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\type42\t42objs.c">
+ <Filter>freetype\type42</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\type42\t42parse.c">
+ <Filter>freetype\type42</Filter>
+ </ClCompile>
+ <ClCompile Include="..\freetype\src\type42\type42.c">
+ <Filter>freetype\type42</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\alloc.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\astring.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\buffer.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\buffer-test.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\docx.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\docx_template.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\extract.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\extract-exe.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\join.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\mem.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\memento.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\misc-test.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\odt.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\odt_template.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\outf.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\sys.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\text.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\xml.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\zip.c">
+ <Filter>extract</Filter>
+ </ClCompile>
+ <ClCompile Include="..\extract\src\zip-test.c">
+ <Filter>extract</Filter>
+ </ClCompile>
</ItemGroup>
<ItemGroup>
<ClInclude Include="..\base\aes.h">
@@ -6121,7 +6746,10 @@
<ClInclude Include="..\base\gs_mro_e.h">
<Filter>base %28.h%29</Filter>
</ClInclude>
- <ClInclude Include="..\base\gsalloc.h">
+ <ClInclude Include="..\devices\vector\gsagl.h">
+ <Filter>base %28.h%29</Filter>
+ </ClInclude>
+ <ClInclude Include="..\base\a">
<Filter>base %28.h%29</Filter>
</ClInclude>
<ClInclude Include="..\base\gsargs.h">
@@ -7132,6 +7760,9 @@
<ClInclude Include="..\base\gdevmrun.h">
<Filter>base %28.h%29\gldevices %28.h%29</Filter>
</ClInclude>
+ <ClInclude Include="..\base\gdevnup.h">
+ <Filter>base %28.h%29\gldevices %28.h%29</Filter>
+ </ClInclude>
<ClInclude Include="..\base\gdevp14.h">
<Filter>base %28.h%29\gldevices %28.h%29</Filter>
</ClInclude>
@@ -7390,9 +8021,6 @@
<ClInclude Include="..\devices\minftrsz.h">
<Filter>devices %28.h%29</Filter>
</ClInclude>
- <ClInclude Include="..\devices\vector\gdevagl.h">
- <Filter>devices %28.h%29\vector %28.h%29</Filter>
- </ClInclude>
<ClInclude Include="..\devices\vector\gdevpdfb.h">
<Filter>devices %28.h%29\vector %28.h%29</Filter>
</ClInclude>
@@ -8968,6 +9596,438 @@
<ClInclude Include="..\base\gsicc_blacktext.h">
<Filter>base %28.h%29\icc %28.h%29</Filter>
</ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\afangles.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\afblue.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\afcjk.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\afcover.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\afdummy.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\aferrors.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\afglobal.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\afhints.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\afindic.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\aflatin.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\aflatin2.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\afloader.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\afmodule.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\afranges.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\afscript.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\afshaper.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\afstyles.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\aftypes.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\afwarp.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\autofit\afwrtsys.h">
+ <Filter>freetype\autofit</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\base\ftbase.h">
+ <Filter>freetype\base</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\base\md5.h">
+ <Filter>freetype\base</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\bdf\bdf.h">
+ <Filter>freetype\bdf</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\bdf\bdfdrivr.h">
+ <Filter>freetype\bdf</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\bdf\bdferror.h">
+ <Filter>freetype\bdf</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cache\ftccache.h">
+ <Filter>freetype\cache</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cache\ftccback.h">
+ <Filter>freetype\cache</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cache\ftcerror.h">
+ <Filter>freetype\cache</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cache\ftcglyph.h">
+ <Filter>freetype\cache</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cache\ftcimage.h">
+ <Filter>freetype\cache</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cache\ftcmanag.h">
+ <Filter>freetype\cache</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cache\ftcmru.h">
+ <Filter>freetype\cache</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cache\ftcsbits.h">
+ <Filter>freetype\cache</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cff\cffcmap.h">
+ <Filter>freetype\cff</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cff\cffdrivr.h">
+ <Filter>freetype\cff</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cff\cfferrs.h">
+ <Filter>freetype\cff</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cff\cffgload.h">
+ <Filter>freetype\cff</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cff\cffload.h">
+ <Filter>freetype\cff</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cff\cffobjs.h">
+ <Filter>freetype\cff</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cff\cffparse.h">
+ <Filter>freetype\cff</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cff\cfftoken.h">
+ <Filter>freetype\cff</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cid\ciderrs.h">
+ <Filter>freetype\cid</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cid\cidgload.h">
+ <Filter>freetype\cid</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cid\cidload.h">
+ <Filter>freetype\cid</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cid\cidobjs.h">
+ <Filter>freetype\cid</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cid\cidparse.h">
+ <Filter>freetype\cid</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cid\cidriver.h">
+ <Filter>freetype\cid</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\cid\cidtoken.h">
+ <Filter>freetype\cid</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\gzip\ftzconf.h">
+ <Filter>freetype\gzip</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\gzip\infblock.h">
+ <Filter>freetype\gzip</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\gzip\infcodes.h">
+ <Filter>freetype\gzip</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\gzip\inffixed.h">
+ <Filter>freetype\gzip</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\gzip\inftrees.h">
+ <Filter>freetype\gzip</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\gzip\infutil.h">
+ <Filter>freetype\gzip</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\gzip\zlib.h">
+ <Filter>freetype\gzip</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\gzip\zutil.h">
+ <Filter>freetype\gzip</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\lzw\ftzopen.h">
+ <Filter>freetype\lzw</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pcf\pcf.h">
+ <Filter>freetype\pcf</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pcf\pcfdrivr.h">
+ <Filter>freetype\pcf</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pcf\pcferror.h">
+ <Filter>freetype\pcf</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pcf\pcfread.h">
+ <Filter>freetype\pcf</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pcf\pcfutil.h">
+ <Filter>freetype\pcf</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pfr\pfrcmap.h">
+ <Filter>freetype\pfr</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pfr\pfrdrivr.h">
+ <Filter>freetype\pfr</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pfr\pfrerror.h">
+ <Filter>freetype\pfr</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pfr\pfrgload.h">
+ <Filter>freetype\pfr</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pfr\pfrload.h">
+ <Filter>freetype\pfr</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pfr\pfrobjs.h">
+ <Filter>freetype\pfr</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pfr\pfrsbit.h">
+ <Filter>freetype\pfr</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pfr\pfrtypes.h">
+ <Filter>freetype\pfr</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\afmparse.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\cffdecode.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\psarrst.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\psauxerr.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\psauxmod.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\psblues.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\psconv.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\pserror.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\psfixed.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\psfont.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\psft.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\psglue.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\pshints.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\psintrp.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\psobjs.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\psread.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\psstack.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\pstypes.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\t1cmap.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psaux\t1decode.h">
+ <Filter>freetype\psaux</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pshinter\pshalgo.h">
+ <Filter>freetype\pshinter</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pshinter\pshglob.h">
+ <Filter>freetype\pshinter</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pshinter\pshmod.h">
+ <Filter>freetype\pshinter</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pshinter\pshnterr.h">
+ <Filter>freetype\pshinter</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\pshinter\pshrec.h">
+ <Filter>freetype\pshinter</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psnames\psmodule.h">
+ <Filter>freetype\psnames</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psnames\psnamerr.h">
+ <Filter>freetype\psnames</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\psnames\pstables.h">
+ <Filter>freetype\psnames</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\raster\ftmisc.h">
+ <Filter>freetype\raster</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\raster\ftraster.h">
+ <Filter>freetype\raster</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\raster\ftrend1.h">
+ <Filter>freetype\raster</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\raster\rasterrs.h">
+ <Filter>freetype\raster</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\smooth\ftgrays.h">
+ <Filter>freetype\smooth</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\smooth\ftsmerrs.h">
+ <Filter>freetype\smooth</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\smooth\ftsmooth.h">
+ <Filter>freetype\smooth</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\pngshim.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\sfdriver.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\sferrors.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\sfobjs.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\sfwoff.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\sfwoff2.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\ttbdf.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\ttcmap.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\ttcmapc.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\ttcolr.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\ttcpal.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\ttkern.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\ttload.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\ttmtx.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\ttpost.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\ttsbit.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\sfnt\woff2tags.h">
+ <Filter>freetype\sfnt</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\truetype\ttdriver.h">
+ <Filter>freetype\truetype</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\truetype\tterrors.h">
+ <Filter>freetype\truetype</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\truetype\ttgload.h">
+ <Filter>freetype\truetype</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\truetype\ttgxvar.h">
+ <Filter>freetype\truetype</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\truetype\ttinterp.h">
+ <Filter>freetype\truetype</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\truetype\ttobjs.h">
+ <Filter>freetype\truetype</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\truetype\ttpload.h">
+ <Filter>freetype\truetype</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\truetype\ttsubpix.h">
+ <Filter>freetype\truetype</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\type1\t1afm.h">
+ <Filter>freetype\type1</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\type1\t1driver.h">
+ <Filter>freetype\type1</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\type1\t1errors.h">
+ <Filter>freetype\type1</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\type1\t1gload.h">
+ <Filter>freetype\type1</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\type1\t1load.h">
+ <Filter>freetype\type1</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\type1\t1objs.h">
+ <Filter>freetype\type1</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\type1\t1parse.h">
+ <Filter>freetype\type1</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\type1\t1tokens.h">
+ <Filter>freetype\type1</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\type42\t42drivr.h">
+ <Filter>freetype\type42</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\type42\t42error.h">
+ <Filter>freetype\type42</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\type42\t42objs.h">
+ <Filter>freetype\type42</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\type42\t42parse.h">
+ <Filter>freetype\type42</Filter>
+ </ClInclude>
+ <ClInclude Include="..\freetype\src\type42\t42types.h">
+ <Filter>freetype\type42</Filter>
+ </ClInclude>
+ <ClInclude Include="..\devices\vector\doc_common.h">
+ <Filter>devices\vector</Filter>
+ </ClInclude>
</ItemGroup>
<ItemGroup>
<ResourceCompile Include="..\base\gspmdrv.rc">
@@ -8997,5 +10057,8 @@
<ResourceCompile Include="..\psi\gsos2.rc">
<Filter>psi %28.rc%29</Filter>
</ResourceCompile>
+ <ResourceCompile Include="..\freetype\src\base\ftver.rc">
+ <Filter>freetype\base</Filter>
+ </ResourceCompile>
</ItemGroup>
</Project>
diff --git a/windows/ghostscript_rt.vcxproj b/windows/ghostscript_rt.vcxproj
index c5f8a4f3..7589ac37 100644
--- a/windows/ghostscript_rt.vcxproj
+++ b/windows/ghostscript_rt.vcxproj
@@ -716,6 +716,7 @@
<ClCompile Include="..\base\gxblend.c" />
<ClCompile Include="..\base\gxblend1.c" />
<ClCompile Include="..\base\gdevdevn.c" />
+ <ClCompile Include="..\base\gsagl.c" />
<ClCompile Include="..\base\gscdevn.c" />
<ClCompile Include="..\base\gscie.c" />
<ClCompile Include="..\base\gsciemap.c" />
@@ -1456,7 +1457,6 @@
<ClCompile Include="..\devices\gdevxres.c" />
<ClCompile Include="..\devices\gxfcopy.c" />
<ClCompile Include="..\devices\minftrsz.c" />
- <ClCompile Include="..\devices\vector\gdevagl.c" />
<ClCompile Include="..\devices\vector\gdevlj56.c" />
<ClCompile Include="..\devices\vector\gdevpdf.c" />
<ClCompile Include="..\devices\vector\gdevpdfb.c" />
@@ -1669,6 +1669,7 @@
<ClInclude Include="..\base\gs_dll_call.h" />
<ClInclude Include="..\base\gs_mgl_e.h" />
<ClInclude Include="..\base\gs_mro_e.h" />
+ <ClInclude Include="..\base\gsagl.h" />
<ClInclude Include="..\base\gsalloc.h" />
<ClInclude Include="..\base\gsalpha.h" />
<ClInclude Include="..\base\gsargs.h" />
@@ -2174,7 +2175,6 @@
<ClInclude Include="..\devices\gxfcopy.h" />
<ClInclude Include="..\devices\minftrsz.h" />
<ClInclude Include="..\devices\vector\doc_common.h" />
- <ClInclude Include="..\devices\vector\gdevagl.h" />
<ClInclude Include="..\devices\vector\gdevpdfb.h" />
<ClInclude Include="..\devices\vector\gdevpdfc.h" />
<ClInclude Include="..\devices\vector\gdevpdfg.h" />